xrdp-0.9.5/000755 001751 001751 00000000000 13220731022 012412 5ustar00metameta000000 000000 xrdp-0.9.5/faq-compile.txt000644 001751 001751 00000002520 13125122133 015350 0ustar00metameta000000 000000 Compile FAQ Q. I get one of the following errors: - "security/pam_appl.h: File or directory doesn't exist" - "configure: error: please install libpam0g-dev or pam-devel" What is wrong? A. You need to install the pam development package. For Debian / Ubuntu this package is called libpam0g-dev. For Red Hat / SUSE this package is called pam-devel. Q. I get an error: "configure: error: please install libssl-dev or openssl-devel" A. You need to install the openssl development package. For Debian / Ubuntu this package is called libssl-dev. For Red Hat / Fedora this package is called openssl-devel. For SUSE / openSUSE this package is called libopenssl-devel. Q. I get one of the following errors: - "configure: error: please install libx11-dev or libX11-devel" - "configure: error: please install libx11-dev and libxfixes-dev or libXfixes-devel" A. You need to install the X11 and X11 Xfixes development package(s). For Debian: libx11-dev and libxfixes-dev. For Red Hat / SUSE: libX11-devel and libXfixes-devel. Q. I get an error: "rail.c:31:35: fatal error: X11/extensions/Xrandr.h: No such file or directory" A. You need to install the Xrandr development package. For Debian / Ubuntu this package is called libxrandr-dev. For SUSE / openSUSE this package is called libXrandr-devel. xrdp-0.9.5/keygen/000755 001751 001751 00000000000 13220731021 013673 5ustar00metameta000000 000000 xrdp-0.9.5/xrdp/000755 001751 001751 00000000000 13220731020 013365 5ustar00metameta000000 000000 xrdp-0.9.5/tests/000755 001751 001751 00000000000 13127114621 013562 5ustar00metameta000000 000000 xrdp-0.9.5/faq-general.txt000644 001751 001751 00000000743 13127114621 015347 0ustar00metameta000000 000000 General FAQ Q. What is RDP? A. RDP stands for Remote Desktop Protocol. It's the protocol used by Windows terminal servers to talk to the terminal server clients. Q. What is xrdp? A. xrdp, usually spelled in lower case, is as open source implementation of the RDP protocol. Q. I can't get xrdp to compile in Ubuntu. What can I do? A. See faq-compile.txt. Q. Can I use LDAP? A. Yes, xrdp uses PAM and thus can be configured to use LDAP for authentication. xrdp-0.9.5/neutrinordp/000755 001751 001751 00000000000 13220731016 014766 5ustar00metameta000000 000000 xrdp-0.9.5/NEWS.md000644 001751 001751 00000013535 13220727201 013523 0ustar00metameta000000 000000 # Release notes for xrdp v0.9.5 (2017/12/27) ## Security fixes * Fix local denial of service [CVE-2017-16927](http://cve.mitre.org/cgi-bin/cvename.cgi?name=CVE-2017-16927) #958 #979 ## New features * Add a new log level TRACE more verbose than DEBUG #835 #944 * SSH agent forwarding via RDP #867 #868 FreeRDP/FreeRDP#4122 * Support horizontal wheel properly #928 ## Bug fixes * Avoid use of hard-coded sesman port #895 * Workaround for corrupted display with Windows Server 2008 using NeutrinoRDP #869 * Fix glitch in audio redirection by AAC #910 #936 * Implement vsock support #930 #935 #948 * Avoid 100% CPU usage on SSL accept #956 ## Other changes * Add US Dvorak keyboard #929 * Suppress some misleading logs #964 * Add Finnish keyboard #972 * Add more user-friendlier description about Xorg config #974 * Renew pulseaudio document #984 #985 * Lots of cleanups and refactoring ## Known issues * Audio redirection by MP3 codec doesn't sound with some client, use AAC instead #965 ----------------------- # Release notes for xrdp v0.9.4 (2017/09/28) ## New features * Accept prefill credentials in base64 form #153 #811 * Indroduce AAC encoder to audio redirection (requires Windows 10 client) ## Bugfixes * Fix ocasional SEGV in drive redirection #838 * Fix client's IP addresses in xrdp-sesman.log are always logged as `0.0.0.0` #878 #882 * Fix `ls_background_image` didn't accept full path #776 #853 * Fix misuse of hidelogwindow #414 #876 * Fix WTSVirtualChannelWrite return code #859 * Fix no longer needed socket files remained in the socket dir #812 #831 * Make creating socket path a bit more robust #823 ## Other changes * Add Belgian keyboard #858 * Add a PAM file for FreeBSD #824 * Several refactorings and cosmetic changes ## Known issues * Windows 10 (1703) shows black blank screen in RemoteFX mode * This issue is already fixed at Insider Preview build 16273 ----------------------- # Release notes for xrdp v0.9.3.1 (2017/08/16) This release fixes a trivial packaging issue #848 occurred in v0.9.3. The issue only affects systemd systems. This release is principally for distro packagers or users who compile & install xrdp from source. Users who running xrdp on these systems don't need to upgrade from v0.9.3 to v0.9.3.1. * Linux systems without systemd * non-Linux systems such as BSD operating systems ----------------------- # Release notes for xrdp v0.9.3 (2017/07/15) ## New features * Log user-friendly messages when certificate/privkey is inaccessible ## Bugfixes * Now sesman sets mandatory LOGNAME environment variable #725 * Now sesman ensures socket directory present #801 * Exit with failure status if port already in use #644 * Eliminate some hard coded paths * Fix glitches with IPv4 struct initialization #803 * Fix some keyboard layout integration (UK, Spanish) * Fix handle OS when IPv6 disabled #714 * Fix issues around systemd session #778 * Fix protocol error when 32 bit color and non RemoteFX session #737 #804 * Fix sesadmin shows error when no sessions #797 * Fix TLS spins 100% CPU #728 * Fix Xvnc backend disconnects when some data copied to clipboard #755 * Pick up the first section if given section(domain) doesn't match anything #750 ## Other changes * Change xrdp-chansrv log path to include display number * Optimize startwm.sh for SUSE * Several cleanups and optimizations ## Known issues * Windows 10 (1703) shows black blank screen in RemoteFX mode ----------------------- # Release notes for xrdp v0.9.2 (2017/03/30) ## New features * RemoteFX codec support is now enabled by default. * Bitmap updates support is now enabled by default. * TLS ciphers suites and version is now logged. * Connected computer name is now logged. * Switched to Xorg (xorgxrdp) as the default backend now. * Miscellaneous RemoteFX codec mode improvements. * Socket directory is configurable at the compile time. ## Bugfixes * Parallels client for MacOS / iOS can now connect (audio redirection must be disabled on client or xrdp server though). * MS RDP client for iOS can now connect using TLS security layer. * MS RDP client for Android can now connect to xrdp. * Large resolutions (4K) can be used with RemoteFX graphics. * Multiple RemoteApps can be opened throguh NeutrinoRDP proxy. * tls_ciphers in xrdp.ini is not limited to 63 chars anymore, it's variable-length. * Fixed an issue where tls_ciphers were ignored and rdp security layer could be used instead. * Kill disconnected sessions feature is working with Xorg (xorgxrdp) backend. * Miscellaneous code cleanup and memory issues fixes. ----------------------- # Release notes for xrdp v0.9.1 (2016/12/21) ## New features * New xorgxrdp backend using existing Xorg with additional modules * Improvements to X11rdp backend * Support for IPv6 (disabled by default) * Initial support for RemoteFX Codec (disabled by default) * Support for TLS security layer (preferred over RDP layer if supported by the client) * Support for disabling deprecated SSLv3 protocol and for selecting custom cipher suites in xrdp.ini * Support for bidirectional fastpath (enabled in both directions by default) * Support clients that don't support drawing orders, such as MS RDP client for Android, ChromeRDP (disabled by default) * More configurable login screen * Support for new virtual channels: * rdpdr: device redirection * rdpsnd: audio output * cliprdr: clipboard * xrdpvr: xrdp video redirection channel (can be used along with NeutrinoRDP client) * Support for disabling virtual channels globally or by session type * Allow to specify the path for backends (Xorg, X11rdp, Xvnc) * Added files for systemd support * Multi-monitor support * xrdp-chansrv stroes logs in `${XDG_DATA_HOME}/xrdp` now ## Security fixes * User's password could be recovered from the Xvnc password file * X11 authentication was not used xrdp-0.9.5/instfiles/000755 001751 001751 00000000000 13220731022 014412 5ustar00metameta000000 000000 xrdp-0.9.5/ltmain.sh000644 001751 001751 00001170771 13220730762 014262 0ustar00metameta000000 000000 #! /bin/sh ## DO NOT EDIT - This file generated from ./build-aux/ltmain.in ## by inline-source v2014-01-03.01 # libtool (GNU libtool) 2.4.6 # Provide generalized library-building support services. # Written by Gordon Matzigkeit , 1996 # Copyright (C) 1996-2015 Free Software Foundation, Inc. # This is free software; see the source for copying conditions. There is NO # warranty; not even for MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. # GNU Libtool 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 2 of the License, or # (at your option) any later version. # # As a special exception to the GNU General Public License, # if you distribute this file as part of a program or library that # is built using GNU Libtool, you may include this file under the # same distribution terms that you use for the rest of that program. # # GNU Libtool 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. # # You should have received a copy of the GNU General Public License # along with this program. If not, see . PROGRAM=libtool PACKAGE=libtool VERSION=2.4.6 package_revision=2.4.6 ## ------ ## ## Usage. ## ## ------ ## # Run './libtool --help' for help with using this script from the # command line. ## ------------------------------- ## ## User overridable command paths. ## ## ------------------------------- ## # After configure completes, it has a better idea of some of the # shell tools we need than the defaults used by the functions shared # with bootstrap, so set those here where they can still be over- # ridden by the user, but otherwise take precedence. : ${AUTOCONF="autoconf"} : ${AUTOMAKE="automake"} ## -------------------------- ## ## Source external libraries. ## ## -------------------------- ## # Much of our low-level functionality needs to be sourced from external # libraries, which are installed to $pkgauxdir. # Set a version string for this script. scriptversion=2015-01-20.17; # UTC # General shell script boiler plate, and helper functions. # Written by Gary V. Vaughan, 2004 # Copyright (C) 2004-2015 Free Software Foundation, Inc. # This is free software; see the source for copying conditions. There is NO # warranty; not even for MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. # 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. # As a special exception to the GNU General Public License, if you distribute # this file as part of a program or library that is built using GNU Libtool, # you may include this file under the same distribution terms that you use # for the rest of that program. # This program is distributed in the hope that it will be useful, # but WITHOUT ANY WARRANTY; without even the implied warranty of # MERCHANTABILITY or FITNES FOR A PARTICULAR PURPOSE. See the GNU # General Public License for more details. # You should have received a copy of the GNU General Public License # along with this program. If not, see . # Please report bugs or propose patches to gary@gnu.org. ## ------ ## ## Usage. ## ## ------ ## # Evaluate this file near the top of your script to gain access to # the functions and variables defined here: # # . `echo "$0" | ${SED-sed} 's|[^/]*$||'`/build-aux/funclib.sh # # If you need to override any of the default environment variable # settings, do that before evaluating this file. ## -------------------- ## ## Shell normalisation. ## ## -------------------- ## # Some shells need a little help to be as Bourne compatible as possible. # Before doing anything else, make sure all that help has been provided! DUALCASE=1; export DUALCASE # for MKS sh if test -n "${ZSH_VERSION+set}" && (emulate sh) >/dev/null 2>&1; then : emulate sh NULLCMD=: # Pre-4.2 versions of Zsh do word splitting on ${1+"$@"}, which # is contrary to our usage. Disable this feature. alias -g '${1+"$@"}'='"$@"' setopt NO_GLOB_SUBST else case `(set -o) 2>/dev/null` in *posix*) set -o posix ;; esac fi # NLS nuisances: We save the old values in case they are required later. _G_user_locale= _G_safe_locale= for _G_var in LANG LANGUAGE LC_ALL LC_CTYPE LC_COLLATE LC_MESSAGES do eval "if test set = \"\${$_G_var+set}\"; then save_$_G_var=\$$_G_var $_G_var=C export $_G_var _G_user_locale=\"$_G_var=\\\$save_\$_G_var; \$_G_user_locale\" _G_safe_locale=\"$_G_var=C; \$_G_safe_locale\" fi" done # CDPATH. (unset CDPATH) >/dev/null 2>&1 && unset CDPATH # Make sure IFS has a sensible default sp=' ' nl=' ' IFS="$sp $nl" # There are apparently some retarded systems that use ';' as a PATH separator! if test "${PATH_SEPARATOR+set}" != set; then PATH_SEPARATOR=: (PATH='/bin;/bin'; FPATH=$PATH; sh -c :) >/dev/null 2>&1 && { (PATH='/bin:/bin'; FPATH=$PATH; sh -c :) >/dev/null 2>&1 || PATH_SEPARATOR=';' } fi ## ------------------------- ## ## Locate command utilities. ## ## ------------------------- ## # func_executable_p FILE # ---------------------- # Check that FILE is an executable regular file. func_executable_p () { test -f "$1" && test -x "$1" } # func_path_progs PROGS_LIST CHECK_FUNC [PATH] # -------------------------------------------- # Search for either a program that responds to --version with output # containing "GNU", or else returned by CHECK_FUNC otherwise, by # trying all the directories in PATH with each of the elements of # PROGS_LIST. # # CHECK_FUNC should accept the path to a candidate program, and # set $func_check_prog_result if it truncates its output less than # $_G_path_prog_max characters. func_path_progs () { _G_progs_list=$1 _G_check_func=$2 _G_PATH=${3-"$PATH"} _G_path_prog_max=0 _G_path_prog_found=false _G_save_IFS=$IFS; IFS=${PATH_SEPARATOR-:} for _G_dir in $_G_PATH; do IFS=$_G_save_IFS test -z "$_G_dir" && _G_dir=. for _G_prog_name in $_G_progs_list; do for _exeext in '' .EXE; do _G_path_prog=$_G_dir/$_G_prog_name$_exeext func_executable_p "$_G_path_prog" || continue case `"$_G_path_prog" --version 2>&1` in *GNU*) func_path_progs_result=$_G_path_prog _G_path_prog_found=: ;; *) $_G_check_func $_G_path_prog func_path_progs_result=$func_check_prog_result ;; esac $_G_path_prog_found && break 3 done done done IFS=$_G_save_IFS test -z "$func_path_progs_result" && { echo "no acceptable sed could be found in \$PATH" >&2 exit 1 } } # We want to be able to use the functions in this file before configure # has figured out where the best binaries are kept, which means we have # to search for them ourselves - except when the results are already set # where we skip the searches. # Unless the user overrides by setting SED, search the path for either GNU # sed, or the sed that truncates its output the least. test -z "$SED" && { _G_sed_script=s/aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa/bbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbb/ for _G_i in 1 2 3 4 5 6 7; do _G_sed_script=$_G_sed_script$nl$_G_sed_script done echo "$_G_sed_script" 2>/dev/null | sed 99q >conftest.sed _G_sed_script= func_check_prog_sed () { _G_path_prog=$1 _G_count=0 printf 0123456789 >conftest.in while : do cat conftest.in conftest.in >conftest.tmp mv conftest.tmp conftest.in cp conftest.in conftest.nl echo '' >> conftest.nl "$_G_path_prog" -f conftest.sed conftest.out 2>/dev/null || break diff conftest.out conftest.nl >/dev/null 2>&1 || break _G_count=`expr $_G_count + 1` if test "$_G_count" -gt "$_G_path_prog_max"; then # Best one so far, save it but keep looking for a better one func_check_prog_result=$_G_path_prog _G_path_prog_max=$_G_count fi # 10*(2^10) chars as input seems more than enough test 10 -lt "$_G_count" && break done rm -f conftest.in conftest.tmp conftest.nl conftest.out } func_path_progs "sed gsed" func_check_prog_sed $PATH:/usr/xpg4/bin rm -f conftest.sed SED=$func_path_progs_result } # Unless the user overrides by setting GREP, search the path for either GNU # grep, or the grep that truncates its output the least. test -z "$GREP" && { func_check_prog_grep () { _G_path_prog=$1 _G_count=0 _G_path_prog_max=0 printf 0123456789 >conftest.in while : do cat conftest.in conftest.in >conftest.tmp mv conftest.tmp conftest.in cp conftest.in conftest.nl echo 'GREP' >> conftest.nl "$_G_path_prog" -e 'GREP$' -e '-(cannot match)-' conftest.out 2>/dev/null || break diff conftest.out conftest.nl >/dev/null 2>&1 || break _G_count=`expr $_G_count + 1` if test "$_G_count" -gt "$_G_path_prog_max"; then # Best one so far, save it but keep looking for a better one func_check_prog_result=$_G_path_prog _G_path_prog_max=$_G_count fi # 10*(2^10) chars as input seems more than enough test 10 -lt "$_G_count" && break done rm -f conftest.in conftest.tmp conftest.nl conftest.out } func_path_progs "grep ggrep" func_check_prog_grep $PATH:/usr/xpg4/bin GREP=$func_path_progs_result } ## ------------------------------- ## ## User overridable command paths. ## ## ------------------------------- ## # All uppercase variable names are used for environment variables. These # variables can be overridden by the user before calling a script that # uses them if a suitable command of that name is not already available # in the command search PATH. : ${CP="cp -f"} : ${ECHO="printf %s\n"} : ${EGREP="$GREP -E"} : ${FGREP="$GREP -F"} : ${LN_S="ln -s"} : ${MAKE="make"} : ${MKDIR="mkdir"} : ${MV="mv -f"} : ${RM="rm -f"} : ${SHELL="${CONFIG_SHELL-/bin/sh}"} ## -------------------- ## ## Useful sed snippets. ## ## -------------------- ## sed_dirname='s|/[^/]*$||' sed_basename='s|^.*/||' # Sed substitution that helps us do robust quoting. It backslashifies # metacharacters that are still active within double-quoted strings. sed_quote_subst='s|\([`"$\\]\)|\\\1|g' # Same as above, but do not quote variable references. sed_double_quote_subst='s/\(["`\\]\)/\\\1/g' # Sed substitution that turns a string into a regex matching for the # string literally. sed_make_literal_regex='s|[].[^$\\*\/]|\\&|g' # Sed substitution that converts a w32 file name or path # that contains forward slashes, into one that contains # (escaped) backslashes. A very naive implementation. sed_naive_backslashify='s|\\\\*|\\|g;s|/|\\|g;s|\\|\\\\|g' # Re-'\' parameter expansions in output of sed_double_quote_subst that # were '\'-ed in input to the same. If an odd number of '\' preceded a # '$' in input to sed_double_quote_subst, that '$' was protected from # expansion. Since each input '\' is now two '\'s, look for any number # of runs of four '\'s followed by two '\'s and then a '$'. '\' that '$'. _G_bs='\\' _G_bs2='\\\\' _G_bs4='\\\\\\\\' _G_dollar='\$' sed_double_backslash="\ s/$_G_bs4/&\\ /g s/^$_G_bs2$_G_dollar/$_G_bs&/ s/\\([^$_G_bs]\\)$_G_bs2$_G_dollar/\\1$_G_bs2$_G_bs$_G_dollar/g s/\n//g" ## ----------------- ## ## Global variables. ## ## ----------------- ## # Except for the global variables explicitly listed below, the following # functions in the '^func_' namespace, and the '^require_' namespace # variables initialised in the 'Resource management' section, sourcing # this file will not pollute your global namespace with anything # else. There's no portable way to scope variables in Bourne shell # though, so actually running these functions will sometimes place # results into a variable named after the function, and often use # temporary variables in the '^_G_' namespace. If you are careful to # avoid using those namespaces casually in your sourcing script, things # should continue to work as you expect. And, of course, you can freely # overwrite any of the functions or variables defined here before # calling anything to customize them. EXIT_SUCCESS=0 EXIT_FAILURE=1 EXIT_MISMATCH=63 # $? = 63 is used to indicate version mismatch to missing. EXIT_SKIP=77 # $? = 77 is used to indicate a skipped test to automake. # Allow overriding, eg assuming that you follow the convention of # putting '$debug_cmd' at the start of all your functions, you can get # bash to show function call trace with: # # debug_cmd='eval echo "${FUNCNAME[0]} $*" >&2' bash your-script-name debug_cmd=${debug_cmd-":"} exit_cmd=: # By convention, finish your script with: # # exit $exit_status # # so that you can set exit_status to non-zero if you want to indicate # something went wrong during execution without actually bailing out at # the point of failure. exit_status=$EXIT_SUCCESS # Work around backward compatibility issue on IRIX 6.5. On IRIX 6.4+, sh # is ksh but when the shell is invoked as "sh" and the current value of # the _XPG environment variable is not equal to 1 (one), the special # positional parameter $0, within a function call, is the name of the # function. progpath=$0 # The name of this program. progname=`$ECHO "$progpath" |$SED "$sed_basename"` # Make sure we have an absolute progpath for reexecution: case $progpath in [\\/]*|[A-Za-z]:\\*) ;; *[\\/]*) progdir=`$ECHO "$progpath" |$SED "$sed_dirname"` progdir=`cd "$progdir" && pwd` progpath=$progdir/$progname ;; *) _G_IFS=$IFS IFS=${PATH_SEPARATOR-:} for progdir in $PATH; do IFS=$_G_IFS test -x "$progdir/$progname" && break done IFS=$_G_IFS test -n "$progdir" || progdir=`pwd` progpath=$progdir/$progname ;; esac ## ----------------- ## ## Standard options. ## ## ----------------- ## # The following options affect the operation of the functions defined # below, and should be set appropriately depending on run-time para- # meters passed on the command line. opt_dry_run=false opt_quiet=false opt_verbose=false # Categories 'all' and 'none' are always available. Append any others # you will pass as the first argument to func_warning from your own # code. warning_categories= # By default, display warnings according to 'opt_warning_types'. Set # 'warning_func' to ':' to elide all warnings, or func_fatal_error to # treat the next displayed warning as a fatal error. warning_func=func_warn_and_continue # Set to 'all' to display all warnings, 'none' to suppress all # warnings, or a space delimited list of some subset of # 'warning_categories' to display only the listed warnings. opt_warning_types=all ## -------------------- ## ## Resource management. ## ## -------------------- ## # This section contains definitions for functions that each ensure a # particular resource (a file, or a non-empty configuration variable for # example) is available, and if appropriate to extract default values # from pertinent package files. Call them using their associated # 'require_*' variable to ensure that they are executed, at most, once. # # It's entirely deliberate that calling these functions can set # variables that don't obey the namespace limitations obeyed by the rest # of this file, in order that that they be as useful as possible to # callers. # require_term_colors # ------------------- # Allow display of bold text on terminals that support it. require_term_colors=func_require_term_colors func_require_term_colors () { $debug_cmd test -t 1 && { # COLORTERM and USE_ANSI_COLORS environment variables take # precedence, because most terminfo databases neglect to describe # whether color sequences are supported. test -n "${COLORTERM+set}" && : ${USE_ANSI_COLORS="1"} if test 1 = "$USE_ANSI_COLORS"; then # Standard ANSI escape sequences tc_reset='' tc_bold=''; tc_standout='' tc_red=''; tc_green='' tc_blue=''; tc_cyan='' else # Otherwise trust the terminfo database after all. test -n "`tput sgr0 2>/dev/null`" && { tc_reset=`tput sgr0` test -n "`tput bold 2>/dev/null`" && tc_bold=`tput bold` tc_standout=$tc_bold test -n "`tput smso 2>/dev/null`" && tc_standout=`tput smso` test -n "`tput setaf 1 2>/dev/null`" && tc_red=`tput setaf 1` test -n "`tput setaf 2 2>/dev/null`" && tc_green=`tput setaf 2` test -n "`tput setaf 4 2>/dev/null`" && tc_blue=`tput setaf 4` test -n "`tput setaf 5 2>/dev/null`" && tc_cyan=`tput setaf 5` } fi } require_term_colors=: } ## ----------------- ## ## Function library. ## ## ----------------- ## # This section contains a variety of useful functions to call in your # scripts. Take note of the portable wrappers for features provided by # some modern shells, which will fall back to slower equivalents on # less featureful shells. # func_append VAR VALUE # --------------------- # Append VALUE onto the existing contents of VAR. # We should try to minimise forks, especially on Windows where they are # unreasonably slow, so skip the feature probes when bash or zsh are # being used: if test set = "${BASH_VERSION+set}${ZSH_VERSION+set}"; then : ${_G_HAVE_ARITH_OP="yes"} : ${_G_HAVE_XSI_OPS="yes"} # The += operator was introduced in bash 3.1 case $BASH_VERSION in [12].* | 3.0 | 3.0*) ;; *) : ${_G_HAVE_PLUSEQ_OP="yes"} ;; esac fi # _G_HAVE_PLUSEQ_OP # Can be empty, in which case the shell is probed, "yes" if += is # useable or anything else if it does not work. test -z "$_G_HAVE_PLUSEQ_OP" \ && (eval 'x=a; x+=" b"; test "a b" = "$x"') 2>/dev/null \ && _G_HAVE_PLUSEQ_OP=yes if test yes = "$_G_HAVE_PLUSEQ_OP" then # This is an XSI compatible shell, allowing a faster implementation... eval 'func_append () { $debug_cmd eval "$1+=\$2" }' else # ...otherwise fall back to using expr, which is often a shell builtin. func_append () { $debug_cmd eval "$1=\$$1\$2" } fi # func_append_quoted VAR VALUE # ---------------------------- # Quote VALUE and append to the end of shell variable VAR, separated # by a space. if test yes = "$_G_HAVE_PLUSEQ_OP"; then eval 'func_append_quoted () { $debug_cmd func_quote_for_eval "$2" eval "$1+=\\ \$func_quote_for_eval_result" }' else func_append_quoted () { $debug_cmd func_quote_for_eval "$2" eval "$1=\$$1\\ \$func_quote_for_eval_result" } fi # func_append_uniq VAR VALUE # -------------------------- # Append unique VALUE onto the existing contents of VAR, assuming # entries are delimited by the first character of VALUE. For example: # # func_append_uniq options " --another-option option-argument" # # will only append to $options if " --another-option option-argument " # is not already present somewhere in $options already (note spaces at # each end implied by leading space in second argument). func_append_uniq () { $debug_cmd eval _G_current_value='`$ECHO $'$1'`' _G_delim=`expr "$2" : '\(.\)'` case $_G_delim$_G_current_value$_G_delim in *"$2$_G_delim"*) ;; *) func_append "$@" ;; esac } # func_arith TERM... # ------------------ # Set func_arith_result to the result of evaluating TERMs. test -z "$_G_HAVE_ARITH_OP" \ && (eval 'test 2 = $(( 1 + 1 ))') 2>/dev/null \ && _G_HAVE_ARITH_OP=yes if test yes = "$_G_HAVE_ARITH_OP"; then eval 'func_arith () { $debug_cmd func_arith_result=$(( $* )) }' else func_arith () { $debug_cmd func_arith_result=`expr "$@"` } fi # func_basename FILE # ------------------ # Set func_basename_result to FILE with everything up to and including # the last / stripped. if test yes = "$_G_HAVE_XSI_OPS"; then # If this shell supports suffix pattern removal, then use it to avoid # forking. Hide the definitions single quotes in case the shell chokes # on unsupported syntax... _b='func_basename_result=${1##*/}' _d='case $1 in */*) func_dirname_result=${1%/*}$2 ;; * ) func_dirname_result=$3 ;; esac' else # ...otherwise fall back to using sed. _b='func_basename_result=`$ECHO "$1" |$SED "$sed_basename"`' _d='func_dirname_result=`$ECHO "$1" |$SED "$sed_dirname"` if test "X$func_dirname_result" = "X$1"; then func_dirname_result=$3 else func_append func_dirname_result "$2" fi' fi eval 'func_basename () { $debug_cmd '"$_b"' }' # func_dirname FILE APPEND NONDIR_REPLACEMENT # ------------------------------------------- # Compute the dirname of FILE. If nonempty, add APPEND to the result, # otherwise set result to NONDIR_REPLACEMENT. eval 'func_dirname () { $debug_cmd '"$_d"' }' # func_dirname_and_basename FILE APPEND NONDIR_REPLACEMENT # -------------------------------------------------------- # Perform func_basename and func_dirname in a single function # call: # dirname: Compute the dirname of FILE. If nonempty, # add APPEND to the result, otherwise set result # to NONDIR_REPLACEMENT. # value returned in "$func_dirname_result" # basename: Compute filename of FILE. # value retuned in "$func_basename_result" # For efficiency, we do not delegate to the functions above but instead # duplicate the functionality here. eval 'func_dirname_and_basename () { $debug_cmd '"$_b"' '"$_d"' }' # func_echo ARG... # ---------------- # Echo program name prefixed message. func_echo () { $debug_cmd _G_message=$* func_echo_IFS=$IFS IFS=$nl for _G_line in $_G_message; do IFS=$func_echo_IFS $ECHO "$progname: $_G_line" done IFS=$func_echo_IFS } # func_echo_all ARG... # -------------------- # Invoke $ECHO with all args, space-separated. func_echo_all () { $ECHO "$*" } # func_echo_infix_1 INFIX ARG... # ------------------------------ # Echo program name, followed by INFIX on the first line, with any # additional lines not showing INFIX. func_echo_infix_1 () { $debug_cmd $require_term_colors _G_infix=$1; shift _G_indent=$_G_infix _G_prefix="$progname: $_G_infix: " _G_message=$* # Strip color escape sequences before counting printable length for _G_tc in "$tc_reset" "$tc_bold" "$tc_standout" "$tc_red" "$tc_green" "$tc_blue" "$tc_cyan" do test -n "$_G_tc" && { _G_esc_tc=`$ECHO "$_G_tc" | $SED "$sed_make_literal_regex"` _G_indent=`$ECHO "$_G_indent" | $SED "s|$_G_esc_tc||g"` } done _G_indent="$progname: "`echo "$_G_indent" | $SED 's|.| |g'`" " ## exclude from sc_prohibit_nested_quotes func_echo_infix_1_IFS=$IFS IFS=$nl for _G_line in $_G_message; do IFS=$func_echo_infix_1_IFS $ECHO "$_G_prefix$tc_bold$_G_line$tc_reset" >&2 _G_prefix=$_G_indent done IFS=$func_echo_infix_1_IFS } # func_error ARG... # ----------------- # Echo program name prefixed message to standard error. func_error () { $debug_cmd $require_term_colors func_echo_infix_1 " $tc_standout${tc_red}error$tc_reset" "$*" >&2 } # func_fatal_error ARG... # ----------------------- # Echo program name prefixed message to standard error, and exit. func_fatal_error () { $debug_cmd func_error "$*" exit $EXIT_FAILURE } # func_grep EXPRESSION FILENAME # ----------------------------- # Check whether EXPRESSION matches any line of FILENAME, without output. func_grep () { $debug_cmd $GREP "$1" "$2" >/dev/null 2>&1 } # func_len STRING # --------------- # Set func_len_result to the length of STRING. STRING may not # start with a hyphen. test -z "$_G_HAVE_XSI_OPS" \ && (eval 'x=a/b/c; test 5aa/bb/cc = "${#x}${x%%/*}${x%/*}${x#*/}${x##*/}"') 2>/dev/null \ && _G_HAVE_XSI_OPS=yes if test yes = "$_G_HAVE_XSI_OPS"; then eval 'func_len () { $debug_cmd func_len_result=${#1} }' else func_len () { $debug_cmd func_len_result=`expr "$1" : ".*" 2>/dev/null || echo $max_cmd_len` } fi # func_mkdir_p DIRECTORY-PATH # --------------------------- # Make sure the entire path to DIRECTORY-PATH is available. func_mkdir_p () { $debug_cmd _G_directory_path=$1 _G_dir_list= if test -n "$_G_directory_path" && test : != "$opt_dry_run"; then # Protect directory names starting with '-' case $_G_directory_path in -*) _G_directory_path=./$_G_directory_path ;; esac # While some portion of DIR does not yet exist... while test ! -d "$_G_directory_path"; do # ...make a list in topmost first order. Use a colon delimited # list incase some portion of path contains whitespace. _G_dir_list=$_G_directory_path:$_G_dir_list # If the last portion added has no slash in it, the list is done case $_G_directory_path in */*) ;; *) break ;; esac # ...otherwise throw away the child directory and loop _G_directory_path=`$ECHO "$_G_directory_path" | $SED -e "$sed_dirname"` done _G_dir_list=`$ECHO "$_G_dir_list" | $SED 's|:*$||'` func_mkdir_p_IFS=$IFS; IFS=: for _G_dir in $_G_dir_list; do IFS=$func_mkdir_p_IFS # mkdir can fail with a 'File exist' error if two processes # try to create one of the directories concurrently. Don't # stop in that case! $MKDIR "$_G_dir" 2>/dev/null || : done IFS=$func_mkdir_p_IFS # Bail out if we (or some other process) failed to create a directory. test -d "$_G_directory_path" || \ func_fatal_error "Failed to create '$1'" fi } # func_mktempdir [BASENAME] # ------------------------- # Make a temporary directory that won't clash with other running # libtool processes, and avoids race conditions if possible. If # given, BASENAME is the basename for that directory. func_mktempdir () { $debug_cmd _G_template=${TMPDIR-/tmp}/${1-$progname} if test : = "$opt_dry_run"; then # Return a directory name, but don't create it in dry-run mode _G_tmpdir=$_G_template-$$ else # If mktemp works, use that first and foremost _G_tmpdir=`mktemp -d "$_G_template-XXXXXXXX" 2>/dev/null` if test ! -d "$_G_tmpdir"; then # Failing that, at least try and use $RANDOM to avoid a race _G_tmpdir=$_G_template-${RANDOM-0}$$ func_mktempdir_umask=`umask` umask 0077 $MKDIR "$_G_tmpdir" umask $func_mktempdir_umask fi # If we're not in dry-run mode, bomb out on failure test -d "$_G_tmpdir" || \ func_fatal_error "cannot create temporary directory '$_G_tmpdir'" fi $ECHO "$_G_tmpdir" } # func_normal_abspath PATH # ------------------------ # Remove doubled-up and trailing slashes, "." path components, # and cancel out any ".." path components in PATH after making # it an absolute path. func_normal_abspath () { $debug_cmd # These SED scripts presuppose an absolute path with a trailing slash. _G_pathcar='s|^/\([^/]*\).*$|\1|' _G_pathcdr='s|^/[^/]*||' _G_removedotparts=':dotsl s|/\./|/|g t dotsl s|/\.$|/|' _G_collapseslashes='s|/\{1,\}|/|g' _G_finalslash='s|/*$|/|' # Start from root dir and reassemble the path. func_normal_abspath_result= func_normal_abspath_tpath=$1 func_normal_abspath_altnamespace= case $func_normal_abspath_tpath in "") # Empty path, that just means $cwd. func_stripname '' '/' "`pwd`" func_normal_abspath_result=$func_stripname_result return ;; # The next three entries are used to spot a run of precisely # two leading slashes without using negated character classes; # we take advantage of case's first-match behaviour. ///*) # Unusual form of absolute path, do nothing. ;; //*) # Not necessarily an ordinary path; POSIX reserves leading '//' # and for example Cygwin uses it to access remote file shares # over CIFS/SMB, so we conserve a leading double slash if found. func_normal_abspath_altnamespace=/ ;; /*) # Absolute path, do nothing. ;; *) # Relative path, prepend $cwd. func_normal_abspath_tpath=`pwd`/$func_normal_abspath_tpath ;; esac # Cancel out all the simple stuff to save iterations. We also want # the path to end with a slash for ease of parsing, so make sure # there is one (and only one) here. func_normal_abspath_tpath=`$ECHO "$func_normal_abspath_tpath" | $SED \ -e "$_G_removedotparts" -e "$_G_collapseslashes" -e "$_G_finalslash"` while :; do # Processed it all yet? if test / = "$func_normal_abspath_tpath"; then # If we ascended to the root using ".." the result may be empty now. if test -z "$func_normal_abspath_result"; then func_normal_abspath_result=/ fi break fi func_normal_abspath_tcomponent=`$ECHO "$func_normal_abspath_tpath" | $SED \ -e "$_G_pathcar"` func_normal_abspath_tpath=`$ECHO "$func_normal_abspath_tpath" | $SED \ -e "$_G_pathcdr"` # Figure out what to do with it case $func_normal_abspath_tcomponent in "") # Trailing empty path component, ignore it. ;; ..) # Parent dir; strip last assembled component from result. func_dirname "$func_normal_abspath_result" func_normal_abspath_result=$func_dirname_result ;; *) # Actual path component, append it. func_append func_normal_abspath_result "/$func_normal_abspath_tcomponent" ;; esac done # Restore leading double-slash if one was found on entry. func_normal_abspath_result=$func_normal_abspath_altnamespace$func_normal_abspath_result } # func_notquiet ARG... # -------------------- # Echo program name prefixed message only when not in quiet mode. func_notquiet () { $debug_cmd $opt_quiet || func_echo ${1+"$@"} # A bug in bash halts the script if the last line of a function # fails when set -e is in force, so we need another command to # work around that: : } # func_relative_path SRCDIR DSTDIR # -------------------------------- # Set func_relative_path_result to the relative path from SRCDIR to DSTDIR. func_relative_path () { $debug_cmd func_relative_path_result= func_normal_abspath "$1" func_relative_path_tlibdir=$func_normal_abspath_result func_normal_abspath "$2" func_relative_path_tbindir=$func_normal_abspath_result # Ascend the tree starting from libdir while :; do # check if we have found a prefix of bindir case $func_relative_path_tbindir in $func_relative_path_tlibdir) # found an exact match func_relative_path_tcancelled= break ;; $func_relative_path_tlibdir*) # found a matching prefix func_stripname "$func_relative_path_tlibdir" '' "$func_relative_path_tbindir" func_relative_path_tcancelled=$func_stripname_result if test -z "$func_relative_path_result"; then func_relative_path_result=. fi break ;; *) func_dirname $func_relative_path_tlibdir func_relative_path_tlibdir=$func_dirname_result if test -z "$func_relative_path_tlibdir"; then # Have to descend all the way to the root! func_relative_path_result=../$func_relative_path_result func_relative_path_tcancelled=$func_relative_path_tbindir break fi func_relative_path_result=../$func_relative_path_result ;; esac done # Now calculate path; take care to avoid doubling-up slashes. func_stripname '' '/' "$func_relative_path_result" func_relative_path_result=$func_stripname_result func_stripname '/' '/' "$func_relative_path_tcancelled" if test -n "$func_stripname_result"; then func_append func_relative_path_result "/$func_stripname_result" fi # Normalisation. If bindir is libdir, return '.' else relative path. if test -n "$func_relative_path_result"; then func_stripname './' '' "$func_relative_path_result" func_relative_path_result=$func_stripname_result fi test -n "$func_relative_path_result" || func_relative_path_result=. : } # func_quote_for_eval ARG... # -------------------------- # Aesthetically quote ARGs to be evaled later. # This function returns two values: # i) func_quote_for_eval_result # double-quoted, suitable for a subsequent eval # ii) func_quote_for_eval_unquoted_result # has all characters that are still active within double # quotes backslashified. func_quote_for_eval () { $debug_cmd func_quote_for_eval_unquoted_result= func_quote_for_eval_result= while test 0 -lt $#; do case $1 in *[\\\`\"\$]*) _G_unquoted_arg=`printf '%s\n' "$1" |$SED "$sed_quote_subst"` ;; *) _G_unquoted_arg=$1 ;; esac if test -n "$func_quote_for_eval_unquoted_result"; then func_append func_quote_for_eval_unquoted_result " $_G_unquoted_arg" else func_append func_quote_for_eval_unquoted_result "$_G_unquoted_arg" fi case $_G_unquoted_arg in # Double-quote args containing shell metacharacters to delay # word splitting, command substitution and variable expansion # for a subsequent eval. # Many Bourne shells cannot handle close brackets correctly # in scan sets, so we specify it separately. *[\[\~\#\^\&\*\(\)\{\}\|\;\<\>\?\'\ \ ]*|*]*|"") _G_quoted_arg=\"$_G_unquoted_arg\" ;; *) _G_quoted_arg=$_G_unquoted_arg ;; esac if test -n "$func_quote_for_eval_result"; then func_append func_quote_for_eval_result " $_G_quoted_arg" else func_append func_quote_for_eval_result "$_G_quoted_arg" fi shift done } # func_quote_for_expand ARG # ------------------------- # Aesthetically quote ARG to be evaled later; same as above, # but do not quote variable references. func_quote_for_expand () { $debug_cmd case $1 in *[\\\`\"]*) _G_arg=`$ECHO "$1" | $SED \ -e "$sed_double_quote_subst" -e "$sed_double_backslash"` ;; *) _G_arg=$1 ;; esac case $_G_arg in # Double-quote args containing shell metacharacters to delay # word splitting and command substitution for a subsequent eval. # Many Bourne shells cannot handle close brackets correctly # in scan sets, so we specify it separately. *[\[\~\#\^\&\*\(\)\{\}\|\;\<\>\?\'\ \ ]*|*]*|"") _G_arg=\"$_G_arg\" ;; esac func_quote_for_expand_result=$_G_arg } # func_stripname PREFIX SUFFIX NAME # --------------------------------- # strip PREFIX and SUFFIX from NAME, and store in func_stripname_result. # PREFIX and SUFFIX must not contain globbing or regex special # characters, hashes, percent signs, but SUFFIX may contain a leading # dot (in which case that matches only a dot). if test yes = "$_G_HAVE_XSI_OPS"; then eval 'func_stripname () { $debug_cmd # pdksh 5.2.14 does not do ${X%$Y} correctly if both X and Y are # positional parameters, so assign one to ordinary variable first. func_stripname_result=$3 func_stripname_result=${func_stripname_result#"$1"} func_stripname_result=${func_stripname_result%"$2"} }' else func_stripname () { $debug_cmd case $2 in .*) func_stripname_result=`$ECHO "$3" | $SED -e "s%^$1%%" -e "s%\\\\$2\$%%"`;; *) func_stripname_result=`$ECHO "$3" | $SED -e "s%^$1%%" -e "s%$2\$%%"`;; esac } fi # func_show_eval CMD [FAIL_EXP] # ----------------------------- # Unless opt_quiet is true, then output CMD. Then, if opt_dryrun is # not true, evaluate CMD. If the evaluation of CMD fails, and FAIL_EXP # is given, then evaluate it. func_show_eval () { $debug_cmd _G_cmd=$1 _G_fail_exp=${2-':'} func_quote_for_expand "$_G_cmd" eval "func_notquiet $func_quote_for_expand_result" $opt_dry_run || { eval "$_G_cmd" _G_status=$? if test 0 -ne "$_G_status"; then eval "(exit $_G_status); $_G_fail_exp" fi } } # func_show_eval_locale CMD [FAIL_EXP] # ------------------------------------ # Unless opt_quiet is true, then output CMD. Then, if opt_dryrun is # not true, evaluate CMD. If the evaluation of CMD fails, and FAIL_EXP # is given, then evaluate it. Use the saved locale for evaluation. func_show_eval_locale () { $debug_cmd _G_cmd=$1 _G_fail_exp=${2-':'} $opt_quiet || { func_quote_for_expand "$_G_cmd" eval "func_echo $func_quote_for_expand_result" } $opt_dry_run || { eval "$_G_user_locale $_G_cmd" _G_status=$? eval "$_G_safe_locale" if test 0 -ne "$_G_status"; then eval "(exit $_G_status); $_G_fail_exp" fi } } # func_tr_sh # ---------- # Turn $1 into a string suitable for a shell variable name. # Result is stored in $func_tr_sh_result. All characters # not in the set a-zA-Z0-9_ are replaced with '_'. Further, # if $1 begins with a digit, a '_' is prepended as well. func_tr_sh () { $debug_cmd case $1 in [0-9]* | *[!a-zA-Z0-9_]*) func_tr_sh_result=`$ECHO "$1" | $SED -e 's/^\([0-9]\)/_\1/' -e 's/[^a-zA-Z0-9_]/_/g'` ;; * ) func_tr_sh_result=$1 ;; esac } # func_verbose ARG... # ------------------- # Echo program name prefixed message in verbose mode only. func_verbose () { $debug_cmd $opt_verbose && func_echo "$*" : } # func_warn_and_continue ARG... # ----------------------------- # Echo program name prefixed warning message to standard error. func_warn_and_continue () { $debug_cmd $require_term_colors func_echo_infix_1 "${tc_red}warning$tc_reset" "$*" >&2 } # func_warning CATEGORY ARG... # ---------------------------- # Echo program name prefixed warning message to standard error. Warning # messages can be filtered according to CATEGORY, where this function # elides messages where CATEGORY is not listed in the global variable # 'opt_warning_types'. func_warning () { $debug_cmd # CATEGORY must be in the warning_categories list! case " $warning_categories " in *" $1 "*) ;; *) func_internal_error "invalid warning category '$1'" ;; esac _G_category=$1 shift case " $opt_warning_types " in *" $_G_category "*) $warning_func ${1+"$@"} ;; esac } # func_sort_ver VER1 VER2 # ----------------------- # 'sort -V' is not generally available. # Note this deviates from the version comparison in automake # in that it treats 1.5 < 1.5.0, and treats 1.4.4a < 1.4-p3a # but this should suffice as we won't be specifying old # version formats or redundant trailing .0 in bootstrap.conf. # If we did want full compatibility then we should probably # use m4_version_compare from autoconf. func_sort_ver () { $debug_cmd printf '%s\n%s\n' "$1" "$2" \ | sort -t. -k 1,1n -k 2,2n -k 3,3n -k 4,4n -k 5,5n -k 6,6n -k 7,7n -k 8,8n -k 9,9n } # func_lt_ver PREV CURR # --------------------- # Return true if PREV and CURR are in the correct order according to # func_sort_ver, otherwise false. Use it like this: # # func_lt_ver "$prev_ver" "$proposed_ver" || func_fatal_error "..." func_lt_ver () { $debug_cmd test "x$1" = x`func_sort_ver "$1" "$2" | $SED 1q` } # Local variables: # mode: shell-script # sh-indentation: 2 # eval: (add-hook 'before-save-hook 'time-stamp) # time-stamp-pattern: "10/scriptversion=%:y-%02m-%02d.%02H; # UTC" # time-stamp-time-zone: "UTC" # End: #! /bin/sh # Set a version string for this script. scriptversion=2014-01-07.03; # UTC # A portable, pluggable option parser for Bourne shell. # Written by Gary V. Vaughan, 2010 # Copyright (C) 2010-2015 Free Software Foundation, Inc. # This is free software; see the source for copying conditions. There is NO # warranty; not even for MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. # 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. # You should have received a copy of the GNU General Public License # along with this program. If not, see . # Please report bugs or propose patches to gary@gnu.org. ## ------ ## ## Usage. ## ## ------ ## # This file is a library for parsing options in your shell scripts along # with assorted other useful supporting features that you can make use # of too. # # For the simplest scripts you might need only: # # #!/bin/sh # . relative/path/to/funclib.sh # . relative/path/to/options-parser # scriptversion=1.0 # func_options ${1+"$@"} # eval set dummy "$func_options_result"; shift # ...rest of your script... # # In order for the '--version' option to work, you will need to have a # suitably formatted comment like the one at the top of this file # starting with '# Written by ' and ending with '# warranty; '. # # For '-h' and '--help' to work, you will also need a one line # description of your script's purpose in a comment directly above the # '# Written by ' line, like the one at the top of this file. # # The default options also support '--debug', which will turn on shell # execution tracing (see the comment above debug_cmd below for another # use), and '--verbose' and the func_verbose function to allow your script # to display verbose messages only when your user has specified # '--verbose'. # # After sourcing this file, you can plug processing for additional # options by amending the variables from the 'Configuration' section # below, and following the instructions in the 'Option parsing' # section further down. ## -------------- ## ## Configuration. ## ## -------------- ## # You should override these variables in your script after sourcing this # file so that they reflect the customisations you have added to the # option parser. # The usage line for option parsing errors and the start of '-h' and # '--help' output messages. You can embed shell variables for delayed # expansion at the time the message is displayed, but you will need to # quote other shell meta-characters carefully to prevent them being # expanded when the contents are evaled. usage='$progpath [OPTION]...' # Short help message in response to '-h' and '--help'. Add to this or # override it after sourcing this library to reflect the full set of # options your script accepts. usage_message="\ --debug enable verbose shell tracing -W, --warnings=CATEGORY report the warnings falling in CATEGORY [all] -v, --verbose verbosely report processing --version print version information and exit -h, --help print short or long help message and exit " # Additional text appended to 'usage_message' in response to '--help'. long_help_message=" Warning categories include: 'all' show all warnings 'none' turn off all the warnings 'error' warnings are treated as fatal errors" # Help message printed before fatal option parsing errors. fatal_help="Try '\$progname --help' for more information." ## ------------------------- ## ## Hook function management. ## ## ------------------------- ## # This section contains functions for adding, removing, and running hooks # to the main code. A hook is just a named list of of function, that can # be run in order later on. # func_hookable FUNC_NAME # ----------------------- # Declare that FUNC_NAME will run hooks added with # 'func_add_hook FUNC_NAME ...'. func_hookable () { $debug_cmd func_append hookable_fns " $1" } # func_add_hook FUNC_NAME HOOK_FUNC # --------------------------------- # Request that FUNC_NAME call HOOK_FUNC before it returns. FUNC_NAME must # first have been declared "hookable" by a call to 'func_hookable'. func_add_hook () { $debug_cmd case " $hookable_fns " in *" $1 "*) ;; *) func_fatal_error "'$1' does not accept hook functions." ;; esac eval func_append ${1}_hooks '" $2"' } # func_remove_hook FUNC_NAME HOOK_FUNC # ------------------------------------ # Remove HOOK_FUNC from the list of functions called by FUNC_NAME. func_remove_hook () { $debug_cmd eval ${1}_hooks='`$ECHO "\$'$1'_hooks" |$SED "s| '$2'||"`' } # func_run_hooks FUNC_NAME [ARG]... # --------------------------------- # Run all hook functions registered to FUNC_NAME. # It is assumed that the list of hook functions contains nothing more # than a whitespace-delimited list of legal shell function names, and # no effort is wasted trying to catch shell meta-characters or preserve # whitespace. func_run_hooks () { $debug_cmd case " $hookable_fns " in *" $1 "*) ;; *) func_fatal_error "'$1' does not support hook funcions.n" ;; esac eval _G_hook_fns=\$$1_hooks; shift for _G_hook in $_G_hook_fns; do eval $_G_hook '"$@"' # store returned options list back into positional # parameters for next 'cmd' execution. eval _G_hook_result=\$${_G_hook}_result eval set dummy "$_G_hook_result"; shift done func_quote_for_eval ${1+"$@"} func_run_hooks_result=$func_quote_for_eval_result } ## --------------- ## ## Option parsing. ## ## --------------- ## # In order to add your own option parsing hooks, you must accept the # full positional parameter list in your hook function, remove any # options that you action, and then pass back the remaining unprocessed # options in '_result', escaped suitably for # 'eval'. Like this: # # my_options_prep () # { # $debug_cmd # # # Extend the existing usage message. # usage_message=$usage_message' # -s, --silent don'\''t print informational messages # ' # # func_quote_for_eval ${1+"$@"} # my_options_prep_result=$func_quote_for_eval_result # } # func_add_hook func_options_prep my_options_prep # # # my_silent_option () # { # $debug_cmd # # # Note that for efficiency, we parse as many options as we can # # recognise in a loop before passing the remainder back to the # # caller on the first unrecognised argument we encounter. # while test $# -gt 0; do # opt=$1; shift # case $opt in # --silent|-s) opt_silent=: ;; # # Separate non-argument short options: # -s*) func_split_short_opt "$_G_opt" # set dummy "$func_split_short_opt_name" \ # "-$func_split_short_opt_arg" ${1+"$@"} # shift # ;; # *) set dummy "$_G_opt" "$*"; shift; break ;; # esac # done # # func_quote_for_eval ${1+"$@"} # my_silent_option_result=$func_quote_for_eval_result # } # func_add_hook func_parse_options my_silent_option # # # my_option_validation () # { # $debug_cmd # # $opt_silent && $opt_verbose && func_fatal_help "\ # '--silent' and '--verbose' options are mutually exclusive." # # func_quote_for_eval ${1+"$@"} # my_option_validation_result=$func_quote_for_eval_result # } # func_add_hook func_validate_options my_option_validation # # You'll alse need to manually amend $usage_message to reflect the extra # options you parse. It's preferable to append if you can, so that # multiple option parsing hooks can be added safely. # func_options [ARG]... # --------------------- # All the functions called inside func_options are hookable. See the # individual implementations for details. func_hookable func_options func_options () { $debug_cmd func_options_prep ${1+"$@"} eval func_parse_options \ ${func_options_prep_result+"$func_options_prep_result"} eval func_validate_options \ ${func_parse_options_result+"$func_parse_options_result"} eval func_run_hooks func_options \ ${func_validate_options_result+"$func_validate_options_result"} # save modified positional parameters for caller func_options_result=$func_run_hooks_result } # func_options_prep [ARG]... # -------------------------- # All initialisations required before starting the option parse loop. # Note that when calling hook functions, we pass through the list of # positional parameters. If a hook function modifies that list, and # needs to propogate that back to rest of this script, then the complete # modified list must be put in 'func_run_hooks_result' before # returning. func_hookable func_options_prep func_options_prep () { $debug_cmd # Option defaults: opt_verbose=false opt_warning_types= func_run_hooks func_options_prep ${1+"$@"} # save modified positional parameters for caller func_options_prep_result=$func_run_hooks_result } # func_parse_options [ARG]... # --------------------------- # The main option parsing loop. func_hookable func_parse_options func_parse_options () { $debug_cmd func_parse_options_result= # this just eases exit handling while test $# -gt 0; do # Defer to hook functions for initial option parsing, so they # get priority in the event of reusing an option name. func_run_hooks func_parse_options ${1+"$@"} # Adjust func_parse_options positional parameters to match eval set dummy "$func_run_hooks_result"; shift # Break out of the loop if we already parsed every option. test $# -gt 0 || break _G_opt=$1 shift case $_G_opt in --debug|-x) debug_cmd='set -x' func_echo "enabling shell trace mode" $debug_cmd ;; --no-warnings|--no-warning|--no-warn) set dummy --warnings none ${1+"$@"} shift ;; --warnings|--warning|-W) test $# = 0 && func_missing_arg $_G_opt && break case " $warning_categories $1" in *" $1 "*) # trailing space prevents matching last $1 above func_append_uniq opt_warning_types " $1" ;; *all) opt_warning_types=$warning_categories ;; *none) opt_warning_types=none warning_func=: ;; *error) opt_warning_types=$warning_categories warning_func=func_fatal_error ;; *) func_fatal_error \ "unsupported warning category: '$1'" ;; esac shift ;; --verbose|-v) opt_verbose=: ;; --version) func_version ;; -\?|-h) func_usage ;; --help) func_help ;; # Separate optargs to long options (plugins may need this): --*=*) func_split_equals "$_G_opt" set dummy "$func_split_equals_lhs" \ "$func_split_equals_rhs" ${1+"$@"} shift ;; # Separate optargs to short options: -W*) func_split_short_opt "$_G_opt" set dummy "$func_split_short_opt_name" \ "$func_split_short_opt_arg" ${1+"$@"} shift ;; # Separate non-argument short options: -\?*|-h*|-v*|-x*) func_split_short_opt "$_G_opt" set dummy "$func_split_short_opt_name" \ "-$func_split_short_opt_arg" ${1+"$@"} shift ;; --) break ;; -*) func_fatal_help "unrecognised option: '$_G_opt'" ;; *) set dummy "$_G_opt" ${1+"$@"}; shift; break ;; esac done # save modified positional parameters for caller func_quote_for_eval ${1+"$@"} func_parse_options_result=$func_quote_for_eval_result } # func_validate_options [ARG]... # ------------------------------ # Perform any sanity checks on option settings and/or unconsumed # arguments. func_hookable func_validate_options func_validate_options () { $debug_cmd # Display all warnings if -W was not given. test -n "$opt_warning_types" || opt_warning_types=" $warning_categories" func_run_hooks func_validate_options ${1+"$@"} # Bail if the options were screwed! $exit_cmd $EXIT_FAILURE # save modified positional parameters for caller func_validate_options_result=$func_run_hooks_result } ## ----------------- ## ## Helper functions. ## ## ----------------- ## # This section contains the helper functions used by the rest of the # hookable option parser framework in ascii-betical order. # func_fatal_help ARG... # ---------------------- # Echo program name prefixed message to standard error, followed by # a help hint, and exit. func_fatal_help () { $debug_cmd eval \$ECHO \""Usage: $usage"\" eval \$ECHO \""$fatal_help"\" func_error ${1+"$@"} exit $EXIT_FAILURE } # func_help # --------- # Echo long help message to standard output and exit. func_help () { $debug_cmd func_usage_message $ECHO "$long_help_message" exit 0 } # func_missing_arg ARGNAME # ------------------------ # Echo program name prefixed message to standard error and set global # exit_cmd. func_missing_arg () { $debug_cmd func_error "Missing argument for '$1'." exit_cmd=exit } # func_split_equals STRING # ------------------------ # Set func_split_equals_lhs and func_split_equals_rhs shell variables after # splitting STRING at the '=' sign. test -z "$_G_HAVE_XSI_OPS" \ && (eval 'x=a/b/c; test 5aa/bb/cc = "${#x}${x%%/*}${x%/*}${x#*/}${x##*/}"') 2>/dev/null \ && _G_HAVE_XSI_OPS=yes if test yes = "$_G_HAVE_XSI_OPS" then # This is an XSI compatible shell, allowing a faster implementation... eval 'func_split_equals () { $debug_cmd func_split_equals_lhs=${1%%=*} func_split_equals_rhs=${1#*=} test "x$func_split_equals_lhs" = "x$1" \ && func_split_equals_rhs= }' else # ...otherwise fall back to using expr, which is often a shell builtin. func_split_equals () { $debug_cmd func_split_equals_lhs=`expr "x$1" : 'x\([^=]*\)'` func_split_equals_rhs= test "x$func_split_equals_lhs" = "x$1" \ || func_split_equals_rhs=`expr "x$1" : 'x[^=]*=\(.*\)$'` } fi #func_split_equals # func_split_short_opt SHORTOPT # ----------------------------- # Set func_split_short_opt_name and func_split_short_opt_arg shell # variables after splitting SHORTOPT after the 2nd character. if test yes = "$_G_HAVE_XSI_OPS" then # This is an XSI compatible shell, allowing a faster implementation... eval 'func_split_short_opt () { $debug_cmd func_split_short_opt_arg=${1#??} func_split_short_opt_name=${1%"$func_split_short_opt_arg"} }' else # ...otherwise fall back to using expr, which is often a shell builtin. func_split_short_opt () { $debug_cmd func_split_short_opt_name=`expr "x$1" : 'x-\(.\)'` func_split_short_opt_arg=`expr "x$1" : 'x-.\(.*\)$'` } fi #func_split_short_opt # func_usage # ---------- # Echo short help message to standard output and exit. func_usage () { $debug_cmd func_usage_message $ECHO "Run '$progname --help |${PAGER-more}' for full usage" exit 0 } # func_usage_message # ------------------ # Echo short help message to standard output. func_usage_message () { $debug_cmd eval \$ECHO \""Usage: $usage"\" echo $SED -n 's|^# || /^Written by/{ x;p;x } h /^Written by/q' < "$progpath" echo eval \$ECHO \""$usage_message"\" } # func_version # ------------ # Echo version message to standard output and exit. func_version () { $debug_cmd printf '%s\n' "$progname $scriptversion" $SED -n ' /(C)/!b go :more /\./!{ N s|\n# | | b more } :go /^# Written by /,/# warranty; / { s|^# || s|^# *$|| s|\((C)\)[ 0-9,-]*[ ,-]\([1-9][0-9]* \)|\1 \2| p } /^# Written by / { s|^# || p } /^warranty; /q' < "$progpath" exit $? } # Local variables: # mode: shell-script # sh-indentation: 2 # eval: (add-hook 'before-save-hook 'time-stamp) # time-stamp-pattern: "10/scriptversion=%:y-%02m-%02d.%02H; # UTC" # time-stamp-time-zone: "UTC" # End: # Set a version string. scriptversion='(GNU libtool) 2.4.6' # func_echo ARG... # ---------------- # Libtool also displays the current mode in messages, so override # funclib.sh func_echo with this custom definition. func_echo () { $debug_cmd _G_message=$* func_echo_IFS=$IFS IFS=$nl for _G_line in $_G_message; do IFS=$func_echo_IFS $ECHO "$progname${opt_mode+: $opt_mode}: $_G_line" done IFS=$func_echo_IFS } # func_warning ARG... # ------------------- # Libtool warnings are not categorized, so override funclib.sh # func_warning with this simpler definition. func_warning () { $debug_cmd $warning_func ${1+"$@"} } ## ---------------- ## ## Options parsing. ## ## ---------------- ## # Hook in the functions to make sure our own options are parsed during # the option parsing loop. usage='$progpath [OPTION]... [MODE-ARG]...' # Short help message in response to '-h'. usage_message="Options: --config show all configuration variables --debug enable verbose shell tracing -n, --dry-run display commands without modifying any files --features display basic configuration information and exit --mode=MODE use operation mode MODE --no-warnings equivalent to '-Wnone' --preserve-dup-deps don't remove duplicate dependency libraries --quiet, --silent don't print informational messages --tag=TAG use configuration variables from tag TAG -v, --verbose print more informational messages than default --version print version information -W, --warnings=CATEGORY report the warnings falling in CATEGORY [all] -h, --help, --help-all print short, long, or detailed help message " # Additional text appended to 'usage_message' in response to '--help'. func_help () { $debug_cmd func_usage_message $ECHO "$long_help_message MODE must be one of the following: clean remove files from the build directory compile compile a source file into a libtool object execute automatically set library path, then run a program finish complete the installation of libtool libraries install install libraries or executables link create a library or an executable uninstall remove libraries from an installed directory MODE-ARGS vary depending on the MODE. When passed as first option, '--mode=MODE' may be abbreviated as 'MODE' or a unique abbreviation of that. Try '$progname --help --mode=MODE' for a more detailed description of MODE. When reporting a bug, please describe a test case to reproduce it and include the following information: host-triplet: $host shell: $SHELL compiler: $LTCC compiler flags: $LTCFLAGS linker: $LD (gnu? $with_gnu_ld) version: $progname (GNU libtool) 2.4.6 automake: `($AUTOMAKE --version) 2>/dev/null |$SED 1q` autoconf: `($AUTOCONF --version) 2>/dev/null |$SED 1q` Report bugs to . GNU libtool home page: . General help using GNU software: ." exit 0 } # func_lo2o OBJECT-NAME # --------------------- # Transform OBJECT-NAME from a '.lo' suffix to the platform specific # object suffix. lo2o=s/\\.lo\$/.$objext/ o2lo=s/\\.$objext\$/.lo/ if test yes = "$_G_HAVE_XSI_OPS"; then eval 'func_lo2o () { case $1 in *.lo) func_lo2o_result=${1%.lo}.$objext ;; * ) func_lo2o_result=$1 ;; esac }' # func_xform LIBOBJ-OR-SOURCE # --------------------------- # Transform LIBOBJ-OR-SOURCE from a '.o' or '.c' (or otherwise) # suffix to a '.lo' libtool-object suffix. eval 'func_xform () { func_xform_result=${1%.*}.lo }' else # ...otherwise fall back to using sed. func_lo2o () { func_lo2o_result=`$ECHO "$1" | $SED "$lo2o"` } func_xform () { func_xform_result=`$ECHO "$1" | $SED 's|\.[^.]*$|.lo|'` } fi # func_fatal_configuration ARG... # ------------------------------- # Echo program name prefixed message to standard error, followed by # a configuration failure hint, and exit. func_fatal_configuration () { func__fatal_error ${1+"$@"} \ "See the $PACKAGE documentation for more information." \ "Fatal configuration error." } # func_config # ----------- # Display the configuration for all the tags in this script. func_config () { re_begincf='^# ### BEGIN LIBTOOL' re_endcf='^# ### END LIBTOOL' # Default configuration. $SED "1,/$re_begincf CONFIG/d;/$re_endcf CONFIG/,\$d" < "$progpath" # Now print the configurations for the tags. for tagname in $taglist; do $SED -n "/$re_begincf TAG CONFIG: $tagname\$/,/$re_endcf TAG CONFIG: $tagname\$/p" < "$progpath" done exit $? } # func_features # ------------- # Display the features supported by this script. func_features () { echo "host: $host" if test yes = "$build_libtool_libs"; then echo "enable shared libraries" else echo "disable shared libraries" fi if test yes = "$build_old_libs"; then echo "enable static libraries" else echo "disable static libraries" fi exit $? } # func_enable_tag TAGNAME # ----------------------- # Verify that TAGNAME is valid, and either flag an error and exit, or # enable the TAGNAME tag. We also add TAGNAME to the global $taglist # variable here. func_enable_tag () { # Global variable: tagname=$1 re_begincf="^# ### BEGIN LIBTOOL TAG CONFIG: $tagname\$" re_endcf="^# ### END LIBTOOL TAG CONFIG: $tagname\$" sed_extractcf=/$re_begincf/,/$re_endcf/p # Validate tagname. case $tagname in *[!-_A-Za-z0-9,/]*) func_fatal_error "invalid tag name: $tagname" ;; esac # Don't test for the "default" C tag, as we know it's # there but not specially marked. case $tagname in CC) ;; *) if $GREP "$re_begincf" "$progpath" >/dev/null 2>&1; then taglist="$taglist $tagname" # Evaluate the configuration. Be careful to quote the path # and the sed script, to avoid splitting on whitespace, but # also don't use non-portable quotes within backquotes within # quotes we have to do it in 2 steps: extractedcf=`$SED -n -e "$sed_extractcf" < "$progpath"` eval "$extractedcf" else func_error "ignoring unknown tag $tagname" fi ;; esac } # func_check_version_match # ------------------------ # Ensure that we are using m4 macros, and libtool script from the same # release of libtool. func_check_version_match () { if test "$package_revision" != "$macro_revision"; then if test "$VERSION" != "$macro_version"; then if test -z "$macro_version"; then cat >&2 <<_LT_EOF $progname: Version mismatch error. This is $PACKAGE $VERSION, but the $progname: definition of this LT_INIT comes from an older release. $progname: You should recreate aclocal.m4 with macros from $PACKAGE $VERSION $progname: and run autoconf again. _LT_EOF else cat >&2 <<_LT_EOF $progname: Version mismatch error. This is $PACKAGE $VERSION, but the $progname: definition of this LT_INIT comes from $PACKAGE $macro_version. $progname: You should recreate aclocal.m4 with macros from $PACKAGE $VERSION $progname: and run autoconf again. _LT_EOF fi else cat >&2 <<_LT_EOF $progname: Version mismatch error. This is $PACKAGE $VERSION, revision $package_revision, $progname: but the definition of this LT_INIT comes from revision $macro_revision. $progname: You should recreate aclocal.m4 with macros from revision $package_revision $progname: of $PACKAGE $VERSION and run autoconf again. _LT_EOF fi exit $EXIT_MISMATCH fi } # libtool_options_prep [ARG]... # ----------------------------- # Preparation for options parsed by libtool. libtool_options_prep () { $debug_mode # Option defaults: opt_config=false opt_dlopen= opt_dry_run=false opt_help=false opt_mode= opt_preserve_dup_deps=false opt_quiet=false nonopt= preserve_args= # Shorthand for --mode=foo, only valid as the first argument case $1 in clean|clea|cle|cl) shift; set dummy --mode clean ${1+"$@"}; shift ;; compile|compil|compi|comp|com|co|c) shift; set dummy --mode compile ${1+"$@"}; shift ;; execute|execut|execu|exec|exe|ex|e) shift; set dummy --mode execute ${1+"$@"}; shift ;; finish|finis|fini|fin|fi|f) shift; set dummy --mode finish ${1+"$@"}; shift ;; install|instal|insta|inst|ins|in|i) shift; set dummy --mode install ${1+"$@"}; shift ;; link|lin|li|l) shift; set dummy --mode link ${1+"$@"}; shift ;; uninstall|uninstal|uninsta|uninst|unins|unin|uni|un|u) shift; set dummy --mode uninstall ${1+"$@"}; shift ;; esac # Pass back the list of options. func_quote_for_eval ${1+"$@"} libtool_options_prep_result=$func_quote_for_eval_result } func_add_hook func_options_prep libtool_options_prep # libtool_parse_options [ARG]... # --------------------------------- # Provide handling for libtool specific options. libtool_parse_options () { $debug_cmd # Perform our own loop to consume as many options as possible in # each iteration. while test $# -gt 0; do _G_opt=$1 shift case $_G_opt in --dry-run|--dryrun|-n) opt_dry_run=: ;; --config) func_config ;; --dlopen|-dlopen) opt_dlopen="${opt_dlopen+$opt_dlopen }$1" shift ;; --preserve-dup-deps) opt_preserve_dup_deps=: ;; --features) func_features ;; --finish) set dummy --mode finish ${1+"$@"}; shift ;; --help) opt_help=: ;; --help-all) opt_help=': help-all' ;; --mode) test $# = 0 && func_missing_arg $_G_opt && break opt_mode=$1 case $1 in # Valid mode arguments: clean|compile|execute|finish|install|link|relink|uninstall) ;; # Catch anything else as an error *) func_error "invalid argument for $_G_opt" exit_cmd=exit break ;; esac shift ;; --no-silent|--no-quiet) opt_quiet=false func_append preserve_args " $_G_opt" ;; --no-warnings|--no-warning|--no-warn) opt_warning=false func_append preserve_args " $_G_opt" ;; --no-verbose) opt_verbose=false func_append preserve_args " $_G_opt" ;; --silent|--quiet) opt_quiet=: opt_verbose=false func_append preserve_args " $_G_opt" ;; --tag) test $# = 0 && func_missing_arg $_G_opt && break opt_tag=$1 func_append preserve_args " $_G_opt $1" func_enable_tag "$1" shift ;; --verbose|-v) opt_quiet=false opt_verbose=: func_append preserve_args " $_G_opt" ;; # An option not handled by this hook function: *) set dummy "$_G_opt" ${1+"$@"}; shift; break ;; esac done # save modified positional parameters for caller func_quote_for_eval ${1+"$@"} libtool_parse_options_result=$func_quote_for_eval_result } func_add_hook func_parse_options libtool_parse_options # libtool_validate_options [ARG]... # --------------------------------- # Perform any sanity checks on option settings and/or unconsumed # arguments. libtool_validate_options () { # save first non-option argument if test 0 -lt $#; then nonopt=$1 shift fi # preserve --debug test : = "$debug_cmd" || func_append preserve_args " --debug" case $host in # Solaris2 added to fix http://debbugs.gnu.org/cgi/bugreport.cgi?bug=16452 # see also: http://gcc.gnu.org/bugzilla/show_bug.cgi?id=59788 *cygwin* | *mingw* | *pw32* | *cegcc* | *solaris2* | *os2*) # don't eliminate duplications in $postdeps and $predeps opt_duplicate_compiler_generated_deps=: ;; *) opt_duplicate_compiler_generated_deps=$opt_preserve_dup_deps ;; esac $opt_help || { # Sanity checks first: func_check_version_match test yes != "$build_libtool_libs" \ && test yes != "$build_old_libs" \ && func_fatal_configuration "not configured to build any kind of library" # Darwin sucks eval std_shrext=\"$shrext_cmds\" # Only execute mode is allowed to have -dlopen flags. if test -n "$opt_dlopen" && test execute != "$opt_mode"; then func_error "unrecognized option '-dlopen'" $ECHO "$help" 1>&2 exit $EXIT_FAILURE fi # Change the help message to a mode-specific one. generic_help=$help help="Try '$progname --help --mode=$opt_mode' for more information." } # Pass back the unparsed argument list func_quote_for_eval ${1+"$@"} libtool_validate_options_result=$func_quote_for_eval_result } func_add_hook func_validate_options libtool_validate_options # Process options as early as possible so that --help and --version # can return quickly. func_options ${1+"$@"} eval set dummy "$func_options_result"; shift ## ----------- ## ## Main. ## ## ----------- ## magic='%%%MAGIC variable%%%' magic_exe='%%%MAGIC EXE variable%%%' # Global variables. extracted_archives= extracted_serial=0 # If this variable is set in any of the actions, the command in it # will be execed at the end. This prevents here-documents from being # left over by shells. exec_cmd= # A function that is used when there is no print builtin or printf. func_fallback_echo () { eval 'cat <<_LTECHO_EOF $1 _LTECHO_EOF' } # func_generated_by_libtool # True iff stdin has been generated by Libtool. This function is only # a basic sanity check; it will hardly flush out determined imposters. func_generated_by_libtool_p () { $GREP "^# Generated by .*$PACKAGE" > /dev/null 2>&1 } # func_lalib_p file # True iff FILE is a libtool '.la' library or '.lo' object file. # This function is only a basic sanity check; it will hardly flush out # determined imposters. func_lalib_p () { test -f "$1" && $SED -e 4q "$1" 2>/dev/null | func_generated_by_libtool_p } # func_lalib_unsafe_p file # True iff FILE is a libtool '.la' library or '.lo' object file. # This function implements the same check as func_lalib_p without # resorting to external programs. To this end, it redirects stdin and # closes it afterwards, without saving the original file descriptor. # As a safety measure, use it only where a negative result would be # fatal anyway. Works if 'file' does not exist. func_lalib_unsafe_p () { lalib_p=no if test -f "$1" && test -r "$1" && exec 5<&0 <"$1"; then for lalib_p_l in 1 2 3 4 do read lalib_p_line case $lalib_p_line in \#\ Generated\ by\ *$PACKAGE* ) lalib_p=yes; break;; esac done exec 0<&5 5<&- fi test yes = "$lalib_p" } # func_ltwrapper_script_p file # True iff FILE is a libtool wrapper script # This function is only a basic sanity check; it will hardly flush out # determined imposters. func_ltwrapper_script_p () { test -f "$1" && $lt_truncate_bin < "$1" 2>/dev/null | func_generated_by_libtool_p } # func_ltwrapper_executable_p file # True iff FILE is a libtool wrapper executable # This function is only a basic sanity check; it will hardly flush out # determined imposters. func_ltwrapper_executable_p () { func_ltwrapper_exec_suffix= case $1 in *.exe) ;; *) func_ltwrapper_exec_suffix=.exe ;; esac $GREP "$magic_exe" "$1$func_ltwrapper_exec_suffix" >/dev/null 2>&1 } # func_ltwrapper_scriptname file # Assumes file is an ltwrapper_executable # uses $file to determine the appropriate filename for a # temporary ltwrapper_script. func_ltwrapper_scriptname () { func_dirname_and_basename "$1" "" "." func_stripname '' '.exe' "$func_basename_result" func_ltwrapper_scriptname_result=$func_dirname_result/$objdir/${func_stripname_result}_ltshwrapper } # func_ltwrapper_p file # True iff FILE is a libtool wrapper script or wrapper executable # This function is only a basic sanity check; it will hardly flush out # determined imposters. func_ltwrapper_p () { func_ltwrapper_script_p "$1" || func_ltwrapper_executable_p "$1" } # func_execute_cmds commands fail_cmd # Execute tilde-delimited COMMANDS. # If FAIL_CMD is given, eval that upon failure. # FAIL_CMD may read-access the current command in variable CMD! func_execute_cmds () { $debug_cmd save_ifs=$IFS; IFS='~' for cmd in $1; do IFS=$sp$nl eval cmd=\"$cmd\" IFS=$save_ifs func_show_eval "$cmd" "${2-:}" done IFS=$save_ifs } # func_source file # Source FILE, adding directory component if necessary. # Note that it is not necessary on cygwin/mingw to append a dot to # FILE even if both FILE and FILE.exe exist: automatic-append-.exe # behavior happens only for exec(3), not for open(2)! Also, sourcing # 'FILE.' does not work on cygwin managed mounts. func_source () { $debug_cmd case $1 in */* | *\\*) . "$1" ;; *) . "./$1" ;; esac } # func_resolve_sysroot PATH # Replace a leading = in PATH with a sysroot. Store the result into # func_resolve_sysroot_result func_resolve_sysroot () { func_resolve_sysroot_result=$1 case $func_resolve_sysroot_result in =*) func_stripname '=' '' "$func_resolve_sysroot_result" func_resolve_sysroot_result=$lt_sysroot$func_stripname_result ;; esac } # func_replace_sysroot PATH # If PATH begins with the sysroot, replace it with = and # store the result into func_replace_sysroot_result. func_replace_sysroot () { case $lt_sysroot:$1 in ?*:"$lt_sysroot"*) func_stripname "$lt_sysroot" '' "$1" func_replace_sysroot_result='='$func_stripname_result ;; *) # Including no sysroot. func_replace_sysroot_result=$1 ;; esac } # func_infer_tag arg # Infer tagged configuration to use if any are available and # if one wasn't chosen via the "--tag" command line option. # Only attempt this if the compiler in the base compile # command doesn't match the default compiler. # arg is usually of the form 'gcc ...' func_infer_tag () { $debug_cmd if test -n "$available_tags" && test -z "$tagname"; then CC_quoted= for arg in $CC; do func_append_quoted CC_quoted "$arg" done CC_expanded=`func_echo_all $CC` CC_quoted_expanded=`func_echo_all $CC_quoted` case $@ in # Blanks in the command may have been stripped by the calling shell, # but not from the CC environment variable when configure was run. " $CC "* | "$CC "* | " $CC_expanded "* | "$CC_expanded "* | \ " $CC_quoted"* | "$CC_quoted "* | " $CC_quoted_expanded "* | "$CC_quoted_expanded "*) ;; # Blanks at the start of $base_compile will cause this to fail # if we don't check for them as well. *) for z in $available_tags; do if $GREP "^# ### BEGIN LIBTOOL TAG CONFIG: $z$" < "$progpath" > /dev/null; then # Evaluate the configuration. eval "`$SED -n -e '/^# ### BEGIN LIBTOOL TAG CONFIG: '$z'$/,/^# ### END LIBTOOL TAG CONFIG: '$z'$/p' < $progpath`" CC_quoted= for arg in $CC; do # Double-quote args containing other shell metacharacters. func_append_quoted CC_quoted "$arg" done CC_expanded=`func_echo_all $CC` CC_quoted_expanded=`func_echo_all $CC_quoted` case "$@ " in " $CC "* | "$CC "* | " $CC_expanded "* | "$CC_expanded "* | \ " $CC_quoted"* | "$CC_quoted "* | " $CC_quoted_expanded "* | "$CC_quoted_expanded "*) # The compiler in the base compile command matches # the one in the tagged configuration. # Assume this is the tagged configuration we want. tagname=$z break ;; esac fi done # If $tagname still isn't set, then no tagged configuration # was found and let the user know that the "--tag" command # line option must be used. if test -z "$tagname"; then func_echo "unable to infer tagged configuration" func_fatal_error "specify a tag with '--tag'" # else # func_verbose "using $tagname tagged configuration" fi ;; esac fi } # func_write_libtool_object output_name pic_name nonpic_name # Create a libtool object file (analogous to a ".la" file), # but don't create it if we're doing a dry run. func_write_libtool_object () { write_libobj=$1 if test yes = "$build_libtool_libs"; then write_lobj=\'$2\' else write_lobj=none fi if test yes = "$build_old_libs"; then write_oldobj=\'$3\' else write_oldobj=none fi $opt_dry_run || { cat >${write_libobj}T </dev/null` if test "$?" -eq 0 && test -n "$func_convert_core_file_wine_to_w32_tmp"; then func_convert_core_file_wine_to_w32_result=`$ECHO "$func_convert_core_file_wine_to_w32_tmp" | $SED -e "$sed_naive_backslashify"` else func_convert_core_file_wine_to_w32_result= fi fi } # end: func_convert_core_file_wine_to_w32 # func_convert_core_path_wine_to_w32 ARG # Helper function used by path conversion functions when $build is *nix, and # $host is mingw, cygwin, or some other w32 environment. Relies on a correctly # configured wine environment available, with the winepath program in $build's # $PATH. Assumes ARG has no leading or trailing path separator characters. # # ARG is path to be converted from $build format to win32. # Result is available in $func_convert_core_path_wine_to_w32_result. # Unconvertible file (directory) names in ARG are skipped; if no directory names # are convertible, then the result may be empty. func_convert_core_path_wine_to_w32 () { $debug_cmd # unfortunately, winepath doesn't convert paths, only file names func_convert_core_path_wine_to_w32_result= if test -n "$1"; then oldIFS=$IFS IFS=: for func_convert_core_path_wine_to_w32_f in $1; do IFS=$oldIFS func_convert_core_file_wine_to_w32 "$func_convert_core_path_wine_to_w32_f" if test -n "$func_convert_core_file_wine_to_w32_result"; then if test -z "$func_convert_core_path_wine_to_w32_result"; then func_convert_core_path_wine_to_w32_result=$func_convert_core_file_wine_to_w32_result else func_append func_convert_core_path_wine_to_w32_result ";$func_convert_core_file_wine_to_w32_result" fi fi done IFS=$oldIFS fi } # end: func_convert_core_path_wine_to_w32 # func_cygpath ARGS... # Wrapper around calling the cygpath program via LT_CYGPATH. This is used when # when (1) $build is *nix and Cygwin is hosted via a wine environment; or (2) # $build is MSYS and $host is Cygwin, or (3) $build is Cygwin. In case (1) or # (2), returns the Cygwin file name or path in func_cygpath_result (input # file name or path is assumed to be in w32 format, as previously converted # from $build's *nix or MSYS format). In case (3), returns the w32 file name # or path in func_cygpath_result (input file name or path is assumed to be in # Cygwin format). Returns an empty string on error. # # ARGS are passed to cygpath, with the last one being the file name or path to # be converted. # # Specify the absolute *nix (or w32) name to cygpath in the LT_CYGPATH # environment variable; do not put it in $PATH. func_cygpath () { $debug_cmd if test -n "$LT_CYGPATH" && test -f "$LT_CYGPATH"; then func_cygpath_result=`$LT_CYGPATH "$@" 2>/dev/null` if test "$?" -ne 0; then # on failure, ensure result is empty func_cygpath_result= fi else func_cygpath_result= func_error "LT_CYGPATH is empty or specifies non-existent file: '$LT_CYGPATH'" fi } #end: func_cygpath # func_convert_core_msys_to_w32 ARG # Convert file name or path ARG from MSYS format to w32 format. Return # result in func_convert_core_msys_to_w32_result. func_convert_core_msys_to_w32 () { $debug_cmd # awkward: cmd appends spaces to result func_convert_core_msys_to_w32_result=`( cmd //c echo "$1" ) 2>/dev/null | $SED -e 's/[ ]*$//' -e "$sed_naive_backslashify"` } #end: func_convert_core_msys_to_w32 # func_convert_file_check ARG1 ARG2 # Verify that ARG1 (a file name in $build format) was converted to $host # format in ARG2. Otherwise, emit an error message, but continue (resetting # func_to_host_file_result to ARG1). func_convert_file_check () { $debug_cmd if test -z "$2" && test -n "$1"; then func_error "Could not determine host file name corresponding to" func_error " '$1'" func_error "Continuing, but uninstalled executables may not work." # Fallback: func_to_host_file_result=$1 fi } # end func_convert_file_check # func_convert_path_check FROM_PATHSEP TO_PATHSEP FROM_PATH TO_PATH # Verify that FROM_PATH (a path in $build format) was converted to $host # format in TO_PATH. Otherwise, emit an error message, but continue, resetting # func_to_host_file_result to a simplistic fallback value (see below). func_convert_path_check () { $debug_cmd if test -z "$4" && test -n "$3"; then func_error "Could not determine the host path corresponding to" func_error " '$3'" func_error "Continuing, but uninstalled executables may not work." # Fallback. This is a deliberately simplistic "conversion" and # should not be "improved". See libtool.info. if test "x$1" != "x$2"; then lt_replace_pathsep_chars="s|$1|$2|g" func_to_host_path_result=`echo "$3" | $SED -e "$lt_replace_pathsep_chars"` else func_to_host_path_result=$3 fi fi } # end func_convert_path_check # func_convert_path_front_back_pathsep FRONTPAT BACKPAT REPL ORIG # Modifies func_to_host_path_result by prepending REPL if ORIG matches FRONTPAT # and appending REPL if ORIG matches BACKPAT. func_convert_path_front_back_pathsep () { $debug_cmd case $4 in $1 ) func_to_host_path_result=$3$func_to_host_path_result ;; esac case $4 in $2 ) func_append func_to_host_path_result "$3" ;; esac } # end func_convert_path_front_back_pathsep ################################################## # $build to $host FILE NAME CONVERSION FUNCTIONS # ################################################## # invoked via '$to_host_file_cmd ARG' # # In each case, ARG is the path to be converted from $build to $host format. # Result will be available in $func_to_host_file_result. # func_to_host_file ARG # Converts the file name ARG from $build format to $host format. Return result # in func_to_host_file_result. func_to_host_file () { $debug_cmd $to_host_file_cmd "$1" } # end func_to_host_file # func_to_tool_file ARG LAZY # converts the file name ARG from $build format to toolchain format. Return # result in func_to_tool_file_result. If the conversion in use is listed # in (the comma separated) LAZY, no conversion takes place. func_to_tool_file () { $debug_cmd case ,$2, in *,"$to_tool_file_cmd",*) func_to_tool_file_result=$1 ;; *) $to_tool_file_cmd "$1" func_to_tool_file_result=$func_to_host_file_result ;; esac } # end func_to_tool_file # func_convert_file_noop ARG # Copy ARG to func_to_host_file_result. func_convert_file_noop () { func_to_host_file_result=$1 } # end func_convert_file_noop # func_convert_file_msys_to_w32 ARG # Convert file name ARG from (mingw) MSYS to (mingw) w32 format; automatic # conversion to w32 is not available inside the cwrapper. Returns result in # func_to_host_file_result. func_convert_file_msys_to_w32 () { $debug_cmd func_to_host_file_result=$1 if test -n "$1"; then func_convert_core_msys_to_w32 "$1" func_to_host_file_result=$func_convert_core_msys_to_w32_result fi func_convert_file_check "$1" "$func_to_host_file_result" } # end func_convert_file_msys_to_w32 # func_convert_file_cygwin_to_w32 ARG # Convert file name ARG from Cygwin to w32 format. Returns result in # func_to_host_file_result. func_convert_file_cygwin_to_w32 () { $debug_cmd func_to_host_file_result=$1 if test -n "$1"; then # because $build is cygwin, we call "the" cygpath in $PATH; no need to use # LT_CYGPATH in this case. func_to_host_file_result=`cygpath -m "$1"` fi func_convert_file_check "$1" "$func_to_host_file_result" } # end func_convert_file_cygwin_to_w32 # func_convert_file_nix_to_w32 ARG # Convert file name ARG from *nix to w32 format. Requires a wine environment # and a working winepath. Returns result in func_to_host_file_result. func_convert_file_nix_to_w32 () { $debug_cmd func_to_host_file_result=$1 if test -n "$1"; then func_convert_core_file_wine_to_w32 "$1" func_to_host_file_result=$func_convert_core_file_wine_to_w32_result fi func_convert_file_check "$1" "$func_to_host_file_result" } # end func_convert_file_nix_to_w32 # func_convert_file_msys_to_cygwin ARG # Convert file name ARG from MSYS to Cygwin format. Requires LT_CYGPATH set. # Returns result in func_to_host_file_result. func_convert_file_msys_to_cygwin () { $debug_cmd func_to_host_file_result=$1 if test -n "$1"; then func_convert_core_msys_to_w32 "$1" func_cygpath -u "$func_convert_core_msys_to_w32_result" func_to_host_file_result=$func_cygpath_result fi func_convert_file_check "$1" "$func_to_host_file_result" } # end func_convert_file_msys_to_cygwin # func_convert_file_nix_to_cygwin ARG # Convert file name ARG from *nix to Cygwin format. Requires Cygwin installed # in a wine environment, working winepath, and LT_CYGPATH set. Returns result # in func_to_host_file_result. func_convert_file_nix_to_cygwin () { $debug_cmd func_to_host_file_result=$1 if test -n "$1"; then # convert from *nix to w32, then use cygpath to convert from w32 to cygwin. func_convert_core_file_wine_to_w32 "$1" func_cygpath -u "$func_convert_core_file_wine_to_w32_result" func_to_host_file_result=$func_cygpath_result fi func_convert_file_check "$1" "$func_to_host_file_result" } # end func_convert_file_nix_to_cygwin ############################################# # $build to $host PATH CONVERSION FUNCTIONS # ############################################# # invoked via '$to_host_path_cmd ARG' # # In each case, ARG is the path to be converted from $build to $host format. # The result will be available in $func_to_host_path_result. # # Path separators are also converted from $build format to $host format. If # ARG begins or ends with a path separator character, it is preserved (but # converted to $host format) on output. # # All path conversion functions are named using the following convention: # file name conversion function : func_convert_file_X_to_Y () # path conversion function : func_convert_path_X_to_Y () # where, for any given $build/$host combination the 'X_to_Y' value is the # same. If conversion functions are added for new $build/$host combinations, # the two new functions must follow this pattern, or func_init_to_host_path_cmd # will break. # func_init_to_host_path_cmd # Ensures that function "pointer" variable $to_host_path_cmd is set to the # appropriate value, based on the value of $to_host_file_cmd. to_host_path_cmd= func_init_to_host_path_cmd () { $debug_cmd if test -z "$to_host_path_cmd"; then func_stripname 'func_convert_file_' '' "$to_host_file_cmd" to_host_path_cmd=func_convert_path_$func_stripname_result fi } # func_to_host_path ARG # Converts the path ARG from $build format to $host format. Return result # in func_to_host_path_result. func_to_host_path () { $debug_cmd func_init_to_host_path_cmd $to_host_path_cmd "$1" } # end func_to_host_path # func_convert_path_noop ARG # Copy ARG to func_to_host_path_result. func_convert_path_noop () { func_to_host_path_result=$1 } # end func_convert_path_noop # func_convert_path_msys_to_w32 ARG # Convert path ARG from (mingw) MSYS to (mingw) w32 format; automatic # conversion to w32 is not available inside the cwrapper. Returns result in # func_to_host_path_result. func_convert_path_msys_to_w32 () { $debug_cmd func_to_host_path_result=$1 if test -n "$1"; then # Remove leading and trailing path separator characters from ARG. MSYS # behavior is inconsistent here; cygpath turns them into '.;' and ';.'; # and winepath ignores them completely. func_stripname : : "$1" func_to_host_path_tmp1=$func_stripname_result func_convert_core_msys_to_w32 "$func_to_host_path_tmp1" func_to_host_path_result=$func_convert_core_msys_to_w32_result func_convert_path_check : ";" \ "$func_to_host_path_tmp1" "$func_to_host_path_result" func_convert_path_front_back_pathsep ":*" "*:" ";" "$1" fi } # end func_convert_path_msys_to_w32 # func_convert_path_cygwin_to_w32 ARG # Convert path ARG from Cygwin to w32 format. Returns result in # func_to_host_file_result. func_convert_path_cygwin_to_w32 () { $debug_cmd func_to_host_path_result=$1 if test -n "$1"; then # See func_convert_path_msys_to_w32: func_stripname : : "$1" func_to_host_path_tmp1=$func_stripname_result func_to_host_path_result=`cygpath -m -p "$func_to_host_path_tmp1"` func_convert_path_check : ";" \ "$func_to_host_path_tmp1" "$func_to_host_path_result" func_convert_path_front_back_pathsep ":*" "*:" ";" "$1" fi } # end func_convert_path_cygwin_to_w32 # func_convert_path_nix_to_w32 ARG # Convert path ARG from *nix to w32 format. Requires a wine environment and # a working winepath. Returns result in func_to_host_file_result. func_convert_path_nix_to_w32 () { $debug_cmd func_to_host_path_result=$1 if test -n "$1"; then # See func_convert_path_msys_to_w32: func_stripname : : "$1" func_to_host_path_tmp1=$func_stripname_result func_convert_core_path_wine_to_w32 "$func_to_host_path_tmp1" func_to_host_path_result=$func_convert_core_path_wine_to_w32_result func_convert_path_check : ";" \ "$func_to_host_path_tmp1" "$func_to_host_path_result" func_convert_path_front_back_pathsep ":*" "*:" ";" "$1" fi } # end func_convert_path_nix_to_w32 # func_convert_path_msys_to_cygwin ARG # Convert path ARG from MSYS to Cygwin format. Requires LT_CYGPATH set. # Returns result in func_to_host_file_result. func_convert_path_msys_to_cygwin () { $debug_cmd func_to_host_path_result=$1 if test -n "$1"; then # See func_convert_path_msys_to_w32: func_stripname : : "$1" func_to_host_path_tmp1=$func_stripname_result func_convert_core_msys_to_w32 "$func_to_host_path_tmp1" func_cygpath -u -p "$func_convert_core_msys_to_w32_result" func_to_host_path_result=$func_cygpath_result func_convert_path_check : : \ "$func_to_host_path_tmp1" "$func_to_host_path_result" func_convert_path_front_back_pathsep ":*" "*:" : "$1" fi } # end func_convert_path_msys_to_cygwin # func_convert_path_nix_to_cygwin ARG # Convert path ARG from *nix to Cygwin format. Requires Cygwin installed in a # a wine environment, working winepath, and LT_CYGPATH set. Returns result in # func_to_host_file_result. func_convert_path_nix_to_cygwin () { $debug_cmd func_to_host_path_result=$1 if test -n "$1"; then # Remove leading and trailing path separator characters from # ARG. msys behavior is inconsistent here, cygpath turns them # into '.;' and ';.', and winepath ignores them completely. func_stripname : : "$1" func_to_host_path_tmp1=$func_stripname_result func_convert_core_path_wine_to_w32 "$func_to_host_path_tmp1" func_cygpath -u -p "$func_convert_core_path_wine_to_w32_result" func_to_host_path_result=$func_cygpath_result func_convert_path_check : : \ "$func_to_host_path_tmp1" "$func_to_host_path_result" func_convert_path_front_back_pathsep ":*" "*:" : "$1" fi } # end func_convert_path_nix_to_cygwin # func_dll_def_p FILE # True iff FILE is a Windows DLL '.def' file. # Keep in sync with _LT_DLL_DEF_P in libtool.m4 func_dll_def_p () { $debug_cmd func_dll_def_p_tmp=`$SED -n \ -e 's/^[ ]*//' \ -e '/^\(;.*\)*$/d' \ -e 's/^\(EXPORTS\|LIBRARY\)\([ ].*\)*$/DEF/p' \ -e q \ "$1"` test DEF = "$func_dll_def_p_tmp" } # func_mode_compile arg... func_mode_compile () { $debug_cmd # Get the compilation command and the source file. base_compile= srcfile=$nonopt # always keep a non-empty value in "srcfile" suppress_opt=yes suppress_output= arg_mode=normal libobj= later= pie_flag= for arg do case $arg_mode in arg ) # do not "continue". Instead, add this to base_compile lastarg=$arg arg_mode=normal ;; target ) libobj=$arg arg_mode=normal continue ;; normal ) # Accept any command-line options. case $arg in -o) test -n "$libobj" && \ func_fatal_error "you cannot specify '-o' more than once" arg_mode=target continue ;; -pie | -fpie | -fPIE) func_append pie_flag " $arg" continue ;; -shared | -static | -prefer-pic | -prefer-non-pic) func_append later " $arg" continue ;; -no-suppress) suppress_opt=no continue ;; -Xcompiler) arg_mode=arg # the next one goes into the "base_compile" arg list continue # The current "srcfile" will either be retained or ;; # replaced later. I would guess that would be a bug. -Wc,*) func_stripname '-Wc,' '' "$arg" args=$func_stripname_result lastarg= save_ifs=$IFS; IFS=, for arg in $args; do IFS=$save_ifs func_append_quoted lastarg "$arg" done IFS=$save_ifs func_stripname ' ' '' "$lastarg" lastarg=$func_stripname_result # Add the arguments to base_compile. func_append base_compile " $lastarg" continue ;; *) # Accept the current argument as the source file. # The previous "srcfile" becomes the current argument. # lastarg=$srcfile srcfile=$arg ;; esac # case $arg ;; esac # case $arg_mode # Aesthetically quote the previous argument. func_append_quoted base_compile "$lastarg" done # for arg case $arg_mode in arg) func_fatal_error "you must specify an argument for -Xcompile" ;; target) func_fatal_error "you must specify a target with '-o'" ;; *) # Get the name of the library object. test -z "$libobj" && { func_basename "$srcfile" libobj=$func_basename_result } ;; esac # Recognize several different file suffixes. # If the user specifies -o file.o, it is replaced with file.lo case $libobj in *.[cCFSifmso] | \ *.ada | *.adb | *.ads | *.asm | \ *.c++ | *.cc | *.ii | *.class | *.cpp | *.cxx | \ *.[fF][09]? | *.for | *.java | *.go | *.obj | *.sx | *.cu | *.cup) func_xform "$libobj" libobj=$func_xform_result ;; esac case $libobj in *.lo) func_lo2o "$libobj"; obj=$func_lo2o_result ;; *) func_fatal_error "cannot determine name of library object from '$libobj'" ;; esac func_infer_tag $base_compile for arg in $later; do case $arg in -shared) test yes = "$build_libtool_libs" \ || func_fatal_configuration "cannot build a shared library" build_old_libs=no continue ;; -static) build_libtool_libs=no build_old_libs=yes continue ;; -prefer-pic) pic_mode=yes continue ;; -prefer-non-pic) pic_mode=no continue ;; esac done func_quote_for_eval "$libobj" test "X$libobj" != "X$func_quote_for_eval_result" \ && $ECHO "X$libobj" | $GREP '[]~#^*{};<>?"'"'"' &()|`$[]' \ && func_warning "libobj name '$libobj' may not contain shell special characters." func_dirname_and_basename "$obj" "/" "" objname=$func_basename_result xdir=$func_dirname_result lobj=$xdir$objdir/$objname test -z "$base_compile" && \ func_fatal_help "you must specify a compilation command" # Delete any leftover library objects. if test yes = "$build_old_libs"; then removelist="$obj $lobj $libobj ${libobj}T" else removelist="$lobj $libobj ${libobj}T" fi # On Cygwin there's no "real" PIC flag so we must build both object types case $host_os in cygwin* | mingw* | pw32* | os2* | cegcc*) pic_mode=default ;; esac if test no = "$pic_mode" && test pass_all != "$deplibs_check_method"; then # non-PIC code in shared libraries is not supported pic_mode=default fi # Calculate the filename of the output object if compiler does # not support -o with -c if test no = "$compiler_c_o"; then output_obj=`$ECHO "$srcfile" | $SED 's%^.*/%%; s%\.[^.]*$%%'`.$objext lockfile=$output_obj.lock else output_obj= need_locks=no lockfile= fi # Lock this critical section if it is needed # We use this script file to make the link, it avoids creating a new file if test yes = "$need_locks"; then until $opt_dry_run || ln "$progpath" "$lockfile" 2>/dev/null; do func_echo "Waiting for $lockfile to be removed" sleep 2 done elif test warn = "$need_locks"; then if test -f "$lockfile"; then $ECHO "\ *** ERROR, $lockfile exists and contains: `cat $lockfile 2>/dev/null` This indicates that another process is trying to use the same temporary object file, and libtool could not work around it because your compiler does not support '-c' and '-o' together. If you repeat this compilation, it may succeed, by chance, but you had better avoid parallel builds (make -j) in this platform, or get a better compiler." $opt_dry_run || $RM $removelist exit $EXIT_FAILURE fi func_append removelist " $output_obj" $ECHO "$srcfile" > "$lockfile" fi $opt_dry_run || $RM $removelist func_append removelist " $lockfile" trap '$opt_dry_run || $RM $removelist; exit $EXIT_FAILURE' 1 2 15 func_to_tool_file "$srcfile" func_convert_file_msys_to_w32 srcfile=$func_to_tool_file_result func_quote_for_eval "$srcfile" qsrcfile=$func_quote_for_eval_result # Only build a PIC object if we are building libtool libraries. if test yes = "$build_libtool_libs"; then # Without this assignment, base_compile gets emptied. fbsd_hideous_sh_bug=$base_compile if test no != "$pic_mode"; then command="$base_compile $qsrcfile $pic_flag" else # Don't build PIC code command="$base_compile $qsrcfile" fi func_mkdir_p "$xdir$objdir" if test -z "$output_obj"; then # Place PIC objects in $objdir func_append command " -o $lobj" fi func_show_eval_locale "$command" \ 'test -n "$output_obj" && $RM $removelist; exit $EXIT_FAILURE' if test warn = "$need_locks" && test "X`cat $lockfile 2>/dev/null`" != "X$srcfile"; then $ECHO "\ *** ERROR, $lockfile contains: `cat $lockfile 2>/dev/null` but it should contain: $srcfile This indicates that another process is trying to use the same temporary object file, and libtool could not work around it because your compiler does not support '-c' and '-o' together. If you repeat this compilation, it may succeed, by chance, but you had better avoid parallel builds (make -j) in this platform, or get a better compiler." $opt_dry_run || $RM $removelist exit $EXIT_FAILURE fi # Just move the object if needed, then go on to compile the next one if test -n "$output_obj" && test "X$output_obj" != "X$lobj"; then func_show_eval '$MV "$output_obj" "$lobj"' \ 'error=$?; $opt_dry_run || $RM $removelist; exit $error' fi # Allow error messages only from the first compilation. if test yes = "$suppress_opt"; then suppress_output=' >/dev/null 2>&1' fi fi # Only build a position-dependent object if we build old libraries. if test yes = "$build_old_libs"; then if test yes != "$pic_mode"; then # Don't build PIC code command="$base_compile $qsrcfile$pie_flag" else command="$base_compile $qsrcfile $pic_flag" fi if test yes = "$compiler_c_o"; then func_append command " -o $obj" fi # Suppress compiler output if we already did a PIC compilation. func_append command "$suppress_output" func_show_eval_locale "$command" \ '$opt_dry_run || $RM $removelist; exit $EXIT_FAILURE' if test warn = "$need_locks" && test "X`cat $lockfile 2>/dev/null`" != "X$srcfile"; then $ECHO "\ *** ERROR, $lockfile contains: `cat $lockfile 2>/dev/null` but it should contain: $srcfile This indicates that another process is trying to use the same temporary object file, and libtool could not work around it because your compiler does not support '-c' and '-o' together. If you repeat this compilation, it may succeed, by chance, but you had better avoid parallel builds (make -j) in this platform, or get a better compiler." $opt_dry_run || $RM $removelist exit $EXIT_FAILURE fi # Just move the object if needed if test -n "$output_obj" && test "X$output_obj" != "X$obj"; then func_show_eval '$MV "$output_obj" "$obj"' \ 'error=$?; $opt_dry_run || $RM $removelist; exit $error' fi fi $opt_dry_run || { func_write_libtool_object "$libobj" "$objdir/$objname" "$objname" # Unlock the critical section if it was locked if test no != "$need_locks"; then removelist=$lockfile $RM "$lockfile" fi } exit $EXIT_SUCCESS } $opt_help || { test compile = "$opt_mode" && func_mode_compile ${1+"$@"} } func_mode_help () { # We need to display help for each of the modes. case $opt_mode in "") # Generic help is extracted from the usage comments # at the start of this file. func_help ;; clean) $ECHO \ "Usage: $progname [OPTION]... --mode=clean RM [RM-OPTION]... FILE... Remove files from the build directory. RM is the name of the program to use to delete files associated with each FILE (typically '/bin/rm'). RM-OPTIONS are options (such as '-f') to be passed to RM. If FILE is a libtool library, object or program, all the files associated with it are deleted. Otherwise, only FILE itself is deleted using RM." ;; compile) $ECHO \ "Usage: $progname [OPTION]... --mode=compile COMPILE-COMMAND... SOURCEFILE Compile a source file into a libtool library object. This mode accepts the following additional options: -o OUTPUT-FILE set the output file name to OUTPUT-FILE -no-suppress do not suppress compiler output for multiple passes -prefer-pic try to build PIC objects only -prefer-non-pic try to build non-PIC objects only -shared do not build a '.o' file suitable for static linking -static only build a '.o' file suitable for static linking -Wc,FLAG pass FLAG directly to the compiler COMPILE-COMMAND is a command to be used in creating a 'standard' object file from the given SOURCEFILE. The output file name is determined by removing the directory component from SOURCEFILE, then substituting the C source code suffix '.c' with the library object suffix, '.lo'." ;; execute) $ECHO \ "Usage: $progname [OPTION]... --mode=execute COMMAND [ARGS]... Automatically set library path, then run a program. This mode accepts the following additional options: -dlopen FILE add the directory containing FILE to the library path This mode sets the library path environment variable according to '-dlopen' flags. If any of the ARGS are libtool executable wrappers, then they are translated into their corresponding uninstalled binary, and any of their required library directories are added to the library path. Then, COMMAND is executed, with ARGS as arguments." ;; finish) $ECHO \ "Usage: $progname [OPTION]... --mode=finish [LIBDIR]... Complete the installation of libtool libraries. Each LIBDIR is a directory that contains libtool libraries. The commands that this mode executes may require superuser privileges. Use the '--dry-run' option if you just want to see what would be executed." ;; install) $ECHO \ "Usage: $progname [OPTION]... --mode=install INSTALL-COMMAND... Install executables or libraries. INSTALL-COMMAND is the installation command. The first component should be either the 'install' or 'cp' program. The following components of INSTALL-COMMAND are treated specially: -inst-prefix-dir PREFIX-DIR Use PREFIX-DIR as a staging area for installation The rest of the components are interpreted as arguments to that command (only BSD-compatible install options are recognized)." ;; link) $ECHO \ "Usage: $progname [OPTION]... --mode=link LINK-COMMAND... Link object files or libraries together to form another library, or to create an executable program. LINK-COMMAND is a command using the C compiler that you would use to create a program from several object files. The following components of LINK-COMMAND are treated specially: -all-static do not do any dynamic linking at all -avoid-version do not add a version suffix if possible -bindir BINDIR specify path to binaries directory (for systems where libraries must be found in the PATH setting at runtime) -dlopen FILE '-dlpreopen' FILE if it cannot be dlopened at runtime -dlpreopen FILE link in FILE and add its symbols to lt_preloaded_symbols -export-dynamic allow symbols from OUTPUT-FILE to be resolved with dlsym(3) -export-symbols SYMFILE try to export only the symbols listed in SYMFILE -export-symbols-regex REGEX try to export only the symbols matching REGEX -LLIBDIR search LIBDIR for required installed libraries -lNAME OUTPUT-FILE requires the installed library libNAME -module build a library that can dlopened -no-fast-install disable the fast-install mode -no-install link a not-installable executable -no-undefined declare that a library does not refer to external symbols -o OUTPUT-FILE create OUTPUT-FILE from the specified objects -objectlist FILE use a list of object files found in FILE to specify objects -os2dllname NAME force a short DLL name on OS/2 (no effect on other OSes) -precious-files-regex REGEX don't remove output files matching REGEX -release RELEASE specify package release information -rpath LIBDIR the created library will eventually be installed in LIBDIR -R[ ]LIBDIR add LIBDIR to the runtime path of programs and libraries -shared only do dynamic linking of libtool libraries -shrext SUFFIX override the standard shared library file extension -static do not do any dynamic linking of uninstalled libtool libraries -static-libtool-libs do not do any dynamic linking of libtool libraries -version-info CURRENT[:REVISION[:AGE]] specify library version info [each variable defaults to 0] -weak LIBNAME declare that the target provides the LIBNAME interface -Wc,FLAG -Xcompiler FLAG pass linker-specific FLAG directly to the compiler -Wl,FLAG -Xlinker FLAG pass linker-specific FLAG directly to the linker -XCClinker FLAG pass link-specific FLAG to the compiler driver (CC) All other options (arguments beginning with '-') are ignored. Every other argument is treated as a filename. Files ending in '.la' are treated as uninstalled libtool libraries, other files are standard or library object files. If the OUTPUT-FILE ends in '.la', then a libtool library is created, only library objects ('.lo' files) may be specified, and '-rpath' is required, except when creating a convenience library. If OUTPUT-FILE ends in '.a' or '.lib', then a standard library is created using 'ar' and 'ranlib', or on Windows using 'lib'. If OUTPUT-FILE ends in '.lo' or '.$objext', then a reloadable object file is created, otherwise an executable program is created." ;; uninstall) $ECHO \ "Usage: $progname [OPTION]... --mode=uninstall RM [RM-OPTION]... FILE... Remove libraries from an installation directory. RM is the name of the program to use to delete files associated with each FILE (typically '/bin/rm'). RM-OPTIONS are options (such as '-f') to be passed to RM. If FILE is a libtool library, all the files associated with it are deleted. Otherwise, only FILE itself is deleted using RM." ;; *) func_fatal_help "invalid operation mode '$opt_mode'" ;; esac echo $ECHO "Try '$progname --help' for more information about other modes." } # Now that we've collected a possible --mode arg, show help if necessary if $opt_help; then if test : = "$opt_help"; then func_mode_help else { func_help noexit for opt_mode in compile link execute install finish uninstall clean; do func_mode_help done } | $SED -n '1p; 2,$s/^Usage:/ or: /p' { func_help noexit for opt_mode in compile link execute install finish uninstall clean; do echo func_mode_help done } | $SED '1d /^When reporting/,/^Report/{ H d } $x /information about other modes/d /more detailed .*MODE/d s/^Usage:.*--mode=\([^ ]*\) .*/Description of \1 mode:/' fi exit $? fi # func_mode_execute arg... func_mode_execute () { $debug_cmd # The first argument is the command name. cmd=$nonopt test -z "$cmd" && \ func_fatal_help "you must specify a COMMAND" # Handle -dlopen flags immediately. for file in $opt_dlopen; do test -f "$file" \ || func_fatal_help "'$file' is not a file" dir= case $file in *.la) func_resolve_sysroot "$file" file=$func_resolve_sysroot_result # Check to see that this really is a libtool archive. func_lalib_unsafe_p "$file" \ || func_fatal_help "'$lib' is not a valid libtool archive" # Read the libtool library. dlname= library_names= func_source "$file" # Skip this library if it cannot be dlopened. if test -z "$dlname"; then # Warn if it was a shared library. test -n "$library_names" && \ func_warning "'$file' was not linked with '-export-dynamic'" continue fi func_dirname "$file" "" "." dir=$func_dirname_result if test -f "$dir/$objdir/$dlname"; then func_append dir "/$objdir" else if test ! -f "$dir/$dlname"; then func_fatal_error "cannot find '$dlname' in '$dir' or '$dir/$objdir'" fi fi ;; *.lo) # Just add the directory containing the .lo file. func_dirname "$file" "" "." dir=$func_dirname_result ;; *) func_warning "'-dlopen' is ignored for non-libtool libraries and objects" continue ;; esac # Get the absolute pathname. absdir=`cd "$dir" && pwd` test -n "$absdir" && dir=$absdir # Now add the directory to shlibpath_var. if eval "test -z \"\$$shlibpath_var\""; then eval "$shlibpath_var=\"\$dir\"" else eval "$shlibpath_var=\"\$dir:\$$shlibpath_var\"" fi done # This variable tells wrapper scripts just to set shlibpath_var # rather than running their programs. libtool_execute_magic=$magic # Check if any of the arguments is a wrapper script. args= for file do case $file in -* | *.la | *.lo ) ;; *) # Do a test to see if this is really a libtool program. if func_ltwrapper_script_p "$file"; then func_source "$file" # Transform arg to wrapped name. file=$progdir/$program elif func_ltwrapper_executable_p "$file"; then func_ltwrapper_scriptname "$file" func_source "$func_ltwrapper_scriptname_result" # Transform arg to wrapped name. file=$progdir/$program fi ;; esac # Quote arguments (to preserve shell metacharacters). func_append_quoted args "$file" done if $opt_dry_run; then # Display what would be done. if test -n "$shlibpath_var"; then eval "\$ECHO \"\$shlibpath_var=\$$shlibpath_var\"" echo "export $shlibpath_var" fi $ECHO "$cmd$args" exit $EXIT_SUCCESS else if test -n "$shlibpath_var"; then # Export the shlibpath_var. eval "export $shlibpath_var" fi # Restore saved environment variables for lt_var in LANG LANGUAGE LC_ALL LC_CTYPE LC_COLLATE LC_MESSAGES do eval "if test \"\${save_$lt_var+set}\" = set; then $lt_var=\$save_$lt_var; export $lt_var else $lt_unset $lt_var fi" done # Now prepare to actually exec the command. exec_cmd=\$cmd$args fi } test execute = "$opt_mode" && func_mode_execute ${1+"$@"} # func_mode_finish arg... func_mode_finish () { $debug_cmd libs= libdirs= admincmds= for opt in "$nonopt" ${1+"$@"} do if test -d "$opt"; then func_append libdirs " $opt" elif test -f "$opt"; then if func_lalib_unsafe_p "$opt"; then func_append libs " $opt" else func_warning "'$opt' is not a valid libtool archive" fi else func_fatal_error "invalid argument '$opt'" fi done if test -n "$libs"; then if test -n "$lt_sysroot"; then sysroot_regex=`$ECHO "$lt_sysroot" | $SED "$sed_make_literal_regex"` sysroot_cmd="s/\([ ']\)$sysroot_regex/\1/g;" else sysroot_cmd= fi # Remove sysroot references if $opt_dry_run; then for lib in $libs; do echo "removing references to $lt_sysroot and '=' prefixes from $lib" done else tmpdir=`func_mktempdir` for lib in $libs; do $SED -e "$sysroot_cmd s/\([ ']-[LR]\)=/\1/g; s/\([ ']\)=/\1/g" $lib \ > $tmpdir/tmp-la mv -f $tmpdir/tmp-la $lib done ${RM}r "$tmpdir" fi fi if test -n "$finish_cmds$finish_eval" && test -n "$libdirs"; then for libdir in $libdirs; do if test -n "$finish_cmds"; then # Do each command in the finish commands. func_execute_cmds "$finish_cmds" 'admincmds="$admincmds '"$cmd"'"' fi if test -n "$finish_eval"; then # Do the single finish_eval. eval cmds=\"$finish_eval\" $opt_dry_run || eval "$cmds" || func_append admincmds " $cmds" fi done fi # Exit here if they wanted silent mode. $opt_quiet && exit $EXIT_SUCCESS if test -n "$finish_cmds$finish_eval" && test -n "$libdirs"; then echo "----------------------------------------------------------------------" echo "Libraries have been installed in:" for libdir in $libdirs; do $ECHO " $libdir" done echo echo "If you ever happen to want to link against installed libraries" echo "in a given directory, LIBDIR, you must either use libtool, and" echo "specify the full pathname of the library, or use the '-LLIBDIR'" echo "flag during linking and do at least one of the following:" if test -n "$shlibpath_var"; then echo " - add LIBDIR to the '$shlibpath_var' environment variable" echo " during execution" fi if test -n "$runpath_var"; then echo " - add LIBDIR to the '$runpath_var' environment variable" echo " during linking" fi if test -n "$hardcode_libdir_flag_spec"; then libdir=LIBDIR eval flag=\"$hardcode_libdir_flag_spec\" $ECHO " - use the '$flag' linker flag" fi if test -n "$admincmds"; then $ECHO " - have your system administrator run these commands:$admincmds" fi if test -f /etc/ld.so.conf; then echo " - have your system administrator add LIBDIR to '/etc/ld.so.conf'" fi echo echo "See any operating system documentation about shared libraries for" case $host in solaris2.[6789]|solaris2.1[0-9]) echo "more information, such as the ld(1), crle(1) and ld.so(8) manual" echo "pages." ;; *) echo "more information, such as the ld(1) and ld.so(8) manual pages." ;; esac echo "----------------------------------------------------------------------" fi exit $EXIT_SUCCESS } test finish = "$opt_mode" && func_mode_finish ${1+"$@"} # func_mode_install arg... func_mode_install () { $debug_cmd # There may be an optional sh(1) argument at the beginning of # install_prog (especially on Windows NT). if test "$SHELL" = "$nonopt" || test /bin/sh = "$nonopt" || # Allow the use of GNU shtool's install command. case $nonopt in *shtool*) :;; *) false;; esac then # Aesthetically quote it. func_quote_for_eval "$nonopt" install_prog="$func_quote_for_eval_result " arg=$1 shift else install_prog= arg=$nonopt fi # The real first argument should be the name of the installation program. # Aesthetically quote it. func_quote_for_eval "$arg" func_append install_prog "$func_quote_for_eval_result" install_shared_prog=$install_prog case " $install_prog " in *[\\\ /]cp\ *) install_cp=: ;; *) install_cp=false ;; esac # We need to accept at least all the BSD install flags. dest= files= opts= prev= install_type= isdir=false stripme= no_mode=: for arg do arg2= if test -n "$dest"; then func_append files " $dest" dest=$arg continue fi case $arg in -d) isdir=: ;; -f) if $install_cp; then :; else prev=$arg fi ;; -g | -m | -o) prev=$arg ;; -s) stripme=" -s" continue ;; -*) ;; *) # If the previous option needed an argument, then skip it. if test -n "$prev"; then if test X-m = "X$prev" && test -n "$install_override_mode"; then arg2=$install_override_mode no_mode=false fi prev= else dest=$arg continue fi ;; esac # Aesthetically quote the argument. func_quote_for_eval "$arg" func_append install_prog " $func_quote_for_eval_result" if test -n "$arg2"; then func_quote_for_eval "$arg2" fi func_append install_shared_prog " $func_quote_for_eval_result" done test -z "$install_prog" && \ func_fatal_help "you must specify an install program" test -n "$prev" && \ func_fatal_help "the '$prev' option requires an argument" if test -n "$install_override_mode" && $no_mode; then if $install_cp; then :; else func_quote_for_eval "$install_override_mode" func_append install_shared_prog " -m $func_quote_for_eval_result" fi fi if test -z "$files"; then if test -z "$dest"; then func_fatal_help "no file or destination specified" else func_fatal_help "you must specify a destination" fi fi # Strip any trailing slash from the destination. func_stripname '' '/' "$dest" dest=$func_stripname_result # Check to see that the destination is a directory. test -d "$dest" && isdir=: if $isdir; then destdir=$dest destname= else func_dirname_and_basename "$dest" "" "." destdir=$func_dirname_result destname=$func_basename_result # Not a directory, so check to see that there is only one file specified. set dummy $files; shift test "$#" -gt 1 && \ func_fatal_help "'$dest' is not a directory" fi case $destdir in [\\/]* | [A-Za-z]:[\\/]*) ;; *) for file in $files; do case $file in *.lo) ;; *) func_fatal_help "'$destdir' must be an absolute directory name" ;; esac done ;; esac # This variable tells wrapper scripts just to set variables rather # than running their programs. libtool_install_magic=$magic staticlibs= future_libdirs= current_libdirs= for file in $files; do # Do each installation. case $file in *.$libext) # Do the static libraries later. func_append staticlibs " $file" ;; *.la) func_resolve_sysroot "$file" file=$func_resolve_sysroot_result # Check to see that this really is a libtool archive. func_lalib_unsafe_p "$file" \ || func_fatal_help "'$file' is not a valid libtool archive" library_names= old_library= relink_command= func_source "$file" # Add the libdir to current_libdirs if it is the destination. if test "X$destdir" = "X$libdir"; then case "$current_libdirs " in *" $libdir "*) ;; *) func_append current_libdirs " $libdir" ;; esac else # Note the libdir as a future libdir. case "$future_libdirs " in *" $libdir "*) ;; *) func_append future_libdirs " $libdir" ;; esac fi func_dirname "$file" "/" "" dir=$func_dirname_result func_append dir "$objdir" if test -n "$relink_command"; then # Determine the prefix the user has applied to our future dir. inst_prefix_dir=`$ECHO "$destdir" | $SED -e "s%$libdir\$%%"` # Don't allow the user to place us outside of our expected # location b/c this prevents finding dependent libraries that # are installed to the same prefix. # At present, this check doesn't affect windows .dll's that # are installed into $libdir/../bin (currently, that works fine) # but it's something to keep an eye on. test "$inst_prefix_dir" = "$destdir" && \ func_fatal_error "error: cannot install '$file' to a directory not ending in $libdir" if test -n "$inst_prefix_dir"; then # Stick the inst_prefix_dir data into the link command. relink_command=`$ECHO "$relink_command" | $SED "s%@inst_prefix_dir@%-inst-prefix-dir $inst_prefix_dir%"` else relink_command=`$ECHO "$relink_command" | $SED "s%@inst_prefix_dir@%%"` fi func_warning "relinking '$file'" func_show_eval "$relink_command" \ 'func_fatal_error "error: relink '\''$file'\'' with the above command before installing it"' fi # See the names of the shared library. set dummy $library_names; shift if test -n "$1"; then realname=$1 shift srcname=$realname test -n "$relink_command" && srcname=${realname}T # Install the shared library and build the symlinks. func_show_eval "$install_shared_prog $dir/$srcname $destdir/$realname" \ 'exit $?' tstripme=$stripme case $host_os in cygwin* | mingw* | pw32* | cegcc*) case $realname in *.dll.a) tstripme= ;; esac ;; os2*) case $realname in *_dll.a) tstripme= ;; esac ;; esac if test -n "$tstripme" && test -n "$striplib"; then func_show_eval "$striplib $destdir/$realname" 'exit $?' fi if test "$#" -gt 0; then # Delete the old symlinks, and create new ones. # Try 'ln -sf' first, because the 'ln' binary might depend on # the symlink we replace! Solaris /bin/ln does not understand -f, # so we also need to try rm && ln -s. for linkname do test "$linkname" != "$realname" \ && func_show_eval "(cd $destdir && { $LN_S -f $realname $linkname || { $RM $linkname && $LN_S $realname $linkname; }; })" done fi # Do each command in the postinstall commands. lib=$destdir/$realname func_execute_cmds "$postinstall_cmds" 'exit $?' fi # Install the pseudo-library for information purposes. func_basename "$file" name=$func_basename_result instname=$dir/${name}i func_show_eval "$install_prog $instname $destdir/$name" 'exit $?' # Maybe install the static library, too. test -n "$old_library" && func_append staticlibs " $dir/$old_library" ;; *.lo) # Install (i.e. copy) a libtool object. # Figure out destination file name, if it wasn't already specified. if test -n "$destname"; then destfile=$destdir/$destname else func_basename "$file" destfile=$func_basename_result destfile=$destdir/$destfile fi # Deduce the name of the destination old-style object file. case $destfile in *.lo) func_lo2o "$destfile" staticdest=$func_lo2o_result ;; *.$objext) staticdest=$destfile destfile= ;; *) func_fatal_help "cannot copy a libtool object to '$destfile'" ;; esac # Install the libtool object if requested. test -n "$destfile" && \ func_show_eval "$install_prog $file $destfile" 'exit $?' # Install the old object if enabled. if test yes = "$build_old_libs"; then # Deduce the name of the old-style object file. func_lo2o "$file" staticobj=$func_lo2o_result func_show_eval "$install_prog \$staticobj \$staticdest" 'exit $?' fi exit $EXIT_SUCCESS ;; *) # Figure out destination file name, if it wasn't already specified. if test -n "$destname"; then destfile=$destdir/$destname else func_basename "$file" destfile=$func_basename_result destfile=$destdir/$destfile fi # If the file is missing, and there is a .exe on the end, strip it # because it is most likely a libtool script we actually want to # install stripped_ext= case $file in *.exe) if test ! -f "$file"; then func_stripname '' '.exe' "$file" file=$func_stripname_result stripped_ext=.exe fi ;; esac # Do a test to see if this is really a libtool program. case $host in *cygwin* | *mingw*) if func_ltwrapper_executable_p "$file"; then func_ltwrapper_scriptname "$file" wrapper=$func_ltwrapper_scriptname_result else func_stripname '' '.exe' "$file" wrapper=$func_stripname_result fi ;; *) wrapper=$file ;; esac if func_ltwrapper_script_p "$wrapper"; then notinst_deplibs= relink_command= func_source "$wrapper" # Check the variables that should have been set. test -z "$generated_by_libtool_version" && \ func_fatal_error "invalid libtool wrapper script '$wrapper'" finalize=: for lib in $notinst_deplibs; do # Check to see that each library is installed. libdir= if test -f "$lib"; then func_source "$lib" fi libfile=$libdir/`$ECHO "$lib" | $SED 's%^.*/%%g'` if test -n "$libdir" && test ! -f "$libfile"; then func_warning "'$lib' has not been installed in '$libdir'" finalize=false fi done relink_command= func_source "$wrapper" outputname= if test no = "$fast_install" && test -n "$relink_command"; then $opt_dry_run || { if $finalize; then tmpdir=`func_mktempdir` func_basename "$file$stripped_ext" file=$func_basename_result outputname=$tmpdir/$file # Replace the output file specification. relink_command=`$ECHO "$relink_command" | $SED 's%@OUTPUT@%'"$outputname"'%g'` $opt_quiet || { func_quote_for_expand "$relink_command" eval "func_echo $func_quote_for_expand_result" } if eval "$relink_command"; then : else func_error "error: relink '$file' with the above command before installing it" $opt_dry_run || ${RM}r "$tmpdir" continue fi file=$outputname else func_warning "cannot relink '$file'" fi } else # Install the binary that we compiled earlier. file=`$ECHO "$file$stripped_ext" | $SED "s%\([^/]*\)$%$objdir/\1%"` fi fi # remove .exe since cygwin /usr/bin/install will append another # one anyway case $install_prog,$host in */usr/bin/install*,*cygwin*) case $file:$destfile in *.exe:*.exe) # this is ok ;; *.exe:*) destfile=$destfile.exe ;; *:*.exe) func_stripname '' '.exe' "$destfile" destfile=$func_stripname_result ;; esac ;; esac func_show_eval "$install_prog\$stripme \$file \$destfile" 'exit $?' $opt_dry_run || if test -n "$outputname"; then ${RM}r "$tmpdir" fi ;; esac done for file in $staticlibs; do func_basename "$file" name=$func_basename_result # Set up the ranlib parameters. oldlib=$destdir/$name func_to_tool_file "$oldlib" func_convert_file_msys_to_w32 tool_oldlib=$func_to_tool_file_result func_show_eval "$install_prog \$file \$oldlib" 'exit $?' if test -n "$stripme" && test -n "$old_striplib"; then func_show_eval "$old_striplib $tool_oldlib" 'exit $?' fi # Do each command in the postinstall commands. func_execute_cmds "$old_postinstall_cmds" 'exit $?' done test -n "$future_libdirs" && \ func_warning "remember to run '$progname --finish$future_libdirs'" if test -n "$current_libdirs"; then # Maybe just do a dry run. $opt_dry_run && current_libdirs=" -n$current_libdirs" exec_cmd='$SHELL "$progpath" $preserve_args --finish$current_libdirs' else exit $EXIT_SUCCESS fi } test install = "$opt_mode" && func_mode_install ${1+"$@"} # func_generate_dlsyms outputname originator pic_p # Extract symbols from dlprefiles and create ${outputname}S.o with # a dlpreopen symbol table. func_generate_dlsyms () { $debug_cmd my_outputname=$1 my_originator=$2 my_pic_p=${3-false} my_prefix=`$ECHO "$my_originator" | $SED 's%[^a-zA-Z0-9]%_%g'` my_dlsyms= if test -n "$dlfiles$dlprefiles" || test no != "$dlself"; then if test -n "$NM" && test -n "$global_symbol_pipe"; then my_dlsyms=${my_outputname}S.c else func_error "not configured to extract global symbols from dlpreopened files" fi fi if test -n "$my_dlsyms"; then case $my_dlsyms in "") ;; *.c) # Discover the nlist of each of the dlfiles. nlist=$output_objdir/$my_outputname.nm func_show_eval "$RM $nlist ${nlist}S ${nlist}T" # Parse the name list into a source file. func_verbose "creating $output_objdir/$my_dlsyms" $opt_dry_run || $ECHO > "$output_objdir/$my_dlsyms" "\ /* $my_dlsyms - symbol resolution table for '$my_outputname' dlsym emulation. */ /* Generated by $PROGRAM (GNU $PACKAGE) $VERSION */ #ifdef __cplusplus extern \"C\" { #endif #if defined __GNUC__ && (((__GNUC__ == 4) && (__GNUC_MINOR__ >= 4)) || (__GNUC__ > 4)) #pragma GCC diagnostic ignored \"-Wstrict-prototypes\" #endif /* Keep this code in sync between libtool.m4, ltmain, lt_system.h, and tests. */ #if defined _WIN32 || defined __CYGWIN__ || defined _WIN32_WCE /* DATA imports from DLLs on WIN32 can't be const, because runtime relocations are performed -- see ld's documentation on pseudo-relocs. */ # define LT_DLSYM_CONST #elif defined __osf__ /* This system does not cope well with relocations in const data. */ # define LT_DLSYM_CONST #else # define LT_DLSYM_CONST const #endif #define STREQ(s1, s2) (strcmp ((s1), (s2)) == 0) /* External symbol declarations for the compiler. */\ " if test yes = "$dlself"; then func_verbose "generating symbol list for '$output'" $opt_dry_run || echo ': @PROGRAM@ ' > "$nlist" # Add our own program objects to the symbol list. progfiles=`$ECHO "$objs$old_deplibs" | $SP2NL | $SED "$lo2o" | $NL2SP` for progfile in $progfiles; do func_to_tool_file "$progfile" func_convert_file_msys_to_w32 func_verbose "extracting global C symbols from '$func_to_tool_file_result'" $opt_dry_run || eval "$NM $func_to_tool_file_result | $global_symbol_pipe >> '$nlist'" done if test -n "$exclude_expsyms"; then $opt_dry_run || { eval '$EGREP -v " ($exclude_expsyms)$" "$nlist" > "$nlist"T' eval '$MV "$nlist"T "$nlist"' } fi if test -n "$export_symbols_regex"; then $opt_dry_run || { eval '$EGREP -e "$export_symbols_regex" "$nlist" > "$nlist"T' eval '$MV "$nlist"T "$nlist"' } fi # Prepare the list of exported symbols if test -z "$export_symbols"; then export_symbols=$output_objdir/$outputname.exp $opt_dry_run || { $RM $export_symbols eval "$SED -n -e '/^: @PROGRAM@ $/d' -e 's/^.* \(.*\)$/\1/p' "'< "$nlist" > "$export_symbols"' case $host in *cygwin* | *mingw* | *cegcc* ) eval "echo EXPORTS "'> "$output_objdir/$outputname.def"' eval 'cat "$export_symbols" >> "$output_objdir/$outputname.def"' ;; esac } else $opt_dry_run || { eval "$SED -e 's/\([].[*^$]\)/\\\\\1/g' -e 's/^/ /' -e 's/$/$/'"' < "$export_symbols" > "$output_objdir/$outputname.exp"' eval '$GREP -f "$output_objdir/$outputname.exp" < "$nlist" > "$nlist"T' eval '$MV "$nlist"T "$nlist"' case $host in *cygwin* | *mingw* | *cegcc* ) eval "echo EXPORTS "'> "$output_objdir/$outputname.def"' eval 'cat "$nlist" >> "$output_objdir/$outputname.def"' ;; esac } fi fi for dlprefile in $dlprefiles; do func_verbose "extracting global C symbols from '$dlprefile'" func_basename "$dlprefile" name=$func_basename_result case $host in *cygwin* | *mingw* | *cegcc* ) # if an import library, we need to obtain dlname if func_win32_import_lib_p "$dlprefile"; then func_tr_sh "$dlprefile" eval "curr_lafile=\$libfile_$func_tr_sh_result" dlprefile_dlbasename= if test -n "$curr_lafile" && func_lalib_p "$curr_lafile"; then # Use subshell, to avoid clobbering current variable values dlprefile_dlname=`source "$curr_lafile" && echo "$dlname"` if test -n "$dlprefile_dlname"; then func_basename "$dlprefile_dlname" dlprefile_dlbasename=$func_basename_result else # no lafile. user explicitly requested -dlpreopen . $sharedlib_from_linklib_cmd "$dlprefile" dlprefile_dlbasename=$sharedlib_from_linklib_result fi fi $opt_dry_run || { if test -n "$dlprefile_dlbasename"; then eval '$ECHO ": $dlprefile_dlbasename" >> "$nlist"' else func_warning "Could not compute DLL name from $name" eval '$ECHO ": $name " >> "$nlist"' fi func_to_tool_file "$dlprefile" func_convert_file_msys_to_w32 eval "$NM \"$func_to_tool_file_result\" 2>/dev/null | $global_symbol_pipe | $SED -e '/I __imp/d' -e 's/I __nm_/D /;s/_nm__//' >> '$nlist'" } else # not an import lib $opt_dry_run || { eval '$ECHO ": $name " >> "$nlist"' func_to_tool_file "$dlprefile" func_convert_file_msys_to_w32 eval "$NM \"$func_to_tool_file_result\" 2>/dev/null | $global_symbol_pipe >> '$nlist'" } fi ;; *) $opt_dry_run || { eval '$ECHO ": $name " >> "$nlist"' func_to_tool_file "$dlprefile" func_convert_file_msys_to_w32 eval "$NM \"$func_to_tool_file_result\" 2>/dev/null | $global_symbol_pipe >> '$nlist'" } ;; esac done $opt_dry_run || { # Make sure we have at least an empty file. test -f "$nlist" || : > "$nlist" if test -n "$exclude_expsyms"; then $EGREP -v " ($exclude_expsyms)$" "$nlist" > "$nlist"T $MV "$nlist"T "$nlist" fi # Try sorting and uniquifying the output. if $GREP -v "^: " < "$nlist" | if sort -k 3 /dev/null 2>&1; then sort -k 3 else sort +2 fi | uniq > "$nlist"S; then : else $GREP -v "^: " < "$nlist" > "$nlist"S fi if test -f "$nlist"S; then eval "$global_symbol_to_cdecl"' < "$nlist"S >> "$output_objdir/$my_dlsyms"' else echo '/* NONE */' >> "$output_objdir/$my_dlsyms" fi func_show_eval '$RM "${nlist}I"' if test -n "$global_symbol_to_import"; then eval "$global_symbol_to_import"' < "$nlist"S > "$nlist"I' fi echo >> "$output_objdir/$my_dlsyms" "\ /* The mapping between symbol names and symbols. */ typedef struct { const char *name; void *address; } lt_dlsymlist; extern LT_DLSYM_CONST lt_dlsymlist lt_${my_prefix}_LTX_preloaded_symbols[];\ " if test -s "$nlist"I; then echo >> "$output_objdir/$my_dlsyms" "\ static void lt_syminit(void) { LT_DLSYM_CONST lt_dlsymlist *symbol = lt_${my_prefix}_LTX_preloaded_symbols; for (; symbol->name; ++symbol) {" $SED 's/.*/ if (STREQ (symbol->name, \"&\")) symbol->address = (void *) \&&;/' < "$nlist"I >> "$output_objdir/$my_dlsyms" echo >> "$output_objdir/$my_dlsyms" "\ } }" fi echo >> "$output_objdir/$my_dlsyms" "\ LT_DLSYM_CONST lt_dlsymlist lt_${my_prefix}_LTX_preloaded_symbols[] = { {\"$my_originator\", (void *) 0}," if test -s "$nlist"I; then echo >> "$output_objdir/$my_dlsyms" "\ {\"@INIT@\", (void *) <_syminit}," fi case $need_lib_prefix in no) eval "$global_symbol_to_c_name_address" < "$nlist" >> "$output_objdir/$my_dlsyms" ;; *) eval "$global_symbol_to_c_name_address_lib_prefix" < "$nlist" >> "$output_objdir/$my_dlsyms" ;; esac echo >> "$output_objdir/$my_dlsyms" "\ {0, (void *) 0} }; /* This works around a problem in FreeBSD linker */ #ifdef FREEBSD_WORKAROUND static const void *lt_preloaded_setup() { return lt_${my_prefix}_LTX_preloaded_symbols; } #endif #ifdef __cplusplus } #endif\ " } # !$opt_dry_run pic_flag_for_symtable= case "$compile_command " in *" -static "*) ;; *) case $host in # compiling the symbol table file with pic_flag works around # a FreeBSD bug that causes programs to crash when -lm is # linked before any other PIC object. But we must not use # pic_flag when linking with -static. The problem exists in # FreeBSD 2.2.6 and is fixed in FreeBSD 3.1. *-*-freebsd2.*|*-*-freebsd3.0*|*-*-freebsdelf3.0*) pic_flag_for_symtable=" $pic_flag -DFREEBSD_WORKAROUND" ;; *-*-hpux*) pic_flag_for_symtable=" $pic_flag" ;; *) $my_pic_p && pic_flag_for_symtable=" $pic_flag" ;; esac ;; esac symtab_cflags= for arg in $LTCFLAGS; do case $arg in -pie | -fpie | -fPIE) ;; *) func_append symtab_cflags " $arg" ;; esac done # Now compile the dynamic symbol file. func_show_eval '(cd $output_objdir && $LTCC$symtab_cflags -c$no_builtin_flag$pic_flag_for_symtable "$my_dlsyms")' 'exit $?' # Clean up the generated files. func_show_eval '$RM "$output_objdir/$my_dlsyms" "$nlist" "${nlist}S" "${nlist}T" "${nlist}I"' # Transform the symbol file into the correct name. symfileobj=$output_objdir/${my_outputname}S.$objext case $host in *cygwin* | *mingw* | *cegcc* ) if test -f "$output_objdir/$my_outputname.def"; then compile_command=`$ECHO "$compile_command" | $SED "s%@SYMFILE@%$output_objdir/$my_outputname.def $symfileobj%"` finalize_command=`$ECHO "$finalize_command" | $SED "s%@SYMFILE@%$output_objdir/$my_outputname.def $symfileobj%"` else compile_command=`$ECHO "$compile_command" | $SED "s%@SYMFILE@%$symfileobj%"` finalize_command=`$ECHO "$finalize_command" | $SED "s%@SYMFILE@%$symfileobj%"` fi ;; *) compile_command=`$ECHO "$compile_command" | $SED "s%@SYMFILE@%$symfileobj%"` finalize_command=`$ECHO "$finalize_command" | $SED "s%@SYMFILE@%$symfileobj%"` ;; esac ;; *) func_fatal_error "unknown suffix for '$my_dlsyms'" ;; esac else # We keep going just in case the user didn't refer to # lt_preloaded_symbols. The linker will fail if global_symbol_pipe # really was required. # Nullify the symbol file. compile_command=`$ECHO "$compile_command" | $SED "s% @SYMFILE@%%"` finalize_command=`$ECHO "$finalize_command" | $SED "s% @SYMFILE@%%"` fi } # func_cygming_gnu_implib_p ARG # This predicate returns with zero status (TRUE) if # ARG is a GNU/binutils-style import library. Returns # with nonzero status (FALSE) otherwise. func_cygming_gnu_implib_p () { $debug_cmd func_to_tool_file "$1" func_convert_file_msys_to_w32 func_cygming_gnu_implib_tmp=`$NM "$func_to_tool_file_result" | eval "$global_symbol_pipe" | $EGREP ' (_head_[A-Za-z0-9_]+_[ad]l*|[A-Za-z0-9_]+_[ad]l*_iname)$'` test -n "$func_cygming_gnu_implib_tmp" } # func_cygming_ms_implib_p ARG # This predicate returns with zero status (TRUE) if # ARG is an MS-style import library. Returns # with nonzero status (FALSE) otherwise. func_cygming_ms_implib_p () { $debug_cmd func_to_tool_file "$1" func_convert_file_msys_to_w32 func_cygming_ms_implib_tmp=`$NM "$func_to_tool_file_result" | eval "$global_symbol_pipe" | $GREP '_NULL_IMPORT_DESCRIPTOR'` test -n "$func_cygming_ms_implib_tmp" } # func_win32_libid arg # return the library type of file 'arg' # # Need a lot of goo to handle *both* DLLs and import libs # Has to be a shell function in order to 'eat' the argument # that is supplied when $file_magic_command is called. # Despite the name, also deal with 64 bit binaries. func_win32_libid () { $debug_cmd win32_libid_type=unknown win32_fileres=`file -L $1 2>/dev/null` case $win32_fileres in *ar\ archive\ import\ library*) # definitely import win32_libid_type="x86 archive import" ;; *ar\ archive*) # could be an import, or static # Keep the egrep pattern in sync with the one in _LT_CHECK_MAGIC_METHOD. if eval $OBJDUMP -f $1 | $SED -e '10q' 2>/dev/null | $EGREP 'file format (pei*-i386(.*architecture: i386)?|pe-arm-wince|pe-x86-64)' >/dev/null; then case $nm_interface in "MS dumpbin") if func_cygming_ms_implib_p "$1" || func_cygming_gnu_implib_p "$1" then win32_nmres=import else win32_nmres= fi ;; *) func_to_tool_file "$1" func_convert_file_msys_to_w32 win32_nmres=`eval $NM -f posix -A \"$func_to_tool_file_result\" | $SED -n -e ' 1,100{ / I /{ s|.*|import| p q } }'` ;; esac case $win32_nmres in import*) win32_libid_type="x86 archive import";; *) win32_libid_type="x86 archive static";; esac fi ;; *DLL*) win32_libid_type="x86 DLL" ;; *executable*) # but shell scripts are "executable" too... case $win32_fileres in *MS\ Windows\ PE\ Intel*) win32_libid_type="x86 DLL" ;; esac ;; esac $ECHO "$win32_libid_type" } # func_cygming_dll_for_implib ARG # # Platform-specific function to extract the # name of the DLL associated with the specified # import library ARG. # Invoked by eval'ing the libtool variable # $sharedlib_from_linklib_cmd # Result is available in the variable # $sharedlib_from_linklib_result func_cygming_dll_for_implib () { $debug_cmd sharedlib_from_linklib_result=`$DLLTOOL --identify-strict --identify "$1"` } # func_cygming_dll_for_implib_fallback_core SECTION_NAME LIBNAMEs # # The is the core of a fallback implementation of a # platform-specific function to extract the name of the # DLL associated with the specified import library LIBNAME. # # SECTION_NAME is either .idata$6 or .idata$7, depending # on the platform and compiler that created the implib. # # Echos the name of the DLL associated with the # specified import library. func_cygming_dll_for_implib_fallback_core () { $debug_cmd match_literal=`$ECHO "$1" | $SED "$sed_make_literal_regex"` $OBJDUMP -s --section "$1" "$2" 2>/dev/null | $SED '/^Contents of section '"$match_literal"':/{ # Place marker at beginning of archive member dllname section s/.*/====MARK====/ p d } # These lines can sometimes be longer than 43 characters, but # are always uninteresting /:[ ]*file format pe[i]\{,1\}-/d /^In archive [^:]*:/d # Ensure marker is printed /^====MARK====/p # Remove all lines with less than 43 characters /^.\{43\}/!d # From remaining lines, remove first 43 characters s/^.\{43\}//' | $SED -n ' # Join marker and all lines until next marker into a single line /^====MARK====/ b para H $ b para b :para x s/\n//g # Remove the marker s/^====MARK====// # Remove trailing dots and whitespace s/[\. \t]*$// # Print /./p' | # we now have a list, one entry per line, of the stringified # contents of the appropriate section of all members of the # archive that possess that section. Heuristic: eliminate # all those that have a first or second character that is # a '.' (that is, objdump's representation of an unprintable # character.) This should work for all archives with less than # 0x302f exports -- but will fail for DLLs whose name actually # begins with a literal '.' or a single character followed by # a '.'. # # Of those that remain, print the first one. $SED -e '/^\./d;/^.\./d;q' } # func_cygming_dll_for_implib_fallback ARG # Platform-specific function to extract the # name of the DLL associated with the specified # import library ARG. # # This fallback implementation is for use when $DLLTOOL # does not support the --identify-strict option. # Invoked by eval'ing the libtool variable # $sharedlib_from_linklib_cmd # Result is available in the variable # $sharedlib_from_linklib_result func_cygming_dll_for_implib_fallback () { $debug_cmd if func_cygming_gnu_implib_p "$1"; then # binutils import library sharedlib_from_linklib_result=`func_cygming_dll_for_implib_fallback_core '.idata$7' "$1"` elif func_cygming_ms_implib_p "$1"; then # ms-generated import library sharedlib_from_linklib_result=`func_cygming_dll_for_implib_fallback_core '.idata$6' "$1"` else # unknown sharedlib_from_linklib_result= fi } # func_extract_an_archive dir oldlib func_extract_an_archive () { $debug_cmd f_ex_an_ar_dir=$1; shift f_ex_an_ar_oldlib=$1 if test yes = "$lock_old_archive_extraction"; then lockfile=$f_ex_an_ar_oldlib.lock until $opt_dry_run || ln "$progpath" "$lockfile" 2>/dev/null; do func_echo "Waiting for $lockfile to be removed" sleep 2 done fi func_show_eval "(cd \$f_ex_an_ar_dir && $AR x \"\$f_ex_an_ar_oldlib\")" \ 'stat=$?; rm -f "$lockfile"; exit $stat' if test yes = "$lock_old_archive_extraction"; then $opt_dry_run || rm -f "$lockfile" fi if ($AR t "$f_ex_an_ar_oldlib" | sort | sort -uc >/dev/null 2>&1); then : else func_fatal_error "object name conflicts in archive: $f_ex_an_ar_dir/$f_ex_an_ar_oldlib" fi } # func_extract_archives gentop oldlib ... func_extract_archives () { $debug_cmd my_gentop=$1; shift my_oldlibs=${1+"$@"} my_oldobjs= my_xlib= my_xabs= my_xdir= for my_xlib in $my_oldlibs; do # Extract the objects. case $my_xlib in [\\/]* | [A-Za-z]:[\\/]*) my_xabs=$my_xlib ;; *) my_xabs=`pwd`"/$my_xlib" ;; esac func_basename "$my_xlib" my_xlib=$func_basename_result my_xlib_u=$my_xlib while :; do case " $extracted_archives " in *" $my_xlib_u "*) func_arith $extracted_serial + 1 extracted_serial=$func_arith_result my_xlib_u=lt$extracted_serial-$my_xlib ;; *) break ;; esac done extracted_archives="$extracted_archives $my_xlib_u" my_xdir=$my_gentop/$my_xlib_u func_mkdir_p "$my_xdir" case $host in *-darwin*) func_verbose "Extracting $my_xabs" # Do not bother doing anything if just a dry run $opt_dry_run || { darwin_orig_dir=`pwd` cd $my_xdir || exit $? darwin_archive=$my_xabs darwin_curdir=`pwd` func_basename "$darwin_archive" darwin_base_archive=$func_basename_result darwin_arches=`$LIPO -info "$darwin_archive" 2>/dev/null | $GREP Architectures 2>/dev/null || true` if test -n "$darwin_arches"; then darwin_arches=`$ECHO "$darwin_arches" | $SED -e 's/.*are://'` darwin_arch= func_verbose "$darwin_base_archive has multiple architectures $darwin_arches" for darwin_arch in $darwin_arches; do func_mkdir_p "unfat-$$/$darwin_base_archive-$darwin_arch" $LIPO -thin $darwin_arch -output "unfat-$$/$darwin_base_archive-$darwin_arch/$darwin_base_archive" "$darwin_archive" cd "unfat-$$/$darwin_base_archive-$darwin_arch" func_extract_an_archive "`pwd`" "$darwin_base_archive" cd "$darwin_curdir" $RM "unfat-$$/$darwin_base_archive-$darwin_arch/$darwin_base_archive" done # $darwin_arches ## Okay now we've a bunch of thin objects, gotta fatten them up :) darwin_filelist=`find unfat-$$ -type f -name \*.o -print -o -name \*.lo -print | $SED -e "$sed_basename" | sort -u` darwin_file= darwin_files= for darwin_file in $darwin_filelist; do darwin_files=`find unfat-$$ -name $darwin_file -print | sort | $NL2SP` $LIPO -create -output "$darwin_file" $darwin_files done # $darwin_filelist $RM -rf unfat-$$ cd "$darwin_orig_dir" else cd $darwin_orig_dir func_extract_an_archive "$my_xdir" "$my_xabs" fi # $darwin_arches } # !$opt_dry_run ;; *) func_extract_an_archive "$my_xdir" "$my_xabs" ;; esac my_oldobjs="$my_oldobjs "`find $my_xdir -name \*.$objext -print -o -name \*.lo -print | sort | $NL2SP` done func_extract_archives_result=$my_oldobjs } # func_emit_wrapper [arg=no] # # Emit a libtool wrapper script on stdout. # Don't directly open a file because we may want to # incorporate the script contents within a cygwin/mingw # wrapper executable. Must ONLY be called from within # func_mode_link because it depends on a number of variables # set therein. # # ARG is the value that the WRAPPER_SCRIPT_BELONGS_IN_OBJDIR # variable will take. If 'yes', then the emitted script # will assume that the directory where it is stored is # the $objdir directory. This is a cygwin/mingw-specific # behavior. func_emit_wrapper () { func_emit_wrapper_arg1=${1-no} $ECHO "\ #! $SHELL # $output - temporary wrapper script for $objdir/$outputname # Generated by $PROGRAM (GNU $PACKAGE) $VERSION # # The $output program cannot be directly executed until all the libtool # libraries that it depends on are installed. # # This wrapper script should never be moved out of the build directory. # If it is, it will not operate correctly. # Sed substitution that helps us do robust quoting. It backslashifies # metacharacters that are still active within double-quoted strings. sed_quote_subst='$sed_quote_subst' # Be Bourne compatible if test -n \"\${ZSH_VERSION+set}\" && (emulate sh) >/dev/null 2>&1; then emulate sh NULLCMD=: # Zsh 3.x and 4.x performs word splitting on \${1+\"\$@\"}, which # is contrary to our usage. Disable this feature. alias -g '\${1+\"\$@\"}'='\"\$@\"' setopt NO_GLOB_SUBST else case \`(set -o) 2>/dev/null\` in *posix*) set -o posix;; esac fi BIN_SH=xpg4; export BIN_SH # for Tru64 DUALCASE=1; export DUALCASE # for MKS sh # The HP-UX ksh and POSIX shell print the target directory to stdout # if CDPATH is set. (unset CDPATH) >/dev/null 2>&1 && unset CDPATH relink_command=\"$relink_command\" # This environment variable determines our operation mode. if test \"\$libtool_install_magic\" = \"$magic\"; then # install mode needs the following variables: generated_by_libtool_version='$macro_version' notinst_deplibs='$notinst_deplibs' else # When we are sourced in execute mode, \$file and \$ECHO are already set. if test \"\$libtool_execute_magic\" != \"$magic\"; then file=\"\$0\"" qECHO=`$ECHO "$ECHO" | $SED "$sed_quote_subst"` $ECHO "\ # A function that is used when there is no print builtin or printf. func_fallback_echo () { eval 'cat <<_LTECHO_EOF \$1 _LTECHO_EOF' } ECHO=\"$qECHO\" fi # Very basic option parsing. These options are (a) specific to # the libtool wrapper, (b) are identical between the wrapper # /script/ and the wrapper /executable/ that is used only on # windows platforms, and (c) all begin with the string "--lt-" # (application programs are unlikely to have options that match # this pattern). # # There are only two supported options: --lt-debug and # --lt-dump-script. There is, deliberately, no --lt-help. # # The first argument to this parsing function should be the # script's $0 value, followed by "$@". lt_option_debug= func_parse_lt_options () { lt_script_arg0=\$0 shift for lt_opt do case \"\$lt_opt\" in --lt-debug) lt_option_debug=1 ;; --lt-dump-script) lt_dump_D=\`\$ECHO \"X\$lt_script_arg0\" | $SED -e 's/^X//' -e 's%/[^/]*$%%'\` test \"X\$lt_dump_D\" = \"X\$lt_script_arg0\" && lt_dump_D=. lt_dump_F=\`\$ECHO \"X\$lt_script_arg0\" | $SED -e 's/^X//' -e 's%^.*/%%'\` cat \"\$lt_dump_D/\$lt_dump_F\" exit 0 ;; --lt-*) \$ECHO \"Unrecognized --lt- option: '\$lt_opt'\" 1>&2 exit 1 ;; esac done # Print the debug banner immediately: if test -n \"\$lt_option_debug\"; then echo \"$outputname:$output:\$LINENO: libtool wrapper (GNU $PACKAGE) $VERSION\" 1>&2 fi } # Used when --lt-debug. Prints its arguments to stdout # (redirection is the responsibility of the caller) func_lt_dump_args () { lt_dump_args_N=1; for lt_arg do \$ECHO \"$outputname:$output:\$LINENO: newargv[\$lt_dump_args_N]: \$lt_arg\" lt_dump_args_N=\`expr \$lt_dump_args_N + 1\` done } # Core function for launching the target application func_exec_program_core () { " case $host in # Backslashes separate directories on plain windows *-*-mingw | *-*-os2* | *-cegcc*) $ECHO "\ if test -n \"\$lt_option_debug\"; then \$ECHO \"$outputname:$output:\$LINENO: newargv[0]: \$progdir\\\\\$program\" 1>&2 func_lt_dump_args \${1+\"\$@\"} 1>&2 fi exec \"\$progdir\\\\\$program\" \${1+\"\$@\"} " ;; *) $ECHO "\ if test -n \"\$lt_option_debug\"; then \$ECHO \"$outputname:$output:\$LINENO: newargv[0]: \$progdir/\$program\" 1>&2 func_lt_dump_args \${1+\"\$@\"} 1>&2 fi exec \"\$progdir/\$program\" \${1+\"\$@\"} " ;; esac $ECHO "\ \$ECHO \"\$0: cannot exec \$program \$*\" 1>&2 exit 1 } # A function to encapsulate launching the target application # Strips options in the --lt-* namespace from \$@ and # launches target application with the remaining arguments. func_exec_program () { case \" \$* \" in *\\ --lt-*) for lt_wr_arg do case \$lt_wr_arg in --lt-*) ;; *) set x \"\$@\" \"\$lt_wr_arg\"; shift;; esac shift done ;; esac func_exec_program_core \${1+\"\$@\"} } # Parse options func_parse_lt_options \"\$0\" \${1+\"\$@\"} # Find the directory that this script lives in. thisdir=\`\$ECHO \"\$file\" | $SED 's%/[^/]*$%%'\` test \"x\$thisdir\" = \"x\$file\" && thisdir=. # Follow symbolic links until we get to the real thisdir. file=\`ls -ld \"\$file\" | $SED -n 's/.*-> //p'\` while test -n \"\$file\"; do destdir=\`\$ECHO \"\$file\" | $SED 's%/[^/]*\$%%'\` # If there was a directory component, then change thisdir. if test \"x\$destdir\" != \"x\$file\"; then case \"\$destdir\" in [\\\\/]* | [A-Za-z]:[\\\\/]*) thisdir=\"\$destdir\" ;; *) thisdir=\"\$thisdir/\$destdir\" ;; esac fi file=\`\$ECHO \"\$file\" | $SED 's%^.*/%%'\` file=\`ls -ld \"\$thisdir/\$file\" | $SED -n 's/.*-> //p'\` done # Usually 'no', except on cygwin/mingw when embedded into # the cwrapper. WRAPPER_SCRIPT_BELONGS_IN_OBJDIR=$func_emit_wrapper_arg1 if test \"\$WRAPPER_SCRIPT_BELONGS_IN_OBJDIR\" = \"yes\"; then # special case for '.' if test \"\$thisdir\" = \".\"; then thisdir=\`pwd\` fi # remove .libs from thisdir case \"\$thisdir\" in *[\\\\/]$objdir ) thisdir=\`\$ECHO \"\$thisdir\" | $SED 's%[\\\\/][^\\\\/]*$%%'\` ;; $objdir ) thisdir=. ;; esac fi # Try to get the absolute directory name. absdir=\`cd \"\$thisdir\" && pwd\` test -n \"\$absdir\" && thisdir=\"\$absdir\" " if test yes = "$fast_install"; then $ECHO "\ program=lt-'$outputname'$exeext progdir=\"\$thisdir/$objdir\" if test ! -f \"\$progdir/\$program\" || { file=\`ls -1dt \"\$progdir/\$program\" \"\$progdir/../\$program\" 2>/dev/null | $SED 1q\`; \\ test \"X\$file\" != \"X\$progdir/\$program\"; }; then file=\"\$\$-\$program\" if test ! -d \"\$progdir\"; then $MKDIR \"\$progdir\" else $RM \"\$progdir/\$file\" fi" $ECHO "\ # relink executable if necessary if test -n \"\$relink_command\"; then if relink_command_output=\`eval \$relink_command 2>&1\`; then : else \$ECHO \"\$relink_command_output\" >&2 $RM \"\$progdir/\$file\" exit 1 fi fi $MV \"\$progdir/\$file\" \"\$progdir/\$program\" 2>/dev/null || { $RM \"\$progdir/\$program\"; $MV \"\$progdir/\$file\" \"\$progdir/\$program\"; } $RM \"\$progdir/\$file\" fi" else $ECHO "\ program='$outputname' progdir=\"\$thisdir/$objdir\" " fi $ECHO "\ if test -f \"\$progdir/\$program\"; then" # fixup the dll searchpath if we need to. # # Fix the DLL searchpath if we need to. Do this before prepending # to shlibpath, because on Windows, both are PATH and uninstalled # libraries must come first. if test -n "$dllsearchpath"; then $ECHO "\ # Add the dll search path components to the executable PATH PATH=$dllsearchpath:\$PATH " fi # Export our shlibpath_var if we have one. if test yes = "$shlibpath_overrides_runpath" && test -n "$shlibpath_var" && test -n "$temp_rpath"; then $ECHO "\ # Add our own library path to $shlibpath_var $shlibpath_var=\"$temp_rpath\$$shlibpath_var\" # Some systems cannot cope with colon-terminated $shlibpath_var # The second colon is a workaround for a bug in BeOS R4 sed $shlibpath_var=\`\$ECHO \"\$$shlibpath_var\" | $SED 's/::*\$//'\` export $shlibpath_var " fi $ECHO "\ if test \"\$libtool_execute_magic\" != \"$magic\"; then # Run the actual program with our arguments. func_exec_program \${1+\"\$@\"} fi else # The program doesn't exist. \$ECHO \"\$0: error: '\$progdir/\$program' does not exist\" 1>&2 \$ECHO \"This script is just a wrapper for \$program.\" 1>&2 \$ECHO \"See the $PACKAGE documentation for more information.\" 1>&2 exit 1 fi fi\ " } # func_emit_cwrapperexe_src # emit the source code for a wrapper executable on stdout # Must ONLY be called from within func_mode_link because # it depends on a number of variable set therein. func_emit_cwrapperexe_src () { cat < #include #ifdef _MSC_VER # include # include # include #else # include # include # ifdef __CYGWIN__ # include # endif #endif #include #include #include #include #include #include #include #include #define STREQ(s1, s2) (strcmp ((s1), (s2)) == 0) /* declarations of non-ANSI functions */ #if defined __MINGW32__ # ifdef __STRICT_ANSI__ int _putenv (const char *); # endif #elif defined __CYGWIN__ # ifdef __STRICT_ANSI__ char *realpath (const char *, char *); int putenv (char *); int setenv (const char *, const char *, int); # endif /* #elif defined other_platform || defined ... */ #endif /* portability defines, excluding path handling macros */ #if defined _MSC_VER # define setmode _setmode # define stat _stat # define chmod _chmod # define getcwd _getcwd # define putenv _putenv # define S_IXUSR _S_IEXEC #elif defined __MINGW32__ # define setmode _setmode # define stat _stat # define chmod _chmod # define getcwd _getcwd # define putenv _putenv #elif defined __CYGWIN__ # define HAVE_SETENV # define FOPEN_WB "wb" /* #elif defined other platforms ... */ #endif #if defined PATH_MAX # define LT_PATHMAX PATH_MAX #elif defined MAXPATHLEN # define LT_PATHMAX MAXPATHLEN #else # define LT_PATHMAX 1024 #endif #ifndef S_IXOTH # define S_IXOTH 0 #endif #ifndef S_IXGRP # define S_IXGRP 0 #endif /* path handling portability macros */ #ifndef DIR_SEPARATOR # define DIR_SEPARATOR '/' # define PATH_SEPARATOR ':' #endif #if defined _WIN32 || defined __MSDOS__ || defined __DJGPP__ || \ defined __OS2__ # define HAVE_DOS_BASED_FILE_SYSTEM # define FOPEN_WB "wb" # ifndef DIR_SEPARATOR_2 # define DIR_SEPARATOR_2 '\\' # endif # ifndef PATH_SEPARATOR_2 # define PATH_SEPARATOR_2 ';' # endif #endif #ifndef DIR_SEPARATOR_2 # define IS_DIR_SEPARATOR(ch) ((ch) == DIR_SEPARATOR) #else /* DIR_SEPARATOR_2 */ # define IS_DIR_SEPARATOR(ch) \ (((ch) == DIR_SEPARATOR) || ((ch) == DIR_SEPARATOR_2)) #endif /* DIR_SEPARATOR_2 */ #ifndef PATH_SEPARATOR_2 # define IS_PATH_SEPARATOR(ch) ((ch) == PATH_SEPARATOR) #else /* PATH_SEPARATOR_2 */ # define IS_PATH_SEPARATOR(ch) ((ch) == PATH_SEPARATOR_2) #endif /* PATH_SEPARATOR_2 */ #ifndef FOPEN_WB # define FOPEN_WB "w" #endif #ifndef _O_BINARY # define _O_BINARY 0 #endif #define XMALLOC(type, num) ((type *) xmalloc ((num) * sizeof(type))) #define XFREE(stale) do { \ if (stale) { free (stale); stale = 0; } \ } while (0) #if defined LT_DEBUGWRAPPER static int lt_debug = 1; #else static int lt_debug = 0; #endif const char *program_name = "libtool-wrapper"; /* in case xstrdup fails */ void *xmalloc (size_t num); char *xstrdup (const char *string); const char *base_name (const char *name); char *find_executable (const char *wrapper); char *chase_symlinks (const char *pathspec); int make_executable (const char *path); int check_executable (const char *path); char *strendzap (char *str, const char *pat); void lt_debugprintf (const char *file, int line, const char *fmt, ...); void lt_fatal (const char *file, int line, const char *message, ...); static const char *nonnull (const char *s); static const char *nonempty (const char *s); void lt_setenv (const char *name, const char *value); char *lt_extend_str (const char *orig_value, const char *add, int to_end); void lt_update_exe_path (const char *name, const char *value); void lt_update_lib_path (const char *name, const char *value); char **prepare_spawn (char **argv); void lt_dump_script (FILE *f); EOF cat <= 0) && (st.st_mode & (S_IXUSR | S_IXGRP | S_IXOTH))) return 1; else return 0; } int make_executable (const char *path) { int rval = 0; struct stat st; lt_debugprintf (__FILE__, __LINE__, "(make_executable): %s\n", nonempty (path)); if ((!path) || (!*path)) return 0; if (stat (path, &st) >= 0) { rval = chmod (path, st.st_mode | S_IXOTH | S_IXGRP | S_IXUSR); } return rval; } /* Searches for the full path of the wrapper. Returns newly allocated full path name if found, NULL otherwise Does not chase symlinks, even on platforms that support them. */ char * find_executable (const char *wrapper) { int has_slash = 0; const char *p; const char *p_next; /* static buffer for getcwd */ char tmp[LT_PATHMAX + 1]; size_t tmp_len; char *concat_name; lt_debugprintf (__FILE__, __LINE__, "(find_executable): %s\n", nonempty (wrapper)); if ((wrapper == NULL) || (*wrapper == '\0')) return NULL; /* Absolute path? */ #if defined HAVE_DOS_BASED_FILE_SYSTEM if (isalpha ((unsigned char) wrapper[0]) && wrapper[1] == ':') { concat_name = xstrdup (wrapper); if (check_executable (concat_name)) return concat_name; XFREE (concat_name); } else { #endif if (IS_DIR_SEPARATOR (wrapper[0])) { concat_name = xstrdup (wrapper); if (check_executable (concat_name)) return concat_name; XFREE (concat_name); } #if defined HAVE_DOS_BASED_FILE_SYSTEM } #endif for (p = wrapper; *p; p++) if (*p == '/') { has_slash = 1; break; } if (!has_slash) { /* no slashes; search PATH */ const char *path = getenv ("PATH"); if (path != NULL) { for (p = path; *p; p = p_next) { const char *q; size_t p_len; for (q = p; *q; q++) if (IS_PATH_SEPARATOR (*q)) break; p_len = (size_t) (q - p); p_next = (*q == '\0' ? q : q + 1); if (p_len == 0) { /* empty path: current directory */ if (getcwd (tmp, LT_PATHMAX) == NULL) lt_fatal (__FILE__, __LINE__, "getcwd failed: %s", nonnull (strerror (errno))); tmp_len = strlen (tmp); concat_name = XMALLOC (char, tmp_len + 1 + strlen (wrapper) + 1); memcpy (concat_name, tmp, tmp_len); concat_name[tmp_len] = '/'; strcpy (concat_name + tmp_len + 1, wrapper); } else { concat_name = XMALLOC (char, p_len + 1 + strlen (wrapper) + 1); memcpy (concat_name, p, p_len); concat_name[p_len] = '/'; strcpy (concat_name + p_len + 1, wrapper); } if (check_executable (concat_name)) return concat_name; XFREE (concat_name); } } /* not found in PATH; assume curdir */ } /* Relative path | not found in path: prepend cwd */ if (getcwd (tmp, LT_PATHMAX) == NULL) lt_fatal (__FILE__, __LINE__, "getcwd failed: %s", nonnull (strerror (errno))); tmp_len = strlen (tmp); concat_name = XMALLOC (char, tmp_len + 1 + strlen (wrapper) + 1); memcpy (concat_name, tmp, tmp_len); concat_name[tmp_len] = '/'; strcpy (concat_name + tmp_len + 1, wrapper); if (check_executable (concat_name)) return concat_name; XFREE (concat_name); return NULL; } char * chase_symlinks (const char *pathspec) { #ifndef S_ISLNK return xstrdup (pathspec); #else char buf[LT_PATHMAX]; struct stat s; char *tmp_pathspec = xstrdup (pathspec); char *p; int has_symlinks = 0; while (strlen (tmp_pathspec) && !has_symlinks) { lt_debugprintf (__FILE__, __LINE__, "checking path component for symlinks: %s\n", tmp_pathspec); if (lstat (tmp_pathspec, &s) == 0) { if (S_ISLNK (s.st_mode) != 0) { has_symlinks = 1; break; } /* search backwards for last DIR_SEPARATOR */ p = tmp_pathspec + strlen (tmp_pathspec) - 1; while ((p > tmp_pathspec) && (!IS_DIR_SEPARATOR (*p))) p--; if ((p == tmp_pathspec) && (!IS_DIR_SEPARATOR (*p))) { /* no more DIR_SEPARATORS left */ break; } *p = '\0'; } else { lt_fatal (__FILE__, __LINE__, "error accessing file \"%s\": %s", tmp_pathspec, nonnull (strerror (errno))); } } XFREE (tmp_pathspec); if (!has_symlinks) { return xstrdup (pathspec); } tmp_pathspec = realpath (pathspec, buf); if (tmp_pathspec == 0) { lt_fatal (__FILE__, __LINE__, "could not follow symlinks for %s", pathspec); } return xstrdup (tmp_pathspec); #endif } char * strendzap (char *str, const char *pat) { size_t len, patlen; assert (str != NULL); assert (pat != NULL); len = strlen (str); patlen = strlen (pat); if (patlen <= len) { str += len - patlen; if (STREQ (str, pat)) *str = '\0'; } return str; } void lt_debugprintf (const char *file, int line, const char *fmt, ...) { va_list args; if (lt_debug) { (void) fprintf (stderr, "%s:%s:%d: ", program_name, file, line); va_start (args, fmt); (void) vfprintf (stderr, fmt, args); va_end (args); } } static void lt_error_core (int exit_status, const char *file, int line, const char *mode, const char *message, va_list ap) { fprintf (stderr, "%s:%s:%d: %s: ", program_name, file, line, mode); vfprintf (stderr, message, ap); fprintf (stderr, ".\n"); if (exit_status >= 0) exit (exit_status); } void lt_fatal (const char *file, int line, const char *message, ...) { va_list ap; va_start (ap, message); lt_error_core (EXIT_FAILURE, file, line, "FATAL", message, ap); va_end (ap); } static const char * nonnull (const char *s) { return s ? s : "(null)"; } static const char * nonempty (const char *s) { return (s && !*s) ? "(empty)" : nonnull (s); } void lt_setenv (const char *name, const char *value) { lt_debugprintf (__FILE__, __LINE__, "(lt_setenv) setting '%s' to '%s'\n", nonnull (name), nonnull (value)); { #ifdef HAVE_SETENV /* always make a copy, for consistency with !HAVE_SETENV */ char *str = xstrdup (value); setenv (name, str, 1); #else size_t len = strlen (name) + 1 + strlen (value) + 1; char *str = XMALLOC (char, len); sprintf (str, "%s=%s", name, value); if (putenv (str) != EXIT_SUCCESS) { XFREE (str); } #endif } } char * lt_extend_str (const char *orig_value, const char *add, int to_end) { char *new_value; if (orig_value && *orig_value) { size_t orig_value_len = strlen (orig_value); size_t add_len = strlen (add); new_value = XMALLOC (char, add_len + orig_value_len + 1); if (to_end) { strcpy (new_value, orig_value); strcpy (new_value + orig_value_len, add); } else { strcpy (new_value, add); strcpy (new_value + add_len, orig_value); } } else { new_value = xstrdup (add); } return new_value; } void lt_update_exe_path (const char *name, const char *value) { lt_debugprintf (__FILE__, __LINE__, "(lt_update_exe_path) modifying '%s' by prepending '%s'\n", nonnull (name), nonnull (value)); if (name && *name && value && *value) { char *new_value = lt_extend_str (getenv (name), value, 0); /* some systems can't cope with a ':'-terminated path #' */ size_t len = strlen (new_value); while ((len > 0) && IS_PATH_SEPARATOR (new_value[len-1])) { new_value[--len] = '\0'; } lt_setenv (name, new_value); XFREE (new_value); } } void lt_update_lib_path (const char *name, const char *value) { lt_debugprintf (__FILE__, __LINE__, "(lt_update_lib_path) modifying '%s' by prepending '%s'\n", nonnull (name), nonnull (value)); if (name && *name && value && *value) { char *new_value = lt_extend_str (getenv (name), value, 0); lt_setenv (name, new_value); XFREE (new_value); } } EOF case $host_os in mingw*) cat <<"EOF" /* Prepares an argument vector before calling spawn(). Note that spawn() does not by itself call the command interpreter (getenv ("COMSPEC") != NULL ? getenv ("COMSPEC") : ({ OSVERSIONINFO v; v.dwOSVersionInfoSize = sizeof(OSVERSIONINFO); GetVersionEx(&v); v.dwPlatformId == VER_PLATFORM_WIN32_NT; }) ? "cmd.exe" : "command.com"). Instead it simply concatenates the arguments, separated by ' ', and calls CreateProcess(). We must quote the arguments since Win32 CreateProcess() interprets characters like ' ', '\t', '\\', '"' (but not '<' and '>') in a special way: - Space and tab are interpreted as delimiters. They are not treated as delimiters if they are surrounded by double quotes: "...". - Unescaped double quotes are removed from the input. Their only effect is that within double quotes, space and tab are treated like normal characters. - Backslashes not followed by double quotes are not special. - But 2*n+1 backslashes followed by a double quote become n backslashes followed by a double quote (n >= 0): \" -> " \\\" -> \" \\\\\" -> \\" */ #define SHELL_SPECIAL_CHARS "\"\\ \001\002\003\004\005\006\007\010\011\012\013\014\015\016\017\020\021\022\023\024\025\026\027\030\031\032\033\034\035\036\037" #define SHELL_SPACE_CHARS " \001\002\003\004\005\006\007\010\011\012\013\014\015\016\017\020\021\022\023\024\025\026\027\030\031\032\033\034\035\036\037" char ** prepare_spawn (char **argv) { size_t argc; char **new_argv; size_t i; /* Count number of arguments. */ for (argc = 0; argv[argc] != NULL; argc++) ; /* Allocate new argument vector. */ new_argv = XMALLOC (char *, argc + 1); /* Put quoted arguments into the new argument vector. */ for (i = 0; i < argc; i++) { const char *string = argv[i]; if (string[0] == '\0') new_argv[i] = xstrdup ("\"\""); else if (strpbrk (string, SHELL_SPECIAL_CHARS) != NULL) { int quote_around = (strpbrk (string, SHELL_SPACE_CHARS) != NULL); size_t length; unsigned int backslashes; const char *s; char *quoted_string; char *p; length = 0; backslashes = 0; if (quote_around) length++; for (s = string; *s != '\0'; s++) { char c = *s; if (c == '"') length += backslashes + 1; length++; if (c == '\\') backslashes++; else backslashes = 0; } if (quote_around) length += backslashes + 1; quoted_string = XMALLOC (char, length + 1); p = quoted_string; backslashes = 0; if (quote_around) *p++ = '"'; for (s = string; *s != '\0'; s++) { char c = *s; if (c == '"') { unsigned int j; for (j = backslashes + 1; j > 0; j--) *p++ = '\\'; } *p++ = c; if (c == '\\') backslashes++; else backslashes = 0; } if (quote_around) { unsigned int j; for (j = backslashes; j > 0; j--) *p++ = '\\'; *p++ = '"'; } *p = '\0'; new_argv[i] = quoted_string; } else new_argv[i] = (char *) string; } new_argv[argc] = NULL; return new_argv; } EOF ;; esac cat <<"EOF" void lt_dump_script (FILE* f) { EOF func_emit_wrapper yes | $SED -n -e ' s/^\(.\{79\}\)\(..*\)/\1\ \2/ h s/\([\\"]\)/\\\1/g s/$/\\n/ s/\([^\n]*\).*/ fputs ("\1", f);/p g D' cat <<"EOF" } EOF } # end: func_emit_cwrapperexe_src # func_win32_import_lib_p ARG # True if ARG is an import lib, as indicated by $file_magic_cmd func_win32_import_lib_p () { $debug_cmd case `eval $file_magic_cmd \"\$1\" 2>/dev/null | $SED -e 10q` in *import*) : ;; *) false ;; esac } # func_suncc_cstd_abi # !!ONLY CALL THIS FOR SUN CC AFTER $compile_command IS FULLY EXPANDED!! # Several compiler flags select an ABI that is incompatible with the # Cstd library. Avoid specifying it if any are in CXXFLAGS. func_suncc_cstd_abi () { $debug_cmd case " $compile_command " in *" -compat=g "*|*\ -std=c++[0-9][0-9]\ *|*" -library=stdcxx4 "*|*" -library=stlport4 "*) suncc_use_cstd_abi=no ;; *) suncc_use_cstd_abi=yes ;; esac } # func_mode_link arg... func_mode_link () { $debug_cmd case $host in *-*-cygwin* | *-*-mingw* | *-*-pw32* | *-*-os2* | *-cegcc*) # It is impossible to link a dll without this setting, and # we shouldn't force the makefile maintainer to figure out # what system we are compiling for in order to pass an extra # flag for every libtool invocation. # allow_undefined=no # FIXME: Unfortunately, there are problems with the above when trying # to make a dll that has undefined symbols, in which case not # even a static library is built. For now, we need to specify # -no-undefined on the libtool link line when we can be certain # that all symbols are satisfied, otherwise we get a static library. allow_undefined=yes ;; *) allow_undefined=yes ;; esac libtool_args=$nonopt base_compile="$nonopt $@" compile_command=$nonopt finalize_command=$nonopt compile_rpath= finalize_rpath= compile_shlibpath= finalize_shlibpath= convenience= old_convenience= deplibs= old_deplibs= compiler_flags= linker_flags= dllsearchpath= lib_search_path=`pwd` inst_prefix_dir= new_inherited_linker_flags= avoid_version=no bindir= dlfiles= dlprefiles= dlself=no export_dynamic=no export_symbols= export_symbols_regex= generated= libobjs= ltlibs= module=no no_install=no objs= os2dllname= non_pic_objects= precious_files_regex= prefer_static_libs=no preload=false prev= prevarg= release= rpath= xrpath= perm_rpath= temp_rpath= thread_safe=no vinfo= vinfo_number=no weak_libs= single_module=$wl-single_module func_infer_tag $base_compile # We need to know -static, to get the right output filenames. for arg do case $arg in -shared) test yes != "$build_libtool_libs" \ && func_fatal_configuration "cannot build a shared library" build_old_libs=no break ;; -all-static | -static | -static-libtool-libs) case $arg in -all-static) if test yes = "$build_libtool_libs" && test -z "$link_static_flag"; then func_warning "complete static linking is impossible in this configuration" fi if test -n "$link_static_flag"; then dlopen_self=$dlopen_self_static fi prefer_static_libs=yes ;; -static) if test -z "$pic_flag" && test -n "$link_static_flag"; then dlopen_self=$dlopen_self_static fi prefer_static_libs=built ;; -static-libtool-libs) if test -z "$pic_flag" && test -n "$link_static_flag"; then dlopen_self=$dlopen_self_static fi prefer_static_libs=yes ;; esac build_libtool_libs=no build_old_libs=yes break ;; esac done # See if our shared archives depend on static archives. test -n "$old_archive_from_new_cmds" && build_old_libs=yes # Go through the arguments, transforming them on the way. while test "$#" -gt 0; do arg=$1 shift func_quote_for_eval "$arg" qarg=$func_quote_for_eval_unquoted_result func_append libtool_args " $func_quote_for_eval_result" # If the previous option needs an argument, assign it. if test -n "$prev"; then case $prev in output) func_append compile_command " @OUTPUT@" func_append finalize_command " @OUTPUT@" ;; esac case $prev in bindir) bindir=$arg prev= continue ;; dlfiles|dlprefiles) $preload || { # Add the symbol object into the linking commands. func_append compile_command " @SYMFILE@" func_append finalize_command " @SYMFILE@" preload=: } case $arg in *.la | *.lo) ;; # We handle these cases below. force) if test no = "$dlself"; then dlself=needless export_dynamic=yes fi prev= continue ;; self) if test dlprefiles = "$prev"; then dlself=yes elif test dlfiles = "$prev" && test yes != "$dlopen_self"; then dlself=yes else dlself=needless export_dynamic=yes fi prev= continue ;; *) if test dlfiles = "$prev"; then func_append dlfiles " $arg" else func_append dlprefiles " $arg" fi prev= continue ;; esac ;; expsyms) export_symbols=$arg test -f "$arg" \ || func_fatal_error "symbol file '$arg' does not exist" prev= continue ;; expsyms_regex) export_symbols_regex=$arg prev= continue ;; framework) case $host in *-*-darwin*) case "$deplibs " in *" $qarg.ltframework "*) ;; *) func_append deplibs " $qarg.ltframework" # this is fixed later ;; esac ;; esac prev= continue ;; inst_prefix) inst_prefix_dir=$arg prev= continue ;; mllvm) # Clang does not use LLVM to link, so we can simply discard any # '-mllvm $arg' options when doing the link step. prev= continue ;; objectlist) if test -f "$arg"; then save_arg=$arg moreargs= for fil in `cat "$save_arg"` do # func_append moreargs " $fil" arg=$fil # A libtool-controlled object. # Check to see that this really is a libtool object. if func_lalib_unsafe_p "$arg"; then pic_object= non_pic_object= # Read the .lo file func_source "$arg" if test -z "$pic_object" || test -z "$non_pic_object" || test none = "$pic_object" && test none = "$non_pic_object"; then func_fatal_error "cannot find name of object for '$arg'" fi # Extract subdirectory from the argument. func_dirname "$arg" "/" "" xdir=$func_dirname_result if test none != "$pic_object"; then # Prepend the subdirectory the object is found in. pic_object=$xdir$pic_object if test dlfiles = "$prev"; then if test yes = "$build_libtool_libs" && test yes = "$dlopen_support"; then func_append dlfiles " $pic_object" prev= continue else # If libtool objects are unsupported, then we need to preload. prev=dlprefiles fi fi # CHECK ME: I think I busted this. -Ossama if test dlprefiles = "$prev"; then # Preload the old-style object. func_append dlprefiles " $pic_object" prev= fi # A PIC object. func_append libobjs " $pic_object" arg=$pic_object fi # Non-PIC object. if test none != "$non_pic_object"; then # Prepend the subdirectory the object is found in. non_pic_object=$xdir$non_pic_object # A standard non-PIC object func_append non_pic_objects " $non_pic_object" if test -z "$pic_object" || test none = "$pic_object"; then arg=$non_pic_object fi else # If the PIC object exists, use it instead. # $xdir was prepended to $pic_object above. non_pic_object=$pic_object func_append non_pic_objects " $non_pic_object" fi else # Only an error if not doing a dry-run. if $opt_dry_run; then # Extract subdirectory from the argument. func_dirname "$arg" "/" "" xdir=$func_dirname_result func_lo2o "$arg" pic_object=$xdir$objdir/$func_lo2o_result non_pic_object=$xdir$func_lo2o_result func_append libobjs " $pic_object" func_append non_pic_objects " $non_pic_object" else func_fatal_error "'$arg' is not a valid libtool object" fi fi done else func_fatal_error "link input file '$arg' does not exist" fi arg=$save_arg prev= continue ;; os2dllname) os2dllname=$arg prev= continue ;; precious_regex) precious_files_regex=$arg prev= continue ;; release) release=-$arg prev= continue ;; rpath | xrpath) # We need an absolute path. case $arg in [\\/]* | [A-Za-z]:[\\/]*) ;; *) func_fatal_error "only absolute run-paths are allowed" ;; esac if test rpath = "$prev"; then case "$rpath " in *" $arg "*) ;; *) func_append rpath " $arg" ;; esac else case "$xrpath " in *" $arg "*) ;; *) func_append xrpath " $arg" ;; esac fi prev= continue ;; shrext) shrext_cmds=$arg prev= continue ;; weak) func_append weak_libs " $arg" prev= continue ;; xcclinker) func_append linker_flags " $qarg" func_append compiler_flags " $qarg" prev= func_append compile_command " $qarg" func_append finalize_command " $qarg" continue ;; xcompiler) func_append compiler_flags " $qarg" prev= func_append compile_command " $qarg" func_append finalize_command " $qarg" continue ;; xlinker) func_append linker_flags " $qarg" func_append compiler_flags " $wl$qarg" prev= func_append compile_command " $wl$qarg" func_append finalize_command " $wl$qarg" continue ;; *) eval "$prev=\"\$arg\"" prev= continue ;; esac fi # test -n "$prev" prevarg=$arg case $arg in -all-static) if test -n "$link_static_flag"; then # See comment for -static flag below, for more details. func_append compile_command " $link_static_flag" func_append finalize_command " $link_static_flag" fi continue ;; -allow-undefined) # FIXME: remove this flag sometime in the future. func_fatal_error "'-allow-undefined' must not be used because it is the default" ;; -avoid-version) avoid_version=yes continue ;; -bindir) prev=bindir continue ;; -dlopen) prev=dlfiles continue ;; -dlpreopen) prev=dlprefiles continue ;; -export-dynamic) export_dynamic=yes continue ;; -export-symbols | -export-symbols-regex) if test -n "$export_symbols" || test -n "$export_symbols_regex"; then func_fatal_error "more than one -exported-symbols argument is not allowed" fi if test X-export-symbols = "X$arg"; then prev=expsyms else prev=expsyms_regex fi continue ;; -framework) prev=framework continue ;; -inst-prefix-dir) prev=inst_prefix continue ;; # The native IRIX linker understands -LANG:*, -LIST:* and -LNO:* # so, if we see these flags be careful not to treat them like -L -L[A-Z][A-Z]*:*) case $with_gcc/$host in no/*-*-irix* | /*-*-irix*) func_append compile_command " $arg" func_append finalize_command " $arg" ;; esac continue ;; -L*) func_stripname "-L" '' "$arg" if test -z "$func_stripname_result"; then if test "$#" -gt 0; then func_fatal_error "require no space between '-L' and '$1'" else func_fatal_error "need path for '-L' option" fi fi func_resolve_sysroot "$func_stripname_result" dir=$func_resolve_sysroot_result # We need an absolute path. case $dir in [\\/]* | [A-Za-z]:[\\/]*) ;; *) absdir=`cd "$dir" && pwd` test -z "$absdir" && \ func_fatal_error "cannot determine absolute directory name of '$dir'" dir=$absdir ;; esac case "$deplibs " in *" -L$dir "* | *" $arg "*) # Will only happen for absolute or sysroot arguments ;; *) # Preserve sysroot, but never include relative directories case $dir in [\\/]* | [A-Za-z]:[\\/]* | =*) func_append deplibs " $arg" ;; *) func_append deplibs " -L$dir" ;; esac func_append lib_search_path " $dir" ;; esac case $host in *-*-cygwin* | *-*-mingw* | *-*-pw32* | *-*-os2* | *-cegcc*) testbindir=`$ECHO "$dir" | $SED 's*/lib$*/bin*'` case :$dllsearchpath: in *":$dir:"*) ;; ::) dllsearchpath=$dir;; *) func_append dllsearchpath ":$dir";; esac case :$dllsearchpath: in *":$testbindir:"*) ;; ::) dllsearchpath=$testbindir;; *) func_append dllsearchpath ":$testbindir";; esac ;; esac continue ;; -l*) if test X-lc = "X$arg" || test X-lm = "X$arg"; then case $host in *-*-cygwin* | *-*-mingw* | *-*-pw32* | *-*-beos* | *-cegcc* | *-*-haiku*) # These systems don't actually have a C or math library (as such) continue ;; *-*-os2*) # These systems don't actually have a C library (as such) test X-lc = "X$arg" && continue ;; *-*-openbsd* | *-*-freebsd* | *-*-dragonfly* | *-*-bitrig*) # Do not include libc due to us having libc/libc_r. test X-lc = "X$arg" && continue ;; *-*-rhapsody* | *-*-darwin1.[012]) # Rhapsody C and math libraries are in the System framework func_append deplibs " System.ltframework" continue ;; *-*-sco3.2v5* | *-*-sco5v6*) # Causes problems with __ctype test X-lc = "X$arg" && continue ;; *-*-sysv4.2uw2* | *-*-sysv5* | *-*-unixware* | *-*-OpenUNIX*) # Compiler inserts libc in the correct place for threads to work test X-lc = "X$arg" && continue ;; esac elif test X-lc_r = "X$arg"; then case $host in *-*-openbsd* | *-*-freebsd* | *-*-dragonfly* | *-*-bitrig*) # Do not include libc_r directly, use -pthread flag. continue ;; esac fi func_append deplibs " $arg" continue ;; -mllvm) prev=mllvm continue ;; -module) module=yes continue ;; # Tru64 UNIX uses -model [arg] to determine the layout of C++ # classes, name mangling, and exception handling. # Darwin uses the -arch flag to determine output architecture. -model|-arch|-isysroot|--sysroot) func_append compiler_flags " $arg" func_append compile_command " $arg" func_append finalize_command " $arg" prev=xcompiler continue ;; -mt|-mthreads|-kthread|-Kthread|-pthread|-pthreads|--thread-safe \ |-threads|-fopenmp|-openmp|-mp|-xopenmp|-omp|-qsmp=*) func_append compiler_flags " $arg" func_append compile_command " $arg" func_append finalize_command " $arg" case "$new_inherited_linker_flags " in *" $arg "*) ;; * ) func_append new_inherited_linker_flags " $arg" ;; esac continue ;; -multi_module) single_module=$wl-multi_module continue ;; -no-fast-install) fast_install=no continue ;; -no-install) case $host in *-*-cygwin* | *-*-mingw* | *-*-pw32* | *-*-os2* | *-*-darwin* | *-cegcc*) # The PATH hackery in wrapper scripts is required on Windows # and Darwin in order for the loader to find any dlls it needs. func_warning "'-no-install' is ignored for $host" func_warning "assuming '-no-fast-install' instead" fast_install=no ;; *) no_install=yes ;; esac continue ;; -no-undefined) allow_undefined=no continue ;; -objectlist) prev=objectlist continue ;; -os2dllname) prev=os2dllname continue ;; -o) prev=output ;; -precious-files-regex) prev=precious_regex continue ;; -release) prev=release continue ;; -rpath) prev=rpath continue ;; -R) prev=xrpath continue ;; -R*) func_stripname '-R' '' "$arg" dir=$func_stripname_result # We need an absolute path. case $dir in [\\/]* | [A-Za-z]:[\\/]*) ;; =*) func_stripname '=' '' "$dir" dir=$lt_sysroot$func_stripname_result ;; *) func_fatal_error "only absolute run-paths are allowed" ;; esac case "$xrpath " in *" $dir "*) ;; *) func_append xrpath " $dir" ;; esac continue ;; -shared) # The effects of -shared are defined in a previous loop. continue ;; -shrext) prev=shrext continue ;; -static | -static-libtool-libs) # The effects of -static are defined in a previous loop. # We used to do the same as -all-static on platforms that # didn't have a PIC flag, but the assumption that the effects # would be equivalent was wrong. It would break on at least # Digital Unix and AIX. continue ;; -thread-safe) thread_safe=yes continue ;; -version-info) prev=vinfo continue ;; -version-number) prev=vinfo vinfo_number=yes continue ;; -weak) prev=weak continue ;; -Wc,*) func_stripname '-Wc,' '' "$arg" args=$func_stripname_result arg= save_ifs=$IFS; IFS=, for flag in $args; do IFS=$save_ifs func_quote_for_eval "$flag" func_append arg " $func_quote_for_eval_result" func_append compiler_flags " $func_quote_for_eval_result" done IFS=$save_ifs func_stripname ' ' '' "$arg" arg=$func_stripname_result ;; -Wl,*) func_stripname '-Wl,' '' "$arg" args=$func_stripname_result arg= save_ifs=$IFS; IFS=, for flag in $args; do IFS=$save_ifs func_quote_for_eval "$flag" func_append arg " $wl$func_quote_for_eval_result" func_append compiler_flags " $wl$func_quote_for_eval_result" func_append linker_flags " $func_quote_for_eval_result" done IFS=$save_ifs func_stripname ' ' '' "$arg" arg=$func_stripname_result ;; -Xcompiler) prev=xcompiler continue ;; -Xlinker) prev=xlinker continue ;; -XCClinker) prev=xcclinker continue ;; # -msg_* for osf cc -msg_*) func_quote_for_eval "$arg" arg=$func_quote_for_eval_result ;; # Flags to be passed through unchanged, with rationale: # -64, -mips[0-9] enable 64-bit mode for the SGI compiler # -r[0-9][0-9]* specify processor for the SGI compiler # -xarch=*, -xtarget=* enable 64-bit mode for the Sun compiler # +DA*, +DD* enable 64-bit mode for the HP compiler # -q* compiler args for the IBM compiler # -m*, -t[45]*, -txscale* architecture-specific flags for GCC # -F/path path to uninstalled frameworks, gcc on darwin # -p, -pg, --coverage, -fprofile-* profiling flags for GCC # -fstack-protector* stack protector flags for GCC # @file GCC response files # -tp=* Portland pgcc target processor selection # --sysroot=* for sysroot support # -O*, -g*, -flto*, -fwhopr*, -fuse-linker-plugin GCC link-time optimization # -stdlib=* select c++ std lib with clang -64|-mips[0-9]|-r[0-9][0-9]*|-xarch=*|-xtarget=*|+DA*|+DD*|-q*|-m*| \ -t[45]*|-txscale*|-p|-pg|--coverage|-fprofile-*|-F*|@*|-tp=*|--sysroot=*| \ -O*|-g*|-flto*|-fwhopr*|-fuse-linker-plugin|-fstack-protector*|-stdlib=*) func_quote_for_eval "$arg" arg=$func_quote_for_eval_result func_append compile_command " $arg" func_append finalize_command " $arg" func_append compiler_flags " $arg" continue ;; -Z*) if test os2 = "`expr $host : '.*\(os2\)'`"; then # OS/2 uses -Zxxx to specify OS/2-specific options compiler_flags="$compiler_flags $arg" func_append compile_command " $arg" func_append finalize_command " $arg" case $arg in -Zlinker | -Zstack) prev=xcompiler ;; esac continue else # Otherwise treat like 'Some other compiler flag' below func_quote_for_eval "$arg" arg=$func_quote_for_eval_result fi ;; # Some other compiler flag. -* | +*) func_quote_for_eval "$arg" arg=$func_quote_for_eval_result ;; *.$objext) # A standard object. func_append objs " $arg" ;; *.lo) # A libtool-controlled object. # Check to see that this really is a libtool object. if func_lalib_unsafe_p "$arg"; then pic_object= non_pic_object= # Read the .lo file func_source "$arg" if test -z "$pic_object" || test -z "$non_pic_object" || test none = "$pic_object" && test none = "$non_pic_object"; then func_fatal_error "cannot find name of object for '$arg'" fi # Extract subdirectory from the argument. func_dirname "$arg" "/" "" xdir=$func_dirname_result test none = "$pic_object" || { # Prepend the subdirectory the object is found in. pic_object=$xdir$pic_object if test dlfiles = "$prev"; then if test yes = "$build_libtool_libs" && test yes = "$dlopen_support"; then func_append dlfiles " $pic_object" prev= continue else # If libtool objects are unsupported, then we need to preload. prev=dlprefiles fi fi # CHECK ME: I think I busted this. -Ossama if test dlprefiles = "$prev"; then # Preload the old-style object. func_append dlprefiles " $pic_object" prev= fi # A PIC object. func_append libobjs " $pic_object" arg=$pic_object } # Non-PIC object. if test none != "$non_pic_object"; then # Prepend the subdirectory the object is found in. non_pic_object=$xdir$non_pic_object # A standard non-PIC object func_append non_pic_objects " $non_pic_object" if test -z "$pic_object" || test none = "$pic_object"; then arg=$non_pic_object fi else # If the PIC object exists, use it instead. # $xdir was prepended to $pic_object above. non_pic_object=$pic_object func_append non_pic_objects " $non_pic_object" fi else # Only an error if not doing a dry-run. if $opt_dry_run; then # Extract subdirectory from the argument. func_dirname "$arg" "/" "" xdir=$func_dirname_result func_lo2o "$arg" pic_object=$xdir$objdir/$func_lo2o_result non_pic_object=$xdir$func_lo2o_result func_append libobjs " $pic_object" func_append non_pic_objects " $non_pic_object" else func_fatal_error "'$arg' is not a valid libtool object" fi fi ;; *.$libext) # An archive. func_append deplibs " $arg" func_append old_deplibs " $arg" continue ;; *.la) # A libtool-controlled library. func_resolve_sysroot "$arg" if test dlfiles = "$prev"; then # This library was specified with -dlopen. func_append dlfiles " $func_resolve_sysroot_result" prev= elif test dlprefiles = "$prev"; then # The library was specified with -dlpreopen. func_append dlprefiles " $func_resolve_sysroot_result" prev= else func_append deplibs " $func_resolve_sysroot_result" fi continue ;; # Some other compiler argument. *) # Unknown arguments in both finalize_command and compile_command need # to be aesthetically quoted because they are evaled later. func_quote_for_eval "$arg" arg=$func_quote_for_eval_result ;; esac # arg # Now actually substitute the argument into the commands. if test -n "$arg"; then func_append compile_command " $arg" func_append finalize_command " $arg" fi done # argument parsing loop test -n "$prev" && \ func_fatal_help "the '$prevarg' option requires an argument" if test yes = "$export_dynamic" && test -n "$export_dynamic_flag_spec"; then eval arg=\"$export_dynamic_flag_spec\" func_append compile_command " $arg" func_append finalize_command " $arg" fi oldlibs= # calculate the name of the file, without its directory func_basename "$output" outputname=$func_basename_result libobjs_save=$libobjs if test -n "$shlibpath_var"; then # get the directories listed in $shlibpath_var eval shlib_search_path=\`\$ECHO \"\$$shlibpath_var\" \| \$SED \'s/:/ /g\'\` else shlib_search_path= fi eval sys_lib_search_path=\"$sys_lib_search_path_spec\" eval sys_lib_dlsearch_path=\"$sys_lib_dlsearch_path_spec\" # Definition is injected by LT_CONFIG during libtool generation. func_munge_path_list sys_lib_dlsearch_path "$LT_SYS_LIBRARY_PATH" func_dirname "$output" "/" "" output_objdir=$func_dirname_result$objdir func_to_tool_file "$output_objdir/" tool_output_objdir=$func_to_tool_file_result # Create the object directory. func_mkdir_p "$output_objdir" # Determine the type of output case $output in "") func_fatal_help "you must specify an output file" ;; *.$libext) linkmode=oldlib ;; *.lo | *.$objext) linkmode=obj ;; *.la) linkmode=lib ;; *) linkmode=prog ;; # Anything else should be a program. esac specialdeplibs= libs= # Find all interdependent deplibs by searching for libraries # that are linked more than once (e.g. -la -lb -la) for deplib in $deplibs; do if $opt_preserve_dup_deps; then case "$libs " in *" $deplib "*) func_append specialdeplibs " $deplib" ;; esac fi func_append libs " $deplib" done if test lib = "$linkmode"; then libs="$predeps $libs $compiler_lib_search_path $postdeps" # Compute libraries that are listed more than once in $predeps # $postdeps and mark them as special (i.e., whose duplicates are # not to be eliminated). pre_post_deps= if $opt_duplicate_compiler_generated_deps; then for pre_post_dep in $predeps $postdeps; do case "$pre_post_deps " in *" $pre_post_dep "*) func_append specialdeplibs " $pre_post_deps" ;; esac func_append pre_post_deps " $pre_post_dep" done fi pre_post_deps= fi deplibs= newdependency_libs= newlib_search_path= need_relink=no # whether we're linking any uninstalled libtool libraries notinst_deplibs= # not-installed libtool libraries notinst_path= # paths that contain not-installed libtool libraries case $linkmode in lib) passes="conv dlpreopen link" for file in $dlfiles $dlprefiles; do case $file in *.la) ;; *) func_fatal_help "libraries can '-dlopen' only libtool libraries: $file" ;; esac done ;; prog) compile_deplibs= finalize_deplibs= alldeplibs=false newdlfiles= newdlprefiles= passes="conv scan dlopen dlpreopen link" ;; *) passes="conv" ;; esac for pass in $passes; do # The preopen pass in lib mode reverses $deplibs; put it back here # so that -L comes before libs that need it for instance... if test lib,link = "$linkmode,$pass"; then ## FIXME: Find the place where the list is rebuilt in the wrong ## order, and fix it there properly tmp_deplibs= for deplib in $deplibs; do tmp_deplibs="$deplib $tmp_deplibs" done deplibs=$tmp_deplibs fi if test lib,link = "$linkmode,$pass" || test prog,scan = "$linkmode,$pass"; then libs=$deplibs deplibs= fi if test prog = "$linkmode"; then case $pass in dlopen) libs=$dlfiles ;; dlpreopen) libs=$dlprefiles ;; link) libs="$deplibs %DEPLIBS% $dependency_libs" ;; esac fi if test lib,dlpreopen = "$linkmode,$pass"; then # Collect and forward deplibs of preopened libtool libs for lib in $dlprefiles; do # Ignore non-libtool-libs dependency_libs= func_resolve_sysroot "$lib" case $lib in *.la) func_source "$func_resolve_sysroot_result" ;; esac # Collect preopened libtool deplibs, except any this library # has declared as weak libs for deplib in $dependency_libs; do func_basename "$deplib" deplib_base=$func_basename_result case " $weak_libs " in *" $deplib_base "*) ;; *) func_append deplibs " $deplib" ;; esac done done libs=$dlprefiles fi if test dlopen = "$pass"; then # Collect dlpreopened libraries save_deplibs=$deplibs deplibs= fi for deplib in $libs; do lib= found=false case $deplib in -mt|-mthreads|-kthread|-Kthread|-pthread|-pthreads|--thread-safe \ |-threads|-fopenmp|-openmp|-mp|-xopenmp|-omp|-qsmp=*) if test prog,link = "$linkmode,$pass"; then compile_deplibs="$deplib $compile_deplibs" finalize_deplibs="$deplib $finalize_deplibs" else func_append compiler_flags " $deplib" if test lib = "$linkmode"; then case "$new_inherited_linker_flags " in *" $deplib "*) ;; * ) func_append new_inherited_linker_flags " $deplib" ;; esac fi fi continue ;; -l*) if test lib != "$linkmode" && test prog != "$linkmode"; then func_warning "'-l' is ignored for archives/objects" continue fi func_stripname '-l' '' "$deplib" name=$func_stripname_result if test lib = "$linkmode"; then searchdirs="$newlib_search_path $lib_search_path $compiler_lib_search_dirs $sys_lib_search_path $shlib_search_path" else searchdirs="$newlib_search_path $lib_search_path $sys_lib_search_path $shlib_search_path" fi for searchdir in $searchdirs; do for search_ext in .la $std_shrext .so .a; do # Search the libtool library lib=$searchdir/lib$name$search_ext if test -f "$lib"; then if test .la = "$search_ext"; then found=: else found=false fi break 2 fi done done if $found; then # deplib is a libtool library # If $allow_libtool_libs_with_static_runtimes && $deplib is a stdlib, # We need to do some special things here, and not later. if test yes = "$allow_libtool_libs_with_static_runtimes"; then case " $predeps $postdeps " in *" $deplib "*) if func_lalib_p "$lib"; then library_names= old_library= func_source "$lib" for l in $old_library $library_names; do ll=$l done if test "X$ll" = "X$old_library"; then # only static version available found=false func_dirname "$lib" "" "." ladir=$func_dirname_result lib=$ladir/$old_library if test prog,link = "$linkmode,$pass"; then compile_deplibs="$deplib $compile_deplibs" finalize_deplibs="$deplib $finalize_deplibs" else deplibs="$deplib $deplibs" test lib = "$linkmode" && newdependency_libs="$deplib $newdependency_libs" fi continue fi fi ;; *) ;; esac fi else # deplib doesn't seem to be a libtool library if test prog,link = "$linkmode,$pass"; then compile_deplibs="$deplib $compile_deplibs" finalize_deplibs="$deplib $finalize_deplibs" else deplibs="$deplib $deplibs" test lib = "$linkmode" && newdependency_libs="$deplib $newdependency_libs" fi continue fi ;; # -l *.ltframework) if test prog,link = "$linkmode,$pass"; then compile_deplibs="$deplib $compile_deplibs" finalize_deplibs="$deplib $finalize_deplibs" else deplibs="$deplib $deplibs" if test lib = "$linkmode"; then case "$new_inherited_linker_flags " in *" $deplib "*) ;; * ) func_append new_inherited_linker_flags " $deplib" ;; esac fi fi continue ;; -L*) case $linkmode in lib) deplibs="$deplib $deplibs" test conv = "$pass" && continue newdependency_libs="$deplib $newdependency_libs" func_stripname '-L' '' "$deplib" func_resolve_sysroot "$func_stripname_result" func_append newlib_search_path " $func_resolve_sysroot_result" ;; prog) if test conv = "$pass"; then deplibs="$deplib $deplibs" continue fi if test scan = "$pass"; then deplibs="$deplib $deplibs" else compile_deplibs="$deplib $compile_deplibs" finalize_deplibs="$deplib $finalize_deplibs" fi func_stripname '-L' '' "$deplib" func_resolve_sysroot "$func_stripname_result" func_append newlib_search_path " $func_resolve_sysroot_result" ;; *) func_warning "'-L' is ignored for archives/objects" ;; esac # linkmode continue ;; # -L -R*) if test link = "$pass"; then func_stripname '-R' '' "$deplib" func_resolve_sysroot "$func_stripname_result" dir=$func_resolve_sysroot_result # Make sure the xrpath contains only unique directories. case "$xrpath " in *" $dir "*) ;; *) func_append xrpath " $dir" ;; esac fi deplibs="$deplib $deplibs" continue ;; *.la) func_resolve_sysroot "$deplib" lib=$func_resolve_sysroot_result ;; *.$libext) if test conv = "$pass"; then deplibs="$deplib $deplibs" continue fi case $linkmode in lib) # Linking convenience modules into shared libraries is allowed, # but linking other static libraries is non-portable. case " $dlpreconveniencelibs " in *" $deplib "*) ;; *) valid_a_lib=false case $deplibs_check_method in match_pattern*) set dummy $deplibs_check_method; shift match_pattern_regex=`expr "$deplibs_check_method" : "$1 \(.*\)"` if eval "\$ECHO \"$deplib\"" 2>/dev/null | $SED 10q \ | $EGREP "$match_pattern_regex" > /dev/null; then valid_a_lib=: fi ;; pass_all) valid_a_lib=: ;; esac if $valid_a_lib; then echo $ECHO "*** Warning: Linking the shared library $output against the" $ECHO "*** static library $deplib is not portable!" deplibs="$deplib $deplibs" else echo $ECHO "*** Warning: Trying to link with static lib archive $deplib." echo "*** I have the capability to make that library automatically link in when" echo "*** you link to this library. But I can only do this if you have a" echo "*** shared version of the library, which you do not appear to have" echo "*** because the file extensions .$libext of this argument makes me believe" echo "*** that it is just a static archive that I should not use here." fi ;; esac continue ;; prog) if test link != "$pass"; then deplibs="$deplib $deplibs" else compile_deplibs="$deplib $compile_deplibs" finalize_deplibs="$deplib $finalize_deplibs" fi continue ;; esac # linkmode ;; # *.$libext *.lo | *.$objext) if test conv = "$pass"; then deplibs="$deplib $deplibs" elif test prog = "$linkmode"; then if test dlpreopen = "$pass" || test yes != "$dlopen_support" || test no = "$build_libtool_libs"; then # If there is no dlopen support or we're linking statically, # we need to preload. func_append newdlprefiles " $deplib" compile_deplibs="$deplib $compile_deplibs" finalize_deplibs="$deplib $finalize_deplibs" else func_append newdlfiles " $deplib" fi fi continue ;; %DEPLIBS%) alldeplibs=: continue ;; esac # case $deplib $found || test -f "$lib" \ || func_fatal_error "cannot find the library '$lib' or unhandled argument '$deplib'" # Check to see that this really is a libtool archive. func_lalib_unsafe_p "$lib" \ || func_fatal_error "'$lib' is not a valid libtool archive" func_dirname "$lib" "" "." ladir=$func_dirname_result dlname= dlopen= dlpreopen= libdir= library_names= old_library= inherited_linker_flags= # If the library was installed with an old release of libtool, # it will not redefine variables installed, or shouldnotlink installed=yes shouldnotlink=no avoidtemprpath= # Read the .la file func_source "$lib" # Convert "-framework foo" to "foo.ltframework" if test -n "$inherited_linker_flags"; then tmp_inherited_linker_flags=`$ECHO "$inherited_linker_flags" | $SED 's/-framework \([^ $]*\)/\1.ltframework/g'` for tmp_inherited_linker_flag in $tmp_inherited_linker_flags; do case " $new_inherited_linker_flags " in *" $tmp_inherited_linker_flag "*) ;; *) func_append new_inherited_linker_flags " $tmp_inherited_linker_flag";; esac done fi dependency_libs=`$ECHO " $dependency_libs" | $SED 's% \([^ $]*\).ltframework% -framework \1%g'` if test lib,link = "$linkmode,$pass" || test prog,scan = "$linkmode,$pass" || { test prog != "$linkmode" && test lib != "$linkmode"; }; then test -n "$dlopen" && func_append dlfiles " $dlopen" test -n "$dlpreopen" && func_append dlprefiles " $dlpreopen" fi if test conv = "$pass"; then # Only check for convenience libraries deplibs="$lib $deplibs" if test -z "$libdir"; then if test -z "$old_library"; then func_fatal_error "cannot find name of link library for '$lib'" fi # It is a libtool convenience library, so add in its objects. func_append convenience " $ladir/$objdir/$old_library" func_append old_convenience " $ladir/$objdir/$old_library" elif test prog != "$linkmode" && test lib != "$linkmode"; then func_fatal_error "'$lib' is not a convenience library" fi tmp_libs= for deplib in $dependency_libs; do deplibs="$deplib $deplibs" if $opt_preserve_dup_deps; then case "$tmp_libs " in *" $deplib "*) func_append specialdeplibs " $deplib" ;; esac fi func_append tmp_libs " $deplib" done continue fi # $pass = conv # Get the name of the library we link against. linklib= if test -n "$old_library" && { test yes = "$prefer_static_libs" || test built,no = "$prefer_static_libs,$installed"; }; then linklib=$old_library else for l in $old_library $library_names; do linklib=$l done fi if test -z "$linklib"; then func_fatal_error "cannot find name of link library for '$lib'" fi # This library was specified with -dlopen. if test dlopen = "$pass"; then test -z "$libdir" \ && func_fatal_error "cannot -dlopen a convenience library: '$lib'" if test -z "$dlname" || test yes != "$dlopen_support" || test no = "$build_libtool_libs" then # If there is no dlname, no dlopen support or we're linking # statically, we need to preload. We also need to preload any # dependent libraries so libltdl's deplib preloader doesn't # bomb out in the load deplibs phase. func_append dlprefiles " $lib $dependency_libs" else func_append newdlfiles " $lib" fi continue fi # $pass = dlopen # We need an absolute path. case $ladir in [\\/]* | [A-Za-z]:[\\/]*) abs_ladir=$ladir ;; *) abs_ladir=`cd "$ladir" && pwd` if test -z "$abs_ladir"; then func_warning "cannot determine absolute directory name of '$ladir'" func_warning "passing it literally to the linker, although it might fail" abs_ladir=$ladir fi ;; esac func_basename "$lib" laname=$func_basename_result # Find the relevant object directory and library name. if test yes = "$installed"; then if test ! -f "$lt_sysroot$libdir/$linklib" && test -f "$abs_ladir/$linklib"; then func_warning "library '$lib' was moved." dir=$ladir absdir=$abs_ladir libdir=$abs_ladir else dir=$lt_sysroot$libdir absdir=$lt_sysroot$libdir fi test yes = "$hardcode_automatic" && avoidtemprpath=yes else if test ! -f "$ladir/$objdir/$linklib" && test -f "$abs_ladir/$linklib"; then dir=$ladir absdir=$abs_ladir # Remove this search path later func_append notinst_path " $abs_ladir" else dir=$ladir/$objdir absdir=$abs_ladir/$objdir # Remove this search path later func_append notinst_path " $abs_ladir" fi fi # $installed = yes func_stripname 'lib' '.la' "$laname" name=$func_stripname_result # This library was specified with -dlpreopen. if test dlpreopen = "$pass"; then if test -z "$libdir" && test prog = "$linkmode"; then func_fatal_error "only libraries may -dlpreopen a convenience library: '$lib'" fi case $host in # special handling for platforms with PE-DLLs. *cygwin* | *mingw* | *cegcc* ) # Linker will automatically link against shared library if both # static and shared are present. Therefore, ensure we extract # symbols from the import library if a shared library is present # (otherwise, the dlopen module name will be incorrect). We do # this by putting the import library name into $newdlprefiles. # We recover the dlopen module name by 'saving' the la file # name in a special purpose variable, and (later) extracting the # dlname from the la file. if test -n "$dlname"; then func_tr_sh "$dir/$linklib" eval "libfile_$func_tr_sh_result=\$abs_ladir/\$laname" func_append newdlprefiles " $dir/$linklib" else func_append newdlprefiles " $dir/$old_library" # Keep a list of preopened convenience libraries to check # that they are being used correctly in the link pass. test -z "$libdir" && \ func_append dlpreconveniencelibs " $dir/$old_library" fi ;; * ) # Prefer using a static library (so that no silly _DYNAMIC symbols # are required to link). if test -n "$old_library"; then func_append newdlprefiles " $dir/$old_library" # Keep a list of preopened convenience libraries to check # that they are being used correctly in the link pass. test -z "$libdir" && \ func_append dlpreconveniencelibs " $dir/$old_library" # Otherwise, use the dlname, so that lt_dlopen finds it. elif test -n "$dlname"; then func_append newdlprefiles " $dir/$dlname" else func_append newdlprefiles " $dir/$linklib" fi ;; esac fi # $pass = dlpreopen if test -z "$libdir"; then # Link the convenience library if test lib = "$linkmode"; then deplibs="$dir/$old_library $deplibs" elif test prog,link = "$linkmode,$pass"; then compile_deplibs="$dir/$old_library $compile_deplibs" finalize_deplibs="$dir/$old_library $finalize_deplibs" else deplibs="$lib $deplibs" # used for prog,scan pass fi continue fi if test prog = "$linkmode" && test link != "$pass"; then func_append newlib_search_path " $ladir" deplibs="$lib $deplibs" linkalldeplibs=false if test no != "$link_all_deplibs" || test -z "$library_names" || test no = "$build_libtool_libs"; then linkalldeplibs=: fi tmp_libs= for deplib in $dependency_libs; do case $deplib in -L*) func_stripname '-L' '' "$deplib" func_resolve_sysroot "$func_stripname_result" func_append newlib_search_path " $func_resolve_sysroot_result" ;; esac # Need to link against all dependency_libs? if $linkalldeplibs; then deplibs="$deplib $deplibs" else # Need to hardcode shared library paths # or/and link against static libraries newdependency_libs="$deplib $newdependency_libs" fi if $opt_preserve_dup_deps; then case "$tmp_libs " in *" $deplib "*) func_append specialdeplibs " $deplib" ;; esac fi func_append tmp_libs " $deplib" done # for deplib continue fi # $linkmode = prog... if test prog,link = "$linkmode,$pass"; then if test -n "$library_names" && { { test no = "$prefer_static_libs" || test built,yes = "$prefer_static_libs,$installed"; } || test -z "$old_library"; }; then # We need to hardcode the library path if test -n "$shlibpath_var" && test -z "$avoidtemprpath"; then # Make sure the rpath contains only unique directories. case $temp_rpath: in *"$absdir:"*) ;; *) func_append temp_rpath "$absdir:" ;; esac fi # Hardcode the library path. # Skip directories that are in the system default run-time # search path. case " $sys_lib_dlsearch_path " in *" $absdir "*) ;; *) case "$compile_rpath " in *" $absdir "*) ;; *) func_append compile_rpath " $absdir" ;; esac ;; esac case " $sys_lib_dlsearch_path " in *" $libdir "*) ;; *) case "$finalize_rpath " in *" $libdir "*) ;; *) func_append finalize_rpath " $libdir" ;; esac ;; esac fi # $linkmode,$pass = prog,link... if $alldeplibs && { test pass_all = "$deplibs_check_method" || { test yes = "$build_libtool_libs" && test -n "$library_names"; }; }; then # We only need to search for static libraries continue fi fi link_static=no # Whether the deplib will be linked statically use_static_libs=$prefer_static_libs if test built = "$use_static_libs" && test yes = "$installed"; then use_static_libs=no fi if test -n "$library_names" && { test no = "$use_static_libs" || test -z "$old_library"; }; then case $host in *cygwin* | *mingw* | *cegcc* | *os2*) # No point in relinking DLLs because paths are not encoded func_append notinst_deplibs " $lib" need_relink=no ;; *) if test no = "$installed"; then func_append notinst_deplibs " $lib" need_relink=yes fi ;; esac # This is a shared library # Warn about portability, can't link against -module's on some # systems (darwin). Don't bleat about dlopened modules though! dlopenmodule= for dlpremoduletest in $dlprefiles; do if test "X$dlpremoduletest" = "X$lib"; then dlopenmodule=$dlpremoduletest break fi done if test -z "$dlopenmodule" && test yes = "$shouldnotlink" && test link = "$pass"; then echo if test prog = "$linkmode"; then $ECHO "*** Warning: Linking the executable $output against the loadable module" else $ECHO "*** Warning: Linking the shared library $output against the loadable module" fi $ECHO "*** $linklib is not portable!" fi if test lib = "$linkmode" && test yes = "$hardcode_into_libs"; then # Hardcode the library path. # Skip directories that are in the system default run-time # search path. case " $sys_lib_dlsearch_path " in *" $absdir "*) ;; *) case "$compile_rpath " in *" $absdir "*) ;; *) func_append compile_rpath " $absdir" ;; esac ;; esac case " $sys_lib_dlsearch_path " in *" $libdir "*) ;; *) case "$finalize_rpath " in *" $libdir "*) ;; *) func_append finalize_rpath " $libdir" ;; esac ;; esac fi if test -n "$old_archive_from_expsyms_cmds"; then # figure out the soname set dummy $library_names shift realname=$1 shift libname=`eval "\\$ECHO \"$libname_spec\""` # use dlname if we got it. it's perfectly good, no? if test -n "$dlname"; then soname=$dlname elif test -n "$soname_spec"; then # bleh windows case $host in *cygwin* | mingw* | *cegcc* | *os2*) func_arith $current - $age major=$func_arith_result versuffix=-$major ;; esac eval soname=\"$soname_spec\" else soname=$realname fi # Make a new name for the extract_expsyms_cmds to use soroot=$soname func_basename "$soroot" soname=$func_basename_result func_stripname 'lib' '.dll' "$soname" newlib=libimp-$func_stripname_result.a # If the library has no export list, then create one now if test -f "$output_objdir/$soname-def"; then : else func_verbose "extracting exported symbol list from '$soname'" func_execute_cmds "$extract_expsyms_cmds" 'exit $?' fi # Create $newlib if test -f "$output_objdir/$newlib"; then :; else func_verbose "generating import library for '$soname'" func_execute_cmds "$old_archive_from_expsyms_cmds" 'exit $?' fi # make sure the library variables are pointing to the new library dir=$output_objdir linklib=$newlib fi # test -n "$old_archive_from_expsyms_cmds" if test prog = "$linkmode" || test relink != "$opt_mode"; then add_shlibpath= add_dir= add= lib_linked=yes case $hardcode_action in immediate | unsupported) if test no = "$hardcode_direct"; then add=$dir/$linklib case $host in *-*-sco3.2v5.0.[024]*) add_dir=-L$dir ;; *-*-sysv4*uw2*) add_dir=-L$dir ;; *-*-sysv5OpenUNIX* | *-*-sysv5UnixWare7.[01].[10]* | \ *-*-unixware7*) add_dir=-L$dir ;; *-*-darwin* ) # if the lib is a (non-dlopened) module then we cannot # link against it, someone is ignoring the earlier warnings if /usr/bin/file -L $add 2> /dev/null | $GREP ": [^:]* bundle" >/dev/null; then if test "X$dlopenmodule" != "X$lib"; then $ECHO "*** Warning: lib $linklib is a module, not a shared library" if test -z "$old_library"; then echo echo "*** And there doesn't seem to be a static archive available" echo "*** The link will probably fail, sorry" else add=$dir/$old_library fi elif test -n "$old_library"; then add=$dir/$old_library fi fi esac elif test no = "$hardcode_minus_L"; then case $host in *-*-sunos*) add_shlibpath=$dir ;; esac add_dir=-L$dir add=-l$name elif test no = "$hardcode_shlibpath_var"; then add_shlibpath=$dir add=-l$name else lib_linked=no fi ;; relink) if test yes = "$hardcode_direct" && test no = "$hardcode_direct_absolute"; then add=$dir/$linklib elif test yes = "$hardcode_minus_L"; then add_dir=-L$absdir # Try looking first in the location we're being installed to. if test -n "$inst_prefix_dir"; then case $libdir in [\\/]*) func_append add_dir " -L$inst_prefix_dir$libdir" ;; esac fi add=-l$name elif test yes = "$hardcode_shlibpath_var"; then add_shlibpath=$dir add=-l$name else lib_linked=no fi ;; *) lib_linked=no ;; esac if test yes != "$lib_linked"; then func_fatal_configuration "unsupported hardcode properties" fi if test -n "$add_shlibpath"; then case :$compile_shlibpath: in *":$add_shlibpath:"*) ;; *) func_append compile_shlibpath "$add_shlibpath:" ;; esac fi if test prog = "$linkmode"; then test -n "$add_dir" && compile_deplibs="$add_dir $compile_deplibs" test -n "$add" && compile_deplibs="$add $compile_deplibs" else test -n "$add_dir" && deplibs="$add_dir $deplibs" test -n "$add" && deplibs="$add $deplibs" if test yes != "$hardcode_direct" && test yes != "$hardcode_minus_L" && test yes = "$hardcode_shlibpath_var"; then case :$finalize_shlibpath: in *":$libdir:"*) ;; *) func_append finalize_shlibpath "$libdir:" ;; esac fi fi fi if test prog = "$linkmode" || test relink = "$opt_mode"; then add_shlibpath= add_dir= add= # Finalize command for both is simple: just hardcode it. if test yes = "$hardcode_direct" && test no = "$hardcode_direct_absolute"; then add=$libdir/$linklib elif test yes = "$hardcode_minus_L"; then add_dir=-L$libdir add=-l$name elif test yes = "$hardcode_shlibpath_var"; then case :$finalize_shlibpath: in *":$libdir:"*) ;; *) func_append finalize_shlibpath "$libdir:" ;; esac add=-l$name elif test yes = "$hardcode_automatic"; then if test -n "$inst_prefix_dir" && test -f "$inst_prefix_dir$libdir/$linklib"; then add=$inst_prefix_dir$libdir/$linklib else add=$libdir/$linklib fi else # We cannot seem to hardcode it, guess we'll fake it. add_dir=-L$libdir # Try looking first in the location we're being installed to. if test -n "$inst_prefix_dir"; then case $libdir in [\\/]*) func_append add_dir " -L$inst_prefix_dir$libdir" ;; esac fi add=-l$name fi if test prog = "$linkmode"; then test -n "$add_dir" && finalize_deplibs="$add_dir $finalize_deplibs" test -n "$add" && finalize_deplibs="$add $finalize_deplibs" else test -n "$add_dir" && deplibs="$add_dir $deplibs" test -n "$add" && deplibs="$add $deplibs" fi fi elif test prog = "$linkmode"; then # Here we assume that one of hardcode_direct or hardcode_minus_L # is not unsupported. This is valid on all known static and # shared platforms. if test unsupported != "$hardcode_direct"; then test -n "$old_library" && linklib=$old_library compile_deplibs="$dir/$linklib $compile_deplibs" finalize_deplibs="$dir/$linklib $finalize_deplibs" else compile_deplibs="-l$name -L$dir $compile_deplibs" finalize_deplibs="-l$name -L$dir $finalize_deplibs" fi elif test yes = "$build_libtool_libs"; then # Not a shared library if test pass_all != "$deplibs_check_method"; then # We're trying link a shared library against a static one # but the system doesn't support it. # Just print a warning and add the library to dependency_libs so # that the program can be linked against the static library. echo $ECHO "*** Warning: This system cannot link to static lib archive $lib." echo "*** I have the capability to make that library automatically link in when" echo "*** you link to this library. But I can only do this if you have a" echo "*** shared version of the library, which you do not appear to have." if test yes = "$module"; then echo "*** But as you try to build a module library, libtool will still create " echo "*** a static module, that should work as long as the dlopening application" echo "*** is linked with the -dlopen flag to resolve symbols at runtime." if test -z "$global_symbol_pipe"; then echo echo "*** However, this would only work if libtool was able to extract symbol" echo "*** lists from a program, using 'nm' or equivalent, but libtool could" echo "*** not find such a program. So, this module is probably useless." echo "*** 'nm' from GNU binutils and a full rebuild may help." fi if test no = "$build_old_libs"; then build_libtool_libs=module build_old_libs=yes else build_libtool_libs=no fi fi else deplibs="$dir/$old_library $deplibs" link_static=yes fi fi # link shared/static library? if test lib = "$linkmode"; then if test -n "$dependency_libs" && { test yes != "$hardcode_into_libs" || test yes = "$build_old_libs" || test yes = "$link_static"; }; then # Extract -R from dependency_libs temp_deplibs= for libdir in $dependency_libs; do case $libdir in -R*) func_stripname '-R' '' "$libdir" temp_xrpath=$func_stripname_result case " $xrpath " in *" $temp_xrpath "*) ;; *) func_append xrpath " $temp_xrpath";; esac;; *) func_append temp_deplibs " $libdir";; esac done dependency_libs=$temp_deplibs fi func_append newlib_search_path " $absdir" # Link against this library test no = "$link_static" && newdependency_libs="$abs_ladir/$laname $newdependency_libs" # ... and its dependency_libs tmp_libs= for deplib in $dependency_libs; do newdependency_libs="$deplib $newdependency_libs" case $deplib in -L*) func_stripname '-L' '' "$deplib" func_resolve_sysroot "$func_stripname_result";; *) func_resolve_sysroot "$deplib" ;; esac if $opt_preserve_dup_deps; then case "$tmp_libs " in *" $func_resolve_sysroot_result "*) func_append specialdeplibs " $func_resolve_sysroot_result" ;; esac fi func_append tmp_libs " $func_resolve_sysroot_result" done if test no != "$link_all_deplibs"; then # Add the search paths of all dependency libraries for deplib in $dependency_libs; do path= case $deplib in -L*) path=$deplib ;; *.la) func_resolve_sysroot "$deplib" deplib=$func_resolve_sysroot_result func_dirname "$deplib" "" "." dir=$func_dirname_result # We need an absolute path. case $dir in [\\/]* | [A-Za-z]:[\\/]*) absdir=$dir ;; *) absdir=`cd "$dir" && pwd` if test -z "$absdir"; then func_warning "cannot determine absolute directory name of '$dir'" absdir=$dir fi ;; esac if $GREP "^installed=no" $deplib > /dev/null; then case $host in *-*-darwin*) depdepl= eval deplibrary_names=`$SED -n -e 's/^library_names=\(.*\)$/\1/p' $deplib` if test -n "$deplibrary_names"; then for tmp in $deplibrary_names; do depdepl=$tmp done if test -f "$absdir/$objdir/$depdepl"; then depdepl=$absdir/$objdir/$depdepl darwin_install_name=`$OTOOL -L $depdepl | awk '{if (NR == 2) {print $1;exit}}'` if test -z "$darwin_install_name"; then darwin_install_name=`$OTOOL64 -L $depdepl | awk '{if (NR == 2) {print $1;exit}}'` fi func_append compiler_flags " $wl-dylib_file $wl$darwin_install_name:$depdepl" func_append linker_flags " -dylib_file $darwin_install_name:$depdepl" path= fi fi ;; *) path=-L$absdir/$objdir ;; esac else eval libdir=`$SED -n -e 's/^libdir=\(.*\)$/\1/p' $deplib` test -z "$libdir" && \ func_fatal_error "'$deplib' is not a valid libtool archive" test "$absdir" != "$libdir" && \ func_warning "'$deplib' seems to be moved" path=-L$absdir fi ;; esac case " $deplibs " in *" $path "*) ;; *) deplibs="$path $deplibs" ;; esac done fi # link_all_deplibs != no fi # linkmode = lib done # for deplib in $libs if test link = "$pass"; then if test prog = "$linkmode"; then compile_deplibs="$new_inherited_linker_flags $compile_deplibs" finalize_deplibs="$new_inherited_linker_flags $finalize_deplibs" else compiler_flags="$compiler_flags "`$ECHO " $new_inherited_linker_flags" | $SED 's% \([^ $]*\).ltframework% -framework \1%g'` fi fi dependency_libs=$newdependency_libs if test dlpreopen = "$pass"; then # Link the dlpreopened libraries before other libraries for deplib in $save_deplibs; do deplibs="$deplib $deplibs" done fi if test dlopen != "$pass"; then test conv = "$pass" || { # Make sure lib_search_path contains only unique directories. lib_search_path= for dir in $newlib_search_path; do case "$lib_search_path " in *" $dir "*) ;; *) func_append lib_search_path " $dir" ;; esac done newlib_search_path= } if test prog,link = "$linkmode,$pass"; then vars="compile_deplibs finalize_deplibs" else vars=deplibs fi for var in $vars dependency_libs; do # Add libraries to $var in reverse order eval tmp_libs=\"\$$var\" new_libs= for deplib in $tmp_libs; do # FIXME: Pedantically, this is the right thing to do, so # that some nasty dependency loop isn't accidentally # broken: #new_libs="$deplib $new_libs" # Pragmatically, this seems to cause very few problems in # practice: case $deplib in -L*) new_libs="$deplib $new_libs" ;; -R*) ;; *) # And here is the reason: when a library appears more # than once as an explicit dependence of a library, or # is implicitly linked in more than once by the # compiler, it is considered special, and multiple # occurrences thereof are not removed. Compare this # with having the same library being listed as a # dependency of multiple other libraries: in this case, # we know (pedantically, we assume) the library does not # need to be listed more than once, so we keep only the # last copy. This is not always right, but it is rare # enough that we require users that really mean to play # such unportable linking tricks to link the library # using -Wl,-lname, so that libtool does not consider it # for duplicate removal. case " $specialdeplibs " in *" $deplib "*) new_libs="$deplib $new_libs" ;; *) case " $new_libs " in *" $deplib "*) ;; *) new_libs="$deplib $new_libs" ;; esac ;; esac ;; esac done tmp_libs= for deplib in $new_libs; do case $deplib in -L*) case " $tmp_libs " in *" $deplib "*) ;; *) func_append tmp_libs " $deplib" ;; esac ;; *) func_append tmp_libs " $deplib" ;; esac done eval $var=\"$tmp_libs\" done # for var fi # Add Sun CC postdeps if required: test CXX = "$tagname" && { case $host_os in linux*) case `$CC -V 2>&1 | sed 5q` in *Sun\ C*) # Sun C++ 5.9 func_suncc_cstd_abi if test no != "$suncc_use_cstd_abi"; then func_append postdeps ' -library=Cstd -library=Crun' fi ;; esac ;; solaris*) func_cc_basename "$CC" case $func_cc_basename_result in CC* | sunCC*) func_suncc_cstd_abi if test no != "$suncc_use_cstd_abi"; then func_append postdeps ' -library=Cstd -library=Crun' fi ;; esac ;; esac } # Last step: remove runtime libs from dependency_libs # (they stay in deplibs) tmp_libs= for i in $dependency_libs; do case " $predeps $postdeps $compiler_lib_search_path " in *" $i "*) i= ;; esac if test -n "$i"; then func_append tmp_libs " $i" fi done dependency_libs=$tmp_libs done # for pass if test prog = "$linkmode"; then dlfiles=$newdlfiles fi if test prog = "$linkmode" || test lib = "$linkmode"; then dlprefiles=$newdlprefiles fi case $linkmode in oldlib) if test -n "$dlfiles$dlprefiles" || test no != "$dlself"; then func_warning "'-dlopen' is ignored for archives" fi case " $deplibs" in *\ -l* | *\ -L*) func_warning "'-l' and '-L' are ignored for archives" ;; esac test -n "$rpath" && \ func_warning "'-rpath' is ignored for archives" test -n "$xrpath" && \ func_warning "'-R' is ignored for archives" test -n "$vinfo" && \ func_warning "'-version-info/-version-number' is ignored for archives" test -n "$release" && \ func_warning "'-release' is ignored for archives" test -n "$export_symbols$export_symbols_regex" && \ func_warning "'-export-symbols' is ignored for archives" # Now set the variables for building old libraries. build_libtool_libs=no oldlibs=$output func_append objs "$old_deplibs" ;; lib) # Make sure we only generate libraries of the form 'libNAME.la'. case $outputname in lib*) func_stripname 'lib' '.la' "$outputname" name=$func_stripname_result eval shared_ext=\"$shrext_cmds\" eval libname=\"$libname_spec\" ;; *) test no = "$module" \ && func_fatal_help "libtool library '$output' must begin with 'lib'" if test no != "$need_lib_prefix"; then # Add the "lib" prefix for modules if required func_stripname '' '.la' "$outputname" name=$func_stripname_result eval shared_ext=\"$shrext_cmds\" eval libname=\"$libname_spec\" else func_stripname '' '.la' "$outputname" libname=$func_stripname_result fi ;; esac if test -n "$objs"; then if test pass_all != "$deplibs_check_method"; then func_fatal_error "cannot build libtool library '$output' from non-libtool objects on this host:$objs" else echo $ECHO "*** Warning: Linking the shared library $output against the non-libtool" $ECHO "*** objects $objs is not portable!" func_append libobjs " $objs" fi fi test no = "$dlself" \ || func_warning "'-dlopen self' is ignored for libtool libraries" set dummy $rpath shift test 1 -lt "$#" \ && func_warning "ignoring multiple '-rpath's for a libtool library" install_libdir=$1 oldlibs= if test -z "$rpath"; then if test yes = "$build_libtool_libs"; then # Building a libtool convenience library. # Some compilers have problems with a '.al' extension so # convenience libraries should have the same extension an # archive normally would. oldlibs="$output_objdir/$libname.$libext $oldlibs" build_libtool_libs=convenience build_old_libs=yes fi test -n "$vinfo" && \ func_warning "'-version-info/-version-number' is ignored for convenience libraries" test -n "$release" && \ func_warning "'-release' is ignored for convenience libraries" else # Parse the version information argument. save_ifs=$IFS; IFS=: set dummy $vinfo 0 0 0 shift IFS=$save_ifs test -n "$7" && \ func_fatal_help "too many parameters to '-version-info'" # convert absolute version numbers to libtool ages # this retains compatibility with .la files and attempts # to make the code below a bit more comprehensible case $vinfo_number in yes) number_major=$1 number_minor=$2 number_revision=$3 # # There are really only two kinds -- those that # use the current revision as the major version # and those that subtract age and use age as # a minor version. But, then there is irix # that has an extra 1 added just for fun # case $version_type in # correct linux to gnu/linux during the next big refactor darwin|freebsd-elf|linux|osf|windows|none) func_arith $number_major + $number_minor current=$func_arith_result age=$number_minor revision=$number_revision ;; freebsd-aout|qnx|sunos) current=$number_major revision=$number_minor age=0 ;; irix|nonstopux) func_arith $number_major + $number_minor current=$func_arith_result age=$number_minor revision=$number_minor lt_irix_increment=no ;; esac ;; no) current=$1 revision=$2 age=$3 ;; esac # Check that each of the things are valid numbers. case $current in 0|[1-9]|[1-9][0-9]|[1-9][0-9][0-9]|[1-9][0-9][0-9][0-9]|[1-9][0-9][0-9][0-9][0-9]) ;; *) func_error "CURRENT '$current' must be a nonnegative integer" func_fatal_error "'$vinfo' is not valid version information" ;; esac case $revision in 0|[1-9]|[1-9][0-9]|[1-9][0-9][0-9]|[1-9][0-9][0-9][0-9]|[1-9][0-9][0-9][0-9][0-9]) ;; *) func_error "REVISION '$revision' must be a nonnegative integer" func_fatal_error "'$vinfo' is not valid version information" ;; esac case $age in 0|[1-9]|[1-9][0-9]|[1-9][0-9][0-9]|[1-9][0-9][0-9][0-9]|[1-9][0-9][0-9][0-9][0-9]) ;; *) func_error "AGE '$age' must be a nonnegative integer" func_fatal_error "'$vinfo' is not valid version information" ;; esac if test "$age" -gt "$current"; then func_error "AGE '$age' is greater than the current interface number '$current'" func_fatal_error "'$vinfo' is not valid version information" fi # Calculate the version variables. major= versuffix= verstring= case $version_type in none) ;; darwin) # Like Linux, but with the current version available in # verstring for coding it into the library header func_arith $current - $age major=.$func_arith_result versuffix=$major.$age.$revision # Darwin ld doesn't like 0 for these options... func_arith $current + 1 minor_current=$func_arith_result xlcverstring="$wl-compatibility_version $wl$minor_current $wl-current_version $wl$minor_current.$revision" verstring="-compatibility_version $minor_current -current_version $minor_current.$revision" # On Darwin other compilers case $CC in nagfor*) verstring="$wl-compatibility_version $wl$minor_current $wl-current_version $wl$minor_current.$revision" ;; *) verstring="-compatibility_version $minor_current -current_version $minor_current.$revision" ;; esac ;; freebsd-aout) major=.$current versuffix=.$current.$revision ;; freebsd-elf) func_arith $current - $age major=.$func_arith_result versuffix=$major.$age.$revision ;; irix | nonstopux) if test no = "$lt_irix_increment"; then func_arith $current - $age else func_arith $current - $age + 1 fi major=$func_arith_result case $version_type in nonstopux) verstring_prefix=nonstopux ;; *) verstring_prefix=sgi ;; esac verstring=$verstring_prefix$major.$revision # Add in all the interfaces that we are compatible with. loop=$revision while test 0 -ne "$loop"; do func_arith $revision - $loop iface=$func_arith_result func_arith $loop - 1 loop=$func_arith_result verstring=$verstring_prefix$major.$iface:$verstring done # Before this point, $major must not contain '.'. major=.$major versuffix=$major.$revision ;; linux) # correct to gnu/linux during the next big refactor func_arith $current - $age major=.$func_arith_result versuffix=$major.$age.$revision ;; osf) func_arith $current - $age major=.$func_arith_result versuffix=.$current.$age.$revision verstring=$current.$age.$revision # Add in all the interfaces that we are compatible with. loop=$age while test 0 -ne "$loop"; do func_arith $current - $loop iface=$func_arith_result func_arith $loop - 1 loop=$func_arith_result verstring=$verstring:$iface.0 done # Make executables depend on our current version. func_append verstring ":$current.0" ;; qnx) major=.$current versuffix=.$current ;; sco) major=.$current versuffix=.$current ;; sunos) major=.$current versuffix=.$current.$revision ;; windows) # Use '-' rather than '.', since we only want one # extension on DOS 8.3 file systems. func_arith $current - $age major=$func_arith_result versuffix=-$major ;; *) func_fatal_configuration "unknown library version type '$version_type'" ;; esac # Clear the version info if we defaulted, and they specified a release. if test -z "$vinfo" && test -n "$release"; then major= case $version_type in darwin) # we can't check for "0.0" in archive_cmds due to quoting # problems, so we reset it completely verstring= ;; *) verstring=0.0 ;; esac if test no = "$need_version"; then versuffix= else versuffix=.0.0 fi fi # Remove version info from name if versioning should be avoided if test yes,no = "$avoid_version,$need_version"; then major= versuffix= verstring= fi # Check to see if the archive will have undefined symbols. if test yes = "$allow_undefined"; then if test unsupported = "$allow_undefined_flag"; then if test yes = "$build_old_libs"; then func_warning "undefined symbols not allowed in $host shared libraries; building static only" build_libtool_libs=no else func_fatal_error "can't build $host shared library unless -no-undefined is specified" fi fi else # Don't allow undefined symbols. allow_undefined_flag=$no_undefined_flag fi fi func_generate_dlsyms "$libname" "$libname" : func_append libobjs " $symfileobj" test " " = "$libobjs" && libobjs= if test relink != "$opt_mode"; then # Remove our outputs, but don't remove object files since they # may have been created when compiling PIC objects. removelist= tempremovelist=`$ECHO "$output_objdir/*"` for p in $tempremovelist; do case $p in *.$objext | *.gcno) ;; $output_objdir/$outputname | $output_objdir/$libname.* | $output_objdir/$libname$release.*) if test -n "$precious_files_regex"; then if $ECHO "$p" | $EGREP -e "$precious_files_regex" >/dev/null 2>&1 then continue fi fi func_append removelist " $p" ;; *) ;; esac done test -n "$removelist" && \ func_show_eval "${RM}r \$removelist" fi # Now set the variables for building old libraries. if test yes = "$build_old_libs" && test convenience != "$build_libtool_libs"; then func_append oldlibs " $output_objdir/$libname.$libext" # Transform .lo files to .o files. oldobjs="$objs "`$ECHO "$libobjs" | $SP2NL | $SED "/\.$libext$/d; $lo2o" | $NL2SP` fi # Eliminate all temporary directories. #for path in $notinst_path; do # lib_search_path=`$ECHO "$lib_search_path " | $SED "s% $path % %g"` # deplibs=`$ECHO "$deplibs " | $SED "s% -L$path % %g"` # dependency_libs=`$ECHO "$dependency_libs " | $SED "s% -L$path % %g"` #done if test -n "$xrpath"; then # If the user specified any rpath flags, then add them. temp_xrpath= for libdir in $xrpath; do func_replace_sysroot "$libdir" func_append temp_xrpath " -R$func_replace_sysroot_result" case "$finalize_rpath " in *" $libdir "*) ;; *) func_append finalize_rpath " $libdir" ;; esac done if test yes != "$hardcode_into_libs" || test yes = "$build_old_libs"; then dependency_libs="$temp_xrpath $dependency_libs" fi fi # Make sure dlfiles contains only unique files that won't be dlpreopened old_dlfiles=$dlfiles dlfiles= for lib in $old_dlfiles; do case " $dlprefiles $dlfiles " in *" $lib "*) ;; *) func_append dlfiles " $lib" ;; esac done # Make sure dlprefiles contains only unique files old_dlprefiles=$dlprefiles dlprefiles= for lib in $old_dlprefiles; do case "$dlprefiles " in *" $lib "*) ;; *) func_append dlprefiles " $lib" ;; esac done if test yes = "$build_libtool_libs"; then if test -n "$rpath"; then case $host in *-*-cygwin* | *-*-mingw* | *-*-pw32* | *-*-os2* | *-*-beos* | *-cegcc* | *-*-haiku*) # these systems don't actually have a c library (as such)! ;; *-*-rhapsody* | *-*-darwin1.[012]) # Rhapsody C library is in the System framework func_append deplibs " System.ltframework" ;; *-*-netbsd*) # Don't link with libc until the a.out ld.so is fixed. ;; *-*-openbsd* | *-*-freebsd* | *-*-dragonfly*) # Do not include libc due to us having libc/libc_r. ;; *-*-sco3.2v5* | *-*-sco5v6*) # Causes problems with __ctype ;; *-*-sysv4.2uw2* | *-*-sysv5* | *-*-unixware* | *-*-OpenUNIX*) # Compiler inserts libc in the correct place for threads to work ;; *) # Add libc to deplibs on all other systems if necessary. if test yes = "$build_libtool_need_lc"; then func_append deplibs " -lc" fi ;; esac fi # Transform deplibs into only deplibs that can be linked in shared. name_save=$name libname_save=$libname release_save=$release versuffix_save=$versuffix major_save=$major # I'm not sure if I'm treating the release correctly. I think # release should show up in the -l (ie -lgmp5) so we don't want to # add it in twice. Is that correct? release= versuffix= major= newdeplibs= droppeddeps=no case $deplibs_check_method in pass_all) # Don't check for shared/static. Everything works. # This might be a little naive. We might want to check # whether the library exists or not. But this is on # osf3 & osf4 and I'm not really sure... Just # implementing what was already the behavior. newdeplibs=$deplibs ;; test_compile) # This code stresses the "libraries are programs" paradigm to its # limits. Maybe even breaks it. We compile a program, linking it # against the deplibs as a proxy for the library. Then we can check # whether they linked in statically or dynamically with ldd. $opt_dry_run || $RM conftest.c cat > conftest.c </dev/null` $nocaseglob else potential_libs=`ls $i/$libnameglob[.-]* 2>/dev/null` fi for potent_lib in $potential_libs; do # Follow soft links. if ls -lLd "$potent_lib" 2>/dev/null | $GREP " -> " >/dev/null; then continue fi # The statement above tries to avoid entering an # endless loop below, in case of cyclic links. # We might still enter an endless loop, since a link # loop can be closed while we follow links, # but so what? potlib=$potent_lib while test -h "$potlib" 2>/dev/null; do potliblink=`ls -ld $potlib | $SED 's/.* -> //'` case $potliblink in [\\/]* | [A-Za-z]:[\\/]*) potlib=$potliblink;; *) potlib=`$ECHO "$potlib" | $SED 's|[^/]*$||'`"$potliblink";; esac done if eval $file_magic_cmd \"\$potlib\" 2>/dev/null | $SED -e 10q | $EGREP "$file_magic_regex" > /dev/null; then func_append newdeplibs " $a_deplib" a_deplib= break 2 fi done done fi if test -n "$a_deplib"; then droppeddeps=yes echo $ECHO "*** Warning: linker path does not have real file for library $a_deplib." echo "*** I have the capability to make that library automatically link in when" echo "*** you link to this library. But I can only do this if you have a" echo "*** shared version of the library, which you do not appear to have" echo "*** because I did check the linker path looking for a file starting" if test -z "$potlib"; then $ECHO "*** with $libname but no candidates were found. (...for file magic test)" else $ECHO "*** with $libname and none of the candidates passed a file format test" $ECHO "*** using a file magic. Last file checked: $potlib" fi fi ;; *) # Add a -L argument. func_append newdeplibs " $a_deplib" ;; esac done # Gone through all deplibs. ;; match_pattern*) set dummy $deplibs_check_method; shift match_pattern_regex=`expr "$deplibs_check_method" : "$1 \(.*\)"` for a_deplib in $deplibs; do case $a_deplib in -l*) func_stripname -l '' "$a_deplib" name=$func_stripname_result if test yes = "$allow_libtool_libs_with_static_runtimes"; then case " $predeps $postdeps " in *" $a_deplib "*) func_append newdeplibs " $a_deplib" a_deplib= ;; esac fi if test -n "$a_deplib"; then libname=`eval "\\$ECHO \"$libname_spec\""` for i in $lib_search_path $sys_lib_search_path $shlib_search_path; do potential_libs=`ls $i/$libname[.-]* 2>/dev/null` for potent_lib in $potential_libs; do potlib=$potent_lib # see symlink-check above in file_magic test if eval "\$ECHO \"$potent_lib\"" 2>/dev/null | $SED 10q | \ $EGREP "$match_pattern_regex" > /dev/null; then func_append newdeplibs " $a_deplib" a_deplib= break 2 fi done done fi if test -n "$a_deplib"; then droppeddeps=yes echo $ECHO "*** Warning: linker path does not have real file for library $a_deplib." echo "*** I have the capability to make that library automatically link in when" echo "*** you link to this library. But I can only do this if you have a" echo "*** shared version of the library, which you do not appear to have" echo "*** because I did check the linker path looking for a file starting" if test -z "$potlib"; then $ECHO "*** with $libname but no candidates were found. (...for regex pattern test)" else $ECHO "*** with $libname and none of the candidates passed a file format test" $ECHO "*** using a regex pattern. Last file checked: $potlib" fi fi ;; *) # Add a -L argument. func_append newdeplibs " $a_deplib" ;; esac done # Gone through all deplibs. ;; none | unknown | *) newdeplibs= tmp_deplibs=`$ECHO " $deplibs" | $SED 's/ -lc$//; s/ -[LR][^ ]*//g'` if test yes = "$allow_libtool_libs_with_static_runtimes"; then for i in $predeps $postdeps; do # can't use Xsed below, because $i might contain '/' tmp_deplibs=`$ECHO " $tmp_deplibs" | $SED "s|$i||"` done fi case $tmp_deplibs in *[!\ \ ]*) echo if test none = "$deplibs_check_method"; then echo "*** Warning: inter-library dependencies are not supported in this platform." else echo "*** Warning: inter-library dependencies are not known to be supported." fi echo "*** All declared inter-library dependencies are being dropped." droppeddeps=yes ;; esac ;; esac versuffix=$versuffix_save major=$major_save release=$release_save libname=$libname_save name=$name_save case $host in *-*-rhapsody* | *-*-darwin1.[012]) # On Rhapsody replace the C library with the System framework newdeplibs=`$ECHO " $newdeplibs" | $SED 's/ -lc / System.ltframework /'` ;; esac if test yes = "$droppeddeps"; then if test yes = "$module"; then echo echo "*** Warning: libtool could not satisfy all declared inter-library" $ECHO "*** dependencies of module $libname. Therefore, libtool will create" echo "*** a static module, that should work as long as the dlopening" echo "*** application is linked with the -dlopen flag." if test -z "$global_symbol_pipe"; then echo echo "*** However, this would only work if libtool was able to extract symbol" echo "*** lists from a program, using 'nm' or equivalent, but libtool could" echo "*** not find such a program. So, this module is probably useless." echo "*** 'nm' from GNU binutils and a full rebuild may help." fi if test no = "$build_old_libs"; then oldlibs=$output_objdir/$libname.$libext build_libtool_libs=module build_old_libs=yes else build_libtool_libs=no fi else echo "*** The inter-library dependencies that have been dropped here will be" echo "*** automatically added whenever a program is linked with this library" echo "*** or is declared to -dlopen it." if test no = "$allow_undefined"; then echo echo "*** Since this library must not contain undefined symbols," echo "*** because either the platform does not support them or" echo "*** it was explicitly requested with -no-undefined," echo "*** libtool will only create a static version of it." if test no = "$build_old_libs"; then oldlibs=$output_objdir/$libname.$libext build_libtool_libs=module build_old_libs=yes else build_libtool_libs=no fi fi fi fi # Done checking deplibs! deplibs=$newdeplibs fi # Time to change all our "foo.ltframework" stuff back to "-framework foo" case $host in *-*-darwin*) newdeplibs=`$ECHO " $newdeplibs" | $SED 's% \([^ $]*\).ltframework% -framework \1%g'` new_inherited_linker_flags=`$ECHO " $new_inherited_linker_flags" | $SED 's% \([^ $]*\).ltframework% -framework \1%g'` deplibs=`$ECHO " $deplibs" | $SED 's% \([^ $]*\).ltframework% -framework \1%g'` ;; esac # move library search paths that coincide with paths to not yet # installed libraries to the beginning of the library search list new_libs= for path in $notinst_path; do case " $new_libs " in *" -L$path/$objdir "*) ;; *) case " $deplibs " in *" -L$path/$objdir "*) func_append new_libs " -L$path/$objdir" ;; esac ;; esac done for deplib in $deplibs; do case $deplib in -L*) case " $new_libs " in *" $deplib "*) ;; *) func_append new_libs " $deplib" ;; esac ;; *) func_append new_libs " $deplib" ;; esac done deplibs=$new_libs # All the library-specific variables (install_libdir is set above). library_names= old_library= dlname= # Test again, we may have decided not to build it any more if test yes = "$build_libtool_libs"; then # Remove $wl instances when linking with ld. # FIXME: should test the right _cmds variable. case $archive_cmds in *\$LD\ *) wl= ;; esac if test yes = "$hardcode_into_libs"; then # Hardcode the library paths hardcode_libdirs= dep_rpath= rpath=$finalize_rpath test relink = "$opt_mode" || rpath=$compile_rpath$rpath for libdir in $rpath; do if test -n "$hardcode_libdir_flag_spec"; then if test -n "$hardcode_libdir_separator"; then func_replace_sysroot "$libdir" libdir=$func_replace_sysroot_result if test -z "$hardcode_libdirs"; then hardcode_libdirs=$libdir else # Just accumulate the unique libdirs. case $hardcode_libdir_separator$hardcode_libdirs$hardcode_libdir_separator in *"$hardcode_libdir_separator$libdir$hardcode_libdir_separator"*) ;; *) func_append hardcode_libdirs "$hardcode_libdir_separator$libdir" ;; esac fi else eval flag=\"$hardcode_libdir_flag_spec\" func_append dep_rpath " $flag" fi elif test -n "$runpath_var"; then case "$perm_rpath " in *" $libdir "*) ;; *) func_append perm_rpath " $libdir" ;; esac fi done # Substitute the hardcoded libdirs into the rpath. if test -n "$hardcode_libdir_separator" && test -n "$hardcode_libdirs"; then libdir=$hardcode_libdirs eval "dep_rpath=\"$hardcode_libdir_flag_spec\"" fi if test -n "$runpath_var" && test -n "$perm_rpath"; then # We should set the runpath_var. rpath= for dir in $perm_rpath; do func_append rpath "$dir:" done eval "$runpath_var='$rpath\$$runpath_var'; export $runpath_var" fi test -n "$dep_rpath" && deplibs="$dep_rpath $deplibs" fi shlibpath=$finalize_shlibpath test relink = "$opt_mode" || shlibpath=$compile_shlibpath$shlibpath if test -n "$shlibpath"; then eval "$shlibpath_var='$shlibpath\$$shlibpath_var'; export $shlibpath_var" fi # Get the real and link names of the library. eval shared_ext=\"$shrext_cmds\" eval library_names=\"$library_names_spec\" set dummy $library_names shift realname=$1 shift if test -n "$soname_spec"; then eval soname=\"$soname_spec\" else soname=$realname fi if test -z "$dlname"; then dlname=$soname fi lib=$output_objdir/$realname linknames= for link do func_append linknames " $link" done # Use standard objects if they are pic test -z "$pic_flag" && libobjs=`$ECHO "$libobjs" | $SP2NL | $SED "$lo2o" | $NL2SP` test "X$libobjs" = "X " && libobjs= delfiles= if test -n "$export_symbols" && test -n "$include_expsyms"; then $opt_dry_run || cp "$export_symbols" "$output_objdir/$libname.uexp" export_symbols=$output_objdir/$libname.uexp func_append delfiles " $export_symbols" fi orig_export_symbols= case $host_os in cygwin* | mingw* | cegcc*) if test -n "$export_symbols" && test -z "$export_symbols_regex"; then # exporting using user supplied symfile func_dll_def_p "$export_symbols" || { # and it's NOT already a .def file. Must figure out # which of the given symbols are data symbols and tag # them as such. So, trigger use of export_symbols_cmds. # export_symbols gets reassigned inside the "prepare # the list of exported symbols" if statement, so the # include_expsyms logic still works. orig_export_symbols=$export_symbols export_symbols= always_export_symbols=yes } fi ;; esac # Prepare the list of exported symbols if test -z "$export_symbols"; then if test yes = "$always_export_symbols" || test -n "$export_symbols_regex"; then func_verbose "generating symbol list for '$libname.la'" export_symbols=$output_objdir/$libname.exp $opt_dry_run || $RM $export_symbols cmds=$export_symbols_cmds save_ifs=$IFS; IFS='~' for cmd1 in $cmds; do IFS=$save_ifs # Take the normal branch if the nm_file_list_spec branch # doesn't work or if tool conversion is not needed. case $nm_file_list_spec~$to_tool_file_cmd in *~func_convert_file_noop | *~func_convert_file_msys_to_w32 | ~*) try_normal_branch=yes eval cmd=\"$cmd1\" func_len " $cmd" len=$func_len_result ;; *) try_normal_branch=no ;; esac if test yes = "$try_normal_branch" \ && { test "$len" -lt "$max_cmd_len" \ || test "$max_cmd_len" -le -1; } then func_show_eval "$cmd" 'exit $?' skipped_export=false elif test -n "$nm_file_list_spec"; then func_basename "$output" output_la=$func_basename_result save_libobjs=$libobjs save_output=$output output=$output_objdir/$output_la.nm func_to_tool_file "$output" libobjs=$nm_file_list_spec$func_to_tool_file_result func_append delfiles " $output" func_verbose "creating $NM input file list: $output" for obj in $save_libobjs; do func_to_tool_file "$obj" $ECHO "$func_to_tool_file_result" done > "$output" eval cmd=\"$cmd1\" func_show_eval "$cmd" 'exit $?' output=$save_output libobjs=$save_libobjs skipped_export=false else # The command line is too long to execute in one step. func_verbose "using reloadable object file for export list..." skipped_export=: # Break out early, otherwise skipped_export may be # set to false by a later but shorter cmd. break fi done IFS=$save_ifs if test -n "$export_symbols_regex" && test : != "$skipped_export"; then func_show_eval '$EGREP -e "$export_symbols_regex" "$export_symbols" > "${export_symbols}T"' func_show_eval '$MV "${export_symbols}T" "$export_symbols"' fi fi fi if test -n "$export_symbols" && test -n "$include_expsyms"; then tmp_export_symbols=$export_symbols test -n "$orig_export_symbols" && tmp_export_symbols=$orig_export_symbols $opt_dry_run || eval '$ECHO "$include_expsyms" | $SP2NL >> "$tmp_export_symbols"' fi if test : != "$skipped_export" && test -n "$orig_export_symbols"; then # The given exports_symbols file has to be filtered, so filter it. func_verbose "filter symbol list for '$libname.la' to tag DATA exports" # FIXME: $output_objdir/$libname.filter potentially contains lots of # 's' commands, which not all seds can handle. GNU sed should be fine # though. Also, the filter scales superlinearly with the number of # global variables. join(1) would be nice here, but unfortunately # isn't a blessed tool. $opt_dry_run || $SED -e '/[ ,]DATA/!d;s,\(.*\)\([ \,].*\),s|^\1$|\1\2|,' < $export_symbols > $output_objdir/$libname.filter func_append delfiles " $export_symbols $output_objdir/$libname.filter" export_symbols=$output_objdir/$libname.def $opt_dry_run || $SED -f $output_objdir/$libname.filter < $orig_export_symbols > $export_symbols fi tmp_deplibs= for test_deplib in $deplibs; do case " $convenience " in *" $test_deplib "*) ;; *) func_append tmp_deplibs " $test_deplib" ;; esac done deplibs=$tmp_deplibs if test -n "$convenience"; then if test -n "$whole_archive_flag_spec" && test yes = "$compiler_needs_object" && test -z "$libobjs"; then # extract the archives, so we have objects to list. # TODO: could optimize this to just extract one archive. whole_archive_flag_spec= fi if test -n "$whole_archive_flag_spec"; then save_libobjs=$libobjs eval libobjs=\"\$libobjs $whole_archive_flag_spec\" test "X$libobjs" = "X " && libobjs= else gentop=$output_objdir/${outputname}x func_append generated " $gentop" func_extract_archives $gentop $convenience func_append libobjs " $func_extract_archives_result" test "X$libobjs" = "X " && libobjs= fi fi if test yes = "$thread_safe" && test -n "$thread_safe_flag_spec"; then eval flag=\"$thread_safe_flag_spec\" func_append linker_flags " $flag" fi # Make a backup of the uninstalled library when relinking if test relink = "$opt_mode"; then $opt_dry_run || eval '(cd $output_objdir && $RM ${realname}U && $MV $realname ${realname}U)' || exit $? fi # Do each of the archive commands. if test yes = "$module" && test -n "$module_cmds"; then if test -n "$export_symbols" && test -n "$module_expsym_cmds"; then eval test_cmds=\"$module_expsym_cmds\" cmds=$module_expsym_cmds else eval test_cmds=\"$module_cmds\" cmds=$module_cmds fi else if test -n "$export_symbols" && test -n "$archive_expsym_cmds"; then eval test_cmds=\"$archive_expsym_cmds\" cmds=$archive_expsym_cmds else eval test_cmds=\"$archive_cmds\" cmds=$archive_cmds fi fi if test : != "$skipped_export" && func_len " $test_cmds" && len=$func_len_result && test "$len" -lt "$max_cmd_len" || test "$max_cmd_len" -le -1; then : else # The command line is too long to link in one step, link piecewise # or, if using GNU ld and skipped_export is not :, use a linker # script. # Save the value of $output and $libobjs because we want to # use them later. If we have whole_archive_flag_spec, we # want to use save_libobjs as it was before # whole_archive_flag_spec was expanded, because we can't # assume the linker understands whole_archive_flag_spec. # This may have to be revisited, in case too many # convenience libraries get linked in and end up exceeding # the spec. if test -z "$convenience" || test -z "$whole_archive_flag_spec"; then save_libobjs=$libobjs fi save_output=$output func_basename "$output" output_la=$func_basename_result # Clear the reloadable object creation command queue and # initialize k to one. test_cmds= concat_cmds= objlist= last_robj= k=1 if test -n "$save_libobjs" && test : != "$skipped_export" && test yes = "$with_gnu_ld"; then output=$output_objdir/$output_la.lnkscript func_verbose "creating GNU ld script: $output" echo 'INPUT (' > $output for obj in $save_libobjs do func_to_tool_file "$obj" $ECHO "$func_to_tool_file_result" >> $output done echo ')' >> $output func_append delfiles " $output" func_to_tool_file "$output" output=$func_to_tool_file_result elif test -n "$save_libobjs" && test : != "$skipped_export" && test -n "$file_list_spec"; then output=$output_objdir/$output_la.lnk func_verbose "creating linker input file list: $output" : > $output set x $save_libobjs shift firstobj= if test yes = "$compiler_needs_object"; then firstobj="$1 " shift fi for obj do func_to_tool_file "$obj" $ECHO "$func_to_tool_file_result" >> $output done func_append delfiles " $output" func_to_tool_file "$output" output=$firstobj\"$file_list_spec$func_to_tool_file_result\" else if test -n "$save_libobjs"; then func_verbose "creating reloadable object files..." output=$output_objdir/$output_la-$k.$objext eval test_cmds=\"$reload_cmds\" func_len " $test_cmds" len0=$func_len_result len=$len0 # Loop over the list of objects to be linked. for obj in $save_libobjs do func_len " $obj" func_arith $len + $func_len_result len=$func_arith_result if test -z "$objlist" || test "$len" -lt "$max_cmd_len"; then func_append objlist " $obj" else # The command $test_cmds is almost too long, add a # command to the queue. if test 1 -eq "$k"; then # The first file doesn't have a previous command to add. reload_objs=$objlist eval concat_cmds=\"$reload_cmds\" else # All subsequent reloadable object files will link in # the last one created. reload_objs="$objlist $last_robj" eval concat_cmds=\"\$concat_cmds~$reload_cmds~\$RM $last_robj\" fi last_robj=$output_objdir/$output_la-$k.$objext func_arith $k + 1 k=$func_arith_result output=$output_objdir/$output_la-$k.$objext objlist=" $obj" func_len " $last_robj" func_arith $len0 + $func_len_result len=$func_arith_result fi done # Handle the remaining objects by creating one last # reloadable object file. All subsequent reloadable object # files will link in the last one created. test -z "$concat_cmds" || concat_cmds=$concat_cmds~ reload_objs="$objlist $last_robj" eval concat_cmds=\"\$concat_cmds$reload_cmds\" if test -n "$last_robj"; then eval concat_cmds=\"\$concat_cmds~\$RM $last_robj\" fi func_append delfiles " $output" else output= fi ${skipped_export-false} && { func_verbose "generating symbol list for '$libname.la'" export_symbols=$output_objdir/$libname.exp $opt_dry_run || $RM $export_symbols libobjs=$output # Append the command to create the export file. test -z "$concat_cmds" || concat_cmds=$concat_cmds~ eval concat_cmds=\"\$concat_cmds$export_symbols_cmds\" if test -n "$last_robj"; then eval concat_cmds=\"\$concat_cmds~\$RM $last_robj\" fi } test -n "$save_libobjs" && func_verbose "creating a temporary reloadable object file: $output" # Loop through the commands generated above and execute them. save_ifs=$IFS; IFS='~' for cmd in $concat_cmds; do IFS=$save_ifs $opt_quiet || { func_quote_for_expand "$cmd" eval "func_echo $func_quote_for_expand_result" } $opt_dry_run || eval "$cmd" || { lt_exit=$? # Restore the uninstalled library and exit if test relink = "$opt_mode"; then ( cd "$output_objdir" && \ $RM "${realname}T" && \ $MV "${realname}U" "$realname" ) fi exit $lt_exit } done IFS=$save_ifs if test -n "$export_symbols_regex" && ${skipped_export-false}; then func_show_eval '$EGREP -e "$export_symbols_regex" "$export_symbols" > "${export_symbols}T"' func_show_eval '$MV "${export_symbols}T" "$export_symbols"' fi fi ${skipped_export-false} && { if test -n "$export_symbols" && test -n "$include_expsyms"; then tmp_export_symbols=$export_symbols test -n "$orig_export_symbols" && tmp_export_symbols=$orig_export_symbols $opt_dry_run || eval '$ECHO "$include_expsyms" | $SP2NL >> "$tmp_export_symbols"' fi if test -n "$orig_export_symbols"; then # The given exports_symbols file has to be filtered, so filter it. func_verbose "filter symbol list for '$libname.la' to tag DATA exports" # FIXME: $output_objdir/$libname.filter potentially contains lots of # 's' commands, which not all seds can handle. GNU sed should be fine # though. Also, the filter scales superlinearly with the number of # global variables. join(1) would be nice here, but unfortunately # isn't a blessed tool. $opt_dry_run || $SED -e '/[ ,]DATA/!d;s,\(.*\)\([ \,].*\),s|^\1$|\1\2|,' < $export_symbols > $output_objdir/$libname.filter func_append delfiles " $export_symbols $output_objdir/$libname.filter" export_symbols=$output_objdir/$libname.def $opt_dry_run || $SED -f $output_objdir/$libname.filter < $orig_export_symbols > $export_symbols fi } libobjs=$output # Restore the value of output. output=$save_output if test -n "$convenience" && test -n "$whole_archive_flag_spec"; then eval libobjs=\"\$libobjs $whole_archive_flag_spec\" test "X$libobjs" = "X " && libobjs= fi # Expand the library linking commands again to reset the # value of $libobjs for piecewise linking. # Do each of the archive commands. if test yes = "$module" && test -n "$module_cmds"; then if test -n "$export_symbols" && test -n "$module_expsym_cmds"; then cmds=$module_expsym_cmds else cmds=$module_cmds fi else if test -n "$export_symbols" && test -n "$archive_expsym_cmds"; then cmds=$archive_expsym_cmds else cmds=$archive_cmds fi fi fi if test -n "$delfiles"; then # Append the command to remove temporary files to $cmds. eval cmds=\"\$cmds~\$RM $delfiles\" fi # Add any objects from preloaded convenience libraries if test -n "$dlprefiles"; then gentop=$output_objdir/${outputname}x func_append generated " $gentop" func_extract_archives $gentop $dlprefiles func_append libobjs " $func_extract_archives_result" test "X$libobjs" = "X " && libobjs= fi save_ifs=$IFS; IFS='~' for cmd in $cmds; do IFS=$sp$nl eval cmd=\"$cmd\" IFS=$save_ifs $opt_quiet || { func_quote_for_expand "$cmd" eval "func_echo $func_quote_for_expand_result" } $opt_dry_run || eval "$cmd" || { lt_exit=$? # Restore the uninstalled library and exit if test relink = "$opt_mode"; then ( cd "$output_objdir" && \ $RM "${realname}T" && \ $MV "${realname}U" "$realname" ) fi exit $lt_exit } done IFS=$save_ifs # Restore the uninstalled library and exit if test relink = "$opt_mode"; then $opt_dry_run || eval '(cd $output_objdir && $RM ${realname}T && $MV $realname ${realname}T && $MV ${realname}U $realname)' || exit $? if test -n "$convenience"; then if test -z "$whole_archive_flag_spec"; then func_show_eval '${RM}r "$gentop"' fi fi exit $EXIT_SUCCESS fi # Create links to the real library. for linkname in $linknames; do if test "$realname" != "$linkname"; then func_show_eval '(cd "$output_objdir" && $RM "$linkname" && $LN_S "$realname" "$linkname")' 'exit $?' fi done # If -module or -export-dynamic was specified, set the dlname. if test yes = "$module" || test yes = "$export_dynamic"; then # On all known operating systems, these are identical. dlname=$soname fi fi ;; obj) if test -n "$dlfiles$dlprefiles" || test no != "$dlself"; then func_warning "'-dlopen' is ignored for objects" fi case " $deplibs" in *\ -l* | *\ -L*) func_warning "'-l' and '-L' are ignored for objects" ;; esac test -n "$rpath" && \ func_warning "'-rpath' is ignored for objects" test -n "$xrpath" && \ func_warning "'-R' is ignored for objects" test -n "$vinfo" && \ func_warning "'-version-info' is ignored for objects" test -n "$release" && \ func_warning "'-release' is ignored for objects" case $output in *.lo) test -n "$objs$old_deplibs" && \ func_fatal_error "cannot build library object '$output' from non-libtool objects" libobj=$output func_lo2o "$libobj" obj=$func_lo2o_result ;; *) libobj= obj=$output ;; esac # Delete the old objects. $opt_dry_run || $RM $obj $libobj # Objects from convenience libraries. This assumes # single-version convenience libraries. Whenever we create # different ones for PIC/non-PIC, this we'll have to duplicate # the extraction. reload_conv_objs= gentop= # if reload_cmds runs $LD directly, get rid of -Wl from # whole_archive_flag_spec and hope we can get by with turning comma # into space. case $reload_cmds in *\$LD[\ \$]*) wl= ;; esac if test -n "$convenience"; then if test -n "$whole_archive_flag_spec"; then eval tmp_whole_archive_flags=\"$whole_archive_flag_spec\" test -n "$wl" || tmp_whole_archive_flags=`$ECHO "$tmp_whole_archive_flags" | $SED 's|,| |g'` reload_conv_objs=$reload_objs\ $tmp_whole_archive_flags else gentop=$output_objdir/${obj}x func_append generated " $gentop" func_extract_archives $gentop $convenience reload_conv_objs="$reload_objs $func_extract_archives_result" fi fi # If we're not building shared, we need to use non_pic_objs test yes = "$build_libtool_libs" || libobjs=$non_pic_objects # Create the old-style object. reload_objs=$objs$old_deplibs' '`$ECHO "$libobjs" | $SP2NL | $SED "/\.$libext$/d; /\.lib$/d; $lo2o" | $NL2SP`' '$reload_conv_objs output=$obj func_execute_cmds "$reload_cmds" 'exit $?' # Exit if we aren't doing a library object file. if test -z "$libobj"; then if test -n "$gentop"; then func_show_eval '${RM}r "$gentop"' fi exit $EXIT_SUCCESS fi test yes = "$build_libtool_libs" || { if test -n "$gentop"; then func_show_eval '${RM}r "$gentop"' fi # Create an invalid libtool object if no PIC, so that we don't # accidentally link it into a program. # $show "echo timestamp > $libobj" # $opt_dry_run || eval "echo timestamp > $libobj" || exit $? exit $EXIT_SUCCESS } if test -n "$pic_flag" || test default != "$pic_mode"; then # Only do commands if we really have different PIC objects. reload_objs="$libobjs $reload_conv_objs" output=$libobj func_execute_cmds "$reload_cmds" 'exit $?' fi if test -n "$gentop"; then func_show_eval '${RM}r "$gentop"' fi exit $EXIT_SUCCESS ;; prog) case $host in *cygwin*) func_stripname '' '.exe' "$output" output=$func_stripname_result.exe;; esac test -n "$vinfo" && \ func_warning "'-version-info' is ignored for programs" test -n "$release" && \ func_warning "'-release' is ignored for programs" $preload \ && test unknown,unknown,unknown = "$dlopen_support,$dlopen_self,$dlopen_self_static" \ && func_warning "'LT_INIT([dlopen])' not used. Assuming no dlopen support." case $host in *-*-rhapsody* | *-*-darwin1.[012]) # On Rhapsody replace the C library is the System framework compile_deplibs=`$ECHO " $compile_deplibs" | $SED 's/ -lc / System.ltframework /'` finalize_deplibs=`$ECHO " $finalize_deplibs" | $SED 's/ -lc / System.ltframework /'` ;; esac case $host in *-*-darwin*) # Don't allow lazy linking, it breaks C++ global constructors # But is supposedly fixed on 10.4 or later (yay!). if test CXX = "$tagname"; then case ${MACOSX_DEPLOYMENT_TARGET-10.0} in 10.[0123]) func_append compile_command " $wl-bind_at_load" func_append finalize_command " $wl-bind_at_load" ;; esac fi # Time to change all our "foo.ltframework" stuff back to "-framework foo" compile_deplibs=`$ECHO " $compile_deplibs" | $SED 's% \([^ $]*\).ltframework% -framework \1%g'` finalize_deplibs=`$ECHO " $finalize_deplibs" | $SED 's% \([^ $]*\).ltframework% -framework \1%g'` ;; esac # move library search paths that coincide with paths to not yet # installed libraries to the beginning of the library search list new_libs= for path in $notinst_path; do case " $new_libs " in *" -L$path/$objdir "*) ;; *) case " $compile_deplibs " in *" -L$path/$objdir "*) func_append new_libs " -L$path/$objdir" ;; esac ;; esac done for deplib in $compile_deplibs; do case $deplib in -L*) case " $new_libs " in *" $deplib "*) ;; *) func_append new_libs " $deplib" ;; esac ;; *) func_append new_libs " $deplib" ;; esac done compile_deplibs=$new_libs func_append compile_command " $compile_deplibs" func_append finalize_command " $finalize_deplibs" if test -n "$rpath$xrpath"; then # If the user specified any rpath flags, then add them. for libdir in $rpath $xrpath; do # This is the magic to use -rpath. case "$finalize_rpath " in *" $libdir "*) ;; *) func_append finalize_rpath " $libdir" ;; esac done fi # Now hardcode the library paths rpath= hardcode_libdirs= for libdir in $compile_rpath $finalize_rpath; do if test -n "$hardcode_libdir_flag_spec"; then if test -n "$hardcode_libdir_separator"; then if test -z "$hardcode_libdirs"; then hardcode_libdirs=$libdir else # Just accumulate the unique libdirs. case $hardcode_libdir_separator$hardcode_libdirs$hardcode_libdir_separator in *"$hardcode_libdir_separator$libdir$hardcode_libdir_separator"*) ;; *) func_append hardcode_libdirs "$hardcode_libdir_separator$libdir" ;; esac fi else eval flag=\"$hardcode_libdir_flag_spec\" func_append rpath " $flag" fi elif test -n "$runpath_var"; then case "$perm_rpath " in *" $libdir "*) ;; *) func_append perm_rpath " $libdir" ;; esac fi case $host in *-*-cygwin* | *-*-mingw* | *-*-pw32* | *-*-os2* | *-cegcc*) testbindir=`$ECHO "$libdir" | $SED -e 's*/lib$*/bin*'` case :$dllsearchpath: in *":$libdir:"*) ;; ::) dllsearchpath=$libdir;; *) func_append dllsearchpath ":$libdir";; esac case :$dllsearchpath: in *":$testbindir:"*) ;; ::) dllsearchpath=$testbindir;; *) func_append dllsearchpath ":$testbindir";; esac ;; esac done # Substitute the hardcoded libdirs into the rpath. if test -n "$hardcode_libdir_separator" && test -n "$hardcode_libdirs"; then libdir=$hardcode_libdirs eval rpath=\" $hardcode_libdir_flag_spec\" fi compile_rpath=$rpath rpath= hardcode_libdirs= for libdir in $finalize_rpath; do if test -n "$hardcode_libdir_flag_spec"; then if test -n "$hardcode_libdir_separator"; then if test -z "$hardcode_libdirs"; then hardcode_libdirs=$libdir else # Just accumulate the unique libdirs. case $hardcode_libdir_separator$hardcode_libdirs$hardcode_libdir_separator in *"$hardcode_libdir_separator$libdir$hardcode_libdir_separator"*) ;; *) func_append hardcode_libdirs "$hardcode_libdir_separator$libdir" ;; esac fi else eval flag=\"$hardcode_libdir_flag_spec\" func_append rpath " $flag" fi elif test -n "$runpath_var"; then case "$finalize_perm_rpath " in *" $libdir "*) ;; *) func_append finalize_perm_rpath " $libdir" ;; esac fi done # Substitute the hardcoded libdirs into the rpath. if test -n "$hardcode_libdir_separator" && test -n "$hardcode_libdirs"; then libdir=$hardcode_libdirs eval rpath=\" $hardcode_libdir_flag_spec\" fi finalize_rpath=$rpath if test -n "$libobjs" && test yes = "$build_old_libs"; then # Transform all the library objects into standard objects. compile_command=`$ECHO "$compile_command" | $SP2NL | $SED "$lo2o" | $NL2SP` finalize_command=`$ECHO "$finalize_command" | $SP2NL | $SED "$lo2o" | $NL2SP` fi func_generate_dlsyms "$outputname" "@PROGRAM@" false # template prelinking step if test -n "$prelink_cmds"; then func_execute_cmds "$prelink_cmds" 'exit $?' fi wrappers_required=: case $host in *cegcc* | *mingw32ce*) # Disable wrappers for cegcc and mingw32ce hosts, we are cross compiling anyway. wrappers_required=false ;; *cygwin* | *mingw* ) test yes = "$build_libtool_libs" || wrappers_required=false ;; *) if test no = "$need_relink" || test yes != "$build_libtool_libs"; then wrappers_required=false fi ;; esac $wrappers_required || { # Replace the output file specification. compile_command=`$ECHO "$compile_command" | $SED 's%@OUTPUT@%'"$output"'%g'` link_command=$compile_command$compile_rpath # We have no uninstalled library dependencies, so finalize right now. exit_status=0 func_show_eval "$link_command" 'exit_status=$?' if test -n "$postlink_cmds"; then func_to_tool_file "$output" postlink_cmds=`func_echo_all "$postlink_cmds" | $SED -e 's%@OUTPUT@%'"$output"'%g' -e 's%@TOOL_OUTPUT@%'"$func_to_tool_file_result"'%g'` func_execute_cmds "$postlink_cmds" 'exit $?' fi # Delete the generated files. if test -f "$output_objdir/${outputname}S.$objext"; then func_show_eval '$RM "$output_objdir/${outputname}S.$objext"' fi exit $exit_status } if test -n "$compile_shlibpath$finalize_shlibpath"; then compile_command="$shlibpath_var=\"$compile_shlibpath$finalize_shlibpath\$$shlibpath_var\" $compile_command" fi if test -n "$finalize_shlibpath"; then finalize_command="$shlibpath_var=\"$finalize_shlibpath\$$shlibpath_var\" $finalize_command" fi compile_var= finalize_var= if test -n "$runpath_var"; then if test -n "$perm_rpath"; then # We should set the runpath_var. rpath= for dir in $perm_rpath; do func_append rpath "$dir:" done compile_var="$runpath_var=\"$rpath\$$runpath_var\" " fi if test -n "$finalize_perm_rpath"; then # We should set the runpath_var. rpath= for dir in $finalize_perm_rpath; do func_append rpath "$dir:" done finalize_var="$runpath_var=\"$rpath\$$runpath_var\" " fi fi if test yes = "$no_install"; then # We don't need to create a wrapper script. link_command=$compile_var$compile_command$compile_rpath # Replace the output file specification. link_command=`$ECHO "$link_command" | $SED 's%@OUTPUT@%'"$output"'%g'` # Delete the old output file. $opt_dry_run || $RM $output # Link the executable and exit func_show_eval "$link_command" 'exit $?' if test -n "$postlink_cmds"; then func_to_tool_file "$output" postlink_cmds=`func_echo_all "$postlink_cmds" | $SED -e 's%@OUTPUT@%'"$output"'%g' -e 's%@TOOL_OUTPUT@%'"$func_to_tool_file_result"'%g'` func_execute_cmds "$postlink_cmds" 'exit $?' fi exit $EXIT_SUCCESS fi case $hardcode_action,$fast_install in relink,*) # Fast installation is not supported link_command=$compile_var$compile_command$compile_rpath relink_command=$finalize_var$finalize_command$finalize_rpath func_warning "this platform does not like uninstalled shared libraries" func_warning "'$output' will be relinked during installation" ;; *,yes) link_command=$finalize_var$compile_command$finalize_rpath relink_command=`$ECHO "$compile_var$compile_command$compile_rpath" | $SED 's%@OUTPUT@%\$progdir/\$file%g'` ;; *,no) link_command=$compile_var$compile_command$compile_rpath relink_command=$finalize_var$finalize_command$finalize_rpath ;; *,needless) link_command=$finalize_var$compile_command$finalize_rpath relink_command= ;; esac # Replace the output file specification. link_command=`$ECHO "$link_command" | $SED 's%@OUTPUT@%'"$output_objdir/$outputname"'%g'` # Delete the old output files. $opt_dry_run || $RM $output $output_objdir/$outputname $output_objdir/lt-$outputname func_show_eval "$link_command" 'exit $?' if test -n "$postlink_cmds"; then func_to_tool_file "$output_objdir/$outputname" postlink_cmds=`func_echo_all "$postlink_cmds" | $SED -e 's%@OUTPUT@%'"$output_objdir/$outputname"'%g' -e 's%@TOOL_OUTPUT@%'"$func_to_tool_file_result"'%g'` func_execute_cmds "$postlink_cmds" 'exit $?' fi # Now create the wrapper script. func_verbose "creating $output" # Quote the relink command for shipping. if test -n "$relink_command"; then # Preserve any variables that may affect compiler behavior for var in $variables_saved_for_relink; do if eval test -z \"\${$var+set}\"; then relink_command="{ test -z \"\${$var+set}\" || $lt_unset $var || { $var=; export $var; }; }; $relink_command" elif eval var_value=\$$var; test -z "$var_value"; then relink_command="$var=; export $var; $relink_command" else func_quote_for_eval "$var_value" relink_command="$var=$func_quote_for_eval_result; export $var; $relink_command" fi done relink_command="(cd `pwd`; $relink_command)" relink_command=`$ECHO "$relink_command" | $SED "$sed_quote_subst"` fi # Only actually do things if not in dry run mode. $opt_dry_run || { # win32 will think the script is a binary if it has # a .exe suffix, so we strip it off here. case $output in *.exe) func_stripname '' '.exe' "$output" output=$func_stripname_result ;; esac # test for cygwin because mv fails w/o .exe extensions case $host in *cygwin*) exeext=.exe func_stripname '' '.exe' "$outputname" outputname=$func_stripname_result ;; *) exeext= ;; esac case $host in *cygwin* | *mingw* ) func_dirname_and_basename "$output" "" "." output_name=$func_basename_result output_path=$func_dirname_result cwrappersource=$output_path/$objdir/lt-$output_name.c cwrapper=$output_path/$output_name.exe $RM $cwrappersource $cwrapper trap "$RM $cwrappersource $cwrapper; exit $EXIT_FAILURE" 1 2 15 func_emit_cwrapperexe_src > $cwrappersource # The wrapper executable is built using the $host compiler, # because it contains $host paths and files. If cross- # compiling, it, like the target executable, must be # executed on the $host or under an emulation environment. $opt_dry_run || { $LTCC $LTCFLAGS -o $cwrapper $cwrappersource $STRIP $cwrapper } # Now, create the wrapper script for func_source use: func_ltwrapper_scriptname $cwrapper $RM $func_ltwrapper_scriptname_result trap "$RM $func_ltwrapper_scriptname_result; exit $EXIT_FAILURE" 1 2 15 $opt_dry_run || { # note: this script will not be executed, so do not chmod. if test "x$build" = "x$host"; then $cwrapper --lt-dump-script > $func_ltwrapper_scriptname_result else func_emit_wrapper no > $func_ltwrapper_scriptname_result fi } ;; * ) $RM $output trap "$RM $output; exit $EXIT_FAILURE" 1 2 15 func_emit_wrapper no > $output chmod +x $output ;; esac } exit $EXIT_SUCCESS ;; esac # See if we need to build an old-fashioned archive. for oldlib in $oldlibs; do case $build_libtool_libs in convenience) oldobjs="$libobjs_save $symfileobj" addlibs=$convenience build_libtool_libs=no ;; module) oldobjs=$libobjs_save addlibs=$old_convenience build_libtool_libs=no ;; *) oldobjs="$old_deplibs $non_pic_objects" $preload && test -f "$symfileobj" \ && func_append oldobjs " $symfileobj" addlibs=$old_convenience ;; esac if test -n "$addlibs"; then gentop=$output_objdir/${outputname}x func_append generated " $gentop" func_extract_archives $gentop $addlibs func_append oldobjs " $func_extract_archives_result" fi # Do each command in the archive commands. if test -n "$old_archive_from_new_cmds" && test yes = "$build_libtool_libs"; then cmds=$old_archive_from_new_cmds else # Add any objects from preloaded convenience libraries if test -n "$dlprefiles"; then gentop=$output_objdir/${outputname}x func_append generated " $gentop" func_extract_archives $gentop $dlprefiles func_append oldobjs " $func_extract_archives_result" fi # POSIX demands no paths to be encoded in archives. We have # to avoid creating archives with duplicate basenames if we # might have to extract them afterwards, e.g., when creating a # static archive out of a convenience library, or when linking # the entirety of a libtool archive into another (currently # not supported by libtool). if (for obj in $oldobjs do func_basename "$obj" $ECHO "$func_basename_result" done | sort | sort -uc >/dev/null 2>&1); then : else echo "copying selected object files to avoid basename conflicts..." gentop=$output_objdir/${outputname}x func_append generated " $gentop" func_mkdir_p "$gentop" save_oldobjs=$oldobjs oldobjs= counter=1 for obj in $save_oldobjs do func_basename "$obj" objbase=$func_basename_result case " $oldobjs " in " ") oldobjs=$obj ;; *[\ /]"$objbase "*) while :; do # Make sure we don't pick an alternate name that also # overlaps. newobj=lt$counter-$objbase func_arith $counter + 1 counter=$func_arith_result case " $oldobjs " in *[\ /]"$newobj "*) ;; *) if test ! -f "$gentop/$newobj"; then break; fi ;; esac done func_show_eval "ln $obj $gentop/$newobj || cp $obj $gentop/$newobj" func_append oldobjs " $gentop/$newobj" ;; *) func_append oldobjs " $obj" ;; esac done fi func_to_tool_file "$oldlib" func_convert_file_msys_to_w32 tool_oldlib=$func_to_tool_file_result eval cmds=\"$old_archive_cmds\" func_len " $cmds" len=$func_len_result if test "$len" -lt "$max_cmd_len" || test "$max_cmd_len" -le -1; then cmds=$old_archive_cmds elif test -n "$archiver_list_spec"; then func_verbose "using command file archive linking..." for obj in $oldobjs do func_to_tool_file "$obj" $ECHO "$func_to_tool_file_result" done > $output_objdir/$libname.libcmd func_to_tool_file "$output_objdir/$libname.libcmd" oldobjs=" $archiver_list_spec$func_to_tool_file_result" cmds=$old_archive_cmds else # the command line is too long to link in one step, link in parts func_verbose "using piecewise archive linking..." save_RANLIB=$RANLIB RANLIB=: objlist= concat_cmds= save_oldobjs=$oldobjs oldobjs= # Is there a better way of finding the last object in the list? for obj in $save_oldobjs do last_oldobj=$obj done eval test_cmds=\"$old_archive_cmds\" func_len " $test_cmds" len0=$func_len_result len=$len0 for obj in $save_oldobjs do func_len " $obj" func_arith $len + $func_len_result len=$func_arith_result func_append objlist " $obj" if test "$len" -lt "$max_cmd_len"; then : else # the above command should be used before it gets too long oldobjs=$objlist if test "$obj" = "$last_oldobj"; then RANLIB=$save_RANLIB fi test -z "$concat_cmds" || concat_cmds=$concat_cmds~ eval concat_cmds=\"\$concat_cmds$old_archive_cmds\" objlist= len=$len0 fi done RANLIB=$save_RANLIB oldobjs=$objlist if test -z "$oldobjs"; then eval cmds=\"\$concat_cmds\" else eval cmds=\"\$concat_cmds~\$old_archive_cmds\" fi fi fi func_execute_cmds "$cmds" 'exit $?' done test -n "$generated" && \ func_show_eval "${RM}r$generated" # Now create the libtool archive. case $output in *.la) old_library= test yes = "$build_old_libs" && old_library=$libname.$libext func_verbose "creating $output" # Preserve any variables that may affect compiler behavior for var in $variables_saved_for_relink; do if eval test -z \"\${$var+set}\"; then relink_command="{ test -z \"\${$var+set}\" || $lt_unset $var || { $var=; export $var; }; }; $relink_command" elif eval var_value=\$$var; test -z "$var_value"; then relink_command="$var=; export $var; $relink_command" else func_quote_for_eval "$var_value" relink_command="$var=$func_quote_for_eval_result; export $var; $relink_command" fi done # Quote the link command for shipping. relink_command="(cd `pwd`; $SHELL \"$progpath\" $preserve_args --mode=relink $libtool_args @inst_prefix_dir@)" relink_command=`$ECHO "$relink_command" | $SED "$sed_quote_subst"` if test yes = "$hardcode_automatic"; then relink_command= fi # Only create the output if not a dry run. $opt_dry_run || { for installed in no yes; do if test yes = "$installed"; then if test -z "$install_libdir"; then break fi output=$output_objdir/${outputname}i # Replace all uninstalled libtool libraries with the installed ones newdependency_libs= for deplib in $dependency_libs; do case $deplib in *.la) func_basename "$deplib" name=$func_basename_result func_resolve_sysroot "$deplib" eval libdir=`$SED -n -e 's/^libdir=\(.*\)$/\1/p' $func_resolve_sysroot_result` test -z "$libdir" && \ func_fatal_error "'$deplib' is not a valid libtool archive" func_append newdependency_libs " ${lt_sysroot:+=}$libdir/$name" ;; -L*) func_stripname -L '' "$deplib" func_replace_sysroot "$func_stripname_result" func_append newdependency_libs " -L$func_replace_sysroot_result" ;; -R*) func_stripname -R '' "$deplib" func_replace_sysroot "$func_stripname_result" func_append newdependency_libs " -R$func_replace_sysroot_result" ;; *) func_append newdependency_libs " $deplib" ;; esac done dependency_libs=$newdependency_libs newdlfiles= for lib in $dlfiles; do case $lib in *.la) func_basename "$lib" name=$func_basename_result eval libdir=`$SED -n -e 's/^libdir=\(.*\)$/\1/p' $lib` test -z "$libdir" && \ func_fatal_error "'$lib' is not a valid libtool archive" func_append newdlfiles " ${lt_sysroot:+=}$libdir/$name" ;; *) func_append newdlfiles " $lib" ;; esac done dlfiles=$newdlfiles newdlprefiles= for lib in $dlprefiles; do case $lib in *.la) # Only pass preopened files to the pseudo-archive (for # eventual linking with the app. that links it) if we # didn't already link the preopened objects directly into # the library: func_basename "$lib" name=$func_basename_result eval libdir=`$SED -n -e 's/^libdir=\(.*\)$/\1/p' $lib` test -z "$libdir" && \ func_fatal_error "'$lib' is not a valid libtool archive" func_append newdlprefiles " ${lt_sysroot:+=}$libdir/$name" ;; esac done dlprefiles=$newdlprefiles else newdlfiles= for lib in $dlfiles; do case $lib in [\\/]* | [A-Za-z]:[\\/]*) abs=$lib ;; *) abs=`pwd`"/$lib" ;; esac func_append newdlfiles " $abs" done dlfiles=$newdlfiles newdlprefiles= for lib in $dlprefiles; do case $lib in [\\/]* | [A-Za-z]:[\\/]*) abs=$lib ;; *) abs=`pwd`"/$lib" ;; esac func_append newdlprefiles " $abs" done dlprefiles=$newdlprefiles fi $RM $output # place dlname in correct position for cygwin # In fact, it would be nice if we could use this code for all target # systems that can't hard-code library paths into their executables # and that have no shared library path variable independent of PATH, # but it turns out we can't easily determine that from inspecting # libtool variables, so we have to hard-code the OSs to which it # applies here; at the moment, that means platforms that use the PE # object format with DLL files. See the long comment at the top of # tests/bindir.at for full details. tdlname=$dlname case $host,$output,$installed,$module,$dlname in *cygwin*,*lai,yes,no,*.dll | *mingw*,*lai,yes,no,*.dll | *cegcc*,*lai,yes,no,*.dll) # If a -bindir argument was supplied, place the dll there. if test -n "$bindir"; then func_relative_path "$install_libdir" "$bindir" tdlname=$func_relative_path_result/$dlname else # Otherwise fall back on heuristic. tdlname=../bin/$dlname fi ;; esac $ECHO > $output "\ # $outputname - a libtool library file # Generated by $PROGRAM (GNU $PACKAGE) $VERSION # # Please DO NOT delete this file! # It is necessary for linking the library. # The name that we can dlopen(3). dlname='$tdlname' # Names of this library. library_names='$library_names' # The name of the static archive. old_library='$old_library' # Linker flags that cannot go in dependency_libs. inherited_linker_flags='$new_inherited_linker_flags' # Libraries that this one depends upon. dependency_libs='$dependency_libs' # Names of additional weak libraries provided by this library weak_library_names='$weak_libs' # Version information for $libname. current=$current age=$age revision=$revision # Is this an already installed library? installed=$installed # Should we warn about portability when linking against -modules? shouldnotlink=$module # Files to dlopen/dlpreopen dlopen='$dlfiles' dlpreopen='$dlprefiles' # Directory that this library needs to be installed in: libdir='$install_libdir'" if test no,yes = "$installed,$need_relink"; then $ECHO >> $output "\ relink_command=\"$relink_command\"" fi done } # Do a symbolic link so that the libtool archive can be found in # LD_LIBRARY_PATH before the program is installed. func_show_eval '( cd "$output_objdir" && $RM "$outputname" && $LN_S "../$outputname" "$outputname" )' 'exit $?' ;; esac exit $EXIT_SUCCESS } if test link = "$opt_mode" || test relink = "$opt_mode"; then func_mode_link ${1+"$@"} fi # func_mode_uninstall arg... func_mode_uninstall () { $debug_cmd RM=$nonopt files= rmforce=false exit_status=0 # This variable tells wrapper scripts just to set variables rather # than running their programs. libtool_install_magic=$magic for arg do case $arg in -f) func_append RM " $arg"; rmforce=: ;; -*) func_append RM " $arg" ;; *) func_append files " $arg" ;; esac done test -z "$RM" && \ func_fatal_help "you must specify an RM program" rmdirs= for file in $files; do func_dirname "$file" "" "." dir=$func_dirname_result if test . = "$dir"; then odir=$objdir else odir=$dir/$objdir fi func_basename "$file" name=$func_basename_result test uninstall = "$opt_mode" && odir=$dir # Remember odir for removal later, being careful to avoid duplicates if test clean = "$opt_mode"; then case " $rmdirs " in *" $odir "*) ;; *) func_append rmdirs " $odir" ;; esac fi # Don't error if the file doesn't exist and rm -f was used. if { test -L "$file"; } >/dev/null 2>&1 || { test -h "$file"; } >/dev/null 2>&1 || test -f "$file"; then : elif test -d "$file"; then exit_status=1 continue elif $rmforce; then continue fi rmfiles=$file case $name in *.la) # Possibly a libtool archive, so verify it. if func_lalib_p "$file"; then func_source $dir/$name # Delete the libtool libraries and symlinks. for n in $library_names; do func_append rmfiles " $odir/$n" done test -n "$old_library" && func_append rmfiles " $odir/$old_library" case $opt_mode in clean) case " $library_names " in *" $dlname "*) ;; *) test -n "$dlname" && func_append rmfiles " $odir/$dlname" ;; esac test -n "$libdir" && func_append rmfiles " $odir/$name $odir/${name}i" ;; uninstall) if test -n "$library_names"; then # Do each command in the postuninstall commands. func_execute_cmds "$postuninstall_cmds" '$rmforce || exit_status=1' fi if test -n "$old_library"; then # Do each command in the old_postuninstall commands. func_execute_cmds "$old_postuninstall_cmds" '$rmforce || exit_status=1' fi # FIXME: should reinstall the best remaining shared library. ;; esac fi ;; *.lo) # Possibly a libtool object, so verify it. if func_lalib_p "$file"; then # Read the .lo file func_source $dir/$name # Add PIC object to the list of files to remove. if test -n "$pic_object" && test none != "$pic_object"; then func_append rmfiles " $dir/$pic_object" fi # Add non-PIC object to the list of files to remove. if test -n "$non_pic_object" && test none != "$non_pic_object"; then func_append rmfiles " $dir/$non_pic_object" fi fi ;; *) if test clean = "$opt_mode"; then noexename=$name case $file in *.exe) func_stripname '' '.exe' "$file" file=$func_stripname_result func_stripname '' '.exe' "$name" noexename=$func_stripname_result # $file with .exe has already been added to rmfiles, # add $file without .exe func_append rmfiles " $file" ;; esac # Do a test to see if this is a libtool program. if func_ltwrapper_p "$file"; then if func_ltwrapper_executable_p "$file"; then func_ltwrapper_scriptname "$file" relink_command= func_source $func_ltwrapper_scriptname_result func_append rmfiles " $func_ltwrapper_scriptname_result" else relink_command= func_source $dir/$noexename fi # note $name still contains .exe if it was in $file originally # as does the version of $file that was added into $rmfiles func_append rmfiles " $odir/$name $odir/${name}S.$objext" if test yes = "$fast_install" && test -n "$relink_command"; then func_append rmfiles " $odir/lt-$name" fi if test "X$noexename" != "X$name"; then func_append rmfiles " $odir/lt-$noexename.c" fi fi fi ;; esac func_show_eval "$RM $rmfiles" 'exit_status=1' done # Try to remove the $objdir's in the directories where we deleted files for dir in $rmdirs; do if test -d "$dir"; then func_show_eval "rmdir $dir >/dev/null 2>&1" fi done exit $exit_status } if test uninstall = "$opt_mode" || test clean = "$opt_mode"; then func_mode_uninstall ${1+"$@"} fi test -z "$opt_mode" && { help=$generic_help func_fatal_help "you must specify a MODE" } test -z "$exec_cmd" && \ func_fatal_help "invalid operation mode '$opt_mode'" if test -n "$exec_cmd"; then eval exec "$exec_cmd" exit $EXIT_FAILURE fi exit $exit_status # The TAGs below are defined such that we never get into a situation # where we disable both kinds of libraries. Given conflicting # choices, we go for a static library, that is the most portable, # since we can't tell whether shared libraries were disabled because # the user asked for that or because the platform doesn't support # them. This is particularly important on AIX, because we don't # support having both static and shared libraries enabled at the same # time on that platform, so we default to a shared-only configuration. # If a disable-shared tag is given, we'll fallback to a static-only # configuration. But we'll never go from static-only to shared-only. # ### BEGIN LIBTOOL TAG CONFIG: disable-shared build_libtool_libs=no build_old_libs=yes # ### END LIBTOOL TAG CONFIG: disable-shared # ### BEGIN LIBTOOL TAG CONFIG: disable-static build_old_libs=`case $build_libtool_libs in yes) echo no;; *) echo yes;; esac` # ### END LIBTOOL TAG CONFIG: disable-static # Local Variables: # mode:shell-script # sh-indentation:2 # End: xrdp-0.9.5/configure.ac000644 001751 001751 00000027270 13220727405 014722 0ustar00metameta000000 000000 # Process this file with autoconf to produce a configure script AC_PREREQ(2.65) AC_INIT([xrdp], [0.9.5], [xrdp-devel@googlegroups.com]) AC_CONFIG_HEADERS(config_ac.h:config_ac-h.in) AM_INIT_AUTOMAKE([1.7.2 foreign]) AC_CONFIG_MACRO_DIR([m4]) AC_PROG_CC AC_C_CONST AC_PROG_LIBTOOL PKG_PROG_PKG_CONFIG if test "x$PKG_CONFIG" = "x"; then AC_MSG_ERROR([please install pkg-config]) fi AC_CONFIG_SUBDIRS([libpainter librfxcodec]) # Use silent rules by default if supported by Automake m4_ifdef([AM_SILENT_RULES], [AM_SILENT_RULES([yes])]) AX_CFLAGS_WARN_ALL AX_APPEND_COMPILE_FLAGS([-Wwrite-strings]) AX_GCC_FUNC_ATTRIBUTE([format]) AX_TYPE_SOCKLEN_T case $host_os in *linux*) linux=yes ;; *kfreebsd*) linux=yes # only used in instfiles/ so that’s ok for us for now ;; *freebsd*) freebsd=yes ;; *netbsd*) netbsd=yes ;; *openbsd*) openbsd=yes ;; esac AM_CONDITIONAL(LINUX, [test "x$linux" = xyes]) AM_CONDITIONAL(FREEBSD, [test "x$freebsd" = xyes]) AM_CONDITIONAL(OPENBSD, [test "x$openbsd" = xyes]) AM_CONDITIONAL(NETBSD, [test "x$netbsd" = xyes]) AC_ARG_WITH([socketdir], [AS_HELP_STRING([--with-socketdir=DIR], [Use directory for UNIX sockets (default: /tmp/.xrdp)])], [], [with_socketdir="/tmp/.xrdp"]) AC_SUBST([socketdir], [$with_socketdir]) AC_ARG_WITH([systemdsystemunitdir], AS_HELP_STRING([--with-systemdsystemunitdir=DIR], [Directory for systemd service files]), [], [ if test "x$linux" = xyes; then with_systemdsystemunitdir=$($PKG_CONFIG --variable=systemdsystemunitdir systemd) fi ]) if test "x$with_systemdsystemunitdir" != xno; then AC_SUBST([systemdsystemunitdir], [$with_systemdsystemunitdir]) fi AM_CONDITIONAL(HAVE_SYSTEMD, [test -n "$with_systemdsystemunitdir" -a "x$with_systemdsystemunitdir" != xno ]) AC_ARG_ENABLE(pam, AS_HELP_STRING([--disable-pam], [Build PAM support (default: yes)]), [], [enable_pam=yes]) AM_CONDITIONAL(SESMAN_NOPAM, [test x$enable_pam != xyes]) AC_ARG_ENABLE(vsock, AS_HELP_STRING([--enable-vsock], [Build AF_VSOCK support (default: no)]), [], [enable_vsock=no]) AC_ARG_ENABLE(ipv6, AS_HELP_STRING([--enable-ipv6], [Build IPv6 support (default: no, experimental)]), [], [enable_ipv6=no]) AC_ARG_ENABLE(ipv6only, AS_HELP_STRING([--enable-ipv6only], [Build IPv6-only (default: no)]), [], [enable_ipv6only=no]) AC_ARG_ENABLE(kerberos, AS_HELP_STRING([--enable-kerberos], [Build kerberos support (default: no)]), [], [enable_kerberos=no]) AC_ARG_ENABLE(bsd, AS_HELP_STRING([--enable-bsd], [Build BSD auth support (default: no)]), [bsd=true], [bsd=false]) AM_CONDITIONAL(SESMAN_BSD, [test x$bsd = xtrue]) AM_CONDITIONAL(SESMAN_KERBEROS, [test x$enable_kerberos = xyes]) AC_ARG_ENABLE(pamuserpass, AS_HELP_STRING([--enable-pamuserpass], [Build pam userpass support (default: no)]), [], [enable_pamuserpass=no]) AM_CONDITIONAL(SESMAN_PAMUSERPASS, [test x$enable_pamuserpass = xyes]) AC_ARG_ENABLE(pam-config, AS_HELP_STRING([--enable-pam-config=CONF], [Select PAM config to install: debian, redhat, suse, freebsd, unix (default: autodetect)])) AC_ARG_ENABLE(xrdpdebug, AS_HELP_STRING([--enable-xrdpdebug], [Build debug (default: no)]), [], [enable_xrdpdebug=no]) AM_CONDITIONAL(XRDP_DEBUG, [test x$enable_xrdpdebug = xyes]) AC_ARG_ENABLE(neutrinordp, AS_HELP_STRING([--enable-neutrinordp], [Build neutrinordp module (default: no)]), [], [enable_neutrinordp=no]) AM_CONDITIONAL(XRDP_NEUTRINORDP, [test x$enable_neutrinordp = xyes]) AC_ARG_ENABLE(jpeg, AS_HELP_STRING([--enable-jpeg], [Build jpeg module (default: no)]), [], [enable_jpeg=no]) AM_CONDITIONAL(XRDP_JPEG, [test x$enable_jpeg = xyes]) AC_ARG_ENABLE(tjpeg, AS_HELP_STRING([--enable-tjpeg], [Build turbo jpeg module (default: no)]), [], [enable_tjpeg=no]) AM_CONDITIONAL(XRDP_TJPEG, [test x$enable_tjpeg = xyes]) AC_ARG_ENABLE(fuse, AS_HELP_STRING([--enable-fuse], [Build fuse(clipboard file / drive redir) (default: no)]), [], [enable_fuse=no]) AM_CONDITIONAL(XRDP_FUSE, [test x$enable_fuse = xyes]) AC_ARG_ENABLE(xrdpvr, AS_HELP_STRING([--enable-xrdpvr], [Build xrdpvr module (default: no)]), [], [enable_xrdpvr=no]) AM_CONDITIONAL(XRDP_XRDPVR, [test x$enable_xrdpvr = xyes]) AC_ARG_ENABLE(fdkaac, AS_HELP_STRING([--enable-fdkaac], [Build aac(audio codec) (default: no)]), [], [enable_fdkaac=no]) AM_CONDITIONAL(XRDP_FDK_AAC, [test x$enable_fdkaac = xyes]) AC_ARG_ENABLE(opus, AS_HELP_STRING([--enable-opus], [Build opus(audio codec) (default: no)]), [], [enable_opus=no]) AM_CONDITIONAL(XRDP_OPUS, [test x$enable_opus = xyes]) AC_ARG_ENABLE(mp3lame, AS_HELP_STRING([--enable-mp3lame], [Build lame mp3(audio codec) (default: no)]), [], [enable_mp3lame=no]) AM_CONDITIONAL(XRDP_MP3LAME, [test x$enable_mp3lame = xyes]) AC_ARG_ENABLE(pixman, AS_HELP_STRING([--enable-pixman], [Use pixman library (default: no)]), [], [enable_pixman=no]) AM_CONDITIONAL(XRDP_PIXMAN, [test x$enable_pixman = xyes]) AC_ARG_ENABLE(painter, AS_HELP_STRING([--disable-painter], [Do not use included painter library (default: no)]), [], [enable_painter=yes]) AM_CONDITIONAL(XRDP_PAINTER, [test x$enable_painter = xyes]) AC_ARG_ENABLE(rfxcodec, AS_HELP_STRING([--disable-rfxcodec], [Do not use included librfxcodec library (default: no)]), [], [enable_rfxcodec=yes]) AM_CONDITIONAL(XRDP_RFXCODEC, [test x$enable_rfxcodec = xyes]) # Don't fail without working nasm if rfxcodec is not enabled if test "x$enable_rfxcodec" != xyes; then with_simd=no export with_simd fi # Check if -ldl is needed to use dlopen() DLOPEN_LIBS= AC_CHECK_FUNC(dlopen, [], [AC_CHECK_LIB(dl, dlopen, [DLOPEN_LIBS=-ldl])]) AC_SUBST(DLOPEN_LIBS) # checking for openssl PKG_CHECK_MODULES([OPENSSL], [openssl >= 0.9.8], [], [AC_MSG_ERROR([please install libssl-dev or openssl-devel])]) # look for openssl binary OPENSSL_BIN=`$PKG_CONFIG --variable=exec_prefix openssl`/bin AC_PATH_PROGS([OPENSSL], [openssl], [:], [$OPENSSL_BIN:$PATH]) # checking for pam variation # Linux-PAM is used in Linux systems # OpenPAM is used by FreeBSD, NetBSD, DragonFly BSD and OS X # OpenBSD uses BSD Authentication rather than both PAMs AC_CHECK_HEADER([security/_pam_types.h], [AC_DEFINE([HAVE__PAM_TYPES_H], 1, [Using Linux-PAM], [])]) AC_CHECK_HEADER([security/pam_constants.h], [AC_DEFINE([HAVE_PAM_CONSTANTS_H], 1, [Using OpenPAM], [])]) # checking if pam should be autodetected. if test "x$enable_pam" = "xyes" then if test "x$enable_kerberos" != "xyes" then if test -z "$enable_bsd" then AC_CHECK_HEADER([security/pam_appl.h], [], [AC_MSG_ERROR([please install libpam0g-dev or pam-devel])]) fi fi if test "x$enable_pam_config" = "x"; then PAM_RULES="auto" else pam_config_file="$srcdir/instfiles/pam.d/xrdp-sesman.$enable_pam_config" if test -f "$pam_config_file"; then PAM_RULES="$enable_pam_config" else AC_MSG_ERROR([PAM file "$pam_config_file" is not available]) fi fi fi AC_SUBST(PAM_RULES) if test "x$enable_vsock" = "xyes" then enable_vsock=yes AC_CHECK_HEADERS([linux/socket.h linux/vm_sockets.h], [AC_DEFINE([XRDP_ENABLE_VSOCK], 1, [Enable AF_VSOCK])], [], [#include ]) fi if test "x$enable_ipv6only" = "xyes" then enable_ipv6=yes AC_DEFINE([XRDP_ENABLE_IPV6ONLY],1,[Enable IPv6 only]) fi if test "x$enable_ipv6" = "xyes" then AC_DEFINE([XRDP_ENABLE_IPV6],1,[Enable IPv6]) fi if test "x$enable_pam" != "xyes" || test "x$bsd" = "xtrue" then AC_DEFINE([USE_NOPAM],1,[Disable PAM]) fi AS_IF( [test "x$enable_neutrinordp" = "xyes"] , [PKG_CHECK_MODULES(FREERDP, freerdp >= 1.0.0)] ) # checking for libjpeg if test "x$enable_jpeg" = "xyes" then AC_CHECK_HEADER([jpeglib.h], [], [AC_MSG_ERROR([please install libjpeg-dev or libjpeg-devel])]) fi if test "x$enable_xrdpdebug" = "xyes" then CFLAGS="-g -O0" fi # checking for fuse if test "x$enable_fuse" = "xyes" then PKG_CHECK_MODULES([FUSE], [fuse >= 2.6], [], [AC_MSG_ERROR([please install libfuse-dev or fuse-devel])]) fi # checking for fdk aac if test "x$enable_fdkaac" = "xyes" then PKG_CHECK_MODULES([FDKAAC], [fdk-aac >= 0.1.0], [], [AC_MSG_ERROR([please install libfdk-aac-dev or fdk-aac-devel])]) fi # checking for opus if test "x$enable_opus" = "xyes" then AC_CHECK_HEADER([opus/opus.h], [], [AC_MSG_ERROR([please install libopus-dev or opus-devel])]) fi # checking for lame mp3 if test "x$enable_mp3lame" = "xyes" then AC_CHECK_HEADER([lame/lame.h], [], [AC_MSG_ERROR([please install libmp3lame-dev or lamemp3-devel])]) fi AS_IF( [test "x$enable_pixman" = "xyes"] , [PKG_CHECK_MODULES(PIXMAN, pixman-1 >= 0.1.0)] ) # checking for TurboJPEG if test "x$enable_tjpeg" = "xyes" then if test ! -z "$TURBOJPEG_PATH" then # env var TURBOJPEG_PATH has been defined, use that AC_CHECK_HEADER([$TURBOJPEG_PATH/include/turbojpeg.h], [], [AC_MSG_ERROR([could not find TurboJPEG in dir specified by env variable TURBOJPEG_PATH ($TURBOJPEG_PATH)])]) AC_SUBST(TurboJpegIncDir, ["-I$TURBOJPEG_PATH/include"]) AC_SUBST(TurboJpegLibDir, ["-L$TURBOJPEG_PATH/lib -Wl,-rpath -Wl,$TURBOJPEG_PATH/lib"]) elif test -e /opt/libjpeg-turbo/lib64 then # TurboJPEG has been installed to /opt on a 64 bit m/c AC_SUBST(TurboJpegIncDir, ["-I/opt/libjpeg-turbo/include"]) AC_SUBST(TurboJpegLibDir, ["-L/opt/libjpeg-turbo/lib64 -Wl,-rpath -Wl,/opt/libjpeg-turbo/lib64"]) elif test -e /opt/libjpeg-turbo/lib32 then # TurboJPEG has been installed to /opt on a 32 bit m/c AC_SUBST(TurboJpegIncDir, ["-I/opt/libjpeg-turbo/include"]) AC_SUBST(TurboJpegLibDir, ["-L/opt/libjpeg-turbo/lib32 -Wl,-rpath -Wl,/opt/libjpeg-turbo/lib32"]) else # check in default location AC_CHECK_HEADER([/usr/include/turbojpeg.h], [], [AC_MSG_ERROR([please install TurboJPEG ])]) AC_SUBST(TurboJpegIncDir, [""]) AC_SUBST(TurboJpegLibDir, [""]) fi fi AC_PATH_XTRA if test "x$no_x" == "xyes"; then AC_MSG_ERROR([please install libx11-dev or libX11-devel]) fi save_CFLAGS="$CFLAGS" CFLAGS="$CFLAGS $X_CFLAGS" # checking for Xfixes AC_CHECK_HEADER([X11/extensions/Xfixes.h], [], [AC_MSG_ERROR([please install libxfixes-dev or libXfixes-devel])], [#include ]) # checking for Xrandr AC_CHECK_HEADER([X11/extensions/Xrandr.h], [], [AC_MSG_ERROR([please install libxrandr-dev or libXrandr-devel])], [#include ]) CFLAGS="$save_CFLAGS" AC_SUBST([moduledir], '${libdir}/xrdp') AC_ARG_ENABLE([strict-locations], [AS_HELP_STRING([--enable-strict-locations], [Use standard Autoconf install directories unless overridden (default: use /etc and /var)])]) if test "x$enable_strict_locations" != "xyes"; then sysconfdir="/etc"; localstatedir="/var"; fi PKG_INSTALLDIR AC_CHECK_HEADERS([sys/prctl.h]) AC_CONFIG_FILES([ common/Makefile docs/Makefile docs/man/Makefile genkeymap/Makefile instfiles/default/Makefile instfiles/init.d/Makefile instfiles/Makefile instfiles/pam.d/Makefile instfiles/pulse/Makefile instfiles/rc.d/Makefile keygen/Makefile libxrdp/Makefile Makefile mc/Makefile neutrinordp/Makefile pkgconfig/Makefile pkgconfig/xrdp.pc pkgconfig/xrdp-uninstalled.pc sesman/chansrv/Makefile sesman/libscp/Makefile sesman/Makefile sesman/tools/Makefile vnc/Makefile xrdpapi/Makefile xrdp/Makefile xrdpvr/Makefile xup/Makefile ]) AC_OUTPUT xrdp-0.9.5/Makefile.in000644 001751 001751 00000065533 13220730773 014507 0ustar00metameta000000 000000 # Makefile.in generated by automake 1.15.1 from Makefile.am. # @configure_input@ # Copyright (C) 1994-2017 Free Software Foundation, Inc. # This Makefile.in is free software; the Free Software Foundation # gives unlimited permission to copy and/or distribute it, # with or without modifications, as long as this notice is preserved. # This program is distributed in the hope that it will be useful, # but WITHOUT ANY WARRANTY, to the extent permitted by law; without # even the implied warranty of MERCHANTABILITY or FITNESS FOR A # PARTICULAR PURPOSE. @SET_MAKE@ VPATH = @srcdir@ am__is_gnu_make = { \ if test -z '$(MAKELEVEL)'; then \ false; \ elif test -n '$(MAKE_HOST)'; then \ true; \ elif test -n '$(MAKE_VERSION)' && test -n '$(CURDIR)'; then \ true; \ else \ false; \ fi; \ } am__make_running_with_option = \ case $${target_option-} in \ ?) ;; \ *) echo "am__make_running_with_option: internal error: invalid" \ "target option '$${target_option-}' specified" >&2; \ exit 1;; \ esac; \ has_opt=no; \ sane_makeflags=$$MAKEFLAGS; \ if $(am__is_gnu_make); then \ sane_makeflags=$$MFLAGS; \ else \ case $$MAKEFLAGS in \ *\\[\ \ ]*) \ bs=\\; \ sane_makeflags=`printf '%s\n' "$$MAKEFLAGS" \ | sed "s/$$bs$$bs[$$bs $$bs ]*//g"`;; \ esac; \ fi; \ skip_next=no; \ strip_trailopt () \ { \ flg=`printf '%s\n' "$$flg" | sed "s/$$1.*$$//"`; \ }; \ for flg in $$sane_makeflags; do \ test $$skip_next = yes && { skip_next=no; continue; }; \ case $$flg in \ *=*|--*) continue;; \ -*I) strip_trailopt 'I'; skip_next=yes;; \ -*I?*) strip_trailopt 'I';; \ -*O) strip_trailopt 'O'; skip_next=yes;; \ -*O?*) strip_trailopt 'O';; \ -*l) strip_trailopt 'l'; skip_next=yes;; \ -*l?*) strip_trailopt 'l';; \ -[dEDm]) skip_next=yes;; \ -[JT]) skip_next=yes;; \ esac; \ case $$flg in \ *$$target_option*) has_opt=yes; break;; \ esac; \ done; \ test $$has_opt = yes am__make_dryrun = (target_option=n; $(am__make_running_with_option)) am__make_keepgoing = (target_option=k; $(am__make_running_with_option)) pkgdatadir = $(datadir)/@PACKAGE@ pkgincludedir = $(includedir)/@PACKAGE@ pkglibdir = $(libdir)/@PACKAGE@ pkglibexecdir = $(libexecdir)/@PACKAGE@ am__cd = CDPATH="$${ZSH_VERSION+.}$(PATH_SEPARATOR)" && cd install_sh_DATA = $(install_sh) -c -m 644 install_sh_PROGRAM = $(install_sh) -c install_sh_SCRIPT = $(install_sh) -c INSTALL_HEADER = $(INSTALL_DATA) transform = $(program_transform_name) NORMAL_INSTALL = : PRE_INSTALL = : POST_INSTALL = : NORMAL_UNINSTALL = : PRE_UNINSTALL = : POST_UNINSTALL = : build_triplet = @build@ host_triplet = @host@ subdir = . ACLOCAL_M4 = $(top_srcdir)/aclocal.m4 am__aclocal_m4_deps = $(top_srcdir)/m4/ax_append_compile_flags.m4 \ $(top_srcdir)/m4/ax_append_flag.m4 \ $(top_srcdir)/m4/ax_cflags_warn_all.m4 \ $(top_srcdir)/m4/ax_check_compile_flag.m4 \ $(top_srcdir)/m4/ax_gcc_func_attribute.m4 \ $(top_srcdir)/m4/ax_require_defined.m4 \ $(top_srcdir)/m4/ax_type_socklen_t.m4 \ $(top_srcdir)/m4/libtool.m4 $(top_srcdir)/m4/ltoptions.m4 \ $(top_srcdir)/m4/ltsugar.m4 $(top_srcdir)/m4/ltversion.m4 \ $(top_srcdir)/m4/lt~obsolete.m4 $(top_srcdir)/m4/pkg.m4 \ $(top_srcdir)/configure.ac am__configure_deps = $(am__aclocal_m4_deps) $(CONFIGURE_DEPENDENCIES) \ $(ACLOCAL_M4) DIST_COMMON = $(srcdir)/Makefile.am $(top_srcdir)/configure \ $(am__configure_deps) $(am__DIST_COMMON) am__CONFIG_DISTCLEAN_FILES = config.status config.cache config.log \ configure.lineno config.status.lineno mkinstalldirs = $(install_sh) -d CONFIG_HEADER = config_ac.h CONFIG_CLEAN_FILES = CONFIG_CLEAN_VPATH_FILES = AM_V_P = $(am__v_P_@AM_V@) am__v_P_ = $(am__v_P_@AM_DEFAULT_V@) am__v_P_0 = false am__v_P_1 = : AM_V_GEN = $(am__v_GEN_@AM_V@) am__v_GEN_ = $(am__v_GEN_@AM_DEFAULT_V@) am__v_GEN_0 = @echo " GEN " $@; am__v_GEN_1 = AM_V_at = $(am__v_at_@AM_V@) am__v_at_ = $(am__v_at_@AM_DEFAULT_V@) am__v_at_0 = @ am__v_at_1 = SOURCES = DIST_SOURCES = RECURSIVE_TARGETS = all-recursive check-recursive cscopelist-recursive \ ctags-recursive dvi-recursive html-recursive info-recursive \ install-data-recursive install-dvi-recursive \ install-exec-recursive install-html-recursive \ install-info-recursive install-pdf-recursive \ install-ps-recursive install-recursive installcheck-recursive \ installdirs-recursive pdf-recursive ps-recursive \ tags-recursive uninstall-recursive am__can_run_installinfo = \ case $$AM_UPDATE_INFO_DIR in \ n|no|NO) false;; \ *) (install-info --version) >/dev/null 2>&1;; \ esac RECURSIVE_CLEAN_TARGETS = mostlyclean-recursive clean-recursive \ distclean-recursive maintainer-clean-recursive am__recursive_targets = \ $(RECURSIVE_TARGETS) \ $(RECURSIVE_CLEAN_TARGETS) \ $(am__extra_recursive_targets) AM_RECURSIVE_TARGETS = $(am__recursive_targets:-recursive=) TAGS CTAGS \ cscope distdir dist dist-all distcheck am__tagged_files = $(HEADERS) $(SOURCES) $(TAGS_FILES) \ $(LISP)config_ac-h.in # Read a list of newline-separated strings from the standard input, # and print each of them once, without duplicates. Input order is # *not* preserved. am__uniquify_input = $(AWK) '\ BEGIN { nonempty = 0; } \ { items[$$0] = 1; nonempty = 1; } \ END { if (nonempty) { for (i in items) print i; }; } \ ' # Make sure the list of sources is unique. This is necessary because, # e.g., the same source file might be shared among _SOURCES variables # for different programs/libraries. am__define_uniq_tagged_files = \ list='$(am__tagged_files)'; \ unique=`for i in $$list; do \ if test -f "$$i"; then echo $$i; else echo $(srcdir)/$$i; fi; \ done | $(am__uniquify_input)` ETAGS = etags CTAGS = ctags CSCOPE = cscope DIST_SUBDIRS = common vnc xup mc neutrinordp libxrdp libpainter \ librfxcodec xrdp sesman keygen docs instfiles genkeymap \ xrdpapi pkgconfig xrdpvr am__DIST_COMMON = $(srcdir)/Makefile.in $(srcdir)/config_ac-h.in \ COPYING compile config.guess config.sub install-sh ltmain.sh \ missing DISTFILES = $(DIST_COMMON) $(DIST_SOURCES) $(TEXINFOS) $(EXTRA_DIST) distdir = $(PACKAGE)-$(VERSION) top_distdir = $(distdir) am__remove_distdir = \ if test -d "$(distdir)"; then \ find "$(distdir)" -type d ! -perm -200 -exec chmod u+w {} ';' \ && rm -rf "$(distdir)" \ || { sleep 5 && rm -rf "$(distdir)"; }; \ else :; fi am__post_remove_distdir = $(am__remove_distdir) am__relativize = \ dir0=`pwd`; \ sed_first='s,^\([^/]*\)/.*$$,\1,'; \ sed_rest='s,^[^/]*/*,,'; \ sed_last='s,^.*/\([^/]*\)$$,\1,'; \ sed_butlast='s,/*[^/]*$$,,'; \ while test -n "$$dir1"; do \ first=`echo "$$dir1" | sed -e "$$sed_first"`; \ if test "$$first" != "."; then \ if test "$$first" = ".."; then \ dir2=`echo "$$dir0" | sed -e "$$sed_last"`/"$$dir2"; \ dir0=`echo "$$dir0" | sed -e "$$sed_butlast"`; \ else \ first2=`echo "$$dir2" | sed -e "$$sed_first"`; \ if test "$$first2" = "$$first"; then \ dir2=`echo "$$dir2" | sed -e "$$sed_rest"`; \ else \ dir2="../$$dir2"; \ fi; \ dir0="$$dir0"/"$$first"; \ fi; \ fi; \ dir1=`echo "$$dir1" | sed -e "$$sed_rest"`; \ done; \ reldir="$$dir2" DIST_ARCHIVES = $(distdir).tar.gz GZIP_ENV = --best DIST_TARGETS = dist-gzip distuninstallcheck_listfiles = find . -type f -print am__distuninstallcheck_listfiles = $(distuninstallcheck_listfiles) \ | sed 's|^\./|$(prefix)/|' | grep -v '$(infodir)/dir$$' distcleancheck_listfiles = find . -type f -print ACLOCAL = @ACLOCAL@ AMTAR = @AMTAR@ AM_DEFAULT_VERBOSITY = @AM_DEFAULT_VERBOSITY@ AR = @AR@ AUTOCONF = @AUTOCONF@ AUTOHEADER = @AUTOHEADER@ AUTOMAKE = @AUTOMAKE@ AWK = @AWK@ CC = @CC@ CCDEPMODE = @CCDEPMODE@ CFLAGS = @CFLAGS@ CPP = @CPP@ CPPFLAGS = @CPPFLAGS@ CYGPATH_W = @CYGPATH_W@ DEFS = @DEFS@ DEPDIR = @DEPDIR@ DLLTOOL = @DLLTOOL@ DLOPEN_LIBS = @DLOPEN_LIBS@ DSYMUTIL = @DSYMUTIL@ DUMPBIN = @DUMPBIN@ ECHO_C = @ECHO_C@ ECHO_N = @ECHO_N@ ECHO_T = @ECHO_T@ EGREP = @EGREP@ EXEEXT = @EXEEXT@ FDKAAC_CFLAGS = @FDKAAC_CFLAGS@ FDKAAC_LIBS = @FDKAAC_LIBS@ FGREP = @FGREP@ FREERDP_CFLAGS = @FREERDP_CFLAGS@ FREERDP_LIBS = @FREERDP_LIBS@ FUSE_CFLAGS = @FUSE_CFLAGS@ FUSE_LIBS = @FUSE_LIBS@ GREP = @GREP@ INSTALL = @INSTALL@ INSTALL_DATA = @INSTALL_DATA@ INSTALL_PROGRAM = @INSTALL_PROGRAM@ INSTALL_SCRIPT = @INSTALL_SCRIPT@ INSTALL_STRIP_PROGRAM = @INSTALL_STRIP_PROGRAM@ LD = @LD@ LDFLAGS = @LDFLAGS@ LIBOBJS = @LIBOBJS@ LIBS = @LIBS@ LIBTOOL = @LIBTOOL@ LIPO = @LIPO@ LN_S = @LN_S@ LTLIBOBJS = @LTLIBOBJS@ LT_SYS_LIBRARY_PATH = @LT_SYS_LIBRARY_PATH@ MAKEINFO = @MAKEINFO@ MANIFEST_TOOL = @MANIFEST_TOOL@ MKDIR_P = @MKDIR_P@ NM = @NM@ NMEDIT = @NMEDIT@ OBJDUMP = @OBJDUMP@ OBJEXT = @OBJEXT@ OPENSSL = @OPENSSL@ OPENSSL_CFLAGS = @OPENSSL_CFLAGS@ OPENSSL_LIBS = @OPENSSL_LIBS@ OTOOL = @OTOOL@ OTOOL64 = @OTOOL64@ PACKAGE = @PACKAGE@ PACKAGE_BUGREPORT = @PACKAGE_BUGREPORT@ PACKAGE_NAME = @PACKAGE_NAME@ PACKAGE_STRING = @PACKAGE_STRING@ PACKAGE_TARNAME = @PACKAGE_TARNAME@ PACKAGE_URL = @PACKAGE_URL@ PACKAGE_VERSION = @PACKAGE_VERSION@ PAM_RULES = @PAM_RULES@ PATH_SEPARATOR = @PATH_SEPARATOR@ PIXMAN_CFLAGS = @PIXMAN_CFLAGS@ PIXMAN_LIBS = @PIXMAN_LIBS@ PKG_CONFIG = @PKG_CONFIG@ PKG_CONFIG_LIBDIR = @PKG_CONFIG_LIBDIR@ PKG_CONFIG_PATH = @PKG_CONFIG_PATH@ RANLIB = @RANLIB@ SED = @SED@ SET_MAKE = @SET_MAKE@ SHELL = @SHELL@ STRIP = @STRIP@ TurboJpegIncDir = @TurboJpegIncDir@ TurboJpegLibDir = @TurboJpegLibDir@ VERSION = @VERSION@ XMKMF = @XMKMF@ X_CFLAGS = @X_CFLAGS@ X_EXTRA_LIBS = @X_EXTRA_LIBS@ X_LIBS = @X_LIBS@ X_PRE_LIBS = @X_PRE_LIBS@ abs_builddir = @abs_builddir@ abs_srcdir = @abs_srcdir@ abs_top_builddir = @abs_top_builddir@ abs_top_srcdir = @abs_top_srcdir@ ac_ct_AR = @ac_ct_AR@ ac_ct_CC = @ac_ct_CC@ ac_ct_DUMPBIN = @ac_ct_DUMPBIN@ am__include = @am__include@ am__leading_dot = @am__leading_dot@ am__quote = @am__quote@ am__tar = @am__tar@ am__untar = @am__untar@ bindir = @bindir@ build = @build@ build_alias = @build_alias@ build_cpu = @build_cpu@ build_os = @build_os@ build_vendor = @build_vendor@ builddir = @builddir@ datadir = @datadir@ datarootdir = @datarootdir@ docdir = @docdir@ dvidir = @dvidir@ exec_prefix = @exec_prefix@ host = @host@ host_alias = @host_alias@ host_cpu = @host_cpu@ host_os = @host_os@ host_vendor = @host_vendor@ htmldir = @htmldir@ includedir = @includedir@ infodir = @infodir@ install_sh = @install_sh@ libdir = @libdir@ libexecdir = @libexecdir@ localedir = @localedir@ localstatedir = @localstatedir@ mandir = @mandir@ mkdir_p = @mkdir_p@ moduledir = @moduledir@ oldincludedir = @oldincludedir@ pdfdir = @pdfdir@ pkgconfigdir = @pkgconfigdir@ prefix = @prefix@ program_transform_name = @program_transform_name@ psdir = @psdir@ sbindir = @sbindir@ sharedstatedir = @sharedstatedir@ socketdir = @socketdir@ srcdir = @srcdir@ subdirs = @subdirs@ sysconfdir = @sysconfdir@ systemdsystemunitdir = @systemdsystemunitdir@ target_alias = @target_alias@ top_build_prefix = @top_build_prefix@ top_builddir = @top_builddir@ top_srcdir = @top_srcdir@ ACLOCAL_AMFLAGS = -I m4 AM_DISTCHECK_CONFIGURE_FLAGS = \ --without-systemdsystemunitdir \ --enable-strict-locations EXTRA_DIST = \ COPYING \ README.md \ NEWS.md \ astyle_config.as \ bootstrap \ coding_style.md \ description-pak \ design.txt \ faq-compile.txt \ faq-general.txt \ file-loc.txt \ fontdump \ install.txt \ m4 \ postinstall-pak \ tcutils \ tests \ vrplayer \ xorg @XRDP_NEUTRINORDP_FALSE@NEUTRINORDPDIR = @XRDP_NEUTRINORDP_TRUE@NEUTRINORDPDIR = neutrinordp @XRDP_XRDPVR_FALSE@XRDPVRDIR = @XRDP_XRDPVR_TRUE@XRDPVRDIR = xrdpvr @XRDP_PAINTER_FALSE@PAINTERDIR = @XRDP_PAINTER_TRUE@PAINTERDIR = libpainter @XRDP_RFXCODEC_FALSE@RFXCODECDIR = @XRDP_RFXCODEC_TRUE@RFXCODECDIR = librfxcodec SUBDIRS = \ common \ vnc \ xup \ mc \ $(NEUTRINORDPDIR) \ libxrdp \ $(PAINTERDIR) \ $(RFXCODECDIR) \ xrdp \ sesman \ keygen \ docs \ instfiles \ genkeymap \ xrdpapi \ pkgconfig \ $(XRDPVRDIR) all: config_ac.h $(MAKE) $(AM_MAKEFLAGS) all-recursive .SUFFIXES: am--refresh: Makefile @: $(srcdir)/Makefile.in: $(srcdir)/Makefile.am $(am__configure_deps) @for dep in $?; do \ case '$(am__configure_deps)' in \ *$$dep*) \ echo ' cd $(srcdir) && $(AUTOMAKE) --foreign'; \ $(am__cd) $(srcdir) && $(AUTOMAKE) --foreign \ && exit 0; \ exit 1;; \ esac; \ done; \ echo ' cd $(top_srcdir) && $(AUTOMAKE) --foreign Makefile'; \ $(am__cd) $(top_srcdir) && \ $(AUTOMAKE) --foreign Makefile Makefile: $(srcdir)/Makefile.in $(top_builddir)/config.status @case '$?' in \ *config.status*) \ echo ' $(SHELL) ./config.status'; \ $(SHELL) ./config.status;; \ *) \ echo ' cd $(top_builddir) && $(SHELL) ./config.status $@ $(am__depfiles_maybe)'; \ cd $(top_builddir) && $(SHELL) ./config.status $@ $(am__depfiles_maybe);; \ esac; $(top_builddir)/config.status: $(top_srcdir)/configure $(CONFIG_STATUS_DEPENDENCIES) $(SHELL) ./config.status --recheck $(top_srcdir)/configure: $(am__configure_deps) $(am__cd) $(srcdir) && $(AUTOCONF) $(ACLOCAL_M4): $(am__aclocal_m4_deps) $(am__cd) $(srcdir) && $(ACLOCAL) $(ACLOCAL_AMFLAGS) $(am__aclocal_m4_deps): config_ac.h: stamp-h1 @test -f $@ || rm -f stamp-h1 @test -f $@ || $(MAKE) $(AM_MAKEFLAGS) stamp-h1 stamp-h1: $(srcdir)/config_ac-h.in $(top_builddir)/config.status @rm -f stamp-h1 cd $(top_builddir) && $(SHELL) ./config.status config_ac.h $(srcdir)/config_ac-h.in: $(am__configure_deps) ($(am__cd) $(top_srcdir) && $(AUTOHEADER)) rm -f stamp-h1 touch $@ distclean-hdr: -rm -f config_ac.h stamp-h1 mostlyclean-libtool: -rm -f *.lo clean-libtool: -rm -rf .libs _libs distclean-libtool: -rm -f libtool config.lt # This directory's subdirectories are mostly independent; you can cd # into them and run 'make' without going through this Makefile. # To change the values of 'make' variables: instead of editing Makefiles, # (1) if the variable is set in 'config.status', edit 'config.status' # (which will cause the Makefiles to be regenerated when you run 'make'); # (2) otherwise, pass the desired values on the 'make' command line. $(am__recursive_targets): @fail=; \ if $(am__make_keepgoing); then \ failcom='fail=yes'; \ else \ failcom='exit 1'; \ fi; \ dot_seen=no; \ target=`echo $@ | sed s/-recursive//`; \ case "$@" in \ distclean-* | maintainer-clean-*) list='$(DIST_SUBDIRS)' ;; \ *) list='$(SUBDIRS)' ;; \ esac; \ for subdir in $$list; do \ echo "Making $$target in $$subdir"; \ if test "$$subdir" = "."; then \ dot_seen=yes; \ local_target="$$target-am"; \ else \ local_target="$$target"; \ fi; \ ($(am__cd) $$subdir && $(MAKE) $(AM_MAKEFLAGS) $$local_target) \ || eval $$failcom; \ done; \ if test "$$dot_seen" = "no"; then \ $(MAKE) $(AM_MAKEFLAGS) "$$target-am" || exit 1; \ fi; test -z "$$fail" ID: $(am__tagged_files) $(am__define_uniq_tagged_files); mkid -fID $$unique tags: tags-recursive TAGS: tags tags-am: $(TAGS_DEPENDENCIES) $(am__tagged_files) set x; \ here=`pwd`; \ if ($(ETAGS) --etags-include --version) >/dev/null 2>&1; then \ include_option=--etags-include; \ empty_fix=.; \ else \ include_option=--include; \ empty_fix=; \ fi; \ list='$(SUBDIRS)'; for subdir in $$list; do \ if test "$$subdir" = .; then :; else \ test ! -f $$subdir/TAGS || \ set "$$@" "$$include_option=$$here/$$subdir/TAGS"; \ fi; \ done; \ $(am__define_uniq_tagged_files); \ shift; \ if test -z "$(ETAGS_ARGS)$$*$$unique"; then :; else \ test -n "$$unique" || unique=$$empty_fix; \ if test $$# -gt 0; then \ $(ETAGS) $(ETAGSFLAGS) $(AM_ETAGSFLAGS) $(ETAGS_ARGS) \ "$$@" $$unique; \ else \ $(ETAGS) $(ETAGSFLAGS) $(AM_ETAGSFLAGS) $(ETAGS_ARGS) \ $$unique; \ fi; \ fi ctags: ctags-recursive CTAGS: ctags ctags-am: $(TAGS_DEPENDENCIES) $(am__tagged_files) $(am__define_uniq_tagged_files); \ test -z "$(CTAGS_ARGS)$$unique" \ || $(CTAGS) $(CTAGSFLAGS) $(AM_CTAGSFLAGS) $(CTAGS_ARGS) \ $$unique GTAGS: here=`$(am__cd) $(top_builddir) && pwd` \ && $(am__cd) $(top_srcdir) \ && gtags -i $(GTAGS_ARGS) "$$here" cscope: cscope.files test ! -s cscope.files \ || $(CSCOPE) -b -q $(AM_CSCOPEFLAGS) $(CSCOPEFLAGS) -i cscope.files $(CSCOPE_ARGS) clean-cscope: -rm -f cscope.files cscope.files: clean-cscope cscopelist cscopelist: cscopelist-recursive cscopelist-am: $(am__tagged_files) list='$(am__tagged_files)'; \ case "$(srcdir)" in \ [\\/]* | ?:[\\/]*) sdir="$(srcdir)" ;; \ *) sdir=$(subdir)/$(srcdir) ;; \ esac; \ for i in $$list; do \ if test -f "$$i"; then \ echo "$(subdir)/$$i"; \ else \ echo "$$sdir/$$i"; \ fi; \ done >> $(top_builddir)/cscope.files distclean-tags: -rm -f TAGS ID GTAGS GRTAGS GSYMS GPATH tags -rm -f cscope.out cscope.in.out cscope.po.out cscope.files distdir: $(DISTFILES) $(am__remove_distdir) test -d "$(distdir)" || mkdir "$(distdir)" @srcdirstrip=`echo "$(srcdir)" | sed 's/[].[^$$\\*]/\\\\&/g'`; \ topsrcdirstrip=`echo "$(top_srcdir)" | sed 's/[].[^$$\\*]/\\\\&/g'`; \ list='$(DISTFILES)'; \ dist_files=`for file in $$list; do echo $$file; done | \ sed -e "s|^$$srcdirstrip/||;t" \ -e "s|^$$topsrcdirstrip/|$(top_builddir)/|;t"`; \ case $$dist_files in \ */*) $(MKDIR_P) `echo "$$dist_files" | \ sed '/\//!d;s|^|$(distdir)/|;s,/[^/]*$$,,' | \ sort -u` ;; \ esac; \ for file in $$dist_files; do \ if test -f $$file || test -d $$file; then d=.; else d=$(srcdir); fi; \ if test -d $$d/$$file; then \ dir=`echo "/$$file" | sed -e 's,/[^/]*$$,,'`; \ if test -d "$(distdir)/$$file"; then \ find "$(distdir)/$$file" -type d ! -perm -700 -exec chmod u+rwx {} \;; \ fi; \ if test -d $(srcdir)/$$file && test $$d != $(srcdir); then \ cp -fpR $(srcdir)/$$file "$(distdir)$$dir" || exit 1; \ find "$(distdir)/$$file" -type d ! -perm -700 -exec chmod u+rwx {} \;; \ fi; \ cp -fpR $$d/$$file "$(distdir)$$dir" || exit 1; \ else \ test -f "$(distdir)/$$file" \ || cp -p $$d/$$file "$(distdir)/$$file" \ || exit 1; \ fi; \ done @list='$(DIST_SUBDIRS)'; for subdir in $$list; do \ if test "$$subdir" = .; then :; else \ $(am__make_dryrun) \ || test -d "$(distdir)/$$subdir" \ || $(MKDIR_P) "$(distdir)/$$subdir" \ || exit 1; \ dir1=$$subdir; dir2="$(distdir)/$$subdir"; \ $(am__relativize); \ new_distdir=$$reldir; \ dir1=$$subdir; dir2="$(top_distdir)"; \ $(am__relativize); \ new_top_distdir=$$reldir; \ echo " (cd $$subdir && $(MAKE) $(AM_MAKEFLAGS) top_distdir="$$new_top_distdir" distdir="$$new_distdir" \\"; \ echo " am__remove_distdir=: am__skip_length_check=: am__skip_mode_fix=: distdir)"; \ ($(am__cd) $$subdir && \ $(MAKE) $(AM_MAKEFLAGS) \ top_distdir="$$new_top_distdir" \ distdir="$$new_distdir" \ am__remove_distdir=: \ am__skip_length_check=: \ am__skip_mode_fix=: \ distdir) \ || exit 1; \ fi; \ done -test -n "$(am__skip_mode_fix)" \ || find "$(distdir)" -type d ! -perm -755 \ -exec chmod u+rwx,go+rx {} \; -o \ ! -type d ! -perm -444 -links 1 -exec chmod a+r {} \; -o \ ! -type d ! -perm -400 -exec chmod a+r {} \; -o \ ! -type d ! -perm -444 -exec $(install_sh) -c -m a+r {} {} \; \ || chmod -R a+r "$(distdir)" dist-gzip: distdir tardir=$(distdir) && $(am__tar) | eval GZIP= gzip $(GZIP_ENV) -c >$(distdir).tar.gz $(am__post_remove_distdir) dist-bzip2: distdir tardir=$(distdir) && $(am__tar) | BZIP2=$${BZIP2--9} bzip2 -c >$(distdir).tar.bz2 $(am__post_remove_distdir) dist-lzip: distdir tardir=$(distdir) && $(am__tar) | lzip -c $${LZIP_OPT--9} >$(distdir).tar.lz $(am__post_remove_distdir) dist-xz: distdir tardir=$(distdir) && $(am__tar) | XZ_OPT=$${XZ_OPT--e} xz -c >$(distdir).tar.xz $(am__post_remove_distdir) dist-tarZ: distdir @echo WARNING: "Support for distribution archives compressed with" \ "legacy program 'compress' is deprecated." >&2 @echo WARNING: "It will be removed altogether in Automake 2.0" >&2 tardir=$(distdir) && $(am__tar) | compress -c >$(distdir).tar.Z $(am__post_remove_distdir) dist-shar: distdir @echo WARNING: "Support for shar distribution archives is" \ "deprecated." >&2 @echo WARNING: "It will be removed altogether in Automake 2.0" >&2 shar $(distdir) | eval GZIP= gzip $(GZIP_ENV) -c >$(distdir).shar.gz $(am__post_remove_distdir) dist-zip: distdir -rm -f $(distdir).zip zip -rq $(distdir).zip $(distdir) $(am__post_remove_distdir) dist dist-all: $(MAKE) $(AM_MAKEFLAGS) $(DIST_TARGETS) am__post_remove_distdir='@:' $(am__post_remove_distdir) # This target untars the dist file and tries a VPATH configuration. Then # it guarantees that the distribution is self-contained by making another # tarfile. distcheck: dist case '$(DIST_ARCHIVES)' in \ *.tar.gz*) \ eval GZIP= gzip $(GZIP_ENV) -dc $(distdir).tar.gz | $(am__untar) ;;\ *.tar.bz2*) \ bzip2 -dc $(distdir).tar.bz2 | $(am__untar) ;;\ *.tar.lz*) \ lzip -dc $(distdir).tar.lz | $(am__untar) ;;\ *.tar.xz*) \ xz -dc $(distdir).tar.xz | $(am__untar) ;;\ *.tar.Z*) \ uncompress -c $(distdir).tar.Z | $(am__untar) ;;\ *.shar.gz*) \ eval GZIP= gzip $(GZIP_ENV) -dc $(distdir).shar.gz | unshar ;;\ *.zip*) \ unzip $(distdir).zip ;;\ esac chmod -R a-w $(distdir) chmod u+w $(distdir) mkdir $(distdir)/_build $(distdir)/_build/sub $(distdir)/_inst chmod a-w $(distdir) test -d $(distdir)/_build || exit 0; \ dc_install_base=`$(am__cd) $(distdir)/_inst && pwd | sed -e 's,^[^:\\/]:[\\/],/,'` \ && dc_destdir="$${TMPDIR-/tmp}/am-dc-$$$$/" \ && am__cwd=`pwd` \ && $(am__cd) $(distdir)/_build/sub \ && ../../configure \ $(AM_DISTCHECK_CONFIGURE_FLAGS) \ $(DISTCHECK_CONFIGURE_FLAGS) \ --srcdir=../.. --prefix="$$dc_install_base" \ && $(MAKE) $(AM_MAKEFLAGS) \ && $(MAKE) $(AM_MAKEFLAGS) dvi \ && $(MAKE) $(AM_MAKEFLAGS) check \ && $(MAKE) $(AM_MAKEFLAGS) install \ && $(MAKE) $(AM_MAKEFLAGS) installcheck \ && $(MAKE) $(AM_MAKEFLAGS) uninstall \ && $(MAKE) $(AM_MAKEFLAGS) distuninstallcheck_dir="$$dc_install_base" \ distuninstallcheck \ && chmod -R a-w "$$dc_install_base" \ && ({ \ (cd ../.. && umask 077 && mkdir "$$dc_destdir") \ && $(MAKE) $(AM_MAKEFLAGS) DESTDIR="$$dc_destdir" install \ && $(MAKE) $(AM_MAKEFLAGS) DESTDIR="$$dc_destdir" uninstall \ && $(MAKE) $(AM_MAKEFLAGS) DESTDIR="$$dc_destdir" \ distuninstallcheck_dir="$$dc_destdir" distuninstallcheck; \ } || { rm -rf "$$dc_destdir"; exit 1; }) \ && rm -rf "$$dc_destdir" \ && $(MAKE) $(AM_MAKEFLAGS) dist \ && rm -rf $(DIST_ARCHIVES) \ && $(MAKE) $(AM_MAKEFLAGS) distcleancheck \ && cd "$$am__cwd" \ || exit 1 $(am__post_remove_distdir) @(echo "$(distdir) archives ready for distribution: "; \ list='$(DIST_ARCHIVES)'; for i in $$list; do echo $$i; done) | \ sed -e 1h -e 1s/./=/g -e 1p -e 1x -e '$$p' -e '$$x' distuninstallcheck: @test -n '$(distuninstallcheck_dir)' || { \ echo 'ERROR: trying to run $@ with an empty' \ '$$(distuninstallcheck_dir)' >&2; \ exit 1; \ }; \ $(am__cd) '$(distuninstallcheck_dir)' || { \ echo 'ERROR: cannot chdir into $(distuninstallcheck_dir)' >&2; \ exit 1; \ }; \ test `$(am__distuninstallcheck_listfiles) | wc -l` -eq 0 \ || { echo "ERROR: files left after uninstall:" ; \ if test -n "$(DESTDIR)"; then \ echo " (check DESTDIR support)"; \ fi ; \ $(distuninstallcheck_listfiles) ; \ exit 1; } >&2 distcleancheck: distclean @if test '$(srcdir)' = . ; then \ echo "ERROR: distcleancheck can only run from a VPATH build" ; \ exit 1 ; \ fi @test `$(distcleancheck_listfiles) | wc -l` -eq 0 \ || { echo "ERROR: files left in build directory after distclean:" ; \ $(distcleancheck_listfiles) ; \ exit 1; } >&2 check-am: all-am check: check-recursive all-am: Makefile config_ac.h installdirs: installdirs-recursive installdirs-am: install: install-recursive install-exec: install-exec-recursive install-data: install-data-recursive uninstall: uninstall-recursive install-am: all-am @$(MAKE) $(AM_MAKEFLAGS) install-exec-am install-data-am installcheck: installcheck-recursive install-strip: if test -z '$(STRIP)'; then \ $(MAKE) $(AM_MAKEFLAGS) INSTALL_PROGRAM="$(INSTALL_STRIP_PROGRAM)" \ install_sh_PROGRAM="$(INSTALL_STRIP_PROGRAM)" INSTALL_STRIP_FLAG=-s \ install; \ else \ $(MAKE) $(AM_MAKEFLAGS) INSTALL_PROGRAM="$(INSTALL_STRIP_PROGRAM)" \ install_sh_PROGRAM="$(INSTALL_STRIP_PROGRAM)" INSTALL_STRIP_FLAG=-s \ "INSTALL_PROGRAM_ENV=STRIPPROG='$(STRIP)'" install; \ fi mostlyclean-generic: clean-generic: distclean-generic: -test -z "$(CONFIG_CLEAN_FILES)" || rm -f $(CONFIG_CLEAN_FILES) -test . = "$(srcdir)" || test -z "$(CONFIG_CLEAN_VPATH_FILES)" || rm -f $(CONFIG_CLEAN_VPATH_FILES) maintainer-clean-generic: @echo "This command is intended for maintainers to use" @echo "it deletes files that may require special tools to rebuild." clean: clean-recursive clean-am: clean-generic clean-libtool mostlyclean-am distclean: distclean-recursive -rm -f $(am__CONFIG_DISTCLEAN_FILES) -rm -f Makefile distclean-am: clean-am distclean-generic distclean-hdr \ distclean-libtool distclean-tags dvi: dvi-recursive dvi-am: html: html-recursive html-am: info: info-recursive info-am: install-data-am: install-dvi: install-dvi-recursive install-dvi-am: install-exec-am: install-html: install-html-recursive install-html-am: install-info: install-info-recursive install-info-am: install-man: install-pdf: install-pdf-recursive install-pdf-am: install-ps: install-ps-recursive install-ps-am: installcheck-am: maintainer-clean: maintainer-clean-recursive -rm -f $(am__CONFIG_DISTCLEAN_FILES) -rm -rf $(top_srcdir)/autom4te.cache -rm -f Makefile maintainer-clean-am: distclean-am maintainer-clean-generic mostlyclean: mostlyclean-recursive mostlyclean-am: mostlyclean-generic mostlyclean-libtool pdf: pdf-recursive pdf-am: ps: ps-recursive ps-am: uninstall-am: .MAKE: $(am__recursive_targets) all install-am install-strip .PHONY: $(am__recursive_targets) CTAGS GTAGS TAGS all all-am \ am--refresh check check-am clean clean-cscope clean-generic \ clean-libtool cscope cscopelist-am ctags ctags-am dist \ dist-all dist-bzip2 dist-gzip dist-lzip dist-shar dist-tarZ \ dist-xz dist-zip distcheck distclean distclean-generic \ distclean-hdr distclean-libtool distclean-tags distcleancheck \ distdir distuninstallcheck dvi dvi-am html html-am info \ info-am install install-am install-data install-data-am \ install-dvi install-dvi-am install-exec install-exec-am \ install-html install-html-am install-info install-info-am \ install-man install-pdf install-pdf-am install-ps \ install-ps-am install-strip installcheck installcheck-am \ installdirs installdirs-am maintainer-clean \ maintainer-clean-generic mostlyclean mostlyclean-generic \ mostlyclean-libtool pdf pdf-am ps ps-am tags tags-am uninstall \ uninstall-am .PRECIOUS: Makefile # Tell versions [3.59,3.63) of GNU make to not export all variables. # Otherwise a system limit (for SysV at least) may be exceeded. .NOEXPORT: xrdp-0.9.5/xup/000755 001751 001751 00000000000 13220731016 013231 5ustar00metameta000000 000000 xrdp-0.9.5/vnc/000755 001751 001751 00000000000 13220731016 013203 5ustar00metameta000000 000000 xrdp-0.9.5/postinstall-pak000644 001751 001751 00000000732 13125122133 015465 0ustar00metameta000000 000000 #!/bin/sh -e if ! ([ "$1" = "configure" ] || [ "$1" = "reconfigure" ]); then exit 0 fi XRDP="xrdp" ADDUSER="/usr/sbin/adduser" XRDPLOG="/var/log/xrdp-sesman.log" SESMANLOG="/var/log/xrdp-sesman.log" [ -d /var/run/xrdp ] || mkdir -p /var/run/xrdp $ADDUSER --system --disabled-password --disabled-login --home /var/run/xrdp \ --no-create-home --quiet --group $XRDP touch $SESMANLOG $XRDPLOG chown $XRDP:$XRDP $SESMANLOG chown $XRDP:$XRDP $XRDPLOG #DEBHELPER# xrdp-0.9.5/common/000755 001751 001751 00000000000 13220731016 013705 5ustar00metameta000000 000000 xrdp-0.9.5/install-sh000755 001751 001751 00000034524 13220730773 014442 0ustar00metameta000000 000000 #!/bin/sh # install - install a program, script, or datafile scriptversion=2016-01-11.22; # UTC # This originates from X11R5 (mit/util/scripts/install.sh), which was # later released in X11R6 (xc/config/util/install.sh) with the # following copyright and license. # # Copyright (C) 1994 X Consortium # # Permission is hereby granted, free of charge, to any person obtaining a copy # of this software and associated documentation files (the "Software"), to # deal in the Software without restriction, including without limitation the # rights to use, copy, modify, merge, publish, distribute, sublicense, and/or # sell copies of the Software, and to permit persons to whom the Software is # furnished to do so, subject to the following conditions: # # The above copyright notice and this permission notice shall be included in # all copies or substantial portions of the Software. # # THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR # IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, # FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE # X CONSORTIUM BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN # AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNEC- # TION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. # # Except as contained in this notice, the name of the X Consortium shall not # be used in advertising or otherwise to promote the sale, use or other deal- # ings in this Software without prior written authorization from the X Consor- # tium. # # # FSF changes to this file are in the public domain. # # Calling this script install-sh is preferred over install.sh, to prevent # 'make' implicit rules from creating a file called install from it # when there is no Makefile. # # This script is compatible with the BSD install script, but was written # from scratch. tab=' ' nl=' ' IFS=" $tab$nl" # Set DOITPROG to "echo" to test this script. doit=${DOITPROG-} doit_exec=${doit:-exec} # Put in absolute file names if you don't have them in your path; # or use environment vars. chgrpprog=${CHGRPPROG-chgrp} chmodprog=${CHMODPROG-chmod} chownprog=${CHOWNPROG-chown} cmpprog=${CMPPROG-cmp} cpprog=${CPPROG-cp} mkdirprog=${MKDIRPROG-mkdir} mvprog=${MVPROG-mv} rmprog=${RMPROG-rm} stripprog=${STRIPPROG-strip} posix_mkdir= # Desired mode of installed file. mode=0755 chgrpcmd= chmodcmd=$chmodprog chowncmd= mvcmd=$mvprog rmcmd="$rmprog -f" stripcmd= src= dst= dir_arg= dst_arg= copy_on_change=false is_target_a_directory=possibly usage="\ Usage: $0 [OPTION]... [-T] SRCFILE DSTFILE or: $0 [OPTION]... SRCFILES... DIRECTORY or: $0 [OPTION]... -t DIRECTORY SRCFILES... or: $0 [OPTION]... -d DIRECTORIES... In the 1st form, copy SRCFILE to DSTFILE. In the 2nd and 3rd, copy all SRCFILES to DIRECTORY. In the 4th, create DIRECTORIES. Options: --help display this help and exit. --version display version info and exit. -c (ignored) -C install only if different (preserve the last data modification time) -d create directories instead of installing files. -g GROUP $chgrpprog installed files to GROUP. -m MODE $chmodprog installed files to MODE. -o USER $chownprog installed files to USER. -s $stripprog installed files. -t DIRECTORY install into DIRECTORY. -T report an error if DSTFILE is a directory. Environment variables override the default commands: CHGRPPROG CHMODPROG CHOWNPROG CMPPROG CPPROG MKDIRPROG MVPROG RMPROG STRIPPROG " while test $# -ne 0; do case $1 in -c) ;; -C) copy_on_change=true;; -d) dir_arg=true;; -g) chgrpcmd="$chgrpprog $2" shift;; --help) echo "$usage"; exit $?;; -m) mode=$2 case $mode in *' '* | *"$tab"* | *"$nl"* | *'*'* | *'?'* | *'['*) echo "$0: invalid mode: $mode" >&2 exit 1;; esac shift;; -o) chowncmd="$chownprog $2" shift;; -s) stripcmd=$stripprog;; -t) is_target_a_directory=always dst_arg=$2 # Protect names problematic for 'test' and other utilities. case $dst_arg in -* | [=\(\)!]) dst_arg=./$dst_arg;; esac shift;; -T) is_target_a_directory=never;; --version) echo "$0 $scriptversion"; exit $?;; --) shift break;; -*) echo "$0: invalid option: $1" >&2 exit 1;; *) break;; esac shift done # We allow the use of options -d and -T together, by making -d # take the precedence; this is for compatibility with GNU install. if test -n "$dir_arg"; then if test -n "$dst_arg"; then echo "$0: target directory not allowed when installing a directory." >&2 exit 1 fi fi if test $# -ne 0 && test -z "$dir_arg$dst_arg"; then # When -d is used, all remaining arguments are directories to create. # When -t is used, the destination is already specified. # Otherwise, the last argument is the destination. Remove it from $@. for arg do if test -n "$dst_arg"; then # $@ is not empty: it contains at least $arg. set fnord "$@" "$dst_arg" shift # fnord fi shift # arg dst_arg=$arg # Protect names problematic for 'test' and other utilities. case $dst_arg in -* | [=\(\)!]) dst_arg=./$dst_arg;; esac done fi if test $# -eq 0; then if test -z "$dir_arg"; then echo "$0: no input file specified." >&2 exit 1 fi # It's OK to call 'install-sh -d' without argument. # This can happen when creating conditional directories. exit 0 fi if test -z "$dir_arg"; then if test $# -gt 1 || test "$is_target_a_directory" = always; then if test ! -d "$dst_arg"; then echo "$0: $dst_arg: Is not a directory." >&2 exit 1 fi fi fi if test -z "$dir_arg"; then do_exit='(exit $ret); exit $ret' trap "ret=129; $do_exit" 1 trap "ret=130; $do_exit" 2 trap "ret=141; $do_exit" 13 trap "ret=143; $do_exit" 15 # Set umask so as not to create temps with too-generous modes. # However, 'strip' requires both read and write access to temps. case $mode in # Optimize common cases. *644) cp_umask=133;; *755) cp_umask=22;; *[0-7]) if test -z "$stripcmd"; then u_plus_rw= else u_plus_rw='% 200' fi cp_umask=`expr '(' 777 - $mode % 1000 ')' $u_plus_rw`;; *) if test -z "$stripcmd"; then u_plus_rw= else u_plus_rw=,u+rw fi cp_umask=$mode$u_plus_rw;; esac fi for src do # Protect names problematic for 'test' and other utilities. case $src in -* | [=\(\)!]) src=./$src;; esac if test -n "$dir_arg"; then dst=$src dstdir=$dst test -d "$dstdir" dstdir_status=$? else # Waiting for this to be detected by the "$cpprog $src $dsttmp" command # might cause directories to be created, which would be especially bad # if $src (and thus $dsttmp) contains '*'. if test ! -f "$src" && test ! -d "$src"; then echo "$0: $src does not exist." >&2 exit 1 fi if test -z "$dst_arg"; then echo "$0: no destination specified." >&2 exit 1 fi dst=$dst_arg # If destination is a directory, append the input filename; won't work # if double slashes aren't ignored. if test -d "$dst"; then if test "$is_target_a_directory" = never; then echo "$0: $dst_arg: Is a directory" >&2 exit 1 fi dstdir=$dst dst=$dstdir/`basename "$src"` dstdir_status=0 else dstdir=`dirname "$dst"` test -d "$dstdir" dstdir_status=$? fi fi obsolete_mkdir_used=false if test $dstdir_status != 0; then case $posix_mkdir in '') # Create intermediate dirs using mode 755 as modified by the umask. # This is like FreeBSD 'install' as of 1997-10-28. umask=`umask` case $stripcmd.$umask in # Optimize common cases. *[2367][2367]) mkdir_umask=$umask;; .*0[02][02] | .[02][02] | .[02]) mkdir_umask=22;; *[0-7]) mkdir_umask=`expr $umask + 22 \ - $umask % 100 % 40 + $umask % 20 \ - $umask % 10 % 4 + $umask % 2 `;; *) mkdir_umask=$umask,go-w;; esac # With -d, create the new directory with the user-specified mode. # Otherwise, rely on $mkdir_umask. if test -n "$dir_arg"; then mkdir_mode=-m$mode else mkdir_mode= fi posix_mkdir=false case $umask in *[123567][0-7][0-7]) # POSIX mkdir -p sets u+wx bits regardless of umask, which # is incompatible with FreeBSD 'install' when (umask & 300) != 0. ;; *) tmpdir=${TMPDIR-/tmp}/ins$RANDOM-$$ trap 'ret=$?; rmdir "$tmpdir/d" "$tmpdir" 2>/dev/null; exit $ret' 0 if (umask $mkdir_umask && exec $mkdirprog $mkdir_mode -p -- "$tmpdir/d") >/dev/null 2>&1 then if test -z "$dir_arg" || { # Check for POSIX incompatibilities with -m. # HP-UX 11.23 and IRIX 6.5 mkdir -m -p sets group- or # other-writable bit of parent directory when it shouldn't. # FreeBSD 6.1 mkdir -m -p sets mode of existing directory. ls_ld_tmpdir=`ls -ld "$tmpdir"` case $ls_ld_tmpdir in d????-?r-*) different_mode=700;; d????-?--*) different_mode=755;; *) false;; esac && $mkdirprog -m$different_mode -p -- "$tmpdir" && { ls_ld_tmpdir_1=`ls -ld "$tmpdir"` test "$ls_ld_tmpdir" = "$ls_ld_tmpdir_1" } } then posix_mkdir=: fi rmdir "$tmpdir/d" "$tmpdir" else # Remove any dirs left behind by ancient mkdir implementations. rmdir ./$mkdir_mode ./-p ./-- 2>/dev/null fi trap '' 0;; esac;; esac if $posix_mkdir && ( umask $mkdir_umask && $doit_exec $mkdirprog $mkdir_mode -p -- "$dstdir" ) then : else # The umask is ridiculous, or mkdir does not conform to POSIX, # or it failed possibly due to a race condition. Create the # directory the slow way, step by step, checking for races as we go. case $dstdir in /*) prefix='/';; [-=\(\)!]*) prefix='./';; *) prefix='';; esac oIFS=$IFS IFS=/ set -f set fnord $dstdir shift set +f IFS=$oIFS prefixes= for d do test X"$d" = X && continue prefix=$prefix$d if test -d "$prefix"; then prefixes= else if $posix_mkdir; then (umask=$mkdir_umask && $doit_exec $mkdirprog $mkdir_mode -p -- "$dstdir") && break # Don't fail if two instances are running concurrently. test -d "$prefix" || exit 1 else case $prefix in *\'*) qprefix=`echo "$prefix" | sed "s/'/'\\\\\\\\''/g"`;; *) qprefix=$prefix;; esac prefixes="$prefixes '$qprefix'" fi fi prefix=$prefix/ done if test -n "$prefixes"; then # Don't fail if two instances are running concurrently. (umask $mkdir_umask && eval "\$doit_exec \$mkdirprog $prefixes") || test -d "$dstdir" || exit 1 obsolete_mkdir_used=true fi fi fi if test -n "$dir_arg"; then { test -z "$chowncmd" || $doit $chowncmd "$dst"; } && { test -z "$chgrpcmd" || $doit $chgrpcmd "$dst"; } && { test "$obsolete_mkdir_used$chowncmd$chgrpcmd" = false || test -z "$chmodcmd" || $doit $chmodcmd $mode "$dst"; } || exit 1 else # Make a couple of temp file names in the proper directory. dsttmp=$dstdir/_inst.$$_ rmtmp=$dstdir/_rm.$$_ # Trap to clean up those temp files at exit. trap 'ret=$?; rm -f "$dsttmp" "$rmtmp" && exit $ret' 0 # Copy the file name to the temp name. (umask $cp_umask && $doit_exec $cpprog "$src" "$dsttmp") && # and set any options; do chmod last to preserve setuid bits. # # If any of these fail, we abort the whole thing. If we want to # ignore errors from any of these, just make sure not to ignore # errors from the above "$doit $cpprog $src $dsttmp" command. # { test -z "$chowncmd" || $doit $chowncmd "$dsttmp"; } && { test -z "$chgrpcmd" || $doit $chgrpcmd "$dsttmp"; } && { test -z "$stripcmd" || $doit $stripcmd "$dsttmp"; } && { test -z "$chmodcmd" || $doit $chmodcmd $mode "$dsttmp"; } && # If -C, don't bother to copy if it wouldn't change the file. if $copy_on_change && old=`LC_ALL=C ls -dlL "$dst" 2>/dev/null` && new=`LC_ALL=C ls -dlL "$dsttmp" 2>/dev/null` && set -f && set X $old && old=:$2:$4:$5:$6 && set X $new && new=:$2:$4:$5:$6 && set +f && test "$old" = "$new" && $cmpprog "$dst" "$dsttmp" >/dev/null 2>&1 then rm -f "$dsttmp" else # Rename the file to the real destination. $doit $mvcmd -f "$dsttmp" "$dst" 2>/dev/null || # The rename failed, perhaps because mv can't rename something else # to itself, or perhaps because mv is so ancient that it does not # support -f. { # Now remove or move aside any old file at destination location. # We try this two ways since rm can't unlink itself on some # systems and the destination file might be busy for other # reasons. In this case, the final cleanup might fail but the new # file should still install successfully. { test ! -f "$dst" || $doit $rmcmd -f "$dst" 2>/dev/null || { $doit $mvcmd -f "$dst" "$rmtmp" 2>/dev/null && { $doit $rmcmd -f "$rmtmp" 2>/dev/null; :; } } || { echo "$0: cannot unlink or rename $dst" >&2 (exit 1); exit 1 } } && # Now rename the file to the real destination. $doit $mvcmd "$dsttmp" "$dst" } fi || exit 1 trap '' 0 fi done # Local variables: # eval: (add-hook 'write-file-hooks 'time-stamp) # time-stamp-start: "scriptversion=" # time-stamp-format: "%:y-%02m-%02d.%02H" # time-stamp-time-zone: "UTC0" # time-stamp-end: "; # UTC" # End: xrdp-0.9.5/file-loc.txt000644 001751 001751 00000001756 13133557325 014675 0ustar00metameta000000 000000 default build will install the following /usr/local/lib/xrdp libcommon.so libmc.so libscp.so libvnc.so libxrdp.so libxrdpapi.so libxup.so /usr/local/bin xrdp-dis xrdp-genkeymap xrdp-keygen xrdp-sesadmin xrdp-sesrun /usr/local/sbin xrdp xrdp-sesman xrdp-sessvc xrdp-chansrv /etc/xrdp km-xxxxxxxx.ini sesman.ini rsakeys.ini startwm.sh xrdp.ini xrdp_keyboard.ini xrdp.sh /etc/xrdp/pulse default.pa /etc/pam.d xrdp-sesman /usr/local/share/man/man1 xrdp-dis.1 /usr/local/share/man/man5 sesman.ini.5 xrdp.ini.5 /usr/local/share/man/man8 xrdp-chansrv.8 xrdp-genkeymap.8 xrdp-keygen.8 xrdp-sesadmin.8 xrdp-sesman.8 xrdp-sesrun.8 xrdp-sessvc.8 xrdp.8 /usr/local/share/xrdp ad24b.bmp ad256.bmp cursor0.cur cursor1.cur sans-10.fv1 xrdp24b.bmp xrdp256.bmp xrdp_logo.bmp when running, the following are created and written to /var/run xrdp.pid sesman.pid /var/log xrdp.log xrdp-sesman.log /tmp/.xrdp xrdp* xrdp-0.9.5/Makefile.am000644 001751 001751 00000001624 13177733764 014503 0ustar00metameta000000 000000 ACLOCAL_AMFLAGS = -I m4 AM_DISTCHECK_CONFIGURE_FLAGS = \ --without-systemdsystemunitdir \ --enable-strict-locations EXTRA_DIST = \ COPYING \ README.md \ NEWS.md \ astyle_config.as \ bootstrap \ coding_style.md \ description-pak \ design.txt \ faq-compile.txt \ faq-general.txt \ file-loc.txt \ fontdump \ install.txt \ m4 \ postinstall-pak \ tcutils \ tests \ vrplayer \ xorg if XRDP_NEUTRINORDP NEUTRINORDPDIR = neutrinordp else NEUTRINORDPDIR = endif if XRDP_XRDPVR XRDPVRDIR = xrdpvr else XRDPVRDIR = endif if XRDP_PAINTER PAINTERDIR = libpainter else PAINTERDIR = endif if XRDP_RFXCODEC RFXCODECDIR = librfxcodec else RFXCODECDIR = endif SUBDIRS = \ common \ vnc \ xup \ mc \ $(NEUTRINORDPDIR) \ libxrdp \ $(PAINTERDIR) \ $(RFXCODECDIR) \ xrdp \ sesman \ keygen \ docs \ instfiles \ genkeymap \ xrdpapi \ pkgconfig \ $(XRDPVRDIR) xrdp-0.9.5/xorg/000755 001751 001751 00000000000 13127114621 013377 5ustar00metameta000000 000000 xrdp-0.9.5/aclocal.m4000644 001751 001751 00000123146 13220730771 014273 0ustar00metameta000000 000000 # generated automatically by aclocal 1.15.1 -*- Autoconf -*- # Copyright (C) 1996-2017 Free Software Foundation, Inc. # This file is free software; the Free Software Foundation # gives unlimited permission to copy and/or distribute it, # with or without modifications, as long as this notice is preserved. # This program is distributed in the hope that it will be useful, # but WITHOUT ANY WARRANTY, to the extent permitted by law; without # even the implied warranty of MERCHANTABILITY or FITNESS FOR A # PARTICULAR PURPOSE. m4_ifndef([AC_CONFIG_MACRO_DIRS], [m4_defun([_AM_CONFIG_MACRO_DIRS], [])m4_defun([AC_CONFIG_MACRO_DIRS], [_AM_CONFIG_MACRO_DIRS($@)])]) m4_ifndef([AC_AUTOCONF_VERSION], [m4_copy([m4_PACKAGE_VERSION], [AC_AUTOCONF_VERSION])])dnl m4_if(m4_defn([AC_AUTOCONF_VERSION]), [2.69],, [m4_warning([this file was generated for autoconf 2.69. You have another version of autoconf. It may work, but is not guaranteed to. If you have problems, you may need to regenerate the build system entirely. To do so, use the procedure documented by the package, typically 'autoreconf'.])]) # Copyright (C) 2002-2017 Free Software Foundation, Inc. # # This file is free software; the Free Software Foundation # gives unlimited permission to copy and/or distribute it, # with or without modifications, as long as this notice is preserved. # AM_AUTOMAKE_VERSION(VERSION) # ---------------------------- # Automake X.Y traces this macro to ensure aclocal.m4 has been # generated from the m4 files accompanying Automake X.Y. # (This private macro should not be called outside this file.) AC_DEFUN([AM_AUTOMAKE_VERSION], [am__api_version='1.15' dnl Some users find AM_AUTOMAKE_VERSION and mistake it for a way to dnl require some minimum version. Point them to the right macro. m4_if([$1], [1.15.1], [], [AC_FATAL([Do not call $0, use AM_INIT_AUTOMAKE([$1]).])])dnl ]) # _AM_AUTOCONF_VERSION(VERSION) # ----------------------------- # aclocal traces this macro to find the Autoconf version. # This is a private macro too. Using m4_define simplifies # the logic in aclocal, which can simply ignore this definition. m4_define([_AM_AUTOCONF_VERSION], []) # AM_SET_CURRENT_AUTOMAKE_VERSION # ------------------------------- # Call AM_AUTOMAKE_VERSION and AM_AUTOMAKE_VERSION so they can be traced. # This function is AC_REQUIREd by AM_INIT_AUTOMAKE. AC_DEFUN([AM_SET_CURRENT_AUTOMAKE_VERSION], [AM_AUTOMAKE_VERSION([1.15.1])dnl m4_ifndef([AC_AUTOCONF_VERSION], [m4_copy([m4_PACKAGE_VERSION], [AC_AUTOCONF_VERSION])])dnl _AM_AUTOCONF_VERSION(m4_defn([AC_AUTOCONF_VERSION]))]) # AM_AUX_DIR_EXPAND -*- Autoconf -*- # Copyright (C) 2001-2017 Free Software Foundation, Inc. # # This file is free software; the Free Software Foundation # gives unlimited permission to copy and/or distribute it, # with or without modifications, as long as this notice is preserved. # For projects using AC_CONFIG_AUX_DIR([foo]), Autoconf sets # $ac_aux_dir to '$srcdir/foo'. In other projects, it is set to # '$srcdir', '$srcdir/..', or '$srcdir/../..'. # # Of course, Automake must honor this variable whenever it calls a # tool from the auxiliary directory. The problem is that $srcdir (and # therefore $ac_aux_dir as well) can be either absolute or relative, # depending on how configure is run. This is pretty annoying, since # it makes $ac_aux_dir quite unusable in subdirectories: in the top # source directory, any form will work fine, but in subdirectories a # relative path needs to be adjusted first. # # $ac_aux_dir/missing # fails when called from a subdirectory if $ac_aux_dir is relative # $top_srcdir/$ac_aux_dir/missing # fails if $ac_aux_dir is absolute, # fails when called from a subdirectory in a VPATH build with # a relative $ac_aux_dir # # The reason of the latter failure is that $top_srcdir and $ac_aux_dir # are both prefixed by $srcdir. In an in-source build this is usually # harmless because $srcdir is '.', but things will broke when you # start a VPATH build or use an absolute $srcdir. # # So we could use something similar to $top_srcdir/$ac_aux_dir/missing, # iff we strip the leading $srcdir from $ac_aux_dir. That would be: # am_aux_dir='\$(top_srcdir)/'`expr "$ac_aux_dir" : "$srcdir//*\(.*\)"` # and then we would define $MISSING as # MISSING="\${SHELL} $am_aux_dir/missing" # This will work as long as MISSING is not called from configure, because # unfortunately $(top_srcdir) has no meaning in configure. # However there are other variables, like CC, which are often used in # configure, and could therefore not use this "fixed" $ac_aux_dir. # # Another solution, used here, is to always expand $ac_aux_dir to an # absolute PATH. The drawback is that using absolute paths prevent a # configured tree to be moved without reconfiguration. AC_DEFUN([AM_AUX_DIR_EXPAND], [AC_REQUIRE([AC_CONFIG_AUX_DIR_DEFAULT])dnl # Expand $ac_aux_dir to an absolute path. am_aux_dir=`cd "$ac_aux_dir" && pwd` ]) # AM_CONDITIONAL -*- Autoconf -*- # Copyright (C) 1997-2017 Free Software Foundation, Inc. # # This file is free software; the Free Software Foundation # gives unlimited permission to copy and/or distribute it, # with or without modifications, as long as this notice is preserved. # AM_CONDITIONAL(NAME, SHELL-CONDITION) # ------------------------------------- # Define a conditional. AC_DEFUN([AM_CONDITIONAL], [AC_PREREQ([2.52])dnl m4_if([$1], [TRUE], [AC_FATAL([$0: invalid condition: $1])], [$1], [FALSE], [AC_FATAL([$0: invalid condition: $1])])dnl AC_SUBST([$1_TRUE])dnl AC_SUBST([$1_FALSE])dnl _AM_SUBST_NOTMAKE([$1_TRUE])dnl _AM_SUBST_NOTMAKE([$1_FALSE])dnl m4_define([_AM_COND_VALUE_$1], [$2])dnl if $2; then $1_TRUE= $1_FALSE='#' else $1_TRUE='#' $1_FALSE= fi AC_CONFIG_COMMANDS_PRE( [if test -z "${$1_TRUE}" && test -z "${$1_FALSE}"; then AC_MSG_ERROR([[conditional "$1" was never defined. Usually this means the macro was only invoked conditionally.]]) fi])]) # Copyright (C) 1999-2017 Free Software Foundation, Inc. # # This file is free software; the Free Software Foundation # gives unlimited permission to copy and/or distribute it, # with or without modifications, as long as this notice is preserved. # There are a few dirty hacks below to avoid letting 'AC_PROG_CC' be # written in clear, in which case automake, when reading aclocal.m4, # will think it sees a *use*, and therefore will trigger all it's # C support machinery. Also note that it means that autoscan, seeing # CC etc. in the Makefile, will ask for an AC_PROG_CC use... # _AM_DEPENDENCIES(NAME) # ---------------------- # See how the compiler implements dependency checking. # NAME is "CC", "CXX", "OBJC", "OBJCXX", "UPC", or "GJC". # We try a few techniques and use that to set a single cache variable. # # We don't AC_REQUIRE the corresponding AC_PROG_CC since the latter was # modified to invoke _AM_DEPENDENCIES(CC); we would have a circular # dependency, and given that the user is not expected to run this macro, # just rely on AC_PROG_CC. AC_DEFUN([_AM_DEPENDENCIES], [AC_REQUIRE([AM_SET_DEPDIR])dnl AC_REQUIRE([AM_OUTPUT_DEPENDENCY_COMMANDS])dnl AC_REQUIRE([AM_MAKE_INCLUDE])dnl AC_REQUIRE([AM_DEP_TRACK])dnl m4_if([$1], [CC], [depcc="$CC" am_compiler_list=], [$1], [CXX], [depcc="$CXX" am_compiler_list=], [$1], [OBJC], [depcc="$OBJC" am_compiler_list='gcc3 gcc'], [$1], [OBJCXX], [depcc="$OBJCXX" am_compiler_list='gcc3 gcc'], [$1], [UPC], [depcc="$UPC" am_compiler_list=], [$1], [GCJ], [depcc="$GCJ" am_compiler_list='gcc3 gcc'], [depcc="$$1" am_compiler_list=]) AC_CACHE_CHECK([dependency style of $depcc], [am_cv_$1_dependencies_compiler_type], [if test -z "$AMDEP_TRUE" && test -f "$am_depcomp"; then # We make a subdir and do the tests there. Otherwise we can end up # making bogus files that we don't know about and never remove. For # instance it was reported that on HP-UX the gcc test will end up # making a dummy file named 'D' -- because '-MD' means "put the output # in D". rm -rf conftest.dir mkdir conftest.dir # Copy depcomp to subdir because otherwise we won't find it if we're # using a relative directory. cp "$am_depcomp" conftest.dir cd conftest.dir # We will build objects and dependencies in a subdirectory because # it helps to detect inapplicable dependency modes. For instance # both Tru64's cc and ICC support -MD to output dependencies as a # side effect of compilation, but ICC will put the dependencies in # the current directory while Tru64 will put them in the object # directory. mkdir sub am_cv_$1_dependencies_compiler_type=none if test "$am_compiler_list" = ""; then am_compiler_list=`sed -n ['s/^#*\([a-zA-Z0-9]*\))$/\1/p'] < ./depcomp` fi am__universal=false m4_case([$1], [CC], [case " $depcc " in #( *\ -arch\ *\ -arch\ *) am__universal=true ;; esac], [CXX], [case " $depcc " in #( *\ -arch\ *\ -arch\ *) am__universal=true ;; esac]) for depmode in $am_compiler_list; do # Setup a source with many dependencies, because some compilers # like to wrap large dependency lists on column 80 (with \), and # we should not choose a depcomp mode which is confused by this. # # We need to recreate these files for each test, as the compiler may # overwrite some of them when testing with obscure command lines. # This happens at least with the AIX C compiler. : > sub/conftest.c for i in 1 2 3 4 5 6; do echo '#include "conftst'$i'.h"' >> sub/conftest.c # Using ": > sub/conftst$i.h" creates only sub/conftst1.h with # Solaris 10 /bin/sh. echo '/* dummy */' > sub/conftst$i.h done echo "${am__include} ${am__quote}sub/conftest.Po${am__quote}" > confmf # We check with '-c' and '-o' for the sake of the "dashmstdout" # mode. It turns out that the SunPro C++ compiler does not properly # handle '-M -o', and we need to detect this. Also, some Intel # versions had trouble with output in subdirs. am__obj=sub/conftest.${OBJEXT-o} am__minus_obj="-o $am__obj" case $depmode in gcc) # This depmode causes a compiler race in universal mode. test "$am__universal" = false || continue ;; nosideeffect) # After this tag, mechanisms are not by side-effect, so they'll # only be used when explicitly requested. if test "x$enable_dependency_tracking" = xyes; then continue else break fi ;; msvc7 | msvc7msys | msvisualcpp | msvcmsys) # This compiler won't grok '-c -o', but also, the minuso test has # not run yet. These depmodes are late enough in the game, and # so weak that their functioning should not be impacted. am__obj=conftest.${OBJEXT-o} am__minus_obj= ;; none) break ;; esac if depmode=$depmode \ source=sub/conftest.c object=$am__obj \ depfile=sub/conftest.Po tmpdepfile=sub/conftest.TPo \ $SHELL ./depcomp $depcc -c $am__minus_obj sub/conftest.c \ >/dev/null 2>conftest.err && grep sub/conftst1.h sub/conftest.Po > /dev/null 2>&1 && grep sub/conftst6.h sub/conftest.Po > /dev/null 2>&1 && grep $am__obj sub/conftest.Po > /dev/null 2>&1 && ${MAKE-make} -s -f confmf > /dev/null 2>&1; then # icc doesn't choke on unknown options, it will just issue warnings # or remarks (even with -Werror). So we grep stderr for any message # that says an option was ignored or not supported. # When given -MP, icc 7.0 and 7.1 complain thusly: # icc: Command line warning: ignoring option '-M'; no argument required # The diagnosis changed in icc 8.0: # icc: Command line remark: option '-MP' not supported if (grep 'ignoring option' conftest.err || grep 'not supported' conftest.err) >/dev/null 2>&1; then :; else am_cv_$1_dependencies_compiler_type=$depmode break fi fi done cd .. rm -rf conftest.dir else am_cv_$1_dependencies_compiler_type=none fi ]) AC_SUBST([$1DEPMODE], [depmode=$am_cv_$1_dependencies_compiler_type]) AM_CONDITIONAL([am__fastdep$1], [ test "x$enable_dependency_tracking" != xno \ && test "$am_cv_$1_dependencies_compiler_type" = gcc3]) ]) # AM_SET_DEPDIR # ------------- # Choose a directory name for dependency files. # This macro is AC_REQUIREd in _AM_DEPENDENCIES. AC_DEFUN([AM_SET_DEPDIR], [AC_REQUIRE([AM_SET_LEADING_DOT])dnl AC_SUBST([DEPDIR], ["${am__leading_dot}deps"])dnl ]) # AM_DEP_TRACK # ------------ AC_DEFUN([AM_DEP_TRACK], [AC_ARG_ENABLE([dependency-tracking], [dnl AS_HELP_STRING( [--enable-dependency-tracking], [do not reject slow dependency extractors]) AS_HELP_STRING( [--disable-dependency-tracking], [speeds up one-time build])]) if test "x$enable_dependency_tracking" != xno; then am_depcomp="$ac_aux_dir/depcomp" AMDEPBACKSLASH='\' am__nodep='_no' fi AM_CONDITIONAL([AMDEP], [test "x$enable_dependency_tracking" != xno]) AC_SUBST([AMDEPBACKSLASH])dnl _AM_SUBST_NOTMAKE([AMDEPBACKSLASH])dnl AC_SUBST([am__nodep])dnl _AM_SUBST_NOTMAKE([am__nodep])dnl ]) # Generate code to set up dependency tracking. -*- Autoconf -*- # Copyright (C) 1999-2017 Free Software Foundation, Inc. # # This file is free software; the Free Software Foundation # gives unlimited permission to copy and/or distribute it, # with or without modifications, as long as this notice is preserved. # _AM_OUTPUT_DEPENDENCY_COMMANDS # ------------------------------ AC_DEFUN([_AM_OUTPUT_DEPENDENCY_COMMANDS], [{ # Older Autoconf quotes --file arguments for eval, but not when files # are listed without --file. Let's play safe and only enable the eval # if we detect the quoting. case $CONFIG_FILES in *\'*) eval set x "$CONFIG_FILES" ;; *) set x $CONFIG_FILES ;; esac shift for mf do # Strip MF so we end up with the name of the file. mf=`echo "$mf" | sed -e 's/:.*$//'` # Check whether this is an Automake generated Makefile or not. # We used to match only the files named 'Makefile.in', but # some people rename them; so instead we look at the file content. # Grep'ing the first line is not enough: some people post-process # each Makefile.in and add a new line on top of each file to say so. # Grep'ing the whole file is not good either: AIX grep has a line # limit of 2048, but all sed's we know have understand at least 4000. if sed -n 's,^#.*generated by automake.*,X,p' "$mf" | grep X >/dev/null 2>&1; then dirpart=`AS_DIRNAME("$mf")` else continue fi # Extract the definition of DEPDIR, am__include, and am__quote # from the Makefile without running 'make'. DEPDIR=`sed -n 's/^DEPDIR = //p' < "$mf"` test -z "$DEPDIR" && continue am__include=`sed -n 's/^am__include = //p' < "$mf"` test -z "$am__include" && continue am__quote=`sed -n 's/^am__quote = //p' < "$mf"` # Find all dependency output files, they are included files with # $(DEPDIR) in their names. We invoke sed twice because it is the # simplest approach to changing $(DEPDIR) to its actual value in the # expansion. for file in `sed -n " s/^$am__include $am__quote\(.*(DEPDIR).*\)$am__quote"'$/\1/p' <"$mf" | \ sed -e 's/\$(DEPDIR)/'"$DEPDIR"'/g'`; do # Make sure the directory exists. test -f "$dirpart/$file" && continue fdir=`AS_DIRNAME(["$file"])` AS_MKDIR_P([$dirpart/$fdir]) # echo "creating $dirpart/$file" echo '# dummy' > "$dirpart/$file" done done } ])# _AM_OUTPUT_DEPENDENCY_COMMANDS # AM_OUTPUT_DEPENDENCY_COMMANDS # ----------------------------- # This macro should only be invoked once -- use via AC_REQUIRE. # # This code is only required when automatic dependency tracking # is enabled. FIXME. This creates each '.P' file that we will # need in order to bootstrap the dependency handling code. AC_DEFUN([AM_OUTPUT_DEPENDENCY_COMMANDS], [AC_CONFIG_COMMANDS([depfiles], [test x"$AMDEP_TRUE" != x"" || _AM_OUTPUT_DEPENDENCY_COMMANDS], [AMDEP_TRUE="$AMDEP_TRUE" ac_aux_dir="$ac_aux_dir"]) ]) # Do all the work for Automake. -*- Autoconf -*- # Copyright (C) 1996-2017 Free Software Foundation, Inc. # # This file is free software; the Free Software Foundation # gives unlimited permission to copy and/or distribute it, # with or without modifications, as long as this notice is preserved. # This macro actually does too much. Some checks are only needed if # your package does certain things. But this isn't really a big deal. dnl Redefine AC_PROG_CC to automatically invoke _AM_PROG_CC_C_O. m4_define([AC_PROG_CC], m4_defn([AC_PROG_CC]) [_AM_PROG_CC_C_O ]) # AM_INIT_AUTOMAKE(PACKAGE, VERSION, [NO-DEFINE]) # AM_INIT_AUTOMAKE([OPTIONS]) # ----------------------------------------------- # The call with PACKAGE and VERSION arguments is the old style # call (pre autoconf-2.50), which is being phased out. PACKAGE # and VERSION should now be passed to AC_INIT and removed from # the call to AM_INIT_AUTOMAKE. # We support both call styles for the transition. After # the next Automake release, Autoconf can make the AC_INIT # arguments mandatory, and then we can depend on a new Autoconf # release and drop the old call support. AC_DEFUN([AM_INIT_AUTOMAKE], [AC_PREREQ([2.65])dnl dnl Autoconf wants to disallow AM_ names. We explicitly allow dnl the ones we care about. m4_pattern_allow([^AM_[A-Z]+FLAGS$])dnl AC_REQUIRE([AM_SET_CURRENT_AUTOMAKE_VERSION])dnl AC_REQUIRE([AC_PROG_INSTALL])dnl if test "`cd $srcdir && pwd`" != "`pwd`"; then # Use -I$(srcdir) only when $(srcdir) != ., so that make's output # is not polluted with repeated "-I." AC_SUBST([am__isrc], [' -I$(srcdir)'])_AM_SUBST_NOTMAKE([am__isrc])dnl # test to see if srcdir already configured if test -f $srcdir/config.status; then AC_MSG_ERROR([source directory already configured; run "make distclean" there first]) fi fi # test whether we have cygpath if test -z "$CYGPATH_W"; then if (cygpath --version) >/dev/null 2>/dev/null; then CYGPATH_W='cygpath -w' else CYGPATH_W=echo fi fi AC_SUBST([CYGPATH_W]) # Define the identity of the package. dnl Distinguish between old-style and new-style calls. m4_ifval([$2], [AC_DIAGNOSE([obsolete], [$0: two- and three-arguments forms are deprecated.]) m4_ifval([$3], [_AM_SET_OPTION([no-define])])dnl AC_SUBST([PACKAGE], [$1])dnl AC_SUBST([VERSION], [$2])], [_AM_SET_OPTIONS([$1])dnl dnl Diagnose old-style AC_INIT with new-style AM_AUTOMAKE_INIT. m4_if( m4_ifdef([AC_PACKAGE_NAME], [ok]):m4_ifdef([AC_PACKAGE_VERSION], [ok]), [ok:ok],, [m4_fatal([AC_INIT should be called with package and version arguments])])dnl AC_SUBST([PACKAGE], ['AC_PACKAGE_TARNAME'])dnl AC_SUBST([VERSION], ['AC_PACKAGE_VERSION'])])dnl _AM_IF_OPTION([no-define],, [AC_DEFINE_UNQUOTED([PACKAGE], ["$PACKAGE"], [Name of package]) AC_DEFINE_UNQUOTED([VERSION], ["$VERSION"], [Version number of package])])dnl # Some tools Automake needs. AC_REQUIRE([AM_SANITY_CHECK])dnl AC_REQUIRE([AC_ARG_PROGRAM])dnl AM_MISSING_PROG([ACLOCAL], [aclocal-${am__api_version}]) AM_MISSING_PROG([AUTOCONF], [autoconf]) AM_MISSING_PROG([AUTOMAKE], [automake-${am__api_version}]) AM_MISSING_PROG([AUTOHEADER], [autoheader]) AM_MISSING_PROG([MAKEINFO], [makeinfo]) AC_REQUIRE([AM_PROG_INSTALL_SH])dnl AC_REQUIRE([AM_PROG_INSTALL_STRIP])dnl AC_REQUIRE([AC_PROG_MKDIR_P])dnl # For better backward compatibility. To be removed once Automake 1.9.x # dies out for good. For more background, see: # # AC_SUBST([mkdir_p], ['$(MKDIR_P)']) # We need awk for the "check" target (and possibly the TAP driver). The # system "awk" is bad on some platforms. AC_REQUIRE([AC_PROG_AWK])dnl AC_REQUIRE([AC_PROG_MAKE_SET])dnl AC_REQUIRE([AM_SET_LEADING_DOT])dnl _AM_IF_OPTION([tar-ustar], [_AM_PROG_TAR([ustar])], [_AM_IF_OPTION([tar-pax], [_AM_PROG_TAR([pax])], [_AM_PROG_TAR([v7])])]) _AM_IF_OPTION([no-dependencies],, [AC_PROVIDE_IFELSE([AC_PROG_CC], [_AM_DEPENDENCIES([CC])], [m4_define([AC_PROG_CC], m4_defn([AC_PROG_CC])[_AM_DEPENDENCIES([CC])])])dnl AC_PROVIDE_IFELSE([AC_PROG_CXX], [_AM_DEPENDENCIES([CXX])], [m4_define([AC_PROG_CXX], m4_defn([AC_PROG_CXX])[_AM_DEPENDENCIES([CXX])])])dnl AC_PROVIDE_IFELSE([AC_PROG_OBJC], [_AM_DEPENDENCIES([OBJC])], [m4_define([AC_PROG_OBJC], m4_defn([AC_PROG_OBJC])[_AM_DEPENDENCIES([OBJC])])])dnl AC_PROVIDE_IFELSE([AC_PROG_OBJCXX], [_AM_DEPENDENCIES([OBJCXX])], [m4_define([AC_PROG_OBJCXX], m4_defn([AC_PROG_OBJCXX])[_AM_DEPENDENCIES([OBJCXX])])])dnl ]) AC_REQUIRE([AM_SILENT_RULES])dnl dnl The testsuite driver may need to know about EXEEXT, so add the dnl 'am__EXEEXT' conditional if _AM_COMPILER_EXEEXT was seen. This dnl macro is hooked onto _AC_COMPILER_EXEEXT early, see below. AC_CONFIG_COMMANDS_PRE(dnl [m4_provide_if([_AM_COMPILER_EXEEXT], [AM_CONDITIONAL([am__EXEEXT], [test -n "$EXEEXT"])])])dnl # POSIX will say in a future version that running "rm -f" with no argument # is OK; and we want to be able to make that assumption in our Makefile # recipes. So use an aggressive probe to check that the usage we want is # actually supported "in the wild" to an acceptable degree. # See automake bug#10828. # To make any issue more visible, cause the running configure to be aborted # by default if the 'rm' program in use doesn't match our expectations; the # user can still override this though. if rm -f && rm -fr && rm -rf; then : OK; else cat >&2 <<'END' Oops! Your 'rm' program seems unable to run without file operands specified on the command line, even when the '-f' option is present. This is contrary to the behaviour of most rm programs out there, and not conforming with the upcoming POSIX standard: Please tell bug-automake@gnu.org about your system, including the value of your $PATH and any error possibly output before this message. This can help us improve future automake versions. END if test x"$ACCEPT_INFERIOR_RM_PROGRAM" = x"yes"; then echo 'Configuration will proceed anyway, since you have set the' >&2 echo 'ACCEPT_INFERIOR_RM_PROGRAM variable to "yes"' >&2 echo >&2 else cat >&2 <<'END' Aborting the configuration process, to ensure you take notice of the issue. You can download and install GNU coreutils to get an 'rm' implementation that behaves properly: . If you want to complete the configuration process using your problematic 'rm' anyway, export the environment variable ACCEPT_INFERIOR_RM_PROGRAM to "yes", and re-run configure. END AC_MSG_ERROR([Your 'rm' program is bad, sorry.]) fi fi dnl The trailing newline in this macro's definition is deliberate, for dnl backward compatibility and to allow trailing 'dnl'-style comments dnl after the AM_INIT_AUTOMAKE invocation. See automake bug#16841. ]) dnl Hook into '_AC_COMPILER_EXEEXT' early to learn its expansion. Do not dnl add the conditional right here, as _AC_COMPILER_EXEEXT may be further dnl mangled by Autoconf and run in a shell conditional statement. m4_define([_AC_COMPILER_EXEEXT], m4_defn([_AC_COMPILER_EXEEXT])[m4_provide([_AM_COMPILER_EXEEXT])]) # When config.status generates a header, we must update the stamp-h file. # This file resides in the same directory as the config header # that is generated. The stamp files are numbered to have different names. # Autoconf calls _AC_AM_CONFIG_HEADER_HOOK (when defined) in the # loop where config.status creates the headers, so we can generate # our stamp files there. AC_DEFUN([_AC_AM_CONFIG_HEADER_HOOK], [# Compute $1's index in $config_headers. _am_arg=$1 _am_stamp_count=1 for _am_header in $config_headers :; do case $_am_header in $_am_arg | $_am_arg:* ) break ;; * ) _am_stamp_count=`expr $_am_stamp_count + 1` ;; esac done echo "timestamp for $_am_arg" >`AS_DIRNAME(["$_am_arg"])`/stamp-h[]$_am_stamp_count]) # Copyright (C) 2001-2017 Free Software Foundation, Inc. # # This file is free software; the Free Software Foundation # gives unlimited permission to copy and/or distribute it, # with or without modifications, as long as this notice is preserved. # AM_PROG_INSTALL_SH # ------------------ # Define $install_sh. AC_DEFUN([AM_PROG_INSTALL_SH], [AC_REQUIRE([AM_AUX_DIR_EXPAND])dnl if test x"${install_sh+set}" != xset; then case $am_aux_dir in *\ * | *\ *) install_sh="\${SHELL} '$am_aux_dir/install-sh'" ;; *) install_sh="\${SHELL} $am_aux_dir/install-sh" esac fi AC_SUBST([install_sh])]) # Copyright (C) 2003-2017 Free Software Foundation, Inc. # # This file is free software; the Free Software Foundation # gives unlimited permission to copy and/or distribute it, # with or without modifications, as long as this notice is preserved. # Check whether the underlying file-system supports filenames # with a leading dot. For instance MS-DOS doesn't. AC_DEFUN([AM_SET_LEADING_DOT], [rm -rf .tst 2>/dev/null mkdir .tst 2>/dev/null if test -d .tst; then am__leading_dot=. else am__leading_dot=_ fi rmdir .tst 2>/dev/null AC_SUBST([am__leading_dot])]) # Check to see how 'make' treats includes. -*- Autoconf -*- # Copyright (C) 2001-2017 Free Software Foundation, Inc. # # This file is free software; the Free Software Foundation # gives unlimited permission to copy and/or distribute it, # with or without modifications, as long as this notice is preserved. # AM_MAKE_INCLUDE() # ----------------- # Check to see how make treats includes. AC_DEFUN([AM_MAKE_INCLUDE], [am_make=${MAKE-make} cat > confinc << 'END' am__doit: @echo this is the am__doit target .PHONY: am__doit END # If we don't find an include directive, just comment out the code. AC_MSG_CHECKING([for style of include used by $am_make]) am__include="#" am__quote= _am_result=none # First try GNU make style include. echo "include confinc" > confmf # Ignore all kinds of additional output from 'make'. case `$am_make -s -f confmf 2> /dev/null` in #( *the\ am__doit\ target*) am__include=include am__quote= _am_result=GNU ;; esac # Now try BSD make style include. if test "$am__include" = "#"; then echo '.include "confinc"' > confmf case `$am_make -s -f confmf 2> /dev/null` in #( *the\ am__doit\ target*) am__include=.include am__quote="\"" _am_result=BSD ;; esac fi AC_SUBST([am__include]) AC_SUBST([am__quote]) AC_MSG_RESULT([$_am_result]) rm -f confinc confmf ]) # Fake the existence of programs that GNU maintainers use. -*- Autoconf -*- # Copyright (C) 1997-2017 Free Software Foundation, Inc. # # This file is free software; the Free Software Foundation # gives unlimited permission to copy and/or distribute it, # with or without modifications, as long as this notice is preserved. # AM_MISSING_PROG(NAME, PROGRAM) # ------------------------------ AC_DEFUN([AM_MISSING_PROG], [AC_REQUIRE([AM_MISSING_HAS_RUN]) $1=${$1-"${am_missing_run}$2"} AC_SUBST($1)]) # AM_MISSING_HAS_RUN # ------------------ # Define MISSING if not defined so far and test if it is modern enough. # If it is, set am_missing_run to use it, otherwise, to nothing. AC_DEFUN([AM_MISSING_HAS_RUN], [AC_REQUIRE([AM_AUX_DIR_EXPAND])dnl AC_REQUIRE_AUX_FILE([missing])dnl if test x"${MISSING+set}" != xset; then case $am_aux_dir in *\ * | *\ *) MISSING="\${SHELL} \"$am_aux_dir/missing\"" ;; *) MISSING="\${SHELL} $am_aux_dir/missing" ;; esac fi # Use eval to expand $SHELL if eval "$MISSING --is-lightweight"; then am_missing_run="$MISSING " else am_missing_run= AC_MSG_WARN(['missing' script is too old or missing]) fi ]) # Helper functions for option handling. -*- Autoconf -*- # Copyright (C) 2001-2017 Free Software Foundation, Inc. # # This file is free software; the Free Software Foundation # gives unlimited permission to copy and/or distribute it, # with or without modifications, as long as this notice is preserved. # _AM_MANGLE_OPTION(NAME) # ----------------------- AC_DEFUN([_AM_MANGLE_OPTION], [[_AM_OPTION_]m4_bpatsubst($1, [[^a-zA-Z0-9_]], [_])]) # _AM_SET_OPTION(NAME) # -------------------- # Set option NAME. Presently that only means defining a flag for this option. AC_DEFUN([_AM_SET_OPTION], [m4_define(_AM_MANGLE_OPTION([$1]), [1])]) # _AM_SET_OPTIONS(OPTIONS) # ------------------------ # OPTIONS is a space-separated list of Automake options. AC_DEFUN([_AM_SET_OPTIONS], [m4_foreach_w([_AM_Option], [$1], [_AM_SET_OPTION(_AM_Option)])]) # _AM_IF_OPTION(OPTION, IF-SET, [IF-NOT-SET]) # ------------------------------------------- # Execute IF-SET if OPTION is set, IF-NOT-SET otherwise. AC_DEFUN([_AM_IF_OPTION], [m4_ifset(_AM_MANGLE_OPTION([$1]), [$2], [$3])]) # Copyright (C) 1999-2017 Free Software Foundation, Inc. # # This file is free software; the Free Software Foundation # gives unlimited permission to copy and/or distribute it, # with or without modifications, as long as this notice is preserved. # _AM_PROG_CC_C_O # --------------- # Like AC_PROG_CC_C_O, but changed for automake. We rewrite AC_PROG_CC # to automatically call this. AC_DEFUN([_AM_PROG_CC_C_O], [AC_REQUIRE([AM_AUX_DIR_EXPAND])dnl AC_REQUIRE_AUX_FILE([compile])dnl AC_LANG_PUSH([C])dnl AC_CACHE_CHECK( [whether $CC understands -c and -o together], [am_cv_prog_cc_c_o], [AC_LANG_CONFTEST([AC_LANG_PROGRAM([])]) # Make sure it works both with $CC and with simple cc. # Following AC_PROG_CC_C_O, we do the test twice because some # compilers refuse to overwrite an existing .o file with -o, # though they will create one. am_cv_prog_cc_c_o=yes for am_i in 1 2; do if AM_RUN_LOG([$CC -c conftest.$ac_ext -o conftest2.$ac_objext]) \ && test -f conftest2.$ac_objext; then : OK else am_cv_prog_cc_c_o=no break fi done rm -f core conftest* unset am_i]) if test "$am_cv_prog_cc_c_o" != yes; then # Losing compiler, so override with the script. # FIXME: It is wrong to rewrite CC. # But if we don't then we get into trouble of one sort or another. # A longer-term fix would be to have automake use am__CC in this case, # and then we could set am__CC="\$(top_srcdir)/compile \$(CC)" CC="$am_aux_dir/compile $CC" fi AC_LANG_POP([C])]) # For backward compatibility. AC_DEFUN_ONCE([AM_PROG_CC_C_O], [AC_REQUIRE([AC_PROG_CC])]) # Copyright (C) 2001-2017 Free Software Foundation, Inc. # # This file is free software; the Free Software Foundation # gives unlimited permission to copy and/or distribute it, # with or without modifications, as long as this notice is preserved. # AM_RUN_LOG(COMMAND) # ------------------- # Run COMMAND, save the exit status in ac_status, and log it. # (This has been adapted from Autoconf's _AC_RUN_LOG macro.) AC_DEFUN([AM_RUN_LOG], [{ echo "$as_me:$LINENO: $1" >&AS_MESSAGE_LOG_FD ($1) >&AS_MESSAGE_LOG_FD 2>&AS_MESSAGE_LOG_FD ac_status=$? echo "$as_me:$LINENO: \$? = $ac_status" >&AS_MESSAGE_LOG_FD (exit $ac_status); }]) # Check to make sure that the build environment is sane. -*- Autoconf -*- # Copyright (C) 1996-2017 Free Software Foundation, Inc. # # This file is free software; the Free Software Foundation # gives unlimited permission to copy and/or distribute it, # with or without modifications, as long as this notice is preserved. # AM_SANITY_CHECK # --------------- AC_DEFUN([AM_SANITY_CHECK], [AC_MSG_CHECKING([whether build environment is sane]) # Reject unsafe characters in $srcdir or the absolute working directory # name. Accept space and tab only in the latter. am_lf=' ' case `pwd` in *[[\\\"\#\$\&\'\`$am_lf]]*) AC_MSG_ERROR([unsafe absolute working directory name]);; esac case $srcdir in *[[\\\"\#\$\&\'\`$am_lf\ \ ]]*) AC_MSG_ERROR([unsafe srcdir value: '$srcdir']);; esac # Do 'set' in a subshell so we don't clobber the current shell's # arguments. Must try -L first in case configure is actually a # symlink; some systems play weird games with the mod time of symlinks # (eg FreeBSD returns the mod time of the symlink's containing # directory). if ( am_has_slept=no for am_try in 1 2; do echo "timestamp, slept: $am_has_slept" > conftest.file set X `ls -Lt "$srcdir/configure" conftest.file 2> /dev/null` if test "$[*]" = "X"; then # -L didn't work. set X `ls -t "$srcdir/configure" conftest.file` fi if test "$[*]" != "X $srcdir/configure conftest.file" \ && test "$[*]" != "X conftest.file $srcdir/configure"; then # If neither matched, then we have a broken ls. This can happen # if, for instance, CONFIG_SHELL is bash and it inherits a # broken ls alias from the environment. This has actually # happened. Such a system could not be considered "sane". AC_MSG_ERROR([ls -t appears to fail. Make sure there is not a broken alias in your environment]) fi if test "$[2]" = conftest.file || test $am_try -eq 2; then break fi # Just in case. sleep 1 am_has_slept=yes done test "$[2]" = conftest.file ) then # Ok. : else AC_MSG_ERROR([newly created file is older than distributed files! Check your system clock]) fi AC_MSG_RESULT([yes]) # If we didn't sleep, we still need to ensure time stamps of config.status and # generated files are strictly newer. am_sleep_pid= if grep 'slept: no' conftest.file >/dev/null 2>&1; then ( sleep 1 ) & am_sleep_pid=$! fi AC_CONFIG_COMMANDS_PRE( [AC_MSG_CHECKING([that generated files are newer than configure]) if test -n "$am_sleep_pid"; then # Hide warnings about reused PIDs. wait $am_sleep_pid 2>/dev/null fi AC_MSG_RESULT([done])]) rm -f conftest.file ]) # Copyright (C) 2009-2017 Free Software Foundation, Inc. # # This file is free software; the Free Software Foundation # gives unlimited permission to copy and/or distribute it, # with or without modifications, as long as this notice is preserved. # AM_SILENT_RULES([DEFAULT]) # -------------------------- # Enable less verbose build rules; with the default set to DEFAULT # ("yes" being less verbose, "no" or empty being verbose). AC_DEFUN([AM_SILENT_RULES], [AC_ARG_ENABLE([silent-rules], [dnl AS_HELP_STRING( [--enable-silent-rules], [less verbose build output (undo: "make V=1")]) AS_HELP_STRING( [--disable-silent-rules], [verbose build output (undo: "make V=0")])dnl ]) case $enable_silent_rules in @%:@ ((( yes) AM_DEFAULT_VERBOSITY=0;; no) AM_DEFAULT_VERBOSITY=1;; *) AM_DEFAULT_VERBOSITY=m4_if([$1], [yes], [0], [1]);; esac dnl dnl A few 'make' implementations (e.g., NonStop OS and NextStep) dnl do not support nested variable expansions. dnl See automake bug#9928 and bug#10237. am_make=${MAKE-make} AC_CACHE_CHECK([whether $am_make supports nested variables], [am_cv_make_support_nested_variables], [if AS_ECHO([['TRUE=$(BAR$(V)) BAR0=false BAR1=true V=1 am__doit: @$(TRUE) .PHONY: am__doit']]) | $am_make -f - >/dev/null 2>&1; then am_cv_make_support_nested_variables=yes else am_cv_make_support_nested_variables=no fi]) if test $am_cv_make_support_nested_variables = yes; then dnl Using '$V' instead of '$(V)' breaks IRIX make. AM_V='$(V)' AM_DEFAULT_V='$(AM_DEFAULT_VERBOSITY)' else AM_V=$AM_DEFAULT_VERBOSITY AM_DEFAULT_V=$AM_DEFAULT_VERBOSITY fi AC_SUBST([AM_V])dnl AM_SUBST_NOTMAKE([AM_V])dnl AC_SUBST([AM_DEFAULT_V])dnl AM_SUBST_NOTMAKE([AM_DEFAULT_V])dnl AC_SUBST([AM_DEFAULT_VERBOSITY])dnl AM_BACKSLASH='\' AC_SUBST([AM_BACKSLASH])dnl _AM_SUBST_NOTMAKE([AM_BACKSLASH])dnl ]) # Copyright (C) 2001-2017 Free Software Foundation, Inc. # # This file is free software; the Free Software Foundation # gives unlimited permission to copy and/or distribute it, # with or without modifications, as long as this notice is preserved. # AM_PROG_INSTALL_STRIP # --------------------- # One issue with vendor 'install' (even GNU) is that you can't # specify the program used to strip binaries. This is especially # annoying in cross-compiling environments, where the build's strip # is unlikely to handle the host's binaries. # Fortunately install-sh will honor a STRIPPROG variable, so we # always use install-sh in "make install-strip", and initialize # STRIPPROG with the value of the STRIP variable (set by the user). AC_DEFUN([AM_PROG_INSTALL_STRIP], [AC_REQUIRE([AM_PROG_INSTALL_SH])dnl # Installed binaries are usually stripped using 'strip' when the user # run "make install-strip". However 'strip' might not be the right # tool to use in cross-compilation environments, therefore Automake # will honor the 'STRIP' environment variable to overrule this program. dnl Don't test for $cross_compiling = yes, because it might be 'maybe'. if test "$cross_compiling" != no; then AC_CHECK_TOOL([STRIP], [strip], :) fi INSTALL_STRIP_PROGRAM="\$(install_sh) -c -s" AC_SUBST([INSTALL_STRIP_PROGRAM])]) # Copyright (C) 2006-2017 Free Software Foundation, Inc. # # This file is free software; the Free Software Foundation # gives unlimited permission to copy and/or distribute it, # with or without modifications, as long as this notice is preserved. # _AM_SUBST_NOTMAKE(VARIABLE) # --------------------------- # Prevent Automake from outputting VARIABLE = @VARIABLE@ in Makefile.in. # This macro is traced by Automake. AC_DEFUN([_AM_SUBST_NOTMAKE]) # AM_SUBST_NOTMAKE(VARIABLE) # -------------------------- # Public sister of _AM_SUBST_NOTMAKE. AC_DEFUN([AM_SUBST_NOTMAKE], [_AM_SUBST_NOTMAKE($@)]) # Check how to create a tarball. -*- Autoconf -*- # Copyright (C) 2004-2017 Free Software Foundation, Inc. # # This file is free software; the Free Software Foundation # gives unlimited permission to copy and/or distribute it, # with or without modifications, as long as this notice is preserved. # _AM_PROG_TAR(FORMAT) # -------------------- # Check how to create a tarball in format FORMAT. # FORMAT should be one of 'v7', 'ustar', or 'pax'. # # Substitute a variable $(am__tar) that is a command # writing to stdout a FORMAT-tarball containing the directory # $tardir. # tardir=directory && $(am__tar) > result.tar # # Substitute a variable $(am__untar) that extract such # a tarball read from stdin. # $(am__untar) < result.tar # AC_DEFUN([_AM_PROG_TAR], [# Always define AMTAR for backward compatibility. Yes, it's still used # in the wild :-( We should find a proper way to deprecate it ... AC_SUBST([AMTAR], ['$${TAR-tar}']) # We'll loop over all known methods to create a tar archive until one works. _am_tools='gnutar m4_if([$1], [ustar], [plaintar]) pax cpio none' m4_if([$1], [v7], [am__tar='$${TAR-tar} chof - "$$tardir"' am__untar='$${TAR-tar} xf -'], [m4_case([$1], [ustar], [# The POSIX 1988 'ustar' format is defined with fixed-size fields. # There is notably a 21 bits limit for the UID and the GID. In fact, # the 'pax' utility can hang on bigger UID/GID (see automake bug#8343 # and bug#13588). am_max_uid=2097151 # 2^21 - 1 am_max_gid=$am_max_uid # The $UID and $GID variables are not portable, so we need to resort # to the POSIX-mandated id(1) utility. Errors in the 'id' calls # below are definitely unexpected, so allow the users to see them # (that is, avoid stderr redirection). am_uid=`id -u || echo unknown` am_gid=`id -g || echo unknown` AC_MSG_CHECKING([whether UID '$am_uid' is supported by ustar format]) if test $am_uid -le $am_max_uid; then AC_MSG_RESULT([yes]) else AC_MSG_RESULT([no]) _am_tools=none fi AC_MSG_CHECKING([whether GID '$am_gid' is supported by ustar format]) if test $am_gid -le $am_max_gid; then AC_MSG_RESULT([yes]) else AC_MSG_RESULT([no]) _am_tools=none fi], [pax], [], [m4_fatal([Unknown tar format])]) AC_MSG_CHECKING([how to create a $1 tar archive]) # Go ahead even if we have the value already cached. We do so because we # need to set the values for the 'am__tar' and 'am__untar' variables. _am_tools=${am_cv_prog_tar_$1-$_am_tools} for _am_tool in $_am_tools; do case $_am_tool in gnutar) for _am_tar in tar gnutar gtar; do AM_RUN_LOG([$_am_tar --version]) && break done am__tar="$_am_tar --format=m4_if([$1], [pax], [posix], [$1]) -chf - "'"$$tardir"' am__tar_="$_am_tar --format=m4_if([$1], [pax], [posix], [$1]) -chf - "'"$tardir"' am__untar="$_am_tar -xf -" ;; plaintar) # Must skip GNU tar: if it does not support --format= it doesn't create # ustar tarball either. (tar --version) >/dev/null 2>&1 && continue am__tar='tar chf - "$$tardir"' am__tar_='tar chf - "$tardir"' am__untar='tar xf -' ;; pax) am__tar='pax -L -x $1 -w "$$tardir"' am__tar_='pax -L -x $1 -w "$tardir"' am__untar='pax -r' ;; cpio) am__tar='find "$$tardir" -print | cpio -o -H $1 -L' am__tar_='find "$tardir" -print | cpio -o -H $1 -L' am__untar='cpio -i -H $1 -d' ;; none) am__tar=false am__tar_=false am__untar=false ;; esac # If the value was cached, stop now. We just wanted to have am__tar # and am__untar set. test -n "${am_cv_prog_tar_$1}" && break # tar/untar a dummy directory, and stop if the command works. rm -rf conftest.dir mkdir conftest.dir echo GrepMe > conftest.dir/file AM_RUN_LOG([tardir=conftest.dir && eval $am__tar_ >conftest.tar]) rm -rf conftest.dir if test -s conftest.tar; then AM_RUN_LOG([$am__untar /dev/null 2>&1 && break fi done rm -rf conftest.dir AC_CACHE_VAL([am_cv_prog_tar_$1], [am_cv_prog_tar_$1=$_am_tool]) AC_MSG_RESULT([$am_cv_prog_tar_$1])]) AC_SUBST([am__tar]) AC_SUBST([am__untar]) ]) # _AM_PROG_TAR m4_include([m4/ax_append_compile_flags.m4]) m4_include([m4/ax_append_flag.m4]) m4_include([m4/ax_cflags_warn_all.m4]) m4_include([m4/ax_check_compile_flag.m4]) m4_include([m4/ax_gcc_func_attribute.m4]) m4_include([m4/ax_require_defined.m4]) m4_include([m4/ax_type_socklen_t.m4]) m4_include([m4/libtool.m4]) m4_include([m4/ltoptions.m4]) m4_include([m4/ltsugar.m4]) m4_include([m4/ltversion.m4]) m4_include([m4/lt~obsolete.m4]) m4_include([m4/pkg.m4]) xrdp-0.9.5/sesman/000755 001751 001751 00000000000 13220731020 013676 5ustar00metameta000000 000000 xrdp-0.9.5/description-pak000644 001751 001751 00000000025 13125122133 015427 0ustar00metameta000000 000000 RDP server for Linux xrdp-0.9.5/xrdpapi/000755 001751 001751 00000000000 13220731022 014061 5ustar00metameta000000 000000 xrdp-0.9.5/README.md000644 001751 001751 00000012035 13220727405 013704 0ustar00metameta000000 000000 [![Build Status](https://travis-ci.org/neutrinolabs/xrdp.svg?branch=devel)](https://travis-ci.org/neutrinolabs/xrdp) [![Gitter](https://badges.gitter.im/Join%20Chat.svg)](https://gitter.im/neutrinolabs/xrdp) ![Apache-License](https://img.shields.io/badge/License-Apache%202.0-blue.svg) *Current Version:* 0.9.5 # xrdp - an open source RDP server ## Overview **xrdp** provides a graphical login to remote machines using Microsoft Remote Desktop Protocol (RDP). xrdp accepts connections from a variety of RDP clients: FreeRDP, rdesktop, NeutrinoRDP and Microsoft Remote Desktop Client (for Windows, Mac OS, iOS and Android). RDP transport is encrypted using TLS by default. ![demo](https://github.com/neutrinolabs/xrdp/raw/gh-pages/xrdp_demo.gif) ## Features ### Remote Desktop Access * Connect to a Linux desktop using RDP from anywhere (requires [xorgxrdp](https://github.com/neutrinolabs/xorgxrdp) Xorg module) * Reconnect to an existing session * Session resizing * RDP/VNC proxy (connect to another RDP/VNC server via xrdp) ### Access to Remote Resources * two-way clipboard transfer (text, bitmap, file) * audio redirection ([requires to build additional modules](https://github.com/neutrinolabs/xrdp/wiki/How-to-set-up-audio-redirection)) * drive redirection (mount local client drives on remote machine) ## Quick Start Most Linux distributions should distribute the latest release of xrdp in their repository. You would need xrdp and xorgxrdp packages for the best experience. It is recommended that xrdp depends on xorgxrdp, so it should be sufficient to install xrdp. If xorgxrdp is not provided, use Xvnc server. ### Ubuntu / Debian ```bash apt-get install xrdp ``` ### RedHat / CentOS / Fedora On RedHat and CentOS, make sure to enable EPEL packages first. ```bash yum install epel-release ``` Install xrdp package. ```bash yum install xrdp ``` `yum` is being replaced with `dnf`, so you may need to use `dnf` instead of `yum` in the above commands. To allow outside access to the service, open port 3389 on the firewall. ``` firewall-cmd --permanent --zone=public --add-port=3389/tcp firewall-cmd --reload ``` ## Environment **xrdp** primarily targets to GNU/Linux. Tested on x86, x86_64, SPARC and PowerPC. xorgxrdp and RemoteFX Codec have special optimization for x86 and x86_64 using SIMD instructions. FreeBSD is not a primary target of xrdp. It is working on FreeBSD except for the drive redirection feature. Other operating systems such as Mac OS are not supported so far, but we welcome your contributions. ## Compiling See also https://github.com/neutrinolabs/xrdp/wiki#building-from-sources ### Prerequisites To compile xrdp from the packaged sources, you need basic build tools - a compiler (**gcc** or **clang**) and the **make** program. Additionally, you would need **openssl-devel**, **pam-devel**, **libX11-devel**, **libXfixes-devel**, **libXrandr-devel**. More additional software would be needed depending on your configuration. To compile xrdp from a checked out git repository, you would additionally need **autoconf**, **automake**, **libtool** and **pkgconfig**. ### Get the source and build it If compiling from the packaged source, unpack the tarball and change to the resulting directory. If compiling from a checked out repository, please make sure you've got the submodules cloned too (use `git clone --recursive https://github.com/neutrinolabs/xrdp`) Then run following commands to compile and install xrdp: ```bash ./bootstrap ./configure make sudo make install ``` If you want to use audio redirection, you need to build and install additional pulseaudio modules. The build instructions can be found at wiki. * [How to set up audio redirection](https://github.com/neutrinolabs/xrdp/wiki/How-to-set-up-audio-redirection) ## Directory Structure ``` xrdp ├── common ······ common code ├── docs ········ documentation ├── fontdump ···· font dump for Windows ├── genkeymap ··· keymap generator ├── instfiles ··· installable data file ├── keygen ······ xrdp RSA key pair generator ├── libpainter ·· painter library ├── librfxcodec · RFX codec library ├── libxrdp ····· core RDP protocol implementation ├── m4 ·········· Autoconf macros ├── mc ·········· media center module ├── neutrinordp · RDP client module for proxying RDP connections using NeutrinoRDP ├── pkgconfig ··· pkg-config configuration ├── sesman ······ session manager for xrdp ├── tcutils ····· QT based utility program for thin clients ├── tests ······· tests for the code ├── vnc ········· VNC client module for xrdp ├── vrplayer ···· QT player redirecting video/audio to clients over xrdpvr channel ├── xorg ········ X11rdp, an Xorg backend for xrdp ├── xrdp ········ main server code ├── xrdpapi ····· virtual channel API ├── xrdpvr ······ API for playing media over RDP └── xup ········· X11rdp and xorgxrdp client module ``` xrdp-0.9.5/install.txt000644 001751 001751 00000002671 13127114621 014635 0ustar00metameta000000 000000 Installation directions for xrdp. Things you need to compile and install. Most systems don't have these installed by default. gcc and make Header files for pam Header files for openssl You can build sesman without pam, there is a Makefile parameter for that. I also have a replacement ssl_calls.c to avoid the openssl dependency email me(Jay) for it or see http://server1.xrdp.org/xrdp/openssl. Due to the license, I can't include it in this project. http://server1.xrdp.org/xrdp/openssl/ unpack the tarball tar -zxvf xrdp-0.1.tar.gz this will create a folder xrdp switch to the xrdp folder(cd xrdp) run make as root, run make install This will install most of the files in /usr/local/xrdp. Some files install in /etc/xrdp. These are configuration files. files and location /usr/local/xrdp/startwm.sh - script that starts the window manager You may need to edit this file to run your window manager. /etc/sesman.ini - sesman configuration file /etc/rsakeys.ini - rsa stuff /etc/xrdp.ini - xrdp configuration file /var/run/sesman.pid /var/rub/xrdp.pid Sesman and xrdp both have to be running as root. You should set them to start when the system starts. You can use xrdp_control.sh script to start them. To completely remove xrdp remove directory /usr/local/xrdp remove directory /etc/xrdp remove file /var/run/xrdp.pid remove file /var/run/sesman.pid remove any startup links added to /etc/init.d or /etc/rcX.d jay.sorg@gmail.com xrdp-0.9.5/configure000755 001751 001751 00001735526 13220730772 014357 0ustar00metameta000000 000000 #! /bin/sh # Guess values for system-dependent variables and create Makefiles. # Generated by GNU Autoconf 2.69 for xrdp 0.9.5. # # Report bugs to . # # # Copyright (C) 1992-1996, 1998-2012 Free Software Foundation, Inc. # # # This configure script is free software; the Free Software Foundation # gives unlimited permission to copy, distribute and modify it. ## -------------------- ## ## M4sh Initialization. ## ## -------------------- ## # Be more Bourne compatible DUALCASE=1; export DUALCASE # for MKS sh if test -n "${ZSH_VERSION+set}" && (emulate sh) >/dev/null 2>&1; then : emulate sh NULLCMD=: # Pre-4.2 versions of Zsh do word splitting on ${1+"$@"}, which # is contrary to our usage. Disable this feature. alias -g '${1+"$@"}'='"$@"' setopt NO_GLOB_SUBST else case `(set -o) 2>/dev/null` in #( *posix*) : set -o posix ;; #( *) : ;; esac fi as_nl=' ' export as_nl # Printing a long string crashes Solaris 7 /usr/bin/printf. as_echo='\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\' as_echo=$as_echo$as_echo$as_echo$as_echo$as_echo as_echo=$as_echo$as_echo$as_echo$as_echo$as_echo$as_echo # Prefer a ksh shell builtin over an external printf program on Solaris, # but without wasting forks for bash or zsh. if test -z "$BASH_VERSION$ZSH_VERSION" \ && (test "X`print -r -- $as_echo`" = "X$as_echo") 2>/dev/null; then as_echo='print -r --' as_echo_n='print -rn --' elif (test "X`printf %s $as_echo`" = "X$as_echo") 2>/dev/null; then as_echo='printf %s\n' as_echo_n='printf %s' else if test "X`(/usr/ucb/echo -n -n $as_echo) 2>/dev/null`" = "X-n $as_echo"; then as_echo_body='eval /usr/ucb/echo -n "$1$as_nl"' as_echo_n='/usr/ucb/echo -n' else as_echo_body='eval expr "X$1" : "X\\(.*\\)"' as_echo_n_body='eval arg=$1; case $arg in #( *"$as_nl"*) expr "X$arg" : "X\\(.*\\)$as_nl"; arg=`expr "X$arg" : ".*$as_nl\\(.*\\)"`;; esac; expr "X$arg" : "X\\(.*\\)" | tr -d "$as_nl" ' export as_echo_n_body as_echo_n='sh -c $as_echo_n_body as_echo' fi export as_echo_body as_echo='sh -c $as_echo_body as_echo' fi # The user is always right. if test "${PATH_SEPARATOR+set}" != set; then PATH_SEPARATOR=: (PATH='/bin;/bin'; FPATH=$PATH; sh -c :) >/dev/null 2>&1 && { (PATH='/bin:/bin'; FPATH=$PATH; sh -c :) >/dev/null 2>&1 || PATH_SEPARATOR=';' } fi # IFS # We need space, tab and new line, in precisely that order. Quoting is # there to prevent editors from complaining about space-tab. # (If _AS_PATH_WALK were called with IFS unset, it would disable word # splitting by setting IFS to empty value.) IFS=" "" $as_nl" # Find who we are. Look in the path if we contain no directory separator. as_myself= case $0 in #(( *[\\/]* ) as_myself=$0 ;; *) as_save_IFS=$IFS; IFS=$PATH_SEPARATOR for as_dir in $PATH do IFS=$as_save_IFS test -z "$as_dir" && as_dir=. test -r "$as_dir/$0" && as_myself=$as_dir/$0 && break done IFS=$as_save_IFS ;; esac # We did not find ourselves, most probably we were run as `sh COMMAND' # in which case we are not to be found in the path. if test "x$as_myself" = x; then as_myself=$0 fi if test ! -f "$as_myself"; then $as_echo "$as_myself: error: cannot find myself; rerun with an absolute file name" >&2 exit 1 fi # Unset variables that we do not need and which cause bugs (e.g. in # pre-3.0 UWIN ksh). But do not cause bugs in bash 2.01; the "|| exit 1" # suppresses any "Segmentation fault" message there. '((' could # trigger a bug in pdksh 5.2.14. for as_var in BASH_ENV ENV MAIL MAILPATH do eval test x\${$as_var+set} = xset \ && ( (unset $as_var) || exit 1) >/dev/null 2>&1 && unset $as_var || : done PS1='$ ' PS2='> ' PS4='+ ' # NLS nuisances. LC_ALL=C export LC_ALL LANGUAGE=C export LANGUAGE # CDPATH. (unset CDPATH) >/dev/null 2>&1 && unset CDPATH # Use a proper internal environment variable to ensure we don't fall # into an infinite loop, continuously re-executing ourselves. if test x"${_as_can_reexec}" != xno && test "x$CONFIG_SHELL" != x; then _as_can_reexec=no; export _as_can_reexec; # We cannot yet assume a decent shell, so we have to provide a # neutralization value for shells without unset; and this also # works around shells that cannot unset nonexistent variables. # Preserve -v and -x to the replacement shell. BASH_ENV=/dev/null ENV=/dev/null (unset BASH_ENV) >/dev/null 2>&1 && unset BASH_ENV ENV case $- in # (((( *v*x* | *x*v* ) as_opts=-vx ;; *v* ) as_opts=-v ;; *x* ) as_opts=-x ;; * ) as_opts= ;; esac exec $CONFIG_SHELL $as_opts "$as_myself" ${1+"$@"} # Admittedly, this is quite paranoid, since all the known shells bail # out after a failed `exec'. $as_echo "$0: could not re-execute with $CONFIG_SHELL" >&2 as_fn_exit 255 fi # We don't want this to propagate to other subprocesses. { _as_can_reexec=; unset _as_can_reexec;} if test "x$CONFIG_SHELL" = x; then as_bourne_compatible="if test -n \"\${ZSH_VERSION+set}\" && (emulate sh) >/dev/null 2>&1; then : emulate sh NULLCMD=: # Pre-4.2 versions of Zsh do word splitting on \${1+\"\$@\"}, which # is contrary to our usage. Disable this feature. alias -g '\${1+\"\$@\"}'='\"\$@\"' setopt NO_GLOB_SUBST else case \`(set -o) 2>/dev/null\` in #( *posix*) : set -o posix ;; #( *) : ;; esac fi " as_required="as_fn_return () { (exit \$1); } as_fn_success () { as_fn_return 0; } as_fn_failure () { as_fn_return 1; } as_fn_ret_success () { return 0; } as_fn_ret_failure () { return 1; } exitcode=0 as_fn_success || { exitcode=1; echo as_fn_success failed.; } as_fn_failure && { exitcode=1; echo as_fn_failure succeeded.; } as_fn_ret_success || { exitcode=1; echo as_fn_ret_success failed.; } as_fn_ret_failure && { exitcode=1; echo as_fn_ret_failure succeeded.; } if ( set x; as_fn_ret_success y && test x = \"\$1\" ); then : else exitcode=1; echo positional parameters were not saved. fi test x\$exitcode = x0 || exit 1 test -x / || exit 1" as_suggested=" as_lineno_1=";as_suggested=$as_suggested$LINENO;as_suggested=$as_suggested" as_lineno_1a=\$LINENO as_lineno_2=";as_suggested=$as_suggested$LINENO;as_suggested=$as_suggested" as_lineno_2a=\$LINENO eval 'test \"x\$as_lineno_1'\$as_run'\" != \"x\$as_lineno_2'\$as_run'\" && test \"x\`expr \$as_lineno_1'\$as_run' + 1\`\" = \"x\$as_lineno_2'\$as_run'\"' || exit 1 test -n \"\${ZSH_VERSION+set}\${BASH_VERSION+set}\" || ( ECHO='\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\' ECHO=\$ECHO\$ECHO\$ECHO\$ECHO\$ECHO ECHO=\$ECHO\$ECHO\$ECHO\$ECHO\$ECHO\$ECHO PATH=/empty FPATH=/empty; export PATH FPATH test \"X\`printf %s \$ECHO\`\" = \"X\$ECHO\" \\ || test \"X\`print -r -- \$ECHO\`\" = \"X\$ECHO\" ) || exit 1 test \$(( 1 + 1 )) = 2 || exit 1" if (eval "$as_required") 2>/dev/null; then : as_have_required=yes else as_have_required=no fi if test x$as_have_required = xyes && (eval "$as_suggested") 2>/dev/null; then : else as_save_IFS=$IFS; IFS=$PATH_SEPARATOR as_found=false for as_dir in /bin$PATH_SEPARATOR/usr/bin$PATH_SEPARATOR$PATH do IFS=$as_save_IFS test -z "$as_dir" && as_dir=. as_found=: case $as_dir in #( /*) for as_base in sh bash ksh sh5; do # Try only shells that exist, to save several forks. as_shell=$as_dir/$as_base if { test -f "$as_shell" || test -f "$as_shell.exe"; } && { $as_echo "$as_bourne_compatible""$as_required" | as_run=a "$as_shell"; } 2>/dev/null; then : CONFIG_SHELL=$as_shell as_have_required=yes if { $as_echo "$as_bourne_compatible""$as_suggested" | as_run=a "$as_shell"; } 2>/dev/null; then : break 2 fi fi done;; esac as_found=false done $as_found || { if { test -f "$SHELL" || test -f "$SHELL.exe"; } && { $as_echo "$as_bourne_compatible""$as_required" | as_run=a "$SHELL"; } 2>/dev/null; then : CONFIG_SHELL=$SHELL as_have_required=yes fi; } IFS=$as_save_IFS if test "x$CONFIG_SHELL" != x; then : export CONFIG_SHELL # We cannot yet assume a decent shell, so we have to provide a # neutralization value for shells without unset; and this also # works around shells that cannot unset nonexistent variables. # Preserve -v and -x to the replacement shell. BASH_ENV=/dev/null ENV=/dev/null (unset BASH_ENV) >/dev/null 2>&1 && unset BASH_ENV ENV case $- in # (((( *v*x* | *x*v* ) as_opts=-vx ;; *v* ) as_opts=-v ;; *x* ) as_opts=-x ;; * ) as_opts= ;; esac exec $CONFIG_SHELL $as_opts "$as_myself" ${1+"$@"} # Admittedly, this is quite paranoid, since all the known shells bail # out after a failed `exec'. $as_echo "$0: could not re-execute with $CONFIG_SHELL" >&2 exit 255 fi if test x$as_have_required = xno; then : $as_echo "$0: This script requires a shell more modern than all" $as_echo "$0: the shells that I found on your system." if test x${ZSH_VERSION+set} = xset ; then $as_echo "$0: In particular, zsh $ZSH_VERSION has bugs and should" $as_echo "$0: be upgraded to zsh 4.3.4 or later." else $as_echo "$0: Please tell bug-autoconf@gnu.org and $0: xrdp-devel@googlegroups.com about your system, $0: including any error possibly output before this $0: message. Then install a modern shell, or manually run $0: the script under such a shell if you do have one." fi exit 1 fi fi fi SHELL=${CONFIG_SHELL-/bin/sh} export SHELL # Unset more variables known to interfere with behavior of common tools. CLICOLOR_FORCE= GREP_OPTIONS= unset CLICOLOR_FORCE GREP_OPTIONS ## --------------------- ## ## M4sh Shell Functions. ## ## --------------------- ## # as_fn_unset VAR # --------------- # Portably unset VAR. as_fn_unset () { { eval $1=; unset $1;} } as_unset=as_fn_unset # as_fn_set_status STATUS # ----------------------- # Set $? to STATUS, without forking. as_fn_set_status () { return $1 } # as_fn_set_status # as_fn_exit STATUS # ----------------- # Exit the shell with STATUS, even in a "trap 0" or "set -e" context. as_fn_exit () { set +e as_fn_set_status $1 exit $1 } # as_fn_exit # as_fn_mkdir_p # ------------- # Create "$as_dir" as a directory, including parents if necessary. as_fn_mkdir_p () { case $as_dir in #( -*) as_dir=./$as_dir;; esac test -d "$as_dir" || eval $as_mkdir_p || { as_dirs= while :; do case $as_dir in #( *\'*) as_qdir=`$as_echo "$as_dir" | sed "s/'/'\\\\\\\\''/g"`;; #'( *) as_qdir=$as_dir;; esac as_dirs="'$as_qdir' $as_dirs" as_dir=`$as_dirname -- "$as_dir" || $as_expr X"$as_dir" : 'X\(.*[^/]\)//*[^/][^/]*/*$' \| \ X"$as_dir" : 'X\(//\)[^/]' \| \ X"$as_dir" : 'X\(//\)$' \| \ X"$as_dir" : 'X\(/\)' \| . 2>/dev/null || $as_echo X"$as_dir" | sed '/^X\(.*[^/]\)\/\/*[^/][^/]*\/*$/{ s//\1/ q } /^X\(\/\/\)[^/].*/{ s//\1/ q } /^X\(\/\/\)$/{ s//\1/ q } /^X\(\/\).*/{ s//\1/ q } s/.*/./; q'` test -d "$as_dir" && break done test -z "$as_dirs" || eval "mkdir $as_dirs" } || test -d "$as_dir" || as_fn_error $? "cannot create directory $as_dir" } # as_fn_mkdir_p # as_fn_executable_p FILE # ----------------------- # Test if FILE is an executable regular file. as_fn_executable_p () { test -f "$1" && test -x "$1" } # as_fn_executable_p # as_fn_append VAR VALUE # ---------------------- # Append the text in VALUE to the end of the definition contained in VAR. Take # advantage of any shell optimizations that allow amortized linear growth over # repeated appends, instead of the typical quadratic growth present in naive # implementations. if (eval "as_var=1; as_var+=2; test x\$as_var = x12") 2>/dev/null; then : eval 'as_fn_append () { eval $1+=\$2 }' else as_fn_append () { eval $1=\$$1\$2 } fi # as_fn_append # as_fn_arith ARG... # ------------------ # Perform arithmetic evaluation on the ARGs, and store the result in the # global $as_val. Take advantage of shells that can avoid forks. The arguments # must be portable across $(()) and expr. if (eval "test \$(( 1 + 1 )) = 2") 2>/dev/null; then : eval 'as_fn_arith () { as_val=$(( $* )) }' else as_fn_arith () { as_val=`expr "$@" || test $? -eq 1` } fi # as_fn_arith # as_fn_error STATUS ERROR [LINENO LOG_FD] # ---------------------------------------- # Output "`basename $0`: error: ERROR" to stderr. If LINENO and LOG_FD are # provided, also output the error to LOG_FD, referencing LINENO. Then exit the # script with STATUS, using 1 if that was 0. as_fn_error () { as_status=$1; test $as_status -eq 0 && as_status=1 if test "$4"; then as_lineno=${as_lineno-"$3"} as_lineno_stack=as_lineno_stack=$as_lineno_stack $as_echo "$as_me:${as_lineno-$LINENO}: error: $2" >&$4 fi $as_echo "$as_me: error: $2" >&2 as_fn_exit $as_status } # as_fn_error if expr a : '\(a\)' >/dev/null 2>&1 && test "X`expr 00001 : '.*\(...\)'`" = X001; then as_expr=expr else as_expr=false fi if (basename -- /) >/dev/null 2>&1 && test "X`basename -- / 2>&1`" = "X/"; then as_basename=basename else as_basename=false fi if (as_dir=`dirname -- /` && test "X$as_dir" = X/) >/dev/null 2>&1; then as_dirname=dirname else as_dirname=false fi as_me=`$as_basename -- "$0" || $as_expr X/"$0" : '.*/\([^/][^/]*\)/*$' \| \ X"$0" : 'X\(//\)$' \| \ X"$0" : 'X\(/\)' \| . 2>/dev/null || $as_echo X/"$0" | sed '/^.*\/\([^/][^/]*\)\/*$/{ s//\1/ q } /^X\/\(\/\/\)$/{ s//\1/ q } /^X\/\(\/\).*/{ s//\1/ q } s/.*/./; q'` # Avoid depending upon Character Ranges. as_cr_letters='abcdefghijklmnopqrstuvwxyz' as_cr_LETTERS='ABCDEFGHIJKLMNOPQRSTUVWXYZ' as_cr_Letters=$as_cr_letters$as_cr_LETTERS as_cr_digits='0123456789' as_cr_alnum=$as_cr_Letters$as_cr_digits as_lineno_1=$LINENO as_lineno_1a=$LINENO as_lineno_2=$LINENO as_lineno_2a=$LINENO eval 'test "x$as_lineno_1'$as_run'" != "x$as_lineno_2'$as_run'" && test "x`expr $as_lineno_1'$as_run' + 1`" = "x$as_lineno_2'$as_run'"' || { # Blame Lee E. McMahon (1931-1989) for sed's syntax. :-) sed -n ' p /[$]LINENO/= ' <$as_myself | sed ' s/[$]LINENO.*/&-/ t lineno b :lineno N :loop s/[$]LINENO\([^'$as_cr_alnum'_].*\n\)\(.*\)/\2\1\2/ t loop s/-\n.*// ' >$as_me.lineno && chmod +x "$as_me.lineno" || { $as_echo "$as_me: error: cannot create $as_me.lineno; rerun with a POSIX shell" >&2; as_fn_exit 1; } # If we had to re-execute with $CONFIG_SHELL, we're ensured to have # already done that, so ensure we don't try to do so again and fall # in an infinite loop. This has already happened in practice. _as_can_reexec=no; export _as_can_reexec # Don't try to exec as it changes $[0], causing all sort of problems # (the dirname of $[0] is not the place where we might find the # original and so on. Autoconf is especially sensitive to this). . "./$as_me.lineno" # Exit status is that of the last command. exit } ECHO_C= ECHO_N= ECHO_T= case `echo -n x` in #((((( -n*) case `echo 'xy\c'` in *c*) ECHO_T=' ';; # ECHO_T is single tab character. xy) ECHO_C='\c';; *) echo `echo ksh88 bug on AIX 6.1` > /dev/null ECHO_T=' ';; esac;; *) ECHO_N='-n';; esac rm -f conf$$ conf$$.exe conf$$.file if test -d conf$$.dir; then rm -f conf$$.dir/conf$$.file else rm -f conf$$.dir mkdir conf$$.dir 2>/dev/null fi if (echo >conf$$.file) 2>/dev/null; then if ln -s conf$$.file conf$$ 2>/dev/null; then as_ln_s='ln -s' # ... but there are two gotchas: # 1) On MSYS, both `ln -s file dir' and `ln file dir' fail. # 2) DJGPP < 2.04 has no symlinks; `ln -s' creates a wrapper executable. # In both cases, we have to default to `cp -pR'. ln -s conf$$.file conf$$.dir 2>/dev/null && test ! -f conf$$.exe || as_ln_s='cp -pR' elif ln conf$$.file conf$$ 2>/dev/null; then as_ln_s=ln else as_ln_s='cp -pR' fi else as_ln_s='cp -pR' fi rm -f conf$$ conf$$.exe conf$$.dir/conf$$.file conf$$.file rmdir conf$$.dir 2>/dev/null if mkdir -p . 2>/dev/null; then as_mkdir_p='mkdir -p "$as_dir"' else test -d ./-p && rmdir ./-p as_mkdir_p=false fi as_test_x='test -x' as_executable_p=as_fn_executable_p # Sed expression to map a string onto a valid CPP name. as_tr_cpp="eval sed 'y%*$as_cr_letters%P$as_cr_LETTERS%;s%[^_$as_cr_alnum]%_%g'" # Sed expression to map a string onto a valid variable name. as_tr_sh="eval sed 'y%*+%pp%;s%[^_$as_cr_alnum]%_%g'" SHELL=${CONFIG_SHELL-/bin/sh} test -n "$DJDIR" || exec 7<&0 &1 # Name of the host. # hostname on some systems (SVR3.2, old GNU/Linux) returns a bogus exit status, # so uname gets run too. ac_hostname=`(hostname || uname -n) 2>/dev/null | sed 1q` # # Initializations. # ac_default_prefix=/usr/local ac_clean_files= ac_config_libobj_dir=. LIBOBJS= cross_compiling=no subdirs= MFLAGS= MAKEFLAGS= # Identity of this package. PACKAGE_NAME='xrdp' PACKAGE_TARNAME='xrdp' PACKAGE_VERSION='0.9.5' PACKAGE_STRING='xrdp 0.9.5' PACKAGE_BUGREPORT='xrdp-devel@googlegroups.com' PACKAGE_URL='' # Factoring default headers for most tests. ac_includes_default="\ #include #ifdef HAVE_SYS_TYPES_H # include #endif #ifdef HAVE_SYS_STAT_H # include #endif #ifdef STDC_HEADERS # include # include #else # ifdef HAVE_STDLIB_H # include # endif #endif #ifdef HAVE_STRING_H # if !defined STDC_HEADERS && defined HAVE_MEMORY_H # include # endif # include #endif #ifdef HAVE_STRINGS_H # include #endif #ifdef HAVE_INTTYPES_H # include #endif #ifdef HAVE_STDINT_H # include #endif #ifdef HAVE_UNISTD_H # include #endif" enable_option_checking=no ac_subst_vars='am__EXEEXT_FALSE am__EXEEXT_TRUE LTLIBOBJS LIBOBJS pkgconfigdir moduledir X_EXTRA_LIBS X_LIBS X_PRE_LIBS X_CFLAGS XMKMF TurboJpegLibDir TurboJpegIncDir PIXMAN_LIBS PIXMAN_CFLAGS FDKAAC_LIBS FDKAAC_CFLAGS FUSE_LIBS FUSE_CFLAGS FREERDP_LIBS FREERDP_CFLAGS PAM_RULES OPENSSL OPENSSL_LIBS OPENSSL_CFLAGS DLOPEN_LIBS XRDP_RFXCODEC_FALSE XRDP_RFXCODEC_TRUE XRDP_PAINTER_FALSE XRDP_PAINTER_TRUE XRDP_PIXMAN_FALSE XRDP_PIXMAN_TRUE XRDP_MP3LAME_FALSE XRDP_MP3LAME_TRUE XRDP_OPUS_FALSE XRDP_OPUS_TRUE XRDP_FDK_AAC_FALSE XRDP_FDK_AAC_TRUE XRDP_XRDPVR_FALSE XRDP_XRDPVR_TRUE XRDP_FUSE_FALSE XRDP_FUSE_TRUE XRDP_TJPEG_FALSE XRDP_TJPEG_TRUE XRDP_JPEG_FALSE XRDP_JPEG_TRUE XRDP_NEUTRINORDP_FALSE XRDP_NEUTRINORDP_TRUE XRDP_DEBUG_FALSE XRDP_DEBUG_TRUE SESMAN_PAMUSERPASS_FALSE SESMAN_PAMUSERPASS_TRUE SESMAN_KERBEROS_FALSE SESMAN_KERBEROS_TRUE SESMAN_BSD_FALSE SESMAN_BSD_TRUE SESMAN_NOPAM_FALSE SESMAN_NOPAM_TRUE HAVE_SYSTEMD_FALSE HAVE_SYSTEMD_TRUE systemdsystemunitdir socketdir NETBSD_FALSE NETBSD_TRUE OPENBSD_FALSE OPENBSD_TRUE FREEBSD_FALSE FREEBSD_TRUE LINUX_FALSE LINUX_TRUE subdirs PKG_CONFIG_LIBDIR PKG_CONFIG_PATH PKG_CONFIG CPP LT_SYS_LIBRARY_PATH OTOOL64 OTOOL LIPO NMEDIT DSYMUTIL MANIFEST_TOOL RANLIB ac_ct_AR AR DLLTOOL OBJDUMP LN_S NM ac_ct_DUMPBIN DUMPBIN LD FGREP EGREP GREP SED host_os host_vendor host_cpu host build_os build_vendor build_cpu build LIBTOOL am__fastdepCC_FALSE am__fastdepCC_TRUE CCDEPMODE am__nodep AMDEPBACKSLASH AMDEP_FALSE AMDEP_TRUE am__quote am__include DEPDIR OBJEXT EXEEXT ac_ct_CC CPPFLAGS LDFLAGS CFLAGS CC AM_BACKSLASH AM_DEFAULT_VERBOSITY AM_DEFAULT_V AM_V am__untar am__tar AMTAR am__leading_dot SET_MAKE AWK mkdir_p MKDIR_P INSTALL_STRIP_PROGRAM STRIP install_sh MAKEINFO AUTOHEADER AUTOMAKE AUTOCONF ACLOCAL VERSION PACKAGE CYGPATH_W am__isrc INSTALL_DATA INSTALL_SCRIPT INSTALL_PROGRAM target_alias host_alias build_alias LIBS ECHO_T ECHO_N ECHO_C DEFS mandir localedir libdir psdir pdfdir dvidir htmldir infodir docdir oldincludedir includedir localstatedir sharedstatedir sysconfdir datadir datarootdir libexecdir sbindir bindir program_transform_name prefix exec_prefix PACKAGE_URL PACKAGE_BUGREPORT PACKAGE_STRING PACKAGE_VERSION PACKAGE_TARNAME PACKAGE_NAME PATH_SEPARATOR SHELL' ac_subst_files='' ac_user_opts=' enable_option_checking enable_silent_rules enable_dependency_tracking enable_shared enable_static with_pic enable_fast_install with_aix_soname with_gnu_ld with_sysroot enable_libtool_lock with_socketdir with_systemdsystemunitdir enable_pam enable_vsock enable_ipv6 enable_ipv6only enable_kerberos enable_bsd enable_pamuserpass enable_pam_config enable_xrdpdebug enable_neutrinordp enable_jpeg enable_tjpeg enable_fuse enable_xrdpvr enable_fdkaac enable_opus enable_mp3lame enable_pixman enable_painter enable_rfxcodec with_x enable_strict_locations with_pkgconfigdir ' ac_precious_vars='build_alias host_alias target_alias CC CFLAGS LDFLAGS LIBS CPPFLAGS LT_SYS_LIBRARY_PATH CPP PKG_CONFIG PKG_CONFIG_PATH PKG_CONFIG_LIBDIR OPENSSL_CFLAGS OPENSSL_LIBS FREERDP_CFLAGS FREERDP_LIBS FUSE_CFLAGS FUSE_LIBS FDKAAC_CFLAGS FDKAAC_LIBS PIXMAN_CFLAGS PIXMAN_LIBS XMKMF' ac_subdirs_all='libpainter librfxcodec' # Initialize some variables set by options. ac_init_help= ac_init_version=false ac_unrecognized_opts= ac_unrecognized_sep= # The variables have the same names as the options, with # dashes changed to underlines. cache_file=/dev/null exec_prefix=NONE no_create= no_recursion= prefix=NONE program_prefix=NONE program_suffix=NONE program_transform_name=s,x,x, silent= site= srcdir= verbose= x_includes=NONE x_libraries=NONE # Installation directory options. # These are left unexpanded so users can "make install exec_prefix=/foo" # and all the variables that are supposed to be based on exec_prefix # by default will actually change. # Use braces instead of parens because sh, perl, etc. also accept them. # (The list follows the same order as the GNU Coding Standards.) bindir='${exec_prefix}/bin' sbindir='${exec_prefix}/sbin' libexecdir='${exec_prefix}/libexec' datarootdir='${prefix}/share' datadir='${datarootdir}' sysconfdir='${prefix}/etc' sharedstatedir='${prefix}/com' localstatedir='${prefix}/var' includedir='${prefix}/include' oldincludedir='/usr/include' docdir='${datarootdir}/doc/${PACKAGE_TARNAME}' infodir='${datarootdir}/info' htmldir='${docdir}' dvidir='${docdir}' pdfdir='${docdir}' psdir='${docdir}' libdir='${exec_prefix}/lib' localedir='${datarootdir}/locale' mandir='${datarootdir}/man' ac_prev= ac_dashdash= for ac_option do # If the previous option needs an argument, assign it. if test -n "$ac_prev"; then eval $ac_prev=\$ac_option ac_prev= continue fi case $ac_option in *=?*) ac_optarg=`expr "X$ac_option" : '[^=]*=\(.*\)'` ;; *=) ac_optarg= ;; *) ac_optarg=yes ;; esac # Accept the important Cygnus configure options, so we can diagnose typos. case $ac_dashdash$ac_option in --) ac_dashdash=yes ;; -bindir | --bindir | --bindi | --bind | --bin | --bi) ac_prev=bindir ;; -bindir=* | --bindir=* | --bindi=* | --bind=* | --bin=* | --bi=*) bindir=$ac_optarg ;; -build | --build | --buil | --bui | --bu) ac_prev=build_alias ;; -build=* | --build=* | --buil=* | --bui=* | --bu=*) build_alias=$ac_optarg ;; -cache-file | --cache-file | --cache-fil | --cache-fi \ | --cache-f | --cache- | --cache | --cach | --cac | --ca | --c) ac_prev=cache_file ;; -cache-file=* | --cache-file=* | --cache-fil=* | --cache-fi=* \ | --cache-f=* | --cache-=* | --cache=* | --cach=* | --cac=* | --ca=* | --c=*) cache_file=$ac_optarg ;; --config-cache | -C) cache_file=config.cache ;; -datadir | --datadir | --datadi | --datad) ac_prev=datadir ;; -datadir=* | --datadir=* | --datadi=* | --datad=*) datadir=$ac_optarg ;; -datarootdir | --datarootdir | --datarootdi | --datarootd | --dataroot \ | --dataroo | --dataro | --datar) ac_prev=datarootdir ;; -datarootdir=* | --datarootdir=* | --datarootdi=* | --datarootd=* \ | --dataroot=* | --dataroo=* | --dataro=* | --datar=*) datarootdir=$ac_optarg ;; -disable-* | --disable-*) ac_useropt=`expr "x$ac_option" : 'x-*disable-\(.*\)'` # Reject names that are not valid shell variable names. expr "x$ac_useropt" : ".*[^-+._$as_cr_alnum]" >/dev/null && as_fn_error $? "invalid feature name: $ac_useropt" ac_useropt_orig=$ac_useropt ac_useropt=`$as_echo "$ac_useropt" | sed 's/[-+.]/_/g'` case $ac_user_opts in *" "enable_$ac_useropt" "*) ;; *) ac_unrecognized_opts="$ac_unrecognized_opts$ac_unrecognized_sep--disable-$ac_useropt_orig" ac_unrecognized_sep=', ';; esac eval enable_$ac_useropt=no ;; -docdir | --docdir | --docdi | --doc | --do) ac_prev=docdir ;; -docdir=* | --docdir=* | --docdi=* | --doc=* | --do=*) docdir=$ac_optarg ;; -dvidir | --dvidir | --dvidi | --dvid | --dvi | --dv) ac_prev=dvidir ;; -dvidir=* | --dvidir=* | --dvidi=* | --dvid=* | --dvi=* | --dv=*) dvidir=$ac_optarg ;; -enable-* | --enable-*) ac_useropt=`expr "x$ac_option" : 'x-*enable-\([^=]*\)'` # Reject names that are not valid shell variable names. expr "x$ac_useropt" : ".*[^-+._$as_cr_alnum]" >/dev/null && as_fn_error $? "invalid feature name: $ac_useropt" ac_useropt_orig=$ac_useropt ac_useropt=`$as_echo "$ac_useropt" | sed 's/[-+.]/_/g'` case $ac_user_opts in *" "enable_$ac_useropt" "*) ;; *) ac_unrecognized_opts="$ac_unrecognized_opts$ac_unrecognized_sep--enable-$ac_useropt_orig" ac_unrecognized_sep=', ';; esac eval enable_$ac_useropt=\$ac_optarg ;; -exec-prefix | --exec_prefix | --exec-prefix | --exec-prefi \ | --exec-pref | --exec-pre | --exec-pr | --exec-p | --exec- \ | --exec | --exe | --ex) ac_prev=exec_prefix ;; -exec-prefix=* | --exec_prefix=* | --exec-prefix=* | --exec-prefi=* \ | --exec-pref=* | --exec-pre=* | --exec-pr=* | --exec-p=* | --exec-=* \ | --exec=* | --exe=* | --ex=*) exec_prefix=$ac_optarg ;; -gas | --gas | --ga | --g) # Obsolete; use --with-gas. with_gas=yes ;; -help | --help | --hel | --he | -h) ac_init_help=long ;; -help=r* | --help=r* | --hel=r* | --he=r* | -hr*) ac_init_help=recursive ;; -help=s* | --help=s* | --hel=s* | --he=s* | -hs*) ac_init_help=short ;; -host | --host | --hos | --ho) ac_prev=host_alias ;; -host=* | --host=* | --hos=* | --ho=*) host_alias=$ac_optarg ;; -htmldir | --htmldir | --htmldi | --htmld | --html | --htm | --ht) ac_prev=htmldir ;; -htmldir=* | --htmldir=* | --htmldi=* | --htmld=* | --html=* | --htm=* \ | --ht=*) htmldir=$ac_optarg ;; -includedir | --includedir | --includedi | --included | --include \ | --includ | --inclu | --incl | --inc) ac_prev=includedir ;; -includedir=* | --includedir=* | --includedi=* | --included=* | --include=* \ | --includ=* | --inclu=* | --incl=* | --inc=*) includedir=$ac_optarg ;; -infodir | --infodir | --infodi | --infod | --info | --inf) ac_prev=infodir ;; -infodir=* | --infodir=* | --infodi=* | --infod=* | --info=* | --inf=*) infodir=$ac_optarg ;; -libdir | --libdir | --libdi | --libd) ac_prev=libdir ;; -libdir=* | --libdir=* | --libdi=* | --libd=*) libdir=$ac_optarg ;; -libexecdir | --libexecdir | --libexecdi | --libexecd | --libexec \ | --libexe | --libex | --libe) ac_prev=libexecdir ;; -libexecdir=* | --libexecdir=* | --libexecdi=* | --libexecd=* | --libexec=* \ | --libexe=* | --libex=* | --libe=*) libexecdir=$ac_optarg ;; -localedir | --localedir | --localedi | --localed | --locale) ac_prev=localedir ;; -localedir=* | --localedir=* | --localedi=* | --localed=* | --locale=*) localedir=$ac_optarg ;; -localstatedir | --localstatedir | --localstatedi | --localstated \ | --localstate | --localstat | --localsta | --localst | --locals) ac_prev=localstatedir ;; -localstatedir=* | --localstatedir=* | --localstatedi=* | --localstated=* \ | --localstate=* | --localstat=* | --localsta=* | --localst=* | --locals=*) localstatedir=$ac_optarg ;; -mandir | --mandir | --mandi | --mand | --man | --ma | --m) ac_prev=mandir ;; -mandir=* | --mandir=* | --mandi=* | --mand=* | --man=* | --ma=* | --m=*) mandir=$ac_optarg ;; -nfp | --nfp | --nf) # Obsolete; use --without-fp. with_fp=no ;; -no-create | --no-create | --no-creat | --no-crea | --no-cre \ | --no-cr | --no-c | -n) no_create=yes ;; -no-recursion | --no-recursion | --no-recursio | --no-recursi \ | --no-recurs | --no-recur | --no-recu | --no-rec | --no-re | --no-r) no_recursion=yes ;; -oldincludedir | --oldincludedir | --oldincludedi | --oldincluded \ | --oldinclude | --oldinclud | --oldinclu | --oldincl | --oldinc \ | --oldin | --oldi | --old | --ol | --o) ac_prev=oldincludedir ;; -oldincludedir=* | --oldincludedir=* | --oldincludedi=* | --oldincluded=* \ | --oldinclude=* | --oldinclud=* | --oldinclu=* | --oldincl=* | --oldinc=* \ | --oldin=* | --oldi=* | --old=* | --ol=* | --o=*) oldincludedir=$ac_optarg ;; -prefix | --prefix | --prefi | --pref | --pre | --pr | --p) ac_prev=prefix ;; -prefix=* | --prefix=* | --prefi=* | --pref=* | --pre=* | --pr=* | --p=*) prefix=$ac_optarg ;; -program-prefix | --program-prefix | --program-prefi | --program-pref \ | --program-pre | --program-pr | --program-p) ac_prev=program_prefix ;; -program-prefix=* | --program-prefix=* | --program-prefi=* \ | --program-pref=* | --program-pre=* | --program-pr=* | --program-p=*) program_prefix=$ac_optarg ;; -program-suffix | --program-suffix | --program-suffi | --program-suff \ | --program-suf | --program-su | --program-s) ac_prev=program_suffix ;; -program-suffix=* | --program-suffix=* | --program-suffi=* \ | --program-suff=* | --program-suf=* | --program-su=* | --program-s=*) program_suffix=$ac_optarg ;; -program-transform-name | --program-transform-name \ | --program-transform-nam | --program-transform-na \ | --program-transform-n | --program-transform- \ | --program-transform | --program-transfor \ | --program-transfo | --program-transf \ | --program-trans | --program-tran \ | --progr-tra | --program-tr | --program-t) ac_prev=program_transform_name ;; -program-transform-name=* | --program-transform-name=* \ | --program-transform-nam=* | --program-transform-na=* \ | --program-transform-n=* | --program-transform-=* \ | --program-transform=* | --program-transfor=* \ | --program-transfo=* | --program-transf=* \ | --program-trans=* | --program-tran=* \ | --progr-tra=* | --program-tr=* | --program-t=*) program_transform_name=$ac_optarg ;; -pdfdir | --pdfdir | --pdfdi | --pdfd | --pdf | --pd) ac_prev=pdfdir ;; -pdfdir=* | --pdfdir=* | --pdfdi=* | --pdfd=* | --pdf=* | --pd=*) pdfdir=$ac_optarg ;; -psdir | --psdir | --psdi | --psd | --ps) ac_prev=psdir ;; -psdir=* | --psdir=* | --psdi=* | --psd=* | --ps=*) psdir=$ac_optarg ;; -q | -quiet | --quiet | --quie | --qui | --qu | --q \ | -silent | --silent | --silen | --sile | --sil) silent=yes ;; -sbindir | --sbindir | --sbindi | --sbind | --sbin | --sbi | --sb) ac_prev=sbindir ;; -sbindir=* | --sbindir=* | --sbindi=* | --sbind=* | --sbin=* \ | --sbi=* | --sb=*) sbindir=$ac_optarg ;; -sharedstatedir | --sharedstatedir | --sharedstatedi \ | --sharedstated | --sharedstate | --sharedstat | --sharedsta \ | --sharedst | --shareds | --shared | --share | --shar \ | --sha | --sh) ac_prev=sharedstatedir ;; -sharedstatedir=* | --sharedstatedir=* | --sharedstatedi=* \ | --sharedstated=* | --sharedstate=* | --sharedstat=* | --sharedsta=* \ | --sharedst=* | --shareds=* | --shared=* | --share=* | --shar=* \ | --sha=* | --sh=*) sharedstatedir=$ac_optarg ;; -site | --site | --sit) ac_prev=site ;; -site=* | --site=* | --sit=*) site=$ac_optarg ;; -srcdir | --srcdir | --srcdi | --srcd | --src | --sr) ac_prev=srcdir ;; -srcdir=* | --srcdir=* | --srcdi=* | --srcd=* | --src=* | --sr=*) srcdir=$ac_optarg ;; -sysconfdir | --sysconfdir | --sysconfdi | --sysconfd | --sysconf \ | --syscon | --sysco | --sysc | --sys | --sy) ac_prev=sysconfdir ;; -sysconfdir=* | --sysconfdir=* | --sysconfdi=* | --sysconfd=* | --sysconf=* \ | --syscon=* | --sysco=* | --sysc=* | --sys=* | --sy=*) sysconfdir=$ac_optarg ;; -target | --target | --targe | --targ | --tar | --ta | --t) ac_prev=target_alias ;; -target=* | --target=* | --targe=* | --targ=* | --tar=* | --ta=* | --t=*) target_alias=$ac_optarg ;; -v | -verbose | --verbose | --verbos | --verbo | --verb) verbose=yes ;; -version | --version | --versio | --versi | --vers | -V) ac_init_version=: ;; -with-* | --with-*) ac_useropt=`expr "x$ac_option" : 'x-*with-\([^=]*\)'` # Reject names that are not valid shell variable names. expr "x$ac_useropt" : ".*[^-+._$as_cr_alnum]" >/dev/null && as_fn_error $? "invalid package name: $ac_useropt" ac_useropt_orig=$ac_useropt ac_useropt=`$as_echo "$ac_useropt" | sed 's/[-+.]/_/g'` case $ac_user_opts in *" "with_$ac_useropt" "*) ;; *) ac_unrecognized_opts="$ac_unrecognized_opts$ac_unrecognized_sep--with-$ac_useropt_orig" ac_unrecognized_sep=', ';; esac eval with_$ac_useropt=\$ac_optarg ;; -without-* | --without-*) ac_useropt=`expr "x$ac_option" : 'x-*without-\(.*\)'` # Reject names that are not valid shell variable names. expr "x$ac_useropt" : ".*[^-+._$as_cr_alnum]" >/dev/null && as_fn_error $? "invalid package name: $ac_useropt" ac_useropt_orig=$ac_useropt ac_useropt=`$as_echo "$ac_useropt" | sed 's/[-+.]/_/g'` case $ac_user_opts in *" "with_$ac_useropt" "*) ;; *) ac_unrecognized_opts="$ac_unrecognized_opts$ac_unrecognized_sep--without-$ac_useropt_orig" ac_unrecognized_sep=', ';; esac eval with_$ac_useropt=no ;; --x) # Obsolete; use --with-x. with_x=yes ;; -x-includes | --x-includes | --x-include | --x-includ | --x-inclu \ | --x-incl | --x-inc | --x-in | --x-i) ac_prev=x_includes ;; -x-includes=* | --x-includes=* | --x-include=* | --x-includ=* | --x-inclu=* \ | --x-incl=* | --x-inc=* | --x-in=* | --x-i=*) x_includes=$ac_optarg ;; -x-libraries | --x-libraries | --x-librarie | --x-librari \ | --x-librar | --x-libra | --x-libr | --x-lib | --x-li | --x-l) ac_prev=x_libraries ;; -x-libraries=* | --x-libraries=* | --x-librarie=* | --x-librari=* \ | --x-librar=* | --x-libra=* | --x-libr=* | --x-lib=* | --x-li=* | --x-l=*) x_libraries=$ac_optarg ;; -*) as_fn_error $? "unrecognized option: \`$ac_option' Try \`$0 --help' for more information" ;; *=*) ac_envvar=`expr "x$ac_option" : 'x\([^=]*\)='` # Reject names that are not valid shell variable names. case $ac_envvar in #( '' | [0-9]* | *[!_$as_cr_alnum]* ) as_fn_error $? "invalid variable name: \`$ac_envvar'" ;; esac eval $ac_envvar=\$ac_optarg export $ac_envvar ;; *) # FIXME: should be removed in autoconf 3.0. $as_echo "$as_me: WARNING: you should use --build, --host, --target" >&2 expr "x$ac_option" : ".*[^-._$as_cr_alnum]" >/dev/null && $as_echo "$as_me: WARNING: invalid host type: $ac_option" >&2 : "${build_alias=$ac_option} ${host_alias=$ac_option} ${target_alias=$ac_option}" ;; esac done if test -n "$ac_prev"; then ac_option=--`echo $ac_prev | sed 's/_/-/g'` as_fn_error $? "missing argument to $ac_option" fi if test -n "$ac_unrecognized_opts"; then case $enable_option_checking in no) ;; fatal) as_fn_error $? "unrecognized options: $ac_unrecognized_opts" ;; *) $as_echo "$as_me: WARNING: unrecognized options: $ac_unrecognized_opts" >&2 ;; esac fi # Check all directory arguments for consistency. for ac_var in exec_prefix prefix bindir sbindir libexecdir datarootdir \ datadir sysconfdir sharedstatedir localstatedir includedir \ oldincludedir docdir infodir htmldir dvidir pdfdir psdir \ libdir localedir mandir do eval ac_val=\$$ac_var # Remove trailing slashes. case $ac_val in */ ) ac_val=`expr "X$ac_val" : 'X\(.*[^/]\)' \| "X$ac_val" : 'X\(.*\)'` eval $ac_var=\$ac_val;; esac # Be sure to have absolute directory names. case $ac_val in [\\/$]* | ?:[\\/]* ) continue;; NONE | '' ) case $ac_var in *prefix ) continue;; esac;; esac as_fn_error $? "expected an absolute directory name for --$ac_var: $ac_val" done # There might be people who depend on the old broken behavior: `$host' # used to hold the argument of --host etc. # FIXME: To remove some day. build=$build_alias host=$host_alias target=$target_alias # FIXME: To remove some day. if test "x$host_alias" != x; then if test "x$build_alias" = x; then cross_compiling=maybe elif test "x$build_alias" != "x$host_alias"; then cross_compiling=yes fi fi ac_tool_prefix= test -n "$host_alias" && ac_tool_prefix=$host_alias- test "$silent" = yes && exec 6>/dev/null ac_pwd=`pwd` && test -n "$ac_pwd" && ac_ls_di=`ls -di .` && ac_pwd_ls_di=`cd "$ac_pwd" && ls -di .` || as_fn_error $? "working directory cannot be determined" test "X$ac_ls_di" = "X$ac_pwd_ls_di" || as_fn_error $? "pwd does not report name of working directory" # Find the source files, if location was not specified. if test -z "$srcdir"; then ac_srcdir_defaulted=yes # Try the directory containing this script, then the parent directory. ac_confdir=`$as_dirname -- "$as_myself" || $as_expr X"$as_myself" : 'X\(.*[^/]\)//*[^/][^/]*/*$' \| \ X"$as_myself" : 'X\(//\)[^/]' \| \ X"$as_myself" : 'X\(//\)$' \| \ X"$as_myself" : 'X\(/\)' \| . 2>/dev/null || $as_echo X"$as_myself" | sed '/^X\(.*[^/]\)\/\/*[^/][^/]*\/*$/{ s//\1/ q } /^X\(\/\/\)[^/].*/{ s//\1/ q } /^X\(\/\/\)$/{ s//\1/ q } /^X\(\/\).*/{ s//\1/ q } s/.*/./; q'` srcdir=$ac_confdir if test ! -r "$srcdir/$ac_unique_file"; then srcdir=.. fi else ac_srcdir_defaulted=no fi if test ! -r "$srcdir/$ac_unique_file"; then test "$ac_srcdir_defaulted" = yes && srcdir="$ac_confdir or .." as_fn_error $? "cannot find sources ($ac_unique_file) in $srcdir" fi ac_msg="sources are in $srcdir, but \`cd $srcdir' does not work" ac_abs_confdir=`( cd "$srcdir" && test -r "./$ac_unique_file" || as_fn_error $? "$ac_msg" pwd)` # When building in place, set srcdir=. if test "$ac_abs_confdir" = "$ac_pwd"; then srcdir=. fi # Remove unnecessary trailing slashes from srcdir. # Double slashes in file names in object file debugging info # mess up M-x gdb in Emacs. case $srcdir in */) srcdir=`expr "X$srcdir" : 'X\(.*[^/]\)' \| "X$srcdir" : 'X\(.*\)'`;; esac for ac_var in $ac_precious_vars; do eval ac_env_${ac_var}_set=\${${ac_var}+set} eval ac_env_${ac_var}_value=\$${ac_var} eval ac_cv_env_${ac_var}_set=\${${ac_var}+set} eval ac_cv_env_${ac_var}_value=\$${ac_var} done # # Report the --help message. # if test "$ac_init_help" = "long"; then # Omit some internal or obsolete options to make the list less imposing. # This message is too long to be a string in the A/UX 3.1 sh. cat <<_ACEOF \`configure' configures xrdp 0.9.5 to adapt to many kinds of systems. Usage: $0 [OPTION]... [VAR=VALUE]... To assign environment variables (e.g., CC, CFLAGS...), specify them as VAR=VALUE. See below for descriptions of some of the useful variables. Defaults for the options are specified in brackets. Configuration: -h, --help display this help and exit --help=short display options specific to this package --help=recursive display the short help of all the included packages -V, --version display version information and exit -q, --quiet, --silent do not print \`checking ...' messages --cache-file=FILE cache test results in FILE [disabled] -C, --config-cache alias for \`--cache-file=config.cache' -n, --no-create do not create output files --srcdir=DIR find the sources in DIR [configure dir or \`..'] Installation directories: --prefix=PREFIX install architecture-independent files in PREFIX [$ac_default_prefix] --exec-prefix=EPREFIX install architecture-dependent files in EPREFIX [PREFIX] By default, \`make install' will install all the files in \`$ac_default_prefix/bin', \`$ac_default_prefix/lib' etc. You can specify an installation prefix other than \`$ac_default_prefix' using \`--prefix', for instance \`--prefix=\$HOME'. For better control, use the options below. Fine tuning of the installation directories: --bindir=DIR user executables [EPREFIX/bin] --sbindir=DIR system admin executables [EPREFIX/sbin] --libexecdir=DIR program executables [EPREFIX/libexec] --sysconfdir=DIR read-only single-machine data [PREFIX/etc] --sharedstatedir=DIR modifiable architecture-independent data [PREFIX/com] --localstatedir=DIR modifiable single-machine data [PREFIX/var] --libdir=DIR object code libraries [EPREFIX/lib] --includedir=DIR C header files [PREFIX/include] --oldincludedir=DIR C header files for non-gcc [/usr/include] --datarootdir=DIR read-only arch.-independent data root [PREFIX/share] --datadir=DIR read-only architecture-independent data [DATAROOTDIR] --infodir=DIR info documentation [DATAROOTDIR/info] --localedir=DIR locale-dependent data [DATAROOTDIR/locale] --mandir=DIR man documentation [DATAROOTDIR/man] --docdir=DIR documentation root [DATAROOTDIR/doc/xrdp] --htmldir=DIR html documentation [DOCDIR] --dvidir=DIR dvi documentation [DOCDIR] --pdfdir=DIR pdf documentation [DOCDIR] --psdir=DIR ps documentation [DOCDIR] _ACEOF cat <<\_ACEOF Program names: --program-prefix=PREFIX prepend PREFIX to installed program names --program-suffix=SUFFIX append SUFFIX to installed program names --program-transform-name=PROGRAM run sed PROGRAM on installed program names X features: --x-includes=DIR X include files are in DIR --x-libraries=DIR X library files are in DIR System types: --build=BUILD configure for building on BUILD [guessed] --host=HOST cross-compile to build programs to run on HOST [BUILD] _ACEOF fi if test -n "$ac_init_help"; then case $ac_init_help in short | recursive ) echo "Configuration of xrdp 0.9.5:";; esac cat <<\_ACEOF Optional Features: --disable-option-checking ignore unrecognized --enable/--with options --disable-FEATURE do not include FEATURE (same as --enable-FEATURE=no) --enable-FEATURE[=ARG] include FEATURE [ARG=yes] --enable-silent-rules less verbose build output (undo: "make V=1") --disable-silent-rules verbose build output (undo: "make V=0") --enable-dependency-tracking do not reject slow dependency extractors --disable-dependency-tracking speeds up one-time build --enable-shared[=PKGS] build shared libraries [default=yes] --enable-static[=PKGS] build static libraries [default=yes] --enable-fast-install[=PKGS] optimize for fast installation [default=yes] --disable-libtool-lock avoid locking (might break parallel builds) --disable-pam Build PAM support (default: yes) --enable-vsock Build AF_VSOCK support (default: no) --enable-ipv6 Build IPv6 support (default: no, experimental) --enable-ipv6only Build IPv6-only (default: no) --enable-kerberos Build kerberos support (default: no) --enable-bsd Build BSD auth support (default: no) --enable-pamuserpass Build pam userpass support (default: no) --enable-pam-config=CONF Select PAM config to install: debian, redhat, suse, freebsd, unix (default: autodetect) --enable-xrdpdebug Build debug (default: no) --enable-neutrinordp Build neutrinordp module (default: no) --enable-jpeg Build jpeg module (default: no) --enable-tjpeg Build turbo jpeg module (default: no) --enable-fuse Build fuse(clipboard file / drive redir) (default: no) --enable-xrdpvr Build xrdpvr module (default: no) --enable-fdkaac Build aac(audio codec) (default: no) --enable-opus Build opus(audio codec) (default: no) --enable-mp3lame Build lame mp3(audio codec) (default: no) --enable-pixman Use pixman library (default: no) --disable-painter Do not use included painter library (default: no) --disable-rfxcodec Do not use included librfxcodec library (default: no) --enable-strict-locations Use standard Autoconf install directories unless overridden (default: use /etc and /var) Optional Packages: --with-PACKAGE[=ARG] use PACKAGE [ARG=yes] --without-PACKAGE do not use PACKAGE (same as --with-PACKAGE=no) --with-pic[=PKGS] try to use only PIC/non-PIC objects [default=use both] --with-aix-soname=aix|svr4|both shared library versioning (aka "SONAME") variant to provide on AIX, [default=aix]. --with-gnu-ld assume the C compiler uses GNU ld [default=no] --with-sysroot[=DIR] Search for dependent libraries within DIR (or the compiler's sysroot if not specified). --with-socketdir=DIR Use directory for UNIX sockets (default: /tmp/.xrdp) --with-systemdsystemunitdir=DIR Directory for systemd service files --with-x use the X Window System --with-pkgconfigdir pkg-config installation directory ['${libdir}/pkgconfig'] Some influential environment variables: CC C compiler command CFLAGS C compiler flags LDFLAGS linker flags, e.g. -L if you have libraries in a nonstandard directory LIBS libraries to pass to the linker, e.g. -l CPPFLAGS (Objective) C/C++ preprocessor flags, e.g. -I if you have headers in a nonstandard directory LT_SYS_LIBRARY_PATH User-defined run-time library search path. CPP C preprocessor PKG_CONFIG path to pkg-config utility PKG_CONFIG_PATH directories to add to pkg-config's search path PKG_CONFIG_LIBDIR path overriding pkg-config's built-in search path OPENSSL_CFLAGS C compiler flags for OPENSSL, overriding pkg-config OPENSSL_LIBS linker flags for OPENSSL, overriding pkg-config FREERDP_CFLAGS C compiler flags for FREERDP, overriding pkg-config FREERDP_LIBS linker flags for FREERDP, overriding pkg-config FUSE_CFLAGS C compiler flags for FUSE, overriding pkg-config FUSE_LIBS linker flags for FUSE, overriding pkg-config FDKAAC_CFLAGS C compiler flags for FDKAAC, overriding pkg-config FDKAAC_LIBS linker flags for FDKAAC, overriding pkg-config PIXMAN_CFLAGS C compiler flags for PIXMAN, overriding pkg-config PIXMAN_LIBS linker flags for PIXMAN, overriding pkg-config XMKMF Path to xmkmf, Makefile generator for X Window System Use these variables to override the choices made by `configure' or to help it to find libraries and programs with nonstandard names/locations. Report bugs to . _ACEOF ac_status=$? fi if test "$ac_init_help" = "recursive"; then # If there are subdirs, report their specific --help. for ac_dir in : $ac_subdirs_all; do test "x$ac_dir" = x: && continue test -d "$ac_dir" || { cd "$srcdir" && ac_pwd=`pwd` && srcdir=. && test -d "$ac_dir"; } || continue ac_builddir=. case "$ac_dir" in .) ac_dir_suffix= ac_top_builddir_sub=. ac_top_build_prefix= ;; *) ac_dir_suffix=/`$as_echo "$ac_dir" | sed 's|^\.[\\/]||'` # A ".." for each directory in $ac_dir_suffix. ac_top_builddir_sub=`$as_echo "$ac_dir_suffix" | sed 's|/[^\\/]*|/..|g;s|/||'` case $ac_top_builddir_sub in "") ac_top_builddir_sub=. ac_top_build_prefix= ;; *) ac_top_build_prefix=$ac_top_builddir_sub/ ;; esac ;; esac ac_abs_top_builddir=$ac_pwd ac_abs_builddir=$ac_pwd$ac_dir_suffix # for backward compatibility: ac_top_builddir=$ac_top_build_prefix case $srcdir in .) # We are building in place. ac_srcdir=. ac_top_srcdir=$ac_top_builddir_sub ac_abs_top_srcdir=$ac_pwd ;; [\\/]* | ?:[\\/]* ) # Absolute name. ac_srcdir=$srcdir$ac_dir_suffix; ac_top_srcdir=$srcdir ac_abs_top_srcdir=$srcdir ;; *) # Relative name. ac_srcdir=$ac_top_build_prefix$srcdir$ac_dir_suffix ac_top_srcdir=$ac_top_build_prefix$srcdir ac_abs_top_srcdir=$ac_pwd/$srcdir ;; esac ac_abs_srcdir=$ac_abs_top_srcdir$ac_dir_suffix cd "$ac_dir" || { ac_status=$?; continue; } # Check for guested configure. if test -f "$ac_srcdir/configure.gnu"; then echo && $SHELL "$ac_srcdir/configure.gnu" --help=recursive elif test -f "$ac_srcdir/configure"; then echo && $SHELL "$ac_srcdir/configure" --help=recursive else $as_echo "$as_me: WARNING: no configuration information is in $ac_dir" >&2 fi || ac_status=$? cd "$ac_pwd" || { ac_status=$?; break; } done fi test -n "$ac_init_help" && exit $ac_status if $ac_init_version; then cat <<\_ACEOF xrdp configure 0.9.5 generated by GNU Autoconf 2.69 Copyright (C) 2012 Free Software Foundation, Inc. This configure script is free software; the Free Software Foundation gives unlimited permission to copy, distribute and modify it. _ACEOF exit fi ## ------------------------ ## ## Autoconf initialization. ## ## ------------------------ ## # ac_fn_c_try_compile LINENO # -------------------------- # Try to compile conftest.$ac_ext, and return whether this succeeded. ac_fn_c_try_compile () { as_lineno=${as_lineno-"$1"} as_lineno_stack=as_lineno_stack=$as_lineno_stack rm -f conftest.$ac_objext if { { ac_try="$ac_compile" case "(($ac_try" in *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; *) ac_try_echo=$ac_try;; esac eval ac_try_echo="\"\$as_me:${as_lineno-$LINENO}: $ac_try_echo\"" $as_echo "$ac_try_echo"; } >&5 (eval "$ac_compile") 2>conftest.err ac_status=$? if test -s conftest.err; then grep -v '^ *+' conftest.err >conftest.er1 cat conftest.er1 >&5 mv -f conftest.er1 conftest.err fi $as_echo "$as_me:${as_lineno-$LINENO}: \$? = $ac_status" >&5 test $ac_status = 0; } && { test -z "$ac_c_werror_flag" || test ! -s conftest.err } && test -s conftest.$ac_objext; then : ac_retval=0 else $as_echo "$as_me: failed program was:" >&5 sed 's/^/| /' conftest.$ac_ext >&5 ac_retval=1 fi eval $as_lineno_stack; ${as_lineno_stack:+:} unset as_lineno as_fn_set_status $ac_retval } # ac_fn_c_try_compile # ac_fn_c_try_link LINENO # ----------------------- # Try to link conftest.$ac_ext, and return whether this succeeded. ac_fn_c_try_link () { as_lineno=${as_lineno-"$1"} as_lineno_stack=as_lineno_stack=$as_lineno_stack rm -f conftest.$ac_objext conftest$ac_exeext if { { ac_try="$ac_link" case "(($ac_try" in *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; *) ac_try_echo=$ac_try;; esac eval ac_try_echo="\"\$as_me:${as_lineno-$LINENO}: $ac_try_echo\"" $as_echo "$ac_try_echo"; } >&5 (eval "$ac_link") 2>conftest.err ac_status=$? if test -s conftest.err; then grep -v '^ *+' conftest.err >conftest.er1 cat conftest.er1 >&5 mv -f conftest.er1 conftest.err fi $as_echo "$as_me:${as_lineno-$LINENO}: \$? = $ac_status" >&5 test $ac_status = 0; } && { test -z "$ac_c_werror_flag" || test ! -s conftest.err } && test -s conftest$ac_exeext && { test "$cross_compiling" = yes || test -x conftest$ac_exeext }; then : ac_retval=0 else $as_echo "$as_me: failed program was:" >&5 sed 's/^/| /' conftest.$ac_ext >&5 ac_retval=1 fi # Delete the IPA/IPO (Inter Procedural Analysis/Optimization) information # created by the PGI compiler (conftest_ipa8_conftest.oo), as it would # interfere with the next link command; also delete a directory that is # left behind by Apple's compiler. We do this before executing the actions. rm -rf conftest.dSYM conftest_ipa8_conftest.oo eval $as_lineno_stack; ${as_lineno_stack:+:} unset as_lineno as_fn_set_status $ac_retval } # ac_fn_c_try_link # ac_fn_c_check_header_compile LINENO HEADER VAR INCLUDES # ------------------------------------------------------- # Tests whether HEADER exists and can be compiled using the include files in # INCLUDES, setting the cache variable VAR accordingly. ac_fn_c_check_header_compile () { as_lineno=${as_lineno-"$1"} as_lineno_stack=as_lineno_stack=$as_lineno_stack { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $2" >&5 $as_echo_n "checking for $2... " >&6; } if eval \${$3+:} false; then : $as_echo_n "(cached) " >&6 else cat confdefs.h - <<_ACEOF >conftest.$ac_ext /* end confdefs.h. */ $4 #include <$2> _ACEOF if ac_fn_c_try_compile "$LINENO"; then : eval "$3=yes" else eval "$3=no" fi rm -f core conftest.err conftest.$ac_objext conftest.$ac_ext fi eval ac_res=\$$3 { $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_res" >&5 $as_echo "$ac_res" >&6; } eval $as_lineno_stack; ${as_lineno_stack:+:} unset as_lineno } # ac_fn_c_check_header_compile # ac_fn_c_try_cpp LINENO # ---------------------- # Try to preprocess conftest.$ac_ext, and return whether this succeeded. ac_fn_c_try_cpp () { as_lineno=${as_lineno-"$1"} as_lineno_stack=as_lineno_stack=$as_lineno_stack if { { ac_try="$ac_cpp conftest.$ac_ext" case "(($ac_try" in *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; *) ac_try_echo=$ac_try;; esac eval ac_try_echo="\"\$as_me:${as_lineno-$LINENO}: $ac_try_echo\"" $as_echo "$ac_try_echo"; } >&5 (eval "$ac_cpp conftest.$ac_ext") 2>conftest.err ac_status=$? if test -s conftest.err; then grep -v '^ *+' conftest.err >conftest.er1 cat conftest.er1 >&5 mv -f conftest.er1 conftest.err fi $as_echo "$as_me:${as_lineno-$LINENO}: \$? = $ac_status" >&5 test $ac_status = 0; } > conftest.i && { test -z "$ac_c_preproc_warn_flag$ac_c_werror_flag" || test ! -s conftest.err }; then : ac_retval=0 else $as_echo "$as_me: failed program was:" >&5 sed 's/^/| /' conftest.$ac_ext >&5 ac_retval=1 fi eval $as_lineno_stack; ${as_lineno_stack:+:} unset as_lineno as_fn_set_status $ac_retval } # ac_fn_c_try_cpp # ac_fn_c_try_run LINENO # ---------------------- # Try to link conftest.$ac_ext, and return whether this succeeded. Assumes # that executables *can* be run. ac_fn_c_try_run () { as_lineno=${as_lineno-"$1"} as_lineno_stack=as_lineno_stack=$as_lineno_stack if { { ac_try="$ac_link" case "(($ac_try" in *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; *) ac_try_echo=$ac_try;; esac eval ac_try_echo="\"\$as_me:${as_lineno-$LINENO}: $ac_try_echo\"" $as_echo "$ac_try_echo"; } >&5 (eval "$ac_link") 2>&5 ac_status=$? $as_echo "$as_me:${as_lineno-$LINENO}: \$? = $ac_status" >&5 test $ac_status = 0; } && { ac_try='./conftest$ac_exeext' { { case "(($ac_try" in *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; *) ac_try_echo=$ac_try;; esac eval ac_try_echo="\"\$as_me:${as_lineno-$LINENO}: $ac_try_echo\"" $as_echo "$ac_try_echo"; } >&5 (eval "$ac_try") 2>&5 ac_status=$? $as_echo "$as_me:${as_lineno-$LINENO}: \$? = $ac_status" >&5 test $ac_status = 0; }; }; then : ac_retval=0 else $as_echo "$as_me: program exited with status $ac_status" >&5 $as_echo "$as_me: failed program was:" >&5 sed 's/^/| /' conftest.$ac_ext >&5 ac_retval=$ac_status fi rm -rf conftest.dSYM conftest_ipa8_conftest.oo eval $as_lineno_stack; ${as_lineno_stack:+:} unset as_lineno as_fn_set_status $ac_retval } # ac_fn_c_try_run # ac_fn_c_check_func LINENO FUNC VAR # ---------------------------------- # Tests whether FUNC exists, setting the cache variable VAR accordingly ac_fn_c_check_func () { as_lineno=${as_lineno-"$1"} as_lineno_stack=as_lineno_stack=$as_lineno_stack { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $2" >&5 $as_echo_n "checking for $2... " >&6; } if eval \${$3+:} false; then : $as_echo_n "(cached) " >&6 else cat confdefs.h - <<_ACEOF >conftest.$ac_ext /* end confdefs.h. */ /* Define $2 to an innocuous variant, in case declares $2. For example, HP-UX 11i declares gettimeofday. */ #define $2 innocuous_$2 /* System header to define __stub macros and hopefully few prototypes, which can conflict with char $2 (); below. Prefer to if __STDC__ is defined, since exists even on freestanding compilers. */ #ifdef __STDC__ # include #else # include #endif #undef $2 /* Override any GCC internal prototype to avoid an error. Use char because int might match the return type of a GCC builtin and then its argument prototype would still apply. */ #ifdef __cplusplus extern "C" #endif char $2 (); /* The GNU C library defines this for functions which it implements to always fail with ENOSYS. Some functions are actually named something starting with __ and the normal name is an alias. */ #if defined __stub_$2 || defined __stub___$2 choke me #endif int main () { return $2 (); ; return 0; } _ACEOF if ac_fn_c_try_link "$LINENO"; then : eval "$3=yes" else eval "$3=no" fi rm -f core conftest.err conftest.$ac_objext \ conftest$ac_exeext conftest.$ac_ext fi eval ac_res=\$$3 { $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_res" >&5 $as_echo "$ac_res" >&6; } eval $as_lineno_stack; ${as_lineno_stack:+:} unset as_lineno } # ac_fn_c_check_func # ac_fn_c_check_header_mongrel LINENO HEADER VAR INCLUDES # ------------------------------------------------------- # Tests whether HEADER exists, giving a warning if it cannot be compiled using # the include files in INCLUDES and setting the cache variable VAR # accordingly. ac_fn_c_check_header_mongrel () { as_lineno=${as_lineno-"$1"} as_lineno_stack=as_lineno_stack=$as_lineno_stack if eval \${$3+:} false; then : { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $2" >&5 $as_echo_n "checking for $2... " >&6; } if eval \${$3+:} false; then : $as_echo_n "(cached) " >&6 fi eval ac_res=\$$3 { $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_res" >&5 $as_echo "$ac_res" >&6; } else # Is the header compilable? { $as_echo "$as_me:${as_lineno-$LINENO}: checking $2 usability" >&5 $as_echo_n "checking $2 usability... " >&6; } cat confdefs.h - <<_ACEOF >conftest.$ac_ext /* end confdefs.h. */ $4 #include <$2> _ACEOF if ac_fn_c_try_compile "$LINENO"; then : ac_header_compiler=yes else ac_header_compiler=no fi rm -f core conftest.err conftest.$ac_objext conftest.$ac_ext { $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_header_compiler" >&5 $as_echo "$ac_header_compiler" >&6; } # Is the header present? { $as_echo "$as_me:${as_lineno-$LINENO}: checking $2 presence" >&5 $as_echo_n "checking $2 presence... " >&6; } cat confdefs.h - <<_ACEOF >conftest.$ac_ext /* end confdefs.h. */ #include <$2> _ACEOF if ac_fn_c_try_cpp "$LINENO"; then : ac_header_preproc=yes else ac_header_preproc=no fi rm -f conftest.err conftest.i conftest.$ac_ext { $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_header_preproc" >&5 $as_echo "$ac_header_preproc" >&6; } # So? What about this header? case $ac_header_compiler:$ac_header_preproc:$ac_c_preproc_warn_flag in #(( yes:no: ) { $as_echo "$as_me:${as_lineno-$LINENO}: WARNING: $2: accepted by the compiler, rejected by the preprocessor!" >&5 $as_echo "$as_me: WARNING: $2: accepted by the compiler, rejected by the preprocessor!" >&2;} { $as_echo "$as_me:${as_lineno-$LINENO}: WARNING: $2: proceeding with the compiler's result" >&5 $as_echo "$as_me: WARNING: $2: proceeding with the compiler's result" >&2;} ;; no:yes:* ) { $as_echo "$as_me:${as_lineno-$LINENO}: WARNING: $2: present but cannot be compiled" >&5 $as_echo "$as_me: WARNING: $2: present but cannot be compiled" >&2;} { $as_echo "$as_me:${as_lineno-$LINENO}: WARNING: $2: check for missing prerequisite headers?" >&5 $as_echo "$as_me: WARNING: $2: check for missing prerequisite headers?" >&2;} { $as_echo "$as_me:${as_lineno-$LINENO}: WARNING: $2: see the Autoconf documentation" >&5 $as_echo "$as_me: WARNING: $2: see the Autoconf documentation" >&2;} { $as_echo "$as_me:${as_lineno-$LINENO}: WARNING: $2: section \"Present But Cannot Be Compiled\"" >&5 $as_echo "$as_me: WARNING: $2: section \"Present But Cannot Be Compiled\"" >&2;} { $as_echo "$as_me:${as_lineno-$LINENO}: WARNING: $2: proceeding with the compiler's result" >&5 $as_echo "$as_me: WARNING: $2: proceeding with the compiler's result" >&2;} ( $as_echo "## ------------------------------------------ ## ## Report this to xrdp-devel@googlegroups.com ## ## ------------------------------------------ ##" ) | sed "s/^/$as_me: WARNING: /" >&2 ;; esac { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $2" >&5 $as_echo_n "checking for $2... " >&6; } if eval \${$3+:} false; then : $as_echo_n "(cached) " >&6 else eval "$3=\$ac_header_compiler" fi eval ac_res=\$$3 { $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_res" >&5 $as_echo "$ac_res" >&6; } fi eval $as_lineno_stack; ${as_lineno_stack:+:} unset as_lineno } # ac_fn_c_check_header_mongrel cat >config.log <<_ACEOF This file contains any messages produced by compilers while running configure, to aid debugging if configure makes a mistake. It was created by xrdp $as_me 0.9.5, which was generated by GNU Autoconf 2.69. Invocation command line was $ $0 $@ _ACEOF exec 5>>config.log { cat <<_ASUNAME ## --------- ## ## Platform. ## ## --------- ## hostname = `(hostname || uname -n) 2>/dev/null | sed 1q` uname -m = `(uname -m) 2>/dev/null || echo unknown` uname -r = `(uname -r) 2>/dev/null || echo unknown` uname -s = `(uname -s) 2>/dev/null || echo unknown` uname -v = `(uname -v) 2>/dev/null || echo unknown` /usr/bin/uname -p = `(/usr/bin/uname -p) 2>/dev/null || echo unknown` /bin/uname -X = `(/bin/uname -X) 2>/dev/null || echo unknown` /bin/arch = `(/bin/arch) 2>/dev/null || echo unknown` /usr/bin/arch -k = `(/usr/bin/arch -k) 2>/dev/null || echo unknown` /usr/convex/getsysinfo = `(/usr/convex/getsysinfo) 2>/dev/null || echo unknown` /usr/bin/hostinfo = `(/usr/bin/hostinfo) 2>/dev/null || echo unknown` /bin/machine = `(/bin/machine) 2>/dev/null || echo unknown` /usr/bin/oslevel = `(/usr/bin/oslevel) 2>/dev/null || echo unknown` /bin/universe = `(/bin/universe) 2>/dev/null || echo unknown` _ASUNAME as_save_IFS=$IFS; IFS=$PATH_SEPARATOR for as_dir in $PATH do IFS=$as_save_IFS test -z "$as_dir" && as_dir=. $as_echo "PATH: $as_dir" done IFS=$as_save_IFS } >&5 cat >&5 <<_ACEOF ## ----------- ## ## Core tests. ## ## ----------- ## _ACEOF # Keep a trace of the command line. # Strip out --no-create and --no-recursion so they do not pile up. # Strip out --silent because we don't want to record it for future runs. # Also quote any args containing shell meta-characters. # Make two passes to allow for proper duplicate-argument suppression. ac_configure_args= ac_configure_args0= ac_configure_args1= ac_must_keep_next=false for ac_pass in 1 2 do for ac_arg do case $ac_arg in -no-create | --no-c* | -n | -no-recursion | --no-r*) continue ;; -q | -quiet | --quiet | --quie | --qui | --qu | --q \ | -silent | --silent | --silen | --sile | --sil) continue ;; *\'*) ac_arg=`$as_echo "$ac_arg" | sed "s/'/'\\\\\\\\''/g"` ;; esac case $ac_pass in 1) as_fn_append ac_configure_args0 " '$ac_arg'" ;; 2) as_fn_append ac_configure_args1 " '$ac_arg'" if test $ac_must_keep_next = true; then ac_must_keep_next=false # Got value, back to normal. else case $ac_arg in *=* | --config-cache | -C | -disable-* | --disable-* \ | -enable-* | --enable-* | -gas | --g* | -nfp | --nf* \ | -q | -quiet | --q* | -silent | --sil* | -v | -verb* \ | -with-* | --with-* | -without-* | --without-* | --x) case "$ac_configure_args0 " in "$ac_configure_args1"*" '$ac_arg' "* ) continue ;; esac ;; -* ) ac_must_keep_next=true ;; esac fi as_fn_append ac_configure_args " '$ac_arg'" ;; esac done done { ac_configure_args0=; unset ac_configure_args0;} { ac_configure_args1=; unset ac_configure_args1;} # When interrupted or exit'd, cleanup temporary files, and complete # config.log. We remove comments because anyway the quotes in there # would cause problems or look ugly. # WARNING: Use '\'' to represent an apostrophe within the trap. # WARNING: Do not start the trap code with a newline, due to a FreeBSD 4.0 bug. trap 'exit_status=$? # Save into config.log some information that might help in debugging. { echo $as_echo "## ---------------- ## ## Cache variables. ## ## ---------------- ##" echo # The following way of writing the cache mishandles newlines in values, ( for ac_var in `(set) 2>&1 | sed -n '\''s/^\([a-zA-Z_][a-zA-Z0-9_]*\)=.*/\1/p'\''`; do eval ac_val=\$$ac_var case $ac_val in #( *${as_nl}*) case $ac_var in #( *_cv_*) { $as_echo "$as_me:${as_lineno-$LINENO}: WARNING: cache variable $ac_var contains a newline" >&5 $as_echo "$as_me: WARNING: cache variable $ac_var contains a newline" >&2;} ;; esac case $ac_var in #( _ | IFS | as_nl) ;; #( BASH_ARGV | BASH_SOURCE) eval $ac_var= ;; #( *) { eval $ac_var=; unset $ac_var;} ;; esac ;; esac done (set) 2>&1 | case $as_nl`(ac_space='\'' '\''; set) 2>&1` in #( *${as_nl}ac_space=\ *) sed -n \ "s/'\''/'\''\\\\'\'''\''/g; s/^\\([_$as_cr_alnum]*_cv_[_$as_cr_alnum]*\\)=\\(.*\\)/\\1='\''\\2'\''/p" ;; #( *) sed -n "/^[_$as_cr_alnum]*_cv_[_$as_cr_alnum]*=/p" ;; esac | sort ) echo $as_echo "## ----------------- ## ## Output variables. ## ## ----------------- ##" echo for ac_var in $ac_subst_vars do eval ac_val=\$$ac_var case $ac_val in *\'\''*) ac_val=`$as_echo "$ac_val" | sed "s/'\''/'\''\\\\\\\\'\'''\''/g"`;; esac $as_echo "$ac_var='\''$ac_val'\''" done | sort echo if test -n "$ac_subst_files"; then $as_echo "## ------------------- ## ## File substitutions. ## ## ------------------- ##" echo for ac_var in $ac_subst_files do eval ac_val=\$$ac_var case $ac_val in *\'\''*) ac_val=`$as_echo "$ac_val" | sed "s/'\''/'\''\\\\\\\\'\'''\''/g"`;; esac $as_echo "$ac_var='\''$ac_val'\''" done | sort echo fi if test -s confdefs.h; then $as_echo "## ----------- ## ## confdefs.h. ## ## ----------- ##" echo cat confdefs.h echo fi test "$ac_signal" != 0 && $as_echo "$as_me: caught signal $ac_signal" $as_echo "$as_me: exit $exit_status" } >&5 rm -f core *.core core.conftest.* && rm -f -r conftest* confdefs* conf$$* $ac_clean_files && exit $exit_status ' 0 for ac_signal in 1 2 13 15; do trap 'ac_signal='$ac_signal'; as_fn_exit 1' $ac_signal done ac_signal=0 # confdefs.h avoids OS command line length limits that DEFS can exceed. rm -f -r conftest* confdefs.h $as_echo "/* confdefs.h */" > confdefs.h # Predefined preprocessor variables. cat >>confdefs.h <<_ACEOF #define PACKAGE_NAME "$PACKAGE_NAME" _ACEOF cat >>confdefs.h <<_ACEOF #define PACKAGE_TARNAME "$PACKAGE_TARNAME" _ACEOF cat >>confdefs.h <<_ACEOF #define PACKAGE_VERSION "$PACKAGE_VERSION" _ACEOF cat >>confdefs.h <<_ACEOF #define PACKAGE_STRING "$PACKAGE_STRING" _ACEOF cat >>confdefs.h <<_ACEOF #define PACKAGE_BUGREPORT "$PACKAGE_BUGREPORT" _ACEOF cat >>confdefs.h <<_ACEOF #define PACKAGE_URL "$PACKAGE_URL" _ACEOF # Let the site file select an alternate cache file if it wants to. # Prefer an explicitly selected file to automatically selected ones. ac_site_file1=NONE ac_site_file2=NONE if test -n "$CONFIG_SITE"; then # We do not want a PATH search for config.site. case $CONFIG_SITE in #(( -*) ac_site_file1=./$CONFIG_SITE;; */*) ac_site_file1=$CONFIG_SITE;; *) ac_site_file1=./$CONFIG_SITE;; esac elif test "x$prefix" != xNONE; then ac_site_file1=$prefix/share/config.site ac_site_file2=$prefix/etc/config.site else ac_site_file1=$ac_default_prefix/share/config.site ac_site_file2=$ac_default_prefix/etc/config.site fi for ac_site_file in "$ac_site_file1" "$ac_site_file2" do test "x$ac_site_file" = xNONE && continue if test /dev/null != "$ac_site_file" && test -r "$ac_site_file"; then { $as_echo "$as_me:${as_lineno-$LINENO}: loading site script $ac_site_file" >&5 $as_echo "$as_me: loading site script $ac_site_file" >&6;} sed 's/^/| /' "$ac_site_file" >&5 . "$ac_site_file" \ || { { $as_echo "$as_me:${as_lineno-$LINENO}: error: in \`$ac_pwd':" >&5 $as_echo "$as_me: error: in \`$ac_pwd':" >&2;} as_fn_error $? "failed to load site script $ac_site_file See \`config.log' for more details" "$LINENO" 5; } fi done if test -r "$cache_file"; then # Some versions of bash will fail to source /dev/null (special files # actually), so we avoid doing that. DJGPP emulates it as a regular file. if test /dev/null != "$cache_file" && test -f "$cache_file"; then { $as_echo "$as_me:${as_lineno-$LINENO}: loading cache $cache_file" >&5 $as_echo "$as_me: loading cache $cache_file" >&6;} case $cache_file in [\\/]* | ?:[\\/]* ) . "$cache_file";; *) . "./$cache_file";; esac fi else { $as_echo "$as_me:${as_lineno-$LINENO}: creating cache $cache_file" >&5 $as_echo "$as_me: creating cache $cache_file" >&6;} >$cache_file fi # Check that the precious variables saved in the cache have kept the same # value. ac_cache_corrupted=false for ac_var in $ac_precious_vars; do eval ac_old_set=\$ac_cv_env_${ac_var}_set eval ac_new_set=\$ac_env_${ac_var}_set eval ac_old_val=\$ac_cv_env_${ac_var}_value eval ac_new_val=\$ac_env_${ac_var}_value case $ac_old_set,$ac_new_set in set,) { $as_echo "$as_me:${as_lineno-$LINENO}: error: \`$ac_var' was set to \`$ac_old_val' in the previous run" >&5 $as_echo "$as_me: error: \`$ac_var' was set to \`$ac_old_val' in the previous run" >&2;} ac_cache_corrupted=: ;; ,set) { $as_echo "$as_me:${as_lineno-$LINENO}: error: \`$ac_var' was not set in the previous run" >&5 $as_echo "$as_me: error: \`$ac_var' was not set in the previous run" >&2;} ac_cache_corrupted=: ;; ,);; *) if test "x$ac_old_val" != "x$ac_new_val"; then # differences in whitespace do not lead to failure. ac_old_val_w=`echo x $ac_old_val` ac_new_val_w=`echo x $ac_new_val` if test "$ac_old_val_w" != "$ac_new_val_w"; then { $as_echo "$as_me:${as_lineno-$LINENO}: error: \`$ac_var' has changed since the previous run:" >&5 $as_echo "$as_me: error: \`$ac_var' has changed since the previous run:" >&2;} ac_cache_corrupted=: else { $as_echo "$as_me:${as_lineno-$LINENO}: warning: ignoring whitespace changes in \`$ac_var' since the previous run:" >&5 $as_echo "$as_me: warning: ignoring whitespace changes in \`$ac_var' since the previous run:" >&2;} eval $ac_var=\$ac_old_val fi { $as_echo "$as_me:${as_lineno-$LINENO}: former value: \`$ac_old_val'" >&5 $as_echo "$as_me: former value: \`$ac_old_val'" >&2;} { $as_echo "$as_me:${as_lineno-$LINENO}: current value: \`$ac_new_val'" >&5 $as_echo "$as_me: current value: \`$ac_new_val'" >&2;} fi;; esac # Pass precious variables to config.status. if test "$ac_new_set" = set; then case $ac_new_val in *\'*) ac_arg=$ac_var=`$as_echo "$ac_new_val" | sed "s/'/'\\\\\\\\''/g"` ;; *) ac_arg=$ac_var=$ac_new_val ;; esac case " $ac_configure_args " in *" '$ac_arg' "*) ;; # Avoid dups. Use of quotes ensures accuracy. *) as_fn_append ac_configure_args " '$ac_arg'" ;; esac fi done if $ac_cache_corrupted; then { $as_echo "$as_me:${as_lineno-$LINENO}: error: in \`$ac_pwd':" >&5 $as_echo "$as_me: error: in \`$ac_pwd':" >&2;} { $as_echo "$as_me:${as_lineno-$LINENO}: error: changes in the environment can compromise the build" >&5 $as_echo "$as_me: error: changes in the environment can compromise the build" >&2;} as_fn_error $? "run \`make distclean' and/or \`rm $cache_file' and start over" "$LINENO" 5 fi ## -------------------- ## ## Main body of script. ## ## -------------------- ## ac_ext=c ac_cpp='$CPP $CPPFLAGS' ac_compile='$CC -c $CFLAGS $CPPFLAGS conftest.$ac_ext >&5' ac_link='$CC -o conftest$ac_exeext $CFLAGS $CPPFLAGS $LDFLAGS conftest.$ac_ext $LIBS >&5' ac_compiler_gnu=$ac_cv_c_compiler_gnu ac_config_headers="$ac_config_headers config_ac.h:config_ac-h.in" am__api_version='1.15' ac_aux_dir= for ac_dir in "$srcdir" "$srcdir/.." "$srcdir/../.."; do if test -f "$ac_dir/install-sh"; then ac_aux_dir=$ac_dir ac_install_sh="$ac_aux_dir/install-sh -c" break elif test -f "$ac_dir/install.sh"; then ac_aux_dir=$ac_dir ac_install_sh="$ac_aux_dir/install.sh -c" break elif test -f "$ac_dir/shtool"; then ac_aux_dir=$ac_dir ac_install_sh="$ac_aux_dir/shtool install -c" break fi done if test -z "$ac_aux_dir"; then as_fn_error $? "cannot find install-sh, install.sh, or shtool in \"$srcdir\" \"$srcdir/..\" \"$srcdir/../..\"" "$LINENO" 5 fi # These three variables are undocumented and unsupported, # and are intended to be withdrawn in a future Autoconf release. # They can cause serious problems if a builder's source tree is in a directory # whose full name contains unusual characters. ac_config_guess="$SHELL $ac_aux_dir/config.guess" # Please don't use this var. ac_config_sub="$SHELL $ac_aux_dir/config.sub" # Please don't use this var. ac_configure="$SHELL $ac_aux_dir/configure" # Please don't use this var. # Find a good install program. We prefer a C program (faster), # so one script is as good as another. But avoid the broken or # incompatible versions: # SysV /etc/install, /usr/sbin/install # SunOS /usr/etc/install # IRIX /sbin/install # AIX /bin/install # AmigaOS /C/install, which installs bootblocks on floppy discs # AIX 4 /usr/bin/installbsd, which doesn't work without a -g flag # AFS /usr/afsws/bin/install, which mishandles nonexistent args # SVR4 /usr/ucb/install, which tries to use the nonexistent group "staff" # OS/2's system install, which has a completely different semantic # ./install, which can be erroneously created by make from ./install.sh. # Reject install programs that cannot install multiple files. { $as_echo "$as_me:${as_lineno-$LINENO}: checking for a BSD-compatible install" >&5 $as_echo_n "checking for a BSD-compatible install... " >&6; } if test -z "$INSTALL"; then if ${ac_cv_path_install+:} false; then : $as_echo_n "(cached) " >&6 else as_save_IFS=$IFS; IFS=$PATH_SEPARATOR for as_dir in $PATH do IFS=$as_save_IFS test -z "$as_dir" && as_dir=. # Account for people who put trailing slashes in PATH elements. case $as_dir/ in #(( ./ | .// | /[cC]/* | \ /etc/* | /usr/sbin/* | /usr/etc/* | /sbin/* | /usr/afsws/bin/* | \ ?:[\\/]os2[\\/]install[\\/]* | ?:[\\/]OS2[\\/]INSTALL[\\/]* | \ /usr/ucb/* ) ;; *) # OSF1 and SCO ODT 3.0 have their own names for install. # Don't use installbsd from OSF since it installs stuff as root # by default. for ac_prog in ginstall scoinst install; do for ac_exec_ext in '' $ac_executable_extensions; do if as_fn_executable_p "$as_dir/$ac_prog$ac_exec_ext"; then if test $ac_prog = install && grep dspmsg "$as_dir/$ac_prog$ac_exec_ext" >/dev/null 2>&1; then # AIX install. It has an incompatible calling convention. : elif test $ac_prog = install && grep pwplus "$as_dir/$ac_prog$ac_exec_ext" >/dev/null 2>&1; then # program-specific install script used by HP pwplus--don't use. : else rm -rf conftest.one conftest.two conftest.dir echo one > conftest.one echo two > conftest.two mkdir conftest.dir if "$as_dir/$ac_prog$ac_exec_ext" -c conftest.one conftest.two "`pwd`/conftest.dir" && test -s conftest.one && test -s conftest.two && test -s conftest.dir/conftest.one && test -s conftest.dir/conftest.two then ac_cv_path_install="$as_dir/$ac_prog$ac_exec_ext -c" break 3 fi fi fi done done ;; esac done IFS=$as_save_IFS rm -rf conftest.one conftest.two conftest.dir fi if test "${ac_cv_path_install+set}" = set; then INSTALL=$ac_cv_path_install else # As a last resort, use the slow shell script. Don't cache a # value for INSTALL within a source directory, because that will # break other packages using the cache if that directory is # removed, or if the value is a relative name. INSTALL=$ac_install_sh fi fi { $as_echo "$as_me:${as_lineno-$LINENO}: result: $INSTALL" >&5 $as_echo "$INSTALL" >&6; } # Use test -z because SunOS4 sh mishandles braces in ${var-val}. # It thinks the first close brace ends the variable substitution. test -z "$INSTALL_PROGRAM" && INSTALL_PROGRAM='${INSTALL}' test -z "$INSTALL_SCRIPT" && INSTALL_SCRIPT='${INSTALL}' test -z "$INSTALL_DATA" && INSTALL_DATA='${INSTALL} -m 644' { $as_echo "$as_me:${as_lineno-$LINENO}: checking whether build environment is sane" >&5 $as_echo_n "checking whether build environment is sane... " >&6; } # Reject unsafe characters in $srcdir or the absolute working directory # name. Accept space and tab only in the latter. am_lf=' ' case `pwd` in *[\\\"\#\$\&\'\`$am_lf]*) as_fn_error $? "unsafe absolute working directory name" "$LINENO" 5;; esac case $srcdir in *[\\\"\#\$\&\'\`$am_lf\ \ ]*) as_fn_error $? "unsafe srcdir value: '$srcdir'" "$LINENO" 5;; esac # Do 'set' in a subshell so we don't clobber the current shell's # arguments. Must try -L first in case configure is actually a # symlink; some systems play weird games with the mod time of symlinks # (eg FreeBSD returns the mod time of the symlink's containing # directory). if ( am_has_slept=no for am_try in 1 2; do echo "timestamp, slept: $am_has_slept" > conftest.file set X `ls -Lt "$srcdir/configure" conftest.file 2> /dev/null` if test "$*" = "X"; then # -L didn't work. set X `ls -t "$srcdir/configure" conftest.file` fi if test "$*" != "X $srcdir/configure conftest.file" \ && test "$*" != "X conftest.file $srcdir/configure"; then # If neither matched, then we have a broken ls. This can happen # if, for instance, CONFIG_SHELL is bash and it inherits a # broken ls alias from the environment. This has actually # happened. Such a system could not be considered "sane". as_fn_error $? "ls -t appears to fail. Make sure there is not a broken alias in your environment" "$LINENO" 5 fi if test "$2" = conftest.file || test $am_try -eq 2; then break fi # Just in case. sleep 1 am_has_slept=yes done test "$2" = conftest.file ) then # Ok. : else as_fn_error $? "newly created file is older than distributed files! Check your system clock" "$LINENO" 5 fi { $as_echo "$as_me:${as_lineno-$LINENO}: result: yes" >&5 $as_echo "yes" >&6; } # If we didn't sleep, we still need to ensure time stamps of config.status and # generated files are strictly newer. am_sleep_pid= if grep 'slept: no' conftest.file >/dev/null 2>&1; then ( sleep 1 ) & am_sleep_pid=$! fi rm -f conftest.file test "$program_prefix" != NONE && program_transform_name="s&^&$program_prefix&;$program_transform_name" # Use a double $ so make ignores it. test "$program_suffix" != NONE && program_transform_name="s&\$&$program_suffix&;$program_transform_name" # Double any \ or $. # By default was `s,x,x', remove it if useless. ac_script='s/[\\$]/&&/g;s/;s,x,x,$//' program_transform_name=`$as_echo "$program_transform_name" | sed "$ac_script"` # Expand $ac_aux_dir to an absolute path. am_aux_dir=`cd "$ac_aux_dir" && pwd` if test x"${MISSING+set}" != xset; then case $am_aux_dir in *\ * | *\ *) MISSING="\${SHELL} \"$am_aux_dir/missing\"" ;; *) MISSING="\${SHELL} $am_aux_dir/missing" ;; esac fi # Use eval to expand $SHELL if eval "$MISSING --is-lightweight"; then am_missing_run="$MISSING " else am_missing_run= { $as_echo "$as_me:${as_lineno-$LINENO}: WARNING: 'missing' script is too old or missing" >&5 $as_echo "$as_me: WARNING: 'missing' script is too old or missing" >&2;} fi if test x"${install_sh+set}" != xset; then case $am_aux_dir in *\ * | *\ *) install_sh="\${SHELL} '$am_aux_dir/install-sh'" ;; *) install_sh="\${SHELL} $am_aux_dir/install-sh" esac fi # Installed binaries are usually stripped using 'strip' when the user # run "make install-strip". However 'strip' might not be the right # tool to use in cross-compilation environments, therefore Automake # will honor the 'STRIP' environment variable to overrule this program. if test "$cross_compiling" != no; then if test -n "$ac_tool_prefix"; then # Extract the first word of "${ac_tool_prefix}strip", so it can be a program name with args. set dummy ${ac_tool_prefix}strip; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } if ${ac_cv_prog_STRIP+:} false; then : $as_echo_n "(cached) " >&6 else if test -n "$STRIP"; then ac_cv_prog_STRIP="$STRIP" # Let the user override the test. else as_save_IFS=$IFS; IFS=$PATH_SEPARATOR for as_dir in $PATH do IFS=$as_save_IFS test -z "$as_dir" && as_dir=. for ac_exec_ext in '' $ac_executable_extensions; do if as_fn_executable_p "$as_dir/$ac_word$ac_exec_ext"; then ac_cv_prog_STRIP="${ac_tool_prefix}strip" $as_echo "$as_me:${as_lineno-$LINENO}: found $as_dir/$ac_word$ac_exec_ext" >&5 break 2 fi done done IFS=$as_save_IFS fi fi STRIP=$ac_cv_prog_STRIP if test -n "$STRIP"; then { $as_echo "$as_me:${as_lineno-$LINENO}: result: $STRIP" >&5 $as_echo "$STRIP" >&6; } else { $as_echo "$as_me:${as_lineno-$LINENO}: result: no" >&5 $as_echo "no" >&6; } fi fi if test -z "$ac_cv_prog_STRIP"; then ac_ct_STRIP=$STRIP # Extract the first word of "strip", so it can be a program name with args. set dummy strip; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } if ${ac_cv_prog_ac_ct_STRIP+:} false; then : $as_echo_n "(cached) " >&6 else if test -n "$ac_ct_STRIP"; then ac_cv_prog_ac_ct_STRIP="$ac_ct_STRIP" # Let the user override the test. else as_save_IFS=$IFS; IFS=$PATH_SEPARATOR for as_dir in $PATH do IFS=$as_save_IFS test -z "$as_dir" && as_dir=. for ac_exec_ext in '' $ac_executable_extensions; do if as_fn_executable_p "$as_dir/$ac_word$ac_exec_ext"; then ac_cv_prog_ac_ct_STRIP="strip" $as_echo "$as_me:${as_lineno-$LINENO}: found $as_dir/$ac_word$ac_exec_ext" >&5 break 2 fi done done IFS=$as_save_IFS fi fi ac_ct_STRIP=$ac_cv_prog_ac_ct_STRIP if test -n "$ac_ct_STRIP"; then { $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_ct_STRIP" >&5 $as_echo "$ac_ct_STRIP" >&6; } else { $as_echo "$as_me:${as_lineno-$LINENO}: result: no" >&5 $as_echo "no" >&6; } fi if test "x$ac_ct_STRIP" = x; then STRIP=":" else case $cross_compiling:$ac_tool_warned in yes:) { $as_echo "$as_me:${as_lineno-$LINENO}: WARNING: using cross tools not prefixed with host triplet" >&5 $as_echo "$as_me: WARNING: using cross tools not prefixed with host triplet" >&2;} ac_tool_warned=yes ;; esac STRIP=$ac_ct_STRIP fi else STRIP="$ac_cv_prog_STRIP" fi fi INSTALL_STRIP_PROGRAM="\$(install_sh) -c -s" { $as_echo "$as_me:${as_lineno-$LINENO}: checking for a thread-safe mkdir -p" >&5 $as_echo_n "checking for a thread-safe mkdir -p... " >&6; } if test -z "$MKDIR_P"; then if ${ac_cv_path_mkdir+:} false; then : $as_echo_n "(cached) " >&6 else as_save_IFS=$IFS; IFS=$PATH_SEPARATOR for as_dir in $PATH$PATH_SEPARATOR/opt/sfw/bin do IFS=$as_save_IFS test -z "$as_dir" && as_dir=. for ac_prog in mkdir gmkdir; do for ac_exec_ext in '' $ac_executable_extensions; do as_fn_executable_p "$as_dir/$ac_prog$ac_exec_ext" || continue case `"$as_dir/$ac_prog$ac_exec_ext" --version 2>&1` in #( 'mkdir (GNU coreutils) '* | \ 'mkdir (coreutils) '* | \ 'mkdir (fileutils) '4.1*) ac_cv_path_mkdir=$as_dir/$ac_prog$ac_exec_ext break 3;; esac done done done IFS=$as_save_IFS fi test -d ./--version && rmdir ./--version if test "${ac_cv_path_mkdir+set}" = set; then MKDIR_P="$ac_cv_path_mkdir -p" else # As a last resort, use the slow shell script. Don't cache a # value for MKDIR_P within a source directory, because that will # break other packages using the cache if that directory is # removed, or if the value is a relative name. MKDIR_P="$ac_install_sh -d" fi fi { $as_echo "$as_me:${as_lineno-$LINENO}: result: $MKDIR_P" >&5 $as_echo "$MKDIR_P" >&6; } for ac_prog in gawk mawk nawk awk do # Extract the first word of "$ac_prog", so it can be a program name with args. set dummy $ac_prog; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } if ${ac_cv_prog_AWK+:} false; then : $as_echo_n "(cached) " >&6 else if test -n "$AWK"; then ac_cv_prog_AWK="$AWK" # Let the user override the test. else as_save_IFS=$IFS; IFS=$PATH_SEPARATOR for as_dir in $PATH do IFS=$as_save_IFS test -z "$as_dir" && as_dir=. for ac_exec_ext in '' $ac_executable_extensions; do if as_fn_executable_p "$as_dir/$ac_word$ac_exec_ext"; then ac_cv_prog_AWK="$ac_prog" $as_echo "$as_me:${as_lineno-$LINENO}: found $as_dir/$ac_word$ac_exec_ext" >&5 break 2 fi done done IFS=$as_save_IFS fi fi AWK=$ac_cv_prog_AWK if test -n "$AWK"; then { $as_echo "$as_me:${as_lineno-$LINENO}: result: $AWK" >&5 $as_echo "$AWK" >&6; } else { $as_echo "$as_me:${as_lineno-$LINENO}: result: no" >&5 $as_echo "no" >&6; } fi test -n "$AWK" && break done { $as_echo "$as_me:${as_lineno-$LINENO}: checking whether ${MAKE-make} sets \$(MAKE)" >&5 $as_echo_n "checking whether ${MAKE-make} sets \$(MAKE)... " >&6; } set x ${MAKE-make} ac_make=`$as_echo "$2" | sed 's/+/p/g; s/[^a-zA-Z0-9_]/_/g'` if eval \${ac_cv_prog_make_${ac_make}_set+:} false; then : $as_echo_n "(cached) " >&6 else cat >conftest.make <<\_ACEOF SHELL = /bin/sh all: @echo '@@@%%%=$(MAKE)=@@@%%%' _ACEOF # GNU make sometimes prints "make[1]: Entering ...", which would confuse us. case `${MAKE-make} -f conftest.make 2>/dev/null` in *@@@%%%=?*=@@@%%%*) eval ac_cv_prog_make_${ac_make}_set=yes;; *) eval ac_cv_prog_make_${ac_make}_set=no;; esac rm -f conftest.make fi if eval test \$ac_cv_prog_make_${ac_make}_set = yes; then { $as_echo "$as_me:${as_lineno-$LINENO}: result: yes" >&5 $as_echo "yes" >&6; } SET_MAKE= else { $as_echo "$as_me:${as_lineno-$LINENO}: result: no" >&5 $as_echo "no" >&6; } SET_MAKE="MAKE=${MAKE-make}" fi rm -rf .tst 2>/dev/null mkdir .tst 2>/dev/null if test -d .tst; then am__leading_dot=. else am__leading_dot=_ fi rmdir .tst 2>/dev/null # Check whether --enable-silent-rules was given. if test "${enable_silent_rules+set}" = set; then : enableval=$enable_silent_rules; fi case $enable_silent_rules in # ((( yes) AM_DEFAULT_VERBOSITY=0;; no) AM_DEFAULT_VERBOSITY=1;; *) AM_DEFAULT_VERBOSITY=1;; esac am_make=${MAKE-make} { $as_echo "$as_me:${as_lineno-$LINENO}: checking whether $am_make supports nested variables" >&5 $as_echo_n "checking whether $am_make supports nested variables... " >&6; } if ${am_cv_make_support_nested_variables+:} false; then : $as_echo_n "(cached) " >&6 else if $as_echo 'TRUE=$(BAR$(V)) BAR0=false BAR1=true V=1 am__doit: @$(TRUE) .PHONY: am__doit' | $am_make -f - >/dev/null 2>&1; then am_cv_make_support_nested_variables=yes else am_cv_make_support_nested_variables=no fi fi { $as_echo "$as_me:${as_lineno-$LINENO}: result: $am_cv_make_support_nested_variables" >&5 $as_echo "$am_cv_make_support_nested_variables" >&6; } if test $am_cv_make_support_nested_variables = yes; then AM_V='$(V)' AM_DEFAULT_V='$(AM_DEFAULT_VERBOSITY)' else AM_V=$AM_DEFAULT_VERBOSITY AM_DEFAULT_V=$AM_DEFAULT_VERBOSITY fi AM_BACKSLASH='\' if test "`cd $srcdir && pwd`" != "`pwd`"; then # Use -I$(srcdir) only when $(srcdir) != ., so that make's output # is not polluted with repeated "-I." am__isrc=' -I$(srcdir)' # test to see if srcdir already configured if test -f $srcdir/config.status; then as_fn_error $? "source directory already configured; run \"make distclean\" there first" "$LINENO" 5 fi fi # test whether we have cygpath if test -z "$CYGPATH_W"; then if (cygpath --version) >/dev/null 2>/dev/null; then CYGPATH_W='cygpath -w' else CYGPATH_W=echo fi fi # Define the identity of the package. PACKAGE='xrdp' VERSION='0.9.5' cat >>confdefs.h <<_ACEOF #define PACKAGE "$PACKAGE" _ACEOF cat >>confdefs.h <<_ACEOF #define VERSION "$VERSION" _ACEOF # Some tools Automake needs. ACLOCAL=${ACLOCAL-"${am_missing_run}aclocal-${am__api_version}"} AUTOCONF=${AUTOCONF-"${am_missing_run}autoconf"} AUTOMAKE=${AUTOMAKE-"${am_missing_run}automake-${am__api_version}"} AUTOHEADER=${AUTOHEADER-"${am_missing_run}autoheader"} MAKEINFO=${MAKEINFO-"${am_missing_run}makeinfo"} # For better backward compatibility. To be removed once Automake 1.9.x # dies out for good. For more background, see: # # mkdir_p='$(MKDIR_P)' # We need awk for the "check" target (and possibly the TAP driver). The # system "awk" is bad on some platforms. # Always define AMTAR for backward compatibility. Yes, it's still used # in the wild :-( We should find a proper way to deprecate it ... AMTAR='$${TAR-tar}' # We'll loop over all known methods to create a tar archive until one works. _am_tools='gnutar pax cpio none' am__tar='$${TAR-tar} chof - "$$tardir"' am__untar='$${TAR-tar} xf -' # POSIX will say in a future version that running "rm -f" with no argument # is OK; and we want to be able to make that assumption in our Makefile # recipes. So use an aggressive probe to check that the usage we want is # actually supported "in the wild" to an acceptable degree. # See automake bug#10828. # To make any issue more visible, cause the running configure to be aborted # by default if the 'rm' program in use doesn't match our expectations; the # user can still override this though. if rm -f && rm -fr && rm -rf; then : OK; else cat >&2 <<'END' Oops! Your 'rm' program seems unable to run without file operands specified on the command line, even when the '-f' option is present. This is contrary to the behaviour of most rm programs out there, and not conforming with the upcoming POSIX standard: Please tell bug-automake@gnu.org about your system, including the value of your $PATH and any error possibly output before this message. This can help us improve future automake versions. END if test x"$ACCEPT_INFERIOR_RM_PROGRAM" = x"yes"; then echo 'Configuration will proceed anyway, since you have set the' >&2 echo 'ACCEPT_INFERIOR_RM_PROGRAM variable to "yes"' >&2 echo >&2 else cat >&2 <<'END' Aborting the configuration process, to ensure you take notice of the issue. You can download and install GNU coreutils to get an 'rm' implementation that behaves properly: . If you want to complete the configuration process using your problematic 'rm' anyway, export the environment variable ACCEPT_INFERIOR_RM_PROGRAM to "yes", and re-run configure. END as_fn_error $? "Your 'rm' program is bad, sorry." "$LINENO" 5 fi fi ac_ext=c ac_cpp='$CPP $CPPFLAGS' ac_compile='$CC -c $CFLAGS $CPPFLAGS conftest.$ac_ext >&5' ac_link='$CC -o conftest$ac_exeext $CFLAGS $CPPFLAGS $LDFLAGS conftest.$ac_ext $LIBS >&5' ac_compiler_gnu=$ac_cv_c_compiler_gnu if test -n "$ac_tool_prefix"; then # Extract the first word of "${ac_tool_prefix}gcc", so it can be a program name with args. set dummy ${ac_tool_prefix}gcc; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } if ${ac_cv_prog_CC+:} false; then : $as_echo_n "(cached) " >&6 else if test -n "$CC"; then ac_cv_prog_CC="$CC" # Let the user override the test. else as_save_IFS=$IFS; IFS=$PATH_SEPARATOR for as_dir in $PATH do IFS=$as_save_IFS test -z "$as_dir" && as_dir=. for ac_exec_ext in '' $ac_executable_extensions; do if as_fn_executable_p "$as_dir/$ac_word$ac_exec_ext"; then ac_cv_prog_CC="${ac_tool_prefix}gcc" $as_echo "$as_me:${as_lineno-$LINENO}: found $as_dir/$ac_word$ac_exec_ext" >&5 break 2 fi done done IFS=$as_save_IFS fi fi CC=$ac_cv_prog_CC if test -n "$CC"; then { $as_echo "$as_me:${as_lineno-$LINENO}: result: $CC" >&5 $as_echo "$CC" >&6; } else { $as_echo "$as_me:${as_lineno-$LINENO}: result: no" >&5 $as_echo "no" >&6; } fi fi if test -z "$ac_cv_prog_CC"; then ac_ct_CC=$CC # Extract the first word of "gcc", so it can be a program name with args. set dummy gcc; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } if ${ac_cv_prog_ac_ct_CC+:} false; then : $as_echo_n "(cached) " >&6 else if test -n "$ac_ct_CC"; then ac_cv_prog_ac_ct_CC="$ac_ct_CC" # Let the user override the test. else as_save_IFS=$IFS; IFS=$PATH_SEPARATOR for as_dir in $PATH do IFS=$as_save_IFS test -z "$as_dir" && as_dir=. for ac_exec_ext in '' $ac_executable_extensions; do if as_fn_executable_p "$as_dir/$ac_word$ac_exec_ext"; then ac_cv_prog_ac_ct_CC="gcc" $as_echo "$as_me:${as_lineno-$LINENO}: found $as_dir/$ac_word$ac_exec_ext" >&5 break 2 fi done done IFS=$as_save_IFS fi fi ac_ct_CC=$ac_cv_prog_ac_ct_CC if test -n "$ac_ct_CC"; then { $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_ct_CC" >&5 $as_echo "$ac_ct_CC" >&6; } else { $as_echo "$as_me:${as_lineno-$LINENO}: result: no" >&5 $as_echo "no" >&6; } fi if test "x$ac_ct_CC" = x; then CC="" else case $cross_compiling:$ac_tool_warned in yes:) { $as_echo "$as_me:${as_lineno-$LINENO}: WARNING: using cross tools not prefixed with host triplet" >&5 $as_echo "$as_me: WARNING: using cross tools not prefixed with host triplet" >&2;} ac_tool_warned=yes ;; esac CC=$ac_ct_CC fi else CC="$ac_cv_prog_CC" fi if test -z "$CC"; then if test -n "$ac_tool_prefix"; then # Extract the first word of "${ac_tool_prefix}cc", so it can be a program name with args. set dummy ${ac_tool_prefix}cc; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } if ${ac_cv_prog_CC+:} false; then : $as_echo_n "(cached) " >&6 else if test -n "$CC"; then ac_cv_prog_CC="$CC" # Let the user override the test. else as_save_IFS=$IFS; IFS=$PATH_SEPARATOR for as_dir in $PATH do IFS=$as_save_IFS test -z "$as_dir" && as_dir=. for ac_exec_ext in '' $ac_executable_extensions; do if as_fn_executable_p "$as_dir/$ac_word$ac_exec_ext"; then ac_cv_prog_CC="${ac_tool_prefix}cc" $as_echo "$as_me:${as_lineno-$LINENO}: found $as_dir/$ac_word$ac_exec_ext" >&5 break 2 fi done done IFS=$as_save_IFS fi fi CC=$ac_cv_prog_CC if test -n "$CC"; then { $as_echo "$as_me:${as_lineno-$LINENO}: result: $CC" >&5 $as_echo "$CC" >&6; } else { $as_echo "$as_me:${as_lineno-$LINENO}: result: no" >&5 $as_echo "no" >&6; } fi fi fi if test -z "$CC"; then # Extract the first word of "cc", so it can be a program name with args. set dummy cc; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } if ${ac_cv_prog_CC+:} false; then : $as_echo_n "(cached) " >&6 else if test -n "$CC"; then ac_cv_prog_CC="$CC" # Let the user override the test. else ac_prog_rejected=no as_save_IFS=$IFS; IFS=$PATH_SEPARATOR for as_dir in $PATH do IFS=$as_save_IFS test -z "$as_dir" && as_dir=. for ac_exec_ext in '' $ac_executable_extensions; do if as_fn_executable_p "$as_dir/$ac_word$ac_exec_ext"; then if test "$as_dir/$ac_word$ac_exec_ext" = "/usr/ucb/cc"; then ac_prog_rejected=yes continue fi ac_cv_prog_CC="cc" $as_echo "$as_me:${as_lineno-$LINENO}: found $as_dir/$ac_word$ac_exec_ext" >&5 break 2 fi done done IFS=$as_save_IFS if test $ac_prog_rejected = yes; then # We found a bogon in the path, so make sure we never use it. set dummy $ac_cv_prog_CC shift if test $# != 0; then # We chose a different compiler from the bogus one. # However, it has the same basename, so the bogon will be chosen # first if we set CC to just the basename; use the full file name. shift ac_cv_prog_CC="$as_dir/$ac_word${1+' '}$@" fi fi fi fi CC=$ac_cv_prog_CC if test -n "$CC"; then { $as_echo "$as_me:${as_lineno-$LINENO}: result: $CC" >&5 $as_echo "$CC" >&6; } else { $as_echo "$as_me:${as_lineno-$LINENO}: result: no" >&5 $as_echo "no" >&6; } fi fi if test -z "$CC"; then if test -n "$ac_tool_prefix"; then for ac_prog in cl.exe do # Extract the first word of "$ac_tool_prefix$ac_prog", so it can be a program name with args. set dummy $ac_tool_prefix$ac_prog; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } if ${ac_cv_prog_CC+:} false; then : $as_echo_n "(cached) " >&6 else if test -n "$CC"; then ac_cv_prog_CC="$CC" # Let the user override the test. else as_save_IFS=$IFS; IFS=$PATH_SEPARATOR for as_dir in $PATH do IFS=$as_save_IFS test -z "$as_dir" && as_dir=. for ac_exec_ext in '' $ac_executable_extensions; do if as_fn_executable_p "$as_dir/$ac_word$ac_exec_ext"; then ac_cv_prog_CC="$ac_tool_prefix$ac_prog" $as_echo "$as_me:${as_lineno-$LINENO}: found $as_dir/$ac_word$ac_exec_ext" >&5 break 2 fi done done IFS=$as_save_IFS fi fi CC=$ac_cv_prog_CC if test -n "$CC"; then { $as_echo "$as_me:${as_lineno-$LINENO}: result: $CC" >&5 $as_echo "$CC" >&6; } else { $as_echo "$as_me:${as_lineno-$LINENO}: result: no" >&5 $as_echo "no" >&6; } fi test -n "$CC" && break done fi if test -z "$CC"; then ac_ct_CC=$CC for ac_prog in cl.exe do # Extract the first word of "$ac_prog", so it can be a program name with args. set dummy $ac_prog; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } if ${ac_cv_prog_ac_ct_CC+:} false; then : $as_echo_n "(cached) " >&6 else if test -n "$ac_ct_CC"; then ac_cv_prog_ac_ct_CC="$ac_ct_CC" # Let the user override the test. else as_save_IFS=$IFS; IFS=$PATH_SEPARATOR for as_dir in $PATH do IFS=$as_save_IFS test -z "$as_dir" && as_dir=. for ac_exec_ext in '' $ac_executable_extensions; do if as_fn_executable_p "$as_dir/$ac_word$ac_exec_ext"; then ac_cv_prog_ac_ct_CC="$ac_prog" $as_echo "$as_me:${as_lineno-$LINENO}: found $as_dir/$ac_word$ac_exec_ext" >&5 break 2 fi done done IFS=$as_save_IFS fi fi ac_ct_CC=$ac_cv_prog_ac_ct_CC if test -n "$ac_ct_CC"; then { $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_ct_CC" >&5 $as_echo "$ac_ct_CC" >&6; } else { $as_echo "$as_me:${as_lineno-$LINENO}: result: no" >&5 $as_echo "no" >&6; } fi test -n "$ac_ct_CC" && break done if test "x$ac_ct_CC" = x; then CC="" else case $cross_compiling:$ac_tool_warned in yes:) { $as_echo "$as_me:${as_lineno-$LINENO}: WARNING: using cross tools not prefixed with host triplet" >&5 $as_echo "$as_me: WARNING: using cross tools not prefixed with host triplet" >&2;} ac_tool_warned=yes ;; esac CC=$ac_ct_CC fi fi fi test -z "$CC" && { { $as_echo "$as_me:${as_lineno-$LINENO}: error: in \`$ac_pwd':" >&5 $as_echo "$as_me: error: in \`$ac_pwd':" >&2;} as_fn_error $? "no acceptable C compiler found in \$PATH See \`config.log' for more details" "$LINENO" 5; } # Provide some information about the compiler. $as_echo "$as_me:${as_lineno-$LINENO}: checking for C compiler version" >&5 set X $ac_compile ac_compiler=$2 for ac_option in --version -v -V -qversion; do { { ac_try="$ac_compiler $ac_option >&5" case "(($ac_try" in *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; *) ac_try_echo=$ac_try;; esac eval ac_try_echo="\"\$as_me:${as_lineno-$LINENO}: $ac_try_echo\"" $as_echo "$ac_try_echo"; } >&5 (eval "$ac_compiler $ac_option >&5") 2>conftest.err ac_status=$? if test -s conftest.err; then sed '10a\ ... rest of stderr output deleted ... 10q' conftest.err >conftest.er1 cat conftest.er1 >&5 fi rm -f conftest.er1 conftest.err $as_echo "$as_me:${as_lineno-$LINENO}: \$? = $ac_status" >&5 test $ac_status = 0; } done cat confdefs.h - <<_ACEOF >conftest.$ac_ext /* end confdefs.h. */ int main () { ; return 0; } _ACEOF ac_clean_files_save=$ac_clean_files ac_clean_files="$ac_clean_files a.out a.out.dSYM a.exe b.out" # Try to create an executable without -o first, disregard a.out. # It will help us diagnose broken compilers, and finding out an intuition # of exeext. { $as_echo "$as_me:${as_lineno-$LINENO}: checking whether the C compiler works" >&5 $as_echo_n "checking whether the C compiler works... " >&6; } ac_link_default=`$as_echo "$ac_link" | sed 's/ -o *conftest[^ ]*//'` # The possible output files: ac_files="a.out conftest.exe conftest a.exe a_out.exe b.out conftest.*" ac_rmfiles= for ac_file in $ac_files do case $ac_file in *.$ac_ext | *.xcoff | *.tds | *.d | *.pdb | *.xSYM | *.bb | *.bbg | *.map | *.inf | *.dSYM | *.o | *.obj ) ;; * ) ac_rmfiles="$ac_rmfiles $ac_file";; esac done rm -f $ac_rmfiles if { { ac_try="$ac_link_default" case "(($ac_try" in *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; *) ac_try_echo=$ac_try;; esac eval ac_try_echo="\"\$as_me:${as_lineno-$LINENO}: $ac_try_echo\"" $as_echo "$ac_try_echo"; } >&5 (eval "$ac_link_default") 2>&5 ac_status=$? $as_echo "$as_me:${as_lineno-$LINENO}: \$? = $ac_status" >&5 test $ac_status = 0; }; then : # Autoconf-2.13 could set the ac_cv_exeext variable to `no'. # So ignore a value of `no', otherwise this would lead to `EXEEXT = no' # in a Makefile. We should not override ac_cv_exeext if it was cached, # so that the user can short-circuit this test for compilers unknown to # Autoconf. for ac_file in $ac_files '' do test -f "$ac_file" || continue case $ac_file in *.$ac_ext | *.xcoff | *.tds | *.d | *.pdb | *.xSYM | *.bb | *.bbg | *.map | *.inf | *.dSYM | *.o | *.obj ) ;; [ab].out ) # We found the default executable, but exeext='' is most # certainly right. break;; *.* ) if test "${ac_cv_exeext+set}" = set && test "$ac_cv_exeext" != no; then :; else ac_cv_exeext=`expr "$ac_file" : '[^.]*\(\..*\)'` fi # We set ac_cv_exeext here because the later test for it is not # safe: cross compilers may not add the suffix if given an `-o' # argument, so we may need to know it at that point already. # Even if this section looks crufty: it has the advantage of # actually working. break;; * ) break;; esac done test "$ac_cv_exeext" = no && ac_cv_exeext= else ac_file='' fi if test -z "$ac_file"; then : { $as_echo "$as_me:${as_lineno-$LINENO}: result: no" >&5 $as_echo "no" >&6; } $as_echo "$as_me: failed program was:" >&5 sed 's/^/| /' conftest.$ac_ext >&5 { { $as_echo "$as_me:${as_lineno-$LINENO}: error: in \`$ac_pwd':" >&5 $as_echo "$as_me: error: in \`$ac_pwd':" >&2;} as_fn_error 77 "C compiler cannot create executables See \`config.log' for more details" "$LINENO" 5; } else { $as_echo "$as_me:${as_lineno-$LINENO}: result: yes" >&5 $as_echo "yes" >&6; } fi { $as_echo "$as_me:${as_lineno-$LINENO}: checking for C compiler default output file name" >&5 $as_echo_n "checking for C compiler default output file name... " >&6; } { $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_file" >&5 $as_echo "$ac_file" >&6; } ac_exeext=$ac_cv_exeext rm -f -r a.out a.out.dSYM a.exe conftest$ac_cv_exeext b.out ac_clean_files=$ac_clean_files_save { $as_echo "$as_me:${as_lineno-$LINENO}: checking for suffix of executables" >&5 $as_echo_n "checking for suffix of executables... " >&6; } if { { ac_try="$ac_link" case "(($ac_try" in *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; *) ac_try_echo=$ac_try;; esac eval ac_try_echo="\"\$as_me:${as_lineno-$LINENO}: $ac_try_echo\"" $as_echo "$ac_try_echo"; } >&5 (eval "$ac_link") 2>&5 ac_status=$? $as_echo "$as_me:${as_lineno-$LINENO}: \$? = $ac_status" >&5 test $ac_status = 0; }; then : # If both `conftest.exe' and `conftest' are `present' (well, observable) # catch `conftest.exe'. For instance with Cygwin, `ls conftest' will # work properly (i.e., refer to `conftest.exe'), while it won't with # `rm'. for ac_file in conftest.exe conftest conftest.*; do test -f "$ac_file" || continue case $ac_file in *.$ac_ext | *.xcoff | *.tds | *.d | *.pdb | *.xSYM | *.bb | *.bbg | *.map | *.inf | *.dSYM | *.o | *.obj ) ;; *.* ) ac_cv_exeext=`expr "$ac_file" : '[^.]*\(\..*\)'` break;; * ) break;; esac done else { { $as_echo "$as_me:${as_lineno-$LINENO}: error: in \`$ac_pwd':" >&5 $as_echo "$as_me: error: in \`$ac_pwd':" >&2;} as_fn_error $? "cannot compute suffix of executables: cannot compile and link See \`config.log' for more details" "$LINENO" 5; } fi rm -f conftest conftest$ac_cv_exeext { $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_cv_exeext" >&5 $as_echo "$ac_cv_exeext" >&6; } rm -f conftest.$ac_ext EXEEXT=$ac_cv_exeext ac_exeext=$EXEEXT cat confdefs.h - <<_ACEOF >conftest.$ac_ext /* end confdefs.h. */ #include int main () { FILE *f = fopen ("conftest.out", "w"); return ferror (f) || fclose (f) != 0; ; return 0; } _ACEOF ac_clean_files="$ac_clean_files conftest.out" # Check that the compiler produces executables we can run. If not, either # the compiler is broken, or we cross compile. { $as_echo "$as_me:${as_lineno-$LINENO}: checking whether we are cross compiling" >&5 $as_echo_n "checking whether we are cross compiling... " >&6; } if test "$cross_compiling" != yes; then { { ac_try="$ac_link" case "(($ac_try" in *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; *) ac_try_echo=$ac_try;; esac eval ac_try_echo="\"\$as_me:${as_lineno-$LINENO}: $ac_try_echo\"" $as_echo "$ac_try_echo"; } >&5 (eval "$ac_link") 2>&5 ac_status=$? $as_echo "$as_me:${as_lineno-$LINENO}: \$? = $ac_status" >&5 test $ac_status = 0; } if { ac_try='./conftest$ac_cv_exeext' { { case "(($ac_try" in *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; *) ac_try_echo=$ac_try;; esac eval ac_try_echo="\"\$as_me:${as_lineno-$LINENO}: $ac_try_echo\"" $as_echo "$ac_try_echo"; } >&5 (eval "$ac_try") 2>&5 ac_status=$? $as_echo "$as_me:${as_lineno-$LINENO}: \$? = $ac_status" >&5 test $ac_status = 0; }; }; then cross_compiling=no else if test "$cross_compiling" = maybe; then cross_compiling=yes else { { $as_echo "$as_me:${as_lineno-$LINENO}: error: in \`$ac_pwd':" >&5 $as_echo "$as_me: error: in \`$ac_pwd':" >&2;} as_fn_error $? "cannot run C compiled programs. If you meant to cross compile, use \`--host'. See \`config.log' for more details" "$LINENO" 5; } fi fi fi { $as_echo "$as_me:${as_lineno-$LINENO}: result: $cross_compiling" >&5 $as_echo "$cross_compiling" >&6; } rm -f conftest.$ac_ext conftest$ac_cv_exeext conftest.out ac_clean_files=$ac_clean_files_save { $as_echo "$as_me:${as_lineno-$LINENO}: checking for suffix of object files" >&5 $as_echo_n "checking for suffix of object files... " >&6; } if ${ac_cv_objext+:} false; then : $as_echo_n "(cached) " >&6 else cat confdefs.h - <<_ACEOF >conftest.$ac_ext /* end confdefs.h. */ int main () { ; return 0; } _ACEOF rm -f conftest.o conftest.obj if { { ac_try="$ac_compile" case "(($ac_try" in *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; *) ac_try_echo=$ac_try;; esac eval ac_try_echo="\"\$as_me:${as_lineno-$LINENO}: $ac_try_echo\"" $as_echo "$ac_try_echo"; } >&5 (eval "$ac_compile") 2>&5 ac_status=$? $as_echo "$as_me:${as_lineno-$LINENO}: \$? = $ac_status" >&5 test $ac_status = 0; }; then : for ac_file in conftest.o conftest.obj conftest.*; do test -f "$ac_file" || continue; case $ac_file in *.$ac_ext | *.xcoff | *.tds | *.d | *.pdb | *.xSYM | *.bb | *.bbg | *.map | *.inf | *.dSYM ) ;; *) ac_cv_objext=`expr "$ac_file" : '.*\.\(.*\)'` break;; esac done else $as_echo "$as_me: failed program was:" >&5 sed 's/^/| /' conftest.$ac_ext >&5 { { $as_echo "$as_me:${as_lineno-$LINENO}: error: in \`$ac_pwd':" >&5 $as_echo "$as_me: error: in \`$ac_pwd':" >&2;} as_fn_error $? "cannot compute suffix of object files: cannot compile See \`config.log' for more details" "$LINENO" 5; } fi rm -f conftest.$ac_cv_objext conftest.$ac_ext fi { $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_cv_objext" >&5 $as_echo "$ac_cv_objext" >&6; } OBJEXT=$ac_cv_objext ac_objext=$OBJEXT { $as_echo "$as_me:${as_lineno-$LINENO}: checking whether we are using the GNU C compiler" >&5 $as_echo_n "checking whether we are using the GNU C compiler... " >&6; } if ${ac_cv_c_compiler_gnu+:} false; then : $as_echo_n "(cached) " >&6 else cat confdefs.h - <<_ACEOF >conftest.$ac_ext /* end confdefs.h. */ int main () { #ifndef __GNUC__ choke me #endif ; return 0; } _ACEOF if ac_fn_c_try_compile "$LINENO"; then : ac_compiler_gnu=yes else ac_compiler_gnu=no fi rm -f core conftest.err conftest.$ac_objext conftest.$ac_ext ac_cv_c_compiler_gnu=$ac_compiler_gnu fi { $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_cv_c_compiler_gnu" >&5 $as_echo "$ac_cv_c_compiler_gnu" >&6; } if test $ac_compiler_gnu = yes; then GCC=yes else GCC= fi ac_test_CFLAGS=${CFLAGS+set} ac_save_CFLAGS=$CFLAGS { $as_echo "$as_me:${as_lineno-$LINENO}: checking whether $CC accepts -g" >&5 $as_echo_n "checking whether $CC accepts -g... " >&6; } if ${ac_cv_prog_cc_g+:} false; then : $as_echo_n "(cached) " >&6 else ac_save_c_werror_flag=$ac_c_werror_flag ac_c_werror_flag=yes ac_cv_prog_cc_g=no CFLAGS="-g" cat confdefs.h - <<_ACEOF >conftest.$ac_ext /* end confdefs.h. */ int main () { ; return 0; } _ACEOF if ac_fn_c_try_compile "$LINENO"; then : ac_cv_prog_cc_g=yes else CFLAGS="" cat confdefs.h - <<_ACEOF >conftest.$ac_ext /* end confdefs.h. */ int main () { ; return 0; } _ACEOF if ac_fn_c_try_compile "$LINENO"; then : else ac_c_werror_flag=$ac_save_c_werror_flag CFLAGS="-g" cat confdefs.h - <<_ACEOF >conftest.$ac_ext /* end confdefs.h. */ int main () { ; return 0; } _ACEOF if ac_fn_c_try_compile "$LINENO"; then : ac_cv_prog_cc_g=yes fi rm -f core conftest.err conftest.$ac_objext conftest.$ac_ext fi rm -f core conftest.err conftest.$ac_objext conftest.$ac_ext fi rm -f core conftest.err conftest.$ac_objext conftest.$ac_ext ac_c_werror_flag=$ac_save_c_werror_flag fi { $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_cv_prog_cc_g" >&5 $as_echo "$ac_cv_prog_cc_g" >&6; } if test "$ac_test_CFLAGS" = set; then CFLAGS=$ac_save_CFLAGS elif test $ac_cv_prog_cc_g = yes; then if test "$GCC" = yes; then CFLAGS="-g -O2" else CFLAGS="-g" fi else if test "$GCC" = yes; then CFLAGS="-O2" else CFLAGS= fi fi { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $CC option to accept ISO C89" >&5 $as_echo_n "checking for $CC option to accept ISO C89... " >&6; } if ${ac_cv_prog_cc_c89+:} false; then : $as_echo_n "(cached) " >&6 else ac_cv_prog_cc_c89=no ac_save_CC=$CC cat confdefs.h - <<_ACEOF >conftest.$ac_ext /* end confdefs.h. */ #include #include struct stat; /* Most of the following tests are stolen from RCS 5.7's src/conf.sh. */ struct buf { int x; }; FILE * (*rcsopen) (struct buf *, struct stat *, int); static char *e (p, i) char **p; int i; { return p[i]; } static char *f (char * (*g) (char **, int), char **p, ...) { char *s; va_list v; va_start (v,p); s = g (p, va_arg (v,int)); va_end (v); return s; } /* OSF 4.0 Compaq cc is some sort of almost-ANSI by default. It has function prototypes and stuff, but not '\xHH' hex character constants. These don't provoke an error unfortunately, instead are silently treated as 'x'. The following induces an error, until -std is added to get proper ANSI mode. Curiously '\x00'!='x' always comes out true, for an array size at least. It's necessary to write '\x00'==0 to get something that's true only with -std. */ int osf4_cc_array ['\x00' == 0 ? 1 : -1]; /* IBM C 6 for AIX is almost-ANSI by default, but it replaces macro parameters inside strings and character constants. */ #define FOO(x) 'x' int xlc6_cc_array[FOO(a) == 'x' ? 1 : -1]; int test (int i, double x); struct s1 {int (*f) (int a);}; struct s2 {int (*f) (double a);}; int pairnames (int, char **, FILE *(*)(struct buf *, struct stat *, int), int, int); int argc; char **argv; int main () { return f (e, argv, 0) != argv[0] || f (e, argv, 1) != argv[1]; ; return 0; } _ACEOF for ac_arg in '' -qlanglvl=extc89 -qlanglvl=ansi -std \ -Ae "-Aa -D_HPUX_SOURCE" "-Xc -D__EXTENSIONS__" do CC="$ac_save_CC $ac_arg" if ac_fn_c_try_compile "$LINENO"; then : ac_cv_prog_cc_c89=$ac_arg fi rm -f core conftest.err conftest.$ac_objext test "x$ac_cv_prog_cc_c89" != "xno" && break done rm -f conftest.$ac_ext CC=$ac_save_CC fi # AC_CACHE_VAL case "x$ac_cv_prog_cc_c89" in x) { $as_echo "$as_me:${as_lineno-$LINENO}: result: none needed" >&5 $as_echo "none needed" >&6; } ;; xno) { $as_echo "$as_me:${as_lineno-$LINENO}: result: unsupported" >&5 $as_echo "unsupported" >&6; } ;; *) CC="$CC $ac_cv_prog_cc_c89" { $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_cv_prog_cc_c89" >&5 $as_echo "$ac_cv_prog_cc_c89" >&6; } ;; esac if test "x$ac_cv_prog_cc_c89" != xno; then : fi ac_ext=c ac_cpp='$CPP $CPPFLAGS' ac_compile='$CC -c $CFLAGS $CPPFLAGS conftest.$ac_ext >&5' ac_link='$CC -o conftest$ac_exeext $CFLAGS $CPPFLAGS $LDFLAGS conftest.$ac_ext $LIBS >&5' ac_compiler_gnu=$ac_cv_c_compiler_gnu ac_ext=c ac_cpp='$CPP $CPPFLAGS' ac_compile='$CC -c $CFLAGS $CPPFLAGS conftest.$ac_ext >&5' ac_link='$CC -o conftest$ac_exeext $CFLAGS $CPPFLAGS $LDFLAGS conftest.$ac_ext $LIBS >&5' ac_compiler_gnu=$ac_cv_c_compiler_gnu { $as_echo "$as_me:${as_lineno-$LINENO}: checking whether $CC understands -c and -o together" >&5 $as_echo_n "checking whether $CC understands -c and -o together... " >&6; } if ${am_cv_prog_cc_c_o+:} false; then : $as_echo_n "(cached) " >&6 else cat confdefs.h - <<_ACEOF >conftest.$ac_ext /* end confdefs.h. */ int main () { ; return 0; } _ACEOF # Make sure it works both with $CC and with simple cc. # Following AC_PROG_CC_C_O, we do the test twice because some # compilers refuse to overwrite an existing .o file with -o, # though they will create one. am_cv_prog_cc_c_o=yes for am_i in 1 2; do if { echo "$as_me:$LINENO: $CC -c conftest.$ac_ext -o conftest2.$ac_objext" >&5 ($CC -c conftest.$ac_ext -o conftest2.$ac_objext) >&5 2>&5 ac_status=$? echo "$as_me:$LINENO: \$? = $ac_status" >&5 (exit $ac_status); } \ && test -f conftest2.$ac_objext; then : OK else am_cv_prog_cc_c_o=no break fi done rm -f core conftest* unset am_i fi { $as_echo "$as_me:${as_lineno-$LINENO}: result: $am_cv_prog_cc_c_o" >&5 $as_echo "$am_cv_prog_cc_c_o" >&6; } if test "$am_cv_prog_cc_c_o" != yes; then # Losing compiler, so override with the script. # FIXME: It is wrong to rewrite CC. # But if we don't then we get into trouble of one sort or another. # A longer-term fix would be to have automake use am__CC in this case, # and then we could set am__CC="\$(top_srcdir)/compile \$(CC)" CC="$am_aux_dir/compile $CC" fi ac_ext=c ac_cpp='$CPP $CPPFLAGS' ac_compile='$CC -c $CFLAGS $CPPFLAGS conftest.$ac_ext >&5' ac_link='$CC -o conftest$ac_exeext $CFLAGS $CPPFLAGS $LDFLAGS conftest.$ac_ext $LIBS >&5' ac_compiler_gnu=$ac_cv_c_compiler_gnu DEPDIR="${am__leading_dot}deps" ac_config_commands="$ac_config_commands depfiles" am_make=${MAKE-make} cat > confinc << 'END' am__doit: @echo this is the am__doit target .PHONY: am__doit END # If we don't find an include directive, just comment out the code. { $as_echo "$as_me:${as_lineno-$LINENO}: checking for style of include used by $am_make" >&5 $as_echo_n "checking for style of include used by $am_make... " >&6; } am__include="#" am__quote= _am_result=none # First try GNU make style include. echo "include confinc" > confmf # Ignore all kinds of additional output from 'make'. case `$am_make -s -f confmf 2> /dev/null` in #( *the\ am__doit\ target*) am__include=include am__quote= _am_result=GNU ;; esac # Now try BSD make style include. if test "$am__include" = "#"; then echo '.include "confinc"' > confmf case `$am_make -s -f confmf 2> /dev/null` in #( *the\ am__doit\ target*) am__include=.include am__quote="\"" _am_result=BSD ;; esac fi { $as_echo "$as_me:${as_lineno-$LINENO}: result: $_am_result" >&5 $as_echo "$_am_result" >&6; } rm -f confinc confmf # Check whether --enable-dependency-tracking was given. if test "${enable_dependency_tracking+set}" = set; then : enableval=$enable_dependency_tracking; fi if test "x$enable_dependency_tracking" != xno; then am_depcomp="$ac_aux_dir/depcomp" AMDEPBACKSLASH='\' am__nodep='_no' fi if test "x$enable_dependency_tracking" != xno; then AMDEP_TRUE= AMDEP_FALSE='#' else AMDEP_TRUE='#' AMDEP_FALSE= fi depcc="$CC" am_compiler_list= { $as_echo "$as_me:${as_lineno-$LINENO}: checking dependency style of $depcc" >&5 $as_echo_n "checking dependency style of $depcc... " >&6; } if ${am_cv_CC_dependencies_compiler_type+:} false; then : $as_echo_n "(cached) " >&6 else if test -z "$AMDEP_TRUE" && test -f "$am_depcomp"; then # We make a subdir and do the tests there. Otherwise we can end up # making bogus files that we don't know about and never remove. For # instance it was reported that on HP-UX the gcc test will end up # making a dummy file named 'D' -- because '-MD' means "put the output # in D". rm -rf conftest.dir mkdir conftest.dir # Copy depcomp to subdir because otherwise we won't find it if we're # using a relative directory. cp "$am_depcomp" conftest.dir cd conftest.dir # We will build objects and dependencies in a subdirectory because # it helps to detect inapplicable dependency modes. For instance # both Tru64's cc and ICC support -MD to output dependencies as a # side effect of compilation, but ICC will put the dependencies in # the current directory while Tru64 will put them in the object # directory. mkdir sub am_cv_CC_dependencies_compiler_type=none if test "$am_compiler_list" = ""; then am_compiler_list=`sed -n 's/^#*\([a-zA-Z0-9]*\))$/\1/p' < ./depcomp` fi am__universal=false case " $depcc " in #( *\ -arch\ *\ -arch\ *) am__universal=true ;; esac for depmode in $am_compiler_list; do # Setup a source with many dependencies, because some compilers # like to wrap large dependency lists on column 80 (with \), and # we should not choose a depcomp mode which is confused by this. # # We need to recreate these files for each test, as the compiler may # overwrite some of them when testing with obscure command lines. # This happens at least with the AIX C compiler. : > sub/conftest.c for i in 1 2 3 4 5 6; do echo '#include "conftst'$i'.h"' >> sub/conftest.c # Using ": > sub/conftst$i.h" creates only sub/conftst1.h with # Solaris 10 /bin/sh. echo '/* dummy */' > sub/conftst$i.h done echo "${am__include} ${am__quote}sub/conftest.Po${am__quote}" > confmf # We check with '-c' and '-o' for the sake of the "dashmstdout" # mode. It turns out that the SunPro C++ compiler does not properly # handle '-M -o', and we need to detect this. Also, some Intel # versions had trouble with output in subdirs. am__obj=sub/conftest.${OBJEXT-o} am__minus_obj="-o $am__obj" case $depmode in gcc) # This depmode causes a compiler race in universal mode. test "$am__universal" = false || continue ;; nosideeffect) # After this tag, mechanisms are not by side-effect, so they'll # only be used when explicitly requested. if test "x$enable_dependency_tracking" = xyes; then continue else break fi ;; msvc7 | msvc7msys | msvisualcpp | msvcmsys) # This compiler won't grok '-c -o', but also, the minuso test has # not run yet. These depmodes are late enough in the game, and # so weak that their functioning should not be impacted. am__obj=conftest.${OBJEXT-o} am__minus_obj= ;; none) break ;; esac if depmode=$depmode \ source=sub/conftest.c object=$am__obj \ depfile=sub/conftest.Po tmpdepfile=sub/conftest.TPo \ $SHELL ./depcomp $depcc -c $am__minus_obj sub/conftest.c \ >/dev/null 2>conftest.err && grep sub/conftst1.h sub/conftest.Po > /dev/null 2>&1 && grep sub/conftst6.h sub/conftest.Po > /dev/null 2>&1 && grep $am__obj sub/conftest.Po > /dev/null 2>&1 && ${MAKE-make} -s -f confmf > /dev/null 2>&1; then # icc doesn't choke on unknown options, it will just issue warnings # or remarks (even with -Werror). So we grep stderr for any message # that says an option was ignored or not supported. # When given -MP, icc 7.0 and 7.1 complain thusly: # icc: Command line warning: ignoring option '-M'; no argument required # The diagnosis changed in icc 8.0: # icc: Command line remark: option '-MP' not supported if (grep 'ignoring option' conftest.err || grep 'not supported' conftest.err) >/dev/null 2>&1; then :; else am_cv_CC_dependencies_compiler_type=$depmode break fi fi done cd .. rm -rf conftest.dir else am_cv_CC_dependencies_compiler_type=none fi fi { $as_echo "$as_me:${as_lineno-$LINENO}: result: $am_cv_CC_dependencies_compiler_type" >&5 $as_echo "$am_cv_CC_dependencies_compiler_type" >&6; } CCDEPMODE=depmode=$am_cv_CC_dependencies_compiler_type if test "x$enable_dependency_tracking" != xno \ && test "$am_cv_CC_dependencies_compiler_type" = gcc3; then am__fastdepCC_TRUE= am__fastdepCC_FALSE='#' else am__fastdepCC_TRUE='#' am__fastdepCC_FALSE= fi { $as_echo "$as_me:${as_lineno-$LINENO}: checking for an ANSI C-conforming const" >&5 $as_echo_n "checking for an ANSI C-conforming const... " >&6; } if ${ac_cv_c_const+:} false; then : $as_echo_n "(cached) " >&6 else cat confdefs.h - <<_ACEOF >conftest.$ac_ext /* end confdefs.h. */ int main () { #ifndef __cplusplus /* Ultrix mips cc rejects this sort of thing. */ typedef int charset[2]; const charset cs = { 0, 0 }; /* SunOS 4.1.1 cc rejects this. */ char const *const *pcpcc; char **ppc; /* NEC SVR4.0.2 mips cc rejects this. */ struct point {int x, y;}; static struct point const zero = {0,0}; /* AIX XL C 1.02.0.0 rejects this. It does not let you subtract one const X* pointer from another in an arm of an if-expression whose if-part is not a constant expression */ const char *g = "string"; pcpcc = &g + (g ? g-g : 0); /* HPUX 7.0 cc rejects these. */ ++pcpcc; ppc = (char**) pcpcc; pcpcc = (char const *const *) ppc; { /* SCO 3.2v4 cc rejects this sort of thing. */ char tx; char *t = &tx; char const *s = 0 ? (char *) 0 : (char const *) 0; *t++ = 0; if (s) return 0; } { /* Someone thinks the Sun supposedly-ANSI compiler will reject this. */ int x[] = {25, 17}; const int *foo = &x[0]; ++foo; } { /* Sun SC1.0 ANSI compiler rejects this -- but not the above. */ typedef const int *iptr; iptr p = 0; ++p; } { /* AIX XL C 1.02.0.0 rejects this sort of thing, saying "k.c", line 2.27: 1506-025 (S) Operand must be a modifiable lvalue. */ struct s { int j; const int *ap[3]; } bx; struct s *b = &bx; b->j = 5; } { /* ULTRIX-32 V3.1 (Rev 9) vcc rejects this */ const int foo = 10; if (!foo) return 0; } return !cs[0] && !zero.x; #endif ; return 0; } _ACEOF if ac_fn_c_try_compile "$LINENO"; then : ac_cv_c_const=yes else ac_cv_c_const=no fi rm -f core conftest.err conftest.$ac_objext conftest.$ac_ext fi { $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_cv_c_const" >&5 $as_echo "$ac_cv_c_const" >&6; } if test $ac_cv_c_const = no; then $as_echo "#define const /**/" >>confdefs.h fi case `pwd` in *\ * | *\ *) { $as_echo "$as_me:${as_lineno-$LINENO}: WARNING: Libtool does not cope well with whitespace in \`pwd\`" >&5 $as_echo "$as_me: WARNING: Libtool does not cope well with whitespace in \`pwd\`" >&2;} ;; esac macro_version='2.4.6' macro_revision='2.4.6' ltmain=$ac_aux_dir/ltmain.sh # Make sure we can run config.sub. $SHELL "$ac_aux_dir/config.sub" sun4 >/dev/null 2>&1 || as_fn_error $? "cannot run $SHELL $ac_aux_dir/config.sub" "$LINENO" 5 { $as_echo "$as_me:${as_lineno-$LINENO}: checking build system type" >&5 $as_echo_n "checking build system type... " >&6; } if ${ac_cv_build+:} false; then : $as_echo_n "(cached) " >&6 else ac_build_alias=$build_alias test "x$ac_build_alias" = x && ac_build_alias=`$SHELL "$ac_aux_dir/config.guess"` test "x$ac_build_alias" = x && as_fn_error $? "cannot guess build type; you must specify one" "$LINENO" 5 ac_cv_build=`$SHELL "$ac_aux_dir/config.sub" $ac_build_alias` || as_fn_error $? "$SHELL $ac_aux_dir/config.sub $ac_build_alias failed" "$LINENO" 5 fi { $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_cv_build" >&5 $as_echo "$ac_cv_build" >&6; } case $ac_cv_build in *-*-*) ;; *) as_fn_error $? "invalid value of canonical build" "$LINENO" 5;; esac build=$ac_cv_build ac_save_IFS=$IFS; IFS='-' set x $ac_cv_build shift build_cpu=$1 build_vendor=$2 shift; shift # Remember, the first character of IFS is used to create $*, # except with old shells: build_os=$* IFS=$ac_save_IFS case $build_os in *\ *) build_os=`echo "$build_os" | sed 's/ /-/g'`;; esac { $as_echo "$as_me:${as_lineno-$LINENO}: checking host system type" >&5 $as_echo_n "checking host system type... " >&6; } if ${ac_cv_host+:} false; then : $as_echo_n "(cached) " >&6 else if test "x$host_alias" = x; then ac_cv_host=$ac_cv_build else ac_cv_host=`$SHELL "$ac_aux_dir/config.sub" $host_alias` || as_fn_error $? "$SHELL $ac_aux_dir/config.sub $host_alias failed" "$LINENO" 5 fi fi { $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_cv_host" >&5 $as_echo "$ac_cv_host" >&6; } case $ac_cv_host in *-*-*) ;; *) as_fn_error $? "invalid value of canonical host" "$LINENO" 5;; esac host=$ac_cv_host ac_save_IFS=$IFS; IFS='-' set x $ac_cv_host shift host_cpu=$1 host_vendor=$2 shift; shift # Remember, the first character of IFS is used to create $*, # except with old shells: host_os=$* IFS=$ac_save_IFS case $host_os in *\ *) host_os=`echo "$host_os" | sed 's/ /-/g'`;; esac # Backslashify metacharacters that are still active within # double-quoted strings. sed_quote_subst='s/\(["`$\\]\)/\\\1/g' # Same as above, but do not quote variable references. double_quote_subst='s/\(["`\\]\)/\\\1/g' # Sed substitution to delay expansion of an escaped shell variable in a # double_quote_subst'ed string. delay_variable_subst='s/\\\\\\\\\\\$/\\\\\\$/g' # Sed substitution to delay expansion of an escaped single quote. delay_single_quote_subst='s/'\''/'\'\\\\\\\'\''/g' # Sed substitution to avoid accidental globbing in evaled expressions no_glob_subst='s/\*/\\\*/g' ECHO='\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\' ECHO=$ECHO$ECHO$ECHO$ECHO$ECHO ECHO=$ECHO$ECHO$ECHO$ECHO$ECHO$ECHO { $as_echo "$as_me:${as_lineno-$LINENO}: checking how to print strings" >&5 $as_echo_n "checking how to print strings... " >&6; } # Test print first, because it will be a builtin if present. if test "X`( print -r -- -n ) 2>/dev/null`" = X-n && \ test "X`print -r -- $ECHO 2>/dev/null`" = "X$ECHO"; then ECHO='print -r --' elif test "X`printf %s $ECHO 2>/dev/null`" = "X$ECHO"; then ECHO='printf %s\n' else # Use this function as a fallback that always works. func_fallback_echo () { eval 'cat <<_LTECHO_EOF $1 _LTECHO_EOF' } ECHO='func_fallback_echo' fi # func_echo_all arg... # Invoke $ECHO with all args, space-separated. func_echo_all () { $ECHO "" } case $ECHO in printf*) { $as_echo "$as_me:${as_lineno-$LINENO}: result: printf" >&5 $as_echo "printf" >&6; } ;; print*) { $as_echo "$as_me:${as_lineno-$LINENO}: result: print -r" >&5 $as_echo "print -r" >&6; } ;; *) { $as_echo "$as_me:${as_lineno-$LINENO}: result: cat" >&5 $as_echo "cat" >&6; } ;; esac { $as_echo "$as_me:${as_lineno-$LINENO}: checking for a sed that does not truncate output" >&5 $as_echo_n "checking for a sed that does not truncate output... " >&6; } if ${ac_cv_path_SED+:} false; then : $as_echo_n "(cached) " >&6 else ac_script=s/aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa/bbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbb/ for ac_i in 1 2 3 4 5 6 7; do ac_script="$ac_script$as_nl$ac_script" done echo "$ac_script" 2>/dev/null | sed 99q >conftest.sed { ac_script=; unset ac_script;} if test -z "$SED"; then ac_path_SED_found=false # Loop through the user's path and test for each of PROGNAME-LIST as_save_IFS=$IFS; IFS=$PATH_SEPARATOR for as_dir in $PATH do IFS=$as_save_IFS test -z "$as_dir" && as_dir=. for ac_prog in sed gsed; do for ac_exec_ext in '' $ac_executable_extensions; do ac_path_SED="$as_dir/$ac_prog$ac_exec_ext" as_fn_executable_p "$ac_path_SED" || continue # Check for GNU ac_path_SED and select it if it is found. # Check for GNU $ac_path_SED case `"$ac_path_SED" --version 2>&1` in *GNU*) ac_cv_path_SED="$ac_path_SED" ac_path_SED_found=:;; *) ac_count=0 $as_echo_n 0123456789 >"conftest.in" while : do cat "conftest.in" "conftest.in" >"conftest.tmp" mv "conftest.tmp" "conftest.in" cp "conftest.in" "conftest.nl" $as_echo '' >> "conftest.nl" "$ac_path_SED" -f conftest.sed < "conftest.nl" >"conftest.out" 2>/dev/null || break diff "conftest.out" "conftest.nl" >/dev/null 2>&1 || break as_fn_arith $ac_count + 1 && ac_count=$as_val if test $ac_count -gt ${ac_path_SED_max-0}; then # Best one so far, save it but keep looking for a better one ac_cv_path_SED="$ac_path_SED" ac_path_SED_max=$ac_count fi # 10*(2^10) chars as input seems more than enough test $ac_count -gt 10 && break done rm -f conftest.in conftest.tmp conftest.nl conftest.out;; esac $ac_path_SED_found && break 3 done done done IFS=$as_save_IFS if test -z "$ac_cv_path_SED"; then as_fn_error $? "no acceptable sed could be found in \$PATH" "$LINENO" 5 fi else ac_cv_path_SED=$SED fi fi { $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_cv_path_SED" >&5 $as_echo "$ac_cv_path_SED" >&6; } SED="$ac_cv_path_SED" rm -f conftest.sed test -z "$SED" && SED=sed Xsed="$SED -e 1s/^X//" { $as_echo "$as_me:${as_lineno-$LINENO}: checking for grep that handles long lines and -e" >&5 $as_echo_n "checking for grep that handles long lines and -e... " >&6; } if ${ac_cv_path_GREP+:} false; then : $as_echo_n "(cached) " >&6 else if test -z "$GREP"; then ac_path_GREP_found=false # Loop through the user's path and test for each of PROGNAME-LIST as_save_IFS=$IFS; IFS=$PATH_SEPARATOR for as_dir in $PATH$PATH_SEPARATOR/usr/xpg4/bin do IFS=$as_save_IFS test -z "$as_dir" && as_dir=. for ac_prog in grep ggrep; do for ac_exec_ext in '' $ac_executable_extensions; do ac_path_GREP="$as_dir/$ac_prog$ac_exec_ext" as_fn_executable_p "$ac_path_GREP" || continue # Check for GNU ac_path_GREP and select it if it is found. # Check for GNU $ac_path_GREP case `"$ac_path_GREP" --version 2>&1` in *GNU*) ac_cv_path_GREP="$ac_path_GREP" ac_path_GREP_found=:;; *) ac_count=0 $as_echo_n 0123456789 >"conftest.in" while : do cat "conftest.in" "conftest.in" >"conftest.tmp" mv "conftest.tmp" "conftest.in" cp "conftest.in" "conftest.nl" $as_echo 'GREP' >> "conftest.nl" "$ac_path_GREP" -e 'GREP$' -e '-(cannot match)-' < "conftest.nl" >"conftest.out" 2>/dev/null || break diff "conftest.out" "conftest.nl" >/dev/null 2>&1 || break as_fn_arith $ac_count + 1 && ac_count=$as_val if test $ac_count -gt ${ac_path_GREP_max-0}; then # Best one so far, save it but keep looking for a better one ac_cv_path_GREP="$ac_path_GREP" ac_path_GREP_max=$ac_count fi # 10*(2^10) chars as input seems more than enough test $ac_count -gt 10 && break done rm -f conftest.in conftest.tmp conftest.nl conftest.out;; esac $ac_path_GREP_found && break 3 done done done IFS=$as_save_IFS if test -z "$ac_cv_path_GREP"; then as_fn_error $? "no acceptable grep could be found in $PATH$PATH_SEPARATOR/usr/xpg4/bin" "$LINENO" 5 fi else ac_cv_path_GREP=$GREP fi fi { $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_cv_path_GREP" >&5 $as_echo "$ac_cv_path_GREP" >&6; } GREP="$ac_cv_path_GREP" { $as_echo "$as_me:${as_lineno-$LINENO}: checking for egrep" >&5 $as_echo_n "checking for egrep... " >&6; } if ${ac_cv_path_EGREP+:} false; then : $as_echo_n "(cached) " >&6 else if echo a | $GREP -E '(a|b)' >/dev/null 2>&1 then ac_cv_path_EGREP="$GREP -E" else if test -z "$EGREP"; then ac_path_EGREP_found=false # Loop through the user's path and test for each of PROGNAME-LIST as_save_IFS=$IFS; IFS=$PATH_SEPARATOR for as_dir in $PATH$PATH_SEPARATOR/usr/xpg4/bin do IFS=$as_save_IFS test -z "$as_dir" && as_dir=. for ac_prog in egrep; do for ac_exec_ext in '' $ac_executable_extensions; do ac_path_EGREP="$as_dir/$ac_prog$ac_exec_ext" as_fn_executable_p "$ac_path_EGREP" || continue # Check for GNU ac_path_EGREP and select it if it is found. # Check for GNU $ac_path_EGREP case `"$ac_path_EGREP" --version 2>&1` in *GNU*) ac_cv_path_EGREP="$ac_path_EGREP" ac_path_EGREP_found=:;; *) ac_count=0 $as_echo_n 0123456789 >"conftest.in" while : do cat "conftest.in" "conftest.in" >"conftest.tmp" mv "conftest.tmp" "conftest.in" cp "conftest.in" "conftest.nl" $as_echo 'EGREP' >> "conftest.nl" "$ac_path_EGREP" 'EGREP$' < "conftest.nl" >"conftest.out" 2>/dev/null || break diff "conftest.out" "conftest.nl" >/dev/null 2>&1 || break as_fn_arith $ac_count + 1 && ac_count=$as_val if test $ac_count -gt ${ac_path_EGREP_max-0}; then # Best one so far, save it but keep looking for a better one ac_cv_path_EGREP="$ac_path_EGREP" ac_path_EGREP_max=$ac_count fi # 10*(2^10) chars as input seems more than enough test $ac_count -gt 10 && break done rm -f conftest.in conftest.tmp conftest.nl conftest.out;; esac $ac_path_EGREP_found && break 3 done done done IFS=$as_save_IFS if test -z "$ac_cv_path_EGREP"; then as_fn_error $? "no acceptable egrep could be found in $PATH$PATH_SEPARATOR/usr/xpg4/bin" "$LINENO" 5 fi else ac_cv_path_EGREP=$EGREP fi fi fi { $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_cv_path_EGREP" >&5 $as_echo "$ac_cv_path_EGREP" >&6; } EGREP="$ac_cv_path_EGREP" { $as_echo "$as_me:${as_lineno-$LINENO}: checking for fgrep" >&5 $as_echo_n "checking for fgrep... " >&6; } if ${ac_cv_path_FGREP+:} false; then : $as_echo_n "(cached) " >&6 else if echo 'ab*c' | $GREP -F 'ab*c' >/dev/null 2>&1 then ac_cv_path_FGREP="$GREP -F" else if test -z "$FGREP"; then ac_path_FGREP_found=false # Loop through the user's path and test for each of PROGNAME-LIST as_save_IFS=$IFS; IFS=$PATH_SEPARATOR for as_dir in $PATH$PATH_SEPARATOR/usr/xpg4/bin do IFS=$as_save_IFS test -z "$as_dir" && as_dir=. for ac_prog in fgrep; do for ac_exec_ext in '' $ac_executable_extensions; do ac_path_FGREP="$as_dir/$ac_prog$ac_exec_ext" as_fn_executable_p "$ac_path_FGREP" || continue # Check for GNU ac_path_FGREP and select it if it is found. # Check for GNU $ac_path_FGREP case `"$ac_path_FGREP" --version 2>&1` in *GNU*) ac_cv_path_FGREP="$ac_path_FGREP" ac_path_FGREP_found=:;; *) ac_count=0 $as_echo_n 0123456789 >"conftest.in" while : do cat "conftest.in" "conftest.in" >"conftest.tmp" mv "conftest.tmp" "conftest.in" cp "conftest.in" "conftest.nl" $as_echo 'FGREP' >> "conftest.nl" "$ac_path_FGREP" FGREP < "conftest.nl" >"conftest.out" 2>/dev/null || break diff "conftest.out" "conftest.nl" >/dev/null 2>&1 || break as_fn_arith $ac_count + 1 && ac_count=$as_val if test $ac_count -gt ${ac_path_FGREP_max-0}; then # Best one so far, save it but keep looking for a better one ac_cv_path_FGREP="$ac_path_FGREP" ac_path_FGREP_max=$ac_count fi # 10*(2^10) chars as input seems more than enough test $ac_count -gt 10 && break done rm -f conftest.in conftest.tmp conftest.nl conftest.out;; esac $ac_path_FGREP_found && break 3 done done done IFS=$as_save_IFS if test -z "$ac_cv_path_FGREP"; then as_fn_error $? "no acceptable fgrep could be found in $PATH$PATH_SEPARATOR/usr/xpg4/bin" "$LINENO" 5 fi else ac_cv_path_FGREP=$FGREP fi fi fi { $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_cv_path_FGREP" >&5 $as_echo "$ac_cv_path_FGREP" >&6; } FGREP="$ac_cv_path_FGREP" test -z "$GREP" && GREP=grep # Check whether --with-gnu-ld was given. if test "${with_gnu_ld+set}" = set; then : withval=$with_gnu_ld; test no = "$withval" || with_gnu_ld=yes else with_gnu_ld=no fi ac_prog=ld if test yes = "$GCC"; then # Check if gcc -print-prog-name=ld gives a path. { $as_echo "$as_me:${as_lineno-$LINENO}: checking for ld used by $CC" >&5 $as_echo_n "checking for ld used by $CC... " >&6; } case $host in *-*-mingw*) # gcc leaves a trailing carriage return, which upsets mingw ac_prog=`($CC -print-prog-name=ld) 2>&5 | tr -d '\015'` ;; *) ac_prog=`($CC -print-prog-name=ld) 2>&5` ;; esac case $ac_prog in # Accept absolute paths. [\\/]* | ?:[\\/]*) re_direlt='/[^/][^/]*/\.\./' # Canonicalize the pathname of ld ac_prog=`$ECHO "$ac_prog"| $SED 's%\\\\%/%g'` while $ECHO "$ac_prog" | $GREP "$re_direlt" > /dev/null 2>&1; do ac_prog=`$ECHO $ac_prog| $SED "s%$re_direlt%/%"` done test -z "$LD" && LD=$ac_prog ;; "") # If it fails, then pretend we aren't using GCC. ac_prog=ld ;; *) # If it is relative, then search for the first ld in PATH. with_gnu_ld=unknown ;; esac elif test yes = "$with_gnu_ld"; then { $as_echo "$as_me:${as_lineno-$LINENO}: checking for GNU ld" >&5 $as_echo_n "checking for GNU ld... " >&6; } else { $as_echo "$as_me:${as_lineno-$LINENO}: checking for non-GNU ld" >&5 $as_echo_n "checking for non-GNU ld... " >&6; } fi if ${lt_cv_path_LD+:} false; then : $as_echo_n "(cached) " >&6 else if test -z "$LD"; then lt_save_ifs=$IFS; IFS=$PATH_SEPARATOR for ac_dir in $PATH; do IFS=$lt_save_ifs test -z "$ac_dir" && ac_dir=. if test -f "$ac_dir/$ac_prog" || test -f "$ac_dir/$ac_prog$ac_exeext"; then lt_cv_path_LD=$ac_dir/$ac_prog # Check to see if the program is GNU ld. I'd rather use --version, # but apparently some variants of GNU ld only accept -v. # Break only if it was the GNU/non-GNU ld that we prefer. case `"$lt_cv_path_LD" -v 2>&1 &5 $as_echo "$LD" >&6; } else { $as_echo "$as_me:${as_lineno-$LINENO}: result: no" >&5 $as_echo "no" >&6; } fi test -z "$LD" && as_fn_error $? "no acceptable ld found in \$PATH" "$LINENO" 5 { $as_echo "$as_me:${as_lineno-$LINENO}: checking if the linker ($LD) is GNU ld" >&5 $as_echo_n "checking if the linker ($LD) is GNU ld... " >&6; } if ${lt_cv_prog_gnu_ld+:} false; then : $as_echo_n "(cached) " >&6 else # I'd rather use --version here, but apparently some GNU lds only accept -v. case `$LD -v 2>&1 &5 $as_echo "$lt_cv_prog_gnu_ld" >&6; } with_gnu_ld=$lt_cv_prog_gnu_ld { $as_echo "$as_me:${as_lineno-$LINENO}: checking for BSD- or MS-compatible name lister (nm)" >&5 $as_echo_n "checking for BSD- or MS-compatible name lister (nm)... " >&6; } if ${lt_cv_path_NM+:} false; then : $as_echo_n "(cached) " >&6 else if test -n "$NM"; then # Let the user override the test. lt_cv_path_NM=$NM else lt_nm_to_check=${ac_tool_prefix}nm if test -n "$ac_tool_prefix" && test "$build" = "$host"; then lt_nm_to_check="$lt_nm_to_check nm" fi for lt_tmp_nm in $lt_nm_to_check; do lt_save_ifs=$IFS; IFS=$PATH_SEPARATOR for ac_dir in $PATH /usr/ccs/bin/elf /usr/ccs/bin /usr/ucb /bin; do IFS=$lt_save_ifs test -z "$ac_dir" && ac_dir=. tmp_nm=$ac_dir/$lt_tmp_nm if test -f "$tmp_nm" || test -f "$tmp_nm$ac_exeext"; then # Check to see if the nm accepts a BSD-compat flag. # Adding the 'sed 1q' prevents false positives on HP-UX, which says: # nm: unknown option "B" ignored # Tru64's nm complains that /dev/null is an invalid object file # MSYS converts /dev/null to NUL, MinGW nm treats NUL as empty case $build_os in mingw*) lt_bad_file=conftest.nm/nofile ;; *) lt_bad_file=/dev/null ;; esac case `"$tmp_nm" -B $lt_bad_file 2>&1 | sed '1q'` in *$lt_bad_file* | *'Invalid file or object type'*) lt_cv_path_NM="$tmp_nm -B" break 2 ;; *) case `"$tmp_nm" -p /dev/null 2>&1 | sed '1q'` in */dev/null*) lt_cv_path_NM="$tmp_nm -p" break 2 ;; *) lt_cv_path_NM=${lt_cv_path_NM="$tmp_nm"} # keep the first match, but continue # so that we can try to find one that supports BSD flags ;; esac ;; esac fi done IFS=$lt_save_ifs done : ${lt_cv_path_NM=no} fi fi { $as_echo "$as_me:${as_lineno-$LINENO}: result: $lt_cv_path_NM" >&5 $as_echo "$lt_cv_path_NM" >&6; } if test no != "$lt_cv_path_NM"; then NM=$lt_cv_path_NM else # Didn't find any BSD compatible name lister, look for dumpbin. if test -n "$DUMPBIN"; then : # Let the user override the test. else if test -n "$ac_tool_prefix"; then for ac_prog in dumpbin "link -dump" do # Extract the first word of "$ac_tool_prefix$ac_prog", so it can be a program name with args. set dummy $ac_tool_prefix$ac_prog; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } if ${ac_cv_prog_DUMPBIN+:} false; then : $as_echo_n "(cached) " >&6 else if test -n "$DUMPBIN"; then ac_cv_prog_DUMPBIN="$DUMPBIN" # Let the user override the test. else as_save_IFS=$IFS; IFS=$PATH_SEPARATOR for as_dir in $PATH do IFS=$as_save_IFS test -z "$as_dir" && as_dir=. for ac_exec_ext in '' $ac_executable_extensions; do if as_fn_executable_p "$as_dir/$ac_word$ac_exec_ext"; then ac_cv_prog_DUMPBIN="$ac_tool_prefix$ac_prog" $as_echo "$as_me:${as_lineno-$LINENO}: found $as_dir/$ac_word$ac_exec_ext" >&5 break 2 fi done done IFS=$as_save_IFS fi fi DUMPBIN=$ac_cv_prog_DUMPBIN if test -n "$DUMPBIN"; then { $as_echo "$as_me:${as_lineno-$LINENO}: result: $DUMPBIN" >&5 $as_echo "$DUMPBIN" >&6; } else { $as_echo "$as_me:${as_lineno-$LINENO}: result: no" >&5 $as_echo "no" >&6; } fi test -n "$DUMPBIN" && break done fi if test -z "$DUMPBIN"; then ac_ct_DUMPBIN=$DUMPBIN for ac_prog in dumpbin "link -dump" do # Extract the first word of "$ac_prog", so it can be a program name with args. set dummy $ac_prog; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } if ${ac_cv_prog_ac_ct_DUMPBIN+:} false; then : $as_echo_n "(cached) " >&6 else if test -n "$ac_ct_DUMPBIN"; then ac_cv_prog_ac_ct_DUMPBIN="$ac_ct_DUMPBIN" # Let the user override the test. else as_save_IFS=$IFS; IFS=$PATH_SEPARATOR for as_dir in $PATH do IFS=$as_save_IFS test -z "$as_dir" && as_dir=. for ac_exec_ext in '' $ac_executable_extensions; do if as_fn_executable_p "$as_dir/$ac_word$ac_exec_ext"; then ac_cv_prog_ac_ct_DUMPBIN="$ac_prog" $as_echo "$as_me:${as_lineno-$LINENO}: found $as_dir/$ac_word$ac_exec_ext" >&5 break 2 fi done done IFS=$as_save_IFS fi fi ac_ct_DUMPBIN=$ac_cv_prog_ac_ct_DUMPBIN if test -n "$ac_ct_DUMPBIN"; then { $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_ct_DUMPBIN" >&5 $as_echo "$ac_ct_DUMPBIN" >&6; } else { $as_echo "$as_me:${as_lineno-$LINENO}: result: no" >&5 $as_echo "no" >&6; } fi test -n "$ac_ct_DUMPBIN" && break done if test "x$ac_ct_DUMPBIN" = x; then DUMPBIN=":" else case $cross_compiling:$ac_tool_warned in yes:) { $as_echo "$as_me:${as_lineno-$LINENO}: WARNING: using cross tools not prefixed with host triplet" >&5 $as_echo "$as_me: WARNING: using cross tools not prefixed with host triplet" >&2;} ac_tool_warned=yes ;; esac DUMPBIN=$ac_ct_DUMPBIN fi fi case `$DUMPBIN -symbols -headers /dev/null 2>&1 | sed '1q'` in *COFF*) DUMPBIN="$DUMPBIN -symbols -headers" ;; *) DUMPBIN=: ;; esac fi if test : != "$DUMPBIN"; then NM=$DUMPBIN fi fi test -z "$NM" && NM=nm { $as_echo "$as_me:${as_lineno-$LINENO}: checking the name lister ($NM) interface" >&5 $as_echo_n "checking the name lister ($NM) interface... " >&6; } if ${lt_cv_nm_interface+:} false; then : $as_echo_n "(cached) " >&6 else lt_cv_nm_interface="BSD nm" echo "int some_variable = 0;" > conftest.$ac_ext (eval echo "\"\$as_me:$LINENO: $ac_compile\"" >&5) (eval "$ac_compile" 2>conftest.err) cat conftest.err >&5 (eval echo "\"\$as_me:$LINENO: $NM \\\"conftest.$ac_objext\\\"\"" >&5) (eval "$NM \"conftest.$ac_objext\"" 2>conftest.err > conftest.out) cat conftest.err >&5 (eval echo "\"\$as_me:$LINENO: output\"" >&5) cat conftest.out >&5 if $GREP 'External.*some_variable' conftest.out > /dev/null; then lt_cv_nm_interface="MS dumpbin" fi rm -f conftest* fi { $as_echo "$as_me:${as_lineno-$LINENO}: result: $lt_cv_nm_interface" >&5 $as_echo "$lt_cv_nm_interface" >&6; } { $as_echo "$as_me:${as_lineno-$LINENO}: checking whether ln -s works" >&5 $as_echo_n "checking whether ln -s works... " >&6; } LN_S=$as_ln_s if test "$LN_S" = "ln -s"; then { $as_echo "$as_me:${as_lineno-$LINENO}: result: yes" >&5 $as_echo "yes" >&6; } else { $as_echo "$as_me:${as_lineno-$LINENO}: result: no, using $LN_S" >&5 $as_echo "no, using $LN_S" >&6; } fi # find the maximum length of command line arguments { $as_echo "$as_me:${as_lineno-$LINENO}: checking the maximum length of command line arguments" >&5 $as_echo_n "checking the maximum length of command line arguments... " >&6; } if ${lt_cv_sys_max_cmd_len+:} false; then : $as_echo_n "(cached) " >&6 else i=0 teststring=ABCD case $build_os in msdosdjgpp*) # On DJGPP, this test can blow up pretty badly due to problems in libc # (any single argument exceeding 2000 bytes causes a buffer overrun # during glob expansion). Even if it were fixed, the result of this # check would be larger than it should be. lt_cv_sys_max_cmd_len=12288; # 12K is about right ;; gnu*) # Under GNU Hurd, this test is not required because there is # no limit to the length of command line arguments. # Libtool will interpret -1 as no limit whatsoever lt_cv_sys_max_cmd_len=-1; ;; cygwin* | mingw* | cegcc*) # On Win9x/ME, this test blows up -- it succeeds, but takes # about 5 minutes as the teststring grows exponentially. # Worse, since 9x/ME are not pre-emptively multitasking, # you end up with a "frozen" computer, even though with patience # the test eventually succeeds (with a max line length of 256k). # Instead, let's just punt: use the minimum linelength reported by # all of the supported platforms: 8192 (on NT/2K/XP). lt_cv_sys_max_cmd_len=8192; ;; mint*) # On MiNT this can take a long time and run out of memory. lt_cv_sys_max_cmd_len=8192; ;; amigaos*) # On AmigaOS with pdksh, this test takes hours, literally. # So we just punt and use a minimum line length of 8192. lt_cv_sys_max_cmd_len=8192; ;; bitrig* | darwin* | dragonfly* | freebsd* | netbsd* | openbsd*) # This has been around since 386BSD, at least. Likely further. if test -x /sbin/sysctl; then lt_cv_sys_max_cmd_len=`/sbin/sysctl -n kern.argmax` elif test -x /usr/sbin/sysctl; then lt_cv_sys_max_cmd_len=`/usr/sbin/sysctl -n kern.argmax` else lt_cv_sys_max_cmd_len=65536 # usable default for all BSDs fi # And add a safety zone lt_cv_sys_max_cmd_len=`expr $lt_cv_sys_max_cmd_len \/ 4` lt_cv_sys_max_cmd_len=`expr $lt_cv_sys_max_cmd_len \* 3` ;; interix*) # We know the value 262144 and hardcode it with a safety zone (like BSD) lt_cv_sys_max_cmd_len=196608 ;; os2*) # The test takes a long time on OS/2. lt_cv_sys_max_cmd_len=8192 ;; osf*) # Dr. Hans Ekkehard Plesser reports seeing a kernel panic running configure # due to this test when exec_disable_arg_limit is 1 on Tru64. It is not # nice to cause kernel panics so lets avoid the loop below. # First set a reasonable default. lt_cv_sys_max_cmd_len=16384 # if test -x /sbin/sysconfig; then case `/sbin/sysconfig -q proc exec_disable_arg_limit` in *1*) lt_cv_sys_max_cmd_len=-1 ;; esac fi ;; sco3.2v5*) lt_cv_sys_max_cmd_len=102400 ;; sysv5* | sco5v6* | sysv4.2uw2*) kargmax=`grep ARG_MAX /etc/conf/cf.d/stune 2>/dev/null` if test -n "$kargmax"; then lt_cv_sys_max_cmd_len=`echo $kargmax | sed 's/.*[ ]//'` else lt_cv_sys_max_cmd_len=32768 fi ;; *) lt_cv_sys_max_cmd_len=`(getconf ARG_MAX) 2> /dev/null` if test -n "$lt_cv_sys_max_cmd_len" && \ test undefined != "$lt_cv_sys_max_cmd_len"; then lt_cv_sys_max_cmd_len=`expr $lt_cv_sys_max_cmd_len \/ 4` lt_cv_sys_max_cmd_len=`expr $lt_cv_sys_max_cmd_len \* 3` else # Make teststring a little bigger before we do anything with it. # a 1K string should be a reasonable start. for i in 1 2 3 4 5 6 7 8; do teststring=$teststring$teststring done SHELL=${SHELL-${CONFIG_SHELL-/bin/sh}} # If test is not a shell built-in, we'll probably end up computing a # maximum length that is only half of the actual maximum length, but # we can't tell. while { test X`env echo "$teststring$teststring" 2>/dev/null` \ = "X$teststring$teststring"; } >/dev/null 2>&1 && test 17 != "$i" # 1/2 MB should be enough do i=`expr $i + 1` teststring=$teststring$teststring done # Only check the string length outside the loop. lt_cv_sys_max_cmd_len=`expr "X$teststring" : ".*" 2>&1` teststring= # Add a significant safety factor because C++ compilers can tack on # massive amounts of additional arguments before passing them to the # linker. It appears as though 1/2 is a usable value. lt_cv_sys_max_cmd_len=`expr $lt_cv_sys_max_cmd_len \/ 2` fi ;; esac fi if test -n "$lt_cv_sys_max_cmd_len"; then { $as_echo "$as_me:${as_lineno-$LINENO}: result: $lt_cv_sys_max_cmd_len" >&5 $as_echo "$lt_cv_sys_max_cmd_len" >&6; } else { $as_echo "$as_me:${as_lineno-$LINENO}: result: none" >&5 $as_echo "none" >&6; } fi max_cmd_len=$lt_cv_sys_max_cmd_len : ${CP="cp -f"} : ${MV="mv -f"} : ${RM="rm -f"} if ( (MAIL=60; unset MAIL) || exit) >/dev/null 2>&1; then lt_unset=unset else lt_unset=false fi # test EBCDIC or ASCII case `echo X|tr X '\101'` in A) # ASCII based system # \n is not interpreted correctly by Solaris 8 /usr/ucb/tr lt_SP2NL='tr \040 \012' lt_NL2SP='tr \015\012 \040\040' ;; *) # EBCDIC based system lt_SP2NL='tr \100 \n' lt_NL2SP='tr \r\n \100\100' ;; esac { $as_echo "$as_me:${as_lineno-$LINENO}: checking how to convert $build file names to $host format" >&5 $as_echo_n "checking how to convert $build file names to $host format... " >&6; } if ${lt_cv_to_host_file_cmd+:} false; then : $as_echo_n "(cached) " >&6 else case $host in *-*-mingw* ) case $build in *-*-mingw* ) # actually msys lt_cv_to_host_file_cmd=func_convert_file_msys_to_w32 ;; *-*-cygwin* ) lt_cv_to_host_file_cmd=func_convert_file_cygwin_to_w32 ;; * ) # otherwise, assume *nix lt_cv_to_host_file_cmd=func_convert_file_nix_to_w32 ;; esac ;; *-*-cygwin* ) case $build in *-*-mingw* ) # actually msys lt_cv_to_host_file_cmd=func_convert_file_msys_to_cygwin ;; *-*-cygwin* ) lt_cv_to_host_file_cmd=func_convert_file_noop ;; * ) # otherwise, assume *nix lt_cv_to_host_file_cmd=func_convert_file_nix_to_cygwin ;; esac ;; * ) # unhandled hosts (and "normal" native builds) lt_cv_to_host_file_cmd=func_convert_file_noop ;; esac fi to_host_file_cmd=$lt_cv_to_host_file_cmd { $as_echo "$as_me:${as_lineno-$LINENO}: result: $lt_cv_to_host_file_cmd" >&5 $as_echo "$lt_cv_to_host_file_cmd" >&6; } { $as_echo "$as_me:${as_lineno-$LINENO}: checking how to convert $build file names to toolchain format" >&5 $as_echo_n "checking how to convert $build file names to toolchain format... " >&6; } if ${lt_cv_to_tool_file_cmd+:} false; then : $as_echo_n "(cached) " >&6 else #assume ordinary cross tools, or native build. lt_cv_to_tool_file_cmd=func_convert_file_noop case $host in *-*-mingw* ) case $build in *-*-mingw* ) # actually msys lt_cv_to_tool_file_cmd=func_convert_file_msys_to_w32 ;; esac ;; esac fi to_tool_file_cmd=$lt_cv_to_tool_file_cmd { $as_echo "$as_me:${as_lineno-$LINENO}: result: $lt_cv_to_tool_file_cmd" >&5 $as_echo "$lt_cv_to_tool_file_cmd" >&6; } { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $LD option to reload object files" >&5 $as_echo_n "checking for $LD option to reload object files... " >&6; } if ${lt_cv_ld_reload_flag+:} false; then : $as_echo_n "(cached) " >&6 else lt_cv_ld_reload_flag='-r' fi { $as_echo "$as_me:${as_lineno-$LINENO}: result: $lt_cv_ld_reload_flag" >&5 $as_echo "$lt_cv_ld_reload_flag" >&6; } reload_flag=$lt_cv_ld_reload_flag case $reload_flag in "" | " "*) ;; *) reload_flag=" $reload_flag" ;; esac reload_cmds='$LD$reload_flag -o $output$reload_objs' case $host_os in cygwin* | mingw* | pw32* | cegcc*) if test yes != "$GCC"; then reload_cmds=false fi ;; darwin*) if test yes = "$GCC"; then reload_cmds='$LTCC $LTCFLAGS -nostdlib $wl-r -o $output$reload_objs' else reload_cmds='$LD$reload_flag -o $output$reload_objs' fi ;; esac if test -n "$ac_tool_prefix"; then # Extract the first word of "${ac_tool_prefix}objdump", so it can be a program name with args. set dummy ${ac_tool_prefix}objdump; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } if ${ac_cv_prog_OBJDUMP+:} false; then : $as_echo_n "(cached) " >&6 else if test -n "$OBJDUMP"; then ac_cv_prog_OBJDUMP="$OBJDUMP" # Let the user override the test. else as_save_IFS=$IFS; IFS=$PATH_SEPARATOR for as_dir in $PATH do IFS=$as_save_IFS test -z "$as_dir" && as_dir=. for ac_exec_ext in '' $ac_executable_extensions; do if as_fn_executable_p "$as_dir/$ac_word$ac_exec_ext"; then ac_cv_prog_OBJDUMP="${ac_tool_prefix}objdump" $as_echo "$as_me:${as_lineno-$LINENO}: found $as_dir/$ac_word$ac_exec_ext" >&5 break 2 fi done done IFS=$as_save_IFS fi fi OBJDUMP=$ac_cv_prog_OBJDUMP if test -n "$OBJDUMP"; then { $as_echo "$as_me:${as_lineno-$LINENO}: result: $OBJDUMP" >&5 $as_echo "$OBJDUMP" >&6; } else { $as_echo "$as_me:${as_lineno-$LINENO}: result: no" >&5 $as_echo "no" >&6; } fi fi if test -z "$ac_cv_prog_OBJDUMP"; then ac_ct_OBJDUMP=$OBJDUMP # Extract the first word of "objdump", so it can be a program name with args. set dummy objdump; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } if ${ac_cv_prog_ac_ct_OBJDUMP+:} false; then : $as_echo_n "(cached) " >&6 else if test -n "$ac_ct_OBJDUMP"; then ac_cv_prog_ac_ct_OBJDUMP="$ac_ct_OBJDUMP" # Let the user override the test. else as_save_IFS=$IFS; IFS=$PATH_SEPARATOR for as_dir in $PATH do IFS=$as_save_IFS test -z "$as_dir" && as_dir=. for ac_exec_ext in '' $ac_executable_extensions; do if as_fn_executable_p "$as_dir/$ac_word$ac_exec_ext"; then ac_cv_prog_ac_ct_OBJDUMP="objdump" $as_echo "$as_me:${as_lineno-$LINENO}: found $as_dir/$ac_word$ac_exec_ext" >&5 break 2 fi done done IFS=$as_save_IFS fi fi ac_ct_OBJDUMP=$ac_cv_prog_ac_ct_OBJDUMP if test -n "$ac_ct_OBJDUMP"; then { $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_ct_OBJDUMP" >&5 $as_echo "$ac_ct_OBJDUMP" >&6; } else { $as_echo "$as_me:${as_lineno-$LINENO}: result: no" >&5 $as_echo "no" >&6; } fi if test "x$ac_ct_OBJDUMP" = x; then OBJDUMP="false" else case $cross_compiling:$ac_tool_warned in yes:) { $as_echo "$as_me:${as_lineno-$LINENO}: WARNING: using cross tools not prefixed with host triplet" >&5 $as_echo "$as_me: WARNING: using cross tools not prefixed with host triplet" >&2;} ac_tool_warned=yes ;; esac OBJDUMP=$ac_ct_OBJDUMP fi else OBJDUMP="$ac_cv_prog_OBJDUMP" fi test -z "$OBJDUMP" && OBJDUMP=objdump { $as_echo "$as_me:${as_lineno-$LINENO}: checking how to recognize dependent libraries" >&5 $as_echo_n "checking how to recognize dependent libraries... " >&6; } if ${lt_cv_deplibs_check_method+:} false; then : $as_echo_n "(cached) " >&6 else lt_cv_file_magic_cmd='$MAGIC_CMD' lt_cv_file_magic_test_file= lt_cv_deplibs_check_method='unknown' # Need to set the preceding variable on all platforms that support # interlibrary dependencies. # 'none' -- dependencies not supported. # 'unknown' -- same as none, but documents that we really don't know. # 'pass_all' -- all dependencies passed with no checks. # 'test_compile' -- check by making test program. # 'file_magic [[regex]]' -- check by looking for files in library path # that responds to the $file_magic_cmd with a given extended regex. # If you have 'file' or equivalent on your system and you're not sure # whether 'pass_all' will *always* work, you probably want this one. case $host_os in aix[4-9]*) lt_cv_deplibs_check_method=pass_all ;; beos*) lt_cv_deplibs_check_method=pass_all ;; bsdi[45]*) lt_cv_deplibs_check_method='file_magic ELF [0-9][0-9]*-bit [ML]SB (shared object|dynamic lib)' lt_cv_file_magic_cmd='/usr/bin/file -L' lt_cv_file_magic_test_file=/shlib/libc.so ;; cygwin*) # func_win32_libid is a shell function defined in ltmain.sh lt_cv_deplibs_check_method='file_magic ^x86 archive import|^x86 DLL' lt_cv_file_magic_cmd='func_win32_libid' ;; mingw* | pw32*) # Base MSYS/MinGW do not provide the 'file' command needed by # func_win32_libid shell function, so use a weaker test based on 'objdump', # unless we find 'file', for example because we are cross-compiling. if ( file / ) >/dev/null 2>&1; then lt_cv_deplibs_check_method='file_magic ^x86 archive import|^x86 DLL' lt_cv_file_magic_cmd='func_win32_libid' else # Keep this pattern in sync with the one in func_win32_libid. lt_cv_deplibs_check_method='file_magic file format (pei*-i386(.*architecture: i386)?|pe-arm-wince|pe-x86-64)' lt_cv_file_magic_cmd='$OBJDUMP -f' fi ;; cegcc*) # use the weaker test based on 'objdump'. See mingw*. lt_cv_deplibs_check_method='file_magic file format pe-arm-.*little(.*architecture: arm)?' lt_cv_file_magic_cmd='$OBJDUMP -f' ;; darwin* | rhapsody*) lt_cv_deplibs_check_method=pass_all ;; freebsd* | dragonfly*) if echo __ELF__ | $CC -E - | $GREP __ELF__ > /dev/null; then case $host_cpu in i*86 ) # Not sure whether the presence of OpenBSD here was a mistake. # Let's accept both of them until this is cleared up. lt_cv_deplibs_check_method='file_magic (FreeBSD|OpenBSD|DragonFly)/i[3-9]86 (compact )?demand paged shared library' lt_cv_file_magic_cmd=/usr/bin/file lt_cv_file_magic_test_file=`echo /usr/lib/libc.so.*` ;; esac else lt_cv_deplibs_check_method=pass_all fi ;; haiku*) lt_cv_deplibs_check_method=pass_all ;; hpux10.20* | hpux11*) lt_cv_file_magic_cmd=/usr/bin/file case $host_cpu in ia64*) lt_cv_deplibs_check_method='file_magic (s[0-9][0-9][0-9]|ELF-[0-9][0-9]) shared object file - IA64' lt_cv_file_magic_test_file=/usr/lib/hpux32/libc.so ;; hppa*64*) lt_cv_deplibs_check_method='file_magic (s[0-9][0-9][0-9]|ELF[ -][0-9][0-9])(-bit)?( [LM]SB)? shared object( file)?[, -]* PA-RISC [0-9]\.[0-9]' lt_cv_file_magic_test_file=/usr/lib/pa20_64/libc.sl ;; *) lt_cv_deplibs_check_method='file_magic (s[0-9][0-9][0-9]|PA-RISC[0-9]\.[0-9]) shared library' lt_cv_file_magic_test_file=/usr/lib/libc.sl ;; esac ;; interix[3-9]*) # PIC code is broken on Interix 3.x, that's why |\.a not |_pic\.a here lt_cv_deplibs_check_method='match_pattern /lib[^/]+(\.so|\.a)$' ;; irix5* | irix6* | nonstopux*) case $LD in *-32|*"-32 ") libmagic=32-bit;; *-n32|*"-n32 ") libmagic=N32;; *-64|*"-64 ") libmagic=64-bit;; *) libmagic=never-match;; esac lt_cv_deplibs_check_method=pass_all ;; # This must be glibc/ELF. linux* | k*bsd*-gnu | kopensolaris*-gnu | gnu*) lt_cv_deplibs_check_method=pass_all ;; netbsd*) if echo __ELF__ | $CC -E - | $GREP __ELF__ > /dev/null; then lt_cv_deplibs_check_method='match_pattern /lib[^/]+(\.so\.[0-9]+\.[0-9]+|_pic\.a)$' else lt_cv_deplibs_check_method='match_pattern /lib[^/]+(\.so|_pic\.a)$' fi ;; newos6*) lt_cv_deplibs_check_method='file_magic ELF [0-9][0-9]*-bit [ML]SB (executable|dynamic lib)' lt_cv_file_magic_cmd=/usr/bin/file lt_cv_file_magic_test_file=/usr/lib/libnls.so ;; *nto* | *qnx*) lt_cv_deplibs_check_method=pass_all ;; openbsd* | bitrig*) if test -z "`echo __ELF__ | $CC -E - | $GREP __ELF__`"; then lt_cv_deplibs_check_method='match_pattern /lib[^/]+(\.so\.[0-9]+\.[0-9]+|\.so|_pic\.a)$' else lt_cv_deplibs_check_method='match_pattern /lib[^/]+(\.so\.[0-9]+\.[0-9]+|_pic\.a)$' fi ;; osf3* | osf4* | osf5*) lt_cv_deplibs_check_method=pass_all ;; rdos*) lt_cv_deplibs_check_method=pass_all ;; solaris*) lt_cv_deplibs_check_method=pass_all ;; sysv5* | sco3.2v5* | sco5v6* | unixware* | OpenUNIX* | sysv4*uw2*) lt_cv_deplibs_check_method=pass_all ;; sysv4 | sysv4.3*) case $host_vendor in motorola) lt_cv_deplibs_check_method='file_magic ELF [0-9][0-9]*-bit [ML]SB (shared object|dynamic lib) M[0-9][0-9]* Version [0-9]' lt_cv_file_magic_test_file=`echo /usr/lib/libc.so*` ;; ncr) lt_cv_deplibs_check_method=pass_all ;; sequent) lt_cv_file_magic_cmd='/bin/file' lt_cv_deplibs_check_method='file_magic ELF [0-9][0-9]*-bit [LM]SB (shared object|dynamic lib )' ;; sni) lt_cv_file_magic_cmd='/bin/file' lt_cv_deplibs_check_method="file_magic ELF [0-9][0-9]*-bit [LM]SB dynamic lib" lt_cv_file_magic_test_file=/lib/libc.so ;; siemens) lt_cv_deplibs_check_method=pass_all ;; pc) lt_cv_deplibs_check_method=pass_all ;; esac ;; tpf*) lt_cv_deplibs_check_method=pass_all ;; os2*) lt_cv_deplibs_check_method=pass_all ;; esac fi { $as_echo "$as_me:${as_lineno-$LINENO}: result: $lt_cv_deplibs_check_method" >&5 $as_echo "$lt_cv_deplibs_check_method" >&6; } file_magic_glob= want_nocaseglob=no if test "$build" = "$host"; then case $host_os in mingw* | pw32*) if ( shopt | grep nocaseglob ) >/dev/null 2>&1; then want_nocaseglob=yes else file_magic_glob=`echo aAbBcCdDeEfFgGhHiIjJkKlLmMnNoOpPqQrRsStTuUvVwWxXyYzZ | $SED -e "s/\(..\)/s\/[\1]\/[\1]\/g;/g"` fi ;; esac fi file_magic_cmd=$lt_cv_file_magic_cmd deplibs_check_method=$lt_cv_deplibs_check_method test -z "$deplibs_check_method" && deplibs_check_method=unknown if test -n "$ac_tool_prefix"; then # Extract the first word of "${ac_tool_prefix}dlltool", so it can be a program name with args. set dummy ${ac_tool_prefix}dlltool; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } if ${ac_cv_prog_DLLTOOL+:} false; then : $as_echo_n "(cached) " >&6 else if test -n "$DLLTOOL"; then ac_cv_prog_DLLTOOL="$DLLTOOL" # Let the user override the test. else as_save_IFS=$IFS; IFS=$PATH_SEPARATOR for as_dir in $PATH do IFS=$as_save_IFS test -z "$as_dir" && as_dir=. for ac_exec_ext in '' $ac_executable_extensions; do if as_fn_executable_p "$as_dir/$ac_word$ac_exec_ext"; then ac_cv_prog_DLLTOOL="${ac_tool_prefix}dlltool" $as_echo "$as_me:${as_lineno-$LINENO}: found $as_dir/$ac_word$ac_exec_ext" >&5 break 2 fi done done IFS=$as_save_IFS fi fi DLLTOOL=$ac_cv_prog_DLLTOOL if test -n "$DLLTOOL"; then { $as_echo "$as_me:${as_lineno-$LINENO}: result: $DLLTOOL" >&5 $as_echo "$DLLTOOL" >&6; } else { $as_echo "$as_me:${as_lineno-$LINENO}: result: no" >&5 $as_echo "no" >&6; } fi fi if test -z "$ac_cv_prog_DLLTOOL"; then ac_ct_DLLTOOL=$DLLTOOL # Extract the first word of "dlltool", so it can be a program name with args. set dummy dlltool; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } if ${ac_cv_prog_ac_ct_DLLTOOL+:} false; then : $as_echo_n "(cached) " >&6 else if test -n "$ac_ct_DLLTOOL"; then ac_cv_prog_ac_ct_DLLTOOL="$ac_ct_DLLTOOL" # Let the user override the test. else as_save_IFS=$IFS; IFS=$PATH_SEPARATOR for as_dir in $PATH do IFS=$as_save_IFS test -z "$as_dir" && as_dir=. for ac_exec_ext in '' $ac_executable_extensions; do if as_fn_executable_p "$as_dir/$ac_word$ac_exec_ext"; then ac_cv_prog_ac_ct_DLLTOOL="dlltool" $as_echo "$as_me:${as_lineno-$LINENO}: found $as_dir/$ac_word$ac_exec_ext" >&5 break 2 fi done done IFS=$as_save_IFS fi fi ac_ct_DLLTOOL=$ac_cv_prog_ac_ct_DLLTOOL if test -n "$ac_ct_DLLTOOL"; then { $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_ct_DLLTOOL" >&5 $as_echo "$ac_ct_DLLTOOL" >&6; } else { $as_echo "$as_me:${as_lineno-$LINENO}: result: no" >&5 $as_echo "no" >&6; } fi if test "x$ac_ct_DLLTOOL" = x; then DLLTOOL="false" else case $cross_compiling:$ac_tool_warned in yes:) { $as_echo "$as_me:${as_lineno-$LINENO}: WARNING: using cross tools not prefixed with host triplet" >&5 $as_echo "$as_me: WARNING: using cross tools not prefixed with host triplet" >&2;} ac_tool_warned=yes ;; esac DLLTOOL=$ac_ct_DLLTOOL fi else DLLTOOL="$ac_cv_prog_DLLTOOL" fi test -z "$DLLTOOL" && DLLTOOL=dlltool { $as_echo "$as_me:${as_lineno-$LINENO}: checking how to associate runtime and link libraries" >&5 $as_echo_n "checking how to associate runtime and link libraries... " >&6; } if ${lt_cv_sharedlib_from_linklib_cmd+:} false; then : $as_echo_n "(cached) " >&6 else lt_cv_sharedlib_from_linklib_cmd='unknown' case $host_os in cygwin* | mingw* | pw32* | cegcc*) # two different shell functions defined in ltmain.sh; # decide which one to use based on capabilities of $DLLTOOL case `$DLLTOOL --help 2>&1` in *--identify-strict*) lt_cv_sharedlib_from_linklib_cmd=func_cygming_dll_for_implib ;; *) lt_cv_sharedlib_from_linklib_cmd=func_cygming_dll_for_implib_fallback ;; esac ;; *) # fallback: assume linklib IS sharedlib lt_cv_sharedlib_from_linklib_cmd=$ECHO ;; esac fi { $as_echo "$as_me:${as_lineno-$LINENO}: result: $lt_cv_sharedlib_from_linklib_cmd" >&5 $as_echo "$lt_cv_sharedlib_from_linklib_cmd" >&6; } sharedlib_from_linklib_cmd=$lt_cv_sharedlib_from_linklib_cmd test -z "$sharedlib_from_linklib_cmd" && sharedlib_from_linklib_cmd=$ECHO if test -n "$ac_tool_prefix"; then for ac_prog in ar do # Extract the first word of "$ac_tool_prefix$ac_prog", so it can be a program name with args. set dummy $ac_tool_prefix$ac_prog; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } if ${ac_cv_prog_AR+:} false; then : $as_echo_n "(cached) " >&6 else if test -n "$AR"; then ac_cv_prog_AR="$AR" # Let the user override the test. else as_save_IFS=$IFS; IFS=$PATH_SEPARATOR for as_dir in $PATH do IFS=$as_save_IFS test -z "$as_dir" && as_dir=. for ac_exec_ext in '' $ac_executable_extensions; do if as_fn_executable_p "$as_dir/$ac_word$ac_exec_ext"; then ac_cv_prog_AR="$ac_tool_prefix$ac_prog" $as_echo "$as_me:${as_lineno-$LINENO}: found $as_dir/$ac_word$ac_exec_ext" >&5 break 2 fi done done IFS=$as_save_IFS fi fi AR=$ac_cv_prog_AR if test -n "$AR"; then { $as_echo "$as_me:${as_lineno-$LINENO}: result: $AR" >&5 $as_echo "$AR" >&6; } else { $as_echo "$as_me:${as_lineno-$LINENO}: result: no" >&5 $as_echo "no" >&6; } fi test -n "$AR" && break done fi if test -z "$AR"; then ac_ct_AR=$AR for ac_prog in ar do # Extract the first word of "$ac_prog", so it can be a program name with args. set dummy $ac_prog; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } if ${ac_cv_prog_ac_ct_AR+:} false; then : $as_echo_n "(cached) " >&6 else if test -n "$ac_ct_AR"; then ac_cv_prog_ac_ct_AR="$ac_ct_AR" # Let the user override the test. else as_save_IFS=$IFS; IFS=$PATH_SEPARATOR for as_dir in $PATH do IFS=$as_save_IFS test -z "$as_dir" && as_dir=. for ac_exec_ext in '' $ac_executable_extensions; do if as_fn_executable_p "$as_dir/$ac_word$ac_exec_ext"; then ac_cv_prog_ac_ct_AR="$ac_prog" $as_echo "$as_me:${as_lineno-$LINENO}: found $as_dir/$ac_word$ac_exec_ext" >&5 break 2 fi done done IFS=$as_save_IFS fi fi ac_ct_AR=$ac_cv_prog_ac_ct_AR if test -n "$ac_ct_AR"; then { $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_ct_AR" >&5 $as_echo "$ac_ct_AR" >&6; } else { $as_echo "$as_me:${as_lineno-$LINENO}: result: no" >&5 $as_echo "no" >&6; } fi test -n "$ac_ct_AR" && break done if test "x$ac_ct_AR" = x; then AR="false" else case $cross_compiling:$ac_tool_warned in yes:) { $as_echo "$as_me:${as_lineno-$LINENO}: WARNING: using cross tools not prefixed with host triplet" >&5 $as_echo "$as_me: WARNING: using cross tools not prefixed with host triplet" >&2;} ac_tool_warned=yes ;; esac AR=$ac_ct_AR fi fi : ${AR=ar} : ${AR_FLAGS=cru} { $as_echo "$as_me:${as_lineno-$LINENO}: checking for archiver @FILE support" >&5 $as_echo_n "checking for archiver @FILE support... " >&6; } if ${lt_cv_ar_at_file+:} false; then : $as_echo_n "(cached) " >&6 else lt_cv_ar_at_file=no cat confdefs.h - <<_ACEOF >conftest.$ac_ext /* end confdefs.h. */ int main () { ; return 0; } _ACEOF if ac_fn_c_try_compile "$LINENO"; then : echo conftest.$ac_objext > conftest.lst lt_ar_try='$AR $AR_FLAGS libconftest.a @conftest.lst >&5' { { eval echo "\"\$as_me\":${as_lineno-$LINENO}: \"$lt_ar_try\""; } >&5 (eval $lt_ar_try) 2>&5 ac_status=$? $as_echo "$as_me:${as_lineno-$LINENO}: \$? = $ac_status" >&5 test $ac_status = 0; } if test 0 -eq "$ac_status"; then # Ensure the archiver fails upon bogus file names. rm -f conftest.$ac_objext libconftest.a { { eval echo "\"\$as_me\":${as_lineno-$LINENO}: \"$lt_ar_try\""; } >&5 (eval $lt_ar_try) 2>&5 ac_status=$? $as_echo "$as_me:${as_lineno-$LINENO}: \$? = $ac_status" >&5 test $ac_status = 0; } if test 0 -ne "$ac_status"; then lt_cv_ar_at_file=@ fi fi rm -f conftest.* libconftest.a fi rm -f core conftest.err conftest.$ac_objext conftest.$ac_ext fi { $as_echo "$as_me:${as_lineno-$LINENO}: result: $lt_cv_ar_at_file" >&5 $as_echo "$lt_cv_ar_at_file" >&6; } if test no = "$lt_cv_ar_at_file"; then archiver_list_spec= else archiver_list_spec=$lt_cv_ar_at_file fi if test -n "$ac_tool_prefix"; then # Extract the first word of "${ac_tool_prefix}strip", so it can be a program name with args. set dummy ${ac_tool_prefix}strip; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } if ${ac_cv_prog_STRIP+:} false; then : $as_echo_n "(cached) " >&6 else if test -n "$STRIP"; then ac_cv_prog_STRIP="$STRIP" # Let the user override the test. else as_save_IFS=$IFS; IFS=$PATH_SEPARATOR for as_dir in $PATH do IFS=$as_save_IFS test -z "$as_dir" && as_dir=. for ac_exec_ext in '' $ac_executable_extensions; do if as_fn_executable_p "$as_dir/$ac_word$ac_exec_ext"; then ac_cv_prog_STRIP="${ac_tool_prefix}strip" $as_echo "$as_me:${as_lineno-$LINENO}: found $as_dir/$ac_word$ac_exec_ext" >&5 break 2 fi done done IFS=$as_save_IFS fi fi STRIP=$ac_cv_prog_STRIP if test -n "$STRIP"; then { $as_echo "$as_me:${as_lineno-$LINENO}: result: $STRIP" >&5 $as_echo "$STRIP" >&6; } else { $as_echo "$as_me:${as_lineno-$LINENO}: result: no" >&5 $as_echo "no" >&6; } fi fi if test -z "$ac_cv_prog_STRIP"; then ac_ct_STRIP=$STRIP # Extract the first word of "strip", so it can be a program name with args. set dummy strip; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } if ${ac_cv_prog_ac_ct_STRIP+:} false; then : $as_echo_n "(cached) " >&6 else if test -n "$ac_ct_STRIP"; then ac_cv_prog_ac_ct_STRIP="$ac_ct_STRIP" # Let the user override the test. else as_save_IFS=$IFS; IFS=$PATH_SEPARATOR for as_dir in $PATH do IFS=$as_save_IFS test -z "$as_dir" && as_dir=. for ac_exec_ext in '' $ac_executable_extensions; do if as_fn_executable_p "$as_dir/$ac_word$ac_exec_ext"; then ac_cv_prog_ac_ct_STRIP="strip" $as_echo "$as_me:${as_lineno-$LINENO}: found $as_dir/$ac_word$ac_exec_ext" >&5 break 2 fi done done IFS=$as_save_IFS fi fi ac_ct_STRIP=$ac_cv_prog_ac_ct_STRIP if test -n "$ac_ct_STRIP"; then { $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_ct_STRIP" >&5 $as_echo "$ac_ct_STRIP" >&6; } else { $as_echo "$as_me:${as_lineno-$LINENO}: result: no" >&5 $as_echo "no" >&6; } fi if test "x$ac_ct_STRIP" = x; then STRIP=":" else case $cross_compiling:$ac_tool_warned in yes:) { $as_echo "$as_me:${as_lineno-$LINENO}: WARNING: using cross tools not prefixed with host triplet" >&5 $as_echo "$as_me: WARNING: using cross tools not prefixed with host triplet" >&2;} ac_tool_warned=yes ;; esac STRIP=$ac_ct_STRIP fi else STRIP="$ac_cv_prog_STRIP" fi test -z "$STRIP" && STRIP=: if test -n "$ac_tool_prefix"; then # Extract the first word of "${ac_tool_prefix}ranlib", so it can be a program name with args. set dummy ${ac_tool_prefix}ranlib; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } if ${ac_cv_prog_RANLIB+:} false; then : $as_echo_n "(cached) " >&6 else if test -n "$RANLIB"; then ac_cv_prog_RANLIB="$RANLIB" # Let the user override the test. else as_save_IFS=$IFS; IFS=$PATH_SEPARATOR for as_dir in $PATH do IFS=$as_save_IFS test -z "$as_dir" && as_dir=. for ac_exec_ext in '' $ac_executable_extensions; do if as_fn_executable_p "$as_dir/$ac_word$ac_exec_ext"; then ac_cv_prog_RANLIB="${ac_tool_prefix}ranlib" $as_echo "$as_me:${as_lineno-$LINENO}: found $as_dir/$ac_word$ac_exec_ext" >&5 break 2 fi done done IFS=$as_save_IFS fi fi RANLIB=$ac_cv_prog_RANLIB if test -n "$RANLIB"; then { $as_echo "$as_me:${as_lineno-$LINENO}: result: $RANLIB" >&5 $as_echo "$RANLIB" >&6; } else { $as_echo "$as_me:${as_lineno-$LINENO}: result: no" >&5 $as_echo "no" >&6; } fi fi if test -z "$ac_cv_prog_RANLIB"; then ac_ct_RANLIB=$RANLIB # Extract the first word of "ranlib", so it can be a program name with args. set dummy ranlib; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } if ${ac_cv_prog_ac_ct_RANLIB+:} false; then : $as_echo_n "(cached) " >&6 else if test -n "$ac_ct_RANLIB"; then ac_cv_prog_ac_ct_RANLIB="$ac_ct_RANLIB" # Let the user override the test. else as_save_IFS=$IFS; IFS=$PATH_SEPARATOR for as_dir in $PATH do IFS=$as_save_IFS test -z "$as_dir" && as_dir=. for ac_exec_ext in '' $ac_executable_extensions; do if as_fn_executable_p "$as_dir/$ac_word$ac_exec_ext"; then ac_cv_prog_ac_ct_RANLIB="ranlib" $as_echo "$as_me:${as_lineno-$LINENO}: found $as_dir/$ac_word$ac_exec_ext" >&5 break 2 fi done done IFS=$as_save_IFS fi fi ac_ct_RANLIB=$ac_cv_prog_ac_ct_RANLIB if test -n "$ac_ct_RANLIB"; then { $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_ct_RANLIB" >&5 $as_echo "$ac_ct_RANLIB" >&6; } else { $as_echo "$as_me:${as_lineno-$LINENO}: result: no" >&5 $as_echo "no" >&6; } fi if test "x$ac_ct_RANLIB" = x; then RANLIB=":" else case $cross_compiling:$ac_tool_warned in yes:) { $as_echo "$as_me:${as_lineno-$LINENO}: WARNING: using cross tools not prefixed with host triplet" >&5 $as_echo "$as_me: WARNING: using cross tools not prefixed with host triplet" >&2;} ac_tool_warned=yes ;; esac RANLIB=$ac_ct_RANLIB fi else RANLIB="$ac_cv_prog_RANLIB" fi test -z "$RANLIB" && RANLIB=: # Determine commands to create old-style static archives. old_archive_cmds='$AR $AR_FLAGS $oldlib$oldobjs' old_postinstall_cmds='chmod 644 $oldlib' old_postuninstall_cmds= if test -n "$RANLIB"; then case $host_os in bitrig* | openbsd*) old_postinstall_cmds="$old_postinstall_cmds~\$RANLIB -t \$tool_oldlib" ;; *) old_postinstall_cmds="$old_postinstall_cmds~\$RANLIB \$tool_oldlib" ;; esac old_archive_cmds="$old_archive_cmds~\$RANLIB \$tool_oldlib" fi case $host_os in darwin*) lock_old_archive_extraction=yes ;; *) lock_old_archive_extraction=no ;; esac # If no C compiler was specified, use CC. LTCC=${LTCC-"$CC"} # If no C compiler flags were specified, use CFLAGS. LTCFLAGS=${LTCFLAGS-"$CFLAGS"} # Allow CC to be a program name with arguments. compiler=$CC # Check for command to grab the raw symbol name followed by C symbol from nm. { $as_echo "$as_me:${as_lineno-$LINENO}: checking command to parse $NM output from $compiler object" >&5 $as_echo_n "checking command to parse $NM output from $compiler object... " >&6; } if ${lt_cv_sys_global_symbol_pipe+:} false; then : $as_echo_n "(cached) " >&6 else # These are sane defaults that work on at least a few old systems. # [They come from Ultrix. What could be older than Ultrix?!! ;)] # Character class describing NM global symbol codes. symcode='[BCDEGRST]' # Regexp to match symbols that can be accessed directly from C. sympat='\([_A-Za-z][_A-Za-z0-9]*\)' # Define system-specific variables. case $host_os in aix*) symcode='[BCDT]' ;; cygwin* | mingw* | pw32* | cegcc*) symcode='[ABCDGISTW]' ;; hpux*) if test ia64 = "$host_cpu"; then symcode='[ABCDEGRST]' fi ;; irix* | nonstopux*) symcode='[BCDEGRST]' ;; osf*) symcode='[BCDEGQRST]' ;; solaris*) symcode='[BDRT]' ;; sco3.2v5*) symcode='[DT]' ;; sysv4.2uw2*) symcode='[DT]' ;; sysv5* | sco5v6* | unixware* | OpenUNIX*) symcode='[ABDT]' ;; sysv4) symcode='[DFNSTU]' ;; esac # If we're using GNU nm, then use its standard symbol codes. case `$NM -V 2>&1` in *GNU* | *'with BFD'*) symcode='[ABCDGIRSTW]' ;; esac if test "$lt_cv_nm_interface" = "MS dumpbin"; then # Gets list of data symbols to import. lt_cv_sys_global_symbol_to_import="sed -n -e 's/^I .* \(.*\)$/\1/p'" # Adjust the below global symbol transforms to fixup imported variables. lt_cdecl_hook=" -e 's/^I .* \(.*\)$/extern __declspec(dllimport) char \1;/p'" lt_c_name_hook=" -e 's/^I .* \(.*\)$/ {\"\1\", (void *) 0},/p'" lt_c_name_lib_hook="\ -e 's/^I .* \(lib.*\)$/ {\"\1\", (void *) 0},/p'\ -e 's/^I .* \(.*\)$/ {\"lib\1\", (void *) 0},/p'" else # Disable hooks by default. lt_cv_sys_global_symbol_to_import= lt_cdecl_hook= lt_c_name_hook= lt_c_name_lib_hook= fi # Transform an extracted symbol line into a proper C declaration. # Some systems (esp. on ia64) link data and code symbols differently, # so use this general approach. lt_cv_sys_global_symbol_to_cdecl="sed -n"\ $lt_cdecl_hook\ " -e 's/^T .* \(.*\)$/extern int \1();/p'"\ " -e 's/^$symcode$symcode* .* \(.*\)$/extern char \1;/p'" # Transform an extracted symbol line into symbol name and symbol address lt_cv_sys_global_symbol_to_c_name_address="sed -n"\ $lt_c_name_hook\ " -e 's/^: \(.*\) .*$/ {\"\1\", (void *) 0},/p'"\ " -e 's/^$symcode$symcode* .* \(.*\)$/ {\"\1\", (void *) \&\1},/p'" # Transform an extracted symbol line into symbol name with lib prefix and # symbol address. lt_cv_sys_global_symbol_to_c_name_address_lib_prefix="sed -n"\ $lt_c_name_lib_hook\ " -e 's/^: \(.*\) .*$/ {\"\1\", (void *) 0},/p'"\ " -e 's/^$symcode$symcode* .* \(lib.*\)$/ {\"\1\", (void *) \&\1},/p'"\ " -e 's/^$symcode$symcode* .* \(.*\)$/ {\"lib\1\", (void *) \&\1},/p'" # Handle CRLF in mingw tool chain opt_cr= case $build_os in mingw*) opt_cr=`$ECHO 'x\{0,1\}' | tr x '\015'` # option cr in regexp ;; esac # Try without a prefix underscore, then with it. for ac_symprfx in "" "_"; do # Transform symcode, sympat, and symprfx into a raw symbol and a C symbol. symxfrm="\\1 $ac_symprfx\\2 \\2" # Write the raw and C identifiers. if test "$lt_cv_nm_interface" = "MS dumpbin"; then # Fake it for dumpbin and say T for any non-static function, # D for any global variable and I for any imported variable. # Also find C++ and __fastcall symbols from MSVC++, # which start with @ or ?. lt_cv_sys_global_symbol_pipe="$AWK '"\ " {last_section=section; section=\$ 3};"\ " /^COFF SYMBOL TABLE/{for(i in hide) delete hide[i]};"\ " /Section length .*#relocs.*(pick any)/{hide[last_section]=1};"\ " /^ *Symbol name *: /{split(\$ 0,sn,\":\"); si=substr(sn[2],2)};"\ " /^ *Type *: code/{print \"T\",si,substr(si,length(prfx))};"\ " /^ *Type *: data/{print \"I\",si,substr(si,length(prfx))};"\ " \$ 0!~/External *\|/{next};"\ " / 0+ UNDEF /{next}; / UNDEF \([^|]\)*()/{next};"\ " {if(hide[section]) next};"\ " {f=\"D\"}; \$ 0~/\(\).*\|/{f=\"T\"};"\ " {split(\$ 0,a,/\||\r/); split(a[2],s)};"\ " s[1]~/^[@?]/{print f,s[1],s[1]; next};"\ " s[1]~prfx {split(s[1],t,\"@\"); print f,t[1],substr(t[1],length(prfx))}"\ " ' prfx=^$ac_symprfx" else lt_cv_sys_global_symbol_pipe="sed -n -e 's/^.*[ ]\($symcode$symcode*\)[ ][ ]*$ac_symprfx$sympat$opt_cr$/$symxfrm/p'" fi lt_cv_sys_global_symbol_pipe="$lt_cv_sys_global_symbol_pipe | sed '/ __gnu_lto/d'" # Check to see that the pipe works correctly. pipe_works=no rm -f conftest* cat > conftest.$ac_ext <<_LT_EOF #ifdef __cplusplus extern "C" { #endif char nm_test_var; void nm_test_func(void); void nm_test_func(void){} #ifdef __cplusplus } #endif int main(){nm_test_var='a';nm_test_func();return(0);} _LT_EOF if { { eval echo "\"\$as_me\":${as_lineno-$LINENO}: \"$ac_compile\""; } >&5 (eval $ac_compile) 2>&5 ac_status=$? $as_echo "$as_me:${as_lineno-$LINENO}: \$? = $ac_status" >&5 test $ac_status = 0; }; then # Now try to grab the symbols. nlist=conftest.nm if { { eval echo "\"\$as_me\":${as_lineno-$LINENO}: \"$NM conftest.$ac_objext \| "$lt_cv_sys_global_symbol_pipe" \> $nlist\""; } >&5 (eval $NM conftest.$ac_objext \| "$lt_cv_sys_global_symbol_pipe" \> $nlist) 2>&5 ac_status=$? $as_echo "$as_me:${as_lineno-$LINENO}: \$? = $ac_status" >&5 test $ac_status = 0; } && test -s "$nlist"; then # Try sorting and uniquifying the output. if sort "$nlist" | uniq > "$nlist"T; then mv -f "$nlist"T "$nlist" else rm -f "$nlist"T fi # Make sure that we snagged all the symbols we need. if $GREP ' nm_test_var$' "$nlist" >/dev/null; then if $GREP ' nm_test_func$' "$nlist" >/dev/null; then cat <<_LT_EOF > conftest.$ac_ext /* Keep this code in sync between libtool.m4, ltmain, lt_system.h, and tests. */ #if defined _WIN32 || defined __CYGWIN__ || defined _WIN32_WCE /* DATA imports from DLLs on WIN32 can't be const, because runtime relocations are performed -- see ld's documentation on pseudo-relocs. */ # define LT_DLSYM_CONST #elif defined __osf__ /* This system does not cope well with relocations in const data. */ # define LT_DLSYM_CONST #else # define LT_DLSYM_CONST const #endif #ifdef __cplusplus extern "C" { #endif _LT_EOF # Now generate the symbol file. eval "$lt_cv_sys_global_symbol_to_cdecl"' < "$nlist" | $GREP -v main >> conftest.$ac_ext' cat <<_LT_EOF >> conftest.$ac_ext /* The mapping between symbol names and symbols. */ LT_DLSYM_CONST struct { const char *name; void *address; } lt__PROGRAM__LTX_preloaded_symbols[] = { { "@PROGRAM@", (void *) 0 }, _LT_EOF $SED "s/^$symcode$symcode* .* \(.*\)$/ {\"\1\", (void *) \&\1},/" < "$nlist" | $GREP -v main >> conftest.$ac_ext cat <<\_LT_EOF >> conftest.$ac_ext {0, (void *) 0} }; /* This works around a problem in FreeBSD linker */ #ifdef FREEBSD_WORKAROUND static const void *lt_preloaded_setup() { return lt__PROGRAM__LTX_preloaded_symbols; } #endif #ifdef __cplusplus } #endif _LT_EOF # Now try linking the two files. mv conftest.$ac_objext conftstm.$ac_objext lt_globsym_save_LIBS=$LIBS lt_globsym_save_CFLAGS=$CFLAGS LIBS=conftstm.$ac_objext CFLAGS="$CFLAGS$lt_prog_compiler_no_builtin_flag" if { { eval echo "\"\$as_me\":${as_lineno-$LINENO}: \"$ac_link\""; } >&5 (eval $ac_link) 2>&5 ac_status=$? $as_echo "$as_me:${as_lineno-$LINENO}: \$? = $ac_status" >&5 test $ac_status = 0; } && test -s conftest$ac_exeext; then pipe_works=yes fi LIBS=$lt_globsym_save_LIBS CFLAGS=$lt_globsym_save_CFLAGS else echo "cannot find nm_test_func in $nlist" >&5 fi else echo "cannot find nm_test_var in $nlist" >&5 fi else echo "cannot run $lt_cv_sys_global_symbol_pipe" >&5 fi else echo "$progname: failed program was:" >&5 cat conftest.$ac_ext >&5 fi rm -rf conftest* conftst* # Do not use the global_symbol_pipe unless it works. if test yes = "$pipe_works"; then break else lt_cv_sys_global_symbol_pipe= fi done fi if test -z "$lt_cv_sys_global_symbol_pipe"; then lt_cv_sys_global_symbol_to_cdecl= fi if test -z "$lt_cv_sys_global_symbol_pipe$lt_cv_sys_global_symbol_to_cdecl"; then { $as_echo "$as_me:${as_lineno-$LINENO}: result: failed" >&5 $as_echo "failed" >&6; } else { $as_echo "$as_me:${as_lineno-$LINENO}: result: ok" >&5 $as_echo "ok" >&6; } fi # Response file support. if test "$lt_cv_nm_interface" = "MS dumpbin"; then nm_file_list_spec='@' elif $NM --help 2>/dev/null | grep '[@]FILE' >/dev/null; then nm_file_list_spec='@' fi { $as_echo "$as_me:${as_lineno-$LINENO}: checking for sysroot" >&5 $as_echo_n "checking for sysroot... " >&6; } # Check whether --with-sysroot was given. if test "${with_sysroot+set}" = set; then : withval=$with_sysroot; else with_sysroot=no fi lt_sysroot= case $with_sysroot in #( yes) if test yes = "$GCC"; then lt_sysroot=`$CC --print-sysroot 2>/dev/null` fi ;; #( /*) lt_sysroot=`echo "$with_sysroot" | sed -e "$sed_quote_subst"` ;; #( no|'') ;; #( *) { $as_echo "$as_me:${as_lineno-$LINENO}: result: $with_sysroot" >&5 $as_echo "$with_sysroot" >&6; } as_fn_error $? "The sysroot must be an absolute path." "$LINENO" 5 ;; esac { $as_echo "$as_me:${as_lineno-$LINENO}: result: ${lt_sysroot:-no}" >&5 $as_echo "${lt_sysroot:-no}" >&6; } { $as_echo "$as_me:${as_lineno-$LINENO}: checking for a working dd" >&5 $as_echo_n "checking for a working dd... " >&6; } if ${ac_cv_path_lt_DD+:} false; then : $as_echo_n "(cached) " >&6 else printf 0123456789abcdef0123456789abcdef >conftest.i cat conftest.i conftest.i >conftest2.i : ${lt_DD:=$DD} if test -z "$lt_DD"; then ac_path_lt_DD_found=false # Loop through the user's path and test for each of PROGNAME-LIST as_save_IFS=$IFS; IFS=$PATH_SEPARATOR for as_dir in $PATH do IFS=$as_save_IFS test -z "$as_dir" && as_dir=. for ac_prog in dd; do for ac_exec_ext in '' $ac_executable_extensions; do ac_path_lt_DD="$as_dir/$ac_prog$ac_exec_ext" as_fn_executable_p "$ac_path_lt_DD" || continue if "$ac_path_lt_DD" bs=32 count=1 conftest.out 2>/dev/null; then cmp -s conftest.i conftest.out \ && ac_cv_path_lt_DD="$ac_path_lt_DD" ac_path_lt_DD_found=: fi $ac_path_lt_DD_found && break 3 done done done IFS=$as_save_IFS if test -z "$ac_cv_path_lt_DD"; then : fi else ac_cv_path_lt_DD=$lt_DD fi rm -f conftest.i conftest2.i conftest.out fi { $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_cv_path_lt_DD" >&5 $as_echo "$ac_cv_path_lt_DD" >&6; } { $as_echo "$as_me:${as_lineno-$LINENO}: checking how to truncate binary pipes" >&5 $as_echo_n "checking how to truncate binary pipes... " >&6; } if ${lt_cv_truncate_bin+:} false; then : $as_echo_n "(cached) " >&6 else printf 0123456789abcdef0123456789abcdef >conftest.i cat conftest.i conftest.i >conftest2.i lt_cv_truncate_bin= if "$ac_cv_path_lt_DD" bs=32 count=1 conftest.out 2>/dev/null; then cmp -s conftest.i conftest.out \ && lt_cv_truncate_bin="$ac_cv_path_lt_DD bs=4096 count=1" fi rm -f conftest.i conftest2.i conftest.out test -z "$lt_cv_truncate_bin" && lt_cv_truncate_bin="$SED -e 4q" fi { $as_echo "$as_me:${as_lineno-$LINENO}: result: $lt_cv_truncate_bin" >&5 $as_echo "$lt_cv_truncate_bin" >&6; } # Calculate cc_basename. Skip known compiler wrappers and cross-prefix. func_cc_basename () { for cc_temp in $*""; do case $cc_temp in compile | *[\\/]compile | ccache | *[\\/]ccache ) ;; distcc | *[\\/]distcc | purify | *[\\/]purify ) ;; \-*) ;; *) break;; esac done func_cc_basename_result=`$ECHO "$cc_temp" | $SED "s%.*/%%; s%^$host_alias-%%"` } # Check whether --enable-libtool-lock was given. if test "${enable_libtool_lock+set}" = set; then : enableval=$enable_libtool_lock; fi test no = "$enable_libtool_lock" || enable_libtool_lock=yes # Some flags need to be propagated to the compiler or linker for good # libtool support. case $host in ia64-*-hpux*) # Find out what ABI is being produced by ac_compile, and set mode # options accordingly. echo 'int i;' > conftest.$ac_ext if { { eval echo "\"\$as_me\":${as_lineno-$LINENO}: \"$ac_compile\""; } >&5 (eval $ac_compile) 2>&5 ac_status=$? $as_echo "$as_me:${as_lineno-$LINENO}: \$? = $ac_status" >&5 test $ac_status = 0; }; then case `/usr/bin/file conftest.$ac_objext` in *ELF-32*) HPUX_IA64_MODE=32 ;; *ELF-64*) HPUX_IA64_MODE=64 ;; esac fi rm -rf conftest* ;; *-*-irix6*) # Find out what ABI is being produced by ac_compile, and set linker # options accordingly. echo '#line '$LINENO' "configure"' > conftest.$ac_ext if { { eval echo "\"\$as_me\":${as_lineno-$LINENO}: \"$ac_compile\""; } >&5 (eval $ac_compile) 2>&5 ac_status=$? $as_echo "$as_me:${as_lineno-$LINENO}: \$? = $ac_status" >&5 test $ac_status = 0; }; then if test yes = "$lt_cv_prog_gnu_ld"; then case `/usr/bin/file conftest.$ac_objext` in *32-bit*) LD="${LD-ld} -melf32bsmip" ;; *N32*) LD="${LD-ld} -melf32bmipn32" ;; *64-bit*) LD="${LD-ld} -melf64bmip" ;; esac else case `/usr/bin/file conftest.$ac_objext` in *32-bit*) LD="${LD-ld} -32" ;; *N32*) LD="${LD-ld} -n32" ;; *64-bit*) LD="${LD-ld} -64" ;; esac fi fi rm -rf conftest* ;; mips64*-*linux*) # Find out what ABI is being produced by ac_compile, and set linker # options accordingly. echo '#line '$LINENO' "configure"' > conftest.$ac_ext if { { eval echo "\"\$as_me\":${as_lineno-$LINENO}: \"$ac_compile\""; } >&5 (eval $ac_compile) 2>&5 ac_status=$? $as_echo "$as_me:${as_lineno-$LINENO}: \$? = $ac_status" >&5 test $ac_status = 0; }; then emul=elf case `/usr/bin/file conftest.$ac_objext` in *32-bit*) emul="${emul}32" ;; *64-bit*) emul="${emul}64" ;; esac case `/usr/bin/file conftest.$ac_objext` in *MSB*) emul="${emul}btsmip" ;; *LSB*) emul="${emul}ltsmip" ;; esac case `/usr/bin/file conftest.$ac_objext` in *N32*) emul="${emul}n32" ;; esac LD="${LD-ld} -m $emul" fi rm -rf conftest* ;; x86_64-*kfreebsd*-gnu|x86_64-*linux*|powerpc*-*linux*| \ s390*-*linux*|s390*-*tpf*|sparc*-*linux*) # Find out what ABI is being produced by ac_compile, and set linker # options accordingly. Note that the listed cases only cover the # situations where additional linker options are needed (such as when # doing 32-bit compilation for a host where ld defaults to 64-bit, or # vice versa); the common cases where no linker options are needed do # not appear in the list. echo 'int i;' > conftest.$ac_ext if { { eval echo "\"\$as_me\":${as_lineno-$LINENO}: \"$ac_compile\""; } >&5 (eval $ac_compile) 2>&5 ac_status=$? $as_echo "$as_me:${as_lineno-$LINENO}: \$? = $ac_status" >&5 test $ac_status = 0; }; then case `/usr/bin/file conftest.o` in *32-bit*) case $host in x86_64-*kfreebsd*-gnu) LD="${LD-ld} -m elf_i386_fbsd" ;; x86_64-*linux*) case `/usr/bin/file conftest.o` in *x86-64*) LD="${LD-ld} -m elf32_x86_64" ;; *) LD="${LD-ld} -m elf_i386" ;; esac ;; powerpc64le-*linux*) LD="${LD-ld} -m elf32lppclinux" ;; powerpc64-*linux*) LD="${LD-ld} -m elf32ppclinux" ;; s390x-*linux*) LD="${LD-ld} -m elf_s390" ;; sparc64-*linux*) LD="${LD-ld} -m elf32_sparc" ;; esac ;; *64-bit*) case $host in x86_64-*kfreebsd*-gnu) LD="${LD-ld} -m elf_x86_64_fbsd" ;; x86_64-*linux*) LD="${LD-ld} -m elf_x86_64" ;; powerpcle-*linux*) LD="${LD-ld} -m elf64lppc" ;; powerpc-*linux*) LD="${LD-ld} -m elf64ppc" ;; s390*-*linux*|s390*-*tpf*) LD="${LD-ld} -m elf64_s390" ;; sparc*-*linux*) LD="${LD-ld} -m elf64_sparc" ;; esac ;; esac fi rm -rf conftest* ;; *-*-sco3.2v5*) # On SCO OpenServer 5, we need -belf to get full-featured binaries. SAVE_CFLAGS=$CFLAGS CFLAGS="$CFLAGS -belf" { $as_echo "$as_me:${as_lineno-$LINENO}: checking whether the C compiler needs -belf" >&5 $as_echo_n "checking whether the C compiler needs -belf... " >&6; } if ${lt_cv_cc_needs_belf+:} false; then : $as_echo_n "(cached) " >&6 else ac_ext=c ac_cpp='$CPP $CPPFLAGS' ac_compile='$CC -c $CFLAGS $CPPFLAGS conftest.$ac_ext >&5' ac_link='$CC -o conftest$ac_exeext $CFLAGS $CPPFLAGS $LDFLAGS conftest.$ac_ext $LIBS >&5' ac_compiler_gnu=$ac_cv_c_compiler_gnu cat confdefs.h - <<_ACEOF >conftest.$ac_ext /* end confdefs.h. */ int main () { ; return 0; } _ACEOF if ac_fn_c_try_link "$LINENO"; then : lt_cv_cc_needs_belf=yes else lt_cv_cc_needs_belf=no fi rm -f core conftest.err conftest.$ac_objext \ conftest$ac_exeext conftest.$ac_ext ac_ext=c ac_cpp='$CPP $CPPFLAGS' ac_compile='$CC -c $CFLAGS $CPPFLAGS conftest.$ac_ext >&5' ac_link='$CC -o conftest$ac_exeext $CFLAGS $CPPFLAGS $LDFLAGS conftest.$ac_ext $LIBS >&5' ac_compiler_gnu=$ac_cv_c_compiler_gnu fi { $as_echo "$as_me:${as_lineno-$LINENO}: result: $lt_cv_cc_needs_belf" >&5 $as_echo "$lt_cv_cc_needs_belf" >&6; } if test yes != "$lt_cv_cc_needs_belf"; then # this is probably gcc 2.8.0, egcs 1.0 or newer; no need for -belf CFLAGS=$SAVE_CFLAGS fi ;; *-*solaris*) # Find out what ABI is being produced by ac_compile, and set linker # options accordingly. echo 'int i;' > conftest.$ac_ext if { { eval echo "\"\$as_me\":${as_lineno-$LINENO}: \"$ac_compile\""; } >&5 (eval $ac_compile) 2>&5 ac_status=$? $as_echo "$as_me:${as_lineno-$LINENO}: \$? = $ac_status" >&5 test $ac_status = 0; }; then case `/usr/bin/file conftest.o` in *64-bit*) case $lt_cv_prog_gnu_ld in yes*) case $host in i?86-*-solaris*|x86_64-*-solaris*) LD="${LD-ld} -m elf_x86_64" ;; sparc*-*-solaris*) LD="${LD-ld} -m elf64_sparc" ;; esac # GNU ld 2.21 introduced _sol2 emulations. Use them if available. if ${LD-ld} -V | grep _sol2 >/dev/null 2>&1; then LD=${LD-ld}_sol2 fi ;; *) if ${LD-ld} -64 -r -o conftest2.o conftest.o >/dev/null 2>&1; then LD="${LD-ld} -64" fi ;; esac ;; esac fi rm -rf conftest* ;; esac need_locks=$enable_libtool_lock if test -n "$ac_tool_prefix"; then # Extract the first word of "${ac_tool_prefix}mt", so it can be a program name with args. set dummy ${ac_tool_prefix}mt; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } if ${ac_cv_prog_MANIFEST_TOOL+:} false; then : $as_echo_n "(cached) " >&6 else if test -n "$MANIFEST_TOOL"; then ac_cv_prog_MANIFEST_TOOL="$MANIFEST_TOOL" # Let the user override the test. else as_save_IFS=$IFS; IFS=$PATH_SEPARATOR for as_dir in $PATH do IFS=$as_save_IFS test -z "$as_dir" && as_dir=. for ac_exec_ext in '' $ac_executable_extensions; do if as_fn_executable_p "$as_dir/$ac_word$ac_exec_ext"; then ac_cv_prog_MANIFEST_TOOL="${ac_tool_prefix}mt" $as_echo "$as_me:${as_lineno-$LINENO}: found $as_dir/$ac_word$ac_exec_ext" >&5 break 2 fi done done IFS=$as_save_IFS fi fi MANIFEST_TOOL=$ac_cv_prog_MANIFEST_TOOL if test -n "$MANIFEST_TOOL"; then { $as_echo "$as_me:${as_lineno-$LINENO}: result: $MANIFEST_TOOL" >&5 $as_echo "$MANIFEST_TOOL" >&6; } else { $as_echo "$as_me:${as_lineno-$LINENO}: result: no" >&5 $as_echo "no" >&6; } fi fi if test -z "$ac_cv_prog_MANIFEST_TOOL"; then ac_ct_MANIFEST_TOOL=$MANIFEST_TOOL # Extract the first word of "mt", so it can be a program name with args. set dummy mt; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } if ${ac_cv_prog_ac_ct_MANIFEST_TOOL+:} false; then : $as_echo_n "(cached) " >&6 else if test -n "$ac_ct_MANIFEST_TOOL"; then ac_cv_prog_ac_ct_MANIFEST_TOOL="$ac_ct_MANIFEST_TOOL" # Let the user override the test. else as_save_IFS=$IFS; IFS=$PATH_SEPARATOR for as_dir in $PATH do IFS=$as_save_IFS test -z "$as_dir" && as_dir=. for ac_exec_ext in '' $ac_executable_extensions; do if as_fn_executable_p "$as_dir/$ac_word$ac_exec_ext"; then ac_cv_prog_ac_ct_MANIFEST_TOOL="mt" $as_echo "$as_me:${as_lineno-$LINENO}: found $as_dir/$ac_word$ac_exec_ext" >&5 break 2 fi done done IFS=$as_save_IFS fi fi ac_ct_MANIFEST_TOOL=$ac_cv_prog_ac_ct_MANIFEST_TOOL if test -n "$ac_ct_MANIFEST_TOOL"; then { $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_ct_MANIFEST_TOOL" >&5 $as_echo "$ac_ct_MANIFEST_TOOL" >&6; } else { $as_echo "$as_me:${as_lineno-$LINENO}: result: no" >&5 $as_echo "no" >&6; } fi if test "x$ac_ct_MANIFEST_TOOL" = x; then MANIFEST_TOOL=":" else case $cross_compiling:$ac_tool_warned in yes:) { $as_echo "$as_me:${as_lineno-$LINENO}: WARNING: using cross tools not prefixed with host triplet" >&5 $as_echo "$as_me: WARNING: using cross tools not prefixed with host triplet" >&2;} ac_tool_warned=yes ;; esac MANIFEST_TOOL=$ac_ct_MANIFEST_TOOL fi else MANIFEST_TOOL="$ac_cv_prog_MANIFEST_TOOL" fi test -z "$MANIFEST_TOOL" && MANIFEST_TOOL=mt { $as_echo "$as_me:${as_lineno-$LINENO}: checking if $MANIFEST_TOOL is a manifest tool" >&5 $as_echo_n "checking if $MANIFEST_TOOL is a manifest tool... " >&6; } if ${lt_cv_path_mainfest_tool+:} false; then : $as_echo_n "(cached) " >&6 else lt_cv_path_mainfest_tool=no echo "$as_me:$LINENO: $MANIFEST_TOOL '-?'" >&5 $MANIFEST_TOOL '-?' 2>conftest.err > conftest.out cat conftest.err >&5 if $GREP 'Manifest Tool' conftest.out > /dev/null; then lt_cv_path_mainfest_tool=yes fi rm -f conftest* fi { $as_echo "$as_me:${as_lineno-$LINENO}: result: $lt_cv_path_mainfest_tool" >&5 $as_echo "$lt_cv_path_mainfest_tool" >&6; } if test yes != "$lt_cv_path_mainfest_tool"; then MANIFEST_TOOL=: fi case $host_os in rhapsody* | darwin*) if test -n "$ac_tool_prefix"; then # Extract the first word of "${ac_tool_prefix}dsymutil", so it can be a program name with args. set dummy ${ac_tool_prefix}dsymutil; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } if ${ac_cv_prog_DSYMUTIL+:} false; then : $as_echo_n "(cached) " >&6 else if test -n "$DSYMUTIL"; then ac_cv_prog_DSYMUTIL="$DSYMUTIL" # Let the user override the test. else as_save_IFS=$IFS; IFS=$PATH_SEPARATOR for as_dir in $PATH do IFS=$as_save_IFS test -z "$as_dir" && as_dir=. for ac_exec_ext in '' $ac_executable_extensions; do if as_fn_executable_p "$as_dir/$ac_word$ac_exec_ext"; then ac_cv_prog_DSYMUTIL="${ac_tool_prefix}dsymutil" $as_echo "$as_me:${as_lineno-$LINENO}: found $as_dir/$ac_word$ac_exec_ext" >&5 break 2 fi done done IFS=$as_save_IFS fi fi DSYMUTIL=$ac_cv_prog_DSYMUTIL if test -n "$DSYMUTIL"; then { $as_echo "$as_me:${as_lineno-$LINENO}: result: $DSYMUTIL" >&5 $as_echo "$DSYMUTIL" >&6; } else { $as_echo "$as_me:${as_lineno-$LINENO}: result: no" >&5 $as_echo "no" >&6; } fi fi if test -z "$ac_cv_prog_DSYMUTIL"; then ac_ct_DSYMUTIL=$DSYMUTIL # Extract the first word of "dsymutil", so it can be a program name with args. set dummy dsymutil; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } if ${ac_cv_prog_ac_ct_DSYMUTIL+:} false; then : $as_echo_n "(cached) " >&6 else if test -n "$ac_ct_DSYMUTIL"; then ac_cv_prog_ac_ct_DSYMUTIL="$ac_ct_DSYMUTIL" # Let the user override the test. else as_save_IFS=$IFS; IFS=$PATH_SEPARATOR for as_dir in $PATH do IFS=$as_save_IFS test -z "$as_dir" && as_dir=. for ac_exec_ext in '' $ac_executable_extensions; do if as_fn_executable_p "$as_dir/$ac_word$ac_exec_ext"; then ac_cv_prog_ac_ct_DSYMUTIL="dsymutil" $as_echo "$as_me:${as_lineno-$LINENO}: found $as_dir/$ac_word$ac_exec_ext" >&5 break 2 fi done done IFS=$as_save_IFS fi fi ac_ct_DSYMUTIL=$ac_cv_prog_ac_ct_DSYMUTIL if test -n "$ac_ct_DSYMUTIL"; then { $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_ct_DSYMUTIL" >&5 $as_echo "$ac_ct_DSYMUTIL" >&6; } else { $as_echo "$as_me:${as_lineno-$LINENO}: result: no" >&5 $as_echo "no" >&6; } fi if test "x$ac_ct_DSYMUTIL" = x; then DSYMUTIL=":" else case $cross_compiling:$ac_tool_warned in yes:) { $as_echo "$as_me:${as_lineno-$LINENO}: WARNING: using cross tools not prefixed with host triplet" >&5 $as_echo "$as_me: WARNING: using cross tools not prefixed with host triplet" >&2;} ac_tool_warned=yes ;; esac DSYMUTIL=$ac_ct_DSYMUTIL fi else DSYMUTIL="$ac_cv_prog_DSYMUTIL" fi if test -n "$ac_tool_prefix"; then # Extract the first word of "${ac_tool_prefix}nmedit", so it can be a program name with args. set dummy ${ac_tool_prefix}nmedit; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } if ${ac_cv_prog_NMEDIT+:} false; then : $as_echo_n "(cached) " >&6 else if test -n "$NMEDIT"; then ac_cv_prog_NMEDIT="$NMEDIT" # Let the user override the test. else as_save_IFS=$IFS; IFS=$PATH_SEPARATOR for as_dir in $PATH do IFS=$as_save_IFS test -z "$as_dir" && as_dir=. for ac_exec_ext in '' $ac_executable_extensions; do if as_fn_executable_p "$as_dir/$ac_word$ac_exec_ext"; then ac_cv_prog_NMEDIT="${ac_tool_prefix}nmedit" $as_echo "$as_me:${as_lineno-$LINENO}: found $as_dir/$ac_word$ac_exec_ext" >&5 break 2 fi done done IFS=$as_save_IFS fi fi NMEDIT=$ac_cv_prog_NMEDIT if test -n "$NMEDIT"; then { $as_echo "$as_me:${as_lineno-$LINENO}: result: $NMEDIT" >&5 $as_echo "$NMEDIT" >&6; } else { $as_echo "$as_me:${as_lineno-$LINENO}: result: no" >&5 $as_echo "no" >&6; } fi fi if test -z "$ac_cv_prog_NMEDIT"; then ac_ct_NMEDIT=$NMEDIT # Extract the first word of "nmedit", so it can be a program name with args. set dummy nmedit; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } if ${ac_cv_prog_ac_ct_NMEDIT+:} false; then : $as_echo_n "(cached) " >&6 else if test -n "$ac_ct_NMEDIT"; then ac_cv_prog_ac_ct_NMEDIT="$ac_ct_NMEDIT" # Let the user override the test. else as_save_IFS=$IFS; IFS=$PATH_SEPARATOR for as_dir in $PATH do IFS=$as_save_IFS test -z "$as_dir" && as_dir=. for ac_exec_ext in '' $ac_executable_extensions; do if as_fn_executable_p "$as_dir/$ac_word$ac_exec_ext"; then ac_cv_prog_ac_ct_NMEDIT="nmedit" $as_echo "$as_me:${as_lineno-$LINENO}: found $as_dir/$ac_word$ac_exec_ext" >&5 break 2 fi done done IFS=$as_save_IFS fi fi ac_ct_NMEDIT=$ac_cv_prog_ac_ct_NMEDIT if test -n "$ac_ct_NMEDIT"; then { $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_ct_NMEDIT" >&5 $as_echo "$ac_ct_NMEDIT" >&6; } else { $as_echo "$as_me:${as_lineno-$LINENO}: result: no" >&5 $as_echo "no" >&6; } fi if test "x$ac_ct_NMEDIT" = x; then NMEDIT=":" else case $cross_compiling:$ac_tool_warned in yes:) { $as_echo "$as_me:${as_lineno-$LINENO}: WARNING: using cross tools not prefixed with host triplet" >&5 $as_echo "$as_me: WARNING: using cross tools not prefixed with host triplet" >&2;} ac_tool_warned=yes ;; esac NMEDIT=$ac_ct_NMEDIT fi else NMEDIT="$ac_cv_prog_NMEDIT" fi if test -n "$ac_tool_prefix"; then # Extract the first word of "${ac_tool_prefix}lipo", so it can be a program name with args. set dummy ${ac_tool_prefix}lipo; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } if ${ac_cv_prog_LIPO+:} false; then : $as_echo_n "(cached) " >&6 else if test -n "$LIPO"; then ac_cv_prog_LIPO="$LIPO" # Let the user override the test. else as_save_IFS=$IFS; IFS=$PATH_SEPARATOR for as_dir in $PATH do IFS=$as_save_IFS test -z "$as_dir" && as_dir=. for ac_exec_ext in '' $ac_executable_extensions; do if as_fn_executable_p "$as_dir/$ac_word$ac_exec_ext"; then ac_cv_prog_LIPO="${ac_tool_prefix}lipo" $as_echo "$as_me:${as_lineno-$LINENO}: found $as_dir/$ac_word$ac_exec_ext" >&5 break 2 fi done done IFS=$as_save_IFS fi fi LIPO=$ac_cv_prog_LIPO if test -n "$LIPO"; then { $as_echo "$as_me:${as_lineno-$LINENO}: result: $LIPO" >&5 $as_echo "$LIPO" >&6; } else { $as_echo "$as_me:${as_lineno-$LINENO}: result: no" >&5 $as_echo "no" >&6; } fi fi if test -z "$ac_cv_prog_LIPO"; then ac_ct_LIPO=$LIPO # Extract the first word of "lipo", so it can be a program name with args. set dummy lipo; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } if ${ac_cv_prog_ac_ct_LIPO+:} false; then : $as_echo_n "(cached) " >&6 else if test -n "$ac_ct_LIPO"; then ac_cv_prog_ac_ct_LIPO="$ac_ct_LIPO" # Let the user override the test. else as_save_IFS=$IFS; IFS=$PATH_SEPARATOR for as_dir in $PATH do IFS=$as_save_IFS test -z "$as_dir" && as_dir=. for ac_exec_ext in '' $ac_executable_extensions; do if as_fn_executable_p "$as_dir/$ac_word$ac_exec_ext"; then ac_cv_prog_ac_ct_LIPO="lipo" $as_echo "$as_me:${as_lineno-$LINENO}: found $as_dir/$ac_word$ac_exec_ext" >&5 break 2 fi done done IFS=$as_save_IFS fi fi ac_ct_LIPO=$ac_cv_prog_ac_ct_LIPO if test -n "$ac_ct_LIPO"; then { $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_ct_LIPO" >&5 $as_echo "$ac_ct_LIPO" >&6; } else { $as_echo "$as_me:${as_lineno-$LINENO}: result: no" >&5 $as_echo "no" >&6; } fi if test "x$ac_ct_LIPO" = x; then LIPO=":" else case $cross_compiling:$ac_tool_warned in yes:) { $as_echo "$as_me:${as_lineno-$LINENO}: WARNING: using cross tools not prefixed with host triplet" >&5 $as_echo "$as_me: WARNING: using cross tools not prefixed with host triplet" >&2;} ac_tool_warned=yes ;; esac LIPO=$ac_ct_LIPO fi else LIPO="$ac_cv_prog_LIPO" fi if test -n "$ac_tool_prefix"; then # Extract the first word of "${ac_tool_prefix}otool", so it can be a program name with args. set dummy ${ac_tool_prefix}otool; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } if ${ac_cv_prog_OTOOL+:} false; then : $as_echo_n "(cached) " >&6 else if test -n "$OTOOL"; then ac_cv_prog_OTOOL="$OTOOL" # Let the user override the test. else as_save_IFS=$IFS; IFS=$PATH_SEPARATOR for as_dir in $PATH do IFS=$as_save_IFS test -z "$as_dir" && as_dir=. for ac_exec_ext in '' $ac_executable_extensions; do if as_fn_executable_p "$as_dir/$ac_word$ac_exec_ext"; then ac_cv_prog_OTOOL="${ac_tool_prefix}otool" $as_echo "$as_me:${as_lineno-$LINENO}: found $as_dir/$ac_word$ac_exec_ext" >&5 break 2 fi done done IFS=$as_save_IFS fi fi OTOOL=$ac_cv_prog_OTOOL if test -n "$OTOOL"; then { $as_echo "$as_me:${as_lineno-$LINENO}: result: $OTOOL" >&5 $as_echo "$OTOOL" >&6; } else { $as_echo "$as_me:${as_lineno-$LINENO}: result: no" >&5 $as_echo "no" >&6; } fi fi if test -z "$ac_cv_prog_OTOOL"; then ac_ct_OTOOL=$OTOOL # Extract the first word of "otool", so it can be a program name with args. set dummy otool; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } if ${ac_cv_prog_ac_ct_OTOOL+:} false; then : $as_echo_n "(cached) " >&6 else if test -n "$ac_ct_OTOOL"; then ac_cv_prog_ac_ct_OTOOL="$ac_ct_OTOOL" # Let the user override the test. else as_save_IFS=$IFS; IFS=$PATH_SEPARATOR for as_dir in $PATH do IFS=$as_save_IFS test -z "$as_dir" && as_dir=. for ac_exec_ext in '' $ac_executable_extensions; do if as_fn_executable_p "$as_dir/$ac_word$ac_exec_ext"; then ac_cv_prog_ac_ct_OTOOL="otool" $as_echo "$as_me:${as_lineno-$LINENO}: found $as_dir/$ac_word$ac_exec_ext" >&5 break 2 fi done done IFS=$as_save_IFS fi fi ac_ct_OTOOL=$ac_cv_prog_ac_ct_OTOOL if test -n "$ac_ct_OTOOL"; then { $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_ct_OTOOL" >&5 $as_echo "$ac_ct_OTOOL" >&6; } else { $as_echo "$as_me:${as_lineno-$LINENO}: result: no" >&5 $as_echo "no" >&6; } fi if test "x$ac_ct_OTOOL" = x; then OTOOL=":" else case $cross_compiling:$ac_tool_warned in yes:) { $as_echo "$as_me:${as_lineno-$LINENO}: WARNING: using cross tools not prefixed with host triplet" >&5 $as_echo "$as_me: WARNING: using cross tools not prefixed with host triplet" >&2;} ac_tool_warned=yes ;; esac OTOOL=$ac_ct_OTOOL fi else OTOOL="$ac_cv_prog_OTOOL" fi if test -n "$ac_tool_prefix"; then # Extract the first word of "${ac_tool_prefix}otool64", so it can be a program name with args. set dummy ${ac_tool_prefix}otool64; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } if ${ac_cv_prog_OTOOL64+:} false; then : $as_echo_n "(cached) " >&6 else if test -n "$OTOOL64"; then ac_cv_prog_OTOOL64="$OTOOL64" # Let the user override the test. else as_save_IFS=$IFS; IFS=$PATH_SEPARATOR for as_dir in $PATH do IFS=$as_save_IFS test -z "$as_dir" && as_dir=. for ac_exec_ext in '' $ac_executable_extensions; do if as_fn_executable_p "$as_dir/$ac_word$ac_exec_ext"; then ac_cv_prog_OTOOL64="${ac_tool_prefix}otool64" $as_echo "$as_me:${as_lineno-$LINENO}: found $as_dir/$ac_word$ac_exec_ext" >&5 break 2 fi done done IFS=$as_save_IFS fi fi OTOOL64=$ac_cv_prog_OTOOL64 if test -n "$OTOOL64"; then { $as_echo "$as_me:${as_lineno-$LINENO}: result: $OTOOL64" >&5 $as_echo "$OTOOL64" >&6; } else { $as_echo "$as_me:${as_lineno-$LINENO}: result: no" >&5 $as_echo "no" >&6; } fi fi if test -z "$ac_cv_prog_OTOOL64"; then ac_ct_OTOOL64=$OTOOL64 # Extract the first word of "otool64", so it can be a program name with args. set dummy otool64; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } if ${ac_cv_prog_ac_ct_OTOOL64+:} false; then : $as_echo_n "(cached) " >&6 else if test -n "$ac_ct_OTOOL64"; then ac_cv_prog_ac_ct_OTOOL64="$ac_ct_OTOOL64" # Let the user override the test. else as_save_IFS=$IFS; IFS=$PATH_SEPARATOR for as_dir in $PATH do IFS=$as_save_IFS test -z "$as_dir" && as_dir=. for ac_exec_ext in '' $ac_executable_extensions; do if as_fn_executable_p "$as_dir/$ac_word$ac_exec_ext"; then ac_cv_prog_ac_ct_OTOOL64="otool64" $as_echo "$as_me:${as_lineno-$LINENO}: found $as_dir/$ac_word$ac_exec_ext" >&5 break 2 fi done done IFS=$as_save_IFS fi fi ac_ct_OTOOL64=$ac_cv_prog_ac_ct_OTOOL64 if test -n "$ac_ct_OTOOL64"; then { $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_ct_OTOOL64" >&5 $as_echo "$ac_ct_OTOOL64" >&6; } else { $as_echo "$as_me:${as_lineno-$LINENO}: result: no" >&5 $as_echo "no" >&6; } fi if test "x$ac_ct_OTOOL64" = x; then OTOOL64=":" else case $cross_compiling:$ac_tool_warned in yes:) { $as_echo "$as_me:${as_lineno-$LINENO}: WARNING: using cross tools not prefixed with host triplet" >&5 $as_echo "$as_me: WARNING: using cross tools not prefixed with host triplet" >&2;} ac_tool_warned=yes ;; esac OTOOL64=$ac_ct_OTOOL64 fi else OTOOL64="$ac_cv_prog_OTOOL64" fi { $as_echo "$as_me:${as_lineno-$LINENO}: checking for -single_module linker flag" >&5 $as_echo_n "checking for -single_module linker flag... " >&6; } if ${lt_cv_apple_cc_single_mod+:} false; then : $as_echo_n "(cached) " >&6 else lt_cv_apple_cc_single_mod=no if test -z "$LT_MULTI_MODULE"; then # By default we will add the -single_module flag. You can override # by either setting the environment variable LT_MULTI_MODULE # non-empty at configure time, or by adding -multi_module to the # link flags. rm -rf libconftest.dylib* echo "int foo(void){return 1;}" > conftest.c echo "$LTCC $LTCFLAGS $LDFLAGS -o libconftest.dylib \ -dynamiclib -Wl,-single_module conftest.c" >&5 $LTCC $LTCFLAGS $LDFLAGS -o libconftest.dylib \ -dynamiclib -Wl,-single_module conftest.c 2>conftest.err _lt_result=$? # If there is a non-empty error log, and "single_module" # appears in it, assume the flag caused a linker warning if test -s conftest.err && $GREP single_module conftest.err; then cat conftest.err >&5 # Otherwise, if the output was created with a 0 exit code from # the compiler, it worked. elif test -f libconftest.dylib && test 0 = "$_lt_result"; then lt_cv_apple_cc_single_mod=yes else cat conftest.err >&5 fi rm -rf libconftest.dylib* rm -f conftest.* fi fi { $as_echo "$as_me:${as_lineno-$LINENO}: result: $lt_cv_apple_cc_single_mod" >&5 $as_echo "$lt_cv_apple_cc_single_mod" >&6; } { $as_echo "$as_me:${as_lineno-$LINENO}: checking for -exported_symbols_list linker flag" >&5 $as_echo_n "checking for -exported_symbols_list linker flag... " >&6; } if ${lt_cv_ld_exported_symbols_list+:} false; then : $as_echo_n "(cached) " >&6 else lt_cv_ld_exported_symbols_list=no save_LDFLAGS=$LDFLAGS echo "_main" > conftest.sym LDFLAGS="$LDFLAGS -Wl,-exported_symbols_list,conftest.sym" cat confdefs.h - <<_ACEOF >conftest.$ac_ext /* end confdefs.h. */ int main () { ; return 0; } _ACEOF if ac_fn_c_try_link "$LINENO"; then : lt_cv_ld_exported_symbols_list=yes else lt_cv_ld_exported_symbols_list=no fi rm -f core conftest.err conftest.$ac_objext \ conftest$ac_exeext conftest.$ac_ext LDFLAGS=$save_LDFLAGS fi { $as_echo "$as_me:${as_lineno-$LINENO}: result: $lt_cv_ld_exported_symbols_list" >&5 $as_echo "$lt_cv_ld_exported_symbols_list" >&6; } { $as_echo "$as_me:${as_lineno-$LINENO}: checking for -force_load linker flag" >&5 $as_echo_n "checking for -force_load linker flag... " >&6; } if ${lt_cv_ld_force_load+:} false; then : $as_echo_n "(cached) " >&6 else lt_cv_ld_force_load=no cat > conftest.c << _LT_EOF int forced_loaded() { return 2;} _LT_EOF echo "$LTCC $LTCFLAGS -c -o conftest.o conftest.c" >&5 $LTCC $LTCFLAGS -c -o conftest.o conftest.c 2>&5 echo "$AR cru libconftest.a conftest.o" >&5 $AR cru libconftest.a conftest.o 2>&5 echo "$RANLIB libconftest.a" >&5 $RANLIB libconftest.a 2>&5 cat > conftest.c << _LT_EOF int main() { return 0;} _LT_EOF echo "$LTCC $LTCFLAGS $LDFLAGS -o conftest conftest.c -Wl,-force_load,./libconftest.a" >&5 $LTCC $LTCFLAGS $LDFLAGS -o conftest conftest.c -Wl,-force_load,./libconftest.a 2>conftest.err _lt_result=$? if test -s conftest.err && $GREP force_load conftest.err; then cat conftest.err >&5 elif test -f conftest && test 0 = "$_lt_result" && $GREP forced_load conftest >/dev/null 2>&1; then lt_cv_ld_force_load=yes else cat conftest.err >&5 fi rm -f conftest.err libconftest.a conftest conftest.c rm -rf conftest.dSYM fi { $as_echo "$as_me:${as_lineno-$LINENO}: result: $lt_cv_ld_force_load" >&5 $as_echo "$lt_cv_ld_force_load" >&6; } case $host_os in rhapsody* | darwin1.[012]) _lt_dar_allow_undefined='$wl-undefined ${wl}suppress' ;; darwin1.*) _lt_dar_allow_undefined='$wl-flat_namespace $wl-undefined ${wl}suppress' ;; darwin*) # darwin 5.x on # if running on 10.5 or later, the deployment target defaults # to the OS version, if on x86, and 10.4, the deployment # target defaults to 10.4. Don't you love it? case ${MACOSX_DEPLOYMENT_TARGET-10.0},$host in 10.0,*86*-darwin8*|10.0,*-darwin[91]*) _lt_dar_allow_undefined='$wl-undefined ${wl}dynamic_lookup' ;; 10.[012][,.]*) _lt_dar_allow_undefined='$wl-flat_namespace $wl-undefined ${wl}suppress' ;; 10.*) _lt_dar_allow_undefined='$wl-undefined ${wl}dynamic_lookup' ;; esac ;; esac if test yes = "$lt_cv_apple_cc_single_mod"; then _lt_dar_single_mod='$single_module' fi if test yes = "$lt_cv_ld_exported_symbols_list"; then _lt_dar_export_syms=' $wl-exported_symbols_list,$output_objdir/$libname-symbols.expsym' else _lt_dar_export_syms='~$NMEDIT -s $output_objdir/$libname-symbols.expsym $lib' fi if test : != "$DSYMUTIL" && test no = "$lt_cv_ld_force_load"; then _lt_dsymutil='~$DSYMUTIL $lib || :' else _lt_dsymutil= fi ;; esac # func_munge_path_list VARIABLE PATH # ----------------------------------- # VARIABLE is name of variable containing _space_ separated list of # directories to be munged by the contents of PATH, which is string # having a format: # "DIR[:DIR]:" # string "DIR[ DIR]" will be prepended to VARIABLE # ":DIR[:DIR]" # string "DIR[ DIR]" will be appended to VARIABLE # "DIRP[:DIRP]::[DIRA:]DIRA" # string "DIRP[ DIRP]" will be prepended to VARIABLE and string # "DIRA[ DIRA]" will be appended to VARIABLE # "DIR[:DIR]" # VARIABLE will be replaced by "DIR[ DIR]" func_munge_path_list () { case x$2 in x) ;; *:) eval $1=\"`$ECHO $2 | $SED 's/:/ /g'` \$$1\" ;; x:*) eval $1=\"\$$1 `$ECHO $2 | $SED 's/:/ /g'`\" ;; *::*) eval $1=\"\$$1\ `$ECHO $2 | $SED -e 's/.*:://' -e 's/:/ /g'`\" eval $1=\"`$ECHO $2 | $SED -e 's/::.*//' -e 's/:/ /g'`\ \$$1\" ;; *) eval $1=\"`$ECHO $2 | $SED 's/:/ /g'`\" ;; esac } ac_ext=c ac_cpp='$CPP $CPPFLAGS' ac_compile='$CC -c $CFLAGS $CPPFLAGS conftest.$ac_ext >&5' ac_link='$CC -o conftest$ac_exeext $CFLAGS $CPPFLAGS $LDFLAGS conftest.$ac_ext $LIBS >&5' ac_compiler_gnu=$ac_cv_c_compiler_gnu { $as_echo "$as_me:${as_lineno-$LINENO}: checking how to run the C preprocessor" >&5 $as_echo_n "checking how to run the C preprocessor... " >&6; } # On Suns, sometimes $CPP names a directory. if test -n "$CPP" && test -d "$CPP"; then CPP= fi if test -z "$CPP"; then if ${ac_cv_prog_CPP+:} false; then : $as_echo_n "(cached) " >&6 else # Double quotes because CPP needs to be expanded for CPP in "$CC -E" "$CC -E -traditional-cpp" "/lib/cpp" do ac_preproc_ok=false for ac_c_preproc_warn_flag in '' yes do # Use a header file that comes with gcc, so configuring glibc # with a fresh cross-compiler works. # Prefer to if __STDC__ is defined, since # exists even on freestanding compilers. # On the NeXT, cc -E runs the code through the compiler's parser, # not just through cpp. "Syntax error" is here to catch this case. cat confdefs.h - <<_ACEOF >conftest.$ac_ext /* end confdefs.h. */ #ifdef __STDC__ # include #else # include #endif Syntax error _ACEOF if ac_fn_c_try_cpp "$LINENO"; then : else # Broken: fails on valid input. continue fi rm -f conftest.err conftest.i conftest.$ac_ext # OK, works on sane cases. Now check whether nonexistent headers # can be detected and how. cat confdefs.h - <<_ACEOF >conftest.$ac_ext /* end confdefs.h. */ #include _ACEOF if ac_fn_c_try_cpp "$LINENO"; then : # Broken: success on invalid input. continue else # Passes both tests. ac_preproc_ok=: break fi rm -f conftest.err conftest.i conftest.$ac_ext done # Because of `break', _AC_PREPROC_IFELSE's cleaning code was skipped. rm -f conftest.i conftest.err conftest.$ac_ext if $ac_preproc_ok; then : break fi done ac_cv_prog_CPP=$CPP fi CPP=$ac_cv_prog_CPP else ac_cv_prog_CPP=$CPP fi { $as_echo "$as_me:${as_lineno-$LINENO}: result: $CPP" >&5 $as_echo "$CPP" >&6; } ac_preproc_ok=false for ac_c_preproc_warn_flag in '' yes do # Use a header file that comes with gcc, so configuring glibc # with a fresh cross-compiler works. # Prefer to if __STDC__ is defined, since # exists even on freestanding compilers. # On the NeXT, cc -E runs the code through the compiler's parser, # not just through cpp. "Syntax error" is here to catch this case. cat confdefs.h - <<_ACEOF >conftest.$ac_ext /* end confdefs.h. */ #ifdef __STDC__ # include #else # include #endif Syntax error _ACEOF if ac_fn_c_try_cpp "$LINENO"; then : else # Broken: fails on valid input. continue fi rm -f conftest.err conftest.i conftest.$ac_ext # OK, works on sane cases. Now check whether nonexistent headers # can be detected and how. cat confdefs.h - <<_ACEOF >conftest.$ac_ext /* end confdefs.h. */ #include _ACEOF if ac_fn_c_try_cpp "$LINENO"; then : # Broken: success on invalid input. continue else # Passes both tests. ac_preproc_ok=: break fi rm -f conftest.err conftest.i conftest.$ac_ext done # Because of `break', _AC_PREPROC_IFELSE's cleaning code was skipped. rm -f conftest.i conftest.err conftest.$ac_ext if $ac_preproc_ok; then : else { { $as_echo "$as_me:${as_lineno-$LINENO}: error: in \`$ac_pwd':" >&5 $as_echo "$as_me: error: in \`$ac_pwd':" >&2;} as_fn_error $? "C preprocessor \"$CPP\" fails sanity check See \`config.log' for more details" "$LINENO" 5; } fi ac_ext=c ac_cpp='$CPP $CPPFLAGS' ac_compile='$CC -c $CFLAGS $CPPFLAGS conftest.$ac_ext >&5' ac_link='$CC -o conftest$ac_exeext $CFLAGS $CPPFLAGS $LDFLAGS conftest.$ac_ext $LIBS >&5' ac_compiler_gnu=$ac_cv_c_compiler_gnu { $as_echo "$as_me:${as_lineno-$LINENO}: checking for ANSI C header files" >&5 $as_echo_n "checking for ANSI C header files... " >&6; } if ${ac_cv_header_stdc+:} false; then : $as_echo_n "(cached) " >&6 else cat confdefs.h - <<_ACEOF >conftest.$ac_ext /* end confdefs.h. */ #include #include #include #include int main () { ; return 0; } _ACEOF if ac_fn_c_try_compile "$LINENO"; then : ac_cv_header_stdc=yes else ac_cv_header_stdc=no fi rm -f core conftest.err conftest.$ac_objext conftest.$ac_ext if test $ac_cv_header_stdc = yes; then # SunOS 4.x string.h does not declare mem*, contrary to ANSI. cat confdefs.h - <<_ACEOF >conftest.$ac_ext /* end confdefs.h. */ #include _ACEOF if (eval "$ac_cpp conftest.$ac_ext") 2>&5 | $EGREP "memchr" >/dev/null 2>&1; then : else ac_cv_header_stdc=no fi rm -f conftest* fi if test $ac_cv_header_stdc = yes; then # ISC 2.0.2 stdlib.h does not declare free, contrary to ANSI. cat confdefs.h - <<_ACEOF >conftest.$ac_ext /* end confdefs.h. */ #include _ACEOF if (eval "$ac_cpp conftest.$ac_ext") 2>&5 | $EGREP "free" >/dev/null 2>&1; then : else ac_cv_header_stdc=no fi rm -f conftest* fi if test $ac_cv_header_stdc = yes; then # /bin/cc in Irix-4.0.5 gets non-ANSI ctype macros unless using -ansi. if test "$cross_compiling" = yes; then : : else cat confdefs.h - <<_ACEOF >conftest.$ac_ext /* end confdefs.h. */ #include #include #if ((' ' & 0x0FF) == 0x020) # define ISLOWER(c) ('a' <= (c) && (c) <= 'z') # define TOUPPER(c) (ISLOWER(c) ? 'A' + ((c) - 'a') : (c)) #else # define ISLOWER(c) \ (('a' <= (c) && (c) <= 'i') \ || ('j' <= (c) && (c) <= 'r') \ || ('s' <= (c) && (c) <= 'z')) # define TOUPPER(c) (ISLOWER(c) ? ((c) | 0x40) : (c)) #endif #define XOR(e, f) (((e) && !(f)) || (!(e) && (f))) int main () { int i; for (i = 0; i < 256; i++) if (XOR (islower (i), ISLOWER (i)) || toupper (i) != TOUPPER (i)) return 2; return 0; } _ACEOF if ac_fn_c_try_run "$LINENO"; then : else ac_cv_header_stdc=no fi rm -f core *.core core.conftest.* gmon.out bb.out conftest$ac_exeext \ conftest.$ac_objext conftest.beam conftest.$ac_ext fi fi fi { $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_cv_header_stdc" >&5 $as_echo "$ac_cv_header_stdc" >&6; } if test $ac_cv_header_stdc = yes; then $as_echo "#define STDC_HEADERS 1" >>confdefs.h fi # On IRIX 5.3, sys/types and inttypes.h are conflicting. for ac_header in sys/types.h sys/stat.h stdlib.h string.h memory.h strings.h \ inttypes.h stdint.h unistd.h do : as_ac_Header=`$as_echo "ac_cv_header_$ac_header" | $as_tr_sh` ac_fn_c_check_header_compile "$LINENO" "$ac_header" "$as_ac_Header" "$ac_includes_default " if eval test \"x\$"$as_ac_Header"\" = x"yes"; then : cat >>confdefs.h <<_ACEOF #define `$as_echo "HAVE_$ac_header" | $as_tr_cpp` 1 _ACEOF fi done for ac_header in dlfcn.h do : ac_fn_c_check_header_compile "$LINENO" "dlfcn.h" "ac_cv_header_dlfcn_h" "$ac_includes_default " if test "x$ac_cv_header_dlfcn_h" = xyes; then : cat >>confdefs.h <<_ACEOF #define HAVE_DLFCN_H 1 _ACEOF fi done # Set options enable_dlopen=no enable_win32_dll=no # Check whether --enable-shared was given. if test "${enable_shared+set}" = set; then : enableval=$enable_shared; p=${PACKAGE-default} case $enableval in yes) enable_shared=yes ;; no) enable_shared=no ;; *) enable_shared=no # Look at the argument we got. We use all the common list separators. lt_save_ifs=$IFS; IFS=$IFS$PATH_SEPARATOR, for pkg in $enableval; do IFS=$lt_save_ifs if test "X$pkg" = "X$p"; then enable_shared=yes fi done IFS=$lt_save_ifs ;; esac else enable_shared=yes fi # Check whether --enable-static was given. if test "${enable_static+set}" = set; then : enableval=$enable_static; p=${PACKAGE-default} case $enableval in yes) enable_static=yes ;; no) enable_static=no ;; *) enable_static=no # Look at the argument we got. We use all the common list separators. lt_save_ifs=$IFS; IFS=$IFS$PATH_SEPARATOR, for pkg in $enableval; do IFS=$lt_save_ifs if test "X$pkg" = "X$p"; then enable_static=yes fi done IFS=$lt_save_ifs ;; esac else enable_static=yes fi # Check whether --with-pic was given. if test "${with_pic+set}" = set; then : withval=$with_pic; lt_p=${PACKAGE-default} case $withval in yes|no) pic_mode=$withval ;; *) pic_mode=default # Look at the argument we got. We use all the common list separators. lt_save_ifs=$IFS; IFS=$IFS$PATH_SEPARATOR, for lt_pkg in $withval; do IFS=$lt_save_ifs if test "X$lt_pkg" = "X$lt_p"; then pic_mode=yes fi done IFS=$lt_save_ifs ;; esac else pic_mode=default fi # Check whether --enable-fast-install was given. if test "${enable_fast_install+set}" = set; then : enableval=$enable_fast_install; p=${PACKAGE-default} case $enableval in yes) enable_fast_install=yes ;; no) enable_fast_install=no ;; *) enable_fast_install=no # Look at the argument we got. We use all the common list separators. lt_save_ifs=$IFS; IFS=$IFS$PATH_SEPARATOR, for pkg in $enableval; do IFS=$lt_save_ifs if test "X$pkg" = "X$p"; then enable_fast_install=yes fi done IFS=$lt_save_ifs ;; esac else enable_fast_install=yes fi shared_archive_member_spec= case $host,$enable_shared in power*-*-aix[5-9]*,yes) { $as_echo "$as_me:${as_lineno-$LINENO}: checking which variant of shared library versioning to provide" >&5 $as_echo_n "checking which variant of shared library versioning to provide... " >&6; } # Check whether --with-aix-soname was given. if test "${with_aix_soname+set}" = set; then : withval=$with_aix_soname; case $withval in aix|svr4|both) ;; *) as_fn_error $? "Unknown argument to --with-aix-soname" "$LINENO" 5 ;; esac lt_cv_with_aix_soname=$with_aix_soname else if ${lt_cv_with_aix_soname+:} false; then : $as_echo_n "(cached) " >&6 else lt_cv_with_aix_soname=aix fi with_aix_soname=$lt_cv_with_aix_soname fi { $as_echo "$as_me:${as_lineno-$LINENO}: result: $with_aix_soname" >&5 $as_echo "$with_aix_soname" >&6; } if test aix != "$with_aix_soname"; then # For the AIX way of multilib, we name the shared archive member # based on the bitwidth used, traditionally 'shr.o' or 'shr_64.o', # and 'shr.imp' or 'shr_64.imp', respectively, for the Import File. # Even when GNU compilers ignore OBJECT_MODE but need '-maix64' flag, # the AIX toolchain works better with OBJECT_MODE set (default 32). if test 64 = "${OBJECT_MODE-32}"; then shared_archive_member_spec=shr_64 else shared_archive_member_spec=shr fi fi ;; *) with_aix_soname=aix ;; esac # This can be used to rebuild libtool when needed LIBTOOL_DEPS=$ltmain # Always use our own libtool. LIBTOOL='$(SHELL) $(top_builddir)/libtool' test -z "$LN_S" && LN_S="ln -s" if test -n "${ZSH_VERSION+set}"; then setopt NO_GLOB_SUBST fi { $as_echo "$as_me:${as_lineno-$LINENO}: checking for objdir" >&5 $as_echo_n "checking for objdir... " >&6; } if ${lt_cv_objdir+:} false; then : $as_echo_n "(cached) " >&6 else rm -f .libs 2>/dev/null mkdir .libs 2>/dev/null if test -d .libs; then lt_cv_objdir=.libs else # MS-DOS does not allow filenames that begin with a dot. lt_cv_objdir=_libs fi rmdir .libs 2>/dev/null fi { $as_echo "$as_me:${as_lineno-$LINENO}: result: $lt_cv_objdir" >&5 $as_echo "$lt_cv_objdir" >&6; } objdir=$lt_cv_objdir cat >>confdefs.h <<_ACEOF #define LT_OBJDIR "$lt_cv_objdir/" _ACEOF case $host_os in aix3*) # AIX sometimes has problems with the GCC collect2 program. For some # reason, if we set the COLLECT_NAMES environment variable, the problems # vanish in a puff of smoke. if test set != "${COLLECT_NAMES+set}"; then COLLECT_NAMES= export COLLECT_NAMES fi ;; esac # Global variables: ofile=libtool can_build_shared=yes # All known linkers require a '.a' archive for static linking (except MSVC, # which needs '.lib'). libext=a with_gnu_ld=$lt_cv_prog_gnu_ld old_CC=$CC old_CFLAGS=$CFLAGS # Set sane defaults for various variables test -z "$CC" && CC=cc test -z "$LTCC" && LTCC=$CC test -z "$LTCFLAGS" && LTCFLAGS=$CFLAGS test -z "$LD" && LD=ld test -z "$ac_objext" && ac_objext=o func_cc_basename $compiler cc_basename=$func_cc_basename_result # Only perform the check for file, if the check method requires it test -z "$MAGIC_CMD" && MAGIC_CMD=file case $deplibs_check_method in file_magic*) if test "$file_magic_cmd" = '$MAGIC_CMD'; then { $as_echo "$as_me:${as_lineno-$LINENO}: checking for ${ac_tool_prefix}file" >&5 $as_echo_n "checking for ${ac_tool_prefix}file... " >&6; } if ${lt_cv_path_MAGIC_CMD+:} false; then : $as_echo_n "(cached) " >&6 else case $MAGIC_CMD in [\\/*] | ?:[\\/]*) lt_cv_path_MAGIC_CMD=$MAGIC_CMD # Let the user override the test with a path. ;; *) lt_save_MAGIC_CMD=$MAGIC_CMD lt_save_ifs=$IFS; IFS=$PATH_SEPARATOR ac_dummy="/usr/bin$PATH_SEPARATOR$PATH" for ac_dir in $ac_dummy; do IFS=$lt_save_ifs test -z "$ac_dir" && ac_dir=. if test -f "$ac_dir/${ac_tool_prefix}file"; then lt_cv_path_MAGIC_CMD=$ac_dir/"${ac_tool_prefix}file" if test -n "$file_magic_test_file"; then case $deplibs_check_method in "file_magic "*) file_magic_regex=`expr "$deplibs_check_method" : "file_magic \(.*\)"` MAGIC_CMD=$lt_cv_path_MAGIC_CMD if eval $file_magic_cmd \$file_magic_test_file 2> /dev/null | $EGREP "$file_magic_regex" > /dev/null; then : else cat <<_LT_EOF 1>&2 *** Warning: the command libtool uses to detect shared libraries, *** $file_magic_cmd, produces output that libtool cannot recognize. *** The result is that libtool may fail to recognize shared libraries *** as such. This will affect the creation of libtool libraries that *** depend on shared libraries, but programs linked with such libtool *** libraries will work regardless of this problem. Nevertheless, you *** may want to report the problem to your system manager and/or to *** bug-libtool@gnu.org _LT_EOF fi ;; esac fi break fi done IFS=$lt_save_ifs MAGIC_CMD=$lt_save_MAGIC_CMD ;; esac fi MAGIC_CMD=$lt_cv_path_MAGIC_CMD if test -n "$MAGIC_CMD"; then { $as_echo "$as_me:${as_lineno-$LINENO}: result: $MAGIC_CMD" >&5 $as_echo "$MAGIC_CMD" >&6; } else { $as_echo "$as_me:${as_lineno-$LINENO}: result: no" >&5 $as_echo "no" >&6; } fi if test -z "$lt_cv_path_MAGIC_CMD"; then if test -n "$ac_tool_prefix"; then { $as_echo "$as_me:${as_lineno-$LINENO}: checking for file" >&5 $as_echo_n "checking for file... " >&6; } if ${lt_cv_path_MAGIC_CMD+:} false; then : $as_echo_n "(cached) " >&6 else case $MAGIC_CMD in [\\/*] | ?:[\\/]*) lt_cv_path_MAGIC_CMD=$MAGIC_CMD # Let the user override the test with a path. ;; *) lt_save_MAGIC_CMD=$MAGIC_CMD lt_save_ifs=$IFS; IFS=$PATH_SEPARATOR ac_dummy="/usr/bin$PATH_SEPARATOR$PATH" for ac_dir in $ac_dummy; do IFS=$lt_save_ifs test -z "$ac_dir" && ac_dir=. if test -f "$ac_dir/file"; then lt_cv_path_MAGIC_CMD=$ac_dir/"file" if test -n "$file_magic_test_file"; then case $deplibs_check_method in "file_magic "*) file_magic_regex=`expr "$deplibs_check_method" : "file_magic \(.*\)"` MAGIC_CMD=$lt_cv_path_MAGIC_CMD if eval $file_magic_cmd \$file_magic_test_file 2> /dev/null | $EGREP "$file_magic_regex" > /dev/null; then : else cat <<_LT_EOF 1>&2 *** Warning: the command libtool uses to detect shared libraries, *** $file_magic_cmd, produces output that libtool cannot recognize. *** The result is that libtool may fail to recognize shared libraries *** as such. This will affect the creation of libtool libraries that *** depend on shared libraries, but programs linked with such libtool *** libraries will work regardless of this problem. Nevertheless, you *** may want to report the problem to your system manager and/or to *** bug-libtool@gnu.org _LT_EOF fi ;; esac fi break fi done IFS=$lt_save_ifs MAGIC_CMD=$lt_save_MAGIC_CMD ;; esac fi MAGIC_CMD=$lt_cv_path_MAGIC_CMD if test -n "$MAGIC_CMD"; then { $as_echo "$as_me:${as_lineno-$LINENO}: result: $MAGIC_CMD" >&5 $as_echo "$MAGIC_CMD" >&6; } else { $as_echo "$as_me:${as_lineno-$LINENO}: result: no" >&5 $as_echo "no" >&6; } fi else MAGIC_CMD=: fi fi fi ;; esac # Use C for the default configuration in the libtool script lt_save_CC=$CC ac_ext=c ac_cpp='$CPP $CPPFLAGS' ac_compile='$CC -c $CFLAGS $CPPFLAGS conftest.$ac_ext >&5' ac_link='$CC -o conftest$ac_exeext $CFLAGS $CPPFLAGS $LDFLAGS conftest.$ac_ext $LIBS >&5' ac_compiler_gnu=$ac_cv_c_compiler_gnu # Source file extension for C test sources. ac_ext=c # Object file extension for compiled C test sources. objext=o objext=$objext # Code to be used in simple compile tests lt_simple_compile_test_code="int some_variable = 0;" # Code to be used in simple link tests lt_simple_link_test_code='int main(){return(0);}' # If no C compiler was specified, use CC. LTCC=${LTCC-"$CC"} # If no C compiler flags were specified, use CFLAGS. LTCFLAGS=${LTCFLAGS-"$CFLAGS"} # Allow CC to be a program name with arguments. compiler=$CC # Save the default compiler, since it gets overwritten when the other # tags are being tested, and _LT_TAGVAR(compiler, []) is a NOP. compiler_DEFAULT=$CC # save warnings/boilerplate of simple test code ac_outfile=conftest.$ac_objext echo "$lt_simple_compile_test_code" >conftest.$ac_ext eval "$ac_compile" 2>&1 >/dev/null | $SED '/^$/d; /^ *+/d' >conftest.err _lt_compiler_boilerplate=`cat conftest.err` $RM conftest* ac_outfile=conftest.$ac_objext echo "$lt_simple_link_test_code" >conftest.$ac_ext eval "$ac_link" 2>&1 >/dev/null | $SED '/^$/d; /^ *+/d' >conftest.err _lt_linker_boilerplate=`cat conftest.err` $RM -r conftest* ## CAVEAT EMPTOR: ## There is no encapsulation within the following macros, do not change ## the running order or otherwise move them around unless you know exactly ## what you are doing... if test -n "$compiler"; then lt_prog_compiler_no_builtin_flag= if test yes = "$GCC"; then case $cc_basename in nvcc*) lt_prog_compiler_no_builtin_flag=' -Xcompiler -fno-builtin' ;; *) lt_prog_compiler_no_builtin_flag=' -fno-builtin' ;; esac { $as_echo "$as_me:${as_lineno-$LINENO}: checking if $compiler supports -fno-rtti -fno-exceptions" >&5 $as_echo_n "checking if $compiler supports -fno-rtti -fno-exceptions... " >&6; } if ${lt_cv_prog_compiler_rtti_exceptions+:} false; then : $as_echo_n "(cached) " >&6 else lt_cv_prog_compiler_rtti_exceptions=no ac_outfile=conftest.$ac_objext echo "$lt_simple_compile_test_code" > conftest.$ac_ext lt_compiler_flag="-fno-rtti -fno-exceptions" ## exclude from sc_useless_quotes_in_assignment # Insert the option either (1) after the last *FLAGS variable, or # (2) before a word containing "conftest.", or (3) at the end. # Note that $ac_compile itself does not contain backslashes and begins # with a dollar sign (not a hyphen), so the echo should work correctly. # The option is referenced via a variable to avoid confusing sed. lt_compile=`echo "$ac_compile" | $SED \ -e 's:.*FLAGS}\{0,1\} :&$lt_compiler_flag :; t' \ -e 's: [^ ]*conftest\.: $lt_compiler_flag&:; t' \ -e 's:$: $lt_compiler_flag:'` (eval echo "\"\$as_me:$LINENO: $lt_compile\"" >&5) (eval "$lt_compile" 2>conftest.err) ac_status=$? cat conftest.err >&5 echo "$as_me:$LINENO: \$? = $ac_status" >&5 if (exit $ac_status) && test -s "$ac_outfile"; then # The compiler can only warn and ignore the option if not recognized # So say no if there are warnings other than the usual output. $ECHO "$_lt_compiler_boilerplate" | $SED '/^$/d' >conftest.exp $SED '/^$/d; /^ *+/d' conftest.err >conftest.er2 if test ! -s conftest.er2 || diff conftest.exp conftest.er2 >/dev/null; then lt_cv_prog_compiler_rtti_exceptions=yes fi fi $RM conftest* fi { $as_echo "$as_me:${as_lineno-$LINENO}: result: $lt_cv_prog_compiler_rtti_exceptions" >&5 $as_echo "$lt_cv_prog_compiler_rtti_exceptions" >&6; } if test yes = "$lt_cv_prog_compiler_rtti_exceptions"; then lt_prog_compiler_no_builtin_flag="$lt_prog_compiler_no_builtin_flag -fno-rtti -fno-exceptions" else : fi fi lt_prog_compiler_wl= lt_prog_compiler_pic= lt_prog_compiler_static= if test yes = "$GCC"; then lt_prog_compiler_wl='-Wl,' lt_prog_compiler_static='-static' case $host_os in aix*) # All AIX code is PIC. if test ia64 = "$host_cpu"; then # AIX 5 now supports IA64 processor lt_prog_compiler_static='-Bstatic' fi lt_prog_compiler_pic='-fPIC' ;; amigaos*) case $host_cpu in powerpc) # see comment about AmigaOS4 .so support lt_prog_compiler_pic='-fPIC' ;; m68k) # FIXME: we need at least 68020 code to build shared libraries, but # adding the '-m68020' flag to GCC prevents building anything better, # like '-m68040'. lt_prog_compiler_pic='-m68020 -resident32 -malways-restore-a4' ;; esac ;; beos* | irix5* | irix6* | nonstopux* | osf3* | osf4* | osf5*) # PIC is the default for these OSes. ;; mingw* | cygwin* | pw32* | os2* | cegcc*) # This hack is so that the source file can tell whether it is being # built for inclusion in a dll (and should export symbols for example). # Although the cygwin gcc ignores -fPIC, still need this for old-style # (--disable-auto-import) libraries lt_prog_compiler_pic='-DDLL_EXPORT' case $host_os in os2*) lt_prog_compiler_static='$wl-static' ;; esac ;; darwin* | rhapsody*) # PIC is the default on this platform # Common symbols not allowed in MH_DYLIB files lt_prog_compiler_pic='-fno-common' ;; haiku*) # PIC is the default for Haiku. # The "-static" flag exists, but is broken. lt_prog_compiler_static= ;; hpux*) # PIC is the default for 64-bit PA HP-UX, but not for 32-bit # PA HP-UX. On IA64 HP-UX, PIC is the default but the pic flag # sets the default TLS model and affects inlining. case $host_cpu in hppa*64*) # +Z the default ;; *) lt_prog_compiler_pic='-fPIC' ;; esac ;; interix[3-9]*) # Interix 3.x gcc -fpic/-fPIC options generate broken code. # Instead, we relocate shared libraries at runtime. ;; msdosdjgpp*) # Just because we use GCC doesn't mean we suddenly get shared libraries # on systems that don't support them. lt_prog_compiler_can_build_shared=no enable_shared=no ;; *nto* | *qnx*) # QNX uses GNU C++, but need to define -shared option too, otherwise # it will coredump. lt_prog_compiler_pic='-fPIC -shared' ;; sysv4*MP*) if test -d /usr/nec; then lt_prog_compiler_pic=-Kconform_pic fi ;; *) lt_prog_compiler_pic='-fPIC' ;; esac case $cc_basename in nvcc*) # Cuda Compiler Driver 2.2 lt_prog_compiler_wl='-Xlinker ' if test -n "$lt_prog_compiler_pic"; then lt_prog_compiler_pic="-Xcompiler $lt_prog_compiler_pic" fi ;; esac else # PORTME Check for flag to pass linker flags through the system compiler. case $host_os in aix*) lt_prog_compiler_wl='-Wl,' if test ia64 = "$host_cpu"; then # AIX 5 now supports IA64 processor lt_prog_compiler_static='-Bstatic' else lt_prog_compiler_static='-bnso -bI:/lib/syscalls.exp' fi ;; darwin* | rhapsody*) # PIC is the default on this platform # Common symbols not allowed in MH_DYLIB files lt_prog_compiler_pic='-fno-common' case $cc_basename in nagfor*) # NAG Fortran compiler lt_prog_compiler_wl='-Wl,-Wl,,' lt_prog_compiler_pic='-PIC' lt_prog_compiler_static='-Bstatic' ;; esac ;; mingw* | cygwin* | pw32* | os2* | cegcc*) # This hack is so that the source file can tell whether it is being # built for inclusion in a dll (and should export symbols for example). lt_prog_compiler_pic='-DDLL_EXPORT' case $host_os in os2*) lt_prog_compiler_static='$wl-static' ;; esac ;; hpux9* | hpux10* | hpux11*) lt_prog_compiler_wl='-Wl,' # PIC is the default for IA64 HP-UX and 64-bit HP-UX, but # not for PA HP-UX. case $host_cpu in hppa*64*|ia64*) # +Z the default ;; *) lt_prog_compiler_pic='+Z' ;; esac # Is there a better lt_prog_compiler_static that works with the bundled CC? lt_prog_compiler_static='$wl-a ${wl}archive' ;; irix5* | irix6* | nonstopux*) lt_prog_compiler_wl='-Wl,' # PIC (with -KPIC) is the default. lt_prog_compiler_static='-non_shared' ;; linux* | k*bsd*-gnu | kopensolaris*-gnu | gnu*) case $cc_basename in # old Intel for x86_64, which still supported -KPIC. ecc*) lt_prog_compiler_wl='-Wl,' lt_prog_compiler_pic='-KPIC' lt_prog_compiler_static='-static' ;; # icc used to be incompatible with GCC. # ICC 10 doesn't accept -KPIC any more. icc* | ifort*) lt_prog_compiler_wl='-Wl,' lt_prog_compiler_pic='-fPIC' lt_prog_compiler_static='-static' ;; # Lahey Fortran 8.1. lf95*) lt_prog_compiler_wl='-Wl,' lt_prog_compiler_pic='--shared' lt_prog_compiler_static='--static' ;; nagfor*) # NAG Fortran compiler lt_prog_compiler_wl='-Wl,-Wl,,' lt_prog_compiler_pic='-PIC' lt_prog_compiler_static='-Bstatic' ;; tcc*) # Fabrice Bellard et al's Tiny C Compiler lt_prog_compiler_wl='-Wl,' lt_prog_compiler_pic='-fPIC' lt_prog_compiler_static='-static' ;; pgcc* | pgf77* | pgf90* | pgf95* | pgfortran*) # Portland Group compilers (*not* the Pentium gcc compiler, # which looks to be a dead project) lt_prog_compiler_wl='-Wl,' lt_prog_compiler_pic='-fpic' lt_prog_compiler_static='-Bstatic' ;; ccc*) lt_prog_compiler_wl='-Wl,' # All Alpha code is PIC. lt_prog_compiler_static='-non_shared' ;; xl* | bgxl* | bgf* | mpixl*) # IBM XL C 8.0/Fortran 10.1, 11.1 on PPC and BlueGene lt_prog_compiler_wl='-Wl,' lt_prog_compiler_pic='-qpic' lt_prog_compiler_static='-qstaticlink' ;; *) case `$CC -V 2>&1 | sed 5q` in *Sun\ Ceres\ Fortran* | *Sun*Fortran*\ [1-7].* | *Sun*Fortran*\ 8.[0-3]*) # Sun Fortran 8.3 passes all unrecognized flags to the linker lt_prog_compiler_pic='-KPIC' lt_prog_compiler_static='-Bstatic' lt_prog_compiler_wl='' ;; *Sun\ F* | *Sun*Fortran*) lt_prog_compiler_pic='-KPIC' lt_prog_compiler_static='-Bstatic' lt_prog_compiler_wl='-Qoption ld ' ;; *Sun\ C*) # Sun C 5.9 lt_prog_compiler_pic='-KPIC' lt_prog_compiler_static='-Bstatic' lt_prog_compiler_wl='-Wl,' ;; *Intel*\ [CF]*Compiler*) lt_prog_compiler_wl='-Wl,' lt_prog_compiler_pic='-fPIC' lt_prog_compiler_static='-static' ;; *Portland\ Group*) lt_prog_compiler_wl='-Wl,' lt_prog_compiler_pic='-fpic' lt_prog_compiler_static='-Bstatic' ;; esac ;; esac ;; newsos6) lt_prog_compiler_pic='-KPIC' lt_prog_compiler_static='-Bstatic' ;; *nto* | *qnx*) # QNX uses GNU C++, but need to define -shared option too, otherwise # it will coredump. lt_prog_compiler_pic='-fPIC -shared' ;; osf3* | osf4* | osf5*) lt_prog_compiler_wl='-Wl,' # All OSF/1 code is PIC. lt_prog_compiler_static='-non_shared' ;; rdos*) lt_prog_compiler_static='-non_shared' ;; solaris*) lt_prog_compiler_pic='-KPIC' lt_prog_compiler_static='-Bstatic' case $cc_basename in f77* | f90* | f95* | sunf77* | sunf90* | sunf95*) lt_prog_compiler_wl='-Qoption ld ';; *) lt_prog_compiler_wl='-Wl,';; esac ;; sunos4*) lt_prog_compiler_wl='-Qoption ld ' lt_prog_compiler_pic='-PIC' lt_prog_compiler_static='-Bstatic' ;; sysv4 | sysv4.2uw2* | sysv4.3*) lt_prog_compiler_wl='-Wl,' lt_prog_compiler_pic='-KPIC' lt_prog_compiler_static='-Bstatic' ;; sysv4*MP*) if test -d /usr/nec; then lt_prog_compiler_pic='-Kconform_pic' lt_prog_compiler_static='-Bstatic' fi ;; sysv5* | unixware* | sco3.2v5* | sco5v6* | OpenUNIX*) lt_prog_compiler_wl='-Wl,' lt_prog_compiler_pic='-KPIC' lt_prog_compiler_static='-Bstatic' ;; unicos*) lt_prog_compiler_wl='-Wl,' lt_prog_compiler_can_build_shared=no ;; uts4*) lt_prog_compiler_pic='-pic' lt_prog_compiler_static='-Bstatic' ;; *) lt_prog_compiler_can_build_shared=no ;; esac fi case $host_os in # For platforms that do not support PIC, -DPIC is meaningless: *djgpp*) lt_prog_compiler_pic= ;; *) lt_prog_compiler_pic="$lt_prog_compiler_pic -DPIC" ;; esac { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $compiler option to produce PIC" >&5 $as_echo_n "checking for $compiler option to produce PIC... " >&6; } if ${lt_cv_prog_compiler_pic+:} false; then : $as_echo_n "(cached) " >&6 else lt_cv_prog_compiler_pic=$lt_prog_compiler_pic fi { $as_echo "$as_me:${as_lineno-$LINENO}: result: $lt_cv_prog_compiler_pic" >&5 $as_echo "$lt_cv_prog_compiler_pic" >&6; } lt_prog_compiler_pic=$lt_cv_prog_compiler_pic # # Check to make sure the PIC flag actually works. # if test -n "$lt_prog_compiler_pic"; then { $as_echo "$as_me:${as_lineno-$LINENO}: checking if $compiler PIC flag $lt_prog_compiler_pic works" >&5 $as_echo_n "checking if $compiler PIC flag $lt_prog_compiler_pic works... " >&6; } if ${lt_cv_prog_compiler_pic_works+:} false; then : $as_echo_n "(cached) " >&6 else lt_cv_prog_compiler_pic_works=no ac_outfile=conftest.$ac_objext echo "$lt_simple_compile_test_code" > conftest.$ac_ext lt_compiler_flag="$lt_prog_compiler_pic -DPIC" ## exclude from sc_useless_quotes_in_assignment # Insert the option either (1) after the last *FLAGS variable, or # (2) before a word containing "conftest.", or (3) at the end. # Note that $ac_compile itself does not contain backslashes and begins # with a dollar sign (not a hyphen), so the echo should work correctly. # The option is referenced via a variable to avoid confusing sed. lt_compile=`echo "$ac_compile" | $SED \ -e 's:.*FLAGS}\{0,1\} :&$lt_compiler_flag :; t' \ -e 's: [^ ]*conftest\.: $lt_compiler_flag&:; t' \ -e 's:$: $lt_compiler_flag:'` (eval echo "\"\$as_me:$LINENO: $lt_compile\"" >&5) (eval "$lt_compile" 2>conftest.err) ac_status=$? cat conftest.err >&5 echo "$as_me:$LINENO: \$? = $ac_status" >&5 if (exit $ac_status) && test -s "$ac_outfile"; then # The compiler can only warn and ignore the option if not recognized # So say no if there are warnings other than the usual output. $ECHO "$_lt_compiler_boilerplate" | $SED '/^$/d' >conftest.exp $SED '/^$/d; /^ *+/d' conftest.err >conftest.er2 if test ! -s conftest.er2 || diff conftest.exp conftest.er2 >/dev/null; then lt_cv_prog_compiler_pic_works=yes fi fi $RM conftest* fi { $as_echo "$as_me:${as_lineno-$LINENO}: result: $lt_cv_prog_compiler_pic_works" >&5 $as_echo "$lt_cv_prog_compiler_pic_works" >&6; } if test yes = "$lt_cv_prog_compiler_pic_works"; then case $lt_prog_compiler_pic in "" | " "*) ;; *) lt_prog_compiler_pic=" $lt_prog_compiler_pic" ;; esac else lt_prog_compiler_pic= lt_prog_compiler_can_build_shared=no fi fi # # Check to make sure the static flag actually works. # wl=$lt_prog_compiler_wl eval lt_tmp_static_flag=\"$lt_prog_compiler_static\" { $as_echo "$as_me:${as_lineno-$LINENO}: checking if $compiler static flag $lt_tmp_static_flag works" >&5 $as_echo_n "checking if $compiler static flag $lt_tmp_static_flag works... " >&6; } if ${lt_cv_prog_compiler_static_works+:} false; then : $as_echo_n "(cached) " >&6 else lt_cv_prog_compiler_static_works=no save_LDFLAGS=$LDFLAGS LDFLAGS="$LDFLAGS $lt_tmp_static_flag" echo "$lt_simple_link_test_code" > conftest.$ac_ext if (eval $ac_link 2>conftest.err) && test -s conftest$ac_exeext; then # The linker can only warn and ignore the option if not recognized # So say no if there are warnings if test -s conftest.err; then # Append any errors to the config.log. cat conftest.err 1>&5 $ECHO "$_lt_linker_boilerplate" | $SED '/^$/d' > conftest.exp $SED '/^$/d; /^ *+/d' conftest.err >conftest.er2 if diff conftest.exp conftest.er2 >/dev/null; then lt_cv_prog_compiler_static_works=yes fi else lt_cv_prog_compiler_static_works=yes fi fi $RM -r conftest* LDFLAGS=$save_LDFLAGS fi { $as_echo "$as_me:${as_lineno-$LINENO}: result: $lt_cv_prog_compiler_static_works" >&5 $as_echo "$lt_cv_prog_compiler_static_works" >&6; } if test yes = "$lt_cv_prog_compiler_static_works"; then : else lt_prog_compiler_static= fi { $as_echo "$as_me:${as_lineno-$LINENO}: checking if $compiler supports -c -o file.$ac_objext" >&5 $as_echo_n "checking if $compiler supports -c -o file.$ac_objext... " >&6; } if ${lt_cv_prog_compiler_c_o+:} false; then : $as_echo_n "(cached) " >&6 else lt_cv_prog_compiler_c_o=no $RM -r conftest 2>/dev/null mkdir conftest cd conftest mkdir out echo "$lt_simple_compile_test_code" > conftest.$ac_ext lt_compiler_flag="-o out/conftest2.$ac_objext" # Insert the option either (1) after the last *FLAGS variable, or # (2) before a word containing "conftest.", or (3) at the end. # Note that $ac_compile itself does not contain backslashes and begins # with a dollar sign (not a hyphen), so the echo should work correctly. lt_compile=`echo "$ac_compile" | $SED \ -e 's:.*FLAGS}\{0,1\} :&$lt_compiler_flag :; t' \ -e 's: [^ ]*conftest\.: $lt_compiler_flag&:; t' \ -e 's:$: $lt_compiler_flag:'` (eval echo "\"\$as_me:$LINENO: $lt_compile\"" >&5) (eval "$lt_compile" 2>out/conftest.err) ac_status=$? cat out/conftest.err >&5 echo "$as_me:$LINENO: \$? = $ac_status" >&5 if (exit $ac_status) && test -s out/conftest2.$ac_objext then # The compiler can only warn and ignore the option if not recognized # So say no if there are warnings $ECHO "$_lt_compiler_boilerplate" | $SED '/^$/d' > out/conftest.exp $SED '/^$/d; /^ *+/d' out/conftest.err >out/conftest.er2 if test ! -s out/conftest.er2 || diff out/conftest.exp out/conftest.er2 >/dev/null; then lt_cv_prog_compiler_c_o=yes fi fi chmod u+w . 2>&5 $RM conftest* # SGI C++ compiler will create directory out/ii_files/ for # template instantiation test -d out/ii_files && $RM out/ii_files/* && rmdir out/ii_files $RM out/* && rmdir out cd .. $RM -r conftest $RM conftest* fi { $as_echo "$as_me:${as_lineno-$LINENO}: result: $lt_cv_prog_compiler_c_o" >&5 $as_echo "$lt_cv_prog_compiler_c_o" >&6; } { $as_echo "$as_me:${as_lineno-$LINENO}: checking if $compiler supports -c -o file.$ac_objext" >&5 $as_echo_n "checking if $compiler supports -c -o file.$ac_objext... " >&6; } if ${lt_cv_prog_compiler_c_o+:} false; then : $as_echo_n "(cached) " >&6 else lt_cv_prog_compiler_c_o=no $RM -r conftest 2>/dev/null mkdir conftest cd conftest mkdir out echo "$lt_simple_compile_test_code" > conftest.$ac_ext lt_compiler_flag="-o out/conftest2.$ac_objext" # Insert the option either (1) after the last *FLAGS variable, or # (2) before a word containing "conftest.", or (3) at the end. # Note that $ac_compile itself does not contain backslashes and begins # with a dollar sign (not a hyphen), so the echo should work correctly. lt_compile=`echo "$ac_compile" | $SED \ -e 's:.*FLAGS}\{0,1\} :&$lt_compiler_flag :; t' \ -e 's: [^ ]*conftest\.: $lt_compiler_flag&:; t' \ -e 's:$: $lt_compiler_flag:'` (eval echo "\"\$as_me:$LINENO: $lt_compile\"" >&5) (eval "$lt_compile" 2>out/conftest.err) ac_status=$? cat out/conftest.err >&5 echo "$as_me:$LINENO: \$? = $ac_status" >&5 if (exit $ac_status) && test -s out/conftest2.$ac_objext then # The compiler can only warn and ignore the option if not recognized # So say no if there are warnings $ECHO "$_lt_compiler_boilerplate" | $SED '/^$/d' > out/conftest.exp $SED '/^$/d; /^ *+/d' out/conftest.err >out/conftest.er2 if test ! -s out/conftest.er2 || diff out/conftest.exp out/conftest.er2 >/dev/null; then lt_cv_prog_compiler_c_o=yes fi fi chmod u+w . 2>&5 $RM conftest* # SGI C++ compiler will create directory out/ii_files/ for # template instantiation test -d out/ii_files && $RM out/ii_files/* && rmdir out/ii_files $RM out/* && rmdir out cd .. $RM -r conftest $RM conftest* fi { $as_echo "$as_me:${as_lineno-$LINENO}: result: $lt_cv_prog_compiler_c_o" >&5 $as_echo "$lt_cv_prog_compiler_c_o" >&6; } hard_links=nottested if test no = "$lt_cv_prog_compiler_c_o" && test no != "$need_locks"; then # do not overwrite the value of need_locks provided by the user { $as_echo "$as_me:${as_lineno-$LINENO}: checking if we can lock with hard links" >&5 $as_echo_n "checking if we can lock with hard links... " >&6; } hard_links=yes $RM conftest* ln conftest.a conftest.b 2>/dev/null && hard_links=no touch conftest.a ln conftest.a conftest.b 2>&5 || hard_links=no ln conftest.a conftest.b 2>/dev/null && hard_links=no { $as_echo "$as_me:${as_lineno-$LINENO}: result: $hard_links" >&5 $as_echo "$hard_links" >&6; } if test no = "$hard_links"; then { $as_echo "$as_me:${as_lineno-$LINENO}: WARNING: '$CC' does not support '-c -o', so 'make -j' may be unsafe" >&5 $as_echo "$as_me: WARNING: '$CC' does not support '-c -o', so 'make -j' may be unsafe" >&2;} need_locks=warn fi else need_locks=no fi { $as_echo "$as_me:${as_lineno-$LINENO}: checking whether the $compiler linker ($LD) supports shared libraries" >&5 $as_echo_n "checking whether the $compiler linker ($LD) supports shared libraries... " >&6; } runpath_var= allow_undefined_flag= always_export_symbols=no archive_cmds= archive_expsym_cmds= compiler_needs_object=no enable_shared_with_static_runtimes=no export_dynamic_flag_spec= export_symbols_cmds='$NM $libobjs $convenience | $global_symbol_pipe | $SED '\''s/.* //'\'' | sort | uniq > $export_symbols' hardcode_automatic=no hardcode_direct=no hardcode_direct_absolute=no hardcode_libdir_flag_spec= hardcode_libdir_separator= hardcode_minus_L=no hardcode_shlibpath_var=unsupported inherit_rpath=no link_all_deplibs=unknown module_cmds= module_expsym_cmds= old_archive_from_new_cmds= old_archive_from_expsyms_cmds= thread_safe_flag_spec= whole_archive_flag_spec= # include_expsyms should be a list of space-separated symbols to be *always* # included in the symbol list include_expsyms= # exclude_expsyms can be an extended regexp of symbols to exclude # it will be wrapped by ' (' and ')$', so one must not match beginning or # end of line. Example: 'a|bc|.*d.*' will exclude the symbols 'a' and 'bc', # as well as any symbol that contains 'd'. exclude_expsyms='_GLOBAL_OFFSET_TABLE_|_GLOBAL__F[ID]_.*' # Although _GLOBAL_OFFSET_TABLE_ is a valid symbol C name, most a.out # platforms (ab)use it in PIC code, but their linkers get confused if # the symbol is explicitly referenced. Since portable code cannot # rely on this symbol name, it's probably fine to never include it in # preloaded symbol tables. # Exclude shared library initialization/finalization symbols. extract_expsyms_cmds= case $host_os in cygwin* | mingw* | pw32* | cegcc*) # FIXME: the MSVC++ port hasn't been tested in a loooong time # When not using gcc, we currently assume that we are using # Microsoft Visual C++. if test yes != "$GCC"; then with_gnu_ld=no fi ;; interix*) # we just hope/assume this is gcc and not c89 (= MSVC++) with_gnu_ld=yes ;; openbsd* | bitrig*) with_gnu_ld=no ;; esac ld_shlibs=yes # On some targets, GNU ld is compatible enough with the native linker # that we're better off using the native interface for both. lt_use_gnu_ld_interface=no if test yes = "$with_gnu_ld"; then case $host_os in aix*) # The AIX port of GNU ld has always aspired to compatibility # with the native linker. However, as the warning in the GNU ld # block says, versions before 2.19.5* couldn't really create working # shared libraries, regardless of the interface used. case `$LD -v 2>&1` in *\ \(GNU\ Binutils\)\ 2.19.5*) ;; *\ \(GNU\ Binutils\)\ 2.[2-9]*) ;; *\ \(GNU\ Binutils\)\ [3-9]*) ;; *) lt_use_gnu_ld_interface=yes ;; esac ;; *) lt_use_gnu_ld_interface=yes ;; esac fi if test yes = "$lt_use_gnu_ld_interface"; then # If archive_cmds runs LD, not CC, wlarc should be empty wlarc='$wl' # Set some defaults for GNU ld with shared library support. These # are reset later if shared libraries are not supported. Putting them # here allows them to be overridden if necessary. runpath_var=LD_RUN_PATH hardcode_libdir_flag_spec='$wl-rpath $wl$libdir' export_dynamic_flag_spec='$wl--export-dynamic' # ancient GNU ld didn't support --whole-archive et. al. if $LD --help 2>&1 | $GREP 'no-whole-archive' > /dev/null; then whole_archive_flag_spec=$wlarc'--whole-archive$convenience '$wlarc'--no-whole-archive' else whole_archive_flag_spec= fi supports_anon_versioning=no case `$LD -v | $SED -e 's/(^)\+)\s\+//' 2>&1` in *GNU\ gold*) supports_anon_versioning=yes ;; *\ [01].* | *\ 2.[0-9].* | *\ 2.10.*) ;; # catch versions < 2.11 *\ 2.11.93.0.2\ *) supports_anon_versioning=yes ;; # RH7.3 ... *\ 2.11.92.0.12\ *) supports_anon_versioning=yes ;; # Mandrake 8.2 ... *\ 2.11.*) ;; # other 2.11 versions *) supports_anon_versioning=yes ;; esac # See if GNU ld supports shared libraries. case $host_os in aix[3-9]*) # On AIX/PPC, the GNU linker is very broken if test ia64 != "$host_cpu"; then ld_shlibs=no cat <<_LT_EOF 1>&2 *** Warning: the GNU linker, at least up to release 2.19, is reported *** to be unable to reliably create shared libraries on AIX. *** Therefore, libtool is disabling shared libraries support. If you *** really care for shared libraries, you may want to install binutils *** 2.20 or above, or modify your PATH so that a non-GNU linker is found. *** You will then need to restart the configuration process. _LT_EOF fi ;; amigaos*) case $host_cpu in powerpc) # see comment about AmigaOS4 .so support archive_cmds='$CC -shared $libobjs $deplibs $compiler_flags $wl-soname $wl$soname -o $lib' archive_expsym_cmds='' ;; m68k) archive_cmds='$RM $output_objdir/a2ixlibrary.data~$ECHO "#define NAME $libname" > $output_objdir/a2ixlibrary.data~$ECHO "#define LIBRARY_ID 1" >> $output_objdir/a2ixlibrary.data~$ECHO "#define VERSION $major" >> $output_objdir/a2ixlibrary.data~$ECHO "#define REVISION $revision" >> $output_objdir/a2ixlibrary.data~$AR $AR_FLAGS $lib $libobjs~$RANLIB $lib~(cd $output_objdir && a2ixlibrary -32)' hardcode_libdir_flag_spec='-L$libdir' hardcode_minus_L=yes ;; esac ;; beos*) if $LD --help 2>&1 | $GREP ': supported targets:.* elf' > /dev/null; then allow_undefined_flag=unsupported # Joseph Beckenbach says some releases of gcc # support --undefined. This deserves some investigation. FIXME archive_cmds='$CC -nostart $libobjs $deplibs $compiler_flags $wl-soname $wl$soname -o $lib' else ld_shlibs=no fi ;; cygwin* | mingw* | pw32* | cegcc*) # _LT_TAGVAR(hardcode_libdir_flag_spec, ) is actually meaningless, # as there is no search path for DLLs. hardcode_libdir_flag_spec='-L$libdir' export_dynamic_flag_spec='$wl--export-all-symbols' allow_undefined_flag=unsupported always_export_symbols=no enable_shared_with_static_runtimes=yes export_symbols_cmds='$NM $libobjs $convenience | $global_symbol_pipe | $SED -e '\''/^[BCDGRS][ ]/s/.*[ ]\([^ ]*\)/\1 DATA/;s/^.*[ ]__nm__\([^ ]*\)[ ][^ ]*/\1 DATA/;/^I[ ]/d;/^[AITW][ ]/s/.* //'\'' | sort | uniq > $export_symbols' exclude_expsyms='[_]+GLOBAL_OFFSET_TABLE_|[_]+GLOBAL__[FID]_.*|[_]+head_[A-Za-z0-9_]+_dll|[A-Za-z0-9_]+_dll_iname' if $LD --help 2>&1 | $GREP 'auto-import' > /dev/null; then archive_cmds='$CC -shared $libobjs $deplibs $compiler_flags -o $output_objdir/$soname $wl--enable-auto-image-base -Xlinker --out-implib -Xlinker $lib' # If the export-symbols file already is a .def file, use it as # is; otherwise, prepend EXPORTS... archive_expsym_cmds='if test DEF = "`$SED -n -e '\''s/^[ ]*//'\'' -e '\''/^\(;.*\)*$/d'\'' -e '\''s/^\(EXPORTS\|LIBRARY\)\([ ].*\)*$/DEF/p'\'' -e q $export_symbols`" ; then cp $export_symbols $output_objdir/$soname.def; else echo EXPORTS > $output_objdir/$soname.def; cat $export_symbols >> $output_objdir/$soname.def; fi~ $CC -shared $output_objdir/$soname.def $libobjs $deplibs $compiler_flags -o $output_objdir/$soname $wl--enable-auto-image-base -Xlinker --out-implib -Xlinker $lib' else ld_shlibs=no fi ;; haiku*) archive_cmds='$CC -shared $libobjs $deplibs $compiler_flags $wl-soname $wl$soname -o $lib' link_all_deplibs=yes ;; os2*) hardcode_libdir_flag_spec='-L$libdir' hardcode_minus_L=yes allow_undefined_flag=unsupported shrext_cmds=.dll archive_cmds='$ECHO "LIBRARY ${soname%$shared_ext} INITINSTANCE TERMINSTANCE" > $output_objdir/$libname.def~ $ECHO "DESCRIPTION \"$libname\"" >> $output_objdir/$libname.def~ $ECHO "DATA MULTIPLE NONSHARED" >> $output_objdir/$libname.def~ $ECHO EXPORTS >> $output_objdir/$libname.def~ emxexp $libobjs | $SED /"_DLL_InitTerm"/d >> $output_objdir/$libname.def~ $CC -Zdll -Zcrtdll -o $output_objdir/$soname $libobjs $deplibs $compiler_flags $output_objdir/$libname.def~ emximp -o $lib $output_objdir/$libname.def' archive_expsym_cmds='$ECHO "LIBRARY ${soname%$shared_ext} INITINSTANCE TERMINSTANCE" > $output_objdir/$libname.def~ $ECHO "DESCRIPTION \"$libname\"" >> $output_objdir/$libname.def~ $ECHO "DATA MULTIPLE NONSHARED" >> $output_objdir/$libname.def~ $ECHO EXPORTS >> $output_objdir/$libname.def~ prefix_cmds="$SED"~ if test EXPORTS = "`$SED 1q $export_symbols`"; then prefix_cmds="$prefix_cmds -e 1d"; fi~ prefix_cmds="$prefix_cmds -e \"s/^\(.*\)$/_\1/g\""~ cat $export_symbols | $prefix_cmds >> $output_objdir/$libname.def~ $CC -Zdll -Zcrtdll -o $output_objdir/$soname $libobjs $deplibs $compiler_flags $output_objdir/$libname.def~ emximp -o $lib $output_objdir/$libname.def' old_archive_From_new_cmds='emximp -o $output_objdir/${libname}_dll.a $output_objdir/$libname.def' enable_shared_with_static_runtimes=yes ;; interix[3-9]*) hardcode_direct=no hardcode_shlibpath_var=no hardcode_libdir_flag_spec='$wl-rpath,$libdir' export_dynamic_flag_spec='$wl-E' # Hack: On Interix 3.x, we cannot compile PIC because of a broken gcc. # Instead, shared libraries are loaded at an image base (0x10000000 by # default) and relocated if they conflict, which is a slow very memory # consuming and fragmenting process. To avoid this, we pick a random, # 256 KiB-aligned image base between 0x50000000 and 0x6FFC0000 at link # time. Moving up from 0x10000000 also allows more sbrk(2) space. archive_cmds='$CC -shared $pic_flag $libobjs $deplibs $compiler_flags $wl-h,$soname $wl--image-base,`expr ${RANDOM-$$} % 4096 / 2 \* 262144 + 1342177280` -o $lib' archive_expsym_cmds='sed "s|^|_|" $export_symbols >$output_objdir/$soname.expsym~$CC -shared $pic_flag $libobjs $deplibs $compiler_flags $wl-h,$soname $wl--retain-symbols-file,$output_objdir/$soname.expsym $wl--image-base,`expr ${RANDOM-$$} % 4096 / 2 \* 262144 + 1342177280` -o $lib' ;; gnu* | linux* | tpf* | k*bsd*-gnu | kopensolaris*-gnu) tmp_diet=no if test linux-dietlibc = "$host_os"; then case $cc_basename in diet\ *) tmp_diet=yes;; # linux-dietlibc with static linking (!diet-dyn) esac fi if $LD --help 2>&1 | $EGREP ': supported targets:.* elf' > /dev/null \ && test no = "$tmp_diet" then tmp_addflag=' $pic_flag' tmp_sharedflag='-shared' case $cc_basename,$host_cpu in pgcc*) # Portland Group C compiler whole_archive_flag_spec='$wl--whole-archive`for conv in $convenience\"\"; do test -n \"$conv\" && new_convenience=\"$new_convenience,$conv\"; done; func_echo_all \"$new_convenience\"` $wl--no-whole-archive' tmp_addflag=' $pic_flag' ;; pgf77* | pgf90* | pgf95* | pgfortran*) # Portland Group f77 and f90 compilers whole_archive_flag_spec='$wl--whole-archive`for conv in $convenience\"\"; do test -n \"$conv\" && new_convenience=\"$new_convenience,$conv\"; done; func_echo_all \"$new_convenience\"` $wl--no-whole-archive' tmp_addflag=' $pic_flag -Mnomain' ;; ecc*,ia64* | icc*,ia64*) # Intel C compiler on ia64 tmp_addflag=' -i_dynamic' ;; efc*,ia64* | ifort*,ia64*) # Intel Fortran compiler on ia64 tmp_addflag=' -i_dynamic -nofor_main' ;; ifc* | ifort*) # Intel Fortran compiler tmp_addflag=' -nofor_main' ;; lf95*) # Lahey Fortran 8.1 whole_archive_flag_spec= tmp_sharedflag='--shared' ;; nagfor*) # NAGFOR 5.3 tmp_sharedflag='-Wl,-shared' ;; xl[cC]* | bgxl[cC]* | mpixl[cC]*) # IBM XL C 8.0 on PPC (deal with xlf below) tmp_sharedflag='-qmkshrobj' tmp_addflag= ;; nvcc*) # Cuda Compiler Driver 2.2 whole_archive_flag_spec='$wl--whole-archive`for conv in $convenience\"\"; do test -n \"$conv\" && new_convenience=\"$new_convenience,$conv\"; done; func_echo_all \"$new_convenience\"` $wl--no-whole-archive' compiler_needs_object=yes ;; esac case `$CC -V 2>&1 | sed 5q` in *Sun\ C*) # Sun C 5.9 whole_archive_flag_spec='$wl--whole-archive`new_convenience=; for conv in $convenience\"\"; do test -z \"$conv\" || new_convenience=\"$new_convenience,$conv\"; done; func_echo_all \"$new_convenience\"` $wl--no-whole-archive' compiler_needs_object=yes tmp_sharedflag='-G' ;; *Sun\ F*) # Sun Fortran 8.3 tmp_sharedflag='-G' ;; esac archive_cmds='$CC '"$tmp_sharedflag""$tmp_addflag"' $libobjs $deplibs $compiler_flags $wl-soname $wl$soname -o $lib' if test yes = "$supports_anon_versioning"; then archive_expsym_cmds='echo "{ global:" > $output_objdir/$libname.ver~ cat $export_symbols | sed -e "s/\(.*\)/\1;/" >> $output_objdir/$libname.ver~ echo "local: *; };" >> $output_objdir/$libname.ver~ $CC '"$tmp_sharedflag""$tmp_addflag"' $libobjs $deplibs $compiler_flags $wl-soname $wl$soname $wl-version-script $wl$output_objdir/$libname.ver -o $lib' fi case $cc_basename in tcc*) export_dynamic_flag_spec='-rdynamic' ;; xlf* | bgf* | bgxlf* | mpixlf*) # IBM XL Fortran 10.1 on PPC cannot create shared libs itself whole_archive_flag_spec='--whole-archive$convenience --no-whole-archive' hardcode_libdir_flag_spec='$wl-rpath $wl$libdir' archive_cmds='$LD -shared $libobjs $deplibs $linker_flags -soname $soname -o $lib' if test yes = "$supports_anon_versioning"; then archive_expsym_cmds='echo "{ global:" > $output_objdir/$libname.ver~ cat $export_symbols | sed -e "s/\(.*\)/\1;/" >> $output_objdir/$libname.ver~ echo "local: *; };" >> $output_objdir/$libname.ver~ $LD -shared $libobjs $deplibs $linker_flags -soname $soname -version-script $output_objdir/$libname.ver -o $lib' fi ;; esac else ld_shlibs=no fi ;; netbsd*) if echo __ELF__ | $CC -E - | $GREP __ELF__ >/dev/null; then archive_cmds='$LD -Bshareable $libobjs $deplibs $linker_flags -o $lib' wlarc= else archive_cmds='$CC -shared $pic_flag $libobjs $deplibs $compiler_flags $wl-soname $wl$soname -o $lib' archive_expsym_cmds='$CC -shared $pic_flag $libobjs $deplibs $compiler_flags $wl-soname $wl$soname $wl-retain-symbols-file $wl$export_symbols -o $lib' fi ;; solaris*) if $LD -v 2>&1 | $GREP 'BFD 2\.8' > /dev/null; then ld_shlibs=no cat <<_LT_EOF 1>&2 *** Warning: The releases 2.8.* of the GNU linker cannot reliably *** create shared libraries on Solaris systems. Therefore, libtool *** is disabling shared libraries support. We urge you to upgrade GNU *** binutils to release 2.9.1 or newer. Another option is to modify *** your PATH or compiler configuration so that the native linker is *** used, and then restart. _LT_EOF elif $LD --help 2>&1 | $GREP ': supported targets:.* elf' > /dev/null; then archive_cmds='$CC -shared $pic_flag $libobjs $deplibs $compiler_flags $wl-soname $wl$soname -o $lib' archive_expsym_cmds='$CC -shared $pic_flag $libobjs $deplibs $compiler_flags $wl-soname $wl$soname $wl-retain-symbols-file $wl$export_symbols -o $lib' else ld_shlibs=no fi ;; sysv5* | sco3.2v5* | sco5v6* | unixware* | OpenUNIX*) case `$LD -v 2>&1` in *\ [01].* | *\ 2.[0-9].* | *\ 2.1[0-5].*) ld_shlibs=no cat <<_LT_EOF 1>&2 *** Warning: Releases of the GNU linker prior to 2.16.91.0.3 cannot *** reliably create shared libraries on SCO systems. Therefore, libtool *** is disabling shared libraries support. We urge you to upgrade GNU *** binutils to release 2.16.91.0.3 or newer. Another option is to modify *** your PATH or compiler configuration so that the native linker is *** used, and then restart. _LT_EOF ;; *) # For security reasons, it is highly recommended that you always # use absolute paths for naming shared libraries, and exclude the # DT_RUNPATH tag from executables and libraries. But doing so # requires that you compile everything twice, which is a pain. if $LD --help 2>&1 | $GREP ': supported targets:.* elf' > /dev/null; then hardcode_libdir_flag_spec='$wl-rpath $wl$libdir' archive_cmds='$CC -shared $libobjs $deplibs $compiler_flags $wl-soname $wl$soname -o $lib' archive_expsym_cmds='$CC -shared $libobjs $deplibs $compiler_flags $wl-soname $wl$soname $wl-retain-symbols-file $wl$export_symbols -o $lib' else ld_shlibs=no fi ;; esac ;; sunos4*) archive_cmds='$LD -assert pure-text -Bshareable -o $lib $libobjs $deplibs $linker_flags' wlarc= hardcode_direct=yes hardcode_shlibpath_var=no ;; *) if $LD --help 2>&1 | $GREP ': supported targets:.* elf' > /dev/null; then archive_cmds='$CC -shared $pic_flag $libobjs $deplibs $compiler_flags $wl-soname $wl$soname -o $lib' archive_expsym_cmds='$CC -shared $pic_flag $libobjs $deplibs $compiler_flags $wl-soname $wl$soname $wl-retain-symbols-file $wl$export_symbols -o $lib' else ld_shlibs=no fi ;; esac if test no = "$ld_shlibs"; then runpath_var= hardcode_libdir_flag_spec= export_dynamic_flag_spec= whole_archive_flag_spec= fi else # PORTME fill in a description of your system's linker (not GNU ld) case $host_os in aix3*) allow_undefined_flag=unsupported always_export_symbols=yes archive_expsym_cmds='$LD -o $output_objdir/$soname $libobjs $deplibs $linker_flags -bE:$export_symbols -T512 -H512 -bM:SRE~$AR $AR_FLAGS $lib $output_objdir/$soname' # Note: this linker hardcodes the directories in LIBPATH if there # are no directories specified by -L. hardcode_minus_L=yes if test yes = "$GCC" && test -z "$lt_prog_compiler_static"; then # Neither direct hardcoding nor static linking is supported with a # broken collect2. hardcode_direct=unsupported fi ;; aix[4-9]*) if test ia64 = "$host_cpu"; then # On IA64, the linker does run time linking by default, so we don't # have to do anything special. aix_use_runtimelinking=no exp_sym_flag='-Bexport' no_entry_flag= else # If we're using GNU nm, then we don't want the "-C" option. # -C means demangle to GNU nm, but means don't demangle to AIX nm. # Without the "-l" option, or with the "-B" option, AIX nm treats # weak defined symbols like other global defined symbols, whereas # GNU nm marks them as "W". # While the 'weak' keyword is ignored in the Export File, we need # it in the Import File for the 'aix-soname' feature, so we have # to replace the "-B" option with "-P" for AIX nm. if $NM -V 2>&1 | $GREP 'GNU' > /dev/null; then export_symbols_cmds='$NM -Bpg $libobjs $convenience | awk '\''{ if (((\$ 2 == "T") || (\$ 2 == "D") || (\$ 2 == "B") || (\$ 2 == "W")) && (substr(\$ 3,1,1) != ".")) { if (\$ 2 == "W") { print \$ 3 " weak" } else { print \$ 3 } } }'\'' | sort -u > $export_symbols' else export_symbols_cmds='`func_echo_all $NM | $SED -e '\''s/B\([^B]*\)$/P\1/'\''` -PCpgl $libobjs $convenience | awk '\''{ if (((\$ 2 == "T") || (\$ 2 == "D") || (\$ 2 == "B") || (\$ 2 == "W") || (\$ 2 == "V") || (\$ 2 == "Z")) && (substr(\$ 1,1,1) != ".")) { if ((\$ 2 == "W") || (\$ 2 == "V") || (\$ 2 == "Z")) { print \$ 1 " weak" } else { print \$ 1 } } }'\'' | sort -u > $export_symbols' fi aix_use_runtimelinking=no # Test if we are trying to use run time linking or normal # AIX style linking. If -brtl is somewhere in LDFLAGS, we # have runtime linking enabled, and use it for executables. # For shared libraries, we enable/disable runtime linking # depending on the kind of the shared library created - # when "with_aix_soname,aix_use_runtimelinking" is: # "aix,no" lib.a(lib.so.V) shared, rtl:no, for executables # "aix,yes" lib.so shared, rtl:yes, for executables # lib.a static archive # "both,no" lib.so.V(shr.o) shared, rtl:yes # lib.a(lib.so.V) shared, rtl:no, for executables # "both,yes" lib.so.V(shr.o) shared, rtl:yes, for executables # lib.a(lib.so.V) shared, rtl:no # "svr4,*" lib.so.V(shr.o) shared, rtl:yes, for executables # lib.a static archive case $host_os in aix4.[23]|aix4.[23].*|aix[5-9]*) for ld_flag in $LDFLAGS; do if (test x-brtl = "x$ld_flag" || test x-Wl,-brtl = "x$ld_flag"); then aix_use_runtimelinking=yes break fi done if test svr4,no = "$with_aix_soname,$aix_use_runtimelinking"; then # With aix-soname=svr4, we create the lib.so.V shared archives only, # so we don't have lib.a shared libs to link our executables. # We have to force runtime linking in this case. aix_use_runtimelinking=yes LDFLAGS="$LDFLAGS -Wl,-brtl" fi ;; esac exp_sym_flag='-bexport' no_entry_flag='-bnoentry' fi # When large executables or shared objects are built, AIX ld can # have problems creating the table of contents. If linking a library # or program results in "error TOC overflow" add -mminimal-toc to # CXXFLAGS/CFLAGS for g++/gcc. In the cases where that is not # enough to fix the problem, add -Wl,-bbigtoc to LDFLAGS. archive_cmds='' hardcode_direct=yes hardcode_direct_absolute=yes hardcode_libdir_separator=':' link_all_deplibs=yes file_list_spec='$wl-f,' case $with_aix_soname,$aix_use_runtimelinking in aix,*) ;; # traditional, no import file svr4,* | *,yes) # use import file # The Import File defines what to hardcode. hardcode_direct=no hardcode_direct_absolute=no ;; esac if test yes = "$GCC"; then case $host_os in aix4.[012]|aix4.[012].*) # We only want to do this on AIX 4.2 and lower, the check # below for broken collect2 doesn't work under 4.3+ collect2name=`$CC -print-prog-name=collect2` if test -f "$collect2name" && strings "$collect2name" | $GREP resolve_lib_name >/dev/null then # We have reworked collect2 : else # We have old collect2 hardcode_direct=unsupported # It fails to find uninstalled libraries when the uninstalled # path is not listed in the libpath. Setting hardcode_minus_L # to unsupported forces relinking hardcode_minus_L=yes hardcode_libdir_flag_spec='-L$libdir' hardcode_libdir_separator= fi ;; esac shared_flag='-shared' if test yes = "$aix_use_runtimelinking"; then shared_flag="$shared_flag "'$wl-G' fi # Need to ensure runtime linking is disabled for the traditional # shared library, or the linker may eventually find shared libraries # /with/ Import File - we do not want to mix them. shared_flag_aix='-shared' shared_flag_svr4='-shared $wl-G' else # not using gcc if test ia64 = "$host_cpu"; then # VisualAge C++, Version 5.5 for AIX 5L for IA-64, Beta 3 Release # chokes on -Wl,-G. The following line is correct: shared_flag='-G' else if test yes = "$aix_use_runtimelinking"; then shared_flag='$wl-G' else shared_flag='$wl-bM:SRE' fi shared_flag_aix='$wl-bM:SRE' shared_flag_svr4='$wl-G' fi fi export_dynamic_flag_spec='$wl-bexpall' # It seems that -bexpall does not export symbols beginning with # underscore (_), so it is better to generate a list of symbols to export. always_export_symbols=yes if test aix,yes = "$with_aix_soname,$aix_use_runtimelinking"; then # Warning - without using the other runtime loading flags (-brtl), # -berok will link without error, but may produce a broken library. allow_undefined_flag='-berok' # Determine the default libpath from the value encoded in an # empty executable. if test set = "${lt_cv_aix_libpath+set}"; then aix_libpath=$lt_cv_aix_libpath else if ${lt_cv_aix_libpath_+:} false; then : $as_echo_n "(cached) " >&6 else cat confdefs.h - <<_ACEOF >conftest.$ac_ext /* end confdefs.h. */ int main () { ; return 0; } _ACEOF if ac_fn_c_try_link "$LINENO"; then : lt_aix_libpath_sed=' /Import File Strings/,/^$/ { /^0/ { s/^0 *\([^ ]*\) *$/\1/ p } }' lt_cv_aix_libpath_=`dump -H conftest$ac_exeext 2>/dev/null | $SED -n -e "$lt_aix_libpath_sed"` # Check for a 64-bit object if we didn't find anything. if test -z "$lt_cv_aix_libpath_"; then lt_cv_aix_libpath_=`dump -HX64 conftest$ac_exeext 2>/dev/null | $SED -n -e "$lt_aix_libpath_sed"` fi fi rm -f core conftest.err conftest.$ac_objext \ conftest$ac_exeext conftest.$ac_ext if test -z "$lt_cv_aix_libpath_"; then lt_cv_aix_libpath_=/usr/lib:/lib fi fi aix_libpath=$lt_cv_aix_libpath_ fi hardcode_libdir_flag_spec='$wl-blibpath:$libdir:'"$aix_libpath" archive_expsym_cmds='$CC -o $output_objdir/$soname $libobjs $deplibs $wl'$no_entry_flag' $compiler_flags `if test -n "$allow_undefined_flag"; then func_echo_all "$wl$allow_undefined_flag"; else :; fi` $wl'$exp_sym_flag:\$export_symbols' '$shared_flag else if test ia64 = "$host_cpu"; then hardcode_libdir_flag_spec='$wl-R $libdir:/usr/lib:/lib' allow_undefined_flag="-z nodefs" archive_expsym_cmds="\$CC $shared_flag"' -o $output_objdir/$soname $libobjs $deplibs '"\$wl$no_entry_flag"' $compiler_flags $wl$allow_undefined_flag '"\$wl$exp_sym_flag:\$export_symbols" else # Determine the default libpath from the value encoded in an # empty executable. if test set = "${lt_cv_aix_libpath+set}"; then aix_libpath=$lt_cv_aix_libpath else if ${lt_cv_aix_libpath_+:} false; then : $as_echo_n "(cached) " >&6 else cat confdefs.h - <<_ACEOF >conftest.$ac_ext /* end confdefs.h. */ int main () { ; return 0; } _ACEOF if ac_fn_c_try_link "$LINENO"; then : lt_aix_libpath_sed=' /Import File Strings/,/^$/ { /^0/ { s/^0 *\([^ ]*\) *$/\1/ p } }' lt_cv_aix_libpath_=`dump -H conftest$ac_exeext 2>/dev/null | $SED -n -e "$lt_aix_libpath_sed"` # Check for a 64-bit object if we didn't find anything. if test -z "$lt_cv_aix_libpath_"; then lt_cv_aix_libpath_=`dump -HX64 conftest$ac_exeext 2>/dev/null | $SED -n -e "$lt_aix_libpath_sed"` fi fi rm -f core conftest.err conftest.$ac_objext \ conftest$ac_exeext conftest.$ac_ext if test -z "$lt_cv_aix_libpath_"; then lt_cv_aix_libpath_=/usr/lib:/lib fi fi aix_libpath=$lt_cv_aix_libpath_ fi hardcode_libdir_flag_spec='$wl-blibpath:$libdir:'"$aix_libpath" # Warning - without using the other run time loading flags, # -berok will link without error, but may produce a broken library. no_undefined_flag=' $wl-bernotok' allow_undefined_flag=' $wl-berok' if test yes = "$with_gnu_ld"; then # We only use this code for GNU lds that support --whole-archive. whole_archive_flag_spec='$wl--whole-archive$convenience $wl--no-whole-archive' else # Exported symbols can be pulled into shared objects from archives whole_archive_flag_spec='$convenience' fi archive_cmds_need_lc=yes archive_expsym_cmds='$RM -r $output_objdir/$realname.d~$MKDIR $output_objdir/$realname.d' # -brtl affects multiple linker settings, -berok does not and is overridden later compiler_flags_filtered='`func_echo_all "$compiler_flags " | $SED -e "s%-brtl\\([, ]\\)%-berok\\1%g"`' if test svr4 != "$with_aix_soname"; then # This is similar to how AIX traditionally builds its shared libraries. archive_expsym_cmds="$archive_expsym_cmds"'~$CC '$shared_flag_aix' -o $output_objdir/$realname.d/$soname $libobjs $deplibs $wl-bnoentry '$compiler_flags_filtered'$wl-bE:$export_symbols$allow_undefined_flag~$AR $AR_FLAGS $output_objdir/$libname$release.a $output_objdir/$realname.d/$soname' fi if test aix != "$with_aix_soname"; then archive_expsym_cmds="$archive_expsym_cmds"'~$CC '$shared_flag_svr4' -o $output_objdir/$realname.d/$shared_archive_member_spec.o $libobjs $deplibs $wl-bnoentry '$compiler_flags_filtered'$wl-bE:$export_symbols$allow_undefined_flag~$STRIP -e $output_objdir/$realname.d/$shared_archive_member_spec.o~( func_echo_all "#! $soname($shared_archive_member_spec.o)"; if test shr_64 = "$shared_archive_member_spec"; then func_echo_all "# 64"; else func_echo_all "# 32"; fi; cat $export_symbols ) > $output_objdir/$realname.d/$shared_archive_member_spec.imp~$AR $AR_FLAGS $output_objdir/$soname $output_objdir/$realname.d/$shared_archive_member_spec.o $output_objdir/$realname.d/$shared_archive_member_spec.imp' else # used by -dlpreopen to get the symbols archive_expsym_cmds="$archive_expsym_cmds"'~$MV $output_objdir/$realname.d/$soname $output_objdir' fi archive_expsym_cmds="$archive_expsym_cmds"'~$RM -r $output_objdir/$realname.d' fi fi ;; amigaos*) case $host_cpu in powerpc) # see comment about AmigaOS4 .so support archive_cmds='$CC -shared $libobjs $deplibs $compiler_flags $wl-soname $wl$soname -o $lib' archive_expsym_cmds='' ;; m68k) archive_cmds='$RM $output_objdir/a2ixlibrary.data~$ECHO "#define NAME $libname" > $output_objdir/a2ixlibrary.data~$ECHO "#define LIBRARY_ID 1" >> $output_objdir/a2ixlibrary.data~$ECHO "#define VERSION $major" >> $output_objdir/a2ixlibrary.data~$ECHO "#define REVISION $revision" >> $output_objdir/a2ixlibrary.data~$AR $AR_FLAGS $lib $libobjs~$RANLIB $lib~(cd $output_objdir && a2ixlibrary -32)' hardcode_libdir_flag_spec='-L$libdir' hardcode_minus_L=yes ;; esac ;; bsdi[45]*) export_dynamic_flag_spec=-rdynamic ;; cygwin* | mingw* | pw32* | cegcc*) # When not using gcc, we currently assume that we are using # Microsoft Visual C++. # hardcode_libdir_flag_spec is actually meaningless, as there is # no search path for DLLs. case $cc_basename in cl*) # Native MSVC hardcode_libdir_flag_spec=' ' allow_undefined_flag=unsupported always_export_symbols=yes file_list_spec='@' # Tell ltmain to make .lib files, not .a files. libext=lib # Tell ltmain to make .dll files, not .so files. shrext_cmds=.dll # FIXME: Setting linknames here is a bad hack. archive_cmds='$CC -o $output_objdir/$soname $libobjs $compiler_flags $deplibs -Wl,-DLL,-IMPLIB:"$tool_output_objdir$libname.dll.lib"~linknames=' archive_expsym_cmds='if test DEF = "`$SED -n -e '\''s/^[ ]*//'\'' -e '\''/^\(;.*\)*$/d'\'' -e '\''s/^\(EXPORTS\|LIBRARY\)\([ ].*\)*$/DEF/p'\'' -e q $export_symbols`" ; then cp "$export_symbols" "$output_objdir/$soname.def"; echo "$tool_output_objdir$soname.def" > "$output_objdir/$soname.exp"; else $SED -e '\''s/^/-link -EXPORT:/'\'' < $export_symbols > $output_objdir/$soname.exp; fi~ $CC -o $tool_output_objdir$soname $libobjs $compiler_flags $deplibs "@$tool_output_objdir$soname.exp" -Wl,-DLL,-IMPLIB:"$tool_output_objdir$libname.dll.lib"~ linknames=' # The linker will not automatically build a static lib if we build a DLL. # _LT_TAGVAR(old_archive_from_new_cmds, )='true' enable_shared_with_static_runtimes=yes exclude_expsyms='_NULL_IMPORT_DESCRIPTOR|_IMPORT_DESCRIPTOR_.*' export_symbols_cmds='$NM $libobjs $convenience | $global_symbol_pipe | $SED -e '\''/^[BCDGRS][ ]/s/.*[ ]\([^ ]*\)/\1,DATA/'\'' | $SED -e '\''/^[AITW][ ]/s/.*[ ]//'\'' | sort | uniq > $export_symbols' # Don't use ranlib old_postinstall_cmds='chmod 644 $oldlib' postlink_cmds='lt_outputfile="@OUTPUT@"~ lt_tool_outputfile="@TOOL_OUTPUT@"~ case $lt_outputfile in *.exe|*.EXE) ;; *) lt_outputfile=$lt_outputfile.exe lt_tool_outputfile=$lt_tool_outputfile.exe ;; esac~ if test : != "$MANIFEST_TOOL" && test -f "$lt_outputfile.manifest"; then $MANIFEST_TOOL -manifest "$lt_tool_outputfile.manifest" -outputresource:"$lt_tool_outputfile" || exit 1; $RM "$lt_outputfile.manifest"; fi' ;; *) # Assume MSVC wrapper hardcode_libdir_flag_spec=' ' allow_undefined_flag=unsupported # Tell ltmain to make .lib files, not .a files. libext=lib # Tell ltmain to make .dll files, not .so files. shrext_cmds=.dll # FIXME: Setting linknames here is a bad hack. archive_cmds='$CC -o $lib $libobjs $compiler_flags `func_echo_all "$deplibs" | $SED '\''s/ -lc$//'\''` -link -dll~linknames=' # The linker will automatically build a .lib file if we build a DLL. old_archive_from_new_cmds='true' # FIXME: Should let the user specify the lib program. old_archive_cmds='lib -OUT:$oldlib$oldobjs$old_deplibs' enable_shared_with_static_runtimes=yes ;; esac ;; darwin* | rhapsody*) archive_cmds_need_lc=no hardcode_direct=no hardcode_automatic=yes hardcode_shlibpath_var=unsupported if test yes = "$lt_cv_ld_force_load"; then whole_archive_flag_spec='`for conv in $convenience\"\"; do test -n \"$conv\" && new_convenience=\"$new_convenience $wl-force_load,$conv\"; done; func_echo_all \"$new_convenience\"`' else whole_archive_flag_spec='' fi link_all_deplibs=yes allow_undefined_flag=$_lt_dar_allow_undefined case $cc_basename in ifort*|nagfor*) _lt_dar_can_shared=yes ;; *) _lt_dar_can_shared=$GCC ;; esac if test yes = "$_lt_dar_can_shared"; then output_verbose_link_cmd=func_echo_all archive_cmds="\$CC -dynamiclib \$allow_undefined_flag -o \$lib \$libobjs \$deplibs \$compiler_flags -install_name \$rpath/\$soname \$verstring $_lt_dar_single_mod$_lt_dsymutil" module_cmds="\$CC \$allow_undefined_flag -o \$lib -bundle \$libobjs \$deplibs \$compiler_flags$_lt_dsymutil" archive_expsym_cmds="sed 's|^|_|' < \$export_symbols > \$output_objdir/\$libname-symbols.expsym~\$CC -dynamiclib \$allow_undefined_flag -o \$lib \$libobjs \$deplibs \$compiler_flags -install_name \$rpath/\$soname \$verstring $_lt_dar_single_mod$_lt_dar_export_syms$_lt_dsymutil" module_expsym_cmds="sed -e 's|^|_|' < \$export_symbols > \$output_objdir/\$libname-symbols.expsym~\$CC \$allow_undefined_flag -o \$lib -bundle \$libobjs \$deplibs \$compiler_flags$_lt_dar_export_syms$_lt_dsymutil" else ld_shlibs=no fi ;; dgux*) archive_cmds='$LD -G -h $soname -o $lib $libobjs $deplibs $linker_flags' hardcode_libdir_flag_spec='-L$libdir' hardcode_shlibpath_var=no ;; # FreeBSD 2.2.[012] allows us to include c++rt0.o to get C++ constructor # support. Future versions do this automatically, but an explicit c++rt0.o # does not break anything, and helps significantly (at the cost of a little # extra space). freebsd2.2*) archive_cmds='$LD -Bshareable -o $lib $libobjs $deplibs $linker_flags /usr/lib/c++rt0.o' hardcode_libdir_flag_spec='-R$libdir' hardcode_direct=yes hardcode_shlibpath_var=no ;; # Unfortunately, older versions of FreeBSD 2 do not have this feature. freebsd2.*) archive_cmds='$LD -Bshareable -o $lib $libobjs $deplibs $linker_flags' hardcode_direct=yes hardcode_minus_L=yes hardcode_shlibpath_var=no ;; # FreeBSD 3 and greater uses gcc -shared to do shared libraries. freebsd* | dragonfly*) archive_cmds='$CC -shared $pic_flag -o $lib $libobjs $deplibs $compiler_flags' hardcode_libdir_flag_spec='-R$libdir' hardcode_direct=yes hardcode_shlibpath_var=no ;; hpux9*) if test yes = "$GCC"; then archive_cmds='$RM $output_objdir/$soname~$CC -shared $pic_flag $wl+b $wl$install_libdir -o $output_objdir/$soname $libobjs $deplibs $compiler_flags~test "x$output_objdir/$soname" = "x$lib" || mv $output_objdir/$soname $lib' else archive_cmds='$RM $output_objdir/$soname~$LD -b +b $install_libdir -o $output_objdir/$soname $libobjs $deplibs $linker_flags~test "x$output_objdir/$soname" = "x$lib" || mv $output_objdir/$soname $lib' fi hardcode_libdir_flag_spec='$wl+b $wl$libdir' hardcode_libdir_separator=: hardcode_direct=yes # hardcode_minus_L: Not really in the search PATH, # but as the default location of the library. hardcode_minus_L=yes export_dynamic_flag_spec='$wl-E' ;; hpux10*) if test yes,no = "$GCC,$with_gnu_ld"; then archive_cmds='$CC -shared $pic_flag $wl+h $wl$soname $wl+b $wl$install_libdir -o $lib $libobjs $deplibs $compiler_flags' else archive_cmds='$LD -b +h $soname +b $install_libdir -o $lib $libobjs $deplibs $linker_flags' fi if test no = "$with_gnu_ld"; then hardcode_libdir_flag_spec='$wl+b $wl$libdir' hardcode_libdir_separator=: hardcode_direct=yes hardcode_direct_absolute=yes export_dynamic_flag_spec='$wl-E' # hardcode_minus_L: Not really in the search PATH, # but as the default location of the library. hardcode_minus_L=yes fi ;; hpux11*) if test yes,no = "$GCC,$with_gnu_ld"; then case $host_cpu in hppa*64*) archive_cmds='$CC -shared $wl+h $wl$soname -o $lib $libobjs $deplibs $compiler_flags' ;; ia64*) archive_cmds='$CC -shared $pic_flag $wl+h $wl$soname $wl+nodefaultrpath -o $lib $libobjs $deplibs $compiler_flags' ;; *) archive_cmds='$CC -shared $pic_flag $wl+h $wl$soname $wl+b $wl$install_libdir -o $lib $libobjs $deplibs $compiler_flags' ;; esac else case $host_cpu in hppa*64*) archive_cmds='$CC -b $wl+h $wl$soname -o $lib $libobjs $deplibs $compiler_flags' ;; ia64*) archive_cmds='$CC -b $wl+h $wl$soname $wl+nodefaultrpath -o $lib $libobjs $deplibs $compiler_flags' ;; *) # Older versions of the 11.00 compiler do not understand -b yet # (HP92453-01 A.11.01.20 doesn't, HP92453-01 B.11.X.35175-35176.GP does) { $as_echo "$as_me:${as_lineno-$LINENO}: checking if $CC understands -b" >&5 $as_echo_n "checking if $CC understands -b... " >&6; } if ${lt_cv_prog_compiler__b+:} false; then : $as_echo_n "(cached) " >&6 else lt_cv_prog_compiler__b=no save_LDFLAGS=$LDFLAGS LDFLAGS="$LDFLAGS -b" echo "$lt_simple_link_test_code" > conftest.$ac_ext if (eval $ac_link 2>conftest.err) && test -s conftest$ac_exeext; then # The linker can only warn and ignore the option if not recognized # So say no if there are warnings if test -s conftest.err; then # Append any errors to the config.log. cat conftest.err 1>&5 $ECHO "$_lt_linker_boilerplate" | $SED '/^$/d' > conftest.exp $SED '/^$/d; /^ *+/d' conftest.err >conftest.er2 if diff conftest.exp conftest.er2 >/dev/null; then lt_cv_prog_compiler__b=yes fi else lt_cv_prog_compiler__b=yes fi fi $RM -r conftest* LDFLAGS=$save_LDFLAGS fi { $as_echo "$as_me:${as_lineno-$LINENO}: result: $lt_cv_prog_compiler__b" >&5 $as_echo "$lt_cv_prog_compiler__b" >&6; } if test yes = "$lt_cv_prog_compiler__b"; then archive_cmds='$CC -b $wl+h $wl$soname $wl+b $wl$install_libdir -o $lib $libobjs $deplibs $compiler_flags' else archive_cmds='$LD -b +h $soname +b $install_libdir -o $lib $libobjs $deplibs $linker_flags' fi ;; esac fi if test no = "$with_gnu_ld"; then hardcode_libdir_flag_spec='$wl+b $wl$libdir' hardcode_libdir_separator=: case $host_cpu in hppa*64*|ia64*) hardcode_direct=no hardcode_shlibpath_var=no ;; *) hardcode_direct=yes hardcode_direct_absolute=yes export_dynamic_flag_spec='$wl-E' # hardcode_minus_L: Not really in the search PATH, # but as the default location of the library. hardcode_minus_L=yes ;; esac fi ;; irix5* | irix6* | nonstopux*) if test yes = "$GCC"; then archive_cmds='$CC -shared $pic_flag $libobjs $deplibs $compiler_flags $wl-soname $wl$soname `test -n "$verstring" && func_echo_all "$wl-set_version $wl$verstring"` $wl-update_registry $wl$output_objdir/so_locations -o $lib' # Try to use the -exported_symbol ld option, if it does not # work, assume that -exports_file does not work either and # implicitly export all symbols. # This should be the same for all languages, so no per-tag cache variable. { $as_echo "$as_me:${as_lineno-$LINENO}: checking whether the $host_os linker accepts -exported_symbol" >&5 $as_echo_n "checking whether the $host_os linker accepts -exported_symbol... " >&6; } if ${lt_cv_irix_exported_symbol+:} false; then : $as_echo_n "(cached) " >&6 else save_LDFLAGS=$LDFLAGS LDFLAGS="$LDFLAGS -shared $wl-exported_symbol ${wl}foo $wl-update_registry $wl/dev/null" cat confdefs.h - <<_ACEOF >conftest.$ac_ext /* end confdefs.h. */ int foo (void) { return 0; } _ACEOF if ac_fn_c_try_link "$LINENO"; then : lt_cv_irix_exported_symbol=yes else lt_cv_irix_exported_symbol=no fi rm -f core conftest.err conftest.$ac_objext \ conftest$ac_exeext conftest.$ac_ext LDFLAGS=$save_LDFLAGS fi { $as_echo "$as_me:${as_lineno-$LINENO}: result: $lt_cv_irix_exported_symbol" >&5 $as_echo "$lt_cv_irix_exported_symbol" >&6; } if test yes = "$lt_cv_irix_exported_symbol"; then archive_expsym_cmds='$CC -shared $pic_flag $libobjs $deplibs $compiler_flags $wl-soname $wl$soname `test -n "$verstring" && func_echo_all "$wl-set_version $wl$verstring"` $wl-update_registry $wl$output_objdir/so_locations $wl-exports_file $wl$export_symbols -o $lib' fi else archive_cmds='$CC -shared $libobjs $deplibs $compiler_flags -soname $soname `test -n "$verstring" && func_echo_all "-set_version $verstring"` -update_registry $output_objdir/so_locations -o $lib' archive_expsym_cmds='$CC -shared $libobjs $deplibs $compiler_flags -soname $soname `test -n "$verstring" && func_echo_all "-set_version $verstring"` -update_registry $output_objdir/so_locations -exports_file $export_symbols -o $lib' fi archive_cmds_need_lc='no' hardcode_libdir_flag_spec='$wl-rpath $wl$libdir' hardcode_libdir_separator=: inherit_rpath=yes link_all_deplibs=yes ;; linux*) case $cc_basename in tcc*) # Fabrice Bellard et al's Tiny C Compiler ld_shlibs=yes archive_cmds='$CC -shared $pic_flag -o $lib $libobjs $deplibs $compiler_flags' ;; esac ;; netbsd*) if echo __ELF__ | $CC -E - | $GREP __ELF__ >/dev/null; then archive_cmds='$LD -Bshareable -o $lib $libobjs $deplibs $linker_flags' # a.out else archive_cmds='$LD -shared -o $lib $libobjs $deplibs $linker_flags' # ELF fi hardcode_libdir_flag_spec='-R$libdir' hardcode_direct=yes hardcode_shlibpath_var=no ;; newsos6) archive_cmds='$LD -G -h $soname -o $lib $libobjs $deplibs $linker_flags' hardcode_direct=yes hardcode_libdir_flag_spec='$wl-rpath $wl$libdir' hardcode_libdir_separator=: hardcode_shlibpath_var=no ;; *nto* | *qnx*) ;; openbsd* | bitrig*) if test -f /usr/libexec/ld.so; then hardcode_direct=yes hardcode_shlibpath_var=no hardcode_direct_absolute=yes if test -z "`echo __ELF__ | $CC -E - | $GREP __ELF__`"; then archive_cmds='$CC -shared $pic_flag -o $lib $libobjs $deplibs $compiler_flags' archive_expsym_cmds='$CC -shared $pic_flag -o $lib $libobjs $deplibs $compiler_flags $wl-retain-symbols-file,$export_symbols' hardcode_libdir_flag_spec='$wl-rpath,$libdir' export_dynamic_flag_spec='$wl-E' else archive_cmds='$CC -shared $pic_flag -o $lib $libobjs $deplibs $compiler_flags' hardcode_libdir_flag_spec='$wl-rpath,$libdir' fi else ld_shlibs=no fi ;; os2*) hardcode_libdir_flag_spec='-L$libdir' hardcode_minus_L=yes allow_undefined_flag=unsupported shrext_cmds=.dll archive_cmds='$ECHO "LIBRARY ${soname%$shared_ext} INITINSTANCE TERMINSTANCE" > $output_objdir/$libname.def~ $ECHO "DESCRIPTION \"$libname\"" >> $output_objdir/$libname.def~ $ECHO "DATA MULTIPLE NONSHARED" >> $output_objdir/$libname.def~ $ECHO EXPORTS >> $output_objdir/$libname.def~ emxexp $libobjs | $SED /"_DLL_InitTerm"/d >> $output_objdir/$libname.def~ $CC -Zdll -Zcrtdll -o $output_objdir/$soname $libobjs $deplibs $compiler_flags $output_objdir/$libname.def~ emximp -o $lib $output_objdir/$libname.def' archive_expsym_cmds='$ECHO "LIBRARY ${soname%$shared_ext} INITINSTANCE TERMINSTANCE" > $output_objdir/$libname.def~ $ECHO "DESCRIPTION \"$libname\"" >> $output_objdir/$libname.def~ $ECHO "DATA MULTIPLE NONSHARED" >> $output_objdir/$libname.def~ $ECHO EXPORTS >> $output_objdir/$libname.def~ prefix_cmds="$SED"~ if test EXPORTS = "`$SED 1q $export_symbols`"; then prefix_cmds="$prefix_cmds -e 1d"; fi~ prefix_cmds="$prefix_cmds -e \"s/^\(.*\)$/_\1/g\""~ cat $export_symbols | $prefix_cmds >> $output_objdir/$libname.def~ $CC -Zdll -Zcrtdll -o $output_objdir/$soname $libobjs $deplibs $compiler_flags $output_objdir/$libname.def~ emximp -o $lib $output_objdir/$libname.def' old_archive_From_new_cmds='emximp -o $output_objdir/${libname}_dll.a $output_objdir/$libname.def' enable_shared_with_static_runtimes=yes ;; osf3*) if test yes = "$GCC"; then allow_undefined_flag=' $wl-expect_unresolved $wl\*' archive_cmds='$CC -shared$allow_undefined_flag $libobjs $deplibs $compiler_flags $wl-soname $wl$soname `test -n "$verstring" && func_echo_all "$wl-set_version $wl$verstring"` $wl-update_registry $wl$output_objdir/so_locations -o $lib' else allow_undefined_flag=' -expect_unresolved \*' archive_cmds='$CC -shared$allow_undefined_flag $libobjs $deplibs $compiler_flags -soname $soname `test -n "$verstring" && func_echo_all "-set_version $verstring"` -update_registry $output_objdir/so_locations -o $lib' fi archive_cmds_need_lc='no' hardcode_libdir_flag_spec='$wl-rpath $wl$libdir' hardcode_libdir_separator=: ;; osf4* | osf5*) # as osf3* with the addition of -msym flag if test yes = "$GCC"; then allow_undefined_flag=' $wl-expect_unresolved $wl\*' archive_cmds='$CC -shared$allow_undefined_flag $pic_flag $libobjs $deplibs $compiler_flags $wl-msym $wl-soname $wl$soname `test -n "$verstring" && func_echo_all "$wl-set_version $wl$verstring"` $wl-update_registry $wl$output_objdir/so_locations -o $lib' hardcode_libdir_flag_spec='$wl-rpath $wl$libdir' else allow_undefined_flag=' -expect_unresolved \*' archive_cmds='$CC -shared$allow_undefined_flag $libobjs $deplibs $compiler_flags -msym -soname $soname `test -n "$verstring" && func_echo_all "-set_version $verstring"` -update_registry $output_objdir/so_locations -o $lib' archive_expsym_cmds='for i in `cat $export_symbols`; do printf "%s %s\\n" -exported_symbol "\$i" >> $lib.exp; done; printf "%s\\n" "-hidden">> $lib.exp~ $CC -shared$allow_undefined_flag $wl-input $wl$lib.exp $compiler_flags $libobjs $deplibs -soname $soname `test -n "$verstring" && $ECHO "-set_version $verstring"` -update_registry $output_objdir/so_locations -o $lib~$RM $lib.exp' # Both c and cxx compiler support -rpath directly hardcode_libdir_flag_spec='-rpath $libdir' fi archive_cmds_need_lc='no' hardcode_libdir_separator=: ;; solaris*) no_undefined_flag=' -z defs' if test yes = "$GCC"; then wlarc='$wl' archive_cmds='$CC -shared $pic_flag $wl-z ${wl}text $wl-h $wl$soname -o $lib $libobjs $deplibs $compiler_flags' archive_expsym_cmds='echo "{ global:" > $lib.exp~cat $export_symbols | $SED -e "s/\(.*\)/\1;/" >> $lib.exp~echo "local: *; };" >> $lib.exp~ $CC -shared $pic_flag $wl-z ${wl}text $wl-M $wl$lib.exp $wl-h $wl$soname -o $lib $libobjs $deplibs $compiler_flags~$RM $lib.exp' else case `$CC -V 2>&1` in *"Compilers 5.0"*) wlarc='' archive_cmds='$LD -G$allow_undefined_flag -h $soname -o $lib $libobjs $deplibs $linker_flags' archive_expsym_cmds='echo "{ global:" > $lib.exp~cat $export_symbols | $SED -e "s/\(.*\)/\1;/" >> $lib.exp~echo "local: *; };" >> $lib.exp~ $LD -G$allow_undefined_flag -M $lib.exp -h $soname -o $lib $libobjs $deplibs $linker_flags~$RM $lib.exp' ;; *) wlarc='$wl' archive_cmds='$CC -G$allow_undefined_flag -h $soname -o $lib $libobjs $deplibs $compiler_flags' archive_expsym_cmds='echo "{ global:" > $lib.exp~cat $export_symbols | $SED -e "s/\(.*\)/\1;/" >> $lib.exp~echo "local: *; };" >> $lib.exp~ $CC -G$allow_undefined_flag -M $lib.exp -h $soname -o $lib $libobjs $deplibs $compiler_flags~$RM $lib.exp' ;; esac fi hardcode_libdir_flag_spec='-R$libdir' hardcode_shlibpath_var=no case $host_os in solaris2.[0-5] | solaris2.[0-5].*) ;; *) # The compiler driver will combine and reorder linker options, # but understands '-z linker_flag'. GCC discards it without '$wl', # but is careful enough not to reorder. # Supported since Solaris 2.6 (maybe 2.5.1?) if test yes = "$GCC"; then whole_archive_flag_spec='$wl-z ${wl}allextract$convenience $wl-z ${wl}defaultextract' else whole_archive_flag_spec='-z allextract$convenience -z defaultextract' fi ;; esac link_all_deplibs=yes ;; sunos4*) if test sequent = "$host_vendor"; then # Use $CC to link under sequent, because it throws in some extra .o # files that make .init and .fini sections work. archive_cmds='$CC -G $wl-h $soname -o $lib $libobjs $deplibs $compiler_flags' else archive_cmds='$LD -assert pure-text -Bstatic -o $lib $libobjs $deplibs $linker_flags' fi hardcode_libdir_flag_spec='-L$libdir' hardcode_direct=yes hardcode_minus_L=yes hardcode_shlibpath_var=no ;; sysv4) case $host_vendor in sni) archive_cmds='$LD -G -h $soname -o $lib $libobjs $deplibs $linker_flags' hardcode_direct=yes # is this really true??? ;; siemens) ## LD is ld it makes a PLAMLIB ## CC just makes a GrossModule. archive_cmds='$LD -G -o $lib $libobjs $deplibs $linker_flags' reload_cmds='$CC -r -o $output$reload_objs' hardcode_direct=no ;; motorola) archive_cmds='$LD -G -h $soname -o $lib $libobjs $deplibs $linker_flags' hardcode_direct=no #Motorola manual says yes, but my tests say they lie ;; esac runpath_var='LD_RUN_PATH' hardcode_shlibpath_var=no ;; sysv4.3*) archive_cmds='$LD -G -h $soname -o $lib $libobjs $deplibs $linker_flags' hardcode_shlibpath_var=no export_dynamic_flag_spec='-Bexport' ;; sysv4*MP*) if test -d /usr/nec; then archive_cmds='$LD -G -h $soname -o $lib $libobjs $deplibs $linker_flags' hardcode_shlibpath_var=no runpath_var=LD_RUN_PATH hardcode_runpath_var=yes ld_shlibs=yes fi ;; sysv4*uw2* | sysv5OpenUNIX* | sysv5UnixWare7.[01].[10]* | unixware7* | sco3.2v5.0.[024]*) no_undefined_flag='$wl-z,text' archive_cmds_need_lc=no hardcode_shlibpath_var=no runpath_var='LD_RUN_PATH' if test yes = "$GCC"; then archive_cmds='$CC -shared $wl-h,$soname -o $lib $libobjs $deplibs $compiler_flags' archive_expsym_cmds='$CC -shared $wl-Bexport:$export_symbols $wl-h,$soname -o $lib $libobjs $deplibs $compiler_flags' else archive_cmds='$CC -G $wl-h,$soname -o $lib $libobjs $deplibs $compiler_flags' archive_expsym_cmds='$CC -G $wl-Bexport:$export_symbols $wl-h,$soname -o $lib $libobjs $deplibs $compiler_flags' fi ;; sysv5* | sco3.2v5* | sco5v6*) # Note: We CANNOT use -z defs as we might desire, because we do not # link with -lc, and that would cause any symbols used from libc to # always be unresolved, which means just about no library would # ever link correctly. If we're not using GNU ld we use -z text # though, which does catch some bad symbols but isn't as heavy-handed # as -z defs. no_undefined_flag='$wl-z,text' allow_undefined_flag='$wl-z,nodefs' archive_cmds_need_lc=no hardcode_shlibpath_var=no hardcode_libdir_flag_spec='$wl-R,$libdir' hardcode_libdir_separator=':' link_all_deplibs=yes export_dynamic_flag_spec='$wl-Bexport' runpath_var='LD_RUN_PATH' if test yes = "$GCC"; then archive_cmds='$CC -shared $wl-h,$soname -o $lib $libobjs $deplibs $compiler_flags' archive_expsym_cmds='$CC -shared $wl-Bexport:$export_symbols $wl-h,$soname -o $lib $libobjs $deplibs $compiler_flags' else archive_cmds='$CC -G $wl-h,$soname -o $lib $libobjs $deplibs $compiler_flags' archive_expsym_cmds='$CC -G $wl-Bexport:$export_symbols $wl-h,$soname -o $lib $libobjs $deplibs $compiler_flags' fi ;; uts4*) archive_cmds='$LD -G -h $soname -o $lib $libobjs $deplibs $linker_flags' hardcode_libdir_flag_spec='-L$libdir' hardcode_shlibpath_var=no ;; *) ld_shlibs=no ;; esac if test sni = "$host_vendor"; then case $host in sysv4 | sysv4.2uw2* | sysv4.3* | sysv5*) export_dynamic_flag_spec='$wl-Blargedynsym' ;; esac fi fi { $as_echo "$as_me:${as_lineno-$LINENO}: result: $ld_shlibs" >&5 $as_echo "$ld_shlibs" >&6; } test no = "$ld_shlibs" && can_build_shared=no with_gnu_ld=$with_gnu_ld # # Do we need to explicitly link libc? # case "x$archive_cmds_need_lc" in x|xyes) # Assume -lc should be added archive_cmds_need_lc=yes if test yes,yes = "$GCC,$enable_shared"; then case $archive_cmds in *'~'*) # FIXME: we may have to deal with multi-command sequences. ;; '$CC '*) # Test whether the compiler implicitly links with -lc since on some # systems, -lgcc has to come before -lc. If gcc already passes -lc # to ld, don't add -lc before -lgcc. { $as_echo "$as_me:${as_lineno-$LINENO}: checking whether -lc should be explicitly linked in" >&5 $as_echo_n "checking whether -lc should be explicitly linked in... " >&6; } if ${lt_cv_archive_cmds_need_lc+:} false; then : $as_echo_n "(cached) " >&6 else $RM conftest* echo "$lt_simple_compile_test_code" > conftest.$ac_ext if { { eval echo "\"\$as_me\":${as_lineno-$LINENO}: \"$ac_compile\""; } >&5 (eval $ac_compile) 2>&5 ac_status=$? $as_echo "$as_me:${as_lineno-$LINENO}: \$? = $ac_status" >&5 test $ac_status = 0; } 2>conftest.err; then soname=conftest lib=conftest libobjs=conftest.$ac_objext deplibs= wl=$lt_prog_compiler_wl pic_flag=$lt_prog_compiler_pic compiler_flags=-v linker_flags=-v verstring= output_objdir=. libname=conftest lt_save_allow_undefined_flag=$allow_undefined_flag allow_undefined_flag= if { { eval echo "\"\$as_me\":${as_lineno-$LINENO}: \"$archive_cmds 2\>\&1 \| $GREP \" -lc \" \>/dev/null 2\>\&1\""; } >&5 (eval $archive_cmds 2\>\&1 \| $GREP \" -lc \" \>/dev/null 2\>\&1) 2>&5 ac_status=$? $as_echo "$as_me:${as_lineno-$LINENO}: \$? = $ac_status" >&5 test $ac_status = 0; } then lt_cv_archive_cmds_need_lc=no else lt_cv_archive_cmds_need_lc=yes fi allow_undefined_flag=$lt_save_allow_undefined_flag else cat conftest.err 1>&5 fi $RM conftest* fi { $as_echo "$as_me:${as_lineno-$LINENO}: result: $lt_cv_archive_cmds_need_lc" >&5 $as_echo "$lt_cv_archive_cmds_need_lc" >&6; } archive_cmds_need_lc=$lt_cv_archive_cmds_need_lc ;; esac fi ;; esac { $as_echo "$as_me:${as_lineno-$LINENO}: checking dynamic linker characteristics" >&5 $as_echo_n "checking dynamic linker characteristics... " >&6; } if test yes = "$GCC"; then case $host_os in darwin*) lt_awk_arg='/^libraries:/,/LR/' ;; *) lt_awk_arg='/^libraries:/' ;; esac case $host_os in mingw* | cegcc*) lt_sed_strip_eq='s|=\([A-Za-z]:\)|\1|g' ;; *) lt_sed_strip_eq='s|=/|/|g' ;; esac lt_search_path_spec=`$CC -print-search-dirs | awk $lt_awk_arg | $SED -e "s/^libraries://" -e $lt_sed_strip_eq` case $lt_search_path_spec in *\;*) # if the path contains ";" then we assume it to be the separator # otherwise default to the standard path separator (i.e. ":") - it is # assumed that no part of a normal pathname contains ";" but that should # okay in the real world where ";" in dirpaths is itself problematic. lt_search_path_spec=`$ECHO "$lt_search_path_spec" | $SED 's/;/ /g'` ;; *) lt_search_path_spec=`$ECHO "$lt_search_path_spec" | $SED "s/$PATH_SEPARATOR/ /g"` ;; esac # Ok, now we have the path, separated by spaces, we can step through it # and add multilib dir if necessary... lt_tmp_lt_search_path_spec= lt_multi_os_dir=/`$CC $CPPFLAGS $CFLAGS $LDFLAGS -print-multi-os-directory 2>/dev/null` # ...but if some path component already ends with the multilib dir we assume # that all is fine and trust -print-search-dirs as is (GCC 4.2? or newer). case "$lt_multi_os_dir; $lt_search_path_spec " in "/; "* | "/.; "* | "/./; "* | *"$lt_multi_os_dir "* | *"$lt_multi_os_dir/ "*) lt_multi_os_dir= ;; esac for lt_sys_path in $lt_search_path_spec; do if test -d "$lt_sys_path$lt_multi_os_dir"; then lt_tmp_lt_search_path_spec="$lt_tmp_lt_search_path_spec $lt_sys_path$lt_multi_os_dir" elif test -n "$lt_multi_os_dir"; then test -d "$lt_sys_path" && \ lt_tmp_lt_search_path_spec="$lt_tmp_lt_search_path_spec $lt_sys_path" fi done lt_search_path_spec=`$ECHO "$lt_tmp_lt_search_path_spec" | awk ' BEGIN {RS = " "; FS = "/|\n";} { lt_foo = ""; lt_count = 0; for (lt_i = NF; lt_i > 0; lt_i--) { if ($lt_i != "" && $lt_i != ".") { if ($lt_i == "..") { lt_count++; } else { if (lt_count == 0) { lt_foo = "/" $lt_i lt_foo; } else { lt_count--; } } } } if (lt_foo != "") { lt_freq[lt_foo]++; } if (lt_freq[lt_foo] == 1) { print lt_foo; } }'` # AWK program above erroneously prepends '/' to C:/dos/paths # for these hosts. case $host_os in mingw* | cegcc*) lt_search_path_spec=`$ECHO "$lt_search_path_spec" |\ $SED 's|/\([A-Za-z]:\)|\1|g'` ;; esac sys_lib_search_path_spec=`$ECHO "$lt_search_path_spec" | $lt_NL2SP` else sys_lib_search_path_spec="/lib /usr/lib /usr/local/lib" fi library_names_spec= libname_spec='lib$name' soname_spec= shrext_cmds=.so postinstall_cmds= postuninstall_cmds= finish_cmds= finish_eval= shlibpath_var= shlibpath_overrides_runpath=unknown version_type=none dynamic_linker="$host_os ld.so" sys_lib_dlsearch_path_spec="/lib /usr/lib" need_lib_prefix=unknown hardcode_into_libs=no # when you set need_version to no, make sure it does not cause -set_version # flags to be left without arguments need_version=unknown case $host_os in aix3*) version_type=linux # correct to gnu/linux during the next big refactor library_names_spec='$libname$release$shared_ext$versuffix $libname.a' shlibpath_var=LIBPATH # AIX 3 has no versioning support, so we append a major version to the name. soname_spec='$libname$release$shared_ext$major' ;; aix[4-9]*) version_type=linux # correct to gnu/linux during the next big refactor need_lib_prefix=no need_version=no hardcode_into_libs=yes if test ia64 = "$host_cpu"; then # AIX 5 supports IA64 library_names_spec='$libname$release$shared_ext$major $libname$release$shared_ext$versuffix $libname$shared_ext' shlibpath_var=LD_LIBRARY_PATH else # With GCC up to 2.95.x, collect2 would create an import file # for dependence libraries. The import file would start with # the line '#! .'. This would cause the generated library to # depend on '.', always an invalid library. This was fixed in # development snapshots of GCC prior to 3.0. case $host_os in aix4 | aix4.[01] | aix4.[01].*) if { echo '#if __GNUC__ > 2 || (__GNUC__ == 2 && __GNUC_MINOR__ >= 97)' echo ' yes ' echo '#endif'; } | $CC -E - | $GREP yes > /dev/null; then : else can_build_shared=no fi ;; esac # Using Import Files as archive members, it is possible to support # filename-based versioning of shared library archives on AIX. While # this would work for both with and without runtime linking, it will # prevent static linking of such archives. So we do filename-based # shared library versioning with .so extension only, which is used # when both runtime linking and shared linking is enabled. # Unfortunately, runtime linking may impact performance, so we do # not want this to be the default eventually. Also, we use the # versioned .so libs for executables only if there is the -brtl # linker flag in LDFLAGS as well, or --with-aix-soname=svr4 only. # To allow for filename-based versioning support, we need to create # libNAME.so.V as an archive file, containing: # *) an Import File, referring to the versioned filename of the # archive as well as the shared archive member, telling the # bitwidth (32 or 64) of that shared object, and providing the # list of exported symbols of that shared object, eventually # decorated with the 'weak' keyword # *) the shared object with the F_LOADONLY flag set, to really avoid # it being seen by the linker. # At run time we better use the real file rather than another symlink, # but for link time we create the symlink libNAME.so -> libNAME.so.V case $with_aix_soname,$aix_use_runtimelinking in # AIX (on Power*) has no versioning support, so currently we cannot hardcode correct # soname into executable. Probably we can add versioning support to # collect2, so additional links can be useful in future. aix,yes) # traditional libtool dynamic_linker='AIX unversionable lib.so' # If using run time linking (on AIX 4.2 or later) use lib.so # instead of lib.a to let people know that these are not # typical AIX shared libraries. library_names_spec='$libname$release$shared_ext$versuffix $libname$release$shared_ext$major $libname$shared_ext' ;; aix,no) # traditional AIX only dynamic_linker='AIX lib.a(lib.so.V)' # We preserve .a as extension for shared libraries through AIX4.2 # and later when we are not doing run time linking. library_names_spec='$libname$release.a $libname.a' soname_spec='$libname$release$shared_ext$major' ;; svr4,*) # full svr4 only dynamic_linker="AIX lib.so.V($shared_archive_member_spec.o)" library_names_spec='$libname$release$shared_ext$major $libname$shared_ext' # We do not specify a path in Import Files, so LIBPATH fires. shlibpath_overrides_runpath=yes ;; *,yes) # both, prefer svr4 dynamic_linker="AIX lib.so.V($shared_archive_member_spec.o), lib.a(lib.so.V)" library_names_spec='$libname$release$shared_ext$major $libname$shared_ext' # unpreferred sharedlib libNAME.a needs extra handling postinstall_cmds='test -n "$linkname" || linkname="$realname"~func_stripname "" ".so" "$linkname"~$install_shared_prog "$dir/$func_stripname_result.$libext" "$destdir/$func_stripname_result.$libext"~test -z "$tstripme" || test -z "$striplib" || $striplib "$destdir/$func_stripname_result.$libext"' postuninstall_cmds='for n in $library_names $old_library; do :; done~func_stripname "" ".so" "$n"~test "$func_stripname_result" = "$n" || func_append rmfiles " $odir/$func_stripname_result.$libext"' # We do not specify a path in Import Files, so LIBPATH fires. shlibpath_overrides_runpath=yes ;; *,no) # both, prefer aix dynamic_linker="AIX lib.a(lib.so.V), lib.so.V($shared_archive_member_spec.o)" library_names_spec='$libname$release.a $libname.a' soname_spec='$libname$release$shared_ext$major' # unpreferred sharedlib libNAME.so.V and symlink libNAME.so need extra handling postinstall_cmds='test -z "$dlname" || $install_shared_prog $dir/$dlname $destdir/$dlname~test -z "$tstripme" || test -z "$striplib" || $striplib $destdir/$dlname~test -n "$linkname" || linkname=$realname~func_stripname "" ".a" "$linkname"~(cd "$destdir" && $LN_S -f $dlname $func_stripname_result.so)' postuninstall_cmds='test -z "$dlname" || func_append rmfiles " $odir/$dlname"~for n in $old_library $library_names; do :; done~func_stripname "" ".a" "$n"~func_append rmfiles " $odir/$func_stripname_result.so"' ;; esac shlibpath_var=LIBPATH fi ;; amigaos*) case $host_cpu in powerpc) # Since July 2007 AmigaOS4 officially supports .so libraries. # When compiling the executable, add -use-dynld -Lsobjs: to the compileline. library_names_spec='$libname$release$shared_ext$versuffix $libname$release$shared_ext$major $libname$shared_ext' ;; m68k) library_names_spec='$libname.ixlibrary $libname.a' # Create ${libname}_ixlibrary.a entries in /sys/libs. finish_eval='for lib in `ls $libdir/*.ixlibrary 2>/dev/null`; do libname=`func_echo_all "$lib" | $SED '\''s%^.*/\([^/]*\)\.ixlibrary$%\1%'\''`; $RM /sys/libs/${libname}_ixlibrary.a; $show "cd /sys/libs && $LN_S $lib ${libname}_ixlibrary.a"; cd /sys/libs && $LN_S $lib ${libname}_ixlibrary.a || exit 1; done' ;; esac ;; beos*) library_names_spec='$libname$shared_ext' dynamic_linker="$host_os ld.so" shlibpath_var=LIBRARY_PATH ;; bsdi[45]*) version_type=linux # correct to gnu/linux during the next big refactor need_version=no library_names_spec='$libname$release$shared_ext$versuffix $libname$release$shared_ext$major $libname$shared_ext' soname_spec='$libname$release$shared_ext$major' finish_cmds='PATH="\$PATH:/sbin" ldconfig $libdir' shlibpath_var=LD_LIBRARY_PATH sys_lib_search_path_spec="/shlib /usr/lib /usr/X11/lib /usr/contrib/lib /lib /usr/local/lib" sys_lib_dlsearch_path_spec="/shlib /usr/lib /usr/local/lib" # the default ld.so.conf also contains /usr/contrib/lib and # /usr/X11R6/lib (/usr/X11 is a link to /usr/X11R6), but let us allow # libtool to hard-code these into programs ;; cygwin* | mingw* | pw32* | cegcc*) version_type=windows shrext_cmds=.dll need_version=no need_lib_prefix=no case $GCC,$cc_basename in yes,*) # gcc library_names_spec='$libname.dll.a' # DLL is installed to $(libdir)/../bin by postinstall_cmds postinstall_cmds='base_file=`basename \$file`~ dlpath=`$SHELL 2>&1 -c '\''. $dir/'\''\$base_file'\''i; echo \$dlname'\''`~ dldir=$destdir/`dirname \$dlpath`~ test -d \$dldir || mkdir -p \$dldir~ $install_prog $dir/$dlname \$dldir/$dlname~ chmod a+x \$dldir/$dlname~ if test -n '\''$stripme'\'' && test -n '\''$striplib'\''; then eval '\''$striplib \$dldir/$dlname'\'' || exit \$?; fi' postuninstall_cmds='dldll=`$SHELL 2>&1 -c '\''. $file; echo \$dlname'\''`~ dlpath=$dir/\$dldll~ $RM \$dlpath' shlibpath_overrides_runpath=yes case $host_os in cygwin*) # Cygwin DLLs use 'cyg' prefix rather than 'lib' soname_spec='`echo $libname | sed -e 's/^lib/cyg/'``echo $release | $SED -e 's/[.]/-/g'`$versuffix$shared_ext' sys_lib_search_path_spec="$sys_lib_search_path_spec /usr/lib/w32api" ;; mingw* | cegcc*) # MinGW DLLs use traditional 'lib' prefix soname_spec='$libname`echo $release | $SED -e 's/[.]/-/g'`$versuffix$shared_ext' ;; pw32*) # pw32 DLLs use 'pw' prefix rather than 'lib' library_names_spec='`echo $libname | sed -e 's/^lib/pw/'``echo $release | $SED -e 's/[.]/-/g'`$versuffix$shared_ext' ;; esac dynamic_linker='Win32 ld.exe' ;; *,cl*) # Native MSVC libname_spec='$name' soname_spec='$libname`echo $release | $SED -e 's/[.]/-/g'`$versuffix$shared_ext' library_names_spec='$libname.dll.lib' case $build_os in mingw*) sys_lib_search_path_spec= lt_save_ifs=$IFS IFS=';' for lt_path in $LIB do IFS=$lt_save_ifs # Let DOS variable expansion print the short 8.3 style file name. lt_path=`cd "$lt_path" 2>/dev/null && cmd //C "for %i in (".") do @echo %~si"` sys_lib_search_path_spec="$sys_lib_search_path_spec $lt_path" done IFS=$lt_save_ifs # Convert to MSYS style. sys_lib_search_path_spec=`$ECHO "$sys_lib_search_path_spec" | sed -e 's|\\\\|/|g' -e 's| \\([a-zA-Z]\\):| /\\1|g' -e 's|^ ||'` ;; cygwin*) # Convert to unix form, then to dos form, then back to unix form # but this time dos style (no spaces!) so that the unix form looks # like /cygdrive/c/PROGRA~1:/cygdr... sys_lib_search_path_spec=`cygpath --path --unix "$LIB"` sys_lib_search_path_spec=`cygpath --path --dos "$sys_lib_search_path_spec" 2>/dev/null` sys_lib_search_path_spec=`cygpath --path --unix "$sys_lib_search_path_spec" | $SED -e "s/$PATH_SEPARATOR/ /g"` ;; *) sys_lib_search_path_spec=$LIB if $ECHO "$sys_lib_search_path_spec" | $GREP ';[c-zC-Z]:/' >/dev/null; then # It is most probably a Windows format PATH. sys_lib_search_path_spec=`$ECHO "$sys_lib_search_path_spec" | $SED -e 's/;/ /g'` else sys_lib_search_path_spec=`$ECHO "$sys_lib_search_path_spec" | $SED -e "s/$PATH_SEPARATOR/ /g"` fi # FIXME: find the short name or the path components, as spaces are # common. (e.g. "Program Files" -> "PROGRA~1") ;; esac # DLL is installed to $(libdir)/../bin by postinstall_cmds postinstall_cmds='base_file=`basename \$file`~ dlpath=`$SHELL 2>&1 -c '\''. $dir/'\''\$base_file'\''i; echo \$dlname'\''`~ dldir=$destdir/`dirname \$dlpath`~ test -d \$dldir || mkdir -p \$dldir~ $install_prog $dir/$dlname \$dldir/$dlname' postuninstall_cmds='dldll=`$SHELL 2>&1 -c '\''. $file; echo \$dlname'\''`~ dlpath=$dir/\$dldll~ $RM \$dlpath' shlibpath_overrides_runpath=yes dynamic_linker='Win32 link.exe' ;; *) # Assume MSVC wrapper library_names_spec='$libname`echo $release | $SED -e 's/[.]/-/g'`$versuffix$shared_ext $libname.lib' dynamic_linker='Win32 ld.exe' ;; esac # FIXME: first we should search . and the directory the executable is in shlibpath_var=PATH ;; darwin* | rhapsody*) dynamic_linker="$host_os dyld" version_type=darwin need_lib_prefix=no need_version=no library_names_spec='$libname$release$major$shared_ext $libname$shared_ext' soname_spec='$libname$release$major$shared_ext' shlibpath_overrides_runpath=yes shlibpath_var=DYLD_LIBRARY_PATH shrext_cmds='`test .$module = .yes && echo .so || echo .dylib`' sys_lib_search_path_spec="$sys_lib_search_path_spec /usr/local/lib" sys_lib_dlsearch_path_spec='/usr/local/lib /lib /usr/lib' ;; dgux*) version_type=linux # correct to gnu/linux during the next big refactor need_lib_prefix=no need_version=no library_names_spec='$libname$release$shared_ext$versuffix $libname$release$shared_ext$major $libname$shared_ext' soname_spec='$libname$release$shared_ext$major' shlibpath_var=LD_LIBRARY_PATH ;; freebsd* | dragonfly*) # DragonFly does not have aout. When/if they implement a new # versioning mechanism, adjust this. if test -x /usr/bin/objformat; then objformat=`/usr/bin/objformat` else case $host_os in freebsd[23].*) objformat=aout ;; *) objformat=elf ;; esac fi version_type=freebsd-$objformat case $version_type in freebsd-elf*) library_names_spec='$libname$release$shared_ext$versuffix $libname$release$shared_ext$major $libname$shared_ext' soname_spec='$libname$release$shared_ext$major' need_version=no need_lib_prefix=no ;; freebsd-*) library_names_spec='$libname$release$shared_ext$versuffix $libname$shared_ext$versuffix' need_version=yes ;; esac shlibpath_var=LD_LIBRARY_PATH case $host_os in freebsd2.*) shlibpath_overrides_runpath=yes ;; freebsd3.[01]* | freebsdelf3.[01]*) shlibpath_overrides_runpath=yes hardcode_into_libs=yes ;; freebsd3.[2-9]* | freebsdelf3.[2-9]* | \ freebsd4.[0-5] | freebsdelf4.[0-5] | freebsd4.1.1 | freebsdelf4.1.1) shlibpath_overrides_runpath=no hardcode_into_libs=yes ;; *) # from 4.6 on, and DragonFly shlibpath_overrides_runpath=yes hardcode_into_libs=yes ;; esac ;; haiku*) version_type=linux # correct to gnu/linux during the next big refactor need_lib_prefix=no need_version=no dynamic_linker="$host_os runtime_loader" library_names_spec='$libname$release$shared_ext$versuffix $libname$release$shared_ext$major $libname$shared_ext' soname_spec='$libname$release$shared_ext$major' shlibpath_var=LIBRARY_PATH shlibpath_overrides_runpath=no sys_lib_dlsearch_path_spec='/boot/home/config/lib /boot/common/lib /boot/system/lib' hardcode_into_libs=yes ;; hpux9* | hpux10* | hpux11*) # Give a soname corresponding to the major version so that dld.sl refuses to # link against other versions. version_type=sunos need_lib_prefix=no need_version=no case $host_cpu in ia64*) shrext_cmds='.so' hardcode_into_libs=yes dynamic_linker="$host_os dld.so" shlibpath_var=LD_LIBRARY_PATH shlibpath_overrides_runpath=yes # Unless +noenvvar is specified. library_names_spec='$libname$release$shared_ext$versuffix $libname$release$shared_ext$major $libname$shared_ext' soname_spec='$libname$release$shared_ext$major' if test 32 = "$HPUX_IA64_MODE"; then sys_lib_search_path_spec="/usr/lib/hpux32 /usr/local/lib/hpux32 /usr/local/lib" sys_lib_dlsearch_path_spec=/usr/lib/hpux32 else sys_lib_search_path_spec="/usr/lib/hpux64 /usr/local/lib/hpux64" sys_lib_dlsearch_path_spec=/usr/lib/hpux64 fi ;; hppa*64*) shrext_cmds='.sl' hardcode_into_libs=yes dynamic_linker="$host_os dld.sl" shlibpath_var=LD_LIBRARY_PATH # How should we handle SHLIB_PATH shlibpath_overrides_runpath=yes # Unless +noenvvar is specified. library_names_spec='$libname$release$shared_ext$versuffix $libname$release$shared_ext$major $libname$shared_ext' soname_spec='$libname$release$shared_ext$major' sys_lib_search_path_spec="/usr/lib/pa20_64 /usr/ccs/lib/pa20_64" sys_lib_dlsearch_path_spec=$sys_lib_search_path_spec ;; *) shrext_cmds='.sl' dynamic_linker="$host_os dld.sl" shlibpath_var=SHLIB_PATH shlibpath_overrides_runpath=no # +s is required to enable SHLIB_PATH library_names_spec='$libname$release$shared_ext$versuffix $libname$release$shared_ext$major $libname$shared_ext' soname_spec='$libname$release$shared_ext$major' ;; esac # HP-UX runs *really* slowly unless shared libraries are mode 555, ... postinstall_cmds='chmod 555 $lib' # or fails outright, so override atomically: install_override_mode=555 ;; interix[3-9]*) version_type=linux # correct to gnu/linux during the next big refactor need_lib_prefix=no need_version=no library_names_spec='$libname$release$shared_ext$versuffix $libname$release$shared_ext$major $libname$shared_ext' soname_spec='$libname$release$shared_ext$major' dynamic_linker='Interix 3.x ld.so.1 (PE, like ELF)' shlibpath_var=LD_LIBRARY_PATH shlibpath_overrides_runpath=no hardcode_into_libs=yes ;; irix5* | irix6* | nonstopux*) case $host_os in nonstopux*) version_type=nonstopux ;; *) if test yes = "$lt_cv_prog_gnu_ld"; then version_type=linux # correct to gnu/linux during the next big refactor else version_type=irix fi ;; esac need_lib_prefix=no need_version=no soname_spec='$libname$release$shared_ext$major' library_names_spec='$libname$release$shared_ext$versuffix $libname$release$shared_ext$major $libname$release$shared_ext $libname$shared_ext' case $host_os in irix5* | nonstopux*) libsuff= shlibsuff= ;; *) case $LD in # libtool.m4 will add one of these switches to LD *-32|*"-32 "|*-melf32bsmip|*"-melf32bsmip ") libsuff= shlibsuff= libmagic=32-bit;; *-n32|*"-n32 "|*-melf32bmipn32|*"-melf32bmipn32 ") libsuff=32 shlibsuff=N32 libmagic=N32;; *-64|*"-64 "|*-melf64bmip|*"-melf64bmip ") libsuff=64 shlibsuff=64 libmagic=64-bit;; *) libsuff= shlibsuff= libmagic=never-match;; esac ;; esac shlibpath_var=LD_LIBRARY${shlibsuff}_PATH shlibpath_overrides_runpath=no sys_lib_search_path_spec="/usr/lib$libsuff /lib$libsuff /usr/local/lib$libsuff" sys_lib_dlsearch_path_spec="/usr/lib$libsuff /lib$libsuff" hardcode_into_libs=yes ;; # No shared lib support for Linux oldld, aout, or coff. linux*oldld* | linux*aout* | linux*coff*) dynamic_linker=no ;; linux*android*) version_type=none # Android doesn't support versioned libraries. need_lib_prefix=no need_version=no library_names_spec='$libname$release$shared_ext' soname_spec='$libname$release$shared_ext' finish_cmds= shlibpath_var=LD_LIBRARY_PATH shlibpath_overrides_runpath=yes # This implies no fast_install, which is unacceptable. # Some rework will be needed to allow for fast_install # before this can be enabled. hardcode_into_libs=yes dynamic_linker='Android linker' # Don't embed -rpath directories since the linker doesn't support them. hardcode_libdir_flag_spec='-L$libdir' ;; # This must be glibc/ELF. linux* | k*bsd*-gnu | kopensolaris*-gnu | gnu*) version_type=linux # correct to gnu/linux during the next big refactor need_lib_prefix=no need_version=no library_names_spec='$libname$release$shared_ext$versuffix $libname$release$shared_ext$major $libname$shared_ext' soname_spec='$libname$release$shared_ext$major' finish_cmds='PATH="\$PATH:/sbin" ldconfig -n $libdir' shlibpath_var=LD_LIBRARY_PATH shlibpath_overrides_runpath=no # Some binutils ld are patched to set DT_RUNPATH if ${lt_cv_shlibpath_overrides_runpath+:} false; then : $as_echo_n "(cached) " >&6 else lt_cv_shlibpath_overrides_runpath=no save_LDFLAGS=$LDFLAGS save_libdir=$libdir eval "libdir=/foo; wl=\"$lt_prog_compiler_wl\"; \ LDFLAGS=\"\$LDFLAGS $hardcode_libdir_flag_spec\"" cat confdefs.h - <<_ACEOF >conftest.$ac_ext /* end confdefs.h. */ int main () { ; return 0; } _ACEOF if ac_fn_c_try_link "$LINENO"; then : if ($OBJDUMP -p conftest$ac_exeext) 2>/dev/null | grep "RUNPATH.*$libdir" >/dev/null; then : lt_cv_shlibpath_overrides_runpath=yes fi fi rm -f core conftest.err conftest.$ac_objext \ conftest$ac_exeext conftest.$ac_ext LDFLAGS=$save_LDFLAGS libdir=$save_libdir fi shlibpath_overrides_runpath=$lt_cv_shlibpath_overrides_runpath # This implies no fast_install, which is unacceptable. # Some rework will be needed to allow for fast_install # before this can be enabled. hardcode_into_libs=yes # Ideally, we could use ldconfig to report *all* directores which are # searched for libraries, however this is still not possible. Aside from not # being certain /sbin/ldconfig is available, command # 'ldconfig -N -X -v | grep ^/' on 64bit Fedora does not report /usr/lib64, # even though it is searched at run-time. Try to do the best guess by # appending ld.so.conf contents (and includes) to the search path. if test -f /etc/ld.so.conf; then lt_ld_extra=`awk '/^include / { system(sprintf("cd /etc; cat %s 2>/dev/null", \$2)); skip = 1; } { if (!skip) print \$0; skip = 0; }' < /etc/ld.so.conf | $SED -e 's/#.*//;/^[ ]*hwcap[ ]/d;s/[:, ]/ /g;s/=[^=]*$//;s/=[^= ]* / /g;s/"//g;/^$/d' | tr '\n' ' '` sys_lib_dlsearch_path_spec="/lib /usr/lib $lt_ld_extra" fi # We used to test for /lib/ld.so.1 and disable shared libraries on # powerpc, because MkLinux only supported shared libraries with the # GNU dynamic linker. Since this was broken with cross compilers, # most powerpc-linux boxes support dynamic linking these days and # people can always --disable-shared, the test was removed, and we # assume the GNU/Linux dynamic linker is in use. dynamic_linker='GNU/Linux ld.so' ;; netbsd*) version_type=sunos need_lib_prefix=no need_version=no if echo __ELF__ | $CC -E - | $GREP __ELF__ >/dev/null; then library_names_spec='$libname$release$shared_ext$versuffix $libname$shared_ext$versuffix' finish_cmds='PATH="\$PATH:/sbin" ldconfig -m $libdir' dynamic_linker='NetBSD (a.out) ld.so' else library_names_spec='$libname$release$shared_ext$versuffix $libname$release$shared_ext$major $libname$shared_ext' soname_spec='$libname$release$shared_ext$major' dynamic_linker='NetBSD ld.elf_so' fi shlibpath_var=LD_LIBRARY_PATH shlibpath_overrides_runpath=yes hardcode_into_libs=yes ;; newsos6) version_type=linux # correct to gnu/linux during the next big refactor library_names_spec='$libname$release$shared_ext$versuffix $libname$release$shared_ext$major $libname$shared_ext' shlibpath_var=LD_LIBRARY_PATH shlibpath_overrides_runpath=yes ;; *nto* | *qnx*) version_type=qnx need_lib_prefix=no need_version=no library_names_spec='$libname$release$shared_ext$versuffix $libname$release$shared_ext$major $libname$shared_ext' soname_spec='$libname$release$shared_ext$major' shlibpath_var=LD_LIBRARY_PATH shlibpath_overrides_runpath=no hardcode_into_libs=yes dynamic_linker='ldqnx.so' ;; openbsd* | bitrig*) version_type=sunos sys_lib_dlsearch_path_spec=/usr/lib need_lib_prefix=no if test -z "`echo __ELF__ | $CC -E - | $GREP __ELF__`"; then need_version=no else need_version=yes fi library_names_spec='$libname$release$shared_ext$versuffix $libname$shared_ext$versuffix' finish_cmds='PATH="\$PATH:/sbin" ldconfig -m $libdir' shlibpath_var=LD_LIBRARY_PATH shlibpath_overrides_runpath=yes ;; os2*) libname_spec='$name' version_type=windows shrext_cmds=.dll need_version=no need_lib_prefix=no # OS/2 can only load a DLL with a base name of 8 characters or less. soname_spec='`test -n "$os2dllname" && libname="$os2dllname"; v=$($ECHO $release$versuffix | tr -d .-); n=$($ECHO $libname | cut -b -$((8 - ${#v})) | tr . _); $ECHO $n$v`$shared_ext' library_names_spec='${libname}_dll.$libext' dynamic_linker='OS/2 ld.exe' shlibpath_var=BEGINLIBPATH sys_lib_search_path_spec="/lib /usr/lib /usr/local/lib" sys_lib_dlsearch_path_spec=$sys_lib_search_path_spec postinstall_cmds='base_file=`basename \$file`~ dlpath=`$SHELL 2>&1 -c '\''. $dir/'\''\$base_file'\''i; $ECHO \$dlname'\''`~ dldir=$destdir/`dirname \$dlpath`~ test -d \$dldir || mkdir -p \$dldir~ $install_prog $dir/$dlname \$dldir/$dlname~ chmod a+x \$dldir/$dlname~ if test -n '\''$stripme'\'' && test -n '\''$striplib'\''; then eval '\''$striplib \$dldir/$dlname'\'' || exit \$?; fi' postuninstall_cmds='dldll=`$SHELL 2>&1 -c '\''. $file; $ECHO \$dlname'\''`~ dlpath=$dir/\$dldll~ $RM \$dlpath' ;; osf3* | osf4* | osf5*) version_type=osf need_lib_prefix=no need_version=no soname_spec='$libname$release$shared_ext$major' library_names_spec='$libname$release$shared_ext$versuffix $libname$release$shared_ext$major $libname$shared_ext' shlibpath_var=LD_LIBRARY_PATH sys_lib_search_path_spec="/usr/shlib /usr/ccs/lib /usr/lib/cmplrs/cc /usr/lib /usr/local/lib /var/shlib" sys_lib_dlsearch_path_spec=$sys_lib_search_path_spec ;; rdos*) dynamic_linker=no ;; solaris*) version_type=linux # correct to gnu/linux during the next big refactor need_lib_prefix=no need_version=no library_names_spec='$libname$release$shared_ext$versuffix $libname$release$shared_ext$major $libname$shared_ext' soname_spec='$libname$release$shared_ext$major' shlibpath_var=LD_LIBRARY_PATH shlibpath_overrides_runpath=yes hardcode_into_libs=yes # ldd complains unless libraries are executable postinstall_cmds='chmod +x $lib' ;; sunos4*) version_type=sunos library_names_spec='$libname$release$shared_ext$versuffix $libname$shared_ext$versuffix' finish_cmds='PATH="\$PATH:/usr/etc" ldconfig $libdir' shlibpath_var=LD_LIBRARY_PATH shlibpath_overrides_runpath=yes if test yes = "$with_gnu_ld"; then need_lib_prefix=no fi need_version=yes ;; sysv4 | sysv4.3*) version_type=linux # correct to gnu/linux during the next big refactor library_names_spec='$libname$release$shared_ext$versuffix $libname$release$shared_ext$major $libname$shared_ext' soname_spec='$libname$release$shared_ext$major' shlibpath_var=LD_LIBRARY_PATH case $host_vendor in sni) shlibpath_overrides_runpath=no need_lib_prefix=no runpath_var=LD_RUN_PATH ;; siemens) need_lib_prefix=no ;; motorola) need_lib_prefix=no need_version=no shlibpath_overrides_runpath=no sys_lib_search_path_spec='/lib /usr/lib /usr/ccs/lib' ;; esac ;; sysv4*MP*) if test -d /usr/nec; then version_type=linux # correct to gnu/linux during the next big refactor library_names_spec='$libname$shared_ext.$versuffix $libname$shared_ext.$major $libname$shared_ext' soname_spec='$libname$shared_ext.$major' shlibpath_var=LD_LIBRARY_PATH fi ;; sysv5* | sco3.2v5* | sco5v6* | unixware* | OpenUNIX* | sysv4*uw2*) version_type=sco need_lib_prefix=no need_version=no library_names_spec='$libname$release$shared_ext$versuffix $libname$release$shared_ext $libname$shared_ext' soname_spec='$libname$release$shared_ext$major' shlibpath_var=LD_LIBRARY_PATH shlibpath_overrides_runpath=yes hardcode_into_libs=yes if test yes = "$with_gnu_ld"; then sys_lib_search_path_spec='/usr/local/lib /usr/gnu/lib /usr/ccs/lib /usr/lib /lib' else sys_lib_search_path_spec='/usr/ccs/lib /usr/lib' case $host_os in sco3.2v5*) sys_lib_search_path_spec="$sys_lib_search_path_spec /lib" ;; esac fi sys_lib_dlsearch_path_spec='/usr/lib' ;; tpf*) # TPF is a cross-target only. Preferred cross-host = GNU/Linux. version_type=linux # correct to gnu/linux during the next big refactor need_lib_prefix=no need_version=no library_names_spec='$libname$release$shared_ext$versuffix $libname$release$shared_ext$major $libname$shared_ext' shlibpath_var=LD_LIBRARY_PATH shlibpath_overrides_runpath=no hardcode_into_libs=yes ;; uts4*) version_type=linux # correct to gnu/linux during the next big refactor library_names_spec='$libname$release$shared_ext$versuffix $libname$release$shared_ext$major $libname$shared_ext' soname_spec='$libname$release$shared_ext$major' shlibpath_var=LD_LIBRARY_PATH ;; *) dynamic_linker=no ;; esac { $as_echo "$as_me:${as_lineno-$LINENO}: result: $dynamic_linker" >&5 $as_echo "$dynamic_linker" >&6; } test no = "$dynamic_linker" && can_build_shared=no variables_saved_for_relink="PATH $shlibpath_var $runpath_var" if test yes = "$GCC"; then variables_saved_for_relink="$variables_saved_for_relink GCC_EXEC_PREFIX COMPILER_PATH LIBRARY_PATH" fi if test set = "${lt_cv_sys_lib_search_path_spec+set}"; then sys_lib_search_path_spec=$lt_cv_sys_lib_search_path_spec fi if test set = "${lt_cv_sys_lib_dlsearch_path_spec+set}"; then sys_lib_dlsearch_path_spec=$lt_cv_sys_lib_dlsearch_path_spec fi # remember unaugmented sys_lib_dlsearch_path content for libtool script decls... configure_time_dlsearch_path=$sys_lib_dlsearch_path_spec # ... but it needs LT_SYS_LIBRARY_PATH munging for other configure-time code func_munge_path_list sys_lib_dlsearch_path_spec "$LT_SYS_LIBRARY_PATH" # to be used as default LT_SYS_LIBRARY_PATH value in generated libtool configure_time_lt_sys_library_path=$LT_SYS_LIBRARY_PATH { $as_echo "$as_me:${as_lineno-$LINENO}: checking how to hardcode library paths into programs" >&5 $as_echo_n "checking how to hardcode library paths into programs... " >&6; } hardcode_action= if test -n "$hardcode_libdir_flag_spec" || test -n "$runpath_var" || test yes = "$hardcode_automatic"; then # We can hardcode non-existent directories. if test no != "$hardcode_direct" && # If the only mechanism to avoid hardcoding is shlibpath_var, we # have to relink, otherwise we might link with an installed library # when we should be linking with a yet-to-be-installed one ## test no != "$_LT_TAGVAR(hardcode_shlibpath_var, )" && test no != "$hardcode_minus_L"; then # Linking always hardcodes the temporary library directory. hardcode_action=relink else # We can link without hardcoding, and we can hardcode nonexisting dirs. hardcode_action=immediate fi else # We cannot hardcode anything, or else we can only hardcode existing # directories. hardcode_action=unsupported fi { $as_echo "$as_me:${as_lineno-$LINENO}: result: $hardcode_action" >&5 $as_echo "$hardcode_action" >&6; } if test relink = "$hardcode_action" || test yes = "$inherit_rpath"; then # Fast installation is not supported enable_fast_install=no elif test yes = "$shlibpath_overrides_runpath" || test no = "$enable_shared"; then # Fast installation is not necessary enable_fast_install=needless fi if test yes != "$enable_dlopen"; then enable_dlopen=unknown enable_dlopen_self=unknown enable_dlopen_self_static=unknown else lt_cv_dlopen=no lt_cv_dlopen_libs= case $host_os in beos*) lt_cv_dlopen=load_add_on lt_cv_dlopen_libs= lt_cv_dlopen_self=yes ;; mingw* | pw32* | cegcc*) lt_cv_dlopen=LoadLibrary lt_cv_dlopen_libs= ;; cygwin*) lt_cv_dlopen=dlopen lt_cv_dlopen_libs= ;; darwin*) # if libdl is installed we need to link against it { $as_echo "$as_me:${as_lineno-$LINENO}: checking for dlopen in -ldl" >&5 $as_echo_n "checking for dlopen in -ldl... " >&6; } if ${ac_cv_lib_dl_dlopen+:} false; then : $as_echo_n "(cached) " >&6 else ac_check_lib_save_LIBS=$LIBS LIBS="-ldl $LIBS" cat confdefs.h - <<_ACEOF >conftest.$ac_ext /* end confdefs.h. */ /* Override any GCC internal prototype to avoid an error. Use char because int might match the return type of a GCC builtin and then its argument prototype would still apply. */ #ifdef __cplusplus extern "C" #endif char dlopen (); int main () { return dlopen (); ; return 0; } _ACEOF if ac_fn_c_try_link "$LINENO"; then : ac_cv_lib_dl_dlopen=yes else ac_cv_lib_dl_dlopen=no fi rm -f core conftest.err conftest.$ac_objext \ conftest$ac_exeext conftest.$ac_ext LIBS=$ac_check_lib_save_LIBS fi { $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_cv_lib_dl_dlopen" >&5 $as_echo "$ac_cv_lib_dl_dlopen" >&6; } if test "x$ac_cv_lib_dl_dlopen" = xyes; then : lt_cv_dlopen=dlopen lt_cv_dlopen_libs=-ldl else lt_cv_dlopen=dyld lt_cv_dlopen_libs= lt_cv_dlopen_self=yes fi ;; tpf*) # Don't try to run any link tests for TPF. We know it's impossible # because TPF is a cross-compiler, and we know how we open DSOs. lt_cv_dlopen=dlopen lt_cv_dlopen_libs= lt_cv_dlopen_self=no ;; *) ac_fn_c_check_func "$LINENO" "shl_load" "ac_cv_func_shl_load" if test "x$ac_cv_func_shl_load" = xyes; then : lt_cv_dlopen=shl_load else { $as_echo "$as_me:${as_lineno-$LINENO}: checking for shl_load in -ldld" >&5 $as_echo_n "checking for shl_load in -ldld... " >&6; } if ${ac_cv_lib_dld_shl_load+:} false; then : $as_echo_n "(cached) " >&6 else ac_check_lib_save_LIBS=$LIBS LIBS="-ldld $LIBS" cat confdefs.h - <<_ACEOF >conftest.$ac_ext /* end confdefs.h. */ /* Override any GCC internal prototype to avoid an error. Use char because int might match the return type of a GCC builtin and then its argument prototype would still apply. */ #ifdef __cplusplus extern "C" #endif char shl_load (); int main () { return shl_load (); ; return 0; } _ACEOF if ac_fn_c_try_link "$LINENO"; then : ac_cv_lib_dld_shl_load=yes else ac_cv_lib_dld_shl_load=no fi rm -f core conftest.err conftest.$ac_objext \ conftest$ac_exeext conftest.$ac_ext LIBS=$ac_check_lib_save_LIBS fi { $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_cv_lib_dld_shl_load" >&5 $as_echo "$ac_cv_lib_dld_shl_load" >&6; } if test "x$ac_cv_lib_dld_shl_load" = xyes; then : lt_cv_dlopen=shl_load lt_cv_dlopen_libs=-ldld else ac_fn_c_check_func "$LINENO" "dlopen" "ac_cv_func_dlopen" if test "x$ac_cv_func_dlopen" = xyes; then : lt_cv_dlopen=dlopen else { $as_echo "$as_me:${as_lineno-$LINENO}: checking for dlopen in -ldl" >&5 $as_echo_n "checking for dlopen in -ldl... " >&6; } if ${ac_cv_lib_dl_dlopen+:} false; then : $as_echo_n "(cached) " >&6 else ac_check_lib_save_LIBS=$LIBS LIBS="-ldl $LIBS" cat confdefs.h - <<_ACEOF >conftest.$ac_ext /* end confdefs.h. */ /* Override any GCC internal prototype to avoid an error. Use char because int might match the return type of a GCC builtin and then its argument prototype would still apply. */ #ifdef __cplusplus extern "C" #endif char dlopen (); int main () { return dlopen (); ; return 0; } _ACEOF if ac_fn_c_try_link "$LINENO"; then : ac_cv_lib_dl_dlopen=yes else ac_cv_lib_dl_dlopen=no fi rm -f core conftest.err conftest.$ac_objext \ conftest$ac_exeext conftest.$ac_ext LIBS=$ac_check_lib_save_LIBS fi { $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_cv_lib_dl_dlopen" >&5 $as_echo "$ac_cv_lib_dl_dlopen" >&6; } if test "x$ac_cv_lib_dl_dlopen" = xyes; then : lt_cv_dlopen=dlopen lt_cv_dlopen_libs=-ldl else { $as_echo "$as_me:${as_lineno-$LINENO}: checking for dlopen in -lsvld" >&5 $as_echo_n "checking for dlopen in -lsvld... " >&6; } if ${ac_cv_lib_svld_dlopen+:} false; then : $as_echo_n "(cached) " >&6 else ac_check_lib_save_LIBS=$LIBS LIBS="-lsvld $LIBS" cat confdefs.h - <<_ACEOF >conftest.$ac_ext /* end confdefs.h. */ /* Override any GCC internal prototype to avoid an error. Use char because int might match the return type of a GCC builtin and then its argument prototype would still apply. */ #ifdef __cplusplus extern "C" #endif char dlopen (); int main () { return dlopen (); ; return 0; } _ACEOF if ac_fn_c_try_link "$LINENO"; then : ac_cv_lib_svld_dlopen=yes else ac_cv_lib_svld_dlopen=no fi rm -f core conftest.err conftest.$ac_objext \ conftest$ac_exeext conftest.$ac_ext LIBS=$ac_check_lib_save_LIBS fi { $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_cv_lib_svld_dlopen" >&5 $as_echo "$ac_cv_lib_svld_dlopen" >&6; } if test "x$ac_cv_lib_svld_dlopen" = xyes; then : lt_cv_dlopen=dlopen lt_cv_dlopen_libs=-lsvld else { $as_echo "$as_me:${as_lineno-$LINENO}: checking for dld_link in -ldld" >&5 $as_echo_n "checking for dld_link in -ldld... " >&6; } if ${ac_cv_lib_dld_dld_link+:} false; then : $as_echo_n "(cached) " >&6 else ac_check_lib_save_LIBS=$LIBS LIBS="-ldld $LIBS" cat confdefs.h - <<_ACEOF >conftest.$ac_ext /* end confdefs.h. */ /* Override any GCC internal prototype to avoid an error. Use char because int might match the return type of a GCC builtin and then its argument prototype would still apply. */ #ifdef __cplusplus extern "C" #endif char dld_link (); int main () { return dld_link (); ; return 0; } _ACEOF if ac_fn_c_try_link "$LINENO"; then : ac_cv_lib_dld_dld_link=yes else ac_cv_lib_dld_dld_link=no fi rm -f core conftest.err conftest.$ac_objext \ conftest$ac_exeext conftest.$ac_ext LIBS=$ac_check_lib_save_LIBS fi { $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_cv_lib_dld_dld_link" >&5 $as_echo "$ac_cv_lib_dld_dld_link" >&6; } if test "x$ac_cv_lib_dld_dld_link" = xyes; then : lt_cv_dlopen=dld_link lt_cv_dlopen_libs=-ldld fi fi fi fi fi fi ;; esac if test no = "$lt_cv_dlopen"; then enable_dlopen=no else enable_dlopen=yes fi case $lt_cv_dlopen in dlopen) save_CPPFLAGS=$CPPFLAGS test yes = "$ac_cv_header_dlfcn_h" && CPPFLAGS="$CPPFLAGS -DHAVE_DLFCN_H" save_LDFLAGS=$LDFLAGS wl=$lt_prog_compiler_wl eval LDFLAGS=\"\$LDFLAGS $export_dynamic_flag_spec\" save_LIBS=$LIBS LIBS="$lt_cv_dlopen_libs $LIBS" { $as_echo "$as_me:${as_lineno-$LINENO}: checking whether a program can dlopen itself" >&5 $as_echo_n "checking whether a program can dlopen itself... " >&6; } if ${lt_cv_dlopen_self+:} false; then : $as_echo_n "(cached) " >&6 else if test yes = "$cross_compiling"; then : lt_cv_dlopen_self=cross else lt_dlunknown=0; lt_dlno_uscore=1; lt_dlneed_uscore=2 lt_status=$lt_dlunknown cat > conftest.$ac_ext <<_LT_EOF #line $LINENO "configure" #include "confdefs.h" #if HAVE_DLFCN_H #include #endif #include #ifdef RTLD_GLOBAL # define LT_DLGLOBAL RTLD_GLOBAL #else # ifdef DL_GLOBAL # define LT_DLGLOBAL DL_GLOBAL # else # define LT_DLGLOBAL 0 # endif #endif /* We may have to define LT_DLLAZY_OR_NOW in the command line if we find out it does not work in some platform. */ #ifndef LT_DLLAZY_OR_NOW # ifdef RTLD_LAZY # define LT_DLLAZY_OR_NOW RTLD_LAZY # else # ifdef DL_LAZY # define LT_DLLAZY_OR_NOW DL_LAZY # else # ifdef RTLD_NOW # define LT_DLLAZY_OR_NOW RTLD_NOW # else # ifdef DL_NOW # define LT_DLLAZY_OR_NOW DL_NOW # else # define LT_DLLAZY_OR_NOW 0 # endif # endif # endif # endif #endif /* When -fvisibility=hidden is used, assume the code has been annotated correspondingly for the symbols needed. */ #if defined __GNUC__ && (((__GNUC__ == 3) && (__GNUC_MINOR__ >= 3)) || (__GNUC__ > 3)) int fnord () __attribute__((visibility("default"))); #endif int fnord () { return 42; } int main () { void *self = dlopen (0, LT_DLGLOBAL|LT_DLLAZY_OR_NOW); int status = $lt_dlunknown; if (self) { if (dlsym (self,"fnord")) status = $lt_dlno_uscore; else { if (dlsym( self,"_fnord")) status = $lt_dlneed_uscore; else puts (dlerror ()); } /* dlclose (self); */ } else puts (dlerror ()); return status; } _LT_EOF if { { eval echo "\"\$as_me\":${as_lineno-$LINENO}: \"$ac_link\""; } >&5 (eval $ac_link) 2>&5 ac_status=$? $as_echo "$as_me:${as_lineno-$LINENO}: \$? = $ac_status" >&5 test $ac_status = 0; } && test -s "conftest$ac_exeext" 2>/dev/null; then (./conftest; exit; ) >&5 2>/dev/null lt_status=$? case x$lt_status in x$lt_dlno_uscore) lt_cv_dlopen_self=yes ;; x$lt_dlneed_uscore) lt_cv_dlopen_self=yes ;; x$lt_dlunknown|x*) lt_cv_dlopen_self=no ;; esac else : # compilation failed lt_cv_dlopen_self=no fi fi rm -fr conftest* fi { $as_echo "$as_me:${as_lineno-$LINENO}: result: $lt_cv_dlopen_self" >&5 $as_echo "$lt_cv_dlopen_self" >&6; } if test yes = "$lt_cv_dlopen_self"; then wl=$lt_prog_compiler_wl eval LDFLAGS=\"\$LDFLAGS $lt_prog_compiler_static\" { $as_echo "$as_me:${as_lineno-$LINENO}: checking whether a statically linked program can dlopen itself" >&5 $as_echo_n "checking whether a statically linked program can dlopen itself... " >&6; } if ${lt_cv_dlopen_self_static+:} false; then : $as_echo_n "(cached) " >&6 else if test yes = "$cross_compiling"; then : lt_cv_dlopen_self_static=cross else lt_dlunknown=0; lt_dlno_uscore=1; lt_dlneed_uscore=2 lt_status=$lt_dlunknown cat > conftest.$ac_ext <<_LT_EOF #line $LINENO "configure" #include "confdefs.h" #if HAVE_DLFCN_H #include #endif #include #ifdef RTLD_GLOBAL # define LT_DLGLOBAL RTLD_GLOBAL #else # ifdef DL_GLOBAL # define LT_DLGLOBAL DL_GLOBAL # else # define LT_DLGLOBAL 0 # endif #endif /* We may have to define LT_DLLAZY_OR_NOW in the command line if we find out it does not work in some platform. */ #ifndef LT_DLLAZY_OR_NOW # ifdef RTLD_LAZY # define LT_DLLAZY_OR_NOW RTLD_LAZY # else # ifdef DL_LAZY # define LT_DLLAZY_OR_NOW DL_LAZY # else # ifdef RTLD_NOW # define LT_DLLAZY_OR_NOW RTLD_NOW # else # ifdef DL_NOW # define LT_DLLAZY_OR_NOW DL_NOW # else # define LT_DLLAZY_OR_NOW 0 # endif # endif # endif # endif #endif /* When -fvisibility=hidden is used, assume the code has been annotated correspondingly for the symbols needed. */ #if defined __GNUC__ && (((__GNUC__ == 3) && (__GNUC_MINOR__ >= 3)) || (__GNUC__ > 3)) int fnord () __attribute__((visibility("default"))); #endif int fnord () { return 42; } int main () { void *self = dlopen (0, LT_DLGLOBAL|LT_DLLAZY_OR_NOW); int status = $lt_dlunknown; if (self) { if (dlsym (self,"fnord")) status = $lt_dlno_uscore; else { if (dlsym( self,"_fnord")) status = $lt_dlneed_uscore; else puts (dlerror ()); } /* dlclose (self); */ } else puts (dlerror ()); return status; } _LT_EOF if { { eval echo "\"\$as_me\":${as_lineno-$LINENO}: \"$ac_link\""; } >&5 (eval $ac_link) 2>&5 ac_status=$? $as_echo "$as_me:${as_lineno-$LINENO}: \$? = $ac_status" >&5 test $ac_status = 0; } && test -s "conftest$ac_exeext" 2>/dev/null; then (./conftest; exit; ) >&5 2>/dev/null lt_status=$? case x$lt_status in x$lt_dlno_uscore) lt_cv_dlopen_self_static=yes ;; x$lt_dlneed_uscore) lt_cv_dlopen_self_static=yes ;; x$lt_dlunknown|x*) lt_cv_dlopen_self_static=no ;; esac else : # compilation failed lt_cv_dlopen_self_static=no fi fi rm -fr conftest* fi { $as_echo "$as_me:${as_lineno-$LINENO}: result: $lt_cv_dlopen_self_static" >&5 $as_echo "$lt_cv_dlopen_self_static" >&6; } fi CPPFLAGS=$save_CPPFLAGS LDFLAGS=$save_LDFLAGS LIBS=$save_LIBS ;; esac case $lt_cv_dlopen_self in yes|no) enable_dlopen_self=$lt_cv_dlopen_self ;; *) enable_dlopen_self=unknown ;; esac case $lt_cv_dlopen_self_static in yes|no) enable_dlopen_self_static=$lt_cv_dlopen_self_static ;; *) enable_dlopen_self_static=unknown ;; esac fi striplib= old_striplib= { $as_echo "$as_me:${as_lineno-$LINENO}: checking whether stripping libraries is possible" >&5 $as_echo_n "checking whether stripping libraries is possible... " >&6; } if test -n "$STRIP" && $STRIP -V 2>&1 | $GREP "GNU strip" >/dev/null; then test -z "$old_striplib" && old_striplib="$STRIP --strip-debug" test -z "$striplib" && striplib="$STRIP --strip-unneeded" { $as_echo "$as_me:${as_lineno-$LINENO}: result: yes" >&5 $as_echo "yes" >&6; } else # FIXME - insert some real tests, host_os isn't really good enough case $host_os in darwin*) if test -n "$STRIP"; then striplib="$STRIP -x" old_striplib="$STRIP -S" { $as_echo "$as_me:${as_lineno-$LINENO}: result: yes" >&5 $as_echo "yes" >&6; } else { $as_echo "$as_me:${as_lineno-$LINENO}: result: no" >&5 $as_echo "no" >&6; } fi ;; *) { $as_echo "$as_me:${as_lineno-$LINENO}: result: no" >&5 $as_echo "no" >&6; } ;; esac fi # Report what library types will actually be built { $as_echo "$as_me:${as_lineno-$LINENO}: checking if libtool supports shared libraries" >&5 $as_echo_n "checking if libtool supports shared libraries... " >&6; } { $as_echo "$as_me:${as_lineno-$LINENO}: result: $can_build_shared" >&5 $as_echo "$can_build_shared" >&6; } { $as_echo "$as_me:${as_lineno-$LINENO}: checking whether to build shared libraries" >&5 $as_echo_n "checking whether to build shared libraries... " >&6; } test no = "$can_build_shared" && enable_shared=no # On AIX, shared libraries and static libraries use the same namespace, and # are all built from PIC. case $host_os in aix3*) test yes = "$enable_shared" && enable_static=no if test -n "$RANLIB"; then archive_cmds="$archive_cmds~\$RANLIB \$lib" postinstall_cmds='$RANLIB $lib' fi ;; aix[4-9]*) if test ia64 != "$host_cpu"; then case $enable_shared,$with_aix_soname,$aix_use_runtimelinking in yes,aix,yes) ;; # shared object as lib.so file only yes,svr4,*) ;; # shared object as lib.so archive member only yes,*) enable_static=no ;; # shared object in lib.a archive as well esac fi ;; esac { $as_echo "$as_me:${as_lineno-$LINENO}: result: $enable_shared" >&5 $as_echo "$enable_shared" >&6; } { $as_echo "$as_me:${as_lineno-$LINENO}: checking whether to build static libraries" >&5 $as_echo_n "checking whether to build static libraries... " >&6; } # Make sure either enable_shared or enable_static is yes. test yes = "$enable_shared" || enable_static=yes { $as_echo "$as_me:${as_lineno-$LINENO}: result: $enable_static" >&5 $as_echo "$enable_static" >&6; } fi ac_ext=c ac_cpp='$CPP $CPPFLAGS' ac_compile='$CC -c $CFLAGS $CPPFLAGS conftest.$ac_ext >&5' ac_link='$CC -o conftest$ac_exeext $CFLAGS $CPPFLAGS $LDFLAGS conftest.$ac_ext $LIBS >&5' ac_compiler_gnu=$ac_cv_c_compiler_gnu CC=$lt_save_CC ac_config_commands="$ac_config_commands libtool" # Only expand once: if test "x$ac_cv_env_PKG_CONFIG_set" != "xset"; then if test -n "$ac_tool_prefix"; then # Extract the first word of "${ac_tool_prefix}pkg-config", so it can be a program name with args. set dummy ${ac_tool_prefix}pkg-config; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } if ${ac_cv_path_PKG_CONFIG+:} false; then : $as_echo_n "(cached) " >&6 else case $PKG_CONFIG in [\\/]* | ?:[\\/]*) ac_cv_path_PKG_CONFIG="$PKG_CONFIG" # Let the user override the test with a path. ;; *) as_save_IFS=$IFS; IFS=$PATH_SEPARATOR for as_dir in $PATH do IFS=$as_save_IFS test -z "$as_dir" && as_dir=. for ac_exec_ext in '' $ac_executable_extensions; do if as_fn_executable_p "$as_dir/$ac_word$ac_exec_ext"; then ac_cv_path_PKG_CONFIG="$as_dir/$ac_word$ac_exec_ext" $as_echo "$as_me:${as_lineno-$LINENO}: found $as_dir/$ac_word$ac_exec_ext" >&5 break 2 fi done done IFS=$as_save_IFS ;; esac fi PKG_CONFIG=$ac_cv_path_PKG_CONFIG if test -n "$PKG_CONFIG"; then { $as_echo "$as_me:${as_lineno-$LINENO}: result: $PKG_CONFIG" >&5 $as_echo "$PKG_CONFIG" >&6; } else { $as_echo "$as_me:${as_lineno-$LINENO}: result: no" >&5 $as_echo "no" >&6; } fi fi if test -z "$ac_cv_path_PKG_CONFIG"; then ac_pt_PKG_CONFIG=$PKG_CONFIG # Extract the first word of "pkg-config", so it can be a program name with args. set dummy pkg-config; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } if ${ac_cv_path_ac_pt_PKG_CONFIG+:} false; then : $as_echo_n "(cached) " >&6 else case $ac_pt_PKG_CONFIG in [\\/]* | ?:[\\/]*) ac_cv_path_ac_pt_PKG_CONFIG="$ac_pt_PKG_CONFIG" # Let the user override the test with a path. ;; *) as_save_IFS=$IFS; IFS=$PATH_SEPARATOR for as_dir in $PATH do IFS=$as_save_IFS test -z "$as_dir" && as_dir=. for ac_exec_ext in '' $ac_executable_extensions; do if as_fn_executable_p "$as_dir/$ac_word$ac_exec_ext"; then ac_cv_path_ac_pt_PKG_CONFIG="$as_dir/$ac_word$ac_exec_ext" $as_echo "$as_me:${as_lineno-$LINENO}: found $as_dir/$ac_word$ac_exec_ext" >&5 break 2 fi done done IFS=$as_save_IFS ;; esac fi ac_pt_PKG_CONFIG=$ac_cv_path_ac_pt_PKG_CONFIG if test -n "$ac_pt_PKG_CONFIG"; then { $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_pt_PKG_CONFIG" >&5 $as_echo "$ac_pt_PKG_CONFIG" >&6; } else { $as_echo "$as_me:${as_lineno-$LINENO}: result: no" >&5 $as_echo "no" >&6; } fi if test "x$ac_pt_PKG_CONFIG" = x; then PKG_CONFIG="" else case $cross_compiling:$ac_tool_warned in yes:) { $as_echo "$as_me:${as_lineno-$LINENO}: WARNING: using cross tools not prefixed with host triplet" >&5 $as_echo "$as_me: WARNING: using cross tools not prefixed with host triplet" >&2;} ac_tool_warned=yes ;; esac PKG_CONFIG=$ac_pt_PKG_CONFIG fi else PKG_CONFIG="$ac_cv_path_PKG_CONFIG" fi fi if test -n "$PKG_CONFIG"; then _pkg_min_version=0.9.0 { $as_echo "$as_me:${as_lineno-$LINENO}: checking pkg-config is at least version $_pkg_min_version" >&5 $as_echo_n "checking pkg-config is at least version $_pkg_min_version... " >&6; } if $PKG_CONFIG --atleast-pkgconfig-version $_pkg_min_version; then { $as_echo "$as_me:${as_lineno-$LINENO}: result: yes" >&5 $as_echo "yes" >&6; } else { $as_echo "$as_me:${as_lineno-$LINENO}: result: no" >&5 $as_echo "no" >&6; } PKG_CONFIG="" fi fi if test "x$PKG_CONFIG" = "x"; then as_fn_error $? "please install pkg-config" "$LINENO" 5 fi subdirs="$subdirs libpainter librfxcodec" # Use silent rules by default if supported by Automake # Check whether --enable-silent-rules was given. if test "${enable_silent_rules+set}" = set; then : enableval=$enable_silent_rules; fi case $enable_silent_rules in # ((( yes) AM_DEFAULT_VERBOSITY=0;; no) AM_DEFAULT_VERBOSITY=1;; *) AM_DEFAULT_VERBOSITY=0;; esac am_make=${MAKE-make} { $as_echo "$as_me:${as_lineno-$LINENO}: checking whether $am_make supports nested variables" >&5 $as_echo_n "checking whether $am_make supports nested variables... " >&6; } if ${am_cv_make_support_nested_variables+:} false; then : $as_echo_n "(cached) " >&6 else if $as_echo 'TRUE=$(BAR$(V)) BAR0=false BAR1=true V=1 am__doit: @$(TRUE) .PHONY: am__doit' | $am_make -f - >/dev/null 2>&1; then am_cv_make_support_nested_variables=yes else am_cv_make_support_nested_variables=no fi fi { $as_echo "$as_me:${as_lineno-$LINENO}: result: $am_cv_make_support_nested_variables" >&5 $as_echo "$am_cv_make_support_nested_variables" >&6; } if test $am_cv_make_support_nested_variables = yes; then AM_V='$(V)' AM_DEFAULT_V='$(AM_DEFAULT_VERBOSITY)' else AM_V=$AM_DEFAULT_VERBOSITY AM_DEFAULT_V=$AM_DEFAULT_VERBOSITY fi AM_BACKSLASH='\' ac_ext=c ac_cpp='$CPP $CPPFLAGS' ac_compile='$CC -c $CFLAGS $CPPFLAGS conftest.$ac_ext >&5' ac_link='$CC -o conftest$ac_exeext $CFLAGS $CPPFLAGS $LDFLAGS conftest.$ac_ext $LIBS >&5' ac_compiler_gnu=$ac_cv_c_compiler_gnu { $as_echo "$as_me:${as_lineno-$LINENO}: checking CFLAGS for maximum warnings" >&5 $as_echo_n "checking CFLAGS for maximum warnings... " >&6; } if ${ac_cv_cflags_warn_all+:} false; then : $as_echo_n "(cached) " >&6 else ac_cv_cflags_warn_all="no, unknown" ac_save_CFLAGS="$CFLAGS" for ac_arg in "-warn all % -warn all" "-pedantic % -Wall" "-xstrconst % -v" "-std1 % -verbose -w0 -warnprotos" "-qlanglvl=ansi % -qsrcmsg -qinfo=all:noppt:noppc:noobs:nocnd" "-ansi -ansiE % -fullwarn" "+ESlit % +w1" "-Xc % -pvctl,fullmsg" "-h conform % -h msglevel 2" # do CFLAGS="$ac_save_CFLAGS "`echo $ac_arg | sed -e 's,%%.*,,' -e 's,%,,'` cat confdefs.h - <<_ACEOF >conftest.$ac_ext /* end confdefs.h. */ int main () { ; return 0; } _ACEOF if ac_fn_c_try_compile "$LINENO"; then : ac_cv_cflags_warn_all=`echo $ac_arg | sed -e 's,.*% *,,'` ; break fi rm -f core conftest.err conftest.$ac_objext conftest.$ac_ext done CFLAGS="$ac_save_CFLAGS" fi { $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_cv_cflags_warn_all" >&5 $as_echo "$ac_cv_cflags_warn_all" >&6; } case ".$ac_cv_cflags_warn_all" in .ok|.ok,*) ;; .|.no|.no,*) ;; *) if ${CFLAGS+:} false; then : case " $CFLAGS " in #( *" $ac_cv_cflags_warn_all "*) : { { $as_echo "$as_me:${as_lineno-$LINENO}: : CFLAGS already contains \$ac_cv_cflags_warn_all"; } >&5 (: CFLAGS already contains $ac_cv_cflags_warn_all) 2>&5 ac_status=$? $as_echo "$as_me:${as_lineno-$LINENO}: \$? = $ac_status" >&5 test $ac_status = 0; } ;; #( *) : as_fn_append CFLAGS " $ac_cv_cflags_warn_all" { { $as_echo "$as_me:${as_lineno-$LINENO}: : CFLAGS=\"\$CFLAGS\""; } >&5 (: CFLAGS="$CFLAGS") 2>&5 ac_status=$? $as_echo "$as_me:${as_lineno-$LINENO}: \$? = $ac_status" >&5 test $ac_status = 0; } ;; esac else CFLAGS=$ac_cv_cflags_warn_all { { $as_echo "$as_me:${as_lineno-$LINENO}: : CFLAGS=\"\$CFLAGS\""; } >&5 (: CFLAGS="$CFLAGS") 2>&5 ac_status=$? $as_echo "$as_me:${as_lineno-$LINENO}: \$? = $ac_status" >&5 test $ac_status = 0; } fi ;; esac ac_ext=c ac_cpp='$CPP $CPPFLAGS' ac_compile='$CC -c $CFLAGS $CPPFLAGS conftest.$ac_ext >&5' ac_link='$CC -o conftest$ac_exeext $CFLAGS $CPPFLAGS $LDFLAGS conftest.$ac_ext $LIBS >&5' ac_compiler_gnu=$ac_cv_c_compiler_gnu for flag in -Wwrite-strings; do as_CACHEVAR=`$as_echo "ax_cv_check_cflags__$flag" | $as_tr_sh` { $as_echo "$as_me:${as_lineno-$LINENO}: checking whether C compiler accepts $flag" >&5 $as_echo_n "checking whether C compiler accepts $flag... " >&6; } if eval \${$as_CACHEVAR+:} false; then : $as_echo_n "(cached) " >&6 else ax_check_save_flags=$CFLAGS CFLAGS="$CFLAGS $flag" cat confdefs.h - <<_ACEOF >conftest.$ac_ext /* end confdefs.h. */ int main () { ; return 0; } _ACEOF if ac_fn_c_try_compile "$LINENO"; then : eval "$as_CACHEVAR=yes" else eval "$as_CACHEVAR=no" fi rm -f core conftest.err conftest.$ac_objext conftest.$ac_ext CFLAGS=$ax_check_save_flags fi eval ac_res=\$$as_CACHEVAR { $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_res" >&5 $as_echo "$ac_res" >&6; } if eval test \"x\$"$as_CACHEVAR"\" = x"yes"; then : if ${CFLAGS+:} false; then : case " $CFLAGS " in #( *" $flag "*) : { { $as_echo "$as_me:${as_lineno-$LINENO}: : CFLAGS already contains \$flag"; } >&5 (: CFLAGS already contains $flag) 2>&5 ac_status=$? $as_echo "$as_me:${as_lineno-$LINENO}: \$? = $ac_status" >&5 test $ac_status = 0; } ;; #( *) : as_fn_append CFLAGS " $flag" { { $as_echo "$as_me:${as_lineno-$LINENO}: : CFLAGS=\"\$CFLAGS\""; } >&5 (: CFLAGS="$CFLAGS") 2>&5 ac_status=$? $as_echo "$as_me:${as_lineno-$LINENO}: \$? = $ac_status" >&5 test $ac_status = 0; } ;; esac else CFLAGS=$flag { { $as_echo "$as_me:${as_lineno-$LINENO}: : CFLAGS=\"\$CFLAGS\""; } >&5 (: CFLAGS="$CFLAGS") 2>&5 ac_status=$? $as_echo "$as_me:${as_lineno-$LINENO}: \$? = $ac_status" >&5 test $ac_status = 0; } fi else : fi done { $as_echo "$as_me:${as_lineno-$LINENO}: checking for __attribute__((format))" >&5 $as_echo_n "checking for __attribute__((format))... " >&6; } if ${ax_cv_have_func_attribute_format+:} false; then : $as_echo_n "(cached) " >&6 else cat confdefs.h - <<_ACEOF >conftest.$ac_ext /* end confdefs.h. */ int foo(const char *p, ...) __attribute__((format(printf, 1, 2))); int main () { ; return 0; } _ACEOF if ac_fn_c_try_link "$LINENO"; then : if test -s conftest.err; then : ax_cv_have_func_attribute_format=no else ax_cv_have_func_attribute_format=yes fi else ax_cv_have_func_attribute_format=no fi rm -f core conftest.err conftest.$ac_objext \ conftest$ac_exeext conftest.$ac_ext fi { $as_echo "$as_me:${as_lineno-$LINENO}: result: $ax_cv_have_func_attribute_format" >&5 $as_echo "$ax_cv_have_func_attribute_format" >&6; } if test yes = $ax_cv_have_func_attribute_format; then : cat >>confdefs.h <<_ACEOF #define HAVE_FUNC_ATTRIBUTE_FORMAT 1 _ACEOF fi { $as_echo "$as_me:${as_lineno-$LINENO}: checking for socklen_t" >&5 $as_echo_n "checking for socklen_t... " >&6; } if ${ac_cv_ax_type_socklen_t+:} false; then : $as_echo_n "(cached) " >&6 else cat confdefs.h - <<_ACEOF >conftest.$ac_ext /* end confdefs.h. */ #include #include int main () { socklen_t len = (socklen_t) 42; return (!len); ; return 0; } _ACEOF if ac_fn_c_try_compile "$LINENO"; then : ac_cv_ax_type_socklen_t=yes else ac_cv_ax_type_socklen_t=no fi rm -f core conftest.err conftest.$ac_objext conftest.$ac_ext fi { $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_cv_ax_type_socklen_t" >&5 $as_echo "$ac_cv_ax_type_socklen_t" >&6; } if test $ac_cv_ax_type_socklen_t != yes; then $as_echo "#define socklen_t int" >>confdefs.h fi case $host_os in *linux*) linux=yes ;; *kfreebsd*) linux=yes # only used in instfiles/ so that’s ok for us for now ;; *freebsd*) freebsd=yes ;; *netbsd*) netbsd=yes ;; *openbsd*) openbsd=yes ;; esac if test "x$linux" = xyes; then LINUX_TRUE= LINUX_FALSE='#' else LINUX_TRUE='#' LINUX_FALSE= fi if test "x$freebsd" = xyes; then FREEBSD_TRUE= FREEBSD_FALSE='#' else FREEBSD_TRUE='#' FREEBSD_FALSE= fi if test "x$openbsd" = xyes; then OPENBSD_TRUE= OPENBSD_FALSE='#' else OPENBSD_TRUE='#' OPENBSD_FALSE= fi if test "x$netbsd" = xyes; then NETBSD_TRUE= NETBSD_FALSE='#' else NETBSD_TRUE='#' NETBSD_FALSE= fi # Check whether --with-socketdir was given. if test "${with_socketdir+set}" = set; then : withval=$with_socketdir; else with_socketdir="/tmp/.xrdp" fi socketdir=$with_socketdir # Check whether --with-systemdsystemunitdir was given. if test "${with_systemdsystemunitdir+set}" = set; then : withval=$with_systemdsystemunitdir; else if test "x$linux" = xyes; then with_systemdsystemunitdir=$($PKG_CONFIG --variable=systemdsystemunitdir systemd) fi fi if test "x$with_systemdsystemunitdir" != xno; then systemdsystemunitdir=$with_systemdsystemunitdir fi if test -n "$with_systemdsystemunitdir" -a "x$with_systemdsystemunitdir" != xno ; then HAVE_SYSTEMD_TRUE= HAVE_SYSTEMD_FALSE='#' else HAVE_SYSTEMD_TRUE='#' HAVE_SYSTEMD_FALSE= fi # Check whether --enable-pam was given. if test "${enable_pam+set}" = set; then : enableval=$enable_pam; else enable_pam=yes fi if test x$enable_pam != xyes; then SESMAN_NOPAM_TRUE= SESMAN_NOPAM_FALSE='#' else SESMAN_NOPAM_TRUE='#' SESMAN_NOPAM_FALSE= fi # Check whether --enable-vsock was given. if test "${enable_vsock+set}" = set; then : enableval=$enable_vsock; else enable_vsock=no fi # Check whether --enable-ipv6 was given. if test "${enable_ipv6+set}" = set; then : enableval=$enable_ipv6; else enable_ipv6=no fi # Check whether --enable-ipv6only was given. if test "${enable_ipv6only+set}" = set; then : enableval=$enable_ipv6only; else enable_ipv6only=no fi # Check whether --enable-kerberos was given. if test "${enable_kerberos+set}" = set; then : enableval=$enable_kerberos; else enable_kerberos=no fi # Check whether --enable-bsd was given. if test "${enable_bsd+set}" = set; then : enableval=$enable_bsd; bsd=true else bsd=false fi if test x$bsd = xtrue; then SESMAN_BSD_TRUE= SESMAN_BSD_FALSE='#' else SESMAN_BSD_TRUE='#' SESMAN_BSD_FALSE= fi if test x$enable_kerberos = xyes; then SESMAN_KERBEROS_TRUE= SESMAN_KERBEROS_FALSE='#' else SESMAN_KERBEROS_TRUE='#' SESMAN_KERBEROS_FALSE= fi # Check whether --enable-pamuserpass was given. if test "${enable_pamuserpass+set}" = set; then : enableval=$enable_pamuserpass; else enable_pamuserpass=no fi if test x$enable_pamuserpass = xyes; then SESMAN_PAMUSERPASS_TRUE= SESMAN_PAMUSERPASS_FALSE='#' else SESMAN_PAMUSERPASS_TRUE='#' SESMAN_PAMUSERPASS_FALSE= fi # Check whether --enable-pam-config was given. if test "${enable_pam_config+set}" = set; then : enableval=$enable_pam_config; fi # Check whether --enable-xrdpdebug was given. if test "${enable_xrdpdebug+set}" = set; then : enableval=$enable_xrdpdebug; else enable_xrdpdebug=no fi if test x$enable_xrdpdebug = xyes; then XRDP_DEBUG_TRUE= XRDP_DEBUG_FALSE='#' else XRDP_DEBUG_TRUE='#' XRDP_DEBUG_FALSE= fi # Check whether --enable-neutrinordp was given. if test "${enable_neutrinordp+set}" = set; then : enableval=$enable_neutrinordp; else enable_neutrinordp=no fi if test x$enable_neutrinordp = xyes; then XRDP_NEUTRINORDP_TRUE= XRDP_NEUTRINORDP_FALSE='#' else XRDP_NEUTRINORDP_TRUE='#' XRDP_NEUTRINORDP_FALSE= fi # Check whether --enable-jpeg was given. if test "${enable_jpeg+set}" = set; then : enableval=$enable_jpeg; else enable_jpeg=no fi if test x$enable_jpeg = xyes; then XRDP_JPEG_TRUE= XRDP_JPEG_FALSE='#' else XRDP_JPEG_TRUE='#' XRDP_JPEG_FALSE= fi # Check whether --enable-tjpeg was given. if test "${enable_tjpeg+set}" = set; then : enableval=$enable_tjpeg; else enable_tjpeg=no fi if test x$enable_tjpeg = xyes; then XRDP_TJPEG_TRUE= XRDP_TJPEG_FALSE='#' else XRDP_TJPEG_TRUE='#' XRDP_TJPEG_FALSE= fi # Check whether --enable-fuse was given. if test "${enable_fuse+set}" = set; then : enableval=$enable_fuse; else enable_fuse=no fi if test x$enable_fuse = xyes; then XRDP_FUSE_TRUE= XRDP_FUSE_FALSE='#' else XRDP_FUSE_TRUE='#' XRDP_FUSE_FALSE= fi # Check whether --enable-xrdpvr was given. if test "${enable_xrdpvr+set}" = set; then : enableval=$enable_xrdpvr; else enable_xrdpvr=no fi if test x$enable_xrdpvr = xyes; then XRDP_XRDPVR_TRUE= XRDP_XRDPVR_FALSE='#' else XRDP_XRDPVR_TRUE='#' XRDP_XRDPVR_FALSE= fi # Check whether --enable-fdkaac was given. if test "${enable_fdkaac+set}" = set; then : enableval=$enable_fdkaac; else enable_fdkaac=no fi if test x$enable_fdkaac = xyes; then XRDP_FDK_AAC_TRUE= XRDP_FDK_AAC_FALSE='#' else XRDP_FDK_AAC_TRUE='#' XRDP_FDK_AAC_FALSE= fi # Check whether --enable-opus was given. if test "${enable_opus+set}" = set; then : enableval=$enable_opus; else enable_opus=no fi if test x$enable_opus = xyes; then XRDP_OPUS_TRUE= XRDP_OPUS_FALSE='#' else XRDP_OPUS_TRUE='#' XRDP_OPUS_FALSE= fi # Check whether --enable-mp3lame was given. if test "${enable_mp3lame+set}" = set; then : enableval=$enable_mp3lame; else enable_mp3lame=no fi if test x$enable_mp3lame = xyes; then XRDP_MP3LAME_TRUE= XRDP_MP3LAME_FALSE='#' else XRDP_MP3LAME_TRUE='#' XRDP_MP3LAME_FALSE= fi # Check whether --enable-pixman was given. if test "${enable_pixman+set}" = set; then : enableval=$enable_pixman; else enable_pixman=no fi if test x$enable_pixman = xyes; then XRDP_PIXMAN_TRUE= XRDP_PIXMAN_FALSE='#' else XRDP_PIXMAN_TRUE='#' XRDP_PIXMAN_FALSE= fi # Check whether --enable-painter was given. if test "${enable_painter+set}" = set; then : enableval=$enable_painter; else enable_painter=yes fi if test x$enable_painter = xyes; then XRDP_PAINTER_TRUE= XRDP_PAINTER_FALSE='#' else XRDP_PAINTER_TRUE='#' XRDP_PAINTER_FALSE= fi # Check whether --enable-rfxcodec was given. if test "${enable_rfxcodec+set}" = set; then : enableval=$enable_rfxcodec; else enable_rfxcodec=yes fi if test x$enable_rfxcodec = xyes; then XRDP_RFXCODEC_TRUE= XRDP_RFXCODEC_FALSE='#' else XRDP_RFXCODEC_TRUE='#' XRDP_RFXCODEC_FALSE= fi # Don't fail without working nasm if rfxcodec is not enabled if test "x$enable_rfxcodec" != xyes; then with_simd=no export with_simd fi # Check if -ldl is needed to use dlopen() DLOPEN_LIBS= ac_fn_c_check_func "$LINENO" "dlopen" "ac_cv_func_dlopen" if test "x$ac_cv_func_dlopen" = xyes; then : else { $as_echo "$as_me:${as_lineno-$LINENO}: checking for dlopen in -ldl" >&5 $as_echo_n "checking for dlopen in -ldl... " >&6; } if ${ac_cv_lib_dl_dlopen+:} false; then : $as_echo_n "(cached) " >&6 else ac_check_lib_save_LIBS=$LIBS LIBS="-ldl $LIBS" cat confdefs.h - <<_ACEOF >conftest.$ac_ext /* end confdefs.h. */ /* Override any GCC internal prototype to avoid an error. Use char because int might match the return type of a GCC builtin and then its argument prototype would still apply. */ #ifdef __cplusplus extern "C" #endif char dlopen (); int main () { return dlopen (); ; return 0; } _ACEOF if ac_fn_c_try_link "$LINENO"; then : ac_cv_lib_dl_dlopen=yes else ac_cv_lib_dl_dlopen=no fi rm -f core conftest.err conftest.$ac_objext \ conftest$ac_exeext conftest.$ac_ext LIBS=$ac_check_lib_save_LIBS fi { $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_cv_lib_dl_dlopen" >&5 $as_echo "$ac_cv_lib_dl_dlopen" >&6; } if test "x$ac_cv_lib_dl_dlopen" = xyes; then : DLOPEN_LIBS=-ldl fi fi # checking for openssl pkg_failed=no { $as_echo "$as_me:${as_lineno-$LINENO}: checking for OPENSSL" >&5 $as_echo_n "checking for OPENSSL... " >&6; } if test -n "$OPENSSL_CFLAGS"; then pkg_cv_OPENSSL_CFLAGS="$OPENSSL_CFLAGS" elif test -n "$PKG_CONFIG"; then if test -n "$PKG_CONFIG" && \ { { $as_echo "$as_me:${as_lineno-$LINENO}: \$PKG_CONFIG --exists --print-errors \"openssl >= 0.9.8\""; } >&5 ($PKG_CONFIG --exists --print-errors "openssl >= 0.9.8") 2>&5 ac_status=$? $as_echo "$as_me:${as_lineno-$LINENO}: \$? = $ac_status" >&5 test $ac_status = 0; }; then pkg_cv_OPENSSL_CFLAGS=`$PKG_CONFIG --cflags "openssl >= 0.9.8" 2>/dev/null` test "x$?" != "x0" && pkg_failed=yes else pkg_failed=yes fi else pkg_failed=untried fi if test -n "$OPENSSL_LIBS"; then pkg_cv_OPENSSL_LIBS="$OPENSSL_LIBS" elif test -n "$PKG_CONFIG"; then if test -n "$PKG_CONFIG" && \ { { $as_echo "$as_me:${as_lineno-$LINENO}: \$PKG_CONFIG --exists --print-errors \"openssl >= 0.9.8\""; } >&5 ($PKG_CONFIG --exists --print-errors "openssl >= 0.9.8") 2>&5 ac_status=$? $as_echo "$as_me:${as_lineno-$LINENO}: \$? = $ac_status" >&5 test $ac_status = 0; }; then pkg_cv_OPENSSL_LIBS=`$PKG_CONFIG --libs "openssl >= 0.9.8" 2>/dev/null` test "x$?" != "x0" && pkg_failed=yes else pkg_failed=yes fi else pkg_failed=untried fi if test $pkg_failed = yes; then { $as_echo "$as_me:${as_lineno-$LINENO}: result: no" >&5 $as_echo "no" >&6; } if $PKG_CONFIG --atleast-pkgconfig-version 0.20; then _pkg_short_errors_supported=yes else _pkg_short_errors_supported=no fi if test $_pkg_short_errors_supported = yes; then OPENSSL_PKG_ERRORS=`$PKG_CONFIG --short-errors --print-errors --cflags --libs "openssl >= 0.9.8" 2>&1` else OPENSSL_PKG_ERRORS=`$PKG_CONFIG --print-errors --cflags --libs "openssl >= 0.9.8" 2>&1` fi # Put the nasty error message in config.log where it belongs echo "$OPENSSL_PKG_ERRORS" >&5 as_fn_error $? "please install libssl-dev or openssl-devel" "$LINENO" 5 elif test $pkg_failed = untried; then { $as_echo "$as_me:${as_lineno-$LINENO}: result: no" >&5 $as_echo "no" >&6; } as_fn_error $? "please install libssl-dev or openssl-devel" "$LINENO" 5 else OPENSSL_CFLAGS=$pkg_cv_OPENSSL_CFLAGS OPENSSL_LIBS=$pkg_cv_OPENSSL_LIBS { $as_echo "$as_me:${as_lineno-$LINENO}: result: yes" >&5 $as_echo "yes" >&6; } fi # look for openssl binary OPENSSL_BIN=`$PKG_CONFIG --variable=exec_prefix openssl`/bin for ac_prog in openssl do # Extract the first word of "$ac_prog", so it can be a program name with args. set dummy $ac_prog; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } if ${ac_cv_path_OPENSSL+:} false; then : $as_echo_n "(cached) " >&6 else case $OPENSSL in [\\/]* | ?:[\\/]*) ac_cv_path_OPENSSL="$OPENSSL" # Let the user override the test with a path. ;; *) as_save_IFS=$IFS; IFS=$PATH_SEPARATOR as_dummy="$OPENSSL_BIN:$PATH" for as_dir in $as_dummy do IFS=$as_save_IFS test -z "$as_dir" && as_dir=. for ac_exec_ext in '' $ac_executable_extensions; do if as_fn_executable_p "$as_dir/$ac_word$ac_exec_ext"; then ac_cv_path_OPENSSL="$as_dir/$ac_word$ac_exec_ext" $as_echo "$as_me:${as_lineno-$LINENO}: found $as_dir/$ac_word$ac_exec_ext" >&5 break 2 fi done done IFS=$as_save_IFS ;; esac fi OPENSSL=$ac_cv_path_OPENSSL if test -n "$OPENSSL"; then { $as_echo "$as_me:${as_lineno-$LINENO}: result: $OPENSSL" >&5 $as_echo "$OPENSSL" >&6; } else { $as_echo "$as_me:${as_lineno-$LINENO}: result: no" >&5 $as_echo "no" >&6; } fi test -n "$OPENSSL" && break done test -n "$OPENSSL" || OPENSSL=":" # checking for pam variation # Linux-PAM is used in Linux systems # OpenPAM is used by FreeBSD, NetBSD, DragonFly BSD and OS X # OpenBSD uses BSD Authentication rather than both PAMs ac_fn_c_check_header_mongrel "$LINENO" "security/_pam_types.h" "ac_cv_header_security__pam_types_h" "$ac_includes_default" if test "x$ac_cv_header_security__pam_types_h" = xyes; then : $as_echo "#define HAVE__PAM_TYPES_H 1" >>confdefs.h fi ac_fn_c_check_header_mongrel "$LINENO" "security/pam_constants.h" "ac_cv_header_security_pam_constants_h" "$ac_includes_default" if test "x$ac_cv_header_security_pam_constants_h" = xyes; then : $as_echo "#define HAVE_PAM_CONSTANTS_H 1" >>confdefs.h fi # checking if pam should be autodetected. if test "x$enable_pam" = "xyes" then if test "x$enable_kerberos" != "xyes" then if test -z "$enable_bsd" then ac_fn_c_check_header_mongrel "$LINENO" "security/pam_appl.h" "ac_cv_header_security_pam_appl_h" "$ac_includes_default" if test "x$ac_cv_header_security_pam_appl_h" = xyes; then : else as_fn_error $? "please install libpam0g-dev or pam-devel" "$LINENO" 5 fi fi fi if test "x$enable_pam_config" = "x"; then PAM_RULES="auto" else pam_config_file="$srcdir/instfiles/pam.d/xrdp-sesman.$enable_pam_config" if test -f "$pam_config_file"; then PAM_RULES="$enable_pam_config" else as_fn_error $? "PAM file \"$pam_config_file\" is not available" "$LINENO" 5 fi fi fi if test "x$enable_vsock" = "xyes" then enable_vsock=yes for ac_header in linux/socket.h linux/vm_sockets.h do : as_ac_Header=`$as_echo "ac_cv_header_$ac_header" | $as_tr_sh` ac_fn_c_check_header_compile "$LINENO" "$ac_header" "$as_ac_Header" "#include " if eval test \"x\$"$as_ac_Header"\" = x"yes"; then : cat >>confdefs.h <<_ACEOF #define `$as_echo "HAVE_$ac_header" | $as_tr_cpp` 1 _ACEOF $as_echo "#define XRDP_ENABLE_VSOCK 1" >>confdefs.h fi done fi if test "x$enable_ipv6only" = "xyes" then enable_ipv6=yes $as_echo "#define XRDP_ENABLE_IPV6ONLY 1" >>confdefs.h fi if test "x$enable_ipv6" = "xyes" then $as_echo "#define XRDP_ENABLE_IPV6 1" >>confdefs.h fi if test "x$enable_pam" != "xyes" || test "x$bsd" = "xtrue" then $as_echo "#define USE_NOPAM 1" >>confdefs.h fi if test "x$enable_neutrinordp" = "xyes" ; then : pkg_failed=no { $as_echo "$as_me:${as_lineno-$LINENO}: checking for FREERDP" >&5 $as_echo_n "checking for FREERDP... " >&6; } if test -n "$FREERDP_CFLAGS"; then pkg_cv_FREERDP_CFLAGS="$FREERDP_CFLAGS" elif test -n "$PKG_CONFIG"; then if test -n "$PKG_CONFIG" && \ { { $as_echo "$as_me:${as_lineno-$LINENO}: \$PKG_CONFIG --exists --print-errors \"freerdp >= 1.0.0\""; } >&5 ($PKG_CONFIG --exists --print-errors "freerdp >= 1.0.0") 2>&5 ac_status=$? $as_echo "$as_me:${as_lineno-$LINENO}: \$? = $ac_status" >&5 test $ac_status = 0; }; then pkg_cv_FREERDP_CFLAGS=`$PKG_CONFIG --cflags "freerdp >= 1.0.0" 2>/dev/null` test "x$?" != "x0" && pkg_failed=yes else pkg_failed=yes fi else pkg_failed=untried fi if test -n "$FREERDP_LIBS"; then pkg_cv_FREERDP_LIBS="$FREERDP_LIBS" elif test -n "$PKG_CONFIG"; then if test -n "$PKG_CONFIG" && \ { { $as_echo "$as_me:${as_lineno-$LINENO}: \$PKG_CONFIG --exists --print-errors \"freerdp >= 1.0.0\""; } >&5 ($PKG_CONFIG --exists --print-errors "freerdp >= 1.0.0") 2>&5 ac_status=$? $as_echo "$as_me:${as_lineno-$LINENO}: \$? = $ac_status" >&5 test $ac_status = 0; }; then pkg_cv_FREERDP_LIBS=`$PKG_CONFIG --libs "freerdp >= 1.0.0" 2>/dev/null` test "x$?" != "x0" && pkg_failed=yes else pkg_failed=yes fi else pkg_failed=untried fi if test $pkg_failed = yes; then { $as_echo "$as_me:${as_lineno-$LINENO}: result: no" >&5 $as_echo "no" >&6; } if $PKG_CONFIG --atleast-pkgconfig-version 0.20; then _pkg_short_errors_supported=yes else _pkg_short_errors_supported=no fi if test $_pkg_short_errors_supported = yes; then FREERDP_PKG_ERRORS=`$PKG_CONFIG --short-errors --print-errors --cflags --libs "freerdp >= 1.0.0" 2>&1` else FREERDP_PKG_ERRORS=`$PKG_CONFIG --print-errors --cflags --libs "freerdp >= 1.0.0" 2>&1` fi # Put the nasty error message in config.log where it belongs echo "$FREERDP_PKG_ERRORS" >&5 as_fn_error $? "Package requirements (freerdp >= 1.0.0) were not met: $FREERDP_PKG_ERRORS Consider adjusting the PKG_CONFIG_PATH environment variable if you installed software in a non-standard prefix. Alternatively, you may set the environment variables FREERDP_CFLAGS and FREERDP_LIBS to avoid the need to call pkg-config. See the pkg-config man page for more details." "$LINENO" 5 elif test $pkg_failed = untried; then { $as_echo "$as_me:${as_lineno-$LINENO}: result: no" >&5 $as_echo "no" >&6; } { { $as_echo "$as_me:${as_lineno-$LINENO}: error: in \`$ac_pwd':" >&5 $as_echo "$as_me: error: in \`$ac_pwd':" >&2;} as_fn_error $? "The pkg-config script could not be found or is too old. Make sure it is in your PATH or set the PKG_CONFIG environment variable to the full path to pkg-config. Alternatively, you may set the environment variables FREERDP_CFLAGS and FREERDP_LIBS to avoid the need to call pkg-config. See the pkg-config man page for more details. To get pkg-config, see . See \`config.log' for more details" "$LINENO" 5; } else FREERDP_CFLAGS=$pkg_cv_FREERDP_CFLAGS FREERDP_LIBS=$pkg_cv_FREERDP_LIBS { $as_echo "$as_me:${as_lineno-$LINENO}: result: yes" >&5 $as_echo "yes" >&6; } fi fi # checking for libjpeg if test "x$enable_jpeg" = "xyes" then ac_fn_c_check_header_mongrel "$LINENO" "jpeglib.h" "ac_cv_header_jpeglib_h" "$ac_includes_default" if test "x$ac_cv_header_jpeglib_h" = xyes; then : else as_fn_error $? "please install libjpeg-dev or libjpeg-devel" "$LINENO" 5 fi fi if test "x$enable_xrdpdebug" = "xyes" then CFLAGS="-g -O0" fi # checking for fuse if test "x$enable_fuse" = "xyes" then pkg_failed=no { $as_echo "$as_me:${as_lineno-$LINENO}: checking for FUSE" >&5 $as_echo_n "checking for FUSE... " >&6; } if test -n "$FUSE_CFLAGS"; then pkg_cv_FUSE_CFLAGS="$FUSE_CFLAGS" elif test -n "$PKG_CONFIG"; then if test -n "$PKG_CONFIG" && \ { { $as_echo "$as_me:${as_lineno-$LINENO}: \$PKG_CONFIG --exists --print-errors \"fuse >= 2.6\""; } >&5 ($PKG_CONFIG --exists --print-errors "fuse >= 2.6") 2>&5 ac_status=$? $as_echo "$as_me:${as_lineno-$LINENO}: \$? = $ac_status" >&5 test $ac_status = 0; }; then pkg_cv_FUSE_CFLAGS=`$PKG_CONFIG --cflags "fuse >= 2.6" 2>/dev/null` test "x$?" != "x0" && pkg_failed=yes else pkg_failed=yes fi else pkg_failed=untried fi if test -n "$FUSE_LIBS"; then pkg_cv_FUSE_LIBS="$FUSE_LIBS" elif test -n "$PKG_CONFIG"; then if test -n "$PKG_CONFIG" && \ { { $as_echo "$as_me:${as_lineno-$LINENO}: \$PKG_CONFIG --exists --print-errors \"fuse >= 2.6\""; } >&5 ($PKG_CONFIG --exists --print-errors "fuse >= 2.6") 2>&5 ac_status=$? $as_echo "$as_me:${as_lineno-$LINENO}: \$? = $ac_status" >&5 test $ac_status = 0; }; then pkg_cv_FUSE_LIBS=`$PKG_CONFIG --libs "fuse >= 2.6" 2>/dev/null` test "x$?" != "x0" && pkg_failed=yes else pkg_failed=yes fi else pkg_failed=untried fi if test $pkg_failed = yes; then { $as_echo "$as_me:${as_lineno-$LINENO}: result: no" >&5 $as_echo "no" >&6; } if $PKG_CONFIG --atleast-pkgconfig-version 0.20; then _pkg_short_errors_supported=yes else _pkg_short_errors_supported=no fi if test $_pkg_short_errors_supported = yes; then FUSE_PKG_ERRORS=`$PKG_CONFIG --short-errors --print-errors --cflags --libs "fuse >= 2.6" 2>&1` else FUSE_PKG_ERRORS=`$PKG_CONFIG --print-errors --cflags --libs "fuse >= 2.6" 2>&1` fi # Put the nasty error message in config.log where it belongs echo "$FUSE_PKG_ERRORS" >&5 as_fn_error $? "please install libfuse-dev or fuse-devel" "$LINENO" 5 elif test $pkg_failed = untried; then { $as_echo "$as_me:${as_lineno-$LINENO}: result: no" >&5 $as_echo "no" >&6; } as_fn_error $? "please install libfuse-dev or fuse-devel" "$LINENO" 5 else FUSE_CFLAGS=$pkg_cv_FUSE_CFLAGS FUSE_LIBS=$pkg_cv_FUSE_LIBS { $as_echo "$as_me:${as_lineno-$LINENO}: result: yes" >&5 $as_echo "yes" >&6; } fi fi # checking for fdk aac if test "x$enable_fdkaac" = "xyes" then pkg_failed=no { $as_echo "$as_me:${as_lineno-$LINENO}: checking for FDKAAC" >&5 $as_echo_n "checking for FDKAAC... " >&6; } if test -n "$FDKAAC_CFLAGS"; then pkg_cv_FDKAAC_CFLAGS="$FDKAAC_CFLAGS" elif test -n "$PKG_CONFIG"; then if test -n "$PKG_CONFIG" && \ { { $as_echo "$as_me:${as_lineno-$LINENO}: \$PKG_CONFIG --exists --print-errors \"fdk-aac >= 0.1.0\""; } >&5 ($PKG_CONFIG --exists --print-errors "fdk-aac >= 0.1.0") 2>&5 ac_status=$? $as_echo "$as_me:${as_lineno-$LINENO}: \$? = $ac_status" >&5 test $ac_status = 0; }; then pkg_cv_FDKAAC_CFLAGS=`$PKG_CONFIG --cflags "fdk-aac >= 0.1.0" 2>/dev/null` test "x$?" != "x0" && pkg_failed=yes else pkg_failed=yes fi else pkg_failed=untried fi if test -n "$FDKAAC_LIBS"; then pkg_cv_FDKAAC_LIBS="$FDKAAC_LIBS" elif test -n "$PKG_CONFIG"; then if test -n "$PKG_CONFIG" && \ { { $as_echo "$as_me:${as_lineno-$LINENO}: \$PKG_CONFIG --exists --print-errors \"fdk-aac >= 0.1.0\""; } >&5 ($PKG_CONFIG --exists --print-errors "fdk-aac >= 0.1.0") 2>&5 ac_status=$? $as_echo "$as_me:${as_lineno-$LINENO}: \$? = $ac_status" >&5 test $ac_status = 0; }; then pkg_cv_FDKAAC_LIBS=`$PKG_CONFIG --libs "fdk-aac >= 0.1.0" 2>/dev/null` test "x$?" != "x0" && pkg_failed=yes else pkg_failed=yes fi else pkg_failed=untried fi if test $pkg_failed = yes; then { $as_echo "$as_me:${as_lineno-$LINENO}: result: no" >&5 $as_echo "no" >&6; } if $PKG_CONFIG --atleast-pkgconfig-version 0.20; then _pkg_short_errors_supported=yes else _pkg_short_errors_supported=no fi if test $_pkg_short_errors_supported = yes; then FDKAAC_PKG_ERRORS=`$PKG_CONFIG --short-errors --print-errors --cflags --libs "fdk-aac >= 0.1.0" 2>&1` else FDKAAC_PKG_ERRORS=`$PKG_CONFIG --print-errors --cflags --libs "fdk-aac >= 0.1.0" 2>&1` fi # Put the nasty error message in config.log where it belongs echo "$FDKAAC_PKG_ERRORS" >&5 as_fn_error $? "please install libfdk-aac-dev or fdk-aac-devel" "$LINENO" 5 elif test $pkg_failed = untried; then { $as_echo "$as_me:${as_lineno-$LINENO}: result: no" >&5 $as_echo "no" >&6; } as_fn_error $? "please install libfdk-aac-dev or fdk-aac-devel" "$LINENO" 5 else FDKAAC_CFLAGS=$pkg_cv_FDKAAC_CFLAGS FDKAAC_LIBS=$pkg_cv_FDKAAC_LIBS { $as_echo "$as_me:${as_lineno-$LINENO}: result: yes" >&5 $as_echo "yes" >&6; } fi fi # checking for opus if test "x$enable_opus" = "xyes" then ac_fn_c_check_header_mongrel "$LINENO" "opus/opus.h" "ac_cv_header_opus_opus_h" "$ac_includes_default" if test "x$ac_cv_header_opus_opus_h" = xyes; then : else as_fn_error $? "please install libopus-dev or opus-devel" "$LINENO" 5 fi fi # checking for lame mp3 if test "x$enable_mp3lame" = "xyes" then ac_fn_c_check_header_mongrel "$LINENO" "lame/lame.h" "ac_cv_header_lame_lame_h" "$ac_includes_default" if test "x$ac_cv_header_lame_lame_h" = xyes; then : else as_fn_error $? "please install libmp3lame-dev or lamemp3-devel" "$LINENO" 5 fi fi if test "x$enable_pixman" = "xyes" ; then : pkg_failed=no { $as_echo "$as_me:${as_lineno-$LINENO}: checking for PIXMAN" >&5 $as_echo_n "checking for PIXMAN... " >&6; } if test -n "$PIXMAN_CFLAGS"; then pkg_cv_PIXMAN_CFLAGS="$PIXMAN_CFLAGS" elif test -n "$PKG_CONFIG"; then if test -n "$PKG_CONFIG" && \ { { $as_echo "$as_me:${as_lineno-$LINENO}: \$PKG_CONFIG --exists --print-errors \"pixman-1 >= 0.1.0\""; } >&5 ($PKG_CONFIG --exists --print-errors "pixman-1 >= 0.1.0") 2>&5 ac_status=$? $as_echo "$as_me:${as_lineno-$LINENO}: \$? = $ac_status" >&5 test $ac_status = 0; }; then pkg_cv_PIXMAN_CFLAGS=`$PKG_CONFIG --cflags "pixman-1 >= 0.1.0" 2>/dev/null` test "x$?" != "x0" && pkg_failed=yes else pkg_failed=yes fi else pkg_failed=untried fi if test -n "$PIXMAN_LIBS"; then pkg_cv_PIXMAN_LIBS="$PIXMAN_LIBS" elif test -n "$PKG_CONFIG"; then if test -n "$PKG_CONFIG" && \ { { $as_echo "$as_me:${as_lineno-$LINENO}: \$PKG_CONFIG --exists --print-errors \"pixman-1 >= 0.1.0\""; } >&5 ($PKG_CONFIG --exists --print-errors "pixman-1 >= 0.1.0") 2>&5 ac_status=$? $as_echo "$as_me:${as_lineno-$LINENO}: \$? = $ac_status" >&5 test $ac_status = 0; }; then pkg_cv_PIXMAN_LIBS=`$PKG_CONFIG --libs "pixman-1 >= 0.1.0" 2>/dev/null` test "x$?" != "x0" && pkg_failed=yes else pkg_failed=yes fi else pkg_failed=untried fi if test $pkg_failed = yes; then { $as_echo "$as_me:${as_lineno-$LINENO}: result: no" >&5 $as_echo "no" >&6; } if $PKG_CONFIG --atleast-pkgconfig-version 0.20; then _pkg_short_errors_supported=yes else _pkg_short_errors_supported=no fi if test $_pkg_short_errors_supported = yes; then PIXMAN_PKG_ERRORS=`$PKG_CONFIG --short-errors --print-errors --cflags --libs "pixman-1 >= 0.1.0" 2>&1` else PIXMAN_PKG_ERRORS=`$PKG_CONFIG --print-errors --cflags --libs "pixman-1 >= 0.1.0" 2>&1` fi # Put the nasty error message in config.log where it belongs echo "$PIXMAN_PKG_ERRORS" >&5 as_fn_error $? "Package requirements (pixman-1 >= 0.1.0) were not met: $PIXMAN_PKG_ERRORS Consider adjusting the PKG_CONFIG_PATH environment variable if you installed software in a non-standard prefix. Alternatively, you may set the environment variables PIXMAN_CFLAGS and PIXMAN_LIBS to avoid the need to call pkg-config. See the pkg-config man page for more details." "$LINENO" 5 elif test $pkg_failed = untried; then { $as_echo "$as_me:${as_lineno-$LINENO}: result: no" >&5 $as_echo "no" >&6; } { { $as_echo "$as_me:${as_lineno-$LINENO}: error: in \`$ac_pwd':" >&5 $as_echo "$as_me: error: in \`$ac_pwd':" >&2;} as_fn_error $? "The pkg-config script could not be found or is too old. Make sure it is in your PATH or set the PKG_CONFIG environment variable to the full path to pkg-config. Alternatively, you may set the environment variables PIXMAN_CFLAGS and PIXMAN_LIBS to avoid the need to call pkg-config. See the pkg-config man page for more details. To get pkg-config, see . See \`config.log' for more details" "$LINENO" 5; } else PIXMAN_CFLAGS=$pkg_cv_PIXMAN_CFLAGS PIXMAN_LIBS=$pkg_cv_PIXMAN_LIBS { $as_echo "$as_me:${as_lineno-$LINENO}: result: yes" >&5 $as_echo "yes" >&6; } fi fi # checking for TurboJPEG if test "x$enable_tjpeg" = "xyes" then if test ! -z "$TURBOJPEG_PATH" then # env var TURBOJPEG_PATH has been defined, use that as_ac_Header=`$as_echo "ac_cv_header_$TURBOJPEG_PATH/include/turbojpeg.h" | $as_tr_sh` ac_fn_c_check_header_mongrel "$LINENO" "$TURBOJPEG_PATH/include/turbojpeg.h" "$as_ac_Header" "$ac_includes_default" if eval test \"x\$"$as_ac_Header"\" = x"yes"; then : else as_fn_error $? "could not find TurboJPEG in dir specified by env variable TURBOJPEG_PATH ($TURBOJPEG_PATH)" "$LINENO" 5 fi TurboJpegIncDir="-I$TURBOJPEG_PATH/include" TurboJpegLibDir="-L$TURBOJPEG_PATH/lib -Wl,-rpath -Wl,$TURBOJPEG_PATH/lib" elif test -e /opt/libjpeg-turbo/lib64 then # TurboJPEG has been installed to /opt on a 64 bit m/c TurboJpegIncDir="-I/opt/libjpeg-turbo/include" TurboJpegLibDir="-L/opt/libjpeg-turbo/lib64 -Wl,-rpath -Wl,/opt/libjpeg-turbo/lib64" elif test -e /opt/libjpeg-turbo/lib32 then # TurboJPEG has been installed to /opt on a 32 bit m/c TurboJpegIncDir="-I/opt/libjpeg-turbo/include" TurboJpegLibDir="-L/opt/libjpeg-turbo/lib32 -Wl,-rpath -Wl,/opt/libjpeg-turbo/lib32" else # check in default location ac_fn_c_check_header_mongrel "$LINENO" "/usr/include/turbojpeg.h" "ac_cv_header__usr_include_turbojpeg_h" "$ac_includes_default" if test "x$ac_cv_header__usr_include_turbojpeg_h" = xyes; then : else as_fn_error $? "please install TurboJPEG " "$LINENO" 5 fi TurboJpegIncDir="" TurboJpegLibDir="" fi fi { $as_echo "$as_me:${as_lineno-$LINENO}: checking for X" >&5 $as_echo_n "checking for X... " >&6; } # Check whether --with-x was given. if test "${with_x+set}" = set; then : withval=$with_x; fi # $have_x is `yes', `no', `disabled', or empty when we do not yet know. if test "x$with_x" = xno; then # The user explicitly disabled X. have_x=disabled else case $x_includes,$x_libraries in #( *\'*) as_fn_error $? "cannot use X directory names containing '" "$LINENO" 5;; #( *,NONE | NONE,*) if ${ac_cv_have_x+:} false; then : $as_echo_n "(cached) " >&6 else # One or both of the vars are not set, and there is no cached value. ac_x_includes=no ac_x_libraries=no rm -f -r conftest.dir if mkdir conftest.dir; then cd conftest.dir cat >Imakefile <<'_ACEOF' incroot: @echo incroot='${INCROOT}' usrlibdir: @echo usrlibdir='${USRLIBDIR}' libdir: @echo libdir='${LIBDIR}' _ACEOF if (export CC; ${XMKMF-xmkmf}) >/dev/null 2>/dev/null && test -f Makefile; then # GNU make sometimes prints "make[1]: Entering ...", which would confuse us. for ac_var in incroot usrlibdir libdir; do eval "ac_im_$ac_var=\`\${MAKE-make} $ac_var 2>/dev/null | sed -n 's/^$ac_var=//p'\`" done # Open Windows xmkmf reportedly sets LIBDIR instead of USRLIBDIR. for ac_extension in a so sl dylib la dll; do if test ! -f "$ac_im_usrlibdir/libX11.$ac_extension" && test -f "$ac_im_libdir/libX11.$ac_extension"; then ac_im_usrlibdir=$ac_im_libdir; break fi done # Screen out bogus values from the imake configuration. They are # bogus both because they are the default anyway, and because # using them would break gcc on systems where it needs fixed includes. case $ac_im_incroot in /usr/include) ac_x_includes= ;; *) test -f "$ac_im_incroot/X11/Xos.h" && ac_x_includes=$ac_im_incroot;; esac case $ac_im_usrlibdir in /usr/lib | /usr/lib64 | /lib | /lib64) ;; *) test -d "$ac_im_usrlibdir" && ac_x_libraries=$ac_im_usrlibdir ;; esac fi cd .. rm -f -r conftest.dir fi # Standard set of common directories for X headers. # Check X11 before X11Rn because it is often a symlink to the current release. ac_x_header_dirs=' /usr/X11/include /usr/X11R7/include /usr/X11R6/include /usr/X11R5/include /usr/X11R4/include /usr/include/X11 /usr/include/X11R7 /usr/include/X11R6 /usr/include/X11R5 /usr/include/X11R4 /usr/local/X11/include /usr/local/X11R7/include /usr/local/X11R6/include /usr/local/X11R5/include /usr/local/X11R4/include /usr/local/include/X11 /usr/local/include/X11R7 /usr/local/include/X11R6 /usr/local/include/X11R5 /usr/local/include/X11R4 /usr/X386/include /usr/x386/include /usr/XFree86/include/X11 /usr/include /usr/local/include /usr/unsupported/include /usr/athena/include /usr/local/x11r5/include /usr/lpp/Xamples/include /usr/openwin/include /usr/openwin/share/include' if test "$ac_x_includes" = no; then # Guess where to find include files, by looking for Xlib.h. # First, try using that file with no special directory specified. cat confdefs.h - <<_ACEOF >conftest.$ac_ext /* end confdefs.h. */ #include _ACEOF if ac_fn_c_try_cpp "$LINENO"; then : # We can compile using X headers with no special include directory. ac_x_includes= else for ac_dir in $ac_x_header_dirs; do if test -r "$ac_dir/X11/Xlib.h"; then ac_x_includes=$ac_dir break fi done fi rm -f conftest.err conftest.i conftest.$ac_ext fi # $ac_x_includes = no if test "$ac_x_libraries" = no; then # Check for the libraries. # See if we find them without any special options. # Don't add to $LIBS permanently. ac_save_LIBS=$LIBS LIBS="-lX11 $LIBS" cat confdefs.h - <<_ACEOF >conftest.$ac_ext /* end confdefs.h. */ #include int main () { XrmInitialize () ; return 0; } _ACEOF if ac_fn_c_try_link "$LINENO"; then : LIBS=$ac_save_LIBS # We can link X programs with no special library path. ac_x_libraries= else LIBS=$ac_save_LIBS for ac_dir in `$as_echo "$ac_x_includes $ac_x_header_dirs" | sed s/include/lib/g` do # Don't even attempt the hair of trying to link an X program! for ac_extension in a so sl dylib la dll; do if test -r "$ac_dir/libX11.$ac_extension"; then ac_x_libraries=$ac_dir break 2 fi done done fi rm -f core conftest.err conftest.$ac_objext \ conftest$ac_exeext conftest.$ac_ext fi # $ac_x_libraries = no case $ac_x_includes,$ac_x_libraries in #( no,* | *,no | *\'*) # Didn't find X, or a directory has "'" in its name. ac_cv_have_x="have_x=no";; #( *) # Record where we found X for the cache. ac_cv_have_x="have_x=yes\ ac_x_includes='$ac_x_includes'\ ac_x_libraries='$ac_x_libraries'" esac fi ;; #( *) have_x=yes;; esac eval "$ac_cv_have_x" fi # $with_x != no if test "$have_x" != yes; then { $as_echo "$as_me:${as_lineno-$LINENO}: result: $have_x" >&5 $as_echo "$have_x" >&6; } no_x=yes else # If each of the values was on the command line, it overrides each guess. test "x$x_includes" = xNONE && x_includes=$ac_x_includes test "x$x_libraries" = xNONE && x_libraries=$ac_x_libraries # Update the cache value to reflect the command line values. ac_cv_have_x="have_x=yes\ ac_x_includes='$x_includes'\ ac_x_libraries='$x_libraries'" { $as_echo "$as_me:${as_lineno-$LINENO}: result: libraries $x_libraries, headers $x_includes" >&5 $as_echo "libraries $x_libraries, headers $x_includes" >&6; } fi if test "$no_x" = yes; then # Not all programs may use this symbol, but it does not hurt to define it. $as_echo "#define X_DISPLAY_MISSING 1" >>confdefs.h X_CFLAGS= X_PRE_LIBS= X_LIBS= X_EXTRA_LIBS= else if test -n "$x_includes"; then X_CFLAGS="$X_CFLAGS -I$x_includes" fi # It would also be nice to do this for all -L options, not just this one. if test -n "$x_libraries"; then X_LIBS="$X_LIBS -L$x_libraries" # For Solaris; some versions of Sun CC require a space after -R and # others require no space. Words are not sufficient . . . . { $as_echo "$as_me:${as_lineno-$LINENO}: checking whether -R must be followed by a space" >&5 $as_echo_n "checking whether -R must be followed by a space... " >&6; } ac_xsave_LIBS=$LIBS; LIBS="$LIBS -R$x_libraries" ac_xsave_c_werror_flag=$ac_c_werror_flag ac_c_werror_flag=yes cat confdefs.h - <<_ACEOF >conftest.$ac_ext /* end confdefs.h. */ int main () { ; return 0; } _ACEOF if ac_fn_c_try_link "$LINENO"; then : { $as_echo "$as_me:${as_lineno-$LINENO}: result: no" >&5 $as_echo "no" >&6; } X_LIBS="$X_LIBS -R$x_libraries" else LIBS="$ac_xsave_LIBS -R $x_libraries" cat confdefs.h - <<_ACEOF >conftest.$ac_ext /* end confdefs.h. */ int main () { ; return 0; } _ACEOF if ac_fn_c_try_link "$LINENO"; then : { $as_echo "$as_me:${as_lineno-$LINENO}: result: yes" >&5 $as_echo "yes" >&6; } X_LIBS="$X_LIBS -R $x_libraries" else { $as_echo "$as_me:${as_lineno-$LINENO}: result: neither works" >&5 $as_echo "neither works" >&6; } fi rm -f core conftest.err conftest.$ac_objext \ conftest$ac_exeext conftest.$ac_ext fi rm -f core conftest.err conftest.$ac_objext \ conftest$ac_exeext conftest.$ac_ext ac_c_werror_flag=$ac_xsave_c_werror_flag LIBS=$ac_xsave_LIBS fi # Check for system-dependent libraries X programs must link with. # Do this before checking for the system-independent R6 libraries # (-lICE), since we may need -lsocket or whatever for X linking. if test "$ISC" = yes; then X_EXTRA_LIBS="$X_EXTRA_LIBS -lnsl_s -linet" else # Martyn Johnson says this is needed for Ultrix, if the X # libraries were built with DECnet support. And Karl Berry says # the Alpha needs dnet_stub (dnet does not exist). ac_xsave_LIBS="$LIBS"; LIBS="$LIBS $X_LIBS -lX11" cat confdefs.h - <<_ACEOF >conftest.$ac_ext /* end confdefs.h. */ /* Override any GCC internal prototype to avoid an error. Use char because int might match the return type of a GCC builtin and then its argument prototype would still apply. */ #ifdef __cplusplus extern "C" #endif char XOpenDisplay (); int main () { return XOpenDisplay (); ; return 0; } _ACEOF if ac_fn_c_try_link "$LINENO"; then : else { $as_echo "$as_me:${as_lineno-$LINENO}: checking for dnet_ntoa in -ldnet" >&5 $as_echo_n "checking for dnet_ntoa in -ldnet... " >&6; } if ${ac_cv_lib_dnet_dnet_ntoa+:} false; then : $as_echo_n "(cached) " >&6 else ac_check_lib_save_LIBS=$LIBS LIBS="-ldnet $LIBS" cat confdefs.h - <<_ACEOF >conftest.$ac_ext /* end confdefs.h. */ /* Override any GCC internal prototype to avoid an error. Use char because int might match the return type of a GCC builtin and then its argument prototype would still apply. */ #ifdef __cplusplus extern "C" #endif char dnet_ntoa (); int main () { return dnet_ntoa (); ; return 0; } _ACEOF if ac_fn_c_try_link "$LINENO"; then : ac_cv_lib_dnet_dnet_ntoa=yes else ac_cv_lib_dnet_dnet_ntoa=no fi rm -f core conftest.err conftest.$ac_objext \ conftest$ac_exeext conftest.$ac_ext LIBS=$ac_check_lib_save_LIBS fi { $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_cv_lib_dnet_dnet_ntoa" >&5 $as_echo "$ac_cv_lib_dnet_dnet_ntoa" >&6; } if test "x$ac_cv_lib_dnet_dnet_ntoa" = xyes; then : X_EXTRA_LIBS="$X_EXTRA_LIBS -ldnet" fi if test $ac_cv_lib_dnet_dnet_ntoa = no; then { $as_echo "$as_me:${as_lineno-$LINENO}: checking for dnet_ntoa in -ldnet_stub" >&5 $as_echo_n "checking for dnet_ntoa in -ldnet_stub... " >&6; } if ${ac_cv_lib_dnet_stub_dnet_ntoa+:} false; then : $as_echo_n "(cached) " >&6 else ac_check_lib_save_LIBS=$LIBS LIBS="-ldnet_stub $LIBS" cat confdefs.h - <<_ACEOF >conftest.$ac_ext /* end confdefs.h. */ /* Override any GCC internal prototype to avoid an error. Use char because int might match the return type of a GCC builtin and then its argument prototype would still apply. */ #ifdef __cplusplus extern "C" #endif char dnet_ntoa (); int main () { return dnet_ntoa (); ; return 0; } _ACEOF if ac_fn_c_try_link "$LINENO"; then : ac_cv_lib_dnet_stub_dnet_ntoa=yes else ac_cv_lib_dnet_stub_dnet_ntoa=no fi rm -f core conftest.err conftest.$ac_objext \ conftest$ac_exeext conftest.$ac_ext LIBS=$ac_check_lib_save_LIBS fi { $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_cv_lib_dnet_stub_dnet_ntoa" >&5 $as_echo "$ac_cv_lib_dnet_stub_dnet_ntoa" >&6; } if test "x$ac_cv_lib_dnet_stub_dnet_ntoa" = xyes; then : X_EXTRA_LIBS="$X_EXTRA_LIBS -ldnet_stub" fi fi fi rm -f core conftest.err conftest.$ac_objext \ conftest$ac_exeext conftest.$ac_ext LIBS="$ac_xsave_LIBS" # msh@cis.ufl.edu says -lnsl (and -lsocket) are needed for his 386/AT, # to get the SysV transport functions. # Chad R. Larson says the Pyramis MIS-ES running DC/OSx (SVR4) # needs -lnsl. # The nsl library prevents programs from opening the X display # on Irix 5.2, according to T.E. Dickey. # The functions gethostbyname, getservbyname, and inet_addr are # in -lbsd on LynxOS 3.0.1/i386, according to Lars Hecking. ac_fn_c_check_func "$LINENO" "gethostbyname" "ac_cv_func_gethostbyname" if test "x$ac_cv_func_gethostbyname" = xyes; then : fi if test $ac_cv_func_gethostbyname = no; then { $as_echo "$as_me:${as_lineno-$LINENO}: checking for gethostbyname in -lnsl" >&5 $as_echo_n "checking for gethostbyname in -lnsl... " >&6; } if ${ac_cv_lib_nsl_gethostbyname+:} false; then : $as_echo_n "(cached) " >&6 else ac_check_lib_save_LIBS=$LIBS LIBS="-lnsl $LIBS" cat confdefs.h - <<_ACEOF >conftest.$ac_ext /* end confdefs.h. */ /* Override any GCC internal prototype to avoid an error. Use char because int might match the return type of a GCC builtin and then its argument prototype would still apply. */ #ifdef __cplusplus extern "C" #endif char gethostbyname (); int main () { return gethostbyname (); ; return 0; } _ACEOF if ac_fn_c_try_link "$LINENO"; then : ac_cv_lib_nsl_gethostbyname=yes else ac_cv_lib_nsl_gethostbyname=no fi rm -f core conftest.err conftest.$ac_objext \ conftest$ac_exeext conftest.$ac_ext LIBS=$ac_check_lib_save_LIBS fi { $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_cv_lib_nsl_gethostbyname" >&5 $as_echo "$ac_cv_lib_nsl_gethostbyname" >&6; } if test "x$ac_cv_lib_nsl_gethostbyname" = xyes; then : X_EXTRA_LIBS="$X_EXTRA_LIBS -lnsl" fi if test $ac_cv_lib_nsl_gethostbyname = no; then { $as_echo "$as_me:${as_lineno-$LINENO}: checking for gethostbyname in -lbsd" >&5 $as_echo_n "checking for gethostbyname in -lbsd... " >&6; } if ${ac_cv_lib_bsd_gethostbyname+:} false; then : $as_echo_n "(cached) " >&6 else ac_check_lib_save_LIBS=$LIBS LIBS="-lbsd $LIBS" cat confdefs.h - <<_ACEOF >conftest.$ac_ext /* end confdefs.h. */ /* Override any GCC internal prototype to avoid an error. Use char because int might match the return type of a GCC builtin and then its argument prototype would still apply. */ #ifdef __cplusplus extern "C" #endif char gethostbyname (); int main () { return gethostbyname (); ; return 0; } _ACEOF if ac_fn_c_try_link "$LINENO"; then : ac_cv_lib_bsd_gethostbyname=yes else ac_cv_lib_bsd_gethostbyname=no fi rm -f core conftest.err conftest.$ac_objext \ conftest$ac_exeext conftest.$ac_ext LIBS=$ac_check_lib_save_LIBS fi { $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_cv_lib_bsd_gethostbyname" >&5 $as_echo "$ac_cv_lib_bsd_gethostbyname" >&6; } if test "x$ac_cv_lib_bsd_gethostbyname" = xyes; then : X_EXTRA_LIBS="$X_EXTRA_LIBS -lbsd" fi fi fi # lieder@skyler.mavd.honeywell.com says without -lsocket, # socket/setsockopt and other routines are undefined under SCO ODT # 2.0. But -lsocket is broken on IRIX 5.2 (and is not necessary # on later versions), says Simon Leinen: it contains gethostby* # variants that don't use the name server (or something). -lsocket # must be given before -lnsl if both are needed. We assume that # if connect needs -lnsl, so does gethostbyname. ac_fn_c_check_func "$LINENO" "connect" "ac_cv_func_connect" if test "x$ac_cv_func_connect" = xyes; then : fi if test $ac_cv_func_connect = no; then { $as_echo "$as_me:${as_lineno-$LINENO}: checking for connect in -lsocket" >&5 $as_echo_n "checking for connect in -lsocket... " >&6; } if ${ac_cv_lib_socket_connect+:} false; then : $as_echo_n "(cached) " >&6 else ac_check_lib_save_LIBS=$LIBS LIBS="-lsocket $X_EXTRA_LIBS $LIBS" cat confdefs.h - <<_ACEOF >conftest.$ac_ext /* end confdefs.h. */ /* Override any GCC internal prototype to avoid an error. Use char because int might match the return type of a GCC builtin and then its argument prototype would still apply. */ #ifdef __cplusplus extern "C" #endif char connect (); int main () { return connect (); ; return 0; } _ACEOF if ac_fn_c_try_link "$LINENO"; then : ac_cv_lib_socket_connect=yes else ac_cv_lib_socket_connect=no fi rm -f core conftest.err conftest.$ac_objext \ conftest$ac_exeext conftest.$ac_ext LIBS=$ac_check_lib_save_LIBS fi { $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_cv_lib_socket_connect" >&5 $as_echo "$ac_cv_lib_socket_connect" >&6; } if test "x$ac_cv_lib_socket_connect" = xyes; then : X_EXTRA_LIBS="-lsocket $X_EXTRA_LIBS" fi fi # Guillermo Gomez says -lposix is necessary on A/UX. ac_fn_c_check_func "$LINENO" "remove" "ac_cv_func_remove" if test "x$ac_cv_func_remove" = xyes; then : fi if test $ac_cv_func_remove = no; then { $as_echo "$as_me:${as_lineno-$LINENO}: checking for remove in -lposix" >&5 $as_echo_n "checking for remove in -lposix... " >&6; } if ${ac_cv_lib_posix_remove+:} false; then : $as_echo_n "(cached) " >&6 else ac_check_lib_save_LIBS=$LIBS LIBS="-lposix $LIBS" cat confdefs.h - <<_ACEOF >conftest.$ac_ext /* end confdefs.h. */ /* Override any GCC internal prototype to avoid an error. Use char because int might match the return type of a GCC builtin and then its argument prototype would still apply. */ #ifdef __cplusplus extern "C" #endif char remove (); int main () { return remove (); ; return 0; } _ACEOF if ac_fn_c_try_link "$LINENO"; then : ac_cv_lib_posix_remove=yes else ac_cv_lib_posix_remove=no fi rm -f core conftest.err conftest.$ac_objext \ conftest$ac_exeext conftest.$ac_ext LIBS=$ac_check_lib_save_LIBS fi { $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_cv_lib_posix_remove" >&5 $as_echo "$ac_cv_lib_posix_remove" >&6; } if test "x$ac_cv_lib_posix_remove" = xyes; then : X_EXTRA_LIBS="$X_EXTRA_LIBS -lposix" fi fi # BSDI BSD/OS 2.1 needs -lipc for XOpenDisplay. ac_fn_c_check_func "$LINENO" "shmat" "ac_cv_func_shmat" if test "x$ac_cv_func_shmat" = xyes; then : fi if test $ac_cv_func_shmat = no; then { $as_echo "$as_me:${as_lineno-$LINENO}: checking for shmat in -lipc" >&5 $as_echo_n "checking for shmat in -lipc... " >&6; } if ${ac_cv_lib_ipc_shmat+:} false; then : $as_echo_n "(cached) " >&6 else ac_check_lib_save_LIBS=$LIBS LIBS="-lipc $LIBS" cat confdefs.h - <<_ACEOF >conftest.$ac_ext /* end confdefs.h. */ /* Override any GCC internal prototype to avoid an error. Use char because int might match the return type of a GCC builtin and then its argument prototype would still apply. */ #ifdef __cplusplus extern "C" #endif char shmat (); int main () { return shmat (); ; return 0; } _ACEOF if ac_fn_c_try_link "$LINENO"; then : ac_cv_lib_ipc_shmat=yes else ac_cv_lib_ipc_shmat=no fi rm -f core conftest.err conftest.$ac_objext \ conftest$ac_exeext conftest.$ac_ext LIBS=$ac_check_lib_save_LIBS fi { $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_cv_lib_ipc_shmat" >&5 $as_echo "$ac_cv_lib_ipc_shmat" >&6; } if test "x$ac_cv_lib_ipc_shmat" = xyes; then : X_EXTRA_LIBS="$X_EXTRA_LIBS -lipc" fi fi fi # Check for libraries that X11R6 Xt/Xaw programs need. ac_save_LDFLAGS=$LDFLAGS test -n "$x_libraries" && LDFLAGS="$LDFLAGS -L$x_libraries" # SM needs ICE to (dynamically) link under SunOS 4.x (so we have to # check for ICE first), but we must link in the order -lSM -lICE or # we get undefined symbols. So assume we have SM if we have ICE. # These have to be linked with before -lX11, unlike the other # libraries we check for below, so use a different variable. # John Interrante, Karl Berry { $as_echo "$as_me:${as_lineno-$LINENO}: checking for IceConnectionNumber in -lICE" >&5 $as_echo_n "checking for IceConnectionNumber in -lICE... " >&6; } if ${ac_cv_lib_ICE_IceConnectionNumber+:} false; then : $as_echo_n "(cached) " >&6 else ac_check_lib_save_LIBS=$LIBS LIBS="-lICE $X_EXTRA_LIBS $LIBS" cat confdefs.h - <<_ACEOF >conftest.$ac_ext /* end confdefs.h. */ /* Override any GCC internal prototype to avoid an error. Use char because int might match the return type of a GCC builtin and then its argument prototype would still apply. */ #ifdef __cplusplus extern "C" #endif char IceConnectionNumber (); int main () { return IceConnectionNumber (); ; return 0; } _ACEOF if ac_fn_c_try_link "$LINENO"; then : ac_cv_lib_ICE_IceConnectionNumber=yes else ac_cv_lib_ICE_IceConnectionNumber=no fi rm -f core conftest.err conftest.$ac_objext \ conftest$ac_exeext conftest.$ac_ext LIBS=$ac_check_lib_save_LIBS fi { $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_cv_lib_ICE_IceConnectionNumber" >&5 $as_echo "$ac_cv_lib_ICE_IceConnectionNumber" >&6; } if test "x$ac_cv_lib_ICE_IceConnectionNumber" = xyes; then : X_PRE_LIBS="$X_PRE_LIBS -lSM -lICE" fi LDFLAGS=$ac_save_LDFLAGS fi if test "x$no_x" == "xyes"; then as_fn_error $? "please install libx11-dev or libX11-devel" "$LINENO" 5 fi save_CFLAGS="$CFLAGS" CFLAGS="$CFLAGS $X_CFLAGS" # checking for Xfixes ac_fn_c_check_header_compile "$LINENO" "X11/extensions/Xfixes.h" "ac_cv_header_X11_extensions_Xfixes_h" "#include " if test "x$ac_cv_header_X11_extensions_Xfixes_h" = xyes; then : else as_fn_error $? "please install libxfixes-dev or libXfixes-devel" "$LINENO" 5 fi # checking for Xrandr ac_fn_c_check_header_compile "$LINENO" "X11/extensions/Xrandr.h" "ac_cv_header_X11_extensions_Xrandr_h" "#include " if test "x$ac_cv_header_X11_extensions_Xrandr_h" = xyes; then : else as_fn_error $? "please install libxrandr-dev or libXrandr-devel" "$LINENO" 5 fi CFLAGS="$save_CFLAGS" moduledir='${libdir}/xrdp' # Check whether --enable-strict-locations was given. if test "${enable_strict_locations+set}" = set; then : enableval=$enable_strict_locations; fi if test "x$enable_strict_locations" != "xyes"; then sysconfdir="/etc"; localstatedir="/var"; fi # Check whether --with-pkgconfigdir was given. if test "${with_pkgconfigdir+set}" = set; then : withval=$with_pkgconfigdir; else with_pkgconfigdir='${libdir}/pkgconfig' fi pkgconfigdir=$with_pkgconfigdir for ac_header in sys/prctl.h do : ac_fn_c_check_header_mongrel "$LINENO" "sys/prctl.h" "ac_cv_header_sys_prctl_h" "$ac_includes_default" if test "x$ac_cv_header_sys_prctl_h" = xyes; then : cat >>confdefs.h <<_ACEOF #define HAVE_SYS_PRCTL_H 1 _ACEOF fi done ac_config_files="$ac_config_files common/Makefile docs/Makefile docs/man/Makefile genkeymap/Makefile instfiles/default/Makefile instfiles/init.d/Makefile instfiles/Makefile instfiles/pam.d/Makefile instfiles/pulse/Makefile instfiles/rc.d/Makefile keygen/Makefile libxrdp/Makefile Makefile mc/Makefile neutrinordp/Makefile pkgconfig/Makefile pkgconfig/xrdp.pc pkgconfig/xrdp-uninstalled.pc sesman/chansrv/Makefile sesman/libscp/Makefile sesman/Makefile sesman/tools/Makefile vnc/Makefile xrdpapi/Makefile xrdp/Makefile xrdpvr/Makefile xup/Makefile" cat >confcache <<\_ACEOF # This file is a shell script that caches the results of configure # tests run on this system so they can be shared between configure # scripts and configure runs, see configure's option --config-cache. # It is not useful on other systems. If it contains results you don't # want to keep, you may remove or edit it. # # config.status only pays attention to the cache file if you give it # the --recheck option to rerun configure. # # `ac_cv_env_foo' variables (set or unset) will be overridden when # loading this file, other *unset* `ac_cv_foo' will be assigned the # following values. _ACEOF # The following way of writing the cache mishandles newlines in values, # but we know of no workaround that is simple, portable, and efficient. # So, we kill variables containing newlines. # Ultrix sh set writes to stderr and can't be redirected directly, # and sets the high bit in the cache file unless we assign to the vars. ( for ac_var in `(set) 2>&1 | sed -n 's/^\([a-zA-Z_][a-zA-Z0-9_]*\)=.*/\1/p'`; do eval ac_val=\$$ac_var case $ac_val in #( *${as_nl}*) case $ac_var in #( *_cv_*) { $as_echo "$as_me:${as_lineno-$LINENO}: WARNING: cache variable $ac_var contains a newline" >&5 $as_echo "$as_me: WARNING: cache variable $ac_var contains a newline" >&2;} ;; esac case $ac_var in #( _ | IFS | as_nl) ;; #( BASH_ARGV | BASH_SOURCE) eval $ac_var= ;; #( *) { eval $ac_var=; unset $ac_var;} ;; esac ;; esac done (set) 2>&1 | case $as_nl`(ac_space=' '; set) 2>&1` in #( *${as_nl}ac_space=\ *) # `set' does not quote correctly, so add quotes: double-quote # substitution turns \\\\ into \\, and sed turns \\ into \. sed -n \ "s/'/'\\\\''/g; s/^\\([_$as_cr_alnum]*_cv_[_$as_cr_alnum]*\\)=\\(.*\\)/\\1='\\2'/p" ;; #( *) # `set' quotes correctly as required by POSIX, so do not add quotes. sed -n "/^[_$as_cr_alnum]*_cv_[_$as_cr_alnum]*=/p" ;; esac | sort ) | sed ' /^ac_cv_env_/b end t clear :clear s/^\([^=]*\)=\(.*[{}].*\)$/test "${\1+set}" = set || &/ t end s/^\([^=]*\)=\(.*\)$/\1=${\1=\2}/ :end' >>confcache if diff "$cache_file" confcache >/dev/null 2>&1; then :; else if test -w "$cache_file"; then if test "x$cache_file" != "x/dev/null"; then { $as_echo "$as_me:${as_lineno-$LINENO}: updating cache $cache_file" >&5 $as_echo "$as_me: updating cache $cache_file" >&6;} if test ! -f "$cache_file" || test -h "$cache_file"; then cat confcache >"$cache_file" else case $cache_file in #( */* | ?:*) mv -f confcache "$cache_file"$$ && mv -f "$cache_file"$$ "$cache_file" ;; #( *) mv -f confcache "$cache_file" ;; esac fi fi else { $as_echo "$as_me:${as_lineno-$LINENO}: not updating unwritable cache $cache_file" >&5 $as_echo "$as_me: not updating unwritable cache $cache_file" >&6;} fi fi rm -f confcache test "x$prefix" = xNONE && prefix=$ac_default_prefix # Let make expand exec_prefix. test "x$exec_prefix" = xNONE && exec_prefix='${prefix}' DEFS=-DHAVE_CONFIG_H ac_libobjs= ac_ltlibobjs= U= for ac_i in : $LIBOBJS; do test "x$ac_i" = x: && continue # 1. Remove the extension, and $U if already installed. ac_script='s/\$U\././;s/\.o$//;s/\.obj$//' ac_i=`$as_echo "$ac_i" | sed "$ac_script"` # 2. Prepend LIBOBJDIR. When used with automake>=1.10 LIBOBJDIR # will be set to the directory where LIBOBJS objects are built. as_fn_append ac_libobjs " \${LIBOBJDIR}$ac_i\$U.$ac_objext" as_fn_append ac_ltlibobjs " \${LIBOBJDIR}$ac_i"'$U.lo' done LIBOBJS=$ac_libobjs LTLIBOBJS=$ac_ltlibobjs { $as_echo "$as_me:${as_lineno-$LINENO}: checking that generated files are newer than configure" >&5 $as_echo_n "checking that generated files are newer than configure... " >&6; } if test -n "$am_sleep_pid"; then # Hide warnings about reused PIDs. wait $am_sleep_pid 2>/dev/null fi { $as_echo "$as_me:${as_lineno-$LINENO}: result: done" >&5 $as_echo "done" >&6; } if test -n "$EXEEXT"; then am__EXEEXT_TRUE= am__EXEEXT_FALSE='#' else am__EXEEXT_TRUE='#' am__EXEEXT_FALSE= fi if test -z "${AMDEP_TRUE}" && test -z "${AMDEP_FALSE}"; then as_fn_error $? "conditional \"AMDEP\" was never defined. Usually this means the macro was only invoked conditionally." "$LINENO" 5 fi if test -z "${am__fastdepCC_TRUE}" && test -z "${am__fastdepCC_FALSE}"; then as_fn_error $? "conditional \"am__fastdepCC\" was never defined. Usually this means the macro was only invoked conditionally." "$LINENO" 5 fi if test -z "${LINUX_TRUE}" && test -z "${LINUX_FALSE}"; then as_fn_error $? "conditional \"LINUX\" was never defined. Usually this means the macro was only invoked conditionally." "$LINENO" 5 fi if test -z "${FREEBSD_TRUE}" && test -z "${FREEBSD_FALSE}"; then as_fn_error $? "conditional \"FREEBSD\" was never defined. Usually this means the macro was only invoked conditionally." "$LINENO" 5 fi if test -z "${OPENBSD_TRUE}" && test -z "${OPENBSD_FALSE}"; then as_fn_error $? "conditional \"OPENBSD\" was never defined. Usually this means the macro was only invoked conditionally." "$LINENO" 5 fi if test -z "${NETBSD_TRUE}" && test -z "${NETBSD_FALSE}"; then as_fn_error $? "conditional \"NETBSD\" was never defined. Usually this means the macro was only invoked conditionally." "$LINENO" 5 fi if test -z "${HAVE_SYSTEMD_TRUE}" && test -z "${HAVE_SYSTEMD_FALSE}"; then as_fn_error $? "conditional \"HAVE_SYSTEMD\" was never defined. Usually this means the macro was only invoked conditionally." "$LINENO" 5 fi if test -z "${SESMAN_NOPAM_TRUE}" && test -z "${SESMAN_NOPAM_FALSE}"; then as_fn_error $? "conditional \"SESMAN_NOPAM\" was never defined. Usually this means the macro was only invoked conditionally." "$LINENO" 5 fi if test -z "${SESMAN_BSD_TRUE}" && test -z "${SESMAN_BSD_FALSE}"; then as_fn_error $? "conditional \"SESMAN_BSD\" was never defined. Usually this means the macro was only invoked conditionally." "$LINENO" 5 fi if test -z "${SESMAN_KERBEROS_TRUE}" && test -z "${SESMAN_KERBEROS_FALSE}"; then as_fn_error $? "conditional \"SESMAN_KERBEROS\" was never defined. Usually this means the macro was only invoked conditionally." "$LINENO" 5 fi if test -z "${SESMAN_PAMUSERPASS_TRUE}" && test -z "${SESMAN_PAMUSERPASS_FALSE}"; then as_fn_error $? "conditional \"SESMAN_PAMUSERPASS\" was never defined. Usually this means the macro was only invoked conditionally." "$LINENO" 5 fi if test -z "${XRDP_DEBUG_TRUE}" && test -z "${XRDP_DEBUG_FALSE}"; then as_fn_error $? "conditional \"XRDP_DEBUG\" was never defined. Usually this means the macro was only invoked conditionally." "$LINENO" 5 fi if test -z "${XRDP_NEUTRINORDP_TRUE}" && test -z "${XRDP_NEUTRINORDP_FALSE}"; then as_fn_error $? "conditional \"XRDP_NEUTRINORDP\" was never defined. Usually this means the macro was only invoked conditionally." "$LINENO" 5 fi if test -z "${XRDP_JPEG_TRUE}" && test -z "${XRDP_JPEG_FALSE}"; then as_fn_error $? "conditional \"XRDP_JPEG\" was never defined. Usually this means the macro was only invoked conditionally." "$LINENO" 5 fi if test -z "${XRDP_TJPEG_TRUE}" && test -z "${XRDP_TJPEG_FALSE}"; then as_fn_error $? "conditional \"XRDP_TJPEG\" was never defined. Usually this means the macro was only invoked conditionally." "$LINENO" 5 fi if test -z "${XRDP_FUSE_TRUE}" && test -z "${XRDP_FUSE_FALSE}"; then as_fn_error $? "conditional \"XRDP_FUSE\" was never defined. Usually this means the macro was only invoked conditionally." "$LINENO" 5 fi if test -z "${XRDP_XRDPVR_TRUE}" && test -z "${XRDP_XRDPVR_FALSE}"; then as_fn_error $? "conditional \"XRDP_XRDPVR\" was never defined. Usually this means the macro was only invoked conditionally." "$LINENO" 5 fi if test -z "${XRDP_FDK_AAC_TRUE}" && test -z "${XRDP_FDK_AAC_FALSE}"; then as_fn_error $? "conditional \"XRDP_FDK_AAC\" was never defined. Usually this means the macro was only invoked conditionally." "$LINENO" 5 fi if test -z "${XRDP_OPUS_TRUE}" && test -z "${XRDP_OPUS_FALSE}"; then as_fn_error $? "conditional \"XRDP_OPUS\" was never defined. Usually this means the macro was only invoked conditionally." "$LINENO" 5 fi if test -z "${XRDP_MP3LAME_TRUE}" && test -z "${XRDP_MP3LAME_FALSE}"; then as_fn_error $? "conditional \"XRDP_MP3LAME\" was never defined. Usually this means the macro was only invoked conditionally." "$LINENO" 5 fi if test -z "${XRDP_PIXMAN_TRUE}" && test -z "${XRDP_PIXMAN_FALSE}"; then as_fn_error $? "conditional \"XRDP_PIXMAN\" was never defined. Usually this means the macro was only invoked conditionally." "$LINENO" 5 fi if test -z "${XRDP_PAINTER_TRUE}" && test -z "${XRDP_PAINTER_FALSE}"; then as_fn_error $? "conditional \"XRDP_PAINTER\" was never defined. Usually this means the macro was only invoked conditionally." "$LINENO" 5 fi if test -z "${XRDP_RFXCODEC_TRUE}" && test -z "${XRDP_RFXCODEC_FALSE}"; then as_fn_error $? "conditional \"XRDP_RFXCODEC\" was never defined. Usually this means the macro was only invoked conditionally." "$LINENO" 5 fi : "${CONFIG_STATUS=./config.status}" ac_write_fail=0 ac_clean_files_save=$ac_clean_files ac_clean_files="$ac_clean_files $CONFIG_STATUS" { $as_echo "$as_me:${as_lineno-$LINENO}: creating $CONFIG_STATUS" >&5 $as_echo "$as_me: creating $CONFIG_STATUS" >&6;} as_write_fail=0 cat >$CONFIG_STATUS <<_ASEOF || as_write_fail=1 #! $SHELL # Generated by $as_me. # Run this file to recreate the current configuration. # Compiler output produced by configure, useful for debugging # configure, is in config.log if it exists. debug=false ac_cs_recheck=false ac_cs_silent=false SHELL=\${CONFIG_SHELL-$SHELL} export SHELL _ASEOF cat >>$CONFIG_STATUS <<\_ASEOF || as_write_fail=1 ## -------------------- ## ## M4sh Initialization. ## ## -------------------- ## # Be more Bourne compatible DUALCASE=1; export DUALCASE # for MKS sh if test -n "${ZSH_VERSION+set}" && (emulate sh) >/dev/null 2>&1; then : emulate sh NULLCMD=: # Pre-4.2 versions of Zsh do word splitting on ${1+"$@"}, which # is contrary to our usage. Disable this feature. alias -g '${1+"$@"}'='"$@"' setopt NO_GLOB_SUBST else case `(set -o) 2>/dev/null` in #( *posix*) : set -o posix ;; #( *) : ;; esac fi as_nl=' ' export as_nl # Printing a long string crashes Solaris 7 /usr/bin/printf. as_echo='\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\' as_echo=$as_echo$as_echo$as_echo$as_echo$as_echo as_echo=$as_echo$as_echo$as_echo$as_echo$as_echo$as_echo # Prefer a ksh shell builtin over an external printf program on Solaris, # but without wasting forks for bash or zsh. if test -z "$BASH_VERSION$ZSH_VERSION" \ && (test "X`print -r -- $as_echo`" = "X$as_echo") 2>/dev/null; then as_echo='print -r --' as_echo_n='print -rn --' elif (test "X`printf %s $as_echo`" = "X$as_echo") 2>/dev/null; then as_echo='printf %s\n' as_echo_n='printf %s' else if test "X`(/usr/ucb/echo -n -n $as_echo) 2>/dev/null`" = "X-n $as_echo"; then as_echo_body='eval /usr/ucb/echo -n "$1$as_nl"' as_echo_n='/usr/ucb/echo -n' else as_echo_body='eval expr "X$1" : "X\\(.*\\)"' as_echo_n_body='eval arg=$1; case $arg in #( *"$as_nl"*) expr "X$arg" : "X\\(.*\\)$as_nl"; arg=`expr "X$arg" : ".*$as_nl\\(.*\\)"`;; esac; expr "X$arg" : "X\\(.*\\)" | tr -d "$as_nl" ' export as_echo_n_body as_echo_n='sh -c $as_echo_n_body as_echo' fi export as_echo_body as_echo='sh -c $as_echo_body as_echo' fi # The user is always right. if test "${PATH_SEPARATOR+set}" != set; then PATH_SEPARATOR=: (PATH='/bin;/bin'; FPATH=$PATH; sh -c :) >/dev/null 2>&1 && { (PATH='/bin:/bin'; FPATH=$PATH; sh -c :) >/dev/null 2>&1 || PATH_SEPARATOR=';' } fi # IFS # We need space, tab and new line, in precisely that order. Quoting is # there to prevent editors from complaining about space-tab. # (If _AS_PATH_WALK were called with IFS unset, it would disable word # splitting by setting IFS to empty value.) IFS=" "" $as_nl" # Find who we are. Look in the path if we contain no directory separator. as_myself= case $0 in #(( *[\\/]* ) as_myself=$0 ;; *) as_save_IFS=$IFS; IFS=$PATH_SEPARATOR for as_dir in $PATH do IFS=$as_save_IFS test -z "$as_dir" && as_dir=. test -r "$as_dir/$0" && as_myself=$as_dir/$0 && break done IFS=$as_save_IFS ;; esac # We did not find ourselves, most probably we were run as `sh COMMAND' # in which case we are not to be found in the path. if test "x$as_myself" = x; then as_myself=$0 fi if test ! -f "$as_myself"; then $as_echo "$as_myself: error: cannot find myself; rerun with an absolute file name" >&2 exit 1 fi # Unset variables that we do not need and which cause bugs (e.g. in # pre-3.0 UWIN ksh). But do not cause bugs in bash 2.01; the "|| exit 1" # suppresses any "Segmentation fault" message there. '((' could # trigger a bug in pdksh 5.2.14. for as_var in BASH_ENV ENV MAIL MAILPATH do eval test x\${$as_var+set} = xset \ && ( (unset $as_var) || exit 1) >/dev/null 2>&1 && unset $as_var || : done PS1='$ ' PS2='> ' PS4='+ ' # NLS nuisances. LC_ALL=C export LC_ALL LANGUAGE=C export LANGUAGE # CDPATH. (unset CDPATH) >/dev/null 2>&1 && unset CDPATH # as_fn_error STATUS ERROR [LINENO LOG_FD] # ---------------------------------------- # Output "`basename $0`: error: ERROR" to stderr. If LINENO and LOG_FD are # provided, also output the error to LOG_FD, referencing LINENO. Then exit the # script with STATUS, using 1 if that was 0. as_fn_error () { as_status=$1; test $as_status -eq 0 && as_status=1 if test "$4"; then as_lineno=${as_lineno-"$3"} as_lineno_stack=as_lineno_stack=$as_lineno_stack $as_echo "$as_me:${as_lineno-$LINENO}: error: $2" >&$4 fi $as_echo "$as_me: error: $2" >&2 as_fn_exit $as_status } # as_fn_error # as_fn_set_status STATUS # ----------------------- # Set $? to STATUS, without forking. as_fn_set_status () { return $1 } # as_fn_set_status # as_fn_exit STATUS # ----------------- # Exit the shell with STATUS, even in a "trap 0" or "set -e" context. as_fn_exit () { set +e as_fn_set_status $1 exit $1 } # as_fn_exit # as_fn_unset VAR # --------------- # Portably unset VAR. as_fn_unset () { { eval $1=; unset $1;} } as_unset=as_fn_unset # as_fn_append VAR VALUE # ---------------------- # Append the text in VALUE to the end of the definition contained in VAR. Take # advantage of any shell optimizations that allow amortized linear growth over # repeated appends, instead of the typical quadratic growth present in naive # implementations. if (eval "as_var=1; as_var+=2; test x\$as_var = x12") 2>/dev/null; then : eval 'as_fn_append () { eval $1+=\$2 }' else as_fn_append () { eval $1=\$$1\$2 } fi # as_fn_append # as_fn_arith ARG... # ------------------ # Perform arithmetic evaluation on the ARGs, and store the result in the # global $as_val. Take advantage of shells that can avoid forks. The arguments # must be portable across $(()) and expr. if (eval "test \$(( 1 + 1 )) = 2") 2>/dev/null; then : eval 'as_fn_arith () { as_val=$(( $* )) }' else as_fn_arith () { as_val=`expr "$@" || test $? -eq 1` } fi # as_fn_arith if expr a : '\(a\)' >/dev/null 2>&1 && test "X`expr 00001 : '.*\(...\)'`" = X001; then as_expr=expr else as_expr=false fi if (basename -- /) >/dev/null 2>&1 && test "X`basename -- / 2>&1`" = "X/"; then as_basename=basename else as_basename=false fi if (as_dir=`dirname -- /` && test "X$as_dir" = X/) >/dev/null 2>&1; then as_dirname=dirname else as_dirname=false fi as_me=`$as_basename -- "$0" || $as_expr X/"$0" : '.*/\([^/][^/]*\)/*$' \| \ X"$0" : 'X\(//\)$' \| \ X"$0" : 'X\(/\)' \| . 2>/dev/null || $as_echo X/"$0" | sed '/^.*\/\([^/][^/]*\)\/*$/{ s//\1/ q } /^X\/\(\/\/\)$/{ s//\1/ q } /^X\/\(\/\).*/{ s//\1/ q } s/.*/./; q'` # Avoid depending upon Character Ranges. as_cr_letters='abcdefghijklmnopqrstuvwxyz' as_cr_LETTERS='ABCDEFGHIJKLMNOPQRSTUVWXYZ' as_cr_Letters=$as_cr_letters$as_cr_LETTERS as_cr_digits='0123456789' as_cr_alnum=$as_cr_Letters$as_cr_digits ECHO_C= ECHO_N= ECHO_T= case `echo -n x` in #((((( -n*) case `echo 'xy\c'` in *c*) ECHO_T=' ';; # ECHO_T is single tab character. xy) ECHO_C='\c';; *) echo `echo ksh88 bug on AIX 6.1` > /dev/null ECHO_T=' ';; esac;; *) ECHO_N='-n';; esac rm -f conf$$ conf$$.exe conf$$.file if test -d conf$$.dir; then rm -f conf$$.dir/conf$$.file else rm -f conf$$.dir mkdir conf$$.dir 2>/dev/null fi if (echo >conf$$.file) 2>/dev/null; then if ln -s conf$$.file conf$$ 2>/dev/null; then as_ln_s='ln -s' # ... but there are two gotchas: # 1) On MSYS, both `ln -s file dir' and `ln file dir' fail. # 2) DJGPP < 2.04 has no symlinks; `ln -s' creates a wrapper executable. # In both cases, we have to default to `cp -pR'. ln -s conf$$.file conf$$.dir 2>/dev/null && test ! -f conf$$.exe || as_ln_s='cp -pR' elif ln conf$$.file conf$$ 2>/dev/null; then as_ln_s=ln else as_ln_s='cp -pR' fi else as_ln_s='cp -pR' fi rm -f conf$$ conf$$.exe conf$$.dir/conf$$.file conf$$.file rmdir conf$$.dir 2>/dev/null # as_fn_mkdir_p # ------------- # Create "$as_dir" as a directory, including parents if necessary. as_fn_mkdir_p () { case $as_dir in #( -*) as_dir=./$as_dir;; esac test -d "$as_dir" || eval $as_mkdir_p || { as_dirs= while :; do case $as_dir in #( *\'*) as_qdir=`$as_echo "$as_dir" | sed "s/'/'\\\\\\\\''/g"`;; #'( *) as_qdir=$as_dir;; esac as_dirs="'$as_qdir' $as_dirs" as_dir=`$as_dirname -- "$as_dir" || $as_expr X"$as_dir" : 'X\(.*[^/]\)//*[^/][^/]*/*$' \| \ X"$as_dir" : 'X\(//\)[^/]' \| \ X"$as_dir" : 'X\(//\)$' \| \ X"$as_dir" : 'X\(/\)' \| . 2>/dev/null || $as_echo X"$as_dir" | sed '/^X\(.*[^/]\)\/\/*[^/][^/]*\/*$/{ s//\1/ q } /^X\(\/\/\)[^/].*/{ s//\1/ q } /^X\(\/\/\)$/{ s//\1/ q } /^X\(\/\).*/{ s//\1/ q } s/.*/./; q'` test -d "$as_dir" && break done test -z "$as_dirs" || eval "mkdir $as_dirs" } || test -d "$as_dir" || as_fn_error $? "cannot create directory $as_dir" } # as_fn_mkdir_p if mkdir -p . 2>/dev/null; then as_mkdir_p='mkdir -p "$as_dir"' else test -d ./-p && rmdir ./-p as_mkdir_p=false fi # as_fn_executable_p FILE # ----------------------- # Test if FILE is an executable regular file. as_fn_executable_p () { test -f "$1" && test -x "$1" } # as_fn_executable_p as_test_x='test -x' as_executable_p=as_fn_executable_p # Sed expression to map a string onto a valid CPP name. as_tr_cpp="eval sed 'y%*$as_cr_letters%P$as_cr_LETTERS%;s%[^_$as_cr_alnum]%_%g'" # Sed expression to map a string onto a valid variable name. as_tr_sh="eval sed 'y%*+%pp%;s%[^_$as_cr_alnum]%_%g'" exec 6>&1 ## ----------------------------------- ## ## Main body of $CONFIG_STATUS script. ## ## ----------------------------------- ## _ASEOF test $as_write_fail = 0 && chmod +x $CONFIG_STATUS || ac_write_fail=1 cat >>$CONFIG_STATUS <<\_ACEOF || ac_write_fail=1 # Save the log message, to keep $0 and so on meaningful, and to # report actual input values of CONFIG_FILES etc. instead of their # values after options handling. ac_log=" This file was extended by xrdp $as_me 0.9.5, which was generated by GNU Autoconf 2.69. Invocation command line was CONFIG_FILES = $CONFIG_FILES CONFIG_HEADERS = $CONFIG_HEADERS CONFIG_LINKS = $CONFIG_LINKS CONFIG_COMMANDS = $CONFIG_COMMANDS $ $0 $@ on `(hostname || uname -n) 2>/dev/null | sed 1q` " _ACEOF case $ac_config_files in *" "*) set x $ac_config_files; shift; ac_config_files=$*;; esac case $ac_config_headers in *" "*) set x $ac_config_headers; shift; ac_config_headers=$*;; esac cat >>$CONFIG_STATUS <<_ACEOF || ac_write_fail=1 # Files that config.status was made for. config_files="$ac_config_files" config_headers="$ac_config_headers" config_commands="$ac_config_commands" _ACEOF cat >>$CONFIG_STATUS <<\_ACEOF || ac_write_fail=1 ac_cs_usage="\ \`$as_me' instantiates files and other configuration actions from templates according to the current configuration. Unless the files and actions are specified as TAGs, all are instantiated by default. Usage: $0 [OPTION]... [TAG]... -h, --help print this help, then exit -V, --version print version number and configuration settings, then exit --config print configuration, then exit -q, --quiet, --silent do not print progress messages -d, --debug don't remove temporary files --recheck update $as_me by reconfiguring in the same conditions --file=FILE[:TEMPLATE] instantiate the configuration file FILE --header=FILE[:TEMPLATE] instantiate the configuration header FILE Configuration files: $config_files Configuration headers: $config_headers Configuration commands: $config_commands Report bugs to ." _ACEOF cat >>$CONFIG_STATUS <<_ACEOF || ac_write_fail=1 ac_cs_config="`$as_echo "$ac_configure_args" | sed 's/^ //; s/[\\""\`\$]/\\\\&/g'`" ac_cs_version="\\ xrdp config.status 0.9.5 configured by $0, generated by GNU Autoconf 2.69, with options \\"\$ac_cs_config\\" Copyright (C) 2012 Free Software Foundation, Inc. This config.status script is free software; the Free Software Foundation gives unlimited permission to copy, distribute and modify it." ac_pwd='$ac_pwd' srcdir='$srcdir' INSTALL='$INSTALL' MKDIR_P='$MKDIR_P' AWK='$AWK' test -n "\$AWK" || AWK=awk _ACEOF cat >>$CONFIG_STATUS <<\_ACEOF || ac_write_fail=1 # The default lists apply if the user does not specify any file. ac_need_defaults=: while test $# != 0 do case $1 in --*=?*) ac_option=`expr "X$1" : 'X\([^=]*\)='` ac_optarg=`expr "X$1" : 'X[^=]*=\(.*\)'` ac_shift=: ;; --*=) ac_option=`expr "X$1" : 'X\([^=]*\)='` ac_optarg= ac_shift=: ;; *) ac_option=$1 ac_optarg=$2 ac_shift=shift ;; esac case $ac_option in # Handling of the options. -recheck | --recheck | --rechec | --reche | --rech | --rec | --re | --r) ac_cs_recheck=: ;; --version | --versio | --versi | --vers | --ver | --ve | --v | -V ) $as_echo "$ac_cs_version"; exit ;; --config | --confi | --conf | --con | --co | --c ) $as_echo "$ac_cs_config"; exit ;; --debug | --debu | --deb | --de | --d | -d ) debug=: ;; --file | --fil | --fi | --f ) $ac_shift case $ac_optarg in *\'*) ac_optarg=`$as_echo "$ac_optarg" | sed "s/'/'\\\\\\\\''/g"` ;; '') as_fn_error $? "missing file argument" ;; esac as_fn_append CONFIG_FILES " '$ac_optarg'" ac_need_defaults=false;; --header | --heade | --head | --hea ) $ac_shift case $ac_optarg in *\'*) ac_optarg=`$as_echo "$ac_optarg" | sed "s/'/'\\\\\\\\''/g"` ;; esac as_fn_append CONFIG_HEADERS " '$ac_optarg'" ac_need_defaults=false;; --he | --h) # Conflict between --help and --header as_fn_error $? "ambiguous option: \`$1' Try \`$0 --help' for more information.";; --help | --hel | -h ) $as_echo "$ac_cs_usage"; exit ;; -q | -quiet | --quiet | --quie | --qui | --qu | --q \ | -silent | --silent | --silen | --sile | --sil | --si | --s) ac_cs_silent=: ;; # This is an error. -*) as_fn_error $? "unrecognized option: \`$1' Try \`$0 --help' for more information." ;; *) as_fn_append ac_config_targets " $1" ac_need_defaults=false ;; esac shift done ac_configure_extra_args= if $ac_cs_silent; then exec 6>/dev/null ac_configure_extra_args="$ac_configure_extra_args --silent" fi _ACEOF cat >>$CONFIG_STATUS <<_ACEOF || ac_write_fail=1 if \$ac_cs_recheck; then set X $SHELL '$0' $ac_configure_args \$ac_configure_extra_args --no-create --no-recursion shift \$as_echo "running CONFIG_SHELL=$SHELL \$*" >&6 CONFIG_SHELL='$SHELL' export CONFIG_SHELL exec "\$@" fi _ACEOF cat >>$CONFIG_STATUS <<\_ACEOF || ac_write_fail=1 exec 5>>config.log { echo sed 'h;s/./-/g;s/^.../## /;s/...$/ ##/;p;x;p;x' <<_ASBOX ## Running $as_me. ## _ASBOX $as_echo "$ac_log" } >&5 _ACEOF cat >>$CONFIG_STATUS <<_ACEOF || ac_write_fail=1 # # INIT-COMMANDS # AMDEP_TRUE="$AMDEP_TRUE" ac_aux_dir="$ac_aux_dir" # The HP-UX ksh and POSIX shell print the target directory to stdout # if CDPATH is set. (unset CDPATH) >/dev/null 2>&1 && unset CDPATH sed_quote_subst='$sed_quote_subst' double_quote_subst='$double_quote_subst' delay_variable_subst='$delay_variable_subst' macro_version='`$ECHO "$macro_version" | $SED "$delay_single_quote_subst"`' macro_revision='`$ECHO "$macro_revision" | $SED "$delay_single_quote_subst"`' enable_shared='`$ECHO "$enable_shared" | $SED "$delay_single_quote_subst"`' enable_static='`$ECHO "$enable_static" | $SED "$delay_single_quote_subst"`' pic_mode='`$ECHO "$pic_mode" | $SED "$delay_single_quote_subst"`' enable_fast_install='`$ECHO "$enable_fast_install" | $SED "$delay_single_quote_subst"`' shared_archive_member_spec='`$ECHO "$shared_archive_member_spec" | $SED "$delay_single_quote_subst"`' SHELL='`$ECHO "$SHELL" | $SED "$delay_single_quote_subst"`' ECHO='`$ECHO "$ECHO" | $SED "$delay_single_quote_subst"`' PATH_SEPARATOR='`$ECHO "$PATH_SEPARATOR" | $SED "$delay_single_quote_subst"`' host_alias='`$ECHO "$host_alias" | $SED "$delay_single_quote_subst"`' host='`$ECHO "$host" | $SED "$delay_single_quote_subst"`' host_os='`$ECHO "$host_os" | $SED "$delay_single_quote_subst"`' build_alias='`$ECHO "$build_alias" | $SED "$delay_single_quote_subst"`' build='`$ECHO "$build" | $SED "$delay_single_quote_subst"`' build_os='`$ECHO "$build_os" | $SED "$delay_single_quote_subst"`' SED='`$ECHO "$SED" | $SED "$delay_single_quote_subst"`' Xsed='`$ECHO "$Xsed" | $SED "$delay_single_quote_subst"`' GREP='`$ECHO "$GREP" | $SED "$delay_single_quote_subst"`' EGREP='`$ECHO "$EGREP" | $SED "$delay_single_quote_subst"`' FGREP='`$ECHO "$FGREP" | $SED "$delay_single_quote_subst"`' LD='`$ECHO "$LD" | $SED "$delay_single_quote_subst"`' NM='`$ECHO "$NM" | $SED "$delay_single_quote_subst"`' LN_S='`$ECHO "$LN_S" | $SED "$delay_single_quote_subst"`' max_cmd_len='`$ECHO "$max_cmd_len" | $SED "$delay_single_quote_subst"`' ac_objext='`$ECHO "$ac_objext" | $SED "$delay_single_quote_subst"`' exeext='`$ECHO "$exeext" | $SED "$delay_single_quote_subst"`' lt_unset='`$ECHO "$lt_unset" | $SED "$delay_single_quote_subst"`' lt_SP2NL='`$ECHO "$lt_SP2NL" | $SED "$delay_single_quote_subst"`' lt_NL2SP='`$ECHO "$lt_NL2SP" | $SED "$delay_single_quote_subst"`' lt_cv_to_host_file_cmd='`$ECHO "$lt_cv_to_host_file_cmd" | $SED "$delay_single_quote_subst"`' lt_cv_to_tool_file_cmd='`$ECHO "$lt_cv_to_tool_file_cmd" | $SED "$delay_single_quote_subst"`' reload_flag='`$ECHO "$reload_flag" | $SED "$delay_single_quote_subst"`' reload_cmds='`$ECHO "$reload_cmds" | $SED "$delay_single_quote_subst"`' OBJDUMP='`$ECHO "$OBJDUMP" | $SED "$delay_single_quote_subst"`' deplibs_check_method='`$ECHO "$deplibs_check_method" | $SED "$delay_single_quote_subst"`' file_magic_cmd='`$ECHO "$file_magic_cmd" | $SED "$delay_single_quote_subst"`' file_magic_glob='`$ECHO "$file_magic_glob" | $SED "$delay_single_quote_subst"`' want_nocaseglob='`$ECHO "$want_nocaseglob" | $SED "$delay_single_quote_subst"`' DLLTOOL='`$ECHO "$DLLTOOL" | $SED "$delay_single_quote_subst"`' sharedlib_from_linklib_cmd='`$ECHO "$sharedlib_from_linklib_cmd" | $SED "$delay_single_quote_subst"`' AR='`$ECHO "$AR" | $SED "$delay_single_quote_subst"`' AR_FLAGS='`$ECHO "$AR_FLAGS" | $SED "$delay_single_quote_subst"`' archiver_list_spec='`$ECHO "$archiver_list_spec" | $SED "$delay_single_quote_subst"`' STRIP='`$ECHO "$STRIP" | $SED "$delay_single_quote_subst"`' RANLIB='`$ECHO "$RANLIB" | $SED "$delay_single_quote_subst"`' old_postinstall_cmds='`$ECHO "$old_postinstall_cmds" | $SED "$delay_single_quote_subst"`' old_postuninstall_cmds='`$ECHO "$old_postuninstall_cmds" | $SED "$delay_single_quote_subst"`' old_archive_cmds='`$ECHO "$old_archive_cmds" | $SED "$delay_single_quote_subst"`' lock_old_archive_extraction='`$ECHO "$lock_old_archive_extraction" | $SED "$delay_single_quote_subst"`' CC='`$ECHO "$CC" | $SED "$delay_single_quote_subst"`' CFLAGS='`$ECHO "$CFLAGS" | $SED "$delay_single_quote_subst"`' compiler='`$ECHO "$compiler" | $SED "$delay_single_quote_subst"`' GCC='`$ECHO "$GCC" | $SED "$delay_single_quote_subst"`' lt_cv_sys_global_symbol_pipe='`$ECHO "$lt_cv_sys_global_symbol_pipe" | $SED "$delay_single_quote_subst"`' lt_cv_sys_global_symbol_to_cdecl='`$ECHO "$lt_cv_sys_global_symbol_to_cdecl" | $SED "$delay_single_quote_subst"`' lt_cv_sys_global_symbol_to_import='`$ECHO "$lt_cv_sys_global_symbol_to_import" | $SED "$delay_single_quote_subst"`' lt_cv_sys_global_symbol_to_c_name_address='`$ECHO "$lt_cv_sys_global_symbol_to_c_name_address" | $SED "$delay_single_quote_subst"`' lt_cv_sys_global_symbol_to_c_name_address_lib_prefix='`$ECHO "$lt_cv_sys_global_symbol_to_c_name_address_lib_prefix" | $SED "$delay_single_quote_subst"`' lt_cv_nm_interface='`$ECHO "$lt_cv_nm_interface" | $SED "$delay_single_quote_subst"`' nm_file_list_spec='`$ECHO "$nm_file_list_spec" | $SED "$delay_single_quote_subst"`' lt_sysroot='`$ECHO "$lt_sysroot" | $SED "$delay_single_quote_subst"`' lt_cv_truncate_bin='`$ECHO "$lt_cv_truncate_bin" | $SED "$delay_single_quote_subst"`' objdir='`$ECHO "$objdir" | $SED "$delay_single_quote_subst"`' MAGIC_CMD='`$ECHO "$MAGIC_CMD" | $SED "$delay_single_quote_subst"`' lt_prog_compiler_no_builtin_flag='`$ECHO "$lt_prog_compiler_no_builtin_flag" | $SED "$delay_single_quote_subst"`' lt_prog_compiler_pic='`$ECHO "$lt_prog_compiler_pic" | $SED "$delay_single_quote_subst"`' lt_prog_compiler_wl='`$ECHO "$lt_prog_compiler_wl" | $SED "$delay_single_quote_subst"`' lt_prog_compiler_static='`$ECHO "$lt_prog_compiler_static" | $SED "$delay_single_quote_subst"`' lt_cv_prog_compiler_c_o='`$ECHO "$lt_cv_prog_compiler_c_o" | $SED "$delay_single_quote_subst"`' need_locks='`$ECHO "$need_locks" | $SED "$delay_single_quote_subst"`' MANIFEST_TOOL='`$ECHO "$MANIFEST_TOOL" | $SED "$delay_single_quote_subst"`' DSYMUTIL='`$ECHO "$DSYMUTIL" | $SED "$delay_single_quote_subst"`' NMEDIT='`$ECHO "$NMEDIT" | $SED "$delay_single_quote_subst"`' LIPO='`$ECHO "$LIPO" | $SED "$delay_single_quote_subst"`' OTOOL='`$ECHO "$OTOOL" | $SED "$delay_single_quote_subst"`' OTOOL64='`$ECHO "$OTOOL64" | $SED "$delay_single_quote_subst"`' libext='`$ECHO "$libext" | $SED "$delay_single_quote_subst"`' shrext_cmds='`$ECHO "$shrext_cmds" | $SED "$delay_single_quote_subst"`' extract_expsyms_cmds='`$ECHO "$extract_expsyms_cmds" | $SED "$delay_single_quote_subst"`' archive_cmds_need_lc='`$ECHO "$archive_cmds_need_lc" | $SED "$delay_single_quote_subst"`' enable_shared_with_static_runtimes='`$ECHO "$enable_shared_with_static_runtimes" | $SED "$delay_single_quote_subst"`' export_dynamic_flag_spec='`$ECHO "$export_dynamic_flag_spec" | $SED "$delay_single_quote_subst"`' whole_archive_flag_spec='`$ECHO "$whole_archive_flag_spec" | $SED "$delay_single_quote_subst"`' compiler_needs_object='`$ECHO "$compiler_needs_object" | $SED "$delay_single_quote_subst"`' old_archive_from_new_cmds='`$ECHO "$old_archive_from_new_cmds" | $SED "$delay_single_quote_subst"`' old_archive_from_expsyms_cmds='`$ECHO "$old_archive_from_expsyms_cmds" | $SED "$delay_single_quote_subst"`' archive_cmds='`$ECHO "$archive_cmds" | $SED "$delay_single_quote_subst"`' archive_expsym_cmds='`$ECHO "$archive_expsym_cmds" | $SED "$delay_single_quote_subst"`' module_cmds='`$ECHO "$module_cmds" | $SED "$delay_single_quote_subst"`' module_expsym_cmds='`$ECHO "$module_expsym_cmds" | $SED "$delay_single_quote_subst"`' with_gnu_ld='`$ECHO "$with_gnu_ld" | $SED "$delay_single_quote_subst"`' allow_undefined_flag='`$ECHO "$allow_undefined_flag" | $SED "$delay_single_quote_subst"`' no_undefined_flag='`$ECHO "$no_undefined_flag" | $SED "$delay_single_quote_subst"`' hardcode_libdir_flag_spec='`$ECHO "$hardcode_libdir_flag_spec" | $SED "$delay_single_quote_subst"`' hardcode_libdir_separator='`$ECHO "$hardcode_libdir_separator" | $SED "$delay_single_quote_subst"`' hardcode_direct='`$ECHO "$hardcode_direct" | $SED "$delay_single_quote_subst"`' hardcode_direct_absolute='`$ECHO "$hardcode_direct_absolute" | $SED "$delay_single_quote_subst"`' hardcode_minus_L='`$ECHO "$hardcode_minus_L" | $SED "$delay_single_quote_subst"`' hardcode_shlibpath_var='`$ECHO "$hardcode_shlibpath_var" | $SED "$delay_single_quote_subst"`' hardcode_automatic='`$ECHO "$hardcode_automatic" | $SED "$delay_single_quote_subst"`' inherit_rpath='`$ECHO "$inherit_rpath" | $SED "$delay_single_quote_subst"`' link_all_deplibs='`$ECHO "$link_all_deplibs" | $SED "$delay_single_quote_subst"`' always_export_symbols='`$ECHO "$always_export_symbols" | $SED "$delay_single_quote_subst"`' export_symbols_cmds='`$ECHO "$export_symbols_cmds" | $SED "$delay_single_quote_subst"`' exclude_expsyms='`$ECHO "$exclude_expsyms" | $SED "$delay_single_quote_subst"`' include_expsyms='`$ECHO "$include_expsyms" | $SED "$delay_single_quote_subst"`' prelink_cmds='`$ECHO "$prelink_cmds" | $SED "$delay_single_quote_subst"`' postlink_cmds='`$ECHO "$postlink_cmds" | $SED "$delay_single_quote_subst"`' file_list_spec='`$ECHO "$file_list_spec" | $SED "$delay_single_quote_subst"`' variables_saved_for_relink='`$ECHO "$variables_saved_for_relink" | $SED "$delay_single_quote_subst"`' need_lib_prefix='`$ECHO "$need_lib_prefix" | $SED "$delay_single_quote_subst"`' need_version='`$ECHO "$need_version" | $SED "$delay_single_quote_subst"`' version_type='`$ECHO "$version_type" | $SED "$delay_single_quote_subst"`' runpath_var='`$ECHO "$runpath_var" | $SED "$delay_single_quote_subst"`' shlibpath_var='`$ECHO "$shlibpath_var" | $SED "$delay_single_quote_subst"`' shlibpath_overrides_runpath='`$ECHO "$shlibpath_overrides_runpath" | $SED "$delay_single_quote_subst"`' libname_spec='`$ECHO "$libname_spec" | $SED "$delay_single_quote_subst"`' library_names_spec='`$ECHO "$library_names_spec" | $SED "$delay_single_quote_subst"`' soname_spec='`$ECHO "$soname_spec" | $SED "$delay_single_quote_subst"`' install_override_mode='`$ECHO "$install_override_mode" | $SED "$delay_single_quote_subst"`' postinstall_cmds='`$ECHO "$postinstall_cmds" | $SED "$delay_single_quote_subst"`' postuninstall_cmds='`$ECHO "$postuninstall_cmds" | $SED "$delay_single_quote_subst"`' finish_cmds='`$ECHO "$finish_cmds" | $SED "$delay_single_quote_subst"`' finish_eval='`$ECHO "$finish_eval" | $SED "$delay_single_quote_subst"`' hardcode_into_libs='`$ECHO "$hardcode_into_libs" | $SED "$delay_single_quote_subst"`' sys_lib_search_path_spec='`$ECHO "$sys_lib_search_path_spec" | $SED "$delay_single_quote_subst"`' configure_time_dlsearch_path='`$ECHO "$configure_time_dlsearch_path" | $SED "$delay_single_quote_subst"`' configure_time_lt_sys_library_path='`$ECHO "$configure_time_lt_sys_library_path" | $SED "$delay_single_quote_subst"`' hardcode_action='`$ECHO "$hardcode_action" | $SED "$delay_single_quote_subst"`' enable_dlopen='`$ECHO "$enable_dlopen" | $SED "$delay_single_quote_subst"`' enable_dlopen_self='`$ECHO "$enable_dlopen_self" | $SED "$delay_single_quote_subst"`' enable_dlopen_self_static='`$ECHO "$enable_dlopen_self_static" | $SED "$delay_single_quote_subst"`' old_striplib='`$ECHO "$old_striplib" | $SED "$delay_single_quote_subst"`' striplib='`$ECHO "$striplib" | $SED "$delay_single_quote_subst"`' LTCC='$LTCC' LTCFLAGS='$LTCFLAGS' compiler='$compiler_DEFAULT' # A function that is used when there is no print builtin or printf. func_fallback_echo () { eval 'cat <<_LTECHO_EOF \$1 _LTECHO_EOF' } # Quote evaled strings. for var in SHELL \ ECHO \ PATH_SEPARATOR \ SED \ GREP \ EGREP \ FGREP \ LD \ NM \ LN_S \ lt_SP2NL \ lt_NL2SP \ reload_flag \ OBJDUMP \ deplibs_check_method \ file_magic_cmd \ file_magic_glob \ want_nocaseglob \ DLLTOOL \ sharedlib_from_linklib_cmd \ AR \ AR_FLAGS \ archiver_list_spec \ STRIP \ RANLIB \ CC \ CFLAGS \ compiler \ lt_cv_sys_global_symbol_pipe \ lt_cv_sys_global_symbol_to_cdecl \ lt_cv_sys_global_symbol_to_import \ lt_cv_sys_global_symbol_to_c_name_address \ lt_cv_sys_global_symbol_to_c_name_address_lib_prefix \ lt_cv_nm_interface \ nm_file_list_spec \ lt_cv_truncate_bin \ lt_prog_compiler_no_builtin_flag \ lt_prog_compiler_pic \ lt_prog_compiler_wl \ lt_prog_compiler_static \ lt_cv_prog_compiler_c_o \ need_locks \ MANIFEST_TOOL \ DSYMUTIL \ NMEDIT \ LIPO \ OTOOL \ OTOOL64 \ shrext_cmds \ export_dynamic_flag_spec \ whole_archive_flag_spec \ compiler_needs_object \ with_gnu_ld \ allow_undefined_flag \ no_undefined_flag \ hardcode_libdir_flag_spec \ hardcode_libdir_separator \ exclude_expsyms \ include_expsyms \ file_list_spec \ variables_saved_for_relink \ libname_spec \ library_names_spec \ soname_spec \ install_override_mode \ finish_eval \ old_striplib \ striplib; do case \`eval \\\\\$ECHO \\\\""\\\\\$\$var"\\\\"\` in *[\\\\\\\`\\"\\\$]*) eval "lt_\$var=\\\\\\"\\\`\\\$ECHO \\"\\\$\$var\\" | \\\$SED \\"\\\$sed_quote_subst\\"\\\`\\\\\\"" ## exclude from sc_prohibit_nested_quotes ;; *) eval "lt_\$var=\\\\\\"\\\$\$var\\\\\\"" ;; esac done # Double-quote double-evaled strings. for var in reload_cmds \ old_postinstall_cmds \ old_postuninstall_cmds \ old_archive_cmds \ extract_expsyms_cmds \ old_archive_from_new_cmds \ old_archive_from_expsyms_cmds \ archive_cmds \ archive_expsym_cmds \ module_cmds \ module_expsym_cmds \ export_symbols_cmds \ prelink_cmds \ postlink_cmds \ postinstall_cmds \ postuninstall_cmds \ finish_cmds \ sys_lib_search_path_spec \ configure_time_dlsearch_path \ configure_time_lt_sys_library_path; do case \`eval \\\\\$ECHO \\\\""\\\\\$\$var"\\\\"\` in *[\\\\\\\`\\"\\\$]*) eval "lt_\$var=\\\\\\"\\\`\\\$ECHO \\"\\\$\$var\\" | \\\$SED -e \\"\\\$double_quote_subst\\" -e \\"\\\$sed_quote_subst\\" -e \\"\\\$delay_variable_subst\\"\\\`\\\\\\"" ## exclude from sc_prohibit_nested_quotes ;; *) eval "lt_\$var=\\\\\\"\\\$\$var\\\\\\"" ;; esac done ac_aux_dir='$ac_aux_dir' # See if we are running on zsh, and set the options that allow our # commands through without removal of \ escapes INIT. if test -n "\${ZSH_VERSION+set}"; then setopt NO_GLOB_SUBST fi PACKAGE='$PACKAGE' VERSION='$VERSION' RM='$RM' ofile='$ofile' _ACEOF cat >>$CONFIG_STATUS <<\_ACEOF || ac_write_fail=1 # Handling of arguments. for ac_config_target in $ac_config_targets do case $ac_config_target in "config_ac.h") CONFIG_HEADERS="$CONFIG_HEADERS config_ac.h:config_ac-h.in" ;; "depfiles") CONFIG_COMMANDS="$CONFIG_COMMANDS depfiles" ;; "libtool") CONFIG_COMMANDS="$CONFIG_COMMANDS libtool" ;; "common/Makefile") CONFIG_FILES="$CONFIG_FILES common/Makefile" ;; "docs/Makefile") CONFIG_FILES="$CONFIG_FILES docs/Makefile" ;; "docs/man/Makefile") CONFIG_FILES="$CONFIG_FILES docs/man/Makefile" ;; "genkeymap/Makefile") CONFIG_FILES="$CONFIG_FILES genkeymap/Makefile" ;; "instfiles/default/Makefile") CONFIG_FILES="$CONFIG_FILES instfiles/default/Makefile" ;; "instfiles/init.d/Makefile") CONFIG_FILES="$CONFIG_FILES instfiles/init.d/Makefile" ;; "instfiles/Makefile") CONFIG_FILES="$CONFIG_FILES instfiles/Makefile" ;; "instfiles/pam.d/Makefile") CONFIG_FILES="$CONFIG_FILES instfiles/pam.d/Makefile" ;; "instfiles/pulse/Makefile") CONFIG_FILES="$CONFIG_FILES instfiles/pulse/Makefile" ;; "instfiles/rc.d/Makefile") CONFIG_FILES="$CONFIG_FILES instfiles/rc.d/Makefile" ;; "keygen/Makefile") CONFIG_FILES="$CONFIG_FILES keygen/Makefile" ;; "libxrdp/Makefile") CONFIG_FILES="$CONFIG_FILES libxrdp/Makefile" ;; "Makefile") CONFIG_FILES="$CONFIG_FILES Makefile" ;; "mc/Makefile") CONFIG_FILES="$CONFIG_FILES mc/Makefile" ;; "neutrinordp/Makefile") CONFIG_FILES="$CONFIG_FILES neutrinordp/Makefile" ;; "pkgconfig/Makefile") CONFIG_FILES="$CONFIG_FILES pkgconfig/Makefile" ;; "pkgconfig/xrdp.pc") CONFIG_FILES="$CONFIG_FILES pkgconfig/xrdp.pc" ;; "pkgconfig/xrdp-uninstalled.pc") CONFIG_FILES="$CONFIG_FILES pkgconfig/xrdp-uninstalled.pc" ;; "sesman/chansrv/Makefile") CONFIG_FILES="$CONFIG_FILES sesman/chansrv/Makefile" ;; "sesman/libscp/Makefile") CONFIG_FILES="$CONFIG_FILES sesman/libscp/Makefile" ;; "sesman/Makefile") CONFIG_FILES="$CONFIG_FILES sesman/Makefile" ;; "sesman/tools/Makefile") CONFIG_FILES="$CONFIG_FILES sesman/tools/Makefile" ;; "vnc/Makefile") CONFIG_FILES="$CONFIG_FILES vnc/Makefile" ;; "xrdpapi/Makefile") CONFIG_FILES="$CONFIG_FILES xrdpapi/Makefile" ;; "xrdp/Makefile") CONFIG_FILES="$CONFIG_FILES xrdp/Makefile" ;; "xrdpvr/Makefile") CONFIG_FILES="$CONFIG_FILES xrdpvr/Makefile" ;; "xup/Makefile") CONFIG_FILES="$CONFIG_FILES xup/Makefile" ;; *) as_fn_error $? "invalid argument: \`$ac_config_target'" "$LINENO" 5;; esac done # If the user did not use the arguments to specify the items to instantiate, # then the envvar interface is used. Set only those that are not. # We use the long form for the default assignment because of an extremely # bizarre bug on SunOS 4.1.3. if $ac_need_defaults; then test "${CONFIG_FILES+set}" = set || CONFIG_FILES=$config_files test "${CONFIG_HEADERS+set}" = set || CONFIG_HEADERS=$config_headers test "${CONFIG_COMMANDS+set}" = set || CONFIG_COMMANDS=$config_commands fi # Have a temporary directory for convenience. Make it in the build tree # simply because there is no reason against having it here, and in addition, # creating and moving files from /tmp can sometimes cause problems. # Hook for its removal unless debugging. # Note that there is a small window in which the directory will not be cleaned: # after its creation but before its name has been assigned to `$tmp'. $debug || { tmp= ac_tmp= trap 'exit_status=$? : "${ac_tmp:=$tmp}" { test ! -d "$ac_tmp" || rm -fr "$ac_tmp"; } && exit $exit_status ' 0 trap 'as_fn_exit 1' 1 2 13 15 } # Create a (secure) tmp directory for tmp files. { tmp=`(umask 077 && mktemp -d "./confXXXXXX") 2>/dev/null` && test -d "$tmp" } || { tmp=./conf$$-$RANDOM (umask 077 && mkdir "$tmp") } || as_fn_error $? "cannot create a temporary directory in ." "$LINENO" 5 ac_tmp=$tmp # Set up the scripts for CONFIG_FILES section. # No need to generate them if there are no CONFIG_FILES. # This happens for instance with `./config.status config.h'. if test -n "$CONFIG_FILES"; then ac_cr=`echo X | tr X '\015'` # On cygwin, bash can eat \r inside `` if the user requested igncr. # But we know of no other shell where ac_cr would be empty at this # point, so we can use a bashism as a fallback. if test "x$ac_cr" = x; then eval ac_cr=\$\'\\r\' fi ac_cs_awk_cr=`$AWK 'BEGIN { print "a\rb" }' /dev/null` if test "$ac_cs_awk_cr" = "a${ac_cr}b"; then ac_cs_awk_cr='\\r' else ac_cs_awk_cr=$ac_cr fi echo 'BEGIN {' >"$ac_tmp/subs1.awk" && _ACEOF { echo "cat >conf$$subs.awk <<_ACEOF" && echo "$ac_subst_vars" | sed 's/.*/&!$&$ac_delim/' && echo "_ACEOF" } >conf$$subs.sh || as_fn_error $? "could not make $CONFIG_STATUS" "$LINENO" 5 ac_delim_num=`echo "$ac_subst_vars" | grep -c '^'` ac_delim='%!_!# ' for ac_last_try in false false false false false :; do . ./conf$$subs.sh || as_fn_error $? "could not make $CONFIG_STATUS" "$LINENO" 5 ac_delim_n=`sed -n "s/.*$ac_delim\$/X/p" conf$$subs.awk | grep -c X` if test $ac_delim_n = $ac_delim_num; then break elif $ac_last_try; then as_fn_error $? "could not make $CONFIG_STATUS" "$LINENO" 5 else ac_delim="$ac_delim!$ac_delim _$ac_delim!! " fi done rm -f conf$$subs.sh cat >>$CONFIG_STATUS <<_ACEOF || ac_write_fail=1 cat >>"\$ac_tmp/subs1.awk" <<\\_ACAWK && _ACEOF sed -n ' h s/^/S["/; s/!.*/"]=/ p g s/^[^!]*!// :repl t repl s/'"$ac_delim"'$// t delim :nl h s/\(.\{148\}\)..*/\1/ t more1 s/["\\]/\\&/g; s/^/"/; s/$/\\n"\\/ p n b repl :more1 s/["\\]/\\&/g; s/^/"/; s/$/"\\/ p g s/.\{148\}// t nl :delim h s/\(.\{148\}\)..*/\1/ t more2 s/["\\]/\\&/g; s/^/"/; s/$/"/ p b :more2 s/["\\]/\\&/g; s/^/"/; s/$/"\\/ p g s/.\{148\}// t delim ' >$CONFIG_STATUS || ac_write_fail=1 rm -f conf$$subs.awk cat >>$CONFIG_STATUS <<_ACEOF || ac_write_fail=1 _ACAWK cat >>"\$ac_tmp/subs1.awk" <<_ACAWK && for (key in S) S_is_set[key] = 1 FS = "" } { line = $ 0 nfields = split(line, field, "@") substed = 0 len = length(field[1]) for (i = 2; i < nfields; i++) { key = field[i] keylen = length(key) if (S_is_set[key]) { value = S[key] line = substr(line, 1, len) "" value "" substr(line, len + keylen + 3) len += length(value) + length(field[++i]) substed = 1 } else len += 1 + keylen } print line } _ACAWK _ACEOF cat >>$CONFIG_STATUS <<\_ACEOF || ac_write_fail=1 if sed "s/$ac_cr//" < /dev/null > /dev/null 2>&1; then sed "s/$ac_cr\$//; s/$ac_cr/$ac_cs_awk_cr/g" else cat fi < "$ac_tmp/subs1.awk" > "$ac_tmp/subs.awk" \ || as_fn_error $? "could not setup config files machinery" "$LINENO" 5 _ACEOF # VPATH may cause trouble with some makes, so we remove sole $(srcdir), # ${srcdir} and @srcdir@ entries from VPATH if srcdir is ".", strip leading and # trailing colons and then remove the whole line if VPATH becomes empty # (actually we leave an empty line to preserve line numbers). if test "x$srcdir" = x.; then ac_vpsub='/^[ ]*VPATH[ ]*=[ ]*/{ h s/// s/^/:/ s/[ ]*$/:/ s/:\$(srcdir):/:/g s/:\${srcdir}:/:/g s/:@srcdir@:/:/g s/^:*// s/:*$// x s/\(=[ ]*\).*/\1/ G s/\n// s/^[^=]*=[ ]*$// }' fi cat >>$CONFIG_STATUS <<\_ACEOF || ac_write_fail=1 fi # test -n "$CONFIG_FILES" # Set up the scripts for CONFIG_HEADERS section. # No need to generate them if there are no CONFIG_HEADERS. # This happens for instance with `./config.status Makefile'. if test -n "$CONFIG_HEADERS"; then cat >"$ac_tmp/defines.awk" <<\_ACAWK || BEGIN { _ACEOF # Transform confdefs.h into an awk script `defines.awk', embedded as # here-document in config.status, that substitutes the proper values into # config.h.in to produce config.h. # Create a delimiter string that does not exist in confdefs.h, to ease # handling of long lines. ac_delim='%!_!# ' for ac_last_try in false false :; do ac_tt=`sed -n "/$ac_delim/p" confdefs.h` if test -z "$ac_tt"; then break elif $ac_last_try; then as_fn_error $? "could not make $CONFIG_HEADERS" "$LINENO" 5 else ac_delim="$ac_delim!$ac_delim _$ac_delim!! " fi done # For the awk script, D is an array of macro values keyed by name, # likewise P contains macro parameters if any. Preserve backslash # newline sequences. ac_word_re=[_$as_cr_Letters][_$as_cr_alnum]* sed -n ' s/.\{148\}/&'"$ac_delim"'/g t rset :rset s/^[ ]*#[ ]*define[ ][ ]*/ / t def d :def s/\\$// t bsnl s/["\\]/\\&/g s/^ \('"$ac_word_re"'\)\(([^()]*)\)[ ]*\(.*\)/P["\1"]="\2"\ D["\1"]=" \3"/p s/^ \('"$ac_word_re"'\)[ ]*\(.*\)/D["\1"]=" \2"/p d :bsnl s/["\\]/\\&/g s/^ \('"$ac_word_re"'\)\(([^()]*)\)[ ]*\(.*\)/P["\1"]="\2"\ D["\1"]=" \3\\\\\\n"\\/p t cont s/^ \('"$ac_word_re"'\)[ ]*\(.*\)/D["\1"]=" \2\\\\\\n"\\/p t cont d :cont n s/.\{148\}/&'"$ac_delim"'/g t clear :clear s/\\$// t bsnlc s/["\\]/\\&/g; s/^/"/; s/$/"/p d :bsnlc s/["\\]/\\&/g; s/^/"/; s/$/\\\\\\n"\\/p b cont ' >$CONFIG_STATUS || ac_write_fail=1 cat >>$CONFIG_STATUS <<_ACEOF || ac_write_fail=1 for (key in D) D_is_set[key] = 1 FS = "" } /^[\t ]*#[\t ]*(define|undef)[\t ]+$ac_word_re([\t (]|\$)/ { line = \$ 0 split(line, arg, " ") if (arg[1] == "#") { defundef = arg[2] mac1 = arg[3] } else { defundef = substr(arg[1], 2) mac1 = arg[2] } split(mac1, mac2, "(") #) macro = mac2[1] prefix = substr(line, 1, index(line, defundef) - 1) if (D_is_set[macro]) { # Preserve the white space surrounding the "#". print prefix "define", macro P[macro] D[macro] next } else { # Replace #undef with comments. This is necessary, for example, # in the case of _POSIX_SOURCE, which is predefined and required # on some systems where configure will not decide to define it. if (defundef == "undef") { print "/*", prefix defundef, macro, "*/" next } } } { print } _ACAWK _ACEOF cat >>$CONFIG_STATUS <<\_ACEOF || ac_write_fail=1 as_fn_error $? "could not setup config headers machinery" "$LINENO" 5 fi # test -n "$CONFIG_HEADERS" eval set X " :F $CONFIG_FILES :H $CONFIG_HEADERS :C $CONFIG_COMMANDS" shift for ac_tag do case $ac_tag in :[FHLC]) ac_mode=$ac_tag; continue;; esac case $ac_mode$ac_tag in :[FHL]*:*);; :L* | :C*:*) as_fn_error $? "invalid tag \`$ac_tag'" "$LINENO" 5;; :[FH]-) ac_tag=-:-;; :[FH]*) ac_tag=$ac_tag:$ac_tag.in;; esac ac_save_IFS=$IFS IFS=: set x $ac_tag IFS=$ac_save_IFS shift ac_file=$1 shift case $ac_mode in :L) ac_source=$1;; :[FH]) ac_file_inputs= for ac_f do case $ac_f in -) ac_f="$ac_tmp/stdin";; *) # Look for the file first in the build tree, then in the source tree # (if the path is not absolute). The absolute path cannot be DOS-style, # because $ac_f cannot contain `:'. test -f "$ac_f" || case $ac_f in [\\/$]*) false;; *) test -f "$srcdir/$ac_f" && ac_f="$srcdir/$ac_f";; esac || as_fn_error 1 "cannot find input file: \`$ac_f'" "$LINENO" 5;; esac case $ac_f in *\'*) ac_f=`$as_echo "$ac_f" | sed "s/'/'\\\\\\\\''/g"`;; esac as_fn_append ac_file_inputs " '$ac_f'" done # Let's still pretend it is `configure' which instantiates (i.e., don't # use $as_me), people would be surprised to read: # /* config.h. Generated by config.status. */ configure_input='Generated from '` $as_echo "$*" | sed 's|^[^:]*/||;s|:[^:]*/|, |g' `' by configure.' if test x"$ac_file" != x-; then configure_input="$ac_file. $configure_input" { $as_echo "$as_me:${as_lineno-$LINENO}: creating $ac_file" >&5 $as_echo "$as_me: creating $ac_file" >&6;} fi # Neutralize special characters interpreted by sed in replacement strings. case $configure_input in #( *\&* | *\|* | *\\* ) ac_sed_conf_input=`$as_echo "$configure_input" | sed 's/[\\\\&|]/\\\\&/g'`;; #( *) ac_sed_conf_input=$configure_input;; esac case $ac_tag in *:-:* | *:-) cat >"$ac_tmp/stdin" \ || as_fn_error $? "could not create $ac_file" "$LINENO" 5 ;; esac ;; esac ac_dir=`$as_dirname -- "$ac_file" || $as_expr X"$ac_file" : 'X\(.*[^/]\)//*[^/][^/]*/*$' \| \ X"$ac_file" : 'X\(//\)[^/]' \| \ X"$ac_file" : 'X\(//\)$' \| \ X"$ac_file" : 'X\(/\)' \| . 2>/dev/null || $as_echo X"$ac_file" | sed '/^X\(.*[^/]\)\/\/*[^/][^/]*\/*$/{ s//\1/ q } /^X\(\/\/\)[^/].*/{ s//\1/ q } /^X\(\/\/\)$/{ s//\1/ q } /^X\(\/\).*/{ s//\1/ q } s/.*/./; q'` as_dir="$ac_dir"; as_fn_mkdir_p ac_builddir=. case "$ac_dir" in .) ac_dir_suffix= ac_top_builddir_sub=. ac_top_build_prefix= ;; *) ac_dir_suffix=/`$as_echo "$ac_dir" | sed 's|^\.[\\/]||'` # A ".." for each directory in $ac_dir_suffix. ac_top_builddir_sub=`$as_echo "$ac_dir_suffix" | sed 's|/[^\\/]*|/..|g;s|/||'` case $ac_top_builddir_sub in "") ac_top_builddir_sub=. ac_top_build_prefix= ;; *) ac_top_build_prefix=$ac_top_builddir_sub/ ;; esac ;; esac ac_abs_top_builddir=$ac_pwd ac_abs_builddir=$ac_pwd$ac_dir_suffix # for backward compatibility: ac_top_builddir=$ac_top_build_prefix case $srcdir in .) # We are building in place. ac_srcdir=. ac_top_srcdir=$ac_top_builddir_sub ac_abs_top_srcdir=$ac_pwd ;; [\\/]* | ?:[\\/]* ) # Absolute name. ac_srcdir=$srcdir$ac_dir_suffix; ac_top_srcdir=$srcdir ac_abs_top_srcdir=$srcdir ;; *) # Relative name. ac_srcdir=$ac_top_build_prefix$srcdir$ac_dir_suffix ac_top_srcdir=$ac_top_build_prefix$srcdir ac_abs_top_srcdir=$ac_pwd/$srcdir ;; esac ac_abs_srcdir=$ac_abs_top_srcdir$ac_dir_suffix case $ac_mode in :F) # # CONFIG_FILE # case $INSTALL in [\\/$]* | ?:[\\/]* ) ac_INSTALL=$INSTALL ;; *) ac_INSTALL=$ac_top_build_prefix$INSTALL ;; esac ac_MKDIR_P=$MKDIR_P case $MKDIR_P in [\\/$]* | ?:[\\/]* ) ;; */*) ac_MKDIR_P=$ac_top_build_prefix$MKDIR_P ;; esac _ACEOF cat >>$CONFIG_STATUS <<\_ACEOF || ac_write_fail=1 # If the template does not know about datarootdir, expand it. # FIXME: This hack should be removed a few years after 2.60. ac_datarootdir_hack=; ac_datarootdir_seen= ac_sed_dataroot=' /datarootdir/ { p q } /@datadir@/p /@docdir@/p /@infodir@/p /@localedir@/p /@mandir@/p' case `eval "sed -n \"\$ac_sed_dataroot\" $ac_file_inputs"` in *datarootdir*) ac_datarootdir_seen=yes;; *@datadir@*|*@docdir@*|*@infodir@*|*@localedir@*|*@mandir@*) { $as_echo "$as_me:${as_lineno-$LINENO}: WARNING: $ac_file_inputs seems to ignore the --datarootdir setting" >&5 $as_echo "$as_me: WARNING: $ac_file_inputs seems to ignore the --datarootdir setting" >&2;} _ACEOF cat >>$CONFIG_STATUS <<_ACEOF || ac_write_fail=1 ac_datarootdir_hack=' s&@datadir@&$datadir&g s&@docdir@&$docdir&g s&@infodir@&$infodir&g s&@localedir@&$localedir&g s&@mandir@&$mandir&g s&\\\${datarootdir}&$datarootdir&g' ;; esac _ACEOF # Neutralize VPATH when `$srcdir' = `.'. # Shell code in configure.ac might set extrasub. # FIXME: do we really want to maintain this feature? cat >>$CONFIG_STATUS <<_ACEOF || ac_write_fail=1 ac_sed_extra="$ac_vpsub $extrasub _ACEOF cat >>$CONFIG_STATUS <<\_ACEOF || ac_write_fail=1 :t /@[a-zA-Z_][a-zA-Z_0-9]*@/!b s|@configure_input@|$ac_sed_conf_input|;t t s&@top_builddir@&$ac_top_builddir_sub&;t t s&@top_build_prefix@&$ac_top_build_prefix&;t t s&@srcdir@&$ac_srcdir&;t t s&@abs_srcdir@&$ac_abs_srcdir&;t t s&@top_srcdir@&$ac_top_srcdir&;t t s&@abs_top_srcdir@&$ac_abs_top_srcdir&;t t s&@builddir@&$ac_builddir&;t t s&@abs_builddir@&$ac_abs_builddir&;t t s&@abs_top_builddir@&$ac_abs_top_builddir&;t t s&@INSTALL@&$ac_INSTALL&;t t s&@MKDIR_P@&$ac_MKDIR_P&;t t $ac_datarootdir_hack " eval sed \"\$ac_sed_extra\" "$ac_file_inputs" | $AWK -f "$ac_tmp/subs.awk" \ >$ac_tmp/out || as_fn_error $? "could not create $ac_file" "$LINENO" 5 test -z "$ac_datarootdir_hack$ac_datarootdir_seen" && { ac_out=`sed -n '/\${datarootdir}/p' "$ac_tmp/out"`; test -n "$ac_out"; } && { ac_out=`sed -n '/^[ ]*datarootdir[ ]*:*=/p' \ "$ac_tmp/out"`; test -z "$ac_out"; } && { $as_echo "$as_me:${as_lineno-$LINENO}: WARNING: $ac_file contains a reference to the variable \`datarootdir' which seems to be undefined. Please make sure it is defined" >&5 $as_echo "$as_me: WARNING: $ac_file contains a reference to the variable \`datarootdir' which seems to be undefined. Please make sure it is defined" >&2;} rm -f "$ac_tmp/stdin" case $ac_file in -) cat "$ac_tmp/out" && rm -f "$ac_tmp/out";; *) rm -f "$ac_file" && mv "$ac_tmp/out" "$ac_file";; esac \ || as_fn_error $? "could not create $ac_file" "$LINENO" 5 ;; :H) # # CONFIG_HEADER # if test x"$ac_file" != x-; then { $as_echo "/* $configure_input */" \ && eval '$AWK -f "$ac_tmp/defines.awk"' "$ac_file_inputs" } >"$ac_tmp/config.h" \ || as_fn_error $? "could not create $ac_file" "$LINENO" 5 if diff "$ac_file" "$ac_tmp/config.h" >/dev/null 2>&1; then { $as_echo "$as_me:${as_lineno-$LINENO}: $ac_file is unchanged" >&5 $as_echo "$as_me: $ac_file is unchanged" >&6;} else rm -f "$ac_file" mv "$ac_tmp/config.h" "$ac_file" \ || as_fn_error $? "could not create $ac_file" "$LINENO" 5 fi else $as_echo "/* $configure_input */" \ && eval '$AWK -f "$ac_tmp/defines.awk"' "$ac_file_inputs" \ || as_fn_error $? "could not create -" "$LINENO" 5 fi # Compute "$ac_file"'s index in $config_headers. _am_arg="$ac_file" _am_stamp_count=1 for _am_header in $config_headers :; do case $_am_header in $_am_arg | $_am_arg:* ) break ;; * ) _am_stamp_count=`expr $_am_stamp_count + 1` ;; esac done echo "timestamp for $_am_arg" >`$as_dirname -- "$_am_arg" || $as_expr X"$_am_arg" : 'X\(.*[^/]\)//*[^/][^/]*/*$' \| \ X"$_am_arg" : 'X\(//\)[^/]' \| \ X"$_am_arg" : 'X\(//\)$' \| \ X"$_am_arg" : 'X\(/\)' \| . 2>/dev/null || $as_echo X"$_am_arg" | sed '/^X\(.*[^/]\)\/\/*[^/][^/]*\/*$/{ s//\1/ q } /^X\(\/\/\)[^/].*/{ s//\1/ q } /^X\(\/\/\)$/{ s//\1/ q } /^X\(\/\).*/{ s//\1/ q } s/.*/./; q'`/stamp-h$_am_stamp_count ;; :C) { $as_echo "$as_me:${as_lineno-$LINENO}: executing $ac_file commands" >&5 $as_echo "$as_me: executing $ac_file commands" >&6;} ;; esac case $ac_file$ac_mode in "depfiles":C) test x"$AMDEP_TRUE" != x"" || { # Older Autoconf quotes --file arguments for eval, but not when files # are listed without --file. Let's play safe and only enable the eval # if we detect the quoting. case $CONFIG_FILES in *\'*) eval set x "$CONFIG_FILES" ;; *) set x $CONFIG_FILES ;; esac shift for mf do # Strip MF so we end up with the name of the file. mf=`echo "$mf" | sed -e 's/:.*$//'` # Check whether this is an Automake generated Makefile or not. # We used to match only the files named 'Makefile.in', but # some people rename them; so instead we look at the file content. # Grep'ing the first line is not enough: some people post-process # each Makefile.in and add a new line on top of each file to say so. # Grep'ing the whole file is not good either: AIX grep has a line # limit of 2048, but all sed's we know have understand at least 4000. if sed -n 's,^#.*generated by automake.*,X,p' "$mf" | grep X >/dev/null 2>&1; then dirpart=`$as_dirname -- "$mf" || $as_expr X"$mf" : 'X\(.*[^/]\)//*[^/][^/]*/*$' \| \ X"$mf" : 'X\(//\)[^/]' \| \ X"$mf" : 'X\(//\)$' \| \ X"$mf" : 'X\(/\)' \| . 2>/dev/null || $as_echo X"$mf" | sed '/^X\(.*[^/]\)\/\/*[^/][^/]*\/*$/{ s//\1/ q } /^X\(\/\/\)[^/].*/{ s//\1/ q } /^X\(\/\/\)$/{ s//\1/ q } /^X\(\/\).*/{ s//\1/ q } s/.*/./; q'` else continue fi # Extract the definition of DEPDIR, am__include, and am__quote # from the Makefile without running 'make'. DEPDIR=`sed -n 's/^DEPDIR = //p' < "$mf"` test -z "$DEPDIR" && continue am__include=`sed -n 's/^am__include = //p' < "$mf"` test -z "$am__include" && continue am__quote=`sed -n 's/^am__quote = //p' < "$mf"` # Find all dependency output files, they are included files with # $(DEPDIR) in their names. We invoke sed twice because it is the # simplest approach to changing $(DEPDIR) to its actual value in the # expansion. for file in `sed -n " s/^$am__include $am__quote\(.*(DEPDIR).*\)$am__quote"'$/\1/p' <"$mf" | \ sed -e 's/\$(DEPDIR)/'"$DEPDIR"'/g'`; do # Make sure the directory exists. test -f "$dirpart/$file" && continue fdir=`$as_dirname -- "$file" || $as_expr X"$file" : 'X\(.*[^/]\)//*[^/][^/]*/*$' \| \ X"$file" : 'X\(//\)[^/]' \| \ X"$file" : 'X\(//\)$' \| \ X"$file" : 'X\(/\)' \| . 2>/dev/null || $as_echo X"$file" | sed '/^X\(.*[^/]\)\/\/*[^/][^/]*\/*$/{ s//\1/ q } /^X\(\/\/\)[^/].*/{ s//\1/ q } /^X\(\/\/\)$/{ s//\1/ q } /^X\(\/\).*/{ s//\1/ q } s/.*/./; q'` as_dir=$dirpart/$fdir; as_fn_mkdir_p # echo "creating $dirpart/$file" echo '# dummy' > "$dirpart/$file" done done } ;; "libtool":C) # See if we are running on zsh, and set the options that allow our # commands through without removal of \ escapes. if test -n "${ZSH_VERSION+set}"; then setopt NO_GLOB_SUBST fi cfgfile=${ofile}T trap "$RM \"$cfgfile\"; exit 1" 1 2 15 $RM "$cfgfile" cat <<_LT_EOF >> "$cfgfile" #! $SHELL # Generated automatically by $as_me ($PACKAGE) $VERSION # Libtool was configured on host `(hostname || uname -n) 2>/dev/null | sed 1q`: # NOTE: Changes made to this file will be lost: look at ltmain.sh. # Provide generalized library-building support services. # Written by Gordon Matzigkeit, 1996 # Copyright (C) 2014 Free Software Foundation, Inc. # This is free software; see the source for copying conditions. There is NO # warranty; not even for MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. # GNU Libtool 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 2 of of the License, or # (at your option) any later version. # # As a special exception to the GNU General Public License, if you # distribute this file as part of a program or library that is built # using GNU Libtool, you may include this file under the same # distribution terms that you use for the rest of that program. # # GNU Libtool 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. # # You should have received a copy of the GNU General Public License # along with this program. If not, see . # The names of the tagged configurations supported by this script. available_tags='' # Configured defaults for sys_lib_dlsearch_path munging. : \${LT_SYS_LIBRARY_PATH="$configure_time_lt_sys_library_path"} # ### BEGIN LIBTOOL CONFIG # Which release of libtool.m4 was used? macro_version=$macro_version macro_revision=$macro_revision # Whether or not to build shared libraries. build_libtool_libs=$enable_shared # Whether or not to build static libraries. build_old_libs=$enable_static # What type of objects to build. pic_mode=$pic_mode # Whether or not to optimize for fast installation. fast_install=$enable_fast_install # Shared archive member basename,for filename based shared library versioning on AIX. shared_archive_member_spec=$shared_archive_member_spec # Shell to use when invoking shell scripts. SHELL=$lt_SHELL # An echo program that protects backslashes. ECHO=$lt_ECHO # The PATH separator for the build system. PATH_SEPARATOR=$lt_PATH_SEPARATOR # The host system. host_alias=$host_alias host=$host host_os=$host_os # The build system. build_alias=$build_alias build=$build build_os=$build_os # A sed program that does not truncate output. SED=$lt_SED # Sed that helps us avoid accidentally triggering echo(1) options like -n. Xsed="\$SED -e 1s/^X//" # A grep program that handles long lines. GREP=$lt_GREP # An ERE matcher. EGREP=$lt_EGREP # A literal string matcher. FGREP=$lt_FGREP # A BSD- or MS-compatible name lister. NM=$lt_NM # Whether we need soft or hard links. LN_S=$lt_LN_S # What is the maximum length of a command? max_cmd_len=$max_cmd_len # Object file suffix (normally "o"). objext=$ac_objext # Executable file suffix (normally ""). exeext=$exeext # whether the shell understands "unset". lt_unset=$lt_unset # turn spaces into newlines. SP2NL=$lt_lt_SP2NL # turn newlines into spaces. NL2SP=$lt_lt_NL2SP # convert \$build file names to \$host format. to_host_file_cmd=$lt_cv_to_host_file_cmd # convert \$build files to toolchain format. to_tool_file_cmd=$lt_cv_to_tool_file_cmd # An object symbol dumper. OBJDUMP=$lt_OBJDUMP # Method to check whether dependent libraries are shared objects. deplibs_check_method=$lt_deplibs_check_method # Command to use when deplibs_check_method = "file_magic". file_magic_cmd=$lt_file_magic_cmd # How to find potential files when deplibs_check_method = "file_magic". file_magic_glob=$lt_file_magic_glob # Find potential files using nocaseglob when deplibs_check_method = "file_magic". want_nocaseglob=$lt_want_nocaseglob # DLL creation program. DLLTOOL=$lt_DLLTOOL # Command to associate shared and link libraries. sharedlib_from_linklib_cmd=$lt_sharedlib_from_linklib_cmd # The archiver. AR=$lt_AR # Flags to create an archive. AR_FLAGS=$lt_AR_FLAGS # How to feed a file listing to the archiver. archiver_list_spec=$lt_archiver_list_spec # A symbol stripping program. STRIP=$lt_STRIP # Commands used to install an old-style archive. RANLIB=$lt_RANLIB old_postinstall_cmds=$lt_old_postinstall_cmds old_postuninstall_cmds=$lt_old_postuninstall_cmds # Whether to use a lock for old archive extraction. lock_old_archive_extraction=$lock_old_archive_extraction # A C compiler. LTCC=$lt_CC # LTCC compiler flags. LTCFLAGS=$lt_CFLAGS # Take the output of nm and produce a listing of raw symbols and C names. global_symbol_pipe=$lt_lt_cv_sys_global_symbol_pipe # Transform the output of nm in a proper C declaration. global_symbol_to_cdecl=$lt_lt_cv_sys_global_symbol_to_cdecl # Transform the output of nm into a list of symbols to manually relocate. global_symbol_to_import=$lt_lt_cv_sys_global_symbol_to_import # Transform the output of nm in a C name address pair. global_symbol_to_c_name_address=$lt_lt_cv_sys_global_symbol_to_c_name_address # Transform the output of nm in a C name address pair when lib prefix is needed. global_symbol_to_c_name_address_lib_prefix=$lt_lt_cv_sys_global_symbol_to_c_name_address_lib_prefix # The name lister interface. nm_interface=$lt_lt_cv_nm_interface # Specify filename containing input files for \$NM. nm_file_list_spec=$lt_nm_file_list_spec # The root where to search for dependent libraries,and where our libraries should be installed. lt_sysroot=$lt_sysroot # Command to truncate a binary pipe. lt_truncate_bin=$lt_lt_cv_truncate_bin # The name of the directory that contains temporary libtool files. objdir=$objdir # Used to examine libraries when file_magic_cmd begins with "file". MAGIC_CMD=$MAGIC_CMD # Must we lock files when doing compilation? need_locks=$lt_need_locks # Manifest tool. MANIFEST_TOOL=$lt_MANIFEST_TOOL # Tool to manipulate archived DWARF debug symbol files on Mac OS X. DSYMUTIL=$lt_DSYMUTIL # Tool to change global to local symbols on Mac OS X. NMEDIT=$lt_NMEDIT # Tool to manipulate fat objects and archives on Mac OS X. LIPO=$lt_LIPO # ldd/readelf like tool for Mach-O binaries on Mac OS X. OTOOL=$lt_OTOOL # ldd/readelf like tool for 64 bit Mach-O binaries on Mac OS X 10.4. OTOOL64=$lt_OTOOL64 # Old archive suffix (normally "a"). libext=$libext # Shared library suffix (normally ".so"). shrext_cmds=$lt_shrext_cmds # The commands to extract the exported symbol list from a shared archive. extract_expsyms_cmds=$lt_extract_expsyms_cmds # Variables whose values should be saved in libtool wrapper scripts and # restored at link time. variables_saved_for_relink=$lt_variables_saved_for_relink # Do we need the "lib" prefix for modules? need_lib_prefix=$need_lib_prefix # Do we need a version for libraries? need_version=$need_version # Library versioning type. version_type=$version_type # Shared library runtime path variable. runpath_var=$runpath_var # Shared library path variable. shlibpath_var=$shlibpath_var # Is shlibpath searched before the hard-coded library search path? shlibpath_overrides_runpath=$shlibpath_overrides_runpath # Format of library name prefix. libname_spec=$lt_libname_spec # List of archive names. First name is the real one, the rest are links. # The last name is the one that the linker finds with -lNAME library_names_spec=$lt_library_names_spec # The coded name of the library, if different from the real name. soname_spec=$lt_soname_spec # Permission mode override for installation of shared libraries. install_override_mode=$lt_install_override_mode # Command to use after installation of a shared archive. postinstall_cmds=$lt_postinstall_cmds # Command to use after uninstallation of a shared archive. postuninstall_cmds=$lt_postuninstall_cmds # Commands used to finish a libtool library installation in a directory. finish_cmds=$lt_finish_cmds # As "finish_cmds", except a single script fragment to be evaled but # not shown. finish_eval=$lt_finish_eval # Whether we should hardcode library paths into libraries. hardcode_into_libs=$hardcode_into_libs # Compile-time system search path for libraries. sys_lib_search_path_spec=$lt_sys_lib_search_path_spec # Detected run-time system search path for libraries. sys_lib_dlsearch_path_spec=$lt_configure_time_dlsearch_path # Explicit LT_SYS_LIBRARY_PATH set during ./configure time. configure_time_lt_sys_library_path=$lt_configure_time_lt_sys_library_path # Whether dlopen is supported. dlopen_support=$enable_dlopen # Whether dlopen of programs is supported. dlopen_self=$enable_dlopen_self # Whether dlopen of statically linked programs is supported. dlopen_self_static=$enable_dlopen_self_static # Commands to strip libraries. old_striplib=$lt_old_striplib striplib=$lt_striplib # The linker used to build libraries. LD=$lt_LD # How to create reloadable object files. reload_flag=$lt_reload_flag reload_cmds=$lt_reload_cmds # Commands used to build an old-style archive. old_archive_cmds=$lt_old_archive_cmds # A language specific compiler. CC=$lt_compiler # Is the compiler the GNU compiler? with_gcc=$GCC # Compiler flag to turn off builtin functions. no_builtin_flag=$lt_lt_prog_compiler_no_builtin_flag # Additional compiler flags for building library objects. pic_flag=$lt_lt_prog_compiler_pic # How to pass a linker flag through the compiler. wl=$lt_lt_prog_compiler_wl # Compiler flag to prevent dynamic linking. link_static_flag=$lt_lt_prog_compiler_static # Does compiler simultaneously support -c and -o options? compiler_c_o=$lt_lt_cv_prog_compiler_c_o # Whether or not to add -lc for building shared libraries. build_libtool_need_lc=$archive_cmds_need_lc # Whether or not to disallow shared libs when runtime libs are static. allow_libtool_libs_with_static_runtimes=$enable_shared_with_static_runtimes # Compiler flag to allow reflexive dlopens. export_dynamic_flag_spec=$lt_export_dynamic_flag_spec # Compiler flag to generate shared objects directly from archives. whole_archive_flag_spec=$lt_whole_archive_flag_spec # Whether the compiler copes with passing no objects directly. compiler_needs_object=$lt_compiler_needs_object # Create an old-style archive from a shared archive. old_archive_from_new_cmds=$lt_old_archive_from_new_cmds # Create a temporary old-style archive to link instead of a shared archive. old_archive_from_expsyms_cmds=$lt_old_archive_from_expsyms_cmds # Commands used to build a shared archive. archive_cmds=$lt_archive_cmds archive_expsym_cmds=$lt_archive_expsym_cmds # Commands used to build a loadable module if different from building # a shared archive. module_cmds=$lt_module_cmds module_expsym_cmds=$lt_module_expsym_cmds # Whether we are building with GNU ld or not. with_gnu_ld=$lt_with_gnu_ld # Flag that allows shared libraries with undefined symbols to be built. allow_undefined_flag=$lt_allow_undefined_flag # Flag that enforces no undefined symbols. no_undefined_flag=$lt_no_undefined_flag # Flag to hardcode \$libdir into a binary during linking. # This must work even if \$libdir does not exist hardcode_libdir_flag_spec=$lt_hardcode_libdir_flag_spec # Whether we need a single "-rpath" flag with a separated argument. hardcode_libdir_separator=$lt_hardcode_libdir_separator # Set to "yes" if using DIR/libNAME\$shared_ext during linking hardcodes # DIR into the resulting binary. hardcode_direct=$hardcode_direct # Set to "yes" if using DIR/libNAME\$shared_ext during linking hardcodes # DIR into the resulting binary and the resulting library dependency is # "absolute",i.e impossible to change by setting \$shlibpath_var if the # library is relocated. hardcode_direct_absolute=$hardcode_direct_absolute # Set to "yes" if using the -LDIR flag during linking hardcodes DIR # into the resulting binary. hardcode_minus_L=$hardcode_minus_L # Set to "yes" if using SHLIBPATH_VAR=DIR during linking hardcodes DIR # into the resulting binary. hardcode_shlibpath_var=$hardcode_shlibpath_var # Set to "yes" if building a shared library automatically hardcodes DIR # into the library and all subsequent libraries and executables linked # against it. hardcode_automatic=$hardcode_automatic # Set to yes if linker adds runtime paths of dependent libraries # to runtime path list. inherit_rpath=$inherit_rpath # Whether libtool must link a program against all its dependency libraries. link_all_deplibs=$link_all_deplibs # Set to "yes" if exported symbols are required. always_export_symbols=$always_export_symbols # The commands to list exported symbols. export_symbols_cmds=$lt_export_symbols_cmds # Symbols that should not be listed in the preloaded symbols. exclude_expsyms=$lt_exclude_expsyms # Symbols that must always be exported. include_expsyms=$lt_include_expsyms # Commands necessary for linking programs (against libraries) with templates. prelink_cmds=$lt_prelink_cmds # Commands necessary for finishing linking programs. postlink_cmds=$lt_postlink_cmds # Specify filename containing input files. file_list_spec=$lt_file_list_spec # How to hardcode a shared library path into an executable. hardcode_action=$hardcode_action # ### END LIBTOOL CONFIG _LT_EOF cat <<'_LT_EOF' >> "$cfgfile" # ### BEGIN FUNCTIONS SHARED WITH CONFIGURE # func_munge_path_list VARIABLE PATH # ----------------------------------- # VARIABLE is name of variable containing _space_ separated list of # directories to be munged by the contents of PATH, which is string # having a format: # "DIR[:DIR]:" # string "DIR[ DIR]" will be prepended to VARIABLE # ":DIR[:DIR]" # string "DIR[ DIR]" will be appended to VARIABLE # "DIRP[:DIRP]::[DIRA:]DIRA" # string "DIRP[ DIRP]" will be prepended to VARIABLE and string # "DIRA[ DIRA]" will be appended to VARIABLE # "DIR[:DIR]" # VARIABLE will be replaced by "DIR[ DIR]" func_munge_path_list () { case x$2 in x) ;; *:) eval $1=\"`$ECHO $2 | $SED 's/:/ /g'` \$$1\" ;; x:*) eval $1=\"\$$1 `$ECHO $2 | $SED 's/:/ /g'`\" ;; *::*) eval $1=\"\$$1\ `$ECHO $2 | $SED -e 's/.*:://' -e 's/:/ /g'`\" eval $1=\"`$ECHO $2 | $SED -e 's/::.*//' -e 's/:/ /g'`\ \$$1\" ;; *) eval $1=\"`$ECHO $2 | $SED 's/:/ /g'`\" ;; esac } # Calculate cc_basename. Skip known compiler wrappers and cross-prefix. func_cc_basename () { for cc_temp in $*""; do case $cc_temp in compile | *[\\/]compile | ccache | *[\\/]ccache ) ;; distcc | *[\\/]distcc | purify | *[\\/]purify ) ;; \-*) ;; *) break;; esac done func_cc_basename_result=`$ECHO "$cc_temp" | $SED "s%.*/%%; s%^$host_alias-%%"` } # ### END FUNCTIONS SHARED WITH CONFIGURE _LT_EOF case $host_os in aix3*) cat <<\_LT_EOF >> "$cfgfile" # AIX sometimes has problems with the GCC collect2 program. For some # reason, if we set the COLLECT_NAMES environment variable, the problems # vanish in a puff of smoke. if test set != "${COLLECT_NAMES+set}"; then COLLECT_NAMES= export COLLECT_NAMES fi _LT_EOF ;; esac ltmain=$ac_aux_dir/ltmain.sh # We use sed instead of cat because bash on DJGPP gets confused if # if finds mixed CR/LF and LF-only lines. Since sed operates in # text mode, it properly converts lines to CR/LF. This bash problem # is reportedly fixed, but why not run on old versions too? sed '$q' "$ltmain" >> "$cfgfile" \ || (rm -f "$cfgfile"; exit 1) mv -f "$cfgfile" "$ofile" || (rm -f "$ofile" && cp "$cfgfile" "$ofile" && rm -f "$cfgfile") chmod +x "$ofile" ;; esac done # for ac_tag as_fn_exit 0 _ACEOF ac_clean_files=$ac_clean_files_save test $ac_write_fail = 0 || as_fn_error $? "write failure creating $CONFIG_STATUS" "$LINENO" 5 # configure is writing to config.log, and then calls config.status. # config.status does its own redirection, appending to config.log. # Unfortunately, on DOS this fails, as config.log is still kept open # by configure, so config.status won't be able to write to it; its # output is simply discarded. So we exec the FD to /dev/null, # effectively closing config.log, so it can be properly (re)opened and # appended to by config.status. When coming back to configure, we # need to make the FD available again. if test "$no_create" != yes; then ac_cs_success=: ac_config_status_args= test "$silent" = yes && ac_config_status_args="$ac_config_status_args --quiet" exec 5>/dev/null $SHELL $CONFIG_STATUS $ac_config_status_args || ac_cs_success=false exec 5>>config.log # Use ||, not &&, to avoid exiting from the if with $? = 1, which # would make configure fail if this is the last instruction. $ac_cs_success || as_fn_exit 1 fi # # CONFIG_SUBDIRS section. # if test "$no_recursion" != yes; then # Remove --cache-file, --srcdir, and --disable-option-checking arguments # so they do not pile up. ac_sub_configure_args= ac_prev= eval "set x $ac_configure_args" shift for ac_arg do if test -n "$ac_prev"; then ac_prev= continue fi case $ac_arg in -cache-file | --cache-file | --cache-fil | --cache-fi \ | --cache-f | --cache- | --cache | --cach | --cac | --ca | --c) ac_prev=cache_file ;; -cache-file=* | --cache-file=* | --cache-fil=* | --cache-fi=* \ | --cache-f=* | --cache-=* | --cache=* | --cach=* | --cac=* | --ca=* \ | --c=*) ;; --config-cache | -C) ;; -srcdir | --srcdir | --srcdi | --srcd | --src | --sr) ac_prev=srcdir ;; -srcdir=* | --srcdir=* | --srcdi=* | --srcd=* | --src=* | --sr=*) ;; -prefix | --prefix | --prefi | --pref | --pre | --pr | --p) ac_prev=prefix ;; -prefix=* | --prefix=* | --prefi=* | --pref=* | --pre=* | --pr=* | --p=*) ;; --disable-option-checking) ;; *) case $ac_arg in *\'*) ac_arg=`$as_echo "$ac_arg" | sed "s/'/'\\\\\\\\''/g"` ;; esac as_fn_append ac_sub_configure_args " '$ac_arg'" ;; esac done # Always prepend --prefix to ensure using the same prefix # in subdir configurations. ac_arg="--prefix=$prefix" case $ac_arg in *\'*) ac_arg=`$as_echo "$ac_arg" | sed "s/'/'\\\\\\\\''/g"` ;; esac ac_sub_configure_args="'$ac_arg' $ac_sub_configure_args" # Pass --silent if test "$silent" = yes; then ac_sub_configure_args="--silent $ac_sub_configure_args" fi # Always prepend --disable-option-checking to silence warnings, since # different subdirs can have different --enable and --with options. ac_sub_configure_args="--disable-option-checking $ac_sub_configure_args" ac_popdir=`pwd` for ac_dir in : $subdirs; do test "x$ac_dir" = x: && continue # Do not complain, so a configure script can configure whichever # parts of a large source tree are present. test -d "$srcdir/$ac_dir" || continue ac_msg="=== configuring in $ac_dir (`pwd`/$ac_dir)" $as_echo "$as_me:${as_lineno-$LINENO}: $ac_msg" >&5 $as_echo "$ac_msg" >&6 as_dir="$ac_dir"; as_fn_mkdir_p ac_builddir=. case "$ac_dir" in .) ac_dir_suffix= ac_top_builddir_sub=. ac_top_build_prefix= ;; *) ac_dir_suffix=/`$as_echo "$ac_dir" | sed 's|^\.[\\/]||'` # A ".." for each directory in $ac_dir_suffix. ac_top_builddir_sub=`$as_echo "$ac_dir_suffix" | sed 's|/[^\\/]*|/..|g;s|/||'` case $ac_top_builddir_sub in "") ac_top_builddir_sub=. ac_top_build_prefix= ;; *) ac_top_build_prefix=$ac_top_builddir_sub/ ;; esac ;; esac ac_abs_top_builddir=$ac_pwd ac_abs_builddir=$ac_pwd$ac_dir_suffix # for backward compatibility: ac_top_builddir=$ac_top_build_prefix case $srcdir in .) # We are building in place. ac_srcdir=. ac_top_srcdir=$ac_top_builddir_sub ac_abs_top_srcdir=$ac_pwd ;; [\\/]* | ?:[\\/]* ) # Absolute name. ac_srcdir=$srcdir$ac_dir_suffix; ac_top_srcdir=$srcdir ac_abs_top_srcdir=$srcdir ;; *) # Relative name. ac_srcdir=$ac_top_build_prefix$srcdir$ac_dir_suffix ac_top_srcdir=$ac_top_build_prefix$srcdir ac_abs_top_srcdir=$ac_pwd/$srcdir ;; esac ac_abs_srcdir=$ac_abs_top_srcdir$ac_dir_suffix cd "$ac_dir" # Check for guested configure; otherwise get Cygnus style configure. if test -f "$ac_srcdir/configure.gnu"; then ac_sub_configure=$ac_srcdir/configure.gnu elif test -f "$ac_srcdir/configure"; then ac_sub_configure=$ac_srcdir/configure elif test -f "$ac_srcdir/configure.in"; then # This should be Cygnus configure. ac_sub_configure=$ac_aux_dir/configure else { $as_echo "$as_me:${as_lineno-$LINENO}: WARNING: no configuration information is in $ac_dir" >&5 $as_echo "$as_me: WARNING: no configuration information is in $ac_dir" >&2;} ac_sub_configure= fi # The recursion is here. if test -n "$ac_sub_configure"; then # Make the cache file name correct relative to the subdirectory. case $cache_file in [\\/]* | ?:[\\/]* ) ac_sub_cache_file=$cache_file ;; *) # Relative name. ac_sub_cache_file=$ac_top_build_prefix$cache_file ;; esac { $as_echo "$as_me:${as_lineno-$LINENO}: running $SHELL $ac_sub_configure $ac_sub_configure_args --cache-file=$ac_sub_cache_file --srcdir=$ac_srcdir" >&5 $as_echo "$as_me: running $SHELL $ac_sub_configure $ac_sub_configure_args --cache-file=$ac_sub_cache_file --srcdir=$ac_srcdir" >&6;} # The eval makes quoting arguments work. eval "\$SHELL \"\$ac_sub_configure\" $ac_sub_configure_args \ --cache-file=\"\$ac_sub_cache_file\" --srcdir=\"\$ac_srcdir\"" || as_fn_error $? "$ac_sub_configure failed for $ac_dir" "$LINENO" 5 fi cd "$ac_popdir" done fi if test -n "$ac_unrecognized_opts" && test "$enable_option_checking" != no; then { $as_echo "$as_me:${as_lineno-$LINENO}: WARNING: unrecognized options: $ac_unrecognized_opts" >&5 $as_echo "$as_me: WARNING: unrecognized options: $ac_unrecognized_opts" >&2;} fi xrdp-0.9.5/pkgconfig/000755 001751 001751 00000000000 13220731022 014361 5ustar00metameta000000 000000 xrdp-0.9.5/depcomp000755 001751 001751 00000056017 13220730775 014016 0ustar00metameta000000 000000 #! /bin/sh # depcomp - compile a program generating dependencies as side-effects scriptversion=2016-01-11.22; # UTC # Copyright (C) 1999-2017 Free Software Foundation, Inc. # 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 2, 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. # You should have received a copy of the GNU General Public License # along with this program. If not, see . # As a special exception to the GNU General Public License, if you # distribute this file as part of a program that contains a # configuration script generated by Autoconf, you may include it under # the same distribution terms that you use for the rest of that program. # Originally written by Alexandre Oliva . case $1 in '') echo "$0: No command. Try '$0 --help' for more information." 1>&2 exit 1; ;; -h | --h*) cat <<\EOF Usage: depcomp [--help] [--version] PROGRAM [ARGS] Run PROGRAMS ARGS to compile a file, generating dependencies as side-effects. Environment variables: depmode Dependency tracking mode. source Source file read by 'PROGRAMS ARGS'. object Object file output by 'PROGRAMS ARGS'. DEPDIR directory where to store dependencies. depfile Dependency file to output. tmpdepfile Temporary file to use when outputting dependencies. libtool Whether libtool is used (yes/no). Report bugs to . EOF exit $? ;; -v | --v*) echo "depcomp $scriptversion" exit $? ;; esac # Get the directory component of the given path, and save it in the # global variables '$dir'. Note that this directory component will # be either empty or ending with a '/' character. This is deliberate. set_dir_from () { case $1 in */*) dir=`echo "$1" | sed -e 's|/[^/]*$|/|'`;; *) dir=;; esac } # Get the suffix-stripped basename of the given path, and save it the # global variable '$base'. set_base_from () { base=`echo "$1" | sed -e 's|^.*/||' -e 's/\.[^.]*$//'` } # If no dependency file was actually created by the compiler invocation, # we still have to create a dummy depfile, to avoid errors with the # Makefile "include basename.Plo" scheme. make_dummy_depfile () { echo "#dummy" > "$depfile" } # Factor out some common post-processing of the generated depfile. # Requires the auxiliary global variable '$tmpdepfile' to be set. aix_post_process_depfile () { # If the compiler actually managed to produce a dependency file, # post-process it. if test -f "$tmpdepfile"; then # Each line is of the form 'foo.o: dependency.h'. # Do two passes, one to just change these to # $object: dependency.h # and one to simply output # dependency.h: # which is needed to avoid the deleted-header problem. { sed -e "s,^.*\.[$lower]*:,$object:," < "$tmpdepfile" sed -e "s,^.*\.[$lower]*:[$tab ]*,," -e 's,$,:,' < "$tmpdepfile" } > "$depfile" rm -f "$tmpdepfile" else make_dummy_depfile fi } # A tabulation character. tab=' ' # A newline character. nl=' ' # Character ranges might be problematic outside the C locale. # These definitions help. upper=ABCDEFGHIJKLMNOPQRSTUVWXYZ lower=abcdefghijklmnopqrstuvwxyz digits=0123456789 alpha=${upper}${lower} if test -z "$depmode" || test -z "$source" || test -z "$object"; then echo "depcomp: Variables source, object and depmode must be set" 1>&2 exit 1 fi # Dependencies for sub/bar.o or sub/bar.obj go into sub/.deps/bar.Po. depfile=${depfile-`echo "$object" | sed 's|[^\\/]*$|'${DEPDIR-.deps}'/&|;s|\.\([^.]*\)$|.P\1|;s|Pobj$|Po|'`} tmpdepfile=${tmpdepfile-`echo "$depfile" | sed 's/\.\([^.]*\)$/.T\1/'`} rm -f "$tmpdepfile" # Avoid interferences from the environment. gccflag= dashmflag= # Some modes work just like other modes, but use different flags. We # parameterize here, but still list the modes in the big case below, # to make depend.m4 easier to write. Note that we *cannot* use a case # here, because this file can only contain one case statement. if test "$depmode" = hp; then # HP compiler uses -M and no extra arg. gccflag=-M depmode=gcc fi if test "$depmode" = dashXmstdout; then # This is just like dashmstdout with a different argument. dashmflag=-xM depmode=dashmstdout fi cygpath_u="cygpath -u -f -" if test "$depmode" = msvcmsys; then # This is just like msvisualcpp but w/o cygpath translation. # Just convert the backslash-escaped backslashes to single forward # slashes to satisfy depend.m4 cygpath_u='sed s,\\\\,/,g' depmode=msvisualcpp fi if test "$depmode" = msvc7msys; then # This is just like msvc7 but w/o cygpath translation. # Just convert the backslash-escaped backslashes to single forward # slashes to satisfy depend.m4 cygpath_u='sed s,\\\\,/,g' depmode=msvc7 fi if test "$depmode" = xlc; then # IBM C/C++ Compilers xlc/xlC can output gcc-like dependency information. gccflag=-qmakedep=gcc,-MF depmode=gcc fi case "$depmode" in gcc3) ## gcc 3 implements dependency tracking that does exactly what ## we want. Yay! Note: for some reason libtool 1.4 doesn't like ## it if -MD -MP comes after the -MF stuff. Hmm. ## Unfortunately, FreeBSD c89 acceptance of flags depends upon ## the command line argument order; so add the flags where they ## appear in depend2.am. Note that the slowdown incurred here ## affects only configure: in makefiles, %FASTDEP% shortcuts this. for arg do case $arg in -c) set fnord "$@" -MT "$object" -MD -MP -MF "$tmpdepfile" "$arg" ;; *) set fnord "$@" "$arg" ;; esac shift # fnord shift # $arg done "$@" stat=$? if test $stat -ne 0; then rm -f "$tmpdepfile" exit $stat fi mv "$tmpdepfile" "$depfile" ;; gcc) ## Note that this doesn't just cater to obsosete pre-3.x GCC compilers. ## but also to in-use compilers like IMB xlc/xlC and the HP C compiler. ## (see the conditional assignment to $gccflag above). ## There are various ways to get dependency output from gcc. Here's ## why we pick this rather obscure method: ## - Don't want to use -MD because we'd like the dependencies to end ## up in a subdir. Having to rename by hand is ugly. ## (We might end up doing this anyway to support other compilers.) ## - The DEPENDENCIES_OUTPUT environment variable makes gcc act like ## -MM, not -M (despite what the docs say). Also, it might not be ## supported by the other compilers which use the 'gcc' depmode. ## - Using -M directly means running the compiler twice (even worse ## than renaming). if test -z "$gccflag"; then gccflag=-MD, fi "$@" -Wp,"$gccflag$tmpdepfile" stat=$? if test $stat -ne 0; then rm -f "$tmpdepfile" exit $stat fi rm -f "$depfile" echo "$object : \\" > "$depfile" # The second -e expression handles DOS-style file names with drive # letters. sed -e 's/^[^:]*: / /' \ -e 's/^['$alpha']:\/[^:]*: / /' < "$tmpdepfile" >> "$depfile" ## This next piece of magic avoids the "deleted header file" problem. ## The problem is that when a header file which appears in a .P file ## is deleted, the dependency causes make to die (because there is ## typically no way to rebuild the header). We avoid this by adding ## dummy dependencies for each header file. Too bad gcc doesn't do ## this for us directly. ## Some versions of gcc put a space before the ':'. On the theory ## that the space means something, we add a space to the output as ## well. hp depmode also adds that space, but also prefixes the VPATH ## to the object. Take care to not repeat it in the output. ## Some versions of the HPUX 10.20 sed can't process this invocation ## correctly. Breaking it into two sed invocations is a workaround. tr ' ' "$nl" < "$tmpdepfile" \ | sed -e 's/^\\$//' -e '/^$/d' -e "s|.*$object$||" -e '/:$/d' \ | sed -e 's/$/ :/' >> "$depfile" rm -f "$tmpdepfile" ;; hp) # This case exists only to let depend.m4 do its work. It works by # looking at the text of this script. This case will never be run, # since it is checked for above. exit 1 ;; sgi) if test "$libtool" = yes; then "$@" "-Wp,-MDupdate,$tmpdepfile" else "$@" -MDupdate "$tmpdepfile" fi stat=$? if test $stat -ne 0; then rm -f "$tmpdepfile" exit $stat fi rm -f "$depfile" if test -f "$tmpdepfile"; then # yes, the sourcefile depend on other files echo "$object : \\" > "$depfile" # Clip off the initial element (the dependent). Don't try to be # clever and replace this with sed code, as IRIX sed won't handle # lines with more than a fixed number of characters (4096 in # IRIX 6.2 sed, 8192 in IRIX 6.5). We also remove comment lines; # the IRIX cc adds comments like '#:fec' to the end of the # dependency line. tr ' ' "$nl" < "$tmpdepfile" \ | sed -e 's/^.*\.o://' -e 's/#.*$//' -e '/^$/ d' \ | tr "$nl" ' ' >> "$depfile" echo >> "$depfile" # The second pass generates a dummy entry for each header file. tr ' ' "$nl" < "$tmpdepfile" \ | sed -e 's/^.*\.o://' -e 's/#.*$//' -e '/^$/ d' -e 's/$/:/' \ >> "$depfile" else make_dummy_depfile fi rm -f "$tmpdepfile" ;; xlc) # This case exists only to let depend.m4 do its work. It works by # looking at the text of this script. This case will never be run, # since it is checked for above. exit 1 ;; aix) # The C for AIX Compiler uses -M and outputs the dependencies # in a .u file. In older versions, this file always lives in the # current directory. Also, the AIX compiler puts '$object:' at the # start of each line; $object doesn't have directory information. # Version 6 uses the directory in both cases. set_dir_from "$object" set_base_from "$object" if test "$libtool" = yes; then tmpdepfile1=$dir$base.u tmpdepfile2=$base.u tmpdepfile3=$dir.libs/$base.u "$@" -Wc,-M else tmpdepfile1=$dir$base.u tmpdepfile2=$dir$base.u tmpdepfile3=$dir$base.u "$@" -M fi stat=$? if test $stat -ne 0; then rm -f "$tmpdepfile1" "$tmpdepfile2" "$tmpdepfile3" exit $stat fi for tmpdepfile in "$tmpdepfile1" "$tmpdepfile2" "$tmpdepfile3" do test -f "$tmpdepfile" && break done aix_post_process_depfile ;; tcc) # tcc (Tiny C Compiler) understand '-MD -MF file' since version 0.9.26 # FIXME: That version still under development at the moment of writing. # Make that this statement remains true also for stable, released # versions. # It will wrap lines (doesn't matter whether long or short) with a # trailing '\', as in: # # foo.o : \ # foo.c \ # foo.h \ # # It will put a trailing '\' even on the last line, and will use leading # spaces rather than leading tabs (at least since its commit 0394caf7 # "Emit spaces for -MD"). "$@" -MD -MF "$tmpdepfile" stat=$? if test $stat -ne 0; then rm -f "$tmpdepfile" exit $stat fi rm -f "$depfile" # Each non-empty line is of the form 'foo.o : \' or ' dep.h \'. # We have to change lines of the first kind to '$object: \'. sed -e "s|.*:|$object :|" < "$tmpdepfile" > "$depfile" # And for each line of the second kind, we have to emit a 'dep.h:' # dummy dependency, to avoid the deleted-header problem. sed -n -e 's|^ *\(.*\) *\\$|\1:|p' < "$tmpdepfile" >> "$depfile" rm -f "$tmpdepfile" ;; ## The order of this option in the case statement is important, since the ## shell code in configure will try each of these formats in the order ## listed in this file. A plain '-MD' option would be understood by many ## compilers, so we must ensure this comes after the gcc and icc options. pgcc) # Portland's C compiler understands '-MD'. # Will always output deps to 'file.d' where file is the root name of the # source file under compilation, even if file resides in a subdirectory. # The object file name does not affect the name of the '.d' file. # pgcc 10.2 will output # foo.o: sub/foo.c sub/foo.h # and will wrap long lines using '\' : # foo.o: sub/foo.c ... \ # sub/foo.h ... \ # ... set_dir_from "$object" # Use the source, not the object, to determine the base name, since # that's sadly what pgcc will do too. set_base_from "$source" tmpdepfile=$base.d # For projects that build the same source file twice into different object # files, the pgcc approach of using the *source* file root name can cause # problems in parallel builds. Use a locking strategy to avoid stomping on # the same $tmpdepfile. lockdir=$base.d-lock trap " echo '$0: caught signal, cleaning up...' >&2 rmdir '$lockdir' exit 1 " 1 2 13 15 numtries=100 i=$numtries while test $i -gt 0; do # mkdir is a portable test-and-set. if mkdir "$lockdir" 2>/dev/null; then # This process acquired the lock. "$@" -MD stat=$? # Release the lock. rmdir "$lockdir" break else # If the lock is being held by a different process, wait # until the winning process is done or we timeout. while test -d "$lockdir" && test $i -gt 0; do sleep 1 i=`expr $i - 1` done fi i=`expr $i - 1` done trap - 1 2 13 15 if test $i -le 0; then echo "$0: failed to acquire lock after $numtries attempts" >&2 echo "$0: check lockdir '$lockdir'" >&2 exit 1 fi if test $stat -ne 0; then rm -f "$tmpdepfile" exit $stat fi rm -f "$depfile" # Each line is of the form `foo.o: dependent.h', # or `foo.o: dep1.h dep2.h \', or ` dep3.h dep4.h \'. # Do two passes, one to just change these to # `$object: dependent.h' and one to simply `dependent.h:'. sed "s,^[^:]*:,$object :," < "$tmpdepfile" > "$depfile" # Some versions of the HPUX 10.20 sed can't process this invocation # correctly. Breaking it into two sed invocations is a workaround. sed 's,^[^:]*: \(.*\)$,\1,;s/^\\$//;/^$/d;/:$/d' < "$tmpdepfile" \ | sed -e 's/$/ :/' >> "$depfile" rm -f "$tmpdepfile" ;; hp2) # The "hp" stanza above does not work with aCC (C++) and HP's ia64 # compilers, which have integrated preprocessors. The correct option # to use with these is +Maked; it writes dependencies to a file named # 'foo.d', which lands next to the object file, wherever that # happens to be. # Much of this is similar to the tru64 case; see comments there. set_dir_from "$object" set_base_from "$object" if test "$libtool" = yes; then tmpdepfile1=$dir$base.d tmpdepfile2=$dir.libs/$base.d "$@" -Wc,+Maked else tmpdepfile1=$dir$base.d tmpdepfile2=$dir$base.d "$@" +Maked fi stat=$? if test $stat -ne 0; then rm -f "$tmpdepfile1" "$tmpdepfile2" exit $stat fi for tmpdepfile in "$tmpdepfile1" "$tmpdepfile2" do test -f "$tmpdepfile" && break done if test -f "$tmpdepfile"; then sed -e "s,^.*\.[$lower]*:,$object:," "$tmpdepfile" > "$depfile" # Add 'dependent.h:' lines. sed -ne '2,${ s/^ *// s/ \\*$// s/$/:/ p }' "$tmpdepfile" >> "$depfile" else make_dummy_depfile fi rm -f "$tmpdepfile" "$tmpdepfile2" ;; tru64) # The Tru64 compiler uses -MD to generate dependencies as a side # effect. 'cc -MD -o foo.o ...' puts the dependencies into 'foo.o.d'. # At least on Alpha/Redhat 6.1, Compaq CCC V6.2-504 seems to put # dependencies in 'foo.d' instead, so we check for that too. # Subdirectories are respected. set_dir_from "$object" set_base_from "$object" if test "$libtool" = yes; then # Libtool generates 2 separate objects for the 2 libraries. These # two compilations output dependencies in $dir.libs/$base.o.d and # in $dir$base.o.d. We have to check for both files, because # one of the two compilations can be disabled. We should prefer # $dir$base.o.d over $dir.libs/$base.o.d because the latter is # automatically cleaned when .libs/ is deleted, while ignoring # the former would cause a distcleancheck panic. tmpdepfile1=$dir$base.o.d # libtool 1.5 tmpdepfile2=$dir.libs/$base.o.d # Likewise. tmpdepfile3=$dir.libs/$base.d # Compaq CCC V6.2-504 "$@" -Wc,-MD else tmpdepfile1=$dir$base.d tmpdepfile2=$dir$base.d tmpdepfile3=$dir$base.d "$@" -MD fi stat=$? if test $stat -ne 0; then rm -f "$tmpdepfile1" "$tmpdepfile2" "$tmpdepfile3" exit $stat fi for tmpdepfile in "$tmpdepfile1" "$tmpdepfile2" "$tmpdepfile3" do test -f "$tmpdepfile" && break done # Same post-processing that is required for AIX mode. aix_post_process_depfile ;; msvc7) if test "$libtool" = yes; then showIncludes=-Wc,-showIncludes else showIncludes=-showIncludes fi "$@" $showIncludes > "$tmpdepfile" stat=$? grep -v '^Note: including file: ' "$tmpdepfile" if test $stat -ne 0; then rm -f "$tmpdepfile" exit $stat fi rm -f "$depfile" echo "$object : \\" > "$depfile" # The first sed program below extracts the file names and escapes # backslashes for cygpath. The second sed program outputs the file # name when reading, but also accumulates all include files in the # hold buffer in order to output them again at the end. This only # works with sed implementations that can handle large buffers. sed < "$tmpdepfile" -n ' /^Note: including file: *\(.*\)/ { s//\1/ s/\\/\\\\/g p }' | $cygpath_u | sort -u | sed -n ' s/ /\\ /g s/\(.*\)/'"$tab"'\1 \\/p s/.\(.*\) \\/\1:/ H $ { s/.*/'"$tab"'/ G p }' >> "$depfile" echo >> "$depfile" # make sure the fragment doesn't end with a backslash rm -f "$tmpdepfile" ;; msvc7msys) # This case exists only to let depend.m4 do its work. It works by # looking at the text of this script. This case will never be run, # since it is checked for above. exit 1 ;; #nosideeffect) # This comment above is used by automake to tell side-effect # dependency tracking mechanisms from slower ones. dashmstdout) # Important note: in order to support this mode, a compiler *must* # always write the preprocessed file to stdout, regardless of -o. "$@" || exit $? # Remove the call to Libtool. if test "$libtool" = yes; then while test "X$1" != 'X--mode=compile'; do shift done shift fi # Remove '-o $object'. IFS=" " for arg do case $arg in -o) shift ;; $object) shift ;; *) set fnord "$@" "$arg" shift # fnord shift # $arg ;; esac done test -z "$dashmflag" && dashmflag=-M # Require at least two characters before searching for ':' # in the target name. This is to cope with DOS-style filenames: # a dependency such as 'c:/foo/bar' could be seen as target 'c' otherwise. "$@" $dashmflag | sed "s|^[$tab ]*[^:$tab ][^:][^:]*:[$tab ]*|$object: |" > "$tmpdepfile" rm -f "$depfile" cat < "$tmpdepfile" > "$depfile" # Some versions of the HPUX 10.20 sed can't process this sed invocation # correctly. Breaking it into two sed invocations is a workaround. tr ' ' "$nl" < "$tmpdepfile" \ | sed -e 's/^\\$//' -e '/^$/d' -e '/:$/d' \ | sed -e 's/$/ :/' >> "$depfile" rm -f "$tmpdepfile" ;; dashXmstdout) # This case only exists to satisfy depend.m4. It is never actually # run, as this mode is specially recognized in the preamble. exit 1 ;; makedepend) "$@" || exit $? # Remove any Libtool call if test "$libtool" = yes; then while test "X$1" != 'X--mode=compile'; do shift done shift fi # X makedepend shift cleared=no eat=no for arg do case $cleared in no) set ""; shift cleared=yes ;; esac if test $eat = yes; then eat=no continue fi case "$arg" in -D*|-I*) set fnord "$@" "$arg"; shift ;; # Strip any option that makedepend may not understand. Remove # the object too, otherwise makedepend will parse it as a source file. -arch) eat=yes ;; -*|$object) ;; *) set fnord "$@" "$arg"; shift ;; esac done obj_suffix=`echo "$object" | sed 's/^.*\././'` touch "$tmpdepfile" ${MAKEDEPEND-makedepend} -o"$obj_suffix" -f"$tmpdepfile" "$@" rm -f "$depfile" # makedepend may prepend the VPATH from the source file name to the object. # No need to regex-escape $object, excess matching of '.' is harmless. sed "s|^.*\($object *:\)|\1|" "$tmpdepfile" > "$depfile" # Some versions of the HPUX 10.20 sed can't process the last invocation # correctly. Breaking it into two sed invocations is a workaround. sed '1,2d' "$tmpdepfile" \ | tr ' ' "$nl" \ | sed -e 's/^\\$//' -e '/^$/d' -e '/:$/d' \ | sed -e 's/$/ :/' >> "$depfile" rm -f "$tmpdepfile" "$tmpdepfile".bak ;; cpp) # Important note: in order to support this mode, a compiler *must* # always write the preprocessed file to stdout. "$@" || exit $? # Remove the call to Libtool. if test "$libtool" = yes; then while test "X$1" != 'X--mode=compile'; do shift done shift fi # Remove '-o $object'. IFS=" " for arg do case $arg in -o) shift ;; $object) shift ;; *) set fnord "$@" "$arg" shift # fnord shift # $arg ;; esac done "$@" -E \ | sed -n -e '/^# [0-9][0-9]* "\([^"]*\)".*/ s:: \1 \\:p' \ -e '/^#line [0-9][0-9]* "\([^"]*\)".*/ s:: \1 \\:p' \ | sed '$ s: \\$::' > "$tmpdepfile" rm -f "$depfile" echo "$object : \\" > "$depfile" cat < "$tmpdepfile" >> "$depfile" sed < "$tmpdepfile" '/^$/d;s/^ //;s/ \\$//;s/$/ :/' >> "$depfile" rm -f "$tmpdepfile" ;; msvisualcpp) # Important note: in order to support this mode, a compiler *must* # always write the preprocessed file to stdout. "$@" || exit $? # Remove the call to Libtool. if test "$libtool" = yes; then while test "X$1" != 'X--mode=compile'; do shift done shift fi IFS=" " for arg do case "$arg" in -o) shift ;; $object) shift ;; "-Gm"|"/Gm"|"-Gi"|"/Gi"|"-ZI"|"/ZI") set fnord "$@" shift shift ;; *) set fnord "$@" "$arg" shift shift ;; esac done "$@" -E 2>/dev/null | sed -n '/^#line [0-9][0-9]* "\([^"]*\)"/ s::\1:p' | $cygpath_u | sort -u > "$tmpdepfile" rm -f "$depfile" echo "$object : \\" > "$depfile" sed < "$tmpdepfile" -n -e 's% %\\ %g' -e '/^\(.*\)$/ s::'"$tab"'\1 \\:p' >> "$depfile" echo "$tab" >> "$depfile" sed < "$tmpdepfile" -n -e 's% %\\ %g' -e '/^\(.*\)$/ s::\1\::p' >> "$depfile" rm -f "$tmpdepfile" ;; msvcmsys) # This case exists only to let depend.m4 do its work. It works by # looking at the text of this script. This case will never be run, # since it is checked for above. exit 1 ;; none) exec "$@" ;; *) echo "Unknown depmode $depmode" 1>&2 exit 1 ;; esac exit 0 # Local Variables: # mode: shell-script # sh-indentation: 2 # eval: (add-hook 'write-file-hooks 'time-stamp) # time-stamp-start: "scriptversion=" # time-stamp-format: "%:y-%02m-%02d.%02H" # time-stamp-time-zone: "UTC0" # time-stamp-end: "; # UTC" # End: xrdp-0.9.5/missing000755 001751 001751 00000015331 13220730773 014030 0ustar00metameta000000 000000 #! /bin/sh # Common wrapper for a few potentially missing GNU programs. scriptversion=2016-01-11.22; # UTC # Copyright (C) 1996-2017 Free Software Foundation, Inc. # Originally written by Fran,cois Pinard , 1996. # 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 2, 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. # You should have received a copy of the GNU General Public License # along with this program. If not, see . # As a special exception to the GNU General Public License, if you # distribute this file as part of a program that contains a # configuration script generated by Autoconf, you may include it under # the same distribution terms that you use for the rest of that program. if test $# -eq 0; then echo 1>&2 "Try '$0 --help' for more information" exit 1 fi case $1 in --is-lightweight) # Used by our autoconf macros to check whether the available missing # script is modern enough. exit 0 ;; --run) # Back-compat with the calling convention used by older automake. shift ;; -h|--h|--he|--hel|--help) echo "\ $0 [OPTION]... PROGRAM [ARGUMENT]... Run 'PROGRAM [ARGUMENT]...', returning a proper advice when this fails due to PROGRAM being missing or too old. Options: -h, --help display this help and exit -v, --version output version information and exit Supported PROGRAM values: aclocal autoconf autoheader autom4te automake makeinfo bison yacc flex lex help2man Version suffixes to PROGRAM as well as the prefixes 'gnu-', 'gnu', and 'g' are ignored when checking the name. Send bug reports to ." exit $? ;; -v|--v|--ve|--ver|--vers|--versi|--versio|--version) echo "missing $scriptversion (GNU Automake)" exit $? ;; -*) echo 1>&2 "$0: unknown '$1' option" echo 1>&2 "Try '$0 --help' for more information" exit 1 ;; esac # Run the given program, remember its exit status. "$@"; st=$? # If it succeeded, we are done. test $st -eq 0 && exit 0 # Also exit now if we it failed (or wasn't found), and '--version' was # passed; such an option is passed most likely to detect whether the # program is present and works. case $2 in --version|--help) exit $st;; esac # Exit code 63 means version mismatch. This often happens when the user # tries to use an ancient version of a tool on a file that requires a # minimum version. if test $st -eq 63; then msg="probably too old" elif test $st -eq 127; then # Program was missing. msg="missing on your system" else # Program was found and executed, but failed. Give up. exit $st fi perl_URL=http://www.perl.org/ flex_URL=http://flex.sourceforge.net/ gnu_software_URL=http://www.gnu.org/software program_details () { case $1 in aclocal|automake) echo "The '$1' program is part of the GNU Automake package:" echo "<$gnu_software_URL/automake>" echo "It also requires GNU Autoconf, GNU m4 and Perl in order to run:" echo "<$gnu_software_URL/autoconf>" echo "<$gnu_software_URL/m4/>" echo "<$perl_URL>" ;; autoconf|autom4te|autoheader) echo "The '$1' program is part of the GNU Autoconf package:" echo "<$gnu_software_URL/autoconf/>" echo "It also requires GNU m4 and Perl in order to run:" echo "<$gnu_software_URL/m4/>" echo "<$perl_URL>" ;; esac } give_advice () { # Normalize program name to check for. normalized_program=`echo "$1" | sed ' s/^gnu-//; t s/^gnu//; t s/^g//; t'` printf '%s\n' "'$1' is $msg." configure_deps="'configure.ac' or m4 files included by 'configure.ac'" case $normalized_program in autoconf*) echo "You should only need it if you modified 'configure.ac'," echo "or m4 files included by it." program_details 'autoconf' ;; autoheader*) echo "You should only need it if you modified 'acconfig.h' or" echo "$configure_deps." program_details 'autoheader' ;; automake*) echo "You should only need it if you modified 'Makefile.am' or" echo "$configure_deps." program_details 'automake' ;; aclocal*) echo "You should only need it if you modified 'acinclude.m4' or" echo "$configure_deps." program_details 'aclocal' ;; autom4te*) echo "You might have modified some maintainer files that require" echo "the 'autom4te' program to be rebuilt." program_details 'autom4te' ;; bison*|yacc*) echo "You should only need it if you modified a '.y' file." echo "You may want to install the GNU Bison package:" echo "<$gnu_software_URL/bison/>" ;; lex*|flex*) echo "You should only need it if you modified a '.l' file." echo "You may want to install the Fast Lexical Analyzer package:" echo "<$flex_URL>" ;; help2man*) echo "You should only need it if you modified a dependency" \ "of a man page." echo "You may want to install the GNU Help2man package:" echo "<$gnu_software_URL/help2man/>" ;; makeinfo*) echo "You should only need it if you modified a '.texi' file, or" echo "any other file indirectly affecting the aspect of the manual." echo "You might want to install the Texinfo package:" echo "<$gnu_software_URL/texinfo/>" echo "The spurious makeinfo call might also be the consequence of" echo "using a buggy 'make' (AIX, DU, IRIX), in which case you might" echo "want to install GNU make:" echo "<$gnu_software_URL/make/>" ;; *) echo "You might have modified some files without having the proper" echo "tools for further handling them. Check the 'README' file, it" echo "often tells you about the needed prerequisites for installing" echo "this package. You may also peek at any GNU archive site, in" echo "case some other package contains this missing '$1' program." ;; esac } give_advice "$1" | sed -e '1s/^/WARNING: /' \ -e '2,$s/^/ /' >&2 # Propagate the correct exit status (expected to be 127 for a program # not found, 63 for a program that failed due to version mismatch). exit $st # Local variables: # eval: (add-hook 'write-file-hooks 'time-stamp) # time-stamp-start: "scriptversion=" # time-stamp-format: "%:y-%02m-%02d.%02H" # time-stamp-time-zone: "UTC0" # time-stamp-end: "; # UTC" # End: xrdp-0.9.5/bootstrap000755 001751 001751 00000001065 13133557324 014375 0ustar00metameta000000 000000 #!/bin/sh which autoconf if ! test $? -eq 0 then echo "error, install autoconf" exit 1 fi which automake if ! test $? -eq 0 then echo "error, install automake" exit 1 fi which libtool || which libtoolize if ! test $? -eq 0 then echo "error, install libtool" exit 1 fi which pkg-config if ! test $? -eq 0 then echo "error, install pkg-config" exit 1 fi if ! test -f libpainter/configure.ac then git submodule update --init libpainter fi if ! test -f librfxcodec/configure.ac then git submodule update --init librfxcodec fi autoreconf -fvi xrdp-0.9.5/vrplayer/000755 001751 001751 00000000000 13174271344 014274 5ustar00metameta000000 000000 xrdp-0.9.5/libxrdp/000755 001751 001751 00000000000 13220731016 014061 5ustar00metameta000000 000000 xrdp-0.9.5/design.txt000644 001751 001751 00000002262 13127114621 014434 0ustar00metameta000000 000000 This document is intended to explain xrdp server design. Many connections, all capable of running different modules one connection could be using a vnc connection one could be running a custom app made for xrdp one could be running a X11 session clients control the screen size and color depth all controlled by a configuration file. you can create a lib or use a lib with your executable that talks to xrdp server. ------ ---------- -xrdp---linked-------mylib.so- session 1 ------ ---------- | | ------------------------- |----unix socket--myapp linked to libxrdp- session 2 | ------------------------- | | ----------- |----linked-------mylib2.so- session 3 ----------- Any of the above sessions can repeat or have different session numbers or not even be used. If a session is disconnected, all that changes is the rdp connection is lost, the session remains. For X11, start the XServer after the user is authenticated. First check for the next available X11 display, create a user session, start the XServer and set the DISPLAY environment variable. xrdp-0.9.5/mc/000755 001751 001751 00000000000 13220731016 013014 5ustar00metameta000000 000000 xrdp-0.9.5/docs/000755 001751 001751 00000000000 13220731021 013341 5ustar00metameta000000 000000 xrdp-0.9.5/config.guess000755 001751 001751 00000124431 13220730773 014753 0ustar00metameta000000 000000 #! /bin/sh # Attempt to guess a canonical system name. # Copyright 1992-2015 Free Software Foundation, Inc. timestamp='2015-03-04' # This file 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. # # You should have received a copy of the GNU General Public License # along with this program; if not, see . # # As a special exception to the GNU General Public License, if you # distribute this file as part of a program that contains a # configuration script generated by Autoconf, you may include it under # the same distribution terms that you use for the rest of that # program. This Exception is an additional permission under section 7 # of the GNU General Public License, version 3 ("GPLv3"). # # Originally written by Per Bothner; maintained since 2000 by Ben Elliston. # # You can get the latest version of this script from: # http://git.savannah.gnu.org/gitweb/?p=config.git;a=blob_plain;f=config.guess;hb=HEAD # # Please send patches to . me=`echo "$0" | sed -e 's,.*/,,'` usage="\ Usage: $0 [OPTION] Output the configuration name of the system \`$me' is run on. Operation modes: -h, --help print this help, then exit -t, --time-stamp print date of last modification, then exit -v, --version print version number, then exit Report bugs and patches to ." version="\ GNU config.guess ($timestamp) Originally written by Per Bothner. Copyright 1992-2015 Free Software Foundation, Inc. This is free software; see the source for copying conditions. There is NO warranty; not even for MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE." help=" Try \`$me --help' for more information." # Parse command line while test $# -gt 0 ; do case $1 in --time-stamp | --time* | -t ) echo "$timestamp" ; exit ;; --version | -v ) echo "$version" ; exit ;; --help | --h* | -h ) echo "$usage"; exit ;; -- ) # Stop option processing shift; break ;; - ) # Use stdin as input. break ;; -* ) echo "$me: invalid option $1$help" >&2 exit 1 ;; * ) break ;; esac done if test $# != 0; then echo "$me: too many arguments$help" >&2 exit 1 fi trap 'exit 1' 1 2 15 # CC_FOR_BUILD -- compiler used by this script. Note that the use of a # compiler to aid in system detection is discouraged as it requires # temporary files to be created and, as you can see below, it is a # headache to deal with in a portable fashion. # Historically, `CC_FOR_BUILD' used to be named `HOST_CC'. We still # use `HOST_CC' if defined, but it is deprecated. # Portable tmp directory creation inspired by the Autoconf team. set_cc_for_build=' trap "exitcode=\$?; (rm -f \$tmpfiles 2>/dev/null; rmdir \$tmp 2>/dev/null) && exit \$exitcode" 0 ; trap "rm -f \$tmpfiles 2>/dev/null; rmdir \$tmp 2>/dev/null; exit 1" 1 2 13 15 ; : ${TMPDIR=/tmp} ; { tmp=`(umask 077 && mktemp -d "$TMPDIR/cgXXXXXX") 2>/dev/null` && test -n "$tmp" && test -d "$tmp" ; } || { test -n "$RANDOM" && tmp=$TMPDIR/cg$$-$RANDOM && (umask 077 && mkdir $tmp) ; } || { tmp=$TMPDIR/cg-$$ && (umask 077 && mkdir $tmp) && echo "Warning: creating insecure temp directory" >&2 ; } || { echo "$me: cannot create a temporary directory in $TMPDIR" >&2 ; exit 1 ; } ; dummy=$tmp/dummy ; tmpfiles="$dummy.c $dummy.o $dummy.rel $dummy" ; case $CC_FOR_BUILD,$HOST_CC,$CC in ,,) echo "int x;" > $dummy.c ; for c in cc gcc c89 c99 ; do if ($c -c -o $dummy.o $dummy.c) >/dev/null 2>&1 ; then CC_FOR_BUILD="$c"; break ; fi ; done ; if test x"$CC_FOR_BUILD" = x ; then CC_FOR_BUILD=no_compiler_found ; fi ;; ,,*) CC_FOR_BUILD=$CC ;; ,*,*) CC_FOR_BUILD=$HOST_CC ;; esac ; set_cc_for_build= ;' # This is needed to find uname on a Pyramid OSx when run in the BSD universe. # (ghazi@noc.rutgers.edu 1994-08-24) if (test -f /.attbin/uname) >/dev/null 2>&1 ; then PATH=$PATH:/.attbin ; export PATH fi UNAME_MACHINE=`(uname -m) 2>/dev/null` || UNAME_MACHINE=unknown UNAME_RELEASE=`(uname -r) 2>/dev/null` || UNAME_RELEASE=unknown UNAME_SYSTEM=`(uname -s) 2>/dev/null` || UNAME_SYSTEM=unknown UNAME_VERSION=`(uname -v) 2>/dev/null` || UNAME_VERSION=unknown case "${UNAME_SYSTEM}" in Linux|GNU|GNU/*) # If the system lacks a compiler, then just pick glibc. # We could probably try harder. LIBC=gnu eval $set_cc_for_build cat <<-EOF > $dummy.c #include #if defined(__UCLIBC__) LIBC=uclibc #elif defined(__dietlibc__) LIBC=dietlibc #else LIBC=gnu #endif EOF eval `$CC_FOR_BUILD -E $dummy.c 2>/dev/null | grep '^LIBC' | sed 's, ,,g'` ;; esac # Note: order is significant - the case branches are not exclusive. case "${UNAME_MACHINE}:${UNAME_SYSTEM}:${UNAME_RELEASE}:${UNAME_VERSION}" in *:NetBSD:*:*) # NetBSD (nbsd) targets should (where applicable) match one or # more of the tuples: *-*-netbsdelf*, *-*-netbsdaout*, # *-*-netbsdecoff* and *-*-netbsd*. For targets that recently # switched to ELF, *-*-netbsd* would select the old # object file format. This provides both forward # compatibility and a consistent mechanism for selecting the # object file format. # # Note: NetBSD doesn't particularly care about the vendor # portion of the name. We always set it to "unknown". sysctl="sysctl -n hw.machine_arch" UNAME_MACHINE_ARCH=`(uname -p 2>/dev/null || \ /sbin/$sysctl 2>/dev/null || \ /usr/sbin/$sysctl 2>/dev/null || \ echo unknown)` case "${UNAME_MACHINE_ARCH}" in armeb) machine=armeb-unknown ;; arm*) machine=arm-unknown ;; sh3el) machine=shl-unknown ;; sh3eb) machine=sh-unknown ;; sh5el) machine=sh5le-unknown ;; earmv*) arch=`echo ${UNAME_MACHINE_ARCH} | sed -e 's,^e\(armv[0-9]\).*$,\1,'` endian=`echo ${UNAME_MACHINE_ARCH} | sed -ne 's,^.*\(eb\)$,\1,p'` machine=${arch}${endian}-unknown ;; *) machine=${UNAME_MACHINE_ARCH}-unknown ;; esac # The Operating System including object format, if it has switched # to ELF recently, or will in the future. case "${UNAME_MACHINE_ARCH}" in arm*|earm*|i386|m68k|ns32k|sh3*|sparc|vax) eval $set_cc_for_build if echo __ELF__ | $CC_FOR_BUILD -E - 2>/dev/null \ | grep -q __ELF__ then # Once all utilities can be ECOFF (netbsdecoff) or a.out (netbsdaout). # Return netbsd for either. FIX? os=netbsd else os=netbsdelf fi ;; *) os=netbsd ;; esac # Determine ABI tags. case "${UNAME_MACHINE_ARCH}" in earm*) expr='s/^earmv[0-9]/-eabi/;s/eb$//' abi=`echo ${UNAME_MACHINE_ARCH} | sed -e "$expr"` ;; esac # The OS release # Debian GNU/NetBSD machines have a different userland, and # thus, need a distinct triplet. However, they do not need # kernel version information, so it can be replaced with a # suitable tag, in the style of linux-gnu. case "${UNAME_VERSION}" in Debian*) release='-gnu' ;; *) release=`echo ${UNAME_RELEASE}|sed -e 's/[-_].*/\./'` ;; esac # Since CPU_TYPE-MANUFACTURER-KERNEL-OPERATING_SYSTEM: # contains redundant information, the shorter form: # CPU_TYPE-MANUFACTURER-OPERATING_SYSTEM is used. echo "${machine}-${os}${release}${abi}" exit ;; *:Bitrig:*:*) UNAME_MACHINE_ARCH=`arch | sed 's/Bitrig.//'` echo ${UNAME_MACHINE_ARCH}-unknown-bitrig${UNAME_RELEASE} exit ;; *:OpenBSD:*:*) UNAME_MACHINE_ARCH=`arch | sed 's/OpenBSD.//'` echo ${UNAME_MACHINE_ARCH}-unknown-openbsd${UNAME_RELEASE} exit ;; *:ekkoBSD:*:*) echo ${UNAME_MACHINE}-unknown-ekkobsd${UNAME_RELEASE} exit ;; *:SolidBSD:*:*) echo ${UNAME_MACHINE}-unknown-solidbsd${UNAME_RELEASE} exit ;; macppc:MirBSD:*:*) echo powerpc-unknown-mirbsd${UNAME_RELEASE} exit ;; *:MirBSD:*:*) echo ${UNAME_MACHINE}-unknown-mirbsd${UNAME_RELEASE} exit ;; alpha:OSF1:*:*) case $UNAME_RELEASE in *4.0) UNAME_RELEASE=`/usr/sbin/sizer -v | awk '{print $3}'` ;; *5.*) UNAME_RELEASE=`/usr/sbin/sizer -v | awk '{print $4}'` ;; esac # According to Compaq, /usr/sbin/psrinfo has been available on # OSF/1 and Tru64 systems produced since 1995. I hope that # covers most systems running today. This code pipes the CPU # types through head -n 1, so we only detect the type of CPU 0. ALPHA_CPU_TYPE=`/usr/sbin/psrinfo -v | sed -n -e 's/^ The alpha \(.*\) processor.*$/\1/p' | head -n 1` case "$ALPHA_CPU_TYPE" in "EV4 (21064)") UNAME_MACHINE="alpha" ;; "EV4.5 (21064)") UNAME_MACHINE="alpha" ;; "LCA4 (21066/21068)") UNAME_MACHINE="alpha" ;; "EV5 (21164)") UNAME_MACHINE="alphaev5" ;; "EV5.6 (21164A)") UNAME_MACHINE="alphaev56" ;; "EV5.6 (21164PC)") UNAME_MACHINE="alphapca56" ;; "EV5.7 (21164PC)") UNAME_MACHINE="alphapca57" ;; "EV6 (21264)") UNAME_MACHINE="alphaev6" ;; "EV6.7 (21264A)") UNAME_MACHINE="alphaev67" ;; "EV6.8CB (21264C)") UNAME_MACHINE="alphaev68" ;; "EV6.8AL (21264B)") UNAME_MACHINE="alphaev68" ;; "EV6.8CX (21264D)") UNAME_MACHINE="alphaev68" ;; "EV6.9A (21264/EV69A)") UNAME_MACHINE="alphaev69" ;; "EV7 (21364)") UNAME_MACHINE="alphaev7" ;; "EV7.9 (21364A)") UNAME_MACHINE="alphaev79" ;; esac # A Pn.n version is a patched version. # A Vn.n version is a released version. # A Tn.n version is a released field test version. # A Xn.n version is an unreleased experimental baselevel. # 1.2 uses "1.2" for uname -r. echo ${UNAME_MACHINE}-dec-osf`echo ${UNAME_RELEASE} | sed -e 's/^[PVTX]//' | tr 'ABCDEFGHIJKLMNOPQRSTUVWXYZ' 'abcdefghijklmnopqrstuvwxyz'` # Reset EXIT trap before exiting to avoid spurious non-zero exit code. exitcode=$? trap '' 0 exit $exitcode ;; Alpha\ *:Windows_NT*:*) # How do we know it's Interix rather than the generic POSIX subsystem? # Should we change UNAME_MACHINE based on the output of uname instead # of the specific Alpha model? echo alpha-pc-interix exit ;; 21064:Windows_NT:50:3) echo alpha-dec-winnt3.5 exit ;; Amiga*:UNIX_System_V:4.0:*) echo m68k-unknown-sysv4 exit ;; *:[Aa]miga[Oo][Ss]:*:*) echo ${UNAME_MACHINE}-unknown-amigaos exit ;; *:[Mm]orph[Oo][Ss]:*:*) echo ${UNAME_MACHINE}-unknown-morphos exit ;; *:OS/390:*:*) echo i370-ibm-openedition exit ;; *:z/VM:*:*) echo s390-ibm-zvmoe exit ;; *:OS400:*:*) echo powerpc-ibm-os400 exit ;; arm:RISC*:1.[012]*:*|arm:riscix:1.[012]*:*) echo arm-acorn-riscix${UNAME_RELEASE} exit ;; arm*:riscos:*:*|arm*:RISCOS:*:*) echo arm-unknown-riscos exit ;; SR2?01:HI-UX/MPP:*:* | SR8000:HI-UX/MPP:*:*) echo hppa1.1-hitachi-hiuxmpp exit ;; Pyramid*:OSx*:*:* | MIS*:OSx*:*:* | MIS*:SMP_DC-OSx*:*:*) # akee@wpdis03.wpafb.af.mil (Earle F. Ake) contributed MIS and NILE. if test "`(/bin/universe) 2>/dev/null`" = att ; then echo pyramid-pyramid-sysv3 else echo pyramid-pyramid-bsd fi exit ;; NILE*:*:*:dcosx) echo pyramid-pyramid-svr4 exit ;; DRS?6000:unix:4.0:6*) echo sparc-icl-nx6 exit ;; DRS?6000:UNIX_SV:4.2*:7* | DRS?6000:isis:4.2*:7*) case `/usr/bin/uname -p` in sparc) echo sparc-icl-nx7; exit ;; esac ;; s390x:SunOS:*:*) echo ${UNAME_MACHINE}-ibm-solaris2`echo ${UNAME_RELEASE}|sed -e 's/[^.]*//'` exit ;; sun4H:SunOS:5.*:*) echo sparc-hal-solaris2`echo ${UNAME_RELEASE}|sed -e 's/[^.]*//'` exit ;; sun4*:SunOS:5.*:* | tadpole*:SunOS:5.*:*) echo sparc-sun-solaris2`echo ${UNAME_RELEASE}|sed -e 's/[^.]*//'` exit ;; i86pc:AuroraUX:5.*:* | i86xen:AuroraUX:5.*:*) echo i386-pc-auroraux${UNAME_RELEASE} exit ;; i86pc:SunOS:5.*:* | i86xen:SunOS:5.*:*) eval $set_cc_for_build SUN_ARCH="i386" # If there is a compiler, see if it is configured for 64-bit objects. # Note that the Sun cc does not turn __LP64__ into 1 like gcc does. # This test works for both compilers. if [ "$CC_FOR_BUILD" != 'no_compiler_found' ]; then if (echo '#ifdef __amd64'; echo IS_64BIT_ARCH; echo '#endif') | \ (CCOPTS= $CC_FOR_BUILD -E - 2>/dev/null) | \ grep IS_64BIT_ARCH >/dev/null then SUN_ARCH="x86_64" fi fi echo ${SUN_ARCH}-pc-solaris2`echo ${UNAME_RELEASE}|sed -e 's/[^.]*//'` exit ;; sun4*:SunOS:6*:*) # According to config.sub, this is the proper way to canonicalize # SunOS6. Hard to guess exactly what SunOS6 will be like, but # it's likely to be more like Solaris than SunOS4. echo sparc-sun-solaris3`echo ${UNAME_RELEASE}|sed -e 's/[^.]*//'` exit ;; sun4*:SunOS:*:*) case "`/usr/bin/arch -k`" in Series*|S4*) UNAME_RELEASE=`uname -v` ;; esac # Japanese Language versions have a version number like `4.1.3-JL'. echo sparc-sun-sunos`echo ${UNAME_RELEASE}|sed -e 's/-/_/'` exit ;; sun3*:SunOS:*:*) echo m68k-sun-sunos${UNAME_RELEASE} exit ;; sun*:*:4.2BSD:*) UNAME_RELEASE=`(sed 1q /etc/motd | awk '{print substr($5,1,3)}') 2>/dev/null` test "x${UNAME_RELEASE}" = "x" && UNAME_RELEASE=3 case "`/bin/arch`" in sun3) echo m68k-sun-sunos${UNAME_RELEASE} ;; sun4) echo sparc-sun-sunos${UNAME_RELEASE} ;; esac exit ;; aushp:SunOS:*:*) echo sparc-auspex-sunos${UNAME_RELEASE} exit ;; # The situation for MiNT is a little confusing. The machine name # can be virtually everything (everything which is not # "atarist" or "atariste" at least should have a processor # > m68000). The system name ranges from "MiNT" over "FreeMiNT" # to the lowercase version "mint" (or "freemint"). Finally # the system name "TOS" denotes a system which is actually not # MiNT. But MiNT is downward compatible to TOS, so this should # be no problem. atarist[e]:*MiNT:*:* | atarist[e]:*mint:*:* | atarist[e]:*TOS:*:*) echo m68k-atari-mint${UNAME_RELEASE} exit ;; atari*:*MiNT:*:* | atari*:*mint:*:* | atarist[e]:*TOS:*:*) echo m68k-atari-mint${UNAME_RELEASE} exit ;; *falcon*:*MiNT:*:* | *falcon*:*mint:*:* | *falcon*:*TOS:*:*) echo m68k-atari-mint${UNAME_RELEASE} exit ;; milan*:*MiNT:*:* | milan*:*mint:*:* | *milan*:*TOS:*:*) echo m68k-milan-mint${UNAME_RELEASE} exit ;; hades*:*MiNT:*:* | hades*:*mint:*:* | *hades*:*TOS:*:*) echo m68k-hades-mint${UNAME_RELEASE} exit ;; *:*MiNT:*:* | *:*mint:*:* | *:*TOS:*:*) echo m68k-unknown-mint${UNAME_RELEASE} exit ;; m68k:machten:*:*) echo m68k-apple-machten${UNAME_RELEASE} exit ;; powerpc:machten:*:*) echo powerpc-apple-machten${UNAME_RELEASE} exit ;; RISC*:Mach:*:*) echo mips-dec-mach_bsd4.3 exit ;; RISC*:ULTRIX:*:*) echo mips-dec-ultrix${UNAME_RELEASE} exit ;; VAX*:ULTRIX*:*:*) echo vax-dec-ultrix${UNAME_RELEASE} exit ;; 2020:CLIX:*:* | 2430:CLIX:*:*) echo clipper-intergraph-clix${UNAME_RELEASE} exit ;; mips:*:*:UMIPS | mips:*:*:RISCos) eval $set_cc_for_build sed 's/^ //' << EOF >$dummy.c #ifdef __cplusplus #include /* for printf() prototype */ int main (int argc, char *argv[]) { #else int main (argc, argv) int argc; char *argv[]; { #endif #if defined (host_mips) && defined (MIPSEB) #if defined (SYSTYPE_SYSV) printf ("mips-mips-riscos%ssysv\n", argv[1]); exit (0); #endif #if defined (SYSTYPE_SVR4) printf ("mips-mips-riscos%ssvr4\n", argv[1]); exit (0); #endif #if defined (SYSTYPE_BSD43) || defined(SYSTYPE_BSD) printf ("mips-mips-riscos%sbsd\n", argv[1]); exit (0); #endif #endif exit (-1); } EOF $CC_FOR_BUILD -o $dummy $dummy.c && dummyarg=`echo "${UNAME_RELEASE}" | sed -n 's/\([0-9]*\).*/\1/p'` && SYSTEM_NAME=`$dummy $dummyarg` && { echo "$SYSTEM_NAME"; exit; } echo mips-mips-riscos${UNAME_RELEASE} exit ;; Motorola:PowerMAX_OS:*:*) echo powerpc-motorola-powermax exit ;; Motorola:*:4.3:PL8-*) echo powerpc-harris-powermax exit ;; Night_Hawk:*:*:PowerMAX_OS | Synergy:PowerMAX_OS:*:*) echo powerpc-harris-powermax exit ;; Night_Hawk:Power_UNIX:*:*) echo powerpc-harris-powerunix exit ;; m88k:CX/UX:7*:*) echo m88k-harris-cxux7 exit ;; m88k:*:4*:R4*) echo m88k-motorola-sysv4 exit ;; m88k:*:3*:R3*) echo m88k-motorola-sysv3 exit ;; AViiON:dgux:*:*) # DG/UX returns AViiON for all architectures UNAME_PROCESSOR=`/usr/bin/uname -p` if [ $UNAME_PROCESSOR = mc88100 ] || [ $UNAME_PROCESSOR = mc88110 ] then if [ ${TARGET_BINARY_INTERFACE}x = m88kdguxelfx ] || \ [ ${TARGET_BINARY_INTERFACE}x = x ] then echo m88k-dg-dgux${UNAME_RELEASE} else echo m88k-dg-dguxbcs${UNAME_RELEASE} fi else echo i586-dg-dgux${UNAME_RELEASE} fi exit ;; M88*:DolphinOS:*:*) # DolphinOS (SVR3) echo m88k-dolphin-sysv3 exit ;; M88*:*:R3*:*) # Delta 88k system running SVR3 echo m88k-motorola-sysv3 exit ;; XD88*:*:*:*) # Tektronix XD88 system running UTekV (SVR3) echo m88k-tektronix-sysv3 exit ;; Tek43[0-9][0-9]:UTek:*:*) # Tektronix 4300 system running UTek (BSD) echo m68k-tektronix-bsd exit ;; *:IRIX*:*:*) echo mips-sgi-irix`echo ${UNAME_RELEASE}|sed -e 's/-/_/g'` exit ;; ????????:AIX?:[12].1:2) # AIX 2.2.1 or AIX 2.1.1 is RT/PC AIX. echo romp-ibm-aix # uname -m gives an 8 hex-code CPU id exit ;; # Note that: echo "'`uname -s`'" gives 'AIX ' i*86:AIX:*:*) echo i386-ibm-aix exit ;; ia64:AIX:*:*) if [ -x /usr/bin/oslevel ] ; then IBM_REV=`/usr/bin/oslevel` else IBM_REV=${UNAME_VERSION}.${UNAME_RELEASE} fi echo ${UNAME_MACHINE}-ibm-aix${IBM_REV} exit ;; *:AIX:2:3) if grep bos325 /usr/include/stdio.h >/dev/null 2>&1; then eval $set_cc_for_build sed 's/^ //' << EOF >$dummy.c #include main() { if (!__power_pc()) exit(1); puts("powerpc-ibm-aix3.2.5"); exit(0); } EOF if $CC_FOR_BUILD -o $dummy $dummy.c && SYSTEM_NAME=`$dummy` then echo "$SYSTEM_NAME" else echo rs6000-ibm-aix3.2.5 fi elif grep bos324 /usr/include/stdio.h >/dev/null 2>&1; then echo rs6000-ibm-aix3.2.4 else echo rs6000-ibm-aix3.2 fi exit ;; *:AIX:*:[4567]) IBM_CPU_ID=`/usr/sbin/lsdev -C -c processor -S available | sed 1q | awk '{ print $1 }'` if /usr/sbin/lsattr -El ${IBM_CPU_ID} | grep ' POWER' >/dev/null 2>&1; then IBM_ARCH=rs6000 else IBM_ARCH=powerpc fi if [ -x /usr/bin/lslpp ] ; then IBM_REV=`/usr/bin/lslpp -Lqc bos.rte.libc | awk -F: '{ print $3 }' | sed s/[0-9]*$/0/` else IBM_REV=${UNAME_VERSION}.${UNAME_RELEASE} fi echo ${IBM_ARCH}-ibm-aix${IBM_REV} exit ;; *:AIX:*:*) echo rs6000-ibm-aix exit ;; ibmrt:4.4BSD:*|romp-ibm:BSD:*) echo romp-ibm-bsd4.4 exit ;; ibmrt:*BSD:*|romp-ibm:BSD:*) # covers RT/PC BSD and echo romp-ibm-bsd${UNAME_RELEASE} # 4.3 with uname added to exit ;; # report: romp-ibm BSD 4.3 *:BOSX:*:*) echo rs6000-bull-bosx exit ;; DPX/2?00:B.O.S.:*:*) echo m68k-bull-sysv3 exit ;; 9000/[34]??:4.3bsd:1.*:*) echo m68k-hp-bsd exit ;; hp300:4.4BSD:*:* | 9000/[34]??:4.3bsd:2.*:*) echo m68k-hp-bsd4.4 exit ;; 9000/[34678]??:HP-UX:*:*) HPUX_REV=`echo ${UNAME_RELEASE}|sed -e 's/[^.]*.[0B]*//'` case "${UNAME_MACHINE}" in 9000/31? ) HP_ARCH=m68000 ;; 9000/[34]?? ) HP_ARCH=m68k ;; 9000/[678][0-9][0-9]) if [ -x /usr/bin/getconf ]; then sc_cpu_version=`/usr/bin/getconf SC_CPU_VERSION 2>/dev/null` sc_kernel_bits=`/usr/bin/getconf SC_KERNEL_BITS 2>/dev/null` case "${sc_cpu_version}" in 523) HP_ARCH="hppa1.0" ;; # CPU_PA_RISC1_0 528) HP_ARCH="hppa1.1" ;; # CPU_PA_RISC1_1 532) # CPU_PA_RISC2_0 case "${sc_kernel_bits}" in 32) HP_ARCH="hppa2.0n" ;; 64) HP_ARCH="hppa2.0w" ;; '') HP_ARCH="hppa2.0" ;; # HP-UX 10.20 esac ;; esac fi if [ "${HP_ARCH}" = "" ]; then eval $set_cc_for_build sed 's/^ //' << EOF >$dummy.c #define _HPUX_SOURCE #include #include int main () { #if defined(_SC_KERNEL_BITS) long bits = sysconf(_SC_KERNEL_BITS); #endif long cpu = sysconf (_SC_CPU_VERSION); switch (cpu) { case CPU_PA_RISC1_0: puts ("hppa1.0"); break; case CPU_PA_RISC1_1: puts ("hppa1.1"); break; case CPU_PA_RISC2_0: #if defined(_SC_KERNEL_BITS) switch (bits) { case 64: puts ("hppa2.0w"); break; case 32: puts ("hppa2.0n"); break; default: puts ("hppa2.0"); break; } break; #else /* !defined(_SC_KERNEL_BITS) */ puts ("hppa2.0"); break; #endif default: puts ("hppa1.0"); break; } exit (0); } EOF (CCOPTS= $CC_FOR_BUILD -o $dummy $dummy.c 2>/dev/null) && HP_ARCH=`$dummy` test -z "$HP_ARCH" && HP_ARCH=hppa fi ;; esac if [ ${HP_ARCH} = "hppa2.0w" ] then eval $set_cc_for_build # hppa2.0w-hp-hpux* has a 64-bit kernel and a compiler generating # 32-bit code. hppa64-hp-hpux* has the same kernel and a compiler # generating 64-bit code. GNU and HP use different nomenclature: # # $ CC_FOR_BUILD=cc ./config.guess # => hppa2.0w-hp-hpux11.23 # $ CC_FOR_BUILD="cc +DA2.0w" ./config.guess # => hppa64-hp-hpux11.23 if echo __LP64__ | (CCOPTS= $CC_FOR_BUILD -E - 2>/dev/null) | grep -q __LP64__ then HP_ARCH="hppa2.0w" else HP_ARCH="hppa64" fi fi echo ${HP_ARCH}-hp-hpux${HPUX_REV} exit ;; ia64:HP-UX:*:*) HPUX_REV=`echo ${UNAME_RELEASE}|sed -e 's/[^.]*.[0B]*//'` echo ia64-hp-hpux${HPUX_REV} exit ;; 3050*:HI-UX:*:*) eval $set_cc_for_build sed 's/^ //' << EOF >$dummy.c #include int main () { long cpu = sysconf (_SC_CPU_VERSION); /* The order matters, because CPU_IS_HP_MC68K erroneously returns true for CPU_PA_RISC1_0. CPU_IS_PA_RISC returns correct results, however. */ if (CPU_IS_PA_RISC (cpu)) { switch (cpu) { case CPU_PA_RISC1_0: puts ("hppa1.0-hitachi-hiuxwe2"); break; case CPU_PA_RISC1_1: puts ("hppa1.1-hitachi-hiuxwe2"); break; case CPU_PA_RISC2_0: puts ("hppa2.0-hitachi-hiuxwe2"); break; default: puts ("hppa-hitachi-hiuxwe2"); break; } } else if (CPU_IS_HP_MC68K (cpu)) puts ("m68k-hitachi-hiuxwe2"); else puts ("unknown-hitachi-hiuxwe2"); exit (0); } EOF $CC_FOR_BUILD -o $dummy $dummy.c && SYSTEM_NAME=`$dummy` && { echo "$SYSTEM_NAME"; exit; } echo unknown-hitachi-hiuxwe2 exit ;; 9000/7??:4.3bsd:*:* | 9000/8?[79]:4.3bsd:*:* ) echo hppa1.1-hp-bsd exit ;; 9000/8??:4.3bsd:*:*) echo hppa1.0-hp-bsd exit ;; *9??*:MPE/iX:*:* | *3000*:MPE/iX:*:*) echo hppa1.0-hp-mpeix exit ;; hp7??:OSF1:*:* | hp8?[79]:OSF1:*:* ) echo hppa1.1-hp-osf exit ;; hp8??:OSF1:*:*) echo hppa1.0-hp-osf exit ;; i*86:OSF1:*:*) if [ -x /usr/sbin/sysversion ] ; then echo ${UNAME_MACHINE}-unknown-osf1mk else echo ${UNAME_MACHINE}-unknown-osf1 fi exit ;; parisc*:Lites*:*:*) echo hppa1.1-hp-lites exit ;; C1*:ConvexOS:*:* | convex:ConvexOS:C1*:*) echo c1-convex-bsd exit ;; C2*:ConvexOS:*:* | convex:ConvexOS:C2*:*) if getsysinfo -f scalar_acc then echo c32-convex-bsd else echo c2-convex-bsd fi exit ;; C34*:ConvexOS:*:* | convex:ConvexOS:C34*:*) echo c34-convex-bsd exit ;; C38*:ConvexOS:*:* | convex:ConvexOS:C38*:*) echo c38-convex-bsd exit ;; C4*:ConvexOS:*:* | convex:ConvexOS:C4*:*) echo c4-convex-bsd exit ;; CRAY*Y-MP:*:*:*) echo ymp-cray-unicos${UNAME_RELEASE} | sed -e 's/\.[^.]*$/.X/' exit ;; CRAY*[A-Z]90:*:*:*) echo ${UNAME_MACHINE}-cray-unicos${UNAME_RELEASE} \ | sed -e 's/CRAY.*\([A-Z]90\)/\1/' \ -e y/ABCDEFGHIJKLMNOPQRSTUVWXYZ/abcdefghijklmnopqrstuvwxyz/ \ -e 's/\.[^.]*$/.X/' exit ;; CRAY*TS:*:*:*) echo t90-cray-unicos${UNAME_RELEASE} | sed -e 's/\.[^.]*$/.X/' exit ;; CRAY*T3E:*:*:*) echo alphaev5-cray-unicosmk${UNAME_RELEASE} | sed -e 's/\.[^.]*$/.X/' exit ;; CRAY*SV1:*:*:*) echo sv1-cray-unicos${UNAME_RELEASE} | sed -e 's/\.[^.]*$/.X/' exit ;; *:UNICOS/mp:*:*) echo craynv-cray-unicosmp${UNAME_RELEASE} | sed -e 's/\.[^.]*$/.X/' exit ;; F30[01]:UNIX_System_V:*:* | F700:UNIX_System_V:*:*) FUJITSU_PROC=`uname -m | tr 'ABCDEFGHIJKLMNOPQRSTUVWXYZ' 'abcdefghijklmnopqrstuvwxyz'` FUJITSU_SYS=`uname -p | tr 'ABCDEFGHIJKLMNOPQRSTUVWXYZ' 'abcdefghijklmnopqrstuvwxyz' | sed -e 's/\///'` FUJITSU_REL=`echo ${UNAME_RELEASE} | sed -e 's/ /_/'` echo "${FUJITSU_PROC}-fujitsu-${FUJITSU_SYS}${FUJITSU_REL}" exit ;; 5000:UNIX_System_V:4.*:*) FUJITSU_SYS=`uname -p | tr 'ABCDEFGHIJKLMNOPQRSTUVWXYZ' 'abcdefghijklmnopqrstuvwxyz' | sed -e 's/\///'` FUJITSU_REL=`echo ${UNAME_RELEASE} | tr 'ABCDEFGHIJKLMNOPQRSTUVWXYZ' 'abcdefghijklmnopqrstuvwxyz' | sed -e 's/ /_/'` echo "sparc-fujitsu-${FUJITSU_SYS}${FUJITSU_REL}" exit ;; i*86:BSD/386:*:* | i*86:BSD/OS:*:* | *:Ascend\ Embedded/OS:*:*) echo ${UNAME_MACHINE}-pc-bsdi${UNAME_RELEASE} exit ;; sparc*:BSD/OS:*:*) echo sparc-unknown-bsdi${UNAME_RELEASE} exit ;; *:BSD/OS:*:*) echo ${UNAME_MACHINE}-unknown-bsdi${UNAME_RELEASE} exit ;; *:FreeBSD:*:*) UNAME_PROCESSOR=`/usr/bin/uname -p` echo ${UNAME_PROCESSOR}-unknown-freebsd`echo ${UNAME_RELEASE}|sed -e 's/[-(].*//'` exit ;; i*:CYGWIN*:*) echo ${UNAME_MACHINE}-pc-cygwin exit ;; *:MINGW64*:*) echo ${UNAME_MACHINE}-pc-mingw64 exit ;; *:MINGW*:*) echo ${UNAME_MACHINE}-pc-mingw32 exit ;; *:MSYS*:*) echo ${UNAME_MACHINE}-pc-msys exit ;; i*:windows32*:*) # uname -m includes "-pc" on this system. echo ${UNAME_MACHINE}-mingw32 exit ;; i*:PW*:*) echo ${UNAME_MACHINE}-pc-pw32 exit ;; *:Interix*:*) case ${UNAME_MACHINE} in x86) echo i586-pc-interix${UNAME_RELEASE} exit ;; authenticamd | genuineintel | EM64T) echo x86_64-unknown-interix${UNAME_RELEASE} exit ;; IA64) echo ia64-unknown-interix${UNAME_RELEASE} exit ;; esac ;; [345]86:Windows_95:* | [345]86:Windows_98:* | [345]86:Windows_NT:*) echo i${UNAME_MACHINE}-pc-mks exit ;; 8664:Windows_NT:*) echo x86_64-pc-mks exit ;; i*:Windows_NT*:* | Pentium*:Windows_NT*:*) # How do we know it's Interix rather than the generic POSIX subsystem? # It also conflicts with pre-2.0 versions of AT&T UWIN. Should we # UNAME_MACHINE based on the output of uname instead of i386? echo i586-pc-interix exit ;; i*:UWIN*:*) echo ${UNAME_MACHINE}-pc-uwin exit ;; amd64:CYGWIN*:*:* | x86_64:CYGWIN*:*:*) echo x86_64-unknown-cygwin exit ;; p*:CYGWIN*:*) echo powerpcle-unknown-cygwin exit ;; prep*:SunOS:5.*:*) echo powerpcle-unknown-solaris2`echo ${UNAME_RELEASE}|sed -e 's/[^.]*//'` exit ;; *:GNU:*:*) # the GNU system echo `echo ${UNAME_MACHINE}|sed -e 's,[-/].*$,,'`-unknown-${LIBC}`echo ${UNAME_RELEASE}|sed -e 's,/.*$,,'` exit ;; *:GNU/*:*:*) # other systems with GNU libc and userland echo ${UNAME_MACHINE}-unknown-`echo ${UNAME_SYSTEM} | sed 's,^[^/]*/,,' | tr '[A-Z]' '[a-z]'``echo ${UNAME_RELEASE}|sed -e 's/[-(].*//'`-${LIBC} exit ;; i*86:Minix:*:*) echo ${UNAME_MACHINE}-pc-minix exit ;; aarch64:Linux:*:*) echo ${UNAME_MACHINE}-unknown-linux-${LIBC} exit ;; aarch64_be:Linux:*:*) UNAME_MACHINE=aarch64_be echo ${UNAME_MACHINE}-unknown-linux-${LIBC} exit ;; alpha:Linux:*:*) case `sed -n '/^cpu model/s/^.*: \(.*\)/\1/p' < /proc/cpuinfo` in EV5) UNAME_MACHINE=alphaev5 ;; EV56) UNAME_MACHINE=alphaev56 ;; PCA56) UNAME_MACHINE=alphapca56 ;; PCA57) UNAME_MACHINE=alphapca56 ;; EV6) UNAME_MACHINE=alphaev6 ;; EV67) UNAME_MACHINE=alphaev67 ;; EV68*) UNAME_MACHINE=alphaev68 ;; esac objdump --private-headers /bin/sh | grep -q ld.so.1 if test "$?" = 0 ; then LIBC="gnulibc1" ; fi echo ${UNAME_MACHINE}-unknown-linux-${LIBC} exit ;; arc:Linux:*:* | arceb:Linux:*:*) echo ${UNAME_MACHINE}-unknown-linux-${LIBC} exit ;; arm*:Linux:*:*) eval $set_cc_for_build if echo __ARM_EABI__ | $CC_FOR_BUILD -E - 2>/dev/null \ | grep -q __ARM_EABI__ then echo ${UNAME_MACHINE}-unknown-linux-${LIBC} else if echo __ARM_PCS_VFP | $CC_FOR_BUILD -E - 2>/dev/null \ | grep -q __ARM_PCS_VFP then echo ${UNAME_MACHINE}-unknown-linux-${LIBC}eabi else echo ${UNAME_MACHINE}-unknown-linux-${LIBC}eabihf fi fi exit ;; avr32*:Linux:*:*) echo ${UNAME_MACHINE}-unknown-linux-${LIBC} exit ;; cris:Linux:*:*) echo ${UNAME_MACHINE}-axis-linux-${LIBC} exit ;; crisv32:Linux:*:*) echo ${UNAME_MACHINE}-axis-linux-${LIBC} exit ;; e2k:Linux:*:*) echo ${UNAME_MACHINE}-unknown-linux-${LIBC} exit ;; frv:Linux:*:*) echo ${UNAME_MACHINE}-unknown-linux-${LIBC} exit ;; hexagon:Linux:*:*) echo ${UNAME_MACHINE}-unknown-linux-${LIBC} exit ;; i*86:Linux:*:*) echo ${UNAME_MACHINE}-pc-linux-${LIBC} exit ;; ia64:Linux:*:*) echo ${UNAME_MACHINE}-unknown-linux-${LIBC} exit ;; m32r*:Linux:*:*) echo ${UNAME_MACHINE}-unknown-linux-${LIBC} exit ;; m68*:Linux:*:*) echo ${UNAME_MACHINE}-unknown-linux-${LIBC} exit ;; mips:Linux:*:* | mips64:Linux:*:*) eval $set_cc_for_build sed 's/^ //' << EOF >$dummy.c #undef CPU #undef ${UNAME_MACHINE} #undef ${UNAME_MACHINE}el #if defined(__MIPSEL__) || defined(__MIPSEL) || defined(_MIPSEL) || defined(MIPSEL) CPU=${UNAME_MACHINE}el #else #if defined(__MIPSEB__) || defined(__MIPSEB) || defined(_MIPSEB) || defined(MIPSEB) CPU=${UNAME_MACHINE} #else CPU= #endif #endif EOF eval `$CC_FOR_BUILD -E $dummy.c 2>/dev/null | grep '^CPU'` test x"${CPU}" != x && { echo "${CPU}-unknown-linux-${LIBC}"; exit; } ;; openrisc*:Linux:*:*) echo or1k-unknown-linux-${LIBC} exit ;; or32:Linux:*:* | or1k*:Linux:*:*) echo ${UNAME_MACHINE}-unknown-linux-${LIBC} exit ;; padre:Linux:*:*) echo sparc-unknown-linux-${LIBC} exit ;; parisc64:Linux:*:* | hppa64:Linux:*:*) echo hppa64-unknown-linux-${LIBC} exit ;; parisc:Linux:*:* | hppa:Linux:*:*) # Look for CPU level case `grep '^cpu[^a-z]*:' /proc/cpuinfo 2>/dev/null | cut -d' ' -f2` in PA7*) echo hppa1.1-unknown-linux-${LIBC} ;; PA8*) echo hppa2.0-unknown-linux-${LIBC} ;; *) echo hppa-unknown-linux-${LIBC} ;; esac exit ;; ppc64:Linux:*:*) echo powerpc64-unknown-linux-${LIBC} exit ;; ppc:Linux:*:*) echo powerpc-unknown-linux-${LIBC} exit ;; ppc64le:Linux:*:*) echo powerpc64le-unknown-linux-${LIBC} exit ;; ppcle:Linux:*:*) echo powerpcle-unknown-linux-${LIBC} exit ;; s390:Linux:*:* | s390x:Linux:*:*) echo ${UNAME_MACHINE}-ibm-linux-${LIBC} exit ;; sh64*:Linux:*:*) echo ${UNAME_MACHINE}-unknown-linux-${LIBC} exit ;; sh*:Linux:*:*) echo ${UNAME_MACHINE}-unknown-linux-${LIBC} exit ;; sparc:Linux:*:* | sparc64:Linux:*:*) echo ${UNAME_MACHINE}-unknown-linux-${LIBC} exit ;; tile*:Linux:*:*) echo ${UNAME_MACHINE}-unknown-linux-${LIBC} exit ;; vax:Linux:*:*) echo ${UNAME_MACHINE}-dec-linux-${LIBC} exit ;; x86_64:Linux:*:*) echo ${UNAME_MACHINE}-unknown-linux-${LIBC} exit ;; xtensa*:Linux:*:*) echo ${UNAME_MACHINE}-unknown-linux-${LIBC} exit ;; i*86:DYNIX/ptx:4*:*) # ptx 4.0 does uname -s correctly, with DYNIX/ptx in there. # earlier versions are messed up and put the nodename in both # sysname and nodename. echo i386-sequent-sysv4 exit ;; i*86:UNIX_SV:4.2MP:2.*) # Unixware is an offshoot of SVR4, but it has its own version # number series starting with 2... # I am not positive that other SVR4 systems won't match this, # I just have to hope. -- rms. # Use sysv4.2uw... so that sysv4* matches it. echo ${UNAME_MACHINE}-pc-sysv4.2uw${UNAME_VERSION} exit ;; i*86:OS/2:*:*) # If we were able to find `uname', then EMX Unix compatibility # is probably installed. echo ${UNAME_MACHINE}-pc-os2-emx exit ;; i*86:XTS-300:*:STOP) echo ${UNAME_MACHINE}-unknown-stop exit ;; i*86:atheos:*:*) echo ${UNAME_MACHINE}-unknown-atheos exit ;; i*86:syllable:*:*) echo ${UNAME_MACHINE}-pc-syllable exit ;; i*86:LynxOS:2.*:* | i*86:LynxOS:3.[01]*:* | i*86:LynxOS:4.[02]*:*) echo i386-unknown-lynxos${UNAME_RELEASE} exit ;; i*86:*DOS:*:*) echo ${UNAME_MACHINE}-pc-msdosdjgpp exit ;; i*86:*:4.*:* | i*86:SYSTEM_V:4.*:*) UNAME_REL=`echo ${UNAME_RELEASE} | sed 's/\/MP$//'` if grep Novell /usr/include/link.h >/dev/null 2>/dev/null; then echo ${UNAME_MACHINE}-univel-sysv${UNAME_REL} else echo ${UNAME_MACHINE}-pc-sysv${UNAME_REL} fi exit ;; i*86:*:5:[678]*) # UnixWare 7.x, OpenUNIX and OpenServer 6. case `/bin/uname -X | grep "^Machine"` in *486*) UNAME_MACHINE=i486 ;; *Pentium) UNAME_MACHINE=i586 ;; *Pent*|*Celeron) UNAME_MACHINE=i686 ;; esac echo ${UNAME_MACHINE}-unknown-sysv${UNAME_RELEASE}${UNAME_SYSTEM}${UNAME_VERSION} exit ;; i*86:*:3.2:*) if test -f /usr/options/cb.name; then UNAME_REL=`sed -n 's/.*Version //p' /dev/null >/dev/null ; then UNAME_REL=`(/bin/uname -X|grep Release|sed -e 's/.*= //')` (/bin/uname -X|grep i80486 >/dev/null) && UNAME_MACHINE=i486 (/bin/uname -X|grep '^Machine.*Pentium' >/dev/null) \ && UNAME_MACHINE=i586 (/bin/uname -X|grep '^Machine.*Pent *II' >/dev/null) \ && UNAME_MACHINE=i686 (/bin/uname -X|grep '^Machine.*Pentium Pro' >/dev/null) \ && UNAME_MACHINE=i686 echo ${UNAME_MACHINE}-pc-sco$UNAME_REL else echo ${UNAME_MACHINE}-pc-sysv32 fi exit ;; pc:*:*:*) # Left here for compatibility: # uname -m prints for DJGPP always 'pc', but it prints nothing about # the processor, so we play safe by assuming i586. # Note: whatever this is, it MUST be the same as what config.sub # prints for the "djgpp" host, or else GDB configury will decide that # this is a cross-build. echo i586-pc-msdosdjgpp exit ;; Intel:Mach:3*:*) echo i386-pc-mach3 exit ;; paragon:*:*:*) echo i860-intel-osf1 exit ;; i860:*:4.*:*) # i860-SVR4 if grep Stardent /usr/include/sys/uadmin.h >/dev/null 2>&1 ; then echo i860-stardent-sysv${UNAME_RELEASE} # Stardent Vistra i860-SVR4 else # Add other i860-SVR4 vendors below as they are discovered. echo i860-unknown-sysv${UNAME_RELEASE} # Unknown i860-SVR4 fi exit ;; mini*:CTIX:SYS*5:*) # "miniframe" echo m68010-convergent-sysv exit ;; mc68k:UNIX:SYSTEM5:3.51m) echo m68k-convergent-sysv exit ;; M680?0:D-NIX:5.3:*) echo m68k-diab-dnix exit ;; M68*:*:R3V[5678]*:*) test -r /sysV68 && { echo 'm68k-motorola-sysv'; exit; } ;; 3[345]??:*:4.0:3.0 | 3[34]??A:*:4.0:3.0 | 3[34]??,*:*:4.0:3.0 | 3[34]??/*:*:4.0:3.0 | 4400:*:4.0:3.0 | 4850:*:4.0:3.0 | SKA40:*:4.0:3.0 | SDS2:*:4.0:3.0 | SHG2:*:4.0:3.0 | S7501*:*:4.0:3.0) OS_REL='' test -r /etc/.relid \ && OS_REL=.`sed -n 's/[^ ]* [^ ]* \([0-9][0-9]\).*/\1/p' < /etc/.relid` /bin/uname -p 2>/dev/null | grep 86 >/dev/null \ && { echo i486-ncr-sysv4.3${OS_REL}; exit; } /bin/uname -p 2>/dev/null | /bin/grep entium >/dev/null \ && { echo i586-ncr-sysv4.3${OS_REL}; exit; } ;; 3[34]??:*:4.0:* | 3[34]??,*:*:4.0:*) /bin/uname -p 2>/dev/null | grep 86 >/dev/null \ && { echo i486-ncr-sysv4; exit; } ;; NCR*:*:4.2:* | MPRAS*:*:4.2:*) OS_REL='.3' test -r /etc/.relid \ && OS_REL=.`sed -n 's/[^ ]* [^ ]* \([0-9][0-9]\).*/\1/p' < /etc/.relid` /bin/uname -p 2>/dev/null | grep 86 >/dev/null \ && { echo i486-ncr-sysv4.3${OS_REL}; exit; } /bin/uname -p 2>/dev/null | /bin/grep entium >/dev/null \ && { echo i586-ncr-sysv4.3${OS_REL}; exit; } /bin/uname -p 2>/dev/null | /bin/grep pteron >/dev/null \ && { echo i586-ncr-sysv4.3${OS_REL}; exit; } ;; m68*:LynxOS:2.*:* | m68*:LynxOS:3.0*:*) echo m68k-unknown-lynxos${UNAME_RELEASE} exit ;; mc68030:UNIX_System_V:4.*:*) echo m68k-atari-sysv4 exit ;; TSUNAMI:LynxOS:2.*:*) echo sparc-unknown-lynxos${UNAME_RELEASE} exit ;; rs6000:LynxOS:2.*:*) echo rs6000-unknown-lynxos${UNAME_RELEASE} exit ;; PowerPC:LynxOS:2.*:* | PowerPC:LynxOS:3.[01]*:* | PowerPC:LynxOS:4.[02]*:*) echo powerpc-unknown-lynxos${UNAME_RELEASE} exit ;; SM[BE]S:UNIX_SV:*:*) echo mips-dde-sysv${UNAME_RELEASE} exit ;; RM*:ReliantUNIX-*:*:*) echo mips-sni-sysv4 exit ;; RM*:SINIX-*:*:*) echo mips-sni-sysv4 exit ;; *:SINIX-*:*:*) if uname -p 2>/dev/null >/dev/null ; then UNAME_MACHINE=`(uname -p) 2>/dev/null` echo ${UNAME_MACHINE}-sni-sysv4 else echo ns32k-sni-sysv fi exit ;; PENTIUM:*:4.0*:*) # Unisys `ClearPath HMP IX 4000' SVR4/MP effort # says echo i586-unisys-sysv4 exit ;; *:UNIX_System_V:4*:FTX*) # From Gerald Hewes . # How about differentiating between stratus architectures? -djm echo hppa1.1-stratus-sysv4 exit ;; *:*:*:FTX*) # From seanf@swdc.stratus.com. echo i860-stratus-sysv4 exit ;; i*86:VOS:*:*) # From Paul.Green@stratus.com. echo ${UNAME_MACHINE}-stratus-vos exit ;; *:VOS:*:*) # From Paul.Green@stratus.com. echo hppa1.1-stratus-vos exit ;; mc68*:A/UX:*:*) echo m68k-apple-aux${UNAME_RELEASE} exit ;; news*:NEWS-OS:6*:*) echo mips-sony-newsos6 exit ;; R[34]000:*System_V*:*:* | R4000:UNIX_SYSV:*:* | R*000:UNIX_SV:*:*) if [ -d /usr/nec ]; then echo mips-nec-sysv${UNAME_RELEASE} else echo mips-unknown-sysv${UNAME_RELEASE} fi exit ;; BeBox:BeOS:*:*) # BeOS running on hardware made by Be, PPC only. echo powerpc-be-beos exit ;; BeMac:BeOS:*:*) # BeOS running on Mac or Mac clone, PPC only. echo powerpc-apple-beos exit ;; BePC:BeOS:*:*) # BeOS running on Intel PC compatible. echo i586-pc-beos exit ;; BePC:Haiku:*:*) # Haiku running on Intel PC compatible. echo i586-pc-haiku exit ;; x86_64:Haiku:*:*) echo x86_64-unknown-haiku exit ;; SX-4:SUPER-UX:*:*) echo sx4-nec-superux${UNAME_RELEASE} exit ;; SX-5:SUPER-UX:*:*) echo sx5-nec-superux${UNAME_RELEASE} exit ;; SX-6:SUPER-UX:*:*) echo sx6-nec-superux${UNAME_RELEASE} exit ;; SX-7:SUPER-UX:*:*) echo sx7-nec-superux${UNAME_RELEASE} exit ;; SX-8:SUPER-UX:*:*) echo sx8-nec-superux${UNAME_RELEASE} exit ;; SX-8R:SUPER-UX:*:*) echo sx8r-nec-superux${UNAME_RELEASE} exit ;; Power*:Rhapsody:*:*) echo powerpc-apple-rhapsody${UNAME_RELEASE} exit ;; *:Rhapsody:*:*) echo ${UNAME_MACHINE}-apple-rhapsody${UNAME_RELEASE} exit ;; *:Darwin:*:*) UNAME_PROCESSOR=`uname -p` || UNAME_PROCESSOR=unknown eval $set_cc_for_build if test "$UNAME_PROCESSOR" = unknown ; then UNAME_PROCESSOR=powerpc fi if test `echo "$UNAME_RELEASE" | sed -e 's/\..*//'` -le 10 ; then if [ "$CC_FOR_BUILD" != 'no_compiler_found' ]; then if (echo '#ifdef __LP64__'; echo IS_64BIT_ARCH; echo '#endif') | \ (CCOPTS= $CC_FOR_BUILD -E - 2>/dev/null) | \ grep IS_64BIT_ARCH >/dev/null then case $UNAME_PROCESSOR in i386) UNAME_PROCESSOR=x86_64 ;; powerpc) UNAME_PROCESSOR=powerpc64 ;; esac fi fi elif test "$UNAME_PROCESSOR" = i386 ; then # Avoid executing cc on OS X 10.9, as it ships with a stub # that puts up a graphical alert prompting to install # developer tools. Any system running Mac OS X 10.7 or # later (Darwin 11 and later) is required to have a 64-bit # processor. This is not true of the ARM version of Darwin # that Apple uses in portable devices. UNAME_PROCESSOR=x86_64 fi echo ${UNAME_PROCESSOR}-apple-darwin${UNAME_RELEASE} exit ;; *:procnto*:*:* | *:QNX:[0123456789]*:*) UNAME_PROCESSOR=`uname -p` if test "$UNAME_PROCESSOR" = "x86"; then UNAME_PROCESSOR=i386 UNAME_MACHINE=pc fi echo ${UNAME_PROCESSOR}-${UNAME_MACHINE}-nto-qnx${UNAME_RELEASE} exit ;; *:QNX:*:4*) echo i386-pc-qnx exit ;; NEO-?:NONSTOP_KERNEL:*:*) echo neo-tandem-nsk${UNAME_RELEASE} exit ;; NSE-*:NONSTOP_KERNEL:*:*) echo nse-tandem-nsk${UNAME_RELEASE} exit ;; NSR-?:NONSTOP_KERNEL:*:*) echo nsr-tandem-nsk${UNAME_RELEASE} exit ;; *:NonStop-UX:*:*) echo mips-compaq-nonstopux exit ;; BS2000:POSIX*:*:*) echo bs2000-siemens-sysv exit ;; DS/*:UNIX_System_V:*:*) echo ${UNAME_MACHINE}-${UNAME_SYSTEM}-${UNAME_RELEASE} exit ;; *:Plan9:*:*) # "uname -m" is not consistent, so use $cputype instead. 386 # is converted to i386 for consistency with other x86 # operating systems. if test "$cputype" = "386"; then UNAME_MACHINE=i386 else UNAME_MACHINE="$cputype" fi echo ${UNAME_MACHINE}-unknown-plan9 exit ;; *:TOPS-10:*:*) echo pdp10-unknown-tops10 exit ;; *:TENEX:*:*) echo pdp10-unknown-tenex exit ;; KS10:TOPS-20:*:* | KL10:TOPS-20:*:* | TYPE4:TOPS-20:*:*) echo pdp10-dec-tops20 exit ;; XKL-1:TOPS-20:*:* | TYPE5:TOPS-20:*:*) echo pdp10-xkl-tops20 exit ;; *:TOPS-20:*:*) echo pdp10-unknown-tops20 exit ;; *:ITS:*:*) echo pdp10-unknown-its exit ;; SEI:*:*:SEIUX) echo mips-sei-seiux${UNAME_RELEASE} exit ;; *:DragonFly:*:*) echo ${UNAME_MACHINE}-unknown-dragonfly`echo ${UNAME_RELEASE}|sed -e 's/[-(].*//'` exit ;; *:*VMS:*:*) UNAME_MACHINE=`(uname -p) 2>/dev/null` case "${UNAME_MACHINE}" in A*) echo alpha-dec-vms ; exit ;; I*) echo ia64-dec-vms ; exit ;; V*) echo vax-dec-vms ; exit ;; esac ;; *:XENIX:*:SysV) echo i386-pc-xenix exit ;; i*86:skyos:*:*) echo ${UNAME_MACHINE}-pc-skyos`echo ${UNAME_RELEASE}` | sed -e 's/ .*$//' exit ;; i*86:rdos:*:*) echo ${UNAME_MACHINE}-pc-rdos exit ;; i*86:AROS:*:*) echo ${UNAME_MACHINE}-pc-aros exit ;; x86_64:VMkernel:*:*) echo ${UNAME_MACHINE}-unknown-esx exit ;; esac cat >&2 < in order to provide the needed information to handle your system. config.guess timestamp = $timestamp uname -m = `(uname -m) 2>/dev/null || echo unknown` uname -r = `(uname -r) 2>/dev/null || echo unknown` uname -s = `(uname -s) 2>/dev/null || echo unknown` uname -v = `(uname -v) 2>/dev/null || echo unknown` /usr/bin/uname -p = `(/usr/bin/uname -p) 2>/dev/null` /bin/uname -X = `(/bin/uname -X) 2>/dev/null` hostinfo = `(hostinfo) 2>/dev/null` /bin/universe = `(/bin/universe) 2>/dev/null` /usr/bin/arch -k = `(/usr/bin/arch -k) 2>/dev/null` /bin/arch = `(/bin/arch) 2>/dev/null` /usr/bin/oslevel = `(/usr/bin/oslevel) 2>/dev/null` /usr/convex/getsysinfo = `(/usr/convex/getsysinfo) 2>/dev/null` UNAME_MACHINE = ${UNAME_MACHINE} UNAME_RELEASE = ${UNAME_RELEASE} UNAME_SYSTEM = ${UNAME_SYSTEM} UNAME_VERSION = ${UNAME_VERSION} EOF exit 1 # Local variables: # eval: (add-hook 'write-file-hooks 'time-stamp) # time-stamp-start: "timestamp='" # time-stamp-format: "%:y-%02m-%02d" # time-stamp-end: "'" # End: xrdp-0.9.5/coding_style.md000644 001751 001751 00000006151 13127114621 015430 0ustar00metameta000000 000000 XRdp Coding Style ================= The coding style used by XRdp is described below. The XRdp project uses astyle (artistic style) to format the code. Astyle requires a configuration file that describes how you want your code formatted. This file is present in the XRdp root directory and is named `astyle_config.as`. Here is how we run the astyle command: astyle --options=/path/to/file/astyle_config.as "*.c" This coding style is a work in progress and is still evolving. Language Standard ----------------- Try to make all code compile with both C and C++ compiler. C++ is more strict, which makes the code safer. Indentation ----------- * 4 spaces per indent * No tabs for any indents ☞ if (fd < 0) { return -1; } Line wrapping ------------- * Keep lines not longer than 80 chars * Align wrapped argument to the first argument ☞ log_message("connection aborted: error %d", ret); Variable names -------------- * Use lowercase with underscores as needed * Don't use camelCase * Preprocessor constants should be uppercase ☞ #define BUF_SIZE 1024 int fd; int bytes_in_stream; Variable declaration -------------------- * Each variable is declared on a separate line ☞ int i; int j; Whitespace ---------- * Use blank lines to group statements * Use at most one empty line between statements * For pointers and references, use a single space before * or & but not after * Use one space after a cast * No space before square brackets ☞ char *cptr; int *iptr; cptr = (char *) malloc(1024); write(fd, &buf[12], 16); Function declarations --------------------- * Use newline before function name ☞ static int value_ok(int val) { return (val >= 0); } Braces ------ * Opening brace is always on a separate line * Align braces with the line preceding the opening brace ☞ struct stream { int flags; char *data; }; void process_data(struct stream *s) { if (stream == NULL) { return; } } `if` statements --------------- * Always use braces * Put both braces on separate lines ☞ if (val <= 0xff) { out_uint8(s, val); } else if (val <= 0xffff) { out_uint16_le(s, val); } else { out_uint32_le(s, val); } `for` statements ---------------- * Always use braces * Put both braces on separate lines ☞ for (i = 0; i < 10; i++) { printf("i = %d\n", i); } `while` and `do while` statements --------------------------------- * Always use braces * `while` after the closing brace is on the same line ☞ while (cptr) { cptr—; } do { cptr--; } while (cptr); `switch` statements ------------------- * Indent `case` once * Indent statements under `case` one more time * Put both braces on separate lines ☞ switch (cmd) { case READ: read(fd, buf, 1024); break; default: printf("bad cmd\n"); } Comments -------- Use /* */ for comments Don't use // xrdp-0.9.5/COPYING000644 001751 001751 00000024224 13125122133 013452 0ustar00metameta000000 000000 Apache License, Version 2.0 Version 2.0, January 2004 http://www.apache.org/licenses/ TERMS AND CONDITIONS FOR USE, REPRODUCTION, AND DISTRIBUTION 1. Definitions. "License" shall mean the terms and conditions for use, reproduction, and distribution as defined by Sections 1 through 9 of this document. "Licensor" shall mean the copyright owner or entity authorized by the copyright owner that is granting the License. "Legal Entity" shall mean the union of the acting entity and all other entities that control, are controlled by, or are under common control with that entity. For the purposes of this definition, "control" means (i) the power, direct or indirect, to cause the direction or management of such entity, whether by contract or otherwise, or (ii) ownership of fifty percent (50%) or more of the outstanding shares, or (iii) beneficial ownership of such entity. "You" (or "Your") shall mean an individual or Legal Entity exercising permissions granted by this License. "Source" form shall mean the preferred form for making modifications, including but not limited to software source code, documentation source, and configuration files. "Object" form shall mean any form resulting from mechanical transformation or translation of a Source form, including but not limited to compiled object code, generated documentation, and conversions to other media types. "Work" shall mean the work of authorship, whether in Source or Object form, made available under the License, as indicated by a copyright notice that is included in or attached to the work (an example is provided in the Appendix below). "Derivative Works" shall mean any work, whether in Source or Object form, that is based on (or derived from) the Work and for which the editorial revisions, annotations, elaborations, or other modifications represent, as a whole, an original work of authorship. For the purposes of this License, Derivative Works shall not include works that remain separable from, or merely link (or bind by name) to the interfaces of, the Work and Derivative Works thereof. "Contribution" shall mean any work of authorship, including the original version of the Work and any modifications or additions to that Work or Derivative Works thereof, that is intentionally submitted to Licensor for inclusion in the Work by the copyright owner or by an individual or Legal Entity authorized to submit on behalf of the copyright owner. For the purposes of this definition, "submitted" means any form of electronic, verbal, or written communication sent to the Licensor or its representatives, including but not limited to communication on electronic mailing lists, source code control systems, and issue tracking systems that are managed by, or on behalf of, the Licensor for the purpose of discussing and improving the Work, but excluding communication that is conspicuously marked or otherwise designated in writing by the copyright owner as "Not a Contribution." "Contributor" shall mean Licensor and any individual or Legal Entity on behalf of whom a Contribution has been received by Licensor and subsequently incorporated within the Work. 2. Grant of Copyright License. Subject to the terms and conditions of this License, each Contributor hereby grants to You a perpetual, worldwide, non-exclusive, no-charge, royalty-free, irrevocable copyright license to reproduce, prepare Derivative Works of, publicly display, publicly perform, sublicense, and distribute the Work and such Derivative Works in Source or Object form. 3. Grant of Patent License. Subject to the terms and conditions of this License, each Contributor hereby grants to You a perpetual, worldwide, non-exclusive, no-charge, royalty-free, irrevocable (except as stated in this section) patent license to make, have made, use, offer to sell, sell, import, and otherwise transfer the Work, where such license applies only to those patent claims licensable by such Contributor that are necessarily infringed by their Contribution(s) alone or by combination of their Contribution(s) with the Work to which such Contribution(s) was submitted. If You institute patent litigation against any entity (including a cross-claim or counterclaim in a lawsuit) alleging that the Work or a Contribution incorporated within the Work constitutes direct or contributory patent infringement, then any patent licenses granted to You under this License for that Work shall terminate as of the date such litigation is filed. 4. Redistribution. You may reproduce and distribute copies of the Work or Derivative Works thereof in any medium, with or without modifications, and in Source or Object form, provided that You meet the following conditions: You must give any other recipients of the Work or Derivative Works a copy of this License; and You must cause any modified files to carry prominent notices stating that You changed the files; and You must retain, in the Source form of any Derivative Works that You distribute, all copyright, patent, trademark, and attribution notices from the Source form of the Work, excluding those notices that do not pertain to any part of the Derivative Works; and If the Work includes a "NOTICE" text file as part of its distribution, then any Derivative Works that You distribute must include a readable copy of the attribution notices contained within such NOTICE file, excluding those notices that do not pertain to any part of the Derivative Works, in at least one of the following places: within a NOTICE text file distributed as part of the Derivative Works; within the Source form or documentation, if provided along with the Derivative Works; or, within a display generated by the Derivative Works, if and wherever such third-party notices normally appear. The contents of the NOTICE file are for informational purposes only and do not modify the License. You may add Your own attribution notices within Derivative Works that You distribute, alongside or as an addendum to the NOTICE text from the Work, provided that such additional attribution notices cannot be construed as modifying the License. You may add Your own copyright statement to Your modifications and may provide additional or different license terms and conditions for use, reproduction, or distribution of Your modifications, or for any such Derivative Works as a whole, provided Your use, reproduction, and distribution of the Work otherwise complies with the conditions stated in this License. 5. Submission of Contributions. Unless You explicitly state otherwise, any Contribution intentionally submitted for inclusion in the Work by You to the Licensor shall be under the terms and conditions of this License, without any additional terms or conditions. Notwithstanding the above, nothing herein shall supersede or modify the terms of any separate license agreement you may have executed with Licensor regarding such Contributions. 6. Trademarks. This License does not grant permission to use the trade names, trademarks, service marks, or product names of the Licensor, except as required for reasonable and customary use in describing the origin of the Work and reproducing the content of the NOTICE file. 7. Disclaimer of Warranty. Unless required by applicable law or agreed to in writing, Licensor provides the Work (and each Contributor provides its Contributions) on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied, including, without limitation, any warranties or conditions of TITLE, NON-INFRINGEMENT, MERCHANTABILITY, or FITNESS FOR A PARTICULAR PURPOSE. You are solely responsible for determining the appropriateness of using or redistributing the Work and assume any risks associated with Your exercise of permissions under this License. 8. Limitation of Liability. In no event and under no legal theory, whether in tort (including negligence), contract, or otherwise, unless required by applicable law (such as deliberate and grossly negligent acts) or agreed to in writing, shall any Contributor be liable to You for damages, including any direct, indirect, special, incidental, or consequential damages of any character arising as a result of this License or out of the use or inability to use the Work (including but not limited to damages for loss of goodwill, work stoppage, computer failure or malfunction, or any and all other commercial damages or losses), even if such Contributor has been advised of the possibility of such damages. 9. Accepting Warranty or Additional Liability. While redistributing the Work or Derivative Works thereof, You may choose to offer, and charge a fee for, acceptance of support, warranty, indemnity, or other liability obligations and/or rights consistent with this License. However, in accepting such obligations, You may act only on Your own behalf and on Your sole responsibility, not on behalf of any other Contributor, and only if You agree to indemnify, defend, and hold each Contributor harmless for any liability incurred by, or claims asserted against, such Contributor by reason of your accepting any such warranty or additional liability. END OF TERMS AND CONDITIONS APPENDIX: How to apply the Apache License to your work To apply the Apache License to your work, attach the following boilerplate notice, with the fields enclosed by brackets "[]" replaced with your own identifying information. (Don't include the brackets!) The text should be enclosed in the appropriate comment syntax for the file format. We also recommend that a file or class name and description of purpose be included on the same "printed page" as the copyright notice for easier identification within third-party archives. Copyright [yyyy] [name of copyright owner] Licensed under the Apache License, Version 2.0 (the "License"); you may not use this file except in compliance with the License. You may obtain a copy of the License at http://www.apache.org/licenses/LICENSE-2.0 Unless required by applicable law or agreed to in writing, software distributed under the License is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the License for the specific language governing permissions and limitations under the License. xrdp-0.9.5/config.sub000755 001751 001751 00000106246 13220730773 014422 0ustar00metameta000000 000000 #! /bin/sh # Configuration validation subroutine script. # Copyright 1992-2015 Free Software Foundation, Inc. timestamp='2015-03-08' # This file 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. # # You should have received a copy of the GNU General Public License # along with this program; if not, see . # # As a special exception to the GNU General Public License, if you # distribute this file as part of a program that contains a # configuration script generated by Autoconf, you may include it under # the same distribution terms that you use for the rest of that # program. This Exception is an additional permission under section 7 # of the GNU General Public License, version 3 ("GPLv3"). # Please send patches to . # # Configuration subroutine to validate and canonicalize a configuration type. # Supply the specified configuration type as an argument. # If it is invalid, we print an error message on stderr and exit with code 1. # Otherwise, we print the canonical config type on stdout and succeed. # You can get the latest version of this script from: # http://git.savannah.gnu.org/gitweb/?p=config.git;a=blob_plain;f=config.sub;hb=HEAD # This file is supposed to be the same for all GNU packages # and recognize all the CPU types, system types and aliases # that are meaningful with *any* GNU software. # Each package is responsible for reporting which valid configurations # it does not support. The user should be able to distinguish # a failure to support a valid configuration from a meaningless # configuration. # The goal of this file is to map all the various variations of a given # machine specification into a single specification in the form: # CPU_TYPE-MANUFACTURER-OPERATING_SYSTEM # or in some cases, the newer four-part form: # CPU_TYPE-MANUFACTURER-KERNEL-OPERATING_SYSTEM # It is wrong to echo any other type of specification. me=`echo "$0" | sed -e 's,.*/,,'` usage="\ Usage: $0 [OPTION] CPU-MFR-OPSYS $0 [OPTION] ALIAS Canonicalize a configuration name. Operation modes: -h, --help print this help, then exit -t, --time-stamp print date of last modification, then exit -v, --version print version number, then exit Report bugs and patches to ." version="\ GNU config.sub ($timestamp) Copyright 1992-2015 Free Software Foundation, Inc. This is free software; see the source for copying conditions. There is NO warranty; not even for MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE." help=" Try \`$me --help' for more information." # Parse command line while test $# -gt 0 ; do case $1 in --time-stamp | --time* | -t ) echo "$timestamp" ; exit ;; --version | -v ) echo "$version" ; exit ;; --help | --h* | -h ) echo "$usage"; exit ;; -- ) # Stop option processing shift; break ;; - ) # Use stdin as input. break ;; -* ) echo "$me: invalid option $1$help" exit 1 ;; *local*) # First pass through any local machine types. echo $1 exit ;; * ) break ;; esac done case $# in 0) echo "$me: missing argument$help" >&2 exit 1;; 1) ;; *) echo "$me: too many arguments$help" >&2 exit 1;; esac # Separate what the user gave into CPU-COMPANY and OS or KERNEL-OS (if any). # Here we must recognize all the valid KERNEL-OS combinations. maybe_os=`echo $1 | sed 's/^\(.*\)-\([^-]*-[^-]*\)$/\2/'` case $maybe_os in nto-qnx* | linux-gnu* | linux-android* | linux-dietlibc | linux-newlib* | \ linux-musl* | linux-uclibc* | uclinux-uclibc* | uclinux-gnu* | kfreebsd*-gnu* | \ knetbsd*-gnu* | netbsd*-gnu* | netbsd*-eabi* | \ kopensolaris*-gnu* | \ storm-chaos* | os2-emx* | rtmk-nova*) os=-$maybe_os basic_machine=`echo $1 | sed 's/^\(.*\)-\([^-]*-[^-]*\)$/\1/'` ;; android-linux) os=-linux-android basic_machine=`echo $1 | sed 's/^\(.*\)-\([^-]*-[^-]*\)$/\1/'`-unknown ;; *) basic_machine=`echo $1 | sed 's/-[^-]*$//'` if [ $basic_machine != $1 ] then os=`echo $1 | sed 's/.*-/-/'` else os=; fi ;; esac ### Let's recognize common machines as not being operating systems so ### that things like config.sub decstation-3100 work. We also ### recognize some manufacturers as not being operating systems, so we ### can provide default operating systems below. case $os in -sun*os*) # Prevent following clause from handling this invalid input. ;; -dec* | -mips* | -sequent* | -encore* | -pc532* | -sgi* | -sony* | \ -att* | -7300* | -3300* | -delta* | -motorola* | -sun[234]* | \ -unicom* | -ibm* | -next | -hp | -isi* | -apollo | -altos* | \ -convergent* | -ncr* | -news | -32* | -3600* | -3100* | -hitachi* |\ -c[123]* | -convex* | -sun | -crds | -omron* | -dg | -ultra | -tti* | \ -harris | -dolphin | -highlevel | -gould | -cbm | -ns | -masscomp | \ -apple | -axis | -knuth | -cray | -microblaze*) os= basic_machine=$1 ;; -bluegene*) os=-cnk ;; -sim | -cisco | -oki | -wec | -winbond) os= basic_machine=$1 ;; -scout) ;; -wrs) os=-vxworks basic_machine=$1 ;; -chorusos*) os=-chorusos basic_machine=$1 ;; -chorusrdb) os=-chorusrdb basic_machine=$1 ;; -hiux*) os=-hiuxwe2 ;; -sco6) os=-sco5v6 basic_machine=`echo $1 | sed -e 's/86-.*/86-pc/'` ;; -sco5) os=-sco3.2v5 basic_machine=`echo $1 | sed -e 's/86-.*/86-pc/'` ;; -sco4) os=-sco3.2v4 basic_machine=`echo $1 | sed -e 's/86-.*/86-pc/'` ;; -sco3.2.[4-9]*) os=`echo $os | sed -e 's/sco3.2./sco3.2v/'` basic_machine=`echo $1 | sed -e 's/86-.*/86-pc/'` ;; -sco3.2v[4-9]*) # Don't forget version if it is 3.2v4 or newer. basic_machine=`echo $1 | sed -e 's/86-.*/86-pc/'` ;; -sco5v6*) # Don't forget version if it is 3.2v4 or newer. basic_machine=`echo $1 | sed -e 's/86-.*/86-pc/'` ;; -sco*) os=-sco3.2v2 basic_machine=`echo $1 | sed -e 's/86-.*/86-pc/'` ;; -udk*) basic_machine=`echo $1 | sed -e 's/86-.*/86-pc/'` ;; -isc) os=-isc2.2 basic_machine=`echo $1 | sed -e 's/86-.*/86-pc/'` ;; -clix*) basic_machine=clipper-intergraph ;; -isc*) basic_machine=`echo $1 | sed -e 's/86-.*/86-pc/'` ;; -lynx*178) os=-lynxos178 ;; -lynx*5) os=-lynxos5 ;; -lynx*) os=-lynxos ;; -ptx*) basic_machine=`echo $1 | sed -e 's/86-.*/86-sequent/'` ;; -windowsnt*) os=`echo $os | sed -e 's/windowsnt/winnt/'` ;; -psos*) os=-psos ;; -mint | -mint[0-9]*) basic_machine=m68k-atari os=-mint ;; esac # Decode aliases for certain CPU-COMPANY combinations. case $basic_machine in # Recognize the basic CPU types without company name. # Some are omitted here because they have special meanings below. 1750a | 580 \ | a29k \ | aarch64 | aarch64_be \ | alpha | alphaev[4-8] | alphaev56 | alphaev6[78] | alphapca5[67] \ | alpha64 | alpha64ev[4-8] | alpha64ev56 | alpha64ev6[78] | alpha64pca5[67] \ | am33_2.0 \ | arc | arceb \ | arm | arm[bl]e | arme[lb] | armv[2-8] | armv[3-8][lb] | armv7[arm] \ | avr | avr32 \ | be32 | be64 \ | bfin \ | c4x | c8051 | clipper \ | d10v | d30v | dlx | dsp16xx \ | e2k | epiphany \ | fido | fr30 | frv | ft32 \ | h8300 | h8500 | hppa | hppa1.[01] | hppa2.0 | hppa2.0[nw] | hppa64 \ | hexagon \ | i370 | i860 | i960 | ia64 \ | ip2k | iq2000 \ | k1om \ | le32 | le64 \ | lm32 \ | m32c | m32r | m32rle | m68000 | m68k | m88k \ | maxq | mb | microblaze | microblazeel | mcore | mep | metag \ | mips | mipsbe | mipseb | mipsel | mipsle \ | mips16 \ | mips64 | mips64el \ | mips64octeon | mips64octeonel \ | mips64orion | mips64orionel \ | mips64r5900 | mips64r5900el \ | mips64vr | mips64vrel \ | mips64vr4100 | mips64vr4100el \ | mips64vr4300 | mips64vr4300el \ | mips64vr5000 | mips64vr5000el \ | mips64vr5900 | mips64vr5900el \ | mipsisa32 | mipsisa32el \ | mipsisa32r2 | mipsisa32r2el \ | mipsisa32r6 | mipsisa32r6el \ | mipsisa64 | mipsisa64el \ | mipsisa64r2 | mipsisa64r2el \ | mipsisa64r6 | mipsisa64r6el \ | mipsisa64sb1 | mipsisa64sb1el \ | mipsisa64sr71k | mipsisa64sr71kel \ | mipsr5900 | mipsr5900el \ | mipstx39 | mipstx39el \ | mn10200 | mn10300 \ | moxie \ | mt \ | msp430 \ | nds32 | nds32le | nds32be \ | nios | nios2 | nios2eb | nios2el \ | ns16k | ns32k \ | open8 | or1k | or1knd | or32 \ | pdp10 | pdp11 | pj | pjl \ | powerpc | powerpc64 | powerpc64le | powerpcle | powerpcspe \ | pyramid \ | riscv32 | riscv64 \ | rl78 | rx \ | score \ | sh | sh[1234] | sh[24]a | sh[24]aeb | sh[23]e | sh[34]eb | sheb | shbe | shle | sh[1234]le | sh3ele \ | sh64 | sh64le \ | sparc | sparc64 | sparc64b | sparc64v | sparc86x | sparclet | sparclite \ | sparcv8 | sparcv9 | sparcv9b | sparcv9v \ | spu \ | tahoe | tic4x | tic54x | tic55x | tic6x | tic80 | tron \ | ubicom32 \ | v850 | v850e | v850e1 | v850e2 | v850es | v850e2v3 \ | visium \ | we32k \ | x86 | xc16x | xstormy16 | xtensa \ | z8k | z80) basic_machine=$basic_machine-unknown ;; c54x) basic_machine=tic54x-unknown ;; c55x) basic_machine=tic55x-unknown ;; c6x) basic_machine=tic6x-unknown ;; leon|leon[3-9]) basic_machine=sparc-$basic_machine ;; m6811 | m68hc11 | m6812 | m68hc12 | m68hcs12x | nvptx | picochip) basic_machine=$basic_machine-unknown os=-none ;; m88110 | m680[12346]0 | m683?2 | m68360 | m5200 | v70 | w65 | z8k) ;; ms1) basic_machine=mt-unknown ;; strongarm | thumb | xscale) basic_machine=arm-unknown ;; xgate) basic_machine=$basic_machine-unknown os=-none ;; xscaleeb) basic_machine=armeb-unknown ;; xscaleel) basic_machine=armel-unknown ;; # We use `pc' rather than `unknown' # because (1) that's what they normally are, and # (2) the word "unknown" tends to confuse beginning users. i*86 | x86_64) basic_machine=$basic_machine-pc ;; # Object if more than one company name word. *-*-*) echo Invalid configuration \`$1\': machine \`$basic_machine\' not recognized 1>&2 exit 1 ;; # Recognize the basic CPU types with company name. 580-* \ | a29k-* \ | aarch64-* | aarch64_be-* \ | alpha-* | alphaev[4-8]-* | alphaev56-* | alphaev6[78]-* \ | alpha64-* | alpha64ev[4-8]-* | alpha64ev56-* | alpha64ev6[78]-* \ | alphapca5[67]-* | alpha64pca5[67]-* | amd64-* | arc-* | arceb-* \ | arm-* | armbe-* | armle-* | armeb-* | armv*-* \ | avr-* | avr32-* \ | be32-* | be64-* \ | bfin-* | bs2000-* \ | c[123]* | c30-* | [cjt]90-* | c4x-* \ | c8051-* | clipper-* | craynv-* | cydra-* \ | d10v-* | d30v-* | dlx-* \ | e2k-* | elxsi-* \ | f30[01]-* | f700-* | fido-* | fr30-* | frv-* | fx80-* \ | h8300-* | h8500-* \ | hppa-* | hppa1.[01]-* | hppa2.0-* | hppa2.0[nw]-* | hppa64-* \ | hexagon-* \ | i*86-* | i860-* | i960-* | ia64-* \ | ip2k-* | iq2000-* \ | k1om-* \ | le32-* | le64-* \ | lm32-* \ | m32c-* | m32r-* | m32rle-* \ | m68000-* | m680[012346]0-* | m68360-* | m683?2-* | m68k-* \ | m88110-* | m88k-* | maxq-* | mcore-* | metag-* \ | microblaze-* | microblazeel-* \ | mips-* | mipsbe-* | mipseb-* | mipsel-* | mipsle-* \ | mips16-* \ | mips64-* | mips64el-* \ | mips64octeon-* | mips64octeonel-* \ | mips64orion-* | mips64orionel-* \ | mips64r5900-* | mips64r5900el-* \ | mips64vr-* | mips64vrel-* \ | mips64vr4100-* | mips64vr4100el-* \ | mips64vr4300-* | mips64vr4300el-* \ | mips64vr5000-* | mips64vr5000el-* \ | mips64vr5900-* | mips64vr5900el-* \ | mipsisa32-* | mipsisa32el-* \ | mipsisa32r2-* | mipsisa32r2el-* \ | mipsisa32r6-* | mipsisa32r6el-* \ | mipsisa64-* | mipsisa64el-* \ | mipsisa64r2-* | mipsisa64r2el-* \ | mipsisa64r6-* | mipsisa64r6el-* \ | mipsisa64sb1-* | mipsisa64sb1el-* \ | mipsisa64sr71k-* | mipsisa64sr71kel-* \ | mipsr5900-* | mipsr5900el-* \ | mipstx39-* | mipstx39el-* \ | mmix-* \ | mt-* \ | msp430-* \ | nds32-* | nds32le-* | nds32be-* \ | nios-* | nios2-* | nios2eb-* | nios2el-* \ | none-* | np1-* | ns16k-* | ns32k-* \ | open8-* \ | or1k*-* \ | orion-* \ | pdp10-* | pdp11-* | pj-* | pjl-* | pn-* | power-* \ | powerpc-* | powerpc64-* | powerpc64le-* | powerpcle-* | powerpcspe-* \ | pyramid-* \ | rl78-* | romp-* | rs6000-* | rx-* \ | sh-* | sh[1234]-* | sh[24]a-* | sh[24]aeb-* | sh[23]e-* | sh[34]eb-* | sheb-* | shbe-* \ | shle-* | sh[1234]le-* | sh3ele-* | sh64-* | sh64le-* \ | sparc-* | sparc64-* | sparc64b-* | sparc64v-* | sparc86x-* | sparclet-* \ | sparclite-* \ | sparcv8-* | sparcv9-* | sparcv9b-* | sparcv9v-* | sv1-* | sx?-* \ | tahoe-* \ | tic30-* | tic4x-* | tic54x-* | tic55x-* | tic6x-* | tic80-* \ | tile*-* \ | tron-* \ | ubicom32-* \ | v850-* | v850e-* | v850e1-* | v850es-* | v850e2-* | v850e2v3-* \ | vax-* \ | visium-* \ | we32k-* \ | x86-* | x86_64-* | xc16x-* | xps100-* \ | xstormy16-* | xtensa*-* \ | ymp-* \ | z8k-* | z80-*) ;; # Recognize the basic CPU types without company name, with glob match. xtensa*) basic_machine=$basic_machine-unknown ;; # Recognize the various machine names and aliases which stand # for a CPU type and a company and sometimes even an OS. 386bsd) basic_machine=i386-unknown os=-bsd ;; 3b1 | 7300 | 7300-att | att-7300 | pc7300 | safari | unixpc) basic_machine=m68000-att ;; 3b*) basic_machine=we32k-att ;; a29khif) basic_machine=a29k-amd os=-udi ;; abacus) basic_machine=abacus-unknown ;; adobe68k) basic_machine=m68010-adobe os=-scout ;; alliant | fx80) basic_machine=fx80-alliant ;; altos | altos3068) basic_machine=m68k-altos ;; am29k) basic_machine=a29k-none os=-bsd ;; amdahl) basic_machine=580-amdahl os=-sysv ;; amiga | amiga-*) basic_machine=m68k-unknown ;; amigaos | amigados) basic_machine=m68k-unknown os=-amigaos ;; amigaunix | amix) basic_machine=m68k-unknown os=-sysv4 ;; apollo68) basic_machine=m68k-apollo os=-sysv ;; apollo68bsd) basic_machine=m68k-apollo os=-bsd ;; aros) basic_machine=i386-pc os=-aros ;; asmjs) basic_machine=asmjs-unknown ;; aux) basic_machine=m68k-apple os=-aux ;; balance) basic_machine=ns32k-sequent os=-dynix ;; blackfin) basic_machine=bfin-unknown os=-linux ;; blackfin-*) basic_machine=bfin-`echo $basic_machine | sed 's/^[^-]*-//'` os=-linux ;; bluegene*) basic_machine=powerpc-ibm os=-cnk ;; c54x-*) basic_machine=tic54x-`echo $basic_machine | sed 's/^[^-]*-//'` ;; c55x-*) basic_machine=tic55x-`echo $basic_machine | sed 's/^[^-]*-//'` ;; c6x-*) basic_machine=tic6x-`echo $basic_machine | sed 's/^[^-]*-//'` ;; c90) basic_machine=c90-cray os=-unicos ;; cegcc) basic_machine=arm-unknown os=-cegcc ;; convex-c1) basic_machine=c1-convex os=-bsd ;; convex-c2) basic_machine=c2-convex os=-bsd ;; convex-c32) basic_machine=c32-convex os=-bsd ;; convex-c34) basic_machine=c34-convex os=-bsd ;; convex-c38) basic_machine=c38-convex os=-bsd ;; cray | j90) basic_machine=j90-cray os=-unicos ;; craynv) basic_machine=craynv-cray os=-unicosmp ;; cr16 | cr16-*) basic_machine=cr16-unknown os=-elf ;; crds | unos) basic_machine=m68k-crds ;; crisv32 | crisv32-* | etraxfs*) basic_machine=crisv32-axis ;; cris | cris-* | etrax*) basic_machine=cris-axis ;; crx) basic_machine=crx-unknown os=-elf ;; da30 | da30-*) basic_machine=m68k-da30 ;; decstation | decstation-3100 | pmax | pmax-* | pmin | dec3100 | decstatn) basic_machine=mips-dec ;; decsystem10* | dec10*) basic_machine=pdp10-dec os=-tops10 ;; decsystem20* | dec20*) basic_machine=pdp10-dec os=-tops20 ;; delta | 3300 | motorola-3300 | motorola-delta \ | 3300-motorola | delta-motorola) basic_machine=m68k-motorola ;; delta88) basic_machine=m88k-motorola os=-sysv3 ;; dicos) basic_machine=i686-pc os=-dicos ;; djgpp) basic_machine=i586-pc os=-msdosdjgpp ;; dpx20 | dpx20-*) basic_machine=rs6000-bull os=-bosx ;; dpx2* | dpx2*-bull) basic_machine=m68k-bull os=-sysv3 ;; ebmon29k) basic_machine=a29k-amd os=-ebmon ;; elxsi) basic_machine=elxsi-elxsi os=-bsd ;; encore | umax | mmax) basic_machine=ns32k-encore ;; es1800 | OSE68k | ose68k | ose | OSE) basic_machine=m68k-ericsson os=-ose ;; fx2800) basic_machine=i860-alliant ;; genix) basic_machine=ns32k-ns ;; gmicro) basic_machine=tron-gmicro os=-sysv ;; go32) basic_machine=i386-pc os=-go32 ;; h3050r* | hiux*) basic_machine=hppa1.1-hitachi os=-hiuxwe2 ;; h8300hms) basic_machine=h8300-hitachi os=-hms ;; h8300xray) basic_machine=h8300-hitachi os=-xray ;; h8500hms) basic_machine=h8500-hitachi os=-hms ;; harris) basic_machine=m88k-harris os=-sysv3 ;; hp300-*) basic_machine=m68k-hp ;; hp300bsd) basic_machine=m68k-hp os=-bsd ;; hp300hpux) basic_machine=m68k-hp os=-hpux ;; hp3k9[0-9][0-9] | hp9[0-9][0-9]) basic_machine=hppa1.0-hp ;; hp9k2[0-9][0-9] | hp9k31[0-9]) basic_machine=m68000-hp ;; hp9k3[2-9][0-9]) basic_machine=m68k-hp ;; hp9k6[0-9][0-9] | hp6[0-9][0-9]) basic_machine=hppa1.0-hp ;; hp9k7[0-79][0-9] | hp7[0-79][0-9]) basic_machine=hppa1.1-hp ;; hp9k78[0-9] | hp78[0-9]) # FIXME: really hppa2.0-hp basic_machine=hppa1.1-hp ;; hp9k8[67]1 | hp8[67]1 | hp9k80[24] | hp80[24] | hp9k8[78]9 | hp8[78]9 | hp9k893 | hp893) # FIXME: really hppa2.0-hp basic_machine=hppa1.1-hp ;; hp9k8[0-9][13679] | hp8[0-9][13679]) basic_machine=hppa1.1-hp ;; hp9k8[0-9][0-9] | hp8[0-9][0-9]) basic_machine=hppa1.0-hp ;; hppa-next) os=-nextstep3 ;; hppaosf) basic_machine=hppa1.1-hp os=-osf ;; hppro) basic_machine=hppa1.1-hp os=-proelf ;; i370-ibm* | ibm*) basic_machine=i370-ibm ;; i*86v32) basic_machine=`echo $1 | sed -e 's/86.*/86-pc/'` os=-sysv32 ;; i*86v4*) basic_machine=`echo $1 | sed -e 's/86.*/86-pc/'` os=-sysv4 ;; i*86v) basic_machine=`echo $1 | sed -e 's/86.*/86-pc/'` os=-sysv ;; i*86sol2) basic_machine=`echo $1 | sed -e 's/86.*/86-pc/'` os=-solaris2 ;; i386mach) basic_machine=i386-mach os=-mach ;; i386-vsta | vsta) basic_machine=i386-unknown os=-vsta ;; iris | iris4d) basic_machine=mips-sgi case $os in -irix*) ;; *) os=-irix4 ;; esac ;; isi68 | isi) basic_machine=m68k-isi os=-sysv ;; leon-*|leon[3-9]-*) basic_machine=sparc-`echo $basic_machine | sed 's/-.*//'` ;; m68knommu) basic_machine=m68k-unknown os=-linux ;; m68knommu-*) basic_machine=m68k-`echo $basic_machine | sed 's/^[^-]*-//'` os=-linux ;; m88k-omron*) basic_machine=m88k-omron ;; magnum | m3230) basic_machine=mips-mips os=-sysv ;; merlin) basic_machine=ns32k-utek os=-sysv ;; microblaze*) basic_machine=microblaze-xilinx ;; mingw64) basic_machine=x86_64-pc os=-mingw64 ;; mingw32) basic_machine=i686-pc os=-mingw32 ;; mingw32ce) basic_machine=arm-unknown os=-mingw32ce ;; miniframe) basic_machine=m68000-convergent ;; *mint | -mint[0-9]* | *MiNT | *MiNT[0-9]*) basic_machine=m68k-atari os=-mint ;; mips3*-*) basic_machine=`echo $basic_machine | sed -e 's/mips3/mips64/'` ;; mips3*) basic_machine=`echo $basic_machine | sed -e 's/mips3/mips64/'`-unknown ;; monitor) basic_machine=m68k-rom68k os=-coff ;; morphos) basic_machine=powerpc-unknown os=-morphos ;; moxiebox) basic_machine=moxie-unknown os=-moxiebox ;; msdos) basic_machine=i386-pc os=-msdos ;; ms1-*) basic_machine=`echo $basic_machine | sed -e 's/ms1-/mt-/'` ;; msys) basic_machine=i686-pc os=-msys ;; mvs) basic_machine=i370-ibm os=-mvs ;; nacl) basic_machine=le32-unknown os=-nacl ;; ncr3000) basic_machine=i486-ncr os=-sysv4 ;; netbsd386) basic_machine=i386-unknown os=-netbsd ;; netwinder) basic_machine=armv4l-rebel os=-linux ;; news | news700 | news800 | news900) basic_machine=m68k-sony os=-newsos ;; news1000) basic_machine=m68030-sony os=-newsos ;; news-3600 | risc-news) basic_machine=mips-sony os=-newsos ;; necv70) basic_machine=v70-nec os=-sysv ;; next | m*-next ) basic_machine=m68k-next case $os in -nextstep* ) ;; -ns2*) os=-nextstep2 ;; *) os=-nextstep3 ;; esac ;; nh3000) basic_machine=m68k-harris os=-cxux ;; nh[45]000) basic_machine=m88k-harris os=-cxux ;; nindy960) basic_machine=i960-intel os=-nindy ;; mon960) basic_machine=i960-intel os=-mon960 ;; nonstopux) basic_machine=mips-compaq os=-nonstopux ;; np1) basic_machine=np1-gould ;; neo-tandem) basic_machine=neo-tandem ;; nse-tandem) basic_machine=nse-tandem ;; nsr-tandem) basic_machine=nsr-tandem ;; op50n-* | op60c-*) basic_machine=hppa1.1-oki os=-proelf ;; openrisc | openrisc-*) basic_machine=or32-unknown ;; os400) basic_machine=powerpc-ibm os=-os400 ;; OSE68000 | ose68000) basic_machine=m68000-ericsson os=-ose ;; os68k) basic_machine=m68k-none os=-os68k ;; pa-hitachi) basic_machine=hppa1.1-hitachi os=-hiuxwe2 ;; paragon) basic_machine=i860-intel os=-osf ;; parisc) basic_machine=hppa-unknown os=-linux ;; parisc-*) basic_machine=hppa-`echo $basic_machine | sed 's/^[^-]*-//'` os=-linux ;; pbd) basic_machine=sparc-tti ;; pbb) basic_machine=m68k-tti ;; pc532 | pc532-*) basic_machine=ns32k-pc532 ;; pc98) basic_machine=i386-pc ;; pc98-*) basic_machine=i386-`echo $basic_machine | sed 's/^[^-]*-//'` ;; pentium | p5 | k5 | k6 | nexgen | viac3) basic_machine=i586-pc ;; pentiumpro | p6 | 6x86 | athlon | athlon_*) basic_machine=i686-pc ;; pentiumii | pentium2 | pentiumiii | pentium3) basic_machine=i686-pc ;; pentium4) basic_machine=i786-pc ;; pentium-* | p5-* | k5-* | k6-* | nexgen-* | viac3-*) basic_machine=i586-`echo $basic_machine | sed 's/^[^-]*-//'` ;; pentiumpro-* | p6-* | 6x86-* | athlon-*) basic_machine=i686-`echo $basic_machine | sed 's/^[^-]*-//'` ;; pentiumii-* | pentium2-* | pentiumiii-* | pentium3-*) basic_machine=i686-`echo $basic_machine | sed 's/^[^-]*-//'` ;; pentium4-*) basic_machine=i786-`echo $basic_machine | sed 's/^[^-]*-//'` ;; pn) basic_machine=pn-gould ;; power) basic_machine=power-ibm ;; ppc | ppcbe) basic_machine=powerpc-unknown ;; ppc-* | ppcbe-*) basic_machine=powerpc-`echo $basic_machine | sed 's/^[^-]*-//'` ;; ppcle | powerpclittle | ppc-le | powerpc-little) basic_machine=powerpcle-unknown ;; ppcle-* | powerpclittle-*) basic_machine=powerpcle-`echo $basic_machine | sed 's/^[^-]*-//'` ;; ppc64) basic_machine=powerpc64-unknown ;; ppc64-*) basic_machine=powerpc64-`echo $basic_machine | sed 's/^[^-]*-//'` ;; ppc64le | powerpc64little | ppc64-le | powerpc64-little) basic_machine=powerpc64le-unknown ;; ppc64le-* | powerpc64little-*) basic_machine=powerpc64le-`echo $basic_machine | sed 's/^[^-]*-//'` ;; ps2) basic_machine=i386-ibm ;; pw32) basic_machine=i586-unknown os=-pw32 ;; rdos | rdos64) basic_machine=x86_64-pc os=-rdos ;; rdos32) basic_machine=i386-pc os=-rdos ;; rom68k) basic_machine=m68k-rom68k os=-coff ;; rm[46]00) basic_machine=mips-siemens ;; rtpc | rtpc-*) basic_machine=romp-ibm ;; s390 | s390-*) basic_machine=s390-ibm ;; s390x | s390x-*) basic_machine=s390x-ibm ;; sa29200) basic_machine=a29k-amd os=-udi ;; sb1) basic_machine=mipsisa64sb1-unknown ;; sb1el) basic_machine=mipsisa64sb1el-unknown ;; sde) basic_machine=mipsisa32-sde os=-elf ;; sei) basic_machine=mips-sei os=-seiux ;; sequent) basic_machine=i386-sequent ;; sh) basic_machine=sh-hitachi os=-hms ;; sh5el) basic_machine=sh5le-unknown ;; sh64) basic_machine=sh64-unknown ;; sparclite-wrs | simso-wrs) basic_machine=sparclite-wrs os=-vxworks ;; sps7) basic_machine=m68k-bull os=-sysv2 ;; spur) basic_machine=spur-unknown ;; st2000) basic_machine=m68k-tandem ;; stratus) basic_machine=i860-stratus os=-sysv4 ;; strongarm-* | thumb-*) basic_machine=arm-`echo $basic_machine | sed 's/^[^-]*-//'` ;; sun2) basic_machine=m68000-sun ;; sun2os3) basic_machine=m68000-sun os=-sunos3 ;; sun2os4) basic_machine=m68000-sun os=-sunos4 ;; sun3os3) basic_machine=m68k-sun os=-sunos3 ;; sun3os4) basic_machine=m68k-sun os=-sunos4 ;; sun4os3) basic_machine=sparc-sun os=-sunos3 ;; sun4os4) basic_machine=sparc-sun os=-sunos4 ;; sun4sol2) basic_machine=sparc-sun os=-solaris2 ;; sun3 | sun3-*) basic_machine=m68k-sun ;; sun4) basic_machine=sparc-sun ;; sun386 | sun386i | roadrunner) basic_machine=i386-sun ;; sv1) basic_machine=sv1-cray os=-unicos ;; symmetry) basic_machine=i386-sequent os=-dynix ;; t3e) basic_machine=alphaev5-cray os=-unicos ;; t90) basic_machine=t90-cray os=-unicos ;; tile*) basic_machine=$basic_machine-unknown os=-linux-gnu ;; tx39) basic_machine=mipstx39-unknown ;; tx39el) basic_machine=mipstx39el-unknown ;; toad1) basic_machine=pdp10-xkl os=-tops20 ;; tower | tower-32) basic_machine=m68k-ncr ;; tpf) basic_machine=s390x-ibm os=-tpf ;; udi29k) basic_machine=a29k-amd os=-udi ;; ultra3) basic_machine=a29k-nyu os=-sym1 ;; v810 | necv810) basic_machine=v810-nec os=-none ;; vaxv) basic_machine=vax-dec os=-sysv ;; vms) basic_machine=vax-dec os=-vms ;; vpp*|vx|vx-*) basic_machine=f301-fujitsu ;; vxworks960) basic_machine=i960-wrs os=-vxworks ;; vxworks68) basic_machine=m68k-wrs os=-vxworks ;; vxworks29k) basic_machine=a29k-wrs os=-vxworks ;; w65*) basic_machine=w65-wdc os=-none ;; w89k-*) basic_machine=hppa1.1-winbond os=-proelf ;; xbox) basic_machine=i686-pc os=-mingw32 ;; xps | xps100) basic_machine=xps100-honeywell ;; xscale-* | xscalee[bl]-*) basic_machine=`echo $basic_machine | sed 's/^xscale/arm/'` ;; ymp) basic_machine=ymp-cray os=-unicos ;; z8k-*-coff) basic_machine=z8k-unknown os=-sim ;; z80-*-coff) basic_machine=z80-unknown os=-sim ;; none) basic_machine=none-none os=-none ;; # Here we handle the default manufacturer of certain CPU types. It is in # some cases the only manufacturer, in others, it is the most popular. w89k) basic_machine=hppa1.1-winbond ;; op50n) basic_machine=hppa1.1-oki ;; op60c) basic_machine=hppa1.1-oki ;; romp) basic_machine=romp-ibm ;; mmix) basic_machine=mmix-knuth ;; rs6000) basic_machine=rs6000-ibm ;; vax) basic_machine=vax-dec ;; pdp10) # there are many clones, so DEC is not a safe bet basic_machine=pdp10-unknown ;; pdp11) basic_machine=pdp11-dec ;; we32k) basic_machine=we32k-att ;; sh[1234] | sh[24]a | sh[24]aeb | sh[34]eb | sh[1234]le | sh[23]ele) basic_machine=sh-unknown ;; sparc | sparcv8 | sparcv9 | sparcv9b | sparcv9v) basic_machine=sparc-sun ;; cydra) basic_machine=cydra-cydrome ;; orion) basic_machine=orion-highlevel ;; orion105) basic_machine=clipper-highlevel ;; mac | mpw | mac-mpw) basic_machine=m68k-apple ;; pmac | pmac-mpw) basic_machine=powerpc-apple ;; *-unknown) # Make sure to match an already-canonicalized machine name. ;; *) echo Invalid configuration \`$1\': machine \`$basic_machine\' not recognized 1>&2 exit 1 ;; esac # Here we canonicalize certain aliases for manufacturers. case $basic_machine in *-digital*) basic_machine=`echo $basic_machine | sed 's/digital.*/dec/'` ;; *-commodore*) basic_machine=`echo $basic_machine | sed 's/commodore.*/cbm/'` ;; *) ;; esac # Decode manufacturer-specific aliases for certain operating systems. if [ x"$os" != x"" ] then case $os in # First match some system type aliases # that might get confused with valid system types. # -solaris* is a basic system type, with this one exception. -auroraux) os=-auroraux ;; -solaris1 | -solaris1.*) os=`echo $os | sed -e 's|solaris1|sunos4|'` ;; -solaris) os=-solaris2 ;; -svr4*) os=-sysv4 ;; -unixware*) os=-sysv4.2uw ;; -gnu/linux*) os=`echo $os | sed -e 's|gnu/linux|linux-gnu|'` ;; # First accept the basic system types. # The portable systems comes first. # Each alternative MUST END IN A *, to match a version number. # -sysv* is not here because it comes later, after sysvr4. -gnu* | -bsd* | -mach* | -minix* | -genix* | -ultrix* | -irix* \ | -*vms* | -sco* | -esix* | -isc* | -aix* | -cnk* | -sunos | -sunos[34]*\ | -hpux* | -unos* | -osf* | -luna* | -dgux* | -auroraux* | -solaris* \ | -sym* | -kopensolaris* | -plan9* \ | -amigaos* | -amigados* | -msdos* | -newsos* | -unicos* | -aof* \ | -aos* | -aros* | -cloudabi* \ | -nindy* | -vxsim* | -vxworks* | -ebmon* | -hms* | -mvs* \ | -clix* | -riscos* | -uniplus* | -iris* | -rtu* | -xenix* \ | -hiux* | -386bsd* | -knetbsd* | -mirbsd* | -netbsd* \ | -bitrig* | -openbsd* | -solidbsd* \ | -ekkobsd* | -kfreebsd* | -freebsd* | -riscix* | -lynxos* \ | -bosx* | -nextstep* | -cxux* | -aout* | -elf* | -oabi* \ | -ptx* | -coff* | -ecoff* | -winnt* | -domain* | -vsta* \ | -udi* | -eabi* | -lites* | -ieee* | -go32* | -aux* \ | -chorusos* | -chorusrdb* | -cegcc* \ | -cygwin* | -msys* | -pe* | -psos* | -moss* | -proelf* | -rtems* \ | -mingw32* | -mingw64* | -linux-gnu* | -linux-android* \ | -linux-newlib* | -linux-musl* | -linux-uclibc* \ | -uxpv* | -beos* | -mpeix* | -udk* | -moxiebox* \ | -interix* | -uwin* | -mks* | -rhapsody* | -darwin* | -opened* \ | -openstep* | -oskit* | -conix* | -pw32* | -nonstopux* \ | -storm-chaos* | -tops10* | -tenex* | -tops20* | -its* \ | -os2* | -vos* | -palmos* | -uclinux* | -nucleus* \ | -morphos* | -superux* | -rtmk* | -rtmk-nova* | -windiss* \ | -powermax* | -dnix* | -nx6 | -nx7 | -sei* | -dragonfly* \ | -skyos* | -haiku* | -rdos* | -toppers* | -drops* | -es* | -tirtos*) # Remember, each alternative MUST END IN *, to match a version number. ;; -qnx*) case $basic_machine in x86-* | i*86-*) ;; *) os=-nto$os ;; esac ;; -nto-qnx*) ;; -nto*) os=`echo $os | sed -e 's|nto|nto-qnx|'` ;; -sim | -es1800* | -hms* | -xray | -os68k* | -none* | -v88r* \ | -windows* | -osx | -abug | -netware* | -os9* | -beos* | -haiku* \ | -macos* | -mpw* | -magic* | -mmixware* | -mon960* | -lnews*) ;; -mac*) os=`echo $os | sed -e 's|mac|macos|'` ;; -linux-dietlibc) os=-linux-dietlibc ;; -linux*) os=`echo $os | sed -e 's|linux|linux-gnu|'` ;; -sunos5*) os=`echo $os | sed -e 's|sunos5|solaris2|'` ;; -sunos6*) os=`echo $os | sed -e 's|sunos6|solaris3|'` ;; -opened*) os=-openedition ;; -os400*) os=-os400 ;; -wince*) os=-wince ;; -osfrose*) os=-osfrose ;; -osf*) os=-osf ;; -utek*) os=-bsd ;; -dynix*) os=-bsd ;; -acis*) os=-aos ;; -atheos*) os=-atheos ;; -syllable*) os=-syllable ;; -386bsd) os=-bsd ;; -ctix* | -uts*) os=-sysv ;; -nova*) os=-rtmk-nova ;; -ns2 ) os=-nextstep2 ;; -nsk*) os=-nsk ;; # Preserve the version number of sinix5. -sinix5.*) os=`echo $os | sed -e 's|sinix|sysv|'` ;; -sinix*) os=-sysv4 ;; -tpf*) os=-tpf ;; -triton*) os=-sysv3 ;; -oss*) os=-sysv3 ;; -svr4) os=-sysv4 ;; -svr3) os=-sysv3 ;; -sysvr4) os=-sysv4 ;; # This must come after -sysvr4. -sysv*) ;; -ose*) os=-ose ;; -es1800*) os=-ose ;; -xenix) os=-xenix ;; -*mint | -mint[0-9]* | -*MiNT | -MiNT[0-9]*) os=-mint ;; -aros*) os=-aros ;; -zvmoe) os=-zvmoe ;; -dicos*) os=-dicos ;; -nacl*) ;; -none) ;; *) # Get rid of the `-' at the beginning of $os. os=`echo $os | sed 's/[^-]*-//'` echo Invalid configuration \`$1\': system \`$os\' not recognized 1>&2 exit 1 ;; esac else # Here we handle the default operating systems that come with various machines. # The value should be what the vendor currently ships out the door with their # machine or put another way, the most popular os provided with the machine. # Note that if you're going to try to match "-MANUFACTURER" here (say, # "-sun"), then you have to tell the case statement up towards the top # that MANUFACTURER isn't an operating system. Otherwise, code above # will signal an error saying that MANUFACTURER isn't an operating # system, and we'll never get to this point. case $basic_machine in score-*) os=-elf ;; spu-*) os=-elf ;; *-acorn) os=-riscix1.2 ;; arm*-rebel) os=-linux ;; arm*-semi) os=-aout ;; c4x-* | tic4x-*) os=-coff ;; c8051-*) os=-elf ;; hexagon-*) os=-elf ;; tic54x-*) os=-coff ;; tic55x-*) os=-coff ;; tic6x-*) os=-coff ;; # This must come before the *-dec entry. pdp10-*) os=-tops20 ;; pdp11-*) os=-none ;; *-dec | vax-*) os=-ultrix4.2 ;; m68*-apollo) os=-domain ;; i386-sun) os=-sunos4.0.2 ;; m68000-sun) os=-sunos3 ;; m68*-cisco) os=-aout ;; mep-*) os=-elf ;; mips*-cisco) os=-elf ;; mips*-*) os=-elf ;; or32-*) os=-coff ;; *-tti) # must be before sparc entry or we get the wrong os. os=-sysv3 ;; sparc-* | *-sun) os=-sunos4.1.1 ;; *-be) os=-beos ;; *-haiku) os=-haiku ;; *-ibm) os=-aix ;; *-knuth) os=-mmixware ;; *-wec) os=-proelf ;; *-winbond) os=-proelf ;; *-oki) os=-proelf ;; *-hp) os=-hpux ;; *-hitachi) os=-hiux ;; i860-* | *-att | *-ncr | *-altos | *-motorola | *-convergent) os=-sysv ;; *-cbm) os=-amigaos ;; *-dg) os=-dgux ;; *-dolphin) os=-sysv3 ;; m68k-ccur) os=-rtu ;; m88k-omron*) os=-luna ;; *-next ) os=-nextstep ;; *-sequent) os=-ptx ;; *-crds) os=-unos ;; *-ns) os=-genix ;; i370-*) os=-mvs ;; *-next) os=-nextstep3 ;; *-gould) os=-sysv ;; *-highlevel) os=-bsd ;; *-encore) os=-bsd ;; *-sgi) os=-irix ;; *-siemens) os=-sysv4 ;; *-masscomp) os=-rtu ;; f30[01]-fujitsu | f700-fujitsu) os=-uxpv ;; *-rom68k) os=-coff ;; *-*bug) os=-coff ;; *-apple) os=-macos ;; *-atari*) os=-mint ;; *) os=-none ;; esac fi # Here we handle the case where we know the os, and the CPU type, but not the # manufacturer. We pick the logical manufacturer. vendor=unknown case $basic_machine in *-unknown) case $os in -riscix*) vendor=acorn ;; -sunos*) vendor=sun ;; -cnk*|-aix*) vendor=ibm ;; -beos*) vendor=be ;; -hpux*) vendor=hp ;; -mpeix*) vendor=hp ;; -hiux*) vendor=hitachi ;; -unos*) vendor=crds ;; -dgux*) vendor=dg ;; -luna*) vendor=omron ;; -genix*) vendor=ns ;; -mvs* | -opened*) vendor=ibm ;; -os400*) vendor=ibm ;; -ptx*) vendor=sequent ;; -tpf*) vendor=ibm ;; -vxsim* | -vxworks* | -windiss*) vendor=wrs ;; -aux*) vendor=apple ;; -hms*) vendor=hitachi ;; -mpw* | -macos*) vendor=apple ;; -*mint | -mint[0-9]* | -*MiNT | -MiNT[0-9]*) vendor=atari ;; -vos*) vendor=stratus ;; esac basic_machine=`echo $basic_machine | sed "s/unknown/$vendor/"` ;; esac echo $basic_machine$os exit # Local variables: # eval: (add-hook 'write-file-hooks 'time-stamp) # time-stamp-start: "timestamp='" # time-stamp-format: "%:y-%02m-%02d" # time-stamp-end: "'" # End: xrdp-0.9.5/tcutils/000755 001751 001751 00000000000 13206666623 014123 5ustar00metameta000000 000000 xrdp-0.9.5/xrdpvr/000755 001751 001751 00000000000 13220731022 013737 5ustar00metameta000000 000000 xrdp-0.9.5/fontdump/000755 001751 001751 00000000000 13127114621 014254 5ustar00metameta000000 000000 xrdp-0.9.5/astyle_config.as000644 001751 001751 00000002444 13174271344 015607 0ustar00metameta000000 000000 # detached brackets --style=allman # 4 spaces, no tabs --indent=spaces=4 # for C++ files only --indent-classes # Indent 'switch' blocks so that the 'case X:' statements are indented in the switch block. # The entire case block is indented. --indent-switches # Add extra indentation to namespace blocks. This option has no effect on Java files. --indent-namespaces # Converts tabs into spaces in the non-indentation part of the line. --convert-tabs # requires --convert-tabs to work properly --indent-preprocessor --indent-col1-comments --min-conditional-indent=2 --max-instatement-indent=40 # Insert space padding around operators. --pad-oper # Insert space padding after paren headers only (e.g. 'if', 'for', 'while'...). --pad-header # Add brackets to unbracketed one line conditional statements (e.g. 'if', 'for', 'while'...). --add-brackets --align-pointer=name # Do not retain a backup of the original file. The original file is purged after it is formatted. --suffix=none # For each directory in the command line, process all subdirectories recursively. --recursive # Preserve the original file's date and time modified. --preserve-date # Formatted files display mode. Display only the files that have been formatted. # Do not display files that are unchanged. --formatted --lineend=linux xrdp-0.9.5/m4/000755 001751 001751 00000000000 13220730762 012744 5ustar00metameta000000 000000 xrdp-0.9.5/compile000755 001751 001751 00000016326 13220730773 014014 0ustar00metameta000000 000000 #! /bin/sh # Wrapper for compilers which do not understand '-c -o'. scriptversion=2016-01-11.22; # UTC # Copyright (C) 1999-2017 Free Software Foundation, Inc. # Written by Tom Tromey . # # 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 2, 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. # # You should have received a copy of the GNU General Public License # along with this program. If not, see . # As a special exception to the GNU General Public License, if you # distribute this file as part of a program that contains a # configuration script generated by Autoconf, you may include it under # the same distribution terms that you use for the rest of that program. # This file is maintained in Automake, please report # bugs to or send patches to # . nl=' ' # We need space, tab and new line, in precisely that order. Quoting is # there to prevent tools from complaining about whitespace usage. IFS=" "" $nl" file_conv= # func_file_conv build_file lazy # Convert a $build file to $host form and store it in $file # Currently only supports Windows hosts. If the determined conversion # type is listed in (the comma separated) LAZY, no conversion will # take place. func_file_conv () { file=$1 case $file in / | /[!/]*) # absolute file, and not a UNC file if test -z "$file_conv"; then # lazily determine how to convert abs files case `uname -s` in MINGW*) file_conv=mingw ;; CYGWIN*) file_conv=cygwin ;; *) file_conv=wine ;; esac fi case $file_conv/,$2, in *,$file_conv,*) ;; mingw/*) file=`cmd //C echo "$file " | sed -e 's/"\(.*\) " *$/\1/'` ;; cygwin/*) file=`cygpath -m "$file" || echo "$file"` ;; wine/*) file=`winepath -w "$file" || echo "$file"` ;; esac ;; esac } # func_cl_dashL linkdir # Make cl look for libraries in LINKDIR func_cl_dashL () { func_file_conv "$1" if test -z "$lib_path"; then lib_path=$file else lib_path="$lib_path;$file" fi linker_opts="$linker_opts -LIBPATH:$file" } # func_cl_dashl library # Do a library search-path lookup for cl func_cl_dashl () { lib=$1 found=no save_IFS=$IFS IFS=';' for dir in $lib_path $LIB do IFS=$save_IFS if $shared && test -f "$dir/$lib.dll.lib"; then found=yes lib=$dir/$lib.dll.lib break fi if test -f "$dir/$lib.lib"; then found=yes lib=$dir/$lib.lib break fi if test -f "$dir/lib$lib.a"; then found=yes lib=$dir/lib$lib.a break fi done IFS=$save_IFS if test "$found" != yes; then lib=$lib.lib fi } # func_cl_wrapper cl arg... # Adjust compile command to suit cl func_cl_wrapper () { # Assume a capable shell lib_path= shared=: linker_opts= for arg do if test -n "$eat"; then eat= else case $1 in -o) # configure might choose to run compile as 'compile cc -o foo foo.c'. eat=1 case $2 in *.o | *.[oO][bB][jJ]) func_file_conv "$2" set x "$@" -Fo"$file" shift ;; *) func_file_conv "$2" set x "$@" -Fe"$file" shift ;; esac ;; -I) eat=1 func_file_conv "$2" mingw set x "$@" -I"$file" shift ;; -I*) func_file_conv "${1#-I}" mingw set x "$@" -I"$file" shift ;; -l) eat=1 func_cl_dashl "$2" set x "$@" "$lib" shift ;; -l*) func_cl_dashl "${1#-l}" set x "$@" "$lib" shift ;; -L) eat=1 func_cl_dashL "$2" ;; -L*) func_cl_dashL "${1#-L}" ;; -static) shared=false ;; -Wl,*) arg=${1#-Wl,} save_ifs="$IFS"; IFS=',' for flag in $arg; do IFS="$save_ifs" linker_opts="$linker_opts $flag" done IFS="$save_ifs" ;; -Xlinker) eat=1 linker_opts="$linker_opts $2" ;; -*) set x "$@" "$1" shift ;; *.cc | *.CC | *.cxx | *.CXX | *.[cC]++) func_file_conv "$1" set x "$@" -Tp"$file" shift ;; *.c | *.cpp | *.CPP | *.lib | *.LIB | *.Lib | *.OBJ | *.obj | *.[oO]) func_file_conv "$1" mingw set x "$@" "$file" shift ;; *) set x "$@" "$1" shift ;; esac fi shift done if test -n "$linker_opts"; then linker_opts="-link$linker_opts" fi exec "$@" $linker_opts exit 1 } eat= case $1 in '') echo "$0: No command. Try '$0 --help' for more information." 1>&2 exit 1; ;; -h | --h*) cat <<\EOF Usage: compile [--help] [--version] PROGRAM [ARGS] Wrapper for compilers which do not understand '-c -o'. Remove '-o dest.o' from ARGS, run PROGRAM with the remaining arguments, and rename the output as expected. If you are trying to build a whole package this is not the right script to run: please start by reading the file 'INSTALL'. Report bugs to . EOF exit $? ;; -v | --v*) echo "compile $scriptversion" exit $? ;; cl | *[/\\]cl | cl.exe | *[/\\]cl.exe | \ icl | *[/\\]icl | icl.exe | *[/\\]icl.exe ) func_cl_wrapper "$@" # Doesn't return... ;; esac ofile= cfile= for arg do if test -n "$eat"; then eat= else case $1 in -o) # configure might choose to run compile as 'compile cc -o foo foo.c'. # So we strip '-o arg' only if arg is an object. eat=1 case $2 in *.o | *.obj) ofile=$2 ;; *) set x "$@" -o "$2" shift ;; esac ;; *.c) cfile=$1 set x "$@" "$1" shift ;; *) set x "$@" "$1" shift ;; esac fi shift done if test -z "$ofile" || test -z "$cfile"; then # If no '-o' option was seen then we might have been invoked from a # pattern rule where we don't need one. That is ok -- this is a # normal compilation that the losing compiler can handle. If no # '.c' file was seen then we are probably linking. That is also # ok. exec "$@" fi # Name of file we expect compiler to create. cofile=`echo "$cfile" | sed 's|^.*[\\/]||; s|^[a-zA-Z]:||; s/\.c$/.o/'` # Create the lock directory. # Note: use '[/\\:.-]' here to ensure that we don't use the same name # that we are using for the .o file. Also, base the name on the expected # object file name, since that is what matters with a parallel build. lockdir=`echo "$cofile" | sed -e 's|[/\\:.-]|_|g'`.d while true; do if mkdir "$lockdir" >/dev/null 2>&1; then break fi sleep 1 done # FIXME: race condition here if user kills between mkdir and trap. trap "rmdir '$lockdir'; exit 1" 1 2 15 # Run the compile. "$@" ret=$? if test -f "$cofile"; then test "$cofile" = "$ofile" || mv "$cofile" "$ofile" elif test -f "${cofile}bj"; then test "${cofile}bj" = "$ofile" || mv "${cofile}bj" "$ofile" fi rmdir "$lockdir" exit $ret # Local Variables: # mode: shell-script # sh-indentation: 2 # eval: (add-hook 'write-file-hooks 'time-stamp) # time-stamp-start: "scriptversion=" # time-stamp-format: "%:y-%02m-%02d.%02H" # time-stamp-time-zone: "UTC0" # time-stamp-end: "; # UTC" # End: xrdp-0.9.5/genkeymap/000755 001751 001751 00000000000 13220731022 014372 5ustar00metameta000000 000000 xrdp-0.9.5/libpainter/000755 001751 001751 00000000000 13220731016 014546 5ustar00metameta000000 000000 xrdp-0.9.5/librfxcodec/000755 001751 001751 00000000000 13220731017 014702 5ustar00metameta000000 000000 xrdp-0.9.5/config_ac-h.in000644 001751 001751 00000004674 13220730773 015126 0ustar00metameta000000 000000 /* config_ac-h.in. Generated from configure.ac by autoheader. */ /* Define to 1 if you have the header file. */ #undef HAVE_DLFCN_H /* Define to 1 if the system has the `format' function attribute */ #undef HAVE_FUNC_ATTRIBUTE_FORMAT /* Define to 1 if you have the header file. */ #undef HAVE_INTTYPES_H /* Define to 1 if you have the header file. */ #undef HAVE_LINUX_SOCKET_H /* Define to 1 if you have the header file. */ #undef HAVE_LINUX_VM_SOCKETS_H /* Define to 1 if you have the header file. */ #undef HAVE_MEMORY_H /* Using OpenPAM */ #undef HAVE_PAM_CONSTANTS_H /* Define to 1 if you have the header file. */ #undef HAVE_STDINT_H /* Define to 1 if you have the header file. */ #undef HAVE_STDLIB_H /* Define to 1 if you have the header file. */ #undef HAVE_STRINGS_H /* Define to 1 if you have the header file. */ #undef HAVE_STRING_H /* Define to 1 if you have the header file. */ #undef HAVE_SYS_PRCTL_H /* Define to 1 if you have the header file. */ #undef HAVE_SYS_STAT_H /* Define to 1 if you have the header file. */ #undef HAVE_SYS_TYPES_H /* Define to 1 if you have the header file. */ #undef HAVE_UNISTD_H /* Using Linux-PAM */ #undef HAVE__PAM_TYPES_H /* Define to the sub-directory where libtool stores uninstalled libraries. */ #undef LT_OBJDIR /* Name of package */ #undef PACKAGE /* Define to the address where bug reports for this package should be sent. */ #undef PACKAGE_BUGREPORT /* Define to the full name of this package. */ #undef PACKAGE_NAME /* Define to the full name and version of this package. */ #undef PACKAGE_STRING /* Define to the one symbol short name of this package. */ #undef PACKAGE_TARNAME /* Define to the home page for this package. */ #undef PACKAGE_URL /* Define to the version of this package. */ #undef PACKAGE_VERSION /* Define to 1 if you have the ANSI C header files. */ #undef STDC_HEADERS /* Disable PAM */ #undef USE_NOPAM /* Version number of package */ #undef VERSION /* Enable IPv6 */ #undef XRDP_ENABLE_IPV6 /* Enable IPv6 only */ #undef XRDP_ENABLE_IPV6ONLY /* Enable AF_VSOCK */ #undef XRDP_ENABLE_VSOCK /* Define to 1 if the X Window System is missing or not being used. */ #undef X_DISPLAY_MISSING /* Define to empty if `const' does not conform to ANSI C. */ #undef const /* Substitute for socklen_t */ #undef socklen_t xrdp-0.9.5/librfxcodec/m4/000755 001751 001751 00000000000 13220731017 015222 5ustar00metameta000000 000000 xrdp-0.9.5/librfxcodec/config_ac-h.in000644 001751 001751 00000003422 13220730761 017375 0ustar00metameta000000 000000 /* config_ac-h.in. Generated from configure.ac by autoheader. */ /* Define to 1 if you have the header file. */ #undef HAVE_DLFCN_H /* Define to 1 if you have the header file. */ #undef HAVE_INTTYPES_H /* Define to 1 if you have the header file. */ #undef HAVE_MEMORY_H /* Define to 1 if you have the header file. */ #undef HAVE_STDINT_H /* Define to 1 if you have the header file. */ #undef HAVE_STDLIB_H /* Define to 1 if you have the header file. */ #undef HAVE_STRINGS_H /* Define to 1 if you have the header file. */ #undef HAVE_STRING_H /* Define to 1 if you have the header file. */ #undef HAVE_SYS_STAT_H /* Define to 1 if you have the header file. */ #undef HAVE_SYS_TYPES_H /* Define to 1 if you have the header file. */ #undef HAVE_UNISTD_H /* Define to the sub-directory where libtool stores uninstalled libraries. */ #undef LT_OBJDIR /* Name of package */ #undef PACKAGE /* Define to the address where bug reports for this package should be sent. */ #undef PACKAGE_BUGREPORT /* Define to the full name of this package. */ #undef PACKAGE_NAME /* Define to the full name and version of this package. */ #undef PACKAGE_STRING /* Define to the one symbol short name of this package. */ #undef PACKAGE_TARNAME /* Define to the home page for this package. */ #undef PACKAGE_URL /* Define to the version of this package. */ #undef PACKAGE_VERSION /* Use x86_64 SIMD instructions */ #undef RFX_USE_ACCEL_AMD64 /* Use x86 SIMD instructions */ #undef RFX_USE_ACCEL_X86 /* Define to 1 if you have the ANSI C header files. */ #undef STDC_HEADERS /* Version number of package */ #undef VERSION /* Define to empty if `const' does not conform to ANSI C. */ #undef const xrdp-0.9.5/librfxcodec/tests/000755 001751 001751 00000000000 13220731017 016044 5ustar00metameta000000 000000 xrdp-0.9.5/librfxcodec/config.guess000755 001751 001751 00000124431 13220730761 017234 0ustar00metameta000000 000000 #! /bin/sh # Attempt to guess a canonical system name. # Copyright 1992-2015 Free Software Foundation, Inc. timestamp='2015-03-04' # This file 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. # # You should have received a copy of the GNU General Public License # along with this program; if not, see . # # As a special exception to the GNU General Public License, if you # distribute this file as part of a program that contains a # configuration script generated by Autoconf, you may include it under # the same distribution terms that you use for the rest of that # program. This Exception is an additional permission under section 7 # of the GNU General Public License, version 3 ("GPLv3"). # # Originally written by Per Bothner; maintained since 2000 by Ben Elliston. # # You can get the latest version of this script from: # http://git.savannah.gnu.org/gitweb/?p=config.git;a=blob_plain;f=config.guess;hb=HEAD # # Please send patches to . me=`echo "$0" | sed -e 's,.*/,,'` usage="\ Usage: $0 [OPTION] Output the configuration name of the system \`$me' is run on. Operation modes: -h, --help print this help, then exit -t, --time-stamp print date of last modification, then exit -v, --version print version number, then exit Report bugs and patches to ." version="\ GNU config.guess ($timestamp) Originally written by Per Bothner. Copyright 1992-2015 Free Software Foundation, Inc. This is free software; see the source for copying conditions. There is NO warranty; not even for MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE." help=" Try \`$me --help' for more information." # Parse command line while test $# -gt 0 ; do case $1 in --time-stamp | --time* | -t ) echo "$timestamp" ; exit ;; --version | -v ) echo "$version" ; exit ;; --help | --h* | -h ) echo "$usage"; exit ;; -- ) # Stop option processing shift; break ;; - ) # Use stdin as input. break ;; -* ) echo "$me: invalid option $1$help" >&2 exit 1 ;; * ) break ;; esac done if test $# != 0; then echo "$me: too many arguments$help" >&2 exit 1 fi trap 'exit 1' 1 2 15 # CC_FOR_BUILD -- compiler used by this script. Note that the use of a # compiler to aid in system detection is discouraged as it requires # temporary files to be created and, as you can see below, it is a # headache to deal with in a portable fashion. # Historically, `CC_FOR_BUILD' used to be named `HOST_CC'. We still # use `HOST_CC' if defined, but it is deprecated. # Portable tmp directory creation inspired by the Autoconf team. set_cc_for_build=' trap "exitcode=\$?; (rm -f \$tmpfiles 2>/dev/null; rmdir \$tmp 2>/dev/null) && exit \$exitcode" 0 ; trap "rm -f \$tmpfiles 2>/dev/null; rmdir \$tmp 2>/dev/null; exit 1" 1 2 13 15 ; : ${TMPDIR=/tmp} ; { tmp=`(umask 077 && mktemp -d "$TMPDIR/cgXXXXXX") 2>/dev/null` && test -n "$tmp" && test -d "$tmp" ; } || { test -n "$RANDOM" && tmp=$TMPDIR/cg$$-$RANDOM && (umask 077 && mkdir $tmp) ; } || { tmp=$TMPDIR/cg-$$ && (umask 077 && mkdir $tmp) && echo "Warning: creating insecure temp directory" >&2 ; } || { echo "$me: cannot create a temporary directory in $TMPDIR" >&2 ; exit 1 ; } ; dummy=$tmp/dummy ; tmpfiles="$dummy.c $dummy.o $dummy.rel $dummy" ; case $CC_FOR_BUILD,$HOST_CC,$CC in ,,) echo "int x;" > $dummy.c ; for c in cc gcc c89 c99 ; do if ($c -c -o $dummy.o $dummy.c) >/dev/null 2>&1 ; then CC_FOR_BUILD="$c"; break ; fi ; done ; if test x"$CC_FOR_BUILD" = x ; then CC_FOR_BUILD=no_compiler_found ; fi ;; ,,*) CC_FOR_BUILD=$CC ;; ,*,*) CC_FOR_BUILD=$HOST_CC ;; esac ; set_cc_for_build= ;' # This is needed to find uname on a Pyramid OSx when run in the BSD universe. # (ghazi@noc.rutgers.edu 1994-08-24) if (test -f /.attbin/uname) >/dev/null 2>&1 ; then PATH=$PATH:/.attbin ; export PATH fi UNAME_MACHINE=`(uname -m) 2>/dev/null` || UNAME_MACHINE=unknown UNAME_RELEASE=`(uname -r) 2>/dev/null` || UNAME_RELEASE=unknown UNAME_SYSTEM=`(uname -s) 2>/dev/null` || UNAME_SYSTEM=unknown UNAME_VERSION=`(uname -v) 2>/dev/null` || UNAME_VERSION=unknown case "${UNAME_SYSTEM}" in Linux|GNU|GNU/*) # If the system lacks a compiler, then just pick glibc. # We could probably try harder. LIBC=gnu eval $set_cc_for_build cat <<-EOF > $dummy.c #include #if defined(__UCLIBC__) LIBC=uclibc #elif defined(__dietlibc__) LIBC=dietlibc #else LIBC=gnu #endif EOF eval `$CC_FOR_BUILD -E $dummy.c 2>/dev/null | grep '^LIBC' | sed 's, ,,g'` ;; esac # Note: order is significant - the case branches are not exclusive. case "${UNAME_MACHINE}:${UNAME_SYSTEM}:${UNAME_RELEASE}:${UNAME_VERSION}" in *:NetBSD:*:*) # NetBSD (nbsd) targets should (where applicable) match one or # more of the tuples: *-*-netbsdelf*, *-*-netbsdaout*, # *-*-netbsdecoff* and *-*-netbsd*. For targets that recently # switched to ELF, *-*-netbsd* would select the old # object file format. This provides both forward # compatibility and a consistent mechanism for selecting the # object file format. # # Note: NetBSD doesn't particularly care about the vendor # portion of the name. We always set it to "unknown". sysctl="sysctl -n hw.machine_arch" UNAME_MACHINE_ARCH=`(uname -p 2>/dev/null || \ /sbin/$sysctl 2>/dev/null || \ /usr/sbin/$sysctl 2>/dev/null || \ echo unknown)` case "${UNAME_MACHINE_ARCH}" in armeb) machine=armeb-unknown ;; arm*) machine=arm-unknown ;; sh3el) machine=shl-unknown ;; sh3eb) machine=sh-unknown ;; sh5el) machine=sh5le-unknown ;; earmv*) arch=`echo ${UNAME_MACHINE_ARCH} | sed -e 's,^e\(armv[0-9]\).*$,\1,'` endian=`echo ${UNAME_MACHINE_ARCH} | sed -ne 's,^.*\(eb\)$,\1,p'` machine=${arch}${endian}-unknown ;; *) machine=${UNAME_MACHINE_ARCH}-unknown ;; esac # The Operating System including object format, if it has switched # to ELF recently, or will in the future. case "${UNAME_MACHINE_ARCH}" in arm*|earm*|i386|m68k|ns32k|sh3*|sparc|vax) eval $set_cc_for_build if echo __ELF__ | $CC_FOR_BUILD -E - 2>/dev/null \ | grep -q __ELF__ then # Once all utilities can be ECOFF (netbsdecoff) or a.out (netbsdaout). # Return netbsd for either. FIX? os=netbsd else os=netbsdelf fi ;; *) os=netbsd ;; esac # Determine ABI tags. case "${UNAME_MACHINE_ARCH}" in earm*) expr='s/^earmv[0-9]/-eabi/;s/eb$//' abi=`echo ${UNAME_MACHINE_ARCH} | sed -e "$expr"` ;; esac # The OS release # Debian GNU/NetBSD machines have a different userland, and # thus, need a distinct triplet. However, they do not need # kernel version information, so it can be replaced with a # suitable tag, in the style of linux-gnu. case "${UNAME_VERSION}" in Debian*) release='-gnu' ;; *) release=`echo ${UNAME_RELEASE}|sed -e 's/[-_].*/\./'` ;; esac # Since CPU_TYPE-MANUFACTURER-KERNEL-OPERATING_SYSTEM: # contains redundant information, the shorter form: # CPU_TYPE-MANUFACTURER-OPERATING_SYSTEM is used. echo "${machine}-${os}${release}${abi}" exit ;; *:Bitrig:*:*) UNAME_MACHINE_ARCH=`arch | sed 's/Bitrig.//'` echo ${UNAME_MACHINE_ARCH}-unknown-bitrig${UNAME_RELEASE} exit ;; *:OpenBSD:*:*) UNAME_MACHINE_ARCH=`arch | sed 's/OpenBSD.//'` echo ${UNAME_MACHINE_ARCH}-unknown-openbsd${UNAME_RELEASE} exit ;; *:ekkoBSD:*:*) echo ${UNAME_MACHINE}-unknown-ekkobsd${UNAME_RELEASE} exit ;; *:SolidBSD:*:*) echo ${UNAME_MACHINE}-unknown-solidbsd${UNAME_RELEASE} exit ;; macppc:MirBSD:*:*) echo powerpc-unknown-mirbsd${UNAME_RELEASE} exit ;; *:MirBSD:*:*) echo ${UNAME_MACHINE}-unknown-mirbsd${UNAME_RELEASE} exit ;; alpha:OSF1:*:*) case $UNAME_RELEASE in *4.0) UNAME_RELEASE=`/usr/sbin/sizer -v | awk '{print $3}'` ;; *5.*) UNAME_RELEASE=`/usr/sbin/sizer -v | awk '{print $4}'` ;; esac # According to Compaq, /usr/sbin/psrinfo has been available on # OSF/1 and Tru64 systems produced since 1995. I hope that # covers most systems running today. This code pipes the CPU # types through head -n 1, so we only detect the type of CPU 0. ALPHA_CPU_TYPE=`/usr/sbin/psrinfo -v | sed -n -e 's/^ The alpha \(.*\) processor.*$/\1/p' | head -n 1` case "$ALPHA_CPU_TYPE" in "EV4 (21064)") UNAME_MACHINE="alpha" ;; "EV4.5 (21064)") UNAME_MACHINE="alpha" ;; "LCA4 (21066/21068)") UNAME_MACHINE="alpha" ;; "EV5 (21164)") UNAME_MACHINE="alphaev5" ;; "EV5.6 (21164A)") UNAME_MACHINE="alphaev56" ;; "EV5.6 (21164PC)") UNAME_MACHINE="alphapca56" ;; "EV5.7 (21164PC)") UNAME_MACHINE="alphapca57" ;; "EV6 (21264)") UNAME_MACHINE="alphaev6" ;; "EV6.7 (21264A)") UNAME_MACHINE="alphaev67" ;; "EV6.8CB (21264C)") UNAME_MACHINE="alphaev68" ;; "EV6.8AL (21264B)") UNAME_MACHINE="alphaev68" ;; "EV6.8CX (21264D)") UNAME_MACHINE="alphaev68" ;; "EV6.9A (21264/EV69A)") UNAME_MACHINE="alphaev69" ;; "EV7 (21364)") UNAME_MACHINE="alphaev7" ;; "EV7.9 (21364A)") UNAME_MACHINE="alphaev79" ;; esac # A Pn.n version is a patched version. # A Vn.n version is a released version. # A Tn.n version is a released field test version. # A Xn.n version is an unreleased experimental baselevel. # 1.2 uses "1.2" for uname -r. echo ${UNAME_MACHINE}-dec-osf`echo ${UNAME_RELEASE} | sed -e 's/^[PVTX]//' | tr 'ABCDEFGHIJKLMNOPQRSTUVWXYZ' 'abcdefghijklmnopqrstuvwxyz'` # Reset EXIT trap before exiting to avoid spurious non-zero exit code. exitcode=$? trap '' 0 exit $exitcode ;; Alpha\ *:Windows_NT*:*) # How do we know it's Interix rather than the generic POSIX subsystem? # Should we change UNAME_MACHINE based on the output of uname instead # of the specific Alpha model? echo alpha-pc-interix exit ;; 21064:Windows_NT:50:3) echo alpha-dec-winnt3.5 exit ;; Amiga*:UNIX_System_V:4.0:*) echo m68k-unknown-sysv4 exit ;; *:[Aa]miga[Oo][Ss]:*:*) echo ${UNAME_MACHINE}-unknown-amigaos exit ;; *:[Mm]orph[Oo][Ss]:*:*) echo ${UNAME_MACHINE}-unknown-morphos exit ;; *:OS/390:*:*) echo i370-ibm-openedition exit ;; *:z/VM:*:*) echo s390-ibm-zvmoe exit ;; *:OS400:*:*) echo powerpc-ibm-os400 exit ;; arm:RISC*:1.[012]*:*|arm:riscix:1.[012]*:*) echo arm-acorn-riscix${UNAME_RELEASE} exit ;; arm*:riscos:*:*|arm*:RISCOS:*:*) echo arm-unknown-riscos exit ;; SR2?01:HI-UX/MPP:*:* | SR8000:HI-UX/MPP:*:*) echo hppa1.1-hitachi-hiuxmpp exit ;; Pyramid*:OSx*:*:* | MIS*:OSx*:*:* | MIS*:SMP_DC-OSx*:*:*) # akee@wpdis03.wpafb.af.mil (Earle F. Ake) contributed MIS and NILE. if test "`(/bin/universe) 2>/dev/null`" = att ; then echo pyramid-pyramid-sysv3 else echo pyramid-pyramid-bsd fi exit ;; NILE*:*:*:dcosx) echo pyramid-pyramid-svr4 exit ;; DRS?6000:unix:4.0:6*) echo sparc-icl-nx6 exit ;; DRS?6000:UNIX_SV:4.2*:7* | DRS?6000:isis:4.2*:7*) case `/usr/bin/uname -p` in sparc) echo sparc-icl-nx7; exit ;; esac ;; s390x:SunOS:*:*) echo ${UNAME_MACHINE}-ibm-solaris2`echo ${UNAME_RELEASE}|sed -e 's/[^.]*//'` exit ;; sun4H:SunOS:5.*:*) echo sparc-hal-solaris2`echo ${UNAME_RELEASE}|sed -e 's/[^.]*//'` exit ;; sun4*:SunOS:5.*:* | tadpole*:SunOS:5.*:*) echo sparc-sun-solaris2`echo ${UNAME_RELEASE}|sed -e 's/[^.]*//'` exit ;; i86pc:AuroraUX:5.*:* | i86xen:AuroraUX:5.*:*) echo i386-pc-auroraux${UNAME_RELEASE} exit ;; i86pc:SunOS:5.*:* | i86xen:SunOS:5.*:*) eval $set_cc_for_build SUN_ARCH="i386" # If there is a compiler, see if it is configured for 64-bit objects. # Note that the Sun cc does not turn __LP64__ into 1 like gcc does. # This test works for both compilers. if [ "$CC_FOR_BUILD" != 'no_compiler_found' ]; then if (echo '#ifdef __amd64'; echo IS_64BIT_ARCH; echo '#endif') | \ (CCOPTS= $CC_FOR_BUILD -E - 2>/dev/null) | \ grep IS_64BIT_ARCH >/dev/null then SUN_ARCH="x86_64" fi fi echo ${SUN_ARCH}-pc-solaris2`echo ${UNAME_RELEASE}|sed -e 's/[^.]*//'` exit ;; sun4*:SunOS:6*:*) # According to config.sub, this is the proper way to canonicalize # SunOS6. Hard to guess exactly what SunOS6 will be like, but # it's likely to be more like Solaris than SunOS4. echo sparc-sun-solaris3`echo ${UNAME_RELEASE}|sed -e 's/[^.]*//'` exit ;; sun4*:SunOS:*:*) case "`/usr/bin/arch -k`" in Series*|S4*) UNAME_RELEASE=`uname -v` ;; esac # Japanese Language versions have a version number like `4.1.3-JL'. echo sparc-sun-sunos`echo ${UNAME_RELEASE}|sed -e 's/-/_/'` exit ;; sun3*:SunOS:*:*) echo m68k-sun-sunos${UNAME_RELEASE} exit ;; sun*:*:4.2BSD:*) UNAME_RELEASE=`(sed 1q /etc/motd | awk '{print substr($5,1,3)}') 2>/dev/null` test "x${UNAME_RELEASE}" = "x" && UNAME_RELEASE=3 case "`/bin/arch`" in sun3) echo m68k-sun-sunos${UNAME_RELEASE} ;; sun4) echo sparc-sun-sunos${UNAME_RELEASE} ;; esac exit ;; aushp:SunOS:*:*) echo sparc-auspex-sunos${UNAME_RELEASE} exit ;; # The situation for MiNT is a little confusing. The machine name # can be virtually everything (everything which is not # "atarist" or "atariste" at least should have a processor # > m68000). The system name ranges from "MiNT" over "FreeMiNT" # to the lowercase version "mint" (or "freemint"). Finally # the system name "TOS" denotes a system which is actually not # MiNT. But MiNT is downward compatible to TOS, so this should # be no problem. atarist[e]:*MiNT:*:* | atarist[e]:*mint:*:* | atarist[e]:*TOS:*:*) echo m68k-atari-mint${UNAME_RELEASE} exit ;; atari*:*MiNT:*:* | atari*:*mint:*:* | atarist[e]:*TOS:*:*) echo m68k-atari-mint${UNAME_RELEASE} exit ;; *falcon*:*MiNT:*:* | *falcon*:*mint:*:* | *falcon*:*TOS:*:*) echo m68k-atari-mint${UNAME_RELEASE} exit ;; milan*:*MiNT:*:* | milan*:*mint:*:* | *milan*:*TOS:*:*) echo m68k-milan-mint${UNAME_RELEASE} exit ;; hades*:*MiNT:*:* | hades*:*mint:*:* | *hades*:*TOS:*:*) echo m68k-hades-mint${UNAME_RELEASE} exit ;; *:*MiNT:*:* | *:*mint:*:* | *:*TOS:*:*) echo m68k-unknown-mint${UNAME_RELEASE} exit ;; m68k:machten:*:*) echo m68k-apple-machten${UNAME_RELEASE} exit ;; powerpc:machten:*:*) echo powerpc-apple-machten${UNAME_RELEASE} exit ;; RISC*:Mach:*:*) echo mips-dec-mach_bsd4.3 exit ;; RISC*:ULTRIX:*:*) echo mips-dec-ultrix${UNAME_RELEASE} exit ;; VAX*:ULTRIX*:*:*) echo vax-dec-ultrix${UNAME_RELEASE} exit ;; 2020:CLIX:*:* | 2430:CLIX:*:*) echo clipper-intergraph-clix${UNAME_RELEASE} exit ;; mips:*:*:UMIPS | mips:*:*:RISCos) eval $set_cc_for_build sed 's/^ //' << EOF >$dummy.c #ifdef __cplusplus #include /* for printf() prototype */ int main (int argc, char *argv[]) { #else int main (argc, argv) int argc; char *argv[]; { #endif #if defined (host_mips) && defined (MIPSEB) #if defined (SYSTYPE_SYSV) printf ("mips-mips-riscos%ssysv\n", argv[1]); exit (0); #endif #if defined (SYSTYPE_SVR4) printf ("mips-mips-riscos%ssvr4\n", argv[1]); exit (0); #endif #if defined (SYSTYPE_BSD43) || defined(SYSTYPE_BSD) printf ("mips-mips-riscos%sbsd\n", argv[1]); exit (0); #endif #endif exit (-1); } EOF $CC_FOR_BUILD -o $dummy $dummy.c && dummyarg=`echo "${UNAME_RELEASE}" | sed -n 's/\([0-9]*\).*/\1/p'` && SYSTEM_NAME=`$dummy $dummyarg` && { echo "$SYSTEM_NAME"; exit; } echo mips-mips-riscos${UNAME_RELEASE} exit ;; Motorola:PowerMAX_OS:*:*) echo powerpc-motorola-powermax exit ;; Motorola:*:4.3:PL8-*) echo powerpc-harris-powermax exit ;; Night_Hawk:*:*:PowerMAX_OS | Synergy:PowerMAX_OS:*:*) echo powerpc-harris-powermax exit ;; Night_Hawk:Power_UNIX:*:*) echo powerpc-harris-powerunix exit ;; m88k:CX/UX:7*:*) echo m88k-harris-cxux7 exit ;; m88k:*:4*:R4*) echo m88k-motorola-sysv4 exit ;; m88k:*:3*:R3*) echo m88k-motorola-sysv3 exit ;; AViiON:dgux:*:*) # DG/UX returns AViiON for all architectures UNAME_PROCESSOR=`/usr/bin/uname -p` if [ $UNAME_PROCESSOR = mc88100 ] || [ $UNAME_PROCESSOR = mc88110 ] then if [ ${TARGET_BINARY_INTERFACE}x = m88kdguxelfx ] || \ [ ${TARGET_BINARY_INTERFACE}x = x ] then echo m88k-dg-dgux${UNAME_RELEASE} else echo m88k-dg-dguxbcs${UNAME_RELEASE} fi else echo i586-dg-dgux${UNAME_RELEASE} fi exit ;; M88*:DolphinOS:*:*) # DolphinOS (SVR3) echo m88k-dolphin-sysv3 exit ;; M88*:*:R3*:*) # Delta 88k system running SVR3 echo m88k-motorola-sysv3 exit ;; XD88*:*:*:*) # Tektronix XD88 system running UTekV (SVR3) echo m88k-tektronix-sysv3 exit ;; Tek43[0-9][0-9]:UTek:*:*) # Tektronix 4300 system running UTek (BSD) echo m68k-tektronix-bsd exit ;; *:IRIX*:*:*) echo mips-sgi-irix`echo ${UNAME_RELEASE}|sed -e 's/-/_/g'` exit ;; ????????:AIX?:[12].1:2) # AIX 2.2.1 or AIX 2.1.1 is RT/PC AIX. echo romp-ibm-aix # uname -m gives an 8 hex-code CPU id exit ;; # Note that: echo "'`uname -s`'" gives 'AIX ' i*86:AIX:*:*) echo i386-ibm-aix exit ;; ia64:AIX:*:*) if [ -x /usr/bin/oslevel ] ; then IBM_REV=`/usr/bin/oslevel` else IBM_REV=${UNAME_VERSION}.${UNAME_RELEASE} fi echo ${UNAME_MACHINE}-ibm-aix${IBM_REV} exit ;; *:AIX:2:3) if grep bos325 /usr/include/stdio.h >/dev/null 2>&1; then eval $set_cc_for_build sed 's/^ //' << EOF >$dummy.c #include main() { if (!__power_pc()) exit(1); puts("powerpc-ibm-aix3.2.5"); exit(0); } EOF if $CC_FOR_BUILD -o $dummy $dummy.c && SYSTEM_NAME=`$dummy` then echo "$SYSTEM_NAME" else echo rs6000-ibm-aix3.2.5 fi elif grep bos324 /usr/include/stdio.h >/dev/null 2>&1; then echo rs6000-ibm-aix3.2.4 else echo rs6000-ibm-aix3.2 fi exit ;; *:AIX:*:[4567]) IBM_CPU_ID=`/usr/sbin/lsdev -C -c processor -S available | sed 1q | awk '{ print $1 }'` if /usr/sbin/lsattr -El ${IBM_CPU_ID} | grep ' POWER' >/dev/null 2>&1; then IBM_ARCH=rs6000 else IBM_ARCH=powerpc fi if [ -x /usr/bin/lslpp ] ; then IBM_REV=`/usr/bin/lslpp -Lqc bos.rte.libc | awk -F: '{ print $3 }' | sed s/[0-9]*$/0/` else IBM_REV=${UNAME_VERSION}.${UNAME_RELEASE} fi echo ${IBM_ARCH}-ibm-aix${IBM_REV} exit ;; *:AIX:*:*) echo rs6000-ibm-aix exit ;; ibmrt:4.4BSD:*|romp-ibm:BSD:*) echo romp-ibm-bsd4.4 exit ;; ibmrt:*BSD:*|romp-ibm:BSD:*) # covers RT/PC BSD and echo romp-ibm-bsd${UNAME_RELEASE} # 4.3 with uname added to exit ;; # report: romp-ibm BSD 4.3 *:BOSX:*:*) echo rs6000-bull-bosx exit ;; DPX/2?00:B.O.S.:*:*) echo m68k-bull-sysv3 exit ;; 9000/[34]??:4.3bsd:1.*:*) echo m68k-hp-bsd exit ;; hp300:4.4BSD:*:* | 9000/[34]??:4.3bsd:2.*:*) echo m68k-hp-bsd4.4 exit ;; 9000/[34678]??:HP-UX:*:*) HPUX_REV=`echo ${UNAME_RELEASE}|sed -e 's/[^.]*.[0B]*//'` case "${UNAME_MACHINE}" in 9000/31? ) HP_ARCH=m68000 ;; 9000/[34]?? ) HP_ARCH=m68k ;; 9000/[678][0-9][0-9]) if [ -x /usr/bin/getconf ]; then sc_cpu_version=`/usr/bin/getconf SC_CPU_VERSION 2>/dev/null` sc_kernel_bits=`/usr/bin/getconf SC_KERNEL_BITS 2>/dev/null` case "${sc_cpu_version}" in 523) HP_ARCH="hppa1.0" ;; # CPU_PA_RISC1_0 528) HP_ARCH="hppa1.1" ;; # CPU_PA_RISC1_1 532) # CPU_PA_RISC2_0 case "${sc_kernel_bits}" in 32) HP_ARCH="hppa2.0n" ;; 64) HP_ARCH="hppa2.0w" ;; '') HP_ARCH="hppa2.0" ;; # HP-UX 10.20 esac ;; esac fi if [ "${HP_ARCH}" = "" ]; then eval $set_cc_for_build sed 's/^ //' << EOF >$dummy.c #define _HPUX_SOURCE #include #include int main () { #if defined(_SC_KERNEL_BITS) long bits = sysconf(_SC_KERNEL_BITS); #endif long cpu = sysconf (_SC_CPU_VERSION); switch (cpu) { case CPU_PA_RISC1_0: puts ("hppa1.0"); break; case CPU_PA_RISC1_1: puts ("hppa1.1"); break; case CPU_PA_RISC2_0: #if defined(_SC_KERNEL_BITS) switch (bits) { case 64: puts ("hppa2.0w"); break; case 32: puts ("hppa2.0n"); break; default: puts ("hppa2.0"); break; } break; #else /* !defined(_SC_KERNEL_BITS) */ puts ("hppa2.0"); break; #endif default: puts ("hppa1.0"); break; } exit (0); } EOF (CCOPTS= $CC_FOR_BUILD -o $dummy $dummy.c 2>/dev/null) && HP_ARCH=`$dummy` test -z "$HP_ARCH" && HP_ARCH=hppa fi ;; esac if [ ${HP_ARCH} = "hppa2.0w" ] then eval $set_cc_for_build # hppa2.0w-hp-hpux* has a 64-bit kernel and a compiler generating # 32-bit code. hppa64-hp-hpux* has the same kernel and a compiler # generating 64-bit code. GNU and HP use different nomenclature: # # $ CC_FOR_BUILD=cc ./config.guess # => hppa2.0w-hp-hpux11.23 # $ CC_FOR_BUILD="cc +DA2.0w" ./config.guess # => hppa64-hp-hpux11.23 if echo __LP64__ | (CCOPTS= $CC_FOR_BUILD -E - 2>/dev/null) | grep -q __LP64__ then HP_ARCH="hppa2.0w" else HP_ARCH="hppa64" fi fi echo ${HP_ARCH}-hp-hpux${HPUX_REV} exit ;; ia64:HP-UX:*:*) HPUX_REV=`echo ${UNAME_RELEASE}|sed -e 's/[^.]*.[0B]*//'` echo ia64-hp-hpux${HPUX_REV} exit ;; 3050*:HI-UX:*:*) eval $set_cc_for_build sed 's/^ //' << EOF >$dummy.c #include int main () { long cpu = sysconf (_SC_CPU_VERSION); /* The order matters, because CPU_IS_HP_MC68K erroneously returns true for CPU_PA_RISC1_0. CPU_IS_PA_RISC returns correct results, however. */ if (CPU_IS_PA_RISC (cpu)) { switch (cpu) { case CPU_PA_RISC1_0: puts ("hppa1.0-hitachi-hiuxwe2"); break; case CPU_PA_RISC1_1: puts ("hppa1.1-hitachi-hiuxwe2"); break; case CPU_PA_RISC2_0: puts ("hppa2.0-hitachi-hiuxwe2"); break; default: puts ("hppa-hitachi-hiuxwe2"); break; } } else if (CPU_IS_HP_MC68K (cpu)) puts ("m68k-hitachi-hiuxwe2"); else puts ("unknown-hitachi-hiuxwe2"); exit (0); } EOF $CC_FOR_BUILD -o $dummy $dummy.c && SYSTEM_NAME=`$dummy` && { echo "$SYSTEM_NAME"; exit; } echo unknown-hitachi-hiuxwe2 exit ;; 9000/7??:4.3bsd:*:* | 9000/8?[79]:4.3bsd:*:* ) echo hppa1.1-hp-bsd exit ;; 9000/8??:4.3bsd:*:*) echo hppa1.0-hp-bsd exit ;; *9??*:MPE/iX:*:* | *3000*:MPE/iX:*:*) echo hppa1.0-hp-mpeix exit ;; hp7??:OSF1:*:* | hp8?[79]:OSF1:*:* ) echo hppa1.1-hp-osf exit ;; hp8??:OSF1:*:*) echo hppa1.0-hp-osf exit ;; i*86:OSF1:*:*) if [ -x /usr/sbin/sysversion ] ; then echo ${UNAME_MACHINE}-unknown-osf1mk else echo ${UNAME_MACHINE}-unknown-osf1 fi exit ;; parisc*:Lites*:*:*) echo hppa1.1-hp-lites exit ;; C1*:ConvexOS:*:* | convex:ConvexOS:C1*:*) echo c1-convex-bsd exit ;; C2*:ConvexOS:*:* | convex:ConvexOS:C2*:*) if getsysinfo -f scalar_acc then echo c32-convex-bsd else echo c2-convex-bsd fi exit ;; C34*:ConvexOS:*:* | convex:ConvexOS:C34*:*) echo c34-convex-bsd exit ;; C38*:ConvexOS:*:* | convex:ConvexOS:C38*:*) echo c38-convex-bsd exit ;; C4*:ConvexOS:*:* | convex:ConvexOS:C4*:*) echo c4-convex-bsd exit ;; CRAY*Y-MP:*:*:*) echo ymp-cray-unicos${UNAME_RELEASE} | sed -e 's/\.[^.]*$/.X/' exit ;; CRAY*[A-Z]90:*:*:*) echo ${UNAME_MACHINE}-cray-unicos${UNAME_RELEASE} \ | sed -e 's/CRAY.*\([A-Z]90\)/\1/' \ -e y/ABCDEFGHIJKLMNOPQRSTUVWXYZ/abcdefghijklmnopqrstuvwxyz/ \ -e 's/\.[^.]*$/.X/' exit ;; CRAY*TS:*:*:*) echo t90-cray-unicos${UNAME_RELEASE} | sed -e 's/\.[^.]*$/.X/' exit ;; CRAY*T3E:*:*:*) echo alphaev5-cray-unicosmk${UNAME_RELEASE} | sed -e 's/\.[^.]*$/.X/' exit ;; CRAY*SV1:*:*:*) echo sv1-cray-unicos${UNAME_RELEASE} | sed -e 's/\.[^.]*$/.X/' exit ;; *:UNICOS/mp:*:*) echo craynv-cray-unicosmp${UNAME_RELEASE} | sed -e 's/\.[^.]*$/.X/' exit ;; F30[01]:UNIX_System_V:*:* | F700:UNIX_System_V:*:*) FUJITSU_PROC=`uname -m | tr 'ABCDEFGHIJKLMNOPQRSTUVWXYZ' 'abcdefghijklmnopqrstuvwxyz'` FUJITSU_SYS=`uname -p | tr 'ABCDEFGHIJKLMNOPQRSTUVWXYZ' 'abcdefghijklmnopqrstuvwxyz' | sed -e 's/\///'` FUJITSU_REL=`echo ${UNAME_RELEASE} | sed -e 's/ /_/'` echo "${FUJITSU_PROC}-fujitsu-${FUJITSU_SYS}${FUJITSU_REL}" exit ;; 5000:UNIX_System_V:4.*:*) FUJITSU_SYS=`uname -p | tr 'ABCDEFGHIJKLMNOPQRSTUVWXYZ' 'abcdefghijklmnopqrstuvwxyz' | sed -e 's/\///'` FUJITSU_REL=`echo ${UNAME_RELEASE} | tr 'ABCDEFGHIJKLMNOPQRSTUVWXYZ' 'abcdefghijklmnopqrstuvwxyz' | sed -e 's/ /_/'` echo "sparc-fujitsu-${FUJITSU_SYS}${FUJITSU_REL}" exit ;; i*86:BSD/386:*:* | i*86:BSD/OS:*:* | *:Ascend\ Embedded/OS:*:*) echo ${UNAME_MACHINE}-pc-bsdi${UNAME_RELEASE} exit ;; sparc*:BSD/OS:*:*) echo sparc-unknown-bsdi${UNAME_RELEASE} exit ;; *:BSD/OS:*:*) echo ${UNAME_MACHINE}-unknown-bsdi${UNAME_RELEASE} exit ;; *:FreeBSD:*:*) UNAME_PROCESSOR=`/usr/bin/uname -p` echo ${UNAME_PROCESSOR}-unknown-freebsd`echo ${UNAME_RELEASE}|sed -e 's/[-(].*//'` exit ;; i*:CYGWIN*:*) echo ${UNAME_MACHINE}-pc-cygwin exit ;; *:MINGW64*:*) echo ${UNAME_MACHINE}-pc-mingw64 exit ;; *:MINGW*:*) echo ${UNAME_MACHINE}-pc-mingw32 exit ;; *:MSYS*:*) echo ${UNAME_MACHINE}-pc-msys exit ;; i*:windows32*:*) # uname -m includes "-pc" on this system. echo ${UNAME_MACHINE}-mingw32 exit ;; i*:PW*:*) echo ${UNAME_MACHINE}-pc-pw32 exit ;; *:Interix*:*) case ${UNAME_MACHINE} in x86) echo i586-pc-interix${UNAME_RELEASE} exit ;; authenticamd | genuineintel | EM64T) echo x86_64-unknown-interix${UNAME_RELEASE} exit ;; IA64) echo ia64-unknown-interix${UNAME_RELEASE} exit ;; esac ;; [345]86:Windows_95:* | [345]86:Windows_98:* | [345]86:Windows_NT:*) echo i${UNAME_MACHINE}-pc-mks exit ;; 8664:Windows_NT:*) echo x86_64-pc-mks exit ;; i*:Windows_NT*:* | Pentium*:Windows_NT*:*) # How do we know it's Interix rather than the generic POSIX subsystem? # It also conflicts with pre-2.0 versions of AT&T UWIN. Should we # UNAME_MACHINE based on the output of uname instead of i386? echo i586-pc-interix exit ;; i*:UWIN*:*) echo ${UNAME_MACHINE}-pc-uwin exit ;; amd64:CYGWIN*:*:* | x86_64:CYGWIN*:*:*) echo x86_64-unknown-cygwin exit ;; p*:CYGWIN*:*) echo powerpcle-unknown-cygwin exit ;; prep*:SunOS:5.*:*) echo powerpcle-unknown-solaris2`echo ${UNAME_RELEASE}|sed -e 's/[^.]*//'` exit ;; *:GNU:*:*) # the GNU system echo `echo ${UNAME_MACHINE}|sed -e 's,[-/].*$,,'`-unknown-${LIBC}`echo ${UNAME_RELEASE}|sed -e 's,/.*$,,'` exit ;; *:GNU/*:*:*) # other systems with GNU libc and userland echo ${UNAME_MACHINE}-unknown-`echo ${UNAME_SYSTEM} | sed 's,^[^/]*/,,' | tr '[A-Z]' '[a-z]'``echo ${UNAME_RELEASE}|sed -e 's/[-(].*//'`-${LIBC} exit ;; i*86:Minix:*:*) echo ${UNAME_MACHINE}-pc-minix exit ;; aarch64:Linux:*:*) echo ${UNAME_MACHINE}-unknown-linux-${LIBC} exit ;; aarch64_be:Linux:*:*) UNAME_MACHINE=aarch64_be echo ${UNAME_MACHINE}-unknown-linux-${LIBC} exit ;; alpha:Linux:*:*) case `sed -n '/^cpu model/s/^.*: \(.*\)/\1/p' < /proc/cpuinfo` in EV5) UNAME_MACHINE=alphaev5 ;; EV56) UNAME_MACHINE=alphaev56 ;; PCA56) UNAME_MACHINE=alphapca56 ;; PCA57) UNAME_MACHINE=alphapca56 ;; EV6) UNAME_MACHINE=alphaev6 ;; EV67) UNAME_MACHINE=alphaev67 ;; EV68*) UNAME_MACHINE=alphaev68 ;; esac objdump --private-headers /bin/sh | grep -q ld.so.1 if test "$?" = 0 ; then LIBC="gnulibc1" ; fi echo ${UNAME_MACHINE}-unknown-linux-${LIBC} exit ;; arc:Linux:*:* | arceb:Linux:*:*) echo ${UNAME_MACHINE}-unknown-linux-${LIBC} exit ;; arm*:Linux:*:*) eval $set_cc_for_build if echo __ARM_EABI__ | $CC_FOR_BUILD -E - 2>/dev/null \ | grep -q __ARM_EABI__ then echo ${UNAME_MACHINE}-unknown-linux-${LIBC} else if echo __ARM_PCS_VFP | $CC_FOR_BUILD -E - 2>/dev/null \ | grep -q __ARM_PCS_VFP then echo ${UNAME_MACHINE}-unknown-linux-${LIBC}eabi else echo ${UNAME_MACHINE}-unknown-linux-${LIBC}eabihf fi fi exit ;; avr32*:Linux:*:*) echo ${UNAME_MACHINE}-unknown-linux-${LIBC} exit ;; cris:Linux:*:*) echo ${UNAME_MACHINE}-axis-linux-${LIBC} exit ;; crisv32:Linux:*:*) echo ${UNAME_MACHINE}-axis-linux-${LIBC} exit ;; e2k:Linux:*:*) echo ${UNAME_MACHINE}-unknown-linux-${LIBC} exit ;; frv:Linux:*:*) echo ${UNAME_MACHINE}-unknown-linux-${LIBC} exit ;; hexagon:Linux:*:*) echo ${UNAME_MACHINE}-unknown-linux-${LIBC} exit ;; i*86:Linux:*:*) echo ${UNAME_MACHINE}-pc-linux-${LIBC} exit ;; ia64:Linux:*:*) echo ${UNAME_MACHINE}-unknown-linux-${LIBC} exit ;; m32r*:Linux:*:*) echo ${UNAME_MACHINE}-unknown-linux-${LIBC} exit ;; m68*:Linux:*:*) echo ${UNAME_MACHINE}-unknown-linux-${LIBC} exit ;; mips:Linux:*:* | mips64:Linux:*:*) eval $set_cc_for_build sed 's/^ //' << EOF >$dummy.c #undef CPU #undef ${UNAME_MACHINE} #undef ${UNAME_MACHINE}el #if defined(__MIPSEL__) || defined(__MIPSEL) || defined(_MIPSEL) || defined(MIPSEL) CPU=${UNAME_MACHINE}el #else #if defined(__MIPSEB__) || defined(__MIPSEB) || defined(_MIPSEB) || defined(MIPSEB) CPU=${UNAME_MACHINE} #else CPU= #endif #endif EOF eval `$CC_FOR_BUILD -E $dummy.c 2>/dev/null | grep '^CPU'` test x"${CPU}" != x && { echo "${CPU}-unknown-linux-${LIBC}"; exit; } ;; openrisc*:Linux:*:*) echo or1k-unknown-linux-${LIBC} exit ;; or32:Linux:*:* | or1k*:Linux:*:*) echo ${UNAME_MACHINE}-unknown-linux-${LIBC} exit ;; padre:Linux:*:*) echo sparc-unknown-linux-${LIBC} exit ;; parisc64:Linux:*:* | hppa64:Linux:*:*) echo hppa64-unknown-linux-${LIBC} exit ;; parisc:Linux:*:* | hppa:Linux:*:*) # Look for CPU level case `grep '^cpu[^a-z]*:' /proc/cpuinfo 2>/dev/null | cut -d' ' -f2` in PA7*) echo hppa1.1-unknown-linux-${LIBC} ;; PA8*) echo hppa2.0-unknown-linux-${LIBC} ;; *) echo hppa-unknown-linux-${LIBC} ;; esac exit ;; ppc64:Linux:*:*) echo powerpc64-unknown-linux-${LIBC} exit ;; ppc:Linux:*:*) echo powerpc-unknown-linux-${LIBC} exit ;; ppc64le:Linux:*:*) echo powerpc64le-unknown-linux-${LIBC} exit ;; ppcle:Linux:*:*) echo powerpcle-unknown-linux-${LIBC} exit ;; s390:Linux:*:* | s390x:Linux:*:*) echo ${UNAME_MACHINE}-ibm-linux-${LIBC} exit ;; sh64*:Linux:*:*) echo ${UNAME_MACHINE}-unknown-linux-${LIBC} exit ;; sh*:Linux:*:*) echo ${UNAME_MACHINE}-unknown-linux-${LIBC} exit ;; sparc:Linux:*:* | sparc64:Linux:*:*) echo ${UNAME_MACHINE}-unknown-linux-${LIBC} exit ;; tile*:Linux:*:*) echo ${UNAME_MACHINE}-unknown-linux-${LIBC} exit ;; vax:Linux:*:*) echo ${UNAME_MACHINE}-dec-linux-${LIBC} exit ;; x86_64:Linux:*:*) echo ${UNAME_MACHINE}-unknown-linux-${LIBC} exit ;; xtensa*:Linux:*:*) echo ${UNAME_MACHINE}-unknown-linux-${LIBC} exit ;; i*86:DYNIX/ptx:4*:*) # ptx 4.0 does uname -s correctly, with DYNIX/ptx in there. # earlier versions are messed up and put the nodename in both # sysname and nodename. echo i386-sequent-sysv4 exit ;; i*86:UNIX_SV:4.2MP:2.*) # Unixware is an offshoot of SVR4, but it has its own version # number series starting with 2... # I am not positive that other SVR4 systems won't match this, # I just have to hope. -- rms. # Use sysv4.2uw... so that sysv4* matches it. echo ${UNAME_MACHINE}-pc-sysv4.2uw${UNAME_VERSION} exit ;; i*86:OS/2:*:*) # If we were able to find `uname', then EMX Unix compatibility # is probably installed. echo ${UNAME_MACHINE}-pc-os2-emx exit ;; i*86:XTS-300:*:STOP) echo ${UNAME_MACHINE}-unknown-stop exit ;; i*86:atheos:*:*) echo ${UNAME_MACHINE}-unknown-atheos exit ;; i*86:syllable:*:*) echo ${UNAME_MACHINE}-pc-syllable exit ;; i*86:LynxOS:2.*:* | i*86:LynxOS:3.[01]*:* | i*86:LynxOS:4.[02]*:*) echo i386-unknown-lynxos${UNAME_RELEASE} exit ;; i*86:*DOS:*:*) echo ${UNAME_MACHINE}-pc-msdosdjgpp exit ;; i*86:*:4.*:* | i*86:SYSTEM_V:4.*:*) UNAME_REL=`echo ${UNAME_RELEASE} | sed 's/\/MP$//'` if grep Novell /usr/include/link.h >/dev/null 2>/dev/null; then echo ${UNAME_MACHINE}-univel-sysv${UNAME_REL} else echo ${UNAME_MACHINE}-pc-sysv${UNAME_REL} fi exit ;; i*86:*:5:[678]*) # UnixWare 7.x, OpenUNIX and OpenServer 6. case `/bin/uname -X | grep "^Machine"` in *486*) UNAME_MACHINE=i486 ;; *Pentium) UNAME_MACHINE=i586 ;; *Pent*|*Celeron) UNAME_MACHINE=i686 ;; esac echo ${UNAME_MACHINE}-unknown-sysv${UNAME_RELEASE}${UNAME_SYSTEM}${UNAME_VERSION} exit ;; i*86:*:3.2:*) if test -f /usr/options/cb.name; then UNAME_REL=`sed -n 's/.*Version //p' /dev/null >/dev/null ; then UNAME_REL=`(/bin/uname -X|grep Release|sed -e 's/.*= //')` (/bin/uname -X|grep i80486 >/dev/null) && UNAME_MACHINE=i486 (/bin/uname -X|grep '^Machine.*Pentium' >/dev/null) \ && UNAME_MACHINE=i586 (/bin/uname -X|grep '^Machine.*Pent *II' >/dev/null) \ && UNAME_MACHINE=i686 (/bin/uname -X|grep '^Machine.*Pentium Pro' >/dev/null) \ && UNAME_MACHINE=i686 echo ${UNAME_MACHINE}-pc-sco$UNAME_REL else echo ${UNAME_MACHINE}-pc-sysv32 fi exit ;; pc:*:*:*) # Left here for compatibility: # uname -m prints for DJGPP always 'pc', but it prints nothing about # the processor, so we play safe by assuming i586. # Note: whatever this is, it MUST be the same as what config.sub # prints for the "djgpp" host, or else GDB configury will decide that # this is a cross-build. echo i586-pc-msdosdjgpp exit ;; Intel:Mach:3*:*) echo i386-pc-mach3 exit ;; paragon:*:*:*) echo i860-intel-osf1 exit ;; i860:*:4.*:*) # i860-SVR4 if grep Stardent /usr/include/sys/uadmin.h >/dev/null 2>&1 ; then echo i860-stardent-sysv${UNAME_RELEASE} # Stardent Vistra i860-SVR4 else # Add other i860-SVR4 vendors below as they are discovered. echo i860-unknown-sysv${UNAME_RELEASE} # Unknown i860-SVR4 fi exit ;; mini*:CTIX:SYS*5:*) # "miniframe" echo m68010-convergent-sysv exit ;; mc68k:UNIX:SYSTEM5:3.51m) echo m68k-convergent-sysv exit ;; M680?0:D-NIX:5.3:*) echo m68k-diab-dnix exit ;; M68*:*:R3V[5678]*:*) test -r /sysV68 && { echo 'm68k-motorola-sysv'; exit; } ;; 3[345]??:*:4.0:3.0 | 3[34]??A:*:4.0:3.0 | 3[34]??,*:*:4.0:3.0 | 3[34]??/*:*:4.0:3.0 | 4400:*:4.0:3.0 | 4850:*:4.0:3.0 | SKA40:*:4.0:3.0 | SDS2:*:4.0:3.0 | SHG2:*:4.0:3.0 | S7501*:*:4.0:3.0) OS_REL='' test -r /etc/.relid \ && OS_REL=.`sed -n 's/[^ ]* [^ ]* \([0-9][0-9]\).*/\1/p' < /etc/.relid` /bin/uname -p 2>/dev/null | grep 86 >/dev/null \ && { echo i486-ncr-sysv4.3${OS_REL}; exit; } /bin/uname -p 2>/dev/null | /bin/grep entium >/dev/null \ && { echo i586-ncr-sysv4.3${OS_REL}; exit; } ;; 3[34]??:*:4.0:* | 3[34]??,*:*:4.0:*) /bin/uname -p 2>/dev/null | grep 86 >/dev/null \ && { echo i486-ncr-sysv4; exit; } ;; NCR*:*:4.2:* | MPRAS*:*:4.2:*) OS_REL='.3' test -r /etc/.relid \ && OS_REL=.`sed -n 's/[^ ]* [^ ]* \([0-9][0-9]\).*/\1/p' < /etc/.relid` /bin/uname -p 2>/dev/null | grep 86 >/dev/null \ && { echo i486-ncr-sysv4.3${OS_REL}; exit; } /bin/uname -p 2>/dev/null | /bin/grep entium >/dev/null \ && { echo i586-ncr-sysv4.3${OS_REL}; exit; } /bin/uname -p 2>/dev/null | /bin/grep pteron >/dev/null \ && { echo i586-ncr-sysv4.3${OS_REL}; exit; } ;; m68*:LynxOS:2.*:* | m68*:LynxOS:3.0*:*) echo m68k-unknown-lynxos${UNAME_RELEASE} exit ;; mc68030:UNIX_System_V:4.*:*) echo m68k-atari-sysv4 exit ;; TSUNAMI:LynxOS:2.*:*) echo sparc-unknown-lynxos${UNAME_RELEASE} exit ;; rs6000:LynxOS:2.*:*) echo rs6000-unknown-lynxos${UNAME_RELEASE} exit ;; PowerPC:LynxOS:2.*:* | PowerPC:LynxOS:3.[01]*:* | PowerPC:LynxOS:4.[02]*:*) echo powerpc-unknown-lynxos${UNAME_RELEASE} exit ;; SM[BE]S:UNIX_SV:*:*) echo mips-dde-sysv${UNAME_RELEASE} exit ;; RM*:ReliantUNIX-*:*:*) echo mips-sni-sysv4 exit ;; RM*:SINIX-*:*:*) echo mips-sni-sysv4 exit ;; *:SINIX-*:*:*) if uname -p 2>/dev/null >/dev/null ; then UNAME_MACHINE=`(uname -p) 2>/dev/null` echo ${UNAME_MACHINE}-sni-sysv4 else echo ns32k-sni-sysv fi exit ;; PENTIUM:*:4.0*:*) # Unisys `ClearPath HMP IX 4000' SVR4/MP effort # says echo i586-unisys-sysv4 exit ;; *:UNIX_System_V:4*:FTX*) # From Gerald Hewes . # How about differentiating between stratus architectures? -djm echo hppa1.1-stratus-sysv4 exit ;; *:*:*:FTX*) # From seanf@swdc.stratus.com. echo i860-stratus-sysv4 exit ;; i*86:VOS:*:*) # From Paul.Green@stratus.com. echo ${UNAME_MACHINE}-stratus-vos exit ;; *:VOS:*:*) # From Paul.Green@stratus.com. echo hppa1.1-stratus-vos exit ;; mc68*:A/UX:*:*) echo m68k-apple-aux${UNAME_RELEASE} exit ;; news*:NEWS-OS:6*:*) echo mips-sony-newsos6 exit ;; R[34]000:*System_V*:*:* | R4000:UNIX_SYSV:*:* | R*000:UNIX_SV:*:*) if [ -d /usr/nec ]; then echo mips-nec-sysv${UNAME_RELEASE} else echo mips-unknown-sysv${UNAME_RELEASE} fi exit ;; BeBox:BeOS:*:*) # BeOS running on hardware made by Be, PPC only. echo powerpc-be-beos exit ;; BeMac:BeOS:*:*) # BeOS running on Mac or Mac clone, PPC only. echo powerpc-apple-beos exit ;; BePC:BeOS:*:*) # BeOS running on Intel PC compatible. echo i586-pc-beos exit ;; BePC:Haiku:*:*) # Haiku running on Intel PC compatible. echo i586-pc-haiku exit ;; x86_64:Haiku:*:*) echo x86_64-unknown-haiku exit ;; SX-4:SUPER-UX:*:*) echo sx4-nec-superux${UNAME_RELEASE} exit ;; SX-5:SUPER-UX:*:*) echo sx5-nec-superux${UNAME_RELEASE} exit ;; SX-6:SUPER-UX:*:*) echo sx6-nec-superux${UNAME_RELEASE} exit ;; SX-7:SUPER-UX:*:*) echo sx7-nec-superux${UNAME_RELEASE} exit ;; SX-8:SUPER-UX:*:*) echo sx8-nec-superux${UNAME_RELEASE} exit ;; SX-8R:SUPER-UX:*:*) echo sx8r-nec-superux${UNAME_RELEASE} exit ;; Power*:Rhapsody:*:*) echo powerpc-apple-rhapsody${UNAME_RELEASE} exit ;; *:Rhapsody:*:*) echo ${UNAME_MACHINE}-apple-rhapsody${UNAME_RELEASE} exit ;; *:Darwin:*:*) UNAME_PROCESSOR=`uname -p` || UNAME_PROCESSOR=unknown eval $set_cc_for_build if test "$UNAME_PROCESSOR" = unknown ; then UNAME_PROCESSOR=powerpc fi if test `echo "$UNAME_RELEASE" | sed -e 's/\..*//'` -le 10 ; then if [ "$CC_FOR_BUILD" != 'no_compiler_found' ]; then if (echo '#ifdef __LP64__'; echo IS_64BIT_ARCH; echo '#endif') | \ (CCOPTS= $CC_FOR_BUILD -E - 2>/dev/null) | \ grep IS_64BIT_ARCH >/dev/null then case $UNAME_PROCESSOR in i386) UNAME_PROCESSOR=x86_64 ;; powerpc) UNAME_PROCESSOR=powerpc64 ;; esac fi fi elif test "$UNAME_PROCESSOR" = i386 ; then # Avoid executing cc on OS X 10.9, as it ships with a stub # that puts up a graphical alert prompting to install # developer tools. Any system running Mac OS X 10.7 or # later (Darwin 11 and later) is required to have a 64-bit # processor. This is not true of the ARM version of Darwin # that Apple uses in portable devices. UNAME_PROCESSOR=x86_64 fi echo ${UNAME_PROCESSOR}-apple-darwin${UNAME_RELEASE} exit ;; *:procnto*:*:* | *:QNX:[0123456789]*:*) UNAME_PROCESSOR=`uname -p` if test "$UNAME_PROCESSOR" = "x86"; then UNAME_PROCESSOR=i386 UNAME_MACHINE=pc fi echo ${UNAME_PROCESSOR}-${UNAME_MACHINE}-nto-qnx${UNAME_RELEASE} exit ;; *:QNX:*:4*) echo i386-pc-qnx exit ;; NEO-?:NONSTOP_KERNEL:*:*) echo neo-tandem-nsk${UNAME_RELEASE} exit ;; NSE-*:NONSTOP_KERNEL:*:*) echo nse-tandem-nsk${UNAME_RELEASE} exit ;; NSR-?:NONSTOP_KERNEL:*:*) echo nsr-tandem-nsk${UNAME_RELEASE} exit ;; *:NonStop-UX:*:*) echo mips-compaq-nonstopux exit ;; BS2000:POSIX*:*:*) echo bs2000-siemens-sysv exit ;; DS/*:UNIX_System_V:*:*) echo ${UNAME_MACHINE}-${UNAME_SYSTEM}-${UNAME_RELEASE} exit ;; *:Plan9:*:*) # "uname -m" is not consistent, so use $cputype instead. 386 # is converted to i386 for consistency with other x86 # operating systems. if test "$cputype" = "386"; then UNAME_MACHINE=i386 else UNAME_MACHINE="$cputype" fi echo ${UNAME_MACHINE}-unknown-plan9 exit ;; *:TOPS-10:*:*) echo pdp10-unknown-tops10 exit ;; *:TENEX:*:*) echo pdp10-unknown-tenex exit ;; KS10:TOPS-20:*:* | KL10:TOPS-20:*:* | TYPE4:TOPS-20:*:*) echo pdp10-dec-tops20 exit ;; XKL-1:TOPS-20:*:* | TYPE5:TOPS-20:*:*) echo pdp10-xkl-tops20 exit ;; *:TOPS-20:*:*) echo pdp10-unknown-tops20 exit ;; *:ITS:*:*) echo pdp10-unknown-its exit ;; SEI:*:*:SEIUX) echo mips-sei-seiux${UNAME_RELEASE} exit ;; *:DragonFly:*:*) echo ${UNAME_MACHINE}-unknown-dragonfly`echo ${UNAME_RELEASE}|sed -e 's/[-(].*//'` exit ;; *:*VMS:*:*) UNAME_MACHINE=`(uname -p) 2>/dev/null` case "${UNAME_MACHINE}" in A*) echo alpha-dec-vms ; exit ;; I*) echo ia64-dec-vms ; exit ;; V*) echo vax-dec-vms ; exit ;; esac ;; *:XENIX:*:SysV) echo i386-pc-xenix exit ;; i*86:skyos:*:*) echo ${UNAME_MACHINE}-pc-skyos`echo ${UNAME_RELEASE}` | sed -e 's/ .*$//' exit ;; i*86:rdos:*:*) echo ${UNAME_MACHINE}-pc-rdos exit ;; i*86:AROS:*:*) echo ${UNAME_MACHINE}-pc-aros exit ;; x86_64:VMkernel:*:*) echo ${UNAME_MACHINE}-unknown-esx exit ;; esac cat >&2 < in order to provide the needed information to handle your system. config.guess timestamp = $timestamp uname -m = `(uname -m) 2>/dev/null || echo unknown` uname -r = `(uname -r) 2>/dev/null || echo unknown` uname -s = `(uname -s) 2>/dev/null || echo unknown` uname -v = `(uname -v) 2>/dev/null || echo unknown` /usr/bin/uname -p = `(/usr/bin/uname -p) 2>/dev/null` /bin/uname -X = `(/bin/uname -X) 2>/dev/null` hostinfo = `(hostinfo) 2>/dev/null` /bin/universe = `(/bin/universe) 2>/dev/null` /usr/bin/arch -k = `(/usr/bin/arch -k) 2>/dev/null` /bin/arch = `(/bin/arch) 2>/dev/null` /usr/bin/oslevel = `(/usr/bin/oslevel) 2>/dev/null` /usr/convex/getsysinfo = `(/usr/convex/getsysinfo) 2>/dev/null` UNAME_MACHINE = ${UNAME_MACHINE} UNAME_RELEASE = ${UNAME_RELEASE} UNAME_SYSTEM = ${UNAME_SYSTEM} UNAME_VERSION = ${UNAME_VERSION} EOF exit 1 # Local variables: # eval: (add-hook 'write-file-hooks 'time-stamp) # time-stamp-start: "timestamp='" # time-stamp-format: "%:y-%02m-%02d" # time-stamp-end: "'" # End: xrdp-0.9.5/librfxcodec/config.sub000755 001751 001751 00000106246 13220730761 016703 0ustar00metameta000000 000000 #! /bin/sh # Configuration validation subroutine script. # Copyright 1992-2015 Free Software Foundation, Inc. timestamp='2015-03-08' # This file 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. # # You should have received a copy of the GNU General Public License # along with this program; if not, see . # # As a special exception to the GNU General Public License, if you # distribute this file as part of a program that contains a # configuration script generated by Autoconf, you may include it under # the same distribution terms that you use for the rest of that # program. This Exception is an additional permission under section 7 # of the GNU General Public License, version 3 ("GPLv3"). # Please send patches to . # # Configuration subroutine to validate and canonicalize a configuration type. # Supply the specified configuration type as an argument. # If it is invalid, we print an error message on stderr and exit with code 1. # Otherwise, we print the canonical config type on stdout and succeed. # You can get the latest version of this script from: # http://git.savannah.gnu.org/gitweb/?p=config.git;a=blob_plain;f=config.sub;hb=HEAD # This file is supposed to be the same for all GNU packages # and recognize all the CPU types, system types and aliases # that are meaningful with *any* GNU software. # Each package is responsible for reporting which valid configurations # it does not support. The user should be able to distinguish # a failure to support a valid configuration from a meaningless # configuration. # The goal of this file is to map all the various variations of a given # machine specification into a single specification in the form: # CPU_TYPE-MANUFACTURER-OPERATING_SYSTEM # or in some cases, the newer four-part form: # CPU_TYPE-MANUFACTURER-KERNEL-OPERATING_SYSTEM # It is wrong to echo any other type of specification. me=`echo "$0" | sed -e 's,.*/,,'` usage="\ Usage: $0 [OPTION] CPU-MFR-OPSYS $0 [OPTION] ALIAS Canonicalize a configuration name. Operation modes: -h, --help print this help, then exit -t, --time-stamp print date of last modification, then exit -v, --version print version number, then exit Report bugs and patches to ." version="\ GNU config.sub ($timestamp) Copyright 1992-2015 Free Software Foundation, Inc. This is free software; see the source for copying conditions. There is NO warranty; not even for MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE." help=" Try \`$me --help' for more information." # Parse command line while test $# -gt 0 ; do case $1 in --time-stamp | --time* | -t ) echo "$timestamp" ; exit ;; --version | -v ) echo "$version" ; exit ;; --help | --h* | -h ) echo "$usage"; exit ;; -- ) # Stop option processing shift; break ;; - ) # Use stdin as input. break ;; -* ) echo "$me: invalid option $1$help" exit 1 ;; *local*) # First pass through any local machine types. echo $1 exit ;; * ) break ;; esac done case $# in 0) echo "$me: missing argument$help" >&2 exit 1;; 1) ;; *) echo "$me: too many arguments$help" >&2 exit 1;; esac # Separate what the user gave into CPU-COMPANY and OS or KERNEL-OS (if any). # Here we must recognize all the valid KERNEL-OS combinations. maybe_os=`echo $1 | sed 's/^\(.*\)-\([^-]*-[^-]*\)$/\2/'` case $maybe_os in nto-qnx* | linux-gnu* | linux-android* | linux-dietlibc | linux-newlib* | \ linux-musl* | linux-uclibc* | uclinux-uclibc* | uclinux-gnu* | kfreebsd*-gnu* | \ knetbsd*-gnu* | netbsd*-gnu* | netbsd*-eabi* | \ kopensolaris*-gnu* | \ storm-chaos* | os2-emx* | rtmk-nova*) os=-$maybe_os basic_machine=`echo $1 | sed 's/^\(.*\)-\([^-]*-[^-]*\)$/\1/'` ;; android-linux) os=-linux-android basic_machine=`echo $1 | sed 's/^\(.*\)-\([^-]*-[^-]*\)$/\1/'`-unknown ;; *) basic_machine=`echo $1 | sed 's/-[^-]*$//'` if [ $basic_machine != $1 ] then os=`echo $1 | sed 's/.*-/-/'` else os=; fi ;; esac ### Let's recognize common machines as not being operating systems so ### that things like config.sub decstation-3100 work. We also ### recognize some manufacturers as not being operating systems, so we ### can provide default operating systems below. case $os in -sun*os*) # Prevent following clause from handling this invalid input. ;; -dec* | -mips* | -sequent* | -encore* | -pc532* | -sgi* | -sony* | \ -att* | -7300* | -3300* | -delta* | -motorola* | -sun[234]* | \ -unicom* | -ibm* | -next | -hp | -isi* | -apollo | -altos* | \ -convergent* | -ncr* | -news | -32* | -3600* | -3100* | -hitachi* |\ -c[123]* | -convex* | -sun | -crds | -omron* | -dg | -ultra | -tti* | \ -harris | -dolphin | -highlevel | -gould | -cbm | -ns | -masscomp | \ -apple | -axis | -knuth | -cray | -microblaze*) os= basic_machine=$1 ;; -bluegene*) os=-cnk ;; -sim | -cisco | -oki | -wec | -winbond) os= basic_machine=$1 ;; -scout) ;; -wrs) os=-vxworks basic_machine=$1 ;; -chorusos*) os=-chorusos basic_machine=$1 ;; -chorusrdb) os=-chorusrdb basic_machine=$1 ;; -hiux*) os=-hiuxwe2 ;; -sco6) os=-sco5v6 basic_machine=`echo $1 | sed -e 's/86-.*/86-pc/'` ;; -sco5) os=-sco3.2v5 basic_machine=`echo $1 | sed -e 's/86-.*/86-pc/'` ;; -sco4) os=-sco3.2v4 basic_machine=`echo $1 | sed -e 's/86-.*/86-pc/'` ;; -sco3.2.[4-9]*) os=`echo $os | sed -e 's/sco3.2./sco3.2v/'` basic_machine=`echo $1 | sed -e 's/86-.*/86-pc/'` ;; -sco3.2v[4-9]*) # Don't forget version if it is 3.2v4 or newer. basic_machine=`echo $1 | sed -e 's/86-.*/86-pc/'` ;; -sco5v6*) # Don't forget version if it is 3.2v4 or newer. basic_machine=`echo $1 | sed -e 's/86-.*/86-pc/'` ;; -sco*) os=-sco3.2v2 basic_machine=`echo $1 | sed -e 's/86-.*/86-pc/'` ;; -udk*) basic_machine=`echo $1 | sed -e 's/86-.*/86-pc/'` ;; -isc) os=-isc2.2 basic_machine=`echo $1 | sed -e 's/86-.*/86-pc/'` ;; -clix*) basic_machine=clipper-intergraph ;; -isc*) basic_machine=`echo $1 | sed -e 's/86-.*/86-pc/'` ;; -lynx*178) os=-lynxos178 ;; -lynx*5) os=-lynxos5 ;; -lynx*) os=-lynxos ;; -ptx*) basic_machine=`echo $1 | sed -e 's/86-.*/86-sequent/'` ;; -windowsnt*) os=`echo $os | sed -e 's/windowsnt/winnt/'` ;; -psos*) os=-psos ;; -mint | -mint[0-9]*) basic_machine=m68k-atari os=-mint ;; esac # Decode aliases for certain CPU-COMPANY combinations. case $basic_machine in # Recognize the basic CPU types without company name. # Some are omitted here because they have special meanings below. 1750a | 580 \ | a29k \ | aarch64 | aarch64_be \ | alpha | alphaev[4-8] | alphaev56 | alphaev6[78] | alphapca5[67] \ | alpha64 | alpha64ev[4-8] | alpha64ev56 | alpha64ev6[78] | alpha64pca5[67] \ | am33_2.0 \ | arc | arceb \ | arm | arm[bl]e | arme[lb] | armv[2-8] | armv[3-8][lb] | armv7[arm] \ | avr | avr32 \ | be32 | be64 \ | bfin \ | c4x | c8051 | clipper \ | d10v | d30v | dlx | dsp16xx \ | e2k | epiphany \ | fido | fr30 | frv | ft32 \ | h8300 | h8500 | hppa | hppa1.[01] | hppa2.0 | hppa2.0[nw] | hppa64 \ | hexagon \ | i370 | i860 | i960 | ia64 \ | ip2k | iq2000 \ | k1om \ | le32 | le64 \ | lm32 \ | m32c | m32r | m32rle | m68000 | m68k | m88k \ | maxq | mb | microblaze | microblazeel | mcore | mep | metag \ | mips | mipsbe | mipseb | mipsel | mipsle \ | mips16 \ | mips64 | mips64el \ | mips64octeon | mips64octeonel \ | mips64orion | mips64orionel \ | mips64r5900 | mips64r5900el \ | mips64vr | mips64vrel \ | mips64vr4100 | mips64vr4100el \ | mips64vr4300 | mips64vr4300el \ | mips64vr5000 | mips64vr5000el \ | mips64vr5900 | mips64vr5900el \ | mipsisa32 | mipsisa32el \ | mipsisa32r2 | mipsisa32r2el \ | mipsisa32r6 | mipsisa32r6el \ | mipsisa64 | mipsisa64el \ | mipsisa64r2 | mipsisa64r2el \ | mipsisa64r6 | mipsisa64r6el \ | mipsisa64sb1 | mipsisa64sb1el \ | mipsisa64sr71k | mipsisa64sr71kel \ | mipsr5900 | mipsr5900el \ | mipstx39 | mipstx39el \ | mn10200 | mn10300 \ | moxie \ | mt \ | msp430 \ | nds32 | nds32le | nds32be \ | nios | nios2 | nios2eb | nios2el \ | ns16k | ns32k \ | open8 | or1k | or1knd | or32 \ | pdp10 | pdp11 | pj | pjl \ | powerpc | powerpc64 | powerpc64le | powerpcle | powerpcspe \ | pyramid \ | riscv32 | riscv64 \ | rl78 | rx \ | score \ | sh | sh[1234] | sh[24]a | sh[24]aeb | sh[23]e | sh[34]eb | sheb | shbe | shle | sh[1234]le | sh3ele \ | sh64 | sh64le \ | sparc | sparc64 | sparc64b | sparc64v | sparc86x | sparclet | sparclite \ | sparcv8 | sparcv9 | sparcv9b | sparcv9v \ | spu \ | tahoe | tic4x | tic54x | tic55x | tic6x | tic80 | tron \ | ubicom32 \ | v850 | v850e | v850e1 | v850e2 | v850es | v850e2v3 \ | visium \ | we32k \ | x86 | xc16x | xstormy16 | xtensa \ | z8k | z80) basic_machine=$basic_machine-unknown ;; c54x) basic_machine=tic54x-unknown ;; c55x) basic_machine=tic55x-unknown ;; c6x) basic_machine=tic6x-unknown ;; leon|leon[3-9]) basic_machine=sparc-$basic_machine ;; m6811 | m68hc11 | m6812 | m68hc12 | m68hcs12x | nvptx | picochip) basic_machine=$basic_machine-unknown os=-none ;; m88110 | m680[12346]0 | m683?2 | m68360 | m5200 | v70 | w65 | z8k) ;; ms1) basic_machine=mt-unknown ;; strongarm | thumb | xscale) basic_machine=arm-unknown ;; xgate) basic_machine=$basic_machine-unknown os=-none ;; xscaleeb) basic_machine=armeb-unknown ;; xscaleel) basic_machine=armel-unknown ;; # We use `pc' rather than `unknown' # because (1) that's what they normally are, and # (2) the word "unknown" tends to confuse beginning users. i*86 | x86_64) basic_machine=$basic_machine-pc ;; # Object if more than one company name word. *-*-*) echo Invalid configuration \`$1\': machine \`$basic_machine\' not recognized 1>&2 exit 1 ;; # Recognize the basic CPU types with company name. 580-* \ | a29k-* \ | aarch64-* | aarch64_be-* \ | alpha-* | alphaev[4-8]-* | alphaev56-* | alphaev6[78]-* \ | alpha64-* | alpha64ev[4-8]-* | alpha64ev56-* | alpha64ev6[78]-* \ | alphapca5[67]-* | alpha64pca5[67]-* | amd64-* | arc-* | arceb-* \ | arm-* | armbe-* | armle-* | armeb-* | armv*-* \ | avr-* | avr32-* \ | be32-* | be64-* \ | bfin-* | bs2000-* \ | c[123]* | c30-* | [cjt]90-* | c4x-* \ | c8051-* | clipper-* | craynv-* | cydra-* \ | d10v-* | d30v-* | dlx-* \ | e2k-* | elxsi-* \ | f30[01]-* | f700-* | fido-* | fr30-* | frv-* | fx80-* \ | h8300-* | h8500-* \ | hppa-* | hppa1.[01]-* | hppa2.0-* | hppa2.0[nw]-* | hppa64-* \ | hexagon-* \ | i*86-* | i860-* | i960-* | ia64-* \ | ip2k-* | iq2000-* \ | k1om-* \ | le32-* | le64-* \ | lm32-* \ | m32c-* | m32r-* | m32rle-* \ | m68000-* | m680[012346]0-* | m68360-* | m683?2-* | m68k-* \ | m88110-* | m88k-* | maxq-* | mcore-* | metag-* \ | microblaze-* | microblazeel-* \ | mips-* | mipsbe-* | mipseb-* | mipsel-* | mipsle-* \ | mips16-* \ | mips64-* | mips64el-* \ | mips64octeon-* | mips64octeonel-* \ | mips64orion-* | mips64orionel-* \ | mips64r5900-* | mips64r5900el-* \ | mips64vr-* | mips64vrel-* \ | mips64vr4100-* | mips64vr4100el-* \ | mips64vr4300-* | mips64vr4300el-* \ | mips64vr5000-* | mips64vr5000el-* \ | mips64vr5900-* | mips64vr5900el-* \ | mipsisa32-* | mipsisa32el-* \ | mipsisa32r2-* | mipsisa32r2el-* \ | mipsisa32r6-* | mipsisa32r6el-* \ | mipsisa64-* | mipsisa64el-* \ | mipsisa64r2-* | mipsisa64r2el-* \ | mipsisa64r6-* | mipsisa64r6el-* \ | mipsisa64sb1-* | mipsisa64sb1el-* \ | mipsisa64sr71k-* | mipsisa64sr71kel-* \ | mipsr5900-* | mipsr5900el-* \ | mipstx39-* | mipstx39el-* \ | mmix-* \ | mt-* \ | msp430-* \ | nds32-* | nds32le-* | nds32be-* \ | nios-* | nios2-* | nios2eb-* | nios2el-* \ | none-* | np1-* | ns16k-* | ns32k-* \ | open8-* \ | or1k*-* \ | orion-* \ | pdp10-* | pdp11-* | pj-* | pjl-* | pn-* | power-* \ | powerpc-* | powerpc64-* | powerpc64le-* | powerpcle-* | powerpcspe-* \ | pyramid-* \ | rl78-* | romp-* | rs6000-* | rx-* \ | sh-* | sh[1234]-* | sh[24]a-* | sh[24]aeb-* | sh[23]e-* | sh[34]eb-* | sheb-* | shbe-* \ | shle-* | sh[1234]le-* | sh3ele-* | sh64-* | sh64le-* \ | sparc-* | sparc64-* | sparc64b-* | sparc64v-* | sparc86x-* | sparclet-* \ | sparclite-* \ | sparcv8-* | sparcv9-* | sparcv9b-* | sparcv9v-* | sv1-* | sx?-* \ | tahoe-* \ | tic30-* | tic4x-* | tic54x-* | tic55x-* | tic6x-* | tic80-* \ | tile*-* \ | tron-* \ | ubicom32-* \ | v850-* | v850e-* | v850e1-* | v850es-* | v850e2-* | v850e2v3-* \ | vax-* \ | visium-* \ | we32k-* \ | x86-* | x86_64-* | xc16x-* | xps100-* \ | xstormy16-* | xtensa*-* \ | ymp-* \ | z8k-* | z80-*) ;; # Recognize the basic CPU types without company name, with glob match. xtensa*) basic_machine=$basic_machine-unknown ;; # Recognize the various machine names and aliases which stand # for a CPU type and a company and sometimes even an OS. 386bsd) basic_machine=i386-unknown os=-bsd ;; 3b1 | 7300 | 7300-att | att-7300 | pc7300 | safari | unixpc) basic_machine=m68000-att ;; 3b*) basic_machine=we32k-att ;; a29khif) basic_machine=a29k-amd os=-udi ;; abacus) basic_machine=abacus-unknown ;; adobe68k) basic_machine=m68010-adobe os=-scout ;; alliant | fx80) basic_machine=fx80-alliant ;; altos | altos3068) basic_machine=m68k-altos ;; am29k) basic_machine=a29k-none os=-bsd ;; amdahl) basic_machine=580-amdahl os=-sysv ;; amiga | amiga-*) basic_machine=m68k-unknown ;; amigaos | amigados) basic_machine=m68k-unknown os=-amigaos ;; amigaunix | amix) basic_machine=m68k-unknown os=-sysv4 ;; apollo68) basic_machine=m68k-apollo os=-sysv ;; apollo68bsd) basic_machine=m68k-apollo os=-bsd ;; aros) basic_machine=i386-pc os=-aros ;; asmjs) basic_machine=asmjs-unknown ;; aux) basic_machine=m68k-apple os=-aux ;; balance) basic_machine=ns32k-sequent os=-dynix ;; blackfin) basic_machine=bfin-unknown os=-linux ;; blackfin-*) basic_machine=bfin-`echo $basic_machine | sed 's/^[^-]*-//'` os=-linux ;; bluegene*) basic_machine=powerpc-ibm os=-cnk ;; c54x-*) basic_machine=tic54x-`echo $basic_machine | sed 's/^[^-]*-//'` ;; c55x-*) basic_machine=tic55x-`echo $basic_machine | sed 's/^[^-]*-//'` ;; c6x-*) basic_machine=tic6x-`echo $basic_machine | sed 's/^[^-]*-//'` ;; c90) basic_machine=c90-cray os=-unicos ;; cegcc) basic_machine=arm-unknown os=-cegcc ;; convex-c1) basic_machine=c1-convex os=-bsd ;; convex-c2) basic_machine=c2-convex os=-bsd ;; convex-c32) basic_machine=c32-convex os=-bsd ;; convex-c34) basic_machine=c34-convex os=-bsd ;; convex-c38) basic_machine=c38-convex os=-bsd ;; cray | j90) basic_machine=j90-cray os=-unicos ;; craynv) basic_machine=craynv-cray os=-unicosmp ;; cr16 | cr16-*) basic_machine=cr16-unknown os=-elf ;; crds | unos) basic_machine=m68k-crds ;; crisv32 | crisv32-* | etraxfs*) basic_machine=crisv32-axis ;; cris | cris-* | etrax*) basic_machine=cris-axis ;; crx) basic_machine=crx-unknown os=-elf ;; da30 | da30-*) basic_machine=m68k-da30 ;; decstation | decstation-3100 | pmax | pmax-* | pmin | dec3100 | decstatn) basic_machine=mips-dec ;; decsystem10* | dec10*) basic_machine=pdp10-dec os=-tops10 ;; decsystem20* | dec20*) basic_machine=pdp10-dec os=-tops20 ;; delta | 3300 | motorola-3300 | motorola-delta \ | 3300-motorola | delta-motorola) basic_machine=m68k-motorola ;; delta88) basic_machine=m88k-motorola os=-sysv3 ;; dicos) basic_machine=i686-pc os=-dicos ;; djgpp) basic_machine=i586-pc os=-msdosdjgpp ;; dpx20 | dpx20-*) basic_machine=rs6000-bull os=-bosx ;; dpx2* | dpx2*-bull) basic_machine=m68k-bull os=-sysv3 ;; ebmon29k) basic_machine=a29k-amd os=-ebmon ;; elxsi) basic_machine=elxsi-elxsi os=-bsd ;; encore | umax | mmax) basic_machine=ns32k-encore ;; es1800 | OSE68k | ose68k | ose | OSE) basic_machine=m68k-ericsson os=-ose ;; fx2800) basic_machine=i860-alliant ;; genix) basic_machine=ns32k-ns ;; gmicro) basic_machine=tron-gmicro os=-sysv ;; go32) basic_machine=i386-pc os=-go32 ;; h3050r* | hiux*) basic_machine=hppa1.1-hitachi os=-hiuxwe2 ;; h8300hms) basic_machine=h8300-hitachi os=-hms ;; h8300xray) basic_machine=h8300-hitachi os=-xray ;; h8500hms) basic_machine=h8500-hitachi os=-hms ;; harris) basic_machine=m88k-harris os=-sysv3 ;; hp300-*) basic_machine=m68k-hp ;; hp300bsd) basic_machine=m68k-hp os=-bsd ;; hp300hpux) basic_machine=m68k-hp os=-hpux ;; hp3k9[0-9][0-9] | hp9[0-9][0-9]) basic_machine=hppa1.0-hp ;; hp9k2[0-9][0-9] | hp9k31[0-9]) basic_machine=m68000-hp ;; hp9k3[2-9][0-9]) basic_machine=m68k-hp ;; hp9k6[0-9][0-9] | hp6[0-9][0-9]) basic_machine=hppa1.0-hp ;; hp9k7[0-79][0-9] | hp7[0-79][0-9]) basic_machine=hppa1.1-hp ;; hp9k78[0-9] | hp78[0-9]) # FIXME: really hppa2.0-hp basic_machine=hppa1.1-hp ;; hp9k8[67]1 | hp8[67]1 | hp9k80[24] | hp80[24] | hp9k8[78]9 | hp8[78]9 | hp9k893 | hp893) # FIXME: really hppa2.0-hp basic_machine=hppa1.1-hp ;; hp9k8[0-9][13679] | hp8[0-9][13679]) basic_machine=hppa1.1-hp ;; hp9k8[0-9][0-9] | hp8[0-9][0-9]) basic_machine=hppa1.0-hp ;; hppa-next) os=-nextstep3 ;; hppaosf) basic_machine=hppa1.1-hp os=-osf ;; hppro) basic_machine=hppa1.1-hp os=-proelf ;; i370-ibm* | ibm*) basic_machine=i370-ibm ;; i*86v32) basic_machine=`echo $1 | sed -e 's/86.*/86-pc/'` os=-sysv32 ;; i*86v4*) basic_machine=`echo $1 | sed -e 's/86.*/86-pc/'` os=-sysv4 ;; i*86v) basic_machine=`echo $1 | sed -e 's/86.*/86-pc/'` os=-sysv ;; i*86sol2) basic_machine=`echo $1 | sed -e 's/86.*/86-pc/'` os=-solaris2 ;; i386mach) basic_machine=i386-mach os=-mach ;; i386-vsta | vsta) basic_machine=i386-unknown os=-vsta ;; iris | iris4d) basic_machine=mips-sgi case $os in -irix*) ;; *) os=-irix4 ;; esac ;; isi68 | isi) basic_machine=m68k-isi os=-sysv ;; leon-*|leon[3-9]-*) basic_machine=sparc-`echo $basic_machine | sed 's/-.*//'` ;; m68knommu) basic_machine=m68k-unknown os=-linux ;; m68knommu-*) basic_machine=m68k-`echo $basic_machine | sed 's/^[^-]*-//'` os=-linux ;; m88k-omron*) basic_machine=m88k-omron ;; magnum | m3230) basic_machine=mips-mips os=-sysv ;; merlin) basic_machine=ns32k-utek os=-sysv ;; microblaze*) basic_machine=microblaze-xilinx ;; mingw64) basic_machine=x86_64-pc os=-mingw64 ;; mingw32) basic_machine=i686-pc os=-mingw32 ;; mingw32ce) basic_machine=arm-unknown os=-mingw32ce ;; miniframe) basic_machine=m68000-convergent ;; *mint | -mint[0-9]* | *MiNT | *MiNT[0-9]*) basic_machine=m68k-atari os=-mint ;; mips3*-*) basic_machine=`echo $basic_machine | sed -e 's/mips3/mips64/'` ;; mips3*) basic_machine=`echo $basic_machine | sed -e 's/mips3/mips64/'`-unknown ;; monitor) basic_machine=m68k-rom68k os=-coff ;; morphos) basic_machine=powerpc-unknown os=-morphos ;; moxiebox) basic_machine=moxie-unknown os=-moxiebox ;; msdos) basic_machine=i386-pc os=-msdos ;; ms1-*) basic_machine=`echo $basic_machine | sed -e 's/ms1-/mt-/'` ;; msys) basic_machine=i686-pc os=-msys ;; mvs) basic_machine=i370-ibm os=-mvs ;; nacl) basic_machine=le32-unknown os=-nacl ;; ncr3000) basic_machine=i486-ncr os=-sysv4 ;; netbsd386) basic_machine=i386-unknown os=-netbsd ;; netwinder) basic_machine=armv4l-rebel os=-linux ;; news | news700 | news800 | news900) basic_machine=m68k-sony os=-newsos ;; news1000) basic_machine=m68030-sony os=-newsos ;; news-3600 | risc-news) basic_machine=mips-sony os=-newsos ;; necv70) basic_machine=v70-nec os=-sysv ;; next | m*-next ) basic_machine=m68k-next case $os in -nextstep* ) ;; -ns2*) os=-nextstep2 ;; *) os=-nextstep3 ;; esac ;; nh3000) basic_machine=m68k-harris os=-cxux ;; nh[45]000) basic_machine=m88k-harris os=-cxux ;; nindy960) basic_machine=i960-intel os=-nindy ;; mon960) basic_machine=i960-intel os=-mon960 ;; nonstopux) basic_machine=mips-compaq os=-nonstopux ;; np1) basic_machine=np1-gould ;; neo-tandem) basic_machine=neo-tandem ;; nse-tandem) basic_machine=nse-tandem ;; nsr-tandem) basic_machine=nsr-tandem ;; op50n-* | op60c-*) basic_machine=hppa1.1-oki os=-proelf ;; openrisc | openrisc-*) basic_machine=or32-unknown ;; os400) basic_machine=powerpc-ibm os=-os400 ;; OSE68000 | ose68000) basic_machine=m68000-ericsson os=-ose ;; os68k) basic_machine=m68k-none os=-os68k ;; pa-hitachi) basic_machine=hppa1.1-hitachi os=-hiuxwe2 ;; paragon) basic_machine=i860-intel os=-osf ;; parisc) basic_machine=hppa-unknown os=-linux ;; parisc-*) basic_machine=hppa-`echo $basic_machine | sed 's/^[^-]*-//'` os=-linux ;; pbd) basic_machine=sparc-tti ;; pbb) basic_machine=m68k-tti ;; pc532 | pc532-*) basic_machine=ns32k-pc532 ;; pc98) basic_machine=i386-pc ;; pc98-*) basic_machine=i386-`echo $basic_machine | sed 's/^[^-]*-//'` ;; pentium | p5 | k5 | k6 | nexgen | viac3) basic_machine=i586-pc ;; pentiumpro | p6 | 6x86 | athlon | athlon_*) basic_machine=i686-pc ;; pentiumii | pentium2 | pentiumiii | pentium3) basic_machine=i686-pc ;; pentium4) basic_machine=i786-pc ;; pentium-* | p5-* | k5-* | k6-* | nexgen-* | viac3-*) basic_machine=i586-`echo $basic_machine | sed 's/^[^-]*-//'` ;; pentiumpro-* | p6-* | 6x86-* | athlon-*) basic_machine=i686-`echo $basic_machine | sed 's/^[^-]*-//'` ;; pentiumii-* | pentium2-* | pentiumiii-* | pentium3-*) basic_machine=i686-`echo $basic_machine | sed 's/^[^-]*-//'` ;; pentium4-*) basic_machine=i786-`echo $basic_machine | sed 's/^[^-]*-//'` ;; pn) basic_machine=pn-gould ;; power) basic_machine=power-ibm ;; ppc | ppcbe) basic_machine=powerpc-unknown ;; ppc-* | ppcbe-*) basic_machine=powerpc-`echo $basic_machine | sed 's/^[^-]*-//'` ;; ppcle | powerpclittle | ppc-le | powerpc-little) basic_machine=powerpcle-unknown ;; ppcle-* | powerpclittle-*) basic_machine=powerpcle-`echo $basic_machine | sed 's/^[^-]*-//'` ;; ppc64) basic_machine=powerpc64-unknown ;; ppc64-*) basic_machine=powerpc64-`echo $basic_machine | sed 's/^[^-]*-//'` ;; ppc64le | powerpc64little | ppc64-le | powerpc64-little) basic_machine=powerpc64le-unknown ;; ppc64le-* | powerpc64little-*) basic_machine=powerpc64le-`echo $basic_machine | sed 's/^[^-]*-//'` ;; ps2) basic_machine=i386-ibm ;; pw32) basic_machine=i586-unknown os=-pw32 ;; rdos | rdos64) basic_machine=x86_64-pc os=-rdos ;; rdos32) basic_machine=i386-pc os=-rdos ;; rom68k) basic_machine=m68k-rom68k os=-coff ;; rm[46]00) basic_machine=mips-siemens ;; rtpc | rtpc-*) basic_machine=romp-ibm ;; s390 | s390-*) basic_machine=s390-ibm ;; s390x | s390x-*) basic_machine=s390x-ibm ;; sa29200) basic_machine=a29k-amd os=-udi ;; sb1) basic_machine=mipsisa64sb1-unknown ;; sb1el) basic_machine=mipsisa64sb1el-unknown ;; sde) basic_machine=mipsisa32-sde os=-elf ;; sei) basic_machine=mips-sei os=-seiux ;; sequent) basic_machine=i386-sequent ;; sh) basic_machine=sh-hitachi os=-hms ;; sh5el) basic_machine=sh5le-unknown ;; sh64) basic_machine=sh64-unknown ;; sparclite-wrs | simso-wrs) basic_machine=sparclite-wrs os=-vxworks ;; sps7) basic_machine=m68k-bull os=-sysv2 ;; spur) basic_machine=spur-unknown ;; st2000) basic_machine=m68k-tandem ;; stratus) basic_machine=i860-stratus os=-sysv4 ;; strongarm-* | thumb-*) basic_machine=arm-`echo $basic_machine | sed 's/^[^-]*-//'` ;; sun2) basic_machine=m68000-sun ;; sun2os3) basic_machine=m68000-sun os=-sunos3 ;; sun2os4) basic_machine=m68000-sun os=-sunos4 ;; sun3os3) basic_machine=m68k-sun os=-sunos3 ;; sun3os4) basic_machine=m68k-sun os=-sunos4 ;; sun4os3) basic_machine=sparc-sun os=-sunos3 ;; sun4os4) basic_machine=sparc-sun os=-sunos4 ;; sun4sol2) basic_machine=sparc-sun os=-solaris2 ;; sun3 | sun3-*) basic_machine=m68k-sun ;; sun4) basic_machine=sparc-sun ;; sun386 | sun386i | roadrunner) basic_machine=i386-sun ;; sv1) basic_machine=sv1-cray os=-unicos ;; symmetry) basic_machine=i386-sequent os=-dynix ;; t3e) basic_machine=alphaev5-cray os=-unicos ;; t90) basic_machine=t90-cray os=-unicos ;; tile*) basic_machine=$basic_machine-unknown os=-linux-gnu ;; tx39) basic_machine=mipstx39-unknown ;; tx39el) basic_machine=mipstx39el-unknown ;; toad1) basic_machine=pdp10-xkl os=-tops20 ;; tower | tower-32) basic_machine=m68k-ncr ;; tpf) basic_machine=s390x-ibm os=-tpf ;; udi29k) basic_machine=a29k-amd os=-udi ;; ultra3) basic_machine=a29k-nyu os=-sym1 ;; v810 | necv810) basic_machine=v810-nec os=-none ;; vaxv) basic_machine=vax-dec os=-sysv ;; vms) basic_machine=vax-dec os=-vms ;; vpp*|vx|vx-*) basic_machine=f301-fujitsu ;; vxworks960) basic_machine=i960-wrs os=-vxworks ;; vxworks68) basic_machine=m68k-wrs os=-vxworks ;; vxworks29k) basic_machine=a29k-wrs os=-vxworks ;; w65*) basic_machine=w65-wdc os=-none ;; w89k-*) basic_machine=hppa1.1-winbond os=-proelf ;; xbox) basic_machine=i686-pc os=-mingw32 ;; xps | xps100) basic_machine=xps100-honeywell ;; xscale-* | xscalee[bl]-*) basic_machine=`echo $basic_machine | sed 's/^xscale/arm/'` ;; ymp) basic_machine=ymp-cray os=-unicos ;; z8k-*-coff) basic_machine=z8k-unknown os=-sim ;; z80-*-coff) basic_machine=z80-unknown os=-sim ;; none) basic_machine=none-none os=-none ;; # Here we handle the default manufacturer of certain CPU types. It is in # some cases the only manufacturer, in others, it is the most popular. w89k) basic_machine=hppa1.1-winbond ;; op50n) basic_machine=hppa1.1-oki ;; op60c) basic_machine=hppa1.1-oki ;; romp) basic_machine=romp-ibm ;; mmix) basic_machine=mmix-knuth ;; rs6000) basic_machine=rs6000-ibm ;; vax) basic_machine=vax-dec ;; pdp10) # there are many clones, so DEC is not a safe bet basic_machine=pdp10-unknown ;; pdp11) basic_machine=pdp11-dec ;; we32k) basic_machine=we32k-att ;; sh[1234] | sh[24]a | sh[24]aeb | sh[34]eb | sh[1234]le | sh[23]ele) basic_machine=sh-unknown ;; sparc | sparcv8 | sparcv9 | sparcv9b | sparcv9v) basic_machine=sparc-sun ;; cydra) basic_machine=cydra-cydrome ;; orion) basic_machine=orion-highlevel ;; orion105) basic_machine=clipper-highlevel ;; mac | mpw | mac-mpw) basic_machine=m68k-apple ;; pmac | pmac-mpw) basic_machine=powerpc-apple ;; *-unknown) # Make sure to match an already-canonicalized machine name. ;; *) echo Invalid configuration \`$1\': machine \`$basic_machine\' not recognized 1>&2 exit 1 ;; esac # Here we canonicalize certain aliases for manufacturers. case $basic_machine in *-digital*) basic_machine=`echo $basic_machine | sed 's/digital.*/dec/'` ;; *-commodore*) basic_machine=`echo $basic_machine | sed 's/commodore.*/cbm/'` ;; *) ;; esac # Decode manufacturer-specific aliases for certain operating systems. if [ x"$os" != x"" ] then case $os in # First match some system type aliases # that might get confused with valid system types. # -solaris* is a basic system type, with this one exception. -auroraux) os=-auroraux ;; -solaris1 | -solaris1.*) os=`echo $os | sed -e 's|solaris1|sunos4|'` ;; -solaris) os=-solaris2 ;; -svr4*) os=-sysv4 ;; -unixware*) os=-sysv4.2uw ;; -gnu/linux*) os=`echo $os | sed -e 's|gnu/linux|linux-gnu|'` ;; # First accept the basic system types. # The portable systems comes first. # Each alternative MUST END IN A *, to match a version number. # -sysv* is not here because it comes later, after sysvr4. -gnu* | -bsd* | -mach* | -minix* | -genix* | -ultrix* | -irix* \ | -*vms* | -sco* | -esix* | -isc* | -aix* | -cnk* | -sunos | -sunos[34]*\ | -hpux* | -unos* | -osf* | -luna* | -dgux* | -auroraux* | -solaris* \ | -sym* | -kopensolaris* | -plan9* \ | -amigaos* | -amigados* | -msdos* | -newsos* | -unicos* | -aof* \ | -aos* | -aros* | -cloudabi* \ | -nindy* | -vxsim* | -vxworks* | -ebmon* | -hms* | -mvs* \ | -clix* | -riscos* | -uniplus* | -iris* | -rtu* | -xenix* \ | -hiux* | -386bsd* | -knetbsd* | -mirbsd* | -netbsd* \ | -bitrig* | -openbsd* | -solidbsd* \ | -ekkobsd* | -kfreebsd* | -freebsd* | -riscix* | -lynxos* \ | -bosx* | -nextstep* | -cxux* | -aout* | -elf* | -oabi* \ | -ptx* | -coff* | -ecoff* | -winnt* | -domain* | -vsta* \ | -udi* | -eabi* | -lites* | -ieee* | -go32* | -aux* \ | -chorusos* | -chorusrdb* | -cegcc* \ | -cygwin* | -msys* | -pe* | -psos* | -moss* | -proelf* | -rtems* \ | -mingw32* | -mingw64* | -linux-gnu* | -linux-android* \ | -linux-newlib* | -linux-musl* | -linux-uclibc* \ | -uxpv* | -beos* | -mpeix* | -udk* | -moxiebox* \ | -interix* | -uwin* | -mks* | -rhapsody* | -darwin* | -opened* \ | -openstep* | -oskit* | -conix* | -pw32* | -nonstopux* \ | -storm-chaos* | -tops10* | -tenex* | -tops20* | -its* \ | -os2* | -vos* | -palmos* | -uclinux* | -nucleus* \ | -morphos* | -superux* | -rtmk* | -rtmk-nova* | -windiss* \ | -powermax* | -dnix* | -nx6 | -nx7 | -sei* | -dragonfly* \ | -skyos* | -haiku* | -rdos* | -toppers* | -drops* | -es* | -tirtos*) # Remember, each alternative MUST END IN *, to match a version number. ;; -qnx*) case $basic_machine in x86-* | i*86-*) ;; *) os=-nto$os ;; esac ;; -nto-qnx*) ;; -nto*) os=`echo $os | sed -e 's|nto|nto-qnx|'` ;; -sim | -es1800* | -hms* | -xray | -os68k* | -none* | -v88r* \ | -windows* | -osx | -abug | -netware* | -os9* | -beos* | -haiku* \ | -macos* | -mpw* | -magic* | -mmixware* | -mon960* | -lnews*) ;; -mac*) os=`echo $os | sed -e 's|mac|macos|'` ;; -linux-dietlibc) os=-linux-dietlibc ;; -linux*) os=`echo $os | sed -e 's|linux|linux-gnu|'` ;; -sunos5*) os=`echo $os | sed -e 's|sunos5|solaris2|'` ;; -sunos6*) os=`echo $os | sed -e 's|sunos6|solaris3|'` ;; -opened*) os=-openedition ;; -os400*) os=-os400 ;; -wince*) os=-wince ;; -osfrose*) os=-osfrose ;; -osf*) os=-osf ;; -utek*) os=-bsd ;; -dynix*) os=-bsd ;; -acis*) os=-aos ;; -atheos*) os=-atheos ;; -syllable*) os=-syllable ;; -386bsd) os=-bsd ;; -ctix* | -uts*) os=-sysv ;; -nova*) os=-rtmk-nova ;; -ns2 ) os=-nextstep2 ;; -nsk*) os=-nsk ;; # Preserve the version number of sinix5. -sinix5.*) os=`echo $os | sed -e 's|sinix|sysv|'` ;; -sinix*) os=-sysv4 ;; -tpf*) os=-tpf ;; -triton*) os=-sysv3 ;; -oss*) os=-sysv3 ;; -svr4) os=-sysv4 ;; -svr3) os=-sysv3 ;; -sysvr4) os=-sysv4 ;; # This must come after -sysvr4. -sysv*) ;; -ose*) os=-ose ;; -es1800*) os=-ose ;; -xenix) os=-xenix ;; -*mint | -mint[0-9]* | -*MiNT | -MiNT[0-9]*) os=-mint ;; -aros*) os=-aros ;; -zvmoe) os=-zvmoe ;; -dicos*) os=-dicos ;; -nacl*) ;; -none) ;; *) # Get rid of the `-' at the beginning of $os. os=`echo $os | sed 's/[^-]*-//'` echo Invalid configuration \`$1\': system \`$os\' not recognized 1>&2 exit 1 ;; esac else # Here we handle the default operating systems that come with various machines. # The value should be what the vendor currently ships out the door with their # machine or put another way, the most popular os provided with the machine. # Note that if you're going to try to match "-MANUFACTURER" here (say, # "-sun"), then you have to tell the case statement up towards the top # that MANUFACTURER isn't an operating system. Otherwise, code above # will signal an error saying that MANUFACTURER isn't an operating # system, and we'll never get to this point. case $basic_machine in score-*) os=-elf ;; spu-*) os=-elf ;; *-acorn) os=-riscix1.2 ;; arm*-rebel) os=-linux ;; arm*-semi) os=-aout ;; c4x-* | tic4x-*) os=-coff ;; c8051-*) os=-elf ;; hexagon-*) os=-elf ;; tic54x-*) os=-coff ;; tic55x-*) os=-coff ;; tic6x-*) os=-coff ;; # This must come before the *-dec entry. pdp10-*) os=-tops20 ;; pdp11-*) os=-none ;; *-dec | vax-*) os=-ultrix4.2 ;; m68*-apollo) os=-domain ;; i386-sun) os=-sunos4.0.2 ;; m68000-sun) os=-sunos3 ;; m68*-cisco) os=-aout ;; mep-*) os=-elf ;; mips*-cisco) os=-elf ;; mips*-*) os=-elf ;; or32-*) os=-coff ;; *-tti) # must be before sparc entry or we get the wrong os. os=-sysv3 ;; sparc-* | *-sun) os=-sunos4.1.1 ;; *-be) os=-beos ;; *-haiku) os=-haiku ;; *-ibm) os=-aix ;; *-knuth) os=-mmixware ;; *-wec) os=-proelf ;; *-winbond) os=-proelf ;; *-oki) os=-proelf ;; *-hp) os=-hpux ;; *-hitachi) os=-hiux ;; i860-* | *-att | *-ncr | *-altos | *-motorola | *-convergent) os=-sysv ;; *-cbm) os=-amigaos ;; *-dg) os=-dgux ;; *-dolphin) os=-sysv3 ;; m68k-ccur) os=-rtu ;; m88k-omron*) os=-luna ;; *-next ) os=-nextstep ;; *-sequent) os=-ptx ;; *-crds) os=-unos ;; *-ns) os=-genix ;; i370-*) os=-mvs ;; *-next) os=-nextstep3 ;; *-gould) os=-sysv ;; *-highlevel) os=-bsd ;; *-encore) os=-bsd ;; *-sgi) os=-irix ;; *-siemens) os=-sysv4 ;; *-masscomp) os=-rtu ;; f30[01]-fujitsu | f700-fujitsu) os=-uxpv ;; *-rom68k) os=-coff ;; *-*bug) os=-coff ;; *-apple) os=-macos ;; *-atari*) os=-mint ;; *) os=-none ;; esac fi # Here we handle the case where we know the os, and the CPU type, but not the # manufacturer. We pick the logical manufacturer. vendor=unknown case $basic_machine in *-unknown) case $os in -riscix*) vendor=acorn ;; -sunos*) vendor=sun ;; -cnk*|-aix*) vendor=ibm ;; -beos*) vendor=be ;; -hpux*) vendor=hp ;; -mpeix*) vendor=hp ;; -hiux*) vendor=hitachi ;; -unos*) vendor=crds ;; -dgux*) vendor=dg ;; -luna*) vendor=omron ;; -genix*) vendor=ns ;; -mvs* | -opened*) vendor=ibm ;; -os400*) vendor=ibm ;; -ptx*) vendor=sequent ;; -tpf*) vendor=ibm ;; -vxsim* | -vxworks* | -windiss*) vendor=wrs ;; -aux*) vendor=apple ;; -hms*) vendor=hitachi ;; -mpw* | -macos*) vendor=apple ;; -*mint | -mint[0-9]* | -*MiNT | -MiNT[0-9]*) vendor=atari ;; -vos*) vendor=stratus ;; esac basic_machine=`echo $basic_machine | sed "s/unknown/$vendor/"` ;; esac echo $basic_machine$os exit # Local variables: # eval: (add-hook 'write-file-hooks 'time-stamp) # time-stamp-start: "timestamp='" # time-stamp-format: "%:y-%02m-%02d" # time-stamp-end: "'" # End: xrdp-0.9.5/librfxcodec/src/000755 001751 001751 00000000000 13220731017 015471 5ustar00metameta000000 000000 xrdp-0.9.5/librfxcodec/ltmain.sh000644 001751 001751 00001170771 13220730751 016544 0ustar00metameta000000 000000 #! /bin/sh ## DO NOT EDIT - This file generated from ./build-aux/ltmain.in ## by inline-source v2014-01-03.01 # libtool (GNU libtool) 2.4.6 # Provide generalized library-building support services. # Written by Gordon Matzigkeit , 1996 # Copyright (C) 1996-2015 Free Software Foundation, Inc. # This is free software; see the source for copying conditions. There is NO # warranty; not even for MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. # GNU Libtool 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 2 of the License, or # (at your option) any later version. # # As a special exception to the GNU General Public License, # if you distribute this file as part of a program or library that # is built using GNU Libtool, you may include this file under the # same distribution terms that you use for the rest of that program. # # GNU Libtool 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. # # You should have received a copy of the GNU General Public License # along with this program. If not, see . PROGRAM=libtool PACKAGE=libtool VERSION=2.4.6 package_revision=2.4.6 ## ------ ## ## Usage. ## ## ------ ## # Run './libtool --help' for help with using this script from the # command line. ## ------------------------------- ## ## User overridable command paths. ## ## ------------------------------- ## # After configure completes, it has a better idea of some of the # shell tools we need than the defaults used by the functions shared # with bootstrap, so set those here where they can still be over- # ridden by the user, but otherwise take precedence. : ${AUTOCONF="autoconf"} : ${AUTOMAKE="automake"} ## -------------------------- ## ## Source external libraries. ## ## -------------------------- ## # Much of our low-level functionality needs to be sourced from external # libraries, which are installed to $pkgauxdir. # Set a version string for this script. scriptversion=2015-01-20.17; # UTC # General shell script boiler plate, and helper functions. # Written by Gary V. Vaughan, 2004 # Copyright (C) 2004-2015 Free Software Foundation, Inc. # This is free software; see the source for copying conditions. There is NO # warranty; not even for MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. # 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. # As a special exception to the GNU General Public License, if you distribute # this file as part of a program or library that is built using GNU Libtool, # you may include this file under the same distribution terms that you use # for the rest of that program. # This program is distributed in the hope that it will be useful, # but WITHOUT ANY WARRANTY; without even the implied warranty of # MERCHANTABILITY or FITNES FOR A PARTICULAR PURPOSE. See the GNU # General Public License for more details. # You should have received a copy of the GNU General Public License # along with this program. If not, see . # Please report bugs or propose patches to gary@gnu.org. ## ------ ## ## Usage. ## ## ------ ## # Evaluate this file near the top of your script to gain access to # the functions and variables defined here: # # . `echo "$0" | ${SED-sed} 's|[^/]*$||'`/build-aux/funclib.sh # # If you need to override any of the default environment variable # settings, do that before evaluating this file. ## -------------------- ## ## Shell normalisation. ## ## -------------------- ## # Some shells need a little help to be as Bourne compatible as possible. # Before doing anything else, make sure all that help has been provided! DUALCASE=1; export DUALCASE # for MKS sh if test -n "${ZSH_VERSION+set}" && (emulate sh) >/dev/null 2>&1; then : emulate sh NULLCMD=: # Pre-4.2 versions of Zsh do word splitting on ${1+"$@"}, which # is contrary to our usage. Disable this feature. alias -g '${1+"$@"}'='"$@"' setopt NO_GLOB_SUBST else case `(set -o) 2>/dev/null` in *posix*) set -o posix ;; esac fi # NLS nuisances: We save the old values in case they are required later. _G_user_locale= _G_safe_locale= for _G_var in LANG LANGUAGE LC_ALL LC_CTYPE LC_COLLATE LC_MESSAGES do eval "if test set = \"\${$_G_var+set}\"; then save_$_G_var=\$$_G_var $_G_var=C export $_G_var _G_user_locale=\"$_G_var=\\\$save_\$_G_var; \$_G_user_locale\" _G_safe_locale=\"$_G_var=C; \$_G_safe_locale\" fi" done # CDPATH. (unset CDPATH) >/dev/null 2>&1 && unset CDPATH # Make sure IFS has a sensible default sp=' ' nl=' ' IFS="$sp $nl" # There are apparently some retarded systems that use ';' as a PATH separator! if test "${PATH_SEPARATOR+set}" != set; then PATH_SEPARATOR=: (PATH='/bin;/bin'; FPATH=$PATH; sh -c :) >/dev/null 2>&1 && { (PATH='/bin:/bin'; FPATH=$PATH; sh -c :) >/dev/null 2>&1 || PATH_SEPARATOR=';' } fi ## ------------------------- ## ## Locate command utilities. ## ## ------------------------- ## # func_executable_p FILE # ---------------------- # Check that FILE is an executable regular file. func_executable_p () { test -f "$1" && test -x "$1" } # func_path_progs PROGS_LIST CHECK_FUNC [PATH] # -------------------------------------------- # Search for either a program that responds to --version with output # containing "GNU", or else returned by CHECK_FUNC otherwise, by # trying all the directories in PATH with each of the elements of # PROGS_LIST. # # CHECK_FUNC should accept the path to a candidate program, and # set $func_check_prog_result if it truncates its output less than # $_G_path_prog_max characters. func_path_progs () { _G_progs_list=$1 _G_check_func=$2 _G_PATH=${3-"$PATH"} _G_path_prog_max=0 _G_path_prog_found=false _G_save_IFS=$IFS; IFS=${PATH_SEPARATOR-:} for _G_dir in $_G_PATH; do IFS=$_G_save_IFS test -z "$_G_dir" && _G_dir=. for _G_prog_name in $_G_progs_list; do for _exeext in '' .EXE; do _G_path_prog=$_G_dir/$_G_prog_name$_exeext func_executable_p "$_G_path_prog" || continue case `"$_G_path_prog" --version 2>&1` in *GNU*) func_path_progs_result=$_G_path_prog _G_path_prog_found=: ;; *) $_G_check_func $_G_path_prog func_path_progs_result=$func_check_prog_result ;; esac $_G_path_prog_found && break 3 done done done IFS=$_G_save_IFS test -z "$func_path_progs_result" && { echo "no acceptable sed could be found in \$PATH" >&2 exit 1 } } # We want to be able to use the functions in this file before configure # has figured out where the best binaries are kept, which means we have # to search for them ourselves - except when the results are already set # where we skip the searches. # Unless the user overrides by setting SED, search the path for either GNU # sed, or the sed that truncates its output the least. test -z "$SED" && { _G_sed_script=s/aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa/bbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbb/ for _G_i in 1 2 3 4 5 6 7; do _G_sed_script=$_G_sed_script$nl$_G_sed_script done echo "$_G_sed_script" 2>/dev/null | sed 99q >conftest.sed _G_sed_script= func_check_prog_sed () { _G_path_prog=$1 _G_count=0 printf 0123456789 >conftest.in while : do cat conftest.in conftest.in >conftest.tmp mv conftest.tmp conftest.in cp conftest.in conftest.nl echo '' >> conftest.nl "$_G_path_prog" -f conftest.sed conftest.out 2>/dev/null || break diff conftest.out conftest.nl >/dev/null 2>&1 || break _G_count=`expr $_G_count + 1` if test "$_G_count" -gt "$_G_path_prog_max"; then # Best one so far, save it but keep looking for a better one func_check_prog_result=$_G_path_prog _G_path_prog_max=$_G_count fi # 10*(2^10) chars as input seems more than enough test 10 -lt "$_G_count" && break done rm -f conftest.in conftest.tmp conftest.nl conftest.out } func_path_progs "sed gsed" func_check_prog_sed $PATH:/usr/xpg4/bin rm -f conftest.sed SED=$func_path_progs_result } # Unless the user overrides by setting GREP, search the path for either GNU # grep, or the grep that truncates its output the least. test -z "$GREP" && { func_check_prog_grep () { _G_path_prog=$1 _G_count=0 _G_path_prog_max=0 printf 0123456789 >conftest.in while : do cat conftest.in conftest.in >conftest.tmp mv conftest.tmp conftest.in cp conftest.in conftest.nl echo 'GREP' >> conftest.nl "$_G_path_prog" -e 'GREP$' -e '-(cannot match)-' conftest.out 2>/dev/null || break diff conftest.out conftest.nl >/dev/null 2>&1 || break _G_count=`expr $_G_count + 1` if test "$_G_count" -gt "$_G_path_prog_max"; then # Best one so far, save it but keep looking for a better one func_check_prog_result=$_G_path_prog _G_path_prog_max=$_G_count fi # 10*(2^10) chars as input seems more than enough test 10 -lt "$_G_count" && break done rm -f conftest.in conftest.tmp conftest.nl conftest.out } func_path_progs "grep ggrep" func_check_prog_grep $PATH:/usr/xpg4/bin GREP=$func_path_progs_result } ## ------------------------------- ## ## User overridable command paths. ## ## ------------------------------- ## # All uppercase variable names are used for environment variables. These # variables can be overridden by the user before calling a script that # uses them if a suitable command of that name is not already available # in the command search PATH. : ${CP="cp -f"} : ${ECHO="printf %s\n"} : ${EGREP="$GREP -E"} : ${FGREP="$GREP -F"} : ${LN_S="ln -s"} : ${MAKE="make"} : ${MKDIR="mkdir"} : ${MV="mv -f"} : ${RM="rm -f"} : ${SHELL="${CONFIG_SHELL-/bin/sh}"} ## -------------------- ## ## Useful sed snippets. ## ## -------------------- ## sed_dirname='s|/[^/]*$||' sed_basename='s|^.*/||' # Sed substitution that helps us do robust quoting. It backslashifies # metacharacters that are still active within double-quoted strings. sed_quote_subst='s|\([`"$\\]\)|\\\1|g' # Same as above, but do not quote variable references. sed_double_quote_subst='s/\(["`\\]\)/\\\1/g' # Sed substitution that turns a string into a regex matching for the # string literally. sed_make_literal_regex='s|[].[^$\\*\/]|\\&|g' # Sed substitution that converts a w32 file name or path # that contains forward slashes, into one that contains # (escaped) backslashes. A very naive implementation. sed_naive_backslashify='s|\\\\*|\\|g;s|/|\\|g;s|\\|\\\\|g' # Re-'\' parameter expansions in output of sed_double_quote_subst that # were '\'-ed in input to the same. If an odd number of '\' preceded a # '$' in input to sed_double_quote_subst, that '$' was protected from # expansion. Since each input '\' is now two '\'s, look for any number # of runs of four '\'s followed by two '\'s and then a '$'. '\' that '$'. _G_bs='\\' _G_bs2='\\\\' _G_bs4='\\\\\\\\' _G_dollar='\$' sed_double_backslash="\ s/$_G_bs4/&\\ /g s/^$_G_bs2$_G_dollar/$_G_bs&/ s/\\([^$_G_bs]\\)$_G_bs2$_G_dollar/\\1$_G_bs2$_G_bs$_G_dollar/g s/\n//g" ## ----------------- ## ## Global variables. ## ## ----------------- ## # Except for the global variables explicitly listed below, the following # functions in the '^func_' namespace, and the '^require_' namespace # variables initialised in the 'Resource management' section, sourcing # this file will not pollute your global namespace with anything # else. There's no portable way to scope variables in Bourne shell # though, so actually running these functions will sometimes place # results into a variable named after the function, and often use # temporary variables in the '^_G_' namespace. If you are careful to # avoid using those namespaces casually in your sourcing script, things # should continue to work as you expect. And, of course, you can freely # overwrite any of the functions or variables defined here before # calling anything to customize them. EXIT_SUCCESS=0 EXIT_FAILURE=1 EXIT_MISMATCH=63 # $? = 63 is used to indicate version mismatch to missing. EXIT_SKIP=77 # $? = 77 is used to indicate a skipped test to automake. # Allow overriding, eg assuming that you follow the convention of # putting '$debug_cmd' at the start of all your functions, you can get # bash to show function call trace with: # # debug_cmd='eval echo "${FUNCNAME[0]} $*" >&2' bash your-script-name debug_cmd=${debug_cmd-":"} exit_cmd=: # By convention, finish your script with: # # exit $exit_status # # so that you can set exit_status to non-zero if you want to indicate # something went wrong during execution without actually bailing out at # the point of failure. exit_status=$EXIT_SUCCESS # Work around backward compatibility issue on IRIX 6.5. On IRIX 6.4+, sh # is ksh but when the shell is invoked as "sh" and the current value of # the _XPG environment variable is not equal to 1 (one), the special # positional parameter $0, within a function call, is the name of the # function. progpath=$0 # The name of this program. progname=`$ECHO "$progpath" |$SED "$sed_basename"` # Make sure we have an absolute progpath for reexecution: case $progpath in [\\/]*|[A-Za-z]:\\*) ;; *[\\/]*) progdir=`$ECHO "$progpath" |$SED "$sed_dirname"` progdir=`cd "$progdir" && pwd` progpath=$progdir/$progname ;; *) _G_IFS=$IFS IFS=${PATH_SEPARATOR-:} for progdir in $PATH; do IFS=$_G_IFS test -x "$progdir/$progname" && break done IFS=$_G_IFS test -n "$progdir" || progdir=`pwd` progpath=$progdir/$progname ;; esac ## ----------------- ## ## Standard options. ## ## ----------------- ## # The following options affect the operation of the functions defined # below, and should be set appropriately depending on run-time para- # meters passed on the command line. opt_dry_run=false opt_quiet=false opt_verbose=false # Categories 'all' and 'none' are always available. Append any others # you will pass as the first argument to func_warning from your own # code. warning_categories= # By default, display warnings according to 'opt_warning_types'. Set # 'warning_func' to ':' to elide all warnings, or func_fatal_error to # treat the next displayed warning as a fatal error. warning_func=func_warn_and_continue # Set to 'all' to display all warnings, 'none' to suppress all # warnings, or a space delimited list of some subset of # 'warning_categories' to display only the listed warnings. opt_warning_types=all ## -------------------- ## ## Resource management. ## ## -------------------- ## # This section contains definitions for functions that each ensure a # particular resource (a file, or a non-empty configuration variable for # example) is available, and if appropriate to extract default values # from pertinent package files. Call them using their associated # 'require_*' variable to ensure that they are executed, at most, once. # # It's entirely deliberate that calling these functions can set # variables that don't obey the namespace limitations obeyed by the rest # of this file, in order that that they be as useful as possible to # callers. # require_term_colors # ------------------- # Allow display of bold text on terminals that support it. require_term_colors=func_require_term_colors func_require_term_colors () { $debug_cmd test -t 1 && { # COLORTERM and USE_ANSI_COLORS environment variables take # precedence, because most terminfo databases neglect to describe # whether color sequences are supported. test -n "${COLORTERM+set}" && : ${USE_ANSI_COLORS="1"} if test 1 = "$USE_ANSI_COLORS"; then # Standard ANSI escape sequences tc_reset='' tc_bold=''; tc_standout='' tc_red=''; tc_green='' tc_blue=''; tc_cyan='' else # Otherwise trust the terminfo database after all. test -n "`tput sgr0 2>/dev/null`" && { tc_reset=`tput sgr0` test -n "`tput bold 2>/dev/null`" && tc_bold=`tput bold` tc_standout=$tc_bold test -n "`tput smso 2>/dev/null`" && tc_standout=`tput smso` test -n "`tput setaf 1 2>/dev/null`" && tc_red=`tput setaf 1` test -n "`tput setaf 2 2>/dev/null`" && tc_green=`tput setaf 2` test -n "`tput setaf 4 2>/dev/null`" && tc_blue=`tput setaf 4` test -n "`tput setaf 5 2>/dev/null`" && tc_cyan=`tput setaf 5` } fi } require_term_colors=: } ## ----------------- ## ## Function library. ## ## ----------------- ## # This section contains a variety of useful functions to call in your # scripts. Take note of the portable wrappers for features provided by # some modern shells, which will fall back to slower equivalents on # less featureful shells. # func_append VAR VALUE # --------------------- # Append VALUE onto the existing contents of VAR. # We should try to minimise forks, especially on Windows where they are # unreasonably slow, so skip the feature probes when bash or zsh are # being used: if test set = "${BASH_VERSION+set}${ZSH_VERSION+set}"; then : ${_G_HAVE_ARITH_OP="yes"} : ${_G_HAVE_XSI_OPS="yes"} # The += operator was introduced in bash 3.1 case $BASH_VERSION in [12].* | 3.0 | 3.0*) ;; *) : ${_G_HAVE_PLUSEQ_OP="yes"} ;; esac fi # _G_HAVE_PLUSEQ_OP # Can be empty, in which case the shell is probed, "yes" if += is # useable or anything else if it does not work. test -z "$_G_HAVE_PLUSEQ_OP" \ && (eval 'x=a; x+=" b"; test "a b" = "$x"') 2>/dev/null \ && _G_HAVE_PLUSEQ_OP=yes if test yes = "$_G_HAVE_PLUSEQ_OP" then # This is an XSI compatible shell, allowing a faster implementation... eval 'func_append () { $debug_cmd eval "$1+=\$2" }' else # ...otherwise fall back to using expr, which is often a shell builtin. func_append () { $debug_cmd eval "$1=\$$1\$2" } fi # func_append_quoted VAR VALUE # ---------------------------- # Quote VALUE and append to the end of shell variable VAR, separated # by a space. if test yes = "$_G_HAVE_PLUSEQ_OP"; then eval 'func_append_quoted () { $debug_cmd func_quote_for_eval "$2" eval "$1+=\\ \$func_quote_for_eval_result" }' else func_append_quoted () { $debug_cmd func_quote_for_eval "$2" eval "$1=\$$1\\ \$func_quote_for_eval_result" } fi # func_append_uniq VAR VALUE # -------------------------- # Append unique VALUE onto the existing contents of VAR, assuming # entries are delimited by the first character of VALUE. For example: # # func_append_uniq options " --another-option option-argument" # # will only append to $options if " --another-option option-argument " # is not already present somewhere in $options already (note spaces at # each end implied by leading space in second argument). func_append_uniq () { $debug_cmd eval _G_current_value='`$ECHO $'$1'`' _G_delim=`expr "$2" : '\(.\)'` case $_G_delim$_G_current_value$_G_delim in *"$2$_G_delim"*) ;; *) func_append "$@" ;; esac } # func_arith TERM... # ------------------ # Set func_arith_result to the result of evaluating TERMs. test -z "$_G_HAVE_ARITH_OP" \ && (eval 'test 2 = $(( 1 + 1 ))') 2>/dev/null \ && _G_HAVE_ARITH_OP=yes if test yes = "$_G_HAVE_ARITH_OP"; then eval 'func_arith () { $debug_cmd func_arith_result=$(( $* )) }' else func_arith () { $debug_cmd func_arith_result=`expr "$@"` } fi # func_basename FILE # ------------------ # Set func_basename_result to FILE with everything up to and including # the last / stripped. if test yes = "$_G_HAVE_XSI_OPS"; then # If this shell supports suffix pattern removal, then use it to avoid # forking. Hide the definitions single quotes in case the shell chokes # on unsupported syntax... _b='func_basename_result=${1##*/}' _d='case $1 in */*) func_dirname_result=${1%/*}$2 ;; * ) func_dirname_result=$3 ;; esac' else # ...otherwise fall back to using sed. _b='func_basename_result=`$ECHO "$1" |$SED "$sed_basename"`' _d='func_dirname_result=`$ECHO "$1" |$SED "$sed_dirname"` if test "X$func_dirname_result" = "X$1"; then func_dirname_result=$3 else func_append func_dirname_result "$2" fi' fi eval 'func_basename () { $debug_cmd '"$_b"' }' # func_dirname FILE APPEND NONDIR_REPLACEMENT # ------------------------------------------- # Compute the dirname of FILE. If nonempty, add APPEND to the result, # otherwise set result to NONDIR_REPLACEMENT. eval 'func_dirname () { $debug_cmd '"$_d"' }' # func_dirname_and_basename FILE APPEND NONDIR_REPLACEMENT # -------------------------------------------------------- # Perform func_basename and func_dirname in a single function # call: # dirname: Compute the dirname of FILE. If nonempty, # add APPEND to the result, otherwise set result # to NONDIR_REPLACEMENT. # value returned in "$func_dirname_result" # basename: Compute filename of FILE. # value retuned in "$func_basename_result" # For efficiency, we do not delegate to the functions above but instead # duplicate the functionality here. eval 'func_dirname_and_basename () { $debug_cmd '"$_b"' '"$_d"' }' # func_echo ARG... # ---------------- # Echo program name prefixed message. func_echo () { $debug_cmd _G_message=$* func_echo_IFS=$IFS IFS=$nl for _G_line in $_G_message; do IFS=$func_echo_IFS $ECHO "$progname: $_G_line" done IFS=$func_echo_IFS } # func_echo_all ARG... # -------------------- # Invoke $ECHO with all args, space-separated. func_echo_all () { $ECHO "$*" } # func_echo_infix_1 INFIX ARG... # ------------------------------ # Echo program name, followed by INFIX on the first line, with any # additional lines not showing INFIX. func_echo_infix_1 () { $debug_cmd $require_term_colors _G_infix=$1; shift _G_indent=$_G_infix _G_prefix="$progname: $_G_infix: " _G_message=$* # Strip color escape sequences before counting printable length for _G_tc in "$tc_reset" "$tc_bold" "$tc_standout" "$tc_red" "$tc_green" "$tc_blue" "$tc_cyan" do test -n "$_G_tc" && { _G_esc_tc=`$ECHO "$_G_tc" | $SED "$sed_make_literal_regex"` _G_indent=`$ECHO "$_G_indent" | $SED "s|$_G_esc_tc||g"` } done _G_indent="$progname: "`echo "$_G_indent" | $SED 's|.| |g'`" " ## exclude from sc_prohibit_nested_quotes func_echo_infix_1_IFS=$IFS IFS=$nl for _G_line in $_G_message; do IFS=$func_echo_infix_1_IFS $ECHO "$_G_prefix$tc_bold$_G_line$tc_reset" >&2 _G_prefix=$_G_indent done IFS=$func_echo_infix_1_IFS } # func_error ARG... # ----------------- # Echo program name prefixed message to standard error. func_error () { $debug_cmd $require_term_colors func_echo_infix_1 " $tc_standout${tc_red}error$tc_reset" "$*" >&2 } # func_fatal_error ARG... # ----------------------- # Echo program name prefixed message to standard error, and exit. func_fatal_error () { $debug_cmd func_error "$*" exit $EXIT_FAILURE } # func_grep EXPRESSION FILENAME # ----------------------------- # Check whether EXPRESSION matches any line of FILENAME, without output. func_grep () { $debug_cmd $GREP "$1" "$2" >/dev/null 2>&1 } # func_len STRING # --------------- # Set func_len_result to the length of STRING. STRING may not # start with a hyphen. test -z "$_G_HAVE_XSI_OPS" \ && (eval 'x=a/b/c; test 5aa/bb/cc = "${#x}${x%%/*}${x%/*}${x#*/}${x##*/}"') 2>/dev/null \ && _G_HAVE_XSI_OPS=yes if test yes = "$_G_HAVE_XSI_OPS"; then eval 'func_len () { $debug_cmd func_len_result=${#1} }' else func_len () { $debug_cmd func_len_result=`expr "$1" : ".*" 2>/dev/null || echo $max_cmd_len` } fi # func_mkdir_p DIRECTORY-PATH # --------------------------- # Make sure the entire path to DIRECTORY-PATH is available. func_mkdir_p () { $debug_cmd _G_directory_path=$1 _G_dir_list= if test -n "$_G_directory_path" && test : != "$opt_dry_run"; then # Protect directory names starting with '-' case $_G_directory_path in -*) _G_directory_path=./$_G_directory_path ;; esac # While some portion of DIR does not yet exist... while test ! -d "$_G_directory_path"; do # ...make a list in topmost first order. Use a colon delimited # list incase some portion of path contains whitespace. _G_dir_list=$_G_directory_path:$_G_dir_list # If the last portion added has no slash in it, the list is done case $_G_directory_path in */*) ;; *) break ;; esac # ...otherwise throw away the child directory and loop _G_directory_path=`$ECHO "$_G_directory_path" | $SED -e "$sed_dirname"` done _G_dir_list=`$ECHO "$_G_dir_list" | $SED 's|:*$||'` func_mkdir_p_IFS=$IFS; IFS=: for _G_dir in $_G_dir_list; do IFS=$func_mkdir_p_IFS # mkdir can fail with a 'File exist' error if two processes # try to create one of the directories concurrently. Don't # stop in that case! $MKDIR "$_G_dir" 2>/dev/null || : done IFS=$func_mkdir_p_IFS # Bail out if we (or some other process) failed to create a directory. test -d "$_G_directory_path" || \ func_fatal_error "Failed to create '$1'" fi } # func_mktempdir [BASENAME] # ------------------------- # Make a temporary directory that won't clash with other running # libtool processes, and avoids race conditions if possible. If # given, BASENAME is the basename for that directory. func_mktempdir () { $debug_cmd _G_template=${TMPDIR-/tmp}/${1-$progname} if test : = "$opt_dry_run"; then # Return a directory name, but don't create it in dry-run mode _G_tmpdir=$_G_template-$$ else # If mktemp works, use that first and foremost _G_tmpdir=`mktemp -d "$_G_template-XXXXXXXX" 2>/dev/null` if test ! -d "$_G_tmpdir"; then # Failing that, at least try and use $RANDOM to avoid a race _G_tmpdir=$_G_template-${RANDOM-0}$$ func_mktempdir_umask=`umask` umask 0077 $MKDIR "$_G_tmpdir" umask $func_mktempdir_umask fi # If we're not in dry-run mode, bomb out on failure test -d "$_G_tmpdir" || \ func_fatal_error "cannot create temporary directory '$_G_tmpdir'" fi $ECHO "$_G_tmpdir" } # func_normal_abspath PATH # ------------------------ # Remove doubled-up and trailing slashes, "." path components, # and cancel out any ".." path components in PATH after making # it an absolute path. func_normal_abspath () { $debug_cmd # These SED scripts presuppose an absolute path with a trailing slash. _G_pathcar='s|^/\([^/]*\).*$|\1|' _G_pathcdr='s|^/[^/]*||' _G_removedotparts=':dotsl s|/\./|/|g t dotsl s|/\.$|/|' _G_collapseslashes='s|/\{1,\}|/|g' _G_finalslash='s|/*$|/|' # Start from root dir and reassemble the path. func_normal_abspath_result= func_normal_abspath_tpath=$1 func_normal_abspath_altnamespace= case $func_normal_abspath_tpath in "") # Empty path, that just means $cwd. func_stripname '' '/' "`pwd`" func_normal_abspath_result=$func_stripname_result return ;; # The next three entries are used to spot a run of precisely # two leading slashes without using negated character classes; # we take advantage of case's first-match behaviour. ///*) # Unusual form of absolute path, do nothing. ;; //*) # Not necessarily an ordinary path; POSIX reserves leading '//' # and for example Cygwin uses it to access remote file shares # over CIFS/SMB, so we conserve a leading double slash if found. func_normal_abspath_altnamespace=/ ;; /*) # Absolute path, do nothing. ;; *) # Relative path, prepend $cwd. func_normal_abspath_tpath=`pwd`/$func_normal_abspath_tpath ;; esac # Cancel out all the simple stuff to save iterations. We also want # the path to end with a slash for ease of parsing, so make sure # there is one (and only one) here. func_normal_abspath_tpath=`$ECHO "$func_normal_abspath_tpath" | $SED \ -e "$_G_removedotparts" -e "$_G_collapseslashes" -e "$_G_finalslash"` while :; do # Processed it all yet? if test / = "$func_normal_abspath_tpath"; then # If we ascended to the root using ".." the result may be empty now. if test -z "$func_normal_abspath_result"; then func_normal_abspath_result=/ fi break fi func_normal_abspath_tcomponent=`$ECHO "$func_normal_abspath_tpath" | $SED \ -e "$_G_pathcar"` func_normal_abspath_tpath=`$ECHO "$func_normal_abspath_tpath" | $SED \ -e "$_G_pathcdr"` # Figure out what to do with it case $func_normal_abspath_tcomponent in "") # Trailing empty path component, ignore it. ;; ..) # Parent dir; strip last assembled component from result. func_dirname "$func_normal_abspath_result" func_normal_abspath_result=$func_dirname_result ;; *) # Actual path component, append it. func_append func_normal_abspath_result "/$func_normal_abspath_tcomponent" ;; esac done # Restore leading double-slash if one was found on entry. func_normal_abspath_result=$func_normal_abspath_altnamespace$func_normal_abspath_result } # func_notquiet ARG... # -------------------- # Echo program name prefixed message only when not in quiet mode. func_notquiet () { $debug_cmd $opt_quiet || func_echo ${1+"$@"} # A bug in bash halts the script if the last line of a function # fails when set -e is in force, so we need another command to # work around that: : } # func_relative_path SRCDIR DSTDIR # -------------------------------- # Set func_relative_path_result to the relative path from SRCDIR to DSTDIR. func_relative_path () { $debug_cmd func_relative_path_result= func_normal_abspath "$1" func_relative_path_tlibdir=$func_normal_abspath_result func_normal_abspath "$2" func_relative_path_tbindir=$func_normal_abspath_result # Ascend the tree starting from libdir while :; do # check if we have found a prefix of bindir case $func_relative_path_tbindir in $func_relative_path_tlibdir) # found an exact match func_relative_path_tcancelled= break ;; $func_relative_path_tlibdir*) # found a matching prefix func_stripname "$func_relative_path_tlibdir" '' "$func_relative_path_tbindir" func_relative_path_tcancelled=$func_stripname_result if test -z "$func_relative_path_result"; then func_relative_path_result=. fi break ;; *) func_dirname $func_relative_path_tlibdir func_relative_path_tlibdir=$func_dirname_result if test -z "$func_relative_path_tlibdir"; then # Have to descend all the way to the root! func_relative_path_result=../$func_relative_path_result func_relative_path_tcancelled=$func_relative_path_tbindir break fi func_relative_path_result=../$func_relative_path_result ;; esac done # Now calculate path; take care to avoid doubling-up slashes. func_stripname '' '/' "$func_relative_path_result" func_relative_path_result=$func_stripname_result func_stripname '/' '/' "$func_relative_path_tcancelled" if test -n "$func_stripname_result"; then func_append func_relative_path_result "/$func_stripname_result" fi # Normalisation. If bindir is libdir, return '.' else relative path. if test -n "$func_relative_path_result"; then func_stripname './' '' "$func_relative_path_result" func_relative_path_result=$func_stripname_result fi test -n "$func_relative_path_result" || func_relative_path_result=. : } # func_quote_for_eval ARG... # -------------------------- # Aesthetically quote ARGs to be evaled later. # This function returns two values: # i) func_quote_for_eval_result # double-quoted, suitable for a subsequent eval # ii) func_quote_for_eval_unquoted_result # has all characters that are still active within double # quotes backslashified. func_quote_for_eval () { $debug_cmd func_quote_for_eval_unquoted_result= func_quote_for_eval_result= while test 0 -lt $#; do case $1 in *[\\\`\"\$]*) _G_unquoted_arg=`printf '%s\n' "$1" |$SED "$sed_quote_subst"` ;; *) _G_unquoted_arg=$1 ;; esac if test -n "$func_quote_for_eval_unquoted_result"; then func_append func_quote_for_eval_unquoted_result " $_G_unquoted_arg" else func_append func_quote_for_eval_unquoted_result "$_G_unquoted_arg" fi case $_G_unquoted_arg in # Double-quote args containing shell metacharacters to delay # word splitting, command substitution and variable expansion # for a subsequent eval. # Many Bourne shells cannot handle close brackets correctly # in scan sets, so we specify it separately. *[\[\~\#\^\&\*\(\)\{\}\|\;\<\>\?\'\ \ ]*|*]*|"") _G_quoted_arg=\"$_G_unquoted_arg\" ;; *) _G_quoted_arg=$_G_unquoted_arg ;; esac if test -n "$func_quote_for_eval_result"; then func_append func_quote_for_eval_result " $_G_quoted_arg" else func_append func_quote_for_eval_result "$_G_quoted_arg" fi shift done } # func_quote_for_expand ARG # ------------------------- # Aesthetically quote ARG to be evaled later; same as above, # but do not quote variable references. func_quote_for_expand () { $debug_cmd case $1 in *[\\\`\"]*) _G_arg=`$ECHO "$1" | $SED \ -e "$sed_double_quote_subst" -e "$sed_double_backslash"` ;; *) _G_arg=$1 ;; esac case $_G_arg in # Double-quote args containing shell metacharacters to delay # word splitting and command substitution for a subsequent eval. # Many Bourne shells cannot handle close brackets correctly # in scan sets, so we specify it separately. *[\[\~\#\^\&\*\(\)\{\}\|\;\<\>\?\'\ \ ]*|*]*|"") _G_arg=\"$_G_arg\" ;; esac func_quote_for_expand_result=$_G_arg } # func_stripname PREFIX SUFFIX NAME # --------------------------------- # strip PREFIX and SUFFIX from NAME, and store in func_stripname_result. # PREFIX and SUFFIX must not contain globbing or regex special # characters, hashes, percent signs, but SUFFIX may contain a leading # dot (in which case that matches only a dot). if test yes = "$_G_HAVE_XSI_OPS"; then eval 'func_stripname () { $debug_cmd # pdksh 5.2.14 does not do ${X%$Y} correctly if both X and Y are # positional parameters, so assign one to ordinary variable first. func_stripname_result=$3 func_stripname_result=${func_stripname_result#"$1"} func_stripname_result=${func_stripname_result%"$2"} }' else func_stripname () { $debug_cmd case $2 in .*) func_stripname_result=`$ECHO "$3" | $SED -e "s%^$1%%" -e "s%\\\\$2\$%%"`;; *) func_stripname_result=`$ECHO "$3" | $SED -e "s%^$1%%" -e "s%$2\$%%"`;; esac } fi # func_show_eval CMD [FAIL_EXP] # ----------------------------- # Unless opt_quiet is true, then output CMD. Then, if opt_dryrun is # not true, evaluate CMD. If the evaluation of CMD fails, and FAIL_EXP # is given, then evaluate it. func_show_eval () { $debug_cmd _G_cmd=$1 _G_fail_exp=${2-':'} func_quote_for_expand "$_G_cmd" eval "func_notquiet $func_quote_for_expand_result" $opt_dry_run || { eval "$_G_cmd" _G_status=$? if test 0 -ne "$_G_status"; then eval "(exit $_G_status); $_G_fail_exp" fi } } # func_show_eval_locale CMD [FAIL_EXP] # ------------------------------------ # Unless opt_quiet is true, then output CMD. Then, if opt_dryrun is # not true, evaluate CMD. If the evaluation of CMD fails, and FAIL_EXP # is given, then evaluate it. Use the saved locale for evaluation. func_show_eval_locale () { $debug_cmd _G_cmd=$1 _G_fail_exp=${2-':'} $opt_quiet || { func_quote_for_expand "$_G_cmd" eval "func_echo $func_quote_for_expand_result" } $opt_dry_run || { eval "$_G_user_locale $_G_cmd" _G_status=$? eval "$_G_safe_locale" if test 0 -ne "$_G_status"; then eval "(exit $_G_status); $_G_fail_exp" fi } } # func_tr_sh # ---------- # Turn $1 into a string suitable for a shell variable name. # Result is stored in $func_tr_sh_result. All characters # not in the set a-zA-Z0-9_ are replaced with '_'. Further, # if $1 begins with a digit, a '_' is prepended as well. func_tr_sh () { $debug_cmd case $1 in [0-9]* | *[!a-zA-Z0-9_]*) func_tr_sh_result=`$ECHO "$1" | $SED -e 's/^\([0-9]\)/_\1/' -e 's/[^a-zA-Z0-9_]/_/g'` ;; * ) func_tr_sh_result=$1 ;; esac } # func_verbose ARG... # ------------------- # Echo program name prefixed message in verbose mode only. func_verbose () { $debug_cmd $opt_verbose && func_echo "$*" : } # func_warn_and_continue ARG... # ----------------------------- # Echo program name prefixed warning message to standard error. func_warn_and_continue () { $debug_cmd $require_term_colors func_echo_infix_1 "${tc_red}warning$tc_reset" "$*" >&2 } # func_warning CATEGORY ARG... # ---------------------------- # Echo program name prefixed warning message to standard error. Warning # messages can be filtered according to CATEGORY, where this function # elides messages where CATEGORY is not listed in the global variable # 'opt_warning_types'. func_warning () { $debug_cmd # CATEGORY must be in the warning_categories list! case " $warning_categories " in *" $1 "*) ;; *) func_internal_error "invalid warning category '$1'" ;; esac _G_category=$1 shift case " $opt_warning_types " in *" $_G_category "*) $warning_func ${1+"$@"} ;; esac } # func_sort_ver VER1 VER2 # ----------------------- # 'sort -V' is not generally available. # Note this deviates from the version comparison in automake # in that it treats 1.5 < 1.5.0, and treats 1.4.4a < 1.4-p3a # but this should suffice as we won't be specifying old # version formats or redundant trailing .0 in bootstrap.conf. # If we did want full compatibility then we should probably # use m4_version_compare from autoconf. func_sort_ver () { $debug_cmd printf '%s\n%s\n' "$1" "$2" \ | sort -t. -k 1,1n -k 2,2n -k 3,3n -k 4,4n -k 5,5n -k 6,6n -k 7,7n -k 8,8n -k 9,9n } # func_lt_ver PREV CURR # --------------------- # Return true if PREV and CURR are in the correct order according to # func_sort_ver, otherwise false. Use it like this: # # func_lt_ver "$prev_ver" "$proposed_ver" || func_fatal_error "..." func_lt_ver () { $debug_cmd test "x$1" = x`func_sort_ver "$1" "$2" | $SED 1q` } # Local variables: # mode: shell-script # sh-indentation: 2 # eval: (add-hook 'before-save-hook 'time-stamp) # time-stamp-pattern: "10/scriptversion=%:y-%02m-%02d.%02H; # UTC" # time-stamp-time-zone: "UTC" # End: #! /bin/sh # Set a version string for this script. scriptversion=2014-01-07.03; # UTC # A portable, pluggable option parser for Bourne shell. # Written by Gary V. Vaughan, 2010 # Copyright (C) 2010-2015 Free Software Foundation, Inc. # This is free software; see the source for copying conditions. There is NO # warranty; not even for MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. # 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. # You should have received a copy of the GNU General Public License # along with this program. If not, see . # Please report bugs or propose patches to gary@gnu.org. ## ------ ## ## Usage. ## ## ------ ## # This file is a library for parsing options in your shell scripts along # with assorted other useful supporting features that you can make use # of too. # # For the simplest scripts you might need only: # # #!/bin/sh # . relative/path/to/funclib.sh # . relative/path/to/options-parser # scriptversion=1.0 # func_options ${1+"$@"} # eval set dummy "$func_options_result"; shift # ...rest of your script... # # In order for the '--version' option to work, you will need to have a # suitably formatted comment like the one at the top of this file # starting with '# Written by ' and ending with '# warranty; '. # # For '-h' and '--help' to work, you will also need a one line # description of your script's purpose in a comment directly above the # '# Written by ' line, like the one at the top of this file. # # The default options also support '--debug', which will turn on shell # execution tracing (see the comment above debug_cmd below for another # use), and '--verbose' and the func_verbose function to allow your script # to display verbose messages only when your user has specified # '--verbose'. # # After sourcing this file, you can plug processing for additional # options by amending the variables from the 'Configuration' section # below, and following the instructions in the 'Option parsing' # section further down. ## -------------- ## ## Configuration. ## ## -------------- ## # You should override these variables in your script after sourcing this # file so that they reflect the customisations you have added to the # option parser. # The usage line for option parsing errors and the start of '-h' and # '--help' output messages. You can embed shell variables for delayed # expansion at the time the message is displayed, but you will need to # quote other shell meta-characters carefully to prevent them being # expanded when the contents are evaled. usage='$progpath [OPTION]...' # Short help message in response to '-h' and '--help'. Add to this or # override it after sourcing this library to reflect the full set of # options your script accepts. usage_message="\ --debug enable verbose shell tracing -W, --warnings=CATEGORY report the warnings falling in CATEGORY [all] -v, --verbose verbosely report processing --version print version information and exit -h, --help print short or long help message and exit " # Additional text appended to 'usage_message' in response to '--help'. long_help_message=" Warning categories include: 'all' show all warnings 'none' turn off all the warnings 'error' warnings are treated as fatal errors" # Help message printed before fatal option parsing errors. fatal_help="Try '\$progname --help' for more information." ## ------------------------- ## ## Hook function management. ## ## ------------------------- ## # This section contains functions for adding, removing, and running hooks # to the main code. A hook is just a named list of of function, that can # be run in order later on. # func_hookable FUNC_NAME # ----------------------- # Declare that FUNC_NAME will run hooks added with # 'func_add_hook FUNC_NAME ...'. func_hookable () { $debug_cmd func_append hookable_fns " $1" } # func_add_hook FUNC_NAME HOOK_FUNC # --------------------------------- # Request that FUNC_NAME call HOOK_FUNC before it returns. FUNC_NAME must # first have been declared "hookable" by a call to 'func_hookable'. func_add_hook () { $debug_cmd case " $hookable_fns " in *" $1 "*) ;; *) func_fatal_error "'$1' does not accept hook functions." ;; esac eval func_append ${1}_hooks '" $2"' } # func_remove_hook FUNC_NAME HOOK_FUNC # ------------------------------------ # Remove HOOK_FUNC from the list of functions called by FUNC_NAME. func_remove_hook () { $debug_cmd eval ${1}_hooks='`$ECHO "\$'$1'_hooks" |$SED "s| '$2'||"`' } # func_run_hooks FUNC_NAME [ARG]... # --------------------------------- # Run all hook functions registered to FUNC_NAME. # It is assumed that the list of hook functions contains nothing more # than a whitespace-delimited list of legal shell function names, and # no effort is wasted trying to catch shell meta-characters or preserve # whitespace. func_run_hooks () { $debug_cmd case " $hookable_fns " in *" $1 "*) ;; *) func_fatal_error "'$1' does not support hook funcions.n" ;; esac eval _G_hook_fns=\$$1_hooks; shift for _G_hook in $_G_hook_fns; do eval $_G_hook '"$@"' # store returned options list back into positional # parameters for next 'cmd' execution. eval _G_hook_result=\$${_G_hook}_result eval set dummy "$_G_hook_result"; shift done func_quote_for_eval ${1+"$@"} func_run_hooks_result=$func_quote_for_eval_result } ## --------------- ## ## Option parsing. ## ## --------------- ## # In order to add your own option parsing hooks, you must accept the # full positional parameter list in your hook function, remove any # options that you action, and then pass back the remaining unprocessed # options in '_result', escaped suitably for # 'eval'. Like this: # # my_options_prep () # { # $debug_cmd # # # Extend the existing usage message. # usage_message=$usage_message' # -s, --silent don'\''t print informational messages # ' # # func_quote_for_eval ${1+"$@"} # my_options_prep_result=$func_quote_for_eval_result # } # func_add_hook func_options_prep my_options_prep # # # my_silent_option () # { # $debug_cmd # # # Note that for efficiency, we parse as many options as we can # # recognise in a loop before passing the remainder back to the # # caller on the first unrecognised argument we encounter. # while test $# -gt 0; do # opt=$1; shift # case $opt in # --silent|-s) opt_silent=: ;; # # Separate non-argument short options: # -s*) func_split_short_opt "$_G_opt" # set dummy "$func_split_short_opt_name" \ # "-$func_split_short_opt_arg" ${1+"$@"} # shift # ;; # *) set dummy "$_G_opt" "$*"; shift; break ;; # esac # done # # func_quote_for_eval ${1+"$@"} # my_silent_option_result=$func_quote_for_eval_result # } # func_add_hook func_parse_options my_silent_option # # # my_option_validation () # { # $debug_cmd # # $opt_silent && $opt_verbose && func_fatal_help "\ # '--silent' and '--verbose' options are mutually exclusive." # # func_quote_for_eval ${1+"$@"} # my_option_validation_result=$func_quote_for_eval_result # } # func_add_hook func_validate_options my_option_validation # # You'll alse need to manually amend $usage_message to reflect the extra # options you parse. It's preferable to append if you can, so that # multiple option parsing hooks can be added safely. # func_options [ARG]... # --------------------- # All the functions called inside func_options are hookable. See the # individual implementations for details. func_hookable func_options func_options () { $debug_cmd func_options_prep ${1+"$@"} eval func_parse_options \ ${func_options_prep_result+"$func_options_prep_result"} eval func_validate_options \ ${func_parse_options_result+"$func_parse_options_result"} eval func_run_hooks func_options \ ${func_validate_options_result+"$func_validate_options_result"} # save modified positional parameters for caller func_options_result=$func_run_hooks_result } # func_options_prep [ARG]... # -------------------------- # All initialisations required before starting the option parse loop. # Note that when calling hook functions, we pass through the list of # positional parameters. If a hook function modifies that list, and # needs to propogate that back to rest of this script, then the complete # modified list must be put in 'func_run_hooks_result' before # returning. func_hookable func_options_prep func_options_prep () { $debug_cmd # Option defaults: opt_verbose=false opt_warning_types= func_run_hooks func_options_prep ${1+"$@"} # save modified positional parameters for caller func_options_prep_result=$func_run_hooks_result } # func_parse_options [ARG]... # --------------------------- # The main option parsing loop. func_hookable func_parse_options func_parse_options () { $debug_cmd func_parse_options_result= # this just eases exit handling while test $# -gt 0; do # Defer to hook functions for initial option parsing, so they # get priority in the event of reusing an option name. func_run_hooks func_parse_options ${1+"$@"} # Adjust func_parse_options positional parameters to match eval set dummy "$func_run_hooks_result"; shift # Break out of the loop if we already parsed every option. test $# -gt 0 || break _G_opt=$1 shift case $_G_opt in --debug|-x) debug_cmd='set -x' func_echo "enabling shell trace mode" $debug_cmd ;; --no-warnings|--no-warning|--no-warn) set dummy --warnings none ${1+"$@"} shift ;; --warnings|--warning|-W) test $# = 0 && func_missing_arg $_G_opt && break case " $warning_categories $1" in *" $1 "*) # trailing space prevents matching last $1 above func_append_uniq opt_warning_types " $1" ;; *all) opt_warning_types=$warning_categories ;; *none) opt_warning_types=none warning_func=: ;; *error) opt_warning_types=$warning_categories warning_func=func_fatal_error ;; *) func_fatal_error \ "unsupported warning category: '$1'" ;; esac shift ;; --verbose|-v) opt_verbose=: ;; --version) func_version ;; -\?|-h) func_usage ;; --help) func_help ;; # Separate optargs to long options (plugins may need this): --*=*) func_split_equals "$_G_opt" set dummy "$func_split_equals_lhs" \ "$func_split_equals_rhs" ${1+"$@"} shift ;; # Separate optargs to short options: -W*) func_split_short_opt "$_G_opt" set dummy "$func_split_short_opt_name" \ "$func_split_short_opt_arg" ${1+"$@"} shift ;; # Separate non-argument short options: -\?*|-h*|-v*|-x*) func_split_short_opt "$_G_opt" set dummy "$func_split_short_opt_name" \ "-$func_split_short_opt_arg" ${1+"$@"} shift ;; --) break ;; -*) func_fatal_help "unrecognised option: '$_G_opt'" ;; *) set dummy "$_G_opt" ${1+"$@"}; shift; break ;; esac done # save modified positional parameters for caller func_quote_for_eval ${1+"$@"} func_parse_options_result=$func_quote_for_eval_result } # func_validate_options [ARG]... # ------------------------------ # Perform any sanity checks on option settings and/or unconsumed # arguments. func_hookable func_validate_options func_validate_options () { $debug_cmd # Display all warnings if -W was not given. test -n "$opt_warning_types" || opt_warning_types=" $warning_categories" func_run_hooks func_validate_options ${1+"$@"} # Bail if the options were screwed! $exit_cmd $EXIT_FAILURE # save modified positional parameters for caller func_validate_options_result=$func_run_hooks_result } ## ----------------- ## ## Helper functions. ## ## ----------------- ## # This section contains the helper functions used by the rest of the # hookable option parser framework in ascii-betical order. # func_fatal_help ARG... # ---------------------- # Echo program name prefixed message to standard error, followed by # a help hint, and exit. func_fatal_help () { $debug_cmd eval \$ECHO \""Usage: $usage"\" eval \$ECHO \""$fatal_help"\" func_error ${1+"$@"} exit $EXIT_FAILURE } # func_help # --------- # Echo long help message to standard output and exit. func_help () { $debug_cmd func_usage_message $ECHO "$long_help_message" exit 0 } # func_missing_arg ARGNAME # ------------------------ # Echo program name prefixed message to standard error and set global # exit_cmd. func_missing_arg () { $debug_cmd func_error "Missing argument for '$1'." exit_cmd=exit } # func_split_equals STRING # ------------------------ # Set func_split_equals_lhs and func_split_equals_rhs shell variables after # splitting STRING at the '=' sign. test -z "$_G_HAVE_XSI_OPS" \ && (eval 'x=a/b/c; test 5aa/bb/cc = "${#x}${x%%/*}${x%/*}${x#*/}${x##*/}"') 2>/dev/null \ && _G_HAVE_XSI_OPS=yes if test yes = "$_G_HAVE_XSI_OPS" then # This is an XSI compatible shell, allowing a faster implementation... eval 'func_split_equals () { $debug_cmd func_split_equals_lhs=${1%%=*} func_split_equals_rhs=${1#*=} test "x$func_split_equals_lhs" = "x$1" \ && func_split_equals_rhs= }' else # ...otherwise fall back to using expr, which is often a shell builtin. func_split_equals () { $debug_cmd func_split_equals_lhs=`expr "x$1" : 'x\([^=]*\)'` func_split_equals_rhs= test "x$func_split_equals_lhs" = "x$1" \ || func_split_equals_rhs=`expr "x$1" : 'x[^=]*=\(.*\)$'` } fi #func_split_equals # func_split_short_opt SHORTOPT # ----------------------------- # Set func_split_short_opt_name and func_split_short_opt_arg shell # variables after splitting SHORTOPT after the 2nd character. if test yes = "$_G_HAVE_XSI_OPS" then # This is an XSI compatible shell, allowing a faster implementation... eval 'func_split_short_opt () { $debug_cmd func_split_short_opt_arg=${1#??} func_split_short_opt_name=${1%"$func_split_short_opt_arg"} }' else # ...otherwise fall back to using expr, which is often a shell builtin. func_split_short_opt () { $debug_cmd func_split_short_opt_name=`expr "x$1" : 'x-\(.\)'` func_split_short_opt_arg=`expr "x$1" : 'x-.\(.*\)$'` } fi #func_split_short_opt # func_usage # ---------- # Echo short help message to standard output and exit. func_usage () { $debug_cmd func_usage_message $ECHO "Run '$progname --help |${PAGER-more}' for full usage" exit 0 } # func_usage_message # ------------------ # Echo short help message to standard output. func_usage_message () { $debug_cmd eval \$ECHO \""Usage: $usage"\" echo $SED -n 's|^# || /^Written by/{ x;p;x } h /^Written by/q' < "$progpath" echo eval \$ECHO \""$usage_message"\" } # func_version # ------------ # Echo version message to standard output and exit. func_version () { $debug_cmd printf '%s\n' "$progname $scriptversion" $SED -n ' /(C)/!b go :more /\./!{ N s|\n# | | b more } :go /^# Written by /,/# warranty; / { s|^# || s|^# *$|| s|\((C)\)[ 0-9,-]*[ ,-]\([1-9][0-9]* \)|\1 \2| p } /^# Written by / { s|^# || p } /^warranty; /q' < "$progpath" exit $? } # Local variables: # mode: shell-script # sh-indentation: 2 # eval: (add-hook 'before-save-hook 'time-stamp) # time-stamp-pattern: "10/scriptversion=%:y-%02m-%02d.%02H; # UTC" # time-stamp-time-zone: "UTC" # End: # Set a version string. scriptversion='(GNU libtool) 2.4.6' # func_echo ARG... # ---------------- # Libtool also displays the current mode in messages, so override # funclib.sh func_echo with this custom definition. func_echo () { $debug_cmd _G_message=$* func_echo_IFS=$IFS IFS=$nl for _G_line in $_G_message; do IFS=$func_echo_IFS $ECHO "$progname${opt_mode+: $opt_mode}: $_G_line" done IFS=$func_echo_IFS } # func_warning ARG... # ------------------- # Libtool warnings are not categorized, so override funclib.sh # func_warning with this simpler definition. func_warning () { $debug_cmd $warning_func ${1+"$@"} } ## ---------------- ## ## Options parsing. ## ## ---------------- ## # Hook in the functions to make sure our own options are parsed during # the option parsing loop. usage='$progpath [OPTION]... [MODE-ARG]...' # Short help message in response to '-h'. usage_message="Options: --config show all configuration variables --debug enable verbose shell tracing -n, --dry-run display commands without modifying any files --features display basic configuration information and exit --mode=MODE use operation mode MODE --no-warnings equivalent to '-Wnone' --preserve-dup-deps don't remove duplicate dependency libraries --quiet, --silent don't print informational messages --tag=TAG use configuration variables from tag TAG -v, --verbose print more informational messages than default --version print version information -W, --warnings=CATEGORY report the warnings falling in CATEGORY [all] -h, --help, --help-all print short, long, or detailed help message " # Additional text appended to 'usage_message' in response to '--help'. func_help () { $debug_cmd func_usage_message $ECHO "$long_help_message MODE must be one of the following: clean remove files from the build directory compile compile a source file into a libtool object execute automatically set library path, then run a program finish complete the installation of libtool libraries install install libraries or executables link create a library or an executable uninstall remove libraries from an installed directory MODE-ARGS vary depending on the MODE. When passed as first option, '--mode=MODE' may be abbreviated as 'MODE' or a unique abbreviation of that. Try '$progname --help --mode=MODE' for a more detailed description of MODE. When reporting a bug, please describe a test case to reproduce it and include the following information: host-triplet: $host shell: $SHELL compiler: $LTCC compiler flags: $LTCFLAGS linker: $LD (gnu? $with_gnu_ld) version: $progname (GNU libtool) 2.4.6 automake: `($AUTOMAKE --version) 2>/dev/null |$SED 1q` autoconf: `($AUTOCONF --version) 2>/dev/null |$SED 1q` Report bugs to . GNU libtool home page: . General help using GNU software: ." exit 0 } # func_lo2o OBJECT-NAME # --------------------- # Transform OBJECT-NAME from a '.lo' suffix to the platform specific # object suffix. lo2o=s/\\.lo\$/.$objext/ o2lo=s/\\.$objext\$/.lo/ if test yes = "$_G_HAVE_XSI_OPS"; then eval 'func_lo2o () { case $1 in *.lo) func_lo2o_result=${1%.lo}.$objext ;; * ) func_lo2o_result=$1 ;; esac }' # func_xform LIBOBJ-OR-SOURCE # --------------------------- # Transform LIBOBJ-OR-SOURCE from a '.o' or '.c' (or otherwise) # suffix to a '.lo' libtool-object suffix. eval 'func_xform () { func_xform_result=${1%.*}.lo }' else # ...otherwise fall back to using sed. func_lo2o () { func_lo2o_result=`$ECHO "$1" | $SED "$lo2o"` } func_xform () { func_xform_result=`$ECHO "$1" | $SED 's|\.[^.]*$|.lo|'` } fi # func_fatal_configuration ARG... # ------------------------------- # Echo program name prefixed message to standard error, followed by # a configuration failure hint, and exit. func_fatal_configuration () { func__fatal_error ${1+"$@"} \ "See the $PACKAGE documentation for more information." \ "Fatal configuration error." } # func_config # ----------- # Display the configuration for all the tags in this script. func_config () { re_begincf='^# ### BEGIN LIBTOOL' re_endcf='^# ### END LIBTOOL' # Default configuration. $SED "1,/$re_begincf CONFIG/d;/$re_endcf CONFIG/,\$d" < "$progpath" # Now print the configurations for the tags. for tagname in $taglist; do $SED -n "/$re_begincf TAG CONFIG: $tagname\$/,/$re_endcf TAG CONFIG: $tagname\$/p" < "$progpath" done exit $? } # func_features # ------------- # Display the features supported by this script. func_features () { echo "host: $host" if test yes = "$build_libtool_libs"; then echo "enable shared libraries" else echo "disable shared libraries" fi if test yes = "$build_old_libs"; then echo "enable static libraries" else echo "disable static libraries" fi exit $? } # func_enable_tag TAGNAME # ----------------------- # Verify that TAGNAME is valid, and either flag an error and exit, or # enable the TAGNAME tag. We also add TAGNAME to the global $taglist # variable here. func_enable_tag () { # Global variable: tagname=$1 re_begincf="^# ### BEGIN LIBTOOL TAG CONFIG: $tagname\$" re_endcf="^# ### END LIBTOOL TAG CONFIG: $tagname\$" sed_extractcf=/$re_begincf/,/$re_endcf/p # Validate tagname. case $tagname in *[!-_A-Za-z0-9,/]*) func_fatal_error "invalid tag name: $tagname" ;; esac # Don't test for the "default" C tag, as we know it's # there but not specially marked. case $tagname in CC) ;; *) if $GREP "$re_begincf" "$progpath" >/dev/null 2>&1; then taglist="$taglist $tagname" # Evaluate the configuration. Be careful to quote the path # and the sed script, to avoid splitting on whitespace, but # also don't use non-portable quotes within backquotes within # quotes we have to do it in 2 steps: extractedcf=`$SED -n -e "$sed_extractcf" < "$progpath"` eval "$extractedcf" else func_error "ignoring unknown tag $tagname" fi ;; esac } # func_check_version_match # ------------------------ # Ensure that we are using m4 macros, and libtool script from the same # release of libtool. func_check_version_match () { if test "$package_revision" != "$macro_revision"; then if test "$VERSION" != "$macro_version"; then if test -z "$macro_version"; then cat >&2 <<_LT_EOF $progname: Version mismatch error. This is $PACKAGE $VERSION, but the $progname: definition of this LT_INIT comes from an older release. $progname: You should recreate aclocal.m4 with macros from $PACKAGE $VERSION $progname: and run autoconf again. _LT_EOF else cat >&2 <<_LT_EOF $progname: Version mismatch error. This is $PACKAGE $VERSION, but the $progname: definition of this LT_INIT comes from $PACKAGE $macro_version. $progname: You should recreate aclocal.m4 with macros from $PACKAGE $VERSION $progname: and run autoconf again. _LT_EOF fi else cat >&2 <<_LT_EOF $progname: Version mismatch error. This is $PACKAGE $VERSION, revision $package_revision, $progname: but the definition of this LT_INIT comes from revision $macro_revision. $progname: You should recreate aclocal.m4 with macros from revision $package_revision $progname: of $PACKAGE $VERSION and run autoconf again. _LT_EOF fi exit $EXIT_MISMATCH fi } # libtool_options_prep [ARG]... # ----------------------------- # Preparation for options parsed by libtool. libtool_options_prep () { $debug_mode # Option defaults: opt_config=false opt_dlopen= opt_dry_run=false opt_help=false opt_mode= opt_preserve_dup_deps=false opt_quiet=false nonopt= preserve_args= # Shorthand for --mode=foo, only valid as the first argument case $1 in clean|clea|cle|cl) shift; set dummy --mode clean ${1+"$@"}; shift ;; compile|compil|compi|comp|com|co|c) shift; set dummy --mode compile ${1+"$@"}; shift ;; execute|execut|execu|exec|exe|ex|e) shift; set dummy --mode execute ${1+"$@"}; shift ;; finish|finis|fini|fin|fi|f) shift; set dummy --mode finish ${1+"$@"}; shift ;; install|instal|insta|inst|ins|in|i) shift; set dummy --mode install ${1+"$@"}; shift ;; link|lin|li|l) shift; set dummy --mode link ${1+"$@"}; shift ;; uninstall|uninstal|uninsta|uninst|unins|unin|uni|un|u) shift; set dummy --mode uninstall ${1+"$@"}; shift ;; esac # Pass back the list of options. func_quote_for_eval ${1+"$@"} libtool_options_prep_result=$func_quote_for_eval_result } func_add_hook func_options_prep libtool_options_prep # libtool_parse_options [ARG]... # --------------------------------- # Provide handling for libtool specific options. libtool_parse_options () { $debug_cmd # Perform our own loop to consume as many options as possible in # each iteration. while test $# -gt 0; do _G_opt=$1 shift case $_G_opt in --dry-run|--dryrun|-n) opt_dry_run=: ;; --config) func_config ;; --dlopen|-dlopen) opt_dlopen="${opt_dlopen+$opt_dlopen }$1" shift ;; --preserve-dup-deps) opt_preserve_dup_deps=: ;; --features) func_features ;; --finish) set dummy --mode finish ${1+"$@"}; shift ;; --help) opt_help=: ;; --help-all) opt_help=': help-all' ;; --mode) test $# = 0 && func_missing_arg $_G_opt && break opt_mode=$1 case $1 in # Valid mode arguments: clean|compile|execute|finish|install|link|relink|uninstall) ;; # Catch anything else as an error *) func_error "invalid argument for $_G_opt" exit_cmd=exit break ;; esac shift ;; --no-silent|--no-quiet) opt_quiet=false func_append preserve_args " $_G_opt" ;; --no-warnings|--no-warning|--no-warn) opt_warning=false func_append preserve_args " $_G_opt" ;; --no-verbose) opt_verbose=false func_append preserve_args " $_G_opt" ;; --silent|--quiet) opt_quiet=: opt_verbose=false func_append preserve_args " $_G_opt" ;; --tag) test $# = 0 && func_missing_arg $_G_opt && break opt_tag=$1 func_append preserve_args " $_G_opt $1" func_enable_tag "$1" shift ;; --verbose|-v) opt_quiet=false opt_verbose=: func_append preserve_args " $_G_opt" ;; # An option not handled by this hook function: *) set dummy "$_G_opt" ${1+"$@"}; shift; break ;; esac done # save modified positional parameters for caller func_quote_for_eval ${1+"$@"} libtool_parse_options_result=$func_quote_for_eval_result } func_add_hook func_parse_options libtool_parse_options # libtool_validate_options [ARG]... # --------------------------------- # Perform any sanity checks on option settings and/or unconsumed # arguments. libtool_validate_options () { # save first non-option argument if test 0 -lt $#; then nonopt=$1 shift fi # preserve --debug test : = "$debug_cmd" || func_append preserve_args " --debug" case $host in # Solaris2 added to fix http://debbugs.gnu.org/cgi/bugreport.cgi?bug=16452 # see also: http://gcc.gnu.org/bugzilla/show_bug.cgi?id=59788 *cygwin* | *mingw* | *pw32* | *cegcc* | *solaris2* | *os2*) # don't eliminate duplications in $postdeps and $predeps opt_duplicate_compiler_generated_deps=: ;; *) opt_duplicate_compiler_generated_deps=$opt_preserve_dup_deps ;; esac $opt_help || { # Sanity checks first: func_check_version_match test yes != "$build_libtool_libs" \ && test yes != "$build_old_libs" \ && func_fatal_configuration "not configured to build any kind of library" # Darwin sucks eval std_shrext=\"$shrext_cmds\" # Only execute mode is allowed to have -dlopen flags. if test -n "$opt_dlopen" && test execute != "$opt_mode"; then func_error "unrecognized option '-dlopen'" $ECHO "$help" 1>&2 exit $EXIT_FAILURE fi # Change the help message to a mode-specific one. generic_help=$help help="Try '$progname --help --mode=$opt_mode' for more information." } # Pass back the unparsed argument list func_quote_for_eval ${1+"$@"} libtool_validate_options_result=$func_quote_for_eval_result } func_add_hook func_validate_options libtool_validate_options # Process options as early as possible so that --help and --version # can return quickly. func_options ${1+"$@"} eval set dummy "$func_options_result"; shift ## ----------- ## ## Main. ## ## ----------- ## magic='%%%MAGIC variable%%%' magic_exe='%%%MAGIC EXE variable%%%' # Global variables. extracted_archives= extracted_serial=0 # If this variable is set in any of the actions, the command in it # will be execed at the end. This prevents here-documents from being # left over by shells. exec_cmd= # A function that is used when there is no print builtin or printf. func_fallback_echo () { eval 'cat <<_LTECHO_EOF $1 _LTECHO_EOF' } # func_generated_by_libtool # True iff stdin has been generated by Libtool. This function is only # a basic sanity check; it will hardly flush out determined imposters. func_generated_by_libtool_p () { $GREP "^# Generated by .*$PACKAGE" > /dev/null 2>&1 } # func_lalib_p file # True iff FILE is a libtool '.la' library or '.lo' object file. # This function is only a basic sanity check; it will hardly flush out # determined imposters. func_lalib_p () { test -f "$1" && $SED -e 4q "$1" 2>/dev/null | func_generated_by_libtool_p } # func_lalib_unsafe_p file # True iff FILE is a libtool '.la' library or '.lo' object file. # This function implements the same check as func_lalib_p without # resorting to external programs. To this end, it redirects stdin and # closes it afterwards, without saving the original file descriptor. # As a safety measure, use it only where a negative result would be # fatal anyway. Works if 'file' does not exist. func_lalib_unsafe_p () { lalib_p=no if test -f "$1" && test -r "$1" && exec 5<&0 <"$1"; then for lalib_p_l in 1 2 3 4 do read lalib_p_line case $lalib_p_line in \#\ Generated\ by\ *$PACKAGE* ) lalib_p=yes; break;; esac done exec 0<&5 5<&- fi test yes = "$lalib_p" } # func_ltwrapper_script_p file # True iff FILE is a libtool wrapper script # This function is only a basic sanity check; it will hardly flush out # determined imposters. func_ltwrapper_script_p () { test -f "$1" && $lt_truncate_bin < "$1" 2>/dev/null | func_generated_by_libtool_p } # func_ltwrapper_executable_p file # True iff FILE is a libtool wrapper executable # This function is only a basic sanity check; it will hardly flush out # determined imposters. func_ltwrapper_executable_p () { func_ltwrapper_exec_suffix= case $1 in *.exe) ;; *) func_ltwrapper_exec_suffix=.exe ;; esac $GREP "$magic_exe" "$1$func_ltwrapper_exec_suffix" >/dev/null 2>&1 } # func_ltwrapper_scriptname file # Assumes file is an ltwrapper_executable # uses $file to determine the appropriate filename for a # temporary ltwrapper_script. func_ltwrapper_scriptname () { func_dirname_and_basename "$1" "" "." func_stripname '' '.exe' "$func_basename_result" func_ltwrapper_scriptname_result=$func_dirname_result/$objdir/${func_stripname_result}_ltshwrapper } # func_ltwrapper_p file # True iff FILE is a libtool wrapper script or wrapper executable # This function is only a basic sanity check; it will hardly flush out # determined imposters. func_ltwrapper_p () { func_ltwrapper_script_p "$1" || func_ltwrapper_executable_p "$1" } # func_execute_cmds commands fail_cmd # Execute tilde-delimited COMMANDS. # If FAIL_CMD is given, eval that upon failure. # FAIL_CMD may read-access the current command in variable CMD! func_execute_cmds () { $debug_cmd save_ifs=$IFS; IFS='~' for cmd in $1; do IFS=$sp$nl eval cmd=\"$cmd\" IFS=$save_ifs func_show_eval "$cmd" "${2-:}" done IFS=$save_ifs } # func_source file # Source FILE, adding directory component if necessary. # Note that it is not necessary on cygwin/mingw to append a dot to # FILE even if both FILE and FILE.exe exist: automatic-append-.exe # behavior happens only for exec(3), not for open(2)! Also, sourcing # 'FILE.' does not work on cygwin managed mounts. func_source () { $debug_cmd case $1 in */* | *\\*) . "$1" ;; *) . "./$1" ;; esac } # func_resolve_sysroot PATH # Replace a leading = in PATH with a sysroot. Store the result into # func_resolve_sysroot_result func_resolve_sysroot () { func_resolve_sysroot_result=$1 case $func_resolve_sysroot_result in =*) func_stripname '=' '' "$func_resolve_sysroot_result" func_resolve_sysroot_result=$lt_sysroot$func_stripname_result ;; esac } # func_replace_sysroot PATH # If PATH begins with the sysroot, replace it with = and # store the result into func_replace_sysroot_result. func_replace_sysroot () { case $lt_sysroot:$1 in ?*:"$lt_sysroot"*) func_stripname "$lt_sysroot" '' "$1" func_replace_sysroot_result='='$func_stripname_result ;; *) # Including no sysroot. func_replace_sysroot_result=$1 ;; esac } # func_infer_tag arg # Infer tagged configuration to use if any are available and # if one wasn't chosen via the "--tag" command line option. # Only attempt this if the compiler in the base compile # command doesn't match the default compiler. # arg is usually of the form 'gcc ...' func_infer_tag () { $debug_cmd if test -n "$available_tags" && test -z "$tagname"; then CC_quoted= for arg in $CC; do func_append_quoted CC_quoted "$arg" done CC_expanded=`func_echo_all $CC` CC_quoted_expanded=`func_echo_all $CC_quoted` case $@ in # Blanks in the command may have been stripped by the calling shell, # but not from the CC environment variable when configure was run. " $CC "* | "$CC "* | " $CC_expanded "* | "$CC_expanded "* | \ " $CC_quoted"* | "$CC_quoted "* | " $CC_quoted_expanded "* | "$CC_quoted_expanded "*) ;; # Blanks at the start of $base_compile will cause this to fail # if we don't check for them as well. *) for z in $available_tags; do if $GREP "^# ### BEGIN LIBTOOL TAG CONFIG: $z$" < "$progpath" > /dev/null; then # Evaluate the configuration. eval "`$SED -n -e '/^# ### BEGIN LIBTOOL TAG CONFIG: '$z'$/,/^# ### END LIBTOOL TAG CONFIG: '$z'$/p' < $progpath`" CC_quoted= for arg in $CC; do # Double-quote args containing other shell metacharacters. func_append_quoted CC_quoted "$arg" done CC_expanded=`func_echo_all $CC` CC_quoted_expanded=`func_echo_all $CC_quoted` case "$@ " in " $CC "* | "$CC "* | " $CC_expanded "* | "$CC_expanded "* | \ " $CC_quoted"* | "$CC_quoted "* | " $CC_quoted_expanded "* | "$CC_quoted_expanded "*) # The compiler in the base compile command matches # the one in the tagged configuration. # Assume this is the tagged configuration we want. tagname=$z break ;; esac fi done # If $tagname still isn't set, then no tagged configuration # was found and let the user know that the "--tag" command # line option must be used. if test -z "$tagname"; then func_echo "unable to infer tagged configuration" func_fatal_error "specify a tag with '--tag'" # else # func_verbose "using $tagname tagged configuration" fi ;; esac fi } # func_write_libtool_object output_name pic_name nonpic_name # Create a libtool object file (analogous to a ".la" file), # but don't create it if we're doing a dry run. func_write_libtool_object () { write_libobj=$1 if test yes = "$build_libtool_libs"; then write_lobj=\'$2\' else write_lobj=none fi if test yes = "$build_old_libs"; then write_oldobj=\'$3\' else write_oldobj=none fi $opt_dry_run || { cat >${write_libobj}T </dev/null` if test "$?" -eq 0 && test -n "$func_convert_core_file_wine_to_w32_tmp"; then func_convert_core_file_wine_to_w32_result=`$ECHO "$func_convert_core_file_wine_to_w32_tmp" | $SED -e "$sed_naive_backslashify"` else func_convert_core_file_wine_to_w32_result= fi fi } # end: func_convert_core_file_wine_to_w32 # func_convert_core_path_wine_to_w32 ARG # Helper function used by path conversion functions when $build is *nix, and # $host is mingw, cygwin, or some other w32 environment. Relies on a correctly # configured wine environment available, with the winepath program in $build's # $PATH. Assumes ARG has no leading or trailing path separator characters. # # ARG is path to be converted from $build format to win32. # Result is available in $func_convert_core_path_wine_to_w32_result. # Unconvertible file (directory) names in ARG are skipped; if no directory names # are convertible, then the result may be empty. func_convert_core_path_wine_to_w32 () { $debug_cmd # unfortunately, winepath doesn't convert paths, only file names func_convert_core_path_wine_to_w32_result= if test -n "$1"; then oldIFS=$IFS IFS=: for func_convert_core_path_wine_to_w32_f in $1; do IFS=$oldIFS func_convert_core_file_wine_to_w32 "$func_convert_core_path_wine_to_w32_f" if test -n "$func_convert_core_file_wine_to_w32_result"; then if test -z "$func_convert_core_path_wine_to_w32_result"; then func_convert_core_path_wine_to_w32_result=$func_convert_core_file_wine_to_w32_result else func_append func_convert_core_path_wine_to_w32_result ";$func_convert_core_file_wine_to_w32_result" fi fi done IFS=$oldIFS fi } # end: func_convert_core_path_wine_to_w32 # func_cygpath ARGS... # Wrapper around calling the cygpath program via LT_CYGPATH. This is used when # when (1) $build is *nix and Cygwin is hosted via a wine environment; or (2) # $build is MSYS and $host is Cygwin, or (3) $build is Cygwin. In case (1) or # (2), returns the Cygwin file name or path in func_cygpath_result (input # file name or path is assumed to be in w32 format, as previously converted # from $build's *nix or MSYS format). In case (3), returns the w32 file name # or path in func_cygpath_result (input file name or path is assumed to be in # Cygwin format). Returns an empty string on error. # # ARGS are passed to cygpath, with the last one being the file name or path to # be converted. # # Specify the absolute *nix (or w32) name to cygpath in the LT_CYGPATH # environment variable; do not put it in $PATH. func_cygpath () { $debug_cmd if test -n "$LT_CYGPATH" && test -f "$LT_CYGPATH"; then func_cygpath_result=`$LT_CYGPATH "$@" 2>/dev/null` if test "$?" -ne 0; then # on failure, ensure result is empty func_cygpath_result= fi else func_cygpath_result= func_error "LT_CYGPATH is empty or specifies non-existent file: '$LT_CYGPATH'" fi } #end: func_cygpath # func_convert_core_msys_to_w32 ARG # Convert file name or path ARG from MSYS format to w32 format. Return # result in func_convert_core_msys_to_w32_result. func_convert_core_msys_to_w32 () { $debug_cmd # awkward: cmd appends spaces to result func_convert_core_msys_to_w32_result=`( cmd //c echo "$1" ) 2>/dev/null | $SED -e 's/[ ]*$//' -e "$sed_naive_backslashify"` } #end: func_convert_core_msys_to_w32 # func_convert_file_check ARG1 ARG2 # Verify that ARG1 (a file name in $build format) was converted to $host # format in ARG2. Otherwise, emit an error message, but continue (resetting # func_to_host_file_result to ARG1). func_convert_file_check () { $debug_cmd if test -z "$2" && test -n "$1"; then func_error "Could not determine host file name corresponding to" func_error " '$1'" func_error "Continuing, but uninstalled executables may not work." # Fallback: func_to_host_file_result=$1 fi } # end func_convert_file_check # func_convert_path_check FROM_PATHSEP TO_PATHSEP FROM_PATH TO_PATH # Verify that FROM_PATH (a path in $build format) was converted to $host # format in TO_PATH. Otherwise, emit an error message, but continue, resetting # func_to_host_file_result to a simplistic fallback value (see below). func_convert_path_check () { $debug_cmd if test -z "$4" && test -n "$3"; then func_error "Could not determine the host path corresponding to" func_error " '$3'" func_error "Continuing, but uninstalled executables may not work." # Fallback. This is a deliberately simplistic "conversion" and # should not be "improved". See libtool.info. if test "x$1" != "x$2"; then lt_replace_pathsep_chars="s|$1|$2|g" func_to_host_path_result=`echo "$3" | $SED -e "$lt_replace_pathsep_chars"` else func_to_host_path_result=$3 fi fi } # end func_convert_path_check # func_convert_path_front_back_pathsep FRONTPAT BACKPAT REPL ORIG # Modifies func_to_host_path_result by prepending REPL if ORIG matches FRONTPAT # and appending REPL if ORIG matches BACKPAT. func_convert_path_front_back_pathsep () { $debug_cmd case $4 in $1 ) func_to_host_path_result=$3$func_to_host_path_result ;; esac case $4 in $2 ) func_append func_to_host_path_result "$3" ;; esac } # end func_convert_path_front_back_pathsep ################################################## # $build to $host FILE NAME CONVERSION FUNCTIONS # ################################################## # invoked via '$to_host_file_cmd ARG' # # In each case, ARG is the path to be converted from $build to $host format. # Result will be available in $func_to_host_file_result. # func_to_host_file ARG # Converts the file name ARG from $build format to $host format. Return result # in func_to_host_file_result. func_to_host_file () { $debug_cmd $to_host_file_cmd "$1" } # end func_to_host_file # func_to_tool_file ARG LAZY # converts the file name ARG from $build format to toolchain format. Return # result in func_to_tool_file_result. If the conversion in use is listed # in (the comma separated) LAZY, no conversion takes place. func_to_tool_file () { $debug_cmd case ,$2, in *,"$to_tool_file_cmd",*) func_to_tool_file_result=$1 ;; *) $to_tool_file_cmd "$1" func_to_tool_file_result=$func_to_host_file_result ;; esac } # end func_to_tool_file # func_convert_file_noop ARG # Copy ARG to func_to_host_file_result. func_convert_file_noop () { func_to_host_file_result=$1 } # end func_convert_file_noop # func_convert_file_msys_to_w32 ARG # Convert file name ARG from (mingw) MSYS to (mingw) w32 format; automatic # conversion to w32 is not available inside the cwrapper. Returns result in # func_to_host_file_result. func_convert_file_msys_to_w32 () { $debug_cmd func_to_host_file_result=$1 if test -n "$1"; then func_convert_core_msys_to_w32 "$1" func_to_host_file_result=$func_convert_core_msys_to_w32_result fi func_convert_file_check "$1" "$func_to_host_file_result" } # end func_convert_file_msys_to_w32 # func_convert_file_cygwin_to_w32 ARG # Convert file name ARG from Cygwin to w32 format. Returns result in # func_to_host_file_result. func_convert_file_cygwin_to_w32 () { $debug_cmd func_to_host_file_result=$1 if test -n "$1"; then # because $build is cygwin, we call "the" cygpath in $PATH; no need to use # LT_CYGPATH in this case. func_to_host_file_result=`cygpath -m "$1"` fi func_convert_file_check "$1" "$func_to_host_file_result" } # end func_convert_file_cygwin_to_w32 # func_convert_file_nix_to_w32 ARG # Convert file name ARG from *nix to w32 format. Requires a wine environment # and a working winepath. Returns result in func_to_host_file_result. func_convert_file_nix_to_w32 () { $debug_cmd func_to_host_file_result=$1 if test -n "$1"; then func_convert_core_file_wine_to_w32 "$1" func_to_host_file_result=$func_convert_core_file_wine_to_w32_result fi func_convert_file_check "$1" "$func_to_host_file_result" } # end func_convert_file_nix_to_w32 # func_convert_file_msys_to_cygwin ARG # Convert file name ARG from MSYS to Cygwin format. Requires LT_CYGPATH set. # Returns result in func_to_host_file_result. func_convert_file_msys_to_cygwin () { $debug_cmd func_to_host_file_result=$1 if test -n "$1"; then func_convert_core_msys_to_w32 "$1" func_cygpath -u "$func_convert_core_msys_to_w32_result" func_to_host_file_result=$func_cygpath_result fi func_convert_file_check "$1" "$func_to_host_file_result" } # end func_convert_file_msys_to_cygwin # func_convert_file_nix_to_cygwin ARG # Convert file name ARG from *nix to Cygwin format. Requires Cygwin installed # in a wine environment, working winepath, and LT_CYGPATH set. Returns result # in func_to_host_file_result. func_convert_file_nix_to_cygwin () { $debug_cmd func_to_host_file_result=$1 if test -n "$1"; then # convert from *nix to w32, then use cygpath to convert from w32 to cygwin. func_convert_core_file_wine_to_w32 "$1" func_cygpath -u "$func_convert_core_file_wine_to_w32_result" func_to_host_file_result=$func_cygpath_result fi func_convert_file_check "$1" "$func_to_host_file_result" } # end func_convert_file_nix_to_cygwin ############################################# # $build to $host PATH CONVERSION FUNCTIONS # ############################################# # invoked via '$to_host_path_cmd ARG' # # In each case, ARG is the path to be converted from $build to $host format. # The result will be available in $func_to_host_path_result. # # Path separators are also converted from $build format to $host format. If # ARG begins or ends with a path separator character, it is preserved (but # converted to $host format) on output. # # All path conversion functions are named using the following convention: # file name conversion function : func_convert_file_X_to_Y () # path conversion function : func_convert_path_X_to_Y () # where, for any given $build/$host combination the 'X_to_Y' value is the # same. If conversion functions are added for new $build/$host combinations, # the two new functions must follow this pattern, or func_init_to_host_path_cmd # will break. # func_init_to_host_path_cmd # Ensures that function "pointer" variable $to_host_path_cmd is set to the # appropriate value, based on the value of $to_host_file_cmd. to_host_path_cmd= func_init_to_host_path_cmd () { $debug_cmd if test -z "$to_host_path_cmd"; then func_stripname 'func_convert_file_' '' "$to_host_file_cmd" to_host_path_cmd=func_convert_path_$func_stripname_result fi } # func_to_host_path ARG # Converts the path ARG from $build format to $host format. Return result # in func_to_host_path_result. func_to_host_path () { $debug_cmd func_init_to_host_path_cmd $to_host_path_cmd "$1" } # end func_to_host_path # func_convert_path_noop ARG # Copy ARG to func_to_host_path_result. func_convert_path_noop () { func_to_host_path_result=$1 } # end func_convert_path_noop # func_convert_path_msys_to_w32 ARG # Convert path ARG from (mingw) MSYS to (mingw) w32 format; automatic # conversion to w32 is not available inside the cwrapper. Returns result in # func_to_host_path_result. func_convert_path_msys_to_w32 () { $debug_cmd func_to_host_path_result=$1 if test -n "$1"; then # Remove leading and trailing path separator characters from ARG. MSYS # behavior is inconsistent here; cygpath turns them into '.;' and ';.'; # and winepath ignores them completely. func_stripname : : "$1" func_to_host_path_tmp1=$func_stripname_result func_convert_core_msys_to_w32 "$func_to_host_path_tmp1" func_to_host_path_result=$func_convert_core_msys_to_w32_result func_convert_path_check : ";" \ "$func_to_host_path_tmp1" "$func_to_host_path_result" func_convert_path_front_back_pathsep ":*" "*:" ";" "$1" fi } # end func_convert_path_msys_to_w32 # func_convert_path_cygwin_to_w32 ARG # Convert path ARG from Cygwin to w32 format. Returns result in # func_to_host_file_result. func_convert_path_cygwin_to_w32 () { $debug_cmd func_to_host_path_result=$1 if test -n "$1"; then # See func_convert_path_msys_to_w32: func_stripname : : "$1" func_to_host_path_tmp1=$func_stripname_result func_to_host_path_result=`cygpath -m -p "$func_to_host_path_tmp1"` func_convert_path_check : ";" \ "$func_to_host_path_tmp1" "$func_to_host_path_result" func_convert_path_front_back_pathsep ":*" "*:" ";" "$1" fi } # end func_convert_path_cygwin_to_w32 # func_convert_path_nix_to_w32 ARG # Convert path ARG from *nix to w32 format. Requires a wine environment and # a working winepath. Returns result in func_to_host_file_result. func_convert_path_nix_to_w32 () { $debug_cmd func_to_host_path_result=$1 if test -n "$1"; then # See func_convert_path_msys_to_w32: func_stripname : : "$1" func_to_host_path_tmp1=$func_stripname_result func_convert_core_path_wine_to_w32 "$func_to_host_path_tmp1" func_to_host_path_result=$func_convert_core_path_wine_to_w32_result func_convert_path_check : ";" \ "$func_to_host_path_tmp1" "$func_to_host_path_result" func_convert_path_front_back_pathsep ":*" "*:" ";" "$1" fi } # end func_convert_path_nix_to_w32 # func_convert_path_msys_to_cygwin ARG # Convert path ARG from MSYS to Cygwin format. Requires LT_CYGPATH set. # Returns result in func_to_host_file_result. func_convert_path_msys_to_cygwin () { $debug_cmd func_to_host_path_result=$1 if test -n "$1"; then # See func_convert_path_msys_to_w32: func_stripname : : "$1" func_to_host_path_tmp1=$func_stripname_result func_convert_core_msys_to_w32 "$func_to_host_path_tmp1" func_cygpath -u -p "$func_convert_core_msys_to_w32_result" func_to_host_path_result=$func_cygpath_result func_convert_path_check : : \ "$func_to_host_path_tmp1" "$func_to_host_path_result" func_convert_path_front_back_pathsep ":*" "*:" : "$1" fi } # end func_convert_path_msys_to_cygwin # func_convert_path_nix_to_cygwin ARG # Convert path ARG from *nix to Cygwin format. Requires Cygwin installed in a # a wine environment, working winepath, and LT_CYGPATH set. Returns result in # func_to_host_file_result. func_convert_path_nix_to_cygwin () { $debug_cmd func_to_host_path_result=$1 if test -n "$1"; then # Remove leading and trailing path separator characters from # ARG. msys behavior is inconsistent here, cygpath turns them # into '.;' and ';.', and winepath ignores them completely. func_stripname : : "$1" func_to_host_path_tmp1=$func_stripname_result func_convert_core_path_wine_to_w32 "$func_to_host_path_tmp1" func_cygpath -u -p "$func_convert_core_path_wine_to_w32_result" func_to_host_path_result=$func_cygpath_result func_convert_path_check : : \ "$func_to_host_path_tmp1" "$func_to_host_path_result" func_convert_path_front_back_pathsep ":*" "*:" : "$1" fi } # end func_convert_path_nix_to_cygwin # func_dll_def_p FILE # True iff FILE is a Windows DLL '.def' file. # Keep in sync with _LT_DLL_DEF_P in libtool.m4 func_dll_def_p () { $debug_cmd func_dll_def_p_tmp=`$SED -n \ -e 's/^[ ]*//' \ -e '/^\(;.*\)*$/d' \ -e 's/^\(EXPORTS\|LIBRARY\)\([ ].*\)*$/DEF/p' \ -e q \ "$1"` test DEF = "$func_dll_def_p_tmp" } # func_mode_compile arg... func_mode_compile () { $debug_cmd # Get the compilation command and the source file. base_compile= srcfile=$nonopt # always keep a non-empty value in "srcfile" suppress_opt=yes suppress_output= arg_mode=normal libobj= later= pie_flag= for arg do case $arg_mode in arg ) # do not "continue". Instead, add this to base_compile lastarg=$arg arg_mode=normal ;; target ) libobj=$arg arg_mode=normal continue ;; normal ) # Accept any command-line options. case $arg in -o) test -n "$libobj" && \ func_fatal_error "you cannot specify '-o' more than once" arg_mode=target continue ;; -pie | -fpie | -fPIE) func_append pie_flag " $arg" continue ;; -shared | -static | -prefer-pic | -prefer-non-pic) func_append later " $arg" continue ;; -no-suppress) suppress_opt=no continue ;; -Xcompiler) arg_mode=arg # the next one goes into the "base_compile" arg list continue # The current "srcfile" will either be retained or ;; # replaced later. I would guess that would be a bug. -Wc,*) func_stripname '-Wc,' '' "$arg" args=$func_stripname_result lastarg= save_ifs=$IFS; IFS=, for arg in $args; do IFS=$save_ifs func_append_quoted lastarg "$arg" done IFS=$save_ifs func_stripname ' ' '' "$lastarg" lastarg=$func_stripname_result # Add the arguments to base_compile. func_append base_compile " $lastarg" continue ;; *) # Accept the current argument as the source file. # The previous "srcfile" becomes the current argument. # lastarg=$srcfile srcfile=$arg ;; esac # case $arg ;; esac # case $arg_mode # Aesthetically quote the previous argument. func_append_quoted base_compile "$lastarg" done # for arg case $arg_mode in arg) func_fatal_error "you must specify an argument for -Xcompile" ;; target) func_fatal_error "you must specify a target with '-o'" ;; *) # Get the name of the library object. test -z "$libobj" && { func_basename "$srcfile" libobj=$func_basename_result } ;; esac # Recognize several different file suffixes. # If the user specifies -o file.o, it is replaced with file.lo case $libobj in *.[cCFSifmso] | \ *.ada | *.adb | *.ads | *.asm | \ *.c++ | *.cc | *.ii | *.class | *.cpp | *.cxx | \ *.[fF][09]? | *.for | *.java | *.go | *.obj | *.sx | *.cu | *.cup) func_xform "$libobj" libobj=$func_xform_result ;; esac case $libobj in *.lo) func_lo2o "$libobj"; obj=$func_lo2o_result ;; *) func_fatal_error "cannot determine name of library object from '$libobj'" ;; esac func_infer_tag $base_compile for arg in $later; do case $arg in -shared) test yes = "$build_libtool_libs" \ || func_fatal_configuration "cannot build a shared library" build_old_libs=no continue ;; -static) build_libtool_libs=no build_old_libs=yes continue ;; -prefer-pic) pic_mode=yes continue ;; -prefer-non-pic) pic_mode=no continue ;; esac done func_quote_for_eval "$libobj" test "X$libobj" != "X$func_quote_for_eval_result" \ && $ECHO "X$libobj" | $GREP '[]~#^*{};<>?"'"'"' &()|`$[]' \ && func_warning "libobj name '$libobj' may not contain shell special characters." func_dirname_and_basename "$obj" "/" "" objname=$func_basename_result xdir=$func_dirname_result lobj=$xdir$objdir/$objname test -z "$base_compile" && \ func_fatal_help "you must specify a compilation command" # Delete any leftover library objects. if test yes = "$build_old_libs"; then removelist="$obj $lobj $libobj ${libobj}T" else removelist="$lobj $libobj ${libobj}T" fi # On Cygwin there's no "real" PIC flag so we must build both object types case $host_os in cygwin* | mingw* | pw32* | os2* | cegcc*) pic_mode=default ;; esac if test no = "$pic_mode" && test pass_all != "$deplibs_check_method"; then # non-PIC code in shared libraries is not supported pic_mode=default fi # Calculate the filename of the output object if compiler does # not support -o with -c if test no = "$compiler_c_o"; then output_obj=`$ECHO "$srcfile" | $SED 's%^.*/%%; s%\.[^.]*$%%'`.$objext lockfile=$output_obj.lock else output_obj= need_locks=no lockfile= fi # Lock this critical section if it is needed # We use this script file to make the link, it avoids creating a new file if test yes = "$need_locks"; then until $opt_dry_run || ln "$progpath" "$lockfile" 2>/dev/null; do func_echo "Waiting for $lockfile to be removed" sleep 2 done elif test warn = "$need_locks"; then if test -f "$lockfile"; then $ECHO "\ *** ERROR, $lockfile exists and contains: `cat $lockfile 2>/dev/null` This indicates that another process is trying to use the same temporary object file, and libtool could not work around it because your compiler does not support '-c' and '-o' together. If you repeat this compilation, it may succeed, by chance, but you had better avoid parallel builds (make -j) in this platform, or get a better compiler." $opt_dry_run || $RM $removelist exit $EXIT_FAILURE fi func_append removelist " $output_obj" $ECHO "$srcfile" > "$lockfile" fi $opt_dry_run || $RM $removelist func_append removelist " $lockfile" trap '$opt_dry_run || $RM $removelist; exit $EXIT_FAILURE' 1 2 15 func_to_tool_file "$srcfile" func_convert_file_msys_to_w32 srcfile=$func_to_tool_file_result func_quote_for_eval "$srcfile" qsrcfile=$func_quote_for_eval_result # Only build a PIC object if we are building libtool libraries. if test yes = "$build_libtool_libs"; then # Without this assignment, base_compile gets emptied. fbsd_hideous_sh_bug=$base_compile if test no != "$pic_mode"; then command="$base_compile $qsrcfile $pic_flag" else # Don't build PIC code command="$base_compile $qsrcfile" fi func_mkdir_p "$xdir$objdir" if test -z "$output_obj"; then # Place PIC objects in $objdir func_append command " -o $lobj" fi func_show_eval_locale "$command" \ 'test -n "$output_obj" && $RM $removelist; exit $EXIT_FAILURE' if test warn = "$need_locks" && test "X`cat $lockfile 2>/dev/null`" != "X$srcfile"; then $ECHO "\ *** ERROR, $lockfile contains: `cat $lockfile 2>/dev/null` but it should contain: $srcfile This indicates that another process is trying to use the same temporary object file, and libtool could not work around it because your compiler does not support '-c' and '-o' together. If you repeat this compilation, it may succeed, by chance, but you had better avoid parallel builds (make -j) in this platform, or get a better compiler." $opt_dry_run || $RM $removelist exit $EXIT_FAILURE fi # Just move the object if needed, then go on to compile the next one if test -n "$output_obj" && test "X$output_obj" != "X$lobj"; then func_show_eval '$MV "$output_obj" "$lobj"' \ 'error=$?; $opt_dry_run || $RM $removelist; exit $error' fi # Allow error messages only from the first compilation. if test yes = "$suppress_opt"; then suppress_output=' >/dev/null 2>&1' fi fi # Only build a position-dependent object if we build old libraries. if test yes = "$build_old_libs"; then if test yes != "$pic_mode"; then # Don't build PIC code command="$base_compile $qsrcfile$pie_flag" else command="$base_compile $qsrcfile $pic_flag" fi if test yes = "$compiler_c_o"; then func_append command " -o $obj" fi # Suppress compiler output if we already did a PIC compilation. func_append command "$suppress_output" func_show_eval_locale "$command" \ '$opt_dry_run || $RM $removelist; exit $EXIT_FAILURE' if test warn = "$need_locks" && test "X`cat $lockfile 2>/dev/null`" != "X$srcfile"; then $ECHO "\ *** ERROR, $lockfile contains: `cat $lockfile 2>/dev/null` but it should contain: $srcfile This indicates that another process is trying to use the same temporary object file, and libtool could not work around it because your compiler does not support '-c' and '-o' together. If you repeat this compilation, it may succeed, by chance, but you had better avoid parallel builds (make -j) in this platform, or get a better compiler." $opt_dry_run || $RM $removelist exit $EXIT_FAILURE fi # Just move the object if needed if test -n "$output_obj" && test "X$output_obj" != "X$obj"; then func_show_eval '$MV "$output_obj" "$obj"' \ 'error=$?; $opt_dry_run || $RM $removelist; exit $error' fi fi $opt_dry_run || { func_write_libtool_object "$libobj" "$objdir/$objname" "$objname" # Unlock the critical section if it was locked if test no != "$need_locks"; then removelist=$lockfile $RM "$lockfile" fi } exit $EXIT_SUCCESS } $opt_help || { test compile = "$opt_mode" && func_mode_compile ${1+"$@"} } func_mode_help () { # We need to display help for each of the modes. case $opt_mode in "") # Generic help is extracted from the usage comments # at the start of this file. func_help ;; clean) $ECHO \ "Usage: $progname [OPTION]... --mode=clean RM [RM-OPTION]... FILE... Remove files from the build directory. RM is the name of the program to use to delete files associated with each FILE (typically '/bin/rm'). RM-OPTIONS are options (such as '-f') to be passed to RM. If FILE is a libtool library, object or program, all the files associated with it are deleted. Otherwise, only FILE itself is deleted using RM." ;; compile) $ECHO \ "Usage: $progname [OPTION]... --mode=compile COMPILE-COMMAND... SOURCEFILE Compile a source file into a libtool library object. This mode accepts the following additional options: -o OUTPUT-FILE set the output file name to OUTPUT-FILE -no-suppress do not suppress compiler output for multiple passes -prefer-pic try to build PIC objects only -prefer-non-pic try to build non-PIC objects only -shared do not build a '.o' file suitable for static linking -static only build a '.o' file suitable for static linking -Wc,FLAG pass FLAG directly to the compiler COMPILE-COMMAND is a command to be used in creating a 'standard' object file from the given SOURCEFILE. The output file name is determined by removing the directory component from SOURCEFILE, then substituting the C source code suffix '.c' with the library object suffix, '.lo'." ;; execute) $ECHO \ "Usage: $progname [OPTION]... --mode=execute COMMAND [ARGS]... Automatically set library path, then run a program. This mode accepts the following additional options: -dlopen FILE add the directory containing FILE to the library path This mode sets the library path environment variable according to '-dlopen' flags. If any of the ARGS are libtool executable wrappers, then they are translated into their corresponding uninstalled binary, and any of their required library directories are added to the library path. Then, COMMAND is executed, with ARGS as arguments." ;; finish) $ECHO \ "Usage: $progname [OPTION]... --mode=finish [LIBDIR]... Complete the installation of libtool libraries. Each LIBDIR is a directory that contains libtool libraries. The commands that this mode executes may require superuser privileges. Use the '--dry-run' option if you just want to see what would be executed." ;; install) $ECHO \ "Usage: $progname [OPTION]... --mode=install INSTALL-COMMAND... Install executables or libraries. INSTALL-COMMAND is the installation command. The first component should be either the 'install' or 'cp' program. The following components of INSTALL-COMMAND are treated specially: -inst-prefix-dir PREFIX-DIR Use PREFIX-DIR as a staging area for installation The rest of the components are interpreted as arguments to that command (only BSD-compatible install options are recognized)." ;; link) $ECHO \ "Usage: $progname [OPTION]... --mode=link LINK-COMMAND... Link object files or libraries together to form another library, or to create an executable program. LINK-COMMAND is a command using the C compiler that you would use to create a program from several object files. The following components of LINK-COMMAND are treated specially: -all-static do not do any dynamic linking at all -avoid-version do not add a version suffix if possible -bindir BINDIR specify path to binaries directory (for systems where libraries must be found in the PATH setting at runtime) -dlopen FILE '-dlpreopen' FILE if it cannot be dlopened at runtime -dlpreopen FILE link in FILE and add its symbols to lt_preloaded_symbols -export-dynamic allow symbols from OUTPUT-FILE to be resolved with dlsym(3) -export-symbols SYMFILE try to export only the symbols listed in SYMFILE -export-symbols-regex REGEX try to export only the symbols matching REGEX -LLIBDIR search LIBDIR for required installed libraries -lNAME OUTPUT-FILE requires the installed library libNAME -module build a library that can dlopened -no-fast-install disable the fast-install mode -no-install link a not-installable executable -no-undefined declare that a library does not refer to external symbols -o OUTPUT-FILE create OUTPUT-FILE from the specified objects -objectlist FILE use a list of object files found in FILE to specify objects -os2dllname NAME force a short DLL name on OS/2 (no effect on other OSes) -precious-files-regex REGEX don't remove output files matching REGEX -release RELEASE specify package release information -rpath LIBDIR the created library will eventually be installed in LIBDIR -R[ ]LIBDIR add LIBDIR to the runtime path of programs and libraries -shared only do dynamic linking of libtool libraries -shrext SUFFIX override the standard shared library file extension -static do not do any dynamic linking of uninstalled libtool libraries -static-libtool-libs do not do any dynamic linking of libtool libraries -version-info CURRENT[:REVISION[:AGE]] specify library version info [each variable defaults to 0] -weak LIBNAME declare that the target provides the LIBNAME interface -Wc,FLAG -Xcompiler FLAG pass linker-specific FLAG directly to the compiler -Wl,FLAG -Xlinker FLAG pass linker-specific FLAG directly to the linker -XCClinker FLAG pass link-specific FLAG to the compiler driver (CC) All other options (arguments beginning with '-') are ignored. Every other argument is treated as a filename. Files ending in '.la' are treated as uninstalled libtool libraries, other files are standard or library object files. If the OUTPUT-FILE ends in '.la', then a libtool library is created, only library objects ('.lo' files) may be specified, and '-rpath' is required, except when creating a convenience library. If OUTPUT-FILE ends in '.a' or '.lib', then a standard library is created using 'ar' and 'ranlib', or on Windows using 'lib'. If OUTPUT-FILE ends in '.lo' or '.$objext', then a reloadable object file is created, otherwise an executable program is created." ;; uninstall) $ECHO \ "Usage: $progname [OPTION]... --mode=uninstall RM [RM-OPTION]... FILE... Remove libraries from an installation directory. RM is the name of the program to use to delete files associated with each FILE (typically '/bin/rm'). RM-OPTIONS are options (such as '-f') to be passed to RM. If FILE is a libtool library, all the files associated with it are deleted. Otherwise, only FILE itself is deleted using RM." ;; *) func_fatal_help "invalid operation mode '$opt_mode'" ;; esac echo $ECHO "Try '$progname --help' for more information about other modes." } # Now that we've collected a possible --mode arg, show help if necessary if $opt_help; then if test : = "$opt_help"; then func_mode_help else { func_help noexit for opt_mode in compile link execute install finish uninstall clean; do func_mode_help done } | $SED -n '1p; 2,$s/^Usage:/ or: /p' { func_help noexit for opt_mode in compile link execute install finish uninstall clean; do echo func_mode_help done } | $SED '1d /^When reporting/,/^Report/{ H d } $x /information about other modes/d /more detailed .*MODE/d s/^Usage:.*--mode=\([^ ]*\) .*/Description of \1 mode:/' fi exit $? fi # func_mode_execute arg... func_mode_execute () { $debug_cmd # The first argument is the command name. cmd=$nonopt test -z "$cmd" && \ func_fatal_help "you must specify a COMMAND" # Handle -dlopen flags immediately. for file in $opt_dlopen; do test -f "$file" \ || func_fatal_help "'$file' is not a file" dir= case $file in *.la) func_resolve_sysroot "$file" file=$func_resolve_sysroot_result # Check to see that this really is a libtool archive. func_lalib_unsafe_p "$file" \ || func_fatal_help "'$lib' is not a valid libtool archive" # Read the libtool library. dlname= library_names= func_source "$file" # Skip this library if it cannot be dlopened. if test -z "$dlname"; then # Warn if it was a shared library. test -n "$library_names" && \ func_warning "'$file' was not linked with '-export-dynamic'" continue fi func_dirname "$file" "" "." dir=$func_dirname_result if test -f "$dir/$objdir/$dlname"; then func_append dir "/$objdir" else if test ! -f "$dir/$dlname"; then func_fatal_error "cannot find '$dlname' in '$dir' or '$dir/$objdir'" fi fi ;; *.lo) # Just add the directory containing the .lo file. func_dirname "$file" "" "." dir=$func_dirname_result ;; *) func_warning "'-dlopen' is ignored for non-libtool libraries and objects" continue ;; esac # Get the absolute pathname. absdir=`cd "$dir" && pwd` test -n "$absdir" && dir=$absdir # Now add the directory to shlibpath_var. if eval "test -z \"\$$shlibpath_var\""; then eval "$shlibpath_var=\"\$dir\"" else eval "$shlibpath_var=\"\$dir:\$$shlibpath_var\"" fi done # This variable tells wrapper scripts just to set shlibpath_var # rather than running their programs. libtool_execute_magic=$magic # Check if any of the arguments is a wrapper script. args= for file do case $file in -* | *.la | *.lo ) ;; *) # Do a test to see if this is really a libtool program. if func_ltwrapper_script_p "$file"; then func_source "$file" # Transform arg to wrapped name. file=$progdir/$program elif func_ltwrapper_executable_p "$file"; then func_ltwrapper_scriptname "$file" func_source "$func_ltwrapper_scriptname_result" # Transform arg to wrapped name. file=$progdir/$program fi ;; esac # Quote arguments (to preserve shell metacharacters). func_append_quoted args "$file" done if $opt_dry_run; then # Display what would be done. if test -n "$shlibpath_var"; then eval "\$ECHO \"\$shlibpath_var=\$$shlibpath_var\"" echo "export $shlibpath_var" fi $ECHO "$cmd$args" exit $EXIT_SUCCESS else if test -n "$shlibpath_var"; then # Export the shlibpath_var. eval "export $shlibpath_var" fi # Restore saved environment variables for lt_var in LANG LANGUAGE LC_ALL LC_CTYPE LC_COLLATE LC_MESSAGES do eval "if test \"\${save_$lt_var+set}\" = set; then $lt_var=\$save_$lt_var; export $lt_var else $lt_unset $lt_var fi" done # Now prepare to actually exec the command. exec_cmd=\$cmd$args fi } test execute = "$opt_mode" && func_mode_execute ${1+"$@"} # func_mode_finish arg... func_mode_finish () { $debug_cmd libs= libdirs= admincmds= for opt in "$nonopt" ${1+"$@"} do if test -d "$opt"; then func_append libdirs " $opt" elif test -f "$opt"; then if func_lalib_unsafe_p "$opt"; then func_append libs " $opt" else func_warning "'$opt' is not a valid libtool archive" fi else func_fatal_error "invalid argument '$opt'" fi done if test -n "$libs"; then if test -n "$lt_sysroot"; then sysroot_regex=`$ECHO "$lt_sysroot" | $SED "$sed_make_literal_regex"` sysroot_cmd="s/\([ ']\)$sysroot_regex/\1/g;" else sysroot_cmd= fi # Remove sysroot references if $opt_dry_run; then for lib in $libs; do echo "removing references to $lt_sysroot and '=' prefixes from $lib" done else tmpdir=`func_mktempdir` for lib in $libs; do $SED -e "$sysroot_cmd s/\([ ']-[LR]\)=/\1/g; s/\([ ']\)=/\1/g" $lib \ > $tmpdir/tmp-la mv -f $tmpdir/tmp-la $lib done ${RM}r "$tmpdir" fi fi if test -n "$finish_cmds$finish_eval" && test -n "$libdirs"; then for libdir in $libdirs; do if test -n "$finish_cmds"; then # Do each command in the finish commands. func_execute_cmds "$finish_cmds" 'admincmds="$admincmds '"$cmd"'"' fi if test -n "$finish_eval"; then # Do the single finish_eval. eval cmds=\"$finish_eval\" $opt_dry_run || eval "$cmds" || func_append admincmds " $cmds" fi done fi # Exit here if they wanted silent mode. $opt_quiet && exit $EXIT_SUCCESS if test -n "$finish_cmds$finish_eval" && test -n "$libdirs"; then echo "----------------------------------------------------------------------" echo "Libraries have been installed in:" for libdir in $libdirs; do $ECHO " $libdir" done echo echo "If you ever happen to want to link against installed libraries" echo "in a given directory, LIBDIR, you must either use libtool, and" echo "specify the full pathname of the library, or use the '-LLIBDIR'" echo "flag during linking and do at least one of the following:" if test -n "$shlibpath_var"; then echo " - add LIBDIR to the '$shlibpath_var' environment variable" echo " during execution" fi if test -n "$runpath_var"; then echo " - add LIBDIR to the '$runpath_var' environment variable" echo " during linking" fi if test -n "$hardcode_libdir_flag_spec"; then libdir=LIBDIR eval flag=\"$hardcode_libdir_flag_spec\" $ECHO " - use the '$flag' linker flag" fi if test -n "$admincmds"; then $ECHO " - have your system administrator run these commands:$admincmds" fi if test -f /etc/ld.so.conf; then echo " - have your system administrator add LIBDIR to '/etc/ld.so.conf'" fi echo echo "See any operating system documentation about shared libraries for" case $host in solaris2.[6789]|solaris2.1[0-9]) echo "more information, such as the ld(1), crle(1) and ld.so(8) manual" echo "pages." ;; *) echo "more information, such as the ld(1) and ld.so(8) manual pages." ;; esac echo "----------------------------------------------------------------------" fi exit $EXIT_SUCCESS } test finish = "$opt_mode" && func_mode_finish ${1+"$@"} # func_mode_install arg... func_mode_install () { $debug_cmd # There may be an optional sh(1) argument at the beginning of # install_prog (especially on Windows NT). if test "$SHELL" = "$nonopt" || test /bin/sh = "$nonopt" || # Allow the use of GNU shtool's install command. case $nonopt in *shtool*) :;; *) false;; esac then # Aesthetically quote it. func_quote_for_eval "$nonopt" install_prog="$func_quote_for_eval_result " arg=$1 shift else install_prog= arg=$nonopt fi # The real first argument should be the name of the installation program. # Aesthetically quote it. func_quote_for_eval "$arg" func_append install_prog "$func_quote_for_eval_result" install_shared_prog=$install_prog case " $install_prog " in *[\\\ /]cp\ *) install_cp=: ;; *) install_cp=false ;; esac # We need to accept at least all the BSD install flags. dest= files= opts= prev= install_type= isdir=false stripme= no_mode=: for arg do arg2= if test -n "$dest"; then func_append files " $dest" dest=$arg continue fi case $arg in -d) isdir=: ;; -f) if $install_cp; then :; else prev=$arg fi ;; -g | -m | -o) prev=$arg ;; -s) stripme=" -s" continue ;; -*) ;; *) # If the previous option needed an argument, then skip it. if test -n "$prev"; then if test X-m = "X$prev" && test -n "$install_override_mode"; then arg2=$install_override_mode no_mode=false fi prev= else dest=$arg continue fi ;; esac # Aesthetically quote the argument. func_quote_for_eval "$arg" func_append install_prog " $func_quote_for_eval_result" if test -n "$arg2"; then func_quote_for_eval "$arg2" fi func_append install_shared_prog " $func_quote_for_eval_result" done test -z "$install_prog" && \ func_fatal_help "you must specify an install program" test -n "$prev" && \ func_fatal_help "the '$prev' option requires an argument" if test -n "$install_override_mode" && $no_mode; then if $install_cp; then :; else func_quote_for_eval "$install_override_mode" func_append install_shared_prog " -m $func_quote_for_eval_result" fi fi if test -z "$files"; then if test -z "$dest"; then func_fatal_help "no file or destination specified" else func_fatal_help "you must specify a destination" fi fi # Strip any trailing slash from the destination. func_stripname '' '/' "$dest" dest=$func_stripname_result # Check to see that the destination is a directory. test -d "$dest" && isdir=: if $isdir; then destdir=$dest destname= else func_dirname_and_basename "$dest" "" "." destdir=$func_dirname_result destname=$func_basename_result # Not a directory, so check to see that there is only one file specified. set dummy $files; shift test "$#" -gt 1 && \ func_fatal_help "'$dest' is not a directory" fi case $destdir in [\\/]* | [A-Za-z]:[\\/]*) ;; *) for file in $files; do case $file in *.lo) ;; *) func_fatal_help "'$destdir' must be an absolute directory name" ;; esac done ;; esac # This variable tells wrapper scripts just to set variables rather # than running their programs. libtool_install_magic=$magic staticlibs= future_libdirs= current_libdirs= for file in $files; do # Do each installation. case $file in *.$libext) # Do the static libraries later. func_append staticlibs " $file" ;; *.la) func_resolve_sysroot "$file" file=$func_resolve_sysroot_result # Check to see that this really is a libtool archive. func_lalib_unsafe_p "$file" \ || func_fatal_help "'$file' is not a valid libtool archive" library_names= old_library= relink_command= func_source "$file" # Add the libdir to current_libdirs if it is the destination. if test "X$destdir" = "X$libdir"; then case "$current_libdirs " in *" $libdir "*) ;; *) func_append current_libdirs " $libdir" ;; esac else # Note the libdir as a future libdir. case "$future_libdirs " in *" $libdir "*) ;; *) func_append future_libdirs " $libdir" ;; esac fi func_dirname "$file" "/" "" dir=$func_dirname_result func_append dir "$objdir" if test -n "$relink_command"; then # Determine the prefix the user has applied to our future dir. inst_prefix_dir=`$ECHO "$destdir" | $SED -e "s%$libdir\$%%"` # Don't allow the user to place us outside of our expected # location b/c this prevents finding dependent libraries that # are installed to the same prefix. # At present, this check doesn't affect windows .dll's that # are installed into $libdir/../bin (currently, that works fine) # but it's something to keep an eye on. test "$inst_prefix_dir" = "$destdir" && \ func_fatal_error "error: cannot install '$file' to a directory not ending in $libdir" if test -n "$inst_prefix_dir"; then # Stick the inst_prefix_dir data into the link command. relink_command=`$ECHO "$relink_command" | $SED "s%@inst_prefix_dir@%-inst-prefix-dir $inst_prefix_dir%"` else relink_command=`$ECHO "$relink_command" | $SED "s%@inst_prefix_dir@%%"` fi func_warning "relinking '$file'" func_show_eval "$relink_command" \ 'func_fatal_error "error: relink '\''$file'\'' with the above command before installing it"' fi # See the names of the shared library. set dummy $library_names; shift if test -n "$1"; then realname=$1 shift srcname=$realname test -n "$relink_command" && srcname=${realname}T # Install the shared library and build the symlinks. func_show_eval "$install_shared_prog $dir/$srcname $destdir/$realname" \ 'exit $?' tstripme=$stripme case $host_os in cygwin* | mingw* | pw32* | cegcc*) case $realname in *.dll.a) tstripme= ;; esac ;; os2*) case $realname in *_dll.a) tstripme= ;; esac ;; esac if test -n "$tstripme" && test -n "$striplib"; then func_show_eval "$striplib $destdir/$realname" 'exit $?' fi if test "$#" -gt 0; then # Delete the old symlinks, and create new ones. # Try 'ln -sf' first, because the 'ln' binary might depend on # the symlink we replace! Solaris /bin/ln does not understand -f, # so we also need to try rm && ln -s. for linkname do test "$linkname" != "$realname" \ && func_show_eval "(cd $destdir && { $LN_S -f $realname $linkname || { $RM $linkname && $LN_S $realname $linkname; }; })" done fi # Do each command in the postinstall commands. lib=$destdir/$realname func_execute_cmds "$postinstall_cmds" 'exit $?' fi # Install the pseudo-library for information purposes. func_basename "$file" name=$func_basename_result instname=$dir/${name}i func_show_eval "$install_prog $instname $destdir/$name" 'exit $?' # Maybe install the static library, too. test -n "$old_library" && func_append staticlibs " $dir/$old_library" ;; *.lo) # Install (i.e. copy) a libtool object. # Figure out destination file name, if it wasn't already specified. if test -n "$destname"; then destfile=$destdir/$destname else func_basename "$file" destfile=$func_basename_result destfile=$destdir/$destfile fi # Deduce the name of the destination old-style object file. case $destfile in *.lo) func_lo2o "$destfile" staticdest=$func_lo2o_result ;; *.$objext) staticdest=$destfile destfile= ;; *) func_fatal_help "cannot copy a libtool object to '$destfile'" ;; esac # Install the libtool object if requested. test -n "$destfile" && \ func_show_eval "$install_prog $file $destfile" 'exit $?' # Install the old object if enabled. if test yes = "$build_old_libs"; then # Deduce the name of the old-style object file. func_lo2o "$file" staticobj=$func_lo2o_result func_show_eval "$install_prog \$staticobj \$staticdest" 'exit $?' fi exit $EXIT_SUCCESS ;; *) # Figure out destination file name, if it wasn't already specified. if test -n "$destname"; then destfile=$destdir/$destname else func_basename "$file" destfile=$func_basename_result destfile=$destdir/$destfile fi # If the file is missing, and there is a .exe on the end, strip it # because it is most likely a libtool script we actually want to # install stripped_ext= case $file in *.exe) if test ! -f "$file"; then func_stripname '' '.exe' "$file" file=$func_stripname_result stripped_ext=.exe fi ;; esac # Do a test to see if this is really a libtool program. case $host in *cygwin* | *mingw*) if func_ltwrapper_executable_p "$file"; then func_ltwrapper_scriptname "$file" wrapper=$func_ltwrapper_scriptname_result else func_stripname '' '.exe' "$file" wrapper=$func_stripname_result fi ;; *) wrapper=$file ;; esac if func_ltwrapper_script_p "$wrapper"; then notinst_deplibs= relink_command= func_source "$wrapper" # Check the variables that should have been set. test -z "$generated_by_libtool_version" && \ func_fatal_error "invalid libtool wrapper script '$wrapper'" finalize=: for lib in $notinst_deplibs; do # Check to see that each library is installed. libdir= if test -f "$lib"; then func_source "$lib" fi libfile=$libdir/`$ECHO "$lib" | $SED 's%^.*/%%g'` if test -n "$libdir" && test ! -f "$libfile"; then func_warning "'$lib' has not been installed in '$libdir'" finalize=false fi done relink_command= func_source "$wrapper" outputname= if test no = "$fast_install" && test -n "$relink_command"; then $opt_dry_run || { if $finalize; then tmpdir=`func_mktempdir` func_basename "$file$stripped_ext" file=$func_basename_result outputname=$tmpdir/$file # Replace the output file specification. relink_command=`$ECHO "$relink_command" | $SED 's%@OUTPUT@%'"$outputname"'%g'` $opt_quiet || { func_quote_for_expand "$relink_command" eval "func_echo $func_quote_for_expand_result" } if eval "$relink_command"; then : else func_error "error: relink '$file' with the above command before installing it" $opt_dry_run || ${RM}r "$tmpdir" continue fi file=$outputname else func_warning "cannot relink '$file'" fi } else # Install the binary that we compiled earlier. file=`$ECHO "$file$stripped_ext" | $SED "s%\([^/]*\)$%$objdir/\1%"` fi fi # remove .exe since cygwin /usr/bin/install will append another # one anyway case $install_prog,$host in */usr/bin/install*,*cygwin*) case $file:$destfile in *.exe:*.exe) # this is ok ;; *.exe:*) destfile=$destfile.exe ;; *:*.exe) func_stripname '' '.exe' "$destfile" destfile=$func_stripname_result ;; esac ;; esac func_show_eval "$install_prog\$stripme \$file \$destfile" 'exit $?' $opt_dry_run || if test -n "$outputname"; then ${RM}r "$tmpdir" fi ;; esac done for file in $staticlibs; do func_basename "$file" name=$func_basename_result # Set up the ranlib parameters. oldlib=$destdir/$name func_to_tool_file "$oldlib" func_convert_file_msys_to_w32 tool_oldlib=$func_to_tool_file_result func_show_eval "$install_prog \$file \$oldlib" 'exit $?' if test -n "$stripme" && test -n "$old_striplib"; then func_show_eval "$old_striplib $tool_oldlib" 'exit $?' fi # Do each command in the postinstall commands. func_execute_cmds "$old_postinstall_cmds" 'exit $?' done test -n "$future_libdirs" && \ func_warning "remember to run '$progname --finish$future_libdirs'" if test -n "$current_libdirs"; then # Maybe just do a dry run. $opt_dry_run && current_libdirs=" -n$current_libdirs" exec_cmd='$SHELL "$progpath" $preserve_args --finish$current_libdirs' else exit $EXIT_SUCCESS fi } test install = "$opt_mode" && func_mode_install ${1+"$@"} # func_generate_dlsyms outputname originator pic_p # Extract symbols from dlprefiles and create ${outputname}S.o with # a dlpreopen symbol table. func_generate_dlsyms () { $debug_cmd my_outputname=$1 my_originator=$2 my_pic_p=${3-false} my_prefix=`$ECHO "$my_originator" | $SED 's%[^a-zA-Z0-9]%_%g'` my_dlsyms= if test -n "$dlfiles$dlprefiles" || test no != "$dlself"; then if test -n "$NM" && test -n "$global_symbol_pipe"; then my_dlsyms=${my_outputname}S.c else func_error "not configured to extract global symbols from dlpreopened files" fi fi if test -n "$my_dlsyms"; then case $my_dlsyms in "") ;; *.c) # Discover the nlist of each of the dlfiles. nlist=$output_objdir/$my_outputname.nm func_show_eval "$RM $nlist ${nlist}S ${nlist}T" # Parse the name list into a source file. func_verbose "creating $output_objdir/$my_dlsyms" $opt_dry_run || $ECHO > "$output_objdir/$my_dlsyms" "\ /* $my_dlsyms - symbol resolution table for '$my_outputname' dlsym emulation. */ /* Generated by $PROGRAM (GNU $PACKAGE) $VERSION */ #ifdef __cplusplus extern \"C\" { #endif #if defined __GNUC__ && (((__GNUC__ == 4) && (__GNUC_MINOR__ >= 4)) || (__GNUC__ > 4)) #pragma GCC diagnostic ignored \"-Wstrict-prototypes\" #endif /* Keep this code in sync between libtool.m4, ltmain, lt_system.h, and tests. */ #if defined _WIN32 || defined __CYGWIN__ || defined _WIN32_WCE /* DATA imports from DLLs on WIN32 can't be const, because runtime relocations are performed -- see ld's documentation on pseudo-relocs. */ # define LT_DLSYM_CONST #elif defined __osf__ /* This system does not cope well with relocations in const data. */ # define LT_DLSYM_CONST #else # define LT_DLSYM_CONST const #endif #define STREQ(s1, s2) (strcmp ((s1), (s2)) == 0) /* External symbol declarations for the compiler. */\ " if test yes = "$dlself"; then func_verbose "generating symbol list for '$output'" $opt_dry_run || echo ': @PROGRAM@ ' > "$nlist" # Add our own program objects to the symbol list. progfiles=`$ECHO "$objs$old_deplibs" | $SP2NL | $SED "$lo2o" | $NL2SP` for progfile in $progfiles; do func_to_tool_file "$progfile" func_convert_file_msys_to_w32 func_verbose "extracting global C symbols from '$func_to_tool_file_result'" $opt_dry_run || eval "$NM $func_to_tool_file_result | $global_symbol_pipe >> '$nlist'" done if test -n "$exclude_expsyms"; then $opt_dry_run || { eval '$EGREP -v " ($exclude_expsyms)$" "$nlist" > "$nlist"T' eval '$MV "$nlist"T "$nlist"' } fi if test -n "$export_symbols_regex"; then $opt_dry_run || { eval '$EGREP -e "$export_symbols_regex" "$nlist" > "$nlist"T' eval '$MV "$nlist"T "$nlist"' } fi # Prepare the list of exported symbols if test -z "$export_symbols"; then export_symbols=$output_objdir/$outputname.exp $opt_dry_run || { $RM $export_symbols eval "$SED -n -e '/^: @PROGRAM@ $/d' -e 's/^.* \(.*\)$/\1/p' "'< "$nlist" > "$export_symbols"' case $host in *cygwin* | *mingw* | *cegcc* ) eval "echo EXPORTS "'> "$output_objdir/$outputname.def"' eval 'cat "$export_symbols" >> "$output_objdir/$outputname.def"' ;; esac } else $opt_dry_run || { eval "$SED -e 's/\([].[*^$]\)/\\\\\1/g' -e 's/^/ /' -e 's/$/$/'"' < "$export_symbols" > "$output_objdir/$outputname.exp"' eval '$GREP -f "$output_objdir/$outputname.exp" < "$nlist" > "$nlist"T' eval '$MV "$nlist"T "$nlist"' case $host in *cygwin* | *mingw* | *cegcc* ) eval "echo EXPORTS "'> "$output_objdir/$outputname.def"' eval 'cat "$nlist" >> "$output_objdir/$outputname.def"' ;; esac } fi fi for dlprefile in $dlprefiles; do func_verbose "extracting global C symbols from '$dlprefile'" func_basename "$dlprefile" name=$func_basename_result case $host in *cygwin* | *mingw* | *cegcc* ) # if an import library, we need to obtain dlname if func_win32_import_lib_p "$dlprefile"; then func_tr_sh "$dlprefile" eval "curr_lafile=\$libfile_$func_tr_sh_result" dlprefile_dlbasename= if test -n "$curr_lafile" && func_lalib_p "$curr_lafile"; then # Use subshell, to avoid clobbering current variable values dlprefile_dlname=`source "$curr_lafile" && echo "$dlname"` if test -n "$dlprefile_dlname"; then func_basename "$dlprefile_dlname" dlprefile_dlbasename=$func_basename_result else # no lafile. user explicitly requested -dlpreopen . $sharedlib_from_linklib_cmd "$dlprefile" dlprefile_dlbasename=$sharedlib_from_linklib_result fi fi $opt_dry_run || { if test -n "$dlprefile_dlbasename"; then eval '$ECHO ": $dlprefile_dlbasename" >> "$nlist"' else func_warning "Could not compute DLL name from $name" eval '$ECHO ": $name " >> "$nlist"' fi func_to_tool_file "$dlprefile" func_convert_file_msys_to_w32 eval "$NM \"$func_to_tool_file_result\" 2>/dev/null | $global_symbol_pipe | $SED -e '/I __imp/d' -e 's/I __nm_/D /;s/_nm__//' >> '$nlist'" } else # not an import lib $opt_dry_run || { eval '$ECHO ": $name " >> "$nlist"' func_to_tool_file "$dlprefile" func_convert_file_msys_to_w32 eval "$NM \"$func_to_tool_file_result\" 2>/dev/null | $global_symbol_pipe >> '$nlist'" } fi ;; *) $opt_dry_run || { eval '$ECHO ": $name " >> "$nlist"' func_to_tool_file "$dlprefile" func_convert_file_msys_to_w32 eval "$NM \"$func_to_tool_file_result\" 2>/dev/null | $global_symbol_pipe >> '$nlist'" } ;; esac done $opt_dry_run || { # Make sure we have at least an empty file. test -f "$nlist" || : > "$nlist" if test -n "$exclude_expsyms"; then $EGREP -v " ($exclude_expsyms)$" "$nlist" > "$nlist"T $MV "$nlist"T "$nlist" fi # Try sorting and uniquifying the output. if $GREP -v "^: " < "$nlist" | if sort -k 3 /dev/null 2>&1; then sort -k 3 else sort +2 fi | uniq > "$nlist"S; then : else $GREP -v "^: " < "$nlist" > "$nlist"S fi if test -f "$nlist"S; then eval "$global_symbol_to_cdecl"' < "$nlist"S >> "$output_objdir/$my_dlsyms"' else echo '/* NONE */' >> "$output_objdir/$my_dlsyms" fi func_show_eval '$RM "${nlist}I"' if test -n "$global_symbol_to_import"; then eval "$global_symbol_to_import"' < "$nlist"S > "$nlist"I' fi echo >> "$output_objdir/$my_dlsyms" "\ /* The mapping between symbol names and symbols. */ typedef struct { const char *name; void *address; } lt_dlsymlist; extern LT_DLSYM_CONST lt_dlsymlist lt_${my_prefix}_LTX_preloaded_symbols[];\ " if test -s "$nlist"I; then echo >> "$output_objdir/$my_dlsyms" "\ static void lt_syminit(void) { LT_DLSYM_CONST lt_dlsymlist *symbol = lt_${my_prefix}_LTX_preloaded_symbols; for (; symbol->name; ++symbol) {" $SED 's/.*/ if (STREQ (symbol->name, \"&\")) symbol->address = (void *) \&&;/' < "$nlist"I >> "$output_objdir/$my_dlsyms" echo >> "$output_objdir/$my_dlsyms" "\ } }" fi echo >> "$output_objdir/$my_dlsyms" "\ LT_DLSYM_CONST lt_dlsymlist lt_${my_prefix}_LTX_preloaded_symbols[] = { {\"$my_originator\", (void *) 0}," if test -s "$nlist"I; then echo >> "$output_objdir/$my_dlsyms" "\ {\"@INIT@\", (void *) <_syminit}," fi case $need_lib_prefix in no) eval "$global_symbol_to_c_name_address" < "$nlist" >> "$output_objdir/$my_dlsyms" ;; *) eval "$global_symbol_to_c_name_address_lib_prefix" < "$nlist" >> "$output_objdir/$my_dlsyms" ;; esac echo >> "$output_objdir/$my_dlsyms" "\ {0, (void *) 0} }; /* This works around a problem in FreeBSD linker */ #ifdef FREEBSD_WORKAROUND static const void *lt_preloaded_setup() { return lt_${my_prefix}_LTX_preloaded_symbols; } #endif #ifdef __cplusplus } #endif\ " } # !$opt_dry_run pic_flag_for_symtable= case "$compile_command " in *" -static "*) ;; *) case $host in # compiling the symbol table file with pic_flag works around # a FreeBSD bug that causes programs to crash when -lm is # linked before any other PIC object. But we must not use # pic_flag when linking with -static. The problem exists in # FreeBSD 2.2.6 and is fixed in FreeBSD 3.1. *-*-freebsd2.*|*-*-freebsd3.0*|*-*-freebsdelf3.0*) pic_flag_for_symtable=" $pic_flag -DFREEBSD_WORKAROUND" ;; *-*-hpux*) pic_flag_for_symtable=" $pic_flag" ;; *) $my_pic_p && pic_flag_for_symtable=" $pic_flag" ;; esac ;; esac symtab_cflags= for arg in $LTCFLAGS; do case $arg in -pie | -fpie | -fPIE) ;; *) func_append symtab_cflags " $arg" ;; esac done # Now compile the dynamic symbol file. func_show_eval '(cd $output_objdir && $LTCC$symtab_cflags -c$no_builtin_flag$pic_flag_for_symtable "$my_dlsyms")' 'exit $?' # Clean up the generated files. func_show_eval '$RM "$output_objdir/$my_dlsyms" "$nlist" "${nlist}S" "${nlist}T" "${nlist}I"' # Transform the symbol file into the correct name. symfileobj=$output_objdir/${my_outputname}S.$objext case $host in *cygwin* | *mingw* | *cegcc* ) if test -f "$output_objdir/$my_outputname.def"; then compile_command=`$ECHO "$compile_command" | $SED "s%@SYMFILE@%$output_objdir/$my_outputname.def $symfileobj%"` finalize_command=`$ECHO "$finalize_command" | $SED "s%@SYMFILE@%$output_objdir/$my_outputname.def $symfileobj%"` else compile_command=`$ECHO "$compile_command" | $SED "s%@SYMFILE@%$symfileobj%"` finalize_command=`$ECHO "$finalize_command" | $SED "s%@SYMFILE@%$symfileobj%"` fi ;; *) compile_command=`$ECHO "$compile_command" | $SED "s%@SYMFILE@%$symfileobj%"` finalize_command=`$ECHO "$finalize_command" | $SED "s%@SYMFILE@%$symfileobj%"` ;; esac ;; *) func_fatal_error "unknown suffix for '$my_dlsyms'" ;; esac else # We keep going just in case the user didn't refer to # lt_preloaded_symbols. The linker will fail if global_symbol_pipe # really was required. # Nullify the symbol file. compile_command=`$ECHO "$compile_command" | $SED "s% @SYMFILE@%%"` finalize_command=`$ECHO "$finalize_command" | $SED "s% @SYMFILE@%%"` fi } # func_cygming_gnu_implib_p ARG # This predicate returns with zero status (TRUE) if # ARG is a GNU/binutils-style import library. Returns # with nonzero status (FALSE) otherwise. func_cygming_gnu_implib_p () { $debug_cmd func_to_tool_file "$1" func_convert_file_msys_to_w32 func_cygming_gnu_implib_tmp=`$NM "$func_to_tool_file_result" | eval "$global_symbol_pipe" | $EGREP ' (_head_[A-Za-z0-9_]+_[ad]l*|[A-Za-z0-9_]+_[ad]l*_iname)$'` test -n "$func_cygming_gnu_implib_tmp" } # func_cygming_ms_implib_p ARG # This predicate returns with zero status (TRUE) if # ARG is an MS-style import library. Returns # with nonzero status (FALSE) otherwise. func_cygming_ms_implib_p () { $debug_cmd func_to_tool_file "$1" func_convert_file_msys_to_w32 func_cygming_ms_implib_tmp=`$NM "$func_to_tool_file_result" | eval "$global_symbol_pipe" | $GREP '_NULL_IMPORT_DESCRIPTOR'` test -n "$func_cygming_ms_implib_tmp" } # func_win32_libid arg # return the library type of file 'arg' # # Need a lot of goo to handle *both* DLLs and import libs # Has to be a shell function in order to 'eat' the argument # that is supplied when $file_magic_command is called. # Despite the name, also deal with 64 bit binaries. func_win32_libid () { $debug_cmd win32_libid_type=unknown win32_fileres=`file -L $1 2>/dev/null` case $win32_fileres in *ar\ archive\ import\ library*) # definitely import win32_libid_type="x86 archive import" ;; *ar\ archive*) # could be an import, or static # Keep the egrep pattern in sync with the one in _LT_CHECK_MAGIC_METHOD. if eval $OBJDUMP -f $1 | $SED -e '10q' 2>/dev/null | $EGREP 'file format (pei*-i386(.*architecture: i386)?|pe-arm-wince|pe-x86-64)' >/dev/null; then case $nm_interface in "MS dumpbin") if func_cygming_ms_implib_p "$1" || func_cygming_gnu_implib_p "$1" then win32_nmres=import else win32_nmres= fi ;; *) func_to_tool_file "$1" func_convert_file_msys_to_w32 win32_nmres=`eval $NM -f posix -A \"$func_to_tool_file_result\" | $SED -n -e ' 1,100{ / I /{ s|.*|import| p q } }'` ;; esac case $win32_nmres in import*) win32_libid_type="x86 archive import";; *) win32_libid_type="x86 archive static";; esac fi ;; *DLL*) win32_libid_type="x86 DLL" ;; *executable*) # but shell scripts are "executable" too... case $win32_fileres in *MS\ Windows\ PE\ Intel*) win32_libid_type="x86 DLL" ;; esac ;; esac $ECHO "$win32_libid_type" } # func_cygming_dll_for_implib ARG # # Platform-specific function to extract the # name of the DLL associated with the specified # import library ARG. # Invoked by eval'ing the libtool variable # $sharedlib_from_linklib_cmd # Result is available in the variable # $sharedlib_from_linklib_result func_cygming_dll_for_implib () { $debug_cmd sharedlib_from_linklib_result=`$DLLTOOL --identify-strict --identify "$1"` } # func_cygming_dll_for_implib_fallback_core SECTION_NAME LIBNAMEs # # The is the core of a fallback implementation of a # platform-specific function to extract the name of the # DLL associated with the specified import library LIBNAME. # # SECTION_NAME is either .idata$6 or .idata$7, depending # on the platform and compiler that created the implib. # # Echos the name of the DLL associated with the # specified import library. func_cygming_dll_for_implib_fallback_core () { $debug_cmd match_literal=`$ECHO "$1" | $SED "$sed_make_literal_regex"` $OBJDUMP -s --section "$1" "$2" 2>/dev/null | $SED '/^Contents of section '"$match_literal"':/{ # Place marker at beginning of archive member dllname section s/.*/====MARK====/ p d } # These lines can sometimes be longer than 43 characters, but # are always uninteresting /:[ ]*file format pe[i]\{,1\}-/d /^In archive [^:]*:/d # Ensure marker is printed /^====MARK====/p # Remove all lines with less than 43 characters /^.\{43\}/!d # From remaining lines, remove first 43 characters s/^.\{43\}//' | $SED -n ' # Join marker and all lines until next marker into a single line /^====MARK====/ b para H $ b para b :para x s/\n//g # Remove the marker s/^====MARK====// # Remove trailing dots and whitespace s/[\. \t]*$// # Print /./p' | # we now have a list, one entry per line, of the stringified # contents of the appropriate section of all members of the # archive that possess that section. Heuristic: eliminate # all those that have a first or second character that is # a '.' (that is, objdump's representation of an unprintable # character.) This should work for all archives with less than # 0x302f exports -- but will fail for DLLs whose name actually # begins with a literal '.' or a single character followed by # a '.'. # # Of those that remain, print the first one. $SED -e '/^\./d;/^.\./d;q' } # func_cygming_dll_for_implib_fallback ARG # Platform-specific function to extract the # name of the DLL associated with the specified # import library ARG. # # This fallback implementation is for use when $DLLTOOL # does not support the --identify-strict option. # Invoked by eval'ing the libtool variable # $sharedlib_from_linklib_cmd # Result is available in the variable # $sharedlib_from_linklib_result func_cygming_dll_for_implib_fallback () { $debug_cmd if func_cygming_gnu_implib_p "$1"; then # binutils import library sharedlib_from_linklib_result=`func_cygming_dll_for_implib_fallback_core '.idata$7' "$1"` elif func_cygming_ms_implib_p "$1"; then # ms-generated import library sharedlib_from_linklib_result=`func_cygming_dll_for_implib_fallback_core '.idata$6' "$1"` else # unknown sharedlib_from_linklib_result= fi } # func_extract_an_archive dir oldlib func_extract_an_archive () { $debug_cmd f_ex_an_ar_dir=$1; shift f_ex_an_ar_oldlib=$1 if test yes = "$lock_old_archive_extraction"; then lockfile=$f_ex_an_ar_oldlib.lock until $opt_dry_run || ln "$progpath" "$lockfile" 2>/dev/null; do func_echo "Waiting for $lockfile to be removed" sleep 2 done fi func_show_eval "(cd \$f_ex_an_ar_dir && $AR x \"\$f_ex_an_ar_oldlib\")" \ 'stat=$?; rm -f "$lockfile"; exit $stat' if test yes = "$lock_old_archive_extraction"; then $opt_dry_run || rm -f "$lockfile" fi if ($AR t "$f_ex_an_ar_oldlib" | sort | sort -uc >/dev/null 2>&1); then : else func_fatal_error "object name conflicts in archive: $f_ex_an_ar_dir/$f_ex_an_ar_oldlib" fi } # func_extract_archives gentop oldlib ... func_extract_archives () { $debug_cmd my_gentop=$1; shift my_oldlibs=${1+"$@"} my_oldobjs= my_xlib= my_xabs= my_xdir= for my_xlib in $my_oldlibs; do # Extract the objects. case $my_xlib in [\\/]* | [A-Za-z]:[\\/]*) my_xabs=$my_xlib ;; *) my_xabs=`pwd`"/$my_xlib" ;; esac func_basename "$my_xlib" my_xlib=$func_basename_result my_xlib_u=$my_xlib while :; do case " $extracted_archives " in *" $my_xlib_u "*) func_arith $extracted_serial + 1 extracted_serial=$func_arith_result my_xlib_u=lt$extracted_serial-$my_xlib ;; *) break ;; esac done extracted_archives="$extracted_archives $my_xlib_u" my_xdir=$my_gentop/$my_xlib_u func_mkdir_p "$my_xdir" case $host in *-darwin*) func_verbose "Extracting $my_xabs" # Do not bother doing anything if just a dry run $opt_dry_run || { darwin_orig_dir=`pwd` cd $my_xdir || exit $? darwin_archive=$my_xabs darwin_curdir=`pwd` func_basename "$darwin_archive" darwin_base_archive=$func_basename_result darwin_arches=`$LIPO -info "$darwin_archive" 2>/dev/null | $GREP Architectures 2>/dev/null || true` if test -n "$darwin_arches"; then darwin_arches=`$ECHO "$darwin_arches" | $SED -e 's/.*are://'` darwin_arch= func_verbose "$darwin_base_archive has multiple architectures $darwin_arches" for darwin_arch in $darwin_arches; do func_mkdir_p "unfat-$$/$darwin_base_archive-$darwin_arch" $LIPO -thin $darwin_arch -output "unfat-$$/$darwin_base_archive-$darwin_arch/$darwin_base_archive" "$darwin_archive" cd "unfat-$$/$darwin_base_archive-$darwin_arch" func_extract_an_archive "`pwd`" "$darwin_base_archive" cd "$darwin_curdir" $RM "unfat-$$/$darwin_base_archive-$darwin_arch/$darwin_base_archive" done # $darwin_arches ## Okay now we've a bunch of thin objects, gotta fatten them up :) darwin_filelist=`find unfat-$$ -type f -name \*.o -print -o -name \*.lo -print | $SED -e "$sed_basename" | sort -u` darwin_file= darwin_files= for darwin_file in $darwin_filelist; do darwin_files=`find unfat-$$ -name $darwin_file -print | sort | $NL2SP` $LIPO -create -output "$darwin_file" $darwin_files done # $darwin_filelist $RM -rf unfat-$$ cd "$darwin_orig_dir" else cd $darwin_orig_dir func_extract_an_archive "$my_xdir" "$my_xabs" fi # $darwin_arches } # !$opt_dry_run ;; *) func_extract_an_archive "$my_xdir" "$my_xabs" ;; esac my_oldobjs="$my_oldobjs "`find $my_xdir -name \*.$objext -print -o -name \*.lo -print | sort | $NL2SP` done func_extract_archives_result=$my_oldobjs } # func_emit_wrapper [arg=no] # # Emit a libtool wrapper script on stdout. # Don't directly open a file because we may want to # incorporate the script contents within a cygwin/mingw # wrapper executable. Must ONLY be called from within # func_mode_link because it depends on a number of variables # set therein. # # ARG is the value that the WRAPPER_SCRIPT_BELONGS_IN_OBJDIR # variable will take. If 'yes', then the emitted script # will assume that the directory where it is stored is # the $objdir directory. This is a cygwin/mingw-specific # behavior. func_emit_wrapper () { func_emit_wrapper_arg1=${1-no} $ECHO "\ #! $SHELL # $output - temporary wrapper script for $objdir/$outputname # Generated by $PROGRAM (GNU $PACKAGE) $VERSION # # The $output program cannot be directly executed until all the libtool # libraries that it depends on are installed. # # This wrapper script should never be moved out of the build directory. # If it is, it will not operate correctly. # Sed substitution that helps us do robust quoting. It backslashifies # metacharacters that are still active within double-quoted strings. sed_quote_subst='$sed_quote_subst' # Be Bourne compatible if test -n \"\${ZSH_VERSION+set}\" && (emulate sh) >/dev/null 2>&1; then emulate sh NULLCMD=: # Zsh 3.x and 4.x performs word splitting on \${1+\"\$@\"}, which # is contrary to our usage. Disable this feature. alias -g '\${1+\"\$@\"}'='\"\$@\"' setopt NO_GLOB_SUBST else case \`(set -o) 2>/dev/null\` in *posix*) set -o posix;; esac fi BIN_SH=xpg4; export BIN_SH # for Tru64 DUALCASE=1; export DUALCASE # for MKS sh # The HP-UX ksh and POSIX shell print the target directory to stdout # if CDPATH is set. (unset CDPATH) >/dev/null 2>&1 && unset CDPATH relink_command=\"$relink_command\" # This environment variable determines our operation mode. if test \"\$libtool_install_magic\" = \"$magic\"; then # install mode needs the following variables: generated_by_libtool_version='$macro_version' notinst_deplibs='$notinst_deplibs' else # When we are sourced in execute mode, \$file and \$ECHO are already set. if test \"\$libtool_execute_magic\" != \"$magic\"; then file=\"\$0\"" qECHO=`$ECHO "$ECHO" | $SED "$sed_quote_subst"` $ECHO "\ # A function that is used when there is no print builtin or printf. func_fallback_echo () { eval 'cat <<_LTECHO_EOF \$1 _LTECHO_EOF' } ECHO=\"$qECHO\" fi # Very basic option parsing. These options are (a) specific to # the libtool wrapper, (b) are identical between the wrapper # /script/ and the wrapper /executable/ that is used only on # windows platforms, and (c) all begin with the string "--lt-" # (application programs are unlikely to have options that match # this pattern). # # There are only two supported options: --lt-debug and # --lt-dump-script. There is, deliberately, no --lt-help. # # The first argument to this parsing function should be the # script's $0 value, followed by "$@". lt_option_debug= func_parse_lt_options () { lt_script_arg0=\$0 shift for lt_opt do case \"\$lt_opt\" in --lt-debug) lt_option_debug=1 ;; --lt-dump-script) lt_dump_D=\`\$ECHO \"X\$lt_script_arg0\" | $SED -e 's/^X//' -e 's%/[^/]*$%%'\` test \"X\$lt_dump_D\" = \"X\$lt_script_arg0\" && lt_dump_D=. lt_dump_F=\`\$ECHO \"X\$lt_script_arg0\" | $SED -e 's/^X//' -e 's%^.*/%%'\` cat \"\$lt_dump_D/\$lt_dump_F\" exit 0 ;; --lt-*) \$ECHO \"Unrecognized --lt- option: '\$lt_opt'\" 1>&2 exit 1 ;; esac done # Print the debug banner immediately: if test -n \"\$lt_option_debug\"; then echo \"$outputname:$output:\$LINENO: libtool wrapper (GNU $PACKAGE) $VERSION\" 1>&2 fi } # Used when --lt-debug. Prints its arguments to stdout # (redirection is the responsibility of the caller) func_lt_dump_args () { lt_dump_args_N=1; for lt_arg do \$ECHO \"$outputname:$output:\$LINENO: newargv[\$lt_dump_args_N]: \$lt_arg\" lt_dump_args_N=\`expr \$lt_dump_args_N + 1\` done } # Core function for launching the target application func_exec_program_core () { " case $host in # Backslashes separate directories on plain windows *-*-mingw | *-*-os2* | *-cegcc*) $ECHO "\ if test -n \"\$lt_option_debug\"; then \$ECHO \"$outputname:$output:\$LINENO: newargv[0]: \$progdir\\\\\$program\" 1>&2 func_lt_dump_args \${1+\"\$@\"} 1>&2 fi exec \"\$progdir\\\\\$program\" \${1+\"\$@\"} " ;; *) $ECHO "\ if test -n \"\$lt_option_debug\"; then \$ECHO \"$outputname:$output:\$LINENO: newargv[0]: \$progdir/\$program\" 1>&2 func_lt_dump_args \${1+\"\$@\"} 1>&2 fi exec \"\$progdir/\$program\" \${1+\"\$@\"} " ;; esac $ECHO "\ \$ECHO \"\$0: cannot exec \$program \$*\" 1>&2 exit 1 } # A function to encapsulate launching the target application # Strips options in the --lt-* namespace from \$@ and # launches target application with the remaining arguments. func_exec_program () { case \" \$* \" in *\\ --lt-*) for lt_wr_arg do case \$lt_wr_arg in --lt-*) ;; *) set x \"\$@\" \"\$lt_wr_arg\"; shift;; esac shift done ;; esac func_exec_program_core \${1+\"\$@\"} } # Parse options func_parse_lt_options \"\$0\" \${1+\"\$@\"} # Find the directory that this script lives in. thisdir=\`\$ECHO \"\$file\" | $SED 's%/[^/]*$%%'\` test \"x\$thisdir\" = \"x\$file\" && thisdir=. # Follow symbolic links until we get to the real thisdir. file=\`ls -ld \"\$file\" | $SED -n 's/.*-> //p'\` while test -n \"\$file\"; do destdir=\`\$ECHO \"\$file\" | $SED 's%/[^/]*\$%%'\` # If there was a directory component, then change thisdir. if test \"x\$destdir\" != \"x\$file\"; then case \"\$destdir\" in [\\\\/]* | [A-Za-z]:[\\\\/]*) thisdir=\"\$destdir\" ;; *) thisdir=\"\$thisdir/\$destdir\" ;; esac fi file=\`\$ECHO \"\$file\" | $SED 's%^.*/%%'\` file=\`ls -ld \"\$thisdir/\$file\" | $SED -n 's/.*-> //p'\` done # Usually 'no', except on cygwin/mingw when embedded into # the cwrapper. WRAPPER_SCRIPT_BELONGS_IN_OBJDIR=$func_emit_wrapper_arg1 if test \"\$WRAPPER_SCRIPT_BELONGS_IN_OBJDIR\" = \"yes\"; then # special case for '.' if test \"\$thisdir\" = \".\"; then thisdir=\`pwd\` fi # remove .libs from thisdir case \"\$thisdir\" in *[\\\\/]$objdir ) thisdir=\`\$ECHO \"\$thisdir\" | $SED 's%[\\\\/][^\\\\/]*$%%'\` ;; $objdir ) thisdir=. ;; esac fi # Try to get the absolute directory name. absdir=\`cd \"\$thisdir\" && pwd\` test -n \"\$absdir\" && thisdir=\"\$absdir\" " if test yes = "$fast_install"; then $ECHO "\ program=lt-'$outputname'$exeext progdir=\"\$thisdir/$objdir\" if test ! -f \"\$progdir/\$program\" || { file=\`ls -1dt \"\$progdir/\$program\" \"\$progdir/../\$program\" 2>/dev/null | $SED 1q\`; \\ test \"X\$file\" != \"X\$progdir/\$program\"; }; then file=\"\$\$-\$program\" if test ! -d \"\$progdir\"; then $MKDIR \"\$progdir\" else $RM \"\$progdir/\$file\" fi" $ECHO "\ # relink executable if necessary if test -n \"\$relink_command\"; then if relink_command_output=\`eval \$relink_command 2>&1\`; then : else \$ECHO \"\$relink_command_output\" >&2 $RM \"\$progdir/\$file\" exit 1 fi fi $MV \"\$progdir/\$file\" \"\$progdir/\$program\" 2>/dev/null || { $RM \"\$progdir/\$program\"; $MV \"\$progdir/\$file\" \"\$progdir/\$program\"; } $RM \"\$progdir/\$file\" fi" else $ECHO "\ program='$outputname' progdir=\"\$thisdir/$objdir\" " fi $ECHO "\ if test -f \"\$progdir/\$program\"; then" # fixup the dll searchpath if we need to. # # Fix the DLL searchpath if we need to. Do this before prepending # to shlibpath, because on Windows, both are PATH and uninstalled # libraries must come first. if test -n "$dllsearchpath"; then $ECHO "\ # Add the dll search path components to the executable PATH PATH=$dllsearchpath:\$PATH " fi # Export our shlibpath_var if we have one. if test yes = "$shlibpath_overrides_runpath" && test -n "$shlibpath_var" && test -n "$temp_rpath"; then $ECHO "\ # Add our own library path to $shlibpath_var $shlibpath_var=\"$temp_rpath\$$shlibpath_var\" # Some systems cannot cope with colon-terminated $shlibpath_var # The second colon is a workaround for a bug in BeOS R4 sed $shlibpath_var=\`\$ECHO \"\$$shlibpath_var\" | $SED 's/::*\$//'\` export $shlibpath_var " fi $ECHO "\ if test \"\$libtool_execute_magic\" != \"$magic\"; then # Run the actual program with our arguments. func_exec_program \${1+\"\$@\"} fi else # The program doesn't exist. \$ECHO \"\$0: error: '\$progdir/\$program' does not exist\" 1>&2 \$ECHO \"This script is just a wrapper for \$program.\" 1>&2 \$ECHO \"See the $PACKAGE documentation for more information.\" 1>&2 exit 1 fi fi\ " } # func_emit_cwrapperexe_src # emit the source code for a wrapper executable on stdout # Must ONLY be called from within func_mode_link because # it depends on a number of variable set therein. func_emit_cwrapperexe_src () { cat < #include #ifdef _MSC_VER # include # include # include #else # include # include # ifdef __CYGWIN__ # include # endif #endif #include #include #include #include #include #include #include #include #define STREQ(s1, s2) (strcmp ((s1), (s2)) == 0) /* declarations of non-ANSI functions */ #if defined __MINGW32__ # ifdef __STRICT_ANSI__ int _putenv (const char *); # endif #elif defined __CYGWIN__ # ifdef __STRICT_ANSI__ char *realpath (const char *, char *); int putenv (char *); int setenv (const char *, const char *, int); # endif /* #elif defined other_platform || defined ... */ #endif /* portability defines, excluding path handling macros */ #if defined _MSC_VER # define setmode _setmode # define stat _stat # define chmod _chmod # define getcwd _getcwd # define putenv _putenv # define S_IXUSR _S_IEXEC #elif defined __MINGW32__ # define setmode _setmode # define stat _stat # define chmod _chmod # define getcwd _getcwd # define putenv _putenv #elif defined __CYGWIN__ # define HAVE_SETENV # define FOPEN_WB "wb" /* #elif defined other platforms ... */ #endif #if defined PATH_MAX # define LT_PATHMAX PATH_MAX #elif defined MAXPATHLEN # define LT_PATHMAX MAXPATHLEN #else # define LT_PATHMAX 1024 #endif #ifndef S_IXOTH # define S_IXOTH 0 #endif #ifndef S_IXGRP # define S_IXGRP 0 #endif /* path handling portability macros */ #ifndef DIR_SEPARATOR # define DIR_SEPARATOR '/' # define PATH_SEPARATOR ':' #endif #if defined _WIN32 || defined __MSDOS__ || defined __DJGPP__ || \ defined __OS2__ # define HAVE_DOS_BASED_FILE_SYSTEM # define FOPEN_WB "wb" # ifndef DIR_SEPARATOR_2 # define DIR_SEPARATOR_2 '\\' # endif # ifndef PATH_SEPARATOR_2 # define PATH_SEPARATOR_2 ';' # endif #endif #ifndef DIR_SEPARATOR_2 # define IS_DIR_SEPARATOR(ch) ((ch) == DIR_SEPARATOR) #else /* DIR_SEPARATOR_2 */ # define IS_DIR_SEPARATOR(ch) \ (((ch) == DIR_SEPARATOR) || ((ch) == DIR_SEPARATOR_2)) #endif /* DIR_SEPARATOR_2 */ #ifndef PATH_SEPARATOR_2 # define IS_PATH_SEPARATOR(ch) ((ch) == PATH_SEPARATOR) #else /* PATH_SEPARATOR_2 */ # define IS_PATH_SEPARATOR(ch) ((ch) == PATH_SEPARATOR_2) #endif /* PATH_SEPARATOR_2 */ #ifndef FOPEN_WB # define FOPEN_WB "w" #endif #ifndef _O_BINARY # define _O_BINARY 0 #endif #define XMALLOC(type, num) ((type *) xmalloc ((num) * sizeof(type))) #define XFREE(stale) do { \ if (stale) { free (stale); stale = 0; } \ } while (0) #if defined LT_DEBUGWRAPPER static int lt_debug = 1; #else static int lt_debug = 0; #endif const char *program_name = "libtool-wrapper"; /* in case xstrdup fails */ void *xmalloc (size_t num); char *xstrdup (const char *string); const char *base_name (const char *name); char *find_executable (const char *wrapper); char *chase_symlinks (const char *pathspec); int make_executable (const char *path); int check_executable (const char *path); char *strendzap (char *str, const char *pat); void lt_debugprintf (const char *file, int line, const char *fmt, ...); void lt_fatal (const char *file, int line, const char *message, ...); static const char *nonnull (const char *s); static const char *nonempty (const char *s); void lt_setenv (const char *name, const char *value); char *lt_extend_str (const char *orig_value, const char *add, int to_end); void lt_update_exe_path (const char *name, const char *value); void lt_update_lib_path (const char *name, const char *value); char **prepare_spawn (char **argv); void lt_dump_script (FILE *f); EOF cat <= 0) && (st.st_mode & (S_IXUSR | S_IXGRP | S_IXOTH))) return 1; else return 0; } int make_executable (const char *path) { int rval = 0; struct stat st; lt_debugprintf (__FILE__, __LINE__, "(make_executable): %s\n", nonempty (path)); if ((!path) || (!*path)) return 0; if (stat (path, &st) >= 0) { rval = chmod (path, st.st_mode | S_IXOTH | S_IXGRP | S_IXUSR); } return rval; } /* Searches for the full path of the wrapper. Returns newly allocated full path name if found, NULL otherwise Does not chase symlinks, even on platforms that support them. */ char * find_executable (const char *wrapper) { int has_slash = 0; const char *p; const char *p_next; /* static buffer for getcwd */ char tmp[LT_PATHMAX + 1]; size_t tmp_len; char *concat_name; lt_debugprintf (__FILE__, __LINE__, "(find_executable): %s\n", nonempty (wrapper)); if ((wrapper == NULL) || (*wrapper == '\0')) return NULL; /* Absolute path? */ #if defined HAVE_DOS_BASED_FILE_SYSTEM if (isalpha ((unsigned char) wrapper[0]) && wrapper[1] == ':') { concat_name = xstrdup (wrapper); if (check_executable (concat_name)) return concat_name; XFREE (concat_name); } else { #endif if (IS_DIR_SEPARATOR (wrapper[0])) { concat_name = xstrdup (wrapper); if (check_executable (concat_name)) return concat_name; XFREE (concat_name); } #if defined HAVE_DOS_BASED_FILE_SYSTEM } #endif for (p = wrapper; *p; p++) if (*p == '/') { has_slash = 1; break; } if (!has_slash) { /* no slashes; search PATH */ const char *path = getenv ("PATH"); if (path != NULL) { for (p = path; *p; p = p_next) { const char *q; size_t p_len; for (q = p; *q; q++) if (IS_PATH_SEPARATOR (*q)) break; p_len = (size_t) (q - p); p_next = (*q == '\0' ? q : q + 1); if (p_len == 0) { /* empty path: current directory */ if (getcwd (tmp, LT_PATHMAX) == NULL) lt_fatal (__FILE__, __LINE__, "getcwd failed: %s", nonnull (strerror (errno))); tmp_len = strlen (tmp); concat_name = XMALLOC (char, tmp_len + 1 + strlen (wrapper) + 1); memcpy (concat_name, tmp, tmp_len); concat_name[tmp_len] = '/'; strcpy (concat_name + tmp_len + 1, wrapper); } else { concat_name = XMALLOC (char, p_len + 1 + strlen (wrapper) + 1); memcpy (concat_name, p, p_len); concat_name[p_len] = '/'; strcpy (concat_name + p_len + 1, wrapper); } if (check_executable (concat_name)) return concat_name; XFREE (concat_name); } } /* not found in PATH; assume curdir */ } /* Relative path | not found in path: prepend cwd */ if (getcwd (tmp, LT_PATHMAX) == NULL) lt_fatal (__FILE__, __LINE__, "getcwd failed: %s", nonnull (strerror (errno))); tmp_len = strlen (tmp); concat_name = XMALLOC (char, tmp_len + 1 + strlen (wrapper) + 1); memcpy (concat_name, tmp, tmp_len); concat_name[tmp_len] = '/'; strcpy (concat_name + tmp_len + 1, wrapper); if (check_executable (concat_name)) return concat_name; XFREE (concat_name); return NULL; } char * chase_symlinks (const char *pathspec) { #ifndef S_ISLNK return xstrdup (pathspec); #else char buf[LT_PATHMAX]; struct stat s; char *tmp_pathspec = xstrdup (pathspec); char *p; int has_symlinks = 0; while (strlen (tmp_pathspec) && !has_symlinks) { lt_debugprintf (__FILE__, __LINE__, "checking path component for symlinks: %s\n", tmp_pathspec); if (lstat (tmp_pathspec, &s) == 0) { if (S_ISLNK (s.st_mode) != 0) { has_symlinks = 1; break; } /* search backwards for last DIR_SEPARATOR */ p = tmp_pathspec + strlen (tmp_pathspec) - 1; while ((p > tmp_pathspec) && (!IS_DIR_SEPARATOR (*p))) p--; if ((p == tmp_pathspec) && (!IS_DIR_SEPARATOR (*p))) { /* no more DIR_SEPARATORS left */ break; } *p = '\0'; } else { lt_fatal (__FILE__, __LINE__, "error accessing file \"%s\": %s", tmp_pathspec, nonnull (strerror (errno))); } } XFREE (tmp_pathspec); if (!has_symlinks) { return xstrdup (pathspec); } tmp_pathspec = realpath (pathspec, buf); if (tmp_pathspec == 0) { lt_fatal (__FILE__, __LINE__, "could not follow symlinks for %s", pathspec); } return xstrdup (tmp_pathspec); #endif } char * strendzap (char *str, const char *pat) { size_t len, patlen; assert (str != NULL); assert (pat != NULL); len = strlen (str); patlen = strlen (pat); if (patlen <= len) { str += len - patlen; if (STREQ (str, pat)) *str = '\0'; } return str; } void lt_debugprintf (const char *file, int line, const char *fmt, ...) { va_list args; if (lt_debug) { (void) fprintf (stderr, "%s:%s:%d: ", program_name, file, line); va_start (args, fmt); (void) vfprintf (stderr, fmt, args); va_end (args); } } static void lt_error_core (int exit_status, const char *file, int line, const char *mode, const char *message, va_list ap) { fprintf (stderr, "%s:%s:%d: %s: ", program_name, file, line, mode); vfprintf (stderr, message, ap); fprintf (stderr, ".\n"); if (exit_status >= 0) exit (exit_status); } void lt_fatal (const char *file, int line, const char *message, ...) { va_list ap; va_start (ap, message); lt_error_core (EXIT_FAILURE, file, line, "FATAL", message, ap); va_end (ap); } static const char * nonnull (const char *s) { return s ? s : "(null)"; } static const char * nonempty (const char *s) { return (s && !*s) ? "(empty)" : nonnull (s); } void lt_setenv (const char *name, const char *value) { lt_debugprintf (__FILE__, __LINE__, "(lt_setenv) setting '%s' to '%s'\n", nonnull (name), nonnull (value)); { #ifdef HAVE_SETENV /* always make a copy, for consistency with !HAVE_SETENV */ char *str = xstrdup (value); setenv (name, str, 1); #else size_t len = strlen (name) + 1 + strlen (value) + 1; char *str = XMALLOC (char, len); sprintf (str, "%s=%s", name, value); if (putenv (str) != EXIT_SUCCESS) { XFREE (str); } #endif } } char * lt_extend_str (const char *orig_value, const char *add, int to_end) { char *new_value; if (orig_value && *orig_value) { size_t orig_value_len = strlen (orig_value); size_t add_len = strlen (add); new_value = XMALLOC (char, add_len + orig_value_len + 1); if (to_end) { strcpy (new_value, orig_value); strcpy (new_value + orig_value_len, add); } else { strcpy (new_value, add); strcpy (new_value + add_len, orig_value); } } else { new_value = xstrdup (add); } return new_value; } void lt_update_exe_path (const char *name, const char *value) { lt_debugprintf (__FILE__, __LINE__, "(lt_update_exe_path) modifying '%s' by prepending '%s'\n", nonnull (name), nonnull (value)); if (name && *name && value && *value) { char *new_value = lt_extend_str (getenv (name), value, 0); /* some systems can't cope with a ':'-terminated path #' */ size_t len = strlen (new_value); while ((len > 0) && IS_PATH_SEPARATOR (new_value[len-1])) { new_value[--len] = '\0'; } lt_setenv (name, new_value); XFREE (new_value); } } void lt_update_lib_path (const char *name, const char *value) { lt_debugprintf (__FILE__, __LINE__, "(lt_update_lib_path) modifying '%s' by prepending '%s'\n", nonnull (name), nonnull (value)); if (name && *name && value && *value) { char *new_value = lt_extend_str (getenv (name), value, 0); lt_setenv (name, new_value); XFREE (new_value); } } EOF case $host_os in mingw*) cat <<"EOF" /* Prepares an argument vector before calling spawn(). Note that spawn() does not by itself call the command interpreter (getenv ("COMSPEC") != NULL ? getenv ("COMSPEC") : ({ OSVERSIONINFO v; v.dwOSVersionInfoSize = sizeof(OSVERSIONINFO); GetVersionEx(&v); v.dwPlatformId == VER_PLATFORM_WIN32_NT; }) ? "cmd.exe" : "command.com"). Instead it simply concatenates the arguments, separated by ' ', and calls CreateProcess(). We must quote the arguments since Win32 CreateProcess() interprets characters like ' ', '\t', '\\', '"' (but not '<' and '>') in a special way: - Space and tab are interpreted as delimiters. They are not treated as delimiters if they are surrounded by double quotes: "...". - Unescaped double quotes are removed from the input. Their only effect is that within double quotes, space and tab are treated like normal characters. - Backslashes not followed by double quotes are not special. - But 2*n+1 backslashes followed by a double quote become n backslashes followed by a double quote (n >= 0): \" -> " \\\" -> \" \\\\\" -> \\" */ #define SHELL_SPECIAL_CHARS "\"\\ \001\002\003\004\005\006\007\010\011\012\013\014\015\016\017\020\021\022\023\024\025\026\027\030\031\032\033\034\035\036\037" #define SHELL_SPACE_CHARS " \001\002\003\004\005\006\007\010\011\012\013\014\015\016\017\020\021\022\023\024\025\026\027\030\031\032\033\034\035\036\037" char ** prepare_spawn (char **argv) { size_t argc; char **new_argv; size_t i; /* Count number of arguments. */ for (argc = 0; argv[argc] != NULL; argc++) ; /* Allocate new argument vector. */ new_argv = XMALLOC (char *, argc + 1); /* Put quoted arguments into the new argument vector. */ for (i = 0; i < argc; i++) { const char *string = argv[i]; if (string[0] == '\0') new_argv[i] = xstrdup ("\"\""); else if (strpbrk (string, SHELL_SPECIAL_CHARS) != NULL) { int quote_around = (strpbrk (string, SHELL_SPACE_CHARS) != NULL); size_t length; unsigned int backslashes; const char *s; char *quoted_string; char *p; length = 0; backslashes = 0; if (quote_around) length++; for (s = string; *s != '\0'; s++) { char c = *s; if (c == '"') length += backslashes + 1; length++; if (c == '\\') backslashes++; else backslashes = 0; } if (quote_around) length += backslashes + 1; quoted_string = XMALLOC (char, length + 1); p = quoted_string; backslashes = 0; if (quote_around) *p++ = '"'; for (s = string; *s != '\0'; s++) { char c = *s; if (c == '"') { unsigned int j; for (j = backslashes + 1; j > 0; j--) *p++ = '\\'; } *p++ = c; if (c == '\\') backslashes++; else backslashes = 0; } if (quote_around) { unsigned int j; for (j = backslashes; j > 0; j--) *p++ = '\\'; *p++ = '"'; } *p = '\0'; new_argv[i] = quoted_string; } else new_argv[i] = (char *) string; } new_argv[argc] = NULL; return new_argv; } EOF ;; esac cat <<"EOF" void lt_dump_script (FILE* f) { EOF func_emit_wrapper yes | $SED -n -e ' s/^\(.\{79\}\)\(..*\)/\1\ \2/ h s/\([\\"]\)/\\\1/g s/$/\\n/ s/\([^\n]*\).*/ fputs ("\1", f);/p g D' cat <<"EOF" } EOF } # end: func_emit_cwrapperexe_src # func_win32_import_lib_p ARG # True if ARG is an import lib, as indicated by $file_magic_cmd func_win32_import_lib_p () { $debug_cmd case `eval $file_magic_cmd \"\$1\" 2>/dev/null | $SED -e 10q` in *import*) : ;; *) false ;; esac } # func_suncc_cstd_abi # !!ONLY CALL THIS FOR SUN CC AFTER $compile_command IS FULLY EXPANDED!! # Several compiler flags select an ABI that is incompatible with the # Cstd library. Avoid specifying it if any are in CXXFLAGS. func_suncc_cstd_abi () { $debug_cmd case " $compile_command " in *" -compat=g "*|*\ -std=c++[0-9][0-9]\ *|*" -library=stdcxx4 "*|*" -library=stlport4 "*) suncc_use_cstd_abi=no ;; *) suncc_use_cstd_abi=yes ;; esac } # func_mode_link arg... func_mode_link () { $debug_cmd case $host in *-*-cygwin* | *-*-mingw* | *-*-pw32* | *-*-os2* | *-cegcc*) # It is impossible to link a dll without this setting, and # we shouldn't force the makefile maintainer to figure out # what system we are compiling for in order to pass an extra # flag for every libtool invocation. # allow_undefined=no # FIXME: Unfortunately, there are problems with the above when trying # to make a dll that has undefined symbols, in which case not # even a static library is built. For now, we need to specify # -no-undefined on the libtool link line when we can be certain # that all symbols are satisfied, otherwise we get a static library. allow_undefined=yes ;; *) allow_undefined=yes ;; esac libtool_args=$nonopt base_compile="$nonopt $@" compile_command=$nonopt finalize_command=$nonopt compile_rpath= finalize_rpath= compile_shlibpath= finalize_shlibpath= convenience= old_convenience= deplibs= old_deplibs= compiler_flags= linker_flags= dllsearchpath= lib_search_path=`pwd` inst_prefix_dir= new_inherited_linker_flags= avoid_version=no bindir= dlfiles= dlprefiles= dlself=no export_dynamic=no export_symbols= export_symbols_regex= generated= libobjs= ltlibs= module=no no_install=no objs= os2dllname= non_pic_objects= precious_files_regex= prefer_static_libs=no preload=false prev= prevarg= release= rpath= xrpath= perm_rpath= temp_rpath= thread_safe=no vinfo= vinfo_number=no weak_libs= single_module=$wl-single_module func_infer_tag $base_compile # We need to know -static, to get the right output filenames. for arg do case $arg in -shared) test yes != "$build_libtool_libs" \ && func_fatal_configuration "cannot build a shared library" build_old_libs=no break ;; -all-static | -static | -static-libtool-libs) case $arg in -all-static) if test yes = "$build_libtool_libs" && test -z "$link_static_flag"; then func_warning "complete static linking is impossible in this configuration" fi if test -n "$link_static_flag"; then dlopen_self=$dlopen_self_static fi prefer_static_libs=yes ;; -static) if test -z "$pic_flag" && test -n "$link_static_flag"; then dlopen_self=$dlopen_self_static fi prefer_static_libs=built ;; -static-libtool-libs) if test -z "$pic_flag" && test -n "$link_static_flag"; then dlopen_self=$dlopen_self_static fi prefer_static_libs=yes ;; esac build_libtool_libs=no build_old_libs=yes break ;; esac done # See if our shared archives depend on static archives. test -n "$old_archive_from_new_cmds" && build_old_libs=yes # Go through the arguments, transforming them on the way. while test "$#" -gt 0; do arg=$1 shift func_quote_for_eval "$arg" qarg=$func_quote_for_eval_unquoted_result func_append libtool_args " $func_quote_for_eval_result" # If the previous option needs an argument, assign it. if test -n "$prev"; then case $prev in output) func_append compile_command " @OUTPUT@" func_append finalize_command " @OUTPUT@" ;; esac case $prev in bindir) bindir=$arg prev= continue ;; dlfiles|dlprefiles) $preload || { # Add the symbol object into the linking commands. func_append compile_command " @SYMFILE@" func_append finalize_command " @SYMFILE@" preload=: } case $arg in *.la | *.lo) ;; # We handle these cases below. force) if test no = "$dlself"; then dlself=needless export_dynamic=yes fi prev= continue ;; self) if test dlprefiles = "$prev"; then dlself=yes elif test dlfiles = "$prev" && test yes != "$dlopen_self"; then dlself=yes else dlself=needless export_dynamic=yes fi prev= continue ;; *) if test dlfiles = "$prev"; then func_append dlfiles " $arg" else func_append dlprefiles " $arg" fi prev= continue ;; esac ;; expsyms) export_symbols=$arg test -f "$arg" \ || func_fatal_error "symbol file '$arg' does not exist" prev= continue ;; expsyms_regex) export_symbols_regex=$arg prev= continue ;; framework) case $host in *-*-darwin*) case "$deplibs " in *" $qarg.ltframework "*) ;; *) func_append deplibs " $qarg.ltframework" # this is fixed later ;; esac ;; esac prev= continue ;; inst_prefix) inst_prefix_dir=$arg prev= continue ;; mllvm) # Clang does not use LLVM to link, so we can simply discard any # '-mllvm $arg' options when doing the link step. prev= continue ;; objectlist) if test -f "$arg"; then save_arg=$arg moreargs= for fil in `cat "$save_arg"` do # func_append moreargs " $fil" arg=$fil # A libtool-controlled object. # Check to see that this really is a libtool object. if func_lalib_unsafe_p "$arg"; then pic_object= non_pic_object= # Read the .lo file func_source "$arg" if test -z "$pic_object" || test -z "$non_pic_object" || test none = "$pic_object" && test none = "$non_pic_object"; then func_fatal_error "cannot find name of object for '$arg'" fi # Extract subdirectory from the argument. func_dirname "$arg" "/" "" xdir=$func_dirname_result if test none != "$pic_object"; then # Prepend the subdirectory the object is found in. pic_object=$xdir$pic_object if test dlfiles = "$prev"; then if test yes = "$build_libtool_libs" && test yes = "$dlopen_support"; then func_append dlfiles " $pic_object" prev= continue else # If libtool objects are unsupported, then we need to preload. prev=dlprefiles fi fi # CHECK ME: I think I busted this. -Ossama if test dlprefiles = "$prev"; then # Preload the old-style object. func_append dlprefiles " $pic_object" prev= fi # A PIC object. func_append libobjs " $pic_object" arg=$pic_object fi # Non-PIC object. if test none != "$non_pic_object"; then # Prepend the subdirectory the object is found in. non_pic_object=$xdir$non_pic_object # A standard non-PIC object func_append non_pic_objects " $non_pic_object" if test -z "$pic_object" || test none = "$pic_object"; then arg=$non_pic_object fi else # If the PIC object exists, use it instead. # $xdir was prepended to $pic_object above. non_pic_object=$pic_object func_append non_pic_objects " $non_pic_object" fi else # Only an error if not doing a dry-run. if $opt_dry_run; then # Extract subdirectory from the argument. func_dirname "$arg" "/" "" xdir=$func_dirname_result func_lo2o "$arg" pic_object=$xdir$objdir/$func_lo2o_result non_pic_object=$xdir$func_lo2o_result func_append libobjs " $pic_object" func_append non_pic_objects " $non_pic_object" else func_fatal_error "'$arg' is not a valid libtool object" fi fi done else func_fatal_error "link input file '$arg' does not exist" fi arg=$save_arg prev= continue ;; os2dllname) os2dllname=$arg prev= continue ;; precious_regex) precious_files_regex=$arg prev= continue ;; release) release=-$arg prev= continue ;; rpath | xrpath) # We need an absolute path. case $arg in [\\/]* | [A-Za-z]:[\\/]*) ;; *) func_fatal_error "only absolute run-paths are allowed" ;; esac if test rpath = "$prev"; then case "$rpath " in *" $arg "*) ;; *) func_append rpath " $arg" ;; esac else case "$xrpath " in *" $arg "*) ;; *) func_append xrpath " $arg" ;; esac fi prev= continue ;; shrext) shrext_cmds=$arg prev= continue ;; weak) func_append weak_libs " $arg" prev= continue ;; xcclinker) func_append linker_flags " $qarg" func_append compiler_flags " $qarg" prev= func_append compile_command " $qarg" func_append finalize_command " $qarg" continue ;; xcompiler) func_append compiler_flags " $qarg" prev= func_append compile_command " $qarg" func_append finalize_command " $qarg" continue ;; xlinker) func_append linker_flags " $qarg" func_append compiler_flags " $wl$qarg" prev= func_append compile_command " $wl$qarg" func_append finalize_command " $wl$qarg" continue ;; *) eval "$prev=\"\$arg\"" prev= continue ;; esac fi # test -n "$prev" prevarg=$arg case $arg in -all-static) if test -n "$link_static_flag"; then # See comment for -static flag below, for more details. func_append compile_command " $link_static_flag" func_append finalize_command " $link_static_flag" fi continue ;; -allow-undefined) # FIXME: remove this flag sometime in the future. func_fatal_error "'-allow-undefined' must not be used because it is the default" ;; -avoid-version) avoid_version=yes continue ;; -bindir) prev=bindir continue ;; -dlopen) prev=dlfiles continue ;; -dlpreopen) prev=dlprefiles continue ;; -export-dynamic) export_dynamic=yes continue ;; -export-symbols | -export-symbols-regex) if test -n "$export_symbols" || test -n "$export_symbols_regex"; then func_fatal_error "more than one -exported-symbols argument is not allowed" fi if test X-export-symbols = "X$arg"; then prev=expsyms else prev=expsyms_regex fi continue ;; -framework) prev=framework continue ;; -inst-prefix-dir) prev=inst_prefix continue ;; # The native IRIX linker understands -LANG:*, -LIST:* and -LNO:* # so, if we see these flags be careful not to treat them like -L -L[A-Z][A-Z]*:*) case $with_gcc/$host in no/*-*-irix* | /*-*-irix*) func_append compile_command " $arg" func_append finalize_command " $arg" ;; esac continue ;; -L*) func_stripname "-L" '' "$arg" if test -z "$func_stripname_result"; then if test "$#" -gt 0; then func_fatal_error "require no space between '-L' and '$1'" else func_fatal_error "need path for '-L' option" fi fi func_resolve_sysroot "$func_stripname_result" dir=$func_resolve_sysroot_result # We need an absolute path. case $dir in [\\/]* | [A-Za-z]:[\\/]*) ;; *) absdir=`cd "$dir" && pwd` test -z "$absdir" && \ func_fatal_error "cannot determine absolute directory name of '$dir'" dir=$absdir ;; esac case "$deplibs " in *" -L$dir "* | *" $arg "*) # Will only happen for absolute or sysroot arguments ;; *) # Preserve sysroot, but never include relative directories case $dir in [\\/]* | [A-Za-z]:[\\/]* | =*) func_append deplibs " $arg" ;; *) func_append deplibs " -L$dir" ;; esac func_append lib_search_path " $dir" ;; esac case $host in *-*-cygwin* | *-*-mingw* | *-*-pw32* | *-*-os2* | *-cegcc*) testbindir=`$ECHO "$dir" | $SED 's*/lib$*/bin*'` case :$dllsearchpath: in *":$dir:"*) ;; ::) dllsearchpath=$dir;; *) func_append dllsearchpath ":$dir";; esac case :$dllsearchpath: in *":$testbindir:"*) ;; ::) dllsearchpath=$testbindir;; *) func_append dllsearchpath ":$testbindir";; esac ;; esac continue ;; -l*) if test X-lc = "X$arg" || test X-lm = "X$arg"; then case $host in *-*-cygwin* | *-*-mingw* | *-*-pw32* | *-*-beos* | *-cegcc* | *-*-haiku*) # These systems don't actually have a C or math library (as such) continue ;; *-*-os2*) # These systems don't actually have a C library (as such) test X-lc = "X$arg" && continue ;; *-*-openbsd* | *-*-freebsd* | *-*-dragonfly* | *-*-bitrig*) # Do not include libc due to us having libc/libc_r. test X-lc = "X$arg" && continue ;; *-*-rhapsody* | *-*-darwin1.[012]) # Rhapsody C and math libraries are in the System framework func_append deplibs " System.ltframework" continue ;; *-*-sco3.2v5* | *-*-sco5v6*) # Causes problems with __ctype test X-lc = "X$arg" && continue ;; *-*-sysv4.2uw2* | *-*-sysv5* | *-*-unixware* | *-*-OpenUNIX*) # Compiler inserts libc in the correct place for threads to work test X-lc = "X$arg" && continue ;; esac elif test X-lc_r = "X$arg"; then case $host in *-*-openbsd* | *-*-freebsd* | *-*-dragonfly* | *-*-bitrig*) # Do not include libc_r directly, use -pthread flag. continue ;; esac fi func_append deplibs " $arg" continue ;; -mllvm) prev=mllvm continue ;; -module) module=yes continue ;; # Tru64 UNIX uses -model [arg] to determine the layout of C++ # classes, name mangling, and exception handling. # Darwin uses the -arch flag to determine output architecture. -model|-arch|-isysroot|--sysroot) func_append compiler_flags " $arg" func_append compile_command " $arg" func_append finalize_command " $arg" prev=xcompiler continue ;; -mt|-mthreads|-kthread|-Kthread|-pthread|-pthreads|--thread-safe \ |-threads|-fopenmp|-openmp|-mp|-xopenmp|-omp|-qsmp=*) func_append compiler_flags " $arg" func_append compile_command " $arg" func_append finalize_command " $arg" case "$new_inherited_linker_flags " in *" $arg "*) ;; * ) func_append new_inherited_linker_flags " $arg" ;; esac continue ;; -multi_module) single_module=$wl-multi_module continue ;; -no-fast-install) fast_install=no continue ;; -no-install) case $host in *-*-cygwin* | *-*-mingw* | *-*-pw32* | *-*-os2* | *-*-darwin* | *-cegcc*) # The PATH hackery in wrapper scripts is required on Windows # and Darwin in order for the loader to find any dlls it needs. func_warning "'-no-install' is ignored for $host" func_warning "assuming '-no-fast-install' instead" fast_install=no ;; *) no_install=yes ;; esac continue ;; -no-undefined) allow_undefined=no continue ;; -objectlist) prev=objectlist continue ;; -os2dllname) prev=os2dllname continue ;; -o) prev=output ;; -precious-files-regex) prev=precious_regex continue ;; -release) prev=release continue ;; -rpath) prev=rpath continue ;; -R) prev=xrpath continue ;; -R*) func_stripname '-R' '' "$arg" dir=$func_stripname_result # We need an absolute path. case $dir in [\\/]* | [A-Za-z]:[\\/]*) ;; =*) func_stripname '=' '' "$dir" dir=$lt_sysroot$func_stripname_result ;; *) func_fatal_error "only absolute run-paths are allowed" ;; esac case "$xrpath " in *" $dir "*) ;; *) func_append xrpath " $dir" ;; esac continue ;; -shared) # The effects of -shared are defined in a previous loop. continue ;; -shrext) prev=shrext continue ;; -static | -static-libtool-libs) # The effects of -static are defined in a previous loop. # We used to do the same as -all-static on platforms that # didn't have a PIC flag, but the assumption that the effects # would be equivalent was wrong. It would break on at least # Digital Unix and AIX. continue ;; -thread-safe) thread_safe=yes continue ;; -version-info) prev=vinfo continue ;; -version-number) prev=vinfo vinfo_number=yes continue ;; -weak) prev=weak continue ;; -Wc,*) func_stripname '-Wc,' '' "$arg" args=$func_stripname_result arg= save_ifs=$IFS; IFS=, for flag in $args; do IFS=$save_ifs func_quote_for_eval "$flag" func_append arg " $func_quote_for_eval_result" func_append compiler_flags " $func_quote_for_eval_result" done IFS=$save_ifs func_stripname ' ' '' "$arg" arg=$func_stripname_result ;; -Wl,*) func_stripname '-Wl,' '' "$arg" args=$func_stripname_result arg= save_ifs=$IFS; IFS=, for flag in $args; do IFS=$save_ifs func_quote_for_eval "$flag" func_append arg " $wl$func_quote_for_eval_result" func_append compiler_flags " $wl$func_quote_for_eval_result" func_append linker_flags " $func_quote_for_eval_result" done IFS=$save_ifs func_stripname ' ' '' "$arg" arg=$func_stripname_result ;; -Xcompiler) prev=xcompiler continue ;; -Xlinker) prev=xlinker continue ;; -XCClinker) prev=xcclinker continue ;; # -msg_* for osf cc -msg_*) func_quote_for_eval "$arg" arg=$func_quote_for_eval_result ;; # Flags to be passed through unchanged, with rationale: # -64, -mips[0-9] enable 64-bit mode for the SGI compiler # -r[0-9][0-9]* specify processor for the SGI compiler # -xarch=*, -xtarget=* enable 64-bit mode for the Sun compiler # +DA*, +DD* enable 64-bit mode for the HP compiler # -q* compiler args for the IBM compiler # -m*, -t[45]*, -txscale* architecture-specific flags for GCC # -F/path path to uninstalled frameworks, gcc on darwin # -p, -pg, --coverage, -fprofile-* profiling flags for GCC # -fstack-protector* stack protector flags for GCC # @file GCC response files # -tp=* Portland pgcc target processor selection # --sysroot=* for sysroot support # -O*, -g*, -flto*, -fwhopr*, -fuse-linker-plugin GCC link-time optimization # -stdlib=* select c++ std lib with clang -64|-mips[0-9]|-r[0-9][0-9]*|-xarch=*|-xtarget=*|+DA*|+DD*|-q*|-m*| \ -t[45]*|-txscale*|-p|-pg|--coverage|-fprofile-*|-F*|@*|-tp=*|--sysroot=*| \ -O*|-g*|-flto*|-fwhopr*|-fuse-linker-plugin|-fstack-protector*|-stdlib=*) func_quote_for_eval "$arg" arg=$func_quote_for_eval_result func_append compile_command " $arg" func_append finalize_command " $arg" func_append compiler_flags " $arg" continue ;; -Z*) if test os2 = "`expr $host : '.*\(os2\)'`"; then # OS/2 uses -Zxxx to specify OS/2-specific options compiler_flags="$compiler_flags $arg" func_append compile_command " $arg" func_append finalize_command " $arg" case $arg in -Zlinker | -Zstack) prev=xcompiler ;; esac continue else # Otherwise treat like 'Some other compiler flag' below func_quote_for_eval "$arg" arg=$func_quote_for_eval_result fi ;; # Some other compiler flag. -* | +*) func_quote_for_eval "$arg" arg=$func_quote_for_eval_result ;; *.$objext) # A standard object. func_append objs " $arg" ;; *.lo) # A libtool-controlled object. # Check to see that this really is a libtool object. if func_lalib_unsafe_p "$arg"; then pic_object= non_pic_object= # Read the .lo file func_source "$arg" if test -z "$pic_object" || test -z "$non_pic_object" || test none = "$pic_object" && test none = "$non_pic_object"; then func_fatal_error "cannot find name of object for '$arg'" fi # Extract subdirectory from the argument. func_dirname "$arg" "/" "" xdir=$func_dirname_result test none = "$pic_object" || { # Prepend the subdirectory the object is found in. pic_object=$xdir$pic_object if test dlfiles = "$prev"; then if test yes = "$build_libtool_libs" && test yes = "$dlopen_support"; then func_append dlfiles " $pic_object" prev= continue else # If libtool objects are unsupported, then we need to preload. prev=dlprefiles fi fi # CHECK ME: I think I busted this. -Ossama if test dlprefiles = "$prev"; then # Preload the old-style object. func_append dlprefiles " $pic_object" prev= fi # A PIC object. func_append libobjs " $pic_object" arg=$pic_object } # Non-PIC object. if test none != "$non_pic_object"; then # Prepend the subdirectory the object is found in. non_pic_object=$xdir$non_pic_object # A standard non-PIC object func_append non_pic_objects " $non_pic_object" if test -z "$pic_object" || test none = "$pic_object"; then arg=$non_pic_object fi else # If the PIC object exists, use it instead. # $xdir was prepended to $pic_object above. non_pic_object=$pic_object func_append non_pic_objects " $non_pic_object" fi else # Only an error if not doing a dry-run. if $opt_dry_run; then # Extract subdirectory from the argument. func_dirname "$arg" "/" "" xdir=$func_dirname_result func_lo2o "$arg" pic_object=$xdir$objdir/$func_lo2o_result non_pic_object=$xdir$func_lo2o_result func_append libobjs " $pic_object" func_append non_pic_objects " $non_pic_object" else func_fatal_error "'$arg' is not a valid libtool object" fi fi ;; *.$libext) # An archive. func_append deplibs " $arg" func_append old_deplibs " $arg" continue ;; *.la) # A libtool-controlled library. func_resolve_sysroot "$arg" if test dlfiles = "$prev"; then # This library was specified with -dlopen. func_append dlfiles " $func_resolve_sysroot_result" prev= elif test dlprefiles = "$prev"; then # The library was specified with -dlpreopen. func_append dlprefiles " $func_resolve_sysroot_result" prev= else func_append deplibs " $func_resolve_sysroot_result" fi continue ;; # Some other compiler argument. *) # Unknown arguments in both finalize_command and compile_command need # to be aesthetically quoted because they are evaled later. func_quote_for_eval "$arg" arg=$func_quote_for_eval_result ;; esac # arg # Now actually substitute the argument into the commands. if test -n "$arg"; then func_append compile_command " $arg" func_append finalize_command " $arg" fi done # argument parsing loop test -n "$prev" && \ func_fatal_help "the '$prevarg' option requires an argument" if test yes = "$export_dynamic" && test -n "$export_dynamic_flag_spec"; then eval arg=\"$export_dynamic_flag_spec\" func_append compile_command " $arg" func_append finalize_command " $arg" fi oldlibs= # calculate the name of the file, without its directory func_basename "$output" outputname=$func_basename_result libobjs_save=$libobjs if test -n "$shlibpath_var"; then # get the directories listed in $shlibpath_var eval shlib_search_path=\`\$ECHO \"\$$shlibpath_var\" \| \$SED \'s/:/ /g\'\` else shlib_search_path= fi eval sys_lib_search_path=\"$sys_lib_search_path_spec\" eval sys_lib_dlsearch_path=\"$sys_lib_dlsearch_path_spec\" # Definition is injected by LT_CONFIG during libtool generation. func_munge_path_list sys_lib_dlsearch_path "$LT_SYS_LIBRARY_PATH" func_dirname "$output" "/" "" output_objdir=$func_dirname_result$objdir func_to_tool_file "$output_objdir/" tool_output_objdir=$func_to_tool_file_result # Create the object directory. func_mkdir_p "$output_objdir" # Determine the type of output case $output in "") func_fatal_help "you must specify an output file" ;; *.$libext) linkmode=oldlib ;; *.lo | *.$objext) linkmode=obj ;; *.la) linkmode=lib ;; *) linkmode=prog ;; # Anything else should be a program. esac specialdeplibs= libs= # Find all interdependent deplibs by searching for libraries # that are linked more than once (e.g. -la -lb -la) for deplib in $deplibs; do if $opt_preserve_dup_deps; then case "$libs " in *" $deplib "*) func_append specialdeplibs " $deplib" ;; esac fi func_append libs " $deplib" done if test lib = "$linkmode"; then libs="$predeps $libs $compiler_lib_search_path $postdeps" # Compute libraries that are listed more than once in $predeps # $postdeps and mark them as special (i.e., whose duplicates are # not to be eliminated). pre_post_deps= if $opt_duplicate_compiler_generated_deps; then for pre_post_dep in $predeps $postdeps; do case "$pre_post_deps " in *" $pre_post_dep "*) func_append specialdeplibs " $pre_post_deps" ;; esac func_append pre_post_deps " $pre_post_dep" done fi pre_post_deps= fi deplibs= newdependency_libs= newlib_search_path= need_relink=no # whether we're linking any uninstalled libtool libraries notinst_deplibs= # not-installed libtool libraries notinst_path= # paths that contain not-installed libtool libraries case $linkmode in lib) passes="conv dlpreopen link" for file in $dlfiles $dlprefiles; do case $file in *.la) ;; *) func_fatal_help "libraries can '-dlopen' only libtool libraries: $file" ;; esac done ;; prog) compile_deplibs= finalize_deplibs= alldeplibs=false newdlfiles= newdlprefiles= passes="conv scan dlopen dlpreopen link" ;; *) passes="conv" ;; esac for pass in $passes; do # The preopen pass in lib mode reverses $deplibs; put it back here # so that -L comes before libs that need it for instance... if test lib,link = "$linkmode,$pass"; then ## FIXME: Find the place where the list is rebuilt in the wrong ## order, and fix it there properly tmp_deplibs= for deplib in $deplibs; do tmp_deplibs="$deplib $tmp_deplibs" done deplibs=$tmp_deplibs fi if test lib,link = "$linkmode,$pass" || test prog,scan = "$linkmode,$pass"; then libs=$deplibs deplibs= fi if test prog = "$linkmode"; then case $pass in dlopen) libs=$dlfiles ;; dlpreopen) libs=$dlprefiles ;; link) libs="$deplibs %DEPLIBS% $dependency_libs" ;; esac fi if test lib,dlpreopen = "$linkmode,$pass"; then # Collect and forward deplibs of preopened libtool libs for lib in $dlprefiles; do # Ignore non-libtool-libs dependency_libs= func_resolve_sysroot "$lib" case $lib in *.la) func_source "$func_resolve_sysroot_result" ;; esac # Collect preopened libtool deplibs, except any this library # has declared as weak libs for deplib in $dependency_libs; do func_basename "$deplib" deplib_base=$func_basename_result case " $weak_libs " in *" $deplib_base "*) ;; *) func_append deplibs " $deplib" ;; esac done done libs=$dlprefiles fi if test dlopen = "$pass"; then # Collect dlpreopened libraries save_deplibs=$deplibs deplibs= fi for deplib in $libs; do lib= found=false case $deplib in -mt|-mthreads|-kthread|-Kthread|-pthread|-pthreads|--thread-safe \ |-threads|-fopenmp|-openmp|-mp|-xopenmp|-omp|-qsmp=*) if test prog,link = "$linkmode,$pass"; then compile_deplibs="$deplib $compile_deplibs" finalize_deplibs="$deplib $finalize_deplibs" else func_append compiler_flags " $deplib" if test lib = "$linkmode"; then case "$new_inherited_linker_flags " in *" $deplib "*) ;; * ) func_append new_inherited_linker_flags " $deplib" ;; esac fi fi continue ;; -l*) if test lib != "$linkmode" && test prog != "$linkmode"; then func_warning "'-l' is ignored for archives/objects" continue fi func_stripname '-l' '' "$deplib" name=$func_stripname_result if test lib = "$linkmode"; then searchdirs="$newlib_search_path $lib_search_path $compiler_lib_search_dirs $sys_lib_search_path $shlib_search_path" else searchdirs="$newlib_search_path $lib_search_path $sys_lib_search_path $shlib_search_path" fi for searchdir in $searchdirs; do for search_ext in .la $std_shrext .so .a; do # Search the libtool library lib=$searchdir/lib$name$search_ext if test -f "$lib"; then if test .la = "$search_ext"; then found=: else found=false fi break 2 fi done done if $found; then # deplib is a libtool library # If $allow_libtool_libs_with_static_runtimes && $deplib is a stdlib, # We need to do some special things here, and not later. if test yes = "$allow_libtool_libs_with_static_runtimes"; then case " $predeps $postdeps " in *" $deplib "*) if func_lalib_p "$lib"; then library_names= old_library= func_source "$lib" for l in $old_library $library_names; do ll=$l done if test "X$ll" = "X$old_library"; then # only static version available found=false func_dirname "$lib" "" "." ladir=$func_dirname_result lib=$ladir/$old_library if test prog,link = "$linkmode,$pass"; then compile_deplibs="$deplib $compile_deplibs" finalize_deplibs="$deplib $finalize_deplibs" else deplibs="$deplib $deplibs" test lib = "$linkmode" && newdependency_libs="$deplib $newdependency_libs" fi continue fi fi ;; *) ;; esac fi else # deplib doesn't seem to be a libtool library if test prog,link = "$linkmode,$pass"; then compile_deplibs="$deplib $compile_deplibs" finalize_deplibs="$deplib $finalize_deplibs" else deplibs="$deplib $deplibs" test lib = "$linkmode" && newdependency_libs="$deplib $newdependency_libs" fi continue fi ;; # -l *.ltframework) if test prog,link = "$linkmode,$pass"; then compile_deplibs="$deplib $compile_deplibs" finalize_deplibs="$deplib $finalize_deplibs" else deplibs="$deplib $deplibs" if test lib = "$linkmode"; then case "$new_inherited_linker_flags " in *" $deplib "*) ;; * ) func_append new_inherited_linker_flags " $deplib" ;; esac fi fi continue ;; -L*) case $linkmode in lib) deplibs="$deplib $deplibs" test conv = "$pass" && continue newdependency_libs="$deplib $newdependency_libs" func_stripname '-L' '' "$deplib" func_resolve_sysroot "$func_stripname_result" func_append newlib_search_path " $func_resolve_sysroot_result" ;; prog) if test conv = "$pass"; then deplibs="$deplib $deplibs" continue fi if test scan = "$pass"; then deplibs="$deplib $deplibs" else compile_deplibs="$deplib $compile_deplibs" finalize_deplibs="$deplib $finalize_deplibs" fi func_stripname '-L' '' "$deplib" func_resolve_sysroot "$func_stripname_result" func_append newlib_search_path " $func_resolve_sysroot_result" ;; *) func_warning "'-L' is ignored for archives/objects" ;; esac # linkmode continue ;; # -L -R*) if test link = "$pass"; then func_stripname '-R' '' "$deplib" func_resolve_sysroot "$func_stripname_result" dir=$func_resolve_sysroot_result # Make sure the xrpath contains only unique directories. case "$xrpath " in *" $dir "*) ;; *) func_append xrpath " $dir" ;; esac fi deplibs="$deplib $deplibs" continue ;; *.la) func_resolve_sysroot "$deplib" lib=$func_resolve_sysroot_result ;; *.$libext) if test conv = "$pass"; then deplibs="$deplib $deplibs" continue fi case $linkmode in lib) # Linking convenience modules into shared libraries is allowed, # but linking other static libraries is non-portable. case " $dlpreconveniencelibs " in *" $deplib "*) ;; *) valid_a_lib=false case $deplibs_check_method in match_pattern*) set dummy $deplibs_check_method; shift match_pattern_regex=`expr "$deplibs_check_method" : "$1 \(.*\)"` if eval "\$ECHO \"$deplib\"" 2>/dev/null | $SED 10q \ | $EGREP "$match_pattern_regex" > /dev/null; then valid_a_lib=: fi ;; pass_all) valid_a_lib=: ;; esac if $valid_a_lib; then echo $ECHO "*** Warning: Linking the shared library $output against the" $ECHO "*** static library $deplib is not portable!" deplibs="$deplib $deplibs" else echo $ECHO "*** Warning: Trying to link with static lib archive $deplib." echo "*** I have the capability to make that library automatically link in when" echo "*** you link to this library. But I can only do this if you have a" echo "*** shared version of the library, which you do not appear to have" echo "*** because the file extensions .$libext of this argument makes me believe" echo "*** that it is just a static archive that I should not use here." fi ;; esac continue ;; prog) if test link != "$pass"; then deplibs="$deplib $deplibs" else compile_deplibs="$deplib $compile_deplibs" finalize_deplibs="$deplib $finalize_deplibs" fi continue ;; esac # linkmode ;; # *.$libext *.lo | *.$objext) if test conv = "$pass"; then deplibs="$deplib $deplibs" elif test prog = "$linkmode"; then if test dlpreopen = "$pass" || test yes != "$dlopen_support" || test no = "$build_libtool_libs"; then # If there is no dlopen support or we're linking statically, # we need to preload. func_append newdlprefiles " $deplib" compile_deplibs="$deplib $compile_deplibs" finalize_deplibs="$deplib $finalize_deplibs" else func_append newdlfiles " $deplib" fi fi continue ;; %DEPLIBS%) alldeplibs=: continue ;; esac # case $deplib $found || test -f "$lib" \ || func_fatal_error "cannot find the library '$lib' or unhandled argument '$deplib'" # Check to see that this really is a libtool archive. func_lalib_unsafe_p "$lib" \ || func_fatal_error "'$lib' is not a valid libtool archive" func_dirname "$lib" "" "." ladir=$func_dirname_result dlname= dlopen= dlpreopen= libdir= library_names= old_library= inherited_linker_flags= # If the library was installed with an old release of libtool, # it will not redefine variables installed, or shouldnotlink installed=yes shouldnotlink=no avoidtemprpath= # Read the .la file func_source "$lib" # Convert "-framework foo" to "foo.ltframework" if test -n "$inherited_linker_flags"; then tmp_inherited_linker_flags=`$ECHO "$inherited_linker_flags" | $SED 's/-framework \([^ $]*\)/\1.ltframework/g'` for tmp_inherited_linker_flag in $tmp_inherited_linker_flags; do case " $new_inherited_linker_flags " in *" $tmp_inherited_linker_flag "*) ;; *) func_append new_inherited_linker_flags " $tmp_inherited_linker_flag";; esac done fi dependency_libs=`$ECHO " $dependency_libs" | $SED 's% \([^ $]*\).ltframework% -framework \1%g'` if test lib,link = "$linkmode,$pass" || test prog,scan = "$linkmode,$pass" || { test prog != "$linkmode" && test lib != "$linkmode"; }; then test -n "$dlopen" && func_append dlfiles " $dlopen" test -n "$dlpreopen" && func_append dlprefiles " $dlpreopen" fi if test conv = "$pass"; then # Only check for convenience libraries deplibs="$lib $deplibs" if test -z "$libdir"; then if test -z "$old_library"; then func_fatal_error "cannot find name of link library for '$lib'" fi # It is a libtool convenience library, so add in its objects. func_append convenience " $ladir/$objdir/$old_library" func_append old_convenience " $ladir/$objdir/$old_library" elif test prog != "$linkmode" && test lib != "$linkmode"; then func_fatal_error "'$lib' is not a convenience library" fi tmp_libs= for deplib in $dependency_libs; do deplibs="$deplib $deplibs" if $opt_preserve_dup_deps; then case "$tmp_libs " in *" $deplib "*) func_append specialdeplibs " $deplib" ;; esac fi func_append tmp_libs " $deplib" done continue fi # $pass = conv # Get the name of the library we link against. linklib= if test -n "$old_library" && { test yes = "$prefer_static_libs" || test built,no = "$prefer_static_libs,$installed"; }; then linklib=$old_library else for l in $old_library $library_names; do linklib=$l done fi if test -z "$linklib"; then func_fatal_error "cannot find name of link library for '$lib'" fi # This library was specified with -dlopen. if test dlopen = "$pass"; then test -z "$libdir" \ && func_fatal_error "cannot -dlopen a convenience library: '$lib'" if test -z "$dlname" || test yes != "$dlopen_support" || test no = "$build_libtool_libs" then # If there is no dlname, no dlopen support or we're linking # statically, we need to preload. We also need to preload any # dependent libraries so libltdl's deplib preloader doesn't # bomb out in the load deplibs phase. func_append dlprefiles " $lib $dependency_libs" else func_append newdlfiles " $lib" fi continue fi # $pass = dlopen # We need an absolute path. case $ladir in [\\/]* | [A-Za-z]:[\\/]*) abs_ladir=$ladir ;; *) abs_ladir=`cd "$ladir" && pwd` if test -z "$abs_ladir"; then func_warning "cannot determine absolute directory name of '$ladir'" func_warning "passing it literally to the linker, although it might fail" abs_ladir=$ladir fi ;; esac func_basename "$lib" laname=$func_basename_result # Find the relevant object directory and library name. if test yes = "$installed"; then if test ! -f "$lt_sysroot$libdir/$linklib" && test -f "$abs_ladir/$linklib"; then func_warning "library '$lib' was moved." dir=$ladir absdir=$abs_ladir libdir=$abs_ladir else dir=$lt_sysroot$libdir absdir=$lt_sysroot$libdir fi test yes = "$hardcode_automatic" && avoidtemprpath=yes else if test ! -f "$ladir/$objdir/$linklib" && test -f "$abs_ladir/$linklib"; then dir=$ladir absdir=$abs_ladir # Remove this search path later func_append notinst_path " $abs_ladir" else dir=$ladir/$objdir absdir=$abs_ladir/$objdir # Remove this search path later func_append notinst_path " $abs_ladir" fi fi # $installed = yes func_stripname 'lib' '.la' "$laname" name=$func_stripname_result # This library was specified with -dlpreopen. if test dlpreopen = "$pass"; then if test -z "$libdir" && test prog = "$linkmode"; then func_fatal_error "only libraries may -dlpreopen a convenience library: '$lib'" fi case $host in # special handling for platforms with PE-DLLs. *cygwin* | *mingw* | *cegcc* ) # Linker will automatically link against shared library if both # static and shared are present. Therefore, ensure we extract # symbols from the import library if a shared library is present # (otherwise, the dlopen module name will be incorrect). We do # this by putting the import library name into $newdlprefiles. # We recover the dlopen module name by 'saving' the la file # name in a special purpose variable, and (later) extracting the # dlname from the la file. if test -n "$dlname"; then func_tr_sh "$dir/$linklib" eval "libfile_$func_tr_sh_result=\$abs_ladir/\$laname" func_append newdlprefiles " $dir/$linklib" else func_append newdlprefiles " $dir/$old_library" # Keep a list of preopened convenience libraries to check # that they are being used correctly in the link pass. test -z "$libdir" && \ func_append dlpreconveniencelibs " $dir/$old_library" fi ;; * ) # Prefer using a static library (so that no silly _DYNAMIC symbols # are required to link). if test -n "$old_library"; then func_append newdlprefiles " $dir/$old_library" # Keep a list of preopened convenience libraries to check # that they are being used correctly in the link pass. test -z "$libdir" && \ func_append dlpreconveniencelibs " $dir/$old_library" # Otherwise, use the dlname, so that lt_dlopen finds it. elif test -n "$dlname"; then func_append newdlprefiles " $dir/$dlname" else func_append newdlprefiles " $dir/$linklib" fi ;; esac fi # $pass = dlpreopen if test -z "$libdir"; then # Link the convenience library if test lib = "$linkmode"; then deplibs="$dir/$old_library $deplibs" elif test prog,link = "$linkmode,$pass"; then compile_deplibs="$dir/$old_library $compile_deplibs" finalize_deplibs="$dir/$old_library $finalize_deplibs" else deplibs="$lib $deplibs" # used for prog,scan pass fi continue fi if test prog = "$linkmode" && test link != "$pass"; then func_append newlib_search_path " $ladir" deplibs="$lib $deplibs" linkalldeplibs=false if test no != "$link_all_deplibs" || test -z "$library_names" || test no = "$build_libtool_libs"; then linkalldeplibs=: fi tmp_libs= for deplib in $dependency_libs; do case $deplib in -L*) func_stripname '-L' '' "$deplib" func_resolve_sysroot "$func_stripname_result" func_append newlib_search_path " $func_resolve_sysroot_result" ;; esac # Need to link against all dependency_libs? if $linkalldeplibs; then deplibs="$deplib $deplibs" else # Need to hardcode shared library paths # or/and link against static libraries newdependency_libs="$deplib $newdependency_libs" fi if $opt_preserve_dup_deps; then case "$tmp_libs " in *" $deplib "*) func_append specialdeplibs " $deplib" ;; esac fi func_append tmp_libs " $deplib" done # for deplib continue fi # $linkmode = prog... if test prog,link = "$linkmode,$pass"; then if test -n "$library_names" && { { test no = "$prefer_static_libs" || test built,yes = "$prefer_static_libs,$installed"; } || test -z "$old_library"; }; then # We need to hardcode the library path if test -n "$shlibpath_var" && test -z "$avoidtemprpath"; then # Make sure the rpath contains only unique directories. case $temp_rpath: in *"$absdir:"*) ;; *) func_append temp_rpath "$absdir:" ;; esac fi # Hardcode the library path. # Skip directories that are in the system default run-time # search path. case " $sys_lib_dlsearch_path " in *" $absdir "*) ;; *) case "$compile_rpath " in *" $absdir "*) ;; *) func_append compile_rpath " $absdir" ;; esac ;; esac case " $sys_lib_dlsearch_path " in *" $libdir "*) ;; *) case "$finalize_rpath " in *" $libdir "*) ;; *) func_append finalize_rpath " $libdir" ;; esac ;; esac fi # $linkmode,$pass = prog,link... if $alldeplibs && { test pass_all = "$deplibs_check_method" || { test yes = "$build_libtool_libs" && test -n "$library_names"; }; }; then # We only need to search for static libraries continue fi fi link_static=no # Whether the deplib will be linked statically use_static_libs=$prefer_static_libs if test built = "$use_static_libs" && test yes = "$installed"; then use_static_libs=no fi if test -n "$library_names" && { test no = "$use_static_libs" || test -z "$old_library"; }; then case $host in *cygwin* | *mingw* | *cegcc* | *os2*) # No point in relinking DLLs because paths are not encoded func_append notinst_deplibs " $lib" need_relink=no ;; *) if test no = "$installed"; then func_append notinst_deplibs " $lib" need_relink=yes fi ;; esac # This is a shared library # Warn about portability, can't link against -module's on some # systems (darwin). Don't bleat about dlopened modules though! dlopenmodule= for dlpremoduletest in $dlprefiles; do if test "X$dlpremoduletest" = "X$lib"; then dlopenmodule=$dlpremoduletest break fi done if test -z "$dlopenmodule" && test yes = "$shouldnotlink" && test link = "$pass"; then echo if test prog = "$linkmode"; then $ECHO "*** Warning: Linking the executable $output against the loadable module" else $ECHO "*** Warning: Linking the shared library $output against the loadable module" fi $ECHO "*** $linklib is not portable!" fi if test lib = "$linkmode" && test yes = "$hardcode_into_libs"; then # Hardcode the library path. # Skip directories that are in the system default run-time # search path. case " $sys_lib_dlsearch_path " in *" $absdir "*) ;; *) case "$compile_rpath " in *" $absdir "*) ;; *) func_append compile_rpath " $absdir" ;; esac ;; esac case " $sys_lib_dlsearch_path " in *" $libdir "*) ;; *) case "$finalize_rpath " in *" $libdir "*) ;; *) func_append finalize_rpath " $libdir" ;; esac ;; esac fi if test -n "$old_archive_from_expsyms_cmds"; then # figure out the soname set dummy $library_names shift realname=$1 shift libname=`eval "\\$ECHO \"$libname_spec\""` # use dlname if we got it. it's perfectly good, no? if test -n "$dlname"; then soname=$dlname elif test -n "$soname_spec"; then # bleh windows case $host in *cygwin* | mingw* | *cegcc* | *os2*) func_arith $current - $age major=$func_arith_result versuffix=-$major ;; esac eval soname=\"$soname_spec\" else soname=$realname fi # Make a new name for the extract_expsyms_cmds to use soroot=$soname func_basename "$soroot" soname=$func_basename_result func_stripname 'lib' '.dll' "$soname" newlib=libimp-$func_stripname_result.a # If the library has no export list, then create one now if test -f "$output_objdir/$soname-def"; then : else func_verbose "extracting exported symbol list from '$soname'" func_execute_cmds "$extract_expsyms_cmds" 'exit $?' fi # Create $newlib if test -f "$output_objdir/$newlib"; then :; else func_verbose "generating import library for '$soname'" func_execute_cmds "$old_archive_from_expsyms_cmds" 'exit $?' fi # make sure the library variables are pointing to the new library dir=$output_objdir linklib=$newlib fi # test -n "$old_archive_from_expsyms_cmds" if test prog = "$linkmode" || test relink != "$opt_mode"; then add_shlibpath= add_dir= add= lib_linked=yes case $hardcode_action in immediate | unsupported) if test no = "$hardcode_direct"; then add=$dir/$linklib case $host in *-*-sco3.2v5.0.[024]*) add_dir=-L$dir ;; *-*-sysv4*uw2*) add_dir=-L$dir ;; *-*-sysv5OpenUNIX* | *-*-sysv5UnixWare7.[01].[10]* | \ *-*-unixware7*) add_dir=-L$dir ;; *-*-darwin* ) # if the lib is a (non-dlopened) module then we cannot # link against it, someone is ignoring the earlier warnings if /usr/bin/file -L $add 2> /dev/null | $GREP ": [^:]* bundle" >/dev/null; then if test "X$dlopenmodule" != "X$lib"; then $ECHO "*** Warning: lib $linklib is a module, not a shared library" if test -z "$old_library"; then echo echo "*** And there doesn't seem to be a static archive available" echo "*** The link will probably fail, sorry" else add=$dir/$old_library fi elif test -n "$old_library"; then add=$dir/$old_library fi fi esac elif test no = "$hardcode_minus_L"; then case $host in *-*-sunos*) add_shlibpath=$dir ;; esac add_dir=-L$dir add=-l$name elif test no = "$hardcode_shlibpath_var"; then add_shlibpath=$dir add=-l$name else lib_linked=no fi ;; relink) if test yes = "$hardcode_direct" && test no = "$hardcode_direct_absolute"; then add=$dir/$linklib elif test yes = "$hardcode_minus_L"; then add_dir=-L$absdir # Try looking first in the location we're being installed to. if test -n "$inst_prefix_dir"; then case $libdir in [\\/]*) func_append add_dir " -L$inst_prefix_dir$libdir" ;; esac fi add=-l$name elif test yes = "$hardcode_shlibpath_var"; then add_shlibpath=$dir add=-l$name else lib_linked=no fi ;; *) lib_linked=no ;; esac if test yes != "$lib_linked"; then func_fatal_configuration "unsupported hardcode properties" fi if test -n "$add_shlibpath"; then case :$compile_shlibpath: in *":$add_shlibpath:"*) ;; *) func_append compile_shlibpath "$add_shlibpath:" ;; esac fi if test prog = "$linkmode"; then test -n "$add_dir" && compile_deplibs="$add_dir $compile_deplibs" test -n "$add" && compile_deplibs="$add $compile_deplibs" else test -n "$add_dir" && deplibs="$add_dir $deplibs" test -n "$add" && deplibs="$add $deplibs" if test yes != "$hardcode_direct" && test yes != "$hardcode_minus_L" && test yes = "$hardcode_shlibpath_var"; then case :$finalize_shlibpath: in *":$libdir:"*) ;; *) func_append finalize_shlibpath "$libdir:" ;; esac fi fi fi if test prog = "$linkmode" || test relink = "$opt_mode"; then add_shlibpath= add_dir= add= # Finalize command for both is simple: just hardcode it. if test yes = "$hardcode_direct" && test no = "$hardcode_direct_absolute"; then add=$libdir/$linklib elif test yes = "$hardcode_minus_L"; then add_dir=-L$libdir add=-l$name elif test yes = "$hardcode_shlibpath_var"; then case :$finalize_shlibpath: in *":$libdir:"*) ;; *) func_append finalize_shlibpath "$libdir:" ;; esac add=-l$name elif test yes = "$hardcode_automatic"; then if test -n "$inst_prefix_dir" && test -f "$inst_prefix_dir$libdir/$linklib"; then add=$inst_prefix_dir$libdir/$linklib else add=$libdir/$linklib fi else # We cannot seem to hardcode it, guess we'll fake it. add_dir=-L$libdir # Try looking first in the location we're being installed to. if test -n "$inst_prefix_dir"; then case $libdir in [\\/]*) func_append add_dir " -L$inst_prefix_dir$libdir" ;; esac fi add=-l$name fi if test prog = "$linkmode"; then test -n "$add_dir" && finalize_deplibs="$add_dir $finalize_deplibs" test -n "$add" && finalize_deplibs="$add $finalize_deplibs" else test -n "$add_dir" && deplibs="$add_dir $deplibs" test -n "$add" && deplibs="$add $deplibs" fi fi elif test prog = "$linkmode"; then # Here we assume that one of hardcode_direct or hardcode_minus_L # is not unsupported. This is valid on all known static and # shared platforms. if test unsupported != "$hardcode_direct"; then test -n "$old_library" && linklib=$old_library compile_deplibs="$dir/$linklib $compile_deplibs" finalize_deplibs="$dir/$linklib $finalize_deplibs" else compile_deplibs="-l$name -L$dir $compile_deplibs" finalize_deplibs="-l$name -L$dir $finalize_deplibs" fi elif test yes = "$build_libtool_libs"; then # Not a shared library if test pass_all != "$deplibs_check_method"; then # We're trying link a shared library against a static one # but the system doesn't support it. # Just print a warning and add the library to dependency_libs so # that the program can be linked against the static library. echo $ECHO "*** Warning: This system cannot link to static lib archive $lib." echo "*** I have the capability to make that library automatically link in when" echo "*** you link to this library. But I can only do this if you have a" echo "*** shared version of the library, which you do not appear to have." if test yes = "$module"; then echo "*** But as you try to build a module library, libtool will still create " echo "*** a static module, that should work as long as the dlopening application" echo "*** is linked with the -dlopen flag to resolve symbols at runtime." if test -z "$global_symbol_pipe"; then echo echo "*** However, this would only work if libtool was able to extract symbol" echo "*** lists from a program, using 'nm' or equivalent, but libtool could" echo "*** not find such a program. So, this module is probably useless." echo "*** 'nm' from GNU binutils and a full rebuild may help." fi if test no = "$build_old_libs"; then build_libtool_libs=module build_old_libs=yes else build_libtool_libs=no fi fi else deplibs="$dir/$old_library $deplibs" link_static=yes fi fi # link shared/static library? if test lib = "$linkmode"; then if test -n "$dependency_libs" && { test yes != "$hardcode_into_libs" || test yes = "$build_old_libs" || test yes = "$link_static"; }; then # Extract -R from dependency_libs temp_deplibs= for libdir in $dependency_libs; do case $libdir in -R*) func_stripname '-R' '' "$libdir" temp_xrpath=$func_stripname_result case " $xrpath " in *" $temp_xrpath "*) ;; *) func_append xrpath " $temp_xrpath";; esac;; *) func_append temp_deplibs " $libdir";; esac done dependency_libs=$temp_deplibs fi func_append newlib_search_path " $absdir" # Link against this library test no = "$link_static" && newdependency_libs="$abs_ladir/$laname $newdependency_libs" # ... and its dependency_libs tmp_libs= for deplib in $dependency_libs; do newdependency_libs="$deplib $newdependency_libs" case $deplib in -L*) func_stripname '-L' '' "$deplib" func_resolve_sysroot "$func_stripname_result";; *) func_resolve_sysroot "$deplib" ;; esac if $opt_preserve_dup_deps; then case "$tmp_libs " in *" $func_resolve_sysroot_result "*) func_append specialdeplibs " $func_resolve_sysroot_result" ;; esac fi func_append tmp_libs " $func_resolve_sysroot_result" done if test no != "$link_all_deplibs"; then # Add the search paths of all dependency libraries for deplib in $dependency_libs; do path= case $deplib in -L*) path=$deplib ;; *.la) func_resolve_sysroot "$deplib" deplib=$func_resolve_sysroot_result func_dirname "$deplib" "" "." dir=$func_dirname_result # We need an absolute path. case $dir in [\\/]* | [A-Za-z]:[\\/]*) absdir=$dir ;; *) absdir=`cd "$dir" && pwd` if test -z "$absdir"; then func_warning "cannot determine absolute directory name of '$dir'" absdir=$dir fi ;; esac if $GREP "^installed=no" $deplib > /dev/null; then case $host in *-*-darwin*) depdepl= eval deplibrary_names=`$SED -n -e 's/^library_names=\(.*\)$/\1/p' $deplib` if test -n "$deplibrary_names"; then for tmp in $deplibrary_names; do depdepl=$tmp done if test -f "$absdir/$objdir/$depdepl"; then depdepl=$absdir/$objdir/$depdepl darwin_install_name=`$OTOOL -L $depdepl | awk '{if (NR == 2) {print $1;exit}}'` if test -z "$darwin_install_name"; then darwin_install_name=`$OTOOL64 -L $depdepl | awk '{if (NR == 2) {print $1;exit}}'` fi func_append compiler_flags " $wl-dylib_file $wl$darwin_install_name:$depdepl" func_append linker_flags " -dylib_file $darwin_install_name:$depdepl" path= fi fi ;; *) path=-L$absdir/$objdir ;; esac else eval libdir=`$SED -n -e 's/^libdir=\(.*\)$/\1/p' $deplib` test -z "$libdir" && \ func_fatal_error "'$deplib' is not a valid libtool archive" test "$absdir" != "$libdir" && \ func_warning "'$deplib' seems to be moved" path=-L$absdir fi ;; esac case " $deplibs " in *" $path "*) ;; *) deplibs="$path $deplibs" ;; esac done fi # link_all_deplibs != no fi # linkmode = lib done # for deplib in $libs if test link = "$pass"; then if test prog = "$linkmode"; then compile_deplibs="$new_inherited_linker_flags $compile_deplibs" finalize_deplibs="$new_inherited_linker_flags $finalize_deplibs" else compiler_flags="$compiler_flags "`$ECHO " $new_inherited_linker_flags" | $SED 's% \([^ $]*\).ltframework% -framework \1%g'` fi fi dependency_libs=$newdependency_libs if test dlpreopen = "$pass"; then # Link the dlpreopened libraries before other libraries for deplib in $save_deplibs; do deplibs="$deplib $deplibs" done fi if test dlopen != "$pass"; then test conv = "$pass" || { # Make sure lib_search_path contains only unique directories. lib_search_path= for dir in $newlib_search_path; do case "$lib_search_path " in *" $dir "*) ;; *) func_append lib_search_path " $dir" ;; esac done newlib_search_path= } if test prog,link = "$linkmode,$pass"; then vars="compile_deplibs finalize_deplibs" else vars=deplibs fi for var in $vars dependency_libs; do # Add libraries to $var in reverse order eval tmp_libs=\"\$$var\" new_libs= for deplib in $tmp_libs; do # FIXME: Pedantically, this is the right thing to do, so # that some nasty dependency loop isn't accidentally # broken: #new_libs="$deplib $new_libs" # Pragmatically, this seems to cause very few problems in # practice: case $deplib in -L*) new_libs="$deplib $new_libs" ;; -R*) ;; *) # And here is the reason: when a library appears more # than once as an explicit dependence of a library, or # is implicitly linked in more than once by the # compiler, it is considered special, and multiple # occurrences thereof are not removed. Compare this # with having the same library being listed as a # dependency of multiple other libraries: in this case, # we know (pedantically, we assume) the library does not # need to be listed more than once, so we keep only the # last copy. This is not always right, but it is rare # enough that we require users that really mean to play # such unportable linking tricks to link the library # using -Wl,-lname, so that libtool does not consider it # for duplicate removal. case " $specialdeplibs " in *" $deplib "*) new_libs="$deplib $new_libs" ;; *) case " $new_libs " in *" $deplib "*) ;; *) new_libs="$deplib $new_libs" ;; esac ;; esac ;; esac done tmp_libs= for deplib in $new_libs; do case $deplib in -L*) case " $tmp_libs " in *" $deplib "*) ;; *) func_append tmp_libs " $deplib" ;; esac ;; *) func_append tmp_libs " $deplib" ;; esac done eval $var=\"$tmp_libs\" done # for var fi # Add Sun CC postdeps if required: test CXX = "$tagname" && { case $host_os in linux*) case `$CC -V 2>&1 | sed 5q` in *Sun\ C*) # Sun C++ 5.9 func_suncc_cstd_abi if test no != "$suncc_use_cstd_abi"; then func_append postdeps ' -library=Cstd -library=Crun' fi ;; esac ;; solaris*) func_cc_basename "$CC" case $func_cc_basename_result in CC* | sunCC*) func_suncc_cstd_abi if test no != "$suncc_use_cstd_abi"; then func_append postdeps ' -library=Cstd -library=Crun' fi ;; esac ;; esac } # Last step: remove runtime libs from dependency_libs # (they stay in deplibs) tmp_libs= for i in $dependency_libs; do case " $predeps $postdeps $compiler_lib_search_path " in *" $i "*) i= ;; esac if test -n "$i"; then func_append tmp_libs " $i" fi done dependency_libs=$tmp_libs done # for pass if test prog = "$linkmode"; then dlfiles=$newdlfiles fi if test prog = "$linkmode" || test lib = "$linkmode"; then dlprefiles=$newdlprefiles fi case $linkmode in oldlib) if test -n "$dlfiles$dlprefiles" || test no != "$dlself"; then func_warning "'-dlopen' is ignored for archives" fi case " $deplibs" in *\ -l* | *\ -L*) func_warning "'-l' and '-L' are ignored for archives" ;; esac test -n "$rpath" && \ func_warning "'-rpath' is ignored for archives" test -n "$xrpath" && \ func_warning "'-R' is ignored for archives" test -n "$vinfo" && \ func_warning "'-version-info/-version-number' is ignored for archives" test -n "$release" && \ func_warning "'-release' is ignored for archives" test -n "$export_symbols$export_symbols_regex" && \ func_warning "'-export-symbols' is ignored for archives" # Now set the variables for building old libraries. build_libtool_libs=no oldlibs=$output func_append objs "$old_deplibs" ;; lib) # Make sure we only generate libraries of the form 'libNAME.la'. case $outputname in lib*) func_stripname 'lib' '.la' "$outputname" name=$func_stripname_result eval shared_ext=\"$shrext_cmds\" eval libname=\"$libname_spec\" ;; *) test no = "$module" \ && func_fatal_help "libtool library '$output' must begin with 'lib'" if test no != "$need_lib_prefix"; then # Add the "lib" prefix for modules if required func_stripname '' '.la' "$outputname" name=$func_stripname_result eval shared_ext=\"$shrext_cmds\" eval libname=\"$libname_spec\" else func_stripname '' '.la' "$outputname" libname=$func_stripname_result fi ;; esac if test -n "$objs"; then if test pass_all != "$deplibs_check_method"; then func_fatal_error "cannot build libtool library '$output' from non-libtool objects on this host:$objs" else echo $ECHO "*** Warning: Linking the shared library $output against the non-libtool" $ECHO "*** objects $objs is not portable!" func_append libobjs " $objs" fi fi test no = "$dlself" \ || func_warning "'-dlopen self' is ignored for libtool libraries" set dummy $rpath shift test 1 -lt "$#" \ && func_warning "ignoring multiple '-rpath's for a libtool library" install_libdir=$1 oldlibs= if test -z "$rpath"; then if test yes = "$build_libtool_libs"; then # Building a libtool convenience library. # Some compilers have problems with a '.al' extension so # convenience libraries should have the same extension an # archive normally would. oldlibs="$output_objdir/$libname.$libext $oldlibs" build_libtool_libs=convenience build_old_libs=yes fi test -n "$vinfo" && \ func_warning "'-version-info/-version-number' is ignored for convenience libraries" test -n "$release" && \ func_warning "'-release' is ignored for convenience libraries" else # Parse the version information argument. save_ifs=$IFS; IFS=: set dummy $vinfo 0 0 0 shift IFS=$save_ifs test -n "$7" && \ func_fatal_help "too many parameters to '-version-info'" # convert absolute version numbers to libtool ages # this retains compatibility with .la files and attempts # to make the code below a bit more comprehensible case $vinfo_number in yes) number_major=$1 number_minor=$2 number_revision=$3 # # There are really only two kinds -- those that # use the current revision as the major version # and those that subtract age and use age as # a minor version. But, then there is irix # that has an extra 1 added just for fun # case $version_type in # correct linux to gnu/linux during the next big refactor darwin|freebsd-elf|linux|osf|windows|none) func_arith $number_major + $number_minor current=$func_arith_result age=$number_minor revision=$number_revision ;; freebsd-aout|qnx|sunos) current=$number_major revision=$number_minor age=0 ;; irix|nonstopux) func_arith $number_major + $number_minor current=$func_arith_result age=$number_minor revision=$number_minor lt_irix_increment=no ;; esac ;; no) current=$1 revision=$2 age=$3 ;; esac # Check that each of the things are valid numbers. case $current in 0|[1-9]|[1-9][0-9]|[1-9][0-9][0-9]|[1-9][0-9][0-9][0-9]|[1-9][0-9][0-9][0-9][0-9]) ;; *) func_error "CURRENT '$current' must be a nonnegative integer" func_fatal_error "'$vinfo' is not valid version information" ;; esac case $revision in 0|[1-9]|[1-9][0-9]|[1-9][0-9][0-9]|[1-9][0-9][0-9][0-9]|[1-9][0-9][0-9][0-9][0-9]) ;; *) func_error "REVISION '$revision' must be a nonnegative integer" func_fatal_error "'$vinfo' is not valid version information" ;; esac case $age in 0|[1-9]|[1-9][0-9]|[1-9][0-9][0-9]|[1-9][0-9][0-9][0-9]|[1-9][0-9][0-9][0-9][0-9]) ;; *) func_error "AGE '$age' must be a nonnegative integer" func_fatal_error "'$vinfo' is not valid version information" ;; esac if test "$age" -gt "$current"; then func_error "AGE '$age' is greater than the current interface number '$current'" func_fatal_error "'$vinfo' is not valid version information" fi # Calculate the version variables. major= versuffix= verstring= case $version_type in none) ;; darwin) # Like Linux, but with the current version available in # verstring for coding it into the library header func_arith $current - $age major=.$func_arith_result versuffix=$major.$age.$revision # Darwin ld doesn't like 0 for these options... func_arith $current + 1 minor_current=$func_arith_result xlcverstring="$wl-compatibility_version $wl$minor_current $wl-current_version $wl$minor_current.$revision" verstring="-compatibility_version $minor_current -current_version $minor_current.$revision" # On Darwin other compilers case $CC in nagfor*) verstring="$wl-compatibility_version $wl$minor_current $wl-current_version $wl$minor_current.$revision" ;; *) verstring="-compatibility_version $minor_current -current_version $minor_current.$revision" ;; esac ;; freebsd-aout) major=.$current versuffix=.$current.$revision ;; freebsd-elf) func_arith $current - $age major=.$func_arith_result versuffix=$major.$age.$revision ;; irix | nonstopux) if test no = "$lt_irix_increment"; then func_arith $current - $age else func_arith $current - $age + 1 fi major=$func_arith_result case $version_type in nonstopux) verstring_prefix=nonstopux ;; *) verstring_prefix=sgi ;; esac verstring=$verstring_prefix$major.$revision # Add in all the interfaces that we are compatible with. loop=$revision while test 0 -ne "$loop"; do func_arith $revision - $loop iface=$func_arith_result func_arith $loop - 1 loop=$func_arith_result verstring=$verstring_prefix$major.$iface:$verstring done # Before this point, $major must not contain '.'. major=.$major versuffix=$major.$revision ;; linux) # correct to gnu/linux during the next big refactor func_arith $current - $age major=.$func_arith_result versuffix=$major.$age.$revision ;; osf) func_arith $current - $age major=.$func_arith_result versuffix=.$current.$age.$revision verstring=$current.$age.$revision # Add in all the interfaces that we are compatible with. loop=$age while test 0 -ne "$loop"; do func_arith $current - $loop iface=$func_arith_result func_arith $loop - 1 loop=$func_arith_result verstring=$verstring:$iface.0 done # Make executables depend on our current version. func_append verstring ":$current.0" ;; qnx) major=.$current versuffix=.$current ;; sco) major=.$current versuffix=.$current ;; sunos) major=.$current versuffix=.$current.$revision ;; windows) # Use '-' rather than '.', since we only want one # extension on DOS 8.3 file systems. func_arith $current - $age major=$func_arith_result versuffix=-$major ;; *) func_fatal_configuration "unknown library version type '$version_type'" ;; esac # Clear the version info if we defaulted, and they specified a release. if test -z "$vinfo" && test -n "$release"; then major= case $version_type in darwin) # we can't check for "0.0" in archive_cmds due to quoting # problems, so we reset it completely verstring= ;; *) verstring=0.0 ;; esac if test no = "$need_version"; then versuffix= else versuffix=.0.0 fi fi # Remove version info from name if versioning should be avoided if test yes,no = "$avoid_version,$need_version"; then major= versuffix= verstring= fi # Check to see if the archive will have undefined symbols. if test yes = "$allow_undefined"; then if test unsupported = "$allow_undefined_flag"; then if test yes = "$build_old_libs"; then func_warning "undefined symbols not allowed in $host shared libraries; building static only" build_libtool_libs=no else func_fatal_error "can't build $host shared library unless -no-undefined is specified" fi fi else # Don't allow undefined symbols. allow_undefined_flag=$no_undefined_flag fi fi func_generate_dlsyms "$libname" "$libname" : func_append libobjs " $symfileobj" test " " = "$libobjs" && libobjs= if test relink != "$opt_mode"; then # Remove our outputs, but don't remove object files since they # may have been created when compiling PIC objects. removelist= tempremovelist=`$ECHO "$output_objdir/*"` for p in $tempremovelist; do case $p in *.$objext | *.gcno) ;; $output_objdir/$outputname | $output_objdir/$libname.* | $output_objdir/$libname$release.*) if test -n "$precious_files_regex"; then if $ECHO "$p" | $EGREP -e "$precious_files_regex" >/dev/null 2>&1 then continue fi fi func_append removelist " $p" ;; *) ;; esac done test -n "$removelist" && \ func_show_eval "${RM}r \$removelist" fi # Now set the variables for building old libraries. if test yes = "$build_old_libs" && test convenience != "$build_libtool_libs"; then func_append oldlibs " $output_objdir/$libname.$libext" # Transform .lo files to .o files. oldobjs="$objs "`$ECHO "$libobjs" | $SP2NL | $SED "/\.$libext$/d; $lo2o" | $NL2SP` fi # Eliminate all temporary directories. #for path in $notinst_path; do # lib_search_path=`$ECHO "$lib_search_path " | $SED "s% $path % %g"` # deplibs=`$ECHO "$deplibs " | $SED "s% -L$path % %g"` # dependency_libs=`$ECHO "$dependency_libs " | $SED "s% -L$path % %g"` #done if test -n "$xrpath"; then # If the user specified any rpath flags, then add them. temp_xrpath= for libdir in $xrpath; do func_replace_sysroot "$libdir" func_append temp_xrpath " -R$func_replace_sysroot_result" case "$finalize_rpath " in *" $libdir "*) ;; *) func_append finalize_rpath " $libdir" ;; esac done if test yes != "$hardcode_into_libs" || test yes = "$build_old_libs"; then dependency_libs="$temp_xrpath $dependency_libs" fi fi # Make sure dlfiles contains only unique files that won't be dlpreopened old_dlfiles=$dlfiles dlfiles= for lib in $old_dlfiles; do case " $dlprefiles $dlfiles " in *" $lib "*) ;; *) func_append dlfiles " $lib" ;; esac done # Make sure dlprefiles contains only unique files old_dlprefiles=$dlprefiles dlprefiles= for lib in $old_dlprefiles; do case "$dlprefiles " in *" $lib "*) ;; *) func_append dlprefiles " $lib" ;; esac done if test yes = "$build_libtool_libs"; then if test -n "$rpath"; then case $host in *-*-cygwin* | *-*-mingw* | *-*-pw32* | *-*-os2* | *-*-beos* | *-cegcc* | *-*-haiku*) # these systems don't actually have a c library (as such)! ;; *-*-rhapsody* | *-*-darwin1.[012]) # Rhapsody C library is in the System framework func_append deplibs " System.ltframework" ;; *-*-netbsd*) # Don't link with libc until the a.out ld.so is fixed. ;; *-*-openbsd* | *-*-freebsd* | *-*-dragonfly*) # Do not include libc due to us having libc/libc_r. ;; *-*-sco3.2v5* | *-*-sco5v6*) # Causes problems with __ctype ;; *-*-sysv4.2uw2* | *-*-sysv5* | *-*-unixware* | *-*-OpenUNIX*) # Compiler inserts libc in the correct place for threads to work ;; *) # Add libc to deplibs on all other systems if necessary. if test yes = "$build_libtool_need_lc"; then func_append deplibs " -lc" fi ;; esac fi # Transform deplibs into only deplibs that can be linked in shared. name_save=$name libname_save=$libname release_save=$release versuffix_save=$versuffix major_save=$major # I'm not sure if I'm treating the release correctly. I think # release should show up in the -l (ie -lgmp5) so we don't want to # add it in twice. Is that correct? release= versuffix= major= newdeplibs= droppeddeps=no case $deplibs_check_method in pass_all) # Don't check for shared/static. Everything works. # This might be a little naive. We might want to check # whether the library exists or not. But this is on # osf3 & osf4 and I'm not really sure... Just # implementing what was already the behavior. newdeplibs=$deplibs ;; test_compile) # This code stresses the "libraries are programs" paradigm to its # limits. Maybe even breaks it. We compile a program, linking it # against the deplibs as a proxy for the library. Then we can check # whether they linked in statically or dynamically with ldd. $opt_dry_run || $RM conftest.c cat > conftest.c </dev/null` $nocaseglob else potential_libs=`ls $i/$libnameglob[.-]* 2>/dev/null` fi for potent_lib in $potential_libs; do # Follow soft links. if ls -lLd "$potent_lib" 2>/dev/null | $GREP " -> " >/dev/null; then continue fi # The statement above tries to avoid entering an # endless loop below, in case of cyclic links. # We might still enter an endless loop, since a link # loop can be closed while we follow links, # but so what? potlib=$potent_lib while test -h "$potlib" 2>/dev/null; do potliblink=`ls -ld $potlib | $SED 's/.* -> //'` case $potliblink in [\\/]* | [A-Za-z]:[\\/]*) potlib=$potliblink;; *) potlib=`$ECHO "$potlib" | $SED 's|[^/]*$||'`"$potliblink";; esac done if eval $file_magic_cmd \"\$potlib\" 2>/dev/null | $SED -e 10q | $EGREP "$file_magic_regex" > /dev/null; then func_append newdeplibs " $a_deplib" a_deplib= break 2 fi done done fi if test -n "$a_deplib"; then droppeddeps=yes echo $ECHO "*** Warning: linker path does not have real file for library $a_deplib." echo "*** I have the capability to make that library automatically link in when" echo "*** you link to this library. But I can only do this if you have a" echo "*** shared version of the library, which you do not appear to have" echo "*** because I did check the linker path looking for a file starting" if test -z "$potlib"; then $ECHO "*** with $libname but no candidates were found. (...for file magic test)" else $ECHO "*** with $libname and none of the candidates passed a file format test" $ECHO "*** using a file magic. Last file checked: $potlib" fi fi ;; *) # Add a -L argument. func_append newdeplibs " $a_deplib" ;; esac done # Gone through all deplibs. ;; match_pattern*) set dummy $deplibs_check_method; shift match_pattern_regex=`expr "$deplibs_check_method" : "$1 \(.*\)"` for a_deplib in $deplibs; do case $a_deplib in -l*) func_stripname -l '' "$a_deplib" name=$func_stripname_result if test yes = "$allow_libtool_libs_with_static_runtimes"; then case " $predeps $postdeps " in *" $a_deplib "*) func_append newdeplibs " $a_deplib" a_deplib= ;; esac fi if test -n "$a_deplib"; then libname=`eval "\\$ECHO \"$libname_spec\""` for i in $lib_search_path $sys_lib_search_path $shlib_search_path; do potential_libs=`ls $i/$libname[.-]* 2>/dev/null` for potent_lib in $potential_libs; do potlib=$potent_lib # see symlink-check above in file_magic test if eval "\$ECHO \"$potent_lib\"" 2>/dev/null | $SED 10q | \ $EGREP "$match_pattern_regex" > /dev/null; then func_append newdeplibs " $a_deplib" a_deplib= break 2 fi done done fi if test -n "$a_deplib"; then droppeddeps=yes echo $ECHO "*** Warning: linker path does not have real file for library $a_deplib." echo "*** I have the capability to make that library automatically link in when" echo "*** you link to this library. But I can only do this if you have a" echo "*** shared version of the library, which you do not appear to have" echo "*** because I did check the linker path looking for a file starting" if test -z "$potlib"; then $ECHO "*** with $libname but no candidates were found. (...for regex pattern test)" else $ECHO "*** with $libname and none of the candidates passed a file format test" $ECHO "*** using a regex pattern. Last file checked: $potlib" fi fi ;; *) # Add a -L argument. func_append newdeplibs " $a_deplib" ;; esac done # Gone through all deplibs. ;; none | unknown | *) newdeplibs= tmp_deplibs=`$ECHO " $deplibs" | $SED 's/ -lc$//; s/ -[LR][^ ]*//g'` if test yes = "$allow_libtool_libs_with_static_runtimes"; then for i in $predeps $postdeps; do # can't use Xsed below, because $i might contain '/' tmp_deplibs=`$ECHO " $tmp_deplibs" | $SED "s|$i||"` done fi case $tmp_deplibs in *[!\ \ ]*) echo if test none = "$deplibs_check_method"; then echo "*** Warning: inter-library dependencies are not supported in this platform." else echo "*** Warning: inter-library dependencies are not known to be supported." fi echo "*** All declared inter-library dependencies are being dropped." droppeddeps=yes ;; esac ;; esac versuffix=$versuffix_save major=$major_save release=$release_save libname=$libname_save name=$name_save case $host in *-*-rhapsody* | *-*-darwin1.[012]) # On Rhapsody replace the C library with the System framework newdeplibs=`$ECHO " $newdeplibs" | $SED 's/ -lc / System.ltframework /'` ;; esac if test yes = "$droppeddeps"; then if test yes = "$module"; then echo echo "*** Warning: libtool could not satisfy all declared inter-library" $ECHO "*** dependencies of module $libname. Therefore, libtool will create" echo "*** a static module, that should work as long as the dlopening" echo "*** application is linked with the -dlopen flag." if test -z "$global_symbol_pipe"; then echo echo "*** However, this would only work if libtool was able to extract symbol" echo "*** lists from a program, using 'nm' or equivalent, but libtool could" echo "*** not find such a program. So, this module is probably useless." echo "*** 'nm' from GNU binutils and a full rebuild may help." fi if test no = "$build_old_libs"; then oldlibs=$output_objdir/$libname.$libext build_libtool_libs=module build_old_libs=yes else build_libtool_libs=no fi else echo "*** The inter-library dependencies that have been dropped here will be" echo "*** automatically added whenever a program is linked with this library" echo "*** or is declared to -dlopen it." if test no = "$allow_undefined"; then echo echo "*** Since this library must not contain undefined symbols," echo "*** because either the platform does not support them or" echo "*** it was explicitly requested with -no-undefined," echo "*** libtool will only create a static version of it." if test no = "$build_old_libs"; then oldlibs=$output_objdir/$libname.$libext build_libtool_libs=module build_old_libs=yes else build_libtool_libs=no fi fi fi fi # Done checking deplibs! deplibs=$newdeplibs fi # Time to change all our "foo.ltframework" stuff back to "-framework foo" case $host in *-*-darwin*) newdeplibs=`$ECHO " $newdeplibs" | $SED 's% \([^ $]*\).ltframework% -framework \1%g'` new_inherited_linker_flags=`$ECHO " $new_inherited_linker_flags" | $SED 's% \([^ $]*\).ltframework% -framework \1%g'` deplibs=`$ECHO " $deplibs" | $SED 's% \([^ $]*\).ltframework% -framework \1%g'` ;; esac # move library search paths that coincide with paths to not yet # installed libraries to the beginning of the library search list new_libs= for path in $notinst_path; do case " $new_libs " in *" -L$path/$objdir "*) ;; *) case " $deplibs " in *" -L$path/$objdir "*) func_append new_libs " -L$path/$objdir" ;; esac ;; esac done for deplib in $deplibs; do case $deplib in -L*) case " $new_libs " in *" $deplib "*) ;; *) func_append new_libs " $deplib" ;; esac ;; *) func_append new_libs " $deplib" ;; esac done deplibs=$new_libs # All the library-specific variables (install_libdir is set above). library_names= old_library= dlname= # Test again, we may have decided not to build it any more if test yes = "$build_libtool_libs"; then # Remove $wl instances when linking with ld. # FIXME: should test the right _cmds variable. case $archive_cmds in *\$LD\ *) wl= ;; esac if test yes = "$hardcode_into_libs"; then # Hardcode the library paths hardcode_libdirs= dep_rpath= rpath=$finalize_rpath test relink = "$opt_mode" || rpath=$compile_rpath$rpath for libdir in $rpath; do if test -n "$hardcode_libdir_flag_spec"; then if test -n "$hardcode_libdir_separator"; then func_replace_sysroot "$libdir" libdir=$func_replace_sysroot_result if test -z "$hardcode_libdirs"; then hardcode_libdirs=$libdir else # Just accumulate the unique libdirs. case $hardcode_libdir_separator$hardcode_libdirs$hardcode_libdir_separator in *"$hardcode_libdir_separator$libdir$hardcode_libdir_separator"*) ;; *) func_append hardcode_libdirs "$hardcode_libdir_separator$libdir" ;; esac fi else eval flag=\"$hardcode_libdir_flag_spec\" func_append dep_rpath " $flag" fi elif test -n "$runpath_var"; then case "$perm_rpath " in *" $libdir "*) ;; *) func_append perm_rpath " $libdir" ;; esac fi done # Substitute the hardcoded libdirs into the rpath. if test -n "$hardcode_libdir_separator" && test -n "$hardcode_libdirs"; then libdir=$hardcode_libdirs eval "dep_rpath=\"$hardcode_libdir_flag_spec\"" fi if test -n "$runpath_var" && test -n "$perm_rpath"; then # We should set the runpath_var. rpath= for dir in $perm_rpath; do func_append rpath "$dir:" done eval "$runpath_var='$rpath\$$runpath_var'; export $runpath_var" fi test -n "$dep_rpath" && deplibs="$dep_rpath $deplibs" fi shlibpath=$finalize_shlibpath test relink = "$opt_mode" || shlibpath=$compile_shlibpath$shlibpath if test -n "$shlibpath"; then eval "$shlibpath_var='$shlibpath\$$shlibpath_var'; export $shlibpath_var" fi # Get the real and link names of the library. eval shared_ext=\"$shrext_cmds\" eval library_names=\"$library_names_spec\" set dummy $library_names shift realname=$1 shift if test -n "$soname_spec"; then eval soname=\"$soname_spec\" else soname=$realname fi if test -z "$dlname"; then dlname=$soname fi lib=$output_objdir/$realname linknames= for link do func_append linknames " $link" done # Use standard objects if they are pic test -z "$pic_flag" && libobjs=`$ECHO "$libobjs" | $SP2NL | $SED "$lo2o" | $NL2SP` test "X$libobjs" = "X " && libobjs= delfiles= if test -n "$export_symbols" && test -n "$include_expsyms"; then $opt_dry_run || cp "$export_symbols" "$output_objdir/$libname.uexp" export_symbols=$output_objdir/$libname.uexp func_append delfiles " $export_symbols" fi orig_export_symbols= case $host_os in cygwin* | mingw* | cegcc*) if test -n "$export_symbols" && test -z "$export_symbols_regex"; then # exporting using user supplied symfile func_dll_def_p "$export_symbols" || { # and it's NOT already a .def file. Must figure out # which of the given symbols are data symbols and tag # them as such. So, trigger use of export_symbols_cmds. # export_symbols gets reassigned inside the "prepare # the list of exported symbols" if statement, so the # include_expsyms logic still works. orig_export_symbols=$export_symbols export_symbols= always_export_symbols=yes } fi ;; esac # Prepare the list of exported symbols if test -z "$export_symbols"; then if test yes = "$always_export_symbols" || test -n "$export_symbols_regex"; then func_verbose "generating symbol list for '$libname.la'" export_symbols=$output_objdir/$libname.exp $opt_dry_run || $RM $export_symbols cmds=$export_symbols_cmds save_ifs=$IFS; IFS='~' for cmd1 in $cmds; do IFS=$save_ifs # Take the normal branch if the nm_file_list_spec branch # doesn't work or if tool conversion is not needed. case $nm_file_list_spec~$to_tool_file_cmd in *~func_convert_file_noop | *~func_convert_file_msys_to_w32 | ~*) try_normal_branch=yes eval cmd=\"$cmd1\" func_len " $cmd" len=$func_len_result ;; *) try_normal_branch=no ;; esac if test yes = "$try_normal_branch" \ && { test "$len" -lt "$max_cmd_len" \ || test "$max_cmd_len" -le -1; } then func_show_eval "$cmd" 'exit $?' skipped_export=false elif test -n "$nm_file_list_spec"; then func_basename "$output" output_la=$func_basename_result save_libobjs=$libobjs save_output=$output output=$output_objdir/$output_la.nm func_to_tool_file "$output" libobjs=$nm_file_list_spec$func_to_tool_file_result func_append delfiles " $output" func_verbose "creating $NM input file list: $output" for obj in $save_libobjs; do func_to_tool_file "$obj" $ECHO "$func_to_tool_file_result" done > "$output" eval cmd=\"$cmd1\" func_show_eval "$cmd" 'exit $?' output=$save_output libobjs=$save_libobjs skipped_export=false else # The command line is too long to execute in one step. func_verbose "using reloadable object file for export list..." skipped_export=: # Break out early, otherwise skipped_export may be # set to false by a later but shorter cmd. break fi done IFS=$save_ifs if test -n "$export_symbols_regex" && test : != "$skipped_export"; then func_show_eval '$EGREP -e "$export_symbols_regex" "$export_symbols" > "${export_symbols}T"' func_show_eval '$MV "${export_symbols}T" "$export_symbols"' fi fi fi if test -n "$export_symbols" && test -n "$include_expsyms"; then tmp_export_symbols=$export_symbols test -n "$orig_export_symbols" && tmp_export_symbols=$orig_export_symbols $opt_dry_run || eval '$ECHO "$include_expsyms" | $SP2NL >> "$tmp_export_symbols"' fi if test : != "$skipped_export" && test -n "$orig_export_symbols"; then # The given exports_symbols file has to be filtered, so filter it. func_verbose "filter symbol list for '$libname.la' to tag DATA exports" # FIXME: $output_objdir/$libname.filter potentially contains lots of # 's' commands, which not all seds can handle. GNU sed should be fine # though. Also, the filter scales superlinearly with the number of # global variables. join(1) would be nice here, but unfortunately # isn't a blessed tool. $opt_dry_run || $SED -e '/[ ,]DATA/!d;s,\(.*\)\([ \,].*\),s|^\1$|\1\2|,' < $export_symbols > $output_objdir/$libname.filter func_append delfiles " $export_symbols $output_objdir/$libname.filter" export_symbols=$output_objdir/$libname.def $opt_dry_run || $SED -f $output_objdir/$libname.filter < $orig_export_symbols > $export_symbols fi tmp_deplibs= for test_deplib in $deplibs; do case " $convenience " in *" $test_deplib "*) ;; *) func_append tmp_deplibs " $test_deplib" ;; esac done deplibs=$tmp_deplibs if test -n "$convenience"; then if test -n "$whole_archive_flag_spec" && test yes = "$compiler_needs_object" && test -z "$libobjs"; then # extract the archives, so we have objects to list. # TODO: could optimize this to just extract one archive. whole_archive_flag_spec= fi if test -n "$whole_archive_flag_spec"; then save_libobjs=$libobjs eval libobjs=\"\$libobjs $whole_archive_flag_spec\" test "X$libobjs" = "X " && libobjs= else gentop=$output_objdir/${outputname}x func_append generated " $gentop" func_extract_archives $gentop $convenience func_append libobjs " $func_extract_archives_result" test "X$libobjs" = "X " && libobjs= fi fi if test yes = "$thread_safe" && test -n "$thread_safe_flag_spec"; then eval flag=\"$thread_safe_flag_spec\" func_append linker_flags " $flag" fi # Make a backup of the uninstalled library when relinking if test relink = "$opt_mode"; then $opt_dry_run || eval '(cd $output_objdir && $RM ${realname}U && $MV $realname ${realname}U)' || exit $? fi # Do each of the archive commands. if test yes = "$module" && test -n "$module_cmds"; then if test -n "$export_symbols" && test -n "$module_expsym_cmds"; then eval test_cmds=\"$module_expsym_cmds\" cmds=$module_expsym_cmds else eval test_cmds=\"$module_cmds\" cmds=$module_cmds fi else if test -n "$export_symbols" && test -n "$archive_expsym_cmds"; then eval test_cmds=\"$archive_expsym_cmds\" cmds=$archive_expsym_cmds else eval test_cmds=\"$archive_cmds\" cmds=$archive_cmds fi fi if test : != "$skipped_export" && func_len " $test_cmds" && len=$func_len_result && test "$len" -lt "$max_cmd_len" || test "$max_cmd_len" -le -1; then : else # The command line is too long to link in one step, link piecewise # or, if using GNU ld and skipped_export is not :, use a linker # script. # Save the value of $output and $libobjs because we want to # use them later. If we have whole_archive_flag_spec, we # want to use save_libobjs as it was before # whole_archive_flag_spec was expanded, because we can't # assume the linker understands whole_archive_flag_spec. # This may have to be revisited, in case too many # convenience libraries get linked in and end up exceeding # the spec. if test -z "$convenience" || test -z "$whole_archive_flag_spec"; then save_libobjs=$libobjs fi save_output=$output func_basename "$output" output_la=$func_basename_result # Clear the reloadable object creation command queue and # initialize k to one. test_cmds= concat_cmds= objlist= last_robj= k=1 if test -n "$save_libobjs" && test : != "$skipped_export" && test yes = "$with_gnu_ld"; then output=$output_objdir/$output_la.lnkscript func_verbose "creating GNU ld script: $output" echo 'INPUT (' > $output for obj in $save_libobjs do func_to_tool_file "$obj" $ECHO "$func_to_tool_file_result" >> $output done echo ')' >> $output func_append delfiles " $output" func_to_tool_file "$output" output=$func_to_tool_file_result elif test -n "$save_libobjs" && test : != "$skipped_export" && test -n "$file_list_spec"; then output=$output_objdir/$output_la.lnk func_verbose "creating linker input file list: $output" : > $output set x $save_libobjs shift firstobj= if test yes = "$compiler_needs_object"; then firstobj="$1 " shift fi for obj do func_to_tool_file "$obj" $ECHO "$func_to_tool_file_result" >> $output done func_append delfiles " $output" func_to_tool_file "$output" output=$firstobj\"$file_list_spec$func_to_tool_file_result\" else if test -n "$save_libobjs"; then func_verbose "creating reloadable object files..." output=$output_objdir/$output_la-$k.$objext eval test_cmds=\"$reload_cmds\" func_len " $test_cmds" len0=$func_len_result len=$len0 # Loop over the list of objects to be linked. for obj in $save_libobjs do func_len " $obj" func_arith $len + $func_len_result len=$func_arith_result if test -z "$objlist" || test "$len" -lt "$max_cmd_len"; then func_append objlist " $obj" else # The command $test_cmds is almost too long, add a # command to the queue. if test 1 -eq "$k"; then # The first file doesn't have a previous command to add. reload_objs=$objlist eval concat_cmds=\"$reload_cmds\" else # All subsequent reloadable object files will link in # the last one created. reload_objs="$objlist $last_robj" eval concat_cmds=\"\$concat_cmds~$reload_cmds~\$RM $last_robj\" fi last_robj=$output_objdir/$output_la-$k.$objext func_arith $k + 1 k=$func_arith_result output=$output_objdir/$output_la-$k.$objext objlist=" $obj" func_len " $last_robj" func_arith $len0 + $func_len_result len=$func_arith_result fi done # Handle the remaining objects by creating one last # reloadable object file. All subsequent reloadable object # files will link in the last one created. test -z "$concat_cmds" || concat_cmds=$concat_cmds~ reload_objs="$objlist $last_robj" eval concat_cmds=\"\$concat_cmds$reload_cmds\" if test -n "$last_robj"; then eval concat_cmds=\"\$concat_cmds~\$RM $last_robj\" fi func_append delfiles " $output" else output= fi ${skipped_export-false} && { func_verbose "generating symbol list for '$libname.la'" export_symbols=$output_objdir/$libname.exp $opt_dry_run || $RM $export_symbols libobjs=$output # Append the command to create the export file. test -z "$concat_cmds" || concat_cmds=$concat_cmds~ eval concat_cmds=\"\$concat_cmds$export_symbols_cmds\" if test -n "$last_robj"; then eval concat_cmds=\"\$concat_cmds~\$RM $last_robj\" fi } test -n "$save_libobjs" && func_verbose "creating a temporary reloadable object file: $output" # Loop through the commands generated above and execute them. save_ifs=$IFS; IFS='~' for cmd in $concat_cmds; do IFS=$save_ifs $opt_quiet || { func_quote_for_expand "$cmd" eval "func_echo $func_quote_for_expand_result" } $opt_dry_run || eval "$cmd" || { lt_exit=$? # Restore the uninstalled library and exit if test relink = "$opt_mode"; then ( cd "$output_objdir" && \ $RM "${realname}T" && \ $MV "${realname}U" "$realname" ) fi exit $lt_exit } done IFS=$save_ifs if test -n "$export_symbols_regex" && ${skipped_export-false}; then func_show_eval '$EGREP -e "$export_symbols_regex" "$export_symbols" > "${export_symbols}T"' func_show_eval '$MV "${export_symbols}T" "$export_symbols"' fi fi ${skipped_export-false} && { if test -n "$export_symbols" && test -n "$include_expsyms"; then tmp_export_symbols=$export_symbols test -n "$orig_export_symbols" && tmp_export_symbols=$orig_export_symbols $opt_dry_run || eval '$ECHO "$include_expsyms" | $SP2NL >> "$tmp_export_symbols"' fi if test -n "$orig_export_symbols"; then # The given exports_symbols file has to be filtered, so filter it. func_verbose "filter symbol list for '$libname.la' to tag DATA exports" # FIXME: $output_objdir/$libname.filter potentially contains lots of # 's' commands, which not all seds can handle. GNU sed should be fine # though. Also, the filter scales superlinearly with the number of # global variables. join(1) would be nice here, but unfortunately # isn't a blessed tool. $opt_dry_run || $SED -e '/[ ,]DATA/!d;s,\(.*\)\([ \,].*\),s|^\1$|\1\2|,' < $export_symbols > $output_objdir/$libname.filter func_append delfiles " $export_symbols $output_objdir/$libname.filter" export_symbols=$output_objdir/$libname.def $opt_dry_run || $SED -f $output_objdir/$libname.filter < $orig_export_symbols > $export_symbols fi } libobjs=$output # Restore the value of output. output=$save_output if test -n "$convenience" && test -n "$whole_archive_flag_spec"; then eval libobjs=\"\$libobjs $whole_archive_flag_spec\" test "X$libobjs" = "X " && libobjs= fi # Expand the library linking commands again to reset the # value of $libobjs for piecewise linking. # Do each of the archive commands. if test yes = "$module" && test -n "$module_cmds"; then if test -n "$export_symbols" && test -n "$module_expsym_cmds"; then cmds=$module_expsym_cmds else cmds=$module_cmds fi else if test -n "$export_symbols" && test -n "$archive_expsym_cmds"; then cmds=$archive_expsym_cmds else cmds=$archive_cmds fi fi fi if test -n "$delfiles"; then # Append the command to remove temporary files to $cmds. eval cmds=\"\$cmds~\$RM $delfiles\" fi # Add any objects from preloaded convenience libraries if test -n "$dlprefiles"; then gentop=$output_objdir/${outputname}x func_append generated " $gentop" func_extract_archives $gentop $dlprefiles func_append libobjs " $func_extract_archives_result" test "X$libobjs" = "X " && libobjs= fi save_ifs=$IFS; IFS='~' for cmd in $cmds; do IFS=$sp$nl eval cmd=\"$cmd\" IFS=$save_ifs $opt_quiet || { func_quote_for_expand "$cmd" eval "func_echo $func_quote_for_expand_result" } $opt_dry_run || eval "$cmd" || { lt_exit=$? # Restore the uninstalled library and exit if test relink = "$opt_mode"; then ( cd "$output_objdir" && \ $RM "${realname}T" && \ $MV "${realname}U" "$realname" ) fi exit $lt_exit } done IFS=$save_ifs # Restore the uninstalled library and exit if test relink = "$opt_mode"; then $opt_dry_run || eval '(cd $output_objdir && $RM ${realname}T && $MV $realname ${realname}T && $MV ${realname}U $realname)' || exit $? if test -n "$convenience"; then if test -z "$whole_archive_flag_spec"; then func_show_eval '${RM}r "$gentop"' fi fi exit $EXIT_SUCCESS fi # Create links to the real library. for linkname in $linknames; do if test "$realname" != "$linkname"; then func_show_eval '(cd "$output_objdir" && $RM "$linkname" && $LN_S "$realname" "$linkname")' 'exit $?' fi done # If -module or -export-dynamic was specified, set the dlname. if test yes = "$module" || test yes = "$export_dynamic"; then # On all known operating systems, these are identical. dlname=$soname fi fi ;; obj) if test -n "$dlfiles$dlprefiles" || test no != "$dlself"; then func_warning "'-dlopen' is ignored for objects" fi case " $deplibs" in *\ -l* | *\ -L*) func_warning "'-l' and '-L' are ignored for objects" ;; esac test -n "$rpath" && \ func_warning "'-rpath' is ignored for objects" test -n "$xrpath" && \ func_warning "'-R' is ignored for objects" test -n "$vinfo" && \ func_warning "'-version-info' is ignored for objects" test -n "$release" && \ func_warning "'-release' is ignored for objects" case $output in *.lo) test -n "$objs$old_deplibs" && \ func_fatal_error "cannot build library object '$output' from non-libtool objects" libobj=$output func_lo2o "$libobj" obj=$func_lo2o_result ;; *) libobj= obj=$output ;; esac # Delete the old objects. $opt_dry_run || $RM $obj $libobj # Objects from convenience libraries. This assumes # single-version convenience libraries. Whenever we create # different ones for PIC/non-PIC, this we'll have to duplicate # the extraction. reload_conv_objs= gentop= # if reload_cmds runs $LD directly, get rid of -Wl from # whole_archive_flag_spec and hope we can get by with turning comma # into space. case $reload_cmds in *\$LD[\ \$]*) wl= ;; esac if test -n "$convenience"; then if test -n "$whole_archive_flag_spec"; then eval tmp_whole_archive_flags=\"$whole_archive_flag_spec\" test -n "$wl" || tmp_whole_archive_flags=`$ECHO "$tmp_whole_archive_flags" | $SED 's|,| |g'` reload_conv_objs=$reload_objs\ $tmp_whole_archive_flags else gentop=$output_objdir/${obj}x func_append generated " $gentop" func_extract_archives $gentop $convenience reload_conv_objs="$reload_objs $func_extract_archives_result" fi fi # If we're not building shared, we need to use non_pic_objs test yes = "$build_libtool_libs" || libobjs=$non_pic_objects # Create the old-style object. reload_objs=$objs$old_deplibs' '`$ECHO "$libobjs" | $SP2NL | $SED "/\.$libext$/d; /\.lib$/d; $lo2o" | $NL2SP`' '$reload_conv_objs output=$obj func_execute_cmds "$reload_cmds" 'exit $?' # Exit if we aren't doing a library object file. if test -z "$libobj"; then if test -n "$gentop"; then func_show_eval '${RM}r "$gentop"' fi exit $EXIT_SUCCESS fi test yes = "$build_libtool_libs" || { if test -n "$gentop"; then func_show_eval '${RM}r "$gentop"' fi # Create an invalid libtool object if no PIC, so that we don't # accidentally link it into a program. # $show "echo timestamp > $libobj" # $opt_dry_run || eval "echo timestamp > $libobj" || exit $? exit $EXIT_SUCCESS } if test -n "$pic_flag" || test default != "$pic_mode"; then # Only do commands if we really have different PIC objects. reload_objs="$libobjs $reload_conv_objs" output=$libobj func_execute_cmds "$reload_cmds" 'exit $?' fi if test -n "$gentop"; then func_show_eval '${RM}r "$gentop"' fi exit $EXIT_SUCCESS ;; prog) case $host in *cygwin*) func_stripname '' '.exe' "$output" output=$func_stripname_result.exe;; esac test -n "$vinfo" && \ func_warning "'-version-info' is ignored for programs" test -n "$release" && \ func_warning "'-release' is ignored for programs" $preload \ && test unknown,unknown,unknown = "$dlopen_support,$dlopen_self,$dlopen_self_static" \ && func_warning "'LT_INIT([dlopen])' not used. Assuming no dlopen support." case $host in *-*-rhapsody* | *-*-darwin1.[012]) # On Rhapsody replace the C library is the System framework compile_deplibs=`$ECHO " $compile_deplibs" | $SED 's/ -lc / System.ltframework /'` finalize_deplibs=`$ECHO " $finalize_deplibs" | $SED 's/ -lc / System.ltframework /'` ;; esac case $host in *-*-darwin*) # Don't allow lazy linking, it breaks C++ global constructors # But is supposedly fixed on 10.4 or later (yay!). if test CXX = "$tagname"; then case ${MACOSX_DEPLOYMENT_TARGET-10.0} in 10.[0123]) func_append compile_command " $wl-bind_at_load" func_append finalize_command " $wl-bind_at_load" ;; esac fi # Time to change all our "foo.ltframework" stuff back to "-framework foo" compile_deplibs=`$ECHO " $compile_deplibs" | $SED 's% \([^ $]*\).ltframework% -framework \1%g'` finalize_deplibs=`$ECHO " $finalize_deplibs" | $SED 's% \([^ $]*\).ltframework% -framework \1%g'` ;; esac # move library search paths that coincide with paths to not yet # installed libraries to the beginning of the library search list new_libs= for path in $notinst_path; do case " $new_libs " in *" -L$path/$objdir "*) ;; *) case " $compile_deplibs " in *" -L$path/$objdir "*) func_append new_libs " -L$path/$objdir" ;; esac ;; esac done for deplib in $compile_deplibs; do case $deplib in -L*) case " $new_libs " in *" $deplib "*) ;; *) func_append new_libs " $deplib" ;; esac ;; *) func_append new_libs " $deplib" ;; esac done compile_deplibs=$new_libs func_append compile_command " $compile_deplibs" func_append finalize_command " $finalize_deplibs" if test -n "$rpath$xrpath"; then # If the user specified any rpath flags, then add them. for libdir in $rpath $xrpath; do # This is the magic to use -rpath. case "$finalize_rpath " in *" $libdir "*) ;; *) func_append finalize_rpath " $libdir" ;; esac done fi # Now hardcode the library paths rpath= hardcode_libdirs= for libdir in $compile_rpath $finalize_rpath; do if test -n "$hardcode_libdir_flag_spec"; then if test -n "$hardcode_libdir_separator"; then if test -z "$hardcode_libdirs"; then hardcode_libdirs=$libdir else # Just accumulate the unique libdirs. case $hardcode_libdir_separator$hardcode_libdirs$hardcode_libdir_separator in *"$hardcode_libdir_separator$libdir$hardcode_libdir_separator"*) ;; *) func_append hardcode_libdirs "$hardcode_libdir_separator$libdir" ;; esac fi else eval flag=\"$hardcode_libdir_flag_spec\" func_append rpath " $flag" fi elif test -n "$runpath_var"; then case "$perm_rpath " in *" $libdir "*) ;; *) func_append perm_rpath " $libdir" ;; esac fi case $host in *-*-cygwin* | *-*-mingw* | *-*-pw32* | *-*-os2* | *-cegcc*) testbindir=`$ECHO "$libdir" | $SED -e 's*/lib$*/bin*'` case :$dllsearchpath: in *":$libdir:"*) ;; ::) dllsearchpath=$libdir;; *) func_append dllsearchpath ":$libdir";; esac case :$dllsearchpath: in *":$testbindir:"*) ;; ::) dllsearchpath=$testbindir;; *) func_append dllsearchpath ":$testbindir";; esac ;; esac done # Substitute the hardcoded libdirs into the rpath. if test -n "$hardcode_libdir_separator" && test -n "$hardcode_libdirs"; then libdir=$hardcode_libdirs eval rpath=\" $hardcode_libdir_flag_spec\" fi compile_rpath=$rpath rpath= hardcode_libdirs= for libdir in $finalize_rpath; do if test -n "$hardcode_libdir_flag_spec"; then if test -n "$hardcode_libdir_separator"; then if test -z "$hardcode_libdirs"; then hardcode_libdirs=$libdir else # Just accumulate the unique libdirs. case $hardcode_libdir_separator$hardcode_libdirs$hardcode_libdir_separator in *"$hardcode_libdir_separator$libdir$hardcode_libdir_separator"*) ;; *) func_append hardcode_libdirs "$hardcode_libdir_separator$libdir" ;; esac fi else eval flag=\"$hardcode_libdir_flag_spec\" func_append rpath " $flag" fi elif test -n "$runpath_var"; then case "$finalize_perm_rpath " in *" $libdir "*) ;; *) func_append finalize_perm_rpath " $libdir" ;; esac fi done # Substitute the hardcoded libdirs into the rpath. if test -n "$hardcode_libdir_separator" && test -n "$hardcode_libdirs"; then libdir=$hardcode_libdirs eval rpath=\" $hardcode_libdir_flag_spec\" fi finalize_rpath=$rpath if test -n "$libobjs" && test yes = "$build_old_libs"; then # Transform all the library objects into standard objects. compile_command=`$ECHO "$compile_command" | $SP2NL | $SED "$lo2o" | $NL2SP` finalize_command=`$ECHO "$finalize_command" | $SP2NL | $SED "$lo2o" | $NL2SP` fi func_generate_dlsyms "$outputname" "@PROGRAM@" false # template prelinking step if test -n "$prelink_cmds"; then func_execute_cmds "$prelink_cmds" 'exit $?' fi wrappers_required=: case $host in *cegcc* | *mingw32ce*) # Disable wrappers for cegcc and mingw32ce hosts, we are cross compiling anyway. wrappers_required=false ;; *cygwin* | *mingw* ) test yes = "$build_libtool_libs" || wrappers_required=false ;; *) if test no = "$need_relink" || test yes != "$build_libtool_libs"; then wrappers_required=false fi ;; esac $wrappers_required || { # Replace the output file specification. compile_command=`$ECHO "$compile_command" | $SED 's%@OUTPUT@%'"$output"'%g'` link_command=$compile_command$compile_rpath # We have no uninstalled library dependencies, so finalize right now. exit_status=0 func_show_eval "$link_command" 'exit_status=$?' if test -n "$postlink_cmds"; then func_to_tool_file "$output" postlink_cmds=`func_echo_all "$postlink_cmds" | $SED -e 's%@OUTPUT@%'"$output"'%g' -e 's%@TOOL_OUTPUT@%'"$func_to_tool_file_result"'%g'` func_execute_cmds "$postlink_cmds" 'exit $?' fi # Delete the generated files. if test -f "$output_objdir/${outputname}S.$objext"; then func_show_eval '$RM "$output_objdir/${outputname}S.$objext"' fi exit $exit_status } if test -n "$compile_shlibpath$finalize_shlibpath"; then compile_command="$shlibpath_var=\"$compile_shlibpath$finalize_shlibpath\$$shlibpath_var\" $compile_command" fi if test -n "$finalize_shlibpath"; then finalize_command="$shlibpath_var=\"$finalize_shlibpath\$$shlibpath_var\" $finalize_command" fi compile_var= finalize_var= if test -n "$runpath_var"; then if test -n "$perm_rpath"; then # We should set the runpath_var. rpath= for dir in $perm_rpath; do func_append rpath "$dir:" done compile_var="$runpath_var=\"$rpath\$$runpath_var\" " fi if test -n "$finalize_perm_rpath"; then # We should set the runpath_var. rpath= for dir in $finalize_perm_rpath; do func_append rpath "$dir:" done finalize_var="$runpath_var=\"$rpath\$$runpath_var\" " fi fi if test yes = "$no_install"; then # We don't need to create a wrapper script. link_command=$compile_var$compile_command$compile_rpath # Replace the output file specification. link_command=`$ECHO "$link_command" | $SED 's%@OUTPUT@%'"$output"'%g'` # Delete the old output file. $opt_dry_run || $RM $output # Link the executable and exit func_show_eval "$link_command" 'exit $?' if test -n "$postlink_cmds"; then func_to_tool_file "$output" postlink_cmds=`func_echo_all "$postlink_cmds" | $SED -e 's%@OUTPUT@%'"$output"'%g' -e 's%@TOOL_OUTPUT@%'"$func_to_tool_file_result"'%g'` func_execute_cmds "$postlink_cmds" 'exit $?' fi exit $EXIT_SUCCESS fi case $hardcode_action,$fast_install in relink,*) # Fast installation is not supported link_command=$compile_var$compile_command$compile_rpath relink_command=$finalize_var$finalize_command$finalize_rpath func_warning "this platform does not like uninstalled shared libraries" func_warning "'$output' will be relinked during installation" ;; *,yes) link_command=$finalize_var$compile_command$finalize_rpath relink_command=`$ECHO "$compile_var$compile_command$compile_rpath" | $SED 's%@OUTPUT@%\$progdir/\$file%g'` ;; *,no) link_command=$compile_var$compile_command$compile_rpath relink_command=$finalize_var$finalize_command$finalize_rpath ;; *,needless) link_command=$finalize_var$compile_command$finalize_rpath relink_command= ;; esac # Replace the output file specification. link_command=`$ECHO "$link_command" | $SED 's%@OUTPUT@%'"$output_objdir/$outputname"'%g'` # Delete the old output files. $opt_dry_run || $RM $output $output_objdir/$outputname $output_objdir/lt-$outputname func_show_eval "$link_command" 'exit $?' if test -n "$postlink_cmds"; then func_to_tool_file "$output_objdir/$outputname" postlink_cmds=`func_echo_all "$postlink_cmds" | $SED -e 's%@OUTPUT@%'"$output_objdir/$outputname"'%g' -e 's%@TOOL_OUTPUT@%'"$func_to_tool_file_result"'%g'` func_execute_cmds "$postlink_cmds" 'exit $?' fi # Now create the wrapper script. func_verbose "creating $output" # Quote the relink command for shipping. if test -n "$relink_command"; then # Preserve any variables that may affect compiler behavior for var in $variables_saved_for_relink; do if eval test -z \"\${$var+set}\"; then relink_command="{ test -z \"\${$var+set}\" || $lt_unset $var || { $var=; export $var; }; }; $relink_command" elif eval var_value=\$$var; test -z "$var_value"; then relink_command="$var=; export $var; $relink_command" else func_quote_for_eval "$var_value" relink_command="$var=$func_quote_for_eval_result; export $var; $relink_command" fi done relink_command="(cd `pwd`; $relink_command)" relink_command=`$ECHO "$relink_command" | $SED "$sed_quote_subst"` fi # Only actually do things if not in dry run mode. $opt_dry_run || { # win32 will think the script is a binary if it has # a .exe suffix, so we strip it off here. case $output in *.exe) func_stripname '' '.exe' "$output" output=$func_stripname_result ;; esac # test for cygwin because mv fails w/o .exe extensions case $host in *cygwin*) exeext=.exe func_stripname '' '.exe' "$outputname" outputname=$func_stripname_result ;; *) exeext= ;; esac case $host in *cygwin* | *mingw* ) func_dirname_and_basename "$output" "" "." output_name=$func_basename_result output_path=$func_dirname_result cwrappersource=$output_path/$objdir/lt-$output_name.c cwrapper=$output_path/$output_name.exe $RM $cwrappersource $cwrapper trap "$RM $cwrappersource $cwrapper; exit $EXIT_FAILURE" 1 2 15 func_emit_cwrapperexe_src > $cwrappersource # The wrapper executable is built using the $host compiler, # because it contains $host paths and files. If cross- # compiling, it, like the target executable, must be # executed on the $host or under an emulation environment. $opt_dry_run || { $LTCC $LTCFLAGS -o $cwrapper $cwrappersource $STRIP $cwrapper } # Now, create the wrapper script for func_source use: func_ltwrapper_scriptname $cwrapper $RM $func_ltwrapper_scriptname_result trap "$RM $func_ltwrapper_scriptname_result; exit $EXIT_FAILURE" 1 2 15 $opt_dry_run || { # note: this script will not be executed, so do not chmod. if test "x$build" = "x$host"; then $cwrapper --lt-dump-script > $func_ltwrapper_scriptname_result else func_emit_wrapper no > $func_ltwrapper_scriptname_result fi } ;; * ) $RM $output trap "$RM $output; exit $EXIT_FAILURE" 1 2 15 func_emit_wrapper no > $output chmod +x $output ;; esac } exit $EXIT_SUCCESS ;; esac # See if we need to build an old-fashioned archive. for oldlib in $oldlibs; do case $build_libtool_libs in convenience) oldobjs="$libobjs_save $symfileobj" addlibs=$convenience build_libtool_libs=no ;; module) oldobjs=$libobjs_save addlibs=$old_convenience build_libtool_libs=no ;; *) oldobjs="$old_deplibs $non_pic_objects" $preload && test -f "$symfileobj" \ && func_append oldobjs " $symfileobj" addlibs=$old_convenience ;; esac if test -n "$addlibs"; then gentop=$output_objdir/${outputname}x func_append generated " $gentop" func_extract_archives $gentop $addlibs func_append oldobjs " $func_extract_archives_result" fi # Do each command in the archive commands. if test -n "$old_archive_from_new_cmds" && test yes = "$build_libtool_libs"; then cmds=$old_archive_from_new_cmds else # Add any objects from preloaded convenience libraries if test -n "$dlprefiles"; then gentop=$output_objdir/${outputname}x func_append generated " $gentop" func_extract_archives $gentop $dlprefiles func_append oldobjs " $func_extract_archives_result" fi # POSIX demands no paths to be encoded in archives. We have # to avoid creating archives with duplicate basenames if we # might have to extract them afterwards, e.g., when creating a # static archive out of a convenience library, or when linking # the entirety of a libtool archive into another (currently # not supported by libtool). if (for obj in $oldobjs do func_basename "$obj" $ECHO "$func_basename_result" done | sort | sort -uc >/dev/null 2>&1); then : else echo "copying selected object files to avoid basename conflicts..." gentop=$output_objdir/${outputname}x func_append generated " $gentop" func_mkdir_p "$gentop" save_oldobjs=$oldobjs oldobjs= counter=1 for obj in $save_oldobjs do func_basename "$obj" objbase=$func_basename_result case " $oldobjs " in " ") oldobjs=$obj ;; *[\ /]"$objbase "*) while :; do # Make sure we don't pick an alternate name that also # overlaps. newobj=lt$counter-$objbase func_arith $counter + 1 counter=$func_arith_result case " $oldobjs " in *[\ /]"$newobj "*) ;; *) if test ! -f "$gentop/$newobj"; then break; fi ;; esac done func_show_eval "ln $obj $gentop/$newobj || cp $obj $gentop/$newobj" func_append oldobjs " $gentop/$newobj" ;; *) func_append oldobjs " $obj" ;; esac done fi func_to_tool_file "$oldlib" func_convert_file_msys_to_w32 tool_oldlib=$func_to_tool_file_result eval cmds=\"$old_archive_cmds\" func_len " $cmds" len=$func_len_result if test "$len" -lt "$max_cmd_len" || test "$max_cmd_len" -le -1; then cmds=$old_archive_cmds elif test -n "$archiver_list_spec"; then func_verbose "using command file archive linking..." for obj in $oldobjs do func_to_tool_file "$obj" $ECHO "$func_to_tool_file_result" done > $output_objdir/$libname.libcmd func_to_tool_file "$output_objdir/$libname.libcmd" oldobjs=" $archiver_list_spec$func_to_tool_file_result" cmds=$old_archive_cmds else # the command line is too long to link in one step, link in parts func_verbose "using piecewise archive linking..." save_RANLIB=$RANLIB RANLIB=: objlist= concat_cmds= save_oldobjs=$oldobjs oldobjs= # Is there a better way of finding the last object in the list? for obj in $save_oldobjs do last_oldobj=$obj done eval test_cmds=\"$old_archive_cmds\" func_len " $test_cmds" len0=$func_len_result len=$len0 for obj in $save_oldobjs do func_len " $obj" func_arith $len + $func_len_result len=$func_arith_result func_append objlist " $obj" if test "$len" -lt "$max_cmd_len"; then : else # the above command should be used before it gets too long oldobjs=$objlist if test "$obj" = "$last_oldobj"; then RANLIB=$save_RANLIB fi test -z "$concat_cmds" || concat_cmds=$concat_cmds~ eval concat_cmds=\"\$concat_cmds$old_archive_cmds\" objlist= len=$len0 fi done RANLIB=$save_RANLIB oldobjs=$objlist if test -z "$oldobjs"; then eval cmds=\"\$concat_cmds\" else eval cmds=\"\$concat_cmds~\$old_archive_cmds\" fi fi fi func_execute_cmds "$cmds" 'exit $?' done test -n "$generated" && \ func_show_eval "${RM}r$generated" # Now create the libtool archive. case $output in *.la) old_library= test yes = "$build_old_libs" && old_library=$libname.$libext func_verbose "creating $output" # Preserve any variables that may affect compiler behavior for var in $variables_saved_for_relink; do if eval test -z \"\${$var+set}\"; then relink_command="{ test -z \"\${$var+set}\" || $lt_unset $var || { $var=; export $var; }; }; $relink_command" elif eval var_value=\$$var; test -z "$var_value"; then relink_command="$var=; export $var; $relink_command" else func_quote_for_eval "$var_value" relink_command="$var=$func_quote_for_eval_result; export $var; $relink_command" fi done # Quote the link command for shipping. relink_command="(cd `pwd`; $SHELL \"$progpath\" $preserve_args --mode=relink $libtool_args @inst_prefix_dir@)" relink_command=`$ECHO "$relink_command" | $SED "$sed_quote_subst"` if test yes = "$hardcode_automatic"; then relink_command= fi # Only create the output if not a dry run. $opt_dry_run || { for installed in no yes; do if test yes = "$installed"; then if test -z "$install_libdir"; then break fi output=$output_objdir/${outputname}i # Replace all uninstalled libtool libraries with the installed ones newdependency_libs= for deplib in $dependency_libs; do case $deplib in *.la) func_basename "$deplib" name=$func_basename_result func_resolve_sysroot "$deplib" eval libdir=`$SED -n -e 's/^libdir=\(.*\)$/\1/p' $func_resolve_sysroot_result` test -z "$libdir" && \ func_fatal_error "'$deplib' is not a valid libtool archive" func_append newdependency_libs " ${lt_sysroot:+=}$libdir/$name" ;; -L*) func_stripname -L '' "$deplib" func_replace_sysroot "$func_stripname_result" func_append newdependency_libs " -L$func_replace_sysroot_result" ;; -R*) func_stripname -R '' "$deplib" func_replace_sysroot "$func_stripname_result" func_append newdependency_libs " -R$func_replace_sysroot_result" ;; *) func_append newdependency_libs " $deplib" ;; esac done dependency_libs=$newdependency_libs newdlfiles= for lib in $dlfiles; do case $lib in *.la) func_basename "$lib" name=$func_basename_result eval libdir=`$SED -n -e 's/^libdir=\(.*\)$/\1/p' $lib` test -z "$libdir" && \ func_fatal_error "'$lib' is not a valid libtool archive" func_append newdlfiles " ${lt_sysroot:+=}$libdir/$name" ;; *) func_append newdlfiles " $lib" ;; esac done dlfiles=$newdlfiles newdlprefiles= for lib in $dlprefiles; do case $lib in *.la) # Only pass preopened files to the pseudo-archive (for # eventual linking with the app. that links it) if we # didn't already link the preopened objects directly into # the library: func_basename "$lib" name=$func_basename_result eval libdir=`$SED -n -e 's/^libdir=\(.*\)$/\1/p' $lib` test -z "$libdir" && \ func_fatal_error "'$lib' is not a valid libtool archive" func_append newdlprefiles " ${lt_sysroot:+=}$libdir/$name" ;; esac done dlprefiles=$newdlprefiles else newdlfiles= for lib in $dlfiles; do case $lib in [\\/]* | [A-Za-z]:[\\/]*) abs=$lib ;; *) abs=`pwd`"/$lib" ;; esac func_append newdlfiles " $abs" done dlfiles=$newdlfiles newdlprefiles= for lib in $dlprefiles; do case $lib in [\\/]* | [A-Za-z]:[\\/]*) abs=$lib ;; *) abs=`pwd`"/$lib" ;; esac func_append newdlprefiles " $abs" done dlprefiles=$newdlprefiles fi $RM $output # place dlname in correct position for cygwin # In fact, it would be nice if we could use this code for all target # systems that can't hard-code library paths into their executables # and that have no shared library path variable independent of PATH, # but it turns out we can't easily determine that from inspecting # libtool variables, so we have to hard-code the OSs to which it # applies here; at the moment, that means platforms that use the PE # object format with DLL files. See the long comment at the top of # tests/bindir.at for full details. tdlname=$dlname case $host,$output,$installed,$module,$dlname in *cygwin*,*lai,yes,no,*.dll | *mingw*,*lai,yes,no,*.dll | *cegcc*,*lai,yes,no,*.dll) # If a -bindir argument was supplied, place the dll there. if test -n "$bindir"; then func_relative_path "$install_libdir" "$bindir" tdlname=$func_relative_path_result/$dlname else # Otherwise fall back on heuristic. tdlname=../bin/$dlname fi ;; esac $ECHO > $output "\ # $outputname - a libtool library file # Generated by $PROGRAM (GNU $PACKAGE) $VERSION # # Please DO NOT delete this file! # It is necessary for linking the library. # The name that we can dlopen(3). dlname='$tdlname' # Names of this library. library_names='$library_names' # The name of the static archive. old_library='$old_library' # Linker flags that cannot go in dependency_libs. inherited_linker_flags='$new_inherited_linker_flags' # Libraries that this one depends upon. dependency_libs='$dependency_libs' # Names of additional weak libraries provided by this library weak_library_names='$weak_libs' # Version information for $libname. current=$current age=$age revision=$revision # Is this an already installed library? installed=$installed # Should we warn about portability when linking against -modules? shouldnotlink=$module # Files to dlopen/dlpreopen dlopen='$dlfiles' dlpreopen='$dlprefiles' # Directory that this library needs to be installed in: libdir='$install_libdir'" if test no,yes = "$installed,$need_relink"; then $ECHO >> $output "\ relink_command=\"$relink_command\"" fi done } # Do a symbolic link so that the libtool archive can be found in # LD_LIBRARY_PATH before the program is installed. func_show_eval '( cd "$output_objdir" && $RM "$outputname" && $LN_S "../$outputname" "$outputname" )' 'exit $?' ;; esac exit $EXIT_SUCCESS } if test link = "$opt_mode" || test relink = "$opt_mode"; then func_mode_link ${1+"$@"} fi # func_mode_uninstall arg... func_mode_uninstall () { $debug_cmd RM=$nonopt files= rmforce=false exit_status=0 # This variable tells wrapper scripts just to set variables rather # than running their programs. libtool_install_magic=$magic for arg do case $arg in -f) func_append RM " $arg"; rmforce=: ;; -*) func_append RM " $arg" ;; *) func_append files " $arg" ;; esac done test -z "$RM" && \ func_fatal_help "you must specify an RM program" rmdirs= for file in $files; do func_dirname "$file" "" "." dir=$func_dirname_result if test . = "$dir"; then odir=$objdir else odir=$dir/$objdir fi func_basename "$file" name=$func_basename_result test uninstall = "$opt_mode" && odir=$dir # Remember odir for removal later, being careful to avoid duplicates if test clean = "$opt_mode"; then case " $rmdirs " in *" $odir "*) ;; *) func_append rmdirs " $odir" ;; esac fi # Don't error if the file doesn't exist and rm -f was used. if { test -L "$file"; } >/dev/null 2>&1 || { test -h "$file"; } >/dev/null 2>&1 || test -f "$file"; then : elif test -d "$file"; then exit_status=1 continue elif $rmforce; then continue fi rmfiles=$file case $name in *.la) # Possibly a libtool archive, so verify it. if func_lalib_p "$file"; then func_source $dir/$name # Delete the libtool libraries and symlinks. for n in $library_names; do func_append rmfiles " $odir/$n" done test -n "$old_library" && func_append rmfiles " $odir/$old_library" case $opt_mode in clean) case " $library_names " in *" $dlname "*) ;; *) test -n "$dlname" && func_append rmfiles " $odir/$dlname" ;; esac test -n "$libdir" && func_append rmfiles " $odir/$name $odir/${name}i" ;; uninstall) if test -n "$library_names"; then # Do each command in the postuninstall commands. func_execute_cmds "$postuninstall_cmds" '$rmforce || exit_status=1' fi if test -n "$old_library"; then # Do each command in the old_postuninstall commands. func_execute_cmds "$old_postuninstall_cmds" '$rmforce || exit_status=1' fi # FIXME: should reinstall the best remaining shared library. ;; esac fi ;; *.lo) # Possibly a libtool object, so verify it. if func_lalib_p "$file"; then # Read the .lo file func_source $dir/$name # Add PIC object to the list of files to remove. if test -n "$pic_object" && test none != "$pic_object"; then func_append rmfiles " $dir/$pic_object" fi # Add non-PIC object to the list of files to remove. if test -n "$non_pic_object" && test none != "$non_pic_object"; then func_append rmfiles " $dir/$non_pic_object" fi fi ;; *) if test clean = "$opt_mode"; then noexename=$name case $file in *.exe) func_stripname '' '.exe' "$file" file=$func_stripname_result func_stripname '' '.exe' "$name" noexename=$func_stripname_result # $file with .exe has already been added to rmfiles, # add $file without .exe func_append rmfiles " $file" ;; esac # Do a test to see if this is a libtool program. if func_ltwrapper_p "$file"; then if func_ltwrapper_executable_p "$file"; then func_ltwrapper_scriptname "$file" relink_command= func_source $func_ltwrapper_scriptname_result func_append rmfiles " $func_ltwrapper_scriptname_result" else relink_command= func_source $dir/$noexename fi # note $name still contains .exe if it was in $file originally # as does the version of $file that was added into $rmfiles func_append rmfiles " $odir/$name $odir/${name}S.$objext" if test yes = "$fast_install" && test -n "$relink_command"; then func_append rmfiles " $odir/lt-$name" fi if test "X$noexename" != "X$name"; then func_append rmfiles " $odir/lt-$noexename.c" fi fi fi ;; esac func_show_eval "$RM $rmfiles" 'exit_status=1' done # Try to remove the $objdir's in the directories where we deleted files for dir in $rmdirs; do if test -d "$dir"; then func_show_eval "rmdir $dir >/dev/null 2>&1" fi done exit $exit_status } if test uninstall = "$opt_mode" || test clean = "$opt_mode"; then func_mode_uninstall ${1+"$@"} fi test -z "$opt_mode" && { help=$generic_help func_fatal_help "you must specify a MODE" } test -z "$exec_cmd" && \ func_fatal_help "invalid operation mode '$opt_mode'" if test -n "$exec_cmd"; then eval exec "$exec_cmd" exit $EXIT_FAILURE fi exit $exit_status # The TAGs below are defined such that we never get into a situation # where we disable both kinds of libraries. Given conflicting # choices, we go for a static library, that is the most portable, # since we can't tell whether shared libraries were disabled because # the user asked for that or because the platform doesn't support # them. This is particularly important on AIX, because we don't # support having both static and shared libraries enabled at the same # time on that platform, so we default to a shared-only configuration. # If a disable-shared tag is given, we'll fallback to a static-only # configuration. But we'll never go from static-only to shared-only. # ### BEGIN LIBTOOL TAG CONFIG: disable-shared build_libtool_libs=no build_old_libs=yes # ### END LIBTOOL TAG CONFIG: disable-shared # ### BEGIN LIBTOOL TAG CONFIG: disable-static build_old_libs=`case $build_libtool_libs in yes) echo no;; *) echo yes;; esac` # ### END LIBTOOL TAG CONFIG: disable-static # Local Variables: # mode:shell-script # sh-indentation:2 # End: xrdp-0.9.5/librfxcodec/Makefile.am000644 001751 001751 00000000202 13061652764 016746 0ustar00metameta000000 000000 ACLOCAL_AMFLAGS = -I m4 pkgconfig_DATA = rfxcodec.pc EXTRA_DIST = bootstrap readme.txt SUBDIRS = \ include \ src \ tests xrdp-0.9.5/librfxcodec/readme.txt000644 001751 001751 00000000324 12446253657 016721 0ustar00metameta000000 000000 This is a fast jpeg2000 codec compatible with MS RDP servers and xrdp. Assembly code in critial parts to maximize speed. Use this to push git remote set-url origin git@github.com:neutrinolabs/librfxcodec.git xrdp-0.9.5/librfxcodec/include/000755 001751 001751 00000000000 13220731017 016325 5ustar00metameta000000 000000 xrdp-0.9.5/librfxcodec/compile000755 001751 001751 00000016326 13220730761 016275 0ustar00metameta000000 000000 #! /bin/sh # Wrapper for compilers which do not understand '-c -o'. scriptversion=2016-01-11.22; # UTC # Copyright (C) 1999-2017 Free Software Foundation, Inc. # Written by Tom Tromey . # # 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 2, 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. # # You should have received a copy of the GNU General Public License # along with this program. If not, see . # As a special exception to the GNU General Public License, if you # distribute this file as part of a program that contains a # configuration script generated by Autoconf, you may include it under # the same distribution terms that you use for the rest of that program. # This file is maintained in Automake, please report # bugs to or send patches to # . nl=' ' # We need space, tab and new line, in precisely that order. Quoting is # there to prevent tools from complaining about whitespace usage. IFS=" "" $nl" file_conv= # func_file_conv build_file lazy # Convert a $build file to $host form and store it in $file # Currently only supports Windows hosts. If the determined conversion # type is listed in (the comma separated) LAZY, no conversion will # take place. func_file_conv () { file=$1 case $file in / | /[!/]*) # absolute file, and not a UNC file if test -z "$file_conv"; then # lazily determine how to convert abs files case `uname -s` in MINGW*) file_conv=mingw ;; CYGWIN*) file_conv=cygwin ;; *) file_conv=wine ;; esac fi case $file_conv/,$2, in *,$file_conv,*) ;; mingw/*) file=`cmd //C echo "$file " | sed -e 's/"\(.*\) " *$/\1/'` ;; cygwin/*) file=`cygpath -m "$file" || echo "$file"` ;; wine/*) file=`winepath -w "$file" || echo "$file"` ;; esac ;; esac } # func_cl_dashL linkdir # Make cl look for libraries in LINKDIR func_cl_dashL () { func_file_conv "$1" if test -z "$lib_path"; then lib_path=$file else lib_path="$lib_path;$file" fi linker_opts="$linker_opts -LIBPATH:$file" } # func_cl_dashl library # Do a library search-path lookup for cl func_cl_dashl () { lib=$1 found=no save_IFS=$IFS IFS=';' for dir in $lib_path $LIB do IFS=$save_IFS if $shared && test -f "$dir/$lib.dll.lib"; then found=yes lib=$dir/$lib.dll.lib break fi if test -f "$dir/$lib.lib"; then found=yes lib=$dir/$lib.lib break fi if test -f "$dir/lib$lib.a"; then found=yes lib=$dir/lib$lib.a break fi done IFS=$save_IFS if test "$found" != yes; then lib=$lib.lib fi } # func_cl_wrapper cl arg... # Adjust compile command to suit cl func_cl_wrapper () { # Assume a capable shell lib_path= shared=: linker_opts= for arg do if test -n "$eat"; then eat= else case $1 in -o) # configure might choose to run compile as 'compile cc -o foo foo.c'. eat=1 case $2 in *.o | *.[oO][bB][jJ]) func_file_conv "$2" set x "$@" -Fo"$file" shift ;; *) func_file_conv "$2" set x "$@" -Fe"$file" shift ;; esac ;; -I) eat=1 func_file_conv "$2" mingw set x "$@" -I"$file" shift ;; -I*) func_file_conv "${1#-I}" mingw set x "$@" -I"$file" shift ;; -l) eat=1 func_cl_dashl "$2" set x "$@" "$lib" shift ;; -l*) func_cl_dashl "${1#-l}" set x "$@" "$lib" shift ;; -L) eat=1 func_cl_dashL "$2" ;; -L*) func_cl_dashL "${1#-L}" ;; -static) shared=false ;; -Wl,*) arg=${1#-Wl,} save_ifs="$IFS"; IFS=',' for flag in $arg; do IFS="$save_ifs" linker_opts="$linker_opts $flag" done IFS="$save_ifs" ;; -Xlinker) eat=1 linker_opts="$linker_opts $2" ;; -*) set x "$@" "$1" shift ;; *.cc | *.CC | *.cxx | *.CXX | *.[cC]++) func_file_conv "$1" set x "$@" -Tp"$file" shift ;; *.c | *.cpp | *.CPP | *.lib | *.LIB | *.Lib | *.OBJ | *.obj | *.[oO]) func_file_conv "$1" mingw set x "$@" "$file" shift ;; *) set x "$@" "$1" shift ;; esac fi shift done if test -n "$linker_opts"; then linker_opts="-link$linker_opts" fi exec "$@" $linker_opts exit 1 } eat= case $1 in '') echo "$0: No command. Try '$0 --help' for more information." 1>&2 exit 1; ;; -h | --h*) cat <<\EOF Usage: compile [--help] [--version] PROGRAM [ARGS] Wrapper for compilers which do not understand '-c -o'. Remove '-o dest.o' from ARGS, run PROGRAM with the remaining arguments, and rename the output as expected. If you are trying to build a whole package this is not the right script to run: please start by reading the file 'INSTALL'. Report bugs to . EOF exit $? ;; -v | --v*) echo "compile $scriptversion" exit $? ;; cl | *[/\\]cl | cl.exe | *[/\\]cl.exe | \ icl | *[/\\]icl | icl.exe | *[/\\]icl.exe ) func_cl_wrapper "$@" # Doesn't return... ;; esac ofile= cfile= for arg do if test -n "$eat"; then eat= else case $1 in -o) # configure might choose to run compile as 'compile cc -o foo foo.c'. # So we strip '-o arg' only if arg is an object. eat=1 case $2 in *.o | *.obj) ofile=$2 ;; *) set x "$@" -o "$2" shift ;; esac ;; *.c) cfile=$1 set x "$@" "$1" shift ;; *) set x "$@" "$1" shift ;; esac fi shift done if test -z "$ofile" || test -z "$cfile"; then # If no '-o' option was seen then we might have been invoked from a # pattern rule where we don't need one. That is ok -- this is a # normal compilation that the losing compiler can handle. If no # '.c' file was seen then we are probably linking. That is also # ok. exec "$@" fi # Name of file we expect compiler to create. cofile=`echo "$cfile" | sed 's|^.*[\\/]||; s|^[a-zA-Z]:||; s/\.c$/.o/'` # Create the lock directory. # Note: use '[/\\:.-]' here to ensure that we don't use the same name # that we are using for the .o file. Also, base the name on the expected # object file name, since that is what matters with a parallel build. lockdir=`echo "$cofile" | sed -e 's|[/\\:.-]|_|g'`.d while true; do if mkdir "$lockdir" >/dev/null 2>&1; then break fi sleep 1 done # FIXME: race condition here if user kills between mkdir and trap. trap "rmdir '$lockdir'; exit 1" 1 2 15 # Run the compile. "$@" ret=$? if test -f "$cofile"; then test "$cofile" = "$ofile" || mv "$cofile" "$ofile" elif test -f "${cofile}bj"; then test "${cofile}bj" = "$ofile" || mv "${cofile}bj" "$ofile" fi rmdir "$lockdir" exit $ret # Local Variables: # mode: shell-script # sh-indentation: 2 # eval: (add-hook 'write-file-hooks 'time-stamp) # time-stamp-start: "scriptversion=" # time-stamp-format: "%:y-%02m-%02d.%02H" # time-stamp-time-zone: "UTC0" # time-stamp-end: "; # UTC" # End: xrdp-0.9.5/librfxcodec/configure.ac000644 001751 001751 00000003063 13220730305 017171 0ustar00metameta000000 000000 # Process this file with autoconf to produce a configure script AC_PREREQ(2.59) AC_INIT([rfxcodec], [0.1.4], [xrdp-devel@googlegroups.com]) AC_CONFIG_HEADERS(config_ac.h:config_ac-h.in) AM_INIT_AUTOMAKE([1.6 foreign]) AC_CONFIG_MACRO_DIR([m4]) m4_ifdef([AM_SILENT_RULES], [AM_SILENT_RULES([yes])]) AC_PROG_CC AC_C_CONST AC_PROG_LIBTOOL PKG_INSTALLDIR AX_CFLAGS_WARN_ALL AX_APPEND_COMPILE_FLAGS([-Wwrite-strings]) # SIMD is optional AC_ARG_WITH([simd], AC_HELP_STRING([--without-simd],[Omit SIMD extensions.])) if test "x${with_simd}" != "xno"; then # Check if we're on a supported CPU AC_MSG_CHECKING([if we have SIMD optimisations for cpu type]) case "$host_cpu" in x86_64 | amd64) AC_MSG_RESULT([yes (x86_64)]) AC_PROG_NASM simd_arch=x86_64 AC_DEFINE([RFX_USE_ACCEL_AMD64], [1], [Use x86_64 SIMD instructions]) ;; i*86 | x86 | ia32) AC_MSG_RESULT([yes (i386)]) AC_PROG_NASM simd_arch=i386 AC_DEFINE([RFX_USE_ACCEL_X86], [1], [Use x86 SIMD instructions]) ;; *) AC_MSG_RESULT([no ("$host_cpu")]) AC_MSG_WARN([SIMD support not available for this CPU. Performance will suffer.]) ;; esac fi AM_CONDITIONAL(WITH_SIMD_AMD64, [test x$simd_arch = xx86_64]) AM_CONDITIONAL(WITH_SIMD_X86, [test x$simd_arch = xi386]) AC_CONFIG_FILES([Makefile include/Makefile src/Makefile src/amd64/Makefile src/x86/Makefile tests/Makefile rfxcodec.pc rfxcodec-uninstalled.pc ]) AC_OUTPUT xrdp-0.9.5/librfxcodec/bootstrap000755 001751 001751 00000000630 13017154341 016647 0ustar00metameta000000 000000 #!/bin/sh which autoconf if ! test $? -eq 0 then echo "error, install autoconf" exit 1 fi which automake if ! test $? -eq 0 then echo "error, install automake" exit 1 fi which libtool || which libtoolize if ! test $? -eq 0 then echo "error, install libtool" exit 1 fi which pkg-config if ! test $? -eq 0 then echo "error, install pkg-config" exit 1 fi touch configure.ac autoreconf -fvi xrdp-0.9.5/librfxcodec/rfxcodec.pc.in000644 001751 001751 00000000374 13017154341 017437 0ustar00metameta000000 000000 prefix=@prefix@ exec_prefix=@exec_prefix@ libdir=@libdir@ includedir=@includedir@ Name: rfxcodec Description: Fast jpeg2000 codec compatible with MS RDP servers and xrdp Version: @PACKAGE_VERSION@ Cflags: -I${includedir} Libs: -L${libdir} -lrfxencode xrdp-0.9.5/librfxcodec/Makefile.in000644 001751 001751 00000067273 13220730761 016773 0ustar00metameta000000 000000 # Makefile.in generated by automake 1.15.1 from Makefile.am. # @configure_input@ # Copyright (C) 1994-2017 Free Software Foundation, Inc. # This Makefile.in is free software; the Free Software Foundation # gives unlimited permission to copy and/or distribute it, # with or without modifications, as long as this notice is preserved. # This program is distributed in the hope that it will be useful, # but WITHOUT ANY WARRANTY, to the extent permitted by law; without # even the implied warranty of MERCHANTABILITY or FITNESS FOR A # PARTICULAR PURPOSE. @SET_MAKE@ VPATH = @srcdir@ am__is_gnu_make = { \ if test -z '$(MAKELEVEL)'; then \ false; \ elif test -n '$(MAKE_HOST)'; then \ true; \ elif test -n '$(MAKE_VERSION)' && test -n '$(CURDIR)'; then \ true; \ else \ false; \ fi; \ } am__make_running_with_option = \ case $${target_option-} in \ ?) ;; \ *) echo "am__make_running_with_option: internal error: invalid" \ "target option '$${target_option-}' specified" >&2; \ exit 1;; \ esac; \ has_opt=no; \ sane_makeflags=$$MAKEFLAGS; \ if $(am__is_gnu_make); then \ sane_makeflags=$$MFLAGS; \ else \ case $$MAKEFLAGS in \ *\\[\ \ ]*) \ bs=\\; \ sane_makeflags=`printf '%s\n' "$$MAKEFLAGS" \ | sed "s/$$bs$$bs[$$bs $$bs ]*//g"`;; \ esac; \ fi; \ skip_next=no; \ strip_trailopt () \ { \ flg=`printf '%s\n' "$$flg" | sed "s/$$1.*$$//"`; \ }; \ for flg in $$sane_makeflags; do \ test $$skip_next = yes && { skip_next=no; continue; }; \ case $$flg in \ *=*|--*) continue;; \ -*I) strip_trailopt 'I'; skip_next=yes;; \ -*I?*) strip_trailopt 'I';; \ -*O) strip_trailopt 'O'; skip_next=yes;; \ -*O?*) strip_trailopt 'O';; \ -*l) strip_trailopt 'l'; skip_next=yes;; \ -*l?*) strip_trailopt 'l';; \ -[dEDm]) skip_next=yes;; \ -[JT]) skip_next=yes;; \ esac; \ case $$flg in \ *$$target_option*) has_opt=yes; break;; \ esac; \ done; \ test $$has_opt = yes am__make_dryrun = (target_option=n; $(am__make_running_with_option)) am__make_keepgoing = (target_option=k; $(am__make_running_with_option)) pkgdatadir = $(datadir)/@PACKAGE@ pkgincludedir = $(includedir)/@PACKAGE@ pkglibdir = $(libdir)/@PACKAGE@ pkglibexecdir = $(libexecdir)/@PACKAGE@ am__cd = CDPATH="$${ZSH_VERSION+.}$(PATH_SEPARATOR)" && cd install_sh_DATA = $(install_sh) -c -m 644 install_sh_PROGRAM = $(install_sh) -c install_sh_SCRIPT = $(install_sh) -c INSTALL_HEADER = $(INSTALL_DATA) transform = $(program_transform_name) NORMAL_INSTALL = : PRE_INSTALL = : POST_INSTALL = : NORMAL_UNINSTALL = : PRE_UNINSTALL = : POST_UNINSTALL = : build_triplet = @build@ host_triplet = @host@ subdir = . ACLOCAL_M4 = $(top_srcdir)/aclocal.m4 am__aclocal_m4_deps = $(top_srcdir)/m4/ax_append_compile_flags.m4 \ $(top_srcdir)/m4/ax_append_flag.m4 \ $(top_srcdir)/m4/ax_cflags_warn_all.m4 \ $(top_srcdir)/m4/ax_check_compile_flag.m4 \ $(top_srcdir)/m4/ax_require_defined.m4 \ $(top_srcdir)/m4/libtool.m4 $(top_srcdir)/m4/ltoptions.m4 \ $(top_srcdir)/m4/ltsugar.m4 $(top_srcdir)/m4/ltversion.m4 \ $(top_srcdir)/m4/lt~obsolete.m4 $(top_srcdir)/m4/nasm.m4 \ $(top_srcdir)/m4/pkg.m4 $(top_srcdir)/configure.ac am__configure_deps = $(am__aclocal_m4_deps) $(CONFIGURE_DEPENDENCIES) \ $(ACLOCAL_M4) DIST_COMMON = $(srcdir)/Makefile.am $(top_srcdir)/configure \ $(am__configure_deps) $(am__DIST_COMMON) am__CONFIG_DISTCLEAN_FILES = config.status config.cache config.log \ configure.lineno config.status.lineno mkinstalldirs = $(install_sh) -d CONFIG_HEADER = config_ac.h CONFIG_CLEAN_FILES = rfxcodec.pc rfxcodec-uninstalled.pc CONFIG_CLEAN_VPATH_FILES = AM_V_P = $(am__v_P_@AM_V@) am__v_P_ = $(am__v_P_@AM_DEFAULT_V@) am__v_P_0 = false am__v_P_1 = : AM_V_GEN = $(am__v_GEN_@AM_V@) am__v_GEN_ = $(am__v_GEN_@AM_DEFAULT_V@) am__v_GEN_0 = @echo " GEN " $@; am__v_GEN_1 = AM_V_at = $(am__v_at_@AM_V@) am__v_at_ = $(am__v_at_@AM_DEFAULT_V@) am__v_at_0 = @ am__v_at_1 = SOURCES = DIST_SOURCES = RECURSIVE_TARGETS = all-recursive check-recursive cscopelist-recursive \ ctags-recursive dvi-recursive html-recursive info-recursive \ install-data-recursive install-dvi-recursive \ install-exec-recursive install-html-recursive \ install-info-recursive install-pdf-recursive \ install-ps-recursive install-recursive installcheck-recursive \ installdirs-recursive pdf-recursive ps-recursive \ tags-recursive uninstall-recursive am__can_run_installinfo = \ case $$AM_UPDATE_INFO_DIR in \ n|no|NO) false;; \ *) (install-info --version) >/dev/null 2>&1;; \ esac am__vpath_adj_setup = srcdirstrip=`echo "$(srcdir)" | sed 's|.|.|g'`; am__vpath_adj = case $$p in \ $(srcdir)/*) f=`echo "$$p" | sed "s|^$$srcdirstrip/||"`;; \ *) f=$$p;; \ esac; am__strip_dir = f=`echo $$p | sed -e 's|^.*/||'`; am__install_max = 40 am__nobase_strip_setup = \ srcdirstrip=`echo "$(srcdir)" | sed 's/[].[^$$\\*|]/\\\\&/g'` am__nobase_strip = \ for p in $$list; do echo "$$p"; done | sed -e "s|$$srcdirstrip/||" am__nobase_list = $(am__nobase_strip_setup); \ for p in $$list; do echo "$$p $$p"; done | \ sed "s| $$srcdirstrip/| |;"' / .*\//!s/ .*/ ./; s,\( .*\)/[^/]*$$,\1,' | \ $(AWK) 'BEGIN { files["."] = "" } { files[$$2] = files[$$2] " " $$1; \ if (++n[$$2] == $(am__install_max)) \ { print $$2, files[$$2]; n[$$2] = 0; files[$$2] = "" } } \ END { for (dir in files) print dir, files[dir] }' am__base_list = \ sed '$$!N;$$!N;$$!N;$$!N;$$!N;$$!N;$$!N;s/\n/ /g' | \ sed '$$!N;$$!N;$$!N;$$!N;s/\n/ /g' am__uninstall_files_from_dir = { \ test -z "$$files" \ || { test ! -d "$$dir" && test ! -f "$$dir" && test ! -r "$$dir"; } \ || { echo " ( cd '$$dir' && rm -f" $$files ")"; \ $(am__cd) "$$dir" && rm -f $$files; }; \ } am__installdirs = "$(DESTDIR)$(pkgconfigdir)" DATA = $(pkgconfig_DATA) RECURSIVE_CLEAN_TARGETS = mostlyclean-recursive clean-recursive \ distclean-recursive maintainer-clean-recursive am__recursive_targets = \ $(RECURSIVE_TARGETS) \ $(RECURSIVE_CLEAN_TARGETS) \ $(am__extra_recursive_targets) AM_RECURSIVE_TARGETS = $(am__recursive_targets:-recursive=) TAGS CTAGS \ cscope distdir dist dist-all distcheck am__tagged_files = $(HEADERS) $(SOURCES) $(TAGS_FILES) \ $(LISP)config_ac-h.in # Read a list of newline-separated strings from the standard input, # and print each of them once, without duplicates. Input order is # *not* preserved. am__uniquify_input = $(AWK) '\ BEGIN { nonempty = 0; } \ { items[$$0] = 1; nonempty = 1; } \ END { if (nonempty) { for (i in items) print i; }; } \ ' # Make sure the list of sources is unique. This is necessary because, # e.g., the same source file might be shared among _SOURCES variables # for different programs/libraries. am__define_uniq_tagged_files = \ list='$(am__tagged_files)'; \ unique=`for i in $$list; do \ if test -f "$$i"; then echo $$i; else echo $(srcdir)/$$i; fi; \ done | $(am__uniquify_input)` ETAGS = etags CTAGS = ctags CSCOPE = cscope DIST_SUBDIRS = $(SUBDIRS) am__DIST_COMMON = $(srcdir)/Makefile.in $(srcdir)/config_ac-h.in \ $(srcdir)/rfxcodec-uninstalled.pc.in $(srcdir)/rfxcodec.pc.in \ compile config.guess config.sub install-sh ltmain.sh missing DISTFILES = $(DIST_COMMON) $(DIST_SOURCES) $(TEXINFOS) $(EXTRA_DIST) distdir = $(PACKAGE)-$(VERSION) top_distdir = $(distdir) am__remove_distdir = \ if test -d "$(distdir)"; then \ find "$(distdir)" -type d ! -perm -200 -exec chmod u+w {} ';' \ && rm -rf "$(distdir)" \ || { sleep 5 && rm -rf "$(distdir)"; }; \ else :; fi am__post_remove_distdir = $(am__remove_distdir) am__relativize = \ dir0=`pwd`; \ sed_first='s,^\([^/]*\)/.*$$,\1,'; \ sed_rest='s,^[^/]*/*,,'; \ sed_last='s,^.*/\([^/]*\)$$,\1,'; \ sed_butlast='s,/*[^/]*$$,,'; \ while test -n "$$dir1"; do \ first=`echo "$$dir1" | sed -e "$$sed_first"`; \ if test "$$first" != "."; then \ if test "$$first" = ".."; then \ dir2=`echo "$$dir0" | sed -e "$$sed_last"`/"$$dir2"; \ dir0=`echo "$$dir0" | sed -e "$$sed_butlast"`; \ else \ first2=`echo "$$dir2" | sed -e "$$sed_first"`; \ if test "$$first2" = "$$first"; then \ dir2=`echo "$$dir2" | sed -e "$$sed_rest"`; \ else \ dir2="../$$dir2"; \ fi; \ dir0="$$dir0"/"$$first"; \ fi; \ fi; \ dir1=`echo "$$dir1" | sed -e "$$sed_rest"`; \ done; \ reldir="$$dir2" DIST_ARCHIVES = $(distdir).tar.gz GZIP_ENV = --best DIST_TARGETS = dist-gzip distuninstallcheck_listfiles = find . -type f -print am__distuninstallcheck_listfiles = $(distuninstallcheck_listfiles) \ | sed 's|^\./|$(prefix)/|' | grep -v '$(infodir)/dir$$' distcleancheck_listfiles = find . -type f -print ACLOCAL = @ACLOCAL@ AMTAR = @AMTAR@ AM_DEFAULT_VERBOSITY = @AM_DEFAULT_VERBOSITY@ AR = @AR@ AUTOCONF = @AUTOCONF@ AUTOHEADER = @AUTOHEADER@ AUTOMAKE = @AUTOMAKE@ AWK = @AWK@ CC = @CC@ CCDEPMODE = @CCDEPMODE@ CFLAGS = @CFLAGS@ CPP = @CPP@ CPPFLAGS = @CPPFLAGS@ CYGPATH_W = @CYGPATH_W@ DEFS = @DEFS@ DEPDIR = @DEPDIR@ DLLTOOL = @DLLTOOL@ DSYMUTIL = @DSYMUTIL@ DUMPBIN = @DUMPBIN@ ECHO_C = @ECHO_C@ ECHO_N = @ECHO_N@ ECHO_T = @ECHO_T@ EGREP = @EGREP@ EXEEXT = @EXEEXT@ FGREP = @FGREP@ GREP = @GREP@ INSTALL = @INSTALL@ INSTALL_DATA = @INSTALL_DATA@ INSTALL_PROGRAM = @INSTALL_PROGRAM@ INSTALL_SCRIPT = @INSTALL_SCRIPT@ INSTALL_STRIP_PROGRAM = @INSTALL_STRIP_PROGRAM@ LD = @LD@ LDFLAGS = @LDFLAGS@ LIBOBJS = @LIBOBJS@ LIBS = @LIBS@ LIBTOOL = @LIBTOOL@ LIPO = @LIPO@ LN_S = @LN_S@ LTLIBOBJS = @LTLIBOBJS@ LT_SYS_LIBRARY_PATH = @LT_SYS_LIBRARY_PATH@ MAKEINFO = @MAKEINFO@ MANIFEST_TOOL = @MANIFEST_TOOL@ MKDIR_P = @MKDIR_P@ NAFLAGS = @NAFLAGS@ NASM = @NASM@ NM = @NM@ NMEDIT = @NMEDIT@ OBJDUMP = @OBJDUMP@ OBJEXT = @OBJEXT@ OTOOL = @OTOOL@ OTOOL64 = @OTOOL64@ PACKAGE = @PACKAGE@ PACKAGE_BUGREPORT = @PACKAGE_BUGREPORT@ PACKAGE_NAME = @PACKAGE_NAME@ PACKAGE_STRING = @PACKAGE_STRING@ PACKAGE_TARNAME = @PACKAGE_TARNAME@ PACKAGE_URL = @PACKAGE_URL@ PACKAGE_VERSION = @PACKAGE_VERSION@ PATH_SEPARATOR = @PATH_SEPARATOR@ RANLIB = @RANLIB@ SED = @SED@ SET_MAKE = @SET_MAKE@ SHELL = @SHELL@ STRIP = @STRIP@ VERSION = @VERSION@ abs_builddir = @abs_builddir@ abs_srcdir = @abs_srcdir@ abs_top_builddir = @abs_top_builddir@ abs_top_srcdir = @abs_top_srcdir@ ac_ct_AR = @ac_ct_AR@ ac_ct_CC = @ac_ct_CC@ ac_ct_DUMPBIN = @ac_ct_DUMPBIN@ am__include = @am__include@ am__leading_dot = @am__leading_dot@ am__quote = @am__quote@ am__tar = @am__tar@ am__untar = @am__untar@ bindir = @bindir@ build = @build@ build_alias = @build_alias@ build_cpu = @build_cpu@ build_os = @build_os@ build_vendor = @build_vendor@ builddir = @builddir@ datadir = @datadir@ datarootdir = @datarootdir@ docdir = @docdir@ dvidir = @dvidir@ exec_prefix = @exec_prefix@ host = @host@ host_alias = @host_alias@ host_cpu = @host_cpu@ host_os = @host_os@ host_vendor = @host_vendor@ htmldir = @htmldir@ includedir = @includedir@ infodir = @infodir@ install_sh = @install_sh@ libdir = @libdir@ libexecdir = @libexecdir@ localedir = @localedir@ localstatedir = @localstatedir@ mandir = @mandir@ mkdir_p = @mkdir_p@ oldincludedir = @oldincludedir@ pdfdir = @pdfdir@ pkgconfigdir = @pkgconfigdir@ prefix = @prefix@ program_transform_name = @program_transform_name@ psdir = @psdir@ sbindir = @sbindir@ sharedstatedir = @sharedstatedir@ srcdir = @srcdir@ sysconfdir = @sysconfdir@ target_alias = @target_alias@ top_build_prefix = @top_build_prefix@ top_builddir = @top_builddir@ top_srcdir = @top_srcdir@ ACLOCAL_AMFLAGS = -I m4 pkgconfig_DATA = rfxcodec.pc EXTRA_DIST = bootstrap readme.txt SUBDIRS = \ include \ src \ tests all: config_ac.h $(MAKE) $(AM_MAKEFLAGS) all-recursive .SUFFIXES: am--refresh: Makefile @: $(srcdir)/Makefile.in: $(srcdir)/Makefile.am $(am__configure_deps) @for dep in $?; do \ case '$(am__configure_deps)' in \ *$$dep*) \ echo ' cd $(srcdir) && $(AUTOMAKE) --foreign'; \ $(am__cd) $(srcdir) && $(AUTOMAKE) --foreign \ && exit 0; \ exit 1;; \ esac; \ done; \ echo ' cd $(top_srcdir) && $(AUTOMAKE) --foreign Makefile'; \ $(am__cd) $(top_srcdir) && \ $(AUTOMAKE) --foreign Makefile Makefile: $(srcdir)/Makefile.in $(top_builddir)/config.status @case '$?' in \ *config.status*) \ echo ' $(SHELL) ./config.status'; \ $(SHELL) ./config.status;; \ *) \ echo ' cd $(top_builddir) && $(SHELL) ./config.status $@ $(am__depfiles_maybe)'; \ cd $(top_builddir) && $(SHELL) ./config.status $@ $(am__depfiles_maybe);; \ esac; $(top_builddir)/config.status: $(top_srcdir)/configure $(CONFIG_STATUS_DEPENDENCIES) $(SHELL) ./config.status --recheck $(top_srcdir)/configure: $(am__configure_deps) $(am__cd) $(srcdir) && $(AUTOCONF) $(ACLOCAL_M4): $(am__aclocal_m4_deps) $(am__cd) $(srcdir) && $(ACLOCAL) $(ACLOCAL_AMFLAGS) $(am__aclocal_m4_deps): config_ac.h: stamp-h1 @test -f $@ || rm -f stamp-h1 @test -f $@ || $(MAKE) $(AM_MAKEFLAGS) stamp-h1 stamp-h1: $(srcdir)/config_ac-h.in $(top_builddir)/config.status @rm -f stamp-h1 cd $(top_builddir) && $(SHELL) ./config.status config_ac.h $(srcdir)/config_ac-h.in: $(am__configure_deps) ($(am__cd) $(top_srcdir) && $(AUTOHEADER)) rm -f stamp-h1 touch $@ distclean-hdr: -rm -f config_ac.h stamp-h1 rfxcodec.pc: $(top_builddir)/config.status $(srcdir)/rfxcodec.pc.in cd $(top_builddir) && $(SHELL) ./config.status $@ rfxcodec-uninstalled.pc: $(top_builddir)/config.status $(srcdir)/rfxcodec-uninstalled.pc.in cd $(top_builddir) && $(SHELL) ./config.status $@ mostlyclean-libtool: -rm -f *.lo clean-libtool: -rm -rf .libs _libs distclean-libtool: -rm -f libtool config.lt install-pkgconfigDATA: $(pkgconfig_DATA) @$(NORMAL_INSTALL) @list='$(pkgconfig_DATA)'; test -n "$(pkgconfigdir)" || list=; \ if test -n "$$list"; then \ echo " $(MKDIR_P) '$(DESTDIR)$(pkgconfigdir)'"; \ $(MKDIR_P) "$(DESTDIR)$(pkgconfigdir)" || exit 1; \ fi; \ for p in $$list; do \ if test -f "$$p"; then d=; else d="$(srcdir)/"; fi; \ echo "$$d$$p"; \ done | $(am__base_list) | \ while read files; do \ echo " $(INSTALL_DATA) $$files '$(DESTDIR)$(pkgconfigdir)'"; \ $(INSTALL_DATA) $$files "$(DESTDIR)$(pkgconfigdir)" || exit $$?; \ done uninstall-pkgconfigDATA: @$(NORMAL_UNINSTALL) @list='$(pkgconfig_DATA)'; test -n "$(pkgconfigdir)" || list=; \ files=`for p in $$list; do echo $$p; done | sed -e 's|^.*/||'`; \ dir='$(DESTDIR)$(pkgconfigdir)'; $(am__uninstall_files_from_dir) # This directory's subdirectories are mostly independent; you can cd # into them and run 'make' without going through this Makefile. # To change the values of 'make' variables: instead of editing Makefiles, # (1) if the variable is set in 'config.status', edit 'config.status' # (which will cause the Makefiles to be regenerated when you run 'make'); # (2) otherwise, pass the desired values on the 'make' command line. $(am__recursive_targets): @fail=; \ if $(am__make_keepgoing); then \ failcom='fail=yes'; \ else \ failcom='exit 1'; \ fi; \ dot_seen=no; \ target=`echo $@ | sed s/-recursive//`; \ case "$@" in \ distclean-* | maintainer-clean-*) list='$(DIST_SUBDIRS)' ;; \ *) list='$(SUBDIRS)' ;; \ esac; \ for subdir in $$list; do \ echo "Making $$target in $$subdir"; \ if test "$$subdir" = "."; then \ dot_seen=yes; \ local_target="$$target-am"; \ else \ local_target="$$target"; \ fi; \ ($(am__cd) $$subdir && $(MAKE) $(AM_MAKEFLAGS) $$local_target) \ || eval $$failcom; \ done; \ if test "$$dot_seen" = "no"; then \ $(MAKE) $(AM_MAKEFLAGS) "$$target-am" || exit 1; \ fi; test -z "$$fail" ID: $(am__tagged_files) $(am__define_uniq_tagged_files); mkid -fID $$unique tags: tags-recursive TAGS: tags tags-am: $(TAGS_DEPENDENCIES) $(am__tagged_files) set x; \ here=`pwd`; \ if ($(ETAGS) --etags-include --version) >/dev/null 2>&1; then \ include_option=--etags-include; \ empty_fix=.; \ else \ include_option=--include; \ empty_fix=; \ fi; \ list='$(SUBDIRS)'; for subdir in $$list; do \ if test "$$subdir" = .; then :; else \ test ! -f $$subdir/TAGS || \ set "$$@" "$$include_option=$$here/$$subdir/TAGS"; \ fi; \ done; \ $(am__define_uniq_tagged_files); \ shift; \ if test -z "$(ETAGS_ARGS)$$*$$unique"; then :; else \ test -n "$$unique" || unique=$$empty_fix; \ if test $$# -gt 0; then \ $(ETAGS) $(ETAGSFLAGS) $(AM_ETAGSFLAGS) $(ETAGS_ARGS) \ "$$@" $$unique; \ else \ $(ETAGS) $(ETAGSFLAGS) $(AM_ETAGSFLAGS) $(ETAGS_ARGS) \ $$unique; \ fi; \ fi ctags: ctags-recursive CTAGS: ctags ctags-am: $(TAGS_DEPENDENCIES) $(am__tagged_files) $(am__define_uniq_tagged_files); \ test -z "$(CTAGS_ARGS)$$unique" \ || $(CTAGS) $(CTAGSFLAGS) $(AM_CTAGSFLAGS) $(CTAGS_ARGS) \ $$unique GTAGS: here=`$(am__cd) $(top_builddir) && pwd` \ && $(am__cd) $(top_srcdir) \ && gtags -i $(GTAGS_ARGS) "$$here" cscope: cscope.files test ! -s cscope.files \ || $(CSCOPE) -b -q $(AM_CSCOPEFLAGS) $(CSCOPEFLAGS) -i cscope.files $(CSCOPE_ARGS) clean-cscope: -rm -f cscope.files cscope.files: clean-cscope cscopelist cscopelist: cscopelist-recursive cscopelist-am: $(am__tagged_files) list='$(am__tagged_files)'; \ case "$(srcdir)" in \ [\\/]* | ?:[\\/]*) sdir="$(srcdir)" ;; \ *) sdir=$(subdir)/$(srcdir) ;; \ esac; \ for i in $$list; do \ if test -f "$$i"; then \ echo "$(subdir)/$$i"; \ else \ echo "$$sdir/$$i"; \ fi; \ done >> $(top_builddir)/cscope.files distclean-tags: -rm -f TAGS ID GTAGS GRTAGS GSYMS GPATH tags -rm -f cscope.out cscope.in.out cscope.po.out cscope.files distdir: $(DISTFILES) $(am__remove_distdir) test -d "$(distdir)" || mkdir "$(distdir)" @srcdirstrip=`echo "$(srcdir)" | sed 's/[].[^$$\\*]/\\\\&/g'`; \ topsrcdirstrip=`echo "$(top_srcdir)" | sed 's/[].[^$$\\*]/\\\\&/g'`; \ list='$(DISTFILES)'; \ dist_files=`for file in $$list; do echo $$file; done | \ sed -e "s|^$$srcdirstrip/||;t" \ -e "s|^$$topsrcdirstrip/|$(top_builddir)/|;t"`; \ case $$dist_files in \ */*) $(MKDIR_P) `echo "$$dist_files" | \ sed '/\//!d;s|^|$(distdir)/|;s,/[^/]*$$,,' | \ sort -u` ;; \ esac; \ for file in $$dist_files; do \ if test -f $$file || test -d $$file; then d=.; else d=$(srcdir); fi; \ if test -d $$d/$$file; then \ dir=`echo "/$$file" | sed -e 's,/[^/]*$$,,'`; \ if test -d "$(distdir)/$$file"; then \ find "$(distdir)/$$file" -type d ! -perm -700 -exec chmod u+rwx {} \;; \ fi; \ if test -d $(srcdir)/$$file && test $$d != $(srcdir); then \ cp -fpR $(srcdir)/$$file "$(distdir)$$dir" || exit 1; \ find "$(distdir)/$$file" -type d ! -perm -700 -exec chmod u+rwx {} \;; \ fi; \ cp -fpR $$d/$$file "$(distdir)$$dir" || exit 1; \ else \ test -f "$(distdir)/$$file" \ || cp -p $$d/$$file "$(distdir)/$$file" \ || exit 1; \ fi; \ done @list='$(DIST_SUBDIRS)'; for subdir in $$list; do \ if test "$$subdir" = .; then :; else \ $(am__make_dryrun) \ || test -d "$(distdir)/$$subdir" \ || $(MKDIR_P) "$(distdir)/$$subdir" \ || exit 1; \ dir1=$$subdir; dir2="$(distdir)/$$subdir"; \ $(am__relativize); \ new_distdir=$$reldir; \ dir1=$$subdir; dir2="$(top_distdir)"; \ $(am__relativize); \ new_top_distdir=$$reldir; \ echo " (cd $$subdir && $(MAKE) $(AM_MAKEFLAGS) top_distdir="$$new_top_distdir" distdir="$$new_distdir" \\"; \ echo " am__remove_distdir=: am__skip_length_check=: am__skip_mode_fix=: distdir)"; \ ($(am__cd) $$subdir && \ $(MAKE) $(AM_MAKEFLAGS) \ top_distdir="$$new_top_distdir" \ distdir="$$new_distdir" \ am__remove_distdir=: \ am__skip_length_check=: \ am__skip_mode_fix=: \ distdir) \ || exit 1; \ fi; \ done -test -n "$(am__skip_mode_fix)" \ || find "$(distdir)" -type d ! -perm -755 \ -exec chmod u+rwx,go+rx {} \; -o \ ! -type d ! -perm -444 -links 1 -exec chmod a+r {} \; -o \ ! -type d ! -perm -400 -exec chmod a+r {} \; -o \ ! -type d ! -perm -444 -exec $(install_sh) -c -m a+r {} {} \; \ || chmod -R a+r "$(distdir)" dist-gzip: distdir tardir=$(distdir) && $(am__tar) | eval GZIP= gzip $(GZIP_ENV) -c >$(distdir).tar.gz $(am__post_remove_distdir) dist-bzip2: distdir tardir=$(distdir) && $(am__tar) | BZIP2=$${BZIP2--9} bzip2 -c >$(distdir).tar.bz2 $(am__post_remove_distdir) dist-lzip: distdir tardir=$(distdir) && $(am__tar) | lzip -c $${LZIP_OPT--9} >$(distdir).tar.lz $(am__post_remove_distdir) dist-xz: distdir tardir=$(distdir) && $(am__tar) | XZ_OPT=$${XZ_OPT--e} xz -c >$(distdir).tar.xz $(am__post_remove_distdir) dist-tarZ: distdir @echo WARNING: "Support for distribution archives compressed with" \ "legacy program 'compress' is deprecated." >&2 @echo WARNING: "It will be removed altogether in Automake 2.0" >&2 tardir=$(distdir) && $(am__tar) | compress -c >$(distdir).tar.Z $(am__post_remove_distdir) dist-shar: distdir @echo WARNING: "Support for shar distribution archives is" \ "deprecated." >&2 @echo WARNING: "It will be removed altogether in Automake 2.0" >&2 shar $(distdir) | eval GZIP= gzip $(GZIP_ENV) -c >$(distdir).shar.gz $(am__post_remove_distdir) dist-zip: distdir -rm -f $(distdir).zip zip -rq $(distdir).zip $(distdir) $(am__post_remove_distdir) dist dist-all: $(MAKE) $(AM_MAKEFLAGS) $(DIST_TARGETS) am__post_remove_distdir='@:' $(am__post_remove_distdir) # This target untars the dist file and tries a VPATH configuration. Then # it guarantees that the distribution is self-contained by making another # tarfile. distcheck: dist case '$(DIST_ARCHIVES)' in \ *.tar.gz*) \ eval GZIP= gzip $(GZIP_ENV) -dc $(distdir).tar.gz | $(am__untar) ;;\ *.tar.bz2*) \ bzip2 -dc $(distdir).tar.bz2 | $(am__untar) ;;\ *.tar.lz*) \ lzip -dc $(distdir).tar.lz | $(am__untar) ;;\ *.tar.xz*) \ xz -dc $(distdir).tar.xz | $(am__untar) ;;\ *.tar.Z*) \ uncompress -c $(distdir).tar.Z | $(am__untar) ;;\ *.shar.gz*) \ eval GZIP= gzip $(GZIP_ENV) -dc $(distdir).shar.gz | unshar ;;\ *.zip*) \ unzip $(distdir).zip ;;\ esac chmod -R a-w $(distdir) chmod u+w $(distdir) mkdir $(distdir)/_build $(distdir)/_build/sub $(distdir)/_inst chmod a-w $(distdir) test -d $(distdir)/_build || exit 0; \ dc_install_base=`$(am__cd) $(distdir)/_inst && pwd | sed -e 's,^[^:\\/]:[\\/],/,'` \ && dc_destdir="$${TMPDIR-/tmp}/am-dc-$$$$/" \ && am__cwd=`pwd` \ && $(am__cd) $(distdir)/_build/sub \ && ../../configure \ $(AM_DISTCHECK_CONFIGURE_FLAGS) \ $(DISTCHECK_CONFIGURE_FLAGS) \ --srcdir=../.. --prefix="$$dc_install_base" \ && $(MAKE) $(AM_MAKEFLAGS) \ && $(MAKE) $(AM_MAKEFLAGS) dvi \ && $(MAKE) $(AM_MAKEFLAGS) check \ && $(MAKE) $(AM_MAKEFLAGS) install \ && $(MAKE) $(AM_MAKEFLAGS) installcheck \ && $(MAKE) $(AM_MAKEFLAGS) uninstall \ && $(MAKE) $(AM_MAKEFLAGS) distuninstallcheck_dir="$$dc_install_base" \ distuninstallcheck \ && chmod -R a-w "$$dc_install_base" \ && ({ \ (cd ../.. && umask 077 && mkdir "$$dc_destdir") \ && $(MAKE) $(AM_MAKEFLAGS) DESTDIR="$$dc_destdir" install \ && $(MAKE) $(AM_MAKEFLAGS) DESTDIR="$$dc_destdir" uninstall \ && $(MAKE) $(AM_MAKEFLAGS) DESTDIR="$$dc_destdir" \ distuninstallcheck_dir="$$dc_destdir" distuninstallcheck; \ } || { rm -rf "$$dc_destdir"; exit 1; }) \ && rm -rf "$$dc_destdir" \ && $(MAKE) $(AM_MAKEFLAGS) dist \ && rm -rf $(DIST_ARCHIVES) \ && $(MAKE) $(AM_MAKEFLAGS) distcleancheck \ && cd "$$am__cwd" \ || exit 1 $(am__post_remove_distdir) @(echo "$(distdir) archives ready for distribution: "; \ list='$(DIST_ARCHIVES)'; for i in $$list; do echo $$i; done) | \ sed -e 1h -e 1s/./=/g -e 1p -e 1x -e '$$p' -e '$$x' distuninstallcheck: @test -n '$(distuninstallcheck_dir)' || { \ echo 'ERROR: trying to run $@ with an empty' \ '$$(distuninstallcheck_dir)' >&2; \ exit 1; \ }; \ $(am__cd) '$(distuninstallcheck_dir)' || { \ echo 'ERROR: cannot chdir into $(distuninstallcheck_dir)' >&2; \ exit 1; \ }; \ test `$(am__distuninstallcheck_listfiles) | wc -l` -eq 0 \ || { echo "ERROR: files left after uninstall:" ; \ if test -n "$(DESTDIR)"; then \ echo " (check DESTDIR support)"; \ fi ; \ $(distuninstallcheck_listfiles) ; \ exit 1; } >&2 distcleancheck: distclean @if test '$(srcdir)' = . ; then \ echo "ERROR: distcleancheck can only run from a VPATH build" ; \ exit 1 ; \ fi @test `$(distcleancheck_listfiles) | wc -l` -eq 0 \ || { echo "ERROR: files left in build directory after distclean:" ; \ $(distcleancheck_listfiles) ; \ exit 1; } >&2 check-am: all-am check: check-recursive all-am: Makefile $(DATA) config_ac.h installdirs: installdirs-recursive installdirs-am: for dir in "$(DESTDIR)$(pkgconfigdir)"; do \ test -z "$$dir" || $(MKDIR_P) "$$dir"; \ done install: install-recursive install-exec: install-exec-recursive install-data: install-data-recursive uninstall: uninstall-recursive install-am: all-am @$(MAKE) $(AM_MAKEFLAGS) install-exec-am install-data-am installcheck: installcheck-recursive install-strip: if test -z '$(STRIP)'; then \ $(MAKE) $(AM_MAKEFLAGS) INSTALL_PROGRAM="$(INSTALL_STRIP_PROGRAM)" \ install_sh_PROGRAM="$(INSTALL_STRIP_PROGRAM)" INSTALL_STRIP_FLAG=-s \ install; \ else \ $(MAKE) $(AM_MAKEFLAGS) INSTALL_PROGRAM="$(INSTALL_STRIP_PROGRAM)" \ install_sh_PROGRAM="$(INSTALL_STRIP_PROGRAM)" INSTALL_STRIP_FLAG=-s \ "INSTALL_PROGRAM_ENV=STRIPPROG='$(STRIP)'" install; \ fi mostlyclean-generic: clean-generic: distclean-generic: -test -z "$(CONFIG_CLEAN_FILES)" || rm -f $(CONFIG_CLEAN_FILES) -test . = "$(srcdir)" || test -z "$(CONFIG_CLEAN_VPATH_FILES)" || rm -f $(CONFIG_CLEAN_VPATH_FILES) maintainer-clean-generic: @echo "This command is intended for maintainers to use" @echo "it deletes files that may require special tools to rebuild." clean: clean-recursive clean-am: clean-generic clean-libtool mostlyclean-am distclean: distclean-recursive -rm -f $(am__CONFIG_DISTCLEAN_FILES) -rm -f Makefile distclean-am: clean-am distclean-generic distclean-hdr \ distclean-libtool distclean-tags dvi: dvi-recursive dvi-am: html: html-recursive html-am: info: info-recursive info-am: install-data-am: install-pkgconfigDATA install-dvi: install-dvi-recursive install-dvi-am: install-exec-am: install-html: install-html-recursive install-html-am: install-info: install-info-recursive install-info-am: install-man: install-pdf: install-pdf-recursive install-pdf-am: install-ps: install-ps-recursive install-ps-am: installcheck-am: maintainer-clean: maintainer-clean-recursive -rm -f $(am__CONFIG_DISTCLEAN_FILES) -rm -rf $(top_srcdir)/autom4te.cache -rm -f Makefile maintainer-clean-am: distclean-am maintainer-clean-generic mostlyclean: mostlyclean-recursive mostlyclean-am: mostlyclean-generic mostlyclean-libtool pdf: pdf-recursive pdf-am: ps: ps-recursive ps-am: uninstall-am: uninstall-pkgconfigDATA .MAKE: $(am__recursive_targets) all install-am install-strip .PHONY: $(am__recursive_targets) CTAGS GTAGS TAGS all all-am \ am--refresh check check-am clean clean-cscope clean-generic \ clean-libtool cscope cscopelist-am ctags ctags-am dist \ dist-all dist-bzip2 dist-gzip dist-lzip dist-shar dist-tarZ \ dist-xz dist-zip distcheck distclean distclean-generic \ distclean-hdr distclean-libtool distclean-tags distcleancheck \ distdir distuninstallcheck dvi dvi-am html html-am info \ info-am install install-am install-data install-data-am \ install-dvi install-dvi-am install-exec install-exec-am \ install-html install-html-am install-info install-info-am \ install-man install-pdf install-pdf-am install-pkgconfigDATA \ install-ps install-ps-am install-strip installcheck \ installcheck-am installdirs installdirs-am maintainer-clean \ maintainer-clean-generic mostlyclean mostlyclean-generic \ mostlyclean-libtool pdf pdf-am ps ps-am tags tags-am uninstall \ uninstall-am uninstall-pkgconfigDATA .PRECIOUS: Makefile # Tell versions [3.59,3.63) of GNU make to not export all variables. # Otherwise a system limit (for SysV at least) may be exceeded. .NOEXPORT: xrdp-0.9.5/librfxcodec/aclocal.m4000644 001751 001751 00000123057 13220730757 016564 0ustar00metameta000000 000000 # generated automatically by aclocal 1.15.1 -*- Autoconf -*- # Copyright (C) 1996-2017 Free Software Foundation, Inc. # This file is free software; the Free Software Foundation # gives unlimited permission to copy and/or distribute it, # with or without modifications, as long as this notice is preserved. # This program is distributed in the hope that it will be useful, # but WITHOUT ANY WARRANTY, to the extent permitted by law; without # even the implied warranty of MERCHANTABILITY or FITNESS FOR A # PARTICULAR PURPOSE. m4_ifndef([AC_CONFIG_MACRO_DIRS], [m4_defun([_AM_CONFIG_MACRO_DIRS], [])m4_defun([AC_CONFIG_MACRO_DIRS], [_AM_CONFIG_MACRO_DIRS($@)])]) m4_ifndef([AC_AUTOCONF_VERSION], [m4_copy([m4_PACKAGE_VERSION], [AC_AUTOCONF_VERSION])])dnl m4_if(m4_defn([AC_AUTOCONF_VERSION]), [2.69],, [m4_warning([this file was generated for autoconf 2.69. You have another version of autoconf. It may work, but is not guaranteed to. If you have problems, you may need to regenerate the build system entirely. To do so, use the procedure documented by the package, typically 'autoreconf'.])]) # Copyright (C) 2002-2017 Free Software Foundation, Inc. # # This file is free software; the Free Software Foundation # gives unlimited permission to copy and/or distribute it, # with or without modifications, as long as this notice is preserved. # AM_AUTOMAKE_VERSION(VERSION) # ---------------------------- # Automake X.Y traces this macro to ensure aclocal.m4 has been # generated from the m4 files accompanying Automake X.Y. # (This private macro should not be called outside this file.) AC_DEFUN([AM_AUTOMAKE_VERSION], [am__api_version='1.15' dnl Some users find AM_AUTOMAKE_VERSION and mistake it for a way to dnl require some minimum version. Point them to the right macro. m4_if([$1], [1.15.1], [], [AC_FATAL([Do not call $0, use AM_INIT_AUTOMAKE([$1]).])])dnl ]) # _AM_AUTOCONF_VERSION(VERSION) # ----------------------------- # aclocal traces this macro to find the Autoconf version. # This is a private macro too. Using m4_define simplifies # the logic in aclocal, which can simply ignore this definition. m4_define([_AM_AUTOCONF_VERSION], []) # AM_SET_CURRENT_AUTOMAKE_VERSION # ------------------------------- # Call AM_AUTOMAKE_VERSION and AM_AUTOMAKE_VERSION so they can be traced. # This function is AC_REQUIREd by AM_INIT_AUTOMAKE. AC_DEFUN([AM_SET_CURRENT_AUTOMAKE_VERSION], [AM_AUTOMAKE_VERSION([1.15.1])dnl m4_ifndef([AC_AUTOCONF_VERSION], [m4_copy([m4_PACKAGE_VERSION], [AC_AUTOCONF_VERSION])])dnl _AM_AUTOCONF_VERSION(m4_defn([AC_AUTOCONF_VERSION]))]) # AM_AUX_DIR_EXPAND -*- Autoconf -*- # Copyright (C) 2001-2017 Free Software Foundation, Inc. # # This file is free software; the Free Software Foundation # gives unlimited permission to copy and/or distribute it, # with or without modifications, as long as this notice is preserved. # For projects using AC_CONFIG_AUX_DIR([foo]), Autoconf sets # $ac_aux_dir to '$srcdir/foo'. In other projects, it is set to # '$srcdir', '$srcdir/..', or '$srcdir/../..'. # # Of course, Automake must honor this variable whenever it calls a # tool from the auxiliary directory. The problem is that $srcdir (and # therefore $ac_aux_dir as well) can be either absolute or relative, # depending on how configure is run. This is pretty annoying, since # it makes $ac_aux_dir quite unusable in subdirectories: in the top # source directory, any form will work fine, but in subdirectories a # relative path needs to be adjusted first. # # $ac_aux_dir/missing # fails when called from a subdirectory if $ac_aux_dir is relative # $top_srcdir/$ac_aux_dir/missing # fails if $ac_aux_dir is absolute, # fails when called from a subdirectory in a VPATH build with # a relative $ac_aux_dir # # The reason of the latter failure is that $top_srcdir and $ac_aux_dir # are both prefixed by $srcdir. In an in-source build this is usually # harmless because $srcdir is '.', but things will broke when you # start a VPATH build or use an absolute $srcdir. # # So we could use something similar to $top_srcdir/$ac_aux_dir/missing, # iff we strip the leading $srcdir from $ac_aux_dir. That would be: # am_aux_dir='\$(top_srcdir)/'`expr "$ac_aux_dir" : "$srcdir//*\(.*\)"` # and then we would define $MISSING as # MISSING="\${SHELL} $am_aux_dir/missing" # This will work as long as MISSING is not called from configure, because # unfortunately $(top_srcdir) has no meaning in configure. # However there are other variables, like CC, which are often used in # configure, and could therefore not use this "fixed" $ac_aux_dir. # # Another solution, used here, is to always expand $ac_aux_dir to an # absolute PATH. The drawback is that using absolute paths prevent a # configured tree to be moved without reconfiguration. AC_DEFUN([AM_AUX_DIR_EXPAND], [AC_REQUIRE([AC_CONFIG_AUX_DIR_DEFAULT])dnl # Expand $ac_aux_dir to an absolute path. am_aux_dir=`cd "$ac_aux_dir" && pwd` ]) # AM_CONDITIONAL -*- Autoconf -*- # Copyright (C) 1997-2017 Free Software Foundation, Inc. # # This file is free software; the Free Software Foundation # gives unlimited permission to copy and/or distribute it, # with or without modifications, as long as this notice is preserved. # AM_CONDITIONAL(NAME, SHELL-CONDITION) # ------------------------------------- # Define a conditional. AC_DEFUN([AM_CONDITIONAL], [AC_PREREQ([2.52])dnl m4_if([$1], [TRUE], [AC_FATAL([$0: invalid condition: $1])], [$1], [FALSE], [AC_FATAL([$0: invalid condition: $1])])dnl AC_SUBST([$1_TRUE])dnl AC_SUBST([$1_FALSE])dnl _AM_SUBST_NOTMAKE([$1_TRUE])dnl _AM_SUBST_NOTMAKE([$1_FALSE])dnl m4_define([_AM_COND_VALUE_$1], [$2])dnl if $2; then $1_TRUE= $1_FALSE='#' else $1_TRUE='#' $1_FALSE= fi AC_CONFIG_COMMANDS_PRE( [if test -z "${$1_TRUE}" && test -z "${$1_FALSE}"; then AC_MSG_ERROR([[conditional "$1" was never defined. Usually this means the macro was only invoked conditionally.]]) fi])]) # Copyright (C) 1999-2017 Free Software Foundation, Inc. # # This file is free software; the Free Software Foundation # gives unlimited permission to copy and/or distribute it, # with or without modifications, as long as this notice is preserved. # There are a few dirty hacks below to avoid letting 'AC_PROG_CC' be # written in clear, in which case automake, when reading aclocal.m4, # will think it sees a *use*, and therefore will trigger all it's # C support machinery. Also note that it means that autoscan, seeing # CC etc. in the Makefile, will ask for an AC_PROG_CC use... # _AM_DEPENDENCIES(NAME) # ---------------------- # See how the compiler implements dependency checking. # NAME is "CC", "CXX", "OBJC", "OBJCXX", "UPC", or "GJC". # We try a few techniques and use that to set a single cache variable. # # We don't AC_REQUIRE the corresponding AC_PROG_CC since the latter was # modified to invoke _AM_DEPENDENCIES(CC); we would have a circular # dependency, and given that the user is not expected to run this macro, # just rely on AC_PROG_CC. AC_DEFUN([_AM_DEPENDENCIES], [AC_REQUIRE([AM_SET_DEPDIR])dnl AC_REQUIRE([AM_OUTPUT_DEPENDENCY_COMMANDS])dnl AC_REQUIRE([AM_MAKE_INCLUDE])dnl AC_REQUIRE([AM_DEP_TRACK])dnl m4_if([$1], [CC], [depcc="$CC" am_compiler_list=], [$1], [CXX], [depcc="$CXX" am_compiler_list=], [$1], [OBJC], [depcc="$OBJC" am_compiler_list='gcc3 gcc'], [$1], [OBJCXX], [depcc="$OBJCXX" am_compiler_list='gcc3 gcc'], [$1], [UPC], [depcc="$UPC" am_compiler_list=], [$1], [GCJ], [depcc="$GCJ" am_compiler_list='gcc3 gcc'], [depcc="$$1" am_compiler_list=]) AC_CACHE_CHECK([dependency style of $depcc], [am_cv_$1_dependencies_compiler_type], [if test -z "$AMDEP_TRUE" && test -f "$am_depcomp"; then # We make a subdir and do the tests there. Otherwise we can end up # making bogus files that we don't know about and never remove. For # instance it was reported that on HP-UX the gcc test will end up # making a dummy file named 'D' -- because '-MD' means "put the output # in D". rm -rf conftest.dir mkdir conftest.dir # Copy depcomp to subdir because otherwise we won't find it if we're # using a relative directory. cp "$am_depcomp" conftest.dir cd conftest.dir # We will build objects and dependencies in a subdirectory because # it helps to detect inapplicable dependency modes. For instance # both Tru64's cc and ICC support -MD to output dependencies as a # side effect of compilation, but ICC will put the dependencies in # the current directory while Tru64 will put them in the object # directory. mkdir sub am_cv_$1_dependencies_compiler_type=none if test "$am_compiler_list" = ""; then am_compiler_list=`sed -n ['s/^#*\([a-zA-Z0-9]*\))$/\1/p'] < ./depcomp` fi am__universal=false m4_case([$1], [CC], [case " $depcc " in #( *\ -arch\ *\ -arch\ *) am__universal=true ;; esac], [CXX], [case " $depcc " in #( *\ -arch\ *\ -arch\ *) am__universal=true ;; esac]) for depmode in $am_compiler_list; do # Setup a source with many dependencies, because some compilers # like to wrap large dependency lists on column 80 (with \), and # we should not choose a depcomp mode which is confused by this. # # We need to recreate these files for each test, as the compiler may # overwrite some of them when testing with obscure command lines. # This happens at least with the AIX C compiler. : > sub/conftest.c for i in 1 2 3 4 5 6; do echo '#include "conftst'$i'.h"' >> sub/conftest.c # Using ": > sub/conftst$i.h" creates only sub/conftst1.h with # Solaris 10 /bin/sh. echo '/* dummy */' > sub/conftst$i.h done echo "${am__include} ${am__quote}sub/conftest.Po${am__quote}" > confmf # We check with '-c' and '-o' for the sake of the "dashmstdout" # mode. It turns out that the SunPro C++ compiler does not properly # handle '-M -o', and we need to detect this. Also, some Intel # versions had trouble with output in subdirs. am__obj=sub/conftest.${OBJEXT-o} am__minus_obj="-o $am__obj" case $depmode in gcc) # This depmode causes a compiler race in universal mode. test "$am__universal" = false || continue ;; nosideeffect) # After this tag, mechanisms are not by side-effect, so they'll # only be used when explicitly requested. if test "x$enable_dependency_tracking" = xyes; then continue else break fi ;; msvc7 | msvc7msys | msvisualcpp | msvcmsys) # This compiler won't grok '-c -o', but also, the minuso test has # not run yet. These depmodes are late enough in the game, and # so weak that their functioning should not be impacted. am__obj=conftest.${OBJEXT-o} am__minus_obj= ;; none) break ;; esac if depmode=$depmode \ source=sub/conftest.c object=$am__obj \ depfile=sub/conftest.Po tmpdepfile=sub/conftest.TPo \ $SHELL ./depcomp $depcc -c $am__minus_obj sub/conftest.c \ >/dev/null 2>conftest.err && grep sub/conftst1.h sub/conftest.Po > /dev/null 2>&1 && grep sub/conftst6.h sub/conftest.Po > /dev/null 2>&1 && grep $am__obj sub/conftest.Po > /dev/null 2>&1 && ${MAKE-make} -s -f confmf > /dev/null 2>&1; then # icc doesn't choke on unknown options, it will just issue warnings # or remarks (even with -Werror). So we grep stderr for any message # that says an option was ignored or not supported. # When given -MP, icc 7.0 and 7.1 complain thusly: # icc: Command line warning: ignoring option '-M'; no argument required # The diagnosis changed in icc 8.0: # icc: Command line remark: option '-MP' not supported if (grep 'ignoring option' conftest.err || grep 'not supported' conftest.err) >/dev/null 2>&1; then :; else am_cv_$1_dependencies_compiler_type=$depmode break fi fi done cd .. rm -rf conftest.dir else am_cv_$1_dependencies_compiler_type=none fi ]) AC_SUBST([$1DEPMODE], [depmode=$am_cv_$1_dependencies_compiler_type]) AM_CONDITIONAL([am__fastdep$1], [ test "x$enable_dependency_tracking" != xno \ && test "$am_cv_$1_dependencies_compiler_type" = gcc3]) ]) # AM_SET_DEPDIR # ------------- # Choose a directory name for dependency files. # This macro is AC_REQUIREd in _AM_DEPENDENCIES. AC_DEFUN([AM_SET_DEPDIR], [AC_REQUIRE([AM_SET_LEADING_DOT])dnl AC_SUBST([DEPDIR], ["${am__leading_dot}deps"])dnl ]) # AM_DEP_TRACK # ------------ AC_DEFUN([AM_DEP_TRACK], [AC_ARG_ENABLE([dependency-tracking], [dnl AS_HELP_STRING( [--enable-dependency-tracking], [do not reject slow dependency extractors]) AS_HELP_STRING( [--disable-dependency-tracking], [speeds up one-time build])]) if test "x$enable_dependency_tracking" != xno; then am_depcomp="$ac_aux_dir/depcomp" AMDEPBACKSLASH='\' am__nodep='_no' fi AM_CONDITIONAL([AMDEP], [test "x$enable_dependency_tracking" != xno]) AC_SUBST([AMDEPBACKSLASH])dnl _AM_SUBST_NOTMAKE([AMDEPBACKSLASH])dnl AC_SUBST([am__nodep])dnl _AM_SUBST_NOTMAKE([am__nodep])dnl ]) # Generate code to set up dependency tracking. -*- Autoconf -*- # Copyright (C) 1999-2017 Free Software Foundation, Inc. # # This file is free software; the Free Software Foundation # gives unlimited permission to copy and/or distribute it, # with or without modifications, as long as this notice is preserved. # _AM_OUTPUT_DEPENDENCY_COMMANDS # ------------------------------ AC_DEFUN([_AM_OUTPUT_DEPENDENCY_COMMANDS], [{ # Older Autoconf quotes --file arguments for eval, but not when files # are listed without --file. Let's play safe and only enable the eval # if we detect the quoting. case $CONFIG_FILES in *\'*) eval set x "$CONFIG_FILES" ;; *) set x $CONFIG_FILES ;; esac shift for mf do # Strip MF so we end up with the name of the file. mf=`echo "$mf" | sed -e 's/:.*$//'` # Check whether this is an Automake generated Makefile or not. # We used to match only the files named 'Makefile.in', but # some people rename them; so instead we look at the file content. # Grep'ing the first line is not enough: some people post-process # each Makefile.in and add a new line on top of each file to say so. # Grep'ing the whole file is not good either: AIX grep has a line # limit of 2048, but all sed's we know have understand at least 4000. if sed -n 's,^#.*generated by automake.*,X,p' "$mf" | grep X >/dev/null 2>&1; then dirpart=`AS_DIRNAME("$mf")` else continue fi # Extract the definition of DEPDIR, am__include, and am__quote # from the Makefile without running 'make'. DEPDIR=`sed -n 's/^DEPDIR = //p' < "$mf"` test -z "$DEPDIR" && continue am__include=`sed -n 's/^am__include = //p' < "$mf"` test -z "$am__include" && continue am__quote=`sed -n 's/^am__quote = //p' < "$mf"` # Find all dependency output files, they are included files with # $(DEPDIR) in their names. We invoke sed twice because it is the # simplest approach to changing $(DEPDIR) to its actual value in the # expansion. for file in `sed -n " s/^$am__include $am__quote\(.*(DEPDIR).*\)$am__quote"'$/\1/p' <"$mf" | \ sed -e 's/\$(DEPDIR)/'"$DEPDIR"'/g'`; do # Make sure the directory exists. test -f "$dirpart/$file" && continue fdir=`AS_DIRNAME(["$file"])` AS_MKDIR_P([$dirpart/$fdir]) # echo "creating $dirpart/$file" echo '# dummy' > "$dirpart/$file" done done } ])# _AM_OUTPUT_DEPENDENCY_COMMANDS # AM_OUTPUT_DEPENDENCY_COMMANDS # ----------------------------- # This macro should only be invoked once -- use via AC_REQUIRE. # # This code is only required when automatic dependency tracking # is enabled. FIXME. This creates each '.P' file that we will # need in order to bootstrap the dependency handling code. AC_DEFUN([AM_OUTPUT_DEPENDENCY_COMMANDS], [AC_CONFIG_COMMANDS([depfiles], [test x"$AMDEP_TRUE" != x"" || _AM_OUTPUT_DEPENDENCY_COMMANDS], [AMDEP_TRUE="$AMDEP_TRUE" ac_aux_dir="$ac_aux_dir"]) ]) # Do all the work for Automake. -*- Autoconf -*- # Copyright (C) 1996-2017 Free Software Foundation, Inc. # # This file is free software; the Free Software Foundation # gives unlimited permission to copy and/or distribute it, # with or without modifications, as long as this notice is preserved. # This macro actually does too much. Some checks are only needed if # your package does certain things. But this isn't really a big deal. dnl Redefine AC_PROG_CC to automatically invoke _AM_PROG_CC_C_O. m4_define([AC_PROG_CC], m4_defn([AC_PROG_CC]) [_AM_PROG_CC_C_O ]) # AM_INIT_AUTOMAKE(PACKAGE, VERSION, [NO-DEFINE]) # AM_INIT_AUTOMAKE([OPTIONS]) # ----------------------------------------------- # The call with PACKAGE and VERSION arguments is the old style # call (pre autoconf-2.50), which is being phased out. PACKAGE # and VERSION should now be passed to AC_INIT and removed from # the call to AM_INIT_AUTOMAKE. # We support both call styles for the transition. After # the next Automake release, Autoconf can make the AC_INIT # arguments mandatory, and then we can depend on a new Autoconf # release and drop the old call support. AC_DEFUN([AM_INIT_AUTOMAKE], [AC_PREREQ([2.65])dnl dnl Autoconf wants to disallow AM_ names. We explicitly allow dnl the ones we care about. m4_pattern_allow([^AM_[A-Z]+FLAGS$])dnl AC_REQUIRE([AM_SET_CURRENT_AUTOMAKE_VERSION])dnl AC_REQUIRE([AC_PROG_INSTALL])dnl if test "`cd $srcdir && pwd`" != "`pwd`"; then # Use -I$(srcdir) only when $(srcdir) != ., so that make's output # is not polluted with repeated "-I." AC_SUBST([am__isrc], [' -I$(srcdir)'])_AM_SUBST_NOTMAKE([am__isrc])dnl # test to see if srcdir already configured if test -f $srcdir/config.status; then AC_MSG_ERROR([source directory already configured; run "make distclean" there first]) fi fi # test whether we have cygpath if test -z "$CYGPATH_W"; then if (cygpath --version) >/dev/null 2>/dev/null; then CYGPATH_W='cygpath -w' else CYGPATH_W=echo fi fi AC_SUBST([CYGPATH_W]) # Define the identity of the package. dnl Distinguish between old-style and new-style calls. m4_ifval([$2], [AC_DIAGNOSE([obsolete], [$0: two- and three-arguments forms are deprecated.]) m4_ifval([$3], [_AM_SET_OPTION([no-define])])dnl AC_SUBST([PACKAGE], [$1])dnl AC_SUBST([VERSION], [$2])], [_AM_SET_OPTIONS([$1])dnl dnl Diagnose old-style AC_INIT with new-style AM_AUTOMAKE_INIT. m4_if( m4_ifdef([AC_PACKAGE_NAME], [ok]):m4_ifdef([AC_PACKAGE_VERSION], [ok]), [ok:ok],, [m4_fatal([AC_INIT should be called with package and version arguments])])dnl AC_SUBST([PACKAGE], ['AC_PACKAGE_TARNAME'])dnl AC_SUBST([VERSION], ['AC_PACKAGE_VERSION'])])dnl _AM_IF_OPTION([no-define],, [AC_DEFINE_UNQUOTED([PACKAGE], ["$PACKAGE"], [Name of package]) AC_DEFINE_UNQUOTED([VERSION], ["$VERSION"], [Version number of package])])dnl # Some tools Automake needs. AC_REQUIRE([AM_SANITY_CHECK])dnl AC_REQUIRE([AC_ARG_PROGRAM])dnl AM_MISSING_PROG([ACLOCAL], [aclocal-${am__api_version}]) AM_MISSING_PROG([AUTOCONF], [autoconf]) AM_MISSING_PROG([AUTOMAKE], [automake-${am__api_version}]) AM_MISSING_PROG([AUTOHEADER], [autoheader]) AM_MISSING_PROG([MAKEINFO], [makeinfo]) AC_REQUIRE([AM_PROG_INSTALL_SH])dnl AC_REQUIRE([AM_PROG_INSTALL_STRIP])dnl AC_REQUIRE([AC_PROG_MKDIR_P])dnl # For better backward compatibility. To be removed once Automake 1.9.x # dies out for good. For more background, see: # # AC_SUBST([mkdir_p], ['$(MKDIR_P)']) # We need awk for the "check" target (and possibly the TAP driver). The # system "awk" is bad on some platforms. AC_REQUIRE([AC_PROG_AWK])dnl AC_REQUIRE([AC_PROG_MAKE_SET])dnl AC_REQUIRE([AM_SET_LEADING_DOT])dnl _AM_IF_OPTION([tar-ustar], [_AM_PROG_TAR([ustar])], [_AM_IF_OPTION([tar-pax], [_AM_PROG_TAR([pax])], [_AM_PROG_TAR([v7])])]) _AM_IF_OPTION([no-dependencies],, [AC_PROVIDE_IFELSE([AC_PROG_CC], [_AM_DEPENDENCIES([CC])], [m4_define([AC_PROG_CC], m4_defn([AC_PROG_CC])[_AM_DEPENDENCIES([CC])])])dnl AC_PROVIDE_IFELSE([AC_PROG_CXX], [_AM_DEPENDENCIES([CXX])], [m4_define([AC_PROG_CXX], m4_defn([AC_PROG_CXX])[_AM_DEPENDENCIES([CXX])])])dnl AC_PROVIDE_IFELSE([AC_PROG_OBJC], [_AM_DEPENDENCIES([OBJC])], [m4_define([AC_PROG_OBJC], m4_defn([AC_PROG_OBJC])[_AM_DEPENDENCIES([OBJC])])])dnl AC_PROVIDE_IFELSE([AC_PROG_OBJCXX], [_AM_DEPENDENCIES([OBJCXX])], [m4_define([AC_PROG_OBJCXX], m4_defn([AC_PROG_OBJCXX])[_AM_DEPENDENCIES([OBJCXX])])])dnl ]) AC_REQUIRE([AM_SILENT_RULES])dnl dnl The testsuite driver may need to know about EXEEXT, so add the dnl 'am__EXEEXT' conditional if _AM_COMPILER_EXEEXT was seen. This dnl macro is hooked onto _AC_COMPILER_EXEEXT early, see below. AC_CONFIG_COMMANDS_PRE(dnl [m4_provide_if([_AM_COMPILER_EXEEXT], [AM_CONDITIONAL([am__EXEEXT], [test -n "$EXEEXT"])])])dnl # POSIX will say in a future version that running "rm -f" with no argument # is OK; and we want to be able to make that assumption in our Makefile # recipes. So use an aggressive probe to check that the usage we want is # actually supported "in the wild" to an acceptable degree. # See automake bug#10828. # To make any issue more visible, cause the running configure to be aborted # by default if the 'rm' program in use doesn't match our expectations; the # user can still override this though. if rm -f && rm -fr && rm -rf; then : OK; else cat >&2 <<'END' Oops! Your 'rm' program seems unable to run without file operands specified on the command line, even when the '-f' option is present. This is contrary to the behaviour of most rm programs out there, and not conforming with the upcoming POSIX standard: Please tell bug-automake@gnu.org about your system, including the value of your $PATH and any error possibly output before this message. This can help us improve future automake versions. END if test x"$ACCEPT_INFERIOR_RM_PROGRAM" = x"yes"; then echo 'Configuration will proceed anyway, since you have set the' >&2 echo 'ACCEPT_INFERIOR_RM_PROGRAM variable to "yes"' >&2 echo >&2 else cat >&2 <<'END' Aborting the configuration process, to ensure you take notice of the issue. You can download and install GNU coreutils to get an 'rm' implementation that behaves properly: . If you want to complete the configuration process using your problematic 'rm' anyway, export the environment variable ACCEPT_INFERIOR_RM_PROGRAM to "yes", and re-run configure. END AC_MSG_ERROR([Your 'rm' program is bad, sorry.]) fi fi dnl The trailing newline in this macro's definition is deliberate, for dnl backward compatibility and to allow trailing 'dnl'-style comments dnl after the AM_INIT_AUTOMAKE invocation. See automake bug#16841. ]) dnl Hook into '_AC_COMPILER_EXEEXT' early to learn its expansion. Do not dnl add the conditional right here, as _AC_COMPILER_EXEEXT may be further dnl mangled by Autoconf and run in a shell conditional statement. m4_define([_AC_COMPILER_EXEEXT], m4_defn([_AC_COMPILER_EXEEXT])[m4_provide([_AM_COMPILER_EXEEXT])]) # When config.status generates a header, we must update the stamp-h file. # This file resides in the same directory as the config header # that is generated. The stamp files are numbered to have different names. # Autoconf calls _AC_AM_CONFIG_HEADER_HOOK (when defined) in the # loop where config.status creates the headers, so we can generate # our stamp files there. AC_DEFUN([_AC_AM_CONFIG_HEADER_HOOK], [# Compute $1's index in $config_headers. _am_arg=$1 _am_stamp_count=1 for _am_header in $config_headers :; do case $_am_header in $_am_arg | $_am_arg:* ) break ;; * ) _am_stamp_count=`expr $_am_stamp_count + 1` ;; esac done echo "timestamp for $_am_arg" >`AS_DIRNAME(["$_am_arg"])`/stamp-h[]$_am_stamp_count]) # Copyright (C) 2001-2017 Free Software Foundation, Inc. # # This file is free software; the Free Software Foundation # gives unlimited permission to copy and/or distribute it, # with or without modifications, as long as this notice is preserved. # AM_PROG_INSTALL_SH # ------------------ # Define $install_sh. AC_DEFUN([AM_PROG_INSTALL_SH], [AC_REQUIRE([AM_AUX_DIR_EXPAND])dnl if test x"${install_sh+set}" != xset; then case $am_aux_dir in *\ * | *\ *) install_sh="\${SHELL} '$am_aux_dir/install-sh'" ;; *) install_sh="\${SHELL} $am_aux_dir/install-sh" esac fi AC_SUBST([install_sh])]) # Copyright (C) 2003-2017 Free Software Foundation, Inc. # # This file is free software; the Free Software Foundation # gives unlimited permission to copy and/or distribute it, # with or without modifications, as long as this notice is preserved. # Check whether the underlying file-system supports filenames # with a leading dot. For instance MS-DOS doesn't. AC_DEFUN([AM_SET_LEADING_DOT], [rm -rf .tst 2>/dev/null mkdir .tst 2>/dev/null if test -d .tst; then am__leading_dot=. else am__leading_dot=_ fi rmdir .tst 2>/dev/null AC_SUBST([am__leading_dot])]) # Check to see how 'make' treats includes. -*- Autoconf -*- # Copyright (C) 2001-2017 Free Software Foundation, Inc. # # This file is free software; the Free Software Foundation # gives unlimited permission to copy and/or distribute it, # with or without modifications, as long as this notice is preserved. # AM_MAKE_INCLUDE() # ----------------- # Check to see how make treats includes. AC_DEFUN([AM_MAKE_INCLUDE], [am_make=${MAKE-make} cat > confinc << 'END' am__doit: @echo this is the am__doit target .PHONY: am__doit END # If we don't find an include directive, just comment out the code. AC_MSG_CHECKING([for style of include used by $am_make]) am__include="#" am__quote= _am_result=none # First try GNU make style include. echo "include confinc" > confmf # Ignore all kinds of additional output from 'make'. case `$am_make -s -f confmf 2> /dev/null` in #( *the\ am__doit\ target*) am__include=include am__quote= _am_result=GNU ;; esac # Now try BSD make style include. if test "$am__include" = "#"; then echo '.include "confinc"' > confmf case `$am_make -s -f confmf 2> /dev/null` in #( *the\ am__doit\ target*) am__include=.include am__quote="\"" _am_result=BSD ;; esac fi AC_SUBST([am__include]) AC_SUBST([am__quote]) AC_MSG_RESULT([$_am_result]) rm -f confinc confmf ]) # Fake the existence of programs that GNU maintainers use. -*- Autoconf -*- # Copyright (C) 1997-2017 Free Software Foundation, Inc. # # This file is free software; the Free Software Foundation # gives unlimited permission to copy and/or distribute it, # with or without modifications, as long as this notice is preserved. # AM_MISSING_PROG(NAME, PROGRAM) # ------------------------------ AC_DEFUN([AM_MISSING_PROG], [AC_REQUIRE([AM_MISSING_HAS_RUN]) $1=${$1-"${am_missing_run}$2"} AC_SUBST($1)]) # AM_MISSING_HAS_RUN # ------------------ # Define MISSING if not defined so far and test if it is modern enough. # If it is, set am_missing_run to use it, otherwise, to nothing. AC_DEFUN([AM_MISSING_HAS_RUN], [AC_REQUIRE([AM_AUX_DIR_EXPAND])dnl AC_REQUIRE_AUX_FILE([missing])dnl if test x"${MISSING+set}" != xset; then case $am_aux_dir in *\ * | *\ *) MISSING="\${SHELL} \"$am_aux_dir/missing\"" ;; *) MISSING="\${SHELL} $am_aux_dir/missing" ;; esac fi # Use eval to expand $SHELL if eval "$MISSING --is-lightweight"; then am_missing_run="$MISSING " else am_missing_run= AC_MSG_WARN(['missing' script is too old or missing]) fi ]) # Helper functions for option handling. -*- Autoconf -*- # Copyright (C) 2001-2017 Free Software Foundation, Inc. # # This file is free software; the Free Software Foundation # gives unlimited permission to copy and/or distribute it, # with or without modifications, as long as this notice is preserved. # _AM_MANGLE_OPTION(NAME) # ----------------------- AC_DEFUN([_AM_MANGLE_OPTION], [[_AM_OPTION_]m4_bpatsubst($1, [[^a-zA-Z0-9_]], [_])]) # _AM_SET_OPTION(NAME) # -------------------- # Set option NAME. Presently that only means defining a flag for this option. AC_DEFUN([_AM_SET_OPTION], [m4_define(_AM_MANGLE_OPTION([$1]), [1])]) # _AM_SET_OPTIONS(OPTIONS) # ------------------------ # OPTIONS is a space-separated list of Automake options. AC_DEFUN([_AM_SET_OPTIONS], [m4_foreach_w([_AM_Option], [$1], [_AM_SET_OPTION(_AM_Option)])]) # _AM_IF_OPTION(OPTION, IF-SET, [IF-NOT-SET]) # ------------------------------------------- # Execute IF-SET if OPTION is set, IF-NOT-SET otherwise. AC_DEFUN([_AM_IF_OPTION], [m4_ifset(_AM_MANGLE_OPTION([$1]), [$2], [$3])]) # Copyright (C) 1999-2017 Free Software Foundation, Inc. # # This file is free software; the Free Software Foundation # gives unlimited permission to copy and/or distribute it, # with or without modifications, as long as this notice is preserved. # _AM_PROG_CC_C_O # --------------- # Like AC_PROG_CC_C_O, but changed for automake. We rewrite AC_PROG_CC # to automatically call this. AC_DEFUN([_AM_PROG_CC_C_O], [AC_REQUIRE([AM_AUX_DIR_EXPAND])dnl AC_REQUIRE_AUX_FILE([compile])dnl AC_LANG_PUSH([C])dnl AC_CACHE_CHECK( [whether $CC understands -c and -o together], [am_cv_prog_cc_c_o], [AC_LANG_CONFTEST([AC_LANG_PROGRAM([])]) # Make sure it works both with $CC and with simple cc. # Following AC_PROG_CC_C_O, we do the test twice because some # compilers refuse to overwrite an existing .o file with -o, # though they will create one. am_cv_prog_cc_c_o=yes for am_i in 1 2; do if AM_RUN_LOG([$CC -c conftest.$ac_ext -o conftest2.$ac_objext]) \ && test -f conftest2.$ac_objext; then : OK else am_cv_prog_cc_c_o=no break fi done rm -f core conftest* unset am_i]) if test "$am_cv_prog_cc_c_o" != yes; then # Losing compiler, so override with the script. # FIXME: It is wrong to rewrite CC. # But if we don't then we get into trouble of one sort or another. # A longer-term fix would be to have automake use am__CC in this case, # and then we could set am__CC="\$(top_srcdir)/compile \$(CC)" CC="$am_aux_dir/compile $CC" fi AC_LANG_POP([C])]) # For backward compatibility. AC_DEFUN_ONCE([AM_PROG_CC_C_O], [AC_REQUIRE([AC_PROG_CC])]) # Copyright (C) 2001-2017 Free Software Foundation, Inc. # # This file is free software; the Free Software Foundation # gives unlimited permission to copy and/or distribute it, # with or without modifications, as long as this notice is preserved. # AM_RUN_LOG(COMMAND) # ------------------- # Run COMMAND, save the exit status in ac_status, and log it. # (This has been adapted from Autoconf's _AC_RUN_LOG macro.) AC_DEFUN([AM_RUN_LOG], [{ echo "$as_me:$LINENO: $1" >&AS_MESSAGE_LOG_FD ($1) >&AS_MESSAGE_LOG_FD 2>&AS_MESSAGE_LOG_FD ac_status=$? echo "$as_me:$LINENO: \$? = $ac_status" >&AS_MESSAGE_LOG_FD (exit $ac_status); }]) # Check to make sure that the build environment is sane. -*- Autoconf -*- # Copyright (C) 1996-2017 Free Software Foundation, Inc. # # This file is free software; the Free Software Foundation # gives unlimited permission to copy and/or distribute it, # with or without modifications, as long as this notice is preserved. # AM_SANITY_CHECK # --------------- AC_DEFUN([AM_SANITY_CHECK], [AC_MSG_CHECKING([whether build environment is sane]) # Reject unsafe characters in $srcdir or the absolute working directory # name. Accept space and tab only in the latter. am_lf=' ' case `pwd` in *[[\\\"\#\$\&\'\`$am_lf]]*) AC_MSG_ERROR([unsafe absolute working directory name]);; esac case $srcdir in *[[\\\"\#\$\&\'\`$am_lf\ \ ]]*) AC_MSG_ERROR([unsafe srcdir value: '$srcdir']);; esac # Do 'set' in a subshell so we don't clobber the current shell's # arguments. Must try -L first in case configure is actually a # symlink; some systems play weird games with the mod time of symlinks # (eg FreeBSD returns the mod time of the symlink's containing # directory). if ( am_has_slept=no for am_try in 1 2; do echo "timestamp, slept: $am_has_slept" > conftest.file set X `ls -Lt "$srcdir/configure" conftest.file 2> /dev/null` if test "$[*]" = "X"; then # -L didn't work. set X `ls -t "$srcdir/configure" conftest.file` fi if test "$[*]" != "X $srcdir/configure conftest.file" \ && test "$[*]" != "X conftest.file $srcdir/configure"; then # If neither matched, then we have a broken ls. This can happen # if, for instance, CONFIG_SHELL is bash and it inherits a # broken ls alias from the environment. This has actually # happened. Such a system could not be considered "sane". AC_MSG_ERROR([ls -t appears to fail. Make sure there is not a broken alias in your environment]) fi if test "$[2]" = conftest.file || test $am_try -eq 2; then break fi # Just in case. sleep 1 am_has_slept=yes done test "$[2]" = conftest.file ) then # Ok. : else AC_MSG_ERROR([newly created file is older than distributed files! Check your system clock]) fi AC_MSG_RESULT([yes]) # If we didn't sleep, we still need to ensure time stamps of config.status and # generated files are strictly newer. am_sleep_pid= if grep 'slept: no' conftest.file >/dev/null 2>&1; then ( sleep 1 ) & am_sleep_pid=$! fi AC_CONFIG_COMMANDS_PRE( [AC_MSG_CHECKING([that generated files are newer than configure]) if test -n "$am_sleep_pid"; then # Hide warnings about reused PIDs. wait $am_sleep_pid 2>/dev/null fi AC_MSG_RESULT([done])]) rm -f conftest.file ]) # Copyright (C) 2009-2017 Free Software Foundation, Inc. # # This file is free software; the Free Software Foundation # gives unlimited permission to copy and/or distribute it, # with or without modifications, as long as this notice is preserved. # AM_SILENT_RULES([DEFAULT]) # -------------------------- # Enable less verbose build rules; with the default set to DEFAULT # ("yes" being less verbose, "no" or empty being verbose). AC_DEFUN([AM_SILENT_RULES], [AC_ARG_ENABLE([silent-rules], [dnl AS_HELP_STRING( [--enable-silent-rules], [less verbose build output (undo: "make V=1")]) AS_HELP_STRING( [--disable-silent-rules], [verbose build output (undo: "make V=0")])dnl ]) case $enable_silent_rules in @%:@ ((( yes) AM_DEFAULT_VERBOSITY=0;; no) AM_DEFAULT_VERBOSITY=1;; *) AM_DEFAULT_VERBOSITY=m4_if([$1], [yes], [0], [1]);; esac dnl dnl A few 'make' implementations (e.g., NonStop OS and NextStep) dnl do not support nested variable expansions. dnl See automake bug#9928 and bug#10237. am_make=${MAKE-make} AC_CACHE_CHECK([whether $am_make supports nested variables], [am_cv_make_support_nested_variables], [if AS_ECHO([['TRUE=$(BAR$(V)) BAR0=false BAR1=true V=1 am__doit: @$(TRUE) .PHONY: am__doit']]) | $am_make -f - >/dev/null 2>&1; then am_cv_make_support_nested_variables=yes else am_cv_make_support_nested_variables=no fi]) if test $am_cv_make_support_nested_variables = yes; then dnl Using '$V' instead of '$(V)' breaks IRIX make. AM_V='$(V)' AM_DEFAULT_V='$(AM_DEFAULT_VERBOSITY)' else AM_V=$AM_DEFAULT_VERBOSITY AM_DEFAULT_V=$AM_DEFAULT_VERBOSITY fi AC_SUBST([AM_V])dnl AM_SUBST_NOTMAKE([AM_V])dnl AC_SUBST([AM_DEFAULT_V])dnl AM_SUBST_NOTMAKE([AM_DEFAULT_V])dnl AC_SUBST([AM_DEFAULT_VERBOSITY])dnl AM_BACKSLASH='\' AC_SUBST([AM_BACKSLASH])dnl _AM_SUBST_NOTMAKE([AM_BACKSLASH])dnl ]) # Copyright (C) 2001-2017 Free Software Foundation, Inc. # # This file is free software; the Free Software Foundation # gives unlimited permission to copy and/or distribute it, # with or without modifications, as long as this notice is preserved. # AM_PROG_INSTALL_STRIP # --------------------- # One issue with vendor 'install' (even GNU) is that you can't # specify the program used to strip binaries. This is especially # annoying in cross-compiling environments, where the build's strip # is unlikely to handle the host's binaries. # Fortunately install-sh will honor a STRIPPROG variable, so we # always use install-sh in "make install-strip", and initialize # STRIPPROG with the value of the STRIP variable (set by the user). AC_DEFUN([AM_PROG_INSTALL_STRIP], [AC_REQUIRE([AM_PROG_INSTALL_SH])dnl # Installed binaries are usually stripped using 'strip' when the user # run "make install-strip". However 'strip' might not be the right # tool to use in cross-compilation environments, therefore Automake # will honor the 'STRIP' environment variable to overrule this program. dnl Don't test for $cross_compiling = yes, because it might be 'maybe'. if test "$cross_compiling" != no; then AC_CHECK_TOOL([STRIP], [strip], :) fi INSTALL_STRIP_PROGRAM="\$(install_sh) -c -s" AC_SUBST([INSTALL_STRIP_PROGRAM])]) # Copyright (C) 2006-2017 Free Software Foundation, Inc. # # This file is free software; the Free Software Foundation # gives unlimited permission to copy and/or distribute it, # with or without modifications, as long as this notice is preserved. # _AM_SUBST_NOTMAKE(VARIABLE) # --------------------------- # Prevent Automake from outputting VARIABLE = @VARIABLE@ in Makefile.in. # This macro is traced by Automake. AC_DEFUN([_AM_SUBST_NOTMAKE]) # AM_SUBST_NOTMAKE(VARIABLE) # -------------------------- # Public sister of _AM_SUBST_NOTMAKE. AC_DEFUN([AM_SUBST_NOTMAKE], [_AM_SUBST_NOTMAKE($@)]) # Check how to create a tarball. -*- Autoconf -*- # Copyright (C) 2004-2017 Free Software Foundation, Inc. # # This file is free software; the Free Software Foundation # gives unlimited permission to copy and/or distribute it, # with or without modifications, as long as this notice is preserved. # _AM_PROG_TAR(FORMAT) # -------------------- # Check how to create a tarball in format FORMAT. # FORMAT should be one of 'v7', 'ustar', or 'pax'. # # Substitute a variable $(am__tar) that is a command # writing to stdout a FORMAT-tarball containing the directory # $tardir. # tardir=directory && $(am__tar) > result.tar # # Substitute a variable $(am__untar) that extract such # a tarball read from stdin. # $(am__untar) < result.tar # AC_DEFUN([_AM_PROG_TAR], [# Always define AMTAR for backward compatibility. Yes, it's still used # in the wild :-( We should find a proper way to deprecate it ... AC_SUBST([AMTAR], ['$${TAR-tar}']) # We'll loop over all known methods to create a tar archive until one works. _am_tools='gnutar m4_if([$1], [ustar], [plaintar]) pax cpio none' m4_if([$1], [v7], [am__tar='$${TAR-tar} chof - "$$tardir"' am__untar='$${TAR-tar} xf -'], [m4_case([$1], [ustar], [# The POSIX 1988 'ustar' format is defined with fixed-size fields. # There is notably a 21 bits limit for the UID and the GID. In fact, # the 'pax' utility can hang on bigger UID/GID (see automake bug#8343 # and bug#13588). am_max_uid=2097151 # 2^21 - 1 am_max_gid=$am_max_uid # The $UID and $GID variables are not portable, so we need to resort # to the POSIX-mandated id(1) utility. Errors in the 'id' calls # below are definitely unexpected, so allow the users to see them # (that is, avoid stderr redirection). am_uid=`id -u || echo unknown` am_gid=`id -g || echo unknown` AC_MSG_CHECKING([whether UID '$am_uid' is supported by ustar format]) if test $am_uid -le $am_max_uid; then AC_MSG_RESULT([yes]) else AC_MSG_RESULT([no]) _am_tools=none fi AC_MSG_CHECKING([whether GID '$am_gid' is supported by ustar format]) if test $am_gid -le $am_max_gid; then AC_MSG_RESULT([yes]) else AC_MSG_RESULT([no]) _am_tools=none fi], [pax], [], [m4_fatal([Unknown tar format])]) AC_MSG_CHECKING([how to create a $1 tar archive]) # Go ahead even if we have the value already cached. We do so because we # need to set the values for the 'am__tar' and 'am__untar' variables. _am_tools=${am_cv_prog_tar_$1-$_am_tools} for _am_tool in $_am_tools; do case $_am_tool in gnutar) for _am_tar in tar gnutar gtar; do AM_RUN_LOG([$_am_tar --version]) && break done am__tar="$_am_tar --format=m4_if([$1], [pax], [posix], [$1]) -chf - "'"$$tardir"' am__tar_="$_am_tar --format=m4_if([$1], [pax], [posix], [$1]) -chf - "'"$tardir"' am__untar="$_am_tar -xf -" ;; plaintar) # Must skip GNU tar: if it does not support --format= it doesn't create # ustar tarball either. (tar --version) >/dev/null 2>&1 && continue am__tar='tar chf - "$$tardir"' am__tar_='tar chf - "$tardir"' am__untar='tar xf -' ;; pax) am__tar='pax -L -x $1 -w "$$tardir"' am__tar_='pax -L -x $1 -w "$tardir"' am__untar='pax -r' ;; cpio) am__tar='find "$$tardir" -print | cpio -o -H $1 -L' am__tar_='find "$tardir" -print | cpio -o -H $1 -L' am__untar='cpio -i -H $1 -d' ;; none) am__tar=false am__tar_=false am__untar=false ;; esac # If the value was cached, stop now. We just wanted to have am__tar # and am__untar set. test -n "${am_cv_prog_tar_$1}" && break # tar/untar a dummy directory, and stop if the command works. rm -rf conftest.dir mkdir conftest.dir echo GrepMe > conftest.dir/file AM_RUN_LOG([tardir=conftest.dir && eval $am__tar_ >conftest.tar]) rm -rf conftest.dir if test -s conftest.tar; then AM_RUN_LOG([$am__untar /dev/null 2>&1 && break fi done rm -rf conftest.dir AC_CACHE_VAL([am_cv_prog_tar_$1], [am_cv_prog_tar_$1=$_am_tool]) AC_MSG_RESULT([$am_cv_prog_tar_$1])]) AC_SUBST([am__tar]) AC_SUBST([am__untar]) ]) # _AM_PROG_TAR m4_include([m4/ax_append_compile_flags.m4]) m4_include([m4/ax_append_flag.m4]) m4_include([m4/ax_cflags_warn_all.m4]) m4_include([m4/ax_check_compile_flag.m4]) m4_include([m4/ax_require_defined.m4]) m4_include([m4/libtool.m4]) m4_include([m4/ltoptions.m4]) m4_include([m4/ltsugar.m4]) m4_include([m4/ltversion.m4]) m4_include([m4/lt~obsolete.m4]) m4_include([m4/nasm.m4]) m4_include([m4/pkg.m4]) xrdp-0.9.5/librfxcodec/configure000755 001751 001751 00001547121 13220730760 016630 0ustar00metameta000000 000000 #! /bin/sh # Guess values for system-dependent variables and create Makefiles. # Generated by GNU Autoconf 2.69 for rfxcodec 0.1.4. # # Report bugs to . # # # Copyright (C) 1992-1996, 1998-2012 Free Software Foundation, Inc. # # # This configure script is free software; the Free Software Foundation # gives unlimited permission to copy, distribute and modify it. ## -------------------- ## ## M4sh Initialization. ## ## -------------------- ## # Be more Bourne compatible DUALCASE=1; export DUALCASE # for MKS sh if test -n "${ZSH_VERSION+set}" && (emulate sh) >/dev/null 2>&1; then : emulate sh NULLCMD=: # Pre-4.2 versions of Zsh do word splitting on ${1+"$@"}, which # is contrary to our usage. Disable this feature. alias -g '${1+"$@"}'='"$@"' setopt NO_GLOB_SUBST else case `(set -o) 2>/dev/null` in #( *posix*) : set -o posix ;; #( *) : ;; esac fi as_nl=' ' export as_nl # Printing a long string crashes Solaris 7 /usr/bin/printf. as_echo='\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\' as_echo=$as_echo$as_echo$as_echo$as_echo$as_echo as_echo=$as_echo$as_echo$as_echo$as_echo$as_echo$as_echo # Prefer a ksh shell builtin over an external printf program on Solaris, # but without wasting forks for bash or zsh. if test -z "$BASH_VERSION$ZSH_VERSION" \ && (test "X`print -r -- $as_echo`" = "X$as_echo") 2>/dev/null; then as_echo='print -r --' as_echo_n='print -rn --' elif (test "X`printf %s $as_echo`" = "X$as_echo") 2>/dev/null; then as_echo='printf %s\n' as_echo_n='printf %s' else if test "X`(/usr/ucb/echo -n -n $as_echo) 2>/dev/null`" = "X-n $as_echo"; then as_echo_body='eval /usr/ucb/echo -n "$1$as_nl"' as_echo_n='/usr/ucb/echo -n' else as_echo_body='eval expr "X$1" : "X\\(.*\\)"' as_echo_n_body='eval arg=$1; case $arg in #( *"$as_nl"*) expr "X$arg" : "X\\(.*\\)$as_nl"; arg=`expr "X$arg" : ".*$as_nl\\(.*\\)"`;; esac; expr "X$arg" : "X\\(.*\\)" | tr -d "$as_nl" ' export as_echo_n_body as_echo_n='sh -c $as_echo_n_body as_echo' fi export as_echo_body as_echo='sh -c $as_echo_body as_echo' fi # The user is always right. if test "${PATH_SEPARATOR+set}" != set; then PATH_SEPARATOR=: (PATH='/bin;/bin'; FPATH=$PATH; sh -c :) >/dev/null 2>&1 && { (PATH='/bin:/bin'; FPATH=$PATH; sh -c :) >/dev/null 2>&1 || PATH_SEPARATOR=';' } fi # IFS # We need space, tab and new line, in precisely that order. Quoting is # there to prevent editors from complaining about space-tab. # (If _AS_PATH_WALK were called with IFS unset, it would disable word # splitting by setting IFS to empty value.) IFS=" "" $as_nl" # Find who we are. Look in the path if we contain no directory separator. as_myself= case $0 in #(( *[\\/]* ) as_myself=$0 ;; *) as_save_IFS=$IFS; IFS=$PATH_SEPARATOR for as_dir in $PATH do IFS=$as_save_IFS test -z "$as_dir" && as_dir=. test -r "$as_dir/$0" && as_myself=$as_dir/$0 && break done IFS=$as_save_IFS ;; esac # We did not find ourselves, most probably we were run as `sh COMMAND' # in which case we are not to be found in the path. if test "x$as_myself" = x; then as_myself=$0 fi if test ! -f "$as_myself"; then $as_echo "$as_myself: error: cannot find myself; rerun with an absolute file name" >&2 exit 1 fi # Unset variables that we do not need and which cause bugs (e.g. in # pre-3.0 UWIN ksh). But do not cause bugs in bash 2.01; the "|| exit 1" # suppresses any "Segmentation fault" message there. '((' could # trigger a bug in pdksh 5.2.14. for as_var in BASH_ENV ENV MAIL MAILPATH do eval test x\${$as_var+set} = xset \ && ( (unset $as_var) || exit 1) >/dev/null 2>&1 && unset $as_var || : done PS1='$ ' PS2='> ' PS4='+ ' # NLS nuisances. LC_ALL=C export LC_ALL LANGUAGE=C export LANGUAGE # CDPATH. (unset CDPATH) >/dev/null 2>&1 && unset CDPATH # Use a proper internal environment variable to ensure we don't fall # into an infinite loop, continuously re-executing ourselves. if test x"${_as_can_reexec}" != xno && test "x$CONFIG_SHELL" != x; then _as_can_reexec=no; export _as_can_reexec; # We cannot yet assume a decent shell, so we have to provide a # neutralization value for shells without unset; and this also # works around shells that cannot unset nonexistent variables. # Preserve -v and -x to the replacement shell. BASH_ENV=/dev/null ENV=/dev/null (unset BASH_ENV) >/dev/null 2>&1 && unset BASH_ENV ENV case $- in # (((( *v*x* | *x*v* ) as_opts=-vx ;; *v* ) as_opts=-v ;; *x* ) as_opts=-x ;; * ) as_opts= ;; esac exec $CONFIG_SHELL $as_opts "$as_myself" ${1+"$@"} # Admittedly, this is quite paranoid, since all the known shells bail # out after a failed `exec'. $as_echo "$0: could not re-execute with $CONFIG_SHELL" >&2 as_fn_exit 255 fi # We don't want this to propagate to other subprocesses. { _as_can_reexec=; unset _as_can_reexec;} if test "x$CONFIG_SHELL" = x; then as_bourne_compatible="if test -n \"\${ZSH_VERSION+set}\" && (emulate sh) >/dev/null 2>&1; then : emulate sh NULLCMD=: # Pre-4.2 versions of Zsh do word splitting on \${1+\"\$@\"}, which # is contrary to our usage. Disable this feature. alias -g '\${1+\"\$@\"}'='\"\$@\"' setopt NO_GLOB_SUBST else case \`(set -o) 2>/dev/null\` in #( *posix*) : set -o posix ;; #( *) : ;; esac fi " as_required="as_fn_return () { (exit \$1); } as_fn_success () { as_fn_return 0; } as_fn_failure () { as_fn_return 1; } as_fn_ret_success () { return 0; } as_fn_ret_failure () { return 1; } exitcode=0 as_fn_success || { exitcode=1; echo as_fn_success failed.; } as_fn_failure && { exitcode=1; echo as_fn_failure succeeded.; } as_fn_ret_success || { exitcode=1; echo as_fn_ret_success failed.; } as_fn_ret_failure && { exitcode=1; echo as_fn_ret_failure succeeded.; } if ( set x; as_fn_ret_success y && test x = \"\$1\" ); then : else exitcode=1; echo positional parameters were not saved. fi test x\$exitcode = x0 || exit 1 test -x / || exit 1" as_suggested=" as_lineno_1=";as_suggested=$as_suggested$LINENO;as_suggested=$as_suggested" as_lineno_1a=\$LINENO as_lineno_2=";as_suggested=$as_suggested$LINENO;as_suggested=$as_suggested" as_lineno_2a=\$LINENO eval 'test \"x\$as_lineno_1'\$as_run'\" != \"x\$as_lineno_2'\$as_run'\" && test \"x\`expr \$as_lineno_1'\$as_run' + 1\`\" = \"x\$as_lineno_2'\$as_run'\"' || exit 1 test -n \"\${ZSH_VERSION+set}\${BASH_VERSION+set}\" || ( ECHO='\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\' ECHO=\$ECHO\$ECHO\$ECHO\$ECHO\$ECHO ECHO=\$ECHO\$ECHO\$ECHO\$ECHO\$ECHO\$ECHO PATH=/empty FPATH=/empty; export PATH FPATH test \"X\`printf %s \$ECHO\`\" = \"X\$ECHO\" \\ || test \"X\`print -r -- \$ECHO\`\" = \"X\$ECHO\" ) || exit 1 test \$(( 1 + 1 )) = 2 || exit 1" if (eval "$as_required") 2>/dev/null; then : as_have_required=yes else as_have_required=no fi if test x$as_have_required = xyes && (eval "$as_suggested") 2>/dev/null; then : else as_save_IFS=$IFS; IFS=$PATH_SEPARATOR as_found=false for as_dir in /bin$PATH_SEPARATOR/usr/bin$PATH_SEPARATOR$PATH do IFS=$as_save_IFS test -z "$as_dir" && as_dir=. as_found=: case $as_dir in #( /*) for as_base in sh bash ksh sh5; do # Try only shells that exist, to save several forks. as_shell=$as_dir/$as_base if { test -f "$as_shell" || test -f "$as_shell.exe"; } && { $as_echo "$as_bourne_compatible""$as_required" | as_run=a "$as_shell"; } 2>/dev/null; then : CONFIG_SHELL=$as_shell as_have_required=yes if { $as_echo "$as_bourne_compatible""$as_suggested" | as_run=a "$as_shell"; } 2>/dev/null; then : break 2 fi fi done;; esac as_found=false done $as_found || { if { test -f "$SHELL" || test -f "$SHELL.exe"; } && { $as_echo "$as_bourne_compatible""$as_required" | as_run=a "$SHELL"; } 2>/dev/null; then : CONFIG_SHELL=$SHELL as_have_required=yes fi; } IFS=$as_save_IFS if test "x$CONFIG_SHELL" != x; then : export CONFIG_SHELL # We cannot yet assume a decent shell, so we have to provide a # neutralization value for shells without unset; and this also # works around shells that cannot unset nonexistent variables. # Preserve -v and -x to the replacement shell. BASH_ENV=/dev/null ENV=/dev/null (unset BASH_ENV) >/dev/null 2>&1 && unset BASH_ENV ENV case $- in # (((( *v*x* | *x*v* ) as_opts=-vx ;; *v* ) as_opts=-v ;; *x* ) as_opts=-x ;; * ) as_opts= ;; esac exec $CONFIG_SHELL $as_opts "$as_myself" ${1+"$@"} # Admittedly, this is quite paranoid, since all the known shells bail # out after a failed `exec'. $as_echo "$0: could not re-execute with $CONFIG_SHELL" >&2 exit 255 fi if test x$as_have_required = xno; then : $as_echo "$0: This script requires a shell more modern than all" $as_echo "$0: the shells that I found on your system." if test x${ZSH_VERSION+set} = xset ; then $as_echo "$0: In particular, zsh $ZSH_VERSION has bugs and should" $as_echo "$0: be upgraded to zsh 4.3.4 or later." else $as_echo "$0: Please tell bug-autoconf@gnu.org and $0: xrdp-devel@googlegroups.com about your system, $0: including any error possibly output before this $0: message. Then install a modern shell, or manually run $0: the script under such a shell if you do have one." fi exit 1 fi fi fi SHELL=${CONFIG_SHELL-/bin/sh} export SHELL # Unset more variables known to interfere with behavior of common tools. CLICOLOR_FORCE= GREP_OPTIONS= unset CLICOLOR_FORCE GREP_OPTIONS ## --------------------- ## ## M4sh Shell Functions. ## ## --------------------- ## # as_fn_unset VAR # --------------- # Portably unset VAR. as_fn_unset () { { eval $1=; unset $1;} } as_unset=as_fn_unset # as_fn_set_status STATUS # ----------------------- # Set $? to STATUS, without forking. as_fn_set_status () { return $1 } # as_fn_set_status # as_fn_exit STATUS # ----------------- # Exit the shell with STATUS, even in a "trap 0" or "set -e" context. as_fn_exit () { set +e as_fn_set_status $1 exit $1 } # as_fn_exit # as_fn_mkdir_p # ------------- # Create "$as_dir" as a directory, including parents if necessary. as_fn_mkdir_p () { case $as_dir in #( -*) as_dir=./$as_dir;; esac test -d "$as_dir" || eval $as_mkdir_p || { as_dirs= while :; do case $as_dir in #( *\'*) as_qdir=`$as_echo "$as_dir" | sed "s/'/'\\\\\\\\''/g"`;; #'( *) as_qdir=$as_dir;; esac as_dirs="'$as_qdir' $as_dirs" as_dir=`$as_dirname -- "$as_dir" || $as_expr X"$as_dir" : 'X\(.*[^/]\)//*[^/][^/]*/*$' \| \ X"$as_dir" : 'X\(//\)[^/]' \| \ X"$as_dir" : 'X\(//\)$' \| \ X"$as_dir" : 'X\(/\)' \| . 2>/dev/null || $as_echo X"$as_dir" | sed '/^X\(.*[^/]\)\/\/*[^/][^/]*\/*$/{ s//\1/ q } /^X\(\/\/\)[^/].*/{ s//\1/ q } /^X\(\/\/\)$/{ s//\1/ q } /^X\(\/\).*/{ s//\1/ q } s/.*/./; q'` test -d "$as_dir" && break done test -z "$as_dirs" || eval "mkdir $as_dirs" } || test -d "$as_dir" || as_fn_error $? "cannot create directory $as_dir" } # as_fn_mkdir_p # as_fn_executable_p FILE # ----------------------- # Test if FILE is an executable regular file. as_fn_executable_p () { test -f "$1" && test -x "$1" } # as_fn_executable_p # as_fn_append VAR VALUE # ---------------------- # Append the text in VALUE to the end of the definition contained in VAR. Take # advantage of any shell optimizations that allow amortized linear growth over # repeated appends, instead of the typical quadratic growth present in naive # implementations. if (eval "as_var=1; as_var+=2; test x\$as_var = x12") 2>/dev/null; then : eval 'as_fn_append () { eval $1+=\$2 }' else as_fn_append () { eval $1=\$$1\$2 } fi # as_fn_append # as_fn_arith ARG... # ------------------ # Perform arithmetic evaluation on the ARGs, and store the result in the # global $as_val. Take advantage of shells that can avoid forks. The arguments # must be portable across $(()) and expr. if (eval "test \$(( 1 + 1 )) = 2") 2>/dev/null; then : eval 'as_fn_arith () { as_val=$(( $* )) }' else as_fn_arith () { as_val=`expr "$@" || test $? -eq 1` } fi # as_fn_arith # as_fn_error STATUS ERROR [LINENO LOG_FD] # ---------------------------------------- # Output "`basename $0`: error: ERROR" to stderr. If LINENO and LOG_FD are # provided, also output the error to LOG_FD, referencing LINENO. Then exit the # script with STATUS, using 1 if that was 0. as_fn_error () { as_status=$1; test $as_status -eq 0 && as_status=1 if test "$4"; then as_lineno=${as_lineno-"$3"} as_lineno_stack=as_lineno_stack=$as_lineno_stack $as_echo "$as_me:${as_lineno-$LINENO}: error: $2" >&$4 fi $as_echo "$as_me: error: $2" >&2 as_fn_exit $as_status } # as_fn_error if expr a : '\(a\)' >/dev/null 2>&1 && test "X`expr 00001 : '.*\(...\)'`" = X001; then as_expr=expr else as_expr=false fi if (basename -- /) >/dev/null 2>&1 && test "X`basename -- / 2>&1`" = "X/"; then as_basename=basename else as_basename=false fi if (as_dir=`dirname -- /` && test "X$as_dir" = X/) >/dev/null 2>&1; then as_dirname=dirname else as_dirname=false fi as_me=`$as_basename -- "$0" || $as_expr X/"$0" : '.*/\([^/][^/]*\)/*$' \| \ X"$0" : 'X\(//\)$' \| \ X"$0" : 'X\(/\)' \| . 2>/dev/null || $as_echo X/"$0" | sed '/^.*\/\([^/][^/]*\)\/*$/{ s//\1/ q } /^X\/\(\/\/\)$/{ s//\1/ q } /^X\/\(\/\).*/{ s//\1/ q } s/.*/./; q'` # Avoid depending upon Character Ranges. as_cr_letters='abcdefghijklmnopqrstuvwxyz' as_cr_LETTERS='ABCDEFGHIJKLMNOPQRSTUVWXYZ' as_cr_Letters=$as_cr_letters$as_cr_LETTERS as_cr_digits='0123456789' as_cr_alnum=$as_cr_Letters$as_cr_digits as_lineno_1=$LINENO as_lineno_1a=$LINENO as_lineno_2=$LINENO as_lineno_2a=$LINENO eval 'test "x$as_lineno_1'$as_run'" != "x$as_lineno_2'$as_run'" && test "x`expr $as_lineno_1'$as_run' + 1`" = "x$as_lineno_2'$as_run'"' || { # Blame Lee E. McMahon (1931-1989) for sed's syntax. :-) sed -n ' p /[$]LINENO/= ' <$as_myself | sed ' s/[$]LINENO.*/&-/ t lineno b :lineno N :loop s/[$]LINENO\([^'$as_cr_alnum'_].*\n\)\(.*\)/\2\1\2/ t loop s/-\n.*// ' >$as_me.lineno && chmod +x "$as_me.lineno" || { $as_echo "$as_me: error: cannot create $as_me.lineno; rerun with a POSIX shell" >&2; as_fn_exit 1; } # If we had to re-execute with $CONFIG_SHELL, we're ensured to have # already done that, so ensure we don't try to do so again and fall # in an infinite loop. This has already happened in practice. _as_can_reexec=no; export _as_can_reexec # Don't try to exec as it changes $[0], causing all sort of problems # (the dirname of $[0] is not the place where we might find the # original and so on. Autoconf is especially sensitive to this). . "./$as_me.lineno" # Exit status is that of the last command. exit } ECHO_C= ECHO_N= ECHO_T= case `echo -n x` in #((((( -n*) case `echo 'xy\c'` in *c*) ECHO_T=' ';; # ECHO_T is single tab character. xy) ECHO_C='\c';; *) echo `echo ksh88 bug on AIX 6.1` > /dev/null ECHO_T=' ';; esac;; *) ECHO_N='-n';; esac rm -f conf$$ conf$$.exe conf$$.file if test -d conf$$.dir; then rm -f conf$$.dir/conf$$.file else rm -f conf$$.dir mkdir conf$$.dir 2>/dev/null fi if (echo >conf$$.file) 2>/dev/null; then if ln -s conf$$.file conf$$ 2>/dev/null; then as_ln_s='ln -s' # ... but there are two gotchas: # 1) On MSYS, both `ln -s file dir' and `ln file dir' fail. # 2) DJGPP < 2.04 has no symlinks; `ln -s' creates a wrapper executable. # In both cases, we have to default to `cp -pR'. ln -s conf$$.file conf$$.dir 2>/dev/null && test ! -f conf$$.exe || as_ln_s='cp -pR' elif ln conf$$.file conf$$ 2>/dev/null; then as_ln_s=ln else as_ln_s='cp -pR' fi else as_ln_s='cp -pR' fi rm -f conf$$ conf$$.exe conf$$.dir/conf$$.file conf$$.file rmdir conf$$.dir 2>/dev/null if mkdir -p . 2>/dev/null; then as_mkdir_p='mkdir -p "$as_dir"' else test -d ./-p && rmdir ./-p as_mkdir_p=false fi as_test_x='test -x' as_executable_p=as_fn_executable_p # Sed expression to map a string onto a valid CPP name. as_tr_cpp="eval sed 'y%*$as_cr_letters%P$as_cr_LETTERS%;s%[^_$as_cr_alnum]%_%g'" # Sed expression to map a string onto a valid variable name. as_tr_sh="eval sed 'y%*+%pp%;s%[^_$as_cr_alnum]%_%g'" SHELL=${CONFIG_SHELL-/bin/sh} test -n "$DJDIR" || exec 7<&0 &1 # Name of the host. # hostname on some systems (SVR3.2, old GNU/Linux) returns a bogus exit status, # so uname gets run too. ac_hostname=`(hostname || uname -n) 2>/dev/null | sed 1q` # # Initializations. # ac_default_prefix=/usr/local ac_clean_files= ac_config_libobj_dir=. LIBOBJS= cross_compiling=no subdirs= MFLAGS= MAKEFLAGS= # Identity of this package. PACKAGE_NAME='rfxcodec' PACKAGE_TARNAME='rfxcodec' PACKAGE_VERSION='0.1.4' PACKAGE_STRING='rfxcodec 0.1.4' PACKAGE_BUGREPORT='xrdp-devel@googlegroups.com' PACKAGE_URL='' # Factoring default headers for most tests. ac_includes_default="\ #include #ifdef HAVE_SYS_TYPES_H # include #endif #ifdef HAVE_SYS_STAT_H # include #endif #ifdef STDC_HEADERS # include # include #else # ifdef HAVE_STDLIB_H # include # endif #endif #ifdef HAVE_STRING_H # if !defined STDC_HEADERS && defined HAVE_MEMORY_H # include # endif # include #endif #ifdef HAVE_STRINGS_H # include #endif #ifdef HAVE_INTTYPES_H # include #endif #ifdef HAVE_STDINT_H # include #endif #ifdef HAVE_UNISTD_H # include #endif" ac_subst_vars='am__EXEEXT_FALSE am__EXEEXT_TRUE LTLIBOBJS LIBOBJS WITH_SIMD_X86_FALSE WITH_SIMD_X86_TRUE WITH_SIMD_AMD64_FALSE WITH_SIMD_AMD64_TRUE NAFLAGS NASM pkgconfigdir CPP LT_SYS_LIBRARY_PATH OTOOL64 OTOOL LIPO NMEDIT DSYMUTIL MANIFEST_TOOL RANLIB ac_ct_AR AR DLLTOOL OBJDUMP LN_S NM ac_ct_DUMPBIN DUMPBIN LD FGREP EGREP GREP SED host_os host_vendor host_cpu host build_os build_vendor build_cpu build LIBTOOL am__fastdepCC_FALSE am__fastdepCC_TRUE CCDEPMODE am__nodep AMDEPBACKSLASH AMDEP_FALSE AMDEP_TRUE am__quote am__include DEPDIR OBJEXT EXEEXT ac_ct_CC CPPFLAGS LDFLAGS CFLAGS CC AM_BACKSLASH AM_DEFAULT_VERBOSITY AM_DEFAULT_V AM_V am__untar am__tar AMTAR am__leading_dot SET_MAKE AWK mkdir_p MKDIR_P INSTALL_STRIP_PROGRAM STRIP install_sh MAKEINFO AUTOHEADER AUTOMAKE AUTOCONF ACLOCAL VERSION PACKAGE CYGPATH_W am__isrc INSTALL_DATA INSTALL_SCRIPT INSTALL_PROGRAM target_alias host_alias build_alias LIBS ECHO_T ECHO_N ECHO_C DEFS mandir localedir libdir psdir pdfdir dvidir htmldir infodir docdir oldincludedir includedir localstatedir sharedstatedir sysconfdir datadir datarootdir libexecdir sbindir bindir program_transform_name prefix exec_prefix PACKAGE_URL PACKAGE_BUGREPORT PACKAGE_STRING PACKAGE_VERSION PACKAGE_TARNAME PACKAGE_NAME PATH_SEPARATOR SHELL' ac_subst_files='' ac_user_opts=' enable_option_checking enable_silent_rules enable_dependency_tracking enable_shared enable_static with_pic enable_fast_install with_aix_soname with_gnu_ld with_sysroot enable_libtool_lock with_pkgconfigdir with_simd ' ac_precious_vars='build_alias host_alias target_alias CC CFLAGS LDFLAGS LIBS CPPFLAGS LT_SYS_LIBRARY_PATH CPP' # Initialize some variables set by options. ac_init_help= ac_init_version=false ac_unrecognized_opts= ac_unrecognized_sep= # The variables have the same names as the options, with # dashes changed to underlines. cache_file=/dev/null exec_prefix=NONE no_create= no_recursion= prefix=NONE program_prefix=NONE program_suffix=NONE program_transform_name=s,x,x, silent= site= srcdir= verbose= x_includes=NONE x_libraries=NONE # Installation directory options. # These are left unexpanded so users can "make install exec_prefix=/foo" # and all the variables that are supposed to be based on exec_prefix # by default will actually change. # Use braces instead of parens because sh, perl, etc. also accept them. # (The list follows the same order as the GNU Coding Standards.) bindir='${exec_prefix}/bin' sbindir='${exec_prefix}/sbin' libexecdir='${exec_prefix}/libexec' datarootdir='${prefix}/share' datadir='${datarootdir}' sysconfdir='${prefix}/etc' sharedstatedir='${prefix}/com' localstatedir='${prefix}/var' includedir='${prefix}/include' oldincludedir='/usr/include' docdir='${datarootdir}/doc/${PACKAGE_TARNAME}' infodir='${datarootdir}/info' htmldir='${docdir}' dvidir='${docdir}' pdfdir='${docdir}' psdir='${docdir}' libdir='${exec_prefix}/lib' localedir='${datarootdir}/locale' mandir='${datarootdir}/man' ac_prev= ac_dashdash= for ac_option do # If the previous option needs an argument, assign it. if test -n "$ac_prev"; then eval $ac_prev=\$ac_option ac_prev= continue fi case $ac_option in *=?*) ac_optarg=`expr "X$ac_option" : '[^=]*=\(.*\)'` ;; *=) ac_optarg= ;; *) ac_optarg=yes ;; esac # Accept the important Cygnus configure options, so we can diagnose typos. case $ac_dashdash$ac_option in --) ac_dashdash=yes ;; -bindir | --bindir | --bindi | --bind | --bin | --bi) ac_prev=bindir ;; -bindir=* | --bindir=* | --bindi=* | --bind=* | --bin=* | --bi=*) bindir=$ac_optarg ;; -build | --build | --buil | --bui | --bu) ac_prev=build_alias ;; -build=* | --build=* | --buil=* | --bui=* | --bu=*) build_alias=$ac_optarg ;; -cache-file | --cache-file | --cache-fil | --cache-fi \ | --cache-f | --cache- | --cache | --cach | --cac | --ca | --c) ac_prev=cache_file ;; -cache-file=* | --cache-file=* | --cache-fil=* | --cache-fi=* \ | --cache-f=* | --cache-=* | --cache=* | --cach=* | --cac=* | --ca=* | --c=*) cache_file=$ac_optarg ;; --config-cache | -C) cache_file=config.cache ;; -datadir | --datadir | --datadi | --datad) ac_prev=datadir ;; -datadir=* | --datadir=* | --datadi=* | --datad=*) datadir=$ac_optarg ;; -datarootdir | --datarootdir | --datarootdi | --datarootd | --dataroot \ | --dataroo | --dataro | --datar) ac_prev=datarootdir ;; -datarootdir=* | --datarootdir=* | --datarootdi=* | --datarootd=* \ | --dataroot=* | --dataroo=* | --dataro=* | --datar=*) datarootdir=$ac_optarg ;; -disable-* | --disable-*) ac_useropt=`expr "x$ac_option" : 'x-*disable-\(.*\)'` # Reject names that are not valid shell variable names. expr "x$ac_useropt" : ".*[^-+._$as_cr_alnum]" >/dev/null && as_fn_error $? "invalid feature name: $ac_useropt" ac_useropt_orig=$ac_useropt ac_useropt=`$as_echo "$ac_useropt" | sed 's/[-+.]/_/g'` case $ac_user_opts in *" "enable_$ac_useropt" "*) ;; *) ac_unrecognized_opts="$ac_unrecognized_opts$ac_unrecognized_sep--disable-$ac_useropt_orig" ac_unrecognized_sep=', ';; esac eval enable_$ac_useropt=no ;; -docdir | --docdir | --docdi | --doc | --do) ac_prev=docdir ;; -docdir=* | --docdir=* | --docdi=* | --doc=* | --do=*) docdir=$ac_optarg ;; -dvidir | --dvidir | --dvidi | --dvid | --dvi | --dv) ac_prev=dvidir ;; -dvidir=* | --dvidir=* | --dvidi=* | --dvid=* | --dvi=* | --dv=*) dvidir=$ac_optarg ;; -enable-* | --enable-*) ac_useropt=`expr "x$ac_option" : 'x-*enable-\([^=]*\)'` # Reject names that are not valid shell variable names. expr "x$ac_useropt" : ".*[^-+._$as_cr_alnum]" >/dev/null && as_fn_error $? "invalid feature name: $ac_useropt" ac_useropt_orig=$ac_useropt ac_useropt=`$as_echo "$ac_useropt" | sed 's/[-+.]/_/g'` case $ac_user_opts in *" "enable_$ac_useropt" "*) ;; *) ac_unrecognized_opts="$ac_unrecognized_opts$ac_unrecognized_sep--enable-$ac_useropt_orig" ac_unrecognized_sep=', ';; esac eval enable_$ac_useropt=\$ac_optarg ;; -exec-prefix | --exec_prefix | --exec-prefix | --exec-prefi \ | --exec-pref | --exec-pre | --exec-pr | --exec-p | --exec- \ | --exec | --exe | --ex) ac_prev=exec_prefix ;; -exec-prefix=* | --exec_prefix=* | --exec-prefix=* | --exec-prefi=* \ | --exec-pref=* | --exec-pre=* | --exec-pr=* | --exec-p=* | --exec-=* \ | --exec=* | --exe=* | --ex=*) exec_prefix=$ac_optarg ;; -gas | --gas | --ga | --g) # Obsolete; use --with-gas. with_gas=yes ;; -help | --help | --hel | --he | -h) ac_init_help=long ;; -help=r* | --help=r* | --hel=r* | --he=r* | -hr*) ac_init_help=recursive ;; -help=s* | --help=s* | --hel=s* | --he=s* | -hs*) ac_init_help=short ;; -host | --host | --hos | --ho) ac_prev=host_alias ;; -host=* | --host=* | --hos=* | --ho=*) host_alias=$ac_optarg ;; -htmldir | --htmldir | --htmldi | --htmld | --html | --htm | --ht) ac_prev=htmldir ;; -htmldir=* | --htmldir=* | --htmldi=* | --htmld=* | --html=* | --htm=* \ | --ht=*) htmldir=$ac_optarg ;; -includedir | --includedir | --includedi | --included | --include \ | --includ | --inclu | --incl | --inc) ac_prev=includedir ;; -includedir=* | --includedir=* | --includedi=* | --included=* | --include=* \ | --includ=* | --inclu=* | --incl=* | --inc=*) includedir=$ac_optarg ;; -infodir | --infodir | --infodi | --infod | --info | --inf) ac_prev=infodir ;; -infodir=* | --infodir=* | --infodi=* | --infod=* | --info=* | --inf=*) infodir=$ac_optarg ;; -libdir | --libdir | --libdi | --libd) ac_prev=libdir ;; -libdir=* | --libdir=* | --libdi=* | --libd=*) libdir=$ac_optarg ;; -libexecdir | --libexecdir | --libexecdi | --libexecd | --libexec \ | --libexe | --libex | --libe) ac_prev=libexecdir ;; -libexecdir=* | --libexecdir=* | --libexecdi=* | --libexecd=* | --libexec=* \ | --libexe=* | --libex=* | --libe=*) libexecdir=$ac_optarg ;; -localedir | --localedir | --localedi | --localed | --locale) ac_prev=localedir ;; -localedir=* | --localedir=* | --localedi=* | --localed=* | --locale=*) localedir=$ac_optarg ;; -localstatedir | --localstatedir | --localstatedi | --localstated \ | --localstate | --localstat | --localsta | --localst | --locals) ac_prev=localstatedir ;; -localstatedir=* | --localstatedir=* | --localstatedi=* | --localstated=* \ | --localstate=* | --localstat=* | --localsta=* | --localst=* | --locals=*) localstatedir=$ac_optarg ;; -mandir | --mandir | --mandi | --mand | --man | --ma | --m) ac_prev=mandir ;; -mandir=* | --mandir=* | --mandi=* | --mand=* | --man=* | --ma=* | --m=*) mandir=$ac_optarg ;; -nfp | --nfp | --nf) # Obsolete; use --without-fp. with_fp=no ;; -no-create | --no-create | --no-creat | --no-crea | --no-cre \ | --no-cr | --no-c | -n) no_create=yes ;; -no-recursion | --no-recursion | --no-recursio | --no-recursi \ | --no-recurs | --no-recur | --no-recu | --no-rec | --no-re | --no-r) no_recursion=yes ;; -oldincludedir | --oldincludedir | --oldincludedi | --oldincluded \ | --oldinclude | --oldinclud | --oldinclu | --oldincl | --oldinc \ | --oldin | --oldi | --old | --ol | --o) ac_prev=oldincludedir ;; -oldincludedir=* | --oldincludedir=* | --oldincludedi=* | --oldincluded=* \ | --oldinclude=* | --oldinclud=* | --oldinclu=* | --oldincl=* | --oldinc=* \ | --oldin=* | --oldi=* | --old=* | --ol=* | --o=*) oldincludedir=$ac_optarg ;; -prefix | --prefix | --prefi | --pref | --pre | --pr | --p) ac_prev=prefix ;; -prefix=* | --prefix=* | --prefi=* | --pref=* | --pre=* | --pr=* | --p=*) prefix=$ac_optarg ;; -program-prefix | --program-prefix | --program-prefi | --program-pref \ | --program-pre | --program-pr | --program-p) ac_prev=program_prefix ;; -program-prefix=* | --program-prefix=* | --program-prefi=* \ | --program-pref=* | --program-pre=* | --program-pr=* | --program-p=*) program_prefix=$ac_optarg ;; -program-suffix | --program-suffix | --program-suffi | --program-suff \ | --program-suf | --program-su | --program-s) ac_prev=program_suffix ;; -program-suffix=* | --program-suffix=* | --program-suffi=* \ | --program-suff=* | --program-suf=* | --program-su=* | --program-s=*) program_suffix=$ac_optarg ;; -program-transform-name | --program-transform-name \ | --program-transform-nam | --program-transform-na \ | --program-transform-n | --program-transform- \ | --program-transform | --program-transfor \ | --program-transfo | --program-transf \ | --program-trans | --program-tran \ | --progr-tra | --program-tr | --program-t) ac_prev=program_transform_name ;; -program-transform-name=* | --program-transform-name=* \ | --program-transform-nam=* | --program-transform-na=* \ | --program-transform-n=* | --program-transform-=* \ | --program-transform=* | --program-transfor=* \ | --program-transfo=* | --program-transf=* \ | --program-trans=* | --program-tran=* \ | --progr-tra=* | --program-tr=* | --program-t=*) program_transform_name=$ac_optarg ;; -pdfdir | --pdfdir | --pdfdi | --pdfd | --pdf | --pd) ac_prev=pdfdir ;; -pdfdir=* | --pdfdir=* | --pdfdi=* | --pdfd=* | --pdf=* | --pd=*) pdfdir=$ac_optarg ;; -psdir | --psdir | --psdi | --psd | --ps) ac_prev=psdir ;; -psdir=* | --psdir=* | --psdi=* | --psd=* | --ps=*) psdir=$ac_optarg ;; -q | -quiet | --quiet | --quie | --qui | --qu | --q \ | -silent | --silent | --silen | --sile | --sil) silent=yes ;; -sbindir | --sbindir | --sbindi | --sbind | --sbin | --sbi | --sb) ac_prev=sbindir ;; -sbindir=* | --sbindir=* | --sbindi=* | --sbind=* | --sbin=* \ | --sbi=* | --sb=*) sbindir=$ac_optarg ;; -sharedstatedir | --sharedstatedir | --sharedstatedi \ | --sharedstated | --sharedstate | --sharedstat | --sharedsta \ | --sharedst | --shareds | --shared | --share | --shar \ | --sha | --sh) ac_prev=sharedstatedir ;; -sharedstatedir=* | --sharedstatedir=* | --sharedstatedi=* \ | --sharedstated=* | --sharedstate=* | --sharedstat=* | --sharedsta=* \ | --sharedst=* | --shareds=* | --shared=* | --share=* | --shar=* \ | --sha=* | --sh=*) sharedstatedir=$ac_optarg ;; -site | --site | --sit) ac_prev=site ;; -site=* | --site=* | --sit=*) site=$ac_optarg ;; -srcdir | --srcdir | --srcdi | --srcd | --src | --sr) ac_prev=srcdir ;; -srcdir=* | --srcdir=* | --srcdi=* | --srcd=* | --src=* | --sr=*) srcdir=$ac_optarg ;; -sysconfdir | --sysconfdir | --sysconfdi | --sysconfd | --sysconf \ | --syscon | --sysco | --sysc | --sys | --sy) ac_prev=sysconfdir ;; -sysconfdir=* | --sysconfdir=* | --sysconfdi=* | --sysconfd=* | --sysconf=* \ | --syscon=* | --sysco=* | --sysc=* | --sys=* | --sy=*) sysconfdir=$ac_optarg ;; -target | --target | --targe | --targ | --tar | --ta | --t) ac_prev=target_alias ;; -target=* | --target=* | --targe=* | --targ=* | --tar=* | --ta=* | --t=*) target_alias=$ac_optarg ;; -v | -verbose | --verbose | --verbos | --verbo | --verb) verbose=yes ;; -version | --version | --versio | --versi | --vers | -V) ac_init_version=: ;; -with-* | --with-*) ac_useropt=`expr "x$ac_option" : 'x-*with-\([^=]*\)'` # Reject names that are not valid shell variable names. expr "x$ac_useropt" : ".*[^-+._$as_cr_alnum]" >/dev/null && as_fn_error $? "invalid package name: $ac_useropt" ac_useropt_orig=$ac_useropt ac_useropt=`$as_echo "$ac_useropt" | sed 's/[-+.]/_/g'` case $ac_user_opts in *" "with_$ac_useropt" "*) ;; *) ac_unrecognized_opts="$ac_unrecognized_opts$ac_unrecognized_sep--with-$ac_useropt_orig" ac_unrecognized_sep=', ';; esac eval with_$ac_useropt=\$ac_optarg ;; -without-* | --without-*) ac_useropt=`expr "x$ac_option" : 'x-*without-\(.*\)'` # Reject names that are not valid shell variable names. expr "x$ac_useropt" : ".*[^-+._$as_cr_alnum]" >/dev/null && as_fn_error $? "invalid package name: $ac_useropt" ac_useropt_orig=$ac_useropt ac_useropt=`$as_echo "$ac_useropt" | sed 's/[-+.]/_/g'` case $ac_user_opts in *" "with_$ac_useropt" "*) ;; *) ac_unrecognized_opts="$ac_unrecognized_opts$ac_unrecognized_sep--without-$ac_useropt_orig" ac_unrecognized_sep=', ';; esac eval with_$ac_useropt=no ;; --x) # Obsolete; use --with-x. with_x=yes ;; -x-includes | --x-includes | --x-include | --x-includ | --x-inclu \ | --x-incl | --x-inc | --x-in | --x-i) ac_prev=x_includes ;; -x-includes=* | --x-includes=* | --x-include=* | --x-includ=* | --x-inclu=* \ | --x-incl=* | --x-inc=* | --x-in=* | --x-i=*) x_includes=$ac_optarg ;; -x-libraries | --x-libraries | --x-librarie | --x-librari \ | --x-librar | --x-libra | --x-libr | --x-lib | --x-li | --x-l) ac_prev=x_libraries ;; -x-libraries=* | --x-libraries=* | --x-librarie=* | --x-librari=* \ | --x-librar=* | --x-libra=* | --x-libr=* | --x-lib=* | --x-li=* | --x-l=*) x_libraries=$ac_optarg ;; -*) as_fn_error $? "unrecognized option: \`$ac_option' Try \`$0 --help' for more information" ;; *=*) ac_envvar=`expr "x$ac_option" : 'x\([^=]*\)='` # Reject names that are not valid shell variable names. case $ac_envvar in #( '' | [0-9]* | *[!_$as_cr_alnum]* ) as_fn_error $? "invalid variable name: \`$ac_envvar'" ;; esac eval $ac_envvar=\$ac_optarg export $ac_envvar ;; *) # FIXME: should be removed in autoconf 3.0. $as_echo "$as_me: WARNING: you should use --build, --host, --target" >&2 expr "x$ac_option" : ".*[^-._$as_cr_alnum]" >/dev/null && $as_echo "$as_me: WARNING: invalid host type: $ac_option" >&2 : "${build_alias=$ac_option} ${host_alias=$ac_option} ${target_alias=$ac_option}" ;; esac done if test -n "$ac_prev"; then ac_option=--`echo $ac_prev | sed 's/_/-/g'` as_fn_error $? "missing argument to $ac_option" fi if test -n "$ac_unrecognized_opts"; then case $enable_option_checking in no) ;; fatal) as_fn_error $? "unrecognized options: $ac_unrecognized_opts" ;; *) $as_echo "$as_me: WARNING: unrecognized options: $ac_unrecognized_opts" >&2 ;; esac fi # Check all directory arguments for consistency. for ac_var in exec_prefix prefix bindir sbindir libexecdir datarootdir \ datadir sysconfdir sharedstatedir localstatedir includedir \ oldincludedir docdir infodir htmldir dvidir pdfdir psdir \ libdir localedir mandir do eval ac_val=\$$ac_var # Remove trailing slashes. case $ac_val in */ ) ac_val=`expr "X$ac_val" : 'X\(.*[^/]\)' \| "X$ac_val" : 'X\(.*\)'` eval $ac_var=\$ac_val;; esac # Be sure to have absolute directory names. case $ac_val in [\\/$]* | ?:[\\/]* ) continue;; NONE | '' ) case $ac_var in *prefix ) continue;; esac;; esac as_fn_error $? "expected an absolute directory name for --$ac_var: $ac_val" done # There might be people who depend on the old broken behavior: `$host' # used to hold the argument of --host etc. # FIXME: To remove some day. build=$build_alias host=$host_alias target=$target_alias # FIXME: To remove some day. if test "x$host_alias" != x; then if test "x$build_alias" = x; then cross_compiling=maybe elif test "x$build_alias" != "x$host_alias"; then cross_compiling=yes fi fi ac_tool_prefix= test -n "$host_alias" && ac_tool_prefix=$host_alias- test "$silent" = yes && exec 6>/dev/null ac_pwd=`pwd` && test -n "$ac_pwd" && ac_ls_di=`ls -di .` && ac_pwd_ls_di=`cd "$ac_pwd" && ls -di .` || as_fn_error $? "working directory cannot be determined" test "X$ac_ls_di" = "X$ac_pwd_ls_di" || as_fn_error $? "pwd does not report name of working directory" # Find the source files, if location was not specified. if test -z "$srcdir"; then ac_srcdir_defaulted=yes # Try the directory containing this script, then the parent directory. ac_confdir=`$as_dirname -- "$as_myself" || $as_expr X"$as_myself" : 'X\(.*[^/]\)//*[^/][^/]*/*$' \| \ X"$as_myself" : 'X\(//\)[^/]' \| \ X"$as_myself" : 'X\(//\)$' \| \ X"$as_myself" : 'X\(/\)' \| . 2>/dev/null || $as_echo X"$as_myself" | sed '/^X\(.*[^/]\)\/\/*[^/][^/]*\/*$/{ s//\1/ q } /^X\(\/\/\)[^/].*/{ s//\1/ q } /^X\(\/\/\)$/{ s//\1/ q } /^X\(\/\).*/{ s//\1/ q } s/.*/./; q'` srcdir=$ac_confdir if test ! -r "$srcdir/$ac_unique_file"; then srcdir=.. fi else ac_srcdir_defaulted=no fi if test ! -r "$srcdir/$ac_unique_file"; then test "$ac_srcdir_defaulted" = yes && srcdir="$ac_confdir or .." as_fn_error $? "cannot find sources ($ac_unique_file) in $srcdir" fi ac_msg="sources are in $srcdir, but \`cd $srcdir' does not work" ac_abs_confdir=`( cd "$srcdir" && test -r "./$ac_unique_file" || as_fn_error $? "$ac_msg" pwd)` # When building in place, set srcdir=. if test "$ac_abs_confdir" = "$ac_pwd"; then srcdir=. fi # Remove unnecessary trailing slashes from srcdir. # Double slashes in file names in object file debugging info # mess up M-x gdb in Emacs. case $srcdir in */) srcdir=`expr "X$srcdir" : 'X\(.*[^/]\)' \| "X$srcdir" : 'X\(.*\)'`;; esac for ac_var in $ac_precious_vars; do eval ac_env_${ac_var}_set=\${${ac_var}+set} eval ac_env_${ac_var}_value=\$${ac_var} eval ac_cv_env_${ac_var}_set=\${${ac_var}+set} eval ac_cv_env_${ac_var}_value=\$${ac_var} done # # Report the --help message. # if test "$ac_init_help" = "long"; then # Omit some internal or obsolete options to make the list less imposing. # This message is too long to be a string in the A/UX 3.1 sh. cat <<_ACEOF \`configure' configures rfxcodec 0.1.4 to adapt to many kinds of systems. Usage: $0 [OPTION]... [VAR=VALUE]... To assign environment variables (e.g., CC, CFLAGS...), specify them as VAR=VALUE. See below for descriptions of some of the useful variables. Defaults for the options are specified in brackets. Configuration: -h, --help display this help and exit --help=short display options specific to this package --help=recursive display the short help of all the included packages -V, --version display version information and exit -q, --quiet, --silent do not print \`checking ...' messages --cache-file=FILE cache test results in FILE [disabled] -C, --config-cache alias for \`--cache-file=config.cache' -n, --no-create do not create output files --srcdir=DIR find the sources in DIR [configure dir or \`..'] Installation directories: --prefix=PREFIX install architecture-independent files in PREFIX [$ac_default_prefix] --exec-prefix=EPREFIX install architecture-dependent files in EPREFIX [PREFIX] By default, \`make install' will install all the files in \`$ac_default_prefix/bin', \`$ac_default_prefix/lib' etc. You can specify an installation prefix other than \`$ac_default_prefix' using \`--prefix', for instance \`--prefix=\$HOME'. For better control, use the options below. Fine tuning of the installation directories: --bindir=DIR user executables [EPREFIX/bin] --sbindir=DIR system admin executables [EPREFIX/sbin] --libexecdir=DIR program executables [EPREFIX/libexec] --sysconfdir=DIR read-only single-machine data [PREFIX/etc] --sharedstatedir=DIR modifiable architecture-independent data [PREFIX/com] --localstatedir=DIR modifiable single-machine data [PREFIX/var] --libdir=DIR object code libraries [EPREFIX/lib] --includedir=DIR C header files [PREFIX/include] --oldincludedir=DIR C header files for non-gcc [/usr/include] --datarootdir=DIR read-only arch.-independent data root [PREFIX/share] --datadir=DIR read-only architecture-independent data [DATAROOTDIR] --infodir=DIR info documentation [DATAROOTDIR/info] --localedir=DIR locale-dependent data [DATAROOTDIR/locale] --mandir=DIR man documentation [DATAROOTDIR/man] --docdir=DIR documentation root [DATAROOTDIR/doc/rfxcodec] --htmldir=DIR html documentation [DOCDIR] --dvidir=DIR dvi documentation [DOCDIR] --pdfdir=DIR pdf documentation [DOCDIR] --psdir=DIR ps documentation [DOCDIR] _ACEOF cat <<\_ACEOF Program names: --program-prefix=PREFIX prepend PREFIX to installed program names --program-suffix=SUFFIX append SUFFIX to installed program names --program-transform-name=PROGRAM run sed PROGRAM on installed program names System types: --build=BUILD configure for building on BUILD [guessed] --host=HOST cross-compile to build programs to run on HOST [BUILD] _ACEOF fi if test -n "$ac_init_help"; then case $ac_init_help in short | recursive ) echo "Configuration of rfxcodec 0.1.4:";; esac cat <<\_ACEOF Optional Features: --disable-option-checking ignore unrecognized --enable/--with options --disable-FEATURE do not include FEATURE (same as --enable-FEATURE=no) --enable-FEATURE[=ARG] include FEATURE [ARG=yes] --enable-silent-rules less verbose build output (undo: "make V=1") --disable-silent-rules verbose build output (undo: "make V=0") --enable-dependency-tracking do not reject slow dependency extractors --disable-dependency-tracking speeds up one-time build --enable-shared[=PKGS] build shared libraries [default=yes] --enable-static[=PKGS] build static libraries [default=yes] --enable-fast-install[=PKGS] optimize for fast installation [default=yes] --disable-libtool-lock avoid locking (might break parallel builds) Optional Packages: --with-PACKAGE[=ARG] use PACKAGE [ARG=yes] --without-PACKAGE do not use PACKAGE (same as --with-PACKAGE=no) --with-pic[=PKGS] try to use only PIC/non-PIC objects [default=use both] --with-aix-soname=aix|svr4|both shared library versioning (aka "SONAME") variant to provide on AIX, [default=aix]. --with-gnu-ld assume the C compiler uses GNU ld [default=no] --with-sysroot[=DIR] Search for dependent libraries within DIR (or the compiler's sysroot if not specified). --with-pkgconfigdir pkg-config installation directory ['${libdir}/pkgconfig'] --without-simd Omit SIMD extensions. Some influential environment variables: CC C compiler command CFLAGS C compiler flags LDFLAGS linker flags, e.g. -L if you have libraries in a nonstandard directory LIBS libraries to pass to the linker, e.g. -l CPPFLAGS (Objective) C/C++ preprocessor flags, e.g. -I if you have headers in a nonstandard directory LT_SYS_LIBRARY_PATH User-defined run-time library search path. CPP C preprocessor Use these variables to override the choices made by `configure' or to help it to find libraries and programs with nonstandard names/locations. Report bugs to . _ACEOF ac_status=$? fi if test "$ac_init_help" = "recursive"; then # If there are subdirs, report their specific --help. for ac_dir in : $ac_subdirs_all; do test "x$ac_dir" = x: && continue test -d "$ac_dir" || { cd "$srcdir" && ac_pwd=`pwd` && srcdir=. && test -d "$ac_dir"; } || continue ac_builddir=. case "$ac_dir" in .) ac_dir_suffix= ac_top_builddir_sub=. ac_top_build_prefix= ;; *) ac_dir_suffix=/`$as_echo "$ac_dir" | sed 's|^\.[\\/]||'` # A ".." for each directory in $ac_dir_suffix. ac_top_builddir_sub=`$as_echo "$ac_dir_suffix" | sed 's|/[^\\/]*|/..|g;s|/||'` case $ac_top_builddir_sub in "") ac_top_builddir_sub=. ac_top_build_prefix= ;; *) ac_top_build_prefix=$ac_top_builddir_sub/ ;; esac ;; esac ac_abs_top_builddir=$ac_pwd ac_abs_builddir=$ac_pwd$ac_dir_suffix # for backward compatibility: ac_top_builddir=$ac_top_build_prefix case $srcdir in .) # We are building in place. ac_srcdir=. ac_top_srcdir=$ac_top_builddir_sub ac_abs_top_srcdir=$ac_pwd ;; [\\/]* | ?:[\\/]* ) # Absolute name. ac_srcdir=$srcdir$ac_dir_suffix; ac_top_srcdir=$srcdir ac_abs_top_srcdir=$srcdir ;; *) # Relative name. ac_srcdir=$ac_top_build_prefix$srcdir$ac_dir_suffix ac_top_srcdir=$ac_top_build_prefix$srcdir ac_abs_top_srcdir=$ac_pwd/$srcdir ;; esac ac_abs_srcdir=$ac_abs_top_srcdir$ac_dir_suffix cd "$ac_dir" || { ac_status=$?; continue; } # Check for guested configure. if test -f "$ac_srcdir/configure.gnu"; then echo && $SHELL "$ac_srcdir/configure.gnu" --help=recursive elif test -f "$ac_srcdir/configure"; then echo && $SHELL "$ac_srcdir/configure" --help=recursive else $as_echo "$as_me: WARNING: no configuration information is in $ac_dir" >&2 fi || ac_status=$? cd "$ac_pwd" || { ac_status=$?; break; } done fi test -n "$ac_init_help" && exit $ac_status if $ac_init_version; then cat <<\_ACEOF rfxcodec configure 0.1.4 generated by GNU Autoconf 2.69 Copyright (C) 2012 Free Software Foundation, Inc. This configure script is free software; the Free Software Foundation gives unlimited permission to copy, distribute and modify it. _ACEOF exit fi ## ------------------------ ## ## Autoconf initialization. ## ## ------------------------ ## # ac_fn_c_try_compile LINENO # -------------------------- # Try to compile conftest.$ac_ext, and return whether this succeeded. ac_fn_c_try_compile () { as_lineno=${as_lineno-"$1"} as_lineno_stack=as_lineno_stack=$as_lineno_stack rm -f conftest.$ac_objext if { { ac_try="$ac_compile" case "(($ac_try" in *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; *) ac_try_echo=$ac_try;; esac eval ac_try_echo="\"\$as_me:${as_lineno-$LINENO}: $ac_try_echo\"" $as_echo "$ac_try_echo"; } >&5 (eval "$ac_compile") 2>conftest.err ac_status=$? if test -s conftest.err; then grep -v '^ *+' conftest.err >conftest.er1 cat conftest.er1 >&5 mv -f conftest.er1 conftest.err fi $as_echo "$as_me:${as_lineno-$LINENO}: \$? = $ac_status" >&5 test $ac_status = 0; } && { test -z "$ac_c_werror_flag" || test ! -s conftest.err } && test -s conftest.$ac_objext; then : ac_retval=0 else $as_echo "$as_me: failed program was:" >&5 sed 's/^/| /' conftest.$ac_ext >&5 ac_retval=1 fi eval $as_lineno_stack; ${as_lineno_stack:+:} unset as_lineno as_fn_set_status $ac_retval } # ac_fn_c_try_compile # ac_fn_c_try_link LINENO # ----------------------- # Try to link conftest.$ac_ext, and return whether this succeeded. ac_fn_c_try_link () { as_lineno=${as_lineno-"$1"} as_lineno_stack=as_lineno_stack=$as_lineno_stack rm -f conftest.$ac_objext conftest$ac_exeext if { { ac_try="$ac_link" case "(($ac_try" in *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; *) ac_try_echo=$ac_try;; esac eval ac_try_echo="\"\$as_me:${as_lineno-$LINENO}: $ac_try_echo\"" $as_echo "$ac_try_echo"; } >&5 (eval "$ac_link") 2>conftest.err ac_status=$? if test -s conftest.err; then grep -v '^ *+' conftest.err >conftest.er1 cat conftest.er1 >&5 mv -f conftest.er1 conftest.err fi $as_echo "$as_me:${as_lineno-$LINENO}: \$? = $ac_status" >&5 test $ac_status = 0; } && { test -z "$ac_c_werror_flag" || test ! -s conftest.err } && test -s conftest$ac_exeext && { test "$cross_compiling" = yes || test -x conftest$ac_exeext }; then : ac_retval=0 else $as_echo "$as_me: failed program was:" >&5 sed 's/^/| /' conftest.$ac_ext >&5 ac_retval=1 fi # Delete the IPA/IPO (Inter Procedural Analysis/Optimization) information # created by the PGI compiler (conftest_ipa8_conftest.oo), as it would # interfere with the next link command; also delete a directory that is # left behind by Apple's compiler. We do this before executing the actions. rm -rf conftest.dSYM conftest_ipa8_conftest.oo eval $as_lineno_stack; ${as_lineno_stack:+:} unset as_lineno as_fn_set_status $ac_retval } # ac_fn_c_try_link # ac_fn_c_check_header_compile LINENO HEADER VAR INCLUDES # ------------------------------------------------------- # Tests whether HEADER exists and can be compiled using the include files in # INCLUDES, setting the cache variable VAR accordingly. ac_fn_c_check_header_compile () { as_lineno=${as_lineno-"$1"} as_lineno_stack=as_lineno_stack=$as_lineno_stack { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $2" >&5 $as_echo_n "checking for $2... " >&6; } if eval \${$3+:} false; then : $as_echo_n "(cached) " >&6 else cat confdefs.h - <<_ACEOF >conftest.$ac_ext /* end confdefs.h. */ $4 #include <$2> _ACEOF if ac_fn_c_try_compile "$LINENO"; then : eval "$3=yes" else eval "$3=no" fi rm -f core conftest.err conftest.$ac_objext conftest.$ac_ext fi eval ac_res=\$$3 { $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_res" >&5 $as_echo "$ac_res" >&6; } eval $as_lineno_stack; ${as_lineno_stack:+:} unset as_lineno } # ac_fn_c_check_header_compile # ac_fn_c_try_cpp LINENO # ---------------------- # Try to preprocess conftest.$ac_ext, and return whether this succeeded. ac_fn_c_try_cpp () { as_lineno=${as_lineno-"$1"} as_lineno_stack=as_lineno_stack=$as_lineno_stack if { { ac_try="$ac_cpp conftest.$ac_ext" case "(($ac_try" in *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; *) ac_try_echo=$ac_try;; esac eval ac_try_echo="\"\$as_me:${as_lineno-$LINENO}: $ac_try_echo\"" $as_echo "$ac_try_echo"; } >&5 (eval "$ac_cpp conftest.$ac_ext") 2>conftest.err ac_status=$? if test -s conftest.err; then grep -v '^ *+' conftest.err >conftest.er1 cat conftest.er1 >&5 mv -f conftest.er1 conftest.err fi $as_echo "$as_me:${as_lineno-$LINENO}: \$? = $ac_status" >&5 test $ac_status = 0; } > conftest.i && { test -z "$ac_c_preproc_warn_flag$ac_c_werror_flag" || test ! -s conftest.err }; then : ac_retval=0 else $as_echo "$as_me: failed program was:" >&5 sed 's/^/| /' conftest.$ac_ext >&5 ac_retval=1 fi eval $as_lineno_stack; ${as_lineno_stack:+:} unset as_lineno as_fn_set_status $ac_retval } # ac_fn_c_try_cpp # ac_fn_c_try_run LINENO # ---------------------- # Try to link conftest.$ac_ext, and return whether this succeeded. Assumes # that executables *can* be run. ac_fn_c_try_run () { as_lineno=${as_lineno-"$1"} as_lineno_stack=as_lineno_stack=$as_lineno_stack if { { ac_try="$ac_link" case "(($ac_try" in *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; *) ac_try_echo=$ac_try;; esac eval ac_try_echo="\"\$as_me:${as_lineno-$LINENO}: $ac_try_echo\"" $as_echo "$ac_try_echo"; } >&5 (eval "$ac_link") 2>&5 ac_status=$? $as_echo "$as_me:${as_lineno-$LINENO}: \$? = $ac_status" >&5 test $ac_status = 0; } && { ac_try='./conftest$ac_exeext' { { case "(($ac_try" in *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; *) ac_try_echo=$ac_try;; esac eval ac_try_echo="\"\$as_me:${as_lineno-$LINENO}: $ac_try_echo\"" $as_echo "$ac_try_echo"; } >&5 (eval "$ac_try") 2>&5 ac_status=$? $as_echo "$as_me:${as_lineno-$LINENO}: \$? = $ac_status" >&5 test $ac_status = 0; }; }; then : ac_retval=0 else $as_echo "$as_me: program exited with status $ac_status" >&5 $as_echo "$as_me: failed program was:" >&5 sed 's/^/| /' conftest.$ac_ext >&5 ac_retval=$ac_status fi rm -rf conftest.dSYM conftest_ipa8_conftest.oo eval $as_lineno_stack; ${as_lineno_stack:+:} unset as_lineno as_fn_set_status $ac_retval } # ac_fn_c_try_run # ac_fn_c_check_func LINENO FUNC VAR # ---------------------------------- # Tests whether FUNC exists, setting the cache variable VAR accordingly ac_fn_c_check_func () { as_lineno=${as_lineno-"$1"} as_lineno_stack=as_lineno_stack=$as_lineno_stack { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $2" >&5 $as_echo_n "checking for $2... " >&6; } if eval \${$3+:} false; then : $as_echo_n "(cached) " >&6 else cat confdefs.h - <<_ACEOF >conftest.$ac_ext /* end confdefs.h. */ /* Define $2 to an innocuous variant, in case declares $2. For example, HP-UX 11i declares gettimeofday. */ #define $2 innocuous_$2 /* System header to define __stub macros and hopefully few prototypes, which can conflict with char $2 (); below. Prefer to if __STDC__ is defined, since exists even on freestanding compilers. */ #ifdef __STDC__ # include #else # include #endif #undef $2 /* Override any GCC internal prototype to avoid an error. Use char because int might match the return type of a GCC builtin and then its argument prototype would still apply. */ #ifdef __cplusplus extern "C" #endif char $2 (); /* The GNU C library defines this for functions which it implements to always fail with ENOSYS. Some functions are actually named something starting with __ and the normal name is an alias. */ #if defined __stub_$2 || defined __stub___$2 choke me #endif int main () { return $2 (); ; return 0; } _ACEOF if ac_fn_c_try_link "$LINENO"; then : eval "$3=yes" else eval "$3=no" fi rm -f core conftest.err conftest.$ac_objext \ conftest$ac_exeext conftest.$ac_ext fi eval ac_res=\$$3 { $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_res" >&5 $as_echo "$ac_res" >&6; } eval $as_lineno_stack; ${as_lineno_stack:+:} unset as_lineno } # ac_fn_c_check_func cat >config.log <<_ACEOF This file contains any messages produced by compilers while running configure, to aid debugging if configure makes a mistake. It was created by rfxcodec $as_me 0.1.4, which was generated by GNU Autoconf 2.69. Invocation command line was $ $0 $@ _ACEOF exec 5>>config.log { cat <<_ASUNAME ## --------- ## ## Platform. ## ## --------- ## hostname = `(hostname || uname -n) 2>/dev/null | sed 1q` uname -m = `(uname -m) 2>/dev/null || echo unknown` uname -r = `(uname -r) 2>/dev/null || echo unknown` uname -s = `(uname -s) 2>/dev/null || echo unknown` uname -v = `(uname -v) 2>/dev/null || echo unknown` /usr/bin/uname -p = `(/usr/bin/uname -p) 2>/dev/null || echo unknown` /bin/uname -X = `(/bin/uname -X) 2>/dev/null || echo unknown` /bin/arch = `(/bin/arch) 2>/dev/null || echo unknown` /usr/bin/arch -k = `(/usr/bin/arch -k) 2>/dev/null || echo unknown` /usr/convex/getsysinfo = `(/usr/convex/getsysinfo) 2>/dev/null || echo unknown` /usr/bin/hostinfo = `(/usr/bin/hostinfo) 2>/dev/null || echo unknown` /bin/machine = `(/bin/machine) 2>/dev/null || echo unknown` /usr/bin/oslevel = `(/usr/bin/oslevel) 2>/dev/null || echo unknown` /bin/universe = `(/bin/universe) 2>/dev/null || echo unknown` _ASUNAME as_save_IFS=$IFS; IFS=$PATH_SEPARATOR for as_dir in $PATH do IFS=$as_save_IFS test -z "$as_dir" && as_dir=. $as_echo "PATH: $as_dir" done IFS=$as_save_IFS } >&5 cat >&5 <<_ACEOF ## ----------- ## ## Core tests. ## ## ----------- ## _ACEOF # Keep a trace of the command line. # Strip out --no-create and --no-recursion so they do not pile up. # Strip out --silent because we don't want to record it for future runs. # Also quote any args containing shell meta-characters. # Make two passes to allow for proper duplicate-argument suppression. ac_configure_args= ac_configure_args0= ac_configure_args1= ac_must_keep_next=false for ac_pass in 1 2 do for ac_arg do case $ac_arg in -no-create | --no-c* | -n | -no-recursion | --no-r*) continue ;; -q | -quiet | --quiet | --quie | --qui | --qu | --q \ | -silent | --silent | --silen | --sile | --sil) continue ;; *\'*) ac_arg=`$as_echo "$ac_arg" | sed "s/'/'\\\\\\\\''/g"` ;; esac case $ac_pass in 1) as_fn_append ac_configure_args0 " '$ac_arg'" ;; 2) as_fn_append ac_configure_args1 " '$ac_arg'" if test $ac_must_keep_next = true; then ac_must_keep_next=false # Got value, back to normal. else case $ac_arg in *=* | --config-cache | -C | -disable-* | --disable-* \ | -enable-* | --enable-* | -gas | --g* | -nfp | --nf* \ | -q | -quiet | --q* | -silent | --sil* | -v | -verb* \ | -with-* | --with-* | -without-* | --without-* | --x) case "$ac_configure_args0 " in "$ac_configure_args1"*" '$ac_arg' "* ) continue ;; esac ;; -* ) ac_must_keep_next=true ;; esac fi as_fn_append ac_configure_args " '$ac_arg'" ;; esac done done { ac_configure_args0=; unset ac_configure_args0;} { ac_configure_args1=; unset ac_configure_args1;} # When interrupted or exit'd, cleanup temporary files, and complete # config.log. We remove comments because anyway the quotes in there # would cause problems or look ugly. # WARNING: Use '\'' to represent an apostrophe within the trap. # WARNING: Do not start the trap code with a newline, due to a FreeBSD 4.0 bug. trap 'exit_status=$? # Save into config.log some information that might help in debugging. { echo $as_echo "## ---------------- ## ## Cache variables. ## ## ---------------- ##" echo # The following way of writing the cache mishandles newlines in values, ( for ac_var in `(set) 2>&1 | sed -n '\''s/^\([a-zA-Z_][a-zA-Z0-9_]*\)=.*/\1/p'\''`; do eval ac_val=\$$ac_var case $ac_val in #( *${as_nl}*) case $ac_var in #( *_cv_*) { $as_echo "$as_me:${as_lineno-$LINENO}: WARNING: cache variable $ac_var contains a newline" >&5 $as_echo "$as_me: WARNING: cache variable $ac_var contains a newline" >&2;} ;; esac case $ac_var in #( _ | IFS | as_nl) ;; #( BASH_ARGV | BASH_SOURCE) eval $ac_var= ;; #( *) { eval $ac_var=; unset $ac_var;} ;; esac ;; esac done (set) 2>&1 | case $as_nl`(ac_space='\'' '\''; set) 2>&1` in #( *${as_nl}ac_space=\ *) sed -n \ "s/'\''/'\''\\\\'\'''\''/g; s/^\\([_$as_cr_alnum]*_cv_[_$as_cr_alnum]*\\)=\\(.*\\)/\\1='\''\\2'\''/p" ;; #( *) sed -n "/^[_$as_cr_alnum]*_cv_[_$as_cr_alnum]*=/p" ;; esac | sort ) echo $as_echo "## ----------------- ## ## Output variables. ## ## ----------------- ##" echo for ac_var in $ac_subst_vars do eval ac_val=\$$ac_var case $ac_val in *\'\''*) ac_val=`$as_echo "$ac_val" | sed "s/'\''/'\''\\\\\\\\'\'''\''/g"`;; esac $as_echo "$ac_var='\''$ac_val'\''" done | sort echo if test -n "$ac_subst_files"; then $as_echo "## ------------------- ## ## File substitutions. ## ## ------------------- ##" echo for ac_var in $ac_subst_files do eval ac_val=\$$ac_var case $ac_val in *\'\''*) ac_val=`$as_echo "$ac_val" | sed "s/'\''/'\''\\\\\\\\'\'''\''/g"`;; esac $as_echo "$ac_var='\''$ac_val'\''" done | sort echo fi if test -s confdefs.h; then $as_echo "## ----------- ## ## confdefs.h. ## ## ----------- ##" echo cat confdefs.h echo fi test "$ac_signal" != 0 && $as_echo "$as_me: caught signal $ac_signal" $as_echo "$as_me: exit $exit_status" } >&5 rm -f core *.core core.conftest.* && rm -f -r conftest* confdefs* conf$$* $ac_clean_files && exit $exit_status ' 0 for ac_signal in 1 2 13 15; do trap 'ac_signal='$ac_signal'; as_fn_exit 1' $ac_signal done ac_signal=0 # confdefs.h avoids OS command line length limits that DEFS can exceed. rm -f -r conftest* confdefs.h $as_echo "/* confdefs.h */" > confdefs.h # Predefined preprocessor variables. cat >>confdefs.h <<_ACEOF #define PACKAGE_NAME "$PACKAGE_NAME" _ACEOF cat >>confdefs.h <<_ACEOF #define PACKAGE_TARNAME "$PACKAGE_TARNAME" _ACEOF cat >>confdefs.h <<_ACEOF #define PACKAGE_VERSION "$PACKAGE_VERSION" _ACEOF cat >>confdefs.h <<_ACEOF #define PACKAGE_STRING "$PACKAGE_STRING" _ACEOF cat >>confdefs.h <<_ACEOF #define PACKAGE_BUGREPORT "$PACKAGE_BUGREPORT" _ACEOF cat >>confdefs.h <<_ACEOF #define PACKAGE_URL "$PACKAGE_URL" _ACEOF # Let the site file select an alternate cache file if it wants to. # Prefer an explicitly selected file to automatically selected ones. ac_site_file1=NONE ac_site_file2=NONE if test -n "$CONFIG_SITE"; then # We do not want a PATH search for config.site. case $CONFIG_SITE in #(( -*) ac_site_file1=./$CONFIG_SITE;; */*) ac_site_file1=$CONFIG_SITE;; *) ac_site_file1=./$CONFIG_SITE;; esac elif test "x$prefix" != xNONE; then ac_site_file1=$prefix/share/config.site ac_site_file2=$prefix/etc/config.site else ac_site_file1=$ac_default_prefix/share/config.site ac_site_file2=$ac_default_prefix/etc/config.site fi for ac_site_file in "$ac_site_file1" "$ac_site_file2" do test "x$ac_site_file" = xNONE && continue if test /dev/null != "$ac_site_file" && test -r "$ac_site_file"; then { $as_echo "$as_me:${as_lineno-$LINENO}: loading site script $ac_site_file" >&5 $as_echo "$as_me: loading site script $ac_site_file" >&6;} sed 's/^/| /' "$ac_site_file" >&5 . "$ac_site_file" \ || { { $as_echo "$as_me:${as_lineno-$LINENO}: error: in \`$ac_pwd':" >&5 $as_echo "$as_me: error: in \`$ac_pwd':" >&2;} as_fn_error $? "failed to load site script $ac_site_file See \`config.log' for more details" "$LINENO" 5; } fi done if test -r "$cache_file"; then # Some versions of bash will fail to source /dev/null (special files # actually), so we avoid doing that. DJGPP emulates it as a regular file. if test /dev/null != "$cache_file" && test -f "$cache_file"; then { $as_echo "$as_me:${as_lineno-$LINENO}: loading cache $cache_file" >&5 $as_echo "$as_me: loading cache $cache_file" >&6;} case $cache_file in [\\/]* | ?:[\\/]* ) . "$cache_file";; *) . "./$cache_file";; esac fi else { $as_echo "$as_me:${as_lineno-$LINENO}: creating cache $cache_file" >&5 $as_echo "$as_me: creating cache $cache_file" >&6;} >$cache_file fi # Check that the precious variables saved in the cache have kept the same # value. ac_cache_corrupted=false for ac_var in $ac_precious_vars; do eval ac_old_set=\$ac_cv_env_${ac_var}_set eval ac_new_set=\$ac_env_${ac_var}_set eval ac_old_val=\$ac_cv_env_${ac_var}_value eval ac_new_val=\$ac_env_${ac_var}_value case $ac_old_set,$ac_new_set in set,) { $as_echo "$as_me:${as_lineno-$LINENO}: error: \`$ac_var' was set to \`$ac_old_val' in the previous run" >&5 $as_echo "$as_me: error: \`$ac_var' was set to \`$ac_old_val' in the previous run" >&2;} ac_cache_corrupted=: ;; ,set) { $as_echo "$as_me:${as_lineno-$LINENO}: error: \`$ac_var' was not set in the previous run" >&5 $as_echo "$as_me: error: \`$ac_var' was not set in the previous run" >&2;} ac_cache_corrupted=: ;; ,);; *) if test "x$ac_old_val" != "x$ac_new_val"; then # differences in whitespace do not lead to failure. ac_old_val_w=`echo x $ac_old_val` ac_new_val_w=`echo x $ac_new_val` if test "$ac_old_val_w" != "$ac_new_val_w"; then { $as_echo "$as_me:${as_lineno-$LINENO}: error: \`$ac_var' has changed since the previous run:" >&5 $as_echo "$as_me: error: \`$ac_var' has changed since the previous run:" >&2;} ac_cache_corrupted=: else { $as_echo "$as_me:${as_lineno-$LINENO}: warning: ignoring whitespace changes in \`$ac_var' since the previous run:" >&5 $as_echo "$as_me: warning: ignoring whitespace changes in \`$ac_var' since the previous run:" >&2;} eval $ac_var=\$ac_old_val fi { $as_echo "$as_me:${as_lineno-$LINENO}: former value: \`$ac_old_val'" >&5 $as_echo "$as_me: former value: \`$ac_old_val'" >&2;} { $as_echo "$as_me:${as_lineno-$LINENO}: current value: \`$ac_new_val'" >&5 $as_echo "$as_me: current value: \`$ac_new_val'" >&2;} fi;; esac # Pass precious variables to config.status. if test "$ac_new_set" = set; then case $ac_new_val in *\'*) ac_arg=$ac_var=`$as_echo "$ac_new_val" | sed "s/'/'\\\\\\\\''/g"` ;; *) ac_arg=$ac_var=$ac_new_val ;; esac case " $ac_configure_args " in *" '$ac_arg' "*) ;; # Avoid dups. Use of quotes ensures accuracy. *) as_fn_append ac_configure_args " '$ac_arg'" ;; esac fi done if $ac_cache_corrupted; then { $as_echo "$as_me:${as_lineno-$LINENO}: error: in \`$ac_pwd':" >&5 $as_echo "$as_me: error: in \`$ac_pwd':" >&2;} { $as_echo "$as_me:${as_lineno-$LINENO}: error: changes in the environment can compromise the build" >&5 $as_echo "$as_me: error: changes in the environment can compromise the build" >&2;} as_fn_error $? "run \`make distclean' and/or \`rm $cache_file' and start over" "$LINENO" 5 fi ## -------------------- ## ## Main body of script. ## ## -------------------- ## ac_ext=c ac_cpp='$CPP $CPPFLAGS' ac_compile='$CC -c $CFLAGS $CPPFLAGS conftest.$ac_ext >&5' ac_link='$CC -o conftest$ac_exeext $CFLAGS $CPPFLAGS $LDFLAGS conftest.$ac_ext $LIBS >&5' ac_compiler_gnu=$ac_cv_c_compiler_gnu ac_config_headers="$ac_config_headers config_ac.h:config_ac-h.in" am__api_version='1.15' ac_aux_dir= for ac_dir in "$srcdir" "$srcdir/.." "$srcdir/../.."; do if test -f "$ac_dir/install-sh"; then ac_aux_dir=$ac_dir ac_install_sh="$ac_aux_dir/install-sh -c" break elif test -f "$ac_dir/install.sh"; then ac_aux_dir=$ac_dir ac_install_sh="$ac_aux_dir/install.sh -c" break elif test -f "$ac_dir/shtool"; then ac_aux_dir=$ac_dir ac_install_sh="$ac_aux_dir/shtool install -c" break fi done if test -z "$ac_aux_dir"; then as_fn_error $? "cannot find install-sh, install.sh, or shtool in \"$srcdir\" \"$srcdir/..\" \"$srcdir/../..\"" "$LINENO" 5 fi # These three variables are undocumented and unsupported, # and are intended to be withdrawn in a future Autoconf release. # They can cause serious problems if a builder's source tree is in a directory # whose full name contains unusual characters. ac_config_guess="$SHELL $ac_aux_dir/config.guess" # Please don't use this var. ac_config_sub="$SHELL $ac_aux_dir/config.sub" # Please don't use this var. ac_configure="$SHELL $ac_aux_dir/configure" # Please don't use this var. # Find a good install program. We prefer a C program (faster), # so one script is as good as another. But avoid the broken or # incompatible versions: # SysV /etc/install, /usr/sbin/install # SunOS /usr/etc/install # IRIX /sbin/install # AIX /bin/install # AmigaOS /C/install, which installs bootblocks on floppy discs # AIX 4 /usr/bin/installbsd, which doesn't work without a -g flag # AFS /usr/afsws/bin/install, which mishandles nonexistent args # SVR4 /usr/ucb/install, which tries to use the nonexistent group "staff" # OS/2's system install, which has a completely different semantic # ./install, which can be erroneously created by make from ./install.sh. # Reject install programs that cannot install multiple files. { $as_echo "$as_me:${as_lineno-$LINENO}: checking for a BSD-compatible install" >&5 $as_echo_n "checking for a BSD-compatible install... " >&6; } if test -z "$INSTALL"; then if ${ac_cv_path_install+:} false; then : $as_echo_n "(cached) " >&6 else as_save_IFS=$IFS; IFS=$PATH_SEPARATOR for as_dir in $PATH do IFS=$as_save_IFS test -z "$as_dir" && as_dir=. # Account for people who put trailing slashes in PATH elements. case $as_dir/ in #(( ./ | .// | /[cC]/* | \ /etc/* | /usr/sbin/* | /usr/etc/* | /sbin/* | /usr/afsws/bin/* | \ ?:[\\/]os2[\\/]install[\\/]* | ?:[\\/]OS2[\\/]INSTALL[\\/]* | \ /usr/ucb/* ) ;; *) # OSF1 and SCO ODT 3.0 have their own names for install. # Don't use installbsd from OSF since it installs stuff as root # by default. for ac_prog in ginstall scoinst install; do for ac_exec_ext in '' $ac_executable_extensions; do if as_fn_executable_p "$as_dir/$ac_prog$ac_exec_ext"; then if test $ac_prog = install && grep dspmsg "$as_dir/$ac_prog$ac_exec_ext" >/dev/null 2>&1; then # AIX install. It has an incompatible calling convention. : elif test $ac_prog = install && grep pwplus "$as_dir/$ac_prog$ac_exec_ext" >/dev/null 2>&1; then # program-specific install script used by HP pwplus--don't use. : else rm -rf conftest.one conftest.two conftest.dir echo one > conftest.one echo two > conftest.two mkdir conftest.dir if "$as_dir/$ac_prog$ac_exec_ext" -c conftest.one conftest.two "`pwd`/conftest.dir" && test -s conftest.one && test -s conftest.two && test -s conftest.dir/conftest.one && test -s conftest.dir/conftest.two then ac_cv_path_install="$as_dir/$ac_prog$ac_exec_ext -c" break 3 fi fi fi done done ;; esac done IFS=$as_save_IFS rm -rf conftest.one conftest.two conftest.dir fi if test "${ac_cv_path_install+set}" = set; then INSTALL=$ac_cv_path_install else # As a last resort, use the slow shell script. Don't cache a # value for INSTALL within a source directory, because that will # break other packages using the cache if that directory is # removed, or if the value is a relative name. INSTALL=$ac_install_sh fi fi { $as_echo "$as_me:${as_lineno-$LINENO}: result: $INSTALL" >&5 $as_echo "$INSTALL" >&6; } # Use test -z because SunOS4 sh mishandles braces in ${var-val}. # It thinks the first close brace ends the variable substitution. test -z "$INSTALL_PROGRAM" && INSTALL_PROGRAM='${INSTALL}' test -z "$INSTALL_SCRIPT" && INSTALL_SCRIPT='${INSTALL}' test -z "$INSTALL_DATA" && INSTALL_DATA='${INSTALL} -m 644' { $as_echo "$as_me:${as_lineno-$LINENO}: checking whether build environment is sane" >&5 $as_echo_n "checking whether build environment is sane... " >&6; } # Reject unsafe characters in $srcdir or the absolute working directory # name. Accept space and tab only in the latter. am_lf=' ' case `pwd` in *[\\\"\#\$\&\'\`$am_lf]*) as_fn_error $? "unsafe absolute working directory name" "$LINENO" 5;; esac case $srcdir in *[\\\"\#\$\&\'\`$am_lf\ \ ]*) as_fn_error $? "unsafe srcdir value: '$srcdir'" "$LINENO" 5;; esac # Do 'set' in a subshell so we don't clobber the current shell's # arguments. Must try -L first in case configure is actually a # symlink; some systems play weird games with the mod time of symlinks # (eg FreeBSD returns the mod time of the symlink's containing # directory). if ( am_has_slept=no for am_try in 1 2; do echo "timestamp, slept: $am_has_slept" > conftest.file set X `ls -Lt "$srcdir/configure" conftest.file 2> /dev/null` if test "$*" = "X"; then # -L didn't work. set X `ls -t "$srcdir/configure" conftest.file` fi if test "$*" != "X $srcdir/configure conftest.file" \ && test "$*" != "X conftest.file $srcdir/configure"; then # If neither matched, then we have a broken ls. This can happen # if, for instance, CONFIG_SHELL is bash and it inherits a # broken ls alias from the environment. This has actually # happened. Such a system could not be considered "sane". as_fn_error $? "ls -t appears to fail. Make sure there is not a broken alias in your environment" "$LINENO" 5 fi if test "$2" = conftest.file || test $am_try -eq 2; then break fi # Just in case. sleep 1 am_has_slept=yes done test "$2" = conftest.file ) then # Ok. : else as_fn_error $? "newly created file is older than distributed files! Check your system clock" "$LINENO" 5 fi { $as_echo "$as_me:${as_lineno-$LINENO}: result: yes" >&5 $as_echo "yes" >&6; } # If we didn't sleep, we still need to ensure time stamps of config.status and # generated files are strictly newer. am_sleep_pid= if grep 'slept: no' conftest.file >/dev/null 2>&1; then ( sleep 1 ) & am_sleep_pid=$! fi rm -f conftest.file test "$program_prefix" != NONE && program_transform_name="s&^&$program_prefix&;$program_transform_name" # Use a double $ so make ignores it. test "$program_suffix" != NONE && program_transform_name="s&\$&$program_suffix&;$program_transform_name" # Double any \ or $. # By default was `s,x,x', remove it if useless. ac_script='s/[\\$]/&&/g;s/;s,x,x,$//' program_transform_name=`$as_echo "$program_transform_name" | sed "$ac_script"` # Expand $ac_aux_dir to an absolute path. am_aux_dir=`cd "$ac_aux_dir" && pwd` if test x"${MISSING+set}" != xset; then case $am_aux_dir in *\ * | *\ *) MISSING="\${SHELL} \"$am_aux_dir/missing\"" ;; *) MISSING="\${SHELL} $am_aux_dir/missing" ;; esac fi # Use eval to expand $SHELL if eval "$MISSING --is-lightweight"; then am_missing_run="$MISSING " else am_missing_run= { $as_echo "$as_me:${as_lineno-$LINENO}: WARNING: 'missing' script is too old or missing" >&5 $as_echo "$as_me: WARNING: 'missing' script is too old or missing" >&2;} fi if test x"${install_sh+set}" != xset; then case $am_aux_dir in *\ * | *\ *) install_sh="\${SHELL} '$am_aux_dir/install-sh'" ;; *) install_sh="\${SHELL} $am_aux_dir/install-sh" esac fi # Installed binaries are usually stripped using 'strip' when the user # run "make install-strip". However 'strip' might not be the right # tool to use in cross-compilation environments, therefore Automake # will honor the 'STRIP' environment variable to overrule this program. if test "$cross_compiling" != no; then if test -n "$ac_tool_prefix"; then # Extract the first word of "${ac_tool_prefix}strip", so it can be a program name with args. set dummy ${ac_tool_prefix}strip; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } if ${ac_cv_prog_STRIP+:} false; then : $as_echo_n "(cached) " >&6 else if test -n "$STRIP"; then ac_cv_prog_STRIP="$STRIP" # Let the user override the test. else as_save_IFS=$IFS; IFS=$PATH_SEPARATOR for as_dir in $PATH do IFS=$as_save_IFS test -z "$as_dir" && as_dir=. for ac_exec_ext in '' $ac_executable_extensions; do if as_fn_executable_p "$as_dir/$ac_word$ac_exec_ext"; then ac_cv_prog_STRIP="${ac_tool_prefix}strip" $as_echo "$as_me:${as_lineno-$LINENO}: found $as_dir/$ac_word$ac_exec_ext" >&5 break 2 fi done done IFS=$as_save_IFS fi fi STRIP=$ac_cv_prog_STRIP if test -n "$STRIP"; then { $as_echo "$as_me:${as_lineno-$LINENO}: result: $STRIP" >&5 $as_echo "$STRIP" >&6; } else { $as_echo "$as_me:${as_lineno-$LINENO}: result: no" >&5 $as_echo "no" >&6; } fi fi if test -z "$ac_cv_prog_STRIP"; then ac_ct_STRIP=$STRIP # Extract the first word of "strip", so it can be a program name with args. set dummy strip; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } if ${ac_cv_prog_ac_ct_STRIP+:} false; then : $as_echo_n "(cached) " >&6 else if test -n "$ac_ct_STRIP"; then ac_cv_prog_ac_ct_STRIP="$ac_ct_STRIP" # Let the user override the test. else as_save_IFS=$IFS; IFS=$PATH_SEPARATOR for as_dir in $PATH do IFS=$as_save_IFS test -z "$as_dir" && as_dir=. for ac_exec_ext in '' $ac_executable_extensions; do if as_fn_executable_p "$as_dir/$ac_word$ac_exec_ext"; then ac_cv_prog_ac_ct_STRIP="strip" $as_echo "$as_me:${as_lineno-$LINENO}: found $as_dir/$ac_word$ac_exec_ext" >&5 break 2 fi done done IFS=$as_save_IFS fi fi ac_ct_STRIP=$ac_cv_prog_ac_ct_STRIP if test -n "$ac_ct_STRIP"; then { $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_ct_STRIP" >&5 $as_echo "$ac_ct_STRIP" >&6; } else { $as_echo "$as_me:${as_lineno-$LINENO}: result: no" >&5 $as_echo "no" >&6; } fi if test "x$ac_ct_STRIP" = x; then STRIP=":" else case $cross_compiling:$ac_tool_warned in yes:) { $as_echo "$as_me:${as_lineno-$LINENO}: WARNING: using cross tools not prefixed with host triplet" >&5 $as_echo "$as_me: WARNING: using cross tools not prefixed with host triplet" >&2;} ac_tool_warned=yes ;; esac STRIP=$ac_ct_STRIP fi else STRIP="$ac_cv_prog_STRIP" fi fi INSTALL_STRIP_PROGRAM="\$(install_sh) -c -s" { $as_echo "$as_me:${as_lineno-$LINENO}: checking for a thread-safe mkdir -p" >&5 $as_echo_n "checking for a thread-safe mkdir -p... " >&6; } if test -z "$MKDIR_P"; then if ${ac_cv_path_mkdir+:} false; then : $as_echo_n "(cached) " >&6 else as_save_IFS=$IFS; IFS=$PATH_SEPARATOR for as_dir in $PATH$PATH_SEPARATOR/opt/sfw/bin do IFS=$as_save_IFS test -z "$as_dir" && as_dir=. for ac_prog in mkdir gmkdir; do for ac_exec_ext in '' $ac_executable_extensions; do as_fn_executable_p "$as_dir/$ac_prog$ac_exec_ext" || continue case `"$as_dir/$ac_prog$ac_exec_ext" --version 2>&1` in #( 'mkdir (GNU coreutils) '* | \ 'mkdir (coreutils) '* | \ 'mkdir (fileutils) '4.1*) ac_cv_path_mkdir=$as_dir/$ac_prog$ac_exec_ext break 3;; esac done done done IFS=$as_save_IFS fi test -d ./--version && rmdir ./--version if test "${ac_cv_path_mkdir+set}" = set; then MKDIR_P="$ac_cv_path_mkdir -p" else # As a last resort, use the slow shell script. Don't cache a # value for MKDIR_P within a source directory, because that will # break other packages using the cache if that directory is # removed, or if the value is a relative name. MKDIR_P="$ac_install_sh -d" fi fi { $as_echo "$as_me:${as_lineno-$LINENO}: result: $MKDIR_P" >&5 $as_echo "$MKDIR_P" >&6; } for ac_prog in gawk mawk nawk awk do # Extract the first word of "$ac_prog", so it can be a program name with args. set dummy $ac_prog; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } if ${ac_cv_prog_AWK+:} false; then : $as_echo_n "(cached) " >&6 else if test -n "$AWK"; then ac_cv_prog_AWK="$AWK" # Let the user override the test. else as_save_IFS=$IFS; IFS=$PATH_SEPARATOR for as_dir in $PATH do IFS=$as_save_IFS test -z "$as_dir" && as_dir=. for ac_exec_ext in '' $ac_executable_extensions; do if as_fn_executable_p "$as_dir/$ac_word$ac_exec_ext"; then ac_cv_prog_AWK="$ac_prog" $as_echo "$as_me:${as_lineno-$LINENO}: found $as_dir/$ac_word$ac_exec_ext" >&5 break 2 fi done done IFS=$as_save_IFS fi fi AWK=$ac_cv_prog_AWK if test -n "$AWK"; then { $as_echo "$as_me:${as_lineno-$LINENO}: result: $AWK" >&5 $as_echo "$AWK" >&6; } else { $as_echo "$as_me:${as_lineno-$LINENO}: result: no" >&5 $as_echo "no" >&6; } fi test -n "$AWK" && break done { $as_echo "$as_me:${as_lineno-$LINENO}: checking whether ${MAKE-make} sets \$(MAKE)" >&5 $as_echo_n "checking whether ${MAKE-make} sets \$(MAKE)... " >&6; } set x ${MAKE-make} ac_make=`$as_echo "$2" | sed 's/+/p/g; s/[^a-zA-Z0-9_]/_/g'` if eval \${ac_cv_prog_make_${ac_make}_set+:} false; then : $as_echo_n "(cached) " >&6 else cat >conftest.make <<\_ACEOF SHELL = /bin/sh all: @echo '@@@%%%=$(MAKE)=@@@%%%' _ACEOF # GNU make sometimes prints "make[1]: Entering ...", which would confuse us. case `${MAKE-make} -f conftest.make 2>/dev/null` in *@@@%%%=?*=@@@%%%*) eval ac_cv_prog_make_${ac_make}_set=yes;; *) eval ac_cv_prog_make_${ac_make}_set=no;; esac rm -f conftest.make fi if eval test \$ac_cv_prog_make_${ac_make}_set = yes; then { $as_echo "$as_me:${as_lineno-$LINENO}: result: yes" >&5 $as_echo "yes" >&6; } SET_MAKE= else { $as_echo "$as_me:${as_lineno-$LINENO}: result: no" >&5 $as_echo "no" >&6; } SET_MAKE="MAKE=${MAKE-make}" fi rm -rf .tst 2>/dev/null mkdir .tst 2>/dev/null if test -d .tst; then am__leading_dot=. else am__leading_dot=_ fi rmdir .tst 2>/dev/null # Check whether --enable-silent-rules was given. if test "${enable_silent_rules+set}" = set; then : enableval=$enable_silent_rules; fi case $enable_silent_rules in # ((( yes) AM_DEFAULT_VERBOSITY=0;; no) AM_DEFAULT_VERBOSITY=1;; *) AM_DEFAULT_VERBOSITY=1;; esac am_make=${MAKE-make} { $as_echo "$as_me:${as_lineno-$LINENO}: checking whether $am_make supports nested variables" >&5 $as_echo_n "checking whether $am_make supports nested variables... " >&6; } if ${am_cv_make_support_nested_variables+:} false; then : $as_echo_n "(cached) " >&6 else if $as_echo 'TRUE=$(BAR$(V)) BAR0=false BAR1=true V=1 am__doit: @$(TRUE) .PHONY: am__doit' | $am_make -f - >/dev/null 2>&1; then am_cv_make_support_nested_variables=yes else am_cv_make_support_nested_variables=no fi fi { $as_echo "$as_me:${as_lineno-$LINENO}: result: $am_cv_make_support_nested_variables" >&5 $as_echo "$am_cv_make_support_nested_variables" >&6; } if test $am_cv_make_support_nested_variables = yes; then AM_V='$(V)' AM_DEFAULT_V='$(AM_DEFAULT_VERBOSITY)' else AM_V=$AM_DEFAULT_VERBOSITY AM_DEFAULT_V=$AM_DEFAULT_VERBOSITY fi AM_BACKSLASH='\' if test "`cd $srcdir && pwd`" != "`pwd`"; then # Use -I$(srcdir) only when $(srcdir) != ., so that make's output # is not polluted with repeated "-I." am__isrc=' -I$(srcdir)' # test to see if srcdir already configured if test -f $srcdir/config.status; then as_fn_error $? "source directory already configured; run \"make distclean\" there first" "$LINENO" 5 fi fi # test whether we have cygpath if test -z "$CYGPATH_W"; then if (cygpath --version) >/dev/null 2>/dev/null; then CYGPATH_W='cygpath -w' else CYGPATH_W=echo fi fi # Define the identity of the package. PACKAGE='rfxcodec' VERSION='0.1.4' cat >>confdefs.h <<_ACEOF #define PACKAGE "$PACKAGE" _ACEOF cat >>confdefs.h <<_ACEOF #define VERSION "$VERSION" _ACEOF # Some tools Automake needs. ACLOCAL=${ACLOCAL-"${am_missing_run}aclocal-${am__api_version}"} AUTOCONF=${AUTOCONF-"${am_missing_run}autoconf"} AUTOMAKE=${AUTOMAKE-"${am_missing_run}automake-${am__api_version}"} AUTOHEADER=${AUTOHEADER-"${am_missing_run}autoheader"} MAKEINFO=${MAKEINFO-"${am_missing_run}makeinfo"} # For better backward compatibility. To be removed once Automake 1.9.x # dies out for good. For more background, see: # # mkdir_p='$(MKDIR_P)' # We need awk for the "check" target (and possibly the TAP driver). The # system "awk" is bad on some platforms. # Always define AMTAR for backward compatibility. Yes, it's still used # in the wild :-( We should find a proper way to deprecate it ... AMTAR='$${TAR-tar}' # We'll loop over all known methods to create a tar archive until one works. _am_tools='gnutar pax cpio none' am__tar='$${TAR-tar} chof - "$$tardir"' am__untar='$${TAR-tar} xf -' # POSIX will say in a future version that running "rm -f" with no argument # is OK; and we want to be able to make that assumption in our Makefile # recipes. So use an aggressive probe to check that the usage we want is # actually supported "in the wild" to an acceptable degree. # See automake bug#10828. # To make any issue more visible, cause the running configure to be aborted # by default if the 'rm' program in use doesn't match our expectations; the # user can still override this though. if rm -f && rm -fr && rm -rf; then : OK; else cat >&2 <<'END' Oops! Your 'rm' program seems unable to run without file operands specified on the command line, even when the '-f' option is present. This is contrary to the behaviour of most rm programs out there, and not conforming with the upcoming POSIX standard: Please tell bug-automake@gnu.org about your system, including the value of your $PATH and any error possibly output before this message. This can help us improve future automake versions. END if test x"$ACCEPT_INFERIOR_RM_PROGRAM" = x"yes"; then echo 'Configuration will proceed anyway, since you have set the' >&2 echo 'ACCEPT_INFERIOR_RM_PROGRAM variable to "yes"' >&2 echo >&2 else cat >&2 <<'END' Aborting the configuration process, to ensure you take notice of the issue. You can download and install GNU coreutils to get an 'rm' implementation that behaves properly: . If you want to complete the configuration process using your problematic 'rm' anyway, export the environment variable ACCEPT_INFERIOR_RM_PROGRAM to "yes", and re-run configure. END as_fn_error $? "Your 'rm' program is bad, sorry." "$LINENO" 5 fi fi # Check whether --enable-silent-rules was given. if test "${enable_silent_rules+set}" = set; then : enableval=$enable_silent_rules; fi case $enable_silent_rules in # ((( yes) AM_DEFAULT_VERBOSITY=0;; no) AM_DEFAULT_VERBOSITY=1;; *) AM_DEFAULT_VERBOSITY=0;; esac am_make=${MAKE-make} { $as_echo "$as_me:${as_lineno-$LINENO}: checking whether $am_make supports nested variables" >&5 $as_echo_n "checking whether $am_make supports nested variables... " >&6; } if ${am_cv_make_support_nested_variables+:} false; then : $as_echo_n "(cached) " >&6 else if $as_echo 'TRUE=$(BAR$(V)) BAR0=false BAR1=true V=1 am__doit: @$(TRUE) .PHONY: am__doit' | $am_make -f - >/dev/null 2>&1; then am_cv_make_support_nested_variables=yes else am_cv_make_support_nested_variables=no fi fi { $as_echo "$as_me:${as_lineno-$LINENO}: result: $am_cv_make_support_nested_variables" >&5 $as_echo "$am_cv_make_support_nested_variables" >&6; } if test $am_cv_make_support_nested_variables = yes; then AM_V='$(V)' AM_DEFAULT_V='$(AM_DEFAULT_VERBOSITY)' else AM_V=$AM_DEFAULT_VERBOSITY AM_DEFAULT_V=$AM_DEFAULT_VERBOSITY fi AM_BACKSLASH='\' ac_ext=c ac_cpp='$CPP $CPPFLAGS' ac_compile='$CC -c $CFLAGS $CPPFLAGS conftest.$ac_ext >&5' ac_link='$CC -o conftest$ac_exeext $CFLAGS $CPPFLAGS $LDFLAGS conftest.$ac_ext $LIBS >&5' ac_compiler_gnu=$ac_cv_c_compiler_gnu if test -n "$ac_tool_prefix"; then # Extract the first word of "${ac_tool_prefix}gcc", so it can be a program name with args. set dummy ${ac_tool_prefix}gcc; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } if ${ac_cv_prog_CC+:} false; then : $as_echo_n "(cached) " >&6 else if test -n "$CC"; then ac_cv_prog_CC="$CC" # Let the user override the test. else as_save_IFS=$IFS; IFS=$PATH_SEPARATOR for as_dir in $PATH do IFS=$as_save_IFS test -z "$as_dir" && as_dir=. for ac_exec_ext in '' $ac_executable_extensions; do if as_fn_executable_p "$as_dir/$ac_word$ac_exec_ext"; then ac_cv_prog_CC="${ac_tool_prefix}gcc" $as_echo "$as_me:${as_lineno-$LINENO}: found $as_dir/$ac_word$ac_exec_ext" >&5 break 2 fi done done IFS=$as_save_IFS fi fi CC=$ac_cv_prog_CC if test -n "$CC"; then { $as_echo "$as_me:${as_lineno-$LINENO}: result: $CC" >&5 $as_echo "$CC" >&6; } else { $as_echo "$as_me:${as_lineno-$LINENO}: result: no" >&5 $as_echo "no" >&6; } fi fi if test -z "$ac_cv_prog_CC"; then ac_ct_CC=$CC # Extract the first word of "gcc", so it can be a program name with args. set dummy gcc; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } if ${ac_cv_prog_ac_ct_CC+:} false; then : $as_echo_n "(cached) " >&6 else if test -n "$ac_ct_CC"; then ac_cv_prog_ac_ct_CC="$ac_ct_CC" # Let the user override the test. else as_save_IFS=$IFS; IFS=$PATH_SEPARATOR for as_dir in $PATH do IFS=$as_save_IFS test -z "$as_dir" && as_dir=. for ac_exec_ext in '' $ac_executable_extensions; do if as_fn_executable_p "$as_dir/$ac_word$ac_exec_ext"; then ac_cv_prog_ac_ct_CC="gcc" $as_echo "$as_me:${as_lineno-$LINENO}: found $as_dir/$ac_word$ac_exec_ext" >&5 break 2 fi done done IFS=$as_save_IFS fi fi ac_ct_CC=$ac_cv_prog_ac_ct_CC if test -n "$ac_ct_CC"; then { $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_ct_CC" >&5 $as_echo "$ac_ct_CC" >&6; } else { $as_echo "$as_me:${as_lineno-$LINENO}: result: no" >&5 $as_echo "no" >&6; } fi if test "x$ac_ct_CC" = x; then CC="" else case $cross_compiling:$ac_tool_warned in yes:) { $as_echo "$as_me:${as_lineno-$LINENO}: WARNING: using cross tools not prefixed with host triplet" >&5 $as_echo "$as_me: WARNING: using cross tools not prefixed with host triplet" >&2;} ac_tool_warned=yes ;; esac CC=$ac_ct_CC fi else CC="$ac_cv_prog_CC" fi if test -z "$CC"; then if test -n "$ac_tool_prefix"; then # Extract the first word of "${ac_tool_prefix}cc", so it can be a program name with args. set dummy ${ac_tool_prefix}cc; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } if ${ac_cv_prog_CC+:} false; then : $as_echo_n "(cached) " >&6 else if test -n "$CC"; then ac_cv_prog_CC="$CC" # Let the user override the test. else as_save_IFS=$IFS; IFS=$PATH_SEPARATOR for as_dir in $PATH do IFS=$as_save_IFS test -z "$as_dir" && as_dir=. for ac_exec_ext in '' $ac_executable_extensions; do if as_fn_executable_p "$as_dir/$ac_word$ac_exec_ext"; then ac_cv_prog_CC="${ac_tool_prefix}cc" $as_echo "$as_me:${as_lineno-$LINENO}: found $as_dir/$ac_word$ac_exec_ext" >&5 break 2 fi done done IFS=$as_save_IFS fi fi CC=$ac_cv_prog_CC if test -n "$CC"; then { $as_echo "$as_me:${as_lineno-$LINENO}: result: $CC" >&5 $as_echo "$CC" >&6; } else { $as_echo "$as_me:${as_lineno-$LINENO}: result: no" >&5 $as_echo "no" >&6; } fi fi fi if test -z "$CC"; then # Extract the first word of "cc", so it can be a program name with args. set dummy cc; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } if ${ac_cv_prog_CC+:} false; then : $as_echo_n "(cached) " >&6 else if test -n "$CC"; then ac_cv_prog_CC="$CC" # Let the user override the test. else ac_prog_rejected=no as_save_IFS=$IFS; IFS=$PATH_SEPARATOR for as_dir in $PATH do IFS=$as_save_IFS test -z "$as_dir" && as_dir=. for ac_exec_ext in '' $ac_executable_extensions; do if as_fn_executable_p "$as_dir/$ac_word$ac_exec_ext"; then if test "$as_dir/$ac_word$ac_exec_ext" = "/usr/ucb/cc"; then ac_prog_rejected=yes continue fi ac_cv_prog_CC="cc" $as_echo "$as_me:${as_lineno-$LINENO}: found $as_dir/$ac_word$ac_exec_ext" >&5 break 2 fi done done IFS=$as_save_IFS if test $ac_prog_rejected = yes; then # We found a bogon in the path, so make sure we never use it. set dummy $ac_cv_prog_CC shift if test $# != 0; then # We chose a different compiler from the bogus one. # However, it has the same basename, so the bogon will be chosen # first if we set CC to just the basename; use the full file name. shift ac_cv_prog_CC="$as_dir/$ac_word${1+' '}$@" fi fi fi fi CC=$ac_cv_prog_CC if test -n "$CC"; then { $as_echo "$as_me:${as_lineno-$LINENO}: result: $CC" >&5 $as_echo "$CC" >&6; } else { $as_echo "$as_me:${as_lineno-$LINENO}: result: no" >&5 $as_echo "no" >&6; } fi fi if test -z "$CC"; then if test -n "$ac_tool_prefix"; then for ac_prog in cl.exe do # Extract the first word of "$ac_tool_prefix$ac_prog", so it can be a program name with args. set dummy $ac_tool_prefix$ac_prog; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } if ${ac_cv_prog_CC+:} false; then : $as_echo_n "(cached) " >&6 else if test -n "$CC"; then ac_cv_prog_CC="$CC" # Let the user override the test. else as_save_IFS=$IFS; IFS=$PATH_SEPARATOR for as_dir in $PATH do IFS=$as_save_IFS test -z "$as_dir" && as_dir=. for ac_exec_ext in '' $ac_executable_extensions; do if as_fn_executable_p "$as_dir/$ac_word$ac_exec_ext"; then ac_cv_prog_CC="$ac_tool_prefix$ac_prog" $as_echo "$as_me:${as_lineno-$LINENO}: found $as_dir/$ac_word$ac_exec_ext" >&5 break 2 fi done done IFS=$as_save_IFS fi fi CC=$ac_cv_prog_CC if test -n "$CC"; then { $as_echo "$as_me:${as_lineno-$LINENO}: result: $CC" >&5 $as_echo "$CC" >&6; } else { $as_echo "$as_me:${as_lineno-$LINENO}: result: no" >&5 $as_echo "no" >&6; } fi test -n "$CC" && break done fi if test -z "$CC"; then ac_ct_CC=$CC for ac_prog in cl.exe do # Extract the first word of "$ac_prog", so it can be a program name with args. set dummy $ac_prog; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } if ${ac_cv_prog_ac_ct_CC+:} false; then : $as_echo_n "(cached) " >&6 else if test -n "$ac_ct_CC"; then ac_cv_prog_ac_ct_CC="$ac_ct_CC" # Let the user override the test. else as_save_IFS=$IFS; IFS=$PATH_SEPARATOR for as_dir in $PATH do IFS=$as_save_IFS test -z "$as_dir" && as_dir=. for ac_exec_ext in '' $ac_executable_extensions; do if as_fn_executable_p "$as_dir/$ac_word$ac_exec_ext"; then ac_cv_prog_ac_ct_CC="$ac_prog" $as_echo "$as_me:${as_lineno-$LINENO}: found $as_dir/$ac_word$ac_exec_ext" >&5 break 2 fi done done IFS=$as_save_IFS fi fi ac_ct_CC=$ac_cv_prog_ac_ct_CC if test -n "$ac_ct_CC"; then { $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_ct_CC" >&5 $as_echo "$ac_ct_CC" >&6; } else { $as_echo "$as_me:${as_lineno-$LINENO}: result: no" >&5 $as_echo "no" >&6; } fi test -n "$ac_ct_CC" && break done if test "x$ac_ct_CC" = x; then CC="" else case $cross_compiling:$ac_tool_warned in yes:) { $as_echo "$as_me:${as_lineno-$LINENO}: WARNING: using cross tools not prefixed with host triplet" >&5 $as_echo "$as_me: WARNING: using cross tools not prefixed with host triplet" >&2;} ac_tool_warned=yes ;; esac CC=$ac_ct_CC fi fi fi test -z "$CC" && { { $as_echo "$as_me:${as_lineno-$LINENO}: error: in \`$ac_pwd':" >&5 $as_echo "$as_me: error: in \`$ac_pwd':" >&2;} as_fn_error $? "no acceptable C compiler found in \$PATH See \`config.log' for more details" "$LINENO" 5; } # Provide some information about the compiler. $as_echo "$as_me:${as_lineno-$LINENO}: checking for C compiler version" >&5 set X $ac_compile ac_compiler=$2 for ac_option in --version -v -V -qversion; do { { ac_try="$ac_compiler $ac_option >&5" case "(($ac_try" in *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; *) ac_try_echo=$ac_try;; esac eval ac_try_echo="\"\$as_me:${as_lineno-$LINENO}: $ac_try_echo\"" $as_echo "$ac_try_echo"; } >&5 (eval "$ac_compiler $ac_option >&5") 2>conftest.err ac_status=$? if test -s conftest.err; then sed '10a\ ... rest of stderr output deleted ... 10q' conftest.err >conftest.er1 cat conftest.er1 >&5 fi rm -f conftest.er1 conftest.err $as_echo "$as_me:${as_lineno-$LINENO}: \$? = $ac_status" >&5 test $ac_status = 0; } done cat confdefs.h - <<_ACEOF >conftest.$ac_ext /* end confdefs.h. */ int main () { ; return 0; } _ACEOF ac_clean_files_save=$ac_clean_files ac_clean_files="$ac_clean_files a.out a.out.dSYM a.exe b.out" # Try to create an executable without -o first, disregard a.out. # It will help us diagnose broken compilers, and finding out an intuition # of exeext. { $as_echo "$as_me:${as_lineno-$LINENO}: checking whether the C compiler works" >&5 $as_echo_n "checking whether the C compiler works... " >&6; } ac_link_default=`$as_echo "$ac_link" | sed 's/ -o *conftest[^ ]*//'` # The possible output files: ac_files="a.out conftest.exe conftest a.exe a_out.exe b.out conftest.*" ac_rmfiles= for ac_file in $ac_files do case $ac_file in *.$ac_ext | *.xcoff | *.tds | *.d | *.pdb | *.xSYM | *.bb | *.bbg | *.map | *.inf | *.dSYM | *.o | *.obj ) ;; * ) ac_rmfiles="$ac_rmfiles $ac_file";; esac done rm -f $ac_rmfiles if { { ac_try="$ac_link_default" case "(($ac_try" in *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; *) ac_try_echo=$ac_try;; esac eval ac_try_echo="\"\$as_me:${as_lineno-$LINENO}: $ac_try_echo\"" $as_echo "$ac_try_echo"; } >&5 (eval "$ac_link_default") 2>&5 ac_status=$? $as_echo "$as_me:${as_lineno-$LINENO}: \$? = $ac_status" >&5 test $ac_status = 0; }; then : # Autoconf-2.13 could set the ac_cv_exeext variable to `no'. # So ignore a value of `no', otherwise this would lead to `EXEEXT = no' # in a Makefile. We should not override ac_cv_exeext if it was cached, # so that the user can short-circuit this test for compilers unknown to # Autoconf. for ac_file in $ac_files '' do test -f "$ac_file" || continue case $ac_file in *.$ac_ext | *.xcoff | *.tds | *.d | *.pdb | *.xSYM | *.bb | *.bbg | *.map | *.inf | *.dSYM | *.o | *.obj ) ;; [ab].out ) # We found the default executable, but exeext='' is most # certainly right. break;; *.* ) if test "${ac_cv_exeext+set}" = set && test "$ac_cv_exeext" != no; then :; else ac_cv_exeext=`expr "$ac_file" : '[^.]*\(\..*\)'` fi # We set ac_cv_exeext here because the later test for it is not # safe: cross compilers may not add the suffix if given an `-o' # argument, so we may need to know it at that point already. # Even if this section looks crufty: it has the advantage of # actually working. break;; * ) break;; esac done test "$ac_cv_exeext" = no && ac_cv_exeext= else ac_file='' fi if test -z "$ac_file"; then : { $as_echo "$as_me:${as_lineno-$LINENO}: result: no" >&5 $as_echo "no" >&6; } $as_echo "$as_me: failed program was:" >&5 sed 's/^/| /' conftest.$ac_ext >&5 { { $as_echo "$as_me:${as_lineno-$LINENO}: error: in \`$ac_pwd':" >&5 $as_echo "$as_me: error: in \`$ac_pwd':" >&2;} as_fn_error 77 "C compiler cannot create executables See \`config.log' for more details" "$LINENO" 5; } else { $as_echo "$as_me:${as_lineno-$LINENO}: result: yes" >&5 $as_echo "yes" >&6; } fi { $as_echo "$as_me:${as_lineno-$LINENO}: checking for C compiler default output file name" >&5 $as_echo_n "checking for C compiler default output file name... " >&6; } { $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_file" >&5 $as_echo "$ac_file" >&6; } ac_exeext=$ac_cv_exeext rm -f -r a.out a.out.dSYM a.exe conftest$ac_cv_exeext b.out ac_clean_files=$ac_clean_files_save { $as_echo "$as_me:${as_lineno-$LINENO}: checking for suffix of executables" >&5 $as_echo_n "checking for suffix of executables... " >&6; } if { { ac_try="$ac_link" case "(($ac_try" in *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; *) ac_try_echo=$ac_try;; esac eval ac_try_echo="\"\$as_me:${as_lineno-$LINENO}: $ac_try_echo\"" $as_echo "$ac_try_echo"; } >&5 (eval "$ac_link") 2>&5 ac_status=$? $as_echo "$as_me:${as_lineno-$LINENO}: \$? = $ac_status" >&5 test $ac_status = 0; }; then : # If both `conftest.exe' and `conftest' are `present' (well, observable) # catch `conftest.exe'. For instance with Cygwin, `ls conftest' will # work properly (i.e., refer to `conftest.exe'), while it won't with # `rm'. for ac_file in conftest.exe conftest conftest.*; do test -f "$ac_file" || continue case $ac_file in *.$ac_ext | *.xcoff | *.tds | *.d | *.pdb | *.xSYM | *.bb | *.bbg | *.map | *.inf | *.dSYM | *.o | *.obj ) ;; *.* ) ac_cv_exeext=`expr "$ac_file" : '[^.]*\(\..*\)'` break;; * ) break;; esac done else { { $as_echo "$as_me:${as_lineno-$LINENO}: error: in \`$ac_pwd':" >&5 $as_echo "$as_me: error: in \`$ac_pwd':" >&2;} as_fn_error $? "cannot compute suffix of executables: cannot compile and link See \`config.log' for more details" "$LINENO" 5; } fi rm -f conftest conftest$ac_cv_exeext { $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_cv_exeext" >&5 $as_echo "$ac_cv_exeext" >&6; } rm -f conftest.$ac_ext EXEEXT=$ac_cv_exeext ac_exeext=$EXEEXT cat confdefs.h - <<_ACEOF >conftest.$ac_ext /* end confdefs.h. */ #include int main () { FILE *f = fopen ("conftest.out", "w"); return ferror (f) || fclose (f) != 0; ; return 0; } _ACEOF ac_clean_files="$ac_clean_files conftest.out" # Check that the compiler produces executables we can run. If not, either # the compiler is broken, or we cross compile. { $as_echo "$as_me:${as_lineno-$LINENO}: checking whether we are cross compiling" >&5 $as_echo_n "checking whether we are cross compiling... " >&6; } if test "$cross_compiling" != yes; then { { ac_try="$ac_link" case "(($ac_try" in *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; *) ac_try_echo=$ac_try;; esac eval ac_try_echo="\"\$as_me:${as_lineno-$LINENO}: $ac_try_echo\"" $as_echo "$ac_try_echo"; } >&5 (eval "$ac_link") 2>&5 ac_status=$? $as_echo "$as_me:${as_lineno-$LINENO}: \$? = $ac_status" >&5 test $ac_status = 0; } if { ac_try='./conftest$ac_cv_exeext' { { case "(($ac_try" in *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; *) ac_try_echo=$ac_try;; esac eval ac_try_echo="\"\$as_me:${as_lineno-$LINENO}: $ac_try_echo\"" $as_echo "$ac_try_echo"; } >&5 (eval "$ac_try") 2>&5 ac_status=$? $as_echo "$as_me:${as_lineno-$LINENO}: \$? = $ac_status" >&5 test $ac_status = 0; }; }; then cross_compiling=no else if test "$cross_compiling" = maybe; then cross_compiling=yes else { { $as_echo "$as_me:${as_lineno-$LINENO}: error: in \`$ac_pwd':" >&5 $as_echo "$as_me: error: in \`$ac_pwd':" >&2;} as_fn_error $? "cannot run C compiled programs. If you meant to cross compile, use \`--host'. See \`config.log' for more details" "$LINENO" 5; } fi fi fi { $as_echo "$as_me:${as_lineno-$LINENO}: result: $cross_compiling" >&5 $as_echo "$cross_compiling" >&6; } rm -f conftest.$ac_ext conftest$ac_cv_exeext conftest.out ac_clean_files=$ac_clean_files_save { $as_echo "$as_me:${as_lineno-$LINENO}: checking for suffix of object files" >&5 $as_echo_n "checking for suffix of object files... " >&6; } if ${ac_cv_objext+:} false; then : $as_echo_n "(cached) " >&6 else cat confdefs.h - <<_ACEOF >conftest.$ac_ext /* end confdefs.h. */ int main () { ; return 0; } _ACEOF rm -f conftest.o conftest.obj if { { ac_try="$ac_compile" case "(($ac_try" in *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; *) ac_try_echo=$ac_try;; esac eval ac_try_echo="\"\$as_me:${as_lineno-$LINENO}: $ac_try_echo\"" $as_echo "$ac_try_echo"; } >&5 (eval "$ac_compile") 2>&5 ac_status=$? $as_echo "$as_me:${as_lineno-$LINENO}: \$? = $ac_status" >&5 test $ac_status = 0; }; then : for ac_file in conftest.o conftest.obj conftest.*; do test -f "$ac_file" || continue; case $ac_file in *.$ac_ext | *.xcoff | *.tds | *.d | *.pdb | *.xSYM | *.bb | *.bbg | *.map | *.inf | *.dSYM ) ;; *) ac_cv_objext=`expr "$ac_file" : '.*\.\(.*\)'` break;; esac done else $as_echo "$as_me: failed program was:" >&5 sed 's/^/| /' conftest.$ac_ext >&5 { { $as_echo "$as_me:${as_lineno-$LINENO}: error: in \`$ac_pwd':" >&5 $as_echo "$as_me: error: in \`$ac_pwd':" >&2;} as_fn_error $? "cannot compute suffix of object files: cannot compile See \`config.log' for more details" "$LINENO" 5; } fi rm -f conftest.$ac_cv_objext conftest.$ac_ext fi { $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_cv_objext" >&5 $as_echo "$ac_cv_objext" >&6; } OBJEXT=$ac_cv_objext ac_objext=$OBJEXT { $as_echo "$as_me:${as_lineno-$LINENO}: checking whether we are using the GNU C compiler" >&5 $as_echo_n "checking whether we are using the GNU C compiler... " >&6; } if ${ac_cv_c_compiler_gnu+:} false; then : $as_echo_n "(cached) " >&6 else cat confdefs.h - <<_ACEOF >conftest.$ac_ext /* end confdefs.h. */ int main () { #ifndef __GNUC__ choke me #endif ; return 0; } _ACEOF if ac_fn_c_try_compile "$LINENO"; then : ac_compiler_gnu=yes else ac_compiler_gnu=no fi rm -f core conftest.err conftest.$ac_objext conftest.$ac_ext ac_cv_c_compiler_gnu=$ac_compiler_gnu fi { $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_cv_c_compiler_gnu" >&5 $as_echo "$ac_cv_c_compiler_gnu" >&6; } if test $ac_compiler_gnu = yes; then GCC=yes else GCC= fi ac_test_CFLAGS=${CFLAGS+set} ac_save_CFLAGS=$CFLAGS { $as_echo "$as_me:${as_lineno-$LINENO}: checking whether $CC accepts -g" >&5 $as_echo_n "checking whether $CC accepts -g... " >&6; } if ${ac_cv_prog_cc_g+:} false; then : $as_echo_n "(cached) " >&6 else ac_save_c_werror_flag=$ac_c_werror_flag ac_c_werror_flag=yes ac_cv_prog_cc_g=no CFLAGS="-g" cat confdefs.h - <<_ACEOF >conftest.$ac_ext /* end confdefs.h. */ int main () { ; return 0; } _ACEOF if ac_fn_c_try_compile "$LINENO"; then : ac_cv_prog_cc_g=yes else CFLAGS="" cat confdefs.h - <<_ACEOF >conftest.$ac_ext /* end confdefs.h. */ int main () { ; return 0; } _ACEOF if ac_fn_c_try_compile "$LINENO"; then : else ac_c_werror_flag=$ac_save_c_werror_flag CFLAGS="-g" cat confdefs.h - <<_ACEOF >conftest.$ac_ext /* end confdefs.h. */ int main () { ; return 0; } _ACEOF if ac_fn_c_try_compile "$LINENO"; then : ac_cv_prog_cc_g=yes fi rm -f core conftest.err conftest.$ac_objext conftest.$ac_ext fi rm -f core conftest.err conftest.$ac_objext conftest.$ac_ext fi rm -f core conftest.err conftest.$ac_objext conftest.$ac_ext ac_c_werror_flag=$ac_save_c_werror_flag fi { $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_cv_prog_cc_g" >&5 $as_echo "$ac_cv_prog_cc_g" >&6; } if test "$ac_test_CFLAGS" = set; then CFLAGS=$ac_save_CFLAGS elif test $ac_cv_prog_cc_g = yes; then if test "$GCC" = yes; then CFLAGS="-g -O2" else CFLAGS="-g" fi else if test "$GCC" = yes; then CFLAGS="-O2" else CFLAGS= fi fi { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $CC option to accept ISO C89" >&5 $as_echo_n "checking for $CC option to accept ISO C89... " >&6; } if ${ac_cv_prog_cc_c89+:} false; then : $as_echo_n "(cached) " >&6 else ac_cv_prog_cc_c89=no ac_save_CC=$CC cat confdefs.h - <<_ACEOF >conftest.$ac_ext /* end confdefs.h. */ #include #include struct stat; /* Most of the following tests are stolen from RCS 5.7's src/conf.sh. */ struct buf { int x; }; FILE * (*rcsopen) (struct buf *, struct stat *, int); static char *e (p, i) char **p; int i; { return p[i]; } static char *f (char * (*g) (char **, int), char **p, ...) { char *s; va_list v; va_start (v,p); s = g (p, va_arg (v,int)); va_end (v); return s; } /* OSF 4.0 Compaq cc is some sort of almost-ANSI by default. It has function prototypes and stuff, but not '\xHH' hex character constants. These don't provoke an error unfortunately, instead are silently treated as 'x'. The following induces an error, until -std is added to get proper ANSI mode. Curiously '\x00'!='x' always comes out true, for an array size at least. It's necessary to write '\x00'==0 to get something that's true only with -std. */ int osf4_cc_array ['\x00' == 0 ? 1 : -1]; /* IBM C 6 for AIX is almost-ANSI by default, but it replaces macro parameters inside strings and character constants. */ #define FOO(x) 'x' int xlc6_cc_array[FOO(a) == 'x' ? 1 : -1]; int test (int i, double x); struct s1 {int (*f) (int a);}; struct s2 {int (*f) (double a);}; int pairnames (int, char **, FILE *(*)(struct buf *, struct stat *, int), int, int); int argc; char **argv; int main () { return f (e, argv, 0) != argv[0] || f (e, argv, 1) != argv[1]; ; return 0; } _ACEOF for ac_arg in '' -qlanglvl=extc89 -qlanglvl=ansi -std \ -Ae "-Aa -D_HPUX_SOURCE" "-Xc -D__EXTENSIONS__" do CC="$ac_save_CC $ac_arg" if ac_fn_c_try_compile "$LINENO"; then : ac_cv_prog_cc_c89=$ac_arg fi rm -f core conftest.err conftest.$ac_objext test "x$ac_cv_prog_cc_c89" != "xno" && break done rm -f conftest.$ac_ext CC=$ac_save_CC fi # AC_CACHE_VAL case "x$ac_cv_prog_cc_c89" in x) { $as_echo "$as_me:${as_lineno-$LINENO}: result: none needed" >&5 $as_echo "none needed" >&6; } ;; xno) { $as_echo "$as_me:${as_lineno-$LINENO}: result: unsupported" >&5 $as_echo "unsupported" >&6; } ;; *) CC="$CC $ac_cv_prog_cc_c89" { $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_cv_prog_cc_c89" >&5 $as_echo "$ac_cv_prog_cc_c89" >&6; } ;; esac if test "x$ac_cv_prog_cc_c89" != xno; then : fi ac_ext=c ac_cpp='$CPP $CPPFLAGS' ac_compile='$CC -c $CFLAGS $CPPFLAGS conftest.$ac_ext >&5' ac_link='$CC -o conftest$ac_exeext $CFLAGS $CPPFLAGS $LDFLAGS conftest.$ac_ext $LIBS >&5' ac_compiler_gnu=$ac_cv_c_compiler_gnu ac_ext=c ac_cpp='$CPP $CPPFLAGS' ac_compile='$CC -c $CFLAGS $CPPFLAGS conftest.$ac_ext >&5' ac_link='$CC -o conftest$ac_exeext $CFLAGS $CPPFLAGS $LDFLAGS conftest.$ac_ext $LIBS >&5' ac_compiler_gnu=$ac_cv_c_compiler_gnu { $as_echo "$as_me:${as_lineno-$LINENO}: checking whether $CC understands -c and -o together" >&5 $as_echo_n "checking whether $CC understands -c and -o together... " >&6; } if ${am_cv_prog_cc_c_o+:} false; then : $as_echo_n "(cached) " >&6 else cat confdefs.h - <<_ACEOF >conftest.$ac_ext /* end confdefs.h. */ int main () { ; return 0; } _ACEOF # Make sure it works both with $CC and with simple cc. # Following AC_PROG_CC_C_O, we do the test twice because some # compilers refuse to overwrite an existing .o file with -o, # though they will create one. am_cv_prog_cc_c_o=yes for am_i in 1 2; do if { echo "$as_me:$LINENO: $CC -c conftest.$ac_ext -o conftest2.$ac_objext" >&5 ($CC -c conftest.$ac_ext -o conftest2.$ac_objext) >&5 2>&5 ac_status=$? echo "$as_me:$LINENO: \$? = $ac_status" >&5 (exit $ac_status); } \ && test -f conftest2.$ac_objext; then : OK else am_cv_prog_cc_c_o=no break fi done rm -f core conftest* unset am_i fi { $as_echo "$as_me:${as_lineno-$LINENO}: result: $am_cv_prog_cc_c_o" >&5 $as_echo "$am_cv_prog_cc_c_o" >&6; } if test "$am_cv_prog_cc_c_o" != yes; then # Losing compiler, so override with the script. # FIXME: It is wrong to rewrite CC. # But if we don't then we get into trouble of one sort or another. # A longer-term fix would be to have automake use am__CC in this case, # and then we could set am__CC="\$(top_srcdir)/compile \$(CC)" CC="$am_aux_dir/compile $CC" fi ac_ext=c ac_cpp='$CPP $CPPFLAGS' ac_compile='$CC -c $CFLAGS $CPPFLAGS conftest.$ac_ext >&5' ac_link='$CC -o conftest$ac_exeext $CFLAGS $CPPFLAGS $LDFLAGS conftest.$ac_ext $LIBS >&5' ac_compiler_gnu=$ac_cv_c_compiler_gnu DEPDIR="${am__leading_dot}deps" ac_config_commands="$ac_config_commands depfiles" am_make=${MAKE-make} cat > confinc << 'END' am__doit: @echo this is the am__doit target .PHONY: am__doit END # If we don't find an include directive, just comment out the code. { $as_echo "$as_me:${as_lineno-$LINENO}: checking for style of include used by $am_make" >&5 $as_echo_n "checking for style of include used by $am_make... " >&6; } am__include="#" am__quote= _am_result=none # First try GNU make style include. echo "include confinc" > confmf # Ignore all kinds of additional output from 'make'. case `$am_make -s -f confmf 2> /dev/null` in #( *the\ am__doit\ target*) am__include=include am__quote= _am_result=GNU ;; esac # Now try BSD make style include. if test "$am__include" = "#"; then echo '.include "confinc"' > confmf case `$am_make -s -f confmf 2> /dev/null` in #( *the\ am__doit\ target*) am__include=.include am__quote="\"" _am_result=BSD ;; esac fi { $as_echo "$as_me:${as_lineno-$LINENO}: result: $_am_result" >&5 $as_echo "$_am_result" >&6; } rm -f confinc confmf # Check whether --enable-dependency-tracking was given. if test "${enable_dependency_tracking+set}" = set; then : enableval=$enable_dependency_tracking; fi if test "x$enable_dependency_tracking" != xno; then am_depcomp="$ac_aux_dir/depcomp" AMDEPBACKSLASH='\' am__nodep='_no' fi if test "x$enable_dependency_tracking" != xno; then AMDEP_TRUE= AMDEP_FALSE='#' else AMDEP_TRUE='#' AMDEP_FALSE= fi depcc="$CC" am_compiler_list= { $as_echo "$as_me:${as_lineno-$LINENO}: checking dependency style of $depcc" >&5 $as_echo_n "checking dependency style of $depcc... " >&6; } if ${am_cv_CC_dependencies_compiler_type+:} false; then : $as_echo_n "(cached) " >&6 else if test -z "$AMDEP_TRUE" && test -f "$am_depcomp"; then # We make a subdir and do the tests there. Otherwise we can end up # making bogus files that we don't know about and never remove. For # instance it was reported that on HP-UX the gcc test will end up # making a dummy file named 'D' -- because '-MD' means "put the output # in D". rm -rf conftest.dir mkdir conftest.dir # Copy depcomp to subdir because otherwise we won't find it if we're # using a relative directory. cp "$am_depcomp" conftest.dir cd conftest.dir # We will build objects and dependencies in a subdirectory because # it helps to detect inapplicable dependency modes. For instance # both Tru64's cc and ICC support -MD to output dependencies as a # side effect of compilation, but ICC will put the dependencies in # the current directory while Tru64 will put them in the object # directory. mkdir sub am_cv_CC_dependencies_compiler_type=none if test "$am_compiler_list" = ""; then am_compiler_list=`sed -n 's/^#*\([a-zA-Z0-9]*\))$/\1/p' < ./depcomp` fi am__universal=false case " $depcc " in #( *\ -arch\ *\ -arch\ *) am__universal=true ;; esac for depmode in $am_compiler_list; do # Setup a source with many dependencies, because some compilers # like to wrap large dependency lists on column 80 (with \), and # we should not choose a depcomp mode which is confused by this. # # We need to recreate these files for each test, as the compiler may # overwrite some of them when testing with obscure command lines. # This happens at least with the AIX C compiler. : > sub/conftest.c for i in 1 2 3 4 5 6; do echo '#include "conftst'$i'.h"' >> sub/conftest.c # Using ": > sub/conftst$i.h" creates only sub/conftst1.h with # Solaris 10 /bin/sh. echo '/* dummy */' > sub/conftst$i.h done echo "${am__include} ${am__quote}sub/conftest.Po${am__quote}" > confmf # We check with '-c' and '-o' for the sake of the "dashmstdout" # mode. It turns out that the SunPro C++ compiler does not properly # handle '-M -o', and we need to detect this. Also, some Intel # versions had trouble with output in subdirs. am__obj=sub/conftest.${OBJEXT-o} am__minus_obj="-o $am__obj" case $depmode in gcc) # This depmode causes a compiler race in universal mode. test "$am__universal" = false || continue ;; nosideeffect) # After this tag, mechanisms are not by side-effect, so they'll # only be used when explicitly requested. if test "x$enable_dependency_tracking" = xyes; then continue else break fi ;; msvc7 | msvc7msys | msvisualcpp | msvcmsys) # This compiler won't grok '-c -o', but also, the minuso test has # not run yet. These depmodes are late enough in the game, and # so weak that their functioning should not be impacted. am__obj=conftest.${OBJEXT-o} am__minus_obj= ;; none) break ;; esac if depmode=$depmode \ source=sub/conftest.c object=$am__obj \ depfile=sub/conftest.Po tmpdepfile=sub/conftest.TPo \ $SHELL ./depcomp $depcc -c $am__minus_obj sub/conftest.c \ >/dev/null 2>conftest.err && grep sub/conftst1.h sub/conftest.Po > /dev/null 2>&1 && grep sub/conftst6.h sub/conftest.Po > /dev/null 2>&1 && grep $am__obj sub/conftest.Po > /dev/null 2>&1 && ${MAKE-make} -s -f confmf > /dev/null 2>&1; then # icc doesn't choke on unknown options, it will just issue warnings # or remarks (even with -Werror). So we grep stderr for any message # that says an option was ignored or not supported. # When given -MP, icc 7.0 and 7.1 complain thusly: # icc: Command line warning: ignoring option '-M'; no argument required # The diagnosis changed in icc 8.0: # icc: Command line remark: option '-MP' not supported if (grep 'ignoring option' conftest.err || grep 'not supported' conftest.err) >/dev/null 2>&1; then :; else am_cv_CC_dependencies_compiler_type=$depmode break fi fi done cd .. rm -rf conftest.dir else am_cv_CC_dependencies_compiler_type=none fi fi { $as_echo "$as_me:${as_lineno-$LINENO}: result: $am_cv_CC_dependencies_compiler_type" >&5 $as_echo "$am_cv_CC_dependencies_compiler_type" >&6; } CCDEPMODE=depmode=$am_cv_CC_dependencies_compiler_type if test "x$enable_dependency_tracking" != xno \ && test "$am_cv_CC_dependencies_compiler_type" = gcc3; then am__fastdepCC_TRUE= am__fastdepCC_FALSE='#' else am__fastdepCC_TRUE='#' am__fastdepCC_FALSE= fi { $as_echo "$as_me:${as_lineno-$LINENO}: checking for an ANSI C-conforming const" >&5 $as_echo_n "checking for an ANSI C-conforming const... " >&6; } if ${ac_cv_c_const+:} false; then : $as_echo_n "(cached) " >&6 else cat confdefs.h - <<_ACEOF >conftest.$ac_ext /* end confdefs.h. */ int main () { #ifndef __cplusplus /* Ultrix mips cc rejects this sort of thing. */ typedef int charset[2]; const charset cs = { 0, 0 }; /* SunOS 4.1.1 cc rejects this. */ char const *const *pcpcc; char **ppc; /* NEC SVR4.0.2 mips cc rejects this. */ struct point {int x, y;}; static struct point const zero = {0,0}; /* AIX XL C 1.02.0.0 rejects this. It does not let you subtract one const X* pointer from another in an arm of an if-expression whose if-part is not a constant expression */ const char *g = "string"; pcpcc = &g + (g ? g-g : 0); /* HPUX 7.0 cc rejects these. */ ++pcpcc; ppc = (char**) pcpcc; pcpcc = (char const *const *) ppc; { /* SCO 3.2v4 cc rejects this sort of thing. */ char tx; char *t = &tx; char const *s = 0 ? (char *) 0 : (char const *) 0; *t++ = 0; if (s) return 0; } { /* Someone thinks the Sun supposedly-ANSI compiler will reject this. */ int x[] = {25, 17}; const int *foo = &x[0]; ++foo; } { /* Sun SC1.0 ANSI compiler rejects this -- but not the above. */ typedef const int *iptr; iptr p = 0; ++p; } { /* AIX XL C 1.02.0.0 rejects this sort of thing, saying "k.c", line 2.27: 1506-025 (S) Operand must be a modifiable lvalue. */ struct s { int j; const int *ap[3]; } bx; struct s *b = &bx; b->j = 5; } { /* ULTRIX-32 V3.1 (Rev 9) vcc rejects this */ const int foo = 10; if (!foo) return 0; } return !cs[0] && !zero.x; #endif ; return 0; } _ACEOF if ac_fn_c_try_compile "$LINENO"; then : ac_cv_c_const=yes else ac_cv_c_const=no fi rm -f core conftest.err conftest.$ac_objext conftest.$ac_ext fi { $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_cv_c_const" >&5 $as_echo "$ac_cv_c_const" >&6; } if test $ac_cv_c_const = no; then $as_echo "#define const /**/" >>confdefs.h fi case `pwd` in *\ * | *\ *) { $as_echo "$as_me:${as_lineno-$LINENO}: WARNING: Libtool does not cope well with whitespace in \`pwd\`" >&5 $as_echo "$as_me: WARNING: Libtool does not cope well with whitespace in \`pwd\`" >&2;} ;; esac macro_version='2.4.6' macro_revision='2.4.6' ltmain=$ac_aux_dir/ltmain.sh # Make sure we can run config.sub. $SHELL "$ac_aux_dir/config.sub" sun4 >/dev/null 2>&1 || as_fn_error $? "cannot run $SHELL $ac_aux_dir/config.sub" "$LINENO" 5 { $as_echo "$as_me:${as_lineno-$LINENO}: checking build system type" >&5 $as_echo_n "checking build system type... " >&6; } if ${ac_cv_build+:} false; then : $as_echo_n "(cached) " >&6 else ac_build_alias=$build_alias test "x$ac_build_alias" = x && ac_build_alias=`$SHELL "$ac_aux_dir/config.guess"` test "x$ac_build_alias" = x && as_fn_error $? "cannot guess build type; you must specify one" "$LINENO" 5 ac_cv_build=`$SHELL "$ac_aux_dir/config.sub" $ac_build_alias` || as_fn_error $? "$SHELL $ac_aux_dir/config.sub $ac_build_alias failed" "$LINENO" 5 fi { $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_cv_build" >&5 $as_echo "$ac_cv_build" >&6; } case $ac_cv_build in *-*-*) ;; *) as_fn_error $? "invalid value of canonical build" "$LINENO" 5;; esac build=$ac_cv_build ac_save_IFS=$IFS; IFS='-' set x $ac_cv_build shift build_cpu=$1 build_vendor=$2 shift; shift # Remember, the first character of IFS is used to create $*, # except with old shells: build_os=$* IFS=$ac_save_IFS case $build_os in *\ *) build_os=`echo "$build_os" | sed 's/ /-/g'`;; esac { $as_echo "$as_me:${as_lineno-$LINENO}: checking host system type" >&5 $as_echo_n "checking host system type... " >&6; } if ${ac_cv_host+:} false; then : $as_echo_n "(cached) " >&6 else if test "x$host_alias" = x; then ac_cv_host=$ac_cv_build else ac_cv_host=`$SHELL "$ac_aux_dir/config.sub" $host_alias` || as_fn_error $? "$SHELL $ac_aux_dir/config.sub $host_alias failed" "$LINENO" 5 fi fi { $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_cv_host" >&5 $as_echo "$ac_cv_host" >&6; } case $ac_cv_host in *-*-*) ;; *) as_fn_error $? "invalid value of canonical host" "$LINENO" 5;; esac host=$ac_cv_host ac_save_IFS=$IFS; IFS='-' set x $ac_cv_host shift host_cpu=$1 host_vendor=$2 shift; shift # Remember, the first character of IFS is used to create $*, # except with old shells: host_os=$* IFS=$ac_save_IFS case $host_os in *\ *) host_os=`echo "$host_os" | sed 's/ /-/g'`;; esac # Backslashify metacharacters that are still active within # double-quoted strings. sed_quote_subst='s/\(["`$\\]\)/\\\1/g' # Same as above, but do not quote variable references. double_quote_subst='s/\(["`\\]\)/\\\1/g' # Sed substitution to delay expansion of an escaped shell variable in a # double_quote_subst'ed string. delay_variable_subst='s/\\\\\\\\\\\$/\\\\\\$/g' # Sed substitution to delay expansion of an escaped single quote. delay_single_quote_subst='s/'\''/'\'\\\\\\\'\''/g' # Sed substitution to avoid accidental globbing in evaled expressions no_glob_subst='s/\*/\\\*/g' ECHO='\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\' ECHO=$ECHO$ECHO$ECHO$ECHO$ECHO ECHO=$ECHO$ECHO$ECHO$ECHO$ECHO$ECHO { $as_echo "$as_me:${as_lineno-$LINENO}: checking how to print strings" >&5 $as_echo_n "checking how to print strings... " >&6; } # Test print first, because it will be a builtin if present. if test "X`( print -r -- -n ) 2>/dev/null`" = X-n && \ test "X`print -r -- $ECHO 2>/dev/null`" = "X$ECHO"; then ECHO='print -r --' elif test "X`printf %s $ECHO 2>/dev/null`" = "X$ECHO"; then ECHO='printf %s\n' else # Use this function as a fallback that always works. func_fallback_echo () { eval 'cat <<_LTECHO_EOF $1 _LTECHO_EOF' } ECHO='func_fallback_echo' fi # func_echo_all arg... # Invoke $ECHO with all args, space-separated. func_echo_all () { $ECHO "" } case $ECHO in printf*) { $as_echo "$as_me:${as_lineno-$LINENO}: result: printf" >&5 $as_echo "printf" >&6; } ;; print*) { $as_echo "$as_me:${as_lineno-$LINENO}: result: print -r" >&5 $as_echo "print -r" >&6; } ;; *) { $as_echo "$as_me:${as_lineno-$LINENO}: result: cat" >&5 $as_echo "cat" >&6; } ;; esac { $as_echo "$as_me:${as_lineno-$LINENO}: checking for a sed that does not truncate output" >&5 $as_echo_n "checking for a sed that does not truncate output... " >&6; } if ${ac_cv_path_SED+:} false; then : $as_echo_n "(cached) " >&6 else ac_script=s/aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa/bbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbb/ for ac_i in 1 2 3 4 5 6 7; do ac_script="$ac_script$as_nl$ac_script" done echo "$ac_script" 2>/dev/null | sed 99q >conftest.sed { ac_script=; unset ac_script;} if test -z "$SED"; then ac_path_SED_found=false # Loop through the user's path and test for each of PROGNAME-LIST as_save_IFS=$IFS; IFS=$PATH_SEPARATOR for as_dir in $PATH do IFS=$as_save_IFS test -z "$as_dir" && as_dir=. for ac_prog in sed gsed; do for ac_exec_ext in '' $ac_executable_extensions; do ac_path_SED="$as_dir/$ac_prog$ac_exec_ext" as_fn_executable_p "$ac_path_SED" || continue # Check for GNU ac_path_SED and select it if it is found. # Check for GNU $ac_path_SED case `"$ac_path_SED" --version 2>&1` in *GNU*) ac_cv_path_SED="$ac_path_SED" ac_path_SED_found=:;; *) ac_count=0 $as_echo_n 0123456789 >"conftest.in" while : do cat "conftest.in" "conftest.in" >"conftest.tmp" mv "conftest.tmp" "conftest.in" cp "conftest.in" "conftest.nl" $as_echo '' >> "conftest.nl" "$ac_path_SED" -f conftest.sed < "conftest.nl" >"conftest.out" 2>/dev/null || break diff "conftest.out" "conftest.nl" >/dev/null 2>&1 || break as_fn_arith $ac_count + 1 && ac_count=$as_val if test $ac_count -gt ${ac_path_SED_max-0}; then # Best one so far, save it but keep looking for a better one ac_cv_path_SED="$ac_path_SED" ac_path_SED_max=$ac_count fi # 10*(2^10) chars as input seems more than enough test $ac_count -gt 10 && break done rm -f conftest.in conftest.tmp conftest.nl conftest.out;; esac $ac_path_SED_found && break 3 done done done IFS=$as_save_IFS if test -z "$ac_cv_path_SED"; then as_fn_error $? "no acceptable sed could be found in \$PATH" "$LINENO" 5 fi else ac_cv_path_SED=$SED fi fi { $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_cv_path_SED" >&5 $as_echo "$ac_cv_path_SED" >&6; } SED="$ac_cv_path_SED" rm -f conftest.sed test -z "$SED" && SED=sed Xsed="$SED -e 1s/^X//" { $as_echo "$as_me:${as_lineno-$LINENO}: checking for grep that handles long lines and -e" >&5 $as_echo_n "checking for grep that handles long lines and -e... " >&6; } if ${ac_cv_path_GREP+:} false; then : $as_echo_n "(cached) " >&6 else if test -z "$GREP"; then ac_path_GREP_found=false # Loop through the user's path and test for each of PROGNAME-LIST as_save_IFS=$IFS; IFS=$PATH_SEPARATOR for as_dir in $PATH$PATH_SEPARATOR/usr/xpg4/bin do IFS=$as_save_IFS test -z "$as_dir" && as_dir=. for ac_prog in grep ggrep; do for ac_exec_ext in '' $ac_executable_extensions; do ac_path_GREP="$as_dir/$ac_prog$ac_exec_ext" as_fn_executable_p "$ac_path_GREP" || continue # Check for GNU ac_path_GREP and select it if it is found. # Check for GNU $ac_path_GREP case `"$ac_path_GREP" --version 2>&1` in *GNU*) ac_cv_path_GREP="$ac_path_GREP" ac_path_GREP_found=:;; *) ac_count=0 $as_echo_n 0123456789 >"conftest.in" while : do cat "conftest.in" "conftest.in" >"conftest.tmp" mv "conftest.tmp" "conftest.in" cp "conftest.in" "conftest.nl" $as_echo 'GREP' >> "conftest.nl" "$ac_path_GREP" -e 'GREP$' -e '-(cannot match)-' < "conftest.nl" >"conftest.out" 2>/dev/null || break diff "conftest.out" "conftest.nl" >/dev/null 2>&1 || break as_fn_arith $ac_count + 1 && ac_count=$as_val if test $ac_count -gt ${ac_path_GREP_max-0}; then # Best one so far, save it but keep looking for a better one ac_cv_path_GREP="$ac_path_GREP" ac_path_GREP_max=$ac_count fi # 10*(2^10) chars as input seems more than enough test $ac_count -gt 10 && break done rm -f conftest.in conftest.tmp conftest.nl conftest.out;; esac $ac_path_GREP_found && break 3 done done done IFS=$as_save_IFS if test -z "$ac_cv_path_GREP"; then as_fn_error $? "no acceptable grep could be found in $PATH$PATH_SEPARATOR/usr/xpg4/bin" "$LINENO" 5 fi else ac_cv_path_GREP=$GREP fi fi { $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_cv_path_GREP" >&5 $as_echo "$ac_cv_path_GREP" >&6; } GREP="$ac_cv_path_GREP" { $as_echo "$as_me:${as_lineno-$LINENO}: checking for egrep" >&5 $as_echo_n "checking for egrep... " >&6; } if ${ac_cv_path_EGREP+:} false; then : $as_echo_n "(cached) " >&6 else if echo a | $GREP -E '(a|b)' >/dev/null 2>&1 then ac_cv_path_EGREP="$GREP -E" else if test -z "$EGREP"; then ac_path_EGREP_found=false # Loop through the user's path and test for each of PROGNAME-LIST as_save_IFS=$IFS; IFS=$PATH_SEPARATOR for as_dir in $PATH$PATH_SEPARATOR/usr/xpg4/bin do IFS=$as_save_IFS test -z "$as_dir" && as_dir=. for ac_prog in egrep; do for ac_exec_ext in '' $ac_executable_extensions; do ac_path_EGREP="$as_dir/$ac_prog$ac_exec_ext" as_fn_executable_p "$ac_path_EGREP" || continue # Check for GNU ac_path_EGREP and select it if it is found. # Check for GNU $ac_path_EGREP case `"$ac_path_EGREP" --version 2>&1` in *GNU*) ac_cv_path_EGREP="$ac_path_EGREP" ac_path_EGREP_found=:;; *) ac_count=0 $as_echo_n 0123456789 >"conftest.in" while : do cat "conftest.in" "conftest.in" >"conftest.tmp" mv "conftest.tmp" "conftest.in" cp "conftest.in" "conftest.nl" $as_echo 'EGREP' >> "conftest.nl" "$ac_path_EGREP" 'EGREP$' < "conftest.nl" >"conftest.out" 2>/dev/null || break diff "conftest.out" "conftest.nl" >/dev/null 2>&1 || break as_fn_arith $ac_count + 1 && ac_count=$as_val if test $ac_count -gt ${ac_path_EGREP_max-0}; then # Best one so far, save it but keep looking for a better one ac_cv_path_EGREP="$ac_path_EGREP" ac_path_EGREP_max=$ac_count fi # 10*(2^10) chars as input seems more than enough test $ac_count -gt 10 && break done rm -f conftest.in conftest.tmp conftest.nl conftest.out;; esac $ac_path_EGREP_found && break 3 done done done IFS=$as_save_IFS if test -z "$ac_cv_path_EGREP"; then as_fn_error $? "no acceptable egrep could be found in $PATH$PATH_SEPARATOR/usr/xpg4/bin" "$LINENO" 5 fi else ac_cv_path_EGREP=$EGREP fi fi fi { $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_cv_path_EGREP" >&5 $as_echo "$ac_cv_path_EGREP" >&6; } EGREP="$ac_cv_path_EGREP" { $as_echo "$as_me:${as_lineno-$LINENO}: checking for fgrep" >&5 $as_echo_n "checking for fgrep... " >&6; } if ${ac_cv_path_FGREP+:} false; then : $as_echo_n "(cached) " >&6 else if echo 'ab*c' | $GREP -F 'ab*c' >/dev/null 2>&1 then ac_cv_path_FGREP="$GREP -F" else if test -z "$FGREP"; then ac_path_FGREP_found=false # Loop through the user's path and test for each of PROGNAME-LIST as_save_IFS=$IFS; IFS=$PATH_SEPARATOR for as_dir in $PATH$PATH_SEPARATOR/usr/xpg4/bin do IFS=$as_save_IFS test -z "$as_dir" && as_dir=. for ac_prog in fgrep; do for ac_exec_ext in '' $ac_executable_extensions; do ac_path_FGREP="$as_dir/$ac_prog$ac_exec_ext" as_fn_executable_p "$ac_path_FGREP" || continue # Check for GNU ac_path_FGREP and select it if it is found. # Check for GNU $ac_path_FGREP case `"$ac_path_FGREP" --version 2>&1` in *GNU*) ac_cv_path_FGREP="$ac_path_FGREP" ac_path_FGREP_found=:;; *) ac_count=0 $as_echo_n 0123456789 >"conftest.in" while : do cat "conftest.in" "conftest.in" >"conftest.tmp" mv "conftest.tmp" "conftest.in" cp "conftest.in" "conftest.nl" $as_echo 'FGREP' >> "conftest.nl" "$ac_path_FGREP" FGREP < "conftest.nl" >"conftest.out" 2>/dev/null || break diff "conftest.out" "conftest.nl" >/dev/null 2>&1 || break as_fn_arith $ac_count + 1 && ac_count=$as_val if test $ac_count -gt ${ac_path_FGREP_max-0}; then # Best one so far, save it but keep looking for a better one ac_cv_path_FGREP="$ac_path_FGREP" ac_path_FGREP_max=$ac_count fi # 10*(2^10) chars as input seems more than enough test $ac_count -gt 10 && break done rm -f conftest.in conftest.tmp conftest.nl conftest.out;; esac $ac_path_FGREP_found && break 3 done done done IFS=$as_save_IFS if test -z "$ac_cv_path_FGREP"; then as_fn_error $? "no acceptable fgrep could be found in $PATH$PATH_SEPARATOR/usr/xpg4/bin" "$LINENO" 5 fi else ac_cv_path_FGREP=$FGREP fi fi fi { $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_cv_path_FGREP" >&5 $as_echo "$ac_cv_path_FGREP" >&6; } FGREP="$ac_cv_path_FGREP" test -z "$GREP" && GREP=grep # Check whether --with-gnu-ld was given. if test "${with_gnu_ld+set}" = set; then : withval=$with_gnu_ld; test no = "$withval" || with_gnu_ld=yes else with_gnu_ld=no fi ac_prog=ld if test yes = "$GCC"; then # Check if gcc -print-prog-name=ld gives a path. { $as_echo "$as_me:${as_lineno-$LINENO}: checking for ld used by $CC" >&5 $as_echo_n "checking for ld used by $CC... " >&6; } case $host in *-*-mingw*) # gcc leaves a trailing carriage return, which upsets mingw ac_prog=`($CC -print-prog-name=ld) 2>&5 | tr -d '\015'` ;; *) ac_prog=`($CC -print-prog-name=ld) 2>&5` ;; esac case $ac_prog in # Accept absolute paths. [\\/]* | ?:[\\/]*) re_direlt='/[^/][^/]*/\.\./' # Canonicalize the pathname of ld ac_prog=`$ECHO "$ac_prog"| $SED 's%\\\\%/%g'` while $ECHO "$ac_prog" | $GREP "$re_direlt" > /dev/null 2>&1; do ac_prog=`$ECHO $ac_prog| $SED "s%$re_direlt%/%"` done test -z "$LD" && LD=$ac_prog ;; "") # If it fails, then pretend we aren't using GCC. ac_prog=ld ;; *) # If it is relative, then search for the first ld in PATH. with_gnu_ld=unknown ;; esac elif test yes = "$with_gnu_ld"; then { $as_echo "$as_me:${as_lineno-$LINENO}: checking for GNU ld" >&5 $as_echo_n "checking for GNU ld... " >&6; } else { $as_echo "$as_me:${as_lineno-$LINENO}: checking for non-GNU ld" >&5 $as_echo_n "checking for non-GNU ld... " >&6; } fi if ${lt_cv_path_LD+:} false; then : $as_echo_n "(cached) " >&6 else if test -z "$LD"; then lt_save_ifs=$IFS; IFS=$PATH_SEPARATOR for ac_dir in $PATH; do IFS=$lt_save_ifs test -z "$ac_dir" && ac_dir=. if test -f "$ac_dir/$ac_prog" || test -f "$ac_dir/$ac_prog$ac_exeext"; then lt_cv_path_LD=$ac_dir/$ac_prog # Check to see if the program is GNU ld. I'd rather use --version, # but apparently some variants of GNU ld only accept -v. # Break only if it was the GNU/non-GNU ld that we prefer. case `"$lt_cv_path_LD" -v 2>&1 &5 $as_echo "$LD" >&6; } else { $as_echo "$as_me:${as_lineno-$LINENO}: result: no" >&5 $as_echo "no" >&6; } fi test -z "$LD" && as_fn_error $? "no acceptable ld found in \$PATH" "$LINENO" 5 { $as_echo "$as_me:${as_lineno-$LINENO}: checking if the linker ($LD) is GNU ld" >&5 $as_echo_n "checking if the linker ($LD) is GNU ld... " >&6; } if ${lt_cv_prog_gnu_ld+:} false; then : $as_echo_n "(cached) " >&6 else # I'd rather use --version here, but apparently some GNU lds only accept -v. case `$LD -v 2>&1 &5 $as_echo "$lt_cv_prog_gnu_ld" >&6; } with_gnu_ld=$lt_cv_prog_gnu_ld { $as_echo "$as_me:${as_lineno-$LINENO}: checking for BSD- or MS-compatible name lister (nm)" >&5 $as_echo_n "checking for BSD- or MS-compatible name lister (nm)... " >&6; } if ${lt_cv_path_NM+:} false; then : $as_echo_n "(cached) " >&6 else if test -n "$NM"; then # Let the user override the test. lt_cv_path_NM=$NM else lt_nm_to_check=${ac_tool_prefix}nm if test -n "$ac_tool_prefix" && test "$build" = "$host"; then lt_nm_to_check="$lt_nm_to_check nm" fi for lt_tmp_nm in $lt_nm_to_check; do lt_save_ifs=$IFS; IFS=$PATH_SEPARATOR for ac_dir in $PATH /usr/ccs/bin/elf /usr/ccs/bin /usr/ucb /bin; do IFS=$lt_save_ifs test -z "$ac_dir" && ac_dir=. tmp_nm=$ac_dir/$lt_tmp_nm if test -f "$tmp_nm" || test -f "$tmp_nm$ac_exeext"; then # Check to see if the nm accepts a BSD-compat flag. # Adding the 'sed 1q' prevents false positives on HP-UX, which says: # nm: unknown option "B" ignored # Tru64's nm complains that /dev/null is an invalid object file # MSYS converts /dev/null to NUL, MinGW nm treats NUL as empty case $build_os in mingw*) lt_bad_file=conftest.nm/nofile ;; *) lt_bad_file=/dev/null ;; esac case `"$tmp_nm" -B $lt_bad_file 2>&1 | sed '1q'` in *$lt_bad_file* | *'Invalid file or object type'*) lt_cv_path_NM="$tmp_nm -B" break 2 ;; *) case `"$tmp_nm" -p /dev/null 2>&1 | sed '1q'` in */dev/null*) lt_cv_path_NM="$tmp_nm -p" break 2 ;; *) lt_cv_path_NM=${lt_cv_path_NM="$tmp_nm"} # keep the first match, but continue # so that we can try to find one that supports BSD flags ;; esac ;; esac fi done IFS=$lt_save_ifs done : ${lt_cv_path_NM=no} fi fi { $as_echo "$as_me:${as_lineno-$LINENO}: result: $lt_cv_path_NM" >&5 $as_echo "$lt_cv_path_NM" >&6; } if test no != "$lt_cv_path_NM"; then NM=$lt_cv_path_NM else # Didn't find any BSD compatible name lister, look for dumpbin. if test -n "$DUMPBIN"; then : # Let the user override the test. else if test -n "$ac_tool_prefix"; then for ac_prog in dumpbin "link -dump" do # Extract the first word of "$ac_tool_prefix$ac_prog", so it can be a program name with args. set dummy $ac_tool_prefix$ac_prog; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } if ${ac_cv_prog_DUMPBIN+:} false; then : $as_echo_n "(cached) " >&6 else if test -n "$DUMPBIN"; then ac_cv_prog_DUMPBIN="$DUMPBIN" # Let the user override the test. else as_save_IFS=$IFS; IFS=$PATH_SEPARATOR for as_dir in $PATH do IFS=$as_save_IFS test -z "$as_dir" && as_dir=. for ac_exec_ext in '' $ac_executable_extensions; do if as_fn_executable_p "$as_dir/$ac_word$ac_exec_ext"; then ac_cv_prog_DUMPBIN="$ac_tool_prefix$ac_prog" $as_echo "$as_me:${as_lineno-$LINENO}: found $as_dir/$ac_word$ac_exec_ext" >&5 break 2 fi done done IFS=$as_save_IFS fi fi DUMPBIN=$ac_cv_prog_DUMPBIN if test -n "$DUMPBIN"; then { $as_echo "$as_me:${as_lineno-$LINENO}: result: $DUMPBIN" >&5 $as_echo "$DUMPBIN" >&6; } else { $as_echo "$as_me:${as_lineno-$LINENO}: result: no" >&5 $as_echo "no" >&6; } fi test -n "$DUMPBIN" && break done fi if test -z "$DUMPBIN"; then ac_ct_DUMPBIN=$DUMPBIN for ac_prog in dumpbin "link -dump" do # Extract the first word of "$ac_prog", so it can be a program name with args. set dummy $ac_prog; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } if ${ac_cv_prog_ac_ct_DUMPBIN+:} false; then : $as_echo_n "(cached) " >&6 else if test -n "$ac_ct_DUMPBIN"; then ac_cv_prog_ac_ct_DUMPBIN="$ac_ct_DUMPBIN" # Let the user override the test. else as_save_IFS=$IFS; IFS=$PATH_SEPARATOR for as_dir in $PATH do IFS=$as_save_IFS test -z "$as_dir" && as_dir=. for ac_exec_ext in '' $ac_executable_extensions; do if as_fn_executable_p "$as_dir/$ac_word$ac_exec_ext"; then ac_cv_prog_ac_ct_DUMPBIN="$ac_prog" $as_echo "$as_me:${as_lineno-$LINENO}: found $as_dir/$ac_word$ac_exec_ext" >&5 break 2 fi done done IFS=$as_save_IFS fi fi ac_ct_DUMPBIN=$ac_cv_prog_ac_ct_DUMPBIN if test -n "$ac_ct_DUMPBIN"; then { $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_ct_DUMPBIN" >&5 $as_echo "$ac_ct_DUMPBIN" >&6; } else { $as_echo "$as_me:${as_lineno-$LINENO}: result: no" >&5 $as_echo "no" >&6; } fi test -n "$ac_ct_DUMPBIN" && break done if test "x$ac_ct_DUMPBIN" = x; then DUMPBIN=":" else case $cross_compiling:$ac_tool_warned in yes:) { $as_echo "$as_me:${as_lineno-$LINENO}: WARNING: using cross tools not prefixed with host triplet" >&5 $as_echo "$as_me: WARNING: using cross tools not prefixed with host triplet" >&2;} ac_tool_warned=yes ;; esac DUMPBIN=$ac_ct_DUMPBIN fi fi case `$DUMPBIN -symbols -headers /dev/null 2>&1 | sed '1q'` in *COFF*) DUMPBIN="$DUMPBIN -symbols -headers" ;; *) DUMPBIN=: ;; esac fi if test : != "$DUMPBIN"; then NM=$DUMPBIN fi fi test -z "$NM" && NM=nm { $as_echo "$as_me:${as_lineno-$LINENO}: checking the name lister ($NM) interface" >&5 $as_echo_n "checking the name lister ($NM) interface... " >&6; } if ${lt_cv_nm_interface+:} false; then : $as_echo_n "(cached) " >&6 else lt_cv_nm_interface="BSD nm" echo "int some_variable = 0;" > conftest.$ac_ext (eval echo "\"\$as_me:$LINENO: $ac_compile\"" >&5) (eval "$ac_compile" 2>conftest.err) cat conftest.err >&5 (eval echo "\"\$as_me:$LINENO: $NM \\\"conftest.$ac_objext\\\"\"" >&5) (eval "$NM \"conftest.$ac_objext\"" 2>conftest.err > conftest.out) cat conftest.err >&5 (eval echo "\"\$as_me:$LINENO: output\"" >&5) cat conftest.out >&5 if $GREP 'External.*some_variable' conftest.out > /dev/null; then lt_cv_nm_interface="MS dumpbin" fi rm -f conftest* fi { $as_echo "$as_me:${as_lineno-$LINENO}: result: $lt_cv_nm_interface" >&5 $as_echo "$lt_cv_nm_interface" >&6; } { $as_echo "$as_me:${as_lineno-$LINENO}: checking whether ln -s works" >&5 $as_echo_n "checking whether ln -s works... " >&6; } LN_S=$as_ln_s if test "$LN_S" = "ln -s"; then { $as_echo "$as_me:${as_lineno-$LINENO}: result: yes" >&5 $as_echo "yes" >&6; } else { $as_echo "$as_me:${as_lineno-$LINENO}: result: no, using $LN_S" >&5 $as_echo "no, using $LN_S" >&6; } fi # find the maximum length of command line arguments { $as_echo "$as_me:${as_lineno-$LINENO}: checking the maximum length of command line arguments" >&5 $as_echo_n "checking the maximum length of command line arguments... " >&6; } if ${lt_cv_sys_max_cmd_len+:} false; then : $as_echo_n "(cached) " >&6 else i=0 teststring=ABCD case $build_os in msdosdjgpp*) # On DJGPP, this test can blow up pretty badly due to problems in libc # (any single argument exceeding 2000 bytes causes a buffer overrun # during glob expansion). Even if it were fixed, the result of this # check would be larger than it should be. lt_cv_sys_max_cmd_len=12288; # 12K is about right ;; gnu*) # Under GNU Hurd, this test is not required because there is # no limit to the length of command line arguments. # Libtool will interpret -1 as no limit whatsoever lt_cv_sys_max_cmd_len=-1; ;; cygwin* | mingw* | cegcc*) # On Win9x/ME, this test blows up -- it succeeds, but takes # about 5 minutes as the teststring grows exponentially. # Worse, since 9x/ME are not pre-emptively multitasking, # you end up with a "frozen" computer, even though with patience # the test eventually succeeds (with a max line length of 256k). # Instead, let's just punt: use the minimum linelength reported by # all of the supported platforms: 8192 (on NT/2K/XP). lt_cv_sys_max_cmd_len=8192; ;; mint*) # On MiNT this can take a long time and run out of memory. lt_cv_sys_max_cmd_len=8192; ;; amigaos*) # On AmigaOS with pdksh, this test takes hours, literally. # So we just punt and use a minimum line length of 8192. lt_cv_sys_max_cmd_len=8192; ;; bitrig* | darwin* | dragonfly* | freebsd* | netbsd* | openbsd*) # This has been around since 386BSD, at least. Likely further. if test -x /sbin/sysctl; then lt_cv_sys_max_cmd_len=`/sbin/sysctl -n kern.argmax` elif test -x /usr/sbin/sysctl; then lt_cv_sys_max_cmd_len=`/usr/sbin/sysctl -n kern.argmax` else lt_cv_sys_max_cmd_len=65536 # usable default for all BSDs fi # And add a safety zone lt_cv_sys_max_cmd_len=`expr $lt_cv_sys_max_cmd_len \/ 4` lt_cv_sys_max_cmd_len=`expr $lt_cv_sys_max_cmd_len \* 3` ;; interix*) # We know the value 262144 and hardcode it with a safety zone (like BSD) lt_cv_sys_max_cmd_len=196608 ;; os2*) # The test takes a long time on OS/2. lt_cv_sys_max_cmd_len=8192 ;; osf*) # Dr. Hans Ekkehard Plesser reports seeing a kernel panic running configure # due to this test when exec_disable_arg_limit is 1 on Tru64. It is not # nice to cause kernel panics so lets avoid the loop below. # First set a reasonable default. lt_cv_sys_max_cmd_len=16384 # if test -x /sbin/sysconfig; then case `/sbin/sysconfig -q proc exec_disable_arg_limit` in *1*) lt_cv_sys_max_cmd_len=-1 ;; esac fi ;; sco3.2v5*) lt_cv_sys_max_cmd_len=102400 ;; sysv5* | sco5v6* | sysv4.2uw2*) kargmax=`grep ARG_MAX /etc/conf/cf.d/stune 2>/dev/null` if test -n "$kargmax"; then lt_cv_sys_max_cmd_len=`echo $kargmax | sed 's/.*[ ]//'` else lt_cv_sys_max_cmd_len=32768 fi ;; *) lt_cv_sys_max_cmd_len=`(getconf ARG_MAX) 2> /dev/null` if test -n "$lt_cv_sys_max_cmd_len" && \ test undefined != "$lt_cv_sys_max_cmd_len"; then lt_cv_sys_max_cmd_len=`expr $lt_cv_sys_max_cmd_len \/ 4` lt_cv_sys_max_cmd_len=`expr $lt_cv_sys_max_cmd_len \* 3` else # Make teststring a little bigger before we do anything with it. # a 1K string should be a reasonable start. for i in 1 2 3 4 5 6 7 8; do teststring=$teststring$teststring done SHELL=${SHELL-${CONFIG_SHELL-/bin/sh}} # If test is not a shell built-in, we'll probably end up computing a # maximum length that is only half of the actual maximum length, but # we can't tell. while { test X`env echo "$teststring$teststring" 2>/dev/null` \ = "X$teststring$teststring"; } >/dev/null 2>&1 && test 17 != "$i" # 1/2 MB should be enough do i=`expr $i + 1` teststring=$teststring$teststring done # Only check the string length outside the loop. lt_cv_sys_max_cmd_len=`expr "X$teststring" : ".*" 2>&1` teststring= # Add a significant safety factor because C++ compilers can tack on # massive amounts of additional arguments before passing them to the # linker. It appears as though 1/2 is a usable value. lt_cv_sys_max_cmd_len=`expr $lt_cv_sys_max_cmd_len \/ 2` fi ;; esac fi if test -n "$lt_cv_sys_max_cmd_len"; then { $as_echo "$as_me:${as_lineno-$LINENO}: result: $lt_cv_sys_max_cmd_len" >&5 $as_echo "$lt_cv_sys_max_cmd_len" >&6; } else { $as_echo "$as_me:${as_lineno-$LINENO}: result: none" >&5 $as_echo "none" >&6; } fi max_cmd_len=$lt_cv_sys_max_cmd_len : ${CP="cp -f"} : ${MV="mv -f"} : ${RM="rm -f"} if ( (MAIL=60; unset MAIL) || exit) >/dev/null 2>&1; then lt_unset=unset else lt_unset=false fi # test EBCDIC or ASCII case `echo X|tr X '\101'` in A) # ASCII based system # \n is not interpreted correctly by Solaris 8 /usr/ucb/tr lt_SP2NL='tr \040 \012' lt_NL2SP='tr \015\012 \040\040' ;; *) # EBCDIC based system lt_SP2NL='tr \100 \n' lt_NL2SP='tr \r\n \100\100' ;; esac { $as_echo "$as_me:${as_lineno-$LINENO}: checking how to convert $build file names to $host format" >&5 $as_echo_n "checking how to convert $build file names to $host format... " >&6; } if ${lt_cv_to_host_file_cmd+:} false; then : $as_echo_n "(cached) " >&6 else case $host in *-*-mingw* ) case $build in *-*-mingw* ) # actually msys lt_cv_to_host_file_cmd=func_convert_file_msys_to_w32 ;; *-*-cygwin* ) lt_cv_to_host_file_cmd=func_convert_file_cygwin_to_w32 ;; * ) # otherwise, assume *nix lt_cv_to_host_file_cmd=func_convert_file_nix_to_w32 ;; esac ;; *-*-cygwin* ) case $build in *-*-mingw* ) # actually msys lt_cv_to_host_file_cmd=func_convert_file_msys_to_cygwin ;; *-*-cygwin* ) lt_cv_to_host_file_cmd=func_convert_file_noop ;; * ) # otherwise, assume *nix lt_cv_to_host_file_cmd=func_convert_file_nix_to_cygwin ;; esac ;; * ) # unhandled hosts (and "normal" native builds) lt_cv_to_host_file_cmd=func_convert_file_noop ;; esac fi to_host_file_cmd=$lt_cv_to_host_file_cmd { $as_echo "$as_me:${as_lineno-$LINENO}: result: $lt_cv_to_host_file_cmd" >&5 $as_echo "$lt_cv_to_host_file_cmd" >&6; } { $as_echo "$as_me:${as_lineno-$LINENO}: checking how to convert $build file names to toolchain format" >&5 $as_echo_n "checking how to convert $build file names to toolchain format... " >&6; } if ${lt_cv_to_tool_file_cmd+:} false; then : $as_echo_n "(cached) " >&6 else #assume ordinary cross tools, or native build. lt_cv_to_tool_file_cmd=func_convert_file_noop case $host in *-*-mingw* ) case $build in *-*-mingw* ) # actually msys lt_cv_to_tool_file_cmd=func_convert_file_msys_to_w32 ;; esac ;; esac fi to_tool_file_cmd=$lt_cv_to_tool_file_cmd { $as_echo "$as_me:${as_lineno-$LINENO}: result: $lt_cv_to_tool_file_cmd" >&5 $as_echo "$lt_cv_to_tool_file_cmd" >&6; } { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $LD option to reload object files" >&5 $as_echo_n "checking for $LD option to reload object files... " >&6; } if ${lt_cv_ld_reload_flag+:} false; then : $as_echo_n "(cached) " >&6 else lt_cv_ld_reload_flag='-r' fi { $as_echo "$as_me:${as_lineno-$LINENO}: result: $lt_cv_ld_reload_flag" >&5 $as_echo "$lt_cv_ld_reload_flag" >&6; } reload_flag=$lt_cv_ld_reload_flag case $reload_flag in "" | " "*) ;; *) reload_flag=" $reload_flag" ;; esac reload_cmds='$LD$reload_flag -o $output$reload_objs' case $host_os in cygwin* | mingw* | pw32* | cegcc*) if test yes != "$GCC"; then reload_cmds=false fi ;; darwin*) if test yes = "$GCC"; then reload_cmds='$LTCC $LTCFLAGS -nostdlib $wl-r -o $output$reload_objs' else reload_cmds='$LD$reload_flag -o $output$reload_objs' fi ;; esac if test -n "$ac_tool_prefix"; then # Extract the first word of "${ac_tool_prefix}objdump", so it can be a program name with args. set dummy ${ac_tool_prefix}objdump; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } if ${ac_cv_prog_OBJDUMP+:} false; then : $as_echo_n "(cached) " >&6 else if test -n "$OBJDUMP"; then ac_cv_prog_OBJDUMP="$OBJDUMP" # Let the user override the test. else as_save_IFS=$IFS; IFS=$PATH_SEPARATOR for as_dir in $PATH do IFS=$as_save_IFS test -z "$as_dir" && as_dir=. for ac_exec_ext in '' $ac_executable_extensions; do if as_fn_executable_p "$as_dir/$ac_word$ac_exec_ext"; then ac_cv_prog_OBJDUMP="${ac_tool_prefix}objdump" $as_echo "$as_me:${as_lineno-$LINENO}: found $as_dir/$ac_word$ac_exec_ext" >&5 break 2 fi done done IFS=$as_save_IFS fi fi OBJDUMP=$ac_cv_prog_OBJDUMP if test -n "$OBJDUMP"; then { $as_echo "$as_me:${as_lineno-$LINENO}: result: $OBJDUMP" >&5 $as_echo "$OBJDUMP" >&6; } else { $as_echo "$as_me:${as_lineno-$LINENO}: result: no" >&5 $as_echo "no" >&6; } fi fi if test -z "$ac_cv_prog_OBJDUMP"; then ac_ct_OBJDUMP=$OBJDUMP # Extract the first word of "objdump", so it can be a program name with args. set dummy objdump; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } if ${ac_cv_prog_ac_ct_OBJDUMP+:} false; then : $as_echo_n "(cached) " >&6 else if test -n "$ac_ct_OBJDUMP"; then ac_cv_prog_ac_ct_OBJDUMP="$ac_ct_OBJDUMP" # Let the user override the test. else as_save_IFS=$IFS; IFS=$PATH_SEPARATOR for as_dir in $PATH do IFS=$as_save_IFS test -z "$as_dir" && as_dir=. for ac_exec_ext in '' $ac_executable_extensions; do if as_fn_executable_p "$as_dir/$ac_word$ac_exec_ext"; then ac_cv_prog_ac_ct_OBJDUMP="objdump" $as_echo "$as_me:${as_lineno-$LINENO}: found $as_dir/$ac_word$ac_exec_ext" >&5 break 2 fi done done IFS=$as_save_IFS fi fi ac_ct_OBJDUMP=$ac_cv_prog_ac_ct_OBJDUMP if test -n "$ac_ct_OBJDUMP"; then { $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_ct_OBJDUMP" >&5 $as_echo "$ac_ct_OBJDUMP" >&6; } else { $as_echo "$as_me:${as_lineno-$LINENO}: result: no" >&5 $as_echo "no" >&6; } fi if test "x$ac_ct_OBJDUMP" = x; then OBJDUMP="false" else case $cross_compiling:$ac_tool_warned in yes:) { $as_echo "$as_me:${as_lineno-$LINENO}: WARNING: using cross tools not prefixed with host triplet" >&5 $as_echo "$as_me: WARNING: using cross tools not prefixed with host triplet" >&2;} ac_tool_warned=yes ;; esac OBJDUMP=$ac_ct_OBJDUMP fi else OBJDUMP="$ac_cv_prog_OBJDUMP" fi test -z "$OBJDUMP" && OBJDUMP=objdump { $as_echo "$as_me:${as_lineno-$LINENO}: checking how to recognize dependent libraries" >&5 $as_echo_n "checking how to recognize dependent libraries... " >&6; } if ${lt_cv_deplibs_check_method+:} false; then : $as_echo_n "(cached) " >&6 else lt_cv_file_magic_cmd='$MAGIC_CMD' lt_cv_file_magic_test_file= lt_cv_deplibs_check_method='unknown' # Need to set the preceding variable on all platforms that support # interlibrary dependencies. # 'none' -- dependencies not supported. # 'unknown' -- same as none, but documents that we really don't know. # 'pass_all' -- all dependencies passed with no checks. # 'test_compile' -- check by making test program. # 'file_magic [[regex]]' -- check by looking for files in library path # that responds to the $file_magic_cmd with a given extended regex. # If you have 'file' or equivalent on your system and you're not sure # whether 'pass_all' will *always* work, you probably want this one. case $host_os in aix[4-9]*) lt_cv_deplibs_check_method=pass_all ;; beos*) lt_cv_deplibs_check_method=pass_all ;; bsdi[45]*) lt_cv_deplibs_check_method='file_magic ELF [0-9][0-9]*-bit [ML]SB (shared object|dynamic lib)' lt_cv_file_magic_cmd='/usr/bin/file -L' lt_cv_file_magic_test_file=/shlib/libc.so ;; cygwin*) # func_win32_libid is a shell function defined in ltmain.sh lt_cv_deplibs_check_method='file_magic ^x86 archive import|^x86 DLL' lt_cv_file_magic_cmd='func_win32_libid' ;; mingw* | pw32*) # Base MSYS/MinGW do not provide the 'file' command needed by # func_win32_libid shell function, so use a weaker test based on 'objdump', # unless we find 'file', for example because we are cross-compiling. if ( file / ) >/dev/null 2>&1; then lt_cv_deplibs_check_method='file_magic ^x86 archive import|^x86 DLL' lt_cv_file_magic_cmd='func_win32_libid' else # Keep this pattern in sync with the one in func_win32_libid. lt_cv_deplibs_check_method='file_magic file format (pei*-i386(.*architecture: i386)?|pe-arm-wince|pe-x86-64)' lt_cv_file_magic_cmd='$OBJDUMP -f' fi ;; cegcc*) # use the weaker test based on 'objdump'. See mingw*. lt_cv_deplibs_check_method='file_magic file format pe-arm-.*little(.*architecture: arm)?' lt_cv_file_magic_cmd='$OBJDUMP -f' ;; darwin* | rhapsody*) lt_cv_deplibs_check_method=pass_all ;; freebsd* | dragonfly*) if echo __ELF__ | $CC -E - | $GREP __ELF__ > /dev/null; then case $host_cpu in i*86 ) # Not sure whether the presence of OpenBSD here was a mistake. # Let's accept both of them until this is cleared up. lt_cv_deplibs_check_method='file_magic (FreeBSD|OpenBSD|DragonFly)/i[3-9]86 (compact )?demand paged shared library' lt_cv_file_magic_cmd=/usr/bin/file lt_cv_file_magic_test_file=`echo /usr/lib/libc.so.*` ;; esac else lt_cv_deplibs_check_method=pass_all fi ;; haiku*) lt_cv_deplibs_check_method=pass_all ;; hpux10.20* | hpux11*) lt_cv_file_magic_cmd=/usr/bin/file case $host_cpu in ia64*) lt_cv_deplibs_check_method='file_magic (s[0-9][0-9][0-9]|ELF-[0-9][0-9]) shared object file - IA64' lt_cv_file_magic_test_file=/usr/lib/hpux32/libc.so ;; hppa*64*) lt_cv_deplibs_check_method='file_magic (s[0-9][0-9][0-9]|ELF[ -][0-9][0-9])(-bit)?( [LM]SB)? shared object( file)?[, -]* PA-RISC [0-9]\.[0-9]' lt_cv_file_magic_test_file=/usr/lib/pa20_64/libc.sl ;; *) lt_cv_deplibs_check_method='file_magic (s[0-9][0-9][0-9]|PA-RISC[0-9]\.[0-9]) shared library' lt_cv_file_magic_test_file=/usr/lib/libc.sl ;; esac ;; interix[3-9]*) # PIC code is broken on Interix 3.x, that's why |\.a not |_pic\.a here lt_cv_deplibs_check_method='match_pattern /lib[^/]+(\.so|\.a)$' ;; irix5* | irix6* | nonstopux*) case $LD in *-32|*"-32 ") libmagic=32-bit;; *-n32|*"-n32 ") libmagic=N32;; *-64|*"-64 ") libmagic=64-bit;; *) libmagic=never-match;; esac lt_cv_deplibs_check_method=pass_all ;; # This must be glibc/ELF. linux* | k*bsd*-gnu | kopensolaris*-gnu | gnu*) lt_cv_deplibs_check_method=pass_all ;; netbsd*) if echo __ELF__ | $CC -E - | $GREP __ELF__ > /dev/null; then lt_cv_deplibs_check_method='match_pattern /lib[^/]+(\.so\.[0-9]+\.[0-9]+|_pic\.a)$' else lt_cv_deplibs_check_method='match_pattern /lib[^/]+(\.so|_pic\.a)$' fi ;; newos6*) lt_cv_deplibs_check_method='file_magic ELF [0-9][0-9]*-bit [ML]SB (executable|dynamic lib)' lt_cv_file_magic_cmd=/usr/bin/file lt_cv_file_magic_test_file=/usr/lib/libnls.so ;; *nto* | *qnx*) lt_cv_deplibs_check_method=pass_all ;; openbsd* | bitrig*) if test -z "`echo __ELF__ | $CC -E - | $GREP __ELF__`"; then lt_cv_deplibs_check_method='match_pattern /lib[^/]+(\.so\.[0-9]+\.[0-9]+|\.so|_pic\.a)$' else lt_cv_deplibs_check_method='match_pattern /lib[^/]+(\.so\.[0-9]+\.[0-9]+|_pic\.a)$' fi ;; osf3* | osf4* | osf5*) lt_cv_deplibs_check_method=pass_all ;; rdos*) lt_cv_deplibs_check_method=pass_all ;; solaris*) lt_cv_deplibs_check_method=pass_all ;; sysv5* | sco3.2v5* | sco5v6* | unixware* | OpenUNIX* | sysv4*uw2*) lt_cv_deplibs_check_method=pass_all ;; sysv4 | sysv4.3*) case $host_vendor in motorola) lt_cv_deplibs_check_method='file_magic ELF [0-9][0-9]*-bit [ML]SB (shared object|dynamic lib) M[0-9][0-9]* Version [0-9]' lt_cv_file_magic_test_file=`echo /usr/lib/libc.so*` ;; ncr) lt_cv_deplibs_check_method=pass_all ;; sequent) lt_cv_file_magic_cmd='/bin/file' lt_cv_deplibs_check_method='file_magic ELF [0-9][0-9]*-bit [LM]SB (shared object|dynamic lib )' ;; sni) lt_cv_file_magic_cmd='/bin/file' lt_cv_deplibs_check_method="file_magic ELF [0-9][0-9]*-bit [LM]SB dynamic lib" lt_cv_file_magic_test_file=/lib/libc.so ;; siemens) lt_cv_deplibs_check_method=pass_all ;; pc) lt_cv_deplibs_check_method=pass_all ;; esac ;; tpf*) lt_cv_deplibs_check_method=pass_all ;; os2*) lt_cv_deplibs_check_method=pass_all ;; esac fi { $as_echo "$as_me:${as_lineno-$LINENO}: result: $lt_cv_deplibs_check_method" >&5 $as_echo "$lt_cv_deplibs_check_method" >&6; } file_magic_glob= want_nocaseglob=no if test "$build" = "$host"; then case $host_os in mingw* | pw32*) if ( shopt | grep nocaseglob ) >/dev/null 2>&1; then want_nocaseglob=yes else file_magic_glob=`echo aAbBcCdDeEfFgGhHiIjJkKlLmMnNoOpPqQrRsStTuUvVwWxXyYzZ | $SED -e "s/\(..\)/s\/[\1]\/[\1]\/g;/g"` fi ;; esac fi file_magic_cmd=$lt_cv_file_magic_cmd deplibs_check_method=$lt_cv_deplibs_check_method test -z "$deplibs_check_method" && deplibs_check_method=unknown if test -n "$ac_tool_prefix"; then # Extract the first word of "${ac_tool_prefix}dlltool", so it can be a program name with args. set dummy ${ac_tool_prefix}dlltool; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } if ${ac_cv_prog_DLLTOOL+:} false; then : $as_echo_n "(cached) " >&6 else if test -n "$DLLTOOL"; then ac_cv_prog_DLLTOOL="$DLLTOOL" # Let the user override the test. else as_save_IFS=$IFS; IFS=$PATH_SEPARATOR for as_dir in $PATH do IFS=$as_save_IFS test -z "$as_dir" && as_dir=. for ac_exec_ext in '' $ac_executable_extensions; do if as_fn_executable_p "$as_dir/$ac_word$ac_exec_ext"; then ac_cv_prog_DLLTOOL="${ac_tool_prefix}dlltool" $as_echo "$as_me:${as_lineno-$LINENO}: found $as_dir/$ac_word$ac_exec_ext" >&5 break 2 fi done done IFS=$as_save_IFS fi fi DLLTOOL=$ac_cv_prog_DLLTOOL if test -n "$DLLTOOL"; then { $as_echo "$as_me:${as_lineno-$LINENO}: result: $DLLTOOL" >&5 $as_echo "$DLLTOOL" >&6; } else { $as_echo "$as_me:${as_lineno-$LINENO}: result: no" >&5 $as_echo "no" >&6; } fi fi if test -z "$ac_cv_prog_DLLTOOL"; then ac_ct_DLLTOOL=$DLLTOOL # Extract the first word of "dlltool", so it can be a program name with args. set dummy dlltool; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } if ${ac_cv_prog_ac_ct_DLLTOOL+:} false; then : $as_echo_n "(cached) " >&6 else if test -n "$ac_ct_DLLTOOL"; then ac_cv_prog_ac_ct_DLLTOOL="$ac_ct_DLLTOOL" # Let the user override the test. else as_save_IFS=$IFS; IFS=$PATH_SEPARATOR for as_dir in $PATH do IFS=$as_save_IFS test -z "$as_dir" && as_dir=. for ac_exec_ext in '' $ac_executable_extensions; do if as_fn_executable_p "$as_dir/$ac_word$ac_exec_ext"; then ac_cv_prog_ac_ct_DLLTOOL="dlltool" $as_echo "$as_me:${as_lineno-$LINENO}: found $as_dir/$ac_word$ac_exec_ext" >&5 break 2 fi done done IFS=$as_save_IFS fi fi ac_ct_DLLTOOL=$ac_cv_prog_ac_ct_DLLTOOL if test -n "$ac_ct_DLLTOOL"; then { $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_ct_DLLTOOL" >&5 $as_echo "$ac_ct_DLLTOOL" >&6; } else { $as_echo "$as_me:${as_lineno-$LINENO}: result: no" >&5 $as_echo "no" >&6; } fi if test "x$ac_ct_DLLTOOL" = x; then DLLTOOL="false" else case $cross_compiling:$ac_tool_warned in yes:) { $as_echo "$as_me:${as_lineno-$LINENO}: WARNING: using cross tools not prefixed with host triplet" >&5 $as_echo "$as_me: WARNING: using cross tools not prefixed with host triplet" >&2;} ac_tool_warned=yes ;; esac DLLTOOL=$ac_ct_DLLTOOL fi else DLLTOOL="$ac_cv_prog_DLLTOOL" fi test -z "$DLLTOOL" && DLLTOOL=dlltool { $as_echo "$as_me:${as_lineno-$LINENO}: checking how to associate runtime and link libraries" >&5 $as_echo_n "checking how to associate runtime and link libraries... " >&6; } if ${lt_cv_sharedlib_from_linklib_cmd+:} false; then : $as_echo_n "(cached) " >&6 else lt_cv_sharedlib_from_linklib_cmd='unknown' case $host_os in cygwin* | mingw* | pw32* | cegcc*) # two different shell functions defined in ltmain.sh; # decide which one to use based on capabilities of $DLLTOOL case `$DLLTOOL --help 2>&1` in *--identify-strict*) lt_cv_sharedlib_from_linklib_cmd=func_cygming_dll_for_implib ;; *) lt_cv_sharedlib_from_linklib_cmd=func_cygming_dll_for_implib_fallback ;; esac ;; *) # fallback: assume linklib IS sharedlib lt_cv_sharedlib_from_linklib_cmd=$ECHO ;; esac fi { $as_echo "$as_me:${as_lineno-$LINENO}: result: $lt_cv_sharedlib_from_linklib_cmd" >&5 $as_echo "$lt_cv_sharedlib_from_linklib_cmd" >&6; } sharedlib_from_linklib_cmd=$lt_cv_sharedlib_from_linklib_cmd test -z "$sharedlib_from_linklib_cmd" && sharedlib_from_linklib_cmd=$ECHO if test -n "$ac_tool_prefix"; then for ac_prog in ar do # Extract the first word of "$ac_tool_prefix$ac_prog", so it can be a program name with args. set dummy $ac_tool_prefix$ac_prog; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } if ${ac_cv_prog_AR+:} false; then : $as_echo_n "(cached) " >&6 else if test -n "$AR"; then ac_cv_prog_AR="$AR" # Let the user override the test. else as_save_IFS=$IFS; IFS=$PATH_SEPARATOR for as_dir in $PATH do IFS=$as_save_IFS test -z "$as_dir" && as_dir=. for ac_exec_ext in '' $ac_executable_extensions; do if as_fn_executable_p "$as_dir/$ac_word$ac_exec_ext"; then ac_cv_prog_AR="$ac_tool_prefix$ac_prog" $as_echo "$as_me:${as_lineno-$LINENO}: found $as_dir/$ac_word$ac_exec_ext" >&5 break 2 fi done done IFS=$as_save_IFS fi fi AR=$ac_cv_prog_AR if test -n "$AR"; then { $as_echo "$as_me:${as_lineno-$LINENO}: result: $AR" >&5 $as_echo "$AR" >&6; } else { $as_echo "$as_me:${as_lineno-$LINENO}: result: no" >&5 $as_echo "no" >&6; } fi test -n "$AR" && break done fi if test -z "$AR"; then ac_ct_AR=$AR for ac_prog in ar do # Extract the first word of "$ac_prog", so it can be a program name with args. set dummy $ac_prog; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } if ${ac_cv_prog_ac_ct_AR+:} false; then : $as_echo_n "(cached) " >&6 else if test -n "$ac_ct_AR"; then ac_cv_prog_ac_ct_AR="$ac_ct_AR" # Let the user override the test. else as_save_IFS=$IFS; IFS=$PATH_SEPARATOR for as_dir in $PATH do IFS=$as_save_IFS test -z "$as_dir" && as_dir=. for ac_exec_ext in '' $ac_executable_extensions; do if as_fn_executable_p "$as_dir/$ac_word$ac_exec_ext"; then ac_cv_prog_ac_ct_AR="$ac_prog" $as_echo "$as_me:${as_lineno-$LINENO}: found $as_dir/$ac_word$ac_exec_ext" >&5 break 2 fi done done IFS=$as_save_IFS fi fi ac_ct_AR=$ac_cv_prog_ac_ct_AR if test -n "$ac_ct_AR"; then { $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_ct_AR" >&5 $as_echo "$ac_ct_AR" >&6; } else { $as_echo "$as_me:${as_lineno-$LINENO}: result: no" >&5 $as_echo "no" >&6; } fi test -n "$ac_ct_AR" && break done if test "x$ac_ct_AR" = x; then AR="false" else case $cross_compiling:$ac_tool_warned in yes:) { $as_echo "$as_me:${as_lineno-$LINENO}: WARNING: using cross tools not prefixed with host triplet" >&5 $as_echo "$as_me: WARNING: using cross tools not prefixed with host triplet" >&2;} ac_tool_warned=yes ;; esac AR=$ac_ct_AR fi fi : ${AR=ar} : ${AR_FLAGS=cru} { $as_echo "$as_me:${as_lineno-$LINENO}: checking for archiver @FILE support" >&5 $as_echo_n "checking for archiver @FILE support... " >&6; } if ${lt_cv_ar_at_file+:} false; then : $as_echo_n "(cached) " >&6 else lt_cv_ar_at_file=no cat confdefs.h - <<_ACEOF >conftest.$ac_ext /* end confdefs.h. */ int main () { ; return 0; } _ACEOF if ac_fn_c_try_compile "$LINENO"; then : echo conftest.$ac_objext > conftest.lst lt_ar_try='$AR $AR_FLAGS libconftest.a @conftest.lst >&5' { { eval echo "\"\$as_me\":${as_lineno-$LINENO}: \"$lt_ar_try\""; } >&5 (eval $lt_ar_try) 2>&5 ac_status=$? $as_echo "$as_me:${as_lineno-$LINENO}: \$? = $ac_status" >&5 test $ac_status = 0; } if test 0 -eq "$ac_status"; then # Ensure the archiver fails upon bogus file names. rm -f conftest.$ac_objext libconftest.a { { eval echo "\"\$as_me\":${as_lineno-$LINENO}: \"$lt_ar_try\""; } >&5 (eval $lt_ar_try) 2>&5 ac_status=$? $as_echo "$as_me:${as_lineno-$LINENO}: \$? = $ac_status" >&5 test $ac_status = 0; } if test 0 -ne "$ac_status"; then lt_cv_ar_at_file=@ fi fi rm -f conftest.* libconftest.a fi rm -f core conftest.err conftest.$ac_objext conftest.$ac_ext fi { $as_echo "$as_me:${as_lineno-$LINENO}: result: $lt_cv_ar_at_file" >&5 $as_echo "$lt_cv_ar_at_file" >&6; } if test no = "$lt_cv_ar_at_file"; then archiver_list_spec= else archiver_list_spec=$lt_cv_ar_at_file fi if test -n "$ac_tool_prefix"; then # Extract the first word of "${ac_tool_prefix}strip", so it can be a program name with args. set dummy ${ac_tool_prefix}strip; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } if ${ac_cv_prog_STRIP+:} false; then : $as_echo_n "(cached) " >&6 else if test -n "$STRIP"; then ac_cv_prog_STRIP="$STRIP" # Let the user override the test. else as_save_IFS=$IFS; IFS=$PATH_SEPARATOR for as_dir in $PATH do IFS=$as_save_IFS test -z "$as_dir" && as_dir=. for ac_exec_ext in '' $ac_executable_extensions; do if as_fn_executable_p "$as_dir/$ac_word$ac_exec_ext"; then ac_cv_prog_STRIP="${ac_tool_prefix}strip" $as_echo "$as_me:${as_lineno-$LINENO}: found $as_dir/$ac_word$ac_exec_ext" >&5 break 2 fi done done IFS=$as_save_IFS fi fi STRIP=$ac_cv_prog_STRIP if test -n "$STRIP"; then { $as_echo "$as_me:${as_lineno-$LINENO}: result: $STRIP" >&5 $as_echo "$STRIP" >&6; } else { $as_echo "$as_me:${as_lineno-$LINENO}: result: no" >&5 $as_echo "no" >&6; } fi fi if test -z "$ac_cv_prog_STRIP"; then ac_ct_STRIP=$STRIP # Extract the first word of "strip", so it can be a program name with args. set dummy strip; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } if ${ac_cv_prog_ac_ct_STRIP+:} false; then : $as_echo_n "(cached) " >&6 else if test -n "$ac_ct_STRIP"; then ac_cv_prog_ac_ct_STRIP="$ac_ct_STRIP" # Let the user override the test. else as_save_IFS=$IFS; IFS=$PATH_SEPARATOR for as_dir in $PATH do IFS=$as_save_IFS test -z "$as_dir" && as_dir=. for ac_exec_ext in '' $ac_executable_extensions; do if as_fn_executable_p "$as_dir/$ac_word$ac_exec_ext"; then ac_cv_prog_ac_ct_STRIP="strip" $as_echo "$as_me:${as_lineno-$LINENO}: found $as_dir/$ac_word$ac_exec_ext" >&5 break 2 fi done done IFS=$as_save_IFS fi fi ac_ct_STRIP=$ac_cv_prog_ac_ct_STRIP if test -n "$ac_ct_STRIP"; then { $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_ct_STRIP" >&5 $as_echo "$ac_ct_STRIP" >&6; } else { $as_echo "$as_me:${as_lineno-$LINENO}: result: no" >&5 $as_echo "no" >&6; } fi if test "x$ac_ct_STRIP" = x; then STRIP=":" else case $cross_compiling:$ac_tool_warned in yes:) { $as_echo "$as_me:${as_lineno-$LINENO}: WARNING: using cross tools not prefixed with host triplet" >&5 $as_echo "$as_me: WARNING: using cross tools not prefixed with host triplet" >&2;} ac_tool_warned=yes ;; esac STRIP=$ac_ct_STRIP fi else STRIP="$ac_cv_prog_STRIP" fi test -z "$STRIP" && STRIP=: if test -n "$ac_tool_prefix"; then # Extract the first word of "${ac_tool_prefix}ranlib", so it can be a program name with args. set dummy ${ac_tool_prefix}ranlib; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } if ${ac_cv_prog_RANLIB+:} false; then : $as_echo_n "(cached) " >&6 else if test -n "$RANLIB"; then ac_cv_prog_RANLIB="$RANLIB" # Let the user override the test. else as_save_IFS=$IFS; IFS=$PATH_SEPARATOR for as_dir in $PATH do IFS=$as_save_IFS test -z "$as_dir" && as_dir=. for ac_exec_ext in '' $ac_executable_extensions; do if as_fn_executable_p "$as_dir/$ac_word$ac_exec_ext"; then ac_cv_prog_RANLIB="${ac_tool_prefix}ranlib" $as_echo "$as_me:${as_lineno-$LINENO}: found $as_dir/$ac_word$ac_exec_ext" >&5 break 2 fi done done IFS=$as_save_IFS fi fi RANLIB=$ac_cv_prog_RANLIB if test -n "$RANLIB"; then { $as_echo "$as_me:${as_lineno-$LINENO}: result: $RANLIB" >&5 $as_echo "$RANLIB" >&6; } else { $as_echo "$as_me:${as_lineno-$LINENO}: result: no" >&5 $as_echo "no" >&6; } fi fi if test -z "$ac_cv_prog_RANLIB"; then ac_ct_RANLIB=$RANLIB # Extract the first word of "ranlib", so it can be a program name with args. set dummy ranlib; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } if ${ac_cv_prog_ac_ct_RANLIB+:} false; then : $as_echo_n "(cached) " >&6 else if test -n "$ac_ct_RANLIB"; then ac_cv_prog_ac_ct_RANLIB="$ac_ct_RANLIB" # Let the user override the test. else as_save_IFS=$IFS; IFS=$PATH_SEPARATOR for as_dir in $PATH do IFS=$as_save_IFS test -z "$as_dir" && as_dir=. for ac_exec_ext in '' $ac_executable_extensions; do if as_fn_executable_p "$as_dir/$ac_word$ac_exec_ext"; then ac_cv_prog_ac_ct_RANLIB="ranlib" $as_echo "$as_me:${as_lineno-$LINENO}: found $as_dir/$ac_word$ac_exec_ext" >&5 break 2 fi done done IFS=$as_save_IFS fi fi ac_ct_RANLIB=$ac_cv_prog_ac_ct_RANLIB if test -n "$ac_ct_RANLIB"; then { $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_ct_RANLIB" >&5 $as_echo "$ac_ct_RANLIB" >&6; } else { $as_echo "$as_me:${as_lineno-$LINENO}: result: no" >&5 $as_echo "no" >&6; } fi if test "x$ac_ct_RANLIB" = x; then RANLIB=":" else case $cross_compiling:$ac_tool_warned in yes:) { $as_echo "$as_me:${as_lineno-$LINENO}: WARNING: using cross tools not prefixed with host triplet" >&5 $as_echo "$as_me: WARNING: using cross tools not prefixed with host triplet" >&2;} ac_tool_warned=yes ;; esac RANLIB=$ac_ct_RANLIB fi else RANLIB="$ac_cv_prog_RANLIB" fi test -z "$RANLIB" && RANLIB=: # Determine commands to create old-style static archives. old_archive_cmds='$AR $AR_FLAGS $oldlib$oldobjs' old_postinstall_cmds='chmod 644 $oldlib' old_postuninstall_cmds= if test -n "$RANLIB"; then case $host_os in bitrig* | openbsd*) old_postinstall_cmds="$old_postinstall_cmds~\$RANLIB -t \$tool_oldlib" ;; *) old_postinstall_cmds="$old_postinstall_cmds~\$RANLIB \$tool_oldlib" ;; esac old_archive_cmds="$old_archive_cmds~\$RANLIB \$tool_oldlib" fi case $host_os in darwin*) lock_old_archive_extraction=yes ;; *) lock_old_archive_extraction=no ;; esac # If no C compiler was specified, use CC. LTCC=${LTCC-"$CC"} # If no C compiler flags were specified, use CFLAGS. LTCFLAGS=${LTCFLAGS-"$CFLAGS"} # Allow CC to be a program name with arguments. compiler=$CC # Check for command to grab the raw symbol name followed by C symbol from nm. { $as_echo "$as_me:${as_lineno-$LINENO}: checking command to parse $NM output from $compiler object" >&5 $as_echo_n "checking command to parse $NM output from $compiler object... " >&6; } if ${lt_cv_sys_global_symbol_pipe+:} false; then : $as_echo_n "(cached) " >&6 else # These are sane defaults that work on at least a few old systems. # [They come from Ultrix. What could be older than Ultrix?!! ;)] # Character class describing NM global symbol codes. symcode='[BCDEGRST]' # Regexp to match symbols that can be accessed directly from C. sympat='\([_A-Za-z][_A-Za-z0-9]*\)' # Define system-specific variables. case $host_os in aix*) symcode='[BCDT]' ;; cygwin* | mingw* | pw32* | cegcc*) symcode='[ABCDGISTW]' ;; hpux*) if test ia64 = "$host_cpu"; then symcode='[ABCDEGRST]' fi ;; irix* | nonstopux*) symcode='[BCDEGRST]' ;; osf*) symcode='[BCDEGQRST]' ;; solaris*) symcode='[BDRT]' ;; sco3.2v5*) symcode='[DT]' ;; sysv4.2uw2*) symcode='[DT]' ;; sysv5* | sco5v6* | unixware* | OpenUNIX*) symcode='[ABDT]' ;; sysv4) symcode='[DFNSTU]' ;; esac # If we're using GNU nm, then use its standard symbol codes. case `$NM -V 2>&1` in *GNU* | *'with BFD'*) symcode='[ABCDGIRSTW]' ;; esac if test "$lt_cv_nm_interface" = "MS dumpbin"; then # Gets list of data symbols to import. lt_cv_sys_global_symbol_to_import="sed -n -e 's/^I .* \(.*\)$/\1/p'" # Adjust the below global symbol transforms to fixup imported variables. lt_cdecl_hook=" -e 's/^I .* \(.*\)$/extern __declspec(dllimport) char \1;/p'" lt_c_name_hook=" -e 's/^I .* \(.*\)$/ {\"\1\", (void *) 0},/p'" lt_c_name_lib_hook="\ -e 's/^I .* \(lib.*\)$/ {\"\1\", (void *) 0},/p'\ -e 's/^I .* \(.*\)$/ {\"lib\1\", (void *) 0},/p'" else # Disable hooks by default. lt_cv_sys_global_symbol_to_import= lt_cdecl_hook= lt_c_name_hook= lt_c_name_lib_hook= fi # Transform an extracted symbol line into a proper C declaration. # Some systems (esp. on ia64) link data and code symbols differently, # so use this general approach. lt_cv_sys_global_symbol_to_cdecl="sed -n"\ $lt_cdecl_hook\ " -e 's/^T .* \(.*\)$/extern int \1();/p'"\ " -e 's/^$symcode$symcode* .* \(.*\)$/extern char \1;/p'" # Transform an extracted symbol line into symbol name and symbol address lt_cv_sys_global_symbol_to_c_name_address="sed -n"\ $lt_c_name_hook\ " -e 's/^: \(.*\) .*$/ {\"\1\", (void *) 0},/p'"\ " -e 's/^$symcode$symcode* .* \(.*\)$/ {\"\1\", (void *) \&\1},/p'" # Transform an extracted symbol line into symbol name with lib prefix and # symbol address. lt_cv_sys_global_symbol_to_c_name_address_lib_prefix="sed -n"\ $lt_c_name_lib_hook\ " -e 's/^: \(.*\) .*$/ {\"\1\", (void *) 0},/p'"\ " -e 's/^$symcode$symcode* .* \(lib.*\)$/ {\"\1\", (void *) \&\1},/p'"\ " -e 's/^$symcode$symcode* .* \(.*\)$/ {\"lib\1\", (void *) \&\1},/p'" # Handle CRLF in mingw tool chain opt_cr= case $build_os in mingw*) opt_cr=`$ECHO 'x\{0,1\}' | tr x '\015'` # option cr in regexp ;; esac # Try without a prefix underscore, then with it. for ac_symprfx in "" "_"; do # Transform symcode, sympat, and symprfx into a raw symbol and a C symbol. symxfrm="\\1 $ac_symprfx\\2 \\2" # Write the raw and C identifiers. if test "$lt_cv_nm_interface" = "MS dumpbin"; then # Fake it for dumpbin and say T for any non-static function, # D for any global variable and I for any imported variable. # Also find C++ and __fastcall symbols from MSVC++, # which start with @ or ?. lt_cv_sys_global_symbol_pipe="$AWK '"\ " {last_section=section; section=\$ 3};"\ " /^COFF SYMBOL TABLE/{for(i in hide) delete hide[i]};"\ " /Section length .*#relocs.*(pick any)/{hide[last_section]=1};"\ " /^ *Symbol name *: /{split(\$ 0,sn,\":\"); si=substr(sn[2],2)};"\ " /^ *Type *: code/{print \"T\",si,substr(si,length(prfx))};"\ " /^ *Type *: data/{print \"I\",si,substr(si,length(prfx))};"\ " \$ 0!~/External *\|/{next};"\ " / 0+ UNDEF /{next}; / UNDEF \([^|]\)*()/{next};"\ " {if(hide[section]) next};"\ " {f=\"D\"}; \$ 0~/\(\).*\|/{f=\"T\"};"\ " {split(\$ 0,a,/\||\r/); split(a[2],s)};"\ " s[1]~/^[@?]/{print f,s[1],s[1]; next};"\ " s[1]~prfx {split(s[1],t,\"@\"); print f,t[1],substr(t[1],length(prfx))}"\ " ' prfx=^$ac_symprfx" else lt_cv_sys_global_symbol_pipe="sed -n -e 's/^.*[ ]\($symcode$symcode*\)[ ][ ]*$ac_symprfx$sympat$opt_cr$/$symxfrm/p'" fi lt_cv_sys_global_symbol_pipe="$lt_cv_sys_global_symbol_pipe | sed '/ __gnu_lto/d'" # Check to see that the pipe works correctly. pipe_works=no rm -f conftest* cat > conftest.$ac_ext <<_LT_EOF #ifdef __cplusplus extern "C" { #endif char nm_test_var; void nm_test_func(void); void nm_test_func(void){} #ifdef __cplusplus } #endif int main(){nm_test_var='a';nm_test_func();return(0);} _LT_EOF if { { eval echo "\"\$as_me\":${as_lineno-$LINENO}: \"$ac_compile\""; } >&5 (eval $ac_compile) 2>&5 ac_status=$? $as_echo "$as_me:${as_lineno-$LINENO}: \$? = $ac_status" >&5 test $ac_status = 0; }; then # Now try to grab the symbols. nlist=conftest.nm if { { eval echo "\"\$as_me\":${as_lineno-$LINENO}: \"$NM conftest.$ac_objext \| "$lt_cv_sys_global_symbol_pipe" \> $nlist\""; } >&5 (eval $NM conftest.$ac_objext \| "$lt_cv_sys_global_symbol_pipe" \> $nlist) 2>&5 ac_status=$? $as_echo "$as_me:${as_lineno-$LINENO}: \$? = $ac_status" >&5 test $ac_status = 0; } && test -s "$nlist"; then # Try sorting and uniquifying the output. if sort "$nlist" | uniq > "$nlist"T; then mv -f "$nlist"T "$nlist" else rm -f "$nlist"T fi # Make sure that we snagged all the symbols we need. if $GREP ' nm_test_var$' "$nlist" >/dev/null; then if $GREP ' nm_test_func$' "$nlist" >/dev/null; then cat <<_LT_EOF > conftest.$ac_ext /* Keep this code in sync between libtool.m4, ltmain, lt_system.h, and tests. */ #if defined _WIN32 || defined __CYGWIN__ || defined _WIN32_WCE /* DATA imports from DLLs on WIN32 can't be const, because runtime relocations are performed -- see ld's documentation on pseudo-relocs. */ # define LT_DLSYM_CONST #elif defined __osf__ /* This system does not cope well with relocations in const data. */ # define LT_DLSYM_CONST #else # define LT_DLSYM_CONST const #endif #ifdef __cplusplus extern "C" { #endif _LT_EOF # Now generate the symbol file. eval "$lt_cv_sys_global_symbol_to_cdecl"' < "$nlist" | $GREP -v main >> conftest.$ac_ext' cat <<_LT_EOF >> conftest.$ac_ext /* The mapping between symbol names and symbols. */ LT_DLSYM_CONST struct { const char *name; void *address; } lt__PROGRAM__LTX_preloaded_symbols[] = { { "@PROGRAM@", (void *) 0 }, _LT_EOF $SED "s/^$symcode$symcode* .* \(.*\)$/ {\"\1\", (void *) \&\1},/" < "$nlist" | $GREP -v main >> conftest.$ac_ext cat <<\_LT_EOF >> conftest.$ac_ext {0, (void *) 0} }; /* This works around a problem in FreeBSD linker */ #ifdef FREEBSD_WORKAROUND static const void *lt_preloaded_setup() { return lt__PROGRAM__LTX_preloaded_symbols; } #endif #ifdef __cplusplus } #endif _LT_EOF # Now try linking the two files. mv conftest.$ac_objext conftstm.$ac_objext lt_globsym_save_LIBS=$LIBS lt_globsym_save_CFLAGS=$CFLAGS LIBS=conftstm.$ac_objext CFLAGS="$CFLAGS$lt_prog_compiler_no_builtin_flag" if { { eval echo "\"\$as_me\":${as_lineno-$LINENO}: \"$ac_link\""; } >&5 (eval $ac_link) 2>&5 ac_status=$? $as_echo "$as_me:${as_lineno-$LINENO}: \$? = $ac_status" >&5 test $ac_status = 0; } && test -s conftest$ac_exeext; then pipe_works=yes fi LIBS=$lt_globsym_save_LIBS CFLAGS=$lt_globsym_save_CFLAGS else echo "cannot find nm_test_func in $nlist" >&5 fi else echo "cannot find nm_test_var in $nlist" >&5 fi else echo "cannot run $lt_cv_sys_global_symbol_pipe" >&5 fi else echo "$progname: failed program was:" >&5 cat conftest.$ac_ext >&5 fi rm -rf conftest* conftst* # Do not use the global_symbol_pipe unless it works. if test yes = "$pipe_works"; then break else lt_cv_sys_global_symbol_pipe= fi done fi if test -z "$lt_cv_sys_global_symbol_pipe"; then lt_cv_sys_global_symbol_to_cdecl= fi if test -z "$lt_cv_sys_global_symbol_pipe$lt_cv_sys_global_symbol_to_cdecl"; then { $as_echo "$as_me:${as_lineno-$LINENO}: result: failed" >&5 $as_echo "failed" >&6; } else { $as_echo "$as_me:${as_lineno-$LINENO}: result: ok" >&5 $as_echo "ok" >&6; } fi # Response file support. if test "$lt_cv_nm_interface" = "MS dumpbin"; then nm_file_list_spec='@' elif $NM --help 2>/dev/null | grep '[@]FILE' >/dev/null; then nm_file_list_spec='@' fi { $as_echo "$as_me:${as_lineno-$LINENO}: checking for sysroot" >&5 $as_echo_n "checking for sysroot... " >&6; } # Check whether --with-sysroot was given. if test "${with_sysroot+set}" = set; then : withval=$with_sysroot; else with_sysroot=no fi lt_sysroot= case $with_sysroot in #( yes) if test yes = "$GCC"; then lt_sysroot=`$CC --print-sysroot 2>/dev/null` fi ;; #( /*) lt_sysroot=`echo "$with_sysroot" | sed -e "$sed_quote_subst"` ;; #( no|'') ;; #( *) { $as_echo "$as_me:${as_lineno-$LINENO}: result: $with_sysroot" >&5 $as_echo "$with_sysroot" >&6; } as_fn_error $? "The sysroot must be an absolute path." "$LINENO" 5 ;; esac { $as_echo "$as_me:${as_lineno-$LINENO}: result: ${lt_sysroot:-no}" >&5 $as_echo "${lt_sysroot:-no}" >&6; } { $as_echo "$as_me:${as_lineno-$LINENO}: checking for a working dd" >&5 $as_echo_n "checking for a working dd... " >&6; } if ${ac_cv_path_lt_DD+:} false; then : $as_echo_n "(cached) " >&6 else printf 0123456789abcdef0123456789abcdef >conftest.i cat conftest.i conftest.i >conftest2.i : ${lt_DD:=$DD} if test -z "$lt_DD"; then ac_path_lt_DD_found=false # Loop through the user's path and test for each of PROGNAME-LIST as_save_IFS=$IFS; IFS=$PATH_SEPARATOR for as_dir in $PATH do IFS=$as_save_IFS test -z "$as_dir" && as_dir=. for ac_prog in dd; do for ac_exec_ext in '' $ac_executable_extensions; do ac_path_lt_DD="$as_dir/$ac_prog$ac_exec_ext" as_fn_executable_p "$ac_path_lt_DD" || continue if "$ac_path_lt_DD" bs=32 count=1 conftest.out 2>/dev/null; then cmp -s conftest.i conftest.out \ && ac_cv_path_lt_DD="$ac_path_lt_DD" ac_path_lt_DD_found=: fi $ac_path_lt_DD_found && break 3 done done done IFS=$as_save_IFS if test -z "$ac_cv_path_lt_DD"; then : fi else ac_cv_path_lt_DD=$lt_DD fi rm -f conftest.i conftest2.i conftest.out fi { $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_cv_path_lt_DD" >&5 $as_echo "$ac_cv_path_lt_DD" >&6; } { $as_echo "$as_me:${as_lineno-$LINENO}: checking how to truncate binary pipes" >&5 $as_echo_n "checking how to truncate binary pipes... " >&6; } if ${lt_cv_truncate_bin+:} false; then : $as_echo_n "(cached) " >&6 else printf 0123456789abcdef0123456789abcdef >conftest.i cat conftest.i conftest.i >conftest2.i lt_cv_truncate_bin= if "$ac_cv_path_lt_DD" bs=32 count=1 conftest.out 2>/dev/null; then cmp -s conftest.i conftest.out \ && lt_cv_truncate_bin="$ac_cv_path_lt_DD bs=4096 count=1" fi rm -f conftest.i conftest2.i conftest.out test -z "$lt_cv_truncate_bin" && lt_cv_truncate_bin="$SED -e 4q" fi { $as_echo "$as_me:${as_lineno-$LINENO}: result: $lt_cv_truncate_bin" >&5 $as_echo "$lt_cv_truncate_bin" >&6; } # Calculate cc_basename. Skip known compiler wrappers and cross-prefix. func_cc_basename () { for cc_temp in $*""; do case $cc_temp in compile | *[\\/]compile | ccache | *[\\/]ccache ) ;; distcc | *[\\/]distcc | purify | *[\\/]purify ) ;; \-*) ;; *) break;; esac done func_cc_basename_result=`$ECHO "$cc_temp" | $SED "s%.*/%%; s%^$host_alias-%%"` } # Check whether --enable-libtool-lock was given. if test "${enable_libtool_lock+set}" = set; then : enableval=$enable_libtool_lock; fi test no = "$enable_libtool_lock" || enable_libtool_lock=yes # Some flags need to be propagated to the compiler or linker for good # libtool support. case $host in ia64-*-hpux*) # Find out what ABI is being produced by ac_compile, and set mode # options accordingly. echo 'int i;' > conftest.$ac_ext if { { eval echo "\"\$as_me\":${as_lineno-$LINENO}: \"$ac_compile\""; } >&5 (eval $ac_compile) 2>&5 ac_status=$? $as_echo "$as_me:${as_lineno-$LINENO}: \$? = $ac_status" >&5 test $ac_status = 0; }; then case `/usr/bin/file conftest.$ac_objext` in *ELF-32*) HPUX_IA64_MODE=32 ;; *ELF-64*) HPUX_IA64_MODE=64 ;; esac fi rm -rf conftest* ;; *-*-irix6*) # Find out what ABI is being produced by ac_compile, and set linker # options accordingly. echo '#line '$LINENO' "configure"' > conftest.$ac_ext if { { eval echo "\"\$as_me\":${as_lineno-$LINENO}: \"$ac_compile\""; } >&5 (eval $ac_compile) 2>&5 ac_status=$? $as_echo "$as_me:${as_lineno-$LINENO}: \$? = $ac_status" >&5 test $ac_status = 0; }; then if test yes = "$lt_cv_prog_gnu_ld"; then case `/usr/bin/file conftest.$ac_objext` in *32-bit*) LD="${LD-ld} -melf32bsmip" ;; *N32*) LD="${LD-ld} -melf32bmipn32" ;; *64-bit*) LD="${LD-ld} -melf64bmip" ;; esac else case `/usr/bin/file conftest.$ac_objext` in *32-bit*) LD="${LD-ld} -32" ;; *N32*) LD="${LD-ld} -n32" ;; *64-bit*) LD="${LD-ld} -64" ;; esac fi fi rm -rf conftest* ;; mips64*-*linux*) # Find out what ABI is being produced by ac_compile, and set linker # options accordingly. echo '#line '$LINENO' "configure"' > conftest.$ac_ext if { { eval echo "\"\$as_me\":${as_lineno-$LINENO}: \"$ac_compile\""; } >&5 (eval $ac_compile) 2>&5 ac_status=$? $as_echo "$as_me:${as_lineno-$LINENO}: \$? = $ac_status" >&5 test $ac_status = 0; }; then emul=elf case `/usr/bin/file conftest.$ac_objext` in *32-bit*) emul="${emul}32" ;; *64-bit*) emul="${emul}64" ;; esac case `/usr/bin/file conftest.$ac_objext` in *MSB*) emul="${emul}btsmip" ;; *LSB*) emul="${emul}ltsmip" ;; esac case `/usr/bin/file conftest.$ac_objext` in *N32*) emul="${emul}n32" ;; esac LD="${LD-ld} -m $emul" fi rm -rf conftest* ;; x86_64-*kfreebsd*-gnu|x86_64-*linux*|powerpc*-*linux*| \ s390*-*linux*|s390*-*tpf*|sparc*-*linux*) # Find out what ABI is being produced by ac_compile, and set linker # options accordingly. Note that the listed cases only cover the # situations where additional linker options are needed (such as when # doing 32-bit compilation for a host where ld defaults to 64-bit, or # vice versa); the common cases where no linker options are needed do # not appear in the list. echo 'int i;' > conftest.$ac_ext if { { eval echo "\"\$as_me\":${as_lineno-$LINENO}: \"$ac_compile\""; } >&5 (eval $ac_compile) 2>&5 ac_status=$? $as_echo "$as_me:${as_lineno-$LINENO}: \$? = $ac_status" >&5 test $ac_status = 0; }; then case `/usr/bin/file conftest.o` in *32-bit*) case $host in x86_64-*kfreebsd*-gnu) LD="${LD-ld} -m elf_i386_fbsd" ;; x86_64-*linux*) case `/usr/bin/file conftest.o` in *x86-64*) LD="${LD-ld} -m elf32_x86_64" ;; *) LD="${LD-ld} -m elf_i386" ;; esac ;; powerpc64le-*linux*) LD="${LD-ld} -m elf32lppclinux" ;; powerpc64-*linux*) LD="${LD-ld} -m elf32ppclinux" ;; s390x-*linux*) LD="${LD-ld} -m elf_s390" ;; sparc64-*linux*) LD="${LD-ld} -m elf32_sparc" ;; esac ;; *64-bit*) case $host in x86_64-*kfreebsd*-gnu) LD="${LD-ld} -m elf_x86_64_fbsd" ;; x86_64-*linux*) LD="${LD-ld} -m elf_x86_64" ;; powerpcle-*linux*) LD="${LD-ld} -m elf64lppc" ;; powerpc-*linux*) LD="${LD-ld} -m elf64ppc" ;; s390*-*linux*|s390*-*tpf*) LD="${LD-ld} -m elf64_s390" ;; sparc*-*linux*) LD="${LD-ld} -m elf64_sparc" ;; esac ;; esac fi rm -rf conftest* ;; *-*-sco3.2v5*) # On SCO OpenServer 5, we need -belf to get full-featured binaries. SAVE_CFLAGS=$CFLAGS CFLAGS="$CFLAGS -belf" { $as_echo "$as_me:${as_lineno-$LINENO}: checking whether the C compiler needs -belf" >&5 $as_echo_n "checking whether the C compiler needs -belf... " >&6; } if ${lt_cv_cc_needs_belf+:} false; then : $as_echo_n "(cached) " >&6 else ac_ext=c ac_cpp='$CPP $CPPFLAGS' ac_compile='$CC -c $CFLAGS $CPPFLAGS conftest.$ac_ext >&5' ac_link='$CC -o conftest$ac_exeext $CFLAGS $CPPFLAGS $LDFLAGS conftest.$ac_ext $LIBS >&5' ac_compiler_gnu=$ac_cv_c_compiler_gnu cat confdefs.h - <<_ACEOF >conftest.$ac_ext /* end confdefs.h. */ int main () { ; return 0; } _ACEOF if ac_fn_c_try_link "$LINENO"; then : lt_cv_cc_needs_belf=yes else lt_cv_cc_needs_belf=no fi rm -f core conftest.err conftest.$ac_objext \ conftest$ac_exeext conftest.$ac_ext ac_ext=c ac_cpp='$CPP $CPPFLAGS' ac_compile='$CC -c $CFLAGS $CPPFLAGS conftest.$ac_ext >&5' ac_link='$CC -o conftest$ac_exeext $CFLAGS $CPPFLAGS $LDFLAGS conftest.$ac_ext $LIBS >&5' ac_compiler_gnu=$ac_cv_c_compiler_gnu fi { $as_echo "$as_me:${as_lineno-$LINENO}: result: $lt_cv_cc_needs_belf" >&5 $as_echo "$lt_cv_cc_needs_belf" >&6; } if test yes != "$lt_cv_cc_needs_belf"; then # this is probably gcc 2.8.0, egcs 1.0 or newer; no need for -belf CFLAGS=$SAVE_CFLAGS fi ;; *-*solaris*) # Find out what ABI is being produced by ac_compile, and set linker # options accordingly. echo 'int i;' > conftest.$ac_ext if { { eval echo "\"\$as_me\":${as_lineno-$LINENO}: \"$ac_compile\""; } >&5 (eval $ac_compile) 2>&5 ac_status=$? $as_echo "$as_me:${as_lineno-$LINENO}: \$? = $ac_status" >&5 test $ac_status = 0; }; then case `/usr/bin/file conftest.o` in *64-bit*) case $lt_cv_prog_gnu_ld in yes*) case $host in i?86-*-solaris*|x86_64-*-solaris*) LD="${LD-ld} -m elf_x86_64" ;; sparc*-*-solaris*) LD="${LD-ld} -m elf64_sparc" ;; esac # GNU ld 2.21 introduced _sol2 emulations. Use them if available. if ${LD-ld} -V | grep _sol2 >/dev/null 2>&1; then LD=${LD-ld}_sol2 fi ;; *) if ${LD-ld} -64 -r -o conftest2.o conftest.o >/dev/null 2>&1; then LD="${LD-ld} -64" fi ;; esac ;; esac fi rm -rf conftest* ;; esac need_locks=$enable_libtool_lock if test -n "$ac_tool_prefix"; then # Extract the first word of "${ac_tool_prefix}mt", so it can be a program name with args. set dummy ${ac_tool_prefix}mt; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } if ${ac_cv_prog_MANIFEST_TOOL+:} false; then : $as_echo_n "(cached) " >&6 else if test -n "$MANIFEST_TOOL"; then ac_cv_prog_MANIFEST_TOOL="$MANIFEST_TOOL" # Let the user override the test. else as_save_IFS=$IFS; IFS=$PATH_SEPARATOR for as_dir in $PATH do IFS=$as_save_IFS test -z "$as_dir" && as_dir=. for ac_exec_ext in '' $ac_executable_extensions; do if as_fn_executable_p "$as_dir/$ac_word$ac_exec_ext"; then ac_cv_prog_MANIFEST_TOOL="${ac_tool_prefix}mt" $as_echo "$as_me:${as_lineno-$LINENO}: found $as_dir/$ac_word$ac_exec_ext" >&5 break 2 fi done done IFS=$as_save_IFS fi fi MANIFEST_TOOL=$ac_cv_prog_MANIFEST_TOOL if test -n "$MANIFEST_TOOL"; then { $as_echo "$as_me:${as_lineno-$LINENO}: result: $MANIFEST_TOOL" >&5 $as_echo "$MANIFEST_TOOL" >&6; } else { $as_echo "$as_me:${as_lineno-$LINENO}: result: no" >&5 $as_echo "no" >&6; } fi fi if test -z "$ac_cv_prog_MANIFEST_TOOL"; then ac_ct_MANIFEST_TOOL=$MANIFEST_TOOL # Extract the first word of "mt", so it can be a program name with args. set dummy mt; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } if ${ac_cv_prog_ac_ct_MANIFEST_TOOL+:} false; then : $as_echo_n "(cached) " >&6 else if test -n "$ac_ct_MANIFEST_TOOL"; then ac_cv_prog_ac_ct_MANIFEST_TOOL="$ac_ct_MANIFEST_TOOL" # Let the user override the test. else as_save_IFS=$IFS; IFS=$PATH_SEPARATOR for as_dir in $PATH do IFS=$as_save_IFS test -z "$as_dir" && as_dir=. for ac_exec_ext in '' $ac_executable_extensions; do if as_fn_executable_p "$as_dir/$ac_word$ac_exec_ext"; then ac_cv_prog_ac_ct_MANIFEST_TOOL="mt" $as_echo "$as_me:${as_lineno-$LINENO}: found $as_dir/$ac_word$ac_exec_ext" >&5 break 2 fi done done IFS=$as_save_IFS fi fi ac_ct_MANIFEST_TOOL=$ac_cv_prog_ac_ct_MANIFEST_TOOL if test -n "$ac_ct_MANIFEST_TOOL"; then { $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_ct_MANIFEST_TOOL" >&5 $as_echo "$ac_ct_MANIFEST_TOOL" >&6; } else { $as_echo "$as_me:${as_lineno-$LINENO}: result: no" >&5 $as_echo "no" >&6; } fi if test "x$ac_ct_MANIFEST_TOOL" = x; then MANIFEST_TOOL=":" else case $cross_compiling:$ac_tool_warned in yes:) { $as_echo "$as_me:${as_lineno-$LINENO}: WARNING: using cross tools not prefixed with host triplet" >&5 $as_echo "$as_me: WARNING: using cross tools not prefixed with host triplet" >&2;} ac_tool_warned=yes ;; esac MANIFEST_TOOL=$ac_ct_MANIFEST_TOOL fi else MANIFEST_TOOL="$ac_cv_prog_MANIFEST_TOOL" fi test -z "$MANIFEST_TOOL" && MANIFEST_TOOL=mt { $as_echo "$as_me:${as_lineno-$LINENO}: checking if $MANIFEST_TOOL is a manifest tool" >&5 $as_echo_n "checking if $MANIFEST_TOOL is a manifest tool... " >&6; } if ${lt_cv_path_mainfest_tool+:} false; then : $as_echo_n "(cached) " >&6 else lt_cv_path_mainfest_tool=no echo "$as_me:$LINENO: $MANIFEST_TOOL '-?'" >&5 $MANIFEST_TOOL '-?' 2>conftest.err > conftest.out cat conftest.err >&5 if $GREP 'Manifest Tool' conftest.out > /dev/null; then lt_cv_path_mainfest_tool=yes fi rm -f conftest* fi { $as_echo "$as_me:${as_lineno-$LINENO}: result: $lt_cv_path_mainfest_tool" >&5 $as_echo "$lt_cv_path_mainfest_tool" >&6; } if test yes != "$lt_cv_path_mainfest_tool"; then MANIFEST_TOOL=: fi case $host_os in rhapsody* | darwin*) if test -n "$ac_tool_prefix"; then # Extract the first word of "${ac_tool_prefix}dsymutil", so it can be a program name with args. set dummy ${ac_tool_prefix}dsymutil; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } if ${ac_cv_prog_DSYMUTIL+:} false; then : $as_echo_n "(cached) " >&6 else if test -n "$DSYMUTIL"; then ac_cv_prog_DSYMUTIL="$DSYMUTIL" # Let the user override the test. else as_save_IFS=$IFS; IFS=$PATH_SEPARATOR for as_dir in $PATH do IFS=$as_save_IFS test -z "$as_dir" && as_dir=. for ac_exec_ext in '' $ac_executable_extensions; do if as_fn_executable_p "$as_dir/$ac_word$ac_exec_ext"; then ac_cv_prog_DSYMUTIL="${ac_tool_prefix}dsymutil" $as_echo "$as_me:${as_lineno-$LINENO}: found $as_dir/$ac_word$ac_exec_ext" >&5 break 2 fi done done IFS=$as_save_IFS fi fi DSYMUTIL=$ac_cv_prog_DSYMUTIL if test -n "$DSYMUTIL"; then { $as_echo "$as_me:${as_lineno-$LINENO}: result: $DSYMUTIL" >&5 $as_echo "$DSYMUTIL" >&6; } else { $as_echo "$as_me:${as_lineno-$LINENO}: result: no" >&5 $as_echo "no" >&6; } fi fi if test -z "$ac_cv_prog_DSYMUTIL"; then ac_ct_DSYMUTIL=$DSYMUTIL # Extract the first word of "dsymutil", so it can be a program name with args. set dummy dsymutil; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } if ${ac_cv_prog_ac_ct_DSYMUTIL+:} false; then : $as_echo_n "(cached) " >&6 else if test -n "$ac_ct_DSYMUTIL"; then ac_cv_prog_ac_ct_DSYMUTIL="$ac_ct_DSYMUTIL" # Let the user override the test. else as_save_IFS=$IFS; IFS=$PATH_SEPARATOR for as_dir in $PATH do IFS=$as_save_IFS test -z "$as_dir" && as_dir=. for ac_exec_ext in '' $ac_executable_extensions; do if as_fn_executable_p "$as_dir/$ac_word$ac_exec_ext"; then ac_cv_prog_ac_ct_DSYMUTIL="dsymutil" $as_echo "$as_me:${as_lineno-$LINENO}: found $as_dir/$ac_word$ac_exec_ext" >&5 break 2 fi done done IFS=$as_save_IFS fi fi ac_ct_DSYMUTIL=$ac_cv_prog_ac_ct_DSYMUTIL if test -n "$ac_ct_DSYMUTIL"; then { $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_ct_DSYMUTIL" >&5 $as_echo "$ac_ct_DSYMUTIL" >&6; } else { $as_echo "$as_me:${as_lineno-$LINENO}: result: no" >&5 $as_echo "no" >&6; } fi if test "x$ac_ct_DSYMUTIL" = x; then DSYMUTIL=":" else case $cross_compiling:$ac_tool_warned in yes:) { $as_echo "$as_me:${as_lineno-$LINENO}: WARNING: using cross tools not prefixed with host triplet" >&5 $as_echo "$as_me: WARNING: using cross tools not prefixed with host triplet" >&2;} ac_tool_warned=yes ;; esac DSYMUTIL=$ac_ct_DSYMUTIL fi else DSYMUTIL="$ac_cv_prog_DSYMUTIL" fi if test -n "$ac_tool_prefix"; then # Extract the first word of "${ac_tool_prefix}nmedit", so it can be a program name with args. set dummy ${ac_tool_prefix}nmedit; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } if ${ac_cv_prog_NMEDIT+:} false; then : $as_echo_n "(cached) " >&6 else if test -n "$NMEDIT"; then ac_cv_prog_NMEDIT="$NMEDIT" # Let the user override the test. else as_save_IFS=$IFS; IFS=$PATH_SEPARATOR for as_dir in $PATH do IFS=$as_save_IFS test -z "$as_dir" && as_dir=. for ac_exec_ext in '' $ac_executable_extensions; do if as_fn_executable_p "$as_dir/$ac_word$ac_exec_ext"; then ac_cv_prog_NMEDIT="${ac_tool_prefix}nmedit" $as_echo "$as_me:${as_lineno-$LINENO}: found $as_dir/$ac_word$ac_exec_ext" >&5 break 2 fi done done IFS=$as_save_IFS fi fi NMEDIT=$ac_cv_prog_NMEDIT if test -n "$NMEDIT"; then { $as_echo "$as_me:${as_lineno-$LINENO}: result: $NMEDIT" >&5 $as_echo "$NMEDIT" >&6; } else { $as_echo "$as_me:${as_lineno-$LINENO}: result: no" >&5 $as_echo "no" >&6; } fi fi if test -z "$ac_cv_prog_NMEDIT"; then ac_ct_NMEDIT=$NMEDIT # Extract the first word of "nmedit", so it can be a program name with args. set dummy nmedit; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } if ${ac_cv_prog_ac_ct_NMEDIT+:} false; then : $as_echo_n "(cached) " >&6 else if test -n "$ac_ct_NMEDIT"; then ac_cv_prog_ac_ct_NMEDIT="$ac_ct_NMEDIT" # Let the user override the test. else as_save_IFS=$IFS; IFS=$PATH_SEPARATOR for as_dir in $PATH do IFS=$as_save_IFS test -z "$as_dir" && as_dir=. for ac_exec_ext in '' $ac_executable_extensions; do if as_fn_executable_p "$as_dir/$ac_word$ac_exec_ext"; then ac_cv_prog_ac_ct_NMEDIT="nmedit" $as_echo "$as_me:${as_lineno-$LINENO}: found $as_dir/$ac_word$ac_exec_ext" >&5 break 2 fi done done IFS=$as_save_IFS fi fi ac_ct_NMEDIT=$ac_cv_prog_ac_ct_NMEDIT if test -n "$ac_ct_NMEDIT"; then { $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_ct_NMEDIT" >&5 $as_echo "$ac_ct_NMEDIT" >&6; } else { $as_echo "$as_me:${as_lineno-$LINENO}: result: no" >&5 $as_echo "no" >&6; } fi if test "x$ac_ct_NMEDIT" = x; then NMEDIT=":" else case $cross_compiling:$ac_tool_warned in yes:) { $as_echo "$as_me:${as_lineno-$LINENO}: WARNING: using cross tools not prefixed with host triplet" >&5 $as_echo "$as_me: WARNING: using cross tools not prefixed with host triplet" >&2;} ac_tool_warned=yes ;; esac NMEDIT=$ac_ct_NMEDIT fi else NMEDIT="$ac_cv_prog_NMEDIT" fi if test -n "$ac_tool_prefix"; then # Extract the first word of "${ac_tool_prefix}lipo", so it can be a program name with args. set dummy ${ac_tool_prefix}lipo; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } if ${ac_cv_prog_LIPO+:} false; then : $as_echo_n "(cached) " >&6 else if test -n "$LIPO"; then ac_cv_prog_LIPO="$LIPO" # Let the user override the test. else as_save_IFS=$IFS; IFS=$PATH_SEPARATOR for as_dir in $PATH do IFS=$as_save_IFS test -z "$as_dir" && as_dir=. for ac_exec_ext in '' $ac_executable_extensions; do if as_fn_executable_p "$as_dir/$ac_word$ac_exec_ext"; then ac_cv_prog_LIPO="${ac_tool_prefix}lipo" $as_echo "$as_me:${as_lineno-$LINENO}: found $as_dir/$ac_word$ac_exec_ext" >&5 break 2 fi done done IFS=$as_save_IFS fi fi LIPO=$ac_cv_prog_LIPO if test -n "$LIPO"; then { $as_echo "$as_me:${as_lineno-$LINENO}: result: $LIPO" >&5 $as_echo "$LIPO" >&6; } else { $as_echo "$as_me:${as_lineno-$LINENO}: result: no" >&5 $as_echo "no" >&6; } fi fi if test -z "$ac_cv_prog_LIPO"; then ac_ct_LIPO=$LIPO # Extract the first word of "lipo", so it can be a program name with args. set dummy lipo; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } if ${ac_cv_prog_ac_ct_LIPO+:} false; then : $as_echo_n "(cached) " >&6 else if test -n "$ac_ct_LIPO"; then ac_cv_prog_ac_ct_LIPO="$ac_ct_LIPO" # Let the user override the test. else as_save_IFS=$IFS; IFS=$PATH_SEPARATOR for as_dir in $PATH do IFS=$as_save_IFS test -z "$as_dir" && as_dir=. for ac_exec_ext in '' $ac_executable_extensions; do if as_fn_executable_p "$as_dir/$ac_word$ac_exec_ext"; then ac_cv_prog_ac_ct_LIPO="lipo" $as_echo "$as_me:${as_lineno-$LINENO}: found $as_dir/$ac_word$ac_exec_ext" >&5 break 2 fi done done IFS=$as_save_IFS fi fi ac_ct_LIPO=$ac_cv_prog_ac_ct_LIPO if test -n "$ac_ct_LIPO"; then { $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_ct_LIPO" >&5 $as_echo "$ac_ct_LIPO" >&6; } else { $as_echo "$as_me:${as_lineno-$LINENO}: result: no" >&5 $as_echo "no" >&6; } fi if test "x$ac_ct_LIPO" = x; then LIPO=":" else case $cross_compiling:$ac_tool_warned in yes:) { $as_echo "$as_me:${as_lineno-$LINENO}: WARNING: using cross tools not prefixed with host triplet" >&5 $as_echo "$as_me: WARNING: using cross tools not prefixed with host triplet" >&2;} ac_tool_warned=yes ;; esac LIPO=$ac_ct_LIPO fi else LIPO="$ac_cv_prog_LIPO" fi if test -n "$ac_tool_prefix"; then # Extract the first word of "${ac_tool_prefix}otool", so it can be a program name with args. set dummy ${ac_tool_prefix}otool; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } if ${ac_cv_prog_OTOOL+:} false; then : $as_echo_n "(cached) " >&6 else if test -n "$OTOOL"; then ac_cv_prog_OTOOL="$OTOOL" # Let the user override the test. else as_save_IFS=$IFS; IFS=$PATH_SEPARATOR for as_dir in $PATH do IFS=$as_save_IFS test -z "$as_dir" && as_dir=. for ac_exec_ext in '' $ac_executable_extensions; do if as_fn_executable_p "$as_dir/$ac_word$ac_exec_ext"; then ac_cv_prog_OTOOL="${ac_tool_prefix}otool" $as_echo "$as_me:${as_lineno-$LINENO}: found $as_dir/$ac_word$ac_exec_ext" >&5 break 2 fi done done IFS=$as_save_IFS fi fi OTOOL=$ac_cv_prog_OTOOL if test -n "$OTOOL"; then { $as_echo "$as_me:${as_lineno-$LINENO}: result: $OTOOL" >&5 $as_echo "$OTOOL" >&6; } else { $as_echo "$as_me:${as_lineno-$LINENO}: result: no" >&5 $as_echo "no" >&6; } fi fi if test -z "$ac_cv_prog_OTOOL"; then ac_ct_OTOOL=$OTOOL # Extract the first word of "otool", so it can be a program name with args. set dummy otool; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } if ${ac_cv_prog_ac_ct_OTOOL+:} false; then : $as_echo_n "(cached) " >&6 else if test -n "$ac_ct_OTOOL"; then ac_cv_prog_ac_ct_OTOOL="$ac_ct_OTOOL" # Let the user override the test. else as_save_IFS=$IFS; IFS=$PATH_SEPARATOR for as_dir in $PATH do IFS=$as_save_IFS test -z "$as_dir" && as_dir=. for ac_exec_ext in '' $ac_executable_extensions; do if as_fn_executable_p "$as_dir/$ac_word$ac_exec_ext"; then ac_cv_prog_ac_ct_OTOOL="otool" $as_echo "$as_me:${as_lineno-$LINENO}: found $as_dir/$ac_word$ac_exec_ext" >&5 break 2 fi done done IFS=$as_save_IFS fi fi ac_ct_OTOOL=$ac_cv_prog_ac_ct_OTOOL if test -n "$ac_ct_OTOOL"; then { $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_ct_OTOOL" >&5 $as_echo "$ac_ct_OTOOL" >&6; } else { $as_echo "$as_me:${as_lineno-$LINENO}: result: no" >&5 $as_echo "no" >&6; } fi if test "x$ac_ct_OTOOL" = x; then OTOOL=":" else case $cross_compiling:$ac_tool_warned in yes:) { $as_echo "$as_me:${as_lineno-$LINENO}: WARNING: using cross tools not prefixed with host triplet" >&5 $as_echo "$as_me: WARNING: using cross tools not prefixed with host triplet" >&2;} ac_tool_warned=yes ;; esac OTOOL=$ac_ct_OTOOL fi else OTOOL="$ac_cv_prog_OTOOL" fi if test -n "$ac_tool_prefix"; then # Extract the first word of "${ac_tool_prefix}otool64", so it can be a program name with args. set dummy ${ac_tool_prefix}otool64; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } if ${ac_cv_prog_OTOOL64+:} false; then : $as_echo_n "(cached) " >&6 else if test -n "$OTOOL64"; then ac_cv_prog_OTOOL64="$OTOOL64" # Let the user override the test. else as_save_IFS=$IFS; IFS=$PATH_SEPARATOR for as_dir in $PATH do IFS=$as_save_IFS test -z "$as_dir" && as_dir=. for ac_exec_ext in '' $ac_executable_extensions; do if as_fn_executable_p "$as_dir/$ac_word$ac_exec_ext"; then ac_cv_prog_OTOOL64="${ac_tool_prefix}otool64" $as_echo "$as_me:${as_lineno-$LINENO}: found $as_dir/$ac_word$ac_exec_ext" >&5 break 2 fi done done IFS=$as_save_IFS fi fi OTOOL64=$ac_cv_prog_OTOOL64 if test -n "$OTOOL64"; then { $as_echo "$as_me:${as_lineno-$LINENO}: result: $OTOOL64" >&5 $as_echo "$OTOOL64" >&6; } else { $as_echo "$as_me:${as_lineno-$LINENO}: result: no" >&5 $as_echo "no" >&6; } fi fi if test -z "$ac_cv_prog_OTOOL64"; then ac_ct_OTOOL64=$OTOOL64 # Extract the first word of "otool64", so it can be a program name with args. set dummy otool64; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } if ${ac_cv_prog_ac_ct_OTOOL64+:} false; then : $as_echo_n "(cached) " >&6 else if test -n "$ac_ct_OTOOL64"; then ac_cv_prog_ac_ct_OTOOL64="$ac_ct_OTOOL64" # Let the user override the test. else as_save_IFS=$IFS; IFS=$PATH_SEPARATOR for as_dir in $PATH do IFS=$as_save_IFS test -z "$as_dir" && as_dir=. for ac_exec_ext in '' $ac_executable_extensions; do if as_fn_executable_p "$as_dir/$ac_word$ac_exec_ext"; then ac_cv_prog_ac_ct_OTOOL64="otool64" $as_echo "$as_me:${as_lineno-$LINENO}: found $as_dir/$ac_word$ac_exec_ext" >&5 break 2 fi done done IFS=$as_save_IFS fi fi ac_ct_OTOOL64=$ac_cv_prog_ac_ct_OTOOL64 if test -n "$ac_ct_OTOOL64"; then { $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_ct_OTOOL64" >&5 $as_echo "$ac_ct_OTOOL64" >&6; } else { $as_echo "$as_me:${as_lineno-$LINENO}: result: no" >&5 $as_echo "no" >&6; } fi if test "x$ac_ct_OTOOL64" = x; then OTOOL64=":" else case $cross_compiling:$ac_tool_warned in yes:) { $as_echo "$as_me:${as_lineno-$LINENO}: WARNING: using cross tools not prefixed with host triplet" >&5 $as_echo "$as_me: WARNING: using cross tools not prefixed with host triplet" >&2;} ac_tool_warned=yes ;; esac OTOOL64=$ac_ct_OTOOL64 fi else OTOOL64="$ac_cv_prog_OTOOL64" fi { $as_echo "$as_me:${as_lineno-$LINENO}: checking for -single_module linker flag" >&5 $as_echo_n "checking for -single_module linker flag... " >&6; } if ${lt_cv_apple_cc_single_mod+:} false; then : $as_echo_n "(cached) " >&6 else lt_cv_apple_cc_single_mod=no if test -z "$LT_MULTI_MODULE"; then # By default we will add the -single_module flag. You can override # by either setting the environment variable LT_MULTI_MODULE # non-empty at configure time, or by adding -multi_module to the # link flags. rm -rf libconftest.dylib* echo "int foo(void){return 1;}" > conftest.c echo "$LTCC $LTCFLAGS $LDFLAGS -o libconftest.dylib \ -dynamiclib -Wl,-single_module conftest.c" >&5 $LTCC $LTCFLAGS $LDFLAGS -o libconftest.dylib \ -dynamiclib -Wl,-single_module conftest.c 2>conftest.err _lt_result=$? # If there is a non-empty error log, and "single_module" # appears in it, assume the flag caused a linker warning if test -s conftest.err && $GREP single_module conftest.err; then cat conftest.err >&5 # Otherwise, if the output was created with a 0 exit code from # the compiler, it worked. elif test -f libconftest.dylib && test 0 = "$_lt_result"; then lt_cv_apple_cc_single_mod=yes else cat conftest.err >&5 fi rm -rf libconftest.dylib* rm -f conftest.* fi fi { $as_echo "$as_me:${as_lineno-$LINENO}: result: $lt_cv_apple_cc_single_mod" >&5 $as_echo "$lt_cv_apple_cc_single_mod" >&6; } { $as_echo "$as_me:${as_lineno-$LINENO}: checking for -exported_symbols_list linker flag" >&5 $as_echo_n "checking for -exported_symbols_list linker flag... " >&6; } if ${lt_cv_ld_exported_symbols_list+:} false; then : $as_echo_n "(cached) " >&6 else lt_cv_ld_exported_symbols_list=no save_LDFLAGS=$LDFLAGS echo "_main" > conftest.sym LDFLAGS="$LDFLAGS -Wl,-exported_symbols_list,conftest.sym" cat confdefs.h - <<_ACEOF >conftest.$ac_ext /* end confdefs.h. */ int main () { ; return 0; } _ACEOF if ac_fn_c_try_link "$LINENO"; then : lt_cv_ld_exported_symbols_list=yes else lt_cv_ld_exported_symbols_list=no fi rm -f core conftest.err conftest.$ac_objext \ conftest$ac_exeext conftest.$ac_ext LDFLAGS=$save_LDFLAGS fi { $as_echo "$as_me:${as_lineno-$LINENO}: result: $lt_cv_ld_exported_symbols_list" >&5 $as_echo "$lt_cv_ld_exported_symbols_list" >&6; } { $as_echo "$as_me:${as_lineno-$LINENO}: checking for -force_load linker flag" >&5 $as_echo_n "checking for -force_load linker flag... " >&6; } if ${lt_cv_ld_force_load+:} false; then : $as_echo_n "(cached) " >&6 else lt_cv_ld_force_load=no cat > conftest.c << _LT_EOF int forced_loaded() { return 2;} _LT_EOF echo "$LTCC $LTCFLAGS -c -o conftest.o conftest.c" >&5 $LTCC $LTCFLAGS -c -o conftest.o conftest.c 2>&5 echo "$AR cru libconftest.a conftest.o" >&5 $AR cru libconftest.a conftest.o 2>&5 echo "$RANLIB libconftest.a" >&5 $RANLIB libconftest.a 2>&5 cat > conftest.c << _LT_EOF int main() { return 0;} _LT_EOF echo "$LTCC $LTCFLAGS $LDFLAGS -o conftest conftest.c -Wl,-force_load,./libconftest.a" >&5 $LTCC $LTCFLAGS $LDFLAGS -o conftest conftest.c -Wl,-force_load,./libconftest.a 2>conftest.err _lt_result=$? if test -s conftest.err && $GREP force_load conftest.err; then cat conftest.err >&5 elif test -f conftest && test 0 = "$_lt_result" && $GREP forced_load conftest >/dev/null 2>&1; then lt_cv_ld_force_load=yes else cat conftest.err >&5 fi rm -f conftest.err libconftest.a conftest conftest.c rm -rf conftest.dSYM fi { $as_echo "$as_me:${as_lineno-$LINENO}: result: $lt_cv_ld_force_load" >&5 $as_echo "$lt_cv_ld_force_load" >&6; } case $host_os in rhapsody* | darwin1.[012]) _lt_dar_allow_undefined='$wl-undefined ${wl}suppress' ;; darwin1.*) _lt_dar_allow_undefined='$wl-flat_namespace $wl-undefined ${wl}suppress' ;; darwin*) # darwin 5.x on # if running on 10.5 or later, the deployment target defaults # to the OS version, if on x86, and 10.4, the deployment # target defaults to 10.4. Don't you love it? case ${MACOSX_DEPLOYMENT_TARGET-10.0},$host in 10.0,*86*-darwin8*|10.0,*-darwin[91]*) _lt_dar_allow_undefined='$wl-undefined ${wl}dynamic_lookup' ;; 10.[012][,.]*) _lt_dar_allow_undefined='$wl-flat_namespace $wl-undefined ${wl}suppress' ;; 10.*) _lt_dar_allow_undefined='$wl-undefined ${wl}dynamic_lookup' ;; esac ;; esac if test yes = "$lt_cv_apple_cc_single_mod"; then _lt_dar_single_mod='$single_module' fi if test yes = "$lt_cv_ld_exported_symbols_list"; then _lt_dar_export_syms=' $wl-exported_symbols_list,$output_objdir/$libname-symbols.expsym' else _lt_dar_export_syms='~$NMEDIT -s $output_objdir/$libname-symbols.expsym $lib' fi if test : != "$DSYMUTIL" && test no = "$lt_cv_ld_force_load"; then _lt_dsymutil='~$DSYMUTIL $lib || :' else _lt_dsymutil= fi ;; esac # func_munge_path_list VARIABLE PATH # ----------------------------------- # VARIABLE is name of variable containing _space_ separated list of # directories to be munged by the contents of PATH, which is string # having a format: # "DIR[:DIR]:" # string "DIR[ DIR]" will be prepended to VARIABLE # ":DIR[:DIR]" # string "DIR[ DIR]" will be appended to VARIABLE # "DIRP[:DIRP]::[DIRA:]DIRA" # string "DIRP[ DIRP]" will be prepended to VARIABLE and string # "DIRA[ DIRA]" will be appended to VARIABLE # "DIR[:DIR]" # VARIABLE will be replaced by "DIR[ DIR]" func_munge_path_list () { case x$2 in x) ;; *:) eval $1=\"`$ECHO $2 | $SED 's/:/ /g'` \$$1\" ;; x:*) eval $1=\"\$$1 `$ECHO $2 | $SED 's/:/ /g'`\" ;; *::*) eval $1=\"\$$1\ `$ECHO $2 | $SED -e 's/.*:://' -e 's/:/ /g'`\" eval $1=\"`$ECHO $2 | $SED -e 's/::.*//' -e 's/:/ /g'`\ \$$1\" ;; *) eval $1=\"`$ECHO $2 | $SED 's/:/ /g'`\" ;; esac } ac_ext=c ac_cpp='$CPP $CPPFLAGS' ac_compile='$CC -c $CFLAGS $CPPFLAGS conftest.$ac_ext >&5' ac_link='$CC -o conftest$ac_exeext $CFLAGS $CPPFLAGS $LDFLAGS conftest.$ac_ext $LIBS >&5' ac_compiler_gnu=$ac_cv_c_compiler_gnu { $as_echo "$as_me:${as_lineno-$LINENO}: checking how to run the C preprocessor" >&5 $as_echo_n "checking how to run the C preprocessor... " >&6; } # On Suns, sometimes $CPP names a directory. if test -n "$CPP" && test -d "$CPP"; then CPP= fi if test -z "$CPP"; then if ${ac_cv_prog_CPP+:} false; then : $as_echo_n "(cached) " >&6 else # Double quotes because CPP needs to be expanded for CPP in "$CC -E" "$CC -E -traditional-cpp" "/lib/cpp" do ac_preproc_ok=false for ac_c_preproc_warn_flag in '' yes do # Use a header file that comes with gcc, so configuring glibc # with a fresh cross-compiler works. # Prefer to if __STDC__ is defined, since # exists even on freestanding compilers. # On the NeXT, cc -E runs the code through the compiler's parser, # not just through cpp. "Syntax error" is here to catch this case. cat confdefs.h - <<_ACEOF >conftest.$ac_ext /* end confdefs.h. */ #ifdef __STDC__ # include #else # include #endif Syntax error _ACEOF if ac_fn_c_try_cpp "$LINENO"; then : else # Broken: fails on valid input. continue fi rm -f conftest.err conftest.i conftest.$ac_ext # OK, works on sane cases. Now check whether nonexistent headers # can be detected and how. cat confdefs.h - <<_ACEOF >conftest.$ac_ext /* end confdefs.h. */ #include _ACEOF if ac_fn_c_try_cpp "$LINENO"; then : # Broken: success on invalid input. continue else # Passes both tests. ac_preproc_ok=: break fi rm -f conftest.err conftest.i conftest.$ac_ext done # Because of `break', _AC_PREPROC_IFELSE's cleaning code was skipped. rm -f conftest.i conftest.err conftest.$ac_ext if $ac_preproc_ok; then : break fi done ac_cv_prog_CPP=$CPP fi CPP=$ac_cv_prog_CPP else ac_cv_prog_CPP=$CPP fi { $as_echo "$as_me:${as_lineno-$LINENO}: result: $CPP" >&5 $as_echo "$CPP" >&6; } ac_preproc_ok=false for ac_c_preproc_warn_flag in '' yes do # Use a header file that comes with gcc, so configuring glibc # with a fresh cross-compiler works. # Prefer to if __STDC__ is defined, since # exists even on freestanding compilers. # On the NeXT, cc -E runs the code through the compiler's parser, # not just through cpp. "Syntax error" is here to catch this case. cat confdefs.h - <<_ACEOF >conftest.$ac_ext /* end confdefs.h. */ #ifdef __STDC__ # include #else # include #endif Syntax error _ACEOF if ac_fn_c_try_cpp "$LINENO"; then : else # Broken: fails on valid input. continue fi rm -f conftest.err conftest.i conftest.$ac_ext # OK, works on sane cases. Now check whether nonexistent headers # can be detected and how. cat confdefs.h - <<_ACEOF >conftest.$ac_ext /* end confdefs.h. */ #include _ACEOF if ac_fn_c_try_cpp "$LINENO"; then : # Broken: success on invalid input. continue else # Passes both tests. ac_preproc_ok=: break fi rm -f conftest.err conftest.i conftest.$ac_ext done # Because of `break', _AC_PREPROC_IFELSE's cleaning code was skipped. rm -f conftest.i conftest.err conftest.$ac_ext if $ac_preproc_ok; then : else { { $as_echo "$as_me:${as_lineno-$LINENO}: error: in \`$ac_pwd':" >&5 $as_echo "$as_me: error: in \`$ac_pwd':" >&2;} as_fn_error $? "C preprocessor \"$CPP\" fails sanity check See \`config.log' for more details" "$LINENO" 5; } fi ac_ext=c ac_cpp='$CPP $CPPFLAGS' ac_compile='$CC -c $CFLAGS $CPPFLAGS conftest.$ac_ext >&5' ac_link='$CC -o conftest$ac_exeext $CFLAGS $CPPFLAGS $LDFLAGS conftest.$ac_ext $LIBS >&5' ac_compiler_gnu=$ac_cv_c_compiler_gnu { $as_echo "$as_me:${as_lineno-$LINENO}: checking for ANSI C header files" >&5 $as_echo_n "checking for ANSI C header files... " >&6; } if ${ac_cv_header_stdc+:} false; then : $as_echo_n "(cached) " >&6 else cat confdefs.h - <<_ACEOF >conftest.$ac_ext /* end confdefs.h. */ #include #include #include #include int main () { ; return 0; } _ACEOF if ac_fn_c_try_compile "$LINENO"; then : ac_cv_header_stdc=yes else ac_cv_header_stdc=no fi rm -f core conftest.err conftest.$ac_objext conftest.$ac_ext if test $ac_cv_header_stdc = yes; then # SunOS 4.x string.h does not declare mem*, contrary to ANSI. cat confdefs.h - <<_ACEOF >conftest.$ac_ext /* end confdefs.h. */ #include _ACEOF if (eval "$ac_cpp conftest.$ac_ext") 2>&5 | $EGREP "memchr" >/dev/null 2>&1; then : else ac_cv_header_stdc=no fi rm -f conftest* fi if test $ac_cv_header_stdc = yes; then # ISC 2.0.2 stdlib.h does not declare free, contrary to ANSI. cat confdefs.h - <<_ACEOF >conftest.$ac_ext /* end confdefs.h. */ #include _ACEOF if (eval "$ac_cpp conftest.$ac_ext") 2>&5 | $EGREP "free" >/dev/null 2>&1; then : else ac_cv_header_stdc=no fi rm -f conftest* fi if test $ac_cv_header_stdc = yes; then # /bin/cc in Irix-4.0.5 gets non-ANSI ctype macros unless using -ansi. if test "$cross_compiling" = yes; then : : else cat confdefs.h - <<_ACEOF >conftest.$ac_ext /* end confdefs.h. */ #include #include #if ((' ' & 0x0FF) == 0x020) # define ISLOWER(c) ('a' <= (c) && (c) <= 'z') # define TOUPPER(c) (ISLOWER(c) ? 'A' + ((c) - 'a') : (c)) #else # define ISLOWER(c) \ (('a' <= (c) && (c) <= 'i') \ || ('j' <= (c) && (c) <= 'r') \ || ('s' <= (c) && (c) <= 'z')) # define TOUPPER(c) (ISLOWER(c) ? ((c) | 0x40) : (c)) #endif #define XOR(e, f) (((e) && !(f)) || (!(e) && (f))) int main () { int i; for (i = 0; i < 256; i++) if (XOR (islower (i), ISLOWER (i)) || toupper (i) != TOUPPER (i)) return 2; return 0; } _ACEOF if ac_fn_c_try_run "$LINENO"; then : else ac_cv_header_stdc=no fi rm -f core *.core core.conftest.* gmon.out bb.out conftest$ac_exeext \ conftest.$ac_objext conftest.beam conftest.$ac_ext fi fi fi { $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_cv_header_stdc" >&5 $as_echo "$ac_cv_header_stdc" >&6; } if test $ac_cv_header_stdc = yes; then $as_echo "#define STDC_HEADERS 1" >>confdefs.h fi # On IRIX 5.3, sys/types and inttypes.h are conflicting. for ac_header in sys/types.h sys/stat.h stdlib.h string.h memory.h strings.h \ inttypes.h stdint.h unistd.h do : as_ac_Header=`$as_echo "ac_cv_header_$ac_header" | $as_tr_sh` ac_fn_c_check_header_compile "$LINENO" "$ac_header" "$as_ac_Header" "$ac_includes_default " if eval test \"x\$"$as_ac_Header"\" = x"yes"; then : cat >>confdefs.h <<_ACEOF #define `$as_echo "HAVE_$ac_header" | $as_tr_cpp` 1 _ACEOF fi done for ac_header in dlfcn.h do : ac_fn_c_check_header_compile "$LINENO" "dlfcn.h" "ac_cv_header_dlfcn_h" "$ac_includes_default " if test "x$ac_cv_header_dlfcn_h" = xyes; then : cat >>confdefs.h <<_ACEOF #define HAVE_DLFCN_H 1 _ACEOF fi done # Set options enable_dlopen=no enable_win32_dll=no # Check whether --enable-shared was given. if test "${enable_shared+set}" = set; then : enableval=$enable_shared; p=${PACKAGE-default} case $enableval in yes) enable_shared=yes ;; no) enable_shared=no ;; *) enable_shared=no # Look at the argument we got. We use all the common list separators. lt_save_ifs=$IFS; IFS=$IFS$PATH_SEPARATOR, for pkg in $enableval; do IFS=$lt_save_ifs if test "X$pkg" = "X$p"; then enable_shared=yes fi done IFS=$lt_save_ifs ;; esac else enable_shared=yes fi # Check whether --enable-static was given. if test "${enable_static+set}" = set; then : enableval=$enable_static; p=${PACKAGE-default} case $enableval in yes) enable_static=yes ;; no) enable_static=no ;; *) enable_static=no # Look at the argument we got. We use all the common list separators. lt_save_ifs=$IFS; IFS=$IFS$PATH_SEPARATOR, for pkg in $enableval; do IFS=$lt_save_ifs if test "X$pkg" = "X$p"; then enable_static=yes fi done IFS=$lt_save_ifs ;; esac else enable_static=yes fi # Check whether --with-pic was given. if test "${with_pic+set}" = set; then : withval=$with_pic; lt_p=${PACKAGE-default} case $withval in yes|no) pic_mode=$withval ;; *) pic_mode=default # Look at the argument we got. We use all the common list separators. lt_save_ifs=$IFS; IFS=$IFS$PATH_SEPARATOR, for lt_pkg in $withval; do IFS=$lt_save_ifs if test "X$lt_pkg" = "X$lt_p"; then pic_mode=yes fi done IFS=$lt_save_ifs ;; esac else pic_mode=default fi # Check whether --enable-fast-install was given. if test "${enable_fast_install+set}" = set; then : enableval=$enable_fast_install; p=${PACKAGE-default} case $enableval in yes) enable_fast_install=yes ;; no) enable_fast_install=no ;; *) enable_fast_install=no # Look at the argument we got. We use all the common list separators. lt_save_ifs=$IFS; IFS=$IFS$PATH_SEPARATOR, for pkg in $enableval; do IFS=$lt_save_ifs if test "X$pkg" = "X$p"; then enable_fast_install=yes fi done IFS=$lt_save_ifs ;; esac else enable_fast_install=yes fi shared_archive_member_spec= case $host,$enable_shared in power*-*-aix[5-9]*,yes) { $as_echo "$as_me:${as_lineno-$LINENO}: checking which variant of shared library versioning to provide" >&5 $as_echo_n "checking which variant of shared library versioning to provide... " >&6; } # Check whether --with-aix-soname was given. if test "${with_aix_soname+set}" = set; then : withval=$with_aix_soname; case $withval in aix|svr4|both) ;; *) as_fn_error $? "Unknown argument to --with-aix-soname" "$LINENO" 5 ;; esac lt_cv_with_aix_soname=$with_aix_soname else if ${lt_cv_with_aix_soname+:} false; then : $as_echo_n "(cached) " >&6 else lt_cv_with_aix_soname=aix fi with_aix_soname=$lt_cv_with_aix_soname fi { $as_echo "$as_me:${as_lineno-$LINENO}: result: $with_aix_soname" >&5 $as_echo "$with_aix_soname" >&6; } if test aix != "$with_aix_soname"; then # For the AIX way of multilib, we name the shared archive member # based on the bitwidth used, traditionally 'shr.o' or 'shr_64.o', # and 'shr.imp' or 'shr_64.imp', respectively, for the Import File. # Even when GNU compilers ignore OBJECT_MODE but need '-maix64' flag, # the AIX toolchain works better with OBJECT_MODE set (default 32). if test 64 = "${OBJECT_MODE-32}"; then shared_archive_member_spec=shr_64 else shared_archive_member_spec=shr fi fi ;; *) with_aix_soname=aix ;; esac # This can be used to rebuild libtool when needed LIBTOOL_DEPS=$ltmain # Always use our own libtool. LIBTOOL='$(SHELL) $(top_builddir)/libtool' test -z "$LN_S" && LN_S="ln -s" if test -n "${ZSH_VERSION+set}"; then setopt NO_GLOB_SUBST fi { $as_echo "$as_me:${as_lineno-$LINENO}: checking for objdir" >&5 $as_echo_n "checking for objdir... " >&6; } if ${lt_cv_objdir+:} false; then : $as_echo_n "(cached) " >&6 else rm -f .libs 2>/dev/null mkdir .libs 2>/dev/null if test -d .libs; then lt_cv_objdir=.libs else # MS-DOS does not allow filenames that begin with a dot. lt_cv_objdir=_libs fi rmdir .libs 2>/dev/null fi { $as_echo "$as_me:${as_lineno-$LINENO}: result: $lt_cv_objdir" >&5 $as_echo "$lt_cv_objdir" >&6; } objdir=$lt_cv_objdir cat >>confdefs.h <<_ACEOF #define LT_OBJDIR "$lt_cv_objdir/" _ACEOF case $host_os in aix3*) # AIX sometimes has problems with the GCC collect2 program. For some # reason, if we set the COLLECT_NAMES environment variable, the problems # vanish in a puff of smoke. if test set != "${COLLECT_NAMES+set}"; then COLLECT_NAMES= export COLLECT_NAMES fi ;; esac # Global variables: ofile=libtool can_build_shared=yes # All known linkers require a '.a' archive for static linking (except MSVC, # which needs '.lib'). libext=a with_gnu_ld=$lt_cv_prog_gnu_ld old_CC=$CC old_CFLAGS=$CFLAGS # Set sane defaults for various variables test -z "$CC" && CC=cc test -z "$LTCC" && LTCC=$CC test -z "$LTCFLAGS" && LTCFLAGS=$CFLAGS test -z "$LD" && LD=ld test -z "$ac_objext" && ac_objext=o func_cc_basename $compiler cc_basename=$func_cc_basename_result # Only perform the check for file, if the check method requires it test -z "$MAGIC_CMD" && MAGIC_CMD=file case $deplibs_check_method in file_magic*) if test "$file_magic_cmd" = '$MAGIC_CMD'; then { $as_echo "$as_me:${as_lineno-$LINENO}: checking for ${ac_tool_prefix}file" >&5 $as_echo_n "checking for ${ac_tool_prefix}file... " >&6; } if ${lt_cv_path_MAGIC_CMD+:} false; then : $as_echo_n "(cached) " >&6 else case $MAGIC_CMD in [\\/*] | ?:[\\/]*) lt_cv_path_MAGIC_CMD=$MAGIC_CMD # Let the user override the test with a path. ;; *) lt_save_MAGIC_CMD=$MAGIC_CMD lt_save_ifs=$IFS; IFS=$PATH_SEPARATOR ac_dummy="/usr/bin$PATH_SEPARATOR$PATH" for ac_dir in $ac_dummy; do IFS=$lt_save_ifs test -z "$ac_dir" && ac_dir=. if test -f "$ac_dir/${ac_tool_prefix}file"; then lt_cv_path_MAGIC_CMD=$ac_dir/"${ac_tool_prefix}file" if test -n "$file_magic_test_file"; then case $deplibs_check_method in "file_magic "*) file_magic_regex=`expr "$deplibs_check_method" : "file_magic \(.*\)"` MAGIC_CMD=$lt_cv_path_MAGIC_CMD if eval $file_magic_cmd \$file_magic_test_file 2> /dev/null | $EGREP "$file_magic_regex" > /dev/null; then : else cat <<_LT_EOF 1>&2 *** Warning: the command libtool uses to detect shared libraries, *** $file_magic_cmd, produces output that libtool cannot recognize. *** The result is that libtool may fail to recognize shared libraries *** as such. This will affect the creation of libtool libraries that *** depend on shared libraries, but programs linked with such libtool *** libraries will work regardless of this problem. Nevertheless, you *** may want to report the problem to your system manager and/or to *** bug-libtool@gnu.org _LT_EOF fi ;; esac fi break fi done IFS=$lt_save_ifs MAGIC_CMD=$lt_save_MAGIC_CMD ;; esac fi MAGIC_CMD=$lt_cv_path_MAGIC_CMD if test -n "$MAGIC_CMD"; then { $as_echo "$as_me:${as_lineno-$LINENO}: result: $MAGIC_CMD" >&5 $as_echo "$MAGIC_CMD" >&6; } else { $as_echo "$as_me:${as_lineno-$LINENO}: result: no" >&5 $as_echo "no" >&6; } fi if test -z "$lt_cv_path_MAGIC_CMD"; then if test -n "$ac_tool_prefix"; then { $as_echo "$as_me:${as_lineno-$LINENO}: checking for file" >&5 $as_echo_n "checking for file... " >&6; } if ${lt_cv_path_MAGIC_CMD+:} false; then : $as_echo_n "(cached) " >&6 else case $MAGIC_CMD in [\\/*] | ?:[\\/]*) lt_cv_path_MAGIC_CMD=$MAGIC_CMD # Let the user override the test with a path. ;; *) lt_save_MAGIC_CMD=$MAGIC_CMD lt_save_ifs=$IFS; IFS=$PATH_SEPARATOR ac_dummy="/usr/bin$PATH_SEPARATOR$PATH" for ac_dir in $ac_dummy; do IFS=$lt_save_ifs test -z "$ac_dir" && ac_dir=. if test -f "$ac_dir/file"; then lt_cv_path_MAGIC_CMD=$ac_dir/"file" if test -n "$file_magic_test_file"; then case $deplibs_check_method in "file_magic "*) file_magic_regex=`expr "$deplibs_check_method" : "file_magic \(.*\)"` MAGIC_CMD=$lt_cv_path_MAGIC_CMD if eval $file_magic_cmd \$file_magic_test_file 2> /dev/null | $EGREP "$file_magic_regex" > /dev/null; then : else cat <<_LT_EOF 1>&2 *** Warning: the command libtool uses to detect shared libraries, *** $file_magic_cmd, produces output that libtool cannot recognize. *** The result is that libtool may fail to recognize shared libraries *** as such. This will affect the creation of libtool libraries that *** depend on shared libraries, but programs linked with such libtool *** libraries will work regardless of this problem. Nevertheless, you *** may want to report the problem to your system manager and/or to *** bug-libtool@gnu.org _LT_EOF fi ;; esac fi break fi done IFS=$lt_save_ifs MAGIC_CMD=$lt_save_MAGIC_CMD ;; esac fi MAGIC_CMD=$lt_cv_path_MAGIC_CMD if test -n "$MAGIC_CMD"; then { $as_echo "$as_me:${as_lineno-$LINENO}: result: $MAGIC_CMD" >&5 $as_echo "$MAGIC_CMD" >&6; } else { $as_echo "$as_me:${as_lineno-$LINENO}: result: no" >&5 $as_echo "no" >&6; } fi else MAGIC_CMD=: fi fi fi ;; esac # Use C for the default configuration in the libtool script lt_save_CC=$CC ac_ext=c ac_cpp='$CPP $CPPFLAGS' ac_compile='$CC -c $CFLAGS $CPPFLAGS conftest.$ac_ext >&5' ac_link='$CC -o conftest$ac_exeext $CFLAGS $CPPFLAGS $LDFLAGS conftest.$ac_ext $LIBS >&5' ac_compiler_gnu=$ac_cv_c_compiler_gnu # Source file extension for C test sources. ac_ext=c # Object file extension for compiled C test sources. objext=o objext=$objext # Code to be used in simple compile tests lt_simple_compile_test_code="int some_variable = 0;" # Code to be used in simple link tests lt_simple_link_test_code='int main(){return(0);}' # If no C compiler was specified, use CC. LTCC=${LTCC-"$CC"} # If no C compiler flags were specified, use CFLAGS. LTCFLAGS=${LTCFLAGS-"$CFLAGS"} # Allow CC to be a program name with arguments. compiler=$CC # Save the default compiler, since it gets overwritten when the other # tags are being tested, and _LT_TAGVAR(compiler, []) is a NOP. compiler_DEFAULT=$CC # save warnings/boilerplate of simple test code ac_outfile=conftest.$ac_objext echo "$lt_simple_compile_test_code" >conftest.$ac_ext eval "$ac_compile" 2>&1 >/dev/null | $SED '/^$/d; /^ *+/d' >conftest.err _lt_compiler_boilerplate=`cat conftest.err` $RM conftest* ac_outfile=conftest.$ac_objext echo "$lt_simple_link_test_code" >conftest.$ac_ext eval "$ac_link" 2>&1 >/dev/null | $SED '/^$/d; /^ *+/d' >conftest.err _lt_linker_boilerplate=`cat conftest.err` $RM -r conftest* ## CAVEAT EMPTOR: ## There is no encapsulation within the following macros, do not change ## the running order or otherwise move them around unless you know exactly ## what you are doing... if test -n "$compiler"; then lt_prog_compiler_no_builtin_flag= if test yes = "$GCC"; then case $cc_basename in nvcc*) lt_prog_compiler_no_builtin_flag=' -Xcompiler -fno-builtin' ;; *) lt_prog_compiler_no_builtin_flag=' -fno-builtin' ;; esac { $as_echo "$as_me:${as_lineno-$LINENO}: checking if $compiler supports -fno-rtti -fno-exceptions" >&5 $as_echo_n "checking if $compiler supports -fno-rtti -fno-exceptions... " >&6; } if ${lt_cv_prog_compiler_rtti_exceptions+:} false; then : $as_echo_n "(cached) " >&6 else lt_cv_prog_compiler_rtti_exceptions=no ac_outfile=conftest.$ac_objext echo "$lt_simple_compile_test_code" > conftest.$ac_ext lt_compiler_flag="-fno-rtti -fno-exceptions" ## exclude from sc_useless_quotes_in_assignment # Insert the option either (1) after the last *FLAGS variable, or # (2) before a word containing "conftest.", or (3) at the end. # Note that $ac_compile itself does not contain backslashes and begins # with a dollar sign (not a hyphen), so the echo should work correctly. # The option is referenced via a variable to avoid confusing sed. lt_compile=`echo "$ac_compile" | $SED \ -e 's:.*FLAGS}\{0,1\} :&$lt_compiler_flag :; t' \ -e 's: [^ ]*conftest\.: $lt_compiler_flag&:; t' \ -e 's:$: $lt_compiler_flag:'` (eval echo "\"\$as_me:$LINENO: $lt_compile\"" >&5) (eval "$lt_compile" 2>conftest.err) ac_status=$? cat conftest.err >&5 echo "$as_me:$LINENO: \$? = $ac_status" >&5 if (exit $ac_status) && test -s "$ac_outfile"; then # The compiler can only warn and ignore the option if not recognized # So say no if there are warnings other than the usual output. $ECHO "$_lt_compiler_boilerplate" | $SED '/^$/d' >conftest.exp $SED '/^$/d; /^ *+/d' conftest.err >conftest.er2 if test ! -s conftest.er2 || diff conftest.exp conftest.er2 >/dev/null; then lt_cv_prog_compiler_rtti_exceptions=yes fi fi $RM conftest* fi { $as_echo "$as_me:${as_lineno-$LINENO}: result: $lt_cv_prog_compiler_rtti_exceptions" >&5 $as_echo "$lt_cv_prog_compiler_rtti_exceptions" >&6; } if test yes = "$lt_cv_prog_compiler_rtti_exceptions"; then lt_prog_compiler_no_builtin_flag="$lt_prog_compiler_no_builtin_flag -fno-rtti -fno-exceptions" else : fi fi lt_prog_compiler_wl= lt_prog_compiler_pic= lt_prog_compiler_static= if test yes = "$GCC"; then lt_prog_compiler_wl='-Wl,' lt_prog_compiler_static='-static' case $host_os in aix*) # All AIX code is PIC. if test ia64 = "$host_cpu"; then # AIX 5 now supports IA64 processor lt_prog_compiler_static='-Bstatic' fi lt_prog_compiler_pic='-fPIC' ;; amigaos*) case $host_cpu in powerpc) # see comment about AmigaOS4 .so support lt_prog_compiler_pic='-fPIC' ;; m68k) # FIXME: we need at least 68020 code to build shared libraries, but # adding the '-m68020' flag to GCC prevents building anything better, # like '-m68040'. lt_prog_compiler_pic='-m68020 -resident32 -malways-restore-a4' ;; esac ;; beos* | irix5* | irix6* | nonstopux* | osf3* | osf4* | osf5*) # PIC is the default for these OSes. ;; mingw* | cygwin* | pw32* | os2* | cegcc*) # This hack is so that the source file can tell whether it is being # built for inclusion in a dll (and should export symbols for example). # Although the cygwin gcc ignores -fPIC, still need this for old-style # (--disable-auto-import) libraries lt_prog_compiler_pic='-DDLL_EXPORT' case $host_os in os2*) lt_prog_compiler_static='$wl-static' ;; esac ;; darwin* | rhapsody*) # PIC is the default on this platform # Common symbols not allowed in MH_DYLIB files lt_prog_compiler_pic='-fno-common' ;; haiku*) # PIC is the default for Haiku. # The "-static" flag exists, but is broken. lt_prog_compiler_static= ;; hpux*) # PIC is the default for 64-bit PA HP-UX, but not for 32-bit # PA HP-UX. On IA64 HP-UX, PIC is the default but the pic flag # sets the default TLS model and affects inlining. case $host_cpu in hppa*64*) # +Z the default ;; *) lt_prog_compiler_pic='-fPIC' ;; esac ;; interix[3-9]*) # Interix 3.x gcc -fpic/-fPIC options generate broken code. # Instead, we relocate shared libraries at runtime. ;; msdosdjgpp*) # Just because we use GCC doesn't mean we suddenly get shared libraries # on systems that don't support them. lt_prog_compiler_can_build_shared=no enable_shared=no ;; *nto* | *qnx*) # QNX uses GNU C++, but need to define -shared option too, otherwise # it will coredump. lt_prog_compiler_pic='-fPIC -shared' ;; sysv4*MP*) if test -d /usr/nec; then lt_prog_compiler_pic=-Kconform_pic fi ;; *) lt_prog_compiler_pic='-fPIC' ;; esac case $cc_basename in nvcc*) # Cuda Compiler Driver 2.2 lt_prog_compiler_wl='-Xlinker ' if test -n "$lt_prog_compiler_pic"; then lt_prog_compiler_pic="-Xcompiler $lt_prog_compiler_pic" fi ;; esac else # PORTME Check for flag to pass linker flags through the system compiler. case $host_os in aix*) lt_prog_compiler_wl='-Wl,' if test ia64 = "$host_cpu"; then # AIX 5 now supports IA64 processor lt_prog_compiler_static='-Bstatic' else lt_prog_compiler_static='-bnso -bI:/lib/syscalls.exp' fi ;; darwin* | rhapsody*) # PIC is the default on this platform # Common symbols not allowed in MH_DYLIB files lt_prog_compiler_pic='-fno-common' case $cc_basename in nagfor*) # NAG Fortran compiler lt_prog_compiler_wl='-Wl,-Wl,,' lt_prog_compiler_pic='-PIC' lt_prog_compiler_static='-Bstatic' ;; esac ;; mingw* | cygwin* | pw32* | os2* | cegcc*) # This hack is so that the source file can tell whether it is being # built for inclusion in a dll (and should export symbols for example). lt_prog_compiler_pic='-DDLL_EXPORT' case $host_os in os2*) lt_prog_compiler_static='$wl-static' ;; esac ;; hpux9* | hpux10* | hpux11*) lt_prog_compiler_wl='-Wl,' # PIC is the default for IA64 HP-UX and 64-bit HP-UX, but # not for PA HP-UX. case $host_cpu in hppa*64*|ia64*) # +Z the default ;; *) lt_prog_compiler_pic='+Z' ;; esac # Is there a better lt_prog_compiler_static that works with the bundled CC? lt_prog_compiler_static='$wl-a ${wl}archive' ;; irix5* | irix6* | nonstopux*) lt_prog_compiler_wl='-Wl,' # PIC (with -KPIC) is the default. lt_prog_compiler_static='-non_shared' ;; linux* | k*bsd*-gnu | kopensolaris*-gnu | gnu*) case $cc_basename in # old Intel for x86_64, which still supported -KPIC. ecc*) lt_prog_compiler_wl='-Wl,' lt_prog_compiler_pic='-KPIC' lt_prog_compiler_static='-static' ;; # icc used to be incompatible with GCC. # ICC 10 doesn't accept -KPIC any more. icc* | ifort*) lt_prog_compiler_wl='-Wl,' lt_prog_compiler_pic='-fPIC' lt_prog_compiler_static='-static' ;; # Lahey Fortran 8.1. lf95*) lt_prog_compiler_wl='-Wl,' lt_prog_compiler_pic='--shared' lt_prog_compiler_static='--static' ;; nagfor*) # NAG Fortran compiler lt_prog_compiler_wl='-Wl,-Wl,,' lt_prog_compiler_pic='-PIC' lt_prog_compiler_static='-Bstatic' ;; tcc*) # Fabrice Bellard et al's Tiny C Compiler lt_prog_compiler_wl='-Wl,' lt_prog_compiler_pic='-fPIC' lt_prog_compiler_static='-static' ;; pgcc* | pgf77* | pgf90* | pgf95* | pgfortran*) # Portland Group compilers (*not* the Pentium gcc compiler, # which looks to be a dead project) lt_prog_compiler_wl='-Wl,' lt_prog_compiler_pic='-fpic' lt_prog_compiler_static='-Bstatic' ;; ccc*) lt_prog_compiler_wl='-Wl,' # All Alpha code is PIC. lt_prog_compiler_static='-non_shared' ;; xl* | bgxl* | bgf* | mpixl*) # IBM XL C 8.0/Fortran 10.1, 11.1 on PPC and BlueGene lt_prog_compiler_wl='-Wl,' lt_prog_compiler_pic='-qpic' lt_prog_compiler_static='-qstaticlink' ;; *) case `$CC -V 2>&1 | sed 5q` in *Sun\ Ceres\ Fortran* | *Sun*Fortran*\ [1-7].* | *Sun*Fortran*\ 8.[0-3]*) # Sun Fortran 8.3 passes all unrecognized flags to the linker lt_prog_compiler_pic='-KPIC' lt_prog_compiler_static='-Bstatic' lt_prog_compiler_wl='' ;; *Sun\ F* | *Sun*Fortran*) lt_prog_compiler_pic='-KPIC' lt_prog_compiler_static='-Bstatic' lt_prog_compiler_wl='-Qoption ld ' ;; *Sun\ C*) # Sun C 5.9 lt_prog_compiler_pic='-KPIC' lt_prog_compiler_static='-Bstatic' lt_prog_compiler_wl='-Wl,' ;; *Intel*\ [CF]*Compiler*) lt_prog_compiler_wl='-Wl,' lt_prog_compiler_pic='-fPIC' lt_prog_compiler_static='-static' ;; *Portland\ Group*) lt_prog_compiler_wl='-Wl,' lt_prog_compiler_pic='-fpic' lt_prog_compiler_static='-Bstatic' ;; esac ;; esac ;; newsos6) lt_prog_compiler_pic='-KPIC' lt_prog_compiler_static='-Bstatic' ;; *nto* | *qnx*) # QNX uses GNU C++, but need to define -shared option too, otherwise # it will coredump. lt_prog_compiler_pic='-fPIC -shared' ;; osf3* | osf4* | osf5*) lt_prog_compiler_wl='-Wl,' # All OSF/1 code is PIC. lt_prog_compiler_static='-non_shared' ;; rdos*) lt_prog_compiler_static='-non_shared' ;; solaris*) lt_prog_compiler_pic='-KPIC' lt_prog_compiler_static='-Bstatic' case $cc_basename in f77* | f90* | f95* | sunf77* | sunf90* | sunf95*) lt_prog_compiler_wl='-Qoption ld ';; *) lt_prog_compiler_wl='-Wl,';; esac ;; sunos4*) lt_prog_compiler_wl='-Qoption ld ' lt_prog_compiler_pic='-PIC' lt_prog_compiler_static='-Bstatic' ;; sysv4 | sysv4.2uw2* | sysv4.3*) lt_prog_compiler_wl='-Wl,' lt_prog_compiler_pic='-KPIC' lt_prog_compiler_static='-Bstatic' ;; sysv4*MP*) if test -d /usr/nec; then lt_prog_compiler_pic='-Kconform_pic' lt_prog_compiler_static='-Bstatic' fi ;; sysv5* | unixware* | sco3.2v5* | sco5v6* | OpenUNIX*) lt_prog_compiler_wl='-Wl,' lt_prog_compiler_pic='-KPIC' lt_prog_compiler_static='-Bstatic' ;; unicos*) lt_prog_compiler_wl='-Wl,' lt_prog_compiler_can_build_shared=no ;; uts4*) lt_prog_compiler_pic='-pic' lt_prog_compiler_static='-Bstatic' ;; *) lt_prog_compiler_can_build_shared=no ;; esac fi case $host_os in # For platforms that do not support PIC, -DPIC is meaningless: *djgpp*) lt_prog_compiler_pic= ;; *) lt_prog_compiler_pic="$lt_prog_compiler_pic -DPIC" ;; esac { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $compiler option to produce PIC" >&5 $as_echo_n "checking for $compiler option to produce PIC... " >&6; } if ${lt_cv_prog_compiler_pic+:} false; then : $as_echo_n "(cached) " >&6 else lt_cv_prog_compiler_pic=$lt_prog_compiler_pic fi { $as_echo "$as_me:${as_lineno-$LINENO}: result: $lt_cv_prog_compiler_pic" >&5 $as_echo "$lt_cv_prog_compiler_pic" >&6; } lt_prog_compiler_pic=$lt_cv_prog_compiler_pic # # Check to make sure the PIC flag actually works. # if test -n "$lt_prog_compiler_pic"; then { $as_echo "$as_me:${as_lineno-$LINENO}: checking if $compiler PIC flag $lt_prog_compiler_pic works" >&5 $as_echo_n "checking if $compiler PIC flag $lt_prog_compiler_pic works... " >&6; } if ${lt_cv_prog_compiler_pic_works+:} false; then : $as_echo_n "(cached) " >&6 else lt_cv_prog_compiler_pic_works=no ac_outfile=conftest.$ac_objext echo "$lt_simple_compile_test_code" > conftest.$ac_ext lt_compiler_flag="$lt_prog_compiler_pic -DPIC" ## exclude from sc_useless_quotes_in_assignment # Insert the option either (1) after the last *FLAGS variable, or # (2) before a word containing "conftest.", or (3) at the end. # Note that $ac_compile itself does not contain backslashes and begins # with a dollar sign (not a hyphen), so the echo should work correctly. # The option is referenced via a variable to avoid confusing sed. lt_compile=`echo "$ac_compile" | $SED \ -e 's:.*FLAGS}\{0,1\} :&$lt_compiler_flag :; t' \ -e 's: [^ ]*conftest\.: $lt_compiler_flag&:; t' \ -e 's:$: $lt_compiler_flag:'` (eval echo "\"\$as_me:$LINENO: $lt_compile\"" >&5) (eval "$lt_compile" 2>conftest.err) ac_status=$? cat conftest.err >&5 echo "$as_me:$LINENO: \$? = $ac_status" >&5 if (exit $ac_status) && test -s "$ac_outfile"; then # The compiler can only warn and ignore the option if not recognized # So say no if there are warnings other than the usual output. $ECHO "$_lt_compiler_boilerplate" | $SED '/^$/d' >conftest.exp $SED '/^$/d; /^ *+/d' conftest.err >conftest.er2 if test ! -s conftest.er2 || diff conftest.exp conftest.er2 >/dev/null; then lt_cv_prog_compiler_pic_works=yes fi fi $RM conftest* fi { $as_echo "$as_me:${as_lineno-$LINENO}: result: $lt_cv_prog_compiler_pic_works" >&5 $as_echo "$lt_cv_prog_compiler_pic_works" >&6; } if test yes = "$lt_cv_prog_compiler_pic_works"; then case $lt_prog_compiler_pic in "" | " "*) ;; *) lt_prog_compiler_pic=" $lt_prog_compiler_pic" ;; esac else lt_prog_compiler_pic= lt_prog_compiler_can_build_shared=no fi fi # # Check to make sure the static flag actually works. # wl=$lt_prog_compiler_wl eval lt_tmp_static_flag=\"$lt_prog_compiler_static\" { $as_echo "$as_me:${as_lineno-$LINENO}: checking if $compiler static flag $lt_tmp_static_flag works" >&5 $as_echo_n "checking if $compiler static flag $lt_tmp_static_flag works... " >&6; } if ${lt_cv_prog_compiler_static_works+:} false; then : $as_echo_n "(cached) " >&6 else lt_cv_prog_compiler_static_works=no save_LDFLAGS=$LDFLAGS LDFLAGS="$LDFLAGS $lt_tmp_static_flag" echo "$lt_simple_link_test_code" > conftest.$ac_ext if (eval $ac_link 2>conftest.err) && test -s conftest$ac_exeext; then # The linker can only warn and ignore the option if not recognized # So say no if there are warnings if test -s conftest.err; then # Append any errors to the config.log. cat conftest.err 1>&5 $ECHO "$_lt_linker_boilerplate" | $SED '/^$/d' > conftest.exp $SED '/^$/d; /^ *+/d' conftest.err >conftest.er2 if diff conftest.exp conftest.er2 >/dev/null; then lt_cv_prog_compiler_static_works=yes fi else lt_cv_prog_compiler_static_works=yes fi fi $RM -r conftest* LDFLAGS=$save_LDFLAGS fi { $as_echo "$as_me:${as_lineno-$LINENO}: result: $lt_cv_prog_compiler_static_works" >&5 $as_echo "$lt_cv_prog_compiler_static_works" >&6; } if test yes = "$lt_cv_prog_compiler_static_works"; then : else lt_prog_compiler_static= fi { $as_echo "$as_me:${as_lineno-$LINENO}: checking if $compiler supports -c -o file.$ac_objext" >&5 $as_echo_n "checking if $compiler supports -c -o file.$ac_objext... " >&6; } if ${lt_cv_prog_compiler_c_o+:} false; then : $as_echo_n "(cached) " >&6 else lt_cv_prog_compiler_c_o=no $RM -r conftest 2>/dev/null mkdir conftest cd conftest mkdir out echo "$lt_simple_compile_test_code" > conftest.$ac_ext lt_compiler_flag="-o out/conftest2.$ac_objext" # Insert the option either (1) after the last *FLAGS variable, or # (2) before a word containing "conftest.", or (3) at the end. # Note that $ac_compile itself does not contain backslashes and begins # with a dollar sign (not a hyphen), so the echo should work correctly. lt_compile=`echo "$ac_compile" | $SED \ -e 's:.*FLAGS}\{0,1\} :&$lt_compiler_flag :; t' \ -e 's: [^ ]*conftest\.: $lt_compiler_flag&:; t' \ -e 's:$: $lt_compiler_flag:'` (eval echo "\"\$as_me:$LINENO: $lt_compile\"" >&5) (eval "$lt_compile" 2>out/conftest.err) ac_status=$? cat out/conftest.err >&5 echo "$as_me:$LINENO: \$? = $ac_status" >&5 if (exit $ac_status) && test -s out/conftest2.$ac_objext then # The compiler can only warn and ignore the option if not recognized # So say no if there are warnings $ECHO "$_lt_compiler_boilerplate" | $SED '/^$/d' > out/conftest.exp $SED '/^$/d; /^ *+/d' out/conftest.err >out/conftest.er2 if test ! -s out/conftest.er2 || diff out/conftest.exp out/conftest.er2 >/dev/null; then lt_cv_prog_compiler_c_o=yes fi fi chmod u+w . 2>&5 $RM conftest* # SGI C++ compiler will create directory out/ii_files/ for # template instantiation test -d out/ii_files && $RM out/ii_files/* && rmdir out/ii_files $RM out/* && rmdir out cd .. $RM -r conftest $RM conftest* fi { $as_echo "$as_me:${as_lineno-$LINENO}: result: $lt_cv_prog_compiler_c_o" >&5 $as_echo "$lt_cv_prog_compiler_c_o" >&6; } { $as_echo "$as_me:${as_lineno-$LINENO}: checking if $compiler supports -c -o file.$ac_objext" >&5 $as_echo_n "checking if $compiler supports -c -o file.$ac_objext... " >&6; } if ${lt_cv_prog_compiler_c_o+:} false; then : $as_echo_n "(cached) " >&6 else lt_cv_prog_compiler_c_o=no $RM -r conftest 2>/dev/null mkdir conftest cd conftest mkdir out echo "$lt_simple_compile_test_code" > conftest.$ac_ext lt_compiler_flag="-o out/conftest2.$ac_objext" # Insert the option either (1) after the last *FLAGS variable, or # (2) before a word containing "conftest.", or (3) at the end. # Note that $ac_compile itself does not contain backslashes and begins # with a dollar sign (not a hyphen), so the echo should work correctly. lt_compile=`echo "$ac_compile" | $SED \ -e 's:.*FLAGS}\{0,1\} :&$lt_compiler_flag :; t' \ -e 's: [^ ]*conftest\.: $lt_compiler_flag&:; t' \ -e 's:$: $lt_compiler_flag:'` (eval echo "\"\$as_me:$LINENO: $lt_compile\"" >&5) (eval "$lt_compile" 2>out/conftest.err) ac_status=$? cat out/conftest.err >&5 echo "$as_me:$LINENO: \$? = $ac_status" >&5 if (exit $ac_status) && test -s out/conftest2.$ac_objext then # The compiler can only warn and ignore the option if not recognized # So say no if there are warnings $ECHO "$_lt_compiler_boilerplate" | $SED '/^$/d' > out/conftest.exp $SED '/^$/d; /^ *+/d' out/conftest.err >out/conftest.er2 if test ! -s out/conftest.er2 || diff out/conftest.exp out/conftest.er2 >/dev/null; then lt_cv_prog_compiler_c_o=yes fi fi chmod u+w . 2>&5 $RM conftest* # SGI C++ compiler will create directory out/ii_files/ for # template instantiation test -d out/ii_files && $RM out/ii_files/* && rmdir out/ii_files $RM out/* && rmdir out cd .. $RM -r conftest $RM conftest* fi { $as_echo "$as_me:${as_lineno-$LINENO}: result: $lt_cv_prog_compiler_c_o" >&5 $as_echo "$lt_cv_prog_compiler_c_o" >&6; } hard_links=nottested if test no = "$lt_cv_prog_compiler_c_o" && test no != "$need_locks"; then # do not overwrite the value of need_locks provided by the user { $as_echo "$as_me:${as_lineno-$LINENO}: checking if we can lock with hard links" >&5 $as_echo_n "checking if we can lock with hard links... " >&6; } hard_links=yes $RM conftest* ln conftest.a conftest.b 2>/dev/null && hard_links=no touch conftest.a ln conftest.a conftest.b 2>&5 || hard_links=no ln conftest.a conftest.b 2>/dev/null && hard_links=no { $as_echo "$as_me:${as_lineno-$LINENO}: result: $hard_links" >&5 $as_echo "$hard_links" >&6; } if test no = "$hard_links"; then { $as_echo "$as_me:${as_lineno-$LINENO}: WARNING: '$CC' does not support '-c -o', so 'make -j' may be unsafe" >&5 $as_echo "$as_me: WARNING: '$CC' does not support '-c -o', so 'make -j' may be unsafe" >&2;} need_locks=warn fi else need_locks=no fi { $as_echo "$as_me:${as_lineno-$LINENO}: checking whether the $compiler linker ($LD) supports shared libraries" >&5 $as_echo_n "checking whether the $compiler linker ($LD) supports shared libraries... " >&6; } runpath_var= allow_undefined_flag= always_export_symbols=no archive_cmds= archive_expsym_cmds= compiler_needs_object=no enable_shared_with_static_runtimes=no export_dynamic_flag_spec= export_symbols_cmds='$NM $libobjs $convenience | $global_symbol_pipe | $SED '\''s/.* //'\'' | sort | uniq > $export_symbols' hardcode_automatic=no hardcode_direct=no hardcode_direct_absolute=no hardcode_libdir_flag_spec= hardcode_libdir_separator= hardcode_minus_L=no hardcode_shlibpath_var=unsupported inherit_rpath=no link_all_deplibs=unknown module_cmds= module_expsym_cmds= old_archive_from_new_cmds= old_archive_from_expsyms_cmds= thread_safe_flag_spec= whole_archive_flag_spec= # include_expsyms should be a list of space-separated symbols to be *always* # included in the symbol list include_expsyms= # exclude_expsyms can be an extended regexp of symbols to exclude # it will be wrapped by ' (' and ')$', so one must not match beginning or # end of line. Example: 'a|bc|.*d.*' will exclude the symbols 'a' and 'bc', # as well as any symbol that contains 'd'. exclude_expsyms='_GLOBAL_OFFSET_TABLE_|_GLOBAL__F[ID]_.*' # Although _GLOBAL_OFFSET_TABLE_ is a valid symbol C name, most a.out # platforms (ab)use it in PIC code, but their linkers get confused if # the symbol is explicitly referenced. Since portable code cannot # rely on this symbol name, it's probably fine to never include it in # preloaded symbol tables. # Exclude shared library initialization/finalization symbols. extract_expsyms_cmds= case $host_os in cygwin* | mingw* | pw32* | cegcc*) # FIXME: the MSVC++ port hasn't been tested in a loooong time # When not using gcc, we currently assume that we are using # Microsoft Visual C++. if test yes != "$GCC"; then with_gnu_ld=no fi ;; interix*) # we just hope/assume this is gcc and not c89 (= MSVC++) with_gnu_ld=yes ;; openbsd* | bitrig*) with_gnu_ld=no ;; esac ld_shlibs=yes # On some targets, GNU ld is compatible enough with the native linker # that we're better off using the native interface for both. lt_use_gnu_ld_interface=no if test yes = "$with_gnu_ld"; then case $host_os in aix*) # The AIX port of GNU ld has always aspired to compatibility # with the native linker. However, as the warning in the GNU ld # block says, versions before 2.19.5* couldn't really create working # shared libraries, regardless of the interface used. case `$LD -v 2>&1` in *\ \(GNU\ Binutils\)\ 2.19.5*) ;; *\ \(GNU\ Binutils\)\ 2.[2-9]*) ;; *\ \(GNU\ Binutils\)\ [3-9]*) ;; *) lt_use_gnu_ld_interface=yes ;; esac ;; *) lt_use_gnu_ld_interface=yes ;; esac fi if test yes = "$lt_use_gnu_ld_interface"; then # If archive_cmds runs LD, not CC, wlarc should be empty wlarc='$wl' # Set some defaults for GNU ld with shared library support. These # are reset later if shared libraries are not supported. Putting them # here allows them to be overridden if necessary. runpath_var=LD_RUN_PATH hardcode_libdir_flag_spec='$wl-rpath $wl$libdir' export_dynamic_flag_spec='$wl--export-dynamic' # ancient GNU ld didn't support --whole-archive et. al. if $LD --help 2>&1 | $GREP 'no-whole-archive' > /dev/null; then whole_archive_flag_spec=$wlarc'--whole-archive$convenience '$wlarc'--no-whole-archive' else whole_archive_flag_spec= fi supports_anon_versioning=no case `$LD -v | $SED -e 's/(^)\+)\s\+//' 2>&1` in *GNU\ gold*) supports_anon_versioning=yes ;; *\ [01].* | *\ 2.[0-9].* | *\ 2.10.*) ;; # catch versions < 2.11 *\ 2.11.93.0.2\ *) supports_anon_versioning=yes ;; # RH7.3 ... *\ 2.11.92.0.12\ *) supports_anon_versioning=yes ;; # Mandrake 8.2 ... *\ 2.11.*) ;; # other 2.11 versions *) supports_anon_versioning=yes ;; esac # See if GNU ld supports shared libraries. case $host_os in aix[3-9]*) # On AIX/PPC, the GNU linker is very broken if test ia64 != "$host_cpu"; then ld_shlibs=no cat <<_LT_EOF 1>&2 *** Warning: the GNU linker, at least up to release 2.19, is reported *** to be unable to reliably create shared libraries on AIX. *** Therefore, libtool is disabling shared libraries support. If you *** really care for shared libraries, you may want to install binutils *** 2.20 or above, or modify your PATH so that a non-GNU linker is found. *** You will then need to restart the configuration process. _LT_EOF fi ;; amigaos*) case $host_cpu in powerpc) # see comment about AmigaOS4 .so support archive_cmds='$CC -shared $libobjs $deplibs $compiler_flags $wl-soname $wl$soname -o $lib' archive_expsym_cmds='' ;; m68k) archive_cmds='$RM $output_objdir/a2ixlibrary.data~$ECHO "#define NAME $libname" > $output_objdir/a2ixlibrary.data~$ECHO "#define LIBRARY_ID 1" >> $output_objdir/a2ixlibrary.data~$ECHO "#define VERSION $major" >> $output_objdir/a2ixlibrary.data~$ECHO "#define REVISION $revision" >> $output_objdir/a2ixlibrary.data~$AR $AR_FLAGS $lib $libobjs~$RANLIB $lib~(cd $output_objdir && a2ixlibrary -32)' hardcode_libdir_flag_spec='-L$libdir' hardcode_minus_L=yes ;; esac ;; beos*) if $LD --help 2>&1 | $GREP ': supported targets:.* elf' > /dev/null; then allow_undefined_flag=unsupported # Joseph Beckenbach says some releases of gcc # support --undefined. This deserves some investigation. FIXME archive_cmds='$CC -nostart $libobjs $deplibs $compiler_flags $wl-soname $wl$soname -o $lib' else ld_shlibs=no fi ;; cygwin* | mingw* | pw32* | cegcc*) # _LT_TAGVAR(hardcode_libdir_flag_spec, ) is actually meaningless, # as there is no search path for DLLs. hardcode_libdir_flag_spec='-L$libdir' export_dynamic_flag_spec='$wl--export-all-symbols' allow_undefined_flag=unsupported always_export_symbols=no enable_shared_with_static_runtimes=yes export_symbols_cmds='$NM $libobjs $convenience | $global_symbol_pipe | $SED -e '\''/^[BCDGRS][ ]/s/.*[ ]\([^ ]*\)/\1 DATA/;s/^.*[ ]__nm__\([^ ]*\)[ ][^ ]*/\1 DATA/;/^I[ ]/d;/^[AITW][ ]/s/.* //'\'' | sort | uniq > $export_symbols' exclude_expsyms='[_]+GLOBAL_OFFSET_TABLE_|[_]+GLOBAL__[FID]_.*|[_]+head_[A-Za-z0-9_]+_dll|[A-Za-z0-9_]+_dll_iname' if $LD --help 2>&1 | $GREP 'auto-import' > /dev/null; then archive_cmds='$CC -shared $libobjs $deplibs $compiler_flags -o $output_objdir/$soname $wl--enable-auto-image-base -Xlinker --out-implib -Xlinker $lib' # If the export-symbols file already is a .def file, use it as # is; otherwise, prepend EXPORTS... archive_expsym_cmds='if test DEF = "`$SED -n -e '\''s/^[ ]*//'\'' -e '\''/^\(;.*\)*$/d'\'' -e '\''s/^\(EXPORTS\|LIBRARY\)\([ ].*\)*$/DEF/p'\'' -e q $export_symbols`" ; then cp $export_symbols $output_objdir/$soname.def; else echo EXPORTS > $output_objdir/$soname.def; cat $export_symbols >> $output_objdir/$soname.def; fi~ $CC -shared $output_objdir/$soname.def $libobjs $deplibs $compiler_flags -o $output_objdir/$soname $wl--enable-auto-image-base -Xlinker --out-implib -Xlinker $lib' else ld_shlibs=no fi ;; haiku*) archive_cmds='$CC -shared $libobjs $deplibs $compiler_flags $wl-soname $wl$soname -o $lib' link_all_deplibs=yes ;; os2*) hardcode_libdir_flag_spec='-L$libdir' hardcode_minus_L=yes allow_undefined_flag=unsupported shrext_cmds=.dll archive_cmds='$ECHO "LIBRARY ${soname%$shared_ext} INITINSTANCE TERMINSTANCE" > $output_objdir/$libname.def~ $ECHO "DESCRIPTION \"$libname\"" >> $output_objdir/$libname.def~ $ECHO "DATA MULTIPLE NONSHARED" >> $output_objdir/$libname.def~ $ECHO EXPORTS >> $output_objdir/$libname.def~ emxexp $libobjs | $SED /"_DLL_InitTerm"/d >> $output_objdir/$libname.def~ $CC -Zdll -Zcrtdll -o $output_objdir/$soname $libobjs $deplibs $compiler_flags $output_objdir/$libname.def~ emximp -o $lib $output_objdir/$libname.def' archive_expsym_cmds='$ECHO "LIBRARY ${soname%$shared_ext} INITINSTANCE TERMINSTANCE" > $output_objdir/$libname.def~ $ECHO "DESCRIPTION \"$libname\"" >> $output_objdir/$libname.def~ $ECHO "DATA MULTIPLE NONSHARED" >> $output_objdir/$libname.def~ $ECHO EXPORTS >> $output_objdir/$libname.def~ prefix_cmds="$SED"~ if test EXPORTS = "`$SED 1q $export_symbols`"; then prefix_cmds="$prefix_cmds -e 1d"; fi~ prefix_cmds="$prefix_cmds -e \"s/^\(.*\)$/_\1/g\""~ cat $export_symbols | $prefix_cmds >> $output_objdir/$libname.def~ $CC -Zdll -Zcrtdll -o $output_objdir/$soname $libobjs $deplibs $compiler_flags $output_objdir/$libname.def~ emximp -o $lib $output_objdir/$libname.def' old_archive_From_new_cmds='emximp -o $output_objdir/${libname}_dll.a $output_objdir/$libname.def' enable_shared_with_static_runtimes=yes ;; interix[3-9]*) hardcode_direct=no hardcode_shlibpath_var=no hardcode_libdir_flag_spec='$wl-rpath,$libdir' export_dynamic_flag_spec='$wl-E' # Hack: On Interix 3.x, we cannot compile PIC because of a broken gcc. # Instead, shared libraries are loaded at an image base (0x10000000 by # default) and relocated if they conflict, which is a slow very memory # consuming and fragmenting process. To avoid this, we pick a random, # 256 KiB-aligned image base between 0x50000000 and 0x6FFC0000 at link # time. Moving up from 0x10000000 also allows more sbrk(2) space. archive_cmds='$CC -shared $pic_flag $libobjs $deplibs $compiler_flags $wl-h,$soname $wl--image-base,`expr ${RANDOM-$$} % 4096 / 2 \* 262144 + 1342177280` -o $lib' archive_expsym_cmds='sed "s|^|_|" $export_symbols >$output_objdir/$soname.expsym~$CC -shared $pic_flag $libobjs $deplibs $compiler_flags $wl-h,$soname $wl--retain-symbols-file,$output_objdir/$soname.expsym $wl--image-base,`expr ${RANDOM-$$} % 4096 / 2 \* 262144 + 1342177280` -o $lib' ;; gnu* | linux* | tpf* | k*bsd*-gnu | kopensolaris*-gnu) tmp_diet=no if test linux-dietlibc = "$host_os"; then case $cc_basename in diet\ *) tmp_diet=yes;; # linux-dietlibc with static linking (!diet-dyn) esac fi if $LD --help 2>&1 | $EGREP ': supported targets:.* elf' > /dev/null \ && test no = "$tmp_diet" then tmp_addflag=' $pic_flag' tmp_sharedflag='-shared' case $cc_basename,$host_cpu in pgcc*) # Portland Group C compiler whole_archive_flag_spec='$wl--whole-archive`for conv in $convenience\"\"; do test -n \"$conv\" && new_convenience=\"$new_convenience,$conv\"; done; func_echo_all \"$new_convenience\"` $wl--no-whole-archive' tmp_addflag=' $pic_flag' ;; pgf77* | pgf90* | pgf95* | pgfortran*) # Portland Group f77 and f90 compilers whole_archive_flag_spec='$wl--whole-archive`for conv in $convenience\"\"; do test -n \"$conv\" && new_convenience=\"$new_convenience,$conv\"; done; func_echo_all \"$new_convenience\"` $wl--no-whole-archive' tmp_addflag=' $pic_flag -Mnomain' ;; ecc*,ia64* | icc*,ia64*) # Intel C compiler on ia64 tmp_addflag=' -i_dynamic' ;; efc*,ia64* | ifort*,ia64*) # Intel Fortran compiler on ia64 tmp_addflag=' -i_dynamic -nofor_main' ;; ifc* | ifort*) # Intel Fortran compiler tmp_addflag=' -nofor_main' ;; lf95*) # Lahey Fortran 8.1 whole_archive_flag_spec= tmp_sharedflag='--shared' ;; nagfor*) # NAGFOR 5.3 tmp_sharedflag='-Wl,-shared' ;; xl[cC]* | bgxl[cC]* | mpixl[cC]*) # IBM XL C 8.0 on PPC (deal with xlf below) tmp_sharedflag='-qmkshrobj' tmp_addflag= ;; nvcc*) # Cuda Compiler Driver 2.2 whole_archive_flag_spec='$wl--whole-archive`for conv in $convenience\"\"; do test -n \"$conv\" && new_convenience=\"$new_convenience,$conv\"; done; func_echo_all \"$new_convenience\"` $wl--no-whole-archive' compiler_needs_object=yes ;; esac case `$CC -V 2>&1 | sed 5q` in *Sun\ C*) # Sun C 5.9 whole_archive_flag_spec='$wl--whole-archive`new_convenience=; for conv in $convenience\"\"; do test -z \"$conv\" || new_convenience=\"$new_convenience,$conv\"; done; func_echo_all \"$new_convenience\"` $wl--no-whole-archive' compiler_needs_object=yes tmp_sharedflag='-G' ;; *Sun\ F*) # Sun Fortran 8.3 tmp_sharedflag='-G' ;; esac archive_cmds='$CC '"$tmp_sharedflag""$tmp_addflag"' $libobjs $deplibs $compiler_flags $wl-soname $wl$soname -o $lib' if test yes = "$supports_anon_versioning"; then archive_expsym_cmds='echo "{ global:" > $output_objdir/$libname.ver~ cat $export_symbols | sed -e "s/\(.*\)/\1;/" >> $output_objdir/$libname.ver~ echo "local: *; };" >> $output_objdir/$libname.ver~ $CC '"$tmp_sharedflag""$tmp_addflag"' $libobjs $deplibs $compiler_flags $wl-soname $wl$soname $wl-version-script $wl$output_objdir/$libname.ver -o $lib' fi case $cc_basename in tcc*) export_dynamic_flag_spec='-rdynamic' ;; xlf* | bgf* | bgxlf* | mpixlf*) # IBM XL Fortran 10.1 on PPC cannot create shared libs itself whole_archive_flag_spec='--whole-archive$convenience --no-whole-archive' hardcode_libdir_flag_spec='$wl-rpath $wl$libdir' archive_cmds='$LD -shared $libobjs $deplibs $linker_flags -soname $soname -o $lib' if test yes = "$supports_anon_versioning"; then archive_expsym_cmds='echo "{ global:" > $output_objdir/$libname.ver~ cat $export_symbols | sed -e "s/\(.*\)/\1;/" >> $output_objdir/$libname.ver~ echo "local: *; };" >> $output_objdir/$libname.ver~ $LD -shared $libobjs $deplibs $linker_flags -soname $soname -version-script $output_objdir/$libname.ver -o $lib' fi ;; esac else ld_shlibs=no fi ;; netbsd*) if echo __ELF__ | $CC -E - | $GREP __ELF__ >/dev/null; then archive_cmds='$LD -Bshareable $libobjs $deplibs $linker_flags -o $lib' wlarc= else archive_cmds='$CC -shared $pic_flag $libobjs $deplibs $compiler_flags $wl-soname $wl$soname -o $lib' archive_expsym_cmds='$CC -shared $pic_flag $libobjs $deplibs $compiler_flags $wl-soname $wl$soname $wl-retain-symbols-file $wl$export_symbols -o $lib' fi ;; solaris*) if $LD -v 2>&1 | $GREP 'BFD 2\.8' > /dev/null; then ld_shlibs=no cat <<_LT_EOF 1>&2 *** Warning: The releases 2.8.* of the GNU linker cannot reliably *** create shared libraries on Solaris systems. Therefore, libtool *** is disabling shared libraries support. We urge you to upgrade GNU *** binutils to release 2.9.1 or newer. Another option is to modify *** your PATH or compiler configuration so that the native linker is *** used, and then restart. _LT_EOF elif $LD --help 2>&1 | $GREP ': supported targets:.* elf' > /dev/null; then archive_cmds='$CC -shared $pic_flag $libobjs $deplibs $compiler_flags $wl-soname $wl$soname -o $lib' archive_expsym_cmds='$CC -shared $pic_flag $libobjs $deplibs $compiler_flags $wl-soname $wl$soname $wl-retain-symbols-file $wl$export_symbols -o $lib' else ld_shlibs=no fi ;; sysv5* | sco3.2v5* | sco5v6* | unixware* | OpenUNIX*) case `$LD -v 2>&1` in *\ [01].* | *\ 2.[0-9].* | *\ 2.1[0-5].*) ld_shlibs=no cat <<_LT_EOF 1>&2 *** Warning: Releases of the GNU linker prior to 2.16.91.0.3 cannot *** reliably create shared libraries on SCO systems. Therefore, libtool *** is disabling shared libraries support. We urge you to upgrade GNU *** binutils to release 2.16.91.0.3 or newer. Another option is to modify *** your PATH or compiler configuration so that the native linker is *** used, and then restart. _LT_EOF ;; *) # For security reasons, it is highly recommended that you always # use absolute paths for naming shared libraries, and exclude the # DT_RUNPATH tag from executables and libraries. But doing so # requires that you compile everything twice, which is a pain. if $LD --help 2>&1 | $GREP ': supported targets:.* elf' > /dev/null; then hardcode_libdir_flag_spec='$wl-rpath $wl$libdir' archive_cmds='$CC -shared $libobjs $deplibs $compiler_flags $wl-soname $wl$soname -o $lib' archive_expsym_cmds='$CC -shared $libobjs $deplibs $compiler_flags $wl-soname $wl$soname $wl-retain-symbols-file $wl$export_symbols -o $lib' else ld_shlibs=no fi ;; esac ;; sunos4*) archive_cmds='$LD -assert pure-text -Bshareable -o $lib $libobjs $deplibs $linker_flags' wlarc= hardcode_direct=yes hardcode_shlibpath_var=no ;; *) if $LD --help 2>&1 | $GREP ': supported targets:.* elf' > /dev/null; then archive_cmds='$CC -shared $pic_flag $libobjs $deplibs $compiler_flags $wl-soname $wl$soname -o $lib' archive_expsym_cmds='$CC -shared $pic_flag $libobjs $deplibs $compiler_flags $wl-soname $wl$soname $wl-retain-symbols-file $wl$export_symbols -o $lib' else ld_shlibs=no fi ;; esac if test no = "$ld_shlibs"; then runpath_var= hardcode_libdir_flag_spec= export_dynamic_flag_spec= whole_archive_flag_spec= fi else # PORTME fill in a description of your system's linker (not GNU ld) case $host_os in aix3*) allow_undefined_flag=unsupported always_export_symbols=yes archive_expsym_cmds='$LD -o $output_objdir/$soname $libobjs $deplibs $linker_flags -bE:$export_symbols -T512 -H512 -bM:SRE~$AR $AR_FLAGS $lib $output_objdir/$soname' # Note: this linker hardcodes the directories in LIBPATH if there # are no directories specified by -L. hardcode_minus_L=yes if test yes = "$GCC" && test -z "$lt_prog_compiler_static"; then # Neither direct hardcoding nor static linking is supported with a # broken collect2. hardcode_direct=unsupported fi ;; aix[4-9]*) if test ia64 = "$host_cpu"; then # On IA64, the linker does run time linking by default, so we don't # have to do anything special. aix_use_runtimelinking=no exp_sym_flag='-Bexport' no_entry_flag= else # If we're using GNU nm, then we don't want the "-C" option. # -C means demangle to GNU nm, but means don't demangle to AIX nm. # Without the "-l" option, or with the "-B" option, AIX nm treats # weak defined symbols like other global defined symbols, whereas # GNU nm marks them as "W". # While the 'weak' keyword is ignored in the Export File, we need # it in the Import File for the 'aix-soname' feature, so we have # to replace the "-B" option with "-P" for AIX nm. if $NM -V 2>&1 | $GREP 'GNU' > /dev/null; then export_symbols_cmds='$NM -Bpg $libobjs $convenience | awk '\''{ if (((\$ 2 == "T") || (\$ 2 == "D") || (\$ 2 == "B") || (\$ 2 == "W")) && (substr(\$ 3,1,1) != ".")) { if (\$ 2 == "W") { print \$ 3 " weak" } else { print \$ 3 } } }'\'' | sort -u > $export_symbols' else export_symbols_cmds='`func_echo_all $NM | $SED -e '\''s/B\([^B]*\)$/P\1/'\''` -PCpgl $libobjs $convenience | awk '\''{ if (((\$ 2 == "T") || (\$ 2 == "D") || (\$ 2 == "B") || (\$ 2 == "W") || (\$ 2 == "V") || (\$ 2 == "Z")) && (substr(\$ 1,1,1) != ".")) { if ((\$ 2 == "W") || (\$ 2 == "V") || (\$ 2 == "Z")) { print \$ 1 " weak" } else { print \$ 1 } } }'\'' | sort -u > $export_symbols' fi aix_use_runtimelinking=no # Test if we are trying to use run time linking or normal # AIX style linking. If -brtl is somewhere in LDFLAGS, we # have runtime linking enabled, and use it for executables. # For shared libraries, we enable/disable runtime linking # depending on the kind of the shared library created - # when "with_aix_soname,aix_use_runtimelinking" is: # "aix,no" lib.a(lib.so.V) shared, rtl:no, for executables # "aix,yes" lib.so shared, rtl:yes, for executables # lib.a static archive # "both,no" lib.so.V(shr.o) shared, rtl:yes # lib.a(lib.so.V) shared, rtl:no, for executables # "both,yes" lib.so.V(shr.o) shared, rtl:yes, for executables # lib.a(lib.so.V) shared, rtl:no # "svr4,*" lib.so.V(shr.o) shared, rtl:yes, for executables # lib.a static archive case $host_os in aix4.[23]|aix4.[23].*|aix[5-9]*) for ld_flag in $LDFLAGS; do if (test x-brtl = "x$ld_flag" || test x-Wl,-brtl = "x$ld_flag"); then aix_use_runtimelinking=yes break fi done if test svr4,no = "$with_aix_soname,$aix_use_runtimelinking"; then # With aix-soname=svr4, we create the lib.so.V shared archives only, # so we don't have lib.a shared libs to link our executables. # We have to force runtime linking in this case. aix_use_runtimelinking=yes LDFLAGS="$LDFLAGS -Wl,-brtl" fi ;; esac exp_sym_flag='-bexport' no_entry_flag='-bnoentry' fi # When large executables or shared objects are built, AIX ld can # have problems creating the table of contents. If linking a library # or program results in "error TOC overflow" add -mminimal-toc to # CXXFLAGS/CFLAGS for g++/gcc. In the cases where that is not # enough to fix the problem, add -Wl,-bbigtoc to LDFLAGS. archive_cmds='' hardcode_direct=yes hardcode_direct_absolute=yes hardcode_libdir_separator=':' link_all_deplibs=yes file_list_spec='$wl-f,' case $with_aix_soname,$aix_use_runtimelinking in aix,*) ;; # traditional, no import file svr4,* | *,yes) # use import file # The Import File defines what to hardcode. hardcode_direct=no hardcode_direct_absolute=no ;; esac if test yes = "$GCC"; then case $host_os in aix4.[012]|aix4.[012].*) # We only want to do this on AIX 4.2 and lower, the check # below for broken collect2 doesn't work under 4.3+ collect2name=`$CC -print-prog-name=collect2` if test -f "$collect2name" && strings "$collect2name" | $GREP resolve_lib_name >/dev/null then # We have reworked collect2 : else # We have old collect2 hardcode_direct=unsupported # It fails to find uninstalled libraries when the uninstalled # path is not listed in the libpath. Setting hardcode_minus_L # to unsupported forces relinking hardcode_minus_L=yes hardcode_libdir_flag_spec='-L$libdir' hardcode_libdir_separator= fi ;; esac shared_flag='-shared' if test yes = "$aix_use_runtimelinking"; then shared_flag="$shared_flag "'$wl-G' fi # Need to ensure runtime linking is disabled for the traditional # shared library, or the linker may eventually find shared libraries # /with/ Import File - we do not want to mix them. shared_flag_aix='-shared' shared_flag_svr4='-shared $wl-G' else # not using gcc if test ia64 = "$host_cpu"; then # VisualAge C++, Version 5.5 for AIX 5L for IA-64, Beta 3 Release # chokes on -Wl,-G. The following line is correct: shared_flag='-G' else if test yes = "$aix_use_runtimelinking"; then shared_flag='$wl-G' else shared_flag='$wl-bM:SRE' fi shared_flag_aix='$wl-bM:SRE' shared_flag_svr4='$wl-G' fi fi export_dynamic_flag_spec='$wl-bexpall' # It seems that -bexpall does not export symbols beginning with # underscore (_), so it is better to generate a list of symbols to export. always_export_symbols=yes if test aix,yes = "$with_aix_soname,$aix_use_runtimelinking"; then # Warning - without using the other runtime loading flags (-brtl), # -berok will link without error, but may produce a broken library. allow_undefined_flag='-berok' # Determine the default libpath from the value encoded in an # empty executable. if test set = "${lt_cv_aix_libpath+set}"; then aix_libpath=$lt_cv_aix_libpath else if ${lt_cv_aix_libpath_+:} false; then : $as_echo_n "(cached) " >&6 else cat confdefs.h - <<_ACEOF >conftest.$ac_ext /* end confdefs.h. */ int main () { ; return 0; } _ACEOF if ac_fn_c_try_link "$LINENO"; then : lt_aix_libpath_sed=' /Import File Strings/,/^$/ { /^0/ { s/^0 *\([^ ]*\) *$/\1/ p } }' lt_cv_aix_libpath_=`dump -H conftest$ac_exeext 2>/dev/null | $SED -n -e "$lt_aix_libpath_sed"` # Check for a 64-bit object if we didn't find anything. if test -z "$lt_cv_aix_libpath_"; then lt_cv_aix_libpath_=`dump -HX64 conftest$ac_exeext 2>/dev/null | $SED -n -e "$lt_aix_libpath_sed"` fi fi rm -f core conftest.err conftest.$ac_objext \ conftest$ac_exeext conftest.$ac_ext if test -z "$lt_cv_aix_libpath_"; then lt_cv_aix_libpath_=/usr/lib:/lib fi fi aix_libpath=$lt_cv_aix_libpath_ fi hardcode_libdir_flag_spec='$wl-blibpath:$libdir:'"$aix_libpath" archive_expsym_cmds='$CC -o $output_objdir/$soname $libobjs $deplibs $wl'$no_entry_flag' $compiler_flags `if test -n "$allow_undefined_flag"; then func_echo_all "$wl$allow_undefined_flag"; else :; fi` $wl'$exp_sym_flag:\$export_symbols' '$shared_flag else if test ia64 = "$host_cpu"; then hardcode_libdir_flag_spec='$wl-R $libdir:/usr/lib:/lib' allow_undefined_flag="-z nodefs" archive_expsym_cmds="\$CC $shared_flag"' -o $output_objdir/$soname $libobjs $deplibs '"\$wl$no_entry_flag"' $compiler_flags $wl$allow_undefined_flag '"\$wl$exp_sym_flag:\$export_symbols" else # Determine the default libpath from the value encoded in an # empty executable. if test set = "${lt_cv_aix_libpath+set}"; then aix_libpath=$lt_cv_aix_libpath else if ${lt_cv_aix_libpath_+:} false; then : $as_echo_n "(cached) " >&6 else cat confdefs.h - <<_ACEOF >conftest.$ac_ext /* end confdefs.h. */ int main () { ; return 0; } _ACEOF if ac_fn_c_try_link "$LINENO"; then : lt_aix_libpath_sed=' /Import File Strings/,/^$/ { /^0/ { s/^0 *\([^ ]*\) *$/\1/ p } }' lt_cv_aix_libpath_=`dump -H conftest$ac_exeext 2>/dev/null | $SED -n -e "$lt_aix_libpath_sed"` # Check for a 64-bit object if we didn't find anything. if test -z "$lt_cv_aix_libpath_"; then lt_cv_aix_libpath_=`dump -HX64 conftest$ac_exeext 2>/dev/null | $SED -n -e "$lt_aix_libpath_sed"` fi fi rm -f core conftest.err conftest.$ac_objext \ conftest$ac_exeext conftest.$ac_ext if test -z "$lt_cv_aix_libpath_"; then lt_cv_aix_libpath_=/usr/lib:/lib fi fi aix_libpath=$lt_cv_aix_libpath_ fi hardcode_libdir_flag_spec='$wl-blibpath:$libdir:'"$aix_libpath" # Warning - without using the other run time loading flags, # -berok will link without error, but may produce a broken library. no_undefined_flag=' $wl-bernotok' allow_undefined_flag=' $wl-berok' if test yes = "$with_gnu_ld"; then # We only use this code for GNU lds that support --whole-archive. whole_archive_flag_spec='$wl--whole-archive$convenience $wl--no-whole-archive' else # Exported symbols can be pulled into shared objects from archives whole_archive_flag_spec='$convenience' fi archive_cmds_need_lc=yes archive_expsym_cmds='$RM -r $output_objdir/$realname.d~$MKDIR $output_objdir/$realname.d' # -brtl affects multiple linker settings, -berok does not and is overridden later compiler_flags_filtered='`func_echo_all "$compiler_flags " | $SED -e "s%-brtl\\([, ]\\)%-berok\\1%g"`' if test svr4 != "$with_aix_soname"; then # This is similar to how AIX traditionally builds its shared libraries. archive_expsym_cmds="$archive_expsym_cmds"'~$CC '$shared_flag_aix' -o $output_objdir/$realname.d/$soname $libobjs $deplibs $wl-bnoentry '$compiler_flags_filtered'$wl-bE:$export_symbols$allow_undefined_flag~$AR $AR_FLAGS $output_objdir/$libname$release.a $output_objdir/$realname.d/$soname' fi if test aix != "$with_aix_soname"; then archive_expsym_cmds="$archive_expsym_cmds"'~$CC '$shared_flag_svr4' -o $output_objdir/$realname.d/$shared_archive_member_spec.o $libobjs $deplibs $wl-bnoentry '$compiler_flags_filtered'$wl-bE:$export_symbols$allow_undefined_flag~$STRIP -e $output_objdir/$realname.d/$shared_archive_member_spec.o~( func_echo_all "#! $soname($shared_archive_member_spec.o)"; if test shr_64 = "$shared_archive_member_spec"; then func_echo_all "# 64"; else func_echo_all "# 32"; fi; cat $export_symbols ) > $output_objdir/$realname.d/$shared_archive_member_spec.imp~$AR $AR_FLAGS $output_objdir/$soname $output_objdir/$realname.d/$shared_archive_member_spec.o $output_objdir/$realname.d/$shared_archive_member_spec.imp' else # used by -dlpreopen to get the symbols archive_expsym_cmds="$archive_expsym_cmds"'~$MV $output_objdir/$realname.d/$soname $output_objdir' fi archive_expsym_cmds="$archive_expsym_cmds"'~$RM -r $output_objdir/$realname.d' fi fi ;; amigaos*) case $host_cpu in powerpc) # see comment about AmigaOS4 .so support archive_cmds='$CC -shared $libobjs $deplibs $compiler_flags $wl-soname $wl$soname -o $lib' archive_expsym_cmds='' ;; m68k) archive_cmds='$RM $output_objdir/a2ixlibrary.data~$ECHO "#define NAME $libname" > $output_objdir/a2ixlibrary.data~$ECHO "#define LIBRARY_ID 1" >> $output_objdir/a2ixlibrary.data~$ECHO "#define VERSION $major" >> $output_objdir/a2ixlibrary.data~$ECHO "#define REVISION $revision" >> $output_objdir/a2ixlibrary.data~$AR $AR_FLAGS $lib $libobjs~$RANLIB $lib~(cd $output_objdir && a2ixlibrary -32)' hardcode_libdir_flag_spec='-L$libdir' hardcode_minus_L=yes ;; esac ;; bsdi[45]*) export_dynamic_flag_spec=-rdynamic ;; cygwin* | mingw* | pw32* | cegcc*) # When not using gcc, we currently assume that we are using # Microsoft Visual C++. # hardcode_libdir_flag_spec is actually meaningless, as there is # no search path for DLLs. case $cc_basename in cl*) # Native MSVC hardcode_libdir_flag_spec=' ' allow_undefined_flag=unsupported always_export_symbols=yes file_list_spec='@' # Tell ltmain to make .lib files, not .a files. libext=lib # Tell ltmain to make .dll files, not .so files. shrext_cmds=.dll # FIXME: Setting linknames here is a bad hack. archive_cmds='$CC -o $output_objdir/$soname $libobjs $compiler_flags $deplibs -Wl,-DLL,-IMPLIB:"$tool_output_objdir$libname.dll.lib"~linknames=' archive_expsym_cmds='if test DEF = "`$SED -n -e '\''s/^[ ]*//'\'' -e '\''/^\(;.*\)*$/d'\'' -e '\''s/^\(EXPORTS\|LIBRARY\)\([ ].*\)*$/DEF/p'\'' -e q $export_symbols`" ; then cp "$export_symbols" "$output_objdir/$soname.def"; echo "$tool_output_objdir$soname.def" > "$output_objdir/$soname.exp"; else $SED -e '\''s/^/-link -EXPORT:/'\'' < $export_symbols > $output_objdir/$soname.exp; fi~ $CC -o $tool_output_objdir$soname $libobjs $compiler_flags $deplibs "@$tool_output_objdir$soname.exp" -Wl,-DLL,-IMPLIB:"$tool_output_objdir$libname.dll.lib"~ linknames=' # The linker will not automatically build a static lib if we build a DLL. # _LT_TAGVAR(old_archive_from_new_cmds, )='true' enable_shared_with_static_runtimes=yes exclude_expsyms='_NULL_IMPORT_DESCRIPTOR|_IMPORT_DESCRIPTOR_.*' export_symbols_cmds='$NM $libobjs $convenience | $global_symbol_pipe | $SED -e '\''/^[BCDGRS][ ]/s/.*[ ]\([^ ]*\)/\1,DATA/'\'' | $SED -e '\''/^[AITW][ ]/s/.*[ ]//'\'' | sort | uniq > $export_symbols' # Don't use ranlib old_postinstall_cmds='chmod 644 $oldlib' postlink_cmds='lt_outputfile="@OUTPUT@"~ lt_tool_outputfile="@TOOL_OUTPUT@"~ case $lt_outputfile in *.exe|*.EXE) ;; *) lt_outputfile=$lt_outputfile.exe lt_tool_outputfile=$lt_tool_outputfile.exe ;; esac~ if test : != "$MANIFEST_TOOL" && test -f "$lt_outputfile.manifest"; then $MANIFEST_TOOL -manifest "$lt_tool_outputfile.manifest" -outputresource:"$lt_tool_outputfile" || exit 1; $RM "$lt_outputfile.manifest"; fi' ;; *) # Assume MSVC wrapper hardcode_libdir_flag_spec=' ' allow_undefined_flag=unsupported # Tell ltmain to make .lib files, not .a files. libext=lib # Tell ltmain to make .dll files, not .so files. shrext_cmds=.dll # FIXME: Setting linknames here is a bad hack. archive_cmds='$CC -o $lib $libobjs $compiler_flags `func_echo_all "$deplibs" | $SED '\''s/ -lc$//'\''` -link -dll~linknames=' # The linker will automatically build a .lib file if we build a DLL. old_archive_from_new_cmds='true' # FIXME: Should let the user specify the lib program. old_archive_cmds='lib -OUT:$oldlib$oldobjs$old_deplibs' enable_shared_with_static_runtimes=yes ;; esac ;; darwin* | rhapsody*) archive_cmds_need_lc=no hardcode_direct=no hardcode_automatic=yes hardcode_shlibpath_var=unsupported if test yes = "$lt_cv_ld_force_load"; then whole_archive_flag_spec='`for conv in $convenience\"\"; do test -n \"$conv\" && new_convenience=\"$new_convenience $wl-force_load,$conv\"; done; func_echo_all \"$new_convenience\"`' else whole_archive_flag_spec='' fi link_all_deplibs=yes allow_undefined_flag=$_lt_dar_allow_undefined case $cc_basename in ifort*|nagfor*) _lt_dar_can_shared=yes ;; *) _lt_dar_can_shared=$GCC ;; esac if test yes = "$_lt_dar_can_shared"; then output_verbose_link_cmd=func_echo_all archive_cmds="\$CC -dynamiclib \$allow_undefined_flag -o \$lib \$libobjs \$deplibs \$compiler_flags -install_name \$rpath/\$soname \$verstring $_lt_dar_single_mod$_lt_dsymutil" module_cmds="\$CC \$allow_undefined_flag -o \$lib -bundle \$libobjs \$deplibs \$compiler_flags$_lt_dsymutil" archive_expsym_cmds="sed 's|^|_|' < \$export_symbols > \$output_objdir/\$libname-symbols.expsym~\$CC -dynamiclib \$allow_undefined_flag -o \$lib \$libobjs \$deplibs \$compiler_flags -install_name \$rpath/\$soname \$verstring $_lt_dar_single_mod$_lt_dar_export_syms$_lt_dsymutil" module_expsym_cmds="sed -e 's|^|_|' < \$export_symbols > \$output_objdir/\$libname-symbols.expsym~\$CC \$allow_undefined_flag -o \$lib -bundle \$libobjs \$deplibs \$compiler_flags$_lt_dar_export_syms$_lt_dsymutil" else ld_shlibs=no fi ;; dgux*) archive_cmds='$LD -G -h $soname -o $lib $libobjs $deplibs $linker_flags' hardcode_libdir_flag_spec='-L$libdir' hardcode_shlibpath_var=no ;; # FreeBSD 2.2.[012] allows us to include c++rt0.o to get C++ constructor # support. Future versions do this automatically, but an explicit c++rt0.o # does not break anything, and helps significantly (at the cost of a little # extra space). freebsd2.2*) archive_cmds='$LD -Bshareable -o $lib $libobjs $deplibs $linker_flags /usr/lib/c++rt0.o' hardcode_libdir_flag_spec='-R$libdir' hardcode_direct=yes hardcode_shlibpath_var=no ;; # Unfortunately, older versions of FreeBSD 2 do not have this feature. freebsd2.*) archive_cmds='$LD -Bshareable -o $lib $libobjs $deplibs $linker_flags' hardcode_direct=yes hardcode_minus_L=yes hardcode_shlibpath_var=no ;; # FreeBSD 3 and greater uses gcc -shared to do shared libraries. freebsd* | dragonfly*) archive_cmds='$CC -shared $pic_flag -o $lib $libobjs $deplibs $compiler_flags' hardcode_libdir_flag_spec='-R$libdir' hardcode_direct=yes hardcode_shlibpath_var=no ;; hpux9*) if test yes = "$GCC"; then archive_cmds='$RM $output_objdir/$soname~$CC -shared $pic_flag $wl+b $wl$install_libdir -o $output_objdir/$soname $libobjs $deplibs $compiler_flags~test "x$output_objdir/$soname" = "x$lib" || mv $output_objdir/$soname $lib' else archive_cmds='$RM $output_objdir/$soname~$LD -b +b $install_libdir -o $output_objdir/$soname $libobjs $deplibs $linker_flags~test "x$output_objdir/$soname" = "x$lib" || mv $output_objdir/$soname $lib' fi hardcode_libdir_flag_spec='$wl+b $wl$libdir' hardcode_libdir_separator=: hardcode_direct=yes # hardcode_minus_L: Not really in the search PATH, # but as the default location of the library. hardcode_minus_L=yes export_dynamic_flag_spec='$wl-E' ;; hpux10*) if test yes,no = "$GCC,$with_gnu_ld"; then archive_cmds='$CC -shared $pic_flag $wl+h $wl$soname $wl+b $wl$install_libdir -o $lib $libobjs $deplibs $compiler_flags' else archive_cmds='$LD -b +h $soname +b $install_libdir -o $lib $libobjs $deplibs $linker_flags' fi if test no = "$with_gnu_ld"; then hardcode_libdir_flag_spec='$wl+b $wl$libdir' hardcode_libdir_separator=: hardcode_direct=yes hardcode_direct_absolute=yes export_dynamic_flag_spec='$wl-E' # hardcode_minus_L: Not really in the search PATH, # but as the default location of the library. hardcode_minus_L=yes fi ;; hpux11*) if test yes,no = "$GCC,$with_gnu_ld"; then case $host_cpu in hppa*64*) archive_cmds='$CC -shared $wl+h $wl$soname -o $lib $libobjs $deplibs $compiler_flags' ;; ia64*) archive_cmds='$CC -shared $pic_flag $wl+h $wl$soname $wl+nodefaultrpath -o $lib $libobjs $deplibs $compiler_flags' ;; *) archive_cmds='$CC -shared $pic_flag $wl+h $wl$soname $wl+b $wl$install_libdir -o $lib $libobjs $deplibs $compiler_flags' ;; esac else case $host_cpu in hppa*64*) archive_cmds='$CC -b $wl+h $wl$soname -o $lib $libobjs $deplibs $compiler_flags' ;; ia64*) archive_cmds='$CC -b $wl+h $wl$soname $wl+nodefaultrpath -o $lib $libobjs $deplibs $compiler_flags' ;; *) # Older versions of the 11.00 compiler do not understand -b yet # (HP92453-01 A.11.01.20 doesn't, HP92453-01 B.11.X.35175-35176.GP does) { $as_echo "$as_me:${as_lineno-$LINENO}: checking if $CC understands -b" >&5 $as_echo_n "checking if $CC understands -b... " >&6; } if ${lt_cv_prog_compiler__b+:} false; then : $as_echo_n "(cached) " >&6 else lt_cv_prog_compiler__b=no save_LDFLAGS=$LDFLAGS LDFLAGS="$LDFLAGS -b" echo "$lt_simple_link_test_code" > conftest.$ac_ext if (eval $ac_link 2>conftest.err) && test -s conftest$ac_exeext; then # The linker can only warn and ignore the option if not recognized # So say no if there are warnings if test -s conftest.err; then # Append any errors to the config.log. cat conftest.err 1>&5 $ECHO "$_lt_linker_boilerplate" | $SED '/^$/d' > conftest.exp $SED '/^$/d; /^ *+/d' conftest.err >conftest.er2 if diff conftest.exp conftest.er2 >/dev/null; then lt_cv_prog_compiler__b=yes fi else lt_cv_prog_compiler__b=yes fi fi $RM -r conftest* LDFLAGS=$save_LDFLAGS fi { $as_echo "$as_me:${as_lineno-$LINENO}: result: $lt_cv_prog_compiler__b" >&5 $as_echo "$lt_cv_prog_compiler__b" >&6; } if test yes = "$lt_cv_prog_compiler__b"; then archive_cmds='$CC -b $wl+h $wl$soname $wl+b $wl$install_libdir -o $lib $libobjs $deplibs $compiler_flags' else archive_cmds='$LD -b +h $soname +b $install_libdir -o $lib $libobjs $deplibs $linker_flags' fi ;; esac fi if test no = "$with_gnu_ld"; then hardcode_libdir_flag_spec='$wl+b $wl$libdir' hardcode_libdir_separator=: case $host_cpu in hppa*64*|ia64*) hardcode_direct=no hardcode_shlibpath_var=no ;; *) hardcode_direct=yes hardcode_direct_absolute=yes export_dynamic_flag_spec='$wl-E' # hardcode_minus_L: Not really in the search PATH, # but as the default location of the library. hardcode_minus_L=yes ;; esac fi ;; irix5* | irix6* | nonstopux*) if test yes = "$GCC"; then archive_cmds='$CC -shared $pic_flag $libobjs $deplibs $compiler_flags $wl-soname $wl$soname `test -n "$verstring" && func_echo_all "$wl-set_version $wl$verstring"` $wl-update_registry $wl$output_objdir/so_locations -o $lib' # Try to use the -exported_symbol ld option, if it does not # work, assume that -exports_file does not work either and # implicitly export all symbols. # This should be the same for all languages, so no per-tag cache variable. { $as_echo "$as_me:${as_lineno-$LINENO}: checking whether the $host_os linker accepts -exported_symbol" >&5 $as_echo_n "checking whether the $host_os linker accepts -exported_symbol... " >&6; } if ${lt_cv_irix_exported_symbol+:} false; then : $as_echo_n "(cached) " >&6 else save_LDFLAGS=$LDFLAGS LDFLAGS="$LDFLAGS -shared $wl-exported_symbol ${wl}foo $wl-update_registry $wl/dev/null" cat confdefs.h - <<_ACEOF >conftest.$ac_ext /* end confdefs.h. */ int foo (void) { return 0; } _ACEOF if ac_fn_c_try_link "$LINENO"; then : lt_cv_irix_exported_symbol=yes else lt_cv_irix_exported_symbol=no fi rm -f core conftest.err conftest.$ac_objext \ conftest$ac_exeext conftest.$ac_ext LDFLAGS=$save_LDFLAGS fi { $as_echo "$as_me:${as_lineno-$LINENO}: result: $lt_cv_irix_exported_symbol" >&5 $as_echo "$lt_cv_irix_exported_symbol" >&6; } if test yes = "$lt_cv_irix_exported_symbol"; then archive_expsym_cmds='$CC -shared $pic_flag $libobjs $deplibs $compiler_flags $wl-soname $wl$soname `test -n "$verstring" && func_echo_all "$wl-set_version $wl$verstring"` $wl-update_registry $wl$output_objdir/so_locations $wl-exports_file $wl$export_symbols -o $lib' fi else archive_cmds='$CC -shared $libobjs $deplibs $compiler_flags -soname $soname `test -n "$verstring" && func_echo_all "-set_version $verstring"` -update_registry $output_objdir/so_locations -o $lib' archive_expsym_cmds='$CC -shared $libobjs $deplibs $compiler_flags -soname $soname `test -n "$verstring" && func_echo_all "-set_version $verstring"` -update_registry $output_objdir/so_locations -exports_file $export_symbols -o $lib' fi archive_cmds_need_lc='no' hardcode_libdir_flag_spec='$wl-rpath $wl$libdir' hardcode_libdir_separator=: inherit_rpath=yes link_all_deplibs=yes ;; linux*) case $cc_basename in tcc*) # Fabrice Bellard et al's Tiny C Compiler ld_shlibs=yes archive_cmds='$CC -shared $pic_flag -o $lib $libobjs $deplibs $compiler_flags' ;; esac ;; netbsd*) if echo __ELF__ | $CC -E - | $GREP __ELF__ >/dev/null; then archive_cmds='$LD -Bshareable -o $lib $libobjs $deplibs $linker_flags' # a.out else archive_cmds='$LD -shared -o $lib $libobjs $deplibs $linker_flags' # ELF fi hardcode_libdir_flag_spec='-R$libdir' hardcode_direct=yes hardcode_shlibpath_var=no ;; newsos6) archive_cmds='$LD -G -h $soname -o $lib $libobjs $deplibs $linker_flags' hardcode_direct=yes hardcode_libdir_flag_spec='$wl-rpath $wl$libdir' hardcode_libdir_separator=: hardcode_shlibpath_var=no ;; *nto* | *qnx*) ;; openbsd* | bitrig*) if test -f /usr/libexec/ld.so; then hardcode_direct=yes hardcode_shlibpath_var=no hardcode_direct_absolute=yes if test -z "`echo __ELF__ | $CC -E - | $GREP __ELF__`"; then archive_cmds='$CC -shared $pic_flag -o $lib $libobjs $deplibs $compiler_flags' archive_expsym_cmds='$CC -shared $pic_flag -o $lib $libobjs $deplibs $compiler_flags $wl-retain-symbols-file,$export_symbols' hardcode_libdir_flag_spec='$wl-rpath,$libdir' export_dynamic_flag_spec='$wl-E' else archive_cmds='$CC -shared $pic_flag -o $lib $libobjs $deplibs $compiler_flags' hardcode_libdir_flag_spec='$wl-rpath,$libdir' fi else ld_shlibs=no fi ;; os2*) hardcode_libdir_flag_spec='-L$libdir' hardcode_minus_L=yes allow_undefined_flag=unsupported shrext_cmds=.dll archive_cmds='$ECHO "LIBRARY ${soname%$shared_ext} INITINSTANCE TERMINSTANCE" > $output_objdir/$libname.def~ $ECHO "DESCRIPTION \"$libname\"" >> $output_objdir/$libname.def~ $ECHO "DATA MULTIPLE NONSHARED" >> $output_objdir/$libname.def~ $ECHO EXPORTS >> $output_objdir/$libname.def~ emxexp $libobjs | $SED /"_DLL_InitTerm"/d >> $output_objdir/$libname.def~ $CC -Zdll -Zcrtdll -o $output_objdir/$soname $libobjs $deplibs $compiler_flags $output_objdir/$libname.def~ emximp -o $lib $output_objdir/$libname.def' archive_expsym_cmds='$ECHO "LIBRARY ${soname%$shared_ext} INITINSTANCE TERMINSTANCE" > $output_objdir/$libname.def~ $ECHO "DESCRIPTION \"$libname\"" >> $output_objdir/$libname.def~ $ECHO "DATA MULTIPLE NONSHARED" >> $output_objdir/$libname.def~ $ECHO EXPORTS >> $output_objdir/$libname.def~ prefix_cmds="$SED"~ if test EXPORTS = "`$SED 1q $export_symbols`"; then prefix_cmds="$prefix_cmds -e 1d"; fi~ prefix_cmds="$prefix_cmds -e \"s/^\(.*\)$/_\1/g\""~ cat $export_symbols | $prefix_cmds >> $output_objdir/$libname.def~ $CC -Zdll -Zcrtdll -o $output_objdir/$soname $libobjs $deplibs $compiler_flags $output_objdir/$libname.def~ emximp -o $lib $output_objdir/$libname.def' old_archive_From_new_cmds='emximp -o $output_objdir/${libname}_dll.a $output_objdir/$libname.def' enable_shared_with_static_runtimes=yes ;; osf3*) if test yes = "$GCC"; then allow_undefined_flag=' $wl-expect_unresolved $wl\*' archive_cmds='$CC -shared$allow_undefined_flag $libobjs $deplibs $compiler_flags $wl-soname $wl$soname `test -n "$verstring" && func_echo_all "$wl-set_version $wl$verstring"` $wl-update_registry $wl$output_objdir/so_locations -o $lib' else allow_undefined_flag=' -expect_unresolved \*' archive_cmds='$CC -shared$allow_undefined_flag $libobjs $deplibs $compiler_flags -soname $soname `test -n "$verstring" && func_echo_all "-set_version $verstring"` -update_registry $output_objdir/so_locations -o $lib' fi archive_cmds_need_lc='no' hardcode_libdir_flag_spec='$wl-rpath $wl$libdir' hardcode_libdir_separator=: ;; osf4* | osf5*) # as osf3* with the addition of -msym flag if test yes = "$GCC"; then allow_undefined_flag=' $wl-expect_unresolved $wl\*' archive_cmds='$CC -shared$allow_undefined_flag $pic_flag $libobjs $deplibs $compiler_flags $wl-msym $wl-soname $wl$soname `test -n "$verstring" && func_echo_all "$wl-set_version $wl$verstring"` $wl-update_registry $wl$output_objdir/so_locations -o $lib' hardcode_libdir_flag_spec='$wl-rpath $wl$libdir' else allow_undefined_flag=' -expect_unresolved \*' archive_cmds='$CC -shared$allow_undefined_flag $libobjs $deplibs $compiler_flags -msym -soname $soname `test -n "$verstring" && func_echo_all "-set_version $verstring"` -update_registry $output_objdir/so_locations -o $lib' archive_expsym_cmds='for i in `cat $export_symbols`; do printf "%s %s\\n" -exported_symbol "\$i" >> $lib.exp; done; printf "%s\\n" "-hidden">> $lib.exp~ $CC -shared$allow_undefined_flag $wl-input $wl$lib.exp $compiler_flags $libobjs $deplibs -soname $soname `test -n "$verstring" && $ECHO "-set_version $verstring"` -update_registry $output_objdir/so_locations -o $lib~$RM $lib.exp' # Both c and cxx compiler support -rpath directly hardcode_libdir_flag_spec='-rpath $libdir' fi archive_cmds_need_lc='no' hardcode_libdir_separator=: ;; solaris*) no_undefined_flag=' -z defs' if test yes = "$GCC"; then wlarc='$wl' archive_cmds='$CC -shared $pic_flag $wl-z ${wl}text $wl-h $wl$soname -o $lib $libobjs $deplibs $compiler_flags' archive_expsym_cmds='echo "{ global:" > $lib.exp~cat $export_symbols | $SED -e "s/\(.*\)/\1;/" >> $lib.exp~echo "local: *; };" >> $lib.exp~ $CC -shared $pic_flag $wl-z ${wl}text $wl-M $wl$lib.exp $wl-h $wl$soname -o $lib $libobjs $deplibs $compiler_flags~$RM $lib.exp' else case `$CC -V 2>&1` in *"Compilers 5.0"*) wlarc='' archive_cmds='$LD -G$allow_undefined_flag -h $soname -o $lib $libobjs $deplibs $linker_flags' archive_expsym_cmds='echo "{ global:" > $lib.exp~cat $export_symbols | $SED -e "s/\(.*\)/\1;/" >> $lib.exp~echo "local: *; };" >> $lib.exp~ $LD -G$allow_undefined_flag -M $lib.exp -h $soname -o $lib $libobjs $deplibs $linker_flags~$RM $lib.exp' ;; *) wlarc='$wl' archive_cmds='$CC -G$allow_undefined_flag -h $soname -o $lib $libobjs $deplibs $compiler_flags' archive_expsym_cmds='echo "{ global:" > $lib.exp~cat $export_symbols | $SED -e "s/\(.*\)/\1;/" >> $lib.exp~echo "local: *; };" >> $lib.exp~ $CC -G$allow_undefined_flag -M $lib.exp -h $soname -o $lib $libobjs $deplibs $compiler_flags~$RM $lib.exp' ;; esac fi hardcode_libdir_flag_spec='-R$libdir' hardcode_shlibpath_var=no case $host_os in solaris2.[0-5] | solaris2.[0-5].*) ;; *) # The compiler driver will combine and reorder linker options, # but understands '-z linker_flag'. GCC discards it without '$wl', # but is careful enough not to reorder. # Supported since Solaris 2.6 (maybe 2.5.1?) if test yes = "$GCC"; then whole_archive_flag_spec='$wl-z ${wl}allextract$convenience $wl-z ${wl}defaultextract' else whole_archive_flag_spec='-z allextract$convenience -z defaultextract' fi ;; esac link_all_deplibs=yes ;; sunos4*) if test sequent = "$host_vendor"; then # Use $CC to link under sequent, because it throws in some extra .o # files that make .init and .fini sections work. archive_cmds='$CC -G $wl-h $soname -o $lib $libobjs $deplibs $compiler_flags' else archive_cmds='$LD -assert pure-text -Bstatic -o $lib $libobjs $deplibs $linker_flags' fi hardcode_libdir_flag_spec='-L$libdir' hardcode_direct=yes hardcode_minus_L=yes hardcode_shlibpath_var=no ;; sysv4) case $host_vendor in sni) archive_cmds='$LD -G -h $soname -o $lib $libobjs $deplibs $linker_flags' hardcode_direct=yes # is this really true??? ;; siemens) ## LD is ld it makes a PLAMLIB ## CC just makes a GrossModule. archive_cmds='$LD -G -o $lib $libobjs $deplibs $linker_flags' reload_cmds='$CC -r -o $output$reload_objs' hardcode_direct=no ;; motorola) archive_cmds='$LD -G -h $soname -o $lib $libobjs $deplibs $linker_flags' hardcode_direct=no #Motorola manual says yes, but my tests say they lie ;; esac runpath_var='LD_RUN_PATH' hardcode_shlibpath_var=no ;; sysv4.3*) archive_cmds='$LD -G -h $soname -o $lib $libobjs $deplibs $linker_flags' hardcode_shlibpath_var=no export_dynamic_flag_spec='-Bexport' ;; sysv4*MP*) if test -d /usr/nec; then archive_cmds='$LD -G -h $soname -o $lib $libobjs $deplibs $linker_flags' hardcode_shlibpath_var=no runpath_var=LD_RUN_PATH hardcode_runpath_var=yes ld_shlibs=yes fi ;; sysv4*uw2* | sysv5OpenUNIX* | sysv5UnixWare7.[01].[10]* | unixware7* | sco3.2v5.0.[024]*) no_undefined_flag='$wl-z,text' archive_cmds_need_lc=no hardcode_shlibpath_var=no runpath_var='LD_RUN_PATH' if test yes = "$GCC"; then archive_cmds='$CC -shared $wl-h,$soname -o $lib $libobjs $deplibs $compiler_flags' archive_expsym_cmds='$CC -shared $wl-Bexport:$export_symbols $wl-h,$soname -o $lib $libobjs $deplibs $compiler_flags' else archive_cmds='$CC -G $wl-h,$soname -o $lib $libobjs $deplibs $compiler_flags' archive_expsym_cmds='$CC -G $wl-Bexport:$export_symbols $wl-h,$soname -o $lib $libobjs $deplibs $compiler_flags' fi ;; sysv5* | sco3.2v5* | sco5v6*) # Note: We CANNOT use -z defs as we might desire, because we do not # link with -lc, and that would cause any symbols used from libc to # always be unresolved, which means just about no library would # ever link correctly. If we're not using GNU ld we use -z text # though, which does catch some bad symbols but isn't as heavy-handed # as -z defs. no_undefined_flag='$wl-z,text' allow_undefined_flag='$wl-z,nodefs' archive_cmds_need_lc=no hardcode_shlibpath_var=no hardcode_libdir_flag_spec='$wl-R,$libdir' hardcode_libdir_separator=':' link_all_deplibs=yes export_dynamic_flag_spec='$wl-Bexport' runpath_var='LD_RUN_PATH' if test yes = "$GCC"; then archive_cmds='$CC -shared $wl-h,$soname -o $lib $libobjs $deplibs $compiler_flags' archive_expsym_cmds='$CC -shared $wl-Bexport:$export_symbols $wl-h,$soname -o $lib $libobjs $deplibs $compiler_flags' else archive_cmds='$CC -G $wl-h,$soname -o $lib $libobjs $deplibs $compiler_flags' archive_expsym_cmds='$CC -G $wl-Bexport:$export_symbols $wl-h,$soname -o $lib $libobjs $deplibs $compiler_flags' fi ;; uts4*) archive_cmds='$LD -G -h $soname -o $lib $libobjs $deplibs $linker_flags' hardcode_libdir_flag_spec='-L$libdir' hardcode_shlibpath_var=no ;; *) ld_shlibs=no ;; esac if test sni = "$host_vendor"; then case $host in sysv4 | sysv4.2uw2* | sysv4.3* | sysv5*) export_dynamic_flag_spec='$wl-Blargedynsym' ;; esac fi fi { $as_echo "$as_me:${as_lineno-$LINENO}: result: $ld_shlibs" >&5 $as_echo "$ld_shlibs" >&6; } test no = "$ld_shlibs" && can_build_shared=no with_gnu_ld=$with_gnu_ld # # Do we need to explicitly link libc? # case "x$archive_cmds_need_lc" in x|xyes) # Assume -lc should be added archive_cmds_need_lc=yes if test yes,yes = "$GCC,$enable_shared"; then case $archive_cmds in *'~'*) # FIXME: we may have to deal with multi-command sequences. ;; '$CC '*) # Test whether the compiler implicitly links with -lc since on some # systems, -lgcc has to come before -lc. If gcc already passes -lc # to ld, don't add -lc before -lgcc. { $as_echo "$as_me:${as_lineno-$LINENO}: checking whether -lc should be explicitly linked in" >&5 $as_echo_n "checking whether -lc should be explicitly linked in... " >&6; } if ${lt_cv_archive_cmds_need_lc+:} false; then : $as_echo_n "(cached) " >&6 else $RM conftest* echo "$lt_simple_compile_test_code" > conftest.$ac_ext if { { eval echo "\"\$as_me\":${as_lineno-$LINENO}: \"$ac_compile\""; } >&5 (eval $ac_compile) 2>&5 ac_status=$? $as_echo "$as_me:${as_lineno-$LINENO}: \$? = $ac_status" >&5 test $ac_status = 0; } 2>conftest.err; then soname=conftest lib=conftest libobjs=conftest.$ac_objext deplibs= wl=$lt_prog_compiler_wl pic_flag=$lt_prog_compiler_pic compiler_flags=-v linker_flags=-v verstring= output_objdir=. libname=conftest lt_save_allow_undefined_flag=$allow_undefined_flag allow_undefined_flag= if { { eval echo "\"\$as_me\":${as_lineno-$LINENO}: \"$archive_cmds 2\>\&1 \| $GREP \" -lc \" \>/dev/null 2\>\&1\""; } >&5 (eval $archive_cmds 2\>\&1 \| $GREP \" -lc \" \>/dev/null 2\>\&1) 2>&5 ac_status=$? $as_echo "$as_me:${as_lineno-$LINENO}: \$? = $ac_status" >&5 test $ac_status = 0; } then lt_cv_archive_cmds_need_lc=no else lt_cv_archive_cmds_need_lc=yes fi allow_undefined_flag=$lt_save_allow_undefined_flag else cat conftest.err 1>&5 fi $RM conftest* fi { $as_echo "$as_me:${as_lineno-$LINENO}: result: $lt_cv_archive_cmds_need_lc" >&5 $as_echo "$lt_cv_archive_cmds_need_lc" >&6; } archive_cmds_need_lc=$lt_cv_archive_cmds_need_lc ;; esac fi ;; esac { $as_echo "$as_me:${as_lineno-$LINENO}: checking dynamic linker characteristics" >&5 $as_echo_n "checking dynamic linker characteristics... " >&6; } if test yes = "$GCC"; then case $host_os in darwin*) lt_awk_arg='/^libraries:/,/LR/' ;; *) lt_awk_arg='/^libraries:/' ;; esac case $host_os in mingw* | cegcc*) lt_sed_strip_eq='s|=\([A-Za-z]:\)|\1|g' ;; *) lt_sed_strip_eq='s|=/|/|g' ;; esac lt_search_path_spec=`$CC -print-search-dirs | awk $lt_awk_arg | $SED -e "s/^libraries://" -e $lt_sed_strip_eq` case $lt_search_path_spec in *\;*) # if the path contains ";" then we assume it to be the separator # otherwise default to the standard path separator (i.e. ":") - it is # assumed that no part of a normal pathname contains ";" but that should # okay in the real world where ";" in dirpaths is itself problematic. lt_search_path_spec=`$ECHO "$lt_search_path_spec" | $SED 's/;/ /g'` ;; *) lt_search_path_spec=`$ECHO "$lt_search_path_spec" | $SED "s/$PATH_SEPARATOR/ /g"` ;; esac # Ok, now we have the path, separated by spaces, we can step through it # and add multilib dir if necessary... lt_tmp_lt_search_path_spec= lt_multi_os_dir=/`$CC $CPPFLAGS $CFLAGS $LDFLAGS -print-multi-os-directory 2>/dev/null` # ...but if some path component already ends with the multilib dir we assume # that all is fine and trust -print-search-dirs as is (GCC 4.2? or newer). case "$lt_multi_os_dir; $lt_search_path_spec " in "/; "* | "/.; "* | "/./; "* | *"$lt_multi_os_dir "* | *"$lt_multi_os_dir/ "*) lt_multi_os_dir= ;; esac for lt_sys_path in $lt_search_path_spec; do if test -d "$lt_sys_path$lt_multi_os_dir"; then lt_tmp_lt_search_path_spec="$lt_tmp_lt_search_path_spec $lt_sys_path$lt_multi_os_dir" elif test -n "$lt_multi_os_dir"; then test -d "$lt_sys_path" && \ lt_tmp_lt_search_path_spec="$lt_tmp_lt_search_path_spec $lt_sys_path" fi done lt_search_path_spec=`$ECHO "$lt_tmp_lt_search_path_spec" | awk ' BEGIN {RS = " "; FS = "/|\n";} { lt_foo = ""; lt_count = 0; for (lt_i = NF; lt_i > 0; lt_i--) { if ($lt_i != "" && $lt_i != ".") { if ($lt_i == "..") { lt_count++; } else { if (lt_count == 0) { lt_foo = "/" $lt_i lt_foo; } else { lt_count--; } } } } if (lt_foo != "") { lt_freq[lt_foo]++; } if (lt_freq[lt_foo] == 1) { print lt_foo; } }'` # AWK program above erroneously prepends '/' to C:/dos/paths # for these hosts. case $host_os in mingw* | cegcc*) lt_search_path_spec=`$ECHO "$lt_search_path_spec" |\ $SED 's|/\([A-Za-z]:\)|\1|g'` ;; esac sys_lib_search_path_spec=`$ECHO "$lt_search_path_spec" | $lt_NL2SP` else sys_lib_search_path_spec="/lib /usr/lib /usr/local/lib" fi library_names_spec= libname_spec='lib$name' soname_spec= shrext_cmds=.so postinstall_cmds= postuninstall_cmds= finish_cmds= finish_eval= shlibpath_var= shlibpath_overrides_runpath=unknown version_type=none dynamic_linker="$host_os ld.so" sys_lib_dlsearch_path_spec="/lib /usr/lib" need_lib_prefix=unknown hardcode_into_libs=no # when you set need_version to no, make sure it does not cause -set_version # flags to be left without arguments need_version=unknown case $host_os in aix3*) version_type=linux # correct to gnu/linux during the next big refactor library_names_spec='$libname$release$shared_ext$versuffix $libname.a' shlibpath_var=LIBPATH # AIX 3 has no versioning support, so we append a major version to the name. soname_spec='$libname$release$shared_ext$major' ;; aix[4-9]*) version_type=linux # correct to gnu/linux during the next big refactor need_lib_prefix=no need_version=no hardcode_into_libs=yes if test ia64 = "$host_cpu"; then # AIX 5 supports IA64 library_names_spec='$libname$release$shared_ext$major $libname$release$shared_ext$versuffix $libname$shared_ext' shlibpath_var=LD_LIBRARY_PATH else # With GCC up to 2.95.x, collect2 would create an import file # for dependence libraries. The import file would start with # the line '#! .'. This would cause the generated library to # depend on '.', always an invalid library. This was fixed in # development snapshots of GCC prior to 3.0. case $host_os in aix4 | aix4.[01] | aix4.[01].*) if { echo '#if __GNUC__ > 2 || (__GNUC__ == 2 && __GNUC_MINOR__ >= 97)' echo ' yes ' echo '#endif'; } | $CC -E - | $GREP yes > /dev/null; then : else can_build_shared=no fi ;; esac # Using Import Files as archive members, it is possible to support # filename-based versioning of shared library archives on AIX. While # this would work for both with and without runtime linking, it will # prevent static linking of such archives. So we do filename-based # shared library versioning with .so extension only, which is used # when both runtime linking and shared linking is enabled. # Unfortunately, runtime linking may impact performance, so we do # not want this to be the default eventually. Also, we use the # versioned .so libs for executables only if there is the -brtl # linker flag in LDFLAGS as well, or --with-aix-soname=svr4 only. # To allow for filename-based versioning support, we need to create # libNAME.so.V as an archive file, containing: # *) an Import File, referring to the versioned filename of the # archive as well as the shared archive member, telling the # bitwidth (32 or 64) of that shared object, and providing the # list of exported symbols of that shared object, eventually # decorated with the 'weak' keyword # *) the shared object with the F_LOADONLY flag set, to really avoid # it being seen by the linker. # At run time we better use the real file rather than another symlink, # but for link time we create the symlink libNAME.so -> libNAME.so.V case $with_aix_soname,$aix_use_runtimelinking in # AIX (on Power*) has no versioning support, so currently we cannot hardcode correct # soname into executable. Probably we can add versioning support to # collect2, so additional links can be useful in future. aix,yes) # traditional libtool dynamic_linker='AIX unversionable lib.so' # If using run time linking (on AIX 4.2 or later) use lib.so # instead of lib.a to let people know that these are not # typical AIX shared libraries. library_names_spec='$libname$release$shared_ext$versuffix $libname$release$shared_ext$major $libname$shared_ext' ;; aix,no) # traditional AIX only dynamic_linker='AIX lib.a(lib.so.V)' # We preserve .a as extension for shared libraries through AIX4.2 # and later when we are not doing run time linking. library_names_spec='$libname$release.a $libname.a' soname_spec='$libname$release$shared_ext$major' ;; svr4,*) # full svr4 only dynamic_linker="AIX lib.so.V($shared_archive_member_spec.o)" library_names_spec='$libname$release$shared_ext$major $libname$shared_ext' # We do not specify a path in Import Files, so LIBPATH fires. shlibpath_overrides_runpath=yes ;; *,yes) # both, prefer svr4 dynamic_linker="AIX lib.so.V($shared_archive_member_spec.o), lib.a(lib.so.V)" library_names_spec='$libname$release$shared_ext$major $libname$shared_ext' # unpreferred sharedlib libNAME.a needs extra handling postinstall_cmds='test -n "$linkname" || linkname="$realname"~func_stripname "" ".so" "$linkname"~$install_shared_prog "$dir/$func_stripname_result.$libext" "$destdir/$func_stripname_result.$libext"~test -z "$tstripme" || test -z "$striplib" || $striplib "$destdir/$func_stripname_result.$libext"' postuninstall_cmds='for n in $library_names $old_library; do :; done~func_stripname "" ".so" "$n"~test "$func_stripname_result" = "$n" || func_append rmfiles " $odir/$func_stripname_result.$libext"' # We do not specify a path in Import Files, so LIBPATH fires. shlibpath_overrides_runpath=yes ;; *,no) # both, prefer aix dynamic_linker="AIX lib.a(lib.so.V), lib.so.V($shared_archive_member_spec.o)" library_names_spec='$libname$release.a $libname.a' soname_spec='$libname$release$shared_ext$major' # unpreferred sharedlib libNAME.so.V and symlink libNAME.so need extra handling postinstall_cmds='test -z "$dlname" || $install_shared_prog $dir/$dlname $destdir/$dlname~test -z "$tstripme" || test -z "$striplib" || $striplib $destdir/$dlname~test -n "$linkname" || linkname=$realname~func_stripname "" ".a" "$linkname"~(cd "$destdir" && $LN_S -f $dlname $func_stripname_result.so)' postuninstall_cmds='test -z "$dlname" || func_append rmfiles " $odir/$dlname"~for n in $old_library $library_names; do :; done~func_stripname "" ".a" "$n"~func_append rmfiles " $odir/$func_stripname_result.so"' ;; esac shlibpath_var=LIBPATH fi ;; amigaos*) case $host_cpu in powerpc) # Since July 2007 AmigaOS4 officially supports .so libraries. # When compiling the executable, add -use-dynld -Lsobjs: to the compileline. library_names_spec='$libname$release$shared_ext$versuffix $libname$release$shared_ext$major $libname$shared_ext' ;; m68k) library_names_spec='$libname.ixlibrary $libname.a' # Create ${libname}_ixlibrary.a entries in /sys/libs. finish_eval='for lib in `ls $libdir/*.ixlibrary 2>/dev/null`; do libname=`func_echo_all "$lib" | $SED '\''s%^.*/\([^/]*\)\.ixlibrary$%\1%'\''`; $RM /sys/libs/${libname}_ixlibrary.a; $show "cd /sys/libs && $LN_S $lib ${libname}_ixlibrary.a"; cd /sys/libs && $LN_S $lib ${libname}_ixlibrary.a || exit 1; done' ;; esac ;; beos*) library_names_spec='$libname$shared_ext' dynamic_linker="$host_os ld.so" shlibpath_var=LIBRARY_PATH ;; bsdi[45]*) version_type=linux # correct to gnu/linux during the next big refactor need_version=no library_names_spec='$libname$release$shared_ext$versuffix $libname$release$shared_ext$major $libname$shared_ext' soname_spec='$libname$release$shared_ext$major' finish_cmds='PATH="\$PATH:/sbin" ldconfig $libdir' shlibpath_var=LD_LIBRARY_PATH sys_lib_search_path_spec="/shlib /usr/lib /usr/X11/lib /usr/contrib/lib /lib /usr/local/lib" sys_lib_dlsearch_path_spec="/shlib /usr/lib /usr/local/lib" # the default ld.so.conf also contains /usr/contrib/lib and # /usr/X11R6/lib (/usr/X11 is a link to /usr/X11R6), but let us allow # libtool to hard-code these into programs ;; cygwin* | mingw* | pw32* | cegcc*) version_type=windows shrext_cmds=.dll need_version=no need_lib_prefix=no case $GCC,$cc_basename in yes,*) # gcc library_names_spec='$libname.dll.a' # DLL is installed to $(libdir)/../bin by postinstall_cmds postinstall_cmds='base_file=`basename \$file`~ dlpath=`$SHELL 2>&1 -c '\''. $dir/'\''\$base_file'\''i; echo \$dlname'\''`~ dldir=$destdir/`dirname \$dlpath`~ test -d \$dldir || mkdir -p \$dldir~ $install_prog $dir/$dlname \$dldir/$dlname~ chmod a+x \$dldir/$dlname~ if test -n '\''$stripme'\'' && test -n '\''$striplib'\''; then eval '\''$striplib \$dldir/$dlname'\'' || exit \$?; fi' postuninstall_cmds='dldll=`$SHELL 2>&1 -c '\''. $file; echo \$dlname'\''`~ dlpath=$dir/\$dldll~ $RM \$dlpath' shlibpath_overrides_runpath=yes case $host_os in cygwin*) # Cygwin DLLs use 'cyg' prefix rather than 'lib' soname_spec='`echo $libname | sed -e 's/^lib/cyg/'``echo $release | $SED -e 's/[.]/-/g'`$versuffix$shared_ext' sys_lib_search_path_spec="$sys_lib_search_path_spec /usr/lib/w32api" ;; mingw* | cegcc*) # MinGW DLLs use traditional 'lib' prefix soname_spec='$libname`echo $release | $SED -e 's/[.]/-/g'`$versuffix$shared_ext' ;; pw32*) # pw32 DLLs use 'pw' prefix rather than 'lib' library_names_spec='`echo $libname | sed -e 's/^lib/pw/'``echo $release | $SED -e 's/[.]/-/g'`$versuffix$shared_ext' ;; esac dynamic_linker='Win32 ld.exe' ;; *,cl*) # Native MSVC libname_spec='$name' soname_spec='$libname`echo $release | $SED -e 's/[.]/-/g'`$versuffix$shared_ext' library_names_spec='$libname.dll.lib' case $build_os in mingw*) sys_lib_search_path_spec= lt_save_ifs=$IFS IFS=';' for lt_path in $LIB do IFS=$lt_save_ifs # Let DOS variable expansion print the short 8.3 style file name. lt_path=`cd "$lt_path" 2>/dev/null && cmd //C "for %i in (".") do @echo %~si"` sys_lib_search_path_spec="$sys_lib_search_path_spec $lt_path" done IFS=$lt_save_ifs # Convert to MSYS style. sys_lib_search_path_spec=`$ECHO "$sys_lib_search_path_spec" | sed -e 's|\\\\|/|g' -e 's| \\([a-zA-Z]\\):| /\\1|g' -e 's|^ ||'` ;; cygwin*) # Convert to unix form, then to dos form, then back to unix form # but this time dos style (no spaces!) so that the unix form looks # like /cygdrive/c/PROGRA~1:/cygdr... sys_lib_search_path_spec=`cygpath --path --unix "$LIB"` sys_lib_search_path_spec=`cygpath --path --dos "$sys_lib_search_path_spec" 2>/dev/null` sys_lib_search_path_spec=`cygpath --path --unix "$sys_lib_search_path_spec" | $SED -e "s/$PATH_SEPARATOR/ /g"` ;; *) sys_lib_search_path_spec=$LIB if $ECHO "$sys_lib_search_path_spec" | $GREP ';[c-zC-Z]:/' >/dev/null; then # It is most probably a Windows format PATH. sys_lib_search_path_spec=`$ECHO "$sys_lib_search_path_spec" | $SED -e 's/;/ /g'` else sys_lib_search_path_spec=`$ECHO "$sys_lib_search_path_spec" | $SED -e "s/$PATH_SEPARATOR/ /g"` fi # FIXME: find the short name or the path components, as spaces are # common. (e.g. "Program Files" -> "PROGRA~1") ;; esac # DLL is installed to $(libdir)/../bin by postinstall_cmds postinstall_cmds='base_file=`basename \$file`~ dlpath=`$SHELL 2>&1 -c '\''. $dir/'\''\$base_file'\''i; echo \$dlname'\''`~ dldir=$destdir/`dirname \$dlpath`~ test -d \$dldir || mkdir -p \$dldir~ $install_prog $dir/$dlname \$dldir/$dlname' postuninstall_cmds='dldll=`$SHELL 2>&1 -c '\''. $file; echo \$dlname'\''`~ dlpath=$dir/\$dldll~ $RM \$dlpath' shlibpath_overrides_runpath=yes dynamic_linker='Win32 link.exe' ;; *) # Assume MSVC wrapper library_names_spec='$libname`echo $release | $SED -e 's/[.]/-/g'`$versuffix$shared_ext $libname.lib' dynamic_linker='Win32 ld.exe' ;; esac # FIXME: first we should search . and the directory the executable is in shlibpath_var=PATH ;; darwin* | rhapsody*) dynamic_linker="$host_os dyld" version_type=darwin need_lib_prefix=no need_version=no library_names_spec='$libname$release$major$shared_ext $libname$shared_ext' soname_spec='$libname$release$major$shared_ext' shlibpath_overrides_runpath=yes shlibpath_var=DYLD_LIBRARY_PATH shrext_cmds='`test .$module = .yes && echo .so || echo .dylib`' sys_lib_search_path_spec="$sys_lib_search_path_spec /usr/local/lib" sys_lib_dlsearch_path_spec='/usr/local/lib /lib /usr/lib' ;; dgux*) version_type=linux # correct to gnu/linux during the next big refactor need_lib_prefix=no need_version=no library_names_spec='$libname$release$shared_ext$versuffix $libname$release$shared_ext$major $libname$shared_ext' soname_spec='$libname$release$shared_ext$major' shlibpath_var=LD_LIBRARY_PATH ;; freebsd* | dragonfly*) # DragonFly does not have aout. When/if they implement a new # versioning mechanism, adjust this. if test -x /usr/bin/objformat; then objformat=`/usr/bin/objformat` else case $host_os in freebsd[23].*) objformat=aout ;; *) objformat=elf ;; esac fi version_type=freebsd-$objformat case $version_type in freebsd-elf*) library_names_spec='$libname$release$shared_ext$versuffix $libname$release$shared_ext$major $libname$shared_ext' soname_spec='$libname$release$shared_ext$major' need_version=no need_lib_prefix=no ;; freebsd-*) library_names_spec='$libname$release$shared_ext$versuffix $libname$shared_ext$versuffix' need_version=yes ;; esac shlibpath_var=LD_LIBRARY_PATH case $host_os in freebsd2.*) shlibpath_overrides_runpath=yes ;; freebsd3.[01]* | freebsdelf3.[01]*) shlibpath_overrides_runpath=yes hardcode_into_libs=yes ;; freebsd3.[2-9]* | freebsdelf3.[2-9]* | \ freebsd4.[0-5] | freebsdelf4.[0-5] | freebsd4.1.1 | freebsdelf4.1.1) shlibpath_overrides_runpath=no hardcode_into_libs=yes ;; *) # from 4.6 on, and DragonFly shlibpath_overrides_runpath=yes hardcode_into_libs=yes ;; esac ;; haiku*) version_type=linux # correct to gnu/linux during the next big refactor need_lib_prefix=no need_version=no dynamic_linker="$host_os runtime_loader" library_names_spec='$libname$release$shared_ext$versuffix $libname$release$shared_ext$major $libname$shared_ext' soname_spec='$libname$release$shared_ext$major' shlibpath_var=LIBRARY_PATH shlibpath_overrides_runpath=no sys_lib_dlsearch_path_spec='/boot/home/config/lib /boot/common/lib /boot/system/lib' hardcode_into_libs=yes ;; hpux9* | hpux10* | hpux11*) # Give a soname corresponding to the major version so that dld.sl refuses to # link against other versions. version_type=sunos need_lib_prefix=no need_version=no case $host_cpu in ia64*) shrext_cmds='.so' hardcode_into_libs=yes dynamic_linker="$host_os dld.so" shlibpath_var=LD_LIBRARY_PATH shlibpath_overrides_runpath=yes # Unless +noenvvar is specified. library_names_spec='$libname$release$shared_ext$versuffix $libname$release$shared_ext$major $libname$shared_ext' soname_spec='$libname$release$shared_ext$major' if test 32 = "$HPUX_IA64_MODE"; then sys_lib_search_path_spec="/usr/lib/hpux32 /usr/local/lib/hpux32 /usr/local/lib" sys_lib_dlsearch_path_spec=/usr/lib/hpux32 else sys_lib_search_path_spec="/usr/lib/hpux64 /usr/local/lib/hpux64" sys_lib_dlsearch_path_spec=/usr/lib/hpux64 fi ;; hppa*64*) shrext_cmds='.sl' hardcode_into_libs=yes dynamic_linker="$host_os dld.sl" shlibpath_var=LD_LIBRARY_PATH # How should we handle SHLIB_PATH shlibpath_overrides_runpath=yes # Unless +noenvvar is specified. library_names_spec='$libname$release$shared_ext$versuffix $libname$release$shared_ext$major $libname$shared_ext' soname_spec='$libname$release$shared_ext$major' sys_lib_search_path_spec="/usr/lib/pa20_64 /usr/ccs/lib/pa20_64" sys_lib_dlsearch_path_spec=$sys_lib_search_path_spec ;; *) shrext_cmds='.sl' dynamic_linker="$host_os dld.sl" shlibpath_var=SHLIB_PATH shlibpath_overrides_runpath=no # +s is required to enable SHLIB_PATH library_names_spec='$libname$release$shared_ext$versuffix $libname$release$shared_ext$major $libname$shared_ext' soname_spec='$libname$release$shared_ext$major' ;; esac # HP-UX runs *really* slowly unless shared libraries are mode 555, ... postinstall_cmds='chmod 555 $lib' # or fails outright, so override atomically: install_override_mode=555 ;; interix[3-9]*) version_type=linux # correct to gnu/linux during the next big refactor need_lib_prefix=no need_version=no library_names_spec='$libname$release$shared_ext$versuffix $libname$release$shared_ext$major $libname$shared_ext' soname_spec='$libname$release$shared_ext$major' dynamic_linker='Interix 3.x ld.so.1 (PE, like ELF)' shlibpath_var=LD_LIBRARY_PATH shlibpath_overrides_runpath=no hardcode_into_libs=yes ;; irix5* | irix6* | nonstopux*) case $host_os in nonstopux*) version_type=nonstopux ;; *) if test yes = "$lt_cv_prog_gnu_ld"; then version_type=linux # correct to gnu/linux during the next big refactor else version_type=irix fi ;; esac need_lib_prefix=no need_version=no soname_spec='$libname$release$shared_ext$major' library_names_spec='$libname$release$shared_ext$versuffix $libname$release$shared_ext$major $libname$release$shared_ext $libname$shared_ext' case $host_os in irix5* | nonstopux*) libsuff= shlibsuff= ;; *) case $LD in # libtool.m4 will add one of these switches to LD *-32|*"-32 "|*-melf32bsmip|*"-melf32bsmip ") libsuff= shlibsuff= libmagic=32-bit;; *-n32|*"-n32 "|*-melf32bmipn32|*"-melf32bmipn32 ") libsuff=32 shlibsuff=N32 libmagic=N32;; *-64|*"-64 "|*-melf64bmip|*"-melf64bmip ") libsuff=64 shlibsuff=64 libmagic=64-bit;; *) libsuff= shlibsuff= libmagic=never-match;; esac ;; esac shlibpath_var=LD_LIBRARY${shlibsuff}_PATH shlibpath_overrides_runpath=no sys_lib_search_path_spec="/usr/lib$libsuff /lib$libsuff /usr/local/lib$libsuff" sys_lib_dlsearch_path_spec="/usr/lib$libsuff /lib$libsuff" hardcode_into_libs=yes ;; # No shared lib support for Linux oldld, aout, or coff. linux*oldld* | linux*aout* | linux*coff*) dynamic_linker=no ;; linux*android*) version_type=none # Android doesn't support versioned libraries. need_lib_prefix=no need_version=no library_names_spec='$libname$release$shared_ext' soname_spec='$libname$release$shared_ext' finish_cmds= shlibpath_var=LD_LIBRARY_PATH shlibpath_overrides_runpath=yes # This implies no fast_install, which is unacceptable. # Some rework will be needed to allow for fast_install # before this can be enabled. hardcode_into_libs=yes dynamic_linker='Android linker' # Don't embed -rpath directories since the linker doesn't support them. hardcode_libdir_flag_spec='-L$libdir' ;; # This must be glibc/ELF. linux* | k*bsd*-gnu | kopensolaris*-gnu | gnu*) version_type=linux # correct to gnu/linux during the next big refactor need_lib_prefix=no need_version=no library_names_spec='$libname$release$shared_ext$versuffix $libname$release$shared_ext$major $libname$shared_ext' soname_spec='$libname$release$shared_ext$major' finish_cmds='PATH="\$PATH:/sbin" ldconfig -n $libdir' shlibpath_var=LD_LIBRARY_PATH shlibpath_overrides_runpath=no # Some binutils ld are patched to set DT_RUNPATH if ${lt_cv_shlibpath_overrides_runpath+:} false; then : $as_echo_n "(cached) " >&6 else lt_cv_shlibpath_overrides_runpath=no save_LDFLAGS=$LDFLAGS save_libdir=$libdir eval "libdir=/foo; wl=\"$lt_prog_compiler_wl\"; \ LDFLAGS=\"\$LDFLAGS $hardcode_libdir_flag_spec\"" cat confdefs.h - <<_ACEOF >conftest.$ac_ext /* end confdefs.h. */ int main () { ; return 0; } _ACEOF if ac_fn_c_try_link "$LINENO"; then : if ($OBJDUMP -p conftest$ac_exeext) 2>/dev/null | grep "RUNPATH.*$libdir" >/dev/null; then : lt_cv_shlibpath_overrides_runpath=yes fi fi rm -f core conftest.err conftest.$ac_objext \ conftest$ac_exeext conftest.$ac_ext LDFLAGS=$save_LDFLAGS libdir=$save_libdir fi shlibpath_overrides_runpath=$lt_cv_shlibpath_overrides_runpath # This implies no fast_install, which is unacceptable. # Some rework will be needed to allow for fast_install # before this can be enabled. hardcode_into_libs=yes # Ideally, we could use ldconfig to report *all* directores which are # searched for libraries, however this is still not possible. Aside from not # being certain /sbin/ldconfig is available, command # 'ldconfig -N -X -v | grep ^/' on 64bit Fedora does not report /usr/lib64, # even though it is searched at run-time. Try to do the best guess by # appending ld.so.conf contents (and includes) to the search path. if test -f /etc/ld.so.conf; then lt_ld_extra=`awk '/^include / { system(sprintf("cd /etc; cat %s 2>/dev/null", \$2)); skip = 1; } { if (!skip) print \$0; skip = 0; }' < /etc/ld.so.conf | $SED -e 's/#.*//;/^[ ]*hwcap[ ]/d;s/[:, ]/ /g;s/=[^=]*$//;s/=[^= ]* / /g;s/"//g;/^$/d' | tr '\n' ' '` sys_lib_dlsearch_path_spec="/lib /usr/lib $lt_ld_extra" fi # We used to test for /lib/ld.so.1 and disable shared libraries on # powerpc, because MkLinux only supported shared libraries with the # GNU dynamic linker. Since this was broken with cross compilers, # most powerpc-linux boxes support dynamic linking these days and # people can always --disable-shared, the test was removed, and we # assume the GNU/Linux dynamic linker is in use. dynamic_linker='GNU/Linux ld.so' ;; netbsd*) version_type=sunos need_lib_prefix=no need_version=no if echo __ELF__ | $CC -E - | $GREP __ELF__ >/dev/null; then library_names_spec='$libname$release$shared_ext$versuffix $libname$shared_ext$versuffix' finish_cmds='PATH="\$PATH:/sbin" ldconfig -m $libdir' dynamic_linker='NetBSD (a.out) ld.so' else library_names_spec='$libname$release$shared_ext$versuffix $libname$release$shared_ext$major $libname$shared_ext' soname_spec='$libname$release$shared_ext$major' dynamic_linker='NetBSD ld.elf_so' fi shlibpath_var=LD_LIBRARY_PATH shlibpath_overrides_runpath=yes hardcode_into_libs=yes ;; newsos6) version_type=linux # correct to gnu/linux during the next big refactor library_names_spec='$libname$release$shared_ext$versuffix $libname$release$shared_ext$major $libname$shared_ext' shlibpath_var=LD_LIBRARY_PATH shlibpath_overrides_runpath=yes ;; *nto* | *qnx*) version_type=qnx need_lib_prefix=no need_version=no library_names_spec='$libname$release$shared_ext$versuffix $libname$release$shared_ext$major $libname$shared_ext' soname_spec='$libname$release$shared_ext$major' shlibpath_var=LD_LIBRARY_PATH shlibpath_overrides_runpath=no hardcode_into_libs=yes dynamic_linker='ldqnx.so' ;; openbsd* | bitrig*) version_type=sunos sys_lib_dlsearch_path_spec=/usr/lib need_lib_prefix=no if test -z "`echo __ELF__ | $CC -E - | $GREP __ELF__`"; then need_version=no else need_version=yes fi library_names_spec='$libname$release$shared_ext$versuffix $libname$shared_ext$versuffix' finish_cmds='PATH="\$PATH:/sbin" ldconfig -m $libdir' shlibpath_var=LD_LIBRARY_PATH shlibpath_overrides_runpath=yes ;; os2*) libname_spec='$name' version_type=windows shrext_cmds=.dll need_version=no need_lib_prefix=no # OS/2 can only load a DLL with a base name of 8 characters or less. soname_spec='`test -n "$os2dllname" && libname="$os2dllname"; v=$($ECHO $release$versuffix | tr -d .-); n=$($ECHO $libname | cut -b -$((8 - ${#v})) | tr . _); $ECHO $n$v`$shared_ext' library_names_spec='${libname}_dll.$libext' dynamic_linker='OS/2 ld.exe' shlibpath_var=BEGINLIBPATH sys_lib_search_path_spec="/lib /usr/lib /usr/local/lib" sys_lib_dlsearch_path_spec=$sys_lib_search_path_spec postinstall_cmds='base_file=`basename \$file`~ dlpath=`$SHELL 2>&1 -c '\''. $dir/'\''\$base_file'\''i; $ECHO \$dlname'\''`~ dldir=$destdir/`dirname \$dlpath`~ test -d \$dldir || mkdir -p \$dldir~ $install_prog $dir/$dlname \$dldir/$dlname~ chmod a+x \$dldir/$dlname~ if test -n '\''$stripme'\'' && test -n '\''$striplib'\''; then eval '\''$striplib \$dldir/$dlname'\'' || exit \$?; fi' postuninstall_cmds='dldll=`$SHELL 2>&1 -c '\''. $file; $ECHO \$dlname'\''`~ dlpath=$dir/\$dldll~ $RM \$dlpath' ;; osf3* | osf4* | osf5*) version_type=osf need_lib_prefix=no need_version=no soname_spec='$libname$release$shared_ext$major' library_names_spec='$libname$release$shared_ext$versuffix $libname$release$shared_ext$major $libname$shared_ext' shlibpath_var=LD_LIBRARY_PATH sys_lib_search_path_spec="/usr/shlib /usr/ccs/lib /usr/lib/cmplrs/cc /usr/lib /usr/local/lib /var/shlib" sys_lib_dlsearch_path_spec=$sys_lib_search_path_spec ;; rdos*) dynamic_linker=no ;; solaris*) version_type=linux # correct to gnu/linux during the next big refactor need_lib_prefix=no need_version=no library_names_spec='$libname$release$shared_ext$versuffix $libname$release$shared_ext$major $libname$shared_ext' soname_spec='$libname$release$shared_ext$major' shlibpath_var=LD_LIBRARY_PATH shlibpath_overrides_runpath=yes hardcode_into_libs=yes # ldd complains unless libraries are executable postinstall_cmds='chmod +x $lib' ;; sunos4*) version_type=sunos library_names_spec='$libname$release$shared_ext$versuffix $libname$shared_ext$versuffix' finish_cmds='PATH="\$PATH:/usr/etc" ldconfig $libdir' shlibpath_var=LD_LIBRARY_PATH shlibpath_overrides_runpath=yes if test yes = "$with_gnu_ld"; then need_lib_prefix=no fi need_version=yes ;; sysv4 | sysv4.3*) version_type=linux # correct to gnu/linux during the next big refactor library_names_spec='$libname$release$shared_ext$versuffix $libname$release$shared_ext$major $libname$shared_ext' soname_spec='$libname$release$shared_ext$major' shlibpath_var=LD_LIBRARY_PATH case $host_vendor in sni) shlibpath_overrides_runpath=no need_lib_prefix=no runpath_var=LD_RUN_PATH ;; siemens) need_lib_prefix=no ;; motorola) need_lib_prefix=no need_version=no shlibpath_overrides_runpath=no sys_lib_search_path_spec='/lib /usr/lib /usr/ccs/lib' ;; esac ;; sysv4*MP*) if test -d /usr/nec; then version_type=linux # correct to gnu/linux during the next big refactor library_names_spec='$libname$shared_ext.$versuffix $libname$shared_ext.$major $libname$shared_ext' soname_spec='$libname$shared_ext.$major' shlibpath_var=LD_LIBRARY_PATH fi ;; sysv5* | sco3.2v5* | sco5v6* | unixware* | OpenUNIX* | sysv4*uw2*) version_type=sco need_lib_prefix=no need_version=no library_names_spec='$libname$release$shared_ext$versuffix $libname$release$shared_ext $libname$shared_ext' soname_spec='$libname$release$shared_ext$major' shlibpath_var=LD_LIBRARY_PATH shlibpath_overrides_runpath=yes hardcode_into_libs=yes if test yes = "$with_gnu_ld"; then sys_lib_search_path_spec='/usr/local/lib /usr/gnu/lib /usr/ccs/lib /usr/lib /lib' else sys_lib_search_path_spec='/usr/ccs/lib /usr/lib' case $host_os in sco3.2v5*) sys_lib_search_path_spec="$sys_lib_search_path_spec /lib" ;; esac fi sys_lib_dlsearch_path_spec='/usr/lib' ;; tpf*) # TPF is a cross-target only. Preferred cross-host = GNU/Linux. version_type=linux # correct to gnu/linux during the next big refactor need_lib_prefix=no need_version=no library_names_spec='$libname$release$shared_ext$versuffix $libname$release$shared_ext$major $libname$shared_ext' shlibpath_var=LD_LIBRARY_PATH shlibpath_overrides_runpath=no hardcode_into_libs=yes ;; uts4*) version_type=linux # correct to gnu/linux during the next big refactor library_names_spec='$libname$release$shared_ext$versuffix $libname$release$shared_ext$major $libname$shared_ext' soname_spec='$libname$release$shared_ext$major' shlibpath_var=LD_LIBRARY_PATH ;; *) dynamic_linker=no ;; esac { $as_echo "$as_me:${as_lineno-$LINENO}: result: $dynamic_linker" >&5 $as_echo "$dynamic_linker" >&6; } test no = "$dynamic_linker" && can_build_shared=no variables_saved_for_relink="PATH $shlibpath_var $runpath_var" if test yes = "$GCC"; then variables_saved_for_relink="$variables_saved_for_relink GCC_EXEC_PREFIX COMPILER_PATH LIBRARY_PATH" fi if test set = "${lt_cv_sys_lib_search_path_spec+set}"; then sys_lib_search_path_spec=$lt_cv_sys_lib_search_path_spec fi if test set = "${lt_cv_sys_lib_dlsearch_path_spec+set}"; then sys_lib_dlsearch_path_spec=$lt_cv_sys_lib_dlsearch_path_spec fi # remember unaugmented sys_lib_dlsearch_path content for libtool script decls... configure_time_dlsearch_path=$sys_lib_dlsearch_path_spec # ... but it needs LT_SYS_LIBRARY_PATH munging for other configure-time code func_munge_path_list sys_lib_dlsearch_path_spec "$LT_SYS_LIBRARY_PATH" # to be used as default LT_SYS_LIBRARY_PATH value in generated libtool configure_time_lt_sys_library_path=$LT_SYS_LIBRARY_PATH { $as_echo "$as_me:${as_lineno-$LINENO}: checking how to hardcode library paths into programs" >&5 $as_echo_n "checking how to hardcode library paths into programs... " >&6; } hardcode_action= if test -n "$hardcode_libdir_flag_spec" || test -n "$runpath_var" || test yes = "$hardcode_automatic"; then # We can hardcode non-existent directories. if test no != "$hardcode_direct" && # If the only mechanism to avoid hardcoding is shlibpath_var, we # have to relink, otherwise we might link with an installed library # when we should be linking with a yet-to-be-installed one ## test no != "$_LT_TAGVAR(hardcode_shlibpath_var, )" && test no != "$hardcode_minus_L"; then # Linking always hardcodes the temporary library directory. hardcode_action=relink else # We can link without hardcoding, and we can hardcode nonexisting dirs. hardcode_action=immediate fi else # We cannot hardcode anything, or else we can only hardcode existing # directories. hardcode_action=unsupported fi { $as_echo "$as_me:${as_lineno-$LINENO}: result: $hardcode_action" >&5 $as_echo "$hardcode_action" >&6; } if test relink = "$hardcode_action" || test yes = "$inherit_rpath"; then # Fast installation is not supported enable_fast_install=no elif test yes = "$shlibpath_overrides_runpath" || test no = "$enable_shared"; then # Fast installation is not necessary enable_fast_install=needless fi if test yes != "$enable_dlopen"; then enable_dlopen=unknown enable_dlopen_self=unknown enable_dlopen_self_static=unknown else lt_cv_dlopen=no lt_cv_dlopen_libs= case $host_os in beos*) lt_cv_dlopen=load_add_on lt_cv_dlopen_libs= lt_cv_dlopen_self=yes ;; mingw* | pw32* | cegcc*) lt_cv_dlopen=LoadLibrary lt_cv_dlopen_libs= ;; cygwin*) lt_cv_dlopen=dlopen lt_cv_dlopen_libs= ;; darwin*) # if libdl is installed we need to link against it { $as_echo "$as_me:${as_lineno-$LINENO}: checking for dlopen in -ldl" >&5 $as_echo_n "checking for dlopen in -ldl... " >&6; } if ${ac_cv_lib_dl_dlopen+:} false; then : $as_echo_n "(cached) " >&6 else ac_check_lib_save_LIBS=$LIBS LIBS="-ldl $LIBS" cat confdefs.h - <<_ACEOF >conftest.$ac_ext /* end confdefs.h. */ /* Override any GCC internal prototype to avoid an error. Use char because int might match the return type of a GCC builtin and then its argument prototype would still apply. */ #ifdef __cplusplus extern "C" #endif char dlopen (); int main () { return dlopen (); ; return 0; } _ACEOF if ac_fn_c_try_link "$LINENO"; then : ac_cv_lib_dl_dlopen=yes else ac_cv_lib_dl_dlopen=no fi rm -f core conftest.err conftest.$ac_objext \ conftest$ac_exeext conftest.$ac_ext LIBS=$ac_check_lib_save_LIBS fi { $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_cv_lib_dl_dlopen" >&5 $as_echo "$ac_cv_lib_dl_dlopen" >&6; } if test "x$ac_cv_lib_dl_dlopen" = xyes; then : lt_cv_dlopen=dlopen lt_cv_dlopen_libs=-ldl else lt_cv_dlopen=dyld lt_cv_dlopen_libs= lt_cv_dlopen_self=yes fi ;; tpf*) # Don't try to run any link tests for TPF. We know it's impossible # because TPF is a cross-compiler, and we know how we open DSOs. lt_cv_dlopen=dlopen lt_cv_dlopen_libs= lt_cv_dlopen_self=no ;; *) ac_fn_c_check_func "$LINENO" "shl_load" "ac_cv_func_shl_load" if test "x$ac_cv_func_shl_load" = xyes; then : lt_cv_dlopen=shl_load else { $as_echo "$as_me:${as_lineno-$LINENO}: checking for shl_load in -ldld" >&5 $as_echo_n "checking for shl_load in -ldld... " >&6; } if ${ac_cv_lib_dld_shl_load+:} false; then : $as_echo_n "(cached) " >&6 else ac_check_lib_save_LIBS=$LIBS LIBS="-ldld $LIBS" cat confdefs.h - <<_ACEOF >conftest.$ac_ext /* end confdefs.h. */ /* Override any GCC internal prototype to avoid an error. Use char because int might match the return type of a GCC builtin and then its argument prototype would still apply. */ #ifdef __cplusplus extern "C" #endif char shl_load (); int main () { return shl_load (); ; return 0; } _ACEOF if ac_fn_c_try_link "$LINENO"; then : ac_cv_lib_dld_shl_load=yes else ac_cv_lib_dld_shl_load=no fi rm -f core conftest.err conftest.$ac_objext \ conftest$ac_exeext conftest.$ac_ext LIBS=$ac_check_lib_save_LIBS fi { $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_cv_lib_dld_shl_load" >&5 $as_echo "$ac_cv_lib_dld_shl_load" >&6; } if test "x$ac_cv_lib_dld_shl_load" = xyes; then : lt_cv_dlopen=shl_load lt_cv_dlopen_libs=-ldld else ac_fn_c_check_func "$LINENO" "dlopen" "ac_cv_func_dlopen" if test "x$ac_cv_func_dlopen" = xyes; then : lt_cv_dlopen=dlopen else { $as_echo "$as_me:${as_lineno-$LINENO}: checking for dlopen in -ldl" >&5 $as_echo_n "checking for dlopen in -ldl... " >&6; } if ${ac_cv_lib_dl_dlopen+:} false; then : $as_echo_n "(cached) " >&6 else ac_check_lib_save_LIBS=$LIBS LIBS="-ldl $LIBS" cat confdefs.h - <<_ACEOF >conftest.$ac_ext /* end confdefs.h. */ /* Override any GCC internal prototype to avoid an error. Use char because int might match the return type of a GCC builtin and then its argument prototype would still apply. */ #ifdef __cplusplus extern "C" #endif char dlopen (); int main () { return dlopen (); ; return 0; } _ACEOF if ac_fn_c_try_link "$LINENO"; then : ac_cv_lib_dl_dlopen=yes else ac_cv_lib_dl_dlopen=no fi rm -f core conftest.err conftest.$ac_objext \ conftest$ac_exeext conftest.$ac_ext LIBS=$ac_check_lib_save_LIBS fi { $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_cv_lib_dl_dlopen" >&5 $as_echo "$ac_cv_lib_dl_dlopen" >&6; } if test "x$ac_cv_lib_dl_dlopen" = xyes; then : lt_cv_dlopen=dlopen lt_cv_dlopen_libs=-ldl else { $as_echo "$as_me:${as_lineno-$LINENO}: checking for dlopen in -lsvld" >&5 $as_echo_n "checking for dlopen in -lsvld... " >&6; } if ${ac_cv_lib_svld_dlopen+:} false; then : $as_echo_n "(cached) " >&6 else ac_check_lib_save_LIBS=$LIBS LIBS="-lsvld $LIBS" cat confdefs.h - <<_ACEOF >conftest.$ac_ext /* end confdefs.h. */ /* Override any GCC internal prototype to avoid an error. Use char because int might match the return type of a GCC builtin and then its argument prototype would still apply. */ #ifdef __cplusplus extern "C" #endif char dlopen (); int main () { return dlopen (); ; return 0; } _ACEOF if ac_fn_c_try_link "$LINENO"; then : ac_cv_lib_svld_dlopen=yes else ac_cv_lib_svld_dlopen=no fi rm -f core conftest.err conftest.$ac_objext \ conftest$ac_exeext conftest.$ac_ext LIBS=$ac_check_lib_save_LIBS fi { $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_cv_lib_svld_dlopen" >&5 $as_echo "$ac_cv_lib_svld_dlopen" >&6; } if test "x$ac_cv_lib_svld_dlopen" = xyes; then : lt_cv_dlopen=dlopen lt_cv_dlopen_libs=-lsvld else { $as_echo "$as_me:${as_lineno-$LINENO}: checking for dld_link in -ldld" >&5 $as_echo_n "checking for dld_link in -ldld... " >&6; } if ${ac_cv_lib_dld_dld_link+:} false; then : $as_echo_n "(cached) " >&6 else ac_check_lib_save_LIBS=$LIBS LIBS="-ldld $LIBS" cat confdefs.h - <<_ACEOF >conftest.$ac_ext /* end confdefs.h. */ /* Override any GCC internal prototype to avoid an error. Use char because int might match the return type of a GCC builtin and then its argument prototype would still apply. */ #ifdef __cplusplus extern "C" #endif char dld_link (); int main () { return dld_link (); ; return 0; } _ACEOF if ac_fn_c_try_link "$LINENO"; then : ac_cv_lib_dld_dld_link=yes else ac_cv_lib_dld_dld_link=no fi rm -f core conftest.err conftest.$ac_objext \ conftest$ac_exeext conftest.$ac_ext LIBS=$ac_check_lib_save_LIBS fi { $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_cv_lib_dld_dld_link" >&5 $as_echo "$ac_cv_lib_dld_dld_link" >&6; } if test "x$ac_cv_lib_dld_dld_link" = xyes; then : lt_cv_dlopen=dld_link lt_cv_dlopen_libs=-ldld fi fi fi fi fi fi ;; esac if test no = "$lt_cv_dlopen"; then enable_dlopen=no else enable_dlopen=yes fi case $lt_cv_dlopen in dlopen) save_CPPFLAGS=$CPPFLAGS test yes = "$ac_cv_header_dlfcn_h" && CPPFLAGS="$CPPFLAGS -DHAVE_DLFCN_H" save_LDFLAGS=$LDFLAGS wl=$lt_prog_compiler_wl eval LDFLAGS=\"\$LDFLAGS $export_dynamic_flag_spec\" save_LIBS=$LIBS LIBS="$lt_cv_dlopen_libs $LIBS" { $as_echo "$as_me:${as_lineno-$LINENO}: checking whether a program can dlopen itself" >&5 $as_echo_n "checking whether a program can dlopen itself... " >&6; } if ${lt_cv_dlopen_self+:} false; then : $as_echo_n "(cached) " >&6 else if test yes = "$cross_compiling"; then : lt_cv_dlopen_self=cross else lt_dlunknown=0; lt_dlno_uscore=1; lt_dlneed_uscore=2 lt_status=$lt_dlunknown cat > conftest.$ac_ext <<_LT_EOF #line $LINENO "configure" #include "confdefs.h" #if HAVE_DLFCN_H #include #endif #include #ifdef RTLD_GLOBAL # define LT_DLGLOBAL RTLD_GLOBAL #else # ifdef DL_GLOBAL # define LT_DLGLOBAL DL_GLOBAL # else # define LT_DLGLOBAL 0 # endif #endif /* We may have to define LT_DLLAZY_OR_NOW in the command line if we find out it does not work in some platform. */ #ifndef LT_DLLAZY_OR_NOW # ifdef RTLD_LAZY # define LT_DLLAZY_OR_NOW RTLD_LAZY # else # ifdef DL_LAZY # define LT_DLLAZY_OR_NOW DL_LAZY # else # ifdef RTLD_NOW # define LT_DLLAZY_OR_NOW RTLD_NOW # else # ifdef DL_NOW # define LT_DLLAZY_OR_NOW DL_NOW # else # define LT_DLLAZY_OR_NOW 0 # endif # endif # endif # endif #endif /* When -fvisibility=hidden is used, assume the code has been annotated correspondingly for the symbols needed. */ #if defined __GNUC__ && (((__GNUC__ == 3) && (__GNUC_MINOR__ >= 3)) || (__GNUC__ > 3)) int fnord () __attribute__((visibility("default"))); #endif int fnord () { return 42; } int main () { void *self = dlopen (0, LT_DLGLOBAL|LT_DLLAZY_OR_NOW); int status = $lt_dlunknown; if (self) { if (dlsym (self,"fnord")) status = $lt_dlno_uscore; else { if (dlsym( self,"_fnord")) status = $lt_dlneed_uscore; else puts (dlerror ()); } /* dlclose (self); */ } else puts (dlerror ()); return status; } _LT_EOF if { { eval echo "\"\$as_me\":${as_lineno-$LINENO}: \"$ac_link\""; } >&5 (eval $ac_link) 2>&5 ac_status=$? $as_echo "$as_me:${as_lineno-$LINENO}: \$? = $ac_status" >&5 test $ac_status = 0; } && test -s "conftest$ac_exeext" 2>/dev/null; then (./conftest; exit; ) >&5 2>/dev/null lt_status=$? case x$lt_status in x$lt_dlno_uscore) lt_cv_dlopen_self=yes ;; x$lt_dlneed_uscore) lt_cv_dlopen_self=yes ;; x$lt_dlunknown|x*) lt_cv_dlopen_self=no ;; esac else : # compilation failed lt_cv_dlopen_self=no fi fi rm -fr conftest* fi { $as_echo "$as_me:${as_lineno-$LINENO}: result: $lt_cv_dlopen_self" >&5 $as_echo "$lt_cv_dlopen_self" >&6; } if test yes = "$lt_cv_dlopen_self"; then wl=$lt_prog_compiler_wl eval LDFLAGS=\"\$LDFLAGS $lt_prog_compiler_static\" { $as_echo "$as_me:${as_lineno-$LINENO}: checking whether a statically linked program can dlopen itself" >&5 $as_echo_n "checking whether a statically linked program can dlopen itself... " >&6; } if ${lt_cv_dlopen_self_static+:} false; then : $as_echo_n "(cached) " >&6 else if test yes = "$cross_compiling"; then : lt_cv_dlopen_self_static=cross else lt_dlunknown=0; lt_dlno_uscore=1; lt_dlneed_uscore=2 lt_status=$lt_dlunknown cat > conftest.$ac_ext <<_LT_EOF #line $LINENO "configure" #include "confdefs.h" #if HAVE_DLFCN_H #include #endif #include #ifdef RTLD_GLOBAL # define LT_DLGLOBAL RTLD_GLOBAL #else # ifdef DL_GLOBAL # define LT_DLGLOBAL DL_GLOBAL # else # define LT_DLGLOBAL 0 # endif #endif /* We may have to define LT_DLLAZY_OR_NOW in the command line if we find out it does not work in some platform. */ #ifndef LT_DLLAZY_OR_NOW # ifdef RTLD_LAZY # define LT_DLLAZY_OR_NOW RTLD_LAZY # else # ifdef DL_LAZY # define LT_DLLAZY_OR_NOW DL_LAZY # else # ifdef RTLD_NOW # define LT_DLLAZY_OR_NOW RTLD_NOW # else # ifdef DL_NOW # define LT_DLLAZY_OR_NOW DL_NOW # else # define LT_DLLAZY_OR_NOW 0 # endif # endif # endif # endif #endif /* When -fvisibility=hidden is used, assume the code has been annotated correspondingly for the symbols needed. */ #if defined __GNUC__ && (((__GNUC__ == 3) && (__GNUC_MINOR__ >= 3)) || (__GNUC__ > 3)) int fnord () __attribute__((visibility("default"))); #endif int fnord () { return 42; } int main () { void *self = dlopen (0, LT_DLGLOBAL|LT_DLLAZY_OR_NOW); int status = $lt_dlunknown; if (self) { if (dlsym (self,"fnord")) status = $lt_dlno_uscore; else { if (dlsym( self,"_fnord")) status = $lt_dlneed_uscore; else puts (dlerror ()); } /* dlclose (self); */ } else puts (dlerror ()); return status; } _LT_EOF if { { eval echo "\"\$as_me\":${as_lineno-$LINENO}: \"$ac_link\""; } >&5 (eval $ac_link) 2>&5 ac_status=$? $as_echo "$as_me:${as_lineno-$LINENO}: \$? = $ac_status" >&5 test $ac_status = 0; } && test -s "conftest$ac_exeext" 2>/dev/null; then (./conftest; exit; ) >&5 2>/dev/null lt_status=$? case x$lt_status in x$lt_dlno_uscore) lt_cv_dlopen_self_static=yes ;; x$lt_dlneed_uscore) lt_cv_dlopen_self_static=yes ;; x$lt_dlunknown|x*) lt_cv_dlopen_self_static=no ;; esac else : # compilation failed lt_cv_dlopen_self_static=no fi fi rm -fr conftest* fi { $as_echo "$as_me:${as_lineno-$LINENO}: result: $lt_cv_dlopen_self_static" >&5 $as_echo "$lt_cv_dlopen_self_static" >&6; } fi CPPFLAGS=$save_CPPFLAGS LDFLAGS=$save_LDFLAGS LIBS=$save_LIBS ;; esac case $lt_cv_dlopen_self in yes|no) enable_dlopen_self=$lt_cv_dlopen_self ;; *) enable_dlopen_self=unknown ;; esac case $lt_cv_dlopen_self_static in yes|no) enable_dlopen_self_static=$lt_cv_dlopen_self_static ;; *) enable_dlopen_self_static=unknown ;; esac fi striplib= old_striplib= { $as_echo "$as_me:${as_lineno-$LINENO}: checking whether stripping libraries is possible" >&5 $as_echo_n "checking whether stripping libraries is possible... " >&6; } if test -n "$STRIP" && $STRIP -V 2>&1 | $GREP "GNU strip" >/dev/null; then test -z "$old_striplib" && old_striplib="$STRIP --strip-debug" test -z "$striplib" && striplib="$STRIP --strip-unneeded" { $as_echo "$as_me:${as_lineno-$LINENO}: result: yes" >&5 $as_echo "yes" >&6; } else # FIXME - insert some real tests, host_os isn't really good enough case $host_os in darwin*) if test -n "$STRIP"; then striplib="$STRIP -x" old_striplib="$STRIP -S" { $as_echo "$as_me:${as_lineno-$LINENO}: result: yes" >&5 $as_echo "yes" >&6; } else { $as_echo "$as_me:${as_lineno-$LINENO}: result: no" >&5 $as_echo "no" >&6; } fi ;; *) { $as_echo "$as_me:${as_lineno-$LINENO}: result: no" >&5 $as_echo "no" >&6; } ;; esac fi # Report what library types will actually be built { $as_echo "$as_me:${as_lineno-$LINENO}: checking if libtool supports shared libraries" >&5 $as_echo_n "checking if libtool supports shared libraries... " >&6; } { $as_echo "$as_me:${as_lineno-$LINENO}: result: $can_build_shared" >&5 $as_echo "$can_build_shared" >&6; } { $as_echo "$as_me:${as_lineno-$LINENO}: checking whether to build shared libraries" >&5 $as_echo_n "checking whether to build shared libraries... " >&6; } test no = "$can_build_shared" && enable_shared=no # On AIX, shared libraries and static libraries use the same namespace, and # are all built from PIC. case $host_os in aix3*) test yes = "$enable_shared" && enable_static=no if test -n "$RANLIB"; then archive_cmds="$archive_cmds~\$RANLIB \$lib" postinstall_cmds='$RANLIB $lib' fi ;; aix[4-9]*) if test ia64 != "$host_cpu"; then case $enable_shared,$with_aix_soname,$aix_use_runtimelinking in yes,aix,yes) ;; # shared object as lib.so file only yes,svr4,*) ;; # shared object as lib.so archive member only yes,*) enable_static=no ;; # shared object in lib.a archive as well esac fi ;; esac { $as_echo "$as_me:${as_lineno-$LINENO}: result: $enable_shared" >&5 $as_echo "$enable_shared" >&6; } { $as_echo "$as_me:${as_lineno-$LINENO}: checking whether to build static libraries" >&5 $as_echo_n "checking whether to build static libraries... " >&6; } # Make sure either enable_shared or enable_static is yes. test yes = "$enable_shared" || enable_static=yes { $as_echo "$as_me:${as_lineno-$LINENO}: result: $enable_static" >&5 $as_echo "$enable_static" >&6; } fi ac_ext=c ac_cpp='$CPP $CPPFLAGS' ac_compile='$CC -c $CFLAGS $CPPFLAGS conftest.$ac_ext >&5' ac_link='$CC -o conftest$ac_exeext $CFLAGS $CPPFLAGS $LDFLAGS conftest.$ac_ext $LIBS >&5' ac_compiler_gnu=$ac_cv_c_compiler_gnu CC=$lt_save_CC ac_config_commands="$ac_config_commands libtool" # Only expand once: # Check whether --with-pkgconfigdir was given. if test "${with_pkgconfigdir+set}" = set; then : withval=$with_pkgconfigdir; else with_pkgconfigdir='${libdir}/pkgconfig' fi pkgconfigdir=$with_pkgconfigdir ac_ext=c ac_cpp='$CPP $CPPFLAGS' ac_compile='$CC -c $CFLAGS $CPPFLAGS conftest.$ac_ext >&5' ac_link='$CC -o conftest$ac_exeext $CFLAGS $CPPFLAGS $LDFLAGS conftest.$ac_ext $LIBS >&5' ac_compiler_gnu=$ac_cv_c_compiler_gnu { $as_echo "$as_me:${as_lineno-$LINENO}: checking CFLAGS for maximum warnings" >&5 $as_echo_n "checking CFLAGS for maximum warnings... " >&6; } if ${ac_cv_cflags_warn_all+:} false; then : $as_echo_n "(cached) " >&6 else ac_cv_cflags_warn_all="no, unknown" ac_save_CFLAGS="$CFLAGS" for ac_arg in "-warn all % -warn all" "-pedantic % -Wall" "-xstrconst % -v" "-std1 % -verbose -w0 -warnprotos" "-qlanglvl=ansi % -qsrcmsg -qinfo=all:noppt:noppc:noobs:nocnd" "-ansi -ansiE % -fullwarn" "+ESlit % +w1" "-Xc % -pvctl,fullmsg" "-h conform % -h msglevel 2" # do CFLAGS="$ac_save_CFLAGS "`echo $ac_arg | sed -e 's,%%.*,,' -e 's,%,,'` cat confdefs.h - <<_ACEOF >conftest.$ac_ext /* end confdefs.h. */ int main () { ; return 0; } _ACEOF if ac_fn_c_try_compile "$LINENO"; then : ac_cv_cflags_warn_all=`echo $ac_arg | sed -e 's,.*% *,,'` ; break fi rm -f core conftest.err conftest.$ac_objext conftest.$ac_ext done CFLAGS="$ac_save_CFLAGS" fi { $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_cv_cflags_warn_all" >&5 $as_echo "$ac_cv_cflags_warn_all" >&6; } case ".$ac_cv_cflags_warn_all" in .ok|.ok,*) ;; .|.no|.no,*) ;; *) if ${CFLAGS+:} false; then : case " $CFLAGS " in #( *" $ac_cv_cflags_warn_all "*) : { { $as_echo "$as_me:${as_lineno-$LINENO}: : CFLAGS already contains \$ac_cv_cflags_warn_all"; } >&5 (: CFLAGS already contains $ac_cv_cflags_warn_all) 2>&5 ac_status=$? $as_echo "$as_me:${as_lineno-$LINENO}: \$? = $ac_status" >&5 test $ac_status = 0; } ;; #( *) : as_fn_append CFLAGS " $ac_cv_cflags_warn_all" { { $as_echo "$as_me:${as_lineno-$LINENO}: : CFLAGS=\"\$CFLAGS\""; } >&5 (: CFLAGS="$CFLAGS") 2>&5 ac_status=$? $as_echo "$as_me:${as_lineno-$LINENO}: \$? = $ac_status" >&5 test $ac_status = 0; } ;; esac else CFLAGS=$ac_cv_cflags_warn_all { { $as_echo "$as_me:${as_lineno-$LINENO}: : CFLAGS=\"\$CFLAGS\""; } >&5 (: CFLAGS="$CFLAGS") 2>&5 ac_status=$? $as_echo "$as_me:${as_lineno-$LINENO}: \$? = $ac_status" >&5 test $ac_status = 0; } fi ;; esac ac_ext=c ac_cpp='$CPP $CPPFLAGS' ac_compile='$CC -c $CFLAGS $CPPFLAGS conftest.$ac_ext >&5' ac_link='$CC -o conftest$ac_exeext $CFLAGS $CPPFLAGS $LDFLAGS conftest.$ac_ext $LIBS >&5' ac_compiler_gnu=$ac_cv_c_compiler_gnu for flag in -Wwrite-strings; do as_CACHEVAR=`$as_echo "ax_cv_check_cflags__$flag" | $as_tr_sh` { $as_echo "$as_me:${as_lineno-$LINENO}: checking whether C compiler accepts $flag" >&5 $as_echo_n "checking whether C compiler accepts $flag... " >&6; } if eval \${$as_CACHEVAR+:} false; then : $as_echo_n "(cached) " >&6 else ax_check_save_flags=$CFLAGS CFLAGS="$CFLAGS $flag" cat confdefs.h - <<_ACEOF >conftest.$ac_ext /* end confdefs.h. */ int main () { ; return 0; } _ACEOF if ac_fn_c_try_compile "$LINENO"; then : eval "$as_CACHEVAR=yes" else eval "$as_CACHEVAR=no" fi rm -f core conftest.err conftest.$ac_objext conftest.$ac_ext CFLAGS=$ax_check_save_flags fi eval ac_res=\$$as_CACHEVAR { $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_res" >&5 $as_echo "$ac_res" >&6; } if eval test \"x\$"$as_CACHEVAR"\" = x"yes"; then : if ${CFLAGS+:} false; then : case " $CFLAGS " in #( *" $flag "*) : { { $as_echo "$as_me:${as_lineno-$LINENO}: : CFLAGS already contains \$flag"; } >&5 (: CFLAGS already contains $flag) 2>&5 ac_status=$? $as_echo "$as_me:${as_lineno-$LINENO}: \$? = $ac_status" >&5 test $ac_status = 0; } ;; #( *) : as_fn_append CFLAGS " $flag" { { $as_echo "$as_me:${as_lineno-$LINENO}: : CFLAGS=\"\$CFLAGS\""; } >&5 (: CFLAGS="$CFLAGS") 2>&5 ac_status=$? $as_echo "$as_me:${as_lineno-$LINENO}: \$? = $ac_status" >&5 test $ac_status = 0; } ;; esac else CFLAGS=$flag { { $as_echo "$as_me:${as_lineno-$LINENO}: : CFLAGS=\"\$CFLAGS\""; } >&5 (: CFLAGS="$CFLAGS") 2>&5 ac_status=$? $as_echo "$as_me:${as_lineno-$LINENO}: \$? = $ac_status" >&5 test $ac_status = 0; } fi else : fi done # SIMD is optional # Check whether --with-simd was given. if test "${with_simd+set}" = set; then : withval=$with_simd; fi if test "x${with_simd}" != "xno"; then # Check if we're on a supported CPU { $as_echo "$as_me:${as_lineno-$LINENO}: checking if we have SIMD optimisations for cpu type" >&5 $as_echo_n "checking if we have SIMD optimisations for cpu type... " >&6; } case "$host_cpu" in x86_64 | amd64) { $as_echo "$as_me:${as_lineno-$LINENO}: result: yes (x86_64)" >&5 $as_echo "yes (x86_64)" >&6; } for ac_prog in nasm nasmw yasm do # Extract the first word of "$ac_prog", so it can be a program name with args. set dummy $ac_prog; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } if ${ac_cv_prog_NASM+:} false; then : $as_echo_n "(cached) " >&6 else if test -n "$NASM"; then ac_cv_prog_NASM="$NASM" # Let the user override the test. else as_save_IFS=$IFS; IFS=$PATH_SEPARATOR for as_dir in $PATH do IFS=$as_save_IFS test -z "$as_dir" && as_dir=. for ac_exec_ext in '' $ac_executable_extensions; do if as_fn_executable_p "$as_dir/$ac_word$ac_exec_ext"; then ac_cv_prog_NASM="$ac_prog" $as_echo "$as_me:${as_lineno-$LINENO}: found $as_dir/$ac_word$ac_exec_ext" >&5 break 2 fi done done IFS=$as_save_IFS fi fi NASM=$ac_cv_prog_NASM if test -n "$NASM"; then { $as_echo "$as_me:${as_lineno-$LINENO}: result: $NASM" >&5 $as_echo "$NASM" >&6; } else { $as_echo "$as_me:${as_lineno-$LINENO}: result: no" >&5 $as_echo "no" >&6; } fi test -n "$NASM" && break done test -z "$NASM" && as_fn_error $? "no nasm (Netwide Assembler) found" "$LINENO" 5 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for object file format of host system" >&5 $as_echo_n "checking for object file format of host system... " >&6; } case "$host_os" in cygwin* | mingw* | pw32* | interix*) case "$host_cpu" in x86_64) objfmt='Win64-COFF' ;; *) objfmt='Win32-COFF' ;; esac ;; msdosdjgpp* | go32*) objfmt='COFF' ;; os2-emx*) # not tested objfmt='MSOMF' # obj ;; linux*coff* | linux*oldld*) objfmt='COFF' # ??? ;; linux*aout*) objfmt='a.out' ;; linux*) case "$host_cpu" in x86_64) objfmt='ELF64' ;; *) objfmt='ELF' ;; esac ;; kfreebsd* | freebsd* | netbsd* | openbsd*) if echo __ELF__ | $CC -E - | grep __ELF__ > /dev/null; then objfmt='BSD-a.out' else case "$host_cpu" in x86_64 | amd64) objfmt='ELF64' ;; *) objfmt='ELF' ;; esac fi ;; solaris* | sunos* | sysv* | sco*) case "$host_cpu" in x86_64) objfmt='ELF64' ;; *) objfmt='ELF' ;; esac ;; darwin* | rhapsody* | nextstep* | openstep* | macos*) case "$host_cpu" in x86_64) objfmt='Mach-O64' ;; *) objfmt='Mach-O' ;; esac ;; *) objfmt='ELF ?' ;; esac { $as_echo "$as_me:${as_lineno-$LINENO}: result: $objfmt" >&5 $as_echo "$objfmt" >&6; } if test "$objfmt" = 'ELF ?'; then objfmt='ELF' { $as_echo "$as_me:${as_lineno-$LINENO}: WARNING: unexpected host system. assumed that the format is $objfmt." >&5 $as_echo "$as_me: WARNING: unexpected host system. assumed that the format is $objfmt." >&2;} fi { $as_echo "$as_me:${as_lineno-$LINENO}: checking for object file format specifier (NAFLAGS) " >&5 $as_echo_n "checking for object file format specifier (NAFLAGS) ... " >&6; } case "$objfmt" in MSOMF) NAFLAGS='-fobj -DOBJ32';; Win32-COFF) NAFLAGS='-fwin32 -DWIN32';; Win64-COFF) NAFLAGS='-fwin64 -DWIN64 -D__x86_64__';; COFF) NAFLAGS='-fcoff -DCOFF';; a.out) NAFLAGS='-faout -DAOUT';; BSD-a.out) NAFLAGS='-faoutb -DAOUT';; ELF) NAFLAGS='-felf -DELF';; ELF64) NAFLAGS='-felf64 -DELF -D__x86_64__';; RDF) NAFLAGS='-frdf -DRDF';; Mach-O) NAFLAGS='-fmacho -DMACHO';; Mach-O64) NAFLAGS='-fmacho64 -DMACHO -D__x86_64__';; esac { $as_echo "$as_me:${as_lineno-$LINENO}: result: $NAFLAGS" >&5 $as_echo "$NAFLAGS" >&6; } { $as_echo "$as_me:${as_lineno-$LINENO}: checking whether the assembler ($NASM $NAFLAGS) works" >&5 $as_echo_n "checking whether the assembler ($NASM $NAFLAGS) works... " >&6; } cat > conftest.asm <&5 (eval $try_nasm) 2>&5 ac_status=$? $as_echo "$as_me:${as_lineno-$LINENO}: \$? = $ac_status" >&5 test $ac_status = 0; } && test -s conftest-nasm.o; then { $as_echo "$as_me:${as_lineno-$LINENO}: result: yes" >&5 $as_echo "yes" >&6; } else echo "configure: failed program was:" >&5 cat conftest.asm >&5 rm -rf conftest* { $as_echo "$as_me:${as_lineno-$LINENO}: result: no" >&5 $as_echo "no" >&6; } as_fn_error $? "installation or configuration problem: assembler cannot create object files." "$LINENO" 5 fi { $as_echo "$as_me:${as_lineno-$LINENO}: checking whether the linker accepts assembler output" >&5 $as_echo_n "checking whether the linker accepts assembler output... " >&6; } nasm_save_LIBS="$LIBS" LIBS="conftest-nasm.o $LIBS" cat confdefs.h - <<_ACEOF >conftest.$ac_ext /* end confdefs.h. */ #ifdef __cplusplus extern "C" #endif void nasmfunc(void); int main () { nasmfunc(); ; return 0; } _ACEOF if ac_fn_c_try_link "$LINENO"; then : nasm_link_ok=yes else nasm_link_ok=no fi rm -f core conftest.err conftest.$ac_objext \ conftest$ac_exeext conftest.$ac_ext LIBS="$nasm_save_LIBS" { $as_echo "$as_me:${as_lineno-$LINENO}: result: $nasm_link_ok" >&5 $as_echo "$nasm_link_ok" >&6; } if test "x$nasm_link_ok" = "xno"; then as_fn_error $? "configuration problem: maybe object file format mismatch." "$LINENO" 5 fi simd_arch=x86_64 $as_echo "#define RFX_USE_ACCEL_AMD64 1" >>confdefs.h ;; i*86 | x86 | ia32) { $as_echo "$as_me:${as_lineno-$LINENO}: result: yes (i386)" >&5 $as_echo "yes (i386)" >&6; } for ac_prog in nasm nasmw yasm do # Extract the first word of "$ac_prog", so it can be a program name with args. set dummy $ac_prog; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } if ${ac_cv_prog_NASM+:} false; then : $as_echo_n "(cached) " >&6 else if test -n "$NASM"; then ac_cv_prog_NASM="$NASM" # Let the user override the test. else as_save_IFS=$IFS; IFS=$PATH_SEPARATOR for as_dir in $PATH do IFS=$as_save_IFS test -z "$as_dir" && as_dir=. for ac_exec_ext in '' $ac_executable_extensions; do if as_fn_executable_p "$as_dir/$ac_word$ac_exec_ext"; then ac_cv_prog_NASM="$ac_prog" $as_echo "$as_me:${as_lineno-$LINENO}: found $as_dir/$ac_word$ac_exec_ext" >&5 break 2 fi done done IFS=$as_save_IFS fi fi NASM=$ac_cv_prog_NASM if test -n "$NASM"; then { $as_echo "$as_me:${as_lineno-$LINENO}: result: $NASM" >&5 $as_echo "$NASM" >&6; } else { $as_echo "$as_me:${as_lineno-$LINENO}: result: no" >&5 $as_echo "no" >&6; } fi test -n "$NASM" && break done test -z "$NASM" && as_fn_error $? "no nasm (Netwide Assembler) found" "$LINENO" 5 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for object file format of host system" >&5 $as_echo_n "checking for object file format of host system... " >&6; } case "$host_os" in cygwin* | mingw* | pw32* | interix*) case "$host_cpu" in x86_64) objfmt='Win64-COFF' ;; *) objfmt='Win32-COFF' ;; esac ;; msdosdjgpp* | go32*) objfmt='COFF' ;; os2-emx*) # not tested objfmt='MSOMF' # obj ;; linux*coff* | linux*oldld*) objfmt='COFF' # ??? ;; linux*aout*) objfmt='a.out' ;; linux*) case "$host_cpu" in x86_64) objfmt='ELF64' ;; *) objfmt='ELF' ;; esac ;; kfreebsd* | freebsd* | netbsd* | openbsd*) if echo __ELF__ | $CC -E - | grep __ELF__ > /dev/null; then objfmt='BSD-a.out' else case "$host_cpu" in x86_64 | amd64) objfmt='ELF64' ;; *) objfmt='ELF' ;; esac fi ;; solaris* | sunos* | sysv* | sco*) case "$host_cpu" in x86_64) objfmt='ELF64' ;; *) objfmt='ELF' ;; esac ;; darwin* | rhapsody* | nextstep* | openstep* | macos*) case "$host_cpu" in x86_64) objfmt='Mach-O64' ;; *) objfmt='Mach-O' ;; esac ;; *) objfmt='ELF ?' ;; esac { $as_echo "$as_me:${as_lineno-$LINENO}: result: $objfmt" >&5 $as_echo "$objfmt" >&6; } if test "$objfmt" = 'ELF ?'; then objfmt='ELF' { $as_echo "$as_me:${as_lineno-$LINENO}: WARNING: unexpected host system. assumed that the format is $objfmt." >&5 $as_echo "$as_me: WARNING: unexpected host system. assumed that the format is $objfmt." >&2;} fi { $as_echo "$as_me:${as_lineno-$LINENO}: checking for object file format specifier (NAFLAGS) " >&5 $as_echo_n "checking for object file format specifier (NAFLAGS) ... " >&6; } case "$objfmt" in MSOMF) NAFLAGS='-fobj -DOBJ32';; Win32-COFF) NAFLAGS='-fwin32 -DWIN32';; Win64-COFF) NAFLAGS='-fwin64 -DWIN64 -D__x86_64__';; COFF) NAFLAGS='-fcoff -DCOFF';; a.out) NAFLAGS='-faout -DAOUT';; BSD-a.out) NAFLAGS='-faoutb -DAOUT';; ELF) NAFLAGS='-felf -DELF';; ELF64) NAFLAGS='-felf64 -DELF -D__x86_64__';; RDF) NAFLAGS='-frdf -DRDF';; Mach-O) NAFLAGS='-fmacho -DMACHO';; Mach-O64) NAFLAGS='-fmacho64 -DMACHO -D__x86_64__';; esac { $as_echo "$as_me:${as_lineno-$LINENO}: result: $NAFLAGS" >&5 $as_echo "$NAFLAGS" >&6; } { $as_echo "$as_me:${as_lineno-$LINENO}: checking whether the assembler ($NASM $NAFLAGS) works" >&5 $as_echo_n "checking whether the assembler ($NASM $NAFLAGS) works... " >&6; } cat > conftest.asm <&5 (eval $try_nasm) 2>&5 ac_status=$? $as_echo "$as_me:${as_lineno-$LINENO}: \$? = $ac_status" >&5 test $ac_status = 0; } && test -s conftest-nasm.o; then { $as_echo "$as_me:${as_lineno-$LINENO}: result: yes" >&5 $as_echo "yes" >&6; } else echo "configure: failed program was:" >&5 cat conftest.asm >&5 rm -rf conftest* { $as_echo "$as_me:${as_lineno-$LINENO}: result: no" >&5 $as_echo "no" >&6; } as_fn_error $? "installation or configuration problem: assembler cannot create object files." "$LINENO" 5 fi { $as_echo "$as_me:${as_lineno-$LINENO}: checking whether the linker accepts assembler output" >&5 $as_echo_n "checking whether the linker accepts assembler output... " >&6; } nasm_save_LIBS="$LIBS" LIBS="conftest-nasm.o $LIBS" cat confdefs.h - <<_ACEOF >conftest.$ac_ext /* end confdefs.h. */ #ifdef __cplusplus extern "C" #endif void nasmfunc(void); int main () { nasmfunc(); ; return 0; } _ACEOF if ac_fn_c_try_link "$LINENO"; then : nasm_link_ok=yes else nasm_link_ok=no fi rm -f core conftest.err conftest.$ac_objext \ conftest$ac_exeext conftest.$ac_ext LIBS="$nasm_save_LIBS" { $as_echo "$as_me:${as_lineno-$LINENO}: result: $nasm_link_ok" >&5 $as_echo "$nasm_link_ok" >&6; } if test "x$nasm_link_ok" = "xno"; then as_fn_error $? "configuration problem: maybe object file format mismatch." "$LINENO" 5 fi simd_arch=i386 $as_echo "#define RFX_USE_ACCEL_X86 1" >>confdefs.h ;; *) { $as_echo "$as_me:${as_lineno-$LINENO}: result: no (\"$host_cpu\")" >&5 $as_echo "no (\"$host_cpu\")" >&6; } { $as_echo "$as_me:${as_lineno-$LINENO}: WARNING: SIMD support not available for this CPU. Performance will suffer." >&5 $as_echo "$as_me: WARNING: SIMD support not available for this CPU. Performance will suffer." >&2;} ;; esac fi if test x$simd_arch = xx86_64; then WITH_SIMD_AMD64_TRUE= WITH_SIMD_AMD64_FALSE='#' else WITH_SIMD_AMD64_TRUE='#' WITH_SIMD_AMD64_FALSE= fi if test x$simd_arch = xi386; then WITH_SIMD_X86_TRUE= WITH_SIMD_X86_FALSE='#' else WITH_SIMD_X86_TRUE='#' WITH_SIMD_X86_FALSE= fi ac_config_files="$ac_config_files Makefile include/Makefile src/Makefile src/amd64/Makefile src/x86/Makefile tests/Makefile rfxcodec.pc rfxcodec-uninstalled.pc" cat >confcache <<\_ACEOF # This file is a shell script that caches the results of configure # tests run on this system so they can be shared between configure # scripts and configure runs, see configure's option --config-cache. # It is not useful on other systems. If it contains results you don't # want to keep, you may remove or edit it. # # config.status only pays attention to the cache file if you give it # the --recheck option to rerun configure. # # `ac_cv_env_foo' variables (set or unset) will be overridden when # loading this file, other *unset* `ac_cv_foo' will be assigned the # following values. _ACEOF # The following way of writing the cache mishandles newlines in values, # but we know of no workaround that is simple, portable, and efficient. # So, we kill variables containing newlines. # Ultrix sh set writes to stderr and can't be redirected directly, # and sets the high bit in the cache file unless we assign to the vars. ( for ac_var in `(set) 2>&1 | sed -n 's/^\([a-zA-Z_][a-zA-Z0-9_]*\)=.*/\1/p'`; do eval ac_val=\$$ac_var case $ac_val in #( *${as_nl}*) case $ac_var in #( *_cv_*) { $as_echo "$as_me:${as_lineno-$LINENO}: WARNING: cache variable $ac_var contains a newline" >&5 $as_echo "$as_me: WARNING: cache variable $ac_var contains a newline" >&2;} ;; esac case $ac_var in #( _ | IFS | as_nl) ;; #( BASH_ARGV | BASH_SOURCE) eval $ac_var= ;; #( *) { eval $ac_var=; unset $ac_var;} ;; esac ;; esac done (set) 2>&1 | case $as_nl`(ac_space=' '; set) 2>&1` in #( *${as_nl}ac_space=\ *) # `set' does not quote correctly, so add quotes: double-quote # substitution turns \\\\ into \\, and sed turns \\ into \. sed -n \ "s/'/'\\\\''/g; s/^\\([_$as_cr_alnum]*_cv_[_$as_cr_alnum]*\\)=\\(.*\\)/\\1='\\2'/p" ;; #( *) # `set' quotes correctly as required by POSIX, so do not add quotes. sed -n "/^[_$as_cr_alnum]*_cv_[_$as_cr_alnum]*=/p" ;; esac | sort ) | sed ' /^ac_cv_env_/b end t clear :clear s/^\([^=]*\)=\(.*[{}].*\)$/test "${\1+set}" = set || &/ t end s/^\([^=]*\)=\(.*\)$/\1=${\1=\2}/ :end' >>confcache if diff "$cache_file" confcache >/dev/null 2>&1; then :; else if test -w "$cache_file"; then if test "x$cache_file" != "x/dev/null"; then { $as_echo "$as_me:${as_lineno-$LINENO}: updating cache $cache_file" >&5 $as_echo "$as_me: updating cache $cache_file" >&6;} if test ! -f "$cache_file" || test -h "$cache_file"; then cat confcache >"$cache_file" else case $cache_file in #( */* | ?:*) mv -f confcache "$cache_file"$$ && mv -f "$cache_file"$$ "$cache_file" ;; #( *) mv -f confcache "$cache_file" ;; esac fi fi else { $as_echo "$as_me:${as_lineno-$LINENO}: not updating unwritable cache $cache_file" >&5 $as_echo "$as_me: not updating unwritable cache $cache_file" >&6;} fi fi rm -f confcache test "x$prefix" = xNONE && prefix=$ac_default_prefix # Let make expand exec_prefix. test "x$exec_prefix" = xNONE && exec_prefix='${prefix}' DEFS=-DHAVE_CONFIG_H ac_libobjs= ac_ltlibobjs= U= for ac_i in : $LIBOBJS; do test "x$ac_i" = x: && continue # 1. Remove the extension, and $U if already installed. ac_script='s/\$U\././;s/\.o$//;s/\.obj$//' ac_i=`$as_echo "$ac_i" | sed "$ac_script"` # 2. Prepend LIBOBJDIR. When used with automake>=1.10 LIBOBJDIR # will be set to the directory where LIBOBJS objects are built. as_fn_append ac_libobjs " \${LIBOBJDIR}$ac_i\$U.$ac_objext" as_fn_append ac_ltlibobjs " \${LIBOBJDIR}$ac_i"'$U.lo' done LIBOBJS=$ac_libobjs LTLIBOBJS=$ac_ltlibobjs { $as_echo "$as_me:${as_lineno-$LINENO}: checking that generated files are newer than configure" >&5 $as_echo_n "checking that generated files are newer than configure... " >&6; } if test -n "$am_sleep_pid"; then # Hide warnings about reused PIDs. wait $am_sleep_pid 2>/dev/null fi { $as_echo "$as_me:${as_lineno-$LINENO}: result: done" >&5 $as_echo "done" >&6; } if test -n "$EXEEXT"; then am__EXEEXT_TRUE= am__EXEEXT_FALSE='#' else am__EXEEXT_TRUE='#' am__EXEEXT_FALSE= fi if test -z "${AMDEP_TRUE}" && test -z "${AMDEP_FALSE}"; then as_fn_error $? "conditional \"AMDEP\" was never defined. Usually this means the macro was only invoked conditionally." "$LINENO" 5 fi if test -z "${am__fastdepCC_TRUE}" && test -z "${am__fastdepCC_FALSE}"; then as_fn_error $? "conditional \"am__fastdepCC\" was never defined. Usually this means the macro was only invoked conditionally." "$LINENO" 5 fi if test -z "${WITH_SIMD_AMD64_TRUE}" && test -z "${WITH_SIMD_AMD64_FALSE}"; then as_fn_error $? "conditional \"WITH_SIMD_AMD64\" was never defined. Usually this means the macro was only invoked conditionally." "$LINENO" 5 fi if test -z "${WITH_SIMD_X86_TRUE}" && test -z "${WITH_SIMD_X86_FALSE}"; then as_fn_error $? "conditional \"WITH_SIMD_X86\" was never defined. Usually this means the macro was only invoked conditionally." "$LINENO" 5 fi : "${CONFIG_STATUS=./config.status}" ac_write_fail=0 ac_clean_files_save=$ac_clean_files ac_clean_files="$ac_clean_files $CONFIG_STATUS" { $as_echo "$as_me:${as_lineno-$LINENO}: creating $CONFIG_STATUS" >&5 $as_echo "$as_me: creating $CONFIG_STATUS" >&6;} as_write_fail=0 cat >$CONFIG_STATUS <<_ASEOF || as_write_fail=1 #! $SHELL # Generated by $as_me. # Run this file to recreate the current configuration. # Compiler output produced by configure, useful for debugging # configure, is in config.log if it exists. debug=false ac_cs_recheck=false ac_cs_silent=false SHELL=\${CONFIG_SHELL-$SHELL} export SHELL _ASEOF cat >>$CONFIG_STATUS <<\_ASEOF || as_write_fail=1 ## -------------------- ## ## M4sh Initialization. ## ## -------------------- ## # Be more Bourne compatible DUALCASE=1; export DUALCASE # for MKS sh if test -n "${ZSH_VERSION+set}" && (emulate sh) >/dev/null 2>&1; then : emulate sh NULLCMD=: # Pre-4.2 versions of Zsh do word splitting on ${1+"$@"}, which # is contrary to our usage. Disable this feature. alias -g '${1+"$@"}'='"$@"' setopt NO_GLOB_SUBST else case `(set -o) 2>/dev/null` in #( *posix*) : set -o posix ;; #( *) : ;; esac fi as_nl=' ' export as_nl # Printing a long string crashes Solaris 7 /usr/bin/printf. as_echo='\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\' as_echo=$as_echo$as_echo$as_echo$as_echo$as_echo as_echo=$as_echo$as_echo$as_echo$as_echo$as_echo$as_echo # Prefer a ksh shell builtin over an external printf program on Solaris, # but without wasting forks for bash or zsh. if test -z "$BASH_VERSION$ZSH_VERSION" \ && (test "X`print -r -- $as_echo`" = "X$as_echo") 2>/dev/null; then as_echo='print -r --' as_echo_n='print -rn --' elif (test "X`printf %s $as_echo`" = "X$as_echo") 2>/dev/null; then as_echo='printf %s\n' as_echo_n='printf %s' else if test "X`(/usr/ucb/echo -n -n $as_echo) 2>/dev/null`" = "X-n $as_echo"; then as_echo_body='eval /usr/ucb/echo -n "$1$as_nl"' as_echo_n='/usr/ucb/echo -n' else as_echo_body='eval expr "X$1" : "X\\(.*\\)"' as_echo_n_body='eval arg=$1; case $arg in #( *"$as_nl"*) expr "X$arg" : "X\\(.*\\)$as_nl"; arg=`expr "X$arg" : ".*$as_nl\\(.*\\)"`;; esac; expr "X$arg" : "X\\(.*\\)" | tr -d "$as_nl" ' export as_echo_n_body as_echo_n='sh -c $as_echo_n_body as_echo' fi export as_echo_body as_echo='sh -c $as_echo_body as_echo' fi # The user is always right. if test "${PATH_SEPARATOR+set}" != set; then PATH_SEPARATOR=: (PATH='/bin;/bin'; FPATH=$PATH; sh -c :) >/dev/null 2>&1 && { (PATH='/bin:/bin'; FPATH=$PATH; sh -c :) >/dev/null 2>&1 || PATH_SEPARATOR=';' } fi # IFS # We need space, tab and new line, in precisely that order. Quoting is # there to prevent editors from complaining about space-tab. # (If _AS_PATH_WALK were called with IFS unset, it would disable word # splitting by setting IFS to empty value.) IFS=" "" $as_nl" # Find who we are. Look in the path if we contain no directory separator. as_myself= case $0 in #(( *[\\/]* ) as_myself=$0 ;; *) as_save_IFS=$IFS; IFS=$PATH_SEPARATOR for as_dir in $PATH do IFS=$as_save_IFS test -z "$as_dir" && as_dir=. test -r "$as_dir/$0" && as_myself=$as_dir/$0 && break done IFS=$as_save_IFS ;; esac # We did not find ourselves, most probably we were run as `sh COMMAND' # in which case we are not to be found in the path. if test "x$as_myself" = x; then as_myself=$0 fi if test ! -f "$as_myself"; then $as_echo "$as_myself: error: cannot find myself; rerun with an absolute file name" >&2 exit 1 fi # Unset variables that we do not need and which cause bugs (e.g. in # pre-3.0 UWIN ksh). But do not cause bugs in bash 2.01; the "|| exit 1" # suppresses any "Segmentation fault" message there. '((' could # trigger a bug in pdksh 5.2.14. for as_var in BASH_ENV ENV MAIL MAILPATH do eval test x\${$as_var+set} = xset \ && ( (unset $as_var) || exit 1) >/dev/null 2>&1 && unset $as_var || : done PS1='$ ' PS2='> ' PS4='+ ' # NLS nuisances. LC_ALL=C export LC_ALL LANGUAGE=C export LANGUAGE # CDPATH. (unset CDPATH) >/dev/null 2>&1 && unset CDPATH # as_fn_error STATUS ERROR [LINENO LOG_FD] # ---------------------------------------- # Output "`basename $0`: error: ERROR" to stderr. If LINENO and LOG_FD are # provided, also output the error to LOG_FD, referencing LINENO. Then exit the # script with STATUS, using 1 if that was 0. as_fn_error () { as_status=$1; test $as_status -eq 0 && as_status=1 if test "$4"; then as_lineno=${as_lineno-"$3"} as_lineno_stack=as_lineno_stack=$as_lineno_stack $as_echo "$as_me:${as_lineno-$LINENO}: error: $2" >&$4 fi $as_echo "$as_me: error: $2" >&2 as_fn_exit $as_status } # as_fn_error # as_fn_set_status STATUS # ----------------------- # Set $? to STATUS, without forking. as_fn_set_status () { return $1 } # as_fn_set_status # as_fn_exit STATUS # ----------------- # Exit the shell with STATUS, even in a "trap 0" or "set -e" context. as_fn_exit () { set +e as_fn_set_status $1 exit $1 } # as_fn_exit # as_fn_unset VAR # --------------- # Portably unset VAR. as_fn_unset () { { eval $1=; unset $1;} } as_unset=as_fn_unset # as_fn_append VAR VALUE # ---------------------- # Append the text in VALUE to the end of the definition contained in VAR. Take # advantage of any shell optimizations that allow amortized linear growth over # repeated appends, instead of the typical quadratic growth present in naive # implementations. if (eval "as_var=1; as_var+=2; test x\$as_var = x12") 2>/dev/null; then : eval 'as_fn_append () { eval $1+=\$2 }' else as_fn_append () { eval $1=\$$1\$2 } fi # as_fn_append # as_fn_arith ARG... # ------------------ # Perform arithmetic evaluation on the ARGs, and store the result in the # global $as_val. Take advantage of shells that can avoid forks. The arguments # must be portable across $(()) and expr. if (eval "test \$(( 1 + 1 )) = 2") 2>/dev/null; then : eval 'as_fn_arith () { as_val=$(( $* )) }' else as_fn_arith () { as_val=`expr "$@" || test $? -eq 1` } fi # as_fn_arith if expr a : '\(a\)' >/dev/null 2>&1 && test "X`expr 00001 : '.*\(...\)'`" = X001; then as_expr=expr else as_expr=false fi if (basename -- /) >/dev/null 2>&1 && test "X`basename -- / 2>&1`" = "X/"; then as_basename=basename else as_basename=false fi if (as_dir=`dirname -- /` && test "X$as_dir" = X/) >/dev/null 2>&1; then as_dirname=dirname else as_dirname=false fi as_me=`$as_basename -- "$0" || $as_expr X/"$0" : '.*/\([^/][^/]*\)/*$' \| \ X"$0" : 'X\(//\)$' \| \ X"$0" : 'X\(/\)' \| . 2>/dev/null || $as_echo X/"$0" | sed '/^.*\/\([^/][^/]*\)\/*$/{ s//\1/ q } /^X\/\(\/\/\)$/{ s//\1/ q } /^X\/\(\/\).*/{ s//\1/ q } s/.*/./; q'` # Avoid depending upon Character Ranges. as_cr_letters='abcdefghijklmnopqrstuvwxyz' as_cr_LETTERS='ABCDEFGHIJKLMNOPQRSTUVWXYZ' as_cr_Letters=$as_cr_letters$as_cr_LETTERS as_cr_digits='0123456789' as_cr_alnum=$as_cr_Letters$as_cr_digits ECHO_C= ECHO_N= ECHO_T= case `echo -n x` in #((((( -n*) case `echo 'xy\c'` in *c*) ECHO_T=' ';; # ECHO_T is single tab character. xy) ECHO_C='\c';; *) echo `echo ksh88 bug on AIX 6.1` > /dev/null ECHO_T=' ';; esac;; *) ECHO_N='-n';; esac rm -f conf$$ conf$$.exe conf$$.file if test -d conf$$.dir; then rm -f conf$$.dir/conf$$.file else rm -f conf$$.dir mkdir conf$$.dir 2>/dev/null fi if (echo >conf$$.file) 2>/dev/null; then if ln -s conf$$.file conf$$ 2>/dev/null; then as_ln_s='ln -s' # ... but there are two gotchas: # 1) On MSYS, both `ln -s file dir' and `ln file dir' fail. # 2) DJGPP < 2.04 has no symlinks; `ln -s' creates a wrapper executable. # In both cases, we have to default to `cp -pR'. ln -s conf$$.file conf$$.dir 2>/dev/null && test ! -f conf$$.exe || as_ln_s='cp -pR' elif ln conf$$.file conf$$ 2>/dev/null; then as_ln_s=ln else as_ln_s='cp -pR' fi else as_ln_s='cp -pR' fi rm -f conf$$ conf$$.exe conf$$.dir/conf$$.file conf$$.file rmdir conf$$.dir 2>/dev/null # as_fn_mkdir_p # ------------- # Create "$as_dir" as a directory, including parents if necessary. as_fn_mkdir_p () { case $as_dir in #( -*) as_dir=./$as_dir;; esac test -d "$as_dir" || eval $as_mkdir_p || { as_dirs= while :; do case $as_dir in #( *\'*) as_qdir=`$as_echo "$as_dir" | sed "s/'/'\\\\\\\\''/g"`;; #'( *) as_qdir=$as_dir;; esac as_dirs="'$as_qdir' $as_dirs" as_dir=`$as_dirname -- "$as_dir" || $as_expr X"$as_dir" : 'X\(.*[^/]\)//*[^/][^/]*/*$' \| \ X"$as_dir" : 'X\(//\)[^/]' \| \ X"$as_dir" : 'X\(//\)$' \| \ X"$as_dir" : 'X\(/\)' \| . 2>/dev/null || $as_echo X"$as_dir" | sed '/^X\(.*[^/]\)\/\/*[^/][^/]*\/*$/{ s//\1/ q } /^X\(\/\/\)[^/].*/{ s//\1/ q } /^X\(\/\/\)$/{ s//\1/ q } /^X\(\/\).*/{ s//\1/ q } s/.*/./; q'` test -d "$as_dir" && break done test -z "$as_dirs" || eval "mkdir $as_dirs" } || test -d "$as_dir" || as_fn_error $? "cannot create directory $as_dir" } # as_fn_mkdir_p if mkdir -p . 2>/dev/null; then as_mkdir_p='mkdir -p "$as_dir"' else test -d ./-p && rmdir ./-p as_mkdir_p=false fi # as_fn_executable_p FILE # ----------------------- # Test if FILE is an executable regular file. as_fn_executable_p () { test -f "$1" && test -x "$1" } # as_fn_executable_p as_test_x='test -x' as_executable_p=as_fn_executable_p # Sed expression to map a string onto a valid CPP name. as_tr_cpp="eval sed 'y%*$as_cr_letters%P$as_cr_LETTERS%;s%[^_$as_cr_alnum]%_%g'" # Sed expression to map a string onto a valid variable name. as_tr_sh="eval sed 'y%*+%pp%;s%[^_$as_cr_alnum]%_%g'" exec 6>&1 ## ----------------------------------- ## ## Main body of $CONFIG_STATUS script. ## ## ----------------------------------- ## _ASEOF test $as_write_fail = 0 && chmod +x $CONFIG_STATUS || ac_write_fail=1 cat >>$CONFIG_STATUS <<\_ACEOF || ac_write_fail=1 # Save the log message, to keep $0 and so on meaningful, and to # report actual input values of CONFIG_FILES etc. instead of their # values after options handling. ac_log=" This file was extended by rfxcodec $as_me 0.1.4, which was generated by GNU Autoconf 2.69. Invocation command line was CONFIG_FILES = $CONFIG_FILES CONFIG_HEADERS = $CONFIG_HEADERS CONFIG_LINKS = $CONFIG_LINKS CONFIG_COMMANDS = $CONFIG_COMMANDS $ $0 $@ on `(hostname || uname -n) 2>/dev/null | sed 1q` " _ACEOF case $ac_config_files in *" "*) set x $ac_config_files; shift; ac_config_files=$*;; esac case $ac_config_headers in *" "*) set x $ac_config_headers; shift; ac_config_headers=$*;; esac cat >>$CONFIG_STATUS <<_ACEOF || ac_write_fail=1 # Files that config.status was made for. config_files="$ac_config_files" config_headers="$ac_config_headers" config_commands="$ac_config_commands" _ACEOF cat >>$CONFIG_STATUS <<\_ACEOF || ac_write_fail=1 ac_cs_usage="\ \`$as_me' instantiates files and other configuration actions from templates according to the current configuration. Unless the files and actions are specified as TAGs, all are instantiated by default. Usage: $0 [OPTION]... [TAG]... -h, --help print this help, then exit -V, --version print version number and configuration settings, then exit --config print configuration, then exit -q, --quiet, --silent do not print progress messages -d, --debug don't remove temporary files --recheck update $as_me by reconfiguring in the same conditions --file=FILE[:TEMPLATE] instantiate the configuration file FILE --header=FILE[:TEMPLATE] instantiate the configuration header FILE Configuration files: $config_files Configuration headers: $config_headers Configuration commands: $config_commands Report bugs to ." _ACEOF cat >>$CONFIG_STATUS <<_ACEOF || ac_write_fail=1 ac_cs_config="`$as_echo "$ac_configure_args" | sed 's/^ //; s/[\\""\`\$]/\\\\&/g'`" ac_cs_version="\\ rfxcodec config.status 0.1.4 configured by $0, generated by GNU Autoconf 2.69, with options \\"\$ac_cs_config\\" Copyright (C) 2012 Free Software Foundation, Inc. This config.status script is free software; the Free Software Foundation gives unlimited permission to copy, distribute and modify it." ac_pwd='$ac_pwd' srcdir='$srcdir' INSTALL='$INSTALL' MKDIR_P='$MKDIR_P' AWK='$AWK' test -n "\$AWK" || AWK=awk _ACEOF cat >>$CONFIG_STATUS <<\_ACEOF || ac_write_fail=1 # The default lists apply if the user does not specify any file. ac_need_defaults=: while test $# != 0 do case $1 in --*=?*) ac_option=`expr "X$1" : 'X\([^=]*\)='` ac_optarg=`expr "X$1" : 'X[^=]*=\(.*\)'` ac_shift=: ;; --*=) ac_option=`expr "X$1" : 'X\([^=]*\)='` ac_optarg= ac_shift=: ;; *) ac_option=$1 ac_optarg=$2 ac_shift=shift ;; esac case $ac_option in # Handling of the options. -recheck | --recheck | --rechec | --reche | --rech | --rec | --re | --r) ac_cs_recheck=: ;; --version | --versio | --versi | --vers | --ver | --ve | --v | -V ) $as_echo "$ac_cs_version"; exit ;; --config | --confi | --conf | --con | --co | --c ) $as_echo "$ac_cs_config"; exit ;; --debug | --debu | --deb | --de | --d | -d ) debug=: ;; --file | --fil | --fi | --f ) $ac_shift case $ac_optarg in *\'*) ac_optarg=`$as_echo "$ac_optarg" | sed "s/'/'\\\\\\\\''/g"` ;; '') as_fn_error $? "missing file argument" ;; esac as_fn_append CONFIG_FILES " '$ac_optarg'" ac_need_defaults=false;; --header | --heade | --head | --hea ) $ac_shift case $ac_optarg in *\'*) ac_optarg=`$as_echo "$ac_optarg" | sed "s/'/'\\\\\\\\''/g"` ;; esac as_fn_append CONFIG_HEADERS " '$ac_optarg'" ac_need_defaults=false;; --he | --h) # Conflict between --help and --header as_fn_error $? "ambiguous option: \`$1' Try \`$0 --help' for more information.";; --help | --hel | -h ) $as_echo "$ac_cs_usage"; exit ;; -q | -quiet | --quiet | --quie | --qui | --qu | --q \ | -silent | --silent | --silen | --sile | --sil | --si | --s) ac_cs_silent=: ;; # This is an error. -*) as_fn_error $? "unrecognized option: \`$1' Try \`$0 --help' for more information." ;; *) as_fn_append ac_config_targets " $1" ac_need_defaults=false ;; esac shift done ac_configure_extra_args= if $ac_cs_silent; then exec 6>/dev/null ac_configure_extra_args="$ac_configure_extra_args --silent" fi _ACEOF cat >>$CONFIG_STATUS <<_ACEOF || ac_write_fail=1 if \$ac_cs_recheck; then set X $SHELL '$0' $ac_configure_args \$ac_configure_extra_args --no-create --no-recursion shift \$as_echo "running CONFIG_SHELL=$SHELL \$*" >&6 CONFIG_SHELL='$SHELL' export CONFIG_SHELL exec "\$@" fi _ACEOF cat >>$CONFIG_STATUS <<\_ACEOF || ac_write_fail=1 exec 5>>config.log { echo sed 'h;s/./-/g;s/^.../## /;s/...$/ ##/;p;x;p;x' <<_ASBOX ## Running $as_me. ## _ASBOX $as_echo "$ac_log" } >&5 _ACEOF cat >>$CONFIG_STATUS <<_ACEOF || ac_write_fail=1 # # INIT-COMMANDS # AMDEP_TRUE="$AMDEP_TRUE" ac_aux_dir="$ac_aux_dir" # The HP-UX ksh and POSIX shell print the target directory to stdout # if CDPATH is set. (unset CDPATH) >/dev/null 2>&1 && unset CDPATH sed_quote_subst='$sed_quote_subst' double_quote_subst='$double_quote_subst' delay_variable_subst='$delay_variable_subst' macro_version='`$ECHO "$macro_version" | $SED "$delay_single_quote_subst"`' macro_revision='`$ECHO "$macro_revision" | $SED "$delay_single_quote_subst"`' enable_shared='`$ECHO "$enable_shared" | $SED "$delay_single_quote_subst"`' enable_static='`$ECHO "$enable_static" | $SED "$delay_single_quote_subst"`' pic_mode='`$ECHO "$pic_mode" | $SED "$delay_single_quote_subst"`' enable_fast_install='`$ECHO "$enable_fast_install" | $SED "$delay_single_quote_subst"`' shared_archive_member_spec='`$ECHO "$shared_archive_member_spec" | $SED "$delay_single_quote_subst"`' SHELL='`$ECHO "$SHELL" | $SED "$delay_single_quote_subst"`' ECHO='`$ECHO "$ECHO" | $SED "$delay_single_quote_subst"`' PATH_SEPARATOR='`$ECHO "$PATH_SEPARATOR" | $SED "$delay_single_quote_subst"`' host_alias='`$ECHO "$host_alias" | $SED "$delay_single_quote_subst"`' host='`$ECHO "$host" | $SED "$delay_single_quote_subst"`' host_os='`$ECHO "$host_os" | $SED "$delay_single_quote_subst"`' build_alias='`$ECHO "$build_alias" | $SED "$delay_single_quote_subst"`' build='`$ECHO "$build" | $SED "$delay_single_quote_subst"`' build_os='`$ECHO "$build_os" | $SED "$delay_single_quote_subst"`' SED='`$ECHO "$SED" | $SED "$delay_single_quote_subst"`' Xsed='`$ECHO "$Xsed" | $SED "$delay_single_quote_subst"`' GREP='`$ECHO "$GREP" | $SED "$delay_single_quote_subst"`' EGREP='`$ECHO "$EGREP" | $SED "$delay_single_quote_subst"`' FGREP='`$ECHO "$FGREP" | $SED "$delay_single_quote_subst"`' LD='`$ECHO "$LD" | $SED "$delay_single_quote_subst"`' NM='`$ECHO "$NM" | $SED "$delay_single_quote_subst"`' LN_S='`$ECHO "$LN_S" | $SED "$delay_single_quote_subst"`' max_cmd_len='`$ECHO "$max_cmd_len" | $SED "$delay_single_quote_subst"`' ac_objext='`$ECHO "$ac_objext" | $SED "$delay_single_quote_subst"`' exeext='`$ECHO "$exeext" | $SED "$delay_single_quote_subst"`' lt_unset='`$ECHO "$lt_unset" | $SED "$delay_single_quote_subst"`' lt_SP2NL='`$ECHO "$lt_SP2NL" | $SED "$delay_single_quote_subst"`' lt_NL2SP='`$ECHO "$lt_NL2SP" | $SED "$delay_single_quote_subst"`' lt_cv_to_host_file_cmd='`$ECHO "$lt_cv_to_host_file_cmd" | $SED "$delay_single_quote_subst"`' lt_cv_to_tool_file_cmd='`$ECHO "$lt_cv_to_tool_file_cmd" | $SED "$delay_single_quote_subst"`' reload_flag='`$ECHO "$reload_flag" | $SED "$delay_single_quote_subst"`' reload_cmds='`$ECHO "$reload_cmds" | $SED "$delay_single_quote_subst"`' OBJDUMP='`$ECHO "$OBJDUMP" | $SED "$delay_single_quote_subst"`' deplibs_check_method='`$ECHO "$deplibs_check_method" | $SED "$delay_single_quote_subst"`' file_magic_cmd='`$ECHO "$file_magic_cmd" | $SED "$delay_single_quote_subst"`' file_magic_glob='`$ECHO "$file_magic_glob" | $SED "$delay_single_quote_subst"`' want_nocaseglob='`$ECHO "$want_nocaseglob" | $SED "$delay_single_quote_subst"`' DLLTOOL='`$ECHO "$DLLTOOL" | $SED "$delay_single_quote_subst"`' sharedlib_from_linklib_cmd='`$ECHO "$sharedlib_from_linklib_cmd" | $SED "$delay_single_quote_subst"`' AR='`$ECHO "$AR" | $SED "$delay_single_quote_subst"`' AR_FLAGS='`$ECHO "$AR_FLAGS" | $SED "$delay_single_quote_subst"`' archiver_list_spec='`$ECHO "$archiver_list_spec" | $SED "$delay_single_quote_subst"`' STRIP='`$ECHO "$STRIP" | $SED "$delay_single_quote_subst"`' RANLIB='`$ECHO "$RANLIB" | $SED "$delay_single_quote_subst"`' old_postinstall_cmds='`$ECHO "$old_postinstall_cmds" | $SED "$delay_single_quote_subst"`' old_postuninstall_cmds='`$ECHO "$old_postuninstall_cmds" | $SED "$delay_single_quote_subst"`' old_archive_cmds='`$ECHO "$old_archive_cmds" | $SED "$delay_single_quote_subst"`' lock_old_archive_extraction='`$ECHO "$lock_old_archive_extraction" | $SED "$delay_single_quote_subst"`' CC='`$ECHO "$CC" | $SED "$delay_single_quote_subst"`' CFLAGS='`$ECHO "$CFLAGS" | $SED "$delay_single_quote_subst"`' compiler='`$ECHO "$compiler" | $SED "$delay_single_quote_subst"`' GCC='`$ECHO "$GCC" | $SED "$delay_single_quote_subst"`' lt_cv_sys_global_symbol_pipe='`$ECHO "$lt_cv_sys_global_symbol_pipe" | $SED "$delay_single_quote_subst"`' lt_cv_sys_global_symbol_to_cdecl='`$ECHO "$lt_cv_sys_global_symbol_to_cdecl" | $SED "$delay_single_quote_subst"`' lt_cv_sys_global_symbol_to_import='`$ECHO "$lt_cv_sys_global_symbol_to_import" | $SED "$delay_single_quote_subst"`' lt_cv_sys_global_symbol_to_c_name_address='`$ECHO "$lt_cv_sys_global_symbol_to_c_name_address" | $SED "$delay_single_quote_subst"`' lt_cv_sys_global_symbol_to_c_name_address_lib_prefix='`$ECHO "$lt_cv_sys_global_symbol_to_c_name_address_lib_prefix" | $SED "$delay_single_quote_subst"`' lt_cv_nm_interface='`$ECHO "$lt_cv_nm_interface" | $SED "$delay_single_quote_subst"`' nm_file_list_spec='`$ECHO "$nm_file_list_spec" | $SED "$delay_single_quote_subst"`' lt_sysroot='`$ECHO "$lt_sysroot" | $SED "$delay_single_quote_subst"`' lt_cv_truncate_bin='`$ECHO "$lt_cv_truncate_bin" | $SED "$delay_single_quote_subst"`' objdir='`$ECHO "$objdir" | $SED "$delay_single_quote_subst"`' MAGIC_CMD='`$ECHO "$MAGIC_CMD" | $SED "$delay_single_quote_subst"`' lt_prog_compiler_no_builtin_flag='`$ECHO "$lt_prog_compiler_no_builtin_flag" | $SED "$delay_single_quote_subst"`' lt_prog_compiler_pic='`$ECHO "$lt_prog_compiler_pic" | $SED "$delay_single_quote_subst"`' lt_prog_compiler_wl='`$ECHO "$lt_prog_compiler_wl" | $SED "$delay_single_quote_subst"`' lt_prog_compiler_static='`$ECHO "$lt_prog_compiler_static" | $SED "$delay_single_quote_subst"`' lt_cv_prog_compiler_c_o='`$ECHO "$lt_cv_prog_compiler_c_o" | $SED "$delay_single_quote_subst"`' need_locks='`$ECHO "$need_locks" | $SED "$delay_single_quote_subst"`' MANIFEST_TOOL='`$ECHO "$MANIFEST_TOOL" | $SED "$delay_single_quote_subst"`' DSYMUTIL='`$ECHO "$DSYMUTIL" | $SED "$delay_single_quote_subst"`' NMEDIT='`$ECHO "$NMEDIT" | $SED "$delay_single_quote_subst"`' LIPO='`$ECHO "$LIPO" | $SED "$delay_single_quote_subst"`' OTOOL='`$ECHO "$OTOOL" | $SED "$delay_single_quote_subst"`' OTOOL64='`$ECHO "$OTOOL64" | $SED "$delay_single_quote_subst"`' libext='`$ECHO "$libext" | $SED "$delay_single_quote_subst"`' shrext_cmds='`$ECHO "$shrext_cmds" | $SED "$delay_single_quote_subst"`' extract_expsyms_cmds='`$ECHO "$extract_expsyms_cmds" | $SED "$delay_single_quote_subst"`' archive_cmds_need_lc='`$ECHO "$archive_cmds_need_lc" | $SED "$delay_single_quote_subst"`' enable_shared_with_static_runtimes='`$ECHO "$enable_shared_with_static_runtimes" | $SED "$delay_single_quote_subst"`' export_dynamic_flag_spec='`$ECHO "$export_dynamic_flag_spec" | $SED "$delay_single_quote_subst"`' whole_archive_flag_spec='`$ECHO "$whole_archive_flag_spec" | $SED "$delay_single_quote_subst"`' compiler_needs_object='`$ECHO "$compiler_needs_object" | $SED "$delay_single_quote_subst"`' old_archive_from_new_cmds='`$ECHO "$old_archive_from_new_cmds" | $SED "$delay_single_quote_subst"`' old_archive_from_expsyms_cmds='`$ECHO "$old_archive_from_expsyms_cmds" | $SED "$delay_single_quote_subst"`' archive_cmds='`$ECHO "$archive_cmds" | $SED "$delay_single_quote_subst"`' archive_expsym_cmds='`$ECHO "$archive_expsym_cmds" | $SED "$delay_single_quote_subst"`' module_cmds='`$ECHO "$module_cmds" | $SED "$delay_single_quote_subst"`' module_expsym_cmds='`$ECHO "$module_expsym_cmds" | $SED "$delay_single_quote_subst"`' with_gnu_ld='`$ECHO "$with_gnu_ld" | $SED "$delay_single_quote_subst"`' allow_undefined_flag='`$ECHO "$allow_undefined_flag" | $SED "$delay_single_quote_subst"`' no_undefined_flag='`$ECHO "$no_undefined_flag" | $SED "$delay_single_quote_subst"`' hardcode_libdir_flag_spec='`$ECHO "$hardcode_libdir_flag_spec" | $SED "$delay_single_quote_subst"`' hardcode_libdir_separator='`$ECHO "$hardcode_libdir_separator" | $SED "$delay_single_quote_subst"`' hardcode_direct='`$ECHO "$hardcode_direct" | $SED "$delay_single_quote_subst"`' hardcode_direct_absolute='`$ECHO "$hardcode_direct_absolute" | $SED "$delay_single_quote_subst"`' hardcode_minus_L='`$ECHO "$hardcode_minus_L" | $SED "$delay_single_quote_subst"`' hardcode_shlibpath_var='`$ECHO "$hardcode_shlibpath_var" | $SED "$delay_single_quote_subst"`' hardcode_automatic='`$ECHO "$hardcode_automatic" | $SED "$delay_single_quote_subst"`' inherit_rpath='`$ECHO "$inherit_rpath" | $SED "$delay_single_quote_subst"`' link_all_deplibs='`$ECHO "$link_all_deplibs" | $SED "$delay_single_quote_subst"`' always_export_symbols='`$ECHO "$always_export_symbols" | $SED "$delay_single_quote_subst"`' export_symbols_cmds='`$ECHO "$export_symbols_cmds" | $SED "$delay_single_quote_subst"`' exclude_expsyms='`$ECHO "$exclude_expsyms" | $SED "$delay_single_quote_subst"`' include_expsyms='`$ECHO "$include_expsyms" | $SED "$delay_single_quote_subst"`' prelink_cmds='`$ECHO "$prelink_cmds" | $SED "$delay_single_quote_subst"`' postlink_cmds='`$ECHO "$postlink_cmds" | $SED "$delay_single_quote_subst"`' file_list_spec='`$ECHO "$file_list_spec" | $SED "$delay_single_quote_subst"`' variables_saved_for_relink='`$ECHO "$variables_saved_for_relink" | $SED "$delay_single_quote_subst"`' need_lib_prefix='`$ECHO "$need_lib_prefix" | $SED "$delay_single_quote_subst"`' need_version='`$ECHO "$need_version" | $SED "$delay_single_quote_subst"`' version_type='`$ECHO "$version_type" | $SED "$delay_single_quote_subst"`' runpath_var='`$ECHO "$runpath_var" | $SED "$delay_single_quote_subst"`' shlibpath_var='`$ECHO "$shlibpath_var" | $SED "$delay_single_quote_subst"`' shlibpath_overrides_runpath='`$ECHO "$shlibpath_overrides_runpath" | $SED "$delay_single_quote_subst"`' libname_spec='`$ECHO "$libname_spec" | $SED "$delay_single_quote_subst"`' library_names_spec='`$ECHO "$library_names_spec" | $SED "$delay_single_quote_subst"`' soname_spec='`$ECHO "$soname_spec" | $SED "$delay_single_quote_subst"`' install_override_mode='`$ECHO "$install_override_mode" | $SED "$delay_single_quote_subst"`' postinstall_cmds='`$ECHO "$postinstall_cmds" | $SED "$delay_single_quote_subst"`' postuninstall_cmds='`$ECHO "$postuninstall_cmds" | $SED "$delay_single_quote_subst"`' finish_cmds='`$ECHO "$finish_cmds" | $SED "$delay_single_quote_subst"`' finish_eval='`$ECHO "$finish_eval" | $SED "$delay_single_quote_subst"`' hardcode_into_libs='`$ECHO "$hardcode_into_libs" | $SED "$delay_single_quote_subst"`' sys_lib_search_path_spec='`$ECHO "$sys_lib_search_path_spec" | $SED "$delay_single_quote_subst"`' configure_time_dlsearch_path='`$ECHO "$configure_time_dlsearch_path" | $SED "$delay_single_quote_subst"`' configure_time_lt_sys_library_path='`$ECHO "$configure_time_lt_sys_library_path" | $SED "$delay_single_quote_subst"`' hardcode_action='`$ECHO "$hardcode_action" | $SED "$delay_single_quote_subst"`' enable_dlopen='`$ECHO "$enable_dlopen" | $SED "$delay_single_quote_subst"`' enable_dlopen_self='`$ECHO "$enable_dlopen_self" | $SED "$delay_single_quote_subst"`' enable_dlopen_self_static='`$ECHO "$enable_dlopen_self_static" | $SED "$delay_single_quote_subst"`' old_striplib='`$ECHO "$old_striplib" | $SED "$delay_single_quote_subst"`' striplib='`$ECHO "$striplib" | $SED "$delay_single_quote_subst"`' LTCC='$LTCC' LTCFLAGS='$LTCFLAGS' compiler='$compiler_DEFAULT' # A function that is used when there is no print builtin or printf. func_fallback_echo () { eval 'cat <<_LTECHO_EOF \$1 _LTECHO_EOF' } # Quote evaled strings. for var in SHELL \ ECHO \ PATH_SEPARATOR \ SED \ GREP \ EGREP \ FGREP \ LD \ NM \ LN_S \ lt_SP2NL \ lt_NL2SP \ reload_flag \ OBJDUMP \ deplibs_check_method \ file_magic_cmd \ file_magic_glob \ want_nocaseglob \ DLLTOOL \ sharedlib_from_linklib_cmd \ AR \ AR_FLAGS \ archiver_list_spec \ STRIP \ RANLIB \ CC \ CFLAGS \ compiler \ lt_cv_sys_global_symbol_pipe \ lt_cv_sys_global_symbol_to_cdecl \ lt_cv_sys_global_symbol_to_import \ lt_cv_sys_global_symbol_to_c_name_address \ lt_cv_sys_global_symbol_to_c_name_address_lib_prefix \ lt_cv_nm_interface \ nm_file_list_spec \ lt_cv_truncate_bin \ lt_prog_compiler_no_builtin_flag \ lt_prog_compiler_pic \ lt_prog_compiler_wl \ lt_prog_compiler_static \ lt_cv_prog_compiler_c_o \ need_locks \ MANIFEST_TOOL \ DSYMUTIL \ NMEDIT \ LIPO \ OTOOL \ OTOOL64 \ shrext_cmds \ export_dynamic_flag_spec \ whole_archive_flag_spec \ compiler_needs_object \ with_gnu_ld \ allow_undefined_flag \ no_undefined_flag \ hardcode_libdir_flag_spec \ hardcode_libdir_separator \ exclude_expsyms \ include_expsyms \ file_list_spec \ variables_saved_for_relink \ libname_spec \ library_names_spec \ soname_spec \ install_override_mode \ finish_eval \ old_striplib \ striplib; do case \`eval \\\\\$ECHO \\\\""\\\\\$\$var"\\\\"\` in *[\\\\\\\`\\"\\\$]*) eval "lt_\$var=\\\\\\"\\\`\\\$ECHO \\"\\\$\$var\\" | \\\$SED \\"\\\$sed_quote_subst\\"\\\`\\\\\\"" ## exclude from sc_prohibit_nested_quotes ;; *) eval "lt_\$var=\\\\\\"\\\$\$var\\\\\\"" ;; esac done # Double-quote double-evaled strings. for var in reload_cmds \ old_postinstall_cmds \ old_postuninstall_cmds \ old_archive_cmds \ extract_expsyms_cmds \ old_archive_from_new_cmds \ old_archive_from_expsyms_cmds \ archive_cmds \ archive_expsym_cmds \ module_cmds \ module_expsym_cmds \ export_symbols_cmds \ prelink_cmds \ postlink_cmds \ postinstall_cmds \ postuninstall_cmds \ finish_cmds \ sys_lib_search_path_spec \ configure_time_dlsearch_path \ configure_time_lt_sys_library_path; do case \`eval \\\\\$ECHO \\\\""\\\\\$\$var"\\\\"\` in *[\\\\\\\`\\"\\\$]*) eval "lt_\$var=\\\\\\"\\\`\\\$ECHO \\"\\\$\$var\\" | \\\$SED -e \\"\\\$double_quote_subst\\" -e \\"\\\$sed_quote_subst\\" -e \\"\\\$delay_variable_subst\\"\\\`\\\\\\"" ## exclude from sc_prohibit_nested_quotes ;; *) eval "lt_\$var=\\\\\\"\\\$\$var\\\\\\"" ;; esac done ac_aux_dir='$ac_aux_dir' # See if we are running on zsh, and set the options that allow our # commands through without removal of \ escapes INIT. if test -n "\${ZSH_VERSION+set}"; then setopt NO_GLOB_SUBST fi PACKAGE='$PACKAGE' VERSION='$VERSION' RM='$RM' ofile='$ofile' _ACEOF cat >>$CONFIG_STATUS <<\_ACEOF || ac_write_fail=1 # Handling of arguments. for ac_config_target in $ac_config_targets do case $ac_config_target in "config_ac.h") CONFIG_HEADERS="$CONFIG_HEADERS config_ac.h:config_ac-h.in" ;; "depfiles") CONFIG_COMMANDS="$CONFIG_COMMANDS depfiles" ;; "libtool") CONFIG_COMMANDS="$CONFIG_COMMANDS libtool" ;; "Makefile") CONFIG_FILES="$CONFIG_FILES Makefile" ;; "include/Makefile") CONFIG_FILES="$CONFIG_FILES include/Makefile" ;; "src/Makefile") CONFIG_FILES="$CONFIG_FILES src/Makefile" ;; "src/amd64/Makefile") CONFIG_FILES="$CONFIG_FILES src/amd64/Makefile" ;; "src/x86/Makefile") CONFIG_FILES="$CONFIG_FILES src/x86/Makefile" ;; "tests/Makefile") CONFIG_FILES="$CONFIG_FILES tests/Makefile" ;; "rfxcodec.pc") CONFIG_FILES="$CONFIG_FILES rfxcodec.pc" ;; "rfxcodec-uninstalled.pc") CONFIG_FILES="$CONFIG_FILES rfxcodec-uninstalled.pc" ;; *) as_fn_error $? "invalid argument: \`$ac_config_target'" "$LINENO" 5;; esac done # If the user did not use the arguments to specify the items to instantiate, # then the envvar interface is used. Set only those that are not. # We use the long form for the default assignment because of an extremely # bizarre bug on SunOS 4.1.3. if $ac_need_defaults; then test "${CONFIG_FILES+set}" = set || CONFIG_FILES=$config_files test "${CONFIG_HEADERS+set}" = set || CONFIG_HEADERS=$config_headers test "${CONFIG_COMMANDS+set}" = set || CONFIG_COMMANDS=$config_commands fi # Have a temporary directory for convenience. Make it in the build tree # simply because there is no reason against having it here, and in addition, # creating and moving files from /tmp can sometimes cause problems. # Hook for its removal unless debugging. # Note that there is a small window in which the directory will not be cleaned: # after its creation but before its name has been assigned to `$tmp'. $debug || { tmp= ac_tmp= trap 'exit_status=$? : "${ac_tmp:=$tmp}" { test ! -d "$ac_tmp" || rm -fr "$ac_tmp"; } && exit $exit_status ' 0 trap 'as_fn_exit 1' 1 2 13 15 } # Create a (secure) tmp directory for tmp files. { tmp=`(umask 077 && mktemp -d "./confXXXXXX") 2>/dev/null` && test -d "$tmp" } || { tmp=./conf$$-$RANDOM (umask 077 && mkdir "$tmp") } || as_fn_error $? "cannot create a temporary directory in ." "$LINENO" 5 ac_tmp=$tmp # Set up the scripts for CONFIG_FILES section. # No need to generate them if there are no CONFIG_FILES. # This happens for instance with `./config.status config.h'. if test -n "$CONFIG_FILES"; then ac_cr=`echo X | tr X '\015'` # On cygwin, bash can eat \r inside `` if the user requested igncr. # But we know of no other shell where ac_cr would be empty at this # point, so we can use a bashism as a fallback. if test "x$ac_cr" = x; then eval ac_cr=\$\'\\r\' fi ac_cs_awk_cr=`$AWK 'BEGIN { print "a\rb" }' /dev/null` if test "$ac_cs_awk_cr" = "a${ac_cr}b"; then ac_cs_awk_cr='\\r' else ac_cs_awk_cr=$ac_cr fi echo 'BEGIN {' >"$ac_tmp/subs1.awk" && _ACEOF { echo "cat >conf$$subs.awk <<_ACEOF" && echo "$ac_subst_vars" | sed 's/.*/&!$&$ac_delim/' && echo "_ACEOF" } >conf$$subs.sh || as_fn_error $? "could not make $CONFIG_STATUS" "$LINENO" 5 ac_delim_num=`echo "$ac_subst_vars" | grep -c '^'` ac_delim='%!_!# ' for ac_last_try in false false false false false :; do . ./conf$$subs.sh || as_fn_error $? "could not make $CONFIG_STATUS" "$LINENO" 5 ac_delim_n=`sed -n "s/.*$ac_delim\$/X/p" conf$$subs.awk | grep -c X` if test $ac_delim_n = $ac_delim_num; then break elif $ac_last_try; then as_fn_error $? "could not make $CONFIG_STATUS" "$LINENO" 5 else ac_delim="$ac_delim!$ac_delim _$ac_delim!! " fi done rm -f conf$$subs.sh cat >>$CONFIG_STATUS <<_ACEOF || ac_write_fail=1 cat >>"\$ac_tmp/subs1.awk" <<\\_ACAWK && _ACEOF sed -n ' h s/^/S["/; s/!.*/"]=/ p g s/^[^!]*!// :repl t repl s/'"$ac_delim"'$// t delim :nl h s/\(.\{148\}\)..*/\1/ t more1 s/["\\]/\\&/g; s/^/"/; s/$/\\n"\\/ p n b repl :more1 s/["\\]/\\&/g; s/^/"/; s/$/"\\/ p g s/.\{148\}// t nl :delim h s/\(.\{148\}\)..*/\1/ t more2 s/["\\]/\\&/g; s/^/"/; s/$/"/ p b :more2 s/["\\]/\\&/g; s/^/"/; s/$/"\\/ p g s/.\{148\}// t delim ' >$CONFIG_STATUS || ac_write_fail=1 rm -f conf$$subs.awk cat >>$CONFIG_STATUS <<_ACEOF || ac_write_fail=1 _ACAWK cat >>"\$ac_tmp/subs1.awk" <<_ACAWK && for (key in S) S_is_set[key] = 1 FS = "" } { line = $ 0 nfields = split(line, field, "@") substed = 0 len = length(field[1]) for (i = 2; i < nfields; i++) { key = field[i] keylen = length(key) if (S_is_set[key]) { value = S[key] line = substr(line, 1, len) "" value "" substr(line, len + keylen + 3) len += length(value) + length(field[++i]) substed = 1 } else len += 1 + keylen } print line } _ACAWK _ACEOF cat >>$CONFIG_STATUS <<\_ACEOF || ac_write_fail=1 if sed "s/$ac_cr//" < /dev/null > /dev/null 2>&1; then sed "s/$ac_cr\$//; s/$ac_cr/$ac_cs_awk_cr/g" else cat fi < "$ac_tmp/subs1.awk" > "$ac_tmp/subs.awk" \ || as_fn_error $? "could not setup config files machinery" "$LINENO" 5 _ACEOF # VPATH may cause trouble with some makes, so we remove sole $(srcdir), # ${srcdir} and @srcdir@ entries from VPATH if srcdir is ".", strip leading and # trailing colons and then remove the whole line if VPATH becomes empty # (actually we leave an empty line to preserve line numbers). if test "x$srcdir" = x.; then ac_vpsub='/^[ ]*VPATH[ ]*=[ ]*/{ h s/// s/^/:/ s/[ ]*$/:/ s/:\$(srcdir):/:/g s/:\${srcdir}:/:/g s/:@srcdir@:/:/g s/^:*// s/:*$// x s/\(=[ ]*\).*/\1/ G s/\n// s/^[^=]*=[ ]*$// }' fi cat >>$CONFIG_STATUS <<\_ACEOF || ac_write_fail=1 fi # test -n "$CONFIG_FILES" # Set up the scripts for CONFIG_HEADERS section. # No need to generate them if there are no CONFIG_HEADERS. # This happens for instance with `./config.status Makefile'. if test -n "$CONFIG_HEADERS"; then cat >"$ac_tmp/defines.awk" <<\_ACAWK || BEGIN { _ACEOF # Transform confdefs.h into an awk script `defines.awk', embedded as # here-document in config.status, that substitutes the proper values into # config.h.in to produce config.h. # Create a delimiter string that does not exist in confdefs.h, to ease # handling of long lines. ac_delim='%!_!# ' for ac_last_try in false false :; do ac_tt=`sed -n "/$ac_delim/p" confdefs.h` if test -z "$ac_tt"; then break elif $ac_last_try; then as_fn_error $? "could not make $CONFIG_HEADERS" "$LINENO" 5 else ac_delim="$ac_delim!$ac_delim _$ac_delim!! " fi done # For the awk script, D is an array of macro values keyed by name, # likewise P contains macro parameters if any. Preserve backslash # newline sequences. ac_word_re=[_$as_cr_Letters][_$as_cr_alnum]* sed -n ' s/.\{148\}/&'"$ac_delim"'/g t rset :rset s/^[ ]*#[ ]*define[ ][ ]*/ / t def d :def s/\\$// t bsnl s/["\\]/\\&/g s/^ \('"$ac_word_re"'\)\(([^()]*)\)[ ]*\(.*\)/P["\1"]="\2"\ D["\1"]=" \3"/p s/^ \('"$ac_word_re"'\)[ ]*\(.*\)/D["\1"]=" \2"/p d :bsnl s/["\\]/\\&/g s/^ \('"$ac_word_re"'\)\(([^()]*)\)[ ]*\(.*\)/P["\1"]="\2"\ D["\1"]=" \3\\\\\\n"\\/p t cont s/^ \('"$ac_word_re"'\)[ ]*\(.*\)/D["\1"]=" \2\\\\\\n"\\/p t cont d :cont n s/.\{148\}/&'"$ac_delim"'/g t clear :clear s/\\$// t bsnlc s/["\\]/\\&/g; s/^/"/; s/$/"/p d :bsnlc s/["\\]/\\&/g; s/^/"/; s/$/\\\\\\n"\\/p b cont ' >$CONFIG_STATUS || ac_write_fail=1 cat >>$CONFIG_STATUS <<_ACEOF || ac_write_fail=1 for (key in D) D_is_set[key] = 1 FS = "" } /^[\t ]*#[\t ]*(define|undef)[\t ]+$ac_word_re([\t (]|\$)/ { line = \$ 0 split(line, arg, " ") if (arg[1] == "#") { defundef = arg[2] mac1 = arg[3] } else { defundef = substr(arg[1], 2) mac1 = arg[2] } split(mac1, mac2, "(") #) macro = mac2[1] prefix = substr(line, 1, index(line, defundef) - 1) if (D_is_set[macro]) { # Preserve the white space surrounding the "#". print prefix "define", macro P[macro] D[macro] next } else { # Replace #undef with comments. This is necessary, for example, # in the case of _POSIX_SOURCE, which is predefined and required # on some systems where configure will not decide to define it. if (defundef == "undef") { print "/*", prefix defundef, macro, "*/" next } } } { print } _ACAWK _ACEOF cat >>$CONFIG_STATUS <<\_ACEOF || ac_write_fail=1 as_fn_error $? "could not setup config headers machinery" "$LINENO" 5 fi # test -n "$CONFIG_HEADERS" eval set X " :F $CONFIG_FILES :H $CONFIG_HEADERS :C $CONFIG_COMMANDS" shift for ac_tag do case $ac_tag in :[FHLC]) ac_mode=$ac_tag; continue;; esac case $ac_mode$ac_tag in :[FHL]*:*);; :L* | :C*:*) as_fn_error $? "invalid tag \`$ac_tag'" "$LINENO" 5;; :[FH]-) ac_tag=-:-;; :[FH]*) ac_tag=$ac_tag:$ac_tag.in;; esac ac_save_IFS=$IFS IFS=: set x $ac_tag IFS=$ac_save_IFS shift ac_file=$1 shift case $ac_mode in :L) ac_source=$1;; :[FH]) ac_file_inputs= for ac_f do case $ac_f in -) ac_f="$ac_tmp/stdin";; *) # Look for the file first in the build tree, then in the source tree # (if the path is not absolute). The absolute path cannot be DOS-style, # because $ac_f cannot contain `:'. test -f "$ac_f" || case $ac_f in [\\/$]*) false;; *) test -f "$srcdir/$ac_f" && ac_f="$srcdir/$ac_f";; esac || as_fn_error 1 "cannot find input file: \`$ac_f'" "$LINENO" 5;; esac case $ac_f in *\'*) ac_f=`$as_echo "$ac_f" | sed "s/'/'\\\\\\\\''/g"`;; esac as_fn_append ac_file_inputs " '$ac_f'" done # Let's still pretend it is `configure' which instantiates (i.e., don't # use $as_me), people would be surprised to read: # /* config.h. Generated by config.status. */ configure_input='Generated from '` $as_echo "$*" | sed 's|^[^:]*/||;s|:[^:]*/|, |g' `' by configure.' if test x"$ac_file" != x-; then configure_input="$ac_file. $configure_input" { $as_echo "$as_me:${as_lineno-$LINENO}: creating $ac_file" >&5 $as_echo "$as_me: creating $ac_file" >&6;} fi # Neutralize special characters interpreted by sed in replacement strings. case $configure_input in #( *\&* | *\|* | *\\* ) ac_sed_conf_input=`$as_echo "$configure_input" | sed 's/[\\\\&|]/\\\\&/g'`;; #( *) ac_sed_conf_input=$configure_input;; esac case $ac_tag in *:-:* | *:-) cat >"$ac_tmp/stdin" \ || as_fn_error $? "could not create $ac_file" "$LINENO" 5 ;; esac ;; esac ac_dir=`$as_dirname -- "$ac_file" || $as_expr X"$ac_file" : 'X\(.*[^/]\)//*[^/][^/]*/*$' \| \ X"$ac_file" : 'X\(//\)[^/]' \| \ X"$ac_file" : 'X\(//\)$' \| \ X"$ac_file" : 'X\(/\)' \| . 2>/dev/null || $as_echo X"$ac_file" | sed '/^X\(.*[^/]\)\/\/*[^/][^/]*\/*$/{ s//\1/ q } /^X\(\/\/\)[^/].*/{ s//\1/ q } /^X\(\/\/\)$/{ s//\1/ q } /^X\(\/\).*/{ s//\1/ q } s/.*/./; q'` as_dir="$ac_dir"; as_fn_mkdir_p ac_builddir=. case "$ac_dir" in .) ac_dir_suffix= ac_top_builddir_sub=. ac_top_build_prefix= ;; *) ac_dir_suffix=/`$as_echo "$ac_dir" | sed 's|^\.[\\/]||'` # A ".." for each directory in $ac_dir_suffix. ac_top_builddir_sub=`$as_echo "$ac_dir_suffix" | sed 's|/[^\\/]*|/..|g;s|/||'` case $ac_top_builddir_sub in "") ac_top_builddir_sub=. ac_top_build_prefix= ;; *) ac_top_build_prefix=$ac_top_builddir_sub/ ;; esac ;; esac ac_abs_top_builddir=$ac_pwd ac_abs_builddir=$ac_pwd$ac_dir_suffix # for backward compatibility: ac_top_builddir=$ac_top_build_prefix case $srcdir in .) # We are building in place. ac_srcdir=. ac_top_srcdir=$ac_top_builddir_sub ac_abs_top_srcdir=$ac_pwd ;; [\\/]* | ?:[\\/]* ) # Absolute name. ac_srcdir=$srcdir$ac_dir_suffix; ac_top_srcdir=$srcdir ac_abs_top_srcdir=$srcdir ;; *) # Relative name. ac_srcdir=$ac_top_build_prefix$srcdir$ac_dir_suffix ac_top_srcdir=$ac_top_build_prefix$srcdir ac_abs_top_srcdir=$ac_pwd/$srcdir ;; esac ac_abs_srcdir=$ac_abs_top_srcdir$ac_dir_suffix case $ac_mode in :F) # # CONFIG_FILE # case $INSTALL in [\\/$]* | ?:[\\/]* ) ac_INSTALL=$INSTALL ;; *) ac_INSTALL=$ac_top_build_prefix$INSTALL ;; esac ac_MKDIR_P=$MKDIR_P case $MKDIR_P in [\\/$]* | ?:[\\/]* ) ;; */*) ac_MKDIR_P=$ac_top_build_prefix$MKDIR_P ;; esac _ACEOF cat >>$CONFIG_STATUS <<\_ACEOF || ac_write_fail=1 # If the template does not know about datarootdir, expand it. # FIXME: This hack should be removed a few years after 2.60. ac_datarootdir_hack=; ac_datarootdir_seen= ac_sed_dataroot=' /datarootdir/ { p q } /@datadir@/p /@docdir@/p /@infodir@/p /@localedir@/p /@mandir@/p' case `eval "sed -n \"\$ac_sed_dataroot\" $ac_file_inputs"` in *datarootdir*) ac_datarootdir_seen=yes;; *@datadir@*|*@docdir@*|*@infodir@*|*@localedir@*|*@mandir@*) { $as_echo "$as_me:${as_lineno-$LINENO}: WARNING: $ac_file_inputs seems to ignore the --datarootdir setting" >&5 $as_echo "$as_me: WARNING: $ac_file_inputs seems to ignore the --datarootdir setting" >&2;} _ACEOF cat >>$CONFIG_STATUS <<_ACEOF || ac_write_fail=1 ac_datarootdir_hack=' s&@datadir@&$datadir&g s&@docdir@&$docdir&g s&@infodir@&$infodir&g s&@localedir@&$localedir&g s&@mandir@&$mandir&g s&\\\${datarootdir}&$datarootdir&g' ;; esac _ACEOF # Neutralize VPATH when `$srcdir' = `.'. # Shell code in configure.ac might set extrasub. # FIXME: do we really want to maintain this feature? cat >>$CONFIG_STATUS <<_ACEOF || ac_write_fail=1 ac_sed_extra="$ac_vpsub $extrasub _ACEOF cat >>$CONFIG_STATUS <<\_ACEOF || ac_write_fail=1 :t /@[a-zA-Z_][a-zA-Z_0-9]*@/!b s|@configure_input@|$ac_sed_conf_input|;t t s&@top_builddir@&$ac_top_builddir_sub&;t t s&@top_build_prefix@&$ac_top_build_prefix&;t t s&@srcdir@&$ac_srcdir&;t t s&@abs_srcdir@&$ac_abs_srcdir&;t t s&@top_srcdir@&$ac_top_srcdir&;t t s&@abs_top_srcdir@&$ac_abs_top_srcdir&;t t s&@builddir@&$ac_builddir&;t t s&@abs_builddir@&$ac_abs_builddir&;t t s&@abs_top_builddir@&$ac_abs_top_builddir&;t t s&@INSTALL@&$ac_INSTALL&;t t s&@MKDIR_P@&$ac_MKDIR_P&;t t $ac_datarootdir_hack " eval sed \"\$ac_sed_extra\" "$ac_file_inputs" | $AWK -f "$ac_tmp/subs.awk" \ >$ac_tmp/out || as_fn_error $? "could not create $ac_file" "$LINENO" 5 test -z "$ac_datarootdir_hack$ac_datarootdir_seen" && { ac_out=`sed -n '/\${datarootdir}/p' "$ac_tmp/out"`; test -n "$ac_out"; } && { ac_out=`sed -n '/^[ ]*datarootdir[ ]*:*=/p' \ "$ac_tmp/out"`; test -z "$ac_out"; } && { $as_echo "$as_me:${as_lineno-$LINENO}: WARNING: $ac_file contains a reference to the variable \`datarootdir' which seems to be undefined. Please make sure it is defined" >&5 $as_echo "$as_me: WARNING: $ac_file contains a reference to the variable \`datarootdir' which seems to be undefined. Please make sure it is defined" >&2;} rm -f "$ac_tmp/stdin" case $ac_file in -) cat "$ac_tmp/out" && rm -f "$ac_tmp/out";; *) rm -f "$ac_file" && mv "$ac_tmp/out" "$ac_file";; esac \ || as_fn_error $? "could not create $ac_file" "$LINENO" 5 ;; :H) # # CONFIG_HEADER # if test x"$ac_file" != x-; then { $as_echo "/* $configure_input */" \ && eval '$AWK -f "$ac_tmp/defines.awk"' "$ac_file_inputs" } >"$ac_tmp/config.h" \ || as_fn_error $? "could not create $ac_file" "$LINENO" 5 if diff "$ac_file" "$ac_tmp/config.h" >/dev/null 2>&1; then { $as_echo "$as_me:${as_lineno-$LINENO}: $ac_file is unchanged" >&5 $as_echo "$as_me: $ac_file is unchanged" >&6;} else rm -f "$ac_file" mv "$ac_tmp/config.h" "$ac_file" \ || as_fn_error $? "could not create $ac_file" "$LINENO" 5 fi else $as_echo "/* $configure_input */" \ && eval '$AWK -f "$ac_tmp/defines.awk"' "$ac_file_inputs" \ || as_fn_error $? "could not create -" "$LINENO" 5 fi # Compute "$ac_file"'s index in $config_headers. _am_arg="$ac_file" _am_stamp_count=1 for _am_header in $config_headers :; do case $_am_header in $_am_arg | $_am_arg:* ) break ;; * ) _am_stamp_count=`expr $_am_stamp_count + 1` ;; esac done echo "timestamp for $_am_arg" >`$as_dirname -- "$_am_arg" || $as_expr X"$_am_arg" : 'X\(.*[^/]\)//*[^/][^/]*/*$' \| \ X"$_am_arg" : 'X\(//\)[^/]' \| \ X"$_am_arg" : 'X\(//\)$' \| \ X"$_am_arg" : 'X\(/\)' \| . 2>/dev/null || $as_echo X"$_am_arg" | sed '/^X\(.*[^/]\)\/\/*[^/][^/]*\/*$/{ s//\1/ q } /^X\(\/\/\)[^/].*/{ s//\1/ q } /^X\(\/\/\)$/{ s//\1/ q } /^X\(\/\).*/{ s//\1/ q } s/.*/./; q'`/stamp-h$_am_stamp_count ;; :C) { $as_echo "$as_me:${as_lineno-$LINENO}: executing $ac_file commands" >&5 $as_echo "$as_me: executing $ac_file commands" >&6;} ;; esac case $ac_file$ac_mode in "depfiles":C) test x"$AMDEP_TRUE" != x"" || { # Older Autoconf quotes --file arguments for eval, but not when files # are listed without --file. Let's play safe and only enable the eval # if we detect the quoting. case $CONFIG_FILES in *\'*) eval set x "$CONFIG_FILES" ;; *) set x $CONFIG_FILES ;; esac shift for mf do # Strip MF so we end up with the name of the file. mf=`echo "$mf" | sed -e 's/:.*$//'` # Check whether this is an Automake generated Makefile or not. # We used to match only the files named 'Makefile.in', but # some people rename them; so instead we look at the file content. # Grep'ing the first line is not enough: some people post-process # each Makefile.in and add a new line on top of each file to say so. # Grep'ing the whole file is not good either: AIX grep has a line # limit of 2048, but all sed's we know have understand at least 4000. if sed -n 's,^#.*generated by automake.*,X,p' "$mf" | grep X >/dev/null 2>&1; then dirpart=`$as_dirname -- "$mf" || $as_expr X"$mf" : 'X\(.*[^/]\)//*[^/][^/]*/*$' \| \ X"$mf" : 'X\(//\)[^/]' \| \ X"$mf" : 'X\(//\)$' \| \ X"$mf" : 'X\(/\)' \| . 2>/dev/null || $as_echo X"$mf" | sed '/^X\(.*[^/]\)\/\/*[^/][^/]*\/*$/{ s//\1/ q } /^X\(\/\/\)[^/].*/{ s//\1/ q } /^X\(\/\/\)$/{ s//\1/ q } /^X\(\/\).*/{ s//\1/ q } s/.*/./; q'` else continue fi # Extract the definition of DEPDIR, am__include, and am__quote # from the Makefile without running 'make'. DEPDIR=`sed -n 's/^DEPDIR = //p' < "$mf"` test -z "$DEPDIR" && continue am__include=`sed -n 's/^am__include = //p' < "$mf"` test -z "$am__include" && continue am__quote=`sed -n 's/^am__quote = //p' < "$mf"` # Find all dependency output files, they are included files with # $(DEPDIR) in their names. We invoke sed twice because it is the # simplest approach to changing $(DEPDIR) to its actual value in the # expansion. for file in `sed -n " s/^$am__include $am__quote\(.*(DEPDIR).*\)$am__quote"'$/\1/p' <"$mf" | \ sed -e 's/\$(DEPDIR)/'"$DEPDIR"'/g'`; do # Make sure the directory exists. test -f "$dirpart/$file" && continue fdir=`$as_dirname -- "$file" || $as_expr X"$file" : 'X\(.*[^/]\)//*[^/][^/]*/*$' \| \ X"$file" : 'X\(//\)[^/]' \| \ X"$file" : 'X\(//\)$' \| \ X"$file" : 'X\(/\)' \| . 2>/dev/null || $as_echo X"$file" | sed '/^X\(.*[^/]\)\/\/*[^/][^/]*\/*$/{ s//\1/ q } /^X\(\/\/\)[^/].*/{ s//\1/ q } /^X\(\/\/\)$/{ s//\1/ q } /^X\(\/\).*/{ s//\1/ q } s/.*/./; q'` as_dir=$dirpart/$fdir; as_fn_mkdir_p # echo "creating $dirpart/$file" echo '# dummy' > "$dirpart/$file" done done } ;; "libtool":C) # See if we are running on zsh, and set the options that allow our # commands through without removal of \ escapes. if test -n "${ZSH_VERSION+set}"; then setopt NO_GLOB_SUBST fi cfgfile=${ofile}T trap "$RM \"$cfgfile\"; exit 1" 1 2 15 $RM "$cfgfile" cat <<_LT_EOF >> "$cfgfile" #! $SHELL # Generated automatically by $as_me ($PACKAGE) $VERSION # Libtool was configured on host `(hostname || uname -n) 2>/dev/null | sed 1q`: # NOTE: Changes made to this file will be lost: look at ltmain.sh. # Provide generalized library-building support services. # Written by Gordon Matzigkeit, 1996 # Copyright (C) 2014 Free Software Foundation, Inc. # This is free software; see the source for copying conditions. There is NO # warranty; not even for MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. # GNU Libtool 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 2 of of the License, or # (at your option) any later version. # # As a special exception to the GNU General Public License, if you # distribute this file as part of a program or library that is built # using GNU Libtool, you may include this file under the same # distribution terms that you use for the rest of that program. # # GNU Libtool 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. # # You should have received a copy of the GNU General Public License # along with this program. If not, see . # The names of the tagged configurations supported by this script. available_tags='' # Configured defaults for sys_lib_dlsearch_path munging. : \${LT_SYS_LIBRARY_PATH="$configure_time_lt_sys_library_path"} # ### BEGIN LIBTOOL CONFIG # Which release of libtool.m4 was used? macro_version=$macro_version macro_revision=$macro_revision # Whether or not to build shared libraries. build_libtool_libs=$enable_shared # Whether or not to build static libraries. build_old_libs=$enable_static # What type of objects to build. pic_mode=$pic_mode # Whether or not to optimize for fast installation. fast_install=$enable_fast_install # Shared archive member basename,for filename based shared library versioning on AIX. shared_archive_member_spec=$shared_archive_member_spec # Shell to use when invoking shell scripts. SHELL=$lt_SHELL # An echo program that protects backslashes. ECHO=$lt_ECHO # The PATH separator for the build system. PATH_SEPARATOR=$lt_PATH_SEPARATOR # The host system. host_alias=$host_alias host=$host host_os=$host_os # The build system. build_alias=$build_alias build=$build build_os=$build_os # A sed program that does not truncate output. SED=$lt_SED # Sed that helps us avoid accidentally triggering echo(1) options like -n. Xsed="\$SED -e 1s/^X//" # A grep program that handles long lines. GREP=$lt_GREP # An ERE matcher. EGREP=$lt_EGREP # A literal string matcher. FGREP=$lt_FGREP # A BSD- or MS-compatible name lister. NM=$lt_NM # Whether we need soft or hard links. LN_S=$lt_LN_S # What is the maximum length of a command? max_cmd_len=$max_cmd_len # Object file suffix (normally "o"). objext=$ac_objext # Executable file suffix (normally ""). exeext=$exeext # whether the shell understands "unset". lt_unset=$lt_unset # turn spaces into newlines. SP2NL=$lt_lt_SP2NL # turn newlines into spaces. NL2SP=$lt_lt_NL2SP # convert \$build file names to \$host format. to_host_file_cmd=$lt_cv_to_host_file_cmd # convert \$build files to toolchain format. to_tool_file_cmd=$lt_cv_to_tool_file_cmd # An object symbol dumper. OBJDUMP=$lt_OBJDUMP # Method to check whether dependent libraries are shared objects. deplibs_check_method=$lt_deplibs_check_method # Command to use when deplibs_check_method = "file_magic". file_magic_cmd=$lt_file_magic_cmd # How to find potential files when deplibs_check_method = "file_magic". file_magic_glob=$lt_file_magic_glob # Find potential files using nocaseglob when deplibs_check_method = "file_magic". want_nocaseglob=$lt_want_nocaseglob # DLL creation program. DLLTOOL=$lt_DLLTOOL # Command to associate shared and link libraries. sharedlib_from_linklib_cmd=$lt_sharedlib_from_linklib_cmd # The archiver. AR=$lt_AR # Flags to create an archive. AR_FLAGS=$lt_AR_FLAGS # How to feed a file listing to the archiver. archiver_list_spec=$lt_archiver_list_spec # A symbol stripping program. STRIP=$lt_STRIP # Commands used to install an old-style archive. RANLIB=$lt_RANLIB old_postinstall_cmds=$lt_old_postinstall_cmds old_postuninstall_cmds=$lt_old_postuninstall_cmds # Whether to use a lock for old archive extraction. lock_old_archive_extraction=$lock_old_archive_extraction # A C compiler. LTCC=$lt_CC # LTCC compiler flags. LTCFLAGS=$lt_CFLAGS # Take the output of nm and produce a listing of raw symbols and C names. global_symbol_pipe=$lt_lt_cv_sys_global_symbol_pipe # Transform the output of nm in a proper C declaration. global_symbol_to_cdecl=$lt_lt_cv_sys_global_symbol_to_cdecl # Transform the output of nm into a list of symbols to manually relocate. global_symbol_to_import=$lt_lt_cv_sys_global_symbol_to_import # Transform the output of nm in a C name address pair. global_symbol_to_c_name_address=$lt_lt_cv_sys_global_symbol_to_c_name_address # Transform the output of nm in a C name address pair when lib prefix is needed. global_symbol_to_c_name_address_lib_prefix=$lt_lt_cv_sys_global_symbol_to_c_name_address_lib_prefix # The name lister interface. nm_interface=$lt_lt_cv_nm_interface # Specify filename containing input files for \$NM. nm_file_list_spec=$lt_nm_file_list_spec # The root where to search for dependent libraries,and where our libraries should be installed. lt_sysroot=$lt_sysroot # Command to truncate a binary pipe. lt_truncate_bin=$lt_lt_cv_truncate_bin # The name of the directory that contains temporary libtool files. objdir=$objdir # Used to examine libraries when file_magic_cmd begins with "file". MAGIC_CMD=$MAGIC_CMD # Must we lock files when doing compilation? need_locks=$lt_need_locks # Manifest tool. MANIFEST_TOOL=$lt_MANIFEST_TOOL # Tool to manipulate archived DWARF debug symbol files on Mac OS X. DSYMUTIL=$lt_DSYMUTIL # Tool to change global to local symbols on Mac OS X. NMEDIT=$lt_NMEDIT # Tool to manipulate fat objects and archives on Mac OS X. LIPO=$lt_LIPO # ldd/readelf like tool for Mach-O binaries on Mac OS X. OTOOL=$lt_OTOOL # ldd/readelf like tool for 64 bit Mach-O binaries on Mac OS X 10.4. OTOOL64=$lt_OTOOL64 # Old archive suffix (normally "a"). libext=$libext # Shared library suffix (normally ".so"). shrext_cmds=$lt_shrext_cmds # The commands to extract the exported symbol list from a shared archive. extract_expsyms_cmds=$lt_extract_expsyms_cmds # Variables whose values should be saved in libtool wrapper scripts and # restored at link time. variables_saved_for_relink=$lt_variables_saved_for_relink # Do we need the "lib" prefix for modules? need_lib_prefix=$need_lib_prefix # Do we need a version for libraries? need_version=$need_version # Library versioning type. version_type=$version_type # Shared library runtime path variable. runpath_var=$runpath_var # Shared library path variable. shlibpath_var=$shlibpath_var # Is shlibpath searched before the hard-coded library search path? shlibpath_overrides_runpath=$shlibpath_overrides_runpath # Format of library name prefix. libname_spec=$lt_libname_spec # List of archive names. First name is the real one, the rest are links. # The last name is the one that the linker finds with -lNAME library_names_spec=$lt_library_names_spec # The coded name of the library, if different from the real name. soname_spec=$lt_soname_spec # Permission mode override for installation of shared libraries. install_override_mode=$lt_install_override_mode # Command to use after installation of a shared archive. postinstall_cmds=$lt_postinstall_cmds # Command to use after uninstallation of a shared archive. postuninstall_cmds=$lt_postuninstall_cmds # Commands used to finish a libtool library installation in a directory. finish_cmds=$lt_finish_cmds # As "finish_cmds", except a single script fragment to be evaled but # not shown. finish_eval=$lt_finish_eval # Whether we should hardcode library paths into libraries. hardcode_into_libs=$hardcode_into_libs # Compile-time system search path for libraries. sys_lib_search_path_spec=$lt_sys_lib_search_path_spec # Detected run-time system search path for libraries. sys_lib_dlsearch_path_spec=$lt_configure_time_dlsearch_path # Explicit LT_SYS_LIBRARY_PATH set during ./configure time. configure_time_lt_sys_library_path=$lt_configure_time_lt_sys_library_path # Whether dlopen is supported. dlopen_support=$enable_dlopen # Whether dlopen of programs is supported. dlopen_self=$enable_dlopen_self # Whether dlopen of statically linked programs is supported. dlopen_self_static=$enable_dlopen_self_static # Commands to strip libraries. old_striplib=$lt_old_striplib striplib=$lt_striplib # The linker used to build libraries. LD=$lt_LD # How to create reloadable object files. reload_flag=$lt_reload_flag reload_cmds=$lt_reload_cmds # Commands used to build an old-style archive. old_archive_cmds=$lt_old_archive_cmds # A language specific compiler. CC=$lt_compiler # Is the compiler the GNU compiler? with_gcc=$GCC # Compiler flag to turn off builtin functions. no_builtin_flag=$lt_lt_prog_compiler_no_builtin_flag # Additional compiler flags for building library objects. pic_flag=$lt_lt_prog_compiler_pic # How to pass a linker flag through the compiler. wl=$lt_lt_prog_compiler_wl # Compiler flag to prevent dynamic linking. link_static_flag=$lt_lt_prog_compiler_static # Does compiler simultaneously support -c and -o options? compiler_c_o=$lt_lt_cv_prog_compiler_c_o # Whether or not to add -lc for building shared libraries. build_libtool_need_lc=$archive_cmds_need_lc # Whether or not to disallow shared libs when runtime libs are static. allow_libtool_libs_with_static_runtimes=$enable_shared_with_static_runtimes # Compiler flag to allow reflexive dlopens. export_dynamic_flag_spec=$lt_export_dynamic_flag_spec # Compiler flag to generate shared objects directly from archives. whole_archive_flag_spec=$lt_whole_archive_flag_spec # Whether the compiler copes with passing no objects directly. compiler_needs_object=$lt_compiler_needs_object # Create an old-style archive from a shared archive. old_archive_from_new_cmds=$lt_old_archive_from_new_cmds # Create a temporary old-style archive to link instead of a shared archive. old_archive_from_expsyms_cmds=$lt_old_archive_from_expsyms_cmds # Commands used to build a shared archive. archive_cmds=$lt_archive_cmds archive_expsym_cmds=$lt_archive_expsym_cmds # Commands used to build a loadable module if different from building # a shared archive. module_cmds=$lt_module_cmds module_expsym_cmds=$lt_module_expsym_cmds # Whether we are building with GNU ld or not. with_gnu_ld=$lt_with_gnu_ld # Flag that allows shared libraries with undefined symbols to be built. allow_undefined_flag=$lt_allow_undefined_flag # Flag that enforces no undefined symbols. no_undefined_flag=$lt_no_undefined_flag # Flag to hardcode \$libdir into a binary during linking. # This must work even if \$libdir does not exist hardcode_libdir_flag_spec=$lt_hardcode_libdir_flag_spec # Whether we need a single "-rpath" flag with a separated argument. hardcode_libdir_separator=$lt_hardcode_libdir_separator # Set to "yes" if using DIR/libNAME\$shared_ext during linking hardcodes # DIR into the resulting binary. hardcode_direct=$hardcode_direct # Set to "yes" if using DIR/libNAME\$shared_ext during linking hardcodes # DIR into the resulting binary and the resulting library dependency is # "absolute",i.e impossible to change by setting \$shlibpath_var if the # library is relocated. hardcode_direct_absolute=$hardcode_direct_absolute # Set to "yes" if using the -LDIR flag during linking hardcodes DIR # into the resulting binary. hardcode_minus_L=$hardcode_minus_L # Set to "yes" if using SHLIBPATH_VAR=DIR during linking hardcodes DIR # into the resulting binary. hardcode_shlibpath_var=$hardcode_shlibpath_var # Set to "yes" if building a shared library automatically hardcodes DIR # into the library and all subsequent libraries and executables linked # against it. hardcode_automatic=$hardcode_automatic # Set to yes if linker adds runtime paths of dependent libraries # to runtime path list. inherit_rpath=$inherit_rpath # Whether libtool must link a program against all its dependency libraries. link_all_deplibs=$link_all_deplibs # Set to "yes" if exported symbols are required. always_export_symbols=$always_export_symbols # The commands to list exported symbols. export_symbols_cmds=$lt_export_symbols_cmds # Symbols that should not be listed in the preloaded symbols. exclude_expsyms=$lt_exclude_expsyms # Symbols that must always be exported. include_expsyms=$lt_include_expsyms # Commands necessary for linking programs (against libraries) with templates. prelink_cmds=$lt_prelink_cmds # Commands necessary for finishing linking programs. postlink_cmds=$lt_postlink_cmds # Specify filename containing input files. file_list_spec=$lt_file_list_spec # How to hardcode a shared library path into an executable. hardcode_action=$hardcode_action # ### END LIBTOOL CONFIG _LT_EOF cat <<'_LT_EOF' >> "$cfgfile" # ### BEGIN FUNCTIONS SHARED WITH CONFIGURE # func_munge_path_list VARIABLE PATH # ----------------------------------- # VARIABLE is name of variable containing _space_ separated list of # directories to be munged by the contents of PATH, which is string # having a format: # "DIR[:DIR]:" # string "DIR[ DIR]" will be prepended to VARIABLE # ":DIR[:DIR]" # string "DIR[ DIR]" will be appended to VARIABLE # "DIRP[:DIRP]::[DIRA:]DIRA" # string "DIRP[ DIRP]" will be prepended to VARIABLE and string # "DIRA[ DIRA]" will be appended to VARIABLE # "DIR[:DIR]" # VARIABLE will be replaced by "DIR[ DIR]" func_munge_path_list () { case x$2 in x) ;; *:) eval $1=\"`$ECHO $2 | $SED 's/:/ /g'` \$$1\" ;; x:*) eval $1=\"\$$1 `$ECHO $2 | $SED 's/:/ /g'`\" ;; *::*) eval $1=\"\$$1\ `$ECHO $2 | $SED -e 's/.*:://' -e 's/:/ /g'`\" eval $1=\"`$ECHO $2 | $SED -e 's/::.*//' -e 's/:/ /g'`\ \$$1\" ;; *) eval $1=\"`$ECHO $2 | $SED 's/:/ /g'`\" ;; esac } # Calculate cc_basename. Skip known compiler wrappers and cross-prefix. func_cc_basename () { for cc_temp in $*""; do case $cc_temp in compile | *[\\/]compile | ccache | *[\\/]ccache ) ;; distcc | *[\\/]distcc | purify | *[\\/]purify ) ;; \-*) ;; *) break;; esac done func_cc_basename_result=`$ECHO "$cc_temp" | $SED "s%.*/%%; s%^$host_alias-%%"` } # ### END FUNCTIONS SHARED WITH CONFIGURE _LT_EOF case $host_os in aix3*) cat <<\_LT_EOF >> "$cfgfile" # AIX sometimes has problems with the GCC collect2 program. For some # reason, if we set the COLLECT_NAMES environment variable, the problems # vanish in a puff of smoke. if test set != "${COLLECT_NAMES+set}"; then COLLECT_NAMES= export COLLECT_NAMES fi _LT_EOF ;; esac ltmain=$ac_aux_dir/ltmain.sh # We use sed instead of cat because bash on DJGPP gets confused if # if finds mixed CR/LF and LF-only lines. Since sed operates in # text mode, it properly converts lines to CR/LF. This bash problem # is reportedly fixed, but why not run on old versions too? sed '$q' "$ltmain" >> "$cfgfile" \ || (rm -f "$cfgfile"; exit 1) mv -f "$cfgfile" "$ofile" || (rm -f "$ofile" && cp "$cfgfile" "$ofile" && rm -f "$cfgfile") chmod +x "$ofile" ;; esac done # for ac_tag as_fn_exit 0 _ACEOF ac_clean_files=$ac_clean_files_save test $ac_write_fail = 0 || as_fn_error $? "write failure creating $CONFIG_STATUS" "$LINENO" 5 # configure is writing to config.log, and then calls config.status. # config.status does its own redirection, appending to config.log. # Unfortunately, on DOS this fails, as config.log is still kept open # by configure, so config.status won't be able to write to it; its # output is simply discarded. So we exec the FD to /dev/null, # effectively closing config.log, so it can be properly (re)opened and # appended to by config.status. When coming back to configure, we # need to make the FD available again. if test "$no_create" != yes; then ac_cs_success=: ac_config_status_args= test "$silent" = yes && ac_config_status_args="$ac_config_status_args --quiet" exec 5>/dev/null $SHELL $CONFIG_STATUS $ac_config_status_args || ac_cs_success=false exec 5>>config.log # Use ||, not &&, to avoid exiting from the if with $? = 1, which # would make configure fail if this is the last instruction. $ac_cs_success || as_fn_exit 1 fi if test -n "$ac_unrecognized_opts" && test "$enable_option_checking" != no; then { $as_echo "$as_me:${as_lineno-$LINENO}: WARNING: unrecognized options: $ac_unrecognized_opts" >&5 $as_echo "$as_me: WARNING: unrecognized options: $ac_unrecognized_opts" >&2;} fi xrdp-0.9.5/librfxcodec/missing000755 001751 001751 00000015331 13220730761 016311 0ustar00metameta000000 000000 #! /bin/sh # Common wrapper for a few potentially missing GNU programs. scriptversion=2016-01-11.22; # UTC # Copyright (C) 1996-2017 Free Software Foundation, Inc. # Originally written by Fran,cois Pinard , 1996. # 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 2, 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. # You should have received a copy of the GNU General Public License # along with this program. If not, see . # As a special exception to the GNU General Public License, if you # distribute this file as part of a program that contains a # configuration script generated by Autoconf, you may include it under # the same distribution terms that you use for the rest of that program. if test $# -eq 0; then echo 1>&2 "Try '$0 --help' for more information" exit 1 fi case $1 in --is-lightweight) # Used by our autoconf macros to check whether the available missing # script is modern enough. exit 0 ;; --run) # Back-compat with the calling convention used by older automake. shift ;; -h|--h|--he|--hel|--help) echo "\ $0 [OPTION]... PROGRAM [ARGUMENT]... Run 'PROGRAM [ARGUMENT]...', returning a proper advice when this fails due to PROGRAM being missing or too old. Options: -h, --help display this help and exit -v, --version output version information and exit Supported PROGRAM values: aclocal autoconf autoheader autom4te automake makeinfo bison yacc flex lex help2man Version suffixes to PROGRAM as well as the prefixes 'gnu-', 'gnu', and 'g' are ignored when checking the name. Send bug reports to ." exit $? ;; -v|--v|--ve|--ver|--vers|--versi|--versio|--version) echo "missing $scriptversion (GNU Automake)" exit $? ;; -*) echo 1>&2 "$0: unknown '$1' option" echo 1>&2 "Try '$0 --help' for more information" exit 1 ;; esac # Run the given program, remember its exit status. "$@"; st=$? # If it succeeded, we are done. test $st -eq 0 && exit 0 # Also exit now if we it failed (or wasn't found), and '--version' was # passed; such an option is passed most likely to detect whether the # program is present and works. case $2 in --version|--help) exit $st;; esac # Exit code 63 means version mismatch. This often happens when the user # tries to use an ancient version of a tool on a file that requires a # minimum version. if test $st -eq 63; then msg="probably too old" elif test $st -eq 127; then # Program was missing. msg="missing on your system" else # Program was found and executed, but failed. Give up. exit $st fi perl_URL=http://www.perl.org/ flex_URL=http://flex.sourceforge.net/ gnu_software_URL=http://www.gnu.org/software program_details () { case $1 in aclocal|automake) echo "The '$1' program is part of the GNU Automake package:" echo "<$gnu_software_URL/automake>" echo "It also requires GNU Autoconf, GNU m4 and Perl in order to run:" echo "<$gnu_software_URL/autoconf>" echo "<$gnu_software_URL/m4/>" echo "<$perl_URL>" ;; autoconf|autom4te|autoheader) echo "The '$1' program is part of the GNU Autoconf package:" echo "<$gnu_software_URL/autoconf/>" echo "It also requires GNU m4 and Perl in order to run:" echo "<$gnu_software_URL/m4/>" echo "<$perl_URL>" ;; esac } give_advice () { # Normalize program name to check for. normalized_program=`echo "$1" | sed ' s/^gnu-//; t s/^gnu//; t s/^g//; t'` printf '%s\n' "'$1' is $msg." configure_deps="'configure.ac' or m4 files included by 'configure.ac'" case $normalized_program in autoconf*) echo "You should only need it if you modified 'configure.ac'," echo "or m4 files included by it." program_details 'autoconf' ;; autoheader*) echo "You should only need it if you modified 'acconfig.h' or" echo "$configure_deps." program_details 'autoheader' ;; automake*) echo "You should only need it if you modified 'Makefile.am' or" echo "$configure_deps." program_details 'automake' ;; aclocal*) echo "You should only need it if you modified 'acinclude.m4' or" echo "$configure_deps." program_details 'aclocal' ;; autom4te*) echo "You might have modified some maintainer files that require" echo "the 'autom4te' program to be rebuilt." program_details 'autom4te' ;; bison*|yacc*) echo "You should only need it if you modified a '.y' file." echo "You may want to install the GNU Bison package:" echo "<$gnu_software_URL/bison/>" ;; lex*|flex*) echo "You should only need it if you modified a '.l' file." echo "You may want to install the Fast Lexical Analyzer package:" echo "<$flex_URL>" ;; help2man*) echo "You should only need it if you modified a dependency" \ "of a man page." echo "You may want to install the GNU Help2man package:" echo "<$gnu_software_URL/help2man/>" ;; makeinfo*) echo "You should only need it if you modified a '.texi' file, or" echo "any other file indirectly affecting the aspect of the manual." echo "You might want to install the Texinfo package:" echo "<$gnu_software_URL/texinfo/>" echo "The spurious makeinfo call might also be the consequence of" echo "using a buggy 'make' (AIX, DU, IRIX), in which case you might" echo "want to install GNU make:" echo "<$gnu_software_URL/make/>" ;; *) echo "You might have modified some files without having the proper" echo "tools for further handling them. Check the 'README' file, it" echo "often tells you about the needed prerequisites for installing" echo "this package. You may also peek at any GNU archive site, in" echo "case some other package contains this missing '$1' program." ;; esac } give_advice "$1" | sed -e '1s/^/WARNING: /' \ -e '2,$s/^/ /' >&2 # Propagate the correct exit status (expected to be 127 for a program # not found, 63 for a program that failed due to version mismatch). exit $st # Local variables: # eval: (add-hook 'write-file-hooks 'time-stamp) # time-stamp-start: "scriptversion=" # time-stamp-format: "%:y-%02m-%02d.%02H" # time-stamp-time-zone: "UTC0" # time-stamp-end: "; # UTC" # End: xrdp-0.9.5/librfxcodec/rfxcodec-uninstalled.pc.in000644 001751 001751 00000000337 13017154341 021756 0ustar00metameta000000 000000 Name: rfxcodec Description: Fast jpeg2000 codec compatible with MS RDP servers and xrdp Version: @PACKAGE_VERSION@ Cflags: -I${pc_top_builddir}/${pcfiledir}/include Libs: ${pc_top_builddir}/${pcfiledir}/src/librfxencode.la xrdp-0.9.5/librfxcodec/depcomp000755 001751 001751 00000056017 13220730761 016275 0ustar00metameta000000 000000 #! /bin/sh # depcomp - compile a program generating dependencies as side-effects scriptversion=2016-01-11.22; # UTC # Copyright (C) 1999-2017 Free Software Foundation, Inc. # 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 2, 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. # You should have received a copy of the GNU General Public License # along with this program. If not, see . # As a special exception to the GNU General Public License, if you # distribute this file as part of a program that contains a # configuration script generated by Autoconf, you may include it under # the same distribution terms that you use for the rest of that program. # Originally written by Alexandre Oliva . case $1 in '') echo "$0: No command. Try '$0 --help' for more information." 1>&2 exit 1; ;; -h | --h*) cat <<\EOF Usage: depcomp [--help] [--version] PROGRAM [ARGS] Run PROGRAMS ARGS to compile a file, generating dependencies as side-effects. Environment variables: depmode Dependency tracking mode. source Source file read by 'PROGRAMS ARGS'. object Object file output by 'PROGRAMS ARGS'. DEPDIR directory where to store dependencies. depfile Dependency file to output. tmpdepfile Temporary file to use when outputting dependencies. libtool Whether libtool is used (yes/no). Report bugs to . EOF exit $? ;; -v | --v*) echo "depcomp $scriptversion" exit $? ;; esac # Get the directory component of the given path, and save it in the # global variables '$dir'. Note that this directory component will # be either empty or ending with a '/' character. This is deliberate. set_dir_from () { case $1 in */*) dir=`echo "$1" | sed -e 's|/[^/]*$|/|'`;; *) dir=;; esac } # Get the suffix-stripped basename of the given path, and save it the # global variable '$base'. set_base_from () { base=`echo "$1" | sed -e 's|^.*/||' -e 's/\.[^.]*$//'` } # If no dependency file was actually created by the compiler invocation, # we still have to create a dummy depfile, to avoid errors with the # Makefile "include basename.Plo" scheme. make_dummy_depfile () { echo "#dummy" > "$depfile" } # Factor out some common post-processing of the generated depfile. # Requires the auxiliary global variable '$tmpdepfile' to be set. aix_post_process_depfile () { # If the compiler actually managed to produce a dependency file, # post-process it. if test -f "$tmpdepfile"; then # Each line is of the form 'foo.o: dependency.h'. # Do two passes, one to just change these to # $object: dependency.h # and one to simply output # dependency.h: # which is needed to avoid the deleted-header problem. { sed -e "s,^.*\.[$lower]*:,$object:," < "$tmpdepfile" sed -e "s,^.*\.[$lower]*:[$tab ]*,," -e 's,$,:,' < "$tmpdepfile" } > "$depfile" rm -f "$tmpdepfile" else make_dummy_depfile fi } # A tabulation character. tab=' ' # A newline character. nl=' ' # Character ranges might be problematic outside the C locale. # These definitions help. upper=ABCDEFGHIJKLMNOPQRSTUVWXYZ lower=abcdefghijklmnopqrstuvwxyz digits=0123456789 alpha=${upper}${lower} if test -z "$depmode" || test -z "$source" || test -z "$object"; then echo "depcomp: Variables source, object and depmode must be set" 1>&2 exit 1 fi # Dependencies for sub/bar.o or sub/bar.obj go into sub/.deps/bar.Po. depfile=${depfile-`echo "$object" | sed 's|[^\\/]*$|'${DEPDIR-.deps}'/&|;s|\.\([^.]*\)$|.P\1|;s|Pobj$|Po|'`} tmpdepfile=${tmpdepfile-`echo "$depfile" | sed 's/\.\([^.]*\)$/.T\1/'`} rm -f "$tmpdepfile" # Avoid interferences from the environment. gccflag= dashmflag= # Some modes work just like other modes, but use different flags. We # parameterize here, but still list the modes in the big case below, # to make depend.m4 easier to write. Note that we *cannot* use a case # here, because this file can only contain one case statement. if test "$depmode" = hp; then # HP compiler uses -M and no extra arg. gccflag=-M depmode=gcc fi if test "$depmode" = dashXmstdout; then # This is just like dashmstdout with a different argument. dashmflag=-xM depmode=dashmstdout fi cygpath_u="cygpath -u -f -" if test "$depmode" = msvcmsys; then # This is just like msvisualcpp but w/o cygpath translation. # Just convert the backslash-escaped backslashes to single forward # slashes to satisfy depend.m4 cygpath_u='sed s,\\\\,/,g' depmode=msvisualcpp fi if test "$depmode" = msvc7msys; then # This is just like msvc7 but w/o cygpath translation. # Just convert the backslash-escaped backslashes to single forward # slashes to satisfy depend.m4 cygpath_u='sed s,\\\\,/,g' depmode=msvc7 fi if test "$depmode" = xlc; then # IBM C/C++ Compilers xlc/xlC can output gcc-like dependency information. gccflag=-qmakedep=gcc,-MF depmode=gcc fi case "$depmode" in gcc3) ## gcc 3 implements dependency tracking that does exactly what ## we want. Yay! Note: for some reason libtool 1.4 doesn't like ## it if -MD -MP comes after the -MF stuff. Hmm. ## Unfortunately, FreeBSD c89 acceptance of flags depends upon ## the command line argument order; so add the flags where they ## appear in depend2.am. Note that the slowdown incurred here ## affects only configure: in makefiles, %FASTDEP% shortcuts this. for arg do case $arg in -c) set fnord "$@" -MT "$object" -MD -MP -MF "$tmpdepfile" "$arg" ;; *) set fnord "$@" "$arg" ;; esac shift # fnord shift # $arg done "$@" stat=$? if test $stat -ne 0; then rm -f "$tmpdepfile" exit $stat fi mv "$tmpdepfile" "$depfile" ;; gcc) ## Note that this doesn't just cater to obsosete pre-3.x GCC compilers. ## but also to in-use compilers like IMB xlc/xlC and the HP C compiler. ## (see the conditional assignment to $gccflag above). ## There are various ways to get dependency output from gcc. Here's ## why we pick this rather obscure method: ## - Don't want to use -MD because we'd like the dependencies to end ## up in a subdir. Having to rename by hand is ugly. ## (We might end up doing this anyway to support other compilers.) ## - The DEPENDENCIES_OUTPUT environment variable makes gcc act like ## -MM, not -M (despite what the docs say). Also, it might not be ## supported by the other compilers which use the 'gcc' depmode. ## - Using -M directly means running the compiler twice (even worse ## than renaming). if test -z "$gccflag"; then gccflag=-MD, fi "$@" -Wp,"$gccflag$tmpdepfile" stat=$? if test $stat -ne 0; then rm -f "$tmpdepfile" exit $stat fi rm -f "$depfile" echo "$object : \\" > "$depfile" # The second -e expression handles DOS-style file names with drive # letters. sed -e 's/^[^:]*: / /' \ -e 's/^['$alpha']:\/[^:]*: / /' < "$tmpdepfile" >> "$depfile" ## This next piece of magic avoids the "deleted header file" problem. ## The problem is that when a header file which appears in a .P file ## is deleted, the dependency causes make to die (because there is ## typically no way to rebuild the header). We avoid this by adding ## dummy dependencies for each header file. Too bad gcc doesn't do ## this for us directly. ## Some versions of gcc put a space before the ':'. On the theory ## that the space means something, we add a space to the output as ## well. hp depmode also adds that space, but also prefixes the VPATH ## to the object. Take care to not repeat it in the output. ## Some versions of the HPUX 10.20 sed can't process this invocation ## correctly. Breaking it into two sed invocations is a workaround. tr ' ' "$nl" < "$tmpdepfile" \ | sed -e 's/^\\$//' -e '/^$/d' -e "s|.*$object$||" -e '/:$/d' \ | sed -e 's/$/ :/' >> "$depfile" rm -f "$tmpdepfile" ;; hp) # This case exists only to let depend.m4 do its work. It works by # looking at the text of this script. This case will never be run, # since it is checked for above. exit 1 ;; sgi) if test "$libtool" = yes; then "$@" "-Wp,-MDupdate,$tmpdepfile" else "$@" -MDupdate "$tmpdepfile" fi stat=$? if test $stat -ne 0; then rm -f "$tmpdepfile" exit $stat fi rm -f "$depfile" if test -f "$tmpdepfile"; then # yes, the sourcefile depend on other files echo "$object : \\" > "$depfile" # Clip off the initial element (the dependent). Don't try to be # clever and replace this with sed code, as IRIX sed won't handle # lines with more than a fixed number of characters (4096 in # IRIX 6.2 sed, 8192 in IRIX 6.5). We also remove comment lines; # the IRIX cc adds comments like '#:fec' to the end of the # dependency line. tr ' ' "$nl" < "$tmpdepfile" \ | sed -e 's/^.*\.o://' -e 's/#.*$//' -e '/^$/ d' \ | tr "$nl" ' ' >> "$depfile" echo >> "$depfile" # The second pass generates a dummy entry for each header file. tr ' ' "$nl" < "$tmpdepfile" \ | sed -e 's/^.*\.o://' -e 's/#.*$//' -e '/^$/ d' -e 's/$/:/' \ >> "$depfile" else make_dummy_depfile fi rm -f "$tmpdepfile" ;; xlc) # This case exists only to let depend.m4 do its work. It works by # looking at the text of this script. This case will never be run, # since it is checked for above. exit 1 ;; aix) # The C for AIX Compiler uses -M and outputs the dependencies # in a .u file. In older versions, this file always lives in the # current directory. Also, the AIX compiler puts '$object:' at the # start of each line; $object doesn't have directory information. # Version 6 uses the directory in both cases. set_dir_from "$object" set_base_from "$object" if test "$libtool" = yes; then tmpdepfile1=$dir$base.u tmpdepfile2=$base.u tmpdepfile3=$dir.libs/$base.u "$@" -Wc,-M else tmpdepfile1=$dir$base.u tmpdepfile2=$dir$base.u tmpdepfile3=$dir$base.u "$@" -M fi stat=$? if test $stat -ne 0; then rm -f "$tmpdepfile1" "$tmpdepfile2" "$tmpdepfile3" exit $stat fi for tmpdepfile in "$tmpdepfile1" "$tmpdepfile2" "$tmpdepfile3" do test -f "$tmpdepfile" && break done aix_post_process_depfile ;; tcc) # tcc (Tiny C Compiler) understand '-MD -MF file' since version 0.9.26 # FIXME: That version still under development at the moment of writing. # Make that this statement remains true also for stable, released # versions. # It will wrap lines (doesn't matter whether long or short) with a # trailing '\', as in: # # foo.o : \ # foo.c \ # foo.h \ # # It will put a trailing '\' even on the last line, and will use leading # spaces rather than leading tabs (at least since its commit 0394caf7 # "Emit spaces for -MD"). "$@" -MD -MF "$tmpdepfile" stat=$? if test $stat -ne 0; then rm -f "$tmpdepfile" exit $stat fi rm -f "$depfile" # Each non-empty line is of the form 'foo.o : \' or ' dep.h \'. # We have to change lines of the first kind to '$object: \'. sed -e "s|.*:|$object :|" < "$tmpdepfile" > "$depfile" # And for each line of the second kind, we have to emit a 'dep.h:' # dummy dependency, to avoid the deleted-header problem. sed -n -e 's|^ *\(.*\) *\\$|\1:|p' < "$tmpdepfile" >> "$depfile" rm -f "$tmpdepfile" ;; ## The order of this option in the case statement is important, since the ## shell code in configure will try each of these formats in the order ## listed in this file. A plain '-MD' option would be understood by many ## compilers, so we must ensure this comes after the gcc and icc options. pgcc) # Portland's C compiler understands '-MD'. # Will always output deps to 'file.d' where file is the root name of the # source file under compilation, even if file resides in a subdirectory. # The object file name does not affect the name of the '.d' file. # pgcc 10.2 will output # foo.o: sub/foo.c sub/foo.h # and will wrap long lines using '\' : # foo.o: sub/foo.c ... \ # sub/foo.h ... \ # ... set_dir_from "$object" # Use the source, not the object, to determine the base name, since # that's sadly what pgcc will do too. set_base_from "$source" tmpdepfile=$base.d # For projects that build the same source file twice into different object # files, the pgcc approach of using the *source* file root name can cause # problems in parallel builds. Use a locking strategy to avoid stomping on # the same $tmpdepfile. lockdir=$base.d-lock trap " echo '$0: caught signal, cleaning up...' >&2 rmdir '$lockdir' exit 1 " 1 2 13 15 numtries=100 i=$numtries while test $i -gt 0; do # mkdir is a portable test-and-set. if mkdir "$lockdir" 2>/dev/null; then # This process acquired the lock. "$@" -MD stat=$? # Release the lock. rmdir "$lockdir" break else # If the lock is being held by a different process, wait # until the winning process is done or we timeout. while test -d "$lockdir" && test $i -gt 0; do sleep 1 i=`expr $i - 1` done fi i=`expr $i - 1` done trap - 1 2 13 15 if test $i -le 0; then echo "$0: failed to acquire lock after $numtries attempts" >&2 echo "$0: check lockdir '$lockdir'" >&2 exit 1 fi if test $stat -ne 0; then rm -f "$tmpdepfile" exit $stat fi rm -f "$depfile" # Each line is of the form `foo.o: dependent.h', # or `foo.o: dep1.h dep2.h \', or ` dep3.h dep4.h \'. # Do two passes, one to just change these to # `$object: dependent.h' and one to simply `dependent.h:'. sed "s,^[^:]*:,$object :," < "$tmpdepfile" > "$depfile" # Some versions of the HPUX 10.20 sed can't process this invocation # correctly. Breaking it into two sed invocations is a workaround. sed 's,^[^:]*: \(.*\)$,\1,;s/^\\$//;/^$/d;/:$/d' < "$tmpdepfile" \ | sed -e 's/$/ :/' >> "$depfile" rm -f "$tmpdepfile" ;; hp2) # The "hp" stanza above does not work with aCC (C++) and HP's ia64 # compilers, which have integrated preprocessors. The correct option # to use with these is +Maked; it writes dependencies to a file named # 'foo.d', which lands next to the object file, wherever that # happens to be. # Much of this is similar to the tru64 case; see comments there. set_dir_from "$object" set_base_from "$object" if test "$libtool" = yes; then tmpdepfile1=$dir$base.d tmpdepfile2=$dir.libs/$base.d "$@" -Wc,+Maked else tmpdepfile1=$dir$base.d tmpdepfile2=$dir$base.d "$@" +Maked fi stat=$? if test $stat -ne 0; then rm -f "$tmpdepfile1" "$tmpdepfile2" exit $stat fi for tmpdepfile in "$tmpdepfile1" "$tmpdepfile2" do test -f "$tmpdepfile" && break done if test -f "$tmpdepfile"; then sed -e "s,^.*\.[$lower]*:,$object:," "$tmpdepfile" > "$depfile" # Add 'dependent.h:' lines. sed -ne '2,${ s/^ *// s/ \\*$// s/$/:/ p }' "$tmpdepfile" >> "$depfile" else make_dummy_depfile fi rm -f "$tmpdepfile" "$tmpdepfile2" ;; tru64) # The Tru64 compiler uses -MD to generate dependencies as a side # effect. 'cc -MD -o foo.o ...' puts the dependencies into 'foo.o.d'. # At least on Alpha/Redhat 6.1, Compaq CCC V6.2-504 seems to put # dependencies in 'foo.d' instead, so we check for that too. # Subdirectories are respected. set_dir_from "$object" set_base_from "$object" if test "$libtool" = yes; then # Libtool generates 2 separate objects for the 2 libraries. These # two compilations output dependencies in $dir.libs/$base.o.d and # in $dir$base.o.d. We have to check for both files, because # one of the two compilations can be disabled. We should prefer # $dir$base.o.d over $dir.libs/$base.o.d because the latter is # automatically cleaned when .libs/ is deleted, while ignoring # the former would cause a distcleancheck panic. tmpdepfile1=$dir$base.o.d # libtool 1.5 tmpdepfile2=$dir.libs/$base.o.d # Likewise. tmpdepfile3=$dir.libs/$base.d # Compaq CCC V6.2-504 "$@" -Wc,-MD else tmpdepfile1=$dir$base.d tmpdepfile2=$dir$base.d tmpdepfile3=$dir$base.d "$@" -MD fi stat=$? if test $stat -ne 0; then rm -f "$tmpdepfile1" "$tmpdepfile2" "$tmpdepfile3" exit $stat fi for tmpdepfile in "$tmpdepfile1" "$tmpdepfile2" "$tmpdepfile3" do test -f "$tmpdepfile" && break done # Same post-processing that is required for AIX mode. aix_post_process_depfile ;; msvc7) if test "$libtool" = yes; then showIncludes=-Wc,-showIncludes else showIncludes=-showIncludes fi "$@" $showIncludes > "$tmpdepfile" stat=$? grep -v '^Note: including file: ' "$tmpdepfile" if test $stat -ne 0; then rm -f "$tmpdepfile" exit $stat fi rm -f "$depfile" echo "$object : \\" > "$depfile" # The first sed program below extracts the file names and escapes # backslashes for cygpath. The second sed program outputs the file # name when reading, but also accumulates all include files in the # hold buffer in order to output them again at the end. This only # works with sed implementations that can handle large buffers. sed < "$tmpdepfile" -n ' /^Note: including file: *\(.*\)/ { s//\1/ s/\\/\\\\/g p }' | $cygpath_u | sort -u | sed -n ' s/ /\\ /g s/\(.*\)/'"$tab"'\1 \\/p s/.\(.*\) \\/\1:/ H $ { s/.*/'"$tab"'/ G p }' >> "$depfile" echo >> "$depfile" # make sure the fragment doesn't end with a backslash rm -f "$tmpdepfile" ;; msvc7msys) # This case exists only to let depend.m4 do its work. It works by # looking at the text of this script. This case will never be run, # since it is checked for above. exit 1 ;; #nosideeffect) # This comment above is used by automake to tell side-effect # dependency tracking mechanisms from slower ones. dashmstdout) # Important note: in order to support this mode, a compiler *must* # always write the preprocessed file to stdout, regardless of -o. "$@" || exit $? # Remove the call to Libtool. if test "$libtool" = yes; then while test "X$1" != 'X--mode=compile'; do shift done shift fi # Remove '-o $object'. IFS=" " for arg do case $arg in -o) shift ;; $object) shift ;; *) set fnord "$@" "$arg" shift # fnord shift # $arg ;; esac done test -z "$dashmflag" && dashmflag=-M # Require at least two characters before searching for ':' # in the target name. This is to cope with DOS-style filenames: # a dependency such as 'c:/foo/bar' could be seen as target 'c' otherwise. "$@" $dashmflag | sed "s|^[$tab ]*[^:$tab ][^:][^:]*:[$tab ]*|$object: |" > "$tmpdepfile" rm -f "$depfile" cat < "$tmpdepfile" > "$depfile" # Some versions of the HPUX 10.20 sed can't process this sed invocation # correctly. Breaking it into two sed invocations is a workaround. tr ' ' "$nl" < "$tmpdepfile" \ | sed -e 's/^\\$//' -e '/^$/d' -e '/:$/d' \ | sed -e 's/$/ :/' >> "$depfile" rm -f "$tmpdepfile" ;; dashXmstdout) # This case only exists to satisfy depend.m4. It is never actually # run, as this mode is specially recognized in the preamble. exit 1 ;; makedepend) "$@" || exit $? # Remove any Libtool call if test "$libtool" = yes; then while test "X$1" != 'X--mode=compile'; do shift done shift fi # X makedepend shift cleared=no eat=no for arg do case $cleared in no) set ""; shift cleared=yes ;; esac if test $eat = yes; then eat=no continue fi case "$arg" in -D*|-I*) set fnord "$@" "$arg"; shift ;; # Strip any option that makedepend may not understand. Remove # the object too, otherwise makedepend will parse it as a source file. -arch) eat=yes ;; -*|$object) ;; *) set fnord "$@" "$arg"; shift ;; esac done obj_suffix=`echo "$object" | sed 's/^.*\././'` touch "$tmpdepfile" ${MAKEDEPEND-makedepend} -o"$obj_suffix" -f"$tmpdepfile" "$@" rm -f "$depfile" # makedepend may prepend the VPATH from the source file name to the object. # No need to regex-escape $object, excess matching of '.' is harmless. sed "s|^.*\($object *:\)|\1|" "$tmpdepfile" > "$depfile" # Some versions of the HPUX 10.20 sed can't process the last invocation # correctly. Breaking it into two sed invocations is a workaround. sed '1,2d' "$tmpdepfile" \ | tr ' ' "$nl" \ | sed -e 's/^\\$//' -e '/^$/d' -e '/:$/d' \ | sed -e 's/$/ :/' >> "$depfile" rm -f "$tmpdepfile" "$tmpdepfile".bak ;; cpp) # Important note: in order to support this mode, a compiler *must* # always write the preprocessed file to stdout. "$@" || exit $? # Remove the call to Libtool. if test "$libtool" = yes; then while test "X$1" != 'X--mode=compile'; do shift done shift fi # Remove '-o $object'. IFS=" " for arg do case $arg in -o) shift ;; $object) shift ;; *) set fnord "$@" "$arg" shift # fnord shift # $arg ;; esac done "$@" -E \ | sed -n -e '/^# [0-9][0-9]* "\([^"]*\)".*/ s:: \1 \\:p' \ -e '/^#line [0-9][0-9]* "\([^"]*\)".*/ s:: \1 \\:p' \ | sed '$ s: \\$::' > "$tmpdepfile" rm -f "$depfile" echo "$object : \\" > "$depfile" cat < "$tmpdepfile" >> "$depfile" sed < "$tmpdepfile" '/^$/d;s/^ //;s/ \\$//;s/$/ :/' >> "$depfile" rm -f "$tmpdepfile" ;; msvisualcpp) # Important note: in order to support this mode, a compiler *must* # always write the preprocessed file to stdout. "$@" || exit $? # Remove the call to Libtool. if test "$libtool" = yes; then while test "X$1" != 'X--mode=compile'; do shift done shift fi IFS=" " for arg do case "$arg" in -o) shift ;; $object) shift ;; "-Gm"|"/Gm"|"-Gi"|"/Gi"|"-ZI"|"/ZI") set fnord "$@" shift shift ;; *) set fnord "$@" "$arg" shift shift ;; esac done "$@" -E 2>/dev/null | sed -n '/^#line [0-9][0-9]* "\([^"]*\)"/ s::\1:p' | $cygpath_u | sort -u > "$tmpdepfile" rm -f "$depfile" echo "$object : \\" > "$depfile" sed < "$tmpdepfile" -n -e 's% %\\ %g' -e '/^\(.*\)$/ s::'"$tab"'\1 \\:p' >> "$depfile" echo "$tab" >> "$depfile" sed < "$tmpdepfile" -n -e 's% %\\ %g' -e '/^\(.*\)$/ s::\1\::p' >> "$depfile" rm -f "$tmpdepfile" ;; msvcmsys) # This case exists only to let depend.m4 do its work. It works by # looking at the text of this script. This case will never be run, # since it is checked for above. exit 1 ;; none) exec "$@" ;; *) echo "Unknown depmode $depmode" 1>&2 exit 1 ;; esac exit 0 # Local Variables: # mode: shell-script # sh-indentation: 2 # eval: (add-hook 'write-file-hooks 'time-stamp) # time-stamp-start: "scriptversion=" # time-stamp-format: "%:y-%02m-%02d.%02H" # time-stamp-time-zone: "UTC0" # time-stamp-end: "; # UTC" # End: xrdp-0.9.5/librfxcodec/install-sh000755 001751 001751 00000034524 13220730761 016723 0ustar00metameta000000 000000 #!/bin/sh # install - install a program, script, or datafile scriptversion=2016-01-11.22; # UTC # This originates from X11R5 (mit/util/scripts/install.sh), which was # later released in X11R6 (xc/config/util/install.sh) with the # following copyright and license. # # Copyright (C) 1994 X Consortium # # Permission is hereby granted, free of charge, to any person obtaining a copy # of this software and associated documentation files (the "Software"), to # deal in the Software without restriction, including without limitation the # rights to use, copy, modify, merge, publish, distribute, sublicense, and/or # sell copies of the Software, and to permit persons to whom the Software is # furnished to do so, subject to the following conditions: # # The above copyright notice and this permission notice shall be included in # all copies or substantial portions of the Software. # # THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR # IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, # FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE # X CONSORTIUM BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN # AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNEC- # TION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. # # Except as contained in this notice, the name of the X Consortium shall not # be used in advertising or otherwise to promote the sale, use or other deal- # ings in this Software without prior written authorization from the X Consor- # tium. # # # FSF changes to this file are in the public domain. # # Calling this script install-sh is preferred over install.sh, to prevent # 'make' implicit rules from creating a file called install from it # when there is no Makefile. # # This script is compatible with the BSD install script, but was written # from scratch. tab=' ' nl=' ' IFS=" $tab$nl" # Set DOITPROG to "echo" to test this script. doit=${DOITPROG-} doit_exec=${doit:-exec} # Put in absolute file names if you don't have them in your path; # or use environment vars. chgrpprog=${CHGRPPROG-chgrp} chmodprog=${CHMODPROG-chmod} chownprog=${CHOWNPROG-chown} cmpprog=${CMPPROG-cmp} cpprog=${CPPROG-cp} mkdirprog=${MKDIRPROG-mkdir} mvprog=${MVPROG-mv} rmprog=${RMPROG-rm} stripprog=${STRIPPROG-strip} posix_mkdir= # Desired mode of installed file. mode=0755 chgrpcmd= chmodcmd=$chmodprog chowncmd= mvcmd=$mvprog rmcmd="$rmprog -f" stripcmd= src= dst= dir_arg= dst_arg= copy_on_change=false is_target_a_directory=possibly usage="\ Usage: $0 [OPTION]... [-T] SRCFILE DSTFILE or: $0 [OPTION]... SRCFILES... DIRECTORY or: $0 [OPTION]... -t DIRECTORY SRCFILES... or: $0 [OPTION]... -d DIRECTORIES... In the 1st form, copy SRCFILE to DSTFILE. In the 2nd and 3rd, copy all SRCFILES to DIRECTORY. In the 4th, create DIRECTORIES. Options: --help display this help and exit. --version display version info and exit. -c (ignored) -C install only if different (preserve the last data modification time) -d create directories instead of installing files. -g GROUP $chgrpprog installed files to GROUP. -m MODE $chmodprog installed files to MODE. -o USER $chownprog installed files to USER. -s $stripprog installed files. -t DIRECTORY install into DIRECTORY. -T report an error if DSTFILE is a directory. Environment variables override the default commands: CHGRPPROG CHMODPROG CHOWNPROG CMPPROG CPPROG MKDIRPROG MVPROG RMPROG STRIPPROG " while test $# -ne 0; do case $1 in -c) ;; -C) copy_on_change=true;; -d) dir_arg=true;; -g) chgrpcmd="$chgrpprog $2" shift;; --help) echo "$usage"; exit $?;; -m) mode=$2 case $mode in *' '* | *"$tab"* | *"$nl"* | *'*'* | *'?'* | *'['*) echo "$0: invalid mode: $mode" >&2 exit 1;; esac shift;; -o) chowncmd="$chownprog $2" shift;; -s) stripcmd=$stripprog;; -t) is_target_a_directory=always dst_arg=$2 # Protect names problematic for 'test' and other utilities. case $dst_arg in -* | [=\(\)!]) dst_arg=./$dst_arg;; esac shift;; -T) is_target_a_directory=never;; --version) echo "$0 $scriptversion"; exit $?;; --) shift break;; -*) echo "$0: invalid option: $1" >&2 exit 1;; *) break;; esac shift done # We allow the use of options -d and -T together, by making -d # take the precedence; this is for compatibility with GNU install. if test -n "$dir_arg"; then if test -n "$dst_arg"; then echo "$0: target directory not allowed when installing a directory." >&2 exit 1 fi fi if test $# -ne 0 && test -z "$dir_arg$dst_arg"; then # When -d is used, all remaining arguments are directories to create. # When -t is used, the destination is already specified. # Otherwise, the last argument is the destination. Remove it from $@. for arg do if test -n "$dst_arg"; then # $@ is not empty: it contains at least $arg. set fnord "$@" "$dst_arg" shift # fnord fi shift # arg dst_arg=$arg # Protect names problematic for 'test' and other utilities. case $dst_arg in -* | [=\(\)!]) dst_arg=./$dst_arg;; esac done fi if test $# -eq 0; then if test -z "$dir_arg"; then echo "$0: no input file specified." >&2 exit 1 fi # It's OK to call 'install-sh -d' without argument. # This can happen when creating conditional directories. exit 0 fi if test -z "$dir_arg"; then if test $# -gt 1 || test "$is_target_a_directory" = always; then if test ! -d "$dst_arg"; then echo "$0: $dst_arg: Is not a directory." >&2 exit 1 fi fi fi if test -z "$dir_arg"; then do_exit='(exit $ret); exit $ret' trap "ret=129; $do_exit" 1 trap "ret=130; $do_exit" 2 trap "ret=141; $do_exit" 13 trap "ret=143; $do_exit" 15 # Set umask so as not to create temps with too-generous modes. # However, 'strip' requires both read and write access to temps. case $mode in # Optimize common cases. *644) cp_umask=133;; *755) cp_umask=22;; *[0-7]) if test -z "$stripcmd"; then u_plus_rw= else u_plus_rw='% 200' fi cp_umask=`expr '(' 777 - $mode % 1000 ')' $u_plus_rw`;; *) if test -z "$stripcmd"; then u_plus_rw= else u_plus_rw=,u+rw fi cp_umask=$mode$u_plus_rw;; esac fi for src do # Protect names problematic for 'test' and other utilities. case $src in -* | [=\(\)!]) src=./$src;; esac if test -n "$dir_arg"; then dst=$src dstdir=$dst test -d "$dstdir" dstdir_status=$? else # Waiting for this to be detected by the "$cpprog $src $dsttmp" command # might cause directories to be created, which would be especially bad # if $src (and thus $dsttmp) contains '*'. if test ! -f "$src" && test ! -d "$src"; then echo "$0: $src does not exist." >&2 exit 1 fi if test -z "$dst_arg"; then echo "$0: no destination specified." >&2 exit 1 fi dst=$dst_arg # If destination is a directory, append the input filename; won't work # if double slashes aren't ignored. if test -d "$dst"; then if test "$is_target_a_directory" = never; then echo "$0: $dst_arg: Is a directory" >&2 exit 1 fi dstdir=$dst dst=$dstdir/`basename "$src"` dstdir_status=0 else dstdir=`dirname "$dst"` test -d "$dstdir" dstdir_status=$? fi fi obsolete_mkdir_used=false if test $dstdir_status != 0; then case $posix_mkdir in '') # Create intermediate dirs using mode 755 as modified by the umask. # This is like FreeBSD 'install' as of 1997-10-28. umask=`umask` case $stripcmd.$umask in # Optimize common cases. *[2367][2367]) mkdir_umask=$umask;; .*0[02][02] | .[02][02] | .[02]) mkdir_umask=22;; *[0-7]) mkdir_umask=`expr $umask + 22 \ - $umask % 100 % 40 + $umask % 20 \ - $umask % 10 % 4 + $umask % 2 `;; *) mkdir_umask=$umask,go-w;; esac # With -d, create the new directory with the user-specified mode. # Otherwise, rely on $mkdir_umask. if test -n "$dir_arg"; then mkdir_mode=-m$mode else mkdir_mode= fi posix_mkdir=false case $umask in *[123567][0-7][0-7]) # POSIX mkdir -p sets u+wx bits regardless of umask, which # is incompatible with FreeBSD 'install' when (umask & 300) != 0. ;; *) tmpdir=${TMPDIR-/tmp}/ins$RANDOM-$$ trap 'ret=$?; rmdir "$tmpdir/d" "$tmpdir" 2>/dev/null; exit $ret' 0 if (umask $mkdir_umask && exec $mkdirprog $mkdir_mode -p -- "$tmpdir/d") >/dev/null 2>&1 then if test -z "$dir_arg" || { # Check for POSIX incompatibilities with -m. # HP-UX 11.23 and IRIX 6.5 mkdir -m -p sets group- or # other-writable bit of parent directory when it shouldn't. # FreeBSD 6.1 mkdir -m -p sets mode of existing directory. ls_ld_tmpdir=`ls -ld "$tmpdir"` case $ls_ld_tmpdir in d????-?r-*) different_mode=700;; d????-?--*) different_mode=755;; *) false;; esac && $mkdirprog -m$different_mode -p -- "$tmpdir" && { ls_ld_tmpdir_1=`ls -ld "$tmpdir"` test "$ls_ld_tmpdir" = "$ls_ld_tmpdir_1" } } then posix_mkdir=: fi rmdir "$tmpdir/d" "$tmpdir" else # Remove any dirs left behind by ancient mkdir implementations. rmdir ./$mkdir_mode ./-p ./-- 2>/dev/null fi trap '' 0;; esac;; esac if $posix_mkdir && ( umask $mkdir_umask && $doit_exec $mkdirprog $mkdir_mode -p -- "$dstdir" ) then : else # The umask is ridiculous, or mkdir does not conform to POSIX, # or it failed possibly due to a race condition. Create the # directory the slow way, step by step, checking for races as we go. case $dstdir in /*) prefix='/';; [-=\(\)!]*) prefix='./';; *) prefix='';; esac oIFS=$IFS IFS=/ set -f set fnord $dstdir shift set +f IFS=$oIFS prefixes= for d do test X"$d" = X && continue prefix=$prefix$d if test -d "$prefix"; then prefixes= else if $posix_mkdir; then (umask=$mkdir_umask && $doit_exec $mkdirprog $mkdir_mode -p -- "$dstdir") && break # Don't fail if two instances are running concurrently. test -d "$prefix" || exit 1 else case $prefix in *\'*) qprefix=`echo "$prefix" | sed "s/'/'\\\\\\\\''/g"`;; *) qprefix=$prefix;; esac prefixes="$prefixes '$qprefix'" fi fi prefix=$prefix/ done if test -n "$prefixes"; then # Don't fail if two instances are running concurrently. (umask $mkdir_umask && eval "\$doit_exec \$mkdirprog $prefixes") || test -d "$dstdir" || exit 1 obsolete_mkdir_used=true fi fi fi if test -n "$dir_arg"; then { test -z "$chowncmd" || $doit $chowncmd "$dst"; } && { test -z "$chgrpcmd" || $doit $chgrpcmd "$dst"; } && { test "$obsolete_mkdir_used$chowncmd$chgrpcmd" = false || test -z "$chmodcmd" || $doit $chmodcmd $mode "$dst"; } || exit 1 else # Make a couple of temp file names in the proper directory. dsttmp=$dstdir/_inst.$$_ rmtmp=$dstdir/_rm.$$_ # Trap to clean up those temp files at exit. trap 'ret=$?; rm -f "$dsttmp" "$rmtmp" && exit $ret' 0 # Copy the file name to the temp name. (umask $cp_umask && $doit_exec $cpprog "$src" "$dsttmp") && # and set any options; do chmod last to preserve setuid bits. # # If any of these fail, we abort the whole thing. If we want to # ignore errors from any of these, just make sure not to ignore # errors from the above "$doit $cpprog $src $dsttmp" command. # { test -z "$chowncmd" || $doit $chowncmd "$dsttmp"; } && { test -z "$chgrpcmd" || $doit $chgrpcmd "$dsttmp"; } && { test -z "$stripcmd" || $doit $stripcmd "$dsttmp"; } && { test -z "$chmodcmd" || $doit $chmodcmd $mode "$dsttmp"; } && # If -C, don't bother to copy if it wouldn't change the file. if $copy_on_change && old=`LC_ALL=C ls -dlL "$dst" 2>/dev/null` && new=`LC_ALL=C ls -dlL "$dsttmp" 2>/dev/null` && set -f && set X $old && old=:$2:$4:$5:$6 && set X $new && new=:$2:$4:$5:$6 && set +f && test "$old" = "$new" && $cmpprog "$dst" "$dsttmp" >/dev/null 2>&1 then rm -f "$dsttmp" else # Rename the file to the real destination. $doit $mvcmd -f "$dsttmp" "$dst" 2>/dev/null || # The rename failed, perhaps because mv can't rename something else # to itself, or perhaps because mv is so ancient that it does not # support -f. { # Now remove or move aside any old file at destination location. # We try this two ways since rm can't unlink itself on some # systems and the destination file might be busy for other # reasons. In this case, the final cleanup might fail but the new # file should still install successfully. { test ! -f "$dst" || $doit $rmcmd -f "$dst" 2>/dev/null || { $doit $mvcmd -f "$dst" "$rmtmp" 2>/dev/null && { $doit $rmcmd -f "$rmtmp" 2>/dev/null; :; } } || { echo "$0: cannot unlink or rename $dst" >&2 (exit 1); exit 1 } } && # Now rename the file to the real destination. $doit $mvcmd "$dsttmp" "$dst" } fi || exit 1 trap '' 0 fi done # Local variables: # eval: (add-hook 'write-file-hooks 'time-stamp) # time-stamp-start: "scriptversion=" # time-stamp-format: "%:y-%02m-%02d.%02H" # time-stamp-time-zone: "UTC0" # time-stamp-end: "; # UTC" # End: xrdp-0.9.5/librfxcodec/include/rfxcodec_common.h000644 001751 001751 00000002302 12777440111 021650 0ustar00metameta000000 000000 /** * RFX codec * * Copyright 2015 Jay Sorg * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ #ifndef __RFXCODEC_COMMON_H #define __RFXCODEC_COMMON_H #define RFX_FORMAT_BGRA 0 #define RFX_FORMAT_RGBA 1 #define RFX_FORMAT_BGR 2 #define RFX_FORMAT_RGB 3 #define RFX_FORMAT_YUV 4 /* YUV444 linear tiled mode */ #define RFX_FLAGS_NONE 0 /* default RFX_FLAGS_RLGR3 and RFX_FLAGS_SAFE */ #define RFX_FLAGS_SAFE 0 /* default */ #define RFX_FLAGS_OPT1 (1 << 3) #define RFX_FLAGS_OPT2 (1 << 4) #define RFX_FLAGS_NOACCEL (1 << 6) #define RFX_FLAGS_RLGR3 0 /* default */ #define RFX_FLAGS_RLGR1 1 #define RFX_FLAGS_ALPHAV1 1 /* used in flags for rfxcodec_encode */ #endif xrdp-0.9.5/librfxcodec/include/Makefile.in000644 001751 001751 00000040434 13220730761 020404 0ustar00metameta000000 000000 # Makefile.in generated by automake 1.15.1 from Makefile.am. # @configure_input@ # Copyright (C) 1994-2017 Free Software Foundation, Inc. # This Makefile.in is free software; the Free Software Foundation # gives unlimited permission to copy and/or distribute it, # with or without modifications, as long as this notice is preserved. # This program is distributed in the hope that it will be useful, # but WITHOUT ANY WARRANTY, to the extent permitted by law; without # even the implied warranty of MERCHANTABILITY or FITNESS FOR A # PARTICULAR PURPOSE. @SET_MAKE@ VPATH = @srcdir@ am__is_gnu_make = { \ if test -z '$(MAKELEVEL)'; then \ false; \ elif test -n '$(MAKE_HOST)'; then \ true; \ elif test -n '$(MAKE_VERSION)' && test -n '$(CURDIR)'; then \ true; \ else \ false; \ fi; \ } am__make_running_with_option = \ case $${target_option-} in \ ?) ;; \ *) echo "am__make_running_with_option: internal error: invalid" \ "target option '$${target_option-}' specified" >&2; \ exit 1;; \ esac; \ has_opt=no; \ sane_makeflags=$$MAKEFLAGS; \ if $(am__is_gnu_make); then \ sane_makeflags=$$MFLAGS; \ else \ case $$MAKEFLAGS in \ *\\[\ \ ]*) \ bs=\\; \ sane_makeflags=`printf '%s\n' "$$MAKEFLAGS" \ | sed "s/$$bs$$bs[$$bs $$bs ]*//g"`;; \ esac; \ fi; \ skip_next=no; \ strip_trailopt () \ { \ flg=`printf '%s\n' "$$flg" | sed "s/$$1.*$$//"`; \ }; \ for flg in $$sane_makeflags; do \ test $$skip_next = yes && { skip_next=no; continue; }; \ case $$flg in \ *=*|--*) continue;; \ -*I) strip_trailopt 'I'; skip_next=yes;; \ -*I?*) strip_trailopt 'I';; \ -*O) strip_trailopt 'O'; skip_next=yes;; \ -*O?*) strip_trailopt 'O';; \ -*l) strip_trailopt 'l'; skip_next=yes;; \ -*l?*) strip_trailopt 'l';; \ -[dEDm]) skip_next=yes;; \ -[JT]) skip_next=yes;; \ esac; \ case $$flg in \ *$$target_option*) has_opt=yes; break;; \ esac; \ done; \ test $$has_opt = yes am__make_dryrun = (target_option=n; $(am__make_running_with_option)) am__make_keepgoing = (target_option=k; $(am__make_running_with_option)) pkgdatadir = $(datadir)/@PACKAGE@ pkgincludedir = $(includedir)/@PACKAGE@ pkglibdir = $(libdir)/@PACKAGE@ pkglibexecdir = $(libexecdir)/@PACKAGE@ am__cd = CDPATH="$${ZSH_VERSION+.}$(PATH_SEPARATOR)" && cd install_sh_DATA = $(install_sh) -c -m 644 install_sh_PROGRAM = $(install_sh) -c install_sh_SCRIPT = $(install_sh) -c INSTALL_HEADER = $(INSTALL_DATA) transform = $(program_transform_name) NORMAL_INSTALL = : PRE_INSTALL = : POST_INSTALL = : NORMAL_UNINSTALL = : PRE_UNINSTALL = : POST_UNINSTALL = : build_triplet = @build@ host_triplet = @host@ subdir = include ACLOCAL_M4 = $(top_srcdir)/aclocal.m4 am__aclocal_m4_deps = $(top_srcdir)/m4/ax_append_compile_flags.m4 \ $(top_srcdir)/m4/ax_append_flag.m4 \ $(top_srcdir)/m4/ax_cflags_warn_all.m4 \ $(top_srcdir)/m4/ax_check_compile_flag.m4 \ $(top_srcdir)/m4/ax_require_defined.m4 \ $(top_srcdir)/m4/libtool.m4 $(top_srcdir)/m4/ltoptions.m4 \ $(top_srcdir)/m4/ltsugar.m4 $(top_srcdir)/m4/ltversion.m4 \ $(top_srcdir)/m4/lt~obsolete.m4 $(top_srcdir)/m4/nasm.m4 \ $(top_srcdir)/m4/pkg.m4 $(top_srcdir)/configure.ac am__configure_deps = $(am__aclocal_m4_deps) $(CONFIGURE_DEPENDENCIES) \ $(ACLOCAL_M4) DIST_COMMON = $(srcdir)/Makefile.am $(include_HEADERS) \ $(am__DIST_COMMON) mkinstalldirs = $(install_sh) -d CONFIG_HEADER = $(top_builddir)/config_ac.h CONFIG_CLEAN_FILES = CONFIG_CLEAN_VPATH_FILES = AM_V_P = $(am__v_P_@AM_V@) am__v_P_ = $(am__v_P_@AM_DEFAULT_V@) am__v_P_0 = false am__v_P_1 = : AM_V_GEN = $(am__v_GEN_@AM_V@) am__v_GEN_ = $(am__v_GEN_@AM_DEFAULT_V@) am__v_GEN_0 = @echo " GEN " $@; am__v_GEN_1 = AM_V_at = $(am__v_at_@AM_V@) am__v_at_ = $(am__v_at_@AM_DEFAULT_V@) am__v_at_0 = @ am__v_at_1 = SOURCES = DIST_SOURCES = am__can_run_installinfo = \ case $$AM_UPDATE_INFO_DIR in \ n|no|NO) false;; \ *) (install-info --version) >/dev/null 2>&1;; \ esac am__vpath_adj_setup = srcdirstrip=`echo "$(srcdir)" | sed 's|.|.|g'`; am__vpath_adj = case $$p in \ $(srcdir)/*) f=`echo "$$p" | sed "s|^$$srcdirstrip/||"`;; \ *) f=$$p;; \ esac; am__strip_dir = f=`echo $$p | sed -e 's|^.*/||'`; am__install_max = 40 am__nobase_strip_setup = \ srcdirstrip=`echo "$(srcdir)" | sed 's/[].[^$$\\*|]/\\\\&/g'` am__nobase_strip = \ for p in $$list; do echo "$$p"; done | sed -e "s|$$srcdirstrip/||" am__nobase_list = $(am__nobase_strip_setup); \ for p in $$list; do echo "$$p $$p"; done | \ sed "s| $$srcdirstrip/| |;"' / .*\//!s/ .*/ ./; s,\( .*\)/[^/]*$$,\1,' | \ $(AWK) 'BEGIN { files["."] = "" } { files[$$2] = files[$$2] " " $$1; \ if (++n[$$2] == $(am__install_max)) \ { print $$2, files[$$2]; n[$$2] = 0; files[$$2] = "" } } \ END { for (dir in files) print dir, files[dir] }' am__base_list = \ sed '$$!N;$$!N;$$!N;$$!N;$$!N;$$!N;$$!N;s/\n/ /g' | \ sed '$$!N;$$!N;$$!N;$$!N;s/\n/ /g' am__uninstall_files_from_dir = { \ test -z "$$files" \ || { test ! -d "$$dir" && test ! -f "$$dir" && test ! -r "$$dir"; } \ || { echo " ( cd '$$dir' && rm -f" $$files ")"; \ $(am__cd) "$$dir" && rm -f $$files; }; \ } am__installdirs = "$(DESTDIR)$(includedir)" HEADERS = $(include_HEADERS) am__tagged_files = $(HEADERS) $(SOURCES) $(TAGS_FILES) $(LISP) # Read a list of newline-separated strings from the standard input, # and print each of them once, without duplicates. Input order is # *not* preserved. am__uniquify_input = $(AWK) '\ BEGIN { nonempty = 0; } \ { items[$$0] = 1; nonempty = 1; } \ END { if (nonempty) { for (i in items) print i; }; } \ ' # Make sure the list of sources is unique. This is necessary because, # e.g., the same source file might be shared among _SOURCES variables # for different programs/libraries. am__define_uniq_tagged_files = \ list='$(am__tagged_files)'; \ unique=`for i in $$list; do \ if test -f "$$i"; then echo $$i; else echo $(srcdir)/$$i; fi; \ done | $(am__uniquify_input)` ETAGS = etags CTAGS = ctags am__DIST_COMMON = $(srcdir)/Makefile.in DISTFILES = $(DIST_COMMON) $(DIST_SOURCES) $(TEXINFOS) $(EXTRA_DIST) ACLOCAL = @ACLOCAL@ AMTAR = @AMTAR@ AM_DEFAULT_VERBOSITY = @AM_DEFAULT_VERBOSITY@ AR = @AR@ AUTOCONF = @AUTOCONF@ AUTOHEADER = @AUTOHEADER@ AUTOMAKE = @AUTOMAKE@ AWK = @AWK@ CC = @CC@ CCDEPMODE = @CCDEPMODE@ CFLAGS = @CFLAGS@ CPP = @CPP@ CPPFLAGS = @CPPFLAGS@ CYGPATH_W = @CYGPATH_W@ DEFS = @DEFS@ DEPDIR = @DEPDIR@ DLLTOOL = @DLLTOOL@ DSYMUTIL = @DSYMUTIL@ DUMPBIN = @DUMPBIN@ ECHO_C = @ECHO_C@ ECHO_N = @ECHO_N@ ECHO_T = @ECHO_T@ EGREP = @EGREP@ EXEEXT = @EXEEXT@ FGREP = @FGREP@ GREP = @GREP@ INSTALL = @INSTALL@ INSTALL_DATA = @INSTALL_DATA@ INSTALL_PROGRAM = @INSTALL_PROGRAM@ INSTALL_SCRIPT = @INSTALL_SCRIPT@ INSTALL_STRIP_PROGRAM = @INSTALL_STRIP_PROGRAM@ LD = @LD@ LDFLAGS = @LDFLAGS@ LIBOBJS = @LIBOBJS@ LIBS = @LIBS@ LIBTOOL = @LIBTOOL@ LIPO = @LIPO@ LN_S = @LN_S@ LTLIBOBJS = @LTLIBOBJS@ LT_SYS_LIBRARY_PATH = @LT_SYS_LIBRARY_PATH@ MAKEINFO = @MAKEINFO@ MANIFEST_TOOL = @MANIFEST_TOOL@ MKDIR_P = @MKDIR_P@ NAFLAGS = @NAFLAGS@ NASM = @NASM@ NM = @NM@ NMEDIT = @NMEDIT@ OBJDUMP = @OBJDUMP@ OBJEXT = @OBJEXT@ OTOOL = @OTOOL@ OTOOL64 = @OTOOL64@ PACKAGE = @PACKAGE@ PACKAGE_BUGREPORT = @PACKAGE_BUGREPORT@ PACKAGE_NAME = @PACKAGE_NAME@ PACKAGE_STRING = @PACKAGE_STRING@ PACKAGE_TARNAME = @PACKAGE_TARNAME@ PACKAGE_URL = @PACKAGE_URL@ PACKAGE_VERSION = @PACKAGE_VERSION@ PATH_SEPARATOR = @PATH_SEPARATOR@ RANLIB = @RANLIB@ SED = @SED@ SET_MAKE = @SET_MAKE@ SHELL = @SHELL@ STRIP = @STRIP@ VERSION = @VERSION@ abs_builddir = @abs_builddir@ abs_srcdir = @abs_srcdir@ abs_top_builddir = @abs_top_builddir@ abs_top_srcdir = @abs_top_srcdir@ ac_ct_AR = @ac_ct_AR@ ac_ct_CC = @ac_ct_CC@ ac_ct_DUMPBIN = @ac_ct_DUMPBIN@ am__include = @am__include@ am__leading_dot = @am__leading_dot@ am__quote = @am__quote@ am__tar = @am__tar@ am__untar = @am__untar@ bindir = @bindir@ build = @build@ build_alias = @build_alias@ build_cpu = @build_cpu@ build_os = @build_os@ build_vendor = @build_vendor@ builddir = @builddir@ datadir = @datadir@ datarootdir = @datarootdir@ docdir = @docdir@ dvidir = @dvidir@ exec_prefix = @exec_prefix@ host = @host@ host_alias = @host_alias@ host_cpu = @host_cpu@ host_os = @host_os@ host_vendor = @host_vendor@ htmldir = @htmldir@ includedir = @includedir@ infodir = @infodir@ install_sh = @install_sh@ libdir = @libdir@ libexecdir = @libexecdir@ localedir = @localedir@ localstatedir = @localstatedir@ mandir = @mandir@ mkdir_p = @mkdir_p@ oldincludedir = @oldincludedir@ pdfdir = @pdfdir@ pkgconfigdir = @pkgconfigdir@ prefix = @prefix@ program_transform_name = @program_transform_name@ psdir = @psdir@ sbindir = @sbindir@ sharedstatedir = @sharedstatedir@ srcdir = @srcdir@ sysconfdir = @sysconfdir@ target_alias = @target_alias@ top_build_prefix = @top_build_prefix@ top_builddir = @top_builddir@ top_srcdir = @top_srcdir@ include_HEADERS = \ rfxcodec_encode.h \ rfxcodec_decode.h \ rfxcodec_common.h all: all-am .SUFFIXES: $(srcdir)/Makefile.in: $(srcdir)/Makefile.am $(am__configure_deps) @for dep in $?; do \ case '$(am__configure_deps)' in \ *$$dep*) \ ( cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh ) \ && { if test -f $@; then exit 0; else break; fi; }; \ exit 1;; \ esac; \ done; \ echo ' cd $(top_srcdir) && $(AUTOMAKE) --foreign include/Makefile'; \ $(am__cd) $(top_srcdir) && \ $(AUTOMAKE) --foreign include/Makefile Makefile: $(srcdir)/Makefile.in $(top_builddir)/config.status @case '$?' in \ *config.status*) \ cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh;; \ *) \ echo ' cd $(top_builddir) && $(SHELL) ./config.status $(subdir)/$@ $(am__depfiles_maybe)'; \ cd $(top_builddir) && $(SHELL) ./config.status $(subdir)/$@ $(am__depfiles_maybe);; \ esac; $(top_builddir)/config.status: $(top_srcdir)/configure $(CONFIG_STATUS_DEPENDENCIES) cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh $(top_srcdir)/configure: $(am__configure_deps) cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh $(ACLOCAL_M4): $(am__aclocal_m4_deps) cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh $(am__aclocal_m4_deps): mostlyclean-libtool: -rm -f *.lo clean-libtool: -rm -rf .libs _libs install-includeHEADERS: $(include_HEADERS) @$(NORMAL_INSTALL) @list='$(include_HEADERS)'; test -n "$(includedir)" || list=; \ if test -n "$$list"; then \ echo " $(MKDIR_P) '$(DESTDIR)$(includedir)'"; \ $(MKDIR_P) "$(DESTDIR)$(includedir)" || exit 1; \ fi; \ for p in $$list; do \ if test -f "$$p"; then d=; else d="$(srcdir)/"; fi; \ echo "$$d$$p"; \ done | $(am__base_list) | \ while read files; do \ echo " $(INSTALL_HEADER) $$files '$(DESTDIR)$(includedir)'"; \ $(INSTALL_HEADER) $$files "$(DESTDIR)$(includedir)" || exit $$?; \ done uninstall-includeHEADERS: @$(NORMAL_UNINSTALL) @list='$(include_HEADERS)'; test -n "$(includedir)" || list=; \ files=`for p in $$list; do echo $$p; done | sed -e 's|^.*/||'`; \ dir='$(DESTDIR)$(includedir)'; $(am__uninstall_files_from_dir) ID: $(am__tagged_files) $(am__define_uniq_tagged_files); mkid -fID $$unique tags: tags-am TAGS: tags tags-am: $(TAGS_DEPENDENCIES) $(am__tagged_files) set x; \ here=`pwd`; \ $(am__define_uniq_tagged_files); \ shift; \ if test -z "$(ETAGS_ARGS)$$*$$unique"; then :; else \ test -n "$$unique" || unique=$$empty_fix; \ if test $$# -gt 0; then \ $(ETAGS) $(ETAGSFLAGS) $(AM_ETAGSFLAGS) $(ETAGS_ARGS) \ "$$@" $$unique; \ else \ $(ETAGS) $(ETAGSFLAGS) $(AM_ETAGSFLAGS) $(ETAGS_ARGS) \ $$unique; \ fi; \ fi ctags: ctags-am CTAGS: ctags ctags-am: $(TAGS_DEPENDENCIES) $(am__tagged_files) $(am__define_uniq_tagged_files); \ test -z "$(CTAGS_ARGS)$$unique" \ || $(CTAGS) $(CTAGSFLAGS) $(AM_CTAGSFLAGS) $(CTAGS_ARGS) \ $$unique GTAGS: here=`$(am__cd) $(top_builddir) && pwd` \ && $(am__cd) $(top_srcdir) \ && gtags -i $(GTAGS_ARGS) "$$here" cscopelist: cscopelist-am cscopelist-am: $(am__tagged_files) list='$(am__tagged_files)'; \ case "$(srcdir)" in \ [\\/]* | ?:[\\/]*) sdir="$(srcdir)" ;; \ *) sdir=$(subdir)/$(srcdir) ;; \ esac; \ for i in $$list; do \ if test -f "$$i"; then \ echo "$(subdir)/$$i"; \ else \ echo "$$sdir/$$i"; \ fi; \ done >> $(top_builddir)/cscope.files distclean-tags: -rm -f TAGS ID GTAGS GRTAGS GSYMS GPATH tags distdir: $(DISTFILES) @srcdirstrip=`echo "$(srcdir)" | sed 's/[].[^$$\\*]/\\\\&/g'`; \ topsrcdirstrip=`echo "$(top_srcdir)" | sed 's/[].[^$$\\*]/\\\\&/g'`; \ list='$(DISTFILES)'; \ dist_files=`for file in $$list; do echo $$file; done | \ sed -e "s|^$$srcdirstrip/||;t" \ -e "s|^$$topsrcdirstrip/|$(top_builddir)/|;t"`; \ case $$dist_files in \ */*) $(MKDIR_P) `echo "$$dist_files" | \ sed '/\//!d;s|^|$(distdir)/|;s,/[^/]*$$,,' | \ sort -u` ;; \ esac; \ for file in $$dist_files; do \ if test -f $$file || test -d $$file; then d=.; else d=$(srcdir); fi; \ if test -d $$d/$$file; then \ dir=`echo "/$$file" | sed -e 's,/[^/]*$$,,'`; \ if test -d "$(distdir)/$$file"; then \ find "$(distdir)/$$file" -type d ! -perm -700 -exec chmod u+rwx {} \;; \ fi; \ if test -d $(srcdir)/$$file && test $$d != $(srcdir); then \ cp -fpR $(srcdir)/$$file "$(distdir)$$dir" || exit 1; \ find "$(distdir)/$$file" -type d ! -perm -700 -exec chmod u+rwx {} \;; \ fi; \ cp -fpR $$d/$$file "$(distdir)$$dir" || exit 1; \ else \ test -f "$(distdir)/$$file" \ || cp -p $$d/$$file "$(distdir)/$$file" \ || exit 1; \ fi; \ done check-am: all-am check: check-am all-am: Makefile $(HEADERS) installdirs: for dir in "$(DESTDIR)$(includedir)"; do \ test -z "$$dir" || $(MKDIR_P) "$$dir"; \ done install: install-am install-exec: install-exec-am install-data: install-data-am uninstall: uninstall-am install-am: all-am @$(MAKE) $(AM_MAKEFLAGS) install-exec-am install-data-am installcheck: installcheck-am install-strip: if test -z '$(STRIP)'; then \ $(MAKE) $(AM_MAKEFLAGS) INSTALL_PROGRAM="$(INSTALL_STRIP_PROGRAM)" \ install_sh_PROGRAM="$(INSTALL_STRIP_PROGRAM)" INSTALL_STRIP_FLAG=-s \ install; \ else \ $(MAKE) $(AM_MAKEFLAGS) INSTALL_PROGRAM="$(INSTALL_STRIP_PROGRAM)" \ install_sh_PROGRAM="$(INSTALL_STRIP_PROGRAM)" INSTALL_STRIP_FLAG=-s \ "INSTALL_PROGRAM_ENV=STRIPPROG='$(STRIP)'" install; \ fi mostlyclean-generic: clean-generic: distclean-generic: -test -z "$(CONFIG_CLEAN_FILES)" || rm -f $(CONFIG_CLEAN_FILES) -test . = "$(srcdir)" || test -z "$(CONFIG_CLEAN_VPATH_FILES)" || rm -f $(CONFIG_CLEAN_VPATH_FILES) maintainer-clean-generic: @echo "This command is intended for maintainers to use" @echo "it deletes files that may require special tools to rebuild." clean: clean-am clean-am: clean-generic clean-libtool mostlyclean-am distclean: distclean-am -rm -f Makefile distclean-am: clean-am distclean-generic distclean-tags dvi: dvi-am dvi-am: html: html-am html-am: info: info-am info-am: install-data-am: install-includeHEADERS install-dvi: install-dvi-am install-dvi-am: install-exec-am: install-html: install-html-am install-html-am: install-info: install-info-am install-info-am: install-man: install-pdf: install-pdf-am install-pdf-am: install-ps: install-ps-am install-ps-am: installcheck-am: maintainer-clean: maintainer-clean-am -rm -f Makefile maintainer-clean-am: distclean-am maintainer-clean-generic mostlyclean: mostlyclean-am mostlyclean-am: mostlyclean-generic mostlyclean-libtool pdf: pdf-am pdf-am: ps: ps-am ps-am: uninstall-am: uninstall-includeHEADERS .MAKE: install-am install-strip .PHONY: CTAGS GTAGS TAGS all all-am check check-am clean clean-generic \ clean-libtool cscopelist-am ctags ctags-am distclean \ distclean-generic distclean-libtool distclean-tags distdir dvi \ dvi-am html html-am info info-am install install-am \ install-data install-data-am install-dvi install-dvi-am \ install-exec install-exec-am install-html install-html-am \ install-includeHEADERS install-info install-info-am \ install-man install-pdf install-pdf-am install-ps \ install-ps-am install-strip installcheck installcheck-am \ installdirs maintainer-clean maintainer-clean-generic \ mostlyclean mostlyclean-generic mostlyclean-libtool pdf pdf-am \ ps ps-am tags tags-am uninstall uninstall-am \ uninstall-includeHEADERS .PRECIOUS: Makefile # Tell versions [3.59,3.63) of GNU make to not export all variables. # Otherwise a system limit (for SysV at least) may be exceeded. .NOEXPORT: xrdp-0.9.5/librfxcodec/include/rfxcodec_decode.h000644 001751 001751 00000002004 12777440111 021602 0ustar00metameta000000 000000 /** * RFX codec decoder * * Copyright 2014-2015 Jay Sorg * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ #ifndef __RFXCODEC_DECODE_H #define __RFXCODEC_DECODE_H #include int rfxcodec_decode_create(int width, int height, int format, int flags, void **handle); int rfxcodec_decode_destroy(void *handle); int rfxcodec_decode(void *handle, char *cdata, int cdata_bytes, char *data, int width, int height, int stride_bytes); #endif xrdp-0.9.5/librfxcodec/include/Makefile.am000644 001751 001751 00000000124 13061652764 020374 0ustar00metameta000000 000000 include_HEADERS = \ rfxcodec_encode.h \ rfxcodec_decode.h \ rfxcodec_common.h xrdp-0.9.5/librfxcodec/include/rfxcodec_encode.h000644 001751 001751 00000010076 13220730305 021613 0ustar00metameta000000 000000 /** * RFX codec encoder * * Copyright 2014-2015 Jay Sorg * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ #ifndef __RFXCODEC_ENCODE_H #define __RFXCODEC_ENCODE_H #include struct rfx_rect { int x; int y; int cx; int cy; }; struct rfx_tile { int x; /* multiple of 64 */ int y; /* multiple of 64 */ int cx; /* must be 64 or less */ int cy; /* must be 64 or less */ int quant_y; int quant_cb; int quant_cr; }; void * rfxcodec_encode_create(int width, int height, int format, int flags); int rfxcodec_encode_create_ex(int width, int height, int format, int flags, void **handle); int rfxcodec_encode_destroy(void *handle); /* quants, 5 ints per set, should be num_quants * 5 chars in quants) * each char is 2 quant values * quantizer order is * 0 - LL3 * 1 - LH3 * 2 - HL3 * 3 - HH3 * 4 - LH2 * 5 - HL2 * 6 - HH2 * 7 - LH1 * 8 - HL1 * 9 - HH1 */ int rfxcodec_encode(void *handle, char *cdata, int *cdata_bytes, const char *buf, int width, int height, int stride_bytes, const struct rfx_rect *region, int num_region, const struct rfx_tile *tiles, int num_tiles, const char *quants, int num_quants); int rfxcodec_encode_ex(void *handle, char *cdata, int *cdata_bytes, const char *buf, int width, int height, int stride_bytes, const struct rfx_rect *region, int num_region, const struct rfx_tile *tiles, int num_tiles, const char *quants, int num_quants, int flags); /* use simple types here, no sint16_t, uint8_t, ... */ typedef int (*rfxencode_rlgr1_proc)(const short *data, unsigned char *buffer, int buffer_size); typedef int (*rfxencode_rlgr3_proc)(const short *data, unsigned char *buffer, int buffer_size); typedef int (*rfxencode_differential_proc)(short *buffer, int buffer_size); typedef int (*rfxencode_quantization_proc)(short *buffer, const char *quantization_values); typedef int (*rfxencode_dwt_2d_proc)(const unsigned char *in_buffer, short *buffer, short *dwt_buffer); typedef int (*rfxencode_diff_rlgr1_proc)(short *coef, unsigned char *cdata, int cdata_size); typedef int (*rfxencode_diff_rlgr3_proc)(short *coef, unsigned char *cdata, int cdata_size); typedef int (*rfxencode_dwt_shift_x86_sse2_proc)(const char *qtable, const unsigned char *data, short *dwt_buffer1, short *dwt_buffer); typedef int (*rfxencode_dwt_shift_x86_sse41_proc)(const char *qtable, const unsigned char *data, short *dwt_buffer1, short *dwt_buffer); typedef int (*rfxencode_dwt_shift_amd64_sse2_proc)(const char *qtable, const unsigned char *data, short *dwt_buffer1, short *dwt_buffer); typedef int (*rfxencode_dwt_shift_amd64_sse41_proc)(const char *qtable, const unsigned char *data, short *dwt_buffer1, short *dwt_buffer); struct rfxcodec_encode_internals { rfxencode_rlgr1_proc rfxencode_rlgr1; rfxencode_rlgr3_proc rfxencode_rlgr3; rfxencode_differential_proc rfxencode_differential; rfxencode_quantization_proc rfxencode_quantization; rfxencode_dwt_2d_proc rfxencode_dwt_2d; rfxencode_diff_rlgr1_proc rfxencode_diff_rlgr1; rfxencode_diff_rlgr3_proc rfxencode_diff_rlgr3; rfxencode_dwt_shift_x86_sse2_proc rfxencode_dwt_shift_x86_sse2; rfxencode_dwt_shift_x86_sse41_proc rfxencode_dwt_shift_x86_sse41; rfxencode_dwt_shift_amd64_sse2_proc rfxencode_dwt_shift_amd64_sse2; rfxencode_dwt_shift_amd64_sse41_proc rfxencode_dwt_shift_amd64_sse41; }; int rfxcodec_encode_get_internals(struct rfxcodec_encode_internals *internals); #endif xrdp-0.9.5/librfxcodec/src/rfxencode_dwt.h000644 001751 001751 00000001424 13127342056 020505 0ustar00metameta000000 000000 /** * RFX codec encoder * * Copyright 2014-2017 Jay Sorg * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ #ifndef __RFXENCODE_RFX_H #define __RFXENCODE_RFX_H int rfx_dwt_2d_encode(const uint8 *in_buffer, sint16 *buffer, sint16 *dwt_buffer); #endif xrdp-0.9.5/librfxcodec/src/rfxencode_differential.h000644 001751 001751 00000001572 12446253657 022362 0ustar00metameta000000 000000 /** * FreeRDP: A Remote Desktop Protocol client. * RemoteFX Codec Library - Differential Encoding * * Copyright 2011 Vic Lee * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ #ifndef __RFXENCODE_DIFFERENTIAL_H #define __RFXENCODE_DIFFERENTIAL_H #include "rfxcommon.h" int rfx_differential_encode(sint16 *buffer, int buffer_size); #endif /* __RFXENCODE_DIFFERENTIAL_H */ xrdp-0.9.5/librfxcodec/src/rfxencode_rgb_to_yuv.h000644 001751 001751 00000002076 13220730305 022062 0ustar00metameta000000 000000 /** * FreeRDP: A Remote Desktop Protocol client. * RemoteFX Codec Library - Encode * * Copyright 2011 Vic Lee * Copyright 2014-2017 Jay Sorg * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ #ifndef __RFXRBGTOYUV_H #define __RFXRBGTOYUV_H #include "rfxcommon.h" int rfx_encode_rgb_to_yuv(struct rfxencode *enc, const char *rgb_data, int width, int height, int stride_bytes); int rfx_encode_argb_to_yuva(struct rfxencode *enc, const char *argb_data, int width, int height, int stride_bytes); #endif xrdp-0.9.5/librfxcodec/src/Makefile.in000644 001751 001751 00000064723 13220730761 017557 0ustar00metameta000000 000000 # Makefile.in generated by automake 1.15.1 from Makefile.am. # @configure_input@ # Copyright (C) 1994-2017 Free Software Foundation, Inc. # This Makefile.in is free software; the Free Software Foundation # gives unlimited permission to copy and/or distribute it, # with or without modifications, as long as this notice is preserved. # This program is distributed in the hope that it will be useful, # but WITHOUT ANY WARRANTY, to the extent permitted by law; without # even the implied warranty of MERCHANTABILITY or FITNESS FOR A # PARTICULAR PURPOSE. @SET_MAKE@ VPATH = @srcdir@ am__is_gnu_make = { \ if test -z '$(MAKELEVEL)'; then \ false; \ elif test -n '$(MAKE_HOST)'; then \ true; \ elif test -n '$(MAKE_VERSION)' && test -n '$(CURDIR)'; then \ true; \ else \ false; \ fi; \ } am__make_running_with_option = \ case $${target_option-} in \ ?) ;; \ *) echo "am__make_running_with_option: internal error: invalid" \ "target option '$${target_option-}' specified" >&2; \ exit 1;; \ esac; \ has_opt=no; \ sane_makeflags=$$MAKEFLAGS; \ if $(am__is_gnu_make); then \ sane_makeflags=$$MFLAGS; \ else \ case $$MAKEFLAGS in \ *\\[\ \ ]*) \ bs=\\; \ sane_makeflags=`printf '%s\n' "$$MAKEFLAGS" \ | sed "s/$$bs$$bs[$$bs $$bs ]*//g"`;; \ esac; \ fi; \ skip_next=no; \ strip_trailopt () \ { \ flg=`printf '%s\n' "$$flg" | sed "s/$$1.*$$//"`; \ }; \ for flg in $$sane_makeflags; do \ test $$skip_next = yes && { skip_next=no; continue; }; \ case $$flg in \ *=*|--*) continue;; \ -*I) strip_trailopt 'I'; skip_next=yes;; \ -*I?*) strip_trailopt 'I';; \ -*O) strip_trailopt 'O'; skip_next=yes;; \ -*O?*) strip_trailopt 'O';; \ -*l) strip_trailopt 'l'; skip_next=yes;; \ -*l?*) strip_trailopt 'l';; \ -[dEDm]) skip_next=yes;; \ -[JT]) skip_next=yes;; \ esac; \ case $$flg in \ *$$target_option*) has_opt=yes; break;; \ esac; \ done; \ test $$has_opt = yes am__make_dryrun = (target_option=n; $(am__make_running_with_option)) am__make_keepgoing = (target_option=k; $(am__make_running_with_option)) pkgdatadir = $(datadir)/@PACKAGE@ pkgincludedir = $(includedir)/@PACKAGE@ pkglibdir = $(libdir)/@PACKAGE@ pkglibexecdir = $(libexecdir)/@PACKAGE@ am__cd = CDPATH="$${ZSH_VERSION+.}$(PATH_SEPARATOR)" && cd install_sh_DATA = $(install_sh) -c -m 644 install_sh_PROGRAM = $(install_sh) -c install_sh_SCRIPT = $(install_sh) -c INSTALL_HEADER = $(INSTALL_DATA) transform = $(program_transform_name) NORMAL_INSTALL = : PRE_INSTALL = : POST_INSTALL = : NORMAL_UNINSTALL = : PRE_UNINSTALL = : POST_UNINSTALL = : build_triplet = @build@ host_triplet = @host@ @WITH_SIMD_AMD64_TRUE@am__append_1 = amd64 @WITH_SIMD_AMD64_TRUE@am__append_2 = -DSIMD_USE_ACCEL=1 -DRFX_USE_ACCEL_AMD64=1 @WITH_SIMD_X86_TRUE@am__append_3 = x86 @WITH_SIMD_X86_TRUE@am__append_4 = -DSIMD_USE_ACCEL=1 -DRFX_USE_ACCEL_X86=1 subdir = src ACLOCAL_M4 = $(top_srcdir)/aclocal.m4 am__aclocal_m4_deps = $(top_srcdir)/m4/ax_append_compile_flags.m4 \ $(top_srcdir)/m4/ax_append_flag.m4 \ $(top_srcdir)/m4/ax_cflags_warn_all.m4 \ $(top_srcdir)/m4/ax_check_compile_flag.m4 \ $(top_srcdir)/m4/ax_require_defined.m4 \ $(top_srcdir)/m4/libtool.m4 $(top_srcdir)/m4/ltoptions.m4 \ $(top_srcdir)/m4/ltsugar.m4 $(top_srcdir)/m4/ltversion.m4 \ $(top_srcdir)/m4/lt~obsolete.m4 $(top_srcdir)/m4/nasm.m4 \ $(top_srcdir)/m4/pkg.m4 $(top_srcdir)/configure.ac am__configure_deps = $(am__aclocal_m4_deps) $(CONFIGURE_DEPENDENCIES) \ $(ACLOCAL_M4) DIST_COMMON = $(srcdir)/Makefile.am $(noinst_HEADERS) \ $(am__DIST_COMMON) mkinstalldirs = $(install_sh) -d CONFIG_HEADER = $(top_builddir)/config_ac.h CONFIG_CLEAN_FILES = CONFIG_CLEAN_VPATH_FILES = am__vpath_adj_setup = srcdirstrip=`echo "$(srcdir)" | sed 's|.|.|g'`; am__vpath_adj = case $$p in \ $(srcdir)/*) f=`echo "$$p" | sed "s|^$$srcdirstrip/||"`;; \ *) f=$$p;; \ esac; am__strip_dir = f=`echo $$p | sed -e 's|^.*/||'`; am__install_max = 40 am__nobase_strip_setup = \ srcdirstrip=`echo "$(srcdir)" | sed 's/[].[^$$\\*|]/\\\\&/g'` am__nobase_strip = \ for p in $$list; do echo "$$p"; done | sed -e "s|$$srcdirstrip/||" am__nobase_list = $(am__nobase_strip_setup); \ for p in $$list; do echo "$$p $$p"; done | \ sed "s| $$srcdirstrip/| |;"' / .*\//!s/ .*/ ./; s,\( .*\)/[^/]*$$,\1,' | \ $(AWK) 'BEGIN { files["."] = "" } { files[$$2] = files[$$2] " " $$1; \ if (++n[$$2] == $(am__install_max)) \ { print $$2, files[$$2]; n[$$2] = 0; files[$$2] = "" } } \ END { for (dir in files) print dir, files[dir] }' am__base_list = \ sed '$$!N;$$!N;$$!N;$$!N;$$!N;$$!N;$$!N;s/\n/ /g' | \ sed '$$!N;$$!N;$$!N;$$!N;s/\n/ /g' am__uninstall_files_from_dir = { \ test -z "$$files" \ || { test ! -d "$$dir" && test ! -f "$$dir" && test ! -r "$$dir"; } \ || { echo " ( cd '$$dir' && rm -f" $$files ")"; \ $(am__cd) "$$dir" && rm -f $$files; }; \ } am__installdirs = "$(DESTDIR)$(libdir)" LTLIBRARIES = $(lib_LTLIBRARIES) @WITH_SIMD_AMD64_FALSE@@WITH_SIMD_X86_TRUE@librfxencode_la_DEPENDENCIES = x86/librfxencode-x86.la @WITH_SIMD_AMD64_TRUE@librfxencode_la_DEPENDENCIES = \ @WITH_SIMD_AMD64_TRUE@ amd64/librfxencode-amd64.la am__objects_1 = am_librfxencode_la_OBJECTS = $(am__objects_1) rfxencode.lo \ rfxencode_compose.lo rfxencode_tile.lo rfxencode_dwt.lo \ rfxencode_quantization.lo rfxencode_differential.lo \ rfxencode_rlgr1.lo rfxencode_rlgr3.lo rfxencode_alpha.lo \ rfxencode_diff_rlgr1.lo rfxencode_diff_rlgr3.lo \ rfxencode_rgb_to_yuv.lo librfxencode_la_OBJECTS = $(am_librfxencode_la_OBJECTS) AM_V_lt = $(am__v_lt_@AM_V@) am__v_lt_ = $(am__v_lt_@AM_DEFAULT_V@) am__v_lt_0 = --silent am__v_lt_1 = AM_V_P = $(am__v_P_@AM_V@) am__v_P_ = $(am__v_P_@AM_DEFAULT_V@) am__v_P_0 = false am__v_P_1 = : AM_V_GEN = $(am__v_GEN_@AM_V@) am__v_GEN_ = $(am__v_GEN_@AM_DEFAULT_V@) am__v_GEN_0 = @echo " GEN " $@; am__v_GEN_1 = AM_V_at = $(am__v_at_@AM_V@) am__v_at_ = $(am__v_at_@AM_DEFAULT_V@) am__v_at_0 = @ am__v_at_1 = DEFAULT_INCLUDES = -I.@am__isrc@ -I$(top_builddir) depcomp = $(SHELL) $(top_srcdir)/depcomp am__depfiles_maybe = depfiles am__mv = mv -f COMPILE = $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) \ $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) LTCOMPILE = $(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) \ $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) \ $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) \ $(AM_CFLAGS) $(CFLAGS) AM_V_CC = $(am__v_CC_@AM_V@) am__v_CC_ = $(am__v_CC_@AM_DEFAULT_V@) am__v_CC_0 = @echo " CC " $@; am__v_CC_1 = CCLD = $(CC) LINK = $(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) \ $(LIBTOOLFLAGS) --mode=link $(CCLD) $(AM_CFLAGS) $(CFLAGS) \ $(AM_LDFLAGS) $(LDFLAGS) -o $@ AM_V_CCLD = $(am__v_CCLD_@AM_V@) am__v_CCLD_ = $(am__v_CCLD_@AM_DEFAULT_V@) am__v_CCLD_0 = @echo " CCLD " $@; am__v_CCLD_1 = SOURCES = $(librfxencode_la_SOURCES) DIST_SOURCES = $(librfxencode_la_SOURCES) RECURSIVE_TARGETS = all-recursive check-recursive cscopelist-recursive \ ctags-recursive dvi-recursive html-recursive info-recursive \ install-data-recursive install-dvi-recursive \ install-exec-recursive install-html-recursive \ install-info-recursive install-pdf-recursive \ install-ps-recursive install-recursive installcheck-recursive \ installdirs-recursive pdf-recursive ps-recursive \ tags-recursive uninstall-recursive am__can_run_installinfo = \ case $$AM_UPDATE_INFO_DIR in \ n|no|NO) false;; \ *) (install-info --version) >/dev/null 2>&1;; \ esac HEADERS = $(noinst_HEADERS) RECURSIVE_CLEAN_TARGETS = mostlyclean-recursive clean-recursive \ distclean-recursive maintainer-clean-recursive am__recursive_targets = \ $(RECURSIVE_TARGETS) \ $(RECURSIVE_CLEAN_TARGETS) \ $(am__extra_recursive_targets) AM_RECURSIVE_TARGETS = $(am__recursive_targets:-recursive=) TAGS CTAGS \ distdir am__tagged_files = $(HEADERS) $(SOURCES) $(TAGS_FILES) $(LISP) # Read a list of newline-separated strings from the standard input, # and print each of them once, without duplicates. Input order is # *not* preserved. am__uniquify_input = $(AWK) '\ BEGIN { nonempty = 0; } \ { items[$$0] = 1; nonempty = 1; } \ END { if (nonempty) { for (i in items) print i; }; } \ ' # Make sure the list of sources is unique. This is necessary because, # e.g., the same source file might be shared among _SOURCES variables # for different programs/libraries. am__define_uniq_tagged_files = \ list='$(am__tagged_files)'; \ unique=`for i in $$list; do \ if test -f "$$i"; then echo $$i; else echo $(srcdir)/$$i; fi; \ done | $(am__uniquify_input)` ETAGS = etags CTAGS = ctags DIST_SUBDIRS = amd64 x86 am__DIST_COMMON = $(srcdir)/Makefile.in $(top_srcdir)/depcomp DISTFILES = $(DIST_COMMON) $(DIST_SOURCES) $(TEXINFOS) $(EXTRA_DIST) am__relativize = \ dir0=`pwd`; \ sed_first='s,^\([^/]*\)/.*$$,\1,'; \ sed_rest='s,^[^/]*/*,,'; \ sed_last='s,^.*/\([^/]*\)$$,\1,'; \ sed_butlast='s,/*[^/]*$$,,'; \ while test -n "$$dir1"; do \ first=`echo "$$dir1" | sed -e "$$sed_first"`; \ if test "$$first" != "."; then \ if test "$$first" = ".."; then \ dir2=`echo "$$dir0" | sed -e "$$sed_last"`/"$$dir2"; \ dir0=`echo "$$dir0" | sed -e "$$sed_butlast"`; \ else \ first2=`echo "$$dir2" | sed -e "$$sed_first"`; \ if test "$$first2" = "$$first"; then \ dir2=`echo "$$dir2" | sed -e "$$sed_rest"`; \ else \ dir2="../$$dir2"; \ fi; \ dir0="$$dir0"/"$$first"; \ fi; \ fi; \ dir1=`echo "$$dir1" | sed -e "$$sed_rest"`; \ done; \ reldir="$$dir2" ACLOCAL = @ACLOCAL@ AMTAR = @AMTAR@ AM_DEFAULT_VERBOSITY = @AM_DEFAULT_VERBOSITY@ AR = @AR@ AUTOCONF = @AUTOCONF@ AUTOHEADER = @AUTOHEADER@ AUTOMAKE = @AUTOMAKE@ AWK = @AWK@ CC = @CC@ CCDEPMODE = @CCDEPMODE@ CFLAGS = @CFLAGS@ CPP = @CPP@ CPPFLAGS = @CPPFLAGS@ CYGPATH_W = @CYGPATH_W@ DEFS = @DEFS@ DEPDIR = @DEPDIR@ DLLTOOL = @DLLTOOL@ DSYMUTIL = @DSYMUTIL@ DUMPBIN = @DUMPBIN@ ECHO_C = @ECHO_C@ ECHO_N = @ECHO_N@ ECHO_T = @ECHO_T@ EGREP = @EGREP@ EXEEXT = @EXEEXT@ FGREP = @FGREP@ GREP = @GREP@ INSTALL = @INSTALL@ INSTALL_DATA = @INSTALL_DATA@ INSTALL_PROGRAM = @INSTALL_PROGRAM@ INSTALL_SCRIPT = @INSTALL_SCRIPT@ INSTALL_STRIP_PROGRAM = @INSTALL_STRIP_PROGRAM@ LD = @LD@ LDFLAGS = @LDFLAGS@ LIBOBJS = @LIBOBJS@ LIBS = @LIBS@ LIBTOOL = @LIBTOOL@ LIPO = @LIPO@ LN_S = @LN_S@ LTLIBOBJS = @LTLIBOBJS@ LT_SYS_LIBRARY_PATH = @LT_SYS_LIBRARY_PATH@ MAKEINFO = @MAKEINFO@ MANIFEST_TOOL = @MANIFEST_TOOL@ MKDIR_P = @MKDIR_P@ NAFLAGS = @NAFLAGS@ NASM = @NASM@ NM = @NM@ NMEDIT = @NMEDIT@ OBJDUMP = @OBJDUMP@ OBJEXT = @OBJEXT@ OTOOL = @OTOOL@ OTOOL64 = @OTOOL64@ PACKAGE = @PACKAGE@ PACKAGE_BUGREPORT = @PACKAGE_BUGREPORT@ PACKAGE_NAME = @PACKAGE_NAME@ PACKAGE_STRING = @PACKAGE_STRING@ PACKAGE_TARNAME = @PACKAGE_TARNAME@ PACKAGE_URL = @PACKAGE_URL@ PACKAGE_VERSION = @PACKAGE_VERSION@ PATH_SEPARATOR = @PATH_SEPARATOR@ RANLIB = @RANLIB@ SED = @SED@ SET_MAKE = @SET_MAKE@ SHELL = @SHELL@ STRIP = @STRIP@ VERSION = @VERSION@ abs_builddir = @abs_builddir@ abs_srcdir = @abs_srcdir@ abs_top_builddir = @abs_top_builddir@ abs_top_srcdir = @abs_top_srcdir@ ac_ct_AR = @ac_ct_AR@ ac_ct_CC = @ac_ct_CC@ ac_ct_DUMPBIN = @ac_ct_DUMPBIN@ am__include = @am__include@ am__leading_dot = @am__leading_dot@ am__quote = @am__quote@ am__tar = @am__tar@ am__untar = @am__untar@ bindir = @bindir@ build = @build@ build_alias = @build_alias@ build_cpu = @build_cpu@ build_os = @build_os@ build_vendor = @build_vendor@ builddir = @builddir@ datadir = @datadir@ datarootdir = @datarootdir@ docdir = @docdir@ dvidir = @dvidir@ exec_prefix = @exec_prefix@ host = @host@ host_alias = @host_alias@ host_cpu = @host_cpu@ host_os = @host_os@ host_vendor = @host_vendor@ htmldir = @htmldir@ includedir = @includedir@ infodir = @infodir@ install_sh = @install_sh@ libdir = @libdir@ libexecdir = @libexecdir@ localedir = @localedir@ localstatedir = @localstatedir@ mandir = @mandir@ mkdir_p = @mkdir_p@ oldincludedir = @oldincludedir@ pdfdir = @pdfdir@ pkgconfigdir = @pkgconfigdir@ prefix = @prefix@ program_transform_name = @program_transform_name@ psdir = @psdir@ sbindir = @sbindir@ sharedstatedir = @sharedstatedir@ srcdir = @srcdir@ sysconfdir = @sysconfdir@ target_alias = @target_alias@ top_build_prefix = @top_build_prefix@ top_builddir = @top_builddir@ top_srcdir = @top_srcdir@ EXTRA_DIST = common.asm nasm_lt.sh SUBDIRS = $(am__append_1) $(am__append_3) AM_CPPFLAGS = -I$(top_srcdir)/include $(am__append_2) $(am__append_4) @WITH_SIMD_AMD64_TRUE@librfxencode_la_LIBADD = amd64/librfxencode-amd64.la @WITH_SIMD_X86_TRUE@librfxencode_la_LIBADD = x86/librfxencode-x86.la noinst_HEADERS = \ rfx_bitstream.h \ rfxcommon.h \ rfxencode_compose.h \ rfxconstants.h \ rfxencode_alpha.h \ rfxencode_differential.h \ rfxencode_dwt.h \ rfxencode.h \ rfxencode_quantization.h \ rfxencode_rlgr1.h \ rfxencode_rlgr3.h \ rfxencode_tile.h \ rfxencode_diff_rlgr1.h \ rfxencode_diff_rlgr3.h \ rfxencode_rgb_to_yuv.h lib_LTLIBRARIES = librfxencode.la librfxencode_la_SOURCES = $(noinst_HEADERS) rfxencode.c \ rfxencode_compose.c rfxencode_tile.c rfxencode_dwt.c \ rfxencode_quantization.c rfxencode_differential.c \ rfxencode_rlgr1.c rfxencode_rlgr3.c rfxencode_alpha.c \ rfxencode_diff_rlgr1.c rfxencode_diff_rlgr3.c \ rfxencode_rgb_to_yuv.c all: all-recursive .SUFFIXES: .SUFFIXES: .c .lo .o .obj $(srcdir)/Makefile.in: $(srcdir)/Makefile.am $(am__configure_deps) @for dep in $?; do \ case '$(am__configure_deps)' in \ *$$dep*) \ ( cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh ) \ && { if test -f $@; then exit 0; else break; fi; }; \ exit 1;; \ esac; \ done; \ echo ' cd $(top_srcdir) && $(AUTOMAKE) --foreign src/Makefile'; \ $(am__cd) $(top_srcdir) && \ $(AUTOMAKE) --foreign src/Makefile Makefile: $(srcdir)/Makefile.in $(top_builddir)/config.status @case '$?' in \ *config.status*) \ cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh;; \ *) \ echo ' cd $(top_builddir) && $(SHELL) ./config.status $(subdir)/$@ $(am__depfiles_maybe)'; \ cd $(top_builddir) && $(SHELL) ./config.status $(subdir)/$@ $(am__depfiles_maybe);; \ esac; $(top_builddir)/config.status: $(top_srcdir)/configure $(CONFIG_STATUS_DEPENDENCIES) cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh $(top_srcdir)/configure: $(am__configure_deps) cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh $(ACLOCAL_M4): $(am__aclocal_m4_deps) cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh $(am__aclocal_m4_deps): install-libLTLIBRARIES: $(lib_LTLIBRARIES) @$(NORMAL_INSTALL) @list='$(lib_LTLIBRARIES)'; test -n "$(libdir)" || list=; \ list2=; for p in $$list; do \ if test -f $$p; then \ list2="$$list2 $$p"; \ else :; fi; \ done; \ test -z "$$list2" || { \ echo " $(MKDIR_P) '$(DESTDIR)$(libdir)'"; \ $(MKDIR_P) "$(DESTDIR)$(libdir)" || exit 1; \ echo " $(LIBTOOL) $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=install $(INSTALL) $(INSTALL_STRIP_FLAG) $$list2 '$(DESTDIR)$(libdir)'"; \ $(LIBTOOL) $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=install $(INSTALL) $(INSTALL_STRIP_FLAG) $$list2 "$(DESTDIR)$(libdir)"; \ } uninstall-libLTLIBRARIES: @$(NORMAL_UNINSTALL) @list='$(lib_LTLIBRARIES)'; test -n "$(libdir)" || list=; \ for p in $$list; do \ $(am__strip_dir) \ echo " $(LIBTOOL) $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=uninstall rm -f '$(DESTDIR)$(libdir)/$$f'"; \ $(LIBTOOL) $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=uninstall rm -f "$(DESTDIR)$(libdir)/$$f"; \ done clean-libLTLIBRARIES: -test -z "$(lib_LTLIBRARIES)" || rm -f $(lib_LTLIBRARIES) @list='$(lib_LTLIBRARIES)'; \ locs=`for p in $$list; do echo $$p; done | \ sed 's|^[^/]*$$|.|; s|/[^/]*$$||; s|$$|/so_locations|' | \ sort -u`; \ test -z "$$locs" || { \ echo rm -f $${locs}; \ rm -f $${locs}; \ } librfxencode.la: $(librfxencode_la_OBJECTS) $(librfxencode_la_DEPENDENCIES) $(EXTRA_librfxencode_la_DEPENDENCIES) $(AM_V_CCLD)$(LINK) -rpath $(libdir) $(librfxencode_la_OBJECTS) $(librfxencode_la_LIBADD) $(LIBS) mostlyclean-compile: -rm -f *.$(OBJEXT) distclean-compile: -rm -f *.tab.c @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/rfxencode.Plo@am__quote@ @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/rfxencode_alpha.Plo@am__quote@ @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/rfxencode_compose.Plo@am__quote@ @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/rfxencode_diff_rlgr1.Plo@am__quote@ @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/rfxencode_diff_rlgr3.Plo@am__quote@ @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/rfxencode_differential.Plo@am__quote@ @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/rfxencode_dwt.Plo@am__quote@ @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/rfxencode_quantization.Plo@am__quote@ @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/rfxencode_rgb_to_yuv.Plo@am__quote@ @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/rfxencode_rlgr1.Plo@am__quote@ @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/rfxencode_rlgr3.Plo@am__quote@ @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/rfxencode_tile.Plo@am__quote@ .c.o: @am__fastdepCC_TRUE@ $(AM_V_CC)$(COMPILE) -MT $@ -MD -MP -MF $(DEPDIR)/$*.Tpo -c -o $@ $< @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) $(DEPDIR)/$*.Tpo $(DEPDIR)/$*.Po @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='$<' object='$@' libtool=no @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(COMPILE) -c -o $@ $< .c.obj: @am__fastdepCC_TRUE@ $(AM_V_CC)$(COMPILE) -MT $@ -MD -MP -MF $(DEPDIR)/$*.Tpo -c -o $@ `$(CYGPATH_W) '$<'` @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) $(DEPDIR)/$*.Tpo $(DEPDIR)/$*.Po @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='$<' object='$@' libtool=no @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(COMPILE) -c -o $@ `$(CYGPATH_W) '$<'` .c.lo: @am__fastdepCC_TRUE@ $(AM_V_CC)$(LTCOMPILE) -MT $@ -MD -MP -MF $(DEPDIR)/$*.Tpo -c -o $@ $< @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) $(DEPDIR)/$*.Tpo $(DEPDIR)/$*.Plo @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='$<' object='$@' libtool=yes @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(LTCOMPILE) -c -o $@ $< mostlyclean-libtool: -rm -f *.lo clean-libtool: -rm -rf .libs _libs # This directory's subdirectories are mostly independent; you can cd # into them and run 'make' without going through this Makefile. # To change the values of 'make' variables: instead of editing Makefiles, # (1) if the variable is set in 'config.status', edit 'config.status' # (which will cause the Makefiles to be regenerated when you run 'make'); # (2) otherwise, pass the desired values on the 'make' command line. $(am__recursive_targets): @fail=; \ if $(am__make_keepgoing); then \ failcom='fail=yes'; \ else \ failcom='exit 1'; \ fi; \ dot_seen=no; \ target=`echo $@ | sed s/-recursive//`; \ case "$@" in \ distclean-* | maintainer-clean-*) list='$(DIST_SUBDIRS)' ;; \ *) list='$(SUBDIRS)' ;; \ esac; \ for subdir in $$list; do \ echo "Making $$target in $$subdir"; \ if test "$$subdir" = "."; then \ dot_seen=yes; \ local_target="$$target-am"; \ else \ local_target="$$target"; \ fi; \ ($(am__cd) $$subdir && $(MAKE) $(AM_MAKEFLAGS) $$local_target) \ || eval $$failcom; \ done; \ if test "$$dot_seen" = "no"; then \ $(MAKE) $(AM_MAKEFLAGS) "$$target-am" || exit 1; \ fi; test -z "$$fail" ID: $(am__tagged_files) $(am__define_uniq_tagged_files); mkid -fID $$unique tags: tags-recursive TAGS: tags tags-am: $(TAGS_DEPENDENCIES) $(am__tagged_files) set x; \ here=`pwd`; \ if ($(ETAGS) --etags-include --version) >/dev/null 2>&1; then \ include_option=--etags-include; \ empty_fix=.; \ else \ include_option=--include; \ empty_fix=; \ fi; \ list='$(SUBDIRS)'; for subdir in $$list; do \ if test "$$subdir" = .; then :; else \ test ! -f $$subdir/TAGS || \ set "$$@" "$$include_option=$$here/$$subdir/TAGS"; \ fi; \ done; \ $(am__define_uniq_tagged_files); \ shift; \ if test -z "$(ETAGS_ARGS)$$*$$unique"; then :; else \ test -n "$$unique" || unique=$$empty_fix; \ if test $$# -gt 0; then \ $(ETAGS) $(ETAGSFLAGS) $(AM_ETAGSFLAGS) $(ETAGS_ARGS) \ "$$@" $$unique; \ else \ $(ETAGS) $(ETAGSFLAGS) $(AM_ETAGSFLAGS) $(ETAGS_ARGS) \ $$unique; \ fi; \ fi ctags: ctags-recursive CTAGS: ctags ctags-am: $(TAGS_DEPENDENCIES) $(am__tagged_files) $(am__define_uniq_tagged_files); \ test -z "$(CTAGS_ARGS)$$unique" \ || $(CTAGS) $(CTAGSFLAGS) $(AM_CTAGSFLAGS) $(CTAGS_ARGS) \ $$unique GTAGS: here=`$(am__cd) $(top_builddir) && pwd` \ && $(am__cd) $(top_srcdir) \ && gtags -i $(GTAGS_ARGS) "$$here" cscopelist: cscopelist-recursive cscopelist-am: $(am__tagged_files) list='$(am__tagged_files)'; \ case "$(srcdir)" in \ [\\/]* | ?:[\\/]*) sdir="$(srcdir)" ;; \ *) sdir=$(subdir)/$(srcdir) ;; \ esac; \ for i in $$list; do \ if test -f "$$i"; then \ echo "$(subdir)/$$i"; \ else \ echo "$$sdir/$$i"; \ fi; \ done >> $(top_builddir)/cscope.files distclean-tags: -rm -f TAGS ID GTAGS GRTAGS GSYMS GPATH tags distdir: $(DISTFILES) @srcdirstrip=`echo "$(srcdir)" | sed 's/[].[^$$\\*]/\\\\&/g'`; \ topsrcdirstrip=`echo "$(top_srcdir)" | sed 's/[].[^$$\\*]/\\\\&/g'`; \ list='$(DISTFILES)'; \ dist_files=`for file in $$list; do echo $$file; done | \ sed -e "s|^$$srcdirstrip/||;t" \ -e "s|^$$topsrcdirstrip/|$(top_builddir)/|;t"`; \ case $$dist_files in \ */*) $(MKDIR_P) `echo "$$dist_files" | \ sed '/\//!d;s|^|$(distdir)/|;s,/[^/]*$$,,' | \ sort -u` ;; \ esac; \ for file in $$dist_files; do \ if test -f $$file || test -d $$file; then d=.; else d=$(srcdir); fi; \ if test -d $$d/$$file; then \ dir=`echo "/$$file" | sed -e 's,/[^/]*$$,,'`; \ if test -d "$(distdir)/$$file"; then \ find "$(distdir)/$$file" -type d ! -perm -700 -exec chmod u+rwx {} \;; \ fi; \ if test -d $(srcdir)/$$file && test $$d != $(srcdir); then \ cp -fpR $(srcdir)/$$file "$(distdir)$$dir" || exit 1; \ find "$(distdir)/$$file" -type d ! -perm -700 -exec chmod u+rwx {} \;; \ fi; \ cp -fpR $$d/$$file "$(distdir)$$dir" || exit 1; \ else \ test -f "$(distdir)/$$file" \ || cp -p $$d/$$file "$(distdir)/$$file" \ || exit 1; \ fi; \ done @list='$(DIST_SUBDIRS)'; for subdir in $$list; do \ if test "$$subdir" = .; then :; else \ $(am__make_dryrun) \ || test -d "$(distdir)/$$subdir" \ || $(MKDIR_P) "$(distdir)/$$subdir" \ || exit 1; \ dir1=$$subdir; dir2="$(distdir)/$$subdir"; \ $(am__relativize); \ new_distdir=$$reldir; \ dir1=$$subdir; dir2="$(top_distdir)"; \ $(am__relativize); \ new_top_distdir=$$reldir; \ echo " (cd $$subdir && $(MAKE) $(AM_MAKEFLAGS) top_distdir="$$new_top_distdir" distdir="$$new_distdir" \\"; \ echo " am__remove_distdir=: am__skip_length_check=: am__skip_mode_fix=: distdir)"; \ ($(am__cd) $$subdir && \ $(MAKE) $(AM_MAKEFLAGS) \ top_distdir="$$new_top_distdir" \ distdir="$$new_distdir" \ am__remove_distdir=: \ am__skip_length_check=: \ am__skip_mode_fix=: \ distdir) \ || exit 1; \ fi; \ done check-am: all-am check: check-recursive all-am: Makefile $(LTLIBRARIES) $(HEADERS) installdirs: installdirs-recursive installdirs-am: for dir in "$(DESTDIR)$(libdir)"; do \ test -z "$$dir" || $(MKDIR_P) "$$dir"; \ done install: install-recursive install-exec: install-exec-recursive install-data: install-data-recursive uninstall: uninstall-recursive install-am: all-am @$(MAKE) $(AM_MAKEFLAGS) install-exec-am install-data-am installcheck: installcheck-recursive install-strip: if test -z '$(STRIP)'; then \ $(MAKE) $(AM_MAKEFLAGS) INSTALL_PROGRAM="$(INSTALL_STRIP_PROGRAM)" \ install_sh_PROGRAM="$(INSTALL_STRIP_PROGRAM)" INSTALL_STRIP_FLAG=-s \ install; \ else \ $(MAKE) $(AM_MAKEFLAGS) INSTALL_PROGRAM="$(INSTALL_STRIP_PROGRAM)" \ install_sh_PROGRAM="$(INSTALL_STRIP_PROGRAM)" INSTALL_STRIP_FLAG=-s \ "INSTALL_PROGRAM_ENV=STRIPPROG='$(STRIP)'" install; \ fi mostlyclean-generic: clean-generic: distclean-generic: -test -z "$(CONFIG_CLEAN_FILES)" || rm -f $(CONFIG_CLEAN_FILES) -test . = "$(srcdir)" || test -z "$(CONFIG_CLEAN_VPATH_FILES)" || rm -f $(CONFIG_CLEAN_VPATH_FILES) maintainer-clean-generic: @echo "This command is intended for maintainers to use" @echo "it deletes files that may require special tools to rebuild." clean: clean-recursive clean-am: clean-generic clean-libLTLIBRARIES clean-libtool \ mostlyclean-am distclean: distclean-recursive -rm -rf ./$(DEPDIR) -rm -f Makefile distclean-am: clean-am distclean-compile distclean-generic \ distclean-tags dvi: dvi-recursive dvi-am: html: html-recursive html-am: info: info-recursive info-am: install-data-am: install-dvi: install-dvi-recursive install-dvi-am: install-exec-am: install-libLTLIBRARIES install-html: install-html-recursive install-html-am: install-info: install-info-recursive install-info-am: install-man: install-pdf: install-pdf-recursive install-pdf-am: install-ps: install-ps-recursive install-ps-am: installcheck-am: maintainer-clean: maintainer-clean-recursive -rm -rf ./$(DEPDIR) -rm -f Makefile maintainer-clean-am: distclean-am maintainer-clean-generic mostlyclean: mostlyclean-recursive mostlyclean-am: mostlyclean-compile mostlyclean-generic \ mostlyclean-libtool pdf: pdf-recursive pdf-am: ps: ps-recursive ps-am: uninstall-am: uninstall-libLTLIBRARIES .MAKE: $(am__recursive_targets) install-am install-strip .PHONY: $(am__recursive_targets) CTAGS GTAGS TAGS all all-am check \ check-am clean clean-generic clean-libLTLIBRARIES \ clean-libtool cscopelist-am ctags ctags-am distclean \ distclean-compile distclean-generic distclean-libtool \ distclean-tags distdir dvi dvi-am html html-am info info-am \ install install-am install-data install-data-am install-dvi \ install-dvi-am install-exec install-exec-am install-html \ install-html-am install-info install-info-am \ install-libLTLIBRARIES install-man install-pdf install-pdf-am \ install-ps install-ps-am install-strip installcheck \ installcheck-am installdirs installdirs-am maintainer-clean \ maintainer-clean-generic mostlyclean mostlyclean-compile \ mostlyclean-generic mostlyclean-libtool pdf pdf-am ps ps-am \ tags tags-am uninstall uninstall-am uninstall-libLTLIBRARIES .PRECIOUS: Makefile # Tell versions [3.59,3.63) of GNU make to not export all variables. # Otherwise a system limit (for SysV at least) may be exceeded. .NOEXPORT: xrdp-0.9.5/librfxcodec/src/amd64/000755 001751 001751 00000000000 13220731017 016404 5ustar00metameta000000 000000 xrdp-0.9.5/librfxcodec/src/rfxencode_alpha.c000644 001751 001751 00000015447 13127342056 021001 0ustar00metameta000000 000000 /** * librfxcodec: A Remote Desktop Protocol client. * RemoteFX Codec Library * * Copyright 2015-2017 Jay Sorg * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ #if defined(HAVE_CONFIG_H) #include #endif #include #include #include #include #include "rfxcommon.h" #include "rfxencode.h" #include "rfxconstants.h" #include "rfxencode_tile.h" #define LLOG_LEVEL 1 #define LLOGLN(_level, _args) \ do { if (_level < LLOG_LEVEL) { printf _args ; printf("\n"); } } while (0) #if 1 /*****************************************************************************/ static int fdelta(const char *in_plane, char *out_plane, int cx, int cy) { char delta; const char *src8; char *dst8; int index; int jndex; memcpy(out_plane, in_plane, cx); src8 = in_plane; dst8 = out_plane; for (jndex = 1; jndex < cy; jndex++) { for (index = 0; index < cx; index++) { delta = src8[cx] - src8[0]; if (delta & 0x80) { delta = (((~delta) + 1) << 1) - 1; } else { delta = delta << 1; } dst8[cx] = delta; src8++; dst8++; } } return 0; } #endif #if 0 /*****************************************************************************/ #define DELTA_ONE \ do { \ delta = src8[cx] - src8[0]; \ is_neg = (delta >> 7) & 1; \ dst8[cx] = (((delta ^ -is_neg) + is_neg) << 1) - is_neg; \ src8++; \ dst8++; \ } while (0) /*****************************************************************************/ static int fdelta(char *in_plane, char *out_plane, int cx, int cy) { char delta; char is_neg; char *src8; char *dst8; char *src8_end; memcpy(out_plane, in_plane, cx); src8 = in_plane; dst8 = out_plane; src8_end = src8 + (cx * cy - cx); while (src8 + 8 <= src8_end) { DELTA_ONE; DELTA_ONE; DELTA_ONE; DELTA_ONE; DELTA_ONE; DELTA_ONE; DELTA_ONE; DELTA_ONE; } while (src8 < src8_end) { DELTA_ONE; } return 0; } #endif /*****************************************************************************/ static int fout(int collen, int replen, char *colptr, STREAM *s) { int code; int lcollen; int lreplen; int cont; LLOGLN(10, ("fout: collen %d replen %d", collen, replen)); cont = collen > 13; while (cont) { lcollen = collen; if (lcollen > 15) { lcollen = 15; } code = lcollen << 4; stream_write_uint8(s, code); memcpy(s->p, colptr, lcollen); s->p += lcollen; colptr += lcollen; collen -= lcollen; cont = collen > 13; } cont = (collen > 0) || (replen > 0); while (cont) { lreplen = replen; if ((collen == 0) && (lreplen > 15)) { /* big run */ if (lreplen > 47) { lreplen = 47; } LLOGLN(10, ("fout: big run lreplen %d", lreplen)); replen -= lreplen; code = ((lreplen & 0xF) << 4) | ((lreplen & 0xF0) >> 4); stream_write_uint8(s, code); colptr += lreplen; } else { if (lreplen > 15) { lreplen = 15; } replen -= lreplen; if (lreplen < 3) { collen += lreplen; lreplen = 0; } code = (collen << 4) | lreplen; stream_write_uint8(s, code); memcpy(s->p, colptr, collen); s->p += collen; colptr += collen + lreplen; collen = 0; } cont = replen > 0; } return 0; } /*****************************************************************************/ static int fpack(char *plane, int cx, int cy, STREAM *s) { char *ptr8; char *colptr; char *lend; uint8 *holdp; int jndex; int collen; int replen; LLOGLN(10, ("fpack:")); holdp = s->p; for (jndex = 0; jndex < cy; jndex++) { LLOGLN(10, ("line start line %d cx %d cy %d", jndex, cx, cy)); ptr8 = (char *) (plane + jndex * cx); lend = ptr8 + (cx - 1); colptr = ptr8; if (colptr[0] == 0) { collen = 0; replen = 1; } else { collen = 1; replen = 0; } while (ptr8 < lend) { if (ptr8[0] == ptr8[1]) { replen++; } else { if (replen > 0) { if (replen < 3) { collen += replen + 1; replen = 0; } else { fout(collen, replen, colptr, s); colptr = ptr8 + 1; replen = 0; collen = 1; } } else { collen++; } } ptr8++; } /* end of line */ fout(collen, replen, colptr, s); } return (int) (s->p - holdp); } /*****************************************************************************/ int rfx_encode_plane(struct rfxencode *enc, const uint8 *plane, int cx, int cy, STREAM *s) { const char *org_plane; char *delta_plane; int bytes; uint8 *holdp; org_plane = (const char *) plane; delta_plane = (char *) (enc->dwt_buffer1); fdelta(org_plane, delta_plane, cx, cy); holdp = s->p; stream_write_uint8(s, 0x10); /* flags, RLE */ bytes = fpack(delta_plane, cx, cy, s); if (bytes > cx * cy) { LLOGLN(10, ("rfx_encode_plane: too big bytes %d", bytes)); s->p = holdp; stream_write_uint8(s, 0); /* flags */ memcpy(s->p, plane, cx * cy); s->p += cx * cy; stream_write_uint8(s, 0); /* pad if not RLE */ bytes = cx * cy + 2; } else { LLOGLN(10, ("rfx_encode_plane: ok bytes %d", bytes)); } return bytes; } xrdp-0.9.5/librfxcodec/src/rfxencode_quantization.h000644 001751 001751 00000001557 12777440111 022445 0ustar00metameta000000 000000 /** * FreeRDP: A Remote Desktop Protocol client. * RemoteFX Codec Library - Quantization * * Copyright 2011 Vic Lee * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ #ifndef __RFX_QUANTIZATION_H #define __RFX_QUANTIZATION_H #include "rfxcommon.h" int rfx_quantization_encode(sint16 *buffer, const char *quantization_values); #endif /* __RFX_QUANTIZATION_H */ xrdp-0.9.5/librfxcodec/src/rfxencode_compose.c000644 001751 001751 00000050702 13127342076 021354 0ustar00metameta000000 000000 /** * FreeRDP: A Remote Desktop Protocol client. * RemoteFX Codec Library * * Copyright 2011 Vic Lee * Copyright 2015-2017 Jay Sorg * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ #if defined(HAVE_CONFIG_H) #include #endif #include #include #include #include #include "rfxcommon.h" #include "rfxencode.h" #include "rfxconstants.h" #include "rfxencode_tile.h" #define LLOG_LEVEL 1 #define LLOGLN(_level, _args) \ do { if (_level < LLOG_LEVEL) { printf _args ; printf("\n"); } } while (0) /* * LL3, LH3, HL3, HH3, LH2, HL2, HH2, LH1, HL1, HH1 */ static const unsigned char g_rfx_default_quantization_values[] = { 0x66, 0x66, 0x77, 0x88, 0x98 }; /******************************************************************************/ static int rfx_compose_message_sync(struct rfxencode *enc, STREAM *s) { if (stream_get_left(s) < 12) { return 1; } stream_write_uint16(s, WBT_SYNC); /* BlockT.blockType */ stream_write_uint32(s, 12); /* BlockT.blockLen */ stream_write_uint32(s, WF_MAGIC); /* magic */ stream_write_uint16(s, WF_VERSION_1_0); /* version */ return 0; } /******************************************************************************/ static int rfx_compose_message_context(struct rfxencode *enc, STREAM *s) { uint16 properties; int rlgr; if (stream_get_left(s) < 13) { return 1; } stream_write_uint16(s, WBT_CONTEXT); /* CodecChannelT.blockType */ stream_write_uint32(s, 13); /* CodecChannelT.blockLen */ stream_write_uint8(s, 1); /* CodecChannelT.codecId */ stream_write_uint8(s, 255); /* CodecChannelT.channelId */ stream_write_uint8(s, 0); /* ctxId */ stream_write_uint16(s, CT_TILE_64x64); /* tileSize */ /* properties */ properties = enc->flags; /* flags */ properties |= (COL_CONV_ICT << 3); /* cct */ properties |= (CLW_XFORM_DWT_53_A << 5); /* xft */ rlgr = enc->mode == RLGR1 ? CLW_ENTROPY_RLGR1 : CLW_ENTROPY_RLGR3; properties |= rlgr << 9; /* et */ properties |= (SCALAR_QUANTIZATION << 13); /* qt */ stream_write_uint16(s, properties); /* properties in tilesets: note that this has different format from * the one in TS_RFX_CONTEXT */ properties = 1; /* lt */ properties |= (enc->flags << 1); /* flags */ properties |= (COL_CONV_ICT << 4); /* cct */ properties |= (CLW_XFORM_DWT_53_A << 6); /* xft */ properties |= rlgr << 10; /* et */ properties |= (SCALAR_QUANTIZATION << 14); /* qt */ enc->properties = properties; return 0; } /******************************************************************************/ static int rfx_compose_message_codec_versions(struct rfxencode *enc, STREAM *s) { if (stream_get_left(s) < 10) { return 1; } stream_write_uint16(s, WBT_CODEC_VERSIONS); /* BlockT.blockType */ stream_write_uint32(s, 10); /* BlockT.blockLen */ stream_write_uint8(s, 1); /* numCodecs */ stream_write_uint8(s, 1); /* codecs.codecId */ stream_write_uint16(s, WF_VERSION_1_0); /* codecs.version */ return 0; } /******************************************************************************/ static int rfx_compose_message_channels(struct rfxencode *enc, STREAM *s) { if (stream_get_left(s) < 12) { return 1; } stream_write_uint16(s, WBT_CHANNELS); /* BlockT.blockType */ stream_write_uint32(s, 12); /* BlockT.blockLen */ stream_write_uint8(s, 1); /* numChannels */ stream_write_uint8(s, 0); /* Channel.channelId */ stream_write_uint16(s, enc->width); /* Channel.width */ stream_write_uint16(s, enc->height); /* Channel.height */ return 0; } /******************************************************************************/ int rfx_compose_message_header(struct rfxencode *enc, STREAM *s) { if (rfx_compose_message_sync(enc, s) != 0) { return 1; } if (rfx_compose_message_context(enc, s) != 0) { return 1; } if (rfx_compose_message_codec_versions(enc, s) != 0) { return 1; } if (rfx_compose_message_channels(enc, s) != 0) { return 1; } enc->header_processed = 1; return 0; } /******************************************************************************/ static int rfx_compose_message_frame_begin(struct rfxencode *enc, STREAM *s) { if (stream_get_left(s) < 14) { return 1; } stream_write_uint16(s, WBT_FRAME_BEGIN); /* CodecChannelT.blockType */ stream_write_uint32(s, 14); /* CodecChannelT.blockLen */ stream_write_uint8(s, 1); /* CodecChannelT.codecId */ stream_write_uint8(s, 0); /* CodecChannelT.channelId */ stream_write_uint32(s, enc->frame_idx); /* frameIdx */ stream_write_uint16(s, 1); /* numRegions */ enc->frame_idx++; return 0; } /******************************************************************************/ static int rfx_compose_message_region(struct rfxencode *enc, STREAM *s, const struct rfx_rect *regions, int num_regions) { int size; int i; size = 15 + num_regions * 8; if (stream_get_left(s) < size) { return 1; } stream_write_uint16(s, WBT_REGION); /* CodecChannelT.blockType */ stream_write_uint32(s, size); /* set CodecChannelT.blockLen later */ stream_write_uint8(s, 1); /* CodecChannelT.codecId */ stream_write_uint8(s, 0); /* CodecChannelT.channelId */ stream_write_uint8(s, 1); /* regionFlags */ stream_write_uint16(s, num_regions); /* numRects */ for (i = 0; i < num_regions; i++) { stream_write_uint16(s, regions[i].x); stream_write_uint16(s, regions[i].y); stream_write_uint16(s, regions[i].cx); stream_write_uint16(s, regions[i].cy); } stream_write_uint16(s, CBT_REGION); /* regionType */ stream_write_uint16(s, 1); /* numTilesets */ return 0; } /******************************************************************************/ static int rfx_compose_message_tile_yuv(struct rfxencode *enc, STREAM *s, const char *tile_data, int tile_width, int tile_height, int stride_bytes, const char *quantVals, int quantIdxY, int quantIdxCb, int quantIdxCr, int xIdx, int yIdx) { int YLen = 0; int CbLen = 0; int CrLen = 0; int start_pos; int end_pos; start_pos = stream_get_pos(s); stream_write_uint16(s, CBT_TILE); /* BlockT.blockType */ stream_seek_uint32(s); /* set BlockT.blockLen later */ stream_write_uint8(s, quantIdxY); stream_write_uint8(s, quantIdxCb); stream_write_uint8(s, quantIdxCr); stream_write_uint16(s, xIdx); stream_write_uint16(s, yIdx); stream_seek(s, 6); /* YLen, CbLen, CrLen */ if (rfx_encode_yuv(enc, tile_data, tile_width, tile_height, stride_bytes, quantVals + quantIdxY * 5, quantVals + quantIdxCb * 5, quantVals + quantIdxCr * 5, s, &YLen, &CbLen, &CrLen) != 0) { return 1; } end_pos = stream_get_pos(s); stream_set_pos(s, start_pos + 2); stream_write_uint32(s, 19 + YLen + CbLen + CrLen); /* BlockT.blockLen */ stream_set_pos(s, start_pos + 13); stream_write_uint16(s, YLen); stream_write_uint16(s, CbLen); stream_write_uint16(s, CrLen); stream_set_pos(s, end_pos); return 0; } /******************************************************************************/ static int rfx_compose_message_tile_yuva(struct rfxencode *enc, STREAM *s, const char *tile_data, int tile_width, int tile_height, int stride_bytes, const char *quantVals, int quantIdxY, int quantIdxCb, int quantIdxCr, int xIdx, int yIdx) { int YLen = 0; int CbLen = 0; int CrLen = 0; int ALen = 0; int start_pos; int end_pos; start_pos = stream_get_pos(s); stream_write_uint16(s, CBT_TILE); /* BlockT.blockType */ stream_seek_uint32(s); /* set BlockT.blockLen later */ stream_write_uint8(s, quantIdxY); stream_write_uint8(s, quantIdxCb); stream_write_uint8(s, quantIdxCr); stream_write_uint16(s, xIdx); stream_write_uint16(s, yIdx); stream_seek(s, 8); /* YLen, CbLen, CrLen, ALen */ if (rfx_encode_yuva(enc, tile_data, tile_width, tile_height, stride_bytes, quantVals + quantIdxY * 5, quantVals + quantIdxCb * 5, quantVals + quantIdxCr * 5, s, &YLen, &CbLen, &CrLen, &ALen) != 0) { return 1; } end_pos = stream_get_pos(s); stream_set_pos(s, start_pos + 2); stream_write_uint32(s, 19 + YLen + CbLen + CrLen + ALen); /* BlockT.blockLen */ stream_set_pos(s, start_pos + 13); stream_write_uint16(s, YLen); stream_write_uint16(s, CbLen); stream_write_uint16(s, CrLen); stream_write_uint16(s, ALen); stream_set_pos(s, end_pos); return 0; } /******************************************************************************/ static int rfx_compose_message_tile_rgb(struct rfxencode *enc, STREAM *s, const char *tile_data, int tile_width, int tile_height, int stride_bytes, const char *quantVals, int quantIdxY, int quantIdxCb, int quantIdxCr, int xIdx, int yIdx) { int YLen = 0; int CbLen = 0; int CrLen = 0; int start_pos; int end_pos; start_pos = stream_get_pos(s); stream_write_uint16(s, CBT_TILE); /* BlockT.blockType */ stream_seek_uint32(s); /* set BlockT.blockLen later */ stream_write_uint8(s, quantIdxY); stream_write_uint8(s, quantIdxCb); stream_write_uint8(s, quantIdxCr); stream_write_uint16(s, xIdx); stream_write_uint16(s, yIdx); stream_seek(s, 6); /* YLen, CbLen, CrLen */ if (rfx_encode_rgb(enc, tile_data, tile_width, tile_height, stride_bytes, quantVals + quantIdxY * 5, quantVals + quantIdxCb * 5, quantVals + quantIdxCr * 5, s, &YLen, &CbLen, &CrLen) != 0) { return 1; } end_pos = stream_get_pos(s); stream_set_pos(s, start_pos + 2); stream_write_uint32(s, 19 + YLen + CbLen + CrLen); /* BlockT.blockLen */ stream_set_pos(s, start_pos + 13); stream_write_uint16(s, YLen); stream_write_uint16(s, CbLen); stream_write_uint16(s, CrLen); stream_set_pos(s, end_pos); return 0; } /******************************************************************************/ static int rfx_compose_message_tile_argb(struct rfxencode *enc, STREAM *s, const char *tile_data, int tile_width, int tile_height, int stride_bytes, const char *quantVals, int quantIdxY, int quantIdxCb, int quantIdxCr, int xIdx, int yIdx) { int YLen = 0; int CbLen = 0; int CrLen = 0; int ALen = 0; int start_pos; int end_pos; LLOGLN(10, ("rfx_compose_message_tile_argb:")); start_pos = stream_get_pos(s); stream_write_uint16(s, CBT_TILE); /* BlockT.blockType */ stream_seek_uint32(s); /* set BlockT.blockLen later */ stream_write_uint8(s, quantIdxY); stream_write_uint8(s, quantIdxCb); stream_write_uint8(s, quantIdxCr); stream_write_uint16(s, xIdx); stream_write_uint16(s, yIdx); stream_seek(s, 8); /* YLen, CbLen, CrLen, ALen */ if (rfx_encode_argb(enc, tile_data, tile_width, tile_height, stride_bytes, quantVals + quantIdxY * 5, quantVals + quantIdxCb * 5, quantVals + quantIdxCr * 5, s, &YLen, &CbLen, &CrLen, &ALen) != 0) { LLOGLN(10, ("rfx_compose_message_tile_argb: rfx_encode_argb failed")); return 1; } end_pos = stream_get_pos(s); stream_set_pos(s, start_pos + 2); stream_write_uint32(s, 19 + YLen + CbLen + CrLen + ALen); /* BlockT.blockLen */ stream_set_pos(s, start_pos + 13); stream_write_uint16(s, YLen); stream_write_uint16(s, CbLen); stream_write_uint16(s, CrLen); stream_write_uint16(s, ALen); stream_set_pos(s, end_pos); return 0; } /******************************************************************************/ static int rfx_compose_message_tileset(struct rfxencode *enc, STREAM *s, const char *buf, int width, int height, int stride_bytes, const struct rfx_tile *tiles, int num_tiles, const char *quants, int num_quants, int flags) { int size; int start_pos; int end_pos; int index; int numQuants; const char *quantVals; int quantIdxY; int quantIdxCb; int quantIdxCr; int numTiles; int tilesDataSize; int x; int y; int cx; int cy; const char *tile_data; LLOGLN(10, ("rfx_compose_message_tileset:")); if (quants == 0) { numQuants = 1; quantVals = (const char *) g_rfx_default_quantization_values; } else { numQuants = num_quants; quantVals = quants; } numTiles = num_tiles; size = 22 + numQuants * 5; start_pos = stream_get_pos(s); if (flags & RFX_FLAGS_ALPHAV1) { LLOGLN(10, ("rfx_compose_message_tileset: RFX_FLAGS_ALPHAV1 set")); stream_write_uint16(s, WBT_EXTENSION_PLUS); /* CodecChannelT.blockType */ } else { stream_write_uint16(s, WBT_EXTENSION); /* CodecChannelT.blockType */ } stream_seek_uint32(s); /* set CodecChannelT.blockLen later */ stream_write_uint8(s, 1); /* CodecChannelT.codecId */ stream_write_uint8(s, 0); /* CodecChannelT.channelId */ stream_write_uint16(s, CBT_TILESET); /* subtype */ stream_write_uint16(s, 0); /* idx */ stream_write_uint16(s, enc->properties); /* properties */ stream_write_uint8(s, numQuants); /* numQuants */ stream_write_uint8(s, 0x40); /* tileSize */ stream_write_uint16(s, numTiles); /* numTiles */ stream_seek_uint32(s); /* set tilesDataSize later */ memcpy(s->p, quantVals, numQuants * 5); s->p += numQuants * 5; end_pos = stream_get_pos(s); if (enc->format == RFX_FORMAT_YUV) { if (flags & RFX_FLAGS_ALPHAV1) { for (index = 0; index < numTiles; index++) { x = tiles[index].x; y = tiles[index].y; cx = tiles[index].cx; cy = tiles[index].cy; quantIdxY = tiles[index].quant_y; quantIdxCb = tiles[index].quant_cb; quantIdxCr = tiles[index].quant_cr; tile_data = buf + (y << 8) * (stride_bytes >> 8) + (x << 8); if (rfx_compose_message_tile_yuva(enc, s, tile_data, cx, cy, stride_bytes, quantVals, quantIdxY, quantIdxCb, quantIdxCr, x / 64, y / 64) != 0) { return 1; } } } else { for (index = 0; index < numTiles; index++) { x = tiles[index].x; y = tiles[index].y; cx = tiles[index].cx; cy = tiles[index].cy; quantIdxY = tiles[index].quant_y; quantIdxCb = tiles[index].quant_cb; quantIdxCr = tiles[index].quant_cr; tile_data = buf + (y << 8) * (stride_bytes >> 8) + (x << 8); if (rfx_compose_message_tile_yuv(enc, s, tile_data, cx, cy, stride_bytes, quantVals, quantIdxY, quantIdxCb, quantIdxCr, x / 64, y / 64) != 0) { return 1; } } } } else { if (flags & RFX_FLAGS_ALPHAV1) { for (index = 0; index < numTiles; index++) { x = tiles[index].x; y = tiles[index].y; cx = tiles[index].cx; cy = tiles[index].cy; quantIdxY = tiles[index].quant_y; quantIdxCb = tiles[index].quant_cb; quantIdxCr = tiles[index].quant_cr; tile_data = buf + y * stride_bytes + x * (enc->bits_per_pixel / 8); if (rfx_compose_message_tile_argb(enc, s, tile_data, cx, cy, stride_bytes, quantVals, quantIdxY, quantIdxCb, quantIdxCr, x / 64, y / 64) != 0) { return 1; } } } else { for (index = 0; index < numTiles; index++) { x = tiles[index].x; y = tiles[index].y; cx = tiles[index].cx; cy = tiles[index].cy; quantIdxY = tiles[index].quant_y; quantIdxCb = tiles[index].quant_cb; quantIdxCr = tiles[index].quant_cr; tile_data = buf + y * stride_bytes + x * (enc->bits_per_pixel / 8); if (rfx_compose_message_tile_rgb(enc, s, tile_data, cx, cy, stride_bytes, quantVals, quantIdxY, quantIdxCb, quantIdxCr, x / 64, y / 64) != 0) { return 1; } } } } tilesDataSize = stream_get_pos(s) - end_pos; size += tilesDataSize; end_pos = stream_get_pos(s); stream_set_pos(s, start_pos + 2); stream_write_uint32(s, size); /* CodecChannelT.blockLen */ stream_set_pos(s, start_pos + 18); stream_write_uint32(s, tilesDataSize); stream_set_pos(s, end_pos); return 0; } /******************************************************************************/ static int rfx_compose_message_frame_end(struct rfxencode *enc, STREAM *s) { if (stream_get_left(s) < 8) { return 1; } stream_write_uint16(s, WBT_FRAME_END); /* CodecChannelT.blockType */ stream_write_uint32(s, 8); /* CodecChannelT.blockLen */ stream_write_uint8(s, 1); /* CodecChannelT.codecId */ stream_write_uint8(s, 0); /* CodecChannelT.channelId */ return 0; } /******************************************************************************/ int rfx_compose_message_data(struct rfxencode *enc, STREAM *s, const struct rfx_rect *regions, int num_regions, const char *buf, int width, int height, int stride_bytes, const struct rfx_tile *tiles, int num_tiles, const char *quants, int num_quants, int flags) { if (rfx_compose_message_frame_begin(enc, s) != 0) { return 1; } if (rfx_compose_message_region(enc, s, regions, num_regions) != 0) { return 1; } if (rfx_compose_message_tileset(enc, s, buf, width, height, stride_bytes, tiles, num_tiles, quants, num_quants, flags) != 0) { return 1; } if (rfx_compose_message_frame_end(enc, s) != 0) { return 1; } return 0; } xrdp-0.9.5/librfxcodec/src/rfxencode.h000644 001751 001751 00000004311 13220730305 017615 0ustar00metameta000000 000000 /** * RFX codec encoder * * Copyright 2014-2015 Jay Sorg * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ #ifndef __RFXENCODE_H #define __RFXENCODE_H struct rfxencode; typedef int (*rfx_encode_rgb_to_yuv_proc)(struct rfxencode *enc, const char *rgb_data, int width, int height, int stride_bytes); typedef int (*rfx_encode_argb_to_yuva_proc)(struct rfxencode *enc, const char *argb_data, int width, int height, int stride_bytes); typedef int (*rfx_encode_proc)(struct rfxencode *enc, const char *qtable, const uint8 *data, uint8 *buffer, int buffer_size, int *size); struct rfxencode { int width; int height; int frame_idx; int header_processed; int mode; int properties; int flags; int bits_per_pixel; int format; int pad0[7]; uint8 a_buffer[4096]; uint8 y_r_buffer[4096]; uint8 u_g_buffer[4096]; uint8 v_b_buffer[4096]; uint8 pad1[16]; sint16 dwt_buffer_a[4096]; sint16 dwt_buffer1_a[4096]; sint16 dwt_buffer2_a[4096]; uint8 pad2[16]; sint16 *dwt_buffer; sint16 *dwt_buffer1; sint16 *dwt_buffer2; rfx_encode_proc rfx_encode; rfx_encode_rgb_to_yuv_proc rfx_encode_rgb_to_yuv; rfx_encode_argb_to_yuva_proc rfx_encode_argb_to_yuva; int got_sse2; int got_sse3; int got_sse41; int got_sse42; int got_sse4a; int got_popcnt; int got_lzcnt; int got_neon; }; #endif xrdp-0.9.5/librfxcodec/src/rfxencode_rlgr3.c000644 001751 001751 00000014566 13061652764 020755 0ustar00metameta000000 000000 /** * FreeRDP: A Remote Desktop Protocol client. * RemoteFX Codec Library - RLGR * * Copyright 2011 Vic Lee * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ /** * This implementation of RLGR refers to * [MS-RDPRFX] 3.1.8.1.7.3 RLGR1/RLGR3 Pseudocode */ #if defined(HAVE_CONFIG_H) #include #endif #include #include #include #include "rfx_bitstream.h" /* Constants used within the RLGR1/RLGR3 algorithm */ #define KPMAX (80) /* max value for kp or krp */ #define LSGR (3) /* shift count to convert kp to k */ #define UP_GR (4) /* increase in kp after a zero run in RL mode */ #define DN_GR (6) /* decrease in kp after a nonzero symbol in RL mode */ #define UQ_GR (3) /* increase in kp after nonzero symbol in GR mode */ #define DQ_GR (3) /* decrease in kp after zero symbol in GR mode */ /* Returns the least number of bits required to represent a given value */ #define GetMinBits(_val, _nbits) \ do { \ uint32 _v = _val; \ _nbits = 0; \ while (_v) \ { \ _v >>= 1; \ _nbits++; \ } \ } while (0) /* * Update the passed parameter and clamp it to the range [0, KPMAX] * Return the value of parameter right-shifted by LSGR */ #define UpdateParam(_param, _deltaP, _k) \ do { \ _param += _deltaP; \ if (_param > KPMAX) \ { \ _param = KPMAX; \ } \ if (_param < 0) \ { \ _param = 0; \ } \ _k = (_param >> LSGR); \ } while (0) /* Returns the next coefficient (a signed int) to encode, from the input stream */ #define GetNextInput(_n) \ do { \ if (data_size > 0) \ { \ _n = *data++; \ data_size--; \ } \ else \ { \ _n = 0; \ } \ } while (0) /* Emit bitPattern to the output bitstream */ #define OutputBits(_numBits, _bitPattern) rfx_bitstream_put_bits(bs, _bitPattern, _numBits) /* Emit a bit (0 or 1), count number of times, to the output bitstream */ #define OutputBit(_count, _bit) \ do \ { \ uint16 b = (_bit ? 0xFFFF : 0); \ int c = _count; \ for (; c > 0; c -= 16) \ { \ rfx_bitstream_put_bits(bs, b, (c > 16 ? 16 : c)); \ } \ } while (0) /* Converts the input value to (2 * abs(input) - sign(input)), where sign(input) = (input < 0 ? 1 : 0) and returns it */ #define Get2MagSign(_input) ((_input) >= 0 ? 2 * (_input) : -2 * (_input) - 1) /* Outputs the Golomb/Rice encoding of a non-negative integer */ #define CodeGR(_krp, _val) \ do { \ int lkr = (_krp) >> LSGR; \ int lval = _val; \ /* unary part of GR code */ \ uint32 lvk = lval >> lkr; \ OutputBit(lvk, 1); \ OutputBit(1, 0); \ /* remainder part of GR code, if needed */ \ if (lkr) \ { \ OutputBits(lkr, lval & ((1 << lkr) - 1)); \ } \ /* update krp, only if it is not equal to 1 */ \ if (lvk == 0) \ { \ UpdateParam(_krp, -2, lkr); \ } \ else if (lvk > 1) \ { \ UpdateParam(_krp, lvk, lkr); \ } \ } while (0) int rfx_rlgr3_encode(const sint16 *data, uint8 *buffer, int buffer_size) { int k; int kp; int krp; int input; int numZeros; int runmax; int mag; int sign; int processed_size; int lmag; int data_size; RFX_BITSTREAM bs; uint32 twoMs1; uint32 twoMs2; uint32 sum2Ms; uint32 nIdx; rfx_bitstream_attach(bs, buffer, buffer_size); /* initialize the parameters */ k = 1; kp = 1 << LSGR; krp = 1 << LSGR; /* process all the input coefficients */ data_size = 4096; while (data_size > 0) { if (k) { /* RUN-LENGTH MODE */ /* collect the run of zeros in the input stream */ numZeros = 0; GetNextInput(input); while (input == 0 && data_size > 0) { numZeros++; GetNextInput(input); } /* emit output zeros */ runmax = 1 << k; while (numZeros >= runmax) { OutputBit(1, 0); /* output a zero bit */ numZeros -= runmax; UpdateParam(kp, UP_GR, k); /* update kp, k */ runmax = 1 << k; } /* output a 1 to terminate runs */ OutputBit(1, 1); /* output the remaining run length using k bits */ OutputBits(k, numZeros); /* note: when we reach here and the last byte being encoded is 0, we still need to output the last two bits, otherwise mstsc will crash */ /* encode the nonzero value using GR coding */ mag = (input < 0 ? -input : input); /* absolute value of input coefficient */ sign = (input < 0 ? 1 : 0); /* sign of input coefficient */ OutputBit(1, sign); /* output the sign bit */ lmag = mag ? mag - 1 : 0; CodeGR(krp, lmag); /* output GR code for (mag - 1) */ UpdateParam(kp, -DN_GR, k); } else { /* GOLOMB-RICE MODE */ /* RLGR3 variant */ /* convert the next two input values to (2*magnitude - sign) and */ /* encode their sum using GR code */ GetNextInput(input); twoMs1 = Get2MagSign(input); GetNextInput(input); twoMs2 = Get2MagSign(input); sum2Ms = twoMs1 + twoMs2; CodeGR(krp, sum2Ms); /* encode binary representation of the first input (twoMs1). */ GetMinBits(sum2Ms, nIdx); OutputBits(nIdx, twoMs1); /* update k,kp for the two input values */ if (twoMs1 && twoMs2) { UpdateParam(kp, -2 * DQ_GR, k); } else if (!twoMs1 && !twoMs2) { UpdateParam(kp, 2 * UQ_GR, k); } } } processed_size = rfx_bitstream_get_processed_bytes(bs); return processed_size; } xrdp-0.9.5/librfxcodec/src/rfxencode_tile.c000644 001751 001751 00000022176 13220730305 020636 0ustar00metameta000000 000000 /** * FreeRDP: A Remote Desktop Protocol client. * RemoteFX Codec Library - Encode * * Copyright 2011 Vic Lee * Copyright 2014-2017 Jay Sorg * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ #if defined(HAVE_CONFIG_H) #include #endif #include #include #include #include #include "rfxcommon.h" #include "rfxencode.h" #include "rfxconstants.h" #include "rfxencode_tile.h" #include "rfxencode_dwt.h" #include "rfxencode_quantization.h" #include "rfxencode_differential.h" #include "rfxencode_rlgr1.h" #include "rfxencode_rlgr3.h" #include "rfxencode_alpha.h" #ifdef RFX_USE_ACCEL_X86 #include "x86/funcs_x86.h" #endif #ifdef RFX_USE_ACCEL_AMD64 #include "amd64/funcs_amd64.h" #endif #define LLOG_LEVEL 1 #define LLOGLN(_level, _args) \ do { if (_level < LLOG_LEVEL) { printf _args ; printf("\n"); } } while (0) /******************************************************************************/ int rfx_encode_component_rlgr1(struct rfxencode *enc, const char *qtable, const uint8 *data, uint8 *buffer, int buffer_size, int *size) { LLOGLN(10, ("rfx_encode_component_rlgr1:")); if (rfx_dwt_2d_encode(data, enc->dwt_buffer1, enc->dwt_buffer) != 0) { return 1; } if (rfx_quantization_encode(enc->dwt_buffer1, qtable) != 0) { return 1; } if (rfx_differential_encode(enc->dwt_buffer1 + 4032, 64) != 0) { return 1; } *size = rfx_rlgr1_encode(enc->dwt_buffer1, buffer, buffer_size); return 0; } /******************************************************************************/ int rfx_encode_component_rlgr3(struct rfxencode *enc, const char *qtable, const uint8 *data, uint8 *buffer, int buffer_size, int *size) { LLOGLN(10, ("rfx_encode_component_rlgr3:")); if (rfx_dwt_2d_encode(data, enc->dwt_buffer1, enc->dwt_buffer) != 0) { return 1; } if (rfx_quantization_encode(enc->dwt_buffer1, qtable) != 0) { return 1; } if (rfx_differential_encode(enc->dwt_buffer1 + 4032, 64) != 0) { return 1; } *size = rfx_rlgr3_encode(enc->dwt_buffer1, buffer, buffer_size); return 0; } /******************************************************************************/ int rfx_encode_rgb(struct rfxencode *enc, const char *rgb_data, int width, int height, int stride_bytes, const char *y_quants, const char *u_quants, const char *v_quants, STREAM *data_out, int *y_size, int *u_size, int *v_size) { uint8 *y_r_buffer; uint8 *u_g_buffer; uint8 *v_b_buffer; LLOGLN(10, ("rfx_encode_rgb:")); if (enc->rfx_encode_rgb_to_yuv(enc, rgb_data, width, height, stride_bytes) != 0) { return 1; } y_r_buffer = enc->y_r_buffer; u_g_buffer = enc->u_g_buffer; v_b_buffer = enc->v_b_buffer; if (enc->rfx_encode(enc, y_quants, y_r_buffer, stream_get_tail(data_out), stream_get_left(data_out), y_size) != 0) { return 1; } LLOGLN(10, ("rfx_encode_rgb: y_size %d", *y_size)); stream_seek(data_out, *y_size); if (enc->rfx_encode(enc, u_quants, u_g_buffer, stream_get_tail(data_out), stream_get_left(data_out), u_size) != 0) { return 1; } LLOGLN(10, ("rfx_encode_rgb: u_size %d", *u_size)); stream_seek(data_out, *u_size); if (enc->rfx_encode(enc, v_quants, v_b_buffer, stream_get_tail(data_out), stream_get_left(data_out), v_size) != 0) { return 1; } LLOGLN(10, ("rfx_encode_rgb: v_size %d", *v_size)); stream_seek(data_out, *v_size); return 0; } /******************************************************************************/ int rfx_encode_argb(struct rfxencode *enc, const char *argb_data, int width, int height, int stride_bytes, const char *y_quants, const char *u_quants, const char *v_quants, STREAM *data_out, int *y_size, int *u_size, int *v_size, int *a_size) { uint8 *a_buffer; uint8 *y_r_buffer; uint8 *u_g_buffer; uint8 *v_b_buffer; LLOGLN(10, ("rfx_encode_argb:")); if (enc->rfx_encode_argb_to_yuva(enc, argb_data, width, height, stride_bytes) != 0) { return 1; } a_buffer = enc->a_buffer; y_r_buffer = enc->y_r_buffer; u_g_buffer = enc->u_g_buffer; v_b_buffer = enc->v_b_buffer; if (enc->rfx_encode(enc, y_quants, y_r_buffer, stream_get_tail(data_out), stream_get_left(data_out), y_size) != 0) { return 1; } LLOGLN(10, ("rfx_encode_rgb: y_size %d", *y_size)); stream_seek(data_out, *y_size); if (enc->rfx_encode(enc, u_quants, u_g_buffer, stream_get_tail(data_out), stream_get_left(data_out), u_size) != 0) { return 1; } LLOGLN(10, ("rfx_encode_rgb: u_size %d", *u_size)); stream_seek(data_out, *u_size); if (enc->rfx_encode(enc, v_quants, v_b_buffer, stream_get_tail(data_out), stream_get_left(data_out), v_size) != 0) { return 1; } LLOGLN(10, ("rfx_encode_rgb: v_size %d", *v_size)); stream_seek(data_out, *v_size); *a_size = rfx_encode_plane(enc, a_buffer, 64, 64, data_out); return 0; } /******************************************************************************/ int rfx_encode_yuv(struct rfxencode *enc, const char *yuv_data, int width, int height, int stride_bytes, const char *y_quants, const char *u_quants, const char *v_quants, STREAM *data_out, int *y_size, int *u_size, int *v_size) { const uint8 *y_buffer; const uint8 *u_buffer; const uint8 *v_buffer; y_buffer = (const uint8 *) yuv_data; u_buffer = (const uint8 *) (yuv_data + RFX_YUV_BTES); v_buffer = (const uint8 *) (yuv_data + RFX_YUV_BTES * 2); if (enc->rfx_encode(enc, y_quants, y_buffer, stream_get_tail(data_out), stream_get_left(data_out), y_size) != 0) { return 1; } stream_seek(data_out, *y_size); if (enc->rfx_encode(enc, u_quants, u_buffer, stream_get_tail(data_out), stream_get_left(data_out), u_size) != 0) { return 1; } stream_seek(data_out, *u_size); if (enc->rfx_encode(enc, v_quants, v_buffer, stream_get_tail(data_out), stream_get_left(data_out), v_size) != 0) { return 1; } stream_seek(data_out, *v_size); return 0; } /******************************************************************************/ int rfx_encode_yuva(struct rfxencode *enc, const char *yuva_data, int width, int height, int stride_bytes, const char *y_quants, const char *u_quants, const char *v_quants, STREAM *data_out, int *y_size, int *u_size, int *v_size, int *a_size) { const uint8 *y_buffer; const uint8 *u_buffer; const uint8 *v_buffer; const uint8 *a_buffer; y_buffer = (const uint8 *) yuva_data; u_buffer = (const uint8 *) (yuva_data + RFX_YUV_BTES); v_buffer = (const uint8 *) (yuva_data + RFX_YUV_BTES * 2); a_buffer = (const uint8 *) (yuva_data + RFX_YUV_BTES * 3); if (enc->rfx_encode(enc, y_quants, y_buffer, stream_get_tail(data_out), stream_get_left(data_out), y_size) != 0) { return 1; } stream_seek(data_out, *y_size); if (enc->rfx_encode(enc, u_quants, u_buffer, stream_get_tail(data_out), stream_get_left(data_out), u_size) != 0) { return 1; } stream_seek(data_out, *u_size); if (enc->rfx_encode(enc, v_quants, v_buffer, stream_get_tail(data_out), stream_get_left(data_out), v_size) != 0) { return 1; } stream_seek(data_out, *v_size); *a_size = rfx_encode_plane(enc, a_buffer, 64, 64, data_out); return 0; } xrdp-0.9.5/librfxcodec/src/rfxencode_diff_rlgr1.c000644 001751 001751 00000013074 13127342076 021727 0ustar00metameta000000 000000 /** * FreeRDP: A Remote Desktop Protocol client. * RemoteFX Codec Library - RLGR * * Copyright 2011 Vic Lee * Copyright 2016-2017 Jay Sorg * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ /** * This implementation of RLGR refers to * [MS-RDPRFX] 3.1.8.1.7.3 RLGR1/RLGR3 Pseudocode */ #if defined(HAVE_CONFIG_H) #include #endif #include #include #include #include "rfxcommon.h" #define PIXELS_IN_TILE 4096 /* Constants used within the RLGR1/RLGR3 algorithm */ #define KPMAX (80) /* max value for kp or krp */ #define LSGR (3) /* shift count to convert kp to k */ #define UP_GR (4) /* increase in kp after a zero run in RL mode */ #define DN_GR (6) /* decrease in kp after a nonzero symbol in RL mode */ #define UQ_GR (3) /* increase in kp after nonzero symbol in GR mode */ #define DQ_GR (3) /* decrease in kp after zero symbol in GR mode */ #define GetNextInput do { \ input = *coef; \ coef++; \ coef_size--; \ } while (0) #define CheckWrite do { \ while (bit_count >= 8) \ { \ bit_count -= 8; \ *cdata = bits >> bit_count; \ cdata++; \ } \ } while (0) /* output GR code for (mag - 1) */ #define CodeGR(_krp, _lmag) do { \ int lkr = _krp >> LSGR; \ /* unary part of GR code */ \ int lvk = _lmag >> lkr; \ int llvk = lvk; \ while (llvk >= 8) \ { \ bits <<= 8; \ bits |= 0xFF; \ llvk -= 8; \ *cdata = bits >> bit_count; \ cdata++; \ } \ bits <<= llvk; \ bits |= (1 << llvk) - 1; \ bit_count += llvk; \ bits <<= 1; \ bit_count++; \ CheckWrite; \ /* remainder part of GR code, if needed */ \ if (lkr) \ { \ bits <<= lkr; \ bits |= _lmag & ((1 << lkr) - 1); \ bit_count += lkr; \ } \ /* update _krp, only if it is not equal to 1 */ \ if (lvk == 0) \ { \ _krp = MAX(0, _krp - 2); \ } \ else if (lvk > 1) \ { \ _krp = MIN(KPMAX, _krp + lvk); \ } \ } while (0) int rfx_encode_diff_rlgr1(sint16 *coef, uint8 *cdata, int cdata_size) { int k; int kp; int krp; int input; int numZeros; int runmax; int mag; int sign; int processed_size; int lmag; int coef_size; int y; int bit_count; unsigned int bits; uint8 *cdata_org; uint32 twoMs; /* the last 64 bytes are diff */ for (k = PIXELS_IN_TILE - 1; k > PIXELS_IN_TILE - 64; k--) { coef[k] -= coef[k - 1]; } /* initialize the parameters */ k = 1; kp = 1 << LSGR; krp = 1 << LSGR; bit_count = 0; bits = 0; cdata_org = cdata; /* process all the input coefficients */ coef_size = PIXELS_IN_TILE; while (coef_size > 0) { if (k) { /* RUN-LENGTH MODE */ /* collect the run of zeros in the input stream */ numZeros = 0; GetNextInput; while (input == 0 && coef_size > 0) { numZeros++; GetNextInput; } /* emit output zeros */ runmax = 1 << k; while (numZeros >= runmax) { bits <<= 1; bit_count++; CheckWrite; numZeros -= runmax; kp = MIN(KPMAX, kp + UP_GR); k = kp >> LSGR; runmax = 1 << k; } /* output a 1 to terminate runs */ bits <<= 1; bits |= 1; bit_count++; /* output the remaining run length using k bits */ bits <<= k; bits |= numZeros; bit_count += k; CheckWrite; /* encode the nonzero value using GR coding */ if (input < 0) { mag = -input; sign = 1; } else { mag = input; sign = 0; } bits <<= 1; bits |= sign; bit_count++; lmag = mag ? mag - 1 : 0; CodeGR(krp, lmag); /* output GR code for (mag - 1) */ CheckWrite; kp = MAX(0, kp - DN_GR); k = kp >> LSGR; } else { /* GOLOMB-RICE MODE */ /* RLGR1 variant */ /* convert input to (2*magnitude - sign), encode using GR code */ GetNextInput; y = input >> 15; twoMs = (((input ^ y) - y) << 1) + y; CodeGR(krp, twoMs); CheckWrite; /* update k, kp */ if (twoMs) { kp = MAX(0, kp - DQ_GR); k = kp >> LSGR; } else { kp = MIN(KPMAX, kp + UQ_GR); k = kp >> LSGR; } } } if (bit_count > 0) { bits <<= 8 - bit_count; *cdata = bits; cdata++; bit_count = 0; } processed_size = cdata - cdata_org; return processed_size; } xrdp-0.9.5/librfxcodec/src/Makefile.am000644 001751 001751 00000002074 13220730305 017527 0ustar00metameta000000 000000 EXTRA_DIST = common.asm nasm_lt.sh SUBDIRS = AM_CPPFLAGS = \ -I$(top_srcdir)/include if WITH_SIMD_AMD64 SUBDIRS += amd64 librfxencode_la_LIBADD = amd64/librfxencode-amd64.la AM_CPPFLAGS += -DSIMD_USE_ACCEL=1 -DRFX_USE_ACCEL_AMD64=1 endif if WITH_SIMD_X86 SUBDIRS += x86 librfxencode_la_LIBADD = x86/librfxencode-x86.la AM_CPPFLAGS += -DSIMD_USE_ACCEL=1 -DRFX_USE_ACCEL_X86=1 endif noinst_HEADERS = \ rfx_bitstream.h \ rfxcommon.h \ rfxencode_compose.h \ rfxconstants.h \ rfxencode_alpha.h \ rfxencode_differential.h \ rfxencode_dwt.h \ rfxencode.h \ rfxencode_quantization.h \ rfxencode_rlgr1.h \ rfxencode_rlgr3.h \ rfxencode_tile.h \ rfxencode_diff_rlgr1.h \ rfxencode_diff_rlgr3.h \ rfxencode_rgb_to_yuv.h lib_LTLIBRARIES = librfxencode.la librfxencode_la_SOURCES = $(noinst_HEADERS) rfxencode.c \ rfxencode_compose.c rfxencode_tile.c rfxencode_dwt.c \ rfxencode_quantization.c rfxencode_differential.c \ rfxencode_rlgr1.c rfxencode_rlgr3.c rfxencode_alpha.c \ rfxencode_diff_rlgr1.c rfxencode_diff_rlgr3.c \ rfxencode_rgb_to_yuv.c xrdp-0.9.5/librfxcodec/src/rfxencode_diff_rlgr3.c000644 001751 001751 00000014573 13127342076 021736 0ustar00metameta000000 000000 /** * FreeRDP: A Remote Desktop Protocol client. * RemoteFX Codec Library - RLGR * * Copyright 2011 Vic Lee * Copyright 2016-2017 Jay Sorg * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ /** * This implementation of RLGR refers to * [MS-RDPRFX] 3.1.8.1.7.3 RLGR1/RLGR3 Pseudocode */ #if defined(HAVE_CONFIG_H) #include #endif #include #include #include #include "rfxcommon.h" #define PIXELS_IN_TILE 4096 /* Constants used within the RLGR1/RLGR3 algorithm */ #define KPMAX (80) /* max value for kp or krp */ #define LSGR (3) /* shift count to convert kp to k */ #define UP_GR (4) /* increase in kp after a zero run in RL mode */ #define DN_GR (6) /* decrease in kp after a nonzero symbol in RL mode */ #define UQ_GR (3) /* increase in kp after nonzero symbol in GR mode */ #define DQ_GR (3) /* decrease in kp after zero symbol in GR mode */ #define GetNextInput do { \ input = *coef; \ coef++; \ coef_size--; \ } while (0) #define CheckWrite do { \ while (bit_count >= 8) \ { \ bit_count -= 8; \ *cdata = bits >> bit_count; \ cdata++; \ } \ } while (0) /* output GR code for (mag - 1) */ #define CodeGR(_krp, _lmag) do { \ int lkr = _krp >> LSGR; \ /* unary part of GR code */ \ int lvk = _lmag >> lkr; \ int llvk = lvk; \ while (llvk >= 8) \ { \ bits <<= 8; \ bits |= 0xFF; \ llvk -= 8; \ *cdata = bits >> bit_count; \ cdata++; \ } \ bits <<= llvk; \ bits |= (1 << llvk) - 1; \ bit_count += llvk; \ bits <<= 1; \ bit_count++; \ CheckWrite; \ /* remainder part of GR code, if needed */ \ if (lkr) \ { \ bits <<= lkr; \ bits |= _lmag & ((1 << lkr) - 1); \ bit_count += lkr; \ } \ /* update _krp, only if it is not equal to 1 */ \ if (lvk == 0) \ { \ _krp = MAX(0, _krp - 2); \ } \ else if (lvk > 1) \ { \ _krp = MIN(KPMAX, _krp + lvk); \ } \ } while (0) int rfx_encode_diff_rlgr3(sint16 *coef, uint8 *cdata, int cdata_size) { int k; int kp; int krp; int input; int numZeros; int runmax; int mag; int sign; int processed_size; int lmag; int coef_size; int y; int bit_count; unsigned int bits; uint8 *cdata_org; uint32 twoMs1; uint32 twoMs2; uint32 sum2Ms; uint32 nIdx; /* the last 64 bytes are diff */ for (k = PIXELS_IN_TILE - 1; k > PIXELS_IN_TILE - 64; k--) { coef[k] -= coef[k - 1]; } /* initialize the parameters */ k = 1; kp = 1 << LSGR; krp = 1 << LSGR; bit_count = 0; bits = 0; cdata_org = cdata; /* process all the input coefficients */ coef_size = PIXELS_IN_TILE; while (coef_size > 0) { if (k) { /* RUN-LENGTH MODE */ /* collect the run of zeros in the input stream */ numZeros = 0; GetNextInput; while (input == 0 && coef_size > 0) { numZeros++; GetNextInput; } /* emit output zeros */ runmax = 1 << k; while (numZeros >= runmax) { bits <<= 1; bit_count++; CheckWrite; numZeros -= runmax; kp = MIN(KPMAX, kp + UP_GR); k = kp >> LSGR; runmax = 1 << k; } /* output a 1 to terminate runs */ bits <<= 1; bits |= 1; bit_count++; /* output the remaining run length using k bits */ bits <<= k; bits |= numZeros; bit_count += k; CheckWrite; /* encode the nonzero value using GR coding */ if (input < 0) { mag = -input; sign = 1; } else { mag = input; sign = 0; } bits <<= 1; bits |= sign; bit_count++; lmag = mag ? mag - 1 : 0; CodeGR(krp, lmag); /* output GR code for (mag - 1) */ CheckWrite; kp = MAX(0, kp - DN_GR); k = kp >> LSGR; } else { /* GOLOMB-RICE MODE */ /* RLGR3 variant */ /* convert the next two input values to (2*magnitude - sign) and */ /* encode their sum using GR code */ GetNextInput; y = input >> 15; twoMs1 = (((input ^ y) - y) << 1) + y; GetNextInput; y = input >> 15; twoMs2 = (((input ^ y) - y) << 1) + y; sum2Ms = twoMs1 + twoMs2; CodeGR(krp, sum2Ms); CheckWrite; /* encode binary representation of the first input (twoMs1). */ if (sum2Ms != 0) { GBSR(sum2Ms, nIdx); nIdx++; } else { nIdx = 0; } bits <<= nIdx; bits |= twoMs1; bit_count += nIdx; CheckWrite; /* update k,kp for the two input values */ if (twoMs1 != 0) { if (twoMs2 != 0) { kp = MAX(0, kp - (2 * DQ_GR)); k = kp >> LSGR; } } else { if (twoMs2 == 0) { kp = MIN(KPMAX, kp + (2 * UQ_GR)); k = kp >> LSGR; } } } } if (bit_count > 0) { bits <<= 8 - bit_count; *cdata = bits; cdata++; bit_count = 0; } processed_size = cdata - cdata_org; return processed_size; } xrdp-0.9.5/librfxcodec/src/common.asm000644 001751 001751 00000005115 13162371073 017474 0ustar00metameta000000 000000 ; ;Copyright 2017 Pavel Roskin ;Copyright 2017 mirabilos ; ;Permission to use, copy, modify, distribute, and sell this software and its ;documentation for any purpose is hereby granted without fee, provided that ;the above copyright notice appear in all copies and that both that ;copyright notice and this permission notice appear in supporting ;documentation. ; ;The above copyright notice and this permission notice shall be included in ;all copies or substantial portions of the Software. ; ;THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR ;IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, ;FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE ;OPEN GROUP BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN ;AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN ;CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. ; ;Common nasm code ; ; Detect ELF formats %ifidn __OUTPUT_FORMAT__,elf %define is_elf 1 %endif %ifidn __OUTPUT_FORMAT__,elf32 %define is_elf 1 %endif %ifidn __OUTPUT_FORMAT__,elf64 %define is_elf 1 %endif ; Detect Mach-O formats %ifidn __OUTPUT_FORMAT__,macho %define is_macho 1 %endif %ifidn __OUTPUT_FORMAT__,macho32 %define is_macho 1 %endif %ifidn __OUTPUT_FORMAT__,macho64 %define is_macho 1 %endif ; Mark stack non-executable %ifdef is_elf section .note.GNU-stack noalloc noexec nowrite progbits %endif ; Global function header %macro PROC 1 align 16 %ifdef is_elf global %1:function %1: %else global _%1 _%1: %endif %endmacro ; Macros for relative access to local data %undef lsym %ifdef ASM_ARCH_AMD64 ; amd64; don't define or call RETRIEVE_RODATA %define lsym(name) rel name %endif %ifdef ASM_ARCH_I386 %ifdef PIC ; i386 PIC %macro END_OF_FILE 0 %ifdef I386_PIC_NEEDED section .text ..@get_caller_address: mov ebx, [esp] ret %endif %ifdef is_macho ; see below align 16 %endif %endmacro %macro RETRIEVE_RODATA 0 %define I386_PIC_NEEDED 1 call ..@get_caller_address %%the_caller_address: sub ebx, %%the_caller_address - ..@rodata_begin %endmacro %define lsym(name) ebx + name - ..@rodata_begin %else ; i386 non-PIC; default case for lsym and RETRIEVE_RODATA %endif %endif %ifndef lsym %macro RETRIEVE_RODATA 0 %endmacro %define lsym(name) name %endif %macro PREPARE_RODATA 0 section .text align 16 ..@rodata_begin: %endmacro %ifnmacro END_OF_FILE 0 %macro END_OF_FILE 0 %ifdef is_macho ; cf. https://github.com/libjpeg-turbo/libjpeg-turbo/blob/master/simd/jccolext-mmx.asm#L474-L476 align 16 %endif %endmacro %endif section .text xrdp-0.9.5/librfxcodec/src/rfxencode_rlgr1.c000644 001751 001751 00000014101 13061652764 020734 0ustar00metameta000000 000000 /** * FreeRDP: A Remote Desktop Protocol client. * RemoteFX Codec Library - RLGR * * Copyright 2011 Vic Lee * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ /** * This implementation of RLGR refers to * [MS-RDPRFX] 3.1.8.1.7.3 RLGR1/RLGR3 Pseudocode */ #if defined(HAVE_CONFIG_H) #include #endif #include #include #include #include "rfx_bitstream.h" /* Constants used within the RLGR1/RLGR3 algorithm */ #define KPMAX (80) /* max value for kp or krp */ #define LSGR (3) /* shift count to convert kp to k */ #define UP_GR (4) /* increase in kp after a zero run in RL mode */ #define DN_GR (6) /* decrease in kp after a nonzero symbol in RL mode */ #define UQ_GR (3) /* increase in kp after nonzero symbol in GR mode */ #define DQ_GR (3) /* decrease in kp after zero symbol in GR mode */ /* Returns the least number of bits required to represent a given value */ #define GetMinBits(_val, _nbits) \ do { \ uint32 _v = _val; \ _nbits = 0; \ while (_v) \ { \ _v >>= 1; \ _nbits++; \ } \ } while (0) /* * Update the passed parameter and clamp it to the range [0, KPMAX] * Return the value of parameter right-shifted by LSGR */ #define UpdateParam(_param, _deltaP, _k) \ do { \ _param += _deltaP; \ if (_param > KPMAX) \ { \ _param = KPMAX; \ } \ if (_param < 0) \ { \ _param = 0; \ } \ _k = (_param >> LSGR); \ } while (0) /* Returns the next coefficient (a signed int) to encode, from the input stream */ #define GetNextInput(_n) \ do { \ if (data_size > 0) \ { \ _n = *data++; \ data_size--; \ } \ else \ { \ _n = 0; \ } \ } while (0) /* Emit bitPattern to the output bitstream */ #define OutputBits(_numBits, _bitPattern) rfx_bitstream_put_bits(bs, _bitPattern, _numBits) /* Emit a bit (0 or 1), count number of times, to the output bitstream */ #define OutputBit(_count, _bit) \ do \ { \ uint16 b = (_bit ? 0xFFFF : 0); \ int c = _count; \ for (; c > 0; c -= 16) \ { \ rfx_bitstream_put_bits(bs, b, (c > 16 ? 16 : c)); \ } \ } while (0) /* Converts the input value to (2 * abs(input) - sign(input)), where sign(input) = (input < 0 ? 1 : 0) and returns it */ #define Get2MagSign(_input) ((_input) >= 0 ? 2 * (_input) : -2 * (_input) - 1) /* Outputs the Golomb/Rice encoding of a non-negative integer */ #define CodeGR(_krp, _val) \ do { \ int lkr = (_krp) >> LSGR; \ int lval = _val; \ /* unary part of GR code */ \ uint32 lvk = lval >> lkr; \ OutputBit(lvk, 1); \ OutputBit(1, 0); \ /* remainder part of GR code, if needed */ \ if (lkr) \ { \ OutputBits(lkr, lval & ((1 << lkr) - 1)); \ } \ /* update krp, only if it is not equal to 1 */ \ if (lvk == 0) \ { \ UpdateParam(_krp, -2, lkr); \ } \ else if (lvk > 1) \ { \ UpdateParam(_krp, lvk, lkr); \ } \ } while (0) int rfx_rlgr1_encode(const sint16 *data, uint8 *buffer, int buffer_size) { int k; int kp; int krp; int input; int numZeros; int runmax; int mag; int sign; int processed_size; int lmag; int data_size; RFX_BITSTREAM bs; uint32 twoMs; rfx_bitstream_attach(bs, buffer, buffer_size); /* initialize the parameters */ k = 1; kp = 1 << LSGR; krp = 1 << LSGR; /* process all the input coefficients */ data_size = 4096; while (data_size > 0) { if (k) { /* RUN-LENGTH MODE */ /* collect the run of zeros in the input stream */ numZeros = 0; GetNextInput(input); while (input == 0 && data_size > 0) { numZeros++; GetNextInput(input); } /* emit output zeros */ runmax = 1 << k; while (numZeros >= runmax) { OutputBit(1, 0); /* output a zero bit */ numZeros -= runmax; UpdateParam(kp, UP_GR, k); /* update kp, k */ runmax = 1 << k; } /* output a 1 to terminate runs */ OutputBit(1, 1); /* output the remaining run length using k bits */ OutputBits(k, numZeros); /* note: when we reach here and the last byte being encoded is 0, we still need to output the last two bits, otherwise mstsc will crash */ /* encode the nonzero value using GR coding */ mag = (input < 0 ? -input : input); /* absolute value of input coefficient */ sign = (input < 0 ? 1 : 0); /* sign of input coefficient */ OutputBit(1, sign); /* output the sign bit */ lmag = mag ? mag - 1 : 0; CodeGR(krp, lmag); /* output GR code for (mag - 1) */ UpdateParam(kp, -DN_GR, k); } else { /* GOLOMB-RICE MODE */ /* RLGR1 variant */ /* convert input to (2*magnitude - sign), encode using GR code */ GetNextInput(input); twoMs = Get2MagSign(input); CodeGR(krp, twoMs); /* update k, kp */ /* NOTE: as of Aug 2011, the algorithm is still wrongly documented and the update direction is reversed */ if (twoMs) { UpdateParam(kp, -DQ_GR, k); } else { UpdateParam(kp, UQ_GR, k); } } } processed_size = rfx_bitstream_get_processed_bytes(bs); return processed_size; } xrdp-0.9.5/librfxcodec/src/x86/000755 001751 001751 00000000000 13220731017 016116 5ustar00metameta000000 000000 xrdp-0.9.5/librfxcodec/src/nasm_lt.sh000755 001751 001751 00000003044 13061652764 017504 0ustar00metameta000000 000000 #! /bin/sh command="" infile="" o_opt=no pic=no while [ $# -gt 0 ]; do case "$1" in -DPIC|-fPIC|-fpic|-Kpic|-KPIC) if [ "$pic" != "yes" ] ; then command="$command -DPIC" pic=yes fi ;; -f|-fbin|-faout|-faoutb|-fcoff|-felf|-felf64|-fas86| \ -fobj|-fwin32|-fwin64|-frdf|-fieee|-fmacho|-fmacho64) # it's a file format specifier for nasm. command="$command $1" ;; -f*) # maybe a code-generation flag for gcc. ;; -[Ii]*) incdir=`echo "$1" | sed 's/^-[Ii]//'` if [ "x$incdir" = x -a "x$2" != x ] ; then case "$2" in -*) ;; *) incdir="$2"; shift;; esac fi if [ "x$incdir" != x ] ; then # In the case of NASM, the trailing slash is necessary. incdir=`echo "$incdir" | sed 's%/*$%/%'` command="$command -I$incdir" fi ;; -o*) o_opt=yes command="$command $1" ;; *.asm) infile=$1 command="$command $1" ;; *) command="$command $1" ;; esac shift done if [ "$o_opt" != yes ] ; then # By default, NASM creates an output file # in the same directory as the input file. outfile="-o `echo $infile | sed -e 's%^.*/%%' -e 's%\.[^.]*$%%'`.o" command="$command $outfile" fi exec $command xrdp-0.9.5/librfxcodec/src/rfx_bitstream.h000644 001751 001751 00000005076 13127342076 020534 0ustar00metameta000000 000000 /** * FreeRDP: A Remote Desktop Protocol client. * RemoteFX Codec Library - Bit Stream * * Copyright 2011 Vic Lee * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ #ifndef __RFX_BITSTREAM_H #define __RFX_BITSTREAM_H #include "rfxcommon.h" struct _RFX_BITSTREAM { uint8 *buffer; int nbytes; int byte_pos; int bits_left; }; typedef struct _RFX_BITSTREAM RFX_BITSTREAM; #define rfx_bitstream_attach(bs, _buffer, _nbytes) do { \ bs.buffer = (uint8 *) (_buffer); \ bs.nbytes = (_nbytes); \ bs.byte_pos = 0; \ bs.bits_left = 8; } while (0) #define rfx_bitstream_get_bits(bs, _nbits, _r) do { \ int nbits = _nbits; \ int b; \ uint16 n = 0; \ while (bs.byte_pos < bs.nbytes && nbits > 0) \ { \ b = nbits; \ if (b > bs.bits_left) \ b = bs.bits_left; \ if (n) \ n <<= b; \ n |= (bs.buffer[bs.byte_pos] >> (bs.bits_left - b)) & ((1 << b) - 1); \ bs.bits_left -= b; \ nbits -= b; \ if (bs.bits_left == 0) \ { \ bs.bits_left = 8; \ bs.byte_pos++; \ } \ } \ _r = n; } while (0) #define rfx_bitstream_put_bits(bs, _bits, _nbits) do { \ uint16 bits = (_bits); \ int nbits = (_nbits); \ int b; \ while (bs.byte_pos < bs.nbytes && nbits > 0) \ { \ b = nbits; \ if (b > bs.bits_left) \ b = bs.bits_left; \ bs.buffer[bs.byte_pos] &= ~((1 << bs.bits_left) - 1); \ bs.buffer[bs.byte_pos] |= ((bits >> (nbits - b)) & ((1 << b) - 1)) << (bs.bits_left - b); \ bs.bits_left -= b; \ nbits -= b; \ if (bs.bits_left == 0) \ { \ bs.bits_left = 8; \ bs.byte_pos++; \ } \ } } while (0) #define rfx_bitstream_eos(_bs) ((_bs).byte_pos >= (_bs).nbytes) #define rfx_bitstream_left(_bs) ((_bs).byte_pos >= (_bs).nbytes ? 0 : ((_bs).nbytes - (_bs).byte_pos - 1) * 8 + (_bs)->bits_left) #define rfx_bitstream_get_processed_bytes(_bs) ((_bs).bits_left < 8 ? (_bs).byte_pos + 1 : (_bs).byte_pos) #endif /* __RFX_BITSTREAM_H */ xrdp-0.9.5/librfxcodec/src/rfxencode_rlgr3.h000644 001751 001751 00000001515 13061652764 020750 0ustar00metameta000000 000000 /** * FreeRDP: A Remote Desktop Protocol client. * RemoteFX Codec Library - RLGR * * Copyright 2011 Vic Lee * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ #ifndef __RFX_RLGR3_H #define __RFX_RLGR3_H #include "rfxcommon.h" int rfx_rlgr3_encode(const sint16 *data, uint8 *buffer, int buffer_size); #endif /* __RFX_RLGR_H */ xrdp-0.9.5/librfxcodec/src/rfxencode_tile.h000644 001751 001751 00000010204 13127342056 020640 0ustar00metameta000000 000000 /** * FreeRDP: A Remote Desktop Protocol client. * RemoteFX Codec Library - Encode * * Copyright 2011 Vic Lee * Copyright 2014-2017 Jay Sorg * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ #ifndef __RFXTILE_H #define __RFXTILE_H #include "rfxcommon.h" #define RFX_YUV_BTES (64 * 64) int rfx_encode_component_rlgr1(struct rfxencode *enc, const char *qtable, const uint8 *data, uint8 *buffer, int buffer_size, int *size); int rfx_encode_component_rlgr3(struct rfxencode *enc, const char *qtable, const uint8 *data, uint8 *buffer, int buffer_size, int *size); int rfx_encode_rgb(struct rfxencode *enc, const char *rgb_data, int width, int height, int stride_bytes, const char *y_quants, const char *u_quants, const char *v_quants, STREAM *data_out, int *y_size, int *cb_size, int *cr_size); int rfx_encode_argb(struct rfxencode *enc, const char *argb_data, int width, int height, int stride_bytes, const char *y_quants, const char *cb_quants, const char *cr_quants, STREAM *data_out, int *y_size, int *u_size, int *v_size, int *a_size); int rfx_encode_yuv(struct rfxencode *enc, const char *yuv_data, int width, int height, int stride_bytes, const char *y_quants, const char *u_quants, const char *v_quants, STREAM *data_out, int *y_size, int *u_size, int *v_size); int rfx_encode_yuva(struct rfxencode *enc, const char *yuv_data, int width, int height, int stride_bytes, const char *y_quants, const char *u_quants, const char *v_quants, STREAM *data_out, int *y_size, int *u_size, int *v_size, int *a_size); int rfx_encode_component_rlgr1_x86_sse2(struct rfxencode *enc, const char *qtable, const uint8 *data, uint8 *buffer, int buffer_size, int *size); int rfx_encode_component_rlgr3_x86_sse2(struct rfxencode *enc, const char *qtable, const uint8 *data, uint8 *buffer, int buffer_size, int *size); int rfx_encode_component_rlgr1_x86_sse41(struct rfxencode *enc, const char *qtable, const uint8 *data, uint8 *buffer, int buffer_size, int *size); int rfx_encode_component_rlgr3_x86_sse41(struct rfxencode *enc, const char *qtable, const uint8 *data, uint8 *buffer, int buffer_size, int *size); int rfx_encode_component_rlgr1_amd64_sse2(struct rfxencode *enc, const char *qtable, const uint8 *data, uint8 *buffer, int buffer_size, int *size); int rfx_encode_component_rlgr3_amd64_sse2(struct rfxencode *enc, const char *qtable, const uint8 *data, uint8 *buffer, int buffer_size, int *size); int rfx_encode_component_rlgr1_amd64_sse41(struct rfxencode *enc, const char *qtable, const uint8 *data, uint8 *buffer, int buffer_size, int *size); int rfx_encode_component_rlgr3_amd64_sse41(struct rfxencode *enc, const char *qtable, const uint8 *data, uint8 *buffer, int buffer_size, int *size); #endif xrdp-0.9.5/librfxcodec/src/rfxencode_diff_rlgr1.h000644 001751 001751 00000001533 13061652764 021736 0ustar00metameta000000 000000 /** * FreeRDP: A Remote Desktop Protocol client. * RemoteFX Codec Library - RLGR * * Copyright 2011 Vic Lee * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ #ifndef __RFX_DIFF_RLGR1_H #define __RFX_DIFF_RLGR1_H #include "rfxcommon.h" int rfx_encode_diff_rlgr1(sint16 *coef, uint8 *cdata, int cdata_size); #endif /* __RFX_DIFF_RLGR1_H */ xrdp-0.9.5/librfxcodec/src/rfxencode_alpha.h000644 001751 001751 00000001561 13061652764 021005 0ustar00metameta000000 000000 /** * librfxcodec: A Remote Desktop Protocol client. * RemoteFX Codec Library * * Copyright 2015 Jay Sorg * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ #ifndef __RFXCODEC_ENCODE_ALPHA_H #define __RFXCODEC_ENCODE_ALPHA_H int rfx_encode_plane(struct rfxencode *enc, const uint8 *plane, int cx, int cy, STREAM *s); #endif xrdp-0.9.5/librfxcodec/src/rfxencode_quantization.c000644 001751 001751 00000010546 13127342056 022435 0ustar00metameta000000 000000 /** * FreeRDP: A Remote Desktop Protocol client. * RemoteFX Codec Library - Quantization * * Copyright 2011 Vic Lee * Copyright 2014-2017 Jay Sorg * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ #if defined(HAVE_CONFIG_H) #include #endif #include #include #include #include #include #include "rfxcommon.h" #include "rfxencode.h" #include "rfxconstants.h" #if 0 /******************************************************************************/ /* return round(d1 / d2) as if d1 ad d2 are float */ static int divround(int d1, int d2) { if ((d1 < 0) ^ (d2 < 0)) { return (d1 - (d2 / 2)) / d2; } return (d1 + (d2 / 2)) / d2; } #endif #if 0 #define DIVROUND(_d1, _d2) \ (_d1) < 0 ? \ ((_d1) - ((_d2) / 2)) / (_d2) : \ ((_d1) + ((_d2) / 2)) / (_d2) /******************************************************************************/ static int rfx_quantization_encode_block(sint16 *buffer, int buffer_size, uint32 factor) { sint16 *dst; sint16 scale_value; if (factor == 0) { return 1; } scale_value = 1 << factor; for (dst = buffer; buffer_size > 0; dst++, buffer_size--) { *dst = DIVROUND(*dst, scale_value); } return 0; } #endif #if 0 /******************************************************************************/ static int rfx_quantization_encode_block(sint16 *buffer, int buffer_size, uint32 factor) { sint16 *dst; if (factor == 0) { return 1; } for (dst = buffer; buffer_size > 0; dst++, buffer_size--) { *dst = *dst >> factor; } return 0; } #endif #if 0 /******************************************************************************/ static int rfx_quantization_encode_block(sint16 *buffer, int buffer_size, uint32 factor) { sint16 *dst; sint16 half; if (factor == 0) { return 1; } half = (1 << (factor - 1)); for (dst = buffer; buffer_size > 0; dst++, buffer_size--) { *dst = (*dst + half) >> factor; } return 0; } #endif #if 1 /******************************************************************************/ static int rfx_quantization_encode_block(sint16 *buffer, int buffer_size, uint32 factor) { sint16 *dst; sint16 half; factor += DWT_FACTOR; if (factor == 0) { return 1; } half = (1 << (factor - 1)); for (dst = buffer; buffer_size > 0; dst++, buffer_size--) { *dst = (*dst + half) >> factor; } return 0; } #endif /******************************************************************************/ int rfx_quantization_encode(sint16 *buffer, const char *qtable) { uint32 factor; factor = ((qtable[4] >> 0) & 0xf) - 6; rfx_quantization_encode_block(buffer, 1024, factor); /* HL1 */ factor = ((qtable[3] >> 4) & 0xf) - 6; rfx_quantization_encode_block(buffer + 1024, 1024, factor); /* LH1 */ factor = ((qtable[4] >> 4) & 0xf) - 6; rfx_quantization_encode_block(buffer + 2048, 1024, factor); /* HH1 */ factor = ((qtable[2] >> 4) & 0xf) - 6; rfx_quantization_encode_block(buffer + 3072, 256, factor); /* HL2 */ factor = ((qtable[2] >> 0) & 0xf) - 6; rfx_quantization_encode_block(buffer + 3328, 256, factor); /* LH2 */ factor = ((qtable[3] >> 0) & 0xf) - 6; rfx_quantization_encode_block(buffer + 3584, 256, factor); /* HH2 */ factor = ((qtable[1] >> 0) & 0xf) - 6; rfx_quantization_encode_block(buffer + 3840, 64, factor); /* HL3 */ factor = ((qtable[0] >> 4) & 0xf) - 6; rfx_quantization_encode_block(buffer + 3904, 64, factor); /* LH3 */ factor = ((qtable[1] >> 4) & 0xf) - 6; rfx_quantization_encode_block(buffer + 3968, 64, factor); /* HH3 */ factor = ((qtable[0] >> 0) & 0xf) - 6; rfx_quantization_encode_block(buffer + 4032, 64, factor); /* LL3 */ return 0; } xrdp-0.9.5/librfxcodec/src/rfxencode_compose.h000644 001751 001751 00000002231 13127342076 021353 0ustar00metameta000000 000000 /** * RFX codec encoder * * Copyright 2014-2017 Jay Sorg * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ #ifndef __RFXCOMPOSE_H #define __RFXCOMPOSE_H #include "rfxcommon.h" int rfx_compose_message_header(struct rfxencode *enc, STREAM *s); int rfx_compose_message_data(struct rfxencode *enc, STREAM *s, const struct rfx_rect *regions, int num_regions, const char *buf, int width, int height, int stride_bytes, const struct rfx_tile *tiles, int num_tiles, const char *quants, int num_quants, int flags); #endif xrdp-0.9.5/librfxcodec/src/rfxencode.c000644 001751 001751 00000027336 13220730305 017624 0ustar00metameta000000 000000 /** * RFX codec encoder * * Copyright 2014-2017 Jay Sorg * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ #if defined(HAVE_CONFIG_H) #include #endif #include #include #include #include #include "rfxcommon.h" #include "rfxencode.h" #include "rfxencode_compose.h" #include "rfxconstants.h" #include "rfxencode_tile.h" #include "rfxencode_rlgr1.h" #include "rfxencode_rlgr3.h" #include "rfxencode_differential.h" #include "rfxencode_quantization.h" #include "rfxencode_dwt.h" #include "rfxencode_diff_rlgr1.h" #include "rfxencode_diff_rlgr3.h" #include "rfxencode_rgb_to_yuv.h" #ifdef RFX_USE_ACCEL_X86 #include "x86/funcs_x86.h" #endif #ifdef RFX_USE_ACCEL_AMD64 #include "amd64/funcs_amd64.h" #endif /******************************************************************************/ int rfxcodec_encode_create_ex(int width, int height, int format, int flags, void **handle) { struct rfxencode *enc; int ax; int bx; int cx; int dx; enc = (struct rfxencode *) calloc(1, sizeof(struct rfxencode)); if (enc == NULL) { return 1; } enc->dwt_buffer = (sint16 *) (((size_t) (enc->dwt_buffer_a)) & ~15); enc->dwt_buffer1 = (sint16 *) (((size_t) (enc->dwt_buffer1_a)) & ~15); enc->dwt_buffer2 = (sint16 *) (((size_t) (enc->dwt_buffer2_a)) & ~15); #if defined(RFX_USE_ACCEL_X86) cpuid_x86(1, 0, &ax, &bx, &cx, &dx); #elif defined(RFX_USE_ACCEL_AMD64) cpuid_amd64(1, 0, &ax, &bx, &cx, &dx); #else ax = 0; bx = 0; cx = 0; dx = 0; #endif if (dx & (1 << 26)) /* SSE 2 */ { printf("rfxcodec_encode_create: got sse2\n"); enc->got_sse2 = 1; } if (cx & (1 << 0)) /* SSE 3 */ { printf("rfxcodec_encode_create: got sse3\n"); enc->got_sse3 = 1; } if (cx & (1 << 19)) /* SSE 4.1 */ { printf("rfxcodec_encode_create: got sse4.1\n"); enc->got_sse41 = 1; } if (cx & (1 << 20)) /* SSE 4.2 */ { printf("rfxcodec_encode_create: got sse4.2\n"); enc->got_sse42 = 1; } if (cx & (1 << 23)) /* popcnt */ { printf("rfxcodec_encode_create: got popcnt\n"); enc->got_popcnt = 1; } #if defined(RFX_USE_ACCEL_X86) cpuid_x86(0x80000001, 0, &ax, &bx, &cx, &dx); #elif defined(RFX_USE_ACCEL_AMD64) cpuid_amd64(0x80000001, 0, &ax, &bx, &cx, &dx); #else ax = 0; bx = 0; cx = 0; dx = 0; #endif if (cx & (1 << 5)) /* lzcnt */ { printf("rfxcodec_encode_create: got lzcnt\n"); enc->got_lzcnt = 1; } if (cx & (1 << 6)) /* SSE 4.a */ { printf("rfxcodec_encode_create: got sse4.a\n"); enc->got_sse4a = 1; } enc->width = width; enc->height = height; enc->mode = RLGR3; if (flags & RFX_FLAGS_RLGR1) { enc->mode = RLGR1; } switch (format) { case RFX_FORMAT_BGRA: enc->bits_per_pixel = 32; break; case RFX_FORMAT_RGBA: enc->bits_per_pixel = 32; break; case RFX_FORMAT_BGR: enc->bits_per_pixel = 24; break; case RFX_FORMAT_RGB: enc->bits_per_pixel = 24; break; case RFX_FORMAT_YUV: enc->bits_per_pixel = 32; break; default: free(enc); return 2; } enc->format = format; enc->rfx_encode_rgb_to_yuv = rfx_encode_rgb_to_yuv; enc->rfx_encode_argb_to_yuva = rfx_encode_argb_to_yuva; /* assign encoding functions */ if (flags & RFX_FLAGS_NOACCEL) { if (enc->mode == RLGR3) { printf("rfxcodec_encode_create: rfx_encode set to rfx_encode_component_rlgr3\n"); enc->rfx_encode = rfx_encode_component_rlgr3; /* rfxencode_tile.c */ } else { printf("rfxcodec_encode_create: rfx_encode set to rfx_encode_component_rlgr1\n"); enc->rfx_encode = rfx_encode_component_rlgr1; /* rfxencode_tile.c */ } } else { #if defined(RFX_USE_ACCEL_X86) if (enc->got_sse41) { if (enc->mode == RLGR3) { printf("rfxcodec_encode_create: rfx_encode set to rfx_encode_component_rlgr3_x86_sse41\n"); enc->rfx_encode = rfx_encode_component_rlgr3_x86_sse41; /* rfxencode_tile.c */ } else { printf("rfxcodec_encode_create: rfx_encode set to rfx_encode_component_rlgr1_x86_sse41\n"); enc->rfx_encode = rfx_encode_component_rlgr1_x86_sse41; /* rfxencode_tile.c */ } } else if (enc->got_sse2) { if (enc->mode == RLGR3) { printf("rfxcodec_encode_create: rfx_encode set to rfx_encode_component_rlgr3_x86_sse2\n"); enc->rfx_encode = rfx_encode_component_rlgr3_x86_sse2; /* rfxencode_tile.c */ } else { printf("rfxcodec_encode_create: rfx_encode set to rfx_encode_component_rlgr1_x86_sse2\n"); enc->rfx_encode = rfx_encode_component_rlgr1_x86_sse2; /* rfxencode_tile.c */ } } else { if (enc->mode == RLGR3) { printf("rfxcodec_encode_create: rfx_encode set to rfx_encode_component_rlgr3\n"); enc->rfx_encode = rfx_encode_component_rlgr3; /* rfxencode_tile.c */ } else { printf("rfxcodec_encode_create: rfx_encode set to rfx_encode_component_rlgr1\n"); enc->rfx_encode = rfx_encode_component_rlgr1; /* rfxencode_tile.c */ } } #elif defined(RFX_USE_ACCEL_AMD64) if (enc->got_sse41) { if (enc->mode == RLGR3) { printf("rfxcodec_encode_create: rfx_encode set to rfx_encode_component_rlgr3_amd64_sse41\n"); enc->rfx_encode = rfx_encode_component_rlgr3_amd64_sse41; /* rfxencode_tile.c */ } else { printf("rfxcodec_encode_create: rfx_encode set to rfx_encode_component_rlgr1_amd64_sse41\n"); enc->rfx_encode = rfx_encode_component_rlgr1_amd64_sse41; /* rfxencode_tile.c */ } } else if (enc->got_sse2) { if (enc->mode == RLGR3) { printf("rfxcodec_encode_create: rfx_encode set to rfx_encode_component_rlgr3_amd64_sse2\n"); enc->rfx_encode = rfx_encode_component_rlgr3_amd64_sse2; /* rfxencode_tile.c */ } else { printf("rfxcodec_encode_create: rfx_encode set to rfx_encode_component_rlgr1_amd64_sse2\n"); enc->rfx_encode = rfx_encode_component_rlgr1_amd64_sse2; /* rfxencode_tile.c */ } } else { if (enc->mode == RLGR3) { printf("rfxcodec_encode_create: rfx_encode set to rfx_encode_component_rlgr3\n"); enc->rfx_encode = rfx_encode_component_rlgr3; /* rfxencode_tile.c */ } else { printf("rfxcodec_encode_create: rfx_encode set to rfx_encode_component_rlgr1\n"); enc->rfx_encode = rfx_encode_component_rlgr1; /* rfxencode_tile.c */ } } #else if (enc->mode == RLGR3) { printf("rfxcodec_encode_create: rfx_encode set to rfx_encode_component_rlgr3\n"); enc->rfx_encode = rfx_encode_component_rlgr3; /* rfxencode_tile.c */ } else { printf("rfxcodec_encode_create: rfx_encode set to rfx_encode_component_rlgr1\n"); enc->rfx_encode = rfx_encode_component_rlgr1; /* rfxencode_tile.c */ } #endif } if (ax == 0) { } if (bx == 0) { } *handle = enc; return 0; } /******************************************************************************/ void * rfxcodec_encode_create(int width, int height, int format, int flags) { int error; void *handle; error = rfxcodec_encode_create_ex(width, height, format, flags, &handle); if (error == 0) { return handle; } return 0; } /******************************************************************************/ int rfxcodec_encode_destroy(void *handle) { struct rfxencode *enc; enc = (struct rfxencode *) handle; if (enc == NULL) { return 0; } free(enc); return 0; } /******************************************************************************/ int rfxcodec_encode_ex(void *handle, char *cdata, int *cdata_bytes, const char *buf, int width, int height, int stride_bytes, const struct rfx_rect *regions, int num_regions, const struct rfx_tile *tiles, int num_tiles, const char *quants, int num_quants, int flags) { struct rfxencode *enc; STREAM s; enc = (struct rfxencode *) handle; s.data = (uint8 *) cdata; s.p = s.data; s.size = *cdata_bytes; /* Only the first frame should send the RemoteFX header */ if ((enc->frame_idx == 0) && (enc->header_processed == 0)) { if (rfx_compose_message_header(enc, &s) != 0) { return 1; } } if (rfx_compose_message_data(enc, &s, regions, num_regions, buf, width, height, stride_bytes, tiles, num_tiles, quants, num_quants, flags) != 0) { return 1; } *cdata_bytes = (int) (s.p - s.data); return 0; } /******************************************************************************/ int rfxcodec_encode(void *handle, char *cdata, int *cdata_bytes, const char *buf, int width, int height, int stride_bytes, const struct rfx_rect *regions, int num_regions, const struct rfx_tile *tiles, int num_tiles, const char *quants, int num_quants) { return rfxcodec_encode_ex(handle, cdata, cdata_bytes, buf, width, height, stride_bytes, regions, num_regions, tiles, num_tiles, quants, num_quants, 0); } /******************************************************************************/ int rfxcodec_encode_get_internals(struct rfxcodec_encode_internals *internals) { memset(internals, 0, sizeof(struct rfxcodec_encode_internals)); internals->rfxencode_rlgr1 = rfx_rlgr1_encode; internals->rfxencode_rlgr3 = rfx_rlgr3_encode; internals->rfxencode_differential = rfx_differential_encode; internals->rfxencode_quantization = rfx_quantization_encode; internals->rfxencode_dwt_2d = rfx_dwt_2d_encode; internals->rfxencode_diff_rlgr1 = rfx_encode_diff_rlgr1; internals->rfxencode_diff_rlgr3 = rfx_encode_diff_rlgr3; #if defined(RFX_USE_ACCEL_X86) internals->rfxencode_dwt_shift_x86_sse2 = rfxcodec_encode_dwt_shift_x86_sse2; internals->rfxencode_dwt_shift_x86_sse41 = rfxcodec_encode_dwt_shift_x86_sse41; #endif #if defined(RFX_USE_ACCEL_AMD64) internals->rfxencode_dwt_shift_amd64_sse2 = rfxcodec_encode_dwt_shift_amd64_sse2; internals->rfxencode_dwt_shift_amd64_sse41 = rfxcodec_encode_dwt_shift_amd64_sse41; #endif return 0; } xrdp-0.9.5/librfxcodec/src/rfxencode_rgb_to_yuv.c000644 001751 001751 00000034500 13220730305 022052 0ustar00metameta000000 000000 /** * FreeRDP: A Remote Desktop Protocol client. * RemoteFX Codec Library - Encode * * Copyright 2011 Vic Lee * Copyright 2014-2017 Jay Sorg * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ #if defined(HAVE_CONFIG_H) #include #endif #include #include #include #include #include "rfxcommon.h" #include "rfxencode.h" #include "rfxconstants.h" #include "rfxencode_tile.h" #include "rfxencode_dwt.h" #include "rfxencode_quantization.h" #include "rfxencode_differential.h" #include "rfxencode_rlgr1.h" #include "rfxencode_rlgr3.h" #include "rfxencode_alpha.h" #define LLOG_LEVEL 1 #define LLOGLN(_level, _args) \ do { if (_level < LLOG_LEVEL) { printf _args ; printf("\n"); } } while (0) /******************************************************************************/ static int rfx_encode_format_rgb(const char *rgb_data, int width, int height, int stride_bytes, int pixel_format, uint8 *r_buf, uint8 *g_buf, uint8 *b_buf) { int x; int y; const uint8 *src; uint8 r; uint8 g; uint8 b; uint8 *lr_buf; uint8 *lg_buf; uint8 *lb_buf; LLOGLN(10, ("rfx_encode_format_rgb: pixel_format %d", pixel_format)); b = 0; g = 0; r = 0; switch (pixel_format) { case RFX_FORMAT_BGRA: for (y = 0; y < height; y++) { src = (uint8 *) (rgb_data + y * stride_bytes); lr_buf = r_buf + y * 64; lg_buf = g_buf + y * 64; lb_buf = b_buf + y * 64; for (x = 0; x < width; x++) { b = *src++; *lb_buf++ = b; g = *src++; *lg_buf++ = g; r = *src++; *lr_buf++ = r; src++; } while (x < 64) { *lr_buf++ = r; *lg_buf++ = g; *lb_buf++ = r; x++; } } while (y < 64) { lr_buf = r_buf + y * 64; lg_buf = g_buf + y * 64; lb_buf = b_buf + y * 64; memcpy(lr_buf, lr_buf - 64, 64); memcpy(lg_buf, lg_buf - 64, 64); memcpy(lb_buf, lb_buf - 64, 64); y++; } break; case RFX_FORMAT_RGBA: for (y = 0; y < height; y++) { src = (uint8 *) (rgb_data + y * stride_bytes); lr_buf = r_buf + y * 64; lg_buf = g_buf + y * 64; lb_buf = b_buf + y * 64; for (x = 0; x < width; x++) { r = *src++; *lr_buf++ = r; g = *src++; *lg_buf++ = g; b = *src++; *lb_buf++ = b; src++; } while (x < 64) { *lr_buf++ = r; *lg_buf++ = g; *lb_buf++ = b; x++; } } while (y < 64) { lr_buf = r_buf + y * 64; lg_buf = g_buf + y * 64; lb_buf = b_buf + y * 64; memcpy(lr_buf, lr_buf - 64, 64); memcpy(lg_buf, lg_buf - 64, 64); memcpy(lb_buf, lb_buf - 64, 64); y++; } break; case RFX_FORMAT_BGR: for (y = 0; y < height; y++) { src = (uint8 *) (rgb_data + y * stride_bytes); lr_buf = r_buf + y * 64; lg_buf = g_buf + y * 64; lb_buf = b_buf + y * 64; for (x = 0; x < width; x++) { b = *src++; *lb_buf++ = b; g = *src++; *lg_buf++ = g; r = *src++; *lr_buf++ = r; } while (x < 64) { *lr_buf++ = r; *lg_buf++ = g; *lb_buf++ = b; x++; } } while (y < 64) { lr_buf = r_buf + y * 64; lg_buf = g_buf + y * 64; lb_buf = b_buf + y * 64; memcpy(lr_buf, lr_buf - 64, 64); memcpy(lg_buf, lg_buf - 64, 64); memcpy(lb_buf, lb_buf - 64, 64); y++; } break; case RFX_FORMAT_RGB: for (y = 0; y < height; y++) { src = (uint8 *) (rgb_data + y * stride_bytes); lr_buf = r_buf + y * 64; lg_buf = g_buf + y * 64; lb_buf = b_buf + y * 64; for (x = 0; x < width; x++) { r = *src++; *lr_buf++ = r; g = *src++; *lg_buf++ = g; b = *src++; *lb_buf++ = b; } while (x < 64) { *lr_buf++ = r; *lg_buf++ = g; *lb_buf++ = b; x++; } } while (y < 64) { lr_buf = r_buf + y * 64; lg_buf = g_buf + y * 64; lb_buf = b_buf + y * 64; memcpy(lr_buf, lr_buf - 64, 64); memcpy(lg_buf, lg_buf - 64, 64); memcpy(lb_buf, lb_buf - 64, 64); y++; } break; } return 0; } /******************************************************************************/ static int rfx_encode_format_argb(const char *argb_data, int width, int height, int stride_bytes, int pixel_format, uint8 *a_buf, uint8 *r_buf, uint8 *g_buf, uint8 *b_buf) { int x; int y; const uint8 *src; uint8 a; uint8 r; uint8 g; uint8 b; uint8 *la_buf; uint8 *lr_buf; uint8 *lg_buf; uint8 *lb_buf; LLOGLN(10, ("rfx_encode_format_argb: pixel_format %d", pixel_format)); b = 0; g = 0; r = 0; a = 0; switch (pixel_format) { case RFX_FORMAT_BGRA: for (y = 0; y < height; y++) { src = (uint8 *) (argb_data + y * stride_bytes); la_buf = a_buf + y * 64; lr_buf = r_buf + y * 64; lg_buf = g_buf + y * 64; lb_buf = b_buf + y * 64; for (x = 0; x < width; x++) { b = *src++; *lb_buf++ = b; g = *src++; *lg_buf++ = g; r = *src++; *lr_buf++ = r; a = *src++; *la_buf++ = a; } while (x < 64) { *la_buf++ = a; *lr_buf++ = r; *lg_buf++ = g; *lb_buf++ = r; x++; } } while (y < 64) { la_buf = a_buf + y * 64; lr_buf = r_buf + y * 64; lg_buf = g_buf + y * 64; lb_buf = b_buf + y * 64; memcpy(la_buf, la_buf - 64, 64); memcpy(lr_buf, lr_buf - 64, 64); memcpy(lg_buf, lg_buf - 64, 64); memcpy(lb_buf, lb_buf - 64, 64); y++; } break; case RFX_FORMAT_RGBA: for (y = 0; y < height; y++) { src = (uint8 *) (argb_data + y * stride_bytes); la_buf = a_buf + y * 64; lr_buf = r_buf + y * 64; lg_buf = g_buf + y * 64; lb_buf = b_buf + y * 64; for (x = 0; x < width; x++) { r = *src++; *lr_buf++ = r; g = *src++; *lg_buf++ = g; b = *src++; *lb_buf++ = b; a = *src++; *la_buf++ = a; } while (x < 64) { *la_buf++ = a; *lr_buf++ = r; *lg_buf++ = g; *lb_buf++ = b; x++; } } while (y < 64) { la_buf = a_buf + y * 64; lr_buf = r_buf + y * 64; lg_buf = g_buf + y * 64; lb_buf = b_buf + y * 64; memcpy(la_buf, la_buf - 64, 64); memcpy(lr_buf, lr_buf - 64, 64); memcpy(lg_buf, lg_buf - 64, 64); memcpy(lb_buf, lb_buf - 64, 64); y++; } break; case RFX_FORMAT_BGR: for (y = 0; y < height; y++) { src = (uint8 *) (argb_data + y * stride_bytes); lr_buf = r_buf + y * 64; lg_buf = g_buf + y * 64; lb_buf = b_buf + y * 64; for (x = 0; x < width; x++) { b = *src++; *lb_buf++ = b; g = *src++; *lg_buf++ = g; r = *src++; *lr_buf++ = r; } while (x < 64) { *lr_buf++ = r; *lg_buf++ = g; *lb_buf++ = b; x++; } } while (y < 64) { lr_buf = r_buf + y * 64; lg_buf = g_buf + y * 64; lb_buf = b_buf + y * 64; memcpy(lr_buf, lr_buf - 64, 64); memcpy(lg_buf, lg_buf - 64, 64); memcpy(lb_buf, lb_buf - 64, 64); y++; } break; case RFX_FORMAT_RGB: for (y = 0; y < height; y++) { src = (uint8 *) (argb_data + y * stride_bytes); lr_buf = r_buf + y * 64; lg_buf = g_buf + y * 64; lb_buf = b_buf + y * 64; for (x = 0; x < width; x++) { r = *src++; *lr_buf++ = r; g = *src++; *lg_buf++ = g; b = *src++; *lb_buf++ = b; } while (x < 64) { *lr_buf++ = r; *lg_buf++ = g; *lb_buf++ = b; x++; } } while (y < 64) { lr_buf = r_buf + y * 64; lg_buf = g_buf + y * 64; lb_buf = b_buf + y * 64; memcpy(lr_buf, lr_buf - 64, 64); memcpy(lg_buf, lg_buf - 64, 64); memcpy(lb_buf, lb_buf - 64, 64); y++; } break; } return 0; } /******************************************************************************/ /* http://msdn.microsoft.com/en-us/library/ff635643.aspx * 0.299 -0.168935 0.499813 * 0.587 -0.331665 -0.418531 * 0.114 0.50059 -0.081282 y = r * 0.299000 + g * 0.587000 + b * 0.114000; u = r * -0.168935 + g * -0.331665 + b * 0.500590; v = r * 0.499813 + g * -0.418531 + b * -0.081282; */ /* 19595 38470 7471 -11071 -21736 32807 32756 -27429 -5327 */ static int rfx_encode_rgb_to_yuv_tile(uint8 *y_r_buf, uint8 *u_g_buf, uint8 *v_b_buf) { int i; sint32 r, g, b; sint32 y, u, v; for (i = 0; i < 4096; i++) { r = y_r_buf[i]; g = u_g_buf[i]; b = v_b_buf[i]; y = (r * 19595 + g * 38470 + b * 7471) >> 16; u = (r * -11071 + g * -21736 + b * 32807) >> 16; v = (r * 32756 + g * -27429 + b * -5327) >> 16; y_r_buf[i] = MINMAX(y, 0, 255); u_g_buf[i] = MINMAX(u + 128, 0, 255); v_b_buf[i] = MINMAX(v + 128, 0, 255); } return 0; } /******************************************************************************/ int rfx_encode_rgb_to_yuv(struct rfxencode *enc, const char *rgb_data, int width, int height, int stride_bytes) { uint8 *y_r_buffer; uint8 *u_g_buffer; uint8 *v_b_buffer; y_r_buffer = enc->y_r_buffer; u_g_buffer = enc->u_g_buffer; v_b_buffer = enc->v_b_buffer; if (rfx_encode_format_rgb(rgb_data, width, height, stride_bytes, enc->format, y_r_buffer, u_g_buffer, v_b_buffer) != 0) { return 1; } if (rfx_encode_rgb_to_yuv_tile(y_r_buffer, u_g_buffer, v_b_buffer) != 0) { return 1; } return 0; } /******************************************************************************/ int rfx_encode_argb_to_yuva(struct rfxencode *enc, const char *argb_data, int width, int height, int stride_bytes) { uint8 *a_buffer; uint8 *y_r_buffer; uint8 *u_g_buffer; uint8 *v_b_buffer; a_buffer = enc->a_buffer; y_r_buffer = enc->y_r_buffer; u_g_buffer = enc->u_g_buffer; v_b_buffer = enc->v_b_buffer; if (rfx_encode_format_argb(argb_data, width, height, stride_bytes, enc->format, a_buffer, y_r_buffer, u_g_buffer, v_b_buffer) != 0) { return 1; } if (rfx_encode_rgb_to_yuv_tile(y_r_buffer, u_g_buffer, v_b_buffer) != 0) { return 1; } return 0; } xrdp-0.9.5/librfxcodec/src/rfxencode_dwt.c000644 001751 001751 00000015177 13127342056 020512 0ustar00metameta000000 000000 /** * FreeRDP: A Remote Desktop Protocol client. * RemoteFX Codec Library - DWT * * Copyright 2011 Vic Lee * Copyright 2014-2017 Jay Sorg * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ #if defined(HAVE_CONFIG_H) #include #endif #include #include #include #include "rfxcommon.h" /******************************************************************************/ static int rfx_dwt_2d_encode_horz(sint16 *buffer, sint16 *dwt, int subband_width) { sint16 *l_src, *h_src; sint16 *hl, *lh, *hh, *ll; int x, y; int n; /* DWT in horizontal direction, results in 4 sub-bands in * HL(0), LH(1), HH(2), LL(3) order, stored in original buffer. */ /* The lower part L generates LL(3) and HL(0). */ /* The higher part H generates LH(1) and HH(2). */ ll = buffer + subband_width * subband_width * 3; hl = buffer; l_src = dwt; lh = buffer + subband_width * subband_width; hh = buffer + subband_width * subband_width * 2; h_src = dwt + subband_width * subband_width * 2; for (y = 0; y < subband_width; y++) { /* pre */ hl[0] = (l_src[1] - ((l_src[0] + l_src[2]) >> 1)) >> 1; ll[0] = l_src[0] + hl[0]; /* loop */ for (n = 1; n < subband_width - 1; n++) { x = n << 1; hl[n] = (l_src[x + 1] - ((l_src[x] + l_src[x + 2]) >> 1)) >> 1; ll[n] = l_src[x] + ((hl[n - 1] + hl[n]) >> 1); } /* post */ n = subband_width - 1; x = n << 1; hl[n] = (l_src[x + 1] - ((l_src[x] + l_src[x]) >> 1)) >> 1; ll[n] = l_src[x] + ((hl[n - 1] + hl[n]) >> 1); /* pre */ hh[0] = (h_src[1] - ((h_src[0] + h_src[2]) >> 1)) >> 1; lh[0] = h_src[0] + hh[0]; /* loop */ for (n = 1; n < subband_width - 1; n++) { x = n << 1; hh[n] = (h_src[x + 1] - ((h_src[x] + h_src[x + 2]) >> 1)) >> 1; lh[n] = h_src[x] + ((hh[n - 1] + hh[n]) >> 1); } /* post */ n = subband_width - 1; x = n << 1; hh[n] = (h_src[x + 1] - ((h_src[x] + h_src[x]) >> 1)) >> 1; lh[n] = h_src[x] + ((hh[n - 1] + hh[n]) >> 1); ll += subband_width; hl += subband_width; l_src += subband_width << 1; lh += subband_width; hh += subband_width; h_src += subband_width << 1; } return 0; } /******************************************************************************/ static int rfx_dwt_2d_encode_block(sint16 *buffer, sint16 *dwt, int subband_width) { sint16 *src, *l, *h; int total_width; int x, y; int n; total_width = subband_width << 1; /* DWT in vertical direction, results in 2 sub-bands in L, H order in * tmp buffer dwt. */ for (x = 0; x < total_width; x++) { /* pre */ l = dwt + x; h = l + subband_width * total_width; src = buffer + x; *h = (src[total_width] - ((src[0] + src[2 * total_width]) >> 1)) >> 1; *l = src[0] + (*h); /* loop */ for (n = 1; n < subband_width - 1; n++) { y = n << 1; l = dwt + n * total_width + x; h = l + subband_width * total_width; src = buffer + y * total_width + x; *h = (src[total_width] - ((src[0] + src[2 * total_width]) >> 1)) >> 1; *l = src[0] + ((*(h - total_width) + *h) >> 1); } /* post */ n = subband_width - 1; y = n << 1; l = dwt + n * total_width + x; h = l + subband_width * total_width; src = buffer + y * total_width + x; *h = (src[total_width] - ((src[0] + src[0]) >> 1)) >> 1; *l = src[0] + ((*(h - total_width) + *h) >> 1); } return rfx_dwt_2d_encode_horz(buffer, dwt, subband_width); } /******************************************************************************/ static int rfx_dwt_2d_encode_block8(const uint8 *in_buffer, sint16 *buffer, sint16 *dwt, int subband_width) { const uint8 *src; sint16 *l, *h; sint16 s1, s2, s3; int total_width; int x, y; int n; total_width = subband_width << 1; /* DWT in vertical direction, results in 2 sub-bands in L, H order in * tmp buffer dwt. */ for (x = 0; x < total_width; x++) { /* pre */ l = dwt + x; h = l + subband_width * total_width; src = in_buffer + x; s1 = (src[total_width] - 128) << DWT_FACTOR; s2 = (src[0] - 128) << DWT_FACTOR; s3 = (src[2 * total_width] - 128) << DWT_FACTOR; *h = (s1 - ((s2 + s3) >> 1)) >> 1; s1 = (src[0] - 128) << DWT_FACTOR; *l = s1 + *h; /* loop */ for (n = 1; n < subband_width - 1; n++) { y = n << 1; l = dwt + n * total_width + x; h = l + subband_width * total_width; src = in_buffer + y * total_width + x; s1 = (src[total_width] - 128) << DWT_FACTOR; s2 = (src[0] - 128) << DWT_FACTOR; s3 = (src[2 * total_width] - 128) << DWT_FACTOR; *h = (s1 - ((s2 + s3) >> 1)) >> 1; s1 = (src[0] - 128) << DWT_FACTOR; *l = s1 + ((*(h - total_width) + *h) >> 1); } /* post */ n = subband_width - 1; y = n << 1; l = dwt + n * total_width + x; h = l + subband_width * total_width; src = in_buffer + y * total_width + x; s1 = (src[total_width] - 128) << DWT_FACTOR; s2 = (src[0] - 128) << DWT_FACTOR; s3 = (src[0] - 128) << DWT_FACTOR; *h = (s1 - ((s2 + s3) >> 1)) >> 1; s1 = (src[0] - 128) << DWT_FACTOR; *l = s1 + ((*(h - total_width) + *h) >> 1); } return rfx_dwt_2d_encode_horz(buffer, dwt, subband_width); } /******************************************************************************/ int rfx_dwt_2d_encode(const uint8 *in_buffer, sint16 *buffer, sint16 *dwt_buffer) { rfx_dwt_2d_encode_block8(in_buffer, buffer, dwt_buffer, 32); rfx_dwt_2d_encode_block(buffer + 3072, dwt_buffer, 16); rfx_dwt_2d_encode_block(buffer + 3840, dwt_buffer, 8); return 0; } xrdp-0.9.5/librfxcodec/src/rfxencode_differential.c000644 001751 001751 00000002352 13061652764 022346 0ustar00metameta000000 000000 /** * FreeRDP: A Remote Desktop Protocol client. * RemoteFX Codec Library - Differential Encoding * * Copyright 2011 Vic Lee * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ #if defined(HAVE_CONFIG_H) #include #endif #include #include #include #include #include "rfxcommon.h" #include "rfxencode.h" #include "rfxconstants.h" /******************************************************************************/ int rfx_differential_encode(sint16 *buffer, int buffer_size) { sint16 n1, n2; sint16 *dst; for (n1 = *buffer, dst = buffer + 1; buffer_size > 1; dst++, buffer_size--) { n2 = *dst; *dst -= n1; n1 = n2; } return 0; } xrdp-0.9.5/librfxcodec/src/rfxconstants.h000644 001751 001751 00000003354 12777440111 020413 0ustar00metameta000000 000000 /** * FreeRDP: A Remote Desktop Protocol client. * RemoteFX Codec Library - API Header * * Copyright 2011 Vic Lee * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ #ifndef __RFX_CONSTANTS_H #define __RFX_CONSTANTS_H enum _RLGR_MODE { RLGR1, RLGR3 }; /* sync */ #define WF_MAGIC 0xCACCACCA #define WF_VERSION_1_0 0x0100 /* blockType */ #define WBT_SYNC 0xCCC0 #define WBT_CODEC_VERSIONS 0xCCC1 #define WBT_CHANNELS 0xCCC2 #define WBT_CONTEXT 0xCCC3 #define WBT_FRAME_BEGIN 0xCCC4 #define WBT_FRAME_END 0xCCC5 #define WBT_REGION 0xCCC6 #define WBT_EXTENSION 0xCCC7 #define WBT_EXTENSION_PLUS 0xDDD7 #define CBT_REGION 0xCAC1 #define CBT_TILESET 0xCAC2 #define CBT_TILE 0xCAC3 /* tileSize */ #define CT_TILE_64x64 0x0040 /* properties.flags */ #define CODEC_MODE 0x02 /* properties.cct */ #define COL_CONV_ICT 0x1 /* properties.xft */ #define CLW_XFORM_DWT_53_A 0x1 /* properties.et */ #define CLW_ENTROPY_RLGR1 0x01 #define CLW_ENTROPY_RLGR3 0x04 /* properties.qt */ #define SCALAR_QUANTIZATION 0x1 #endif /* __RFX_CONSTANTS_H */ xrdp-0.9.5/librfxcodec/src/rfxcommon.h000644 001751 001751 00000010050 13127342056 017655 0ustar00metameta000000 000000 /** * RFX codec * * Copyright 2014-2017 Jay Sorg * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ #ifndef __RFXCOMMON_H #define __RFXCOMMON_H #define MIN(_val1, _val2) (_val1) < (_val2) ? (_val1) : (_val2) #define MAX(_val1, _val2) (_val1) > (_val2) ? (_val1) : (_val2) #define MINMAX(_v, _l, _h) ((_v) < (_l) ? (_l) : ((_v) > (_h) ? (_h) : (_v))) #define DWT_FACTOR 5 typedef signed char sint8; typedef unsigned char uint8; typedef signed short sint16; typedef unsigned short uint16; typedef signed int sint32; typedef unsigned int uint32; struct _STREAM { uint8 *data; uint8 *p; int size; }; typedef struct _STREAM STREAM; #if defined(__x86__) || defined(__x86_64__) || \ defined(__AMD64__) || defined(_M_IX86) || defined (_M_AMD64) || \ defined(__i386__) #define stream_read_uint8(_s, _v) do { _v = ((uint8 *) ((_s)->p))[0]; (_s)->p += 1; } while (0) #define stream_read_uint16(_s, _v) do { _v = ((uint16 *) ((_s)->p))[0]; (_s)->p += 2; } while (0) #define stream_read_uint32(_s, _v) do { _v = ((uint32 *) ((_s)->p))[0]; (_s)->p += 4; } while (0) #define stream_write_uint8(_s, _v) do { ((uint8 *) ((_s)->p))[0] = _v; (_s)->p += 1; } while (0) #define stream_write_uint16(_s, _v) do { ((uint16 *) ((_s)->p))[0] = _v; (_s)->p += 2; } while (0) #define stream_write_uint32(_s, _v) do { ((uint32 *) ((_s)->p))[0] = _v; (_s)->p += 4; } while (0) #else #define stream_read_uint8(_s, _v) do { \ _v = ((uint8 *) ((_s)->p))[0]; \ (_s)->p += 1; \ } while (0) #define stream_read_uint16(_s, _v) do { \ _v = (((uint8 *) ((_s)->p))[0]) | \ ((((uint8 *) ((_s)->p))[1]) << 8); \ (_s)->p += 2; \ } while (0) #define stream_read_uint32(_s, _v) do { \ _v = (((uint8 *) ((_s)->p))[0]) | \ ((((uint8 *) ((_s)->p))[1]) << 8) | \ ((((uint8 *) ((_s)->p))[2]) << 16) | \ ((((uint8 *) ((_s)->p))[3]) << 24); \ (_s)->p += 4; \ } while (0) #define stream_write_uint8(_s, _v) do { \ ((uint8 *) ((_s)->p))[0] = _v; \ (_s)->p += 1; \ } while (0) #define stream_write_uint16(_s, _v) do { \ ((uint8 *) ((_s)->p))[0] = (uint8) (_v); \ ((uint8 *) ((_s)->p))[1] = (uint8) ((_v) >> 8); \ (_s)->p += 2; \ } while (0) #define stream_write_uint32(_s, _v) do { \ ((uint8 *) ((_s)->p))[0] = (uint8) (_v); \ ((uint8 *) ((_s)->p))[1] = (uint8) ((_v) >> 8); \ ((uint8 *) ((_s)->p))[2] = (uint8) ((_v) >> 16); \ ((uint8 *) ((_s)->p))[3] = (uint8) ((_v) >> 24); \ (_s)->p += 4; \ } while (0) #endif #define stream_seek(_s, _n) (_s)->p += _n #define stream_seek_uint8(_s) (_s)->p += 1 #define stream_seek_uint16(_s) (_s)->p += 2 #define stream_seek_uint32(_s) (_s)->p += 4 #define stream_get_pos(_s) ((int) ((_s)->p - (_s)->data)) #define stream_get_tail(_s) (_s)->p #define stream_get_left(_s) ((_s)->size - ((_s)->p - (_s)->data)) #define stream_set_pos(_s, _m) (_s)->p = (_s)->data + (_m) #define xnew(_type) (_type *) calloc(1, sizeof(_type)) /* GCC has __builtin_clz that translates to BSR on x86/x64, CLZ on ARM, etc. and emulates the instruction if the hardware does not implement it. Visual C++ 2005 and up has _BitScanReverse LZCNT = BSR ^ 31 */ #if defined(__GNUC__) #define GBSR(_in, _r) do { \ _r = __builtin_clz(_in) ^ 31; \ } while (0) #elif defined(_MSC_VER) && (_MSC_VER > 1000) #define GBSR(_in, _r) do { \ unsigned long rv = 0; \ _BitScanReverse(&rv, _in); \ _r = rv; \ } while (0) #else #define GBSR(_in, _r) do { \ int rv = -1; \ int x = _in; \ while (x != 0) \ { \ rv++; \ x = x >> 1; \ } \ _r = rv; \ } while (0) #endif #endif xrdp-0.9.5/librfxcodec/src/rfxencode_diff_rlgr3.h000644 001751 001751 00000001533 13061652764 021740 0ustar00metameta000000 000000 /** * FreeRDP: A Remote Desktop Protocol client. * RemoteFX Codec Library - RLGR * * Copyright 2011 Vic Lee * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ #ifndef __RFX_DIFF_RLGR3_H #define __RFX_DIFF_RLGR3_H #include "rfxcommon.h" int rfx_encode_diff_rlgr3(sint16 *coef, uint8 *cdata, int cdata_size); #endif /* __RFX_DIFF_RLGR3_H */ xrdp-0.9.5/librfxcodec/src/rfxencode_rlgr1.h000644 001751 001751 00000001515 13061652764 020746 0ustar00metameta000000 000000 /** * FreeRDP: A Remote Desktop Protocol client. * RemoteFX Codec Library - RLGR * * Copyright 2011 Vic Lee * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ #ifndef __RFX_RLGR1_H #define __RFX_RLGR1_H #include "rfxcommon.h" int rfx_rlgr1_encode(const sint16 *data, uint8 *buffer, int buffer_size); #endif /* __RFX_RLGR_H */ xrdp-0.9.5/librfxcodec/src/x86/rfxencode_tile_x86.c000644 001751 001751 00000007232 13061652764 022003 0ustar00metameta000000 000000 /** * FreeRDP: A Remote Desktop Protocol client. * RemoteFX Codec Library - Encode * * Copyright 2011 Vic Lee * Copyright 2014-2015 Jay Sorg * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ #if defined(HAVE_CONFIG_H) #include #endif #include #include #include #include "rfxcommon.h" #include "rfxencode.h" #include "rfxencode_differential.h" #include "rfxencode_rlgr1.h" #include "rfxencode_rlgr3.h" #include "rfxencode_alpha.h" #include "rfxencode_diff_rlgr1.h" #include "rfxencode_diff_rlgr3.h" #include "x86/funcs_x86.h" #define LLOG_LEVEL 1 #define LLOGLN(_level, _args) \ do { if (_level < LLOG_LEVEL) { printf _args ; printf("\n"); } } while (0) /******************************************************************************/ int rfx_encode_component_rlgr1_x86_sse2(struct rfxencode *enc, const char *qtable, const uint8 *data, uint8 *buffer, int buffer_size, int *size) { LLOGLN(10, ("rfx_encode_component_rlgr1_x86_sse2:")); if (rfxcodec_encode_dwt_shift_x86_sse2(qtable, data, enc->dwt_buffer1, enc->dwt_buffer) != 0) { return 1; } *size = rfx_encode_diff_rlgr1(enc->dwt_buffer1, buffer, buffer_size); return 0; } /******************************************************************************/ int rfx_encode_component_rlgr3_x86_sse2(struct rfxencode *enc, const char *qtable, const uint8 *data, uint8 *buffer, int buffer_size, int *size) { LLOGLN(10, ("rfx_encode_component_rlgr3_x86_sse2:")); if (rfxcodec_encode_dwt_shift_x86_sse2(qtable, data, enc->dwt_buffer1, enc->dwt_buffer) != 0) { return 1; } *size = rfx_encode_diff_rlgr3(enc->dwt_buffer1, buffer, buffer_size); return 0; } /******************************************************************************/ int rfx_encode_component_rlgr1_x86_sse41(struct rfxencode *enc, const char *qtable, const uint8 *data, uint8 *buffer, int buffer_size, int *size) { LLOGLN(10, ("rfx_encode_component_rlgr1_x86_sse41:")); if (rfxcodec_encode_dwt_shift_x86_sse41(qtable, data, enc->dwt_buffer1, enc->dwt_buffer) != 0) { return 1; } *size = rfx_encode_diff_rlgr1(enc->dwt_buffer1, buffer, buffer_size); return 0; } /******************************************************************************/ int rfx_encode_component_rlgr3_x86_sse41(struct rfxencode *enc, const char *qtable, const uint8 *data, uint8 *buffer, int buffer_size, int *size) { LLOGLN(10, ("rfx_encode_component_rlgr3_x86_sse41:")); if (rfxcodec_encode_dwt_shift_x86_sse41(qtable, data, enc->dwt_buffer1, enc->dwt_buffer) != 0) { return 1; } *size = rfx_encode_diff_rlgr3(enc->dwt_buffer1, buffer, buffer_size); return 0; } xrdp-0.9.5/librfxcodec/src/x86/Makefile.am000644 001751 001751 00000001147 13162371073 020164 0ustar00metameta000000 000000 NAFLAGS += -DASM_ARCH_I386 X86_ASM = \ cpuid_x86.asm \ rfxcodec_encode_dwt_shift_x86_sse2.asm \ rfxcodec_encode_dwt_shift_x86_sse41.asm AM_CPPFLAGS = \ -I$(top_srcdir)/include \ -I$(top_srcdir)/src noinst_LTLIBRARIES = librfxencode-x86.la librfxencode_x86_la_SOURCES = \ funcs_x86.h \ rfxencode_tile_x86.c \ $(X86_ASM) nasm_verbose = $(nasm_verbose_@AM_V@) nasm_verbose_ = $(nasm_verbose_@AM_DEFAULT_V@) nasm_verbose_0 = @echo " NASM $@"; .asm.lo: $(nasm_verbose)$(LIBTOOL) $(AM_V_lt) --mode=compile \ $(top_srcdir)/src/nasm_lt.sh $(NASM) $(NAFLAGS) \ -I$(top_srcdir)/src $< -o $@ xrdp-0.9.5/librfxcodec/src/x86/rfxcodec_encode_dwt_shift_x86_sse41.asm000644 001751 001751 00000107073 13162371073 025550 0ustar00metameta000000 000000 ; ;Copyright 2016 Jay Sorg ;Copyright 2017 mirabilos ; ;Permission to use, copy, modify, distribute, and sell this software and its ;documentation for any purpose is hereby granted without fee, provided that ;the above copyright notice appear in all copies and that both that ;copyright notice and this permission notice appear in supporting ;documentation. ; ;The above copyright notice and this permission notice shall be included in ;all copies or substantial portions of the Software. ; ;THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR ;IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, ;FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE ;OPEN GROUP BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN ;AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN ;CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. ; ;x86 asm dwt %include "common.asm" PREPARE_RODATA cw128 times 8 dw 128 cdFFFF times 4 dd 65535 ; these are 1 << (factor - 1) 0 to 15 is factor cwa0 times 8 dw 0 ; 0 cwa1 times 8 dw 1 ; 1 cwa2 times 8 dw 2 ; 2 cwa4 times 8 dw 4 ; 3 cwa8 times 8 dw 8 ; 4 cwa16 times 8 dw 16 ; 5 cwa32 times 8 dw 32 ; 6 cwa64 times 8 dw 64 ; 7 cwa128 times 8 dw 128 ; 8 cwa256 times 8 dw 256 ; 9 cwa512 times 8 dw 512 ; 10 cwa1024 times 8 dw 1024 ; 11 cwa2048 times 8 dw 2048 ; 12 cwa4096 times 8 dw 4096 ; 13 cwa8192 times 8 dw 8192 ; 14 cwa16384 times 8 dw 16384 ; 15 %define LHI_ADD [esp + 1 * 16 + 4] %define LHI_SFT [esp + 2 * 16 + 4] %define LLO_ADD [esp + 3 * 16 + 4] %define LLO_SFT [esp + 4 * 16 + 4] ;****************************************************************************** ; source 16 bit signed, 16 pixel width rfx_dwt_2d_encode_block_horiz_16_16: mov ecx, 8 loop1a: ; pre / post movdqa xmm1, [esi] ; src[2n] movdqa xmm2, [esi + 16] movdqa xmm6, xmm1 movdqa xmm7, xmm2 pand xmm1, [lsym(cdFFFF)] pand xmm2, [lsym(cdFFFF)] packusdw xmm1, xmm2 movdqa xmm2, xmm6 ; src[2n + 1] movdqa xmm3, xmm7 psrldq xmm2, 2 psrldq xmm3, 2 pand xmm2, [lsym(cdFFFF)] pand xmm3, [lsym(cdFFFF)] packusdw xmm2, xmm3 movdqa xmm3, xmm6 ; src[2n + 2] movdqa xmm4, xmm7 psrldq xmm3, 4 psrldq xmm4, 4 movd eax, xmm7 movd xmm5, eax pslldq xmm5, 12 por xmm3, xmm5 movdqa xmm5, xmm7 psrldq xmm5, 12 pslldq xmm5, 12 por xmm4, xmm5 pand xmm3, [lsym(cdFFFF)] pand xmm4, [lsym(cdFFFF)] packusdw xmm3, xmm4 movdqa xmm4, xmm1 movdqa xmm5, xmm2 movdqa xmm6, xmm3 ; h[n] = (src[2n + 1] - ((src[2n] + src[2n + 2]) >> 1)) >> 1 paddw xmm4, xmm6 psraw xmm4, 1 psubw xmm5, xmm4 psraw xmm5, 1 movdqa xmm6, xmm5 ; out hi paddw xmm6, LHI_ADD psraw xmm6, LHI_SFT movdqa [edi], xmm6 ; l[n] = src[2n] + ((h[n - 1] + h[n]) >> 1) movdqa xmm7, xmm5 movd eax, xmm7 pslldq xmm7, 2 and eax, 0xFFFF movd xmm6, eax por xmm7, xmm6 paddw xmm5, xmm7 psraw xmm5, 1 paddw xmm5, xmm1 movdqa xmm6, xmm5 ; out lo paddw xmm6, LLO_ADD psraw xmm6, LLO_SFT movdqa [edx], xmm6 ; move right lea esi, [esi + 16 * 2] lea edi, [edi + 8 * 2] lea edx, [edx + 8 * 2] ; move left lea esi, [esi - 16 * 2] lea edi, [edi - 8 * 2] lea edx, [edx - 8 * 2] ; move down lea esi, [esi + 16 * 2] lea edi, [edi + 8 * 2] lea edx, [edx + 8 * 2] dec ecx jnz loop1a ret ;****************************************************************************** ; source 16 bit signed, 16 pixel width rfx_dwt_2d_encode_block_verti_16_16: mov ecx, 2 loop1b: ; pre movdqa xmm1, [esi] ; src[2n] movdqa xmm2, [esi + 16 * 2] ; src[2n + 1] movdqa xmm3, [esi + 16 * 2 * 2] ; src[2n + 2] movdqa xmm4, xmm1 movdqa xmm5, xmm2 movdqa xmm6, xmm3 ; h[n] = (src[2n + 1] - ((src[2n] + src[2n + 2]) >> 1)) >> 1 paddw xmm4, xmm6 psraw xmm4, 1 psubw xmm5, xmm4 psraw xmm5, 1 movdqa [edi], xmm5 ; out hi movdqa xmm6, xmm5 ; save hi ; l[n] = src[2n] + ((h[n - 1] + h[n]) >> 1) paddw xmm5, xmm1 movdqa [edx], xmm5 ; out lo movdqa xmm7, xmm6 ; save hi ; move down lea esi, [esi + 16 * 2 * 2] ; 2 rows lea edi, [edi + 16 * 2] ; 1 row lea edx, [edx + 16 * 2] ; 1 row ; loop shl ecx, 16 mov cx, 6 loop2b: movdqa xmm1, xmm3 ; src[2n] movdqa xmm2, [esi + 16 * 2] ; src[2n + 1] movdqa xmm3, [esi + 16 * 2 * 2] ; src[2n + 2] movdqa xmm4, xmm1 movdqa xmm5, xmm2 movdqa xmm6, xmm3 ; h[n] = (src[2n + 1] - ((src[2n] + src[2n + 2]) >> 1)) >> 1 paddw xmm4, xmm6 psraw xmm4, 1 psubw xmm5, xmm4 psraw xmm5, 1 movdqa [edi], xmm5 ; out hi movdqa xmm6, xmm5 ; save hi ; l[n] = src[2n] + ((h[n - 1] + h[n]) >> 1) paddw xmm5, xmm7 psraw xmm5, 1 paddw xmm5, xmm1 movdqa [edx], xmm5 ; out lo movdqa xmm7, xmm6 ; save hi ; move down lea esi, [esi + 16 * 2 * 2] ; 2 rows lea edi, [edi + 16 * 2] ; 1 row lea edx, [edx + 16 * 2] ; 1 row dec cx jnz loop2b shr ecx, 16 ; post movdqa xmm1, xmm3 ; src[2n] movdqa xmm2, [esi + 16 * 2] ; src[2n + 1] movdqa xmm4, xmm1 movdqa xmm5, xmm2 movdqa xmm6, xmm3 ; h[n] = (src[2n + 1] - ((src[2n] + src[2n + 2]) >> 1)) >> 1 paddw xmm4, xmm6 psraw xmm4, 1 psubw xmm5, xmm4 psraw xmm5, 1 movdqa [edi], xmm5 ; out hi ; l[n] = src[2n] + ((h[n - 1] + h[n]) >> 1) paddw xmm5, xmm7 psraw xmm5, 1 paddw xmm5, xmm1 movdqa [edx], xmm5 ; out lo ; move down lea esi, [esi + 16 * 2 * 2] ; 2 row lea edi, [edi + 16 * 2] ; 1 row lea edx, [edx + 16 * 2] ; 1 row ; move up lea esi, [esi - 16 * 16 * 2] lea edi, [edi - 8 * 16 * 2] lea edx, [edx - 8 * 16 * 2] ; move right lea esi, [esi + 16] lea edi, [edi + 16] lea edx, [edx + 16] dec ecx jnz loop1b ret ;****************************************************************************** ; source 16 bit signed, 32 pixel width rfx_dwt_2d_encode_block_horiz_16_32: mov ecx, 16 loop1c: ; pre movdqa xmm1, [esi] ; src[2n] movdqa xmm2, [esi + 16] movdqa xmm6, xmm1 movdqa xmm7, xmm2 pand xmm1, [lsym(cdFFFF)] pand xmm2, [lsym(cdFFFF)] packusdw xmm1, xmm2 movdqa xmm2, xmm6 ; src[2n + 1] movdqa xmm3, xmm7 psrldq xmm2, 2 psrldq xmm3, 2 pand xmm2, [lsym(cdFFFF)] pand xmm3, [lsym(cdFFFF)] packusdw xmm2, xmm3 movdqa xmm3, xmm6 ; src[2n + 2] movdqa xmm4, xmm7 psrldq xmm3, 4 psrldq xmm4, 4 movd eax, xmm7 movd xmm5, eax pslldq xmm5, 12 por xmm3, xmm5 mov eax, [esi + 32] movd xmm5, eax pslldq xmm5, 12 por xmm4, xmm5 pand xmm3, [lsym(cdFFFF)] pand xmm4, [lsym(cdFFFF)] packusdw xmm3, xmm4 movdqa xmm4, xmm1 movdqa xmm5, xmm2 movdqa xmm6, xmm3 ; h[n] = (src[2n + 1] - ((src[2n] + src[2n + 2]) >> 1)) >> 1 paddw xmm4, xmm6 psraw xmm4, 1 psubw xmm5, xmm4 psraw xmm5, 1 movdqa xmm6, xmm5 ; out hi paddw xmm6, LHI_ADD psraw xmm6, LHI_SFT movdqa [edi], xmm6 movdqa xmm2, xmm5 ; save hi ; l[n] = src[2n] + ((h[n - 1] + h[n]) >> 1) movdqa xmm7, xmm5 movd eax, xmm7 pslldq xmm7, 2 and eax, 0xFFFF movd xmm6, eax por xmm7, xmm6 paddw xmm5, xmm7 psraw xmm5, 1 paddw xmm5, xmm1 psrldq xmm2, 14 movd ebp, xmm2 ; save hi movdqa xmm6, xmm5 ; out lo paddw xmm6, LLO_ADD psraw xmm6, LLO_SFT movdqa [edx], xmm6 ; move right lea esi, [esi + 16 * 2] lea edi, [edi + 8 * 2] lea edx, [edx + 8 * 2] ; post movdqa xmm1, [esi] ; src[2n] movdqa xmm2, [esi + 16] movdqa xmm6, xmm1 movdqa xmm7, xmm2 pand xmm1, [lsym(cdFFFF)] pand xmm2, [lsym(cdFFFF)] packusdw xmm1, xmm2 movdqa xmm2, xmm6 ; src[2n + 1] movdqa xmm3, xmm7 psrldq xmm2, 2 psrldq xmm3, 2 pand xmm2, [lsym(cdFFFF)] pand xmm3, [lsym(cdFFFF)] packusdw xmm2, xmm3 movdqa xmm3, xmm6 ; src[2n + 2] movdqa xmm4, xmm7 psrldq xmm3, 4 psrldq xmm4, 4 movd eax, xmm7 movd xmm5, eax pslldq xmm5, 12 por xmm3, xmm5 movdqa xmm5, xmm7 psrldq xmm5, 12 pslldq xmm5, 12 por xmm4, xmm5 pand xmm3, [lsym(cdFFFF)] pand xmm4, [lsym(cdFFFF)] packusdw xmm3, xmm4 movdqa xmm4, xmm1 movdqa xmm5, xmm2 movdqa xmm6, xmm3 ; h[n] = (src[2n + 1] - ((src[2n] + src[2n + 2]) >> 1)) >> 1 paddw xmm4, xmm6 psraw xmm4, 1 psubw xmm5, xmm4 psraw xmm5, 1 movdqa xmm6, xmm5 ; out hi paddw xmm6, LHI_ADD psraw xmm6, LHI_SFT movdqa [edi], xmm6 ; l[n] = src[2n] + ((h[n - 1] + h[n]) >> 1) movdqa xmm7, xmm5 pslldq xmm7, 2 movd xmm6, ebp por xmm7, xmm6 paddw xmm5, xmm7 psraw xmm5, 1 paddw xmm5, xmm1 movdqa xmm6, xmm5 ; out lo paddw xmm6, LLO_ADD psraw xmm6, LLO_SFT movdqa [edx], xmm6 ; move right lea esi, [esi + 16 * 2] lea edi, [edi + 8 * 2] lea edx, [edx + 8 * 2] ; move left lea esi, [esi - 32 * 2] lea edi, [edi - 16 * 2] lea edx, [edx - 16 * 2] ; move down lea esi, [esi + 32 * 2] lea edi, [edi + 16 * 2] lea edx, [edx + 16 * 2] dec ecx jnz loop1c ret ;****************************************************************************** ; source 16 bit signed, 32 pixel width rfx_dwt_2d_encode_block_horiz_16_32_no_lo: mov ecx, 16 loop1c1: ; pre movdqa xmm1, [esi] ; src[2n] movdqa xmm2, [esi + 16] movdqa xmm6, xmm1 movdqa xmm7, xmm2 pand xmm1, [lsym(cdFFFF)] pand xmm2, [lsym(cdFFFF)] packusdw xmm1, xmm2 movdqa xmm2, xmm6 ; src[2n + 1] movdqa xmm3, xmm7 psrldq xmm2, 2 psrldq xmm3, 2 pand xmm2, [lsym(cdFFFF)] pand xmm3, [lsym(cdFFFF)] packusdw xmm2, xmm3 movdqa xmm3, xmm6 ; src[2n + 2] movdqa xmm4, xmm7 psrldq xmm3, 4 psrldq xmm4, 4 movd eax, xmm7 movd xmm5, eax pslldq xmm5, 12 por xmm3, xmm5 mov eax, [esi + 32] movd xmm5, eax pslldq xmm5, 12 por xmm4, xmm5 pand xmm3, [lsym(cdFFFF)] pand xmm4, [lsym(cdFFFF)] packusdw xmm3, xmm4 movdqa xmm4, xmm1 movdqa xmm5, xmm2 movdqa xmm6, xmm3 ; h[n] = (src[2n + 1] - ((src[2n] + src[2n + 2]) >> 1)) >> 1 paddw xmm4, xmm6 psraw xmm4, 1 psubw xmm5, xmm4 psraw xmm5, 1 movdqa xmm6, xmm5 ; out hi paddw xmm6, LHI_ADD psraw xmm6, LHI_SFT movdqa [edi], xmm6 movdqa xmm2, xmm5 ; save hi ; l[n] = src[2n] + ((h[n - 1] + h[n]) >> 1) movdqa xmm7, xmm5 movd eax, xmm7 pslldq xmm7, 2 and eax, 0xFFFF movd xmm6, eax por xmm7, xmm6 paddw xmm5, xmm7 psraw xmm5, 1 paddw xmm5, xmm1 psrldq xmm2, 14 movd ebp, xmm2 ; save hi movdqa [edx], xmm5 ; out lo ; move right lea esi, [esi + 16 * 2] lea edi, [edi + 8 * 2] lea edx, [edx + 8 * 2] ; post movdqa xmm1, [esi] ; src[2n] movdqa xmm2, [esi + 16] movdqa xmm6, xmm1 movdqa xmm7, xmm2 pand xmm1, [lsym(cdFFFF)] pand xmm2, [lsym(cdFFFF)] packusdw xmm1, xmm2 movdqa xmm2, xmm6 ; src[2n + 1] movdqa xmm3, xmm7 psrldq xmm2, 2 psrldq xmm3, 2 pand xmm2, [lsym(cdFFFF)] pand xmm3, [lsym(cdFFFF)] packusdw xmm2, xmm3 movdqa xmm3, xmm6 ; src[2n + 2] movdqa xmm4, xmm7 psrldq xmm3, 4 psrldq xmm4, 4 movd eax, xmm7 movd xmm5, eax pslldq xmm5, 12 por xmm3, xmm5 movdqa xmm5, xmm7 psrldq xmm5, 12 pslldq xmm5, 12 por xmm4, xmm5 pand xmm3, [lsym(cdFFFF)] pand xmm4, [lsym(cdFFFF)] packusdw xmm3, xmm4 movdqa xmm4, xmm1 movdqa xmm5, xmm2 movdqa xmm6, xmm3 ; h[n] = (src[2n + 1] - ((src[2n] + src[2n + 2]) >> 1)) >> 1 paddw xmm4, xmm6 psraw xmm4, 1 psubw xmm5, xmm4 psraw xmm5, 1 movdqa xmm6, xmm5 ; out hi paddw xmm6, LHI_ADD psraw xmm6, LHI_SFT movdqa [edi], xmm6 ; l[n] = src[2n] + ((h[n - 1] + h[n]) >> 1) movdqa xmm7, xmm5 pslldq xmm7, 2 movd xmm6, ebp por xmm7, xmm6 paddw xmm5, xmm7 psraw xmm5, 1 paddw xmm5, xmm1 movdqa [edx], xmm5 ; out lo ; move right lea esi, [esi + 16 * 2] lea edi, [edi + 8 * 2] lea edx, [edx + 8 * 2] ; move left lea esi, [esi - 32 * 2] lea edi, [edi - 16 * 2] lea edx, [edx - 16 * 2] ; move down lea esi, [esi + 32 * 2] lea edi, [edi + 16 * 2] lea edx, [edx + 16 * 2] dec ecx jnz loop1c1 ret ;****************************************************************************** ; source 16 bit signed, 32 pixel width rfx_dwt_2d_encode_block_verti_16_32: mov ecx, 4 loop1d: ; pre movdqa xmm1, [esi] ; src[2n] movdqa xmm2, [esi + 32 * 2] ; src[2n + 1] movdqa xmm3, [esi + 32 * 2 * 2] ; src[2n + 2] movdqa xmm4, xmm1 movdqa xmm5, xmm2 movdqa xmm6, xmm3 ; h[n] = (src[2n + 1] - ((src[2n] + src[2n + 2]) >> 1)) >> 1 paddw xmm4, xmm6 psraw xmm4, 1 psubw xmm5, xmm4 psraw xmm5, 1 movdqa [edi], xmm5 ; out hi movdqa xmm6, xmm5 ; save hi ; l[n] = src[2n] + ((h[n - 1] + h[n]) >> 1) paddw xmm5, xmm1 movdqa [edx], xmm5 ; out lo movdqa xmm7, xmm6 ; save hi ; move down lea esi, [esi + 32 * 2 * 2] ; 2 rows lea edi, [edi + 32 * 2] ; 1 row lea edx, [edx + 32 * 2] ; 1 row ; loop shl ecx, 16 mov cx, 14 loop2d: movdqa xmm1, xmm3 ; src[2n] movdqa xmm2, [esi + 32 * 2] ; src[2n + 1] movdqa xmm3, [esi + 32 * 2 * 2] ; src[2n + 2] movdqa xmm4, xmm1 movdqa xmm5, xmm2 movdqa xmm6, xmm3 ; h[n] = (src[2n + 1] - ((src[2n] + src[2n + 2]) >> 1)) >> 1 paddw xmm4, xmm6 psraw xmm4, 1 psubw xmm5, xmm4 psraw xmm5, 1 movdqa [edi], xmm5 ; out hi movdqa xmm6, xmm5 ; save hi ; l[n] = src[2n] + ((h[n - 1] + h[n]) >> 1) paddw xmm5, xmm7 psraw xmm5, 1 paddw xmm5, xmm1 movdqa [edx], xmm5 ; out lo movdqa xmm7, xmm6 ; save hi ; move down lea esi, [esi + 32 * 2 * 2] ; 2 rows lea edi, [edi + 32 * 2] ; 1 row lea edx, [edx + 32 * 2] ; 1 row dec cx jnz loop2d shr ecx, 16 ; post movdqa xmm1, xmm3 ; src[2n] movdqa xmm2, [esi + 32 * 2] ; src[2n + 1] movdqa xmm4, xmm1 movdqa xmm5, xmm2 movdqa xmm6, xmm3 ; h[n] = (src[2n + 1] - ((src[2n] + src[2n + 2]) >> 1)) >> 1 paddw xmm4, xmm6 psraw xmm4, 1 psubw xmm5, xmm4 psraw xmm5, 1 movdqa [edi], xmm5 ; out hi ; l[n] = src[2n] + ((h[n - 1] + h[n]) >> 1) paddw xmm5, xmm7 psraw xmm5, 1 paddw xmm5, xmm1 movdqa [edx], xmm5 ; out lo ; move down lea esi, [esi + 32 * 2 * 2] ; 2 row lea edi, [edi + 32 * 2] ; 1 row lea edx, [edx + 32 * 2] ; 1 row ; move up lea esi, [esi - 32 * 32 * 2] lea edi, [edi - 16 * 32 * 2] lea edx, [edx - 16 * 32 * 2] ; move right lea esi, [esi + 16] lea edi, [edi + 16] lea edx, [edx + 16] dec ecx jnz loop1d ret ;****************************************************************************** ; source 16 bit signed, 64 pixel width rfx_dwt_2d_encode_block_horiz_16_64: mov ecx, 32 loop1e: ; pre movdqa xmm1, [esi] ; src[2n] movdqa xmm2, [esi + 16] movdqa xmm6, xmm1 movdqa xmm7, xmm2 pand xmm1, [lsym(cdFFFF)] pand xmm2, [lsym(cdFFFF)] packusdw xmm1, xmm2 movdqa xmm2, xmm6 ; src[2n + 1] movdqa xmm3, xmm7 psrldq xmm2, 2 psrldq xmm3, 2 pand xmm2, [lsym(cdFFFF)] pand xmm3, [lsym(cdFFFF)] packusdw xmm2, xmm3 movdqa xmm3, xmm6 ; src[2n + 2] movdqa xmm4, xmm7 psrldq xmm3, 4 psrldq xmm4, 4 movd eax, xmm7 movd xmm5, eax pslldq xmm5, 12 por xmm3, xmm5 mov eax, [esi + 32] movd xmm5, eax pslldq xmm5, 12 por xmm4, xmm5 pand xmm3, [lsym(cdFFFF)] pand xmm4, [lsym(cdFFFF)] packusdw xmm3, xmm4 movdqa xmm4, xmm1 movdqa xmm5, xmm2 movdqa xmm6, xmm3 ; h[n] = (src[2n + 1] - ((src[2n] + src[2n + 2]) >> 1)) >> 1 paddw xmm4, xmm6 psraw xmm4, 1 psubw xmm5, xmm4 psraw xmm5, 1 movdqa xmm6, xmm5 ; out hi paddw xmm6, LHI_ADD psraw xmm6, LHI_SFT movdqa [edi], xmm6 movdqa xmm2, xmm5 ; save hi ; l[n] = src[2n] + ((h[n - 1] + h[n]) >> 1) movdqa xmm7, xmm5 movd eax, xmm7 pslldq xmm7, 2 and eax, 0xFFFF movd xmm6, eax por xmm7, xmm6 paddw xmm5, xmm7 psraw xmm5, 1 paddw xmm5, xmm1 psrldq xmm2, 14 movd ebp, xmm2 ; save hi movdqa xmm6, xmm5 ; out lo paddw xmm6, LLO_ADD psraw xmm6, LLO_SFT movdqa [edx], xmm6 ; move right lea esi, [esi + 16 * 2] lea edi, [edi + 8 * 2] lea edx, [edx + 8 * 2] ; loop shl ecx, 16 mov cx, 2 loop2e: movdqa xmm1, [esi] ; src[2n] movdqa xmm2, [esi + 16] movdqa xmm6, xmm1 movdqa xmm7, xmm2 pand xmm1, [lsym(cdFFFF)] pand xmm2, [lsym(cdFFFF)] packusdw xmm1, xmm2 movdqa xmm2, xmm6 ; src[2n + 1] movdqa xmm3, xmm7 psrldq xmm2, 2 psrldq xmm3, 2 pand xmm2, [lsym(cdFFFF)] pand xmm3, [lsym(cdFFFF)] packusdw xmm2, xmm3 movdqa xmm3, xmm6 ; src[2n + 2] movdqa xmm4, xmm7 psrldq xmm3, 4 psrldq xmm4, 4 movd eax, xmm7 movd xmm5, eax pslldq xmm5, 12 por xmm3, xmm5 mov eax, [esi + 32] movd xmm5, eax pslldq xmm5, 12 por xmm4, xmm5 pand xmm3, [lsym(cdFFFF)] pand xmm4, [lsym(cdFFFF)] packusdw xmm3, xmm4 movdqa xmm4, xmm1 movdqa xmm5, xmm2 movdqa xmm6, xmm3 ; h[n] = (src[2n + 1] - ((src[2n] + src[2n + 2]) >> 1)) >> 1 paddw xmm4, xmm6 psraw xmm4, 1 psubw xmm5, xmm4 psraw xmm5, 1 movdqa xmm6, xmm5 ; out hi paddw xmm6, LHI_ADD psraw xmm6, LHI_SFT movdqa [edi], xmm6 movdqa xmm2, xmm5 ; save hi ; l[n] = src[2n] + ((h[n - 1] + h[n]) >> 1) movdqa xmm7, xmm5 pslldq xmm7, 2 movd xmm6, ebp por xmm7, xmm6 paddw xmm5, xmm7 psraw xmm5, 1 paddw xmm5, xmm1 psrldq xmm2, 14 movd ebp, xmm2 ; save hi movdqa xmm6, xmm5 ; out lo paddw xmm6, LLO_ADD psraw xmm6, LLO_SFT movdqa [edx], xmm6 ; move right lea esi, [esi + 16 * 2] lea edi, [edi + 8 * 2] lea edx, [edx + 8 * 2] dec cx jnz loop2e shr ecx, 16 ; post movdqa xmm1, [esi] ; src[2n] movdqa xmm2, [esi + 16] movdqa xmm6, xmm1 movdqa xmm7, xmm2 pand xmm1, [lsym(cdFFFF)] pand xmm2, [lsym(cdFFFF)] packusdw xmm1, xmm2 movdqa xmm2, xmm6 ; src[2n + 1] movdqa xmm3, xmm7 psrldq xmm2, 2 psrldq xmm3, 2 pand xmm2, [lsym(cdFFFF)] pand xmm3, [lsym(cdFFFF)] packusdw xmm2, xmm3 movdqa xmm3, xmm6 ; src[2n + 2] movdqa xmm4, xmm7 psrldq xmm3, 4 psrldq xmm4, 4 movd eax, xmm7 movd xmm5, eax pslldq xmm5, 12 por xmm3, xmm5 movdqa xmm5, xmm7 psrldq xmm5, 12 pslldq xmm5, 12 por xmm4, xmm5 pand xmm3, [lsym(cdFFFF)] pand xmm4, [lsym(cdFFFF)] packusdw xmm3, xmm4 movdqa xmm4, xmm1 movdqa xmm5, xmm2 movdqa xmm6, xmm3 ; h[n] = (src[2n + 1] - ((src[2n] + src[2n + 2]) >> 1)) >> 1 paddw xmm4, xmm6 psraw xmm4, 1 psubw xmm5, xmm4 psraw xmm5, 1 movdqa xmm6, xmm5 ; out hi paddw xmm6, LHI_ADD psraw xmm6, LHI_SFT movdqa [edi], xmm6 ; l[n] = src[2n] + ((h[n - 1] + h[n]) >> 1) movdqa xmm7, xmm5 pslldq xmm7, 2 movd xmm6, ebp por xmm7, xmm6 paddw xmm5, xmm7 psraw xmm5, 1 paddw xmm5, xmm1 movdqa xmm6, xmm5 ; out lo paddw xmm6, LLO_ADD psraw xmm6, LLO_SFT movdqa [edx], xmm6 ; move right lea esi, [esi + 16 * 2] lea edi, [edi + 8 * 2] lea edx, [edx + 8 * 2] ; move left lea esi, [esi - 64 * 2] lea edi, [edi - 32 * 2] lea edx, [edx - 32 * 2] ; move down lea esi, [esi + 64 * 2] lea edi, [edi + 32 * 2] lea edx, [edx + 32 * 2] dec ecx jnz loop1e ret ;****************************************************************************** ; source 16 bit signed, 64 pixel width rfx_dwt_2d_encode_block_horiz_16_64_no_lo: mov ecx, 32 loop1e1: ; pre movdqa xmm1, [esi] ; src[2n] movdqa xmm2, [esi + 16] movdqa xmm6, xmm1 movdqa xmm7, xmm2 pand xmm1, [lsym(cdFFFF)] pand xmm2, [lsym(cdFFFF)] packusdw xmm1, xmm2 movdqa xmm2, xmm6 ; src[2n + 1] movdqa xmm3, xmm7 psrldq xmm2, 2 psrldq xmm3, 2 pand xmm2, [lsym(cdFFFF)] pand xmm3, [lsym(cdFFFF)] packusdw xmm2, xmm3 movdqa xmm3, xmm6 ; src[2n + 2] movdqa xmm4, xmm7 psrldq xmm3, 4 psrldq xmm4, 4 movd eax, xmm7 movd xmm5, eax pslldq xmm5, 12 por xmm3, xmm5 mov eax, [esi + 32] movd xmm5, eax pslldq xmm5, 12 por xmm4, xmm5 pand xmm3, [lsym(cdFFFF)] pand xmm4, [lsym(cdFFFF)] packusdw xmm3, xmm4 movdqa xmm4, xmm1 movdqa xmm5, xmm2 movdqa xmm6, xmm3 ; h[n] = (src[2n + 1] - ((src[2n] + src[2n + 2]) >> 1)) >> 1 paddw xmm4, xmm6 psraw xmm4, 1 psubw xmm5, xmm4 psraw xmm5, 1 movdqa xmm6, xmm5 ; out hi paddw xmm6, LHI_ADD psraw xmm6, LHI_SFT movdqa [edi], xmm6 movdqa xmm2, xmm5 ; save hi ; l[n] = src[2n] + ((h[n - 1] + h[n]) >> 1) movdqa xmm7, xmm5 movd eax, xmm7 pslldq xmm7, 2 and eax, 0xFFFF movd xmm6, eax por xmm7, xmm6 paddw xmm5, xmm7 psraw xmm5, 1 paddw xmm5, xmm1 psrldq xmm2, 14 movd ebp, xmm2 ; save hi movdqa [edx], xmm5 ; out lo ; move right lea esi, [esi + 16 * 2] lea edi, [edi + 8 * 2] lea edx, [edx + 8 * 2] ; loop shl ecx, 16 mov cx, 2 loop2e1: movdqa xmm1, [esi] ; src[2n] movdqa xmm2, [esi + 16] movdqa xmm6, xmm1 movdqa xmm7, xmm2 pand xmm1, [lsym(cdFFFF)] pand xmm2, [lsym(cdFFFF)] packusdw xmm1, xmm2 movdqa xmm2, xmm6 ; src[2n + 1] movdqa xmm3, xmm7 psrldq xmm2, 2 psrldq xmm3, 2 pand xmm2, [lsym(cdFFFF)] pand xmm3, [lsym(cdFFFF)] packusdw xmm2, xmm3 movdqa xmm3, xmm6 ; src[2n + 2] movdqa xmm4, xmm7 psrldq xmm3, 4 psrldq xmm4, 4 movd eax, xmm7 movd xmm5, eax pslldq xmm5, 12 por xmm3, xmm5 mov eax, [esi + 32] movd xmm5, eax pslldq xmm5, 12 por xmm4, xmm5 pand xmm3, [lsym(cdFFFF)] pand xmm4, [lsym(cdFFFF)] packusdw xmm3, xmm4 movdqa xmm4, xmm1 movdqa xmm5, xmm2 movdqa xmm6, xmm3 ; h[n] = (src[2n + 1] - ((src[2n] + src[2n + 2]) >> 1)) >> 1 paddw xmm4, xmm6 psraw xmm4, 1 psubw xmm5, xmm4 psraw xmm5, 1 movdqa xmm6, xmm5 ; out hi paddw xmm6, LHI_ADD psraw xmm6, LHI_SFT movdqa [edi], xmm6 movdqa xmm2, xmm5 ; save hi ; l[n] = src[2n] + ((h[n - 1] + h[n]) >> 1) movdqa xmm7, xmm5 pslldq xmm7, 2 movd xmm6, ebp por xmm7, xmm6 paddw xmm5, xmm7 psraw xmm5, 1 paddw xmm5, xmm1 psrldq xmm2, 14 movd ebp, xmm2 ; save hi movdqa [edx], xmm5 ; out lo ; move right lea esi, [esi + 16 * 2] lea edi, [edi + 8 * 2] lea edx, [edx + 8 * 2] dec cx jnz loop2e1 shr ecx, 16 ; post movdqa xmm1, [esi] ; src[2n] movdqa xmm2, [esi + 16] movdqa xmm6, xmm1 movdqa xmm7, xmm2 pand xmm1, [lsym(cdFFFF)] pand xmm2, [lsym(cdFFFF)] packusdw xmm1, xmm2 movdqa xmm2, xmm6 ; src[2n + 1] movdqa xmm3, xmm7 psrldq xmm2, 2 psrldq xmm3, 2 pand xmm2, [lsym(cdFFFF)] pand xmm3, [lsym(cdFFFF)] packusdw xmm2, xmm3 movdqa xmm3, xmm6 ; src[2n + 2] movdqa xmm4, xmm7 psrldq xmm3, 4 psrldq xmm4, 4 movd eax, xmm7 movd xmm5, eax pslldq xmm5, 12 por xmm3, xmm5 movdqa xmm5, xmm7 psrldq xmm5, 12 pslldq xmm5, 12 por xmm4, xmm5 pand xmm3, [lsym(cdFFFF)] pand xmm4, [lsym(cdFFFF)] packusdw xmm3, xmm4 movdqa xmm4, xmm1 movdqa xmm5, xmm2 movdqa xmm6, xmm3 ; h[n] = (src[2n + 1] - ((src[2n] + src[2n + 2]) >> 1)) >> 1 paddw xmm4, xmm6 psraw xmm4, 1 psubw xmm5, xmm4 psraw xmm5, 1 movdqa xmm6, xmm5 ; out hi paddw xmm6, LHI_ADD psraw xmm6, LHI_SFT movdqa [edi], xmm6 ; l[n] = src[2n] + ((h[n - 1] + h[n]) >> 1) movdqa xmm7, xmm5 pslldq xmm7, 2 movd xmm6, ebp por xmm7, xmm6 paddw xmm5, xmm7 psraw xmm5, 1 paddw xmm5, xmm1 movdqa [edx], xmm5 ; out lo ; move right lea esi, [esi + 16 * 2] lea edi, [edi + 8 * 2] lea edx, [edx + 8 * 2] ; move left lea esi, [esi - 64 * 2] lea edi, [edi - 32 * 2] lea edx, [edx - 32 * 2] ; move down lea esi, [esi + 64 * 2] lea edi, [edi + 32 * 2] lea edx, [edx + 32 * 2] dec ecx jnz loop1e1 ret ;****************************************************************************** ; source 8 bit unsigned, 64 pixel width rfx_dwt_2d_encode_block_verti_8_64: mov ecx, 8 loop1f: ; pre movq xmm1, [esi] ; src[2n] movq xmm2, [esi + 64 * 1] ; src[2n + 1] movq xmm3, [esi + 64 * 1 * 2] ; src[2n + 2] punpcklbw xmm1, xmm0 punpcklbw xmm2, xmm0 punpcklbw xmm3, xmm0 psubw xmm1, [lsym(cw128)] psubw xmm2, [lsym(cw128)] psubw xmm3, [lsym(cw128)] psllw xmm1, 5 psllw xmm2, 5 psllw xmm3, 5 movdqa xmm4, xmm1 movdqa xmm5, xmm2 movdqa xmm6, xmm3 ; h[n] = (src[2n + 1] - ((src[2n] + src[2n + 2]) >> 1)) >> 1 paddw xmm4, xmm6 psraw xmm4, 1 psubw xmm5, xmm4 psraw xmm5, 1 movdqa [edi], xmm5 ; out hi movdqa xmm6, xmm5 ; save hi ; l[n] = src[2n] + ((h[n - 1] + h[n]) >> 1) paddw xmm5, xmm1 movdqa [edx], xmm5 ; out lo movdqa xmm7, xmm6 ; save hi ; move down lea esi, [esi + 64 * 1 * 2] ; 2 rows lea edi, [edi + 64 * 2] ; 1 row lea edx, [edx + 64 * 2] ; 1 row ; loop shl ecx, 16 mov cx, 30 loop2f: movdqa xmm1, xmm3 ; src[2n] movq xmm2, [esi + 64 * 1] ; src[2n + 1] movq xmm3, [esi + 64 * 1 * 2] ; src[2n + 2] punpcklbw xmm2, xmm0 punpcklbw xmm3, xmm0 psubw xmm2, [lsym(cw128)] psubw xmm3, [lsym(cw128)] psllw xmm2, 5 psllw xmm3, 5 movdqa xmm4, xmm1 movdqa xmm5, xmm2 movdqa xmm6, xmm3 ; h[n] = (src[2n + 1] - ((src[2n] + src[2n + 2]) >> 1)) >> 1 paddw xmm4, xmm6 psraw xmm4, 1 psubw xmm5, xmm4 psraw xmm5, 1 movdqa [edi], xmm5 ; out hi movdqa xmm6, xmm5 ; save hi ; l[n] = src[2n] + ((h[n - 1] + h[n]) >> 1) paddw xmm5, xmm7 psraw xmm5, 1 paddw xmm5, xmm1 movdqa [edx], xmm5 ; out lo movdqa xmm7, xmm6 ; save hi ; move down lea esi, [esi + 64 * 1 * 2] ; 2 rows lea edi, [edi + 64 * 2] ; 1 row lea edx, [edx + 64 * 2] ; 1 row dec cx jnz loop2f shr ecx, 16 ; post movdqa xmm1, xmm3 ; src[2n] movq xmm2, [esi + 64 * 1] ; src[2n + 1] punpcklbw xmm2, xmm0 psubw xmm2, [lsym(cw128)] psllw xmm2, 5 movdqa xmm4, xmm1 movdqa xmm5, xmm2 movdqa xmm6, xmm3 ; h[n] = (src[2n + 1] - ((src[2n] + src[2n + 2]) >> 1)) >> 1 paddw xmm4, xmm6 psraw xmm4, 1 psubw xmm5, xmm4 psraw xmm5, 1 movdqa [edi], xmm5 ; out hi ; l[n] = src[2n] + ((h[n - 1] + h[n]) >> 1) paddw xmm5, xmm7 psraw xmm5, 1 paddw xmm5, xmm1 movdqa [edx], xmm5 ; out lo ; move down lea esi, [esi + 64 * 1 * 2] ; 2 rows lea edi, [edi + 64 * 2] ; 1 row lea edx, [edx + 64 * 2] ; 1 row ; move up lea esi, [esi - 64 * 1 * 64] lea edi, [edi - 32 * 64 * 2] lea edx, [edx - 32 * 64 * 2] ; move right lea esi, [esi + 8] lea edi, [edi + 16] lea edx, [edx + 16] dec ecx jnz loop1f ret set_quants_hi: sub eax, 6 - 5 movd xmm1, eax movdqa LHI_SFT, xmm1 imul eax, 16 lea edx, [lsym(cwa0)] add edx, eax movdqa xmm1, [edx] movdqa LHI_ADD, xmm1 ret set_quants_lo: sub eax, 6 - 5 movd xmm1, eax movdqa LLO_SFT, xmm1 imul eax, 16 lea edx, [lsym(cwa0)] add edx, eax movdqa xmm1, [edx] movdqa LLO_ADD, xmm1 ret %define LQTABLE [esp + 144] ; qtable %define LIN_BUFFER [esp + 148] ; in_buffer %define LOUT_BUFFER [esp + 152] ; out_buffer %define LWORK_BUFFER [esp + 156] ; work_buffer ;int ;rfxcodec_encode_dwt_shift_x86_sse41(const char *qtable, ; unsigned char *in_buffer, ; short *out_buffer, ; short *work_buffer); ;****************************************************************************** PROC rfxcodec_encode_dwt_shift_x86_sse41 ; align stack mov eax, esp sub eax, 0x10 and eax, 0x0F sub esp, eax push eax sub esp, 3 * 4 sub esp, 4 * 4 ; copy params to after align movdqu xmm0, [esp + eax + 4 * 4 + 3 * 4 + 4 + 4] movdqu [esp], xmm0 ; save registers push ebx RETRIEVE_RODATA push esi push edi push ebp sub esp, 16 * 8 pxor xmm0, xmm0 ; verical DWT to work buffer, level 1 mov esi, LIN_BUFFER ; src mov edi, LWORK_BUFFER ; dst hi lea edi, [edi + 64 * 32 * 2] ; dst hi mov edx, LWORK_BUFFER ; dst lo call rfx_dwt_2d_encode_block_verti_8_64 ; horizontal DWT to out buffer, level 1, part 1 xor eax, eax mov edx, LQTABLE mov al, [edx + 4] and al, 0xF call set_quants_hi mov esi, LWORK_BUFFER ; src mov edi, LOUT_BUFFER ; dst hi - HL1 mov edx, LOUT_BUFFER ; dst lo - LL1 lea edx, [edx + 32 * 32 * 6] ; dst lo - LL1 call rfx_dwt_2d_encode_block_horiz_16_64_no_lo ; horizontal DWT to out buffer, level 1, part 2 xor eax, eax mov edx, LQTABLE mov al, [edx + 4] shr al, 4 call set_quants_hi xor eax, eax mov edx, LQTABLE mov al, [edx + 3] shr al, 4 call set_quants_lo mov esi, LWORK_BUFFER ; src lea esi, [esi + 64 * 32 * 2] ; src mov edi, LOUT_BUFFER ; dst hi - HH1 lea edi, [edi + 32 * 32 * 4] ; dst hi - HH1 mov edx, LOUT_BUFFER ; dst lo - LH1 lea edx, [edx + 32 * 32 * 2] ; dst lo - LH1 call rfx_dwt_2d_encode_block_horiz_16_64 ; verical DWT to work buffer, level 2 mov esi, LOUT_BUFFER ; src lea esi, [esi + 32 * 32 * 6] ; src mov edi, LWORK_BUFFER ; dst hi lea edi, [edi + 32 * 16 * 2] ; dst hi mov edx, LWORK_BUFFER ; dst lo call rfx_dwt_2d_encode_block_verti_16_32 ; horizontal DWT to out buffer, level 2, part 1 xor eax, eax mov edx, LQTABLE mov al, [edx + 2] shr al, 4 call set_quants_hi mov esi, LWORK_BUFFER ; src ; 32 * 32 * 6 + 16 * 16 * 0 = 6144 mov edi, LOUT_BUFFER ; dst hi - HL2 lea edi, [edi + 6144] ; dst hi - HL2 ; 32 * 32 * 6 + 16 * 16 * 6 = 7680 mov edx, LOUT_BUFFER ; dst lo - LL2 lea edx, [edx + 7680] ; dst lo - LL2 call rfx_dwt_2d_encode_block_horiz_16_32_no_lo ; horizontal DWT to out buffer, level 2, part 2 xor eax, eax mov edx, LQTABLE mov al, [edx + 3] and al, 0xF call set_quants_hi xor eax, eax mov edx, LQTABLE mov al, [edx + 2] and al, 0xF call set_quants_lo mov esi, LWORK_BUFFER ; src lea esi, [esi + 32 * 16 * 2] ; src ; 32 * 32 * 6 + 16 * 16 * 4 = 7168 mov edi, LOUT_BUFFER ; dst hi - HH2 lea edi, [edi + 7168] ; dst hi - HH2 ; 32 * 32 * 6 + 16 * 16 * 2 = 6656 mov edx, LOUT_BUFFER ; dst lo - LH2 lea edx, [edx + 6656] ; dst lo - LH2 call rfx_dwt_2d_encode_block_horiz_16_32 ; verical DWT to work buffer, level 3 ; 32 * 32 * 6 + 16 * 16 * 6 = 7680 mov esi, LOUT_BUFFER ; src lea esi, [esi + 7680] ; src mov edi, LWORK_BUFFER ; dst hi lea edi, [edi + 16 * 8 * 2] ; dst hi mov edx, LWORK_BUFFER ; dst lo call rfx_dwt_2d_encode_block_verti_16_16 ; horizontal DWT to out buffer, level 3, part 1 xor eax, eax mov edx, LQTABLE mov al, [edx + 1] and al, 0xF call set_quants_hi xor eax, eax mov edx, LQTABLE mov al, [edx + 0] and al, 0xF call set_quants_lo mov esi, LWORK_BUFFER ; src ; 32 * 32 * 6 + 16 * 16 * 6 + 8 * 8 * 0 = 7680 mov edi, LOUT_BUFFER ; dst hi - HL3 lea edi, [edi + 7680] ; dst hi - HL3 ; 32 * 32 * 6 + 16 * 16 * 6 + 8 * 8 * 6 = 8064 mov edx, LOUT_BUFFER ; dst lo - LL3 lea edx, [edx + 8064] ; dst lo - LL3 call rfx_dwt_2d_encode_block_horiz_16_16 ; horizontal DWT to out buffer, level 3, part 2 xor eax, eax mov edx, LQTABLE mov al, [edx + 1] shr al, 4 call set_quants_hi xor eax, eax mov edx, LQTABLE mov al, [edx + 0] shr al, 4 call set_quants_lo mov esi, LWORK_BUFFER ; src lea esi, [esi + 16 * 8 * 2] ; src ; 32 * 32 * 6 + 16 * 16 * 6 + 8 * 8 * 4 = 7936 mov edi, LOUT_BUFFER ; dst hi - HH3 lea edi, [edi + 7936] ; dst hi - HH3 ; 32 * 32 * 6 + 16 * 16 * 6 + 8 * 8 * 2 = 7808 mov edx, LOUT_BUFFER ; dst lo - LH3 lea edx, [edx + 7808] ; dst lo - LH3 call rfx_dwt_2d_encode_block_horiz_16_16 ; quants add esp, 16 * 8 ; restore registers pop ebp pop edi pop esi pop ebx ; params add esp, 3 * 4 add esp, 4 * 4 ; align pop eax add esp, eax ; return value mov eax, 0 ret END_OF_FILE xrdp-0.9.5/librfxcodec/src/x86/Makefile.in000644 001751 001751 00000044103 13220730761 020172 0ustar00metameta000000 000000 # Makefile.in generated by automake 1.15.1 from Makefile.am. # @configure_input@ # Copyright (C) 1994-2017 Free Software Foundation, Inc. # This Makefile.in is free software; the Free Software Foundation # gives unlimited permission to copy and/or distribute it, # with or without modifications, as long as this notice is preserved. # This program is distributed in the hope that it will be useful, # but WITHOUT ANY WARRANTY, to the extent permitted by law; without # even the implied warranty of MERCHANTABILITY or FITNESS FOR A # PARTICULAR PURPOSE. @SET_MAKE@ VPATH = @srcdir@ am__is_gnu_make = { \ if test -z '$(MAKELEVEL)'; then \ false; \ elif test -n '$(MAKE_HOST)'; then \ true; \ elif test -n '$(MAKE_VERSION)' && test -n '$(CURDIR)'; then \ true; \ else \ false; \ fi; \ } am__make_running_with_option = \ case $${target_option-} in \ ?) ;; \ *) echo "am__make_running_with_option: internal error: invalid" \ "target option '$${target_option-}' specified" >&2; \ exit 1;; \ esac; \ has_opt=no; \ sane_makeflags=$$MAKEFLAGS; \ if $(am__is_gnu_make); then \ sane_makeflags=$$MFLAGS; \ else \ case $$MAKEFLAGS in \ *\\[\ \ ]*) \ bs=\\; \ sane_makeflags=`printf '%s\n' "$$MAKEFLAGS" \ | sed "s/$$bs$$bs[$$bs $$bs ]*//g"`;; \ esac; \ fi; \ skip_next=no; \ strip_trailopt () \ { \ flg=`printf '%s\n' "$$flg" | sed "s/$$1.*$$//"`; \ }; \ for flg in $$sane_makeflags; do \ test $$skip_next = yes && { skip_next=no; continue; }; \ case $$flg in \ *=*|--*) continue;; \ -*I) strip_trailopt 'I'; skip_next=yes;; \ -*I?*) strip_trailopt 'I';; \ -*O) strip_trailopt 'O'; skip_next=yes;; \ -*O?*) strip_trailopt 'O';; \ -*l) strip_trailopt 'l'; skip_next=yes;; \ -*l?*) strip_trailopt 'l';; \ -[dEDm]) skip_next=yes;; \ -[JT]) skip_next=yes;; \ esac; \ case $$flg in \ *$$target_option*) has_opt=yes; break;; \ esac; \ done; \ test $$has_opt = yes am__make_dryrun = (target_option=n; $(am__make_running_with_option)) am__make_keepgoing = (target_option=k; $(am__make_running_with_option)) pkgdatadir = $(datadir)/@PACKAGE@ pkgincludedir = $(includedir)/@PACKAGE@ pkglibdir = $(libdir)/@PACKAGE@ pkglibexecdir = $(libexecdir)/@PACKAGE@ am__cd = CDPATH="$${ZSH_VERSION+.}$(PATH_SEPARATOR)" && cd install_sh_DATA = $(install_sh) -c -m 644 install_sh_PROGRAM = $(install_sh) -c install_sh_SCRIPT = $(install_sh) -c INSTALL_HEADER = $(INSTALL_DATA) transform = $(program_transform_name) NORMAL_INSTALL = : PRE_INSTALL = : POST_INSTALL = : NORMAL_UNINSTALL = : PRE_UNINSTALL = : POST_UNINSTALL = : build_triplet = @build@ host_triplet = @host@ subdir = src/x86 ACLOCAL_M4 = $(top_srcdir)/aclocal.m4 am__aclocal_m4_deps = $(top_srcdir)/m4/ax_append_compile_flags.m4 \ $(top_srcdir)/m4/ax_append_flag.m4 \ $(top_srcdir)/m4/ax_cflags_warn_all.m4 \ $(top_srcdir)/m4/ax_check_compile_flag.m4 \ $(top_srcdir)/m4/ax_require_defined.m4 \ $(top_srcdir)/m4/libtool.m4 $(top_srcdir)/m4/ltoptions.m4 \ $(top_srcdir)/m4/ltsugar.m4 $(top_srcdir)/m4/ltversion.m4 \ $(top_srcdir)/m4/lt~obsolete.m4 $(top_srcdir)/m4/nasm.m4 \ $(top_srcdir)/m4/pkg.m4 $(top_srcdir)/configure.ac am__configure_deps = $(am__aclocal_m4_deps) $(CONFIGURE_DEPENDENCIES) \ $(ACLOCAL_M4) DIST_COMMON = $(srcdir)/Makefile.am $(am__DIST_COMMON) mkinstalldirs = $(install_sh) -d CONFIG_HEADER = $(top_builddir)/config_ac.h CONFIG_CLEAN_FILES = CONFIG_CLEAN_VPATH_FILES = LTLIBRARIES = $(noinst_LTLIBRARIES) librfxencode_x86_la_LIBADD = am__objects_1 = cpuid_x86.lo rfxcodec_encode_dwt_shift_x86_sse2.lo \ rfxcodec_encode_dwt_shift_x86_sse41.lo am_librfxencode_x86_la_OBJECTS = rfxencode_tile_x86.lo \ $(am__objects_1) librfxencode_x86_la_OBJECTS = $(am_librfxencode_x86_la_OBJECTS) AM_V_lt = $(am__v_lt_@AM_V@) am__v_lt_ = $(am__v_lt_@AM_DEFAULT_V@) am__v_lt_0 = --silent am__v_lt_1 = AM_V_P = $(am__v_P_@AM_V@) am__v_P_ = $(am__v_P_@AM_DEFAULT_V@) am__v_P_0 = false am__v_P_1 = : AM_V_GEN = $(am__v_GEN_@AM_V@) am__v_GEN_ = $(am__v_GEN_@AM_DEFAULT_V@) am__v_GEN_0 = @echo " GEN " $@; am__v_GEN_1 = AM_V_at = $(am__v_at_@AM_V@) am__v_at_ = $(am__v_at_@AM_DEFAULT_V@) am__v_at_0 = @ am__v_at_1 = DEFAULT_INCLUDES = -I.@am__isrc@ -I$(top_builddir) depcomp = $(SHELL) $(top_srcdir)/depcomp am__depfiles_maybe = depfiles am__mv = mv -f COMPILE = $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) \ $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) LTCOMPILE = $(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) \ $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) \ $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) \ $(AM_CFLAGS) $(CFLAGS) AM_V_CC = $(am__v_CC_@AM_V@) am__v_CC_ = $(am__v_CC_@AM_DEFAULT_V@) am__v_CC_0 = @echo " CC " $@; am__v_CC_1 = CCLD = $(CC) LINK = $(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) \ $(LIBTOOLFLAGS) --mode=link $(CCLD) $(AM_CFLAGS) $(CFLAGS) \ $(AM_LDFLAGS) $(LDFLAGS) -o $@ AM_V_CCLD = $(am__v_CCLD_@AM_V@) am__v_CCLD_ = $(am__v_CCLD_@AM_DEFAULT_V@) am__v_CCLD_0 = @echo " CCLD " $@; am__v_CCLD_1 = SOURCES = $(librfxencode_x86_la_SOURCES) DIST_SOURCES = $(librfxencode_x86_la_SOURCES) am__can_run_installinfo = \ case $$AM_UPDATE_INFO_DIR in \ n|no|NO) false;; \ *) (install-info --version) >/dev/null 2>&1;; \ esac am__tagged_files = $(HEADERS) $(SOURCES) $(TAGS_FILES) $(LISP) # Read a list of newline-separated strings from the standard input, # and print each of them once, without duplicates. Input order is # *not* preserved. am__uniquify_input = $(AWK) '\ BEGIN { nonempty = 0; } \ { items[$$0] = 1; nonempty = 1; } \ END { if (nonempty) { for (i in items) print i; }; } \ ' # Make sure the list of sources is unique. This is necessary because, # e.g., the same source file might be shared among _SOURCES variables # for different programs/libraries. am__define_uniq_tagged_files = \ list='$(am__tagged_files)'; \ unique=`for i in $$list; do \ if test -f "$$i"; then echo $$i; else echo $(srcdir)/$$i; fi; \ done | $(am__uniquify_input)` ETAGS = etags CTAGS = ctags am__DIST_COMMON = $(srcdir)/Makefile.in $(top_srcdir)/depcomp DISTFILES = $(DIST_COMMON) $(DIST_SOURCES) $(TEXINFOS) $(EXTRA_DIST) ACLOCAL = @ACLOCAL@ AMTAR = @AMTAR@ AM_DEFAULT_VERBOSITY = @AM_DEFAULT_VERBOSITY@ AR = @AR@ AUTOCONF = @AUTOCONF@ AUTOHEADER = @AUTOHEADER@ AUTOMAKE = @AUTOMAKE@ AWK = @AWK@ CC = @CC@ CCDEPMODE = @CCDEPMODE@ CFLAGS = @CFLAGS@ CPP = @CPP@ CPPFLAGS = @CPPFLAGS@ CYGPATH_W = @CYGPATH_W@ DEFS = @DEFS@ DEPDIR = @DEPDIR@ DLLTOOL = @DLLTOOL@ DSYMUTIL = @DSYMUTIL@ DUMPBIN = @DUMPBIN@ ECHO_C = @ECHO_C@ ECHO_N = @ECHO_N@ ECHO_T = @ECHO_T@ EGREP = @EGREP@ EXEEXT = @EXEEXT@ FGREP = @FGREP@ GREP = @GREP@ INSTALL = @INSTALL@ INSTALL_DATA = @INSTALL_DATA@ INSTALL_PROGRAM = @INSTALL_PROGRAM@ INSTALL_SCRIPT = @INSTALL_SCRIPT@ INSTALL_STRIP_PROGRAM = @INSTALL_STRIP_PROGRAM@ LD = @LD@ LDFLAGS = @LDFLAGS@ LIBOBJS = @LIBOBJS@ LIBS = @LIBS@ LIBTOOL = @LIBTOOL@ LIPO = @LIPO@ LN_S = @LN_S@ LTLIBOBJS = @LTLIBOBJS@ LT_SYS_LIBRARY_PATH = @LT_SYS_LIBRARY_PATH@ MAKEINFO = @MAKEINFO@ MANIFEST_TOOL = @MANIFEST_TOOL@ MKDIR_P = @MKDIR_P@ NAFLAGS = @NAFLAGS@ -DASM_ARCH_I386 NASM = @NASM@ NM = @NM@ NMEDIT = @NMEDIT@ OBJDUMP = @OBJDUMP@ OBJEXT = @OBJEXT@ OTOOL = @OTOOL@ OTOOL64 = @OTOOL64@ PACKAGE = @PACKAGE@ PACKAGE_BUGREPORT = @PACKAGE_BUGREPORT@ PACKAGE_NAME = @PACKAGE_NAME@ PACKAGE_STRING = @PACKAGE_STRING@ PACKAGE_TARNAME = @PACKAGE_TARNAME@ PACKAGE_URL = @PACKAGE_URL@ PACKAGE_VERSION = @PACKAGE_VERSION@ PATH_SEPARATOR = @PATH_SEPARATOR@ RANLIB = @RANLIB@ SED = @SED@ SET_MAKE = @SET_MAKE@ SHELL = @SHELL@ STRIP = @STRIP@ VERSION = @VERSION@ abs_builddir = @abs_builddir@ abs_srcdir = @abs_srcdir@ abs_top_builddir = @abs_top_builddir@ abs_top_srcdir = @abs_top_srcdir@ ac_ct_AR = @ac_ct_AR@ ac_ct_CC = @ac_ct_CC@ ac_ct_DUMPBIN = @ac_ct_DUMPBIN@ am__include = @am__include@ am__leading_dot = @am__leading_dot@ am__quote = @am__quote@ am__tar = @am__tar@ am__untar = @am__untar@ bindir = @bindir@ build = @build@ build_alias = @build_alias@ build_cpu = @build_cpu@ build_os = @build_os@ build_vendor = @build_vendor@ builddir = @builddir@ datadir = @datadir@ datarootdir = @datarootdir@ docdir = @docdir@ dvidir = @dvidir@ exec_prefix = @exec_prefix@ host = @host@ host_alias = @host_alias@ host_cpu = @host_cpu@ host_os = @host_os@ host_vendor = @host_vendor@ htmldir = @htmldir@ includedir = @includedir@ infodir = @infodir@ install_sh = @install_sh@ libdir = @libdir@ libexecdir = @libexecdir@ localedir = @localedir@ localstatedir = @localstatedir@ mandir = @mandir@ mkdir_p = @mkdir_p@ oldincludedir = @oldincludedir@ pdfdir = @pdfdir@ pkgconfigdir = @pkgconfigdir@ prefix = @prefix@ program_transform_name = @program_transform_name@ psdir = @psdir@ sbindir = @sbindir@ sharedstatedir = @sharedstatedir@ srcdir = @srcdir@ sysconfdir = @sysconfdir@ target_alias = @target_alias@ top_build_prefix = @top_build_prefix@ top_builddir = @top_builddir@ top_srcdir = @top_srcdir@ X86_ASM = \ cpuid_x86.asm \ rfxcodec_encode_dwt_shift_x86_sse2.asm \ rfxcodec_encode_dwt_shift_x86_sse41.asm AM_CPPFLAGS = \ -I$(top_srcdir)/include \ -I$(top_srcdir)/src noinst_LTLIBRARIES = librfxencode-x86.la librfxencode_x86_la_SOURCES = \ funcs_x86.h \ rfxencode_tile_x86.c \ $(X86_ASM) nasm_verbose = $(nasm_verbose_@AM_V@) nasm_verbose_ = $(nasm_verbose_@AM_DEFAULT_V@) nasm_verbose_0 = @echo " NASM $@"; all: all-am .SUFFIXES: .SUFFIXES: .asm .c .lo .o .obj $(srcdir)/Makefile.in: $(srcdir)/Makefile.am $(am__configure_deps) @for dep in $?; do \ case '$(am__configure_deps)' in \ *$$dep*) \ ( cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh ) \ && { if test -f $@; then exit 0; else break; fi; }; \ exit 1;; \ esac; \ done; \ echo ' cd $(top_srcdir) && $(AUTOMAKE) --foreign src/x86/Makefile'; \ $(am__cd) $(top_srcdir) && \ $(AUTOMAKE) --foreign src/x86/Makefile Makefile: $(srcdir)/Makefile.in $(top_builddir)/config.status @case '$?' in \ *config.status*) \ cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh;; \ *) \ echo ' cd $(top_builddir) && $(SHELL) ./config.status $(subdir)/$@ $(am__depfiles_maybe)'; \ cd $(top_builddir) && $(SHELL) ./config.status $(subdir)/$@ $(am__depfiles_maybe);; \ esac; $(top_builddir)/config.status: $(top_srcdir)/configure $(CONFIG_STATUS_DEPENDENCIES) cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh $(top_srcdir)/configure: $(am__configure_deps) cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh $(ACLOCAL_M4): $(am__aclocal_m4_deps) cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh $(am__aclocal_m4_deps): clean-noinstLTLIBRARIES: -test -z "$(noinst_LTLIBRARIES)" || rm -f $(noinst_LTLIBRARIES) @list='$(noinst_LTLIBRARIES)'; \ locs=`for p in $$list; do echo $$p; done | \ sed 's|^[^/]*$$|.|; s|/[^/]*$$||; s|$$|/so_locations|' | \ sort -u`; \ test -z "$$locs" || { \ echo rm -f $${locs}; \ rm -f $${locs}; \ } librfxencode-x86.la: $(librfxencode_x86_la_OBJECTS) $(librfxencode_x86_la_DEPENDENCIES) $(EXTRA_librfxencode_x86_la_DEPENDENCIES) $(AM_V_CCLD)$(LINK) $(librfxencode_x86_la_OBJECTS) $(librfxencode_x86_la_LIBADD) $(LIBS) mostlyclean-compile: -rm -f *.$(OBJEXT) distclean-compile: -rm -f *.tab.c @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/rfxencode_tile_x86.Plo@am__quote@ .c.o: @am__fastdepCC_TRUE@ $(AM_V_CC)$(COMPILE) -MT $@ -MD -MP -MF $(DEPDIR)/$*.Tpo -c -o $@ $< @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) $(DEPDIR)/$*.Tpo $(DEPDIR)/$*.Po @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='$<' object='$@' libtool=no @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(COMPILE) -c -o $@ $< .c.obj: @am__fastdepCC_TRUE@ $(AM_V_CC)$(COMPILE) -MT $@ -MD -MP -MF $(DEPDIR)/$*.Tpo -c -o $@ `$(CYGPATH_W) '$<'` @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) $(DEPDIR)/$*.Tpo $(DEPDIR)/$*.Po @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='$<' object='$@' libtool=no @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(COMPILE) -c -o $@ `$(CYGPATH_W) '$<'` .c.lo: @am__fastdepCC_TRUE@ $(AM_V_CC)$(LTCOMPILE) -MT $@ -MD -MP -MF $(DEPDIR)/$*.Tpo -c -o $@ $< @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) $(DEPDIR)/$*.Tpo $(DEPDIR)/$*.Plo @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='$<' object='$@' libtool=yes @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(LTCOMPILE) -c -o $@ $< mostlyclean-libtool: -rm -f *.lo clean-libtool: -rm -rf .libs _libs ID: $(am__tagged_files) $(am__define_uniq_tagged_files); mkid -fID $$unique tags: tags-am TAGS: tags tags-am: $(TAGS_DEPENDENCIES) $(am__tagged_files) set x; \ here=`pwd`; \ $(am__define_uniq_tagged_files); \ shift; \ if test -z "$(ETAGS_ARGS)$$*$$unique"; then :; else \ test -n "$$unique" || unique=$$empty_fix; \ if test $$# -gt 0; then \ $(ETAGS) $(ETAGSFLAGS) $(AM_ETAGSFLAGS) $(ETAGS_ARGS) \ "$$@" $$unique; \ else \ $(ETAGS) $(ETAGSFLAGS) $(AM_ETAGSFLAGS) $(ETAGS_ARGS) \ $$unique; \ fi; \ fi ctags: ctags-am CTAGS: ctags ctags-am: $(TAGS_DEPENDENCIES) $(am__tagged_files) $(am__define_uniq_tagged_files); \ test -z "$(CTAGS_ARGS)$$unique" \ || $(CTAGS) $(CTAGSFLAGS) $(AM_CTAGSFLAGS) $(CTAGS_ARGS) \ $$unique GTAGS: here=`$(am__cd) $(top_builddir) && pwd` \ && $(am__cd) $(top_srcdir) \ && gtags -i $(GTAGS_ARGS) "$$here" cscopelist: cscopelist-am cscopelist-am: $(am__tagged_files) list='$(am__tagged_files)'; \ case "$(srcdir)" in \ [\\/]* | ?:[\\/]*) sdir="$(srcdir)" ;; \ *) sdir=$(subdir)/$(srcdir) ;; \ esac; \ for i in $$list; do \ if test -f "$$i"; then \ echo "$(subdir)/$$i"; \ else \ echo "$$sdir/$$i"; \ fi; \ done >> $(top_builddir)/cscope.files distclean-tags: -rm -f TAGS ID GTAGS GRTAGS GSYMS GPATH tags distdir: $(DISTFILES) @srcdirstrip=`echo "$(srcdir)" | sed 's/[].[^$$\\*]/\\\\&/g'`; \ topsrcdirstrip=`echo "$(top_srcdir)" | sed 's/[].[^$$\\*]/\\\\&/g'`; \ list='$(DISTFILES)'; \ dist_files=`for file in $$list; do echo $$file; done | \ sed -e "s|^$$srcdirstrip/||;t" \ -e "s|^$$topsrcdirstrip/|$(top_builddir)/|;t"`; \ case $$dist_files in \ */*) $(MKDIR_P) `echo "$$dist_files" | \ sed '/\//!d;s|^|$(distdir)/|;s,/[^/]*$$,,' | \ sort -u` ;; \ esac; \ for file in $$dist_files; do \ if test -f $$file || test -d $$file; then d=.; else d=$(srcdir); fi; \ if test -d $$d/$$file; then \ dir=`echo "/$$file" | sed -e 's,/[^/]*$$,,'`; \ if test -d "$(distdir)/$$file"; then \ find "$(distdir)/$$file" -type d ! -perm -700 -exec chmod u+rwx {} \;; \ fi; \ if test -d $(srcdir)/$$file && test $$d != $(srcdir); then \ cp -fpR $(srcdir)/$$file "$(distdir)$$dir" || exit 1; \ find "$(distdir)/$$file" -type d ! -perm -700 -exec chmod u+rwx {} \;; \ fi; \ cp -fpR $$d/$$file "$(distdir)$$dir" || exit 1; \ else \ test -f "$(distdir)/$$file" \ || cp -p $$d/$$file "$(distdir)/$$file" \ || exit 1; \ fi; \ done check-am: all-am check: check-am all-am: Makefile $(LTLIBRARIES) installdirs: install: install-am install-exec: install-exec-am install-data: install-data-am uninstall: uninstall-am install-am: all-am @$(MAKE) $(AM_MAKEFLAGS) install-exec-am install-data-am installcheck: installcheck-am install-strip: if test -z '$(STRIP)'; then \ $(MAKE) $(AM_MAKEFLAGS) INSTALL_PROGRAM="$(INSTALL_STRIP_PROGRAM)" \ install_sh_PROGRAM="$(INSTALL_STRIP_PROGRAM)" INSTALL_STRIP_FLAG=-s \ install; \ else \ $(MAKE) $(AM_MAKEFLAGS) INSTALL_PROGRAM="$(INSTALL_STRIP_PROGRAM)" \ install_sh_PROGRAM="$(INSTALL_STRIP_PROGRAM)" INSTALL_STRIP_FLAG=-s \ "INSTALL_PROGRAM_ENV=STRIPPROG='$(STRIP)'" install; \ fi mostlyclean-generic: clean-generic: distclean-generic: -test -z "$(CONFIG_CLEAN_FILES)" || rm -f $(CONFIG_CLEAN_FILES) -test . = "$(srcdir)" || test -z "$(CONFIG_CLEAN_VPATH_FILES)" || rm -f $(CONFIG_CLEAN_VPATH_FILES) maintainer-clean-generic: @echo "This command is intended for maintainers to use" @echo "it deletes files that may require special tools to rebuild." clean: clean-am clean-am: clean-generic clean-libtool clean-noinstLTLIBRARIES \ mostlyclean-am distclean: distclean-am -rm -rf ./$(DEPDIR) -rm -f Makefile distclean-am: clean-am distclean-compile distclean-generic \ distclean-tags dvi: dvi-am dvi-am: html: html-am html-am: info: info-am info-am: install-data-am: install-dvi: install-dvi-am install-dvi-am: install-exec-am: install-html: install-html-am install-html-am: install-info: install-info-am install-info-am: install-man: install-pdf: install-pdf-am install-pdf-am: install-ps: install-ps-am install-ps-am: installcheck-am: maintainer-clean: maintainer-clean-am -rm -rf ./$(DEPDIR) -rm -f Makefile maintainer-clean-am: distclean-am maintainer-clean-generic mostlyclean: mostlyclean-am mostlyclean-am: mostlyclean-compile mostlyclean-generic \ mostlyclean-libtool pdf: pdf-am pdf-am: ps: ps-am ps-am: uninstall-am: .MAKE: install-am install-strip .PHONY: CTAGS GTAGS TAGS all all-am check check-am clean clean-generic \ clean-libtool clean-noinstLTLIBRARIES cscopelist-am ctags \ ctags-am distclean distclean-compile distclean-generic \ distclean-libtool distclean-tags distdir dvi dvi-am html \ html-am info info-am install install-am install-data \ install-data-am install-dvi install-dvi-am install-exec \ install-exec-am install-html install-html-am install-info \ install-info-am install-man install-pdf install-pdf-am \ install-ps install-ps-am install-strip installcheck \ installcheck-am installdirs maintainer-clean \ maintainer-clean-generic mostlyclean mostlyclean-compile \ mostlyclean-generic mostlyclean-libtool pdf pdf-am ps ps-am \ tags tags-am uninstall uninstall-am .PRECIOUS: Makefile .asm.lo: $(nasm_verbose)$(LIBTOOL) $(AM_V_lt) --mode=compile \ $(top_srcdir)/src/nasm_lt.sh $(NASM) $(NAFLAGS) \ -I$(top_srcdir)/src $< -o $@ # Tell versions [3.59,3.63) of GNU make to not export all variables. # Otherwise a system limit (for SysV at least) may be exceeded. .NOEXPORT: xrdp-0.9.5/librfxcodec/src/x86/funcs_x86.h000644 001751 001751 00000003070 13061652764 020130 0ustar00metameta000000 000000 /* Copyright 2014-2015 Jay Sorg Permission to use, copy, modify, distribute, and sell this software and its documentation for any purpose is hereby granted without fee, provided that the above copyright notice appear in all copies and that both that copyright notice and this permission notice appear in supporting documentation. The above copyright notice and this permission notice shall be included in all copies or substantial portions of the Software. THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE OPEN GROUP BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. x86 asm files */ #ifndef __FUNCS_X86_H #define __FUNCS_X86_H #ifdef __cplusplus extern "C" { #endif int cpuid_x86(int eax_in, int ecx_in, int *eax, int *ebx, int *ecx, int *edx); int rfxcodec_encode_dwt_shift_x86_sse2(const char *qtable, const unsigned char *data, short *dwt_buffer1, short *dwt_buffer); int rfxcodec_encode_dwt_shift_x86_sse41(const char *qtable, const unsigned char *data, short *dwt_buffer1, short *dwt_buffer); #ifdef __cplusplus } #endif #endif xrdp-0.9.5/librfxcodec/src/x86/cpuid_x86.asm000644 001751 001751 00000001035 13162371073 020437 0ustar00metameta000000 000000 %include "common.asm" ;int ;cpuid_x86(int eax_in, int ecx_in, int *eax, int *ebx, int *ecx, int *edx) PROC cpuid_x86 ; save registers push ebx push ecx push edx push edi ; cpuid mov eax, [esp + 20] mov ecx, [esp + 24] cpuid mov edi, [esp + 28] mov [edi], eax mov edi, [esp + 32] mov [edi], ebx mov edi, [esp + 36] mov [edi], ecx mov edi, [esp + 40] mov [edi], edx mov eax, 0 ; restore registers pop edi pop edx pop ecx pop ebx ret END_OF_FILE xrdp-0.9.5/librfxcodec/src/x86/rfxcodec_encode_dwt_shift_x86_sse2.asm000644 001751 001751 00000114002 13162371073 025453 0ustar00metameta000000 000000 ; ;Copyright 2016 Jay Sorg ;Copyright 2017 mirabilos ; ;Permission to use, copy, modify, distribute, and sell this software and its ;documentation for any purpose is hereby granted without fee, provided that ;the above copyright notice appear in all copies and that both that ;copyright notice and this permission notice appear in supporting ;documentation. ; ;The above copyright notice and this permission notice shall be included in ;all copies or substantial portions of the Software. ; ;THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR ;IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, ;FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE ;OPEN GROUP BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN ;AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN ;CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. ; ;x86 asm dwt %include "common.asm" PREPARE_RODATA cw128 times 8 dw 128 cdFFFF times 4 dd 65535 ; these are 1 << (factor - 1) 0 to 15 is factor cwa0 times 8 dw 0 ; 0 cwa1 times 8 dw 1 ; 1 cwa2 times 8 dw 2 ; 2 cwa4 times 8 dw 4 ; 3 cwa8 times 8 dw 8 ; 4 cwa16 times 8 dw 16 ; 5 cwa32 times 8 dw 32 ; 6 cwa64 times 8 dw 64 ; 7 cwa128 times 8 dw 128 ; 8 cwa256 times 8 dw 256 ; 9 cwa512 times 8 dw 512 ; 10 cwa1024 times 8 dw 1024 ; 11 cwa2048 times 8 dw 2048 ; 12 cwa4096 times 8 dw 4096 ; 13 cwa8192 times 8 dw 8192 ; 14 cwa16384 times 8 dw 16384 ; 15 %define LHI_ADD [esp + 1 * 16 + 4] %define LHI_SFT [esp + 2 * 16 + 4] %define LLO_ADD [esp + 3 * 16 + 4] %define LLO_SFT [esp + 4 * 16 + 4] ;****************************************************************************** ; source 16 bit signed, 16 pixel width rfx_dwt_2d_encode_block_horiz_16_16: mov ecx, 8 loop1a: ; pre / post movdqa xmm1, [esi] ; src[2n] movdqa xmm2, [esi + 16] movdqa xmm6, xmm1 movdqa xmm7, xmm2 pand xmm1, [lsym(cdFFFF)] pand xmm2, [lsym(cdFFFF)] pslld xmm1, 16 pslld xmm2, 16 psrad xmm1, 16 psrad xmm2, 16 packssdw xmm1, xmm2 movdqa xmm2, xmm6 ; src[2n + 1] movdqa xmm3, xmm7 psrldq xmm2, 2 psrldq xmm3, 2 pand xmm2, [lsym(cdFFFF)] pand xmm3, [lsym(cdFFFF)] pslld xmm2, 16 pslld xmm3, 16 psrad xmm2, 16 psrad xmm3, 16 packssdw xmm2, xmm3 movdqa xmm3, xmm6 ; src[2n + 2] movdqa xmm4, xmm7 psrldq xmm3, 4 psrldq xmm4, 4 movd eax, xmm7 movd xmm5, eax pslldq xmm5, 12 por xmm3, xmm5 movdqa xmm5, xmm7 psrldq xmm5, 12 pslldq xmm5, 12 por xmm4, xmm5 pand xmm3, [lsym(cdFFFF)] pand xmm4, [lsym(cdFFFF)] pslld xmm3, 16 pslld xmm4, 16 psrad xmm3, 16 psrad xmm4, 16 packssdw xmm3, xmm4 movdqa xmm4, xmm1 movdqa xmm5, xmm2 movdqa xmm6, xmm3 ; h[n] = (src[2n + 1] - ((src[2n] + src[2n + 2]) >> 1)) >> 1 paddw xmm4, xmm6 psraw xmm4, 1 psubw xmm5, xmm4 psraw xmm5, 1 movdqa xmm6, xmm5 ; out hi paddw xmm6, LHI_ADD psraw xmm6, LHI_SFT movdqa [edi], xmm6 ; l[n] = src[2n] + ((h[n - 1] + h[n]) >> 1) movdqa xmm7, xmm5 movd eax, xmm7 pslldq xmm7, 2 and eax, 0xFFFF movd xmm6, eax por xmm7, xmm6 paddw xmm5, xmm7 psraw xmm5, 1 paddw xmm5, xmm1 movdqa xmm6, xmm5 ; out lo paddw xmm6, LLO_ADD psraw xmm6, LLO_SFT movdqa [edx], xmm6 ; move right lea esi, [esi + 16 * 2] lea edi, [edi + 8 * 2] lea edx, [edx + 8 * 2] ; move left lea esi, [esi - 16 * 2] lea edi, [edi - 8 * 2] lea edx, [edx - 8 * 2] ; move down lea esi, [esi + 16 * 2] lea edi, [edi + 8 * 2] lea edx, [edx + 8 * 2] dec ecx jnz loop1a ret ;****************************************************************************** ; source 16 bit signed, 16 pixel width rfx_dwt_2d_encode_block_verti_16_16: mov ecx, 2 loop1b: ; pre movdqa xmm1, [esi] ; src[2n] movdqa xmm2, [esi + 16 * 2] ; src[2n + 1] movdqa xmm3, [esi + 16 * 2 * 2] ; src[2n + 2] movdqa xmm4, xmm1 movdqa xmm5, xmm2 movdqa xmm6, xmm3 ; h[n] = (src[2n + 1] - ((src[2n] + src[2n + 2]) >> 1)) >> 1 paddw xmm4, xmm6 psraw xmm4, 1 psubw xmm5, xmm4 psraw xmm5, 1 movdqa [edi], xmm5 ; out hi movdqa xmm6, xmm5 ; save hi ; l[n] = src[2n] + ((h[n - 1] + h[n]) >> 1) paddw xmm5, xmm1 movdqa [edx], xmm5 ; out lo movdqa xmm7, xmm6 ; save hi ; move down lea esi, [esi + 16 * 2 * 2] ; 2 rows lea edi, [edi + 16 * 2] ; 1 row lea edx, [edx + 16 * 2] ; 1 row ; loop shl ecx, 16 mov cx, 6 loop2b: movdqa xmm1, xmm3 ; src[2n] movdqa xmm2, [esi + 16 * 2] ; src[2n + 1] movdqa xmm3, [esi + 16 * 2 * 2] ; src[2n + 2] movdqa xmm4, xmm1 movdqa xmm5, xmm2 movdqa xmm6, xmm3 ; h[n] = (src[2n + 1] - ((src[2n] + src[2n + 2]) >> 1)) >> 1 paddw xmm4, xmm6 psraw xmm4, 1 psubw xmm5, xmm4 psraw xmm5, 1 movdqa [edi], xmm5 ; out hi movdqa xmm6, xmm5 ; save hi ; l[n] = src[2n] + ((h[n - 1] + h[n]) >> 1) paddw xmm5, xmm7 psraw xmm5, 1 paddw xmm5, xmm1 movdqa [edx], xmm5 ; out lo movdqa xmm7, xmm6 ; save hi ; move down lea esi, [esi + 16 * 2 * 2] ; 2 rows lea edi, [edi + 16 * 2] ; 1 row lea edx, [edx + 16 * 2] ; 1 row dec cx jnz loop2b shr ecx, 16 ; post movdqa xmm1, xmm3 ; src[2n] movdqa xmm2, [esi + 16 * 2] ; src[2n + 1] movdqa xmm4, xmm1 movdqa xmm5, xmm2 movdqa xmm6, xmm3 ; h[n] = (src[2n + 1] - ((src[2n] + src[2n + 2]) >> 1)) >> 1 paddw xmm4, xmm6 psraw xmm4, 1 psubw xmm5, xmm4 psraw xmm5, 1 movdqa [edi], xmm5 ; out hi ; l[n] = src[2n] + ((h[n - 1] + h[n]) >> 1) paddw xmm5, xmm7 psraw xmm5, 1 paddw xmm5, xmm1 movdqa [edx], xmm5 ; out lo ; move down lea esi, [esi + 16 * 2 * 2] ; 2 row lea edi, [edi + 16 * 2] ; 1 row lea edx, [edx + 16 * 2] ; 1 row ; move up lea esi, [esi - 16 * 16 * 2] lea edi, [edi - 8 * 16 * 2] lea edx, [edx - 8 * 16 * 2] ; move right lea esi, [esi + 16] lea edi, [edi + 16] lea edx, [edx + 16] dec ecx jnz loop1b ret ;****************************************************************************** ; source 16 bit signed, 32 pixel width rfx_dwt_2d_encode_block_horiz_16_32: mov ecx, 16 loop1c: ; pre movdqa xmm1, [esi] ; src[2n] movdqa xmm2, [esi + 16] movdqa xmm6, xmm1 movdqa xmm7, xmm2 pand xmm1, [lsym(cdFFFF)] pand xmm2, [lsym(cdFFFF)] pslld xmm1, 16 pslld xmm2, 16 psrad xmm1, 16 psrad xmm2, 16 packssdw xmm1, xmm2 movdqa xmm2, xmm6 ; src[2n + 1] movdqa xmm3, xmm7 psrldq xmm2, 2 psrldq xmm3, 2 pand xmm2, [lsym(cdFFFF)] pand xmm3, [lsym(cdFFFF)] pslld xmm2, 16 pslld xmm3, 16 psrad xmm2, 16 psrad xmm3, 16 packssdw xmm2, xmm3 movdqa xmm3, xmm6 ; src[2n + 2] movdqa xmm4, xmm7 psrldq xmm3, 4 psrldq xmm4, 4 movd eax, xmm7 movd xmm5, eax pslldq xmm5, 12 por xmm3, xmm5 mov eax, [esi + 32] movd xmm5, eax pslldq xmm5, 12 por xmm4, xmm5 pand xmm3, [lsym(cdFFFF)] pand xmm4, [lsym(cdFFFF)] pslld xmm3, 16 pslld xmm4, 16 psrad xmm3, 16 psrad xmm4, 16 packssdw xmm3, xmm4 movdqa xmm4, xmm1 movdqa xmm5, xmm2 movdqa xmm6, xmm3 ; h[n] = (src[2n + 1] - ((src[2n] + src[2n + 2]) >> 1)) >> 1 paddw xmm4, xmm6 psraw xmm4, 1 psubw xmm5, xmm4 psraw xmm5, 1 movdqa xmm6, xmm5 ; out hi paddw xmm6, LHI_ADD psraw xmm6, LHI_SFT movdqa [edi], xmm6 movdqa xmm2, xmm5 ; save hi ; l[n] = src[2n] + ((h[n - 1] + h[n]) >> 1) movdqa xmm7, xmm5 movd eax, xmm7 pslldq xmm7, 2 and eax, 0xFFFF movd xmm6, eax por xmm7, xmm6 paddw xmm5, xmm7 psraw xmm5, 1 paddw xmm5, xmm1 psrldq xmm2, 14 movd ebp, xmm2 ; save hi movdqa xmm6, xmm5 ; out lo paddw xmm6, LLO_ADD psraw xmm6, LLO_SFT movdqa [edx], xmm6 ; move right lea esi, [esi + 16 * 2] lea edi, [edi + 8 * 2] lea edx, [edx + 8 * 2] ; post movdqa xmm1, [esi] ; src[2n] movdqa xmm2, [esi + 16] movdqa xmm6, xmm1 movdqa xmm7, xmm2 pand xmm1, [lsym(cdFFFF)] pand xmm2, [lsym(cdFFFF)] pslld xmm1, 16 pslld xmm2, 16 psrad xmm1, 16 psrad xmm2, 16 packssdw xmm1, xmm2 movdqa xmm2, xmm6 ; src[2n + 1] movdqa xmm3, xmm7 psrldq xmm2, 2 psrldq xmm3, 2 pand xmm2, [lsym(cdFFFF)] pand xmm3, [lsym(cdFFFF)] pslld xmm2, 16 pslld xmm3, 16 psrad xmm2, 16 psrad xmm3, 16 packssdw xmm2, xmm3 movdqa xmm3, xmm6 ; src[2n + 2] movdqa xmm4, xmm7 psrldq xmm3, 4 psrldq xmm4, 4 movd eax, xmm7 movd xmm5, eax pslldq xmm5, 12 por xmm3, xmm5 movdqa xmm5, xmm7 psrldq xmm5, 12 pslldq xmm5, 12 por xmm4, xmm5 pand xmm3, [lsym(cdFFFF)] pand xmm4, [lsym(cdFFFF)] pslld xmm3, 16 pslld xmm4, 16 psrad xmm3, 16 psrad xmm4, 16 packssdw xmm3, xmm4 movdqa xmm4, xmm1 movdqa xmm5, xmm2 movdqa xmm6, xmm3 ; h[n] = (src[2n + 1] - ((src[2n] + src[2n + 2]) >> 1)) >> 1 paddw xmm4, xmm6 psraw xmm4, 1 psubw xmm5, xmm4 psraw xmm5, 1 movdqa xmm6, xmm5 ; out hi paddw xmm6, LHI_ADD psraw xmm6, LHI_SFT movdqa [edi], xmm6 ; l[n] = src[2n] + ((h[n - 1] + h[n]) >> 1) movdqa xmm7, xmm5 pslldq xmm7, 2 movd xmm6, ebp por xmm7, xmm6 paddw xmm5, xmm7 psraw xmm5, 1 paddw xmm5, xmm1 movdqa xmm6, xmm5 ; out lo paddw xmm6, LLO_ADD psraw xmm6, LLO_SFT movdqa [edx], xmm6 ; move right lea esi, [esi + 16 * 2] lea edi, [edi + 8 * 2] lea edx, [edx + 8 * 2] ; move left lea esi, [esi - 32 * 2] lea edi, [edi - 16 * 2] lea edx, [edx - 16 * 2] ; move down lea esi, [esi + 32 * 2] lea edi, [edi + 16 * 2] lea edx, [edx + 16 * 2] dec ecx jnz loop1c ret ;****************************************************************************** ; source 16 bit signed, 32 pixel width rfx_dwt_2d_encode_block_horiz_16_32_no_lo: mov ecx, 16 loop1c1: ; pre movdqa xmm1, [esi] ; src[2n] movdqa xmm2, [esi + 16] movdqa xmm6, xmm1 movdqa xmm7, xmm2 pand xmm1, [lsym(cdFFFF)] pand xmm2, [lsym(cdFFFF)] pslld xmm1, 16 pslld xmm2, 16 psrad xmm1, 16 psrad xmm2, 16 packssdw xmm1, xmm2 movdqa xmm2, xmm6 ; src[2n + 1] movdqa xmm3, xmm7 psrldq xmm2, 2 psrldq xmm3, 2 pand xmm2, [lsym(cdFFFF)] pand xmm3, [lsym(cdFFFF)] pslld xmm2, 16 pslld xmm3, 16 psrad xmm2, 16 psrad xmm3, 16 packssdw xmm2, xmm3 movdqa xmm3, xmm6 ; src[2n + 2] movdqa xmm4, xmm7 psrldq xmm3, 4 psrldq xmm4, 4 movd eax, xmm7 movd xmm5, eax pslldq xmm5, 12 por xmm3, xmm5 mov eax, [esi + 32] movd xmm5, eax pslldq xmm5, 12 por xmm4, xmm5 pand xmm3, [lsym(cdFFFF)] pand xmm4, [lsym(cdFFFF)] pslld xmm3, 16 pslld xmm4, 16 psrad xmm3, 16 psrad xmm4, 16 packssdw xmm3, xmm4 movdqa xmm4, xmm1 movdqa xmm5, xmm2 movdqa xmm6, xmm3 ; h[n] = (src[2n + 1] - ((src[2n] + src[2n + 2]) >> 1)) >> 1 paddw xmm4, xmm6 psraw xmm4, 1 psubw xmm5, xmm4 psraw xmm5, 1 movdqa xmm6, xmm5 ; out hi paddw xmm6, LHI_ADD psraw xmm6, LHI_SFT movdqa [edi], xmm6 movdqa xmm2, xmm5 ; save hi ; l[n] = src[2n] + ((h[n - 1] + h[n]) >> 1) movdqa xmm7, xmm5 movd eax, xmm7 pslldq xmm7, 2 and eax, 0xFFFF movd xmm6, eax por xmm7, xmm6 paddw xmm5, xmm7 psraw xmm5, 1 paddw xmm5, xmm1 psrldq xmm2, 14 movd ebp, xmm2 ; save hi movdqa [edx], xmm5 ; out lo ; move right lea esi, [esi + 16 * 2] lea edi, [edi + 8 * 2] lea edx, [edx + 8 * 2] ; post movdqa xmm1, [esi] ; src[2n] movdqa xmm2, [esi + 16] movdqa xmm6, xmm1 movdqa xmm7, xmm2 pand xmm1, [lsym(cdFFFF)] pand xmm2, [lsym(cdFFFF)] pslld xmm1, 16 pslld xmm2, 16 psrad xmm1, 16 psrad xmm2, 16 packssdw xmm1, xmm2 movdqa xmm2, xmm6 ; src[2n + 1] movdqa xmm3, xmm7 psrldq xmm2, 2 psrldq xmm3, 2 pand xmm2, [lsym(cdFFFF)] pand xmm3, [lsym(cdFFFF)] pslld xmm2, 16 pslld xmm3, 16 psrad xmm2, 16 psrad xmm3, 16 packssdw xmm2, xmm3 movdqa xmm3, xmm6 ; src[2n + 2] movdqa xmm4, xmm7 psrldq xmm3, 4 psrldq xmm4, 4 movd eax, xmm7 movd xmm5, eax pslldq xmm5, 12 por xmm3, xmm5 movdqa xmm5, xmm7 psrldq xmm5, 12 pslldq xmm5, 12 por xmm4, xmm5 pand xmm3, [lsym(cdFFFF)] pand xmm4, [lsym(cdFFFF)] pslld xmm3, 16 pslld xmm4, 16 psrad xmm3, 16 psrad xmm4, 16 packssdw xmm3, xmm4 movdqa xmm4, xmm1 movdqa xmm5, xmm2 movdqa xmm6, xmm3 ; h[n] = (src[2n + 1] - ((src[2n] + src[2n + 2]) >> 1)) >> 1 paddw xmm4, xmm6 psraw xmm4, 1 psubw xmm5, xmm4 psraw xmm5, 1 movdqa xmm6, xmm5 ; out hi paddw xmm6, LHI_ADD psraw xmm6, LHI_SFT movdqa [edi], xmm6 ; l[n] = src[2n] + ((h[n - 1] + h[n]) >> 1) movdqa xmm7, xmm5 pslldq xmm7, 2 movd xmm6, ebp por xmm7, xmm6 paddw xmm5, xmm7 psraw xmm5, 1 paddw xmm5, xmm1 movdqa [edx], xmm5 ; out lo ; move right lea esi, [esi + 16 * 2] lea edi, [edi + 8 * 2] lea edx, [edx + 8 * 2] ; move left lea esi, [esi - 32 * 2] lea edi, [edi - 16 * 2] lea edx, [edx - 16 * 2] ; move down lea esi, [esi + 32 * 2] lea edi, [edi + 16 * 2] lea edx, [edx + 16 * 2] dec ecx jnz loop1c1 ret ;****************************************************************************** ; source 16 bit signed, 32 pixel width rfx_dwt_2d_encode_block_verti_16_32: mov ecx, 4 loop1d: ; pre movdqa xmm1, [esi] ; src[2n] movdqa xmm2, [esi + 32 * 2] ; src[2n + 1] movdqa xmm3, [esi + 32 * 2 * 2] ; src[2n + 2] movdqa xmm4, xmm1 movdqa xmm5, xmm2 movdqa xmm6, xmm3 ; h[n] = (src[2n + 1] - ((src[2n] + src[2n + 2]) >> 1)) >> 1 paddw xmm4, xmm6 psraw xmm4, 1 psubw xmm5, xmm4 psraw xmm5, 1 movdqa [edi], xmm5 ; out hi movdqa xmm6, xmm5 ; save hi ; l[n] = src[2n] + ((h[n - 1] + h[n]) >> 1) paddw xmm5, xmm1 movdqa [edx], xmm5 ; out lo movdqa xmm7, xmm6 ; save hi ; move down lea esi, [esi + 32 * 2 * 2] ; 2 rows lea edi, [edi + 32 * 2] ; 1 row lea edx, [edx + 32 * 2] ; 1 row ; loop shl ecx, 16 mov cx, 14 loop2d: movdqa xmm1, xmm3 ; src[2n] movdqa xmm2, [esi + 32 * 2] ; src[2n + 1] movdqa xmm3, [esi + 32 * 2 * 2] ; src[2n + 2] movdqa xmm4, xmm1 movdqa xmm5, xmm2 movdqa xmm6, xmm3 ; h[n] = (src[2n + 1] - ((src[2n] + src[2n + 2]) >> 1)) >> 1 paddw xmm4, xmm6 psraw xmm4, 1 psubw xmm5, xmm4 psraw xmm5, 1 movdqa [edi], xmm5 ; out hi movdqa xmm6, xmm5 ; save hi ; l[n] = src[2n] + ((h[n - 1] + h[n]) >> 1) paddw xmm5, xmm7 psraw xmm5, 1 paddw xmm5, xmm1 movdqa [edx], xmm5 ; out lo movdqa xmm7, xmm6 ; save hi ; move down lea esi, [esi + 32 * 2 * 2] ; 2 rows lea edi, [edi + 32 * 2] ; 1 row lea edx, [edx + 32 * 2] ; 1 row dec cx jnz loop2d shr ecx, 16 ; post movdqa xmm1, xmm3 ; src[2n] movdqa xmm2, [esi + 32 * 2] ; src[2n + 1] movdqa xmm4, xmm1 movdqa xmm5, xmm2 movdqa xmm6, xmm3 ; h[n] = (src[2n + 1] - ((src[2n] + src[2n + 2]) >> 1)) >> 1 paddw xmm4, xmm6 psraw xmm4, 1 psubw xmm5, xmm4 psraw xmm5, 1 movdqa [edi], xmm5 ; out hi ; l[n] = src[2n] + ((h[n - 1] + h[n]) >> 1) paddw xmm5, xmm7 psraw xmm5, 1 paddw xmm5, xmm1 movdqa [edx], xmm5 ; out lo ; move down lea esi, [esi + 32 * 2 * 2] ; 2 row lea edi, [edi + 32 * 2] ; 1 row lea edx, [edx + 32 * 2] ; 1 row ; move up lea esi, [esi - 32 * 32 * 2] lea edi, [edi - 16 * 32 * 2] lea edx, [edx - 16 * 32 * 2] ; move right lea esi, [esi + 16] lea edi, [edi + 16] lea edx, [edx + 16] dec ecx jnz loop1d ret ;****************************************************************************** ; source 16 bit signed, 64 pixel width rfx_dwt_2d_encode_block_horiz_16_64: mov ecx, 32 loop1e: ; pre movdqa xmm1, [esi] ; src[2n] movdqa xmm2, [esi + 16] movdqa xmm6, xmm1 movdqa xmm7, xmm2 pand xmm1, [lsym(cdFFFF)] pand xmm2, [lsym(cdFFFF)] pslld xmm1, 16 pslld xmm2, 16 psrad xmm1, 16 psrad xmm2, 16 packssdw xmm1, xmm2 movdqa xmm2, xmm6 ; src[2n + 1] movdqa xmm3, xmm7 psrldq xmm2, 2 psrldq xmm3, 2 pand xmm2, [lsym(cdFFFF)] pand xmm3, [lsym(cdFFFF)] pslld xmm2, 16 pslld xmm3, 16 psrad xmm2, 16 psrad xmm3, 16 packssdw xmm2, xmm3 movdqa xmm3, xmm6 ; src[2n + 2] movdqa xmm4, xmm7 psrldq xmm3, 4 psrldq xmm4, 4 movd eax, xmm7 movd xmm5, eax pslldq xmm5, 12 por xmm3, xmm5 mov eax, [esi + 32] movd xmm5, eax pslldq xmm5, 12 por xmm4, xmm5 pand xmm3, [lsym(cdFFFF)] pand xmm4, [lsym(cdFFFF)] pslld xmm3, 16 pslld xmm4, 16 psrad xmm3, 16 psrad xmm4, 16 packssdw xmm3, xmm4 movdqa xmm4, xmm1 movdqa xmm5, xmm2 movdqa xmm6, xmm3 ; h[n] = (src[2n + 1] - ((src[2n] + src[2n + 2]) >> 1)) >> 1 paddw xmm4, xmm6 psraw xmm4, 1 psubw xmm5, xmm4 psraw xmm5, 1 movdqa xmm6, xmm5 ; out hi paddw xmm6, LHI_ADD psraw xmm6, LHI_SFT movdqa [edi], xmm6 movdqa xmm2, xmm5 ; save hi ; l[n] = src[2n] + ((h[n - 1] + h[n]) >> 1) movdqa xmm7, xmm5 movd eax, xmm7 pslldq xmm7, 2 and eax, 0xFFFF movd xmm6, eax por xmm7, xmm6 paddw xmm5, xmm7 psraw xmm5, 1 paddw xmm5, xmm1 psrldq xmm2, 14 movd ebp, xmm2 ; save hi movdqa xmm6, xmm5 ; out lo paddw xmm6, LLO_ADD psraw xmm6, LLO_SFT movdqa [edx], xmm6 ; move right lea esi, [esi + 16 * 2] lea edi, [edi + 8 * 2] lea edx, [edx + 8 * 2] ; loop shl ecx, 16 mov cx, 2 loop2e: movdqa xmm1, [esi] ; src[2n] movdqa xmm2, [esi + 16] movdqa xmm6, xmm1 movdqa xmm7, xmm2 pand xmm1, [lsym(cdFFFF)] pand xmm2, [lsym(cdFFFF)] pslld xmm1, 16 pslld xmm2, 16 psrad xmm1, 16 psrad xmm2, 16 packssdw xmm1, xmm2 movdqa xmm2, xmm6 ; src[2n + 1] movdqa xmm3, xmm7 psrldq xmm2, 2 psrldq xmm3, 2 pand xmm2, [lsym(cdFFFF)] pand xmm3, [lsym(cdFFFF)] pslld xmm2, 16 pslld xmm3, 16 psrad xmm2, 16 psrad xmm3, 16 packssdw xmm2, xmm3 movdqa xmm3, xmm6 ; src[2n + 2] movdqa xmm4, xmm7 psrldq xmm3, 4 psrldq xmm4, 4 movd eax, xmm7 movd xmm5, eax pslldq xmm5, 12 por xmm3, xmm5 mov eax, [esi + 32] movd xmm5, eax pslldq xmm5, 12 por xmm4, xmm5 pand xmm3, [lsym(cdFFFF)] pand xmm4, [lsym(cdFFFF)] pslld xmm3, 16 pslld xmm4, 16 psrad xmm3, 16 psrad xmm4, 16 packssdw xmm3, xmm4 movdqa xmm4, xmm1 movdqa xmm5, xmm2 movdqa xmm6, xmm3 ; h[n] = (src[2n + 1] - ((src[2n] + src[2n + 2]) >> 1)) >> 1 paddw xmm4, xmm6 psraw xmm4, 1 psubw xmm5, xmm4 psraw xmm5, 1 movdqa xmm6, xmm5 ; out hi paddw xmm6, LHI_ADD psraw xmm6, LHI_SFT movdqa [edi], xmm6 movdqa xmm2, xmm5 ; save hi ; l[n] = src[2n] + ((h[n - 1] + h[n]) >> 1) movdqa xmm7, xmm5 pslldq xmm7, 2 movd xmm6, ebp por xmm7, xmm6 paddw xmm5, xmm7 psraw xmm5, 1 paddw xmm5, xmm1 psrldq xmm2, 14 movd ebp, xmm2 ; save hi movdqa xmm6, xmm5 ; out lo paddw xmm6, LLO_ADD psraw xmm6, LLO_SFT movdqa [edx], xmm6 ; move right lea esi, [esi + 16 * 2] lea edi, [edi + 8 * 2] lea edx, [edx + 8 * 2] dec cx jnz loop2e shr ecx, 16 ; post movdqa xmm1, [esi] ; src[2n] movdqa xmm2, [esi + 16] movdqa xmm6, xmm1 movdqa xmm7, xmm2 pand xmm1, [lsym(cdFFFF)] pand xmm2, [lsym(cdFFFF)] pslld xmm1, 16 pslld xmm2, 16 psrad xmm1, 16 psrad xmm2, 16 packssdw xmm1, xmm2 movdqa xmm2, xmm6 ; src[2n + 1] movdqa xmm3, xmm7 psrldq xmm2, 2 psrldq xmm3, 2 pand xmm2, [lsym(cdFFFF)] pand xmm3, [lsym(cdFFFF)] pslld xmm2, 16 pslld xmm3, 16 psrad xmm2, 16 psrad xmm3, 16 packssdw xmm2, xmm3 movdqa xmm3, xmm6 ; src[2n + 2] movdqa xmm4, xmm7 psrldq xmm3, 4 psrldq xmm4, 4 movd eax, xmm7 movd xmm5, eax pslldq xmm5, 12 por xmm3, xmm5 movdqa xmm5, xmm7 psrldq xmm5, 12 pslldq xmm5, 12 por xmm4, xmm5 pand xmm3, [lsym(cdFFFF)] pand xmm4, [lsym(cdFFFF)] pslld xmm3, 16 pslld xmm4, 16 psrad xmm3, 16 psrad xmm4, 16 packssdw xmm3, xmm4 movdqa xmm4, xmm1 movdqa xmm5, xmm2 movdqa xmm6, xmm3 ; h[n] = (src[2n + 1] - ((src[2n] + src[2n + 2]) >> 1)) >> 1 paddw xmm4, xmm6 psraw xmm4, 1 psubw xmm5, xmm4 psraw xmm5, 1 movdqa xmm6, xmm5 ; out hi paddw xmm6, LHI_ADD psraw xmm6, LHI_SFT movdqa [edi], xmm6 ; l[n] = src[2n] + ((h[n - 1] + h[n]) >> 1) movdqa xmm7, xmm5 pslldq xmm7, 2 movd xmm6, ebp por xmm7, xmm6 paddw xmm5, xmm7 psraw xmm5, 1 paddw xmm5, xmm1 movdqa xmm6, xmm5 ; out lo paddw xmm6, LLO_ADD psraw xmm6, LLO_SFT movdqa [edx], xmm6 ; move right lea esi, [esi + 16 * 2] lea edi, [edi + 8 * 2] lea edx, [edx + 8 * 2] ; move left lea esi, [esi - 64 * 2] lea edi, [edi - 32 * 2] lea edx, [edx - 32 * 2] ; move down lea esi, [esi + 64 * 2] lea edi, [edi + 32 * 2] lea edx, [edx + 32 * 2] dec ecx jnz loop1e ret ;****************************************************************************** ; source 16 bit signed, 64 pixel width rfx_dwt_2d_encode_block_horiz_16_64_no_lo: mov ecx, 32 loop1e1: ; pre movdqa xmm1, [esi] ; src[2n] movdqa xmm2, [esi + 16] movdqa xmm6, xmm1 movdqa xmm7, xmm2 pand xmm1, [lsym(cdFFFF)] pand xmm2, [lsym(cdFFFF)] pslld xmm1, 16 pslld xmm2, 16 psrad xmm1, 16 psrad xmm2, 16 packssdw xmm1, xmm2 movdqa xmm2, xmm6 ; src[2n + 1] movdqa xmm3, xmm7 psrldq xmm2, 2 psrldq xmm3, 2 pand xmm2, [lsym(cdFFFF)] pand xmm3, [lsym(cdFFFF)] pslld xmm2, 16 pslld xmm3, 16 psrad xmm2, 16 psrad xmm3, 16 packssdw xmm2, xmm3 movdqa xmm3, xmm6 ; src[2n + 2] movdqa xmm4, xmm7 psrldq xmm3, 4 psrldq xmm4, 4 movd eax, xmm7 movd xmm5, eax pslldq xmm5, 12 por xmm3, xmm5 mov eax, [esi + 32] movd xmm5, eax pslldq xmm5, 12 por xmm4, xmm5 pand xmm3, [lsym(cdFFFF)] pand xmm4, [lsym(cdFFFF)] pslld xmm3, 16 pslld xmm4, 16 psrad xmm3, 16 psrad xmm4, 16 packssdw xmm3, xmm4 movdqa xmm4, xmm1 movdqa xmm5, xmm2 movdqa xmm6, xmm3 ; h[n] = (src[2n + 1] - ((src[2n] + src[2n + 2]) >> 1)) >> 1 paddw xmm4, xmm6 psraw xmm4, 1 psubw xmm5, xmm4 psraw xmm5, 1 movdqa xmm6, xmm5 ; out hi paddw xmm6, LHI_ADD psraw xmm6, LHI_SFT movdqa [edi], xmm6 movdqa xmm2, xmm5 ; save hi ; l[n] = src[2n] + ((h[n - 1] + h[n]) >> 1) movdqa xmm7, xmm5 movd eax, xmm7 pslldq xmm7, 2 and eax, 0xFFFF movd xmm6, eax por xmm7, xmm6 paddw xmm5, xmm7 psraw xmm5, 1 paddw xmm5, xmm1 psrldq xmm2, 14 movd ebp, xmm2 ; save hi movdqa [edx], xmm5 ; out lo ; move right lea esi, [esi + 16 * 2] lea edi, [edi + 8 * 2] lea edx, [edx + 8 * 2] ; loop shl ecx, 16 mov cx, 2 loop2e1: movdqa xmm1, [esi] ; src[2n] movdqa xmm2, [esi + 16] movdqa xmm6, xmm1 movdqa xmm7, xmm2 pand xmm1, [lsym(cdFFFF)] pand xmm2, [lsym(cdFFFF)] pslld xmm1, 16 pslld xmm2, 16 psrad xmm1, 16 psrad xmm2, 16 packssdw xmm1, xmm2 movdqa xmm2, xmm6 ; src[2n + 1] movdqa xmm3, xmm7 psrldq xmm2, 2 psrldq xmm3, 2 pand xmm2, [lsym(cdFFFF)] pand xmm3, [lsym(cdFFFF)] pslld xmm2, 16 pslld xmm3, 16 psrad xmm2, 16 psrad xmm3, 16 packssdw xmm2, xmm3 movdqa xmm3, xmm6 ; src[2n + 2] movdqa xmm4, xmm7 psrldq xmm3, 4 psrldq xmm4, 4 movd eax, xmm7 movd xmm5, eax pslldq xmm5, 12 por xmm3, xmm5 mov eax, [esi + 32] movd xmm5, eax pslldq xmm5, 12 por xmm4, xmm5 pand xmm3, [lsym(cdFFFF)] pand xmm4, [lsym(cdFFFF)] pslld xmm3, 16 pslld xmm4, 16 psrad xmm3, 16 psrad xmm4, 16 packssdw xmm3, xmm4 movdqa xmm4, xmm1 movdqa xmm5, xmm2 movdqa xmm6, xmm3 ; h[n] = (src[2n + 1] - ((src[2n] + src[2n + 2]) >> 1)) >> 1 paddw xmm4, xmm6 psraw xmm4, 1 psubw xmm5, xmm4 psraw xmm5, 1 movdqa xmm6, xmm5 ; out hi paddw xmm6, LHI_ADD psraw xmm6, LHI_SFT movdqa [edi], xmm6 movdqa xmm2, xmm5 ; save hi ; l[n] = src[2n] + ((h[n - 1] + h[n]) >> 1) movdqa xmm7, xmm5 pslldq xmm7, 2 movd xmm6, ebp por xmm7, xmm6 paddw xmm5, xmm7 psraw xmm5, 1 paddw xmm5, xmm1 psrldq xmm2, 14 movd ebp, xmm2 ; save hi movdqa [edx], xmm5 ; out lo ; move right lea esi, [esi + 16 * 2] lea edi, [edi + 8 * 2] lea edx, [edx + 8 * 2] dec cx jnz loop2e1 shr ecx, 16 ; post movdqa xmm1, [esi] ; src[2n] movdqa xmm2, [esi + 16] movdqa xmm6, xmm1 movdqa xmm7, xmm2 pand xmm1, [lsym(cdFFFF)] pand xmm2, [lsym(cdFFFF)] pslld xmm1, 16 pslld xmm2, 16 psrad xmm1, 16 psrad xmm2, 16 packssdw xmm1, xmm2 movdqa xmm2, xmm6 ; src[2n + 1] movdqa xmm3, xmm7 psrldq xmm2, 2 psrldq xmm3, 2 pand xmm2, [lsym(cdFFFF)] pand xmm3, [lsym(cdFFFF)] pslld xmm2, 16 pslld xmm3, 16 psrad xmm2, 16 psrad xmm3, 16 packssdw xmm2, xmm3 movdqa xmm3, xmm6 ; src[2n + 2] movdqa xmm4, xmm7 psrldq xmm3, 4 psrldq xmm4, 4 movd eax, xmm7 movd xmm5, eax pslldq xmm5, 12 por xmm3, xmm5 movdqa xmm5, xmm7 psrldq xmm5, 12 pslldq xmm5, 12 por xmm4, xmm5 pand xmm3, [lsym(cdFFFF)] pand xmm4, [lsym(cdFFFF)] pslld xmm3, 16 pslld xmm4, 16 psrad xmm3, 16 psrad xmm4, 16 packssdw xmm3, xmm4 movdqa xmm4, xmm1 movdqa xmm5, xmm2 movdqa xmm6, xmm3 ; h[n] = (src[2n + 1] - ((src[2n] + src[2n + 2]) >> 1)) >> 1 paddw xmm4, xmm6 psraw xmm4, 1 psubw xmm5, xmm4 psraw xmm5, 1 movdqa xmm6, xmm5 ; out hi paddw xmm6, LHI_ADD psraw xmm6, LHI_SFT movdqa [edi], xmm6 ; l[n] = src[2n] + ((h[n - 1] + h[n]) >> 1) movdqa xmm7, xmm5 pslldq xmm7, 2 movd xmm6, ebp por xmm7, xmm6 paddw xmm5, xmm7 psraw xmm5, 1 paddw xmm5, xmm1 movdqa [edx], xmm5 ; out lo ; move right lea esi, [esi + 16 * 2] lea edi, [edi + 8 * 2] lea edx, [edx + 8 * 2] ; move left lea esi, [esi - 64 * 2] lea edi, [edi - 32 * 2] lea edx, [edx - 32 * 2] ; move down lea esi, [esi + 64 * 2] lea edi, [edi + 32 * 2] lea edx, [edx + 32 * 2] dec ecx jnz loop1e1 ret ;****************************************************************************** ; source 8 bit unsigned, 64 pixel width rfx_dwt_2d_encode_block_verti_8_64: mov ecx, 8 loop1f: ; pre movq xmm1, [esi] ; src[2n] movq xmm2, [esi + 64 * 1] ; src[2n + 1] movq xmm3, [esi + 64 * 1 * 2] ; src[2n + 2] punpcklbw xmm1, xmm0 punpcklbw xmm2, xmm0 punpcklbw xmm3, xmm0 psubw xmm1, [lsym(cw128)] psubw xmm2, [lsym(cw128)] psubw xmm3, [lsym(cw128)] psllw xmm1, 5 psllw xmm2, 5 psllw xmm3, 5 movdqa xmm4, xmm1 movdqa xmm5, xmm2 movdqa xmm6, xmm3 ; h[n] = (src[2n + 1] - ((src[2n] + src[2n + 2]) >> 1)) >> 1 paddw xmm4, xmm6 psraw xmm4, 1 psubw xmm5, xmm4 psraw xmm5, 1 movdqa [edi], xmm5 ; out hi movdqa xmm6, xmm5 ; save hi ; l[n] = src[2n] + ((h[n - 1] + h[n]) >> 1) paddw xmm5, xmm1 movdqa [edx], xmm5 ; out lo movdqa xmm7, xmm6 ; save hi ; move down lea esi, [esi + 64 * 1 * 2] ; 2 rows lea edi, [edi + 64 * 2] ; 1 row lea edx, [edx + 64 * 2] ; 1 row ; loop shl ecx, 16 mov cx, 30 loop2f: movdqa xmm1, xmm3 ; src[2n] movq xmm2, [esi + 64 * 1] ; src[2n + 1] movq xmm3, [esi + 64 * 1 * 2] ; src[2n + 2] punpcklbw xmm2, xmm0 punpcklbw xmm3, xmm0 psubw xmm2, [lsym(cw128)] psubw xmm3, [lsym(cw128)] psllw xmm2, 5 psllw xmm3, 5 movdqa xmm4, xmm1 movdqa xmm5, xmm2 movdqa xmm6, xmm3 ; h[n] = (src[2n + 1] - ((src[2n] + src[2n + 2]) >> 1)) >> 1 paddw xmm4, xmm6 psraw xmm4, 1 psubw xmm5, xmm4 psraw xmm5, 1 movdqa [edi], xmm5 ; out hi movdqa xmm6, xmm5 ; save hi ; l[n] = src[2n] + ((h[n - 1] + h[n]) >> 1) paddw xmm5, xmm7 psraw xmm5, 1 paddw xmm5, xmm1 movdqa [edx], xmm5 ; out lo movdqa xmm7, xmm6 ; save hi ; move down lea esi, [esi + 64 * 1 * 2] ; 2 rows lea edi, [edi + 64 * 2] ; 1 row lea edx, [edx + 64 * 2] ; 1 row dec cx jnz loop2f shr ecx, 16 ; post movdqa xmm1, xmm3 ; src[2n] movq xmm2, [esi + 64 * 1] ; src[2n + 1] punpcklbw xmm2, xmm0 psubw xmm2, [lsym(cw128)] psllw xmm2, 5 movdqa xmm4, xmm1 movdqa xmm5, xmm2 movdqa xmm6, xmm3 ; h[n] = (src[2n + 1] - ((src[2n] + src[2n + 2]) >> 1)) >> 1 paddw xmm4, xmm6 psraw xmm4, 1 psubw xmm5, xmm4 psraw xmm5, 1 movdqa [edi], xmm5 ; out hi ; l[n] = src[2n] + ((h[n - 1] + h[n]) >> 1) paddw xmm5, xmm7 psraw xmm5, 1 paddw xmm5, xmm1 movdqa [edx], xmm5 ; out lo ; move down lea esi, [esi + 64 * 1 * 2] ; 2 rows lea edi, [edi + 64 * 2] ; 1 row lea edx, [edx + 64 * 2] ; 1 row ; move up lea esi, [esi - 64 * 1 * 64] lea edi, [edi - 32 * 64 * 2] lea edx, [edx - 32 * 64 * 2] ; move right lea esi, [esi + 8] lea edi, [edi + 16] lea edx, [edx + 16] dec ecx jnz loop1f ret set_quants_hi: sub eax, 6 - 5 movd xmm1, eax movdqa LHI_SFT, xmm1 imul eax, 16 lea edx, [lsym(cwa0)] add edx, eax movdqa xmm1, [edx] movdqa LHI_ADD, xmm1 ret set_quants_lo: sub eax, 6 - 5 movd xmm1, eax movdqa LLO_SFT, xmm1 imul eax, 16 lea edx, [lsym(cwa0)] add edx, eax movdqa xmm1, [edx] movdqa LLO_ADD, xmm1 ret %define LQTABLE [esp + 144] ; qtable %define LIN_BUFFER [esp + 148] ; in_buffer %define LOUT_BUFFER [esp + 152] ; out_buffer %define LWORK_BUFFER [esp + 156] ; work_buffer ;int ;rfxcodec_encode_dwt_shift_x86_sse2(const char *qtable, ; unsigned char *in_buffer, ; short *out_buffer, ; short *work_buffer); ;****************************************************************************** PROC rfxcodec_encode_dwt_shift_x86_sse2 ; align stack mov eax, esp sub eax, 0x10 and eax, 0x0F sub esp, eax push eax sub esp, 3 * 4 sub esp, 4 * 4 ; copy params to after align movdqu xmm0, [esp + eax + 4 * 4 + 3 * 4 + 4 + 4] movdqu [esp], xmm0 ; save registers push ebx RETRIEVE_RODATA push esi push edi push ebp sub esp, 16 * 8 pxor xmm0, xmm0 ; verical DWT to work buffer, level 1 mov esi, LIN_BUFFER ; src mov edi, LWORK_BUFFER ; dst hi lea edi, [edi + 64 * 32 * 2] ; dst hi mov edx, LWORK_BUFFER ; dst lo call rfx_dwt_2d_encode_block_verti_8_64 ; horizontal DWT to out buffer, level 1, part 1 xor eax, eax mov edx, LQTABLE mov al, [edx + 4] and al, 0xF call set_quants_hi mov esi, LWORK_BUFFER ; src mov edi, LOUT_BUFFER ; dst hi - HL1 mov edx, LOUT_BUFFER ; dst lo - LL1 lea edx, [edx + 32 * 32 * 6] ; dst lo - LL1 call rfx_dwt_2d_encode_block_horiz_16_64_no_lo ; horizontal DWT to out buffer, level 1, part 2 xor eax, eax mov edx, LQTABLE mov al, [edx + 4] shr al, 4 call set_quants_hi xor eax, eax mov edx, LQTABLE mov al, [edx + 3] shr al, 4 call set_quants_lo mov esi, LWORK_BUFFER ; src lea esi, [esi + 64 * 32 * 2] ; src mov edi, LOUT_BUFFER ; dst hi - HH1 lea edi, [edi + 32 * 32 * 4] ; dst hi - HH1 mov edx, LOUT_BUFFER ; dst lo - LH1 lea edx, [edx + 32 * 32 * 2] ; dst lo - LH1 call rfx_dwt_2d_encode_block_horiz_16_64 ; verical DWT to work buffer, level 2 mov esi, LOUT_BUFFER ; src lea esi, [esi + 32 * 32 * 6] ; src mov edi, LWORK_BUFFER ; dst hi lea edi, [edi + 32 * 16 * 2] ; dst hi mov edx, LWORK_BUFFER ; dst lo call rfx_dwt_2d_encode_block_verti_16_32 ; horizontal DWT to out buffer, level 2, part 1 xor eax, eax mov edx, LQTABLE mov al, [edx + 2] shr al, 4 call set_quants_hi mov esi, LWORK_BUFFER ; src ; 32 * 32 * 6 + 16 * 16 * 0 = 6144 mov edi, LOUT_BUFFER ; dst hi - HL2 lea edi, [edi + 6144] ; dst hi - HL2 ; 32 * 32 * 6 + 16 * 16 * 6 = 7680 mov edx, LOUT_BUFFER ; dst lo - LL2 lea edx, [edx + 7680] ; dst lo - LL2 call rfx_dwt_2d_encode_block_horiz_16_32_no_lo ; horizontal DWT to out buffer, level 2, part 2 xor eax, eax mov edx, LQTABLE mov al, [edx + 3] and al, 0xF call set_quants_hi xor eax, eax mov edx, LQTABLE mov al, [edx + 2] and al, 0xF call set_quants_lo mov esi, LWORK_BUFFER ; src lea esi, [esi + 32 * 16 * 2] ; src ; 32 * 32 * 6 + 16 * 16 * 4 = 7168 mov edi, LOUT_BUFFER ; dst hi - HH2 lea edi, [edi + 7168] ; dst hi - HH2 ; 32 * 32 * 6 + 16 * 16 * 2 = 6656 mov edx, LOUT_BUFFER ; dst lo - LH2 lea edx, [edx + 6656] ; dst lo - LH2 call rfx_dwt_2d_encode_block_horiz_16_32 ; verical DWT to work buffer, level 3 ; 32 * 32 * 6 + 16 * 16 * 6 = 7680 mov esi, LOUT_BUFFER ; src lea esi, [esi + 7680] ; src mov edi, LWORK_BUFFER ; dst hi lea edi, [edi + 16 * 8 * 2] ; dst hi mov edx, LWORK_BUFFER ; dst lo call rfx_dwt_2d_encode_block_verti_16_16 ; horizontal DWT to out buffer, level 3, part 1 xor eax, eax mov edx, LQTABLE mov al, [edx + 1] and al, 0xF call set_quants_hi xor eax, eax mov edx, LQTABLE mov al, [edx + 0] and al, 0xF call set_quants_lo mov esi, LWORK_BUFFER ; src ; 32 * 32 * 6 + 16 * 16 * 6 + 8 * 8 * 0 = 7680 mov edi, LOUT_BUFFER ; dst hi - HL3 lea edi, [edi + 7680] ; dst hi - HL3 ; 32 * 32 * 6 + 16 * 16 * 6 + 8 * 8 * 6 = 8064 mov edx, LOUT_BUFFER ; dst lo - LL3 lea edx, [edx + 8064] ; dst lo - LL3 call rfx_dwt_2d_encode_block_horiz_16_16 ; horizontal DWT to out buffer, level 3, part 2 xor eax, eax mov edx, LQTABLE mov al, [edx + 1] shr al, 4 call set_quants_hi xor eax, eax mov edx, LQTABLE mov al, [edx + 0] shr al, 4 call set_quants_lo mov esi, LWORK_BUFFER ; src lea esi, [esi + 16 * 8 * 2] ; src ; 32 * 32 * 6 + 16 * 16 * 6 + 8 * 8 * 4 = 7936 mov edi, LOUT_BUFFER ; dst hi - HH3 lea edi, [edi + 7936] ; dst hi - HH3 ; 32 * 32 * 6 + 16 * 16 * 6 + 8 * 8 * 2 = 7808 mov edx, LOUT_BUFFER ; dst lo - LH3 lea edx, [edx + 7808] ; dst lo - LH3 call rfx_dwt_2d_encode_block_horiz_16_16 ; quants add esp, 16 * 8 ; restore registers pop ebp pop edi pop esi pop ebx ; params add esp, 3 * 4 add esp, 4 * 4 ; align pop eax add esp, eax ; return value mov eax, 0 ret END_OF_FILE xrdp-0.9.5/librfxcodec/src/amd64/funcs_amd64.h000644 001751 001751 00000003120 13061652764 020700 0ustar00metameta000000 000000 /* Copyright 2014-2015 Jay Sorg Permission to use, copy, modify, distribute, and sell this software and its documentation for any purpose is hereby granted without fee, provided that the above copyright notice appear in all copies and that both that copyright notice and this permission notice appear in supporting documentation. The above copyright notice and this permission notice shall be included in all copies or substantial portions of the Software. THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE OPEN GROUP BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. amd64 asm files */ #ifndef __FUNCS_AMD64_H #define __FUNCS_AMD64_H #ifdef __cplusplus extern "C" { #endif int cpuid_amd64(int eax_in, int ecx_in, int *eax, int *ebx, int *ecx, int *edx); int rfxcodec_encode_dwt_shift_amd64_sse2(const char *qtable, const unsigned char *data, short *dwt_buffer1, short *dwt_buffer); int rfxcodec_encode_dwt_shift_amd64_sse41(const char *qtable, const unsigned char *data, short *dwt_buffer1, short *dwt_buffer); #ifdef __cplusplus } #endif #endif xrdp-0.9.5/librfxcodec/src/amd64/rfxcodec_encode_dwt_shift_amd64_sse2.asm000644 001751 001751 00000112230 13162371073 026230 0ustar00metameta000000 000000 ; ;Copyright 2016 Jay Sorg ; ;Permission to use, copy, modify, distribute, and sell this software and its ;documentation for any purpose is hereby granted without fee, provided that ;the above copyright notice appear in all copies and that both that ;copyright notice and this permission notice appear in supporting ;documentation. ; ;The above copyright notice and this permission notice shall be included in ;all copies or substantial portions of the Software. ; ;THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR ;IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, ;FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE ;OPEN GROUP BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN ;AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN ;CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. ; ;amd64 asm dwt %include "common.asm" PREPARE_RODATA cw128 times 8 dw 128 cdFFFF times 4 dd 65535 ; these are 1 << (factor - 1) 0 to 15 is factor cwa0 times 8 dw 0 ; 0 cwa1 times 8 dw 1 ; 1 cwa2 times 8 dw 2 ; 2 cwa4 times 8 dw 4 ; 3 cwa8 times 8 dw 8 ; 4 cwa16 times 8 dw 16 ; 5 cwa32 times 8 dw 32 ; 6 cwa64 times 8 dw 64 ; 7 cwa128 times 8 dw 128 ; 8 cwa256 times 8 dw 256 ; 9 cwa512 times 8 dw 512 ; 10 cwa1024 times 8 dw 1024 ; 11 cwa2048 times 8 dw 2048 ; 12 cwa4096 times 8 dw 4096 ; 13 cwa8192 times 8 dw 8192 ; 14 cwa16384 times 8 dw 16384 ; 15 ;****************************************************************************** ; source 16 bit signed, 16 pixel width rfx_dwt_2d_encode_block_horiz_16_16: mov ecx, 8 loop1a: ; pre / post movdqa xmm1, [rsi] ; src[2n] movdqa xmm2, [rsi + 16] movdqa xmm6, xmm1 movdqa xmm7, xmm2 pand xmm1, [lsym(cdFFFF)] pand xmm2, [lsym(cdFFFF)] pslld xmm1, 16 pslld xmm2, 16 psrad xmm1, 16 psrad xmm2, 16 packssdw xmm1, xmm2 movdqa xmm2, xmm6 ; src[2n + 1] movdqa xmm3, xmm7 psrldq xmm2, 2 psrldq xmm3, 2 pand xmm2, [lsym(cdFFFF)] pand xmm3, [lsym(cdFFFF)] pslld xmm2, 16 pslld xmm3, 16 psrad xmm2, 16 psrad xmm3, 16 packssdw xmm2, xmm3 movdqa xmm3, xmm6 ; src[2n + 2] movdqa xmm4, xmm7 psrldq xmm3, 4 psrldq xmm4, 4 movd eax, xmm7 movd xmm5, eax pslldq xmm5, 12 por xmm3, xmm5 movdqa xmm5, xmm7 psrldq xmm5, 12 pslldq xmm5, 12 por xmm4, xmm5 pand xmm3, [lsym(cdFFFF)] pand xmm4, [lsym(cdFFFF)] pslld xmm3, 16 pslld xmm4, 16 psrad xmm3, 16 psrad xmm4, 16 packssdw xmm3, xmm4 movdqa xmm4, xmm1 movdqa xmm5, xmm2 movdqa xmm6, xmm3 ; h[n] = (src[2n + 1] - ((src[2n] + src[2n + 2]) >> 1)) >> 1 paddw xmm4, xmm6 psraw xmm4, 1 psubw xmm5, xmm4 psraw xmm5, 1 movdqa xmm6, xmm5 ; out hi paddw xmm6, xmm8 psraw xmm6, xmm9 movdqa [rdi], xmm6 ; l[n] = src[2n] + ((h[n - 1] + h[n]) >> 1) movdqa xmm7, xmm5 movd eax, xmm7 pslldq xmm7, 2 and eax, 0xFFFF movd xmm6, eax por xmm7, xmm6 paddw xmm5, xmm7 psraw xmm5, 1 paddw xmm5, xmm1 movdqa xmm6, xmm5 ; out lo paddw xmm6, xmm10 psraw xmm6, xmm11 movdqa [rdx], xmm6 ; move right lea rsi, [rsi + 16 * 2] lea rdi, [rdi + 8 * 2] lea rdx, [rdx + 8 * 2] ; move left lea rsi, [rsi - 16 * 2] lea rdi, [rdi - 8 * 2] lea rdx, [rdx - 8 * 2] ; move down lea rsi, [rsi + 16 * 2] lea rdi, [rdi + 8 * 2] lea rdx, [rdx + 8 * 2] dec ecx jnz loop1a ret ;****************************************************************************** ; source 16 bit signed, 16 pixel width rfx_dwt_2d_encode_block_verti_16_16: mov ecx, 2 loop1b: ; pre movdqa xmm1, [rsi] ; src[2n] movdqa xmm2, [rsi + 16 * 2] ; src[2n + 1] movdqa xmm3, [rsi + 16 * 2 * 2] ; src[2n + 2] movdqa xmm4, xmm1 movdqa xmm5, xmm2 movdqa xmm6, xmm3 ; h[n] = (src[2n + 1] - ((src[2n] + src[2n + 2]) >> 1)) >> 1 paddw xmm4, xmm6 psraw xmm4, 1 psubw xmm5, xmm4 psraw xmm5, 1 movdqa [rdi], xmm5 ; out hi movdqa xmm6, xmm5 ; save hi ; l[n] = src[2n] + ((h[n - 1] + h[n]) >> 1) paddw xmm5, xmm1 movdqa [rdx], xmm5 ; out lo movdqa xmm7, xmm6 ; save hi ; move down lea rsi, [rsi + 16 * 2 * 2] ; 2 rows lea rdi, [rdi + 16 * 2] ; 1 row lea rdx, [rdx + 16 * 2] ; 1 row ; loop shl ecx, 16 mov cx, 6 loop2b: movdqa xmm1, xmm3 ; src[2n] movdqa xmm2, [rsi + 16 * 2] ; src[2n + 1] movdqa xmm3, [rsi + 16 * 2 * 2] ; src[2n + 2] movdqa xmm4, xmm1 movdqa xmm5, xmm2 movdqa xmm6, xmm3 ; h[n] = (src[2n + 1] - ((src[2n] + src[2n + 2]) >> 1)) >> 1 paddw xmm4, xmm6 psraw xmm4, 1 psubw xmm5, xmm4 psraw xmm5, 1 movdqa [rdi], xmm5 ; out hi movdqa xmm6, xmm5 ; save hi ; l[n] = src[2n] + ((h[n - 1] + h[n]) >> 1) paddw xmm5, xmm7 psraw xmm5, 1 paddw xmm5, xmm1 movdqa [rdx], xmm5 ; out lo movdqa xmm7, xmm6 ; save hi ; move down lea rsi, [rsi + 16 * 2 * 2] ; 2 rows lea rdi, [rdi + 16 * 2] ; 1 row lea rdx, [rdx + 16 * 2] ; 1 row dec cx jnz loop2b shr ecx, 16 ; post movdqa xmm1, xmm3 ; src[2n] movdqa xmm2, [rsi + 16 * 2] ; src[2n + 1] movdqa xmm4, xmm1 movdqa xmm5, xmm2 movdqa xmm6, xmm3 ; h[n] = (src[2n + 1] - ((src[2n] + src[2n + 2]) >> 1)) >> 1 paddw xmm4, xmm6 psraw xmm4, 1 psubw xmm5, xmm4 psraw xmm5, 1 movdqa [rdi], xmm5 ; out hi ; l[n] = src[2n] + ((h[n - 1] + h[n]) >> 1) paddw xmm5, xmm7 psraw xmm5, 1 paddw xmm5, xmm1 movdqa [rdx], xmm5 ; out lo ; move down lea rsi, [rsi + 16 * 2 * 2] ; 2 row lea rdi, [rdi + 16 * 2] ; 1 row lea rdx, [rdx + 16 * 2] ; 1 row ; move up lea rsi, [rsi - 16 * 16 * 2] lea rdi, [rdi - 8 * 16 * 2] lea rdx, [rdx - 8 * 16 * 2] ; move right lea rsi, [rsi + 16] lea rdi, [rdi + 16] lea rdx, [rdx + 16] dec ecx jnz loop1b ret ;****************************************************************************** ; source 16 bit signed, 32 pixel width rfx_dwt_2d_encode_block_horiz_16_32: mov ecx, 16 loop1c: ; pre movdqa xmm1, [rsi] ; src[2n] movdqa xmm2, [rsi + 16] movdqa xmm6, xmm1 movdqa xmm7, xmm2 pand xmm1, [lsym(cdFFFF)] pand xmm2, [lsym(cdFFFF)] pslld xmm1, 16 pslld xmm2, 16 psrad xmm1, 16 psrad xmm2, 16 packssdw xmm1, xmm2 movdqa xmm2, xmm6 ; src[2n + 1] movdqa xmm3, xmm7 psrldq xmm2, 2 psrldq xmm3, 2 pand xmm2, [lsym(cdFFFF)] pand xmm3, [lsym(cdFFFF)] pslld xmm2, 16 pslld xmm3, 16 psrad xmm2, 16 psrad xmm3, 16 packssdw xmm2, xmm3 movdqa xmm3, xmm6 ; src[2n + 2] movdqa xmm4, xmm7 psrldq xmm3, 4 psrldq xmm4, 4 movd eax, xmm7 movd xmm5, eax pslldq xmm5, 12 por xmm3, xmm5 mov eax, [rsi + 32] movd xmm5, eax pslldq xmm5, 12 por xmm4, xmm5 pand xmm3, [lsym(cdFFFF)] pand xmm4, [lsym(cdFFFF)] pslld xmm3, 16 pslld xmm4, 16 psrad xmm3, 16 psrad xmm4, 16 packssdw xmm3, xmm4 movdqa xmm4, xmm1 movdqa xmm5, xmm2 movdqa xmm6, xmm3 ; h[n] = (src[2n + 1] - ((src[2n] + src[2n + 2]) >> 1)) >> 1 paddw xmm4, xmm6 psraw xmm4, 1 psubw xmm5, xmm4 psraw xmm5, 1 movdqa xmm6, xmm5 ; out hi paddw xmm6, xmm8 psraw xmm6, xmm9 movdqa [rdi], xmm6 movdqa xmm2, xmm5 ; save hi ; l[n] = src[2n] + ((h[n - 1] + h[n]) >> 1) movdqa xmm7, xmm5 movd eax, xmm7 pslldq xmm7, 2 and eax, 0xFFFF movd xmm6, eax por xmm7, xmm6 paddw xmm5, xmm7 psraw xmm5, 1 paddw xmm5, xmm1 psrldq xmm2, 14 movd ebx, xmm2 ; save hi movdqa xmm6, xmm5 ; out lo paddw xmm6, xmm10 psraw xmm6, xmm11 movdqa [rdx], xmm6 ; move right lea rsi, [rsi + 16 * 2] lea rdi, [rdi + 8 * 2] lea rdx, [rdx + 8 * 2] ; post movdqa xmm1, [rsi] ; src[2n] movdqa xmm2, [rsi + 16] movdqa xmm6, xmm1 movdqa xmm7, xmm2 pand xmm1, [lsym(cdFFFF)] pand xmm2, [lsym(cdFFFF)] pslld xmm1, 16 pslld xmm2, 16 psrad xmm1, 16 psrad xmm2, 16 packssdw xmm1, xmm2 movdqa xmm2, xmm6 ; src[2n + 1] movdqa xmm3, xmm7 psrldq xmm2, 2 psrldq xmm3, 2 pand xmm2, [lsym(cdFFFF)] pand xmm3, [lsym(cdFFFF)] pslld xmm2, 16 pslld xmm3, 16 psrad xmm2, 16 psrad xmm3, 16 packssdw xmm2, xmm3 movdqa xmm3, xmm6 ; src[2n + 2] movdqa xmm4, xmm7 psrldq xmm3, 4 psrldq xmm4, 4 movd eax, xmm7 movd xmm5, eax pslldq xmm5, 12 por xmm3, xmm5 movdqa xmm5, xmm7 psrldq xmm5, 12 pslldq xmm5, 12 por xmm4, xmm5 pand xmm3, [lsym(cdFFFF)] pand xmm4, [lsym(cdFFFF)] pslld xmm3, 16 pslld xmm4, 16 psrad xmm3, 16 psrad xmm4, 16 packssdw xmm3, xmm4 movdqa xmm4, xmm1 movdqa xmm5, xmm2 movdqa xmm6, xmm3 ; h[n] = (src[2n + 1] - ((src[2n] + src[2n + 2]) >> 1)) >> 1 paddw xmm4, xmm6 psraw xmm4, 1 psubw xmm5, xmm4 psraw xmm5, 1 movdqa xmm6, xmm5 ; out hi paddw xmm6, xmm8 psraw xmm6, xmm9 movdqa [rdi], xmm6 ; l[n] = src[2n] + ((h[n - 1] + h[n]) >> 1) movdqa xmm7, xmm5 pslldq xmm7, 2 movd xmm6, ebx por xmm7, xmm6 paddw xmm5, xmm7 psraw xmm5, 1 paddw xmm5, xmm1 movdqa xmm6, xmm5 ; out lo paddw xmm6, xmm10 psraw xmm6, xmm11 movdqa [rdx], xmm6 ; move right lea rsi, [rsi + 16 * 2] lea rdi, [rdi + 8 * 2] lea rdx, [rdx + 8 * 2] ; move left lea rsi, [rsi - 32 * 2] lea rdi, [rdi - 16 * 2] lea rdx, [rdx - 16 * 2] ; move down lea rsi, [rsi + 32 * 2] lea rdi, [rdi + 16 * 2] lea rdx, [rdx + 16 * 2] dec ecx jnz loop1c ret ;****************************************************************************** ; source 16 bit signed, 32 pixel width rfx_dwt_2d_encode_block_horiz_16_32_no_lo: mov ecx, 16 loop1c1: ; pre movdqa xmm1, [rsi] ; src[2n] movdqa xmm2, [rsi + 16] movdqa xmm6, xmm1 movdqa xmm7, xmm2 pand xmm1, [lsym(cdFFFF)] pand xmm2, [lsym(cdFFFF)] pslld xmm1, 16 pslld xmm2, 16 psrad xmm1, 16 psrad xmm2, 16 packssdw xmm1, xmm2 movdqa xmm2, xmm6 ; src[2n + 1] movdqa xmm3, xmm7 psrldq xmm2, 2 psrldq xmm3, 2 pand xmm2, [lsym(cdFFFF)] pand xmm3, [lsym(cdFFFF)] pslld xmm2, 16 pslld xmm3, 16 psrad xmm2, 16 psrad xmm3, 16 packssdw xmm2, xmm3 movdqa xmm3, xmm6 ; src[2n + 2] movdqa xmm4, xmm7 psrldq xmm3, 4 psrldq xmm4, 4 movd eax, xmm7 movd xmm5, eax pslldq xmm5, 12 por xmm3, xmm5 mov eax, [rsi + 32] movd xmm5, eax pslldq xmm5, 12 por xmm4, xmm5 pand xmm3, [lsym(cdFFFF)] pand xmm4, [lsym(cdFFFF)] pslld xmm3, 16 pslld xmm4, 16 psrad xmm3, 16 psrad xmm4, 16 packssdw xmm3, xmm4 movdqa xmm4, xmm1 movdqa xmm5, xmm2 movdqa xmm6, xmm3 ; h[n] = (src[2n + 1] - ((src[2n] + src[2n + 2]) >> 1)) >> 1 paddw xmm4, xmm6 psraw xmm4, 1 psubw xmm5, xmm4 psraw xmm5, 1 movdqa xmm6, xmm5 ; out hi paddw xmm6, xmm8 psraw xmm6, xmm9 movdqa [rdi], xmm6 movdqa xmm2, xmm5 ; save hi ; l[n] = src[2n] + ((h[n - 1] + h[n]) >> 1) movdqa xmm7, xmm5 movd eax, xmm7 pslldq xmm7, 2 and eax, 0xFFFF movd xmm6, eax por xmm7, xmm6 paddw xmm5, xmm7 psraw xmm5, 1 paddw xmm5, xmm1 psrldq xmm2, 14 movd ebx, xmm2 ; save hi movdqa [rdx], xmm5 ; out lo ; move right lea rsi, [rsi + 16 * 2] lea rdi, [rdi + 8 * 2] lea rdx, [rdx + 8 * 2] ; post movdqa xmm1, [rsi] ; src[2n] movdqa xmm2, [rsi + 16] movdqa xmm6, xmm1 movdqa xmm7, xmm2 pand xmm1, [lsym(cdFFFF)] pand xmm2, [lsym(cdFFFF)] pslld xmm1, 16 pslld xmm2, 16 psrad xmm1, 16 psrad xmm2, 16 packssdw xmm1, xmm2 movdqa xmm2, xmm6 ; src[2n + 1] movdqa xmm3, xmm7 psrldq xmm2, 2 psrldq xmm3, 2 pand xmm2, [lsym(cdFFFF)] pand xmm3, [lsym(cdFFFF)] pslld xmm2, 16 pslld xmm3, 16 psrad xmm2, 16 psrad xmm3, 16 packssdw xmm2, xmm3 movdqa xmm3, xmm6 ; src[2n + 2] movdqa xmm4, xmm7 psrldq xmm3, 4 psrldq xmm4, 4 movd eax, xmm7 movd xmm5, eax pslldq xmm5, 12 por xmm3, xmm5 movdqa xmm5, xmm7 psrldq xmm5, 12 pslldq xmm5, 12 por xmm4, xmm5 pand xmm3, [lsym(cdFFFF)] pand xmm4, [lsym(cdFFFF)] pslld xmm3, 16 pslld xmm4, 16 psrad xmm3, 16 psrad xmm4, 16 packssdw xmm3, xmm4 movdqa xmm4, xmm1 movdqa xmm5, xmm2 movdqa xmm6, xmm3 ; h[n] = (src[2n + 1] - ((src[2n] + src[2n + 2]) >> 1)) >> 1 paddw xmm4, xmm6 psraw xmm4, 1 psubw xmm5, xmm4 psraw xmm5, 1 movdqa xmm6, xmm5 ; out hi paddw xmm6, xmm8 psraw xmm6, xmm9 movdqa [rdi], xmm6 ; l[n] = src[2n] + ((h[n - 1] + h[n]) >> 1) movdqa xmm7, xmm5 pslldq xmm7, 2 movd xmm6, ebx por xmm7, xmm6 paddw xmm5, xmm7 psraw xmm5, 1 paddw xmm5, xmm1 movdqa [rdx], xmm5 ; out lo ; move right lea rsi, [rsi + 16 * 2] lea rdi, [rdi + 8 * 2] lea rdx, [rdx + 8 * 2] ; move left lea rsi, [rsi - 32 * 2] lea rdi, [rdi - 16 * 2] lea rdx, [rdx - 16 * 2] ; move down lea rsi, [rsi + 32 * 2] lea rdi, [rdi + 16 * 2] lea rdx, [rdx + 16 * 2] dec ecx jnz loop1c1 ret ;****************************************************************************** ; source 16 bit signed, 32 pixel width rfx_dwt_2d_encode_block_verti_16_32: mov ecx, 4 loop1d: ; pre movdqa xmm1, [rsi] ; src[2n] movdqa xmm2, [rsi + 32 * 2] ; src[2n + 1] movdqa xmm3, [rsi + 32 * 2 * 2] ; src[2n + 2] movdqa xmm4, xmm1 movdqa xmm5, xmm2 movdqa xmm6, xmm3 ; h[n] = (src[2n + 1] - ((src[2n] + src[2n + 2]) >> 1)) >> 1 paddw xmm4, xmm6 psraw xmm4, 1 psubw xmm5, xmm4 psraw xmm5, 1 movdqa [rdi], xmm5 ; out hi movdqa xmm6, xmm5 ; save hi ; l[n] = src[2n] + ((h[n - 1] + h[n]) >> 1) paddw xmm5, xmm1 movdqa [rdx], xmm5 ; out lo movdqa xmm7, xmm6 ; save hi ; move down lea rsi, [rsi + 32 * 2 * 2] ; 2 rows lea rdi, [rdi + 32 * 2] ; 1 row lea rdx, [rdx + 32 * 2] ; 1 row ; loop shl ecx, 16 mov cx, 14 loop2d: movdqa xmm1, xmm3 ; src[2n] movdqa xmm2, [rsi + 32 * 2] ; src[2n + 1] movdqa xmm3, [rsi + 32 * 2 * 2] ; src[2n + 2] movdqa xmm4, xmm1 movdqa xmm5, xmm2 movdqa xmm6, xmm3 ; h[n] = (src[2n + 1] - ((src[2n] + src[2n + 2]) >> 1)) >> 1 paddw xmm4, xmm6 psraw xmm4, 1 psubw xmm5, xmm4 psraw xmm5, 1 movdqa [rdi], xmm5 ; out hi movdqa xmm6, xmm5 ; save hi ; l[n] = src[2n] + ((h[n - 1] + h[n]) >> 1) paddw xmm5, xmm7 psraw xmm5, 1 paddw xmm5, xmm1 movdqa [rdx], xmm5 ; out lo movdqa xmm7, xmm6 ; save hi ; move down lea rsi, [rsi + 32 * 2 * 2] ; 2 rows lea rdi, [rdi + 32 * 2] ; 1 row lea rdx, [rdx + 32 * 2] ; 1 row dec cx jnz loop2d shr ecx, 16 ; post movdqa xmm1, xmm3 ; src[2n] movdqa xmm2, [rsi + 32 * 2] ; src[2n + 1] movdqa xmm4, xmm1 movdqa xmm5, xmm2 movdqa xmm6, xmm3 ; h[n] = (src[2n + 1] - ((src[2n] + src[2n + 2]) >> 1)) >> 1 paddw xmm4, xmm6 psraw xmm4, 1 psubw xmm5, xmm4 psraw xmm5, 1 movdqa [rdi], xmm5 ; out hi ; l[n] = src[2n] + ((h[n - 1] + h[n]) >> 1) paddw xmm5, xmm7 psraw xmm5, 1 paddw xmm5, xmm1 movdqa [rdx], xmm5 ; out lo ; move down lea rsi, [rsi + 32 * 2 * 2] ; 2 row lea rdi, [rdi + 32 * 2] ; 1 row lea rdx, [rdx + 32 * 2] ; 1 row ; move up lea rsi, [rsi - 32 * 32 * 2] lea rdi, [rdi - 16 * 32 * 2] lea rdx, [rdx - 16 * 32 * 2] ; move right lea rsi, [rsi + 16] lea rdi, [rdi + 16] lea rdx, [rdx + 16] dec ecx jnz loop1d ret ;****************************************************************************** ; source 16 bit signed, 64 pixel width rfx_dwt_2d_encode_block_horiz_16_64: mov ecx, 32 loop1e: ; pre movdqa xmm1, [rsi] ; src[2n] movdqa xmm2, [rsi + 16] movdqa xmm6, xmm1 movdqa xmm7, xmm2 pand xmm1, [lsym(cdFFFF)] pand xmm2, [lsym(cdFFFF)] pslld xmm1, 16 pslld xmm2, 16 psrad xmm1, 16 psrad xmm2, 16 packssdw xmm1, xmm2 movdqa xmm2, xmm6 ; src[2n + 1] movdqa xmm3, xmm7 psrldq xmm2, 2 psrldq xmm3, 2 pand xmm2, [lsym(cdFFFF)] pand xmm3, [lsym(cdFFFF)] pslld xmm2, 16 pslld xmm3, 16 psrad xmm2, 16 psrad xmm3, 16 packssdw xmm2, xmm3 movdqa xmm3, xmm6 ; src[2n + 2] movdqa xmm4, xmm7 psrldq xmm3, 4 psrldq xmm4, 4 movd eax, xmm7 movd xmm5, eax pslldq xmm5, 12 por xmm3, xmm5 mov eax, [rsi + 32] movd xmm5, eax pslldq xmm5, 12 por xmm4, xmm5 pand xmm3, [lsym(cdFFFF)] pand xmm4, [lsym(cdFFFF)] pslld xmm3, 16 pslld xmm4, 16 psrad xmm3, 16 psrad xmm4, 16 packssdw xmm3, xmm4 movdqa xmm4, xmm1 movdqa xmm5, xmm2 movdqa xmm6, xmm3 ; h[n] = (src[2n + 1] - ((src[2n] + src[2n + 2]) >> 1)) >> 1 paddw xmm4, xmm6 psraw xmm4, 1 psubw xmm5, xmm4 psraw xmm5, 1 movdqa xmm6, xmm5 ; out hi paddw xmm6, xmm8 psraw xmm6, xmm9 movdqa [rdi], xmm6 movdqa xmm2, xmm5 ; save hi ; l[n] = src[2n] + ((h[n - 1] + h[n]) >> 1) movdqa xmm7, xmm5 movd eax, xmm7 pslldq xmm7, 2 and eax, 0xFFFF movd xmm6, eax por xmm7, xmm6 paddw xmm5, xmm7 psraw xmm5, 1 paddw xmm5, xmm1 psrldq xmm2, 14 movd ebx, xmm2 ; save hi movdqa xmm6, xmm5 ; out lo paddw xmm6, xmm10 psraw xmm6, xmm11 movdqa [rdx], xmm6 ; move right lea rsi, [rsi + 16 * 2] lea rdi, [rdi + 8 * 2] lea rdx, [rdx + 8 * 2] ; loop shl ecx, 16 mov cx, 2 loop2e: movdqa xmm1, [rsi] ; src[2n] movdqa xmm2, [rsi + 16] movdqa xmm6, xmm1 movdqa xmm7, xmm2 pand xmm1, [lsym(cdFFFF)] pand xmm2, [lsym(cdFFFF)] pslld xmm1, 16 pslld xmm2, 16 psrad xmm1, 16 psrad xmm2, 16 packssdw xmm1, xmm2 movdqa xmm2, xmm6 ; src[2n + 1] movdqa xmm3, xmm7 psrldq xmm2, 2 psrldq xmm3, 2 pand xmm2, [lsym(cdFFFF)] pand xmm3, [lsym(cdFFFF)] pslld xmm2, 16 pslld xmm3, 16 psrad xmm2, 16 psrad xmm3, 16 packssdw xmm2, xmm3 movdqa xmm3, xmm6 ; src[2n + 2] movdqa xmm4, xmm7 psrldq xmm3, 4 psrldq xmm4, 4 movd eax, xmm7 movd xmm5, eax pslldq xmm5, 12 por xmm3, xmm5 mov eax, [rsi + 32] movd xmm5, eax pslldq xmm5, 12 por xmm4, xmm5 pand xmm3, [lsym(cdFFFF)] pand xmm4, [lsym(cdFFFF)] pslld xmm3, 16 pslld xmm4, 16 psrad xmm3, 16 psrad xmm4, 16 packssdw xmm3, xmm4 movdqa xmm4, xmm1 movdqa xmm5, xmm2 movdqa xmm6, xmm3 ; h[n] = (src[2n + 1] - ((src[2n] + src[2n + 2]) >> 1)) >> 1 paddw xmm4, xmm6 psraw xmm4, 1 psubw xmm5, xmm4 psraw xmm5, 1 movdqa xmm6, xmm5 ; out hi paddw xmm6, xmm8 psraw xmm6, xmm9 movdqa [rdi], xmm6 movdqa xmm2, xmm5 ; save hi ; l[n] = src[2n] + ((h[n - 1] + h[n]) >> 1) movdqa xmm7, xmm5 pslldq xmm7, 2 movd xmm6, ebx por xmm7, xmm6 paddw xmm5, xmm7 psraw xmm5, 1 paddw xmm5, xmm1 psrldq xmm2, 14 movd ebx, xmm2 ; save hi movdqa xmm6, xmm5 ; out lo paddw xmm6, xmm10 psraw xmm6, xmm11 movdqa [rdx], xmm6 ; move right lea rsi, [rsi + 16 * 2] lea rdi, [rdi + 8 * 2] lea rdx, [rdx + 8 * 2] dec cx jnz loop2e shr ecx, 16 ; post movdqa xmm1, [rsi] ; src[2n] movdqa xmm2, [rsi + 16] movdqa xmm6, xmm1 movdqa xmm7, xmm2 pand xmm1, [lsym(cdFFFF)] pand xmm2, [lsym(cdFFFF)] pslld xmm1, 16 pslld xmm2, 16 psrad xmm1, 16 psrad xmm2, 16 packssdw xmm1, xmm2 movdqa xmm2, xmm6 ; src[2n + 1] movdqa xmm3, xmm7 psrldq xmm2, 2 psrldq xmm3, 2 pand xmm2, [lsym(cdFFFF)] pand xmm3, [lsym(cdFFFF)] pslld xmm2, 16 pslld xmm3, 16 psrad xmm2, 16 psrad xmm3, 16 packssdw xmm2, xmm3 movdqa xmm3, xmm6 ; src[2n + 2] movdqa xmm4, xmm7 psrldq xmm3, 4 psrldq xmm4, 4 movd eax, xmm7 movd xmm5, eax pslldq xmm5, 12 por xmm3, xmm5 movdqa xmm5, xmm7 psrldq xmm5, 12 pslldq xmm5, 12 por xmm4, xmm5 pand xmm3, [lsym(cdFFFF)] pand xmm4, [lsym(cdFFFF)] pslld xmm3, 16 pslld xmm4, 16 psrad xmm3, 16 psrad xmm4, 16 packssdw xmm3, xmm4 movdqa xmm4, xmm1 movdqa xmm5, xmm2 movdqa xmm6, xmm3 ; h[n] = (src[2n + 1] - ((src[2n] + src[2n + 2]) >> 1)) >> 1 paddw xmm4, xmm6 psraw xmm4, 1 psubw xmm5, xmm4 psraw xmm5, 1 movdqa xmm6, xmm5 ; out hi paddw xmm6, xmm8 psraw xmm6, xmm9 movdqa [rdi], xmm6 ; l[n] = src[2n] + ((h[n - 1] + h[n]) >> 1) movdqa xmm7, xmm5 pslldq xmm7, 2 movd xmm6, ebx por xmm7, xmm6 paddw xmm5, xmm7 psraw xmm5, 1 paddw xmm5, xmm1 movdqa xmm6, xmm5 ; out lo paddw xmm6, xmm10 psraw xmm6, xmm11 movdqa [rdx], xmm6 ; move right lea rsi, [rsi + 16 * 2] lea rdi, [rdi + 8 * 2] lea rdx, [rdx + 8 * 2] ; move left lea rsi, [rsi - 64 * 2] lea rdi, [rdi - 32 * 2] lea rdx, [rdx - 32 * 2] ; move down lea rsi, [rsi + 64 * 2] lea rdi, [rdi + 32 * 2] lea rdx, [rdx + 32 * 2] dec ecx jnz loop1e ret ;****************************************************************************** ; source 16 bit signed, 64 pixel width rfx_dwt_2d_encode_block_horiz_16_64_no_lo: mov ecx, 32 loop1e1: ; pre movdqa xmm1, [rsi] ; src[2n] movdqa xmm2, [rsi + 16] movdqa xmm6, xmm1 movdqa xmm7, xmm2 pand xmm1, [lsym(cdFFFF)] pand xmm2, [lsym(cdFFFF)] pslld xmm1, 16 pslld xmm2, 16 psrad xmm1, 16 psrad xmm2, 16 packssdw xmm1, xmm2 movdqa xmm2, xmm6 ; src[2n + 1] movdqa xmm3, xmm7 psrldq xmm2, 2 psrldq xmm3, 2 pand xmm2, [lsym(cdFFFF)] pand xmm3, [lsym(cdFFFF)] pslld xmm2, 16 pslld xmm3, 16 psrad xmm2, 16 psrad xmm3, 16 packssdw xmm2, xmm3 movdqa xmm3, xmm6 ; src[2n + 2] movdqa xmm4, xmm7 psrldq xmm3, 4 psrldq xmm4, 4 movd eax, xmm7 movd xmm5, eax pslldq xmm5, 12 por xmm3, xmm5 mov eax, [rsi + 32] movd xmm5, eax pslldq xmm5, 12 por xmm4, xmm5 pand xmm3, [lsym(cdFFFF)] pand xmm4, [lsym(cdFFFF)] pslld xmm3, 16 pslld xmm4, 16 psrad xmm3, 16 psrad xmm4, 16 packssdw xmm3, xmm4 movdqa xmm4, xmm1 movdqa xmm5, xmm2 movdqa xmm6, xmm3 ; h[n] = (src[2n + 1] - ((src[2n] + src[2n + 2]) >> 1)) >> 1 paddw xmm4, xmm6 psraw xmm4, 1 psubw xmm5, xmm4 psraw xmm5, 1 movdqa xmm6, xmm5 ; out hi paddw xmm6, xmm8 psraw xmm6, xmm9 movdqa [rdi], xmm6 movdqa xmm2, xmm5 ; save hi ; l[n] = src[2n] + ((h[n - 1] + h[n]) >> 1) movdqa xmm7, xmm5 movd eax, xmm7 pslldq xmm7, 2 and eax, 0xFFFF movd xmm6, eax por xmm7, xmm6 paddw xmm5, xmm7 psraw xmm5, 1 paddw xmm5, xmm1 psrldq xmm2, 14 movd ebx, xmm2 ; save hi movdqa [rdx], xmm5 ; out lo ; move right lea rsi, [rsi + 16 * 2] lea rdi, [rdi + 8 * 2] lea rdx, [rdx + 8 * 2] ; loop shl ecx, 16 mov cx, 2 loop2e1: movdqa xmm1, [rsi] ; src[2n] movdqa xmm2, [rsi + 16] movdqa xmm6, xmm1 movdqa xmm7, xmm2 pand xmm1, [lsym(cdFFFF)] pand xmm2, [lsym(cdFFFF)] pslld xmm1, 16 pslld xmm2, 16 psrad xmm1, 16 psrad xmm2, 16 packssdw xmm1, xmm2 movdqa xmm2, xmm6 ; src[2n + 1] movdqa xmm3, xmm7 psrldq xmm2, 2 psrldq xmm3, 2 pand xmm2, [lsym(cdFFFF)] pand xmm3, [lsym(cdFFFF)] pslld xmm2, 16 pslld xmm3, 16 psrad xmm2, 16 psrad xmm3, 16 packssdw xmm2, xmm3 movdqa xmm3, xmm6 ; src[2n + 2] movdqa xmm4, xmm7 psrldq xmm3, 4 psrldq xmm4, 4 movd eax, xmm7 movd xmm5, eax pslldq xmm5, 12 por xmm3, xmm5 mov eax, [rsi + 32] movd xmm5, eax pslldq xmm5, 12 por xmm4, xmm5 pand xmm3, [lsym(cdFFFF)] pand xmm4, [lsym(cdFFFF)] pslld xmm3, 16 pslld xmm4, 16 psrad xmm3, 16 psrad xmm4, 16 packssdw xmm3, xmm4 movdqa xmm4, xmm1 movdqa xmm5, xmm2 movdqa xmm6, xmm3 ; h[n] = (src[2n + 1] - ((src[2n] + src[2n + 2]) >> 1)) >> 1 paddw xmm4, xmm6 psraw xmm4, 1 psubw xmm5, xmm4 psraw xmm5, 1 movdqa xmm6, xmm5 ; out hi paddw xmm6, xmm8 psraw xmm6, xmm9 movdqa [rdi], xmm6 movdqa xmm2, xmm5 ; save hi ; l[n] = src[2n] + ((h[n - 1] + h[n]) >> 1) movdqa xmm7, xmm5 pslldq xmm7, 2 movd xmm6, ebx por xmm7, xmm6 paddw xmm5, xmm7 psraw xmm5, 1 paddw xmm5, xmm1 psrldq xmm2, 14 movd ebx, xmm2 ; save hi movdqa [rdx], xmm5 ; out lo ; move right lea rsi, [rsi + 16 * 2] lea rdi, [rdi + 8 * 2] lea rdx, [rdx + 8 * 2] dec cx jnz loop2e1 shr ecx, 16 ; post movdqa xmm1, [rsi] ; src[2n] movdqa xmm2, [rsi + 16] movdqa xmm6, xmm1 movdqa xmm7, xmm2 pand xmm1, [lsym(cdFFFF)] pand xmm2, [lsym(cdFFFF)] pslld xmm1, 16 pslld xmm2, 16 psrad xmm1, 16 psrad xmm2, 16 packssdw xmm1, xmm2 movdqa xmm2, xmm6 ; src[2n + 1] movdqa xmm3, xmm7 psrldq xmm2, 2 psrldq xmm3, 2 pand xmm2, [lsym(cdFFFF)] pand xmm3, [lsym(cdFFFF)] pslld xmm2, 16 pslld xmm3, 16 psrad xmm2, 16 psrad xmm3, 16 packssdw xmm2, xmm3 movdqa xmm3, xmm6 ; src[2n + 2] movdqa xmm4, xmm7 psrldq xmm3, 4 psrldq xmm4, 4 movd eax, xmm7 movd xmm5, eax pslldq xmm5, 12 por xmm3, xmm5 movdqa xmm5, xmm7 psrldq xmm5, 12 pslldq xmm5, 12 por xmm4, xmm5 pand xmm3, [lsym(cdFFFF)] pand xmm4, [lsym(cdFFFF)] pslld xmm3, 16 pslld xmm4, 16 psrad xmm3, 16 psrad xmm4, 16 packssdw xmm3, xmm4 movdqa xmm4, xmm1 movdqa xmm5, xmm2 movdqa xmm6, xmm3 ; h[n] = (src[2n + 1] - ((src[2n] + src[2n + 2]) >> 1)) >> 1 paddw xmm4, xmm6 psraw xmm4, 1 psubw xmm5, xmm4 psraw xmm5, 1 movdqa xmm6, xmm5 ; out hi paddw xmm6, xmm8 psraw xmm6, xmm9 movdqa [rdi], xmm6 ; l[n] = src[2n] + ((h[n - 1] + h[n]) >> 1) movdqa xmm7, xmm5 pslldq xmm7, 2 movd xmm6, ebx por xmm7, xmm6 paddw xmm5, xmm7 psraw xmm5, 1 paddw xmm5, xmm1 movdqa [rdx], xmm5 ; out lo ; move right lea rsi, [rsi + 16 * 2] lea rdi, [rdi + 8 * 2] lea rdx, [rdx + 8 * 2] ; move left lea rsi, [rsi - 64 * 2] lea rdi, [rdi - 32 * 2] lea rdx, [rdx - 32 * 2] ; move down lea rsi, [rsi + 64 * 2] lea rdi, [rdi + 32 * 2] lea rdx, [rdx + 32 * 2] dec ecx jnz loop1e1 ret ;****************************************************************************** ; source 8 bit unsigned, 64 pixel width rfx_dwt_2d_encode_block_verti_8_64: mov ecx, 8 loop1f: ; pre movq xmm1, [rsi] ; src[2n] movq xmm2, [rsi + 64 * 1] ; src[2n + 1] movq xmm3, [rsi + 64 * 1 * 2] ; src[2n + 2] punpcklbw xmm1, xmm0 punpcklbw xmm2, xmm0 punpcklbw xmm3, xmm0 psubw xmm1, [lsym(cw128)] psubw xmm2, [lsym(cw128)] psubw xmm3, [lsym(cw128)] psllw xmm1, 5 psllw xmm2, 5 psllw xmm3, 5 movdqa xmm4, xmm1 movdqa xmm5, xmm2 movdqa xmm6, xmm3 ; h[n] = (src[2n + 1] - ((src[2n] + src[2n + 2]) >> 1)) >> 1 paddw xmm4, xmm6 psraw xmm4, 1 psubw xmm5, xmm4 psraw xmm5, 1 movdqa [rdi], xmm5 ; out hi movdqa xmm6, xmm5 ; save hi ; l[n] = src[2n] + ((h[n - 1] + h[n]) >> 1) paddw xmm5, xmm1 movdqa [rdx], xmm5 ; out lo movdqa xmm7, xmm6 ; save hi ; move down lea rsi, [rsi + 64 * 1 * 2] ; 2 rows lea rdi, [rdi + 64 * 2] ; 1 row lea rdx, [rdx + 64 * 2] ; 1 row ; loop shl ecx, 16 mov cx, 30 loop2f: movdqa xmm1, xmm3 ; src[2n] movq xmm2, [rsi + 64 * 1] ; src[2n + 1] movq xmm3, [rsi + 64 * 1 * 2] ; src[2n + 2] punpcklbw xmm2, xmm0 punpcklbw xmm3, xmm0 psubw xmm2, [lsym(cw128)] psubw xmm3, [lsym(cw128)] psllw xmm2, 5 psllw xmm3, 5 movdqa xmm4, xmm1 movdqa xmm5, xmm2 movdqa xmm6, xmm3 ; h[n] = (src[2n + 1] - ((src[2n] + src[2n + 2]) >> 1)) >> 1 paddw xmm4, xmm6 psraw xmm4, 1 psubw xmm5, xmm4 psraw xmm5, 1 movdqa [rdi], xmm5 ; out hi movdqa xmm6, xmm5 ; save hi ; l[n] = src[2n] + ((h[n - 1] + h[n]) >> 1) paddw xmm5, xmm7 psraw xmm5, 1 paddw xmm5, xmm1 movdqa [rdx], xmm5 ; out lo movdqa xmm7, xmm6 ; save hi ; move down lea rsi, [rsi + 64 * 1 * 2] ; 2 rows lea rdi, [rdi + 64 * 2] ; 1 row lea rdx, [rdx + 64 * 2] ; 1 row dec cx jnz loop2f shr ecx, 16 ; post movdqa xmm1, xmm3 ; src[2n] movq xmm2, [rsi + 64 * 1] ; src[2n + 1] punpcklbw xmm2, xmm0 psubw xmm2, [lsym(cw128)] psllw xmm2, 5 movdqa xmm4, xmm1 movdqa xmm5, xmm2 movdqa xmm6, xmm3 ; h[n] = (src[2n + 1] - ((src[2n] + src[2n + 2]) >> 1)) >> 1 paddw xmm4, xmm6 psraw xmm4, 1 psubw xmm5, xmm4 psraw xmm5, 1 movdqa [rdi], xmm5 ; out hi ; l[n] = src[2n] + ((h[n - 1] + h[n]) >> 1) paddw xmm5, xmm7 psraw xmm5, 1 paddw xmm5, xmm1 movdqa [rdx], xmm5 ; out lo ; move down lea rsi, [rsi + 64 * 1 * 2] ; 2 rows lea rdi, [rdi + 64 * 2] ; 1 row lea rdx, [rdx + 64 * 2] ; 1 row ; move up lea rsi, [rsi - 64 * 1 * 64] lea rdi, [rdi - 32 * 64 * 2] lea rdx, [rdx - 32 * 64 * 2] ; move right lea rsi, [rsi + 8] lea rdi, [rdi + 16] lea rdx, [rdx + 16] dec ecx jnz loop1f ret set_quants_hi: sub rax, 6 - 5 movd xmm9, eax imul rax, 16 lea rdx, [lsym(cwa0)] add rdx, rax movdqa xmm8, [rdx] ret set_quants_lo: sub rax, 6 - 5 movd xmm11, eax imul rax, 16 lea rdx, [lsym(cwa0)] add rdx, rax movdqa xmm10, [rdx] ret ;The first six integer or pointer arguments are passed in registers ;RDI, RSI, RDX, RCX, R8, and R9 ;int ;rfxcodec_encode_dwt_shift_amd64_sse2(const char *qtable, ; unsigned char *in_buffer, ; short *out_buffer, ; short *work_buffer); ;****************************************************************************** PROC rfxcodec_encode_dwt_shift_amd64_sse2 ; save registers push rbx push rdx push rcx push rsi push rdi pxor xmm0, xmm0 ; verical DWT to work buffer, level 1 mov rsi, [rsp + 8] ; src mov rdi, [rsp + 16] ; dst hi lea rdi, [rdi + 64 * 32 * 2] ; dst hi mov rdx, [rsp + 16] ; dst lo call rfx_dwt_2d_encode_block_verti_8_64 ; horizontal DWT to out buffer, level 1, part 1 xor rax, rax mov rdx, [rsp] mov al, [rdx + 4] and al, 0xF call set_quants_hi mov rsi, [rsp + 16] ; src mov rdi, [rsp + 24] ; dst hi - HL1 mov rdx, [rsp + 24] ; dst lo - LL1 lea rdx, [rdx + 32 * 32 * 6] ; dst lo - LL1 call rfx_dwt_2d_encode_block_horiz_16_64_no_lo ; horizontal DWT to out buffer, level 1, part 2 xor rax, rax mov rdx, [rsp] mov al, [rdx + 4] shr al, 4 call set_quants_hi xor rax, rax mov rdx, [rsp] mov al, [rdx + 3] shr al, 4 call set_quants_lo mov rsi, [rsp + 16] ; src lea rsi, [rsi + 64 * 32 * 2] ; src mov rdi, [rsp + 24] ; dst hi - HH1 lea rdi, [rdi + 32 * 32 * 4] ; dst hi - HH1 mov rdx, [rsp + 24] ; dst lo - LH1 lea rdx, [rdx + 32 * 32 * 2] ; dst lo - LH1 call rfx_dwt_2d_encode_block_horiz_16_64 ; verical DWT to work buffer, level 2 mov rsi, [rsp + 24] ; src lea rsi, [rsi + 32 * 32 * 6] ; src mov rdi, [rsp + 16] ; dst hi lea rdi, [rdi + 32 * 16 * 2] ; dst hi mov rdx, [rsp + 16] ; dst lo call rfx_dwt_2d_encode_block_verti_16_32 ; horizontal DWT to out buffer, level 2, part 1 xor rax, rax mov rdx, [rsp] mov al, [rdx + 2] shr al, 4 call set_quants_hi mov rsi, [rsp + 16] ; src ; 32 * 32 * 6 + 16 * 16 * 0 = 6144 mov rdi, [rsp + 24] ; dst hi - HL2 lea rdi, [rdi + 6144] ; dst hi - HL2 ; 32 * 32 * 6 + 16 * 16 * 6 = 7680 mov rdx, [rsp + 24] ; dst lo - LL2 lea rdx, [rdx + 7680] ; dst lo - LL2 call rfx_dwt_2d_encode_block_horiz_16_32_no_lo ; horizontal DWT to out buffer, level 2, part 2 xor rax, rax mov rdx, [rsp] mov al, [rdx + 3] and al, 0xF call set_quants_hi xor rax, rax mov rdx, [rsp] mov al, [rdx + 2] and al, 0xF call set_quants_lo mov rsi, [rsp + 16] ; src lea rsi, [rsi + 32 * 16 * 2] ; src ; 32 * 32 * 6 + 16 * 16 * 4 = 7168 mov rdi, [rsp + 24] ; dst hi - HH2 lea rdi, [rdi + 7168] ; dst hi - HH2 ; 32 * 32 * 6 + 16 * 16 * 2 = 6656 mov rdx, [rsp + 24] ; dst lo - LH2 lea rdx, [rdx + 6656] ; dst lo - LH2 call rfx_dwt_2d_encode_block_horiz_16_32 ; verical DWT to work buffer, level 3 ; 32 * 32 * 6 + 16 * 16 * 6 = 7680 mov rsi, [rsp + 24] ; src lea rsi, [rsi + 7680] ; src mov rdi, [rsp + 16] ; dst hi lea rdi, [rdi + 16 * 8 * 2] ; dst hi mov rdx, [rsp + 16] ; dst lo call rfx_dwt_2d_encode_block_verti_16_16 ; horizontal DWT to out buffer, level 3, part 1 xor rax, rax mov rdx, [rsp] mov al, [rdx + 1] and al, 0xF call set_quants_hi xor rax, rax mov rdx, [rsp] mov al, [rdx + 0] and al, 0xF call set_quants_lo mov rsi, [rsp + 16] ; src ; 32 * 32 * 6 + 16 * 16 * 6 + 8 * 8 * 0 = 7680 mov rdi, [rsp + 24] ; dst hi - HL3 lea rdi, [rdi + 7680] ; dst hi - HL3 ; 32 * 32 * 6 + 16 * 16 * 6 + 8 * 8 * 6 = 8064 mov rdx, [rsp + 24] ; dst lo - LL3 lea rdx, [rdx + 8064] ; dst lo - LL3 call rfx_dwt_2d_encode_block_horiz_16_16 ; horizontal DWT to out buffer, level 3, part 2 xor rax, rax mov rdx, [rsp] mov al, [rdx + 1] shr al, 4 call set_quants_hi xor rax, rax mov rdx, [rsp] mov al, [rdx + 0] shr al, 4 call set_quants_lo mov rsi, [rsp + 16] ; src lea rsi, [rsi + 16 * 8 * 2] ; src ; 32 * 32 * 6 + 16 * 16 * 6 + 8 * 8 * 4 = 7936 mov rdi, [rsp + 24] ; dst hi - HH3 lea rdi, [rdi + 7936] ; dst hi - HH3 ; 32 * 32 * 6 + 16 * 16 * 6 + 8 * 8 * 2 = 7808 mov rdx, [rsp + 24] ; dst lo - LH3 lea rdx, [rdx + 7808] ; dst lo - LH3 call rfx_dwt_2d_encode_block_horiz_16_16 mov rax, 0 ; restore registers pop rdi pop rsi pop rcx pop rdx pop rbx ret END_OF_FILE xrdp-0.9.5/librfxcodec/src/amd64/Makefile.am000644 001751 001751 00000001172 13162371073 020450 0ustar00metameta000000 000000 NAFLAGS += -DASM_ARCH_AMD64 AMD64_ASM = \ cpuid_amd64.asm \ rfxcodec_encode_dwt_shift_amd64_sse2.asm \ rfxcodec_encode_dwt_shift_amd64_sse41.asm AM_CPPFLAGS = \ -I$(top_srcdir)/include \ -I$(top_srcdir)/src noinst_LTLIBRARIES = librfxencode-amd64.la librfxencode_amd64_la_SOURCES = \ funcs_amd64.h \ rfxencode_tile_amd64.c \ $(AMD64_ASM) nasm_verbose = $(nasm_verbose_@AM_V@) nasm_verbose_ = $(nasm_verbose_@AM_DEFAULT_V@) nasm_verbose_0 = @echo " NASM $@"; .asm.lo: $(nasm_verbose)$(LIBTOOL) $(AM_V_lt) --mode=compile \ $(top_srcdir)/src/nasm_lt.sh $(NASM) $(NAFLAGS) \ -I$(top_srcdir)/src $< -o $@ xrdp-0.9.5/librfxcodec/src/amd64/rfxencode_tile_amd64.c000644 001751 001751 00000007316 13061652764 022562 0ustar00metameta000000 000000 /** * FreeRDP: A Remote Desktop Protocol client. * RemoteFX Codec Library - Encode * * Copyright 2011 Vic Lee * Copyright 2014-2015 Jay Sorg * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ #if defined(HAVE_CONFIG_H) #include #endif #include #include #include #include "rfxcommon.h" #include "rfxencode.h" #include "rfxencode_differential.h" #include "rfxencode_rlgr1.h" #include "rfxencode_rlgr3.h" #include "rfxencode_alpha.h" #include "rfxencode_diff_rlgr1.h" #include "rfxencode_diff_rlgr3.h" #include "amd64/funcs_amd64.h" #define LLOG_LEVEL 1 #define LLOGLN(_level, _args) \ do { if (_level < LLOG_LEVEL) { printf _args ; printf("\n"); } } while (0) /******************************************************************************/ int rfx_encode_component_rlgr1_amd64_sse2(struct rfxencode *enc, const char *qtable, const uint8 *data, uint8 *buffer, int buffer_size, int *size) { LLOGLN(10, ("rfx_encode_component_rlgr1_amd64_sse2:")); if (rfxcodec_encode_dwt_shift_amd64_sse2(qtable, data, enc->dwt_buffer1, enc->dwt_buffer) != 0) { return 1; } *size = rfx_encode_diff_rlgr1(enc->dwt_buffer1, buffer, buffer_size); return 0; } /******************************************************************************/ int rfx_encode_component_rlgr3_amd64_sse2(struct rfxencode *enc, const char *qtable, const uint8 *data, uint8 *buffer, int buffer_size, int *size) { LLOGLN(10, ("rfx_encode_component_rlgr3_amd64_sse2:")); if (rfxcodec_encode_dwt_shift_amd64_sse2(qtable, data, enc->dwt_buffer1, enc->dwt_buffer) != 0) { return 1; } *size = rfx_encode_diff_rlgr3(enc->dwt_buffer1, buffer, buffer_size); return 0; } /******************************************************************************/ int rfx_encode_component_rlgr1_amd64_sse41(struct rfxencode *enc, const char *qtable, const uint8 *data, uint8 *buffer, int buffer_size, int *size) { LLOGLN(10, ("rfx_encode_component_rlgr1_amd64_sse41:")); if (rfxcodec_encode_dwt_shift_amd64_sse41(qtable, data, enc->dwt_buffer1, enc->dwt_buffer) != 0) { return 1; } *size = rfx_encode_diff_rlgr1(enc->dwt_buffer1, buffer, buffer_size); return 0; } /******************************************************************************/ int rfx_encode_component_rlgr3_amd64_sse41(struct rfxencode *enc, const char *qtable, const uint8 *data, uint8 *buffer, int buffer_size, int *size) { LLOGLN(10, ("rfx_encode_component_rlgr3_amd64_sse41:")); if (rfxcodec_encode_dwt_shift_amd64_sse41(qtable, data, enc->dwt_buffer1, enc->dwt_buffer) != 0) { return 1; } *size = rfx_encode_diff_rlgr3(enc->dwt_buffer1, buffer, buffer_size); return 0; } xrdp-0.9.5/librfxcodec/src/amd64/rfxcodec_encode_dwt_shift_amd64_sse41.asm000644 001751 001751 00000105321 13162371073 026316 0ustar00metameta000000 000000 ; ;Copyright 2016 Jay Sorg ; ;Permission to use, copy, modify, distribute, and sell this software and its ;documentation for any purpose is hereby granted without fee, provided that ;the above copyright notice appear in all copies and that both that ;copyright notice and this permission notice appear in supporting ;documentation. ; ;The above copyright notice and this permission notice shall be included in ;all copies or substantial portions of the Software. ; ;THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR ;IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, ;FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE ;OPEN GROUP BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN ;AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN ;CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. ; ;amd64 asm dwt %include "common.asm" PREPARE_RODATA cw128 times 8 dw 128 cdFFFF times 4 dd 65535 ; these are 1 << (factor - 1) 0 to 15 is factor cwa0 times 8 dw 0 ; 0 cwa1 times 8 dw 1 ; 1 cwa2 times 8 dw 2 ; 2 cwa4 times 8 dw 4 ; 3 cwa8 times 8 dw 8 ; 4 cwa16 times 8 dw 16 ; 5 cwa32 times 8 dw 32 ; 6 cwa64 times 8 dw 64 ; 7 cwa128 times 8 dw 128 ; 8 cwa256 times 8 dw 256 ; 9 cwa512 times 8 dw 512 ; 10 cwa1024 times 8 dw 1024 ; 11 cwa2048 times 8 dw 2048 ; 12 cwa4096 times 8 dw 4096 ; 13 cwa8192 times 8 dw 8192 ; 14 cwa16384 times 8 dw 16384 ; 15 ;****************************************************************************** ; source 16 bit signed, 16 pixel width rfx_dwt_2d_encode_block_horiz_16_16: mov ecx, 8 loop1a: ; pre / post movdqa xmm1, [rsi] ; src[2n] movdqa xmm2, [rsi + 16] movdqa xmm6, xmm1 movdqa xmm7, xmm2 pand xmm1, [lsym(cdFFFF)] pand xmm2, [lsym(cdFFFF)] packusdw xmm1, xmm2 movdqa xmm2, xmm6 ; src[2n + 1] movdqa xmm3, xmm7 psrldq xmm2, 2 psrldq xmm3, 2 pand xmm2, [lsym(cdFFFF)] pand xmm3, [lsym(cdFFFF)] packusdw xmm2, xmm3 movdqa xmm3, xmm6 ; src[2n + 2] movdqa xmm4, xmm7 psrldq xmm3, 4 psrldq xmm4, 4 movd eax, xmm7 movd xmm5, eax pslldq xmm5, 12 por xmm3, xmm5 movdqa xmm5, xmm7 psrldq xmm5, 12 pslldq xmm5, 12 por xmm4, xmm5 pand xmm3, [lsym(cdFFFF)] pand xmm4, [lsym(cdFFFF)] packusdw xmm3, xmm4 movdqa xmm4, xmm1 movdqa xmm5, xmm2 movdqa xmm6, xmm3 ; h[n] = (src[2n + 1] - ((src[2n] + src[2n + 2]) >> 1)) >> 1 paddw xmm4, xmm6 psraw xmm4, 1 psubw xmm5, xmm4 psraw xmm5, 1 movdqa xmm6, xmm5 ; out hi paddw xmm6, xmm8 psraw xmm6, xmm9 movdqa [rdi], xmm6 ; l[n] = src[2n] + ((h[n - 1] + h[n]) >> 1) movdqa xmm7, xmm5 movd eax, xmm7 pslldq xmm7, 2 and eax, 0xFFFF movd xmm6, eax por xmm7, xmm6 paddw xmm5, xmm7 psraw xmm5, 1 paddw xmm5, xmm1 movdqa xmm6, xmm5 ; out lo paddw xmm6, xmm10 psraw xmm6, xmm11 movdqa [rdx], xmm6 ; move right lea rsi, [rsi + 16 * 2] lea rdi, [rdi + 8 * 2] lea rdx, [rdx + 8 * 2] ; move left lea rsi, [rsi - 16 * 2] lea rdi, [rdi - 8 * 2] lea rdx, [rdx - 8 * 2] ; move down lea rsi, [rsi + 16 * 2] lea rdi, [rdi + 8 * 2] lea rdx, [rdx + 8 * 2] dec ecx jnz loop1a ret ;****************************************************************************** ; source 16 bit signed, 16 pixel width rfx_dwt_2d_encode_block_verti_16_16: mov ecx, 2 loop1b: ; pre movdqa xmm1, [rsi] ; src[2n] movdqa xmm2, [rsi + 16 * 2] ; src[2n + 1] movdqa xmm3, [rsi + 16 * 2 * 2] ; src[2n + 2] movdqa xmm4, xmm1 movdqa xmm5, xmm2 movdqa xmm6, xmm3 ; h[n] = (src[2n + 1] - ((src[2n] + src[2n + 2]) >> 1)) >> 1 paddw xmm4, xmm6 psraw xmm4, 1 psubw xmm5, xmm4 psraw xmm5, 1 movdqa [rdi], xmm5 ; out hi movdqa xmm6, xmm5 ; save hi ; l[n] = src[2n] + ((h[n - 1] + h[n]) >> 1) paddw xmm5, xmm1 movdqa [rdx], xmm5 ; out lo movdqa xmm7, xmm6 ; save hi ; move down lea rsi, [rsi + 16 * 2 * 2] ; 2 rows lea rdi, [rdi + 16 * 2] ; 1 row lea rdx, [rdx + 16 * 2] ; 1 row ; loop shl ecx, 16 mov cx, 6 loop2b: movdqa xmm1, xmm3 ; src[2n] movdqa xmm2, [rsi + 16 * 2] ; src[2n + 1] movdqa xmm3, [rsi + 16 * 2 * 2] ; src[2n + 2] movdqa xmm4, xmm1 movdqa xmm5, xmm2 movdqa xmm6, xmm3 ; h[n] = (src[2n + 1] - ((src[2n] + src[2n + 2]) >> 1)) >> 1 paddw xmm4, xmm6 psraw xmm4, 1 psubw xmm5, xmm4 psraw xmm5, 1 movdqa [rdi], xmm5 ; out hi movdqa xmm6, xmm5 ; save hi ; l[n] = src[2n] + ((h[n - 1] + h[n]) >> 1) paddw xmm5, xmm7 psraw xmm5, 1 paddw xmm5, xmm1 movdqa [rdx], xmm5 ; out lo movdqa xmm7, xmm6 ; save hi ; move down lea rsi, [rsi + 16 * 2 * 2] ; 2 rows lea rdi, [rdi + 16 * 2] ; 1 row lea rdx, [rdx + 16 * 2] ; 1 row dec cx jnz loop2b shr ecx, 16 ; post movdqa xmm1, xmm3 ; src[2n] movdqa xmm2, [rsi + 16 * 2] ; src[2n + 1] movdqa xmm4, xmm1 movdqa xmm5, xmm2 movdqa xmm6, xmm3 ; h[n] = (src[2n + 1] - ((src[2n] + src[2n + 2]) >> 1)) >> 1 paddw xmm4, xmm6 psraw xmm4, 1 psubw xmm5, xmm4 psraw xmm5, 1 movdqa [rdi], xmm5 ; out hi ; l[n] = src[2n] + ((h[n - 1] + h[n]) >> 1) paddw xmm5, xmm7 psraw xmm5, 1 paddw xmm5, xmm1 movdqa [rdx], xmm5 ; out lo ; move down lea rsi, [rsi + 16 * 2 * 2] ; 2 row lea rdi, [rdi + 16 * 2] ; 1 row lea rdx, [rdx + 16 * 2] ; 1 row ; move up lea rsi, [rsi - 16 * 16 * 2] lea rdi, [rdi - 8 * 16 * 2] lea rdx, [rdx - 8 * 16 * 2] ; move right lea rsi, [rsi + 16] lea rdi, [rdi + 16] lea rdx, [rdx + 16] dec ecx jnz loop1b ret ;****************************************************************************** ; source 16 bit signed, 32 pixel width rfx_dwt_2d_encode_block_horiz_16_32: mov ecx, 16 loop1c: ; pre movdqa xmm1, [rsi] ; src[2n] movdqa xmm2, [rsi + 16] movdqa xmm6, xmm1 movdqa xmm7, xmm2 pand xmm1, [lsym(cdFFFF)] pand xmm2, [lsym(cdFFFF)] packusdw xmm1, xmm2 movdqa xmm2, xmm6 ; src[2n + 1] movdqa xmm3, xmm7 psrldq xmm2, 2 psrldq xmm3, 2 pand xmm2, [lsym(cdFFFF)] pand xmm3, [lsym(cdFFFF)] packusdw xmm2, xmm3 movdqa xmm3, xmm6 ; src[2n + 2] movdqa xmm4, xmm7 psrldq xmm3, 4 psrldq xmm4, 4 movd eax, xmm7 movd xmm5, eax pslldq xmm5, 12 por xmm3, xmm5 mov eax, [rsi + 32] movd xmm5, eax pslldq xmm5, 12 por xmm4, xmm5 pand xmm3, [lsym(cdFFFF)] pand xmm4, [lsym(cdFFFF)] packusdw xmm3, xmm4 movdqa xmm4, xmm1 movdqa xmm5, xmm2 movdqa xmm6, xmm3 ; h[n] = (src[2n + 1] - ((src[2n] + src[2n + 2]) >> 1)) >> 1 paddw xmm4, xmm6 psraw xmm4, 1 psubw xmm5, xmm4 psraw xmm5, 1 movdqa xmm6, xmm5 ; out hi paddw xmm6, xmm8 psraw xmm6, xmm9 movdqa [rdi], xmm6 movdqa xmm2, xmm5 ; save hi ; l[n] = src[2n] + ((h[n - 1] + h[n]) >> 1) movdqa xmm7, xmm5 movd eax, xmm7 pslldq xmm7, 2 and eax, 0xFFFF movd xmm6, eax por xmm7, xmm6 paddw xmm5, xmm7 psraw xmm5, 1 paddw xmm5, xmm1 psrldq xmm2, 14 movd ebx, xmm2 ; save hi movdqa xmm6, xmm5 ; out lo paddw xmm6, xmm10 psraw xmm6, xmm11 movdqa [rdx], xmm6 ; move right lea rsi, [rsi + 16 * 2] lea rdi, [rdi + 8 * 2] lea rdx, [rdx + 8 * 2] ; post movdqa xmm1, [rsi] ; src[2n] movdqa xmm2, [rsi + 16] movdqa xmm6, xmm1 movdqa xmm7, xmm2 pand xmm1, [lsym(cdFFFF)] pand xmm2, [lsym(cdFFFF)] packusdw xmm1, xmm2 movdqa xmm2, xmm6 ; src[2n + 1] movdqa xmm3, xmm7 psrldq xmm2, 2 psrldq xmm3, 2 pand xmm2, [lsym(cdFFFF)] pand xmm3, [lsym(cdFFFF)] packusdw xmm2, xmm3 movdqa xmm3, xmm6 ; src[2n + 2] movdqa xmm4, xmm7 psrldq xmm3, 4 psrldq xmm4, 4 movd eax, xmm7 movd xmm5, eax pslldq xmm5, 12 por xmm3, xmm5 movdqa xmm5, xmm7 psrldq xmm5, 12 pslldq xmm5, 12 por xmm4, xmm5 pand xmm3, [lsym(cdFFFF)] pand xmm4, [lsym(cdFFFF)] packusdw xmm3, xmm4 movdqa xmm4, xmm1 movdqa xmm5, xmm2 movdqa xmm6, xmm3 ; h[n] = (src[2n + 1] - ((src[2n] + src[2n + 2]) >> 1)) >> 1 paddw xmm4, xmm6 psraw xmm4, 1 psubw xmm5, xmm4 psraw xmm5, 1 movdqa xmm6, xmm5 ; out hi paddw xmm6, xmm8 psraw xmm6, xmm9 movdqa [rdi], xmm6 ; l[n] = src[2n] + ((h[n - 1] + h[n]) >> 1) movdqa xmm7, xmm5 pslldq xmm7, 2 movd xmm6, ebx por xmm7, xmm6 paddw xmm5, xmm7 psraw xmm5, 1 paddw xmm5, xmm1 movdqa xmm6, xmm5 ; out lo paddw xmm6, xmm10 psraw xmm6, xmm11 movdqa [rdx], xmm6 ; move right lea rsi, [rsi + 16 * 2] lea rdi, [rdi + 8 * 2] lea rdx, [rdx + 8 * 2] ; move left lea rsi, [rsi - 32 * 2] lea rdi, [rdi - 16 * 2] lea rdx, [rdx - 16 * 2] ; move down lea rsi, [rsi + 32 * 2] lea rdi, [rdi + 16 * 2] lea rdx, [rdx + 16 * 2] dec ecx jnz loop1c ret ;****************************************************************************** ; source 16 bit signed, 32 pixel width rfx_dwt_2d_encode_block_horiz_16_32_no_lo: mov ecx, 16 loop1c1: ; pre movdqa xmm1, [rsi] ; src[2n] movdqa xmm2, [rsi + 16] movdqa xmm6, xmm1 movdqa xmm7, xmm2 pand xmm1, [lsym(cdFFFF)] pand xmm2, [lsym(cdFFFF)] packusdw xmm1, xmm2 movdqa xmm2, xmm6 ; src[2n + 1] movdqa xmm3, xmm7 psrldq xmm2, 2 psrldq xmm3, 2 pand xmm2, [lsym(cdFFFF)] pand xmm3, [lsym(cdFFFF)] packusdw xmm2, xmm3 movdqa xmm3, xmm6 ; src[2n + 2] movdqa xmm4, xmm7 psrldq xmm3, 4 psrldq xmm4, 4 movd eax, xmm7 movd xmm5, eax pslldq xmm5, 12 por xmm3, xmm5 mov eax, [rsi + 32] movd xmm5, eax pslldq xmm5, 12 por xmm4, xmm5 pand xmm3, [lsym(cdFFFF)] pand xmm4, [lsym(cdFFFF)] packusdw xmm3, xmm4 movdqa xmm4, xmm1 movdqa xmm5, xmm2 movdqa xmm6, xmm3 ; h[n] = (src[2n + 1] - ((src[2n] + src[2n + 2]) >> 1)) >> 1 paddw xmm4, xmm6 psraw xmm4, 1 psubw xmm5, xmm4 psraw xmm5, 1 movdqa xmm6, xmm5 ; out hi paddw xmm6, xmm8 psraw xmm6, xmm9 movdqa [rdi], xmm6 movdqa xmm2, xmm5 ; save hi ; l[n] = src[2n] + ((h[n - 1] + h[n]) >> 1) movdqa xmm7, xmm5 movd eax, xmm7 pslldq xmm7, 2 and eax, 0xFFFF movd xmm6, eax por xmm7, xmm6 paddw xmm5, xmm7 psraw xmm5, 1 paddw xmm5, xmm1 psrldq xmm2, 14 movd ebx, xmm2 ; save hi movdqa [rdx], xmm5 ; out lo ; move right lea rsi, [rsi + 16 * 2] lea rdi, [rdi + 8 * 2] lea rdx, [rdx + 8 * 2] ; post movdqa xmm1, [rsi] ; src[2n] movdqa xmm2, [rsi + 16] movdqa xmm6, xmm1 movdqa xmm7, xmm2 pand xmm1, [lsym(cdFFFF)] pand xmm2, [lsym(cdFFFF)] packusdw xmm1, xmm2 movdqa xmm2, xmm6 ; src[2n + 1] movdqa xmm3, xmm7 psrldq xmm2, 2 psrldq xmm3, 2 pand xmm2, [lsym(cdFFFF)] pand xmm3, [lsym(cdFFFF)] packusdw xmm2, xmm3 movdqa xmm3, xmm6 ; src[2n + 2] movdqa xmm4, xmm7 psrldq xmm3, 4 psrldq xmm4, 4 movd eax, xmm7 movd xmm5, eax pslldq xmm5, 12 por xmm3, xmm5 movdqa xmm5, xmm7 psrldq xmm5, 12 pslldq xmm5, 12 por xmm4, xmm5 pand xmm3, [lsym(cdFFFF)] pand xmm4, [lsym(cdFFFF)] packusdw xmm3, xmm4 movdqa xmm4, xmm1 movdqa xmm5, xmm2 movdqa xmm6, xmm3 ; h[n] = (src[2n + 1] - ((src[2n] + src[2n + 2]) >> 1)) >> 1 paddw xmm4, xmm6 psraw xmm4, 1 psubw xmm5, xmm4 psraw xmm5, 1 movdqa xmm6, xmm5 ; out hi paddw xmm6, xmm8 psraw xmm6, xmm9 movdqa [rdi], xmm6 ; l[n] = src[2n] + ((h[n - 1] + h[n]) >> 1) movdqa xmm7, xmm5 pslldq xmm7, 2 movd xmm6, ebx por xmm7, xmm6 paddw xmm5, xmm7 psraw xmm5, 1 paddw xmm5, xmm1 movdqa [rdx], xmm5 ; out lo ; move right lea rsi, [rsi + 16 * 2] lea rdi, [rdi + 8 * 2] lea rdx, [rdx + 8 * 2] ; move left lea rsi, [rsi - 32 * 2] lea rdi, [rdi - 16 * 2] lea rdx, [rdx - 16 * 2] ; move down lea rsi, [rsi + 32 * 2] lea rdi, [rdi + 16 * 2] lea rdx, [rdx + 16 * 2] dec ecx jnz loop1c1 ret ;****************************************************************************** ; source 16 bit signed, 32 pixel width rfx_dwt_2d_encode_block_verti_16_32: mov ecx, 4 loop1d: ; pre movdqa xmm1, [rsi] ; src[2n] movdqa xmm2, [rsi + 32 * 2] ; src[2n + 1] movdqa xmm3, [rsi + 32 * 2 * 2] ; src[2n + 2] movdqa xmm4, xmm1 movdqa xmm5, xmm2 movdqa xmm6, xmm3 ; h[n] = (src[2n + 1] - ((src[2n] + src[2n + 2]) >> 1)) >> 1 paddw xmm4, xmm6 psraw xmm4, 1 psubw xmm5, xmm4 psraw xmm5, 1 movdqa [rdi], xmm5 ; out hi movdqa xmm6, xmm5 ; save hi ; l[n] = src[2n] + ((h[n - 1] + h[n]) >> 1) paddw xmm5, xmm1 movdqa [rdx], xmm5 ; out lo movdqa xmm7, xmm6 ; save hi ; move down lea rsi, [rsi + 32 * 2 * 2] ; 2 rows lea rdi, [rdi + 32 * 2] ; 1 row lea rdx, [rdx + 32 * 2] ; 1 row ; loop shl ecx, 16 mov cx, 14 loop2d: movdqa xmm1, xmm3 ; src[2n] movdqa xmm2, [rsi + 32 * 2] ; src[2n + 1] movdqa xmm3, [rsi + 32 * 2 * 2] ; src[2n + 2] movdqa xmm4, xmm1 movdqa xmm5, xmm2 movdqa xmm6, xmm3 ; h[n] = (src[2n + 1] - ((src[2n] + src[2n + 2]) >> 1)) >> 1 paddw xmm4, xmm6 psraw xmm4, 1 psubw xmm5, xmm4 psraw xmm5, 1 movdqa [rdi], xmm5 ; out hi movdqa xmm6, xmm5 ; save hi ; l[n] = src[2n] + ((h[n - 1] + h[n]) >> 1) paddw xmm5, xmm7 psraw xmm5, 1 paddw xmm5, xmm1 movdqa [rdx], xmm5 ; out lo movdqa xmm7, xmm6 ; save hi ; move down lea rsi, [rsi + 32 * 2 * 2] ; 2 rows lea rdi, [rdi + 32 * 2] ; 1 row lea rdx, [rdx + 32 * 2] ; 1 row dec cx jnz loop2d shr ecx, 16 ; post movdqa xmm1, xmm3 ; src[2n] movdqa xmm2, [rsi + 32 * 2] ; src[2n + 1] movdqa xmm4, xmm1 movdqa xmm5, xmm2 movdqa xmm6, xmm3 ; h[n] = (src[2n + 1] - ((src[2n] + src[2n + 2]) >> 1)) >> 1 paddw xmm4, xmm6 psraw xmm4, 1 psubw xmm5, xmm4 psraw xmm5, 1 movdqa [rdi], xmm5 ; out hi ; l[n] = src[2n] + ((h[n - 1] + h[n]) >> 1) paddw xmm5, xmm7 psraw xmm5, 1 paddw xmm5, xmm1 movdqa [rdx], xmm5 ; out lo ; move down lea rsi, [rsi + 32 * 2 * 2] ; 2 row lea rdi, [rdi + 32 * 2] ; 1 row lea rdx, [rdx + 32 * 2] ; 1 row ; move up lea rsi, [rsi - 32 * 32 * 2] lea rdi, [rdi - 16 * 32 * 2] lea rdx, [rdx - 16 * 32 * 2] ; move right lea rsi, [rsi + 16] lea rdi, [rdi + 16] lea rdx, [rdx + 16] dec ecx jnz loop1d ret ;****************************************************************************** ; source 16 bit signed, 64 pixel width rfx_dwt_2d_encode_block_horiz_16_64: mov ecx, 32 loop1e: ; pre movdqa xmm1, [rsi] ; src[2n] movdqa xmm2, [rsi + 16] movdqa xmm6, xmm1 movdqa xmm7, xmm2 pand xmm1, [lsym(cdFFFF)] pand xmm2, [lsym(cdFFFF)] packusdw xmm1, xmm2 movdqa xmm2, xmm6 ; src[2n + 1] movdqa xmm3, xmm7 psrldq xmm2, 2 psrldq xmm3, 2 pand xmm2, [lsym(cdFFFF)] pand xmm3, [lsym(cdFFFF)] packusdw xmm2, xmm3 movdqa xmm3, xmm6 ; src[2n + 2] movdqa xmm4, xmm7 psrldq xmm3, 4 psrldq xmm4, 4 movd eax, xmm7 movd xmm5, eax pslldq xmm5, 12 por xmm3, xmm5 mov eax, [rsi + 32] movd xmm5, eax pslldq xmm5, 12 por xmm4, xmm5 pand xmm3, [lsym(cdFFFF)] pand xmm4, [lsym(cdFFFF)] packusdw xmm3, xmm4 movdqa xmm4, xmm1 movdqa xmm5, xmm2 movdqa xmm6, xmm3 ; h[n] = (src[2n + 1] - ((src[2n] + src[2n + 2]) >> 1)) >> 1 paddw xmm4, xmm6 psraw xmm4, 1 psubw xmm5, xmm4 psraw xmm5, 1 movdqa xmm6, xmm5 ; out hi paddw xmm6, xmm8 psraw xmm6, xmm9 movdqa [rdi], xmm6 movdqa xmm2, xmm5 ; save hi ; l[n] = src[2n] + ((h[n - 1] + h[n]) >> 1) movdqa xmm7, xmm5 movd eax, xmm7 pslldq xmm7, 2 and eax, 0xFFFF movd xmm6, eax por xmm7, xmm6 paddw xmm5, xmm7 psraw xmm5, 1 paddw xmm5, xmm1 psrldq xmm2, 14 movd ebx, xmm2 ; save hi movdqa xmm6, xmm5 ; out lo paddw xmm6, xmm10 psraw xmm6, xmm11 movdqa [rdx], xmm6 ; move right lea rsi, [rsi + 16 * 2] lea rdi, [rdi + 8 * 2] lea rdx, [rdx + 8 * 2] ; loop shl ecx, 16 mov cx, 2 loop2e: movdqa xmm1, [rsi] ; src[2n] movdqa xmm2, [rsi + 16] movdqa xmm6, xmm1 movdqa xmm7, xmm2 pand xmm1, [lsym(cdFFFF)] pand xmm2, [lsym(cdFFFF)] packusdw xmm1, xmm2 movdqa xmm2, xmm6 ; src[2n + 1] movdqa xmm3, xmm7 psrldq xmm2, 2 psrldq xmm3, 2 pand xmm2, [lsym(cdFFFF)] pand xmm3, [lsym(cdFFFF)] packusdw xmm2, xmm3 movdqa xmm3, xmm6 ; src[2n + 2] movdqa xmm4, xmm7 psrldq xmm3, 4 psrldq xmm4, 4 movd eax, xmm7 movd xmm5, eax pslldq xmm5, 12 por xmm3, xmm5 mov eax, [rsi + 32] movd xmm5, eax pslldq xmm5, 12 por xmm4, xmm5 pand xmm3, [lsym(cdFFFF)] pand xmm4, [lsym(cdFFFF)] packusdw xmm3, xmm4 movdqa xmm4, xmm1 movdqa xmm5, xmm2 movdqa xmm6, xmm3 ; h[n] = (src[2n + 1] - ((src[2n] + src[2n + 2]) >> 1)) >> 1 paddw xmm4, xmm6 psraw xmm4, 1 psubw xmm5, xmm4 psraw xmm5, 1 movdqa xmm6, xmm5 ; out hi paddw xmm6, xmm8 psraw xmm6, xmm9 movdqa [rdi], xmm6 movdqa xmm2, xmm5 ; save hi ; l[n] = src[2n] + ((h[n - 1] + h[n]) >> 1) movdqa xmm7, xmm5 pslldq xmm7, 2 movd xmm6, ebx por xmm7, xmm6 paddw xmm5, xmm7 psraw xmm5, 1 paddw xmm5, xmm1 psrldq xmm2, 14 movd ebx, xmm2 ; save hi movdqa xmm6, xmm5 ; out lo paddw xmm6, xmm10 psraw xmm6, xmm11 movdqa [rdx], xmm6 ; move right lea rsi, [rsi + 16 * 2] lea rdi, [rdi + 8 * 2] lea rdx, [rdx + 8 * 2] dec cx jnz loop2e shr ecx, 16 ; post movdqa xmm1, [rsi] ; src[2n] movdqa xmm2, [rsi + 16] movdqa xmm6, xmm1 movdqa xmm7, xmm2 pand xmm1, [lsym(cdFFFF)] pand xmm2, [lsym(cdFFFF)] packusdw xmm1, xmm2 movdqa xmm2, xmm6 ; src[2n + 1] movdqa xmm3, xmm7 psrldq xmm2, 2 psrldq xmm3, 2 pand xmm2, [lsym(cdFFFF)] pand xmm3, [lsym(cdFFFF)] packusdw xmm2, xmm3 movdqa xmm3, xmm6 ; src[2n + 2] movdqa xmm4, xmm7 psrldq xmm3, 4 psrldq xmm4, 4 movd eax, xmm7 movd xmm5, eax pslldq xmm5, 12 por xmm3, xmm5 movdqa xmm5, xmm7 psrldq xmm5, 12 pslldq xmm5, 12 por xmm4, xmm5 pand xmm3, [lsym(cdFFFF)] pand xmm4, [lsym(cdFFFF)] packusdw xmm3, xmm4 movdqa xmm4, xmm1 movdqa xmm5, xmm2 movdqa xmm6, xmm3 ; h[n] = (src[2n + 1] - ((src[2n] + src[2n + 2]) >> 1)) >> 1 paddw xmm4, xmm6 psraw xmm4, 1 psubw xmm5, xmm4 psraw xmm5, 1 movdqa xmm6, xmm5 ; out hi paddw xmm6, xmm8 psraw xmm6, xmm9 movdqa [rdi], xmm6 ; l[n] = src[2n] + ((h[n - 1] + h[n]) >> 1) movdqa xmm7, xmm5 pslldq xmm7, 2 movd xmm6, ebx por xmm7, xmm6 paddw xmm5, xmm7 psraw xmm5, 1 paddw xmm5, xmm1 movdqa xmm6, xmm5 ; out lo paddw xmm6, xmm10 psraw xmm6, xmm11 movdqa [rdx], xmm6 ; move right lea rsi, [rsi + 16 * 2] lea rdi, [rdi + 8 * 2] lea rdx, [rdx + 8 * 2] ; move left lea rsi, [rsi - 64 * 2] lea rdi, [rdi - 32 * 2] lea rdx, [rdx - 32 * 2] ; move down lea rsi, [rsi + 64 * 2] lea rdi, [rdi + 32 * 2] lea rdx, [rdx + 32 * 2] dec ecx jnz loop1e ret ;****************************************************************************** ; source 16 bit signed, 64 pixel width rfx_dwt_2d_encode_block_horiz_16_64_no_lo: mov ecx, 32 loop1e1: ; pre movdqa xmm1, [rsi] ; src[2n] movdqa xmm2, [rsi + 16] movdqa xmm6, xmm1 movdqa xmm7, xmm2 pand xmm1, [lsym(cdFFFF)] pand xmm2, [lsym(cdFFFF)] packusdw xmm1, xmm2 movdqa xmm2, xmm6 ; src[2n + 1] movdqa xmm3, xmm7 psrldq xmm2, 2 psrldq xmm3, 2 pand xmm2, [lsym(cdFFFF)] pand xmm3, [lsym(cdFFFF)] packusdw xmm2, xmm3 movdqa xmm3, xmm6 ; src[2n + 2] movdqa xmm4, xmm7 psrldq xmm3, 4 psrldq xmm4, 4 movd eax, xmm7 movd xmm5, eax pslldq xmm5, 12 por xmm3, xmm5 mov eax, [rsi + 32] movd xmm5, eax pslldq xmm5, 12 por xmm4, xmm5 pand xmm3, [lsym(cdFFFF)] pand xmm4, [lsym(cdFFFF)] packusdw xmm3, xmm4 movdqa xmm4, xmm1 movdqa xmm5, xmm2 movdqa xmm6, xmm3 ; h[n] = (src[2n + 1] - ((src[2n] + src[2n + 2]) >> 1)) >> 1 paddw xmm4, xmm6 psraw xmm4, 1 psubw xmm5, xmm4 psraw xmm5, 1 movdqa xmm6, xmm5 ; out hi paddw xmm6, xmm8 psraw xmm6, xmm9 movdqa [rdi], xmm6 movdqa xmm2, xmm5 ; save hi ; l[n] = src[2n] + ((h[n - 1] + h[n]) >> 1) movdqa xmm7, xmm5 movd eax, xmm7 pslldq xmm7, 2 and eax, 0xFFFF movd xmm6, eax por xmm7, xmm6 paddw xmm5, xmm7 psraw xmm5, 1 paddw xmm5, xmm1 psrldq xmm2, 14 movd ebx, xmm2 ; save hi movdqa [rdx], xmm5 ; out lo ; move right lea rsi, [rsi + 16 * 2] lea rdi, [rdi + 8 * 2] lea rdx, [rdx + 8 * 2] ; loop shl ecx, 16 mov cx, 2 loop2e1: movdqa xmm1, [rsi] ; src[2n] movdqa xmm2, [rsi + 16] movdqa xmm6, xmm1 movdqa xmm7, xmm2 pand xmm1, [lsym(cdFFFF)] pand xmm2, [lsym(cdFFFF)] packusdw xmm1, xmm2 movdqa xmm2, xmm6 ; src[2n + 1] movdqa xmm3, xmm7 psrldq xmm2, 2 psrldq xmm3, 2 pand xmm2, [lsym(cdFFFF)] pand xmm3, [lsym(cdFFFF)] packusdw xmm2, xmm3 movdqa xmm3, xmm6 ; src[2n + 2] movdqa xmm4, xmm7 psrldq xmm3, 4 psrldq xmm4, 4 movd eax, xmm7 movd xmm5, eax pslldq xmm5, 12 por xmm3, xmm5 mov eax, [rsi + 32] movd xmm5, eax pslldq xmm5, 12 por xmm4, xmm5 pand xmm3, [lsym(cdFFFF)] pand xmm4, [lsym(cdFFFF)] packusdw xmm3, xmm4 movdqa xmm4, xmm1 movdqa xmm5, xmm2 movdqa xmm6, xmm3 ; h[n] = (src[2n + 1] - ((src[2n] + src[2n + 2]) >> 1)) >> 1 paddw xmm4, xmm6 psraw xmm4, 1 psubw xmm5, xmm4 psraw xmm5, 1 movdqa xmm6, xmm5 ; out hi paddw xmm6, xmm8 psraw xmm6, xmm9 movdqa [rdi], xmm6 movdqa xmm2, xmm5 ; save hi ; l[n] = src[2n] + ((h[n - 1] + h[n]) >> 1) movdqa xmm7, xmm5 pslldq xmm7, 2 movd xmm6, ebx por xmm7, xmm6 paddw xmm5, xmm7 psraw xmm5, 1 paddw xmm5, xmm1 psrldq xmm2, 14 movd ebx, xmm2 ; save hi movdqa [rdx], xmm5 ; out lo ; move right lea rsi, [rsi + 16 * 2] lea rdi, [rdi + 8 * 2] lea rdx, [rdx + 8 * 2] dec cx jnz loop2e1 shr ecx, 16 ; post movdqa xmm1, [rsi] ; src[2n] movdqa xmm2, [rsi + 16] movdqa xmm6, xmm1 movdqa xmm7, xmm2 pand xmm1, [lsym(cdFFFF)] pand xmm2, [lsym(cdFFFF)] packusdw xmm1, xmm2 movdqa xmm2, xmm6 ; src[2n + 1] movdqa xmm3, xmm7 psrldq xmm2, 2 psrldq xmm3, 2 pand xmm2, [lsym(cdFFFF)] pand xmm3, [lsym(cdFFFF)] packusdw xmm2, xmm3 movdqa xmm3, xmm6 ; src[2n + 2] movdqa xmm4, xmm7 psrldq xmm3, 4 psrldq xmm4, 4 movd eax, xmm7 movd xmm5, eax pslldq xmm5, 12 por xmm3, xmm5 movdqa xmm5, xmm7 psrldq xmm5, 12 pslldq xmm5, 12 por xmm4, xmm5 pand xmm3, [lsym(cdFFFF)] pand xmm4, [lsym(cdFFFF)] packusdw xmm3, xmm4 movdqa xmm4, xmm1 movdqa xmm5, xmm2 movdqa xmm6, xmm3 ; h[n] = (src[2n + 1] - ((src[2n] + src[2n + 2]) >> 1)) >> 1 paddw xmm4, xmm6 psraw xmm4, 1 psubw xmm5, xmm4 psraw xmm5, 1 movdqa xmm6, xmm5 ; out hi paddw xmm6, xmm8 psraw xmm6, xmm9 movdqa [rdi], xmm6 ; l[n] = src[2n] + ((h[n - 1] + h[n]) >> 1) movdqa xmm7, xmm5 pslldq xmm7, 2 movd xmm6, ebx por xmm7, xmm6 paddw xmm5, xmm7 psraw xmm5, 1 paddw xmm5, xmm1 movdqa [rdx], xmm5 ; out lo ; move right lea rsi, [rsi + 16 * 2] lea rdi, [rdi + 8 * 2] lea rdx, [rdx + 8 * 2] ; move left lea rsi, [rsi - 64 * 2] lea rdi, [rdi - 32 * 2] lea rdx, [rdx - 32 * 2] ; move down lea rsi, [rsi + 64 * 2] lea rdi, [rdi + 32 * 2] lea rdx, [rdx + 32 * 2] dec ecx jnz loop1e1 ret ;****************************************************************************** ; source 8 bit unsigned, 64 pixel width rfx_dwt_2d_encode_block_verti_8_64: mov ecx, 8 loop1f: ; pre movq xmm1, [rsi] ; src[2n] movq xmm2, [rsi + 64 * 1] ; src[2n + 1] movq xmm3, [rsi + 64 * 1 * 2] ; src[2n + 2] punpcklbw xmm1, xmm0 punpcklbw xmm2, xmm0 punpcklbw xmm3, xmm0 psubw xmm1, [lsym(cw128)] psubw xmm2, [lsym(cw128)] psubw xmm3, [lsym(cw128)] psllw xmm1, 5 psllw xmm2, 5 psllw xmm3, 5 movdqa xmm4, xmm1 movdqa xmm5, xmm2 movdqa xmm6, xmm3 ; h[n] = (src[2n + 1] - ((src[2n] + src[2n + 2]) >> 1)) >> 1 paddw xmm4, xmm6 psraw xmm4, 1 psubw xmm5, xmm4 psraw xmm5, 1 movdqa [rdi], xmm5 ; out hi movdqa xmm6, xmm5 ; save hi ; l[n] = src[2n] + ((h[n - 1] + h[n]) >> 1) paddw xmm5, xmm1 movdqa [rdx], xmm5 ; out lo movdqa xmm7, xmm6 ; save hi ; move down lea rsi, [rsi + 64 * 1 * 2] ; 2 rows lea rdi, [rdi + 64 * 2] ; 1 row lea rdx, [rdx + 64 * 2] ; 1 row ; loop shl ecx, 16 mov cx, 30 loop2f: movdqa xmm1, xmm3 ; src[2n] movq xmm2, [rsi + 64 * 1] ; src[2n + 1] movq xmm3, [rsi + 64 * 1 * 2] ; src[2n + 2] punpcklbw xmm2, xmm0 punpcklbw xmm3, xmm0 psubw xmm2, [lsym(cw128)] psubw xmm3, [lsym(cw128)] psllw xmm2, 5 psllw xmm3, 5 movdqa xmm4, xmm1 movdqa xmm5, xmm2 movdqa xmm6, xmm3 ; h[n] = (src[2n + 1] - ((src[2n] + src[2n + 2]) >> 1)) >> 1 paddw xmm4, xmm6 psraw xmm4, 1 psubw xmm5, xmm4 psraw xmm5, 1 movdqa [rdi], xmm5 ; out hi movdqa xmm6, xmm5 ; save hi ; l[n] = src[2n] + ((h[n - 1] + h[n]) >> 1) paddw xmm5, xmm7 psraw xmm5, 1 paddw xmm5, xmm1 movdqa [rdx], xmm5 ; out lo movdqa xmm7, xmm6 ; save hi ; move down lea rsi, [rsi + 64 * 1 * 2] ; 2 rows lea rdi, [rdi + 64 * 2] ; 1 row lea rdx, [rdx + 64 * 2] ; 1 row dec cx jnz loop2f shr ecx, 16 ; post movdqa xmm1, xmm3 ; src[2n] movq xmm2, [rsi + 64 * 1] ; src[2n + 1] punpcklbw xmm2, xmm0 psubw xmm2, [lsym(cw128)] psllw xmm2, 5 movdqa xmm4, xmm1 movdqa xmm5, xmm2 movdqa xmm6, xmm3 ; h[n] = (src[2n + 1] - ((src[2n] + src[2n + 2]) >> 1)) >> 1 paddw xmm4, xmm6 psraw xmm4, 1 psubw xmm5, xmm4 psraw xmm5, 1 movdqa [rdi], xmm5 ; out hi ; l[n] = src[2n] + ((h[n - 1] + h[n]) >> 1) paddw xmm5, xmm7 psraw xmm5, 1 paddw xmm5, xmm1 movdqa [rdx], xmm5 ; out lo ; move down lea rsi, [rsi + 64 * 1 * 2] ; 2 rows lea rdi, [rdi + 64 * 2] ; 1 row lea rdx, [rdx + 64 * 2] ; 1 row ; move up lea rsi, [rsi - 64 * 1 * 64] lea rdi, [rdi - 32 * 64 * 2] lea rdx, [rdx - 32 * 64 * 2] ; move right lea rsi, [rsi + 8] lea rdi, [rdi + 16] lea rdx, [rdx + 16] dec ecx jnz loop1f ret set_quants_hi: sub rax, 6 - 5 movd xmm9, eax imul rax, 16 lea rdx, [lsym(cwa0)] add rdx, rax movdqa xmm8, [rdx] ret set_quants_lo: sub rax, 6 - 5 movd xmm11, eax imul rax, 16 lea rdx, [lsym(cwa0)] add rdx, rax movdqa xmm10, [rdx] ret ;The first six integer or pointer arguments are passed in registers ;RDI, RSI, RDX, RCX, R8, and R9 ;int ;rfxcodec_encode_dwt_shift_amd64_sse41(const char *qtable, ; unsigned char *in_buffer, ; short *out_buffer, ; short *work_buffer); ;****************************************************************************** PROC rfxcodec_encode_dwt_shift_amd64_sse41 ; save registers push rbx push rdx push rcx push rsi push rdi pxor xmm0, xmm0 ; verical DWT to work buffer, level 1 mov rsi, [rsp + 8] ; src mov rdi, [rsp + 16] ; dst hi lea rdi, [rdi + 64 * 32 * 2] ; dst hi mov rdx, [rsp + 16] ; dst lo call rfx_dwt_2d_encode_block_verti_8_64 ; horizontal DWT to out buffer, level 1, part 1 xor rax, rax mov rdx, [rsp] mov al, [rdx + 4] and al, 0xF call set_quants_hi mov rsi, [rsp + 16] ; src mov rdi, [rsp + 24] ; dst hi - HL1 mov rdx, [rsp + 24] ; dst lo - LL1 lea rdx, [rdx + 32 * 32 * 6] ; dst lo - LL1 call rfx_dwt_2d_encode_block_horiz_16_64_no_lo ; horizontal DWT to out buffer, level 1, part 2 xor rax, rax mov rdx, [rsp] mov al, [rdx + 4] shr al, 4 call set_quants_hi xor rax, rax mov rdx, [rsp] mov al, [rdx + 3] shr al, 4 call set_quants_lo mov rsi, [rsp + 16] ; src lea rsi, [rsi + 64 * 32 * 2] ; src mov rdi, [rsp + 24] ; dst hi - HH1 lea rdi, [rdi + 32 * 32 * 4] ; dst hi - HH1 mov rdx, [rsp + 24] ; dst lo - LH1 lea rdx, [rdx + 32 * 32 * 2] ; dst lo - LH1 call rfx_dwt_2d_encode_block_horiz_16_64 ; verical DWT to work buffer, level 2 mov rsi, [rsp + 24] ; src lea rsi, [rsi + 32 * 32 * 6] ; src mov rdi, [rsp + 16] ; dst hi lea rdi, [rdi + 32 * 16 * 2] ; dst hi mov rdx, [rsp + 16] ; dst lo call rfx_dwt_2d_encode_block_verti_16_32 ; horizontal DWT to out buffer, level 2, part 1 xor rax, rax mov rdx, [rsp] mov al, [rdx + 2] shr al, 4 call set_quants_hi mov rsi, [rsp + 16] ; src ; 32 * 32 * 6 + 16 * 16 * 0 = 6144 mov rdi, [rsp + 24] ; dst hi - HL2 lea rdi, [rdi + 6144] ; dst hi - HL2 ; 32 * 32 * 6 + 16 * 16 * 6 = 7680 mov rdx, [rsp + 24] ; dst lo - LL2 lea rdx, [rdx + 7680] ; dst lo - LL2 call rfx_dwt_2d_encode_block_horiz_16_32_no_lo ; horizontal DWT to out buffer, level 2, part 2 xor rax, rax mov rdx, [rsp] mov al, [rdx + 3] and al, 0xF call set_quants_hi xor rax, rax mov rdx, [rsp] mov al, [rdx + 2] and al, 0xF call set_quants_lo mov rsi, [rsp + 16] ; src lea rsi, [rsi + 32 * 16 * 2] ; src ; 32 * 32 * 6 + 16 * 16 * 4 = 7168 mov rdi, [rsp + 24] ; dst hi - HH2 lea rdi, [rdi + 7168] ; dst hi - HH2 ; 32 * 32 * 6 + 16 * 16 * 2 = 6656 mov rdx, [rsp + 24] ; dst lo - LH2 lea rdx, [rdx + 6656] ; dst lo - LH2 call rfx_dwt_2d_encode_block_horiz_16_32 ; verical DWT to work buffer, level 3 ; 32 * 32 * 6 + 16 * 16 * 6 = 7680 mov rsi, [rsp + 24] ; src lea rsi, [rsi + 7680] ; src mov rdi, [rsp + 16] ; dst hi lea rdi, [rdi + 16 * 8 * 2] ; dst hi mov rdx, [rsp + 16] ; dst lo call rfx_dwt_2d_encode_block_verti_16_16 ; horizontal DWT to out buffer, level 3, part 1 xor rax, rax mov rdx, [rsp] mov al, [rdx + 1] and al, 0xF call set_quants_hi xor rax, rax mov rdx, [rsp] mov al, [rdx + 0] and al, 0xF call set_quants_lo mov rsi, [rsp + 16] ; src ; 32 * 32 * 6 + 16 * 16 * 6 + 8 * 8 * 0 = 7680 mov rdi, [rsp + 24] ; dst hi - HL3 lea rdi, [rdi + 7680] ; dst hi - HL3 ; 32 * 32 * 6 + 16 * 16 * 6 + 8 * 8 * 6 = 8064 mov rdx, [rsp + 24] ; dst lo - LL3 lea rdx, [rdx + 8064] ; dst lo - LL3 call rfx_dwt_2d_encode_block_horiz_16_16 ; horizontal DWT to out buffer, level 3, part 2 xor rax, rax mov rdx, [rsp] mov al, [rdx + 1] shr al, 4 call set_quants_hi xor rax, rax mov rdx, [rsp] mov al, [rdx + 0] shr al, 4 call set_quants_lo mov rsi, [rsp + 16] ; src lea rsi, [rsi + 16 * 8 * 2] ; src ; 32 * 32 * 6 + 16 * 16 * 6 + 8 * 8 * 4 = 7936 mov rdi, [rsp + 24] ; dst hi - HH3 lea rdi, [rdi + 7936] ; dst hi - HH3 ; 32 * 32 * 6 + 16 * 16 * 6 + 8 * 8 * 2 = 7808 mov rdx, [rsp + 24] ; dst lo - LH3 lea rdx, [rdx + 7808] ; dst lo - LH3 call rfx_dwt_2d_encode_block_horiz_16_16 mov rax, 0 ; restore registers pop rdi pop rsi pop rcx pop rdx pop rbx ret END_OF_FILE xrdp-0.9.5/librfxcodec/src/amd64/cpuid_amd64.asm000644 001751 001751 00000001045 13162371073 021214 0ustar00metameta000000 000000 %include "common.asm" ;The first six integer or pointer arguments are passed in registers ;RDI, RSI, RDX, RCX, R8, and R9 ;int ;cpuid_amd64(int eax_in, int ecx_in, int *eax, int *ebx, int *ecx, int *edx) PROC cpuid_amd64 ; save registers push rbx push rdx push rcx push r8 push r9 mov rax, rdi mov rcx, rsi cpuid pop rdi mov [rdi], edx pop rdi mov [rdi], ecx pop rdi mov [rdi], ebx pop rdi mov [rdi], eax mov rax, 0 ; restore registers pop rbx ret END_OF_FILE xrdp-0.9.5/librfxcodec/src/amd64/Makefile.in000644 001751 001751 00000044176 13220730761 020472 0ustar00metameta000000 000000 # Makefile.in generated by automake 1.15.1 from Makefile.am. # @configure_input@ # Copyright (C) 1994-2017 Free Software Foundation, Inc. # This Makefile.in is free software; the Free Software Foundation # gives unlimited permission to copy and/or distribute it, # with or without modifications, as long as this notice is preserved. # This program is distributed in the hope that it will be useful, # but WITHOUT ANY WARRANTY, to the extent permitted by law; without # even the implied warranty of MERCHANTABILITY or FITNESS FOR A # PARTICULAR PURPOSE. @SET_MAKE@ VPATH = @srcdir@ am__is_gnu_make = { \ if test -z '$(MAKELEVEL)'; then \ false; \ elif test -n '$(MAKE_HOST)'; then \ true; \ elif test -n '$(MAKE_VERSION)' && test -n '$(CURDIR)'; then \ true; \ else \ false; \ fi; \ } am__make_running_with_option = \ case $${target_option-} in \ ?) ;; \ *) echo "am__make_running_with_option: internal error: invalid" \ "target option '$${target_option-}' specified" >&2; \ exit 1;; \ esac; \ has_opt=no; \ sane_makeflags=$$MAKEFLAGS; \ if $(am__is_gnu_make); then \ sane_makeflags=$$MFLAGS; \ else \ case $$MAKEFLAGS in \ *\\[\ \ ]*) \ bs=\\; \ sane_makeflags=`printf '%s\n' "$$MAKEFLAGS" \ | sed "s/$$bs$$bs[$$bs $$bs ]*//g"`;; \ esac; \ fi; \ skip_next=no; \ strip_trailopt () \ { \ flg=`printf '%s\n' "$$flg" | sed "s/$$1.*$$//"`; \ }; \ for flg in $$sane_makeflags; do \ test $$skip_next = yes && { skip_next=no; continue; }; \ case $$flg in \ *=*|--*) continue;; \ -*I) strip_trailopt 'I'; skip_next=yes;; \ -*I?*) strip_trailopt 'I';; \ -*O) strip_trailopt 'O'; skip_next=yes;; \ -*O?*) strip_trailopt 'O';; \ -*l) strip_trailopt 'l'; skip_next=yes;; \ -*l?*) strip_trailopt 'l';; \ -[dEDm]) skip_next=yes;; \ -[JT]) skip_next=yes;; \ esac; \ case $$flg in \ *$$target_option*) has_opt=yes; break;; \ esac; \ done; \ test $$has_opt = yes am__make_dryrun = (target_option=n; $(am__make_running_with_option)) am__make_keepgoing = (target_option=k; $(am__make_running_with_option)) pkgdatadir = $(datadir)/@PACKAGE@ pkgincludedir = $(includedir)/@PACKAGE@ pkglibdir = $(libdir)/@PACKAGE@ pkglibexecdir = $(libexecdir)/@PACKAGE@ am__cd = CDPATH="$${ZSH_VERSION+.}$(PATH_SEPARATOR)" && cd install_sh_DATA = $(install_sh) -c -m 644 install_sh_PROGRAM = $(install_sh) -c install_sh_SCRIPT = $(install_sh) -c INSTALL_HEADER = $(INSTALL_DATA) transform = $(program_transform_name) NORMAL_INSTALL = : PRE_INSTALL = : POST_INSTALL = : NORMAL_UNINSTALL = : PRE_UNINSTALL = : POST_UNINSTALL = : build_triplet = @build@ host_triplet = @host@ subdir = src/amd64 ACLOCAL_M4 = $(top_srcdir)/aclocal.m4 am__aclocal_m4_deps = $(top_srcdir)/m4/ax_append_compile_flags.m4 \ $(top_srcdir)/m4/ax_append_flag.m4 \ $(top_srcdir)/m4/ax_cflags_warn_all.m4 \ $(top_srcdir)/m4/ax_check_compile_flag.m4 \ $(top_srcdir)/m4/ax_require_defined.m4 \ $(top_srcdir)/m4/libtool.m4 $(top_srcdir)/m4/ltoptions.m4 \ $(top_srcdir)/m4/ltsugar.m4 $(top_srcdir)/m4/ltversion.m4 \ $(top_srcdir)/m4/lt~obsolete.m4 $(top_srcdir)/m4/nasm.m4 \ $(top_srcdir)/m4/pkg.m4 $(top_srcdir)/configure.ac am__configure_deps = $(am__aclocal_m4_deps) $(CONFIGURE_DEPENDENCIES) \ $(ACLOCAL_M4) DIST_COMMON = $(srcdir)/Makefile.am $(am__DIST_COMMON) mkinstalldirs = $(install_sh) -d CONFIG_HEADER = $(top_builddir)/config_ac.h CONFIG_CLEAN_FILES = CONFIG_CLEAN_VPATH_FILES = LTLIBRARIES = $(noinst_LTLIBRARIES) librfxencode_amd64_la_LIBADD = am__objects_1 = cpuid_amd64.lo rfxcodec_encode_dwt_shift_amd64_sse2.lo \ rfxcodec_encode_dwt_shift_amd64_sse41.lo am_librfxencode_amd64_la_OBJECTS = rfxencode_tile_amd64.lo \ $(am__objects_1) librfxencode_amd64_la_OBJECTS = $(am_librfxencode_amd64_la_OBJECTS) AM_V_lt = $(am__v_lt_@AM_V@) am__v_lt_ = $(am__v_lt_@AM_DEFAULT_V@) am__v_lt_0 = --silent am__v_lt_1 = AM_V_P = $(am__v_P_@AM_V@) am__v_P_ = $(am__v_P_@AM_DEFAULT_V@) am__v_P_0 = false am__v_P_1 = : AM_V_GEN = $(am__v_GEN_@AM_V@) am__v_GEN_ = $(am__v_GEN_@AM_DEFAULT_V@) am__v_GEN_0 = @echo " GEN " $@; am__v_GEN_1 = AM_V_at = $(am__v_at_@AM_V@) am__v_at_ = $(am__v_at_@AM_DEFAULT_V@) am__v_at_0 = @ am__v_at_1 = DEFAULT_INCLUDES = -I.@am__isrc@ -I$(top_builddir) depcomp = $(SHELL) $(top_srcdir)/depcomp am__depfiles_maybe = depfiles am__mv = mv -f COMPILE = $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) \ $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) LTCOMPILE = $(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) \ $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) \ $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) \ $(AM_CFLAGS) $(CFLAGS) AM_V_CC = $(am__v_CC_@AM_V@) am__v_CC_ = $(am__v_CC_@AM_DEFAULT_V@) am__v_CC_0 = @echo " CC " $@; am__v_CC_1 = CCLD = $(CC) LINK = $(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) \ $(LIBTOOLFLAGS) --mode=link $(CCLD) $(AM_CFLAGS) $(CFLAGS) \ $(AM_LDFLAGS) $(LDFLAGS) -o $@ AM_V_CCLD = $(am__v_CCLD_@AM_V@) am__v_CCLD_ = $(am__v_CCLD_@AM_DEFAULT_V@) am__v_CCLD_0 = @echo " CCLD " $@; am__v_CCLD_1 = SOURCES = $(librfxencode_amd64_la_SOURCES) DIST_SOURCES = $(librfxencode_amd64_la_SOURCES) am__can_run_installinfo = \ case $$AM_UPDATE_INFO_DIR in \ n|no|NO) false;; \ *) (install-info --version) >/dev/null 2>&1;; \ esac am__tagged_files = $(HEADERS) $(SOURCES) $(TAGS_FILES) $(LISP) # Read a list of newline-separated strings from the standard input, # and print each of them once, without duplicates. Input order is # *not* preserved. am__uniquify_input = $(AWK) '\ BEGIN { nonempty = 0; } \ { items[$$0] = 1; nonempty = 1; } \ END { if (nonempty) { for (i in items) print i; }; } \ ' # Make sure the list of sources is unique. This is necessary because, # e.g., the same source file might be shared among _SOURCES variables # for different programs/libraries. am__define_uniq_tagged_files = \ list='$(am__tagged_files)'; \ unique=`for i in $$list; do \ if test -f "$$i"; then echo $$i; else echo $(srcdir)/$$i; fi; \ done | $(am__uniquify_input)` ETAGS = etags CTAGS = ctags am__DIST_COMMON = $(srcdir)/Makefile.in $(top_srcdir)/depcomp DISTFILES = $(DIST_COMMON) $(DIST_SOURCES) $(TEXINFOS) $(EXTRA_DIST) ACLOCAL = @ACLOCAL@ AMTAR = @AMTAR@ AM_DEFAULT_VERBOSITY = @AM_DEFAULT_VERBOSITY@ AR = @AR@ AUTOCONF = @AUTOCONF@ AUTOHEADER = @AUTOHEADER@ AUTOMAKE = @AUTOMAKE@ AWK = @AWK@ CC = @CC@ CCDEPMODE = @CCDEPMODE@ CFLAGS = @CFLAGS@ CPP = @CPP@ CPPFLAGS = @CPPFLAGS@ CYGPATH_W = @CYGPATH_W@ DEFS = @DEFS@ DEPDIR = @DEPDIR@ DLLTOOL = @DLLTOOL@ DSYMUTIL = @DSYMUTIL@ DUMPBIN = @DUMPBIN@ ECHO_C = @ECHO_C@ ECHO_N = @ECHO_N@ ECHO_T = @ECHO_T@ EGREP = @EGREP@ EXEEXT = @EXEEXT@ FGREP = @FGREP@ GREP = @GREP@ INSTALL = @INSTALL@ INSTALL_DATA = @INSTALL_DATA@ INSTALL_PROGRAM = @INSTALL_PROGRAM@ INSTALL_SCRIPT = @INSTALL_SCRIPT@ INSTALL_STRIP_PROGRAM = @INSTALL_STRIP_PROGRAM@ LD = @LD@ LDFLAGS = @LDFLAGS@ LIBOBJS = @LIBOBJS@ LIBS = @LIBS@ LIBTOOL = @LIBTOOL@ LIPO = @LIPO@ LN_S = @LN_S@ LTLIBOBJS = @LTLIBOBJS@ LT_SYS_LIBRARY_PATH = @LT_SYS_LIBRARY_PATH@ MAKEINFO = @MAKEINFO@ MANIFEST_TOOL = @MANIFEST_TOOL@ MKDIR_P = @MKDIR_P@ NAFLAGS = @NAFLAGS@ -DASM_ARCH_AMD64 NASM = @NASM@ NM = @NM@ NMEDIT = @NMEDIT@ OBJDUMP = @OBJDUMP@ OBJEXT = @OBJEXT@ OTOOL = @OTOOL@ OTOOL64 = @OTOOL64@ PACKAGE = @PACKAGE@ PACKAGE_BUGREPORT = @PACKAGE_BUGREPORT@ PACKAGE_NAME = @PACKAGE_NAME@ PACKAGE_STRING = @PACKAGE_STRING@ PACKAGE_TARNAME = @PACKAGE_TARNAME@ PACKAGE_URL = @PACKAGE_URL@ PACKAGE_VERSION = @PACKAGE_VERSION@ PATH_SEPARATOR = @PATH_SEPARATOR@ RANLIB = @RANLIB@ SED = @SED@ SET_MAKE = @SET_MAKE@ SHELL = @SHELL@ STRIP = @STRIP@ VERSION = @VERSION@ abs_builddir = @abs_builddir@ abs_srcdir = @abs_srcdir@ abs_top_builddir = @abs_top_builddir@ abs_top_srcdir = @abs_top_srcdir@ ac_ct_AR = @ac_ct_AR@ ac_ct_CC = @ac_ct_CC@ ac_ct_DUMPBIN = @ac_ct_DUMPBIN@ am__include = @am__include@ am__leading_dot = @am__leading_dot@ am__quote = @am__quote@ am__tar = @am__tar@ am__untar = @am__untar@ bindir = @bindir@ build = @build@ build_alias = @build_alias@ build_cpu = @build_cpu@ build_os = @build_os@ build_vendor = @build_vendor@ builddir = @builddir@ datadir = @datadir@ datarootdir = @datarootdir@ docdir = @docdir@ dvidir = @dvidir@ exec_prefix = @exec_prefix@ host = @host@ host_alias = @host_alias@ host_cpu = @host_cpu@ host_os = @host_os@ host_vendor = @host_vendor@ htmldir = @htmldir@ includedir = @includedir@ infodir = @infodir@ install_sh = @install_sh@ libdir = @libdir@ libexecdir = @libexecdir@ localedir = @localedir@ localstatedir = @localstatedir@ mandir = @mandir@ mkdir_p = @mkdir_p@ oldincludedir = @oldincludedir@ pdfdir = @pdfdir@ pkgconfigdir = @pkgconfigdir@ prefix = @prefix@ program_transform_name = @program_transform_name@ psdir = @psdir@ sbindir = @sbindir@ sharedstatedir = @sharedstatedir@ srcdir = @srcdir@ sysconfdir = @sysconfdir@ target_alias = @target_alias@ top_build_prefix = @top_build_prefix@ top_builddir = @top_builddir@ top_srcdir = @top_srcdir@ AMD64_ASM = \ cpuid_amd64.asm \ rfxcodec_encode_dwt_shift_amd64_sse2.asm \ rfxcodec_encode_dwt_shift_amd64_sse41.asm AM_CPPFLAGS = \ -I$(top_srcdir)/include \ -I$(top_srcdir)/src noinst_LTLIBRARIES = librfxencode-amd64.la librfxencode_amd64_la_SOURCES = \ funcs_amd64.h \ rfxencode_tile_amd64.c \ $(AMD64_ASM) nasm_verbose = $(nasm_verbose_@AM_V@) nasm_verbose_ = $(nasm_verbose_@AM_DEFAULT_V@) nasm_verbose_0 = @echo " NASM $@"; all: all-am .SUFFIXES: .SUFFIXES: .asm .c .lo .o .obj $(srcdir)/Makefile.in: $(srcdir)/Makefile.am $(am__configure_deps) @for dep in $?; do \ case '$(am__configure_deps)' in \ *$$dep*) \ ( cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh ) \ && { if test -f $@; then exit 0; else break; fi; }; \ exit 1;; \ esac; \ done; \ echo ' cd $(top_srcdir) && $(AUTOMAKE) --foreign src/amd64/Makefile'; \ $(am__cd) $(top_srcdir) && \ $(AUTOMAKE) --foreign src/amd64/Makefile Makefile: $(srcdir)/Makefile.in $(top_builddir)/config.status @case '$?' in \ *config.status*) \ cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh;; \ *) \ echo ' cd $(top_builddir) && $(SHELL) ./config.status $(subdir)/$@ $(am__depfiles_maybe)'; \ cd $(top_builddir) && $(SHELL) ./config.status $(subdir)/$@ $(am__depfiles_maybe);; \ esac; $(top_builddir)/config.status: $(top_srcdir)/configure $(CONFIG_STATUS_DEPENDENCIES) cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh $(top_srcdir)/configure: $(am__configure_deps) cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh $(ACLOCAL_M4): $(am__aclocal_m4_deps) cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh $(am__aclocal_m4_deps): clean-noinstLTLIBRARIES: -test -z "$(noinst_LTLIBRARIES)" || rm -f $(noinst_LTLIBRARIES) @list='$(noinst_LTLIBRARIES)'; \ locs=`for p in $$list; do echo $$p; done | \ sed 's|^[^/]*$$|.|; s|/[^/]*$$||; s|$$|/so_locations|' | \ sort -u`; \ test -z "$$locs" || { \ echo rm -f $${locs}; \ rm -f $${locs}; \ } librfxencode-amd64.la: $(librfxencode_amd64_la_OBJECTS) $(librfxencode_amd64_la_DEPENDENCIES) $(EXTRA_librfxencode_amd64_la_DEPENDENCIES) $(AM_V_CCLD)$(LINK) $(librfxencode_amd64_la_OBJECTS) $(librfxencode_amd64_la_LIBADD) $(LIBS) mostlyclean-compile: -rm -f *.$(OBJEXT) distclean-compile: -rm -f *.tab.c @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/rfxencode_tile_amd64.Plo@am__quote@ .c.o: @am__fastdepCC_TRUE@ $(AM_V_CC)$(COMPILE) -MT $@ -MD -MP -MF $(DEPDIR)/$*.Tpo -c -o $@ $< @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) $(DEPDIR)/$*.Tpo $(DEPDIR)/$*.Po @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='$<' object='$@' libtool=no @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(COMPILE) -c -o $@ $< .c.obj: @am__fastdepCC_TRUE@ $(AM_V_CC)$(COMPILE) -MT $@ -MD -MP -MF $(DEPDIR)/$*.Tpo -c -o $@ `$(CYGPATH_W) '$<'` @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) $(DEPDIR)/$*.Tpo $(DEPDIR)/$*.Po @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='$<' object='$@' libtool=no @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(COMPILE) -c -o $@ `$(CYGPATH_W) '$<'` .c.lo: @am__fastdepCC_TRUE@ $(AM_V_CC)$(LTCOMPILE) -MT $@ -MD -MP -MF $(DEPDIR)/$*.Tpo -c -o $@ $< @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) $(DEPDIR)/$*.Tpo $(DEPDIR)/$*.Plo @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='$<' object='$@' libtool=yes @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(LTCOMPILE) -c -o $@ $< mostlyclean-libtool: -rm -f *.lo clean-libtool: -rm -rf .libs _libs ID: $(am__tagged_files) $(am__define_uniq_tagged_files); mkid -fID $$unique tags: tags-am TAGS: tags tags-am: $(TAGS_DEPENDENCIES) $(am__tagged_files) set x; \ here=`pwd`; \ $(am__define_uniq_tagged_files); \ shift; \ if test -z "$(ETAGS_ARGS)$$*$$unique"; then :; else \ test -n "$$unique" || unique=$$empty_fix; \ if test $$# -gt 0; then \ $(ETAGS) $(ETAGSFLAGS) $(AM_ETAGSFLAGS) $(ETAGS_ARGS) \ "$$@" $$unique; \ else \ $(ETAGS) $(ETAGSFLAGS) $(AM_ETAGSFLAGS) $(ETAGS_ARGS) \ $$unique; \ fi; \ fi ctags: ctags-am CTAGS: ctags ctags-am: $(TAGS_DEPENDENCIES) $(am__tagged_files) $(am__define_uniq_tagged_files); \ test -z "$(CTAGS_ARGS)$$unique" \ || $(CTAGS) $(CTAGSFLAGS) $(AM_CTAGSFLAGS) $(CTAGS_ARGS) \ $$unique GTAGS: here=`$(am__cd) $(top_builddir) && pwd` \ && $(am__cd) $(top_srcdir) \ && gtags -i $(GTAGS_ARGS) "$$here" cscopelist: cscopelist-am cscopelist-am: $(am__tagged_files) list='$(am__tagged_files)'; \ case "$(srcdir)" in \ [\\/]* | ?:[\\/]*) sdir="$(srcdir)" ;; \ *) sdir=$(subdir)/$(srcdir) ;; \ esac; \ for i in $$list; do \ if test -f "$$i"; then \ echo "$(subdir)/$$i"; \ else \ echo "$$sdir/$$i"; \ fi; \ done >> $(top_builddir)/cscope.files distclean-tags: -rm -f TAGS ID GTAGS GRTAGS GSYMS GPATH tags distdir: $(DISTFILES) @srcdirstrip=`echo "$(srcdir)" | sed 's/[].[^$$\\*]/\\\\&/g'`; \ topsrcdirstrip=`echo "$(top_srcdir)" | sed 's/[].[^$$\\*]/\\\\&/g'`; \ list='$(DISTFILES)'; \ dist_files=`for file in $$list; do echo $$file; done | \ sed -e "s|^$$srcdirstrip/||;t" \ -e "s|^$$topsrcdirstrip/|$(top_builddir)/|;t"`; \ case $$dist_files in \ */*) $(MKDIR_P) `echo "$$dist_files" | \ sed '/\//!d;s|^|$(distdir)/|;s,/[^/]*$$,,' | \ sort -u` ;; \ esac; \ for file in $$dist_files; do \ if test -f $$file || test -d $$file; then d=.; else d=$(srcdir); fi; \ if test -d $$d/$$file; then \ dir=`echo "/$$file" | sed -e 's,/[^/]*$$,,'`; \ if test -d "$(distdir)/$$file"; then \ find "$(distdir)/$$file" -type d ! -perm -700 -exec chmod u+rwx {} \;; \ fi; \ if test -d $(srcdir)/$$file && test $$d != $(srcdir); then \ cp -fpR $(srcdir)/$$file "$(distdir)$$dir" || exit 1; \ find "$(distdir)/$$file" -type d ! -perm -700 -exec chmod u+rwx {} \;; \ fi; \ cp -fpR $$d/$$file "$(distdir)$$dir" || exit 1; \ else \ test -f "$(distdir)/$$file" \ || cp -p $$d/$$file "$(distdir)/$$file" \ || exit 1; \ fi; \ done check-am: all-am check: check-am all-am: Makefile $(LTLIBRARIES) installdirs: install: install-am install-exec: install-exec-am install-data: install-data-am uninstall: uninstall-am install-am: all-am @$(MAKE) $(AM_MAKEFLAGS) install-exec-am install-data-am installcheck: installcheck-am install-strip: if test -z '$(STRIP)'; then \ $(MAKE) $(AM_MAKEFLAGS) INSTALL_PROGRAM="$(INSTALL_STRIP_PROGRAM)" \ install_sh_PROGRAM="$(INSTALL_STRIP_PROGRAM)" INSTALL_STRIP_FLAG=-s \ install; \ else \ $(MAKE) $(AM_MAKEFLAGS) INSTALL_PROGRAM="$(INSTALL_STRIP_PROGRAM)" \ install_sh_PROGRAM="$(INSTALL_STRIP_PROGRAM)" INSTALL_STRIP_FLAG=-s \ "INSTALL_PROGRAM_ENV=STRIPPROG='$(STRIP)'" install; \ fi mostlyclean-generic: clean-generic: distclean-generic: -test -z "$(CONFIG_CLEAN_FILES)" || rm -f $(CONFIG_CLEAN_FILES) -test . = "$(srcdir)" || test -z "$(CONFIG_CLEAN_VPATH_FILES)" || rm -f $(CONFIG_CLEAN_VPATH_FILES) maintainer-clean-generic: @echo "This command is intended for maintainers to use" @echo "it deletes files that may require special tools to rebuild." clean: clean-am clean-am: clean-generic clean-libtool clean-noinstLTLIBRARIES \ mostlyclean-am distclean: distclean-am -rm -rf ./$(DEPDIR) -rm -f Makefile distclean-am: clean-am distclean-compile distclean-generic \ distclean-tags dvi: dvi-am dvi-am: html: html-am html-am: info: info-am info-am: install-data-am: install-dvi: install-dvi-am install-dvi-am: install-exec-am: install-html: install-html-am install-html-am: install-info: install-info-am install-info-am: install-man: install-pdf: install-pdf-am install-pdf-am: install-ps: install-ps-am install-ps-am: installcheck-am: maintainer-clean: maintainer-clean-am -rm -rf ./$(DEPDIR) -rm -f Makefile maintainer-clean-am: distclean-am maintainer-clean-generic mostlyclean: mostlyclean-am mostlyclean-am: mostlyclean-compile mostlyclean-generic \ mostlyclean-libtool pdf: pdf-am pdf-am: ps: ps-am ps-am: uninstall-am: .MAKE: install-am install-strip .PHONY: CTAGS GTAGS TAGS all all-am check check-am clean clean-generic \ clean-libtool clean-noinstLTLIBRARIES cscopelist-am ctags \ ctags-am distclean distclean-compile distclean-generic \ distclean-libtool distclean-tags distdir dvi dvi-am html \ html-am info info-am install install-am install-data \ install-data-am install-dvi install-dvi-am install-exec \ install-exec-am install-html install-html-am install-info \ install-info-am install-man install-pdf install-pdf-am \ install-ps install-ps-am install-strip installcheck \ installcheck-am installdirs maintainer-clean \ maintainer-clean-generic mostlyclean mostlyclean-compile \ mostlyclean-generic mostlyclean-libtool pdf pdf-am ps ps-am \ tags tags-am uninstall uninstall-am .PRECIOUS: Makefile .asm.lo: $(nasm_verbose)$(LIBTOOL) $(AM_V_lt) --mode=compile \ $(top_srcdir)/src/nasm_lt.sh $(NASM) $(NAFLAGS) \ -I$(top_srcdir)/src $< -o $@ # Tell versions [3.59,3.63) of GNU make to not export all variables. # Otherwise a system limit (for SysV at least) may be exceeded. .NOEXPORT: xrdp-0.9.5/librfxcodec/tests/rfxencode.c000644 001751 001751 00000017266 13127342056 020210 0ustar00metameta000000 000000 /** * RFX codec encoder test * * Copyright 2014-2017 Jay Sorg * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ #if defined(HAVE_CONFIG_H) #include #endif #include #include #include #include #include #include #include #include #include #define MAX_OUT_DATA_BYTES (1024 * 1024) #define MAX_BMP_DATA_BYTES (10 * 1024 * 1024) static char g_in_filename[256] = ""; static char g_out_filename[256] = ""; static int g_count = 1; static int g_no_accel = 0; static int g_use_rlgr1 = 0; struct bmp_magic { char magic[2]; }; struct bmp_hdr { unsigned int size; unsigned short reserved1; unsigned short reserved2; unsigned int offset; }; struct dib_hdr { unsigned int hdr_size; int width; int height; unsigned short nplanes; unsigned short bpp; unsigned int compress_type; unsigned int image_size; int hres; int vres; unsigned int ncolors; unsigned int nimpcolors; }; static int read_bitmap(char *file_name, int *width, int *height, int *bpp, char *bmp_data) { int i; int j; int e; int fd; int file_stride_bytes; int pixel; struct bmp_magic bm; struct bmp_hdr bh; struct dib_hdr dh; unsigned char *src8; int *src32; int *dst32; fd = open(file_name, O_RDONLY); if (fd == -1) { return 1; } if (read(fd, &bm, sizeof(bm)) != sizeof(bm)) { close(fd); return 1; } if (read(fd, &bh, sizeof(bh)) != sizeof(bh)) { close(fd); return 1; } if (read(fd, &dh, sizeof(dh)) != sizeof(dh)) { close(fd); return 1; } if (dh.bpp != 24 && dh.bpp != 32) { printf("error, only support 24 and 32 bpp\n"); close(fd); return 1; } *width = dh.width; *height = dh.height; *bpp = dh.bpp; file_stride_bytes = dh.width * ((dh.bpp + 7) / 8); e = (4 - file_stride_bytes) & 3; src8 = (unsigned char *) malloc(file_stride_bytes * 4); for (j = 0; j < dh.height; j++) { dst32 = (int *) (bmp_data + (dh.width * dh.height * 4) - ((j + 1) * dh.width * 4)); if (read(fd, src8, file_stride_bytes + e) != file_stride_bytes + e) { free(src8); close(fd); return 1; } if (dh.bpp == 32) { src32 = (int *) src8; for (i = 0; i < dh.width; i++) { pixel = src32[i]; dst32[i] = pixel; } } else if (dh.bpp == 24) { for (i = 0; i < dh.width; i++) { pixel = src8[i * 3 + 0] << 0; pixel |= src8[i * 3 + 1] << 8; pixel |= src8[i * 3 + 2] << 16; dst32[i] = pixel; } } } free(src8); close(fd); return 0; } int out_params(void) { printf("rfxencode: a RemoteFX encoder testing program.\n"); printf(" -i bmp file\n"); printf(" -o rfx file\n"); printf(" -c times to loop\n"); printf(" -n no accel\n"); printf(" -1 use rlgr1\n"); return 0; } int process(void) { char *out_data; char *bmp_data; int out_fd; int out_bytes; int error; int index; int index_x; int index_y; void *han; int num_tiles; int num_tiles_x; int num_tiles_y; int flags; int width; int height; int bpp; struct rfx_rect region; struct rfx_tile *tiles; struct rfx_tile *tile; out_data = (char *) malloc(MAX_OUT_DATA_BYTES); bmp_data = (char *) malloc(MAX_BMP_DATA_BYTES); memset(bmp_data, 0xff, MAX_BMP_DATA_BYTES); if (read_bitmap(g_in_filename, &width, &height, &bpp, bmp_data) != 0) { printf("read bitmap failed\n"); free(bmp_data); free(out_data); return 1; } printf("process: got bitmap width %d height %d bpp %d\n", width, height, bpp); flags = 0; if (g_no_accel) { flags |= RFX_FLAGS_NOACCEL; } if (g_use_rlgr1) { flags |= RFX_FLAGS_RLGR1; } han = rfxcodec_encode_create(1920, 1080, RFX_FORMAT_BGRA, flags); region.x = 0; region.y = 0; region.cx = width; region.cy = height; num_tiles_x = (width + 63) / 64; num_tiles_y = (height + 63) / 64; num_tiles = num_tiles_x * num_tiles_y; tiles = (struct rfx_tile *) calloc(num_tiles, sizeof(struct rfx_tile)); if (tiles == NULL) { free(bmp_data); free(out_data); return 1; } for (index_y = 0; index_y < num_tiles_y; index_y++) { for (index_x = 0; index_x < num_tiles_x; index_x++) { tile = tiles + (index_y * num_tiles_x + index_x); tile->x = index_x * 64; tile->y = index_y * 64; tile->cx = 64; tile->cy = 64; } } if (han != NULL) { error = 0; for (index = 0; index < g_count; index++) { out_bytes = 1024 * 1024; error = rfxcodec_encode(han, out_data, &out_bytes, bmp_data, width, height, width * 4, ®ion, 1, tiles, num_tiles, NULL, 0); if (error != 0) { break; } } printf("error %d out_bytes %d num_tiles %d\n", error, out_bytes, num_tiles); if (g_out_filename[0] != 0) { out_fd = open(g_out_filename, O_RDWR | O_CREAT | O_TRUNC, S_IRUSR | S_IWUSR); if (out_fd == -1) { printf("failed to open %s\n", g_out_filename); free(bmp_data); free(out_data); free(tiles); return 1; } if (write(out_fd, out_data, out_bytes) != out_bytes) { printf("write failed\n"); free(bmp_data); free(out_data); free(tiles); close(out_fd); return 1; } close(out_fd); } } rfxcodec_encode_destroy(han); free(bmp_data); free(out_data); free(tiles); return 0; } int main(int argc, char **argv) { int index; if (argc < 2) { out_params(); return 0; } for (index = 1; index < argc; index++) { if (strcmp(argv[index], "-i") == 0) { index++; strcpy(g_in_filename, argv[index]); } else if (strcmp(argv[index], "-o") == 0) { index++; strcpy(g_out_filename, argv[index]); } else if (strcmp(argv[index], "-c") == 0) { index++; g_count = atoi(argv[index]); } else if (strcmp(argv[index], "-n") == 0) { g_no_accel = 1; } else if (strcmp(argv[index], "-1") == 0) { g_use_rlgr1 = 1; } else { out_params(); return 0; } } process(); return 0; } xrdp-0.9.5/librfxcodec/tests/Makefile.am000644 001751 001751 00000000456 13061652764 020123 0ustar00metameta000000 000000 EXTRA_DIST = readme.txt AM_CPPFLAGS = \ -I$(top_srcdir)/include check_PROGRAMS = rfxcodectest rfxencode rfxcodectest_SOURCES = rfxcodectest.c rfxencode_SOURCES = rfxencode.c rfxcodectest_LDADD = \ $(top_builddir)/src/librfxencode.la rfxencode_LDADD = \ $(top_builddir)/src/librfxencode.la xrdp-0.9.5/librfxcodec/tests/readme.txt000644 001751 001751 00000000262 12446253657 020064 0ustar00metameta000000 000000 profiling the test build with -pg run make clean make PROFIL=-pg run tests/rfxcodectest --speed --count 10000 gprof -b tests/rfxcodectest > profile.txt look at profile.txt xrdp-0.9.5/librfxcodec/tests/Makefile.in000644 001751 001751 00000044036 13220730761 020125 0ustar00metameta000000 000000 # Makefile.in generated by automake 1.15.1 from Makefile.am. # @configure_input@ # Copyright (C) 1994-2017 Free Software Foundation, Inc. # This Makefile.in is free software; the Free Software Foundation # gives unlimited permission to copy and/or distribute it, # with or without modifications, as long as this notice is preserved. # This program is distributed in the hope that it will be useful, # but WITHOUT ANY WARRANTY, to the extent permitted by law; without # even the implied warranty of MERCHANTABILITY or FITNESS FOR A # PARTICULAR PURPOSE. @SET_MAKE@ VPATH = @srcdir@ am__is_gnu_make = { \ if test -z '$(MAKELEVEL)'; then \ false; \ elif test -n '$(MAKE_HOST)'; then \ true; \ elif test -n '$(MAKE_VERSION)' && test -n '$(CURDIR)'; then \ true; \ else \ false; \ fi; \ } am__make_running_with_option = \ case $${target_option-} in \ ?) ;; \ *) echo "am__make_running_with_option: internal error: invalid" \ "target option '$${target_option-}' specified" >&2; \ exit 1;; \ esac; \ has_opt=no; \ sane_makeflags=$$MAKEFLAGS; \ if $(am__is_gnu_make); then \ sane_makeflags=$$MFLAGS; \ else \ case $$MAKEFLAGS in \ *\\[\ \ ]*) \ bs=\\; \ sane_makeflags=`printf '%s\n' "$$MAKEFLAGS" \ | sed "s/$$bs$$bs[$$bs $$bs ]*//g"`;; \ esac; \ fi; \ skip_next=no; \ strip_trailopt () \ { \ flg=`printf '%s\n' "$$flg" | sed "s/$$1.*$$//"`; \ }; \ for flg in $$sane_makeflags; do \ test $$skip_next = yes && { skip_next=no; continue; }; \ case $$flg in \ *=*|--*) continue;; \ -*I) strip_trailopt 'I'; skip_next=yes;; \ -*I?*) strip_trailopt 'I';; \ -*O) strip_trailopt 'O'; skip_next=yes;; \ -*O?*) strip_trailopt 'O';; \ -*l) strip_trailopt 'l'; skip_next=yes;; \ -*l?*) strip_trailopt 'l';; \ -[dEDm]) skip_next=yes;; \ -[JT]) skip_next=yes;; \ esac; \ case $$flg in \ *$$target_option*) has_opt=yes; break;; \ esac; \ done; \ test $$has_opt = yes am__make_dryrun = (target_option=n; $(am__make_running_with_option)) am__make_keepgoing = (target_option=k; $(am__make_running_with_option)) pkgdatadir = $(datadir)/@PACKAGE@ pkgincludedir = $(includedir)/@PACKAGE@ pkglibdir = $(libdir)/@PACKAGE@ pkglibexecdir = $(libexecdir)/@PACKAGE@ am__cd = CDPATH="$${ZSH_VERSION+.}$(PATH_SEPARATOR)" && cd install_sh_DATA = $(install_sh) -c -m 644 install_sh_PROGRAM = $(install_sh) -c install_sh_SCRIPT = $(install_sh) -c INSTALL_HEADER = $(INSTALL_DATA) transform = $(program_transform_name) NORMAL_INSTALL = : PRE_INSTALL = : POST_INSTALL = : NORMAL_UNINSTALL = : PRE_UNINSTALL = : POST_UNINSTALL = : build_triplet = @build@ host_triplet = @host@ check_PROGRAMS = rfxcodectest$(EXEEXT) rfxencode$(EXEEXT) subdir = tests ACLOCAL_M4 = $(top_srcdir)/aclocal.m4 am__aclocal_m4_deps = $(top_srcdir)/m4/ax_append_compile_flags.m4 \ $(top_srcdir)/m4/ax_append_flag.m4 \ $(top_srcdir)/m4/ax_cflags_warn_all.m4 \ $(top_srcdir)/m4/ax_check_compile_flag.m4 \ $(top_srcdir)/m4/ax_require_defined.m4 \ $(top_srcdir)/m4/libtool.m4 $(top_srcdir)/m4/ltoptions.m4 \ $(top_srcdir)/m4/ltsugar.m4 $(top_srcdir)/m4/ltversion.m4 \ $(top_srcdir)/m4/lt~obsolete.m4 $(top_srcdir)/m4/nasm.m4 \ $(top_srcdir)/m4/pkg.m4 $(top_srcdir)/configure.ac am__configure_deps = $(am__aclocal_m4_deps) $(CONFIGURE_DEPENDENCIES) \ $(ACLOCAL_M4) DIST_COMMON = $(srcdir)/Makefile.am $(am__DIST_COMMON) mkinstalldirs = $(install_sh) -d CONFIG_HEADER = $(top_builddir)/config_ac.h CONFIG_CLEAN_FILES = CONFIG_CLEAN_VPATH_FILES = am_rfxcodectest_OBJECTS = rfxcodectest.$(OBJEXT) rfxcodectest_OBJECTS = $(am_rfxcodectest_OBJECTS) rfxcodectest_DEPENDENCIES = $(top_builddir)/src/librfxencode.la AM_V_lt = $(am__v_lt_@AM_V@) am__v_lt_ = $(am__v_lt_@AM_DEFAULT_V@) am__v_lt_0 = --silent am__v_lt_1 = am_rfxencode_OBJECTS = rfxencode.$(OBJEXT) rfxencode_OBJECTS = $(am_rfxencode_OBJECTS) rfxencode_DEPENDENCIES = $(top_builddir)/src/librfxencode.la AM_V_P = $(am__v_P_@AM_V@) am__v_P_ = $(am__v_P_@AM_DEFAULT_V@) am__v_P_0 = false am__v_P_1 = : AM_V_GEN = $(am__v_GEN_@AM_V@) am__v_GEN_ = $(am__v_GEN_@AM_DEFAULT_V@) am__v_GEN_0 = @echo " GEN " $@; am__v_GEN_1 = AM_V_at = $(am__v_at_@AM_V@) am__v_at_ = $(am__v_at_@AM_DEFAULT_V@) am__v_at_0 = @ am__v_at_1 = DEFAULT_INCLUDES = -I.@am__isrc@ -I$(top_builddir) depcomp = $(SHELL) $(top_srcdir)/depcomp am__depfiles_maybe = depfiles am__mv = mv -f COMPILE = $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) \ $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) LTCOMPILE = $(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) \ $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) \ $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) \ $(AM_CFLAGS) $(CFLAGS) AM_V_CC = $(am__v_CC_@AM_V@) am__v_CC_ = $(am__v_CC_@AM_DEFAULT_V@) am__v_CC_0 = @echo " CC " $@; am__v_CC_1 = CCLD = $(CC) LINK = $(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) \ $(LIBTOOLFLAGS) --mode=link $(CCLD) $(AM_CFLAGS) $(CFLAGS) \ $(AM_LDFLAGS) $(LDFLAGS) -o $@ AM_V_CCLD = $(am__v_CCLD_@AM_V@) am__v_CCLD_ = $(am__v_CCLD_@AM_DEFAULT_V@) am__v_CCLD_0 = @echo " CCLD " $@; am__v_CCLD_1 = SOURCES = $(rfxcodectest_SOURCES) $(rfxencode_SOURCES) DIST_SOURCES = $(rfxcodectest_SOURCES) $(rfxencode_SOURCES) am__can_run_installinfo = \ case $$AM_UPDATE_INFO_DIR in \ n|no|NO) false;; \ *) (install-info --version) >/dev/null 2>&1;; \ esac am__tagged_files = $(HEADERS) $(SOURCES) $(TAGS_FILES) $(LISP) # Read a list of newline-separated strings from the standard input, # and print each of them once, without duplicates. Input order is # *not* preserved. am__uniquify_input = $(AWK) '\ BEGIN { nonempty = 0; } \ { items[$$0] = 1; nonempty = 1; } \ END { if (nonempty) { for (i in items) print i; }; } \ ' # Make sure the list of sources is unique. This is necessary because, # e.g., the same source file might be shared among _SOURCES variables # for different programs/libraries. am__define_uniq_tagged_files = \ list='$(am__tagged_files)'; \ unique=`for i in $$list; do \ if test -f "$$i"; then echo $$i; else echo $(srcdir)/$$i; fi; \ done | $(am__uniquify_input)` ETAGS = etags CTAGS = ctags am__DIST_COMMON = $(srcdir)/Makefile.in $(top_srcdir)/depcomp DISTFILES = $(DIST_COMMON) $(DIST_SOURCES) $(TEXINFOS) $(EXTRA_DIST) ACLOCAL = @ACLOCAL@ AMTAR = @AMTAR@ AM_DEFAULT_VERBOSITY = @AM_DEFAULT_VERBOSITY@ AR = @AR@ AUTOCONF = @AUTOCONF@ AUTOHEADER = @AUTOHEADER@ AUTOMAKE = @AUTOMAKE@ AWK = @AWK@ CC = @CC@ CCDEPMODE = @CCDEPMODE@ CFLAGS = @CFLAGS@ CPP = @CPP@ CPPFLAGS = @CPPFLAGS@ CYGPATH_W = @CYGPATH_W@ DEFS = @DEFS@ DEPDIR = @DEPDIR@ DLLTOOL = @DLLTOOL@ DSYMUTIL = @DSYMUTIL@ DUMPBIN = @DUMPBIN@ ECHO_C = @ECHO_C@ ECHO_N = @ECHO_N@ ECHO_T = @ECHO_T@ EGREP = @EGREP@ EXEEXT = @EXEEXT@ FGREP = @FGREP@ GREP = @GREP@ INSTALL = @INSTALL@ INSTALL_DATA = @INSTALL_DATA@ INSTALL_PROGRAM = @INSTALL_PROGRAM@ INSTALL_SCRIPT = @INSTALL_SCRIPT@ INSTALL_STRIP_PROGRAM = @INSTALL_STRIP_PROGRAM@ LD = @LD@ LDFLAGS = @LDFLAGS@ LIBOBJS = @LIBOBJS@ LIBS = @LIBS@ LIBTOOL = @LIBTOOL@ LIPO = @LIPO@ LN_S = @LN_S@ LTLIBOBJS = @LTLIBOBJS@ LT_SYS_LIBRARY_PATH = @LT_SYS_LIBRARY_PATH@ MAKEINFO = @MAKEINFO@ MANIFEST_TOOL = @MANIFEST_TOOL@ MKDIR_P = @MKDIR_P@ NAFLAGS = @NAFLAGS@ NASM = @NASM@ NM = @NM@ NMEDIT = @NMEDIT@ OBJDUMP = @OBJDUMP@ OBJEXT = @OBJEXT@ OTOOL = @OTOOL@ OTOOL64 = @OTOOL64@ PACKAGE = @PACKAGE@ PACKAGE_BUGREPORT = @PACKAGE_BUGREPORT@ PACKAGE_NAME = @PACKAGE_NAME@ PACKAGE_STRING = @PACKAGE_STRING@ PACKAGE_TARNAME = @PACKAGE_TARNAME@ PACKAGE_URL = @PACKAGE_URL@ PACKAGE_VERSION = @PACKAGE_VERSION@ PATH_SEPARATOR = @PATH_SEPARATOR@ RANLIB = @RANLIB@ SED = @SED@ SET_MAKE = @SET_MAKE@ SHELL = @SHELL@ STRIP = @STRIP@ VERSION = @VERSION@ abs_builddir = @abs_builddir@ abs_srcdir = @abs_srcdir@ abs_top_builddir = @abs_top_builddir@ abs_top_srcdir = @abs_top_srcdir@ ac_ct_AR = @ac_ct_AR@ ac_ct_CC = @ac_ct_CC@ ac_ct_DUMPBIN = @ac_ct_DUMPBIN@ am__include = @am__include@ am__leading_dot = @am__leading_dot@ am__quote = @am__quote@ am__tar = @am__tar@ am__untar = @am__untar@ bindir = @bindir@ build = @build@ build_alias = @build_alias@ build_cpu = @build_cpu@ build_os = @build_os@ build_vendor = @build_vendor@ builddir = @builddir@ datadir = @datadir@ datarootdir = @datarootdir@ docdir = @docdir@ dvidir = @dvidir@ exec_prefix = @exec_prefix@ host = @host@ host_alias = @host_alias@ host_cpu = @host_cpu@ host_os = @host_os@ host_vendor = @host_vendor@ htmldir = @htmldir@ includedir = @includedir@ infodir = @infodir@ install_sh = @install_sh@ libdir = @libdir@ libexecdir = @libexecdir@ localedir = @localedir@ localstatedir = @localstatedir@ mandir = @mandir@ mkdir_p = @mkdir_p@ oldincludedir = @oldincludedir@ pdfdir = @pdfdir@ pkgconfigdir = @pkgconfigdir@ prefix = @prefix@ program_transform_name = @program_transform_name@ psdir = @psdir@ sbindir = @sbindir@ sharedstatedir = @sharedstatedir@ srcdir = @srcdir@ sysconfdir = @sysconfdir@ target_alias = @target_alias@ top_build_prefix = @top_build_prefix@ top_builddir = @top_builddir@ top_srcdir = @top_srcdir@ EXTRA_DIST = readme.txt AM_CPPFLAGS = \ -I$(top_srcdir)/include rfxcodectest_SOURCES = rfxcodectest.c rfxencode_SOURCES = rfxencode.c rfxcodectest_LDADD = \ $(top_builddir)/src/librfxencode.la rfxencode_LDADD = \ $(top_builddir)/src/librfxencode.la all: all-am .SUFFIXES: .SUFFIXES: .c .lo .o .obj $(srcdir)/Makefile.in: $(srcdir)/Makefile.am $(am__configure_deps) @for dep in $?; do \ case '$(am__configure_deps)' in \ *$$dep*) \ ( cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh ) \ && { if test -f $@; then exit 0; else break; fi; }; \ exit 1;; \ esac; \ done; \ echo ' cd $(top_srcdir) && $(AUTOMAKE) --foreign tests/Makefile'; \ $(am__cd) $(top_srcdir) && \ $(AUTOMAKE) --foreign tests/Makefile Makefile: $(srcdir)/Makefile.in $(top_builddir)/config.status @case '$?' in \ *config.status*) \ cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh;; \ *) \ echo ' cd $(top_builddir) && $(SHELL) ./config.status $(subdir)/$@ $(am__depfiles_maybe)'; \ cd $(top_builddir) && $(SHELL) ./config.status $(subdir)/$@ $(am__depfiles_maybe);; \ esac; $(top_builddir)/config.status: $(top_srcdir)/configure $(CONFIG_STATUS_DEPENDENCIES) cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh $(top_srcdir)/configure: $(am__configure_deps) cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh $(ACLOCAL_M4): $(am__aclocal_m4_deps) cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh $(am__aclocal_m4_deps): clean-checkPROGRAMS: @list='$(check_PROGRAMS)'; test -n "$$list" || exit 0; \ echo " rm -f" $$list; \ rm -f $$list || exit $$?; \ test -n "$(EXEEXT)" || exit 0; \ list=`for p in $$list; do echo "$$p"; done | sed 's/$(EXEEXT)$$//'`; \ echo " rm -f" $$list; \ rm -f $$list rfxcodectest$(EXEEXT): $(rfxcodectest_OBJECTS) $(rfxcodectest_DEPENDENCIES) $(EXTRA_rfxcodectest_DEPENDENCIES) @rm -f rfxcodectest$(EXEEXT) $(AM_V_CCLD)$(LINK) $(rfxcodectest_OBJECTS) $(rfxcodectest_LDADD) $(LIBS) rfxencode$(EXEEXT): $(rfxencode_OBJECTS) $(rfxencode_DEPENDENCIES) $(EXTRA_rfxencode_DEPENDENCIES) @rm -f rfxencode$(EXEEXT) $(AM_V_CCLD)$(LINK) $(rfxencode_OBJECTS) $(rfxencode_LDADD) $(LIBS) mostlyclean-compile: -rm -f *.$(OBJEXT) distclean-compile: -rm -f *.tab.c @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/rfxcodectest.Po@am__quote@ @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/rfxencode.Po@am__quote@ .c.o: @am__fastdepCC_TRUE@ $(AM_V_CC)$(COMPILE) -MT $@ -MD -MP -MF $(DEPDIR)/$*.Tpo -c -o $@ $< @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) $(DEPDIR)/$*.Tpo $(DEPDIR)/$*.Po @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='$<' object='$@' libtool=no @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(COMPILE) -c -o $@ $< .c.obj: @am__fastdepCC_TRUE@ $(AM_V_CC)$(COMPILE) -MT $@ -MD -MP -MF $(DEPDIR)/$*.Tpo -c -o $@ `$(CYGPATH_W) '$<'` @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) $(DEPDIR)/$*.Tpo $(DEPDIR)/$*.Po @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='$<' object='$@' libtool=no @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(COMPILE) -c -o $@ `$(CYGPATH_W) '$<'` .c.lo: @am__fastdepCC_TRUE@ $(AM_V_CC)$(LTCOMPILE) -MT $@ -MD -MP -MF $(DEPDIR)/$*.Tpo -c -o $@ $< @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) $(DEPDIR)/$*.Tpo $(DEPDIR)/$*.Plo @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='$<' object='$@' libtool=yes @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(LTCOMPILE) -c -o $@ $< mostlyclean-libtool: -rm -f *.lo clean-libtool: -rm -rf .libs _libs ID: $(am__tagged_files) $(am__define_uniq_tagged_files); mkid -fID $$unique tags: tags-am TAGS: tags tags-am: $(TAGS_DEPENDENCIES) $(am__tagged_files) set x; \ here=`pwd`; \ $(am__define_uniq_tagged_files); \ shift; \ if test -z "$(ETAGS_ARGS)$$*$$unique"; then :; else \ test -n "$$unique" || unique=$$empty_fix; \ if test $$# -gt 0; then \ $(ETAGS) $(ETAGSFLAGS) $(AM_ETAGSFLAGS) $(ETAGS_ARGS) \ "$$@" $$unique; \ else \ $(ETAGS) $(ETAGSFLAGS) $(AM_ETAGSFLAGS) $(ETAGS_ARGS) \ $$unique; \ fi; \ fi ctags: ctags-am CTAGS: ctags ctags-am: $(TAGS_DEPENDENCIES) $(am__tagged_files) $(am__define_uniq_tagged_files); \ test -z "$(CTAGS_ARGS)$$unique" \ || $(CTAGS) $(CTAGSFLAGS) $(AM_CTAGSFLAGS) $(CTAGS_ARGS) \ $$unique GTAGS: here=`$(am__cd) $(top_builddir) && pwd` \ && $(am__cd) $(top_srcdir) \ && gtags -i $(GTAGS_ARGS) "$$here" cscopelist: cscopelist-am cscopelist-am: $(am__tagged_files) list='$(am__tagged_files)'; \ case "$(srcdir)" in \ [\\/]* | ?:[\\/]*) sdir="$(srcdir)" ;; \ *) sdir=$(subdir)/$(srcdir) ;; \ esac; \ for i in $$list; do \ if test -f "$$i"; then \ echo "$(subdir)/$$i"; \ else \ echo "$$sdir/$$i"; \ fi; \ done >> $(top_builddir)/cscope.files distclean-tags: -rm -f TAGS ID GTAGS GRTAGS GSYMS GPATH tags distdir: $(DISTFILES) @srcdirstrip=`echo "$(srcdir)" | sed 's/[].[^$$\\*]/\\\\&/g'`; \ topsrcdirstrip=`echo "$(top_srcdir)" | sed 's/[].[^$$\\*]/\\\\&/g'`; \ list='$(DISTFILES)'; \ dist_files=`for file in $$list; do echo $$file; done | \ sed -e "s|^$$srcdirstrip/||;t" \ -e "s|^$$topsrcdirstrip/|$(top_builddir)/|;t"`; \ case $$dist_files in \ */*) $(MKDIR_P) `echo "$$dist_files" | \ sed '/\//!d;s|^|$(distdir)/|;s,/[^/]*$$,,' | \ sort -u` ;; \ esac; \ for file in $$dist_files; do \ if test -f $$file || test -d $$file; then d=.; else d=$(srcdir); fi; \ if test -d $$d/$$file; then \ dir=`echo "/$$file" | sed -e 's,/[^/]*$$,,'`; \ if test -d "$(distdir)/$$file"; then \ find "$(distdir)/$$file" -type d ! -perm -700 -exec chmod u+rwx {} \;; \ fi; \ if test -d $(srcdir)/$$file && test $$d != $(srcdir); then \ cp -fpR $(srcdir)/$$file "$(distdir)$$dir" || exit 1; \ find "$(distdir)/$$file" -type d ! -perm -700 -exec chmod u+rwx {} \;; \ fi; \ cp -fpR $$d/$$file "$(distdir)$$dir" || exit 1; \ else \ test -f "$(distdir)/$$file" \ || cp -p $$d/$$file "$(distdir)/$$file" \ || exit 1; \ fi; \ done check-am: all-am $(MAKE) $(AM_MAKEFLAGS) $(check_PROGRAMS) check: check-am all-am: Makefile installdirs: install: install-am install-exec: install-exec-am install-data: install-data-am uninstall: uninstall-am install-am: all-am @$(MAKE) $(AM_MAKEFLAGS) install-exec-am install-data-am installcheck: installcheck-am install-strip: if test -z '$(STRIP)'; then \ $(MAKE) $(AM_MAKEFLAGS) INSTALL_PROGRAM="$(INSTALL_STRIP_PROGRAM)" \ install_sh_PROGRAM="$(INSTALL_STRIP_PROGRAM)" INSTALL_STRIP_FLAG=-s \ install; \ else \ $(MAKE) $(AM_MAKEFLAGS) INSTALL_PROGRAM="$(INSTALL_STRIP_PROGRAM)" \ install_sh_PROGRAM="$(INSTALL_STRIP_PROGRAM)" INSTALL_STRIP_FLAG=-s \ "INSTALL_PROGRAM_ENV=STRIPPROG='$(STRIP)'" install; \ fi mostlyclean-generic: clean-generic: distclean-generic: -test -z "$(CONFIG_CLEAN_FILES)" || rm -f $(CONFIG_CLEAN_FILES) -test . = "$(srcdir)" || test -z "$(CONFIG_CLEAN_VPATH_FILES)" || rm -f $(CONFIG_CLEAN_VPATH_FILES) maintainer-clean-generic: @echo "This command is intended for maintainers to use" @echo "it deletes files that may require special tools to rebuild." clean: clean-am clean-am: clean-checkPROGRAMS clean-generic clean-libtool \ mostlyclean-am distclean: distclean-am -rm -rf ./$(DEPDIR) -rm -f Makefile distclean-am: clean-am distclean-compile distclean-generic \ distclean-tags dvi: dvi-am dvi-am: html: html-am html-am: info: info-am info-am: install-data-am: install-dvi: install-dvi-am install-dvi-am: install-exec-am: install-html: install-html-am install-html-am: install-info: install-info-am install-info-am: install-man: install-pdf: install-pdf-am install-pdf-am: install-ps: install-ps-am install-ps-am: installcheck-am: maintainer-clean: maintainer-clean-am -rm -rf ./$(DEPDIR) -rm -f Makefile maintainer-clean-am: distclean-am maintainer-clean-generic mostlyclean: mostlyclean-am mostlyclean-am: mostlyclean-compile mostlyclean-generic \ mostlyclean-libtool pdf: pdf-am pdf-am: ps: ps-am ps-am: uninstall-am: .MAKE: check-am install-am install-strip .PHONY: CTAGS GTAGS TAGS all all-am check check-am clean \ clean-checkPROGRAMS clean-generic clean-libtool cscopelist-am \ ctags ctags-am distclean distclean-compile distclean-generic \ distclean-libtool distclean-tags distdir dvi dvi-am html \ html-am info info-am install install-am install-data \ install-data-am install-dvi install-dvi-am install-exec \ install-exec-am install-html install-html-am install-info \ install-info-am install-man install-pdf install-pdf-am \ install-ps install-ps-am install-strip installcheck \ installcheck-am installdirs maintainer-clean \ maintainer-clean-generic mostlyclean mostlyclean-compile \ mostlyclean-generic mostlyclean-libtool pdf pdf-am ps ps-am \ tags tags-am uninstall uninstall-am .PRECIOUS: Makefile # Tell versions [3.59,3.63) of GNU make to not export all variables. # Otherwise a system limit (for SysV at least) may be exceeded. .NOEXPORT: xrdp-0.9.5/librfxcodec/tests/rfxcodectest.c000644 001751 001751 00000026047 13127342056 020725 0ustar00metameta000000 000000 /** * RFX codec encoder test * * Copyright 2014-2017 Jay Sorg * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ #if defined(HAVE_CONFIG_H) #include #endif #include #include #include #include #include #include #include #include #include static const unsigned char g_rfx_default_quantization_values[] = { /* LL3 LH3 HL3 HH3 LH2 HL2 HH2 LH1 HL1 HH1 */ 0x66, 0x66, 0x77, 0x88, 0x98, 0x99, 0x99, 0xaa, 0xcc, 0xdc }; /*****************************************************************************/ static int get_mstime(void) { struct timeval tp; gettimeofday(&tp, 0); return (tp.tv_sec * 1000) + (tp.tv_usec / 1000); } /******************************************************************************/ static int speed_random(int count, const char *quants) { void *han; int error; int index; int cdata_bytes; int fd; char *cdata; char *buf; struct rfx_rect regions[1]; struct rfx_tile tiles[2]; int stime; int etime; int tiles_per_second; int num_regions; int num_tiles; int num_quants; int flags; printf("speed_random:\n"); //flags = RFX_FLAGS_RLGR1 | RFX_FLAGS_NOACCEL; flags = RFX_FLAGS_RLGR1; //flags = RFX_FLAGS_RLGR3; //flags = RFX_FLAGS_RLGR1 | RFX_FLAGS_ALPHAV1; error = rfxcodec_encode_create_ex(1920, 1024, RFX_FORMAT_BGRA, flags, &han); if (error != 0) { printf("speed_random: rfxcodec_encode_create_ex failed\n"); return 1; } printf("speed_random: rfxcodec_encode_create_ex ok\n"); cdata = (char *) malloc(128 * 64 * 4); cdata_bytes = 128 * 64 * 4; buf = (char *) malloc(128 * 64 * 4); #if 1 fd = open("/dev/urandom", O_RDONLY); //fd = open("/dev/zero", O_RDONLY); if (read(fd, buf, 128 * 64 * 4) != 128 * 64 * 4) { printf("speed_random: read error\n"); } close(fd); #else memset(buf, 0x7f, 128 * 64 * 4); #endif regions[0].x = 0; regions[0].y = 0; regions[0].cx = 128; regions[0].cy = 64; num_regions = 1; tiles[0].x = 0; tiles[0].y = 0; tiles[0].cx = 64; tiles[0].cy = 64; tiles[0].quant_y = 0; tiles[0].quant_cb = 0; tiles[0].quant_cr = 0; tiles[1].x = 64; tiles[1].y = 0; tiles[1].cx = 64; tiles[1].cy = 64; tiles[1].quant_y = 0; tiles[1].quant_cb = 0; tiles[1].quant_cr = 0; num_tiles = 1; num_quants = 1; error = 0; stime = get_mstime(); flags = 0; //flags = RFX_FLAGS_ALPHAV1; for (index = 0; index < count; index++) { error = rfxcodec_encode_ex(han, cdata, &cdata_bytes, buf, 64, 64, 64 * 4, regions, num_regions, tiles, num_tiles, quants, num_quants, flags); if (error != 0) { break; } } etime = get_mstime(); tiles_per_second = count * num_tiles * 1000 / (etime - stime + 1); printf("speed_random: cdata_bytes %d count %d ms time %d " "tiles_per_second %d\n", cdata_bytes, count, etime - stime, tiles_per_second); rfxcodec_encode_destroy(han); free(buf); free(cdata); return 0; } struct bmp_magic { char magic[2]; }; struct bmp_hdr { unsigned int size; unsigned short reserved1; unsigned short reserved2; unsigned int offset; }; struct dib_hdr { unsigned int hdr_size; int width; int height; unsigned short nplanes; unsigned short bpp; unsigned int compress_type; unsigned int image_size; int hres; int vres; unsigned int ncolors; unsigned int nimpcolors; }; /******************************************************************************/ static int load_bmp_file(int in_fd, char **data, int *width, int *height) { struct bmp_magic bmpm; struct bmp_hdr bmph; struct dib_hdr dibh; int awidth; int aheight; int line_bytes; int index; int jndex; int red; int gre; int blu; int *dst32; char *line; char *line_ptr; if (read(in_fd, &bmpm, sizeof(struct bmp_magic)) != sizeof(struct bmp_magic)) { return 1; } if (read(in_fd, &bmph, sizeof(struct bmp_hdr)) != sizeof(struct bmp_hdr)) { return 1; } if (read(in_fd, &dibh, sizeof(struct dib_hdr)) != sizeof(struct dib_hdr)) { return 1; } if (dibh.bpp != 24) { printf("only support 24 bpp bmp file now\n"); return 1; } printf("bpp %d\n", dibh.bpp); *width = dibh.width; *height = dibh.height; awidth = (dibh.width + 63) & ~63; aheight = (dibh.height + 63) & ~63; *data = (char *) malloc(awidth * aheight * 4); line_bytes = dibh.width * 3; line_bytes = (line_bytes + 3) & ~3; line = (char *) malloc(line_bytes); memset(*data, 0, awidth * aheight); for (index = 0; index < dibh.height; index++) { dst32 = (int *) (*data); dst32 += index * awidth; line_ptr = line; if (read(in_fd, line, line_bytes) != line_bytes) { return 1; } for (jndex = 0; jndex < dibh.width; jndex++) { red = *(line_ptr++); gre = *(line_ptr++); blu = *(line_ptr++); *(dst32++) = (red << 16) | (gre << 8) | blu; } } free(line); return 0; } /******************************************************************************/ static int encode_file(char *data, int width, int height, char *cdata, int *cdata_bytes, const char *quants, int num_quants) { int awidth; int aheight; int num_tiles; int index; int jndex; int error; int num_regions; struct rfx_tile *tiles; struct rfx_tile *tiles_ptr; void *han; struct rfx_rect regions[1]; error = rfxcodec_encode_create_ex(1920, 1024, RFX_FORMAT_BGRA, RFX_FLAGS_RLGR1, &han); if (error != 0) { printf("encode_file: rfxcodec_encode_create_ex failed\n"); return 1; } awidth = (width + 63) & ~63; aheight = (height + 63) & ~63; num_tiles = (awidth / 64) * (aheight / 64); tiles = (struct rfx_tile *) malloc(num_tiles * sizeof(struct rfx_tile)); tiles_ptr = tiles; for (index = 0; index < aheight; index += 64) { for (jndex = 0; jndex < awidth; jndex += 64) { tiles_ptr[0].x = jndex; tiles_ptr[0].y = index; tiles_ptr[0].cx = 64; tiles_ptr[0].cy = 64; tiles_ptr[0].quant_y = 0; tiles_ptr[0].quant_cb = num_quants - 1; tiles_ptr[0].quant_cr = num_quants - 1; tiles_ptr++; } } regions[0].x = 0; regions[0].y = 0; regions[0].cx = width; regions[0].cy = height; num_regions = 1; error = rfxcodec_encode_ex(han, cdata, cdata_bytes, data, width, height, width * 4, regions, num_regions, tiles, num_tiles, quants, num_quants, 0); if (error != 0) { printf("encode_file: rfxcodec_encode failed error %d\n", error); return 1; } rfxcodec_encode_destroy(han); free(tiles); return 0; } /******************************************************************************/ static int read_file(int count, const char *quants, int num_quants, const char *in_file, const char *out_file) { int in_fd; int out_fd; int width; int height; int cdata_bytes; char *data; char *cdata; in_fd = open(in_file, O_RDONLY); if (in_fd == -1) { printf("error opening %s\n", in_file); return 1; } out_fd = -1; if (out_file[0] != 0) { if (access(out_file, F_OK) == 0) { printf("out files exists\n"); return 1; } out_fd = open(out_file, O_RDWR | O_CREAT | O_TRUNC, S_IRUSR | S_IWUSR); if (out_fd == -1) { printf("error opening %s\n", out_file); return 1; } } data = 0; width = 0; height = 0; if (load_bmp_file(in_fd, &data, &width, &height) != 0) { printf("load_bmp_file failed\n"); return 1; } printf("loaded file ok width %d height %d\n", width, height); cdata_bytes = (width + 64) * (height + 64); cdata = (char *) malloc(cdata_bytes); if (encode_file(data, width, height, cdata, &cdata_bytes, quants, num_quants) != 0) { printf("encode_file failed\n"); return 1; } printf("encode data ok bytes %d\n", cdata_bytes); if (out_fd != -1) { if (write(out_fd, cdata, cdata_bytes) != cdata_bytes) { printf("write failed\n"); } } free(data); free(cdata); close(in_fd); if (out_fd != -1) { close(out_fd); } return 0; } /******************************************************************************/ static int out_usage(void) { printf("rfxdectest usage\n"); printf("this program is used for testing the rfx encoder for both speed " "and integrity\n"); printf("examples\n"); printf(" ./rfxcodectest --speed --count 1000\n"); printf(" ./rfxcodectest -i infile.bmp -o outfile.rfx\n"); printf("\n"); return 0; } /******************************************************************************/ int main(int argc, char **argv) { int index; int do_speed; int do_read; int count; char in_file[256]; char out_file[256]; const char *quants = (const char *) g_rfx_default_quantization_values; do_speed = 0; do_read = 0; in_file[0] = 0; out_file[0] = 0; count = 1; if (argc < 2) { return out_usage(); } for (index = 1; index < argc; index++) { if (strcmp("--speed", argv[index]) == 0) { do_speed = 1; } else if (strcmp("--count", argv[index]) == 0) { index++; count = atoi(argv[index]); } else if (strcmp("-i", argv[index]) == 0) { index++; snprintf(in_file, 255, "%s", argv[index]); do_read = 1; } else if (strcmp("-o", argv[index]) == 0) { index++; snprintf(out_file, 255, "%s", argv[index]); } else { return out_usage(); } } if (do_speed) { speed_random(count, quants); } if (do_read) { read_file(count, quants, 2, in_file, out_file); } return 0; } xrdp-0.9.5/librfxcodec/m4/ax_require_defined.m4000644 001751 001751 00000002302 13127342056 021312 0ustar00metameta000000 000000 # =========================================================================== # https://www.gnu.org/software/autoconf-archive/ax_require_defined.html # =========================================================================== # # SYNOPSIS # # AX_REQUIRE_DEFINED(MACRO) # # DESCRIPTION # # AX_REQUIRE_DEFINED is a simple helper for making sure other macros have # been defined and thus are available for use. This avoids random issues # where a macro isn't expanded. Instead the configure script emits a # non-fatal: # # ./configure: line 1673: AX_CFLAGS_WARN_ALL: command not found # # It's like AC_REQUIRE except it doesn't expand the required macro. # # Here's an example: # # AX_REQUIRE_DEFINED([AX_CHECK_LINK_FLAG]) # # LICENSE # # Copyright (c) 2014 Mike Frysinger # # Copying and distribution of this file, with or without modification, are # permitted in any medium without royalty provided the copyright notice # and this notice are preserved. This file is offered as-is, without any # warranty. #serial 2 AC_DEFUN([AX_REQUIRE_DEFINED], [dnl m4_ifndef([$1], [m4_fatal([macro ]$1[ is not defined; is a m4 file missing?])]) ])dnl AX_REQUIRE_DEFINED xrdp-0.9.5/librfxcodec/m4/nasm.m4000644 001751 001751 00000006427 13061652764 016451 0ustar00metameta000000 000000 # AC_PROG_NASM # -------------------------- # Check that NASM exists and determine flags AC_DEFUN([AC_PROG_NASM],[ AC_CHECK_PROGS(NASM, [nasm nasmw yasm]) test -z "$NASM" && AC_MSG_ERROR([no nasm (Netwide Assembler) found]) AC_MSG_CHECKING([for object file format of host system]) case "$host_os" in cygwin* | mingw* | pw32* | interix*) case "$host_cpu" in x86_64) objfmt='Win64-COFF' ;; *) objfmt='Win32-COFF' ;; esac ;; msdosdjgpp* | go32*) objfmt='COFF' ;; os2-emx*) # not tested objfmt='MSOMF' # obj ;; linux*coff* | linux*oldld*) objfmt='COFF' # ??? ;; linux*aout*) objfmt='a.out' ;; linux*) case "$host_cpu" in x86_64) objfmt='ELF64' ;; *) objfmt='ELF' ;; esac ;; kfreebsd* | freebsd* | netbsd* | openbsd*) if echo __ELF__ | $CC -E - | grep __ELF__ > /dev/null; then objfmt='BSD-a.out' else case "$host_cpu" in x86_64 | amd64) objfmt='ELF64' ;; *) objfmt='ELF' ;; esac fi ;; solaris* | sunos* | sysv* | sco*) case "$host_cpu" in x86_64) objfmt='ELF64' ;; *) objfmt='ELF' ;; esac ;; darwin* | rhapsody* | nextstep* | openstep* | macos*) case "$host_cpu" in x86_64) objfmt='Mach-O64' ;; *) objfmt='Mach-O' ;; esac ;; *) objfmt='ELF ?' ;; esac AC_MSG_RESULT([$objfmt]) if test "$objfmt" = 'ELF ?'; then objfmt='ELF' AC_MSG_WARN([unexpected host system. assumed that the format is $objfmt.]) fi AC_MSG_CHECKING([for object file format specifier (NAFLAGS) ]) case "$objfmt" in MSOMF) NAFLAGS='-fobj -DOBJ32';; Win32-COFF) NAFLAGS='-fwin32 -DWIN32';; Win64-COFF) NAFLAGS='-fwin64 -DWIN64 -D__x86_64__';; COFF) NAFLAGS='-fcoff -DCOFF';; a.out) NAFLAGS='-faout -DAOUT';; BSD-a.out) NAFLAGS='-faoutb -DAOUT';; ELF) NAFLAGS='-felf -DELF';; ELF64) NAFLAGS='-felf64 -DELF -D__x86_64__';; RDF) NAFLAGS='-frdf -DRDF';; Mach-O) NAFLAGS='-fmacho -DMACHO';; Mach-O64) NAFLAGS='-fmacho64 -DMACHO -D__x86_64__';; esac AC_MSG_RESULT([$NAFLAGS]) AC_SUBST([NAFLAGS]) AC_MSG_CHECKING([whether the assembler ($NASM $NAFLAGS) works]) cat > conftest.asm <&AC_FD_CC cat conftest.asm >&AC_FD_CC rm -rf conftest* AC_MSG_RESULT(no) AC_MSG_ERROR([installation or configuration problem: assembler cannot create object files.]) fi AC_MSG_CHECKING([whether the linker accepts assembler output]) nasm_save_LIBS="$LIBS" LIBS="conftest-nasm.o $LIBS" AC_LINK_IFELSE( [AC_LANG_PROGRAM([[ #ifdef __cplusplus extern "C" #endif void nasmfunc(void); ]], [[nasmfunc();]])], [nasm_link_ok=yes], [nasm_link_ok=no]) LIBS="$nasm_save_LIBS" AC_MSG_RESULT([$nasm_link_ok]) if test "x$nasm_link_ok" = "xno"; then AC_MSG_ERROR([configuration problem: maybe object file format mismatch.]) fi ]) xrdp-0.9.5/librfxcodec/m4/libtool.m4000644 001751 001751 00001125073 13220730751 017145 0ustar00metameta000000 000000 # libtool.m4 - Configure libtool for the host system. -*-Autoconf-*- # # Copyright (C) 1996-2001, 2003-2015 Free Software Foundation, Inc. # Written by Gordon Matzigkeit, 1996 # # This file is free software; the Free Software Foundation gives # unlimited permission to copy and/or distribute it, with or without # modifications, as long as this notice is preserved. m4_define([_LT_COPYING], [dnl # Copyright (C) 2014 Free Software Foundation, Inc. # This is free software; see the source for copying conditions. There is NO # warranty; not even for MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. # GNU Libtool 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 2 of of the License, or # (at your option) any later version. # # As a special exception to the GNU General Public License, if you # distribute this file as part of a program or library that is built # using GNU Libtool, you may include this file under the same # distribution terms that you use for the rest of that program. # # GNU Libtool 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. # # You should have received a copy of the GNU General Public License # along with this program. If not, see . ]) # serial 58 LT_INIT # LT_PREREQ(VERSION) # ------------------ # Complain and exit if this libtool version is less that VERSION. m4_defun([LT_PREREQ], [m4_if(m4_version_compare(m4_defn([LT_PACKAGE_VERSION]), [$1]), -1, [m4_default([$3], [m4_fatal([Libtool version $1 or higher is required], 63)])], [$2])]) # _LT_CHECK_BUILDDIR # ------------------ # Complain if the absolute build directory name contains unusual characters m4_defun([_LT_CHECK_BUILDDIR], [case `pwd` in *\ * | *\ *) AC_MSG_WARN([Libtool does not cope well with whitespace in `pwd`]) ;; esac ]) # LT_INIT([OPTIONS]) # ------------------ AC_DEFUN([LT_INIT], [AC_PREREQ([2.62])dnl We use AC_PATH_PROGS_FEATURE_CHECK AC_REQUIRE([AC_CONFIG_AUX_DIR_DEFAULT])dnl AC_BEFORE([$0], [LT_LANG])dnl AC_BEFORE([$0], [LT_OUTPUT])dnl AC_BEFORE([$0], [LTDL_INIT])dnl m4_require([_LT_CHECK_BUILDDIR])dnl dnl Autoconf doesn't catch unexpanded LT_ macros by default: m4_pattern_forbid([^_?LT_[A-Z_]+$])dnl m4_pattern_allow([^(_LT_EOF|LT_DLGLOBAL|LT_DLLAZY_OR_NOW|LT_MULTI_MODULE)$])dnl dnl aclocal doesn't pull ltoptions.m4, ltsugar.m4, or ltversion.m4 dnl unless we require an AC_DEFUNed macro: AC_REQUIRE([LTOPTIONS_VERSION])dnl AC_REQUIRE([LTSUGAR_VERSION])dnl AC_REQUIRE([LTVERSION_VERSION])dnl AC_REQUIRE([LTOBSOLETE_VERSION])dnl m4_require([_LT_PROG_LTMAIN])dnl _LT_SHELL_INIT([SHELL=${CONFIG_SHELL-/bin/sh}]) dnl Parse OPTIONS _LT_SET_OPTIONS([$0], [$1]) # This can be used to rebuild libtool when needed LIBTOOL_DEPS=$ltmain # Always use our own libtool. LIBTOOL='$(SHELL) $(top_builddir)/libtool' AC_SUBST(LIBTOOL)dnl _LT_SETUP # Only expand once: m4_define([LT_INIT]) ])# LT_INIT # Old names: AU_ALIAS([AC_PROG_LIBTOOL], [LT_INIT]) AU_ALIAS([AM_PROG_LIBTOOL], [LT_INIT]) dnl aclocal-1.4 backwards compatibility: dnl AC_DEFUN([AC_PROG_LIBTOOL], []) dnl AC_DEFUN([AM_PROG_LIBTOOL], []) # _LT_PREPARE_CC_BASENAME # ----------------------- m4_defun([_LT_PREPARE_CC_BASENAME], [ # Calculate cc_basename. Skip known compiler wrappers and cross-prefix. func_cc_basename () { for cc_temp in @S|@*""; do case $cc_temp in compile | *[[\\/]]compile | ccache | *[[\\/]]ccache ) ;; distcc | *[[\\/]]distcc | purify | *[[\\/]]purify ) ;; \-*) ;; *) break;; esac done func_cc_basename_result=`$ECHO "$cc_temp" | $SED "s%.*/%%; s%^$host_alias-%%"` } ])# _LT_PREPARE_CC_BASENAME # _LT_CC_BASENAME(CC) # ------------------- # It would be clearer to call AC_REQUIREs from _LT_PREPARE_CC_BASENAME, # but that macro is also expanded into generated libtool script, which # arranges for $SED and $ECHO to be set by different means. m4_defun([_LT_CC_BASENAME], [m4_require([_LT_PREPARE_CC_BASENAME])dnl AC_REQUIRE([_LT_DECL_SED])dnl AC_REQUIRE([_LT_PROG_ECHO_BACKSLASH])dnl func_cc_basename $1 cc_basename=$func_cc_basename_result ]) # _LT_FILEUTILS_DEFAULTS # ---------------------- # It is okay to use these file commands and assume they have been set # sensibly after 'm4_require([_LT_FILEUTILS_DEFAULTS])'. m4_defun([_LT_FILEUTILS_DEFAULTS], [: ${CP="cp -f"} : ${MV="mv -f"} : ${RM="rm -f"} ])# _LT_FILEUTILS_DEFAULTS # _LT_SETUP # --------- m4_defun([_LT_SETUP], [AC_REQUIRE([AC_CANONICAL_HOST])dnl AC_REQUIRE([AC_CANONICAL_BUILD])dnl AC_REQUIRE([_LT_PREPARE_SED_QUOTE_VARS])dnl AC_REQUIRE([_LT_PROG_ECHO_BACKSLASH])dnl _LT_DECL([], [PATH_SEPARATOR], [1], [The PATH separator for the build system])dnl dnl _LT_DECL([], [host_alias], [0], [The host system])dnl _LT_DECL([], [host], [0])dnl _LT_DECL([], [host_os], [0])dnl dnl _LT_DECL([], [build_alias], [0], [The build system])dnl _LT_DECL([], [build], [0])dnl _LT_DECL([], [build_os], [0])dnl dnl AC_REQUIRE([AC_PROG_CC])dnl AC_REQUIRE([LT_PATH_LD])dnl AC_REQUIRE([LT_PATH_NM])dnl dnl AC_REQUIRE([AC_PROG_LN_S])dnl test -z "$LN_S" && LN_S="ln -s" _LT_DECL([], [LN_S], [1], [Whether we need soft or hard links])dnl dnl AC_REQUIRE([LT_CMD_MAX_LEN])dnl _LT_DECL([objext], [ac_objext], [0], [Object file suffix (normally "o")])dnl _LT_DECL([], [exeext], [0], [Executable file suffix (normally "")])dnl dnl m4_require([_LT_FILEUTILS_DEFAULTS])dnl m4_require([_LT_CHECK_SHELL_FEATURES])dnl m4_require([_LT_PATH_CONVERSION_FUNCTIONS])dnl m4_require([_LT_CMD_RELOAD])dnl m4_require([_LT_CHECK_MAGIC_METHOD])dnl m4_require([_LT_CHECK_SHAREDLIB_FROM_LINKLIB])dnl m4_require([_LT_CMD_OLD_ARCHIVE])dnl m4_require([_LT_CMD_GLOBAL_SYMBOLS])dnl m4_require([_LT_WITH_SYSROOT])dnl m4_require([_LT_CMD_TRUNCATE])dnl _LT_CONFIG_LIBTOOL_INIT([ # See if we are running on zsh, and set the options that allow our # commands through without removal of \ escapes INIT. if test -n "\${ZSH_VERSION+set}"; then setopt NO_GLOB_SUBST fi ]) if test -n "${ZSH_VERSION+set}"; then setopt NO_GLOB_SUBST fi _LT_CHECK_OBJDIR m4_require([_LT_TAG_COMPILER])dnl case $host_os in aix3*) # AIX sometimes has problems with the GCC collect2 program. For some # reason, if we set the COLLECT_NAMES environment variable, the problems # vanish in a puff of smoke. if test set != "${COLLECT_NAMES+set}"; then COLLECT_NAMES= export COLLECT_NAMES fi ;; esac # Global variables: ofile=libtool can_build_shared=yes # All known linkers require a '.a' archive for static linking (except MSVC, # which needs '.lib'). libext=a with_gnu_ld=$lt_cv_prog_gnu_ld old_CC=$CC old_CFLAGS=$CFLAGS # Set sane defaults for various variables test -z "$CC" && CC=cc test -z "$LTCC" && LTCC=$CC test -z "$LTCFLAGS" && LTCFLAGS=$CFLAGS test -z "$LD" && LD=ld test -z "$ac_objext" && ac_objext=o _LT_CC_BASENAME([$compiler]) # Only perform the check for file, if the check method requires it test -z "$MAGIC_CMD" && MAGIC_CMD=file case $deplibs_check_method in file_magic*) if test "$file_magic_cmd" = '$MAGIC_CMD'; then _LT_PATH_MAGIC fi ;; esac # Use C for the default configuration in the libtool script LT_SUPPORTED_TAG([CC]) _LT_LANG_C_CONFIG _LT_LANG_DEFAULT_CONFIG _LT_CONFIG_COMMANDS ])# _LT_SETUP # _LT_PREPARE_SED_QUOTE_VARS # -------------------------- # Define a few sed substitution that help us do robust quoting. m4_defun([_LT_PREPARE_SED_QUOTE_VARS], [# Backslashify metacharacters that are still active within # double-quoted strings. sed_quote_subst='s/\([["`$\\]]\)/\\\1/g' # Same as above, but do not quote variable references. double_quote_subst='s/\([["`\\]]\)/\\\1/g' # Sed substitution to delay expansion of an escaped shell variable in a # double_quote_subst'ed string. delay_variable_subst='s/\\\\\\\\\\\$/\\\\\\$/g' # Sed substitution to delay expansion of an escaped single quote. delay_single_quote_subst='s/'\''/'\'\\\\\\\'\''/g' # Sed substitution to avoid accidental globbing in evaled expressions no_glob_subst='s/\*/\\\*/g' ]) # _LT_PROG_LTMAIN # --------------- # Note that this code is called both from 'configure', and 'config.status' # now that we use AC_CONFIG_COMMANDS to generate libtool. Notably, # 'config.status' has no value for ac_aux_dir unless we are using Automake, # so we pass a copy along to make sure it has a sensible value anyway. m4_defun([_LT_PROG_LTMAIN], [m4_ifdef([AC_REQUIRE_AUX_FILE], [AC_REQUIRE_AUX_FILE([ltmain.sh])])dnl _LT_CONFIG_LIBTOOL_INIT([ac_aux_dir='$ac_aux_dir']) ltmain=$ac_aux_dir/ltmain.sh ])# _LT_PROG_LTMAIN ## ------------------------------------- ## ## Accumulate code for creating libtool. ## ## ------------------------------------- ## # So that we can recreate a full libtool script including additional # tags, we accumulate the chunks of code to send to AC_CONFIG_COMMANDS # in macros and then make a single call at the end using the 'libtool' # label. # _LT_CONFIG_LIBTOOL_INIT([INIT-COMMANDS]) # ---------------------------------------- # Register INIT-COMMANDS to be passed to AC_CONFIG_COMMANDS later. m4_define([_LT_CONFIG_LIBTOOL_INIT], [m4_ifval([$1], [m4_append([_LT_OUTPUT_LIBTOOL_INIT], [$1 ])])]) # Initialize. m4_define([_LT_OUTPUT_LIBTOOL_INIT]) # _LT_CONFIG_LIBTOOL([COMMANDS]) # ------------------------------ # Register COMMANDS to be passed to AC_CONFIG_COMMANDS later. m4_define([_LT_CONFIG_LIBTOOL], [m4_ifval([$1], [m4_append([_LT_OUTPUT_LIBTOOL_COMMANDS], [$1 ])])]) # Initialize. m4_define([_LT_OUTPUT_LIBTOOL_COMMANDS]) # _LT_CONFIG_SAVE_COMMANDS([COMMANDS], [INIT_COMMANDS]) # ----------------------------------------------------- m4_defun([_LT_CONFIG_SAVE_COMMANDS], [_LT_CONFIG_LIBTOOL([$1]) _LT_CONFIG_LIBTOOL_INIT([$2]) ]) # _LT_FORMAT_COMMENT([COMMENT]) # ----------------------------- # Add leading comment marks to the start of each line, and a trailing # full-stop to the whole comment if one is not present already. m4_define([_LT_FORMAT_COMMENT], [m4_ifval([$1], [ m4_bpatsubst([m4_bpatsubst([$1], [^ *], [# ])], [['`$\]], [\\\&])]m4_bmatch([$1], [[!?.]$], [], [.]) )]) ## ------------------------ ## ## FIXME: Eliminate VARNAME ## ## ------------------------ ## # _LT_DECL([CONFIGNAME], VARNAME, VALUE, [DESCRIPTION], [IS-TAGGED?]) # ------------------------------------------------------------------- # CONFIGNAME is the name given to the value in the libtool script. # VARNAME is the (base) name used in the configure script. # VALUE may be 0, 1 or 2 for a computed quote escaped value based on # VARNAME. Any other value will be used directly. m4_define([_LT_DECL], [lt_if_append_uniq([lt_decl_varnames], [$2], [, ], [lt_dict_add_subkey([lt_decl_dict], [$2], [libtool_name], [m4_ifval([$1], [$1], [$2])]) lt_dict_add_subkey([lt_decl_dict], [$2], [value], [$3]) m4_ifval([$4], [lt_dict_add_subkey([lt_decl_dict], [$2], [description], [$4])]) lt_dict_add_subkey([lt_decl_dict], [$2], [tagged?], [m4_ifval([$5], [yes], [no])])]) ]) # _LT_TAGDECL([CONFIGNAME], VARNAME, VALUE, [DESCRIPTION]) # -------------------------------------------------------- m4_define([_LT_TAGDECL], [_LT_DECL([$1], [$2], [$3], [$4], [yes])]) # lt_decl_tag_varnames([SEPARATOR], [VARNAME1...]) # ------------------------------------------------ m4_define([lt_decl_tag_varnames], [_lt_decl_filter([tagged?], [yes], $@)]) # _lt_decl_filter(SUBKEY, VALUE, [SEPARATOR], [VARNAME1..]) # --------------------------------------------------------- m4_define([_lt_decl_filter], [m4_case([$#], [0], [m4_fatal([$0: too few arguments: $#])], [1], [m4_fatal([$0: too few arguments: $#: $1])], [2], [lt_dict_filter([lt_decl_dict], [$1], [$2], [], lt_decl_varnames)], [3], [lt_dict_filter([lt_decl_dict], [$1], [$2], [$3], lt_decl_varnames)], [lt_dict_filter([lt_decl_dict], $@)])[]dnl ]) # lt_decl_quote_varnames([SEPARATOR], [VARNAME1...]) # -------------------------------------------------- m4_define([lt_decl_quote_varnames], [_lt_decl_filter([value], [1], $@)]) # lt_decl_dquote_varnames([SEPARATOR], [VARNAME1...]) # --------------------------------------------------- m4_define([lt_decl_dquote_varnames], [_lt_decl_filter([value], [2], $@)]) # lt_decl_varnames_tagged([SEPARATOR], [VARNAME1...]) # --------------------------------------------------- m4_define([lt_decl_varnames_tagged], [m4_assert([$# <= 2])dnl _$0(m4_quote(m4_default([$1], [[, ]])), m4_ifval([$2], [[$2]], [m4_dquote(lt_decl_tag_varnames)]), m4_split(m4_normalize(m4_quote(_LT_TAGS)), [ ]))]) m4_define([_lt_decl_varnames_tagged], [m4_ifval([$3], [lt_combine([$1], [$2], [_], $3)])]) # lt_decl_all_varnames([SEPARATOR], [VARNAME1...]) # ------------------------------------------------ m4_define([lt_decl_all_varnames], [_$0(m4_quote(m4_default([$1], [[, ]])), m4_if([$2], [], m4_quote(lt_decl_varnames), m4_quote(m4_shift($@))))[]dnl ]) m4_define([_lt_decl_all_varnames], [lt_join($@, lt_decl_varnames_tagged([$1], lt_decl_tag_varnames([[, ]], m4_shift($@))))dnl ]) # _LT_CONFIG_STATUS_DECLARE([VARNAME]) # ------------------------------------ # Quote a variable value, and forward it to 'config.status' so that its # declaration there will have the same value as in 'configure'. VARNAME # must have a single quote delimited value for this to work. m4_define([_LT_CONFIG_STATUS_DECLARE], [$1='`$ECHO "$][$1" | $SED "$delay_single_quote_subst"`']) # _LT_CONFIG_STATUS_DECLARATIONS # ------------------------------ # We delimit libtool config variables with single quotes, so when # we write them to config.status, we have to be sure to quote all # embedded single quotes properly. In configure, this macro expands # each variable declared with _LT_DECL (and _LT_TAGDECL) into: # # ='`$ECHO "$" | $SED "$delay_single_quote_subst"`' m4_defun([_LT_CONFIG_STATUS_DECLARATIONS], [m4_foreach([_lt_var], m4_quote(lt_decl_all_varnames), [m4_n([_LT_CONFIG_STATUS_DECLARE(_lt_var)])])]) # _LT_LIBTOOL_TAGS # ---------------- # Output comment and list of tags supported by the script m4_defun([_LT_LIBTOOL_TAGS], [_LT_FORMAT_COMMENT([The names of the tagged configurations supported by this script])dnl available_tags='_LT_TAGS'dnl ]) # _LT_LIBTOOL_DECLARE(VARNAME, [TAG]) # ----------------------------------- # Extract the dictionary values for VARNAME (optionally with TAG) and # expand to a commented shell variable setting: # # # Some comment about what VAR is for. # visible_name=$lt_internal_name m4_define([_LT_LIBTOOL_DECLARE], [_LT_FORMAT_COMMENT(m4_quote(lt_dict_fetch([lt_decl_dict], [$1], [description])))[]dnl m4_pushdef([_libtool_name], m4_quote(lt_dict_fetch([lt_decl_dict], [$1], [libtool_name])))[]dnl m4_case(m4_quote(lt_dict_fetch([lt_decl_dict], [$1], [value])), [0], [_libtool_name=[$]$1], [1], [_libtool_name=$lt_[]$1], [2], [_libtool_name=$lt_[]$1], [_libtool_name=lt_dict_fetch([lt_decl_dict], [$1], [value])])[]dnl m4_ifval([$2], [_$2])[]m4_popdef([_libtool_name])[]dnl ]) # _LT_LIBTOOL_CONFIG_VARS # ----------------------- # Produce commented declarations of non-tagged libtool config variables # suitable for insertion in the LIBTOOL CONFIG section of the 'libtool' # script. Tagged libtool config variables (even for the LIBTOOL CONFIG # section) are produced by _LT_LIBTOOL_TAG_VARS. m4_defun([_LT_LIBTOOL_CONFIG_VARS], [m4_foreach([_lt_var], m4_quote(_lt_decl_filter([tagged?], [no], [], lt_decl_varnames)), [m4_n([_LT_LIBTOOL_DECLARE(_lt_var)])])]) # _LT_LIBTOOL_TAG_VARS(TAG) # ------------------------- m4_define([_LT_LIBTOOL_TAG_VARS], [m4_foreach([_lt_var], m4_quote(lt_decl_tag_varnames), [m4_n([_LT_LIBTOOL_DECLARE(_lt_var, [$1])])])]) # _LT_TAGVAR(VARNAME, [TAGNAME]) # ------------------------------ m4_define([_LT_TAGVAR], [m4_ifval([$2], [$1_$2], [$1])]) # _LT_CONFIG_COMMANDS # ------------------- # Send accumulated output to $CONFIG_STATUS. Thanks to the lists of # variables for single and double quote escaping we saved from calls # to _LT_DECL, we can put quote escaped variables declarations # into 'config.status', and then the shell code to quote escape them in # for loops in 'config.status'. Finally, any additional code accumulated # from calls to _LT_CONFIG_LIBTOOL_INIT is expanded. m4_defun([_LT_CONFIG_COMMANDS], [AC_PROVIDE_IFELSE([LT_OUTPUT], dnl If the libtool generation code has been placed in $CONFIG_LT, dnl instead of duplicating it all over again into config.status, dnl then we will have config.status run $CONFIG_LT later, so it dnl needs to know what name is stored there: [AC_CONFIG_COMMANDS([libtool], [$SHELL $CONFIG_LT || AS_EXIT(1)], [CONFIG_LT='$CONFIG_LT'])], dnl If the libtool generation code is destined for config.status, dnl expand the accumulated commands and init code now: [AC_CONFIG_COMMANDS([libtool], [_LT_OUTPUT_LIBTOOL_COMMANDS], [_LT_OUTPUT_LIBTOOL_COMMANDS_INIT])]) ])#_LT_CONFIG_COMMANDS # Initialize. m4_define([_LT_OUTPUT_LIBTOOL_COMMANDS_INIT], [ # The HP-UX ksh and POSIX shell print the target directory to stdout # if CDPATH is set. (unset CDPATH) >/dev/null 2>&1 && unset CDPATH sed_quote_subst='$sed_quote_subst' double_quote_subst='$double_quote_subst' delay_variable_subst='$delay_variable_subst' _LT_CONFIG_STATUS_DECLARATIONS LTCC='$LTCC' LTCFLAGS='$LTCFLAGS' compiler='$compiler_DEFAULT' # A function that is used when there is no print builtin or printf. func_fallback_echo () { eval 'cat <<_LTECHO_EOF \$[]1 _LTECHO_EOF' } # Quote evaled strings. for var in lt_decl_all_varnames([[ \ ]], lt_decl_quote_varnames); do case \`eval \\\\\$ECHO \\\\""\\\\\$\$var"\\\\"\` in *[[\\\\\\\`\\"\\\$]]*) eval "lt_\$var=\\\\\\"\\\`\\\$ECHO \\"\\\$\$var\\" | \\\$SED \\"\\\$sed_quote_subst\\"\\\`\\\\\\"" ## exclude from sc_prohibit_nested_quotes ;; *) eval "lt_\$var=\\\\\\"\\\$\$var\\\\\\"" ;; esac done # Double-quote double-evaled strings. for var in lt_decl_all_varnames([[ \ ]], lt_decl_dquote_varnames); do case \`eval \\\\\$ECHO \\\\""\\\\\$\$var"\\\\"\` in *[[\\\\\\\`\\"\\\$]]*) eval "lt_\$var=\\\\\\"\\\`\\\$ECHO \\"\\\$\$var\\" | \\\$SED -e \\"\\\$double_quote_subst\\" -e \\"\\\$sed_quote_subst\\" -e \\"\\\$delay_variable_subst\\"\\\`\\\\\\"" ## exclude from sc_prohibit_nested_quotes ;; *) eval "lt_\$var=\\\\\\"\\\$\$var\\\\\\"" ;; esac done _LT_OUTPUT_LIBTOOL_INIT ]) # _LT_GENERATED_FILE_INIT(FILE, [COMMENT]) # ------------------------------------ # Generate a child script FILE with all initialization necessary to # reuse the environment learned by the parent script, and make the # file executable. If COMMENT is supplied, it is inserted after the # '#!' sequence but before initialization text begins. After this # macro, additional text can be appended to FILE to form the body of # the child script. The macro ends with non-zero status if the # file could not be fully written (such as if the disk is full). m4_ifdef([AS_INIT_GENERATED], [m4_defun([_LT_GENERATED_FILE_INIT],[AS_INIT_GENERATED($@)])], [m4_defun([_LT_GENERATED_FILE_INIT], [m4_require([AS_PREPARE])]dnl [m4_pushdef([AS_MESSAGE_LOG_FD])]dnl [lt_write_fail=0 cat >$1 <<_ASEOF || lt_write_fail=1 #! $SHELL # Generated by $as_me. $2 SHELL=\${CONFIG_SHELL-$SHELL} export SHELL _ASEOF cat >>$1 <<\_ASEOF || lt_write_fail=1 AS_SHELL_SANITIZE _AS_PREPARE exec AS_MESSAGE_FD>&1 _ASEOF test 0 = "$lt_write_fail" && chmod +x $1[]dnl m4_popdef([AS_MESSAGE_LOG_FD])])])# _LT_GENERATED_FILE_INIT # LT_OUTPUT # --------- # This macro allows early generation of the libtool script (before # AC_OUTPUT is called), incase it is used in configure for compilation # tests. AC_DEFUN([LT_OUTPUT], [: ${CONFIG_LT=./config.lt} AC_MSG_NOTICE([creating $CONFIG_LT]) _LT_GENERATED_FILE_INIT(["$CONFIG_LT"], [# Run this file to recreate a libtool stub with the current configuration.]) cat >>"$CONFIG_LT" <<\_LTEOF lt_cl_silent=false exec AS_MESSAGE_LOG_FD>>config.log { echo AS_BOX([Running $as_me.]) } >&AS_MESSAGE_LOG_FD lt_cl_help="\ '$as_me' creates a local libtool stub from the current configuration, for use in further configure time tests before the real libtool is generated. Usage: $[0] [[OPTIONS]] -h, --help print this help, then exit -V, --version print version number, then exit -q, --quiet do not print progress messages -d, --debug don't remove temporary files Report bugs to ." lt_cl_version="\ m4_ifset([AC_PACKAGE_NAME], [AC_PACKAGE_NAME ])config.lt[]dnl m4_ifset([AC_PACKAGE_VERSION], [ AC_PACKAGE_VERSION]) configured by $[0], generated by m4_PACKAGE_STRING. Copyright (C) 2011 Free Software Foundation, Inc. This config.lt script is free software; the Free Software Foundation gives unlimited permision to copy, distribute and modify it." while test 0 != $[#] do case $[1] in --version | --v* | -V ) echo "$lt_cl_version"; exit 0 ;; --help | --h* | -h ) echo "$lt_cl_help"; exit 0 ;; --debug | --d* | -d ) debug=: ;; --quiet | --q* | --silent | --s* | -q ) lt_cl_silent=: ;; -*) AC_MSG_ERROR([unrecognized option: $[1] Try '$[0] --help' for more information.]) ;; *) AC_MSG_ERROR([unrecognized argument: $[1] Try '$[0] --help' for more information.]) ;; esac shift done if $lt_cl_silent; then exec AS_MESSAGE_FD>/dev/null fi _LTEOF cat >>"$CONFIG_LT" <<_LTEOF _LT_OUTPUT_LIBTOOL_COMMANDS_INIT _LTEOF cat >>"$CONFIG_LT" <<\_LTEOF AC_MSG_NOTICE([creating $ofile]) _LT_OUTPUT_LIBTOOL_COMMANDS AS_EXIT(0) _LTEOF chmod +x "$CONFIG_LT" # configure is writing to config.log, but config.lt does its own redirection, # appending to config.log, which fails on DOS, as config.log is still kept # open by configure. Here we exec the FD to /dev/null, effectively closing # config.log, so it can be properly (re)opened and appended to by config.lt. lt_cl_success=: test yes = "$silent" && lt_config_lt_args="$lt_config_lt_args --quiet" exec AS_MESSAGE_LOG_FD>/dev/null $SHELL "$CONFIG_LT" $lt_config_lt_args || lt_cl_success=false exec AS_MESSAGE_LOG_FD>>config.log $lt_cl_success || AS_EXIT(1) ])# LT_OUTPUT # _LT_CONFIG(TAG) # --------------- # If TAG is the built-in tag, create an initial libtool script with a # default configuration from the untagged config vars. Otherwise add code # to config.status for appending the configuration named by TAG from the # matching tagged config vars. m4_defun([_LT_CONFIG], [m4_require([_LT_FILEUTILS_DEFAULTS])dnl _LT_CONFIG_SAVE_COMMANDS([ m4_define([_LT_TAG], m4_if([$1], [], [C], [$1]))dnl m4_if(_LT_TAG, [C], [ # See if we are running on zsh, and set the options that allow our # commands through without removal of \ escapes. if test -n "${ZSH_VERSION+set}"; then setopt NO_GLOB_SUBST fi cfgfile=${ofile}T trap "$RM \"$cfgfile\"; exit 1" 1 2 15 $RM "$cfgfile" cat <<_LT_EOF >> "$cfgfile" #! $SHELL # Generated automatically by $as_me ($PACKAGE) $VERSION # Libtool was configured on host `(hostname || uname -n) 2>/dev/null | sed 1q`: # NOTE: Changes made to this file will be lost: look at ltmain.sh. # Provide generalized library-building support services. # Written by Gordon Matzigkeit, 1996 _LT_COPYING _LT_LIBTOOL_TAGS # Configured defaults for sys_lib_dlsearch_path munging. : \${LT_SYS_LIBRARY_PATH="$configure_time_lt_sys_library_path"} # ### BEGIN LIBTOOL CONFIG _LT_LIBTOOL_CONFIG_VARS _LT_LIBTOOL_TAG_VARS # ### END LIBTOOL CONFIG _LT_EOF cat <<'_LT_EOF' >> "$cfgfile" # ### BEGIN FUNCTIONS SHARED WITH CONFIGURE _LT_PREPARE_MUNGE_PATH_LIST _LT_PREPARE_CC_BASENAME # ### END FUNCTIONS SHARED WITH CONFIGURE _LT_EOF case $host_os in aix3*) cat <<\_LT_EOF >> "$cfgfile" # AIX sometimes has problems with the GCC collect2 program. For some # reason, if we set the COLLECT_NAMES environment variable, the problems # vanish in a puff of smoke. if test set != "${COLLECT_NAMES+set}"; then COLLECT_NAMES= export COLLECT_NAMES fi _LT_EOF ;; esac _LT_PROG_LTMAIN # We use sed instead of cat because bash on DJGPP gets confused if # if finds mixed CR/LF and LF-only lines. Since sed operates in # text mode, it properly converts lines to CR/LF. This bash problem # is reportedly fixed, but why not run on old versions too? sed '$q' "$ltmain" >> "$cfgfile" \ || (rm -f "$cfgfile"; exit 1) mv -f "$cfgfile" "$ofile" || (rm -f "$ofile" && cp "$cfgfile" "$ofile" && rm -f "$cfgfile") chmod +x "$ofile" ], [cat <<_LT_EOF >> "$ofile" dnl Unfortunately we have to use $1 here, since _LT_TAG is not expanded dnl in a comment (ie after a #). # ### BEGIN LIBTOOL TAG CONFIG: $1 _LT_LIBTOOL_TAG_VARS(_LT_TAG) # ### END LIBTOOL TAG CONFIG: $1 _LT_EOF ])dnl /m4_if ], [m4_if([$1], [], [ PACKAGE='$PACKAGE' VERSION='$VERSION' RM='$RM' ofile='$ofile'], []) ])dnl /_LT_CONFIG_SAVE_COMMANDS ])# _LT_CONFIG # LT_SUPPORTED_TAG(TAG) # --------------------- # Trace this macro to discover what tags are supported by the libtool # --tag option, using: # autoconf --trace 'LT_SUPPORTED_TAG:$1' AC_DEFUN([LT_SUPPORTED_TAG], []) # C support is built-in for now m4_define([_LT_LANG_C_enabled], []) m4_define([_LT_TAGS], []) # LT_LANG(LANG) # ------------- # Enable libtool support for the given language if not already enabled. AC_DEFUN([LT_LANG], [AC_BEFORE([$0], [LT_OUTPUT])dnl m4_case([$1], [C], [_LT_LANG(C)], [C++], [_LT_LANG(CXX)], [Go], [_LT_LANG(GO)], [Java], [_LT_LANG(GCJ)], [Fortran 77], [_LT_LANG(F77)], [Fortran], [_LT_LANG(FC)], [Windows Resource], [_LT_LANG(RC)], [m4_ifdef([_LT_LANG_]$1[_CONFIG], [_LT_LANG($1)], [m4_fatal([$0: unsupported language: "$1"])])])dnl ])# LT_LANG # _LT_LANG(LANGNAME) # ------------------ m4_defun([_LT_LANG], [m4_ifdef([_LT_LANG_]$1[_enabled], [], [LT_SUPPORTED_TAG([$1])dnl m4_append([_LT_TAGS], [$1 ])dnl m4_define([_LT_LANG_]$1[_enabled], [])dnl _LT_LANG_$1_CONFIG($1)])dnl ])# _LT_LANG m4_ifndef([AC_PROG_GO], [ ############################################################ # NOTE: This macro has been submitted for inclusion into # # GNU Autoconf as AC_PROG_GO. When it is available in # # a released version of Autoconf we should remove this # # macro and use it instead. # ############################################################ m4_defun([AC_PROG_GO], [AC_LANG_PUSH(Go)dnl AC_ARG_VAR([GOC], [Go compiler command])dnl AC_ARG_VAR([GOFLAGS], [Go compiler flags])dnl _AC_ARG_VAR_LDFLAGS()dnl AC_CHECK_TOOL(GOC, gccgo) if test -z "$GOC"; then if test -n "$ac_tool_prefix"; then AC_CHECK_PROG(GOC, [${ac_tool_prefix}gccgo], [${ac_tool_prefix}gccgo]) fi fi if test -z "$GOC"; then AC_CHECK_PROG(GOC, gccgo, gccgo, false) fi ])#m4_defun ])#m4_ifndef # _LT_LANG_DEFAULT_CONFIG # ----------------------- m4_defun([_LT_LANG_DEFAULT_CONFIG], [AC_PROVIDE_IFELSE([AC_PROG_CXX], [LT_LANG(CXX)], [m4_define([AC_PROG_CXX], defn([AC_PROG_CXX])[LT_LANG(CXX)])]) AC_PROVIDE_IFELSE([AC_PROG_F77], [LT_LANG(F77)], [m4_define([AC_PROG_F77], defn([AC_PROG_F77])[LT_LANG(F77)])]) AC_PROVIDE_IFELSE([AC_PROG_FC], [LT_LANG(FC)], [m4_define([AC_PROG_FC], defn([AC_PROG_FC])[LT_LANG(FC)])]) dnl The call to [A][M_PROG_GCJ] is quoted like that to stop aclocal dnl pulling things in needlessly. AC_PROVIDE_IFELSE([AC_PROG_GCJ], [LT_LANG(GCJ)], [AC_PROVIDE_IFELSE([A][M_PROG_GCJ], [LT_LANG(GCJ)], [AC_PROVIDE_IFELSE([LT_PROG_GCJ], [LT_LANG(GCJ)], [m4_ifdef([AC_PROG_GCJ], [m4_define([AC_PROG_GCJ], defn([AC_PROG_GCJ])[LT_LANG(GCJ)])]) m4_ifdef([A][M_PROG_GCJ], [m4_define([A][M_PROG_GCJ], defn([A][M_PROG_GCJ])[LT_LANG(GCJ)])]) m4_ifdef([LT_PROG_GCJ], [m4_define([LT_PROG_GCJ], defn([LT_PROG_GCJ])[LT_LANG(GCJ)])])])])]) AC_PROVIDE_IFELSE([AC_PROG_GO], [LT_LANG(GO)], [m4_define([AC_PROG_GO], defn([AC_PROG_GO])[LT_LANG(GO)])]) AC_PROVIDE_IFELSE([LT_PROG_RC], [LT_LANG(RC)], [m4_define([LT_PROG_RC], defn([LT_PROG_RC])[LT_LANG(RC)])]) ])# _LT_LANG_DEFAULT_CONFIG # Obsolete macros: AU_DEFUN([AC_LIBTOOL_CXX], [LT_LANG(C++)]) AU_DEFUN([AC_LIBTOOL_F77], [LT_LANG(Fortran 77)]) AU_DEFUN([AC_LIBTOOL_FC], [LT_LANG(Fortran)]) AU_DEFUN([AC_LIBTOOL_GCJ], [LT_LANG(Java)]) AU_DEFUN([AC_LIBTOOL_RC], [LT_LANG(Windows Resource)]) dnl aclocal-1.4 backwards compatibility: dnl AC_DEFUN([AC_LIBTOOL_CXX], []) dnl AC_DEFUN([AC_LIBTOOL_F77], []) dnl AC_DEFUN([AC_LIBTOOL_FC], []) dnl AC_DEFUN([AC_LIBTOOL_GCJ], []) dnl AC_DEFUN([AC_LIBTOOL_RC], []) # _LT_TAG_COMPILER # ---------------- m4_defun([_LT_TAG_COMPILER], [AC_REQUIRE([AC_PROG_CC])dnl _LT_DECL([LTCC], [CC], [1], [A C compiler])dnl _LT_DECL([LTCFLAGS], [CFLAGS], [1], [LTCC compiler flags])dnl _LT_TAGDECL([CC], [compiler], [1], [A language specific compiler])dnl _LT_TAGDECL([with_gcc], [GCC], [0], [Is the compiler the GNU compiler?])dnl # If no C compiler was specified, use CC. LTCC=${LTCC-"$CC"} # If no C compiler flags were specified, use CFLAGS. LTCFLAGS=${LTCFLAGS-"$CFLAGS"} # Allow CC to be a program name with arguments. compiler=$CC ])# _LT_TAG_COMPILER # _LT_COMPILER_BOILERPLATE # ------------------------ # Check for compiler boilerplate output or warnings with # the simple compiler test code. m4_defun([_LT_COMPILER_BOILERPLATE], [m4_require([_LT_DECL_SED])dnl ac_outfile=conftest.$ac_objext echo "$lt_simple_compile_test_code" >conftest.$ac_ext eval "$ac_compile" 2>&1 >/dev/null | $SED '/^$/d; /^ *+/d' >conftest.err _lt_compiler_boilerplate=`cat conftest.err` $RM conftest* ])# _LT_COMPILER_BOILERPLATE # _LT_LINKER_BOILERPLATE # ---------------------- # Check for linker boilerplate output or warnings with # the simple link test code. m4_defun([_LT_LINKER_BOILERPLATE], [m4_require([_LT_DECL_SED])dnl ac_outfile=conftest.$ac_objext echo "$lt_simple_link_test_code" >conftest.$ac_ext eval "$ac_link" 2>&1 >/dev/null | $SED '/^$/d; /^ *+/d' >conftest.err _lt_linker_boilerplate=`cat conftest.err` $RM -r conftest* ])# _LT_LINKER_BOILERPLATE # _LT_REQUIRED_DARWIN_CHECKS # ------------------------- m4_defun_once([_LT_REQUIRED_DARWIN_CHECKS],[ case $host_os in rhapsody* | darwin*) AC_CHECK_TOOL([DSYMUTIL], [dsymutil], [:]) AC_CHECK_TOOL([NMEDIT], [nmedit], [:]) AC_CHECK_TOOL([LIPO], [lipo], [:]) AC_CHECK_TOOL([OTOOL], [otool], [:]) AC_CHECK_TOOL([OTOOL64], [otool64], [:]) _LT_DECL([], [DSYMUTIL], [1], [Tool to manipulate archived DWARF debug symbol files on Mac OS X]) _LT_DECL([], [NMEDIT], [1], [Tool to change global to local symbols on Mac OS X]) _LT_DECL([], [LIPO], [1], [Tool to manipulate fat objects and archives on Mac OS X]) _LT_DECL([], [OTOOL], [1], [ldd/readelf like tool for Mach-O binaries on Mac OS X]) _LT_DECL([], [OTOOL64], [1], [ldd/readelf like tool for 64 bit Mach-O binaries on Mac OS X 10.4]) AC_CACHE_CHECK([for -single_module linker flag],[lt_cv_apple_cc_single_mod], [lt_cv_apple_cc_single_mod=no if test -z "$LT_MULTI_MODULE"; then # By default we will add the -single_module flag. You can override # by either setting the environment variable LT_MULTI_MODULE # non-empty at configure time, or by adding -multi_module to the # link flags. rm -rf libconftest.dylib* echo "int foo(void){return 1;}" > conftest.c echo "$LTCC $LTCFLAGS $LDFLAGS -o libconftest.dylib \ -dynamiclib -Wl,-single_module conftest.c" >&AS_MESSAGE_LOG_FD $LTCC $LTCFLAGS $LDFLAGS -o libconftest.dylib \ -dynamiclib -Wl,-single_module conftest.c 2>conftest.err _lt_result=$? # If there is a non-empty error log, and "single_module" # appears in it, assume the flag caused a linker warning if test -s conftest.err && $GREP single_module conftest.err; then cat conftest.err >&AS_MESSAGE_LOG_FD # Otherwise, if the output was created with a 0 exit code from # the compiler, it worked. elif test -f libconftest.dylib && test 0 = "$_lt_result"; then lt_cv_apple_cc_single_mod=yes else cat conftest.err >&AS_MESSAGE_LOG_FD fi rm -rf libconftest.dylib* rm -f conftest.* fi]) AC_CACHE_CHECK([for -exported_symbols_list linker flag], [lt_cv_ld_exported_symbols_list], [lt_cv_ld_exported_symbols_list=no save_LDFLAGS=$LDFLAGS echo "_main" > conftest.sym LDFLAGS="$LDFLAGS -Wl,-exported_symbols_list,conftest.sym" AC_LINK_IFELSE([AC_LANG_PROGRAM([],[])], [lt_cv_ld_exported_symbols_list=yes], [lt_cv_ld_exported_symbols_list=no]) LDFLAGS=$save_LDFLAGS ]) AC_CACHE_CHECK([for -force_load linker flag],[lt_cv_ld_force_load], [lt_cv_ld_force_load=no cat > conftest.c << _LT_EOF int forced_loaded() { return 2;} _LT_EOF echo "$LTCC $LTCFLAGS -c -o conftest.o conftest.c" >&AS_MESSAGE_LOG_FD $LTCC $LTCFLAGS -c -o conftest.o conftest.c 2>&AS_MESSAGE_LOG_FD echo "$AR cru libconftest.a conftest.o" >&AS_MESSAGE_LOG_FD $AR cru libconftest.a conftest.o 2>&AS_MESSAGE_LOG_FD echo "$RANLIB libconftest.a" >&AS_MESSAGE_LOG_FD $RANLIB libconftest.a 2>&AS_MESSAGE_LOG_FD cat > conftest.c << _LT_EOF int main() { return 0;} _LT_EOF echo "$LTCC $LTCFLAGS $LDFLAGS -o conftest conftest.c -Wl,-force_load,./libconftest.a" >&AS_MESSAGE_LOG_FD $LTCC $LTCFLAGS $LDFLAGS -o conftest conftest.c -Wl,-force_load,./libconftest.a 2>conftest.err _lt_result=$? if test -s conftest.err && $GREP force_load conftest.err; then cat conftest.err >&AS_MESSAGE_LOG_FD elif test -f conftest && test 0 = "$_lt_result" && $GREP forced_load conftest >/dev/null 2>&1; then lt_cv_ld_force_load=yes else cat conftest.err >&AS_MESSAGE_LOG_FD fi rm -f conftest.err libconftest.a conftest conftest.c rm -rf conftest.dSYM ]) case $host_os in rhapsody* | darwin1.[[012]]) _lt_dar_allow_undefined='$wl-undefined ${wl}suppress' ;; darwin1.*) _lt_dar_allow_undefined='$wl-flat_namespace $wl-undefined ${wl}suppress' ;; darwin*) # darwin 5.x on # if running on 10.5 or later, the deployment target defaults # to the OS version, if on x86, and 10.4, the deployment # target defaults to 10.4. Don't you love it? case ${MACOSX_DEPLOYMENT_TARGET-10.0},$host in 10.0,*86*-darwin8*|10.0,*-darwin[[91]]*) _lt_dar_allow_undefined='$wl-undefined ${wl}dynamic_lookup' ;; 10.[[012]][[,.]]*) _lt_dar_allow_undefined='$wl-flat_namespace $wl-undefined ${wl}suppress' ;; 10.*) _lt_dar_allow_undefined='$wl-undefined ${wl}dynamic_lookup' ;; esac ;; esac if test yes = "$lt_cv_apple_cc_single_mod"; then _lt_dar_single_mod='$single_module' fi if test yes = "$lt_cv_ld_exported_symbols_list"; then _lt_dar_export_syms=' $wl-exported_symbols_list,$output_objdir/$libname-symbols.expsym' else _lt_dar_export_syms='~$NMEDIT -s $output_objdir/$libname-symbols.expsym $lib' fi if test : != "$DSYMUTIL" && test no = "$lt_cv_ld_force_load"; then _lt_dsymutil='~$DSYMUTIL $lib || :' else _lt_dsymutil= fi ;; esac ]) # _LT_DARWIN_LINKER_FEATURES([TAG]) # --------------------------------- # Checks for linker and compiler features on darwin m4_defun([_LT_DARWIN_LINKER_FEATURES], [ m4_require([_LT_REQUIRED_DARWIN_CHECKS]) _LT_TAGVAR(archive_cmds_need_lc, $1)=no _LT_TAGVAR(hardcode_direct, $1)=no _LT_TAGVAR(hardcode_automatic, $1)=yes _LT_TAGVAR(hardcode_shlibpath_var, $1)=unsupported if test yes = "$lt_cv_ld_force_load"; then _LT_TAGVAR(whole_archive_flag_spec, $1)='`for conv in $convenience\"\"; do test -n \"$conv\" && new_convenience=\"$new_convenience $wl-force_load,$conv\"; done; func_echo_all \"$new_convenience\"`' m4_case([$1], [F77], [_LT_TAGVAR(compiler_needs_object, $1)=yes], [FC], [_LT_TAGVAR(compiler_needs_object, $1)=yes]) else _LT_TAGVAR(whole_archive_flag_spec, $1)='' fi _LT_TAGVAR(link_all_deplibs, $1)=yes _LT_TAGVAR(allow_undefined_flag, $1)=$_lt_dar_allow_undefined case $cc_basename in ifort*|nagfor*) _lt_dar_can_shared=yes ;; *) _lt_dar_can_shared=$GCC ;; esac if test yes = "$_lt_dar_can_shared"; then output_verbose_link_cmd=func_echo_all _LT_TAGVAR(archive_cmds, $1)="\$CC -dynamiclib \$allow_undefined_flag -o \$lib \$libobjs \$deplibs \$compiler_flags -install_name \$rpath/\$soname \$verstring $_lt_dar_single_mod$_lt_dsymutil" _LT_TAGVAR(module_cmds, $1)="\$CC \$allow_undefined_flag -o \$lib -bundle \$libobjs \$deplibs \$compiler_flags$_lt_dsymutil" _LT_TAGVAR(archive_expsym_cmds, $1)="sed 's|^|_|' < \$export_symbols > \$output_objdir/\$libname-symbols.expsym~\$CC -dynamiclib \$allow_undefined_flag -o \$lib \$libobjs \$deplibs \$compiler_flags -install_name \$rpath/\$soname \$verstring $_lt_dar_single_mod$_lt_dar_export_syms$_lt_dsymutil" _LT_TAGVAR(module_expsym_cmds, $1)="sed -e 's|^|_|' < \$export_symbols > \$output_objdir/\$libname-symbols.expsym~\$CC \$allow_undefined_flag -o \$lib -bundle \$libobjs \$deplibs \$compiler_flags$_lt_dar_export_syms$_lt_dsymutil" m4_if([$1], [CXX], [ if test yes != "$lt_cv_apple_cc_single_mod"; then _LT_TAGVAR(archive_cmds, $1)="\$CC -r -keep_private_externs -nostdlib -o \$lib-master.o \$libobjs~\$CC -dynamiclib \$allow_undefined_flag -o \$lib \$lib-master.o \$deplibs \$compiler_flags -install_name \$rpath/\$soname \$verstring$_lt_dsymutil" _LT_TAGVAR(archive_expsym_cmds, $1)="sed 's|^|_|' < \$export_symbols > \$output_objdir/\$libname-symbols.expsym~\$CC -r -keep_private_externs -nostdlib -o \$lib-master.o \$libobjs~\$CC -dynamiclib \$allow_undefined_flag -o \$lib \$lib-master.o \$deplibs \$compiler_flags -install_name \$rpath/\$soname \$verstring$_lt_dar_export_syms$_lt_dsymutil" fi ],[]) else _LT_TAGVAR(ld_shlibs, $1)=no fi ]) # _LT_SYS_MODULE_PATH_AIX([TAGNAME]) # ---------------------------------- # Links a minimal program and checks the executable # for the system default hardcoded library path. In most cases, # this is /usr/lib:/lib, but when the MPI compilers are used # the location of the communication and MPI libs are included too. # If we don't find anything, use the default library path according # to the aix ld manual. # Store the results from the different compilers for each TAGNAME. # Allow to override them for all tags through lt_cv_aix_libpath. m4_defun([_LT_SYS_MODULE_PATH_AIX], [m4_require([_LT_DECL_SED])dnl if test set = "${lt_cv_aix_libpath+set}"; then aix_libpath=$lt_cv_aix_libpath else AC_CACHE_VAL([_LT_TAGVAR([lt_cv_aix_libpath_], [$1])], [AC_LINK_IFELSE([AC_LANG_PROGRAM],[ lt_aix_libpath_sed='[ /Import File Strings/,/^$/ { /^0/ { s/^0 *\([^ ]*\) *$/\1/ p } }]' _LT_TAGVAR([lt_cv_aix_libpath_], [$1])=`dump -H conftest$ac_exeext 2>/dev/null | $SED -n -e "$lt_aix_libpath_sed"` # Check for a 64-bit object if we didn't find anything. if test -z "$_LT_TAGVAR([lt_cv_aix_libpath_], [$1])"; then _LT_TAGVAR([lt_cv_aix_libpath_], [$1])=`dump -HX64 conftest$ac_exeext 2>/dev/null | $SED -n -e "$lt_aix_libpath_sed"` fi],[]) if test -z "$_LT_TAGVAR([lt_cv_aix_libpath_], [$1])"; then _LT_TAGVAR([lt_cv_aix_libpath_], [$1])=/usr/lib:/lib fi ]) aix_libpath=$_LT_TAGVAR([lt_cv_aix_libpath_], [$1]) fi ])# _LT_SYS_MODULE_PATH_AIX # _LT_SHELL_INIT(ARG) # ------------------- m4_define([_LT_SHELL_INIT], [m4_divert_text([M4SH-INIT], [$1 ])])# _LT_SHELL_INIT # _LT_PROG_ECHO_BACKSLASH # ----------------------- # Find how we can fake an echo command that does not interpret backslash. # In particular, with Autoconf 2.60 or later we add some code to the start # of the generated configure script that will find a shell with a builtin # printf (that we can use as an echo command). m4_defun([_LT_PROG_ECHO_BACKSLASH], [ECHO='\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\' ECHO=$ECHO$ECHO$ECHO$ECHO$ECHO ECHO=$ECHO$ECHO$ECHO$ECHO$ECHO$ECHO AC_MSG_CHECKING([how to print strings]) # Test print first, because it will be a builtin if present. if test "X`( print -r -- -n ) 2>/dev/null`" = X-n && \ test "X`print -r -- $ECHO 2>/dev/null`" = "X$ECHO"; then ECHO='print -r --' elif test "X`printf %s $ECHO 2>/dev/null`" = "X$ECHO"; then ECHO='printf %s\n' else # Use this function as a fallback that always works. func_fallback_echo () { eval 'cat <<_LTECHO_EOF $[]1 _LTECHO_EOF' } ECHO='func_fallback_echo' fi # func_echo_all arg... # Invoke $ECHO with all args, space-separated. func_echo_all () { $ECHO "$*" } case $ECHO in printf*) AC_MSG_RESULT([printf]) ;; print*) AC_MSG_RESULT([print -r]) ;; *) AC_MSG_RESULT([cat]) ;; esac m4_ifdef([_AS_DETECT_SUGGESTED], [_AS_DETECT_SUGGESTED([ test -n "${ZSH_VERSION+set}${BASH_VERSION+set}" || ( ECHO='\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\' ECHO=$ECHO$ECHO$ECHO$ECHO$ECHO ECHO=$ECHO$ECHO$ECHO$ECHO$ECHO$ECHO PATH=/empty FPATH=/empty; export PATH FPATH test "X`printf %s $ECHO`" = "X$ECHO" \ || test "X`print -r -- $ECHO`" = "X$ECHO" )])]) _LT_DECL([], [SHELL], [1], [Shell to use when invoking shell scripts]) _LT_DECL([], [ECHO], [1], [An echo program that protects backslashes]) ])# _LT_PROG_ECHO_BACKSLASH # _LT_WITH_SYSROOT # ---------------- AC_DEFUN([_LT_WITH_SYSROOT], [AC_MSG_CHECKING([for sysroot]) AC_ARG_WITH([sysroot], [AS_HELP_STRING([--with-sysroot@<:@=DIR@:>@], [Search for dependent libraries within DIR (or the compiler's sysroot if not specified).])], [], [with_sysroot=no]) dnl lt_sysroot will always be passed unquoted. We quote it here dnl in case the user passed a directory name. lt_sysroot= case $with_sysroot in #( yes) if test yes = "$GCC"; then lt_sysroot=`$CC --print-sysroot 2>/dev/null` fi ;; #( /*) lt_sysroot=`echo "$with_sysroot" | sed -e "$sed_quote_subst"` ;; #( no|'') ;; #( *) AC_MSG_RESULT([$with_sysroot]) AC_MSG_ERROR([The sysroot must be an absolute path.]) ;; esac AC_MSG_RESULT([${lt_sysroot:-no}]) _LT_DECL([], [lt_sysroot], [0], [The root where to search for ]dnl [dependent libraries, and where our libraries should be installed.])]) # _LT_ENABLE_LOCK # --------------- m4_defun([_LT_ENABLE_LOCK], [AC_ARG_ENABLE([libtool-lock], [AS_HELP_STRING([--disable-libtool-lock], [avoid locking (might break parallel builds)])]) test no = "$enable_libtool_lock" || enable_libtool_lock=yes # Some flags need to be propagated to the compiler or linker for good # libtool support. case $host in ia64-*-hpux*) # Find out what ABI is being produced by ac_compile, and set mode # options accordingly. echo 'int i;' > conftest.$ac_ext if AC_TRY_EVAL(ac_compile); then case `/usr/bin/file conftest.$ac_objext` in *ELF-32*) HPUX_IA64_MODE=32 ;; *ELF-64*) HPUX_IA64_MODE=64 ;; esac fi rm -rf conftest* ;; *-*-irix6*) # Find out what ABI is being produced by ac_compile, and set linker # options accordingly. echo '[#]line '$LINENO' "configure"' > conftest.$ac_ext if AC_TRY_EVAL(ac_compile); then if test yes = "$lt_cv_prog_gnu_ld"; then case `/usr/bin/file conftest.$ac_objext` in *32-bit*) LD="${LD-ld} -melf32bsmip" ;; *N32*) LD="${LD-ld} -melf32bmipn32" ;; *64-bit*) LD="${LD-ld} -melf64bmip" ;; esac else case `/usr/bin/file conftest.$ac_objext` in *32-bit*) LD="${LD-ld} -32" ;; *N32*) LD="${LD-ld} -n32" ;; *64-bit*) LD="${LD-ld} -64" ;; esac fi fi rm -rf conftest* ;; mips64*-*linux*) # Find out what ABI is being produced by ac_compile, and set linker # options accordingly. echo '[#]line '$LINENO' "configure"' > conftest.$ac_ext if AC_TRY_EVAL(ac_compile); then emul=elf case `/usr/bin/file conftest.$ac_objext` in *32-bit*) emul="${emul}32" ;; *64-bit*) emul="${emul}64" ;; esac case `/usr/bin/file conftest.$ac_objext` in *MSB*) emul="${emul}btsmip" ;; *LSB*) emul="${emul}ltsmip" ;; esac case `/usr/bin/file conftest.$ac_objext` in *N32*) emul="${emul}n32" ;; esac LD="${LD-ld} -m $emul" fi rm -rf conftest* ;; x86_64-*kfreebsd*-gnu|x86_64-*linux*|powerpc*-*linux*| \ s390*-*linux*|s390*-*tpf*|sparc*-*linux*) # Find out what ABI is being produced by ac_compile, and set linker # options accordingly. Note that the listed cases only cover the # situations where additional linker options are needed (such as when # doing 32-bit compilation for a host where ld defaults to 64-bit, or # vice versa); the common cases where no linker options are needed do # not appear in the list. echo 'int i;' > conftest.$ac_ext if AC_TRY_EVAL(ac_compile); then case `/usr/bin/file conftest.o` in *32-bit*) case $host in x86_64-*kfreebsd*-gnu) LD="${LD-ld} -m elf_i386_fbsd" ;; x86_64-*linux*) case `/usr/bin/file conftest.o` in *x86-64*) LD="${LD-ld} -m elf32_x86_64" ;; *) LD="${LD-ld} -m elf_i386" ;; esac ;; powerpc64le-*linux*) LD="${LD-ld} -m elf32lppclinux" ;; powerpc64-*linux*) LD="${LD-ld} -m elf32ppclinux" ;; s390x-*linux*) LD="${LD-ld} -m elf_s390" ;; sparc64-*linux*) LD="${LD-ld} -m elf32_sparc" ;; esac ;; *64-bit*) case $host in x86_64-*kfreebsd*-gnu) LD="${LD-ld} -m elf_x86_64_fbsd" ;; x86_64-*linux*) LD="${LD-ld} -m elf_x86_64" ;; powerpcle-*linux*) LD="${LD-ld} -m elf64lppc" ;; powerpc-*linux*) LD="${LD-ld} -m elf64ppc" ;; s390*-*linux*|s390*-*tpf*) LD="${LD-ld} -m elf64_s390" ;; sparc*-*linux*) LD="${LD-ld} -m elf64_sparc" ;; esac ;; esac fi rm -rf conftest* ;; *-*-sco3.2v5*) # On SCO OpenServer 5, we need -belf to get full-featured binaries. SAVE_CFLAGS=$CFLAGS CFLAGS="$CFLAGS -belf" AC_CACHE_CHECK([whether the C compiler needs -belf], lt_cv_cc_needs_belf, [AC_LANG_PUSH(C) AC_LINK_IFELSE([AC_LANG_PROGRAM([[]],[[]])],[lt_cv_cc_needs_belf=yes],[lt_cv_cc_needs_belf=no]) AC_LANG_POP]) if test yes != "$lt_cv_cc_needs_belf"; then # this is probably gcc 2.8.0, egcs 1.0 or newer; no need for -belf CFLAGS=$SAVE_CFLAGS fi ;; *-*solaris*) # Find out what ABI is being produced by ac_compile, and set linker # options accordingly. echo 'int i;' > conftest.$ac_ext if AC_TRY_EVAL(ac_compile); then case `/usr/bin/file conftest.o` in *64-bit*) case $lt_cv_prog_gnu_ld in yes*) case $host in i?86-*-solaris*|x86_64-*-solaris*) LD="${LD-ld} -m elf_x86_64" ;; sparc*-*-solaris*) LD="${LD-ld} -m elf64_sparc" ;; esac # GNU ld 2.21 introduced _sol2 emulations. Use them if available. if ${LD-ld} -V | grep _sol2 >/dev/null 2>&1; then LD=${LD-ld}_sol2 fi ;; *) if ${LD-ld} -64 -r -o conftest2.o conftest.o >/dev/null 2>&1; then LD="${LD-ld} -64" fi ;; esac ;; esac fi rm -rf conftest* ;; esac need_locks=$enable_libtool_lock ])# _LT_ENABLE_LOCK # _LT_PROG_AR # ----------- m4_defun([_LT_PROG_AR], [AC_CHECK_TOOLS(AR, [ar], false) : ${AR=ar} : ${AR_FLAGS=cru} _LT_DECL([], [AR], [1], [The archiver]) _LT_DECL([], [AR_FLAGS], [1], [Flags to create an archive]) AC_CACHE_CHECK([for archiver @FILE support], [lt_cv_ar_at_file], [lt_cv_ar_at_file=no AC_COMPILE_IFELSE([AC_LANG_PROGRAM], [echo conftest.$ac_objext > conftest.lst lt_ar_try='$AR $AR_FLAGS libconftest.a @conftest.lst >&AS_MESSAGE_LOG_FD' AC_TRY_EVAL([lt_ar_try]) if test 0 -eq "$ac_status"; then # Ensure the archiver fails upon bogus file names. rm -f conftest.$ac_objext libconftest.a AC_TRY_EVAL([lt_ar_try]) if test 0 -ne "$ac_status"; then lt_cv_ar_at_file=@ fi fi rm -f conftest.* libconftest.a ]) ]) if test no = "$lt_cv_ar_at_file"; then archiver_list_spec= else archiver_list_spec=$lt_cv_ar_at_file fi _LT_DECL([], [archiver_list_spec], [1], [How to feed a file listing to the archiver]) ])# _LT_PROG_AR # _LT_CMD_OLD_ARCHIVE # ------------------- m4_defun([_LT_CMD_OLD_ARCHIVE], [_LT_PROG_AR AC_CHECK_TOOL(STRIP, strip, :) test -z "$STRIP" && STRIP=: _LT_DECL([], [STRIP], [1], [A symbol stripping program]) AC_CHECK_TOOL(RANLIB, ranlib, :) test -z "$RANLIB" && RANLIB=: _LT_DECL([], [RANLIB], [1], [Commands used to install an old-style archive]) # Determine commands to create old-style static archives. old_archive_cmds='$AR $AR_FLAGS $oldlib$oldobjs' old_postinstall_cmds='chmod 644 $oldlib' old_postuninstall_cmds= if test -n "$RANLIB"; then case $host_os in bitrig* | openbsd*) old_postinstall_cmds="$old_postinstall_cmds~\$RANLIB -t \$tool_oldlib" ;; *) old_postinstall_cmds="$old_postinstall_cmds~\$RANLIB \$tool_oldlib" ;; esac old_archive_cmds="$old_archive_cmds~\$RANLIB \$tool_oldlib" fi case $host_os in darwin*) lock_old_archive_extraction=yes ;; *) lock_old_archive_extraction=no ;; esac _LT_DECL([], [old_postinstall_cmds], [2]) _LT_DECL([], [old_postuninstall_cmds], [2]) _LT_TAGDECL([], [old_archive_cmds], [2], [Commands used to build an old-style archive]) _LT_DECL([], [lock_old_archive_extraction], [0], [Whether to use a lock for old archive extraction]) ])# _LT_CMD_OLD_ARCHIVE # _LT_COMPILER_OPTION(MESSAGE, VARIABLE-NAME, FLAGS, # [OUTPUT-FILE], [ACTION-SUCCESS], [ACTION-FAILURE]) # ---------------------------------------------------------------- # Check whether the given compiler option works AC_DEFUN([_LT_COMPILER_OPTION], [m4_require([_LT_FILEUTILS_DEFAULTS])dnl m4_require([_LT_DECL_SED])dnl AC_CACHE_CHECK([$1], [$2], [$2=no m4_if([$4], , [ac_outfile=conftest.$ac_objext], [ac_outfile=$4]) echo "$lt_simple_compile_test_code" > conftest.$ac_ext lt_compiler_flag="$3" ## exclude from sc_useless_quotes_in_assignment # Insert the option either (1) after the last *FLAGS variable, or # (2) before a word containing "conftest.", or (3) at the end. # Note that $ac_compile itself does not contain backslashes and begins # with a dollar sign (not a hyphen), so the echo should work correctly. # The option is referenced via a variable to avoid confusing sed. lt_compile=`echo "$ac_compile" | $SED \ -e 's:.*FLAGS}\{0,1\} :&$lt_compiler_flag :; t' \ -e 's: [[^ ]]*conftest\.: $lt_compiler_flag&:; t' \ -e 's:$: $lt_compiler_flag:'` (eval echo "\"\$as_me:$LINENO: $lt_compile\"" >&AS_MESSAGE_LOG_FD) (eval "$lt_compile" 2>conftest.err) ac_status=$? cat conftest.err >&AS_MESSAGE_LOG_FD echo "$as_me:$LINENO: \$? = $ac_status" >&AS_MESSAGE_LOG_FD if (exit $ac_status) && test -s "$ac_outfile"; then # The compiler can only warn and ignore the option if not recognized # So say no if there are warnings other than the usual output. $ECHO "$_lt_compiler_boilerplate" | $SED '/^$/d' >conftest.exp $SED '/^$/d; /^ *+/d' conftest.err >conftest.er2 if test ! -s conftest.er2 || diff conftest.exp conftest.er2 >/dev/null; then $2=yes fi fi $RM conftest* ]) if test yes = "[$]$2"; then m4_if([$5], , :, [$5]) else m4_if([$6], , :, [$6]) fi ])# _LT_COMPILER_OPTION # Old name: AU_ALIAS([AC_LIBTOOL_COMPILER_OPTION], [_LT_COMPILER_OPTION]) dnl aclocal-1.4 backwards compatibility: dnl AC_DEFUN([AC_LIBTOOL_COMPILER_OPTION], []) # _LT_LINKER_OPTION(MESSAGE, VARIABLE-NAME, FLAGS, # [ACTION-SUCCESS], [ACTION-FAILURE]) # ---------------------------------------------------- # Check whether the given linker option works AC_DEFUN([_LT_LINKER_OPTION], [m4_require([_LT_FILEUTILS_DEFAULTS])dnl m4_require([_LT_DECL_SED])dnl AC_CACHE_CHECK([$1], [$2], [$2=no save_LDFLAGS=$LDFLAGS LDFLAGS="$LDFLAGS $3" echo "$lt_simple_link_test_code" > conftest.$ac_ext if (eval $ac_link 2>conftest.err) && test -s conftest$ac_exeext; then # The linker can only warn and ignore the option if not recognized # So say no if there are warnings if test -s conftest.err; then # Append any errors to the config.log. cat conftest.err 1>&AS_MESSAGE_LOG_FD $ECHO "$_lt_linker_boilerplate" | $SED '/^$/d' > conftest.exp $SED '/^$/d; /^ *+/d' conftest.err >conftest.er2 if diff conftest.exp conftest.er2 >/dev/null; then $2=yes fi else $2=yes fi fi $RM -r conftest* LDFLAGS=$save_LDFLAGS ]) if test yes = "[$]$2"; then m4_if([$4], , :, [$4]) else m4_if([$5], , :, [$5]) fi ])# _LT_LINKER_OPTION # Old name: AU_ALIAS([AC_LIBTOOL_LINKER_OPTION], [_LT_LINKER_OPTION]) dnl aclocal-1.4 backwards compatibility: dnl AC_DEFUN([AC_LIBTOOL_LINKER_OPTION], []) # LT_CMD_MAX_LEN #--------------- AC_DEFUN([LT_CMD_MAX_LEN], [AC_REQUIRE([AC_CANONICAL_HOST])dnl # find the maximum length of command line arguments AC_MSG_CHECKING([the maximum length of command line arguments]) AC_CACHE_VAL([lt_cv_sys_max_cmd_len], [dnl i=0 teststring=ABCD case $build_os in msdosdjgpp*) # On DJGPP, this test can blow up pretty badly due to problems in libc # (any single argument exceeding 2000 bytes causes a buffer overrun # during glob expansion). Even if it were fixed, the result of this # check would be larger than it should be. lt_cv_sys_max_cmd_len=12288; # 12K is about right ;; gnu*) # Under GNU Hurd, this test is not required because there is # no limit to the length of command line arguments. # Libtool will interpret -1 as no limit whatsoever lt_cv_sys_max_cmd_len=-1; ;; cygwin* | mingw* | cegcc*) # On Win9x/ME, this test blows up -- it succeeds, but takes # about 5 minutes as the teststring grows exponentially. # Worse, since 9x/ME are not pre-emptively multitasking, # you end up with a "frozen" computer, even though with patience # the test eventually succeeds (with a max line length of 256k). # Instead, let's just punt: use the minimum linelength reported by # all of the supported platforms: 8192 (on NT/2K/XP). lt_cv_sys_max_cmd_len=8192; ;; mint*) # On MiNT this can take a long time and run out of memory. lt_cv_sys_max_cmd_len=8192; ;; amigaos*) # On AmigaOS with pdksh, this test takes hours, literally. # So we just punt and use a minimum line length of 8192. lt_cv_sys_max_cmd_len=8192; ;; bitrig* | darwin* | dragonfly* | freebsd* | netbsd* | openbsd*) # This has been around since 386BSD, at least. Likely further. if test -x /sbin/sysctl; then lt_cv_sys_max_cmd_len=`/sbin/sysctl -n kern.argmax` elif test -x /usr/sbin/sysctl; then lt_cv_sys_max_cmd_len=`/usr/sbin/sysctl -n kern.argmax` else lt_cv_sys_max_cmd_len=65536 # usable default for all BSDs fi # And add a safety zone lt_cv_sys_max_cmd_len=`expr $lt_cv_sys_max_cmd_len \/ 4` lt_cv_sys_max_cmd_len=`expr $lt_cv_sys_max_cmd_len \* 3` ;; interix*) # We know the value 262144 and hardcode it with a safety zone (like BSD) lt_cv_sys_max_cmd_len=196608 ;; os2*) # The test takes a long time on OS/2. lt_cv_sys_max_cmd_len=8192 ;; osf*) # Dr. Hans Ekkehard Plesser reports seeing a kernel panic running configure # due to this test when exec_disable_arg_limit is 1 on Tru64. It is not # nice to cause kernel panics so lets avoid the loop below. # First set a reasonable default. lt_cv_sys_max_cmd_len=16384 # if test -x /sbin/sysconfig; then case `/sbin/sysconfig -q proc exec_disable_arg_limit` in *1*) lt_cv_sys_max_cmd_len=-1 ;; esac fi ;; sco3.2v5*) lt_cv_sys_max_cmd_len=102400 ;; sysv5* | sco5v6* | sysv4.2uw2*) kargmax=`grep ARG_MAX /etc/conf/cf.d/stune 2>/dev/null` if test -n "$kargmax"; then lt_cv_sys_max_cmd_len=`echo $kargmax | sed 's/.*[[ ]]//'` else lt_cv_sys_max_cmd_len=32768 fi ;; *) lt_cv_sys_max_cmd_len=`(getconf ARG_MAX) 2> /dev/null` if test -n "$lt_cv_sys_max_cmd_len" && \ test undefined != "$lt_cv_sys_max_cmd_len"; then lt_cv_sys_max_cmd_len=`expr $lt_cv_sys_max_cmd_len \/ 4` lt_cv_sys_max_cmd_len=`expr $lt_cv_sys_max_cmd_len \* 3` else # Make teststring a little bigger before we do anything with it. # a 1K string should be a reasonable start. for i in 1 2 3 4 5 6 7 8; do teststring=$teststring$teststring done SHELL=${SHELL-${CONFIG_SHELL-/bin/sh}} # If test is not a shell built-in, we'll probably end up computing a # maximum length that is only half of the actual maximum length, but # we can't tell. while { test X`env echo "$teststring$teststring" 2>/dev/null` \ = "X$teststring$teststring"; } >/dev/null 2>&1 && test 17 != "$i" # 1/2 MB should be enough do i=`expr $i + 1` teststring=$teststring$teststring done # Only check the string length outside the loop. lt_cv_sys_max_cmd_len=`expr "X$teststring" : ".*" 2>&1` teststring= # Add a significant safety factor because C++ compilers can tack on # massive amounts of additional arguments before passing them to the # linker. It appears as though 1/2 is a usable value. lt_cv_sys_max_cmd_len=`expr $lt_cv_sys_max_cmd_len \/ 2` fi ;; esac ]) if test -n "$lt_cv_sys_max_cmd_len"; then AC_MSG_RESULT($lt_cv_sys_max_cmd_len) else AC_MSG_RESULT(none) fi max_cmd_len=$lt_cv_sys_max_cmd_len _LT_DECL([], [max_cmd_len], [0], [What is the maximum length of a command?]) ])# LT_CMD_MAX_LEN # Old name: AU_ALIAS([AC_LIBTOOL_SYS_MAX_CMD_LEN], [LT_CMD_MAX_LEN]) dnl aclocal-1.4 backwards compatibility: dnl AC_DEFUN([AC_LIBTOOL_SYS_MAX_CMD_LEN], []) # _LT_HEADER_DLFCN # ---------------- m4_defun([_LT_HEADER_DLFCN], [AC_CHECK_HEADERS([dlfcn.h], [], [], [AC_INCLUDES_DEFAULT])dnl ])# _LT_HEADER_DLFCN # _LT_TRY_DLOPEN_SELF (ACTION-IF-TRUE, ACTION-IF-TRUE-W-USCORE, # ACTION-IF-FALSE, ACTION-IF-CROSS-COMPILING) # ---------------------------------------------------------------- m4_defun([_LT_TRY_DLOPEN_SELF], [m4_require([_LT_HEADER_DLFCN])dnl if test yes = "$cross_compiling"; then : [$4] else lt_dlunknown=0; lt_dlno_uscore=1; lt_dlneed_uscore=2 lt_status=$lt_dlunknown cat > conftest.$ac_ext <<_LT_EOF [#line $LINENO "configure" #include "confdefs.h" #if HAVE_DLFCN_H #include #endif #include #ifdef RTLD_GLOBAL # define LT_DLGLOBAL RTLD_GLOBAL #else # ifdef DL_GLOBAL # define LT_DLGLOBAL DL_GLOBAL # else # define LT_DLGLOBAL 0 # endif #endif /* We may have to define LT_DLLAZY_OR_NOW in the command line if we find out it does not work in some platform. */ #ifndef LT_DLLAZY_OR_NOW # ifdef RTLD_LAZY # define LT_DLLAZY_OR_NOW RTLD_LAZY # else # ifdef DL_LAZY # define LT_DLLAZY_OR_NOW DL_LAZY # else # ifdef RTLD_NOW # define LT_DLLAZY_OR_NOW RTLD_NOW # else # ifdef DL_NOW # define LT_DLLAZY_OR_NOW DL_NOW # else # define LT_DLLAZY_OR_NOW 0 # endif # endif # endif # endif #endif /* When -fvisibility=hidden is used, assume the code has been annotated correspondingly for the symbols needed. */ #if defined __GNUC__ && (((__GNUC__ == 3) && (__GNUC_MINOR__ >= 3)) || (__GNUC__ > 3)) int fnord () __attribute__((visibility("default"))); #endif int fnord () { return 42; } int main () { void *self = dlopen (0, LT_DLGLOBAL|LT_DLLAZY_OR_NOW); int status = $lt_dlunknown; if (self) { if (dlsym (self,"fnord")) status = $lt_dlno_uscore; else { if (dlsym( self,"_fnord")) status = $lt_dlneed_uscore; else puts (dlerror ()); } /* dlclose (self); */ } else puts (dlerror ()); return status; }] _LT_EOF if AC_TRY_EVAL(ac_link) && test -s "conftest$ac_exeext" 2>/dev/null; then (./conftest; exit; ) >&AS_MESSAGE_LOG_FD 2>/dev/null lt_status=$? case x$lt_status in x$lt_dlno_uscore) $1 ;; x$lt_dlneed_uscore) $2 ;; x$lt_dlunknown|x*) $3 ;; esac else : # compilation failed $3 fi fi rm -fr conftest* ])# _LT_TRY_DLOPEN_SELF # LT_SYS_DLOPEN_SELF # ------------------ AC_DEFUN([LT_SYS_DLOPEN_SELF], [m4_require([_LT_HEADER_DLFCN])dnl if test yes != "$enable_dlopen"; then enable_dlopen=unknown enable_dlopen_self=unknown enable_dlopen_self_static=unknown else lt_cv_dlopen=no lt_cv_dlopen_libs= case $host_os in beos*) lt_cv_dlopen=load_add_on lt_cv_dlopen_libs= lt_cv_dlopen_self=yes ;; mingw* | pw32* | cegcc*) lt_cv_dlopen=LoadLibrary lt_cv_dlopen_libs= ;; cygwin*) lt_cv_dlopen=dlopen lt_cv_dlopen_libs= ;; darwin*) # if libdl is installed we need to link against it AC_CHECK_LIB([dl], [dlopen], [lt_cv_dlopen=dlopen lt_cv_dlopen_libs=-ldl],[ lt_cv_dlopen=dyld lt_cv_dlopen_libs= lt_cv_dlopen_self=yes ]) ;; tpf*) # Don't try to run any link tests for TPF. We know it's impossible # because TPF is a cross-compiler, and we know how we open DSOs. lt_cv_dlopen=dlopen lt_cv_dlopen_libs= lt_cv_dlopen_self=no ;; *) AC_CHECK_FUNC([shl_load], [lt_cv_dlopen=shl_load], [AC_CHECK_LIB([dld], [shl_load], [lt_cv_dlopen=shl_load lt_cv_dlopen_libs=-ldld], [AC_CHECK_FUNC([dlopen], [lt_cv_dlopen=dlopen], [AC_CHECK_LIB([dl], [dlopen], [lt_cv_dlopen=dlopen lt_cv_dlopen_libs=-ldl], [AC_CHECK_LIB([svld], [dlopen], [lt_cv_dlopen=dlopen lt_cv_dlopen_libs=-lsvld], [AC_CHECK_LIB([dld], [dld_link], [lt_cv_dlopen=dld_link lt_cv_dlopen_libs=-ldld]) ]) ]) ]) ]) ]) ;; esac if test no = "$lt_cv_dlopen"; then enable_dlopen=no else enable_dlopen=yes fi case $lt_cv_dlopen in dlopen) save_CPPFLAGS=$CPPFLAGS test yes = "$ac_cv_header_dlfcn_h" && CPPFLAGS="$CPPFLAGS -DHAVE_DLFCN_H" save_LDFLAGS=$LDFLAGS wl=$lt_prog_compiler_wl eval LDFLAGS=\"\$LDFLAGS $export_dynamic_flag_spec\" save_LIBS=$LIBS LIBS="$lt_cv_dlopen_libs $LIBS" AC_CACHE_CHECK([whether a program can dlopen itself], lt_cv_dlopen_self, [dnl _LT_TRY_DLOPEN_SELF( lt_cv_dlopen_self=yes, lt_cv_dlopen_self=yes, lt_cv_dlopen_self=no, lt_cv_dlopen_self=cross) ]) if test yes = "$lt_cv_dlopen_self"; then wl=$lt_prog_compiler_wl eval LDFLAGS=\"\$LDFLAGS $lt_prog_compiler_static\" AC_CACHE_CHECK([whether a statically linked program can dlopen itself], lt_cv_dlopen_self_static, [dnl _LT_TRY_DLOPEN_SELF( lt_cv_dlopen_self_static=yes, lt_cv_dlopen_self_static=yes, lt_cv_dlopen_self_static=no, lt_cv_dlopen_self_static=cross) ]) fi CPPFLAGS=$save_CPPFLAGS LDFLAGS=$save_LDFLAGS LIBS=$save_LIBS ;; esac case $lt_cv_dlopen_self in yes|no) enable_dlopen_self=$lt_cv_dlopen_self ;; *) enable_dlopen_self=unknown ;; esac case $lt_cv_dlopen_self_static in yes|no) enable_dlopen_self_static=$lt_cv_dlopen_self_static ;; *) enable_dlopen_self_static=unknown ;; esac fi _LT_DECL([dlopen_support], [enable_dlopen], [0], [Whether dlopen is supported]) _LT_DECL([dlopen_self], [enable_dlopen_self], [0], [Whether dlopen of programs is supported]) _LT_DECL([dlopen_self_static], [enable_dlopen_self_static], [0], [Whether dlopen of statically linked programs is supported]) ])# LT_SYS_DLOPEN_SELF # Old name: AU_ALIAS([AC_LIBTOOL_DLOPEN_SELF], [LT_SYS_DLOPEN_SELF]) dnl aclocal-1.4 backwards compatibility: dnl AC_DEFUN([AC_LIBTOOL_DLOPEN_SELF], []) # _LT_COMPILER_C_O([TAGNAME]) # --------------------------- # Check to see if options -c and -o are simultaneously supported by compiler. # This macro does not hard code the compiler like AC_PROG_CC_C_O. m4_defun([_LT_COMPILER_C_O], [m4_require([_LT_DECL_SED])dnl m4_require([_LT_FILEUTILS_DEFAULTS])dnl m4_require([_LT_TAG_COMPILER])dnl AC_CACHE_CHECK([if $compiler supports -c -o file.$ac_objext], [_LT_TAGVAR(lt_cv_prog_compiler_c_o, $1)], [_LT_TAGVAR(lt_cv_prog_compiler_c_o, $1)=no $RM -r conftest 2>/dev/null mkdir conftest cd conftest mkdir out echo "$lt_simple_compile_test_code" > conftest.$ac_ext lt_compiler_flag="-o out/conftest2.$ac_objext" # Insert the option either (1) after the last *FLAGS variable, or # (2) before a word containing "conftest.", or (3) at the end. # Note that $ac_compile itself does not contain backslashes and begins # with a dollar sign (not a hyphen), so the echo should work correctly. lt_compile=`echo "$ac_compile" | $SED \ -e 's:.*FLAGS}\{0,1\} :&$lt_compiler_flag :; t' \ -e 's: [[^ ]]*conftest\.: $lt_compiler_flag&:; t' \ -e 's:$: $lt_compiler_flag:'` (eval echo "\"\$as_me:$LINENO: $lt_compile\"" >&AS_MESSAGE_LOG_FD) (eval "$lt_compile" 2>out/conftest.err) ac_status=$? cat out/conftest.err >&AS_MESSAGE_LOG_FD echo "$as_me:$LINENO: \$? = $ac_status" >&AS_MESSAGE_LOG_FD if (exit $ac_status) && test -s out/conftest2.$ac_objext then # The compiler can only warn and ignore the option if not recognized # So say no if there are warnings $ECHO "$_lt_compiler_boilerplate" | $SED '/^$/d' > out/conftest.exp $SED '/^$/d; /^ *+/d' out/conftest.err >out/conftest.er2 if test ! -s out/conftest.er2 || diff out/conftest.exp out/conftest.er2 >/dev/null; then _LT_TAGVAR(lt_cv_prog_compiler_c_o, $1)=yes fi fi chmod u+w . 2>&AS_MESSAGE_LOG_FD $RM conftest* # SGI C++ compiler will create directory out/ii_files/ for # template instantiation test -d out/ii_files && $RM out/ii_files/* && rmdir out/ii_files $RM out/* && rmdir out cd .. $RM -r conftest $RM conftest* ]) _LT_TAGDECL([compiler_c_o], [lt_cv_prog_compiler_c_o], [1], [Does compiler simultaneously support -c and -o options?]) ])# _LT_COMPILER_C_O # _LT_COMPILER_FILE_LOCKS([TAGNAME]) # ---------------------------------- # Check to see if we can do hard links to lock some files if needed m4_defun([_LT_COMPILER_FILE_LOCKS], [m4_require([_LT_ENABLE_LOCK])dnl m4_require([_LT_FILEUTILS_DEFAULTS])dnl _LT_COMPILER_C_O([$1]) hard_links=nottested if test no = "$_LT_TAGVAR(lt_cv_prog_compiler_c_o, $1)" && test no != "$need_locks"; then # do not overwrite the value of need_locks provided by the user AC_MSG_CHECKING([if we can lock with hard links]) hard_links=yes $RM conftest* ln conftest.a conftest.b 2>/dev/null && hard_links=no touch conftest.a ln conftest.a conftest.b 2>&5 || hard_links=no ln conftest.a conftest.b 2>/dev/null && hard_links=no AC_MSG_RESULT([$hard_links]) if test no = "$hard_links"; then AC_MSG_WARN(['$CC' does not support '-c -o', so 'make -j' may be unsafe]) need_locks=warn fi else need_locks=no fi _LT_DECL([], [need_locks], [1], [Must we lock files when doing compilation?]) ])# _LT_COMPILER_FILE_LOCKS # _LT_CHECK_OBJDIR # ---------------- m4_defun([_LT_CHECK_OBJDIR], [AC_CACHE_CHECK([for objdir], [lt_cv_objdir], [rm -f .libs 2>/dev/null mkdir .libs 2>/dev/null if test -d .libs; then lt_cv_objdir=.libs else # MS-DOS does not allow filenames that begin with a dot. lt_cv_objdir=_libs fi rmdir .libs 2>/dev/null]) objdir=$lt_cv_objdir _LT_DECL([], [objdir], [0], [The name of the directory that contains temporary libtool files])dnl m4_pattern_allow([LT_OBJDIR])dnl AC_DEFINE_UNQUOTED([LT_OBJDIR], "$lt_cv_objdir/", [Define to the sub-directory where libtool stores uninstalled libraries.]) ])# _LT_CHECK_OBJDIR # _LT_LINKER_HARDCODE_LIBPATH([TAGNAME]) # -------------------------------------- # Check hardcoding attributes. m4_defun([_LT_LINKER_HARDCODE_LIBPATH], [AC_MSG_CHECKING([how to hardcode library paths into programs]) _LT_TAGVAR(hardcode_action, $1)= if test -n "$_LT_TAGVAR(hardcode_libdir_flag_spec, $1)" || test -n "$_LT_TAGVAR(runpath_var, $1)" || test yes = "$_LT_TAGVAR(hardcode_automatic, $1)"; then # We can hardcode non-existent directories. if test no != "$_LT_TAGVAR(hardcode_direct, $1)" && # If the only mechanism to avoid hardcoding is shlibpath_var, we # have to relink, otherwise we might link with an installed library # when we should be linking with a yet-to-be-installed one ## test no != "$_LT_TAGVAR(hardcode_shlibpath_var, $1)" && test no != "$_LT_TAGVAR(hardcode_minus_L, $1)"; then # Linking always hardcodes the temporary library directory. _LT_TAGVAR(hardcode_action, $1)=relink else # We can link without hardcoding, and we can hardcode nonexisting dirs. _LT_TAGVAR(hardcode_action, $1)=immediate fi else # We cannot hardcode anything, or else we can only hardcode existing # directories. _LT_TAGVAR(hardcode_action, $1)=unsupported fi AC_MSG_RESULT([$_LT_TAGVAR(hardcode_action, $1)]) if test relink = "$_LT_TAGVAR(hardcode_action, $1)" || test yes = "$_LT_TAGVAR(inherit_rpath, $1)"; then # Fast installation is not supported enable_fast_install=no elif test yes = "$shlibpath_overrides_runpath" || test no = "$enable_shared"; then # Fast installation is not necessary enable_fast_install=needless fi _LT_TAGDECL([], [hardcode_action], [0], [How to hardcode a shared library path into an executable]) ])# _LT_LINKER_HARDCODE_LIBPATH # _LT_CMD_STRIPLIB # ---------------- m4_defun([_LT_CMD_STRIPLIB], [m4_require([_LT_DECL_EGREP]) striplib= old_striplib= AC_MSG_CHECKING([whether stripping libraries is possible]) if test -n "$STRIP" && $STRIP -V 2>&1 | $GREP "GNU strip" >/dev/null; then test -z "$old_striplib" && old_striplib="$STRIP --strip-debug" test -z "$striplib" && striplib="$STRIP --strip-unneeded" AC_MSG_RESULT([yes]) else # FIXME - insert some real tests, host_os isn't really good enough case $host_os in darwin*) if test -n "$STRIP"; then striplib="$STRIP -x" old_striplib="$STRIP -S" AC_MSG_RESULT([yes]) else AC_MSG_RESULT([no]) fi ;; *) AC_MSG_RESULT([no]) ;; esac fi _LT_DECL([], [old_striplib], [1], [Commands to strip libraries]) _LT_DECL([], [striplib], [1]) ])# _LT_CMD_STRIPLIB # _LT_PREPARE_MUNGE_PATH_LIST # --------------------------- # Make sure func_munge_path_list() is defined correctly. m4_defun([_LT_PREPARE_MUNGE_PATH_LIST], [[# func_munge_path_list VARIABLE PATH # ----------------------------------- # VARIABLE is name of variable containing _space_ separated list of # directories to be munged by the contents of PATH, which is string # having a format: # "DIR[:DIR]:" # string "DIR[ DIR]" will be prepended to VARIABLE # ":DIR[:DIR]" # string "DIR[ DIR]" will be appended to VARIABLE # "DIRP[:DIRP]::[DIRA:]DIRA" # string "DIRP[ DIRP]" will be prepended to VARIABLE and string # "DIRA[ DIRA]" will be appended to VARIABLE # "DIR[:DIR]" # VARIABLE will be replaced by "DIR[ DIR]" func_munge_path_list () { case x@S|@2 in x) ;; *:) eval @S|@1=\"`$ECHO @S|@2 | $SED 's/:/ /g'` \@S|@@S|@1\" ;; x:*) eval @S|@1=\"\@S|@@S|@1 `$ECHO @S|@2 | $SED 's/:/ /g'`\" ;; *::*) eval @S|@1=\"\@S|@@S|@1\ `$ECHO @S|@2 | $SED -e 's/.*:://' -e 's/:/ /g'`\" eval @S|@1=\"`$ECHO @S|@2 | $SED -e 's/::.*//' -e 's/:/ /g'`\ \@S|@@S|@1\" ;; *) eval @S|@1=\"`$ECHO @S|@2 | $SED 's/:/ /g'`\" ;; esac } ]])# _LT_PREPARE_PATH_LIST # _LT_SYS_DYNAMIC_LINKER([TAG]) # ----------------------------- # PORTME Fill in your ld.so characteristics m4_defun([_LT_SYS_DYNAMIC_LINKER], [AC_REQUIRE([AC_CANONICAL_HOST])dnl m4_require([_LT_DECL_EGREP])dnl m4_require([_LT_FILEUTILS_DEFAULTS])dnl m4_require([_LT_DECL_OBJDUMP])dnl m4_require([_LT_DECL_SED])dnl m4_require([_LT_CHECK_SHELL_FEATURES])dnl m4_require([_LT_PREPARE_MUNGE_PATH_LIST])dnl AC_MSG_CHECKING([dynamic linker characteristics]) m4_if([$1], [], [ if test yes = "$GCC"; then case $host_os in darwin*) lt_awk_arg='/^libraries:/,/LR/' ;; *) lt_awk_arg='/^libraries:/' ;; esac case $host_os in mingw* | cegcc*) lt_sed_strip_eq='s|=\([[A-Za-z]]:\)|\1|g' ;; *) lt_sed_strip_eq='s|=/|/|g' ;; esac lt_search_path_spec=`$CC -print-search-dirs | awk $lt_awk_arg | $SED -e "s/^libraries://" -e $lt_sed_strip_eq` case $lt_search_path_spec in *\;*) # if the path contains ";" then we assume it to be the separator # otherwise default to the standard path separator (i.e. ":") - it is # assumed that no part of a normal pathname contains ";" but that should # okay in the real world where ";" in dirpaths is itself problematic. lt_search_path_spec=`$ECHO "$lt_search_path_spec" | $SED 's/;/ /g'` ;; *) lt_search_path_spec=`$ECHO "$lt_search_path_spec" | $SED "s/$PATH_SEPARATOR/ /g"` ;; esac # Ok, now we have the path, separated by spaces, we can step through it # and add multilib dir if necessary... lt_tmp_lt_search_path_spec= lt_multi_os_dir=/`$CC $CPPFLAGS $CFLAGS $LDFLAGS -print-multi-os-directory 2>/dev/null` # ...but if some path component already ends with the multilib dir we assume # that all is fine and trust -print-search-dirs as is (GCC 4.2? or newer). case "$lt_multi_os_dir; $lt_search_path_spec " in "/; "* | "/.; "* | "/./; "* | *"$lt_multi_os_dir "* | *"$lt_multi_os_dir/ "*) lt_multi_os_dir= ;; esac for lt_sys_path in $lt_search_path_spec; do if test -d "$lt_sys_path$lt_multi_os_dir"; then lt_tmp_lt_search_path_spec="$lt_tmp_lt_search_path_spec $lt_sys_path$lt_multi_os_dir" elif test -n "$lt_multi_os_dir"; then test -d "$lt_sys_path" && \ lt_tmp_lt_search_path_spec="$lt_tmp_lt_search_path_spec $lt_sys_path" fi done lt_search_path_spec=`$ECHO "$lt_tmp_lt_search_path_spec" | awk ' BEGIN {RS = " "; FS = "/|\n";} { lt_foo = ""; lt_count = 0; for (lt_i = NF; lt_i > 0; lt_i--) { if ($lt_i != "" && $lt_i != ".") { if ($lt_i == "..") { lt_count++; } else { if (lt_count == 0) { lt_foo = "/" $lt_i lt_foo; } else { lt_count--; } } } } if (lt_foo != "") { lt_freq[[lt_foo]]++; } if (lt_freq[[lt_foo]] == 1) { print lt_foo; } }'` # AWK program above erroneously prepends '/' to C:/dos/paths # for these hosts. case $host_os in mingw* | cegcc*) lt_search_path_spec=`$ECHO "$lt_search_path_spec" |\ $SED 's|/\([[A-Za-z]]:\)|\1|g'` ;; esac sys_lib_search_path_spec=`$ECHO "$lt_search_path_spec" | $lt_NL2SP` else sys_lib_search_path_spec="/lib /usr/lib /usr/local/lib" fi]) library_names_spec= libname_spec='lib$name' soname_spec= shrext_cmds=.so postinstall_cmds= postuninstall_cmds= finish_cmds= finish_eval= shlibpath_var= shlibpath_overrides_runpath=unknown version_type=none dynamic_linker="$host_os ld.so" sys_lib_dlsearch_path_spec="/lib /usr/lib" need_lib_prefix=unknown hardcode_into_libs=no # when you set need_version to no, make sure it does not cause -set_version # flags to be left without arguments need_version=unknown AC_ARG_VAR([LT_SYS_LIBRARY_PATH], [User-defined run-time library search path.]) case $host_os in aix3*) version_type=linux # correct to gnu/linux during the next big refactor library_names_spec='$libname$release$shared_ext$versuffix $libname.a' shlibpath_var=LIBPATH # AIX 3 has no versioning support, so we append a major version to the name. soname_spec='$libname$release$shared_ext$major' ;; aix[[4-9]]*) version_type=linux # correct to gnu/linux during the next big refactor need_lib_prefix=no need_version=no hardcode_into_libs=yes if test ia64 = "$host_cpu"; then # AIX 5 supports IA64 library_names_spec='$libname$release$shared_ext$major $libname$release$shared_ext$versuffix $libname$shared_ext' shlibpath_var=LD_LIBRARY_PATH else # With GCC up to 2.95.x, collect2 would create an import file # for dependence libraries. The import file would start with # the line '#! .'. This would cause the generated library to # depend on '.', always an invalid library. This was fixed in # development snapshots of GCC prior to 3.0. case $host_os in aix4 | aix4.[[01]] | aix4.[[01]].*) if { echo '#if __GNUC__ > 2 || (__GNUC__ == 2 && __GNUC_MINOR__ >= 97)' echo ' yes ' echo '#endif'; } | $CC -E - | $GREP yes > /dev/null; then : else can_build_shared=no fi ;; esac # Using Import Files as archive members, it is possible to support # filename-based versioning of shared library archives on AIX. While # this would work for both with and without runtime linking, it will # prevent static linking of such archives. So we do filename-based # shared library versioning with .so extension only, which is used # when both runtime linking and shared linking is enabled. # Unfortunately, runtime linking may impact performance, so we do # not want this to be the default eventually. Also, we use the # versioned .so libs for executables only if there is the -brtl # linker flag in LDFLAGS as well, or --with-aix-soname=svr4 only. # To allow for filename-based versioning support, we need to create # libNAME.so.V as an archive file, containing: # *) an Import File, referring to the versioned filename of the # archive as well as the shared archive member, telling the # bitwidth (32 or 64) of that shared object, and providing the # list of exported symbols of that shared object, eventually # decorated with the 'weak' keyword # *) the shared object with the F_LOADONLY flag set, to really avoid # it being seen by the linker. # At run time we better use the real file rather than another symlink, # but for link time we create the symlink libNAME.so -> libNAME.so.V case $with_aix_soname,$aix_use_runtimelinking in # AIX (on Power*) has no versioning support, so currently we cannot hardcode correct # soname into executable. Probably we can add versioning support to # collect2, so additional links can be useful in future. aix,yes) # traditional libtool dynamic_linker='AIX unversionable lib.so' # If using run time linking (on AIX 4.2 or later) use lib.so # instead of lib.a to let people know that these are not # typical AIX shared libraries. library_names_spec='$libname$release$shared_ext$versuffix $libname$release$shared_ext$major $libname$shared_ext' ;; aix,no) # traditional AIX only dynamic_linker='AIX lib.a[(]lib.so.V[)]' # We preserve .a as extension for shared libraries through AIX4.2 # and later when we are not doing run time linking. library_names_spec='$libname$release.a $libname.a' soname_spec='$libname$release$shared_ext$major' ;; svr4,*) # full svr4 only dynamic_linker="AIX lib.so.V[(]$shared_archive_member_spec.o[)]" library_names_spec='$libname$release$shared_ext$major $libname$shared_ext' # We do not specify a path in Import Files, so LIBPATH fires. shlibpath_overrides_runpath=yes ;; *,yes) # both, prefer svr4 dynamic_linker="AIX lib.so.V[(]$shared_archive_member_spec.o[)], lib.a[(]lib.so.V[)]" library_names_spec='$libname$release$shared_ext$major $libname$shared_ext' # unpreferred sharedlib libNAME.a needs extra handling postinstall_cmds='test -n "$linkname" || linkname="$realname"~func_stripname "" ".so" "$linkname"~$install_shared_prog "$dir/$func_stripname_result.$libext" "$destdir/$func_stripname_result.$libext"~test -z "$tstripme" || test -z "$striplib" || $striplib "$destdir/$func_stripname_result.$libext"' postuninstall_cmds='for n in $library_names $old_library; do :; done~func_stripname "" ".so" "$n"~test "$func_stripname_result" = "$n" || func_append rmfiles " $odir/$func_stripname_result.$libext"' # We do not specify a path in Import Files, so LIBPATH fires. shlibpath_overrides_runpath=yes ;; *,no) # both, prefer aix dynamic_linker="AIX lib.a[(]lib.so.V[)], lib.so.V[(]$shared_archive_member_spec.o[)]" library_names_spec='$libname$release.a $libname.a' soname_spec='$libname$release$shared_ext$major' # unpreferred sharedlib libNAME.so.V and symlink libNAME.so need extra handling postinstall_cmds='test -z "$dlname" || $install_shared_prog $dir/$dlname $destdir/$dlname~test -z "$tstripme" || test -z "$striplib" || $striplib $destdir/$dlname~test -n "$linkname" || linkname=$realname~func_stripname "" ".a" "$linkname"~(cd "$destdir" && $LN_S -f $dlname $func_stripname_result.so)' postuninstall_cmds='test -z "$dlname" || func_append rmfiles " $odir/$dlname"~for n in $old_library $library_names; do :; done~func_stripname "" ".a" "$n"~func_append rmfiles " $odir/$func_stripname_result.so"' ;; esac shlibpath_var=LIBPATH fi ;; amigaos*) case $host_cpu in powerpc) # Since July 2007 AmigaOS4 officially supports .so libraries. # When compiling the executable, add -use-dynld -Lsobjs: to the compileline. library_names_spec='$libname$release$shared_ext$versuffix $libname$release$shared_ext$major $libname$shared_ext' ;; m68k) library_names_spec='$libname.ixlibrary $libname.a' # Create ${libname}_ixlibrary.a entries in /sys/libs. finish_eval='for lib in `ls $libdir/*.ixlibrary 2>/dev/null`; do libname=`func_echo_all "$lib" | $SED '\''s%^.*/\([[^/]]*\)\.ixlibrary$%\1%'\''`; $RM /sys/libs/${libname}_ixlibrary.a; $show "cd /sys/libs && $LN_S $lib ${libname}_ixlibrary.a"; cd /sys/libs && $LN_S $lib ${libname}_ixlibrary.a || exit 1; done' ;; esac ;; beos*) library_names_spec='$libname$shared_ext' dynamic_linker="$host_os ld.so" shlibpath_var=LIBRARY_PATH ;; bsdi[[45]]*) version_type=linux # correct to gnu/linux during the next big refactor need_version=no library_names_spec='$libname$release$shared_ext$versuffix $libname$release$shared_ext$major $libname$shared_ext' soname_spec='$libname$release$shared_ext$major' finish_cmds='PATH="\$PATH:/sbin" ldconfig $libdir' shlibpath_var=LD_LIBRARY_PATH sys_lib_search_path_spec="/shlib /usr/lib /usr/X11/lib /usr/contrib/lib /lib /usr/local/lib" sys_lib_dlsearch_path_spec="/shlib /usr/lib /usr/local/lib" # the default ld.so.conf also contains /usr/contrib/lib and # /usr/X11R6/lib (/usr/X11 is a link to /usr/X11R6), but let us allow # libtool to hard-code these into programs ;; cygwin* | mingw* | pw32* | cegcc*) version_type=windows shrext_cmds=.dll need_version=no need_lib_prefix=no case $GCC,$cc_basename in yes,*) # gcc library_names_spec='$libname.dll.a' # DLL is installed to $(libdir)/../bin by postinstall_cmds postinstall_cmds='base_file=`basename \$file`~ dlpath=`$SHELL 2>&1 -c '\''. $dir/'\''\$base_file'\''i; echo \$dlname'\''`~ dldir=$destdir/`dirname \$dlpath`~ test -d \$dldir || mkdir -p \$dldir~ $install_prog $dir/$dlname \$dldir/$dlname~ chmod a+x \$dldir/$dlname~ if test -n '\''$stripme'\'' && test -n '\''$striplib'\''; then eval '\''$striplib \$dldir/$dlname'\'' || exit \$?; fi' postuninstall_cmds='dldll=`$SHELL 2>&1 -c '\''. $file; echo \$dlname'\''`~ dlpath=$dir/\$dldll~ $RM \$dlpath' shlibpath_overrides_runpath=yes case $host_os in cygwin*) # Cygwin DLLs use 'cyg' prefix rather than 'lib' soname_spec='`echo $libname | sed -e 's/^lib/cyg/'``echo $release | $SED -e 's/[[.]]/-/g'`$versuffix$shared_ext' m4_if([$1], [],[ sys_lib_search_path_spec="$sys_lib_search_path_spec /usr/lib/w32api"]) ;; mingw* | cegcc*) # MinGW DLLs use traditional 'lib' prefix soname_spec='$libname`echo $release | $SED -e 's/[[.]]/-/g'`$versuffix$shared_ext' ;; pw32*) # pw32 DLLs use 'pw' prefix rather than 'lib' library_names_spec='`echo $libname | sed -e 's/^lib/pw/'``echo $release | $SED -e 's/[[.]]/-/g'`$versuffix$shared_ext' ;; esac dynamic_linker='Win32 ld.exe' ;; *,cl*) # Native MSVC libname_spec='$name' soname_spec='$libname`echo $release | $SED -e 's/[[.]]/-/g'`$versuffix$shared_ext' library_names_spec='$libname.dll.lib' case $build_os in mingw*) sys_lib_search_path_spec= lt_save_ifs=$IFS IFS=';' for lt_path in $LIB do IFS=$lt_save_ifs # Let DOS variable expansion print the short 8.3 style file name. lt_path=`cd "$lt_path" 2>/dev/null && cmd //C "for %i in (".") do @echo %~si"` sys_lib_search_path_spec="$sys_lib_search_path_spec $lt_path" done IFS=$lt_save_ifs # Convert to MSYS style. sys_lib_search_path_spec=`$ECHO "$sys_lib_search_path_spec" | sed -e 's|\\\\|/|g' -e 's| \\([[a-zA-Z]]\\):| /\\1|g' -e 's|^ ||'` ;; cygwin*) # Convert to unix form, then to dos form, then back to unix form # but this time dos style (no spaces!) so that the unix form looks # like /cygdrive/c/PROGRA~1:/cygdr... sys_lib_search_path_spec=`cygpath --path --unix "$LIB"` sys_lib_search_path_spec=`cygpath --path --dos "$sys_lib_search_path_spec" 2>/dev/null` sys_lib_search_path_spec=`cygpath --path --unix "$sys_lib_search_path_spec" | $SED -e "s/$PATH_SEPARATOR/ /g"` ;; *) sys_lib_search_path_spec=$LIB if $ECHO "$sys_lib_search_path_spec" | [$GREP ';[c-zC-Z]:/' >/dev/null]; then # It is most probably a Windows format PATH. sys_lib_search_path_spec=`$ECHO "$sys_lib_search_path_spec" | $SED -e 's/;/ /g'` else sys_lib_search_path_spec=`$ECHO "$sys_lib_search_path_spec" | $SED -e "s/$PATH_SEPARATOR/ /g"` fi # FIXME: find the short name or the path components, as spaces are # common. (e.g. "Program Files" -> "PROGRA~1") ;; esac # DLL is installed to $(libdir)/../bin by postinstall_cmds postinstall_cmds='base_file=`basename \$file`~ dlpath=`$SHELL 2>&1 -c '\''. $dir/'\''\$base_file'\''i; echo \$dlname'\''`~ dldir=$destdir/`dirname \$dlpath`~ test -d \$dldir || mkdir -p \$dldir~ $install_prog $dir/$dlname \$dldir/$dlname' postuninstall_cmds='dldll=`$SHELL 2>&1 -c '\''. $file; echo \$dlname'\''`~ dlpath=$dir/\$dldll~ $RM \$dlpath' shlibpath_overrides_runpath=yes dynamic_linker='Win32 link.exe' ;; *) # Assume MSVC wrapper library_names_spec='$libname`echo $release | $SED -e 's/[[.]]/-/g'`$versuffix$shared_ext $libname.lib' dynamic_linker='Win32 ld.exe' ;; esac # FIXME: first we should search . and the directory the executable is in shlibpath_var=PATH ;; darwin* | rhapsody*) dynamic_linker="$host_os dyld" version_type=darwin need_lib_prefix=no need_version=no library_names_spec='$libname$release$major$shared_ext $libname$shared_ext' soname_spec='$libname$release$major$shared_ext' shlibpath_overrides_runpath=yes shlibpath_var=DYLD_LIBRARY_PATH shrext_cmds='`test .$module = .yes && echo .so || echo .dylib`' m4_if([$1], [],[ sys_lib_search_path_spec="$sys_lib_search_path_spec /usr/local/lib"]) sys_lib_dlsearch_path_spec='/usr/local/lib /lib /usr/lib' ;; dgux*) version_type=linux # correct to gnu/linux during the next big refactor need_lib_prefix=no need_version=no library_names_spec='$libname$release$shared_ext$versuffix $libname$release$shared_ext$major $libname$shared_ext' soname_spec='$libname$release$shared_ext$major' shlibpath_var=LD_LIBRARY_PATH ;; freebsd* | dragonfly*) # DragonFly does not have aout. When/if they implement a new # versioning mechanism, adjust this. if test -x /usr/bin/objformat; then objformat=`/usr/bin/objformat` else case $host_os in freebsd[[23]].*) objformat=aout ;; *) objformat=elf ;; esac fi version_type=freebsd-$objformat case $version_type in freebsd-elf*) library_names_spec='$libname$release$shared_ext$versuffix $libname$release$shared_ext$major $libname$shared_ext' soname_spec='$libname$release$shared_ext$major' need_version=no need_lib_prefix=no ;; freebsd-*) library_names_spec='$libname$release$shared_ext$versuffix $libname$shared_ext$versuffix' need_version=yes ;; esac shlibpath_var=LD_LIBRARY_PATH case $host_os in freebsd2.*) shlibpath_overrides_runpath=yes ;; freebsd3.[[01]]* | freebsdelf3.[[01]]*) shlibpath_overrides_runpath=yes hardcode_into_libs=yes ;; freebsd3.[[2-9]]* | freebsdelf3.[[2-9]]* | \ freebsd4.[[0-5]] | freebsdelf4.[[0-5]] | freebsd4.1.1 | freebsdelf4.1.1) shlibpath_overrides_runpath=no hardcode_into_libs=yes ;; *) # from 4.6 on, and DragonFly shlibpath_overrides_runpath=yes hardcode_into_libs=yes ;; esac ;; haiku*) version_type=linux # correct to gnu/linux during the next big refactor need_lib_prefix=no need_version=no dynamic_linker="$host_os runtime_loader" library_names_spec='$libname$release$shared_ext$versuffix $libname$release$shared_ext$major $libname$shared_ext' soname_spec='$libname$release$shared_ext$major' shlibpath_var=LIBRARY_PATH shlibpath_overrides_runpath=no sys_lib_dlsearch_path_spec='/boot/home/config/lib /boot/common/lib /boot/system/lib' hardcode_into_libs=yes ;; hpux9* | hpux10* | hpux11*) # Give a soname corresponding to the major version so that dld.sl refuses to # link against other versions. version_type=sunos need_lib_prefix=no need_version=no case $host_cpu in ia64*) shrext_cmds='.so' hardcode_into_libs=yes dynamic_linker="$host_os dld.so" shlibpath_var=LD_LIBRARY_PATH shlibpath_overrides_runpath=yes # Unless +noenvvar is specified. library_names_spec='$libname$release$shared_ext$versuffix $libname$release$shared_ext$major $libname$shared_ext' soname_spec='$libname$release$shared_ext$major' if test 32 = "$HPUX_IA64_MODE"; then sys_lib_search_path_spec="/usr/lib/hpux32 /usr/local/lib/hpux32 /usr/local/lib" sys_lib_dlsearch_path_spec=/usr/lib/hpux32 else sys_lib_search_path_spec="/usr/lib/hpux64 /usr/local/lib/hpux64" sys_lib_dlsearch_path_spec=/usr/lib/hpux64 fi ;; hppa*64*) shrext_cmds='.sl' hardcode_into_libs=yes dynamic_linker="$host_os dld.sl" shlibpath_var=LD_LIBRARY_PATH # How should we handle SHLIB_PATH shlibpath_overrides_runpath=yes # Unless +noenvvar is specified. library_names_spec='$libname$release$shared_ext$versuffix $libname$release$shared_ext$major $libname$shared_ext' soname_spec='$libname$release$shared_ext$major' sys_lib_search_path_spec="/usr/lib/pa20_64 /usr/ccs/lib/pa20_64" sys_lib_dlsearch_path_spec=$sys_lib_search_path_spec ;; *) shrext_cmds='.sl' dynamic_linker="$host_os dld.sl" shlibpath_var=SHLIB_PATH shlibpath_overrides_runpath=no # +s is required to enable SHLIB_PATH library_names_spec='$libname$release$shared_ext$versuffix $libname$release$shared_ext$major $libname$shared_ext' soname_spec='$libname$release$shared_ext$major' ;; esac # HP-UX runs *really* slowly unless shared libraries are mode 555, ... postinstall_cmds='chmod 555 $lib' # or fails outright, so override atomically: install_override_mode=555 ;; interix[[3-9]]*) version_type=linux # correct to gnu/linux during the next big refactor need_lib_prefix=no need_version=no library_names_spec='$libname$release$shared_ext$versuffix $libname$release$shared_ext$major $libname$shared_ext' soname_spec='$libname$release$shared_ext$major' dynamic_linker='Interix 3.x ld.so.1 (PE, like ELF)' shlibpath_var=LD_LIBRARY_PATH shlibpath_overrides_runpath=no hardcode_into_libs=yes ;; irix5* | irix6* | nonstopux*) case $host_os in nonstopux*) version_type=nonstopux ;; *) if test yes = "$lt_cv_prog_gnu_ld"; then version_type=linux # correct to gnu/linux during the next big refactor else version_type=irix fi ;; esac need_lib_prefix=no need_version=no soname_spec='$libname$release$shared_ext$major' library_names_spec='$libname$release$shared_ext$versuffix $libname$release$shared_ext$major $libname$release$shared_ext $libname$shared_ext' case $host_os in irix5* | nonstopux*) libsuff= shlibsuff= ;; *) case $LD in # libtool.m4 will add one of these switches to LD *-32|*"-32 "|*-melf32bsmip|*"-melf32bsmip ") libsuff= shlibsuff= libmagic=32-bit;; *-n32|*"-n32 "|*-melf32bmipn32|*"-melf32bmipn32 ") libsuff=32 shlibsuff=N32 libmagic=N32;; *-64|*"-64 "|*-melf64bmip|*"-melf64bmip ") libsuff=64 shlibsuff=64 libmagic=64-bit;; *) libsuff= shlibsuff= libmagic=never-match;; esac ;; esac shlibpath_var=LD_LIBRARY${shlibsuff}_PATH shlibpath_overrides_runpath=no sys_lib_search_path_spec="/usr/lib$libsuff /lib$libsuff /usr/local/lib$libsuff" sys_lib_dlsearch_path_spec="/usr/lib$libsuff /lib$libsuff" hardcode_into_libs=yes ;; # No shared lib support for Linux oldld, aout, or coff. linux*oldld* | linux*aout* | linux*coff*) dynamic_linker=no ;; linux*android*) version_type=none # Android doesn't support versioned libraries. need_lib_prefix=no need_version=no library_names_spec='$libname$release$shared_ext' soname_spec='$libname$release$shared_ext' finish_cmds= shlibpath_var=LD_LIBRARY_PATH shlibpath_overrides_runpath=yes # This implies no fast_install, which is unacceptable. # Some rework will be needed to allow for fast_install # before this can be enabled. hardcode_into_libs=yes dynamic_linker='Android linker' # Don't embed -rpath directories since the linker doesn't support them. _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='-L$libdir' ;; # This must be glibc/ELF. linux* | k*bsd*-gnu | kopensolaris*-gnu | gnu*) version_type=linux # correct to gnu/linux during the next big refactor need_lib_prefix=no need_version=no library_names_spec='$libname$release$shared_ext$versuffix $libname$release$shared_ext$major $libname$shared_ext' soname_spec='$libname$release$shared_ext$major' finish_cmds='PATH="\$PATH:/sbin" ldconfig -n $libdir' shlibpath_var=LD_LIBRARY_PATH shlibpath_overrides_runpath=no # Some binutils ld are patched to set DT_RUNPATH AC_CACHE_VAL([lt_cv_shlibpath_overrides_runpath], [lt_cv_shlibpath_overrides_runpath=no save_LDFLAGS=$LDFLAGS save_libdir=$libdir eval "libdir=/foo; wl=\"$_LT_TAGVAR(lt_prog_compiler_wl, $1)\"; \ LDFLAGS=\"\$LDFLAGS $_LT_TAGVAR(hardcode_libdir_flag_spec, $1)\"" AC_LINK_IFELSE([AC_LANG_PROGRAM([],[])], [AS_IF([ ($OBJDUMP -p conftest$ac_exeext) 2>/dev/null | grep "RUNPATH.*$libdir" >/dev/null], [lt_cv_shlibpath_overrides_runpath=yes])]) LDFLAGS=$save_LDFLAGS libdir=$save_libdir ]) shlibpath_overrides_runpath=$lt_cv_shlibpath_overrides_runpath # This implies no fast_install, which is unacceptable. # Some rework will be needed to allow for fast_install # before this can be enabled. hardcode_into_libs=yes # Ideally, we could use ldconfig to report *all* directores which are # searched for libraries, however this is still not possible. Aside from not # being certain /sbin/ldconfig is available, command # 'ldconfig -N -X -v | grep ^/' on 64bit Fedora does not report /usr/lib64, # even though it is searched at run-time. Try to do the best guess by # appending ld.so.conf contents (and includes) to the search path. if test -f /etc/ld.so.conf; then lt_ld_extra=`awk '/^include / { system(sprintf("cd /etc; cat %s 2>/dev/null", \[$]2)); skip = 1; } { if (!skip) print \[$]0; skip = 0; }' < /etc/ld.so.conf | $SED -e 's/#.*//;/^[ ]*hwcap[ ]/d;s/[:, ]/ /g;s/=[^=]*$//;s/=[^= ]* / /g;s/"//g;/^$/d' | tr '\n' ' '` sys_lib_dlsearch_path_spec="/lib /usr/lib $lt_ld_extra" fi # We used to test for /lib/ld.so.1 and disable shared libraries on # powerpc, because MkLinux only supported shared libraries with the # GNU dynamic linker. Since this was broken with cross compilers, # most powerpc-linux boxes support dynamic linking these days and # people can always --disable-shared, the test was removed, and we # assume the GNU/Linux dynamic linker is in use. dynamic_linker='GNU/Linux ld.so' ;; netbsd*) version_type=sunos need_lib_prefix=no need_version=no if echo __ELF__ | $CC -E - | $GREP __ELF__ >/dev/null; then library_names_spec='$libname$release$shared_ext$versuffix $libname$shared_ext$versuffix' finish_cmds='PATH="\$PATH:/sbin" ldconfig -m $libdir' dynamic_linker='NetBSD (a.out) ld.so' else library_names_spec='$libname$release$shared_ext$versuffix $libname$release$shared_ext$major $libname$shared_ext' soname_spec='$libname$release$shared_ext$major' dynamic_linker='NetBSD ld.elf_so' fi shlibpath_var=LD_LIBRARY_PATH shlibpath_overrides_runpath=yes hardcode_into_libs=yes ;; newsos6) version_type=linux # correct to gnu/linux during the next big refactor library_names_spec='$libname$release$shared_ext$versuffix $libname$release$shared_ext$major $libname$shared_ext' shlibpath_var=LD_LIBRARY_PATH shlibpath_overrides_runpath=yes ;; *nto* | *qnx*) version_type=qnx need_lib_prefix=no need_version=no library_names_spec='$libname$release$shared_ext$versuffix $libname$release$shared_ext$major $libname$shared_ext' soname_spec='$libname$release$shared_ext$major' shlibpath_var=LD_LIBRARY_PATH shlibpath_overrides_runpath=no hardcode_into_libs=yes dynamic_linker='ldqnx.so' ;; openbsd* | bitrig*) version_type=sunos sys_lib_dlsearch_path_spec=/usr/lib need_lib_prefix=no if test -z "`echo __ELF__ | $CC -E - | $GREP __ELF__`"; then need_version=no else need_version=yes fi library_names_spec='$libname$release$shared_ext$versuffix $libname$shared_ext$versuffix' finish_cmds='PATH="\$PATH:/sbin" ldconfig -m $libdir' shlibpath_var=LD_LIBRARY_PATH shlibpath_overrides_runpath=yes ;; os2*) libname_spec='$name' version_type=windows shrext_cmds=.dll need_version=no need_lib_prefix=no # OS/2 can only load a DLL with a base name of 8 characters or less. soname_spec='`test -n "$os2dllname" && libname="$os2dllname"; v=$($ECHO $release$versuffix | tr -d .-); n=$($ECHO $libname | cut -b -$((8 - ${#v})) | tr . _); $ECHO $n$v`$shared_ext' library_names_spec='${libname}_dll.$libext' dynamic_linker='OS/2 ld.exe' shlibpath_var=BEGINLIBPATH sys_lib_search_path_spec="/lib /usr/lib /usr/local/lib" sys_lib_dlsearch_path_spec=$sys_lib_search_path_spec postinstall_cmds='base_file=`basename \$file`~ dlpath=`$SHELL 2>&1 -c '\''. $dir/'\''\$base_file'\''i; $ECHO \$dlname'\''`~ dldir=$destdir/`dirname \$dlpath`~ test -d \$dldir || mkdir -p \$dldir~ $install_prog $dir/$dlname \$dldir/$dlname~ chmod a+x \$dldir/$dlname~ if test -n '\''$stripme'\'' && test -n '\''$striplib'\''; then eval '\''$striplib \$dldir/$dlname'\'' || exit \$?; fi' postuninstall_cmds='dldll=`$SHELL 2>&1 -c '\''. $file; $ECHO \$dlname'\''`~ dlpath=$dir/\$dldll~ $RM \$dlpath' ;; osf3* | osf4* | osf5*) version_type=osf need_lib_prefix=no need_version=no soname_spec='$libname$release$shared_ext$major' library_names_spec='$libname$release$shared_ext$versuffix $libname$release$shared_ext$major $libname$shared_ext' shlibpath_var=LD_LIBRARY_PATH sys_lib_search_path_spec="/usr/shlib /usr/ccs/lib /usr/lib/cmplrs/cc /usr/lib /usr/local/lib /var/shlib" sys_lib_dlsearch_path_spec=$sys_lib_search_path_spec ;; rdos*) dynamic_linker=no ;; solaris*) version_type=linux # correct to gnu/linux during the next big refactor need_lib_prefix=no need_version=no library_names_spec='$libname$release$shared_ext$versuffix $libname$release$shared_ext$major $libname$shared_ext' soname_spec='$libname$release$shared_ext$major' shlibpath_var=LD_LIBRARY_PATH shlibpath_overrides_runpath=yes hardcode_into_libs=yes # ldd complains unless libraries are executable postinstall_cmds='chmod +x $lib' ;; sunos4*) version_type=sunos library_names_spec='$libname$release$shared_ext$versuffix $libname$shared_ext$versuffix' finish_cmds='PATH="\$PATH:/usr/etc" ldconfig $libdir' shlibpath_var=LD_LIBRARY_PATH shlibpath_overrides_runpath=yes if test yes = "$with_gnu_ld"; then need_lib_prefix=no fi need_version=yes ;; sysv4 | sysv4.3*) version_type=linux # correct to gnu/linux during the next big refactor library_names_spec='$libname$release$shared_ext$versuffix $libname$release$shared_ext$major $libname$shared_ext' soname_spec='$libname$release$shared_ext$major' shlibpath_var=LD_LIBRARY_PATH case $host_vendor in sni) shlibpath_overrides_runpath=no need_lib_prefix=no runpath_var=LD_RUN_PATH ;; siemens) need_lib_prefix=no ;; motorola) need_lib_prefix=no need_version=no shlibpath_overrides_runpath=no sys_lib_search_path_spec='/lib /usr/lib /usr/ccs/lib' ;; esac ;; sysv4*MP*) if test -d /usr/nec; then version_type=linux # correct to gnu/linux during the next big refactor library_names_spec='$libname$shared_ext.$versuffix $libname$shared_ext.$major $libname$shared_ext' soname_spec='$libname$shared_ext.$major' shlibpath_var=LD_LIBRARY_PATH fi ;; sysv5* | sco3.2v5* | sco5v6* | unixware* | OpenUNIX* | sysv4*uw2*) version_type=sco need_lib_prefix=no need_version=no library_names_spec='$libname$release$shared_ext$versuffix $libname$release$shared_ext $libname$shared_ext' soname_spec='$libname$release$shared_ext$major' shlibpath_var=LD_LIBRARY_PATH shlibpath_overrides_runpath=yes hardcode_into_libs=yes if test yes = "$with_gnu_ld"; then sys_lib_search_path_spec='/usr/local/lib /usr/gnu/lib /usr/ccs/lib /usr/lib /lib' else sys_lib_search_path_spec='/usr/ccs/lib /usr/lib' case $host_os in sco3.2v5*) sys_lib_search_path_spec="$sys_lib_search_path_spec /lib" ;; esac fi sys_lib_dlsearch_path_spec='/usr/lib' ;; tpf*) # TPF is a cross-target only. Preferred cross-host = GNU/Linux. version_type=linux # correct to gnu/linux during the next big refactor need_lib_prefix=no need_version=no library_names_spec='$libname$release$shared_ext$versuffix $libname$release$shared_ext$major $libname$shared_ext' shlibpath_var=LD_LIBRARY_PATH shlibpath_overrides_runpath=no hardcode_into_libs=yes ;; uts4*) version_type=linux # correct to gnu/linux during the next big refactor library_names_spec='$libname$release$shared_ext$versuffix $libname$release$shared_ext$major $libname$shared_ext' soname_spec='$libname$release$shared_ext$major' shlibpath_var=LD_LIBRARY_PATH ;; *) dynamic_linker=no ;; esac AC_MSG_RESULT([$dynamic_linker]) test no = "$dynamic_linker" && can_build_shared=no variables_saved_for_relink="PATH $shlibpath_var $runpath_var" if test yes = "$GCC"; then variables_saved_for_relink="$variables_saved_for_relink GCC_EXEC_PREFIX COMPILER_PATH LIBRARY_PATH" fi if test set = "${lt_cv_sys_lib_search_path_spec+set}"; then sys_lib_search_path_spec=$lt_cv_sys_lib_search_path_spec fi if test set = "${lt_cv_sys_lib_dlsearch_path_spec+set}"; then sys_lib_dlsearch_path_spec=$lt_cv_sys_lib_dlsearch_path_spec fi # remember unaugmented sys_lib_dlsearch_path content for libtool script decls... configure_time_dlsearch_path=$sys_lib_dlsearch_path_spec # ... but it needs LT_SYS_LIBRARY_PATH munging for other configure-time code func_munge_path_list sys_lib_dlsearch_path_spec "$LT_SYS_LIBRARY_PATH" # to be used as default LT_SYS_LIBRARY_PATH value in generated libtool configure_time_lt_sys_library_path=$LT_SYS_LIBRARY_PATH _LT_DECL([], [variables_saved_for_relink], [1], [Variables whose values should be saved in libtool wrapper scripts and restored at link time]) _LT_DECL([], [need_lib_prefix], [0], [Do we need the "lib" prefix for modules?]) _LT_DECL([], [need_version], [0], [Do we need a version for libraries?]) _LT_DECL([], [version_type], [0], [Library versioning type]) _LT_DECL([], [runpath_var], [0], [Shared library runtime path variable]) _LT_DECL([], [shlibpath_var], [0],[Shared library path variable]) _LT_DECL([], [shlibpath_overrides_runpath], [0], [Is shlibpath searched before the hard-coded library search path?]) _LT_DECL([], [libname_spec], [1], [Format of library name prefix]) _LT_DECL([], [library_names_spec], [1], [[List of archive names. First name is the real one, the rest are links. The last name is the one that the linker finds with -lNAME]]) _LT_DECL([], [soname_spec], [1], [[The coded name of the library, if different from the real name]]) _LT_DECL([], [install_override_mode], [1], [Permission mode override for installation of shared libraries]) _LT_DECL([], [postinstall_cmds], [2], [Command to use after installation of a shared archive]) _LT_DECL([], [postuninstall_cmds], [2], [Command to use after uninstallation of a shared archive]) _LT_DECL([], [finish_cmds], [2], [Commands used to finish a libtool library installation in a directory]) _LT_DECL([], [finish_eval], [1], [[As "finish_cmds", except a single script fragment to be evaled but not shown]]) _LT_DECL([], [hardcode_into_libs], [0], [Whether we should hardcode library paths into libraries]) _LT_DECL([], [sys_lib_search_path_spec], [2], [Compile-time system search path for libraries]) _LT_DECL([sys_lib_dlsearch_path_spec], [configure_time_dlsearch_path], [2], [Detected run-time system search path for libraries]) _LT_DECL([], [configure_time_lt_sys_library_path], [2], [Explicit LT_SYS_LIBRARY_PATH set during ./configure time]) ])# _LT_SYS_DYNAMIC_LINKER # _LT_PATH_TOOL_PREFIX(TOOL) # -------------------------- # find a file program that can recognize shared library AC_DEFUN([_LT_PATH_TOOL_PREFIX], [m4_require([_LT_DECL_EGREP])dnl AC_MSG_CHECKING([for $1]) AC_CACHE_VAL(lt_cv_path_MAGIC_CMD, [case $MAGIC_CMD in [[\\/*] | ?:[\\/]*]) lt_cv_path_MAGIC_CMD=$MAGIC_CMD # Let the user override the test with a path. ;; *) lt_save_MAGIC_CMD=$MAGIC_CMD lt_save_ifs=$IFS; IFS=$PATH_SEPARATOR dnl $ac_dummy forces splitting on constant user-supplied paths. dnl POSIX.2 word splitting is done only on the output of word expansions, dnl not every word. This closes a longstanding sh security hole. ac_dummy="m4_if([$2], , $PATH, [$2])" for ac_dir in $ac_dummy; do IFS=$lt_save_ifs test -z "$ac_dir" && ac_dir=. if test -f "$ac_dir/$1"; then lt_cv_path_MAGIC_CMD=$ac_dir/"$1" if test -n "$file_magic_test_file"; then case $deplibs_check_method in "file_magic "*) file_magic_regex=`expr "$deplibs_check_method" : "file_magic \(.*\)"` MAGIC_CMD=$lt_cv_path_MAGIC_CMD if eval $file_magic_cmd \$file_magic_test_file 2> /dev/null | $EGREP "$file_magic_regex" > /dev/null; then : else cat <<_LT_EOF 1>&2 *** Warning: the command libtool uses to detect shared libraries, *** $file_magic_cmd, produces output that libtool cannot recognize. *** The result is that libtool may fail to recognize shared libraries *** as such. This will affect the creation of libtool libraries that *** depend on shared libraries, but programs linked with such libtool *** libraries will work regardless of this problem. Nevertheless, you *** may want to report the problem to your system manager and/or to *** bug-libtool@gnu.org _LT_EOF fi ;; esac fi break fi done IFS=$lt_save_ifs MAGIC_CMD=$lt_save_MAGIC_CMD ;; esac]) MAGIC_CMD=$lt_cv_path_MAGIC_CMD if test -n "$MAGIC_CMD"; then AC_MSG_RESULT($MAGIC_CMD) else AC_MSG_RESULT(no) fi _LT_DECL([], [MAGIC_CMD], [0], [Used to examine libraries when file_magic_cmd begins with "file"])dnl ])# _LT_PATH_TOOL_PREFIX # Old name: AU_ALIAS([AC_PATH_TOOL_PREFIX], [_LT_PATH_TOOL_PREFIX]) dnl aclocal-1.4 backwards compatibility: dnl AC_DEFUN([AC_PATH_TOOL_PREFIX], []) # _LT_PATH_MAGIC # -------------- # find a file program that can recognize a shared library m4_defun([_LT_PATH_MAGIC], [_LT_PATH_TOOL_PREFIX(${ac_tool_prefix}file, /usr/bin$PATH_SEPARATOR$PATH) if test -z "$lt_cv_path_MAGIC_CMD"; then if test -n "$ac_tool_prefix"; then _LT_PATH_TOOL_PREFIX(file, /usr/bin$PATH_SEPARATOR$PATH) else MAGIC_CMD=: fi fi ])# _LT_PATH_MAGIC # LT_PATH_LD # ---------- # find the pathname to the GNU or non-GNU linker AC_DEFUN([LT_PATH_LD], [AC_REQUIRE([AC_PROG_CC])dnl AC_REQUIRE([AC_CANONICAL_HOST])dnl AC_REQUIRE([AC_CANONICAL_BUILD])dnl m4_require([_LT_DECL_SED])dnl m4_require([_LT_DECL_EGREP])dnl m4_require([_LT_PROG_ECHO_BACKSLASH])dnl AC_ARG_WITH([gnu-ld], [AS_HELP_STRING([--with-gnu-ld], [assume the C compiler uses GNU ld @<:@default=no@:>@])], [test no = "$withval" || with_gnu_ld=yes], [with_gnu_ld=no])dnl ac_prog=ld if test yes = "$GCC"; then # Check if gcc -print-prog-name=ld gives a path. AC_MSG_CHECKING([for ld used by $CC]) case $host in *-*-mingw*) # gcc leaves a trailing carriage return, which upsets mingw ac_prog=`($CC -print-prog-name=ld) 2>&5 | tr -d '\015'` ;; *) ac_prog=`($CC -print-prog-name=ld) 2>&5` ;; esac case $ac_prog in # Accept absolute paths. [[\\/]]* | ?:[[\\/]]*) re_direlt='/[[^/]][[^/]]*/\.\./' # Canonicalize the pathname of ld ac_prog=`$ECHO "$ac_prog"| $SED 's%\\\\%/%g'` while $ECHO "$ac_prog" | $GREP "$re_direlt" > /dev/null 2>&1; do ac_prog=`$ECHO $ac_prog| $SED "s%$re_direlt%/%"` done test -z "$LD" && LD=$ac_prog ;; "") # If it fails, then pretend we aren't using GCC. ac_prog=ld ;; *) # If it is relative, then search for the first ld in PATH. with_gnu_ld=unknown ;; esac elif test yes = "$with_gnu_ld"; then AC_MSG_CHECKING([for GNU ld]) else AC_MSG_CHECKING([for non-GNU ld]) fi AC_CACHE_VAL(lt_cv_path_LD, [if test -z "$LD"; then lt_save_ifs=$IFS; IFS=$PATH_SEPARATOR for ac_dir in $PATH; do IFS=$lt_save_ifs test -z "$ac_dir" && ac_dir=. if test -f "$ac_dir/$ac_prog" || test -f "$ac_dir/$ac_prog$ac_exeext"; then lt_cv_path_LD=$ac_dir/$ac_prog # Check to see if the program is GNU ld. I'd rather use --version, # but apparently some variants of GNU ld only accept -v. # Break only if it was the GNU/non-GNU ld that we prefer. case `"$lt_cv_path_LD" -v 2>&1 &1 conftest.i cat conftest.i conftest.i >conftest2.i : ${lt_DD:=$DD} AC_PATH_PROGS_FEATURE_CHECK([lt_DD], [dd], [if "$ac_path_lt_DD" bs=32 count=1 conftest.out 2>/dev/null; then cmp -s conftest.i conftest.out \ && ac_cv_path_lt_DD="$ac_path_lt_DD" ac_path_lt_DD_found=: fi]) rm -f conftest.i conftest2.i conftest.out]) ])# _LT_PATH_DD # _LT_CMD_TRUNCATE # ---------------- # find command to truncate a binary pipe m4_defun([_LT_CMD_TRUNCATE], [m4_require([_LT_PATH_DD]) AC_CACHE_CHECK([how to truncate binary pipes], [lt_cv_truncate_bin], [printf 0123456789abcdef0123456789abcdef >conftest.i cat conftest.i conftest.i >conftest2.i lt_cv_truncate_bin= if "$ac_cv_path_lt_DD" bs=32 count=1 conftest.out 2>/dev/null; then cmp -s conftest.i conftest.out \ && lt_cv_truncate_bin="$ac_cv_path_lt_DD bs=4096 count=1" fi rm -f conftest.i conftest2.i conftest.out test -z "$lt_cv_truncate_bin" && lt_cv_truncate_bin="$SED -e 4q"]) _LT_DECL([lt_truncate_bin], [lt_cv_truncate_bin], [1], [Command to truncate a binary pipe]) ])# _LT_CMD_TRUNCATE # _LT_CHECK_MAGIC_METHOD # ---------------------- # how to check for library dependencies # -- PORTME fill in with the dynamic library characteristics m4_defun([_LT_CHECK_MAGIC_METHOD], [m4_require([_LT_DECL_EGREP]) m4_require([_LT_DECL_OBJDUMP]) AC_CACHE_CHECK([how to recognize dependent libraries], lt_cv_deplibs_check_method, [lt_cv_file_magic_cmd='$MAGIC_CMD' lt_cv_file_magic_test_file= lt_cv_deplibs_check_method='unknown' # Need to set the preceding variable on all platforms that support # interlibrary dependencies. # 'none' -- dependencies not supported. # 'unknown' -- same as none, but documents that we really don't know. # 'pass_all' -- all dependencies passed with no checks. # 'test_compile' -- check by making test program. # 'file_magic [[regex]]' -- check by looking for files in library path # that responds to the $file_magic_cmd with a given extended regex. # If you have 'file' or equivalent on your system and you're not sure # whether 'pass_all' will *always* work, you probably want this one. case $host_os in aix[[4-9]]*) lt_cv_deplibs_check_method=pass_all ;; beos*) lt_cv_deplibs_check_method=pass_all ;; bsdi[[45]]*) lt_cv_deplibs_check_method='file_magic ELF [[0-9]][[0-9]]*-bit [[ML]]SB (shared object|dynamic lib)' lt_cv_file_magic_cmd='/usr/bin/file -L' lt_cv_file_magic_test_file=/shlib/libc.so ;; cygwin*) # func_win32_libid is a shell function defined in ltmain.sh lt_cv_deplibs_check_method='file_magic ^x86 archive import|^x86 DLL' lt_cv_file_magic_cmd='func_win32_libid' ;; mingw* | pw32*) # Base MSYS/MinGW do not provide the 'file' command needed by # func_win32_libid shell function, so use a weaker test based on 'objdump', # unless we find 'file', for example because we are cross-compiling. if ( file / ) >/dev/null 2>&1; then lt_cv_deplibs_check_method='file_magic ^x86 archive import|^x86 DLL' lt_cv_file_magic_cmd='func_win32_libid' else # Keep this pattern in sync with the one in func_win32_libid. lt_cv_deplibs_check_method='file_magic file format (pei*-i386(.*architecture: i386)?|pe-arm-wince|pe-x86-64)' lt_cv_file_magic_cmd='$OBJDUMP -f' fi ;; cegcc*) # use the weaker test based on 'objdump'. See mingw*. lt_cv_deplibs_check_method='file_magic file format pe-arm-.*little(.*architecture: arm)?' lt_cv_file_magic_cmd='$OBJDUMP -f' ;; darwin* | rhapsody*) lt_cv_deplibs_check_method=pass_all ;; freebsd* | dragonfly*) if echo __ELF__ | $CC -E - | $GREP __ELF__ > /dev/null; then case $host_cpu in i*86 ) # Not sure whether the presence of OpenBSD here was a mistake. # Let's accept both of them until this is cleared up. lt_cv_deplibs_check_method='file_magic (FreeBSD|OpenBSD|DragonFly)/i[[3-9]]86 (compact )?demand paged shared library' lt_cv_file_magic_cmd=/usr/bin/file lt_cv_file_magic_test_file=`echo /usr/lib/libc.so.*` ;; esac else lt_cv_deplibs_check_method=pass_all fi ;; haiku*) lt_cv_deplibs_check_method=pass_all ;; hpux10.20* | hpux11*) lt_cv_file_magic_cmd=/usr/bin/file case $host_cpu in ia64*) lt_cv_deplibs_check_method='file_magic (s[[0-9]][[0-9]][[0-9]]|ELF-[[0-9]][[0-9]]) shared object file - IA64' lt_cv_file_magic_test_file=/usr/lib/hpux32/libc.so ;; hppa*64*) [lt_cv_deplibs_check_method='file_magic (s[0-9][0-9][0-9]|ELF[ -][0-9][0-9])(-bit)?( [LM]SB)? shared object( file)?[, -]* PA-RISC [0-9]\.[0-9]'] lt_cv_file_magic_test_file=/usr/lib/pa20_64/libc.sl ;; *) lt_cv_deplibs_check_method='file_magic (s[[0-9]][[0-9]][[0-9]]|PA-RISC[[0-9]]\.[[0-9]]) shared library' lt_cv_file_magic_test_file=/usr/lib/libc.sl ;; esac ;; interix[[3-9]]*) # PIC code is broken on Interix 3.x, that's why |\.a not |_pic\.a here lt_cv_deplibs_check_method='match_pattern /lib[[^/]]+(\.so|\.a)$' ;; irix5* | irix6* | nonstopux*) case $LD in *-32|*"-32 ") libmagic=32-bit;; *-n32|*"-n32 ") libmagic=N32;; *-64|*"-64 ") libmagic=64-bit;; *) libmagic=never-match;; esac lt_cv_deplibs_check_method=pass_all ;; # This must be glibc/ELF. linux* | k*bsd*-gnu | kopensolaris*-gnu | gnu*) lt_cv_deplibs_check_method=pass_all ;; netbsd*) if echo __ELF__ | $CC -E - | $GREP __ELF__ > /dev/null; then lt_cv_deplibs_check_method='match_pattern /lib[[^/]]+(\.so\.[[0-9]]+\.[[0-9]]+|_pic\.a)$' else lt_cv_deplibs_check_method='match_pattern /lib[[^/]]+(\.so|_pic\.a)$' fi ;; newos6*) lt_cv_deplibs_check_method='file_magic ELF [[0-9]][[0-9]]*-bit [[ML]]SB (executable|dynamic lib)' lt_cv_file_magic_cmd=/usr/bin/file lt_cv_file_magic_test_file=/usr/lib/libnls.so ;; *nto* | *qnx*) lt_cv_deplibs_check_method=pass_all ;; openbsd* | bitrig*) if test -z "`echo __ELF__ | $CC -E - | $GREP __ELF__`"; then lt_cv_deplibs_check_method='match_pattern /lib[[^/]]+(\.so\.[[0-9]]+\.[[0-9]]+|\.so|_pic\.a)$' else lt_cv_deplibs_check_method='match_pattern /lib[[^/]]+(\.so\.[[0-9]]+\.[[0-9]]+|_pic\.a)$' fi ;; osf3* | osf4* | osf5*) lt_cv_deplibs_check_method=pass_all ;; rdos*) lt_cv_deplibs_check_method=pass_all ;; solaris*) lt_cv_deplibs_check_method=pass_all ;; sysv5* | sco3.2v5* | sco5v6* | unixware* | OpenUNIX* | sysv4*uw2*) lt_cv_deplibs_check_method=pass_all ;; sysv4 | sysv4.3*) case $host_vendor in motorola) lt_cv_deplibs_check_method='file_magic ELF [[0-9]][[0-9]]*-bit [[ML]]SB (shared object|dynamic lib) M[[0-9]][[0-9]]* Version [[0-9]]' lt_cv_file_magic_test_file=`echo /usr/lib/libc.so*` ;; ncr) lt_cv_deplibs_check_method=pass_all ;; sequent) lt_cv_file_magic_cmd='/bin/file' lt_cv_deplibs_check_method='file_magic ELF [[0-9]][[0-9]]*-bit [[LM]]SB (shared object|dynamic lib )' ;; sni) lt_cv_file_magic_cmd='/bin/file' lt_cv_deplibs_check_method="file_magic ELF [[0-9]][[0-9]]*-bit [[LM]]SB dynamic lib" lt_cv_file_magic_test_file=/lib/libc.so ;; siemens) lt_cv_deplibs_check_method=pass_all ;; pc) lt_cv_deplibs_check_method=pass_all ;; esac ;; tpf*) lt_cv_deplibs_check_method=pass_all ;; os2*) lt_cv_deplibs_check_method=pass_all ;; esac ]) file_magic_glob= want_nocaseglob=no if test "$build" = "$host"; then case $host_os in mingw* | pw32*) if ( shopt | grep nocaseglob ) >/dev/null 2>&1; then want_nocaseglob=yes else file_magic_glob=`echo aAbBcCdDeEfFgGhHiIjJkKlLmMnNoOpPqQrRsStTuUvVwWxXyYzZ | $SED -e "s/\(..\)/s\/[[\1]]\/[[\1]]\/g;/g"` fi ;; esac fi file_magic_cmd=$lt_cv_file_magic_cmd deplibs_check_method=$lt_cv_deplibs_check_method test -z "$deplibs_check_method" && deplibs_check_method=unknown _LT_DECL([], [deplibs_check_method], [1], [Method to check whether dependent libraries are shared objects]) _LT_DECL([], [file_magic_cmd], [1], [Command to use when deplibs_check_method = "file_magic"]) _LT_DECL([], [file_magic_glob], [1], [How to find potential files when deplibs_check_method = "file_magic"]) _LT_DECL([], [want_nocaseglob], [1], [Find potential files using nocaseglob when deplibs_check_method = "file_magic"]) ])# _LT_CHECK_MAGIC_METHOD # LT_PATH_NM # ---------- # find the pathname to a BSD- or MS-compatible name lister AC_DEFUN([LT_PATH_NM], [AC_REQUIRE([AC_PROG_CC])dnl AC_CACHE_CHECK([for BSD- or MS-compatible name lister (nm)], lt_cv_path_NM, [if test -n "$NM"; then # Let the user override the test. lt_cv_path_NM=$NM else lt_nm_to_check=${ac_tool_prefix}nm if test -n "$ac_tool_prefix" && test "$build" = "$host"; then lt_nm_to_check="$lt_nm_to_check nm" fi for lt_tmp_nm in $lt_nm_to_check; do lt_save_ifs=$IFS; IFS=$PATH_SEPARATOR for ac_dir in $PATH /usr/ccs/bin/elf /usr/ccs/bin /usr/ucb /bin; do IFS=$lt_save_ifs test -z "$ac_dir" && ac_dir=. tmp_nm=$ac_dir/$lt_tmp_nm if test -f "$tmp_nm" || test -f "$tmp_nm$ac_exeext"; then # Check to see if the nm accepts a BSD-compat flag. # Adding the 'sed 1q' prevents false positives on HP-UX, which says: # nm: unknown option "B" ignored # Tru64's nm complains that /dev/null is an invalid object file # MSYS converts /dev/null to NUL, MinGW nm treats NUL as empty case $build_os in mingw*) lt_bad_file=conftest.nm/nofile ;; *) lt_bad_file=/dev/null ;; esac case `"$tmp_nm" -B $lt_bad_file 2>&1 | sed '1q'` in *$lt_bad_file* | *'Invalid file or object type'*) lt_cv_path_NM="$tmp_nm -B" break 2 ;; *) case `"$tmp_nm" -p /dev/null 2>&1 | sed '1q'` in */dev/null*) lt_cv_path_NM="$tmp_nm -p" break 2 ;; *) lt_cv_path_NM=${lt_cv_path_NM="$tmp_nm"} # keep the first match, but continue # so that we can try to find one that supports BSD flags ;; esac ;; esac fi done IFS=$lt_save_ifs done : ${lt_cv_path_NM=no} fi]) if test no != "$lt_cv_path_NM"; then NM=$lt_cv_path_NM else # Didn't find any BSD compatible name lister, look for dumpbin. if test -n "$DUMPBIN"; then : # Let the user override the test. else AC_CHECK_TOOLS(DUMPBIN, [dumpbin "link -dump"], :) case `$DUMPBIN -symbols -headers /dev/null 2>&1 | sed '1q'` in *COFF*) DUMPBIN="$DUMPBIN -symbols -headers" ;; *) DUMPBIN=: ;; esac fi AC_SUBST([DUMPBIN]) if test : != "$DUMPBIN"; then NM=$DUMPBIN fi fi test -z "$NM" && NM=nm AC_SUBST([NM]) _LT_DECL([], [NM], [1], [A BSD- or MS-compatible name lister])dnl AC_CACHE_CHECK([the name lister ($NM) interface], [lt_cv_nm_interface], [lt_cv_nm_interface="BSD nm" echo "int some_variable = 0;" > conftest.$ac_ext (eval echo "\"\$as_me:$LINENO: $ac_compile\"" >&AS_MESSAGE_LOG_FD) (eval "$ac_compile" 2>conftest.err) cat conftest.err >&AS_MESSAGE_LOG_FD (eval echo "\"\$as_me:$LINENO: $NM \\\"conftest.$ac_objext\\\"\"" >&AS_MESSAGE_LOG_FD) (eval "$NM \"conftest.$ac_objext\"" 2>conftest.err > conftest.out) cat conftest.err >&AS_MESSAGE_LOG_FD (eval echo "\"\$as_me:$LINENO: output\"" >&AS_MESSAGE_LOG_FD) cat conftest.out >&AS_MESSAGE_LOG_FD if $GREP 'External.*some_variable' conftest.out > /dev/null; then lt_cv_nm_interface="MS dumpbin" fi rm -f conftest*]) ])# LT_PATH_NM # Old names: AU_ALIAS([AM_PROG_NM], [LT_PATH_NM]) AU_ALIAS([AC_PROG_NM], [LT_PATH_NM]) dnl aclocal-1.4 backwards compatibility: dnl AC_DEFUN([AM_PROG_NM], []) dnl AC_DEFUN([AC_PROG_NM], []) # _LT_CHECK_SHAREDLIB_FROM_LINKLIB # -------------------------------- # how to determine the name of the shared library # associated with a specific link library. # -- PORTME fill in with the dynamic library characteristics m4_defun([_LT_CHECK_SHAREDLIB_FROM_LINKLIB], [m4_require([_LT_DECL_EGREP]) m4_require([_LT_DECL_OBJDUMP]) m4_require([_LT_DECL_DLLTOOL]) AC_CACHE_CHECK([how to associate runtime and link libraries], lt_cv_sharedlib_from_linklib_cmd, [lt_cv_sharedlib_from_linklib_cmd='unknown' case $host_os in cygwin* | mingw* | pw32* | cegcc*) # two different shell functions defined in ltmain.sh; # decide which one to use based on capabilities of $DLLTOOL case `$DLLTOOL --help 2>&1` in *--identify-strict*) lt_cv_sharedlib_from_linklib_cmd=func_cygming_dll_for_implib ;; *) lt_cv_sharedlib_from_linklib_cmd=func_cygming_dll_for_implib_fallback ;; esac ;; *) # fallback: assume linklib IS sharedlib lt_cv_sharedlib_from_linklib_cmd=$ECHO ;; esac ]) sharedlib_from_linklib_cmd=$lt_cv_sharedlib_from_linklib_cmd test -z "$sharedlib_from_linklib_cmd" && sharedlib_from_linklib_cmd=$ECHO _LT_DECL([], [sharedlib_from_linklib_cmd], [1], [Command to associate shared and link libraries]) ])# _LT_CHECK_SHAREDLIB_FROM_LINKLIB # _LT_PATH_MANIFEST_TOOL # ---------------------- # locate the manifest tool m4_defun([_LT_PATH_MANIFEST_TOOL], [AC_CHECK_TOOL(MANIFEST_TOOL, mt, :) test -z "$MANIFEST_TOOL" && MANIFEST_TOOL=mt AC_CACHE_CHECK([if $MANIFEST_TOOL is a manifest tool], [lt_cv_path_mainfest_tool], [lt_cv_path_mainfest_tool=no echo "$as_me:$LINENO: $MANIFEST_TOOL '-?'" >&AS_MESSAGE_LOG_FD $MANIFEST_TOOL '-?' 2>conftest.err > conftest.out cat conftest.err >&AS_MESSAGE_LOG_FD if $GREP 'Manifest Tool' conftest.out > /dev/null; then lt_cv_path_mainfest_tool=yes fi rm -f conftest*]) if test yes != "$lt_cv_path_mainfest_tool"; then MANIFEST_TOOL=: fi _LT_DECL([], [MANIFEST_TOOL], [1], [Manifest tool])dnl ])# _LT_PATH_MANIFEST_TOOL # _LT_DLL_DEF_P([FILE]) # --------------------- # True iff FILE is a Windows DLL '.def' file. # Keep in sync with func_dll_def_p in the libtool script AC_DEFUN([_LT_DLL_DEF_P], [dnl test DEF = "`$SED -n dnl -e '\''s/^[[ ]]*//'\'' dnl Strip leading whitespace -e '\''/^\(;.*\)*$/d'\'' dnl Delete empty lines and comments -e '\''s/^\(EXPORTS\|LIBRARY\)\([[ ]].*\)*$/DEF/p'\'' dnl -e q dnl Only consider the first "real" line $1`" dnl ])# _LT_DLL_DEF_P # LT_LIB_M # -------- # check for math library AC_DEFUN([LT_LIB_M], [AC_REQUIRE([AC_CANONICAL_HOST])dnl LIBM= case $host in *-*-beos* | *-*-cegcc* | *-*-cygwin* | *-*-haiku* | *-*-pw32* | *-*-darwin*) # These system don't have libm, or don't need it ;; *-ncr-sysv4.3*) AC_CHECK_LIB(mw, _mwvalidcheckl, LIBM=-lmw) AC_CHECK_LIB(m, cos, LIBM="$LIBM -lm") ;; *) AC_CHECK_LIB(m, cos, LIBM=-lm) ;; esac AC_SUBST([LIBM]) ])# LT_LIB_M # Old name: AU_ALIAS([AC_CHECK_LIBM], [LT_LIB_M]) dnl aclocal-1.4 backwards compatibility: dnl AC_DEFUN([AC_CHECK_LIBM], []) # _LT_COMPILER_NO_RTTI([TAGNAME]) # ------------------------------- m4_defun([_LT_COMPILER_NO_RTTI], [m4_require([_LT_TAG_COMPILER])dnl _LT_TAGVAR(lt_prog_compiler_no_builtin_flag, $1)= if test yes = "$GCC"; then case $cc_basename in nvcc*) _LT_TAGVAR(lt_prog_compiler_no_builtin_flag, $1)=' -Xcompiler -fno-builtin' ;; *) _LT_TAGVAR(lt_prog_compiler_no_builtin_flag, $1)=' -fno-builtin' ;; esac _LT_COMPILER_OPTION([if $compiler supports -fno-rtti -fno-exceptions], lt_cv_prog_compiler_rtti_exceptions, [-fno-rtti -fno-exceptions], [], [_LT_TAGVAR(lt_prog_compiler_no_builtin_flag, $1)="$_LT_TAGVAR(lt_prog_compiler_no_builtin_flag, $1) -fno-rtti -fno-exceptions"]) fi _LT_TAGDECL([no_builtin_flag], [lt_prog_compiler_no_builtin_flag], [1], [Compiler flag to turn off builtin functions]) ])# _LT_COMPILER_NO_RTTI # _LT_CMD_GLOBAL_SYMBOLS # ---------------------- m4_defun([_LT_CMD_GLOBAL_SYMBOLS], [AC_REQUIRE([AC_CANONICAL_HOST])dnl AC_REQUIRE([AC_PROG_CC])dnl AC_REQUIRE([AC_PROG_AWK])dnl AC_REQUIRE([LT_PATH_NM])dnl AC_REQUIRE([LT_PATH_LD])dnl m4_require([_LT_DECL_SED])dnl m4_require([_LT_DECL_EGREP])dnl m4_require([_LT_TAG_COMPILER])dnl # Check for command to grab the raw symbol name followed by C symbol from nm. AC_MSG_CHECKING([command to parse $NM output from $compiler object]) AC_CACHE_VAL([lt_cv_sys_global_symbol_pipe], [ # These are sane defaults that work on at least a few old systems. # [They come from Ultrix. What could be older than Ultrix?!! ;)] # Character class describing NM global symbol codes. symcode='[[BCDEGRST]]' # Regexp to match symbols that can be accessed directly from C. sympat='\([[_A-Za-z]][[_A-Za-z0-9]]*\)' # Define system-specific variables. case $host_os in aix*) symcode='[[BCDT]]' ;; cygwin* | mingw* | pw32* | cegcc*) symcode='[[ABCDGISTW]]' ;; hpux*) if test ia64 = "$host_cpu"; then symcode='[[ABCDEGRST]]' fi ;; irix* | nonstopux*) symcode='[[BCDEGRST]]' ;; osf*) symcode='[[BCDEGQRST]]' ;; solaris*) symcode='[[BDRT]]' ;; sco3.2v5*) symcode='[[DT]]' ;; sysv4.2uw2*) symcode='[[DT]]' ;; sysv5* | sco5v6* | unixware* | OpenUNIX*) symcode='[[ABDT]]' ;; sysv4) symcode='[[DFNSTU]]' ;; esac # If we're using GNU nm, then use its standard symbol codes. case `$NM -V 2>&1` in *GNU* | *'with BFD'*) symcode='[[ABCDGIRSTW]]' ;; esac if test "$lt_cv_nm_interface" = "MS dumpbin"; then # Gets list of data symbols to import. lt_cv_sys_global_symbol_to_import="sed -n -e 's/^I .* \(.*\)$/\1/p'" # Adjust the below global symbol transforms to fixup imported variables. lt_cdecl_hook=" -e 's/^I .* \(.*\)$/extern __declspec(dllimport) char \1;/p'" lt_c_name_hook=" -e 's/^I .* \(.*\)$/ {\"\1\", (void *) 0},/p'" lt_c_name_lib_hook="\ -e 's/^I .* \(lib.*\)$/ {\"\1\", (void *) 0},/p'\ -e 's/^I .* \(.*\)$/ {\"lib\1\", (void *) 0},/p'" else # Disable hooks by default. lt_cv_sys_global_symbol_to_import= lt_cdecl_hook= lt_c_name_hook= lt_c_name_lib_hook= fi # Transform an extracted symbol line into a proper C declaration. # Some systems (esp. on ia64) link data and code symbols differently, # so use this general approach. lt_cv_sys_global_symbol_to_cdecl="sed -n"\ $lt_cdecl_hook\ " -e 's/^T .* \(.*\)$/extern int \1();/p'"\ " -e 's/^$symcode$symcode* .* \(.*\)$/extern char \1;/p'" # Transform an extracted symbol line into symbol name and symbol address lt_cv_sys_global_symbol_to_c_name_address="sed -n"\ $lt_c_name_hook\ " -e 's/^: \(.*\) .*$/ {\"\1\", (void *) 0},/p'"\ " -e 's/^$symcode$symcode* .* \(.*\)$/ {\"\1\", (void *) \&\1},/p'" # Transform an extracted symbol line into symbol name with lib prefix and # symbol address. lt_cv_sys_global_symbol_to_c_name_address_lib_prefix="sed -n"\ $lt_c_name_lib_hook\ " -e 's/^: \(.*\) .*$/ {\"\1\", (void *) 0},/p'"\ " -e 's/^$symcode$symcode* .* \(lib.*\)$/ {\"\1\", (void *) \&\1},/p'"\ " -e 's/^$symcode$symcode* .* \(.*\)$/ {\"lib\1\", (void *) \&\1},/p'" # Handle CRLF in mingw tool chain opt_cr= case $build_os in mingw*) opt_cr=`$ECHO 'x\{0,1\}' | tr x '\015'` # option cr in regexp ;; esac # Try without a prefix underscore, then with it. for ac_symprfx in "" "_"; do # Transform symcode, sympat, and symprfx into a raw symbol and a C symbol. symxfrm="\\1 $ac_symprfx\\2 \\2" # Write the raw and C identifiers. if test "$lt_cv_nm_interface" = "MS dumpbin"; then # Fake it for dumpbin and say T for any non-static function, # D for any global variable and I for any imported variable. # Also find C++ and __fastcall symbols from MSVC++, # which start with @ or ?. lt_cv_sys_global_symbol_pipe="$AWK ['"\ " {last_section=section; section=\$ 3};"\ " /^COFF SYMBOL TABLE/{for(i in hide) delete hide[i]};"\ " /Section length .*#relocs.*(pick any)/{hide[last_section]=1};"\ " /^ *Symbol name *: /{split(\$ 0,sn,\":\"); si=substr(sn[2],2)};"\ " /^ *Type *: code/{print \"T\",si,substr(si,length(prfx))};"\ " /^ *Type *: data/{print \"I\",si,substr(si,length(prfx))};"\ " \$ 0!~/External *\|/{next};"\ " / 0+ UNDEF /{next}; / UNDEF \([^|]\)*()/{next};"\ " {if(hide[section]) next};"\ " {f=\"D\"}; \$ 0~/\(\).*\|/{f=\"T\"};"\ " {split(\$ 0,a,/\||\r/); split(a[2],s)};"\ " s[1]~/^[@?]/{print f,s[1],s[1]; next};"\ " s[1]~prfx {split(s[1],t,\"@\"); print f,t[1],substr(t[1],length(prfx))}"\ " ' prfx=^$ac_symprfx]" else lt_cv_sys_global_symbol_pipe="sed -n -e 's/^.*[[ ]]\($symcode$symcode*\)[[ ]][[ ]]*$ac_symprfx$sympat$opt_cr$/$symxfrm/p'" fi lt_cv_sys_global_symbol_pipe="$lt_cv_sys_global_symbol_pipe | sed '/ __gnu_lto/d'" # Check to see that the pipe works correctly. pipe_works=no rm -f conftest* cat > conftest.$ac_ext <<_LT_EOF #ifdef __cplusplus extern "C" { #endif char nm_test_var; void nm_test_func(void); void nm_test_func(void){} #ifdef __cplusplus } #endif int main(){nm_test_var='a';nm_test_func();return(0);} _LT_EOF if AC_TRY_EVAL(ac_compile); then # Now try to grab the symbols. nlist=conftest.nm if AC_TRY_EVAL(NM conftest.$ac_objext \| "$lt_cv_sys_global_symbol_pipe" \> $nlist) && test -s "$nlist"; then # Try sorting and uniquifying the output. if sort "$nlist" | uniq > "$nlist"T; then mv -f "$nlist"T "$nlist" else rm -f "$nlist"T fi # Make sure that we snagged all the symbols we need. if $GREP ' nm_test_var$' "$nlist" >/dev/null; then if $GREP ' nm_test_func$' "$nlist" >/dev/null; then cat <<_LT_EOF > conftest.$ac_ext /* Keep this code in sync between libtool.m4, ltmain, lt_system.h, and tests. */ #if defined _WIN32 || defined __CYGWIN__ || defined _WIN32_WCE /* DATA imports from DLLs on WIN32 can't be const, because runtime relocations are performed -- see ld's documentation on pseudo-relocs. */ # define LT@&t@_DLSYM_CONST #elif defined __osf__ /* This system does not cope well with relocations in const data. */ # define LT@&t@_DLSYM_CONST #else # define LT@&t@_DLSYM_CONST const #endif #ifdef __cplusplus extern "C" { #endif _LT_EOF # Now generate the symbol file. eval "$lt_cv_sys_global_symbol_to_cdecl"' < "$nlist" | $GREP -v main >> conftest.$ac_ext' cat <<_LT_EOF >> conftest.$ac_ext /* The mapping between symbol names and symbols. */ LT@&t@_DLSYM_CONST struct { const char *name; void *address; } lt__PROGRAM__LTX_preloaded_symbols[[]] = { { "@PROGRAM@", (void *) 0 }, _LT_EOF $SED "s/^$symcode$symcode* .* \(.*\)$/ {\"\1\", (void *) \&\1},/" < "$nlist" | $GREP -v main >> conftest.$ac_ext cat <<\_LT_EOF >> conftest.$ac_ext {0, (void *) 0} }; /* This works around a problem in FreeBSD linker */ #ifdef FREEBSD_WORKAROUND static const void *lt_preloaded_setup() { return lt__PROGRAM__LTX_preloaded_symbols; } #endif #ifdef __cplusplus } #endif _LT_EOF # Now try linking the two files. mv conftest.$ac_objext conftstm.$ac_objext lt_globsym_save_LIBS=$LIBS lt_globsym_save_CFLAGS=$CFLAGS LIBS=conftstm.$ac_objext CFLAGS="$CFLAGS$_LT_TAGVAR(lt_prog_compiler_no_builtin_flag, $1)" if AC_TRY_EVAL(ac_link) && test -s conftest$ac_exeext; then pipe_works=yes fi LIBS=$lt_globsym_save_LIBS CFLAGS=$lt_globsym_save_CFLAGS else echo "cannot find nm_test_func in $nlist" >&AS_MESSAGE_LOG_FD fi else echo "cannot find nm_test_var in $nlist" >&AS_MESSAGE_LOG_FD fi else echo "cannot run $lt_cv_sys_global_symbol_pipe" >&AS_MESSAGE_LOG_FD fi else echo "$progname: failed program was:" >&AS_MESSAGE_LOG_FD cat conftest.$ac_ext >&5 fi rm -rf conftest* conftst* # Do not use the global_symbol_pipe unless it works. if test yes = "$pipe_works"; then break else lt_cv_sys_global_symbol_pipe= fi done ]) if test -z "$lt_cv_sys_global_symbol_pipe"; then lt_cv_sys_global_symbol_to_cdecl= fi if test -z "$lt_cv_sys_global_symbol_pipe$lt_cv_sys_global_symbol_to_cdecl"; then AC_MSG_RESULT(failed) else AC_MSG_RESULT(ok) fi # Response file support. if test "$lt_cv_nm_interface" = "MS dumpbin"; then nm_file_list_spec='@' elif $NM --help 2>/dev/null | grep '[[@]]FILE' >/dev/null; then nm_file_list_spec='@' fi _LT_DECL([global_symbol_pipe], [lt_cv_sys_global_symbol_pipe], [1], [Take the output of nm and produce a listing of raw symbols and C names]) _LT_DECL([global_symbol_to_cdecl], [lt_cv_sys_global_symbol_to_cdecl], [1], [Transform the output of nm in a proper C declaration]) _LT_DECL([global_symbol_to_import], [lt_cv_sys_global_symbol_to_import], [1], [Transform the output of nm into a list of symbols to manually relocate]) _LT_DECL([global_symbol_to_c_name_address], [lt_cv_sys_global_symbol_to_c_name_address], [1], [Transform the output of nm in a C name address pair]) _LT_DECL([global_symbol_to_c_name_address_lib_prefix], [lt_cv_sys_global_symbol_to_c_name_address_lib_prefix], [1], [Transform the output of nm in a C name address pair when lib prefix is needed]) _LT_DECL([nm_interface], [lt_cv_nm_interface], [1], [The name lister interface]) _LT_DECL([], [nm_file_list_spec], [1], [Specify filename containing input files for $NM]) ]) # _LT_CMD_GLOBAL_SYMBOLS # _LT_COMPILER_PIC([TAGNAME]) # --------------------------- m4_defun([_LT_COMPILER_PIC], [m4_require([_LT_TAG_COMPILER])dnl _LT_TAGVAR(lt_prog_compiler_wl, $1)= _LT_TAGVAR(lt_prog_compiler_pic, $1)= _LT_TAGVAR(lt_prog_compiler_static, $1)= m4_if([$1], [CXX], [ # C++ specific cases for pic, static, wl, etc. if test yes = "$GXX"; then _LT_TAGVAR(lt_prog_compiler_wl, $1)='-Wl,' _LT_TAGVAR(lt_prog_compiler_static, $1)='-static' case $host_os in aix*) # All AIX code is PIC. if test ia64 = "$host_cpu"; then # AIX 5 now supports IA64 processor _LT_TAGVAR(lt_prog_compiler_static, $1)='-Bstatic' fi _LT_TAGVAR(lt_prog_compiler_pic, $1)='-fPIC' ;; amigaos*) case $host_cpu in powerpc) # see comment about AmigaOS4 .so support _LT_TAGVAR(lt_prog_compiler_pic, $1)='-fPIC' ;; m68k) # FIXME: we need at least 68020 code to build shared libraries, but # adding the '-m68020' flag to GCC prevents building anything better, # like '-m68040'. _LT_TAGVAR(lt_prog_compiler_pic, $1)='-m68020 -resident32 -malways-restore-a4' ;; esac ;; beos* | irix5* | irix6* | nonstopux* | osf3* | osf4* | osf5*) # PIC is the default for these OSes. ;; mingw* | cygwin* | os2* | pw32* | cegcc*) # This hack is so that the source file can tell whether it is being # built for inclusion in a dll (and should export symbols for example). # Although the cygwin gcc ignores -fPIC, still need this for old-style # (--disable-auto-import) libraries m4_if([$1], [GCJ], [], [_LT_TAGVAR(lt_prog_compiler_pic, $1)='-DDLL_EXPORT']) case $host_os in os2*) _LT_TAGVAR(lt_prog_compiler_static, $1)='$wl-static' ;; esac ;; darwin* | rhapsody*) # PIC is the default on this platform # Common symbols not allowed in MH_DYLIB files _LT_TAGVAR(lt_prog_compiler_pic, $1)='-fno-common' ;; *djgpp*) # DJGPP does not support shared libraries at all _LT_TAGVAR(lt_prog_compiler_pic, $1)= ;; haiku*) # PIC is the default for Haiku. # The "-static" flag exists, but is broken. _LT_TAGVAR(lt_prog_compiler_static, $1)= ;; interix[[3-9]]*) # Interix 3.x gcc -fpic/-fPIC options generate broken code. # Instead, we relocate shared libraries at runtime. ;; sysv4*MP*) if test -d /usr/nec; then _LT_TAGVAR(lt_prog_compiler_pic, $1)=-Kconform_pic fi ;; hpux*) # PIC is the default for 64-bit PA HP-UX, but not for 32-bit # PA HP-UX. On IA64 HP-UX, PIC is the default but the pic flag # sets the default TLS model and affects inlining. case $host_cpu in hppa*64*) ;; *) _LT_TAGVAR(lt_prog_compiler_pic, $1)='-fPIC' ;; esac ;; *qnx* | *nto*) # QNX uses GNU C++, but need to define -shared option too, otherwise # it will coredump. _LT_TAGVAR(lt_prog_compiler_pic, $1)='-fPIC -shared' ;; *) _LT_TAGVAR(lt_prog_compiler_pic, $1)='-fPIC' ;; esac else case $host_os in aix[[4-9]]*) # All AIX code is PIC. if test ia64 = "$host_cpu"; then # AIX 5 now supports IA64 processor _LT_TAGVAR(lt_prog_compiler_static, $1)='-Bstatic' else _LT_TAGVAR(lt_prog_compiler_static, $1)='-bnso -bI:/lib/syscalls.exp' fi ;; chorus*) case $cc_basename in cxch68*) # Green Hills C++ Compiler # _LT_TAGVAR(lt_prog_compiler_static, $1)="--no_auto_instantiation -u __main -u __premain -u _abort -r $COOL_DIR/lib/libOrb.a $MVME_DIR/lib/CC/libC.a $MVME_DIR/lib/classix/libcx.s.a" ;; esac ;; mingw* | cygwin* | os2* | pw32* | cegcc*) # This hack is so that the source file can tell whether it is being # built for inclusion in a dll (and should export symbols for example). m4_if([$1], [GCJ], [], [_LT_TAGVAR(lt_prog_compiler_pic, $1)='-DDLL_EXPORT']) ;; dgux*) case $cc_basename in ec++*) _LT_TAGVAR(lt_prog_compiler_pic, $1)='-KPIC' ;; ghcx*) # Green Hills C++ Compiler _LT_TAGVAR(lt_prog_compiler_pic, $1)='-pic' ;; *) ;; esac ;; freebsd* | dragonfly*) # FreeBSD uses GNU C++ ;; hpux9* | hpux10* | hpux11*) case $cc_basename in CC*) _LT_TAGVAR(lt_prog_compiler_wl, $1)='-Wl,' _LT_TAGVAR(lt_prog_compiler_static, $1)='$wl-a ${wl}archive' if test ia64 != "$host_cpu"; then _LT_TAGVAR(lt_prog_compiler_pic, $1)='+Z' fi ;; aCC*) _LT_TAGVAR(lt_prog_compiler_wl, $1)='-Wl,' _LT_TAGVAR(lt_prog_compiler_static, $1)='$wl-a ${wl}archive' case $host_cpu in hppa*64*|ia64*) # +Z the default ;; *) _LT_TAGVAR(lt_prog_compiler_pic, $1)='+Z' ;; esac ;; *) ;; esac ;; interix*) # This is c89, which is MS Visual C++ (no shared libs) # Anyone wants to do a port? ;; irix5* | irix6* | nonstopux*) case $cc_basename in CC*) _LT_TAGVAR(lt_prog_compiler_wl, $1)='-Wl,' _LT_TAGVAR(lt_prog_compiler_static, $1)='-non_shared' # CC pic flag -KPIC is the default. ;; *) ;; esac ;; linux* | k*bsd*-gnu | kopensolaris*-gnu | gnu*) case $cc_basename in KCC*) # KAI C++ Compiler _LT_TAGVAR(lt_prog_compiler_wl, $1)='--backend -Wl,' _LT_TAGVAR(lt_prog_compiler_pic, $1)='-fPIC' ;; ecpc* ) # old Intel C++ for x86_64, which still supported -KPIC. _LT_TAGVAR(lt_prog_compiler_wl, $1)='-Wl,' _LT_TAGVAR(lt_prog_compiler_pic, $1)='-KPIC' _LT_TAGVAR(lt_prog_compiler_static, $1)='-static' ;; icpc* ) # Intel C++, used to be incompatible with GCC. # ICC 10 doesn't accept -KPIC any more. _LT_TAGVAR(lt_prog_compiler_wl, $1)='-Wl,' _LT_TAGVAR(lt_prog_compiler_pic, $1)='-fPIC' _LT_TAGVAR(lt_prog_compiler_static, $1)='-static' ;; pgCC* | pgcpp*) # Portland Group C++ compiler _LT_TAGVAR(lt_prog_compiler_wl, $1)='-Wl,' _LT_TAGVAR(lt_prog_compiler_pic, $1)='-fpic' _LT_TAGVAR(lt_prog_compiler_static, $1)='-Bstatic' ;; cxx*) # Compaq C++ # Make sure the PIC flag is empty. It appears that all Alpha # Linux and Compaq Tru64 Unix objects are PIC. _LT_TAGVAR(lt_prog_compiler_pic, $1)= _LT_TAGVAR(lt_prog_compiler_static, $1)='-non_shared' ;; xlc* | xlC* | bgxl[[cC]]* | mpixl[[cC]]*) # IBM XL 8.0, 9.0 on PPC and BlueGene _LT_TAGVAR(lt_prog_compiler_wl, $1)='-Wl,' _LT_TAGVAR(lt_prog_compiler_pic, $1)='-qpic' _LT_TAGVAR(lt_prog_compiler_static, $1)='-qstaticlink' ;; *) case `$CC -V 2>&1 | sed 5q` in *Sun\ C*) # Sun C++ 5.9 _LT_TAGVAR(lt_prog_compiler_pic, $1)='-KPIC' _LT_TAGVAR(lt_prog_compiler_static, $1)='-Bstatic' _LT_TAGVAR(lt_prog_compiler_wl, $1)='-Qoption ld ' ;; esac ;; esac ;; lynxos*) ;; m88k*) ;; mvs*) case $cc_basename in cxx*) _LT_TAGVAR(lt_prog_compiler_pic, $1)='-W c,exportall' ;; *) ;; esac ;; netbsd*) ;; *qnx* | *nto*) # QNX uses GNU C++, but need to define -shared option too, otherwise # it will coredump. _LT_TAGVAR(lt_prog_compiler_pic, $1)='-fPIC -shared' ;; osf3* | osf4* | osf5*) case $cc_basename in KCC*) _LT_TAGVAR(lt_prog_compiler_wl, $1)='--backend -Wl,' ;; RCC*) # Rational C++ 2.4.1 _LT_TAGVAR(lt_prog_compiler_pic, $1)='-pic' ;; cxx*) # Digital/Compaq C++ _LT_TAGVAR(lt_prog_compiler_wl, $1)='-Wl,' # Make sure the PIC flag is empty. It appears that all Alpha # Linux and Compaq Tru64 Unix objects are PIC. _LT_TAGVAR(lt_prog_compiler_pic, $1)= _LT_TAGVAR(lt_prog_compiler_static, $1)='-non_shared' ;; *) ;; esac ;; psos*) ;; solaris*) case $cc_basename in CC* | sunCC*) # Sun C++ 4.2, 5.x and Centerline C++ _LT_TAGVAR(lt_prog_compiler_pic, $1)='-KPIC' _LT_TAGVAR(lt_prog_compiler_static, $1)='-Bstatic' _LT_TAGVAR(lt_prog_compiler_wl, $1)='-Qoption ld ' ;; gcx*) # Green Hills C++ Compiler _LT_TAGVAR(lt_prog_compiler_pic, $1)='-PIC' ;; *) ;; esac ;; sunos4*) case $cc_basename in CC*) # Sun C++ 4.x _LT_TAGVAR(lt_prog_compiler_pic, $1)='-pic' _LT_TAGVAR(lt_prog_compiler_static, $1)='-Bstatic' ;; lcc*) # Lucid _LT_TAGVAR(lt_prog_compiler_pic, $1)='-pic' ;; *) ;; esac ;; sysv5* | unixware* | sco3.2v5* | sco5v6* | OpenUNIX*) case $cc_basename in CC*) _LT_TAGVAR(lt_prog_compiler_wl, $1)='-Wl,' _LT_TAGVAR(lt_prog_compiler_pic, $1)='-KPIC' _LT_TAGVAR(lt_prog_compiler_static, $1)='-Bstatic' ;; esac ;; tandem*) case $cc_basename in NCC*) # NonStop-UX NCC 3.20 _LT_TAGVAR(lt_prog_compiler_pic, $1)='-KPIC' ;; *) ;; esac ;; vxworks*) ;; *) _LT_TAGVAR(lt_prog_compiler_can_build_shared, $1)=no ;; esac fi ], [ if test yes = "$GCC"; then _LT_TAGVAR(lt_prog_compiler_wl, $1)='-Wl,' _LT_TAGVAR(lt_prog_compiler_static, $1)='-static' case $host_os in aix*) # All AIX code is PIC. if test ia64 = "$host_cpu"; then # AIX 5 now supports IA64 processor _LT_TAGVAR(lt_prog_compiler_static, $1)='-Bstatic' fi _LT_TAGVAR(lt_prog_compiler_pic, $1)='-fPIC' ;; amigaos*) case $host_cpu in powerpc) # see comment about AmigaOS4 .so support _LT_TAGVAR(lt_prog_compiler_pic, $1)='-fPIC' ;; m68k) # FIXME: we need at least 68020 code to build shared libraries, but # adding the '-m68020' flag to GCC prevents building anything better, # like '-m68040'. _LT_TAGVAR(lt_prog_compiler_pic, $1)='-m68020 -resident32 -malways-restore-a4' ;; esac ;; beos* | irix5* | irix6* | nonstopux* | osf3* | osf4* | osf5*) # PIC is the default for these OSes. ;; mingw* | cygwin* | pw32* | os2* | cegcc*) # This hack is so that the source file can tell whether it is being # built for inclusion in a dll (and should export symbols for example). # Although the cygwin gcc ignores -fPIC, still need this for old-style # (--disable-auto-import) libraries m4_if([$1], [GCJ], [], [_LT_TAGVAR(lt_prog_compiler_pic, $1)='-DDLL_EXPORT']) case $host_os in os2*) _LT_TAGVAR(lt_prog_compiler_static, $1)='$wl-static' ;; esac ;; darwin* | rhapsody*) # PIC is the default on this platform # Common symbols not allowed in MH_DYLIB files _LT_TAGVAR(lt_prog_compiler_pic, $1)='-fno-common' ;; haiku*) # PIC is the default for Haiku. # The "-static" flag exists, but is broken. _LT_TAGVAR(lt_prog_compiler_static, $1)= ;; hpux*) # PIC is the default for 64-bit PA HP-UX, but not for 32-bit # PA HP-UX. On IA64 HP-UX, PIC is the default but the pic flag # sets the default TLS model and affects inlining. case $host_cpu in hppa*64*) # +Z the default ;; *) _LT_TAGVAR(lt_prog_compiler_pic, $1)='-fPIC' ;; esac ;; interix[[3-9]]*) # Interix 3.x gcc -fpic/-fPIC options generate broken code. # Instead, we relocate shared libraries at runtime. ;; msdosdjgpp*) # Just because we use GCC doesn't mean we suddenly get shared libraries # on systems that don't support them. _LT_TAGVAR(lt_prog_compiler_can_build_shared, $1)=no enable_shared=no ;; *nto* | *qnx*) # QNX uses GNU C++, but need to define -shared option too, otherwise # it will coredump. _LT_TAGVAR(lt_prog_compiler_pic, $1)='-fPIC -shared' ;; sysv4*MP*) if test -d /usr/nec; then _LT_TAGVAR(lt_prog_compiler_pic, $1)=-Kconform_pic fi ;; *) _LT_TAGVAR(lt_prog_compiler_pic, $1)='-fPIC' ;; esac case $cc_basename in nvcc*) # Cuda Compiler Driver 2.2 _LT_TAGVAR(lt_prog_compiler_wl, $1)='-Xlinker ' if test -n "$_LT_TAGVAR(lt_prog_compiler_pic, $1)"; then _LT_TAGVAR(lt_prog_compiler_pic, $1)="-Xcompiler $_LT_TAGVAR(lt_prog_compiler_pic, $1)" fi ;; esac else # PORTME Check for flag to pass linker flags through the system compiler. case $host_os in aix*) _LT_TAGVAR(lt_prog_compiler_wl, $1)='-Wl,' if test ia64 = "$host_cpu"; then # AIX 5 now supports IA64 processor _LT_TAGVAR(lt_prog_compiler_static, $1)='-Bstatic' else _LT_TAGVAR(lt_prog_compiler_static, $1)='-bnso -bI:/lib/syscalls.exp' fi ;; darwin* | rhapsody*) # PIC is the default on this platform # Common symbols not allowed in MH_DYLIB files _LT_TAGVAR(lt_prog_compiler_pic, $1)='-fno-common' case $cc_basename in nagfor*) # NAG Fortran compiler _LT_TAGVAR(lt_prog_compiler_wl, $1)='-Wl,-Wl,,' _LT_TAGVAR(lt_prog_compiler_pic, $1)='-PIC' _LT_TAGVAR(lt_prog_compiler_static, $1)='-Bstatic' ;; esac ;; mingw* | cygwin* | pw32* | os2* | cegcc*) # This hack is so that the source file can tell whether it is being # built for inclusion in a dll (and should export symbols for example). m4_if([$1], [GCJ], [], [_LT_TAGVAR(lt_prog_compiler_pic, $1)='-DDLL_EXPORT']) case $host_os in os2*) _LT_TAGVAR(lt_prog_compiler_static, $1)='$wl-static' ;; esac ;; hpux9* | hpux10* | hpux11*) _LT_TAGVAR(lt_prog_compiler_wl, $1)='-Wl,' # PIC is the default for IA64 HP-UX and 64-bit HP-UX, but # not for PA HP-UX. case $host_cpu in hppa*64*|ia64*) # +Z the default ;; *) _LT_TAGVAR(lt_prog_compiler_pic, $1)='+Z' ;; esac # Is there a better lt_prog_compiler_static that works with the bundled CC? _LT_TAGVAR(lt_prog_compiler_static, $1)='$wl-a ${wl}archive' ;; irix5* | irix6* | nonstopux*) _LT_TAGVAR(lt_prog_compiler_wl, $1)='-Wl,' # PIC (with -KPIC) is the default. _LT_TAGVAR(lt_prog_compiler_static, $1)='-non_shared' ;; linux* | k*bsd*-gnu | kopensolaris*-gnu | gnu*) case $cc_basename in # old Intel for x86_64, which still supported -KPIC. ecc*) _LT_TAGVAR(lt_prog_compiler_wl, $1)='-Wl,' _LT_TAGVAR(lt_prog_compiler_pic, $1)='-KPIC' _LT_TAGVAR(lt_prog_compiler_static, $1)='-static' ;; # icc used to be incompatible with GCC. # ICC 10 doesn't accept -KPIC any more. icc* | ifort*) _LT_TAGVAR(lt_prog_compiler_wl, $1)='-Wl,' _LT_TAGVAR(lt_prog_compiler_pic, $1)='-fPIC' _LT_TAGVAR(lt_prog_compiler_static, $1)='-static' ;; # Lahey Fortran 8.1. lf95*) _LT_TAGVAR(lt_prog_compiler_wl, $1)='-Wl,' _LT_TAGVAR(lt_prog_compiler_pic, $1)='--shared' _LT_TAGVAR(lt_prog_compiler_static, $1)='--static' ;; nagfor*) # NAG Fortran compiler _LT_TAGVAR(lt_prog_compiler_wl, $1)='-Wl,-Wl,,' _LT_TAGVAR(lt_prog_compiler_pic, $1)='-PIC' _LT_TAGVAR(lt_prog_compiler_static, $1)='-Bstatic' ;; tcc*) # Fabrice Bellard et al's Tiny C Compiler _LT_TAGVAR(lt_prog_compiler_wl, $1)='-Wl,' _LT_TAGVAR(lt_prog_compiler_pic, $1)='-fPIC' _LT_TAGVAR(lt_prog_compiler_static, $1)='-static' ;; pgcc* | pgf77* | pgf90* | pgf95* | pgfortran*) # Portland Group compilers (*not* the Pentium gcc compiler, # which looks to be a dead project) _LT_TAGVAR(lt_prog_compiler_wl, $1)='-Wl,' _LT_TAGVAR(lt_prog_compiler_pic, $1)='-fpic' _LT_TAGVAR(lt_prog_compiler_static, $1)='-Bstatic' ;; ccc*) _LT_TAGVAR(lt_prog_compiler_wl, $1)='-Wl,' # All Alpha code is PIC. _LT_TAGVAR(lt_prog_compiler_static, $1)='-non_shared' ;; xl* | bgxl* | bgf* | mpixl*) # IBM XL C 8.0/Fortran 10.1, 11.1 on PPC and BlueGene _LT_TAGVAR(lt_prog_compiler_wl, $1)='-Wl,' _LT_TAGVAR(lt_prog_compiler_pic, $1)='-qpic' _LT_TAGVAR(lt_prog_compiler_static, $1)='-qstaticlink' ;; *) case `$CC -V 2>&1 | sed 5q` in *Sun\ Ceres\ Fortran* | *Sun*Fortran*\ [[1-7]].* | *Sun*Fortran*\ 8.[[0-3]]*) # Sun Fortran 8.3 passes all unrecognized flags to the linker _LT_TAGVAR(lt_prog_compiler_pic, $1)='-KPIC' _LT_TAGVAR(lt_prog_compiler_static, $1)='-Bstatic' _LT_TAGVAR(lt_prog_compiler_wl, $1)='' ;; *Sun\ F* | *Sun*Fortran*) _LT_TAGVAR(lt_prog_compiler_pic, $1)='-KPIC' _LT_TAGVAR(lt_prog_compiler_static, $1)='-Bstatic' _LT_TAGVAR(lt_prog_compiler_wl, $1)='-Qoption ld ' ;; *Sun\ C*) # Sun C 5.9 _LT_TAGVAR(lt_prog_compiler_pic, $1)='-KPIC' _LT_TAGVAR(lt_prog_compiler_static, $1)='-Bstatic' _LT_TAGVAR(lt_prog_compiler_wl, $1)='-Wl,' ;; *Intel*\ [[CF]]*Compiler*) _LT_TAGVAR(lt_prog_compiler_wl, $1)='-Wl,' _LT_TAGVAR(lt_prog_compiler_pic, $1)='-fPIC' _LT_TAGVAR(lt_prog_compiler_static, $1)='-static' ;; *Portland\ Group*) _LT_TAGVAR(lt_prog_compiler_wl, $1)='-Wl,' _LT_TAGVAR(lt_prog_compiler_pic, $1)='-fpic' _LT_TAGVAR(lt_prog_compiler_static, $1)='-Bstatic' ;; esac ;; esac ;; newsos6) _LT_TAGVAR(lt_prog_compiler_pic, $1)='-KPIC' _LT_TAGVAR(lt_prog_compiler_static, $1)='-Bstatic' ;; *nto* | *qnx*) # QNX uses GNU C++, but need to define -shared option too, otherwise # it will coredump. _LT_TAGVAR(lt_prog_compiler_pic, $1)='-fPIC -shared' ;; osf3* | osf4* | osf5*) _LT_TAGVAR(lt_prog_compiler_wl, $1)='-Wl,' # All OSF/1 code is PIC. _LT_TAGVAR(lt_prog_compiler_static, $1)='-non_shared' ;; rdos*) _LT_TAGVAR(lt_prog_compiler_static, $1)='-non_shared' ;; solaris*) _LT_TAGVAR(lt_prog_compiler_pic, $1)='-KPIC' _LT_TAGVAR(lt_prog_compiler_static, $1)='-Bstatic' case $cc_basename in f77* | f90* | f95* | sunf77* | sunf90* | sunf95*) _LT_TAGVAR(lt_prog_compiler_wl, $1)='-Qoption ld ';; *) _LT_TAGVAR(lt_prog_compiler_wl, $1)='-Wl,';; esac ;; sunos4*) _LT_TAGVAR(lt_prog_compiler_wl, $1)='-Qoption ld ' _LT_TAGVAR(lt_prog_compiler_pic, $1)='-PIC' _LT_TAGVAR(lt_prog_compiler_static, $1)='-Bstatic' ;; sysv4 | sysv4.2uw2* | sysv4.3*) _LT_TAGVAR(lt_prog_compiler_wl, $1)='-Wl,' _LT_TAGVAR(lt_prog_compiler_pic, $1)='-KPIC' _LT_TAGVAR(lt_prog_compiler_static, $1)='-Bstatic' ;; sysv4*MP*) if test -d /usr/nec; then _LT_TAGVAR(lt_prog_compiler_pic, $1)='-Kconform_pic' _LT_TAGVAR(lt_prog_compiler_static, $1)='-Bstatic' fi ;; sysv5* | unixware* | sco3.2v5* | sco5v6* | OpenUNIX*) _LT_TAGVAR(lt_prog_compiler_wl, $1)='-Wl,' _LT_TAGVAR(lt_prog_compiler_pic, $1)='-KPIC' _LT_TAGVAR(lt_prog_compiler_static, $1)='-Bstatic' ;; unicos*) _LT_TAGVAR(lt_prog_compiler_wl, $1)='-Wl,' _LT_TAGVAR(lt_prog_compiler_can_build_shared, $1)=no ;; uts4*) _LT_TAGVAR(lt_prog_compiler_pic, $1)='-pic' _LT_TAGVAR(lt_prog_compiler_static, $1)='-Bstatic' ;; *) _LT_TAGVAR(lt_prog_compiler_can_build_shared, $1)=no ;; esac fi ]) case $host_os in # For platforms that do not support PIC, -DPIC is meaningless: *djgpp*) _LT_TAGVAR(lt_prog_compiler_pic, $1)= ;; *) _LT_TAGVAR(lt_prog_compiler_pic, $1)="$_LT_TAGVAR(lt_prog_compiler_pic, $1)@&t@m4_if([$1],[],[ -DPIC],[m4_if([$1],[CXX],[ -DPIC],[])])" ;; esac AC_CACHE_CHECK([for $compiler option to produce PIC], [_LT_TAGVAR(lt_cv_prog_compiler_pic, $1)], [_LT_TAGVAR(lt_cv_prog_compiler_pic, $1)=$_LT_TAGVAR(lt_prog_compiler_pic, $1)]) _LT_TAGVAR(lt_prog_compiler_pic, $1)=$_LT_TAGVAR(lt_cv_prog_compiler_pic, $1) # # Check to make sure the PIC flag actually works. # if test -n "$_LT_TAGVAR(lt_prog_compiler_pic, $1)"; then _LT_COMPILER_OPTION([if $compiler PIC flag $_LT_TAGVAR(lt_prog_compiler_pic, $1) works], [_LT_TAGVAR(lt_cv_prog_compiler_pic_works, $1)], [$_LT_TAGVAR(lt_prog_compiler_pic, $1)@&t@m4_if([$1],[],[ -DPIC],[m4_if([$1],[CXX],[ -DPIC],[])])], [], [case $_LT_TAGVAR(lt_prog_compiler_pic, $1) in "" | " "*) ;; *) _LT_TAGVAR(lt_prog_compiler_pic, $1)=" $_LT_TAGVAR(lt_prog_compiler_pic, $1)" ;; esac], [_LT_TAGVAR(lt_prog_compiler_pic, $1)= _LT_TAGVAR(lt_prog_compiler_can_build_shared, $1)=no]) fi _LT_TAGDECL([pic_flag], [lt_prog_compiler_pic], [1], [Additional compiler flags for building library objects]) _LT_TAGDECL([wl], [lt_prog_compiler_wl], [1], [How to pass a linker flag through the compiler]) # # Check to make sure the static flag actually works. # wl=$_LT_TAGVAR(lt_prog_compiler_wl, $1) eval lt_tmp_static_flag=\"$_LT_TAGVAR(lt_prog_compiler_static, $1)\" _LT_LINKER_OPTION([if $compiler static flag $lt_tmp_static_flag works], _LT_TAGVAR(lt_cv_prog_compiler_static_works, $1), $lt_tmp_static_flag, [], [_LT_TAGVAR(lt_prog_compiler_static, $1)=]) _LT_TAGDECL([link_static_flag], [lt_prog_compiler_static], [1], [Compiler flag to prevent dynamic linking]) ])# _LT_COMPILER_PIC # _LT_LINKER_SHLIBS([TAGNAME]) # ---------------------------- # See if the linker supports building shared libraries. m4_defun([_LT_LINKER_SHLIBS], [AC_REQUIRE([LT_PATH_LD])dnl AC_REQUIRE([LT_PATH_NM])dnl m4_require([_LT_PATH_MANIFEST_TOOL])dnl m4_require([_LT_FILEUTILS_DEFAULTS])dnl m4_require([_LT_DECL_EGREP])dnl m4_require([_LT_DECL_SED])dnl m4_require([_LT_CMD_GLOBAL_SYMBOLS])dnl m4_require([_LT_TAG_COMPILER])dnl AC_MSG_CHECKING([whether the $compiler linker ($LD) supports shared libraries]) m4_if([$1], [CXX], [ _LT_TAGVAR(export_symbols_cmds, $1)='$NM $libobjs $convenience | $global_symbol_pipe | $SED '\''s/.* //'\'' | sort | uniq > $export_symbols' _LT_TAGVAR(exclude_expsyms, $1)=['_GLOBAL_OFFSET_TABLE_|_GLOBAL__F[ID]_.*'] case $host_os in aix[[4-9]]*) # If we're using GNU nm, then we don't want the "-C" option. # -C means demangle to GNU nm, but means don't demangle to AIX nm. # Without the "-l" option, or with the "-B" option, AIX nm treats # weak defined symbols like other global defined symbols, whereas # GNU nm marks them as "W". # While the 'weak' keyword is ignored in the Export File, we need # it in the Import File for the 'aix-soname' feature, so we have # to replace the "-B" option with "-P" for AIX nm. if $NM -V 2>&1 | $GREP 'GNU' > /dev/null; then _LT_TAGVAR(export_symbols_cmds, $1)='$NM -Bpg $libobjs $convenience | awk '\''{ if (((\$ 2 == "T") || (\$ 2 == "D") || (\$ 2 == "B") || (\$ 2 == "W")) && ([substr](\$ 3,1,1) != ".")) { if (\$ 2 == "W") { print \$ 3 " weak" } else { print \$ 3 } } }'\'' | sort -u > $export_symbols' else _LT_TAGVAR(export_symbols_cmds, $1)='`func_echo_all $NM | $SED -e '\''s/B\([[^B]]*\)$/P\1/'\''` -PCpgl $libobjs $convenience | awk '\''{ if (((\$ 2 == "T") || (\$ 2 == "D") || (\$ 2 == "B") || (\$ 2 == "W") || (\$ 2 == "V") || (\$ 2 == "Z")) && ([substr](\$ 1,1,1) != ".")) { if ((\$ 2 == "W") || (\$ 2 == "V") || (\$ 2 == "Z")) { print \$ 1 " weak" } else { print \$ 1 } } }'\'' | sort -u > $export_symbols' fi ;; pw32*) _LT_TAGVAR(export_symbols_cmds, $1)=$ltdll_cmds ;; cygwin* | mingw* | cegcc*) case $cc_basename in cl*) _LT_TAGVAR(exclude_expsyms, $1)='_NULL_IMPORT_DESCRIPTOR|_IMPORT_DESCRIPTOR_.*' ;; *) _LT_TAGVAR(export_symbols_cmds, $1)='$NM $libobjs $convenience | $global_symbol_pipe | $SED -e '\''/^[[BCDGRS]][[ ]]/s/.*[[ ]]\([[^ ]]*\)/\1 DATA/;s/^.*[[ ]]__nm__\([[^ ]]*\)[[ ]][[^ ]]*/\1 DATA/;/^I[[ ]]/d;/^[[AITW]][[ ]]/s/.* //'\'' | sort | uniq > $export_symbols' _LT_TAGVAR(exclude_expsyms, $1)=['[_]+GLOBAL_OFFSET_TABLE_|[_]+GLOBAL__[FID]_.*|[_]+head_[A-Za-z0-9_]+_dll|[A-Za-z0-9_]+_dll_iname'] ;; esac ;; *) _LT_TAGVAR(export_symbols_cmds, $1)='$NM $libobjs $convenience | $global_symbol_pipe | $SED '\''s/.* //'\'' | sort | uniq > $export_symbols' ;; esac ], [ runpath_var= _LT_TAGVAR(allow_undefined_flag, $1)= _LT_TAGVAR(always_export_symbols, $1)=no _LT_TAGVAR(archive_cmds, $1)= _LT_TAGVAR(archive_expsym_cmds, $1)= _LT_TAGVAR(compiler_needs_object, $1)=no _LT_TAGVAR(enable_shared_with_static_runtimes, $1)=no _LT_TAGVAR(export_dynamic_flag_spec, $1)= _LT_TAGVAR(export_symbols_cmds, $1)='$NM $libobjs $convenience | $global_symbol_pipe | $SED '\''s/.* //'\'' | sort | uniq > $export_symbols' _LT_TAGVAR(hardcode_automatic, $1)=no _LT_TAGVAR(hardcode_direct, $1)=no _LT_TAGVAR(hardcode_direct_absolute, $1)=no _LT_TAGVAR(hardcode_libdir_flag_spec, $1)= _LT_TAGVAR(hardcode_libdir_separator, $1)= _LT_TAGVAR(hardcode_minus_L, $1)=no _LT_TAGVAR(hardcode_shlibpath_var, $1)=unsupported _LT_TAGVAR(inherit_rpath, $1)=no _LT_TAGVAR(link_all_deplibs, $1)=unknown _LT_TAGVAR(module_cmds, $1)= _LT_TAGVAR(module_expsym_cmds, $1)= _LT_TAGVAR(old_archive_from_new_cmds, $1)= _LT_TAGVAR(old_archive_from_expsyms_cmds, $1)= _LT_TAGVAR(thread_safe_flag_spec, $1)= _LT_TAGVAR(whole_archive_flag_spec, $1)= # include_expsyms should be a list of space-separated symbols to be *always* # included in the symbol list _LT_TAGVAR(include_expsyms, $1)= # exclude_expsyms can be an extended regexp of symbols to exclude # it will be wrapped by ' (' and ')$', so one must not match beginning or # end of line. Example: 'a|bc|.*d.*' will exclude the symbols 'a' and 'bc', # as well as any symbol that contains 'd'. _LT_TAGVAR(exclude_expsyms, $1)=['_GLOBAL_OFFSET_TABLE_|_GLOBAL__F[ID]_.*'] # Although _GLOBAL_OFFSET_TABLE_ is a valid symbol C name, most a.out # platforms (ab)use it in PIC code, but their linkers get confused if # the symbol is explicitly referenced. Since portable code cannot # rely on this symbol name, it's probably fine to never include it in # preloaded symbol tables. # Exclude shared library initialization/finalization symbols. dnl Note also adjust exclude_expsyms for C++ above. extract_expsyms_cmds= case $host_os in cygwin* | mingw* | pw32* | cegcc*) # FIXME: the MSVC++ port hasn't been tested in a loooong time # When not using gcc, we currently assume that we are using # Microsoft Visual C++. if test yes != "$GCC"; then with_gnu_ld=no fi ;; interix*) # we just hope/assume this is gcc and not c89 (= MSVC++) with_gnu_ld=yes ;; openbsd* | bitrig*) with_gnu_ld=no ;; esac _LT_TAGVAR(ld_shlibs, $1)=yes # On some targets, GNU ld is compatible enough with the native linker # that we're better off using the native interface for both. lt_use_gnu_ld_interface=no if test yes = "$with_gnu_ld"; then case $host_os in aix*) # The AIX port of GNU ld has always aspired to compatibility # with the native linker. However, as the warning in the GNU ld # block says, versions before 2.19.5* couldn't really create working # shared libraries, regardless of the interface used. case `$LD -v 2>&1` in *\ \(GNU\ Binutils\)\ 2.19.5*) ;; *\ \(GNU\ Binutils\)\ 2.[[2-9]]*) ;; *\ \(GNU\ Binutils\)\ [[3-9]]*) ;; *) lt_use_gnu_ld_interface=yes ;; esac ;; *) lt_use_gnu_ld_interface=yes ;; esac fi if test yes = "$lt_use_gnu_ld_interface"; then # If archive_cmds runs LD, not CC, wlarc should be empty wlarc='$wl' # Set some defaults for GNU ld with shared library support. These # are reset later if shared libraries are not supported. Putting them # here allows them to be overridden if necessary. runpath_var=LD_RUN_PATH _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='$wl-rpath $wl$libdir' _LT_TAGVAR(export_dynamic_flag_spec, $1)='$wl--export-dynamic' # ancient GNU ld didn't support --whole-archive et. al. if $LD --help 2>&1 | $GREP 'no-whole-archive' > /dev/null; then _LT_TAGVAR(whole_archive_flag_spec, $1)=$wlarc'--whole-archive$convenience '$wlarc'--no-whole-archive' else _LT_TAGVAR(whole_archive_flag_spec, $1)= fi supports_anon_versioning=no case `$LD -v | $SED -e 's/([^)]\+)\s\+//' 2>&1` in *GNU\ gold*) supports_anon_versioning=yes ;; *\ [[01]].* | *\ 2.[[0-9]].* | *\ 2.10.*) ;; # catch versions < 2.11 *\ 2.11.93.0.2\ *) supports_anon_versioning=yes ;; # RH7.3 ... *\ 2.11.92.0.12\ *) supports_anon_versioning=yes ;; # Mandrake 8.2 ... *\ 2.11.*) ;; # other 2.11 versions *) supports_anon_versioning=yes ;; esac # See if GNU ld supports shared libraries. case $host_os in aix[[3-9]]*) # On AIX/PPC, the GNU linker is very broken if test ia64 != "$host_cpu"; then _LT_TAGVAR(ld_shlibs, $1)=no cat <<_LT_EOF 1>&2 *** Warning: the GNU linker, at least up to release 2.19, is reported *** to be unable to reliably create shared libraries on AIX. *** Therefore, libtool is disabling shared libraries support. If you *** really care for shared libraries, you may want to install binutils *** 2.20 or above, or modify your PATH so that a non-GNU linker is found. *** You will then need to restart the configuration process. _LT_EOF fi ;; amigaos*) case $host_cpu in powerpc) # see comment about AmigaOS4 .so support _LT_TAGVAR(archive_cmds, $1)='$CC -shared $libobjs $deplibs $compiler_flags $wl-soname $wl$soname -o $lib' _LT_TAGVAR(archive_expsym_cmds, $1)='' ;; m68k) _LT_TAGVAR(archive_cmds, $1)='$RM $output_objdir/a2ixlibrary.data~$ECHO "#define NAME $libname" > $output_objdir/a2ixlibrary.data~$ECHO "#define LIBRARY_ID 1" >> $output_objdir/a2ixlibrary.data~$ECHO "#define VERSION $major" >> $output_objdir/a2ixlibrary.data~$ECHO "#define REVISION $revision" >> $output_objdir/a2ixlibrary.data~$AR $AR_FLAGS $lib $libobjs~$RANLIB $lib~(cd $output_objdir && a2ixlibrary -32)' _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='-L$libdir' _LT_TAGVAR(hardcode_minus_L, $1)=yes ;; esac ;; beos*) if $LD --help 2>&1 | $GREP ': supported targets:.* elf' > /dev/null; then _LT_TAGVAR(allow_undefined_flag, $1)=unsupported # Joseph Beckenbach says some releases of gcc # support --undefined. This deserves some investigation. FIXME _LT_TAGVAR(archive_cmds, $1)='$CC -nostart $libobjs $deplibs $compiler_flags $wl-soname $wl$soname -o $lib' else _LT_TAGVAR(ld_shlibs, $1)=no fi ;; cygwin* | mingw* | pw32* | cegcc*) # _LT_TAGVAR(hardcode_libdir_flag_spec, $1) is actually meaningless, # as there is no search path for DLLs. _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='-L$libdir' _LT_TAGVAR(export_dynamic_flag_spec, $1)='$wl--export-all-symbols' _LT_TAGVAR(allow_undefined_flag, $1)=unsupported _LT_TAGVAR(always_export_symbols, $1)=no _LT_TAGVAR(enable_shared_with_static_runtimes, $1)=yes _LT_TAGVAR(export_symbols_cmds, $1)='$NM $libobjs $convenience | $global_symbol_pipe | $SED -e '\''/^[[BCDGRS]][[ ]]/s/.*[[ ]]\([[^ ]]*\)/\1 DATA/;s/^.*[[ ]]__nm__\([[^ ]]*\)[[ ]][[^ ]]*/\1 DATA/;/^I[[ ]]/d;/^[[AITW]][[ ]]/s/.* //'\'' | sort | uniq > $export_symbols' _LT_TAGVAR(exclude_expsyms, $1)=['[_]+GLOBAL_OFFSET_TABLE_|[_]+GLOBAL__[FID]_.*|[_]+head_[A-Za-z0-9_]+_dll|[A-Za-z0-9_]+_dll_iname'] if $LD --help 2>&1 | $GREP 'auto-import' > /dev/null; then _LT_TAGVAR(archive_cmds, $1)='$CC -shared $libobjs $deplibs $compiler_flags -o $output_objdir/$soname $wl--enable-auto-image-base -Xlinker --out-implib -Xlinker $lib' # If the export-symbols file already is a .def file, use it as # is; otherwise, prepend EXPORTS... _LT_TAGVAR(archive_expsym_cmds, $1)='if _LT_DLL_DEF_P([$export_symbols]); then cp $export_symbols $output_objdir/$soname.def; else echo EXPORTS > $output_objdir/$soname.def; cat $export_symbols >> $output_objdir/$soname.def; fi~ $CC -shared $output_objdir/$soname.def $libobjs $deplibs $compiler_flags -o $output_objdir/$soname $wl--enable-auto-image-base -Xlinker --out-implib -Xlinker $lib' else _LT_TAGVAR(ld_shlibs, $1)=no fi ;; haiku*) _LT_TAGVAR(archive_cmds, $1)='$CC -shared $libobjs $deplibs $compiler_flags $wl-soname $wl$soname -o $lib' _LT_TAGVAR(link_all_deplibs, $1)=yes ;; os2*) _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='-L$libdir' _LT_TAGVAR(hardcode_minus_L, $1)=yes _LT_TAGVAR(allow_undefined_flag, $1)=unsupported shrext_cmds=.dll _LT_TAGVAR(archive_cmds, $1)='$ECHO "LIBRARY ${soname%$shared_ext} INITINSTANCE TERMINSTANCE" > $output_objdir/$libname.def~ $ECHO "DESCRIPTION \"$libname\"" >> $output_objdir/$libname.def~ $ECHO "DATA MULTIPLE NONSHARED" >> $output_objdir/$libname.def~ $ECHO EXPORTS >> $output_objdir/$libname.def~ emxexp $libobjs | $SED /"_DLL_InitTerm"/d >> $output_objdir/$libname.def~ $CC -Zdll -Zcrtdll -o $output_objdir/$soname $libobjs $deplibs $compiler_flags $output_objdir/$libname.def~ emximp -o $lib $output_objdir/$libname.def' _LT_TAGVAR(archive_expsym_cmds, $1)='$ECHO "LIBRARY ${soname%$shared_ext} INITINSTANCE TERMINSTANCE" > $output_objdir/$libname.def~ $ECHO "DESCRIPTION \"$libname\"" >> $output_objdir/$libname.def~ $ECHO "DATA MULTIPLE NONSHARED" >> $output_objdir/$libname.def~ $ECHO EXPORTS >> $output_objdir/$libname.def~ prefix_cmds="$SED"~ if test EXPORTS = "`$SED 1q $export_symbols`"; then prefix_cmds="$prefix_cmds -e 1d"; fi~ prefix_cmds="$prefix_cmds -e \"s/^\(.*\)$/_\1/g\""~ cat $export_symbols | $prefix_cmds >> $output_objdir/$libname.def~ $CC -Zdll -Zcrtdll -o $output_objdir/$soname $libobjs $deplibs $compiler_flags $output_objdir/$libname.def~ emximp -o $lib $output_objdir/$libname.def' _LT_TAGVAR(old_archive_From_new_cmds, $1)='emximp -o $output_objdir/${libname}_dll.a $output_objdir/$libname.def' _LT_TAGVAR(enable_shared_with_static_runtimes, $1)=yes ;; interix[[3-9]]*) _LT_TAGVAR(hardcode_direct, $1)=no _LT_TAGVAR(hardcode_shlibpath_var, $1)=no _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='$wl-rpath,$libdir' _LT_TAGVAR(export_dynamic_flag_spec, $1)='$wl-E' # Hack: On Interix 3.x, we cannot compile PIC because of a broken gcc. # Instead, shared libraries are loaded at an image base (0x10000000 by # default) and relocated if they conflict, which is a slow very memory # consuming and fragmenting process. To avoid this, we pick a random, # 256 KiB-aligned image base between 0x50000000 and 0x6FFC0000 at link # time. Moving up from 0x10000000 also allows more sbrk(2) space. _LT_TAGVAR(archive_cmds, $1)='$CC -shared $pic_flag $libobjs $deplibs $compiler_flags $wl-h,$soname $wl--image-base,`expr ${RANDOM-$$} % 4096 / 2 \* 262144 + 1342177280` -o $lib' _LT_TAGVAR(archive_expsym_cmds, $1)='sed "s|^|_|" $export_symbols >$output_objdir/$soname.expsym~$CC -shared $pic_flag $libobjs $deplibs $compiler_flags $wl-h,$soname $wl--retain-symbols-file,$output_objdir/$soname.expsym $wl--image-base,`expr ${RANDOM-$$} % 4096 / 2 \* 262144 + 1342177280` -o $lib' ;; gnu* | linux* | tpf* | k*bsd*-gnu | kopensolaris*-gnu) tmp_diet=no if test linux-dietlibc = "$host_os"; then case $cc_basename in diet\ *) tmp_diet=yes;; # linux-dietlibc with static linking (!diet-dyn) esac fi if $LD --help 2>&1 | $EGREP ': supported targets:.* elf' > /dev/null \ && test no = "$tmp_diet" then tmp_addflag=' $pic_flag' tmp_sharedflag='-shared' case $cc_basename,$host_cpu in pgcc*) # Portland Group C compiler _LT_TAGVAR(whole_archive_flag_spec, $1)='$wl--whole-archive`for conv in $convenience\"\"; do test -n \"$conv\" && new_convenience=\"$new_convenience,$conv\"; done; func_echo_all \"$new_convenience\"` $wl--no-whole-archive' tmp_addflag=' $pic_flag' ;; pgf77* | pgf90* | pgf95* | pgfortran*) # Portland Group f77 and f90 compilers _LT_TAGVAR(whole_archive_flag_spec, $1)='$wl--whole-archive`for conv in $convenience\"\"; do test -n \"$conv\" && new_convenience=\"$new_convenience,$conv\"; done; func_echo_all \"$new_convenience\"` $wl--no-whole-archive' tmp_addflag=' $pic_flag -Mnomain' ;; ecc*,ia64* | icc*,ia64*) # Intel C compiler on ia64 tmp_addflag=' -i_dynamic' ;; efc*,ia64* | ifort*,ia64*) # Intel Fortran compiler on ia64 tmp_addflag=' -i_dynamic -nofor_main' ;; ifc* | ifort*) # Intel Fortran compiler tmp_addflag=' -nofor_main' ;; lf95*) # Lahey Fortran 8.1 _LT_TAGVAR(whole_archive_flag_spec, $1)= tmp_sharedflag='--shared' ;; nagfor*) # NAGFOR 5.3 tmp_sharedflag='-Wl,-shared' ;; xl[[cC]]* | bgxl[[cC]]* | mpixl[[cC]]*) # IBM XL C 8.0 on PPC (deal with xlf below) tmp_sharedflag='-qmkshrobj' tmp_addflag= ;; nvcc*) # Cuda Compiler Driver 2.2 _LT_TAGVAR(whole_archive_flag_spec, $1)='$wl--whole-archive`for conv in $convenience\"\"; do test -n \"$conv\" && new_convenience=\"$new_convenience,$conv\"; done; func_echo_all \"$new_convenience\"` $wl--no-whole-archive' _LT_TAGVAR(compiler_needs_object, $1)=yes ;; esac case `$CC -V 2>&1 | sed 5q` in *Sun\ C*) # Sun C 5.9 _LT_TAGVAR(whole_archive_flag_spec, $1)='$wl--whole-archive`new_convenience=; for conv in $convenience\"\"; do test -z \"$conv\" || new_convenience=\"$new_convenience,$conv\"; done; func_echo_all \"$new_convenience\"` $wl--no-whole-archive' _LT_TAGVAR(compiler_needs_object, $1)=yes tmp_sharedflag='-G' ;; *Sun\ F*) # Sun Fortran 8.3 tmp_sharedflag='-G' ;; esac _LT_TAGVAR(archive_cmds, $1)='$CC '"$tmp_sharedflag""$tmp_addflag"' $libobjs $deplibs $compiler_flags $wl-soname $wl$soname -o $lib' if test yes = "$supports_anon_versioning"; then _LT_TAGVAR(archive_expsym_cmds, $1)='echo "{ global:" > $output_objdir/$libname.ver~ cat $export_symbols | sed -e "s/\(.*\)/\1;/" >> $output_objdir/$libname.ver~ echo "local: *; };" >> $output_objdir/$libname.ver~ $CC '"$tmp_sharedflag""$tmp_addflag"' $libobjs $deplibs $compiler_flags $wl-soname $wl$soname $wl-version-script $wl$output_objdir/$libname.ver -o $lib' fi case $cc_basename in tcc*) _LT_TAGVAR(export_dynamic_flag_spec, $1)='-rdynamic' ;; xlf* | bgf* | bgxlf* | mpixlf*) # IBM XL Fortran 10.1 on PPC cannot create shared libs itself _LT_TAGVAR(whole_archive_flag_spec, $1)='--whole-archive$convenience --no-whole-archive' _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='$wl-rpath $wl$libdir' _LT_TAGVAR(archive_cmds, $1)='$LD -shared $libobjs $deplibs $linker_flags -soname $soname -o $lib' if test yes = "$supports_anon_versioning"; then _LT_TAGVAR(archive_expsym_cmds, $1)='echo "{ global:" > $output_objdir/$libname.ver~ cat $export_symbols | sed -e "s/\(.*\)/\1;/" >> $output_objdir/$libname.ver~ echo "local: *; };" >> $output_objdir/$libname.ver~ $LD -shared $libobjs $deplibs $linker_flags -soname $soname -version-script $output_objdir/$libname.ver -o $lib' fi ;; esac else _LT_TAGVAR(ld_shlibs, $1)=no fi ;; netbsd*) if echo __ELF__ | $CC -E - | $GREP __ELF__ >/dev/null; then _LT_TAGVAR(archive_cmds, $1)='$LD -Bshareable $libobjs $deplibs $linker_flags -o $lib' wlarc= else _LT_TAGVAR(archive_cmds, $1)='$CC -shared $pic_flag $libobjs $deplibs $compiler_flags $wl-soname $wl$soname -o $lib' _LT_TAGVAR(archive_expsym_cmds, $1)='$CC -shared $pic_flag $libobjs $deplibs $compiler_flags $wl-soname $wl$soname $wl-retain-symbols-file $wl$export_symbols -o $lib' fi ;; solaris*) if $LD -v 2>&1 | $GREP 'BFD 2\.8' > /dev/null; then _LT_TAGVAR(ld_shlibs, $1)=no cat <<_LT_EOF 1>&2 *** Warning: The releases 2.8.* of the GNU linker cannot reliably *** create shared libraries on Solaris systems. Therefore, libtool *** is disabling shared libraries support. We urge you to upgrade GNU *** binutils to release 2.9.1 or newer. Another option is to modify *** your PATH or compiler configuration so that the native linker is *** used, and then restart. _LT_EOF elif $LD --help 2>&1 | $GREP ': supported targets:.* elf' > /dev/null; then _LT_TAGVAR(archive_cmds, $1)='$CC -shared $pic_flag $libobjs $deplibs $compiler_flags $wl-soname $wl$soname -o $lib' _LT_TAGVAR(archive_expsym_cmds, $1)='$CC -shared $pic_flag $libobjs $deplibs $compiler_flags $wl-soname $wl$soname $wl-retain-symbols-file $wl$export_symbols -o $lib' else _LT_TAGVAR(ld_shlibs, $1)=no fi ;; sysv5* | sco3.2v5* | sco5v6* | unixware* | OpenUNIX*) case `$LD -v 2>&1` in *\ [[01]].* | *\ 2.[[0-9]].* | *\ 2.1[[0-5]].*) _LT_TAGVAR(ld_shlibs, $1)=no cat <<_LT_EOF 1>&2 *** Warning: Releases of the GNU linker prior to 2.16.91.0.3 cannot *** reliably create shared libraries on SCO systems. Therefore, libtool *** is disabling shared libraries support. We urge you to upgrade GNU *** binutils to release 2.16.91.0.3 or newer. Another option is to modify *** your PATH or compiler configuration so that the native linker is *** used, and then restart. _LT_EOF ;; *) # For security reasons, it is highly recommended that you always # use absolute paths for naming shared libraries, and exclude the # DT_RUNPATH tag from executables and libraries. But doing so # requires that you compile everything twice, which is a pain. if $LD --help 2>&1 | $GREP ': supported targets:.* elf' > /dev/null; then _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='$wl-rpath $wl$libdir' _LT_TAGVAR(archive_cmds, $1)='$CC -shared $libobjs $deplibs $compiler_flags $wl-soname $wl$soname -o $lib' _LT_TAGVAR(archive_expsym_cmds, $1)='$CC -shared $libobjs $deplibs $compiler_flags $wl-soname $wl$soname $wl-retain-symbols-file $wl$export_symbols -o $lib' else _LT_TAGVAR(ld_shlibs, $1)=no fi ;; esac ;; sunos4*) _LT_TAGVAR(archive_cmds, $1)='$LD -assert pure-text -Bshareable -o $lib $libobjs $deplibs $linker_flags' wlarc= _LT_TAGVAR(hardcode_direct, $1)=yes _LT_TAGVAR(hardcode_shlibpath_var, $1)=no ;; *) if $LD --help 2>&1 | $GREP ': supported targets:.* elf' > /dev/null; then _LT_TAGVAR(archive_cmds, $1)='$CC -shared $pic_flag $libobjs $deplibs $compiler_flags $wl-soname $wl$soname -o $lib' _LT_TAGVAR(archive_expsym_cmds, $1)='$CC -shared $pic_flag $libobjs $deplibs $compiler_flags $wl-soname $wl$soname $wl-retain-symbols-file $wl$export_symbols -o $lib' else _LT_TAGVAR(ld_shlibs, $1)=no fi ;; esac if test no = "$_LT_TAGVAR(ld_shlibs, $1)"; then runpath_var= _LT_TAGVAR(hardcode_libdir_flag_spec, $1)= _LT_TAGVAR(export_dynamic_flag_spec, $1)= _LT_TAGVAR(whole_archive_flag_spec, $1)= fi else # PORTME fill in a description of your system's linker (not GNU ld) case $host_os in aix3*) _LT_TAGVAR(allow_undefined_flag, $1)=unsupported _LT_TAGVAR(always_export_symbols, $1)=yes _LT_TAGVAR(archive_expsym_cmds, $1)='$LD -o $output_objdir/$soname $libobjs $deplibs $linker_flags -bE:$export_symbols -T512 -H512 -bM:SRE~$AR $AR_FLAGS $lib $output_objdir/$soname' # Note: this linker hardcodes the directories in LIBPATH if there # are no directories specified by -L. _LT_TAGVAR(hardcode_minus_L, $1)=yes if test yes = "$GCC" && test -z "$lt_prog_compiler_static"; then # Neither direct hardcoding nor static linking is supported with a # broken collect2. _LT_TAGVAR(hardcode_direct, $1)=unsupported fi ;; aix[[4-9]]*) if test ia64 = "$host_cpu"; then # On IA64, the linker does run time linking by default, so we don't # have to do anything special. aix_use_runtimelinking=no exp_sym_flag='-Bexport' no_entry_flag= else # If we're using GNU nm, then we don't want the "-C" option. # -C means demangle to GNU nm, but means don't demangle to AIX nm. # Without the "-l" option, or with the "-B" option, AIX nm treats # weak defined symbols like other global defined symbols, whereas # GNU nm marks them as "W". # While the 'weak' keyword is ignored in the Export File, we need # it in the Import File for the 'aix-soname' feature, so we have # to replace the "-B" option with "-P" for AIX nm. if $NM -V 2>&1 | $GREP 'GNU' > /dev/null; then _LT_TAGVAR(export_symbols_cmds, $1)='$NM -Bpg $libobjs $convenience | awk '\''{ if (((\$ 2 == "T") || (\$ 2 == "D") || (\$ 2 == "B") || (\$ 2 == "W")) && ([substr](\$ 3,1,1) != ".")) { if (\$ 2 == "W") { print \$ 3 " weak" } else { print \$ 3 } } }'\'' | sort -u > $export_symbols' else _LT_TAGVAR(export_symbols_cmds, $1)='`func_echo_all $NM | $SED -e '\''s/B\([[^B]]*\)$/P\1/'\''` -PCpgl $libobjs $convenience | awk '\''{ if (((\$ 2 == "T") || (\$ 2 == "D") || (\$ 2 == "B") || (\$ 2 == "W") || (\$ 2 == "V") || (\$ 2 == "Z")) && ([substr](\$ 1,1,1) != ".")) { if ((\$ 2 == "W") || (\$ 2 == "V") || (\$ 2 == "Z")) { print \$ 1 " weak" } else { print \$ 1 } } }'\'' | sort -u > $export_symbols' fi aix_use_runtimelinking=no # Test if we are trying to use run time linking or normal # AIX style linking. If -brtl is somewhere in LDFLAGS, we # have runtime linking enabled, and use it for executables. # For shared libraries, we enable/disable runtime linking # depending on the kind of the shared library created - # when "with_aix_soname,aix_use_runtimelinking" is: # "aix,no" lib.a(lib.so.V) shared, rtl:no, for executables # "aix,yes" lib.so shared, rtl:yes, for executables # lib.a static archive # "both,no" lib.so.V(shr.o) shared, rtl:yes # lib.a(lib.so.V) shared, rtl:no, for executables # "both,yes" lib.so.V(shr.o) shared, rtl:yes, for executables # lib.a(lib.so.V) shared, rtl:no # "svr4,*" lib.so.V(shr.o) shared, rtl:yes, for executables # lib.a static archive case $host_os in aix4.[[23]]|aix4.[[23]].*|aix[[5-9]]*) for ld_flag in $LDFLAGS; do if (test x-brtl = "x$ld_flag" || test x-Wl,-brtl = "x$ld_flag"); then aix_use_runtimelinking=yes break fi done if test svr4,no = "$with_aix_soname,$aix_use_runtimelinking"; then # With aix-soname=svr4, we create the lib.so.V shared archives only, # so we don't have lib.a shared libs to link our executables. # We have to force runtime linking in this case. aix_use_runtimelinking=yes LDFLAGS="$LDFLAGS -Wl,-brtl" fi ;; esac exp_sym_flag='-bexport' no_entry_flag='-bnoentry' fi # When large executables or shared objects are built, AIX ld can # have problems creating the table of contents. If linking a library # or program results in "error TOC overflow" add -mminimal-toc to # CXXFLAGS/CFLAGS for g++/gcc. In the cases where that is not # enough to fix the problem, add -Wl,-bbigtoc to LDFLAGS. _LT_TAGVAR(archive_cmds, $1)='' _LT_TAGVAR(hardcode_direct, $1)=yes _LT_TAGVAR(hardcode_direct_absolute, $1)=yes _LT_TAGVAR(hardcode_libdir_separator, $1)=':' _LT_TAGVAR(link_all_deplibs, $1)=yes _LT_TAGVAR(file_list_spec, $1)='$wl-f,' case $with_aix_soname,$aix_use_runtimelinking in aix,*) ;; # traditional, no import file svr4,* | *,yes) # use import file # The Import File defines what to hardcode. _LT_TAGVAR(hardcode_direct, $1)=no _LT_TAGVAR(hardcode_direct_absolute, $1)=no ;; esac if test yes = "$GCC"; then case $host_os in aix4.[[012]]|aix4.[[012]].*) # We only want to do this on AIX 4.2 and lower, the check # below for broken collect2 doesn't work under 4.3+ collect2name=`$CC -print-prog-name=collect2` if test -f "$collect2name" && strings "$collect2name" | $GREP resolve_lib_name >/dev/null then # We have reworked collect2 : else # We have old collect2 _LT_TAGVAR(hardcode_direct, $1)=unsupported # It fails to find uninstalled libraries when the uninstalled # path is not listed in the libpath. Setting hardcode_minus_L # to unsupported forces relinking _LT_TAGVAR(hardcode_minus_L, $1)=yes _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='-L$libdir' _LT_TAGVAR(hardcode_libdir_separator, $1)= fi ;; esac shared_flag='-shared' if test yes = "$aix_use_runtimelinking"; then shared_flag="$shared_flag "'$wl-G' fi # Need to ensure runtime linking is disabled for the traditional # shared library, or the linker may eventually find shared libraries # /with/ Import File - we do not want to mix them. shared_flag_aix='-shared' shared_flag_svr4='-shared $wl-G' else # not using gcc if test ia64 = "$host_cpu"; then # VisualAge C++, Version 5.5 for AIX 5L for IA-64, Beta 3 Release # chokes on -Wl,-G. The following line is correct: shared_flag='-G' else if test yes = "$aix_use_runtimelinking"; then shared_flag='$wl-G' else shared_flag='$wl-bM:SRE' fi shared_flag_aix='$wl-bM:SRE' shared_flag_svr4='$wl-G' fi fi _LT_TAGVAR(export_dynamic_flag_spec, $1)='$wl-bexpall' # It seems that -bexpall does not export symbols beginning with # underscore (_), so it is better to generate a list of symbols to export. _LT_TAGVAR(always_export_symbols, $1)=yes if test aix,yes = "$with_aix_soname,$aix_use_runtimelinking"; then # Warning - without using the other runtime loading flags (-brtl), # -berok will link without error, but may produce a broken library. _LT_TAGVAR(allow_undefined_flag, $1)='-berok' # Determine the default libpath from the value encoded in an # empty executable. _LT_SYS_MODULE_PATH_AIX([$1]) _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='$wl-blibpath:$libdir:'"$aix_libpath" _LT_TAGVAR(archive_expsym_cmds, $1)='$CC -o $output_objdir/$soname $libobjs $deplibs $wl'$no_entry_flag' $compiler_flags `if test -n "$allow_undefined_flag"; then func_echo_all "$wl$allow_undefined_flag"; else :; fi` $wl'$exp_sym_flag:\$export_symbols' '$shared_flag else if test ia64 = "$host_cpu"; then _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='$wl-R $libdir:/usr/lib:/lib' _LT_TAGVAR(allow_undefined_flag, $1)="-z nodefs" _LT_TAGVAR(archive_expsym_cmds, $1)="\$CC $shared_flag"' -o $output_objdir/$soname $libobjs $deplibs '"\$wl$no_entry_flag"' $compiler_flags $wl$allow_undefined_flag '"\$wl$exp_sym_flag:\$export_symbols" else # Determine the default libpath from the value encoded in an # empty executable. _LT_SYS_MODULE_PATH_AIX([$1]) _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='$wl-blibpath:$libdir:'"$aix_libpath" # Warning - without using the other run time loading flags, # -berok will link without error, but may produce a broken library. _LT_TAGVAR(no_undefined_flag, $1)=' $wl-bernotok' _LT_TAGVAR(allow_undefined_flag, $1)=' $wl-berok' if test yes = "$with_gnu_ld"; then # We only use this code for GNU lds that support --whole-archive. _LT_TAGVAR(whole_archive_flag_spec, $1)='$wl--whole-archive$convenience $wl--no-whole-archive' else # Exported symbols can be pulled into shared objects from archives _LT_TAGVAR(whole_archive_flag_spec, $1)='$convenience' fi _LT_TAGVAR(archive_cmds_need_lc, $1)=yes _LT_TAGVAR(archive_expsym_cmds, $1)='$RM -r $output_objdir/$realname.d~$MKDIR $output_objdir/$realname.d' # -brtl affects multiple linker settings, -berok does not and is overridden later compiler_flags_filtered='`func_echo_all "$compiler_flags " | $SED -e "s%-brtl\\([[, ]]\\)%-berok\\1%g"`' if test svr4 != "$with_aix_soname"; then # This is similar to how AIX traditionally builds its shared libraries. _LT_TAGVAR(archive_expsym_cmds, $1)="$_LT_TAGVAR(archive_expsym_cmds, $1)"'~$CC '$shared_flag_aix' -o $output_objdir/$realname.d/$soname $libobjs $deplibs $wl-bnoentry '$compiler_flags_filtered'$wl-bE:$export_symbols$allow_undefined_flag~$AR $AR_FLAGS $output_objdir/$libname$release.a $output_objdir/$realname.d/$soname' fi if test aix != "$with_aix_soname"; then _LT_TAGVAR(archive_expsym_cmds, $1)="$_LT_TAGVAR(archive_expsym_cmds, $1)"'~$CC '$shared_flag_svr4' -o $output_objdir/$realname.d/$shared_archive_member_spec.o $libobjs $deplibs $wl-bnoentry '$compiler_flags_filtered'$wl-bE:$export_symbols$allow_undefined_flag~$STRIP -e $output_objdir/$realname.d/$shared_archive_member_spec.o~( func_echo_all "#! $soname($shared_archive_member_spec.o)"; if test shr_64 = "$shared_archive_member_spec"; then func_echo_all "# 64"; else func_echo_all "# 32"; fi; cat $export_symbols ) > $output_objdir/$realname.d/$shared_archive_member_spec.imp~$AR $AR_FLAGS $output_objdir/$soname $output_objdir/$realname.d/$shared_archive_member_spec.o $output_objdir/$realname.d/$shared_archive_member_spec.imp' else # used by -dlpreopen to get the symbols _LT_TAGVAR(archive_expsym_cmds, $1)="$_LT_TAGVAR(archive_expsym_cmds, $1)"'~$MV $output_objdir/$realname.d/$soname $output_objdir' fi _LT_TAGVAR(archive_expsym_cmds, $1)="$_LT_TAGVAR(archive_expsym_cmds, $1)"'~$RM -r $output_objdir/$realname.d' fi fi ;; amigaos*) case $host_cpu in powerpc) # see comment about AmigaOS4 .so support _LT_TAGVAR(archive_cmds, $1)='$CC -shared $libobjs $deplibs $compiler_flags $wl-soname $wl$soname -o $lib' _LT_TAGVAR(archive_expsym_cmds, $1)='' ;; m68k) _LT_TAGVAR(archive_cmds, $1)='$RM $output_objdir/a2ixlibrary.data~$ECHO "#define NAME $libname" > $output_objdir/a2ixlibrary.data~$ECHO "#define LIBRARY_ID 1" >> $output_objdir/a2ixlibrary.data~$ECHO "#define VERSION $major" >> $output_objdir/a2ixlibrary.data~$ECHO "#define REVISION $revision" >> $output_objdir/a2ixlibrary.data~$AR $AR_FLAGS $lib $libobjs~$RANLIB $lib~(cd $output_objdir && a2ixlibrary -32)' _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='-L$libdir' _LT_TAGVAR(hardcode_minus_L, $1)=yes ;; esac ;; bsdi[[45]]*) _LT_TAGVAR(export_dynamic_flag_spec, $1)=-rdynamic ;; cygwin* | mingw* | pw32* | cegcc*) # When not using gcc, we currently assume that we are using # Microsoft Visual C++. # hardcode_libdir_flag_spec is actually meaningless, as there is # no search path for DLLs. case $cc_basename in cl*) # Native MSVC _LT_TAGVAR(hardcode_libdir_flag_spec, $1)=' ' _LT_TAGVAR(allow_undefined_flag, $1)=unsupported _LT_TAGVAR(always_export_symbols, $1)=yes _LT_TAGVAR(file_list_spec, $1)='@' # Tell ltmain to make .lib files, not .a files. libext=lib # Tell ltmain to make .dll files, not .so files. shrext_cmds=.dll # FIXME: Setting linknames here is a bad hack. _LT_TAGVAR(archive_cmds, $1)='$CC -o $output_objdir/$soname $libobjs $compiler_flags $deplibs -Wl,-DLL,-IMPLIB:"$tool_output_objdir$libname.dll.lib"~linknames=' _LT_TAGVAR(archive_expsym_cmds, $1)='if _LT_DLL_DEF_P([$export_symbols]); then cp "$export_symbols" "$output_objdir/$soname.def"; echo "$tool_output_objdir$soname.def" > "$output_objdir/$soname.exp"; else $SED -e '\''s/^/-link -EXPORT:/'\'' < $export_symbols > $output_objdir/$soname.exp; fi~ $CC -o $tool_output_objdir$soname $libobjs $compiler_flags $deplibs "@$tool_output_objdir$soname.exp" -Wl,-DLL,-IMPLIB:"$tool_output_objdir$libname.dll.lib"~ linknames=' # The linker will not automatically build a static lib if we build a DLL. # _LT_TAGVAR(old_archive_from_new_cmds, $1)='true' _LT_TAGVAR(enable_shared_with_static_runtimes, $1)=yes _LT_TAGVAR(exclude_expsyms, $1)='_NULL_IMPORT_DESCRIPTOR|_IMPORT_DESCRIPTOR_.*' _LT_TAGVAR(export_symbols_cmds, $1)='$NM $libobjs $convenience | $global_symbol_pipe | $SED -e '\''/^[[BCDGRS]][[ ]]/s/.*[[ ]]\([[^ ]]*\)/\1,DATA/'\'' | $SED -e '\''/^[[AITW]][[ ]]/s/.*[[ ]]//'\'' | sort | uniq > $export_symbols' # Don't use ranlib _LT_TAGVAR(old_postinstall_cmds, $1)='chmod 644 $oldlib' _LT_TAGVAR(postlink_cmds, $1)='lt_outputfile="@OUTPUT@"~ lt_tool_outputfile="@TOOL_OUTPUT@"~ case $lt_outputfile in *.exe|*.EXE) ;; *) lt_outputfile=$lt_outputfile.exe lt_tool_outputfile=$lt_tool_outputfile.exe ;; esac~ if test : != "$MANIFEST_TOOL" && test -f "$lt_outputfile.manifest"; then $MANIFEST_TOOL -manifest "$lt_tool_outputfile.manifest" -outputresource:"$lt_tool_outputfile" || exit 1; $RM "$lt_outputfile.manifest"; fi' ;; *) # Assume MSVC wrapper _LT_TAGVAR(hardcode_libdir_flag_spec, $1)=' ' _LT_TAGVAR(allow_undefined_flag, $1)=unsupported # Tell ltmain to make .lib files, not .a files. libext=lib # Tell ltmain to make .dll files, not .so files. shrext_cmds=.dll # FIXME: Setting linknames here is a bad hack. _LT_TAGVAR(archive_cmds, $1)='$CC -o $lib $libobjs $compiler_flags `func_echo_all "$deplibs" | $SED '\''s/ -lc$//'\''` -link -dll~linknames=' # The linker will automatically build a .lib file if we build a DLL. _LT_TAGVAR(old_archive_from_new_cmds, $1)='true' # FIXME: Should let the user specify the lib program. _LT_TAGVAR(old_archive_cmds, $1)='lib -OUT:$oldlib$oldobjs$old_deplibs' _LT_TAGVAR(enable_shared_with_static_runtimes, $1)=yes ;; esac ;; darwin* | rhapsody*) _LT_DARWIN_LINKER_FEATURES($1) ;; dgux*) _LT_TAGVAR(archive_cmds, $1)='$LD -G -h $soname -o $lib $libobjs $deplibs $linker_flags' _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='-L$libdir' _LT_TAGVAR(hardcode_shlibpath_var, $1)=no ;; # FreeBSD 2.2.[012] allows us to include c++rt0.o to get C++ constructor # support. Future versions do this automatically, but an explicit c++rt0.o # does not break anything, and helps significantly (at the cost of a little # extra space). freebsd2.2*) _LT_TAGVAR(archive_cmds, $1)='$LD -Bshareable -o $lib $libobjs $deplibs $linker_flags /usr/lib/c++rt0.o' _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='-R$libdir' _LT_TAGVAR(hardcode_direct, $1)=yes _LT_TAGVAR(hardcode_shlibpath_var, $1)=no ;; # Unfortunately, older versions of FreeBSD 2 do not have this feature. freebsd2.*) _LT_TAGVAR(archive_cmds, $1)='$LD -Bshareable -o $lib $libobjs $deplibs $linker_flags' _LT_TAGVAR(hardcode_direct, $1)=yes _LT_TAGVAR(hardcode_minus_L, $1)=yes _LT_TAGVAR(hardcode_shlibpath_var, $1)=no ;; # FreeBSD 3 and greater uses gcc -shared to do shared libraries. freebsd* | dragonfly*) _LT_TAGVAR(archive_cmds, $1)='$CC -shared $pic_flag -o $lib $libobjs $deplibs $compiler_flags' _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='-R$libdir' _LT_TAGVAR(hardcode_direct, $1)=yes _LT_TAGVAR(hardcode_shlibpath_var, $1)=no ;; hpux9*) if test yes = "$GCC"; then _LT_TAGVAR(archive_cmds, $1)='$RM $output_objdir/$soname~$CC -shared $pic_flag $wl+b $wl$install_libdir -o $output_objdir/$soname $libobjs $deplibs $compiler_flags~test "x$output_objdir/$soname" = "x$lib" || mv $output_objdir/$soname $lib' else _LT_TAGVAR(archive_cmds, $1)='$RM $output_objdir/$soname~$LD -b +b $install_libdir -o $output_objdir/$soname $libobjs $deplibs $linker_flags~test "x$output_objdir/$soname" = "x$lib" || mv $output_objdir/$soname $lib' fi _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='$wl+b $wl$libdir' _LT_TAGVAR(hardcode_libdir_separator, $1)=: _LT_TAGVAR(hardcode_direct, $1)=yes # hardcode_minus_L: Not really in the search PATH, # but as the default location of the library. _LT_TAGVAR(hardcode_minus_L, $1)=yes _LT_TAGVAR(export_dynamic_flag_spec, $1)='$wl-E' ;; hpux10*) if test yes,no = "$GCC,$with_gnu_ld"; then _LT_TAGVAR(archive_cmds, $1)='$CC -shared $pic_flag $wl+h $wl$soname $wl+b $wl$install_libdir -o $lib $libobjs $deplibs $compiler_flags' else _LT_TAGVAR(archive_cmds, $1)='$LD -b +h $soname +b $install_libdir -o $lib $libobjs $deplibs $linker_flags' fi if test no = "$with_gnu_ld"; then _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='$wl+b $wl$libdir' _LT_TAGVAR(hardcode_libdir_separator, $1)=: _LT_TAGVAR(hardcode_direct, $1)=yes _LT_TAGVAR(hardcode_direct_absolute, $1)=yes _LT_TAGVAR(export_dynamic_flag_spec, $1)='$wl-E' # hardcode_minus_L: Not really in the search PATH, # but as the default location of the library. _LT_TAGVAR(hardcode_minus_L, $1)=yes fi ;; hpux11*) if test yes,no = "$GCC,$with_gnu_ld"; then case $host_cpu in hppa*64*) _LT_TAGVAR(archive_cmds, $1)='$CC -shared $wl+h $wl$soname -o $lib $libobjs $deplibs $compiler_flags' ;; ia64*) _LT_TAGVAR(archive_cmds, $1)='$CC -shared $pic_flag $wl+h $wl$soname $wl+nodefaultrpath -o $lib $libobjs $deplibs $compiler_flags' ;; *) _LT_TAGVAR(archive_cmds, $1)='$CC -shared $pic_flag $wl+h $wl$soname $wl+b $wl$install_libdir -o $lib $libobjs $deplibs $compiler_flags' ;; esac else case $host_cpu in hppa*64*) _LT_TAGVAR(archive_cmds, $1)='$CC -b $wl+h $wl$soname -o $lib $libobjs $deplibs $compiler_flags' ;; ia64*) _LT_TAGVAR(archive_cmds, $1)='$CC -b $wl+h $wl$soname $wl+nodefaultrpath -o $lib $libobjs $deplibs $compiler_flags' ;; *) m4_if($1, [], [ # Older versions of the 11.00 compiler do not understand -b yet # (HP92453-01 A.11.01.20 doesn't, HP92453-01 B.11.X.35175-35176.GP does) _LT_LINKER_OPTION([if $CC understands -b], _LT_TAGVAR(lt_cv_prog_compiler__b, $1), [-b], [_LT_TAGVAR(archive_cmds, $1)='$CC -b $wl+h $wl$soname $wl+b $wl$install_libdir -o $lib $libobjs $deplibs $compiler_flags'], [_LT_TAGVAR(archive_cmds, $1)='$LD -b +h $soname +b $install_libdir -o $lib $libobjs $deplibs $linker_flags'])], [_LT_TAGVAR(archive_cmds, $1)='$CC -b $wl+h $wl$soname $wl+b $wl$install_libdir -o $lib $libobjs $deplibs $compiler_flags']) ;; esac fi if test no = "$with_gnu_ld"; then _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='$wl+b $wl$libdir' _LT_TAGVAR(hardcode_libdir_separator, $1)=: case $host_cpu in hppa*64*|ia64*) _LT_TAGVAR(hardcode_direct, $1)=no _LT_TAGVAR(hardcode_shlibpath_var, $1)=no ;; *) _LT_TAGVAR(hardcode_direct, $1)=yes _LT_TAGVAR(hardcode_direct_absolute, $1)=yes _LT_TAGVAR(export_dynamic_flag_spec, $1)='$wl-E' # hardcode_minus_L: Not really in the search PATH, # but as the default location of the library. _LT_TAGVAR(hardcode_minus_L, $1)=yes ;; esac fi ;; irix5* | irix6* | nonstopux*) if test yes = "$GCC"; then _LT_TAGVAR(archive_cmds, $1)='$CC -shared $pic_flag $libobjs $deplibs $compiler_flags $wl-soname $wl$soname `test -n "$verstring" && func_echo_all "$wl-set_version $wl$verstring"` $wl-update_registry $wl$output_objdir/so_locations -o $lib' # Try to use the -exported_symbol ld option, if it does not # work, assume that -exports_file does not work either and # implicitly export all symbols. # This should be the same for all languages, so no per-tag cache variable. AC_CACHE_CHECK([whether the $host_os linker accepts -exported_symbol], [lt_cv_irix_exported_symbol], [save_LDFLAGS=$LDFLAGS LDFLAGS="$LDFLAGS -shared $wl-exported_symbol ${wl}foo $wl-update_registry $wl/dev/null" AC_LINK_IFELSE( [AC_LANG_SOURCE( [AC_LANG_CASE([C], [[int foo (void) { return 0; }]], [C++], [[int foo (void) { return 0; }]], [Fortran 77], [[ subroutine foo end]], [Fortran], [[ subroutine foo end]])])], [lt_cv_irix_exported_symbol=yes], [lt_cv_irix_exported_symbol=no]) LDFLAGS=$save_LDFLAGS]) if test yes = "$lt_cv_irix_exported_symbol"; then _LT_TAGVAR(archive_expsym_cmds, $1)='$CC -shared $pic_flag $libobjs $deplibs $compiler_flags $wl-soname $wl$soname `test -n "$verstring" && func_echo_all "$wl-set_version $wl$verstring"` $wl-update_registry $wl$output_objdir/so_locations $wl-exports_file $wl$export_symbols -o $lib' fi else _LT_TAGVAR(archive_cmds, $1)='$CC -shared $libobjs $deplibs $compiler_flags -soname $soname `test -n "$verstring" && func_echo_all "-set_version $verstring"` -update_registry $output_objdir/so_locations -o $lib' _LT_TAGVAR(archive_expsym_cmds, $1)='$CC -shared $libobjs $deplibs $compiler_flags -soname $soname `test -n "$verstring" && func_echo_all "-set_version $verstring"` -update_registry $output_objdir/so_locations -exports_file $export_symbols -o $lib' fi _LT_TAGVAR(archive_cmds_need_lc, $1)='no' _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='$wl-rpath $wl$libdir' _LT_TAGVAR(hardcode_libdir_separator, $1)=: _LT_TAGVAR(inherit_rpath, $1)=yes _LT_TAGVAR(link_all_deplibs, $1)=yes ;; linux*) case $cc_basename in tcc*) # Fabrice Bellard et al's Tiny C Compiler _LT_TAGVAR(ld_shlibs, $1)=yes _LT_TAGVAR(archive_cmds, $1)='$CC -shared $pic_flag -o $lib $libobjs $deplibs $compiler_flags' ;; esac ;; netbsd*) if echo __ELF__ | $CC -E - | $GREP __ELF__ >/dev/null; then _LT_TAGVAR(archive_cmds, $1)='$LD -Bshareable -o $lib $libobjs $deplibs $linker_flags' # a.out else _LT_TAGVAR(archive_cmds, $1)='$LD -shared -o $lib $libobjs $deplibs $linker_flags' # ELF fi _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='-R$libdir' _LT_TAGVAR(hardcode_direct, $1)=yes _LT_TAGVAR(hardcode_shlibpath_var, $1)=no ;; newsos6) _LT_TAGVAR(archive_cmds, $1)='$LD -G -h $soname -o $lib $libobjs $deplibs $linker_flags' _LT_TAGVAR(hardcode_direct, $1)=yes _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='$wl-rpath $wl$libdir' _LT_TAGVAR(hardcode_libdir_separator, $1)=: _LT_TAGVAR(hardcode_shlibpath_var, $1)=no ;; *nto* | *qnx*) ;; openbsd* | bitrig*) if test -f /usr/libexec/ld.so; then _LT_TAGVAR(hardcode_direct, $1)=yes _LT_TAGVAR(hardcode_shlibpath_var, $1)=no _LT_TAGVAR(hardcode_direct_absolute, $1)=yes if test -z "`echo __ELF__ | $CC -E - | $GREP __ELF__`"; then _LT_TAGVAR(archive_cmds, $1)='$CC -shared $pic_flag -o $lib $libobjs $deplibs $compiler_flags' _LT_TAGVAR(archive_expsym_cmds, $1)='$CC -shared $pic_flag -o $lib $libobjs $deplibs $compiler_flags $wl-retain-symbols-file,$export_symbols' _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='$wl-rpath,$libdir' _LT_TAGVAR(export_dynamic_flag_spec, $1)='$wl-E' else _LT_TAGVAR(archive_cmds, $1)='$CC -shared $pic_flag -o $lib $libobjs $deplibs $compiler_flags' _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='$wl-rpath,$libdir' fi else _LT_TAGVAR(ld_shlibs, $1)=no fi ;; os2*) _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='-L$libdir' _LT_TAGVAR(hardcode_minus_L, $1)=yes _LT_TAGVAR(allow_undefined_flag, $1)=unsupported shrext_cmds=.dll _LT_TAGVAR(archive_cmds, $1)='$ECHO "LIBRARY ${soname%$shared_ext} INITINSTANCE TERMINSTANCE" > $output_objdir/$libname.def~ $ECHO "DESCRIPTION \"$libname\"" >> $output_objdir/$libname.def~ $ECHO "DATA MULTIPLE NONSHARED" >> $output_objdir/$libname.def~ $ECHO EXPORTS >> $output_objdir/$libname.def~ emxexp $libobjs | $SED /"_DLL_InitTerm"/d >> $output_objdir/$libname.def~ $CC -Zdll -Zcrtdll -o $output_objdir/$soname $libobjs $deplibs $compiler_flags $output_objdir/$libname.def~ emximp -o $lib $output_objdir/$libname.def' _LT_TAGVAR(archive_expsym_cmds, $1)='$ECHO "LIBRARY ${soname%$shared_ext} INITINSTANCE TERMINSTANCE" > $output_objdir/$libname.def~ $ECHO "DESCRIPTION \"$libname\"" >> $output_objdir/$libname.def~ $ECHO "DATA MULTIPLE NONSHARED" >> $output_objdir/$libname.def~ $ECHO EXPORTS >> $output_objdir/$libname.def~ prefix_cmds="$SED"~ if test EXPORTS = "`$SED 1q $export_symbols`"; then prefix_cmds="$prefix_cmds -e 1d"; fi~ prefix_cmds="$prefix_cmds -e \"s/^\(.*\)$/_\1/g\""~ cat $export_symbols | $prefix_cmds >> $output_objdir/$libname.def~ $CC -Zdll -Zcrtdll -o $output_objdir/$soname $libobjs $deplibs $compiler_flags $output_objdir/$libname.def~ emximp -o $lib $output_objdir/$libname.def' _LT_TAGVAR(old_archive_From_new_cmds, $1)='emximp -o $output_objdir/${libname}_dll.a $output_objdir/$libname.def' _LT_TAGVAR(enable_shared_with_static_runtimes, $1)=yes ;; osf3*) if test yes = "$GCC"; then _LT_TAGVAR(allow_undefined_flag, $1)=' $wl-expect_unresolved $wl\*' _LT_TAGVAR(archive_cmds, $1)='$CC -shared$allow_undefined_flag $libobjs $deplibs $compiler_flags $wl-soname $wl$soname `test -n "$verstring" && func_echo_all "$wl-set_version $wl$verstring"` $wl-update_registry $wl$output_objdir/so_locations -o $lib' else _LT_TAGVAR(allow_undefined_flag, $1)=' -expect_unresolved \*' _LT_TAGVAR(archive_cmds, $1)='$CC -shared$allow_undefined_flag $libobjs $deplibs $compiler_flags -soname $soname `test -n "$verstring" && func_echo_all "-set_version $verstring"` -update_registry $output_objdir/so_locations -o $lib' fi _LT_TAGVAR(archive_cmds_need_lc, $1)='no' _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='$wl-rpath $wl$libdir' _LT_TAGVAR(hardcode_libdir_separator, $1)=: ;; osf4* | osf5*) # as osf3* with the addition of -msym flag if test yes = "$GCC"; then _LT_TAGVAR(allow_undefined_flag, $1)=' $wl-expect_unresolved $wl\*' _LT_TAGVAR(archive_cmds, $1)='$CC -shared$allow_undefined_flag $pic_flag $libobjs $deplibs $compiler_flags $wl-msym $wl-soname $wl$soname `test -n "$verstring" && func_echo_all "$wl-set_version $wl$verstring"` $wl-update_registry $wl$output_objdir/so_locations -o $lib' _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='$wl-rpath $wl$libdir' else _LT_TAGVAR(allow_undefined_flag, $1)=' -expect_unresolved \*' _LT_TAGVAR(archive_cmds, $1)='$CC -shared$allow_undefined_flag $libobjs $deplibs $compiler_flags -msym -soname $soname `test -n "$verstring" && func_echo_all "-set_version $verstring"` -update_registry $output_objdir/so_locations -o $lib' _LT_TAGVAR(archive_expsym_cmds, $1)='for i in `cat $export_symbols`; do printf "%s %s\\n" -exported_symbol "\$i" >> $lib.exp; done; printf "%s\\n" "-hidden">> $lib.exp~ $CC -shared$allow_undefined_flag $wl-input $wl$lib.exp $compiler_flags $libobjs $deplibs -soname $soname `test -n "$verstring" && $ECHO "-set_version $verstring"` -update_registry $output_objdir/so_locations -o $lib~$RM $lib.exp' # Both c and cxx compiler support -rpath directly _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='-rpath $libdir' fi _LT_TAGVAR(archive_cmds_need_lc, $1)='no' _LT_TAGVAR(hardcode_libdir_separator, $1)=: ;; solaris*) _LT_TAGVAR(no_undefined_flag, $1)=' -z defs' if test yes = "$GCC"; then wlarc='$wl' _LT_TAGVAR(archive_cmds, $1)='$CC -shared $pic_flag $wl-z ${wl}text $wl-h $wl$soname -o $lib $libobjs $deplibs $compiler_flags' _LT_TAGVAR(archive_expsym_cmds, $1)='echo "{ global:" > $lib.exp~cat $export_symbols | $SED -e "s/\(.*\)/\1;/" >> $lib.exp~echo "local: *; };" >> $lib.exp~ $CC -shared $pic_flag $wl-z ${wl}text $wl-M $wl$lib.exp $wl-h $wl$soname -o $lib $libobjs $deplibs $compiler_flags~$RM $lib.exp' else case `$CC -V 2>&1` in *"Compilers 5.0"*) wlarc='' _LT_TAGVAR(archive_cmds, $1)='$LD -G$allow_undefined_flag -h $soname -o $lib $libobjs $deplibs $linker_flags' _LT_TAGVAR(archive_expsym_cmds, $1)='echo "{ global:" > $lib.exp~cat $export_symbols | $SED -e "s/\(.*\)/\1;/" >> $lib.exp~echo "local: *; };" >> $lib.exp~ $LD -G$allow_undefined_flag -M $lib.exp -h $soname -o $lib $libobjs $deplibs $linker_flags~$RM $lib.exp' ;; *) wlarc='$wl' _LT_TAGVAR(archive_cmds, $1)='$CC -G$allow_undefined_flag -h $soname -o $lib $libobjs $deplibs $compiler_flags' _LT_TAGVAR(archive_expsym_cmds, $1)='echo "{ global:" > $lib.exp~cat $export_symbols | $SED -e "s/\(.*\)/\1;/" >> $lib.exp~echo "local: *; };" >> $lib.exp~ $CC -G$allow_undefined_flag -M $lib.exp -h $soname -o $lib $libobjs $deplibs $compiler_flags~$RM $lib.exp' ;; esac fi _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='-R$libdir' _LT_TAGVAR(hardcode_shlibpath_var, $1)=no case $host_os in solaris2.[[0-5]] | solaris2.[[0-5]].*) ;; *) # The compiler driver will combine and reorder linker options, # but understands '-z linker_flag'. GCC discards it without '$wl', # but is careful enough not to reorder. # Supported since Solaris 2.6 (maybe 2.5.1?) if test yes = "$GCC"; then _LT_TAGVAR(whole_archive_flag_spec, $1)='$wl-z ${wl}allextract$convenience $wl-z ${wl}defaultextract' else _LT_TAGVAR(whole_archive_flag_spec, $1)='-z allextract$convenience -z defaultextract' fi ;; esac _LT_TAGVAR(link_all_deplibs, $1)=yes ;; sunos4*) if test sequent = "$host_vendor"; then # Use $CC to link under sequent, because it throws in some extra .o # files that make .init and .fini sections work. _LT_TAGVAR(archive_cmds, $1)='$CC -G $wl-h $soname -o $lib $libobjs $deplibs $compiler_flags' else _LT_TAGVAR(archive_cmds, $1)='$LD -assert pure-text -Bstatic -o $lib $libobjs $deplibs $linker_flags' fi _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='-L$libdir' _LT_TAGVAR(hardcode_direct, $1)=yes _LT_TAGVAR(hardcode_minus_L, $1)=yes _LT_TAGVAR(hardcode_shlibpath_var, $1)=no ;; sysv4) case $host_vendor in sni) _LT_TAGVAR(archive_cmds, $1)='$LD -G -h $soname -o $lib $libobjs $deplibs $linker_flags' _LT_TAGVAR(hardcode_direct, $1)=yes # is this really true??? ;; siemens) ## LD is ld it makes a PLAMLIB ## CC just makes a GrossModule. _LT_TAGVAR(archive_cmds, $1)='$LD -G -o $lib $libobjs $deplibs $linker_flags' _LT_TAGVAR(reload_cmds, $1)='$CC -r -o $output$reload_objs' _LT_TAGVAR(hardcode_direct, $1)=no ;; motorola) _LT_TAGVAR(archive_cmds, $1)='$LD -G -h $soname -o $lib $libobjs $deplibs $linker_flags' _LT_TAGVAR(hardcode_direct, $1)=no #Motorola manual says yes, but my tests say they lie ;; esac runpath_var='LD_RUN_PATH' _LT_TAGVAR(hardcode_shlibpath_var, $1)=no ;; sysv4.3*) _LT_TAGVAR(archive_cmds, $1)='$LD -G -h $soname -o $lib $libobjs $deplibs $linker_flags' _LT_TAGVAR(hardcode_shlibpath_var, $1)=no _LT_TAGVAR(export_dynamic_flag_spec, $1)='-Bexport' ;; sysv4*MP*) if test -d /usr/nec; then _LT_TAGVAR(archive_cmds, $1)='$LD -G -h $soname -o $lib $libobjs $deplibs $linker_flags' _LT_TAGVAR(hardcode_shlibpath_var, $1)=no runpath_var=LD_RUN_PATH hardcode_runpath_var=yes _LT_TAGVAR(ld_shlibs, $1)=yes fi ;; sysv4*uw2* | sysv5OpenUNIX* | sysv5UnixWare7.[[01]].[[10]]* | unixware7* | sco3.2v5.0.[[024]]*) _LT_TAGVAR(no_undefined_flag, $1)='$wl-z,text' _LT_TAGVAR(archive_cmds_need_lc, $1)=no _LT_TAGVAR(hardcode_shlibpath_var, $1)=no runpath_var='LD_RUN_PATH' if test yes = "$GCC"; then _LT_TAGVAR(archive_cmds, $1)='$CC -shared $wl-h,$soname -o $lib $libobjs $deplibs $compiler_flags' _LT_TAGVAR(archive_expsym_cmds, $1)='$CC -shared $wl-Bexport:$export_symbols $wl-h,$soname -o $lib $libobjs $deplibs $compiler_flags' else _LT_TAGVAR(archive_cmds, $1)='$CC -G $wl-h,$soname -o $lib $libobjs $deplibs $compiler_flags' _LT_TAGVAR(archive_expsym_cmds, $1)='$CC -G $wl-Bexport:$export_symbols $wl-h,$soname -o $lib $libobjs $deplibs $compiler_flags' fi ;; sysv5* | sco3.2v5* | sco5v6*) # Note: We CANNOT use -z defs as we might desire, because we do not # link with -lc, and that would cause any symbols used from libc to # always be unresolved, which means just about no library would # ever link correctly. If we're not using GNU ld we use -z text # though, which does catch some bad symbols but isn't as heavy-handed # as -z defs. _LT_TAGVAR(no_undefined_flag, $1)='$wl-z,text' _LT_TAGVAR(allow_undefined_flag, $1)='$wl-z,nodefs' _LT_TAGVAR(archive_cmds_need_lc, $1)=no _LT_TAGVAR(hardcode_shlibpath_var, $1)=no _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='$wl-R,$libdir' _LT_TAGVAR(hardcode_libdir_separator, $1)=':' _LT_TAGVAR(link_all_deplibs, $1)=yes _LT_TAGVAR(export_dynamic_flag_spec, $1)='$wl-Bexport' runpath_var='LD_RUN_PATH' if test yes = "$GCC"; then _LT_TAGVAR(archive_cmds, $1)='$CC -shared $wl-h,$soname -o $lib $libobjs $deplibs $compiler_flags' _LT_TAGVAR(archive_expsym_cmds, $1)='$CC -shared $wl-Bexport:$export_symbols $wl-h,$soname -o $lib $libobjs $deplibs $compiler_flags' else _LT_TAGVAR(archive_cmds, $1)='$CC -G $wl-h,$soname -o $lib $libobjs $deplibs $compiler_flags' _LT_TAGVAR(archive_expsym_cmds, $1)='$CC -G $wl-Bexport:$export_symbols $wl-h,$soname -o $lib $libobjs $deplibs $compiler_flags' fi ;; uts4*) _LT_TAGVAR(archive_cmds, $1)='$LD -G -h $soname -o $lib $libobjs $deplibs $linker_flags' _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='-L$libdir' _LT_TAGVAR(hardcode_shlibpath_var, $1)=no ;; *) _LT_TAGVAR(ld_shlibs, $1)=no ;; esac if test sni = "$host_vendor"; then case $host in sysv4 | sysv4.2uw2* | sysv4.3* | sysv5*) _LT_TAGVAR(export_dynamic_flag_spec, $1)='$wl-Blargedynsym' ;; esac fi fi ]) AC_MSG_RESULT([$_LT_TAGVAR(ld_shlibs, $1)]) test no = "$_LT_TAGVAR(ld_shlibs, $1)" && can_build_shared=no _LT_TAGVAR(with_gnu_ld, $1)=$with_gnu_ld _LT_DECL([], [libext], [0], [Old archive suffix (normally "a")])dnl _LT_DECL([], [shrext_cmds], [1], [Shared library suffix (normally ".so")])dnl _LT_DECL([], [extract_expsyms_cmds], [2], [The commands to extract the exported symbol list from a shared archive]) # # Do we need to explicitly link libc? # case "x$_LT_TAGVAR(archive_cmds_need_lc, $1)" in x|xyes) # Assume -lc should be added _LT_TAGVAR(archive_cmds_need_lc, $1)=yes if test yes,yes = "$GCC,$enable_shared"; then case $_LT_TAGVAR(archive_cmds, $1) in *'~'*) # FIXME: we may have to deal with multi-command sequences. ;; '$CC '*) # Test whether the compiler implicitly links with -lc since on some # systems, -lgcc has to come before -lc. If gcc already passes -lc # to ld, don't add -lc before -lgcc. AC_CACHE_CHECK([whether -lc should be explicitly linked in], [lt_cv_]_LT_TAGVAR(archive_cmds_need_lc, $1), [$RM conftest* echo "$lt_simple_compile_test_code" > conftest.$ac_ext if AC_TRY_EVAL(ac_compile) 2>conftest.err; then soname=conftest lib=conftest libobjs=conftest.$ac_objext deplibs= wl=$_LT_TAGVAR(lt_prog_compiler_wl, $1) pic_flag=$_LT_TAGVAR(lt_prog_compiler_pic, $1) compiler_flags=-v linker_flags=-v verstring= output_objdir=. libname=conftest lt_save_allow_undefined_flag=$_LT_TAGVAR(allow_undefined_flag, $1) _LT_TAGVAR(allow_undefined_flag, $1)= if AC_TRY_EVAL(_LT_TAGVAR(archive_cmds, $1) 2\>\&1 \| $GREP \" -lc \" \>/dev/null 2\>\&1) then lt_cv_[]_LT_TAGVAR(archive_cmds_need_lc, $1)=no else lt_cv_[]_LT_TAGVAR(archive_cmds_need_lc, $1)=yes fi _LT_TAGVAR(allow_undefined_flag, $1)=$lt_save_allow_undefined_flag else cat conftest.err 1>&5 fi $RM conftest* ]) _LT_TAGVAR(archive_cmds_need_lc, $1)=$lt_cv_[]_LT_TAGVAR(archive_cmds_need_lc, $1) ;; esac fi ;; esac _LT_TAGDECL([build_libtool_need_lc], [archive_cmds_need_lc], [0], [Whether or not to add -lc for building shared libraries]) _LT_TAGDECL([allow_libtool_libs_with_static_runtimes], [enable_shared_with_static_runtimes], [0], [Whether or not to disallow shared libs when runtime libs are static]) _LT_TAGDECL([], [export_dynamic_flag_spec], [1], [Compiler flag to allow reflexive dlopens]) _LT_TAGDECL([], [whole_archive_flag_spec], [1], [Compiler flag to generate shared objects directly from archives]) _LT_TAGDECL([], [compiler_needs_object], [1], [Whether the compiler copes with passing no objects directly]) _LT_TAGDECL([], [old_archive_from_new_cmds], [2], [Create an old-style archive from a shared archive]) _LT_TAGDECL([], [old_archive_from_expsyms_cmds], [2], [Create a temporary old-style archive to link instead of a shared archive]) _LT_TAGDECL([], [archive_cmds], [2], [Commands used to build a shared archive]) _LT_TAGDECL([], [archive_expsym_cmds], [2]) _LT_TAGDECL([], [module_cmds], [2], [Commands used to build a loadable module if different from building a shared archive.]) _LT_TAGDECL([], [module_expsym_cmds], [2]) _LT_TAGDECL([], [with_gnu_ld], [1], [Whether we are building with GNU ld or not]) _LT_TAGDECL([], [allow_undefined_flag], [1], [Flag that allows shared libraries with undefined symbols to be built]) _LT_TAGDECL([], [no_undefined_flag], [1], [Flag that enforces no undefined symbols]) _LT_TAGDECL([], [hardcode_libdir_flag_spec], [1], [Flag to hardcode $libdir into a binary during linking. This must work even if $libdir does not exist]) _LT_TAGDECL([], [hardcode_libdir_separator], [1], [Whether we need a single "-rpath" flag with a separated argument]) _LT_TAGDECL([], [hardcode_direct], [0], [Set to "yes" if using DIR/libNAME$shared_ext during linking hardcodes DIR into the resulting binary]) _LT_TAGDECL([], [hardcode_direct_absolute], [0], [Set to "yes" if using DIR/libNAME$shared_ext during linking hardcodes DIR into the resulting binary and the resulting library dependency is "absolute", i.e impossible to change by setting $shlibpath_var if the library is relocated]) _LT_TAGDECL([], [hardcode_minus_L], [0], [Set to "yes" if using the -LDIR flag during linking hardcodes DIR into the resulting binary]) _LT_TAGDECL([], [hardcode_shlibpath_var], [0], [Set to "yes" if using SHLIBPATH_VAR=DIR during linking hardcodes DIR into the resulting binary]) _LT_TAGDECL([], [hardcode_automatic], [0], [Set to "yes" if building a shared library automatically hardcodes DIR into the library and all subsequent libraries and executables linked against it]) _LT_TAGDECL([], [inherit_rpath], [0], [Set to yes if linker adds runtime paths of dependent libraries to runtime path list]) _LT_TAGDECL([], [link_all_deplibs], [0], [Whether libtool must link a program against all its dependency libraries]) _LT_TAGDECL([], [always_export_symbols], [0], [Set to "yes" if exported symbols are required]) _LT_TAGDECL([], [export_symbols_cmds], [2], [The commands to list exported symbols]) _LT_TAGDECL([], [exclude_expsyms], [1], [Symbols that should not be listed in the preloaded symbols]) _LT_TAGDECL([], [include_expsyms], [1], [Symbols that must always be exported]) _LT_TAGDECL([], [prelink_cmds], [2], [Commands necessary for linking programs (against libraries) with templates]) _LT_TAGDECL([], [postlink_cmds], [2], [Commands necessary for finishing linking programs]) _LT_TAGDECL([], [file_list_spec], [1], [Specify filename containing input files]) dnl FIXME: Not yet implemented dnl _LT_TAGDECL([], [thread_safe_flag_spec], [1], dnl [Compiler flag to generate thread safe objects]) ])# _LT_LINKER_SHLIBS # _LT_LANG_C_CONFIG([TAG]) # ------------------------ # Ensure that the configuration variables for a C compiler are suitably # defined. These variables are subsequently used by _LT_CONFIG to write # the compiler configuration to 'libtool'. m4_defun([_LT_LANG_C_CONFIG], [m4_require([_LT_DECL_EGREP])dnl lt_save_CC=$CC AC_LANG_PUSH(C) # Source file extension for C test sources. ac_ext=c # Object file extension for compiled C test sources. objext=o _LT_TAGVAR(objext, $1)=$objext # Code to be used in simple compile tests lt_simple_compile_test_code="int some_variable = 0;" # Code to be used in simple link tests lt_simple_link_test_code='int main(){return(0);}' _LT_TAG_COMPILER # Save the default compiler, since it gets overwritten when the other # tags are being tested, and _LT_TAGVAR(compiler, []) is a NOP. compiler_DEFAULT=$CC # save warnings/boilerplate of simple test code _LT_COMPILER_BOILERPLATE _LT_LINKER_BOILERPLATE ## CAVEAT EMPTOR: ## There is no encapsulation within the following macros, do not change ## the running order or otherwise move them around unless you know exactly ## what you are doing... if test -n "$compiler"; then _LT_COMPILER_NO_RTTI($1) _LT_COMPILER_PIC($1) _LT_COMPILER_C_O($1) _LT_COMPILER_FILE_LOCKS($1) _LT_LINKER_SHLIBS($1) _LT_SYS_DYNAMIC_LINKER($1) _LT_LINKER_HARDCODE_LIBPATH($1) LT_SYS_DLOPEN_SELF _LT_CMD_STRIPLIB # Report what library types will actually be built AC_MSG_CHECKING([if libtool supports shared libraries]) AC_MSG_RESULT([$can_build_shared]) AC_MSG_CHECKING([whether to build shared libraries]) test no = "$can_build_shared" && enable_shared=no # On AIX, shared libraries and static libraries use the same namespace, and # are all built from PIC. case $host_os in aix3*) test yes = "$enable_shared" && enable_static=no if test -n "$RANLIB"; then archive_cmds="$archive_cmds~\$RANLIB \$lib" postinstall_cmds='$RANLIB $lib' fi ;; aix[[4-9]]*) if test ia64 != "$host_cpu"; then case $enable_shared,$with_aix_soname,$aix_use_runtimelinking in yes,aix,yes) ;; # shared object as lib.so file only yes,svr4,*) ;; # shared object as lib.so archive member only yes,*) enable_static=no ;; # shared object in lib.a archive as well esac fi ;; esac AC_MSG_RESULT([$enable_shared]) AC_MSG_CHECKING([whether to build static libraries]) # Make sure either enable_shared or enable_static is yes. test yes = "$enable_shared" || enable_static=yes AC_MSG_RESULT([$enable_static]) _LT_CONFIG($1) fi AC_LANG_POP CC=$lt_save_CC ])# _LT_LANG_C_CONFIG # _LT_LANG_CXX_CONFIG([TAG]) # -------------------------- # Ensure that the configuration variables for a C++ compiler are suitably # defined. These variables are subsequently used by _LT_CONFIG to write # the compiler configuration to 'libtool'. m4_defun([_LT_LANG_CXX_CONFIG], [m4_require([_LT_FILEUTILS_DEFAULTS])dnl m4_require([_LT_DECL_EGREP])dnl m4_require([_LT_PATH_MANIFEST_TOOL])dnl if test -n "$CXX" && ( test no != "$CXX" && ( (test g++ = "$CXX" && `g++ -v >/dev/null 2>&1` ) || (test g++ != "$CXX"))); then AC_PROG_CXXCPP else _lt_caught_CXX_error=yes fi AC_LANG_PUSH(C++) _LT_TAGVAR(archive_cmds_need_lc, $1)=no _LT_TAGVAR(allow_undefined_flag, $1)= _LT_TAGVAR(always_export_symbols, $1)=no _LT_TAGVAR(archive_expsym_cmds, $1)= _LT_TAGVAR(compiler_needs_object, $1)=no _LT_TAGVAR(export_dynamic_flag_spec, $1)= _LT_TAGVAR(hardcode_direct, $1)=no _LT_TAGVAR(hardcode_direct_absolute, $1)=no _LT_TAGVAR(hardcode_libdir_flag_spec, $1)= _LT_TAGVAR(hardcode_libdir_separator, $1)= _LT_TAGVAR(hardcode_minus_L, $1)=no _LT_TAGVAR(hardcode_shlibpath_var, $1)=unsupported _LT_TAGVAR(hardcode_automatic, $1)=no _LT_TAGVAR(inherit_rpath, $1)=no _LT_TAGVAR(module_cmds, $1)= _LT_TAGVAR(module_expsym_cmds, $1)= _LT_TAGVAR(link_all_deplibs, $1)=unknown _LT_TAGVAR(old_archive_cmds, $1)=$old_archive_cmds _LT_TAGVAR(reload_flag, $1)=$reload_flag _LT_TAGVAR(reload_cmds, $1)=$reload_cmds _LT_TAGVAR(no_undefined_flag, $1)= _LT_TAGVAR(whole_archive_flag_spec, $1)= _LT_TAGVAR(enable_shared_with_static_runtimes, $1)=no # Source file extension for C++ test sources. ac_ext=cpp # Object file extension for compiled C++ test sources. objext=o _LT_TAGVAR(objext, $1)=$objext # No sense in running all these tests if we already determined that # the CXX compiler isn't working. Some variables (like enable_shared) # are currently assumed to apply to all compilers on this platform, # and will be corrupted by setting them based on a non-working compiler. if test yes != "$_lt_caught_CXX_error"; then # Code to be used in simple compile tests lt_simple_compile_test_code="int some_variable = 0;" # Code to be used in simple link tests lt_simple_link_test_code='int main(int, char *[[]]) { return(0); }' # ltmain only uses $CC for tagged configurations so make sure $CC is set. _LT_TAG_COMPILER # save warnings/boilerplate of simple test code _LT_COMPILER_BOILERPLATE _LT_LINKER_BOILERPLATE # Allow CC to be a program name with arguments. lt_save_CC=$CC lt_save_CFLAGS=$CFLAGS lt_save_LD=$LD lt_save_GCC=$GCC GCC=$GXX lt_save_with_gnu_ld=$with_gnu_ld lt_save_path_LD=$lt_cv_path_LD if test -n "${lt_cv_prog_gnu_ldcxx+set}"; then lt_cv_prog_gnu_ld=$lt_cv_prog_gnu_ldcxx else $as_unset lt_cv_prog_gnu_ld fi if test -n "${lt_cv_path_LDCXX+set}"; then lt_cv_path_LD=$lt_cv_path_LDCXX else $as_unset lt_cv_path_LD fi test -z "${LDCXX+set}" || LD=$LDCXX CC=${CXX-"c++"} CFLAGS=$CXXFLAGS compiler=$CC _LT_TAGVAR(compiler, $1)=$CC _LT_CC_BASENAME([$compiler]) if test -n "$compiler"; then # We don't want -fno-exception when compiling C++ code, so set the # no_builtin_flag separately if test yes = "$GXX"; then _LT_TAGVAR(lt_prog_compiler_no_builtin_flag, $1)=' -fno-builtin' else _LT_TAGVAR(lt_prog_compiler_no_builtin_flag, $1)= fi if test yes = "$GXX"; then # Set up default GNU C++ configuration LT_PATH_LD # Check if GNU C++ uses GNU ld as the underlying linker, since the # archiving commands below assume that GNU ld is being used. if test yes = "$with_gnu_ld"; then _LT_TAGVAR(archive_cmds, $1)='$CC $pic_flag -shared -nostdlib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags $wl-soname $wl$soname -o $lib' _LT_TAGVAR(archive_expsym_cmds, $1)='$CC $pic_flag -shared -nostdlib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags $wl-soname $wl$soname $wl-retain-symbols-file $wl$export_symbols -o $lib' _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='$wl-rpath $wl$libdir' _LT_TAGVAR(export_dynamic_flag_spec, $1)='$wl--export-dynamic' # If archive_cmds runs LD, not CC, wlarc should be empty # XXX I think wlarc can be eliminated in ltcf-cxx, but I need to # investigate it a little bit more. (MM) wlarc='$wl' # ancient GNU ld didn't support --whole-archive et. al. if eval "`$CC -print-prog-name=ld` --help 2>&1" | $GREP 'no-whole-archive' > /dev/null; then _LT_TAGVAR(whole_archive_flag_spec, $1)=$wlarc'--whole-archive$convenience '$wlarc'--no-whole-archive' else _LT_TAGVAR(whole_archive_flag_spec, $1)= fi else with_gnu_ld=no wlarc= # A generic and very simple default shared library creation # command for GNU C++ for the case where it uses the native # linker, instead of GNU ld. If possible, this setting should # overridden to take advantage of the native linker features on # the platform it is being used on. _LT_TAGVAR(archive_cmds, $1)='$CC -shared -nostdlib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags -o $lib' fi # Commands to make compiler produce verbose output that lists # what "hidden" libraries, object files and flags are used when # linking a shared library. output_verbose_link_cmd='$CC -shared $CFLAGS -v conftest.$objext 2>&1 | $GREP -v "^Configured with:" | $GREP "\-L"' else GXX=no with_gnu_ld=no wlarc= fi # PORTME: fill in a description of your system's C++ link characteristics AC_MSG_CHECKING([whether the $compiler linker ($LD) supports shared libraries]) _LT_TAGVAR(ld_shlibs, $1)=yes case $host_os in aix3*) # FIXME: insert proper C++ library support _LT_TAGVAR(ld_shlibs, $1)=no ;; aix[[4-9]]*) if test ia64 = "$host_cpu"; then # On IA64, the linker does run time linking by default, so we don't # have to do anything special. aix_use_runtimelinking=no exp_sym_flag='-Bexport' no_entry_flag= else aix_use_runtimelinking=no # Test if we are trying to use run time linking or normal # AIX style linking. If -brtl is somewhere in LDFLAGS, we # have runtime linking enabled, and use it for executables. # For shared libraries, we enable/disable runtime linking # depending on the kind of the shared library created - # when "with_aix_soname,aix_use_runtimelinking" is: # "aix,no" lib.a(lib.so.V) shared, rtl:no, for executables # "aix,yes" lib.so shared, rtl:yes, for executables # lib.a static archive # "both,no" lib.so.V(shr.o) shared, rtl:yes # lib.a(lib.so.V) shared, rtl:no, for executables # "both,yes" lib.so.V(shr.o) shared, rtl:yes, for executables # lib.a(lib.so.V) shared, rtl:no # "svr4,*" lib.so.V(shr.o) shared, rtl:yes, for executables # lib.a static archive case $host_os in aix4.[[23]]|aix4.[[23]].*|aix[[5-9]]*) for ld_flag in $LDFLAGS; do case $ld_flag in *-brtl*) aix_use_runtimelinking=yes break ;; esac done if test svr4,no = "$with_aix_soname,$aix_use_runtimelinking"; then # With aix-soname=svr4, we create the lib.so.V shared archives only, # so we don't have lib.a shared libs to link our executables. # We have to force runtime linking in this case. aix_use_runtimelinking=yes LDFLAGS="$LDFLAGS -Wl,-brtl" fi ;; esac exp_sym_flag='-bexport' no_entry_flag='-bnoentry' fi # When large executables or shared objects are built, AIX ld can # have problems creating the table of contents. If linking a library # or program results in "error TOC overflow" add -mminimal-toc to # CXXFLAGS/CFLAGS for g++/gcc. In the cases where that is not # enough to fix the problem, add -Wl,-bbigtoc to LDFLAGS. _LT_TAGVAR(archive_cmds, $1)='' _LT_TAGVAR(hardcode_direct, $1)=yes _LT_TAGVAR(hardcode_direct_absolute, $1)=yes _LT_TAGVAR(hardcode_libdir_separator, $1)=':' _LT_TAGVAR(link_all_deplibs, $1)=yes _LT_TAGVAR(file_list_spec, $1)='$wl-f,' case $with_aix_soname,$aix_use_runtimelinking in aix,*) ;; # no import file svr4,* | *,yes) # use import file # The Import File defines what to hardcode. _LT_TAGVAR(hardcode_direct, $1)=no _LT_TAGVAR(hardcode_direct_absolute, $1)=no ;; esac if test yes = "$GXX"; then case $host_os in aix4.[[012]]|aix4.[[012]].*) # We only want to do this on AIX 4.2 and lower, the check # below for broken collect2 doesn't work under 4.3+ collect2name=`$CC -print-prog-name=collect2` if test -f "$collect2name" && strings "$collect2name" | $GREP resolve_lib_name >/dev/null then # We have reworked collect2 : else # We have old collect2 _LT_TAGVAR(hardcode_direct, $1)=unsupported # It fails to find uninstalled libraries when the uninstalled # path is not listed in the libpath. Setting hardcode_minus_L # to unsupported forces relinking _LT_TAGVAR(hardcode_minus_L, $1)=yes _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='-L$libdir' _LT_TAGVAR(hardcode_libdir_separator, $1)= fi esac shared_flag='-shared' if test yes = "$aix_use_runtimelinking"; then shared_flag=$shared_flag' $wl-G' fi # Need to ensure runtime linking is disabled for the traditional # shared library, or the linker may eventually find shared libraries # /with/ Import File - we do not want to mix them. shared_flag_aix='-shared' shared_flag_svr4='-shared $wl-G' else # not using gcc if test ia64 = "$host_cpu"; then # VisualAge C++, Version 5.5 for AIX 5L for IA-64, Beta 3 Release # chokes on -Wl,-G. The following line is correct: shared_flag='-G' else if test yes = "$aix_use_runtimelinking"; then shared_flag='$wl-G' else shared_flag='$wl-bM:SRE' fi shared_flag_aix='$wl-bM:SRE' shared_flag_svr4='$wl-G' fi fi _LT_TAGVAR(export_dynamic_flag_spec, $1)='$wl-bexpall' # It seems that -bexpall does not export symbols beginning with # underscore (_), so it is better to generate a list of symbols to # export. _LT_TAGVAR(always_export_symbols, $1)=yes if test aix,yes = "$with_aix_soname,$aix_use_runtimelinking"; then # Warning - without using the other runtime loading flags (-brtl), # -berok will link without error, but may produce a broken library. # The "-G" linker flag allows undefined symbols. _LT_TAGVAR(no_undefined_flag, $1)='-bernotok' # Determine the default libpath from the value encoded in an empty # executable. _LT_SYS_MODULE_PATH_AIX([$1]) _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='$wl-blibpath:$libdir:'"$aix_libpath" _LT_TAGVAR(archive_expsym_cmds, $1)='$CC -o $output_objdir/$soname $libobjs $deplibs $wl'$no_entry_flag' $compiler_flags `if test -n "$allow_undefined_flag"; then func_echo_all "$wl$allow_undefined_flag"; else :; fi` $wl'$exp_sym_flag:\$export_symbols' '$shared_flag else if test ia64 = "$host_cpu"; then _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='$wl-R $libdir:/usr/lib:/lib' _LT_TAGVAR(allow_undefined_flag, $1)="-z nodefs" _LT_TAGVAR(archive_expsym_cmds, $1)="\$CC $shared_flag"' -o $output_objdir/$soname $libobjs $deplibs '"\$wl$no_entry_flag"' $compiler_flags $wl$allow_undefined_flag '"\$wl$exp_sym_flag:\$export_symbols" else # Determine the default libpath from the value encoded in an # empty executable. _LT_SYS_MODULE_PATH_AIX([$1]) _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='$wl-blibpath:$libdir:'"$aix_libpath" # Warning - without using the other run time loading flags, # -berok will link without error, but may produce a broken library. _LT_TAGVAR(no_undefined_flag, $1)=' $wl-bernotok' _LT_TAGVAR(allow_undefined_flag, $1)=' $wl-berok' if test yes = "$with_gnu_ld"; then # We only use this code for GNU lds that support --whole-archive. _LT_TAGVAR(whole_archive_flag_spec, $1)='$wl--whole-archive$convenience $wl--no-whole-archive' else # Exported symbols can be pulled into shared objects from archives _LT_TAGVAR(whole_archive_flag_spec, $1)='$convenience' fi _LT_TAGVAR(archive_cmds_need_lc, $1)=yes _LT_TAGVAR(archive_expsym_cmds, $1)='$RM -r $output_objdir/$realname.d~$MKDIR $output_objdir/$realname.d' # -brtl affects multiple linker settings, -berok does not and is overridden later compiler_flags_filtered='`func_echo_all "$compiler_flags " | $SED -e "s%-brtl\\([[, ]]\\)%-berok\\1%g"`' if test svr4 != "$with_aix_soname"; then # This is similar to how AIX traditionally builds its shared # libraries. Need -bnortl late, we may have -brtl in LDFLAGS. _LT_TAGVAR(archive_expsym_cmds, $1)="$_LT_TAGVAR(archive_expsym_cmds, $1)"'~$CC '$shared_flag_aix' -o $output_objdir/$realname.d/$soname $libobjs $deplibs $wl-bnoentry '$compiler_flags_filtered'$wl-bE:$export_symbols$allow_undefined_flag~$AR $AR_FLAGS $output_objdir/$libname$release.a $output_objdir/$realname.d/$soname' fi if test aix != "$with_aix_soname"; then _LT_TAGVAR(archive_expsym_cmds, $1)="$_LT_TAGVAR(archive_expsym_cmds, $1)"'~$CC '$shared_flag_svr4' -o $output_objdir/$realname.d/$shared_archive_member_spec.o $libobjs $deplibs $wl-bnoentry '$compiler_flags_filtered'$wl-bE:$export_symbols$allow_undefined_flag~$STRIP -e $output_objdir/$realname.d/$shared_archive_member_spec.o~( func_echo_all "#! $soname($shared_archive_member_spec.o)"; if test shr_64 = "$shared_archive_member_spec"; then func_echo_all "# 64"; else func_echo_all "# 32"; fi; cat $export_symbols ) > $output_objdir/$realname.d/$shared_archive_member_spec.imp~$AR $AR_FLAGS $output_objdir/$soname $output_objdir/$realname.d/$shared_archive_member_spec.o $output_objdir/$realname.d/$shared_archive_member_spec.imp' else # used by -dlpreopen to get the symbols _LT_TAGVAR(archive_expsym_cmds, $1)="$_LT_TAGVAR(archive_expsym_cmds, $1)"'~$MV $output_objdir/$realname.d/$soname $output_objdir' fi _LT_TAGVAR(archive_expsym_cmds, $1)="$_LT_TAGVAR(archive_expsym_cmds, $1)"'~$RM -r $output_objdir/$realname.d' fi fi ;; beos*) if $LD --help 2>&1 | $GREP ': supported targets:.* elf' > /dev/null; then _LT_TAGVAR(allow_undefined_flag, $1)=unsupported # Joseph Beckenbach says some releases of gcc # support --undefined. This deserves some investigation. FIXME _LT_TAGVAR(archive_cmds, $1)='$CC -nostart $libobjs $deplibs $compiler_flags $wl-soname $wl$soname -o $lib' else _LT_TAGVAR(ld_shlibs, $1)=no fi ;; chorus*) case $cc_basename in *) # FIXME: insert proper C++ library support _LT_TAGVAR(ld_shlibs, $1)=no ;; esac ;; cygwin* | mingw* | pw32* | cegcc*) case $GXX,$cc_basename in ,cl* | no,cl*) # Native MSVC # hardcode_libdir_flag_spec is actually meaningless, as there is # no search path for DLLs. _LT_TAGVAR(hardcode_libdir_flag_spec, $1)=' ' _LT_TAGVAR(allow_undefined_flag, $1)=unsupported _LT_TAGVAR(always_export_symbols, $1)=yes _LT_TAGVAR(file_list_spec, $1)='@' # Tell ltmain to make .lib files, not .a files. libext=lib # Tell ltmain to make .dll files, not .so files. shrext_cmds=.dll # FIXME: Setting linknames here is a bad hack. _LT_TAGVAR(archive_cmds, $1)='$CC -o $output_objdir/$soname $libobjs $compiler_flags $deplibs -Wl,-DLL,-IMPLIB:"$tool_output_objdir$libname.dll.lib"~linknames=' _LT_TAGVAR(archive_expsym_cmds, $1)='if _LT_DLL_DEF_P([$export_symbols]); then cp "$export_symbols" "$output_objdir/$soname.def"; echo "$tool_output_objdir$soname.def" > "$output_objdir/$soname.exp"; else $SED -e '\''s/^/-link -EXPORT:/'\'' < $export_symbols > $output_objdir/$soname.exp; fi~ $CC -o $tool_output_objdir$soname $libobjs $compiler_flags $deplibs "@$tool_output_objdir$soname.exp" -Wl,-DLL,-IMPLIB:"$tool_output_objdir$libname.dll.lib"~ linknames=' # The linker will not automatically build a static lib if we build a DLL. # _LT_TAGVAR(old_archive_from_new_cmds, $1)='true' _LT_TAGVAR(enable_shared_with_static_runtimes, $1)=yes # Don't use ranlib _LT_TAGVAR(old_postinstall_cmds, $1)='chmod 644 $oldlib' _LT_TAGVAR(postlink_cmds, $1)='lt_outputfile="@OUTPUT@"~ lt_tool_outputfile="@TOOL_OUTPUT@"~ case $lt_outputfile in *.exe|*.EXE) ;; *) lt_outputfile=$lt_outputfile.exe lt_tool_outputfile=$lt_tool_outputfile.exe ;; esac~ func_to_tool_file "$lt_outputfile"~ if test : != "$MANIFEST_TOOL" && test -f "$lt_outputfile.manifest"; then $MANIFEST_TOOL -manifest "$lt_tool_outputfile.manifest" -outputresource:"$lt_tool_outputfile" || exit 1; $RM "$lt_outputfile.manifest"; fi' ;; *) # g++ # _LT_TAGVAR(hardcode_libdir_flag_spec, $1) is actually meaningless, # as there is no search path for DLLs. _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='-L$libdir' _LT_TAGVAR(export_dynamic_flag_spec, $1)='$wl--export-all-symbols' _LT_TAGVAR(allow_undefined_flag, $1)=unsupported _LT_TAGVAR(always_export_symbols, $1)=no _LT_TAGVAR(enable_shared_with_static_runtimes, $1)=yes if $LD --help 2>&1 | $GREP 'auto-import' > /dev/null; then _LT_TAGVAR(archive_cmds, $1)='$CC -shared -nostdlib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags -o $output_objdir/$soname $wl--enable-auto-image-base -Xlinker --out-implib -Xlinker $lib' # If the export-symbols file already is a .def file, use it as # is; otherwise, prepend EXPORTS... _LT_TAGVAR(archive_expsym_cmds, $1)='if _LT_DLL_DEF_P([$export_symbols]); then cp $export_symbols $output_objdir/$soname.def; else echo EXPORTS > $output_objdir/$soname.def; cat $export_symbols >> $output_objdir/$soname.def; fi~ $CC -shared -nostdlib $output_objdir/$soname.def $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags -o $output_objdir/$soname $wl--enable-auto-image-base -Xlinker --out-implib -Xlinker $lib' else _LT_TAGVAR(ld_shlibs, $1)=no fi ;; esac ;; darwin* | rhapsody*) _LT_DARWIN_LINKER_FEATURES($1) ;; os2*) _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='-L$libdir' _LT_TAGVAR(hardcode_minus_L, $1)=yes _LT_TAGVAR(allow_undefined_flag, $1)=unsupported shrext_cmds=.dll _LT_TAGVAR(archive_cmds, $1)='$ECHO "LIBRARY ${soname%$shared_ext} INITINSTANCE TERMINSTANCE" > $output_objdir/$libname.def~ $ECHO "DESCRIPTION \"$libname\"" >> $output_objdir/$libname.def~ $ECHO "DATA MULTIPLE NONSHARED" >> $output_objdir/$libname.def~ $ECHO EXPORTS >> $output_objdir/$libname.def~ emxexp $libobjs | $SED /"_DLL_InitTerm"/d >> $output_objdir/$libname.def~ $CC -Zdll -Zcrtdll -o $output_objdir/$soname $libobjs $deplibs $compiler_flags $output_objdir/$libname.def~ emximp -o $lib $output_objdir/$libname.def' _LT_TAGVAR(archive_expsym_cmds, $1)='$ECHO "LIBRARY ${soname%$shared_ext} INITINSTANCE TERMINSTANCE" > $output_objdir/$libname.def~ $ECHO "DESCRIPTION \"$libname\"" >> $output_objdir/$libname.def~ $ECHO "DATA MULTIPLE NONSHARED" >> $output_objdir/$libname.def~ $ECHO EXPORTS >> $output_objdir/$libname.def~ prefix_cmds="$SED"~ if test EXPORTS = "`$SED 1q $export_symbols`"; then prefix_cmds="$prefix_cmds -e 1d"; fi~ prefix_cmds="$prefix_cmds -e \"s/^\(.*\)$/_\1/g\""~ cat $export_symbols | $prefix_cmds >> $output_objdir/$libname.def~ $CC -Zdll -Zcrtdll -o $output_objdir/$soname $libobjs $deplibs $compiler_flags $output_objdir/$libname.def~ emximp -o $lib $output_objdir/$libname.def' _LT_TAGVAR(old_archive_From_new_cmds, $1)='emximp -o $output_objdir/${libname}_dll.a $output_objdir/$libname.def' _LT_TAGVAR(enable_shared_with_static_runtimes, $1)=yes ;; dgux*) case $cc_basename in ec++*) # FIXME: insert proper C++ library support _LT_TAGVAR(ld_shlibs, $1)=no ;; ghcx*) # Green Hills C++ Compiler # FIXME: insert proper C++ library support _LT_TAGVAR(ld_shlibs, $1)=no ;; *) # FIXME: insert proper C++ library support _LT_TAGVAR(ld_shlibs, $1)=no ;; esac ;; freebsd2.*) # C++ shared libraries reported to be fairly broken before # switch to ELF _LT_TAGVAR(ld_shlibs, $1)=no ;; freebsd-elf*) _LT_TAGVAR(archive_cmds_need_lc, $1)=no ;; freebsd* | dragonfly*) # FreeBSD 3 and later use GNU C++ and GNU ld with standard ELF # conventions _LT_TAGVAR(ld_shlibs, $1)=yes ;; haiku*) _LT_TAGVAR(archive_cmds, $1)='$CC -shared $libobjs $deplibs $compiler_flags $wl-soname $wl$soname -o $lib' _LT_TAGVAR(link_all_deplibs, $1)=yes ;; hpux9*) _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='$wl+b $wl$libdir' _LT_TAGVAR(hardcode_libdir_separator, $1)=: _LT_TAGVAR(export_dynamic_flag_spec, $1)='$wl-E' _LT_TAGVAR(hardcode_direct, $1)=yes _LT_TAGVAR(hardcode_minus_L, $1)=yes # Not in the search PATH, # but as the default # location of the library. case $cc_basename in CC*) # FIXME: insert proper C++ library support _LT_TAGVAR(ld_shlibs, $1)=no ;; aCC*) _LT_TAGVAR(archive_cmds, $1)='$RM $output_objdir/$soname~$CC -b $wl+b $wl$install_libdir -o $output_objdir/$soname $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags~test "x$output_objdir/$soname" = "x$lib" || mv $output_objdir/$soname $lib' # Commands to make compiler produce verbose output that lists # what "hidden" libraries, object files and flags are used when # linking a shared library. # # There doesn't appear to be a way to prevent this compiler from # explicitly linking system object files so we need to strip them # from the output so that they don't get included in the library # dependencies. output_verbose_link_cmd='templist=`($CC -b $CFLAGS -v conftest.$objext 2>&1) | $EGREP "\-L"`; list= ; for z in $templist; do case $z in conftest.$objext) list="$list $z";; *.$objext);; *) list="$list $z";;esac; done; func_echo_all "$list"' ;; *) if test yes = "$GXX"; then _LT_TAGVAR(archive_cmds, $1)='$RM $output_objdir/$soname~$CC -shared -nostdlib $pic_flag $wl+b $wl$install_libdir -o $output_objdir/$soname $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags~test "x$output_objdir/$soname" = "x$lib" || mv $output_objdir/$soname $lib' else # FIXME: insert proper C++ library support _LT_TAGVAR(ld_shlibs, $1)=no fi ;; esac ;; hpux10*|hpux11*) if test no = "$with_gnu_ld"; then _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='$wl+b $wl$libdir' _LT_TAGVAR(hardcode_libdir_separator, $1)=: case $host_cpu in hppa*64*|ia64*) ;; *) _LT_TAGVAR(export_dynamic_flag_spec, $1)='$wl-E' ;; esac fi case $host_cpu in hppa*64*|ia64*) _LT_TAGVAR(hardcode_direct, $1)=no _LT_TAGVAR(hardcode_shlibpath_var, $1)=no ;; *) _LT_TAGVAR(hardcode_direct, $1)=yes _LT_TAGVAR(hardcode_direct_absolute, $1)=yes _LT_TAGVAR(hardcode_minus_L, $1)=yes # Not in the search PATH, # but as the default # location of the library. ;; esac case $cc_basename in CC*) # FIXME: insert proper C++ library support _LT_TAGVAR(ld_shlibs, $1)=no ;; aCC*) case $host_cpu in hppa*64*) _LT_TAGVAR(archive_cmds, $1)='$CC -b $wl+h $wl$soname -o $lib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags' ;; ia64*) _LT_TAGVAR(archive_cmds, $1)='$CC -b $wl+h $wl$soname $wl+nodefaultrpath -o $lib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags' ;; *) _LT_TAGVAR(archive_cmds, $1)='$CC -b $wl+h $wl$soname $wl+b $wl$install_libdir -o $lib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags' ;; esac # Commands to make compiler produce verbose output that lists # what "hidden" libraries, object files and flags are used when # linking a shared library. # # There doesn't appear to be a way to prevent this compiler from # explicitly linking system object files so we need to strip them # from the output so that they don't get included in the library # dependencies. output_verbose_link_cmd='templist=`($CC -b $CFLAGS -v conftest.$objext 2>&1) | $GREP "\-L"`; list= ; for z in $templist; do case $z in conftest.$objext) list="$list $z";; *.$objext);; *) list="$list $z";;esac; done; func_echo_all "$list"' ;; *) if test yes = "$GXX"; then if test no = "$with_gnu_ld"; then case $host_cpu in hppa*64*) _LT_TAGVAR(archive_cmds, $1)='$CC -shared -nostdlib -fPIC $wl+h $wl$soname -o $lib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags' ;; ia64*) _LT_TAGVAR(archive_cmds, $1)='$CC -shared -nostdlib $pic_flag $wl+h $wl$soname $wl+nodefaultrpath -o $lib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags' ;; *) _LT_TAGVAR(archive_cmds, $1)='$CC -shared -nostdlib $pic_flag $wl+h $wl$soname $wl+b $wl$install_libdir -o $lib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags' ;; esac fi else # FIXME: insert proper C++ library support _LT_TAGVAR(ld_shlibs, $1)=no fi ;; esac ;; interix[[3-9]]*) _LT_TAGVAR(hardcode_direct, $1)=no _LT_TAGVAR(hardcode_shlibpath_var, $1)=no _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='$wl-rpath,$libdir' _LT_TAGVAR(export_dynamic_flag_spec, $1)='$wl-E' # Hack: On Interix 3.x, we cannot compile PIC because of a broken gcc. # Instead, shared libraries are loaded at an image base (0x10000000 by # default) and relocated if they conflict, which is a slow very memory # consuming and fragmenting process. To avoid this, we pick a random, # 256 KiB-aligned image base between 0x50000000 and 0x6FFC0000 at link # time. Moving up from 0x10000000 also allows more sbrk(2) space. _LT_TAGVAR(archive_cmds, $1)='$CC -shared $pic_flag $libobjs $deplibs $compiler_flags $wl-h,$soname $wl--image-base,`expr ${RANDOM-$$} % 4096 / 2 \* 262144 + 1342177280` -o $lib' _LT_TAGVAR(archive_expsym_cmds, $1)='sed "s|^|_|" $export_symbols >$output_objdir/$soname.expsym~$CC -shared $pic_flag $libobjs $deplibs $compiler_flags $wl-h,$soname $wl--retain-symbols-file,$output_objdir/$soname.expsym $wl--image-base,`expr ${RANDOM-$$} % 4096 / 2 \* 262144 + 1342177280` -o $lib' ;; irix5* | irix6*) case $cc_basename in CC*) # SGI C++ _LT_TAGVAR(archive_cmds, $1)='$CC -shared -all -multigot $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags -soname $soname `test -n "$verstring" && func_echo_all "-set_version $verstring"` -update_registry $output_objdir/so_locations -o $lib' # Archives containing C++ object files must be created using # "CC -ar", where "CC" is the IRIX C++ compiler. This is # necessary to make sure instantiated templates are included # in the archive. _LT_TAGVAR(old_archive_cmds, $1)='$CC -ar -WR,-u -o $oldlib $oldobjs' ;; *) if test yes = "$GXX"; then if test no = "$with_gnu_ld"; then _LT_TAGVAR(archive_cmds, $1)='$CC -shared $pic_flag -nostdlib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags $wl-soname $wl$soname `test -n "$verstring" && func_echo_all "$wl-set_version $wl$verstring"` $wl-update_registry $wl$output_objdir/so_locations -o $lib' else _LT_TAGVAR(archive_cmds, $1)='$CC -shared $pic_flag -nostdlib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags $wl-soname $wl$soname `test -n "$verstring" && func_echo_all "$wl-set_version $wl$verstring"` -o $lib' fi fi _LT_TAGVAR(link_all_deplibs, $1)=yes ;; esac _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='$wl-rpath $wl$libdir' _LT_TAGVAR(hardcode_libdir_separator, $1)=: _LT_TAGVAR(inherit_rpath, $1)=yes ;; linux* | k*bsd*-gnu | kopensolaris*-gnu | gnu*) case $cc_basename in KCC*) # Kuck and Associates, Inc. (KAI) C++ Compiler # KCC will only create a shared library if the output file # ends with ".so" (or ".sl" for HP-UX), so rename the library # to its proper name (with version) after linking. _LT_TAGVAR(archive_cmds, $1)='tempext=`echo $shared_ext | $SED -e '\''s/\([[^()0-9A-Za-z{}]]\)/\\\\\1/g'\''`; templib=`echo $lib | $SED -e "s/\$tempext\..*/.so/"`; $CC $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags --soname $soname -o \$templib; mv \$templib $lib' _LT_TAGVAR(archive_expsym_cmds, $1)='tempext=`echo $shared_ext | $SED -e '\''s/\([[^()0-9A-Za-z{}]]\)/\\\\\1/g'\''`; templib=`echo $lib | $SED -e "s/\$tempext\..*/.so/"`; $CC $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags --soname $soname -o \$templib $wl-retain-symbols-file,$export_symbols; mv \$templib $lib' # Commands to make compiler produce verbose output that lists # what "hidden" libraries, object files and flags are used when # linking a shared library. # # There doesn't appear to be a way to prevent this compiler from # explicitly linking system object files so we need to strip them # from the output so that they don't get included in the library # dependencies. output_verbose_link_cmd='templist=`$CC $CFLAGS -v conftest.$objext -o libconftest$shared_ext 2>&1 | $GREP "ld"`; rm -f libconftest$shared_ext; list= ; for z in $templist; do case $z in conftest.$objext) list="$list $z";; *.$objext);; *) list="$list $z";;esac; done; func_echo_all "$list"' _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='$wl-rpath,$libdir' _LT_TAGVAR(export_dynamic_flag_spec, $1)='$wl--export-dynamic' # Archives containing C++ object files must be created using # "CC -Bstatic", where "CC" is the KAI C++ compiler. _LT_TAGVAR(old_archive_cmds, $1)='$CC -Bstatic -o $oldlib $oldobjs' ;; icpc* | ecpc* ) # Intel C++ with_gnu_ld=yes # version 8.0 and above of icpc choke on multiply defined symbols # if we add $predep_objects and $postdep_objects, however 7.1 and # earlier do not add the objects themselves. case `$CC -V 2>&1` in *"Version 7."*) _LT_TAGVAR(archive_cmds, $1)='$CC -shared $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags $wl-soname $wl$soname -o $lib' _LT_TAGVAR(archive_expsym_cmds, $1)='$CC -shared $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags $wl-soname $wl$soname $wl-retain-symbols-file $wl$export_symbols -o $lib' ;; *) # Version 8.0 or newer tmp_idyn= case $host_cpu in ia64*) tmp_idyn=' -i_dynamic';; esac _LT_TAGVAR(archive_cmds, $1)='$CC -shared'"$tmp_idyn"' $libobjs $deplibs $compiler_flags $wl-soname $wl$soname -o $lib' _LT_TAGVAR(archive_expsym_cmds, $1)='$CC -shared'"$tmp_idyn"' $libobjs $deplibs $compiler_flags $wl-soname $wl$soname $wl-retain-symbols-file $wl$export_symbols -o $lib' ;; esac _LT_TAGVAR(archive_cmds_need_lc, $1)=no _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='$wl-rpath,$libdir' _LT_TAGVAR(export_dynamic_flag_spec, $1)='$wl--export-dynamic' _LT_TAGVAR(whole_archive_flag_spec, $1)='$wl--whole-archive$convenience $wl--no-whole-archive' ;; pgCC* | pgcpp*) # Portland Group C++ compiler case `$CC -V` in *pgCC\ [[1-5]].* | *pgcpp\ [[1-5]].*) _LT_TAGVAR(prelink_cmds, $1)='tpldir=Template.dir~ rm -rf $tpldir~ $CC --prelink_objects --instantiation_dir $tpldir $objs $libobjs $compile_deplibs~ compile_command="$compile_command `find $tpldir -name \*.o | sort | $NL2SP`"' _LT_TAGVAR(old_archive_cmds, $1)='tpldir=Template.dir~ rm -rf $tpldir~ $CC --prelink_objects --instantiation_dir $tpldir $oldobjs$old_deplibs~ $AR $AR_FLAGS $oldlib$oldobjs$old_deplibs `find $tpldir -name \*.o | sort | $NL2SP`~ $RANLIB $oldlib' _LT_TAGVAR(archive_cmds, $1)='tpldir=Template.dir~ rm -rf $tpldir~ $CC --prelink_objects --instantiation_dir $tpldir $predep_objects $libobjs $deplibs $convenience $postdep_objects~ $CC -shared $pic_flag $predep_objects $libobjs $deplibs `find $tpldir -name \*.o | sort | $NL2SP` $postdep_objects $compiler_flags $wl-soname $wl$soname -o $lib' _LT_TAGVAR(archive_expsym_cmds, $1)='tpldir=Template.dir~ rm -rf $tpldir~ $CC --prelink_objects --instantiation_dir $tpldir $predep_objects $libobjs $deplibs $convenience $postdep_objects~ $CC -shared $pic_flag $predep_objects $libobjs $deplibs `find $tpldir -name \*.o | sort | $NL2SP` $postdep_objects $compiler_flags $wl-soname $wl$soname $wl-retain-symbols-file $wl$export_symbols -o $lib' ;; *) # Version 6 and above use weak symbols _LT_TAGVAR(archive_cmds, $1)='$CC -shared $pic_flag $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags $wl-soname $wl$soname -o $lib' _LT_TAGVAR(archive_expsym_cmds, $1)='$CC -shared $pic_flag $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags $wl-soname $wl$soname $wl-retain-symbols-file $wl$export_symbols -o $lib' ;; esac _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='$wl--rpath $wl$libdir' _LT_TAGVAR(export_dynamic_flag_spec, $1)='$wl--export-dynamic' _LT_TAGVAR(whole_archive_flag_spec, $1)='$wl--whole-archive`for conv in $convenience\"\"; do test -n \"$conv\" && new_convenience=\"$new_convenience,$conv\"; done; func_echo_all \"$new_convenience\"` $wl--no-whole-archive' ;; cxx*) # Compaq C++ _LT_TAGVAR(archive_cmds, $1)='$CC -shared $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags $wl-soname $wl$soname -o $lib' _LT_TAGVAR(archive_expsym_cmds, $1)='$CC -shared $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags $wl-soname $wl$soname -o $lib $wl-retain-symbols-file $wl$export_symbols' runpath_var=LD_RUN_PATH _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='-rpath $libdir' _LT_TAGVAR(hardcode_libdir_separator, $1)=: # Commands to make compiler produce verbose output that lists # what "hidden" libraries, object files and flags are used when # linking a shared library. # # There doesn't appear to be a way to prevent this compiler from # explicitly linking system object files so we need to strip them # from the output so that they don't get included in the library # dependencies. output_verbose_link_cmd='templist=`$CC -shared $CFLAGS -v conftest.$objext 2>&1 | $GREP "ld"`; templist=`func_echo_all "$templist" | $SED "s/\(^.*ld.*\)\( .*ld .*$\)/\1/"`; list= ; for z in $templist; do case $z in conftest.$objext) list="$list $z";; *.$objext);; *) list="$list $z";;esac; done; func_echo_all "X$list" | $Xsed' ;; xl* | mpixl* | bgxl*) # IBM XL 8.0 on PPC, with GNU ld _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='$wl-rpath $wl$libdir' _LT_TAGVAR(export_dynamic_flag_spec, $1)='$wl--export-dynamic' _LT_TAGVAR(archive_cmds, $1)='$CC -qmkshrobj $libobjs $deplibs $compiler_flags $wl-soname $wl$soname -o $lib' if test yes = "$supports_anon_versioning"; then _LT_TAGVAR(archive_expsym_cmds, $1)='echo "{ global:" > $output_objdir/$libname.ver~ cat $export_symbols | sed -e "s/\(.*\)/\1;/" >> $output_objdir/$libname.ver~ echo "local: *; };" >> $output_objdir/$libname.ver~ $CC -qmkshrobj $libobjs $deplibs $compiler_flags $wl-soname $wl$soname $wl-version-script $wl$output_objdir/$libname.ver -o $lib' fi ;; *) case `$CC -V 2>&1 | sed 5q` in *Sun\ C*) # Sun C++ 5.9 _LT_TAGVAR(no_undefined_flag, $1)=' -zdefs' _LT_TAGVAR(archive_cmds, $1)='$CC -G$allow_undefined_flag -h$soname -o $lib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags' _LT_TAGVAR(archive_expsym_cmds, $1)='$CC -G$allow_undefined_flag -h$soname -o $lib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags $wl-retain-symbols-file $wl$export_symbols' _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='-R$libdir' _LT_TAGVAR(whole_archive_flag_spec, $1)='$wl--whole-archive`new_convenience=; for conv in $convenience\"\"; do test -z \"$conv\" || new_convenience=\"$new_convenience,$conv\"; done; func_echo_all \"$new_convenience\"` $wl--no-whole-archive' _LT_TAGVAR(compiler_needs_object, $1)=yes # Not sure whether something based on # $CC $CFLAGS -v conftest.$objext -o libconftest$shared_ext 2>&1 # would be better. output_verbose_link_cmd='func_echo_all' # Archives containing C++ object files must be created using # "CC -xar", where "CC" is the Sun C++ compiler. This is # necessary to make sure instantiated templates are included # in the archive. _LT_TAGVAR(old_archive_cmds, $1)='$CC -xar -o $oldlib $oldobjs' ;; esac ;; esac ;; lynxos*) # FIXME: insert proper C++ library support _LT_TAGVAR(ld_shlibs, $1)=no ;; m88k*) # FIXME: insert proper C++ library support _LT_TAGVAR(ld_shlibs, $1)=no ;; mvs*) case $cc_basename in cxx*) # FIXME: insert proper C++ library support _LT_TAGVAR(ld_shlibs, $1)=no ;; *) # FIXME: insert proper C++ library support _LT_TAGVAR(ld_shlibs, $1)=no ;; esac ;; netbsd*) if echo __ELF__ | $CC -E - | $GREP __ELF__ >/dev/null; then _LT_TAGVAR(archive_cmds, $1)='$LD -Bshareable -o $lib $predep_objects $libobjs $deplibs $postdep_objects $linker_flags' wlarc= _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='-R$libdir' _LT_TAGVAR(hardcode_direct, $1)=yes _LT_TAGVAR(hardcode_shlibpath_var, $1)=no fi # Workaround some broken pre-1.5 toolchains output_verbose_link_cmd='$CC -shared $CFLAGS -v conftest.$objext 2>&1 | $GREP conftest.$objext | $SED -e "s:-lgcc -lc -lgcc::"' ;; *nto* | *qnx*) _LT_TAGVAR(ld_shlibs, $1)=yes ;; openbsd* | bitrig*) if test -f /usr/libexec/ld.so; then _LT_TAGVAR(hardcode_direct, $1)=yes _LT_TAGVAR(hardcode_shlibpath_var, $1)=no _LT_TAGVAR(hardcode_direct_absolute, $1)=yes _LT_TAGVAR(archive_cmds, $1)='$CC -shared $pic_flag $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags -o $lib' _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='$wl-rpath,$libdir' if test -z "`echo __ELF__ | $CC -E - | grep __ELF__`"; then _LT_TAGVAR(archive_expsym_cmds, $1)='$CC -shared $pic_flag $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags $wl-retain-symbols-file,$export_symbols -o $lib' _LT_TAGVAR(export_dynamic_flag_spec, $1)='$wl-E' _LT_TAGVAR(whole_archive_flag_spec, $1)=$wlarc'--whole-archive$convenience '$wlarc'--no-whole-archive' fi output_verbose_link_cmd=func_echo_all else _LT_TAGVAR(ld_shlibs, $1)=no fi ;; osf3* | osf4* | osf5*) case $cc_basename in KCC*) # Kuck and Associates, Inc. (KAI) C++ Compiler # KCC will only create a shared library if the output file # ends with ".so" (or ".sl" for HP-UX), so rename the library # to its proper name (with version) after linking. _LT_TAGVAR(archive_cmds, $1)='tempext=`echo $shared_ext | $SED -e '\''s/\([[^()0-9A-Za-z{}]]\)/\\\\\1/g'\''`; templib=`echo "$lib" | $SED -e "s/\$tempext\..*/.so/"`; $CC $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags --soname $soname -o \$templib; mv \$templib $lib' _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='$wl-rpath,$libdir' _LT_TAGVAR(hardcode_libdir_separator, $1)=: # Archives containing C++ object files must be created using # the KAI C++ compiler. case $host in osf3*) _LT_TAGVAR(old_archive_cmds, $1)='$CC -Bstatic -o $oldlib $oldobjs' ;; *) _LT_TAGVAR(old_archive_cmds, $1)='$CC -o $oldlib $oldobjs' ;; esac ;; RCC*) # Rational C++ 2.4.1 # FIXME: insert proper C++ library support _LT_TAGVAR(ld_shlibs, $1)=no ;; cxx*) case $host in osf3*) _LT_TAGVAR(allow_undefined_flag, $1)=' $wl-expect_unresolved $wl\*' _LT_TAGVAR(archive_cmds, $1)='$CC -shared$allow_undefined_flag $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags $wl-soname $soname `test -n "$verstring" && func_echo_all "$wl-set_version $verstring"` -update_registry $output_objdir/so_locations -o $lib' _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='$wl-rpath $wl$libdir' ;; *) _LT_TAGVAR(allow_undefined_flag, $1)=' -expect_unresolved \*' _LT_TAGVAR(archive_cmds, $1)='$CC -shared$allow_undefined_flag $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags -msym -soname $soname `test -n "$verstring" && func_echo_all "-set_version $verstring"` -update_registry $output_objdir/so_locations -o $lib' _LT_TAGVAR(archive_expsym_cmds, $1)='for i in `cat $export_symbols`; do printf "%s %s\\n" -exported_symbol "\$i" >> $lib.exp; done~ echo "-hidden">> $lib.exp~ $CC -shared$allow_undefined_flag $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags -msym -soname $soname $wl-input $wl$lib.exp `test -n "$verstring" && $ECHO "-set_version $verstring"` -update_registry $output_objdir/so_locations -o $lib~ $RM $lib.exp' _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='-rpath $libdir' ;; esac _LT_TAGVAR(hardcode_libdir_separator, $1)=: # Commands to make compiler produce verbose output that lists # what "hidden" libraries, object files and flags are used when # linking a shared library. # # There doesn't appear to be a way to prevent this compiler from # explicitly linking system object files so we need to strip them # from the output so that they don't get included in the library # dependencies. output_verbose_link_cmd='templist=`$CC -shared $CFLAGS -v conftest.$objext 2>&1 | $GREP "ld" | $GREP -v "ld:"`; templist=`func_echo_all "$templist" | $SED "s/\(^.*ld.*\)\( .*ld.*$\)/\1/"`; list= ; for z in $templist; do case $z in conftest.$objext) list="$list $z";; *.$objext);; *) list="$list $z";;esac; done; func_echo_all "$list"' ;; *) if test yes,no = "$GXX,$with_gnu_ld"; then _LT_TAGVAR(allow_undefined_flag, $1)=' $wl-expect_unresolved $wl\*' case $host in osf3*) _LT_TAGVAR(archive_cmds, $1)='$CC -shared -nostdlib $allow_undefined_flag $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags $wl-soname $wl$soname `test -n "$verstring" && func_echo_all "$wl-set_version $wl$verstring"` $wl-update_registry $wl$output_objdir/so_locations -o $lib' ;; *) _LT_TAGVAR(archive_cmds, $1)='$CC -shared $pic_flag -nostdlib $allow_undefined_flag $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags $wl-msym $wl-soname $wl$soname `test -n "$verstring" && func_echo_all "$wl-set_version $wl$verstring"` $wl-update_registry $wl$output_objdir/so_locations -o $lib' ;; esac _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='$wl-rpath $wl$libdir' _LT_TAGVAR(hardcode_libdir_separator, $1)=: # Commands to make compiler produce verbose output that lists # what "hidden" libraries, object files and flags are used when # linking a shared library. output_verbose_link_cmd='$CC -shared $CFLAGS -v conftest.$objext 2>&1 | $GREP -v "^Configured with:" | $GREP "\-L"' else # FIXME: insert proper C++ library support _LT_TAGVAR(ld_shlibs, $1)=no fi ;; esac ;; psos*) # FIXME: insert proper C++ library support _LT_TAGVAR(ld_shlibs, $1)=no ;; sunos4*) case $cc_basename in CC*) # Sun C++ 4.x # FIXME: insert proper C++ library support _LT_TAGVAR(ld_shlibs, $1)=no ;; lcc*) # Lucid # FIXME: insert proper C++ library support _LT_TAGVAR(ld_shlibs, $1)=no ;; *) # FIXME: insert proper C++ library support _LT_TAGVAR(ld_shlibs, $1)=no ;; esac ;; solaris*) case $cc_basename in CC* | sunCC*) # Sun C++ 4.2, 5.x and Centerline C++ _LT_TAGVAR(archive_cmds_need_lc,$1)=yes _LT_TAGVAR(no_undefined_flag, $1)=' -zdefs' _LT_TAGVAR(archive_cmds, $1)='$CC -G$allow_undefined_flag -h$soname -o $lib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags' _LT_TAGVAR(archive_expsym_cmds, $1)='echo "{ global:" > $lib.exp~cat $export_symbols | $SED -e "s/\(.*\)/\1;/" >> $lib.exp~echo "local: *; };" >> $lib.exp~ $CC -G$allow_undefined_flag $wl-M $wl$lib.exp -h$soname -o $lib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags~$RM $lib.exp' _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='-R$libdir' _LT_TAGVAR(hardcode_shlibpath_var, $1)=no case $host_os in solaris2.[[0-5]] | solaris2.[[0-5]].*) ;; *) # The compiler driver will combine and reorder linker options, # but understands '-z linker_flag'. # Supported since Solaris 2.6 (maybe 2.5.1?) _LT_TAGVAR(whole_archive_flag_spec, $1)='-z allextract$convenience -z defaultextract' ;; esac _LT_TAGVAR(link_all_deplibs, $1)=yes output_verbose_link_cmd='func_echo_all' # Archives containing C++ object files must be created using # "CC -xar", where "CC" is the Sun C++ compiler. This is # necessary to make sure instantiated templates are included # in the archive. _LT_TAGVAR(old_archive_cmds, $1)='$CC -xar -o $oldlib $oldobjs' ;; gcx*) # Green Hills C++ Compiler _LT_TAGVAR(archive_cmds, $1)='$CC -shared $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags $wl-h $wl$soname -o $lib' # The C++ compiler must be used to create the archive. _LT_TAGVAR(old_archive_cmds, $1)='$CC $LDFLAGS -archive -o $oldlib $oldobjs' ;; *) # GNU C++ compiler with Solaris linker if test yes,no = "$GXX,$with_gnu_ld"; then _LT_TAGVAR(no_undefined_flag, $1)=' $wl-z ${wl}defs' if $CC --version | $GREP -v '^2\.7' > /dev/null; then _LT_TAGVAR(archive_cmds, $1)='$CC -shared $pic_flag -nostdlib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags $wl-h $wl$soname -o $lib' _LT_TAGVAR(archive_expsym_cmds, $1)='echo "{ global:" > $lib.exp~cat $export_symbols | $SED -e "s/\(.*\)/\1;/" >> $lib.exp~echo "local: *; };" >> $lib.exp~ $CC -shared $pic_flag -nostdlib $wl-M $wl$lib.exp $wl-h $wl$soname -o $lib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags~$RM $lib.exp' # Commands to make compiler produce verbose output that lists # what "hidden" libraries, object files and flags are used when # linking a shared library. output_verbose_link_cmd='$CC -shared $CFLAGS -v conftest.$objext 2>&1 | $GREP -v "^Configured with:" | $GREP "\-L"' else # g++ 2.7 appears to require '-G' NOT '-shared' on this # platform. _LT_TAGVAR(archive_cmds, $1)='$CC -G -nostdlib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags $wl-h $wl$soname -o $lib' _LT_TAGVAR(archive_expsym_cmds, $1)='echo "{ global:" > $lib.exp~cat $export_symbols | $SED -e "s/\(.*\)/\1;/" >> $lib.exp~echo "local: *; };" >> $lib.exp~ $CC -G -nostdlib $wl-M $wl$lib.exp $wl-h $wl$soname -o $lib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags~$RM $lib.exp' # Commands to make compiler produce verbose output that lists # what "hidden" libraries, object files and flags are used when # linking a shared library. output_verbose_link_cmd='$CC -G $CFLAGS -v conftest.$objext 2>&1 | $GREP -v "^Configured with:" | $GREP "\-L"' fi _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='$wl-R $wl$libdir' case $host_os in solaris2.[[0-5]] | solaris2.[[0-5]].*) ;; *) _LT_TAGVAR(whole_archive_flag_spec, $1)='$wl-z ${wl}allextract$convenience $wl-z ${wl}defaultextract' ;; esac fi ;; esac ;; sysv4*uw2* | sysv5OpenUNIX* | sysv5UnixWare7.[[01]].[[10]]* | unixware7* | sco3.2v5.0.[[024]]*) _LT_TAGVAR(no_undefined_flag, $1)='$wl-z,text' _LT_TAGVAR(archive_cmds_need_lc, $1)=no _LT_TAGVAR(hardcode_shlibpath_var, $1)=no runpath_var='LD_RUN_PATH' case $cc_basename in CC*) _LT_TAGVAR(archive_cmds, $1)='$CC -G $wl-h,$soname -o $lib $libobjs $deplibs $compiler_flags' _LT_TAGVAR(archive_expsym_cmds, $1)='$CC -G $wl-Bexport:$export_symbols $wl-h,$soname -o $lib $libobjs $deplibs $compiler_flags' ;; *) _LT_TAGVAR(archive_cmds, $1)='$CC -shared $wl-h,$soname -o $lib $libobjs $deplibs $compiler_flags' _LT_TAGVAR(archive_expsym_cmds, $1)='$CC -shared $wl-Bexport:$export_symbols $wl-h,$soname -o $lib $libobjs $deplibs $compiler_flags' ;; esac ;; sysv5* | sco3.2v5* | sco5v6*) # Note: We CANNOT use -z defs as we might desire, because we do not # link with -lc, and that would cause any symbols used from libc to # always be unresolved, which means just about no library would # ever link correctly. If we're not using GNU ld we use -z text # though, which does catch some bad symbols but isn't as heavy-handed # as -z defs. _LT_TAGVAR(no_undefined_flag, $1)='$wl-z,text' _LT_TAGVAR(allow_undefined_flag, $1)='$wl-z,nodefs' _LT_TAGVAR(archive_cmds_need_lc, $1)=no _LT_TAGVAR(hardcode_shlibpath_var, $1)=no _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='$wl-R,$libdir' _LT_TAGVAR(hardcode_libdir_separator, $1)=':' _LT_TAGVAR(link_all_deplibs, $1)=yes _LT_TAGVAR(export_dynamic_flag_spec, $1)='$wl-Bexport' runpath_var='LD_RUN_PATH' case $cc_basename in CC*) _LT_TAGVAR(archive_cmds, $1)='$CC -G $wl-h,$soname -o $lib $libobjs $deplibs $compiler_flags' _LT_TAGVAR(archive_expsym_cmds, $1)='$CC -G $wl-Bexport:$export_symbols $wl-h,$soname -o $lib $libobjs $deplibs $compiler_flags' _LT_TAGVAR(old_archive_cmds, $1)='$CC -Tprelink_objects $oldobjs~ '"$_LT_TAGVAR(old_archive_cmds, $1)" _LT_TAGVAR(reload_cmds, $1)='$CC -Tprelink_objects $reload_objs~ '"$_LT_TAGVAR(reload_cmds, $1)" ;; *) _LT_TAGVAR(archive_cmds, $1)='$CC -shared $wl-h,$soname -o $lib $libobjs $deplibs $compiler_flags' _LT_TAGVAR(archive_expsym_cmds, $1)='$CC -shared $wl-Bexport:$export_symbols $wl-h,$soname -o $lib $libobjs $deplibs $compiler_flags' ;; esac ;; tandem*) case $cc_basename in NCC*) # NonStop-UX NCC 3.20 # FIXME: insert proper C++ library support _LT_TAGVAR(ld_shlibs, $1)=no ;; *) # FIXME: insert proper C++ library support _LT_TAGVAR(ld_shlibs, $1)=no ;; esac ;; vxworks*) # FIXME: insert proper C++ library support _LT_TAGVAR(ld_shlibs, $1)=no ;; *) # FIXME: insert proper C++ library support _LT_TAGVAR(ld_shlibs, $1)=no ;; esac AC_MSG_RESULT([$_LT_TAGVAR(ld_shlibs, $1)]) test no = "$_LT_TAGVAR(ld_shlibs, $1)" && can_build_shared=no _LT_TAGVAR(GCC, $1)=$GXX _LT_TAGVAR(LD, $1)=$LD ## CAVEAT EMPTOR: ## There is no encapsulation within the following macros, do not change ## the running order or otherwise move them around unless you know exactly ## what you are doing... _LT_SYS_HIDDEN_LIBDEPS($1) _LT_COMPILER_PIC($1) _LT_COMPILER_C_O($1) _LT_COMPILER_FILE_LOCKS($1) _LT_LINKER_SHLIBS($1) _LT_SYS_DYNAMIC_LINKER($1) _LT_LINKER_HARDCODE_LIBPATH($1) _LT_CONFIG($1) fi # test -n "$compiler" CC=$lt_save_CC CFLAGS=$lt_save_CFLAGS LDCXX=$LD LD=$lt_save_LD GCC=$lt_save_GCC with_gnu_ld=$lt_save_with_gnu_ld lt_cv_path_LDCXX=$lt_cv_path_LD lt_cv_path_LD=$lt_save_path_LD lt_cv_prog_gnu_ldcxx=$lt_cv_prog_gnu_ld lt_cv_prog_gnu_ld=$lt_save_with_gnu_ld fi # test yes != "$_lt_caught_CXX_error" AC_LANG_POP ])# _LT_LANG_CXX_CONFIG # _LT_FUNC_STRIPNAME_CNF # ---------------------- # func_stripname_cnf prefix suffix name # strip PREFIX and SUFFIX off of NAME. # PREFIX and SUFFIX must not contain globbing or regex special # characters, hashes, percent signs, but SUFFIX may contain a leading # dot (in which case that matches only a dot). # # This function is identical to the (non-XSI) version of func_stripname, # except this one can be used by m4 code that may be executed by configure, # rather than the libtool script. m4_defun([_LT_FUNC_STRIPNAME_CNF],[dnl AC_REQUIRE([_LT_DECL_SED]) AC_REQUIRE([_LT_PROG_ECHO_BACKSLASH]) func_stripname_cnf () { case @S|@2 in .*) func_stripname_result=`$ECHO "@S|@3" | $SED "s%^@S|@1%%; s%\\\\@S|@2\$%%"`;; *) func_stripname_result=`$ECHO "@S|@3" | $SED "s%^@S|@1%%; s%@S|@2\$%%"`;; esac } # func_stripname_cnf ])# _LT_FUNC_STRIPNAME_CNF # _LT_SYS_HIDDEN_LIBDEPS([TAGNAME]) # --------------------------------- # Figure out "hidden" library dependencies from verbose # compiler output when linking a shared library. # Parse the compiler output and extract the necessary # objects, libraries and library flags. m4_defun([_LT_SYS_HIDDEN_LIBDEPS], [m4_require([_LT_FILEUTILS_DEFAULTS])dnl AC_REQUIRE([_LT_FUNC_STRIPNAME_CNF])dnl # Dependencies to place before and after the object being linked: _LT_TAGVAR(predep_objects, $1)= _LT_TAGVAR(postdep_objects, $1)= _LT_TAGVAR(predeps, $1)= _LT_TAGVAR(postdeps, $1)= _LT_TAGVAR(compiler_lib_search_path, $1)= dnl we can't use the lt_simple_compile_test_code here, dnl because it contains code intended for an executable, dnl not a library. It's possible we should let each dnl tag define a new lt_????_link_test_code variable, dnl but it's only used here... m4_if([$1], [], [cat > conftest.$ac_ext <<_LT_EOF int a; void foo (void) { a = 0; } _LT_EOF ], [$1], [CXX], [cat > conftest.$ac_ext <<_LT_EOF class Foo { public: Foo (void) { a = 0; } private: int a; }; _LT_EOF ], [$1], [F77], [cat > conftest.$ac_ext <<_LT_EOF subroutine foo implicit none integer*4 a a=0 return end _LT_EOF ], [$1], [FC], [cat > conftest.$ac_ext <<_LT_EOF subroutine foo implicit none integer a a=0 return end _LT_EOF ], [$1], [GCJ], [cat > conftest.$ac_ext <<_LT_EOF public class foo { private int a; public void bar (void) { a = 0; } }; _LT_EOF ], [$1], [GO], [cat > conftest.$ac_ext <<_LT_EOF package foo func foo() { } _LT_EOF ]) _lt_libdeps_save_CFLAGS=$CFLAGS case "$CC $CFLAGS " in #( *\ -flto*\ *) CFLAGS="$CFLAGS -fno-lto" ;; *\ -fwhopr*\ *) CFLAGS="$CFLAGS -fno-whopr" ;; *\ -fuse-linker-plugin*\ *) CFLAGS="$CFLAGS -fno-use-linker-plugin" ;; esac dnl Parse the compiler output and extract the necessary dnl objects, libraries and library flags. if AC_TRY_EVAL(ac_compile); then # Parse the compiler output and extract the necessary # objects, libraries and library flags. # Sentinel used to keep track of whether or not we are before # the conftest object file. pre_test_object_deps_done=no for p in `eval "$output_verbose_link_cmd"`; do case $prev$p in -L* | -R* | -l*) # Some compilers place space between "-{L,R}" and the path. # Remove the space. if test x-L = "$p" || test x-R = "$p"; then prev=$p continue fi # Expand the sysroot to ease extracting the directories later. if test -z "$prev"; then case $p in -L*) func_stripname_cnf '-L' '' "$p"; prev=-L; p=$func_stripname_result ;; -R*) func_stripname_cnf '-R' '' "$p"; prev=-R; p=$func_stripname_result ;; -l*) func_stripname_cnf '-l' '' "$p"; prev=-l; p=$func_stripname_result ;; esac fi case $p in =*) func_stripname_cnf '=' '' "$p"; p=$lt_sysroot$func_stripname_result ;; esac if test no = "$pre_test_object_deps_done"; then case $prev in -L | -R) # Internal compiler library paths should come after those # provided the user. The postdeps already come after the # user supplied libs so there is no need to process them. if test -z "$_LT_TAGVAR(compiler_lib_search_path, $1)"; then _LT_TAGVAR(compiler_lib_search_path, $1)=$prev$p else _LT_TAGVAR(compiler_lib_search_path, $1)="${_LT_TAGVAR(compiler_lib_search_path, $1)} $prev$p" fi ;; # The "-l" case would never come before the object being # linked, so don't bother handling this case. esac else if test -z "$_LT_TAGVAR(postdeps, $1)"; then _LT_TAGVAR(postdeps, $1)=$prev$p else _LT_TAGVAR(postdeps, $1)="${_LT_TAGVAR(postdeps, $1)} $prev$p" fi fi prev= ;; *.lto.$objext) ;; # Ignore GCC LTO objects *.$objext) # This assumes that the test object file only shows up # once in the compiler output. if test "$p" = "conftest.$objext"; then pre_test_object_deps_done=yes continue fi if test no = "$pre_test_object_deps_done"; then if test -z "$_LT_TAGVAR(predep_objects, $1)"; then _LT_TAGVAR(predep_objects, $1)=$p else _LT_TAGVAR(predep_objects, $1)="$_LT_TAGVAR(predep_objects, $1) $p" fi else if test -z "$_LT_TAGVAR(postdep_objects, $1)"; then _LT_TAGVAR(postdep_objects, $1)=$p else _LT_TAGVAR(postdep_objects, $1)="$_LT_TAGVAR(postdep_objects, $1) $p" fi fi ;; *) ;; # Ignore the rest. esac done # Clean up. rm -f a.out a.exe else echo "libtool.m4: error: problem compiling $1 test program" fi $RM -f confest.$objext CFLAGS=$_lt_libdeps_save_CFLAGS # PORTME: override above test on systems where it is broken m4_if([$1], [CXX], [case $host_os in interix[[3-9]]*) # Interix 3.5 installs completely hosed .la files for C++, so rather than # hack all around it, let's just trust "g++" to DTRT. _LT_TAGVAR(predep_objects,$1)= _LT_TAGVAR(postdep_objects,$1)= _LT_TAGVAR(postdeps,$1)= ;; esac ]) case " $_LT_TAGVAR(postdeps, $1) " in *" -lc "*) _LT_TAGVAR(archive_cmds_need_lc, $1)=no ;; esac _LT_TAGVAR(compiler_lib_search_dirs, $1)= if test -n "${_LT_TAGVAR(compiler_lib_search_path, $1)}"; then _LT_TAGVAR(compiler_lib_search_dirs, $1)=`echo " ${_LT_TAGVAR(compiler_lib_search_path, $1)}" | $SED -e 's! -L! !g' -e 's!^ !!'` fi _LT_TAGDECL([], [compiler_lib_search_dirs], [1], [The directories searched by this compiler when creating a shared library]) _LT_TAGDECL([], [predep_objects], [1], [Dependencies to place before and after the objects being linked to create a shared library]) _LT_TAGDECL([], [postdep_objects], [1]) _LT_TAGDECL([], [predeps], [1]) _LT_TAGDECL([], [postdeps], [1]) _LT_TAGDECL([], [compiler_lib_search_path], [1], [The library search path used internally by the compiler when linking a shared library]) ])# _LT_SYS_HIDDEN_LIBDEPS # _LT_LANG_F77_CONFIG([TAG]) # -------------------------- # Ensure that the configuration variables for a Fortran 77 compiler are # suitably defined. These variables are subsequently used by _LT_CONFIG # to write the compiler configuration to 'libtool'. m4_defun([_LT_LANG_F77_CONFIG], [AC_LANG_PUSH(Fortran 77) if test -z "$F77" || test no = "$F77"; then _lt_disable_F77=yes fi _LT_TAGVAR(archive_cmds_need_lc, $1)=no _LT_TAGVAR(allow_undefined_flag, $1)= _LT_TAGVAR(always_export_symbols, $1)=no _LT_TAGVAR(archive_expsym_cmds, $1)= _LT_TAGVAR(export_dynamic_flag_spec, $1)= _LT_TAGVAR(hardcode_direct, $1)=no _LT_TAGVAR(hardcode_direct_absolute, $1)=no _LT_TAGVAR(hardcode_libdir_flag_spec, $1)= _LT_TAGVAR(hardcode_libdir_separator, $1)= _LT_TAGVAR(hardcode_minus_L, $1)=no _LT_TAGVAR(hardcode_automatic, $1)=no _LT_TAGVAR(inherit_rpath, $1)=no _LT_TAGVAR(module_cmds, $1)= _LT_TAGVAR(module_expsym_cmds, $1)= _LT_TAGVAR(link_all_deplibs, $1)=unknown _LT_TAGVAR(old_archive_cmds, $1)=$old_archive_cmds _LT_TAGVAR(reload_flag, $1)=$reload_flag _LT_TAGVAR(reload_cmds, $1)=$reload_cmds _LT_TAGVAR(no_undefined_flag, $1)= _LT_TAGVAR(whole_archive_flag_spec, $1)= _LT_TAGVAR(enable_shared_with_static_runtimes, $1)=no # Source file extension for f77 test sources. ac_ext=f # Object file extension for compiled f77 test sources. objext=o _LT_TAGVAR(objext, $1)=$objext # No sense in running all these tests if we already determined that # the F77 compiler isn't working. Some variables (like enable_shared) # are currently assumed to apply to all compilers on this platform, # and will be corrupted by setting them based on a non-working compiler. if test yes != "$_lt_disable_F77"; then # Code to be used in simple compile tests lt_simple_compile_test_code="\ subroutine t return end " # Code to be used in simple link tests lt_simple_link_test_code="\ program t end " # ltmain only uses $CC for tagged configurations so make sure $CC is set. _LT_TAG_COMPILER # save warnings/boilerplate of simple test code _LT_COMPILER_BOILERPLATE _LT_LINKER_BOILERPLATE # Allow CC to be a program name with arguments. lt_save_CC=$CC lt_save_GCC=$GCC lt_save_CFLAGS=$CFLAGS CC=${F77-"f77"} CFLAGS=$FFLAGS compiler=$CC _LT_TAGVAR(compiler, $1)=$CC _LT_CC_BASENAME([$compiler]) GCC=$G77 if test -n "$compiler"; then AC_MSG_CHECKING([if libtool supports shared libraries]) AC_MSG_RESULT([$can_build_shared]) AC_MSG_CHECKING([whether to build shared libraries]) test no = "$can_build_shared" && enable_shared=no # On AIX, shared libraries and static libraries use the same namespace, and # are all built from PIC. case $host_os in aix3*) test yes = "$enable_shared" && enable_static=no if test -n "$RANLIB"; then archive_cmds="$archive_cmds~\$RANLIB \$lib" postinstall_cmds='$RANLIB $lib' fi ;; aix[[4-9]]*) if test ia64 != "$host_cpu"; then case $enable_shared,$with_aix_soname,$aix_use_runtimelinking in yes,aix,yes) ;; # shared object as lib.so file only yes,svr4,*) ;; # shared object as lib.so archive member only yes,*) enable_static=no ;; # shared object in lib.a archive as well esac fi ;; esac AC_MSG_RESULT([$enable_shared]) AC_MSG_CHECKING([whether to build static libraries]) # Make sure either enable_shared or enable_static is yes. test yes = "$enable_shared" || enable_static=yes AC_MSG_RESULT([$enable_static]) _LT_TAGVAR(GCC, $1)=$G77 _LT_TAGVAR(LD, $1)=$LD ## CAVEAT EMPTOR: ## There is no encapsulation within the following macros, do not change ## the running order or otherwise move them around unless you know exactly ## what you are doing... _LT_COMPILER_PIC($1) _LT_COMPILER_C_O($1) _LT_COMPILER_FILE_LOCKS($1) _LT_LINKER_SHLIBS($1) _LT_SYS_DYNAMIC_LINKER($1) _LT_LINKER_HARDCODE_LIBPATH($1) _LT_CONFIG($1) fi # test -n "$compiler" GCC=$lt_save_GCC CC=$lt_save_CC CFLAGS=$lt_save_CFLAGS fi # test yes != "$_lt_disable_F77" AC_LANG_POP ])# _LT_LANG_F77_CONFIG # _LT_LANG_FC_CONFIG([TAG]) # ------------------------- # Ensure that the configuration variables for a Fortran compiler are # suitably defined. These variables are subsequently used by _LT_CONFIG # to write the compiler configuration to 'libtool'. m4_defun([_LT_LANG_FC_CONFIG], [AC_LANG_PUSH(Fortran) if test -z "$FC" || test no = "$FC"; then _lt_disable_FC=yes fi _LT_TAGVAR(archive_cmds_need_lc, $1)=no _LT_TAGVAR(allow_undefined_flag, $1)= _LT_TAGVAR(always_export_symbols, $1)=no _LT_TAGVAR(archive_expsym_cmds, $1)= _LT_TAGVAR(export_dynamic_flag_spec, $1)= _LT_TAGVAR(hardcode_direct, $1)=no _LT_TAGVAR(hardcode_direct_absolute, $1)=no _LT_TAGVAR(hardcode_libdir_flag_spec, $1)= _LT_TAGVAR(hardcode_libdir_separator, $1)= _LT_TAGVAR(hardcode_minus_L, $1)=no _LT_TAGVAR(hardcode_automatic, $1)=no _LT_TAGVAR(inherit_rpath, $1)=no _LT_TAGVAR(module_cmds, $1)= _LT_TAGVAR(module_expsym_cmds, $1)= _LT_TAGVAR(link_all_deplibs, $1)=unknown _LT_TAGVAR(old_archive_cmds, $1)=$old_archive_cmds _LT_TAGVAR(reload_flag, $1)=$reload_flag _LT_TAGVAR(reload_cmds, $1)=$reload_cmds _LT_TAGVAR(no_undefined_flag, $1)= _LT_TAGVAR(whole_archive_flag_spec, $1)= _LT_TAGVAR(enable_shared_with_static_runtimes, $1)=no # Source file extension for fc test sources. ac_ext=${ac_fc_srcext-f} # Object file extension for compiled fc test sources. objext=o _LT_TAGVAR(objext, $1)=$objext # No sense in running all these tests if we already determined that # the FC compiler isn't working. Some variables (like enable_shared) # are currently assumed to apply to all compilers on this platform, # and will be corrupted by setting them based on a non-working compiler. if test yes != "$_lt_disable_FC"; then # Code to be used in simple compile tests lt_simple_compile_test_code="\ subroutine t return end " # Code to be used in simple link tests lt_simple_link_test_code="\ program t end " # ltmain only uses $CC for tagged configurations so make sure $CC is set. _LT_TAG_COMPILER # save warnings/boilerplate of simple test code _LT_COMPILER_BOILERPLATE _LT_LINKER_BOILERPLATE # Allow CC to be a program name with arguments. lt_save_CC=$CC lt_save_GCC=$GCC lt_save_CFLAGS=$CFLAGS CC=${FC-"f95"} CFLAGS=$FCFLAGS compiler=$CC GCC=$ac_cv_fc_compiler_gnu _LT_TAGVAR(compiler, $1)=$CC _LT_CC_BASENAME([$compiler]) if test -n "$compiler"; then AC_MSG_CHECKING([if libtool supports shared libraries]) AC_MSG_RESULT([$can_build_shared]) AC_MSG_CHECKING([whether to build shared libraries]) test no = "$can_build_shared" && enable_shared=no # On AIX, shared libraries and static libraries use the same namespace, and # are all built from PIC. case $host_os in aix3*) test yes = "$enable_shared" && enable_static=no if test -n "$RANLIB"; then archive_cmds="$archive_cmds~\$RANLIB \$lib" postinstall_cmds='$RANLIB $lib' fi ;; aix[[4-9]]*) if test ia64 != "$host_cpu"; then case $enable_shared,$with_aix_soname,$aix_use_runtimelinking in yes,aix,yes) ;; # shared object as lib.so file only yes,svr4,*) ;; # shared object as lib.so archive member only yes,*) enable_static=no ;; # shared object in lib.a archive as well esac fi ;; esac AC_MSG_RESULT([$enable_shared]) AC_MSG_CHECKING([whether to build static libraries]) # Make sure either enable_shared or enable_static is yes. test yes = "$enable_shared" || enable_static=yes AC_MSG_RESULT([$enable_static]) _LT_TAGVAR(GCC, $1)=$ac_cv_fc_compiler_gnu _LT_TAGVAR(LD, $1)=$LD ## CAVEAT EMPTOR: ## There is no encapsulation within the following macros, do not change ## the running order or otherwise move them around unless you know exactly ## what you are doing... _LT_SYS_HIDDEN_LIBDEPS($1) _LT_COMPILER_PIC($1) _LT_COMPILER_C_O($1) _LT_COMPILER_FILE_LOCKS($1) _LT_LINKER_SHLIBS($1) _LT_SYS_DYNAMIC_LINKER($1) _LT_LINKER_HARDCODE_LIBPATH($1) _LT_CONFIG($1) fi # test -n "$compiler" GCC=$lt_save_GCC CC=$lt_save_CC CFLAGS=$lt_save_CFLAGS fi # test yes != "$_lt_disable_FC" AC_LANG_POP ])# _LT_LANG_FC_CONFIG # _LT_LANG_GCJ_CONFIG([TAG]) # -------------------------- # Ensure that the configuration variables for the GNU Java Compiler compiler # are suitably defined. These variables are subsequently used by _LT_CONFIG # to write the compiler configuration to 'libtool'. m4_defun([_LT_LANG_GCJ_CONFIG], [AC_REQUIRE([LT_PROG_GCJ])dnl AC_LANG_SAVE # Source file extension for Java test sources. ac_ext=java # Object file extension for compiled Java test sources. objext=o _LT_TAGVAR(objext, $1)=$objext # Code to be used in simple compile tests lt_simple_compile_test_code="class foo {}" # Code to be used in simple link tests lt_simple_link_test_code='public class conftest { public static void main(String[[]] argv) {}; }' # ltmain only uses $CC for tagged configurations so make sure $CC is set. _LT_TAG_COMPILER # save warnings/boilerplate of simple test code _LT_COMPILER_BOILERPLATE _LT_LINKER_BOILERPLATE # Allow CC to be a program name with arguments. lt_save_CC=$CC lt_save_CFLAGS=$CFLAGS lt_save_GCC=$GCC GCC=yes CC=${GCJ-"gcj"} CFLAGS=$GCJFLAGS compiler=$CC _LT_TAGVAR(compiler, $1)=$CC _LT_TAGVAR(LD, $1)=$LD _LT_CC_BASENAME([$compiler]) # GCJ did not exist at the time GCC didn't implicitly link libc in. _LT_TAGVAR(archive_cmds_need_lc, $1)=no _LT_TAGVAR(old_archive_cmds, $1)=$old_archive_cmds _LT_TAGVAR(reload_flag, $1)=$reload_flag _LT_TAGVAR(reload_cmds, $1)=$reload_cmds ## CAVEAT EMPTOR: ## There is no encapsulation within the following macros, do not change ## the running order or otherwise move them around unless you know exactly ## what you are doing... if test -n "$compiler"; then _LT_COMPILER_NO_RTTI($1) _LT_COMPILER_PIC($1) _LT_COMPILER_C_O($1) _LT_COMPILER_FILE_LOCKS($1) _LT_LINKER_SHLIBS($1) _LT_LINKER_HARDCODE_LIBPATH($1) _LT_CONFIG($1) fi AC_LANG_RESTORE GCC=$lt_save_GCC CC=$lt_save_CC CFLAGS=$lt_save_CFLAGS ])# _LT_LANG_GCJ_CONFIG # _LT_LANG_GO_CONFIG([TAG]) # -------------------------- # Ensure that the configuration variables for the GNU Go compiler # are suitably defined. These variables are subsequently used by _LT_CONFIG # to write the compiler configuration to 'libtool'. m4_defun([_LT_LANG_GO_CONFIG], [AC_REQUIRE([LT_PROG_GO])dnl AC_LANG_SAVE # Source file extension for Go test sources. ac_ext=go # Object file extension for compiled Go test sources. objext=o _LT_TAGVAR(objext, $1)=$objext # Code to be used in simple compile tests lt_simple_compile_test_code="package main; func main() { }" # Code to be used in simple link tests lt_simple_link_test_code='package main; func main() { }' # ltmain only uses $CC for tagged configurations so make sure $CC is set. _LT_TAG_COMPILER # save warnings/boilerplate of simple test code _LT_COMPILER_BOILERPLATE _LT_LINKER_BOILERPLATE # Allow CC to be a program name with arguments. lt_save_CC=$CC lt_save_CFLAGS=$CFLAGS lt_save_GCC=$GCC GCC=yes CC=${GOC-"gccgo"} CFLAGS=$GOFLAGS compiler=$CC _LT_TAGVAR(compiler, $1)=$CC _LT_TAGVAR(LD, $1)=$LD _LT_CC_BASENAME([$compiler]) # Go did not exist at the time GCC didn't implicitly link libc in. _LT_TAGVAR(archive_cmds_need_lc, $1)=no _LT_TAGVAR(old_archive_cmds, $1)=$old_archive_cmds _LT_TAGVAR(reload_flag, $1)=$reload_flag _LT_TAGVAR(reload_cmds, $1)=$reload_cmds ## CAVEAT EMPTOR: ## There is no encapsulation within the following macros, do not change ## the running order or otherwise move them around unless you know exactly ## what you are doing... if test -n "$compiler"; then _LT_COMPILER_NO_RTTI($1) _LT_COMPILER_PIC($1) _LT_COMPILER_C_O($1) _LT_COMPILER_FILE_LOCKS($1) _LT_LINKER_SHLIBS($1) _LT_LINKER_HARDCODE_LIBPATH($1) _LT_CONFIG($1) fi AC_LANG_RESTORE GCC=$lt_save_GCC CC=$lt_save_CC CFLAGS=$lt_save_CFLAGS ])# _LT_LANG_GO_CONFIG # _LT_LANG_RC_CONFIG([TAG]) # ------------------------- # Ensure that the configuration variables for the Windows resource compiler # are suitably defined. These variables are subsequently used by _LT_CONFIG # to write the compiler configuration to 'libtool'. m4_defun([_LT_LANG_RC_CONFIG], [AC_REQUIRE([LT_PROG_RC])dnl AC_LANG_SAVE # Source file extension for RC test sources. ac_ext=rc # Object file extension for compiled RC test sources. objext=o _LT_TAGVAR(objext, $1)=$objext # Code to be used in simple compile tests lt_simple_compile_test_code='sample MENU { MENUITEM "&Soup", 100, CHECKED }' # Code to be used in simple link tests lt_simple_link_test_code=$lt_simple_compile_test_code # ltmain only uses $CC for tagged configurations so make sure $CC is set. _LT_TAG_COMPILER # save warnings/boilerplate of simple test code _LT_COMPILER_BOILERPLATE _LT_LINKER_BOILERPLATE # Allow CC to be a program name with arguments. lt_save_CC=$CC lt_save_CFLAGS=$CFLAGS lt_save_GCC=$GCC GCC= CC=${RC-"windres"} CFLAGS= compiler=$CC _LT_TAGVAR(compiler, $1)=$CC _LT_CC_BASENAME([$compiler]) _LT_TAGVAR(lt_cv_prog_compiler_c_o, $1)=yes if test -n "$compiler"; then : _LT_CONFIG($1) fi GCC=$lt_save_GCC AC_LANG_RESTORE CC=$lt_save_CC CFLAGS=$lt_save_CFLAGS ])# _LT_LANG_RC_CONFIG # LT_PROG_GCJ # ----------- AC_DEFUN([LT_PROG_GCJ], [m4_ifdef([AC_PROG_GCJ], [AC_PROG_GCJ], [m4_ifdef([A][M_PROG_GCJ], [A][M_PROG_GCJ], [AC_CHECK_TOOL(GCJ, gcj,) test set = "${GCJFLAGS+set}" || GCJFLAGS="-g -O2" AC_SUBST(GCJFLAGS)])])[]dnl ]) # Old name: AU_ALIAS([LT_AC_PROG_GCJ], [LT_PROG_GCJ]) dnl aclocal-1.4 backwards compatibility: dnl AC_DEFUN([LT_AC_PROG_GCJ], []) # LT_PROG_GO # ---------- AC_DEFUN([LT_PROG_GO], [AC_CHECK_TOOL(GOC, gccgo,) ]) # LT_PROG_RC # ---------- AC_DEFUN([LT_PROG_RC], [AC_CHECK_TOOL(RC, windres,) ]) # Old name: AU_ALIAS([LT_AC_PROG_RC], [LT_PROG_RC]) dnl aclocal-1.4 backwards compatibility: dnl AC_DEFUN([LT_AC_PROG_RC], []) # _LT_DECL_EGREP # -------------- # If we don't have a new enough Autoconf to choose the best grep # available, choose the one first in the user's PATH. m4_defun([_LT_DECL_EGREP], [AC_REQUIRE([AC_PROG_EGREP])dnl AC_REQUIRE([AC_PROG_FGREP])dnl test -z "$GREP" && GREP=grep _LT_DECL([], [GREP], [1], [A grep program that handles long lines]) _LT_DECL([], [EGREP], [1], [An ERE matcher]) _LT_DECL([], [FGREP], [1], [A literal string matcher]) dnl Non-bleeding-edge autoconf doesn't subst GREP, so do it here too AC_SUBST([GREP]) ]) # _LT_DECL_OBJDUMP # -------------- # If we don't have a new enough Autoconf to choose the best objdump # available, choose the one first in the user's PATH. m4_defun([_LT_DECL_OBJDUMP], [AC_CHECK_TOOL(OBJDUMP, objdump, false) test -z "$OBJDUMP" && OBJDUMP=objdump _LT_DECL([], [OBJDUMP], [1], [An object symbol dumper]) AC_SUBST([OBJDUMP]) ]) # _LT_DECL_DLLTOOL # ---------------- # Ensure DLLTOOL variable is set. m4_defun([_LT_DECL_DLLTOOL], [AC_CHECK_TOOL(DLLTOOL, dlltool, false) test -z "$DLLTOOL" && DLLTOOL=dlltool _LT_DECL([], [DLLTOOL], [1], [DLL creation program]) AC_SUBST([DLLTOOL]) ]) # _LT_DECL_SED # ------------ # Check for a fully-functional sed program, that truncates # as few characters as possible. Prefer GNU sed if found. m4_defun([_LT_DECL_SED], [AC_PROG_SED test -z "$SED" && SED=sed Xsed="$SED -e 1s/^X//" _LT_DECL([], [SED], [1], [A sed program that does not truncate output]) _LT_DECL([], [Xsed], ["\$SED -e 1s/^X//"], [Sed that helps us avoid accidentally triggering echo(1) options like -n]) ])# _LT_DECL_SED m4_ifndef([AC_PROG_SED], [ ############################################################ # NOTE: This macro has been submitted for inclusion into # # GNU Autoconf as AC_PROG_SED. When it is available in # # a released version of Autoconf we should remove this # # macro and use it instead. # ############################################################ m4_defun([AC_PROG_SED], [AC_MSG_CHECKING([for a sed that does not truncate output]) AC_CACHE_VAL(lt_cv_path_SED, [# Loop through the user's path and test for sed and gsed. # Then use that list of sed's as ones to test for truncation. as_save_IFS=$IFS; IFS=$PATH_SEPARATOR for as_dir in $PATH do IFS=$as_save_IFS test -z "$as_dir" && as_dir=. for lt_ac_prog in sed gsed; do for ac_exec_ext in '' $ac_executable_extensions; do if $as_executable_p "$as_dir/$lt_ac_prog$ac_exec_ext"; then lt_ac_sed_list="$lt_ac_sed_list $as_dir/$lt_ac_prog$ac_exec_ext" fi done done done IFS=$as_save_IFS lt_ac_max=0 lt_ac_count=0 # Add /usr/xpg4/bin/sed as it is typically found on Solaris # along with /bin/sed that truncates output. for lt_ac_sed in $lt_ac_sed_list /usr/xpg4/bin/sed; do test ! -f "$lt_ac_sed" && continue cat /dev/null > conftest.in lt_ac_count=0 echo $ECHO_N "0123456789$ECHO_C" >conftest.in # Check for GNU sed and select it if it is found. if "$lt_ac_sed" --version 2>&1 < /dev/null | grep 'GNU' > /dev/null; then lt_cv_path_SED=$lt_ac_sed break fi while true; do cat conftest.in conftest.in >conftest.tmp mv conftest.tmp conftest.in cp conftest.in conftest.nl echo >>conftest.nl $lt_ac_sed -e 's/a$//' < conftest.nl >conftest.out || break cmp -s conftest.out conftest.nl || break # 10000 chars as input seems more than enough test 10 -lt "$lt_ac_count" && break lt_ac_count=`expr $lt_ac_count + 1` if test "$lt_ac_count" -gt "$lt_ac_max"; then lt_ac_max=$lt_ac_count lt_cv_path_SED=$lt_ac_sed fi done done ]) SED=$lt_cv_path_SED AC_SUBST([SED]) AC_MSG_RESULT([$SED]) ])#AC_PROG_SED ])#m4_ifndef # Old name: AU_ALIAS([LT_AC_PROG_SED], [AC_PROG_SED]) dnl aclocal-1.4 backwards compatibility: dnl AC_DEFUN([LT_AC_PROG_SED], []) # _LT_CHECK_SHELL_FEATURES # ------------------------ # Find out whether the shell is Bourne or XSI compatible, # or has some other useful features. m4_defun([_LT_CHECK_SHELL_FEATURES], [if ( (MAIL=60; unset MAIL) || exit) >/dev/null 2>&1; then lt_unset=unset else lt_unset=false fi _LT_DECL([], [lt_unset], [0], [whether the shell understands "unset"])dnl # test EBCDIC or ASCII case `echo X|tr X '\101'` in A) # ASCII based system # \n is not interpreted correctly by Solaris 8 /usr/ucb/tr lt_SP2NL='tr \040 \012' lt_NL2SP='tr \015\012 \040\040' ;; *) # EBCDIC based system lt_SP2NL='tr \100 \n' lt_NL2SP='tr \r\n \100\100' ;; esac _LT_DECL([SP2NL], [lt_SP2NL], [1], [turn spaces into newlines])dnl _LT_DECL([NL2SP], [lt_NL2SP], [1], [turn newlines into spaces])dnl ])# _LT_CHECK_SHELL_FEATURES # _LT_PATH_CONVERSION_FUNCTIONS # ----------------------------- # Determine what file name conversion functions should be used by # func_to_host_file (and, implicitly, by func_to_host_path). These are needed # for certain cross-compile configurations and native mingw. m4_defun([_LT_PATH_CONVERSION_FUNCTIONS], [AC_REQUIRE([AC_CANONICAL_HOST])dnl AC_REQUIRE([AC_CANONICAL_BUILD])dnl AC_MSG_CHECKING([how to convert $build file names to $host format]) AC_CACHE_VAL(lt_cv_to_host_file_cmd, [case $host in *-*-mingw* ) case $build in *-*-mingw* ) # actually msys lt_cv_to_host_file_cmd=func_convert_file_msys_to_w32 ;; *-*-cygwin* ) lt_cv_to_host_file_cmd=func_convert_file_cygwin_to_w32 ;; * ) # otherwise, assume *nix lt_cv_to_host_file_cmd=func_convert_file_nix_to_w32 ;; esac ;; *-*-cygwin* ) case $build in *-*-mingw* ) # actually msys lt_cv_to_host_file_cmd=func_convert_file_msys_to_cygwin ;; *-*-cygwin* ) lt_cv_to_host_file_cmd=func_convert_file_noop ;; * ) # otherwise, assume *nix lt_cv_to_host_file_cmd=func_convert_file_nix_to_cygwin ;; esac ;; * ) # unhandled hosts (and "normal" native builds) lt_cv_to_host_file_cmd=func_convert_file_noop ;; esac ]) to_host_file_cmd=$lt_cv_to_host_file_cmd AC_MSG_RESULT([$lt_cv_to_host_file_cmd]) _LT_DECL([to_host_file_cmd], [lt_cv_to_host_file_cmd], [0], [convert $build file names to $host format])dnl AC_MSG_CHECKING([how to convert $build file names to toolchain format]) AC_CACHE_VAL(lt_cv_to_tool_file_cmd, [#assume ordinary cross tools, or native build. lt_cv_to_tool_file_cmd=func_convert_file_noop case $host in *-*-mingw* ) case $build in *-*-mingw* ) # actually msys lt_cv_to_tool_file_cmd=func_convert_file_msys_to_w32 ;; esac ;; esac ]) to_tool_file_cmd=$lt_cv_to_tool_file_cmd AC_MSG_RESULT([$lt_cv_to_tool_file_cmd]) _LT_DECL([to_tool_file_cmd], [lt_cv_to_tool_file_cmd], [0], [convert $build files to toolchain format])dnl ])# _LT_PATH_CONVERSION_FUNCTIONS xrdp-0.9.5/librfxcodec/m4/ltversion.m4000644 001751 001751 00000001273 13220730751 017520 0ustar00metameta000000 000000 # ltversion.m4 -- version numbers -*- Autoconf -*- # # Copyright (C) 2004, 2011-2015 Free Software Foundation, Inc. # Written by Scott James Remnant, 2004 # # This file is free software; the Free Software Foundation gives # unlimited permission to copy and/or distribute it, with or without # modifications, as long as this notice is preserved. # @configure_input@ # serial 4179 ltversion.m4 # This file is part of GNU Libtool m4_define([LT_PACKAGE_VERSION], [2.4.6]) m4_define([LT_PACKAGE_REVISION], [2.4.6]) AC_DEFUN([LTVERSION_VERSION], [macro_version='2.4.6' macro_revision='2.4.6' _LT_DECL(, macro_version, 0, [Which release of libtool.m4 was used?]) _LT_DECL(, macro_revision, 0) ]) xrdp-0.9.5/librfxcodec/m4/ax_cflags_warn_all.m4000644 001751 001751 00000011703 13127342056 021303 0ustar00metameta000000 000000 # =========================================================================== # https://www.gnu.org/software/autoconf-archive/ax_cflags_warn_all.html # =========================================================================== # # SYNOPSIS # # AX_CFLAGS_WARN_ALL [(shellvar [,default, [A/NA]])] # AX_CXXFLAGS_WARN_ALL [(shellvar [,default, [A/NA]])] # AX_FCFLAGS_WARN_ALL [(shellvar [,default, [A/NA]])] # # DESCRIPTION # # Try to find a compiler option that enables most reasonable warnings. # # For the GNU compiler it will be -Wall (and -ansi -pedantic) The result # is added to the shellvar being CFLAGS, CXXFLAGS, or FCFLAGS by default. # # Currently this macro knows about the GCC, Solaris, Digital Unix, AIX, # HP-UX, IRIX, NEC SX-5 (Super-UX 10), Cray J90 (Unicos 10.0.0.8), and # Intel compilers. For a given compiler, the Fortran flags are much more # experimental than their C equivalents. # # - $1 shell-variable-to-add-to : CFLAGS, CXXFLAGS, or FCFLAGS # - $2 add-value-if-not-found : nothing # - $3 action-if-found : add value to shellvariable # - $4 action-if-not-found : nothing # # NOTE: These macros depend on AX_APPEND_FLAG. # # LICENSE # # Copyright (c) 2008 Guido U. Draheim # Copyright (c) 2010 Rhys Ulerich # # 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. # # You should have received a copy of the GNU General Public License along # with this program. If not, see . # # As a special exception, the respective Autoconf Macro's copyright owner # gives unlimited permission to copy, distribute and modify the configure # scripts that are the output of Autoconf when processing the Macro. You # need not follow the terms of the GNU General Public License when using # or distributing such scripts, even though portions of the text of the # Macro appear in them. The GNU General Public License (GPL) does govern # all other use of the material that constitutes the Autoconf Macro. # # This special exception to the GPL applies to versions of the Autoconf # Macro released by the Autoconf Archive. When you make and distribute a # modified version of the Autoconf Macro, you may extend this special # exception to the GPL to apply to your modified version as well. #serial 16 AC_DEFUN([AX_FLAGS_WARN_ALL],[dnl AS_VAR_PUSHDEF([FLAGS],[_AC_LANG_PREFIX[]FLAGS])dnl AS_VAR_PUSHDEF([VAR],[ac_cv_[]_AC_LANG_ABBREV[]flags_warn_all])dnl AC_CACHE_CHECK([m4_ifval($1,$1,FLAGS) for maximum warnings], VAR,[VAR="no, unknown" ac_save_[]FLAGS="$[]FLAGS" for ac_arg dnl in "-warn all % -warn all" dnl Intel "-pedantic % -Wall" dnl GCC "-xstrconst % -v" dnl Solaris C "-std1 % -verbose -w0 -warnprotos" dnl Digital Unix "-qlanglvl=ansi % -qsrcmsg -qinfo=all:noppt:noppc:noobs:nocnd" dnl AIX "-ansi -ansiE % -fullwarn" dnl IRIX "+ESlit % +w1" dnl HP-UX C "-Xc % -pvctl[,]fullmsg" dnl NEC SX-5 (Super-UX 10) "-h conform % -h msglevel 2" dnl Cray C (Unicos) # do FLAGS="$ac_save_[]FLAGS "`echo $ac_arg | sed -e 's,%%.*,,' -e 's,%,,'` AC_COMPILE_IFELSE([AC_LANG_PROGRAM], [VAR=`echo $ac_arg | sed -e 's,.*% *,,'` ; break]) done FLAGS="$ac_save_[]FLAGS" ]) AS_VAR_POPDEF([FLAGS])dnl AX_REQUIRE_DEFINED([AX_APPEND_FLAG]) case ".$VAR" in .ok|.ok,*) m4_ifvaln($3,$3) ;; .|.no|.no,*) m4_default($4,[m4_ifval($2,[AX_APPEND_FLAG([$2], [$1])])]) ;; *) m4_default($3,[AX_APPEND_FLAG([$VAR], [$1])]) ;; esac AS_VAR_POPDEF([VAR])dnl ])dnl AX_FLAGS_WARN_ALL dnl implementation tactics: dnl the for-argument contains a list of options. The first part of dnl these does only exist to detect the compiler - usually it is dnl a global option to enable -ansi or -extrawarnings. All other dnl compilers will fail about it. That was needed since a lot of dnl compilers will give false positives for some option-syntax dnl like -Woption or -Xoption as they think of it is a pass-through dnl to later compile stages or something. The "%" is used as a dnl delimiter. A non-option comment can be given after "%%" marks dnl which will be shown but not added to the respective C/CXXFLAGS. AC_DEFUN([AX_CFLAGS_WARN_ALL],[dnl AC_LANG_PUSH([C]) AX_FLAGS_WARN_ALL([$1], [$2], [$3], [$4]) AC_LANG_POP([C]) ]) AC_DEFUN([AX_CXXFLAGS_WARN_ALL],[dnl AC_LANG_PUSH([C++]) AX_FLAGS_WARN_ALL([$1], [$2], [$3], [$4]) AC_LANG_POP([C++]) ]) AC_DEFUN([AX_FCFLAGS_WARN_ALL],[dnl AC_LANG_PUSH([Fortran]) AX_FLAGS_WARN_ALL([$1], [$2], [$3], [$4]) AC_LANG_POP([Fortran]) ]) xrdp-0.9.5/librfxcodec/m4/ax_append_compile_flags.m4000644 001751 001751 00000005660 13127342056 022325 0ustar00metameta000000 000000 # ============================================================================ # https://www.gnu.org/software/autoconf-archive/ax_append_compile_flags.html # ============================================================================ # # SYNOPSIS # # AX_APPEND_COMPILE_FLAGS([FLAG1 FLAG2 ...], [FLAGS-VARIABLE], [EXTRA-FLAGS], [INPUT]) # # DESCRIPTION # # For every FLAG1, FLAG2 it is checked whether the compiler works with the # flag. If it does, the flag is added FLAGS-VARIABLE # # If FLAGS-VARIABLE is not specified, the current language's flags (e.g. # CFLAGS) is used. During the check the flag is always added to the # current language's flags. # # If EXTRA-FLAGS is defined, it is added to the current language's default # flags (e.g. CFLAGS) when the check is done. The check is thus made with # the flags: "CFLAGS EXTRA-FLAGS FLAG". This can for example be used to # force the compiler to issue an error when a bad flag is given. # # INPUT gives an alternative input source to AC_COMPILE_IFELSE. # # NOTE: This macro depends on the AX_APPEND_FLAG and # AX_CHECK_COMPILE_FLAG. Please keep this macro in sync with # AX_APPEND_LINK_FLAGS. # # LICENSE # # Copyright (c) 2011 Maarten Bosmans # # 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. # # You should have received a copy of the GNU General Public License along # with this program. If not, see . # # As a special exception, the respective Autoconf Macro's copyright owner # gives unlimited permission to copy, distribute and modify the configure # scripts that are the output of Autoconf when processing the Macro. You # need not follow the terms of the GNU General Public License when using # or distributing such scripts, even though portions of the text of the # Macro appear in them. The GNU General Public License (GPL) does govern # all other use of the material that constitutes the Autoconf Macro. # # This special exception to the GPL applies to versions of the Autoconf # Macro released by the Autoconf Archive. When you make and distribute a # modified version of the Autoconf Macro, you may extend this special # exception to the GPL to apply to your modified version as well. #serial 6 AC_DEFUN([AX_APPEND_COMPILE_FLAGS], [AX_REQUIRE_DEFINED([AX_CHECK_COMPILE_FLAG]) AX_REQUIRE_DEFINED([AX_APPEND_FLAG]) for flag in $1; do AX_CHECK_COMPILE_FLAG([$flag], [AX_APPEND_FLAG([$flag], [$2])], [], [$3], [$4]) done ])dnl AX_APPEND_COMPILE_FLAGS xrdp-0.9.5/librfxcodec/m4/ltoptions.m4000644 001751 001751 00000034262 13220730751 017532 0ustar00metameta000000 000000 # Helper functions for option handling. -*- Autoconf -*- # # Copyright (C) 2004-2005, 2007-2009, 2011-2015 Free Software # Foundation, Inc. # Written by Gary V. Vaughan, 2004 # # This file is free software; the Free Software Foundation gives # unlimited permission to copy and/or distribute it, with or without # modifications, as long as this notice is preserved. # serial 8 ltoptions.m4 # This is to help aclocal find these macros, as it can't see m4_define. AC_DEFUN([LTOPTIONS_VERSION], [m4_if([1])]) # _LT_MANGLE_OPTION(MACRO-NAME, OPTION-NAME) # ------------------------------------------ m4_define([_LT_MANGLE_OPTION], [[_LT_OPTION_]m4_bpatsubst($1__$2, [[^a-zA-Z0-9_]], [_])]) # _LT_SET_OPTION(MACRO-NAME, OPTION-NAME) # --------------------------------------- # Set option OPTION-NAME for macro MACRO-NAME, and if there is a # matching handler defined, dispatch to it. Other OPTION-NAMEs are # saved as a flag. m4_define([_LT_SET_OPTION], [m4_define(_LT_MANGLE_OPTION([$1], [$2]))dnl m4_ifdef(_LT_MANGLE_DEFUN([$1], [$2]), _LT_MANGLE_DEFUN([$1], [$2]), [m4_warning([Unknown $1 option '$2'])])[]dnl ]) # _LT_IF_OPTION(MACRO-NAME, OPTION-NAME, IF-SET, [IF-NOT-SET]) # ------------------------------------------------------------ # Execute IF-SET if OPTION is set, IF-NOT-SET otherwise. m4_define([_LT_IF_OPTION], [m4_ifdef(_LT_MANGLE_OPTION([$1], [$2]), [$3], [$4])]) # _LT_UNLESS_OPTIONS(MACRO-NAME, OPTION-LIST, IF-NOT-SET) # ------------------------------------------------------- # Execute IF-NOT-SET unless all options in OPTION-LIST for MACRO-NAME # are set. m4_define([_LT_UNLESS_OPTIONS], [m4_foreach([_LT_Option], m4_split(m4_normalize([$2])), [m4_ifdef(_LT_MANGLE_OPTION([$1], _LT_Option), [m4_define([$0_found])])])[]dnl m4_ifdef([$0_found], [m4_undefine([$0_found])], [$3 ])[]dnl ]) # _LT_SET_OPTIONS(MACRO-NAME, OPTION-LIST) # ---------------------------------------- # OPTION-LIST is a space-separated list of Libtool options associated # with MACRO-NAME. If any OPTION has a matching handler declared with # LT_OPTION_DEFINE, dispatch to that macro; otherwise complain about # the unknown option and exit. m4_defun([_LT_SET_OPTIONS], [# Set options m4_foreach([_LT_Option], m4_split(m4_normalize([$2])), [_LT_SET_OPTION([$1], _LT_Option)]) m4_if([$1],[LT_INIT],[ dnl dnl Simply set some default values (i.e off) if boolean options were not dnl specified: _LT_UNLESS_OPTIONS([LT_INIT], [dlopen], [enable_dlopen=no ]) _LT_UNLESS_OPTIONS([LT_INIT], [win32-dll], [enable_win32_dll=no ]) dnl dnl If no reference was made to various pairs of opposing options, then dnl we run the default mode handler for the pair. For example, if neither dnl 'shared' nor 'disable-shared' was passed, we enable building of shared dnl archives by default: _LT_UNLESS_OPTIONS([LT_INIT], [shared disable-shared], [_LT_ENABLE_SHARED]) _LT_UNLESS_OPTIONS([LT_INIT], [static disable-static], [_LT_ENABLE_STATIC]) _LT_UNLESS_OPTIONS([LT_INIT], [pic-only no-pic], [_LT_WITH_PIC]) _LT_UNLESS_OPTIONS([LT_INIT], [fast-install disable-fast-install], [_LT_ENABLE_FAST_INSTALL]) _LT_UNLESS_OPTIONS([LT_INIT], [aix-soname=aix aix-soname=both aix-soname=svr4], [_LT_WITH_AIX_SONAME([aix])]) ]) ])# _LT_SET_OPTIONS ## --------------------------------- ## ## Macros to handle LT_INIT options. ## ## --------------------------------- ## # _LT_MANGLE_DEFUN(MACRO-NAME, OPTION-NAME) # ----------------------------------------- m4_define([_LT_MANGLE_DEFUN], [[_LT_OPTION_DEFUN_]m4_bpatsubst(m4_toupper([$1__$2]), [[^A-Z0-9_]], [_])]) # LT_OPTION_DEFINE(MACRO-NAME, OPTION-NAME, CODE) # ----------------------------------------------- m4_define([LT_OPTION_DEFINE], [m4_define(_LT_MANGLE_DEFUN([$1], [$2]), [$3])[]dnl ])# LT_OPTION_DEFINE # dlopen # ------ LT_OPTION_DEFINE([LT_INIT], [dlopen], [enable_dlopen=yes ]) AU_DEFUN([AC_LIBTOOL_DLOPEN], [_LT_SET_OPTION([LT_INIT], [dlopen]) AC_DIAGNOSE([obsolete], [$0: Remove this warning and the call to _LT_SET_OPTION when you put the 'dlopen' option into LT_INIT's first parameter.]) ]) dnl aclocal-1.4 backwards compatibility: dnl AC_DEFUN([AC_LIBTOOL_DLOPEN], []) # win32-dll # --------- # Declare package support for building win32 dll's. LT_OPTION_DEFINE([LT_INIT], [win32-dll], [enable_win32_dll=yes case $host in *-*-cygwin* | *-*-mingw* | *-*-pw32* | *-*-cegcc*) AC_CHECK_TOOL(AS, as, false) AC_CHECK_TOOL(DLLTOOL, dlltool, false) AC_CHECK_TOOL(OBJDUMP, objdump, false) ;; esac test -z "$AS" && AS=as _LT_DECL([], [AS], [1], [Assembler program])dnl test -z "$DLLTOOL" && DLLTOOL=dlltool _LT_DECL([], [DLLTOOL], [1], [DLL creation program])dnl test -z "$OBJDUMP" && OBJDUMP=objdump _LT_DECL([], [OBJDUMP], [1], [Object dumper program])dnl ])# win32-dll AU_DEFUN([AC_LIBTOOL_WIN32_DLL], [AC_REQUIRE([AC_CANONICAL_HOST])dnl _LT_SET_OPTION([LT_INIT], [win32-dll]) AC_DIAGNOSE([obsolete], [$0: Remove this warning and the call to _LT_SET_OPTION when you put the 'win32-dll' option into LT_INIT's first parameter.]) ]) dnl aclocal-1.4 backwards compatibility: dnl AC_DEFUN([AC_LIBTOOL_WIN32_DLL], []) # _LT_ENABLE_SHARED([DEFAULT]) # ---------------------------- # implement the --enable-shared flag, and supports the 'shared' and # 'disable-shared' LT_INIT options. # DEFAULT is either 'yes' or 'no'. If omitted, it defaults to 'yes'. m4_define([_LT_ENABLE_SHARED], [m4_define([_LT_ENABLE_SHARED_DEFAULT], [m4_if($1, no, no, yes)])dnl AC_ARG_ENABLE([shared], [AS_HELP_STRING([--enable-shared@<:@=PKGS@:>@], [build shared libraries @<:@default=]_LT_ENABLE_SHARED_DEFAULT[@:>@])], [p=${PACKAGE-default} case $enableval in yes) enable_shared=yes ;; no) enable_shared=no ;; *) enable_shared=no # Look at the argument we got. We use all the common list separators. lt_save_ifs=$IFS; IFS=$IFS$PATH_SEPARATOR, for pkg in $enableval; do IFS=$lt_save_ifs if test "X$pkg" = "X$p"; then enable_shared=yes fi done IFS=$lt_save_ifs ;; esac], [enable_shared=]_LT_ENABLE_SHARED_DEFAULT) _LT_DECL([build_libtool_libs], [enable_shared], [0], [Whether or not to build shared libraries]) ])# _LT_ENABLE_SHARED LT_OPTION_DEFINE([LT_INIT], [shared], [_LT_ENABLE_SHARED([yes])]) LT_OPTION_DEFINE([LT_INIT], [disable-shared], [_LT_ENABLE_SHARED([no])]) # Old names: AC_DEFUN([AC_ENABLE_SHARED], [_LT_SET_OPTION([LT_INIT], m4_if([$1], [no], [disable-])[shared]) ]) AC_DEFUN([AC_DISABLE_SHARED], [_LT_SET_OPTION([LT_INIT], [disable-shared]) ]) AU_DEFUN([AM_ENABLE_SHARED], [AC_ENABLE_SHARED($@)]) AU_DEFUN([AM_DISABLE_SHARED], [AC_DISABLE_SHARED($@)]) dnl aclocal-1.4 backwards compatibility: dnl AC_DEFUN([AM_ENABLE_SHARED], []) dnl AC_DEFUN([AM_DISABLE_SHARED], []) # _LT_ENABLE_STATIC([DEFAULT]) # ---------------------------- # implement the --enable-static flag, and support the 'static' and # 'disable-static' LT_INIT options. # DEFAULT is either 'yes' or 'no'. If omitted, it defaults to 'yes'. m4_define([_LT_ENABLE_STATIC], [m4_define([_LT_ENABLE_STATIC_DEFAULT], [m4_if($1, no, no, yes)])dnl AC_ARG_ENABLE([static], [AS_HELP_STRING([--enable-static@<:@=PKGS@:>@], [build static libraries @<:@default=]_LT_ENABLE_STATIC_DEFAULT[@:>@])], [p=${PACKAGE-default} case $enableval in yes) enable_static=yes ;; no) enable_static=no ;; *) enable_static=no # Look at the argument we got. We use all the common list separators. lt_save_ifs=$IFS; IFS=$IFS$PATH_SEPARATOR, for pkg in $enableval; do IFS=$lt_save_ifs if test "X$pkg" = "X$p"; then enable_static=yes fi done IFS=$lt_save_ifs ;; esac], [enable_static=]_LT_ENABLE_STATIC_DEFAULT) _LT_DECL([build_old_libs], [enable_static], [0], [Whether or not to build static libraries]) ])# _LT_ENABLE_STATIC LT_OPTION_DEFINE([LT_INIT], [static], [_LT_ENABLE_STATIC([yes])]) LT_OPTION_DEFINE([LT_INIT], [disable-static], [_LT_ENABLE_STATIC([no])]) # Old names: AC_DEFUN([AC_ENABLE_STATIC], [_LT_SET_OPTION([LT_INIT], m4_if([$1], [no], [disable-])[static]) ]) AC_DEFUN([AC_DISABLE_STATIC], [_LT_SET_OPTION([LT_INIT], [disable-static]) ]) AU_DEFUN([AM_ENABLE_STATIC], [AC_ENABLE_STATIC($@)]) AU_DEFUN([AM_DISABLE_STATIC], [AC_DISABLE_STATIC($@)]) dnl aclocal-1.4 backwards compatibility: dnl AC_DEFUN([AM_ENABLE_STATIC], []) dnl AC_DEFUN([AM_DISABLE_STATIC], []) # _LT_ENABLE_FAST_INSTALL([DEFAULT]) # ---------------------------------- # implement the --enable-fast-install flag, and support the 'fast-install' # and 'disable-fast-install' LT_INIT options. # DEFAULT is either 'yes' or 'no'. If omitted, it defaults to 'yes'. m4_define([_LT_ENABLE_FAST_INSTALL], [m4_define([_LT_ENABLE_FAST_INSTALL_DEFAULT], [m4_if($1, no, no, yes)])dnl AC_ARG_ENABLE([fast-install], [AS_HELP_STRING([--enable-fast-install@<:@=PKGS@:>@], [optimize for fast installation @<:@default=]_LT_ENABLE_FAST_INSTALL_DEFAULT[@:>@])], [p=${PACKAGE-default} case $enableval in yes) enable_fast_install=yes ;; no) enable_fast_install=no ;; *) enable_fast_install=no # Look at the argument we got. We use all the common list separators. lt_save_ifs=$IFS; IFS=$IFS$PATH_SEPARATOR, for pkg in $enableval; do IFS=$lt_save_ifs if test "X$pkg" = "X$p"; then enable_fast_install=yes fi done IFS=$lt_save_ifs ;; esac], [enable_fast_install=]_LT_ENABLE_FAST_INSTALL_DEFAULT) _LT_DECL([fast_install], [enable_fast_install], [0], [Whether or not to optimize for fast installation])dnl ])# _LT_ENABLE_FAST_INSTALL LT_OPTION_DEFINE([LT_INIT], [fast-install], [_LT_ENABLE_FAST_INSTALL([yes])]) LT_OPTION_DEFINE([LT_INIT], [disable-fast-install], [_LT_ENABLE_FAST_INSTALL([no])]) # Old names: AU_DEFUN([AC_ENABLE_FAST_INSTALL], [_LT_SET_OPTION([LT_INIT], m4_if([$1], [no], [disable-])[fast-install]) AC_DIAGNOSE([obsolete], [$0: Remove this warning and the call to _LT_SET_OPTION when you put the 'fast-install' option into LT_INIT's first parameter.]) ]) AU_DEFUN([AC_DISABLE_FAST_INSTALL], [_LT_SET_OPTION([LT_INIT], [disable-fast-install]) AC_DIAGNOSE([obsolete], [$0: Remove this warning and the call to _LT_SET_OPTION when you put the 'disable-fast-install' option into LT_INIT's first parameter.]) ]) dnl aclocal-1.4 backwards compatibility: dnl AC_DEFUN([AC_ENABLE_FAST_INSTALL], []) dnl AC_DEFUN([AM_DISABLE_FAST_INSTALL], []) # _LT_WITH_AIX_SONAME([DEFAULT]) # ---------------------------------- # implement the --with-aix-soname flag, and support the `aix-soname=aix' # and `aix-soname=both' and `aix-soname=svr4' LT_INIT options. DEFAULT # is either `aix', `both' or `svr4'. If omitted, it defaults to `aix'. m4_define([_LT_WITH_AIX_SONAME], [m4_define([_LT_WITH_AIX_SONAME_DEFAULT], [m4_if($1, svr4, svr4, m4_if($1, both, both, aix))])dnl shared_archive_member_spec= case $host,$enable_shared in power*-*-aix[[5-9]]*,yes) AC_MSG_CHECKING([which variant of shared library versioning to provide]) AC_ARG_WITH([aix-soname], [AS_HELP_STRING([--with-aix-soname=aix|svr4|both], [shared library versioning (aka "SONAME") variant to provide on AIX, @<:@default=]_LT_WITH_AIX_SONAME_DEFAULT[@:>@.])], [case $withval in aix|svr4|both) ;; *) AC_MSG_ERROR([Unknown argument to --with-aix-soname]) ;; esac lt_cv_with_aix_soname=$with_aix_soname], [AC_CACHE_VAL([lt_cv_with_aix_soname], [lt_cv_with_aix_soname=]_LT_WITH_AIX_SONAME_DEFAULT) with_aix_soname=$lt_cv_with_aix_soname]) AC_MSG_RESULT([$with_aix_soname]) if test aix != "$with_aix_soname"; then # For the AIX way of multilib, we name the shared archive member # based on the bitwidth used, traditionally 'shr.o' or 'shr_64.o', # and 'shr.imp' or 'shr_64.imp', respectively, for the Import File. # Even when GNU compilers ignore OBJECT_MODE but need '-maix64' flag, # the AIX toolchain works better with OBJECT_MODE set (default 32). if test 64 = "${OBJECT_MODE-32}"; then shared_archive_member_spec=shr_64 else shared_archive_member_spec=shr fi fi ;; *) with_aix_soname=aix ;; esac _LT_DECL([], [shared_archive_member_spec], [0], [Shared archive member basename, for filename based shared library versioning on AIX])dnl ])# _LT_WITH_AIX_SONAME LT_OPTION_DEFINE([LT_INIT], [aix-soname=aix], [_LT_WITH_AIX_SONAME([aix])]) LT_OPTION_DEFINE([LT_INIT], [aix-soname=both], [_LT_WITH_AIX_SONAME([both])]) LT_OPTION_DEFINE([LT_INIT], [aix-soname=svr4], [_LT_WITH_AIX_SONAME([svr4])]) # _LT_WITH_PIC([MODE]) # -------------------- # implement the --with-pic flag, and support the 'pic-only' and 'no-pic' # LT_INIT options. # MODE is either 'yes' or 'no'. If omitted, it defaults to 'both'. m4_define([_LT_WITH_PIC], [AC_ARG_WITH([pic], [AS_HELP_STRING([--with-pic@<:@=PKGS@:>@], [try to use only PIC/non-PIC objects @<:@default=use both@:>@])], [lt_p=${PACKAGE-default} case $withval in yes|no) pic_mode=$withval ;; *) pic_mode=default # Look at the argument we got. We use all the common list separators. lt_save_ifs=$IFS; IFS=$IFS$PATH_SEPARATOR, for lt_pkg in $withval; do IFS=$lt_save_ifs if test "X$lt_pkg" = "X$lt_p"; then pic_mode=yes fi done IFS=$lt_save_ifs ;; esac], [pic_mode=m4_default([$1], [default])]) _LT_DECL([], [pic_mode], [0], [What type of objects to build])dnl ])# _LT_WITH_PIC LT_OPTION_DEFINE([LT_INIT], [pic-only], [_LT_WITH_PIC([yes])]) LT_OPTION_DEFINE([LT_INIT], [no-pic], [_LT_WITH_PIC([no])]) # Old name: AU_DEFUN([AC_LIBTOOL_PICMODE], [_LT_SET_OPTION([LT_INIT], [pic-only]) AC_DIAGNOSE([obsolete], [$0: Remove this warning and the call to _LT_SET_OPTION when you put the 'pic-only' option into LT_INIT's first parameter.]) ]) dnl aclocal-1.4 backwards compatibility: dnl AC_DEFUN([AC_LIBTOOL_PICMODE], []) ## ----------------- ## ## LTDL_INIT Options ## ## ----------------- ## m4_define([_LTDL_MODE], []) LT_OPTION_DEFINE([LTDL_INIT], [nonrecursive], [m4_define([_LTDL_MODE], [nonrecursive])]) LT_OPTION_DEFINE([LTDL_INIT], [recursive], [m4_define([_LTDL_MODE], [recursive])]) LT_OPTION_DEFINE([LTDL_INIT], [subproject], [m4_define([_LTDL_MODE], [subproject])]) m4_define([_LTDL_TYPE], []) LT_OPTION_DEFINE([LTDL_INIT], [installable], [m4_define([_LTDL_TYPE], [installable])]) LT_OPTION_DEFINE([LTDL_INIT], [convenience], [m4_define([_LTDL_TYPE], [convenience])]) xrdp-0.9.5/librfxcodec/m4/ax_append_flag.m4000644 001751 001751 00000005333 13127342056 020427 0ustar00metameta000000 000000 # =========================================================================== # https://www.gnu.org/software/autoconf-archive/ax_append_flag.html # =========================================================================== # # SYNOPSIS # # AX_APPEND_FLAG(FLAG, [FLAGS-VARIABLE]) # # DESCRIPTION # # FLAG is appended to the FLAGS-VARIABLE shell variable, with a space # added in between. # # If FLAGS-VARIABLE is not specified, the current language's flags (e.g. # CFLAGS) is used. FLAGS-VARIABLE is not changed if it already contains # FLAG. If FLAGS-VARIABLE is unset in the shell, it is set to exactly # FLAG. # # NOTE: Implementation based on AX_CFLAGS_GCC_OPTION. # # LICENSE # # Copyright (c) 2008 Guido U. Draheim # Copyright (c) 2011 Maarten Bosmans # # 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. # # You should have received a copy of the GNU General Public License along # with this program. If not, see . # # As a special exception, the respective Autoconf Macro's copyright owner # gives unlimited permission to copy, distribute and modify the configure # scripts that are the output of Autoconf when processing the Macro. You # need not follow the terms of the GNU General Public License when using # or distributing such scripts, even though portions of the text of the # Macro appear in them. The GNU General Public License (GPL) does govern # all other use of the material that constitutes the Autoconf Macro. # # This special exception to the GPL applies to versions of the Autoconf # Macro released by the Autoconf Archive. When you make and distribute a # modified version of the Autoconf Macro, you may extend this special # exception to the GPL to apply to your modified version as well. #serial 7 AC_DEFUN([AX_APPEND_FLAG], [dnl AC_PREREQ(2.64)dnl for _AC_LANG_PREFIX and AS_VAR_SET_IF AS_VAR_PUSHDEF([FLAGS], [m4_default($2,_AC_LANG_PREFIX[FLAGS])]) AS_VAR_SET_IF(FLAGS,[ AS_CASE([" AS_VAR_GET(FLAGS) "], [*" $1 "*], [AC_RUN_LOG([: FLAGS already contains $1])], [ AS_VAR_APPEND(FLAGS,[" $1"]) AC_RUN_LOG([: FLAGS="$FLAGS"]) ]) ], [ AS_VAR_SET(FLAGS,[$1]) AC_RUN_LOG([: FLAGS="$FLAGS"]) ]) AS_VAR_POPDEF([FLAGS])dnl ])dnl AX_APPEND_FLAG xrdp-0.9.5/librfxcodec/m4/lt~obsolete.m4000644 001751 001751 00000013774 13220730751 020056 0ustar00metameta000000 000000 # lt~obsolete.m4 -- aclocal satisfying obsolete definitions. -*-Autoconf-*- # # Copyright (C) 2004-2005, 2007, 2009, 2011-2015 Free Software # Foundation, Inc. # Written by Scott James Remnant, 2004. # # This file is free software; the Free Software Foundation gives # unlimited permission to copy and/or distribute it, with or without # modifications, as long as this notice is preserved. # serial 5 lt~obsolete.m4 # These exist entirely to fool aclocal when bootstrapping libtool. # # In the past libtool.m4 has provided macros via AC_DEFUN (or AU_DEFUN), # which have later been changed to m4_define as they aren't part of the # exported API, or moved to Autoconf or Automake where they belong. # # The trouble is, aclocal is a bit thick. It'll see the old AC_DEFUN # in /usr/share/aclocal/libtool.m4 and remember it, then when it sees us # using a macro with the same name in our local m4/libtool.m4 it'll # pull the old libtool.m4 in (it doesn't see our shiny new m4_define # and doesn't know about Autoconf macros at all.) # # So we provide this file, which has a silly filename so it's always # included after everything else. This provides aclocal with the # AC_DEFUNs it wants, but when m4 processes it, it doesn't do anything # because those macros already exist, or will be overwritten later. # We use AC_DEFUN over AU_DEFUN for compatibility with aclocal-1.6. # # Anytime we withdraw an AC_DEFUN or AU_DEFUN, remember to add it here. # Yes, that means every name once taken will need to remain here until # we give up compatibility with versions before 1.7, at which point # we need to keep only those names which we still refer to. # This is to help aclocal find these macros, as it can't see m4_define. AC_DEFUN([LTOBSOLETE_VERSION], [m4_if([1])]) m4_ifndef([AC_LIBTOOL_LINKER_OPTION], [AC_DEFUN([AC_LIBTOOL_LINKER_OPTION])]) m4_ifndef([AC_PROG_EGREP], [AC_DEFUN([AC_PROG_EGREP])]) m4_ifndef([_LT_AC_PROG_ECHO_BACKSLASH], [AC_DEFUN([_LT_AC_PROG_ECHO_BACKSLASH])]) m4_ifndef([_LT_AC_SHELL_INIT], [AC_DEFUN([_LT_AC_SHELL_INIT])]) m4_ifndef([_LT_AC_SYS_LIBPATH_AIX], [AC_DEFUN([_LT_AC_SYS_LIBPATH_AIX])]) m4_ifndef([_LT_PROG_LTMAIN], [AC_DEFUN([_LT_PROG_LTMAIN])]) m4_ifndef([_LT_AC_TAGVAR], [AC_DEFUN([_LT_AC_TAGVAR])]) m4_ifndef([AC_LTDL_ENABLE_INSTALL], [AC_DEFUN([AC_LTDL_ENABLE_INSTALL])]) m4_ifndef([AC_LTDL_PREOPEN], [AC_DEFUN([AC_LTDL_PREOPEN])]) m4_ifndef([_LT_AC_SYS_COMPILER], [AC_DEFUN([_LT_AC_SYS_COMPILER])]) m4_ifndef([_LT_AC_LOCK], [AC_DEFUN([_LT_AC_LOCK])]) m4_ifndef([AC_LIBTOOL_SYS_OLD_ARCHIVE], [AC_DEFUN([AC_LIBTOOL_SYS_OLD_ARCHIVE])]) m4_ifndef([_LT_AC_TRY_DLOPEN_SELF], [AC_DEFUN([_LT_AC_TRY_DLOPEN_SELF])]) m4_ifndef([AC_LIBTOOL_PROG_CC_C_O], [AC_DEFUN([AC_LIBTOOL_PROG_CC_C_O])]) m4_ifndef([AC_LIBTOOL_SYS_HARD_LINK_LOCKS], [AC_DEFUN([AC_LIBTOOL_SYS_HARD_LINK_LOCKS])]) m4_ifndef([AC_LIBTOOL_OBJDIR], [AC_DEFUN([AC_LIBTOOL_OBJDIR])]) m4_ifndef([AC_LTDL_OBJDIR], [AC_DEFUN([AC_LTDL_OBJDIR])]) m4_ifndef([AC_LIBTOOL_PROG_LD_HARDCODE_LIBPATH], [AC_DEFUN([AC_LIBTOOL_PROG_LD_HARDCODE_LIBPATH])]) m4_ifndef([AC_LIBTOOL_SYS_LIB_STRIP], [AC_DEFUN([AC_LIBTOOL_SYS_LIB_STRIP])]) m4_ifndef([AC_PATH_MAGIC], [AC_DEFUN([AC_PATH_MAGIC])]) m4_ifndef([AC_PROG_LD_GNU], [AC_DEFUN([AC_PROG_LD_GNU])]) m4_ifndef([AC_PROG_LD_RELOAD_FLAG], [AC_DEFUN([AC_PROG_LD_RELOAD_FLAG])]) m4_ifndef([AC_DEPLIBS_CHECK_METHOD], [AC_DEFUN([AC_DEPLIBS_CHECK_METHOD])]) m4_ifndef([AC_LIBTOOL_PROG_COMPILER_NO_RTTI], [AC_DEFUN([AC_LIBTOOL_PROG_COMPILER_NO_RTTI])]) m4_ifndef([AC_LIBTOOL_SYS_GLOBAL_SYMBOL_PIPE], [AC_DEFUN([AC_LIBTOOL_SYS_GLOBAL_SYMBOL_PIPE])]) m4_ifndef([AC_LIBTOOL_PROG_COMPILER_PIC], [AC_DEFUN([AC_LIBTOOL_PROG_COMPILER_PIC])]) m4_ifndef([AC_LIBTOOL_PROG_LD_SHLIBS], [AC_DEFUN([AC_LIBTOOL_PROG_LD_SHLIBS])]) m4_ifndef([AC_LIBTOOL_POSTDEP_PREDEP], [AC_DEFUN([AC_LIBTOOL_POSTDEP_PREDEP])]) m4_ifndef([LT_AC_PROG_EGREP], [AC_DEFUN([LT_AC_PROG_EGREP])]) m4_ifndef([LT_AC_PROG_SED], [AC_DEFUN([LT_AC_PROG_SED])]) m4_ifndef([_LT_CC_BASENAME], [AC_DEFUN([_LT_CC_BASENAME])]) m4_ifndef([_LT_COMPILER_BOILERPLATE], [AC_DEFUN([_LT_COMPILER_BOILERPLATE])]) m4_ifndef([_LT_LINKER_BOILERPLATE], [AC_DEFUN([_LT_LINKER_BOILERPLATE])]) m4_ifndef([_AC_PROG_LIBTOOL], [AC_DEFUN([_AC_PROG_LIBTOOL])]) m4_ifndef([AC_LIBTOOL_SETUP], [AC_DEFUN([AC_LIBTOOL_SETUP])]) m4_ifndef([_LT_AC_CHECK_DLFCN], [AC_DEFUN([_LT_AC_CHECK_DLFCN])]) m4_ifndef([AC_LIBTOOL_SYS_DYNAMIC_LINKER], [AC_DEFUN([AC_LIBTOOL_SYS_DYNAMIC_LINKER])]) m4_ifndef([_LT_AC_TAGCONFIG], [AC_DEFUN([_LT_AC_TAGCONFIG])]) m4_ifndef([AC_DISABLE_FAST_INSTALL], [AC_DEFUN([AC_DISABLE_FAST_INSTALL])]) m4_ifndef([_LT_AC_LANG_CXX], [AC_DEFUN([_LT_AC_LANG_CXX])]) m4_ifndef([_LT_AC_LANG_F77], [AC_DEFUN([_LT_AC_LANG_F77])]) m4_ifndef([_LT_AC_LANG_GCJ], [AC_DEFUN([_LT_AC_LANG_GCJ])]) m4_ifndef([AC_LIBTOOL_LANG_C_CONFIG], [AC_DEFUN([AC_LIBTOOL_LANG_C_CONFIG])]) m4_ifndef([_LT_AC_LANG_C_CONFIG], [AC_DEFUN([_LT_AC_LANG_C_CONFIG])]) m4_ifndef([AC_LIBTOOL_LANG_CXX_CONFIG], [AC_DEFUN([AC_LIBTOOL_LANG_CXX_CONFIG])]) m4_ifndef([_LT_AC_LANG_CXX_CONFIG], [AC_DEFUN([_LT_AC_LANG_CXX_CONFIG])]) m4_ifndef([AC_LIBTOOL_LANG_F77_CONFIG], [AC_DEFUN([AC_LIBTOOL_LANG_F77_CONFIG])]) m4_ifndef([_LT_AC_LANG_F77_CONFIG], [AC_DEFUN([_LT_AC_LANG_F77_CONFIG])]) m4_ifndef([AC_LIBTOOL_LANG_GCJ_CONFIG], [AC_DEFUN([AC_LIBTOOL_LANG_GCJ_CONFIG])]) m4_ifndef([_LT_AC_LANG_GCJ_CONFIG], [AC_DEFUN([_LT_AC_LANG_GCJ_CONFIG])]) m4_ifndef([AC_LIBTOOL_LANG_RC_CONFIG], [AC_DEFUN([AC_LIBTOOL_LANG_RC_CONFIG])]) m4_ifndef([_LT_AC_LANG_RC_CONFIG], [AC_DEFUN([_LT_AC_LANG_RC_CONFIG])]) m4_ifndef([AC_LIBTOOL_CONFIG], [AC_DEFUN([AC_LIBTOOL_CONFIG])]) m4_ifndef([_LT_AC_FILE_LTDLL_C], [AC_DEFUN([_LT_AC_FILE_LTDLL_C])]) m4_ifndef([_LT_REQUIRED_DARWIN_CHECKS], [AC_DEFUN([_LT_REQUIRED_DARWIN_CHECKS])]) m4_ifndef([_LT_AC_PROG_CXXCPP], [AC_DEFUN([_LT_AC_PROG_CXXCPP])]) m4_ifndef([_LT_PREPARE_SED_QUOTE_VARS], [AC_DEFUN([_LT_PREPARE_SED_QUOTE_VARS])]) m4_ifndef([_LT_PROG_ECHO_BACKSLASH], [AC_DEFUN([_LT_PROG_ECHO_BACKSLASH])]) m4_ifndef([_LT_PROG_F77], [AC_DEFUN([_LT_PROG_F77])]) m4_ifndef([_LT_PROG_FC], [AC_DEFUN([_LT_PROG_FC])]) m4_ifndef([_LT_PROG_CXX], [AC_DEFUN([_LT_PROG_CXX])]) xrdp-0.9.5/librfxcodec/m4/ltsugar.m4000644 001751 001751 00000010440 13220730751 017150 0ustar00metameta000000 000000 # ltsugar.m4 -- libtool m4 base layer. -*-Autoconf-*- # # Copyright (C) 2004-2005, 2007-2008, 2011-2015 Free Software # Foundation, Inc. # Written by Gary V. Vaughan, 2004 # # This file is free software; the Free Software Foundation gives # unlimited permission to copy and/or distribute it, with or without # modifications, as long as this notice is preserved. # serial 6 ltsugar.m4 # This is to help aclocal find these macros, as it can't see m4_define. AC_DEFUN([LTSUGAR_VERSION], [m4_if([0.1])]) # lt_join(SEP, ARG1, [ARG2...]) # ----------------------------- # Produce ARG1SEPARG2...SEPARGn, omitting [] arguments and their # associated separator. # Needed until we can rely on m4_join from Autoconf 2.62, since all earlier # versions in m4sugar had bugs. m4_define([lt_join], [m4_if([$#], [1], [], [$#], [2], [[$2]], [m4_if([$2], [], [], [[$2]_])$0([$1], m4_shift(m4_shift($@)))])]) m4_define([_lt_join], [m4_if([$#$2], [2], [], [m4_if([$2], [], [], [[$1$2]])$0([$1], m4_shift(m4_shift($@)))])]) # lt_car(LIST) # lt_cdr(LIST) # ------------ # Manipulate m4 lists. # These macros are necessary as long as will still need to support # Autoconf-2.59, which quotes differently. m4_define([lt_car], [[$1]]) m4_define([lt_cdr], [m4_if([$#], 0, [m4_fatal([$0: cannot be called without arguments])], [$#], 1, [], [m4_dquote(m4_shift($@))])]) m4_define([lt_unquote], $1) # lt_append(MACRO-NAME, STRING, [SEPARATOR]) # ------------------------------------------ # Redefine MACRO-NAME to hold its former content plus 'SEPARATOR''STRING'. # Note that neither SEPARATOR nor STRING are expanded; they are appended # to MACRO-NAME as is (leaving the expansion for when MACRO-NAME is invoked). # No SEPARATOR is output if MACRO-NAME was previously undefined (different # than defined and empty). # # This macro is needed until we can rely on Autoconf 2.62, since earlier # versions of m4sugar mistakenly expanded SEPARATOR but not STRING. m4_define([lt_append], [m4_define([$1], m4_ifdef([$1], [m4_defn([$1])[$3]])[$2])]) # lt_combine(SEP, PREFIX-LIST, INFIX, SUFFIX1, [SUFFIX2...]) # ---------------------------------------------------------- # Produce a SEP delimited list of all paired combinations of elements of # PREFIX-LIST with SUFFIX1 through SUFFIXn. Each element of the list # has the form PREFIXmINFIXSUFFIXn. # Needed until we can rely on m4_combine added in Autoconf 2.62. m4_define([lt_combine], [m4_if(m4_eval([$# > 3]), [1], [m4_pushdef([_Lt_sep], [m4_define([_Lt_sep], m4_defn([lt_car]))])]]dnl [[m4_foreach([_Lt_prefix], [$2], [m4_foreach([_Lt_suffix], ]m4_dquote(m4_dquote(m4_shift(m4_shift(m4_shift($@)))))[, [_Lt_sep([$1])[]m4_defn([_Lt_prefix])[$3]m4_defn([_Lt_suffix])])])])]) # lt_if_append_uniq(MACRO-NAME, VARNAME, [SEPARATOR], [UNIQ], [NOT-UNIQ]) # ----------------------------------------------------------------------- # Iff MACRO-NAME does not yet contain VARNAME, then append it (delimited # by SEPARATOR if supplied) and expand UNIQ, else NOT-UNIQ. m4_define([lt_if_append_uniq], [m4_ifdef([$1], [m4_if(m4_index([$3]m4_defn([$1])[$3], [$3$2$3]), [-1], [lt_append([$1], [$2], [$3])$4], [$5])], [lt_append([$1], [$2], [$3])$4])]) # lt_dict_add(DICT, KEY, VALUE) # ----------------------------- m4_define([lt_dict_add], [m4_define([$1($2)], [$3])]) # lt_dict_add_subkey(DICT, KEY, SUBKEY, VALUE) # -------------------------------------------- m4_define([lt_dict_add_subkey], [m4_define([$1($2:$3)], [$4])]) # lt_dict_fetch(DICT, KEY, [SUBKEY]) # ---------------------------------- m4_define([lt_dict_fetch], [m4_ifval([$3], m4_ifdef([$1($2:$3)], [m4_defn([$1($2:$3)])]), m4_ifdef([$1($2)], [m4_defn([$1($2)])]))]) # lt_if_dict_fetch(DICT, KEY, [SUBKEY], VALUE, IF-TRUE, [IF-FALSE]) # ----------------------------------------------------------------- m4_define([lt_if_dict_fetch], [m4_if(lt_dict_fetch([$1], [$2], [$3]), [$4], [$5], [$6])]) # lt_dict_filter(DICT, [SUBKEY], VALUE, [SEPARATOR], KEY, [...]) # -------------------------------------------------------------- m4_define([lt_dict_filter], [m4_if([$5], [], [], [lt_join(m4_quote(m4_default([$4], [[, ]])), lt_unquote(m4_split(m4_normalize(m4_foreach(_Lt_key, lt_car([m4_shiftn(4, $@)]), [lt_if_dict_fetch([$1], _Lt_key, [$2], [$3], [_Lt_key ])])))))])[]dnl ]) xrdp-0.9.5/librfxcodec/m4/pkg.m4000644 001751 001751 00000024011 13035113357 016250 0ustar00metameta000000 000000 dnl pkg.m4 - Macros to locate and utilise pkg-config. -*- Autoconf -*- dnl serial 11 (pkg-config-0.29.1) dnl dnl Copyright © 2004 Scott James Remnant . dnl Copyright © 2012-2015 Dan Nicholson dnl dnl This program is free software; you can redistribute it and/or modify dnl it under the terms of the GNU General Public License as published by dnl the Free Software Foundation; either version 2 of the License, or dnl (at your option) any later version. dnl dnl This program is distributed in the hope that it will be useful, but dnl WITHOUT ANY WARRANTY; without even the implied warranty of dnl MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU dnl General Public License for more details. dnl dnl You should have received a copy of the GNU General Public License dnl along with this program; if not, write to the Free Software dnl Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA dnl 02111-1307, USA. dnl dnl As a special exception to the GNU General Public License, if you dnl distribute this file as part of a program that contains a dnl configuration script generated by Autoconf, you may include it under dnl the same distribution terms that you use for the rest of that dnl program. dnl PKG_PREREQ(MIN-VERSION) dnl ----------------------- dnl Since: 0.29 dnl dnl Verify that the version of the pkg-config macros are at least dnl MIN-VERSION. Unlike PKG_PROG_PKG_CONFIG, which checks the user's dnl installed version of pkg-config, this checks the developer's version dnl of pkg.m4 when generating configure. dnl dnl To ensure that this macro is defined, also add: dnl m4_ifndef([PKG_PREREQ], dnl [m4_fatal([must install pkg-config 0.29 or later before running autoconf/autogen])]) dnl dnl See the "Since" comment for each macro you use to see what version dnl of the macros you require. m4_defun([PKG_PREREQ], [m4_define([PKG_MACROS_VERSION], [0.29.1]) m4_if(m4_version_compare(PKG_MACROS_VERSION, [$1]), -1, [m4_fatal([pkg.m4 version $1 or higher is required but ]PKG_MACROS_VERSION[ found])]) ])dnl PKG_PREREQ dnl PKG_PROG_PKG_CONFIG([MIN-VERSION]) dnl ---------------------------------- dnl Since: 0.16 dnl dnl Search for the pkg-config tool and set the PKG_CONFIG variable to dnl first found in the path. Checks that the version of pkg-config found dnl is at least MIN-VERSION. If MIN-VERSION is not specified, 0.9.0 is dnl used since that's the first version where most current features of dnl pkg-config existed. AC_DEFUN([PKG_PROG_PKG_CONFIG], [m4_pattern_forbid([^_?PKG_[A-Z_]+$]) m4_pattern_allow([^PKG_CONFIG(_(PATH|LIBDIR|SYSROOT_DIR|ALLOW_SYSTEM_(CFLAGS|LIBS)))?$]) m4_pattern_allow([^PKG_CONFIG_(DISABLE_UNINSTALLED|TOP_BUILD_DIR|DEBUG_SPEW)$]) AC_ARG_VAR([PKG_CONFIG], [path to pkg-config utility]) AC_ARG_VAR([PKG_CONFIG_PATH], [directories to add to pkg-config's search path]) AC_ARG_VAR([PKG_CONFIG_LIBDIR], [path overriding pkg-config's built-in search path]) if test "x$ac_cv_env_PKG_CONFIG_set" != "xset"; then AC_PATH_TOOL([PKG_CONFIG], [pkg-config]) fi if test -n "$PKG_CONFIG"; then _pkg_min_version=m4_default([$1], [0.9.0]) AC_MSG_CHECKING([pkg-config is at least version $_pkg_min_version]) if $PKG_CONFIG --atleast-pkgconfig-version $_pkg_min_version; then AC_MSG_RESULT([yes]) else AC_MSG_RESULT([no]) PKG_CONFIG="" fi fi[]dnl ])dnl PKG_PROG_PKG_CONFIG dnl PKG_CHECK_EXISTS(MODULES, [ACTION-IF-FOUND], [ACTION-IF-NOT-FOUND]) dnl ------------------------------------------------------------------- dnl Since: 0.18 dnl dnl Check to see whether a particular set of modules exists. Similar to dnl PKG_CHECK_MODULES(), but does not set variables or print errors. dnl dnl Please remember that m4 expands AC_REQUIRE([PKG_PROG_PKG_CONFIG]) dnl only at the first occurence in configure.ac, so if the first place dnl it's called might be skipped (such as if it is within an "if", you dnl have to call PKG_CHECK_EXISTS manually AC_DEFUN([PKG_CHECK_EXISTS], [AC_REQUIRE([PKG_PROG_PKG_CONFIG])dnl if test -n "$PKG_CONFIG" && \ AC_RUN_LOG([$PKG_CONFIG --exists --print-errors "$1"]); then m4_default([$2], [:]) m4_ifvaln([$3], [else $3])dnl fi]) dnl _PKG_CONFIG([VARIABLE], [COMMAND], [MODULES]) dnl --------------------------------------------- dnl Internal wrapper calling pkg-config via PKG_CONFIG and setting dnl pkg_failed based on the result. m4_define([_PKG_CONFIG], [if test -n "$$1"; then pkg_cv_[]$1="$$1" elif test -n "$PKG_CONFIG"; then PKG_CHECK_EXISTS([$3], [pkg_cv_[]$1=`$PKG_CONFIG --[]$2 "$3" 2>/dev/null` test "x$?" != "x0" && pkg_failed=yes ], [pkg_failed=yes]) else pkg_failed=untried fi[]dnl ])dnl _PKG_CONFIG dnl _PKG_SHORT_ERRORS_SUPPORTED dnl --------------------------- dnl Internal check to see if pkg-config supports short errors. AC_DEFUN([_PKG_SHORT_ERRORS_SUPPORTED], [AC_REQUIRE([PKG_PROG_PKG_CONFIG]) if $PKG_CONFIG --atleast-pkgconfig-version 0.20; then _pkg_short_errors_supported=yes else _pkg_short_errors_supported=no fi[]dnl ])dnl _PKG_SHORT_ERRORS_SUPPORTED dnl PKG_CHECK_MODULES(VARIABLE-PREFIX, MODULES, [ACTION-IF-FOUND], dnl [ACTION-IF-NOT-FOUND]) dnl -------------------------------------------------------------- dnl Since: 0.4.0 dnl dnl Note that if there is a possibility the first call to dnl PKG_CHECK_MODULES might not happen, you should be sure to include an dnl explicit call to PKG_PROG_PKG_CONFIG in your configure.ac AC_DEFUN([PKG_CHECK_MODULES], [AC_REQUIRE([PKG_PROG_PKG_CONFIG])dnl AC_ARG_VAR([$1][_CFLAGS], [C compiler flags for $1, overriding pkg-config])dnl AC_ARG_VAR([$1][_LIBS], [linker flags for $1, overriding pkg-config])dnl pkg_failed=no AC_MSG_CHECKING([for $1]) _PKG_CONFIG([$1][_CFLAGS], [cflags], [$2]) _PKG_CONFIG([$1][_LIBS], [libs], [$2]) m4_define([_PKG_TEXT], [Alternatively, you may set the environment variables $1[]_CFLAGS and $1[]_LIBS to avoid the need to call pkg-config. See the pkg-config man page for more details.]) if test $pkg_failed = yes; then AC_MSG_RESULT([no]) _PKG_SHORT_ERRORS_SUPPORTED if test $_pkg_short_errors_supported = yes; then $1[]_PKG_ERRORS=`$PKG_CONFIG --short-errors --print-errors --cflags --libs "$2" 2>&1` else $1[]_PKG_ERRORS=`$PKG_CONFIG --print-errors --cflags --libs "$2" 2>&1` fi # Put the nasty error message in config.log where it belongs echo "$$1[]_PKG_ERRORS" >&AS_MESSAGE_LOG_FD m4_default([$4], [AC_MSG_ERROR( [Package requirements ($2) were not met: $$1_PKG_ERRORS Consider adjusting the PKG_CONFIG_PATH environment variable if you installed software in a non-standard prefix. _PKG_TEXT])[]dnl ]) elif test $pkg_failed = untried; then AC_MSG_RESULT([no]) m4_default([$4], [AC_MSG_FAILURE( [The pkg-config script could not be found or is too old. Make sure it is in your PATH or set the PKG_CONFIG environment variable to the full path to pkg-config. _PKG_TEXT To get pkg-config, see .])[]dnl ]) else $1[]_CFLAGS=$pkg_cv_[]$1[]_CFLAGS $1[]_LIBS=$pkg_cv_[]$1[]_LIBS AC_MSG_RESULT([yes]) $3 fi[]dnl ])dnl PKG_CHECK_MODULES dnl PKG_CHECK_MODULES_STATIC(VARIABLE-PREFIX, MODULES, [ACTION-IF-FOUND], dnl [ACTION-IF-NOT-FOUND]) dnl --------------------------------------------------------------------- dnl Since: 0.29 dnl dnl Checks for existence of MODULES and gathers its build flags with dnl static libraries enabled. Sets VARIABLE-PREFIX_CFLAGS from --cflags dnl and VARIABLE-PREFIX_LIBS from --libs. dnl dnl Note that if there is a possibility the first call to dnl PKG_CHECK_MODULES_STATIC might not happen, you should be sure to dnl include an explicit call to PKG_PROG_PKG_CONFIG in your dnl configure.ac. AC_DEFUN([PKG_CHECK_MODULES_STATIC], [AC_REQUIRE([PKG_PROG_PKG_CONFIG])dnl _save_PKG_CONFIG=$PKG_CONFIG PKG_CONFIG="$PKG_CONFIG --static" PKG_CHECK_MODULES($@) PKG_CONFIG=$_save_PKG_CONFIG[]dnl ])dnl PKG_CHECK_MODULES_STATIC dnl PKG_INSTALLDIR([DIRECTORY]) dnl ------------------------- dnl Since: 0.27 dnl dnl Substitutes the variable pkgconfigdir as the location where a module dnl should install pkg-config .pc files. By default the directory is dnl $libdir/pkgconfig, but the default can be changed by passing dnl DIRECTORY. The user can override through the --with-pkgconfigdir dnl parameter. AC_DEFUN([PKG_INSTALLDIR], [m4_pushdef([pkg_default], [m4_default([$1], ['${libdir}/pkgconfig'])]) m4_pushdef([pkg_description], [pkg-config installation directory @<:@]pkg_default[@:>@]) AC_ARG_WITH([pkgconfigdir], [AS_HELP_STRING([--with-pkgconfigdir], pkg_description)],, [with_pkgconfigdir=]pkg_default) AC_SUBST([pkgconfigdir], [$with_pkgconfigdir]) m4_popdef([pkg_default]) m4_popdef([pkg_description]) ])dnl PKG_INSTALLDIR dnl PKG_NOARCH_INSTALLDIR([DIRECTORY]) dnl -------------------------------- dnl Since: 0.27 dnl dnl Substitutes the variable noarch_pkgconfigdir as the location where a dnl module should install arch-independent pkg-config .pc files. By dnl default the directory is $datadir/pkgconfig, but the default can be dnl changed by passing DIRECTORY. The user can override through the dnl --with-noarch-pkgconfigdir parameter. AC_DEFUN([PKG_NOARCH_INSTALLDIR], [m4_pushdef([pkg_default], [m4_default([$1], ['${datadir}/pkgconfig'])]) m4_pushdef([pkg_description], [pkg-config arch-independent installation directory @<:@]pkg_default[@:>@]) AC_ARG_WITH([noarch-pkgconfigdir], [AS_HELP_STRING([--with-noarch-pkgconfigdir], pkg_description)],, [with_noarch_pkgconfigdir=]pkg_default) AC_SUBST([noarch_pkgconfigdir], [$with_noarch_pkgconfigdir]) m4_popdef([pkg_default]) m4_popdef([pkg_description]) ])dnl PKG_NOARCH_INSTALLDIR dnl PKG_CHECK_VAR(VARIABLE, MODULE, CONFIG-VARIABLE, dnl [ACTION-IF-FOUND], [ACTION-IF-NOT-FOUND]) dnl ------------------------------------------- dnl Since: 0.28 dnl dnl Retrieves the value of the pkg-config variable for the given module. AC_DEFUN([PKG_CHECK_VAR], [AC_REQUIRE([PKG_PROG_PKG_CONFIG])dnl AC_ARG_VAR([$1], [value of $3 for $2, overriding pkg-config])dnl _PKG_CONFIG([$1], [variable="][$3]["], [$2]) AS_VAR_COPY([$1], [pkg_cv_][$1]) AS_VAR_IF([$1], [""], [$5], [$4])dnl ])dnl PKG_CHECK_VAR xrdp-0.9.5/librfxcodec/m4/ax_check_compile_flag.m4000644 001751 001751 00000006403 13127342056 021744 0ustar00metameta000000 000000 # =========================================================================== # https://www.gnu.org/software/autoconf-archive/ax_check_compile_flag.html # =========================================================================== # # SYNOPSIS # # AX_CHECK_COMPILE_FLAG(FLAG, [ACTION-SUCCESS], [ACTION-FAILURE], [EXTRA-FLAGS], [INPUT]) # # DESCRIPTION # # Check whether the given FLAG works with the current language's compiler # or gives an error. (Warnings, however, are ignored) # # ACTION-SUCCESS/ACTION-FAILURE are shell commands to execute on # success/failure. # # If EXTRA-FLAGS is defined, it is added to the current language's default # flags (e.g. CFLAGS) when the check is done. The check is thus made with # the flags: "CFLAGS EXTRA-FLAGS FLAG". This can for example be used to # force the compiler to issue an error when a bad flag is given. # # INPUT gives an alternative input source to AC_COMPILE_IFELSE. # # NOTE: Implementation based on AX_CFLAGS_GCC_OPTION. Please keep this # macro in sync with AX_CHECK_{PREPROC,LINK}_FLAG. # # LICENSE # # Copyright (c) 2008 Guido U. Draheim # Copyright (c) 2011 Maarten Bosmans # # 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. # # You should have received a copy of the GNU General Public License along # with this program. If not, see . # # As a special exception, the respective Autoconf Macro's copyright owner # gives unlimited permission to copy, distribute and modify the configure # scripts that are the output of Autoconf when processing the Macro. You # need not follow the terms of the GNU General Public License when using # or distributing such scripts, even though portions of the text of the # Macro appear in them. The GNU General Public License (GPL) does govern # all other use of the material that constitutes the Autoconf Macro. # # This special exception to the GPL applies to versions of the Autoconf # Macro released by the Autoconf Archive. When you make and distribute a # modified version of the Autoconf Macro, you may extend this special # exception to the GPL to apply to your modified version as well. #serial 5 AC_DEFUN([AX_CHECK_COMPILE_FLAG], [AC_PREREQ(2.64)dnl for _AC_LANG_PREFIX and AS_VAR_IF AS_VAR_PUSHDEF([CACHEVAR],[ax_cv_check_[]_AC_LANG_ABBREV[]flags_$4_$1])dnl AC_CACHE_CHECK([whether _AC_LANG compiler accepts $1], CACHEVAR, [ ax_check_save_flags=$[]_AC_LANG_PREFIX[]FLAGS _AC_LANG_PREFIX[]FLAGS="$[]_AC_LANG_PREFIX[]FLAGS $4 $1" AC_COMPILE_IFELSE([m4_default([$5],[AC_LANG_PROGRAM()])], [AS_VAR_SET(CACHEVAR,[yes])], [AS_VAR_SET(CACHEVAR,[no])]) _AC_LANG_PREFIX[]FLAGS=$ax_check_save_flags]) AS_VAR_IF(CACHEVAR,yes, [m4_default([$2], :)], [m4_default([$3], :)]) AS_VAR_POPDEF([CACHEVAR])dnl ])dnl AX_CHECK_COMPILE_FLAGS xrdp-0.9.5/libpainter/config.sub000755 001751 001751 00000106246 13220730741 016546 0ustar00metameta000000 000000 #! /bin/sh # Configuration validation subroutine script. # Copyright 1992-2015 Free Software Foundation, Inc. timestamp='2015-03-08' # This file 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. # # You should have received a copy of the GNU General Public License # along with this program; if not, see . # # As a special exception to the GNU General Public License, if you # distribute this file as part of a program that contains a # configuration script generated by Autoconf, you may include it under # the same distribution terms that you use for the rest of that # program. This Exception is an additional permission under section 7 # of the GNU General Public License, version 3 ("GPLv3"). # Please send patches to . # # Configuration subroutine to validate and canonicalize a configuration type. # Supply the specified configuration type as an argument. # If it is invalid, we print an error message on stderr and exit with code 1. # Otherwise, we print the canonical config type on stdout and succeed. # You can get the latest version of this script from: # http://git.savannah.gnu.org/gitweb/?p=config.git;a=blob_plain;f=config.sub;hb=HEAD # This file is supposed to be the same for all GNU packages # and recognize all the CPU types, system types and aliases # that are meaningful with *any* GNU software. # Each package is responsible for reporting which valid configurations # it does not support. The user should be able to distinguish # a failure to support a valid configuration from a meaningless # configuration. # The goal of this file is to map all the various variations of a given # machine specification into a single specification in the form: # CPU_TYPE-MANUFACTURER-OPERATING_SYSTEM # or in some cases, the newer four-part form: # CPU_TYPE-MANUFACTURER-KERNEL-OPERATING_SYSTEM # It is wrong to echo any other type of specification. me=`echo "$0" | sed -e 's,.*/,,'` usage="\ Usage: $0 [OPTION] CPU-MFR-OPSYS $0 [OPTION] ALIAS Canonicalize a configuration name. Operation modes: -h, --help print this help, then exit -t, --time-stamp print date of last modification, then exit -v, --version print version number, then exit Report bugs and patches to ." version="\ GNU config.sub ($timestamp) Copyright 1992-2015 Free Software Foundation, Inc. This is free software; see the source for copying conditions. There is NO warranty; not even for MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE." help=" Try \`$me --help' for more information." # Parse command line while test $# -gt 0 ; do case $1 in --time-stamp | --time* | -t ) echo "$timestamp" ; exit ;; --version | -v ) echo "$version" ; exit ;; --help | --h* | -h ) echo "$usage"; exit ;; -- ) # Stop option processing shift; break ;; - ) # Use stdin as input. break ;; -* ) echo "$me: invalid option $1$help" exit 1 ;; *local*) # First pass through any local machine types. echo $1 exit ;; * ) break ;; esac done case $# in 0) echo "$me: missing argument$help" >&2 exit 1;; 1) ;; *) echo "$me: too many arguments$help" >&2 exit 1;; esac # Separate what the user gave into CPU-COMPANY and OS or KERNEL-OS (if any). # Here we must recognize all the valid KERNEL-OS combinations. maybe_os=`echo $1 | sed 's/^\(.*\)-\([^-]*-[^-]*\)$/\2/'` case $maybe_os in nto-qnx* | linux-gnu* | linux-android* | linux-dietlibc | linux-newlib* | \ linux-musl* | linux-uclibc* | uclinux-uclibc* | uclinux-gnu* | kfreebsd*-gnu* | \ knetbsd*-gnu* | netbsd*-gnu* | netbsd*-eabi* | \ kopensolaris*-gnu* | \ storm-chaos* | os2-emx* | rtmk-nova*) os=-$maybe_os basic_machine=`echo $1 | sed 's/^\(.*\)-\([^-]*-[^-]*\)$/\1/'` ;; android-linux) os=-linux-android basic_machine=`echo $1 | sed 's/^\(.*\)-\([^-]*-[^-]*\)$/\1/'`-unknown ;; *) basic_machine=`echo $1 | sed 's/-[^-]*$//'` if [ $basic_machine != $1 ] then os=`echo $1 | sed 's/.*-/-/'` else os=; fi ;; esac ### Let's recognize common machines as not being operating systems so ### that things like config.sub decstation-3100 work. We also ### recognize some manufacturers as not being operating systems, so we ### can provide default operating systems below. case $os in -sun*os*) # Prevent following clause from handling this invalid input. ;; -dec* | -mips* | -sequent* | -encore* | -pc532* | -sgi* | -sony* | \ -att* | -7300* | -3300* | -delta* | -motorola* | -sun[234]* | \ -unicom* | -ibm* | -next | -hp | -isi* | -apollo | -altos* | \ -convergent* | -ncr* | -news | -32* | -3600* | -3100* | -hitachi* |\ -c[123]* | -convex* | -sun | -crds | -omron* | -dg | -ultra | -tti* | \ -harris | -dolphin | -highlevel | -gould | -cbm | -ns | -masscomp | \ -apple | -axis | -knuth | -cray | -microblaze*) os= basic_machine=$1 ;; -bluegene*) os=-cnk ;; -sim | -cisco | -oki | -wec | -winbond) os= basic_machine=$1 ;; -scout) ;; -wrs) os=-vxworks basic_machine=$1 ;; -chorusos*) os=-chorusos basic_machine=$1 ;; -chorusrdb) os=-chorusrdb basic_machine=$1 ;; -hiux*) os=-hiuxwe2 ;; -sco6) os=-sco5v6 basic_machine=`echo $1 | sed -e 's/86-.*/86-pc/'` ;; -sco5) os=-sco3.2v5 basic_machine=`echo $1 | sed -e 's/86-.*/86-pc/'` ;; -sco4) os=-sco3.2v4 basic_machine=`echo $1 | sed -e 's/86-.*/86-pc/'` ;; -sco3.2.[4-9]*) os=`echo $os | sed -e 's/sco3.2./sco3.2v/'` basic_machine=`echo $1 | sed -e 's/86-.*/86-pc/'` ;; -sco3.2v[4-9]*) # Don't forget version if it is 3.2v4 or newer. basic_machine=`echo $1 | sed -e 's/86-.*/86-pc/'` ;; -sco5v6*) # Don't forget version if it is 3.2v4 or newer. basic_machine=`echo $1 | sed -e 's/86-.*/86-pc/'` ;; -sco*) os=-sco3.2v2 basic_machine=`echo $1 | sed -e 's/86-.*/86-pc/'` ;; -udk*) basic_machine=`echo $1 | sed -e 's/86-.*/86-pc/'` ;; -isc) os=-isc2.2 basic_machine=`echo $1 | sed -e 's/86-.*/86-pc/'` ;; -clix*) basic_machine=clipper-intergraph ;; -isc*) basic_machine=`echo $1 | sed -e 's/86-.*/86-pc/'` ;; -lynx*178) os=-lynxos178 ;; -lynx*5) os=-lynxos5 ;; -lynx*) os=-lynxos ;; -ptx*) basic_machine=`echo $1 | sed -e 's/86-.*/86-sequent/'` ;; -windowsnt*) os=`echo $os | sed -e 's/windowsnt/winnt/'` ;; -psos*) os=-psos ;; -mint | -mint[0-9]*) basic_machine=m68k-atari os=-mint ;; esac # Decode aliases for certain CPU-COMPANY combinations. case $basic_machine in # Recognize the basic CPU types without company name. # Some are omitted here because they have special meanings below. 1750a | 580 \ | a29k \ | aarch64 | aarch64_be \ | alpha | alphaev[4-8] | alphaev56 | alphaev6[78] | alphapca5[67] \ | alpha64 | alpha64ev[4-8] | alpha64ev56 | alpha64ev6[78] | alpha64pca5[67] \ | am33_2.0 \ | arc | arceb \ | arm | arm[bl]e | arme[lb] | armv[2-8] | armv[3-8][lb] | armv7[arm] \ | avr | avr32 \ | be32 | be64 \ | bfin \ | c4x | c8051 | clipper \ | d10v | d30v | dlx | dsp16xx \ | e2k | epiphany \ | fido | fr30 | frv | ft32 \ | h8300 | h8500 | hppa | hppa1.[01] | hppa2.0 | hppa2.0[nw] | hppa64 \ | hexagon \ | i370 | i860 | i960 | ia64 \ | ip2k | iq2000 \ | k1om \ | le32 | le64 \ | lm32 \ | m32c | m32r | m32rle | m68000 | m68k | m88k \ | maxq | mb | microblaze | microblazeel | mcore | mep | metag \ | mips | mipsbe | mipseb | mipsel | mipsle \ | mips16 \ | mips64 | mips64el \ | mips64octeon | mips64octeonel \ | mips64orion | mips64orionel \ | mips64r5900 | mips64r5900el \ | mips64vr | mips64vrel \ | mips64vr4100 | mips64vr4100el \ | mips64vr4300 | mips64vr4300el \ | mips64vr5000 | mips64vr5000el \ | mips64vr5900 | mips64vr5900el \ | mipsisa32 | mipsisa32el \ | mipsisa32r2 | mipsisa32r2el \ | mipsisa32r6 | mipsisa32r6el \ | mipsisa64 | mipsisa64el \ | mipsisa64r2 | mipsisa64r2el \ | mipsisa64r6 | mipsisa64r6el \ | mipsisa64sb1 | mipsisa64sb1el \ | mipsisa64sr71k | mipsisa64sr71kel \ | mipsr5900 | mipsr5900el \ | mipstx39 | mipstx39el \ | mn10200 | mn10300 \ | moxie \ | mt \ | msp430 \ | nds32 | nds32le | nds32be \ | nios | nios2 | nios2eb | nios2el \ | ns16k | ns32k \ | open8 | or1k | or1knd | or32 \ | pdp10 | pdp11 | pj | pjl \ | powerpc | powerpc64 | powerpc64le | powerpcle | powerpcspe \ | pyramid \ | riscv32 | riscv64 \ | rl78 | rx \ | score \ | sh | sh[1234] | sh[24]a | sh[24]aeb | sh[23]e | sh[34]eb | sheb | shbe | shle | sh[1234]le | sh3ele \ | sh64 | sh64le \ | sparc | sparc64 | sparc64b | sparc64v | sparc86x | sparclet | sparclite \ | sparcv8 | sparcv9 | sparcv9b | sparcv9v \ | spu \ | tahoe | tic4x | tic54x | tic55x | tic6x | tic80 | tron \ | ubicom32 \ | v850 | v850e | v850e1 | v850e2 | v850es | v850e2v3 \ | visium \ | we32k \ | x86 | xc16x | xstormy16 | xtensa \ | z8k | z80) basic_machine=$basic_machine-unknown ;; c54x) basic_machine=tic54x-unknown ;; c55x) basic_machine=tic55x-unknown ;; c6x) basic_machine=tic6x-unknown ;; leon|leon[3-9]) basic_machine=sparc-$basic_machine ;; m6811 | m68hc11 | m6812 | m68hc12 | m68hcs12x | nvptx | picochip) basic_machine=$basic_machine-unknown os=-none ;; m88110 | m680[12346]0 | m683?2 | m68360 | m5200 | v70 | w65 | z8k) ;; ms1) basic_machine=mt-unknown ;; strongarm | thumb | xscale) basic_machine=arm-unknown ;; xgate) basic_machine=$basic_machine-unknown os=-none ;; xscaleeb) basic_machine=armeb-unknown ;; xscaleel) basic_machine=armel-unknown ;; # We use `pc' rather than `unknown' # because (1) that's what they normally are, and # (2) the word "unknown" tends to confuse beginning users. i*86 | x86_64) basic_machine=$basic_machine-pc ;; # Object if more than one company name word. *-*-*) echo Invalid configuration \`$1\': machine \`$basic_machine\' not recognized 1>&2 exit 1 ;; # Recognize the basic CPU types with company name. 580-* \ | a29k-* \ | aarch64-* | aarch64_be-* \ | alpha-* | alphaev[4-8]-* | alphaev56-* | alphaev6[78]-* \ | alpha64-* | alpha64ev[4-8]-* | alpha64ev56-* | alpha64ev6[78]-* \ | alphapca5[67]-* | alpha64pca5[67]-* | amd64-* | arc-* | arceb-* \ | arm-* | armbe-* | armle-* | armeb-* | armv*-* \ | avr-* | avr32-* \ | be32-* | be64-* \ | bfin-* | bs2000-* \ | c[123]* | c30-* | [cjt]90-* | c4x-* \ | c8051-* | clipper-* | craynv-* | cydra-* \ | d10v-* | d30v-* | dlx-* \ | e2k-* | elxsi-* \ | f30[01]-* | f700-* | fido-* | fr30-* | frv-* | fx80-* \ | h8300-* | h8500-* \ | hppa-* | hppa1.[01]-* | hppa2.0-* | hppa2.0[nw]-* | hppa64-* \ | hexagon-* \ | i*86-* | i860-* | i960-* | ia64-* \ | ip2k-* | iq2000-* \ | k1om-* \ | le32-* | le64-* \ | lm32-* \ | m32c-* | m32r-* | m32rle-* \ | m68000-* | m680[012346]0-* | m68360-* | m683?2-* | m68k-* \ | m88110-* | m88k-* | maxq-* | mcore-* | metag-* \ | microblaze-* | microblazeel-* \ | mips-* | mipsbe-* | mipseb-* | mipsel-* | mipsle-* \ | mips16-* \ | mips64-* | mips64el-* \ | mips64octeon-* | mips64octeonel-* \ | mips64orion-* | mips64orionel-* \ | mips64r5900-* | mips64r5900el-* \ | mips64vr-* | mips64vrel-* \ | mips64vr4100-* | mips64vr4100el-* \ | mips64vr4300-* | mips64vr4300el-* \ | mips64vr5000-* | mips64vr5000el-* \ | mips64vr5900-* | mips64vr5900el-* \ | mipsisa32-* | mipsisa32el-* \ | mipsisa32r2-* | mipsisa32r2el-* \ | mipsisa32r6-* | mipsisa32r6el-* \ | mipsisa64-* | mipsisa64el-* \ | mipsisa64r2-* | mipsisa64r2el-* \ | mipsisa64r6-* | mipsisa64r6el-* \ | mipsisa64sb1-* | mipsisa64sb1el-* \ | mipsisa64sr71k-* | mipsisa64sr71kel-* \ | mipsr5900-* | mipsr5900el-* \ | mipstx39-* | mipstx39el-* \ | mmix-* \ | mt-* \ | msp430-* \ | nds32-* | nds32le-* | nds32be-* \ | nios-* | nios2-* | nios2eb-* | nios2el-* \ | none-* | np1-* | ns16k-* | ns32k-* \ | open8-* \ | or1k*-* \ | orion-* \ | pdp10-* | pdp11-* | pj-* | pjl-* | pn-* | power-* \ | powerpc-* | powerpc64-* | powerpc64le-* | powerpcle-* | powerpcspe-* \ | pyramid-* \ | rl78-* | romp-* | rs6000-* | rx-* \ | sh-* | sh[1234]-* | sh[24]a-* | sh[24]aeb-* | sh[23]e-* | sh[34]eb-* | sheb-* | shbe-* \ | shle-* | sh[1234]le-* | sh3ele-* | sh64-* | sh64le-* \ | sparc-* | sparc64-* | sparc64b-* | sparc64v-* | sparc86x-* | sparclet-* \ | sparclite-* \ | sparcv8-* | sparcv9-* | sparcv9b-* | sparcv9v-* | sv1-* | sx?-* \ | tahoe-* \ | tic30-* | tic4x-* | tic54x-* | tic55x-* | tic6x-* | tic80-* \ | tile*-* \ | tron-* \ | ubicom32-* \ | v850-* | v850e-* | v850e1-* | v850es-* | v850e2-* | v850e2v3-* \ | vax-* \ | visium-* \ | we32k-* \ | x86-* | x86_64-* | xc16x-* | xps100-* \ | xstormy16-* | xtensa*-* \ | ymp-* \ | z8k-* | z80-*) ;; # Recognize the basic CPU types without company name, with glob match. xtensa*) basic_machine=$basic_machine-unknown ;; # Recognize the various machine names and aliases which stand # for a CPU type and a company and sometimes even an OS. 386bsd) basic_machine=i386-unknown os=-bsd ;; 3b1 | 7300 | 7300-att | att-7300 | pc7300 | safari | unixpc) basic_machine=m68000-att ;; 3b*) basic_machine=we32k-att ;; a29khif) basic_machine=a29k-amd os=-udi ;; abacus) basic_machine=abacus-unknown ;; adobe68k) basic_machine=m68010-adobe os=-scout ;; alliant | fx80) basic_machine=fx80-alliant ;; altos | altos3068) basic_machine=m68k-altos ;; am29k) basic_machine=a29k-none os=-bsd ;; amdahl) basic_machine=580-amdahl os=-sysv ;; amiga | amiga-*) basic_machine=m68k-unknown ;; amigaos | amigados) basic_machine=m68k-unknown os=-amigaos ;; amigaunix | amix) basic_machine=m68k-unknown os=-sysv4 ;; apollo68) basic_machine=m68k-apollo os=-sysv ;; apollo68bsd) basic_machine=m68k-apollo os=-bsd ;; aros) basic_machine=i386-pc os=-aros ;; asmjs) basic_machine=asmjs-unknown ;; aux) basic_machine=m68k-apple os=-aux ;; balance) basic_machine=ns32k-sequent os=-dynix ;; blackfin) basic_machine=bfin-unknown os=-linux ;; blackfin-*) basic_machine=bfin-`echo $basic_machine | sed 's/^[^-]*-//'` os=-linux ;; bluegene*) basic_machine=powerpc-ibm os=-cnk ;; c54x-*) basic_machine=tic54x-`echo $basic_machine | sed 's/^[^-]*-//'` ;; c55x-*) basic_machine=tic55x-`echo $basic_machine | sed 's/^[^-]*-//'` ;; c6x-*) basic_machine=tic6x-`echo $basic_machine | sed 's/^[^-]*-//'` ;; c90) basic_machine=c90-cray os=-unicos ;; cegcc) basic_machine=arm-unknown os=-cegcc ;; convex-c1) basic_machine=c1-convex os=-bsd ;; convex-c2) basic_machine=c2-convex os=-bsd ;; convex-c32) basic_machine=c32-convex os=-bsd ;; convex-c34) basic_machine=c34-convex os=-bsd ;; convex-c38) basic_machine=c38-convex os=-bsd ;; cray | j90) basic_machine=j90-cray os=-unicos ;; craynv) basic_machine=craynv-cray os=-unicosmp ;; cr16 | cr16-*) basic_machine=cr16-unknown os=-elf ;; crds | unos) basic_machine=m68k-crds ;; crisv32 | crisv32-* | etraxfs*) basic_machine=crisv32-axis ;; cris | cris-* | etrax*) basic_machine=cris-axis ;; crx) basic_machine=crx-unknown os=-elf ;; da30 | da30-*) basic_machine=m68k-da30 ;; decstation | decstation-3100 | pmax | pmax-* | pmin | dec3100 | decstatn) basic_machine=mips-dec ;; decsystem10* | dec10*) basic_machine=pdp10-dec os=-tops10 ;; decsystem20* | dec20*) basic_machine=pdp10-dec os=-tops20 ;; delta | 3300 | motorola-3300 | motorola-delta \ | 3300-motorola | delta-motorola) basic_machine=m68k-motorola ;; delta88) basic_machine=m88k-motorola os=-sysv3 ;; dicos) basic_machine=i686-pc os=-dicos ;; djgpp) basic_machine=i586-pc os=-msdosdjgpp ;; dpx20 | dpx20-*) basic_machine=rs6000-bull os=-bosx ;; dpx2* | dpx2*-bull) basic_machine=m68k-bull os=-sysv3 ;; ebmon29k) basic_machine=a29k-amd os=-ebmon ;; elxsi) basic_machine=elxsi-elxsi os=-bsd ;; encore | umax | mmax) basic_machine=ns32k-encore ;; es1800 | OSE68k | ose68k | ose | OSE) basic_machine=m68k-ericsson os=-ose ;; fx2800) basic_machine=i860-alliant ;; genix) basic_machine=ns32k-ns ;; gmicro) basic_machine=tron-gmicro os=-sysv ;; go32) basic_machine=i386-pc os=-go32 ;; h3050r* | hiux*) basic_machine=hppa1.1-hitachi os=-hiuxwe2 ;; h8300hms) basic_machine=h8300-hitachi os=-hms ;; h8300xray) basic_machine=h8300-hitachi os=-xray ;; h8500hms) basic_machine=h8500-hitachi os=-hms ;; harris) basic_machine=m88k-harris os=-sysv3 ;; hp300-*) basic_machine=m68k-hp ;; hp300bsd) basic_machine=m68k-hp os=-bsd ;; hp300hpux) basic_machine=m68k-hp os=-hpux ;; hp3k9[0-9][0-9] | hp9[0-9][0-9]) basic_machine=hppa1.0-hp ;; hp9k2[0-9][0-9] | hp9k31[0-9]) basic_machine=m68000-hp ;; hp9k3[2-9][0-9]) basic_machine=m68k-hp ;; hp9k6[0-9][0-9] | hp6[0-9][0-9]) basic_machine=hppa1.0-hp ;; hp9k7[0-79][0-9] | hp7[0-79][0-9]) basic_machine=hppa1.1-hp ;; hp9k78[0-9] | hp78[0-9]) # FIXME: really hppa2.0-hp basic_machine=hppa1.1-hp ;; hp9k8[67]1 | hp8[67]1 | hp9k80[24] | hp80[24] | hp9k8[78]9 | hp8[78]9 | hp9k893 | hp893) # FIXME: really hppa2.0-hp basic_machine=hppa1.1-hp ;; hp9k8[0-9][13679] | hp8[0-9][13679]) basic_machine=hppa1.1-hp ;; hp9k8[0-9][0-9] | hp8[0-9][0-9]) basic_machine=hppa1.0-hp ;; hppa-next) os=-nextstep3 ;; hppaosf) basic_machine=hppa1.1-hp os=-osf ;; hppro) basic_machine=hppa1.1-hp os=-proelf ;; i370-ibm* | ibm*) basic_machine=i370-ibm ;; i*86v32) basic_machine=`echo $1 | sed -e 's/86.*/86-pc/'` os=-sysv32 ;; i*86v4*) basic_machine=`echo $1 | sed -e 's/86.*/86-pc/'` os=-sysv4 ;; i*86v) basic_machine=`echo $1 | sed -e 's/86.*/86-pc/'` os=-sysv ;; i*86sol2) basic_machine=`echo $1 | sed -e 's/86.*/86-pc/'` os=-solaris2 ;; i386mach) basic_machine=i386-mach os=-mach ;; i386-vsta | vsta) basic_machine=i386-unknown os=-vsta ;; iris | iris4d) basic_machine=mips-sgi case $os in -irix*) ;; *) os=-irix4 ;; esac ;; isi68 | isi) basic_machine=m68k-isi os=-sysv ;; leon-*|leon[3-9]-*) basic_machine=sparc-`echo $basic_machine | sed 's/-.*//'` ;; m68knommu) basic_machine=m68k-unknown os=-linux ;; m68knommu-*) basic_machine=m68k-`echo $basic_machine | sed 's/^[^-]*-//'` os=-linux ;; m88k-omron*) basic_machine=m88k-omron ;; magnum | m3230) basic_machine=mips-mips os=-sysv ;; merlin) basic_machine=ns32k-utek os=-sysv ;; microblaze*) basic_machine=microblaze-xilinx ;; mingw64) basic_machine=x86_64-pc os=-mingw64 ;; mingw32) basic_machine=i686-pc os=-mingw32 ;; mingw32ce) basic_machine=arm-unknown os=-mingw32ce ;; miniframe) basic_machine=m68000-convergent ;; *mint | -mint[0-9]* | *MiNT | *MiNT[0-9]*) basic_machine=m68k-atari os=-mint ;; mips3*-*) basic_machine=`echo $basic_machine | sed -e 's/mips3/mips64/'` ;; mips3*) basic_machine=`echo $basic_machine | sed -e 's/mips3/mips64/'`-unknown ;; monitor) basic_machine=m68k-rom68k os=-coff ;; morphos) basic_machine=powerpc-unknown os=-morphos ;; moxiebox) basic_machine=moxie-unknown os=-moxiebox ;; msdos) basic_machine=i386-pc os=-msdos ;; ms1-*) basic_machine=`echo $basic_machine | sed -e 's/ms1-/mt-/'` ;; msys) basic_machine=i686-pc os=-msys ;; mvs) basic_machine=i370-ibm os=-mvs ;; nacl) basic_machine=le32-unknown os=-nacl ;; ncr3000) basic_machine=i486-ncr os=-sysv4 ;; netbsd386) basic_machine=i386-unknown os=-netbsd ;; netwinder) basic_machine=armv4l-rebel os=-linux ;; news | news700 | news800 | news900) basic_machine=m68k-sony os=-newsos ;; news1000) basic_machine=m68030-sony os=-newsos ;; news-3600 | risc-news) basic_machine=mips-sony os=-newsos ;; necv70) basic_machine=v70-nec os=-sysv ;; next | m*-next ) basic_machine=m68k-next case $os in -nextstep* ) ;; -ns2*) os=-nextstep2 ;; *) os=-nextstep3 ;; esac ;; nh3000) basic_machine=m68k-harris os=-cxux ;; nh[45]000) basic_machine=m88k-harris os=-cxux ;; nindy960) basic_machine=i960-intel os=-nindy ;; mon960) basic_machine=i960-intel os=-mon960 ;; nonstopux) basic_machine=mips-compaq os=-nonstopux ;; np1) basic_machine=np1-gould ;; neo-tandem) basic_machine=neo-tandem ;; nse-tandem) basic_machine=nse-tandem ;; nsr-tandem) basic_machine=nsr-tandem ;; op50n-* | op60c-*) basic_machine=hppa1.1-oki os=-proelf ;; openrisc | openrisc-*) basic_machine=or32-unknown ;; os400) basic_machine=powerpc-ibm os=-os400 ;; OSE68000 | ose68000) basic_machine=m68000-ericsson os=-ose ;; os68k) basic_machine=m68k-none os=-os68k ;; pa-hitachi) basic_machine=hppa1.1-hitachi os=-hiuxwe2 ;; paragon) basic_machine=i860-intel os=-osf ;; parisc) basic_machine=hppa-unknown os=-linux ;; parisc-*) basic_machine=hppa-`echo $basic_machine | sed 's/^[^-]*-//'` os=-linux ;; pbd) basic_machine=sparc-tti ;; pbb) basic_machine=m68k-tti ;; pc532 | pc532-*) basic_machine=ns32k-pc532 ;; pc98) basic_machine=i386-pc ;; pc98-*) basic_machine=i386-`echo $basic_machine | sed 's/^[^-]*-//'` ;; pentium | p5 | k5 | k6 | nexgen | viac3) basic_machine=i586-pc ;; pentiumpro | p6 | 6x86 | athlon | athlon_*) basic_machine=i686-pc ;; pentiumii | pentium2 | pentiumiii | pentium3) basic_machine=i686-pc ;; pentium4) basic_machine=i786-pc ;; pentium-* | p5-* | k5-* | k6-* | nexgen-* | viac3-*) basic_machine=i586-`echo $basic_machine | sed 's/^[^-]*-//'` ;; pentiumpro-* | p6-* | 6x86-* | athlon-*) basic_machine=i686-`echo $basic_machine | sed 's/^[^-]*-//'` ;; pentiumii-* | pentium2-* | pentiumiii-* | pentium3-*) basic_machine=i686-`echo $basic_machine | sed 's/^[^-]*-//'` ;; pentium4-*) basic_machine=i786-`echo $basic_machine | sed 's/^[^-]*-//'` ;; pn) basic_machine=pn-gould ;; power) basic_machine=power-ibm ;; ppc | ppcbe) basic_machine=powerpc-unknown ;; ppc-* | ppcbe-*) basic_machine=powerpc-`echo $basic_machine | sed 's/^[^-]*-//'` ;; ppcle | powerpclittle | ppc-le | powerpc-little) basic_machine=powerpcle-unknown ;; ppcle-* | powerpclittle-*) basic_machine=powerpcle-`echo $basic_machine | sed 's/^[^-]*-//'` ;; ppc64) basic_machine=powerpc64-unknown ;; ppc64-*) basic_machine=powerpc64-`echo $basic_machine | sed 's/^[^-]*-//'` ;; ppc64le | powerpc64little | ppc64-le | powerpc64-little) basic_machine=powerpc64le-unknown ;; ppc64le-* | powerpc64little-*) basic_machine=powerpc64le-`echo $basic_machine | sed 's/^[^-]*-//'` ;; ps2) basic_machine=i386-ibm ;; pw32) basic_machine=i586-unknown os=-pw32 ;; rdos | rdos64) basic_machine=x86_64-pc os=-rdos ;; rdos32) basic_machine=i386-pc os=-rdos ;; rom68k) basic_machine=m68k-rom68k os=-coff ;; rm[46]00) basic_machine=mips-siemens ;; rtpc | rtpc-*) basic_machine=romp-ibm ;; s390 | s390-*) basic_machine=s390-ibm ;; s390x | s390x-*) basic_machine=s390x-ibm ;; sa29200) basic_machine=a29k-amd os=-udi ;; sb1) basic_machine=mipsisa64sb1-unknown ;; sb1el) basic_machine=mipsisa64sb1el-unknown ;; sde) basic_machine=mipsisa32-sde os=-elf ;; sei) basic_machine=mips-sei os=-seiux ;; sequent) basic_machine=i386-sequent ;; sh) basic_machine=sh-hitachi os=-hms ;; sh5el) basic_machine=sh5le-unknown ;; sh64) basic_machine=sh64-unknown ;; sparclite-wrs | simso-wrs) basic_machine=sparclite-wrs os=-vxworks ;; sps7) basic_machine=m68k-bull os=-sysv2 ;; spur) basic_machine=spur-unknown ;; st2000) basic_machine=m68k-tandem ;; stratus) basic_machine=i860-stratus os=-sysv4 ;; strongarm-* | thumb-*) basic_machine=arm-`echo $basic_machine | sed 's/^[^-]*-//'` ;; sun2) basic_machine=m68000-sun ;; sun2os3) basic_machine=m68000-sun os=-sunos3 ;; sun2os4) basic_machine=m68000-sun os=-sunos4 ;; sun3os3) basic_machine=m68k-sun os=-sunos3 ;; sun3os4) basic_machine=m68k-sun os=-sunos4 ;; sun4os3) basic_machine=sparc-sun os=-sunos3 ;; sun4os4) basic_machine=sparc-sun os=-sunos4 ;; sun4sol2) basic_machine=sparc-sun os=-solaris2 ;; sun3 | sun3-*) basic_machine=m68k-sun ;; sun4) basic_machine=sparc-sun ;; sun386 | sun386i | roadrunner) basic_machine=i386-sun ;; sv1) basic_machine=sv1-cray os=-unicos ;; symmetry) basic_machine=i386-sequent os=-dynix ;; t3e) basic_machine=alphaev5-cray os=-unicos ;; t90) basic_machine=t90-cray os=-unicos ;; tile*) basic_machine=$basic_machine-unknown os=-linux-gnu ;; tx39) basic_machine=mipstx39-unknown ;; tx39el) basic_machine=mipstx39el-unknown ;; toad1) basic_machine=pdp10-xkl os=-tops20 ;; tower | tower-32) basic_machine=m68k-ncr ;; tpf) basic_machine=s390x-ibm os=-tpf ;; udi29k) basic_machine=a29k-amd os=-udi ;; ultra3) basic_machine=a29k-nyu os=-sym1 ;; v810 | necv810) basic_machine=v810-nec os=-none ;; vaxv) basic_machine=vax-dec os=-sysv ;; vms) basic_machine=vax-dec os=-vms ;; vpp*|vx|vx-*) basic_machine=f301-fujitsu ;; vxworks960) basic_machine=i960-wrs os=-vxworks ;; vxworks68) basic_machine=m68k-wrs os=-vxworks ;; vxworks29k) basic_machine=a29k-wrs os=-vxworks ;; w65*) basic_machine=w65-wdc os=-none ;; w89k-*) basic_machine=hppa1.1-winbond os=-proelf ;; xbox) basic_machine=i686-pc os=-mingw32 ;; xps | xps100) basic_machine=xps100-honeywell ;; xscale-* | xscalee[bl]-*) basic_machine=`echo $basic_machine | sed 's/^xscale/arm/'` ;; ymp) basic_machine=ymp-cray os=-unicos ;; z8k-*-coff) basic_machine=z8k-unknown os=-sim ;; z80-*-coff) basic_machine=z80-unknown os=-sim ;; none) basic_machine=none-none os=-none ;; # Here we handle the default manufacturer of certain CPU types. It is in # some cases the only manufacturer, in others, it is the most popular. w89k) basic_machine=hppa1.1-winbond ;; op50n) basic_machine=hppa1.1-oki ;; op60c) basic_machine=hppa1.1-oki ;; romp) basic_machine=romp-ibm ;; mmix) basic_machine=mmix-knuth ;; rs6000) basic_machine=rs6000-ibm ;; vax) basic_machine=vax-dec ;; pdp10) # there are many clones, so DEC is not a safe bet basic_machine=pdp10-unknown ;; pdp11) basic_machine=pdp11-dec ;; we32k) basic_machine=we32k-att ;; sh[1234] | sh[24]a | sh[24]aeb | sh[34]eb | sh[1234]le | sh[23]ele) basic_machine=sh-unknown ;; sparc | sparcv8 | sparcv9 | sparcv9b | sparcv9v) basic_machine=sparc-sun ;; cydra) basic_machine=cydra-cydrome ;; orion) basic_machine=orion-highlevel ;; orion105) basic_machine=clipper-highlevel ;; mac | mpw | mac-mpw) basic_machine=m68k-apple ;; pmac | pmac-mpw) basic_machine=powerpc-apple ;; *-unknown) # Make sure to match an already-canonicalized machine name. ;; *) echo Invalid configuration \`$1\': machine \`$basic_machine\' not recognized 1>&2 exit 1 ;; esac # Here we canonicalize certain aliases for manufacturers. case $basic_machine in *-digital*) basic_machine=`echo $basic_machine | sed 's/digital.*/dec/'` ;; *-commodore*) basic_machine=`echo $basic_machine | sed 's/commodore.*/cbm/'` ;; *) ;; esac # Decode manufacturer-specific aliases for certain operating systems. if [ x"$os" != x"" ] then case $os in # First match some system type aliases # that might get confused with valid system types. # -solaris* is a basic system type, with this one exception. -auroraux) os=-auroraux ;; -solaris1 | -solaris1.*) os=`echo $os | sed -e 's|solaris1|sunos4|'` ;; -solaris) os=-solaris2 ;; -svr4*) os=-sysv4 ;; -unixware*) os=-sysv4.2uw ;; -gnu/linux*) os=`echo $os | sed -e 's|gnu/linux|linux-gnu|'` ;; # First accept the basic system types. # The portable systems comes first. # Each alternative MUST END IN A *, to match a version number. # -sysv* is not here because it comes later, after sysvr4. -gnu* | -bsd* | -mach* | -minix* | -genix* | -ultrix* | -irix* \ | -*vms* | -sco* | -esix* | -isc* | -aix* | -cnk* | -sunos | -sunos[34]*\ | -hpux* | -unos* | -osf* | -luna* | -dgux* | -auroraux* | -solaris* \ | -sym* | -kopensolaris* | -plan9* \ | -amigaos* | -amigados* | -msdos* | -newsos* | -unicos* | -aof* \ | -aos* | -aros* | -cloudabi* \ | -nindy* | -vxsim* | -vxworks* | -ebmon* | -hms* | -mvs* \ | -clix* | -riscos* | -uniplus* | -iris* | -rtu* | -xenix* \ | -hiux* | -386bsd* | -knetbsd* | -mirbsd* | -netbsd* \ | -bitrig* | -openbsd* | -solidbsd* \ | -ekkobsd* | -kfreebsd* | -freebsd* | -riscix* | -lynxos* \ | -bosx* | -nextstep* | -cxux* | -aout* | -elf* | -oabi* \ | -ptx* | -coff* | -ecoff* | -winnt* | -domain* | -vsta* \ | -udi* | -eabi* | -lites* | -ieee* | -go32* | -aux* \ | -chorusos* | -chorusrdb* | -cegcc* \ | -cygwin* | -msys* | -pe* | -psos* | -moss* | -proelf* | -rtems* \ | -mingw32* | -mingw64* | -linux-gnu* | -linux-android* \ | -linux-newlib* | -linux-musl* | -linux-uclibc* \ | -uxpv* | -beos* | -mpeix* | -udk* | -moxiebox* \ | -interix* | -uwin* | -mks* | -rhapsody* | -darwin* | -opened* \ | -openstep* | -oskit* | -conix* | -pw32* | -nonstopux* \ | -storm-chaos* | -tops10* | -tenex* | -tops20* | -its* \ | -os2* | -vos* | -palmos* | -uclinux* | -nucleus* \ | -morphos* | -superux* | -rtmk* | -rtmk-nova* | -windiss* \ | -powermax* | -dnix* | -nx6 | -nx7 | -sei* | -dragonfly* \ | -skyos* | -haiku* | -rdos* | -toppers* | -drops* | -es* | -tirtos*) # Remember, each alternative MUST END IN *, to match a version number. ;; -qnx*) case $basic_machine in x86-* | i*86-*) ;; *) os=-nto$os ;; esac ;; -nto-qnx*) ;; -nto*) os=`echo $os | sed -e 's|nto|nto-qnx|'` ;; -sim | -es1800* | -hms* | -xray | -os68k* | -none* | -v88r* \ | -windows* | -osx | -abug | -netware* | -os9* | -beos* | -haiku* \ | -macos* | -mpw* | -magic* | -mmixware* | -mon960* | -lnews*) ;; -mac*) os=`echo $os | sed -e 's|mac|macos|'` ;; -linux-dietlibc) os=-linux-dietlibc ;; -linux*) os=`echo $os | sed -e 's|linux|linux-gnu|'` ;; -sunos5*) os=`echo $os | sed -e 's|sunos5|solaris2|'` ;; -sunos6*) os=`echo $os | sed -e 's|sunos6|solaris3|'` ;; -opened*) os=-openedition ;; -os400*) os=-os400 ;; -wince*) os=-wince ;; -osfrose*) os=-osfrose ;; -osf*) os=-osf ;; -utek*) os=-bsd ;; -dynix*) os=-bsd ;; -acis*) os=-aos ;; -atheos*) os=-atheos ;; -syllable*) os=-syllable ;; -386bsd) os=-bsd ;; -ctix* | -uts*) os=-sysv ;; -nova*) os=-rtmk-nova ;; -ns2 ) os=-nextstep2 ;; -nsk*) os=-nsk ;; # Preserve the version number of sinix5. -sinix5.*) os=`echo $os | sed -e 's|sinix|sysv|'` ;; -sinix*) os=-sysv4 ;; -tpf*) os=-tpf ;; -triton*) os=-sysv3 ;; -oss*) os=-sysv3 ;; -svr4) os=-sysv4 ;; -svr3) os=-sysv3 ;; -sysvr4) os=-sysv4 ;; # This must come after -sysvr4. -sysv*) ;; -ose*) os=-ose ;; -es1800*) os=-ose ;; -xenix) os=-xenix ;; -*mint | -mint[0-9]* | -*MiNT | -MiNT[0-9]*) os=-mint ;; -aros*) os=-aros ;; -zvmoe) os=-zvmoe ;; -dicos*) os=-dicos ;; -nacl*) ;; -none) ;; *) # Get rid of the `-' at the beginning of $os. os=`echo $os | sed 's/[^-]*-//'` echo Invalid configuration \`$1\': system \`$os\' not recognized 1>&2 exit 1 ;; esac else # Here we handle the default operating systems that come with various machines. # The value should be what the vendor currently ships out the door with their # machine or put another way, the most popular os provided with the machine. # Note that if you're going to try to match "-MANUFACTURER" here (say, # "-sun"), then you have to tell the case statement up towards the top # that MANUFACTURER isn't an operating system. Otherwise, code above # will signal an error saying that MANUFACTURER isn't an operating # system, and we'll never get to this point. case $basic_machine in score-*) os=-elf ;; spu-*) os=-elf ;; *-acorn) os=-riscix1.2 ;; arm*-rebel) os=-linux ;; arm*-semi) os=-aout ;; c4x-* | tic4x-*) os=-coff ;; c8051-*) os=-elf ;; hexagon-*) os=-elf ;; tic54x-*) os=-coff ;; tic55x-*) os=-coff ;; tic6x-*) os=-coff ;; # This must come before the *-dec entry. pdp10-*) os=-tops20 ;; pdp11-*) os=-none ;; *-dec | vax-*) os=-ultrix4.2 ;; m68*-apollo) os=-domain ;; i386-sun) os=-sunos4.0.2 ;; m68000-sun) os=-sunos3 ;; m68*-cisco) os=-aout ;; mep-*) os=-elf ;; mips*-cisco) os=-elf ;; mips*-*) os=-elf ;; or32-*) os=-coff ;; *-tti) # must be before sparc entry or we get the wrong os. os=-sysv3 ;; sparc-* | *-sun) os=-sunos4.1.1 ;; *-be) os=-beos ;; *-haiku) os=-haiku ;; *-ibm) os=-aix ;; *-knuth) os=-mmixware ;; *-wec) os=-proelf ;; *-winbond) os=-proelf ;; *-oki) os=-proelf ;; *-hp) os=-hpux ;; *-hitachi) os=-hiux ;; i860-* | *-att | *-ncr | *-altos | *-motorola | *-convergent) os=-sysv ;; *-cbm) os=-amigaos ;; *-dg) os=-dgux ;; *-dolphin) os=-sysv3 ;; m68k-ccur) os=-rtu ;; m88k-omron*) os=-luna ;; *-next ) os=-nextstep ;; *-sequent) os=-ptx ;; *-crds) os=-unos ;; *-ns) os=-genix ;; i370-*) os=-mvs ;; *-next) os=-nextstep3 ;; *-gould) os=-sysv ;; *-highlevel) os=-bsd ;; *-encore) os=-bsd ;; *-sgi) os=-irix ;; *-siemens) os=-sysv4 ;; *-masscomp) os=-rtu ;; f30[01]-fujitsu | f700-fujitsu) os=-uxpv ;; *-rom68k) os=-coff ;; *-*bug) os=-coff ;; *-apple) os=-macos ;; *-atari*) os=-mint ;; *) os=-none ;; esac fi # Here we handle the case where we know the os, and the CPU type, but not the # manufacturer. We pick the logical manufacturer. vendor=unknown case $basic_machine in *-unknown) case $os in -riscix*) vendor=acorn ;; -sunos*) vendor=sun ;; -cnk*|-aix*) vendor=ibm ;; -beos*) vendor=be ;; -hpux*) vendor=hp ;; -mpeix*) vendor=hp ;; -hiux*) vendor=hitachi ;; -unos*) vendor=crds ;; -dgux*) vendor=dg ;; -luna*) vendor=omron ;; -genix*) vendor=ns ;; -mvs* | -opened*) vendor=ibm ;; -os400*) vendor=ibm ;; -ptx*) vendor=sequent ;; -tpf*) vendor=ibm ;; -vxsim* | -vxworks* | -windiss*) vendor=wrs ;; -aux*) vendor=apple ;; -hms*) vendor=hitachi ;; -mpw* | -macos*) vendor=apple ;; -*mint | -mint[0-9]* | -*MiNT | -MiNT[0-9]*) vendor=atari ;; -vos*) vendor=stratus ;; esac basic_machine=`echo $basic_machine | sed "s/unknown/$vendor/"` ;; esac echo $basic_machine$os exit # Local variables: # eval: (add-hook 'write-file-hooks 'time-stamp) # time-stamp-start: "timestamp='" # time-stamp-format: "%:y-%02m-%02d" # time-stamp-end: "'" # End: xrdp-0.9.5/libpainter/Makefile.in000644 001751 001751 00000062221 13220730741 016622 0ustar00metameta000000 000000 # Makefile.in generated by automake 1.15.1 from Makefile.am. # @configure_input@ # Copyright (C) 1994-2017 Free Software Foundation, Inc. # This Makefile.in is free software; the Free Software Foundation # gives unlimited permission to copy and/or distribute it, # with or without modifications, as long as this notice is preserved. # This program is distributed in the hope that it will be useful, # but WITHOUT ANY WARRANTY, to the extent permitted by law; without # even the implied warranty of MERCHANTABILITY or FITNESS FOR A # PARTICULAR PURPOSE. @SET_MAKE@ VPATH = @srcdir@ am__is_gnu_make = { \ if test -z '$(MAKELEVEL)'; then \ false; \ elif test -n '$(MAKE_HOST)'; then \ true; \ elif test -n '$(MAKE_VERSION)' && test -n '$(CURDIR)'; then \ true; \ else \ false; \ fi; \ } am__make_running_with_option = \ case $${target_option-} in \ ?) ;; \ *) echo "am__make_running_with_option: internal error: invalid" \ "target option '$${target_option-}' specified" >&2; \ exit 1;; \ esac; \ has_opt=no; \ sane_makeflags=$$MAKEFLAGS; \ if $(am__is_gnu_make); then \ sane_makeflags=$$MFLAGS; \ else \ case $$MAKEFLAGS in \ *\\[\ \ ]*) \ bs=\\; \ sane_makeflags=`printf '%s\n' "$$MAKEFLAGS" \ | sed "s/$$bs$$bs[$$bs $$bs ]*//g"`;; \ esac; \ fi; \ skip_next=no; \ strip_trailopt () \ { \ flg=`printf '%s\n' "$$flg" | sed "s/$$1.*$$//"`; \ }; \ for flg in $$sane_makeflags; do \ test $$skip_next = yes && { skip_next=no; continue; }; \ case $$flg in \ *=*|--*) continue;; \ -*I) strip_trailopt 'I'; skip_next=yes;; \ -*I?*) strip_trailopt 'I';; \ -*O) strip_trailopt 'O'; skip_next=yes;; \ -*O?*) strip_trailopt 'O';; \ -*l) strip_trailopt 'l'; skip_next=yes;; \ -*l?*) strip_trailopt 'l';; \ -[dEDm]) skip_next=yes;; \ -[JT]) skip_next=yes;; \ esac; \ case $$flg in \ *$$target_option*) has_opt=yes; break;; \ esac; \ done; \ test $$has_opt = yes am__make_dryrun = (target_option=n; $(am__make_running_with_option)) am__make_keepgoing = (target_option=k; $(am__make_running_with_option)) pkgdatadir = $(datadir)/@PACKAGE@ pkgincludedir = $(includedir)/@PACKAGE@ pkglibdir = $(libdir)/@PACKAGE@ pkglibexecdir = $(libexecdir)/@PACKAGE@ am__cd = CDPATH="$${ZSH_VERSION+.}$(PATH_SEPARATOR)" && cd install_sh_DATA = $(install_sh) -c -m 644 install_sh_PROGRAM = $(install_sh) -c install_sh_SCRIPT = $(install_sh) -c INSTALL_HEADER = $(INSTALL_DATA) transform = $(program_transform_name) NORMAL_INSTALL = : PRE_INSTALL = : POST_INSTALL = : NORMAL_UNINSTALL = : PRE_UNINSTALL = : POST_UNINSTALL = : build_triplet = @build@ host_triplet = @host@ @PT_TESTS_TRUE@am__append_1 = tests subdir = . ACLOCAL_M4 = $(top_srcdir)/aclocal.m4 am__aclocal_m4_deps = $(top_srcdir)/m4/ax_append_compile_flags.m4 \ $(top_srcdir)/m4/ax_append_flag.m4 \ $(top_srcdir)/m4/ax_cflags_warn_all.m4 \ $(top_srcdir)/m4/ax_check_compile_flag.m4 \ $(top_srcdir)/m4/ax_require_defined.m4 \ $(top_srcdir)/m4/libtool.m4 $(top_srcdir)/m4/ltoptions.m4 \ $(top_srcdir)/m4/ltsugar.m4 $(top_srcdir)/m4/ltversion.m4 \ $(top_srcdir)/m4/lt~obsolete.m4 $(top_srcdir)/m4/pkg.m4 \ $(top_srcdir)/configure.ac am__configure_deps = $(am__aclocal_m4_deps) $(CONFIGURE_DEPENDENCIES) \ $(ACLOCAL_M4) DIST_COMMON = $(srcdir)/Makefile.am $(top_srcdir)/configure \ $(am__configure_deps) $(am__DIST_COMMON) am__CONFIG_DISTCLEAN_FILES = config.status config.cache config.log \ configure.lineno config.status.lineno mkinstalldirs = $(install_sh) -d CONFIG_HEADER = config_ac.h CONFIG_CLEAN_FILES = CONFIG_CLEAN_VPATH_FILES = AM_V_P = $(am__v_P_@AM_V@) am__v_P_ = $(am__v_P_@AM_DEFAULT_V@) am__v_P_0 = false am__v_P_1 = : AM_V_GEN = $(am__v_GEN_@AM_V@) am__v_GEN_ = $(am__v_GEN_@AM_DEFAULT_V@) am__v_GEN_0 = @echo " GEN " $@; am__v_GEN_1 = AM_V_at = $(am__v_at_@AM_V@) am__v_at_ = $(am__v_at_@AM_DEFAULT_V@) am__v_at_0 = @ am__v_at_1 = SOURCES = DIST_SOURCES = RECURSIVE_TARGETS = all-recursive check-recursive cscopelist-recursive \ ctags-recursive dvi-recursive html-recursive info-recursive \ install-data-recursive install-dvi-recursive \ install-exec-recursive install-html-recursive \ install-info-recursive install-pdf-recursive \ install-ps-recursive install-recursive installcheck-recursive \ installdirs-recursive pdf-recursive ps-recursive \ tags-recursive uninstall-recursive am__can_run_installinfo = \ case $$AM_UPDATE_INFO_DIR in \ n|no|NO) false;; \ *) (install-info --version) >/dev/null 2>&1;; \ esac RECURSIVE_CLEAN_TARGETS = mostlyclean-recursive clean-recursive \ distclean-recursive maintainer-clean-recursive am__recursive_targets = \ $(RECURSIVE_TARGETS) \ $(RECURSIVE_CLEAN_TARGETS) \ $(am__extra_recursive_targets) AM_RECURSIVE_TARGETS = $(am__recursive_targets:-recursive=) TAGS CTAGS \ cscope distdir dist dist-all distcheck am__tagged_files = $(HEADERS) $(SOURCES) $(TAGS_FILES) \ $(LISP)config_ac-h.in # Read a list of newline-separated strings from the standard input, # and print each of them once, without duplicates. Input order is # *not* preserved. am__uniquify_input = $(AWK) '\ BEGIN { nonempty = 0; } \ { items[$$0] = 1; nonempty = 1; } \ END { if (nonempty) { for (i in items) print i; }; } \ ' # Make sure the list of sources is unique. This is necessary because, # e.g., the same source file might be shared among _SOURCES variables # for different programs/libraries. am__define_uniq_tagged_files = \ list='$(am__tagged_files)'; \ unique=`for i in $$list; do \ if test -f "$$i"; then echo $$i; else echo $(srcdir)/$$i; fi; \ done | $(am__uniquify_input)` ETAGS = etags CTAGS = ctags CSCOPE = cscope DIST_SUBDIRS = src include pkgconfig tests am__DIST_COMMON = $(srcdir)/Makefile.in $(srcdir)/config_ac-h.in \ AUTHORS ChangeLog NEWS README compile config.guess config.sub \ install-sh ltmain.sh missing DISTFILES = $(DIST_COMMON) $(DIST_SOURCES) $(TEXINFOS) $(EXTRA_DIST) distdir = $(PACKAGE)-$(VERSION) top_distdir = $(distdir) am__remove_distdir = \ if test -d "$(distdir)"; then \ find "$(distdir)" -type d ! -perm -200 -exec chmod u+w {} ';' \ && rm -rf "$(distdir)" \ || { sleep 5 && rm -rf "$(distdir)"; }; \ else :; fi am__post_remove_distdir = $(am__remove_distdir) am__relativize = \ dir0=`pwd`; \ sed_first='s,^\([^/]*\)/.*$$,\1,'; \ sed_rest='s,^[^/]*/*,,'; \ sed_last='s,^.*/\([^/]*\)$$,\1,'; \ sed_butlast='s,/*[^/]*$$,,'; \ while test -n "$$dir1"; do \ first=`echo "$$dir1" | sed -e "$$sed_first"`; \ if test "$$first" != "."; then \ if test "$$first" = ".."; then \ dir2=`echo "$$dir0" | sed -e "$$sed_last"`/"$$dir2"; \ dir0=`echo "$$dir0" | sed -e "$$sed_butlast"`; \ else \ first2=`echo "$$dir2" | sed -e "$$sed_first"`; \ if test "$$first2" = "$$first"; then \ dir2=`echo "$$dir2" | sed -e "$$sed_rest"`; \ else \ dir2="../$$dir2"; \ fi; \ dir0="$$dir0"/"$$first"; \ fi; \ fi; \ dir1=`echo "$$dir1" | sed -e "$$sed_rest"`; \ done; \ reldir="$$dir2" DIST_ARCHIVES = $(distdir).tar.gz GZIP_ENV = --best DIST_TARGETS = dist-gzip distuninstallcheck_listfiles = find . -type f -print am__distuninstallcheck_listfiles = $(distuninstallcheck_listfiles) \ | sed 's|^\./|$(prefix)/|' | grep -v '$(infodir)/dir$$' distcleancheck_listfiles = find . -type f -print ACLOCAL = @ACLOCAL@ AMTAR = @AMTAR@ AM_DEFAULT_VERBOSITY = @AM_DEFAULT_VERBOSITY@ AR = @AR@ AUTOCONF = @AUTOCONF@ AUTOHEADER = @AUTOHEADER@ AUTOMAKE = @AUTOMAKE@ AWK = @AWK@ CC = @CC@ CCDEPMODE = @CCDEPMODE@ CFLAGS = @CFLAGS@ CPP = @CPP@ CPPFLAGS = @CPPFLAGS@ CYGPATH_W = @CYGPATH_W@ DEFS = @DEFS@ DEPDIR = @DEPDIR@ DLLTOOL = @DLLTOOL@ DSYMUTIL = @DSYMUTIL@ DUMPBIN = @DUMPBIN@ ECHO_C = @ECHO_C@ ECHO_N = @ECHO_N@ ECHO_T = @ECHO_T@ EGREP = @EGREP@ EXEEXT = @EXEEXT@ FGREP = @FGREP@ GREP = @GREP@ INSTALL = @INSTALL@ INSTALL_DATA = @INSTALL_DATA@ INSTALL_PROGRAM = @INSTALL_PROGRAM@ INSTALL_SCRIPT = @INSTALL_SCRIPT@ INSTALL_STRIP_PROGRAM = @INSTALL_STRIP_PROGRAM@ LD = @LD@ LDFLAGS = @LDFLAGS@ LIBOBJS = @LIBOBJS@ LIBS = @LIBS@ LIBTOOL = @LIBTOOL@ LIPO = @LIPO@ LN_S = @LN_S@ LTLIBOBJS = @LTLIBOBJS@ LT_SYS_LIBRARY_PATH = @LT_SYS_LIBRARY_PATH@ MAKEINFO = @MAKEINFO@ MANIFEST_TOOL = @MANIFEST_TOOL@ MKDIR_P = @MKDIR_P@ NM = @NM@ NMEDIT = @NMEDIT@ OBJDUMP = @OBJDUMP@ OBJEXT = @OBJEXT@ OTOOL = @OTOOL@ OTOOL64 = @OTOOL64@ PACKAGE = @PACKAGE@ PACKAGE_BUGREPORT = @PACKAGE_BUGREPORT@ PACKAGE_NAME = @PACKAGE_NAME@ PACKAGE_STRING = @PACKAGE_STRING@ PACKAGE_TARNAME = @PACKAGE_TARNAME@ PACKAGE_URL = @PACKAGE_URL@ PACKAGE_VERSION = @PACKAGE_VERSION@ PATH_SEPARATOR = @PATH_SEPARATOR@ RANLIB = @RANLIB@ SED = @SED@ SET_MAKE = @SET_MAKE@ SHELL = @SHELL@ STRIP = @STRIP@ VERSION = @VERSION@ abs_builddir = @abs_builddir@ abs_srcdir = @abs_srcdir@ abs_top_builddir = @abs_top_builddir@ abs_top_srcdir = @abs_top_srcdir@ ac_ct_AR = @ac_ct_AR@ ac_ct_CC = @ac_ct_CC@ ac_ct_DUMPBIN = @ac_ct_DUMPBIN@ am__include = @am__include@ am__leading_dot = @am__leading_dot@ am__quote = @am__quote@ am__tar = @am__tar@ am__untar = @am__untar@ bindir = @bindir@ build = @build@ build_alias = @build_alias@ build_cpu = @build_cpu@ build_os = @build_os@ build_vendor = @build_vendor@ builddir = @builddir@ datadir = @datadir@ datarootdir = @datarootdir@ docdir = @docdir@ dvidir = @dvidir@ exec_prefix = @exec_prefix@ host = @host@ host_alias = @host_alias@ host_cpu = @host_cpu@ host_os = @host_os@ host_vendor = @host_vendor@ htmldir = @htmldir@ includedir = @includedir@ infodir = @infodir@ install_sh = @install_sh@ libdir = @libdir@ libexecdir = @libexecdir@ localedir = @localedir@ localstatedir = @localstatedir@ mandir = @mandir@ mkdir_p = @mkdir_p@ oldincludedir = @oldincludedir@ pdfdir = @pdfdir@ pkgconfigdir = @pkgconfigdir@ prefix = @prefix@ program_transform_name = @program_transform_name@ psdir = @psdir@ sbindir = @sbindir@ sharedstatedir = @sharedstatedir@ srcdir = @srcdir@ sysconfdir = @sysconfdir@ target_alias = @target_alias@ top_build_prefix = @top_build_prefix@ top_builddir = @top_builddir@ top_srcdir = @top_srcdir@ ACLOCAL_AMFLAGS = -I m4 EXTRA_DIST = bootstrap EXTRA_DIRS = $(am__append_1) SUBDIRS = \ src \ include \ pkgconfig \ $(EXTRA_DIRS) all: config_ac.h $(MAKE) $(AM_MAKEFLAGS) all-recursive .SUFFIXES: am--refresh: Makefile @: $(srcdir)/Makefile.in: $(srcdir)/Makefile.am $(am__configure_deps) @for dep in $?; do \ case '$(am__configure_deps)' in \ *$$dep*) \ echo ' cd $(srcdir) && $(AUTOMAKE) --foreign'; \ $(am__cd) $(srcdir) && $(AUTOMAKE) --foreign \ && exit 0; \ exit 1;; \ esac; \ done; \ echo ' cd $(top_srcdir) && $(AUTOMAKE) --foreign Makefile'; \ $(am__cd) $(top_srcdir) && \ $(AUTOMAKE) --foreign Makefile Makefile: $(srcdir)/Makefile.in $(top_builddir)/config.status @case '$?' in \ *config.status*) \ echo ' $(SHELL) ./config.status'; \ $(SHELL) ./config.status;; \ *) \ echo ' cd $(top_builddir) && $(SHELL) ./config.status $@ $(am__depfiles_maybe)'; \ cd $(top_builddir) && $(SHELL) ./config.status $@ $(am__depfiles_maybe);; \ esac; $(top_builddir)/config.status: $(top_srcdir)/configure $(CONFIG_STATUS_DEPENDENCIES) $(SHELL) ./config.status --recheck $(top_srcdir)/configure: $(am__configure_deps) $(am__cd) $(srcdir) && $(AUTOCONF) $(ACLOCAL_M4): $(am__aclocal_m4_deps) $(am__cd) $(srcdir) && $(ACLOCAL) $(ACLOCAL_AMFLAGS) $(am__aclocal_m4_deps): config_ac.h: stamp-h1 @test -f $@ || rm -f stamp-h1 @test -f $@ || $(MAKE) $(AM_MAKEFLAGS) stamp-h1 stamp-h1: $(srcdir)/config_ac-h.in $(top_builddir)/config.status @rm -f stamp-h1 cd $(top_builddir) && $(SHELL) ./config.status config_ac.h $(srcdir)/config_ac-h.in: $(am__configure_deps) ($(am__cd) $(top_srcdir) && $(AUTOHEADER)) rm -f stamp-h1 touch $@ distclean-hdr: -rm -f config_ac.h stamp-h1 mostlyclean-libtool: -rm -f *.lo clean-libtool: -rm -rf .libs _libs distclean-libtool: -rm -f libtool config.lt # This directory's subdirectories are mostly independent; you can cd # into them and run 'make' without going through this Makefile. # To change the values of 'make' variables: instead of editing Makefiles, # (1) if the variable is set in 'config.status', edit 'config.status' # (which will cause the Makefiles to be regenerated when you run 'make'); # (2) otherwise, pass the desired values on the 'make' command line. $(am__recursive_targets): @fail=; \ if $(am__make_keepgoing); then \ failcom='fail=yes'; \ else \ failcom='exit 1'; \ fi; \ dot_seen=no; \ target=`echo $@ | sed s/-recursive//`; \ case "$@" in \ distclean-* | maintainer-clean-*) list='$(DIST_SUBDIRS)' ;; \ *) list='$(SUBDIRS)' ;; \ esac; \ for subdir in $$list; do \ echo "Making $$target in $$subdir"; \ if test "$$subdir" = "."; then \ dot_seen=yes; \ local_target="$$target-am"; \ else \ local_target="$$target"; \ fi; \ ($(am__cd) $$subdir && $(MAKE) $(AM_MAKEFLAGS) $$local_target) \ || eval $$failcom; \ done; \ if test "$$dot_seen" = "no"; then \ $(MAKE) $(AM_MAKEFLAGS) "$$target-am" || exit 1; \ fi; test -z "$$fail" ID: $(am__tagged_files) $(am__define_uniq_tagged_files); mkid -fID $$unique tags: tags-recursive TAGS: tags tags-am: $(TAGS_DEPENDENCIES) $(am__tagged_files) set x; \ here=`pwd`; \ if ($(ETAGS) --etags-include --version) >/dev/null 2>&1; then \ include_option=--etags-include; \ empty_fix=.; \ else \ include_option=--include; \ empty_fix=; \ fi; \ list='$(SUBDIRS)'; for subdir in $$list; do \ if test "$$subdir" = .; then :; else \ test ! -f $$subdir/TAGS || \ set "$$@" "$$include_option=$$here/$$subdir/TAGS"; \ fi; \ done; \ $(am__define_uniq_tagged_files); \ shift; \ if test -z "$(ETAGS_ARGS)$$*$$unique"; then :; else \ test -n "$$unique" || unique=$$empty_fix; \ if test $$# -gt 0; then \ $(ETAGS) $(ETAGSFLAGS) $(AM_ETAGSFLAGS) $(ETAGS_ARGS) \ "$$@" $$unique; \ else \ $(ETAGS) $(ETAGSFLAGS) $(AM_ETAGSFLAGS) $(ETAGS_ARGS) \ $$unique; \ fi; \ fi ctags: ctags-recursive CTAGS: ctags ctags-am: $(TAGS_DEPENDENCIES) $(am__tagged_files) $(am__define_uniq_tagged_files); \ test -z "$(CTAGS_ARGS)$$unique" \ || $(CTAGS) $(CTAGSFLAGS) $(AM_CTAGSFLAGS) $(CTAGS_ARGS) \ $$unique GTAGS: here=`$(am__cd) $(top_builddir) && pwd` \ && $(am__cd) $(top_srcdir) \ && gtags -i $(GTAGS_ARGS) "$$here" cscope: cscope.files test ! -s cscope.files \ || $(CSCOPE) -b -q $(AM_CSCOPEFLAGS) $(CSCOPEFLAGS) -i cscope.files $(CSCOPE_ARGS) clean-cscope: -rm -f cscope.files cscope.files: clean-cscope cscopelist cscopelist: cscopelist-recursive cscopelist-am: $(am__tagged_files) list='$(am__tagged_files)'; \ case "$(srcdir)" in \ [\\/]* | ?:[\\/]*) sdir="$(srcdir)" ;; \ *) sdir=$(subdir)/$(srcdir) ;; \ esac; \ for i in $$list; do \ if test -f "$$i"; then \ echo "$(subdir)/$$i"; \ else \ echo "$$sdir/$$i"; \ fi; \ done >> $(top_builddir)/cscope.files distclean-tags: -rm -f TAGS ID GTAGS GRTAGS GSYMS GPATH tags -rm -f cscope.out cscope.in.out cscope.po.out cscope.files distdir: $(DISTFILES) $(am__remove_distdir) test -d "$(distdir)" || mkdir "$(distdir)" @srcdirstrip=`echo "$(srcdir)" | sed 's/[].[^$$\\*]/\\\\&/g'`; \ topsrcdirstrip=`echo "$(top_srcdir)" | sed 's/[].[^$$\\*]/\\\\&/g'`; \ list='$(DISTFILES)'; \ dist_files=`for file in $$list; do echo $$file; done | \ sed -e "s|^$$srcdirstrip/||;t" \ -e "s|^$$topsrcdirstrip/|$(top_builddir)/|;t"`; \ case $$dist_files in \ */*) $(MKDIR_P) `echo "$$dist_files" | \ sed '/\//!d;s|^|$(distdir)/|;s,/[^/]*$$,,' | \ sort -u` ;; \ esac; \ for file in $$dist_files; do \ if test -f $$file || test -d $$file; then d=.; else d=$(srcdir); fi; \ if test -d $$d/$$file; then \ dir=`echo "/$$file" | sed -e 's,/[^/]*$$,,'`; \ if test -d "$(distdir)/$$file"; then \ find "$(distdir)/$$file" -type d ! -perm -700 -exec chmod u+rwx {} \;; \ fi; \ if test -d $(srcdir)/$$file && test $$d != $(srcdir); then \ cp -fpR $(srcdir)/$$file "$(distdir)$$dir" || exit 1; \ find "$(distdir)/$$file" -type d ! -perm -700 -exec chmod u+rwx {} \;; \ fi; \ cp -fpR $$d/$$file "$(distdir)$$dir" || exit 1; \ else \ test -f "$(distdir)/$$file" \ || cp -p $$d/$$file "$(distdir)/$$file" \ || exit 1; \ fi; \ done @list='$(DIST_SUBDIRS)'; for subdir in $$list; do \ if test "$$subdir" = .; then :; else \ $(am__make_dryrun) \ || test -d "$(distdir)/$$subdir" \ || $(MKDIR_P) "$(distdir)/$$subdir" \ || exit 1; \ dir1=$$subdir; dir2="$(distdir)/$$subdir"; \ $(am__relativize); \ new_distdir=$$reldir; \ dir1=$$subdir; dir2="$(top_distdir)"; \ $(am__relativize); \ new_top_distdir=$$reldir; \ echo " (cd $$subdir && $(MAKE) $(AM_MAKEFLAGS) top_distdir="$$new_top_distdir" distdir="$$new_distdir" \\"; \ echo " am__remove_distdir=: am__skip_length_check=: am__skip_mode_fix=: distdir)"; \ ($(am__cd) $$subdir && \ $(MAKE) $(AM_MAKEFLAGS) \ top_distdir="$$new_top_distdir" \ distdir="$$new_distdir" \ am__remove_distdir=: \ am__skip_length_check=: \ am__skip_mode_fix=: \ distdir) \ || exit 1; \ fi; \ done -test -n "$(am__skip_mode_fix)" \ || find "$(distdir)" -type d ! -perm -755 \ -exec chmod u+rwx,go+rx {} \; -o \ ! -type d ! -perm -444 -links 1 -exec chmod a+r {} \; -o \ ! -type d ! -perm -400 -exec chmod a+r {} \; -o \ ! -type d ! -perm -444 -exec $(install_sh) -c -m a+r {} {} \; \ || chmod -R a+r "$(distdir)" dist-gzip: distdir tardir=$(distdir) && $(am__tar) | eval GZIP= gzip $(GZIP_ENV) -c >$(distdir).tar.gz $(am__post_remove_distdir) dist-bzip2: distdir tardir=$(distdir) && $(am__tar) | BZIP2=$${BZIP2--9} bzip2 -c >$(distdir).tar.bz2 $(am__post_remove_distdir) dist-lzip: distdir tardir=$(distdir) && $(am__tar) | lzip -c $${LZIP_OPT--9} >$(distdir).tar.lz $(am__post_remove_distdir) dist-xz: distdir tardir=$(distdir) && $(am__tar) | XZ_OPT=$${XZ_OPT--e} xz -c >$(distdir).tar.xz $(am__post_remove_distdir) dist-tarZ: distdir @echo WARNING: "Support for distribution archives compressed with" \ "legacy program 'compress' is deprecated." >&2 @echo WARNING: "It will be removed altogether in Automake 2.0" >&2 tardir=$(distdir) && $(am__tar) | compress -c >$(distdir).tar.Z $(am__post_remove_distdir) dist-shar: distdir @echo WARNING: "Support for shar distribution archives is" \ "deprecated." >&2 @echo WARNING: "It will be removed altogether in Automake 2.0" >&2 shar $(distdir) | eval GZIP= gzip $(GZIP_ENV) -c >$(distdir).shar.gz $(am__post_remove_distdir) dist-zip: distdir -rm -f $(distdir).zip zip -rq $(distdir).zip $(distdir) $(am__post_remove_distdir) dist dist-all: $(MAKE) $(AM_MAKEFLAGS) $(DIST_TARGETS) am__post_remove_distdir='@:' $(am__post_remove_distdir) # This target untars the dist file and tries a VPATH configuration. Then # it guarantees that the distribution is self-contained by making another # tarfile. distcheck: dist case '$(DIST_ARCHIVES)' in \ *.tar.gz*) \ eval GZIP= gzip $(GZIP_ENV) -dc $(distdir).tar.gz | $(am__untar) ;;\ *.tar.bz2*) \ bzip2 -dc $(distdir).tar.bz2 | $(am__untar) ;;\ *.tar.lz*) \ lzip -dc $(distdir).tar.lz | $(am__untar) ;;\ *.tar.xz*) \ xz -dc $(distdir).tar.xz | $(am__untar) ;;\ *.tar.Z*) \ uncompress -c $(distdir).tar.Z | $(am__untar) ;;\ *.shar.gz*) \ eval GZIP= gzip $(GZIP_ENV) -dc $(distdir).shar.gz | unshar ;;\ *.zip*) \ unzip $(distdir).zip ;;\ esac chmod -R a-w $(distdir) chmod u+w $(distdir) mkdir $(distdir)/_build $(distdir)/_build/sub $(distdir)/_inst chmod a-w $(distdir) test -d $(distdir)/_build || exit 0; \ dc_install_base=`$(am__cd) $(distdir)/_inst && pwd | sed -e 's,^[^:\\/]:[\\/],/,'` \ && dc_destdir="$${TMPDIR-/tmp}/am-dc-$$$$/" \ && am__cwd=`pwd` \ && $(am__cd) $(distdir)/_build/sub \ && ../../configure \ $(AM_DISTCHECK_CONFIGURE_FLAGS) \ $(DISTCHECK_CONFIGURE_FLAGS) \ --srcdir=../.. --prefix="$$dc_install_base" \ && $(MAKE) $(AM_MAKEFLAGS) \ && $(MAKE) $(AM_MAKEFLAGS) dvi \ && $(MAKE) $(AM_MAKEFLAGS) check \ && $(MAKE) $(AM_MAKEFLAGS) install \ && $(MAKE) $(AM_MAKEFLAGS) installcheck \ && $(MAKE) $(AM_MAKEFLAGS) uninstall \ && $(MAKE) $(AM_MAKEFLAGS) distuninstallcheck_dir="$$dc_install_base" \ distuninstallcheck \ && chmod -R a-w "$$dc_install_base" \ && ({ \ (cd ../.. && umask 077 && mkdir "$$dc_destdir") \ && $(MAKE) $(AM_MAKEFLAGS) DESTDIR="$$dc_destdir" install \ && $(MAKE) $(AM_MAKEFLAGS) DESTDIR="$$dc_destdir" uninstall \ && $(MAKE) $(AM_MAKEFLAGS) DESTDIR="$$dc_destdir" \ distuninstallcheck_dir="$$dc_destdir" distuninstallcheck; \ } || { rm -rf "$$dc_destdir"; exit 1; }) \ && rm -rf "$$dc_destdir" \ && $(MAKE) $(AM_MAKEFLAGS) dist \ && rm -rf $(DIST_ARCHIVES) \ && $(MAKE) $(AM_MAKEFLAGS) distcleancheck \ && cd "$$am__cwd" \ || exit 1 $(am__post_remove_distdir) @(echo "$(distdir) archives ready for distribution: "; \ list='$(DIST_ARCHIVES)'; for i in $$list; do echo $$i; done) | \ sed -e 1h -e 1s/./=/g -e 1p -e 1x -e '$$p' -e '$$x' distuninstallcheck: @test -n '$(distuninstallcheck_dir)' || { \ echo 'ERROR: trying to run $@ with an empty' \ '$$(distuninstallcheck_dir)' >&2; \ exit 1; \ }; \ $(am__cd) '$(distuninstallcheck_dir)' || { \ echo 'ERROR: cannot chdir into $(distuninstallcheck_dir)' >&2; \ exit 1; \ }; \ test `$(am__distuninstallcheck_listfiles) | wc -l` -eq 0 \ || { echo "ERROR: files left after uninstall:" ; \ if test -n "$(DESTDIR)"; then \ echo " (check DESTDIR support)"; \ fi ; \ $(distuninstallcheck_listfiles) ; \ exit 1; } >&2 distcleancheck: distclean @if test '$(srcdir)' = . ; then \ echo "ERROR: distcleancheck can only run from a VPATH build" ; \ exit 1 ; \ fi @test `$(distcleancheck_listfiles) | wc -l` -eq 0 \ || { echo "ERROR: files left in build directory after distclean:" ; \ $(distcleancheck_listfiles) ; \ exit 1; } >&2 check-am: all-am check: check-recursive all-am: Makefile config_ac.h installdirs: installdirs-recursive installdirs-am: install: install-recursive install-exec: install-exec-recursive install-data: install-data-recursive uninstall: uninstall-recursive install-am: all-am @$(MAKE) $(AM_MAKEFLAGS) install-exec-am install-data-am installcheck: installcheck-recursive install-strip: if test -z '$(STRIP)'; then \ $(MAKE) $(AM_MAKEFLAGS) INSTALL_PROGRAM="$(INSTALL_STRIP_PROGRAM)" \ install_sh_PROGRAM="$(INSTALL_STRIP_PROGRAM)" INSTALL_STRIP_FLAG=-s \ install; \ else \ $(MAKE) $(AM_MAKEFLAGS) INSTALL_PROGRAM="$(INSTALL_STRIP_PROGRAM)" \ install_sh_PROGRAM="$(INSTALL_STRIP_PROGRAM)" INSTALL_STRIP_FLAG=-s \ "INSTALL_PROGRAM_ENV=STRIPPROG='$(STRIP)'" install; \ fi mostlyclean-generic: clean-generic: distclean-generic: -test -z "$(CONFIG_CLEAN_FILES)" || rm -f $(CONFIG_CLEAN_FILES) -test . = "$(srcdir)" || test -z "$(CONFIG_CLEAN_VPATH_FILES)" || rm -f $(CONFIG_CLEAN_VPATH_FILES) maintainer-clean-generic: @echo "This command is intended for maintainers to use" @echo "it deletes files that may require special tools to rebuild." clean: clean-recursive clean-am: clean-generic clean-libtool mostlyclean-am distclean: distclean-recursive -rm -f $(am__CONFIG_DISTCLEAN_FILES) -rm -f Makefile distclean-am: clean-am distclean-generic distclean-hdr \ distclean-libtool distclean-tags dvi: dvi-recursive dvi-am: html: html-recursive html-am: info: info-recursive info-am: install-data-am: install-dvi: install-dvi-recursive install-dvi-am: install-exec-am: install-html: install-html-recursive install-html-am: install-info: install-info-recursive install-info-am: install-man: install-pdf: install-pdf-recursive install-pdf-am: install-ps: install-ps-recursive install-ps-am: installcheck-am: maintainer-clean: maintainer-clean-recursive -rm -f $(am__CONFIG_DISTCLEAN_FILES) -rm -rf $(top_srcdir)/autom4te.cache -rm -f Makefile maintainer-clean-am: distclean-am maintainer-clean-generic mostlyclean: mostlyclean-recursive mostlyclean-am: mostlyclean-generic mostlyclean-libtool pdf: pdf-recursive pdf-am: ps: ps-recursive ps-am: uninstall-am: .MAKE: $(am__recursive_targets) all install-am install-strip .PHONY: $(am__recursive_targets) CTAGS GTAGS TAGS all all-am \ am--refresh check check-am clean clean-cscope clean-generic \ clean-libtool cscope cscopelist-am ctags ctags-am dist \ dist-all dist-bzip2 dist-gzip dist-lzip dist-shar dist-tarZ \ dist-xz dist-zip distcheck distclean distclean-generic \ distclean-hdr distclean-libtool distclean-tags distcleancheck \ distdir distuninstallcheck dvi dvi-am html html-am info \ info-am install install-am install-data install-data-am \ install-dvi install-dvi-am install-exec install-exec-am \ install-html install-html-am install-info install-info-am \ install-man install-pdf install-pdf-am install-ps \ install-ps-am install-strip installcheck installcheck-am \ installdirs installdirs-am maintainer-clean \ maintainer-clean-generic mostlyclean mostlyclean-generic \ mostlyclean-libtool pdf pdf-am ps ps-am tags tags-am uninstall \ uninstall-am .PRECIOUS: Makefile # Tell versions [3.59,3.63) of GNU make to not export all variables. # Otherwise a system limit (for SysV at least) may be exceeded. .NOEXPORT: xrdp-0.9.5/libpainter/configure000755 001751 001751 00001516565 13220730740 016503 0ustar00metameta000000 000000 #! /bin/sh # Guess values for system-dependent variables and create Makefiles. # Generated by GNU Autoconf 2.69 for libpainter 0.1.1. # # Report bugs to . # # # Copyright (C) 1992-1996, 1998-2012 Free Software Foundation, Inc. # # # This configure script is free software; the Free Software Foundation # gives unlimited permission to copy, distribute and modify it. ## -------------------- ## ## M4sh Initialization. ## ## -------------------- ## # Be more Bourne compatible DUALCASE=1; export DUALCASE # for MKS sh if test -n "${ZSH_VERSION+set}" && (emulate sh) >/dev/null 2>&1; then : emulate sh NULLCMD=: # Pre-4.2 versions of Zsh do word splitting on ${1+"$@"}, which # is contrary to our usage. Disable this feature. alias -g '${1+"$@"}'='"$@"' setopt NO_GLOB_SUBST else case `(set -o) 2>/dev/null` in #( *posix*) : set -o posix ;; #( *) : ;; esac fi as_nl=' ' export as_nl # Printing a long string crashes Solaris 7 /usr/bin/printf. as_echo='\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\' as_echo=$as_echo$as_echo$as_echo$as_echo$as_echo as_echo=$as_echo$as_echo$as_echo$as_echo$as_echo$as_echo # Prefer a ksh shell builtin over an external printf program on Solaris, # but without wasting forks for bash or zsh. if test -z "$BASH_VERSION$ZSH_VERSION" \ && (test "X`print -r -- $as_echo`" = "X$as_echo") 2>/dev/null; then as_echo='print -r --' as_echo_n='print -rn --' elif (test "X`printf %s $as_echo`" = "X$as_echo") 2>/dev/null; then as_echo='printf %s\n' as_echo_n='printf %s' else if test "X`(/usr/ucb/echo -n -n $as_echo) 2>/dev/null`" = "X-n $as_echo"; then as_echo_body='eval /usr/ucb/echo -n "$1$as_nl"' as_echo_n='/usr/ucb/echo -n' else as_echo_body='eval expr "X$1" : "X\\(.*\\)"' as_echo_n_body='eval arg=$1; case $arg in #( *"$as_nl"*) expr "X$arg" : "X\\(.*\\)$as_nl"; arg=`expr "X$arg" : ".*$as_nl\\(.*\\)"`;; esac; expr "X$arg" : "X\\(.*\\)" | tr -d "$as_nl" ' export as_echo_n_body as_echo_n='sh -c $as_echo_n_body as_echo' fi export as_echo_body as_echo='sh -c $as_echo_body as_echo' fi # The user is always right. if test "${PATH_SEPARATOR+set}" != set; then PATH_SEPARATOR=: (PATH='/bin;/bin'; FPATH=$PATH; sh -c :) >/dev/null 2>&1 && { (PATH='/bin:/bin'; FPATH=$PATH; sh -c :) >/dev/null 2>&1 || PATH_SEPARATOR=';' } fi # IFS # We need space, tab and new line, in precisely that order. Quoting is # there to prevent editors from complaining about space-tab. # (If _AS_PATH_WALK were called with IFS unset, it would disable word # splitting by setting IFS to empty value.) IFS=" "" $as_nl" # Find who we are. Look in the path if we contain no directory separator. as_myself= case $0 in #(( *[\\/]* ) as_myself=$0 ;; *) as_save_IFS=$IFS; IFS=$PATH_SEPARATOR for as_dir in $PATH do IFS=$as_save_IFS test -z "$as_dir" && as_dir=. test -r "$as_dir/$0" && as_myself=$as_dir/$0 && break done IFS=$as_save_IFS ;; esac # We did not find ourselves, most probably we were run as `sh COMMAND' # in which case we are not to be found in the path. if test "x$as_myself" = x; then as_myself=$0 fi if test ! -f "$as_myself"; then $as_echo "$as_myself: error: cannot find myself; rerun with an absolute file name" >&2 exit 1 fi # Unset variables that we do not need and which cause bugs (e.g. in # pre-3.0 UWIN ksh). But do not cause bugs in bash 2.01; the "|| exit 1" # suppresses any "Segmentation fault" message there. '((' could # trigger a bug in pdksh 5.2.14. for as_var in BASH_ENV ENV MAIL MAILPATH do eval test x\${$as_var+set} = xset \ && ( (unset $as_var) || exit 1) >/dev/null 2>&1 && unset $as_var || : done PS1='$ ' PS2='> ' PS4='+ ' # NLS nuisances. LC_ALL=C export LC_ALL LANGUAGE=C export LANGUAGE # CDPATH. (unset CDPATH) >/dev/null 2>&1 && unset CDPATH # Use a proper internal environment variable to ensure we don't fall # into an infinite loop, continuously re-executing ourselves. if test x"${_as_can_reexec}" != xno && test "x$CONFIG_SHELL" != x; then _as_can_reexec=no; export _as_can_reexec; # We cannot yet assume a decent shell, so we have to provide a # neutralization value for shells without unset; and this also # works around shells that cannot unset nonexistent variables. # Preserve -v and -x to the replacement shell. BASH_ENV=/dev/null ENV=/dev/null (unset BASH_ENV) >/dev/null 2>&1 && unset BASH_ENV ENV case $- in # (((( *v*x* | *x*v* ) as_opts=-vx ;; *v* ) as_opts=-v ;; *x* ) as_opts=-x ;; * ) as_opts= ;; esac exec $CONFIG_SHELL $as_opts "$as_myself" ${1+"$@"} # Admittedly, this is quite paranoid, since all the known shells bail # out after a failed `exec'. $as_echo "$0: could not re-execute with $CONFIG_SHELL" >&2 as_fn_exit 255 fi # We don't want this to propagate to other subprocesses. { _as_can_reexec=; unset _as_can_reexec;} if test "x$CONFIG_SHELL" = x; then as_bourne_compatible="if test -n \"\${ZSH_VERSION+set}\" && (emulate sh) >/dev/null 2>&1; then : emulate sh NULLCMD=: # Pre-4.2 versions of Zsh do word splitting on \${1+\"\$@\"}, which # is contrary to our usage. Disable this feature. alias -g '\${1+\"\$@\"}'='\"\$@\"' setopt NO_GLOB_SUBST else case \`(set -o) 2>/dev/null\` in #( *posix*) : set -o posix ;; #( *) : ;; esac fi " as_required="as_fn_return () { (exit \$1); } as_fn_success () { as_fn_return 0; } as_fn_failure () { as_fn_return 1; } as_fn_ret_success () { return 0; } as_fn_ret_failure () { return 1; } exitcode=0 as_fn_success || { exitcode=1; echo as_fn_success failed.; } as_fn_failure && { exitcode=1; echo as_fn_failure succeeded.; } as_fn_ret_success || { exitcode=1; echo as_fn_ret_success failed.; } as_fn_ret_failure && { exitcode=1; echo as_fn_ret_failure succeeded.; } if ( set x; as_fn_ret_success y && test x = \"\$1\" ); then : else exitcode=1; echo positional parameters were not saved. fi test x\$exitcode = x0 || exit 1 test -x / || exit 1" as_suggested=" as_lineno_1=";as_suggested=$as_suggested$LINENO;as_suggested=$as_suggested" as_lineno_1a=\$LINENO as_lineno_2=";as_suggested=$as_suggested$LINENO;as_suggested=$as_suggested" as_lineno_2a=\$LINENO eval 'test \"x\$as_lineno_1'\$as_run'\" != \"x\$as_lineno_2'\$as_run'\" && test \"x\`expr \$as_lineno_1'\$as_run' + 1\`\" = \"x\$as_lineno_2'\$as_run'\"' || exit 1 test -n \"\${ZSH_VERSION+set}\${BASH_VERSION+set}\" || ( ECHO='\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\' ECHO=\$ECHO\$ECHO\$ECHO\$ECHO\$ECHO ECHO=\$ECHO\$ECHO\$ECHO\$ECHO\$ECHO\$ECHO PATH=/empty FPATH=/empty; export PATH FPATH test \"X\`printf %s \$ECHO\`\" = \"X\$ECHO\" \\ || test \"X\`print -r -- \$ECHO\`\" = \"X\$ECHO\" ) || exit 1 test \$(( 1 + 1 )) = 2 || exit 1" if (eval "$as_required") 2>/dev/null; then : as_have_required=yes else as_have_required=no fi if test x$as_have_required = xyes && (eval "$as_suggested") 2>/dev/null; then : else as_save_IFS=$IFS; IFS=$PATH_SEPARATOR as_found=false for as_dir in /bin$PATH_SEPARATOR/usr/bin$PATH_SEPARATOR$PATH do IFS=$as_save_IFS test -z "$as_dir" && as_dir=. as_found=: case $as_dir in #( /*) for as_base in sh bash ksh sh5; do # Try only shells that exist, to save several forks. as_shell=$as_dir/$as_base if { test -f "$as_shell" || test -f "$as_shell.exe"; } && { $as_echo "$as_bourne_compatible""$as_required" | as_run=a "$as_shell"; } 2>/dev/null; then : CONFIG_SHELL=$as_shell as_have_required=yes if { $as_echo "$as_bourne_compatible""$as_suggested" | as_run=a "$as_shell"; } 2>/dev/null; then : break 2 fi fi done;; esac as_found=false done $as_found || { if { test -f "$SHELL" || test -f "$SHELL.exe"; } && { $as_echo "$as_bourne_compatible""$as_required" | as_run=a "$SHELL"; } 2>/dev/null; then : CONFIG_SHELL=$SHELL as_have_required=yes fi; } IFS=$as_save_IFS if test "x$CONFIG_SHELL" != x; then : export CONFIG_SHELL # We cannot yet assume a decent shell, so we have to provide a # neutralization value for shells without unset; and this also # works around shells that cannot unset nonexistent variables. # Preserve -v and -x to the replacement shell. BASH_ENV=/dev/null ENV=/dev/null (unset BASH_ENV) >/dev/null 2>&1 && unset BASH_ENV ENV case $- in # (((( *v*x* | *x*v* ) as_opts=-vx ;; *v* ) as_opts=-v ;; *x* ) as_opts=-x ;; * ) as_opts= ;; esac exec $CONFIG_SHELL $as_opts "$as_myself" ${1+"$@"} # Admittedly, this is quite paranoid, since all the known shells bail # out after a failed `exec'. $as_echo "$0: could not re-execute with $CONFIG_SHELL" >&2 exit 255 fi if test x$as_have_required = xno; then : $as_echo "$0: This script requires a shell more modern than all" $as_echo "$0: the shells that I found on your system." if test x${ZSH_VERSION+set} = xset ; then $as_echo "$0: In particular, zsh $ZSH_VERSION has bugs and should" $as_echo "$0: be upgraded to zsh 4.3.4 or later." else $as_echo "$0: Please tell bug-autoconf@gnu.org and $0: xrdp-devel@googlegroups.com about your system, $0: including any error possibly output before this $0: message. Then install a modern shell, or manually run $0: the script under such a shell if you do have one." fi exit 1 fi fi fi SHELL=${CONFIG_SHELL-/bin/sh} export SHELL # Unset more variables known to interfere with behavior of common tools. CLICOLOR_FORCE= GREP_OPTIONS= unset CLICOLOR_FORCE GREP_OPTIONS ## --------------------- ## ## M4sh Shell Functions. ## ## --------------------- ## # as_fn_unset VAR # --------------- # Portably unset VAR. as_fn_unset () { { eval $1=; unset $1;} } as_unset=as_fn_unset # as_fn_set_status STATUS # ----------------------- # Set $? to STATUS, without forking. as_fn_set_status () { return $1 } # as_fn_set_status # as_fn_exit STATUS # ----------------- # Exit the shell with STATUS, even in a "trap 0" or "set -e" context. as_fn_exit () { set +e as_fn_set_status $1 exit $1 } # as_fn_exit # as_fn_mkdir_p # ------------- # Create "$as_dir" as a directory, including parents if necessary. as_fn_mkdir_p () { case $as_dir in #( -*) as_dir=./$as_dir;; esac test -d "$as_dir" || eval $as_mkdir_p || { as_dirs= while :; do case $as_dir in #( *\'*) as_qdir=`$as_echo "$as_dir" | sed "s/'/'\\\\\\\\''/g"`;; #'( *) as_qdir=$as_dir;; esac as_dirs="'$as_qdir' $as_dirs" as_dir=`$as_dirname -- "$as_dir" || $as_expr X"$as_dir" : 'X\(.*[^/]\)//*[^/][^/]*/*$' \| \ X"$as_dir" : 'X\(//\)[^/]' \| \ X"$as_dir" : 'X\(//\)$' \| \ X"$as_dir" : 'X\(/\)' \| . 2>/dev/null || $as_echo X"$as_dir" | sed '/^X\(.*[^/]\)\/\/*[^/][^/]*\/*$/{ s//\1/ q } /^X\(\/\/\)[^/].*/{ s//\1/ q } /^X\(\/\/\)$/{ s//\1/ q } /^X\(\/\).*/{ s//\1/ q } s/.*/./; q'` test -d "$as_dir" && break done test -z "$as_dirs" || eval "mkdir $as_dirs" } || test -d "$as_dir" || as_fn_error $? "cannot create directory $as_dir" } # as_fn_mkdir_p # as_fn_executable_p FILE # ----------------------- # Test if FILE is an executable regular file. as_fn_executable_p () { test -f "$1" && test -x "$1" } # as_fn_executable_p # as_fn_append VAR VALUE # ---------------------- # Append the text in VALUE to the end of the definition contained in VAR. Take # advantage of any shell optimizations that allow amortized linear growth over # repeated appends, instead of the typical quadratic growth present in naive # implementations. if (eval "as_var=1; as_var+=2; test x\$as_var = x12") 2>/dev/null; then : eval 'as_fn_append () { eval $1+=\$2 }' else as_fn_append () { eval $1=\$$1\$2 } fi # as_fn_append # as_fn_arith ARG... # ------------------ # Perform arithmetic evaluation on the ARGs, and store the result in the # global $as_val. Take advantage of shells that can avoid forks. The arguments # must be portable across $(()) and expr. if (eval "test \$(( 1 + 1 )) = 2") 2>/dev/null; then : eval 'as_fn_arith () { as_val=$(( $* )) }' else as_fn_arith () { as_val=`expr "$@" || test $? -eq 1` } fi # as_fn_arith # as_fn_error STATUS ERROR [LINENO LOG_FD] # ---------------------------------------- # Output "`basename $0`: error: ERROR" to stderr. If LINENO and LOG_FD are # provided, also output the error to LOG_FD, referencing LINENO. Then exit the # script with STATUS, using 1 if that was 0. as_fn_error () { as_status=$1; test $as_status -eq 0 && as_status=1 if test "$4"; then as_lineno=${as_lineno-"$3"} as_lineno_stack=as_lineno_stack=$as_lineno_stack $as_echo "$as_me:${as_lineno-$LINENO}: error: $2" >&$4 fi $as_echo "$as_me: error: $2" >&2 as_fn_exit $as_status } # as_fn_error if expr a : '\(a\)' >/dev/null 2>&1 && test "X`expr 00001 : '.*\(...\)'`" = X001; then as_expr=expr else as_expr=false fi if (basename -- /) >/dev/null 2>&1 && test "X`basename -- / 2>&1`" = "X/"; then as_basename=basename else as_basename=false fi if (as_dir=`dirname -- /` && test "X$as_dir" = X/) >/dev/null 2>&1; then as_dirname=dirname else as_dirname=false fi as_me=`$as_basename -- "$0" || $as_expr X/"$0" : '.*/\([^/][^/]*\)/*$' \| \ X"$0" : 'X\(//\)$' \| \ X"$0" : 'X\(/\)' \| . 2>/dev/null || $as_echo X/"$0" | sed '/^.*\/\([^/][^/]*\)\/*$/{ s//\1/ q } /^X\/\(\/\/\)$/{ s//\1/ q } /^X\/\(\/\).*/{ s//\1/ q } s/.*/./; q'` # Avoid depending upon Character Ranges. as_cr_letters='abcdefghijklmnopqrstuvwxyz' as_cr_LETTERS='ABCDEFGHIJKLMNOPQRSTUVWXYZ' as_cr_Letters=$as_cr_letters$as_cr_LETTERS as_cr_digits='0123456789' as_cr_alnum=$as_cr_Letters$as_cr_digits as_lineno_1=$LINENO as_lineno_1a=$LINENO as_lineno_2=$LINENO as_lineno_2a=$LINENO eval 'test "x$as_lineno_1'$as_run'" != "x$as_lineno_2'$as_run'" && test "x`expr $as_lineno_1'$as_run' + 1`" = "x$as_lineno_2'$as_run'"' || { # Blame Lee E. McMahon (1931-1989) for sed's syntax. :-) sed -n ' p /[$]LINENO/= ' <$as_myself | sed ' s/[$]LINENO.*/&-/ t lineno b :lineno N :loop s/[$]LINENO\([^'$as_cr_alnum'_].*\n\)\(.*\)/\2\1\2/ t loop s/-\n.*// ' >$as_me.lineno && chmod +x "$as_me.lineno" || { $as_echo "$as_me: error: cannot create $as_me.lineno; rerun with a POSIX shell" >&2; as_fn_exit 1; } # If we had to re-execute with $CONFIG_SHELL, we're ensured to have # already done that, so ensure we don't try to do so again and fall # in an infinite loop. This has already happened in practice. _as_can_reexec=no; export _as_can_reexec # Don't try to exec as it changes $[0], causing all sort of problems # (the dirname of $[0] is not the place where we might find the # original and so on. Autoconf is especially sensitive to this). . "./$as_me.lineno" # Exit status is that of the last command. exit } ECHO_C= ECHO_N= ECHO_T= case `echo -n x` in #((((( -n*) case `echo 'xy\c'` in *c*) ECHO_T=' ';; # ECHO_T is single tab character. xy) ECHO_C='\c';; *) echo `echo ksh88 bug on AIX 6.1` > /dev/null ECHO_T=' ';; esac;; *) ECHO_N='-n';; esac rm -f conf$$ conf$$.exe conf$$.file if test -d conf$$.dir; then rm -f conf$$.dir/conf$$.file else rm -f conf$$.dir mkdir conf$$.dir 2>/dev/null fi if (echo >conf$$.file) 2>/dev/null; then if ln -s conf$$.file conf$$ 2>/dev/null; then as_ln_s='ln -s' # ... but there are two gotchas: # 1) On MSYS, both `ln -s file dir' and `ln file dir' fail. # 2) DJGPP < 2.04 has no symlinks; `ln -s' creates a wrapper executable. # In both cases, we have to default to `cp -pR'. ln -s conf$$.file conf$$.dir 2>/dev/null && test ! -f conf$$.exe || as_ln_s='cp -pR' elif ln conf$$.file conf$$ 2>/dev/null; then as_ln_s=ln else as_ln_s='cp -pR' fi else as_ln_s='cp -pR' fi rm -f conf$$ conf$$.exe conf$$.dir/conf$$.file conf$$.file rmdir conf$$.dir 2>/dev/null if mkdir -p . 2>/dev/null; then as_mkdir_p='mkdir -p "$as_dir"' else test -d ./-p && rmdir ./-p as_mkdir_p=false fi as_test_x='test -x' as_executable_p=as_fn_executable_p # Sed expression to map a string onto a valid CPP name. as_tr_cpp="eval sed 'y%*$as_cr_letters%P$as_cr_LETTERS%;s%[^_$as_cr_alnum]%_%g'" # Sed expression to map a string onto a valid variable name. as_tr_sh="eval sed 'y%*+%pp%;s%[^_$as_cr_alnum]%_%g'" SHELL=${CONFIG_SHELL-/bin/sh} test -n "$DJDIR" || exec 7<&0 &1 # Name of the host. # hostname on some systems (SVR3.2, old GNU/Linux) returns a bogus exit status, # so uname gets run too. ac_hostname=`(hostname || uname -n) 2>/dev/null | sed 1q` # # Initializations. # ac_default_prefix=/usr/local ac_clean_files= ac_config_libobj_dir=. LIBOBJS= cross_compiling=no subdirs= MFLAGS= MAKEFLAGS= # Identity of this package. PACKAGE_NAME='libpainter' PACKAGE_TARNAME='libpainter' PACKAGE_VERSION='0.1.1' PACKAGE_STRING='libpainter 0.1.1' PACKAGE_BUGREPORT='xrdp-devel@googlegroups.com' PACKAGE_URL='' # Factoring default headers for most tests. ac_includes_default="\ #include #ifdef HAVE_SYS_TYPES_H # include #endif #ifdef HAVE_SYS_STAT_H # include #endif #ifdef STDC_HEADERS # include # include #else # ifdef HAVE_STDLIB_H # include # endif #endif #ifdef HAVE_STRING_H # if !defined STDC_HEADERS && defined HAVE_MEMORY_H # include # endif # include #endif #ifdef HAVE_STRINGS_H # include #endif #ifdef HAVE_INTTYPES_H # include #endif #ifdef HAVE_STDINT_H # include #endif #ifdef HAVE_UNISTD_H # include #endif" ac_subst_vars='am__EXEEXT_FALSE am__EXEEXT_TRUE LTLIBOBJS LIBOBJS PT_TESTS_FALSE PT_TESTS_TRUE pkgconfigdir CPP LT_SYS_LIBRARY_PATH OTOOL64 OTOOL LIPO NMEDIT DSYMUTIL MANIFEST_TOOL RANLIB ac_ct_AR AR DLLTOOL OBJDUMP LN_S NM ac_ct_DUMPBIN DUMPBIN LD FGREP EGREP GREP SED host_os host_vendor host_cpu host build_os build_vendor build_cpu build LIBTOOL am__fastdepCC_FALSE am__fastdepCC_TRUE CCDEPMODE am__nodep AMDEPBACKSLASH AMDEP_FALSE AMDEP_TRUE am__quote am__include DEPDIR OBJEXT EXEEXT ac_ct_CC CPPFLAGS LDFLAGS CFLAGS CC AM_BACKSLASH AM_DEFAULT_VERBOSITY AM_DEFAULT_V AM_V am__untar am__tar AMTAR am__leading_dot SET_MAKE AWK mkdir_p MKDIR_P INSTALL_STRIP_PROGRAM STRIP install_sh MAKEINFO AUTOHEADER AUTOMAKE AUTOCONF ACLOCAL VERSION PACKAGE CYGPATH_W am__isrc INSTALL_DATA INSTALL_SCRIPT INSTALL_PROGRAM target_alias host_alias build_alias LIBS ECHO_T ECHO_N ECHO_C DEFS mandir localedir libdir psdir pdfdir dvidir htmldir infodir docdir oldincludedir includedir localstatedir sharedstatedir sysconfdir datadir datarootdir libexecdir sbindir bindir program_transform_name prefix exec_prefix PACKAGE_URL PACKAGE_BUGREPORT PACKAGE_STRING PACKAGE_VERSION PACKAGE_TARNAME PACKAGE_NAME PATH_SEPARATOR SHELL' ac_subst_files='' ac_user_opts=' enable_option_checking enable_silent_rules enable_dependency_tracking enable_shared enable_static with_pic enable_fast_install with_aix_soname with_gnu_ld with_sysroot enable_libtool_lock with_pkgconfigdir enable_tests ' ac_precious_vars='build_alias host_alias target_alias CC CFLAGS LDFLAGS LIBS CPPFLAGS LT_SYS_LIBRARY_PATH CPP' # Initialize some variables set by options. ac_init_help= ac_init_version=false ac_unrecognized_opts= ac_unrecognized_sep= # The variables have the same names as the options, with # dashes changed to underlines. cache_file=/dev/null exec_prefix=NONE no_create= no_recursion= prefix=NONE program_prefix=NONE program_suffix=NONE program_transform_name=s,x,x, silent= site= srcdir= verbose= x_includes=NONE x_libraries=NONE # Installation directory options. # These are left unexpanded so users can "make install exec_prefix=/foo" # and all the variables that are supposed to be based on exec_prefix # by default will actually change. # Use braces instead of parens because sh, perl, etc. also accept them. # (The list follows the same order as the GNU Coding Standards.) bindir='${exec_prefix}/bin' sbindir='${exec_prefix}/sbin' libexecdir='${exec_prefix}/libexec' datarootdir='${prefix}/share' datadir='${datarootdir}' sysconfdir='${prefix}/etc' sharedstatedir='${prefix}/com' localstatedir='${prefix}/var' includedir='${prefix}/include' oldincludedir='/usr/include' docdir='${datarootdir}/doc/${PACKAGE_TARNAME}' infodir='${datarootdir}/info' htmldir='${docdir}' dvidir='${docdir}' pdfdir='${docdir}' psdir='${docdir}' libdir='${exec_prefix}/lib' localedir='${datarootdir}/locale' mandir='${datarootdir}/man' ac_prev= ac_dashdash= for ac_option do # If the previous option needs an argument, assign it. if test -n "$ac_prev"; then eval $ac_prev=\$ac_option ac_prev= continue fi case $ac_option in *=?*) ac_optarg=`expr "X$ac_option" : '[^=]*=\(.*\)'` ;; *=) ac_optarg= ;; *) ac_optarg=yes ;; esac # Accept the important Cygnus configure options, so we can diagnose typos. case $ac_dashdash$ac_option in --) ac_dashdash=yes ;; -bindir | --bindir | --bindi | --bind | --bin | --bi) ac_prev=bindir ;; -bindir=* | --bindir=* | --bindi=* | --bind=* | --bin=* | --bi=*) bindir=$ac_optarg ;; -build | --build | --buil | --bui | --bu) ac_prev=build_alias ;; -build=* | --build=* | --buil=* | --bui=* | --bu=*) build_alias=$ac_optarg ;; -cache-file | --cache-file | --cache-fil | --cache-fi \ | --cache-f | --cache- | --cache | --cach | --cac | --ca | --c) ac_prev=cache_file ;; -cache-file=* | --cache-file=* | --cache-fil=* | --cache-fi=* \ | --cache-f=* | --cache-=* | --cache=* | --cach=* | --cac=* | --ca=* | --c=*) cache_file=$ac_optarg ;; --config-cache | -C) cache_file=config.cache ;; -datadir | --datadir | --datadi | --datad) ac_prev=datadir ;; -datadir=* | --datadir=* | --datadi=* | --datad=*) datadir=$ac_optarg ;; -datarootdir | --datarootdir | --datarootdi | --datarootd | --dataroot \ | --dataroo | --dataro | --datar) ac_prev=datarootdir ;; -datarootdir=* | --datarootdir=* | --datarootdi=* | --datarootd=* \ | --dataroot=* | --dataroo=* | --dataro=* | --datar=*) datarootdir=$ac_optarg ;; -disable-* | --disable-*) ac_useropt=`expr "x$ac_option" : 'x-*disable-\(.*\)'` # Reject names that are not valid shell variable names. expr "x$ac_useropt" : ".*[^-+._$as_cr_alnum]" >/dev/null && as_fn_error $? "invalid feature name: $ac_useropt" ac_useropt_orig=$ac_useropt ac_useropt=`$as_echo "$ac_useropt" | sed 's/[-+.]/_/g'` case $ac_user_opts in *" "enable_$ac_useropt" "*) ;; *) ac_unrecognized_opts="$ac_unrecognized_opts$ac_unrecognized_sep--disable-$ac_useropt_orig" ac_unrecognized_sep=', ';; esac eval enable_$ac_useropt=no ;; -docdir | --docdir | --docdi | --doc | --do) ac_prev=docdir ;; -docdir=* | --docdir=* | --docdi=* | --doc=* | --do=*) docdir=$ac_optarg ;; -dvidir | --dvidir | --dvidi | --dvid | --dvi | --dv) ac_prev=dvidir ;; -dvidir=* | --dvidir=* | --dvidi=* | --dvid=* | --dvi=* | --dv=*) dvidir=$ac_optarg ;; -enable-* | --enable-*) ac_useropt=`expr "x$ac_option" : 'x-*enable-\([^=]*\)'` # Reject names that are not valid shell variable names. expr "x$ac_useropt" : ".*[^-+._$as_cr_alnum]" >/dev/null && as_fn_error $? "invalid feature name: $ac_useropt" ac_useropt_orig=$ac_useropt ac_useropt=`$as_echo "$ac_useropt" | sed 's/[-+.]/_/g'` case $ac_user_opts in *" "enable_$ac_useropt" "*) ;; *) ac_unrecognized_opts="$ac_unrecognized_opts$ac_unrecognized_sep--enable-$ac_useropt_orig" ac_unrecognized_sep=', ';; esac eval enable_$ac_useropt=\$ac_optarg ;; -exec-prefix | --exec_prefix | --exec-prefix | --exec-prefi \ | --exec-pref | --exec-pre | --exec-pr | --exec-p | --exec- \ | --exec | --exe | --ex) ac_prev=exec_prefix ;; -exec-prefix=* | --exec_prefix=* | --exec-prefix=* | --exec-prefi=* \ | --exec-pref=* | --exec-pre=* | --exec-pr=* | --exec-p=* | --exec-=* \ | --exec=* | --exe=* | --ex=*) exec_prefix=$ac_optarg ;; -gas | --gas | --ga | --g) # Obsolete; use --with-gas. with_gas=yes ;; -help | --help | --hel | --he | -h) ac_init_help=long ;; -help=r* | --help=r* | --hel=r* | --he=r* | -hr*) ac_init_help=recursive ;; -help=s* | --help=s* | --hel=s* | --he=s* | -hs*) ac_init_help=short ;; -host | --host | --hos | --ho) ac_prev=host_alias ;; -host=* | --host=* | --hos=* | --ho=*) host_alias=$ac_optarg ;; -htmldir | --htmldir | --htmldi | --htmld | --html | --htm | --ht) ac_prev=htmldir ;; -htmldir=* | --htmldir=* | --htmldi=* | --htmld=* | --html=* | --htm=* \ | --ht=*) htmldir=$ac_optarg ;; -includedir | --includedir | --includedi | --included | --include \ | --includ | --inclu | --incl | --inc) ac_prev=includedir ;; -includedir=* | --includedir=* | --includedi=* | --included=* | --include=* \ | --includ=* | --inclu=* | --incl=* | --inc=*) includedir=$ac_optarg ;; -infodir | --infodir | --infodi | --infod | --info | --inf) ac_prev=infodir ;; -infodir=* | --infodir=* | --infodi=* | --infod=* | --info=* | --inf=*) infodir=$ac_optarg ;; -libdir | --libdir | --libdi | --libd) ac_prev=libdir ;; -libdir=* | --libdir=* | --libdi=* | --libd=*) libdir=$ac_optarg ;; -libexecdir | --libexecdir | --libexecdi | --libexecd | --libexec \ | --libexe | --libex | --libe) ac_prev=libexecdir ;; -libexecdir=* | --libexecdir=* | --libexecdi=* | --libexecd=* | --libexec=* \ | --libexe=* | --libex=* | --libe=*) libexecdir=$ac_optarg ;; -localedir | --localedir | --localedi | --localed | --locale) ac_prev=localedir ;; -localedir=* | --localedir=* | --localedi=* | --localed=* | --locale=*) localedir=$ac_optarg ;; -localstatedir | --localstatedir | --localstatedi | --localstated \ | --localstate | --localstat | --localsta | --localst | --locals) ac_prev=localstatedir ;; -localstatedir=* | --localstatedir=* | --localstatedi=* | --localstated=* \ | --localstate=* | --localstat=* | --localsta=* | --localst=* | --locals=*) localstatedir=$ac_optarg ;; -mandir | --mandir | --mandi | --mand | --man | --ma | --m) ac_prev=mandir ;; -mandir=* | --mandir=* | --mandi=* | --mand=* | --man=* | --ma=* | --m=*) mandir=$ac_optarg ;; -nfp | --nfp | --nf) # Obsolete; use --without-fp. with_fp=no ;; -no-create | --no-create | --no-creat | --no-crea | --no-cre \ | --no-cr | --no-c | -n) no_create=yes ;; -no-recursion | --no-recursion | --no-recursio | --no-recursi \ | --no-recurs | --no-recur | --no-recu | --no-rec | --no-re | --no-r) no_recursion=yes ;; -oldincludedir | --oldincludedir | --oldincludedi | --oldincluded \ | --oldinclude | --oldinclud | --oldinclu | --oldincl | --oldinc \ | --oldin | --oldi | --old | --ol | --o) ac_prev=oldincludedir ;; -oldincludedir=* | --oldincludedir=* | --oldincludedi=* | --oldincluded=* \ | --oldinclude=* | --oldinclud=* | --oldinclu=* | --oldincl=* | --oldinc=* \ | --oldin=* | --oldi=* | --old=* | --ol=* | --o=*) oldincludedir=$ac_optarg ;; -prefix | --prefix | --prefi | --pref | --pre | --pr | --p) ac_prev=prefix ;; -prefix=* | --prefix=* | --prefi=* | --pref=* | --pre=* | --pr=* | --p=*) prefix=$ac_optarg ;; -program-prefix | --program-prefix | --program-prefi | --program-pref \ | --program-pre | --program-pr | --program-p) ac_prev=program_prefix ;; -program-prefix=* | --program-prefix=* | --program-prefi=* \ | --program-pref=* | --program-pre=* | --program-pr=* | --program-p=*) program_prefix=$ac_optarg ;; -program-suffix | --program-suffix | --program-suffi | --program-suff \ | --program-suf | --program-su | --program-s) ac_prev=program_suffix ;; -program-suffix=* | --program-suffix=* | --program-suffi=* \ | --program-suff=* | --program-suf=* | --program-su=* | --program-s=*) program_suffix=$ac_optarg ;; -program-transform-name | --program-transform-name \ | --program-transform-nam | --program-transform-na \ | --program-transform-n | --program-transform- \ | --program-transform | --program-transfor \ | --program-transfo | --program-transf \ | --program-trans | --program-tran \ | --progr-tra | --program-tr | --program-t) ac_prev=program_transform_name ;; -program-transform-name=* | --program-transform-name=* \ | --program-transform-nam=* | --program-transform-na=* \ | --program-transform-n=* | --program-transform-=* \ | --program-transform=* | --program-transfor=* \ | --program-transfo=* | --program-transf=* \ | --program-trans=* | --program-tran=* \ | --progr-tra=* | --program-tr=* | --program-t=*) program_transform_name=$ac_optarg ;; -pdfdir | --pdfdir | --pdfdi | --pdfd | --pdf | --pd) ac_prev=pdfdir ;; -pdfdir=* | --pdfdir=* | --pdfdi=* | --pdfd=* | --pdf=* | --pd=*) pdfdir=$ac_optarg ;; -psdir | --psdir | --psdi | --psd | --ps) ac_prev=psdir ;; -psdir=* | --psdir=* | --psdi=* | --psd=* | --ps=*) psdir=$ac_optarg ;; -q | -quiet | --quiet | --quie | --qui | --qu | --q \ | -silent | --silent | --silen | --sile | --sil) silent=yes ;; -sbindir | --sbindir | --sbindi | --sbind | --sbin | --sbi | --sb) ac_prev=sbindir ;; -sbindir=* | --sbindir=* | --sbindi=* | --sbind=* | --sbin=* \ | --sbi=* | --sb=*) sbindir=$ac_optarg ;; -sharedstatedir | --sharedstatedir | --sharedstatedi \ | --sharedstated | --sharedstate | --sharedstat | --sharedsta \ | --sharedst | --shareds | --shared | --share | --shar \ | --sha | --sh) ac_prev=sharedstatedir ;; -sharedstatedir=* | --sharedstatedir=* | --sharedstatedi=* \ | --sharedstated=* | --sharedstate=* | --sharedstat=* | --sharedsta=* \ | --sharedst=* | --shareds=* | --shared=* | --share=* | --shar=* \ | --sha=* | --sh=*) sharedstatedir=$ac_optarg ;; -site | --site | --sit) ac_prev=site ;; -site=* | --site=* | --sit=*) site=$ac_optarg ;; -srcdir | --srcdir | --srcdi | --srcd | --src | --sr) ac_prev=srcdir ;; -srcdir=* | --srcdir=* | --srcdi=* | --srcd=* | --src=* | --sr=*) srcdir=$ac_optarg ;; -sysconfdir | --sysconfdir | --sysconfdi | --sysconfd | --sysconf \ | --syscon | --sysco | --sysc | --sys | --sy) ac_prev=sysconfdir ;; -sysconfdir=* | --sysconfdir=* | --sysconfdi=* | --sysconfd=* | --sysconf=* \ | --syscon=* | --sysco=* | --sysc=* | --sys=* | --sy=*) sysconfdir=$ac_optarg ;; -target | --target | --targe | --targ | --tar | --ta | --t) ac_prev=target_alias ;; -target=* | --target=* | --targe=* | --targ=* | --tar=* | --ta=* | --t=*) target_alias=$ac_optarg ;; -v | -verbose | --verbose | --verbos | --verbo | --verb) verbose=yes ;; -version | --version | --versio | --versi | --vers | -V) ac_init_version=: ;; -with-* | --with-*) ac_useropt=`expr "x$ac_option" : 'x-*with-\([^=]*\)'` # Reject names that are not valid shell variable names. expr "x$ac_useropt" : ".*[^-+._$as_cr_alnum]" >/dev/null && as_fn_error $? "invalid package name: $ac_useropt" ac_useropt_orig=$ac_useropt ac_useropt=`$as_echo "$ac_useropt" | sed 's/[-+.]/_/g'` case $ac_user_opts in *" "with_$ac_useropt" "*) ;; *) ac_unrecognized_opts="$ac_unrecognized_opts$ac_unrecognized_sep--with-$ac_useropt_orig" ac_unrecognized_sep=', ';; esac eval with_$ac_useropt=\$ac_optarg ;; -without-* | --without-*) ac_useropt=`expr "x$ac_option" : 'x-*without-\(.*\)'` # Reject names that are not valid shell variable names. expr "x$ac_useropt" : ".*[^-+._$as_cr_alnum]" >/dev/null && as_fn_error $? "invalid package name: $ac_useropt" ac_useropt_orig=$ac_useropt ac_useropt=`$as_echo "$ac_useropt" | sed 's/[-+.]/_/g'` case $ac_user_opts in *" "with_$ac_useropt" "*) ;; *) ac_unrecognized_opts="$ac_unrecognized_opts$ac_unrecognized_sep--without-$ac_useropt_orig" ac_unrecognized_sep=', ';; esac eval with_$ac_useropt=no ;; --x) # Obsolete; use --with-x. with_x=yes ;; -x-includes | --x-includes | --x-include | --x-includ | --x-inclu \ | --x-incl | --x-inc | --x-in | --x-i) ac_prev=x_includes ;; -x-includes=* | --x-includes=* | --x-include=* | --x-includ=* | --x-inclu=* \ | --x-incl=* | --x-inc=* | --x-in=* | --x-i=*) x_includes=$ac_optarg ;; -x-libraries | --x-libraries | --x-librarie | --x-librari \ | --x-librar | --x-libra | --x-libr | --x-lib | --x-li | --x-l) ac_prev=x_libraries ;; -x-libraries=* | --x-libraries=* | --x-librarie=* | --x-librari=* \ | --x-librar=* | --x-libra=* | --x-libr=* | --x-lib=* | --x-li=* | --x-l=*) x_libraries=$ac_optarg ;; -*) as_fn_error $? "unrecognized option: \`$ac_option' Try \`$0 --help' for more information" ;; *=*) ac_envvar=`expr "x$ac_option" : 'x\([^=]*\)='` # Reject names that are not valid shell variable names. case $ac_envvar in #( '' | [0-9]* | *[!_$as_cr_alnum]* ) as_fn_error $? "invalid variable name: \`$ac_envvar'" ;; esac eval $ac_envvar=\$ac_optarg export $ac_envvar ;; *) # FIXME: should be removed in autoconf 3.0. $as_echo "$as_me: WARNING: you should use --build, --host, --target" >&2 expr "x$ac_option" : ".*[^-._$as_cr_alnum]" >/dev/null && $as_echo "$as_me: WARNING: invalid host type: $ac_option" >&2 : "${build_alias=$ac_option} ${host_alias=$ac_option} ${target_alias=$ac_option}" ;; esac done if test -n "$ac_prev"; then ac_option=--`echo $ac_prev | sed 's/_/-/g'` as_fn_error $? "missing argument to $ac_option" fi if test -n "$ac_unrecognized_opts"; then case $enable_option_checking in no) ;; fatal) as_fn_error $? "unrecognized options: $ac_unrecognized_opts" ;; *) $as_echo "$as_me: WARNING: unrecognized options: $ac_unrecognized_opts" >&2 ;; esac fi # Check all directory arguments for consistency. for ac_var in exec_prefix prefix bindir sbindir libexecdir datarootdir \ datadir sysconfdir sharedstatedir localstatedir includedir \ oldincludedir docdir infodir htmldir dvidir pdfdir psdir \ libdir localedir mandir do eval ac_val=\$$ac_var # Remove trailing slashes. case $ac_val in */ ) ac_val=`expr "X$ac_val" : 'X\(.*[^/]\)' \| "X$ac_val" : 'X\(.*\)'` eval $ac_var=\$ac_val;; esac # Be sure to have absolute directory names. case $ac_val in [\\/$]* | ?:[\\/]* ) continue;; NONE | '' ) case $ac_var in *prefix ) continue;; esac;; esac as_fn_error $? "expected an absolute directory name for --$ac_var: $ac_val" done # There might be people who depend on the old broken behavior: `$host' # used to hold the argument of --host etc. # FIXME: To remove some day. build=$build_alias host=$host_alias target=$target_alias # FIXME: To remove some day. if test "x$host_alias" != x; then if test "x$build_alias" = x; then cross_compiling=maybe elif test "x$build_alias" != "x$host_alias"; then cross_compiling=yes fi fi ac_tool_prefix= test -n "$host_alias" && ac_tool_prefix=$host_alias- test "$silent" = yes && exec 6>/dev/null ac_pwd=`pwd` && test -n "$ac_pwd" && ac_ls_di=`ls -di .` && ac_pwd_ls_di=`cd "$ac_pwd" && ls -di .` || as_fn_error $? "working directory cannot be determined" test "X$ac_ls_di" = "X$ac_pwd_ls_di" || as_fn_error $? "pwd does not report name of working directory" # Find the source files, if location was not specified. if test -z "$srcdir"; then ac_srcdir_defaulted=yes # Try the directory containing this script, then the parent directory. ac_confdir=`$as_dirname -- "$as_myself" || $as_expr X"$as_myself" : 'X\(.*[^/]\)//*[^/][^/]*/*$' \| \ X"$as_myself" : 'X\(//\)[^/]' \| \ X"$as_myself" : 'X\(//\)$' \| \ X"$as_myself" : 'X\(/\)' \| . 2>/dev/null || $as_echo X"$as_myself" | sed '/^X\(.*[^/]\)\/\/*[^/][^/]*\/*$/{ s//\1/ q } /^X\(\/\/\)[^/].*/{ s//\1/ q } /^X\(\/\/\)$/{ s//\1/ q } /^X\(\/\).*/{ s//\1/ q } s/.*/./; q'` srcdir=$ac_confdir if test ! -r "$srcdir/$ac_unique_file"; then srcdir=.. fi else ac_srcdir_defaulted=no fi if test ! -r "$srcdir/$ac_unique_file"; then test "$ac_srcdir_defaulted" = yes && srcdir="$ac_confdir or .." as_fn_error $? "cannot find sources ($ac_unique_file) in $srcdir" fi ac_msg="sources are in $srcdir, but \`cd $srcdir' does not work" ac_abs_confdir=`( cd "$srcdir" && test -r "./$ac_unique_file" || as_fn_error $? "$ac_msg" pwd)` # When building in place, set srcdir=. if test "$ac_abs_confdir" = "$ac_pwd"; then srcdir=. fi # Remove unnecessary trailing slashes from srcdir. # Double slashes in file names in object file debugging info # mess up M-x gdb in Emacs. case $srcdir in */) srcdir=`expr "X$srcdir" : 'X\(.*[^/]\)' \| "X$srcdir" : 'X\(.*\)'`;; esac for ac_var in $ac_precious_vars; do eval ac_env_${ac_var}_set=\${${ac_var}+set} eval ac_env_${ac_var}_value=\$${ac_var} eval ac_cv_env_${ac_var}_set=\${${ac_var}+set} eval ac_cv_env_${ac_var}_value=\$${ac_var} done # # Report the --help message. # if test "$ac_init_help" = "long"; then # Omit some internal or obsolete options to make the list less imposing. # This message is too long to be a string in the A/UX 3.1 sh. cat <<_ACEOF \`configure' configures libpainter 0.1.1 to adapt to many kinds of systems. Usage: $0 [OPTION]... [VAR=VALUE]... To assign environment variables (e.g., CC, CFLAGS...), specify them as VAR=VALUE. See below for descriptions of some of the useful variables. Defaults for the options are specified in brackets. Configuration: -h, --help display this help and exit --help=short display options specific to this package --help=recursive display the short help of all the included packages -V, --version display version information and exit -q, --quiet, --silent do not print \`checking ...' messages --cache-file=FILE cache test results in FILE [disabled] -C, --config-cache alias for \`--cache-file=config.cache' -n, --no-create do not create output files --srcdir=DIR find the sources in DIR [configure dir or \`..'] Installation directories: --prefix=PREFIX install architecture-independent files in PREFIX [$ac_default_prefix] --exec-prefix=EPREFIX install architecture-dependent files in EPREFIX [PREFIX] By default, \`make install' will install all the files in \`$ac_default_prefix/bin', \`$ac_default_prefix/lib' etc. You can specify an installation prefix other than \`$ac_default_prefix' using \`--prefix', for instance \`--prefix=\$HOME'. For better control, use the options below. Fine tuning of the installation directories: --bindir=DIR user executables [EPREFIX/bin] --sbindir=DIR system admin executables [EPREFIX/sbin] --libexecdir=DIR program executables [EPREFIX/libexec] --sysconfdir=DIR read-only single-machine data [PREFIX/etc] --sharedstatedir=DIR modifiable architecture-independent data [PREFIX/com] --localstatedir=DIR modifiable single-machine data [PREFIX/var] --libdir=DIR object code libraries [EPREFIX/lib] --includedir=DIR C header files [PREFIX/include] --oldincludedir=DIR C header files for non-gcc [/usr/include] --datarootdir=DIR read-only arch.-independent data root [PREFIX/share] --datadir=DIR read-only architecture-independent data [DATAROOTDIR] --infodir=DIR info documentation [DATAROOTDIR/info] --localedir=DIR locale-dependent data [DATAROOTDIR/locale] --mandir=DIR man documentation [DATAROOTDIR/man] --docdir=DIR documentation root [DATAROOTDIR/doc/libpainter] --htmldir=DIR html documentation [DOCDIR] --dvidir=DIR dvi documentation [DOCDIR] --pdfdir=DIR pdf documentation [DOCDIR] --psdir=DIR ps documentation [DOCDIR] _ACEOF cat <<\_ACEOF Program names: --program-prefix=PREFIX prepend PREFIX to installed program names --program-suffix=SUFFIX append SUFFIX to installed program names --program-transform-name=PROGRAM run sed PROGRAM on installed program names System types: --build=BUILD configure for building on BUILD [guessed] --host=HOST cross-compile to build programs to run on HOST [BUILD] _ACEOF fi if test -n "$ac_init_help"; then case $ac_init_help in short | recursive ) echo "Configuration of libpainter 0.1.1:";; esac cat <<\_ACEOF Optional Features: --disable-option-checking ignore unrecognized --enable/--with options --disable-FEATURE do not include FEATURE (same as --enable-FEATURE=no) --enable-FEATURE[=ARG] include FEATURE [ARG=yes] --enable-silent-rules less verbose build output (undo: "make V=1") --disable-silent-rules verbose build output (undo: "make V=0") --enable-dependency-tracking do not reject slow dependency extractors --disable-dependency-tracking speeds up one-time build --enable-shared[=PKGS] build shared libraries [default=yes] --enable-static[=PKGS] build static libraries [default=yes] --enable-fast-install[=PKGS] optimize for fast installation [default=yes] --disable-libtool-lock avoid locking (might break parallel builds) --enable-tests Build install tests (default: no) Optional Packages: --with-PACKAGE[=ARG] use PACKAGE [ARG=yes] --without-PACKAGE do not use PACKAGE (same as --with-PACKAGE=no) --with-pic[=PKGS] try to use only PIC/non-PIC objects [default=use both] --with-aix-soname=aix|svr4|both shared library versioning (aka "SONAME") variant to provide on AIX, [default=aix]. --with-gnu-ld assume the C compiler uses GNU ld [default=no] --with-sysroot[=DIR] Search for dependent libraries within DIR (or the compiler's sysroot if not specified). --with-pkgconfigdir pkg-config installation directory ['${libdir}/pkgconfig'] Some influential environment variables: CC C compiler command CFLAGS C compiler flags LDFLAGS linker flags, e.g. -L if you have libraries in a nonstandard directory LIBS libraries to pass to the linker, e.g. -l CPPFLAGS (Objective) C/C++ preprocessor flags, e.g. -I if you have headers in a nonstandard directory LT_SYS_LIBRARY_PATH User-defined run-time library search path. CPP C preprocessor Use these variables to override the choices made by `configure' or to help it to find libraries and programs with nonstandard names/locations. Report bugs to . _ACEOF ac_status=$? fi if test "$ac_init_help" = "recursive"; then # If there are subdirs, report their specific --help. for ac_dir in : $ac_subdirs_all; do test "x$ac_dir" = x: && continue test -d "$ac_dir" || { cd "$srcdir" && ac_pwd=`pwd` && srcdir=. && test -d "$ac_dir"; } || continue ac_builddir=. case "$ac_dir" in .) ac_dir_suffix= ac_top_builddir_sub=. ac_top_build_prefix= ;; *) ac_dir_suffix=/`$as_echo "$ac_dir" | sed 's|^\.[\\/]||'` # A ".." for each directory in $ac_dir_suffix. ac_top_builddir_sub=`$as_echo "$ac_dir_suffix" | sed 's|/[^\\/]*|/..|g;s|/||'` case $ac_top_builddir_sub in "") ac_top_builddir_sub=. ac_top_build_prefix= ;; *) ac_top_build_prefix=$ac_top_builddir_sub/ ;; esac ;; esac ac_abs_top_builddir=$ac_pwd ac_abs_builddir=$ac_pwd$ac_dir_suffix # for backward compatibility: ac_top_builddir=$ac_top_build_prefix case $srcdir in .) # We are building in place. ac_srcdir=. ac_top_srcdir=$ac_top_builddir_sub ac_abs_top_srcdir=$ac_pwd ;; [\\/]* | ?:[\\/]* ) # Absolute name. ac_srcdir=$srcdir$ac_dir_suffix; ac_top_srcdir=$srcdir ac_abs_top_srcdir=$srcdir ;; *) # Relative name. ac_srcdir=$ac_top_build_prefix$srcdir$ac_dir_suffix ac_top_srcdir=$ac_top_build_prefix$srcdir ac_abs_top_srcdir=$ac_pwd/$srcdir ;; esac ac_abs_srcdir=$ac_abs_top_srcdir$ac_dir_suffix cd "$ac_dir" || { ac_status=$?; continue; } # Check for guested configure. if test -f "$ac_srcdir/configure.gnu"; then echo && $SHELL "$ac_srcdir/configure.gnu" --help=recursive elif test -f "$ac_srcdir/configure"; then echo && $SHELL "$ac_srcdir/configure" --help=recursive else $as_echo "$as_me: WARNING: no configuration information is in $ac_dir" >&2 fi || ac_status=$? cd "$ac_pwd" || { ac_status=$?; break; } done fi test -n "$ac_init_help" && exit $ac_status if $ac_init_version; then cat <<\_ACEOF libpainter configure 0.1.1 generated by GNU Autoconf 2.69 Copyright (C) 2012 Free Software Foundation, Inc. This configure script is free software; the Free Software Foundation gives unlimited permission to copy, distribute and modify it. _ACEOF exit fi ## ------------------------ ## ## Autoconf initialization. ## ## ------------------------ ## # ac_fn_c_try_compile LINENO # -------------------------- # Try to compile conftest.$ac_ext, and return whether this succeeded. ac_fn_c_try_compile () { as_lineno=${as_lineno-"$1"} as_lineno_stack=as_lineno_stack=$as_lineno_stack rm -f conftest.$ac_objext if { { ac_try="$ac_compile" case "(($ac_try" in *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; *) ac_try_echo=$ac_try;; esac eval ac_try_echo="\"\$as_me:${as_lineno-$LINENO}: $ac_try_echo\"" $as_echo "$ac_try_echo"; } >&5 (eval "$ac_compile") 2>conftest.err ac_status=$? if test -s conftest.err; then grep -v '^ *+' conftest.err >conftest.er1 cat conftest.er1 >&5 mv -f conftest.er1 conftest.err fi $as_echo "$as_me:${as_lineno-$LINENO}: \$? = $ac_status" >&5 test $ac_status = 0; } && { test -z "$ac_c_werror_flag" || test ! -s conftest.err } && test -s conftest.$ac_objext; then : ac_retval=0 else $as_echo "$as_me: failed program was:" >&5 sed 's/^/| /' conftest.$ac_ext >&5 ac_retval=1 fi eval $as_lineno_stack; ${as_lineno_stack:+:} unset as_lineno as_fn_set_status $ac_retval } # ac_fn_c_try_compile # ac_fn_c_try_link LINENO # ----------------------- # Try to link conftest.$ac_ext, and return whether this succeeded. ac_fn_c_try_link () { as_lineno=${as_lineno-"$1"} as_lineno_stack=as_lineno_stack=$as_lineno_stack rm -f conftest.$ac_objext conftest$ac_exeext if { { ac_try="$ac_link" case "(($ac_try" in *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; *) ac_try_echo=$ac_try;; esac eval ac_try_echo="\"\$as_me:${as_lineno-$LINENO}: $ac_try_echo\"" $as_echo "$ac_try_echo"; } >&5 (eval "$ac_link") 2>conftest.err ac_status=$? if test -s conftest.err; then grep -v '^ *+' conftest.err >conftest.er1 cat conftest.er1 >&5 mv -f conftest.er1 conftest.err fi $as_echo "$as_me:${as_lineno-$LINENO}: \$? = $ac_status" >&5 test $ac_status = 0; } && { test -z "$ac_c_werror_flag" || test ! -s conftest.err } && test -s conftest$ac_exeext && { test "$cross_compiling" = yes || test -x conftest$ac_exeext }; then : ac_retval=0 else $as_echo "$as_me: failed program was:" >&5 sed 's/^/| /' conftest.$ac_ext >&5 ac_retval=1 fi # Delete the IPA/IPO (Inter Procedural Analysis/Optimization) information # created by the PGI compiler (conftest_ipa8_conftest.oo), as it would # interfere with the next link command; also delete a directory that is # left behind by Apple's compiler. We do this before executing the actions. rm -rf conftest.dSYM conftest_ipa8_conftest.oo eval $as_lineno_stack; ${as_lineno_stack:+:} unset as_lineno as_fn_set_status $ac_retval } # ac_fn_c_try_link # ac_fn_c_check_header_compile LINENO HEADER VAR INCLUDES # ------------------------------------------------------- # Tests whether HEADER exists and can be compiled using the include files in # INCLUDES, setting the cache variable VAR accordingly. ac_fn_c_check_header_compile () { as_lineno=${as_lineno-"$1"} as_lineno_stack=as_lineno_stack=$as_lineno_stack { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $2" >&5 $as_echo_n "checking for $2... " >&6; } if eval \${$3+:} false; then : $as_echo_n "(cached) " >&6 else cat confdefs.h - <<_ACEOF >conftest.$ac_ext /* end confdefs.h. */ $4 #include <$2> _ACEOF if ac_fn_c_try_compile "$LINENO"; then : eval "$3=yes" else eval "$3=no" fi rm -f core conftest.err conftest.$ac_objext conftest.$ac_ext fi eval ac_res=\$$3 { $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_res" >&5 $as_echo "$ac_res" >&6; } eval $as_lineno_stack; ${as_lineno_stack:+:} unset as_lineno } # ac_fn_c_check_header_compile # ac_fn_c_try_cpp LINENO # ---------------------- # Try to preprocess conftest.$ac_ext, and return whether this succeeded. ac_fn_c_try_cpp () { as_lineno=${as_lineno-"$1"} as_lineno_stack=as_lineno_stack=$as_lineno_stack if { { ac_try="$ac_cpp conftest.$ac_ext" case "(($ac_try" in *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; *) ac_try_echo=$ac_try;; esac eval ac_try_echo="\"\$as_me:${as_lineno-$LINENO}: $ac_try_echo\"" $as_echo "$ac_try_echo"; } >&5 (eval "$ac_cpp conftest.$ac_ext") 2>conftest.err ac_status=$? if test -s conftest.err; then grep -v '^ *+' conftest.err >conftest.er1 cat conftest.er1 >&5 mv -f conftest.er1 conftest.err fi $as_echo "$as_me:${as_lineno-$LINENO}: \$? = $ac_status" >&5 test $ac_status = 0; } > conftest.i && { test -z "$ac_c_preproc_warn_flag$ac_c_werror_flag" || test ! -s conftest.err }; then : ac_retval=0 else $as_echo "$as_me: failed program was:" >&5 sed 's/^/| /' conftest.$ac_ext >&5 ac_retval=1 fi eval $as_lineno_stack; ${as_lineno_stack:+:} unset as_lineno as_fn_set_status $ac_retval } # ac_fn_c_try_cpp # ac_fn_c_try_run LINENO # ---------------------- # Try to link conftest.$ac_ext, and return whether this succeeded. Assumes # that executables *can* be run. ac_fn_c_try_run () { as_lineno=${as_lineno-"$1"} as_lineno_stack=as_lineno_stack=$as_lineno_stack if { { ac_try="$ac_link" case "(($ac_try" in *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; *) ac_try_echo=$ac_try;; esac eval ac_try_echo="\"\$as_me:${as_lineno-$LINENO}: $ac_try_echo\"" $as_echo "$ac_try_echo"; } >&5 (eval "$ac_link") 2>&5 ac_status=$? $as_echo "$as_me:${as_lineno-$LINENO}: \$? = $ac_status" >&5 test $ac_status = 0; } && { ac_try='./conftest$ac_exeext' { { case "(($ac_try" in *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; *) ac_try_echo=$ac_try;; esac eval ac_try_echo="\"\$as_me:${as_lineno-$LINENO}: $ac_try_echo\"" $as_echo "$ac_try_echo"; } >&5 (eval "$ac_try") 2>&5 ac_status=$? $as_echo "$as_me:${as_lineno-$LINENO}: \$? = $ac_status" >&5 test $ac_status = 0; }; }; then : ac_retval=0 else $as_echo "$as_me: program exited with status $ac_status" >&5 $as_echo "$as_me: failed program was:" >&5 sed 's/^/| /' conftest.$ac_ext >&5 ac_retval=$ac_status fi rm -rf conftest.dSYM conftest_ipa8_conftest.oo eval $as_lineno_stack; ${as_lineno_stack:+:} unset as_lineno as_fn_set_status $ac_retval } # ac_fn_c_try_run # ac_fn_c_check_func LINENO FUNC VAR # ---------------------------------- # Tests whether FUNC exists, setting the cache variable VAR accordingly ac_fn_c_check_func () { as_lineno=${as_lineno-"$1"} as_lineno_stack=as_lineno_stack=$as_lineno_stack { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $2" >&5 $as_echo_n "checking for $2... " >&6; } if eval \${$3+:} false; then : $as_echo_n "(cached) " >&6 else cat confdefs.h - <<_ACEOF >conftest.$ac_ext /* end confdefs.h. */ /* Define $2 to an innocuous variant, in case declares $2. For example, HP-UX 11i declares gettimeofday. */ #define $2 innocuous_$2 /* System header to define __stub macros and hopefully few prototypes, which can conflict with char $2 (); below. Prefer to if __STDC__ is defined, since exists even on freestanding compilers. */ #ifdef __STDC__ # include #else # include #endif #undef $2 /* Override any GCC internal prototype to avoid an error. Use char because int might match the return type of a GCC builtin and then its argument prototype would still apply. */ #ifdef __cplusplus extern "C" #endif char $2 (); /* The GNU C library defines this for functions which it implements to always fail with ENOSYS. Some functions are actually named something starting with __ and the normal name is an alias. */ #if defined __stub_$2 || defined __stub___$2 choke me #endif int main () { return $2 (); ; return 0; } _ACEOF if ac_fn_c_try_link "$LINENO"; then : eval "$3=yes" else eval "$3=no" fi rm -f core conftest.err conftest.$ac_objext \ conftest$ac_exeext conftest.$ac_ext fi eval ac_res=\$$3 { $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_res" >&5 $as_echo "$ac_res" >&6; } eval $as_lineno_stack; ${as_lineno_stack:+:} unset as_lineno } # ac_fn_c_check_func cat >config.log <<_ACEOF This file contains any messages produced by compilers while running configure, to aid debugging if configure makes a mistake. It was created by libpainter $as_me 0.1.1, which was generated by GNU Autoconf 2.69. Invocation command line was $ $0 $@ _ACEOF exec 5>>config.log { cat <<_ASUNAME ## --------- ## ## Platform. ## ## --------- ## hostname = `(hostname || uname -n) 2>/dev/null | sed 1q` uname -m = `(uname -m) 2>/dev/null || echo unknown` uname -r = `(uname -r) 2>/dev/null || echo unknown` uname -s = `(uname -s) 2>/dev/null || echo unknown` uname -v = `(uname -v) 2>/dev/null || echo unknown` /usr/bin/uname -p = `(/usr/bin/uname -p) 2>/dev/null || echo unknown` /bin/uname -X = `(/bin/uname -X) 2>/dev/null || echo unknown` /bin/arch = `(/bin/arch) 2>/dev/null || echo unknown` /usr/bin/arch -k = `(/usr/bin/arch -k) 2>/dev/null || echo unknown` /usr/convex/getsysinfo = `(/usr/convex/getsysinfo) 2>/dev/null || echo unknown` /usr/bin/hostinfo = `(/usr/bin/hostinfo) 2>/dev/null || echo unknown` /bin/machine = `(/bin/machine) 2>/dev/null || echo unknown` /usr/bin/oslevel = `(/usr/bin/oslevel) 2>/dev/null || echo unknown` /bin/universe = `(/bin/universe) 2>/dev/null || echo unknown` _ASUNAME as_save_IFS=$IFS; IFS=$PATH_SEPARATOR for as_dir in $PATH do IFS=$as_save_IFS test -z "$as_dir" && as_dir=. $as_echo "PATH: $as_dir" done IFS=$as_save_IFS } >&5 cat >&5 <<_ACEOF ## ----------- ## ## Core tests. ## ## ----------- ## _ACEOF # Keep a trace of the command line. # Strip out --no-create and --no-recursion so they do not pile up. # Strip out --silent because we don't want to record it for future runs. # Also quote any args containing shell meta-characters. # Make two passes to allow for proper duplicate-argument suppression. ac_configure_args= ac_configure_args0= ac_configure_args1= ac_must_keep_next=false for ac_pass in 1 2 do for ac_arg do case $ac_arg in -no-create | --no-c* | -n | -no-recursion | --no-r*) continue ;; -q | -quiet | --quiet | --quie | --qui | --qu | --q \ | -silent | --silent | --silen | --sile | --sil) continue ;; *\'*) ac_arg=`$as_echo "$ac_arg" | sed "s/'/'\\\\\\\\''/g"` ;; esac case $ac_pass in 1) as_fn_append ac_configure_args0 " '$ac_arg'" ;; 2) as_fn_append ac_configure_args1 " '$ac_arg'" if test $ac_must_keep_next = true; then ac_must_keep_next=false # Got value, back to normal. else case $ac_arg in *=* | --config-cache | -C | -disable-* | --disable-* \ | -enable-* | --enable-* | -gas | --g* | -nfp | --nf* \ | -q | -quiet | --q* | -silent | --sil* | -v | -verb* \ | -with-* | --with-* | -without-* | --without-* | --x) case "$ac_configure_args0 " in "$ac_configure_args1"*" '$ac_arg' "* ) continue ;; esac ;; -* ) ac_must_keep_next=true ;; esac fi as_fn_append ac_configure_args " '$ac_arg'" ;; esac done done { ac_configure_args0=; unset ac_configure_args0;} { ac_configure_args1=; unset ac_configure_args1;} # When interrupted or exit'd, cleanup temporary files, and complete # config.log. We remove comments because anyway the quotes in there # would cause problems or look ugly. # WARNING: Use '\'' to represent an apostrophe within the trap. # WARNING: Do not start the trap code with a newline, due to a FreeBSD 4.0 bug. trap 'exit_status=$? # Save into config.log some information that might help in debugging. { echo $as_echo "## ---------------- ## ## Cache variables. ## ## ---------------- ##" echo # The following way of writing the cache mishandles newlines in values, ( for ac_var in `(set) 2>&1 | sed -n '\''s/^\([a-zA-Z_][a-zA-Z0-9_]*\)=.*/\1/p'\''`; do eval ac_val=\$$ac_var case $ac_val in #( *${as_nl}*) case $ac_var in #( *_cv_*) { $as_echo "$as_me:${as_lineno-$LINENO}: WARNING: cache variable $ac_var contains a newline" >&5 $as_echo "$as_me: WARNING: cache variable $ac_var contains a newline" >&2;} ;; esac case $ac_var in #( _ | IFS | as_nl) ;; #( BASH_ARGV | BASH_SOURCE) eval $ac_var= ;; #( *) { eval $ac_var=; unset $ac_var;} ;; esac ;; esac done (set) 2>&1 | case $as_nl`(ac_space='\'' '\''; set) 2>&1` in #( *${as_nl}ac_space=\ *) sed -n \ "s/'\''/'\''\\\\'\'''\''/g; s/^\\([_$as_cr_alnum]*_cv_[_$as_cr_alnum]*\\)=\\(.*\\)/\\1='\''\\2'\''/p" ;; #( *) sed -n "/^[_$as_cr_alnum]*_cv_[_$as_cr_alnum]*=/p" ;; esac | sort ) echo $as_echo "## ----------------- ## ## Output variables. ## ## ----------------- ##" echo for ac_var in $ac_subst_vars do eval ac_val=\$$ac_var case $ac_val in *\'\''*) ac_val=`$as_echo "$ac_val" | sed "s/'\''/'\''\\\\\\\\'\'''\''/g"`;; esac $as_echo "$ac_var='\''$ac_val'\''" done | sort echo if test -n "$ac_subst_files"; then $as_echo "## ------------------- ## ## File substitutions. ## ## ------------------- ##" echo for ac_var in $ac_subst_files do eval ac_val=\$$ac_var case $ac_val in *\'\''*) ac_val=`$as_echo "$ac_val" | sed "s/'\''/'\''\\\\\\\\'\'''\''/g"`;; esac $as_echo "$ac_var='\''$ac_val'\''" done | sort echo fi if test -s confdefs.h; then $as_echo "## ----------- ## ## confdefs.h. ## ## ----------- ##" echo cat confdefs.h echo fi test "$ac_signal" != 0 && $as_echo "$as_me: caught signal $ac_signal" $as_echo "$as_me: exit $exit_status" } >&5 rm -f core *.core core.conftest.* && rm -f -r conftest* confdefs* conf$$* $ac_clean_files && exit $exit_status ' 0 for ac_signal in 1 2 13 15; do trap 'ac_signal='$ac_signal'; as_fn_exit 1' $ac_signal done ac_signal=0 # confdefs.h avoids OS command line length limits that DEFS can exceed. rm -f -r conftest* confdefs.h $as_echo "/* confdefs.h */" > confdefs.h # Predefined preprocessor variables. cat >>confdefs.h <<_ACEOF #define PACKAGE_NAME "$PACKAGE_NAME" _ACEOF cat >>confdefs.h <<_ACEOF #define PACKAGE_TARNAME "$PACKAGE_TARNAME" _ACEOF cat >>confdefs.h <<_ACEOF #define PACKAGE_VERSION "$PACKAGE_VERSION" _ACEOF cat >>confdefs.h <<_ACEOF #define PACKAGE_STRING "$PACKAGE_STRING" _ACEOF cat >>confdefs.h <<_ACEOF #define PACKAGE_BUGREPORT "$PACKAGE_BUGREPORT" _ACEOF cat >>confdefs.h <<_ACEOF #define PACKAGE_URL "$PACKAGE_URL" _ACEOF # Let the site file select an alternate cache file if it wants to. # Prefer an explicitly selected file to automatically selected ones. ac_site_file1=NONE ac_site_file2=NONE if test -n "$CONFIG_SITE"; then # We do not want a PATH search for config.site. case $CONFIG_SITE in #(( -*) ac_site_file1=./$CONFIG_SITE;; */*) ac_site_file1=$CONFIG_SITE;; *) ac_site_file1=./$CONFIG_SITE;; esac elif test "x$prefix" != xNONE; then ac_site_file1=$prefix/share/config.site ac_site_file2=$prefix/etc/config.site else ac_site_file1=$ac_default_prefix/share/config.site ac_site_file2=$ac_default_prefix/etc/config.site fi for ac_site_file in "$ac_site_file1" "$ac_site_file2" do test "x$ac_site_file" = xNONE && continue if test /dev/null != "$ac_site_file" && test -r "$ac_site_file"; then { $as_echo "$as_me:${as_lineno-$LINENO}: loading site script $ac_site_file" >&5 $as_echo "$as_me: loading site script $ac_site_file" >&6;} sed 's/^/| /' "$ac_site_file" >&5 . "$ac_site_file" \ || { { $as_echo "$as_me:${as_lineno-$LINENO}: error: in \`$ac_pwd':" >&5 $as_echo "$as_me: error: in \`$ac_pwd':" >&2;} as_fn_error $? "failed to load site script $ac_site_file See \`config.log' for more details" "$LINENO" 5; } fi done if test -r "$cache_file"; then # Some versions of bash will fail to source /dev/null (special files # actually), so we avoid doing that. DJGPP emulates it as a regular file. if test /dev/null != "$cache_file" && test -f "$cache_file"; then { $as_echo "$as_me:${as_lineno-$LINENO}: loading cache $cache_file" >&5 $as_echo "$as_me: loading cache $cache_file" >&6;} case $cache_file in [\\/]* | ?:[\\/]* ) . "$cache_file";; *) . "./$cache_file";; esac fi else { $as_echo "$as_me:${as_lineno-$LINENO}: creating cache $cache_file" >&5 $as_echo "$as_me: creating cache $cache_file" >&6;} >$cache_file fi # Check that the precious variables saved in the cache have kept the same # value. ac_cache_corrupted=false for ac_var in $ac_precious_vars; do eval ac_old_set=\$ac_cv_env_${ac_var}_set eval ac_new_set=\$ac_env_${ac_var}_set eval ac_old_val=\$ac_cv_env_${ac_var}_value eval ac_new_val=\$ac_env_${ac_var}_value case $ac_old_set,$ac_new_set in set,) { $as_echo "$as_me:${as_lineno-$LINENO}: error: \`$ac_var' was set to \`$ac_old_val' in the previous run" >&5 $as_echo "$as_me: error: \`$ac_var' was set to \`$ac_old_val' in the previous run" >&2;} ac_cache_corrupted=: ;; ,set) { $as_echo "$as_me:${as_lineno-$LINENO}: error: \`$ac_var' was not set in the previous run" >&5 $as_echo "$as_me: error: \`$ac_var' was not set in the previous run" >&2;} ac_cache_corrupted=: ;; ,);; *) if test "x$ac_old_val" != "x$ac_new_val"; then # differences in whitespace do not lead to failure. ac_old_val_w=`echo x $ac_old_val` ac_new_val_w=`echo x $ac_new_val` if test "$ac_old_val_w" != "$ac_new_val_w"; then { $as_echo "$as_me:${as_lineno-$LINENO}: error: \`$ac_var' has changed since the previous run:" >&5 $as_echo "$as_me: error: \`$ac_var' has changed since the previous run:" >&2;} ac_cache_corrupted=: else { $as_echo "$as_me:${as_lineno-$LINENO}: warning: ignoring whitespace changes in \`$ac_var' since the previous run:" >&5 $as_echo "$as_me: warning: ignoring whitespace changes in \`$ac_var' since the previous run:" >&2;} eval $ac_var=\$ac_old_val fi { $as_echo "$as_me:${as_lineno-$LINENO}: former value: \`$ac_old_val'" >&5 $as_echo "$as_me: former value: \`$ac_old_val'" >&2;} { $as_echo "$as_me:${as_lineno-$LINENO}: current value: \`$ac_new_val'" >&5 $as_echo "$as_me: current value: \`$ac_new_val'" >&2;} fi;; esac # Pass precious variables to config.status. if test "$ac_new_set" = set; then case $ac_new_val in *\'*) ac_arg=$ac_var=`$as_echo "$ac_new_val" | sed "s/'/'\\\\\\\\''/g"` ;; *) ac_arg=$ac_var=$ac_new_val ;; esac case " $ac_configure_args " in *" '$ac_arg' "*) ;; # Avoid dups. Use of quotes ensures accuracy. *) as_fn_append ac_configure_args " '$ac_arg'" ;; esac fi done if $ac_cache_corrupted; then { $as_echo "$as_me:${as_lineno-$LINENO}: error: in \`$ac_pwd':" >&5 $as_echo "$as_me: error: in \`$ac_pwd':" >&2;} { $as_echo "$as_me:${as_lineno-$LINENO}: error: changes in the environment can compromise the build" >&5 $as_echo "$as_me: error: changes in the environment can compromise the build" >&2;} as_fn_error $? "run \`make distclean' and/or \`rm $cache_file' and start over" "$LINENO" 5 fi ## -------------------- ## ## Main body of script. ## ## -------------------- ## ac_ext=c ac_cpp='$CPP $CPPFLAGS' ac_compile='$CC -c $CFLAGS $CPPFLAGS conftest.$ac_ext >&5' ac_link='$CC -o conftest$ac_exeext $CFLAGS $CPPFLAGS $LDFLAGS conftest.$ac_ext $LIBS >&5' ac_compiler_gnu=$ac_cv_c_compiler_gnu ac_config_headers="$ac_config_headers config_ac.h:config_ac-h.in" am__api_version='1.15' ac_aux_dir= for ac_dir in "$srcdir" "$srcdir/.." "$srcdir/../.."; do if test -f "$ac_dir/install-sh"; then ac_aux_dir=$ac_dir ac_install_sh="$ac_aux_dir/install-sh -c" break elif test -f "$ac_dir/install.sh"; then ac_aux_dir=$ac_dir ac_install_sh="$ac_aux_dir/install.sh -c" break elif test -f "$ac_dir/shtool"; then ac_aux_dir=$ac_dir ac_install_sh="$ac_aux_dir/shtool install -c" break fi done if test -z "$ac_aux_dir"; then as_fn_error $? "cannot find install-sh, install.sh, or shtool in \"$srcdir\" \"$srcdir/..\" \"$srcdir/../..\"" "$LINENO" 5 fi # These three variables are undocumented and unsupported, # and are intended to be withdrawn in a future Autoconf release. # They can cause serious problems if a builder's source tree is in a directory # whose full name contains unusual characters. ac_config_guess="$SHELL $ac_aux_dir/config.guess" # Please don't use this var. ac_config_sub="$SHELL $ac_aux_dir/config.sub" # Please don't use this var. ac_configure="$SHELL $ac_aux_dir/configure" # Please don't use this var. # Find a good install program. We prefer a C program (faster), # so one script is as good as another. But avoid the broken or # incompatible versions: # SysV /etc/install, /usr/sbin/install # SunOS /usr/etc/install # IRIX /sbin/install # AIX /bin/install # AmigaOS /C/install, which installs bootblocks on floppy discs # AIX 4 /usr/bin/installbsd, which doesn't work without a -g flag # AFS /usr/afsws/bin/install, which mishandles nonexistent args # SVR4 /usr/ucb/install, which tries to use the nonexistent group "staff" # OS/2's system install, which has a completely different semantic # ./install, which can be erroneously created by make from ./install.sh. # Reject install programs that cannot install multiple files. { $as_echo "$as_me:${as_lineno-$LINENO}: checking for a BSD-compatible install" >&5 $as_echo_n "checking for a BSD-compatible install... " >&6; } if test -z "$INSTALL"; then if ${ac_cv_path_install+:} false; then : $as_echo_n "(cached) " >&6 else as_save_IFS=$IFS; IFS=$PATH_SEPARATOR for as_dir in $PATH do IFS=$as_save_IFS test -z "$as_dir" && as_dir=. # Account for people who put trailing slashes in PATH elements. case $as_dir/ in #(( ./ | .// | /[cC]/* | \ /etc/* | /usr/sbin/* | /usr/etc/* | /sbin/* | /usr/afsws/bin/* | \ ?:[\\/]os2[\\/]install[\\/]* | ?:[\\/]OS2[\\/]INSTALL[\\/]* | \ /usr/ucb/* ) ;; *) # OSF1 and SCO ODT 3.0 have their own names for install. # Don't use installbsd from OSF since it installs stuff as root # by default. for ac_prog in ginstall scoinst install; do for ac_exec_ext in '' $ac_executable_extensions; do if as_fn_executable_p "$as_dir/$ac_prog$ac_exec_ext"; then if test $ac_prog = install && grep dspmsg "$as_dir/$ac_prog$ac_exec_ext" >/dev/null 2>&1; then # AIX install. It has an incompatible calling convention. : elif test $ac_prog = install && grep pwplus "$as_dir/$ac_prog$ac_exec_ext" >/dev/null 2>&1; then # program-specific install script used by HP pwplus--don't use. : else rm -rf conftest.one conftest.two conftest.dir echo one > conftest.one echo two > conftest.two mkdir conftest.dir if "$as_dir/$ac_prog$ac_exec_ext" -c conftest.one conftest.two "`pwd`/conftest.dir" && test -s conftest.one && test -s conftest.two && test -s conftest.dir/conftest.one && test -s conftest.dir/conftest.two then ac_cv_path_install="$as_dir/$ac_prog$ac_exec_ext -c" break 3 fi fi fi done done ;; esac done IFS=$as_save_IFS rm -rf conftest.one conftest.two conftest.dir fi if test "${ac_cv_path_install+set}" = set; then INSTALL=$ac_cv_path_install else # As a last resort, use the slow shell script. Don't cache a # value for INSTALL within a source directory, because that will # break other packages using the cache if that directory is # removed, or if the value is a relative name. INSTALL=$ac_install_sh fi fi { $as_echo "$as_me:${as_lineno-$LINENO}: result: $INSTALL" >&5 $as_echo "$INSTALL" >&6; } # Use test -z because SunOS4 sh mishandles braces in ${var-val}. # It thinks the first close brace ends the variable substitution. test -z "$INSTALL_PROGRAM" && INSTALL_PROGRAM='${INSTALL}' test -z "$INSTALL_SCRIPT" && INSTALL_SCRIPT='${INSTALL}' test -z "$INSTALL_DATA" && INSTALL_DATA='${INSTALL} -m 644' { $as_echo "$as_me:${as_lineno-$LINENO}: checking whether build environment is sane" >&5 $as_echo_n "checking whether build environment is sane... " >&6; } # Reject unsafe characters in $srcdir or the absolute working directory # name. Accept space and tab only in the latter. am_lf=' ' case `pwd` in *[\\\"\#\$\&\'\`$am_lf]*) as_fn_error $? "unsafe absolute working directory name" "$LINENO" 5;; esac case $srcdir in *[\\\"\#\$\&\'\`$am_lf\ \ ]*) as_fn_error $? "unsafe srcdir value: '$srcdir'" "$LINENO" 5;; esac # Do 'set' in a subshell so we don't clobber the current shell's # arguments. Must try -L first in case configure is actually a # symlink; some systems play weird games with the mod time of symlinks # (eg FreeBSD returns the mod time of the symlink's containing # directory). if ( am_has_slept=no for am_try in 1 2; do echo "timestamp, slept: $am_has_slept" > conftest.file set X `ls -Lt "$srcdir/configure" conftest.file 2> /dev/null` if test "$*" = "X"; then # -L didn't work. set X `ls -t "$srcdir/configure" conftest.file` fi if test "$*" != "X $srcdir/configure conftest.file" \ && test "$*" != "X conftest.file $srcdir/configure"; then # If neither matched, then we have a broken ls. This can happen # if, for instance, CONFIG_SHELL is bash and it inherits a # broken ls alias from the environment. This has actually # happened. Such a system could not be considered "sane". as_fn_error $? "ls -t appears to fail. Make sure there is not a broken alias in your environment" "$LINENO" 5 fi if test "$2" = conftest.file || test $am_try -eq 2; then break fi # Just in case. sleep 1 am_has_slept=yes done test "$2" = conftest.file ) then # Ok. : else as_fn_error $? "newly created file is older than distributed files! Check your system clock" "$LINENO" 5 fi { $as_echo "$as_me:${as_lineno-$LINENO}: result: yes" >&5 $as_echo "yes" >&6; } # If we didn't sleep, we still need to ensure time stamps of config.status and # generated files are strictly newer. am_sleep_pid= if grep 'slept: no' conftest.file >/dev/null 2>&1; then ( sleep 1 ) & am_sleep_pid=$! fi rm -f conftest.file test "$program_prefix" != NONE && program_transform_name="s&^&$program_prefix&;$program_transform_name" # Use a double $ so make ignores it. test "$program_suffix" != NONE && program_transform_name="s&\$&$program_suffix&;$program_transform_name" # Double any \ or $. # By default was `s,x,x', remove it if useless. ac_script='s/[\\$]/&&/g;s/;s,x,x,$//' program_transform_name=`$as_echo "$program_transform_name" | sed "$ac_script"` # Expand $ac_aux_dir to an absolute path. am_aux_dir=`cd "$ac_aux_dir" && pwd` if test x"${MISSING+set}" != xset; then case $am_aux_dir in *\ * | *\ *) MISSING="\${SHELL} \"$am_aux_dir/missing\"" ;; *) MISSING="\${SHELL} $am_aux_dir/missing" ;; esac fi # Use eval to expand $SHELL if eval "$MISSING --is-lightweight"; then am_missing_run="$MISSING " else am_missing_run= { $as_echo "$as_me:${as_lineno-$LINENO}: WARNING: 'missing' script is too old or missing" >&5 $as_echo "$as_me: WARNING: 'missing' script is too old or missing" >&2;} fi if test x"${install_sh+set}" != xset; then case $am_aux_dir in *\ * | *\ *) install_sh="\${SHELL} '$am_aux_dir/install-sh'" ;; *) install_sh="\${SHELL} $am_aux_dir/install-sh" esac fi # Installed binaries are usually stripped using 'strip' when the user # run "make install-strip". However 'strip' might not be the right # tool to use in cross-compilation environments, therefore Automake # will honor the 'STRIP' environment variable to overrule this program. if test "$cross_compiling" != no; then if test -n "$ac_tool_prefix"; then # Extract the first word of "${ac_tool_prefix}strip", so it can be a program name with args. set dummy ${ac_tool_prefix}strip; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } if ${ac_cv_prog_STRIP+:} false; then : $as_echo_n "(cached) " >&6 else if test -n "$STRIP"; then ac_cv_prog_STRIP="$STRIP" # Let the user override the test. else as_save_IFS=$IFS; IFS=$PATH_SEPARATOR for as_dir in $PATH do IFS=$as_save_IFS test -z "$as_dir" && as_dir=. for ac_exec_ext in '' $ac_executable_extensions; do if as_fn_executable_p "$as_dir/$ac_word$ac_exec_ext"; then ac_cv_prog_STRIP="${ac_tool_prefix}strip" $as_echo "$as_me:${as_lineno-$LINENO}: found $as_dir/$ac_word$ac_exec_ext" >&5 break 2 fi done done IFS=$as_save_IFS fi fi STRIP=$ac_cv_prog_STRIP if test -n "$STRIP"; then { $as_echo "$as_me:${as_lineno-$LINENO}: result: $STRIP" >&5 $as_echo "$STRIP" >&6; } else { $as_echo "$as_me:${as_lineno-$LINENO}: result: no" >&5 $as_echo "no" >&6; } fi fi if test -z "$ac_cv_prog_STRIP"; then ac_ct_STRIP=$STRIP # Extract the first word of "strip", so it can be a program name with args. set dummy strip; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } if ${ac_cv_prog_ac_ct_STRIP+:} false; then : $as_echo_n "(cached) " >&6 else if test -n "$ac_ct_STRIP"; then ac_cv_prog_ac_ct_STRIP="$ac_ct_STRIP" # Let the user override the test. else as_save_IFS=$IFS; IFS=$PATH_SEPARATOR for as_dir in $PATH do IFS=$as_save_IFS test -z "$as_dir" && as_dir=. for ac_exec_ext in '' $ac_executable_extensions; do if as_fn_executable_p "$as_dir/$ac_word$ac_exec_ext"; then ac_cv_prog_ac_ct_STRIP="strip" $as_echo "$as_me:${as_lineno-$LINENO}: found $as_dir/$ac_word$ac_exec_ext" >&5 break 2 fi done done IFS=$as_save_IFS fi fi ac_ct_STRIP=$ac_cv_prog_ac_ct_STRIP if test -n "$ac_ct_STRIP"; then { $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_ct_STRIP" >&5 $as_echo "$ac_ct_STRIP" >&6; } else { $as_echo "$as_me:${as_lineno-$LINENO}: result: no" >&5 $as_echo "no" >&6; } fi if test "x$ac_ct_STRIP" = x; then STRIP=":" else case $cross_compiling:$ac_tool_warned in yes:) { $as_echo "$as_me:${as_lineno-$LINENO}: WARNING: using cross tools not prefixed with host triplet" >&5 $as_echo "$as_me: WARNING: using cross tools not prefixed with host triplet" >&2;} ac_tool_warned=yes ;; esac STRIP=$ac_ct_STRIP fi else STRIP="$ac_cv_prog_STRIP" fi fi INSTALL_STRIP_PROGRAM="\$(install_sh) -c -s" { $as_echo "$as_me:${as_lineno-$LINENO}: checking for a thread-safe mkdir -p" >&5 $as_echo_n "checking for a thread-safe mkdir -p... " >&6; } if test -z "$MKDIR_P"; then if ${ac_cv_path_mkdir+:} false; then : $as_echo_n "(cached) " >&6 else as_save_IFS=$IFS; IFS=$PATH_SEPARATOR for as_dir in $PATH$PATH_SEPARATOR/opt/sfw/bin do IFS=$as_save_IFS test -z "$as_dir" && as_dir=. for ac_prog in mkdir gmkdir; do for ac_exec_ext in '' $ac_executable_extensions; do as_fn_executable_p "$as_dir/$ac_prog$ac_exec_ext" || continue case `"$as_dir/$ac_prog$ac_exec_ext" --version 2>&1` in #( 'mkdir (GNU coreutils) '* | \ 'mkdir (coreutils) '* | \ 'mkdir (fileutils) '4.1*) ac_cv_path_mkdir=$as_dir/$ac_prog$ac_exec_ext break 3;; esac done done done IFS=$as_save_IFS fi test -d ./--version && rmdir ./--version if test "${ac_cv_path_mkdir+set}" = set; then MKDIR_P="$ac_cv_path_mkdir -p" else # As a last resort, use the slow shell script. Don't cache a # value for MKDIR_P within a source directory, because that will # break other packages using the cache if that directory is # removed, or if the value is a relative name. MKDIR_P="$ac_install_sh -d" fi fi { $as_echo "$as_me:${as_lineno-$LINENO}: result: $MKDIR_P" >&5 $as_echo "$MKDIR_P" >&6; } for ac_prog in gawk mawk nawk awk do # Extract the first word of "$ac_prog", so it can be a program name with args. set dummy $ac_prog; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } if ${ac_cv_prog_AWK+:} false; then : $as_echo_n "(cached) " >&6 else if test -n "$AWK"; then ac_cv_prog_AWK="$AWK" # Let the user override the test. else as_save_IFS=$IFS; IFS=$PATH_SEPARATOR for as_dir in $PATH do IFS=$as_save_IFS test -z "$as_dir" && as_dir=. for ac_exec_ext in '' $ac_executable_extensions; do if as_fn_executable_p "$as_dir/$ac_word$ac_exec_ext"; then ac_cv_prog_AWK="$ac_prog" $as_echo "$as_me:${as_lineno-$LINENO}: found $as_dir/$ac_word$ac_exec_ext" >&5 break 2 fi done done IFS=$as_save_IFS fi fi AWK=$ac_cv_prog_AWK if test -n "$AWK"; then { $as_echo "$as_me:${as_lineno-$LINENO}: result: $AWK" >&5 $as_echo "$AWK" >&6; } else { $as_echo "$as_me:${as_lineno-$LINENO}: result: no" >&5 $as_echo "no" >&6; } fi test -n "$AWK" && break done { $as_echo "$as_me:${as_lineno-$LINENO}: checking whether ${MAKE-make} sets \$(MAKE)" >&5 $as_echo_n "checking whether ${MAKE-make} sets \$(MAKE)... " >&6; } set x ${MAKE-make} ac_make=`$as_echo "$2" | sed 's/+/p/g; s/[^a-zA-Z0-9_]/_/g'` if eval \${ac_cv_prog_make_${ac_make}_set+:} false; then : $as_echo_n "(cached) " >&6 else cat >conftest.make <<\_ACEOF SHELL = /bin/sh all: @echo '@@@%%%=$(MAKE)=@@@%%%' _ACEOF # GNU make sometimes prints "make[1]: Entering ...", which would confuse us. case `${MAKE-make} -f conftest.make 2>/dev/null` in *@@@%%%=?*=@@@%%%*) eval ac_cv_prog_make_${ac_make}_set=yes;; *) eval ac_cv_prog_make_${ac_make}_set=no;; esac rm -f conftest.make fi if eval test \$ac_cv_prog_make_${ac_make}_set = yes; then { $as_echo "$as_me:${as_lineno-$LINENO}: result: yes" >&5 $as_echo "yes" >&6; } SET_MAKE= else { $as_echo "$as_me:${as_lineno-$LINENO}: result: no" >&5 $as_echo "no" >&6; } SET_MAKE="MAKE=${MAKE-make}" fi rm -rf .tst 2>/dev/null mkdir .tst 2>/dev/null if test -d .tst; then am__leading_dot=. else am__leading_dot=_ fi rmdir .tst 2>/dev/null # Check whether --enable-silent-rules was given. if test "${enable_silent_rules+set}" = set; then : enableval=$enable_silent_rules; fi case $enable_silent_rules in # ((( yes) AM_DEFAULT_VERBOSITY=0;; no) AM_DEFAULT_VERBOSITY=1;; *) AM_DEFAULT_VERBOSITY=1;; esac am_make=${MAKE-make} { $as_echo "$as_me:${as_lineno-$LINENO}: checking whether $am_make supports nested variables" >&5 $as_echo_n "checking whether $am_make supports nested variables... " >&6; } if ${am_cv_make_support_nested_variables+:} false; then : $as_echo_n "(cached) " >&6 else if $as_echo 'TRUE=$(BAR$(V)) BAR0=false BAR1=true V=1 am__doit: @$(TRUE) .PHONY: am__doit' | $am_make -f - >/dev/null 2>&1; then am_cv_make_support_nested_variables=yes else am_cv_make_support_nested_variables=no fi fi { $as_echo "$as_me:${as_lineno-$LINENO}: result: $am_cv_make_support_nested_variables" >&5 $as_echo "$am_cv_make_support_nested_variables" >&6; } if test $am_cv_make_support_nested_variables = yes; then AM_V='$(V)' AM_DEFAULT_V='$(AM_DEFAULT_VERBOSITY)' else AM_V=$AM_DEFAULT_VERBOSITY AM_DEFAULT_V=$AM_DEFAULT_VERBOSITY fi AM_BACKSLASH='\' if test "`cd $srcdir && pwd`" != "`pwd`"; then # Use -I$(srcdir) only when $(srcdir) != ., so that make's output # is not polluted with repeated "-I." am__isrc=' -I$(srcdir)' # test to see if srcdir already configured if test -f $srcdir/config.status; then as_fn_error $? "source directory already configured; run \"make distclean\" there first" "$LINENO" 5 fi fi # test whether we have cygpath if test -z "$CYGPATH_W"; then if (cygpath --version) >/dev/null 2>/dev/null; then CYGPATH_W='cygpath -w' else CYGPATH_W=echo fi fi # Define the identity of the package. PACKAGE='libpainter' VERSION='0.1.1' cat >>confdefs.h <<_ACEOF #define PACKAGE "$PACKAGE" _ACEOF cat >>confdefs.h <<_ACEOF #define VERSION "$VERSION" _ACEOF # Some tools Automake needs. ACLOCAL=${ACLOCAL-"${am_missing_run}aclocal-${am__api_version}"} AUTOCONF=${AUTOCONF-"${am_missing_run}autoconf"} AUTOMAKE=${AUTOMAKE-"${am_missing_run}automake-${am__api_version}"} AUTOHEADER=${AUTOHEADER-"${am_missing_run}autoheader"} MAKEINFO=${MAKEINFO-"${am_missing_run}makeinfo"} # For better backward compatibility. To be removed once Automake 1.9.x # dies out for good. For more background, see: # # mkdir_p='$(MKDIR_P)' # We need awk for the "check" target (and possibly the TAP driver). The # system "awk" is bad on some platforms. # Always define AMTAR for backward compatibility. Yes, it's still used # in the wild :-( We should find a proper way to deprecate it ... AMTAR='$${TAR-tar}' # We'll loop over all known methods to create a tar archive until one works. _am_tools='gnutar pax cpio none' am__tar='$${TAR-tar} chof - "$$tardir"' am__untar='$${TAR-tar} xf -' # POSIX will say in a future version that running "rm -f" with no argument # is OK; and we want to be able to make that assumption in our Makefile # recipes. So use an aggressive probe to check that the usage we want is # actually supported "in the wild" to an acceptable degree. # See automake bug#10828. # To make any issue more visible, cause the running configure to be aborted # by default if the 'rm' program in use doesn't match our expectations; the # user can still override this though. if rm -f && rm -fr && rm -rf; then : OK; else cat >&2 <<'END' Oops! Your 'rm' program seems unable to run without file operands specified on the command line, even when the '-f' option is present. This is contrary to the behaviour of most rm programs out there, and not conforming with the upcoming POSIX standard: Please tell bug-automake@gnu.org about your system, including the value of your $PATH and any error possibly output before this message. This can help us improve future automake versions. END if test x"$ACCEPT_INFERIOR_RM_PROGRAM" = x"yes"; then echo 'Configuration will proceed anyway, since you have set the' >&2 echo 'ACCEPT_INFERIOR_RM_PROGRAM variable to "yes"' >&2 echo >&2 else cat >&2 <<'END' Aborting the configuration process, to ensure you take notice of the issue. You can download and install GNU coreutils to get an 'rm' implementation that behaves properly: . If you want to complete the configuration process using your problematic 'rm' anyway, export the environment variable ACCEPT_INFERIOR_RM_PROGRAM to "yes", and re-run configure. END as_fn_error $? "Your 'rm' program is bad, sorry." "$LINENO" 5 fi fi ac_ext=c ac_cpp='$CPP $CPPFLAGS' ac_compile='$CC -c $CFLAGS $CPPFLAGS conftest.$ac_ext >&5' ac_link='$CC -o conftest$ac_exeext $CFLAGS $CPPFLAGS $LDFLAGS conftest.$ac_ext $LIBS >&5' ac_compiler_gnu=$ac_cv_c_compiler_gnu if test -n "$ac_tool_prefix"; then # Extract the first word of "${ac_tool_prefix}gcc", so it can be a program name with args. set dummy ${ac_tool_prefix}gcc; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } if ${ac_cv_prog_CC+:} false; then : $as_echo_n "(cached) " >&6 else if test -n "$CC"; then ac_cv_prog_CC="$CC" # Let the user override the test. else as_save_IFS=$IFS; IFS=$PATH_SEPARATOR for as_dir in $PATH do IFS=$as_save_IFS test -z "$as_dir" && as_dir=. for ac_exec_ext in '' $ac_executable_extensions; do if as_fn_executable_p "$as_dir/$ac_word$ac_exec_ext"; then ac_cv_prog_CC="${ac_tool_prefix}gcc" $as_echo "$as_me:${as_lineno-$LINENO}: found $as_dir/$ac_word$ac_exec_ext" >&5 break 2 fi done done IFS=$as_save_IFS fi fi CC=$ac_cv_prog_CC if test -n "$CC"; then { $as_echo "$as_me:${as_lineno-$LINENO}: result: $CC" >&5 $as_echo "$CC" >&6; } else { $as_echo "$as_me:${as_lineno-$LINENO}: result: no" >&5 $as_echo "no" >&6; } fi fi if test -z "$ac_cv_prog_CC"; then ac_ct_CC=$CC # Extract the first word of "gcc", so it can be a program name with args. set dummy gcc; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } if ${ac_cv_prog_ac_ct_CC+:} false; then : $as_echo_n "(cached) " >&6 else if test -n "$ac_ct_CC"; then ac_cv_prog_ac_ct_CC="$ac_ct_CC" # Let the user override the test. else as_save_IFS=$IFS; IFS=$PATH_SEPARATOR for as_dir in $PATH do IFS=$as_save_IFS test -z "$as_dir" && as_dir=. for ac_exec_ext in '' $ac_executable_extensions; do if as_fn_executable_p "$as_dir/$ac_word$ac_exec_ext"; then ac_cv_prog_ac_ct_CC="gcc" $as_echo "$as_me:${as_lineno-$LINENO}: found $as_dir/$ac_word$ac_exec_ext" >&5 break 2 fi done done IFS=$as_save_IFS fi fi ac_ct_CC=$ac_cv_prog_ac_ct_CC if test -n "$ac_ct_CC"; then { $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_ct_CC" >&5 $as_echo "$ac_ct_CC" >&6; } else { $as_echo "$as_me:${as_lineno-$LINENO}: result: no" >&5 $as_echo "no" >&6; } fi if test "x$ac_ct_CC" = x; then CC="" else case $cross_compiling:$ac_tool_warned in yes:) { $as_echo "$as_me:${as_lineno-$LINENO}: WARNING: using cross tools not prefixed with host triplet" >&5 $as_echo "$as_me: WARNING: using cross tools not prefixed with host triplet" >&2;} ac_tool_warned=yes ;; esac CC=$ac_ct_CC fi else CC="$ac_cv_prog_CC" fi if test -z "$CC"; then if test -n "$ac_tool_prefix"; then # Extract the first word of "${ac_tool_prefix}cc", so it can be a program name with args. set dummy ${ac_tool_prefix}cc; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } if ${ac_cv_prog_CC+:} false; then : $as_echo_n "(cached) " >&6 else if test -n "$CC"; then ac_cv_prog_CC="$CC" # Let the user override the test. else as_save_IFS=$IFS; IFS=$PATH_SEPARATOR for as_dir in $PATH do IFS=$as_save_IFS test -z "$as_dir" && as_dir=. for ac_exec_ext in '' $ac_executable_extensions; do if as_fn_executable_p "$as_dir/$ac_word$ac_exec_ext"; then ac_cv_prog_CC="${ac_tool_prefix}cc" $as_echo "$as_me:${as_lineno-$LINENO}: found $as_dir/$ac_word$ac_exec_ext" >&5 break 2 fi done done IFS=$as_save_IFS fi fi CC=$ac_cv_prog_CC if test -n "$CC"; then { $as_echo "$as_me:${as_lineno-$LINENO}: result: $CC" >&5 $as_echo "$CC" >&6; } else { $as_echo "$as_me:${as_lineno-$LINENO}: result: no" >&5 $as_echo "no" >&6; } fi fi fi if test -z "$CC"; then # Extract the first word of "cc", so it can be a program name with args. set dummy cc; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } if ${ac_cv_prog_CC+:} false; then : $as_echo_n "(cached) " >&6 else if test -n "$CC"; then ac_cv_prog_CC="$CC" # Let the user override the test. else ac_prog_rejected=no as_save_IFS=$IFS; IFS=$PATH_SEPARATOR for as_dir in $PATH do IFS=$as_save_IFS test -z "$as_dir" && as_dir=. for ac_exec_ext in '' $ac_executable_extensions; do if as_fn_executable_p "$as_dir/$ac_word$ac_exec_ext"; then if test "$as_dir/$ac_word$ac_exec_ext" = "/usr/ucb/cc"; then ac_prog_rejected=yes continue fi ac_cv_prog_CC="cc" $as_echo "$as_me:${as_lineno-$LINENO}: found $as_dir/$ac_word$ac_exec_ext" >&5 break 2 fi done done IFS=$as_save_IFS if test $ac_prog_rejected = yes; then # We found a bogon in the path, so make sure we never use it. set dummy $ac_cv_prog_CC shift if test $# != 0; then # We chose a different compiler from the bogus one. # However, it has the same basename, so the bogon will be chosen # first if we set CC to just the basename; use the full file name. shift ac_cv_prog_CC="$as_dir/$ac_word${1+' '}$@" fi fi fi fi CC=$ac_cv_prog_CC if test -n "$CC"; then { $as_echo "$as_me:${as_lineno-$LINENO}: result: $CC" >&5 $as_echo "$CC" >&6; } else { $as_echo "$as_me:${as_lineno-$LINENO}: result: no" >&5 $as_echo "no" >&6; } fi fi if test -z "$CC"; then if test -n "$ac_tool_prefix"; then for ac_prog in cl.exe do # Extract the first word of "$ac_tool_prefix$ac_prog", so it can be a program name with args. set dummy $ac_tool_prefix$ac_prog; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } if ${ac_cv_prog_CC+:} false; then : $as_echo_n "(cached) " >&6 else if test -n "$CC"; then ac_cv_prog_CC="$CC" # Let the user override the test. else as_save_IFS=$IFS; IFS=$PATH_SEPARATOR for as_dir in $PATH do IFS=$as_save_IFS test -z "$as_dir" && as_dir=. for ac_exec_ext in '' $ac_executable_extensions; do if as_fn_executable_p "$as_dir/$ac_word$ac_exec_ext"; then ac_cv_prog_CC="$ac_tool_prefix$ac_prog" $as_echo "$as_me:${as_lineno-$LINENO}: found $as_dir/$ac_word$ac_exec_ext" >&5 break 2 fi done done IFS=$as_save_IFS fi fi CC=$ac_cv_prog_CC if test -n "$CC"; then { $as_echo "$as_me:${as_lineno-$LINENO}: result: $CC" >&5 $as_echo "$CC" >&6; } else { $as_echo "$as_me:${as_lineno-$LINENO}: result: no" >&5 $as_echo "no" >&6; } fi test -n "$CC" && break done fi if test -z "$CC"; then ac_ct_CC=$CC for ac_prog in cl.exe do # Extract the first word of "$ac_prog", so it can be a program name with args. set dummy $ac_prog; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } if ${ac_cv_prog_ac_ct_CC+:} false; then : $as_echo_n "(cached) " >&6 else if test -n "$ac_ct_CC"; then ac_cv_prog_ac_ct_CC="$ac_ct_CC" # Let the user override the test. else as_save_IFS=$IFS; IFS=$PATH_SEPARATOR for as_dir in $PATH do IFS=$as_save_IFS test -z "$as_dir" && as_dir=. for ac_exec_ext in '' $ac_executable_extensions; do if as_fn_executable_p "$as_dir/$ac_word$ac_exec_ext"; then ac_cv_prog_ac_ct_CC="$ac_prog" $as_echo "$as_me:${as_lineno-$LINENO}: found $as_dir/$ac_word$ac_exec_ext" >&5 break 2 fi done done IFS=$as_save_IFS fi fi ac_ct_CC=$ac_cv_prog_ac_ct_CC if test -n "$ac_ct_CC"; then { $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_ct_CC" >&5 $as_echo "$ac_ct_CC" >&6; } else { $as_echo "$as_me:${as_lineno-$LINENO}: result: no" >&5 $as_echo "no" >&6; } fi test -n "$ac_ct_CC" && break done if test "x$ac_ct_CC" = x; then CC="" else case $cross_compiling:$ac_tool_warned in yes:) { $as_echo "$as_me:${as_lineno-$LINENO}: WARNING: using cross tools not prefixed with host triplet" >&5 $as_echo "$as_me: WARNING: using cross tools not prefixed with host triplet" >&2;} ac_tool_warned=yes ;; esac CC=$ac_ct_CC fi fi fi test -z "$CC" && { { $as_echo "$as_me:${as_lineno-$LINENO}: error: in \`$ac_pwd':" >&5 $as_echo "$as_me: error: in \`$ac_pwd':" >&2;} as_fn_error $? "no acceptable C compiler found in \$PATH See \`config.log' for more details" "$LINENO" 5; } # Provide some information about the compiler. $as_echo "$as_me:${as_lineno-$LINENO}: checking for C compiler version" >&5 set X $ac_compile ac_compiler=$2 for ac_option in --version -v -V -qversion; do { { ac_try="$ac_compiler $ac_option >&5" case "(($ac_try" in *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; *) ac_try_echo=$ac_try;; esac eval ac_try_echo="\"\$as_me:${as_lineno-$LINENO}: $ac_try_echo\"" $as_echo "$ac_try_echo"; } >&5 (eval "$ac_compiler $ac_option >&5") 2>conftest.err ac_status=$? if test -s conftest.err; then sed '10a\ ... rest of stderr output deleted ... 10q' conftest.err >conftest.er1 cat conftest.er1 >&5 fi rm -f conftest.er1 conftest.err $as_echo "$as_me:${as_lineno-$LINENO}: \$? = $ac_status" >&5 test $ac_status = 0; } done cat confdefs.h - <<_ACEOF >conftest.$ac_ext /* end confdefs.h. */ int main () { ; return 0; } _ACEOF ac_clean_files_save=$ac_clean_files ac_clean_files="$ac_clean_files a.out a.out.dSYM a.exe b.out" # Try to create an executable without -o first, disregard a.out. # It will help us diagnose broken compilers, and finding out an intuition # of exeext. { $as_echo "$as_me:${as_lineno-$LINENO}: checking whether the C compiler works" >&5 $as_echo_n "checking whether the C compiler works... " >&6; } ac_link_default=`$as_echo "$ac_link" | sed 's/ -o *conftest[^ ]*//'` # The possible output files: ac_files="a.out conftest.exe conftest a.exe a_out.exe b.out conftest.*" ac_rmfiles= for ac_file in $ac_files do case $ac_file in *.$ac_ext | *.xcoff | *.tds | *.d | *.pdb | *.xSYM | *.bb | *.bbg | *.map | *.inf | *.dSYM | *.o | *.obj ) ;; * ) ac_rmfiles="$ac_rmfiles $ac_file";; esac done rm -f $ac_rmfiles if { { ac_try="$ac_link_default" case "(($ac_try" in *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; *) ac_try_echo=$ac_try;; esac eval ac_try_echo="\"\$as_me:${as_lineno-$LINENO}: $ac_try_echo\"" $as_echo "$ac_try_echo"; } >&5 (eval "$ac_link_default") 2>&5 ac_status=$? $as_echo "$as_me:${as_lineno-$LINENO}: \$? = $ac_status" >&5 test $ac_status = 0; }; then : # Autoconf-2.13 could set the ac_cv_exeext variable to `no'. # So ignore a value of `no', otherwise this would lead to `EXEEXT = no' # in a Makefile. We should not override ac_cv_exeext if it was cached, # so that the user can short-circuit this test for compilers unknown to # Autoconf. for ac_file in $ac_files '' do test -f "$ac_file" || continue case $ac_file in *.$ac_ext | *.xcoff | *.tds | *.d | *.pdb | *.xSYM | *.bb | *.bbg | *.map | *.inf | *.dSYM | *.o | *.obj ) ;; [ab].out ) # We found the default executable, but exeext='' is most # certainly right. break;; *.* ) if test "${ac_cv_exeext+set}" = set && test "$ac_cv_exeext" != no; then :; else ac_cv_exeext=`expr "$ac_file" : '[^.]*\(\..*\)'` fi # We set ac_cv_exeext here because the later test for it is not # safe: cross compilers may not add the suffix if given an `-o' # argument, so we may need to know it at that point already. # Even if this section looks crufty: it has the advantage of # actually working. break;; * ) break;; esac done test "$ac_cv_exeext" = no && ac_cv_exeext= else ac_file='' fi if test -z "$ac_file"; then : { $as_echo "$as_me:${as_lineno-$LINENO}: result: no" >&5 $as_echo "no" >&6; } $as_echo "$as_me: failed program was:" >&5 sed 's/^/| /' conftest.$ac_ext >&5 { { $as_echo "$as_me:${as_lineno-$LINENO}: error: in \`$ac_pwd':" >&5 $as_echo "$as_me: error: in \`$ac_pwd':" >&2;} as_fn_error 77 "C compiler cannot create executables See \`config.log' for more details" "$LINENO" 5; } else { $as_echo "$as_me:${as_lineno-$LINENO}: result: yes" >&5 $as_echo "yes" >&6; } fi { $as_echo "$as_me:${as_lineno-$LINENO}: checking for C compiler default output file name" >&5 $as_echo_n "checking for C compiler default output file name... " >&6; } { $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_file" >&5 $as_echo "$ac_file" >&6; } ac_exeext=$ac_cv_exeext rm -f -r a.out a.out.dSYM a.exe conftest$ac_cv_exeext b.out ac_clean_files=$ac_clean_files_save { $as_echo "$as_me:${as_lineno-$LINENO}: checking for suffix of executables" >&5 $as_echo_n "checking for suffix of executables... " >&6; } if { { ac_try="$ac_link" case "(($ac_try" in *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; *) ac_try_echo=$ac_try;; esac eval ac_try_echo="\"\$as_me:${as_lineno-$LINENO}: $ac_try_echo\"" $as_echo "$ac_try_echo"; } >&5 (eval "$ac_link") 2>&5 ac_status=$? $as_echo "$as_me:${as_lineno-$LINENO}: \$? = $ac_status" >&5 test $ac_status = 0; }; then : # If both `conftest.exe' and `conftest' are `present' (well, observable) # catch `conftest.exe'. For instance with Cygwin, `ls conftest' will # work properly (i.e., refer to `conftest.exe'), while it won't with # `rm'. for ac_file in conftest.exe conftest conftest.*; do test -f "$ac_file" || continue case $ac_file in *.$ac_ext | *.xcoff | *.tds | *.d | *.pdb | *.xSYM | *.bb | *.bbg | *.map | *.inf | *.dSYM | *.o | *.obj ) ;; *.* ) ac_cv_exeext=`expr "$ac_file" : '[^.]*\(\..*\)'` break;; * ) break;; esac done else { { $as_echo "$as_me:${as_lineno-$LINENO}: error: in \`$ac_pwd':" >&5 $as_echo "$as_me: error: in \`$ac_pwd':" >&2;} as_fn_error $? "cannot compute suffix of executables: cannot compile and link See \`config.log' for more details" "$LINENO" 5; } fi rm -f conftest conftest$ac_cv_exeext { $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_cv_exeext" >&5 $as_echo "$ac_cv_exeext" >&6; } rm -f conftest.$ac_ext EXEEXT=$ac_cv_exeext ac_exeext=$EXEEXT cat confdefs.h - <<_ACEOF >conftest.$ac_ext /* end confdefs.h. */ #include int main () { FILE *f = fopen ("conftest.out", "w"); return ferror (f) || fclose (f) != 0; ; return 0; } _ACEOF ac_clean_files="$ac_clean_files conftest.out" # Check that the compiler produces executables we can run. If not, either # the compiler is broken, or we cross compile. { $as_echo "$as_me:${as_lineno-$LINENO}: checking whether we are cross compiling" >&5 $as_echo_n "checking whether we are cross compiling... " >&6; } if test "$cross_compiling" != yes; then { { ac_try="$ac_link" case "(($ac_try" in *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; *) ac_try_echo=$ac_try;; esac eval ac_try_echo="\"\$as_me:${as_lineno-$LINENO}: $ac_try_echo\"" $as_echo "$ac_try_echo"; } >&5 (eval "$ac_link") 2>&5 ac_status=$? $as_echo "$as_me:${as_lineno-$LINENO}: \$? = $ac_status" >&5 test $ac_status = 0; } if { ac_try='./conftest$ac_cv_exeext' { { case "(($ac_try" in *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; *) ac_try_echo=$ac_try;; esac eval ac_try_echo="\"\$as_me:${as_lineno-$LINENO}: $ac_try_echo\"" $as_echo "$ac_try_echo"; } >&5 (eval "$ac_try") 2>&5 ac_status=$? $as_echo "$as_me:${as_lineno-$LINENO}: \$? = $ac_status" >&5 test $ac_status = 0; }; }; then cross_compiling=no else if test "$cross_compiling" = maybe; then cross_compiling=yes else { { $as_echo "$as_me:${as_lineno-$LINENO}: error: in \`$ac_pwd':" >&5 $as_echo "$as_me: error: in \`$ac_pwd':" >&2;} as_fn_error $? "cannot run C compiled programs. If you meant to cross compile, use \`--host'. See \`config.log' for more details" "$LINENO" 5; } fi fi fi { $as_echo "$as_me:${as_lineno-$LINENO}: result: $cross_compiling" >&5 $as_echo "$cross_compiling" >&6; } rm -f conftest.$ac_ext conftest$ac_cv_exeext conftest.out ac_clean_files=$ac_clean_files_save { $as_echo "$as_me:${as_lineno-$LINENO}: checking for suffix of object files" >&5 $as_echo_n "checking for suffix of object files... " >&6; } if ${ac_cv_objext+:} false; then : $as_echo_n "(cached) " >&6 else cat confdefs.h - <<_ACEOF >conftest.$ac_ext /* end confdefs.h. */ int main () { ; return 0; } _ACEOF rm -f conftest.o conftest.obj if { { ac_try="$ac_compile" case "(($ac_try" in *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; *) ac_try_echo=$ac_try;; esac eval ac_try_echo="\"\$as_me:${as_lineno-$LINENO}: $ac_try_echo\"" $as_echo "$ac_try_echo"; } >&5 (eval "$ac_compile") 2>&5 ac_status=$? $as_echo "$as_me:${as_lineno-$LINENO}: \$? = $ac_status" >&5 test $ac_status = 0; }; then : for ac_file in conftest.o conftest.obj conftest.*; do test -f "$ac_file" || continue; case $ac_file in *.$ac_ext | *.xcoff | *.tds | *.d | *.pdb | *.xSYM | *.bb | *.bbg | *.map | *.inf | *.dSYM ) ;; *) ac_cv_objext=`expr "$ac_file" : '.*\.\(.*\)'` break;; esac done else $as_echo "$as_me: failed program was:" >&5 sed 's/^/| /' conftest.$ac_ext >&5 { { $as_echo "$as_me:${as_lineno-$LINENO}: error: in \`$ac_pwd':" >&5 $as_echo "$as_me: error: in \`$ac_pwd':" >&2;} as_fn_error $? "cannot compute suffix of object files: cannot compile See \`config.log' for more details" "$LINENO" 5; } fi rm -f conftest.$ac_cv_objext conftest.$ac_ext fi { $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_cv_objext" >&5 $as_echo "$ac_cv_objext" >&6; } OBJEXT=$ac_cv_objext ac_objext=$OBJEXT { $as_echo "$as_me:${as_lineno-$LINENO}: checking whether we are using the GNU C compiler" >&5 $as_echo_n "checking whether we are using the GNU C compiler... " >&6; } if ${ac_cv_c_compiler_gnu+:} false; then : $as_echo_n "(cached) " >&6 else cat confdefs.h - <<_ACEOF >conftest.$ac_ext /* end confdefs.h. */ int main () { #ifndef __GNUC__ choke me #endif ; return 0; } _ACEOF if ac_fn_c_try_compile "$LINENO"; then : ac_compiler_gnu=yes else ac_compiler_gnu=no fi rm -f core conftest.err conftest.$ac_objext conftest.$ac_ext ac_cv_c_compiler_gnu=$ac_compiler_gnu fi { $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_cv_c_compiler_gnu" >&5 $as_echo "$ac_cv_c_compiler_gnu" >&6; } if test $ac_compiler_gnu = yes; then GCC=yes else GCC= fi ac_test_CFLAGS=${CFLAGS+set} ac_save_CFLAGS=$CFLAGS { $as_echo "$as_me:${as_lineno-$LINENO}: checking whether $CC accepts -g" >&5 $as_echo_n "checking whether $CC accepts -g... " >&6; } if ${ac_cv_prog_cc_g+:} false; then : $as_echo_n "(cached) " >&6 else ac_save_c_werror_flag=$ac_c_werror_flag ac_c_werror_flag=yes ac_cv_prog_cc_g=no CFLAGS="-g" cat confdefs.h - <<_ACEOF >conftest.$ac_ext /* end confdefs.h. */ int main () { ; return 0; } _ACEOF if ac_fn_c_try_compile "$LINENO"; then : ac_cv_prog_cc_g=yes else CFLAGS="" cat confdefs.h - <<_ACEOF >conftest.$ac_ext /* end confdefs.h. */ int main () { ; return 0; } _ACEOF if ac_fn_c_try_compile "$LINENO"; then : else ac_c_werror_flag=$ac_save_c_werror_flag CFLAGS="-g" cat confdefs.h - <<_ACEOF >conftest.$ac_ext /* end confdefs.h. */ int main () { ; return 0; } _ACEOF if ac_fn_c_try_compile "$LINENO"; then : ac_cv_prog_cc_g=yes fi rm -f core conftest.err conftest.$ac_objext conftest.$ac_ext fi rm -f core conftest.err conftest.$ac_objext conftest.$ac_ext fi rm -f core conftest.err conftest.$ac_objext conftest.$ac_ext ac_c_werror_flag=$ac_save_c_werror_flag fi { $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_cv_prog_cc_g" >&5 $as_echo "$ac_cv_prog_cc_g" >&6; } if test "$ac_test_CFLAGS" = set; then CFLAGS=$ac_save_CFLAGS elif test $ac_cv_prog_cc_g = yes; then if test "$GCC" = yes; then CFLAGS="-g -O2" else CFLAGS="-g" fi else if test "$GCC" = yes; then CFLAGS="-O2" else CFLAGS= fi fi { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $CC option to accept ISO C89" >&5 $as_echo_n "checking for $CC option to accept ISO C89... " >&6; } if ${ac_cv_prog_cc_c89+:} false; then : $as_echo_n "(cached) " >&6 else ac_cv_prog_cc_c89=no ac_save_CC=$CC cat confdefs.h - <<_ACEOF >conftest.$ac_ext /* end confdefs.h. */ #include #include struct stat; /* Most of the following tests are stolen from RCS 5.7's src/conf.sh. */ struct buf { int x; }; FILE * (*rcsopen) (struct buf *, struct stat *, int); static char *e (p, i) char **p; int i; { return p[i]; } static char *f (char * (*g) (char **, int), char **p, ...) { char *s; va_list v; va_start (v,p); s = g (p, va_arg (v,int)); va_end (v); return s; } /* OSF 4.0 Compaq cc is some sort of almost-ANSI by default. It has function prototypes and stuff, but not '\xHH' hex character constants. These don't provoke an error unfortunately, instead are silently treated as 'x'. The following induces an error, until -std is added to get proper ANSI mode. Curiously '\x00'!='x' always comes out true, for an array size at least. It's necessary to write '\x00'==0 to get something that's true only with -std. */ int osf4_cc_array ['\x00' == 0 ? 1 : -1]; /* IBM C 6 for AIX is almost-ANSI by default, but it replaces macro parameters inside strings and character constants. */ #define FOO(x) 'x' int xlc6_cc_array[FOO(a) == 'x' ? 1 : -1]; int test (int i, double x); struct s1 {int (*f) (int a);}; struct s2 {int (*f) (double a);}; int pairnames (int, char **, FILE *(*)(struct buf *, struct stat *, int), int, int); int argc; char **argv; int main () { return f (e, argv, 0) != argv[0] || f (e, argv, 1) != argv[1]; ; return 0; } _ACEOF for ac_arg in '' -qlanglvl=extc89 -qlanglvl=ansi -std \ -Ae "-Aa -D_HPUX_SOURCE" "-Xc -D__EXTENSIONS__" do CC="$ac_save_CC $ac_arg" if ac_fn_c_try_compile "$LINENO"; then : ac_cv_prog_cc_c89=$ac_arg fi rm -f core conftest.err conftest.$ac_objext test "x$ac_cv_prog_cc_c89" != "xno" && break done rm -f conftest.$ac_ext CC=$ac_save_CC fi # AC_CACHE_VAL case "x$ac_cv_prog_cc_c89" in x) { $as_echo "$as_me:${as_lineno-$LINENO}: result: none needed" >&5 $as_echo "none needed" >&6; } ;; xno) { $as_echo "$as_me:${as_lineno-$LINENO}: result: unsupported" >&5 $as_echo "unsupported" >&6; } ;; *) CC="$CC $ac_cv_prog_cc_c89" { $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_cv_prog_cc_c89" >&5 $as_echo "$ac_cv_prog_cc_c89" >&6; } ;; esac if test "x$ac_cv_prog_cc_c89" != xno; then : fi ac_ext=c ac_cpp='$CPP $CPPFLAGS' ac_compile='$CC -c $CFLAGS $CPPFLAGS conftest.$ac_ext >&5' ac_link='$CC -o conftest$ac_exeext $CFLAGS $CPPFLAGS $LDFLAGS conftest.$ac_ext $LIBS >&5' ac_compiler_gnu=$ac_cv_c_compiler_gnu ac_ext=c ac_cpp='$CPP $CPPFLAGS' ac_compile='$CC -c $CFLAGS $CPPFLAGS conftest.$ac_ext >&5' ac_link='$CC -o conftest$ac_exeext $CFLAGS $CPPFLAGS $LDFLAGS conftest.$ac_ext $LIBS >&5' ac_compiler_gnu=$ac_cv_c_compiler_gnu { $as_echo "$as_me:${as_lineno-$LINENO}: checking whether $CC understands -c and -o together" >&5 $as_echo_n "checking whether $CC understands -c and -o together... " >&6; } if ${am_cv_prog_cc_c_o+:} false; then : $as_echo_n "(cached) " >&6 else cat confdefs.h - <<_ACEOF >conftest.$ac_ext /* end confdefs.h. */ int main () { ; return 0; } _ACEOF # Make sure it works both with $CC and with simple cc. # Following AC_PROG_CC_C_O, we do the test twice because some # compilers refuse to overwrite an existing .o file with -o, # though they will create one. am_cv_prog_cc_c_o=yes for am_i in 1 2; do if { echo "$as_me:$LINENO: $CC -c conftest.$ac_ext -o conftest2.$ac_objext" >&5 ($CC -c conftest.$ac_ext -o conftest2.$ac_objext) >&5 2>&5 ac_status=$? echo "$as_me:$LINENO: \$? = $ac_status" >&5 (exit $ac_status); } \ && test -f conftest2.$ac_objext; then : OK else am_cv_prog_cc_c_o=no break fi done rm -f core conftest* unset am_i fi { $as_echo "$as_me:${as_lineno-$LINENO}: result: $am_cv_prog_cc_c_o" >&5 $as_echo "$am_cv_prog_cc_c_o" >&6; } if test "$am_cv_prog_cc_c_o" != yes; then # Losing compiler, so override with the script. # FIXME: It is wrong to rewrite CC. # But if we don't then we get into trouble of one sort or another. # A longer-term fix would be to have automake use am__CC in this case, # and then we could set am__CC="\$(top_srcdir)/compile \$(CC)" CC="$am_aux_dir/compile $CC" fi ac_ext=c ac_cpp='$CPP $CPPFLAGS' ac_compile='$CC -c $CFLAGS $CPPFLAGS conftest.$ac_ext >&5' ac_link='$CC -o conftest$ac_exeext $CFLAGS $CPPFLAGS $LDFLAGS conftest.$ac_ext $LIBS >&5' ac_compiler_gnu=$ac_cv_c_compiler_gnu DEPDIR="${am__leading_dot}deps" ac_config_commands="$ac_config_commands depfiles" am_make=${MAKE-make} cat > confinc << 'END' am__doit: @echo this is the am__doit target .PHONY: am__doit END # If we don't find an include directive, just comment out the code. { $as_echo "$as_me:${as_lineno-$LINENO}: checking for style of include used by $am_make" >&5 $as_echo_n "checking for style of include used by $am_make... " >&6; } am__include="#" am__quote= _am_result=none # First try GNU make style include. echo "include confinc" > confmf # Ignore all kinds of additional output from 'make'. case `$am_make -s -f confmf 2> /dev/null` in #( *the\ am__doit\ target*) am__include=include am__quote= _am_result=GNU ;; esac # Now try BSD make style include. if test "$am__include" = "#"; then echo '.include "confinc"' > confmf case `$am_make -s -f confmf 2> /dev/null` in #( *the\ am__doit\ target*) am__include=.include am__quote="\"" _am_result=BSD ;; esac fi { $as_echo "$as_me:${as_lineno-$LINENO}: result: $_am_result" >&5 $as_echo "$_am_result" >&6; } rm -f confinc confmf # Check whether --enable-dependency-tracking was given. if test "${enable_dependency_tracking+set}" = set; then : enableval=$enable_dependency_tracking; fi if test "x$enable_dependency_tracking" != xno; then am_depcomp="$ac_aux_dir/depcomp" AMDEPBACKSLASH='\' am__nodep='_no' fi if test "x$enable_dependency_tracking" != xno; then AMDEP_TRUE= AMDEP_FALSE='#' else AMDEP_TRUE='#' AMDEP_FALSE= fi depcc="$CC" am_compiler_list= { $as_echo "$as_me:${as_lineno-$LINENO}: checking dependency style of $depcc" >&5 $as_echo_n "checking dependency style of $depcc... " >&6; } if ${am_cv_CC_dependencies_compiler_type+:} false; then : $as_echo_n "(cached) " >&6 else if test -z "$AMDEP_TRUE" && test -f "$am_depcomp"; then # We make a subdir and do the tests there. Otherwise we can end up # making bogus files that we don't know about and never remove. For # instance it was reported that on HP-UX the gcc test will end up # making a dummy file named 'D' -- because '-MD' means "put the output # in D". rm -rf conftest.dir mkdir conftest.dir # Copy depcomp to subdir because otherwise we won't find it if we're # using a relative directory. cp "$am_depcomp" conftest.dir cd conftest.dir # We will build objects and dependencies in a subdirectory because # it helps to detect inapplicable dependency modes. For instance # both Tru64's cc and ICC support -MD to output dependencies as a # side effect of compilation, but ICC will put the dependencies in # the current directory while Tru64 will put them in the object # directory. mkdir sub am_cv_CC_dependencies_compiler_type=none if test "$am_compiler_list" = ""; then am_compiler_list=`sed -n 's/^#*\([a-zA-Z0-9]*\))$/\1/p' < ./depcomp` fi am__universal=false case " $depcc " in #( *\ -arch\ *\ -arch\ *) am__universal=true ;; esac for depmode in $am_compiler_list; do # Setup a source with many dependencies, because some compilers # like to wrap large dependency lists on column 80 (with \), and # we should not choose a depcomp mode which is confused by this. # # We need to recreate these files for each test, as the compiler may # overwrite some of them when testing with obscure command lines. # This happens at least with the AIX C compiler. : > sub/conftest.c for i in 1 2 3 4 5 6; do echo '#include "conftst'$i'.h"' >> sub/conftest.c # Using ": > sub/conftst$i.h" creates only sub/conftst1.h with # Solaris 10 /bin/sh. echo '/* dummy */' > sub/conftst$i.h done echo "${am__include} ${am__quote}sub/conftest.Po${am__quote}" > confmf # We check with '-c' and '-o' for the sake of the "dashmstdout" # mode. It turns out that the SunPro C++ compiler does not properly # handle '-M -o', and we need to detect this. Also, some Intel # versions had trouble with output in subdirs. am__obj=sub/conftest.${OBJEXT-o} am__minus_obj="-o $am__obj" case $depmode in gcc) # This depmode causes a compiler race in universal mode. test "$am__universal" = false || continue ;; nosideeffect) # After this tag, mechanisms are not by side-effect, so they'll # only be used when explicitly requested. if test "x$enable_dependency_tracking" = xyes; then continue else break fi ;; msvc7 | msvc7msys | msvisualcpp | msvcmsys) # This compiler won't grok '-c -o', but also, the minuso test has # not run yet. These depmodes are late enough in the game, and # so weak that their functioning should not be impacted. am__obj=conftest.${OBJEXT-o} am__minus_obj= ;; none) break ;; esac if depmode=$depmode \ source=sub/conftest.c object=$am__obj \ depfile=sub/conftest.Po tmpdepfile=sub/conftest.TPo \ $SHELL ./depcomp $depcc -c $am__minus_obj sub/conftest.c \ >/dev/null 2>conftest.err && grep sub/conftst1.h sub/conftest.Po > /dev/null 2>&1 && grep sub/conftst6.h sub/conftest.Po > /dev/null 2>&1 && grep $am__obj sub/conftest.Po > /dev/null 2>&1 && ${MAKE-make} -s -f confmf > /dev/null 2>&1; then # icc doesn't choke on unknown options, it will just issue warnings # or remarks (even with -Werror). So we grep stderr for any message # that says an option was ignored or not supported. # When given -MP, icc 7.0 and 7.1 complain thusly: # icc: Command line warning: ignoring option '-M'; no argument required # The diagnosis changed in icc 8.0: # icc: Command line remark: option '-MP' not supported if (grep 'ignoring option' conftest.err || grep 'not supported' conftest.err) >/dev/null 2>&1; then :; else am_cv_CC_dependencies_compiler_type=$depmode break fi fi done cd .. rm -rf conftest.dir else am_cv_CC_dependencies_compiler_type=none fi fi { $as_echo "$as_me:${as_lineno-$LINENO}: result: $am_cv_CC_dependencies_compiler_type" >&5 $as_echo "$am_cv_CC_dependencies_compiler_type" >&6; } CCDEPMODE=depmode=$am_cv_CC_dependencies_compiler_type if test "x$enable_dependency_tracking" != xno \ && test "$am_cv_CC_dependencies_compiler_type" = gcc3; then am__fastdepCC_TRUE= am__fastdepCC_FALSE='#' else am__fastdepCC_TRUE='#' am__fastdepCC_FALSE= fi { $as_echo "$as_me:${as_lineno-$LINENO}: checking for an ANSI C-conforming const" >&5 $as_echo_n "checking for an ANSI C-conforming const... " >&6; } if ${ac_cv_c_const+:} false; then : $as_echo_n "(cached) " >&6 else cat confdefs.h - <<_ACEOF >conftest.$ac_ext /* end confdefs.h. */ int main () { #ifndef __cplusplus /* Ultrix mips cc rejects this sort of thing. */ typedef int charset[2]; const charset cs = { 0, 0 }; /* SunOS 4.1.1 cc rejects this. */ char const *const *pcpcc; char **ppc; /* NEC SVR4.0.2 mips cc rejects this. */ struct point {int x, y;}; static struct point const zero = {0,0}; /* AIX XL C 1.02.0.0 rejects this. It does not let you subtract one const X* pointer from another in an arm of an if-expression whose if-part is not a constant expression */ const char *g = "string"; pcpcc = &g + (g ? g-g : 0); /* HPUX 7.0 cc rejects these. */ ++pcpcc; ppc = (char**) pcpcc; pcpcc = (char const *const *) ppc; { /* SCO 3.2v4 cc rejects this sort of thing. */ char tx; char *t = &tx; char const *s = 0 ? (char *) 0 : (char const *) 0; *t++ = 0; if (s) return 0; } { /* Someone thinks the Sun supposedly-ANSI compiler will reject this. */ int x[] = {25, 17}; const int *foo = &x[0]; ++foo; } { /* Sun SC1.0 ANSI compiler rejects this -- but not the above. */ typedef const int *iptr; iptr p = 0; ++p; } { /* AIX XL C 1.02.0.0 rejects this sort of thing, saying "k.c", line 2.27: 1506-025 (S) Operand must be a modifiable lvalue. */ struct s { int j; const int *ap[3]; } bx; struct s *b = &bx; b->j = 5; } { /* ULTRIX-32 V3.1 (Rev 9) vcc rejects this */ const int foo = 10; if (!foo) return 0; } return !cs[0] && !zero.x; #endif ; return 0; } _ACEOF if ac_fn_c_try_compile "$LINENO"; then : ac_cv_c_const=yes else ac_cv_c_const=no fi rm -f core conftest.err conftest.$ac_objext conftest.$ac_ext fi { $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_cv_c_const" >&5 $as_echo "$ac_cv_c_const" >&6; } if test $ac_cv_c_const = no; then $as_echo "#define const /**/" >>confdefs.h fi case `pwd` in *\ * | *\ *) { $as_echo "$as_me:${as_lineno-$LINENO}: WARNING: Libtool does not cope well with whitespace in \`pwd\`" >&5 $as_echo "$as_me: WARNING: Libtool does not cope well with whitespace in \`pwd\`" >&2;} ;; esac macro_version='2.4.6' macro_revision='2.4.6' ltmain=$ac_aux_dir/ltmain.sh # Make sure we can run config.sub. $SHELL "$ac_aux_dir/config.sub" sun4 >/dev/null 2>&1 || as_fn_error $? "cannot run $SHELL $ac_aux_dir/config.sub" "$LINENO" 5 { $as_echo "$as_me:${as_lineno-$LINENO}: checking build system type" >&5 $as_echo_n "checking build system type... " >&6; } if ${ac_cv_build+:} false; then : $as_echo_n "(cached) " >&6 else ac_build_alias=$build_alias test "x$ac_build_alias" = x && ac_build_alias=`$SHELL "$ac_aux_dir/config.guess"` test "x$ac_build_alias" = x && as_fn_error $? "cannot guess build type; you must specify one" "$LINENO" 5 ac_cv_build=`$SHELL "$ac_aux_dir/config.sub" $ac_build_alias` || as_fn_error $? "$SHELL $ac_aux_dir/config.sub $ac_build_alias failed" "$LINENO" 5 fi { $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_cv_build" >&5 $as_echo "$ac_cv_build" >&6; } case $ac_cv_build in *-*-*) ;; *) as_fn_error $? "invalid value of canonical build" "$LINENO" 5;; esac build=$ac_cv_build ac_save_IFS=$IFS; IFS='-' set x $ac_cv_build shift build_cpu=$1 build_vendor=$2 shift; shift # Remember, the first character of IFS is used to create $*, # except with old shells: build_os=$* IFS=$ac_save_IFS case $build_os in *\ *) build_os=`echo "$build_os" | sed 's/ /-/g'`;; esac { $as_echo "$as_me:${as_lineno-$LINENO}: checking host system type" >&5 $as_echo_n "checking host system type... " >&6; } if ${ac_cv_host+:} false; then : $as_echo_n "(cached) " >&6 else if test "x$host_alias" = x; then ac_cv_host=$ac_cv_build else ac_cv_host=`$SHELL "$ac_aux_dir/config.sub" $host_alias` || as_fn_error $? "$SHELL $ac_aux_dir/config.sub $host_alias failed" "$LINENO" 5 fi fi { $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_cv_host" >&5 $as_echo "$ac_cv_host" >&6; } case $ac_cv_host in *-*-*) ;; *) as_fn_error $? "invalid value of canonical host" "$LINENO" 5;; esac host=$ac_cv_host ac_save_IFS=$IFS; IFS='-' set x $ac_cv_host shift host_cpu=$1 host_vendor=$2 shift; shift # Remember, the first character of IFS is used to create $*, # except with old shells: host_os=$* IFS=$ac_save_IFS case $host_os in *\ *) host_os=`echo "$host_os" | sed 's/ /-/g'`;; esac # Backslashify metacharacters that are still active within # double-quoted strings. sed_quote_subst='s/\(["`$\\]\)/\\\1/g' # Same as above, but do not quote variable references. double_quote_subst='s/\(["`\\]\)/\\\1/g' # Sed substitution to delay expansion of an escaped shell variable in a # double_quote_subst'ed string. delay_variable_subst='s/\\\\\\\\\\\$/\\\\\\$/g' # Sed substitution to delay expansion of an escaped single quote. delay_single_quote_subst='s/'\''/'\'\\\\\\\'\''/g' # Sed substitution to avoid accidental globbing in evaled expressions no_glob_subst='s/\*/\\\*/g' ECHO='\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\' ECHO=$ECHO$ECHO$ECHO$ECHO$ECHO ECHO=$ECHO$ECHO$ECHO$ECHO$ECHO$ECHO { $as_echo "$as_me:${as_lineno-$LINENO}: checking how to print strings" >&5 $as_echo_n "checking how to print strings... " >&6; } # Test print first, because it will be a builtin if present. if test "X`( print -r -- -n ) 2>/dev/null`" = X-n && \ test "X`print -r -- $ECHO 2>/dev/null`" = "X$ECHO"; then ECHO='print -r --' elif test "X`printf %s $ECHO 2>/dev/null`" = "X$ECHO"; then ECHO='printf %s\n' else # Use this function as a fallback that always works. func_fallback_echo () { eval 'cat <<_LTECHO_EOF $1 _LTECHO_EOF' } ECHO='func_fallback_echo' fi # func_echo_all arg... # Invoke $ECHO with all args, space-separated. func_echo_all () { $ECHO "" } case $ECHO in printf*) { $as_echo "$as_me:${as_lineno-$LINENO}: result: printf" >&5 $as_echo "printf" >&6; } ;; print*) { $as_echo "$as_me:${as_lineno-$LINENO}: result: print -r" >&5 $as_echo "print -r" >&6; } ;; *) { $as_echo "$as_me:${as_lineno-$LINENO}: result: cat" >&5 $as_echo "cat" >&6; } ;; esac { $as_echo "$as_me:${as_lineno-$LINENO}: checking for a sed that does not truncate output" >&5 $as_echo_n "checking for a sed that does not truncate output... " >&6; } if ${ac_cv_path_SED+:} false; then : $as_echo_n "(cached) " >&6 else ac_script=s/aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa/bbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbb/ for ac_i in 1 2 3 4 5 6 7; do ac_script="$ac_script$as_nl$ac_script" done echo "$ac_script" 2>/dev/null | sed 99q >conftest.sed { ac_script=; unset ac_script;} if test -z "$SED"; then ac_path_SED_found=false # Loop through the user's path and test for each of PROGNAME-LIST as_save_IFS=$IFS; IFS=$PATH_SEPARATOR for as_dir in $PATH do IFS=$as_save_IFS test -z "$as_dir" && as_dir=. for ac_prog in sed gsed; do for ac_exec_ext in '' $ac_executable_extensions; do ac_path_SED="$as_dir/$ac_prog$ac_exec_ext" as_fn_executable_p "$ac_path_SED" || continue # Check for GNU ac_path_SED and select it if it is found. # Check for GNU $ac_path_SED case `"$ac_path_SED" --version 2>&1` in *GNU*) ac_cv_path_SED="$ac_path_SED" ac_path_SED_found=:;; *) ac_count=0 $as_echo_n 0123456789 >"conftest.in" while : do cat "conftest.in" "conftest.in" >"conftest.tmp" mv "conftest.tmp" "conftest.in" cp "conftest.in" "conftest.nl" $as_echo '' >> "conftest.nl" "$ac_path_SED" -f conftest.sed < "conftest.nl" >"conftest.out" 2>/dev/null || break diff "conftest.out" "conftest.nl" >/dev/null 2>&1 || break as_fn_arith $ac_count + 1 && ac_count=$as_val if test $ac_count -gt ${ac_path_SED_max-0}; then # Best one so far, save it but keep looking for a better one ac_cv_path_SED="$ac_path_SED" ac_path_SED_max=$ac_count fi # 10*(2^10) chars as input seems more than enough test $ac_count -gt 10 && break done rm -f conftest.in conftest.tmp conftest.nl conftest.out;; esac $ac_path_SED_found && break 3 done done done IFS=$as_save_IFS if test -z "$ac_cv_path_SED"; then as_fn_error $? "no acceptable sed could be found in \$PATH" "$LINENO" 5 fi else ac_cv_path_SED=$SED fi fi { $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_cv_path_SED" >&5 $as_echo "$ac_cv_path_SED" >&6; } SED="$ac_cv_path_SED" rm -f conftest.sed test -z "$SED" && SED=sed Xsed="$SED -e 1s/^X//" { $as_echo "$as_me:${as_lineno-$LINENO}: checking for grep that handles long lines and -e" >&5 $as_echo_n "checking for grep that handles long lines and -e... " >&6; } if ${ac_cv_path_GREP+:} false; then : $as_echo_n "(cached) " >&6 else if test -z "$GREP"; then ac_path_GREP_found=false # Loop through the user's path and test for each of PROGNAME-LIST as_save_IFS=$IFS; IFS=$PATH_SEPARATOR for as_dir in $PATH$PATH_SEPARATOR/usr/xpg4/bin do IFS=$as_save_IFS test -z "$as_dir" && as_dir=. for ac_prog in grep ggrep; do for ac_exec_ext in '' $ac_executable_extensions; do ac_path_GREP="$as_dir/$ac_prog$ac_exec_ext" as_fn_executable_p "$ac_path_GREP" || continue # Check for GNU ac_path_GREP and select it if it is found. # Check for GNU $ac_path_GREP case `"$ac_path_GREP" --version 2>&1` in *GNU*) ac_cv_path_GREP="$ac_path_GREP" ac_path_GREP_found=:;; *) ac_count=0 $as_echo_n 0123456789 >"conftest.in" while : do cat "conftest.in" "conftest.in" >"conftest.tmp" mv "conftest.tmp" "conftest.in" cp "conftest.in" "conftest.nl" $as_echo 'GREP' >> "conftest.nl" "$ac_path_GREP" -e 'GREP$' -e '-(cannot match)-' < "conftest.nl" >"conftest.out" 2>/dev/null || break diff "conftest.out" "conftest.nl" >/dev/null 2>&1 || break as_fn_arith $ac_count + 1 && ac_count=$as_val if test $ac_count -gt ${ac_path_GREP_max-0}; then # Best one so far, save it but keep looking for a better one ac_cv_path_GREP="$ac_path_GREP" ac_path_GREP_max=$ac_count fi # 10*(2^10) chars as input seems more than enough test $ac_count -gt 10 && break done rm -f conftest.in conftest.tmp conftest.nl conftest.out;; esac $ac_path_GREP_found && break 3 done done done IFS=$as_save_IFS if test -z "$ac_cv_path_GREP"; then as_fn_error $? "no acceptable grep could be found in $PATH$PATH_SEPARATOR/usr/xpg4/bin" "$LINENO" 5 fi else ac_cv_path_GREP=$GREP fi fi { $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_cv_path_GREP" >&5 $as_echo "$ac_cv_path_GREP" >&6; } GREP="$ac_cv_path_GREP" { $as_echo "$as_me:${as_lineno-$LINENO}: checking for egrep" >&5 $as_echo_n "checking for egrep... " >&6; } if ${ac_cv_path_EGREP+:} false; then : $as_echo_n "(cached) " >&6 else if echo a | $GREP -E '(a|b)' >/dev/null 2>&1 then ac_cv_path_EGREP="$GREP -E" else if test -z "$EGREP"; then ac_path_EGREP_found=false # Loop through the user's path and test for each of PROGNAME-LIST as_save_IFS=$IFS; IFS=$PATH_SEPARATOR for as_dir in $PATH$PATH_SEPARATOR/usr/xpg4/bin do IFS=$as_save_IFS test -z "$as_dir" && as_dir=. for ac_prog in egrep; do for ac_exec_ext in '' $ac_executable_extensions; do ac_path_EGREP="$as_dir/$ac_prog$ac_exec_ext" as_fn_executable_p "$ac_path_EGREP" || continue # Check for GNU ac_path_EGREP and select it if it is found. # Check for GNU $ac_path_EGREP case `"$ac_path_EGREP" --version 2>&1` in *GNU*) ac_cv_path_EGREP="$ac_path_EGREP" ac_path_EGREP_found=:;; *) ac_count=0 $as_echo_n 0123456789 >"conftest.in" while : do cat "conftest.in" "conftest.in" >"conftest.tmp" mv "conftest.tmp" "conftest.in" cp "conftest.in" "conftest.nl" $as_echo 'EGREP' >> "conftest.nl" "$ac_path_EGREP" 'EGREP$' < "conftest.nl" >"conftest.out" 2>/dev/null || break diff "conftest.out" "conftest.nl" >/dev/null 2>&1 || break as_fn_arith $ac_count + 1 && ac_count=$as_val if test $ac_count -gt ${ac_path_EGREP_max-0}; then # Best one so far, save it but keep looking for a better one ac_cv_path_EGREP="$ac_path_EGREP" ac_path_EGREP_max=$ac_count fi # 10*(2^10) chars as input seems more than enough test $ac_count -gt 10 && break done rm -f conftest.in conftest.tmp conftest.nl conftest.out;; esac $ac_path_EGREP_found && break 3 done done done IFS=$as_save_IFS if test -z "$ac_cv_path_EGREP"; then as_fn_error $? "no acceptable egrep could be found in $PATH$PATH_SEPARATOR/usr/xpg4/bin" "$LINENO" 5 fi else ac_cv_path_EGREP=$EGREP fi fi fi { $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_cv_path_EGREP" >&5 $as_echo "$ac_cv_path_EGREP" >&6; } EGREP="$ac_cv_path_EGREP" { $as_echo "$as_me:${as_lineno-$LINENO}: checking for fgrep" >&5 $as_echo_n "checking for fgrep... " >&6; } if ${ac_cv_path_FGREP+:} false; then : $as_echo_n "(cached) " >&6 else if echo 'ab*c' | $GREP -F 'ab*c' >/dev/null 2>&1 then ac_cv_path_FGREP="$GREP -F" else if test -z "$FGREP"; then ac_path_FGREP_found=false # Loop through the user's path and test for each of PROGNAME-LIST as_save_IFS=$IFS; IFS=$PATH_SEPARATOR for as_dir in $PATH$PATH_SEPARATOR/usr/xpg4/bin do IFS=$as_save_IFS test -z "$as_dir" && as_dir=. for ac_prog in fgrep; do for ac_exec_ext in '' $ac_executable_extensions; do ac_path_FGREP="$as_dir/$ac_prog$ac_exec_ext" as_fn_executable_p "$ac_path_FGREP" || continue # Check for GNU ac_path_FGREP and select it if it is found. # Check for GNU $ac_path_FGREP case `"$ac_path_FGREP" --version 2>&1` in *GNU*) ac_cv_path_FGREP="$ac_path_FGREP" ac_path_FGREP_found=:;; *) ac_count=0 $as_echo_n 0123456789 >"conftest.in" while : do cat "conftest.in" "conftest.in" >"conftest.tmp" mv "conftest.tmp" "conftest.in" cp "conftest.in" "conftest.nl" $as_echo 'FGREP' >> "conftest.nl" "$ac_path_FGREP" FGREP < "conftest.nl" >"conftest.out" 2>/dev/null || break diff "conftest.out" "conftest.nl" >/dev/null 2>&1 || break as_fn_arith $ac_count + 1 && ac_count=$as_val if test $ac_count -gt ${ac_path_FGREP_max-0}; then # Best one so far, save it but keep looking for a better one ac_cv_path_FGREP="$ac_path_FGREP" ac_path_FGREP_max=$ac_count fi # 10*(2^10) chars as input seems more than enough test $ac_count -gt 10 && break done rm -f conftest.in conftest.tmp conftest.nl conftest.out;; esac $ac_path_FGREP_found && break 3 done done done IFS=$as_save_IFS if test -z "$ac_cv_path_FGREP"; then as_fn_error $? "no acceptable fgrep could be found in $PATH$PATH_SEPARATOR/usr/xpg4/bin" "$LINENO" 5 fi else ac_cv_path_FGREP=$FGREP fi fi fi { $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_cv_path_FGREP" >&5 $as_echo "$ac_cv_path_FGREP" >&6; } FGREP="$ac_cv_path_FGREP" test -z "$GREP" && GREP=grep # Check whether --with-gnu-ld was given. if test "${with_gnu_ld+set}" = set; then : withval=$with_gnu_ld; test no = "$withval" || with_gnu_ld=yes else with_gnu_ld=no fi ac_prog=ld if test yes = "$GCC"; then # Check if gcc -print-prog-name=ld gives a path. { $as_echo "$as_me:${as_lineno-$LINENO}: checking for ld used by $CC" >&5 $as_echo_n "checking for ld used by $CC... " >&6; } case $host in *-*-mingw*) # gcc leaves a trailing carriage return, which upsets mingw ac_prog=`($CC -print-prog-name=ld) 2>&5 | tr -d '\015'` ;; *) ac_prog=`($CC -print-prog-name=ld) 2>&5` ;; esac case $ac_prog in # Accept absolute paths. [\\/]* | ?:[\\/]*) re_direlt='/[^/][^/]*/\.\./' # Canonicalize the pathname of ld ac_prog=`$ECHO "$ac_prog"| $SED 's%\\\\%/%g'` while $ECHO "$ac_prog" | $GREP "$re_direlt" > /dev/null 2>&1; do ac_prog=`$ECHO $ac_prog| $SED "s%$re_direlt%/%"` done test -z "$LD" && LD=$ac_prog ;; "") # If it fails, then pretend we aren't using GCC. ac_prog=ld ;; *) # If it is relative, then search for the first ld in PATH. with_gnu_ld=unknown ;; esac elif test yes = "$with_gnu_ld"; then { $as_echo "$as_me:${as_lineno-$LINENO}: checking for GNU ld" >&5 $as_echo_n "checking for GNU ld... " >&6; } else { $as_echo "$as_me:${as_lineno-$LINENO}: checking for non-GNU ld" >&5 $as_echo_n "checking for non-GNU ld... " >&6; } fi if ${lt_cv_path_LD+:} false; then : $as_echo_n "(cached) " >&6 else if test -z "$LD"; then lt_save_ifs=$IFS; IFS=$PATH_SEPARATOR for ac_dir in $PATH; do IFS=$lt_save_ifs test -z "$ac_dir" && ac_dir=. if test -f "$ac_dir/$ac_prog" || test -f "$ac_dir/$ac_prog$ac_exeext"; then lt_cv_path_LD=$ac_dir/$ac_prog # Check to see if the program is GNU ld. I'd rather use --version, # but apparently some variants of GNU ld only accept -v. # Break only if it was the GNU/non-GNU ld that we prefer. case `"$lt_cv_path_LD" -v 2>&1 &5 $as_echo "$LD" >&6; } else { $as_echo "$as_me:${as_lineno-$LINENO}: result: no" >&5 $as_echo "no" >&6; } fi test -z "$LD" && as_fn_error $? "no acceptable ld found in \$PATH" "$LINENO" 5 { $as_echo "$as_me:${as_lineno-$LINENO}: checking if the linker ($LD) is GNU ld" >&5 $as_echo_n "checking if the linker ($LD) is GNU ld... " >&6; } if ${lt_cv_prog_gnu_ld+:} false; then : $as_echo_n "(cached) " >&6 else # I'd rather use --version here, but apparently some GNU lds only accept -v. case `$LD -v 2>&1 &5 $as_echo "$lt_cv_prog_gnu_ld" >&6; } with_gnu_ld=$lt_cv_prog_gnu_ld { $as_echo "$as_me:${as_lineno-$LINENO}: checking for BSD- or MS-compatible name lister (nm)" >&5 $as_echo_n "checking for BSD- or MS-compatible name lister (nm)... " >&6; } if ${lt_cv_path_NM+:} false; then : $as_echo_n "(cached) " >&6 else if test -n "$NM"; then # Let the user override the test. lt_cv_path_NM=$NM else lt_nm_to_check=${ac_tool_prefix}nm if test -n "$ac_tool_prefix" && test "$build" = "$host"; then lt_nm_to_check="$lt_nm_to_check nm" fi for lt_tmp_nm in $lt_nm_to_check; do lt_save_ifs=$IFS; IFS=$PATH_SEPARATOR for ac_dir in $PATH /usr/ccs/bin/elf /usr/ccs/bin /usr/ucb /bin; do IFS=$lt_save_ifs test -z "$ac_dir" && ac_dir=. tmp_nm=$ac_dir/$lt_tmp_nm if test -f "$tmp_nm" || test -f "$tmp_nm$ac_exeext"; then # Check to see if the nm accepts a BSD-compat flag. # Adding the 'sed 1q' prevents false positives on HP-UX, which says: # nm: unknown option "B" ignored # Tru64's nm complains that /dev/null is an invalid object file # MSYS converts /dev/null to NUL, MinGW nm treats NUL as empty case $build_os in mingw*) lt_bad_file=conftest.nm/nofile ;; *) lt_bad_file=/dev/null ;; esac case `"$tmp_nm" -B $lt_bad_file 2>&1 | sed '1q'` in *$lt_bad_file* | *'Invalid file or object type'*) lt_cv_path_NM="$tmp_nm -B" break 2 ;; *) case `"$tmp_nm" -p /dev/null 2>&1 | sed '1q'` in */dev/null*) lt_cv_path_NM="$tmp_nm -p" break 2 ;; *) lt_cv_path_NM=${lt_cv_path_NM="$tmp_nm"} # keep the first match, but continue # so that we can try to find one that supports BSD flags ;; esac ;; esac fi done IFS=$lt_save_ifs done : ${lt_cv_path_NM=no} fi fi { $as_echo "$as_me:${as_lineno-$LINENO}: result: $lt_cv_path_NM" >&5 $as_echo "$lt_cv_path_NM" >&6; } if test no != "$lt_cv_path_NM"; then NM=$lt_cv_path_NM else # Didn't find any BSD compatible name lister, look for dumpbin. if test -n "$DUMPBIN"; then : # Let the user override the test. else if test -n "$ac_tool_prefix"; then for ac_prog in dumpbin "link -dump" do # Extract the first word of "$ac_tool_prefix$ac_prog", so it can be a program name with args. set dummy $ac_tool_prefix$ac_prog; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } if ${ac_cv_prog_DUMPBIN+:} false; then : $as_echo_n "(cached) " >&6 else if test -n "$DUMPBIN"; then ac_cv_prog_DUMPBIN="$DUMPBIN" # Let the user override the test. else as_save_IFS=$IFS; IFS=$PATH_SEPARATOR for as_dir in $PATH do IFS=$as_save_IFS test -z "$as_dir" && as_dir=. for ac_exec_ext in '' $ac_executable_extensions; do if as_fn_executable_p "$as_dir/$ac_word$ac_exec_ext"; then ac_cv_prog_DUMPBIN="$ac_tool_prefix$ac_prog" $as_echo "$as_me:${as_lineno-$LINENO}: found $as_dir/$ac_word$ac_exec_ext" >&5 break 2 fi done done IFS=$as_save_IFS fi fi DUMPBIN=$ac_cv_prog_DUMPBIN if test -n "$DUMPBIN"; then { $as_echo "$as_me:${as_lineno-$LINENO}: result: $DUMPBIN" >&5 $as_echo "$DUMPBIN" >&6; } else { $as_echo "$as_me:${as_lineno-$LINENO}: result: no" >&5 $as_echo "no" >&6; } fi test -n "$DUMPBIN" && break done fi if test -z "$DUMPBIN"; then ac_ct_DUMPBIN=$DUMPBIN for ac_prog in dumpbin "link -dump" do # Extract the first word of "$ac_prog", so it can be a program name with args. set dummy $ac_prog; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } if ${ac_cv_prog_ac_ct_DUMPBIN+:} false; then : $as_echo_n "(cached) " >&6 else if test -n "$ac_ct_DUMPBIN"; then ac_cv_prog_ac_ct_DUMPBIN="$ac_ct_DUMPBIN" # Let the user override the test. else as_save_IFS=$IFS; IFS=$PATH_SEPARATOR for as_dir in $PATH do IFS=$as_save_IFS test -z "$as_dir" && as_dir=. for ac_exec_ext in '' $ac_executable_extensions; do if as_fn_executable_p "$as_dir/$ac_word$ac_exec_ext"; then ac_cv_prog_ac_ct_DUMPBIN="$ac_prog" $as_echo "$as_me:${as_lineno-$LINENO}: found $as_dir/$ac_word$ac_exec_ext" >&5 break 2 fi done done IFS=$as_save_IFS fi fi ac_ct_DUMPBIN=$ac_cv_prog_ac_ct_DUMPBIN if test -n "$ac_ct_DUMPBIN"; then { $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_ct_DUMPBIN" >&5 $as_echo "$ac_ct_DUMPBIN" >&6; } else { $as_echo "$as_me:${as_lineno-$LINENO}: result: no" >&5 $as_echo "no" >&6; } fi test -n "$ac_ct_DUMPBIN" && break done if test "x$ac_ct_DUMPBIN" = x; then DUMPBIN=":" else case $cross_compiling:$ac_tool_warned in yes:) { $as_echo "$as_me:${as_lineno-$LINENO}: WARNING: using cross tools not prefixed with host triplet" >&5 $as_echo "$as_me: WARNING: using cross tools not prefixed with host triplet" >&2;} ac_tool_warned=yes ;; esac DUMPBIN=$ac_ct_DUMPBIN fi fi case `$DUMPBIN -symbols -headers /dev/null 2>&1 | sed '1q'` in *COFF*) DUMPBIN="$DUMPBIN -symbols -headers" ;; *) DUMPBIN=: ;; esac fi if test : != "$DUMPBIN"; then NM=$DUMPBIN fi fi test -z "$NM" && NM=nm { $as_echo "$as_me:${as_lineno-$LINENO}: checking the name lister ($NM) interface" >&5 $as_echo_n "checking the name lister ($NM) interface... " >&6; } if ${lt_cv_nm_interface+:} false; then : $as_echo_n "(cached) " >&6 else lt_cv_nm_interface="BSD nm" echo "int some_variable = 0;" > conftest.$ac_ext (eval echo "\"\$as_me:$LINENO: $ac_compile\"" >&5) (eval "$ac_compile" 2>conftest.err) cat conftest.err >&5 (eval echo "\"\$as_me:$LINENO: $NM \\\"conftest.$ac_objext\\\"\"" >&5) (eval "$NM \"conftest.$ac_objext\"" 2>conftest.err > conftest.out) cat conftest.err >&5 (eval echo "\"\$as_me:$LINENO: output\"" >&5) cat conftest.out >&5 if $GREP 'External.*some_variable' conftest.out > /dev/null; then lt_cv_nm_interface="MS dumpbin" fi rm -f conftest* fi { $as_echo "$as_me:${as_lineno-$LINENO}: result: $lt_cv_nm_interface" >&5 $as_echo "$lt_cv_nm_interface" >&6; } { $as_echo "$as_me:${as_lineno-$LINENO}: checking whether ln -s works" >&5 $as_echo_n "checking whether ln -s works... " >&6; } LN_S=$as_ln_s if test "$LN_S" = "ln -s"; then { $as_echo "$as_me:${as_lineno-$LINENO}: result: yes" >&5 $as_echo "yes" >&6; } else { $as_echo "$as_me:${as_lineno-$LINENO}: result: no, using $LN_S" >&5 $as_echo "no, using $LN_S" >&6; } fi # find the maximum length of command line arguments { $as_echo "$as_me:${as_lineno-$LINENO}: checking the maximum length of command line arguments" >&5 $as_echo_n "checking the maximum length of command line arguments... " >&6; } if ${lt_cv_sys_max_cmd_len+:} false; then : $as_echo_n "(cached) " >&6 else i=0 teststring=ABCD case $build_os in msdosdjgpp*) # On DJGPP, this test can blow up pretty badly due to problems in libc # (any single argument exceeding 2000 bytes causes a buffer overrun # during glob expansion). Even if it were fixed, the result of this # check would be larger than it should be. lt_cv_sys_max_cmd_len=12288; # 12K is about right ;; gnu*) # Under GNU Hurd, this test is not required because there is # no limit to the length of command line arguments. # Libtool will interpret -1 as no limit whatsoever lt_cv_sys_max_cmd_len=-1; ;; cygwin* | mingw* | cegcc*) # On Win9x/ME, this test blows up -- it succeeds, but takes # about 5 minutes as the teststring grows exponentially. # Worse, since 9x/ME are not pre-emptively multitasking, # you end up with a "frozen" computer, even though with patience # the test eventually succeeds (with a max line length of 256k). # Instead, let's just punt: use the minimum linelength reported by # all of the supported platforms: 8192 (on NT/2K/XP). lt_cv_sys_max_cmd_len=8192; ;; mint*) # On MiNT this can take a long time and run out of memory. lt_cv_sys_max_cmd_len=8192; ;; amigaos*) # On AmigaOS with pdksh, this test takes hours, literally. # So we just punt and use a minimum line length of 8192. lt_cv_sys_max_cmd_len=8192; ;; bitrig* | darwin* | dragonfly* | freebsd* | netbsd* | openbsd*) # This has been around since 386BSD, at least. Likely further. if test -x /sbin/sysctl; then lt_cv_sys_max_cmd_len=`/sbin/sysctl -n kern.argmax` elif test -x /usr/sbin/sysctl; then lt_cv_sys_max_cmd_len=`/usr/sbin/sysctl -n kern.argmax` else lt_cv_sys_max_cmd_len=65536 # usable default for all BSDs fi # And add a safety zone lt_cv_sys_max_cmd_len=`expr $lt_cv_sys_max_cmd_len \/ 4` lt_cv_sys_max_cmd_len=`expr $lt_cv_sys_max_cmd_len \* 3` ;; interix*) # We know the value 262144 and hardcode it with a safety zone (like BSD) lt_cv_sys_max_cmd_len=196608 ;; os2*) # The test takes a long time on OS/2. lt_cv_sys_max_cmd_len=8192 ;; osf*) # Dr. Hans Ekkehard Plesser reports seeing a kernel panic running configure # due to this test when exec_disable_arg_limit is 1 on Tru64. It is not # nice to cause kernel panics so lets avoid the loop below. # First set a reasonable default. lt_cv_sys_max_cmd_len=16384 # if test -x /sbin/sysconfig; then case `/sbin/sysconfig -q proc exec_disable_arg_limit` in *1*) lt_cv_sys_max_cmd_len=-1 ;; esac fi ;; sco3.2v5*) lt_cv_sys_max_cmd_len=102400 ;; sysv5* | sco5v6* | sysv4.2uw2*) kargmax=`grep ARG_MAX /etc/conf/cf.d/stune 2>/dev/null` if test -n "$kargmax"; then lt_cv_sys_max_cmd_len=`echo $kargmax | sed 's/.*[ ]//'` else lt_cv_sys_max_cmd_len=32768 fi ;; *) lt_cv_sys_max_cmd_len=`(getconf ARG_MAX) 2> /dev/null` if test -n "$lt_cv_sys_max_cmd_len" && \ test undefined != "$lt_cv_sys_max_cmd_len"; then lt_cv_sys_max_cmd_len=`expr $lt_cv_sys_max_cmd_len \/ 4` lt_cv_sys_max_cmd_len=`expr $lt_cv_sys_max_cmd_len \* 3` else # Make teststring a little bigger before we do anything with it. # a 1K string should be a reasonable start. for i in 1 2 3 4 5 6 7 8; do teststring=$teststring$teststring done SHELL=${SHELL-${CONFIG_SHELL-/bin/sh}} # If test is not a shell built-in, we'll probably end up computing a # maximum length that is only half of the actual maximum length, but # we can't tell. while { test X`env echo "$teststring$teststring" 2>/dev/null` \ = "X$teststring$teststring"; } >/dev/null 2>&1 && test 17 != "$i" # 1/2 MB should be enough do i=`expr $i + 1` teststring=$teststring$teststring done # Only check the string length outside the loop. lt_cv_sys_max_cmd_len=`expr "X$teststring" : ".*" 2>&1` teststring= # Add a significant safety factor because C++ compilers can tack on # massive amounts of additional arguments before passing them to the # linker. It appears as though 1/2 is a usable value. lt_cv_sys_max_cmd_len=`expr $lt_cv_sys_max_cmd_len \/ 2` fi ;; esac fi if test -n "$lt_cv_sys_max_cmd_len"; then { $as_echo "$as_me:${as_lineno-$LINENO}: result: $lt_cv_sys_max_cmd_len" >&5 $as_echo "$lt_cv_sys_max_cmd_len" >&6; } else { $as_echo "$as_me:${as_lineno-$LINENO}: result: none" >&5 $as_echo "none" >&6; } fi max_cmd_len=$lt_cv_sys_max_cmd_len : ${CP="cp -f"} : ${MV="mv -f"} : ${RM="rm -f"} if ( (MAIL=60; unset MAIL) || exit) >/dev/null 2>&1; then lt_unset=unset else lt_unset=false fi # test EBCDIC or ASCII case `echo X|tr X '\101'` in A) # ASCII based system # \n is not interpreted correctly by Solaris 8 /usr/ucb/tr lt_SP2NL='tr \040 \012' lt_NL2SP='tr \015\012 \040\040' ;; *) # EBCDIC based system lt_SP2NL='tr \100 \n' lt_NL2SP='tr \r\n \100\100' ;; esac { $as_echo "$as_me:${as_lineno-$LINENO}: checking how to convert $build file names to $host format" >&5 $as_echo_n "checking how to convert $build file names to $host format... " >&6; } if ${lt_cv_to_host_file_cmd+:} false; then : $as_echo_n "(cached) " >&6 else case $host in *-*-mingw* ) case $build in *-*-mingw* ) # actually msys lt_cv_to_host_file_cmd=func_convert_file_msys_to_w32 ;; *-*-cygwin* ) lt_cv_to_host_file_cmd=func_convert_file_cygwin_to_w32 ;; * ) # otherwise, assume *nix lt_cv_to_host_file_cmd=func_convert_file_nix_to_w32 ;; esac ;; *-*-cygwin* ) case $build in *-*-mingw* ) # actually msys lt_cv_to_host_file_cmd=func_convert_file_msys_to_cygwin ;; *-*-cygwin* ) lt_cv_to_host_file_cmd=func_convert_file_noop ;; * ) # otherwise, assume *nix lt_cv_to_host_file_cmd=func_convert_file_nix_to_cygwin ;; esac ;; * ) # unhandled hosts (and "normal" native builds) lt_cv_to_host_file_cmd=func_convert_file_noop ;; esac fi to_host_file_cmd=$lt_cv_to_host_file_cmd { $as_echo "$as_me:${as_lineno-$LINENO}: result: $lt_cv_to_host_file_cmd" >&5 $as_echo "$lt_cv_to_host_file_cmd" >&6; } { $as_echo "$as_me:${as_lineno-$LINENO}: checking how to convert $build file names to toolchain format" >&5 $as_echo_n "checking how to convert $build file names to toolchain format... " >&6; } if ${lt_cv_to_tool_file_cmd+:} false; then : $as_echo_n "(cached) " >&6 else #assume ordinary cross tools, or native build. lt_cv_to_tool_file_cmd=func_convert_file_noop case $host in *-*-mingw* ) case $build in *-*-mingw* ) # actually msys lt_cv_to_tool_file_cmd=func_convert_file_msys_to_w32 ;; esac ;; esac fi to_tool_file_cmd=$lt_cv_to_tool_file_cmd { $as_echo "$as_me:${as_lineno-$LINENO}: result: $lt_cv_to_tool_file_cmd" >&5 $as_echo "$lt_cv_to_tool_file_cmd" >&6; } { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $LD option to reload object files" >&5 $as_echo_n "checking for $LD option to reload object files... " >&6; } if ${lt_cv_ld_reload_flag+:} false; then : $as_echo_n "(cached) " >&6 else lt_cv_ld_reload_flag='-r' fi { $as_echo "$as_me:${as_lineno-$LINENO}: result: $lt_cv_ld_reload_flag" >&5 $as_echo "$lt_cv_ld_reload_flag" >&6; } reload_flag=$lt_cv_ld_reload_flag case $reload_flag in "" | " "*) ;; *) reload_flag=" $reload_flag" ;; esac reload_cmds='$LD$reload_flag -o $output$reload_objs' case $host_os in cygwin* | mingw* | pw32* | cegcc*) if test yes != "$GCC"; then reload_cmds=false fi ;; darwin*) if test yes = "$GCC"; then reload_cmds='$LTCC $LTCFLAGS -nostdlib $wl-r -o $output$reload_objs' else reload_cmds='$LD$reload_flag -o $output$reload_objs' fi ;; esac if test -n "$ac_tool_prefix"; then # Extract the first word of "${ac_tool_prefix}objdump", so it can be a program name with args. set dummy ${ac_tool_prefix}objdump; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } if ${ac_cv_prog_OBJDUMP+:} false; then : $as_echo_n "(cached) " >&6 else if test -n "$OBJDUMP"; then ac_cv_prog_OBJDUMP="$OBJDUMP" # Let the user override the test. else as_save_IFS=$IFS; IFS=$PATH_SEPARATOR for as_dir in $PATH do IFS=$as_save_IFS test -z "$as_dir" && as_dir=. for ac_exec_ext in '' $ac_executable_extensions; do if as_fn_executable_p "$as_dir/$ac_word$ac_exec_ext"; then ac_cv_prog_OBJDUMP="${ac_tool_prefix}objdump" $as_echo "$as_me:${as_lineno-$LINENO}: found $as_dir/$ac_word$ac_exec_ext" >&5 break 2 fi done done IFS=$as_save_IFS fi fi OBJDUMP=$ac_cv_prog_OBJDUMP if test -n "$OBJDUMP"; then { $as_echo "$as_me:${as_lineno-$LINENO}: result: $OBJDUMP" >&5 $as_echo "$OBJDUMP" >&6; } else { $as_echo "$as_me:${as_lineno-$LINENO}: result: no" >&5 $as_echo "no" >&6; } fi fi if test -z "$ac_cv_prog_OBJDUMP"; then ac_ct_OBJDUMP=$OBJDUMP # Extract the first word of "objdump", so it can be a program name with args. set dummy objdump; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } if ${ac_cv_prog_ac_ct_OBJDUMP+:} false; then : $as_echo_n "(cached) " >&6 else if test -n "$ac_ct_OBJDUMP"; then ac_cv_prog_ac_ct_OBJDUMP="$ac_ct_OBJDUMP" # Let the user override the test. else as_save_IFS=$IFS; IFS=$PATH_SEPARATOR for as_dir in $PATH do IFS=$as_save_IFS test -z "$as_dir" && as_dir=. for ac_exec_ext in '' $ac_executable_extensions; do if as_fn_executable_p "$as_dir/$ac_word$ac_exec_ext"; then ac_cv_prog_ac_ct_OBJDUMP="objdump" $as_echo "$as_me:${as_lineno-$LINENO}: found $as_dir/$ac_word$ac_exec_ext" >&5 break 2 fi done done IFS=$as_save_IFS fi fi ac_ct_OBJDUMP=$ac_cv_prog_ac_ct_OBJDUMP if test -n "$ac_ct_OBJDUMP"; then { $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_ct_OBJDUMP" >&5 $as_echo "$ac_ct_OBJDUMP" >&6; } else { $as_echo "$as_me:${as_lineno-$LINENO}: result: no" >&5 $as_echo "no" >&6; } fi if test "x$ac_ct_OBJDUMP" = x; then OBJDUMP="false" else case $cross_compiling:$ac_tool_warned in yes:) { $as_echo "$as_me:${as_lineno-$LINENO}: WARNING: using cross tools not prefixed with host triplet" >&5 $as_echo "$as_me: WARNING: using cross tools not prefixed with host triplet" >&2;} ac_tool_warned=yes ;; esac OBJDUMP=$ac_ct_OBJDUMP fi else OBJDUMP="$ac_cv_prog_OBJDUMP" fi test -z "$OBJDUMP" && OBJDUMP=objdump { $as_echo "$as_me:${as_lineno-$LINENO}: checking how to recognize dependent libraries" >&5 $as_echo_n "checking how to recognize dependent libraries... " >&6; } if ${lt_cv_deplibs_check_method+:} false; then : $as_echo_n "(cached) " >&6 else lt_cv_file_magic_cmd='$MAGIC_CMD' lt_cv_file_magic_test_file= lt_cv_deplibs_check_method='unknown' # Need to set the preceding variable on all platforms that support # interlibrary dependencies. # 'none' -- dependencies not supported. # 'unknown' -- same as none, but documents that we really don't know. # 'pass_all' -- all dependencies passed with no checks. # 'test_compile' -- check by making test program. # 'file_magic [[regex]]' -- check by looking for files in library path # that responds to the $file_magic_cmd with a given extended regex. # If you have 'file' or equivalent on your system and you're not sure # whether 'pass_all' will *always* work, you probably want this one. case $host_os in aix[4-9]*) lt_cv_deplibs_check_method=pass_all ;; beos*) lt_cv_deplibs_check_method=pass_all ;; bsdi[45]*) lt_cv_deplibs_check_method='file_magic ELF [0-9][0-9]*-bit [ML]SB (shared object|dynamic lib)' lt_cv_file_magic_cmd='/usr/bin/file -L' lt_cv_file_magic_test_file=/shlib/libc.so ;; cygwin*) # func_win32_libid is a shell function defined in ltmain.sh lt_cv_deplibs_check_method='file_magic ^x86 archive import|^x86 DLL' lt_cv_file_magic_cmd='func_win32_libid' ;; mingw* | pw32*) # Base MSYS/MinGW do not provide the 'file' command needed by # func_win32_libid shell function, so use a weaker test based on 'objdump', # unless we find 'file', for example because we are cross-compiling. if ( file / ) >/dev/null 2>&1; then lt_cv_deplibs_check_method='file_magic ^x86 archive import|^x86 DLL' lt_cv_file_magic_cmd='func_win32_libid' else # Keep this pattern in sync with the one in func_win32_libid. lt_cv_deplibs_check_method='file_magic file format (pei*-i386(.*architecture: i386)?|pe-arm-wince|pe-x86-64)' lt_cv_file_magic_cmd='$OBJDUMP -f' fi ;; cegcc*) # use the weaker test based on 'objdump'. See mingw*. lt_cv_deplibs_check_method='file_magic file format pe-arm-.*little(.*architecture: arm)?' lt_cv_file_magic_cmd='$OBJDUMP -f' ;; darwin* | rhapsody*) lt_cv_deplibs_check_method=pass_all ;; freebsd* | dragonfly*) if echo __ELF__ | $CC -E - | $GREP __ELF__ > /dev/null; then case $host_cpu in i*86 ) # Not sure whether the presence of OpenBSD here was a mistake. # Let's accept both of them until this is cleared up. lt_cv_deplibs_check_method='file_magic (FreeBSD|OpenBSD|DragonFly)/i[3-9]86 (compact )?demand paged shared library' lt_cv_file_magic_cmd=/usr/bin/file lt_cv_file_magic_test_file=`echo /usr/lib/libc.so.*` ;; esac else lt_cv_deplibs_check_method=pass_all fi ;; haiku*) lt_cv_deplibs_check_method=pass_all ;; hpux10.20* | hpux11*) lt_cv_file_magic_cmd=/usr/bin/file case $host_cpu in ia64*) lt_cv_deplibs_check_method='file_magic (s[0-9][0-9][0-9]|ELF-[0-9][0-9]) shared object file - IA64' lt_cv_file_magic_test_file=/usr/lib/hpux32/libc.so ;; hppa*64*) lt_cv_deplibs_check_method='file_magic (s[0-9][0-9][0-9]|ELF[ -][0-9][0-9])(-bit)?( [LM]SB)? shared object( file)?[, -]* PA-RISC [0-9]\.[0-9]' lt_cv_file_magic_test_file=/usr/lib/pa20_64/libc.sl ;; *) lt_cv_deplibs_check_method='file_magic (s[0-9][0-9][0-9]|PA-RISC[0-9]\.[0-9]) shared library' lt_cv_file_magic_test_file=/usr/lib/libc.sl ;; esac ;; interix[3-9]*) # PIC code is broken on Interix 3.x, that's why |\.a not |_pic\.a here lt_cv_deplibs_check_method='match_pattern /lib[^/]+(\.so|\.a)$' ;; irix5* | irix6* | nonstopux*) case $LD in *-32|*"-32 ") libmagic=32-bit;; *-n32|*"-n32 ") libmagic=N32;; *-64|*"-64 ") libmagic=64-bit;; *) libmagic=never-match;; esac lt_cv_deplibs_check_method=pass_all ;; # This must be glibc/ELF. linux* | k*bsd*-gnu | kopensolaris*-gnu | gnu*) lt_cv_deplibs_check_method=pass_all ;; netbsd*) if echo __ELF__ | $CC -E - | $GREP __ELF__ > /dev/null; then lt_cv_deplibs_check_method='match_pattern /lib[^/]+(\.so\.[0-9]+\.[0-9]+|_pic\.a)$' else lt_cv_deplibs_check_method='match_pattern /lib[^/]+(\.so|_pic\.a)$' fi ;; newos6*) lt_cv_deplibs_check_method='file_magic ELF [0-9][0-9]*-bit [ML]SB (executable|dynamic lib)' lt_cv_file_magic_cmd=/usr/bin/file lt_cv_file_magic_test_file=/usr/lib/libnls.so ;; *nto* | *qnx*) lt_cv_deplibs_check_method=pass_all ;; openbsd* | bitrig*) if test -z "`echo __ELF__ | $CC -E - | $GREP __ELF__`"; then lt_cv_deplibs_check_method='match_pattern /lib[^/]+(\.so\.[0-9]+\.[0-9]+|\.so|_pic\.a)$' else lt_cv_deplibs_check_method='match_pattern /lib[^/]+(\.so\.[0-9]+\.[0-9]+|_pic\.a)$' fi ;; osf3* | osf4* | osf5*) lt_cv_deplibs_check_method=pass_all ;; rdos*) lt_cv_deplibs_check_method=pass_all ;; solaris*) lt_cv_deplibs_check_method=pass_all ;; sysv5* | sco3.2v5* | sco5v6* | unixware* | OpenUNIX* | sysv4*uw2*) lt_cv_deplibs_check_method=pass_all ;; sysv4 | sysv4.3*) case $host_vendor in motorola) lt_cv_deplibs_check_method='file_magic ELF [0-9][0-9]*-bit [ML]SB (shared object|dynamic lib) M[0-9][0-9]* Version [0-9]' lt_cv_file_magic_test_file=`echo /usr/lib/libc.so*` ;; ncr) lt_cv_deplibs_check_method=pass_all ;; sequent) lt_cv_file_magic_cmd='/bin/file' lt_cv_deplibs_check_method='file_magic ELF [0-9][0-9]*-bit [LM]SB (shared object|dynamic lib )' ;; sni) lt_cv_file_magic_cmd='/bin/file' lt_cv_deplibs_check_method="file_magic ELF [0-9][0-9]*-bit [LM]SB dynamic lib" lt_cv_file_magic_test_file=/lib/libc.so ;; siemens) lt_cv_deplibs_check_method=pass_all ;; pc) lt_cv_deplibs_check_method=pass_all ;; esac ;; tpf*) lt_cv_deplibs_check_method=pass_all ;; os2*) lt_cv_deplibs_check_method=pass_all ;; esac fi { $as_echo "$as_me:${as_lineno-$LINENO}: result: $lt_cv_deplibs_check_method" >&5 $as_echo "$lt_cv_deplibs_check_method" >&6; } file_magic_glob= want_nocaseglob=no if test "$build" = "$host"; then case $host_os in mingw* | pw32*) if ( shopt | grep nocaseglob ) >/dev/null 2>&1; then want_nocaseglob=yes else file_magic_glob=`echo aAbBcCdDeEfFgGhHiIjJkKlLmMnNoOpPqQrRsStTuUvVwWxXyYzZ | $SED -e "s/\(..\)/s\/[\1]\/[\1]\/g;/g"` fi ;; esac fi file_magic_cmd=$lt_cv_file_magic_cmd deplibs_check_method=$lt_cv_deplibs_check_method test -z "$deplibs_check_method" && deplibs_check_method=unknown if test -n "$ac_tool_prefix"; then # Extract the first word of "${ac_tool_prefix}dlltool", so it can be a program name with args. set dummy ${ac_tool_prefix}dlltool; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } if ${ac_cv_prog_DLLTOOL+:} false; then : $as_echo_n "(cached) " >&6 else if test -n "$DLLTOOL"; then ac_cv_prog_DLLTOOL="$DLLTOOL" # Let the user override the test. else as_save_IFS=$IFS; IFS=$PATH_SEPARATOR for as_dir in $PATH do IFS=$as_save_IFS test -z "$as_dir" && as_dir=. for ac_exec_ext in '' $ac_executable_extensions; do if as_fn_executable_p "$as_dir/$ac_word$ac_exec_ext"; then ac_cv_prog_DLLTOOL="${ac_tool_prefix}dlltool" $as_echo "$as_me:${as_lineno-$LINENO}: found $as_dir/$ac_word$ac_exec_ext" >&5 break 2 fi done done IFS=$as_save_IFS fi fi DLLTOOL=$ac_cv_prog_DLLTOOL if test -n "$DLLTOOL"; then { $as_echo "$as_me:${as_lineno-$LINENO}: result: $DLLTOOL" >&5 $as_echo "$DLLTOOL" >&6; } else { $as_echo "$as_me:${as_lineno-$LINENO}: result: no" >&5 $as_echo "no" >&6; } fi fi if test -z "$ac_cv_prog_DLLTOOL"; then ac_ct_DLLTOOL=$DLLTOOL # Extract the first word of "dlltool", so it can be a program name with args. set dummy dlltool; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } if ${ac_cv_prog_ac_ct_DLLTOOL+:} false; then : $as_echo_n "(cached) " >&6 else if test -n "$ac_ct_DLLTOOL"; then ac_cv_prog_ac_ct_DLLTOOL="$ac_ct_DLLTOOL" # Let the user override the test. else as_save_IFS=$IFS; IFS=$PATH_SEPARATOR for as_dir in $PATH do IFS=$as_save_IFS test -z "$as_dir" && as_dir=. for ac_exec_ext in '' $ac_executable_extensions; do if as_fn_executable_p "$as_dir/$ac_word$ac_exec_ext"; then ac_cv_prog_ac_ct_DLLTOOL="dlltool" $as_echo "$as_me:${as_lineno-$LINENO}: found $as_dir/$ac_word$ac_exec_ext" >&5 break 2 fi done done IFS=$as_save_IFS fi fi ac_ct_DLLTOOL=$ac_cv_prog_ac_ct_DLLTOOL if test -n "$ac_ct_DLLTOOL"; then { $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_ct_DLLTOOL" >&5 $as_echo "$ac_ct_DLLTOOL" >&6; } else { $as_echo "$as_me:${as_lineno-$LINENO}: result: no" >&5 $as_echo "no" >&6; } fi if test "x$ac_ct_DLLTOOL" = x; then DLLTOOL="false" else case $cross_compiling:$ac_tool_warned in yes:) { $as_echo "$as_me:${as_lineno-$LINENO}: WARNING: using cross tools not prefixed with host triplet" >&5 $as_echo "$as_me: WARNING: using cross tools not prefixed with host triplet" >&2;} ac_tool_warned=yes ;; esac DLLTOOL=$ac_ct_DLLTOOL fi else DLLTOOL="$ac_cv_prog_DLLTOOL" fi test -z "$DLLTOOL" && DLLTOOL=dlltool { $as_echo "$as_me:${as_lineno-$LINENO}: checking how to associate runtime and link libraries" >&5 $as_echo_n "checking how to associate runtime and link libraries... " >&6; } if ${lt_cv_sharedlib_from_linklib_cmd+:} false; then : $as_echo_n "(cached) " >&6 else lt_cv_sharedlib_from_linklib_cmd='unknown' case $host_os in cygwin* | mingw* | pw32* | cegcc*) # two different shell functions defined in ltmain.sh; # decide which one to use based on capabilities of $DLLTOOL case `$DLLTOOL --help 2>&1` in *--identify-strict*) lt_cv_sharedlib_from_linklib_cmd=func_cygming_dll_for_implib ;; *) lt_cv_sharedlib_from_linklib_cmd=func_cygming_dll_for_implib_fallback ;; esac ;; *) # fallback: assume linklib IS sharedlib lt_cv_sharedlib_from_linklib_cmd=$ECHO ;; esac fi { $as_echo "$as_me:${as_lineno-$LINENO}: result: $lt_cv_sharedlib_from_linklib_cmd" >&5 $as_echo "$lt_cv_sharedlib_from_linklib_cmd" >&6; } sharedlib_from_linklib_cmd=$lt_cv_sharedlib_from_linklib_cmd test -z "$sharedlib_from_linklib_cmd" && sharedlib_from_linklib_cmd=$ECHO if test -n "$ac_tool_prefix"; then for ac_prog in ar do # Extract the first word of "$ac_tool_prefix$ac_prog", so it can be a program name with args. set dummy $ac_tool_prefix$ac_prog; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } if ${ac_cv_prog_AR+:} false; then : $as_echo_n "(cached) " >&6 else if test -n "$AR"; then ac_cv_prog_AR="$AR" # Let the user override the test. else as_save_IFS=$IFS; IFS=$PATH_SEPARATOR for as_dir in $PATH do IFS=$as_save_IFS test -z "$as_dir" && as_dir=. for ac_exec_ext in '' $ac_executable_extensions; do if as_fn_executable_p "$as_dir/$ac_word$ac_exec_ext"; then ac_cv_prog_AR="$ac_tool_prefix$ac_prog" $as_echo "$as_me:${as_lineno-$LINENO}: found $as_dir/$ac_word$ac_exec_ext" >&5 break 2 fi done done IFS=$as_save_IFS fi fi AR=$ac_cv_prog_AR if test -n "$AR"; then { $as_echo "$as_me:${as_lineno-$LINENO}: result: $AR" >&5 $as_echo "$AR" >&6; } else { $as_echo "$as_me:${as_lineno-$LINENO}: result: no" >&5 $as_echo "no" >&6; } fi test -n "$AR" && break done fi if test -z "$AR"; then ac_ct_AR=$AR for ac_prog in ar do # Extract the first word of "$ac_prog", so it can be a program name with args. set dummy $ac_prog; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } if ${ac_cv_prog_ac_ct_AR+:} false; then : $as_echo_n "(cached) " >&6 else if test -n "$ac_ct_AR"; then ac_cv_prog_ac_ct_AR="$ac_ct_AR" # Let the user override the test. else as_save_IFS=$IFS; IFS=$PATH_SEPARATOR for as_dir in $PATH do IFS=$as_save_IFS test -z "$as_dir" && as_dir=. for ac_exec_ext in '' $ac_executable_extensions; do if as_fn_executable_p "$as_dir/$ac_word$ac_exec_ext"; then ac_cv_prog_ac_ct_AR="$ac_prog" $as_echo "$as_me:${as_lineno-$LINENO}: found $as_dir/$ac_word$ac_exec_ext" >&5 break 2 fi done done IFS=$as_save_IFS fi fi ac_ct_AR=$ac_cv_prog_ac_ct_AR if test -n "$ac_ct_AR"; then { $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_ct_AR" >&5 $as_echo "$ac_ct_AR" >&6; } else { $as_echo "$as_me:${as_lineno-$LINENO}: result: no" >&5 $as_echo "no" >&6; } fi test -n "$ac_ct_AR" && break done if test "x$ac_ct_AR" = x; then AR="false" else case $cross_compiling:$ac_tool_warned in yes:) { $as_echo "$as_me:${as_lineno-$LINENO}: WARNING: using cross tools not prefixed with host triplet" >&5 $as_echo "$as_me: WARNING: using cross tools not prefixed with host triplet" >&2;} ac_tool_warned=yes ;; esac AR=$ac_ct_AR fi fi : ${AR=ar} : ${AR_FLAGS=cru} { $as_echo "$as_me:${as_lineno-$LINENO}: checking for archiver @FILE support" >&5 $as_echo_n "checking for archiver @FILE support... " >&6; } if ${lt_cv_ar_at_file+:} false; then : $as_echo_n "(cached) " >&6 else lt_cv_ar_at_file=no cat confdefs.h - <<_ACEOF >conftest.$ac_ext /* end confdefs.h. */ int main () { ; return 0; } _ACEOF if ac_fn_c_try_compile "$LINENO"; then : echo conftest.$ac_objext > conftest.lst lt_ar_try='$AR $AR_FLAGS libconftest.a @conftest.lst >&5' { { eval echo "\"\$as_me\":${as_lineno-$LINENO}: \"$lt_ar_try\""; } >&5 (eval $lt_ar_try) 2>&5 ac_status=$? $as_echo "$as_me:${as_lineno-$LINENO}: \$? = $ac_status" >&5 test $ac_status = 0; } if test 0 -eq "$ac_status"; then # Ensure the archiver fails upon bogus file names. rm -f conftest.$ac_objext libconftest.a { { eval echo "\"\$as_me\":${as_lineno-$LINENO}: \"$lt_ar_try\""; } >&5 (eval $lt_ar_try) 2>&5 ac_status=$? $as_echo "$as_me:${as_lineno-$LINENO}: \$? = $ac_status" >&5 test $ac_status = 0; } if test 0 -ne "$ac_status"; then lt_cv_ar_at_file=@ fi fi rm -f conftest.* libconftest.a fi rm -f core conftest.err conftest.$ac_objext conftest.$ac_ext fi { $as_echo "$as_me:${as_lineno-$LINENO}: result: $lt_cv_ar_at_file" >&5 $as_echo "$lt_cv_ar_at_file" >&6; } if test no = "$lt_cv_ar_at_file"; then archiver_list_spec= else archiver_list_spec=$lt_cv_ar_at_file fi if test -n "$ac_tool_prefix"; then # Extract the first word of "${ac_tool_prefix}strip", so it can be a program name with args. set dummy ${ac_tool_prefix}strip; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } if ${ac_cv_prog_STRIP+:} false; then : $as_echo_n "(cached) " >&6 else if test -n "$STRIP"; then ac_cv_prog_STRIP="$STRIP" # Let the user override the test. else as_save_IFS=$IFS; IFS=$PATH_SEPARATOR for as_dir in $PATH do IFS=$as_save_IFS test -z "$as_dir" && as_dir=. for ac_exec_ext in '' $ac_executable_extensions; do if as_fn_executable_p "$as_dir/$ac_word$ac_exec_ext"; then ac_cv_prog_STRIP="${ac_tool_prefix}strip" $as_echo "$as_me:${as_lineno-$LINENO}: found $as_dir/$ac_word$ac_exec_ext" >&5 break 2 fi done done IFS=$as_save_IFS fi fi STRIP=$ac_cv_prog_STRIP if test -n "$STRIP"; then { $as_echo "$as_me:${as_lineno-$LINENO}: result: $STRIP" >&5 $as_echo "$STRIP" >&6; } else { $as_echo "$as_me:${as_lineno-$LINENO}: result: no" >&5 $as_echo "no" >&6; } fi fi if test -z "$ac_cv_prog_STRIP"; then ac_ct_STRIP=$STRIP # Extract the first word of "strip", so it can be a program name with args. set dummy strip; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } if ${ac_cv_prog_ac_ct_STRIP+:} false; then : $as_echo_n "(cached) " >&6 else if test -n "$ac_ct_STRIP"; then ac_cv_prog_ac_ct_STRIP="$ac_ct_STRIP" # Let the user override the test. else as_save_IFS=$IFS; IFS=$PATH_SEPARATOR for as_dir in $PATH do IFS=$as_save_IFS test -z "$as_dir" && as_dir=. for ac_exec_ext in '' $ac_executable_extensions; do if as_fn_executable_p "$as_dir/$ac_word$ac_exec_ext"; then ac_cv_prog_ac_ct_STRIP="strip" $as_echo "$as_me:${as_lineno-$LINENO}: found $as_dir/$ac_word$ac_exec_ext" >&5 break 2 fi done done IFS=$as_save_IFS fi fi ac_ct_STRIP=$ac_cv_prog_ac_ct_STRIP if test -n "$ac_ct_STRIP"; then { $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_ct_STRIP" >&5 $as_echo "$ac_ct_STRIP" >&6; } else { $as_echo "$as_me:${as_lineno-$LINENO}: result: no" >&5 $as_echo "no" >&6; } fi if test "x$ac_ct_STRIP" = x; then STRIP=":" else case $cross_compiling:$ac_tool_warned in yes:) { $as_echo "$as_me:${as_lineno-$LINENO}: WARNING: using cross tools not prefixed with host triplet" >&5 $as_echo "$as_me: WARNING: using cross tools not prefixed with host triplet" >&2;} ac_tool_warned=yes ;; esac STRIP=$ac_ct_STRIP fi else STRIP="$ac_cv_prog_STRIP" fi test -z "$STRIP" && STRIP=: if test -n "$ac_tool_prefix"; then # Extract the first word of "${ac_tool_prefix}ranlib", so it can be a program name with args. set dummy ${ac_tool_prefix}ranlib; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } if ${ac_cv_prog_RANLIB+:} false; then : $as_echo_n "(cached) " >&6 else if test -n "$RANLIB"; then ac_cv_prog_RANLIB="$RANLIB" # Let the user override the test. else as_save_IFS=$IFS; IFS=$PATH_SEPARATOR for as_dir in $PATH do IFS=$as_save_IFS test -z "$as_dir" && as_dir=. for ac_exec_ext in '' $ac_executable_extensions; do if as_fn_executable_p "$as_dir/$ac_word$ac_exec_ext"; then ac_cv_prog_RANLIB="${ac_tool_prefix}ranlib" $as_echo "$as_me:${as_lineno-$LINENO}: found $as_dir/$ac_word$ac_exec_ext" >&5 break 2 fi done done IFS=$as_save_IFS fi fi RANLIB=$ac_cv_prog_RANLIB if test -n "$RANLIB"; then { $as_echo "$as_me:${as_lineno-$LINENO}: result: $RANLIB" >&5 $as_echo "$RANLIB" >&6; } else { $as_echo "$as_me:${as_lineno-$LINENO}: result: no" >&5 $as_echo "no" >&6; } fi fi if test -z "$ac_cv_prog_RANLIB"; then ac_ct_RANLIB=$RANLIB # Extract the first word of "ranlib", so it can be a program name with args. set dummy ranlib; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } if ${ac_cv_prog_ac_ct_RANLIB+:} false; then : $as_echo_n "(cached) " >&6 else if test -n "$ac_ct_RANLIB"; then ac_cv_prog_ac_ct_RANLIB="$ac_ct_RANLIB" # Let the user override the test. else as_save_IFS=$IFS; IFS=$PATH_SEPARATOR for as_dir in $PATH do IFS=$as_save_IFS test -z "$as_dir" && as_dir=. for ac_exec_ext in '' $ac_executable_extensions; do if as_fn_executable_p "$as_dir/$ac_word$ac_exec_ext"; then ac_cv_prog_ac_ct_RANLIB="ranlib" $as_echo "$as_me:${as_lineno-$LINENO}: found $as_dir/$ac_word$ac_exec_ext" >&5 break 2 fi done done IFS=$as_save_IFS fi fi ac_ct_RANLIB=$ac_cv_prog_ac_ct_RANLIB if test -n "$ac_ct_RANLIB"; then { $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_ct_RANLIB" >&5 $as_echo "$ac_ct_RANLIB" >&6; } else { $as_echo "$as_me:${as_lineno-$LINENO}: result: no" >&5 $as_echo "no" >&6; } fi if test "x$ac_ct_RANLIB" = x; then RANLIB=":" else case $cross_compiling:$ac_tool_warned in yes:) { $as_echo "$as_me:${as_lineno-$LINENO}: WARNING: using cross tools not prefixed with host triplet" >&5 $as_echo "$as_me: WARNING: using cross tools not prefixed with host triplet" >&2;} ac_tool_warned=yes ;; esac RANLIB=$ac_ct_RANLIB fi else RANLIB="$ac_cv_prog_RANLIB" fi test -z "$RANLIB" && RANLIB=: # Determine commands to create old-style static archives. old_archive_cmds='$AR $AR_FLAGS $oldlib$oldobjs' old_postinstall_cmds='chmod 644 $oldlib' old_postuninstall_cmds= if test -n "$RANLIB"; then case $host_os in bitrig* | openbsd*) old_postinstall_cmds="$old_postinstall_cmds~\$RANLIB -t \$tool_oldlib" ;; *) old_postinstall_cmds="$old_postinstall_cmds~\$RANLIB \$tool_oldlib" ;; esac old_archive_cmds="$old_archive_cmds~\$RANLIB \$tool_oldlib" fi case $host_os in darwin*) lock_old_archive_extraction=yes ;; *) lock_old_archive_extraction=no ;; esac # If no C compiler was specified, use CC. LTCC=${LTCC-"$CC"} # If no C compiler flags were specified, use CFLAGS. LTCFLAGS=${LTCFLAGS-"$CFLAGS"} # Allow CC to be a program name with arguments. compiler=$CC # Check for command to grab the raw symbol name followed by C symbol from nm. { $as_echo "$as_me:${as_lineno-$LINENO}: checking command to parse $NM output from $compiler object" >&5 $as_echo_n "checking command to parse $NM output from $compiler object... " >&6; } if ${lt_cv_sys_global_symbol_pipe+:} false; then : $as_echo_n "(cached) " >&6 else # These are sane defaults that work on at least a few old systems. # [They come from Ultrix. What could be older than Ultrix?!! ;)] # Character class describing NM global symbol codes. symcode='[BCDEGRST]' # Regexp to match symbols that can be accessed directly from C. sympat='\([_A-Za-z][_A-Za-z0-9]*\)' # Define system-specific variables. case $host_os in aix*) symcode='[BCDT]' ;; cygwin* | mingw* | pw32* | cegcc*) symcode='[ABCDGISTW]' ;; hpux*) if test ia64 = "$host_cpu"; then symcode='[ABCDEGRST]' fi ;; irix* | nonstopux*) symcode='[BCDEGRST]' ;; osf*) symcode='[BCDEGQRST]' ;; solaris*) symcode='[BDRT]' ;; sco3.2v5*) symcode='[DT]' ;; sysv4.2uw2*) symcode='[DT]' ;; sysv5* | sco5v6* | unixware* | OpenUNIX*) symcode='[ABDT]' ;; sysv4) symcode='[DFNSTU]' ;; esac # If we're using GNU nm, then use its standard symbol codes. case `$NM -V 2>&1` in *GNU* | *'with BFD'*) symcode='[ABCDGIRSTW]' ;; esac if test "$lt_cv_nm_interface" = "MS dumpbin"; then # Gets list of data symbols to import. lt_cv_sys_global_symbol_to_import="sed -n -e 's/^I .* \(.*\)$/\1/p'" # Adjust the below global symbol transforms to fixup imported variables. lt_cdecl_hook=" -e 's/^I .* \(.*\)$/extern __declspec(dllimport) char \1;/p'" lt_c_name_hook=" -e 's/^I .* \(.*\)$/ {\"\1\", (void *) 0},/p'" lt_c_name_lib_hook="\ -e 's/^I .* \(lib.*\)$/ {\"\1\", (void *) 0},/p'\ -e 's/^I .* \(.*\)$/ {\"lib\1\", (void *) 0},/p'" else # Disable hooks by default. lt_cv_sys_global_symbol_to_import= lt_cdecl_hook= lt_c_name_hook= lt_c_name_lib_hook= fi # Transform an extracted symbol line into a proper C declaration. # Some systems (esp. on ia64) link data and code symbols differently, # so use this general approach. lt_cv_sys_global_symbol_to_cdecl="sed -n"\ $lt_cdecl_hook\ " -e 's/^T .* \(.*\)$/extern int \1();/p'"\ " -e 's/^$symcode$symcode* .* \(.*\)$/extern char \1;/p'" # Transform an extracted symbol line into symbol name and symbol address lt_cv_sys_global_symbol_to_c_name_address="sed -n"\ $lt_c_name_hook\ " -e 's/^: \(.*\) .*$/ {\"\1\", (void *) 0},/p'"\ " -e 's/^$symcode$symcode* .* \(.*\)$/ {\"\1\", (void *) \&\1},/p'" # Transform an extracted symbol line into symbol name with lib prefix and # symbol address. lt_cv_sys_global_symbol_to_c_name_address_lib_prefix="sed -n"\ $lt_c_name_lib_hook\ " -e 's/^: \(.*\) .*$/ {\"\1\", (void *) 0},/p'"\ " -e 's/^$symcode$symcode* .* \(lib.*\)$/ {\"\1\", (void *) \&\1},/p'"\ " -e 's/^$symcode$symcode* .* \(.*\)$/ {\"lib\1\", (void *) \&\1},/p'" # Handle CRLF in mingw tool chain opt_cr= case $build_os in mingw*) opt_cr=`$ECHO 'x\{0,1\}' | tr x '\015'` # option cr in regexp ;; esac # Try without a prefix underscore, then with it. for ac_symprfx in "" "_"; do # Transform symcode, sympat, and symprfx into a raw symbol and a C symbol. symxfrm="\\1 $ac_symprfx\\2 \\2" # Write the raw and C identifiers. if test "$lt_cv_nm_interface" = "MS dumpbin"; then # Fake it for dumpbin and say T for any non-static function, # D for any global variable and I for any imported variable. # Also find C++ and __fastcall symbols from MSVC++, # which start with @ or ?. lt_cv_sys_global_symbol_pipe="$AWK '"\ " {last_section=section; section=\$ 3};"\ " /^COFF SYMBOL TABLE/{for(i in hide) delete hide[i]};"\ " /Section length .*#relocs.*(pick any)/{hide[last_section]=1};"\ " /^ *Symbol name *: /{split(\$ 0,sn,\":\"); si=substr(sn[2],2)};"\ " /^ *Type *: code/{print \"T\",si,substr(si,length(prfx))};"\ " /^ *Type *: data/{print \"I\",si,substr(si,length(prfx))};"\ " \$ 0!~/External *\|/{next};"\ " / 0+ UNDEF /{next}; / UNDEF \([^|]\)*()/{next};"\ " {if(hide[section]) next};"\ " {f=\"D\"}; \$ 0~/\(\).*\|/{f=\"T\"};"\ " {split(\$ 0,a,/\||\r/); split(a[2],s)};"\ " s[1]~/^[@?]/{print f,s[1],s[1]; next};"\ " s[1]~prfx {split(s[1],t,\"@\"); print f,t[1],substr(t[1],length(prfx))}"\ " ' prfx=^$ac_symprfx" else lt_cv_sys_global_symbol_pipe="sed -n -e 's/^.*[ ]\($symcode$symcode*\)[ ][ ]*$ac_symprfx$sympat$opt_cr$/$symxfrm/p'" fi lt_cv_sys_global_symbol_pipe="$lt_cv_sys_global_symbol_pipe | sed '/ __gnu_lto/d'" # Check to see that the pipe works correctly. pipe_works=no rm -f conftest* cat > conftest.$ac_ext <<_LT_EOF #ifdef __cplusplus extern "C" { #endif char nm_test_var; void nm_test_func(void); void nm_test_func(void){} #ifdef __cplusplus } #endif int main(){nm_test_var='a';nm_test_func();return(0);} _LT_EOF if { { eval echo "\"\$as_me\":${as_lineno-$LINENO}: \"$ac_compile\""; } >&5 (eval $ac_compile) 2>&5 ac_status=$? $as_echo "$as_me:${as_lineno-$LINENO}: \$? = $ac_status" >&5 test $ac_status = 0; }; then # Now try to grab the symbols. nlist=conftest.nm if { { eval echo "\"\$as_me\":${as_lineno-$LINENO}: \"$NM conftest.$ac_objext \| "$lt_cv_sys_global_symbol_pipe" \> $nlist\""; } >&5 (eval $NM conftest.$ac_objext \| "$lt_cv_sys_global_symbol_pipe" \> $nlist) 2>&5 ac_status=$? $as_echo "$as_me:${as_lineno-$LINENO}: \$? = $ac_status" >&5 test $ac_status = 0; } && test -s "$nlist"; then # Try sorting and uniquifying the output. if sort "$nlist" | uniq > "$nlist"T; then mv -f "$nlist"T "$nlist" else rm -f "$nlist"T fi # Make sure that we snagged all the symbols we need. if $GREP ' nm_test_var$' "$nlist" >/dev/null; then if $GREP ' nm_test_func$' "$nlist" >/dev/null; then cat <<_LT_EOF > conftest.$ac_ext /* Keep this code in sync between libtool.m4, ltmain, lt_system.h, and tests. */ #if defined _WIN32 || defined __CYGWIN__ || defined _WIN32_WCE /* DATA imports from DLLs on WIN32 can't be const, because runtime relocations are performed -- see ld's documentation on pseudo-relocs. */ # define LT_DLSYM_CONST #elif defined __osf__ /* This system does not cope well with relocations in const data. */ # define LT_DLSYM_CONST #else # define LT_DLSYM_CONST const #endif #ifdef __cplusplus extern "C" { #endif _LT_EOF # Now generate the symbol file. eval "$lt_cv_sys_global_symbol_to_cdecl"' < "$nlist" | $GREP -v main >> conftest.$ac_ext' cat <<_LT_EOF >> conftest.$ac_ext /* The mapping between symbol names and symbols. */ LT_DLSYM_CONST struct { const char *name; void *address; } lt__PROGRAM__LTX_preloaded_symbols[] = { { "@PROGRAM@", (void *) 0 }, _LT_EOF $SED "s/^$symcode$symcode* .* \(.*\)$/ {\"\1\", (void *) \&\1},/" < "$nlist" | $GREP -v main >> conftest.$ac_ext cat <<\_LT_EOF >> conftest.$ac_ext {0, (void *) 0} }; /* This works around a problem in FreeBSD linker */ #ifdef FREEBSD_WORKAROUND static const void *lt_preloaded_setup() { return lt__PROGRAM__LTX_preloaded_symbols; } #endif #ifdef __cplusplus } #endif _LT_EOF # Now try linking the two files. mv conftest.$ac_objext conftstm.$ac_objext lt_globsym_save_LIBS=$LIBS lt_globsym_save_CFLAGS=$CFLAGS LIBS=conftstm.$ac_objext CFLAGS="$CFLAGS$lt_prog_compiler_no_builtin_flag" if { { eval echo "\"\$as_me\":${as_lineno-$LINENO}: \"$ac_link\""; } >&5 (eval $ac_link) 2>&5 ac_status=$? $as_echo "$as_me:${as_lineno-$LINENO}: \$? = $ac_status" >&5 test $ac_status = 0; } && test -s conftest$ac_exeext; then pipe_works=yes fi LIBS=$lt_globsym_save_LIBS CFLAGS=$lt_globsym_save_CFLAGS else echo "cannot find nm_test_func in $nlist" >&5 fi else echo "cannot find nm_test_var in $nlist" >&5 fi else echo "cannot run $lt_cv_sys_global_symbol_pipe" >&5 fi else echo "$progname: failed program was:" >&5 cat conftest.$ac_ext >&5 fi rm -rf conftest* conftst* # Do not use the global_symbol_pipe unless it works. if test yes = "$pipe_works"; then break else lt_cv_sys_global_symbol_pipe= fi done fi if test -z "$lt_cv_sys_global_symbol_pipe"; then lt_cv_sys_global_symbol_to_cdecl= fi if test -z "$lt_cv_sys_global_symbol_pipe$lt_cv_sys_global_symbol_to_cdecl"; then { $as_echo "$as_me:${as_lineno-$LINENO}: result: failed" >&5 $as_echo "failed" >&6; } else { $as_echo "$as_me:${as_lineno-$LINENO}: result: ok" >&5 $as_echo "ok" >&6; } fi # Response file support. if test "$lt_cv_nm_interface" = "MS dumpbin"; then nm_file_list_spec='@' elif $NM --help 2>/dev/null | grep '[@]FILE' >/dev/null; then nm_file_list_spec='@' fi { $as_echo "$as_me:${as_lineno-$LINENO}: checking for sysroot" >&5 $as_echo_n "checking for sysroot... " >&6; } # Check whether --with-sysroot was given. if test "${with_sysroot+set}" = set; then : withval=$with_sysroot; else with_sysroot=no fi lt_sysroot= case $with_sysroot in #( yes) if test yes = "$GCC"; then lt_sysroot=`$CC --print-sysroot 2>/dev/null` fi ;; #( /*) lt_sysroot=`echo "$with_sysroot" | sed -e "$sed_quote_subst"` ;; #( no|'') ;; #( *) { $as_echo "$as_me:${as_lineno-$LINENO}: result: $with_sysroot" >&5 $as_echo "$with_sysroot" >&6; } as_fn_error $? "The sysroot must be an absolute path." "$LINENO" 5 ;; esac { $as_echo "$as_me:${as_lineno-$LINENO}: result: ${lt_sysroot:-no}" >&5 $as_echo "${lt_sysroot:-no}" >&6; } { $as_echo "$as_me:${as_lineno-$LINENO}: checking for a working dd" >&5 $as_echo_n "checking for a working dd... " >&6; } if ${ac_cv_path_lt_DD+:} false; then : $as_echo_n "(cached) " >&6 else printf 0123456789abcdef0123456789abcdef >conftest.i cat conftest.i conftest.i >conftest2.i : ${lt_DD:=$DD} if test -z "$lt_DD"; then ac_path_lt_DD_found=false # Loop through the user's path and test for each of PROGNAME-LIST as_save_IFS=$IFS; IFS=$PATH_SEPARATOR for as_dir in $PATH do IFS=$as_save_IFS test -z "$as_dir" && as_dir=. for ac_prog in dd; do for ac_exec_ext in '' $ac_executable_extensions; do ac_path_lt_DD="$as_dir/$ac_prog$ac_exec_ext" as_fn_executable_p "$ac_path_lt_DD" || continue if "$ac_path_lt_DD" bs=32 count=1 conftest.out 2>/dev/null; then cmp -s conftest.i conftest.out \ && ac_cv_path_lt_DD="$ac_path_lt_DD" ac_path_lt_DD_found=: fi $ac_path_lt_DD_found && break 3 done done done IFS=$as_save_IFS if test -z "$ac_cv_path_lt_DD"; then : fi else ac_cv_path_lt_DD=$lt_DD fi rm -f conftest.i conftest2.i conftest.out fi { $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_cv_path_lt_DD" >&5 $as_echo "$ac_cv_path_lt_DD" >&6; } { $as_echo "$as_me:${as_lineno-$LINENO}: checking how to truncate binary pipes" >&5 $as_echo_n "checking how to truncate binary pipes... " >&6; } if ${lt_cv_truncate_bin+:} false; then : $as_echo_n "(cached) " >&6 else printf 0123456789abcdef0123456789abcdef >conftest.i cat conftest.i conftest.i >conftest2.i lt_cv_truncate_bin= if "$ac_cv_path_lt_DD" bs=32 count=1 conftest.out 2>/dev/null; then cmp -s conftest.i conftest.out \ && lt_cv_truncate_bin="$ac_cv_path_lt_DD bs=4096 count=1" fi rm -f conftest.i conftest2.i conftest.out test -z "$lt_cv_truncate_bin" && lt_cv_truncate_bin="$SED -e 4q" fi { $as_echo "$as_me:${as_lineno-$LINENO}: result: $lt_cv_truncate_bin" >&5 $as_echo "$lt_cv_truncate_bin" >&6; } # Calculate cc_basename. Skip known compiler wrappers and cross-prefix. func_cc_basename () { for cc_temp in $*""; do case $cc_temp in compile | *[\\/]compile | ccache | *[\\/]ccache ) ;; distcc | *[\\/]distcc | purify | *[\\/]purify ) ;; \-*) ;; *) break;; esac done func_cc_basename_result=`$ECHO "$cc_temp" | $SED "s%.*/%%; s%^$host_alias-%%"` } # Check whether --enable-libtool-lock was given. if test "${enable_libtool_lock+set}" = set; then : enableval=$enable_libtool_lock; fi test no = "$enable_libtool_lock" || enable_libtool_lock=yes # Some flags need to be propagated to the compiler or linker for good # libtool support. case $host in ia64-*-hpux*) # Find out what ABI is being produced by ac_compile, and set mode # options accordingly. echo 'int i;' > conftest.$ac_ext if { { eval echo "\"\$as_me\":${as_lineno-$LINENO}: \"$ac_compile\""; } >&5 (eval $ac_compile) 2>&5 ac_status=$? $as_echo "$as_me:${as_lineno-$LINENO}: \$? = $ac_status" >&5 test $ac_status = 0; }; then case `/usr/bin/file conftest.$ac_objext` in *ELF-32*) HPUX_IA64_MODE=32 ;; *ELF-64*) HPUX_IA64_MODE=64 ;; esac fi rm -rf conftest* ;; *-*-irix6*) # Find out what ABI is being produced by ac_compile, and set linker # options accordingly. echo '#line '$LINENO' "configure"' > conftest.$ac_ext if { { eval echo "\"\$as_me\":${as_lineno-$LINENO}: \"$ac_compile\""; } >&5 (eval $ac_compile) 2>&5 ac_status=$? $as_echo "$as_me:${as_lineno-$LINENO}: \$? = $ac_status" >&5 test $ac_status = 0; }; then if test yes = "$lt_cv_prog_gnu_ld"; then case `/usr/bin/file conftest.$ac_objext` in *32-bit*) LD="${LD-ld} -melf32bsmip" ;; *N32*) LD="${LD-ld} -melf32bmipn32" ;; *64-bit*) LD="${LD-ld} -melf64bmip" ;; esac else case `/usr/bin/file conftest.$ac_objext` in *32-bit*) LD="${LD-ld} -32" ;; *N32*) LD="${LD-ld} -n32" ;; *64-bit*) LD="${LD-ld} -64" ;; esac fi fi rm -rf conftest* ;; mips64*-*linux*) # Find out what ABI is being produced by ac_compile, and set linker # options accordingly. echo '#line '$LINENO' "configure"' > conftest.$ac_ext if { { eval echo "\"\$as_me\":${as_lineno-$LINENO}: \"$ac_compile\""; } >&5 (eval $ac_compile) 2>&5 ac_status=$? $as_echo "$as_me:${as_lineno-$LINENO}: \$? = $ac_status" >&5 test $ac_status = 0; }; then emul=elf case `/usr/bin/file conftest.$ac_objext` in *32-bit*) emul="${emul}32" ;; *64-bit*) emul="${emul}64" ;; esac case `/usr/bin/file conftest.$ac_objext` in *MSB*) emul="${emul}btsmip" ;; *LSB*) emul="${emul}ltsmip" ;; esac case `/usr/bin/file conftest.$ac_objext` in *N32*) emul="${emul}n32" ;; esac LD="${LD-ld} -m $emul" fi rm -rf conftest* ;; x86_64-*kfreebsd*-gnu|x86_64-*linux*|powerpc*-*linux*| \ s390*-*linux*|s390*-*tpf*|sparc*-*linux*) # Find out what ABI is being produced by ac_compile, and set linker # options accordingly. Note that the listed cases only cover the # situations where additional linker options are needed (such as when # doing 32-bit compilation for a host where ld defaults to 64-bit, or # vice versa); the common cases where no linker options are needed do # not appear in the list. echo 'int i;' > conftest.$ac_ext if { { eval echo "\"\$as_me\":${as_lineno-$LINENO}: \"$ac_compile\""; } >&5 (eval $ac_compile) 2>&5 ac_status=$? $as_echo "$as_me:${as_lineno-$LINENO}: \$? = $ac_status" >&5 test $ac_status = 0; }; then case `/usr/bin/file conftest.o` in *32-bit*) case $host in x86_64-*kfreebsd*-gnu) LD="${LD-ld} -m elf_i386_fbsd" ;; x86_64-*linux*) case `/usr/bin/file conftest.o` in *x86-64*) LD="${LD-ld} -m elf32_x86_64" ;; *) LD="${LD-ld} -m elf_i386" ;; esac ;; powerpc64le-*linux*) LD="${LD-ld} -m elf32lppclinux" ;; powerpc64-*linux*) LD="${LD-ld} -m elf32ppclinux" ;; s390x-*linux*) LD="${LD-ld} -m elf_s390" ;; sparc64-*linux*) LD="${LD-ld} -m elf32_sparc" ;; esac ;; *64-bit*) case $host in x86_64-*kfreebsd*-gnu) LD="${LD-ld} -m elf_x86_64_fbsd" ;; x86_64-*linux*) LD="${LD-ld} -m elf_x86_64" ;; powerpcle-*linux*) LD="${LD-ld} -m elf64lppc" ;; powerpc-*linux*) LD="${LD-ld} -m elf64ppc" ;; s390*-*linux*|s390*-*tpf*) LD="${LD-ld} -m elf64_s390" ;; sparc*-*linux*) LD="${LD-ld} -m elf64_sparc" ;; esac ;; esac fi rm -rf conftest* ;; *-*-sco3.2v5*) # On SCO OpenServer 5, we need -belf to get full-featured binaries. SAVE_CFLAGS=$CFLAGS CFLAGS="$CFLAGS -belf" { $as_echo "$as_me:${as_lineno-$LINENO}: checking whether the C compiler needs -belf" >&5 $as_echo_n "checking whether the C compiler needs -belf... " >&6; } if ${lt_cv_cc_needs_belf+:} false; then : $as_echo_n "(cached) " >&6 else ac_ext=c ac_cpp='$CPP $CPPFLAGS' ac_compile='$CC -c $CFLAGS $CPPFLAGS conftest.$ac_ext >&5' ac_link='$CC -o conftest$ac_exeext $CFLAGS $CPPFLAGS $LDFLAGS conftest.$ac_ext $LIBS >&5' ac_compiler_gnu=$ac_cv_c_compiler_gnu cat confdefs.h - <<_ACEOF >conftest.$ac_ext /* end confdefs.h. */ int main () { ; return 0; } _ACEOF if ac_fn_c_try_link "$LINENO"; then : lt_cv_cc_needs_belf=yes else lt_cv_cc_needs_belf=no fi rm -f core conftest.err conftest.$ac_objext \ conftest$ac_exeext conftest.$ac_ext ac_ext=c ac_cpp='$CPP $CPPFLAGS' ac_compile='$CC -c $CFLAGS $CPPFLAGS conftest.$ac_ext >&5' ac_link='$CC -o conftest$ac_exeext $CFLAGS $CPPFLAGS $LDFLAGS conftest.$ac_ext $LIBS >&5' ac_compiler_gnu=$ac_cv_c_compiler_gnu fi { $as_echo "$as_me:${as_lineno-$LINENO}: result: $lt_cv_cc_needs_belf" >&5 $as_echo "$lt_cv_cc_needs_belf" >&6; } if test yes != "$lt_cv_cc_needs_belf"; then # this is probably gcc 2.8.0, egcs 1.0 or newer; no need for -belf CFLAGS=$SAVE_CFLAGS fi ;; *-*solaris*) # Find out what ABI is being produced by ac_compile, and set linker # options accordingly. echo 'int i;' > conftest.$ac_ext if { { eval echo "\"\$as_me\":${as_lineno-$LINENO}: \"$ac_compile\""; } >&5 (eval $ac_compile) 2>&5 ac_status=$? $as_echo "$as_me:${as_lineno-$LINENO}: \$? = $ac_status" >&5 test $ac_status = 0; }; then case `/usr/bin/file conftest.o` in *64-bit*) case $lt_cv_prog_gnu_ld in yes*) case $host in i?86-*-solaris*|x86_64-*-solaris*) LD="${LD-ld} -m elf_x86_64" ;; sparc*-*-solaris*) LD="${LD-ld} -m elf64_sparc" ;; esac # GNU ld 2.21 introduced _sol2 emulations. Use them if available. if ${LD-ld} -V | grep _sol2 >/dev/null 2>&1; then LD=${LD-ld}_sol2 fi ;; *) if ${LD-ld} -64 -r -o conftest2.o conftest.o >/dev/null 2>&1; then LD="${LD-ld} -64" fi ;; esac ;; esac fi rm -rf conftest* ;; esac need_locks=$enable_libtool_lock if test -n "$ac_tool_prefix"; then # Extract the first word of "${ac_tool_prefix}mt", so it can be a program name with args. set dummy ${ac_tool_prefix}mt; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } if ${ac_cv_prog_MANIFEST_TOOL+:} false; then : $as_echo_n "(cached) " >&6 else if test -n "$MANIFEST_TOOL"; then ac_cv_prog_MANIFEST_TOOL="$MANIFEST_TOOL" # Let the user override the test. else as_save_IFS=$IFS; IFS=$PATH_SEPARATOR for as_dir in $PATH do IFS=$as_save_IFS test -z "$as_dir" && as_dir=. for ac_exec_ext in '' $ac_executable_extensions; do if as_fn_executable_p "$as_dir/$ac_word$ac_exec_ext"; then ac_cv_prog_MANIFEST_TOOL="${ac_tool_prefix}mt" $as_echo "$as_me:${as_lineno-$LINENO}: found $as_dir/$ac_word$ac_exec_ext" >&5 break 2 fi done done IFS=$as_save_IFS fi fi MANIFEST_TOOL=$ac_cv_prog_MANIFEST_TOOL if test -n "$MANIFEST_TOOL"; then { $as_echo "$as_me:${as_lineno-$LINENO}: result: $MANIFEST_TOOL" >&5 $as_echo "$MANIFEST_TOOL" >&6; } else { $as_echo "$as_me:${as_lineno-$LINENO}: result: no" >&5 $as_echo "no" >&6; } fi fi if test -z "$ac_cv_prog_MANIFEST_TOOL"; then ac_ct_MANIFEST_TOOL=$MANIFEST_TOOL # Extract the first word of "mt", so it can be a program name with args. set dummy mt; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } if ${ac_cv_prog_ac_ct_MANIFEST_TOOL+:} false; then : $as_echo_n "(cached) " >&6 else if test -n "$ac_ct_MANIFEST_TOOL"; then ac_cv_prog_ac_ct_MANIFEST_TOOL="$ac_ct_MANIFEST_TOOL" # Let the user override the test. else as_save_IFS=$IFS; IFS=$PATH_SEPARATOR for as_dir in $PATH do IFS=$as_save_IFS test -z "$as_dir" && as_dir=. for ac_exec_ext in '' $ac_executable_extensions; do if as_fn_executable_p "$as_dir/$ac_word$ac_exec_ext"; then ac_cv_prog_ac_ct_MANIFEST_TOOL="mt" $as_echo "$as_me:${as_lineno-$LINENO}: found $as_dir/$ac_word$ac_exec_ext" >&5 break 2 fi done done IFS=$as_save_IFS fi fi ac_ct_MANIFEST_TOOL=$ac_cv_prog_ac_ct_MANIFEST_TOOL if test -n "$ac_ct_MANIFEST_TOOL"; then { $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_ct_MANIFEST_TOOL" >&5 $as_echo "$ac_ct_MANIFEST_TOOL" >&6; } else { $as_echo "$as_me:${as_lineno-$LINENO}: result: no" >&5 $as_echo "no" >&6; } fi if test "x$ac_ct_MANIFEST_TOOL" = x; then MANIFEST_TOOL=":" else case $cross_compiling:$ac_tool_warned in yes:) { $as_echo "$as_me:${as_lineno-$LINENO}: WARNING: using cross tools not prefixed with host triplet" >&5 $as_echo "$as_me: WARNING: using cross tools not prefixed with host triplet" >&2;} ac_tool_warned=yes ;; esac MANIFEST_TOOL=$ac_ct_MANIFEST_TOOL fi else MANIFEST_TOOL="$ac_cv_prog_MANIFEST_TOOL" fi test -z "$MANIFEST_TOOL" && MANIFEST_TOOL=mt { $as_echo "$as_me:${as_lineno-$LINENO}: checking if $MANIFEST_TOOL is a manifest tool" >&5 $as_echo_n "checking if $MANIFEST_TOOL is a manifest tool... " >&6; } if ${lt_cv_path_mainfest_tool+:} false; then : $as_echo_n "(cached) " >&6 else lt_cv_path_mainfest_tool=no echo "$as_me:$LINENO: $MANIFEST_TOOL '-?'" >&5 $MANIFEST_TOOL '-?' 2>conftest.err > conftest.out cat conftest.err >&5 if $GREP 'Manifest Tool' conftest.out > /dev/null; then lt_cv_path_mainfest_tool=yes fi rm -f conftest* fi { $as_echo "$as_me:${as_lineno-$LINENO}: result: $lt_cv_path_mainfest_tool" >&5 $as_echo "$lt_cv_path_mainfest_tool" >&6; } if test yes != "$lt_cv_path_mainfest_tool"; then MANIFEST_TOOL=: fi case $host_os in rhapsody* | darwin*) if test -n "$ac_tool_prefix"; then # Extract the first word of "${ac_tool_prefix}dsymutil", so it can be a program name with args. set dummy ${ac_tool_prefix}dsymutil; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } if ${ac_cv_prog_DSYMUTIL+:} false; then : $as_echo_n "(cached) " >&6 else if test -n "$DSYMUTIL"; then ac_cv_prog_DSYMUTIL="$DSYMUTIL" # Let the user override the test. else as_save_IFS=$IFS; IFS=$PATH_SEPARATOR for as_dir in $PATH do IFS=$as_save_IFS test -z "$as_dir" && as_dir=. for ac_exec_ext in '' $ac_executable_extensions; do if as_fn_executable_p "$as_dir/$ac_word$ac_exec_ext"; then ac_cv_prog_DSYMUTIL="${ac_tool_prefix}dsymutil" $as_echo "$as_me:${as_lineno-$LINENO}: found $as_dir/$ac_word$ac_exec_ext" >&5 break 2 fi done done IFS=$as_save_IFS fi fi DSYMUTIL=$ac_cv_prog_DSYMUTIL if test -n "$DSYMUTIL"; then { $as_echo "$as_me:${as_lineno-$LINENO}: result: $DSYMUTIL" >&5 $as_echo "$DSYMUTIL" >&6; } else { $as_echo "$as_me:${as_lineno-$LINENO}: result: no" >&5 $as_echo "no" >&6; } fi fi if test -z "$ac_cv_prog_DSYMUTIL"; then ac_ct_DSYMUTIL=$DSYMUTIL # Extract the first word of "dsymutil", so it can be a program name with args. set dummy dsymutil; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } if ${ac_cv_prog_ac_ct_DSYMUTIL+:} false; then : $as_echo_n "(cached) " >&6 else if test -n "$ac_ct_DSYMUTIL"; then ac_cv_prog_ac_ct_DSYMUTIL="$ac_ct_DSYMUTIL" # Let the user override the test. else as_save_IFS=$IFS; IFS=$PATH_SEPARATOR for as_dir in $PATH do IFS=$as_save_IFS test -z "$as_dir" && as_dir=. for ac_exec_ext in '' $ac_executable_extensions; do if as_fn_executable_p "$as_dir/$ac_word$ac_exec_ext"; then ac_cv_prog_ac_ct_DSYMUTIL="dsymutil" $as_echo "$as_me:${as_lineno-$LINENO}: found $as_dir/$ac_word$ac_exec_ext" >&5 break 2 fi done done IFS=$as_save_IFS fi fi ac_ct_DSYMUTIL=$ac_cv_prog_ac_ct_DSYMUTIL if test -n "$ac_ct_DSYMUTIL"; then { $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_ct_DSYMUTIL" >&5 $as_echo "$ac_ct_DSYMUTIL" >&6; } else { $as_echo "$as_me:${as_lineno-$LINENO}: result: no" >&5 $as_echo "no" >&6; } fi if test "x$ac_ct_DSYMUTIL" = x; then DSYMUTIL=":" else case $cross_compiling:$ac_tool_warned in yes:) { $as_echo "$as_me:${as_lineno-$LINENO}: WARNING: using cross tools not prefixed with host triplet" >&5 $as_echo "$as_me: WARNING: using cross tools not prefixed with host triplet" >&2;} ac_tool_warned=yes ;; esac DSYMUTIL=$ac_ct_DSYMUTIL fi else DSYMUTIL="$ac_cv_prog_DSYMUTIL" fi if test -n "$ac_tool_prefix"; then # Extract the first word of "${ac_tool_prefix}nmedit", so it can be a program name with args. set dummy ${ac_tool_prefix}nmedit; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } if ${ac_cv_prog_NMEDIT+:} false; then : $as_echo_n "(cached) " >&6 else if test -n "$NMEDIT"; then ac_cv_prog_NMEDIT="$NMEDIT" # Let the user override the test. else as_save_IFS=$IFS; IFS=$PATH_SEPARATOR for as_dir in $PATH do IFS=$as_save_IFS test -z "$as_dir" && as_dir=. for ac_exec_ext in '' $ac_executable_extensions; do if as_fn_executable_p "$as_dir/$ac_word$ac_exec_ext"; then ac_cv_prog_NMEDIT="${ac_tool_prefix}nmedit" $as_echo "$as_me:${as_lineno-$LINENO}: found $as_dir/$ac_word$ac_exec_ext" >&5 break 2 fi done done IFS=$as_save_IFS fi fi NMEDIT=$ac_cv_prog_NMEDIT if test -n "$NMEDIT"; then { $as_echo "$as_me:${as_lineno-$LINENO}: result: $NMEDIT" >&5 $as_echo "$NMEDIT" >&6; } else { $as_echo "$as_me:${as_lineno-$LINENO}: result: no" >&5 $as_echo "no" >&6; } fi fi if test -z "$ac_cv_prog_NMEDIT"; then ac_ct_NMEDIT=$NMEDIT # Extract the first word of "nmedit", so it can be a program name with args. set dummy nmedit; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } if ${ac_cv_prog_ac_ct_NMEDIT+:} false; then : $as_echo_n "(cached) " >&6 else if test -n "$ac_ct_NMEDIT"; then ac_cv_prog_ac_ct_NMEDIT="$ac_ct_NMEDIT" # Let the user override the test. else as_save_IFS=$IFS; IFS=$PATH_SEPARATOR for as_dir in $PATH do IFS=$as_save_IFS test -z "$as_dir" && as_dir=. for ac_exec_ext in '' $ac_executable_extensions; do if as_fn_executable_p "$as_dir/$ac_word$ac_exec_ext"; then ac_cv_prog_ac_ct_NMEDIT="nmedit" $as_echo "$as_me:${as_lineno-$LINENO}: found $as_dir/$ac_word$ac_exec_ext" >&5 break 2 fi done done IFS=$as_save_IFS fi fi ac_ct_NMEDIT=$ac_cv_prog_ac_ct_NMEDIT if test -n "$ac_ct_NMEDIT"; then { $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_ct_NMEDIT" >&5 $as_echo "$ac_ct_NMEDIT" >&6; } else { $as_echo "$as_me:${as_lineno-$LINENO}: result: no" >&5 $as_echo "no" >&6; } fi if test "x$ac_ct_NMEDIT" = x; then NMEDIT=":" else case $cross_compiling:$ac_tool_warned in yes:) { $as_echo "$as_me:${as_lineno-$LINENO}: WARNING: using cross tools not prefixed with host triplet" >&5 $as_echo "$as_me: WARNING: using cross tools not prefixed with host triplet" >&2;} ac_tool_warned=yes ;; esac NMEDIT=$ac_ct_NMEDIT fi else NMEDIT="$ac_cv_prog_NMEDIT" fi if test -n "$ac_tool_prefix"; then # Extract the first word of "${ac_tool_prefix}lipo", so it can be a program name with args. set dummy ${ac_tool_prefix}lipo; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } if ${ac_cv_prog_LIPO+:} false; then : $as_echo_n "(cached) " >&6 else if test -n "$LIPO"; then ac_cv_prog_LIPO="$LIPO" # Let the user override the test. else as_save_IFS=$IFS; IFS=$PATH_SEPARATOR for as_dir in $PATH do IFS=$as_save_IFS test -z "$as_dir" && as_dir=. for ac_exec_ext in '' $ac_executable_extensions; do if as_fn_executable_p "$as_dir/$ac_word$ac_exec_ext"; then ac_cv_prog_LIPO="${ac_tool_prefix}lipo" $as_echo "$as_me:${as_lineno-$LINENO}: found $as_dir/$ac_word$ac_exec_ext" >&5 break 2 fi done done IFS=$as_save_IFS fi fi LIPO=$ac_cv_prog_LIPO if test -n "$LIPO"; then { $as_echo "$as_me:${as_lineno-$LINENO}: result: $LIPO" >&5 $as_echo "$LIPO" >&6; } else { $as_echo "$as_me:${as_lineno-$LINENO}: result: no" >&5 $as_echo "no" >&6; } fi fi if test -z "$ac_cv_prog_LIPO"; then ac_ct_LIPO=$LIPO # Extract the first word of "lipo", so it can be a program name with args. set dummy lipo; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } if ${ac_cv_prog_ac_ct_LIPO+:} false; then : $as_echo_n "(cached) " >&6 else if test -n "$ac_ct_LIPO"; then ac_cv_prog_ac_ct_LIPO="$ac_ct_LIPO" # Let the user override the test. else as_save_IFS=$IFS; IFS=$PATH_SEPARATOR for as_dir in $PATH do IFS=$as_save_IFS test -z "$as_dir" && as_dir=. for ac_exec_ext in '' $ac_executable_extensions; do if as_fn_executable_p "$as_dir/$ac_word$ac_exec_ext"; then ac_cv_prog_ac_ct_LIPO="lipo" $as_echo "$as_me:${as_lineno-$LINENO}: found $as_dir/$ac_word$ac_exec_ext" >&5 break 2 fi done done IFS=$as_save_IFS fi fi ac_ct_LIPO=$ac_cv_prog_ac_ct_LIPO if test -n "$ac_ct_LIPO"; then { $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_ct_LIPO" >&5 $as_echo "$ac_ct_LIPO" >&6; } else { $as_echo "$as_me:${as_lineno-$LINENO}: result: no" >&5 $as_echo "no" >&6; } fi if test "x$ac_ct_LIPO" = x; then LIPO=":" else case $cross_compiling:$ac_tool_warned in yes:) { $as_echo "$as_me:${as_lineno-$LINENO}: WARNING: using cross tools not prefixed with host triplet" >&5 $as_echo "$as_me: WARNING: using cross tools not prefixed with host triplet" >&2;} ac_tool_warned=yes ;; esac LIPO=$ac_ct_LIPO fi else LIPO="$ac_cv_prog_LIPO" fi if test -n "$ac_tool_prefix"; then # Extract the first word of "${ac_tool_prefix}otool", so it can be a program name with args. set dummy ${ac_tool_prefix}otool; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } if ${ac_cv_prog_OTOOL+:} false; then : $as_echo_n "(cached) " >&6 else if test -n "$OTOOL"; then ac_cv_prog_OTOOL="$OTOOL" # Let the user override the test. else as_save_IFS=$IFS; IFS=$PATH_SEPARATOR for as_dir in $PATH do IFS=$as_save_IFS test -z "$as_dir" && as_dir=. for ac_exec_ext in '' $ac_executable_extensions; do if as_fn_executable_p "$as_dir/$ac_word$ac_exec_ext"; then ac_cv_prog_OTOOL="${ac_tool_prefix}otool" $as_echo "$as_me:${as_lineno-$LINENO}: found $as_dir/$ac_word$ac_exec_ext" >&5 break 2 fi done done IFS=$as_save_IFS fi fi OTOOL=$ac_cv_prog_OTOOL if test -n "$OTOOL"; then { $as_echo "$as_me:${as_lineno-$LINENO}: result: $OTOOL" >&5 $as_echo "$OTOOL" >&6; } else { $as_echo "$as_me:${as_lineno-$LINENO}: result: no" >&5 $as_echo "no" >&6; } fi fi if test -z "$ac_cv_prog_OTOOL"; then ac_ct_OTOOL=$OTOOL # Extract the first word of "otool", so it can be a program name with args. set dummy otool; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } if ${ac_cv_prog_ac_ct_OTOOL+:} false; then : $as_echo_n "(cached) " >&6 else if test -n "$ac_ct_OTOOL"; then ac_cv_prog_ac_ct_OTOOL="$ac_ct_OTOOL" # Let the user override the test. else as_save_IFS=$IFS; IFS=$PATH_SEPARATOR for as_dir in $PATH do IFS=$as_save_IFS test -z "$as_dir" && as_dir=. for ac_exec_ext in '' $ac_executable_extensions; do if as_fn_executable_p "$as_dir/$ac_word$ac_exec_ext"; then ac_cv_prog_ac_ct_OTOOL="otool" $as_echo "$as_me:${as_lineno-$LINENO}: found $as_dir/$ac_word$ac_exec_ext" >&5 break 2 fi done done IFS=$as_save_IFS fi fi ac_ct_OTOOL=$ac_cv_prog_ac_ct_OTOOL if test -n "$ac_ct_OTOOL"; then { $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_ct_OTOOL" >&5 $as_echo "$ac_ct_OTOOL" >&6; } else { $as_echo "$as_me:${as_lineno-$LINENO}: result: no" >&5 $as_echo "no" >&6; } fi if test "x$ac_ct_OTOOL" = x; then OTOOL=":" else case $cross_compiling:$ac_tool_warned in yes:) { $as_echo "$as_me:${as_lineno-$LINENO}: WARNING: using cross tools not prefixed with host triplet" >&5 $as_echo "$as_me: WARNING: using cross tools not prefixed with host triplet" >&2;} ac_tool_warned=yes ;; esac OTOOL=$ac_ct_OTOOL fi else OTOOL="$ac_cv_prog_OTOOL" fi if test -n "$ac_tool_prefix"; then # Extract the first word of "${ac_tool_prefix}otool64", so it can be a program name with args. set dummy ${ac_tool_prefix}otool64; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } if ${ac_cv_prog_OTOOL64+:} false; then : $as_echo_n "(cached) " >&6 else if test -n "$OTOOL64"; then ac_cv_prog_OTOOL64="$OTOOL64" # Let the user override the test. else as_save_IFS=$IFS; IFS=$PATH_SEPARATOR for as_dir in $PATH do IFS=$as_save_IFS test -z "$as_dir" && as_dir=. for ac_exec_ext in '' $ac_executable_extensions; do if as_fn_executable_p "$as_dir/$ac_word$ac_exec_ext"; then ac_cv_prog_OTOOL64="${ac_tool_prefix}otool64" $as_echo "$as_me:${as_lineno-$LINENO}: found $as_dir/$ac_word$ac_exec_ext" >&5 break 2 fi done done IFS=$as_save_IFS fi fi OTOOL64=$ac_cv_prog_OTOOL64 if test -n "$OTOOL64"; then { $as_echo "$as_me:${as_lineno-$LINENO}: result: $OTOOL64" >&5 $as_echo "$OTOOL64" >&6; } else { $as_echo "$as_me:${as_lineno-$LINENO}: result: no" >&5 $as_echo "no" >&6; } fi fi if test -z "$ac_cv_prog_OTOOL64"; then ac_ct_OTOOL64=$OTOOL64 # Extract the first word of "otool64", so it can be a program name with args. set dummy otool64; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } if ${ac_cv_prog_ac_ct_OTOOL64+:} false; then : $as_echo_n "(cached) " >&6 else if test -n "$ac_ct_OTOOL64"; then ac_cv_prog_ac_ct_OTOOL64="$ac_ct_OTOOL64" # Let the user override the test. else as_save_IFS=$IFS; IFS=$PATH_SEPARATOR for as_dir in $PATH do IFS=$as_save_IFS test -z "$as_dir" && as_dir=. for ac_exec_ext in '' $ac_executable_extensions; do if as_fn_executable_p "$as_dir/$ac_word$ac_exec_ext"; then ac_cv_prog_ac_ct_OTOOL64="otool64" $as_echo "$as_me:${as_lineno-$LINENO}: found $as_dir/$ac_word$ac_exec_ext" >&5 break 2 fi done done IFS=$as_save_IFS fi fi ac_ct_OTOOL64=$ac_cv_prog_ac_ct_OTOOL64 if test -n "$ac_ct_OTOOL64"; then { $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_ct_OTOOL64" >&5 $as_echo "$ac_ct_OTOOL64" >&6; } else { $as_echo "$as_me:${as_lineno-$LINENO}: result: no" >&5 $as_echo "no" >&6; } fi if test "x$ac_ct_OTOOL64" = x; then OTOOL64=":" else case $cross_compiling:$ac_tool_warned in yes:) { $as_echo "$as_me:${as_lineno-$LINENO}: WARNING: using cross tools not prefixed with host triplet" >&5 $as_echo "$as_me: WARNING: using cross tools not prefixed with host triplet" >&2;} ac_tool_warned=yes ;; esac OTOOL64=$ac_ct_OTOOL64 fi else OTOOL64="$ac_cv_prog_OTOOL64" fi { $as_echo "$as_me:${as_lineno-$LINENO}: checking for -single_module linker flag" >&5 $as_echo_n "checking for -single_module linker flag... " >&6; } if ${lt_cv_apple_cc_single_mod+:} false; then : $as_echo_n "(cached) " >&6 else lt_cv_apple_cc_single_mod=no if test -z "$LT_MULTI_MODULE"; then # By default we will add the -single_module flag. You can override # by either setting the environment variable LT_MULTI_MODULE # non-empty at configure time, or by adding -multi_module to the # link flags. rm -rf libconftest.dylib* echo "int foo(void){return 1;}" > conftest.c echo "$LTCC $LTCFLAGS $LDFLAGS -o libconftest.dylib \ -dynamiclib -Wl,-single_module conftest.c" >&5 $LTCC $LTCFLAGS $LDFLAGS -o libconftest.dylib \ -dynamiclib -Wl,-single_module conftest.c 2>conftest.err _lt_result=$? # If there is a non-empty error log, and "single_module" # appears in it, assume the flag caused a linker warning if test -s conftest.err && $GREP single_module conftest.err; then cat conftest.err >&5 # Otherwise, if the output was created with a 0 exit code from # the compiler, it worked. elif test -f libconftest.dylib && test 0 = "$_lt_result"; then lt_cv_apple_cc_single_mod=yes else cat conftest.err >&5 fi rm -rf libconftest.dylib* rm -f conftest.* fi fi { $as_echo "$as_me:${as_lineno-$LINENO}: result: $lt_cv_apple_cc_single_mod" >&5 $as_echo "$lt_cv_apple_cc_single_mod" >&6; } { $as_echo "$as_me:${as_lineno-$LINENO}: checking for -exported_symbols_list linker flag" >&5 $as_echo_n "checking for -exported_symbols_list linker flag... " >&6; } if ${lt_cv_ld_exported_symbols_list+:} false; then : $as_echo_n "(cached) " >&6 else lt_cv_ld_exported_symbols_list=no save_LDFLAGS=$LDFLAGS echo "_main" > conftest.sym LDFLAGS="$LDFLAGS -Wl,-exported_symbols_list,conftest.sym" cat confdefs.h - <<_ACEOF >conftest.$ac_ext /* end confdefs.h. */ int main () { ; return 0; } _ACEOF if ac_fn_c_try_link "$LINENO"; then : lt_cv_ld_exported_symbols_list=yes else lt_cv_ld_exported_symbols_list=no fi rm -f core conftest.err conftest.$ac_objext \ conftest$ac_exeext conftest.$ac_ext LDFLAGS=$save_LDFLAGS fi { $as_echo "$as_me:${as_lineno-$LINENO}: result: $lt_cv_ld_exported_symbols_list" >&5 $as_echo "$lt_cv_ld_exported_symbols_list" >&6; } { $as_echo "$as_me:${as_lineno-$LINENO}: checking for -force_load linker flag" >&5 $as_echo_n "checking for -force_load linker flag... " >&6; } if ${lt_cv_ld_force_load+:} false; then : $as_echo_n "(cached) " >&6 else lt_cv_ld_force_load=no cat > conftest.c << _LT_EOF int forced_loaded() { return 2;} _LT_EOF echo "$LTCC $LTCFLAGS -c -o conftest.o conftest.c" >&5 $LTCC $LTCFLAGS -c -o conftest.o conftest.c 2>&5 echo "$AR cru libconftest.a conftest.o" >&5 $AR cru libconftest.a conftest.o 2>&5 echo "$RANLIB libconftest.a" >&5 $RANLIB libconftest.a 2>&5 cat > conftest.c << _LT_EOF int main() { return 0;} _LT_EOF echo "$LTCC $LTCFLAGS $LDFLAGS -o conftest conftest.c -Wl,-force_load,./libconftest.a" >&5 $LTCC $LTCFLAGS $LDFLAGS -o conftest conftest.c -Wl,-force_load,./libconftest.a 2>conftest.err _lt_result=$? if test -s conftest.err && $GREP force_load conftest.err; then cat conftest.err >&5 elif test -f conftest && test 0 = "$_lt_result" && $GREP forced_load conftest >/dev/null 2>&1; then lt_cv_ld_force_load=yes else cat conftest.err >&5 fi rm -f conftest.err libconftest.a conftest conftest.c rm -rf conftest.dSYM fi { $as_echo "$as_me:${as_lineno-$LINENO}: result: $lt_cv_ld_force_load" >&5 $as_echo "$lt_cv_ld_force_load" >&6; } case $host_os in rhapsody* | darwin1.[012]) _lt_dar_allow_undefined='$wl-undefined ${wl}suppress' ;; darwin1.*) _lt_dar_allow_undefined='$wl-flat_namespace $wl-undefined ${wl}suppress' ;; darwin*) # darwin 5.x on # if running on 10.5 or later, the deployment target defaults # to the OS version, if on x86, and 10.4, the deployment # target defaults to 10.4. Don't you love it? case ${MACOSX_DEPLOYMENT_TARGET-10.0},$host in 10.0,*86*-darwin8*|10.0,*-darwin[91]*) _lt_dar_allow_undefined='$wl-undefined ${wl}dynamic_lookup' ;; 10.[012][,.]*) _lt_dar_allow_undefined='$wl-flat_namespace $wl-undefined ${wl}suppress' ;; 10.*) _lt_dar_allow_undefined='$wl-undefined ${wl}dynamic_lookup' ;; esac ;; esac if test yes = "$lt_cv_apple_cc_single_mod"; then _lt_dar_single_mod='$single_module' fi if test yes = "$lt_cv_ld_exported_symbols_list"; then _lt_dar_export_syms=' $wl-exported_symbols_list,$output_objdir/$libname-symbols.expsym' else _lt_dar_export_syms='~$NMEDIT -s $output_objdir/$libname-symbols.expsym $lib' fi if test : != "$DSYMUTIL" && test no = "$lt_cv_ld_force_load"; then _lt_dsymutil='~$DSYMUTIL $lib || :' else _lt_dsymutil= fi ;; esac # func_munge_path_list VARIABLE PATH # ----------------------------------- # VARIABLE is name of variable containing _space_ separated list of # directories to be munged by the contents of PATH, which is string # having a format: # "DIR[:DIR]:" # string "DIR[ DIR]" will be prepended to VARIABLE # ":DIR[:DIR]" # string "DIR[ DIR]" will be appended to VARIABLE # "DIRP[:DIRP]::[DIRA:]DIRA" # string "DIRP[ DIRP]" will be prepended to VARIABLE and string # "DIRA[ DIRA]" will be appended to VARIABLE # "DIR[:DIR]" # VARIABLE will be replaced by "DIR[ DIR]" func_munge_path_list () { case x$2 in x) ;; *:) eval $1=\"`$ECHO $2 | $SED 's/:/ /g'` \$$1\" ;; x:*) eval $1=\"\$$1 `$ECHO $2 | $SED 's/:/ /g'`\" ;; *::*) eval $1=\"\$$1\ `$ECHO $2 | $SED -e 's/.*:://' -e 's/:/ /g'`\" eval $1=\"`$ECHO $2 | $SED -e 's/::.*//' -e 's/:/ /g'`\ \$$1\" ;; *) eval $1=\"`$ECHO $2 | $SED 's/:/ /g'`\" ;; esac } ac_ext=c ac_cpp='$CPP $CPPFLAGS' ac_compile='$CC -c $CFLAGS $CPPFLAGS conftest.$ac_ext >&5' ac_link='$CC -o conftest$ac_exeext $CFLAGS $CPPFLAGS $LDFLAGS conftest.$ac_ext $LIBS >&5' ac_compiler_gnu=$ac_cv_c_compiler_gnu { $as_echo "$as_me:${as_lineno-$LINENO}: checking how to run the C preprocessor" >&5 $as_echo_n "checking how to run the C preprocessor... " >&6; } # On Suns, sometimes $CPP names a directory. if test -n "$CPP" && test -d "$CPP"; then CPP= fi if test -z "$CPP"; then if ${ac_cv_prog_CPP+:} false; then : $as_echo_n "(cached) " >&6 else # Double quotes because CPP needs to be expanded for CPP in "$CC -E" "$CC -E -traditional-cpp" "/lib/cpp" do ac_preproc_ok=false for ac_c_preproc_warn_flag in '' yes do # Use a header file that comes with gcc, so configuring glibc # with a fresh cross-compiler works. # Prefer to if __STDC__ is defined, since # exists even on freestanding compilers. # On the NeXT, cc -E runs the code through the compiler's parser, # not just through cpp. "Syntax error" is here to catch this case. cat confdefs.h - <<_ACEOF >conftest.$ac_ext /* end confdefs.h. */ #ifdef __STDC__ # include #else # include #endif Syntax error _ACEOF if ac_fn_c_try_cpp "$LINENO"; then : else # Broken: fails on valid input. continue fi rm -f conftest.err conftest.i conftest.$ac_ext # OK, works on sane cases. Now check whether nonexistent headers # can be detected and how. cat confdefs.h - <<_ACEOF >conftest.$ac_ext /* end confdefs.h. */ #include _ACEOF if ac_fn_c_try_cpp "$LINENO"; then : # Broken: success on invalid input. continue else # Passes both tests. ac_preproc_ok=: break fi rm -f conftest.err conftest.i conftest.$ac_ext done # Because of `break', _AC_PREPROC_IFELSE's cleaning code was skipped. rm -f conftest.i conftest.err conftest.$ac_ext if $ac_preproc_ok; then : break fi done ac_cv_prog_CPP=$CPP fi CPP=$ac_cv_prog_CPP else ac_cv_prog_CPP=$CPP fi { $as_echo "$as_me:${as_lineno-$LINENO}: result: $CPP" >&5 $as_echo "$CPP" >&6; } ac_preproc_ok=false for ac_c_preproc_warn_flag in '' yes do # Use a header file that comes with gcc, so configuring glibc # with a fresh cross-compiler works. # Prefer to if __STDC__ is defined, since # exists even on freestanding compilers. # On the NeXT, cc -E runs the code through the compiler's parser, # not just through cpp. "Syntax error" is here to catch this case. cat confdefs.h - <<_ACEOF >conftest.$ac_ext /* end confdefs.h. */ #ifdef __STDC__ # include #else # include #endif Syntax error _ACEOF if ac_fn_c_try_cpp "$LINENO"; then : else # Broken: fails on valid input. continue fi rm -f conftest.err conftest.i conftest.$ac_ext # OK, works on sane cases. Now check whether nonexistent headers # can be detected and how. cat confdefs.h - <<_ACEOF >conftest.$ac_ext /* end confdefs.h. */ #include _ACEOF if ac_fn_c_try_cpp "$LINENO"; then : # Broken: success on invalid input. continue else # Passes both tests. ac_preproc_ok=: break fi rm -f conftest.err conftest.i conftest.$ac_ext done # Because of `break', _AC_PREPROC_IFELSE's cleaning code was skipped. rm -f conftest.i conftest.err conftest.$ac_ext if $ac_preproc_ok; then : else { { $as_echo "$as_me:${as_lineno-$LINENO}: error: in \`$ac_pwd':" >&5 $as_echo "$as_me: error: in \`$ac_pwd':" >&2;} as_fn_error $? "C preprocessor \"$CPP\" fails sanity check See \`config.log' for more details" "$LINENO" 5; } fi ac_ext=c ac_cpp='$CPP $CPPFLAGS' ac_compile='$CC -c $CFLAGS $CPPFLAGS conftest.$ac_ext >&5' ac_link='$CC -o conftest$ac_exeext $CFLAGS $CPPFLAGS $LDFLAGS conftest.$ac_ext $LIBS >&5' ac_compiler_gnu=$ac_cv_c_compiler_gnu { $as_echo "$as_me:${as_lineno-$LINENO}: checking for ANSI C header files" >&5 $as_echo_n "checking for ANSI C header files... " >&6; } if ${ac_cv_header_stdc+:} false; then : $as_echo_n "(cached) " >&6 else cat confdefs.h - <<_ACEOF >conftest.$ac_ext /* end confdefs.h. */ #include #include #include #include int main () { ; return 0; } _ACEOF if ac_fn_c_try_compile "$LINENO"; then : ac_cv_header_stdc=yes else ac_cv_header_stdc=no fi rm -f core conftest.err conftest.$ac_objext conftest.$ac_ext if test $ac_cv_header_stdc = yes; then # SunOS 4.x string.h does not declare mem*, contrary to ANSI. cat confdefs.h - <<_ACEOF >conftest.$ac_ext /* end confdefs.h. */ #include _ACEOF if (eval "$ac_cpp conftest.$ac_ext") 2>&5 | $EGREP "memchr" >/dev/null 2>&1; then : else ac_cv_header_stdc=no fi rm -f conftest* fi if test $ac_cv_header_stdc = yes; then # ISC 2.0.2 stdlib.h does not declare free, contrary to ANSI. cat confdefs.h - <<_ACEOF >conftest.$ac_ext /* end confdefs.h. */ #include _ACEOF if (eval "$ac_cpp conftest.$ac_ext") 2>&5 | $EGREP "free" >/dev/null 2>&1; then : else ac_cv_header_stdc=no fi rm -f conftest* fi if test $ac_cv_header_stdc = yes; then # /bin/cc in Irix-4.0.5 gets non-ANSI ctype macros unless using -ansi. if test "$cross_compiling" = yes; then : : else cat confdefs.h - <<_ACEOF >conftest.$ac_ext /* end confdefs.h. */ #include #include #if ((' ' & 0x0FF) == 0x020) # define ISLOWER(c) ('a' <= (c) && (c) <= 'z') # define TOUPPER(c) (ISLOWER(c) ? 'A' + ((c) - 'a') : (c)) #else # define ISLOWER(c) \ (('a' <= (c) && (c) <= 'i') \ || ('j' <= (c) && (c) <= 'r') \ || ('s' <= (c) && (c) <= 'z')) # define TOUPPER(c) (ISLOWER(c) ? ((c) | 0x40) : (c)) #endif #define XOR(e, f) (((e) && !(f)) || (!(e) && (f))) int main () { int i; for (i = 0; i < 256; i++) if (XOR (islower (i), ISLOWER (i)) || toupper (i) != TOUPPER (i)) return 2; return 0; } _ACEOF if ac_fn_c_try_run "$LINENO"; then : else ac_cv_header_stdc=no fi rm -f core *.core core.conftest.* gmon.out bb.out conftest$ac_exeext \ conftest.$ac_objext conftest.beam conftest.$ac_ext fi fi fi { $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_cv_header_stdc" >&5 $as_echo "$ac_cv_header_stdc" >&6; } if test $ac_cv_header_stdc = yes; then $as_echo "#define STDC_HEADERS 1" >>confdefs.h fi # On IRIX 5.3, sys/types and inttypes.h are conflicting. for ac_header in sys/types.h sys/stat.h stdlib.h string.h memory.h strings.h \ inttypes.h stdint.h unistd.h do : as_ac_Header=`$as_echo "ac_cv_header_$ac_header" | $as_tr_sh` ac_fn_c_check_header_compile "$LINENO" "$ac_header" "$as_ac_Header" "$ac_includes_default " if eval test \"x\$"$as_ac_Header"\" = x"yes"; then : cat >>confdefs.h <<_ACEOF #define `$as_echo "HAVE_$ac_header" | $as_tr_cpp` 1 _ACEOF fi done for ac_header in dlfcn.h do : ac_fn_c_check_header_compile "$LINENO" "dlfcn.h" "ac_cv_header_dlfcn_h" "$ac_includes_default " if test "x$ac_cv_header_dlfcn_h" = xyes; then : cat >>confdefs.h <<_ACEOF #define HAVE_DLFCN_H 1 _ACEOF fi done # Set options enable_dlopen=no enable_win32_dll=no # Check whether --enable-shared was given. if test "${enable_shared+set}" = set; then : enableval=$enable_shared; p=${PACKAGE-default} case $enableval in yes) enable_shared=yes ;; no) enable_shared=no ;; *) enable_shared=no # Look at the argument we got. We use all the common list separators. lt_save_ifs=$IFS; IFS=$IFS$PATH_SEPARATOR, for pkg in $enableval; do IFS=$lt_save_ifs if test "X$pkg" = "X$p"; then enable_shared=yes fi done IFS=$lt_save_ifs ;; esac else enable_shared=yes fi # Check whether --enable-static was given. if test "${enable_static+set}" = set; then : enableval=$enable_static; p=${PACKAGE-default} case $enableval in yes) enable_static=yes ;; no) enable_static=no ;; *) enable_static=no # Look at the argument we got. We use all the common list separators. lt_save_ifs=$IFS; IFS=$IFS$PATH_SEPARATOR, for pkg in $enableval; do IFS=$lt_save_ifs if test "X$pkg" = "X$p"; then enable_static=yes fi done IFS=$lt_save_ifs ;; esac else enable_static=yes fi # Check whether --with-pic was given. if test "${with_pic+set}" = set; then : withval=$with_pic; lt_p=${PACKAGE-default} case $withval in yes|no) pic_mode=$withval ;; *) pic_mode=default # Look at the argument we got. We use all the common list separators. lt_save_ifs=$IFS; IFS=$IFS$PATH_SEPARATOR, for lt_pkg in $withval; do IFS=$lt_save_ifs if test "X$lt_pkg" = "X$lt_p"; then pic_mode=yes fi done IFS=$lt_save_ifs ;; esac else pic_mode=default fi # Check whether --enable-fast-install was given. if test "${enable_fast_install+set}" = set; then : enableval=$enable_fast_install; p=${PACKAGE-default} case $enableval in yes) enable_fast_install=yes ;; no) enable_fast_install=no ;; *) enable_fast_install=no # Look at the argument we got. We use all the common list separators. lt_save_ifs=$IFS; IFS=$IFS$PATH_SEPARATOR, for pkg in $enableval; do IFS=$lt_save_ifs if test "X$pkg" = "X$p"; then enable_fast_install=yes fi done IFS=$lt_save_ifs ;; esac else enable_fast_install=yes fi shared_archive_member_spec= case $host,$enable_shared in power*-*-aix[5-9]*,yes) { $as_echo "$as_me:${as_lineno-$LINENO}: checking which variant of shared library versioning to provide" >&5 $as_echo_n "checking which variant of shared library versioning to provide... " >&6; } # Check whether --with-aix-soname was given. if test "${with_aix_soname+set}" = set; then : withval=$with_aix_soname; case $withval in aix|svr4|both) ;; *) as_fn_error $? "Unknown argument to --with-aix-soname" "$LINENO" 5 ;; esac lt_cv_with_aix_soname=$with_aix_soname else if ${lt_cv_with_aix_soname+:} false; then : $as_echo_n "(cached) " >&6 else lt_cv_with_aix_soname=aix fi with_aix_soname=$lt_cv_with_aix_soname fi { $as_echo "$as_me:${as_lineno-$LINENO}: result: $with_aix_soname" >&5 $as_echo "$with_aix_soname" >&6; } if test aix != "$with_aix_soname"; then # For the AIX way of multilib, we name the shared archive member # based on the bitwidth used, traditionally 'shr.o' or 'shr_64.o', # and 'shr.imp' or 'shr_64.imp', respectively, for the Import File. # Even when GNU compilers ignore OBJECT_MODE but need '-maix64' flag, # the AIX toolchain works better with OBJECT_MODE set (default 32). if test 64 = "${OBJECT_MODE-32}"; then shared_archive_member_spec=shr_64 else shared_archive_member_spec=shr fi fi ;; *) with_aix_soname=aix ;; esac # This can be used to rebuild libtool when needed LIBTOOL_DEPS=$ltmain # Always use our own libtool. LIBTOOL='$(SHELL) $(top_builddir)/libtool' test -z "$LN_S" && LN_S="ln -s" if test -n "${ZSH_VERSION+set}"; then setopt NO_GLOB_SUBST fi { $as_echo "$as_me:${as_lineno-$LINENO}: checking for objdir" >&5 $as_echo_n "checking for objdir... " >&6; } if ${lt_cv_objdir+:} false; then : $as_echo_n "(cached) " >&6 else rm -f .libs 2>/dev/null mkdir .libs 2>/dev/null if test -d .libs; then lt_cv_objdir=.libs else # MS-DOS does not allow filenames that begin with a dot. lt_cv_objdir=_libs fi rmdir .libs 2>/dev/null fi { $as_echo "$as_me:${as_lineno-$LINENO}: result: $lt_cv_objdir" >&5 $as_echo "$lt_cv_objdir" >&6; } objdir=$lt_cv_objdir cat >>confdefs.h <<_ACEOF #define LT_OBJDIR "$lt_cv_objdir/" _ACEOF case $host_os in aix3*) # AIX sometimes has problems with the GCC collect2 program. For some # reason, if we set the COLLECT_NAMES environment variable, the problems # vanish in a puff of smoke. if test set != "${COLLECT_NAMES+set}"; then COLLECT_NAMES= export COLLECT_NAMES fi ;; esac # Global variables: ofile=libtool can_build_shared=yes # All known linkers require a '.a' archive for static linking (except MSVC, # which needs '.lib'). libext=a with_gnu_ld=$lt_cv_prog_gnu_ld old_CC=$CC old_CFLAGS=$CFLAGS # Set sane defaults for various variables test -z "$CC" && CC=cc test -z "$LTCC" && LTCC=$CC test -z "$LTCFLAGS" && LTCFLAGS=$CFLAGS test -z "$LD" && LD=ld test -z "$ac_objext" && ac_objext=o func_cc_basename $compiler cc_basename=$func_cc_basename_result # Only perform the check for file, if the check method requires it test -z "$MAGIC_CMD" && MAGIC_CMD=file case $deplibs_check_method in file_magic*) if test "$file_magic_cmd" = '$MAGIC_CMD'; then { $as_echo "$as_me:${as_lineno-$LINENO}: checking for ${ac_tool_prefix}file" >&5 $as_echo_n "checking for ${ac_tool_prefix}file... " >&6; } if ${lt_cv_path_MAGIC_CMD+:} false; then : $as_echo_n "(cached) " >&6 else case $MAGIC_CMD in [\\/*] | ?:[\\/]*) lt_cv_path_MAGIC_CMD=$MAGIC_CMD # Let the user override the test with a path. ;; *) lt_save_MAGIC_CMD=$MAGIC_CMD lt_save_ifs=$IFS; IFS=$PATH_SEPARATOR ac_dummy="/usr/bin$PATH_SEPARATOR$PATH" for ac_dir in $ac_dummy; do IFS=$lt_save_ifs test -z "$ac_dir" && ac_dir=. if test -f "$ac_dir/${ac_tool_prefix}file"; then lt_cv_path_MAGIC_CMD=$ac_dir/"${ac_tool_prefix}file" if test -n "$file_magic_test_file"; then case $deplibs_check_method in "file_magic "*) file_magic_regex=`expr "$deplibs_check_method" : "file_magic \(.*\)"` MAGIC_CMD=$lt_cv_path_MAGIC_CMD if eval $file_magic_cmd \$file_magic_test_file 2> /dev/null | $EGREP "$file_magic_regex" > /dev/null; then : else cat <<_LT_EOF 1>&2 *** Warning: the command libtool uses to detect shared libraries, *** $file_magic_cmd, produces output that libtool cannot recognize. *** The result is that libtool may fail to recognize shared libraries *** as such. This will affect the creation of libtool libraries that *** depend on shared libraries, but programs linked with such libtool *** libraries will work regardless of this problem. Nevertheless, you *** may want to report the problem to your system manager and/or to *** bug-libtool@gnu.org _LT_EOF fi ;; esac fi break fi done IFS=$lt_save_ifs MAGIC_CMD=$lt_save_MAGIC_CMD ;; esac fi MAGIC_CMD=$lt_cv_path_MAGIC_CMD if test -n "$MAGIC_CMD"; then { $as_echo "$as_me:${as_lineno-$LINENO}: result: $MAGIC_CMD" >&5 $as_echo "$MAGIC_CMD" >&6; } else { $as_echo "$as_me:${as_lineno-$LINENO}: result: no" >&5 $as_echo "no" >&6; } fi if test -z "$lt_cv_path_MAGIC_CMD"; then if test -n "$ac_tool_prefix"; then { $as_echo "$as_me:${as_lineno-$LINENO}: checking for file" >&5 $as_echo_n "checking for file... " >&6; } if ${lt_cv_path_MAGIC_CMD+:} false; then : $as_echo_n "(cached) " >&6 else case $MAGIC_CMD in [\\/*] | ?:[\\/]*) lt_cv_path_MAGIC_CMD=$MAGIC_CMD # Let the user override the test with a path. ;; *) lt_save_MAGIC_CMD=$MAGIC_CMD lt_save_ifs=$IFS; IFS=$PATH_SEPARATOR ac_dummy="/usr/bin$PATH_SEPARATOR$PATH" for ac_dir in $ac_dummy; do IFS=$lt_save_ifs test -z "$ac_dir" && ac_dir=. if test -f "$ac_dir/file"; then lt_cv_path_MAGIC_CMD=$ac_dir/"file" if test -n "$file_magic_test_file"; then case $deplibs_check_method in "file_magic "*) file_magic_regex=`expr "$deplibs_check_method" : "file_magic \(.*\)"` MAGIC_CMD=$lt_cv_path_MAGIC_CMD if eval $file_magic_cmd \$file_magic_test_file 2> /dev/null | $EGREP "$file_magic_regex" > /dev/null; then : else cat <<_LT_EOF 1>&2 *** Warning: the command libtool uses to detect shared libraries, *** $file_magic_cmd, produces output that libtool cannot recognize. *** The result is that libtool may fail to recognize shared libraries *** as such. This will affect the creation of libtool libraries that *** depend on shared libraries, but programs linked with such libtool *** libraries will work regardless of this problem. Nevertheless, you *** may want to report the problem to your system manager and/or to *** bug-libtool@gnu.org _LT_EOF fi ;; esac fi break fi done IFS=$lt_save_ifs MAGIC_CMD=$lt_save_MAGIC_CMD ;; esac fi MAGIC_CMD=$lt_cv_path_MAGIC_CMD if test -n "$MAGIC_CMD"; then { $as_echo "$as_me:${as_lineno-$LINENO}: result: $MAGIC_CMD" >&5 $as_echo "$MAGIC_CMD" >&6; } else { $as_echo "$as_me:${as_lineno-$LINENO}: result: no" >&5 $as_echo "no" >&6; } fi else MAGIC_CMD=: fi fi fi ;; esac # Use C for the default configuration in the libtool script lt_save_CC=$CC ac_ext=c ac_cpp='$CPP $CPPFLAGS' ac_compile='$CC -c $CFLAGS $CPPFLAGS conftest.$ac_ext >&5' ac_link='$CC -o conftest$ac_exeext $CFLAGS $CPPFLAGS $LDFLAGS conftest.$ac_ext $LIBS >&5' ac_compiler_gnu=$ac_cv_c_compiler_gnu # Source file extension for C test sources. ac_ext=c # Object file extension for compiled C test sources. objext=o objext=$objext # Code to be used in simple compile tests lt_simple_compile_test_code="int some_variable = 0;" # Code to be used in simple link tests lt_simple_link_test_code='int main(){return(0);}' # If no C compiler was specified, use CC. LTCC=${LTCC-"$CC"} # If no C compiler flags were specified, use CFLAGS. LTCFLAGS=${LTCFLAGS-"$CFLAGS"} # Allow CC to be a program name with arguments. compiler=$CC # Save the default compiler, since it gets overwritten when the other # tags are being tested, and _LT_TAGVAR(compiler, []) is a NOP. compiler_DEFAULT=$CC # save warnings/boilerplate of simple test code ac_outfile=conftest.$ac_objext echo "$lt_simple_compile_test_code" >conftest.$ac_ext eval "$ac_compile" 2>&1 >/dev/null | $SED '/^$/d; /^ *+/d' >conftest.err _lt_compiler_boilerplate=`cat conftest.err` $RM conftest* ac_outfile=conftest.$ac_objext echo "$lt_simple_link_test_code" >conftest.$ac_ext eval "$ac_link" 2>&1 >/dev/null | $SED '/^$/d; /^ *+/d' >conftest.err _lt_linker_boilerplate=`cat conftest.err` $RM -r conftest* ## CAVEAT EMPTOR: ## There is no encapsulation within the following macros, do not change ## the running order or otherwise move them around unless you know exactly ## what you are doing... if test -n "$compiler"; then lt_prog_compiler_no_builtin_flag= if test yes = "$GCC"; then case $cc_basename in nvcc*) lt_prog_compiler_no_builtin_flag=' -Xcompiler -fno-builtin' ;; *) lt_prog_compiler_no_builtin_flag=' -fno-builtin' ;; esac { $as_echo "$as_me:${as_lineno-$LINENO}: checking if $compiler supports -fno-rtti -fno-exceptions" >&5 $as_echo_n "checking if $compiler supports -fno-rtti -fno-exceptions... " >&6; } if ${lt_cv_prog_compiler_rtti_exceptions+:} false; then : $as_echo_n "(cached) " >&6 else lt_cv_prog_compiler_rtti_exceptions=no ac_outfile=conftest.$ac_objext echo "$lt_simple_compile_test_code" > conftest.$ac_ext lt_compiler_flag="-fno-rtti -fno-exceptions" ## exclude from sc_useless_quotes_in_assignment # Insert the option either (1) after the last *FLAGS variable, or # (2) before a word containing "conftest.", or (3) at the end. # Note that $ac_compile itself does not contain backslashes and begins # with a dollar sign (not a hyphen), so the echo should work correctly. # The option is referenced via a variable to avoid confusing sed. lt_compile=`echo "$ac_compile" | $SED \ -e 's:.*FLAGS}\{0,1\} :&$lt_compiler_flag :; t' \ -e 's: [^ ]*conftest\.: $lt_compiler_flag&:; t' \ -e 's:$: $lt_compiler_flag:'` (eval echo "\"\$as_me:$LINENO: $lt_compile\"" >&5) (eval "$lt_compile" 2>conftest.err) ac_status=$? cat conftest.err >&5 echo "$as_me:$LINENO: \$? = $ac_status" >&5 if (exit $ac_status) && test -s "$ac_outfile"; then # The compiler can only warn and ignore the option if not recognized # So say no if there are warnings other than the usual output. $ECHO "$_lt_compiler_boilerplate" | $SED '/^$/d' >conftest.exp $SED '/^$/d; /^ *+/d' conftest.err >conftest.er2 if test ! -s conftest.er2 || diff conftest.exp conftest.er2 >/dev/null; then lt_cv_prog_compiler_rtti_exceptions=yes fi fi $RM conftest* fi { $as_echo "$as_me:${as_lineno-$LINENO}: result: $lt_cv_prog_compiler_rtti_exceptions" >&5 $as_echo "$lt_cv_prog_compiler_rtti_exceptions" >&6; } if test yes = "$lt_cv_prog_compiler_rtti_exceptions"; then lt_prog_compiler_no_builtin_flag="$lt_prog_compiler_no_builtin_flag -fno-rtti -fno-exceptions" else : fi fi lt_prog_compiler_wl= lt_prog_compiler_pic= lt_prog_compiler_static= if test yes = "$GCC"; then lt_prog_compiler_wl='-Wl,' lt_prog_compiler_static='-static' case $host_os in aix*) # All AIX code is PIC. if test ia64 = "$host_cpu"; then # AIX 5 now supports IA64 processor lt_prog_compiler_static='-Bstatic' fi lt_prog_compiler_pic='-fPIC' ;; amigaos*) case $host_cpu in powerpc) # see comment about AmigaOS4 .so support lt_prog_compiler_pic='-fPIC' ;; m68k) # FIXME: we need at least 68020 code to build shared libraries, but # adding the '-m68020' flag to GCC prevents building anything better, # like '-m68040'. lt_prog_compiler_pic='-m68020 -resident32 -malways-restore-a4' ;; esac ;; beos* | irix5* | irix6* | nonstopux* | osf3* | osf4* | osf5*) # PIC is the default for these OSes. ;; mingw* | cygwin* | pw32* | os2* | cegcc*) # This hack is so that the source file can tell whether it is being # built for inclusion in a dll (and should export symbols for example). # Although the cygwin gcc ignores -fPIC, still need this for old-style # (--disable-auto-import) libraries lt_prog_compiler_pic='-DDLL_EXPORT' case $host_os in os2*) lt_prog_compiler_static='$wl-static' ;; esac ;; darwin* | rhapsody*) # PIC is the default on this platform # Common symbols not allowed in MH_DYLIB files lt_prog_compiler_pic='-fno-common' ;; haiku*) # PIC is the default for Haiku. # The "-static" flag exists, but is broken. lt_prog_compiler_static= ;; hpux*) # PIC is the default for 64-bit PA HP-UX, but not for 32-bit # PA HP-UX. On IA64 HP-UX, PIC is the default but the pic flag # sets the default TLS model and affects inlining. case $host_cpu in hppa*64*) # +Z the default ;; *) lt_prog_compiler_pic='-fPIC' ;; esac ;; interix[3-9]*) # Interix 3.x gcc -fpic/-fPIC options generate broken code. # Instead, we relocate shared libraries at runtime. ;; msdosdjgpp*) # Just because we use GCC doesn't mean we suddenly get shared libraries # on systems that don't support them. lt_prog_compiler_can_build_shared=no enable_shared=no ;; *nto* | *qnx*) # QNX uses GNU C++, but need to define -shared option too, otherwise # it will coredump. lt_prog_compiler_pic='-fPIC -shared' ;; sysv4*MP*) if test -d /usr/nec; then lt_prog_compiler_pic=-Kconform_pic fi ;; *) lt_prog_compiler_pic='-fPIC' ;; esac case $cc_basename in nvcc*) # Cuda Compiler Driver 2.2 lt_prog_compiler_wl='-Xlinker ' if test -n "$lt_prog_compiler_pic"; then lt_prog_compiler_pic="-Xcompiler $lt_prog_compiler_pic" fi ;; esac else # PORTME Check for flag to pass linker flags through the system compiler. case $host_os in aix*) lt_prog_compiler_wl='-Wl,' if test ia64 = "$host_cpu"; then # AIX 5 now supports IA64 processor lt_prog_compiler_static='-Bstatic' else lt_prog_compiler_static='-bnso -bI:/lib/syscalls.exp' fi ;; darwin* | rhapsody*) # PIC is the default on this platform # Common symbols not allowed in MH_DYLIB files lt_prog_compiler_pic='-fno-common' case $cc_basename in nagfor*) # NAG Fortran compiler lt_prog_compiler_wl='-Wl,-Wl,,' lt_prog_compiler_pic='-PIC' lt_prog_compiler_static='-Bstatic' ;; esac ;; mingw* | cygwin* | pw32* | os2* | cegcc*) # This hack is so that the source file can tell whether it is being # built for inclusion in a dll (and should export symbols for example). lt_prog_compiler_pic='-DDLL_EXPORT' case $host_os in os2*) lt_prog_compiler_static='$wl-static' ;; esac ;; hpux9* | hpux10* | hpux11*) lt_prog_compiler_wl='-Wl,' # PIC is the default for IA64 HP-UX and 64-bit HP-UX, but # not for PA HP-UX. case $host_cpu in hppa*64*|ia64*) # +Z the default ;; *) lt_prog_compiler_pic='+Z' ;; esac # Is there a better lt_prog_compiler_static that works with the bundled CC? lt_prog_compiler_static='$wl-a ${wl}archive' ;; irix5* | irix6* | nonstopux*) lt_prog_compiler_wl='-Wl,' # PIC (with -KPIC) is the default. lt_prog_compiler_static='-non_shared' ;; linux* | k*bsd*-gnu | kopensolaris*-gnu | gnu*) case $cc_basename in # old Intel for x86_64, which still supported -KPIC. ecc*) lt_prog_compiler_wl='-Wl,' lt_prog_compiler_pic='-KPIC' lt_prog_compiler_static='-static' ;; # icc used to be incompatible with GCC. # ICC 10 doesn't accept -KPIC any more. icc* | ifort*) lt_prog_compiler_wl='-Wl,' lt_prog_compiler_pic='-fPIC' lt_prog_compiler_static='-static' ;; # Lahey Fortran 8.1. lf95*) lt_prog_compiler_wl='-Wl,' lt_prog_compiler_pic='--shared' lt_prog_compiler_static='--static' ;; nagfor*) # NAG Fortran compiler lt_prog_compiler_wl='-Wl,-Wl,,' lt_prog_compiler_pic='-PIC' lt_prog_compiler_static='-Bstatic' ;; tcc*) # Fabrice Bellard et al's Tiny C Compiler lt_prog_compiler_wl='-Wl,' lt_prog_compiler_pic='-fPIC' lt_prog_compiler_static='-static' ;; pgcc* | pgf77* | pgf90* | pgf95* | pgfortran*) # Portland Group compilers (*not* the Pentium gcc compiler, # which looks to be a dead project) lt_prog_compiler_wl='-Wl,' lt_prog_compiler_pic='-fpic' lt_prog_compiler_static='-Bstatic' ;; ccc*) lt_prog_compiler_wl='-Wl,' # All Alpha code is PIC. lt_prog_compiler_static='-non_shared' ;; xl* | bgxl* | bgf* | mpixl*) # IBM XL C 8.0/Fortran 10.1, 11.1 on PPC and BlueGene lt_prog_compiler_wl='-Wl,' lt_prog_compiler_pic='-qpic' lt_prog_compiler_static='-qstaticlink' ;; *) case `$CC -V 2>&1 | sed 5q` in *Sun\ Ceres\ Fortran* | *Sun*Fortran*\ [1-7].* | *Sun*Fortran*\ 8.[0-3]*) # Sun Fortran 8.3 passes all unrecognized flags to the linker lt_prog_compiler_pic='-KPIC' lt_prog_compiler_static='-Bstatic' lt_prog_compiler_wl='' ;; *Sun\ F* | *Sun*Fortran*) lt_prog_compiler_pic='-KPIC' lt_prog_compiler_static='-Bstatic' lt_prog_compiler_wl='-Qoption ld ' ;; *Sun\ C*) # Sun C 5.9 lt_prog_compiler_pic='-KPIC' lt_prog_compiler_static='-Bstatic' lt_prog_compiler_wl='-Wl,' ;; *Intel*\ [CF]*Compiler*) lt_prog_compiler_wl='-Wl,' lt_prog_compiler_pic='-fPIC' lt_prog_compiler_static='-static' ;; *Portland\ Group*) lt_prog_compiler_wl='-Wl,' lt_prog_compiler_pic='-fpic' lt_prog_compiler_static='-Bstatic' ;; esac ;; esac ;; newsos6) lt_prog_compiler_pic='-KPIC' lt_prog_compiler_static='-Bstatic' ;; *nto* | *qnx*) # QNX uses GNU C++, but need to define -shared option too, otherwise # it will coredump. lt_prog_compiler_pic='-fPIC -shared' ;; osf3* | osf4* | osf5*) lt_prog_compiler_wl='-Wl,' # All OSF/1 code is PIC. lt_prog_compiler_static='-non_shared' ;; rdos*) lt_prog_compiler_static='-non_shared' ;; solaris*) lt_prog_compiler_pic='-KPIC' lt_prog_compiler_static='-Bstatic' case $cc_basename in f77* | f90* | f95* | sunf77* | sunf90* | sunf95*) lt_prog_compiler_wl='-Qoption ld ';; *) lt_prog_compiler_wl='-Wl,';; esac ;; sunos4*) lt_prog_compiler_wl='-Qoption ld ' lt_prog_compiler_pic='-PIC' lt_prog_compiler_static='-Bstatic' ;; sysv4 | sysv4.2uw2* | sysv4.3*) lt_prog_compiler_wl='-Wl,' lt_prog_compiler_pic='-KPIC' lt_prog_compiler_static='-Bstatic' ;; sysv4*MP*) if test -d /usr/nec; then lt_prog_compiler_pic='-Kconform_pic' lt_prog_compiler_static='-Bstatic' fi ;; sysv5* | unixware* | sco3.2v5* | sco5v6* | OpenUNIX*) lt_prog_compiler_wl='-Wl,' lt_prog_compiler_pic='-KPIC' lt_prog_compiler_static='-Bstatic' ;; unicos*) lt_prog_compiler_wl='-Wl,' lt_prog_compiler_can_build_shared=no ;; uts4*) lt_prog_compiler_pic='-pic' lt_prog_compiler_static='-Bstatic' ;; *) lt_prog_compiler_can_build_shared=no ;; esac fi case $host_os in # For platforms that do not support PIC, -DPIC is meaningless: *djgpp*) lt_prog_compiler_pic= ;; *) lt_prog_compiler_pic="$lt_prog_compiler_pic -DPIC" ;; esac { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $compiler option to produce PIC" >&5 $as_echo_n "checking for $compiler option to produce PIC... " >&6; } if ${lt_cv_prog_compiler_pic+:} false; then : $as_echo_n "(cached) " >&6 else lt_cv_prog_compiler_pic=$lt_prog_compiler_pic fi { $as_echo "$as_me:${as_lineno-$LINENO}: result: $lt_cv_prog_compiler_pic" >&5 $as_echo "$lt_cv_prog_compiler_pic" >&6; } lt_prog_compiler_pic=$lt_cv_prog_compiler_pic # # Check to make sure the PIC flag actually works. # if test -n "$lt_prog_compiler_pic"; then { $as_echo "$as_me:${as_lineno-$LINENO}: checking if $compiler PIC flag $lt_prog_compiler_pic works" >&5 $as_echo_n "checking if $compiler PIC flag $lt_prog_compiler_pic works... " >&6; } if ${lt_cv_prog_compiler_pic_works+:} false; then : $as_echo_n "(cached) " >&6 else lt_cv_prog_compiler_pic_works=no ac_outfile=conftest.$ac_objext echo "$lt_simple_compile_test_code" > conftest.$ac_ext lt_compiler_flag="$lt_prog_compiler_pic -DPIC" ## exclude from sc_useless_quotes_in_assignment # Insert the option either (1) after the last *FLAGS variable, or # (2) before a word containing "conftest.", or (3) at the end. # Note that $ac_compile itself does not contain backslashes and begins # with a dollar sign (not a hyphen), so the echo should work correctly. # The option is referenced via a variable to avoid confusing sed. lt_compile=`echo "$ac_compile" | $SED \ -e 's:.*FLAGS}\{0,1\} :&$lt_compiler_flag :; t' \ -e 's: [^ ]*conftest\.: $lt_compiler_flag&:; t' \ -e 's:$: $lt_compiler_flag:'` (eval echo "\"\$as_me:$LINENO: $lt_compile\"" >&5) (eval "$lt_compile" 2>conftest.err) ac_status=$? cat conftest.err >&5 echo "$as_me:$LINENO: \$? = $ac_status" >&5 if (exit $ac_status) && test -s "$ac_outfile"; then # The compiler can only warn and ignore the option if not recognized # So say no if there are warnings other than the usual output. $ECHO "$_lt_compiler_boilerplate" | $SED '/^$/d' >conftest.exp $SED '/^$/d; /^ *+/d' conftest.err >conftest.er2 if test ! -s conftest.er2 || diff conftest.exp conftest.er2 >/dev/null; then lt_cv_prog_compiler_pic_works=yes fi fi $RM conftest* fi { $as_echo "$as_me:${as_lineno-$LINENO}: result: $lt_cv_prog_compiler_pic_works" >&5 $as_echo "$lt_cv_prog_compiler_pic_works" >&6; } if test yes = "$lt_cv_prog_compiler_pic_works"; then case $lt_prog_compiler_pic in "" | " "*) ;; *) lt_prog_compiler_pic=" $lt_prog_compiler_pic" ;; esac else lt_prog_compiler_pic= lt_prog_compiler_can_build_shared=no fi fi # # Check to make sure the static flag actually works. # wl=$lt_prog_compiler_wl eval lt_tmp_static_flag=\"$lt_prog_compiler_static\" { $as_echo "$as_me:${as_lineno-$LINENO}: checking if $compiler static flag $lt_tmp_static_flag works" >&5 $as_echo_n "checking if $compiler static flag $lt_tmp_static_flag works... " >&6; } if ${lt_cv_prog_compiler_static_works+:} false; then : $as_echo_n "(cached) " >&6 else lt_cv_prog_compiler_static_works=no save_LDFLAGS=$LDFLAGS LDFLAGS="$LDFLAGS $lt_tmp_static_flag" echo "$lt_simple_link_test_code" > conftest.$ac_ext if (eval $ac_link 2>conftest.err) && test -s conftest$ac_exeext; then # The linker can only warn and ignore the option if not recognized # So say no if there are warnings if test -s conftest.err; then # Append any errors to the config.log. cat conftest.err 1>&5 $ECHO "$_lt_linker_boilerplate" | $SED '/^$/d' > conftest.exp $SED '/^$/d; /^ *+/d' conftest.err >conftest.er2 if diff conftest.exp conftest.er2 >/dev/null; then lt_cv_prog_compiler_static_works=yes fi else lt_cv_prog_compiler_static_works=yes fi fi $RM -r conftest* LDFLAGS=$save_LDFLAGS fi { $as_echo "$as_me:${as_lineno-$LINENO}: result: $lt_cv_prog_compiler_static_works" >&5 $as_echo "$lt_cv_prog_compiler_static_works" >&6; } if test yes = "$lt_cv_prog_compiler_static_works"; then : else lt_prog_compiler_static= fi { $as_echo "$as_me:${as_lineno-$LINENO}: checking if $compiler supports -c -o file.$ac_objext" >&5 $as_echo_n "checking if $compiler supports -c -o file.$ac_objext... " >&6; } if ${lt_cv_prog_compiler_c_o+:} false; then : $as_echo_n "(cached) " >&6 else lt_cv_prog_compiler_c_o=no $RM -r conftest 2>/dev/null mkdir conftest cd conftest mkdir out echo "$lt_simple_compile_test_code" > conftest.$ac_ext lt_compiler_flag="-o out/conftest2.$ac_objext" # Insert the option either (1) after the last *FLAGS variable, or # (2) before a word containing "conftest.", or (3) at the end. # Note that $ac_compile itself does not contain backslashes and begins # with a dollar sign (not a hyphen), so the echo should work correctly. lt_compile=`echo "$ac_compile" | $SED \ -e 's:.*FLAGS}\{0,1\} :&$lt_compiler_flag :; t' \ -e 's: [^ ]*conftest\.: $lt_compiler_flag&:; t' \ -e 's:$: $lt_compiler_flag:'` (eval echo "\"\$as_me:$LINENO: $lt_compile\"" >&5) (eval "$lt_compile" 2>out/conftest.err) ac_status=$? cat out/conftest.err >&5 echo "$as_me:$LINENO: \$? = $ac_status" >&5 if (exit $ac_status) && test -s out/conftest2.$ac_objext then # The compiler can only warn and ignore the option if not recognized # So say no if there are warnings $ECHO "$_lt_compiler_boilerplate" | $SED '/^$/d' > out/conftest.exp $SED '/^$/d; /^ *+/d' out/conftest.err >out/conftest.er2 if test ! -s out/conftest.er2 || diff out/conftest.exp out/conftest.er2 >/dev/null; then lt_cv_prog_compiler_c_o=yes fi fi chmod u+w . 2>&5 $RM conftest* # SGI C++ compiler will create directory out/ii_files/ for # template instantiation test -d out/ii_files && $RM out/ii_files/* && rmdir out/ii_files $RM out/* && rmdir out cd .. $RM -r conftest $RM conftest* fi { $as_echo "$as_me:${as_lineno-$LINENO}: result: $lt_cv_prog_compiler_c_o" >&5 $as_echo "$lt_cv_prog_compiler_c_o" >&6; } { $as_echo "$as_me:${as_lineno-$LINENO}: checking if $compiler supports -c -o file.$ac_objext" >&5 $as_echo_n "checking if $compiler supports -c -o file.$ac_objext... " >&6; } if ${lt_cv_prog_compiler_c_o+:} false; then : $as_echo_n "(cached) " >&6 else lt_cv_prog_compiler_c_o=no $RM -r conftest 2>/dev/null mkdir conftest cd conftest mkdir out echo "$lt_simple_compile_test_code" > conftest.$ac_ext lt_compiler_flag="-o out/conftest2.$ac_objext" # Insert the option either (1) after the last *FLAGS variable, or # (2) before a word containing "conftest.", or (3) at the end. # Note that $ac_compile itself does not contain backslashes and begins # with a dollar sign (not a hyphen), so the echo should work correctly. lt_compile=`echo "$ac_compile" | $SED \ -e 's:.*FLAGS}\{0,1\} :&$lt_compiler_flag :; t' \ -e 's: [^ ]*conftest\.: $lt_compiler_flag&:; t' \ -e 's:$: $lt_compiler_flag:'` (eval echo "\"\$as_me:$LINENO: $lt_compile\"" >&5) (eval "$lt_compile" 2>out/conftest.err) ac_status=$? cat out/conftest.err >&5 echo "$as_me:$LINENO: \$? = $ac_status" >&5 if (exit $ac_status) && test -s out/conftest2.$ac_objext then # The compiler can only warn and ignore the option if not recognized # So say no if there are warnings $ECHO "$_lt_compiler_boilerplate" | $SED '/^$/d' > out/conftest.exp $SED '/^$/d; /^ *+/d' out/conftest.err >out/conftest.er2 if test ! -s out/conftest.er2 || diff out/conftest.exp out/conftest.er2 >/dev/null; then lt_cv_prog_compiler_c_o=yes fi fi chmod u+w . 2>&5 $RM conftest* # SGI C++ compiler will create directory out/ii_files/ for # template instantiation test -d out/ii_files && $RM out/ii_files/* && rmdir out/ii_files $RM out/* && rmdir out cd .. $RM -r conftest $RM conftest* fi { $as_echo "$as_me:${as_lineno-$LINENO}: result: $lt_cv_prog_compiler_c_o" >&5 $as_echo "$lt_cv_prog_compiler_c_o" >&6; } hard_links=nottested if test no = "$lt_cv_prog_compiler_c_o" && test no != "$need_locks"; then # do not overwrite the value of need_locks provided by the user { $as_echo "$as_me:${as_lineno-$LINENO}: checking if we can lock with hard links" >&5 $as_echo_n "checking if we can lock with hard links... " >&6; } hard_links=yes $RM conftest* ln conftest.a conftest.b 2>/dev/null && hard_links=no touch conftest.a ln conftest.a conftest.b 2>&5 || hard_links=no ln conftest.a conftest.b 2>/dev/null && hard_links=no { $as_echo "$as_me:${as_lineno-$LINENO}: result: $hard_links" >&5 $as_echo "$hard_links" >&6; } if test no = "$hard_links"; then { $as_echo "$as_me:${as_lineno-$LINENO}: WARNING: '$CC' does not support '-c -o', so 'make -j' may be unsafe" >&5 $as_echo "$as_me: WARNING: '$CC' does not support '-c -o', so 'make -j' may be unsafe" >&2;} need_locks=warn fi else need_locks=no fi { $as_echo "$as_me:${as_lineno-$LINENO}: checking whether the $compiler linker ($LD) supports shared libraries" >&5 $as_echo_n "checking whether the $compiler linker ($LD) supports shared libraries... " >&6; } runpath_var= allow_undefined_flag= always_export_symbols=no archive_cmds= archive_expsym_cmds= compiler_needs_object=no enable_shared_with_static_runtimes=no export_dynamic_flag_spec= export_symbols_cmds='$NM $libobjs $convenience | $global_symbol_pipe | $SED '\''s/.* //'\'' | sort | uniq > $export_symbols' hardcode_automatic=no hardcode_direct=no hardcode_direct_absolute=no hardcode_libdir_flag_spec= hardcode_libdir_separator= hardcode_minus_L=no hardcode_shlibpath_var=unsupported inherit_rpath=no link_all_deplibs=unknown module_cmds= module_expsym_cmds= old_archive_from_new_cmds= old_archive_from_expsyms_cmds= thread_safe_flag_spec= whole_archive_flag_spec= # include_expsyms should be a list of space-separated symbols to be *always* # included in the symbol list include_expsyms= # exclude_expsyms can be an extended regexp of symbols to exclude # it will be wrapped by ' (' and ')$', so one must not match beginning or # end of line. Example: 'a|bc|.*d.*' will exclude the symbols 'a' and 'bc', # as well as any symbol that contains 'd'. exclude_expsyms='_GLOBAL_OFFSET_TABLE_|_GLOBAL__F[ID]_.*' # Although _GLOBAL_OFFSET_TABLE_ is a valid symbol C name, most a.out # platforms (ab)use it in PIC code, but their linkers get confused if # the symbol is explicitly referenced. Since portable code cannot # rely on this symbol name, it's probably fine to never include it in # preloaded symbol tables. # Exclude shared library initialization/finalization symbols. extract_expsyms_cmds= case $host_os in cygwin* | mingw* | pw32* | cegcc*) # FIXME: the MSVC++ port hasn't been tested in a loooong time # When not using gcc, we currently assume that we are using # Microsoft Visual C++. if test yes != "$GCC"; then with_gnu_ld=no fi ;; interix*) # we just hope/assume this is gcc and not c89 (= MSVC++) with_gnu_ld=yes ;; openbsd* | bitrig*) with_gnu_ld=no ;; esac ld_shlibs=yes # On some targets, GNU ld is compatible enough with the native linker # that we're better off using the native interface for both. lt_use_gnu_ld_interface=no if test yes = "$with_gnu_ld"; then case $host_os in aix*) # The AIX port of GNU ld has always aspired to compatibility # with the native linker. However, as the warning in the GNU ld # block says, versions before 2.19.5* couldn't really create working # shared libraries, regardless of the interface used. case `$LD -v 2>&1` in *\ \(GNU\ Binutils\)\ 2.19.5*) ;; *\ \(GNU\ Binutils\)\ 2.[2-9]*) ;; *\ \(GNU\ Binutils\)\ [3-9]*) ;; *) lt_use_gnu_ld_interface=yes ;; esac ;; *) lt_use_gnu_ld_interface=yes ;; esac fi if test yes = "$lt_use_gnu_ld_interface"; then # If archive_cmds runs LD, not CC, wlarc should be empty wlarc='$wl' # Set some defaults for GNU ld with shared library support. These # are reset later if shared libraries are not supported. Putting them # here allows them to be overridden if necessary. runpath_var=LD_RUN_PATH hardcode_libdir_flag_spec='$wl-rpath $wl$libdir' export_dynamic_flag_spec='$wl--export-dynamic' # ancient GNU ld didn't support --whole-archive et. al. if $LD --help 2>&1 | $GREP 'no-whole-archive' > /dev/null; then whole_archive_flag_spec=$wlarc'--whole-archive$convenience '$wlarc'--no-whole-archive' else whole_archive_flag_spec= fi supports_anon_versioning=no case `$LD -v | $SED -e 's/(^)\+)\s\+//' 2>&1` in *GNU\ gold*) supports_anon_versioning=yes ;; *\ [01].* | *\ 2.[0-9].* | *\ 2.10.*) ;; # catch versions < 2.11 *\ 2.11.93.0.2\ *) supports_anon_versioning=yes ;; # RH7.3 ... *\ 2.11.92.0.12\ *) supports_anon_versioning=yes ;; # Mandrake 8.2 ... *\ 2.11.*) ;; # other 2.11 versions *) supports_anon_versioning=yes ;; esac # See if GNU ld supports shared libraries. case $host_os in aix[3-9]*) # On AIX/PPC, the GNU linker is very broken if test ia64 != "$host_cpu"; then ld_shlibs=no cat <<_LT_EOF 1>&2 *** Warning: the GNU linker, at least up to release 2.19, is reported *** to be unable to reliably create shared libraries on AIX. *** Therefore, libtool is disabling shared libraries support. If you *** really care for shared libraries, you may want to install binutils *** 2.20 or above, or modify your PATH so that a non-GNU linker is found. *** You will then need to restart the configuration process. _LT_EOF fi ;; amigaos*) case $host_cpu in powerpc) # see comment about AmigaOS4 .so support archive_cmds='$CC -shared $libobjs $deplibs $compiler_flags $wl-soname $wl$soname -o $lib' archive_expsym_cmds='' ;; m68k) archive_cmds='$RM $output_objdir/a2ixlibrary.data~$ECHO "#define NAME $libname" > $output_objdir/a2ixlibrary.data~$ECHO "#define LIBRARY_ID 1" >> $output_objdir/a2ixlibrary.data~$ECHO "#define VERSION $major" >> $output_objdir/a2ixlibrary.data~$ECHO "#define REVISION $revision" >> $output_objdir/a2ixlibrary.data~$AR $AR_FLAGS $lib $libobjs~$RANLIB $lib~(cd $output_objdir && a2ixlibrary -32)' hardcode_libdir_flag_spec='-L$libdir' hardcode_minus_L=yes ;; esac ;; beos*) if $LD --help 2>&1 | $GREP ': supported targets:.* elf' > /dev/null; then allow_undefined_flag=unsupported # Joseph Beckenbach says some releases of gcc # support --undefined. This deserves some investigation. FIXME archive_cmds='$CC -nostart $libobjs $deplibs $compiler_flags $wl-soname $wl$soname -o $lib' else ld_shlibs=no fi ;; cygwin* | mingw* | pw32* | cegcc*) # _LT_TAGVAR(hardcode_libdir_flag_spec, ) is actually meaningless, # as there is no search path for DLLs. hardcode_libdir_flag_spec='-L$libdir' export_dynamic_flag_spec='$wl--export-all-symbols' allow_undefined_flag=unsupported always_export_symbols=no enable_shared_with_static_runtimes=yes export_symbols_cmds='$NM $libobjs $convenience | $global_symbol_pipe | $SED -e '\''/^[BCDGRS][ ]/s/.*[ ]\([^ ]*\)/\1 DATA/;s/^.*[ ]__nm__\([^ ]*\)[ ][^ ]*/\1 DATA/;/^I[ ]/d;/^[AITW][ ]/s/.* //'\'' | sort | uniq > $export_symbols' exclude_expsyms='[_]+GLOBAL_OFFSET_TABLE_|[_]+GLOBAL__[FID]_.*|[_]+head_[A-Za-z0-9_]+_dll|[A-Za-z0-9_]+_dll_iname' if $LD --help 2>&1 | $GREP 'auto-import' > /dev/null; then archive_cmds='$CC -shared $libobjs $deplibs $compiler_flags -o $output_objdir/$soname $wl--enable-auto-image-base -Xlinker --out-implib -Xlinker $lib' # If the export-symbols file already is a .def file, use it as # is; otherwise, prepend EXPORTS... archive_expsym_cmds='if test DEF = "`$SED -n -e '\''s/^[ ]*//'\'' -e '\''/^\(;.*\)*$/d'\'' -e '\''s/^\(EXPORTS\|LIBRARY\)\([ ].*\)*$/DEF/p'\'' -e q $export_symbols`" ; then cp $export_symbols $output_objdir/$soname.def; else echo EXPORTS > $output_objdir/$soname.def; cat $export_symbols >> $output_objdir/$soname.def; fi~ $CC -shared $output_objdir/$soname.def $libobjs $deplibs $compiler_flags -o $output_objdir/$soname $wl--enable-auto-image-base -Xlinker --out-implib -Xlinker $lib' else ld_shlibs=no fi ;; haiku*) archive_cmds='$CC -shared $libobjs $deplibs $compiler_flags $wl-soname $wl$soname -o $lib' link_all_deplibs=yes ;; os2*) hardcode_libdir_flag_spec='-L$libdir' hardcode_minus_L=yes allow_undefined_flag=unsupported shrext_cmds=.dll archive_cmds='$ECHO "LIBRARY ${soname%$shared_ext} INITINSTANCE TERMINSTANCE" > $output_objdir/$libname.def~ $ECHO "DESCRIPTION \"$libname\"" >> $output_objdir/$libname.def~ $ECHO "DATA MULTIPLE NONSHARED" >> $output_objdir/$libname.def~ $ECHO EXPORTS >> $output_objdir/$libname.def~ emxexp $libobjs | $SED /"_DLL_InitTerm"/d >> $output_objdir/$libname.def~ $CC -Zdll -Zcrtdll -o $output_objdir/$soname $libobjs $deplibs $compiler_flags $output_objdir/$libname.def~ emximp -o $lib $output_objdir/$libname.def' archive_expsym_cmds='$ECHO "LIBRARY ${soname%$shared_ext} INITINSTANCE TERMINSTANCE" > $output_objdir/$libname.def~ $ECHO "DESCRIPTION \"$libname\"" >> $output_objdir/$libname.def~ $ECHO "DATA MULTIPLE NONSHARED" >> $output_objdir/$libname.def~ $ECHO EXPORTS >> $output_objdir/$libname.def~ prefix_cmds="$SED"~ if test EXPORTS = "`$SED 1q $export_symbols`"; then prefix_cmds="$prefix_cmds -e 1d"; fi~ prefix_cmds="$prefix_cmds -e \"s/^\(.*\)$/_\1/g\""~ cat $export_symbols | $prefix_cmds >> $output_objdir/$libname.def~ $CC -Zdll -Zcrtdll -o $output_objdir/$soname $libobjs $deplibs $compiler_flags $output_objdir/$libname.def~ emximp -o $lib $output_objdir/$libname.def' old_archive_From_new_cmds='emximp -o $output_objdir/${libname}_dll.a $output_objdir/$libname.def' enable_shared_with_static_runtimes=yes ;; interix[3-9]*) hardcode_direct=no hardcode_shlibpath_var=no hardcode_libdir_flag_spec='$wl-rpath,$libdir' export_dynamic_flag_spec='$wl-E' # Hack: On Interix 3.x, we cannot compile PIC because of a broken gcc. # Instead, shared libraries are loaded at an image base (0x10000000 by # default) and relocated if they conflict, which is a slow very memory # consuming and fragmenting process. To avoid this, we pick a random, # 256 KiB-aligned image base between 0x50000000 and 0x6FFC0000 at link # time. Moving up from 0x10000000 also allows more sbrk(2) space. archive_cmds='$CC -shared $pic_flag $libobjs $deplibs $compiler_flags $wl-h,$soname $wl--image-base,`expr ${RANDOM-$$} % 4096 / 2 \* 262144 + 1342177280` -o $lib' archive_expsym_cmds='sed "s|^|_|" $export_symbols >$output_objdir/$soname.expsym~$CC -shared $pic_flag $libobjs $deplibs $compiler_flags $wl-h,$soname $wl--retain-symbols-file,$output_objdir/$soname.expsym $wl--image-base,`expr ${RANDOM-$$} % 4096 / 2 \* 262144 + 1342177280` -o $lib' ;; gnu* | linux* | tpf* | k*bsd*-gnu | kopensolaris*-gnu) tmp_diet=no if test linux-dietlibc = "$host_os"; then case $cc_basename in diet\ *) tmp_diet=yes;; # linux-dietlibc with static linking (!diet-dyn) esac fi if $LD --help 2>&1 | $EGREP ': supported targets:.* elf' > /dev/null \ && test no = "$tmp_diet" then tmp_addflag=' $pic_flag' tmp_sharedflag='-shared' case $cc_basename,$host_cpu in pgcc*) # Portland Group C compiler whole_archive_flag_spec='$wl--whole-archive`for conv in $convenience\"\"; do test -n \"$conv\" && new_convenience=\"$new_convenience,$conv\"; done; func_echo_all \"$new_convenience\"` $wl--no-whole-archive' tmp_addflag=' $pic_flag' ;; pgf77* | pgf90* | pgf95* | pgfortran*) # Portland Group f77 and f90 compilers whole_archive_flag_spec='$wl--whole-archive`for conv in $convenience\"\"; do test -n \"$conv\" && new_convenience=\"$new_convenience,$conv\"; done; func_echo_all \"$new_convenience\"` $wl--no-whole-archive' tmp_addflag=' $pic_flag -Mnomain' ;; ecc*,ia64* | icc*,ia64*) # Intel C compiler on ia64 tmp_addflag=' -i_dynamic' ;; efc*,ia64* | ifort*,ia64*) # Intel Fortran compiler on ia64 tmp_addflag=' -i_dynamic -nofor_main' ;; ifc* | ifort*) # Intel Fortran compiler tmp_addflag=' -nofor_main' ;; lf95*) # Lahey Fortran 8.1 whole_archive_flag_spec= tmp_sharedflag='--shared' ;; nagfor*) # NAGFOR 5.3 tmp_sharedflag='-Wl,-shared' ;; xl[cC]* | bgxl[cC]* | mpixl[cC]*) # IBM XL C 8.0 on PPC (deal with xlf below) tmp_sharedflag='-qmkshrobj' tmp_addflag= ;; nvcc*) # Cuda Compiler Driver 2.2 whole_archive_flag_spec='$wl--whole-archive`for conv in $convenience\"\"; do test -n \"$conv\" && new_convenience=\"$new_convenience,$conv\"; done; func_echo_all \"$new_convenience\"` $wl--no-whole-archive' compiler_needs_object=yes ;; esac case `$CC -V 2>&1 | sed 5q` in *Sun\ C*) # Sun C 5.9 whole_archive_flag_spec='$wl--whole-archive`new_convenience=; for conv in $convenience\"\"; do test -z \"$conv\" || new_convenience=\"$new_convenience,$conv\"; done; func_echo_all \"$new_convenience\"` $wl--no-whole-archive' compiler_needs_object=yes tmp_sharedflag='-G' ;; *Sun\ F*) # Sun Fortran 8.3 tmp_sharedflag='-G' ;; esac archive_cmds='$CC '"$tmp_sharedflag""$tmp_addflag"' $libobjs $deplibs $compiler_flags $wl-soname $wl$soname -o $lib' if test yes = "$supports_anon_versioning"; then archive_expsym_cmds='echo "{ global:" > $output_objdir/$libname.ver~ cat $export_symbols | sed -e "s/\(.*\)/\1;/" >> $output_objdir/$libname.ver~ echo "local: *; };" >> $output_objdir/$libname.ver~ $CC '"$tmp_sharedflag""$tmp_addflag"' $libobjs $deplibs $compiler_flags $wl-soname $wl$soname $wl-version-script $wl$output_objdir/$libname.ver -o $lib' fi case $cc_basename in tcc*) export_dynamic_flag_spec='-rdynamic' ;; xlf* | bgf* | bgxlf* | mpixlf*) # IBM XL Fortran 10.1 on PPC cannot create shared libs itself whole_archive_flag_spec='--whole-archive$convenience --no-whole-archive' hardcode_libdir_flag_spec='$wl-rpath $wl$libdir' archive_cmds='$LD -shared $libobjs $deplibs $linker_flags -soname $soname -o $lib' if test yes = "$supports_anon_versioning"; then archive_expsym_cmds='echo "{ global:" > $output_objdir/$libname.ver~ cat $export_symbols | sed -e "s/\(.*\)/\1;/" >> $output_objdir/$libname.ver~ echo "local: *; };" >> $output_objdir/$libname.ver~ $LD -shared $libobjs $deplibs $linker_flags -soname $soname -version-script $output_objdir/$libname.ver -o $lib' fi ;; esac else ld_shlibs=no fi ;; netbsd*) if echo __ELF__ | $CC -E - | $GREP __ELF__ >/dev/null; then archive_cmds='$LD -Bshareable $libobjs $deplibs $linker_flags -o $lib' wlarc= else archive_cmds='$CC -shared $pic_flag $libobjs $deplibs $compiler_flags $wl-soname $wl$soname -o $lib' archive_expsym_cmds='$CC -shared $pic_flag $libobjs $deplibs $compiler_flags $wl-soname $wl$soname $wl-retain-symbols-file $wl$export_symbols -o $lib' fi ;; solaris*) if $LD -v 2>&1 | $GREP 'BFD 2\.8' > /dev/null; then ld_shlibs=no cat <<_LT_EOF 1>&2 *** Warning: The releases 2.8.* of the GNU linker cannot reliably *** create shared libraries on Solaris systems. Therefore, libtool *** is disabling shared libraries support. We urge you to upgrade GNU *** binutils to release 2.9.1 or newer. Another option is to modify *** your PATH or compiler configuration so that the native linker is *** used, and then restart. _LT_EOF elif $LD --help 2>&1 | $GREP ': supported targets:.* elf' > /dev/null; then archive_cmds='$CC -shared $pic_flag $libobjs $deplibs $compiler_flags $wl-soname $wl$soname -o $lib' archive_expsym_cmds='$CC -shared $pic_flag $libobjs $deplibs $compiler_flags $wl-soname $wl$soname $wl-retain-symbols-file $wl$export_symbols -o $lib' else ld_shlibs=no fi ;; sysv5* | sco3.2v5* | sco5v6* | unixware* | OpenUNIX*) case `$LD -v 2>&1` in *\ [01].* | *\ 2.[0-9].* | *\ 2.1[0-5].*) ld_shlibs=no cat <<_LT_EOF 1>&2 *** Warning: Releases of the GNU linker prior to 2.16.91.0.3 cannot *** reliably create shared libraries on SCO systems. Therefore, libtool *** is disabling shared libraries support. We urge you to upgrade GNU *** binutils to release 2.16.91.0.3 or newer. Another option is to modify *** your PATH or compiler configuration so that the native linker is *** used, and then restart. _LT_EOF ;; *) # For security reasons, it is highly recommended that you always # use absolute paths for naming shared libraries, and exclude the # DT_RUNPATH tag from executables and libraries. But doing so # requires that you compile everything twice, which is a pain. if $LD --help 2>&1 | $GREP ': supported targets:.* elf' > /dev/null; then hardcode_libdir_flag_spec='$wl-rpath $wl$libdir' archive_cmds='$CC -shared $libobjs $deplibs $compiler_flags $wl-soname $wl$soname -o $lib' archive_expsym_cmds='$CC -shared $libobjs $deplibs $compiler_flags $wl-soname $wl$soname $wl-retain-symbols-file $wl$export_symbols -o $lib' else ld_shlibs=no fi ;; esac ;; sunos4*) archive_cmds='$LD -assert pure-text -Bshareable -o $lib $libobjs $deplibs $linker_flags' wlarc= hardcode_direct=yes hardcode_shlibpath_var=no ;; *) if $LD --help 2>&1 | $GREP ': supported targets:.* elf' > /dev/null; then archive_cmds='$CC -shared $pic_flag $libobjs $deplibs $compiler_flags $wl-soname $wl$soname -o $lib' archive_expsym_cmds='$CC -shared $pic_flag $libobjs $deplibs $compiler_flags $wl-soname $wl$soname $wl-retain-symbols-file $wl$export_symbols -o $lib' else ld_shlibs=no fi ;; esac if test no = "$ld_shlibs"; then runpath_var= hardcode_libdir_flag_spec= export_dynamic_flag_spec= whole_archive_flag_spec= fi else # PORTME fill in a description of your system's linker (not GNU ld) case $host_os in aix3*) allow_undefined_flag=unsupported always_export_symbols=yes archive_expsym_cmds='$LD -o $output_objdir/$soname $libobjs $deplibs $linker_flags -bE:$export_symbols -T512 -H512 -bM:SRE~$AR $AR_FLAGS $lib $output_objdir/$soname' # Note: this linker hardcodes the directories in LIBPATH if there # are no directories specified by -L. hardcode_minus_L=yes if test yes = "$GCC" && test -z "$lt_prog_compiler_static"; then # Neither direct hardcoding nor static linking is supported with a # broken collect2. hardcode_direct=unsupported fi ;; aix[4-9]*) if test ia64 = "$host_cpu"; then # On IA64, the linker does run time linking by default, so we don't # have to do anything special. aix_use_runtimelinking=no exp_sym_flag='-Bexport' no_entry_flag= else # If we're using GNU nm, then we don't want the "-C" option. # -C means demangle to GNU nm, but means don't demangle to AIX nm. # Without the "-l" option, or with the "-B" option, AIX nm treats # weak defined symbols like other global defined symbols, whereas # GNU nm marks them as "W". # While the 'weak' keyword is ignored in the Export File, we need # it in the Import File for the 'aix-soname' feature, so we have # to replace the "-B" option with "-P" for AIX nm. if $NM -V 2>&1 | $GREP 'GNU' > /dev/null; then export_symbols_cmds='$NM -Bpg $libobjs $convenience | awk '\''{ if (((\$ 2 == "T") || (\$ 2 == "D") || (\$ 2 == "B") || (\$ 2 == "W")) && (substr(\$ 3,1,1) != ".")) { if (\$ 2 == "W") { print \$ 3 " weak" } else { print \$ 3 } } }'\'' | sort -u > $export_symbols' else export_symbols_cmds='`func_echo_all $NM | $SED -e '\''s/B\([^B]*\)$/P\1/'\''` -PCpgl $libobjs $convenience | awk '\''{ if (((\$ 2 == "T") || (\$ 2 == "D") || (\$ 2 == "B") || (\$ 2 == "W") || (\$ 2 == "V") || (\$ 2 == "Z")) && (substr(\$ 1,1,1) != ".")) { if ((\$ 2 == "W") || (\$ 2 == "V") || (\$ 2 == "Z")) { print \$ 1 " weak" } else { print \$ 1 } } }'\'' | sort -u > $export_symbols' fi aix_use_runtimelinking=no # Test if we are trying to use run time linking or normal # AIX style linking. If -brtl is somewhere in LDFLAGS, we # have runtime linking enabled, and use it for executables. # For shared libraries, we enable/disable runtime linking # depending on the kind of the shared library created - # when "with_aix_soname,aix_use_runtimelinking" is: # "aix,no" lib.a(lib.so.V) shared, rtl:no, for executables # "aix,yes" lib.so shared, rtl:yes, for executables # lib.a static archive # "both,no" lib.so.V(shr.o) shared, rtl:yes # lib.a(lib.so.V) shared, rtl:no, for executables # "both,yes" lib.so.V(shr.o) shared, rtl:yes, for executables # lib.a(lib.so.V) shared, rtl:no # "svr4,*" lib.so.V(shr.o) shared, rtl:yes, for executables # lib.a static archive case $host_os in aix4.[23]|aix4.[23].*|aix[5-9]*) for ld_flag in $LDFLAGS; do if (test x-brtl = "x$ld_flag" || test x-Wl,-brtl = "x$ld_flag"); then aix_use_runtimelinking=yes break fi done if test svr4,no = "$with_aix_soname,$aix_use_runtimelinking"; then # With aix-soname=svr4, we create the lib.so.V shared archives only, # so we don't have lib.a shared libs to link our executables. # We have to force runtime linking in this case. aix_use_runtimelinking=yes LDFLAGS="$LDFLAGS -Wl,-brtl" fi ;; esac exp_sym_flag='-bexport' no_entry_flag='-bnoentry' fi # When large executables or shared objects are built, AIX ld can # have problems creating the table of contents. If linking a library # or program results in "error TOC overflow" add -mminimal-toc to # CXXFLAGS/CFLAGS for g++/gcc. In the cases where that is not # enough to fix the problem, add -Wl,-bbigtoc to LDFLAGS. archive_cmds='' hardcode_direct=yes hardcode_direct_absolute=yes hardcode_libdir_separator=':' link_all_deplibs=yes file_list_spec='$wl-f,' case $with_aix_soname,$aix_use_runtimelinking in aix,*) ;; # traditional, no import file svr4,* | *,yes) # use import file # The Import File defines what to hardcode. hardcode_direct=no hardcode_direct_absolute=no ;; esac if test yes = "$GCC"; then case $host_os in aix4.[012]|aix4.[012].*) # We only want to do this on AIX 4.2 and lower, the check # below for broken collect2 doesn't work under 4.3+ collect2name=`$CC -print-prog-name=collect2` if test -f "$collect2name" && strings "$collect2name" | $GREP resolve_lib_name >/dev/null then # We have reworked collect2 : else # We have old collect2 hardcode_direct=unsupported # It fails to find uninstalled libraries when the uninstalled # path is not listed in the libpath. Setting hardcode_minus_L # to unsupported forces relinking hardcode_minus_L=yes hardcode_libdir_flag_spec='-L$libdir' hardcode_libdir_separator= fi ;; esac shared_flag='-shared' if test yes = "$aix_use_runtimelinking"; then shared_flag="$shared_flag "'$wl-G' fi # Need to ensure runtime linking is disabled for the traditional # shared library, or the linker may eventually find shared libraries # /with/ Import File - we do not want to mix them. shared_flag_aix='-shared' shared_flag_svr4='-shared $wl-G' else # not using gcc if test ia64 = "$host_cpu"; then # VisualAge C++, Version 5.5 for AIX 5L for IA-64, Beta 3 Release # chokes on -Wl,-G. The following line is correct: shared_flag='-G' else if test yes = "$aix_use_runtimelinking"; then shared_flag='$wl-G' else shared_flag='$wl-bM:SRE' fi shared_flag_aix='$wl-bM:SRE' shared_flag_svr4='$wl-G' fi fi export_dynamic_flag_spec='$wl-bexpall' # It seems that -bexpall does not export symbols beginning with # underscore (_), so it is better to generate a list of symbols to export. always_export_symbols=yes if test aix,yes = "$with_aix_soname,$aix_use_runtimelinking"; then # Warning - without using the other runtime loading flags (-brtl), # -berok will link without error, but may produce a broken library. allow_undefined_flag='-berok' # Determine the default libpath from the value encoded in an # empty executable. if test set = "${lt_cv_aix_libpath+set}"; then aix_libpath=$lt_cv_aix_libpath else if ${lt_cv_aix_libpath_+:} false; then : $as_echo_n "(cached) " >&6 else cat confdefs.h - <<_ACEOF >conftest.$ac_ext /* end confdefs.h. */ int main () { ; return 0; } _ACEOF if ac_fn_c_try_link "$LINENO"; then : lt_aix_libpath_sed=' /Import File Strings/,/^$/ { /^0/ { s/^0 *\([^ ]*\) *$/\1/ p } }' lt_cv_aix_libpath_=`dump -H conftest$ac_exeext 2>/dev/null | $SED -n -e "$lt_aix_libpath_sed"` # Check for a 64-bit object if we didn't find anything. if test -z "$lt_cv_aix_libpath_"; then lt_cv_aix_libpath_=`dump -HX64 conftest$ac_exeext 2>/dev/null | $SED -n -e "$lt_aix_libpath_sed"` fi fi rm -f core conftest.err conftest.$ac_objext \ conftest$ac_exeext conftest.$ac_ext if test -z "$lt_cv_aix_libpath_"; then lt_cv_aix_libpath_=/usr/lib:/lib fi fi aix_libpath=$lt_cv_aix_libpath_ fi hardcode_libdir_flag_spec='$wl-blibpath:$libdir:'"$aix_libpath" archive_expsym_cmds='$CC -o $output_objdir/$soname $libobjs $deplibs $wl'$no_entry_flag' $compiler_flags `if test -n "$allow_undefined_flag"; then func_echo_all "$wl$allow_undefined_flag"; else :; fi` $wl'$exp_sym_flag:\$export_symbols' '$shared_flag else if test ia64 = "$host_cpu"; then hardcode_libdir_flag_spec='$wl-R $libdir:/usr/lib:/lib' allow_undefined_flag="-z nodefs" archive_expsym_cmds="\$CC $shared_flag"' -o $output_objdir/$soname $libobjs $deplibs '"\$wl$no_entry_flag"' $compiler_flags $wl$allow_undefined_flag '"\$wl$exp_sym_flag:\$export_symbols" else # Determine the default libpath from the value encoded in an # empty executable. if test set = "${lt_cv_aix_libpath+set}"; then aix_libpath=$lt_cv_aix_libpath else if ${lt_cv_aix_libpath_+:} false; then : $as_echo_n "(cached) " >&6 else cat confdefs.h - <<_ACEOF >conftest.$ac_ext /* end confdefs.h. */ int main () { ; return 0; } _ACEOF if ac_fn_c_try_link "$LINENO"; then : lt_aix_libpath_sed=' /Import File Strings/,/^$/ { /^0/ { s/^0 *\([^ ]*\) *$/\1/ p } }' lt_cv_aix_libpath_=`dump -H conftest$ac_exeext 2>/dev/null | $SED -n -e "$lt_aix_libpath_sed"` # Check for a 64-bit object if we didn't find anything. if test -z "$lt_cv_aix_libpath_"; then lt_cv_aix_libpath_=`dump -HX64 conftest$ac_exeext 2>/dev/null | $SED -n -e "$lt_aix_libpath_sed"` fi fi rm -f core conftest.err conftest.$ac_objext \ conftest$ac_exeext conftest.$ac_ext if test -z "$lt_cv_aix_libpath_"; then lt_cv_aix_libpath_=/usr/lib:/lib fi fi aix_libpath=$lt_cv_aix_libpath_ fi hardcode_libdir_flag_spec='$wl-blibpath:$libdir:'"$aix_libpath" # Warning - without using the other run time loading flags, # -berok will link without error, but may produce a broken library. no_undefined_flag=' $wl-bernotok' allow_undefined_flag=' $wl-berok' if test yes = "$with_gnu_ld"; then # We only use this code for GNU lds that support --whole-archive. whole_archive_flag_spec='$wl--whole-archive$convenience $wl--no-whole-archive' else # Exported symbols can be pulled into shared objects from archives whole_archive_flag_spec='$convenience' fi archive_cmds_need_lc=yes archive_expsym_cmds='$RM -r $output_objdir/$realname.d~$MKDIR $output_objdir/$realname.d' # -brtl affects multiple linker settings, -berok does not and is overridden later compiler_flags_filtered='`func_echo_all "$compiler_flags " | $SED -e "s%-brtl\\([, ]\\)%-berok\\1%g"`' if test svr4 != "$with_aix_soname"; then # This is similar to how AIX traditionally builds its shared libraries. archive_expsym_cmds="$archive_expsym_cmds"'~$CC '$shared_flag_aix' -o $output_objdir/$realname.d/$soname $libobjs $deplibs $wl-bnoentry '$compiler_flags_filtered'$wl-bE:$export_symbols$allow_undefined_flag~$AR $AR_FLAGS $output_objdir/$libname$release.a $output_objdir/$realname.d/$soname' fi if test aix != "$with_aix_soname"; then archive_expsym_cmds="$archive_expsym_cmds"'~$CC '$shared_flag_svr4' -o $output_objdir/$realname.d/$shared_archive_member_spec.o $libobjs $deplibs $wl-bnoentry '$compiler_flags_filtered'$wl-bE:$export_symbols$allow_undefined_flag~$STRIP -e $output_objdir/$realname.d/$shared_archive_member_spec.o~( func_echo_all "#! $soname($shared_archive_member_spec.o)"; if test shr_64 = "$shared_archive_member_spec"; then func_echo_all "# 64"; else func_echo_all "# 32"; fi; cat $export_symbols ) > $output_objdir/$realname.d/$shared_archive_member_spec.imp~$AR $AR_FLAGS $output_objdir/$soname $output_objdir/$realname.d/$shared_archive_member_spec.o $output_objdir/$realname.d/$shared_archive_member_spec.imp' else # used by -dlpreopen to get the symbols archive_expsym_cmds="$archive_expsym_cmds"'~$MV $output_objdir/$realname.d/$soname $output_objdir' fi archive_expsym_cmds="$archive_expsym_cmds"'~$RM -r $output_objdir/$realname.d' fi fi ;; amigaos*) case $host_cpu in powerpc) # see comment about AmigaOS4 .so support archive_cmds='$CC -shared $libobjs $deplibs $compiler_flags $wl-soname $wl$soname -o $lib' archive_expsym_cmds='' ;; m68k) archive_cmds='$RM $output_objdir/a2ixlibrary.data~$ECHO "#define NAME $libname" > $output_objdir/a2ixlibrary.data~$ECHO "#define LIBRARY_ID 1" >> $output_objdir/a2ixlibrary.data~$ECHO "#define VERSION $major" >> $output_objdir/a2ixlibrary.data~$ECHO "#define REVISION $revision" >> $output_objdir/a2ixlibrary.data~$AR $AR_FLAGS $lib $libobjs~$RANLIB $lib~(cd $output_objdir && a2ixlibrary -32)' hardcode_libdir_flag_spec='-L$libdir' hardcode_minus_L=yes ;; esac ;; bsdi[45]*) export_dynamic_flag_spec=-rdynamic ;; cygwin* | mingw* | pw32* | cegcc*) # When not using gcc, we currently assume that we are using # Microsoft Visual C++. # hardcode_libdir_flag_spec is actually meaningless, as there is # no search path for DLLs. case $cc_basename in cl*) # Native MSVC hardcode_libdir_flag_spec=' ' allow_undefined_flag=unsupported always_export_symbols=yes file_list_spec='@' # Tell ltmain to make .lib files, not .a files. libext=lib # Tell ltmain to make .dll files, not .so files. shrext_cmds=.dll # FIXME: Setting linknames here is a bad hack. archive_cmds='$CC -o $output_objdir/$soname $libobjs $compiler_flags $deplibs -Wl,-DLL,-IMPLIB:"$tool_output_objdir$libname.dll.lib"~linknames=' archive_expsym_cmds='if test DEF = "`$SED -n -e '\''s/^[ ]*//'\'' -e '\''/^\(;.*\)*$/d'\'' -e '\''s/^\(EXPORTS\|LIBRARY\)\([ ].*\)*$/DEF/p'\'' -e q $export_symbols`" ; then cp "$export_symbols" "$output_objdir/$soname.def"; echo "$tool_output_objdir$soname.def" > "$output_objdir/$soname.exp"; else $SED -e '\''s/^/-link -EXPORT:/'\'' < $export_symbols > $output_objdir/$soname.exp; fi~ $CC -o $tool_output_objdir$soname $libobjs $compiler_flags $deplibs "@$tool_output_objdir$soname.exp" -Wl,-DLL,-IMPLIB:"$tool_output_objdir$libname.dll.lib"~ linknames=' # The linker will not automatically build a static lib if we build a DLL. # _LT_TAGVAR(old_archive_from_new_cmds, )='true' enable_shared_with_static_runtimes=yes exclude_expsyms='_NULL_IMPORT_DESCRIPTOR|_IMPORT_DESCRIPTOR_.*' export_symbols_cmds='$NM $libobjs $convenience | $global_symbol_pipe | $SED -e '\''/^[BCDGRS][ ]/s/.*[ ]\([^ ]*\)/\1,DATA/'\'' | $SED -e '\''/^[AITW][ ]/s/.*[ ]//'\'' | sort | uniq > $export_symbols' # Don't use ranlib old_postinstall_cmds='chmod 644 $oldlib' postlink_cmds='lt_outputfile="@OUTPUT@"~ lt_tool_outputfile="@TOOL_OUTPUT@"~ case $lt_outputfile in *.exe|*.EXE) ;; *) lt_outputfile=$lt_outputfile.exe lt_tool_outputfile=$lt_tool_outputfile.exe ;; esac~ if test : != "$MANIFEST_TOOL" && test -f "$lt_outputfile.manifest"; then $MANIFEST_TOOL -manifest "$lt_tool_outputfile.manifest" -outputresource:"$lt_tool_outputfile" || exit 1; $RM "$lt_outputfile.manifest"; fi' ;; *) # Assume MSVC wrapper hardcode_libdir_flag_spec=' ' allow_undefined_flag=unsupported # Tell ltmain to make .lib files, not .a files. libext=lib # Tell ltmain to make .dll files, not .so files. shrext_cmds=.dll # FIXME: Setting linknames here is a bad hack. archive_cmds='$CC -o $lib $libobjs $compiler_flags `func_echo_all "$deplibs" | $SED '\''s/ -lc$//'\''` -link -dll~linknames=' # The linker will automatically build a .lib file if we build a DLL. old_archive_from_new_cmds='true' # FIXME: Should let the user specify the lib program. old_archive_cmds='lib -OUT:$oldlib$oldobjs$old_deplibs' enable_shared_with_static_runtimes=yes ;; esac ;; darwin* | rhapsody*) archive_cmds_need_lc=no hardcode_direct=no hardcode_automatic=yes hardcode_shlibpath_var=unsupported if test yes = "$lt_cv_ld_force_load"; then whole_archive_flag_spec='`for conv in $convenience\"\"; do test -n \"$conv\" && new_convenience=\"$new_convenience $wl-force_load,$conv\"; done; func_echo_all \"$new_convenience\"`' else whole_archive_flag_spec='' fi link_all_deplibs=yes allow_undefined_flag=$_lt_dar_allow_undefined case $cc_basename in ifort*|nagfor*) _lt_dar_can_shared=yes ;; *) _lt_dar_can_shared=$GCC ;; esac if test yes = "$_lt_dar_can_shared"; then output_verbose_link_cmd=func_echo_all archive_cmds="\$CC -dynamiclib \$allow_undefined_flag -o \$lib \$libobjs \$deplibs \$compiler_flags -install_name \$rpath/\$soname \$verstring $_lt_dar_single_mod$_lt_dsymutil" module_cmds="\$CC \$allow_undefined_flag -o \$lib -bundle \$libobjs \$deplibs \$compiler_flags$_lt_dsymutil" archive_expsym_cmds="sed 's|^|_|' < \$export_symbols > \$output_objdir/\$libname-symbols.expsym~\$CC -dynamiclib \$allow_undefined_flag -o \$lib \$libobjs \$deplibs \$compiler_flags -install_name \$rpath/\$soname \$verstring $_lt_dar_single_mod$_lt_dar_export_syms$_lt_dsymutil" module_expsym_cmds="sed -e 's|^|_|' < \$export_symbols > \$output_objdir/\$libname-symbols.expsym~\$CC \$allow_undefined_flag -o \$lib -bundle \$libobjs \$deplibs \$compiler_flags$_lt_dar_export_syms$_lt_dsymutil" else ld_shlibs=no fi ;; dgux*) archive_cmds='$LD -G -h $soname -o $lib $libobjs $deplibs $linker_flags' hardcode_libdir_flag_spec='-L$libdir' hardcode_shlibpath_var=no ;; # FreeBSD 2.2.[012] allows us to include c++rt0.o to get C++ constructor # support. Future versions do this automatically, but an explicit c++rt0.o # does not break anything, and helps significantly (at the cost of a little # extra space). freebsd2.2*) archive_cmds='$LD -Bshareable -o $lib $libobjs $deplibs $linker_flags /usr/lib/c++rt0.o' hardcode_libdir_flag_spec='-R$libdir' hardcode_direct=yes hardcode_shlibpath_var=no ;; # Unfortunately, older versions of FreeBSD 2 do not have this feature. freebsd2.*) archive_cmds='$LD -Bshareable -o $lib $libobjs $deplibs $linker_flags' hardcode_direct=yes hardcode_minus_L=yes hardcode_shlibpath_var=no ;; # FreeBSD 3 and greater uses gcc -shared to do shared libraries. freebsd* | dragonfly*) archive_cmds='$CC -shared $pic_flag -o $lib $libobjs $deplibs $compiler_flags' hardcode_libdir_flag_spec='-R$libdir' hardcode_direct=yes hardcode_shlibpath_var=no ;; hpux9*) if test yes = "$GCC"; then archive_cmds='$RM $output_objdir/$soname~$CC -shared $pic_flag $wl+b $wl$install_libdir -o $output_objdir/$soname $libobjs $deplibs $compiler_flags~test "x$output_objdir/$soname" = "x$lib" || mv $output_objdir/$soname $lib' else archive_cmds='$RM $output_objdir/$soname~$LD -b +b $install_libdir -o $output_objdir/$soname $libobjs $deplibs $linker_flags~test "x$output_objdir/$soname" = "x$lib" || mv $output_objdir/$soname $lib' fi hardcode_libdir_flag_spec='$wl+b $wl$libdir' hardcode_libdir_separator=: hardcode_direct=yes # hardcode_minus_L: Not really in the search PATH, # but as the default location of the library. hardcode_minus_L=yes export_dynamic_flag_spec='$wl-E' ;; hpux10*) if test yes,no = "$GCC,$with_gnu_ld"; then archive_cmds='$CC -shared $pic_flag $wl+h $wl$soname $wl+b $wl$install_libdir -o $lib $libobjs $deplibs $compiler_flags' else archive_cmds='$LD -b +h $soname +b $install_libdir -o $lib $libobjs $deplibs $linker_flags' fi if test no = "$with_gnu_ld"; then hardcode_libdir_flag_spec='$wl+b $wl$libdir' hardcode_libdir_separator=: hardcode_direct=yes hardcode_direct_absolute=yes export_dynamic_flag_spec='$wl-E' # hardcode_minus_L: Not really in the search PATH, # but as the default location of the library. hardcode_minus_L=yes fi ;; hpux11*) if test yes,no = "$GCC,$with_gnu_ld"; then case $host_cpu in hppa*64*) archive_cmds='$CC -shared $wl+h $wl$soname -o $lib $libobjs $deplibs $compiler_flags' ;; ia64*) archive_cmds='$CC -shared $pic_flag $wl+h $wl$soname $wl+nodefaultrpath -o $lib $libobjs $deplibs $compiler_flags' ;; *) archive_cmds='$CC -shared $pic_flag $wl+h $wl$soname $wl+b $wl$install_libdir -o $lib $libobjs $deplibs $compiler_flags' ;; esac else case $host_cpu in hppa*64*) archive_cmds='$CC -b $wl+h $wl$soname -o $lib $libobjs $deplibs $compiler_flags' ;; ia64*) archive_cmds='$CC -b $wl+h $wl$soname $wl+nodefaultrpath -o $lib $libobjs $deplibs $compiler_flags' ;; *) # Older versions of the 11.00 compiler do not understand -b yet # (HP92453-01 A.11.01.20 doesn't, HP92453-01 B.11.X.35175-35176.GP does) { $as_echo "$as_me:${as_lineno-$LINENO}: checking if $CC understands -b" >&5 $as_echo_n "checking if $CC understands -b... " >&6; } if ${lt_cv_prog_compiler__b+:} false; then : $as_echo_n "(cached) " >&6 else lt_cv_prog_compiler__b=no save_LDFLAGS=$LDFLAGS LDFLAGS="$LDFLAGS -b" echo "$lt_simple_link_test_code" > conftest.$ac_ext if (eval $ac_link 2>conftest.err) && test -s conftest$ac_exeext; then # The linker can only warn and ignore the option if not recognized # So say no if there are warnings if test -s conftest.err; then # Append any errors to the config.log. cat conftest.err 1>&5 $ECHO "$_lt_linker_boilerplate" | $SED '/^$/d' > conftest.exp $SED '/^$/d; /^ *+/d' conftest.err >conftest.er2 if diff conftest.exp conftest.er2 >/dev/null; then lt_cv_prog_compiler__b=yes fi else lt_cv_prog_compiler__b=yes fi fi $RM -r conftest* LDFLAGS=$save_LDFLAGS fi { $as_echo "$as_me:${as_lineno-$LINENO}: result: $lt_cv_prog_compiler__b" >&5 $as_echo "$lt_cv_prog_compiler__b" >&6; } if test yes = "$lt_cv_prog_compiler__b"; then archive_cmds='$CC -b $wl+h $wl$soname $wl+b $wl$install_libdir -o $lib $libobjs $deplibs $compiler_flags' else archive_cmds='$LD -b +h $soname +b $install_libdir -o $lib $libobjs $deplibs $linker_flags' fi ;; esac fi if test no = "$with_gnu_ld"; then hardcode_libdir_flag_spec='$wl+b $wl$libdir' hardcode_libdir_separator=: case $host_cpu in hppa*64*|ia64*) hardcode_direct=no hardcode_shlibpath_var=no ;; *) hardcode_direct=yes hardcode_direct_absolute=yes export_dynamic_flag_spec='$wl-E' # hardcode_minus_L: Not really in the search PATH, # but as the default location of the library. hardcode_minus_L=yes ;; esac fi ;; irix5* | irix6* | nonstopux*) if test yes = "$GCC"; then archive_cmds='$CC -shared $pic_flag $libobjs $deplibs $compiler_flags $wl-soname $wl$soname `test -n "$verstring" && func_echo_all "$wl-set_version $wl$verstring"` $wl-update_registry $wl$output_objdir/so_locations -o $lib' # Try to use the -exported_symbol ld option, if it does not # work, assume that -exports_file does not work either and # implicitly export all symbols. # This should be the same for all languages, so no per-tag cache variable. { $as_echo "$as_me:${as_lineno-$LINENO}: checking whether the $host_os linker accepts -exported_symbol" >&5 $as_echo_n "checking whether the $host_os linker accepts -exported_symbol... " >&6; } if ${lt_cv_irix_exported_symbol+:} false; then : $as_echo_n "(cached) " >&6 else save_LDFLAGS=$LDFLAGS LDFLAGS="$LDFLAGS -shared $wl-exported_symbol ${wl}foo $wl-update_registry $wl/dev/null" cat confdefs.h - <<_ACEOF >conftest.$ac_ext /* end confdefs.h. */ int foo (void) { return 0; } _ACEOF if ac_fn_c_try_link "$LINENO"; then : lt_cv_irix_exported_symbol=yes else lt_cv_irix_exported_symbol=no fi rm -f core conftest.err conftest.$ac_objext \ conftest$ac_exeext conftest.$ac_ext LDFLAGS=$save_LDFLAGS fi { $as_echo "$as_me:${as_lineno-$LINENO}: result: $lt_cv_irix_exported_symbol" >&5 $as_echo "$lt_cv_irix_exported_symbol" >&6; } if test yes = "$lt_cv_irix_exported_symbol"; then archive_expsym_cmds='$CC -shared $pic_flag $libobjs $deplibs $compiler_flags $wl-soname $wl$soname `test -n "$verstring" && func_echo_all "$wl-set_version $wl$verstring"` $wl-update_registry $wl$output_objdir/so_locations $wl-exports_file $wl$export_symbols -o $lib' fi else archive_cmds='$CC -shared $libobjs $deplibs $compiler_flags -soname $soname `test -n "$verstring" && func_echo_all "-set_version $verstring"` -update_registry $output_objdir/so_locations -o $lib' archive_expsym_cmds='$CC -shared $libobjs $deplibs $compiler_flags -soname $soname `test -n "$verstring" && func_echo_all "-set_version $verstring"` -update_registry $output_objdir/so_locations -exports_file $export_symbols -o $lib' fi archive_cmds_need_lc='no' hardcode_libdir_flag_spec='$wl-rpath $wl$libdir' hardcode_libdir_separator=: inherit_rpath=yes link_all_deplibs=yes ;; linux*) case $cc_basename in tcc*) # Fabrice Bellard et al's Tiny C Compiler ld_shlibs=yes archive_cmds='$CC -shared $pic_flag -o $lib $libobjs $deplibs $compiler_flags' ;; esac ;; netbsd*) if echo __ELF__ | $CC -E - | $GREP __ELF__ >/dev/null; then archive_cmds='$LD -Bshareable -o $lib $libobjs $deplibs $linker_flags' # a.out else archive_cmds='$LD -shared -o $lib $libobjs $deplibs $linker_flags' # ELF fi hardcode_libdir_flag_spec='-R$libdir' hardcode_direct=yes hardcode_shlibpath_var=no ;; newsos6) archive_cmds='$LD -G -h $soname -o $lib $libobjs $deplibs $linker_flags' hardcode_direct=yes hardcode_libdir_flag_spec='$wl-rpath $wl$libdir' hardcode_libdir_separator=: hardcode_shlibpath_var=no ;; *nto* | *qnx*) ;; openbsd* | bitrig*) if test -f /usr/libexec/ld.so; then hardcode_direct=yes hardcode_shlibpath_var=no hardcode_direct_absolute=yes if test -z "`echo __ELF__ | $CC -E - | $GREP __ELF__`"; then archive_cmds='$CC -shared $pic_flag -o $lib $libobjs $deplibs $compiler_flags' archive_expsym_cmds='$CC -shared $pic_flag -o $lib $libobjs $deplibs $compiler_flags $wl-retain-symbols-file,$export_symbols' hardcode_libdir_flag_spec='$wl-rpath,$libdir' export_dynamic_flag_spec='$wl-E' else archive_cmds='$CC -shared $pic_flag -o $lib $libobjs $deplibs $compiler_flags' hardcode_libdir_flag_spec='$wl-rpath,$libdir' fi else ld_shlibs=no fi ;; os2*) hardcode_libdir_flag_spec='-L$libdir' hardcode_minus_L=yes allow_undefined_flag=unsupported shrext_cmds=.dll archive_cmds='$ECHO "LIBRARY ${soname%$shared_ext} INITINSTANCE TERMINSTANCE" > $output_objdir/$libname.def~ $ECHO "DESCRIPTION \"$libname\"" >> $output_objdir/$libname.def~ $ECHO "DATA MULTIPLE NONSHARED" >> $output_objdir/$libname.def~ $ECHO EXPORTS >> $output_objdir/$libname.def~ emxexp $libobjs | $SED /"_DLL_InitTerm"/d >> $output_objdir/$libname.def~ $CC -Zdll -Zcrtdll -o $output_objdir/$soname $libobjs $deplibs $compiler_flags $output_objdir/$libname.def~ emximp -o $lib $output_objdir/$libname.def' archive_expsym_cmds='$ECHO "LIBRARY ${soname%$shared_ext} INITINSTANCE TERMINSTANCE" > $output_objdir/$libname.def~ $ECHO "DESCRIPTION \"$libname\"" >> $output_objdir/$libname.def~ $ECHO "DATA MULTIPLE NONSHARED" >> $output_objdir/$libname.def~ $ECHO EXPORTS >> $output_objdir/$libname.def~ prefix_cmds="$SED"~ if test EXPORTS = "`$SED 1q $export_symbols`"; then prefix_cmds="$prefix_cmds -e 1d"; fi~ prefix_cmds="$prefix_cmds -e \"s/^\(.*\)$/_\1/g\""~ cat $export_symbols | $prefix_cmds >> $output_objdir/$libname.def~ $CC -Zdll -Zcrtdll -o $output_objdir/$soname $libobjs $deplibs $compiler_flags $output_objdir/$libname.def~ emximp -o $lib $output_objdir/$libname.def' old_archive_From_new_cmds='emximp -o $output_objdir/${libname}_dll.a $output_objdir/$libname.def' enable_shared_with_static_runtimes=yes ;; osf3*) if test yes = "$GCC"; then allow_undefined_flag=' $wl-expect_unresolved $wl\*' archive_cmds='$CC -shared$allow_undefined_flag $libobjs $deplibs $compiler_flags $wl-soname $wl$soname `test -n "$verstring" && func_echo_all "$wl-set_version $wl$verstring"` $wl-update_registry $wl$output_objdir/so_locations -o $lib' else allow_undefined_flag=' -expect_unresolved \*' archive_cmds='$CC -shared$allow_undefined_flag $libobjs $deplibs $compiler_flags -soname $soname `test -n "$verstring" && func_echo_all "-set_version $verstring"` -update_registry $output_objdir/so_locations -o $lib' fi archive_cmds_need_lc='no' hardcode_libdir_flag_spec='$wl-rpath $wl$libdir' hardcode_libdir_separator=: ;; osf4* | osf5*) # as osf3* with the addition of -msym flag if test yes = "$GCC"; then allow_undefined_flag=' $wl-expect_unresolved $wl\*' archive_cmds='$CC -shared$allow_undefined_flag $pic_flag $libobjs $deplibs $compiler_flags $wl-msym $wl-soname $wl$soname `test -n "$verstring" && func_echo_all "$wl-set_version $wl$verstring"` $wl-update_registry $wl$output_objdir/so_locations -o $lib' hardcode_libdir_flag_spec='$wl-rpath $wl$libdir' else allow_undefined_flag=' -expect_unresolved \*' archive_cmds='$CC -shared$allow_undefined_flag $libobjs $deplibs $compiler_flags -msym -soname $soname `test -n "$verstring" && func_echo_all "-set_version $verstring"` -update_registry $output_objdir/so_locations -o $lib' archive_expsym_cmds='for i in `cat $export_symbols`; do printf "%s %s\\n" -exported_symbol "\$i" >> $lib.exp; done; printf "%s\\n" "-hidden">> $lib.exp~ $CC -shared$allow_undefined_flag $wl-input $wl$lib.exp $compiler_flags $libobjs $deplibs -soname $soname `test -n "$verstring" && $ECHO "-set_version $verstring"` -update_registry $output_objdir/so_locations -o $lib~$RM $lib.exp' # Both c and cxx compiler support -rpath directly hardcode_libdir_flag_spec='-rpath $libdir' fi archive_cmds_need_lc='no' hardcode_libdir_separator=: ;; solaris*) no_undefined_flag=' -z defs' if test yes = "$GCC"; then wlarc='$wl' archive_cmds='$CC -shared $pic_flag $wl-z ${wl}text $wl-h $wl$soname -o $lib $libobjs $deplibs $compiler_flags' archive_expsym_cmds='echo "{ global:" > $lib.exp~cat $export_symbols | $SED -e "s/\(.*\)/\1;/" >> $lib.exp~echo "local: *; };" >> $lib.exp~ $CC -shared $pic_flag $wl-z ${wl}text $wl-M $wl$lib.exp $wl-h $wl$soname -o $lib $libobjs $deplibs $compiler_flags~$RM $lib.exp' else case `$CC -V 2>&1` in *"Compilers 5.0"*) wlarc='' archive_cmds='$LD -G$allow_undefined_flag -h $soname -o $lib $libobjs $deplibs $linker_flags' archive_expsym_cmds='echo "{ global:" > $lib.exp~cat $export_symbols | $SED -e "s/\(.*\)/\1;/" >> $lib.exp~echo "local: *; };" >> $lib.exp~ $LD -G$allow_undefined_flag -M $lib.exp -h $soname -o $lib $libobjs $deplibs $linker_flags~$RM $lib.exp' ;; *) wlarc='$wl' archive_cmds='$CC -G$allow_undefined_flag -h $soname -o $lib $libobjs $deplibs $compiler_flags' archive_expsym_cmds='echo "{ global:" > $lib.exp~cat $export_symbols | $SED -e "s/\(.*\)/\1;/" >> $lib.exp~echo "local: *; };" >> $lib.exp~ $CC -G$allow_undefined_flag -M $lib.exp -h $soname -o $lib $libobjs $deplibs $compiler_flags~$RM $lib.exp' ;; esac fi hardcode_libdir_flag_spec='-R$libdir' hardcode_shlibpath_var=no case $host_os in solaris2.[0-5] | solaris2.[0-5].*) ;; *) # The compiler driver will combine and reorder linker options, # but understands '-z linker_flag'. GCC discards it without '$wl', # but is careful enough not to reorder. # Supported since Solaris 2.6 (maybe 2.5.1?) if test yes = "$GCC"; then whole_archive_flag_spec='$wl-z ${wl}allextract$convenience $wl-z ${wl}defaultextract' else whole_archive_flag_spec='-z allextract$convenience -z defaultextract' fi ;; esac link_all_deplibs=yes ;; sunos4*) if test sequent = "$host_vendor"; then # Use $CC to link under sequent, because it throws in some extra .o # files that make .init and .fini sections work. archive_cmds='$CC -G $wl-h $soname -o $lib $libobjs $deplibs $compiler_flags' else archive_cmds='$LD -assert pure-text -Bstatic -o $lib $libobjs $deplibs $linker_flags' fi hardcode_libdir_flag_spec='-L$libdir' hardcode_direct=yes hardcode_minus_L=yes hardcode_shlibpath_var=no ;; sysv4) case $host_vendor in sni) archive_cmds='$LD -G -h $soname -o $lib $libobjs $deplibs $linker_flags' hardcode_direct=yes # is this really true??? ;; siemens) ## LD is ld it makes a PLAMLIB ## CC just makes a GrossModule. archive_cmds='$LD -G -o $lib $libobjs $deplibs $linker_flags' reload_cmds='$CC -r -o $output$reload_objs' hardcode_direct=no ;; motorola) archive_cmds='$LD -G -h $soname -o $lib $libobjs $deplibs $linker_flags' hardcode_direct=no #Motorola manual says yes, but my tests say they lie ;; esac runpath_var='LD_RUN_PATH' hardcode_shlibpath_var=no ;; sysv4.3*) archive_cmds='$LD -G -h $soname -o $lib $libobjs $deplibs $linker_flags' hardcode_shlibpath_var=no export_dynamic_flag_spec='-Bexport' ;; sysv4*MP*) if test -d /usr/nec; then archive_cmds='$LD -G -h $soname -o $lib $libobjs $deplibs $linker_flags' hardcode_shlibpath_var=no runpath_var=LD_RUN_PATH hardcode_runpath_var=yes ld_shlibs=yes fi ;; sysv4*uw2* | sysv5OpenUNIX* | sysv5UnixWare7.[01].[10]* | unixware7* | sco3.2v5.0.[024]*) no_undefined_flag='$wl-z,text' archive_cmds_need_lc=no hardcode_shlibpath_var=no runpath_var='LD_RUN_PATH' if test yes = "$GCC"; then archive_cmds='$CC -shared $wl-h,$soname -o $lib $libobjs $deplibs $compiler_flags' archive_expsym_cmds='$CC -shared $wl-Bexport:$export_symbols $wl-h,$soname -o $lib $libobjs $deplibs $compiler_flags' else archive_cmds='$CC -G $wl-h,$soname -o $lib $libobjs $deplibs $compiler_flags' archive_expsym_cmds='$CC -G $wl-Bexport:$export_symbols $wl-h,$soname -o $lib $libobjs $deplibs $compiler_flags' fi ;; sysv5* | sco3.2v5* | sco5v6*) # Note: We CANNOT use -z defs as we might desire, because we do not # link with -lc, and that would cause any symbols used from libc to # always be unresolved, which means just about no library would # ever link correctly. If we're not using GNU ld we use -z text # though, which does catch some bad symbols but isn't as heavy-handed # as -z defs. no_undefined_flag='$wl-z,text' allow_undefined_flag='$wl-z,nodefs' archive_cmds_need_lc=no hardcode_shlibpath_var=no hardcode_libdir_flag_spec='$wl-R,$libdir' hardcode_libdir_separator=':' link_all_deplibs=yes export_dynamic_flag_spec='$wl-Bexport' runpath_var='LD_RUN_PATH' if test yes = "$GCC"; then archive_cmds='$CC -shared $wl-h,$soname -o $lib $libobjs $deplibs $compiler_flags' archive_expsym_cmds='$CC -shared $wl-Bexport:$export_symbols $wl-h,$soname -o $lib $libobjs $deplibs $compiler_flags' else archive_cmds='$CC -G $wl-h,$soname -o $lib $libobjs $deplibs $compiler_flags' archive_expsym_cmds='$CC -G $wl-Bexport:$export_symbols $wl-h,$soname -o $lib $libobjs $deplibs $compiler_flags' fi ;; uts4*) archive_cmds='$LD -G -h $soname -o $lib $libobjs $deplibs $linker_flags' hardcode_libdir_flag_spec='-L$libdir' hardcode_shlibpath_var=no ;; *) ld_shlibs=no ;; esac if test sni = "$host_vendor"; then case $host in sysv4 | sysv4.2uw2* | sysv4.3* | sysv5*) export_dynamic_flag_spec='$wl-Blargedynsym' ;; esac fi fi { $as_echo "$as_me:${as_lineno-$LINENO}: result: $ld_shlibs" >&5 $as_echo "$ld_shlibs" >&6; } test no = "$ld_shlibs" && can_build_shared=no with_gnu_ld=$with_gnu_ld # # Do we need to explicitly link libc? # case "x$archive_cmds_need_lc" in x|xyes) # Assume -lc should be added archive_cmds_need_lc=yes if test yes,yes = "$GCC,$enable_shared"; then case $archive_cmds in *'~'*) # FIXME: we may have to deal with multi-command sequences. ;; '$CC '*) # Test whether the compiler implicitly links with -lc since on some # systems, -lgcc has to come before -lc. If gcc already passes -lc # to ld, don't add -lc before -lgcc. { $as_echo "$as_me:${as_lineno-$LINENO}: checking whether -lc should be explicitly linked in" >&5 $as_echo_n "checking whether -lc should be explicitly linked in... " >&6; } if ${lt_cv_archive_cmds_need_lc+:} false; then : $as_echo_n "(cached) " >&6 else $RM conftest* echo "$lt_simple_compile_test_code" > conftest.$ac_ext if { { eval echo "\"\$as_me\":${as_lineno-$LINENO}: \"$ac_compile\""; } >&5 (eval $ac_compile) 2>&5 ac_status=$? $as_echo "$as_me:${as_lineno-$LINENO}: \$? = $ac_status" >&5 test $ac_status = 0; } 2>conftest.err; then soname=conftest lib=conftest libobjs=conftest.$ac_objext deplibs= wl=$lt_prog_compiler_wl pic_flag=$lt_prog_compiler_pic compiler_flags=-v linker_flags=-v verstring= output_objdir=. libname=conftest lt_save_allow_undefined_flag=$allow_undefined_flag allow_undefined_flag= if { { eval echo "\"\$as_me\":${as_lineno-$LINENO}: \"$archive_cmds 2\>\&1 \| $GREP \" -lc \" \>/dev/null 2\>\&1\""; } >&5 (eval $archive_cmds 2\>\&1 \| $GREP \" -lc \" \>/dev/null 2\>\&1) 2>&5 ac_status=$? $as_echo "$as_me:${as_lineno-$LINENO}: \$? = $ac_status" >&5 test $ac_status = 0; } then lt_cv_archive_cmds_need_lc=no else lt_cv_archive_cmds_need_lc=yes fi allow_undefined_flag=$lt_save_allow_undefined_flag else cat conftest.err 1>&5 fi $RM conftest* fi { $as_echo "$as_me:${as_lineno-$LINENO}: result: $lt_cv_archive_cmds_need_lc" >&5 $as_echo "$lt_cv_archive_cmds_need_lc" >&6; } archive_cmds_need_lc=$lt_cv_archive_cmds_need_lc ;; esac fi ;; esac { $as_echo "$as_me:${as_lineno-$LINENO}: checking dynamic linker characteristics" >&5 $as_echo_n "checking dynamic linker characteristics... " >&6; } if test yes = "$GCC"; then case $host_os in darwin*) lt_awk_arg='/^libraries:/,/LR/' ;; *) lt_awk_arg='/^libraries:/' ;; esac case $host_os in mingw* | cegcc*) lt_sed_strip_eq='s|=\([A-Za-z]:\)|\1|g' ;; *) lt_sed_strip_eq='s|=/|/|g' ;; esac lt_search_path_spec=`$CC -print-search-dirs | awk $lt_awk_arg | $SED -e "s/^libraries://" -e $lt_sed_strip_eq` case $lt_search_path_spec in *\;*) # if the path contains ";" then we assume it to be the separator # otherwise default to the standard path separator (i.e. ":") - it is # assumed that no part of a normal pathname contains ";" but that should # okay in the real world where ";" in dirpaths is itself problematic. lt_search_path_spec=`$ECHO "$lt_search_path_spec" | $SED 's/;/ /g'` ;; *) lt_search_path_spec=`$ECHO "$lt_search_path_spec" | $SED "s/$PATH_SEPARATOR/ /g"` ;; esac # Ok, now we have the path, separated by spaces, we can step through it # and add multilib dir if necessary... lt_tmp_lt_search_path_spec= lt_multi_os_dir=/`$CC $CPPFLAGS $CFLAGS $LDFLAGS -print-multi-os-directory 2>/dev/null` # ...but if some path component already ends with the multilib dir we assume # that all is fine and trust -print-search-dirs as is (GCC 4.2? or newer). case "$lt_multi_os_dir; $lt_search_path_spec " in "/; "* | "/.; "* | "/./; "* | *"$lt_multi_os_dir "* | *"$lt_multi_os_dir/ "*) lt_multi_os_dir= ;; esac for lt_sys_path in $lt_search_path_spec; do if test -d "$lt_sys_path$lt_multi_os_dir"; then lt_tmp_lt_search_path_spec="$lt_tmp_lt_search_path_spec $lt_sys_path$lt_multi_os_dir" elif test -n "$lt_multi_os_dir"; then test -d "$lt_sys_path" && \ lt_tmp_lt_search_path_spec="$lt_tmp_lt_search_path_spec $lt_sys_path" fi done lt_search_path_spec=`$ECHO "$lt_tmp_lt_search_path_spec" | awk ' BEGIN {RS = " "; FS = "/|\n";} { lt_foo = ""; lt_count = 0; for (lt_i = NF; lt_i > 0; lt_i--) { if ($lt_i != "" && $lt_i != ".") { if ($lt_i == "..") { lt_count++; } else { if (lt_count == 0) { lt_foo = "/" $lt_i lt_foo; } else { lt_count--; } } } } if (lt_foo != "") { lt_freq[lt_foo]++; } if (lt_freq[lt_foo] == 1) { print lt_foo; } }'` # AWK program above erroneously prepends '/' to C:/dos/paths # for these hosts. case $host_os in mingw* | cegcc*) lt_search_path_spec=`$ECHO "$lt_search_path_spec" |\ $SED 's|/\([A-Za-z]:\)|\1|g'` ;; esac sys_lib_search_path_spec=`$ECHO "$lt_search_path_spec" | $lt_NL2SP` else sys_lib_search_path_spec="/lib /usr/lib /usr/local/lib" fi library_names_spec= libname_spec='lib$name' soname_spec= shrext_cmds=.so postinstall_cmds= postuninstall_cmds= finish_cmds= finish_eval= shlibpath_var= shlibpath_overrides_runpath=unknown version_type=none dynamic_linker="$host_os ld.so" sys_lib_dlsearch_path_spec="/lib /usr/lib" need_lib_prefix=unknown hardcode_into_libs=no # when you set need_version to no, make sure it does not cause -set_version # flags to be left without arguments need_version=unknown case $host_os in aix3*) version_type=linux # correct to gnu/linux during the next big refactor library_names_spec='$libname$release$shared_ext$versuffix $libname.a' shlibpath_var=LIBPATH # AIX 3 has no versioning support, so we append a major version to the name. soname_spec='$libname$release$shared_ext$major' ;; aix[4-9]*) version_type=linux # correct to gnu/linux during the next big refactor need_lib_prefix=no need_version=no hardcode_into_libs=yes if test ia64 = "$host_cpu"; then # AIX 5 supports IA64 library_names_spec='$libname$release$shared_ext$major $libname$release$shared_ext$versuffix $libname$shared_ext' shlibpath_var=LD_LIBRARY_PATH else # With GCC up to 2.95.x, collect2 would create an import file # for dependence libraries. The import file would start with # the line '#! .'. This would cause the generated library to # depend on '.', always an invalid library. This was fixed in # development snapshots of GCC prior to 3.0. case $host_os in aix4 | aix4.[01] | aix4.[01].*) if { echo '#if __GNUC__ > 2 || (__GNUC__ == 2 && __GNUC_MINOR__ >= 97)' echo ' yes ' echo '#endif'; } | $CC -E - | $GREP yes > /dev/null; then : else can_build_shared=no fi ;; esac # Using Import Files as archive members, it is possible to support # filename-based versioning of shared library archives on AIX. While # this would work for both with and without runtime linking, it will # prevent static linking of such archives. So we do filename-based # shared library versioning with .so extension only, which is used # when both runtime linking and shared linking is enabled. # Unfortunately, runtime linking may impact performance, so we do # not want this to be the default eventually. Also, we use the # versioned .so libs for executables only if there is the -brtl # linker flag in LDFLAGS as well, or --with-aix-soname=svr4 only. # To allow for filename-based versioning support, we need to create # libNAME.so.V as an archive file, containing: # *) an Import File, referring to the versioned filename of the # archive as well as the shared archive member, telling the # bitwidth (32 or 64) of that shared object, and providing the # list of exported symbols of that shared object, eventually # decorated with the 'weak' keyword # *) the shared object with the F_LOADONLY flag set, to really avoid # it being seen by the linker. # At run time we better use the real file rather than another symlink, # but for link time we create the symlink libNAME.so -> libNAME.so.V case $with_aix_soname,$aix_use_runtimelinking in # AIX (on Power*) has no versioning support, so currently we cannot hardcode correct # soname into executable. Probably we can add versioning support to # collect2, so additional links can be useful in future. aix,yes) # traditional libtool dynamic_linker='AIX unversionable lib.so' # If using run time linking (on AIX 4.2 or later) use lib.so # instead of lib.a to let people know that these are not # typical AIX shared libraries. library_names_spec='$libname$release$shared_ext$versuffix $libname$release$shared_ext$major $libname$shared_ext' ;; aix,no) # traditional AIX only dynamic_linker='AIX lib.a(lib.so.V)' # We preserve .a as extension for shared libraries through AIX4.2 # and later when we are not doing run time linking. library_names_spec='$libname$release.a $libname.a' soname_spec='$libname$release$shared_ext$major' ;; svr4,*) # full svr4 only dynamic_linker="AIX lib.so.V($shared_archive_member_spec.o)" library_names_spec='$libname$release$shared_ext$major $libname$shared_ext' # We do not specify a path in Import Files, so LIBPATH fires. shlibpath_overrides_runpath=yes ;; *,yes) # both, prefer svr4 dynamic_linker="AIX lib.so.V($shared_archive_member_spec.o), lib.a(lib.so.V)" library_names_spec='$libname$release$shared_ext$major $libname$shared_ext' # unpreferred sharedlib libNAME.a needs extra handling postinstall_cmds='test -n "$linkname" || linkname="$realname"~func_stripname "" ".so" "$linkname"~$install_shared_prog "$dir/$func_stripname_result.$libext" "$destdir/$func_stripname_result.$libext"~test -z "$tstripme" || test -z "$striplib" || $striplib "$destdir/$func_stripname_result.$libext"' postuninstall_cmds='for n in $library_names $old_library; do :; done~func_stripname "" ".so" "$n"~test "$func_stripname_result" = "$n" || func_append rmfiles " $odir/$func_stripname_result.$libext"' # We do not specify a path in Import Files, so LIBPATH fires. shlibpath_overrides_runpath=yes ;; *,no) # both, prefer aix dynamic_linker="AIX lib.a(lib.so.V), lib.so.V($shared_archive_member_spec.o)" library_names_spec='$libname$release.a $libname.a' soname_spec='$libname$release$shared_ext$major' # unpreferred sharedlib libNAME.so.V and symlink libNAME.so need extra handling postinstall_cmds='test -z "$dlname" || $install_shared_prog $dir/$dlname $destdir/$dlname~test -z "$tstripme" || test -z "$striplib" || $striplib $destdir/$dlname~test -n "$linkname" || linkname=$realname~func_stripname "" ".a" "$linkname"~(cd "$destdir" && $LN_S -f $dlname $func_stripname_result.so)' postuninstall_cmds='test -z "$dlname" || func_append rmfiles " $odir/$dlname"~for n in $old_library $library_names; do :; done~func_stripname "" ".a" "$n"~func_append rmfiles " $odir/$func_stripname_result.so"' ;; esac shlibpath_var=LIBPATH fi ;; amigaos*) case $host_cpu in powerpc) # Since July 2007 AmigaOS4 officially supports .so libraries. # When compiling the executable, add -use-dynld -Lsobjs: to the compileline. library_names_spec='$libname$release$shared_ext$versuffix $libname$release$shared_ext$major $libname$shared_ext' ;; m68k) library_names_spec='$libname.ixlibrary $libname.a' # Create ${libname}_ixlibrary.a entries in /sys/libs. finish_eval='for lib in `ls $libdir/*.ixlibrary 2>/dev/null`; do libname=`func_echo_all "$lib" | $SED '\''s%^.*/\([^/]*\)\.ixlibrary$%\1%'\''`; $RM /sys/libs/${libname}_ixlibrary.a; $show "cd /sys/libs && $LN_S $lib ${libname}_ixlibrary.a"; cd /sys/libs && $LN_S $lib ${libname}_ixlibrary.a || exit 1; done' ;; esac ;; beos*) library_names_spec='$libname$shared_ext' dynamic_linker="$host_os ld.so" shlibpath_var=LIBRARY_PATH ;; bsdi[45]*) version_type=linux # correct to gnu/linux during the next big refactor need_version=no library_names_spec='$libname$release$shared_ext$versuffix $libname$release$shared_ext$major $libname$shared_ext' soname_spec='$libname$release$shared_ext$major' finish_cmds='PATH="\$PATH:/sbin" ldconfig $libdir' shlibpath_var=LD_LIBRARY_PATH sys_lib_search_path_spec="/shlib /usr/lib /usr/X11/lib /usr/contrib/lib /lib /usr/local/lib" sys_lib_dlsearch_path_spec="/shlib /usr/lib /usr/local/lib" # the default ld.so.conf also contains /usr/contrib/lib and # /usr/X11R6/lib (/usr/X11 is a link to /usr/X11R6), but let us allow # libtool to hard-code these into programs ;; cygwin* | mingw* | pw32* | cegcc*) version_type=windows shrext_cmds=.dll need_version=no need_lib_prefix=no case $GCC,$cc_basename in yes,*) # gcc library_names_spec='$libname.dll.a' # DLL is installed to $(libdir)/../bin by postinstall_cmds postinstall_cmds='base_file=`basename \$file`~ dlpath=`$SHELL 2>&1 -c '\''. $dir/'\''\$base_file'\''i; echo \$dlname'\''`~ dldir=$destdir/`dirname \$dlpath`~ test -d \$dldir || mkdir -p \$dldir~ $install_prog $dir/$dlname \$dldir/$dlname~ chmod a+x \$dldir/$dlname~ if test -n '\''$stripme'\'' && test -n '\''$striplib'\''; then eval '\''$striplib \$dldir/$dlname'\'' || exit \$?; fi' postuninstall_cmds='dldll=`$SHELL 2>&1 -c '\''. $file; echo \$dlname'\''`~ dlpath=$dir/\$dldll~ $RM \$dlpath' shlibpath_overrides_runpath=yes case $host_os in cygwin*) # Cygwin DLLs use 'cyg' prefix rather than 'lib' soname_spec='`echo $libname | sed -e 's/^lib/cyg/'``echo $release | $SED -e 's/[.]/-/g'`$versuffix$shared_ext' sys_lib_search_path_spec="$sys_lib_search_path_spec /usr/lib/w32api" ;; mingw* | cegcc*) # MinGW DLLs use traditional 'lib' prefix soname_spec='$libname`echo $release | $SED -e 's/[.]/-/g'`$versuffix$shared_ext' ;; pw32*) # pw32 DLLs use 'pw' prefix rather than 'lib' library_names_spec='`echo $libname | sed -e 's/^lib/pw/'``echo $release | $SED -e 's/[.]/-/g'`$versuffix$shared_ext' ;; esac dynamic_linker='Win32 ld.exe' ;; *,cl*) # Native MSVC libname_spec='$name' soname_spec='$libname`echo $release | $SED -e 's/[.]/-/g'`$versuffix$shared_ext' library_names_spec='$libname.dll.lib' case $build_os in mingw*) sys_lib_search_path_spec= lt_save_ifs=$IFS IFS=';' for lt_path in $LIB do IFS=$lt_save_ifs # Let DOS variable expansion print the short 8.3 style file name. lt_path=`cd "$lt_path" 2>/dev/null && cmd //C "for %i in (".") do @echo %~si"` sys_lib_search_path_spec="$sys_lib_search_path_spec $lt_path" done IFS=$lt_save_ifs # Convert to MSYS style. sys_lib_search_path_spec=`$ECHO "$sys_lib_search_path_spec" | sed -e 's|\\\\|/|g' -e 's| \\([a-zA-Z]\\):| /\\1|g' -e 's|^ ||'` ;; cygwin*) # Convert to unix form, then to dos form, then back to unix form # but this time dos style (no spaces!) so that the unix form looks # like /cygdrive/c/PROGRA~1:/cygdr... sys_lib_search_path_spec=`cygpath --path --unix "$LIB"` sys_lib_search_path_spec=`cygpath --path --dos "$sys_lib_search_path_spec" 2>/dev/null` sys_lib_search_path_spec=`cygpath --path --unix "$sys_lib_search_path_spec" | $SED -e "s/$PATH_SEPARATOR/ /g"` ;; *) sys_lib_search_path_spec=$LIB if $ECHO "$sys_lib_search_path_spec" | $GREP ';[c-zC-Z]:/' >/dev/null; then # It is most probably a Windows format PATH. sys_lib_search_path_spec=`$ECHO "$sys_lib_search_path_spec" | $SED -e 's/;/ /g'` else sys_lib_search_path_spec=`$ECHO "$sys_lib_search_path_spec" | $SED -e "s/$PATH_SEPARATOR/ /g"` fi # FIXME: find the short name or the path components, as spaces are # common. (e.g. "Program Files" -> "PROGRA~1") ;; esac # DLL is installed to $(libdir)/../bin by postinstall_cmds postinstall_cmds='base_file=`basename \$file`~ dlpath=`$SHELL 2>&1 -c '\''. $dir/'\''\$base_file'\''i; echo \$dlname'\''`~ dldir=$destdir/`dirname \$dlpath`~ test -d \$dldir || mkdir -p \$dldir~ $install_prog $dir/$dlname \$dldir/$dlname' postuninstall_cmds='dldll=`$SHELL 2>&1 -c '\''. $file; echo \$dlname'\''`~ dlpath=$dir/\$dldll~ $RM \$dlpath' shlibpath_overrides_runpath=yes dynamic_linker='Win32 link.exe' ;; *) # Assume MSVC wrapper library_names_spec='$libname`echo $release | $SED -e 's/[.]/-/g'`$versuffix$shared_ext $libname.lib' dynamic_linker='Win32 ld.exe' ;; esac # FIXME: first we should search . and the directory the executable is in shlibpath_var=PATH ;; darwin* | rhapsody*) dynamic_linker="$host_os dyld" version_type=darwin need_lib_prefix=no need_version=no library_names_spec='$libname$release$major$shared_ext $libname$shared_ext' soname_spec='$libname$release$major$shared_ext' shlibpath_overrides_runpath=yes shlibpath_var=DYLD_LIBRARY_PATH shrext_cmds='`test .$module = .yes && echo .so || echo .dylib`' sys_lib_search_path_spec="$sys_lib_search_path_spec /usr/local/lib" sys_lib_dlsearch_path_spec='/usr/local/lib /lib /usr/lib' ;; dgux*) version_type=linux # correct to gnu/linux during the next big refactor need_lib_prefix=no need_version=no library_names_spec='$libname$release$shared_ext$versuffix $libname$release$shared_ext$major $libname$shared_ext' soname_spec='$libname$release$shared_ext$major' shlibpath_var=LD_LIBRARY_PATH ;; freebsd* | dragonfly*) # DragonFly does not have aout. When/if they implement a new # versioning mechanism, adjust this. if test -x /usr/bin/objformat; then objformat=`/usr/bin/objformat` else case $host_os in freebsd[23].*) objformat=aout ;; *) objformat=elf ;; esac fi version_type=freebsd-$objformat case $version_type in freebsd-elf*) library_names_spec='$libname$release$shared_ext$versuffix $libname$release$shared_ext$major $libname$shared_ext' soname_spec='$libname$release$shared_ext$major' need_version=no need_lib_prefix=no ;; freebsd-*) library_names_spec='$libname$release$shared_ext$versuffix $libname$shared_ext$versuffix' need_version=yes ;; esac shlibpath_var=LD_LIBRARY_PATH case $host_os in freebsd2.*) shlibpath_overrides_runpath=yes ;; freebsd3.[01]* | freebsdelf3.[01]*) shlibpath_overrides_runpath=yes hardcode_into_libs=yes ;; freebsd3.[2-9]* | freebsdelf3.[2-9]* | \ freebsd4.[0-5] | freebsdelf4.[0-5] | freebsd4.1.1 | freebsdelf4.1.1) shlibpath_overrides_runpath=no hardcode_into_libs=yes ;; *) # from 4.6 on, and DragonFly shlibpath_overrides_runpath=yes hardcode_into_libs=yes ;; esac ;; haiku*) version_type=linux # correct to gnu/linux during the next big refactor need_lib_prefix=no need_version=no dynamic_linker="$host_os runtime_loader" library_names_spec='$libname$release$shared_ext$versuffix $libname$release$shared_ext$major $libname$shared_ext' soname_spec='$libname$release$shared_ext$major' shlibpath_var=LIBRARY_PATH shlibpath_overrides_runpath=no sys_lib_dlsearch_path_spec='/boot/home/config/lib /boot/common/lib /boot/system/lib' hardcode_into_libs=yes ;; hpux9* | hpux10* | hpux11*) # Give a soname corresponding to the major version so that dld.sl refuses to # link against other versions. version_type=sunos need_lib_prefix=no need_version=no case $host_cpu in ia64*) shrext_cmds='.so' hardcode_into_libs=yes dynamic_linker="$host_os dld.so" shlibpath_var=LD_LIBRARY_PATH shlibpath_overrides_runpath=yes # Unless +noenvvar is specified. library_names_spec='$libname$release$shared_ext$versuffix $libname$release$shared_ext$major $libname$shared_ext' soname_spec='$libname$release$shared_ext$major' if test 32 = "$HPUX_IA64_MODE"; then sys_lib_search_path_spec="/usr/lib/hpux32 /usr/local/lib/hpux32 /usr/local/lib" sys_lib_dlsearch_path_spec=/usr/lib/hpux32 else sys_lib_search_path_spec="/usr/lib/hpux64 /usr/local/lib/hpux64" sys_lib_dlsearch_path_spec=/usr/lib/hpux64 fi ;; hppa*64*) shrext_cmds='.sl' hardcode_into_libs=yes dynamic_linker="$host_os dld.sl" shlibpath_var=LD_LIBRARY_PATH # How should we handle SHLIB_PATH shlibpath_overrides_runpath=yes # Unless +noenvvar is specified. library_names_spec='$libname$release$shared_ext$versuffix $libname$release$shared_ext$major $libname$shared_ext' soname_spec='$libname$release$shared_ext$major' sys_lib_search_path_spec="/usr/lib/pa20_64 /usr/ccs/lib/pa20_64" sys_lib_dlsearch_path_spec=$sys_lib_search_path_spec ;; *) shrext_cmds='.sl' dynamic_linker="$host_os dld.sl" shlibpath_var=SHLIB_PATH shlibpath_overrides_runpath=no # +s is required to enable SHLIB_PATH library_names_spec='$libname$release$shared_ext$versuffix $libname$release$shared_ext$major $libname$shared_ext' soname_spec='$libname$release$shared_ext$major' ;; esac # HP-UX runs *really* slowly unless shared libraries are mode 555, ... postinstall_cmds='chmod 555 $lib' # or fails outright, so override atomically: install_override_mode=555 ;; interix[3-9]*) version_type=linux # correct to gnu/linux during the next big refactor need_lib_prefix=no need_version=no library_names_spec='$libname$release$shared_ext$versuffix $libname$release$shared_ext$major $libname$shared_ext' soname_spec='$libname$release$shared_ext$major' dynamic_linker='Interix 3.x ld.so.1 (PE, like ELF)' shlibpath_var=LD_LIBRARY_PATH shlibpath_overrides_runpath=no hardcode_into_libs=yes ;; irix5* | irix6* | nonstopux*) case $host_os in nonstopux*) version_type=nonstopux ;; *) if test yes = "$lt_cv_prog_gnu_ld"; then version_type=linux # correct to gnu/linux during the next big refactor else version_type=irix fi ;; esac need_lib_prefix=no need_version=no soname_spec='$libname$release$shared_ext$major' library_names_spec='$libname$release$shared_ext$versuffix $libname$release$shared_ext$major $libname$release$shared_ext $libname$shared_ext' case $host_os in irix5* | nonstopux*) libsuff= shlibsuff= ;; *) case $LD in # libtool.m4 will add one of these switches to LD *-32|*"-32 "|*-melf32bsmip|*"-melf32bsmip ") libsuff= shlibsuff= libmagic=32-bit;; *-n32|*"-n32 "|*-melf32bmipn32|*"-melf32bmipn32 ") libsuff=32 shlibsuff=N32 libmagic=N32;; *-64|*"-64 "|*-melf64bmip|*"-melf64bmip ") libsuff=64 shlibsuff=64 libmagic=64-bit;; *) libsuff= shlibsuff= libmagic=never-match;; esac ;; esac shlibpath_var=LD_LIBRARY${shlibsuff}_PATH shlibpath_overrides_runpath=no sys_lib_search_path_spec="/usr/lib$libsuff /lib$libsuff /usr/local/lib$libsuff" sys_lib_dlsearch_path_spec="/usr/lib$libsuff /lib$libsuff" hardcode_into_libs=yes ;; # No shared lib support for Linux oldld, aout, or coff. linux*oldld* | linux*aout* | linux*coff*) dynamic_linker=no ;; linux*android*) version_type=none # Android doesn't support versioned libraries. need_lib_prefix=no need_version=no library_names_spec='$libname$release$shared_ext' soname_spec='$libname$release$shared_ext' finish_cmds= shlibpath_var=LD_LIBRARY_PATH shlibpath_overrides_runpath=yes # This implies no fast_install, which is unacceptable. # Some rework will be needed to allow for fast_install # before this can be enabled. hardcode_into_libs=yes dynamic_linker='Android linker' # Don't embed -rpath directories since the linker doesn't support them. hardcode_libdir_flag_spec='-L$libdir' ;; # This must be glibc/ELF. linux* | k*bsd*-gnu | kopensolaris*-gnu | gnu*) version_type=linux # correct to gnu/linux during the next big refactor need_lib_prefix=no need_version=no library_names_spec='$libname$release$shared_ext$versuffix $libname$release$shared_ext$major $libname$shared_ext' soname_spec='$libname$release$shared_ext$major' finish_cmds='PATH="\$PATH:/sbin" ldconfig -n $libdir' shlibpath_var=LD_LIBRARY_PATH shlibpath_overrides_runpath=no # Some binutils ld are patched to set DT_RUNPATH if ${lt_cv_shlibpath_overrides_runpath+:} false; then : $as_echo_n "(cached) " >&6 else lt_cv_shlibpath_overrides_runpath=no save_LDFLAGS=$LDFLAGS save_libdir=$libdir eval "libdir=/foo; wl=\"$lt_prog_compiler_wl\"; \ LDFLAGS=\"\$LDFLAGS $hardcode_libdir_flag_spec\"" cat confdefs.h - <<_ACEOF >conftest.$ac_ext /* end confdefs.h. */ int main () { ; return 0; } _ACEOF if ac_fn_c_try_link "$LINENO"; then : if ($OBJDUMP -p conftest$ac_exeext) 2>/dev/null | grep "RUNPATH.*$libdir" >/dev/null; then : lt_cv_shlibpath_overrides_runpath=yes fi fi rm -f core conftest.err conftest.$ac_objext \ conftest$ac_exeext conftest.$ac_ext LDFLAGS=$save_LDFLAGS libdir=$save_libdir fi shlibpath_overrides_runpath=$lt_cv_shlibpath_overrides_runpath # This implies no fast_install, which is unacceptable. # Some rework will be needed to allow for fast_install # before this can be enabled. hardcode_into_libs=yes # Ideally, we could use ldconfig to report *all* directores which are # searched for libraries, however this is still not possible. Aside from not # being certain /sbin/ldconfig is available, command # 'ldconfig -N -X -v | grep ^/' on 64bit Fedora does not report /usr/lib64, # even though it is searched at run-time. Try to do the best guess by # appending ld.so.conf contents (and includes) to the search path. if test -f /etc/ld.so.conf; then lt_ld_extra=`awk '/^include / { system(sprintf("cd /etc; cat %s 2>/dev/null", \$2)); skip = 1; } { if (!skip) print \$0; skip = 0; }' < /etc/ld.so.conf | $SED -e 's/#.*//;/^[ ]*hwcap[ ]/d;s/[:, ]/ /g;s/=[^=]*$//;s/=[^= ]* / /g;s/"//g;/^$/d' | tr '\n' ' '` sys_lib_dlsearch_path_spec="/lib /usr/lib $lt_ld_extra" fi # We used to test for /lib/ld.so.1 and disable shared libraries on # powerpc, because MkLinux only supported shared libraries with the # GNU dynamic linker. Since this was broken with cross compilers, # most powerpc-linux boxes support dynamic linking these days and # people can always --disable-shared, the test was removed, and we # assume the GNU/Linux dynamic linker is in use. dynamic_linker='GNU/Linux ld.so' ;; netbsd*) version_type=sunos need_lib_prefix=no need_version=no if echo __ELF__ | $CC -E - | $GREP __ELF__ >/dev/null; then library_names_spec='$libname$release$shared_ext$versuffix $libname$shared_ext$versuffix' finish_cmds='PATH="\$PATH:/sbin" ldconfig -m $libdir' dynamic_linker='NetBSD (a.out) ld.so' else library_names_spec='$libname$release$shared_ext$versuffix $libname$release$shared_ext$major $libname$shared_ext' soname_spec='$libname$release$shared_ext$major' dynamic_linker='NetBSD ld.elf_so' fi shlibpath_var=LD_LIBRARY_PATH shlibpath_overrides_runpath=yes hardcode_into_libs=yes ;; newsos6) version_type=linux # correct to gnu/linux during the next big refactor library_names_spec='$libname$release$shared_ext$versuffix $libname$release$shared_ext$major $libname$shared_ext' shlibpath_var=LD_LIBRARY_PATH shlibpath_overrides_runpath=yes ;; *nto* | *qnx*) version_type=qnx need_lib_prefix=no need_version=no library_names_spec='$libname$release$shared_ext$versuffix $libname$release$shared_ext$major $libname$shared_ext' soname_spec='$libname$release$shared_ext$major' shlibpath_var=LD_LIBRARY_PATH shlibpath_overrides_runpath=no hardcode_into_libs=yes dynamic_linker='ldqnx.so' ;; openbsd* | bitrig*) version_type=sunos sys_lib_dlsearch_path_spec=/usr/lib need_lib_prefix=no if test -z "`echo __ELF__ | $CC -E - | $GREP __ELF__`"; then need_version=no else need_version=yes fi library_names_spec='$libname$release$shared_ext$versuffix $libname$shared_ext$versuffix' finish_cmds='PATH="\$PATH:/sbin" ldconfig -m $libdir' shlibpath_var=LD_LIBRARY_PATH shlibpath_overrides_runpath=yes ;; os2*) libname_spec='$name' version_type=windows shrext_cmds=.dll need_version=no need_lib_prefix=no # OS/2 can only load a DLL with a base name of 8 characters or less. soname_spec='`test -n "$os2dllname" && libname="$os2dllname"; v=$($ECHO $release$versuffix | tr -d .-); n=$($ECHO $libname | cut -b -$((8 - ${#v})) | tr . _); $ECHO $n$v`$shared_ext' library_names_spec='${libname}_dll.$libext' dynamic_linker='OS/2 ld.exe' shlibpath_var=BEGINLIBPATH sys_lib_search_path_spec="/lib /usr/lib /usr/local/lib" sys_lib_dlsearch_path_spec=$sys_lib_search_path_spec postinstall_cmds='base_file=`basename \$file`~ dlpath=`$SHELL 2>&1 -c '\''. $dir/'\''\$base_file'\''i; $ECHO \$dlname'\''`~ dldir=$destdir/`dirname \$dlpath`~ test -d \$dldir || mkdir -p \$dldir~ $install_prog $dir/$dlname \$dldir/$dlname~ chmod a+x \$dldir/$dlname~ if test -n '\''$stripme'\'' && test -n '\''$striplib'\''; then eval '\''$striplib \$dldir/$dlname'\'' || exit \$?; fi' postuninstall_cmds='dldll=`$SHELL 2>&1 -c '\''. $file; $ECHO \$dlname'\''`~ dlpath=$dir/\$dldll~ $RM \$dlpath' ;; osf3* | osf4* | osf5*) version_type=osf need_lib_prefix=no need_version=no soname_spec='$libname$release$shared_ext$major' library_names_spec='$libname$release$shared_ext$versuffix $libname$release$shared_ext$major $libname$shared_ext' shlibpath_var=LD_LIBRARY_PATH sys_lib_search_path_spec="/usr/shlib /usr/ccs/lib /usr/lib/cmplrs/cc /usr/lib /usr/local/lib /var/shlib" sys_lib_dlsearch_path_spec=$sys_lib_search_path_spec ;; rdos*) dynamic_linker=no ;; solaris*) version_type=linux # correct to gnu/linux during the next big refactor need_lib_prefix=no need_version=no library_names_spec='$libname$release$shared_ext$versuffix $libname$release$shared_ext$major $libname$shared_ext' soname_spec='$libname$release$shared_ext$major' shlibpath_var=LD_LIBRARY_PATH shlibpath_overrides_runpath=yes hardcode_into_libs=yes # ldd complains unless libraries are executable postinstall_cmds='chmod +x $lib' ;; sunos4*) version_type=sunos library_names_spec='$libname$release$shared_ext$versuffix $libname$shared_ext$versuffix' finish_cmds='PATH="\$PATH:/usr/etc" ldconfig $libdir' shlibpath_var=LD_LIBRARY_PATH shlibpath_overrides_runpath=yes if test yes = "$with_gnu_ld"; then need_lib_prefix=no fi need_version=yes ;; sysv4 | sysv4.3*) version_type=linux # correct to gnu/linux during the next big refactor library_names_spec='$libname$release$shared_ext$versuffix $libname$release$shared_ext$major $libname$shared_ext' soname_spec='$libname$release$shared_ext$major' shlibpath_var=LD_LIBRARY_PATH case $host_vendor in sni) shlibpath_overrides_runpath=no need_lib_prefix=no runpath_var=LD_RUN_PATH ;; siemens) need_lib_prefix=no ;; motorola) need_lib_prefix=no need_version=no shlibpath_overrides_runpath=no sys_lib_search_path_spec='/lib /usr/lib /usr/ccs/lib' ;; esac ;; sysv4*MP*) if test -d /usr/nec; then version_type=linux # correct to gnu/linux during the next big refactor library_names_spec='$libname$shared_ext.$versuffix $libname$shared_ext.$major $libname$shared_ext' soname_spec='$libname$shared_ext.$major' shlibpath_var=LD_LIBRARY_PATH fi ;; sysv5* | sco3.2v5* | sco5v6* | unixware* | OpenUNIX* | sysv4*uw2*) version_type=sco need_lib_prefix=no need_version=no library_names_spec='$libname$release$shared_ext$versuffix $libname$release$shared_ext $libname$shared_ext' soname_spec='$libname$release$shared_ext$major' shlibpath_var=LD_LIBRARY_PATH shlibpath_overrides_runpath=yes hardcode_into_libs=yes if test yes = "$with_gnu_ld"; then sys_lib_search_path_spec='/usr/local/lib /usr/gnu/lib /usr/ccs/lib /usr/lib /lib' else sys_lib_search_path_spec='/usr/ccs/lib /usr/lib' case $host_os in sco3.2v5*) sys_lib_search_path_spec="$sys_lib_search_path_spec /lib" ;; esac fi sys_lib_dlsearch_path_spec='/usr/lib' ;; tpf*) # TPF is a cross-target only. Preferred cross-host = GNU/Linux. version_type=linux # correct to gnu/linux during the next big refactor need_lib_prefix=no need_version=no library_names_spec='$libname$release$shared_ext$versuffix $libname$release$shared_ext$major $libname$shared_ext' shlibpath_var=LD_LIBRARY_PATH shlibpath_overrides_runpath=no hardcode_into_libs=yes ;; uts4*) version_type=linux # correct to gnu/linux during the next big refactor library_names_spec='$libname$release$shared_ext$versuffix $libname$release$shared_ext$major $libname$shared_ext' soname_spec='$libname$release$shared_ext$major' shlibpath_var=LD_LIBRARY_PATH ;; *) dynamic_linker=no ;; esac { $as_echo "$as_me:${as_lineno-$LINENO}: result: $dynamic_linker" >&5 $as_echo "$dynamic_linker" >&6; } test no = "$dynamic_linker" && can_build_shared=no variables_saved_for_relink="PATH $shlibpath_var $runpath_var" if test yes = "$GCC"; then variables_saved_for_relink="$variables_saved_for_relink GCC_EXEC_PREFIX COMPILER_PATH LIBRARY_PATH" fi if test set = "${lt_cv_sys_lib_search_path_spec+set}"; then sys_lib_search_path_spec=$lt_cv_sys_lib_search_path_spec fi if test set = "${lt_cv_sys_lib_dlsearch_path_spec+set}"; then sys_lib_dlsearch_path_spec=$lt_cv_sys_lib_dlsearch_path_spec fi # remember unaugmented sys_lib_dlsearch_path content for libtool script decls... configure_time_dlsearch_path=$sys_lib_dlsearch_path_spec # ... but it needs LT_SYS_LIBRARY_PATH munging for other configure-time code func_munge_path_list sys_lib_dlsearch_path_spec "$LT_SYS_LIBRARY_PATH" # to be used as default LT_SYS_LIBRARY_PATH value in generated libtool configure_time_lt_sys_library_path=$LT_SYS_LIBRARY_PATH { $as_echo "$as_me:${as_lineno-$LINENO}: checking how to hardcode library paths into programs" >&5 $as_echo_n "checking how to hardcode library paths into programs... " >&6; } hardcode_action= if test -n "$hardcode_libdir_flag_spec" || test -n "$runpath_var" || test yes = "$hardcode_automatic"; then # We can hardcode non-existent directories. if test no != "$hardcode_direct" && # If the only mechanism to avoid hardcoding is shlibpath_var, we # have to relink, otherwise we might link with an installed library # when we should be linking with a yet-to-be-installed one ## test no != "$_LT_TAGVAR(hardcode_shlibpath_var, )" && test no != "$hardcode_minus_L"; then # Linking always hardcodes the temporary library directory. hardcode_action=relink else # We can link without hardcoding, and we can hardcode nonexisting dirs. hardcode_action=immediate fi else # We cannot hardcode anything, or else we can only hardcode existing # directories. hardcode_action=unsupported fi { $as_echo "$as_me:${as_lineno-$LINENO}: result: $hardcode_action" >&5 $as_echo "$hardcode_action" >&6; } if test relink = "$hardcode_action" || test yes = "$inherit_rpath"; then # Fast installation is not supported enable_fast_install=no elif test yes = "$shlibpath_overrides_runpath" || test no = "$enable_shared"; then # Fast installation is not necessary enable_fast_install=needless fi if test yes != "$enable_dlopen"; then enable_dlopen=unknown enable_dlopen_self=unknown enable_dlopen_self_static=unknown else lt_cv_dlopen=no lt_cv_dlopen_libs= case $host_os in beos*) lt_cv_dlopen=load_add_on lt_cv_dlopen_libs= lt_cv_dlopen_self=yes ;; mingw* | pw32* | cegcc*) lt_cv_dlopen=LoadLibrary lt_cv_dlopen_libs= ;; cygwin*) lt_cv_dlopen=dlopen lt_cv_dlopen_libs= ;; darwin*) # if libdl is installed we need to link against it { $as_echo "$as_me:${as_lineno-$LINENO}: checking for dlopen in -ldl" >&5 $as_echo_n "checking for dlopen in -ldl... " >&6; } if ${ac_cv_lib_dl_dlopen+:} false; then : $as_echo_n "(cached) " >&6 else ac_check_lib_save_LIBS=$LIBS LIBS="-ldl $LIBS" cat confdefs.h - <<_ACEOF >conftest.$ac_ext /* end confdefs.h. */ /* Override any GCC internal prototype to avoid an error. Use char because int might match the return type of a GCC builtin and then its argument prototype would still apply. */ #ifdef __cplusplus extern "C" #endif char dlopen (); int main () { return dlopen (); ; return 0; } _ACEOF if ac_fn_c_try_link "$LINENO"; then : ac_cv_lib_dl_dlopen=yes else ac_cv_lib_dl_dlopen=no fi rm -f core conftest.err conftest.$ac_objext \ conftest$ac_exeext conftest.$ac_ext LIBS=$ac_check_lib_save_LIBS fi { $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_cv_lib_dl_dlopen" >&5 $as_echo "$ac_cv_lib_dl_dlopen" >&6; } if test "x$ac_cv_lib_dl_dlopen" = xyes; then : lt_cv_dlopen=dlopen lt_cv_dlopen_libs=-ldl else lt_cv_dlopen=dyld lt_cv_dlopen_libs= lt_cv_dlopen_self=yes fi ;; tpf*) # Don't try to run any link tests for TPF. We know it's impossible # because TPF is a cross-compiler, and we know how we open DSOs. lt_cv_dlopen=dlopen lt_cv_dlopen_libs= lt_cv_dlopen_self=no ;; *) ac_fn_c_check_func "$LINENO" "shl_load" "ac_cv_func_shl_load" if test "x$ac_cv_func_shl_load" = xyes; then : lt_cv_dlopen=shl_load else { $as_echo "$as_me:${as_lineno-$LINENO}: checking for shl_load in -ldld" >&5 $as_echo_n "checking for shl_load in -ldld... " >&6; } if ${ac_cv_lib_dld_shl_load+:} false; then : $as_echo_n "(cached) " >&6 else ac_check_lib_save_LIBS=$LIBS LIBS="-ldld $LIBS" cat confdefs.h - <<_ACEOF >conftest.$ac_ext /* end confdefs.h. */ /* Override any GCC internal prototype to avoid an error. Use char because int might match the return type of a GCC builtin and then its argument prototype would still apply. */ #ifdef __cplusplus extern "C" #endif char shl_load (); int main () { return shl_load (); ; return 0; } _ACEOF if ac_fn_c_try_link "$LINENO"; then : ac_cv_lib_dld_shl_load=yes else ac_cv_lib_dld_shl_load=no fi rm -f core conftest.err conftest.$ac_objext \ conftest$ac_exeext conftest.$ac_ext LIBS=$ac_check_lib_save_LIBS fi { $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_cv_lib_dld_shl_load" >&5 $as_echo "$ac_cv_lib_dld_shl_load" >&6; } if test "x$ac_cv_lib_dld_shl_load" = xyes; then : lt_cv_dlopen=shl_load lt_cv_dlopen_libs=-ldld else ac_fn_c_check_func "$LINENO" "dlopen" "ac_cv_func_dlopen" if test "x$ac_cv_func_dlopen" = xyes; then : lt_cv_dlopen=dlopen else { $as_echo "$as_me:${as_lineno-$LINENO}: checking for dlopen in -ldl" >&5 $as_echo_n "checking for dlopen in -ldl... " >&6; } if ${ac_cv_lib_dl_dlopen+:} false; then : $as_echo_n "(cached) " >&6 else ac_check_lib_save_LIBS=$LIBS LIBS="-ldl $LIBS" cat confdefs.h - <<_ACEOF >conftest.$ac_ext /* end confdefs.h. */ /* Override any GCC internal prototype to avoid an error. Use char because int might match the return type of a GCC builtin and then its argument prototype would still apply. */ #ifdef __cplusplus extern "C" #endif char dlopen (); int main () { return dlopen (); ; return 0; } _ACEOF if ac_fn_c_try_link "$LINENO"; then : ac_cv_lib_dl_dlopen=yes else ac_cv_lib_dl_dlopen=no fi rm -f core conftest.err conftest.$ac_objext \ conftest$ac_exeext conftest.$ac_ext LIBS=$ac_check_lib_save_LIBS fi { $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_cv_lib_dl_dlopen" >&5 $as_echo "$ac_cv_lib_dl_dlopen" >&6; } if test "x$ac_cv_lib_dl_dlopen" = xyes; then : lt_cv_dlopen=dlopen lt_cv_dlopen_libs=-ldl else { $as_echo "$as_me:${as_lineno-$LINENO}: checking for dlopen in -lsvld" >&5 $as_echo_n "checking for dlopen in -lsvld... " >&6; } if ${ac_cv_lib_svld_dlopen+:} false; then : $as_echo_n "(cached) " >&6 else ac_check_lib_save_LIBS=$LIBS LIBS="-lsvld $LIBS" cat confdefs.h - <<_ACEOF >conftest.$ac_ext /* end confdefs.h. */ /* Override any GCC internal prototype to avoid an error. Use char because int might match the return type of a GCC builtin and then its argument prototype would still apply. */ #ifdef __cplusplus extern "C" #endif char dlopen (); int main () { return dlopen (); ; return 0; } _ACEOF if ac_fn_c_try_link "$LINENO"; then : ac_cv_lib_svld_dlopen=yes else ac_cv_lib_svld_dlopen=no fi rm -f core conftest.err conftest.$ac_objext \ conftest$ac_exeext conftest.$ac_ext LIBS=$ac_check_lib_save_LIBS fi { $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_cv_lib_svld_dlopen" >&5 $as_echo "$ac_cv_lib_svld_dlopen" >&6; } if test "x$ac_cv_lib_svld_dlopen" = xyes; then : lt_cv_dlopen=dlopen lt_cv_dlopen_libs=-lsvld else { $as_echo "$as_me:${as_lineno-$LINENO}: checking for dld_link in -ldld" >&5 $as_echo_n "checking for dld_link in -ldld... " >&6; } if ${ac_cv_lib_dld_dld_link+:} false; then : $as_echo_n "(cached) " >&6 else ac_check_lib_save_LIBS=$LIBS LIBS="-ldld $LIBS" cat confdefs.h - <<_ACEOF >conftest.$ac_ext /* end confdefs.h. */ /* Override any GCC internal prototype to avoid an error. Use char because int might match the return type of a GCC builtin and then its argument prototype would still apply. */ #ifdef __cplusplus extern "C" #endif char dld_link (); int main () { return dld_link (); ; return 0; } _ACEOF if ac_fn_c_try_link "$LINENO"; then : ac_cv_lib_dld_dld_link=yes else ac_cv_lib_dld_dld_link=no fi rm -f core conftest.err conftest.$ac_objext \ conftest$ac_exeext conftest.$ac_ext LIBS=$ac_check_lib_save_LIBS fi { $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_cv_lib_dld_dld_link" >&5 $as_echo "$ac_cv_lib_dld_dld_link" >&6; } if test "x$ac_cv_lib_dld_dld_link" = xyes; then : lt_cv_dlopen=dld_link lt_cv_dlopen_libs=-ldld fi fi fi fi fi fi ;; esac if test no = "$lt_cv_dlopen"; then enable_dlopen=no else enable_dlopen=yes fi case $lt_cv_dlopen in dlopen) save_CPPFLAGS=$CPPFLAGS test yes = "$ac_cv_header_dlfcn_h" && CPPFLAGS="$CPPFLAGS -DHAVE_DLFCN_H" save_LDFLAGS=$LDFLAGS wl=$lt_prog_compiler_wl eval LDFLAGS=\"\$LDFLAGS $export_dynamic_flag_spec\" save_LIBS=$LIBS LIBS="$lt_cv_dlopen_libs $LIBS" { $as_echo "$as_me:${as_lineno-$LINENO}: checking whether a program can dlopen itself" >&5 $as_echo_n "checking whether a program can dlopen itself... " >&6; } if ${lt_cv_dlopen_self+:} false; then : $as_echo_n "(cached) " >&6 else if test yes = "$cross_compiling"; then : lt_cv_dlopen_self=cross else lt_dlunknown=0; lt_dlno_uscore=1; lt_dlneed_uscore=2 lt_status=$lt_dlunknown cat > conftest.$ac_ext <<_LT_EOF #line $LINENO "configure" #include "confdefs.h" #if HAVE_DLFCN_H #include #endif #include #ifdef RTLD_GLOBAL # define LT_DLGLOBAL RTLD_GLOBAL #else # ifdef DL_GLOBAL # define LT_DLGLOBAL DL_GLOBAL # else # define LT_DLGLOBAL 0 # endif #endif /* We may have to define LT_DLLAZY_OR_NOW in the command line if we find out it does not work in some platform. */ #ifndef LT_DLLAZY_OR_NOW # ifdef RTLD_LAZY # define LT_DLLAZY_OR_NOW RTLD_LAZY # else # ifdef DL_LAZY # define LT_DLLAZY_OR_NOW DL_LAZY # else # ifdef RTLD_NOW # define LT_DLLAZY_OR_NOW RTLD_NOW # else # ifdef DL_NOW # define LT_DLLAZY_OR_NOW DL_NOW # else # define LT_DLLAZY_OR_NOW 0 # endif # endif # endif # endif #endif /* When -fvisibility=hidden is used, assume the code has been annotated correspondingly for the symbols needed. */ #if defined __GNUC__ && (((__GNUC__ == 3) && (__GNUC_MINOR__ >= 3)) || (__GNUC__ > 3)) int fnord () __attribute__((visibility("default"))); #endif int fnord () { return 42; } int main () { void *self = dlopen (0, LT_DLGLOBAL|LT_DLLAZY_OR_NOW); int status = $lt_dlunknown; if (self) { if (dlsym (self,"fnord")) status = $lt_dlno_uscore; else { if (dlsym( self,"_fnord")) status = $lt_dlneed_uscore; else puts (dlerror ()); } /* dlclose (self); */ } else puts (dlerror ()); return status; } _LT_EOF if { { eval echo "\"\$as_me\":${as_lineno-$LINENO}: \"$ac_link\""; } >&5 (eval $ac_link) 2>&5 ac_status=$? $as_echo "$as_me:${as_lineno-$LINENO}: \$? = $ac_status" >&5 test $ac_status = 0; } && test -s "conftest$ac_exeext" 2>/dev/null; then (./conftest; exit; ) >&5 2>/dev/null lt_status=$? case x$lt_status in x$lt_dlno_uscore) lt_cv_dlopen_self=yes ;; x$lt_dlneed_uscore) lt_cv_dlopen_self=yes ;; x$lt_dlunknown|x*) lt_cv_dlopen_self=no ;; esac else : # compilation failed lt_cv_dlopen_self=no fi fi rm -fr conftest* fi { $as_echo "$as_me:${as_lineno-$LINENO}: result: $lt_cv_dlopen_self" >&5 $as_echo "$lt_cv_dlopen_self" >&6; } if test yes = "$lt_cv_dlopen_self"; then wl=$lt_prog_compiler_wl eval LDFLAGS=\"\$LDFLAGS $lt_prog_compiler_static\" { $as_echo "$as_me:${as_lineno-$LINENO}: checking whether a statically linked program can dlopen itself" >&5 $as_echo_n "checking whether a statically linked program can dlopen itself... " >&6; } if ${lt_cv_dlopen_self_static+:} false; then : $as_echo_n "(cached) " >&6 else if test yes = "$cross_compiling"; then : lt_cv_dlopen_self_static=cross else lt_dlunknown=0; lt_dlno_uscore=1; lt_dlneed_uscore=2 lt_status=$lt_dlunknown cat > conftest.$ac_ext <<_LT_EOF #line $LINENO "configure" #include "confdefs.h" #if HAVE_DLFCN_H #include #endif #include #ifdef RTLD_GLOBAL # define LT_DLGLOBAL RTLD_GLOBAL #else # ifdef DL_GLOBAL # define LT_DLGLOBAL DL_GLOBAL # else # define LT_DLGLOBAL 0 # endif #endif /* We may have to define LT_DLLAZY_OR_NOW in the command line if we find out it does not work in some platform. */ #ifndef LT_DLLAZY_OR_NOW # ifdef RTLD_LAZY # define LT_DLLAZY_OR_NOW RTLD_LAZY # else # ifdef DL_LAZY # define LT_DLLAZY_OR_NOW DL_LAZY # else # ifdef RTLD_NOW # define LT_DLLAZY_OR_NOW RTLD_NOW # else # ifdef DL_NOW # define LT_DLLAZY_OR_NOW DL_NOW # else # define LT_DLLAZY_OR_NOW 0 # endif # endif # endif # endif #endif /* When -fvisibility=hidden is used, assume the code has been annotated correspondingly for the symbols needed. */ #if defined __GNUC__ && (((__GNUC__ == 3) && (__GNUC_MINOR__ >= 3)) || (__GNUC__ > 3)) int fnord () __attribute__((visibility("default"))); #endif int fnord () { return 42; } int main () { void *self = dlopen (0, LT_DLGLOBAL|LT_DLLAZY_OR_NOW); int status = $lt_dlunknown; if (self) { if (dlsym (self,"fnord")) status = $lt_dlno_uscore; else { if (dlsym( self,"_fnord")) status = $lt_dlneed_uscore; else puts (dlerror ()); } /* dlclose (self); */ } else puts (dlerror ()); return status; } _LT_EOF if { { eval echo "\"\$as_me\":${as_lineno-$LINENO}: \"$ac_link\""; } >&5 (eval $ac_link) 2>&5 ac_status=$? $as_echo "$as_me:${as_lineno-$LINENO}: \$? = $ac_status" >&5 test $ac_status = 0; } && test -s "conftest$ac_exeext" 2>/dev/null; then (./conftest; exit; ) >&5 2>/dev/null lt_status=$? case x$lt_status in x$lt_dlno_uscore) lt_cv_dlopen_self_static=yes ;; x$lt_dlneed_uscore) lt_cv_dlopen_self_static=yes ;; x$lt_dlunknown|x*) lt_cv_dlopen_self_static=no ;; esac else : # compilation failed lt_cv_dlopen_self_static=no fi fi rm -fr conftest* fi { $as_echo "$as_me:${as_lineno-$LINENO}: result: $lt_cv_dlopen_self_static" >&5 $as_echo "$lt_cv_dlopen_self_static" >&6; } fi CPPFLAGS=$save_CPPFLAGS LDFLAGS=$save_LDFLAGS LIBS=$save_LIBS ;; esac case $lt_cv_dlopen_self in yes|no) enable_dlopen_self=$lt_cv_dlopen_self ;; *) enable_dlopen_self=unknown ;; esac case $lt_cv_dlopen_self_static in yes|no) enable_dlopen_self_static=$lt_cv_dlopen_self_static ;; *) enable_dlopen_self_static=unknown ;; esac fi striplib= old_striplib= { $as_echo "$as_me:${as_lineno-$LINENO}: checking whether stripping libraries is possible" >&5 $as_echo_n "checking whether stripping libraries is possible... " >&6; } if test -n "$STRIP" && $STRIP -V 2>&1 | $GREP "GNU strip" >/dev/null; then test -z "$old_striplib" && old_striplib="$STRIP --strip-debug" test -z "$striplib" && striplib="$STRIP --strip-unneeded" { $as_echo "$as_me:${as_lineno-$LINENO}: result: yes" >&5 $as_echo "yes" >&6; } else # FIXME - insert some real tests, host_os isn't really good enough case $host_os in darwin*) if test -n "$STRIP"; then striplib="$STRIP -x" old_striplib="$STRIP -S" { $as_echo "$as_me:${as_lineno-$LINENO}: result: yes" >&5 $as_echo "yes" >&6; } else { $as_echo "$as_me:${as_lineno-$LINENO}: result: no" >&5 $as_echo "no" >&6; } fi ;; *) { $as_echo "$as_me:${as_lineno-$LINENO}: result: no" >&5 $as_echo "no" >&6; } ;; esac fi # Report what library types will actually be built { $as_echo "$as_me:${as_lineno-$LINENO}: checking if libtool supports shared libraries" >&5 $as_echo_n "checking if libtool supports shared libraries... " >&6; } { $as_echo "$as_me:${as_lineno-$LINENO}: result: $can_build_shared" >&5 $as_echo "$can_build_shared" >&6; } { $as_echo "$as_me:${as_lineno-$LINENO}: checking whether to build shared libraries" >&5 $as_echo_n "checking whether to build shared libraries... " >&6; } test no = "$can_build_shared" && enable_shared=no # On AIX, shared libraries and static libraries use the same namespace, and # are all built from PIC. case $host_os in aix3*) test yes = "$enable_shared" && enable_static=no if test -n "$RANLIB"; then archive_cmds="$archive_cmds~\$RANLIB \$lib" postinstall_cmds='$RANLIB $lib' fi ;; aix[4-9]*) if test ia64 != "$host_cpu"; then case $enable_shared,$with_aix_soname,$aix_use_runtimelinking in yes,aix,yes) ;; # shared object as lib.so file only yes,svr4,*) ;; # shared object as lib.so archive member only yes,*) enable_static=no ;; # shared object in lib.a archive as well esac fi ;; esac { $as_echo "$as_me:${as_lineno-$LINENO}: result: $enable_shared" >&5 $as_echo "$enable_shared" >&6; } { $as_echo "$as_me:${as_lineno-$LINENO}: checking whether to build static libraries" >&5 $as_echo_n "checking whether to build static libraries... " >&6; } # Make sure either enable_shared or enable_static is yes. test yes = "$enable_shared" || enable_static=yes { $as_echo "$as_me:${as_lineno-$LINENO}: result: $enable_static" >&5 $as_echo "$enable_static" >&6; } fi ac_ext=c ac_cpp='$CPP $CPPFLAGS' ac_compile='$CC -c $CFLAGS $CPPFLAGS conftest.$ac_ext >&5' ac_link='$CC -o conftest$ac_exeext $CFLAGS $CPPFLAGS $LDFLAGS conftest.$ac_ext $LIBS >&5' ac_compiler_gnu=$ac_cv_c_compiler_gnu CC=$lt_save_CC ac_config_commands="$ac_config_commands libtool" # Only expand once: # Check whether --with-pkgconfigdir was given. if test "${with_pkgconfigdir+set}" = set; then : withval=$with_pkgconfigdir; else with_pkgconfigdir='${libdir}/pkgconfig' fi pkgconfigdir=$with_pkgconfigdir # Use silent rules by default if supported by Automake # Check whether --enable-silent-rules was given. if test "${enable_silent_rules+set}" = set; then : enableval=$enable_silent_rules; fi case $enable_silent_rules in # ((( yes) AM_DEFAULT_VERBOSITY=0;; no) AM_DEFAULT_VERBOSITY=1;; *) AM_DEFAULT_VERBOSITY=0;; esac am_make=${MAKE-make} { $as_echo "$as_me:${as_lineno-$LINENO}: checking whether $am_make supports nested variables" >&5 $as_echo_n "checking whether $am_make supports nested variables... " >&6; } if ${am_cv_make_support_nested_variables+:} false; then : $as_echo_n "(cached) " >&6 else if $as_echo 'TRUE=$(BAR$(V)) BAR0=false BAR1=true V=1 am__doit: @$(TRUE) .PHONY: am__doit' | $am_make -f - >/dev/null 2>&1; then am_cv_make_support_nested_variables=yes else am_cv_make_support_nested_variables=no fi fi { $as_echo "$as_me:${as_lineno-$LINENO}: result: $am_cv_make_support_nested_variables" >&5 $as_echo "$am_cv_make_support_nested_variables" >&6; } if test $am_cv_make_support_nested_variables = yes; then AM_V='$(V)' AM_DEFAULT_V='$(AM_DEFAULT_VERBOSITY)' else AM_V=$AM_DEFAULT_VERBOSITY AM_DEFAULT_V=$AM_DEFAULT_VERBOSITY fi AM_BACKSLASH='\' ac_ext=c ac_cpp='$CPP $CPPFLAGS' ac_compile='$CC -c $CFLAGS $CPPFLAGS conftest.$ac_ext >&5' ac_link='$CC -o conftest$ac_exeext $CFLAGS $CPPFLAGS $LDFLAGS conftest.$ac_ext $LIBS >&5' ac_compiler_gnu=$ac_cv_c_compiler_gnu { $as_echo "$as_me:${as_lineno-$LINENO}: checking CFLAGS for maximum warnings" >&5 $as_echo_n "checking CFLAGS for maximum warnings... " >&6; } if ${ac_cv_cflags_warn_all+:} false; then : $as_echo_n "(cached) " >&6 else ac_cv_cflags_warn_all="no, unknown" ac_save_CFLAGS="$CFLAGS" for ac_arg in "-warn all % -warn all" "-pedantic % -Wall" "-xstrconst % -v" "-std1 % -verbose -w0 -warnprotos" "-qlanglvl=ansi % -qsrcmsg -qinfo=all:noppt:noppc:noobs:nocnd" "-ansi -ansiE % -fullwarn" "+ESlit % +w1" "-Xc % -pvctl,fullmsg" "-h conform % -h msglevel 2" # do CFLAGS="$ac_save_CFLAGS "`echo $ac_arg | sed -e 's,%%.*,,' -e 's,%,,'` cat confdefs.h - <<_ACEOF >conftest.$ac_ext /* end confdefs.h. */ int main () { ; return 0; } _ACEOF if ac_fn_c_try_compile "$LINENO"; then : ac_cv_cflags_warn_all=`echo $ac_arg | sed -e 's,.*% *,,'` ; break fi rm -f core conftest.err conftest.$ac_objext conftest.$ac_ext done CFLAGS="$ac_save_CFLAGS" fi { $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_cv_cflags_warn_all" >&5 $as_echo "$ac_cv_cflags_warn_all" >&6; } case ".$ac_cv_cflags_warn_all" in .ok|.ok,*) ;; .|.no|.no,*) ;; *) if ${CFLAGS+:} false; then : case " $CFLAGS " in #( *" $ac_cv_cflags_warn_all "*) : { { $as_echo "$as_me:${as_lineno-$LINENO}: : CFLAGS already contains \$ac_cv_cflags_warn_all"; } >&5 (: CFLAGS already contains $ac_cv_cflags_warn_all) 2>&5 ac_status=$? $as_echo "$as_me:${as_lineno-$LINENO}: \$? = $ac_status" >&5 test $ac_status = 0; } ;; #( *) : as_fn_append CFLAGS " $ac_cv_cflags_warn_all" { { $as_echo "$as_me:${as_lineno-$LINENO}: : CFLAGS=\"\$CFLAGS\""; } >&5 (: CFLAGS="$CFLAGS") 2>&5 ac_status=$? $as_echo "$as_me:${as_lineno-$LINENO}: \$? = $ac_status" >&5 test $ac_status = 0; } ;; esac else CFLAGS=$ac_cv_cflags_warn_all { { $as_echo "$as_me:${as_lineno-$LINENO}: : CFLAGS=\"\$CFLAGS\""; } >&5 (: CFLAGS="$CFLAGS") 2>&5 ac_status=$? $as_echo "$as_me:${as_lineno-$LINENO}: \$? = $ac_status" >&5 test $ac_status = 0; } fi ;; esac ac_ext=c ac_cpp='$CPP $CPPFLAGS' ac_compile='$CC -c $CFLAGS $CPPFLAGS conftest.$ac_ext >&5' ac_link='$CC -o conftest$ac_exeext $CFLAGS $CPPFLAGS $LDFLAGS conftest.$ac_ext $LIBS >&5' ac_compiler_gnu=$ac_cv_c_compiler_gnu for flag in -Wwrite-strings; do as_CACHEVAR=`$as_echo "ax_cv_check_cflags__$flag" | $as_tr_sh` { $as_echo "$as_me:${as_lineno-$LINENO}: checking whether C compiler accepts $flag" >&5 $as_echo_n "checking whether C compiler accepts $flag... " >&6; } if eval \${$as_CACHEVAR+:} false; then : $as_echo_n "(cached) " >&6 else ax_check_save_flags=$CFLAGS CFLAGS="$CFLAGS $flag" cat confdefs.h - <<_ACEOF >conftest.$ac_ext /* end confdefs.h. */ int main () { ; return 0; } _ACEOF if ac_fn_c_try_compile "$LINENO"; then : eval "$as_CACHEVAR=yes" else eval "$as_CACHEVAR=no" fi rm -f core conftest.err conftest.$ac_objext conftest.$ac_ext CFLAGS=$ax_check_save_flags fi eval ac_res=\$$as_CACHEVAR { $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_res" >&5 $as_echo "$ac_res" >&6; } if eval test \"x\$"$as_CACHEVAR"\" = x"yes"; then : if ${CFLAGS+:} false; then : case " $CFLAGS " in #( *" $flag "*) : { { $as_echo "$as_me:${as_lineno-$LINENO}: : CFLAGS already contains \$flag"; } >&5 (: CFLAGS already contains $flag) 2>&5 ac_status=$? $as_echo "$as_me:${as_lineno-$LINENO}: \$? = $ac_status" >&5 test $ac_status = 0; } ;; #( *) : as_fn_append CFLAGS " $flag" { { $as_echo "$as_me:${as_lineno-$LINENO}: : CFLAGS=\"\$CFLAGS\""; } >&5 (: CFLAGS="$CFLAGS") 2>&5 ac_status=$? $as_echo "$as_me:${as_lineno-$LINENO}: \$? = $ac_status" >&5 test $ac_status = 0; } ;; esac else CFLAGS=$flag { { $as_echo "$as_me:${as_lineno-$LINENO}: : CFLAGS=\"\$CFLAGS\""; } >&5 (: CFLAGS="$CFLAGS") 2>&5 ac_status=$? $as_echo "$as_me:${as_lineno-$LINENO}: \$? = $ac_status" >&5 test $ac_status = 0; } fi else : fi done # Check whether --enable-tests was given. if test "${enable_tests+set}" = set; then : enableval=$enable_tests; else enable_tests=no fi if test x$enable_tests = xyes; then PT_TESTS_TRUE= PT_TESTS_FALSE='#' else PT_TESTS_TRUE='#' PT_TESTS_FALSE= fi ac_config_files="$ac_config_files Makefile include/Makefile pkgconfig/libpainter.pc pkgconfig/libpainter-uninstalled.pc pkgconfig/Makefile src/Makefile tests/Makefile" cat >confcache <<\_ACEOF # This file is a shell script that caches the results of configure # tests run on this system so they can be shared between configure # scripts and configure runs, see configure's option --config-cache. # It is not useful on other systems. If it contains results you don't # want to keep, you may remove or edit it. # # config.status only pays attention to the cache file if you give it # the --recheck option to rerun configure. # # `ac_cv_env_foo' variables (set or unset) will be overridden when # loading this file, other *unset* `ac_cv_foo' will be assigned the # following values. _ACEOF # The following way of writing the cache mishandles newlines in values, # but we know of no workaround that is simple, portable, and efficient. # So, we kill variables containing newlines. # Ultrix sh set writes to stderr and can't be redirected directly, # and sets the high bit in the cache file unless we assign to the vars. ( for ac_var in `(set) 2>&1 | sed -n 's/^\([a-zA-Z_][a-zA-Z0-9_]*\)=.*/\1/p'`; do eval ac_val=\$$ac_var case $ac_val in #( *${as_nl}*) case $ac_var in #( *_cv_*) { $as_echo "$as_me:${as_lineno-$LINENO}: WARNING: cache variable $ac_var contains a newline" >&5 $as_echo "$as_me: WARNING: cache variable $ac_var contains a newline" >&2;} ;; esac case $ac_var in #( _ | IFS | as_nl) ;; #( BASH_ARGV | BASH_SOURCE) eval $ac_var= ;; #( *) { eval $ac_var=; unset $ac_var;} ;; esac ;; esac done (set) 2>&1 | case $as_nl`(ac_space=' '; set) 2>&1` in #( *${as_nl}ac_space=\ *) # `set' does not quote correctly, so add quotes: double-quote # substitution turns \\\\ into \\, and sed turns \\ into \. sed -n \ "s/'/'\\\\''/g; s/^\\([_$as_cr_alnum]*_cv_[_$as_cr_alnum]*\\)=\\(.*\\)/\\1='\\2'/p" ;; #( *) # `set' quotes correctly as required by POSIX, so do not add quotes. sed -n "/^[_$as_cr_alnum]*_cv_[_$as_cr_alnum]*=/p" ;; esac | sort ) | sed ' /^ac_cv_env_/b end t clear :clear s/^\([^=]*\)=\(.*[{}].*\)$/test "${\1+set}" = set || &/ t end s/^\([^=]*\)=\(.*\)$/\1=${\1=\2}/ :end' >>confcache if diff "$cache_file" confcache >/dev/null 2>&1; then :; else if test -w "$cache_file"; then if test "x$cache_file" != "x/dev/null"; then { $as_echo "$as_me:${as_lineno-$LINENO}: updating cache $cache_file" >&5 $as_echo "$as_me: updating cache $cache_file" >&6;} if test ! -f "$cache_file" || test -h "$cache_file"; then cat confcache >"$cache_file" else case $cache_file in #( */* | ?:*) mv -f confcache "$cache_file"$$ && mv -f "$cache_file"$$ "$cache_file" ;; #( *) mv -f confcache "$cache_file" ;; esac fi fi else { $as_echo "$as_me:${as_lineno-$LINENO}: not updating unwritable cache $cache_file" >&5 $as_echo "$as_me: not updating unwritable cache $cache_file" >&6;} fi fi rm -f confcache test "x$prefix" = xNONE && prefix=$ac_default_prefix # Let make expand exec_prefix. test "x$exec_prefix" = xNONE && exec_prefix='${prefix}' DEFS=-DHAVE_CONFIG_H ac_libobjs= ac_ltlibobjs= U= for ac_i in : $LIBOBJS; do test "x$ac_i" = x: && continue # 1. Remove the extension, and $U if already installed. ac_script='s/\$U\././;s/\.o$//;s/\.obj$//' ac_i=`$as_echo "$ac_i" | sed "$ac_script"` # 2. Prepend LIBOBJDIR. When used with automake>=1.10 LIBOBJDIR # will be set to the directory where LIBOBJS objects are built. as_fn_append ac_libobjs " \${LIBOBJDIR}$ac_i\$U.$ac_objext" as_fn_append ac_ltlibobjs " \${LIBOBJDIR}$ac_i"'$U.lo' done LIBOBJS=$ac_libobjs LTLIBOBJS=$ac_ltlibobjs { $as_echo "$as_me:${as_lineno-$LINENO}: checking that generated files are newer than configure" >&5 $as_echo_n "checking that generated files are newer than configure... " >&6; } if test -n "$am_sleep_pid"; then # Hide warnings about reused PIDs. wait $am_sleep_pid 2>/dev/null fi { $as_echo "$as_me:${as_lineno-$LINENO}: result: done" >&5 $as_echo "done" >&6; } if test -n "$EXEEXT"; then am__EXEEXT_TRUE= am__EXEEXT_FALSE='#' else am__EXEEXT_TRUE='#' am__EXEEXT_FALSE= fi if test -z "${AMDEP_TRUE}" && test -z "${AMDEP_FALSE}"; then as_fn_error $? "conditional \"AMDEP\" was never defined. Usually this means the macro was only invoked conditionally." "$LINENO" 5 fi if test -z "${am__fastdepCC_TRUE}" && test -z "${am__fastdepCC_FALSE}"; then as_fn_error $? "conditional \"am__fastdepCC\" was never defined. Usually this means the macro was only invoked conditionally." "$LINENO" 5 fi if test -z "${PT_TESTS_TRUE}" && test -z "${PT_TESTS_FALSE}"; then as_fn_error $? "conditional \"PT_TESTS\" was never defined. Usually this means the macro was only invoked conditionally." "$LINENO" 5 fi : "${CONFIG_STATUS=./config.status}" ac_write_fail=0 ac_clean_files_save=$ac_clean_files ac_clean_files="$ac_clean_files $CONFIG_STATUS" { $as_echo "$as_me:${as_lineno-$LINENO}: creating $CONFIG_STATUS" >&5 $as_echo "$as_me: creating $CONFIG_STATUS" >&6;} as_write_fail=0 cat >$CONFIG_STATUS <<_ASEOF || as_write_fail=1 #! $SHELL # Generated by $as_me. # Run this file to recreate the current configuration. # Compiler output produced by configure, useful for debugging # configure, is in config.log if it exists. debug=false ac_cs_recheck=false ac_cs_silent=false SHELL=\${CONFIG_SHELL-$SHELL} export SHELL _ASEOF cat >>$CONFIG_STATUS <<\_ASEOF || as_write_fail=1 ## -------------------- ## ## M4sh Initialization. ## ## -------------------- ## # Be more Bourne compatible DUALCASE=1; export DUALCASE # for MKS sh if test -n "${ZSH_VERSION+set}" && (emulate sh) >/dev/null 2>&1; then : emulate sh NULLCMD=: # Pre-4.2 versions of Zsh do word splitting on ${1+"$@"}, which # is contrary to our usage. Disable this feature. alias -g '${1+"$@"}'='"$@"' setopt NO_GLOB_SUBST else case `(set -o) 2>/dev/null` in #( *posix*) : set -o posix ;; #( *) : ;; esac fi as_nl=' ' export as_nl # Printing a long string crashes Solaris 7 /usr/bin/printf. as_echo='\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\' as_echo=$as_echo$as_echo$as_echo$as_echo$as_echo as_echo=$as_echo$as_echo$as_echo$as_echo$as_echo$as_echo # Prefer a ksh shell builtin over an external printf program on Solaris, # but without wasting forks for bash or zsh. if test -z "$BASH_VERSION$ZSH_VERSION" \ && (test "X`print -r -- $as_echo`" = "X$as_echo") 2>/dev/null; then as_echo='print -r --' as_echo_n='print -rn --' elif (test "X`printf %s $as_echo`" = "X$as_echo") 2>/dev/null; then as_echo='printf %s\n' as_echo_n='printf %s' else if test "X`(/usr/ucb/echo -n -n $as_echo) 2>/dev/null`" = "X-n $as_echo"; then as_echo_body='eval /usr/ucb/echo -n "$1$as_nl"' as_echo_n='/usr/ucb/echo -n' else as_echo_body='eval expr "X$1" : "X\\(.*\\)"' as_echo_n_body='eval arg=$1; case $arg in #( *"$as_nl"*) expr "X$arg" : "X\\(.*\\)$as_nl"; arg=`expr "X$arg" : ".*$as_nl\\(.*\\)"`;; esac; expr "X$arg" : "X\\(.*\\)" | tr -d "$as_nl" ' export as_echo_n_body as_echo_n='sh -c $as_echo_n_body as_echo' fi export as_echo_body as_echo='sh -c $as_echo_body as_echo' fi # The user is always right. if test "${PATH_SEPARATOR+set}" != set; then PATH_SEPARATOR=: (PATH='/bin;/bin'; FPATH=$PATH; sh -c :) >/dev/null 2>&1 && { (PATH='/bin:/bin'; FPATH=$PATH; sh -c :) >/dev/null 2>&1 || PATH_SEPARATOR=';' } fi # IFS # We need space, tab and new line, in precisely that order. Quoting is # there to prevent editors from complaining about space-tab. # (If _AS_PATH_WALK were called with IFS unset, it would disable word # splitting by setting IFS to empty value.) IFS=" "" $as_nl" # Find who we are. Look in the path if we contain no directory separator. as_myself= case $0 in #(( *[\\/]* ) as_myself=$0 ;; *) as_save_IFS=$IFS; IFS=$PATH_SEPARATOR for as_dir in $PATH do IFS=$as_save_IFS test -z "$as_dir" && as_dir=. test -r "$as_dir/$0" && as_myself=$as_dir/$0 && break done IFS=$as_save_IFS ;; esac # We did not find ourselves, most probably we were run as `sh COMMAND' # in which case we are not to be found in the path. if test "x$as_myself" = x; then as_myself=$0 fi if test ! -f "$as_myself"; then $as_echo "$as_myself: error: cannot find myself; rerun with an absolute file name" >&2 exit 1 fi # Unset variables that we do not need and which cause bugs (e.g. in # pre-3.0 UWIN ksh). But do not cause bugs in bash 2.01; the "|| exit 1" # suppresses any "Segmentation fault" message there. '((' could # trigger a bug in pdksh 5.2.14. for as_var in BASH_ENV ENV MAIL MAILPATH do eval test x\${$as_var+set} = xset \ && ( (unset $as_var) || exit 1) >/dev/null 2>&1 && unset $as_var || : done PS1='$ ' PS2='> ' PS4='+ ' # NLS nuisances. LC_ALL=C export LC_ALL LANGUAGE=C export LANGUAGE # CDPATH. (unset CDPATH) >/dev/null 2>&1 && unset CDPATH # as_fn_error STATUS ERROR [LINENO LOG_FD] # ---------------------------------------- # Output "`basename $0`: error: ERROR" to stderr. If LINENO and LOG_FD are # provided, also output the error to LOG_FD, referencing LINENO. Then exit the # script with STATUS, using 1 if that was 0. as_fn_error () { as_status=$1; test $as_status -eq 0 && as_status=1 if test "$4"; then as_lineno=${as_lineno-"$3"} as_lineno_stack=as_lineno_stack=$as_lineno_stack $as_echo "$as_me:${as_lineno-$LINENO}: error: $2" >&$4 fi $as_echo "$as_me: error: $2" >&2 as_fn_exit $as_status } # as_fn_error # as_fn_set_status STATUS # ----------------------- # Set $? to STATUS, without forking. as_fn_set_status () { return $1 } # as_fn_set_status # as_fn_exit STATUS # ----------------- # Exit the shell with STATUS, even in a "trap 0" or "set -e" context. as_fn_exit () { set +e as_fn_set_status $1 exit $1 } # as_fn_exit # as_fn_unset VAR # --------------- # Portably unset VAR. as_fn_unset () { { eval $1=; unset $1;} } as_unset=as_fn_unset # as_fn_append VAR VALUE # ---------------------- # Append the text in VALUE to the end of the definition contained in VAR. Take # advantage of any shell optimizations that allow amortized linear growth over # repeated appends, instead of the typical quadratic growth present in naive # implementations. if (eval "as_var=1; as_var+=2; test x\$as_var = x12") 2>/dev/null; then : eval 'as_fn_append () { eval $1+=\$2 }' else as_fn_append () { eval $1=\$$1\$2 } fi # as_fn_append # as_fn_arith ARG... # ------------------ # Perform arithmetic evaluation on the ARGs, and store the result in the # global $as_val. Take advantage of shells that can avoid forks. The arguments # must be portable across $(()) and expr. if (eval "test \$(( 1 + 1 )) = 2") 2>/dev/null; then : eval 'as_fn_arith () { as_val=$(( $* )) }' else as_fn_arith () { as_val=`expr "$@" || test $? -eq 1` } fi # as_fn_arith if expr a : '\(a\)' >/dev/null 2>&1 && test "X`expr 00001 : '.*\(...\)'`" = X001; then as_expr=expr else as_expr=false fi if (basename -- /) >/dev/null 2>&1 && test "X`basename -- / 2>&1`" = "X/"; then as_basename=basename else as_basename=false fi if (as_dir=`dirname -- /` && test "X$as_dir" = X/) >/dev/null 2>&1; then as_dirname=dirname else as_dirname=false fi as_me=`$as_basename -- "$0" || $as_expr X/"$0" : '.*/\([^/][^/]*\)/*$' \| \ X"$0" : 'X\(//\)$' \| \ X"$0" : 'X\(/\)' \| . 2>/dev/null || $as_echo X/"$0" | sed '/^.*\/\([^/][^/]*\)\/*$/{ s//\1/ q } /^X\/\(\/\/\)$/{ s//\1/ q } /^X\/\(\/\).*/{ s//\1/ q } s/.*/./; q'` # Avoid depending upon Character Ranges. as_cr_letters='abcdefghijklmnopqrstuvwxyz' as_cr_LETTERS='ABCDEFGHIJKLMNOPQRSTUVWXYZ' as_cr_Letters=$as_cr_letters$as_cr_LETTERS as_cr_digits='0123456789' as_cr_alnum=$as_cr_Letters$as_cr_digits ECHO_C= ECHO_N= ECHO_T= case `echo -n x` in #((((( -n*) case `echo 'xy\c'` in *c*) ECHO_T=' ';; # ECHO_T is single tab character. xy) ECHO_C='\c';; *) echo `echo ksh88 bug on AIX 6.1` > /dev/null ECHO_T=' ';; esac;; *) ECHO_N='-n';; esac rm -f conf$$ conf$$.exe conf$$.file if test -d conf$$.dir; then rm -f conf$$.dir/conf$$.file else rm -f conf$$.dir mkdir conf$$.dir 2>/dev/null fi if (echo >conf$$.file) 2>/dev/null; then if ln -s conf$$.file conf$$ 2>/dev/null; then as_ln_s='ln -s' # ... but there are two gotchas: # 1) On MSYS, both `ln -s file dir' and `ln file dir' fail. # 2) DJGPP < 2.04 has no symlinks; `ln -s' creates a wrapper executable. # In both cases, we have to default to `cp -pR'. ln -s conf$$.file conf$$.dir 2>/dev/null && test ! -f conf$$.exe || as_ln_s='cp -pR' elif ln conf$$.file conf$$ 2>/dev/null; then as_ln_s=ln else as_ln_s='cp -pR' fi else as_ln_s='cp -pR' fi rm -f conf$$ conf$$.exe conf$$.dir/conf$$.file conf$$.file rmdir conf$$.dir 2>/dev/null # as_fn_mkdir_p # ------------- # Create "$as_dir" as a directory, including parents if necessary. as_fn_mkdir_p () { case $as_dir in #( -*) as_dir=./$as_dir;; esac test -d "$as_dir" || eval $as_mkdir_p || { as_dirs= while :; do case $as_dir in #( *\'*) as_qdir=`$as_echo "$as_dir" | sed "s/'/'\\\\\\\\''/g"`;; #'( *) as_qdir=$as_dir;; esac as_dirs="'$as_qdir' $as_dirs" as_dir=`$as_dirname -- "$as_dir" || $as_expr X"$as_dir" : 'X\(.*[^/]\)//*[^/][^/]*/*$' \| \ X"$as_dir" : 'X\(//\)[^/]' \| \ X"$as_dir" : 'X\(//\)$' \| \ X"$as_dir" : 'X\(/\)' \| . 2>/dev/null || $as_echo X"$as_dir" | sed '/^X\(.*[^/]\)\/\/*[^/][^/]*\/*$/{ s//\1/ q } /^X\(\/\/\)[^/].*/{ s//\1/ q } /^X\(\/\/\)$/{ s//\1/ q } /^X\(\/\).*/{ s//\1/ q } s/.*/./; q'` test -d "$as_dir" && break done test -z "$as_dirs" || eval "mkdir $as_dirs" } || test -d "$as_dir" || as_fn_error $? "cannot create directory $as_dir" } # as_fn_mkdir_p if mkdir -p . 2>/dev/null; then as_mkdir_p='mkdir -p "$as_dir"' else test -d ./-p && rmdir ./-p as_mkdir_p=false fi # as_fn_executable_p FILE # ----------------------- # Test if FILE is an executable regular file. as_fn_executable_p () { test -f "$1" && test -x "$1" } # as_fn_executable_p as_test_x='test -x' as_executable_p=as_fn_executable_p # Sed expression to map a string onto a valid CPP name. as_tr_cpp="eval sed 'y%*$as_cr_letters%P$as_cr_LETTERS%;s%[^_$as_cr_alnum]%_%g'" # Sed expression to map a string onto a valid variable name. as_tr_sh="eval sed 'y%*+%pp%;s%[^_$as_cr_alnum]%_%g'" exec 6>&1 ## ----------------------------------- ## ## Main body of $CONFIG_STATUS script. ## ## ----------------------------------- ## _ASEOF test $as_write_fail = 0 && chmod +x $CONFIG_STATUS || ac_write_fail=1 cat >>$CONFIG_STATUS <<\_ACEOF || ac_write_fail=1 # Save the log message, to keep $0 and so on meaningful, and to # report actual input values of CONFIG_FILES etc. instead of their # values after options handling. ac_log=" This file was extended by libpainter $as_me 0.1.1, which was generated by GNU Autoconf 2.69. Invocation command line was CONFIG_FILES = $CONFIG_FILES CONFIG_HEADERS = $CONFIG_HEADERS CONFIG_LINKS = $CONFIG_LINKS CONFIG_COMMANDS = $CONFIG_COMMANDS $ $0 $@ on `(hostname || uname -n) 2>/dev/null | sed 1q` " _ACEOF case $ac_config_files in *" "*) set x $ac_config_files; shift; ac_config_files=$*;; esac case $ac_config_headers in *" "*) set x $ac_config_headers; shift; ac_config_headers=$*;; esac cat >>$CONFIG_STATUS <<_ACEOF || ac_write_fail=1 # Files that config.status was made for. config_files="$ac_config_files" config_headers="$ac_config_headers" config_commands="$ac_config_commands" _ACEOF cat >>$CONFIG_STATUS <<\_ACEOF || ac_write_fail=1 ac_cs_usage="\ \`$as_me' instantiates files and other configuration actions from templates according to the current configuration. Unless the files and actions are specified as TAGs, all are instantiated by default. Usage: $0 [OPTION]... [TAG]... -h, --help print this help, then exit -V, --version print version number and configuration settings, then exit --config print configuration, then exit -q, --quiet, --silent do not print progress messages -d, --debug don't remove temporary files --recheck update $as_me by reconfiguring in the same conditions --file=FILE[:TEMPLATE] instantiate the configuration file FILE --header=FILE[:TEMPLATE] instantiate the configuration header FILE Configuration files: $config_files Configuration headers: $config_headers Configuration commands: $config_commands Report bugs to ." _ACEOF cat >>$CONFIG_STATUS <<_ACEOF || ac_write_fail=1 ac_cs_config="`$as_echo "$ac_configure_args" | sed 's/^ //; s/[\\""\`\$]/\\\\&/g'`" ac_cs_version="\\ libpainter config.status 0.1.1 configured by $0, generated by GNU Autoconf 2.69, with options \\"\$ac_cs_config\\" Copyright (C) 2012 Free Software Foundation, Inc. This config.status script is free software; the Free Software Foundation gives unlimited permission to copy, distribute and modify it." ac_pwd='$ac_pwd' srcdir='$srcdir' INSTALL='$INSTALL' MKDIR_P='$MKDIR_P' AWK='$AWK' test -n "\$AWK" || AWK=awk _ACEOF cat >>$CONFIG_STATUS <<\_ACEOF || ac_write_fail=1 # The default lists apply if the user does not specify any file. ac_need_defaults=: while test $# != 0 do case $1 in --*=?*) ac_option=`expr "X$1" : 'X\([^=]*\)='` ac_optarg=`expr "X$1" : 'X[^=]*=\(.*\)'` ac_shift=: ;; --*=) ac_option=`expr "X$1" : 'X\([^=]*\)='` ac_optarg= ac_shift=: ;; *) ac_option=$1 ac_optarg=$2 ac_shift=shift ;; esac case $ac_option in # Handling of the options. -recheck | --recheck | --rechec | --reche | --rech | --rec | --re | --r) ac_cs_recheck=: ;; --version | --versio | --versi | --vers | --ver | --ve | --v | -V ) $as_echo "$ac_cs_version"; exit ;; --config | --confi | --conf | --con | --co | --c ) $as_echo "$ac_cs_config"; exit ;; --debug | --debu | --deb | --de | --d | -d ) debug=: ;; --file | --fil | --fi | --f ) $ac_shift case $ac_optarg in *\'*) ac_optarg=`$as_echo "$ac_optarg" | sed "s/'/'\\\\\\\\''/g"` ;; '') as_fn_error $? "missing file argument" ;; esac as_fn_append CONFIG_FILES " '$ac_optarg'" ac_need_defaults=false;; --header | --heade | --head | --hea ) $ac_shift case $ac_optarg in *\'*) ac_optarg=`$as_echo "$ac_optarg" | sed "s/'/'\\\\\\\\''/g"` ;; esac as_fn_append CONFIG_HEADERS " '$ac_optarg'" ac_need_defaults=false;; --he | --h) # Conflict between --help and --header as_fn_error $? "ambiguous option: \`$1' Try \`$0 --help' for more information.";; --help | --hel | -h ) $as_echo "$ac_cs_usage"; exit ;; -q | -quiet | --quiet | --quie | --qui | --qu | --q \ | -silent | --silent | --silen | --sile | --sil | --si | --s) ac_cs_silent=: ;; # This is an error. -*) as_fn_error $? "unrecognized option: \`$1' Try \`$0 --help' for more information." ;; *) as_fn_append ac_config_targets " $1" ac_need_defaults=false ;; esac shift done ac_configure_extra_args= if $ac_cs_silent; then exec 6>/dev/null ac_configure_extra_args="$ac_configure_extra_args --silent" fi _ACEOF cat >>$CONFIG_STATUS <<_ACEOF || ac_write_fail=1 if \$ac_cs_recheck; then set X $SHELL '$0' $ac_configure_args \$ac_configure_extra_args --no-create --no-recursion shift \$as_echo "running CONFIG_SHELL=$SHELL \$*" >&6 CONFIG_SHELL='$SHELL' export CONFIG_SHELL exec "\$@" fi _ACEOF cat >>$CONFIG_STATUS <<\_ACEOF || ac_write_fail=1 exec 5>>config.log { echo sed 'h;s/./-/g;s/^.../## /;s/...$/ ##/;p;x;p;x' <<_ASBOX ## Running $as_me. ## _ASBOX $as_echo "$ac_log" } >&5 _ACEOF cat >>$CONFIG_STATUS <<_ACEOF || ac_write_fail=1 # # INIT-COMMANDS # AMDEP_TRUE="$AMDEP_TRUE" ac_aux_dir="$ac_aux_dir" # The HP-UX ksh and POSIX shell print the target directory to stdout # if CDPATH is set. (unset CDPATH) >/dev/null 2>&1 && unset CDPATH sed_quote_subst='$sed_quote_subst' double_quote_subst='$double_quote_subst' delay_variable_subst='$delay_variable_subst' macro_version='`$ECHO "$macro_version" | $SED "$delay_single_quote_subst"`' macro_revision='`$ECHO "$macro_revision" | $SED "$delay_single_quote_subst"`' enable_shared='`$ECHO "$enable_shared" | $SED "$delay_single_quote_subst"`' enable_static='`$ECHO "$enable_static" | $SED "$delay_single_quote_subst"`' pic_mode='`$ECHO "$pic_mode" | $SED "$delay_single_quote_subst"`' enable_fast_install='`$ECHO "$enable_fast_install" | $SED "$delay_single_quote_subst"`' shared_archive_member_spec='`$ECHO "$shared_archive_member_spec" | $SED "$delay_single_quote_subst"`' SHELL='`$ECHO "$SHELL" | $SED "$delay_single_quote_subst"`' ECHO='`$ECHO "$ECHO" | $SED "$delay_single_quote_subst"`' PATH_SEPARATOR='`$ECHO "$PATH_SEPARATOR" | $SED "$delay_single_quote_subst"`' host_alias='`$ECHO "$host_alias" | $SED "$delay_single_quote_subst"`' host='`$ECHO "$host" | $SED "$delay_single_quote_subst"`' host_os='`$ECHO "$host_os" | $SED "$delay_single_quote_subst"`' build_alias='`$ECHO "$build_alias" | $SED "$delay_single_quote_subst"`' build='`$ECHO "$build" | $SED "$delay_single_quote_subst"`' build_os='`$ECHO "$build_os" | $SED "$delay_single_quote_subst"`' SED='`$ECHO "$SED" | $SED "$delay_single_quote_subst"`' Xsed='`$ECHO "$Xsed" | $SED "$delay_single_quote_subst"`' GREP='`$ECHO "$GREP" | $SED "$delay_single_quote_subst"`' EGREP='`$ECHO "$EGREP" | $SED "$delay_single_quote_subst"`' FGREP='`$ECHO "$FGREP" | $SED "$delay_single_quote_subst"`' LD='`$ECHO "$LD" | $SED "$delay_single_quote_subst"`' NM='`$ECHO "$NM" | $SED "$delay_single_quote_subst"`' LN_S='`$ECHO "$LN_S" | $SED "$delay_single_quote_subst"`' max_cmd_len='`$ECHO "$max_cmd_len" | $SED "$delay_single_quote_subst"`' ac_objext='`$ECHO "$ac_objext" | $SED "$delay_single_quote_subst"`' exeext='`$ECHO "$exeext" | $SED "$delay_single_quote_subst"`' lt_unset='`$ECHO "$lt_unset" | $SED "$delay_single_quote_subst"`' lt_SP2NL='`$ECHO "$lt_SP2NL" | $SED "$delay_single_quote_subst"`' lt_NL2SP='`$ECHO "$lt_NL2SP" | $SED "$delay_single_quote_subst"`' lt_cv_to_host_file_cmd='`$ECHO "$lt_cv_to_host_file_cmd" | $SED "$delay_single_quote_subst"`' lt_cv_to_tool_file_cmd='`$ECHO "$lt_cv_to_tool_file_cmd" | $SED "$delay_single_quote_subst"`' reload_flag='`$ECHO "$reload_flag" | $SED "$delay_single_quote_subst"`' reload_cmds='`$ECHO "$reload_cmds" | $SED "$delay_single_quote_subst"`' OBJDUMP='`$ECHO "$OBJDUMP" | $SED "$delay_single_quote_subst"`' deplibs_check_method='`$ECHO "$deplibs_check_method" | $SED "$delay_single_quote_subst"`' file_magic_cmd='`$ECHO "$file_magic_cmd" | $SED "$delay_single_quote_subst"`' file_magic_glob='`$ECHO "$file_magic_glob" | $SED "$delay_single_quote_subst"`' want_nocaseglob='`$ECHO "$want_nocaseglob" | $SED "$delay_single_quote_subst"`' DLLTOOL='`$ECHO "$DLLTOOL" | $SED "$delay_single_quote_subst"`' sharedlib_from_linklib_cmd='`$ECHO "$sharedlib_from_linklib_cmd" | $SED "$delay_single_quote_subst"`' AR='`$ECHO "$AR" | $SED "$delay_single_quote_subst"`' AR_FLAGS='`$ECHO "$AR_FLAGS" | $SED "$delay_single_quote_subst"`' archiver_list_spec='`$ECHO "$archiver_list_spec" | $SED "$delay_single_quote_subst"`' STRIP='`$ECHO "$STRIP" | $SED "$delay_single_quote_subst"`' RANLIB='`$ECHO "$RANLIB" | $SED "$delay_single_quote_subst"`' old_postinstall_cmds='`$ECHO "$old_postinstall_cmds" | $SED "$delay_single_quote_subst"`' old_postuninstall_cmds='`$ECHO "$old_postuninstall_cmds" | $SED "$delay_single_quote_subst"`' old_archive_cmds='`$ECHO "$old_archive_cmds" | $SED "$delay_single_quote_subst"`' lock_old_archive_extraction='`$ECHO "$lock_old_archive_extraction" | $SED "$delay_single_quote_subst"`' CC='`$ECHO "$CC" | $SED "$delay_single_quote_subst"`' CFLAGS='`$ECHO "$CFLAGS" | $SED "$delay_single_quote_subst"`' compiler='`$ECHO "$compiler" | $SED "$delay_single_quote_subst"`' GCC='`$ECHO "$GCC" | $SED "$delay_single_quote_subst"`' lt_cv_sys_global_symbol_pipe='`$ECHO "$lt_cv_sys_global_symbol_pipe" | $SED "$delay_single_quote_subst"`' lt_cv_sys_global_symbol_to_cdecl='`$ECHO "$lt_cv_sys_global_symbol_to_cdecl" | $SED "$delay_single_quote_subst"`' lt_cv_sys_global_symbol_to_import='`$ECHO "$lt_cv_sys_global_symbol_to_import" | $SED "$delay_single_quote_subst"`' lt_cv_sys_global_symbol_to_c_name_address='`$ECHO "$lt_cv_sys_global_symbol_to_c_name_address" | $SED "$delay_single_quote_subst"`' lt_cv_sys_global_symbol_to_c_name_address_lib_prefix='`$ECHO "$lt_cv_sys_global_symbol_to_c_name_address_lib_prefix" | $SED "$delay_single_quote_subst"`' lt_cv_nm_interface='`$ECHO "$lt_cv_nm_interface" | $SED "$delay_single_quote_subst"`' nm_file_list_spec='`$ECHO "$nm_file_list_spec" | $SED "$delay_single_quote_subst"`' lt_sysroot='`$ECHO "$lt_sysroot" | $SED "$delay_single_quote_subst"`' lt_cv_truncate_bin='`$ECHO "$lt_cv_truncate_bin" | $SED "$delay_single_quote_subst"`' objdir='`$ECHO "$objdir" | $SED "$delay_single_quote_subst"`' MAGIC_CMD='`$ECHO "$MAGIC_CMD" | $SED "$delay_single_quote_subst"`' lt_prog_compiler_no_builtin_flag='`$ECHO "$lt_prog_compiler_no_builtin_flag" | $SED "$delay_single_quote_subst"`' lt_prog_compiler_pic='`$ECHO "$lt_prog_compiler_pic" | $SED "$delay_single_quote_subst"`' lt_prog_compiler_wl='`$ECHO "$lt_prog_compiler_wl" | $SED "$delay_single_quote_subst"`' lt_prog_compiler_static='`$ECHO "$lt_prog_compiler_static" | $SED "$delay_single_quote_subst"`' lt_cv_prog_compiler_c_o='`$ECHO "$lt_cv_prog_compiler_c_o" | $SED "$delay_single_quote_subst"`' need_locks='`$ECHO "$need_locks" | $SED "$delay_single_quote_subst"`' MANIFEST_TOOL='`$ECHO "$MANIFEST_TOOL" | $SED "$delay_single_quote_subst"`' DSYMUTIL='`$ECHO "$DSYMUTIL" | $SED "$delay_single_quote_subst"`' NMEDIT='`$ECHO "$NMEDIT" | $SED "$delay_single_quote_subst"`' LIPO='`$ECHO "$LIPO" | $SED "$delay_single_quote_subst"`' OTOOL='`$ECHO "$OTOOL" | $SED "$delay_single_quote_subst"`' OTOOL64='`$ECHO "$OTOOL64" | $SED "$delay_single_quote_subst"`' libext='`$ECHO "$libext" | $SED "$delay_single_quote_subst"`' shrext_cmds='`$ECHO "$shrext_cmds" | $SED "$delay_single_quote_subst"`' extract_expsyms_cmds='`$ECHO "$extract_expsyms_cmds" | $SED "$delay_single_quote_subst"`' archive_cmds_need_lc='`$ECHO "$archive_cmds_need_lc" | $SED "$delay_single_quote_subst"`' enable_shared_with_static_runtimes='`$ECHO "$enable_shared_with_static_runtimes" | $SED "$delay_single_quote_subst"`' export_dynamic_flag_spec='`$ECHO "$export_dynamic_flag_spec" | $SED "$delay_single_quote_subst"`' whole_archive_flag_spec='`$ECHO "$whole_archive_flag_spec" | $SED "$delay_single_quote_subst"`' compiler_needs_object='`$ECHO "$compiler_needs_object" | $SED "$delay_single_quote_subst"`' old_archive_from_new_cmds='`$ECHO "$old_archive_from_new_cmds" | $SED "$delay_single_quote_subst"`' old_archive_from_expsyms_cmds='`$ECHO "$old_archive_from_expsyms_cmds" | $SED "$delay_single_quote_subst"`' archive_cmds='`$ECHO "$archive_cmds" | $SED "$delay_single_quote_subst"`' archive_expsym_cmds='`$ECHO "$archive_expsym_cmds" | $SED "$delay_single_quote_subst"`' module_cmds='`$ECHO "$module_cmds" | $SED "$delay_single_quote_subst"`' module_expsym_cmds='`$ECHO "$module_expsym_cmds" | $SED "$delay_single_quote_subst"`' with_gnu_ld='`$ECHO "$with_gnu_ld" | $SED "$delay_single_quote_subst"`' allow_undefined_flag='`$ECHO "$allow_undefined_flag" | $SED "$delay_single_quote_subst"`' no_undefined_flag='`$ECHO "$no_undefined_flag" | $SED "$delay_single_quote_subst"`' hardcode_libdir_flag_spec='`$ECHO "$hardcode_libdir_flag_spec" | $SED "$delay_single_quote_subst"`' hardcode_libdir_separator='`$ECHO "$hardcode_libdir_separator" | $SED "$delay_single_quote_subst"`' hardcode_direct='`$ECHO "$hardcode_direct" | $SED "$delay_single_quote_subst"`' hardcode_direct_absolute='`$ECHO "$hardcode_direct_absolute" | $SED "$delay_single_quote_subst"`' hardcode_minus_L='`$ECHO "$hardcode_minus_L" | $SED "$delay_single_quote_subst"`' hardcode_shlibpath_var='`$ECHO "$hardcode_shlibpath_var" | $SED "$delay_single_quote_subst"`' hardcode_automatic='`$ECHO "$hardcode_automatic" | $SED "$delay_single_quote_subst"`' inherit_rpath='`$ECHO "$inherit_rpath" | $SED "$delay_single_quote_subst"`' link_all_deplibs='`$ECHO "$link_all_deplibs" | $SED "$delay_single_quote_subst"`' always_export_symbols='`$ECHO "$always_export_symbols" | $SED "$delay_single_quote_subst"`' export_symbols_cmds='`$ECHO "$export_symbols_cmds" | $SED "$delay_single_quote_subst"`' exclude_expsyms='`$ECHO "$exclude_expsyms" | $SED "$delay_single_quote_subst"`' include_expsyms='`$ECHO "$include_expsyms" | $SED "$delay_single_quote_subst"`' prelink_cmds='`$ECHO "$prelink_cmds" | $SED "$delay_single_quote_subst"`' postlink_cmds='`$ECHO "$postlink_cmds" | $SED "$delay_single_quote_subst"`' file_list_spec='`$ECHO "$file_list_spec" | $SED "$delay_single_quote_subst"`' variables_saved_for_relink='`$ECHO "$variables_saved_for_relink" | $SED "$delay_single_quote_subst"`' need_lib_prefix='`$ECHO "$need_lib_prefix" | $SED "$delay_single_quote_subst"`' need_version='`$ECHO "$need_version" | $SED "$delay_single_quote_subst"`' version_type='`$ECHO "$version_type" | $SED "$delay_single_quote_subst"`' runpath_var='`$ECHO "$runpath_var" | $SED "$delay_single_quote_subst"`' shlibpath_var='`$ECHO "$shlibpath_var" | $SED "$delay_single_quote_subst"`' shlibpath_overrides_runpath='`$ECHO "$shlibpath_overrides_runpath" | $SED "$delay_single_quote_subst"`' libname_spec='`$ECHO "$libname_spec" | $SED "$delay_single_quote_subst"`' library_names_spec='`$ECHO "$library_names_spec" | $SED "$delay_single_quote_subst"`' soname_spec='`$ECHO "$soname_spec" | $SED "$delay_single_quote_subst"`' install_override_mode='`$ECHO "$install_override_mode" | $SED "$delay_single_quote_subst"`' postinstall_cmds='`$ECHO "$postinstall_cmds" | $SED "$delay_single_quote_subst"`' postuninstall_cmds='`$ECHO "$postuninstall_cmds" | $SED "$delay_single_quote_subst"`' finish_cmds='`$ECHO "$finish_cmds" | $SED "$delay_single_quote_subst"`' finish_eval='`$ECHO "$finish_eval" | $SED "$delay_single_quote_subst"`' hardcode_into_libs='`$ECHO "$hardcode_into_libs" | $SED "$delay_single_quote_subst"`' sys_lib_search_path_spec='`$ECHO "$sys_lib_search_path_spec" | $SED "$delay_single_quote_subst"`' configure_time_dlsearch_path='`$ECHO "$configure_time_dlsearch_path" | $SED "$delay_single_quote_subst"`' configure_time_lt_sys_library_path='`$ECHO "$configure_time_lt_sys_library_path" | $SED "$delay_single_quote_subst"`' hardcode_action='`$ECHO "$hardcode_action" | $SED "$delay_single_quote_subst"`' enable_dlopen='`$ECHO "$enable_dlopen" | $SED "$delay_single_quote_subst"`' enable_dlopen_self='`$ECHO "$enable_dlopen_self" | $SED "$delay_single_quote_subst"`' enable_dlopen_self_static='`$ECHO "$enable_dlopen_self_static" | $SED "$delay_single_quote_subst"`' old_striplib='`$ECHO "$old_striplib" | $SED "$delay_single_quote_subst"`' striplib='`$ECHO "$striplib" | $SED "$delay_single_quote_subst"`' LTCC='$LTCC' LTCFLAGS='$LTCFLAGS' compiler='$compiler_DEFAULT' # A function that is used when there is no print builtin or printf. func_fallback_echo () { eval 'cat <<_LTECHO_EOF \$1 _LTECHO_EOF' } # Quote evaled strings. for var in SHELL \ ECHO \ PATH_SEPARATOR \ SED \ GREP \ EGREP \ FGREP \ LD \ NM \ LN_S \ lt_SP2NL \ lt_NL2SP \ reload_flag \ OBJDUMP \ deplibs_check_method \ file_magic_cmd \ file_magic_glob \ want_nocaseglob \ DLLTOOL \ sharedlib_from_linklib_cmd \ AR \ AR_FLAGS \ archiver_list_spec \ STRIP \ RANLIB \ CC \ CFLAGS \ compiler \ lt_cv_sys_global_symbol_pipe \ lt_cv_sys_global_symbol_to_cdecl \ lt_cv_sys_global_symbol_to_import \ lt_cv_sys_global_symbol_to_c_name_address \ lt_cv_sys_global_symbol_to_c_name_address_lib_prefix \ lt_cv_nm_interface \ nm_file_list_spec \ lt_cv_truncate_bin \ lt_prog_compiler_no_builtin_flag \ lt_prog_compiler_pic \ lt_prog_compiler_wl \ lt_prog_compiler_static \ lt_cv_prog_compiler_c_o \ need_locks \ MANIFEST_TOOL \ DSYMUTIL \ NMEDIT \ LIPO \ OTOOL \ OTOOL64 \ shrext_cmds \ export_dynamic_flag_spec \ whole_archive_flag_spec \ compiler_needs_object \ with_gnu_ld \ allow_undefined_flag \ no_undefined_flag \ hardcode_libdir_flag_spec \ hardcode_libdir_separator \ exclude_expsyms \ include_expsyms \ file_list_spec \ variables_saved_for_relink \ libname_spec \ library_names_spec \ soname_spec \ install_override_mode \ finish_eval \ old_striplib \ striplib; do case \`eval \\\\\$ECHO \\\\""\\\\\$\$var"\\\\"\` in *[\\\\\\\`\\"\\\$]*) eval "lt_\$var=\\\\\\"\\\`\\\$ECHO \\"\\\$\$var\\" | \\\$SED \\"\\\$sed_quote_subst\\"\\\`\\\\\\"" ## exclude from sc_prohibit_nested_quotes ;; *) eval "lt_\$var=\\\\\\"\\\$\$var\\\\\\"" ;; esac done # Double-quote double-evaled strings. for var in reload_cmds \ old_postinstall_cmds \ old_postuninstall_cmds \ old_archive_cmds \ extract_expsyms_cmds \ old_archive_from_new_cmds \ old_archive_from_expsyms_cmds \ archive_cmds \ archive_expsym_cmds \ module_cmds \ module_expsym_cmds \ export_symbols_cmds \ prelink_cmds \ postlink_cmds \ postinstall_cmds \ postuninstall_cmds \ finish_cmds \ sys_lib_search_path_spec \ configure_time_dlsearch_path \ configure_time_lt_sys_library_path; do case \`eval \\\\\$ECHO \\\\""\\\\\$\$var"\\\\"\` in *[\\\\\\\`\\"\\\$]*) eval "lt_\$var=\\\\\\"\\\`\\\$ECHO \\"\\\$\$var\\" | \\\$SED -e \\"\\\$double_quote_subst\\" -e \\"\\\$sed_quote_subst\\" -e \\"\\\$delay_variable_subst\\"\\\`\\\\\\"" ## exclude from sc_prohibit_nested_quotes ;; *) eval "lt_\$var=\\\\\\"\\\$\$var\\\\\\"" ;; esac done ac_aux_dir='$ac_aux_dir' # See if we are running on zsh, and set the options that allow our # commands through without removal of \ escapes INIT. if test -n "\${ZSH_VERSION+set}"; then setopt NO_GLOB_SUBST fi PACKAGE='$PACKAGE' VERSION='$VERSION' RM='$RM' ofile='$ofile' _ACEOF cat >>$CONFIG_STATUS <<\_ACEOF || ac_write_fail=1 # Handling of arguments. for ac_config_target in $ac_config_targets do case $ac_config_target in "config_ac.h") CONFIG_HEADERS="$CONFIG_HEADERS config_ac.h:config_ac-h.in" ;; "depfiles") CONFIG_COMMANDS="$CONFIG_COMMANDS depfiles" ;; "libtool") CONFIG_COMMANDS="$CONFIG_COMMANDS libtool" ;; "Makefile") CONFIG_FILES="$CONFIG_FILES Makefile" ;; "include/Makefile") CONFIG_FILES="$CONFIG_FILES include/Makefile" ;; "pkgconfig/libpainter.pc") CONFIG_FILES="$CONFIG_FILES pkgconfig/libpainter.pc" ;; "pkgconfig/libpainter-uninstalled.pc") CONFIG_FILES="$CONFIG_FILES pkgconfig/libpainter-uninstalled.pc" ;; "pkgconfig/Makefile") CONFIG_FILES="$CONFIG_FILES pkgconfig/Makefile" ;; "src/Makefile") CONFIG_FILES="$CONFIG_FILES src/Makefile" ;; "tests/Makefile") CONFIG_FILES="$CONFIG_FILES tests/Makefile" ;; *) as_fn_error $? "invalid argument: \`$ac_config_target'" "$LINENO" 5;; esac done # If the user did not use the arguments to specify the items to instantiate, # then the envvar interface is used. Set only those that are not. # We use the long form for the default assignment because of an extremely # bizarre bug on SunOS 4.1.3. if $ac_need_defaults; then test "${CONFIG_FILES+set}" = set || CONFIG_FILES=$config_files test "${CONFIG_HEADERS+set}" = set || CONFIG_HEADERS=$config_headers test "${CONFIG_COMMANDS+set}" = set || CONFIG_COMMANDS=$config_commands fi # Have a temporary directory for convenience. Make it in the build tree # simply because there is no reason against having it here, and in addition, # creating and moving files from /tmp can sometimes cause problems. # Hook for its removal unless debugging. # Note that there is a small window in which the directory will not be cleaned: # after its creation but before its name has been assigned to `$tmp'. $debug || { tmp= ac_tmp= trap 'exit_status=$? : "${ac_tmp:=$tmp}" { test ! -d "$ac_tmp" || rm -fr "$ac_tmp"; } && exit $exit_status ' 0 trap 'as_fn_exit 1' 1 2 13 15 } # Create a (secure) tmp directory for tmp files. { tmp=`(umask 077 && mktemp -d "./confXXXXXX") 2>/dev/null` && test -d "$tmp" } || { tmp=./conf$$-$RANDOM (umask 077 && mkdir "$tmp") } || as_fn_error $? "cannot create a temporary directory in ." "$LINENO" 5 ac_tmp=$tmp # Set up the scripts for CONFIG_FILES section. # No need to generate them if there are no CONFIG_FILES. # This happens for instance with `./config.status config.h'. if test -n "$CONFIG_FILES"; then ac_cr=`echo X | tr X '\015'` # On cygwin, bash can eat \r inside `` if the user requested igncr. # But we know of no other shell where ac_cr would be empty at this # point, so we can use a bashism as a fallback. if test "x$ac_cr" = x; then eval ac_cr=\$\'\\r\' fi ac_cs_awk_cr=`$AWK 'BEGIN { print "a\rb" }' /dev/null` if test "$ac_cs_awk_cr" = "a${ac_cr}b"; then ac_cs_awk_cr='\\r' else ac_cs_awk_cr=$ac_cr fi echo 'BEGIN {' >"$ac_tmp/subs1.awk" && _ACEOF { echo "cat >conf$$subs.awk <<_ACEOF" && echo "$ac_subst_vars" | sed 's/.*/&!$&$ac_delim/' && echo "_ACEOF" } >conf$$subs.sh || as_fn_error $? "could not make $CONFIG_STATUS" "$LINENO" 5 ac_delim_num=`echo "$ac_subst_vars" | grep -c '^'` ac_delim='%!_!# ' for ac_last_try in false false false false false :; do . ./conf$$subs.sh || as_fn_error $? "could not make $CONFIG_STATUS" "$LINENO" 5 ac_delim_n=`sed -n "s/.*$ac_delim\$/X/p" conf$$subs.awk | grep -c X` if test $ac_delim_n = $ac_delim_num; then break elif $ac_last_try; then as_fn_error $? "could not make $CONFIG_STATUS" "$LINENO" 5 else ac_delim="$ac_delim!$ac_delim _$ac_delim!! " fi done rm -f conf$$subs.sh cat >>$CONFIG_STATUS <<_ACEOF || ac_write_fail=1 cat >>"\$ac_tmp/subs1.awk" <<\\_ACAWK && _ACEOF sed -n ' h s/^/S["/; s/!.*/"]=/ p g s/^[^!]*!// :repl t repl s/'"$ac_delim"'$// t delim :nl h s/\(.\{148\}\)..*/\1/ t more1 s/["\\]/\\&/g; s/^/"/; s/$/\\n"\\/ p n b repl :more1 s/["\\]/\\&/g; s/^/"/; s/$/"\\/ p g s/.\{148\}// t nl :delim h s/\(.\{148\}\)..*/\1/ t more2 s/["\\]/\\&/g; s/^/"/; s/$/"/ p b :more2 s/["\\]/\\&/g; s/^/"/; s/$/"\\/ p g s/.\{148\}// t delim ' >$CONFIG_STATUS || ac_write_fail=1 rm -f conf$$subs.awk cat >>$CONFIG_STATUS <<_ACEOF || ac_write_fail=1 _ACAWK cat >>"\$ac_tmp/subs1.awk" <<_ACAWK && for (key in S) S_is_set[key] = 1 FS = "" } { line = $ 0 nfields = split(line, field, "@") substed = 0 len = length(field[1]) for (i = 2; i < nfields; i++) { key = field[i] keylen = length(key) if (S_is_set[key]) { value = S[key] line = substr(line, 1, len) "" value "" substr(line, len + keylen + 3) len += length(value) + length(field[++i]) substed = 1 } else len += 1 + keylen } print line } _ACAWK _ACEOF cat >>$CONFIG_STATUS <<\_ACEOF || ac_write_fail=1 if sed "s/$ac_cr//" < /dev/null > /dev/null 2>&1; then sed "s/$ac_cr\$//; s/$ac_cr/$ac_cs_awk_cr/g" else cat fi < "$ac_tmp/subs1.awk" > "$ac_tmp/subs.awk" \ || as_fn_error $? "could not setup config files machinery" "$LINENO" 5 _ACEOF # VPATH may cause trouble with some makes, so we remove sole $(srcdir), # ${srcdir} and @srcdir@ entries from VPATH if srcdir is ".", strip leading and # trailing colons and then remove the whole line if VPATH becomes empty # (actually we leave an empty line to preserve line numbers). if test "x$srcdir" = x.; then ac_vpsub='/^[ ]*VPATH[ ]*=[ ]*/{ h s/// s/^/:/ s/[ ]*$/:/ s/:\$(srcdir):/:/g s/:\${srcdir}:/:/g s/:@srcdir@:/:/g s/^:*// s/:*$// x s/\(=[ ]*\).*/\1/ G s/\n// s/^[^=]*=[ ]*$// }' fi cat >>$CONFIG_STATUS <<\_ACEOF || ac_write_fail=1 fi # test -n "$CONFIG_FILES" # Set up the scripts for CONFIG_HEADERS section. # No need to generate them if there are no CONFIG_HEADERS. # This happens for instance with `./config.status Makefile'. if test -n "$CONFIG_HEADERS"; then cat >"$ac_tmp/defines.awk" <<\_ACAWK || BEGIN { _ACEOF # Transform confdefs.h into an awk script `defines.awk', embedded as # here-document in config.status, that substitutes the proper values into # config.h.in to produce config.h. # Create a delimiter string that does not exist in confdefs.h, to ease # handling of long lines. ac_delim='%!_!# ' for ac_last_try in false false :; do ac_tt=`sed -n "/$ac_delim/p" confdefs.h` if test -z "$ac_tt"; then break elif $ac_last_try; then as_fn_error $? "could not make $CONFIG_HEADERS" "$LINENO" 5 else ac_delim="$ac_delim!$ac_delim _$ac_delim!! " fi done # For the awk script, D is an array of macro values keyed by name, # likewise P contains macro parameters if any. Preserve backslash # newline sequences. ac_word_re=[_$as_cr_Letters][_$as_cr_alnum]* sed -n ' s/.\{148\}/&'"$ac_delim"'/g t rset :rset s/^[ ]*#[ ]*define[ ][ ]*/ / t def d :def s/\\$// t bsnl s/["\\]/\\&/g s/^ \('"$ac_word_re"'\)\(([^()]*)\)[ ]*\(.*\)/P["\1"]="\2"\ D["\1"]=" \3"/p s/^ \('"$ac_word_re"'\)[ ]*\(.*\)/D["\1"]=" \2"/p d :bsnl s/["\\]/\\&/g s/^ \('"$ac_word_re"'\)\(([^()]*)\)[ ]*\(.*\)/P["\1"]="\2"\ D["\1"]=" \3\\\\\\n"\\/p t cont s/^ \('"$ac_word_re"'\)[ ]*\(.*\)/D["\1"]=" \2\\\\\\n"\\/p t cont d :cont n s/.\{148\}/&'"$ac_delim"'/g t clear :clear s/\\$// t bsnlc s/["\\]/\\&/g; s/^/"/; s/$/"/p d :bsnlc s/["\\]/\\&/g; s/^/"/; s/$/\\\\\\n"\\/p b cont ' >$CONFIG_STATUS || ac_write_fail=1 cat >>$CONFIG_STATUS <<_ACEOF || ac_write_fail=1 for (key in D) D_is_set[key] = 1 FS = "" } /^[\t ]*#[\t ]*(define|undef)[\t ]+$ac_word_re([\t (]|\$)/ { line = \$ 0 split(line, arg, " ") if (arg[1] == "#") { defundef = arg[2] mac1 = arg[3] } else { defundef = substr(arg[1], 2) mac1 = arg[2] } split(mac1, mac2, "(") #) macro = mac2[1] prefix = substr(line, 1, index(line, defundef) - 1) if (D_is_set[macro]) { # Preserve the white space surrounding the "#". print prefix "define", macro P[macro] D[macro] next } else { # Replace #undef with comments. This is necessary, for example, # in the case of _POSIX_SOURCE, which is predefined and required # on some systems where configure will not decide to define it. if (defundef == "undef") { print "/*", prefix defundef, macro, "*/" next } } } { print } _ACAWK _ACEOF cat >>$CONFIG_STATUS <<\_ACEOF || ac_write_fail=1 as_fn_error $? "could not setup config headers machinery" "$LINENO" 5 fi # test -n "$CONFIG_HEADERS" eval set X " :F $CONFIG_FILES :H $CONFIG_HEADERS :C $CONFIG_COMMANDS" shift for ac_tag do case $ac_tag in :[FHLC]) ac_mode=$ac_tag; continue;; esac case $ac_mode$ac_tag in :[FHL]*:*);; :L* | :C*:*) as_fn_error $? "invalid tag \`$ac_tag'" "$LINENO" 5;; :[FH]-) ac_tag=-:-;; :[FH]*) ac_tag=$ac_tag:$ac_tag.in;; esac ac_save_IFS=$IFS IFS=: set x $ac_tag IFS=$ac_save_IFS shift ac_file=$1 shift case $ac_mode in :L) ac_source=$1;; :[FH]) ac_file_inputs= for ac_f do case $ac_f in -) ac_f="$ac_tmp/stdin";; *) # Look for the file first in the build tree, then in the source tree # (if the path is not absolute). The absolute path cannot be DOS-style, # because $ac_f cannot contain `:'. test -f "$ac_f" || case $ac_f in [\\/$]*) false;; *) test -f "$srcdir/$ac_f" && ac_f="$srcdir/$ac_f";; esac || as_fn_error 1 "cannot find input file: \`$ac_f'" "$LINENO" 5;; esac case $ac_f in *\'*) ac_f=`$as_echo "$ac_f" | sed "s/'/'\\\\\\\\''/g"`;; esac as_fn_append ac_file_inputs " '$ac_f'" done # Let's still pretend it is `configure' which instantiates (i.e., don't # use $as_me), people would be surprised to read: # /* config.h. Generated by config.status. */ configure_input='Generated from '` $as_echo "$*" | sed 's|^[^:]*/||;s|:[^:]*/|, |g' `' by configure.' if test x"$ac_file" != x-; then configure_input="$ac_file. $configure_input" { $as_echo "$as_me:${as_lineno-$LINENO}: creating $ac_file" >&5 $as_echo "$as_me: creating $ac_file" >&6;} fi # Neutralize special characters interpreted by sed in replacement strings. case $configure_input in #( *\&* | *\|* | *\\* ) ac_sed_conf_input=`$as_echo "$configure_input" | sed 's/[\\\\&|]/\\\\&/g'`;; #( *) ac_sed_conf_input=$configure_input;; esac case $ac_tag in *:-:* | *:-) cat >"$ac_tmp/stdin" \ || as_fn_error $? "could not create $ac_file" "$LINENO" 5 ;; esac ;; esac ac_dir=`$as_dirname -- "$ac_file" || $as_expr X"$ac_file" : 'X\(.*[^/]\)//*[^/][^/]*/*$' \| \ X"$ac_file" : 'X\(//\)[^/]' \| \ X"$ac_file" : 'X\(//\)$' \| \ X"$ac_file" : 'X\(/\)' \| . 2>/dev/null || $as_echo X"$ac_file" | sed '/^X\(.*[^/]\)\/\/*[^/][^/]*\/*$/{ s//\1/ q } /^X\(\/\/\)[^/].*/{ s//\1/ q } /^X\(\/\/\)$/{ s//\1/ q } /^X\(\/\).*/{ s//\1/ q } s/.*/./; q'` as_dir="$ac_dir"; as_fn_mkdir_p ac_builddir=. case "$ac_dir" in .) ac_dir_suffix= ac_top_builddir_sub=. ac_top_build_prefix= ;; *) ac_dir_suffix=/`$as_echo "$ac_dir" | sed 's|^\.[\\/]||'` # A ".." for each directory in $ac_dir_suffix. ac_top_builddir_sub=`$as_echo "$ac_dir_suffix" | sed 's|/[^\\/]*|/..|g;s|/||'` case $ac_top_builddir_sub in "") ac_top_builddir_sub=. ac_top_build_prefix= ;; *) ac_top_build_prefix=$ac_top_builddir_sub/ ;; esac ;; esac ac_abs_top_builddir=$ac_pwd ac_abs_builddir=$ac_pwd$ac_dir_suffix # for backward compatibility: ac_top_builddir=$ac_top_build_prefix case $srcdir in .) # We are building in place. ac_srcdir=. ac_top_srcdir=$ac_top_builddir_sub ac_abs_top_srcdir=$ac_pwd ;; [\\/]* | ?:[\\/]* ) # Absolute name. ac_srcdir=$srcdir$ac_dir_suffix; ac_top_srcdir=$srcdir ac_abs_top_srcdir=$srcdir ;; *) # Relative name. ac_srcdir=$ac_top_build_prefix$srcdir$ac_dir_suffix ac_top_srcdir=$ac_top_build_prefix$srcdir ac_abs_top_srcdir=$ac_pwd/$srcdir ;; esac ac_abs_srcdir=$ac_abs_top_srcdir$ac_dir_suffix case $ac_mode in :F) # # CONFIG_FILE # case $INSTALL in [\\/$]* | ?:[\\/]* ) ac_INSTALL=$INSTALL ;; *) ac_INSTALL=$ac_top_build_prefix$INSTALL ;; esac ac_MKDIR_P=$MKDIR_P case $MKDIR_P in [\\/$]* | ?:[\\/]* ) ;; */*) ac_MKDIR_P=$ac_top_build_prefix$MKDIR_P ;; esac _ACEOF cat >>$CONFIG_STATUS <<\_ACEOF || ac_write_fail=1 # If the template does not know about datarootdir, expand it. # FIXME: This hack should be removed a few years after 2.60. ac_datarootdir_hack=; ac_datarootdir_seen= ac_sed_dataroot=' /datarootdir/ { p q } /@datadir@/p /@docdir@/p /@infodir@/p /@localedir@/p /@mandir@/p' case `eval "sed -n \"\$ac_sed_dataroot\" $ac_file_inputs"` in *datarootdir*) ac_datarootdir_seen=yes;; *@datadir@*|*@docdir@*|*@infodir@*|*@localedir@*|*@mandir@*) { $as_echo "$as_me:${as_lineno-$LINENO}: WARNING: $ac_file_inputs seems to ignore the --datarootdir setting" >&5 $as_echo "$as_me: WARNING: $ac_file_inputs seems to ignore the --datarootdir setting" >&2;} _ACEOF cat >>$CONFIG_STATUS <<_ACEOF || ac_write_fail=1 ac_datarootdir_hack=' s&@datadir@&$datadir&g s&@docdir@&$docdir&g s&@infodir@&$infodir&g s&@localedir@&$localedir&g s&@mandir@&$mandir&g s&\\\${datarootdir}&$datarootdir&g' ;; esac _ACEOF # Neutralize VPATH when `$srcdir' = `.'. # Shell code in configure.ac might set extrasub. # FIXME: do we really want to maintain this feature? cat >>$CONFIG_STATUS <<_ACEOF || ac_write_fail=1 ac_sed_extra="$ac_vpsub $extrasub _ACEOF cat >>$CONFIG_STATUS <<\_ACEOF || ac_write_fail=1 :t /@[a-zA-Z_][a-zA-Z_0-9]*@/!b s|@configure_input@|$ac_sed_conf_input|;t t s&@top_builddir@&$ac_top_builddir_sub&;t t s&@top_build_prefix@&$ac_top_build_prefix&;t t s&@srcdir@&$ac_srcdir&;t t s&@abs_srcdir@&$ac_abs_srcdir&;t t s&@top_srcdir@&$ac_top_srcdir&;t t s&@abs_top_srcdir@&$ac_abs_top_srcdir&;t t s&@builddir@&$ac_builddir&;t t s&@abs_builddir@&$ac_abs_builddir&;t t s&@abs_top_builddir@&$ac_abs_top_builddir&;t t s&@INSTALL@&$ac_INSTALL&;t t s&@MKDIR_P@&$ac_MKDIR_P&;t t $ac_datarootdir_hack " eval sed \"\$ac_sed_extra\" "$ac_file_inputs" | $AWK -f "$ac_tmp/subs.awk" \ >$ac_tmp/out || as_fn_error $? "could not create $ac_file" "$LINENO" 5 test -z "$ac_datarootdir_hack$ac_datarootdir_seen" && { ac_out=`sed -n '/\${datarootdir}/p' "$ac_tmp/out"`; test -n "$ac_out"; } && { ac_out=`sed -n '/^[ ]*datarootdir[ ]*:*=/p' \ "$ac_tmp/out"`; test -z "$ac_out"; } && { $as_echo "$as_me:${as_lineno-$LINENO}: WARNING: $ac_file contains a reference to the variable \`datarootdir' which seems to be undefined. Please make sure it is defined" >&5 $as_echo "$as_me: WARNING: $ac_file contains a reference to the variable \`datarootdir' which seems to be undefined. Please make sure it is defined" >&2;} rm -f "$ac_tmp/stdin" case $ac_file in -) cat "$ac_tmp/out" && rm -f "$ac_tmp/out";; *) rm -f "$ac_file" && mv "$ac_tmp/out" "$ac_file";; esac \ || as_fn_error $? "could not create $ac_file" "$LINENO" 5 ;; :H) # # CONFIG_HEADER # if test x"$ac_file" != x-; then { $as_echo "/* $configure_input */" \ && eval '$AWK -f "$ac_tmp/defines.awk"' "$ac_file_inputs" } >"$ac_tmp/config.h" \ || as_fn_error $? "could not create $ac_file" "$LINENO" 5 if diff "$ac_file" "$ac_tmp/config.h" >/dev/null 2>&1; then { $as_echo "$as_me:${as_lineno-$LINENO}: $ac_file is unchanged" >&5 $as_echo "$as_me: $ac_file is unchanged" >&6;} else rm -f "$ac_file" mv "$ac_tmp/config.h" "$ac_file" \ || as_fn_error $? "could not create $ac_file" "$LINENO" 5 fi else $as_echo "/* $configure_input */" \ && eval '$AWK -f "$ac_tmp/defines.awk"' "$ac_file_inputs" \ || as_fn_error $? "could not create -" "$LINENO" 5 fi # Compute "$ac_file"'s index in $config_headers. _am_arg="$ac_file" _am_stamp_count=1 for _am_header in $config_headers :; do case $_am_header in $_am_arg | $_am_arg:* ) break ;; * ) _am_stamp_count=`expr $_am_stamp_count + 1` ;; esac done echo "timestamp for $_am_arg" >`$as_dirname -- "$_am_arg" || $as_expr X"$_am_arg" : 'X\(.*[^/]\)//*[^/][^/]*/*$' \| \ X"$_am_arg" : 'X\(//\)[^/]' \| \ X"$_am_arg" : 'X\(//\)$' \| \ X"$_am_arg" : 'X\(/\)' \| . 2>/dev/null || $as_echo X"$_am_arg" | sed '/^X\(.*[^/]\)\/\/*[^/][^/]*\/*$/{ s//\1/ q } /^X\(\/\/\)[^/].*/{ s//\1/ q } /^X\(\/\/\)$/{ s//\1/ q } /^X\(\/\).*/{ s//\1/ q } s/.*/./; q'`/stamp-h$_am_stamp_count ;; :C) { $as_echo "$as_me:${as_lineno-$LINENO}: executing $ac_file commands" >&5 $as_echo "$as_me: executing $ac_file commands" >&6;} ;; esac case $ac_file$ac_mode in "depfiles":C) test x"$AMDEP_TRUE" != x"" || { # Older Autoconf quotes --file arguments for eval, but not when files # are listed without --file. Let's play safe and only enable the eval # if we detect the quoting. case $CONFIG_FILES in *\'*) eval set x "$CONFIG_FILES" ;; *) set x $CONFIG_FILES ;; esac shift for mf do # Strip MF so we end up with the name of the file. mf=`echo "$mf" | sed -e 's/:.*$//'` # Check whether this is an Automake generated Makefile or not. # We used to match only the files named 'Makefile.in', but # some people rename them; so instead we look at the file content. # Grep'ing the first line is not enough: some people post-process # each Makefile.in and add a new line on top of each file to say so. # Grep'ing the whole file is not good either: AIX grep has a line # limit of 2048, but all sed's we know have understand at least 4000. if sed -n 's,^#.*generated by automake.*,X,p' "$mf" | grep X >/dev/null 2>&1; then dirpart=`$as_dirname -- "$mf" || $as_expr X"$mf" : 'X\(.*[^/]\)//*[^/][^/]*/*$' \| \ X"$mf" : 'X\(//\)[^/]' \| \ X"$mf" : 'X\(//\)$' \| \ X"$mf" : 'X\(/\)' \| . 2>/dev/null || $as_echo X"$mf" | sed '/^X\(.*[^/]\)\/\/*[^/][^/]*\/*$/{ s//\1/ q } /^X\(\/\/\)[^/].*/{ s//\1/ q } /^X\(\/\/\)$/{ s//\1/ q } /^X\(\/\).*/{ s//\1/ q } s/.*/./; q'` else continue fi # Extract the definition of DEPDIR, am__include, and am__quote # from the Makefile without running 'make'. DEPDIR=`sed -n 's/^DEPDIR = //p' < "$mf"` test -z "$DEPDIR" && continue am__include=`sed -n 's/^am__include = //p' < "$mf"` test -z "$am__include" && continue am__quote=`sed -n 's/^am__quote = //p' < "$mf"` # Find all dependency output files, they are included files with # $(DEPDIR) in their names. We invoke sed twice because it is the # simplest approach to changing $(DEPDIR) to its actual value in the # expansion. for file in `sed -n " s/^$am__include $am__quote\(.*(DEPDIR).*\)$am__quote"'$/\1/p' <"$mf" | \ sed -e 's/\$(DEPDIR)/'"$DEPDIR"'/g'`; do # Make sure the directory exists. test -f "$dirpart/$file" && continue fdir=`$as_dirname -- "$file" || $as_expr X"$file" : 'X\(.*[^/]\)//*[^/][^/]*/*$' \| \ X"$file" : 'X\(//\)[^/]' \| \ X"$file" : 'X\(//\)$' \| \ X"$file" : 'X\(/\)' \| . 2>/dev/null || $as_echo X"$file" | sed '/^X\(.*[^/]\)\/\/*[^/][^/]*\/*$/{ s//\1/ q } /^X\(\/\/\)[^/].*/{ s//\1/ q } /^X\(\/\/\)$/{ s//\1/ q } /^X\(\/\).*/{ s//\1/ q } s/.*/./; q'` as_dir=$dirpart/$fdir; as_fn_mkdir_p # echo "creating $dirpart/$file" echo '# dummy' > "$dirpart/$file" done done } ;; "libtool":C) # See if we are running on zsh, and set the options that allow our # commands through without removal of \ escapes. if test -n "${ZSH_VERSION+set}"; then setopt NO_GLOB_SUBST fi cfgfile=${ofile}T trap "$RM \"$cfgfile\"; exit 1" 1 2 15 $RM "$cfgfile" cat <<_LT_EOF >> "$cfgfile" #! $SHELL # Generated automatically by $as_me ($PACKAGE) $VERSION # Libtool was configured on host `(hostname || uname -n) 2>/dev/null | sed 1q`: # NOTE: Changes made to this file will be lost: look at ltmain.sh. # Provide generalized library-building support services. # Written by Gordon Matzigkeit, 1996 # Copyright (C) 2014 Free Software Foundation, Inc. # This is free software; see the source for copying conditions. There is NO # warranty; not even for MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. # GNU Libtool 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 2 of of the License, or # (at your option) any later version. # # As a special exception to the GNU General Public License, if you # distribute this file as part of a program or library that is built # using GNU Libtool, you may include this file under the same # distribution terms that you use for the rest of that program. # # GNU Libtool 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. # # You should have received a copy of the GNU General Public License # along with this program. If not, see . # The names of the tagged configurations supported by this script. available_tags='' # Configured defaults for sys_lib_dlsearch_path munging. : \${LT_SYS_LIBRARY_PATH="$configure_time_lt_sys_library_path"} # ### BEGIN LIBTOOL CONFIG # Which release of libtool.m4 was used? macro_version=$macro_version macro_revision=$macro_revision # Whether or not to build shared libraries. build_libtool_libs=$enable_shared # Whether or not to build static libraries. build_old_libs=$enable_static # What type of objects to build. pic_mode=$pic_mode # Whether or not to optimize for fast installation. fast_install=$enable_fast_install # Shared archive member basename,for filename based shared library versioning on AIX. shared_archive_member_spec=$shared_archive_member_spec # Shell to use when invoking shell scripts. SHELL=$lt_SHELL # An echo program that protects backslashes. ECHO=$lt_ECHO # The PATH separator for the build system. PATH_SEPARATOR=$lt_PATH_SEPARATOR # The host system. host_alias=$host_alias host=$host host_os=$host_os # The build system. build_alias=$build_alias build=$build build_os=$build_os # A sed program that does not truncate output. SED=$lt_SED # Sed that helps us avoid accidentally triggering echo(1) options like -n. Xsed="\$SED -e 1s/^X//" # A grep program that handles long lines. GREP=$lt_GREP # An ERE matcher. EGREP=$lt_EGREP # A literal string matcher. FGREP=$lt_FGREP # A BSD- or MS-compatible name lister. NM=$lt_NM # Whether we need soft or hard links. LN_S=$lt_LN_S # What is the maximum length of a command? max_cmd_len=$max_cmd_len # Object file suffix (normally "o"). objext=$ac_objext # Executable file suffix (normally ""). exeext=$exeext # whether the shell understands "unset". lt_unset=$lt_unset # turn spaces into newlines. SP2NL=$lt_lt_SP2NL # turn newlines into spaces. NL2SP=$lt_lt_NL2SP # convert \$build file names to \$host format. to_host_file_cmd=$lt_cv_to_host_file_cmd # convert \$build files to toolchain format. to_tool_file_cmd=$lt_cv_to_tool_file_cmd # An object symbol dumper. OBJDUMP=$lt_OBJDUMP # Method to check whether dependent libraries are shared objects. deplibs_check_method=$lt_deplibs_check_method # Command to use when deplibs_check_method = "file_magic". file_magic_cmd=$lt_file_magic_cmd # How to find potential files when deplibs_check_method = "file_magic". file_magic_glob=$lt_file_magic_glob # Find potential files using nocaseglob when deplibs_check_method = "file_magic". want_nocaseglob=$lt_want_nocaseglob # DLL creation program. DLLTOOL=$lt_DLLTOOL # Command to associate shared and link libraries. sharedlib_from_linklib_cmd=$lt_sharedlib_from_linklib_cmd # The archiver. AR=$lt_AR # Flags to create an archive. AR_FLAGS=$lt_AR_FLAGS # How to feed a file listing to the archiver. archiver_list_spec=$lt_archiver_list_spec # A symbol stripping program. STRIP=$lt_STRIP # Commands used to install an old-style archive. RANLIB=$lt_RANLIB old_postinstall_cmds=$lt_old_postinstall_cmds old_postuninstall_cmds=$lt_old_postuninstall_cmds # Whether to use a lock for old archive extraction. lock_old_archive_extraction=$lock_old_archive_extraction # A C compiler. LTCC=$lt_CC # LTCC compiler flags. LTCFLAGS=$lt_CFLAGS # Take the output of nm and produce a listing of raw symbols and C names. global_symbol_pipe=$lt_lt_cv_sys_global_symbol_pipe # Transform the output of nm in a proper C declaration. global_symbol_to_cdecl=$lt_lt_cv_sys_global_symbol_to_cdecl # Transform the output of nm into a list of symbols to manually relocate. global_symbol_to_import=$lt_lt_cv_sys_global_symbol_to_import # Transform the output of nm in a C name address pair. global_symbol_to_c_name_address=$lt_lt_cv_sys_global_symbol_to_c_name_address # Transform the output of nm in a C name address pair when lib prefix is needed. global_symbol_to_c_name_address_lib_prefix=$lt_lt_cv_sys_global_symbol_to_c_name_address_lib_prefix # The name lister interface. nm_interface=$lt_lt_cv_nm_interface # Specify filename containing input files for \$NM. nm_file_list_spec=$lt_nm_file_list_spec # The root where to search for dependent libraries,and where our libraries should be installed. lt_sysroot=$lt_sysroot # Command to truncate a binary pipe. lt_truncate_bin=$lt_lt_cv_truncate_bin # The name of the directory that contains temporary libtool files. objdir=$objdir # Used to examine libraries when file_magic_cmd begins with "file". MAGIC_CMD=$MAGIC_CMD # Must we lock files when doing compilation? need_locks=$lt_need_locks # Manifest tool. MANIFEST_TOOL=$lt_MANIFEST_TOOL # Tool to manipulate archived DWARF debug symbol files on Mac OS X. DSYMUTIL=$lt_DSYMUTIL # Tool to change global to local symbols on Mac OS X. NMEDIT=$lt_NMEDIT # Tool to manipulate fat objects and archives on Mac OS X. LIPO=$lt_LIPO # ldd/readelf like tool for Mach-O binaries on Mac OS X. OTOOL=$lt_OTOOL # ldd/readelf like tool for 64 bit Mach-O binaries on Mac OS X 10.4. OTOOL64=$lt_OTOOL64 # Old archive suffix (normally "a"). libext=$libext # Shared library suffix (normally ".so"). shrext_cmds=$lt_shrext_cmds # The commands to extract the exported symbol list from a shared archive. extract_expsyms_cmds=$lt_extract_expsyms_cmds # Variables whose values should be saved in libtool wrapper scripts and # restored at link time. variables_saved_for_relink=$lt_variables_saved_for_relink # Do we need the "lib" prefix for modules? need_lib_prefix=$need_lib_prefix # Do we need a version for libraries? need_version=$need_version # Library versioning type. version_type=$version_type # Shared library runtime path variable. runpath_var=$runpath_var # Shared library path variable. shlibpath_var=$shlibpath_var # Is shlibpath searched before the hard-coded library search path? shlibpath_overrides_runpath=$shlibpath_overrides_runpath # Format of library name prefix. libname_spec=$lt_libname_spec # List of archive names. First name is the real one, the rest are links. # The last name is the one that the linker finds with -lNAME library_names_spec=$lt_library_names_spec # The coded name of the library, if different from the real name. soname_spec=$lt_soname_spec # Permission mode override for installation of shared libraries. install_override_mode=$lt_install_override_mode # Command to use after installation of a shared archive. postinstall_cmds=$lt_postinstall_cmds # Command to use after uninstallation of a shared archive. postuninstall_cmds=$lt_postuninstall_cmds # Commands used to finish a libtool library installation in a directory. finish_cmds=$lt_finish_cmds # As "finish_cmds", except a single script fragment to be evaled but # not shown. finish_eval=$lt_finish_eval # Whether we should hardcode library paths into libraries. hardcode_into_libs=$hardcode_into_libs # Compile-time system search path for libraries. sys_lib_search_path_spec=$lt_sys_lib_search_path_spec # Detected run-time system search path for libraries. sys_lib_dlsearch_path_spec=$lt_configure_time_dlsearch_path # Explicit LT_SYS_LIBRARY_PATH set during ./configure time. configure_time_lt_sys_library_path=$lt_configure_time_lt_sys_library_path # Whether dlopen is supported. dlopen_support=$enable_dlopen # Whether dlopen of programs is supported. dlopen_self=$enable_dlopen_self # Whether dlopen of statically linked programs is supported. dlopen_self_static=$enable_dlopen_self_static # Commands to strip libraries. old_striplib=$lt_old_striplib striplib=$lt_striplib # The linker used to build libraries. LD=$lt_LD # How to create reloadable object files. reload_flag=$lt_reload_flag reload_cmds=$lt_reload_cmds # Commands used to build an old-style archive. old_archive_cmds=$lt_old_archive_cmds # A language specific compiler. CC=$lt_compiler # Is the compiler the GNU compiler? with_gcc=$GCC # Compiler flag to turn off builtin functions. no_builtin_flag=$lt_lt_prog_compiler_no_builtin_flag # Additional compiler flags for building library objects. pic_flag=$lt_lt_prog_compiler_pic # How to pass a linker flag through the compiler. wl=$lt_lt_prog_compiler_wl # Compiler flag to prevent dynamic linking. link_static_flag=$lt_lt_prog_compiler_static # Does compiler simultaneously support -c and -o options? compiler_c_o=$lt_lt_cv_prog_compiler_c_o # Whether or not to add -lc for building shared libraries. build_libtool_need_lc=$archive_cmds_need_lc # Whether or not to disallow shared libs when runtime libs are static. allow_libtool_libs_with_static_runtimes=$enable_shared_with_static_runtimes # Compiler flag to allow reflexive dlopens. export_dynamic_flag_spec=$lt_export_dynamic_flag_spec # Compiler flag to generate shared objects directly from archives. whole_archive_flag_spec=$lt_whole_archive_flag_spec # Whether the compiler copes with passing no objects directly. compiler_needs_object=$lt_compiler_needs_object # Create an old-style archive from a shared archive. old_archive_from_new_cmds=$lt_old_archive_from_new_cmds # Create a temporary old-style archive to link instead of a shared archive. old_archive_from_expsyms_cmds=$lt_old_archive_from_expsyms_cmds # Commands used to build a shared archive. archive_cmds=$lt_archive_cmds archive_expsym_cmds=$lt_archive_expsym_cmds # Commands used to build a loadable module if different from building # a shared archive. module_cmds=$lt_module_cmds module_expsym_cmds=$lt_module_expsym_cmds # Whether we are building with GNU ld or not. with_gnu_ld=$lt_with_gnu_ld # Flag that allows shared libraries with undefined symbols to be built. allow_undefined_flag=$lt_allow_undefined_flag # Flag that enforces no undefined symbols. no_undefined_flag=$lt_no_undefined_flag # Flag to hardcode \$libdir into a binary during linking. # This must work even if \$libdir does not exist hardcode_libdir_flag_spec=$lt_hardcode_libdir_flag_spec # Whether we need a single "-rpath" flag with a separated argument. hardcode_libdir_separator=$lt_hardcode_libdir_separator # Set to "yes" if using DIR/libNAME\$shared_ext during linking hardcodes # DIR into the resulting binary. hardcode_direct=$hardcode_direct # Set to "yes" if using DIR/libNAME\$shared_ext during linking hardcodes # DIR into the resulting binary and the resulting library dependency is # "absolute",i.e impossible to change by setting \$shlibpath_var if the # library is relocated. hardcode_direct_absolute=$hardcode_direct_absolute # Set to "yes" if using the -LDIR flag during linking hardcodes DIR # into the resulting binary. hardcode_minus_L=$hardcode_minus_L # Set to "yes" if using SHLIBPATH_VAR=DIR during linking hardcodes DIR # into the resulting binary. hardcode_shlibpath_var=$hardcode_shlibpath_var # Set to "yes" if building a shared library automatically hardcodes DIR # into the library and all subsequent libraries and executables linked # against it. hardcode_automatic=$hardcode_automatic # Set to yes if linker adds runtime paths of dependent libraries # to runtime path list. inherit_rpath=$inherit_rpath # Whether libtool must link a program against all its dependency libraries. link_all_deplibs=$link_all_deplibs # Set to "yes" if exported symbols are required. always_export_symbols=$always_export_symbols # The commands to list exported symbols. export_symbols_cmds=$lt_export_symbols_cmds # Symbols that should not be listed in the preloaded symbols. exclude_expsyms=$lt_exclude_expsyms # Symbols that must always be exported. include_expsyms=$lt_include_expsyms # Commands necessary for linking programs (against libraries) with templates. prelink_cmds=$lt_prelink_cmds # Commands necessary for finishing linking programs. postlink_cmds=$lt_postlink_cmds # Specify filename containing input files. file_list_spec=$lt_file_list_spec # How to hardcode a shared library path into an executable. hardcode_action=$hardcode_action # ### END LIBTOOL CONFIG _LT_EOF cat <<'_LT_EOF' >> "$cfgfile" # ### BEGIN FUNCTIONS SHARED WITH CONFIGURE # func_munge_path_list VARIABLE PATH # ----------------------------------- # VARIABLE is name of variable containing _space_ separated list of # directories to be munged by the contents of PATH, which is string # having a format: # "DIR[:DIR]:" # string "DIR[ DIR]" will be prepended to VARIABLE # ":DIR[:DIR]" # string "DIR[ DIR]" will be appended to VARIABLE # "DIRP[:DIRP]::[DIRA:]DIRA" # string "DIRP[ DIRP]" will be prepended to VARIABLE and string # "DIRA[ DIRA]" will be appended to VARIABLE # "DIR[:DIR]" # VARIABLE will be replaced by "DIR[ DIR]" func_munge_path_list () { case x$2 in x) ;; *:) eval $1=\"`$ECHO $2 | $SED 's/:/ /g'` \$$1\" ;; x:*) eval $1=\"\$$1 `$ECHO $2 | $SED 's/:/ /g'`\" ;; *::*) eval $1=\"\$$1\ `$ECHO $2 | $SED -e 's/.*:://' -e 's/:/ /g'`\" eval $1=\"`$ECHO $2 | $SED -e 's/::.*//' -e 's/:/ /g'`\ \$$1\" ;; *) eval $1=\"`$ECHO $2 | $SED 's/:/ /g'`\" ;; esac } # Calculate cc_basename. Skip known compiler wrappers and cross-prefix. func_cc_basename () { for cc_temp in $*""; do case $cc_temp in compile | *[\\/]compile | ccache | *[\\/]ccache ) ;; distcc | *[\\/]distcc | purify | *[\\/]purify ) ;; \-*) ;; *) break;; esac done func_cc_basename_result=`$ECHO "$cc_temp" | $SED "s%.*/%%; s%^$host_alias-%%"` } # ### END FUNCTIONS SHARED WITH CONFIGURE _LT_EOF case $host_os in aix3*) cat <<\_LT_EOF >> "$cfgfile" # AIX sometimes has problems with the GCC collect2 program. For some # reason, if we set the COLLECT_NAMES environment variable, the problems # vanish in a puff of smoke. if test set != "${COLLECT_NAMES+set}"; then COLLECT_NAMES= export COLLECT_NAMES fi _LT_EOF ;; esac ltmain=$ac_aux_dir/ltmain.sh # We use sed instead of cat because bash on DJGPP gets confused if # if finds mixed CR/LF and LF-only lines. Since sed operates in # text mode, it properly converts lines to CR/LF. This bash problem # is reportedly fixed, but why not run on old versions too? sed '$q' "$ltmain" >> "$cfgfile" \ || (rm -f "$cfgfile"; exit 1) mv -f "$cfgfile" "$ofile" || (rm -f "$ofile" && cp "$cfgfile" "$ofile" && rm -f "$cfgfile") chmod +x "$ofile" ;; esac done # for ac_tag as_fn_exit 0 _ACEOF ac_clean_files=$ac_clean_files_save test $ac_write_fail = 0 || as_fn_error $? "write failure creating $CONFIG_STATUS" "$LINENO" 5 # configure is writing to config.log, and then calls config.status. # config.status does its own redirection, appending to config.log. # Unfortunately, on DOS this fails, as config.log is still kept open # by configure, so config.status won't be able to write to it; its # output is simply discarded. So we exec the FD to /dev/null, # effectively closing config.log, so it can be properly (re)opened and # appended to by config.status. When coming back to configure, we # need to make the FD available again. if test "$no_create" != yes; then ac_cs_success=: ac_config_status_args= test "$silent" = yes && ac_config_status_args="$ac_config_status_args --quiet" exec 5>/dev/null $SHELL $CONFIG_STATUS $ac_config_status_args || ac_cs_success=false exec 5>>config.log # Use ||, not &&, to avoid exiting from the if with $? = 1, which # would make configure fail if this is the last instruction. $ac_cs_success || as_fn_exit 1 fi if test -n "$ac_unrecognized_opts" && test "$enable_option_checking" != no; then { $as_echo "$as_me:${as_lineno-$LINENO}: WARNING: unrecognized options: $ac_unrecognized_opts" >&5 $as_echo "$as_me: WARNING: unrecognized options: $ac_unrecognized_opts" >&2;} fi xrdp-0.9.5/libpainter/config.guess000755 001751 001751 00000124431 13220730741 017077 0ustar00metameta000000 000000 #! /bin/sh # Attempt to guess a canonical system name. # Copyright 1992-2015 Free Software Foundation, Inc. timestamp='2015-03-04' # This file 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. # # You should have received a copy of the GNU General Public License # along with this program; if not, see . # # As a special exception to the GNU General Public License, if you # distribute this file as part of a program that contains a # configuration script generated by Autoconf, you may include it under # the same distribution terms that you use for the rest of that # program. This Exception is an additional permission under section 7 # of the GNU General Public License, version 3 ("GPLv3"). # # Originally written by Per Bothner; maintained since 2000 by Ben Elliston. # # You can get the latest version of this script from: # http://git.savannah.gnu.org/gitweb/?p=config.git;a=blob_plain;f=config.guess;hb=HEAD # # Please send patches to . me=`echo "$0" | sed -e 's,.*/,,'` usage="\ Usage: $0 [OPTION] Output the configuration name of the system \`$me' is run on. Operation modes: -h, --help print this help, then exit -t, --time-stamp print date of last modification, then exit -v, --version print version number, then exit Report bugs and patches to ." version="\ GNU config.guess ($timestamp) Originally written by Per Bothner. Copyright 1992-2015 Free Software Foundation, Inc. This is free software; see the source for copying conditions. There is NO warranty; not even for MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE." help=" Try \`$me --help' for more information." # Parse command line while test $# -gt 0 ; do case $1 in --time-stamp | --time* | -t ) echo "$timestamp" ; exit ;; --version | -v ) echo "$version" ; exit ;; --help | --h* | -h ) echo "$usage"; exit ;; -- ) # Stop option processing shift; break ;; - ) # Use stdin as input. break ;; -* ) echo "$me: invalid option $1$help" >&2 exit 1 ;; * ) break ;; esac done if test $# != 0; then echo "$me: too many arguments$help" >&2 exit 1 fi trap 'exit 1' 1 2 15 # CC_FOR_BUILD -- compiler used by this script. Note that the use of a # compiler to aid in system detection is discouraged as it requires # temporary files to be created and, as you can see below, it is a # headache to deal with in a portable fashion. # Historically, `CC_FOR_BUILD' used to be named `HOST_CC'. We still # use `HOST_CC' if defined, but it is deprecated. # Portable tmp directory creation inspired by the Autoconf team. set_cc_for_build=' trap "exitcode=\$?; (rm -f \$tmpfiles 2>/dev/null; rmdir \$tmp 2>/dev/null) && exit \$exitcode" 0 ; trap "rm -f \$tmpfiles 2>/dev/null; rmdir \$tmp 2>/dev/null; exit 1" 1 2 13 15 ; : ${TMPDIR=/tmp} ; { tmp=`(umask 077 && mktemp -d "$TMPDIR/cgXXXXXX") 2>/dev/null` && test -n "$tmp" && test -d "$tmp" ; } || { test -n "$RANDOM" && tmp=$TMPDIR/cg$$-$RANDOM && (umask 077 && mkdir $tmp) ; } || { tmp=$TMPDIR/cg-$$ && (umask 077 && mkdir $tmp) && echo "Warning: creating insecure temp directory" >&2 ; } || { echo "$me: cannot create a temporary directory in $TMPDIR" >&2 ; exit 1 ; } ; dummy=$tmp/dummy ; tmpfiles="$dummy.c $dummy.o $dummy.rel $dummy" ; case $CC_FOR_BUILD,$HOST_CC,$CC in ,,) echo "int x;" > $dummy.c ; for c in cc gcc c89 c99 ; do if ($c -c -o $dummy.o $dummy.c) >/dev/null 2>&1 ; then CC_FOR_BUILD="$c"; break ; fi ; done ; if test x"$CC_FOR_BUILD" = x ; then CC_FOR_BUILD=no_compiler_found ; fi ;; ,,*) CC_FOR_BUILD=$CC ;; ,*,*) CC_FOR_BUILD=$HOST_CC ;; esac ; set_cc_for_build= ;' # This is needed to find uname on a Pyramid OSx when run in the BSD universe. # (ghazi@noc.rutgers.edu 1994-08-24) if (test -f /.attbin/uname) >/dev/null 2>&1 ; then PATH=$PATH:/.attbin ; export PATH fi UNAME_MACHINE=`(uname -m) 2>/dev/null` || UNAME_MACHINE=unknown UNAME_RELEASE=`(uname -r) 2>/dev/null` || UNAME_RELEASE=unknown UNAME_SYSTEM=`(uname -s) 2>/dev/null` || UNAME_SYSTEM=unknown UNAME_VERSION=`(uname -v) 2>/dev/null` || UNAME_VERSION=unknown case "${UNAME_SYSTEM}" in Linux|GNU|GNU/*) # If the system lacks a compiler, then just pick glibc. # We could probably try harder. LIBC=gnu eval $set_cc_for_build cat <<-EOF > $dummy.c #include #if defined(__UCLIBC__) LIBC=uclibc #elif defined(__dietlibc__) LIBC=dietlibc #else LIBC=gnu #endif EOF eval `$CC_FOR_BUILD -E $dummy.c 2>/dev/null | grep '^LIBC' | sed 's, ,,g'` ;; esac # Note: order is significant - the case branches are not exclusive. case "${UNAME_MACHINE}:${UNAME_SYSTEM}:${UNAME_RELEASE}:${UNAME_VERSION}" in *:NetBSD:*:*) # NetBSD (nbsd) targets should (where applicable) match one or # more of the tuples: *-*-netbsdelf*, *-*-netbsdaout*, # *-*-netbsdecoff* and *-*-netbsd*. For targets that recently # switched to ELF, *-*-netbsd* would select the old # object file format. This provides both forward # compatibility and a consistent mechanism for selecting the # object file format. # # Note: NetBSD doesn't particularly care about the vendor # portion of the name. We always set it to "unknown". sysctl="sysctl -n hw.machine_arch" UNAME_MACHINE_ARCH=`(uname -p 2>/dev/null || \ /sbin/$sysctl 2>/dev/null || \ /usr/sbin/$sysctl 2>/dev/null || \ echo unknown)` case "${UNAME_MACHINE_ARCH}" in armeb) machine=armeb-unknown ;; arm*) machine=arm-unknown ;; sh3el) machine=shl-unknown ;; sh3eb) machine=sh-unknown ;; sh5el) machine=sh5le-unknown ;; earmv*) arch=`echo ${UNAME_MACHINE_ARCH} | sed -e 's,^e\(armv[0-9]\).*$,\1,'` endian=`echo ${UNAME_MACHINE_ARCH} | sed -ne 's,^.*\(eb\)$,\1,p'` machine=${arch}${endian}-unknown ;; *) machine=${UNAME_MACHINE_ARCH}-unknown ;; esac # The Operating System including object format, if it has switched # to ELF recently, or will in the future. case "${UNAME_MACHINE_ARCH}" in arm*|earm*|i386|m68k|ns32k|sh3*|sparc|vax) eval $set_cc_for_build if echo __ELF__ | $CC_FOR_BUILD -E - 2>/dev/null \ | grep -q __ELF__ then # Once all utilities can be ECOFF (netbsdecoff) or a.out (netbsdaout). # Return netbsd for either. FIX? os=netbsd else os=netbsdelf fi ;; *) os=netbsd ;; esac # Determine ABI tags. case "${UNAME_MACHINE_ARCH}" in earm*) expr='s/^earmv[0-9]/-eabi/;s/eb$//' abi=`echo ${UNAME_MACHINE_ARCH} | sed -e "$expr"` ;; esac # The OS release # Debian GNU/NetBSD machines have a different userland, and # thus, need a distinct triplet. However, they do not need # kernel version information, so it can be replaced with a # suitable tag, in the style of linux-gnu. case "${UNAME_VERSION}" in Debian*) release='-gnu' ;; *) release=`echo ${UNAME_RELEASE}|sed -e 's/[-_].*/\./'` ;; esac # Since CPU_TYPE-MANUFACTURER-KERNEL-OPERATING_SYSTEM: # contains redundant information, the shorter form: # CPU_TYPE-MANUFACTURER-OPERATING_SYSTEM is used. echo "${machine}-${os}${release}${abi}" exit ;; *:Bitrig:*:*) UNAME_MACHINE_ARCH=`arch | sed 's/Bitrig.//'` echo ${UNAME_MACHINE_ARCH}-unknown-bitrig${UNAME_RELEASE} exit ;; *:OpenBSD:*:*) UNAME_MACHINE_ARCH=`arch | sed 's/OpenBSD.//'` echo ${UNAME_MACHINE_ARCH}-unknown-openbsd${UNAME_RELEASE} exit ;; *:ekkoBSD:*:*) echo ${UNAME_MACHINE}-unknown-ekkobsd${UNAME_RELEASE} exit ;; *:SolidBSD:*:*) echo ${UNAME_MACHINE}-unknown-solidbsd${UNAME_RELEASE} exit ;; macppc:MirBSD:*:*) echo powerpc-unknown-mirbsd${UNAME_RELEASE} exit ;; *:MirBSD:*:*) echo ${UNAME_MACHINE}-unknown-mirbsd${UNAME_RELEASE} exit ;; alpha:OSF1:*:*) case $UNAME_RELEASE in *4.0) UNAME_RELEASE=`/usr/sbin/sizer -v | awk '{print $3}'` ;; *5.*) UNAME_RELEASE=`/usr/sbin/sizer -v | awk '{print $4}'` ;; esac # According to Compaq, /usr/sbin/psrinfo has been available on # OSF/1 and Tru64 systems produced since 1995. I hope that # covers most systems running today. This code pipes the CPU # types through head -n 1, so we only detect the type of CPU 0. ALPHA_CPU_TYPE=`/usr/sbin/psrinfo -v | sed -n -e 's/^ The alpha \(.*\) processor.*$/\1/p' | head -n 1` case "$ALPHA_CPU_TYPE" in "EV4 (21064)") UNAME_MACHINE="alpha" ;; "EV4.5 (21064)") UNAME_MACHINE="alpha" ;; "LCA4 (21066/21068)") UNAME_MACHINE="alpha" ;; "EV5 (21164)") UNAME_MACHINE="alphaev5" ;; "EV5.6 (21164A)") UNAME_MACHINE="alphaev56" ;; "EV5.6 (21164PC)") UNAME_MACHINE="alphapca56" ;; "EV5.7 (21164PC)") UNAME_MACHINE="alphapca57" ;; "EV6 (21264)") UNAME_MACHINE="alphaev6" ;; "EV6.7 (21264A)") UNAME_MACHINE="alphaev67" ;; "EV6.8CB (21264C)") UNAME_MACHINE="alphaev68" ;; "EV6.8AL (21264B)") UNAME_MACHINE="alphaev68" ;; "EV6.8CX (21264D)") UNAME_MACHINE="alphaev68" ;; "EV6.9A (21264/EV69A)") UNAME_MACHINE="alphaev69" ;; "EV7 (21364)") UNAME_MACHINE="alphaev7" ;; "EV7.9 (21364A)") UNAME_MACHINE="alphaev79" ;; esac # A Pn.n version is a patched version. # A Vn.n version is a released version. # A Tn.n version is a released field test version. # A Xn.n version is an unreleased experimental baselevel. # 1.2 uses "1.2" for uname -r. echo ${UNAME_MACHINE}-dec-osf`echo ${UNAME_RELEASE} | sed -e 's/^[PVTX]//' | tr 'ABCDEFGHIJKLMNOPQRSTUVWXYZ' 'abcdefghijklmnopqrstuvwxyz'` # Reset EXIT trap before exiting to avoid spurious non-zero exit code. exitcode=$? trap '' 0 exit $exitcode ;; Alpha\ *:Windows_NT*:*) # How do we know it's Interix rather than the generic POSIX subsystem? # Should we change UNAME_MACHINE based on the output of uname instead # of the specific Alpha model? echo alpha-pc-interix exit ;; 21064:Windows_NT:50:3) echo alpha-dec-winnt3.5 exit ;; Amiga*:UNIX_System_V:4.0:*) echo m68k-unknown-sysv4 exit ;; *:[Aa]miga[Oo][Ss]:*:*) echo ${UNAME_MACHINE}-unknown-amigaos exit ;; *:[Mm]orph[Oo][Ss]:*:*) echo ${UNAME_MACHINE}-unknown-morphos exit ;; *:OS/390:*:*) echo i370-ibm-openedition exit ;; *:z/VM:*:*) echo s390-ibm-zvmoe exit ;; *:OS400:*:*) echo powerpc-ibm-os400 exit ;; arm:RISC*:1.[012]*:*|arm:riscix:1.[012]*:*) echo arm-acorn-riscix${UNAME_RELEASE} exit ;; arm*:riscos:*:*|arm*:RISCOS:*:*) echo arm-unknown-riscos exit ;; SR2?01:HI-UX/MPP:*:* | SR8000:HI-UX/MPP:*:*) echo hppa1.1-hitachi-hiuxmpp exit ;; Pyramid*:OSx*:*:* | MIS*:OSx*:*:* | MIS*:SMP_DC-OSx*:*:*) # akee@wpdis03.wpafb.af.mil (Earle F. Ake) contributed MIS and NILE. if test "`(/bin/universe) 2>/dev/null`" = att ; then echo pyramid-pyramid-sysv3 else echo pyramid-pyramid-bsd fi exit ;; NILE*:*:*:dcosx) echo pyramid-pyramid-svr4 exit ;; DRS?6000:unix:4.0:6*) echo sparc-icl-nx6 exit ;; DRS?6000:UNIX_SV:4.2*:7* | DRS?6000:isis:4.2*:7*) case `/usr/bin/uname -p` in sparc) echo sparc-icl-nx7; exit ;; esac ;; s390x:SunOS:*:*) echo ${UNAME_MACHINE}-ibm-solaris2`echo ${UNAME_RELEASE}|sed -e 's/[^.]*//'` exit ;; sun4H:SunOS:5.*:*) echo sparc-hal-solaris2`echo ${UNAME_RELEASE}|sed -e 's/[^.]*//'` exit ;; sun4*:SunOS:5.*:* | tadpole*:SunOS:5.*:*) echo sparc-sun-solaris2`echo ${UNAME_RELEASE}|sed -e 's/[^.]*//'` exit ;; i86pc:AuroraUX:5.*:* | i86xen:AuroraUX:5.*:*) echo i386-pc-auroraux${UNAME_RELEASE} exit ;; i86pc:SunOS:5.*:* | i86xen:SunOS:5.*:*) eval $set_cc_for_build SUN_ARCH="i386" # If there is a compiler, see if it is configured for 64-bit objects. # Note that the Sun cc does not turn __LP64__ into 1 like gcc does. # This test works for both compilers. if [ "$CC_FOR_BUILD" != 'no_compiler_found' ]; then if (echo '#ifdef __amd64'; echo IS_64BIT_ARCH; echo '#endif') | \ (CCOPTS= $CC_FOR_BUILD -E - 2>/dev/null) | \ grep IS_64BIT_ARCH >/dev/null then SUN_ARCH="x86_64" fi fi echo ${SUN_ARCH}-pc-solaris2`echo ${UNAME_RELEASE}|sed -e 's/[^.]*//'` exit ;; sun4*:SunOS:6*:*) # According to config.sub, this is the proper way to canonicalize # SunOS6. Hard to guess exactly what SunOS6 will be like, but # it's likely to be more like Solaris than SunOS4. echo sparc-sun-solaris3`echo ${UNAME_RELEASE}|sed -e 's/[^.]*//'` exit ;; sun4*:SunOS:*:*) case "`/usr/bin/arch -k`" in Series*|S4*) UNAME_RELEASE=`uname -v` ;; esac # Japanese Language versions have a version number like `4.1.3-JL'. echo sparc-sun-sunos`echo ${UNAME_RELEASE}|sed -e 's/-/_/'` exit ;; sun3*:SunOS:*:*) echo m68k-sun-sunos${UNAME_RELEASE} exit ;; sun*:*:4.2BSD:*) UNAME_RELEASE=`(sed 1q /etc/motd | awk '{print substr($5,1,3)}') 2>/dev/null` test "x${UNAME_RELEASE}" = "x" && UNAME_RELEASE=3 case "`/bin/arch`" in sun3) echo m68k-sun-sunos${UNAME_RELEASE} ;; sun4) echo sparc-sun-sunos${UNAME_RELEASE} ;; esac exit ;; aushp:SunOS:*:*) echo sparc-auspex-sunos${UNAME_RELEASE} exit ;; # The situation for MiNT is a little confusing. The machine name # can be virtually everything (everything which is not # "atarist" or "atariste" at least should have a processor # > m68000). The system name ranges from "MiNT" over "FreeMiNT" # to the lowercase version "mint" (or "freemint"). Finally # the system name "TOS" denotes a system which is actually not # MiNT. But MiNT is downward compatible to TOS, so this should # be no problem. atarist[e]:*MiNT:*:* | atarist[e]:*mint:*:* | atarist[e]:*TOS:*:*) echo m68k-atari-mint${UNAME_RELEASE} exit ;; atari*:*MiNT:*:* | atari*:*mint:*:* | atarist[e]:*TOS:*:*) echo m68k-atari-mint${UNAME_RELEASE} exit ;; *falcon*:*MiNT:*:* | *falcon*:*mint:*:* | *falcon*:*TOS:*:*) echo m68k-atari-mint${UNAME_RELEASE} exit ;; milan*:*MiNT:*:* | milan*:*mint:*:* | *milan*:*TOS:*:*) echo m68k-milan-mint${UNAME_RELEASE} exit ;; hades*:*MiNT:*:* | hades*:*mint:*:* | *hades*:*TOS:*:*) echo m68k-hades-mint${UNAME_RELEASE} exit ;; *:*MiNT:*:* | *:*mint:*:* | *:*TOS:*:*) echo m68k-unknown-mint${UNAME_RELEASE} exit ;; m68k:machten:*:*) echo m68k-apple-machten${UNAME_RELEASE} exit ;; powerpc:machten:*:*) echo powerpc-apple-machten${UNAME_RELEASE} exit ;; RISC*:Mach:*:*) echo mips-dec-mach_bsd4.3 exit ;; RISC*:ULTRIX:*:*) echo mips-dec-ultrix${UNAME_RELEASE} exit ;; VAX*:ULTRIX*:*:*) echo vax-dec-ultrix${UNAME_RELEASE} exit ;; 2020:CLIX:*:* | 2430:CLIX:*:*) echo clipper-intergraph-clix${UNAME_RELEASE} exit ;; mips:*:*:UMIPS | mips:*:*:RISCos) eval $set_cc_for_build sed 's/^ //' << EOF >$dummy.c #ifdef __cplusplus #include /* for printf() prototype */ int main (int argc, char *argv[]) { #else int main (argc, argv) int argc; char *argv[]; { #endif #if defined (host_mips) && defined (MIPSEB) #if defined (SYSTYPE_SYSV) printf ("mips-mips-riscos%ssysv\n", argv[1]); exit (0); #endif #if defined (SYSTYPE_SVR4) printf ("mips-mips-riscos%ssvr4\n", argv[1]); exit (0); #endif #if defined (SYSTYPE_BSD43) || defined(SYSTYPE_BSD) printf ("mips-mips-riscos%sbsd\n", argv[1]); exit (0); #endif #endif exit (-1); } EOF $CC_FOR_BUILD -o $dummy $dummy.c && dummyarg=`echo "${UNAME_RELEASE}" | sed -n 's/\([0-9]*\).*/\1/p'` && SYSTEM_NAME=`$dummy $dummyarg` && { echo "$SYSTEM_NAME"; exit; } echo mips-mips-riscos${UNAME_RELEASE} exit ;; Motorola:PowerMAX_OS:*:*) echo powerpc-motorola-powermax exit ;; Motorola:*:4.3:PL8-*) echo powerpc-harris-powermax exit ;; Night_Hawk:*:*:PowerMAX_OS | Synergy:PowerMAX_OS:*:*) echo powerpc-harris-powermax exit ;; Night_Hawk:Power_UNIX:*:*) echo powerpc-harris-powerunix exit ;; m88k:CX/UX:7*:*) echo m88k-harris-cxux7 exit ;; m88k:*:4*:R4*) echo m88k-motorola-sysv4 exit ;; m88k:*:3*:R3*) echo m88k-motorola-sysv3 exit ;; AViiON:dgux:*:*) # DG/UX returns AViiON for all architectures UNAME_PROCESSOR=`/usr/bin/uname -p` if [ $UNAME_PROCESSOR = mc88100 ] || [ $UNAME_PROCESSOR = mc88110 ] then if [ ${TARGET_BINARY_INTERFACE}x = m88kdguxelfx ] || \ [ ${TARGET_BINARY_INTERFACE}x = x ] then echo m88k-dg-dgux${UNAME_RELEASE} else echo m88k-dg-dguxbcs${UNAME_RELEASE} fi else echo i586-dg-dgux${UNAME_RELEASE} fi exit ;; M88*:DolphinOS:*:*) # DolphinOS (SVR3) echo m88k-dolphin-sysv3 exit ;; M88*:*:R3*:*) # Delta 88k system running SVR3 echo m88k-motorola-sysv3 exit ;; XD88*:*:*:*) # Tektronix XD88 system running UTekV (SVR3) echo m88k-tektronix-sysv3 exit ;; Tek43[0-9][0-9]:UTek:*:*) # Tektronix 4300 system running UTek (BSD) echo m68k-tektronix-bsd exit ;; *:IRIX*:*:*) echo mips-sgi-irix`echo ${UNAME_RELEASE}|sed -e 's/-/_/g'` exit ;; ????????:AIX?:[12].1:2) # AIX 2.2.1 or AIX 2.1.1 is RT/PC AIX. echo romp-ibm-aix # uname -m gives an 8 hex-code CPU id exit ;; # Note that: echo "'`uname -s`'" gives 'AIX ' i*86:AIX:*:*) echo i386-ibm-aix exit ;; ia64:AIX:*:*) if [ -x /usr/bin/oslevel ] ; then IBM_REV=`/usr/bin/oslevel` else IBM_REV=${UNAME_VERSION}.${UNAME_RELEASE} fi echo ${UNAME_MACHINE}-ibm-aix${IBM_REV} exit ;; *:AIX:2:3) if grep bos325 /usr/include/stdio.h >/dev/null 2>&1; then eval $set_cc_for_build sed 's/^ //' << EOF >$dummy.c #include main() { if (!__power_pc()) exit(1); puts("powerpc-ibm-aix3.2.5"); exit(0); } EOF if $CC_FOR_BUILD -o $dummy $dummy.c && SYSTEM_NAME=`$dummy` then echo "$SYSTEM_NAME" else echo rs6000-ibm-aix3.2.5 fi elif grep bos324 /usr/include/stdio.h >/dev/null 2>&1; then echo rs6000-ibm-aix3.2.4 else echo rs6000-ibm-aix3.2 fi exit ;; *:AIX:*:[4567]) IBM_CPU_ID=`/usr/sbin/lsdev -C -c processor -S available | sed 1q | awk '{ print $1 }'` if /usr/sbin/lsattr -El ${IBM_CPU_ID} | grep ' POWER' >/dev/null 2>&1; then IBM_ARCH=rs6000 else IBM_ARCH=powerpc fi if [ -x /usr/bin/lslpp ] ; then IBM_REV=`/usr/bin/lslpp -Lqc bos.rte.libc | awk -F: '{ print $3 }' | sed s/[0-9]*$/0/` else IBM_REV=${UNAME_VERSION}.${UNAME_RELEASE} fi echo ${IBM_ARCH}-ibm-aix${IBM_REV} exit ;; *:AIX:*:*) echo rs6000-ibm-aix exit ;; ibmrt:4.4BSD:*|romp-ibm:BSD:*) echo romp-ibm-bsd4.4 exit ;; ibmrt:*BSD:*|romp-ibm:BSD:*) # covers RT/PC BSD and echo romp-ibm-bsd${UNAME_RELEASE} # 4.3 with uname added to exit ;; # report: romp-ibm BSD 4.3 *:BOSX:*:*) echo rs6000-bull-bosx exit ;; DPX/2?00:B.O.S.:*:*) echo m68k-bull-sysv3 exit ;; 9000/[34]??:4.3bsd:1.*:*) echo m68k-hp-bsd exit ;; hp300:4.4BSD:*:* | 9000/[34]??:4.3bsd:2.*:*) echo m68k-hp-bsd4.4 exit ;; 9000/[34678]??:HP-UX:*:*) HPUX_REV=`echo ${UNAME_RELEASE}|sed -e 's/[^.]*.[0B]*//'` case "${UNAME_MACHINE}" in 9000/31? ) HP_ARCH=m68000 ;; 9000/[34]?? ) HP_ARCH=m68k ;; 9000/[678][0-9][0-9]) if [ -x /usr/bin/getconf ]; then sc_cpu_version=`/usr/bin/getconf SC_CPU_VERSION 2>/dev/null` sc_kernel_bits=`/usr/bin/getconf SC_KERNEL_BITS 2>/dev/null` case "${sc_cpu_version}" in 523) HP_ARCH="hppa1.0" ;; # CPU_PA_RISC1_0 528) HP_ARCH="hppa1.1" ;; # CPU_PA_RISC1_1 532) # CPU_PA_RISC2_0 case "${sc_kernel_bits}" in 32) HP_ARCH="hppa2.0n" ;; 64) HP_ARCH="hppa2.0w" ;; '') HP_ARCH="hppa2.0" ;; # HP-UX 10.20 esac ;; esac fi if [ "${HP_ARCH}" = "" ]; then eval $set_cc_for_build sed 's/^ //' << EOF >$dummy.c #define _HPUX_SOURCE #include #include int main () { #if defined(_SC_KERNEL_BITS) long bits = sysconf(_SC_KERNEL_BITS); #endif long cpu = sysconf (_SC_CPU_VERSION); switch (cpu) { case CPU_PA_RISC1_0: puts ("hppa1.0"); break; case CPU_PA_RISC1_1: puts ("hppa1.1"); break; case CPU_PA_RISC2_0: #if defined(_SC_KERNEL_BITS) switch (bits) { case 64: puts ("hppa2.0w"); break; case 32: puts ("hppa2.0n"); break; default: puts ("hppa2.0"); break; } break; #else /* !defined(_SC_KERNEL_BITS) */ puts ("hppa2.0"); break; #endif default: puts ("hppa1.0"); break; } exit (0); } EOF (CCOPTS= $CC_FOR_BUILD -o $dummy $dummy.c 2>/dev/null) && HP_ARCH=`$dummy` test -z "$HP_ARCH" && HP_ARCH=hppa fi ;; esac if [ ${HP_ARCH} = "hppa2.0w" ] then eval $set_cc_for_build # hppa2.0w-hp-hpux* has a 64-bit kernel and a compiler generating # 32-bit code. hppa64-hp-hpux* has the same kernel and a compiler # generating 64-bit code. GNU and HP use different nomenclature: # # $ CC_FOR_BUILD=cc ./config.guess # => hppa2.0w-hp-hpux11.23 # $ CC_FOR_BUILD="cc +DA2.0w" ./config.guess # => hppa64-hp-hpux11.23 if echo __LP64__ | (CCOPTS= $CC_FOR_BUILD -E - 2>/dev/null) | grep -q __LP64__ then HP_ARCH="hppa2.0w" else HP_ARCH="hppa64" fi fi echo ${HP_ARCH}-hp-hpux${HPUX_REV} exit ;; ia64:HP-UX:*:*) HPUX_REV=`echo ${UNAME_RELEASE}|sed -e 's/[^.]*.[0B]*//'` echo ia64-hp-hpux${HPUX_REV} exit ;; 3050*:HI-UX:*:*) eval $set_cc_for_build sed 's/^ //' << EOF >$dummy.c #include int main () { long cpu = sysconf (_SC_CPU_VERSION); /* The order matters, because CPU_IS_HP_MC68K erroneously returns true for CPU_PA_RISC1_0. CPU_IS_PA_RISC returns correct results, however. */ if (CPU_IS_PA_RISC (cpu)) { switch (cpu) { case CPU_PA_RISC1_0: puts ("hppa1.0-hitachi-hiuxwe2"); break; case CPU_PA_RISC1_1: puts ("hppa1.1-hitachi-hiuxwe2"); break; case CPU_PA_RISC2_0: puts ("hppa2.0-hitachi-hiuxwe2"); break; default: puts ("hppa-hitachi-hiuxwe2"); break; } } else if (CPU_IS_HP_MC68K (cpu)) puts ("m68k-hitachi-hiuxwe2"); else puts ("unknown-hitachi-hiuxwe2"); exit (0); } EOF $CC_FOR_BUILD -o $dummy $dummy.c && SYSTEM_NAME=`$dummy` && { echo "$SYSTEM_NAME"; exit; } echo unknown-hitachi-hiuxwe2 exit ;; 9000/7??:4.3bsd:*:* | 9000/8?[79]:4.3bsd:*:* ) echo hppa1.1-hp-bsd exit ;; 9000/8??:4.3bsd:*:*) echo hppa1.0-hp-bsd exit ;; *9??*:MPE/iX:*:* | *3000*:MPE/iX:*:*) echo hppa1.0-hp-mpeix exit ;; hp7??:OSF1:*:* | hp8?[79]:OSF1:*:* ) echo hppa1.1-hp-osf exit ;; hp8??:OSF1:*:*) echo hppa1.0-hp-osf exit ;; i*86:OSF1:*:*) if [ -x /usr/sbin/sysversion ] ; then echo ${UNAME_MACHINE}-unknown-osf1mk else echo ${UNAME_MACHINE}-unknown-osf1 fi exit ;; parisc*:Lites*:*:*) echo hppa1.1-hp-lites exit ;; C1*:ConvexOS:*:* | convex:ConvexOS:C1*:*) echo c1-convex-bsd exit ;; C2*:ConvexOS:*:* | convex:ConvexOS:C2*:*) if getsysinfo -f scalar_acc then echo c32-convex-bsd else echo c2-convex-bsd fi exit ;; C34*:ConvexOS:*:* | convex:ConvexOS:C34*:*) echo c34-convex-bsd exit ;; C38*:ConvexOS:*:* | convex:ConvexOS:C38*:*) echo c38-convex-bsd exit ;; C4*:ConvexOS:*:* | convex:ConvexOS:C4*:*) echo c4-convex-bsd exit ;; CRAY*Y-MP:*:*:*) echo ymp-cray-unicos${UNAME_RELEASE} | sed -e 's/\.[^.]*$/.X/' exit ;; CRAY*[A-Z]90:*:*:*) echo ${UNAME_MACHINE}-cray-unicos${UNAME_RELEASE} \ | sed -e 's/CRAY.*\([A-Z]90\)/\1/' \ -e y/ABCDEFGHIJKLMNOPQRSTUVWXYZ/abcdefghijklmnopqrstuvwxyz/ \ -e 's/\.[^.]*$/.X/' exit ;; CRAY*TS:*:*:*) echo t90-cray-unicos${UNAME_RELEASE} | sed -e 's/\.[^.]*$/.X/' exit ;; CRAY*T3E:*:*:*) echo alphaev5-cray-unicosmk${UNAME_RELEASE} | sed -e 's/\.[^.]*$/.X/' exit ;; CRAY*SV1:*:*:*) echo sv1-cray-unicos${UNAME_RELEASE} | sed -e 's/\.[^.]*$/.X/' exit ;; *:UNICOS/mp:*:*) echo craynv-cray-unicosmp${UNAME_RELEASE} | sed -e 's/\.[^.]*$/.X/' exit ;; F30[01]:UNIX_System_V:*:* | F700:UNIX_System_V:*:*) FUJITSU_PROC=`uname -m | tr 'ABCDEFGHIJKLMNOPQRSTUVWXYZ' 'abcdefghijklmnopqrstuvwxyz'` FUJITSU_SYS=`uname -p | tr 'ABCDEFGHIJKLMNOPQRSTUVWXYZ' 'abcdefghijklmnopqrstuvwxyz' | sed -e 's/\///'` FUJITSU_REL=`echo ${UNAME_RELEASE} | sed -e 's/ /_/'` echo "${FUJITSU_PROC}-fujitsu-${FUJITSU_SYS}${FUJITSU_REL}" exit ;; 5000:UNIX_System_V:4.*:*) FUJITSU_SYS=`uname -p | tr 'ABCDEFGHIJKLMNOPQRSTUVWXYZ' 'abcdefghijklmnopqrstuvwxyz' | sed -e 's/\///'` FUJITSU_REL=`echo ${UNAME_RELEASE} | tr 'ABCDEFGHIJKLMNOPQRSTUVWXYZ' 'abcdefghijklmnopqrstuvwxyz' | sed -e 's/ /_/'` echo "sparc-fujitsu-${FUJITSU_SYS}${FUJITSU_REL}" exit ;; i*86:BSD/386:*:* | i*86:BSD/OS:*:* | *:Ascend\ Embedded/OS:*:*) echo ${UNAME_MACHINE}-pc-bsdi${UNAME_RELEASE} exit ;; sparc*:BSD/OS:*:*) echo sparc-unknown-bsdi${UNAME_RELEASE} exit ;; *:BSD/OS:*:*) echo ${UNAME_MACHINE}-unknown-bsdi${UNAME_RELEASE} exit ;; *:FreeBSD:*:*) UNAME_PROCESSOR=`/usr/bin/uname -p` echo ${UNAME_PROCESSOR}-unknown-freebsd`echo ${UNAME_RELEASE}|sed -e 's/[-(].*//'` exit ;; i*:CYGWIN*:*) echo ${UNAME_MACHINE}-pc-cygwin exit ;; *:MINGW64*:*) echo ${UNAME_MACHINE}-pc-mingw64 exit ;; *:MINGW*:*) echo ${UNAME_MACHINE}-pc-mingw32 exit ;; *:MSYS*:*) echo ${UNAME_MACHINE}-pc-msys exit ;; i*:windows32*:*) # uname -m includes "-pc" on this system. echo ${UNAME_MACHINE}-mingw32 exit ;; i*:PW*:*) echo ${UNAME_MACHINE}-pc-pw32 exit ;; *:Interix*:*) case ${UNAME_MACHINE} in x86) echo i586-pc-interix${UNAME_RELEASE} exit ;; authenticamd | genuineintel | EM64T) echo x86_64-unknown-interix${UNAME_RELEASE} exit ;; IA64) echo ia64-unknown-interix${UNAME_RELEASE} exit ;; esac ;; [345]86:Windows_95:* | [345]86:Windows_98:* | [345]86:Windows_NT:*) echo i${UNAME_MACHINE}-pc-mks exit ;; 8664:Windows_NT:*) echo x86_64-pc-mks exit ;; i*:Windows_NT*:* | Pentium*:Windows_NT*:*) # How do we know it's Interix rather than the generic POSIX subsystem? # It also conflicts with pre-2.0 versions of AT&T UWIN. Should we # UNAME_MACHINE based on the output of uname instead of i386? echo i586-pc-interix exit ;; i*:UWIN*:*) echo ${UNAME_MACHINE}-pc-uwin exit ;; amd64:CYGWIN*:*:* | x86_64:CYGWIN*:*:*) echo x86_64-unknown-cygwin exit ;; p*:CYGWIN*:*) echo powerpcle-unknown-cygwin exit ;; prep*:SunOS:5.*:*) echo powerpcle-unknown-solaris2`echo ${UNAME_RELEASE}|sed -e 's/[^.]*//'` exit ;; *:GNU:*:*) # the GNU system echo `echo ${UNAME_MACHINE}|sed -e 's,[-/].*$,,'`-unknown-${LIBC}`echo ${UNAME_RELEASE}|sed -e 's,/.*$,,'` exit ;; *:GNU/*:*:*) # other systems with GNU libc and userland echo ${UNAME_MACHINE}-unknown-`echo ${UNAME_SYSTEM} | sed 's,^[^/]*/,,' | tr '[A-Z]' '[a-z]'``echo ${UNAME_RELEASE}|sed -e 's/[-(].*//'`-${LIBC} exit ;; i*86:Minix:*:*) echo ${UNAME_MACHINE}-pc-minix exit ;; aarch64:Linux:*:*) echo ${UNAME_MACHINE}-unknown-linux-${LIBC} exit ;; aarch64_be:Linux:*:*) UNAME_MACHINE=aarch64_be echo ${UNAME_MACHINE}-unknown-linux-${LIBC} exit ;; alpha:Linux:*:*) case `sed -n '/^cpu model/s/^.*: \(.*\)/\1/p' < /proc/cpuinfo` in EV5) UNAME_MACHINE=alphaev5 ;; EV56) UNAME_MACHINE=alphaev56 ;; PCA56) UNAME_MACHINE=alphapca56 ;; PCA57) UNAME_MACHINE=alphapca56 ;; EV6) UNAME_MACHINE=alphaev6 ;; EV67) UNAME_MACHINE=alphaev67 ;; EV68*) UNAME_MACHINE=alphaev68 ;; esac objdump --private-headers /bin/sh | grep -q ld.so.1 if test "$?" = 0 ; then LIBC="gnulibc1" ; fi echo ${UNAME_MACHINE}-unknown-linux-${LIBC} exit ;; arc:Linux:*:* | arceb:Linux:*:*) echo ${UNAME_MACHINE}-unknown-linux-${LIBC} exit ;; arm*:Linux:*:*) eval $set_cc_for_build if echo __ARM_EABI__ | $CC_FOR_BUILD -E - 2>/dev/null \ | grep -q __ARM_EABI__ then echo ${UNAME_MACHINE}-unknown-linux-${LIBC} else if echo __ARM_PCS_VFP | $CC_FOR_BUILD -E - 2>/dev/null \ | grep -q __ARM_PCS_VFP then echo ${UNAME_MACHINE}-unknown-linux-${LIBC}eabi else echo ${UNAME_MACHINE}-unknown-linux-${LIBC}eabihf fi fi exit ;; avr32*:Linux:*:*) echo ${UNAME_MACHINE}-unknown-linux-${LIBC} exit ;; cris:Linux:*:*) echo ${UNAME_MACHINE}-axis-linux-${LIBC} exit ;; crisv32:Linux:*:*) echo ${UNAME_MACHINE}-axis-linux-${LIBC} exit ;; e2k:Linux:*:*) echo ${UNAME_MACHINE}-unknown-linux-${LIBC} exit ;; frv:Linux:*:*) echo ${UNAME_MACHINE}-unknown-linux-${LIBC} exit ;; hexagon:Linux:*:*) echo ${UNAME_MACHINE}-unknown-linux-${LIBC} exit ;; i*86:Linux:*:*) echo ${UNAME_MACHINE}-pc-linux-${LIBC} exit ;; ia64:Linux:*:*) echo ${UNAME_MACHINE}-unknown-linux-${LIBC} exit ;; m32r*:Linux:*:*) echo ${UNAME_MACHINE}-unknown-linux-${LIBC} exit ;; m68*:Linux:*:*) echo ${UNAME_MACHINE}-unknown-linux-${LIBC} exit ;; mips:Linux:*:* | mips64:Linux:*:*) eval $set_cc_for_build sed 's/^ //' << EOF >$dummy.c #undef CPU #undef ${UNAME_MACHINE} #undef ${UNAME_MACHINE}el #if defined(__MIPSEL__) || defined(__MIPSEL) || defined(_MIPSEL) || defined(MIPSEL) CPU=${UNAME_MACHINE}el #else #if defined(__MIPSEB__) || defined(__MIPSEB) || defined(_MIPSEB) || defined(MIPSEB) CPU=${UNAME_MACHINE} #else CPU= #endif #endif EOF eval `$CC_FOR_BUILD -E $dummy.c 2>/dev/null | grep '^CPU'` test x"${CPU}" != x && { echo "${CPU}-unknown-linux-${LIBC}"; exit; } ;; openrisc*:Linux:*:*) echo or1k-unknown-linux-${LIBC} exit ;; or32:Linux:*:* | or1k*:Linux:*:*) echo ${UNAME_MACHINE}-unknown-linux-${LIBC} exit ;; padre:Linux:*:*) echo sparc-unknown-linux-${LIBC} exit ;; parisc64:Linux:*:* | hppa64:Linux:*:*) echo hppa64-unknown-linux-${LIBC} exit ;; parisc:Linux:*:* | hppa:Linux:*:*) # Look for CPU level case `grep '^cpu[^a-z]*:' /proc/cpuinfo 2>/dev/null | cut -d' ' -f2` in PA7*) echo hppa1.1-unknown-linux-${LIBC} ;; PA8*) echo hppa2.0-unknown-linux-${LIBC} ;; *) echo hppa-unknown-linux-${LIBC} ;; esac exit ;; ppc64:Linux:*:*) echo powerpc64-unknown-linux-${LIBC} exit ;; ppc:Linux:*:*) echo powerpc-unknown-linux-${LIBC} exit ;; ppc64le:Linux:*:*) echo powerpc64le-unknown-linux-${LIBC} exit ;; ppcle:Linux:*:*) echo powerpcle-unknown-linux-${LIBC} exit ;; s390:Linux:*:* | s390x:Linux:*:*) echo ${UNAME_MACHINE}-ibm-linux-${LIBC} exit ;; sh64*:Linux:*:*) echo ${UNAME_MACHINE}-unknown-linux-${LIBC} exit ;; sh*:Linux:*:*) echo ${UNAME_MACHINE}-unknown-linux-${LIBC} exit ;; sparc:Linux:*:* | sparc64:Linux:*:*) echo ${UNAME_MACHINE}-unknown-linux-${LIBC} exit ;; tile*:Linux:*:*) echo ${UNAME_MACHINE}-unknown-linux-${LIBC} exit ;; vax:Linux:*:*) echo ${UNAME_MACHINE}-dec-linux-${LIBC} exit ;; x86_64:Linux:*:*) echo ${UNAME_MACHINE}-unknown-linux-${LIBC} exit ;; xtensa*:Linux:*:*) echo ${UNAME_MACHINE}-unknown-linux-${LIBC} exit ;; i*86:DYNIX/ptx:4*:*) # ptx 4.0 does uname -s correctly, with DYNIX/ptx in there. # earlier versions are messed up and put the nodename in both # sysname and nodename. echo i386-sequent-sysv4 exit ;; i*86:UNIX_SV:4.2MP:2.*) # Unixware is an offshoot of SVR4, but it has its own version # number series starting with 2... # I am not positive that other SVR4 systems won't match this, # I just have to hope. -- rms. # Use sysv4.2uw... so that sysv4* matches it. echo ${UNAME_MACHINE}-pc-sysv4.2uw${UNAME_VERSION} exit ;; i*86:OS/2:*:*) # If we were able to find `uname', then EMX Unix compatibility # is probably installed. echo ${UNAME_MACHINE}-pc-os2-emx exit ;; i*86:XTS-300:*:STOP) echo ${UNAME_MACHINE}-unknown-stop exit ;; i*86:atheos:*:*) echo ${UNAME_MACHINE}-unknown-atheos exit ;; i*86:syllable:*:*) echo ${UNAME_MACHINE}-pc-syllable exit ;; i*86:LynxOS:2.*:* | i*86:LynxOS:3.[01]*:* | i*86:LynxOS:4.[02]*:*) echo i386-unknown-lynxos${UNAME_RELEASE} exit ;; i*86:*DOS:*:*) echo ${UNAME_MACHINE}-pc-msdosdjgpp exit ;; i*86:*:4.*:* | i*86:SYSTEM_V:4.*:*) UNAME_REL=`echo ${UNAME_RELEASE} | sed 's/\/MP$//'` if grep Novell /usr/include/link.h >/dev/null 2>/dev/null; then echo ${UNAME_MACHINE}-univel-sysv${UNAME_REL} else echo ${UNAME_MACHINE}-pc-sysv${UNAME_REL} fi exit ;; i*86:*:5:[678]*) # UnixWare 7.x, OpenUNIX and OpenServer 6. case `/bin/uname -X | grep "^Machine"` in *486*) UNAME_MACHINE=i486 ;; *Pentium) UNAME_MACHINE=i586 ;; *Pent*|*Celeron) UNAME_MACHINE=i686 ;; esac echo ${UNAME_MACHINE}-unknown-sysv${UNAME_RELEASE}${UNAME_SYSTEM}${UNAME_VERSION} exit ;; i*86:*:3.2:*) if test -f /usr/options/cb.name; then UNAME_REL=`sed -n 's/.*Version //p' /dev/null >/dev/null ; then UNAME_REL=`(/bin/uname -X|grep Release|sed -e 's/.*= //')` (/bin/uname -X|grep i80486 >/dev/null) && UNAME_MACHINE=i486 (/bin/uname -X|grep '^Machine.*Pentium' >/dev/null) \ && UNAME_MACHINE=i586 (/bin/uname -X|grep '^Machine.*Pent *II' >/dev/null) \ && UNAME_MACHINE=i686 (/bin/uname -X|grep '^Machine.*Pentium Pro' >/dev/null) \ && UNAME_MACHINE=i686 echo ${UNAME_MACHINE}-pc-sco$UNAME_REL else echo ${UNAME_MACHINE}-pc-sysv32 fi exit ;; pc:*:*:*) # Left here for compatibility: # uname -m prints for DJGPP always 'pc', but it prints nothing about # the processor, so we play safe by assuming i586. # Note: whatever this is, it MUST be the same as what config.sub # prints for the "djgpp" host, or else GDB configury will decide that # this is a cross-build. echo i586-pc-msdosdjgpp exit ;; Intel:Mach:3*:*) echo i386-pc-mach3 exit ;; paragon:*:*:*) echo i860-intel-osf1 exit ;; i860:*:4.*:*) # i860-SVR4 if grep Stardent /usr/include/sys/uadmin.h >/dev/null 2>&1 ; then echo i860-stardent-sysv${UNAME_RELEASE} # Stardent Vistra i860-SVR4 else # Add other i860-SVR4 vendors below as they are discovered. echo i860-unknown-sysv${UNAME_RELEASE} # Unknown i860-SVR4 fi exit ;; mini*:CTIX:SYS*5:*) # "miniframe" echo m68010-convergent-sysv exit ;; mc68k:UNIX:SYSTEM5:3.51m) echo m68k-convergent-sysv exit ;; M680?0:D-NIX:5.3:*) echo m68k-diab-dnix exit ;; M68*:*:R3V[5678]*:*) test -r /sysV68 && { echo 'm68k-motorola-sysv'; exit; } ;; 3[345]??:*:4.0:3.0 | 3[34]??A:*:4.0:3.0 | 3[34]??,*:*:4.0:3.0 | 3[34]??/*:*:4.0:3.0 | 4400:*:4.0:3.0 | 4850:*:4.0:3.0 | SKA40:*:4.0:3.0 | SDS2:*:4.0:3.0 | SHG2:*:4.0:3.0 | S7501*:*:4.0:3.0) OS_REL='' test -r /etc/.relid \ && OS_REL=.`sed -n 's/[^ ]* [^ ]* \([0-9][0-9]\).*/\1/p' < /etc/.relid` /bin/uname -p 2>/dev/null | grep 86 >/dev/null \ && { echo i486-ncr-sysv4.3${OS_REL}; exit; } /bin/uname -p 2>/dev/null | /bin/grep entium >/dev/null \ && { echo i586-ncr-sysv4.3${OS_REL}; exit; } ;; 3[34]??:*:4.0:* | 3[34]??,*:*:4.0:*) /bin/uname -p 2>/dev/null | grep 86 >/dev/null \ && { echo i486-ncr-sysv4; exit; } ;; NCR*:*:4.2:* | MPRAS*:*:4.2:*) OS_REL='.3' test -r /etc/.relid \ && OS_REL=.`sed -n 's/[^ ]* [^ ]* \([0-9][0-9]\).*/\1/p' < /etc/.relid` /bin/uname -p 2>/dev/null | grep 86 >/dev/null \ && { echo i486-ncr-sysv4.3${OS_REL}; exit; } /bin/uname -p 2>/dev/null | /bin/grep entium >/dev/null \ && { echo i586-ncr-sysv4.3${OS_REL}; exit; } /bin/uname -p 2>/dev/null | /bin/grep pteron >/dev/null \ && { echo i586-ncr-sysv4.3${OS_REL}; exit; } ;; m68*:LynxOS:2.*:* | m68*:LynxOS:3.0*:*) echo m68k-unknown-lynxos${UNAME_RELEASE} exit ;; mc68030:UNIX_System_V:4.*:*) echo m68k-atari-sysv4 exit ;; TSUNAMI:LynxOS:2.*:*) echo sparc-unknown-lynxos${UNAME_RELEASE} exit ;; rs6000:LynxOS:2.*:*) echo rs6000-unknown-lynxos${UNAME_RELEASE} exit ;; PowerPC:LynxOS:2.*:* | PowerPC:LynxOS:3.[01]*:* | PowerPC:LynxOS:4.[02]*:*) echo powerpc-unknown-lynxos${UNAME_RELEASE} exit ;; SM[BE]S:UNIX_SV:*:*) echo mips-dde-sysv${UNAME_RELEASE} exit ;; RM*:ReliantUNIX-*:*:*) echo mips-sni-sysv4 exit ;; RM*:SINIX-*:*:*) echo mips-sni-sysv4 exit ;; *:SINIX-*:*:*) if uname -p 2>/dev/null >/dev/null ; then UNAME_MACHINE=`(uname -p) 2>/dev/null` echo ${UNAME_MACHINE}-sni-sysv4 else echo ns32k-sni-sysv fi exit ;; PENTIUM:*:4.0*:*) # Unisys `ClearPath HMP IX 4000' SVR4/MP effort # says echo i586-unisys-sysv4 exit ;; *:UNIX_System_V:4*:FTX*) # From Gerald Hewes . # How about differentiating between stratus architectures? -djm echo hppa1.1-stratus-sysv4 exit ;; *:*:*:FTX*) # From seanf@swdc.stratus.com. echo i860-stratus-sysv4 exit ;; i*86:VOS:*:*) # From Paul.Green@stratus.com. echo ${UNAME_MACHINE}-stratus-vos exit ;; *:VOS:*:*) # From Paul.Green@stratus.com. echo hppa1.1-stratus-vos exit ;; mc68*:A/UX:*:*) echo m68k-apple-aux${UNAME_RELEASE} exit ;; news*:NEWS-OS:6*:*) echo mips-sony-newsos6 exit ;; R[34]000:*System_V*:*:* | R4000:UNIX_SYSV:*:* | R*000:UNIX_SV:*:*) if [ -d /usr/nec ]; then echo mips-nec-sysv${UNAME_RELEASE} else echo mips-unknown-sysv${UNAME_RELEASE} fi exit ;; BeBox:BeOS:*:*) # BeOS running on hardware made by Be, PPC only. echo powerpc-be-beos exit ;; BeMac:BeOS:*:*) # BeOS running on Mac or Mac clone, PPC only. echo powerpc-apple-beos exit ;; BePC:BeOS:*:*) # BeOS running on Intel PC compatible. echo i586-pc-beos exit ;; BePC:Haiku:*:*) # Haiku running on Intel PC compatible. echo i586-pc-haiku exit ;; x86_64:Haiku:*:*) echo x86_64-unknown-haiku exit ;; SX-4:SUPER-UX:*:*) echo sx4-nec-superux${UNAME_RELEASE} exit ;; SX-5:SUPER-UX:*:*) echo sx5-nec-superux${UNAME_RELEASE} exit ;; SX-6:SUPER-UX:*:*) echo sx6-nec-superux${UNAME_RELEASE} exit ;; SX-7:SUPER-UX:*:*) echo sx7-nec-superux${UNAME_RELEASE} exit ;; SX-8:SUPER-UX:*:*) echo sx8-nec-superux${UNAME_RELEASE} exit ;; SX-8R:SUPER-UX:*:*) echo sx8r-nec-superux${UNAME_RELEASE} exit ;; Power*:Rhapsody:*:*) echo powerpc-apple-rhapsody${UNAME_RELEASE} exit ;; *:Rhapsody:*:*) echo ${UNAME_MACHINE}-apple-rhapsody${UNAME_RELEASE} exit ;; *:Darwin:*:*) UNAME_PROCESSOR=`uname -p` || UNAME_PROCESSOR=unknown eval $set_cc_for_build if test "$UNAME_PROCESSOR" = unknown ; then UNAME_PROCESSOR=powerpc fi if test `echo "$UNAME_RELEASE" | sed -e 's/\..*//'` -le 10 ; then if [ "$CC_FOR_BUILD" != 'no_compiler_found' ]; then if (echo '#ifdef __LP64__'; echo IS_64BIT_ARCH; echo '#endif') | \ (CCOPTS= $CC_FOR_BUILD -E - 2>/dev/null) | \ grep IS_64BIT_ARCH >/dev/null then case $UNAME_PROCESSOR in i386) UNAME_PROCESSOR=x86_64 ;; powerpc) UNAME_PROCESSOR=powerpc64 ;; esac fi fi elif test "$UNAME_PROCESSOR" = i386 ; then # Avoid executing cc on OS X 10.9, as it ships with a stub # that puts up a graphical alert prompting to install # developer tools. Any system running Mac OS X 10.7 or # later (Darwin 11 and later) is required to have a 64-bit # processor. This is not true of the ARM version of Darwin # that Apple uses in portable devices. UNAME_PROCESSOR=x86_64 fi echo ${UNAME_PROCESSOR}-apple-darwin${UNAME_RELEASE} exit ;; *:procnto*:*:* | *:QNX:[0123456789]*:*) UNAME_PROCESSOR=`uname -p` if test "$UNAME_PROCESSOR" = "x86"; then UNAME_PROCESSOR=i386 UNAME_MACHINE=pc fi echo ${UNAME_PROCESSOR}-${UNAME_MACHINE}-nto-qnx${UNAME_RELEASE} exit ;; *:QNX:*:4*) echo i386-pc-qnx exit ;; NEO-?:NONSTOP_KERNEL:*:*) echo neo-tandem-nsk${UNAME_RELEASE} exit ;; NSE-*:NONSTOP_KERNEL:*:*) echo nse-tandem-nsk${UNAME_RELEASE} exit ;; NSR-?:NONSTOP_KERNEL:*:*) echo nsr-tandem-nsk${UNAME_RELEASE} exit ;; *:NonStop-UX:*:*) echo mips-compaq-nonstopux exit ;; BS2000:POSIX*:*:*) echo bs2000-siemens-sysv exit ;; DS/*:UNIX_System_V:*:*) echo ${UNAME_MACHINE}-${UNAME_SYSTEM}-${UNAME_RELEASE} exit ;; *:Plan9:*:*) # "uname -m" is not consistent, so use $cputype instead. 386 # is converted to i386 for consistency with other x86 # operating systems. if test "$cputype" = "386"; then UNAME_MACHINE=i386 else UNAME_MACHINE="$cputype" fi echo ${UNAME_MACHINE}-unknown-plan9 exit ;; *:TOPS-10:*:*) echo pdp10-unknown-tops10 exit ;; *:TENEX:*:*) echo pdp10-unknown-tenex exit ;; KS10:TOPS-20:*:* | KL10:TOPS-20:*:* | TYPE4:TOPS-20:*:*) echo pdp10-dec-tops20 exit ;; XKL-1:TOPS-20:*:* | TYPE5:TOPS-20:*:*) echo pdp10-xkl-tops20 exit ;; *:TOPS-20:*:*) echo pdp10-unknown-tops20 exit ;; *:ITS:*:*) echo pdp10-unknown-its exit ;; SEI:*:*:SEIUX) echo mips-sei-seiux${UNAME_RELEASE} exit ;; *:DragonFly:*:*) echo ${UNAME_MACHINE}-unknown-dragonfly`echo ${UNAME_RELEASE}|sed -e 's/[-(].*//'` exit ;; *:*VMS:*:*) UNAME_MACHINE=`(uname -p) 2>/dev/null` case "${UNAME_MACHINE}" in A*) echo alpha-dec-vms ; exit ;; I*) echo ia64-dec-vms ; exit ;; V*) echo vax-dec-vms ; exit ;; esac ;; *:XENIX:*:SysV) echo i386-pc-xenix exit ;; i*86:skyos:*:*) echo ${UNAME_MACHINE}-pc-skyos`echo ${UNAME_RELEASE}` | sed -e 's/ .*$//' exit ;; i*86:rdos:*:*) echo ${UNAME_MACHINE}-pc-rdos exit ;; i*86:AROS:*:*) echo ${UNAME_MACHINE}-pc-aros exit ;; x86_64:VMkernel:*:*) echo ${UNAME_MACHINE}-unknown-esx exit ;; esac cat >&2 < in order to provide the needed information to handle your system. config.guess timestamp = $timestamp uname -m = `(uname -m) 2>/dev/null || echo unknown` uname -r = `(uname -r) 2>/dev/null || echo unknown` uname -s = `(uname -s) 2>/dev/null || echo unknown` uname -v = `(uname -v) 2>/dev/null || echo unknown` /usr/bin/uname -p = `(/usr/bin/uname -p) 2>/dev/null` /bin/uname -X = `(/bin/uname -X) 2>/dev/null` hostinfo = `(hostinfo) 2>/dev/null` /bin/universe = `(/bin/universe) 2>/dev/null` /usr/bin/arch -k = `(/usr/bin/arch -k) 2>/dev/null` /bin/arch = `(/bin/arch) 2>/dev/null` /usr/bin/oslevel = `(/usr/bin/oslevel) 2>/dev/null` /usr/convex/getsysinfo = `(/usr/convex/getsysinfo) 2>/dev/null` UNAME_MACHINE = ${UNAME_MACHINE} UNAME_RELEASE = ${UNAME_RELEASE} UNAME_SYSTEM = ${UNAME_SYSTEM} UNAME_VERSION = ${UNAME_VERSION} EOF exit 1 # Local variables: # eval: (add-hook 'write-file-hooks 'time-stamp) # time-stamp-start: "timestamp='" # time-stamp-format: "%:y-%02m-%02d" # time-stamp-end: "'" # End: xrdp-0.9.5/libpainter/README000644 001751 001751 00000000000 13017426060 015420 0ustar00metameta000000 000000 xrdp-0.9.5/libpainter/tests/000755 001751 001751 00000000000 13220731017 015711 5ustar00metameta000000 000000 xrdp-0.9.5/libpainter/ChangeLog000644 001751 001751 00000000000 13017426060 016312 0ustar00metameta000000 000000 xrdp-0.9.5/libpainter/Makefile.am000644 001751 001751 00000000245 13127342056 016613 0ustar00metameta000000 000000 ACLOCAL_AMFLAGS = -I m4 EXTRA_DIST = bootstrap EXTRA_DIRS = if PT_TESTS EXTRA_DIRS += tests endif SUBDIRS = \ src \ include \ pkgconfig \ $(EXTRA_DIRS) xrdp-0.9.5/libpainter/pkgconfig/000755 001751 001751 00000000000 13220731016 016515 5ustar00metameta000000 000000 xrdp-0.9.5/libpainter/NEWS000644 001751 001751 00000000000 13017426060 015237 0ustar00metameta000000 000000 xrdp-0.9.5/libpainter/bootstrap000755 001751 001751 00000000605 13035113356 016517 0ustar00metameta000000 000000 #!/bin/sh which autoconf if ! test $? -eq 0 then echo "error, install autoconf" exit 1 fi which automake if ! test $? -eq 0 then echo "error, install automake" exit 1 fi which libtool || which libtoolize if ! test $? -eq 0 then echo "error, install libtool" exit 1 fi which pkg-config if ! test $? -eq 0 then echo "error, install pkg-config" exit 1 fi autoreconf -fvi xrdp-0.9.5/libpainter/aclocal.m4000644 001751 001751 00000123026 13220730737 016423 0ustar00metameta000000 000000 # generated automatically by aclocal 1.15.1 -*- Autoconf -*- # Copyright (C) 1996-2017 Free Software Foundation, Inc. # This file is free software; the Free Software Foundation # gives unlimited permission to copy and/or distribute it, # with or without modifications, as long as this notice is preserved. # This program is distributed in the hope that it will be useful, # but WITHOUT ANY WARRANTY, to the extent permitted by law; without # even the implied warranty of MERCHANTABILITY or FITNESS FOR A # PARTICULAR PURPOSE. m4_ifndef([AC_CONFIG_MACRO_DIRS], [m4_defun([_AM_CONFIG_MACRO_DIRS], [])m4_defun([AC_CONFIG_MACRO_DIRS], [_AM_CONFIG_MACRO_DIRS($@)])]) m4_ifndef([AC_AUTOCONF_VERSION], [m4_copy([m4_PACKAGE_VERSION], [AC_AUTOCONF_VERSION])])dnl m4_if(m4_defn([AC_AUTOCONF_VERSION]), [2.69],, [m4_warning([this file was generated for autoconf 2.69. You have another version of autoconf. It may work, but is not guaranteed to. If you have problems, you may need to regenerate the build system entirely. To do so, use the procedure documented by the package, typically 'autoreconf'.])]) # Copyright (C) 2002-2017 Free Software Foundation, Inc. # # This file is free software; the Free Software Foundation # gives unlimited permission to copy and/or distribute it, # with or without modifications, as long as this notice is preserved. # AM_AUTOMAKE_VERSION(VERSION) # ---------------------------- # Automake X.Y traces this macro to ensure aclocal.m4 has been # generated from the m4 files accompanying Automake X.Y. # (This private macro should not be called outside this file.) AC_DEFUN([AM_AUTOMAKE_VERSION], [am__api_version='1.15' dnl Some users find AM_AUTOMAKE_VERSION and mistake it for a way to dnl require some minimum version. Point them to the right macro. m4_if([$1], [1.15.1], [], [AC_FATAL([Do not call $0, use AM_INIT_AUTOMAKE([$1]).])])dnl ]) # _AM_AUTOCONF_VERSION(VERSION) # ----------------------------- # aclocal traces this macro to find the Autoconf version. # This is a private macro too. Using m4_define simplifies # the logic in aclocal, which can simply ignore this definition. m4_define([_AM_AUTOCONF_VERSION], []) # AM_SET_CURRENT_AUTOMAKE_VERSION # ------------------------------- # Call AM_AUTOMAKE_VERSION and AM_AUTOMAKE_VERSION so they can be traced. # This function is AC_REQUIREd by AM_INIT_AUTOMAKE. AC_DEFUN([AM_SET_CURRENT_AUTOMAKE_VERSION], [AM_AUTOMAKE_VERSION([1.15.1])dnl m4_ifndef([AC_AUTOCONF_VERSION], [m4_copy([m4_PACKAGE_VERSION], [AC_AUTOCONF_VERSION])])dnl _AM_AUTOCONF_VERSION(m4_defn([AC_AUTOCONF_VERSION]))]) # AM_AUX_DIR_EXPAND -*- Autoconf -*- # Copyright (C) 2001-2017 Free Software Foundation, Inc. # # This file is free software; the Free Software Foundation # gives unlimited permission to copy and/or distribute it, # with or without modifications, as long as this notice is preserved. # For projects using AC_CONFIG_AUX_DIR([foo]), Autoconf sets # $ac_aux_dir to '$srcdir/foo'. In other projects, it is set to # '$srcdir', '$srcdir/..', or '$srcdir/../..'. # # Of course, Automake must honor this variable whenever it calls a # tool from the auxiliary directory. The problem is that $srcdir (and # therefore $ac_aux_dir as well) can be either absolute or relative, # depending on how configure is run. This is pretty annoying, since # it makes $ac_aux_dir quite unusable in subdirectories: in the top # source directory, any form will work fine, but in subdirectories a # relative path needs to be adjusted first. # # $ac_aux_dir/missing # fails when called from a subdirectory if $ac_aux_dir is relative # $top_srcdir/$ac_aux_dir/missing # fails if $ac_aux_dir is absolute, # fails when called from a subdirectory in a VPATH build with # a relative $ac_aux_dir # # The reason of the latter failure is that $top_srcdir and $ac_aux_dir # are both prefixed by $srcdir. In an in-source build this is usually # harmless because $srcdir is '.', but things will broke when you # start a VPATH build or use an absolute $srcdir. # # So we could use something similar to $top_srcdir/$ac_aux_dir/missing, # iff we strip the leading $srcdir from $ac_aux_dir. That would be: # am_aux_dir='\$(top_srcdir)/'`expr "$ac_aux_dir" : "$srcdir//*\(.*\)"` # and then we would define $MISSING as # MISSING="\${SHELL} $am_aux_dir/missing" # This will work as long as MISSING is not called from configure, because # unfortunately $(top_srcdir) has no meaning in configure. # However there are other variables, like CC, which are often used in # configure, and could therefore not use this "fixed" $ac_aux_dir. # # Another solution, used here, is to always expand $ac_aux_dir to an # absolute PATH. The drawback is that using absolute paths prevent a # configured tree to be moved without reconfiguration. AC_DEFUN([AM_AUX_DIR_EXPAND], [AC_REQUIRE([AC_CONFIG_AUX_DIR_DEFAULT])dnl # Expand $ac_aux_dir to an absolute path. am_aux_dir=`cd "$ac_aux_dir" && pwd` ]) # AM_CONDITIONAL -*- Autoconf -*- # Copyright (C) 1997-2017 Free Software Foundation, Inc. # # This file is free software; the Free Software Foundation # gives unlimited permission to copy and/or distribute it, # with or without modifications, as long as this notice is preserved. # AM_CONDITIONAL(NAME, SHELL-CONDITION) # ------------------------------------- # Define a conditional. AC_DEFUN([AM_CONDITIONAL], [AC_PREREQ([2.52])dnl m4_if([$1], [TRUE], [AC_FATAL([$0: invalid condition: $1])], [$1], [FALSE], [AC_FATAL([$0: invalid condition: $1])])dnl AC_SUBST([$1_TRUE])dnl AC_SUBST([$1_FALSE])dnl _AM_SUBST_NOTMAKE([$1_TRUE])dnl _AM_SUBST_NOTMAKE([$1_FALSE])dnl m4_define([_AM_COND_VALUE_$1], [$2])dnl if $2; then $1_TRUE= $1_FALSE='#' else $1_TRUE='#' $1_FALSE= fi AC_CONFIG_COMMANDS_PRE( [if test -z "${$1_TRUE}" && test -z "${$1_FALSE}"; then AC_MSG_ERROR([[conditional "$1" was never defined. Usually this means the macro was only invoked conditionally.]]) fi])]) # Copyright (C) 1999-2017 Free Software Foundation, Inc. # # This file is free software; the Free Software Foundation # gives unlimited permission to copy and/or distribute it, # with or without modifications, as long as this notice is preserved. # There are a few dirty hacks below to avoid letting 'AC_PROG_CC' be # written in clear, in which case automake, when reading aclocal.m4, # will think it sees a *use*, and therefore will trigger all it's # C support machinery. Also note that it means that autoscan, seeing # CC etc. in the Makefile, will ask for an AC_PROG_CC use... # _AM_DEPENDENCIES(NAME) # ---------------------- # See how the compiler implements dependency checking. # NAME is "CC", "CXX", "OBJC", "OBJCXX", "UPC", or "GJC". # We try a few techniques and use that to set a single cache variable. # # We don't AC_REQUIRE the corresponding AC_PROG_CC since the latter was # modified to invoke _AM_DEPENDENCIES(CC); we would have a circular # dependency, and given that the user is not expected to run this macro, # just rely on AC_PROG_CC. AC_DEFUN([_AM_DEPENDENCIES], [AC_REQUIRE([AM_SET_DEPDIR])dnl AC_REQUIRE([AM_OUTPUT_DEPENDENCY_COMMANDS])dnl AC_REQUIRE([AM_MAKE_INCLUDE])dnl AC_REQUIRE([AM_DEP_TRACK])dnl m4_if([$1], [CC], [depcc="$CC" am_compiler_list=], [$1], [CXX], [depcc="$CXX" am_compiler_list=], [$1], [OBJC], [depcc="$OBJC" am_compiler_list='gcc3 gcc'], [$1], [OBJCXX], [depcc="$OBJCXX" am_compiler_list='gcc3 gcc'], [$1], [UPC], [depcc="$UPC" am_compiler_list=], [$1], [GCJ], [depcc="$GCJ" am_compiler_list='gcc3 gcc'], [depcc="$$1" am_compiler_list=]) AC_CACHE_CHECK([dependency style of $depcc], [am_cv_$1_dependencies_compiler_type], [if test -z "$AMDEP_TRUE" && test -f "$am_depcomp"; then # We make a subdir and do the tests there. Otherwise we can end up # making bogus files that we don't know about and never remove. For # instance it was reported that on HP-UX the gcc test will end up # making a dummy file named 'D' -- because '-MD' means "put the output # in D". rm -rf conftest.dir mkdir conftest.dir # Copy depcomp to subdir because otherwise we won't find it if we're # using a relative directory. cp "$am_depcomp" conftest.dir cd conftest.dir # We will build objects and dependencies in a subdirectory because # it helps to detect inapplicable dependency modes. For instance # both Tru64's cc and ICC support -MD to output dependencies as a # side effect of compilation, but ICC will put the dependencies in # the current directory while Tru64 will put them in the object # directory. mkdir sub am_cv_$1_dependencies_compiler_type=none if test "$am_compiler_list" = ""; then am_compiler_list=`sed -n ['s/^#*\([a-zA-Z0-9]*\))$/\1/p'] < ./depcomp` fi am__universal=false m4_case([$1], [CC], [case " $depcc " in #( *\ -arch\ *\ -arch\ *) am__universal=true ;; esac], [CXX], [case " $depcc " in #( *\ -arch\ *\ -arch\ *) am__universal=true ;; esac]) for depmode in $am_compiler_list; do # Setup a source with many dependencies, because some compilers # like to wrap large dependency lists on column 80 (with \), and # we should not choose a depcomp mode which is confused by this. # # We need to recreate these files for each test, as the compiler may # overwrite some of them when testing with obscure command lines. # This happens at least with the AIX C compiler. : > sub/conftest.c for i in 1 2 3 4 5 6; do echo '#include "conftst'$i'.h"' >> sub/conftest.c # Using ": > sub/conftst$i.h" creates only sub/conftst1.h with # Solaris 10 /bin/sh. echo '/* dummy */' > sub/conftst$i.h done echo "${am__include} ${am__quote}sub/conftest.Po${am__quote}" > confmf # We check with '-c' and '-o' for the sake of the "dashmstdout" # mode. It turns out that the SunPro C++ compiler does not properly # handle '-M -o', and we need to detect this. Also, some Intel # versions had trouble with output in subdirs. am__obj=sub/conftest.${OBJEXT-o} am__minus_obj="-o $am__obj" case $depmode in gcc) # This depmode causes a compiler race in universal mode. test "$am__universal" = false || continue ;; nosideeffect) # After this tag, mechanisms are not by side-effect, so they'll # only be used when explicitly requested. if test "x$enable_dependency_tracking" = xyes; then continue else break fi ;; msvc7 | msvc7msys | msvisualcpp | msvcmsys) # This compiler won't grok '-c -o', but also, the minuso test has # not run yet. These depmodes are late enough in the game, and # so weak that their functioning should not be impacted. am__obj=conftest.${OBJEXT-o} am__minus_obj= ;; none) break ;; esac if depmode=$depmode \ source=sub/conftest.c object=$am__obj \ depfile=sub/conftest.Po tmpdepfile=sub/conftest.TPo \ $SHELL ./depcomp $depcc -c $am__minus_obj sub/conftest.c \ >/dev/null 2>conftest.err && grep sub/conftst1.h sub/conftest.Po > /dev/null 2>&1 && grep sub/conftst6.h sub/conftest.Po > /dev/null 2>&1 && grep $am__obj sub/conftest.Po > /dev/null 2>&1 && ${MAKE-make} -s -f confmf > /dev/null 2>&1; then # icc doesn't choke on unknown options, it will just issue warnings # or remarks (even with -Werror). So we grep stderr for any message # that says an option was ignored or not supported. # When given -MP, icc 7.0 and 7.1 complain thusly: # icc: Command line warning: ignoring option '-M'; no argument required # The diagnosis changed in icc 8.0: # icc: Command line remark: option '-MP' not supported if (grep 'ignoring option' conftest.err || grep 'not supported' conftest.err) >/dev/null 2>&1; then :; else am_cv_$1_dependencies_compiler_type=$depmode break fi fi done cd .. rm -rf conftest.dir else am_cv_$1_dependencies_compiler_type=none fi ]) AC_SUBST([$1DEPMODE], [depmode=$am_cv_$1_dependencies_compiler_type]) AM_CONDITIONAL([am__fastdep$1], [ test "x$enable_dependency_tracking" != xno \ && test "$am_cv_$1_dependencies_compiler_type" = gcc3]) ]) # AM_SET_DEPDIR # ------------- # Choose a directory name for dependency files. # This macro is AC_REQUIREd in _AM_DEPENDENCIES. AC_DEFUN([AM_SET_DEPDIR], [AC_REQUIRE([AM_SET_LEADING_DOT])dnl AC_SUBST([DEPDIR], ["${am__leading_dot}deps"])dnl ]) # AM_DEP_TRACK # ------------ AC_DEFUN([AM_DEP_TRACK], [AC_ARG_ENABLE([dependency-tracking], [dnl AS_HELP_STRING( [--enable-dependency-tracking], [do not reject slow dependency extractors]) AS_HELP_STRING( [--disable-dependency-tracking], [speeds up one-time build])]) if test "x$enable_dependency_tracking" != xno; then am_depcomp="$ac_aux_dir/depcomp" AMDEPBACKSLASH='\' am__nodep='_no' fi AM_CONDITIONAL([AMDEP], [test "x$enable_dependency_tracking" != xno]) AC_SUBST([AMDEPBACKSLASH])dnl _AM_SUBST_NOTMAKE([AMDEPBACKSLASH])dnl AC_SUBST([am__nodep])dnl _AM_SUBST_NOTMAKE([am__nodep])dnl ]) # Generate code to set up dependency tracking. -*- Autoconf -*- # Copyright (C) 1999-2017 Free Software Foundation, Inc. # # This file is free software; the Free Software Foundation # gives unlimited permission to copy and/or distribute it, # with or without modifications, as long as this notice is preserved. # _AM_OUTPUT_DEPENDENCY_COMMANDS # ------------------------------ AC_DEFUN([_AM_OUTPUT_DEPENDENCY_COMMANDS], [{ # Older Autoconf quotes --file arguments for eval, but not when files # are listed without --file. Let's play safe and only enable the eval # if we detect the quoting. case $CONFIG_FILES in *\'*) eval set x "$CONFIG_FILES" ;; *) set x $CONFIG_FILES ;; esac shift for mf do # Strip MF so we end up with the name of the file. mf=`echo "$mf" | sed -e 's/:.*$//'` # Check whether this is an Automake generated Makefile or not. # We used to match only the files named 'Makefile.in', but # some people rename them; so instead we look at the file content. # Grep'ing the first line is not enough: some people post-process # each Makefile.in and add a new line on top of each file to say so. # Grep'ing the whole file is not good either: AIX grep has a line # limit of 2048, but all sed's we know have understand at least 4000. if sed -n 's,^#.*generated by automake.*,X,p' "$mf" | grep X >/dev/null 2>&1; then dirpart=`AS_DIRNAME("$mf")` else continue fi # Extract the definition of DEPDIR, am__include, and am__quote # from the Makefile without running 'make'. DEPDIR=`sed -n 's/^DEPDIR = //p' < "$mf"` test -z "$DEPDIR" && continue am__include=`sed -n 's/^am__include = //p' < "$mf"` test -z "$am__include" && continue am__quote=`sed -n 's/^am__quote = //p' < "$mf"` # Find all dependency output files, they are included files with # $(DEPDIR) in their names. We invoke sed twice because it is the # simplest approach to changing $(DEPDIR) to its actual value in the # expansion. for file in `sed -n " s/^$am__include $am__quote\(.*(DEPDIR).*\)$am__quote"'$/\1/p' <"$mf" | \ sed -e 's/\$(DEPDIR)/'"$DEPDIR"'/g'`; do # Make sure the directory exists. test -f "$dirpart/$file" && continue fdir=`AS_DIRNAME(["$file"])` AS_MKDIR_P([$dirpart/$fdir]) # echo "creating $dirpart/$file" echo '# dummy' > "$dirpart/$file" done done } ])# _AM_OUTPUT_DEPENDENCY_COMMANDS # AM_OUTPUT_DEPENDENCY_COMMANDS # ----------------------------- # This macro should only be invoked once -- use via AC_REQUIRE. # # This code is only required when automatic dependency tracking # is enabled. FIXME. This creates each '.P' file that we will # need in order to bootstrap the dependency handling code. AC_DEFUN([AM_OUTPUT_DEPENDENCY_COMMANDS], [AC_CONFIG_COMMANDS([depfiles], [test x"$AMDEP_TRUE" != x"" || _AM_OUTPUT_DEPENDENCY_COMMANDS], [AMDEP_TRUE="$AMDEP_TRUE" ac_aux_dir="$ac_aux_dir"]) ]) # Do all the work for Automake. -*- Autoconf -*- # Copyright (C) 1996-2017 Free Software Foundation, Inc. # # This file is free software; the Free Software Foundation # gives unlimited permission to copy and/or distribute it, # with or without modifications, as long as this notice is preserved. # This macro actually does too much. Some checks are only needed if # your package does certain things. But this isn't really a big deal. dnl Redefine AC_PROG_CC to automatically invoke _AM_PROG_CC_C_O. m4_define([AC_PROG_CC], m4_defn([AC_PROG_CC]) [_AM_PROG_CC_C_O ]) # AM_INIT_AUTOMAKE(PACKAGE, VERSION, [NO-DEFINE]) # AM_INIT_AUTOMAKE([OPTIONS]) # ----------------------------------------------- # The call with PACKAGE and VERSION arguments is the old style # call (pre autoconf-2.50), which is being phased out. PACKAGE # and VERSION should now be passed to AC_INIT and removed from # the call to AM_INIT_AUTOMAKE. # We support both call styles for the transition. After # the next Automake release, Autoconf can make the AC_INIT # arguments mandatory, and then we can depend on a new Autoconf # release and drop the old call support. AC_DEFUN([AM_INIT_AUTOMAKE], [AC_PREREQ([2.65])dnl dnl Autoconf wants to disallow AM_ names. We explicitly allow dnl the ones we care about. m4_pattern_allow([^AM_[A-Z]+FLAGS$])dnl AC_REQUIRE([AM_SET_CURRENT_AUTOMAKE_VERSION])dnl AC_REQUIRE([AC_PROG_INSTALL])dnl if test "`cd $srcdir && pwd`" != "`pwd`"; then # Use -I$(srcdir) only when $(srcdir) != ., so that make's output # is not polluted with repeated "-I." AC_SUBST([am__isrc], [' -I$(srcdir)'])_AM_SUBST_NOTMAKE([am__isrc])dnl # test to see if srcdir already configured if test -f $srcdir/config.status; then AC_MSG_ERROR([source directory already configured; run "make distclean" there first]) fi fi # test whether we have cygpath if test -z "$CYGPATH_W"; then if (cygpath --version) >/dev/null 2>/dev/null; then CYGPATH_W='cygpath -w' else CYGPATH_W=echo fi fi AC_SUBST([CYGPATH_W]) # Define the identity of the package. dnl Distinguish between old-style and new-style calls. m4_ifval([$2], [AC_DIAGNOSE([obsolete], [$0: two- and three-arguments forms are deprecated.]) m4_ifval([$3], [_AM_SET_OPTION([no-define])])dnl AC_SUBST([PACKAGE], [$1])dnl AC_SUBST([VERSION], [$2])], [_AM_SET_OPTIONS([$1])dnl dnl Diagnose old-style AC_INIT with new-style AM_AUTOMAKE_INIT. m4_if( m4_ifdef([AC_PACKAGE_NAME], [ok]):m4_ifdef([AC_PACKAGE_VERSION], [ok]), [ok:ok],, [m4_fatal([AC_INIT should be called with package and version arguments])])dnl AC_SUBST([PACKAGE], ['AC_PACKAGE_TARNAME'])dnl AC_SUBST([VERSION], ['AC_PACKAGE_VERSION'])])dnl _AM_IF_OPTION([no-define],, [AC_DEFINE_UNQUOTED([PACKAGE], ["$PACKAGE"], [Name of package]) AC_DEFINE_UNQUOTED([VERSION], ["$VERSION"], [Version number of package])])dnl # Some tools Automake needs. AC_REQUIRE([AM_SANITY_CHECK])dnl AC_REQUIRE([AC_ARG_PROGRAM])dnl AM_MISSING_PROG([ACLOCAL], [aclocal-${am__api_version}]) AM_MISSING_PROG([AUTOCONF], [autoconf]) AM_MISSING_PROG([AUTOMAKE], [automake-${am__api_version}]) AM_MISSING_PROG([AUTOHEADER], [autoheader]) AM_MISSING_PROG([MAKEINFO], [makeinfo]) AC_REQUIRE([AM_PROG_INSTALL_SH])dnl AC_REQUIRE([AM_PROG_INSTALL_STRIP])dnl AC_REQUIRE([AC_PROG_MKDIR_P])dnl # For better backward compatibility. To be removed once Automake 1.9.x # dies out for good. For more background, see: # # AC_SUBST([mkdir_p], ['$(MKDIR_P)']) # We need awk for the "check" target (and possibly the TAP driver). The # system "awk" is bad on some platforms. AC_REQUIRE([AC_PROG_AWK])dnl AC_REQUIRE([AC_PROG_MAKE_SET])dnl AC_REQUIRE([AM_SET_LEADING_DOT])dnl _AM_IF_OPTION([tar-ustar], [_AM_PROG_TAR([ustar])], [_AM_IF_OPTION([tar-pax], [_AM_PROG_TAR([pax])], [_AM_PROG_TAR([v7])])]) _AM_IF_OPTION([no-dependencies],, [AC_PROVIDE_IFELSE([AC_PROG_CC], [_AM_DEPENDENCIES([CC])], [m4_define([AC_PROG_CC], m4_defn([AC_PROG_CC])[_AM_DEPENDENCIES([CC])])])dnl AC_PROVIDE_IFELSE([AC_PROG_CXX], [_AM_DEPENDENCIES([CXX])], [m4_define([AC_PROG_CXX], m4_defn([AC_PROG_CXX])[_AM_DEPENDENCIES([CXX])])])dnl AC_PROVIDE_IFELSE([AC_PROG_OBJC], [_AM_DEPENDENCIES([OBJC])], [m4_define([AC_PROG_OBJC], m4_defn([AC_PROG_OBJC])[_AM_DEPENDENCIES([OBJC])])])dnl AC_PROVIDE_IFELSE([AC_PROG_OBJCXX], [_AM_DEPENDENCIES([OBJCXX])], [m4_define([AC_PROG_OBJCXX], m4_defn([AC_PROG_OBJCXX])[_AM_DEPENDENCIES([OBJCXX])])])dnl ]) AC_REQUIRE([AM_SILENT_RULES])dnl dnl The testsuite driver may need to know about EXEEXT, so add the dnl 'am__EXEEXT' conditional if _AM_COMPILER_EXEEXT was seen. This dnl macro is hooked onto _AC_COMPILER_EXEEXT early, see below. AC_CONFIG_COMMANDS_PRE(dnl [m4_provide_if([_AM_COMPILER_EXEEXT], [AM_CONDITIONAL([am__EXEEXT], [test -n "$EXEEXT"])])])dnl # POSIX will say in a future version that running "rm -f" with no argument # is OK; and we want to be able to make that assumption in our Makefile # recipes. So use an aggressive probe to check that the usage we want is # actually supported "in the wild" to an acceptable degree. # See automake bug#10828. # To make any issue more visible, cause the running configure to be aborted # by default if the 'rm' program in use doesn't match our expectations; the # user can still override this though. if rm -f && rm -fr && rm -rf; then : OK; else cat >&2 <<'END' Oops! Your 'rm' program seems unable to run without file operands specified on the command line, even when the '-f' option is present. This is contrary to the behaviour of most rm programs out there, and not conforming with the upcoming POSIX standard: Please tell bug-automake@gnu.org about your system, including the value of your $PATH and any error possibly output before this message. This can help us improve future automake versions. END if test x"$ACCEPT_INFERIOR_RM_PROGRAM" = x"yes"; then echo 'Configuration will proceed anyway, since you have set the' >&2 echo 'ACCEPT_INFERIOR_RM_PROGRAM variable to "yes"' >&2 echo >&2 else cat >&2 <<'END' Aborting the configuration process, to ensure you take notice of the issue. You can download and install GNU coreutils to get an 'rm' implementation that behaves properly: . If you want to complete the configuration process using your problematic 'rm' anyway, export the environment variable ACCEPT_INFERIOR_RM_PROGRAM to "yes", and re-run configure. END AC_MSG_ERROR([Your 'rm' program is bad, sorry.]) fi fi dnl The trailing newline in this macro's definition is deliberate, for dnl backward compatibility and to allow trailing 'dnl'-style comments dnl after the AM_INIT_AUTOMAKE invocation. See automake bug#16841. ]) dnl Hook into '_AC_COMPILER_EXEEXT' early to learn its expansion. Do not dnl add the conditional right here, as _AC_COMPILER_EXEEXT may be further dnl mangled by Autoconf and run in a shell conditional statement. m4_define([_AC_COMPILER_EXEEXT], m4_defn([_AC_COMPILER_EXEEXT])[m4_provide([_AM_COMPILER_EXEEXT])]) # When config.status generates a header, we must update the stamp-h file. # This file resides in the same directory as the config header # that is generated. The stamp files are numbered to have different names. # Autoconf calls _AC_AM_CONFIG_HEADER_HOOK (when defined) in the # loop where config.status creates the headers, so we can generate # our stamp files there. AC_DEFUN([_AC_AM_CONFIG_HEADER_HOOK], [# Compute $1's index in $config_headers. _am_arg=$1 _am_stamp_count=1 for _am_header in $config_headers :; do case $_am_header in $_am_arg | $_am_arg:* ) break ;; * ) _am_stamp_count=`expr $_am_stamp_count + 1` ;; esac done echo "timestamp for $_am_arg" >`AS_DIRNAME(["$_am_arg"])`/stamp-h[]$_am_stamp_count]) # Copyright (C) 2001-2017 Free Software Foundation, Inc. # # This file is free software; the Free Software Foundation # gives unlimited permission to copy and/or distribute it, # with or without modifications, as long as this notice is preserved. # AM_PROG_INSTALL_SH # ------------------ # Define $install_sh. AC_DEFUN([AM_PROG_INSTALL_SH], [AC_REQUIRE([AM_AUX_DIR_EXPAND])dnl if test x"${install_sh+set}" != xset; then case $am_aux_dir in *\ * | *\ *) install_sh="\${SHELL} '$am_aux_dir/install-sh'" ;; *) install_sh="\${SHELL} $am_aux_dir/install-sh" esac fi AC_SUBST([install_sh])]) # Copyright (C) 2003-2017 Free Software Foundation, Inc. # # This file is free software; the Free Software Foundation # gives unlimited permission to copy and/or distribute it, # with or without modifications, as long as this notice is preserved. # Check whether the underlying file-system supports filenames # with a leading dot. For instance MS-DOS doesn't. AC_DEFUN([AM_SET_LEADING_DOT], [rm -rf .tst 2>/dev/null mkdir .tst 2>/dev/null if test -d .tst; then am__leading_dot=. else am__leading_dot=_ fi rmdir .tst 2>/dev/null AC_SUBST([am__leading_dot])]) # Check to see how 'make' treats includes. -*- Autoconf -*- # Copyright (C) 2001-2017 Free Software Foundation, Inc. # # This file is free software; the Free Software Foundation # gives unlimited permission to copy and/or distribute it, # with or without modifications, as long as this notice is preserved. # AM_MAKE_INCLUDE() # ----------------- # Check to see how make treats includes. AC_DEFUN([AM_MAKE_INCLUDE], [am_make=${MAKE-make} cat > confinc << 'END' am__doit: @echo this is the am__doit target .PHONY: am__doit END # If we don't find an include directive, just comment out the code. AC_MSG_CHECKING([for style of include used by $am_make]) am__include="#" am__quote= _am_result=none # First try GNU make style include. echo "include confinc" > confmf # Ignore all kinds of additional output from 'make'. case `$am_make -s -f confmf 2> /dev/null` in #( *the\ am__doit\ target*) am__include=include am__quote= _am_result=GNU ;; esac # Now try BSD make style include. if test "$am__include" = "#"; then echo '.include "confinc"' > confmf case `$am_make -s -f confmf 2> /dev/null` in #( *the\ am__doit\ target*) am__include=.include am__quote="\"" _am_result=BSD ;; esac fi AC_SUBST([am__include]) AC_SUBST([am__quote]) AC_MSG_RESULT([$_am_result]) rm -f confinc confmf ]) # Fake the existence of programs that GNU maintainers use. -*- Autoconf -*- # Copyright (C) 1997-2017 Free Software Foundation, Inc. # # This file is free software; the Free Software Foundation # gives unlimited permission to copy and/or distribute it, # with or without modifications, as long as this notice is preserved. # AM_MISSING_PROG(NAME, PROGRAM) # ------------------------------ AC_DEFUN([AM_MISSING_PROG], [AC_REQUIRE([AM_MISSING_HAS_RUN]) $1=${$1-"${am_missing_run}$2"} AC_SUBST($1)]) # AM_MISSING_HAS_RUN # ------------------ # Define MISSING if not defined so far and test if it is modern enough. # If it is, set am_missing_run to use it, otherwise, to nothing. AC_DEFUN([AM_MISSING_HAS_RUN], [AC_REQUIRE([AM_AUX_DIR_EXPAND])dnl AC_REQUIRE_AUX_FILE([missing])dnl if test x"${MISSING+set}" != xset; then case $am_aux_dir in *\ * | *\ *) MISSING="\${SHELL} \"$am_aux_dir/missing\"" ;; *) MISSING="\${SHELL} $am_aux_dir/missing" ;; esac fi # Use eval to expand $SHELL if eval "$MISSING --is-lightweight"; then am_missing_run="$MISSING " else am_missing_run= AC_MSG_WARN(['missing' script is too old or missing]) fi ]) # Helper functions for option handling. -*- Autoconf -*- # Copyright (C) 2001-2017 Free Software Foundation, Inc. # # This file is free software; the Free Software Foundation # gives unlimited permission to copy and/or distribute it, # with or without modifications, as long as this notice is preserved. # _AM_MANGLE_OPTION(NAME) # ----------------------- AC_DEFUN([_AM_MANGLE_OPTION], [[_AM_OPTION_]m4_bpatsubst($1, [[^a-zA-Z0-9_]], [_])]) # _AM_SET_OPTION(NAME) # -------------------- # Set option NAME. Presently that only means defining a flag for this option. AC_DEFUN([_AM_SET_OPTION], [m4_define(_AM_MANGLE_OPTION([$1]), [1])]) # _AM_SET_OPTIONS(OPTIONS) # ------------------------ # OPTIONS is a space-separated list of Automake options. AC_DEFUN([_AM_SET_OPTIONS], [m4_foreach_w([_AM_Option], [$1], [_AM_SET_OPTION(_AM_Option)])]) # _AM_IF_OPTION(OPTION, IF-SET, [IF-NOT-SET]) # ------------------------------------------- # Execute IF-SET if OPTION is set, IF-NOT-SET otherwise. AC_DEFUN([_AM_IF_OPTION], [m4_ifset(_AM_MANGLE_OPTION([$1]), [$2], [$3])]) # Copyright (C) 1999-2017 Free Software Foundation, Inc. # # This file is free software; the Free Software Foundation # gives unlimited permission to copy and/or distribute it, # with or without modifications, as long as this notice is preserved. # _AM_PROG_CC_C_O # --------------- # Like AC_PROG_CC_C_O, but changed for automake. We rewrite AC_PROG_CC # to automatically call this. AC_DEFUN([_AM_PROG_CC_C_O], [AC_REQUIRE([AM_AUX_DIR_EXPAND])dnl AC_REQUIRE_AUX_FILE([compile])dnl AC_LANG_PUSH([C])dnl AC_CACHE_CHECK( [whether $CC understands -c and -o together], [am_cv_prog_cc_c_o], [AC_LANG_CONFTEST([AC_LANG_PROGRAM([])]) # Make sure it works both with $CC and with simple cc. # Following AC_PROG_CC_C_O, we do the test twice because some # compilers refuse to overwrite an existing .o file with -o, # though they will create one. am_cv_prog_cc_c_o=yes for am_i in 1 2; do if AM_RUN_LOG([$CC -c conftest.$ac_ext -o conftest2.$ac_objext]) \ && test -f conftest2.$ac_objext; then : OK else am_cv_prog_cc_c_o=no break fi done rm -f core conftest* unset am_i]) if test "$am_cv_prog_cc_c_o" != yes; then # Losing compiler, so override with the script. # FIXME: It is wrong to rewrite CC. # But if we don't then we get into trouble of one sort or another. # A longer-term fix would be to have automake use am__CC in this case, # and then we could set am__CC="\$(top_srcdir)/compile \$(CC)" CC="$am_aux_dir/compile $CC" fi AC_LANG_POP([C])]) # For backward compatibility. AC_DEFUN_ONCE([AM_PROG_CC_C_O], [AC_REQUIRE([AC_PROG_CC])]) # Copyright (C) 2001-2017 Free Software Foundation, Inc. # # This file is free software; the Free Software Foundation # gives unlimited permission to copy and/or distribute it, # with or without modifications, as long as this notice is preserved. # AM_RUN_LOG(COMMAND) # ------------------- # Run COMMAND, save the exit status in ac_status, and log it. # (This has been adapted from Autoconf's _AC_RUN_LOG macro.) AC_DEFUN([AM_RUN_LOG], [{ echo "$as_me:$LINENO: $1" >&AS_MESSAGE_LOG_FD ($1) >&AS_MESSAGE_LOG_FD 2>&AS_MESSAGE_LOG_FD ac_status=$? echo "$as_me:$LINENO: \$? = $ac_status" >&AS_MESSAGE_LOG_FD (exit $ac_status); }]) # Check to make sure that the build environment is sane. -*- Autoconf -*- # Copyright (C) 1996-2017 Free Software Foundation, Inc. # # This file is free software; the Free Software Foundation # gives unlimited permission to copy and/or distribute it, # with or without modifications, as long as this notice is preserved. # AM_SANITY_CHECK # --------------- AC_DEFUN([AM_SANITY_CHECK], [AC_MSG_CHECKING([whether build environment is sane]) # Reject unsafe characters in $srcdir or the absolute working directory # name. Accept space and tab only in the latter. am_lf=' ' case `pwd` in *[[\\\"\#\$\&\'\`$am_lf]]*) AC_MSG_ERROR([unsafe absolute working directory name]);; esac case $srcdir in *[[\\\"\#\$\&\'\`$am_lf\ \ ]]*) AC_MSG_ERROR([unsafe srcdir value: '$srcdir']);; esac # Do 'set' in a subshell so we don't clobber the current shell's # arguments. Must try -L first in case configure is actually a # symlink; some systems play weird games with the mod time of symlinks # (eg FreeBSD returns the mod time of the symlink's containing # directory). if ( am_has_slept=no for am_try in 1 2; do echo "timestamp, slept: $am_has_slept" > conftest.file set X `ls -Lt "$srcdir/configure" conftest.file 2> /dev/null` if test "$[*]" = "X"; then # -L didn't work. set X `ls -t "$srcdir/configure" conftest.file` fi if test "$[*]" != "X $srcdir/configure conftest.file" \ && test "$[*]" != "X conftest.file $srcdir/configure"; then # If neither matched, then we have a broken ls. This can happen # if, for instance, CONFIG_SHELL is bash and it inherits a # broken ls alias from the environment. This has actually # happened. Such a system could not be considered "sane". AC_MSG_ERROR([ls -t appears to fail. Make sure there is not a broken alias in your environment]) fi if test "$[2]" = conftest.file || test $am_try -eq 2; then break fi # Just in case. sleep 1 am_has_slept=yes done test "$[2]" = conftest.file ) then # Ok. : else AC_MSG_ERROR([newly created file is older than distributed files! Check your system clock]) fi AC_MSG_RESULT([yes]) # If we didn't sleep, we still need to ensure time stamps of config.status and # generated files are strictly newer. am_sleep_pid= if grep 'slept: no' conftest.file >/dev/null 2>&1; then ( sleep 1 ) & am_sleep_pid=$! fi AC_CONFIG_COMMANDS_PRE( [AC_MSG_CHECKING([that generated files are newer than configure]) if test -n "$am_sleep_pid"; then # Hide warnings about reused PIDs. wait $am_sleep_pid 2>/dev/null fi AC_MSG_RESULT([done])]) rm -f conftest.file ]) # Copyright (C) 2009-2017 Free Software Foundation, Inc. # # This file is free software; the Free Software Foundation # gives unlimited permission to copy and/or distribute it, # with or without modifications, as long as this notice is preserved. # AM_SILENT_RULES([DEFAULT]) # -------------------------- # Enable less verbose build rules; with the default set to DEFAULT # ("yes" being less verbose, "no" or empty being verbose). AC_DEFUN([AM_SILENT_RULES], [AC_ARG_ENABLE([silent-rules], [dnl AS_HELP_STRING( [--enable-silent-rules], [less verbose build output (undo: "make V=1")]) AS_HELP_STRING( [--disable-silent-rules], [verbose build output (undo: "make V=0")])dnl ]) case $enable_silent_rules in @%:@ ((( yes) AM_DEFAULT_VERBOSITY=0;; no) AM_DEFAULT_VERBOSITY=1;; *) AM_DEFAULT_VERBOSITY=m4_if([$1], [yes], [0], [1]);; esac dnl dnl A few 'make' implementations (e.g., NonStop OS and NextStep) dnl do not support nested variable expansions. dnl See automake bug#9928 and bug#10237. am_make=${MAKE-make} AC_CACHE_CHECK([whether $am_make supports nested variables], [am_cv_make_support_nested_variables], [if AS_ECHO([['TRUE=$(BAR$(V)) BAR0=false BAR1=true V=1 am__doit: @$(TRUE) .PHONY: am__doit']]) | $am_make -f - >/dev/null 2>&1; then am_cv_make_support_nested_variables=yes else am_cv_make_support_nested_variables=no fi]) if test $am_cv_make_support_nested_variables = yes; then dnl Using '$V' instead of '$(V)' breaks IRIX make. AM_V='$(V)' AM_DEFAULT_V='$(AM_DEFAULT_VERBOSITY)' else AM_V=$AM_DEFAULT_VERBOSITY AM_DEFAULT_V=$AM_DEFAULT_VERBOSITY fi AC_SUBST([AM_V])dnl AM_SUBST_NOTMAKE([AM_V])dnl AC_SUBST([AM_DEFAULT_V])dnl AM_SUBST_NOTMAKE([AM_DEFAULT_V])dnl AC_SUBST([AM_DEFAULT_VERBOSITY])dnl AM_BACKSLASH='\' AC_SUBST([AM_BACKSLASH])dnl _AM_SUBST_NOTMAKE([AM_BACKSLASH])dnl ]) # Copyright (C) 2001-2017 Free Software Foundation, Inc. # # This file is free software; the Free Software Foundation # gives unlimited permission to copy and/or distribute it, # with or without modifications, as long as this notice is preserved. # AM_PROG_INSTALL_STRIP # --------------------- # One issue with vendor 'install' (even GNU) is that you can't # specify the program used to strip binaries. This is especially # annoying in cross-compiling environments, where the build's strip # is unlikely to handle the host's binaries. # Fortunately install-sh will honor a STRIPPROG variable, so we # always use install-sh in "make install-strip", and initialize # STRIPPROG with the value of the STRIP variable (set by the user). AC_DEFUN([AM_PROG_INSTALL_STRIP], [AC_REQUIRE([AM_PROG_INSTALL_SH])dnl # Installed binaries are usually stripped using 'strip' when the user # run "make install-strip". However 'strip' might not be the right # tool to use in cross-compilation environments, therefore Automake # will honor the 'STRIP' environment variable to overrule this program. dnl Don't test for $cross_compiling = yes, because it might be 'maybe'. if test "$cross_compiling" != no; then AC_CHECK_TOOL([STRIP], [strip], :) fi INSTALL_STRIP_PROGRAM="\$(install_sh) -c -s" AC_SUBST([INSTALL_STRIP_PROGRAM])]) # Copyright (C) 2006-2017 Free Software Foundation, Inc. # # This file is free software; the Free Software Foundation # gives unlimited permission to copy and/or distribute it, # with or without modifications, as long as this notice is preserved. # _AM_SUBST_NOTMAKE(VARIABLE) # --------------------------- # Prevent Automake from outputting VARIABLE = @VARIABLE@ in Makefile.in. # This macro is traced by Automake. AC_DEFUN([_AM_SUBST_NOTMAKE]) # AM_SUBST_NOTMAKE(VARIABLE) # -------------------------- # Public sister of _AM_SUBST_NOTMAKE. AC_DEFUN([AM_SUBST_NOTMAKE], [_AM_SUBST_NOTMAKE($@)]) # Check how to create a tarball. -*- Autoconf -*- # Copyright (C) 2004-2017 Free Software Foundation, Inc. # # This file is free software; the Free Software Foundation # gives unlimited permission to copy and/or distribute it, # with or without modifications, as long as this notice is preserved. # _AM_PROG_TAR(FORMAT) # -------------------- # Check how to create a tarball in format FORMAT. # FORMAT should be one of 'v7', 'ustar', or 'pax'. # # Substitute a variable $(am__tar) that is a command # writing to stdout a FORMAT-tarball containing the directory # $tardir. # tardir=directory && $(am__tar) > result.tar # # Substitute a variable $(am__untar) that extract such # a tarball read from stdin. # $(am__untar) < result.tar # AC_DEFUN([_AM_PROG_TAR], [# Always define AMTAR for backward compatibility. Yes, it's still used # in the wild :-( We should find a proper way to deprecate it ... AC_SUBST([AMTAR], ['$${TAR-tar}']) # We'll loop over all known methods to create a tar archive until one works. _am_tools='gnutar m4_if([$1], [ustar], [plaintar]) pax cpio none' m4_if([$1], [v7], [am__tar='$${TAR-tar} chof - "$$tardir"' am__untar='$${TAR-tar} xf -'], [m4_case([$1], [ustar], [# The POSIX 1988 'ustar' format is defined with fixed-size fields. # There is notably a 21 bits limit for the UID and the GID. In fact, # the 'pax' utility can hang on bigger UID/GID (see automake bug#8343 # and bug#13588). am_max_uid=2097151 # 2^21 - 1 am_max_gid=$am_max_uid # The $UID and $GID variables are not portable, so we need to resort # to the POSIX-mandated id(1) utility. Errors in the 'id' calls # below are definitely unexpected, so allow the users to see them # (that is, avoid stderr redirection). am_uid=`id -u || echo unknown` am_gid=`id -g || echo unknown` AC_MSG_CHECKING([whether UID '$am_uid' is supported by ustar format]) if test $am_uid -le $am_max_uid; then AC_MSG_RESULT([yes]) else AC_MSG_RESULT([no]) _am_tools=none fi AC_MSG_CHECKING([whether GID '$am_gid' is supported by ustar format]) if test $am_gid -le $am_max_gid; then AC_MSG_RESULT([yes]) else AC_MSG_RESULT([no]) _am_tools=none fi], [pax], [], [m4_fatal([Unknown tar format])]) AC_MSG_CHECKING([how to create a $1 tar archive]) # Go ahead even if we have the value already cached. We do so because we # need to set the values for the 'am__tar' and 'am__untar' variables. _am_tools=${am_cv_prog_tar_$1-$_am_tools} for _am_tool in $_am_tools; do case $_am_tool in gnutar) for _am_tar in tar gnutar gtar; do AM_RUN_LOG([$_am_tar --version]) && break done am__tar="$_am_tar --format=m4_if([$1], [pax], [posix], [$1]) -chf - "'"$$tardir"' am__tar_="$_am_tar --format=m4_if([$1], [pax], [posix], [$1]) -chf - "'"$tardir"' am__untar="$_am_tar -xf -" ;; plaintar) # Must skip GNU tar: if it does not support --format= it doesn't create # ustar tarball either. (tar --version) >/dev/null 2>&1 && continue am__tar='tar chf - "$$tardir"' am__tar_='tar chf - "$tardir"' am__untar='tar xf -' ;; pax) am__tar='pax -L -x $1 -w "$$tardir"' am__tar_='pax -L -x $1 -w "$tardir"' am__untar='pax -r' ;; cpio) am__tar='find "$$tardir" -print | cpio -o -H $1 -L' am__tar_='find "$tardir" -print | cpio -o -H $1 -L' am__untar='cpio -i -H $1 -d' ;; none) am__tar=false am__tar_=false am__untar=false ;; esac # If the value was cached, stop now. We just wanted to have am__tar # and am__untar set. test -n "${am_cv_prog_tar_$1}" && break # tar/untar a dummy directory, and stop if the command works. rm -rf conftest.dir mkdir conftest.dir echo GrepMe > conftest.dir/file AM_RUN_LOG([tardir=conftest.dir && eval $am__tar_ >conftest.tar]) rm -rf conftest.dir if test -s conftest.tar; then AM_RUN_LOG([$am__untar /dev/null 2>&1 && break fi done rm -rf conftest.dir AC_CACHE_VAL([am_cv_prog_tar_$1], [am_cv_prog_tar_$1=$_am_tool]) AC_MSG_RESULT([$am_cv_prog_tar_$1])]) AC_SUBST([am__tar]) AC_SUBST([am__untar]) ]) # _AM_PROG_TAR m4_include([m4/ax_append_compile_flags.m4]) m4_include([m4/ax_append_flag.m4]) m4_include([m4/ax_cflags_warn_all.m4]) m4_include([m4/ax_check_compile_flag.m4]) m4_include([m4/ax_require_defined.m4]) m4_include([m4/libtool.m4]) m4_include([m4/ltoptions.m4]) m4_include([m4/ltsugar.m4]) m4_include([m4/ltversion.m4]) m4_include([m4/lt~obsolete.m4]) m4_include([m4/pkg.m4]) xrdp-0.9.5/libpainter/config_ac-h.in000644 001751 001751 00000003231 13220730740 017235 0ustar00metameta000000 000000 /* config_ac-h.in. Generated from configure.ac by autoheader. */ /* Define to 1 if you have the header file. */ #undef HAVE_DLFCN_H /* Define to 1 if you have the header file. */ #undef HAVE_INTTYPES_H /* Define to 1 if you have the header file. */ #undef HAVE_MEMORY_H /* Define to 1 if you have the header file. */ #undef HAVE_STDINT_H /* Define to 1 if you have the header file. */ #undef HAVE_STDLIB_H /* Define to 1 if you have the header file. */ #undef HAVE_STRINGS_H /* Define to 1 if you have the header file. */ #undef HAVE_STRING_H /* Define to 1 if you have the header file. */ #undef HAVE_SYS_STAT_H /* Define to 1 if you have the header file. */ #undef HAVE_SYS_TYPES_H /* Define to 1 if you have the header file. */ #undef HAVE_UNISTD_H /* Define to the sub-directory where libtool stores uninstalled libraries. */ #undef LT_OBJDIR /* Name of package */ #undef PACKAGE /* Define to the address where bug reports for this package should be sent. */ #undef PACKAGE_BUGREPORT /* Define to the full name of this package. */ #undef PACKAGE_NAME /* Define to the full name and version of this package. */ #undef PACKAGE_STRING /* Define to the one symbol short name of this package. */ #undef PACKAGE_TARNAME /* Define to the home page for this package. */ #undef PACKAGE_URL /* Define to the version of this package. */ #undef PACKAGE_VERSION /* Define to 1 if you have the ANSI C header files. */ #undef STDC_HEADERS /* Version number of package */ #undef VERSION /* Define to empty if `const' does not conform to ANSI C. */ #undef const xrdp-0.9.5/libpainter/install-sh000755 001751 001751 00000034524 13220730741 016566 0ustar00metameta000000 000000 #!/bin/sh # install - install a program, script, or datafile scriptversion=2016-01-11.22; # UTC # This originates from X11R5 (mit/util/scripts/install.sh), which was # later released in X11R6 (xc/config/util/install.sh) with the # following copyright and license. # # Copyright (C) 1994 X Consortium # # Permission is hereby granted, free of charge, to any person obtaining a copy # of this software and associated documentation files (the "Software"), to # deal in the Software without restriction, including without limitation the # rights to use, copy, modify, merge, publish, distribute, sublicense, and/or # sell copies of the Software, and to permit persons to whom the Software is # furnished to do so, subject to the following conditions: # # The above copyright notice and this permission notice shall be included in # all copies or substantial portions of the Software. # # THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR # IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, # FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE # X CONSORTIUM BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN # AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNEC- # TION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. # # Except as contained in this notice, the name of the X Consortium shall not # be used in advertising or otherwise to promote the sale, use or other deal- # ings in this Software without prior written authorization from the X Consor- # tium. # # # FSF changes to this file are in the public domain. # # Calling this script install-sh is preferred over install.sh, to prevent # 'make' implicit rules from creating a file called install from it # when there is no Makefile. # # This script is compatible with the BSD install script, but was written # from scratch. tab=' ' nl=' ' IFS=" $tab$nl" # Set DOITPROG to "echo" to test this script. doit=${DOITPROG-} doit_exec=${doit:-exec} # Put in absolute file names if you don't have them in your path; # or use environment vars. chgrpprog=${CHGRPPROG-chgrp} chmodprog=${CHMODPROG-chmod} chownprog=${CHOWNPROG-chown} cmpprog=${CMPPROG-cmp} cpprog=${CPPROG-cp} mkdirprog=${MKDIRPROG-mkdir} mvprog=${MVPROG-mv} rmprog=${RMPROG-rm} stripprog=${STRIPPROG-strip} posix_mkdir= # Desired mode of installed file. mode=0755 chgrpcmd= chmodcmd=$chmodprog chowncmd= mvcmd=$mvprog rmcmd="$rmprog -f" stripcmd= src= dst= dir_arg= dst_arg= copy_on_change=false is_target_a_directory=possibly usage="\ Usage: $0 [OPTION]... [-T] SRCFILE DSTFILE or: $0 [OPTION]... SRCFILES... DIRECTORY or: $0 [OPTION]... -t DIRECTORY SRCFILES... or: $0 [OPTION]... -d DIRECTORIES... In the 1st form, copy SRCFILE to DSTFILE. In the 2nd and 3rd, copy all SRCFILES to DIRECTORY. In the 4th, create DIRECTORIES. Options: --help display this help and exit. --version display version info and exit. -c (ignored) -C install only if different (preserve the last data modification time) -d create directories instead of installing files. -g GROUP $chgrpprog installed files to GROUP. -m MODE $chmodprog installed files to MODE. -o USER $chownprog installed files to USER. -s $stripprog installed files. -t DIRECTORY install into DIRECTORY. -T report an error if DSTFILE is a directory. Environment variables override the default commands: CHGRPPROG CHMODPROG CHOWNPROG CMPPROG CPPROG MKDIRPROG MVPROG RMPROG STRIPPROG " while test $# -ne 0; do case $1 in -c) ;; -C) copy_on_change=true;; -d) dir_arg=true;; -g) chgrpcmd="$chgrpprog $2" shift;; --help) echo "$usage"; exit $?;; -m) mode=$2 case $mode in *' '* | *"$tab"* | *"$nl"* | *'*'* | *'?'* | *'['*) echo "$0: invalid mode: $mode" >&2 exit 1;; esac shift;; -o) chowncmd="$chownprog $2" shift;; -s) stripcmd=$stripprog;; -t) is_target_a_directory=always dst_arg=$2 # Protect names problematic for 'test' and other utilities. case $dst_arg in -* | [=\(\)!]) dst_arg=./$dst_arg;; esac shift;; -T) is_target_a_directory=never;; --version) echo "$0 $scriptversion"; exit $?;; --) shift break;; -*) echo "$0: invalid option: $1" >&2 exit 1;; *) break;; esac shift done # We allow the use of options -d and -T together, by making -d # take the precedence; this is for compatibility with GNU install. if test -n "$dir_arg"; then if test -n "$dst_arg"; then echo "$0: target directory not allowed when installing a directory." >&2 exit 1 fi fi if test $# -ne 0 && test -z "$dir_arg$dst_arg"; then # When -d is used, all remaining arguments are directories to create. # When -t is used, the destination is already specified. # Otherwise, the last argument is the destination. Remove it from $@. for arg do if test -n "$dst_arg"; then # $@ is not empty: it contains at least $arg. set fnord "$@" "$dst_arg" shift # fnord fi shift # arg dst_arg=$arg # Protect names problematic for 'test' and other utilities. case $dst_arg in -* | [=\(\)!]) dst_arg=./$dst_arg;; esac done fi if test $# -eq 0; then if test -z "$dir_arg"; then echo "$0: no input file specified." >&2 exit 1 fi # It's OK to call 'install-sh -d' without argument. # This can happen when creating conditional directories. exit 0 fi if test -z "$dir_arg"; then if test $# -gt 1 || test "$is_target_a_directory" = always; then if test ! -d "$dst_arg"; then echo "$0: $dst_arg: Is not a directory." >&2 exit 1 fi fi fi if test -z "$dir_arg"; then do_exit='(exit $ret); exit $ret' trap "ret=129; $do_exit" 1 trap "ret=130; $do_exit" 2 trap "ret=141; $do_exit" 13 trap "ret=143; $do_exit" 15 # Set umask so as not to create temps with too-generous modes. # However, 'strip' requires both read and write access to temps. case $mode in # Optimize common cases. *644) cp_umask=133;; *755) cp_umask=22;; *[0-7]) if test -z "$stripcmd"; then u_plus_rw= else u_plus_rw='% 200' fi cp_umask=`expr '(' 777 - $mode % 1000 ')' $u_plus_rw`;; *) if test -z "$stripcmd"; then u_plus_rw= else u_plus_rw=,u+rw fi cp_umask=$mode$u_plus_rw;; esac fi for src do # Protect names problematic for 'test' and other utilities. case $src in -* | [=\(\)!]) src=./$src;; esac if test -n "$dir_arg"; then dst=$src dstdir=$dst test -d "$dstdir" dstdir_status=$? else # Waiting for this to be detected by the "$cpprog $src $dsttmp" command # might cause directories to be created, which would be especially bad # if $src (and thus $dsttmp) contains '*'. if test ! -f "$src" && test ! -d "$src"; then echo "$0: $src does not exist." >&2 exit 1 fi if test -z "$dst_arg"; then echo "$0: no destination specified." >&2 exit 1 fi dst=$dst_arg # If destination is a directory, append the input filename; won't work # if double slashes aren't ignored. if test -d "$dst"; then if test "$is_target_a_directory" = never; then echo "$0: $dst_arg: Is a directory" >&2 exit 1 fi dstdir=$dst dst=$dstdir/`basename "$src"` dstdir_status=0 else dstdir=`dirname "$dst"` test -d "$dstdir" dstdir_status=$? fi fi obsolete_mkdir_used=false if test $dstdir_status != 0; then case $posix_mkdir in '') # Create intermediate dirs using mode 755 as modified by the umask. # This is like FreeBSD 'install' as of 1997-10-28. umask=`umask` case $stripcmd.$umask in # Optimize common cases. *[2367][2367]) mkdir_umask=$umask;; .*0[02][02] | .[02][02] | .[02]) mkdir_umask=22;; *[0-7]) mkdir_umask=`expr $umask + 22 \ - $umask % 100 % 40 + $umask % 20 \ - $umask % 10 % 4 + $umask % 2 `;; *) mkdir_umask=$umask,go-w;; esac # With -d, create the new directory with the user-specified mode. # Otherwise, rely on $mkdir_umask. if test -n "$dir_arg"; then mkdir_mode=-m$mode else mkdir_mode= fi posix_mkdir=false case $umask in *[123567][0-7][0-7]) # POSIX mkdir -p sets u+wx bits regardless of umask, which # is incompatible with FreeBSD 'install' when (umask & 300) != 0. ;; *) tmpdir=${TMPDIR-/tmp}/ins$RANDOM-$$ trap 'ret=$?; rmdir "$tmpdir/d" "$tmpdir" 2>/dev/null; exit $ret' 0 if (umask $mkdir_umask && exec $mkdirprog $mkdir_mode -p -- "$tmpdir/d") >/dev/null 2>&1 then if test -z "$dir_arg" || { # Check for POSIX incompatibilities with -m. # HP-UX 11.23 and IRIX 6.5 mkdir -m -p sets group- or # other-writable bit of parent directory when it shouldn't. # FreeBSD 6.1 mkdir -m -p sets mode of existing directory. ls_ld_tmpdir=`ls -ld "$tmpdir"` case $ls_ld_tmpdir in d????-?r-*) different_mode=700;; d????-?--*) different_mode=755;; *) false;; esac && $mkdirprog -m$different_mode -p -- "$tmpdir" && { ls_ld_tmpdir_1=`ls -ld "$tmpdir"` test "$ls_ld_tmpdir" = "$ls_ld_tmpdir_1" } } then posix_mkdir=: fi rmdir "$tmpdir/d" "$tmpdir" else # Remove any dirs left behind by ancient mkdir implementations. rmdir ./$mkdir_mode ./-p ./-- 2>/dev/null fi trap '' 0;; esac;; esac if $posix_mkdir && ( umask $mkdir_umask && $doit_exec $mkdirprog $mkdir_mode -p -- "$dstdir" ) then : else # The umask is ridiculous, or mkdir does not conform to POSIX, # or it failed possibly due to a race condition. Create the # directory the slow way, step by step, checking for races as we go. case $dstdir in /*) prefix='/';; [-=\(\)!]*) prefix='./';; *) prefix='';; esac oIFS=$IFS IFS=/ set -f set fnord $dstdir shift set +f IFS=$oIFS prefixes= for d do test X"$d" = X && continue prefix=$prefix$d if test -d "$prefix"; then prefixes= else if $posix_mkdir; then (umask=$mkdir_umask && $doit_exec $mkdirprog $mkdir_mode -p -- "$dstdir") && break # Don't fail if two instances are running concurrently. test -d "$prefix" || exit 1 else case $prefix in *\'*) qprefix=`echo "$prefix" | sed "s/'/'\\\\\\\\''/g"`;; *) qprefix=$prefix;; esac prefixes="$prefixes '$qprefix'" fi fi prefix=$prefix/ done if test -n "$prefixes"; then # Don't fail if two instances are running concurrently. (umask $mkdir_umask && eval "\$doit_exec \$mkdirprog $prefixes") || test -d "$dstdir" || exit 1 obsolete_mkdir_used=true fi fi fi if test -n "$dir_arg"; then { test -z "$chowncmd" || $doit $chowncmd "$dst"; } && { test -z "$chgrpcmd" || $doit $chgrpcmd "$dst"; } && { test "$obsolete_mkdir_used$chowncmd$chgrpcmd" = false || test -z "$chmodcmd" || $doit $chmodcmd $mode "$dst"; } || exit 1 else # Make a couple of temp file names in the proper directory. dsttmp=$dstdir/_inst.$$_ rmtmp=$dstdir/_rm.$$_ # Trap to clean up those temp files at exit. trap 'ret=$?; rm -f "$dsttmp" "$rmtmp" && exit $ret' 0 # Copy the file name to the temp name. (umask $cp_umask && $doit_exec $cpprog "$src" "$dsttmp") && # and set any options; do chmod last to preserve setuid bits. # # If any of these fail, we abort the whole thing. If we want to # ignore errors from any of these, just make sure not to ignore # errors from the above "$doit $cpprog $src $dsttmp" command. # { test -z "$chowncmd" || $doit $chowncmd "$dsttmp"; } && { test -z "$chgrpcmd" || $doit $chgrpcmd "$dsttmp"; } && { test -z "$stripcmd" || $doit $stripcmd "$dsttmp"; } && { test -z "$chmodcmd" || $doit $chmodcmd $mode "$dsttmp"; } && # If -C, don't bother to copy if it wouldn't change the file. if $copy_on_change && old=`LC_ALL=C ls -dlL "$dst" 2>/dev/null` && new=`LC_ALL=C ls -dlL "$dsttmp" 2>/dev/null` && set -f && set X $old && old=:$2:$4:$5:$6 && set X $new && new=:$2:$4:$5:$6 && set +f && test "$old" = "$new" && $cmpprog "$dst" "$dsttmp" >/dev/null 2>&1 then rm -f "$dsttmp" else # Rename the file to the real destination. $doit $mvcmd -f "$dsttmp" "$dst" 2>/dev/null || # The rename failed, perhaps because mv can't rename something else # to itself, or perhaps because mv is so ancient that it does not # support -f. { # Now remove or move aside any old file at destination location. # We try this two ways since rm can't unlink itself on some # systems and the destination file might be busy for other # reasons. In this case, the final cleanup might fail but the new # file should still install successfully. { test ! -f "$dst" || $doit $rmcmd -f "$dst" 2>/dev/null || { $doit $mvcmd -f "$dst" "$rmtmp" 2>/dev/null && { $doit $rmcmd -f "$rmtmp" 2>/dev/null; :; } } || { echo "$0: cannot unlink or rename $dst" >&2 (exit 1); exit 1 } } && # Now rename the file to the real destination. $doit $mvcmd "$dsttmp" "$dst" } fi || exit 1 trap '' 0 fi done # Local variables: # eval: (add-hook 'write-file-hooks 'time-stamp) # time-stamp-start: "scriptversion=" # time-stamp-format: "%:y-%02m-%02d.%02H" # time-stamp-time-zone: "UTC0" # time-stamp-end: "; # UTC" # End: xrdp-0.9.5/libpainter/m4/000755 001751 001751 00000000000 13220731016 015066 5ustar00metameta000000 000000 xrdp-0.9.5/libpainter/src/000755 001751 001751 00000000000 13220731016 015335 5ustar00metameta000000 000000 xrdp-0.9.5/libpainter/configure.ac000644 001751 001751 00000001524 13127342056 017046 0ustar00metameta000000 000000 # Process this file with autoconf to produce a configure script AC_PREREQ(2.59) AC_INIT([libpainter], [0.1.1], [xrdp-devel@googlegroups.com]) AC_CONFIG_HEADERS(config_ac.h:config_ac-h.in) AM_INIT_AUTOMAKE([1.6 foreign]) AC_CONFIG_MACRO_DIR([m4]) AC_PROG_CC AC_C_CONST AC_PROG_LIBTOOL PKG_INSTALLDIR # Use silent rules by default if supported by Automake m4_ifdef([AM_SILENT_RULES], [AM_SILENT_RULES([yes])]) AX_CFLAGS_WARN_ALL AX_APPEND_COMPILE_FLAGS([-Wwrite-strings]) AC_ARG_ENABLE(tests, AS_HELP_STRING([--enable-tests], [Build install tests (default: no)]), [], [enable_tests=no]) AM_CONDITIONAL(PT_TESTS, [test x$enable_tests = xyes]) AC_CONFIG_FILES([ Makefile include/Makefile pkgconfig/libpainter.pc pkgconfig/libpainter-uninstalled.pc pkgconfig/Makefile src/Makefile tests/Makefile ]) AC_OUTPUT xrdp-0.9.5/libpainter/depcomp000755 001751 001751 00000056017 13220730741 016140 0ustar00metameta000000 000000 #! /bin/sh # depcomp - compile a program generating dependencies as side-effects scriptversion=2016-01-11.22; # UTC # Copyright (C) 1999-2017 Free Software Foundation, Inc. # 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 2, 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. # You should have received a copy of the GNU General Public License # along with this program. If not, see . # As a special exception to the GNU General Public License, if you # distribute this file as part of a program that contains a # configuration script generated by Autoconf, you may include it under # the same distribution terms that you use for the rest of that program. # Originally written by Alexandre Oliva . case $1 in '') echo "$0: No command. Try '$0 --help' for more information." 1>&2 exit 1; ;; -h | --h*) cat <<\EOF Usage: depcomp [--help] [--version] PROGRAM [ARGS] Run PROGRAMS ARGS to compile a file, generating dependencies as side-effects. Environment variables: depmode Dependency tracking mode. source Source file read by 'PROGRAMS ARGS'. object Object file output by 'PROGRAMS ARGS'. DEPDIR directory where to store dependencies. depfile Dependency file to output. tmpdepfile Temporary file to use when outputting dependencies. libtool Whether libtool is used (yes/no). Report bugs to . EOF exit $? ;; -v | --v*) echo "depcomp $scriptversion" exit $? ;; esac # Get the directory component of the given path, and save it in the # global variables '$dir'. Note that this directory component will # be either empty or ending with a '/' character. This is deliberate. set_dir_from () { case $1 in */*) dir=`echo "$1" | sed -e 's|/[^/]*$|/|'`;; *) dir=;; esac } # Get the suffix-stripped basename of the given path, and save it the # global variable '$base'. set_base_from () { base=`echo "$1" | sed -e 's|^.*/||' -e 's/\.[^.]*$//'` } # If no dependency file was actually created by the compiler invocation, # we still have to create a dummy depfile, to avoid errors with the # Makefile "include basename.Plo" scheme. make_dummy_depfile () { echo "#dummy" > "$depfile" } # Factor out some common post-processing of the generated depfile. # Requires the auxiliary global variable '$tmpdepfile' to be set. aix_post_process_depfile () { # If the compiler actually managed to produce a dependency file, # post-process it. if test -f "$tmpdepfile"; then # Each line is of the form 'foo.o: dependency.h'. # Do two passes, one to just change these to # $object: dependency.h # and one to simply output # dependency.h: # which is needed to avoid the deleted-header problem. { sed -e "s,^.*\.[$lower]*:,$object:," < "$tmpdepfile" sed -e "s,^.*\.[$lower]*:[$tab ]*,," -e 's,$,:,' < "$tmpdepfile" } > "$depfile" rm -f "$tmpdepfile" else make_dummy_depfile fi } # A tabulation character. tab=' ' # A newline character. nl=' ' # Character ranges might be problematic outside the C locale. # These definitions help. upper=ABCDEFGHIJKLMNOPQRSTUVWXYZ lower=abcdefghijklmnopqrstuvwxyz digits=0123456789 alpha=${upper}${lower} if test -z "$depmode" || test -z "$source" || test -z "$object"; then echo "depcomp: Variables source, object and depmode must be set" 1>&2 exit 1 fi # Dependencies for sub/bar.o or sub/bar.obj go into sub/.deps/bar.Po. depfile=${depfile-`echo "$object" | sed 's|[^\\/]*$|'${DEPDIR-.deps}'/&|;s|\.\([^.]*\)$|.P\1|;s|Pobj$|Po|'`} tmpdepfile=${tmpdepfile-`echo "$depfile" | sed 's/\.\([^.]*\)$/.T\1/'`} rm -f "$tmpdepfile" # Avoid interferences from the environment. gccflag= dashmflag= # Some modes work just like other modes, but use different flags. We # parameterize here, but still list the modes in the big case below, # to make depend.m4 easier to write. Note that we *cannot* use a case # here, because this file can only contain one case statement. if test "$depmode" = hp; then # HP compiler uses -M and no extra arg. gccflag=-M depmode=gcc fi if test "$depmode" = dashXmstdout; then # This is just like dashmstdout with a different argument. dashmflag=-xM depmode=dashmstdout fi cygpath_u="cygpath -u -f -" if test "$depmode" = msvcmsys; then # This is just like msvisualcpp but w/o cygpath translation. # Just convert the backslash-escaped backslashes to single forward # slashes to satisfy depend.m4 cygpath_u='sed s,\\\\,/,g' depmode=msvisualcpp fi if test "$depmode" = msvc7msys; then # This is just like msvc7 but w/o cygpath translation. # Just convert the backslash-escaped backslashes to single forward # slashes to satisfy depend.m4 cygpath_u='sed s,\\\\,/,g' depmode=msvc7 fi if test "$depmode" = xlc; then # IBM C/C++ Compilers xlc/xlC can output gcc-like dependency information. gccflag=-qmakedep=gcc,-MF depmode=gcc fi case "$depmode" in gcc3) ## gcc 3 implements dependency tracking that does exactly what ## we want. Yay! Note: for some reason libtool 1.4 doesn't like ## it if -MD -MP comes after the -MF stuff. Hmm. ## Unfortunately, FreeBSD c89 acceptance of flags depends upon ## the command line argument order; so add the flags where they ## appear in depend2.am. Note that the slowdown incurred here ## affects only configure: in makefiles, %FASTDEP% shortcuts this. for arg do case $arg in -c) set fnord "$@" -MT "$object" -MD -MP -MF "$tmpdepfile" "$arg" ;; *) set fnord "$@" "$arg" ;; esac shift # fnord shift # $arg done "$@" stat=$? if test $stat -ne 0; then rm -f "$tmpdepfile" exit $stat fi mv "$tmpdepfile" "$depfile" ;; gcc) ## Note that this doesn't just cater to obsosete pre-3.x GCC compilers. ## but also to in-use compilers like IMB xlc/xlC and the HP C compiler. ## (see the conditional assignment to $gccflag above). ## There are various ways to get dependency output from gcc. Here's ## why we pick this rather obscure method: ## - Don't want to use -MD because we'd like the dependencies to end ## up in a subdir. Having to rename by hand is ugly. ## (We might end up doing this anyway to support other compilers.) ## - The DEPENDENCIES_OUTPUT environment variable makes gcc act like ## -MM, not -M (despite what the docs say). Also, it might not be ## supported by the other compilers which use the 'gcc' depmode. ## - Using -M directly means running the compiler twice (even worse ## than renaming). if test -z "$gccflag"; then gccflag=-MD, fi "$@" -Wp,"$gccflag$tmpdepfile" stat=$? if test $stat -ne 0; then rm -f "$tmpdepfile" exit $stat fi rm -f "$depfile" echo "$object : \\" > "$depfile" # The second -e expression handles DOS-style file names with drive # letters. sed -e 's/^[^:]*: / /' \ -e 's/^['$alpha']:\/[^:]*: / /' < "$tmpdepfile" >> "$depfile" ## This next piece of magic avoids the "deleted header file" problem. ## The problem is that when a header file which appears in a .P file ## is deleted, the dependency causes make to die (because there is ## typically no way to rebuild the header). We avoid this by adding ## dummy dependencies for each header file. Too bad gcc doesn't do ## this for us directly. ## Some versions of gcc put a space before the ':'. On the theory ## that the space means something, we add a space to the output as ## well. hp depmode also adds that space, but also prefixes the VPATH ## to the object. Take care to not repeat it in the output. ## Some versions of the HPUX 10.20 sed can't process this invocation ## correctly. Breaking it into two sed invocations is a workaround. tr ' ' "$nl" < "$tmpdepfile" \ | sed -e 's/^\\$//' -e '/^$/d' -e "s|.*$object$||" -e '/:$/d' \ | sed -e 's/$/ :/' >> "$depfile" rm -f "$tmpdepfile" ;; hp) # This case exists only to let depend.m4 do its work. It works by # looking at the text of this script. This case will never be run, # since it is checked for above. exit 1 ;; sgi) if test "$libtool" = yes; then "$@" "-Wp,-MDupdate,$tmpdepfile" else "$@" -MDupdate "$tmpdepfile" fi stat=$? if test $stat -ne 0; then rm -f "$tmpdepfile" exit $stat fi rm -f "$depfile" if test -f "$tmpdepfile"; then # yes, the sourcefile depend on other files echo "$object : \\" > "$depfile" # Clip off the initial element (the dependent). Don't try to be # clever and replace this with sed code, as IRIX sed won't handle # lines with more than a fixed number of characters (4096 in # IRIX 6.2 sed, 8192 in IRIX 6.5). We also remove comment lines; # the IRIX cc adds comments like '#:fec' to the end of the # dependency line. tr ' ' "$nl" < "$tmpdepfile" \ | sed -e 's/^.*\.o://' -e 's/#.*$//' -e '/^$/ d' \ | tr "$nl" ' ' >> "$depfile" echo >> "$depfile" # The second pass generates a dummy entry for each header file. tr ' ' "$nl" < "$tmpdepfile" \ | sed -e 's/^.*\.o://' -e 's/#.*$//' -e '/^$/ d' -e 's/$/:/' \ >> "$depfile" else make_dummy_depfile fi rm -f "$tmpdepfile" ;; xlc) # This case exists only to let depend.m4 do its work. It works by # looking at the text of this script. This case will never be run, # since it is checked for above. exit 1 ;; aix) # The C for AIX Compiler uses -M and outputs the dependencies # in a .u file. In older versions, this file always lives in the # current directory. Also, the AIX compiler puts '$object:' at the # start of each line; $object doesn't have directory information. # Version 6 uses the directory in both cases. set_dir_from "$object" set_base_from "$object" if test "$libtool" = yes; then tmpdepfile1=$dir$base.u tmpdepfile2=$base.u tmpdepfile3=$dir.libs/$base.u "$@" -Wc,-M else tmpdepfile1=$dir$base.u tmpdepfile2=$dir$base.u tmpdepfile3=$dir$base.u "$@" -M fi stat=$? if test $stat -ne 0; then rm -f "$tmpdepfile1" "$tmpdepfile2" "$tmpdepfile3" exit $stat fi for tmpdepfile in "$tmpdepfile1" "$tmpdepfile2" "$tmpdepfile3" do test -f "$tmpdepfile" && break done aix_post_process_depfile ;; tcc) # tcc (Tiny C Compiler) understand '-MD -MF file' since version 0.9.26 # FIXME: That version still under development at the moment of writing. # Make that this statement remains true also for stable, released # versions. # It will wrap lines (doesn't matter whether long or short) with a # trailing '\', as in: # # foo.o : \ # foo.c \ # foo.h \ # # It will put a trailing '\' even on the last line, and will use leading # spaces rather than leading tabs (at least since its commit 0394caf7 # "Emit spaces for -MD"). "$@" -MD -MF "$tmpdepfile" stat=$? if test $stat -ne 0; then rm -f "$tmpdepfile" exit $stat fi rm -f "$depfile" # Each non-empty line is of the form 'foo.o : \' or ' dep.h \'. # We have to change lines of the first kind to '$object: \'. sed -e "s|.*:|$object :|" < "$tmpdepfile" > "$depfile" # And for each line of the second kind, we have to emit a 'dep.h:' # dummy dependency, to avoid the deleted-header problem. sed -n -e 's|^ *\(.*\) *\\$|\1:|p' < "$tmpdepfile" >> "$depfile" rm -f "$tmpdepfile" ;; ## The order of this option in the case statement is important, since the ## shell code in configure will try each of these formats in the order ## listed in this file. A plain '-MD' option would be understood by many ## compilers, so we must ensure this comes after the gcc and icc options. pgcc) # Portland's C compiler understands '-MD'. # Will always output deps to 'file.d' where file is the root name of the # source file under compilation, even if file resides in a subdirectory. # The object file name does not affect the name of the '.d' file. # pgcc 10.2 will output # foo.o: sub/foo.c sub/foo.h # and will wrap long lines using '\' : # foo.o: sub/foo.c ... \ # sub/foo.h ... \ # ... set_dir_from "$object" # Use the source, not the object, to determine the base name, since # that's sadly what pgcc will do too. set_base_from "$source" tmpdepfile=$base.d # For projects that build the same source file twice into different object # files, the pgcc approach of using the *source* file root name can cause # problems in parallel builds. Use a locking strategy to avoid stomping on # the same $tmpdepfile. lockdir=$base.d-lock trap " echo '$0: caught signal, cleaning up...' >&2 rmdir '$lockdir' exit 1 " 1 2 13 15 numtries=100 i=$numtries while test $i -gt 0; do # mkdir is a portable test-and-set. if mkdir "$lockdir" 2>/dev/null; then # This process acquired the lock. "$@" -MD stat=$? # Release the lock. rmdir "$lockdir" break else # If the lock is being held by a different process, wait # until the winning process is done or we timeout. while test -d "$lockdir" && test $i -gt 0; do sleep 1 i=`expr $i - 1` done fi i=`expr $i - 1` done trap - 1 2 13 15 if test $i -le 0; then echo "$0: failed to acquire lock after $numtries attempts" >&2 echo "$0: check lockdir '$lockdir'" >&2 exit 1 fi if test $stat -ne 0; then rm -f "$tmpdepfile" exit $stat fi rm -f "$depfile" # Each line is of the form `foo.o: dependent.h', # or `foo.o: dep1.h dep2.h \', or ` dep3.h dep4.h \'. # Do two passes, one to just change these to # `$object: dependent.h' and one to simply `dependent.h:'. sed "s,^[^:]*:,$object :," < "$tmpdepfile" > "$depfile" # Some versions of the HPUX 10.20 sed can't process this invocation # correctly. Breaking it into two sed invocations is a workaround. sed 's,^[^:]*: \(.*\)$,\1,;s/^\\$//;/^$/d;/:$/d' < "$tmpdepfile" \ | sed -e 's/$/ :/' >> "$depfile" rm -f "$tmpdepfile" ;; hp2) # The "hp" stanza above does not work with aCC (C++) and HP's ia64 # compilers, which have integrated preprocessors. The correct option # to use with these is +Maked; it writes dependencies to a file named # 'foo.d', which lands next to the object file, wherever that # happens to be. # Much of this is similar to the tru64 case; see comments there. set_dir_from "$object" set_base_from "$object" if test "$libtool" = yes; then tmpdepfile1=$dir$base.d tmpdepfile2=$dir.libs/$base.d "$@" -Wc,+Maked else tmpdepfile1=$dir$base.d tmpdepfile2=$dir$base.d "$@" +Maked fi stat=$? if test $stat -ne 0; then rm -f "$tmpdepfile1" "$tmpdepfile2" exit $stat fi for tmpdepfile in "$tmpdepfile1" "$tmpdepfile2" do test -f "$tmpdepfile" && break done if test -f "$tmpdepfile"; then sed -e "s,^.*\.[$lower]*:,$object:," "$tmpdepfile" > "$depfile" # Add 'dependent.h:' lines. sed -ne '2,${ s/^ *// s/ \\*$// s/$/:/ p }' "$tmpdepfile" >> "$depfile" else make_dummy_depfile fi rm -f "$tmpdepfile" "$tmpdepfile2" ;; tru64) # The Tru64 compiler uses -MD to generate dependencies as a side # effect. 'cc -MD -o foo.o ...' puts the dependencies into 'foo.o.d'. # At least on Alpha/Redhat 6.1, Compaq CCC V6.2-504 seems to put # dependencies in 'foo.d' instead, so we check for that too. # Subdirectories are respected. set_dir_from "$object" set_base_from "$object" if test "$libtool" = yes; then # Libtool generates 2 separate objects for the 2 libraries. These # two compilations output dependencies in $dir.libs/$base.o.d and # in $dir$base.o.d. We have to check for both files, because # one of the two compilations can be disabled. We should prefer # $dir$base.o.d over $dir.libs/$base.o.d because the latter is # automatically cleaned when .libs/ is deleted, while ignoring # the former would cause a distcleancheck panic. tmpdepfile1=$dir$base.o.d # libtool 1.5 tmpdepfile2=$dir.libs/$base.o.d # Likewise. tmpdepfile3=$dir.libs/$base.d # Compaq CCC V6.2-504 "$@" -Wc,-MD else tmpdepfile1=$dir$base.d tmpdepfile2=$dir$base.d tmpdepfile3=$dir$base.d "$@" -MD fi stat=$? if test $stat -ne 0; then rm -f "$tmpdepfile1" "$tmpdepfile2" "$tmpdepfile3" exit $stat fi for tmpdepfile in "$tmpdepfile1" "$tmpdepfile2" "$tmpdepfile3" do test -f "$tmpdepfile" && break done # Same post-processing that is required for AIX mode. aix_post_process_depfile ;; msvc7) if test "$libtool" = yes; then showIncludes=-Wc,-showIncludes else showIncludes=-showIncludes fi "$@" $showIncludes > "$tmpdepfile" stat=$? grep -v '^Note: including file: ' "$tmpdepfile" if test $stat -ne 0; then rm -f "$tmpdepfile" exit $stat fi rm -f "$depfile" echo "$object : \\" > "$depfile" # The first sed program below extracts the file names and escapes # backslashes for cygpath. The second sed program outputs the file # name when reading, but also accumulates all include files in the # hold buffer in order to output them again at the end. This only # works with sed implementations that can handle large buffers. sed < "$tmpdepfile" -n ' /^Note: including file: *\(.*\)/ { s//\1/ s/\\/\\\\/g p }' | $cygpath_u | sort -u | sed -n ' s/ /\\ /g s/\(.*\)/'"$tab"'\1 \\/p s/.\(.*\) \\/\1:/ H $ { s/.*/'"$tab"'/ G p }' >> "$depfile" echo >> "$depfile" # make sure the fragment doesn't end with a backslash rm -f "$tmpdepfile" ;; msvc7msys) # This case exists only to let depend.m4 do its work. It works by # looking at the text of this script. This case will never be run, # since it is checked for above. exit 1 ;; #nosideeffect) # This comment above is used by automake to tell side-effect # dependency tracking mechanisms from slower ones. dashmstdout) # Important note: in order to support this mode, a compiler *must* # always write the preprocessed file to stdout, regardless of -o. "$@" || exit $? # Remove the call to Libtool. if test "$libtool" = yes; then while test "X$1" != 'X--mode=compile'; do shift done shift fi # Remove '-o $object'. IFS=" " for arg do case $arg in -o) shift ;; $object) shift ;; *) set fnord "$@" "$arg" shift # fnord shift # $arg ;; esac done test -z "$dashmflag" && dashmflag=-M # Require at least two characters before searching for ':' # in the target name. This is to cope with DOS-style filenames: # a dependency such as 'c:/foo/bar' could be seen as target 'c' otherwise. "$@" $dashmflag | sed "s|^[$tab ]*[^:$tab ][^:][^:]*:[$tab ]*|$object: |" > "$tmpdepfile" rm -f "$depfile" cat < "$tmpdepfile" > "$depfile" # Some versions of the HPUX 10.20 sed can't process this sed invocation # correctly. Breaking it into two sed invocations is a workaround. tr ' ' "$nl" < "$tmpdepfile" \ | sed -e 's/^\\$//' -e '/^$/d' -e '/:$/d' \ | sed -e 's/$/ :/' >> "$depfile" rm -f "$tmpdepfile" ;; dashXmstdout) # This case only exists to satisfy depend.m4. It is never actually # run, as this mode is specially recognized in the preamble. exit 1 ;; makedepend) "$@" || exit $? # Remove any Libtool call if test "$libtool" = yes; then while test "X$1" != 'X--mode=compile'; do shift done shift fi # X makedepend shift cleared=no eat=no for arg do case $cleared in no) set ""; shift cleared=yes ;; esac if test $eat = yes; then eat=no continue fi case "$arg" in -D*|-I*) set fnord "$@" "$arg"; shift ;; # Strip any option that makedepend may not understand. Remove # the object too, otherwise makedepend will parse it as a source file. -arch) eat=yes ;; -*|$object) ;; *) set fnord "$@" "$arg"; shift ;; esac done obj_suffix=`echo "$object" | sed 's/^.*\././'` touch "$tmpdepfile" ${MAKEDEPEND-makedepend} -o"$obj_suffix" -f"$tmpdepfile" "$@" rm -f "$depfile" # makedepend may prepend the VPATH from the source file name to the object. # No need to regex-escape $object, excess matching of '.' is harmless. sed "s|^.*\($object *:\)|\1|" "$tmpdepfile" > "$depfile" # Some versions of the HPUX 10.20 sed can't process the last invocation # correctly. Breaking it into two sed invocations is a workaround. sed '1,2d' "$tmpdepfile" \ | tr ' ' "$nl" \ | sed -e 's/^\\$//' -e '/^$/d' -e '/:$/d' \ | sed -e 's/$/ :/' >> "$depfile" rm -f "$tmpdepfile" "$tmpdepfile".bak ;; cpp) # Important note: in order to support this mode, a compiler *must* # always write the preprocessed file to stdout. "$@" || exit $? # Remove the call to Libtool. if test "$libtool" = yes; then while test "X$1" != 'X--mode=compile'; do shift done shift fi # Remove '-o $object'. IFS=" " for arg do case $arg in -o) shift ;; $object) shift ;; *) set fnord "$@" "$arg" shift # fnord shift # $arg ;; esac done "$@" -E \ | sed -n -e '/^# [0-9][0-9]* "\([^"]*\)".*/ s:: \1 \\:p' \ -e '/^#line [0-9][0-9]* "\([^"]*\)".*/ s:: \1 \\:p' \ | sed '$ s: \\$::' > "$tmpdepfile" rm -f "$depfile" echo "$object : \\" > "$depfile" cat < "$tmpdepfile" >> "$depfile" sed < "$tmpdepfile" '/^$/d;s/^ //;s/ \\$//;s/$/ :/' >> "$depfile" rm -f "$tmpdepfile" ;; msvisualcpp) # Important note: in order to support this mode, a compiler *must* # always write the preprocessed file to stdout. "$@" || exit $? # Remove the call to Libtool. if test "$libtool" = yes; then while test "X$1" != 'X--mode=compile'; do shift done shift fi IFS=" " for arg do case "$arg" in -o) shift ;; $object) shift ;; "-Gm"|"/Gm"|"-Gi"|"/Gi"|"-ZI"|"/ZI") set fnord "$@" shift shift ;; *) set fnord "$@" "$arg" shift shift ;; esac done "$@" -E 2>/dev/null | sed -n '/^#line [0-9][0-9]* "\([^"]*\)"/ s::\1:p' | $cygpath_u | sort -u > "$tmpdepfile" rm -f "$depfile" echo "$object : \\" > "$depfile" sed < "$tmpdepfile" -n -e 's% %\\ %g' -e '/^\(.*\)$/ s::'"$tab"'\1 \\:p' >> "$depfile" echo "$tab" >> "$depfile" sed < "$tmpdepfile" -n -e 's% %\\ %g' -e '/^\(.*\)$/ s::\1\::p' >> "$depfile" rm -f "$tmpdepfile" ;; msvcmsys) # This case exists only to let depend.m4 do its work. It works by # looking at the text of this script. This case will never be run, # since it is checked for above. exit 1 ;; none) exec "$@" ;; *) echo "Unknown depmode $depmode" 1>&2 exit 1 ;; esac exit 0 # Local Variables: # mode: shell-script # sh-indentation: 2 # eval: (add-hook 'write-file-hooks 'time-stamp) # time-stamp-start: "scriptversion=" # time-stamp-format: "%:y-%02m-%02d.%02H" # time-stamp-time-zone: "UTC0" # time-stamp-end: "; # UTC" # End: xrdp-0.9.5/libpainter/missing000755 001751 001751 00000015331 13220730741 016154 0ustar00metameta000000 000000 #! /bin/sh # Common wrapper for a few potentially missing GNU programs. scriptversion=2016-01-11.22; # UTC # Copyright (C) 1996-2017 Free Software Foundation, Inc. # Originally written by Fran,cois Pinard , 1996. # 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 2, 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. # You should have received a copy of the GNU General Public License # along with this program. If not, see . # As a special exception to the GNU General Public License, if you # distribute this file as part of a program that contains a # configuration script generated by Autoconf, you may include it under # the same distribution terms that you use for the rest of that program. if test $# -eq 0; then echo 1>&2 "Try '$0 --help' for more information" exit 1 fi case $1 in --is-lightweight) # Used by our autoconf macros to check whether the available missing # script is modern enough. exit 0 ;; --run) # Back-compat with the calling convention used by older automake. shift ;; -h|--h|--he|--hel|--help) echo "\ $0 [OPTION]... PROGRAM [ARGUMENT]... Run 'PROGRAM [ARGUMENT]...', returning a proper advice when this fails due to PROGRAM being missing or too old. Options: -h, --help display this help and exit -v, --version output version information and exit Supported PROGRAM values: aclocal autoconf autoheader autom4te automake makeinfo bison yacc flex lex help2man Version suffixes to PROGRAM as well as the prefixes 'gnu-', 'gnu', and 'g' are ignored when checking the name. Send bug reports to ." exit $? ;; -v|--v|--ve|--ver|--vers|--versi|--versio|--version) echo "missing $scriptversion (GNU Automake)" exit $? ;; -*) echo 1>&2 "$0: unknown '$1' option" echo 1>&2 "Try '$0 --help' for more information" exit 1 ;; esac # Run the given program, remember its exit status. "$@"; st=$? # If it succeeded, we are done. test $st -eq 0 && exit 0 # Also exit now if we it failed (or wasn't found), and '--version' was # passed; such an option is passed most likely to detect whether the # program is present and works. case $2 in --version|--help) exit $st;; esac # Exit code 63 means version mismatch. This often happens when the user # tries to use an ancient version of a tool on a file that requires a # minimum version. if test $st -eq 63; then msg="probably too old" elif test $st -eq 127; then # Program was missing. msg="missing on your system" else # Program was found and executed, but failed. Give up. exit $st fi perl_URL=http://www.perl.org/ flex_URL=http://flex.sourceforge.net/ gnu_software_URL=http://www.gnu.org/software program_details () { case $1 in aclocal|automake) echo "The '$1' program is part of the GNU Automake package:" echo "<$gnu_software_URL/automake>" echo "It also requires GNU Autoconf, GNU m4 and Perl in order to run:" echo "<$gnu_software_URL/autoconf>" echo "<$gnu_software_URL/m4/>" echo "<$perl_URL>" ;; autoconf|autom4te|autoheader) echo "The '$1' program is part of the GNU Autoconf package:" echo "<$gnu_software_URL/autoconf/>" echo "It also requires GNU m4 and Perl in order to run:" echo "<$gnu_software_URL/m4/>" echo "<$perl_URL>" ;; esac } give_advice () { # Normalize program name to check for. normalized_program=`echo "$1" | sed ' s/^gnu-//; t s/^gnu//; t s/^g//; t'` printf '%s\n' "'$1' is $msg." configure_deps="'configure.ac' or m4 files included by 'configure.ac'" case $normalized_program in autoconf*) echo "You should only need it if you modified 'configure.ac'," echo "or m4 files included by it." program_details 'autoconf' ;; autoheader*) echo "You should only need it if you modified 'acconfig.h' or" echo "$configure_deps." program_details 'autoheader' ;; automake*) echo "You should only need it if you modified 'Makefile.am' or" echo "$configure_deps." program_details 'automake' ;; aclocal*) echo "You should only need it if you modified 'acinclude.m4' or" echo "$configure_deps." program_details 'aclocal' ;; autom4te*) echo "You might have modified some maintainer files that require" echo "the 'autom4te' program to be rebuilt." program_details 'autom4te' ;; bison*|yacc*) echo "You should only need it if you modified a '.y' file." echo "You may want to install the GNU Bison package:" echo "<$gnu_software_URL/bison/>" ;; lex*|flex*) echo "You should only need it if you modified a '.l' file." echo "You may want to install the Fast Lexical Analyzer package:" echo "<$flex_URL>" ;; help2man*) echo "You should only need it if you modified a dependency" \ "of a man page." echo "You may want to install the GNU Help2man package:" echo "<$gnu_software_URL/help2man/>" ;; makeinfo*) echo "You should only need it if you modified a '.texi' file, or" echo "any other file indirectly affecting the aspect of the manual." echo "You might want to install the Texinfo package:" echo "<$gnu_software_URL/texinfo/>" echo "The spurious makeinfo call might also be the consequence of" echo "using a buggy 'make' (AIX, DU, IRIX), in which case you might" echo "want to install GNU make:" echo "<$gnu_software_URL/make/>" ;; *) echo "You might have modified some files without having the proper" echo "tools for further handling them. Check the 'README' file, it" echo "often tells you about the needed prerequisites for installing" echo "this package. You may also peek at any GNU archive site, in" echo "case some other package contains this missing '$1' program." ;; esac } give_advice "$1" | sed -e '1s/^/WARNING: /' \ -e '2,$s/^/ /' >&2 # Propagate the correct exit status (expected to be 127 for a program # not found, 63 for a program that failed due to version mismatch). exit $st # Local variables: # eval: (add-hook 'write-file-hooks 'time-stamp) # time-stamp-start: "scriptversion=" # time-stamp-format: "%:y-%02m-%02d.%02H" # time-stamp-time-zone: "UTC0" # time-stamp-end: "; # UTC" # End: xrdp-0.9.5/libpainter/include/000755 001751 001751 00000000000 13220731016 016171 5ustar00metameta000000 000000 xrdp-0.9.5/libpainter/ltmain.sh000644 001751 001751 00001170771 13220730731 016407 0ustar00metameta000000 000000 #! /bin/sh ## DO NOT EDIT - This file generated from ./build-aux/ltmain.in ## by inline-source v2014-01-03.01 # libtool (GNU libtool) 2.4.6 # Provide generalized library-building support services. # Written by Gordon Matzigkeit , 1996 # Copyright (C) 1996-2015 Free Software Foundation, Inc. # This is free software; see the source for copying conditions. There is NO # warranty; not even for MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. # GNU Libtool 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 2 of the License, or # (at your option) any later version. # # As a special exception to the GNU General Public License, # if you distribute this file as part of a program or library that # is built using GNU Libtool, you may include this file under the # same distribution terms that you use for the rest of that program. # # GNU Libtool 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. # # You should have received a copy of the GNU General Public License # along with this program. If not, see . PROGRAM=libtool PACKAGE=libtool VERSION=2.4.6 package_revision=2.4.6 ## ------ ## ## Usage. ## ## ------ ## # Run './libtool --help' for help with using this script from the # command line. ## ------------------------------- ## ## User overridable command paths. ## ## ------------------------------- ## # After configure completes, it has a better idea of some of the # shell tools we need than the defaults used by the functions shared # with bootstrap, so set those here where they can still be over- # ridden by the user, but otherwise take precedence. : ${AUTOCONF="autoconf"} : ${AUTOMAKE="automake"} ## -------------------------- ## ## Source external libraries. ## ## -------------------------- ## # Much of our low-level functionality needs to be sourced from external # libraries, which are installed to $pkgauxdir. # Set a version string for this script. scriptversion=2015-01-20.17; # UTC # General shell script boiler plate, and helper functions. # Written by Gary V. Vaughan, 2004 # Copyright (C) 2004-2015 Free Software Foundation, Inc. # This is free software; see the source for copying conditions. There is NO # warranty; not even for MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. # 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. # As a special exception to the GNU General Public License, if you distribute # this file as part of a program or library that is built using GNU Libtool, # you may include this file under the same distribution terms that you use # for the rest of that program. # This program is distributed in the hope that it will be useful, # but WITHOUT ANY WARRANTY; without even the implied warranty of # MERCHANTABILITY or FITNES FOR A PARTICULAR PURPOSE. See the GNU # General Public License for more details. # You should have received a copy of the GNU General Public License # along with this program. If not, see . # Please report bugs or propose patches to gary@gnu.org. ## ------ ## ## Usage. ## ## ------ ## # Evaluate this file near the top of your script to gain access to # the functions and variables defined here: # # . `echo "$0" | ${SED-sed} 's|[^/]*$||'`/build-aux/funclib.sh # # If you need to override any of the default environment variable # settings, do that before evaluating this file. ## -------------------- ## ## Shell normalisation. ## ## -------------------- ## # Some shells need a little help to be as Bourne compatible as possible. # Before doing anything else, make sure all that help has been provided! DUALCASE=1; export DUALCASE # for MKS sh if test -n "${ZSH_VERSION+set}" && (emulate sh) >/dev/null 2>&1; then : emulate sh NULLCMD=: # Pre-4.2 versions of Zsh do word splitting on ${1+"$@"}, which # is contrary to our usage. Disable this feature. alias -g '${1+"$@"}'='"$@"' setopt NO_GLOB_SUBST else case `(set -o) 2>/dev/null` in *posix*) set -o posix ;; esac fi # NLS nuisances: We save the old values in case they are required later. _G_user_locale= _G_safe_locale= for _G_var in LANG LANGUAGE LC_ALL LC_CTYPE LC_COLLATE LC_MESSAGES do eval "if test set = \"\${$_G_var+set}\"; then save_$_G_var=\$$_G_var $_G_var=C export $_G_var _G_user_locale=\"$_G_var=\\\$save_\$_G_var; \$_G_user_locale\" _G_safe_locale=\"$_G_var=C; \$_G_safe_locale\" fi" done # CDPATH. (unset CDPATH) >/dev/null 2>&1 && unset CDPATH # Make sure IFS has a sensible default sp=' ' nl=' ' IFS="$sp $nl" # There are apparently some retarded systems that use ';' as a PATH separator! if test "${PATH_SEPARATOR+set}" != set; then PATH_SEPARATOR=: (PATH='/bin;/bin'; FPATH=$PATH; sh -c :) >/dev/null 2>&1 && { (PATH='/bin:/bin'; FPATH=$PATH; sh -c :) >/dev/null 2>&1 || PATH_SEPARATOR=';' } fi ## ------------------------- ## ## Locate command utilities. ## ## ------------------------- ## # func_executable_p FILE # ---------------------- # Check that FILE is an executable regular file. func_executable_p () { test -f "$1" && test -x "$1" } # func_path_progs PROGS_LIST CHECK_FUNC [PATH] # -------------------------------------------- # Search for either a program that responds to --version with output # containing "GNU", or else returned by CHECK_FUNC otherwise, by # trying all the directories in PATH with each of the elements of # PROGS_LIST. # # CHECK_FUNC should accept the path to a candidate program, and # set $func_check_prog_result if it truncates its output less than # $_G_path_prog_max characters. func_path_progs () { _G_progs_list=$1 _G_check_func=$2 _G_PATH=${3-"$PATH"} _G_path_prog_max=0 _G_path_prog_found=false _G_save_IFS=$IFS; IFS=${PATH_SEPARATOR-:} for _G_dir in $_G_PATH; do IFS=$_G_save_IFS test -z "$_G_dir" && _G_dir=. for _G_prog_name in $_G_progs_list; do for _exeext in '' .EXE; do _G_path_prog=$_G_dir/$_G_prog_name$_exeext func_executable_p "$_G_path_prog" || continue case `"$_G_path_prog" --version 2>&1` in *GNU*) func_path_progs_result=$_G_path_prog _G_path_prog_found=: ;; *) $_G_check_func $_G_path_prog func_path_progs_result=$func_check_prog_result ;; esac $_G_path_prog_found && break 3 done done done IFS=$_G_save_IFS test -z "$func_path_progs_result" && { echo "no acceptable sed could be found in \$PATH" >&2 exit 1 } } # We want to be able to use the functions in this file before configure # has figured out where the best binaries are kept, which means we have # to search for them ourselves - except when the results are already set # where we skip the searches. # Unless the user overrides by setting SED, search the path for either GNU # sed, or the sed that truncates its output the least. test -z "$SED" && { _G_sed_script=s/aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa/bbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbb/ for _G_i in 1 2 3 4 5 6 7; do _G_sed_script=$_G_sed_script$nl$_G_sed_script done echo "$_G_sed_script" 2>/dev/null | sed 99q >conftest.sed _G_sed_script= func_check_prog_sed () { _G_path_prog=$1 _G_count=0 printf 0123456789 >conftest.in while : do cat conftest.in conftest.in >conftest.tmp mv conftest.tmp conftest.in cp conftest.in conftest.nl echo '' >> conftest.nl "$_G_path_prog" -f conftest.sed conftest.out 2>/dev/null || break diff conftest.out conftest.nl >/dev/null 2>&1 || break _G_count=`expr $_G_count + 1` if test "$_G_count" -gt "$_G_path_prog_max"; then # Best one so far, save it but keep looking for a better one func_check_prog_result=$_G_path_prog _G_path_prog_max=$_G_count fi # 10*(2^10) chars as input seems more than enough test 10 -lt "$_G_count" && break done rm -f conftest.in conftest.tmp conftest.nl conftest.out } func_path_progs "sed gsed" func_check_prog_sed $PATH:/usr/xpg4/bin rm -f conftest.sed SED=$func_path_progs_result } # Unless the user overrides by setting GREP, search the path for either GNU # grep, or the grep that truncates its output the least. test -z "$GREP" && { func_check_prog_grep () { _G_path_prog=$1 _G_count=0 _G_path_prog_max=0 printf 0123456789 >conftest.in while : do cat conftest.in conftest.in >conftest.tmp mv conftest.tmp conftest.in cp conftest.in conftest.nl echo 'GREP' >> conftest.nl "$_G_path_prog" -e 'GREP$' -e '-(cannot match)-' conftest.out 2>/dev/null || break diff conftest.out conftest.nl >/dev/null 2>&1 || break _G_count=`expr $_G_count + 1` if test "$_G_count" -gt "$_G_path_prog_max"; then # Best one so far, save it but keep looking for a better one func_check_prog_result=$_G_path_prog _G_path_prog_max=$_G_count fi # 10*(2^10) chars as input seems more than enough test 10 -lt "$_G_count" && break done rm -f conftest.in conftest.tmp conftest.nl conftest.out } func_path_progs "grep ggrep" func_check_prog_grep $PATH:/usr/xpg4/bin GREP=$func_path_progs_result } ## ------------------------------- ## ## User overridable command paths. ## ## ------------------------------- ## # All uppercase variable names are used for environment variables. These # variables can be overridden by the user before calling a script that # uses them if a suitable command of that name is not already available # in the command search PATH. : ${CP="cp -f"} : ${ECHO="printf %s\n"} : ${EGREP="$GREP -E"} : ${FGREP="$GREP -F"} : ${LN_S="ln -s"} : ${MAKE="make"} : ${MKDIR="mkdir"} : ${MV="mv -f"} : ${RM="rm -f"} : ${SHELL="${CONFIG_SHELL-/bin/sh}"} ## -------------------- ## ## Useful sed snippets. ## ## -------------------- ## sed_dirname='s|/[^/]*$||' sed_basename='s|^.*/||' # Sed substitution that helps us do robust quoting. It backslashifies # metacharacters that are still active within double-quoted strings. sed_quote_subst='s|\([`"$\\]\)|\\\1|g' # Same as above, but do not quote variable references. sed_double_quote_subst='s/\(["`\\]\)/\\\1/g' # Sed substitution that turns a string into a regex matching for the # string literally. sed_make_literal_regex='s|[].[^$\\*\/]|\\&|g' # Sed substitution that converts a w32 file name or path # that contains forward slashes, into one that contains # (escaped) backslashes. A very naive implementation. sed_naive_backslashify='s|\\\\*|\\|g;s|/|\\|g;s|\\|\\\\|g' # Re-'\' parameter expansions in output of sed_double_quote_subst that # were '\'-ed in input to the same. If an odd number of '\' preceded a # '$' in input to sed_double_quote_subst, that '$' was protected from # expansion. Since each input '\' is now two '\'s, look for any number # of runs of four '\'s followed by two '\'s and then a '$'. '\' that '$'. _G_bs='\\' _G_bs2='\\\\' _G_bs4='\\\\\\\\' _G_dollar='\$' sed_double_backslash="\ s/$_G_bs4/&\\ /g s/^$_G_bs2$_G_dollar/$_G_bs&/ s/\\([^$_G_bs]\\)$_G_bs2$_G_dollar/\\1$_G_bs2$_G_bs$_G_dollar/g s/\n//g" ## ----------------- ## ## Global variables. ## ## ----------------- ## # Except for the global variables explicitly listed below, the following # functions in the '^func_' namespace, and the '^require_' namespace # variables initialised in the 'Resource management' section, sourcing # this file will not pollute your global namespace with anything # else. There's no portable way to scope variables in Bourne shell # though, so actually running these functions will sometimes place # results into a variable named after the function, and often use # temporary variables in the '^_G_' namespace. If you are careful to # avoid using those namespaces casually in your sourcing script, things # should continue to work as you expect. And, of course, you can freely # overwrite any of the functions or variables defined here before # calling anything to customize them. EXIT_SUCCESS=0 EXIT_FAILURE=1 EXIT_MISMATCH=63 # $? = 63 is used to indicate version mismatch to missing. EXIT_SKIP=77 # $? = 77 is used to indicate a skipped test to automake. # Allow overriding, eg assuming that you follow the convention of # putting '$debug_cmd' at the start of all your functions, you can get # bash to show function call trace with: # # debug_cmd='eval echo "${FUNCNAME[0]} $*" >&2' bash your-script-name debug_cmd=${debug_cmd-":"} exit_cmd=: # By convention, finish your script with: # # exit $exit_status # # so that you can set exit_status to non-zero if you want to indicate # something went wrong during execution without actually bailing out at # the point of failure. exit_status=$EXIT_SUCCESS # Work around backward compatibility issue on IRIX 6.5. On IRIX 6.4+, sh # is ksh but when the shell is invoked as "sh" and the current value of # the _XPG environment variable is not equal to 1 (one), the special # positional parameter $0, within a function call, is the name of the # function. progpath=$0 # The name of this program. progname=`$ECHO "$progpath" |$SED "$sed_basename"` # Make sure we have an absolute progpath for reexecution: case $progpath in [\\/]*|[A-Za-z]:\\*) ;; *[\\/]*) progdir=`$ECHO "$progpath" |$SED "$sed_dirname"` progdir=`cd "$progdir" && pwd` progpath=$progdir/$progname ;; *) _G_IFS=$IFS IFS=${PATH_SEPARATOR-:} for progdir in $PATH; do IFS=$_G_IFS test -x "$progdir/$progname" && break done IFS=$_G_IFS test -n "$progdir" || progdir=`pwd` progpath=$progdir/$progname ;; esac ## ----------------- ## ## Standard options. ## ## ----------------- ## # The following options affect the operation of the functions defined # below, and should be set appropriately depending on run-time para- # meters passed on the command line. opt_dry_run=false opt_quiet=false opt_verbose=false # Categories 'all' and 'none' are always available. Append any others # you will pass as the first argument to func_warning from your own # code. warning_categories= # By default, display warnings according to 'opt_warning_types'. Set # 'warning_func' to ':' to elide all warnings, or func_fatal_error to # treat the next displayed warning as a fatal error. warning_func=func_warn_and_continue # Set to 'all' to display all warnings, 'none' to suppress all # warnings, or a space delimited list of some subset of # 'warning_categories' to display only the listed warnings. opt_warning_types=all ## -------------------- ## ## Resource management. ## ## -------------------- ## # This section contains definitions for functions that each ensure a # particular resource (a file, or a non-empty configuration variable for # example) is available, and if appropriate to extract default values # from pertinent package files. Call them using their associated # 'require_*' variable to ensure that they are executed, at most, once. # # It's entirely deliberate that calling these functions can set # variables that don't obey the namespace limitations obeyed by the rest # of this file, in order that that they be as useful as possible to # callers. # require_term_colors # ------------------- # Allow display of bold text on terminals that support it. require_term_colors=func_require_term_colors func_require_term_colors () { $debug_cmd test -t 1 && { # COLORTERM and USE_ANSI_COLORS environment variables take # precedence, because most terminfo databases neglect to describe # whether color sequences are supported. test -n "${COLORTERM+set}" && : ${USE_ANSI_COLORS="1"} if test 1 = "$USE_ANSI_COLORS"; then # Standard ANSI escape sequences tc_reset='' tc_bold=''; tc_standout='' tc_red=''; tc_green='' tc_blue=''; tc_cyan='' else # Otherwise trust the terminfo database after all. test -n "`tput sgr0 2>/dev/null`" && { tc_reset=`tput sgr0` test -n "`tput bold 2>/dev/null`" && tc_bold=`tput bold` tc_standout=$tc_bold test -n "`tput smso 2>/dev/null`" && tc_standout=`tput smso` test -n "`tput setaf 1 2>/dev/null`" && tc_red=`tput setaf 1` test -n "`tput setaf 2 2>/dev/null`" && tc_green=`tput setaf 2` test -n "`tput setaf 4 2>/dev/null`" && tc_blue=`tput setaf 4` test -n "`tput setaf 5 2>/dev/null`" && tc_cyan=`tput setaf 5` } fi } require_term_colors=: } ## ----------------- ## ## Function library. ## ## ----------------- ## # This section contains a variety of useful functions to call in your # scripts. Take note of the portable wrappers for features provided by # some modern shells, which will fall back to slower equivalents on # less featureful shells. # func_append VAR VALUE # --------------------- # Append VALUE onto the existing contents of VAR. # We should try to minimise forks, especially on Windows where they are # unreasonably slow, so skip the feature probes when bash or zsh are # being used: if test set = "${BASH_VERSION+set}${ZSH_VERSION+set}"; then : ${_G_HAVE_ARITH_OP="yes"} : ${_G_HAVE_XSI_OPS="yes"} # The += operator was introduced in bash 3.1 case $BASH_VERSION in [12].* | 3.0 | 3.0*) ;; *) : ${_G_HAVE_PLUSEQ_OP="yes"} ;; esac fi # _G_HAVE_PLUSEQ_OP # Can be empty, in which case the shell is probed, "yes" if += is # useable or anything else if it does not work. test -z "$_G_HAVE_PLUSEQ_OP" \ && (eval 'x=a; x+=" b"; test "a b" = "$x"') 2>/dev/null \ && _G_HAVE_PLUSEQ_OP=yes if test yes = "$_G_HAVE_PLUSEQ_OP" then # This is an XSI compatible shell, allowing a faster implementation... eval 'func_append () { $debug_cmd eval "$1+=\$2" }' else # ...otherwise fall back to using expr, which is often a shell builtin. func_append () { $debug_cmd eval "$1=\$$1\$2" } fi # func_append_quoted VAR VALUE # ---------------------------- # Quote VALUE and append to the end of shell variable VAR, separated # by a space. if test yes = "$_G_HAVE_PLUSEQ_OP"; then eval 'func_append_quoted () { $debug_cmd func_quote_for_eval "$2" eval "$1+=\\ \$func_quote_for_eval_result" }' else func_append_quoted () { $debug_cmd func_quote_for_eval "$2" eval "$1=\$$1\\ \$func_quote_for_eval_result" } fi # func_append_uniq VAR VALUE # -------------------------- # Append unique VALUE onto the existing contents of VAR, assuming # entries are delimited by the first character of VALUE. For example: # # func_append_uniq options " --another-option option-argument" # # will only append to $options if " --another-option option-argument " # is not already present somewhere in $options already (note spaces at # each end implied by leading space in second argument). func_append_uniq () { $debug_cmd eval _G_current_value='`$ECHO $'$1'`' _G_delim=`expr "$2" : '\(.\)'` case $_G_delim$_G_current_value$_G_delim in *"$2$_G_delim"*) ;; *) func_append "$@" ;; esac } # func_arith TERM... # ------------------ # Set func_arith_result to the result of evaluating TERMs. test -z "$_G_HAVE_ARITH_OP" \ && (eval 'test 2 = $(( 1 + 1 ))') 2>/dev/null \ && _G_HAVE_ARITH_OP=yes if test yes = "$_G_HAVE_ARITH_OP"; then eval 'func_arith () { $debug_cmd func_arith_result=$(( $* )) }' else func_arith () { $debug_cmd func_arith_result=`expr "$@"` } fi # func_basename FILE # ------------------ # Set func_basename_result to FILE with everything up to and including # the last / stripped. if test yes = "$_G_HAVE_XSI_OPS"; then # If this shell supports suffix pattern removal, then use it to avoid # forking. Hide the definitions single quotes in case the shell chokes # on unsupported syntax... _b='func_basename_result=${1##*/}' _d='case $1 in */*) func_dirname_result=${1%/*}$2 ;; * ) func_dirname_result=$3 ;; esac' else # ...otherwise fall back to using sed. _b='func_basename_result=`$ECHO "$1" |$SED "$sed_basename"`' _d='func_dirname_result=`$ECHO "$1" |$SED "$sed_dirname"` if test "X$func_dirname_result" = "X$1"; then func_dirname_result=$3 else func_append func_dirname_result "$2" fi' fi eval 'func_basename () { $debug_cmd '"$_b"' }' # func_dirname FILE APPEND NONDIR_REPLACEMENT # ------------------------------------------- # Compute the dirname of FILE. If nonempty, add APPEND to the result, # otherwise set result to NONDIR_REPLACEMENT. eval 'func_dirname () { $debug_cmd '"$_d"' }' # func_dirname_and_basename FILE APPEND NONDIR_REPLACEMENT # -------------------------------------------------------- # Perform func_basename and func_dirname in a single function # call: # dirname: Compute the dirname of FILE. If nonempty, # add APPEND to the result, otherwise set result # to NONDIR_REPLACEMENT. # value returned in "$func_dirname_result" # basename: Compute filename of FILE. # value retuned in "$func_basename_result" # For efficiency, we do not delegate to the functions above but instead # duplicate the functionality here. eval 'func_dirname_and_basename () { $debug_cmd '"$_b"' '"$_d"' }' # func_echo ARG... # ---------------- # Echo program name prefixed message. func_echo () { $debug_cmd _G_message=$* func_echo_IFS=$IFS IFS=$nl for _G_line in $_G_message; do IFS=$func_echo_IFS $ECHO "$progname: $_G_line" done IFS=$func_echo_IFS } # func_echo_all ARG... # -------------------- # Invoke $ECHO with all args, space-separated. func_echo_all () { $ECHO "$*" } # func_echo_infix_1 INFIX ARG... # ------------------------------ # Echo program name, followed by INFIX on the first line, with any # additional lines not showing INFIX. func_echo_infix_1 () { $debug_cmd $require_term_colors _G_infix=$1; shift _G_indent=$_G_infix _G_prefix="$progname: $_G_infix: " _G_message=$* # Strip color escape sequences before counting printable length for _G_tc in "$tc_reset" "$tc_bold" "$tc_standout" "$tc_red" "$tc_green" "$tc_blue" "$tc_cyan" do test -n "$_G_tc" && { _G_esc_tc=`$ECHO "$_G_tc" | $SED "$sed_make_literal_regex"` _G_indent=`$ECHO "$_G_indent" | $SED "s|$_G_esc_tc||g"` } done _G_indent="$progname: "`echo "$_G_indent" | $SED 's|.| |g'`" " ## exclude from sc_prohibit_nested_quotes func_echo_infix_1_IFS=$IFS IFS=$nl for _G_line in $_G_message; do IFS=$func_echo_infix_1_IFS $ECHO "$_G_prefix$tc_bold$_G_line$tc_reset" >&2 _G_prefix=$_G_indent done IFS=$func_echo_infix_1_IFS } # func_error ARG... # ----------------- # Echo program name prefixed message to standard error. func_error () { $debug_cmd $require_term_colors func_echo_infix_1 " $tc_standout${tc_red}error$tc_reset" "$*" >&2 } # func_fatal_error ARG... # ----------------------- # Echo program name prefixed message to standard error, and exit. func_fatal_error () { $debug_cmd func_error "$*" exit $EXIT_FAILURE } # func_grep EXPRESSION FILENAME # ----------------------------- # Check whether EXPRESSION matches any line of FILENAME, without output. func_grep () { $debug_cmd $GREP "$1" "$2" >/dev/null 2>&1 } # func_len STRING # --------------- # Set func_len_result to the length of STRING. STRING may not # start with a hyphen. test -z "$_G_HAVE_XSI_OPS" \ && (eval 'x=a/b/c; test 5aa/bb/cc = "${#x}${x%%/*}${x%/*}${x#*/}${x##*/}"') 2>/dev/null \ && _G_HAVE_XSI_OPS=yes if test yes = "$_G_HAVE_XSI_OPS"; then eval 'func_len () { $debug_cmd func_len_result=${#1} }' else func_len () { $debug_cmd func_len_result=`expr "$1" : ".*" 2>/dev/null || echo $max_cmd_len` } fi # func_mkdir_p DIRECTORY-PATH # --------------------------- # Make sure the entire path to DIRECTORY-PATH is available. func_mkdir_p () { $debug_cmd _G_directory_path=$1 _G_dir_list= if test -n "$_G_directory_path" && test : != "$opt_dry_run"; then # Protect directory names starting with '-' case $_G_directory_path in -*) _G_directory_path=./$_G_directory_path ;; esac # While some portion of DIR does not yet exist... while test ! -d "$_G_directory_path"; do # ...make a list in topmost first order. Use a colon delimited # list incase some portion of path contains whitespace. _G_dir_list=$_G_directory_path:$_G_dir_list # If the last portion added has no slash in it, the list is done case $_G_directory_path in */*) ;; *) break ;; esac # ...otherwise throw away the child directory and loop _G_directory_path=`$ECHO "$_G_directory_path" | $SED -e "$sed_dirname"` done _G_dir_list=`$ECHO "$_G_dir_list" | $SED 's|:*$||'` func_mkdir_p_IFS=$IFS; IFS=: for _G_dir in $_G_dir_list; do IFS=$func_mkdir_p_IFS # mkdir can fail with a 'File exist' error if two processes # try to create one of the directories concurrently. Don't # stop in that case! $MKDIR "$_G_dir" 2>/dev/null || : done IFS=$func_mkdir_p_IFS # Bail out if we (or some other process) failed to create a directory. test -d "$_G_directory_path" || \ func_fatal_error "Failed to create '$1'" fi } # func_mktempdir [BASENAME] # ------------------------- # Make a temporary directory that won't clash with other running # libtool processes, and avoids race conditions if possible. If # given, BASENAME is the basename for that directory. func_mktempdir () { $debug_cmd _G_template=${TMPDIR-/tmp}/${1-$progname} if test : = "$opt_dry_run"; then # Return a directory name, but don't create it in dry-run mode _G_tmpdir=$_G_template-$$ else # If mktemp works, use that first and foremost _G_tmpdir=`mktemp -d "$_G_template-XXXXXXXX" 2>/dev/null` if test ! -d "$_G_tmpdir"; then # Failing that, at least try and use $RANDOM to avoid a race _G_tmpdir=$_G_template-${RANDOM-0}$$ func_mktempdir_umask=`umask` umask 0077 $MKDIR "$_G_tmpdir" umask $func_mktempdir_umask fi # If we're not in dry-run mode, bomb out on failure test -d "$_G_tmpdir" || \ func_fatal_error "cannot create temporary directory '$_G_tmpdir'" fi $ECHO "$_G_tmpdir" } # func_normal_abspath PATH # ------------------------ # Remove doubled-up and trailing slashes, "." path components, # and cancel out any ".." path components in PATH after making # it an absolute path. func_normal_abspath () { $debug_cmd # These SED scripts presuppose an absolute path with a trailing slash. _G_pathcar='s|^/\([^/]*\).*$|\1|' _G_pathcdr='s|^/[^/]*||' _G_removedotparts=':dotsl s|/\./|/|g t dotsl s|/\.$|/|' _G_collapseslashes='s|/\{1,\}|/|g' _G_finalslash='s|/*$|/|' # Start from root dir and reassemble the path. func_normal_abspath_result= func_normal_abspath_tpath=$1 func_normal_abspath_altnamespace= case $func_normal_abspath_tpath in "") # Empty path, that just means $cwd. func_stripname '' '/' "`pwd`" func_normal_abspath_result=$func_stripname_result return ;; # The next three entries are used to spot a run of precisely # two leading slashes without using negated character classes; # we take advantage of case's first-match behaviour. ///*) # Unusual form of absolute path, do nothing. ;; //*) # Not necessarily an ordinary path; POSIX reserves leading '//' # and for example Cygwin uses it to access remote file shares # over CIFS/SMB, so we conserve a leading double slash if found. func_normal_abspath_altnamespace=/ ;; /*) # Absolute path, do nothing. ;; *) # Relative path, prepend $cwd. func_normal_abspath_tpath=`pwd`/$func_normal_abspath_tpath ;; esac # Cancel out all the simple stuff to save iterations. We also want # the path to end with a slash for ease of parsing, so make sure # there is one (and only one) here. func_normal_abspath_tpath=`$ECHO "$func_normal_abspath_tpath" | $SED \ -e "$_G_removedotparts" -e "$_G_collapseslashes" -e "$_G_finalslash"` while :; do # Processed it all yet? if test / = "$func_normal_abspath_tpath"; then # If we ascended to the root using ".." the result may be empty now. if test -z "$func_normal_abspath_result"; then func_normal_abspath_result=/ fi break fi func_normal_abspath_tcomponent=`$ECHO "$func_normal_abspath_tpath" | $SED \ -e "$_G_pathcar"` func_normal_abspath_tpath=`$ECHO "$func_normal_abspath_tpath" | $SED \ -e "$_G_pathcdr"` # Figure out what to do with it case $func_normal_abspath_tcomponent in "") # Trailing empty path component, ignore it. ;; ..) # Parent dir; strip last assembled component from result. func_dirname "$func_normal_abspath_result" func_normal_abspath_result=$func_dirname_result ;; *) # Actual path component, append it. func_append func_normal_abspath_result "/$func_normal_abspath_tcomponent" ;; esac done # Restore leading double-slash if one was found on entry. func_normal_abspath_result=$func_normal_abspath_altnamespace$func_normal_abspath_result } # func_notquiet ARG... # -------------------- # Echo program name prefixed message only when not in quiet mode. func_notquiet () { $debug_cmd $opt_quiet || func_echo ${1+"$@"} # A bug in bash halts the script if the last line of a function # fails when set -e is in force, so we need another command to # work around that: : } # func_relative_path SRCDIR DSTDIR # -------------------------------- # Set func_relative_path_result to the relative path from SRCDIR to DSTDIR. func_relative_path () { $debug_cmd func_relative_path_result= func_normal_abspath "$1" func_relative_path_tlibdir=$func_normal_abspath_result func_normal_abspath "$2" func_relative_path_tbindir=$func_normal_abspath_result # Ascend the tree starting from libdir while :; do # check if we have found a prefix of bindir case $func_relative_path_tbindir in $func_relative_path_tlibdir) # found an exact match func_relative_path_tcancelled= break ;; $func_relative_path_tlibdir*) # found a matching prefix func_stripname "$func_relative_path_tlibdir" '' "$func_relative_path_tbindir" func_relative_path_tcancelled=$func_stripname_result if test -z "$func_relative_path_result"; then func_relative_path_result=. fi break ;; *) func_dirname $func_relative_path_tlibdir func_relative_path_tlibdir=$func_dirname_result if test -z "$func_relative_path_tlibdir"; then # Have to descend all the way to the root! func_relative_path_result=../$func_relative_path_result func_relative_path_tcancelled=$func_relative_path_tbindir break fi func_relative_path_result=../$func_relative_path_result ;; esac done # Now calculate path; take care to avoid doubling-up slashes. func_stripname '' '/' "$func_relative_path_result" func_relative_path_result=$func_stripname_result func_stripname '/' '/' "$func_relative_path_tcancelled" if test -n "$func_stripname_result"; then func_append func_relative_path_result "/$func_stripname_result" fi # Normalisation. If bindir is libdir, return '.' else relative path. if test -n "$func_relative_path_result"; then func_stripname './' '' "$func_relative_path_result" func_relative_path_result=$func_stripname_result fi test -n "$func_relative_path_result" || func_relative_path_result=. : } # func_quote_for_eval ARG... # -------------------------- # Aesthetically quote ARGs to be evaled later. # This function returns two values: # i) func_quote_for_eval_result # double-quoted, suitable for a subsequent eval # ii) func_quote_for_eval_unquoted_result # has all characters that are still active within double # quotes backslashified. func_quote_for_eval () { $debug_cmd func_quote_for_eval_unquoted_result= func_quote_for_eval_result= while test 0 -lt $#; do case $1 in *[\\\`\"\$]*) _G_unquoted_arg=`printf '%s\n' "$1" |$SED "$sed_quote_subst"` ;; *) _G_unquoted_arg=$1 ;; esac if test -n "$func_quote_for_eval_unquoted_result"; then func_append func_quote_for_eval_unquoted_result " $_G_unquoted_arg" else func_append func_quote_for_eval_unquoted_result "$_G_unquoted_arg" fi case $_G_unquoted_arg in # Double-quote args containing shell metacharacters to delay # word splitting, command substitution and variable expansion # for a subsequent eval. # Many Bourne shells cannot handle close brackets correctly # in scan sets, so we specify it separately. *[\[\~\#\^\&\*\(\)\{\}\|\;\<\>\?\'\ \ ]*|*]*|"") _G_quoted_arg=\"$_G_unquoted_arg\" ;; *) _G_quoted_arg=$_G_unquoted_arg ;; esac if test -n "$func_quote_for_eval_result"; then func_append func_quote_for_eval_result " $_G_quoted_arg" else func_append func_quote_for_eval_result "$_G_quoted_arg" fi shift done } # func_quote_for_expand ARG # ------------------------- # Aesthetically quote ARG to be evaled later; same as above, # but do not quote variable references. func_quote_for_expand () { $debug_cmd case $1 in *[\\\`\"]*) _G_arg=`$ECHO "$1" | $SED \ -e "$sed_double_quote_subst" -e "$sed_double_backslash"` ;; *) _G_arg=$1 ;; esac case $_G_arg in # Double-quote args containing shell metacharacters to delay # word splitting and command substitution for a subsequent eval. # Many Bourne shells cannot handle close brackets correctly # in scan sets, so we specify it separately. *[\[\~\#\^\&\*\(\)\{\}\|\;\<\>\?\'\ \ ]*|*]*|"") _G_arg=\"$_G_arg\" ;; esac func_quote_for_expand_result=$_G_arg } # func_stripname PREFIX SUFFIX NAME # --------------------------------- # strip PREFIX and SUFFIX from NAME, and store in func_stripname_result. # PREFIX and SUFFIX must not contain globbing or regex special # characters, hashes, percent signs, but SUFFIX may contain a leading # dot (in which case that matches only a dot). if test yes = "$_G_HAVE_XSI_OPS"; then eval 'func_stripname () { $debug_cmd # pdksh 5.2.14 does not do ${X%$Y} correctly if both X and Y are # positional parameters, so assign one to ordinary variable first. func_stripname_result=$3 func_stripname_result=${func_stripname_result#"$1"} func_stripname_result=${func_stripname_result%"$2"} }' else func_stripname () { $debug_cmd case $2 in .*) func_stripname_result=`$ECHO "$3" | $SED -e "s%^$1%%" -e "s%\\\\$2\$%%"`;; *) func_stripname_result=`$ECHO "$3" | $SED -e "s%^$1%%" -e "s%$2\$%%"`;; esac } fi # func_show_eval CMD [FAIL_EXP] # ----------------------------- # Unless opt_quiet is true, then output CMD. Then, if opt_dryrun is # not true, evaluate CMD. If the evaluation of CMD fails, and FAIL_EXP # is given, then evaluate it. func_show_eval () { $debug_cmd _G_cmd=$1 _G_fail_exp=${2-':'} func_quote_for_expand "$_G_cmd" eval "func_notquiet $func_quote_for_expand_result" $opt_dry_run || { eval "$_G_cmd" _G_status=$? if test 0 -ne "$_G_status"; then eval "(exit $_G_status); $_G_fail_exp" fi } } # func_show_eval_locale CMD [FAIL_EXP] # ------------------------------------ # Unless opt_quiet is true, then output CMD. Then, if opt_dryrun is # not true, evaluate CMD. If the evaluation of CMD fails, and FAIL_EXP # is given, then evaluate it. Use the saved locale for evaluation. func_show_eval_locale () { $debug_cmd _G_cmd=$1 _G_fail_exp=${2-':'} $opt_quiet || { func_quote_for_expand "$_G_cmd" eval "func_echo $func_quote_for_expand_result" } $opt_dry_run || { eval "$_G_user_locale $_G_cmd" _G_status=$? eval "$_G_safe_locale" if test 0 -ne "$_G_status"; then eval "(exit $_G_status); $_G_fail_exp" fi } } # func_tr_sh # ---------- # Turn $1 into a string suitable for a shell variable name. # Result is stored in $func_tr_sh_result. All characters # not in the set a-zA-Z0-9_ are replaced with '_'. Further, # if $1 begins with a digit, a '_' is prepended as well. func_tr_sh () { $debug_cmd case $1 in [0-9]* | *[!a-zA-Z0-9_]*) func_tr_sh_result=`$ECHO "$1" | $SED -e 's/^\([0-9]\)/_\1/' -e 's/[^a-zA-Z0-9_]/_/g'` ;; * ) func_tr_sh_result=$1 ;; esac } # func_verbose ARG... # ------------------- # Echo program name prefixed message in verbose mode only. func_verbose () { $debug_cmd $opt_verbose && func_echo "$*" : } # func_warn_and_continue ARG... # ----------------------------- # Echo program name prefixed warning message to standard error. func_warn_and_continue () { $debug_cmd $require_term_colors func_echo_infix_1 "${tc_red}warning$tc_reset" "$*" >&2 } # func_warning CATEGORY ARG... # ---------------------------- # Echo program name prefixed warning message to standard error. Warning # messages can be filtered according to CATEGORY, where this function # elides messages where CATEGORY is not listed in the global variable # 'opt_warning_types'. func_warning () { $debug_cmd # CATEGORY must be in the warning_categories list! case " $warning_categories " in *" $1 "*) ;; *) func_internal_error "invalid warning category '$1'" ;; esac _G_category=$1 shift case " $opt_warning_types " in *" $_G_category "*) $warning_func ${1+"$@"} ;; esac } # func_sort_ver VER1 VER2 # ----------------------- # 'sort -V' is not generally available. # Note this deviates from the version comparison in automake # in that it treats 1.5 < 1.5.0, and treats 1.4.4a < 1.4-p3a # but this should suffice as we won't be specifying old # version formats or redundant trailing .0 in bootstrap.conf. # If we did want full compatibility then we should probably # use m4_version_compare from autoconf. func_sort_ver () { $debug_cmd printf '%s\n%s\n' "$1" "$2" \ | sort -t. -k 1,1n -k 2,2n -k 3,3n -k 4,4n -k 5,5n -k 6,6n -k 7,7n -k 8,8n -k 9,9n } # func_lt_ver PREV CURR # --------------------- # Return true if PREV and CURR are in the correct order according to # func_sort_ver, otherwise false. Use it like this: # # func_lt_ver "$prev_ver" "$proposed_ver" || func_fatal_error "..." func_lt_ver () { $debug_cmd test "x$1" = x`func_sort_ver "$1" "$2" | $SED 1q` } # Local variables: # mode: shell-script # sh-indentation: 2 # eval: (add-hook 'before-save-hook 'time-stamp) # time-stamp-pattern: "10/scriptversion=%:y-%02m-%02d.%02H; # UTC" # time-stamp-time-zone: "UTC" # End: #! /bin/sh # Set a version string for this script. scriptversion=2014-01-07.03; # UTC # A portable, pluggable option parser for Bourne shell. # Written by Gary V. Vaughan, 2010 # Copyright (C) 2010-2015 Free Software Foundation, Inc. # This is free software; see the source for copying conditions. There is NO # warranty; not even for MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. # 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. # You should have received a copy of the GNU General Public License # along with this program. If not, see . # Please report bugs or propose patches to gary@gnu.org. ## ------ ## ## Usage. ## ## ------ ## # This file is a library for parsing options in your shell scripts along # with assorted other useful supporting features that you can make use # of too. # # For the simplest scripts you might need only: # # #!/bin/sh # . relative/path/to/funclib.sh # . relative/path/to/options-parser # scriptversion=1.0 # func_options ${1+"$@"} # eval set dummy "$func_options_result"; shift # ...rest of your script... # # In order for the '--version' option to work, you will need to have a # suitably formatted comment like the one at the top of this file # starting with '# Written by ' and ending with '# warranty; '. # # For '-h' and '--help' to work, you will also need a one line # description of your script's purpose in a comment directly above the # '# Written by ' line, like the one at the top of this file. # # The default options also support '--debug', which will turn on shell # execution tracing (see the comment above debug_cmd below for another # use), and '--verbose' and the func_verbose function to allow your script # to display verbose messages only when your user has specified # '--verbose'. # # After sourcing this file, you can plug processing for additional # options by amending the variables from the 'Configuration' section # below, and following the instructions in the 'Option parsing' # section further down. ## -------------- ## ## Configuration. ## ## -------------- ## # You should override these variables in your script after sourcing this # file so that they reflect the customisations you have added to the # option parser. # The usage line for option parsing errors and the start of '-h' and # '--help' output messages. You can embed shell variables for delayed # expansion at the time the message is displayed, but you will need to # quote other shell meta-characters carefully to prevent them being # expanded when the contents are evaled. usage='$progpath [OPTION]...' # Short help message in response to '-h' and '--help'. Add to this or # override it after sourcing this library to reflect the full set of # options your script accepts. usage_message="\ --debug enable verbose shell tracing -W, --warnings=CATEGORY report the warnings falling in CATEGORY [all] -v, --verbose verbosely report processing --version print version information and exit -h, --help print short or long help message and exit " # Additional text appended to 'usage_message' in response to '--help'. long_help_message=" Warning categories include: 'all' show all warnings 'none' turn off all the warnings 'error' warnings are treated as fatal errors" # Help message printed before fatal option parsing errors. fatal_help="Try '\$progname --help' for more information." ## ------------------------- ## ## Hook function management. ## ## ------------------------- ## # This section contains functions for adding, removing, and running hooks # to the main code. A hook is just a named list of of function, that can # be run in order later on. # func_hookable FUNC_NAME # ----------------------- # Declare that FUNC_NAME will run hooks added with # 'func_add_hook FUNC_NAME ...'. func_hookable () { $debug_cmd func_append hookable_fns " $1" } # func_add_hook FUNC_NAME HOOK_FUNC # --------------------------------- # Request that FUNC_NAME call HOOK_FUNC before it returns. FUNC_NAME must # first have been declared "hookable" by a call to 'func_hookable'. func_add_hook () { $debug_cmd case " $hookable_fns " in *" $1 "*) ;; *) func_fatal_error "'$1' does not accept hook functions." ;; esac eval func_append ${1}_hooks '" $2"' } # func_remove_hook FUNC_NAME HOOK_FUNC # ------------------------------------ # Remove HOOK_FUNC from the list of functions called by FUNC_NAME. func_remove_hook () { $debug_cmd eval ${1}_hooks='`$ECHO "\$'$1'_hooks" |$SED "s| '$2'||"`' } # func_run_hooks FUNC_NAME [ARG]... # --------------------------------- # Run all hook functions registered to FUNC_NAME. # It is assumed that the list of hook functions contains nothing more # than a whitespace-delimited list of legal shell function names, and # no effort is wasted trying to catch shell meta-characters or preserve # whitespace. func_run_hooks () { $debug_cmd case " $hookable_fns " in *" $1 "*) ;; *) func_fatal_error "'$1' does not support hook funcions.n" ;; esac eval _G_hook_fns=\$$1_hooks; shift for _G_hook in $_G_hook_fns; do eval $_G_hook '"$@"' # store returned options list back into positional # parameters for next 'cmd' execution. eval _G_hook_result=\$${_G_hook}_result eval set dummy "$_G_hook_result"; shift done func_quote_for_eval ${1+"$@"} func_run_hooks_result=$func_quote_for_eval_result } ## --------------- ## ## Option parsing. ## ## --------------- ## # In order to add your own option parsing hooks, you must accept the # full positional parameter list in your hook function, remove any # options that you action, and then pass back the remaining unprocessed # options in '_result', escaped suitably for # 'eval'. Like this: # # my_options_prep () # { # $debug_cmd # # # Extend the existing usage message. # usage_message=$usage_message' # -s, --silent don'\''t print informational messages # ' # # func_quote_for_eval ${1+"$@"} # my_options_prep_result=$func_quote_for_eval_result # } # func_add_hook func_options_prep my_options_prep # # # my_silent_option () # { # $debug_cmd # # # Note that for efficiency, we parse as many options as we can # # recognise in a loop before passing the remainder back to the # # caller on the first unrecognised argument we encounter. # while test $# -gt 0; do # opt=$1; shift # case $opt in # --silent|-s) opt_silent=: ;; # # Separate non-argument short options: # -s*) func_split_short_opt "$_G_opt" # set dummy "$func_split_short_opt_name" \ # "-$func_split_short_opt_arg" ${1+"$@"} # shift # ;; # *) set dummy "$_G_opt" "$*"; shift; break ;; # esac # done # # func_quote_for_eval ${1+"$@"} # my_silent_option_result=$func_quote_for_eval_result # } # func_add_hook func_parse_options my_silent_option # # # my_option_validation () # { # $debug_cmd # # $opt_silent && $opt_verbose && func_fatal_help "\ # '--silent' and '--verbose' options are mutually exclusive." # # func_quote_for_eval ${1+"$@"} # my_option_validation_result=$func_quote_for_eval_result # } # func_add_hook func_validate_options my_option_validation # # You'll alse need to manually amend $usage_message to reflect the extra # options you parse. It's preferable to append if you can, so that # multiple option parsing hooks can be added safely. # func_options [ARG]... # --------------------- # All the functions called inside func_options are hookable. See the # individual implementations for details. func_hookable func_options func_options () { $debug_cmd func_options_prep ${1+"$@"} eval func_parse_options \ ${func_options_prep_result+"$func_options_prep_result"} eval func_validate_options \ ${func_parse_options_result+"$func_parse_options_result"} eval func_run_hooks func_options \ ${func_validate_options_result+"$func_validate_options_result"} # save modified positional parameters for caller func_options_result=$func_run_hooks_result } # func_options_prep [ARG]... # -------------------------- # All initialisations required before starting the option parse loop. # Note that when calling hook functions, we pass through the list of # positional parameters. If a hook function modifies that list, and # needs to propogate that back to rest of this script, then the complete # modified list must be put in 'func_run_hooks_result' before # returning. func_hookable func_options_prep func_options_prep () { $debug_cmd # Option defaults: opt_verbose=false opt_warning_types= func_run_hooks func_options_prep ${1+"$@"} # save modified positional parameters for caller func_options_prep_result=$func_run_hooks_result } # func_parse_options [ARG]... # --------------------------- # The main option parsing loop. func_hookable func_parse_options func_parse_options () { $debug_cmd func_parse_options_result= # this just eases exit handling while test $# -gt 0; do # Defer to hook functions for initial option parsing, so they # get priority in the event of reusing an option name. func_run_hooks func_parse_options ${1+"$@"} # Adjust func_parse_options positional parameters to match eval set dummy "$func_run_hooks_result"; shift # Break out of the loop if we already parsed every option. test $# -gt 0 || break _G_opt=$1 shift case $_G_opt in --debug|-x) debug_cmd='set -x' func_echo "enabling shell trace mode" $debug_cmd ;; --no-warnings|--no-warning|--no-warn) set dummy --warnings none ${1+"$@"} shift ;; --warnings|--warning|-W) test $# = 0 && func_missing_arg $_G_opt && break case " $warning_categories $1" in *" $1 "*) # trailing space prevents matching last $1 above func_append_uniq opt_warning_types " $1" ;; *all) opt_warning_types=$warning_categories ;; *none) opt_warning_types=none warning_func=: ;; *error) opt_warning_types=$warning_categories warning_func=func_fatal_error ;; *) func_fatal_error \ "unsupported warning category: '$1'" ;; esac shift ;; --verbose|-v) opt_verbose=: ;; --version) func_version ;; -\?|-h) func_usage ;; --help) func_help ;; # Separate optargs to long options (plugins may need this): --*=*) func_split_equals "$_G_opt" set dummy "$func_split_equals_lhs" \ "$func_split_equals_rhs" ${1+"$@"} shift ;; # Separate optargs to short options: -W*) func_split_short_opt "$_G_opt" set dummy "$func_split_short_opt_name" \ "$func_split_short_opt_arg" ${1+"$@"} shift ;; # Separate non-argument short options: -\?*|-h*|-v*|-x*) func_split_short_opt "$_G_opt" set dummy "$func_split_short_opt_name" \ "-$func_split_short_opt_arg" ${1+"$@"} shift ;; --) break ;; -*) func_fatal_help "unrecognised option: '$_G_opt'" ;; *) set dummy "$_G_opt" ${1+"$@"}; shift; break ;; esac done # save modified positional parameters for caller func_quote_for_eval ${1+"$@"} func_parse_options_result=$func_quote_for_eval_result } # func_validate_options [ARG]... # ------------------------------ # Perform any sanity checks on option settings and/or unconsumed # arguments. func_hookable func_validate_options func_validate_options () { $debug_cmd # Display all warnings if -W was not given. test -n "$opt_warning_types" || opt_warning_types=" $warning_categories" func_run_hooks func_validate_options ${1+"$@"} # Bail if the options were screwed! $exit_cmd $EXIT_FAILURE # save modified positional parameters for caller func_validate_options_result=$func_run_hooks_result } ## ----------------- ## ## Helper functions. ## ## ----------------- ## # This section contains the helper functions used by the rest of the # hookable option parser framework in ascii-betical order. # func_fatal_help ARG... # ---------------------- # Echo program name prefixed message to standard error, followed by # a help hint, and exit. func_fatal_help () { $debug_cmd eval \$ECHO \""Usage: $usage"\" eval \$ECHO \""$fatal_help"\" func_error ${1+"$@"} exit $EXIT_FAILURE } # func_help # --------- # Echo long help message to standard output and exit. func_help () { $debug_cmd func_usage_message $ECHO "$long_help_message" exit 0 } # func_missing_arg ARGNAME # ------------------------ # Echo program name prefixed message to standard error and set global # exit_cmd. func_missing_arg () { $debug_cmd func_error "Missing argument for '$1'." exit_cmd=exit } # func_split_equals STRING # ------------------------ # Set func_split_equals_lhs and func_split_equals_rhs shell variables after # splitting STRING at the '=' sign. test -z "$_G_HAVE_XSI_OPS" \ && (eval 'x=a/b/c; test 5aa/bb/cc = "${#x}${x%%/*}${x%/*}${x#*/}${x##*/}"') 2>/dev/null \ && _G_HAVE_XSI_OPS=yes if test yes = "$_G_HAVE_XSI_OPS" then # This is an XSI compatible shell, allowing a faster implementation... eval 'func_split_equals () { $debug_cmd func_split_equals_lhs=${1%%=*} func_split_equals_rhs=${1#*=} test "x$func_split_equals_lhs" = "x$1" \ && func_split_equals_rhs= }' else # ...otherwise fall back to using expr, which is often a shell builtin. func_split_equals () { $debug_cmd func_split_equals_lhs=`expr "x$1" : 'x\([^=]*\)'` func_split_equals_rhs= test "x$func_split_equals_lhs" = "x$1" \ || func_split_equals_rhs=`expr "x$1" : 'x[^=]*=\(.*\)$'` } fi #func_split_equals # func_split_short_opt SHORTOPT # ----------------------------- # Set func_split_short_opt_name and func_split_short_opt_arg shell # variables after splitting SHORTOPT after the 2nd character. if test yes = "$_G_HAVE_XSI_OPS" then # This is an XSI compatible shell, allowing a faster implementation... eval 'func_split_short_opt () { $debug_cmd func_split_short_opt_arg=${1#??} func_split_short_opt_name=${1%"$func_split_short_opt_arg"} }' else # ...otherwise fall back to using expr, which is often a shell builtin. func_split_short_opt () { $debug_cmd func_split_short_opt_name=`expr "x$1" : 'x-\(.\)'` func_split_short_opt_arg=`expr "x$1" : 'x-.\(.*\)$'` } fi #func_split_short_opt # func_usage # ---------- # Echo short help message to standard output and exit. func_usage () { $debug_cmd func_usage_message $ECHO "Run '$progname --help |${PAGER-more}' for full usage" exit 0 } # func_usage_message # ------------------ # Echo short help message to standard output. func_usage_message () { $debug_cmd eval \$ECHO \""Usage: $usage"\" echo $SED -n 's|^# || /^Written by/{ x;p;x } h /^Written by/q' < "$progpath" echo eval \$ECHO \""$usage_message"\" } # func_version # ------------ # Echo version message to standard output and exit. func_version () { $debug_cmd printf '%s\n' "$progname $scriptversion" $SED -n ' /(C)/!b go :more /\./!{ N s|\n# | | b more } :go /^# Written by /,/# warranty; / { s|^# || s|^# *$|| s|\((C)\)[ 0-9,-]*[ ,-]\([1-9][0-9]* \)|\1 \2| p } /^# Written by / { s|^# || p } /^warranty; /q' < "$progpath" exit $? } # Local variables: # mode: shell-script # sh-indentation: 2 # eval: (add-hook 'before-save-hook 'time-stamp) # time-stamp-pattern: "10/scriptversion=%:y-%02m-%02d.%02H; # UTC" # time-stamp-time-zone: "UTC" # End: # Set a version string. scriptversion='(GNU libtool) 2.4.6' # func_echo ARG... # ---------------- # Libtool also displays the current mode in messages, so override # funclib.sh func_echo with this custom definition. func_echo () { $debug_cmd _G_message=$* func_echo_IFS=$IFS IFS=$nl for _G_line in $_G_message; do IFS=$func_echo_IFS $ECHO "$progname${opt_mode+: $opt_mode}: $_G_line" done IFS=$func_echo_IFS } # func_warning ARG... # ------------------- # Libtool warnings are not categorized, so override funclib.sh # func_warning with this simpler definition. func_warning () { $debug_cmd $warning_func ${1+"$@"} } ## ---------------- ## ## Options parsing. ## ## ---------------- ## # Hook in the functions to make sure our own options are parsed during # the option parsing loop. usage='$progpath [OPTION]... [MODE-ARG]...' # Short help message in response to '-h'. usage_message="Options: --config show all configuration variables --debug enable verbose shell tracing -n, --dry-run display commands without modifying any files --features display basic configuration information and exit --mode=MODE use operation mode MODE --no-warnings equivalent to '-Wnone' --preserve-dup-deps don't remove duplicate dependency libraries --quiet, --silent don't print informational messages --tag=TAG use configuration variables from tag TAG -v, --verbose print more informational messages than default --version print version information -W, --warnings=CATEGORY report the warnings falling in CATEGORY [all] -h, --help, --help-all print short, long, or detailed help message " # Additional text appended to 'usage_message' in response to '--help'. func_help () { $debug_cmd func_usage_message $ECHO "$long_help_message MODE must be one of the following: clean remove files from the build directory compile compile a source file into a libtool object execute automatically set library path, then run a program finish complete the installation of libtool libraries install install libraries or executables link create a library or an executable uninstall remove libraries from an installed directory MODE-ARGS vary depending on the MODE. When passed as first option, '--mode=MODE' may be abbreviated as 'MODE' or a unique abbreviation of that. Try '$progname --help --mode=MODE' for a more detailed description of MODE. When reporting a bug, please describe a test case to reproduce it and include the following information: host-triplet: $host shell: $SHELL compiler: $LTCC compiler flags: $LTCFLAGS linker: $LD (gnu? $with_gnu_ld) version: $progname (GNU libtool) 2.4.6 automake: `($AUTOMAKE --version) 2>/dev/null |$SED 1q` autoconf: `($AUTOCONF --version) 2>/dev/null |$SED 1q` Report bugs to . GNU libtool home page: . General help using GNU software: ." exit 0 } # func_lo2o OBJECT-NAME # --------------------- # Transform OBJECT-NAME from a '.lo' suffix to the platform specific # object suffix. lo2o=s/\\.lo\$/.$objext/ o2lo=s/\\.$objext\$/.lo/ if test yes = "$_G_HAVE_XSI_OPS"; then eval 'func_lo2o () { case $1 in *.lo) func_lo2o_result=${1%.lo}.$objext ;; * ) func_lo2o_result=$1 ;; esac }' # func_xform LIBOBJ-OR-SOURCE # --------------------------- # Transform LIBOBJ-OR-SOURCE from a '.o' or '.c' (or otherwise) # suffix to a '.lo' libtool-object suffix. eval 'func_xform () { func_xform_result=${1%.*}.lo }' else # ...otherwise fall back to using sed. func_lo2o () { func_lo2o_result=`$ECHO "$1" | $SED "$lo2o"` } func_xform () { func_xform_result=`$ECHO "$1" | $SED 's|\.[^.]*$|.lo|'` } fi # func_fatal_configuration ARG... # ------------------------------- # Echo program name prefixed message to standard error, followed by # a configuration failure hint, and exit. func_fatal_configuration () { func__fatal_error ${1+"$@"} \ "See the $PACKAGE documentation for more information." \ "Fatal configuration error." } # func_config # ----------- # Display the configuration for all the tags in this script. func_config () { re_begincf='^# ### BEGIN LIBTOOL' re_endcf='^# ### END LIBTOOL' # Default configuration. $SED "1,/$re_begincf CONFIG/d;/$re_endcf CONFIG/,\$d" < "$progpath" # Now print the configurations for the tags. for tagname in $taglist; do $SED -n "/$re_begincf TAG CONFIG: $tagname\$/,/$re_endcf TAG CONFIG: $tagname\$/p" < "$progpath" done exit $? } # func_features # ------------- # Display the features supported by this script. func_features () { echo "host: $host" if test yes = "$build_libtool_libs"; then echo "enable shared libraries" else echo "disable shared libraries" fi if test yes = "$build_old_libs"; then echo "enable static libraries" else echo "disable static libraries" fi exit $? } # func_enable_tag TAGNAME # ----------------------- # Verify that TAGNAME is valid, and either flag an error and exit, or # enable the TAGNAME tag. We also add TAGNAME to the global $taglist # variable here. func_enable_tag () { # Global variable: tagname=$1 re_begincf="^# ### BEGIN LIBTOOL TAG CONFIG: $tagname\$" re_endcf="^# ### END LIBTOOL TAG CONFIG: $tagname\$" sed_extractcf=/$re_begincf/,/$re_endcf/p # Validate tagname. case $tagname in *[!-_A-Za-z0-9,/]*) func_fatal_error "invalid tag name: $tagname" ;; esac # Don't test for the "default" C tag, as we know it's # there but not specially marked. case $tagname in CC) ;; *) if $GREP "$re_begincf" "$progpath" >/dev/null 2>&1; then taglist="$taglist $tagname" # Evaluate the configuration. Be careful to quote the path # and the sed script, to avoid splitting on whitespace, but # also don't use non-portable quotes within backquotes within # quotes we have to do it in 2 steps: extractedcf=`$SED -n -e "$sed_extractcf" < "$progpath"` eval "$extractedcf" else func_error "ignoring unknown tag $tagname" fi ;; esac } # func_check_version_match # ------------------------ # Ensure that we are using m4 macros, and libtool script from the same # release of libtool. func_check_version_match () { if test "$package_revision" != "$macro_revision"; then if test "$VERSION" != "$macro_version"; then if test -z "$macro_version"; then cat >&2 <<_LT_EOF $progname: Version mismatch error. This is $PACKAGE $VERSION, but the $progname: definition of this LT_INIT comes from an older release. $progname: You should recreate aclocal.m4 with macros from $PACKAGE $VERSION $progname: and run autoconf again. _LT_EOF else cat >&2 <<_LT_EOF $progname: Version mismatch error. This is $PACKAGE $VERSION, but the $progname: definition of this LT_INIT comes from $PACKAGE $macro_version. $progname: You should recreate aclocal.m4 with macros from $PACKAGE $VERSION $progname: and run autoconf again. _LT_EOF fi else cat >&2 <<_LT_EOF $progname: Version mismatch error. This is $PACKAGE $VERSION, revision $package_revision, $progname: but the definition of this LT_INIT comes from revision $macro_revision. $progname: You should recreate aclocal.m4 with macros from revision $package_revision $progname: of $PACKAGE $VERSION and run autoconf again. _LT_EOF fi exit $EXIT_MISMATCH fi } # libtool_options_prep [ARG]... # ----------------------------- # Preparation for options parsed by libtool. libtool_options_prep () { $debug_mode # Option defaults: opt_config=false opt_dlopen= opt_dry_run=false opt_help=false opt_mode= opt_preserve_dup_deps=false opt_quiet=false nonopt= preserve_args= # Shorthand for --mode=foo, only valid as the first argument case $1 in clean|clea|cle|cl) shift; set dummy --mode clean ${1+"$@"}; shift ;; compile|compil|compi|comp|com|co|c) shift; set dummy --mode compile ${1+"$@"}; shift ;; execute|execut|execu|exec|exe|ex|e) shift; set dummy --mode execute ${1+"$@"}; shift ;; finish|finis|fini|fin|fi|f) shift; set dummy --mode finish ${1+"$@"}; shift ;; install|instal|insta|inst|ins|in|i) shift; set dummy --mode install ${1+"$@"}; shift ;; link|lin|li|l) shift; set dummy --mode link ${1+"$@"}; shift ;; uninstall|uninstal|uninsta|uninst|unins|unin|uni|un|u) shift; set dummy --mode uninstall ${1+"$@"}; shift ;; esac # Pass back the list of options. func_quote_for_eval ${1+"$@"} libtool_options_prep_result=$func_quote_for_eval_result } func_add_hook func_options_prep libtool_options_prep # libtool_parse_options [ARG]... # --------------------------------- # Provide handling for libtool specific options. libtool_parse_options () { $debug_cmd # Perform our own loop to consume as many options as possible in # each iteration. while test $# -gt 0; do _G_opt=$1 shift case $_G_opt in --dry-run|--dryrun|-n) opt_dry_run=: ;; --config) func_config ;; --dlopen|-dlopen) opt_dlopen="${opt_dlopen+$opt_dlopen }$1" shift ;; --preserve-dup-deps) opt_preserve_dup_deps=: ;; --features) func_features ;; --finish) set dummy --mode finish ${1+"$@"}; shift ;; --help) opt_help=: ;; --help-all) opt_help=': help-all' ;; --mode) test $# = 0 && func_missing_arg $_G_opt && break opt_mode=$1 case $1 in # Valid mode arguments: clean|compile|execute|finish|install|link|relink|uninstall) ;; # Catch anything else as an error *) func_error "invalid argument for $_G_opt" exit_cmd=exit break ;; esac shift ;; --no-silent|--no-quiet) opt_quiet=false func_append preserve_args " $_G_opt" ;; --no-warnings|--no-warning|--no-warn) opt_warning=false func_append preserve_args " $_G_opt" ;; --no-verbose) opt_verbose=false func_append preserve_args " $_G_opt" ;; --silent|--quiet) opt_quiet=: opt_verbose=false func_append preserve_args " $_G_opt" ;; --tag) test $# = 0 && func_missing_arg $_G_opt && break opt_tag=$1 func_append preserve_args " $_G_opt $1" func_enable_tag "$1" shift ;; --verbose|-v) opt_quiet=false opt_verbose=: func_append preserve_args " $_G_opt" ;; # An option not handled by this hook function: *) set dummy "$_G_opt" ${1+"$@"}; shift; break ;; esac done # save modified positional parameters for caller func_quote_for_eval ${1+"$@"} libtool_parse_options_result=$func_quote_for_eval_result } func_add_hook func_parse_options libtool_parse_options # libtool_validate_options [ARG]... # --------------------------------- # Perform any sanity checks on option settings and/or unconsumed # arguments. libtool_validate_options () { # save first non-option argument if test 0 -lt $#; then nonopt=$1 shift fi # preserve --debug test : = "$debug_cmd" || func_append preserve_args " --debug" case $host in # Solaris2 added to fix http://debbugs.gnu.org/cgi/bugreport.cgi?bug=16452 # see also: http://gcc.gnu.org/bugzilla/show_bug.cgi?id=59788 *cygwin* | *mingw* | *pw32* | *cegcc* | *solaris2* | *os2*) # don't eliminate duplications in $postdeps and $predeps opt_duplicate_compiler_generated_deps=: ;; *) opt_duplicate_compiler_generated_deps=$opt_preserve_dup_deps ;; esac $opt_help || { # Sanity checks first: func_check_version_match test yes != "$build_libtool_libs" \ && test yes != "$build_old_libs" \ && func_fatal_configuration "not configured to build any kind of library" # Darwin sucks eval std_shrext=\"$shrext_cmds\" # Only execute mode is allowed to have -dlopen flags. if test -n "$opt_dlopen" && test execute != "$opt_mode"; then func_error "unrecognized option '-dlopen'" $ECHO "$help" 1>&2 exit $EXIT_FAILURE fi # Change the help message to a mode-specific one. generic_help=$help help="Try '$progname --help --mode=$opt_mode' for more information." } # Pass back the unparsed argument list func_quote_for_eval ${1+"$@"} libtool_validate_options_result=$func_quote_for_eval_result } func_add_hook func_validate_options libtool_validate_options # Process options as early as possible so that --help and --version # can return quickly. func_options ${1+"$@"} eval set dummy "$func_options_result"; shift ## ----------- ## ## Main. ## ## ----------- ## magic='%%%MAGIC variable%%%' magic_exe='%%%MAGIC EXE variable%%%' # Global variables. extracted_archives= extracted_serial=0 # If this variable is set in any of the actions, the command in it # will be execed at the end. This prevents here-documents from being # left over by shells. exec_cmd= # A function that is used when there is no print builtin or printf. func_fallback_echo () { eval 'cat <<_LTECHO_EOF $1 _LTECHO_EOF' } # func_generated_by_libtool # True iff stdin has been generated by Libtool. This function is only # a basic sanity check; it will hardly flush out determined imposters. func_generated_by_libtool_p () { $GREP "^# Generated by .*$PACKAGE" > /dev/null 2>&1 } # func_lalib_p file # True iff FILE is a libtool '.la' library or '.lo' object file. # This function is only a basic sanity check; it will hardly flush out # determined imposters. func_lalib_p () { test -f "$1" && $SED -e 4q "$1" 2>/dev/null | func_generated_by_libtool_p } # func_lalib_unsafe_p file # True iff FILE is a libtool '.la' library or '.lo' object file. # This function implements the same check as func_lalib_p without # resorting to external programs. To this end, it redirects stdin and # closes it afterwards, without saving the original file descriptor. # As a safety measure, use it only where a negative result would be # fatal anyway. Works if 'file' does not exist. func_lalib_unsafe_p () { lalib_p=no if test -f "$1" && test -r "$1" && exec 5<&0 <"$1"; then for lalib_p_l in 1 2 3 4 do read lalib_p_line case $lalib_p_line in \#\ Generated\ by\ *$PACKAGE* ) lalib_p=yes; break;; esac done exec 0<&5 5<&- fi test yes = "$lalib_p" } # func_ltwrapper_script_p file # True iff FILE is a libtool wrapper script # This function is only a basic sanity check; it will hardly flush out # determined imposters. func_ltwrapper_script_p () { test -f "$1" && $lt_truncate_bin < "$1" 2>/dev/null | func_generated_by_libtool_p } # func_ltwrapper_executable_p file # True iff FILE is a libtool wrapper executable # This function is only a basic sanity check; it will hardly flush out # determined imposters. func_ltwrapper_executable_p () { func_ltwrapper_exec_suffix= case $1 in *.exe) ;; *) func_ltwrapper_exec_suffix=.exe ;; esac $GREP "$magic_exe" "$1$func_ltwrapper_exec_suffix" >/dev/null 2>&1 } # func_ltwrapper_scriptname file # Assumes file is an ltwrapper_executable # uses $file to determine the appropriate filename for a # temporary ltwrapper_script. func_ltwrapper_scriptname () { func_dirname_and_basename "$1" "" "." func_stripname '' '.exe' "$func_basename_result" func_ltwrapper_scriptname_result=$func_dirname_result/$objdir/${func_stripname_result}_ltshwrapper } # func_ltwrapper_p file # True iff FILE is a libtool wrapper script or wrapper executable # This function is only a basic sanity check; it will hardly flush out # determined imposters. func_ltwrapper_p () { func_ltwrapper_script_p "$1" || func_ltwrapper_executable_p "$1" } # func_execute_cmds commands fail_cmd # Execute tilde-delimited COMMANDS. # If FAIL_CMD is given, eval that upon failure. # FAIL_CMD may read-access the current command in variable CMD! func_execute_cmds () { $debug_cmd save_ifs=$IFS; IFS='~' for cmd in $1; do IFS=$sp$nl eval cmd=\"$cmd\" IFS=$save_ifs func_show_eval "$cmd" "${2-:}" done IFS=$save_ifs } # func_source file # Source FILE, adding directory component if necessary. # Note that it is not necessary on cygwin/mingw to append a dot to # FILE even if both FILE and FILE.exe exist: automatic-append-.exe # behavior happens only for exec(3), not for open(2)! Also, sourcing # 'FILE.' does not work on cygwin managed mounts. func_source () { $debug_cmd case $1 in */* | *\\*) . "$1" ;; *) . "./$1" ;; esac } # func_resolve_sysroot PATH # Replace a leading = in PATH with a sysroot. Store the result into # func_resolve_sysroot_result func_resolve_sysroot () { func_resolve_sysroot_result=$1 case $func_resolve_sysroot_result in =*) func_stripname '=' '' "$func_resolve_sysroot_result" func_resolve_sysroot_result=$lt_sysroot$func_stripname_result ;; esac } # func_replace_sysroot PATH # If PATH begins with the sysroot, replace it with = and # store the result into func_replace_sysroot_result. func_replace_sysroot () { case $lt_sysroot:$1 in ?*:"$lt_sysroot"*) func_stripname "$lt_sysroot" '' "$1" func_replace_sysroot_result='='$func_stripname_result ;; *) # Including no sysroot. func_replace_sysroot_result=$1 ;; esac } # func_infer_tag arg # Infer tagged configuration to use if any are available and # if one wasn't chosen via the "--tag" command line option. # Only attempt this if the compiler in the base compile # command doesn't match the default compiler. # arg is usually of the form 'gcc ...' func_infer_tag () { $debug_cmd if test -n "$available_tags" && test -z "$tagname"; then CC_quoted= for arg in $CC; do func_append_quoted CC_quoted "$arg" done CC_expanded=`func_echo_all $CC` CC_quoted_expanded=`func_echo_all $CC_quoted` case $@ in # Blanks in the command may have been stripped by the calling shell, # but not from the CC environment variable when configure was run. " $CC "* | "$CC "* | " $CC_expanded "* | "$CC_expanded "* | \ " $CC_quoted"* | "$CC_quoted "* | " $CC_quoted_expanded "* | "$CC_quoted_expanded "*) ;; # Blanks at the start of $base_compile will cause this to fail # if we don't check for them as well. *) for z in $available_tags; do if $GREP "^# ### BEGIN LIBTOOL TAG CONFIG: $z$" < "$progpath" > /dev/null; then # Evaluate the configuration. eval "`$SED -n -e '/^# ### BEGIN LIBTOOL TAG CONFIG: '$z'$/,/^# ### END LIBTOOL TAG CONFIG: '$z'$/p' < $progpath`" CC_quoted= for arg in $CC; do # Double-quote args containing other shell metacharacters. func_append_quoted CC_quoted "$arg" done CC_expanded=`func_echo_all $CC` CC_quoted_expanded=`func_echo_all $CC_quoted` case "$@ " in " $CC "* | "$CC "* | " $CC_expanded "* | "$CC_expanded "* | \ " $CC_quoted"* | "$CC_quoted "* | " $CC_quoted_expanded "* | "$CC_quoted_expanded "*) # The compiler in the base compile command matches # the one in the tagged configuration. # Assume this is the tagged configuration we want. tagname=$z break ;; esac fi done # If $tagname still isn't set, then no tagged configuration # was found and let the user know that the "--tag" command # line option must be used. if test -z "$tagname"; then func_echo "unable to infer tagged configuration" func_fatal_error "specify a tag with '--tag'" # else # func_verbose "using $tagname tagged configuration" fi ;; esac fi } # func_write_libtool_object output_name pic_name nonpic_name # Create a libtool object file (analogous to a ".la" file), # but don't create it if we're doing a dry run. func_write_libtool_object () { write_libobj=$1 if test yes = "$build_libtool_libs"; then write_lobj=\'$2\' else write_lobj=none fi if test yes = "$build_old_libs"; then write_oldobj=\'$3\' else write_oldobj=none fi $opt_dry_run || { cat >${write_libobj}T </dev/null` if test "$?" -eq 0 && test -n "$func_convert_core_file_wine_to_w32_tmp"; then func_convert_core_file_wine_to_w32_result=`$ECHO "$func_convert_core_file_wine_to_w32_tmp" | $SED -e "$sed_naive_backslashify"` else func_convert_core_file_wine_to_w32_result= fi fi } # end: func_convert_core_file_wine_to_w32 # func_convert_core_path_wine_to_w32 ARG # Helper function used by path conversion functions when $build is *nix, and # $host is mingw, cygwin, or some other w32 environment. Relies on a correctly # configured wine environment available, with the winepath program in $build's # $PATH. Assumes ARG has no leading or trailing path separator characters. # # ARG is path to be converted from $build format to win32. # Result is available in $func_convert_core_path_wine_to_w32_result. # Unconvertible file (directory) names in ARG are skipped; if no directory names # are convertible, then the result may be empty. func_convert_core_path_wine_to_w32 () { $debug_cmd # unfortunately, winepath doesn't convert paths, only file names func_convert_core_path_wine_to_w32_result= if test -n "$1"; then oldIFS=$IFS IFS=: for func_convert_core_path_wine_to_w32_f in $1; do IFS=$oldIFS func_convert_core_file_wine_to_w32 "$func_convert_core_path_wine_to_w32_f" if test -n "$func_convert_core_file_wine_to_w32_result"; then if test -z "$func_convert_core_path_wine_to_w32_result"; then func_convert_core_path_wine_to_w32_result=$func_convert_core_file_wine_to_w32_result else func_append func_convert_core_path_wine_to_w32_result ";$func_convert_core_file_wine_to_w32_result" fi fi done IFS=$oldIFS fi } # end: func_convert_core_path_wine_to_w32 # func_cygpath ARGS... # Wrapper around calling the cygpath program via LT_CYGPATH. This is used when # when (1) $build is *nix and Cygwin is hosted via a wine environment; or (2) # $build is MSYS and $host is Cygwin, or (3) $build is Cygwin. In case (1) or # (2), returns the Cygwin file name or path in func_cygpath_result (input # file name or path is assumed to be in w32 format, as previously converted # from $build's *nix or MSYS format). In case (3), returns the w32 file name # or path in func_cygpath_result (input file name or path is assumed to be in # Cygwin format). Returns an empty string on error. # # ARGS are passed to cygpath, with the last one being the file name or path to # be converted. # # Specify the absolute *nix (or w32) name to cygpath in the LT_CYGPATH # environment variable; do not put it in $PATH. func_cygpath () { $debug_cmd if test -n "$LT_CYGPATH" && test -f "$LT_CYGPATH"; then func_cygpath_result=`$LT_CYGPATH "$@" 2>/dev/null` if test "$?" -ne 0; then # on failure, ensure result is empty func_cygpath_result= fi else func_cygpath_result= func_error "LT_CYGPATH is empty or specifies non-existent file: '$LT_CYGPATH'" fi } #end: func_cygpath # func_convert_core_msys_to_w32 ARG # Convert file name or path ARG from MSYS format to w32 format. Return # result in func_convert_core_msys_to_w32_result. func_convert_core_msys_to_w32 () { $debug_cmd # awkward: cmd appends spaces to result func_convert_core_msys_to_w32_result=`( cmd //c echo "$1" ) 2>/dev/null | $SED -e 's/[ ]*$//' -e "$sed_naive_backslashify"` } #end: func_convert_core_msys_to_w32 # func_convert_file_check ARG1 ARG2 # Verify that ARG1 (a file name in $build format) was converted to $host # format in ARG2. Otherwise, emit an error message, but continue (resetting # func_to_host_file_result to ARG1). func_convert_file_check () { $debug_cmd if test -z "$2" && test -n "$1"; then func_error "Could not determine host file name corresponding to" func_error " '$1'" func_error "Continuing, but uninstalled executables may not work." # Fallback: func_to_host_file_result=$1 fi } # end func_convert_file_check # func_convert_path_check FROM_PATHSEP TO_PATHSEP FROM_PATH TO_PATH # Verify that FROM_PATH (a path in $build format) was converted to $host # format in TO_PATH. Otherwise, emit an error message, but continue, resetting # func_to_host_file_result to a simplistic fallback value (see below). func_convert_path_check () { $debug_cmd if test -z "$4" && test -n "$3"; then func_error "Could not determine the host path corresponding to" func_error " '$3'" func_error "Continuing, but uninstalled executables may not work." # Fallback. This is a deliberately simplistic "conversion" and # should not be "improved". See libtool.info. if test "x$1" != "x$2"; then lt_replace_pathsep_chars="s|$1|$2|g" func_to_host_path_result=`echo "$3" | $SED -e "$lt_replace_pathsep_chars"` else func_to_host_path_result=$3 fi fi } # end func_convert_path_check # func_convert_path_front_back_pathsep FRONTPAT BACKPAT REPL ORIG # Modifies func_to_host_path_result by prepending REPL if ORIG matches FRONTPAT # and appending REPL if ORIG matches BACKPAT. func_convert_path_front_back_pathsep () { $debug_cmd case $4 in $1 ) func_to_host_path_result=$3$func_to_host_path_result ;; esac case $4 in $2 ) func_append func_to_host_path_result "$3" ;; esac } # end func_convert_path_front_back_pathsep ################################################## # $build to $host FILE NAME CONVERSION FUNCTIONS # ################################################## # invoked via '$to_host_file_cmd ARG' # # In each case, ARG is the path to be converted from $build to $host format. # Result will be available in $func_to_host_file_result. # func_to_host_file ARG # Converts the file name ARG from $build format to $host format. Return result # in func_to_host_file_result. func_to_host_file () { $debug_cmd $to_host_file_cmd "$1" } # end func_to_host_file # func_to_tool_file ARG LAZY # converts the file name ARG from $build format to toolchain format. Return # result in func_to_tool_file_result. If the conversion in use is listed # in (the comma separated) LAZY, no conversion takes place. func_to_tool_file () { $debug_cmd case ,$2, in *,"$to_tool_file_cmd",*) func_to_tool_file_result=$1 ;; *) $to_tool_file_cmd "$1" func_to_tool_file_result=$func_to_host_file_result ;; esac } # end func_to_tool_file # func_convert_file_noop ARG # Copy ARG to func_to_host_file_result. func_convert_file_noop () { func_to_host_file_result=$1 } # end func_convert_file_noop # func_convert_file_msys_to_w32 ARG # Convert file name ARG from (mingw) MSYS to (mingw) w32 format; automatic # conversion to w32 is not available inside the cwrapper. Returns result in # func_to_host_file_result. func_convert_file_msys_to_w32 () { $debug_cmd func_to_host_file_result=$1 if test -n "$1"; then func_convert_core_msys_to_w32 "$1" func_to_host_file_result=$func_convert_core_msys_to_w32_result fi func_convert_file_check "$1" "$func_to_host_file_result" } # end func_convert_file_msys_to_w32 # func_convert_file_cygwin_to_w32 ARG # Convert file name ARG from Cygwin to w32 format. Returns result in # func_to_host_file_result. func_convert_file_cygwin_to_w32 () { $debug_cmd func_to_host_file_result=$1 if test -n "$1"; then # because $build is cygwin, we call "the" cygpath in $PATH; no need to use # LT_CYGPATH in this case. func_to_host_file_result=`cygpath -m "$1"` fi func_convert_file_check "$1" "$func_to_host_file_result" } # end func_convert_file_cygwin_to_w32 # func_convert_file_nix_to_w32 ARG # Convert file name ARG from *nix to w32 format. Requires a wine environment # and a working winepath. Returns result in func_to_host_file_result. func_convert_file_nix_to_w32 () { $debug_cmd func_to_host_file_result=$1 if test -n "$1"; then func_convert_core_file_wine_to_w32 "$1" func_to_host_file_result=$func_convert_core_file_wine_to_w32_result fi func_convert_file_check "$1" "$func_to_host_file_result" } # end func_convert_file_nix_to_w32 # func_convert_file_msys_to_cygwin ARG # Convert file name ARG from MSYS to Cygwin format. Requires LT_CYGPATH set. # Returns result in func_to_host_file_result. func_convert_file_msys_to_cygwin () { $debug_cmd func_to_host_file_result=$1 if test -n "$1"; then func_convert_core_msys_to_w32 "$1" func_cygpath -u "$func_convert_core_msys_to_w32_result" func_to_host_file_result=$func_cygpath_result fi func_convert_file_check "$1" "$func_to_host_file_result" } # end func_convert_file_msys_to_cygwin # func_convert_file_nix_to_cygwin ARG # Convert file name ARG from *nix to Cygwin format. Requires Cygwin installed # in a wine environment, working winepath, and LT_CYGPATH set. Returns result # in func_to_host_file_result. func_convert_file_nix_to_cygwin () { $debug_cmd func_to_host_file_result=$1 if test -n "$1"; then # convert from *nix to w32, then use cygpath to convert from w32 to cygwin. func_convert_core_file_wine_to_w32 "$1" func_cygpath -u "$func_convert_core_file_wine_to_w32_result" func_to_host_file_result=$func_cygpath_result fi func_convert_file_check "$1" "$func_to_host_file_result" } # end func_convert_file_nix_to_cygwin ############################################# # $build to $host PATH CONVERSION FUNCTIONS # ############################################# # invoked via '$to_host_path_cmd ARG' # # In each case, ARG is the path to be converted from $build to $host format. # The result will be available in $func_to_host_path_result. # # Path separators are also converted from $build format to $host format. If # ARG begins or ends with a path separator character, it is preserved (but # converted to $host format) on output. # # All path conversion functions are named using the following convention: # file name conversion function : func_convert_file_X_to_Y () # path conversion function : func_convert_path_X_to_Y () # where, for any given $build/$host combination the 'X_to_Y' value is the # same. If conversion functions are added for new $build/$host combinations, # the two new functions must follow this pattern, or func_init_to_host_path_cmd # will break. # func_init_to_host_path_cmd # Ensures that function "pointer" variable $to_host_path_cmd is set to the # appropriate value, based on the value of $to_host_file_cmd. to_host_path_cmd= func_init_to_host_path_cmd () { $debug_cmd if test -z "$to_host_path_cmd"; then func_stripname 'func_convert_file_' '' "$to_host_file_cmd" to_host_path_cmd=func_convert_path_$func_stripname_result fi } # func_to_host_path ARG # Converts the path ARG from $build format to $host format. Return result # in func_to_host_path_result. func_to_host_path () { $debug_cmd func_init_to_host_path_cmd $to_host_path_cmd "$1" } # end func_to_host_path # func_convert_path_noop ARG # Copy ARG to func_to_host_path_result. func_convert_path_noop () { func_to_host_path_result=$1 } # end func_convert_path_noop # func_convert_path_msys_to_w32 ARG # Convert path ARG from (mingw) MSYS to (mingw) w32 format; automatic # conversion to w32 is not available inside the cwrapper. Returns result in # func_to_host_path_result. func_convert_path_msys_to_w32 () { $debug_cmd func_to_host_path_result=$1 if test -n "$1"; then # Remove leading and trailing path separator characters from ARG. MSYS # behavior is inconsistent here; cygpath turns them into '.;' and ';.'; # and winepath ignores them completely. func_stripname : : "$1" func_to_host_path_tmp1=$func_stripname_result func_convert_core_msys_to_w32 "$func_to_host_path_tmp1" func_to_host_path_result=$func_convert_core_msys_to_w32_result func_convert_path_check : ";" \ "$func_to_host_path_tmp1" "$func_to_host_path_result" func_convert_path_front_back_pathsep ":*" "*:" ";" "$1" fi } # end func_convert_path_msys_to_w32 # func_convert_path_cygwin_to_w32 ARG # Convert path ARG from Cygwin to w32 format. Returns result in # func_to_host_file_result. func_convert_path_cygwin_to_w32 () { $debug_cmd func_to_host_path_result=$1 if test -n "$1"; then # See func_convert_path_msys_to_w32: func_stripname : : "$1" func_to_host_path_tmp1=$func_stripname_result func_to_host_path_result=`cygpath -m -p "$func_to_host_path_tmp1"` func_convert_path_check : ";" \ "$func_to_host_path_tmp1" "$func_to_host_path_result" func_convert_path_front_back_pathsep ":*" "*:" ";" "$1" fi } # end func_convert_path_cygwin_to_w32 # func_convert_path_nix_to_w32 ARG # Convert path ARG from *nix to w32 format. Requires a wine environment and # a working winepath. Returns result in func_to_host_file_result. func_convert_path_nix_to_w32 () { $debug_cmd func_to_host_path_result=$1 if test -n "$1"; then # See func_convert_path_msys_to_w32: func_stripname : : "$1" func_to_host_path_tmp1=$func_stripname_result func_convert_core_path_wine_to_w32 "$func_to_host_path_tmp1" func_to_host_path_result=$func_convert_core_path_wine_to_w32_result func_convert_path_check : ";" \ "$func_to_host_path_tmp1" "$func_to_host_path_result" func_convert_path_front_back_pathsep ":*" "*:" ";" "$1" fi } # end func_convert_path_nix_to_w32 # func_convert_path_msys_to_cygwin ARG # Convert path ARG from MSYS to Cygwin format. Requires LT_CYGPATH set. # Returns result in func_to_host_file_result. func_convert_path_msys_to_cygwin () { $debug_cmd func_to_host_path_result=$1 if test -n "$1"; then # See func_convert_path_msys_to_w32: func_stripname : : "$1" func_to_host_path_tmp1=$func_stripname_result func_convert_core_msys_to_w32 "$func_to_host_path_tmp1" func_cygpath -u -p "$func_convert_core_msys_to_w32_result" func_to_host_path_result=$func_cygpath_result func_convert_path_check : : \ "$func_to_host_path_tmp1" "$func_to_host_path_result" func_convert_path_front_back_pathsep ":*" "*:" : "$1" fi } # end func_convert_path_msys_to_cygwin # func_convert_path_nix_to_cygwin ARG # Convert path ARG from *nix to Cygwin format. Requires Cygwin installed in a # a wine environment, working winepath, and LT_CYGPATH set. Returns result in # func_to_host_file_result. func_convert_path_nix_to_cygwin () { $debug_cmd func_to_host_path_result=$1 if test -n "$1"; then # Remove leading and trailing path separator characters from # ARG. msys behavior is inconsistent here, cygpath turns them # into '.;' and ';.', and winepath ignores them completely. func_stripname : : "$1" func_to_host_path_tmp1=$func_stripname_result func_convert_core_path_wine_to_w32 "$func_to_host_path_tmp1" func_cygpath -u -p "$func_convert_core_path_wine_to_w32_result" func_to_host_path_result=$func_cygpath_result func_convert_path_check : : \ "$func_to_host_path_tmp1" "$func_to_host_path_result" func_convert_path_front_back_pathsep ":*" "*:" : "$1" fi } # end func_convert_path_nix_to_cygwin # func_dll_def_p FILE # True iff FILE is a Windows DLL '.def' file. # Keep in sync with _LT_DLL_DEF_P in libtool.m4 func_dll_def_p () { $debug_cmd func_dll_def_p_tmp=`$SED -n \ -e 's/^[ ]*//' \ -e '/^\(;.*\)*$/d' \ -e 's/^\(EXPORTS\|LIBRARY\)\([ ].*\)*$/DEF/p' \ -e q \ "$1"` test DEF = "$func_dll_def_p_tmp" } # func_mode_compile arg... func_mode_compile () { $debug_cmd # Get the compilation command and the source file. base_compile= srcfile=$nonopt # always keep a non-empty value in "srcfile" suppress_opt=yes suppress_output= arg_mode=normal libobj= later= pie_flag= for arg do case $arg_mode in arg ) # do not "continue". Instead, add this to base_compile lastarg=$arg arg_mode=normal ;; target ) libobj=$arg arg_mode=normal continue ;; normal ) # Accept any command-line options. case $arg in -o) test -n "$libobj" && \ func_fatal_error "you cannot specify '-o' more than once" arg_mode=target continue ;; -pie | -fpie | -fPIE) func_append pie_flag " $arg" continue ;; -shared | -static | -prefer-pic | -prefer-non-pic) func_append later " $arg" continue ;; -no-suppress) suppress_opt=no continue ;; -Xcompiler) arg_mode=arg # the next one goes into the "base_compile" arg list continue # The current "srcfile" will either be retained or ;; # replaced later. I would guess that would be a bug. -Wc,*) func_stripname '-Wc,' '' "$arg" args=$func_stripname_result lastarg= save_ifs=$IFS; IFS=, for arg in $args; do IFS=$save_ifs func_append_quoted lastarg "$arg" done IFS=$save_ifs func_stripname ' ' '' "$lastarg" lastarg=$func_stripname_result # Add the arguments to base_compile. func_append base_compile " $lastarg" continue ;; *) # Accept the current argument as the source file. # The previous "srcfile" becomes the current argument. # lastarg=$srcfile srcfile=$arg ;; esac # case $arg ;; esac # case $arg_mode # Aesthetically quote the previous argument. func_append_quoted base_compile "$lastarg" done # for arg case $arg_mode in arg) func_fatal_error "you must specify an argument for -Xcompile" ;; target) func_fatal_error "you must specify a target with '-o'" ;; *) # Get the name of the library object. test -z "$libobj" && { func_basename "$srcfile" libobj=$func_basename_result } ;; esac # Recognize several different file suffixes. # If the user specifies -o file.o, it is replaced with file.lo case $libobj in *.[cCFSifmso] | \ *.ada | *.adb | *.ads | *.asm | \ *.c++ | *.cc | *.ii | *.class | *.cpp | *.cxx | \ *.[fF][09]? | *.for | *.java | *.go | *.obj | *.sx | *.cu | *.cup) func_xform "$libobj" libobj=$func_xform_result ;; esac case $libobj in *.lo) func_lo2o "$libobj"; obj=$func_lo2o_result ;; *) func_fatal_error "cannot determine name of library object from '$libobj'" ;; esac func_infer_tag $base_compile for arg in $later; do case $arg in -shared) test yes = "$build_libtool_libs" \ || func_fatal_configuration "cannot build a shared library" build_old_libs=no continue ;; -static) build_libtool_libs=no build_old_libs=yes continue ;; -prefer-pic) pic_mode=yes continue ;; -prefer-non-pic) pic_mode=no continue ;; esac done func_quote_for_eval "$libobj" test "X$libobj" != "X$func_quote_for_eval_result" \ && $ECHO "X$libobj" | $GREP '[]~#^*{};<>?"'"'"' &()|`$[]' \ && func_warning "libobj name '$libobj' may not contain shell special characters." func_dirname_and_basename "$obj" "/" "" objname=$func_basename_result xdir=$func_dirname_result lobj=$xdir$objdir/$objname test -z "$base_compile" && \ func_fatal_help "you must specify a compilation command" # Delete any leftover library objects. if test yes = "$build_old_libs"; then removelist="$obj $lobj $libobj ${libobj}T" else removelist="$lobj $libobj ${libobj}T" fi # On Cygwin there's no "real" PIC flag so we must build both object types case $host_os in cygwin* | mingw* | pw32* | os2* | cegcc*) pic_mode=default ;; esac if test no = "$pic_mode" && test pass_all != "$deplibs_check_method"; then # non-PIC code in shared libraries is not supported pic_mode=default fi # Calculate the filename of the output object if compiler does # not support -o with -c if test no = "$compiler_c_o"; then output_obj=`$ECHO "$srcfile" | $SED 's%^.*/%%; s%\.[^.]*$%%'`.$objext lockfile=$output_obj.lock else output_obj= need_locks=no lockfile= fi # Lock this critical section if it is needed # We use this script file to make the link, it avoids creating a new file if test yes = "$need_locks"; then until $opt_dry_run || ln "$progpath" "$lockfile" 2>/dev/null; do func_echo "Waiting for $lockfile to be removed" sleep 2 done elif test warn = "$need_locks"; then if test -f "$lockfile"; then $ECHO "\ *** ERROR, $lockfile exists and contains: `cat $lockfile 2>/dev/null` This indicates that another process is trying to use the same temporary object file, and libtool could not work around it because your compiler does not support '-c' and '-o' together. If you repeat this compilation, it may succeed, by chance, but you had better avoid parallel builds (make -j) in this platform, or get a better compiler." $opt_dry_run || $RM $removelist exit $EXIT_FAILURE fi func_append removelist " $output_obj" $ECHO "$srcfile" > "$lockfile" fi $opt_dry_run || $RM $removelist func_append removelist " $lockfile" trap '$opt_dry_run || $RM $removelist; exit $EXIT_FAILURE' 1 2 15 func_to_tool_file "$srcfile" func_convert_file_msys_to_w32 srcfile=$func_to_tool_file_result func_quote_for_eval "$srcfile" qsrcfile=$func_quote_for_eval_result # Only build a PIC object if we are building libtool libraries. if test yes = "$build_libtool_libs"; then # Without this assignment, base_compile gets emptied. fbsd_hideous_sh_bug=$base_compile if test no != "$pic_mode"; then command="$base_compile $qsrcfile $pic_flag" else # Don't build PIC code command="$base_compile $qsrcfile" fi func_mkdir_p "$xdir$objdir" if test -z "$output_obj"; then # Place PIC objects in $objdir func_append command " -o $lobj" fi func_show_eval_locale "$command" \ 'test -n "$output_obj" && $RM $removelist; exit $EXIT_FAILURE' if test warn = "$need_locks" && test "X`cat $lockfile 2>/dev/null`" != "X$srcfile"; then $ECHO "\ *** ERROR, $lockfile contains: `cat $lockfile 2>/dev/null` but it should contain: $srcfile This indicates that another process is trying to use the same temporary object file, and libtool could not work around it because your compiler does not support '-c' and '-o' together. If you repeat this compilation, it may succeed, by chance, but you had better avoid parallel builds (make -j) in this platform, or get a better compiler." $opt_dry_run || $RM $removelist exit $EXIT_FAILURE fi # Just move the object if needed, then go on to compile the next one if test -n "$output_obj" && test "X$output_obj" != "X$lobj"; then func_show_eval '$MV "$output_obj" "$lobj"' \ 'error=$?; $opt_dry_run || $RM $removelist; exit $error' fi # Allow error messages only from the first compilation. if test yes = "$suppress_opt"; then suppress_output=' >/dev/null 2>&1' fi fi # Only build a position-dependent object if we build old libraries. if test yes = "$build_old_libs"; then if test yes != "$pic_mode"; then # Don't build PIC code command="$base_compile $qsrcfile$pie_flag" else command="$base_compile $qsrcfile $pic_flag" fi if test yes = "$compiler_c_o"; then func_append command " -o $obj" fi # Suppress compiler output if we already did a PIC compilation. func_append command "$suppress_output" func_show_eval_locale "$command" \ '$opt_dry_run || $RM $removelist; exit $EXIT_FAILURE' if test warn = "$need_locks" && test "X`cat $lockfile 2>/dev/null`" != "X$srcfile"; then $ECHO "\ *** ERROR, $lockfile contains: `cat $lockfile 2>/dev/null` but it should contain: $srcfile This indicates that another process is trying to use the same temporary object file, and libtool could not work around it because your compiler does not support '-c' and '-o' together. If you repeat this compilation, it may succeed, by chance, but you had better avoid parallel builds (make -j) in this platform, or get a better compiler." $opt_dry_run || $RM $removelist exit $EXIT_FAILURE fi # Just move the object if needed if test -n "$output_obj" && test "X$output_obj" != "X$obj"; then func_show_eval '$MV "$output_obj" "$obj"' \ 'error=$?; $opt_dry_run || $RM $removelist; exit $error' fi fi $opt_dry_run || { func_write_libtool_object "$libobj" "$objdir/$objname" "$objname" # Unlock the critical section if it was locked if test no != "$need_locks"; then removelist=$lockfile $RM "$lockfile" fi } exit $EXIT_SUCCESS } $opt_help || { test compile = "$opt_mode" && func_mode_compile ${1+"$@"} } func_mode_help () { # We need to display help for each of the modes. case $opt_mode in "") # Generic help is extracted from the usage comments # at the start of this file. func_help ;; clean) $ECHO \ "Usage: $progname [OPTION]... --mode=clean RM [RM-OPTION]... FILE... Remove files from the build directory. RM is the name of the program to use to delete files associated with each FILE (typically '/bin/rm'). RM-OPTIONS are options (such as '-f') to be passed to RM. If FILE is a libtool library, object or program, all the files associated with it are deleted. Otherwise, only FILE itself is deleted using RM." ;; compile) $ECHO \ "Usage: $progname [OPTION]... --mode=compile COMPILE-COMMAND... SOURCEFILE Compile a source file into a libtool library object. This mode accepts the following additional options: -o OUTPUT-FILE set the output file name to OUTPUT-FILE -no-suppress do not suppress compiler output for multiple passes -prefer-pic try to build PIC objects only -prefer-non-pic try to build non-PIC objects only -shared do not build a '.o' file suitable for static linking -static only build a '.o' file suitable for static linking -Wc,FLAG pass FLAG directly to the compiler COMPILE-COMMAND is a command to be used in creating a 'standard' object file from the given SOURCEFILE. The output file name is determined by removing the directory component from SOURCEFILE, then substituting the C source code suffix '.c' with the library object suffix, '.lo'." ;; execute) $ECHO \ "Usage: $progname [OPTION]... --mode=execute COMMAND [ARGS]... Automatically set library path, then run a program. This mode accepts the following additional options: -dlopen FILE add the directory containing FILE to the library path This mode sets the library path environment variable according to '-dlopen' flags. If any of the ARGS are libtool executable wrappers, then they are translated into their corresponding uninstalled binary, and any of their required library directories are added to the library path. Then, COMMAND is executed, with ARGS as arguments." ;; finish) $ECHO \ "Usage: $progname [OPTION]... --mode=finish [LIBDIR]... Complete the installation of libtool libraries. Each LIBDIR is a directory that contains libtool libraries. The commands that this mode executes may require superuser privileges. Use the '--dry-run' option if you just want to see what would be executed." ;; install) $ECHO \ "Usage: $progname [OPTION]... --mode=install INSTALL-COMMAND... Install executables or libraries. INSTALL-COMMAND is the installation command. The first component should be either the 'install' or 'cp' program. The following components of INSTALL-COMMAND are treated specially: -inst-prefix-dir PREFIX-DIR Use PREFIX-DIR as a staging area for installation The rest of the components are interpreted as arguments to that command (only BSD-compatible install options are recognized)." ;; link) $ECHO \ "Usage: $progname [OPTION]... --mode=link LINK-COMMAND... Link object files or libraries together to form another library, or to create an executable program. LINK-COMMAND is a command using the C compiler that you would use to create a program from several object files. The following components of LINK-COMMAND are treated specially: -all-static do not do any dynamic linking at all -avoid-version do not add a version suffix if possible -bindir BINDIR specify path to binaries directory (for systems where libraries must be found in the PATH setting at runtime) -dlopen FILE '-dlpreopen' FILE if it cannot be dlopened at runtime -dlpreopen FILE link in FILE and add its symbols to lt_preloaded_symbols -export-dynamic allow symbols from OUTPUT-FILE to be resolved with dlsym(3) -export-symbols SYMFILE try to export only the symbols listed in SYMFILE -export-symbols-regex REGEX try to export only the symbols matching REGEX -LLIBDIR search LIBDIR for required installed libraries -lNAME OUTPUT-FILE requires the installed library libNAME -module build a library that can dlopened -no-fast-install disable the fast-install mode -no-install link a not-installable executable -no-undefined declare that a library does not refer to external symbols -o OUTPUT-FILE create OUTPUT-FILE from the specified objects -objectlist FILE use a list of object files found in FILE to specify objects -os2dllname NAME force a short DLL name on OS/2 (no effect on other OSes) -precious-files-regex REGEX don't remove output files matching REGEX -release RELEASE specify package release information -rpath LIBDIR the created library will eventually be installed in LIBDIR -R[ ]LIBDIR add LIBDIR to the runtime path of programs and libraries -shared only do dynamic linking of libtool libraries -shrext SUFFIX override the standard shared library file extension -static do not do any dynamic linking of uninstalled libtool libraries -static-libtool-libs do not do any dynamic linking of libtool libraries -version-info CURRENT[:REVISION[:AGE]] specify library version info [each variable defaults to 0] -weak LIBNAME declare that the target provides the LIBNAME interface -Wc,FLAG -Xcompiler FLAG pass linker-specific FLAG directly to the compiler -Wl,FLAG -Xlinker FLAG pass linker-specific FLAG directly to the linker -XCClinker FLAG pass link-specific FLAG to the compiler driver (CC) All other options (arguments beginning with '-') are ignored. Every other argument is treated as a filename. Files ending in '.la' are treated as uninstalled libtool libraries, other files are standard or library object files. If the OUTPUT-FILE ends in '.la', then a libtool library is created, only library objects ('.lo' files) may be specified, and '-rpath' is required, except when creating a convenience library. If OUTPUT-FILE ends in '.a' or '.lib', then a standard library is created using 'ar' and 'ranlib', or on Windows using 'lib'. If OUTPUT-FILE ends in '.lo' or '.$objext', then a reloadable object file is created, otherwise an executable program is created." ;; uninstall) $ECHO \ "Usage: $progname [OPTION]... --mode=uninstall RM [RM-OPTION]... FILE... Remove libraries from an installation directory. RM is the name of the program to use to delete files associated with each FILE (typically '/bin/rm'). RM-OPTIONS are options (such as '-f') to be passed to RM. If FILE is a libtool library, all the files associated with it are deleted. Otherwise, only FILE itself is deleted using RM." ;; *) func_fatal_help "invalid operation mode '$opt_mode'" ;; esac echo $ECHO "Try '$progname --help' for more information about other modes." } # Now that we've collected a possible --mode arg, show help if necessary if $opt_help; then if test : = "$opt_help"; then func_mode_help else { func_help noexit for opt_mode in compile link execute install finish uninstall clean; do func_mode_help done } | $SED -n '1p; 2,$s/^Usage:/ or: /p' { func_help noexit for opt_mode in compile link execute install finish uninstall clean; do echo func_mode_help done } | $SED '1d /^When reporting/,/^Report/{ H d } $x /information about other modes/d /more detailed .*MODE/d s/^Usage:.*--mode=\([^ ]*\) .*/Description of \1 mode:/' fi exit $? fi # func_mode_execute arg... func_mode_execute () { $debug_cmd # The first argument is the command name. cmd=$nonopt test -z "$cmd" && \ func_fatal_help "you must specify a COMMAND" # Handle -dlopen flags immediately. for file in $opt_dlopen; do test -f "$file" \ || func_fatal_help "'$file' is not a file" dir= case $file in *.la) func_resolve_sysroot "$file" file=$func_resolve_sysroot_result # Check to see that this really is a libtool archive. func_lalib_unsafe_p "$file" \ || func_fatal_help "'$lib' is not a valid libtool archive" # Read the libtool library. dlname= library_names= func_source "$file" # Skip this library if it cannot be dlopened. if test -z "$dlname"; then # Warn if it was a shared library. test -n "$library_names" && \ func_warning "'$file' was not linked with '-export-dynamic'" continue fi func_dirname "$file" "" "." dir=$func_dirname_result if test -f "$dir/$objdir/$dlname"; then func_append dir "/$objdir" else if test ! -f "$dir/$dlname"; then func_fatal_error "cannot find '$dlname' in '$dir' or '$dir/$objdir'" fi fi ;; *.lo) # Just add the directory containing the .lo file. func_dirname "$file" "" "." dir=$func_dirname_result ;; *) func_warning "'-dlopen' is ignored for non-libtool libraries and objects" continue ;; esac # Get the absolute pathname. absdir=`cd "$dir" && pwd` test -n "$absdir" && dir=$absdir # Now add the directory to shlibpath_var. if eval "test -z \"\$$shlibpath_var\""; then eval "$shlibpath_var=\"\$dir\"" else eval "$shlibpath_var=\"\$dir:\$$shlibpath_var\"" fi done # This variable tells wrapper scripts just to set shlibpath_var # rather than running their programs. libtool_execute_magic=$magic # Check if any of the arguments is a wrapper script. args= for file do case $file in -* | *.la | *.lo ) ;; *) # Do a test to see if this is really a libtool program. if func_ltwrapper_script_p "$file"; then func_source "$file" # Transform arg to wrapped name. file=$progdir/$program elif func_ltwrapper_executable_p "$file"; then func_ltwrapper_scriptname "$file" func_source "$func_ltwrapper_scriptname_result" # Transform arg to wrapped name. file=$progdir/$program fi ;; esac # Quote arguments (to preserve shell metacharacters). func_append_quoted args "$file" done if $opt_dry_run; then # Display what would be done. if test -n "$shlibpath_var"; then eval "\$ECHO \"\$shlibpath_var=\$$shlibpath_var\"" echo "export $shlibpath_var" fi $ECHO "$cmd$args" exit $EXIT_SUCCESS else if test -n "$shlibpath_var"; then # Export the shlibpath_var. eval "export $shlibpath_var" fi # Restore saved environment variables for lt_var in LANG LANGUAGE LC_ALL LC_CTYPE LC_COLLATE LC_MESSAGES do eval "if test \"\${save_$lt_var+set}\" = set; then $lt_var=\$save_$lt_var; export $lt_var else $lt_unset $lt_var fi" done # Now prepare to actually exec the command. exec_cmd=\$cmd$args fi } test execute = "$opt_mode" && func_mode_execute ${1+"$@"} # func_mode_finish arg... func_mode_finish () { $debug_cmd libs= libdirs= admincmds= for opt in "$nonopt" ${1+"$@"} do if test -d "$opt"; then func_append libdirs " $opt" elif test -f "$opt"; then if func_lalib_unsafe_p "$opt"; then func_append libs " $opt" else func_warning "'$opt' is not a valid libtool archive" fi else func_fatal_error "invalid argument '$opt'" fi done if test -n "$libs"; then if test -n "$lt_sysroot"; then sysroot_regex=`$ECHO "$lt_sysroot" | $SED "$sed_make_literal_regex"` sysroot_cmd="s/\([ ']\)$sysroot_regex/\1/g;" else sysroot_cmd= fi # Remove sysroot references if $opt_dry_run; then for lib in $libs; do echo "removing references to $lt_sysroot and '=' prefixes from $lib" done else tmpdir=`func_mktempdir` for lib in $libs; do $SED -e "$sysroot_cmd s/\([ ']-[LR]\)=/\1/g; s/\([ ']\)=/\1/g" $lib \ > $tmpdir/tmp-la mv -f $tmpdir/tmp-la $lib done ${RM}r "$tmpdir" fi fi if test -n "$finish_cmds$finish_eval" && test -n "$libdirs"; then for libdir in $libdirs; do if test -n "$finish_cmds"; then # Do each command in the finish commands. func_execute_cmds "$finish_cmds" 'admincmds="$admincmds '"$cmd"'"' fi if test -n "$finish_eval"; then # Do the single finish_eval. eval cmds=\"$finish_eval\" $opt_dry_run || eval "$cmds" || func_append admincmds " $cmds" fi done fi # Exit here if they wanted silent mode. $opt_quiet && exit $EXIT_SUCCESS if test -n "$finish_cmds$finish_eval" && test -n "$libdirs"; then echo "----------------------------------------------------------------------" echo "Libraries have been installed in:" for libdir in $libdirs; do $ECHO " $libdir" done echo echo "If you ever happen to want to link against installed libraries" echo "in a given directory, LIBDIR, you must either use libtool, and" echo "specify the full pathname of the library, or use the '-LLIBDIR'" echo "flag during linking and do at least one of the following:" if test -n "$shlibpath_var"; then echo " - add LIBDIR to the '$shlibpath_var' environment variable" echo " during execution" fi if test -n "$runpath_var"; then echo " - add LIBDIR to the '$runpath_var' environment variable" echo " during linking" fi if test -n "$hardcode_libdir_flag_spec"; then libdir=LIBDIR eval flag=\"$hardcode_libdir_flag_spec\" $ECHO " - use the '$flag' linker flag" fi if test -n "$admincmds"; then $ECHO " - have your system administrator run these commands:$admincmds" fi if test -f /etc/ld.so.conf; then echo " - have your system administrator add LIBDIR to '/etc/ld.so.conf'" fi echo echo "See any operating system documentation about shared libraries for" case $host in solaris2.[6789]|solaris2.1[0-9]) echo "more information, such as the ld(1), crle(1) and ld.so(8) manual" echo "pages." ;; *) echo "more information, such as the ld(1) and ld.so(8) manual pages." ;; esac echo "----------------------------------------------------------------------" fi exit $EXIT_SUCCESS } test finish = "$opt_mode" && func_mode_finish ${1+"$@"} # func_mode_install arg... func_mode_install () { $debug_cmd # There may be an optional sh(1) argument at the beginning of # install_prog (especially on Windows NT). if test "$SHELL" = "$nonopt" || test /bin/sh = "$nonopt" || # Allow the use of GNU shtool's install command. case $nonopt in *shtool*) :;; *) false;; esac then # Aesthetically quote it. func_quote_for_eval "$nonopt" install_prog="$func_quote_for_eval_result " arg=$1 shift else install_prog= arg=$nonopt fi # The real first argument should be the name of the installation program. # Aesthetically quote it. func_quote_for_eval "$arg" func_append install_prog "$func_quote_for_eval_result" install_shared_prog=$install_prog case " $install_prog " in *[\\\ /]cp\ *) install_cp=: ;; *) install_cp=false ;; esac # We need to accept at least all the BSD install flags. dest= files= opts= prev= install_type= isdir=false stripme= no_mode=: for arg do arg2= if test -n "$dest"; then func_append files " $dest" dest=$arg continue fi case $arg in -d) isdir=: ;; -f) if $install_cp; then :; else prev=$arg fi ;; -g | -m | -o) prev=$arg ;; -s) stripme=" -s" continue ;; -*) ;; *) # If the previous option needed an argument, then skip it. if test -n "$prev"; then if test X-m = "X$prev" && test -n "$install_override_mode"; then arg2=$install_override_mode no_mode=false fi prev= else dest=$arg continue fi ;; esac # Aesthetically quote the argument. func_quote_for_eval "$arg" func_append install_prog " $func_quote_for_eval_result" if test -n "$arg2"; then func_quote_for_eval "$arg2" fi func_append install_shared_prog " $func_quote_for_eval_result" done test -z "$install_prog" && \ func_fatal_help "you must specify an install program" test -n "$prev" && \ func_fatal_help "the '$prev' option requires an argument" if test -n "$install_override_mode" && $no_mode; then if $install_cp; then :; else func_quote_for_eval "$install_override_mode" func_append install_shared_prog " -m $func_quote_for_eval_result" fi fi if test -z "$files"; then if test -z "$dest"; then func_fatal_help "no file or destination specified" else func_fatal_help "you must specify a destination" fi fi # Strip any trailing slash from the destination. func_stripname '' '/' "$dest" dest=$func_stripname_result # Check to see that the destination is a directory. test -d "$dest" && isdir=: if $isdir; then destdir=$dest destname= else func_dirname_and_basename "$dest" "" "." destdir=$func_dirname_result destname=$func_basename_result # Not a directory, so check to see that there is only one file specified. set dummy $files; shift test "$#" -gt 1 && \ func_fatal_help "'$dest' is not a directory" fi case $destdir in [\\/]* | [A-Za-z]:[\\/]*) ;; *) for file in $files; do case $file in *.lo) ;; *) func_fatal_help "'$destdir' must be an absolute directory name" ;; esac done ;; esac # This variable tells wrapper scripts just to set variables rather # than running their programs. libtool_install_magic=$magic staticlibs= future_libdirs= current_libdirs= for file in $files; do # Do each installation. case $file in *.$libext) # Do the static libraries later. func_append staticlibs " $file" ;; *.la) func_resolve_sysroot "$file" file=$func_resolve_sysroot_result # Check to see that this really is a libtool archive. func_lalib_unsafe_p "$file" \ || func_fatal_help "'$file' is not a valid libtool archive" library_names= old_library= relink_command= func_source "$file" # Add the libdir to current_libdirs if it is the destination. if test "X$destdir" = "X$libdir"; then case "$current_libdirs " in *" $libdir "*) ;; *) func_append current_libdirs " $libdir" ;; esac else # Note the libdir as a future libdir. case "$future_libdirs " in *" $libdir "*) ;; *) func_append future_libdirs " $libdir" ;; esac fi func_dirname "$file" "/" "" dir=$func_dirname_result func_append dir "$objdir" if test -n "$relink_command"; then # Determine the prefix the user has applied to our future dir. inst_prefix_dir=`$ECHO "$destdir" | $SED -e "s%$libdir\$%%"` # Don't allow the user to place us outside of our expected # location b/c this prevents finding dependent libraries that # are installed to the same prefix. # At present, this check doesn't affect windows .dll's that # are installed into $libdir/../bin (currently, that works fine) # but it's something to keep an eye on. test "$inst_prefix_dir" = "$destdir" && \ func_fatal_error "error: cannot install '$file' to a directory not ending in $libdir" if test -n "$inst_prefix_dir"; then # Stick the inst_prefix_dir data into the link command. relink_command=`$ECHO "$relink_command" | $SED "s%@inst_prefix_dir@%-inst-prefix-dir $inst_prefix_dir%"` else relink_command=`$ECHO "$relink_command" | $SED "s%@inst_prefix_dir@%%"` fi func_warning "relinking '$file'" func_show_eval "$relink_command" \ 'func_fatal_error "error: relink '\''$file'\'' with the above command before installing it"' fi # See the names of the shared library. set dummy $library_names; shift if test -n "$1"; then realname=$1 shift srcname=$realname test -n "$relink_command" && srcname=${realname}T # Install the shared library and build the symlinks. func_show_eval "$install_shared_prog $dir/$srcname $destdir/$realname" \ 'exit $?' tstripme=$stripme case $host_os in cygwin* | mingw* | pw32* | cegcc*) case $realname in *.dll.a) tstripme= ;; esac ;; os2*) case $realname in *_dll.a) tstripme= ;; esac ;; esac if test -n "$tstripme" && test -n "$striplib"; then func_show_eval "$striplib $destdir/$realname" 'exit $?' fi if test "$#" -gt 0; then # Delete the old symlinks, and create new ones. # Try 'ln -sf' first, because the 'ln' binary might depend on # the symlink we replace! Solaris /bin/ln does not understand -f, # so we also need to try rm && ln -s. for linkname do test "$linkname" != "$realname" \ && func_show_eval "(cd $destdir && { $LN_S -f $realname $linkname || { $RM $linkname && $LN_S $realname $linkname; }; })" done fi # Do each command in the postinstall commands. lib=$destdir/$realname func_execute_cmds "$postinstall_cmds" 'exit $?' fi # Install the pseudo-library for information purposes. func_basename "$file" name=$func_basename_result instname=$dir/${name}i func_show_eval "$install_prog $instname $destdir/$name" 'exit $?' # Maybe install the static library, too. test -n "$old_library" && func_append staticlibs " $dir/$old_library" ;; *.lo) # Install (i.e. copy) a libtool object. # Figure out destination file name, if it wasn't already specified. if test -n "$destname"; then destfile=$destdir/$destname else func_basename "$file" destfile=$func_basename_result destfile=$destdir/$destfile fi # Deduce the name of the destination old-style object file. case $destfile in *.lo) func_lo2o "$destfile" staticdest=$func_lo2o_result ;; *.$objext) staticdest=$destfile destfile= ;; *) func_fatal_help "cannot copy a libtool object to '$destfile'" ;; esac # Install the libtool object if requested. test -n "$destfile" && \ func_show_eval "$install_prog $file $destfile" 'exit $?' # Install the old object if enabled. if test yes = "$build_old_libs"; then # Deduce the name of the old-style object file. func_lo2o "$file" staticobj=$func_lo2o_result func_show_eval "$install_prog \$staticobj \$staticdest" 'exit $?' fi exit $EXIT_SUCCESS ;; *) # Figure out destination file name, if it wasn't already specified. if test -n "$destname"; then destfile=$destdir/$destname else func_basename "$file" destfile=$func_basename_result destfile=$destdir/$destfile fi # If the file is missing, and there is a .exe on the end, strip it # because it is most likely a libtool script we actually want to # install stripped_ext= case $file in *.exe) if test ! -f "$file"; then func_stripname '' '.exe' "$file" file=$func_stripname_result stripped_ext=.exe fi ;; esac # Do a test to see if this is really a libtool program. case $host in *cygwin* | *mingw*) if func_ltwrapper_executable_p "$file"; then func_ltwrapper_scriptname "$file" wrapper=$func_ltwrapper_scriptname_result else func_stripname '' '.exe' "$file" wrapper=$func_stripname_result fi ;; *) wrapper=$file ;; esac if func_ltwrapper_script_p "$wrapper"; then notinst_deplibs= relink_command= func_source "$wrapper" # Check the variables that should have been set. test -z "$generated_by_libtool_version" && \ func_fatal_error "invalid libtool wrapper script '$wrapper'" finalize=: for lib in $notinst_deplibs; do # Check to see that each library is installed. libdir= if test -f "$lib"; then func_source "$lib" fi libfile=$libdir/`$ECHO "$lib" | $SED 's%^.*/%%g'` if test -n "$libdir" && test ! -f "$libfile"; then func_warning "'$lib' has not been installed in '$libdir'" finalize=false fi done relink_command= func_source "$wrapper" outputname= if test no = "$fast_install" && test -n "$relink_command"; then $opt_dry_run || { if $finalize; then tmpdir=`func_mktempdir` func_basename "$file$stripped_ext" file=$func_basename_result outputname=$tmpdir/$file # Replace the output file specification. relink_command=`$ECHO "$relink_command" | $SED 's%@OUTPUT@%'"$outputname"'%g'` $opt_quiet || { func_quote_for_expand "$relink_command" eval "func_echo $func_quote_for_expand_result" } if eval "$relink_command"; then : else func_error "error: relink '$file' with the above command before installing it" $opt_dry_run || ${RM}r "$tmpdir" continue fi file=$outputname else func_warning "cannot relink '$file'" fi } else # Install the binary that we compiled earlier. file=`$ECHO "$file$stripped_ext" | $SED "s%\([^/]*\)$%$objdir/\1%"` fi fi # remove .exe since cygwin /usr/bin/install will append another # one anyway case $install_prog,$host in */usr/bin/install*,*cygwin*) case $file:$destfile in *.exe:*.exe) # this is ok ;; *.exe:*) destfile=$destfile.exe ;; *:*.exe) func_stripname '' '.exe' "$destfile" destfile=$func_stripname_result ;; esac ;; esac func_show_eval "$install_prog\$stripme \$file \$destfile" 'exit $?' $opt_dry_run || if test -n "$outputname"; then ${RM}r "$tmpdir" fi ;; esac done for file in $staticlibs; do func_basename "$file" name=$func_basename_result # Set up the ranlib parameters. oldlib=$destdir/$name func_to_tool_file "$oldlib" func_convert_file_msys_to_w32 tool_oldlib=$func_to_tool_file_result func_show_eval "$install_prog \$file \$oldlib" 'exit $?' if test -n "$stripme" && test -n "$old_striplib"; then func_show_eval "$old_striplib $tool_oldlib" 'exit $?' fi # Do each command in the postinstall commands. func_execute_cmds "$old_postinstall_cmds" 'exit $?' done test -n "$future_libdirs" && \ func_warning "remember to run '$progname --finish$future_libdirs'" if test -n "$current_libdirs"; then # Maybe just do a dry run. $opt_dry_run && current_libdirs=" -n$current_libdirs" exec_cmd='$SHELL "$progpath" $preserve_args --finish$current_libdirs' else exit $EXIT_SUCCESS fi } test install = "$opt_mode" && func_mode_install ${1+"$@"} # func_generate_dlsyms outputname originator pic_p # Extract symbols from dlprefiles and create ${outputname}S.o with # a dlpreopen symbol table. func_generate_dlsyms () { $debug_cmd my_outputname=$1 my_originator=$2 my_pic_p=${3-false} my_prefix=`$ECHO "$my_originator" | $SED 's%[^a-zA-Z0-9]%_%g'` my_dlsyms= if test -n "$dlfiles$dlprefiles" || test no != "$dlself"; then if test -n "$NM" && test -n "$global_symbol_pipe"; then my_dlsyms=${my_outputname}S.c else func_error "not configured to extract global symbols from dlpreopened files" fi fi if test -n "$my_dlsyms"; then case $my_dlsyms in "") ;; *.c) # Discover the nlist of each of the dlfiles. nlist=$output_objdir/$my_outputname.nm func_show_eval "$RM $nlist ${nlist}S ${nlist}T" # Parse the name list into a source file. func_verbose "creating $output_objdir/$my_dlsyms" $opt_dry_run || $ECHO > "$output_objdir/$my_dlsyms" "\ /* $my_dlsyms - symbol resolution table for '$my_outputname' dlsym emulation. */ /* Generated by $PROGRAM (GNU $PACKAGE) $VERSION */ #ifdef __cplusplus extern \"C\" { #endif #if defined __GNUC__ && (((__GNUC__ == 4) && (__GNUC_MINOR__ >= 4)) || (__GNUC__ > 4)) #pragma GCC diagnostic ignored \"-Wstrict-prototypes\" #endif /* Keep this code in sync between libtool.m4, ltmain, lt_system.h, and tests. */ #if defined _WIN32 || defined __CYGWIN__ || defined _WIN32_WCE /* DATA imports from DLLs on WIN32 can't be const, because runtime relocations are performed -- see ld's documentation on pseudo-relocs. */ # define LT_DLSYM_CONST #elif defined __osf__ /* This system does not cope well with relocations in const data. */ # define LT_DLSYM_CONST #else # define LT_DLSYM_CONST const #endif #define STREQ(s1, s2) (strcmp ((s1), (s2)) == 0) /* External symbol declarations for the compiler. */\ " if test yes = "$dlself"; then func_verbose "generating symbol list for '$output'" $opt_dry_run || echo ': @PROGRAM@ ' > "$nlist" # Add our own program objects to the symbol list. progfiles=`$ECHO "$objs$old_deplibs" | $SP2NL | $SED "$lo2o" | $NL2SP` for progfile in $progfiles; do func_to_tool_file "$progfile" func_convert_file_msys_to_w32 func_verbose "extracting global C symbols from '$func_to_tool_file_result'" $opt_dry_run || eval "$NM $func_to_tool_file_result | $global_symbol_pipe >> '$nlist'" done if test -n "$exclude_expsyms"; then $opt_dry_run || { eval '$EGREP -v " ($exclude_expsyms)$" "$nlist" > "$nlist"T' eval '$MV "$nlist"T "$nlist"' } fi if test -n "$export_symbols_regex"; then $opt_dry_run || { eval '$EGREP -e "$export_symbols_regex" "$nlist" > "$nlist"T' eval '$MV "$nlist"T "$nlist"' } fi # Prepare the list of exported symbols if test -z "$export_symbols"; then export_symbols=$output_objdir/$outputname.exp $opt_dry_run || { $RM $export_symbols eval "$SED -n -e '/^: @PROGRAM@ $/d' -e 's/^.* \(.*\)$/\1/p' "'< "$nlist" > "$export_symbols"' case $host in *cygwin* | *mingw* | *cegcc* ) eval "echo EXPORTS "'> "$output_objdir/$outputname.def"' eval 'cat "$export_symbols" >> "$output_objdir/$outputname.def"' ;; esac } else $opt_dry_run || { eval "$SED -e 's/\([].[*^$]\)/\\\\\1/g' -e 's/^/ /' -e 's/$/$/'"' < "$export_symbols" > "$output_objdir/$outputname.exp"' eval '$GREP -f "$output_objdir/$outputname.exp" < "$nlist" > "$nlist"T' eval '$MV "$nlist"T "$nlist"' case $host in *cygwin* | *mingw* | *cegcc* ) eval "echo EXPORTS "'> "$output_objdir/$outputname.def"' eval 'cat "$nlist" >> "$output_objdir/$outputname.def"' ;; esac } fi fi for dlprefile in $dlprefiles; do func_verbose "extracting global C symbols from '$dlprefile'" func_basename "$dlprefile" name=$func_basename_result case $host in *cygwin* | *mingw* | *cegcc* ) # if an import library, we need to obtain dlname if func_win32_import_lib_p "$dlprefile"; then func_tr_sh "$dlprefile" eval "curr_lafile=\$libfile_$func_tr_sh_result" dlprefile_dlbasename= if test -n "$curr_lafile" && func_lalib_p "$curr_lafile"; then # Use subshell, to avoid clobbering current variable values dlprefile_dlname=`source "$curr_lafile" && echo "$dlname"` if test -n "$dlprefile_dlname"; then func_basename "$dlprefile_dlname" dlprefile_dlbasename=$func_basename_result else # no lafile. user explicitly requested -dlpreopen . $sharedlib_from_linklib_cmd "$dlprefile" dlprefile_dlbasename=$sharedlib_from_linklib_result fi fi $opt_dry_run || { if test -n "$dlprefile_dlbasename"; then eval '$ECHO ": $dlprefile_dlbasename" >> "$nlist"' else func_warning "Could not compute DLL name from $name" eval '$ECHO ": $name " >> "$nlist"' fi func_to_tool_file "$dlprefile" func_convert_file_msys_to_w32 eval "$NM \"$func_to_tool_file_result\" 2>/dev/null | $global_symbol_pipe | $SED -e '/I __imp/d' -e 's/I __nm_/D /;s/_nm__//' >> '$nlist'" } else # not an import lib $opt_dry_run || { eval '$ECHO ": $name " >> "$nlist"' func_to_tool_file "$dlprefile" func_convert_file_msys_to_w32 eval "$NM \"$func_to_tool_file_result\" 2>/dev/null | $global_symbol_pipe >> '$nlist'" } fi ;; *) $opt_dry_run || { eval '$ECHO ": $name " >> "$nlist"' func_to_tool_file "$dlprefile" func_convert_file_msys_to_w32 eval "$NM \"$func_to_tool_file_result\" 2>/dev/null | $global_symbol_pipe >> '$nlist'" } ;; esac done $opt_dry_run || { # Make sure we have at least an empty file. test -f "$nlist" || : > "$nlist" if test -n "$exclude_expsyms"; then $EGREP -v " ($exclude_expsyms)$" "$nlist" > "$nlist"T $MV "$nlist"T "$nlist" fi # Try sorting and uniquifying the output. if $GREP -v "^: " < "$nlist" | if sort -k 3 /dev/null 2>&1; then sort -k 3 else sort +2 fi | uniq > "$nlist"S; then : else $GREP -v "^: " < "$nlist" > "$nlist"S fi if test -f "$nlist"S; then eval "$global_symbol_to_cdecl"' < "$nlist"S >> "$output_objdir/$my_dlsyms"' else echo '/* NONE */' >> "$output_objdir/$my_dlsyms" fi func_show_eval '$RM "${nlist}I"' if test -n "$global_symbol_to_import"; then eval "$global_symbol_to_import"' < "$nlist"S > "$nlist"I' fi echo >> "$output_objdir/$my_dlsyms" "\ /* The mapping between symbol names and symbols. */ typedef struct { const char *name; void *address; } lt_dlsymlist; extern LT_DLSYM_CONST lt_dlsymlist lt_${my_prefix}_LTX_preloaded_symbols[];\ " if test -s "$nlist"I; then echo >> "$output_objdir/$my_dlsyms" "\ static void lt_syminit(void) { LT_DLSYM_CONST lt_dlsymlist *symbol = lt_${my_prefix}_LTX_preloaded_symbols; for (; symbol->name; ++symbol) {" $SED 's/.*/ if (STREQ (symbol->name, \"&\")) symbol->address = (void *) \&&;/' < "$nlist"I >> "$output_objdir/$my_dlsyms" echo >> "$output_objdir/$my_dlsyms" "\ } }" fi echo >> "$output_objdir/$my_dlsyms" "\ LT_DLSYM_CONST lt_dlsymlist lt_${my_prefix}_LTX_preloaded_symbols[] = { {\"$my_originator\", (void *) 0}," if test -s "$nlist"I; then echo >> "$output_objdir/$my_dlsyms" "\ {\"@INIT@\", (void *) <_syminit}," fi case $need_lib_prefix in no) eval "$global_symbol_to_c_name_address" < "$nlist" >> "$output_objdir/$my_dlsyms" ;; *) eval "$global_symbol_to_c_name_address_lib_prefix" < "$nlist" >> "$output_objdir/$my_dlsyms" ;; esac echo >> "$output_objdir/$my_dlsyms" "\ {0, (void *) 0} }; /* This works around a problem in FreeBSD linker */ #ifdef FREEBSD_WORKAROUND static const void *lt_preloaded_setup() { return lt_${my_prefix}_LTX_preloaded_symbols; } #endif #ifdef __cplusplus } #endif\ " } # !$opt_dry_run pic_flag_for_symtable= case "$compile_command " in *" -static "*) ;; *) case $host in # compiling the symbol table file with pic_flag works around # a FreeBSD bug that causes programs to crash when -lm is # linked before any other PIC object. But we must not use # pic_flag when linking with -static. The problem exists in # FreeBSD 2.2.6 and is fixed in FreeBSD 3.1. *-*-freebsd2.*|*-*-freebsd3.0*|*-*-freebsdelf3.0*) pic_flag_for_symtable=" $pic_flag -DFREEBSD_WORKAROUND" ;; *-*-hpux*) pic_flag_for_symtable=" $pic_flag" ;; *) $my_pic_p && pic_flag_for_symtable=" $pic_flag" ;; esac ;; esac symtab_cflags= for arg in $LTCFLAGS; do case $arg in -pie | -fpie | -fPIE) ;; *) func_append symtab_cflags " $arg" ;; esac done # Now compile the dynamic symbol file. func_show_eval '(cd $output_objdir && $LTCC$symtab_cflags -c$no_builtin_flag$pic_flag_for_symtable "$my_dlsyms")' 'exit $?' # Clean up the generated files. func_show_eval '$RM "$output_objdir/$my_dlsyms" "$nlist" "${nlist}S" "${nlist}T" "${nlist}I"' # Transform the symbol file into the correct name. symfileobj=$output_objdir/${my_outputname}S.$objext case $host in *cygwin* | *mingw* | *cegcc* ) if test -f "$output_objdir/$my_outputname.def"; then compile_command=`$ECHO "$compile_command" | $SED "s%@SYMFILE@%$output_objdir/$my_outputname.def $symfileobj%"` finalize_command=`$ECHO "$finalize_command" | $SED "s%@SYMFILE@%$output_objdir/$my_outputname.def $symfileobj%"` else compile_command=`$ECHO "$compile_command" | $SED "s%@SYMFILE@%$symfileobj%"` finalize_command=`$ECHO "$finalize_command" | $SED "s%@SYMFILE@%$symfileobj%"` fi ;; *) compile_command=`$ECHO "$compile_command" | $SED "s%@SYMFILE@%$symfileobj%"` finalize_command=`$ECHO "$finalize_command" | $SED "s%@SYMFILE@%$symfileobj%"` ;; esac ;; *) func_fatal_error "unknown suffix for '$my_dlsyms'" ;; esac else # We keep going just in case the user didn't refer to # lt_preloaded_symbols. The linker will fail if global_symbol_pipe # really was required. # Nullify the symbol file. compile_command=`$ECHO "$compile_command" | $SED "s% @SYMFILE@%%"` finalize_command=`$ECHO "$finalize_command" | $SED "s% @SYMFILE@%%"` fi } # func_cygming_gnu_implib_p ARG # This predicate returns with zero status (TRUE) if # ARG is a GNU/binutils-style import library. Returns # with nonzero status (FALSE) otherwise. func_cygming_gnu_implib_p () { $debug_cmd func_to_tool_file "$1" func_convert_file_msys_to_w32 func_cygming_gnu_implib_tmp=`$NM "$func_to_tool_file_result" | eval "$global_symbol_pipe" | $EGREP ' (_head_[A-Za-z0-9_]+_[ad]l*|[A-Za-z0-9_]+_[ad]l*_iname)$'` test -n "$func_cygming_gnu_implib_tmp" } # func_cygming_ms_implib_p ARG # This predicate returns with zero status (TRUE) if # ARG is an MS-style import library. Returns # with nonzero status (FALSE) otherwise. func_cygming_ms_implib_p () { $debug_cmd func_to_tool_file "$1" func_convert_file_msys_to_w32 func_cygming_ms_implib_tmp=`$NM "$func_to_tool_file_result" | eval "$global_symbol_pipe" | $GREP '_NULL_IMPORT_DESCRIPTOR'` test -n "$func_cygming_ms_implib_tmp" } # func_win32_libid arg # return the library type of file 'arg' # # Need a lot of goo to handle *both* DLLs and import libs # Has to be a shell function in order to 'eat' the argument # that is supplied when $file_magic_command is called. # Despite the name, also deal with 64 bit binaries. func_win32_libid () { $debug_cmd win32_libid_type=unknown win32_fileres=`file -L $1 2>/dev/null` case $win32_fileres in *ar\ archive\ import\ library*) # definitely import win32_libid_type="x86 archive import" ;; *ar\ archive*) # could be an import, or static # Keep the egrep pattern in sync with the one in _LT_CHECK_MAGIC_METHOD. if eval $OBJDUMP -f $1 | $SED -e '10q' 2>/dev/null | $EGREP 'file format (pei*-i386(.*architecture: i386)?|pe-arm-wince|pe-x86-64)' >/dev/null; then case $nm_interface in "MS dumpbin") if func_cygming_ms_implib_p "$1" || func_cygming_gnu_implib_p "$1" then win32_nmres=import else win32_nmres= fi ;; *) func_to_tool_file "$1" func_convert_file_msys_to_w32 win32_nmres=`eval $NM -f posix -A \"$func_to_tool_file_result\" | $SED -n -e ' 1,100{ / I /{ s|.*|import| p q } }'` ;; esac case $win32_nmres in import*) win32_libid_type="x86 archive import";; *) win32_libid_type="x86 archive static";; esac fi ;; *DLL*) win32_libid_type="x86 DLL" ;; *executable*) # but shell scripts are "executable" too... case $win32_fileres in *MS\ Windows\ PE\ Intel*) win32_libid_type="x86 DLL" ;; esac ;; esac $ECHO "$win32_libid_type" } # func_cygming_dll_for_implib ARG # # Platform-specific function to extract the # name of the DLL associated with the specified # import library ARG. # Invoked by eval'ing the libtool variable # $sharedlib_from_linklib_cmd # Result is available in the variable # $sharedlib_from_linklib_result func_cygming_dll_for_implib () { $debug_cmd sharedlib_from_linklib_result=`$DLLTOOL --identify-strict --identify "$1"` } # func_cygming_dll_for_implib_fallback_core SECTION_NAME LIBNAMEs # # The is the core of a fallback implementation of a # platform-specific function to extract the name of the # DLL associated with the specified import library LIBNAME. # # SECTION_NAME is either .idata$6 or .idata$7, depending # on the platform and compiler that created the implib. # # Echos the name of the DLL associated with the # specified import library. func_cygming_dll_for_implib_fallback_core () { $debug_cmd match_literal=`$ECHO "$1" | $SED "$sed_make_literal_regex"` $OBJDUMP -s --section "$1" "$2" 2>/dev/null | $SED '/^Contents of section '"$match_literal"':/{ # Place marker at beginning of archive member dllname section s/.*/====MARK====/ p d } # These lines can sometimes be longer than 43 characters, but # are always uninteresting /:[ ]*file format pe[i]\{,1\}-/d /^In archive [^:]*:/d # Ensure marker is printed /^====MARK====/p # Remove all lines with less than 43 characters /^.\{43\}/!d # From remaining lines, remove first 43 characters s/^.\{43\}//' | $SED -n ' # Join marker and all lines until next marker into a single line /^====MARK====/ b para H $ b para b :para x s/\n//g # Remove the marker s/^====MARK====// # Remove trailing dots and whitespace s/[\. \t]*$// # Print /./p' | # we now have a list, one entry per line, of the stringified # contents of the appropriate section of all members of the # archive that possess that section. Heuristic: eliminate # all those that have a first or second character that is # a '.' (that is, objdump's representation of an unprintable # character.) This should work for all archives with less than # 0x302f exports -- but will fail for DLLs whose name actually # begins with a literal '.' or a single character followed by # a '.'. # # Of those that remain, print the first one. $SED -e '/^\./d;/^.\./d;q' } # func_cygming_dll_for_implib_fallback ARG # Platform-specific function to extract the # name of the DLL associated with the specified # import library ARG. # # This fallback implementation is for use when $DLLTOOL # does not support the --identify-strict option. # Invoked by eval'ing the libtool variable # $sharedlib_from_linklib_cmd # Result is available in the variable # $sharedlib_from_linklib_result func_cygming_dll_for_implib_fallback () { $debug_cmd if func_cygming_gnu_implib_p "$1"; then # binutils import library sharedlib_from_linklib_result=`func_cygming_dll_for_implib_fallback_core '.idata$7' "$1"` elif func_cygming_ms_implib_p "$1"; then # ms-generated import library sharedlib_from_linklib_result=`func_cygming_dll_for_implib_fallback_core '.idata$6' "$1"` else # unknown sharedlib_from_linklib_result= fi } # func_extract_an_archive dir oldlib func_extract_an_archive () { $debug_cmd f_ex_an_ar_dir=$1; shift f_ex_an_ar_oldlib=$1 if test yes = "$lock_old_archive_extraction"; then lockfile=$f_ex_an_ar_oldlib.lock until $opt_dry_run || ln "$progpath" "$lockfile" 2>/dev/null; do func_echo "Waiting for $lockfile to be removed" sleep 2 done fi func_show_eval "(cd \$f_ex_an_ar_dir && $AR x \"\$f_ex_an_ar_oldlib\")" \ 'stat=$?; rm -f "$lockfile"; exit $stat' if test yes = "$lock_old_archive_extraction"; then $opt_dry_run || rm -f "$lockfile" fi if ($AR t "$f_ex_an_ar_oldlib" | sort | sort -uc >/dev/null 2>&1); then : else func_fatal_error "object name conflicts in archive: $f_ex_an_ar_dir/$f_ex_an_ar_oldlib" fi } # func_extract_archives gentop oldlib ... func_extract_archives () { $debug_cmd my_gentop=$1; shift my_oldlibs=${1+"$@"} my_oldobjs= my_xlib= my_xabs= my_xdir= for my_xlib in $my_oldlibs; do # Extract the objects. case $my_xlib in [\\/]* | [A-Za-z]:[\\/]*) my_xabs=$my_xlib ;; *) my_xabs=`pwd`"/$my_xlib" ;; esac func_basename "$my_xlib" my_xlib=$func_basename_result my_xlib_u=$my_xlib while :; do case " $extracted_archives " in *" $my_xlib_u "*) func_arith $extracted_serial + 1 extracted_serial=$func_arith_result my_xlib_u=lt$extracted_serial-$my_xlib ;; *) break ;; esac done extracted_archives="$extracted_archives $my_xlib_u" my_xdir=$my_gentop/$my_xlib_u func_mkdir_p "$my_xdir" case $host in *-darwin*) func_verbose "Extracting $my_xabs" # Do not bother doing anything if just a dry run $opt_dry_run || { darwin_orig_dir=`pwd` cd $my_xdir || exit $? darwin_archive=$my_xabs darwin_curdir=`pwd` func_basename "$darwin_archive" darwin_base_archive=$func_basename_result darwin_arches=`$LIPO -info "$darwin_archive" 2>/dev/null | $GREP Architectures 2>/dev/null || true` if test -n "$darwin_arches"; then darwin_arches=`$ECHO "$darwin_arches" | $SED -e 's/.*are://'` darwin_arch= func_verbose "$darwin_base_archive has multiple architectures $darwin_arches" for darwin_arch in $darwin_arches; do func_mkdir_p "unfat-$$/$darwin_base_archive-$darwin_arch" $LIPO -thin $darwin_arch -output "unfat-$$/$darwin_base_archive-$darwin_arch/$darwin_base_archive" "$darwin_archive" cd "unfat-$$/$darwin_base_archive-$darwin_arch" func_extract_an_archive "`pwd`" "$darwin_base_archive" cd "$darwin_curdir" $RM "unfat-$$/$darwin_base_archive-$darwin_arch/$darwin_base_archive" done # $darwin_arches ## Okay now we've a bunch of thin objects, gotta fatten them up :) darwin_filelist=`find unfat-$$ -type f -name \*.o -print -o -name \*.lo -print | $SED -e "$sed_basename" | sort -u` darwin_file= darwin_files= for darwin_file in $darwin_filelist; do darwin_files=`find unfat-$$ -name $darwin_file -print | sort | $NL2SP` $LIPO -create -output "$darwin_file" $darwin_files done # $darwin_filelist $RM -rf unfat-$$ cd "$darwin_orig_dir" else cd $darwin_orig_dir func_extract_an_archive "$my_xdir" "$my_xabs" fi # $darwin_arches } # !$opt_dry_run ;; *) func_extract_an_archive "$my_xdir" "$my_xabs" ;; esac my_oldobjs="$my_oldobjs "`find $my_xdir -name \*.$objext -print -o -name \*.lo -print | sort | $NL2SP` done func_extract_archives_result=$my_oldobjs } # func_emit_wrapper [arg=no] # # Emit a libtool wrapper script on stdout. # Don't directly open a file because we may want to # incorporate the script contents within a cygwin/mingw # wrapper executable. Must ONLY be called from within # func_mode_link because it depends on a number of variables # set therein. # # ARG is the value that the WRAPPER_SCRIPT_BELONGS_IN_OBJDIR # variable will take. If 'yes', then the emitted script # will assume that the directory where it is stored is # the $objdir directory. This is a cygwin/mingw-specific # behavior. func_emit_wrapper () { func_emit_wrapper_arg1=${1-no} $ECHO "\ #! $SHELL # $output - temporary wrapper script for $objdir/$outputname # Generated by $PROGRAM (GNU $PACKAGE) $VERSION # # The $output program cannot be directly executed until all the libtool # libraries that it depends on are installed. # # This wrapper script should never be moved out of the build directory. # If it is, it will not operate correctly. # Sed substitution that helps us do robust quoting. It backslashifies # metacharacters that are still active within double-quoted strings. sed_quote_subst='$sed_quote_subst' # Be Bourne compatible if test -n \"\${ZSH_VERSION+set}\" && (emulate sh) >/dev/null 2>&1; then emulate sh NULLCMD=: # Zsh 3.x and 4.x performs word splitting on \${1+\"\$@\"}, which # is contrary to our usage. Disable this feature. alias -g '\${1+\"\$@\"}'='\"\$@\"' setopt NO_GLOB_SUBST else case \`(set -o) 2>/dev/null\` in *posix*) set -o posix;; esac fi BIN_SH=xpg4; export BIN_SH # for Tru64 DUALCASE=1; export DUALCASE # for MKS sh # The HP-UX ksh and POSIX shell print the target directory to stdout # if CDPATH is set. (unset CDPATH) >/dev/null 2>&1 && unset CDPATH relink_command=\"$relink_command\" # This environment variable determines our operation mode. if test \"\$libtool_install_magic\" = \"$magic\"; then # install mode needs the following variables: generated_by_libtool_version='$macro_version' notinst_deplibs='$notinst_deplibs' else # When we are sourced in execute mode, \$file and \$ECHO are already set. if test \"\$libtool_execute_magic\" != \"$magic\"; then file=\"\$0\"" qECHO=`$ECHO "$ECHO" | $SED "$sed_quote_subst"` $ECHO "\ # A function that is used when there is no print builtin or printf. func_fallback_echo () { eval 'cat <<_LTECHO_EOF \$1 _LTECHO_EOF' } ECHO=\"$qECHO\" fi # Very basic option parsing. These options are (a) specific to # the libtool wrapper, (b) are identical between the wrapper # /script/ and the wrapper /executable/ that is used only on # windows platforms, and (c) all begin with the string "--lt-" # (application programs are unlikely to have options that match # this pattern). # # There are only two supported options: --lt-debug and # --lt-dump-script. There is, deliberately, no --lt-help. # # The first argument to this parsing function should be the # script's $0 value, followed by "$@". lt_option_debug= func_parse_lt_options () { lt_script_arg0=\$0 shift for lt_opt do case \"\$lt_opt\" in --lt-debug) lt_option_debug=1 ;; --lt-dump-script) lt_dump_D=\`\$ECHO \"X\$lt_script_arg0\" | $SED -e 's/^X//' -e 's%/[^/]*$%%'\` test \"X\$lt_dump_D\" = \"X\$lt_script_arg0\" && lt_dump_D=. lt_dump_F=\`\$ECHO \"X\$lt_script_arg0\" | $SED -e 's/^X//' -e 's%^.*/%%'\` cat \"\$lt_dump_D/\$lt_dump_F\" exit 0 ;; --lt-*) \$ECHO \"Unrecognized --lt- option: '\$lt_opt'\" 1>&2 exit 1 ;; esac done # Print the debug banner immediately: if test -n \"\$lt_option_debug\"; then echo \"$outputname:$output:\$LINENO: libtool wrapper (GNU $PACKAGE) $VERSION\" 1>&2 fi } # Used when --lt-debug. Prints its arguments to stdout # (redirection is the responsibility of the caller) func_lt_dump_args () { lt_dump_args_N=1; for lt_arg do \$ECHO \"$outputname:$output:\$LINENO: newargv[\$lt_dump_args_N]: \$lt_arg\" lt_dump_args_N=\`expr \$lt_dump_args_N + 1\` done } # Core function for launching the target application func_exec_program_core () { " case $host in # Backslashes separate directories on plain windows *-*-mingw | *-*-os2* | *-cegcc*) $ECHO "\ if test -n \"\$lt_option_debug\"; then \$ECHO \"$outputname:$output:\$LINENO: newargv[0]: \$progdir\\\\\$program\" 1>&2 func_lt_dump_args \${1+\"\$@\"} 1>&2 fi exec \"\$progdir\\\\\$program\" \${1+\"\$@\"} " ;; *) $ECHO "\ if test -n \"\$lt_option_debug\"; then \$ECHO \"$outputname:$output:\$LINENO: newargv[0]: \$progdir/\$program\" 1>&2 func_lt_dump_args \${1+\"\$@\"} 1>&2 fi exec \"\$progdir/\$program\" \${1+\"\$@\"} " ;; esac $ECHO "\ \$ECHO \"\$0: cannot exec \$program \$*\" 1>&2 exit 1 } # A function to encapsulate launching the target application # Strips options in the --lt-* namespace from \$@ and # launches target application with the remaining arguments. func_exec_program () { case \" \$* \" in *\\ --lt-*) for lt_wr_arg do case \$lt_wr_arg in --lt-*) ;; *) set x \"\$@\" \"\$lt_wr_arg\"; shift;; esac shift done ;; esac func_exec_program_core \${1+\"\$@\"} } # Parse options func_parse_lt_options \"\$0\" \${1+\"\$@\"} # Find the directory that this script lives in. thisdir=\`\$ECHO \"\$file\" | $SED 's%/[^/]*$%%'\` test \"x\$thisdir\" = \"x\$file\" && thisdir=. # Follow symbolic links until we get to the real thisdir. file=\`ls -ld \"\$file\" | $SED -n 's/.*-> //p'\` while test -n \"\$file\"; do destdir=\`\$ECHO \"\$file\" | $SED 's%/[^/]*\$%%'\` # If there was a directory component, then change thisdir. if test \"x\$destdir\" != \"x\$file\"; then case \"\$destdir\" in [\\\\/]* | [A-Za-z]:[\\\\/]*) thisdir=\"\$destdir\" ;; *) thisdir=\"\$thisdir/\$destdir\" ;; esac fi file=\`\$ECHO \"\$file\" | $SED 's%^.*/%%'\` file=\`ls -ld \"\$thisdir/\$file\" | $SED -n 's/.*-> //p'\` done # Usually 'no', except on cygwin/mingw when embedded into # the cwrapper. WRAPPER_SCRIPT_BELONGS_IN_OBJDIR=$func_emit_wrapper_arg1 if test \"\$WRAPPER_SCRIPT_BELONGS_IN_OBJDIR\" = \"yes\"; then # special case for '.' if test \"\$thisdir\" = \".\"; then thisdir=\`pwd\` fi # remove .libs from thisdir case \"\$thisdir\" in *[\\\\/]$objdir ) thisdir=\`\$ECHO \"\$thisdir\" | $SED 's%[\\\\/][^\\\\/]*$%%'\` ;; $objdir ) thisdir=. ;; esac fi # Try to get the absolute directory name. absdir=\`cd \"\$thisdir\" && pwd\` test -n \"\$absdir\" && thisdir=\"\$absdir\" " if test yes = "$fast_install"; then $ECHO "\ program=lt-'$outputname'$exeext progdir=\"\$thisdir/$objdir\" if test ! -f \"\$progdir/\$program\" || { file=\`ls -1dt \"\$progdir/\$program\" \"\$progdir/../\$program\" 2>/dev/null | $SED 1q\`; \\ test \"X\$file\" != \"X\$progdir/\$program\"; }; then file=\"\$\$-\$program\" if test ! -d \"\$progdir\"; then $MKDIR \"\$progdir\" else $RM \"\$progdir/\$file\" fi" $ECHO "\ # relink executable if necessary if test -n \"\$relink_command\"; then if relink_command_output=\`eval \$relink_command 2>&1\`; then : else \$ECHO \"\$relink_command_output\" >&2 $RM \"\$progdir/\$file\" exit 1 fi fi $MV \"\$progdir/\$file\" \"\$progdir/\$program\" 2>/dev/null || { $RM \"\$progdir/\$program\"; $MV \"\$progdir/\$file\" \"\$progdir/\$program\"; } $RM \"\$progdir/\$file\" fi" else $ECHO "\ program='$outputname' progdir=\"\$thisdir/$objdir\" " fi $ECHO "\ if test -f \"\$progdir/\$program\"; then" # fixup the dll searchpath if we need to. # # Fix the DLL searchpath if we need to. Do this before prepending # to shlibpath, because on Windows, both are PATH and uninstalled # libraries must come first. if test -n "$dllsearchpath"; then $ECHO "\ # Add the dll search path components to the executable PATH PATH=$dllsearchpath:\$PATH " fi # Export our shlibpath_var if we have one. if test yes = "$shlibpath_overrides_runpath" && test -n "$shlibpath_var" && test -n "$temp_rpath"; then $ECHO "\ # Add our own library path to $shlibpath_var $shlibpath_var=\"$temp_rpath\$$shlibpath_var\" # Some systems cannot cope with colon-terminated $shlibpath_var # The second colon is a workaround for a bug in BeOS R4 sed $shlibpath_var=\`\$ECHO \"\$$shlibpath_var\" | $SED 's/::*\$//'\` export $shlibpath_var " fi $ECHO "\ if test \"\$libtool_execute_magic\" != \"$magic\"; then # Run the actual program with our arguments. func_exec_program \${1+\"\$@\"} fi else # The program doesn't exist. \$ECHO \"\$0: error: '\$progdir/\$program' does not exist\" 1>&2 \$ECHO \"This script is just a wrapper for \$program.\" 1>&2 \$ECHO \"See the $PACKAGE documentation for more information.\" 1>&2 exit 1 fi fi\ " } # func_emit_cwrapperexe_src # emit the source code for a wrapper executable on stdout # Must ONLY be called from within func_mode_link because # it depends on a number of variable set therein. func_emit_cwrapperexe_src () { cat < #include #ifdef _MSC_VER # include # include # include #else # include # include # ifdef __CYGWIN__ # include # endif #endif #include #include #include #include #include #include #include #include #define STREQ(s1, s2) (strcmp ((s1), (s2)) == 0) /* declarations of non-ANSI functions */ #if defined __MINGW32__ # ifdef __STRICT_ANSI__ int _putenv (const char *); # endif #elif defined __CYGWIN__ # ifdef __STRICT_ANSI__ char *realpath (const char *, char *); int putenv (char *); int setenv (const char *, const char *, int); # endif /* #elif defined other_platform || defined ... */ #endif /* portability defines, excluding path handling macros */ #if defined _MSC_VER # define setmode _setmode # define stat _stat # define chmod _chmod # define getcwd _getcwd # define putenv _putenv # define S_IXUSR _S_IEXEC #elif defined __MINGW32__ # define setmode _setmode # define stat _stat # define chmod _chmod # define getcwd _getcwd # define putenv _putenv #elif defined __CYGWIN__ # define HAVE_SETENV # define FOPEN_WB "wb" /* #elif defined other platforms ... */ #endif #if defined PATH_MAX # define LT_PATHMAX PATH_MAX #elif defined MAXPATHLEN # define LT_PATHMAX MAXPATHLEN #else # define LT_PATHMAX 1024 #endif #ifndef S_IXOTH # define S_IXOTH 0 #endif #ifndef S_IXGRP # define S_IXGRP 0 #endif /* path handling portability macros */ #ifndef DIR_SEPARATOR # define DIR_SEPARATOR '/' # define PATH_SEPARATOR ':' #endif #if defined _WIN32 || defined __MSDOS__ || defined __DJGPP__ || \ defined __OS2__ # define HAVE_DOS_BASED_FILE_SYSTEM # define FOPEN_WB "wb" # ifndef DIR_SEPARATOR_2 # define DIR_SEPARATOR_2 '\\' # endif # ifndef PATH_SEPARATOR_2 # define PATH_SEPARATOR_2 ';' # endif #endif #ifndef DIR_SEPARATOR_2 # define IS_DIR_SEPARATOR(ch) ((ch) == DIR_SEPARATOR) #else /* DIR_SEPARATOR_2 */ # define IS_DIR_SEPARATOR(ch) \ (((ch) == DIR_SEPARATOR) || ((ch) == DIR_SEPARATOR_2)) #endif /* DIR_SEPARATOR_2 */ #ifndef PATH_SEPARATOR_2 # define IS_PATH_SEPARATOR(ch) ((ch) == PATH_SEPARATOR) #else /* PATH_SEPARATOR_2 */ # define IS_PATH_SEPARATOR(ch) ((ch) == PATH_SEPARATOR_2) #endif /* PATH_SEPARATOR_2 */ #ifndef FOPEN_WB # define FOPEN_WB "w" #endif #ifndef _O_BINARY # define _O_BINARY 0 #endif #define XMALLOC(type, num) ((type *) xmalloc ((num) * sizeof(type))) #define XFREE(stale) do { \ if (stale) { free (stale); stale = 0; } \ } while (0) #if defined LT_DEBUGWRAPPER static int lt_debug = 1; #else static int lt_debug = 0; #endif const char *program_name = "libtool-wrapper"; /* in case xstrdup fails */ void *xmalloc (size_t num); char *xstrdup (const char *string); const char *base_name (const char *name); char *find_executable (const char *wrapper); char *chase_symlinks (const char *pathspec); int make_executable (const char *path); int check_executable (const char *path); char *strendzap (char *str, const char *pat); void lt_debugprintf (const char *file, int line, const char *fmt, ...); void lt_fatal (const char *file, int line, const char *message, ...); static const char *nonnull (const char *s); static const char *nonempty (const char *s); void lt_setenv (const char *name, const char *value); char *lt_extend_str (const char *orig_value, const char *add, int to_end); void lt_update_exe_path (const char *name, const char *value); void lt_update_lib_path (const char *name, const char *value); char **prepare_spawn (char **argv); void lt_dump_script (FILE *f); EOF cat <= 0) && (st.st_mode & (S_IXUSR | S_IXGRP | S_IXOTH))) return 1; else return 0; } int make_executable (const char *path) { int rval = 0; struct stat st; lt_debugprintf (__FILE__, __LINE__, "(make_executable): %s\n", nonempty (path)); if ((!path) || (!*path)) return 0; if (stat (path, &st) >= 0) { rval = chmod (path, st.st_mode | S_IXOTH | S_IXGRP | S_IXUSR); } return rval; } /* Searches for the full path of the wrapper. Returns newly allocated full path name if found, NULL otherwise Does not chase symlinks, even on platforms that support them. */ char * find_executable (const char *wrapper) { int has_slash = 0; const char *p; const char *p_next; /* static buffer for getcwd */ char tmp[LT_PATHMAX + 1]; size_t tmp_len; char *concat_name; lt_debugprintf (__FILE__, __LINE__, "(find_executable): %s\n", nonempty (wrapper)); if ((wrapper == NULL) || (*wrapper == '\0')) return NULL; /* Absolute path? */ #if defined HAVE_DOS_BASED_FILE_SYSTEM if (isalpha ((unsigned char) wrapper[0]) && wrapper[1] == ':') { concat_name = xstrdup (wrapper); if (check_executable (concat_name)) return concat_name; XFREE (concat_name); } else { #endif if (IS_DIR_SEPARATOR (wrapper[0])) { concat_name = xstrdup (wrapper); if (check_executable (concat_name)) return concat_name; XFREE (concat_name); } #if defined HAVE_DOS_BASED_FILE_SYSTEM } #endif for (p = wrapper; *p; p++) if (*p == '/') { has_slash = 1; break; } if (!has_slash) { /* no slashes; search PATH */ const char *path = getenv ("PATH"); if (path != NULL) { for (p = path; *p; p = p_next) { const char *q; size_t p_len; for (q = p; *q; q++) if (IS_PATH_SEPARATOR (*q)) break; p_len = (size_t) (q - p); p_next = (*q == '\0' ? q : q + 1); if (p_len == 0) { /* empty path: current directory */ if (getcwd (tmp, LT_PATHMAX) == NULL) lt_fatal (__FILE__, __LINE__, "getcwd failed: %s", nonnull (strerror (errno))); tmp_len = strlen (tmp); concat_name = XMALLOC (char, tmp_len + 1 + strlen (wrapper) + 1); memcpy (concat_name, tmp, tmp_len); concat_name[tmp_len] = '/'; strcpy (concat_name + tmp_len + 1, wrapper); } else { concat_name = XMALLOC (char, p_len + 1 + strlen (wrapper) + 1); memcpy (concat_name, p, p_len); concat_name[p_len] = '/'; strcpy (concat_name + p_len + 1, wrapper); } if (check_executable (concat_name)) return concat_name; XFREE (concat_name); } } /* not found in PATH; assume curdir */ } /* Relative path | not found in path: prepend cwd */ if (getcwd (tmp, LT_PATHMAX) == NULL) lt_fatal (__FILE__, __LINE__, "getcwd failed: %s", nonnull (strerror (errno))); tmp_len = strlen (tmp); concat_name = XMALLOC (char, tmp_len + 1 + strlen (wrapper) + 1); memcpy (concat_name, tmp, tmp_len); concat_name[tmp_len] = '/'; strcpy (concat_name + tmp_len + 1, wrapper); if (check_executable (concat_name)) return concat_name; XFREE (concat_name); return NULL; } char * chase_symlinks (const char *pathspec) { #ifndef S_ISLNK return xstrdup (pathspec); #else char buf[LT_PATHMAX]; struct stat s; char *tmp_pathspec = xstrdup (pathspec); char *p; int has_symlinks = 0; while (strlen (tmp_pathspec) && !has_symlinks) { lt_debugprintf (__FILE__, __LINE__, "checking path component for symlinks: %s\n", tmp_pathspec); if (lstat (tmp_pathspec, &s) == 0) { if (S_ISLNK (s.st_mode) != 0) { has_symlinks = 1; break; } /* search backwards for last DIR_SEPARATOR */ p = tmp_pathspec + strlen (tmp_pathspec) - 1; while ((p > tmp_pathspec) && (!IS_DIR_SEPARATOR (*p))) p--; if ((p == tmp_pathspec) && (!IS_DIR_SEPARATOR (*p))) { /* no more DIR_SEPARATORS left */ break; } *p = '\0'; } else { lt_fatal (__FILE__, __LINE__, "error accessing file \"%s\": %s", tmp_pathspec, nonnull (strerror (errno))); } } XFREE (tmp_pathspec); if (!has_symlinks) { return xstrdup (pathspec); } tmp_pathspec = realpath (pathspec, buf); if (tmp_pathspec == 0) { lt_fatal (__FILE__, __LINE__, "could not follow symlinks for %s", pathspec); } return xstrdup (tmp_pathspec); #endif } char * strendzap (char *str, const char *pat) { size_t len, patlen; assert (str != NULL); assert (pat != NULL); len = strlen (str); patlen = strlen (pat); if (patlen <= len) { str += len - patlen; if (STREQ (str, pat)) *str = '\0'; } return str; } void lt_debugprintf (const char *file, int line, const char *fmt, ...) { va_list args; if (lt_debug) { (void) fprintf (stderr, "%s:%s:%d: ", program_name, file, line); va_start (args, fmt); (void) vfprintf (stderr, fmt, args); va_end (args); } } static void lt_error_core (int exit_status, const char *file, int line, const char *mode, const char *message, va_list ap) { fprintf (stderr, "%s:%s:%d: %s: ", program_name, file, line, mode); vfprintf (stderr, message, ap); fprintf (stderr, ".\n"); if (exit_status >= 0) exit (exit_status); } void lt_fatal (const char *file, int line, const char *message, ...) { va_list ap; va_start (ap, message); lt_error_core (EXIT_FAILURE, file, line, "FATAL", message, ap); va_end (ap); } static const char * nonnull (const char *s) { return s ? s : "(null)"; } static const char * nonempty (const char *s) { return (s && !*s) ? "(empty)" : nonnull (s); } void lt_setenv (const char *name, const char *value) { lt_debugprintf (__FILE__, __LINE__, "(lt_setenv) setting '%s' to '%s'\n", nonnull (name), nonnull (value)); { #ifdef HAVE_SETENV /* always make a copy, for consistency with !HAVE_SETENV */ char *str = xstrdup (value); setenv (name, str, 1); #else size_t len = strlen (name) + 1 + strlen (value) + 1; char *str = XMALLOC (char, len); sprintf (str, "%s=%s", name, value); if (putenv (str) != EXIT_SUCCESS) { XFREE (str); } #endif } } char * lt_extend_str (const char *orig_value, const char *add, int to_end) { char *new_value; if (orig_value && *orig_value) { size_t orig_value_len = strlen (orig_value); size_t add_len = strlen (add); new_value = XMALLOC (char, add_len + orig_value_len + 1); if (to_end) { strcpy (new_value, orig_value); strcpy (new_value + orig_value_len, add); } else { strcpy (new_value, add); strcpy (new_value + add_len, orig_value); } } else { new_value = xstrdup (add); } return new_value; } void lt_update_exe_path (const char *name, const char *value) { lt_debugprintf (__FILE__, __LINE__, "(lt_update_exe_path) modifying '%s' by prepending '%s'\n", nonnull (name), nonnull (value)); if (name && *name && value && *value) { char *new_value = lt_extend_str (getenv (name), value, 0); /* some systems can't cope with a ':'-terminated path #' */ size_t len = strlen (new_value); while ((len > 0) && IS_PATH_SEPARATOR (new_value[len-1])) { new_value[--len] = '\0'; } lt_setenv (name, new_value); XFREE (new_value); } } void lt_update_lib_path (const char *name, const char *value) { lt_debugprintf (__FILE__, __LINE__, "(lt_update_lib_path) modifying '%s' by prepending '%s'\n", nonnull (name), nonnull (value)); if (name && *name && value && *value) { char *new_value = lt_extend_str (getenv (name), value, 0); lt_setenv (name, new_value); XFREE (new_value); } } EOF case $host_os in mingw*) cat <<"EOF" /* Prepares an argument vector before calling spawn(). Note that spawn() does not by itself call the command interpreter (getenv ("COMSPEC") != NULL ? getenv ("COMSPEC") : ({ OSVERSIONINFO v; v.dwOSVersionInfoSize = sizeof(OSVERSIONINFO); GetVersionEx(&v); v.dwPlatformId == VER_PLATFORM_WIN32_NT; }) ? "cmd.exe" : "command.com"). Instead it simply concatenates the arguments, separated by ' ', and calls CreateProcess(). We must quote the arguments since Win32 CreateProcess() interprets characters like ' ', '\t', '\\', '"' (but not '<' and '>') in a special way: - Space and tab are interpreted as delimiters. They are not treated as delimiters if they are surrounded by double quotes: "...". - Unescaped double quotes are removed from the input. Their only effect is that within double quotes, space and tab are treated like normal characters. - Backslashes not followed by double quotes are not special. - But 2*n+1 backslashes followed by a double quote become n backslashes followed by a double quote (n >= 0): \" -> " \\\" -> \" \\\\\" -> \\" */ #define SHELL_SPECIAL_CHARS "\"\\ \001\002\003\004\005\006\007\010\011\012\013\014\015\016\017\020\021\022\023\024\025\026\027\030\031\032\033\034\035\036\037" #define SHELL_SPACE_CHARS " \001\002\003\004\005\006\007\010\011\012\013\014\015\016\017\020\021\022\023\024\025\026\027\030\031\032\033\034\035\036\037" char ** prepare_spawn (char **argv) { size_t argc; char **new_argv; size_t i; /* Count number of arguments. */ for (argc = 0; argv[argc] != NULL; argc++) ; /* Allocate new argument vector. */ new_argv = XMALLOC (char *, argc + 1); /* Put quoted arguments into the new argument vector. */ for (i = 0; i < argc; i++) { const char *string = argv[i]; if (string[0] == '\0') new_argv[i] = xstrdup ("\"\""); else if (strpbrk (string, SHELL_SPECIAL_CHARS) != NULL) { int quote_around = (strpbrk (string, SHELL_SPACE_CHARS) != NULL); size_t length; unsigned int backslashes; const char *s; char *quoted_string; char *p; length = 0; backslashes = 0; if (quote_around) length++; for (s = string; *s != '\0'; s++) { char c = *s; if (c == '"') length += backslashes + 1; length++; if (c == '\\') backslashes++; else backslashes = 0; } if (quote_around) length += backslashes + 1; quoted_string = XMALLOC (char, length + 1); p = quoted_string; backslashes = 0; if (quote_around) *p++ = '"'; for (s = string; *s != '\0'; s++) { char c = *s; if (c == '"') { unsigned int j; for (j = backslashes + 1; j > 0; j--) *p++ = '\\'; } *p++ = c; if (c == '\\') backslashes++; else backslashes = 0; } if (quote_around) { unsigned int j; for (j = backslashes; j > 0; j--) *p++ = '\\'; *p++ = '"'; } *p = '\0'; new_argv[i] = quoted_string; } else new_argv[i] = (char *) string; } new_argv[argc] = NULL; return new_argv; } EOF ;; esac cat <<"EOF" void lt_dump_script (FILE* f) { EOF func_emit_wrapper yes | $SED -n -e ' s/^\(.\{79\}\)\(..*\)/\1\ \2/ h s/\([\\"]\)/\\\1/g s/$/\\n/ s/\([^\n]*\).*/ fputs ("\1", f);/p g D' cat <<"EOF" } EOF } # end: func_emit_cwrapperexe_src # func_win32_import_lib_p ARG # True if ARG is an import lib, as indicated by $file_magic_cmd func_win32_import_lib_p () { $debug_cmd case `eval $file_magic_cmd \"\$1\" 2>/dev/null | $SED -e 10q` in *import*) : ;; *) false ;; esac } # func_suncc_cstd_abi # !!ONLY CALL THIS FOR SUN CC AFTER $compile_command IS FULLY EXPANDED!! # Several compiler flags select an ABI that is incompatible with the # Cstd library. Avoid specifying it if any are in CXXFLAGS. func_suncc_cstd_abi () { $debug_cmd case " $compile_command " in *" -compat=g "*|*\ -std=c++[0-9][0-9]\ *|*" -library=stdcxx4 "*|*" -library=stlport4 "*) suncc_use_cstd_abi=no ;; *) suncc_use_cstd_abi=yes ;; esac } # func_mode_link arg... func_mode_link () { $debug_cmd case $host in *-*-cygwin* | *-*-mingw* | *-*-pw32* | *-*-os2* | *-cegcc*) # It is impossible to link a dll without this setting, and # we shouldn't force the makefile maintainer to figure out # what system we are compiling for in order to pass an extra # flag for every libtool invocation. # allow_undefined=no # FIXME: Unfortunately, there are problems with the above when trying # to make a dll that has undefined symbols, in which case not # even a static library is built. For now, we need to specify # -no-undefined on the libtool link line when we can be certain # that all symbols are satisfied, otherwise we get a static library. allow_undefined=yes ;; *) allow_undefined=yes ;; esac libtool_args=$nonopt base_compile="$nonopt $@" compile_command=$nonopt finalize_command=$nonopt compile_rpath= finalize_rpath= compile_shlibpath= finalize_shlibpath= convenience= old_convenience= deplibs= old_deplibs= compiler_flags= linker_flags= dllsearchpath= lib_search_path=`pwd` inst_prefix_dir= new_inherited_linker_flags= avoid_version=no bindir= dlfiles= dlprefiles= dlself=no export_dynamic=no export_symbols= export_symbols_regex= generated= libobjs= ltlibs= module=no no_install=no objs= os2dllname= non_pic_objects= precious_files_regex= prefer_static_libs=no preload=false prev= prevarg= release= rpath= xrpath= perm_rpath= temp_rpath= thread_safe=no vinfo= vinfo_number=no weak_libs= single_module=$wl-single_module func_infer_tag $base_compile # We need to know -static, to get the right output filenames. for arg do case $arg in -shared) test yes != "$build_libtool_libs" \ && func_fatal_configuration "cannot build a shared library" build_old_libs=no break ;; -all-static | -static | -static-libtool-libs) case $arg in -all-static) if test yes = "$build_libtool_libs" && test -z "$link_static_flag"; then func_warning "complete static linking is impossible in this configuration" fi if test -n "$link_static_flag"; then dlopen_self=$dlopen_self_static fi prefer_static_libs=yes ;; -static) if test -z "$pic_flag" && test -n "$link_static_flag"; then dlopen_self=$dlopen_self_static fi prefer_static_libs=built ;; -static-libtool-libs) if test -z "$pic_flag" && test -n "$link_static_flag"; then dlopen_self=$dlopen_self_static fi prefer_static_libs=yes ;; esac build_libtool_libs=no build_old_libs=yes break ;; esac done # See if our shared archives depend on static archives. test -n "$old_archive_from_new_cmds" && build_old_libs=yes # Go through the arguments, transforming them on the way. while test "$#" -gt 0; do arg=$1 shift func_quote_for_eval "$arg" qarg=$func_quote_for_eval_unquoted_result func_append libtool_args " $func_quote_for_eval_result" # If the previous option needs an argument, assign it. if test -n "$prev"; then case $prev in output) func_append compile_command " @OUTPUT@" func_append finalize_command " @OUTPUT@" ;; esac case $prev in bindir) bindir=$arg prev= continue ;; dlfiles|dlprefiles) $preload || { # Add the symbol object into the linking commands. func_append compile_command " @SYMFILE@" func_append finalize_command " @SYMFILE@" preload=: } case $arg in *.la | *.lo) ;; # We handle these cases below. force) if test no = "$dlself"; then dlself=needless export_dynamic=yes fi prev= continue ;; self) if test dlprefiles = "$prev"; then dlself=yes elif test dlfiles = "$prev" && test yes != "$dlopen_self"; then dlself=yes else dlself=needless export_dynamic=yes fi prev= continue ;; *) if test dlfiles = "$prev"; then func_append dlfiles " $arg" else func_append dlprefiles " $arg" fi prev= continue ;; esac ;; expsyms) export_symbols=$arg test -f "$arg" \ || func_fatal_error "symbol file '$arg' does not exist" prev= continue ;; expsyms_regex) export_symbols_regex=$arg prev= continue ;; framework) case $host in *-*-darwin*) case "$deplibs " in *" $qarg.ltframework "*) ;; *) func_append deplibs " $qarg.ltframework" # this is fixed later ;; esac ;; esac prev= continue ;; inst_prefix) inst_prefix_dir=$arg prev= continue ;; mllvm) # Clang does not use LLVM to link, so we can simply discard any # '-mllvm $arg' options when doing the link step. prev= continue ;; objectlist) if test -f "$arg"; then save_arg=$arg moreargs= for fil in `cat "$save_arg"` do # func_append moreargs " $fil" arg=$fil # A libtool-controlled object. # Check to see that this really is a libtool object. if func_lalib_unsafe_p "$arg"; then pic_object= non_pic_object= # Read the .lo file func_source "$arg" if test -z "$pic_object" || test -z "$non_pic_object" || test none = "$pic_object" && test none = "$non_pic_object"; then func_fatal_error "cannot find name of object for '$arg'" fi # Extract subdirectory from the argument. func_dirname "$arg" "/" "" xdir=$func_dirname_result if test none != "$pic_object"; then # Prepend the subdirectory the object is found in. pic_object=$xdir$pic_object if test dlfiles = "$prev"; then if test yes = "$build_libtool_libs" && test yes = "$dlopen_support"; then func_append dlfiles " $pic_object" prev= continue else # If libtool objects are unsupported, then we need to preload. prev=dlprefiles fi fi # CHECK ME: I think I busted this. -Ossama if test dlprefiles = "$prev"; then # Preload the old-style object. func_append dlprefiles " $pic_object" prev= fi # A PIC object. func_append libobjs " $pic_object" arg=$pic_object fi # Non-PIC object. if test none != "$non_pic_object"; then # Prepend the subdirectory the object is found in. non_pic_object=$xdir$non_pic_object # A standard non-PIC object func_append non_pic_objects " $non_pic_object" if test -z "$pic_object" || test none = "$pic_object"; then arg=$non_pic_object fi else # If the PIC object exists, use it instead. # $xdir was prepended to $pic_object above. non_pic_object=$pic_object func_append non_pic_objects " $non_pic_object" fi else # Only an error if not doing a dry-run. if $opt_dry_run; then # Extract subdirectory from the argument. func_dirname "$arg" "/" "" xdir=$func_dirname_result func_lo2o "$arg" pic_object=$xdir$objdir/$func_lo2o_result non_pic_object=$xdir$func_lo2o_result func_append libobjs " $pic_object" func_append non_pic_objects " $non_pic_object" else func_fatal_error "'$arg' is not a valid libtool object" fi fi done else func_fatal_error "link input file '$arg' does not exist" fi arg=$save_arg prev= continue ;; os2dllname) os2dllname=$arg prev= continue ;; precious_regex) precious_files_regex=$arg prev= continue ;; release) release=-$arg prev= continue ;; rpath | xrpath) # We need an absolute path. case $arg in [\\/]* | [A-Za-z]:[\\/]*) ;; *) func_fatal_error "only absolute run-paths are allowed" ;; esac if test rpath = "$prev"; then case "$rpath " in *" $arg "*) ;; *) func_append rpath " $arg" ;; esac else case "$xrpath " in *" $arg "*) ;; *) func_append xrpath " $arg" ;; esac fi prev= continue ;; shrext) shrext_cmds=$arg prev= continue ;; weak) func_append weak_libs " $arg" prev= continue ;; xcclinker) func_append linker_flags " $qarg" func_append compiler_flags " $qarg" prev= func_append compile_command " $qarg" func_append finalize_command " $qarg" continue ;; xcompiler) func_append compiler_flags " $qarg" prev= func_append compile_command " $qarg" func_append finalize_command " $qarg" continue ;; xlinker) func_append linker_flags " $qarg" func_append compiler_flags " $wl$qarg" prev= func_append compile_command " $wl$qarg" func_append finalize_command " $wl$qarg" continue ;; *) eval "$prev=\"\$arg\"" prev= continue ;; esac fi # test -n "$prev" prevarg=$arg case $arg in -all-static) if test -n "$link_static_flag"; then # See comment for -static flag below, for more details. func_append compile_command " $link_static_flag" func_append finalize_command " $link_static_flag" fi continue ;; -allow-undefined) # FIXME: remove this flag sometime in the future. func_fatal_error "'-allow-undefined' must not be used because it is the default" ;; -avoid-version) avoid_version=yes continue ;; -bindir) prev=bindir continue ;; -dlopen) prev=dlfiles continue ;; -dlpreopen) prev=dlprefiles continue ;; -export-dynamic) export_dynamic=yes continue ;; -export-symbols | -export-symbols-regex) if test -n "$export_symbols" || test -n "$export_symbols_regex"; then func_fatal_error "more than one -exported-symbols argument is not allowed" fi if test X-export-symbols = "X$arg"; then prev=expsyms else prev=expsyms_regex fi continue ;; -framework) prev=framework continue ;; -inst-prefix-dir) prev=inst_prefix continue ;; # The native IRIX linker understands -LANG:*, -LIST:* and -LNO:* # so, if we see these flags be careful not to treat them like -L -L[A-Z][A-Z]*:*) case $with_gcc/$host in no/*-*-irix* | /*-*-irix*) func_append compile_command " $arg" func_append finalize_command " $arg" ;; esac continue ;; -L*) func_stripname "-L" '' "$arg" if test -z "$func_stripname_result"; then if test "$#" -gt 0; then func_fatal_error "require no space between '-L' and '$1'" else func_fatal_error "need path for '-L' option" fi fi func_resolve_sysroot "$func_stripname_result" dir=$func_resolve_sysroot_result # We need an absolute path. case $dir in [\\/]* | [A-Za-z]:[\\/]*) ;; *) absdir=`cd "$dir" && pwd` test -z "$absdir" && \ func_fatal_error "cannot determine absolute directory name of '$dir'" dir=$absdir ;; esac case "$deplibs " in *" -L$dir "* | *" $arg "*) # Will only happen for absolute or sysroot arguments ;; *) # Preserve sysroot, but never include relative directories case $dir in [\\/]* | [A-Za-z]:[\\/]* | =*) func_append deplibs " $arg" ;; *) func_append deplibs " -L$dir" ;; esac func_append lib_search_path " $dir" ;; esac case $host in *-*-cygwin* | *-*-mingw* | *-*-pw32* | *-*-os2* | *-cegcc*) testbindir=`$ECHO "$dir" | $SED 's*/lib$*/bin*'` case :$dllsearchpath: in *":$dir:"*) ;; ::) dllsearchpath=$dir;; *) func_append dllsearchpath ":$dir";; esac case :$dllsearchpath: in *":$testbindir:"*) ;; ::) dllsearchpath=$testbindir;; *) func_append dllsearchpath ":$testbindir";; esac ;; esac continue ;; -l*) if test X-lc = "X$arg" || test X-lm = "X$arg"; then case $host in *-*-cygwin* | *-*-mingw* | *-*-pw32* | *-*-beos* | *-cegcc* | *-*-haiku*) # These systems don't actually have a C or math library (as such) continue ;; *-*-os2*) # These systems don't actually have a C library (as such) test X-lc = "X$arg" && continue ;; *-*-openbsd* | *-*-freebsd* | *-*-dragonfly* | *-*-bitrig*) # Do not include libc due to us having libc/libc_r. test X-lc = "X$arg" && continue ;; *-*-rhapsody* | *-*-darwin1.[012]) # Rhapsody C and math libraries are in the System framework func_append deplibs " System.ltframework" continue ;; *-*-sco3.2v5* | *-*-sco5v6*) # Causes problems with __ctype test X-lc = "X$arg" && continue ;; *-*-sysv4.2uw2* | *-*-sysv5* | *-*-unixware* | *-*-OpenUNIX*) # Compiler inserts libc in the correct place for threads to work test X-lc = "X$arg" && continue ;; esac elif test X-lc_r = "X$arg"; then case $host in *-*-openbsd* | *-*-freebsd* | *-*-dragonfly* | *-*-bitrig*) # Do not include libc_r directly, use -pthread flag. continue ;; esac fi func_append deplibs " $arg" continue ;; -mllvm) prev=mllvm continue ;; -module) module=yes continue ;; # Tru64 UNIX uses -model [arg] to determine the layout of C++ # classes, name mangling, and exception handling. # Darwin uses the -arch flag to determine output architecture. -model|-arch|-isysroot|--sysroot) func_append compiler_flags " $arg" func_append compile_command " $arg" func_append finalize_command " $arg" prev=xcompiler continue ;; -mt|-mthreads|-kthread|-Kthread|-pthread|-pthreads|--thread-safe \ |-threads|-fopenmp|-openmp|-mp|-xopenmp|-omp|-qsmp=*) func_append compiler_flags " $arg" func_append compile_command " $arg" func_append finalize_command " $arg" case "$new_inherited_linker_flags " in *" $arg "*) ;; * ) func_append new_inherited_linker_flags " $arg" ;; esac continue ;; -multi_module) single_module=$wl-multi_module continue ;; -no-fast-install) fast_install=no continue ;; -no-install) case $host in *-*-cygwin* | *-*-mingw* | *-*-pw32* | *-*-os2* | *-*-darwin* | *-cegcc*) # The PATH hackery in wrapper scripts is required on Windows # and Darwin in order for the loader to find any dlls it needs. func_warning "'-no-install' is ignored for $host" func_warning "assuming '-no-fast-install' instead" fast_install=no ;; *) no_install=yes ;; esac continue ;; -no-undefined) allow_undefined=no continue ;; -objectlist) prev=objectlist continue ;; -os2dllname) prev=os2dllname continue ;; -o) prev=output ;; -precious-files-regex) prev=precious_regex continue ;; -release) prev=release continue ;; -rpath) prev=rpath continue ;; -R) prev=xrpath continue ;; -R*) func_stripname '-R' '' "$arg" dir=$func_stripname_result # We need an absolute path. case $dir in [\\/]* | [A-Za-z]:[\\/]*) ;; =*) func_stripname '=' '' "$dir" dir=$lt_sysroot$func_stripname_result ;; *) func_fatal_error "only absolute run-paths are allowed" ;; esac case "$xrpath " in *" $dir "*) ;; *) func_append xrpath " $dir" ;; esac continue ;; -shared) # The effects of -shared are defined in a previous loop. continue ;; -shrext) prev=shrext continue ;; -static | -static-libtool-libs) # The effects of -static are defined in a previous loop. # We used to do the same as -all-static on platforms that # didn't have a PIC flag, but the assumption that the effects # would be equivalent was wrong. It would break on at least # Digital Unix and AIX. continue ;; -thread-safe) thread_safe=yes continue ;; -version-info) prev=vinfo continue ;; -version-number) prev=vinfo vinfo_number=yes continue ;; -weak) prev=weak continue ;; -Wc,*) func_stripname '-Wc,' '' "$arg" args=$func_stripname_result arg= save_ifs=$IFS; IFS=, for flag in $args; do IFS=$save_ifs func_quote_for_eval "$flag" func_append arg " $func_quote_for_eval_result" func_append compiler_flags " $func_quote_for_eval_result" done IFS=$save_ifs func_stripname ' ' '' "$arg" arg=$func_stripname_result ;; -Wl,*) func_stripname '-Wl,' '' "$arg" args=$func_stripname_result arg= save_ifs=$IFS; IFS=, for flag in $args; do IFS=$save_ifs func_quote_for_eval "$flag" func_append arg " $wl$func_quote_for_eval_result" func_append compiler_flags " $wl$func_quote_for_eval_result" func_append linker_flags " $func_quote_for_eval_result" done IFS=$save_ifs func_stripname ' ' '' "$arg" arg=$func_stripname_result ;; -Xcompiler) prev=xcompiler continue ;; -Xlinker) prev=xlinker continue ;; -XCClinker) prev=xcclinker continue ;; # -msg_* for osf cc -msg_*) func_quote_for_eval "$arg" arg=$func_quote_for_eval_result ;; # Flags to be passed through unchanged, with rationale: # -64, -mips[0-9] enable 64-bit mode for the SGI compiler # -r[0-9][0-9]* specify processor for the SGI compiler # -xarch=*, -xtarget=* enable 64-bit mode for the Sun compiler # +DA*, +DD* enable 64-bit mode for the HP compiler # -q* compiler args for the IBM compiler # -m*, -t[45]*, -txscale* architecture-specific flags for GCC # -F/path path to uninstalled frameworks, gcc on darwin # -p, -pg, --coverage, -fprofile-* profiling flags for GCC # -fstack-protector* stack protector flags for GCC # @file GCC response files # -tp=* Portland pgcc target processor selection # --sysroot=* for sysroot support # -O*, -g*, -flto*, -fwhopr*, -fuse-linker-plugin GCC link-time optimization # -stdlib=* select c++ std lib with clang -64|-mips[0-9]|-r[0-9][0-9]*|-xarch=*|-xtarget=*|+DA*|+DD*|-q*|-m*| \ -t[45]*|-txscale*|-p|-pg|--coverage|-fprofile-*|-F*|@*|-tp=*|--sysroot=*| \ -O*|-g*|-flto*|-fwhopr*|-fuse-linker-plugin|-fstack-protector*|-stdlib=*) func_quote_for_eval "$arg" arg=$func_quote_for_eval_result func_append compile_command " $arg" func_append finalize_command " $arg" func_append compiler_flags " $arg" continue ;; -Z*) if test os2 = "`expr $host : '.*\(os2\)'`"; then # OS/2 uses -Zxxx to specify OS/2-specific options compiler_flags="$compiler_flags $arg" func_append compile_command " $arg" func_append finalize_command " $arg" case $arg in -Zlinker | -Zstack) prev=xcompiler ;; esac continue else # Otherwise treat like 'Some other compiler flag' below func_quote_for_eval "$arg" arg=$func_quote_for_eval_result fi ;; # Some other compiler flag. -* | +*) func_quote_for_eval "$arg" arg=$func_quote_for_eval_result ;; *.$objext) # A standard object. func_append objs " $arg" ;; *.lo) # A libtool-controlled object. # Check to see that this really is a libtool object. if func_lalib_unsafe_p "$arg"; then pic_object= non_pic_object= # Read the .lo file func_source "$arg" if test -z "$pic_object" || test -z "$non_pic_object" || test none = "$pic_object" && test none = "$non_pic_object"; then func_fatal_error "cannot find name of object for '$arg'" fi # Extract subdirectory from the argument. func_dirname "$arg" "/" "" xdir=$func_dirname_result test none = "$pic_object" || { # Prepend the subdirectory the object is found in. pic_object=$xdir$pic_object if test dlfiles = "$prev"; then if test yes = "$build_libtool_libs" && test yes = "$dlopen_support"; then func_append dlfiles " $pic_object" prev= continue else # If libtool objects are unsupported, then we need to preload. prev=dlprefiles fi fi # CHECK ME: I think I busted this. -Ossama if test dlprefiles = "$prev"; then # Preload the old-style object. func_append dlprefiles " $pic_object" prev= fi # A PIC object. func_append libobjs " $pic_object" arg=$pic_object } # Non-PIC object. if test none != "$non_pic_object"; then # Prepend the subdirectory the object is found in. non_pic_object=$xdir$non_pic_object # A standard non-PIC object func_append non_pic_objects " $non_pic_object" if test -z "$pic_object" || test none = "$pic_object"; then arg=$non_pic_object fi else # If the PIC object exists, use it instead. # $xdir was prepended to $pic_object above. non_pic_object=$pic_object func_append non_pic_objects " $non_pic_object" fi else # Only an error if not doing a dry-run. if $opt_dry_run; then # Extract subdirectory from the argument. func_dirname "$arg" "/" "" xdir=$func_dirname_result func_lo2o "$arg" pic_object=$xdir$objdir/$func_lo2o_result non_pic_object=$xdir$func_lo2o_result func_append libobjs " $pic_object" func_append non_pic_objects " $non_pic_object" else func_fatal_error "'$arg' is not a valid libtool object" fi fi ;; *.$libext) # An archive. func_append deplibs " $arg" func_append old_deplibs " $arg" continue ;; *.la) # A libtool-controlled library. func_resolve_sysroot "$arg" if test dlfiles = "$prev"; then # This library was specified with -dlopen. func_append dlfiles " $func_resolve_sysroot_result" prev= elif test dlprefiles = "$prev"; then # The library was specified with -dlpreopen. func_append dlprefiles " $func_resolve_sysroot_result" prev= else func_append deplibs " $func_resolve_sysroot_result" fi continue ;; # Some other compiler argument. *) # Unknown arguments in both finalize_command and compile_command need # to be aesthetically quoted because they are evaled later. func_quote_for_eval "$arg" arg=$func_quote_for_eval_result ;; esac # arg # Now actually substitute the argument into the commands. if test -n "$arg"; then func_append compile_command " $arg" func_append finalize_command " $arg" fi done # argument parsing loop test -n "$prev" && \ func_fatal_help "the '$prevarg' option requires an argument" if test yes = "$export_dynamic" && test -n "$export_dynamic_flag_spec"; then eval arg=\"$export_dynamic_flag_spec\" func_append compile_command " $arg" func_append finalize_command " $arg" fi oldlibs= # calculate the name of the file, without its directory func_basename "$output" outputname=$func_basename_result libobjs_save=$libobjs if test -n "$shlibpath_var"; then # get the directories listed in $shlibpath_var eval shlib_search_path=\`\$ECHO \"\$$shlibpath_var\" \| \$SED \'s/:/ /g\'\` else shlib_search_path= fi eval sys_lib_search_path=\"$sys_lib_search_path_spec\" eval sys_lib_dlsearch_path=\"$sys_lib_dlsearch_path_spec\" # Definition is injected by LT_CONFIG during libtool generation. func_munge_path_list sys_lib_dlsearch_path "$LT_SYS_LIBRARY_PATH" func_dirname "$output" "/" "" output_objdir=$func_dirname_result$objdir func_to_tool_file "$output_objdir/" tool_output_objdir=$func_to_tool_file_result # Create the object directory. func_mkdir_p "$output_objdir" # Determine the type of output case $output in "") func_fatal_help "you must specify an output file" ;; *.$libext) linkmode=oldlib ;; *.lo | *.$objext) linkmode=obj ;; *.la) linkmode=lib ;; *) linkmode=prog ;; # Anything else should be a program. esac specialdeplibs= libs= # Find all interdependent deplibs by searching for libraries # that are linked more than once (e.g. -la -lb -la) for deplib in $deplibs; do if $opt_preserve_dup_deps; then case "$libs " in *" $deplib "*) func_append specialdeplibs " $deplib" ;; esac fi func_append libs " $deplib" done if test lib = "$linkmode"; then libs="$predeps $libs $compiler_lib_search_path $postdeps" # Compute libraries that are listed more than once in $predeps # $postdeps and mark them as special (i.e., whose duplicates are # not to be eliminated). pre_post_deps= if $opt_duplicate_compiler_generated_deps; then for pre_post_dep in $predeps $postdeps; do case "$pre_post_deps " in *" $pre_post_dep "*) func_append specialdeplibs " $pre_post_deps" ;; esac func_append pre_post_deps " $pre_post_dep" done fi pre_post_deps= fi deplibs= newdependency_libs= newlib_search_path= need_relink=no # whether we're linking any uninstalled libtool libraries notinst_deplibs= # not-installed libtool libraries notinst_path= # paths that contain not-installed libtool libraries case $linkmode in lib) passes="conv dlpreopen link" for file in $dlfiles $dlprefiles; do case $file in *.la) ;; *) func_fatal_help "libraries can '-dlopen' only libtool libraries: $file" ;; esac done ;; prog) compile_deplibs= finalize_deplibs= alldeplibs=false newdlfiles= newdlprefiles= passes="conv scan dlopen dlpreopen link" ;; *) passes="conv" ;; esac for pass in $passes; do # The preopen pass in lib mode reverses $deplibs; put it back here # so that -L comes before libs that need it for instance... if test lib,link = "$linkmode,$pass"; then ## FIXME: Find the place where the list is rebuilt in the wrong ## order, and fix it there properly tmp_deplibs= for deplib in $deplibs; do tmp_deplibs="$deplib $tmp_deplibs" done deplibs=$tmp_deplibs fi if test lib,link = "$linkmode,$pass" || test prog,scan = "$linkmode,$pass"; then libs=$deplibs deplibs= fi if test prog = "$linkmode"; then case $pass in dlopen) libs=$dlfiles ;; dlpreopen) libs=$dlprefiles ;; link) libs="$deplibs %DEPLIBS% $dependency_libs" ;; esac fi if test lib,dlpreopen = "$linkmode,$pass"; then # Collect and forward deplibs of preopened libtool libs for lib in $dlprefiles; do # Ignore non-libtool-libs dependency_libs= func_resolve_sysroot "$lib" case $lib in *.la) func_source "$func_resolve_sysroot_result" ;; esac # Collect preopened libtool deplibs, except any this library # has declared as weak libs for deplib in $dependency_libs; do func_basename "$deplib" deplib_base=$func_basename_result case " $weak_libs " in *" $deplib_base "*) ;; *) func_append deplibs " $deplib" ;; esac done done libs=$dlprefiles fi if test dlopen = "$pass"; then # Collect dlpreopened libraries save_deplibs=$deplibs deplibs= fi for deplib in $libs; do lib= found=false case $deplib in -mt|-mthreads|-kthread|-Kthread|-pthread|-pthreads|--thread-safe \ |-threads|-fopenmp|-openmp|-mp|-xopenmp|-omp|-qsmp=*) if test prog,link = "$linkmode,$pass"; then compile_deplibs="$deplib $compile_deplibs" finalize_deplibs="$deplib $finalize_deplibs" else func_append compiler_flags " $deplib" if test lib = "$linkmode"; then case "$new_inherited_linker_flags " in *" $deplib "*) ;; * ) func_append new_inherited_linker_flags " $deplib" ;; esac fi fi continue ;; -l*) if test lib != "$linkmode" && test prog != "$linkmode"; then func_warning "'-l' is ignored for archives/objects" continue fi func_stripname '-l' '' "$deplib" name=$func_stripname_result if test lib = "$linkmode"; then searchdirs="$newlib_search_path $lib_search_path $compiler_lib_search_dirs $sys_lib_search_path $shlib_search_path" else searchdirs="$newlib_search_path $lib_search_path $sys_lib_search_path $shlib_search_path" fi for searchdir in $searchdirs; do for search_ext in .la $std_shrext .so .a; do # Search the libtool library lib=$searchdir/lib$name$search_ext if test -f "$lib"; then if test .la = "$search_ext"; then found=: else found=false fi break 2 fi done done if $found; then # deplib is a libtool library # If $allow_libtool_libs_with_static_runtimes && $deplib is a stdlib, # We need to do some special things here, and not later. if test yes = "$allow_libtool_libs_with_static_runtimes"; then case " $predeps $postdeps " in *" $deplib "*) if func_lalib_p "$lib"; then library_names= old_library= func_source "$lib" for l in $old_library $library_names; do ll=$l done if test "X$ll" = "X$old_library"; then # only static version available found=false func_dirname "$lib" "" "." ladir=$func_dirname_result lib=$ladir/$old_library if test prog,link = "$linkmode,$pass"; then compile_deplibs="$deplib $compile_deplibs" finalize_deplibs="$deplib $finalize_deplibs" else deplibs="$deplib $deplibs" test lib = "$linkmode" && newdependency_libs="$deplib $newdependency_libs" fi continue fi fi ;; *) ;; esac fi else # deplib doesn't seem to be a libtool library if test prog,link = "$linkmode,$pass"; then compile_deplibs="$deplib $compile_deplibs" finalize_deplibs="$deplib $finalize_deplibs" else deplibs="$deplib $deplibs" test lib = "$linkmode" && newdependency_libs="$deplib $newdependency_libs" fi continue fi ;; # -l *.ltframework) if test prog,link = "$linkmode,$pass"; then compile_deplibs="$deplib $compile_deplibs" finalize_deplibs="$deplib $finalize_deplibs" else deplibs="$deplib $deplibs" if test lib = "$linkmode"; then case "$new_inherited_linker_flags " in *" $deplib "*) ;; * ) func_append new_inherited_linker_flags " $deplib" ;; esac fi fi continue ;; -L*) case $linkmode in lib) deplibs="$deplib $deplibs" test conv = "$pass" && continue newdependency_libs="$deplib $newdependency_libs" func_stripname '-L' '' "$deplib" func_resolve_sysroot "$func_stripname_result" func_append newlib_search_path " $func_resolve_sysroot_result" ;; prog) if test conv = "$pass"; then deplibs="$deplib $deplibs" continue fi if test scan = "$pass"; then deplibs="$deplib $deplibs" else compile_deplibs="$deplib $compile_deplibs" finalize_deplibs="$deplib $finalize_deplibs" fi func_stripname '-L' '' "$deplib" func_resolve_sysroot "$func_stripname_result" func_append newlib_search_path " $func_resolve_sysroot_result" ;; *) func_warning "'-L' is ignored for archives/objects" ;; esac # linkmode continue ;; # -L -R*) if test link = "$pass"; then func_stripname '-R' '' "$deplib" func_resolve_sysroot "$func_stripname_result" dir=$func_resolve_sysroot_result # Make sure the xrpath contains only unique directories. case "$xrpath " in *" $dir "*) ;; *) func_append xrpath " $dir" ;; esac fi deplibs="$deplib $deplibs" continue ;; *.la) func_resolve_sysroot "$deplib" lib=$func_resolve_sysroot_result ;; *.$libext) if test conv = "$pass"; then deplibs="$deplib $deplibs" continue fi case $linkmode in lib) # Linking convenience modules into shared libraries is allowed, # but linking other static libraries is non-portable. case " $dlpreconveniencelibs " in *" $deplib "*) ;; *) valid_a_lib=false case $deplibs_check_method in match_pattern*) set dummy $deplibs_check_method; shift match_pattern_regex=`expr "$deplibs_check_method" : "$1 \(.*\)"` if eval "\$ECHO \"$deplib\"" 2>/dev/null | $SED 10q \ | $EGREP "$match_pattern_regex" > /dev/null; then valid_a_lib=: fi ;; pass_all) valid_a_lib=: ;; esac if $valid_a_lib; then echo $ECHO "*** Warning: Linking the shared library $output against the" $ECHO "*** static library $deplib is not portable!" deplibs="$deplib $deplibs" else echo $ECHO "*** Warning: Trying to link with static lib archive $deplib." echo "*** I have the capability to make that library automatically link in when" echo "*** you link to this library. But I can only do this if you have a" echo "*** shared version of the library, which you do not appear to have" echo "*** because the file extensions .$libext of this argument makes me believe" echo "*** that it is just a static archive that I should not use here." fi ;; esac continue ;; prog) if test link != "$pass"; then deplibs="$deplib $deplibs" else compile_deplibs="$deplib $compile_deplibs" finalize_deplibs="$deplib $finalize_deplibs" fi continue ;; esac # linkmode ;; # *.$libext *.lo | *.$objext) if test conv = "$pass"; then deplibs="$deplib $deplibs" elif test prog = "$linkmode"; then if test dlpreopen = "$pass" || test yes != "$dlopen_support" || test no = "$build_libtool_libs"; then # If there is no dlopen support or we're linking statically, # we need to preload. func_append newdlprefiles " $deplib" compile_deplibs="$deplib $compile_deplibs" finalize_deplibs="$deplib $finalize_deplibs" else func_append newdlfiles " $deplib" fi fi continue ;; %DEPLIBS%) alldeplibs=: continue ;; esac # case $deplib $found || test -f "$lib" \ || func_fatal_error "cannot find the library '$lib' or unhandled argument '$deplib'" # Check to see that this really is a libtool archive. func_lalib_unsafe_p "$lib" \ || func_fatal_error "'$lib' is not a valid libtool archive" func_dirname "$lib" "" "." ladir=$func_dirname_result dlname= dlopen= dlpreopen= libdir= library_names= old_library= inherited_linker_flags= # If the library was installed with an old release of libtool, # it will not redefine variables installed, or shouldnotlink installed=yes shouldnotlink=no avoidtemprpath= # Read the .la file func_source "$lib" # Convert "-framework foo" to "foo.ltframework" if test -n "$inherited_linker_flags"; then tmp_inherited_linker_flags=`$ECHO "$inherited_linker_flags" | $SED 's/-framework \([^ $]*\)/\1.ltframework/g'` for tmp_inherited_linker_flag in $tmp_inherited_linker_flags; do case " $new_inherited_linker_flags " in *" $tmp_inherited_linker_flag "*) ;; *) func_append new_inherited_linker_flags " $tmp_inherited_linker_flag";; esac done fi dependency_libs=`$ECHO " $dependency_libs" | $SED 's% \([^ $]*\).ltframework% -framework \1%g'` if test lib,link = "$linkmode,$pass" || test prog,scan = "$linkmode,$pass" || { test prog != "$linkmode" && test lib != "$linkmode"; }; then test -n "$dlopen" && func_append dlfiles " $dlopen" test -n "$dlpreopen" && func_append dlprefiles " $dlpreopen" fi if test conv = "$pass"; then # Only check for convenience libraries deplibs="$lib $deplibs" if test -z "$libdir"; then if test -z "$old_library"; then func_fatal_error "cannot find name of link library for '$lib'" fi # It is a libtool convenience library, so add in its objects. func_append convenience " $ladir/$objdir/$old_library" func_append old_convenience " $ladir/$objdir/$old_library" elif test prog != "$linkmode" && test lib != "$linkmode"; then func_fatal_error "'$lib' is not a convenience library" fi tmp_libs= for deplib in $dependency_libs; do deplibs="$deplib $deplibs" if $opt_preserve_dup_deps; then case "$tmp_libs " in *" $deplib "*) func_append specialdeplibs " $deplib" ;; esac fi func_append tmp_libs " $deplib" done continue fi # $pass = conv # Get the name of the library we link against. linklib= if test -n "$old_library" && { test yes = "$prefer_static_libs" || test built,no = "$prefer_static_libs,$installed"; }; then linklib=$old_library else for l in $old_library $library_names; do linklib=$l done fi if test -z "$linklib"; then func_fatal_error "cannot find name of link library for '$lib'" fi # This library was specified with -dlopen. if test dlopen = "$pass"; then test -z "$libdir" \ && func_fatal_error "cannot -dlopen a convenience library: '$lib'" if test -z "$dlname" || test yes != "$dlopen_support" || test no = "$build_libtool_libs" then # If there is no dlname, no dlopen support or we're linking # statically, we need to preload. We also need to preload any # dependent libraries so libltdl's deplib preloader doesn't # bomb out in the load deplibs phase. func_append dlprefiles " $lib $dependency_libs" else func_append newdlfiles " $lib" fi continue fi # $pass = dlopen # We need an absolute path. case $ladir in [\\/]* | [A-Za-z]:[\\/]*) abs_ladir=$ladir ;; *) abs_ladir=`cd "$ladir" && pwd` if test -z "$abs_ladir"; then func_warning "cannot determine absolute directory name of '$ladir'" func_warning "passing it literally to the linker, although it might fail" abs_ladir=$ladir fi ;; esac func_basename "$lib" laname=$func_basename_result # Find the relevant object directory and library name. if test yes = "$installed"; then if test ! -f "$lt_sysroot$libdir/$linklib" && test -f "$abs_ladir/$linklib"; then func_warning "library '$lib' was moved." dir=$ladir absdir=$abs_ladir libdir=$abs_ladir else dir=$lt_sysroot$libdir absdir=$lt_sysroot$libdir fi test yes = "$hardcode_automatic" && avoidtemprpath=yes else if test ! -f "$ladir/$objdir/$linklib" && test -f "$abs_ladir/$linklib"; then dir=$ladir absdir=$abs_ladir # Remove this search path later func_append notinst_path " $abs_ladir" else dir=$ladir/$objdir absdir=$abs_ladir/$objdir # Remove this search path later func_append notinst_path " $abs_ladir" fi fi # $installed = yes func_stripname 'lib' '.la' "$laname" name=$func_stripname_result # This library was specified with -dlpreopen. if test dlpreopen = "$pass"; then if test -z "$libdir" && test prog = "$linkmode"; then func_fatal_error "only libraries may -dlpreopen a convenience library: '$lib'" fi case $host in # special handling for platforms with PE-DLLs. *cygwin* | *mingw* | *cegcc* ) # Linker will automatically link against shared library if both # static and shared are present. Therefore, ensure we extract # symbols from the import library if a shared library is present # (otherwise, the dlopen module name will be incorrect). We do # this by putting the import library name into $newdlprefiles. # We recover the dlopen module name by 'saving' the la file # name in a special purpose variable, and (later) extracting the # dlname from the la file. if test -n "$dlname"; then func_tr_sh "$dir/$linklib" eval "libfile_$func_tr_sh_result=\$abs_ladir/\$laname" func_append newdlprefiles " $dir/$linklib" else func_append newdlprefiles " $dir/$old_library" # Keep a list of preopened convenience libraries to check # that they are being used correctly in the link pass. test -z "$libdir" && \ func_append dlpreconveniencelibs " $dir/$old_library" fi ;; * ) # Prefer using a static library (so that no silly _DYNAMIC symbols # are required to link). if test -n "$old_library"; then func_append newdlprefiles " $dir/$old_library" # Keep a list of preopened convenience libraries to check # that they are being used correctly in the link pass. test -z "$libdir" && \ func_append dlpreconveniencelibs " $dir/$old_library" # Otherwise, use the dlname, so that lt_dlopen finds it. elif test -n "$dlname"; then func_append newdlprefiles " $dir/$dlname" else func_append newdlprefiles " $dir/$linklib" fi ;; esac fi # $pass = dlpreopen if test -z "$libdir"; then # Link the convenience library if test lib = "$linkmode"; then deplibs="$dir/$old_library $deplibs" elif test prog,link = "$linkmode,$pass"; then compile_deplibs="$dir/$old_library $compile_deplibs" finalize_deplibs="$dir/$old_library $finalize_deplibs" else deplibs="$lib $deplibs" # used for prog,scan pass fi continue fi if test prog = "$linkmode" && test link != "$pass"; then func_append newlib_search_path " $ladir" deplibs="$lib $deplibs" linkalldeplibs=false if test no != "$link_all_deplibs" || test -z "$library_names" || test no = "$build_libtool_libs"; then linkalldeplibs=: fi tmp_libs= for deplib in $dependency_libs; do case $deplib in -L*) func_stripname '-L' '' "$deplib" func_resolve_sysroot "$func_stripname_result" func_append newlib_search_path " $func_resolve_sysroot_result" ;; esac # Need to link against all dependency_libs? if $linkalldeplibs; then deplibs="$deplib $deplibs" else # Need to hardcode shared library paths # or/and link against static libraries newdependency_libs="$deplib $newdependency_libs" fi if $opt_preserve_dup_deps; then case "$tmp_libs " in *" $deplib "*) func_append specialdeplibs " $deplib" ;; esac fi func_append tmp_libs " $deplib" done # for deplib continue fi # $linkmode = prog... if test prog,link = "$linkmode,$pass"; then if test -n "$library_names" && { { test no = "$prefer_static_libs" || test built,yes = "$prefer_static_libs,$installed"; } || test -z "$old_library"; }; then # We need to hardcode the library path if test -n "$shlibpath_var" && test -z "$avoidtemprpath"; then # Make sure the rpath contains only unique directories. case $temp_rpath: in *"$absdir:"*) ;; *) func_append temp_rpath "$absdir:" ;; esac fi # Hardcode the library path. # Skip directories that are in the system default run-time # search path. case " $sys_lib_dlsearch_path " in *" $absdir "*) ;; *) case "$compile_rpath " in *" $absdir "*) ;; *) func_append compile_rpath " $absdir" ;; esac ;; esac case " $sys_lib_dlsearch_path " in *" $libdir "*) ;; *) case "$finalize_rpath " in *" $libdir "*) ;; *) func_append finalize_rpath " $libdir" ;; esac ;; esac fi # $linkmode,$pass = prog,link... if $alldeplibs && { test pass_all = "$deplibs_check_method" || { test yes = "$build_libtool_libs" && test -n "$library_names"; }; }; then # We only need to search for static libraries continue fi fi link_static=no # Whether the deplib will be linked statically use_static_libs=$prefer_static_libs if test built = "$use_static_libs" && test yes = "$installed"; then use_static_libs=no fi if test -n "$library_names" && { test no = "$use_static_libs" || test -z "$old_library"; }; then case $host in *cygwin* | *mingw* | *cegcc* | *os2*) # No point in relinking DLLs because paths are not encoded func_append notinst_deplibs " $lib" need_relink=no ;; *) if test no = "$installed"; then func_append notinst_deplibs " $lib" need_relink=yes fi ;; esac # This is a shared library # Warn about portability, can't link against -module's on some # systems (darwin). Don't bleat about dlopened modules though! dlopenmodule= for dlpremoduletest in $dlprefiles; do if test "X$dlpremoduletest" = "X$lib"; then dlopenmodule=$dlpremoduletest break fi done if test -z "$dlopenmodule" && test yes = "$shouldnotlink" && test link = "$pass"; then echo if test prog = "$linkmode"; then $ECHO "*** Warning: Linking the executable $output against the loadable module" else $ECHO "*** Warning: Linking the shared library $output against the loadable module" fi $ECHO "*** $linklib is not portable!" fi if test lib = "$linkmode" && test yes = "$hardcode_into_libs"; then # Hardcode the library path. # Skip directories that are in the system default run-time # search path. case " $sys_lib_dlsearch_path " in *" $absdir "*) ;; *) case "$compile_rpath " in *" $absdir "*) ;; *) func_append compile_rpath " $absdir" ;; esac ;; esac case " $sys_lib_dlsearch_path " in *" $libdir "*) ;; *) case "$finalize_rpath " in *" $libdir "*) ;; *) func_append finalize_rpath " $libdir" ;; esac ;; esac fi if test -n "$old_archive_from_expsyms_cmds"; then # figure out the soname set dummy $library_names shift realname=$1 shift libname=`eval "\\$ECHO \"$libname_spec\""` # use dlname if we got it. it's perfectly good, no? if test -n "$dlname"; then soname=$dlname elif test -n "$soname_spec"; then # bleh windows case $host in *cygwin* | mingw* | *cegcc* | *os2*) func_arith $current - $age major=$func_arith_result versuffix=-$major ;; esac eval soname=\"$soname_spec\" else soname=$realname fi # Make a new name for the extract_expsyms_cmds to use soroot=$soname func_basename "$soroot" soname=$func_basename_result func_stripname 'lib' '.dll' "$soname" newlib=libimp-$func_stripname_result.a # If the library has no export list, then create one now if test -f "$output_objdir/$soname-def"; then : else func_verbose "extracting exported symbol list from '$soname'" func_execute_cmds "$extract_expsyms_cmds" 'exit $?' fi # Create $newlib if test -f "$output_objdir/$newlib"; then :; else func_verbose "generating import library for '$soname'" func_execute_cmds "$old_archive_from_expsyms_cmds" 'exit $?' fi # make sure the library variables are pointing to the new library dir=$output_objdir linklib=$newlib fi # test -n "$old_archive_from_expsyms_cmds" if test prog = "$linkmode" || test relink != "$opt_mode"; then add_shlibpath= add_dir= add= lib_linked=yes case $hardcode_action in immediate | unsupported) if test no = "$hardcode_direct"; then add=$dir/$linklib case $host in *-*-sco3.2v5.0.[024]*) add_dir=-L$dir ;; *-*-sysv4*uw2*) add_dir=-L$dir ;; *-*-sysv5OpenUNIX* | *-*-sysv5UnixWare7.[01].[10]* | \ *-*-unixware7*) add_dir=-L$dir ;; *-*-darwin* ) # if the lib is a (non-dlopened) module then we cannot # link against it, someone is ignoring the earlier warnings if /usr/bin/file -L $add 2> /dev/null | $GREP ": [^:]* bundle" >/dev/null; then if test "X$dlopenmodule" != "X$lib"; then $ECHO "*** Warning: lib $linklib is a module, not a shared library" if test -z "$old_library"; then echo echo "*** And there doesn't seem to be a static archive available" echo "*** The link will probably fail, sorry" else add=$dir/$old_library fi elif test -n "$old_library"; then add=$dir/$old_library fi fi esac elif test no = "$hardcode_minus_L"; then case $host in *-*-sunos*) add_shlibpath=$dir ;; esac add_dir=-L$dir add=-l$name elif test no = "$hardcode_shlibpath_var"; then add_shlibpath=$dir add=-l$name else lib_linked=no fi ;; relink) if test yes = "$hardcode_direct" && test no = "$hardcode_direct_absolute"; then add=$dir/$linklib elif test yes = "$hardcode_minus_L"; then add_dir=-L$absdir # Try looking first in the location we're being installed to. if test -n "$inst_prefix_dir"; then case $libdir in [\\/]*) func_append add_dir " -L$inst_prefix_dir$libdir" ;; esac fi add=-l$name elif test yes = "$hardcode_shlibpath_var"; then add_shlibpath=$dir add=-l$name else lib_linked=no fi ;; *) lib_linked=no ;; esac if test yes != "$lib_linked"; then func_fatal_configuration "unsupported hardcode properties" fi if test -n "$add_shlibpath"; then case :$compile_shlibpath: in *":$add_shlibpath:"*) ;; *) func_append compile_shlibpath "$add_shlibpath:" ;; esac fi if test prog = "$linkmode"; then test -n "$add_dir" && compile_deplibs="$add_dir $compile_deplibs" test -n "$add" && compile_deplibs="$add $compile_deplibs" else test -n "$add_dir" && deplibs="$add_dir $deplibs" test -n "$add" && deplibs="$add $deplibs" if test yes != "$hardcode_direct" && test yes != "$hardcode_minus_L" && test yes = "$hardcode_shlibpath_var"; then case :$finalize_shlibpath: in *":$libdir:"*) ;; *) func_append finalize_shlibpath "$libdir:" ;; esac fi fi fi if test prog = "$linkmode" || test relink = "$opt_mode"; then add_shlibpath= add_dir= add= # Finalize command for both is simple: just hardcode it. if test yes = "$hardcode_direct" && test no = "$hardcode_direct_absolute"; then add=$libdir/$linklib elif test yes = "$hardcode_minus_L"; then add_dir=-L$libdir add=-l$name elif test yes = "$hardcode_shlibpath_var"; then case :$finalize_shlibpath: in *":$libdir:"*) ;; *) func_append finalize_shlibpath "$libdir:" ;; esac add=-l$name elif test yes = "$hardcode_automatic"; then if test -n "$inst_prefix_dir" && test -f "$inst_prefix_dir$libdir/$linklib"; then add=$inst_prefix_dir$libdir/$linklib else add=$libdir/$linklib fi else # We cannot seem to hardcode it, guess we'll fake it. add_dir=-L$libdir # Try looking first in the location we're being installed to. if test -n "$inst_prefix_dir"; then case $libdir in [\\/]*) func_append add_dir " -L$inst_prefix_dir$libdir" ;; esac fi add=-l$name fi if test prog = "$linkmode"; then test -n "$add_dir" && finalize_deplibs="$add_dir $finalize_deplibs" test -n "$add" && finalize_deplibs="$add $finalize_deplibs" else test -n "$add_dir" && deplibs="$add_dir $deplibs" test -n "$add" && deplibs="$add $deplibs" fi fi elif test prog = "$linkmode"; then # Here we assume that one of hardcode_direct or hardcode_minus_L # is not unsupported. This is valid on all known static and # shared platforms. if test unsupported != "$hardcode_direct"; then test -n "$old_library" && linklib=$old_library compile_deplibs="$dir/$linklib $compile_deplibs" finalize_deplibs="$dir/$linklib $finalize_deplibs" else compile_deplibs="-l$name -L$dir $compile_deplibs" finalize_deplibs="-l$name -L$dir $finalize_deplibs" fi elif test yes = "$build_libtool_libs"; then # Not a shared library if test pass_all != "$deplibs_check_method"; then # We're trying link a shared library against a static one # but the system doesn't support it. # Just print a warning and add the library to dependency_libs so # that the program can be linked against the static library. echo $ECHO "*** Warning: This system cannot link to static lib archive $lib." echo "*** I have the capability to make that library automatically link in when" echo "*** you link to this library. But I can only do this if you have a" echo "*** shared version of the library, which you do not appear to have." if test yes = "$module"; then echo "*** But as you try to build a module library, libtool will still create " echo "*** a static module, that should work as long as the dlopening application" echo "*** is linked with the -dlopen flag to resolve symbols at runtime." if test -z "$global_symbol_pipe"; then echo echo "*** However, this would only work if libtool was able to extract symbol" echo "*** lists from a program, using 'nm' or equivalent, but libtool could" echo "*** not find such a program. So, this module is probably useless." echo "*** 'nm' from GNU binutils and a full rebuild may help." fi if test no = "$build_old_libs"; then build_libtool_libs=module build_old_libs=yes else build_libtool_libs=no fi fi else deplibs="$dir/$old_library $deplibs" link_static=yes fi fi # link shared/static library? if test lib = "$linkmode"; then if test -n "$dependency_libs" && { test yes != "$hardcode_into_libs" || test yes = "$build_old_libs" || test yes = "$link_static"; }; then # Extract -R from dependency_libs temp_deplibs= for libdir in $dependency_libs; do case $libdir in -R*) func_stripname '-R' '' "$libdir" temp_xrpath=$func_stripname_result case " $xrpath " in *" $temp_xrpath "*) ;; *) func_append xrpath " $temp_xrpath";; esac;; *) func_append temp_deplibs " $libdir";; esac done dependency_libs=$temp_deplibs fi func_append newlib_search_path " $absdir" # Link against this library test no = "$link_static" && newdependency_libs="$abs_ladir/$laname $newdependency_libs" # ... and its dependency_libs tmp_libs= for deplib in $dependency_libs; do newdependency_libs="$deplib $newdependency_libs" case $deplib in -L*) func_stripname '-L' '' "$deplib" func_resolve_sysroot "$func_stripname_result";; *) func_resolve_sysroot "$deplib" ;; esac if $opt_preserve_dup_deps; then case "$tmp_libs " in *" $func_resolve_sysroot_result "*) func_append specialdeplibs " $func_resolve_sysroot_result" ;; esac fi func_append tmp_libs " $func_resolve_sysroot_result" done if test no != "$link_all_deplibs"; then # Add the search paths of all dependency libraries for deplib in $dependency_libs; do path= case $deplib in -L*) path=$deplib ;; *.la) func_resolve_sysroot "$deplib" deplib=$func_resolve_sysroot_result func_dirname "$deplib" "" "." dir=$func_dirname_result # We need an absolute path. case $dir in [\\/]* | [A-Za-z]:[\\/]*) absdir=$dir ;; *) absdir=`cd "$dir" && pwd` if test -z "$absdir"; then func_warning "cannot determine absolute directory name of '$dir'" absdir=$dir fi ;; esac if $GREP "^installed=no" $deplib > /dev/null; then case $host in *-*-darwin*) depdepl= eval deplibrary_names=`$SED -n -e 's/^library_names=\(.*\)$/\1/p' $deplib` if test -n "$deplibrary_names"; then for tmp in $deplibrary_names; do depdepl=$tmp done if test -f "$absdir/$objdir/$depdepl"; then depdepl=$absdir/$objdir/$depdepl darwin_install_name=`$OTOOL -L $depdepl | awk '{if (NR == 2) {print $1;exit}}'` if test -z "$darwin_install_name"; then darwin_install_name=`$OTOOL64 -L $depdepl | awk '{if (NR == 2) {print $1;exit}}'` fi func_append compiler_flags " $wl-dylib_file $wl$darwin_install_name:$depdepl" func_append linker_flags " -dylib_file $darwin_install_name:$depdepl" path= fi fi ;; *) path=-L$absdir/$objdir ;; esac else eval libdir=`$SED -n -e 's/^libdir=\(.*\)$/\1/p' $deplib` test -z "$libdir" && \ func_fatal_error "'$deplib' is not a valid libtool archive" test "$absdir" != "$libdir" && \ func_warning "'$deplib' seems to be moved" path=-L$absdir fi ;; esac case " $deplibs " in *" $path "*) ;; *) deplibs="$path $deplibs" ;; esac done fi # link_all_deplibs != no fi # linkmode = lib done # for deplib in $libs if test link = "$pass"; then if test prog = "$linkmode"; then compile_deplibs="$new_inherited_linker_flags $compile_deplibs" finalize_deplibs="$new_inherited_linker_flags $finalize_deplibs" else compiler_flags="$compiler_flags "`$ECHO " $new_inherited_linker_flags" | $SED 's% \([^ $]*\).ltframework% -framework \1%g'` fi fi dependency_libs=$newdependency_libs if test dlpreopen = "$pass"; then # Link the dlpreopened libraries before other libraries for deplib in $save_deplibs; do deplibs="$deplib $deplibs" done fi if test dlopen != "$pass"; then test conv = "$pass" || { # Make sure lib_search_path contains only unique directories. lib_search_path= for dir in $newlib_search_path; do case "$lib_search_path " in *" $dir "*) ;; *) func_append lib_search_path " $dir" ;; esac done newlib_search_path= } if test prog,link = "$linkmode,$pass"; then vars="compile_deplibs finalize_deplibs" else vars=deplibs fi for var in $vars dependency_libs; do # Add libraries to $var in reverse order eval tmp_libs=\"\$$var\" new_libs= for deplib in $tmp_libs; do # FIXME: Pedantically, this is the right thing to do, so # that some nasty dependency loop isn't accidentally # broken: #new_libs="$deplib $new_libs" # Pragmatically, this seems to cause very few problems in # practice: case $deplib in -L*) new_libs="$deplib $new_libs" ;; -R*) ;; *) # And here is the reason: when a library appears more # than once as an explicit dependence of a library, or # is implicitly linked in more than once by the # compiler, it is considered special, and multiple # occurrences thereof are not removed. Compare this # with having the same library being listed as a # dependency of multiple other libraries: in this case, # we know (pedantically, we assume) the library does not # need to be listed more than once, so we keep only the # last copy. This is not always right, but it is rare # enough that we require users that really mean to play # such unportable linking tricks to link the library # using -Wl,-lname, so that libtool does not consider it # for duplicate removal. case " $specialdeplibs " in *" $deplib "*) new_libs="$deplib $new_libs" ;; *) case " $new_libs " in *" $deplib "*) ;; *) new_libs="$deplib $new_libs" ;; esac ;; esac ;; esac done tmp_libs= for deplib in $new_libs; do case $deplib in -L*) case " $tmp_libs " in *" $deplib "*) ;; *) func_append tmp_libs " $deplib" ;; esac ;; *) func_append tmp_libs " $deplib" ;; esac done eval $var=\"$tmp_libs\" done # for var fi # Add Sun CC postdeps if required: test CXX = "$tagname" && { case $host_os in linux*) case `$CC -V 2>&1 | sed 5q` in *Sun\ C*) # Sun C++ 5.9 func_suncc_cstd_abi if test no != "$suncc_use_cstd_abi"; then func_append postdeps ' -library=Cstd -library=Crun' fi ;; esac ;; solaris*) func_cc_basename "$CC" case $func_cc_basename_result in CC* | sunCC*) func_suncc_cstd_abi if test no != "$suncc_use_cstd_abi"; then func_append postdeps ' -library=Cstd -library=Crun' fi ;; esac ;; esac } # Last step: remove runtime libs from dependency_libs # (they stay in deplibs) tmp_libs= for i in $dependency_libs; do case " $predeps $postdeps $compiler_lib_search_path " in *" $i "*) i= ;; esac if test -n "$i"; then func_append tmp_libs " $i" fi done dependency_libs=$tmp_libs done # for pass if test prog = "$linkmode"; then dlfiles=$newdlfiles fi if test prog = "$linkmode" || test lib = "$linkmode"; then dlprefiles=$newdlprefiles fi case $linkmode in oldlib) if test -n "$dlfiles$dlprefiles" || test no != "$dlself"; then func_warning "'-dlopen' is ignored for archives" fi case " $deplibs" in *\ -l* | *\ -L*) func_warning "'-l' and '-L' are ignored for archives" ;; esac test -n "$rpath" && \ func_warning "'-rpath' is ignored for archives" test -n "$xrpath" && \ func_warning "'-R' is ignored for archives" test -n "$vinfo" && \ func_warning "'-version-info/-version-number' is ignored for archives" test -n "$release" && \ func_warning "'-release' is ignored for archives" test -n "$export_symbols$export_symbols_regex" && \ func_warning "'-export-symbols' is ignored for archives" # Now set the variables for building old libraries. build_libtool_libs=no oldlibs=$output func_append objs "$old_deplibs" ;; lib) # Make sure we only generate libraries of the form 'libNAME.la'. case $outputname in lib*) func_stripname 'lib' '.la' "$outputname" name=$func_stripname_result eval shared_ext=\"$shrext_cmds\" eval libname=\"$libname_spec\" ;; *) test no = "$module" \ && func_fatal_help "libtool library '$output' must begin with 'lib'" if test no != "$need_lib_prefix"; then # Add the "lib" prefix for modules if required func_stripname '' '.la' "$outputname" name=$func_stripname_result eval shared_ext=\"$shrext_cmds\" eval libname=\"$libname_spec\" else func_stripname '' '.la' "$outputname" libname=$func_stripname_result fi ;; esac if test -n "$objs"; then if test pass_all != "$deplibs_check_method"; then func_fatal_error "cannot build libtool library '$output' from non-libtool objects on this host:$objs" else echo $ECHO "*** Warning: Linking the shared library $output against the non-libtool" $ECHO "*** objects $objs is not portable!" func_append libobjs " $objs" fi fi test no = "$dlself" \ || func_warning "'-dlopen self' is ignored for libtool libraries" set dummy $rpath shift test 1 -lt "$#" \ && func_warning "ignoring multiple '-rpath's for a libtool library" install_libdir=$1 oldlibs= if test -z "$rpath"; then if test yes = "$build_libtool_libs"; then # Building a libtool convenience library. # Some compilers have problems with a '.al' extension so # convenience libraries should have the same extension an # archive normally would. oldlibs="$output_objdir/$libname.$libext $oldlibs" build_libtool_libs=convenience build_old_libs=yes fi test -n "$vinfo" && \ func_warning "'-version-info/-version-number' is ignored for convenience libraries" test -n "$release" && \ func_warning "'-release' is ignored for convenience libraries" else # Parse the version information argument. save_ifs=$IFS; IFS=: set dummy $vinfo 0 0 0 shift IFS=$save_ifs test -n "$7" && \ func_fatal_help "too many parameters to '-version-info'" # convert absolute version numbers to libtool ages # this retains compatibility with .la files and attempts # to make the code below a bit more comprehensible case $vinfo_number in yes) number_major=$1 number_minor=$2 number_revision=$3 # # There are really only two kinds -- those that # use the current revision as the major version # and those that subtract age and use age as # a minor version. But, then there is irix # that has an extra 1 added just for fun # case $version_type in # correct linux to gnu/linux during the next big refactor darwin|freebsd-elf|linux|osf|windows|none) func_arith $number_major + $number_minor current=$func_arith_result age=$number_minor revision=$number_revision ;; freebsd-aout|qnx|sunos) current=$number_major revision=$number_minor age=0 ;; irix|nonstopux) func_arith $number_major + $number_minor current=$func_arith_result age=$number_minor revision=$number_minor lt_irix_increment=no ;; esac ;; no) current=$1 revision=$2 age=$3 ;; esac # Check that each of the things are valid numbers. case $current in 0|[1-9]|[1-9][0-9]|[1-9][0-9][0-9]|[1-9][0-9][0-9][0-9]|[1-9][0-9][0-9][0-9][0-9]) ;; *) func_error "CURRENT '$current' must be a nonnegative integer" func_fatal_error "'$vinfo' is not valid version information" ;; esac case $revision in 0|[1-9]|[1-9][0-9]|[1-9][0-9][0-9]|[1-9][0-9][0-9][0-9]|[1-9][0-9][0-9][0-9][0-9]) ;; *) func_error "REVISION '$revision' must be a nonnegative integer" func_fatal_error "'$vinfo' is not valid version information" ;; esac case $age in 0|[1-9]|[1-9][0-9]|[1-9][0-9][0-9]|[1-9][0-9][0-9][0-9]|[1-9][0-9][0-9][0-9][0-9]) ;; *) func_error "AGE '$age' must be a nonnegative integer" func_fatal_error "'$vinfo' is not valid version information" ;; esac if test "$age" -gt "$current"; then func_error "AGE '$age' is greater than the current interface number '$current'" func_fatal_error "'$vinfo' is not valid version information" fi # Calculate the version variables. major= versuffix= verstring= case $version_type in none) ;; darwin) # Like Linux, but with the current version available in # verstring for coding it into the library header func_arith $current - $age major=.$func_arith_result versuffix=$major.$age.$revision # Darwin ld doesn't like 0 for these options... func_arith $current + 1 minor_current=$func_arith_result xlcverstring="$wl-compatibility_version $wl$minor_current $wl-current_version $wl$minor_current.$revision" verstring="-compatibility_version $minor_current -current_version $minor_current.$revision" # On Darwin other compilers case $CC in nagfor*) verstring="$wl-compatibility_version $wl$minor_current $wl-current_version $wl$minor_current.$revision" ;; *) verstring="-compatibility_version $minor_current -current_version $minor_current.$revision" ;; esac ;; freebsd-aout) major=.$current versuffix=.$current.$revision ;; freebsd-elf) func_arith $current - $age major=.$func_arith_result versuffix=$major.$age.$revision ;; irix | nonstopux) if test no = "$lt_irix_increment"; then func_arith $current - $age else func_arith $current - $age + 1 fi major=$func_arith_result case $version_type in nonstopux) verstring_prefix=nonstopux ;; *) verstring_prefix=sgi ;; esac verstring=$verstring_prefix$major.$revision # Add in all the interfaces that we are compatible with. loop=$revision while test 0 -ne "$loop"; do func_arith $revision - $loop iface=$func_arith_result func_arith $loop - 1 loop=$func_arith_result verstring=$verstring_prefix$major.$iface:$verstring done # Before this point, $major must not contain '.'. major=.$major versuffix=$major.$revision ;; linux) # correct to gnu/linux during the next big refactor func_arith $current - $age major=.$func_arith_result versuffix=$major.$age.$revision ;; osf) func_arith $current - $age major=.$func_arith_result versuffix=.$current.$age.$revision verstring=$current.$age.$revision # Add in all the interfaces that we are compatible with. loop=$age while test 0 -ne "$loop"; do func_arith $current - $loop iface=$func_arith_result func_arith $loop - 1 loop=$func_arith_result verstring=$verstring:$iface.0 done # Make executables depend on our current version. func_append verstring ":$current.0" ;; qnx) major=.$current versuffix=.$current ;; sco) major=.$current versuffix=.$current ;; sunos) major=.$current versuffix=.$current.$revision ;; windows) # Use '-' rather than '.', since we only want one # extension on DOS 8.3 file systems. func_arith $current - $age major=$func_arith_result versuffix=-$major ;; *) func_fatal_configuration "unknown library version type '$version_type'" ;; esac # Clear the version info if we defaulted, and they specified a release. if test -z "$vinfo" && test -n "$release"; then major= case $version_type in darwin) # we can't check for "0.0" in archive_cmds due to quoting # problems, so we reset it completely verstring= ;; *) verstring=0.0 ;; esac if test no = "$need_version"; then versuffix= else versuffix=.0.0 fi fi # Remove version info from name if versioning should be avoided if test yes,no = "$avoid_version,$need_version"; then major= versuffix= verstring= fi # Check to see if the archive will have undefined symbols. if test yes = "$allow_undefined"; then if test unsupported = "$allow_undefined_flag"; then if test yes = "$build_old_libs"; then func_warning "undefined symbols not allowed in $host shared libraries; building static only" build_libtool_libs=no else func_fatal_error "can't build $host shared library unless -no-undefined is specified" fi fi else # Don't allow undefined symbols. allow_undefined_flag=$no_undefined_flag fi fi func_generate_dlsyms "$libname" "$libname" : func_append libobjs " $symfileobj" test " " = "$libobjs" && libobjs= if test relink != "$opt_mode"; then # Remove our outputs, but don't remove object files since they # may have been created when compiling PIC objects. removelist= tempremovelist=`$ECHO "$output_objdir/*"` for p in $tempremovelist; do case $p in *.$objext | *.gcno) ;; $output_objdir/$outputname | $output_objdir/$libname.* | $output_objdir/$libname$release.*) if test -n "$precious_files_regex"; then if $ECHO "$p" | $EGREP -e "$precious_files_regex" >/dev/null 2>&1 then continue fi fi func_append removelist " $p" ;; *) ;; esac done test -n "$removelist" && \ func_show_eval "${RM}r \$removelist" fi # Now set the variables for building old libraries. if test yes = "$build_old_libs" && test convenience != "$build_libtool_libs"; then func_append oldlibs " $output_objdir/$libname.$libext" # Transform .lo files to .o files. oldobjs="$objs "`$ECHO "$libobjs" | $SP2NL | $SED "/\.$libext$/d; $lo2o" | $NL2SP` fi # Eliminate all temporary directories. #for path in $notinst_path; do # lib_search_path=`$ECHO "$lib_search_path " | $SED "s% $path % %g"` # deplibs=`$ECHO "$deplibs " | $SED "s% -L$path % %g"` # dependency_libs=`$ECHO "$dependency_libs " | $SED "s% -L$path % %g"` #done if test -n "$xrpath"; then # If the user specified any rpath flags, then add them. temp_xrpath= for libdir in $xrpath; do func_replace_sysroot "$libdir" func_append temp_xrpath " -R$func_replace_sysroot_result" case "$finalize_rpath " in *" $libdir "*) ;; *) func_append finalize_rpath " $libdir" ;; esac done if test yes != "$hardcode_into_libs" || test yes = "$build_old_libs"; then dependency_libs="$temp_xrpath $dependency_libs" fi fi # Make sure dlfiles contains only unique files that won't be dlpreopened old_dlfiles=$dlfiles dlfiles= for lib in $old_dlfiles; do case " $dlprefiles $dlfiles " in *" $lib "*) ;; *) func_append dlfiles " $lib" ;; esac done # Make sure dlprefiles contains only unique files old_dlprefiles=$dlprefiles dlprefiles= for lib in $old_dlprefiles; do case "$dlprefiles " in *" $lib "*) ;; *) func_append dlprefiles " $lib" ;; esac done if test yes = "$build_libtool_libs"; then if test -n "$rpath"; then case $host in *-*-cygwin* | *-*-mingw* | *-*-pw32* | *-*-os2* | *-*-beos* | *-cegcc* | *-*-haiku*) # these systems don't actually have a c library (as such)! ;; *-*-rhapsody* | *-*-darwin1.[012]) # Rhapsody C library is in the System framework func_append deplibs " System.ltframework" ;; *-*-netbsd*) # Don't link with libc until the a.out ld.so is fixed. ;; *-*-openbsd* | *-*-freebsd* | *-*-dragonfly*) # Do not include libc due to us having libc/libc_r. ;; *-*-sco3.2v5* | *-*-sco5v6*) # Causes problems with __ctype ;; *-*-sysv4.2uw2* | *-*-sysv5* | *-*-unixware* | *-*-OpenUNIX*) # Compiler inserts libc in the correct place for threads to work ;; *) # Add libc to deplibs on all other systems if necessary. if test yes = "$build_libtool_need_lc"; then func_append deplibs " -lc" fi ;; esac fi # Transform deplibs into only deplibs that can be linked in shared. name_save=$name libname_save=$libname release_save=$release versuffix_save=$versuffix major_save=$major # I'm not sure if I'm treating the release correctly. I think # release should show up in the -l (ie -lgmp5) so we don't want to # add it in twice. Is that correct? release= versuffix= major= newdeplibs= droppeddeps=no case $deplibs_check_method in pass_all) # Don't check for shared/static. Everything works. # This might be a little naive. We might want to check # whether the library exists or not. But this is on # osf3 & osf4 and I'm not really sure... Just # implementing what was already the behavior. newdeplibs=$deplibs ;; test_compile) # This code stresses the "libraries are programs" paradigm to its # limits. Maybe even breaks it. We compile a program, linking it # against the deplibs as a proxy for the library. Then we can check # whether they linked in statically or dynamically with ldd. $opt_dry_run || $RM conftest.c cat > conftest.c </dev/null` $nocaseglob else potential_libs=`ls $i/$libnameglob[.-]* 2>/dev/null` fi for potent_lib in $potential_libs; do # Follow soft links. if ls -lLd "$potent_lib" 2>/dev/null | $GREP " -> " >/dev/null; then continue fi # The statement above tries to avoid entering an # endless loop below, in case of cyclic links. # We might still enter an endless loop, since a link # loop can be closed while we follow links, # but so what? potlib=$potent_lib while test -h "$potlib" 2>/dev/null; do potliblink=`ls -ld $potlib | $SED 's/.* -> //'` case $potliblink in [\\/]* | [A-Za-z]:[\\/]*) potlib=$potliblink;; *) potlib=`$ECHO "$potlib" | $SED 's|[^/]*$||'`"$potliblink";; esac done if eval $file_magic_cmd \"\$potlib\" 2>/dev/null | $SED -e 10q | $EGREP "$file_magic_regex" > /dev/null; then func_append newdeplibs " $a_deplib" a_deplib= break 2 fi done done fi if test -n "$a_deplib"; then droppeddeps=yes echo $ECHO "*** Warning: linker path does not have real file for library $a_deplib." echo "*** I have the capability to make that library automatically link in when" echo "*** you link to this library. But I can only do this if you have a" echo "*** shared version of the library, which you do not appear to have" echo "*** because I did check the linker path looking for a file starting" if test -z "$potlib"; then $ECHO "*** with $libname but no candidates were found. (...for file magic test)" else $ECHO "*** with $libname and none of the candidates passed a file format test" $ECHO "*** using a file magic. Last file checked: $potlib" fi fi ;; *) # Add a -L argument. func_append newdeplibs " $a_deplib" ;; esac done # Gone through all deplibs. ;; match_pattern*) set dummy $deplibs_check_method; shift match_pattern_regex=`expr "$deplibs_check_method" : "$1 \(.*\)"` for a_deplib in $deplibs; do case $a_deplib in -l*) func_stripname -l '' "$a_deplib" name=$func_stripname_result if test yes = "$allow_libtool_libs_with_static_runtimes"; then case " $predeps $postdeps " in *" $a_deplib "*) func_append newdeplibs " $a_deplib" a_deplib= ;; esac fi if test -n "$a_deplib"; then libname=`eval "\\$ECHO \"$libname_spec\""` for i in $lib_search_path $sys_lib_search_path $shlib_search_path; do potential_libs=`ls $i/$libname[.-]* 2>/dev/null` for potent_lib in $potential_libs; do potlib=$potent_lib # see symlink-check above in file_magic test if eval "\$ECHO \"$potent_lib\"" 2>/dev/null | $SED 10q | \ $EGREP "$match_pattern_regex" > /dev/null; then func_append newdeplibs " $a_deplib" a_deplib= break 2 fi done done fi if test -n "$a_deplib"; then droppeddeps=yes echo $ECHO "*** Warning: linker path does not have real file for library $a_deplib." echo "*** I have the capability to make that library automatically link in when" echo "*** you link to this library. But I can only do this if you have a" echo "*** shared version of the library, which you do not appear to have" echo "*** because I did check the linker path looking for a file starting" if test -z "$potlib"; then $ECHO "*** with $libname but no candidates were found. (...for regex pattern test)" else $ECHO "*** with $libname and none of the candidates passed a file format test" $ECHO "*** using a regex pattern. Last file checked: $potlib" fi fi ;; *) # Add a -L argument. func_append newdeplibs " $a_deplib" ;; esac done # Gone through all deplibs. ;; none | unknown | *) newdeplibs= tmp_deplibs=`$ECHO " $deplibs" | $SED 's/ -lc$//; s/ -[LR][^ ]*//g'` if test yes = "$allow_libtool_libs_with_static_runtimes"; then for i in $predeps $postdeps; do # can't use Xsed below, because $i might contain '/' tmp_deplibs=`$ECHO " $tmp_deplibs" | $SED "s|$i||"` done fi case $tmp_deplibs in *[!\ \ ]*) echo if test none = "$deplibs_check_method"; then echo "*** Warning: inter-library dependencies are not supported in this platform." else echo "*** Warning: inter-library dependencies are not known to be supported." fi echo "*** All declared inter-library dependencies are being dropped." droppeddeps=yes ;; esac ;; esac versuffix=$versuffix_save major=$major_save release=$release_save libname=$libname_save name=$name_save case $host in *-*-rhapsody* | *-*-darwin1.[012]) # On Rhapsody replace the C library with the System framework newdeplibs=`$ECHO " $newdeplibs" | $SED 's/ -lc / System.ltframework /'` ;; esac if test yes = "$droppeddeps"; then if test yes = "$module"; then echo echo "*** Warning: libtool could not satisfy all declared inter-library" $ECHO "*** dependencies of module $libname. Therefore, libtool will create" echo "*** a static module, that should work as long as the dlopening" echo "*** application is linked with the -dlopen flag." if test -z "$global_symbol_pipe"; then echo echo "*** However, this would only work if libtool was able to extract symbol" echo "*** lists from a program, using 'nm' or equivalent, but libtool could" echo "*** not find such a program. So, this module is probably useless." echo "*** 'nm' from GNU binutils and a full rebuild may help." fi if test no = "$build_old_libs"; then oldlibs=$output_objdir/$libname.$libext build_libtool_libs=module build_old_libs=yes else build_libtool_libs=no fi else echo "*** The inter-library dependencies that have been dropped here will be" echo "*** automatically added whenever a program is linked with this library" echo "*** or is declared to -dlopen it." if test no = "$allow_undefined"; then echo echo "*** Since this library must not contain undefined symbols," echo "*** because either the platform does not support them or" echo "*** it was explicitly requested with -no-undefined," echo "*** libtool will only create a static version of it." if test no = "$build_old_libs"; then oldlibs=$output_objdir/$libname.$libext build_libtool_libs=module build_old_libs=yes else build_libtool_libs=no fi fi fi fi # Done checking deplibs! deplibs=$newdeplibs fi # Time to change all our "foo.ltframework" stuff back to "-framework foo" case $host in *-*-darwin*) newdeplibs=`$ECHO " $newdeplibs" | $SED 's% \([^ $]*\).ltframework% -framework \1%g'` new_inherited_linker_flags=`$ECHO " $new_inherited_linker_flags" | $SED 's% \([^ $]*\).ltframework% -framework \1%g'` deplibs=`$ECHO " $deplibs" | $SED 's% \([^ $]*\).ltframework% -framework \1%g'` ;; esac # move library search paths that coincide with paths to not yet # installed libraries to the beginning of the library search list new_libs= for path in $notinst_path; do case " $new_libs " in *" -L$path/$objdir "*) ;; *) case " $deplibs " in *" -L$path/$objdir "*) func_append new_libs " -L$path/$objdir" ;; esac ;; esac done for deplib in $deplibs; do case $deplib in -L*) case " $new_libs " in *" $deplib "*) ;; *) func_append new_libs " $deplib" ;; esac ;; *) func_append new_libs " $deplib" ;; esac done deplibs=$new_libs # All the library-specific variables (install_libdir is set above). library_names= old_library= dlname= # Test again, we may have decided not to build it any more if test yes = "$build_libtool_libs"; then # Remove $wl instances when linking with ld. # FIXME: should test the right _cmds variable. case $archive_cmds in *\$LD\ *) wl= ;; esac if test yes = "$hardcode_into_libs"; then # Hardcode the library paths hardcode_libdirs= dep_rpath= rpath=$finalize_rpath test relink = "$opt_mode" || rpath=$compile_rpath$rpath for libdir in $rpath; do if test -n "$hardcode_libdir_flag_spec"; then if test -n "$hardcode_libdir_separator"; then func_replace_sysroot "$libdir" libdir=$func_replace_sysroot_result if test -z "$hardcode_libdirs"; then hardcode_libdirs=$libdir else # Just accumulate the unique libdirs. case $hardcode_libdir_separator$hardcode_libdirs$hardcode_libdir_separator in *"$hardcode_libdir_separator$libdir$hardcode_libdir_separator"*) ;; *) func_append hardcode_libdirs "$hardcode_libdir_separator$libdir" ;; esac fi else eval flag=\"$hardcode_libdir_flag_spec\" func_append dep_rpath " $flag" fi elif test -n "$runpath_var"; then case "$perm_rpath " in *" $libdir "*) ;; *) func_append perm_rpath " $libdir" ;; esac fi done # Substitute the hardcoded libdirs into the rpath. if test -n "$hardcode_libdir_separator" && test -n "$hardcode_libdirs"; then libdir=$hardcode_libdirs eval "dep_rpath=\"$hardcode_libdir_flag_spec\"" fi if test -n "$runpath_var" && test -n "$perm_rpath"; then # We should set the runpath_var. rpath= for dir in $perm_rpath; do func_append rpath "$dir:" done eval "$runpath_var='$rpath\$$runpath_var'; export $runpath_var" fi test -n "$dep_rpath" && deplibs="$dep_rpath $deplibs" fi shlibpath=$finalize_shlibpath test relink = "$opt_mode" || shlibpath=$compile_shlibpath$shlibpath if test -n "$shlibpath"; then eval "$shlibpath_var='$shlibpath\$$shlibpath_var'; export $shlibpath_var" fi # Get the real and link names of the library. eval shared_ext=\"$shrext_cmds\" eval library_names=\"$library_names_spec\" set dummy $library_names shift realname=$1 shift if test -n "$soname_spec"; then eval soname=\"$soname_spec\" else soname=$realname fi if test -z "$dlname"; then dlname=$soname fi lib=$output_objdir/$realname linknames= for link do func_append linknames " $link" done # Use standard objects if they are pic test -z "$pic_flag" && libobjs=`$ECHO "$libobjs" | $SP2NL | $SED "$lo2o" | $NL2SP` test "X$libobjs" = "X " && libobjs= delfiles= if test -n "$export_symbols" && test -n "$include_expsyms"; then $opt_dry_run || cp "$export_symbols" "$output_objdir/$libname.uexp" export_symbols=$output_objdir/$libname.uexp func_append delfiles " $export_symbols" fi orig_export_symbols= case $host_os in cygwin* | mingw* | cegcc*) if test -n "$export_symbols" && test -z "$export_symbols_regex"; then # exporting using user supplied symfile func_dll_def_p "$export_symbols" || { # and it's NOT already a .def file. Must figure out # which of the given symbols are data symbols and tag # them as such. So, trigger use of export_symbols_cmds. # export_symbols gets reassigned inside the "prepare # the list of exported symbols" if statement, so the # include_expsyms logic still works. orig_export_symbols=$export_symbols export_symbols= always_export_symbols=yes } fi ;; esac # Prepare the list of exported symbols if test -z "$export_symbols"; then if test yes = "$always_export_symbols" || test -n "$export_symbols_regex"; then func_verbose "generating symbol list for '$libname.la'" export_symbols=$output_objdir/$libname.exp $opt_dry_run || $RM $export_symbols cmds=$export_symbols_cmds save_ifs=$IFS; IFS='~' for cmd1 in $cmds; do IFS=$save_ifs # Take the normal branch if the nm_file_list_spec branch # doesn't work or if tool conversion is not needed. case $nm_file_list_spec~$to_tool_file_cmd in *~func_convert_file_noop | *~func_convert_file_msys_to_w32 | ~*) try_normal_branch=yes eval cmd=\"$cmd1\" func_len " $cmd" len=$func_len_result ;; *) try_normal_branch=no ;; esac if test yes = "$try_normal_branch" \ && { test "$len" -lt "$max_cmd_len" \ || test "$max_cmd_len" -le -1; } then func_show_eval "$cmd" 'exit $?' skipped_export=false elif test -n "$nm_file_list_spec"; then func_basename "$output" output_la=$func_basename_result save_libobjs=$libobjs save_output=$output output=$output_objdir/$output_la.nm func_to_tool_file "$output" libobjs=$nm_file_list_spec$func_to_tool_file_result func_append delfiles " $output" func_verbose "creating $NM input file list: $output" for obj in $save_libobjs; do func_to_tool_file "$obj" $ECHO "$func_to_tool_file_result" done > "$output" eval cmd=\"$cmd1\" func_show_eval "$cmd" 'exit $?' output=$save_output libobjs=$save_libobjs skipped_export=false else # The command line is too long to execute in one step. func_verbose "using reloadable object file for export list..." skipped_export=: # Break out early, otherwise skipped_export may be # set to false by a later but shorter cmd. break fi done IFS=$save_ifs if test -n "$export_symbols_regex" && test : != "$skipped_export"; then func_show_eval '$EGREP -e "$export_symbols_regex" "$export_symbols" > "${export_symbols}T"' func_show_eval '$MV "${export_symbols}T" "$export_symbols"' fi fi fi if test -n "$export_symbols" && test -n "$include_expsyms"; then tmp_export_symbols=$export_symbols test -n "$orig_export_symbols" && tmp_export_symbols=$orig_export_symbols $opt_dry_run || eval '$ECHO "$include_expsyms" | $SP2NL >> "$tmp_export_symbols"' fi if test : != "$skipped_export" && test -n "$orig_export_symbols"; then # The given exports_symbols file has to be filtered, so filter it. func_verbose "filter symbol list for '$libname.la' to tag DATA exports" # FIXME: $output_objdir/$libname.filter potentially contains lots of # 's' commands, which not all seds can handle. GNU sed should be fine # though. Also, the filter scales superlinearly with the number of # global variables. join(1) would be nice here, but unfortunately # isn't a blessed tool. $opt_dry_run || $SED -e '/[ ,]DATA/!d;s,\(.*\)\([ \,].*\),s|^\1$|\1\2|,' < $export_symbols > $output_objdir/$libname.filter func_append delfiles " $export_symbols $output_objdir/$libname.filter" export_symbols=$output_objdir/$libname.def $opt_dry_run || $SED -f $output_objdir/$libname.filter < $orig_export_symbols > $export_symbols fi tmp_deplibs= for test_deplib in $deplibs; do case " $convenience " in *" $test_deplib "*) ;; *) func_append tmp_deplibs " $test_deplib" ;; esac done deplibs=$tmp_deplibs if test -n "$convenience"; then if test -n "$whole_archive_flag_spec" && test yes = "$compiler_needs_object" && test -z "$libobjs"; then # extract the archives, so we have objects to list. # TODO: could optimize this to just extract one archive. whole_archive_flag_spec= fi if test -n "$whole_archive_flag_spec"; then save_libobjs=$libobjs eval libobjs=\"\$libobjs $whole_archive_flag_spec\" test "X$libobjs" = "X " && libobjs= else gentop=$output_objdir/${outputname}x func_append generated " $gentop" func_extract_archives $gentop $convenience func_append libobjs " $func_extract_archives_result" test "X$libobjs" = "X " && libobjs= fi fi if test yes = "$thread_safe" && test -n "$thread_safe_flag_spec"; then eval flag=\"$thread_safe_flag_spec\" func_append linker_flags " $flag" fi # Make a backup of the uninstalled library when relinking if test relink = "$opt_mode"; then $opt_dry_run || eval '(cd $output_objdir && $RM ${realname}U && $MV $realname ${realname}U)' || exit $? fi # Do each of the archive commands. if test yes = "$module" && test -n "$module_cmds"; then if test -n "$export_symbols" && test -n "$module_expsym_cmds"; then eval test_cmds=\"$module_expsym_cmds\" cmds=$module_expsym_cmds else eval test_cmds=\"$module_cmds\" cmds=$module_cmds fi else if test -n "$export_symbols" && test -n "$archive_expsym_cmds"; then eval test_cmds=\"$archive_expsym_cmds\" cmds=$archive_expsym_cmds else eval test_cmds=\"$archive_cmds\" cmds=$archive_cmds fi fi if test : != "$skipped_export" && func_len " $test_cmds" && len=$func_len_result && test "$len" -lt "$max_cmd_len" || test "$max_cmd_len" -le -1; then : else # The command line is too long to link in one step, link piecewise # or, if using GNU ld and skipped_export is not :, use a linker # script. # Save the value of $output and $libobjs because we want to # use them later. If we have whole_archive_flag_spec, we # want to use save_libobjs as it was before # whole_archive_flag_spec was expanded, because we can't # assume the linker understands whole_archive_flag_spec. # This may have to be revisited, in case too many # convenience libraries get linked in and end up exceeding # the spec. if test -z "$convenience" || test -z "$whole_archive_flag_spec"; then save_libobjs=$libobjs fi save_output=$output func_basename "$output" output_la=$func_basename_result # Clear the reloadable object creation command queue and # initialize k to one. test_cmds= concat_cmds= objlist= last_robj= k=1 if test -n "$save_libobjs" && test : != "$skipped_export" && test yes = "$with_gnu_ld"; then output=$output_objdir/$output_la.lnkscript func_verbose "creating GNU ld script: $output" echo 'INPUT (' > $output for obj in $save_libobjs do func_to_tool_file "$obj" $ECHO "$func_to_tool_file_result" >> $output done echo ')' >> $output func_append delfiles " $output" func_to_tool_file "$output" output=$func_to_tool_file_result elif test -n "$save_libobjs" && test : != "$skipped_export" && test -n "$file_list_spec"; then output=$output_objdir/$output_la.lnk func_verbose "creating linker input file list: $output" : > $output set x $save_libobjs shift firstobj= if test yes = "$compiler_needs_object"; then firstobj="$1 " shift fi for obj do func_to_tool_file "$obj" $ECHO "$func_to_tool_file_result" >> $output done func_append delfiles " $output" func_to_tool_file "$output" output=$firstobj\"$file_list_spec$func_to_tool_file_result\" else if test -n "$save_libobjs"; then func_verbose "creating reloadable object files..." output=$output_objdir/$output_la-$k.$objext eval test_cmds=\"$reload_cmds\" func_len " $test_cmds" len0=$func_len_result len=$len0 # Loop over the list of objects to be linked. for obj in $save_libobjs do func_len " $obj" func_arith $len + $func_len_result len=$func_arith_result if test -z "$objlist" || test "$len" -lt "$max_cmd_len"; then func_append objlist " $obj" else # The command $test_cmds is almost too long, add a # command to the queue. if test 1 -eq "$k"; then # The first file doesn't have a previous command to add. reload_objs=$objlist eval concat_cmds=\"$reload_cmds\" else # All subsequent reloadable object files will link in # the last one created. reload_objs="$objlist $last_robj" eval concat_cmds=\"\$concat_cmds~$reload_cmds~\$RM $last_robj\" fi last_robj=$output_objdir/$output_la-$k.$objext func_arith $k + 1 k=$func_arith_result output=$output_objdir/$output_la-$k.$objext objlist=" $obj" func_len " $last_robj" func_arith $len0 + $func_len_result len=$func_arith_result fi done # Handle the remaining objects by creating one last # reloadable object file. All subsequent reloadable object # files will link in the last one created. test -z "$concat_cmds" || concat_cmds=$concat_cmds~ reload_objs="$objlist $last_robj" eval concat_cmds=\"\$concat_cmds$reload_cmds\" if test -n "$last_robj"; then eval concat_cmds=\"\$concat_cmds~\$RM $last_robj\" fi func_append delfiles " $output" else output= fi ${skipped_export-false} && { func_verbose "generating symbol list for '$libname.la'" export_symbols=$output_objdir/$libname.exp $opt_dry_run || $RM $export_symbols libobjs=$output # Append the command to create the export file. test -z "$concat_cmds" || concat_cmds=$concat_cmds~ eval concat_cmds=\"\$concat_cmds$export_symbols_cmds\" if test -n "$last_robj"; then eval concat_cmds=\"\$concat_cmds~\$RM $last_robj\" fi } test -n "$save_libobjs" && func_verbose "creating a temporary reloadable object file: $output" # Loop through the commands generated above and execute them. save_ifs=$IFS; IFS='~' for cmd in $concat_cmds; do IFS=$save_ifs $opt_quiet || { func_quote_for_expand "$cmd" eval "func_echo $func_quote_for_expand_result" } $opt_dry_run || eval "$cmd" || { lt_exit=$? # Restore the uninstalled library and exit if test relink = "$opt_mode"; then ( cd "$output_objdir" && \ $RM "${realname}T" && \ $MV "${realname}U" "$realname" ) fi exit $lt_exit } done IFS=$save_ifs if test -n "$export_symbols_regex" && ${skipped_export-false}; then func_show_eval '$EGREP -e "$export_symbols_regex" "$export_symbols" > "${export_symbols}T"' func_show_eval '$MV "${export_symbols}T" "$export_symbols"' fi fi ${skipped_export-false} && { if test -n "$export_symbols" && test -n "$include_expsyms"; then tmp_export_symbols=$export_symbols test -n "$orig_export_symbols" && tmp_export_symbols=$orig_export_symbols $opt_dry_run || eval '$ECHO "$include_expsyms" | $SP2NL >> "$tmp_export_symbols"' fi if test -n "$orig_export_symbols"; then # The given exports_symbols file has to be filtered, so filter it. func_verbose "filter symbol list for '$libname.la' to tag DATA exports" # FIXME: $output_objdir/$libname.filter potentially contains lots of # 's' commands, which not all seds can handle. GNU sed should be fine # though. Also, the filter scales superlinearly with the number of # global variables. join(1) would be nice here, but unfortunately # isn't a blessed tool. $opt_dry_run || $SED -e '/[ ,]DATA/!d;s,\(.*\)\([ \,].*\),s|^\1$|\1\2|,' < $export_symbols > $output_objdir/$libname.filter func_append delfiles " $export_symbols $output_objdir/$libname.filter" export_symbols=$output_objdir/$libname.def $opt_dry_run || $SED -f $output_objdir/$libname.filter < $orig_export_symbols > $export_symbols fi } libobjs=$output # Restore the value of output. output=$save_output if test -n "$convenience" && test -n "$whole_archive_flag_spec"; then eval libobjs=\"\$libobjs $whole_archive_flag_spec\" test "X$libobjs" = "X " && libobjs= fi # Expand the library linking commands again to reset the # value of $libobjs for piecewise linking. # Do each of the archive commands. if test yes = "$module" && test -n "$module_cmds"; then if test -n "$export_symbols" && test -n "$module_expsym_cmds"; then cmds=$module_expsym_cmds else cmds=$module_cmds fi else if test -n "$export_symbols" && test -n "$archive_expsym_cmds"; then cmds=$archive_expsym_cmds else cmds=$archive_cmds fi fi fi if test -n "$delfiles"; then # Append the command to remove temporary files to $cmds. eval cmds=\"\$cmds~\$RM $delfiles\" fi # Add any objects from preloaded convenience libraries if test -n "$dlprefiles"; then gentop=$output_objdir/${outputname}x func_append generated " $gentop" func_extract_archives $gentop $dlprefiles func_append libobjs " $func_extract_archives_result" test "X$libobjs" = "X " && libobjs= fi save_ifs=$IFS; IFS='~' for cmd in $cmds; do IFS=$sp$nl eval cmd=\"$cmd\" IFS=$save_ifs $opt_quiet || { func_quote_for_expand "$cmd" eval "func_echo $func_quote_for_expand_result" } $opt_dry_run || eval "$cmd" || { lt_exit=$? # Restore the uninstalled library and exit if test relink = "$opt_mode"; then ( cd "$output_objdir" && \ $RM "${realname}T" && \ $MV "${realname}U" "$realname" ) fi exit $lt_exit } done IFS=$save_ifs # Restore the uninstalled library and exit if test relink = "$opt_mode"; then $opt_dry_run || eval '(cd $output_objdir && $RM ${realname}T && $MV $realname ${realname}T && $MV ${realname}U $realname)' || exit $? if test -n "$convenience"; then if test -z "$whole_archive_flag_spec"; then func_show_eval '${RM}r "$gentop"' fi fi exit $EXIT_SUCCESS fi # Create links to the real library. for linkname in $linknames; do if test "$realname" != "$linkname"; then func_show_eval '(cd "$output_objdir" && $RM "$linkname" && $LN_S "$realname" "$linkname")' 'exit $?' fi done # If -module or -export-dynamic was specified, set the dlname. if test yes = "$module" || test yes = "$export_dynamic"; then # On all known operating systems, these are identical. dlname=$soname fi fi ;; obj) if test -n "$dlfiles$dlprefiles" || test no != "$dlself"; then func_warning "'-dlopen' is ignored for objects" fi case " $deplibs" in *\ -l* | *\ -L*) func_warning "'-l' and '-L' are ignored for objects" ;; esac test -n "$rpath" && \ func_warning "'-rpath' is ignored for objects" test -n "$xrpath" && \ func_warning "'-R' is ignored for objects" test -n "$vinfo" && \ func_warning "'-version-info' is ignored for objects" test -n "$release" && \ func_warning "'-release' is ignored for objects" case $output in *.lo) test -n "$objs$old_deplibs" && \ func_fatal_error "cannot build library object '$output' from non-libtool objects" libobj=$output func_lo2o "$libobj" obj=$func_lo2o_result ;; *) libobj= obj=$output ;; esac # Delete the old objects. $opt_dry_run || $RM $obj $libobj # Objects from convenience libraries. This assumes # single-version convenience libraries. Whenever we create # different ones for PIC/non-PIC, this we'll have to duplicate # the extraction. reload_conv_objs= gentop= # if reload_cmds runs $LD directly, get rid of -Wl from # whole_archive_flag_spec and hope we can get by with turning comma # into space. case $reload_cmds in *\$LD[\ \$]*) wl= ;; esac if test -n "$convenience"; then if test -n "$whole_archive_flag_spec"; then eval tmp_whole_archive_flags=\"$whole_archive_flag_spec\" test -n "$wl" || tmp_whole_archive_flags=`$ECHO "$tmp_whole_archive_flags" | $SED 's|,| |g'` reload_conv_objs=$reload_objs\ $tmp_whole_archive_flags else gentop=$output_objdir/${obj}x func_append generated " $gentop" func_extract_archives $gentop $convenience reload_conv_objs="$reload_objs $func_extract_archives_result" fi fi # If we're not building shared, we need to use non_pic_objs test yes = "$build_libtool_libs" || libobjs=$non_pic_objects # Create the old-style object. reload_objs=$objs$old_deplibs' '`$ECHO "$libobjs" | $SP2NL | $SED "/\.$libext$/d; /\.lib$/d; $lo2o" | $NL2SP`' '$reload_conv_objs output=$obj func_execute_cmds "$reload_cmds" 'exit $?' # Exit if we aren't doing a library object file. if test -z "$libobj"; then if test -n "$gentop"; then func_show_eval '${RM}r "$gentop"' fi exit $EXIT_SUCCESS fi test yes = "$build_libtool_libs" || { if test -n "$gentop"; then func_show_eval '${RM}r "$gentop"' fi # Create an invalid libtool object if no PIC, so that we don't # accidentally link it into a program. # $show "echo timestamp > $libobj" # $opt_dry_run || eval "echo timestamp > $libobj" || exit $? exit $EXIT_SUCCESS } if test -n "$pic_flag" || test default != "$pic_mode"; then # Only do commands if we really have different PIC objects. reload_objs="$libobjs $reload_conv_objs" output=$libobj func_execute_cmds "$reload_cmds" 'exit $?' fi if test -n "$gentop"; then func_show_eval '${RM}r "$gentop"' fi exit $EXIT_SUCCESS ;; prog) case $host in *cygwin*) func_stripname '' '.exe' "$output" output=$func_stripname_result.exe;; esac test -n "$vinfo" && \ func_warning "'-version-info' is ignored for programs" test -n "$release" && \ func_warning "'-release' is ignored for programs" $preload \ && test unknown,unknown,unknown = "$dlopen_support,$dlopen_self,$dlopen_self_static" \ && func_warning "'LT_INIT([dlopen])' not used. Assuming no dlopen support." case $host in *-*-rhapsody* | *-*-darwin1.[012]) # On Rhapsody replace the C library is the System framework compile_deplibs=`$ECHO " $compile_deplibs" | $SED 's/ -lc / System.ltframework /'` finalize_deplibs=`$ECHO " $finalize_deplibs" | $SED 's/ -lc / System.ltframework /'` ;; esac case $host in *-*-darwin*) # Don't allow lazy linking, it breaks C++ global constructors # But is supposedly fixed on 10.4 or later (yay!). if test CXX = "$tagname"; then case ${MACOSX_DEPLOYMENT_TARGET-10.0} in 10.[0123]) func_append compile_command " $wl-bind_at_load" func_append finalize_command " $wl-bind_at_load" ;; esac fi # Time to change all our "foo.ltframework" stuff back to "-framework foo" compile_deplibs=`$ECHO " $compile_deplibs" | $SED 's% \([^ $]*\).ltframework% -framework \1%g'` finalize_deplibs=`$ECHO " $finalize_deplibs" | $SED 's% \([^ $]*\).ltframework% -framework \1%g'` ;; esac # move library search paths that coincide with paths to not yet # installed libraries to the beginning of the library search list new_libs= for path in $notinst_path; do case " $new_libs " in *" -L$path/$objdir "*) ;; *) case " $compile_deplibs " in *" -L$path/$objdir "*) func_append new_libs " -L$path/$objdir" ;; esac ;; esac done for deplib in $compile_deplibs; do case $deplib in -L*) case " $new_libs " in *" $deplib "*) ;; *) func_append new_libs " $deplib" ;; esac ;; *) func_append new_libs " $deplib" ;; esac done compile_deplibs=$new_libs func_append compile_command " $compile_deplibs" func_append finalize_command " $finalize_deplibs" if test -n "$rpath$xrpath"; then # If the user specified any rpath flags, then add them. for libdir in $rpath $xrpath; do # This is the magic to use -rpath. case "$finalize_rpath " in *" $libdir "*) ;; *) func_append finalize_rpath " $libdir" ;; esac done fi # Now hardcode the library paths rpath= hardcode_libdirs= for libdir in $compile_rpath $finalize_rpath; do if test -n "$hardcode_libdir_flag_spec"; then if test -n "$hardcode_libdir_separator"; then if test -z "$hardcode_libdirs"; then hardcode_libdirs=$libdir else # Just accumulate the unique libdirs. case $hardcode_libdir_separator$hardcode_libdirs$hardcode_libdir_separator in *"$hardcode_libdir_separator$libdir$hardcode_libdir_separator"*) ;; *) func_append hardcode_libdirs "$hardcode_libdir_separator$libdir" ;; esac fi else eval flag=\"$hardcode_libdir_flag_spec\" func_append rpath " $flag" fi elif test -n "$runpath_var"; then case "$perm_rpath " in *" $libdir "*) ;; *) func_append perm_rpath " $libdir" ;; esac fi case $host in *-*-cygwin* | *-*-mingw* | *-*-pw32* | *-*-os2* | *-cegcc*) testbindir=`$ECHO "$libdir" | $SED -e 's*/lib$*/bin*'` case :$dllsearchpath: in *":$libdir:"*) ;; ::) dllsearchpath=$libdir;; *) func_append dllsearchpath ":$libdir";; esac case :$dllsearchpath: in *":$testbindir:"*) ;; ::) dllsearchpath=$testbindir;; *) func_append dllsearchpath ":$testbindir";; esac ;; esac done # Substitute the hardcoded libdirs into the rpath. if test -n "$hardcode_libdir_separator" && test -n "$hardcode_libdirs"; then libdir=$hardcode_libdirs eval rpath=\" $hardcode_libdir_flag_spec\" fi compile_rpath=$rpath rpath= hardcode_libdirs= for libdir in $finalize_rpath; do if test -n "$hardcode_libdir_flag_spec"; then if test -n "$hardcode_libdir_separator"; then if test -z "$hardcode_libdirs"; then hardcode_libdirs=$libdir else # Just accumulate the unique libdirs. case $hardcode_libdir_separator$hardcode_libdirs$hardcode_libdir_separator in *"$hardcode_libdir_separator$libdir$hardcode_libdir_separator"*) ;; *) func_append hardcode_libdirs "$hardcode_libdir_separator$libdir" ;; esac fi else eval flag=\"$hardcode_libdir_flag_spec\" func_append rpath " $flag" fi elif test -n "$runpath_var"; then case "$finalize_perm_rpath " in *" $libdir "*) ;; *) func_append finalize_perm_rpath " $libdir" ;; esac fi done # Substitute the hardcoded libdirs into the rpath. if test -n "$hardcode_libdir_separator" && test -n "$hardcode_libdirs"; then libdir=$hardcode_libdirs eval rpath=\" $hardcode_libdir_flag_spec\" fi finalize_rpath=$rpath if test -n "$libobjs" && test yes = "$build_old_libs"; then # Transform all the library objects into standard objects. compile_command=`$ECHO "$compile_command" | $SP2NL | $SED "$lo2o" | $NL2SP` finalize_command=`$ECHO "$finalize_command" | $SP2NL | $SED "$lo2o" | $NL2SP` fi func_generate_dlsyms "$outputname" "@PROGRAM@" false # template prelinking step if test -n "$prelink_cmds"; then func_execute_cmds "$prelink_cmds" 'exit $?' fi wrappers_required=: case $host in *cegcc* | *mingw32ce*) # Disable wrappers for cegcc and mingw32ce hosts, we are cross compiling anyway. wrappers_required=false ;; *cygwin* | *mingw* ) test yes = "$build_libtool_libs" || wrappers_required=false ;; *) if test no = "$need_relink" || test yes != "$build_libtool_libs"; then wrappers_required=false fi ;; esac $wrappers_required || { # Replace the output file specification. compile_command=`$ECHO "$compile_command" | $SED 's%@OUTPUT@%'"$output"'%g'` link_command=$compile_command$compile_rpath # We have no uninstalled library dependencies, so finalize right now. exit_status=0 func_show_eval "$link_command" 'exit_status=$?' if test -n "$postlink_cmds"; then func_to_tool_file "$output" postlink_cmds=`func_echo_all "$postlink_cmds" | $SED -e 's%@OUTPUT@%'"$output"'%g' -e 's%@TOOL_OUTPUT@%'"$func_to_tool_file_result"'%g'` func_execute_cmds "$postlink_cmds" 'exit $?' fi # Delete the generated files. if test -f "$output_objdir/${outputname}S.$objext"; then func_show_eval '$RM "$output_objdir/${outputname}S.$objext"' fi exit $exit_status } if test -n "$compile_shlibpath$finalize_shlibpath"; then compile_command="$shlibpath_var=\"$compile_shlibpath$finalize_shlibpath\$$shlibpath_var\" $compile_command" fi if test -n "$finalize_shlibpath"; then finalize_command="$shlibpath_var=\"$finalize_shlibpath\$$shlibpath_var\" $finalize_command" fi compile_var= finalize_var= if test -n "$runpath_var"; then if test -n "$perm_rpath"; then # We should set the runpath_var. rpath= for dir in $perm_rpath; do func_append rpath "$dir:" done compile_var="$runpath_var=\"$rpath\$$runpath_var\" " fi if test -n "$finalize_perm_rpath"; then # We should set the runpath_var. rpath= for dir in $finalize_perm_rpath; do func_append rpath "$dir:" done finalize_var="$runpath_var=\"$rpath\$$runpath_var\" " fi fi if test yes = "$no_install"; then # We don't need to create a wrapper script. link_command=$compile_var$compile_command$compile_rpath # Replace the output file specification. link_command=`$ECHO "$link_command" | $SED 's%@OUTPUT@%'"$output"'%g'` # Delete the old output file. $opt_dry_run || $RM $output # Link the executable and exit func_show_eval "$link_command" 'exit $?' if test -n "$postlink_cmds"; then func_to_tool_file "$output" postlink_cmds=`func_echo_all "$postlink_cmds" | $SED -e 's%@OUTPUT@%'"$output"'%g' -e 's%@TOOL_OUTPUT@%'"$func_to_tool_file_result"'%g'` func_execute_cmds "$postlink_cmds" 'exit $?' fi exit $EXIT_SUCCESS fi case $hardcode_action,$fast_install in relink,*) # Fast installation is not supported link_command=$compile_var$compile_command$compile_rpath relink_command=$finalize_var$finalize_command$finalize_rpath func_warning "this platform does not like uninstalled shared libraries" func_warning "'$output' will be relinked during installation" ;; *,yes) link_command=$finalize_var$compile_command$finalize_rpath relink_command=`$ECHO "$compile_var$compile_command$compile_rpath" | $SED 's%@OUTPUT@%\$progdir/\$file%g'` ;; *,no) link_command=$compile_var$compile_command$compile_rpath relink_command=$finalize_var$finalize_command$finalize_rpath ;; *,needless) link_command=$finalize_var$compile_command$finalize_rpath relink_command= ;; esac # Replace the output file specification. link_command=`$ECHO "$link_command" | $SED 's%@OUTPUT@%'"$output_objdir/$outputname"'%g'` # Delete the old output files. $opt_dry_run || $RM $output $output_objdir/$outputname $output_objdir/lt-$outputname func_show_eval "$link_command" 'exit $?' if test -n "$postlink_cmds"; then func_to_tool_file "$output_objdir/$outputname" postlink_cmds=`func_echo_all "$postlink_cmds" | $SED -e 's%@OUTPUT@%'"$output_objdir/$outputname"'%g' -e 's%@TOOL_OUTPUT@%'"$func_to_tool_file_result"'%g'` func_execute_cmds "$postlink_cmds" 'exit $?' fi # Now create the wrapper script. func_verbose "creating $output" # Quote the relink command for shipping. if test -n "$relink_command"; then # Preserve any variables that may affect compiler behavior for var in $variables_saved_for_relink; do if eval test -z \"\${$var+set}\"; then relink_command="{ test -z \"\${$var+set}\" || $lt_unset $var || { $var=; export $var; }; }; $relink_command" elif eval var_value=\$$var; test -z "$var_value"; then relink_command="$var=; export $var; $relink_command" else func_quote_for_eval "$var_value" relink_command="$var=$func_quote_for_eval_result; export $var; $relink_command" fi done relink_command="(cd `pwd`; $relink_command)" relink_command=`$ECHO "$relink_command" | $SED "$sed_quote_subst"` fi # Only actually do things if not in dry run mode. $opt_dry_run || { # win32 will think the script is a binary if it has # a .exe suffix, so we strip it off here. case $output in *.exe) func_stripname '' '.exe' "$output" output=$func_stripname_result ;; esac # test for cygwin because mv fails w/o .exe extensions case $host in *cygwin*) exeext=.exe func_stripname '' '.exe' "$outputname" outputname=$func_stripname_result ;; *) exeext= ;; esac case $host in *cygwin* | *mingw* ) func_dirname_and_basename "$output" "" "." output_name=$func_basename_result output_path=$func_dirname_result cwrappersource=$output_path/$objdir/lt-$output_name.c cwrapper=$output_path/$output_name.exe $RM $cwrappersource $cwrapper trap "$RM $cwrappersource $cwrapper; exit $EXIT_FAILURE" 1 2 15 func_emit_cwrapperexe_src > $cwrappersource # The wrapper executable is built using the $host compiler, # because it contains $host paths and files. If cross- # compiling, it, like the target executable, must be # executed on the $host or under an emulation environment. $opt_dry_run || { $LTCC $LTCFLAGS -o $cwrapper $cwrappersource $STRIP $cwrapper } # Now, create the wrapper script for func_source use: func_ltwrapper_scriptname $cwrapper $RM $func_ltwrapper_scriptname_result trap "$RM $func_ltwrapper_scriptname_result; exit $EXIT_FAILURE" 1 2 15 $opt_dry_run || { # note: this script will not be executed, so do not chmod. if test "x$build" = "x$host"; then $cwrapper --lt-dump-script > $func_ltwrapper_scriptname_result else func_emit_wrapper no > $func_ltwrapper_scriptname_result fi } ;; * ) $RM $output trap "$RM $output; exit $EXIT_FAILURE" 1 2 15 func_emit_wrapper no > $output chmod +x $output ;; esac } exit $EXIT_SUCCESS ;; esac # See if we need to build an old-fashioned archive. for oldlib in $oldlibs; do case $build_libtool_libs in convenience) oldobjs="$libobjs_save $symfileobj" addlibs=$convenience build_libtool_libs=no ;; module) oldobjs=$libobjs_save addlibs=$old_convenience build_libtool_libs=no ;; *) oldobjs="$old_deplibs $non_pic_objects" $preload && test -f "$symfileobj" \ && func_append oldobjs " $symfileobj" addlibs=$old_convenience ;; esac if test -n "$addlibs"; then gentop=$output_objdir/${outputname}x func_append generated " $gentop" func_extract_archives $gentop $addlibs func_append oldobjs " $func_extract_archives_result" fi # Do each command in the archive commands. if test -n "$old_archive_from_new_cmds" && test yes = "$build_libtool_libs"; then cmds=$old_archive_from_new_cmds else # Add any objects from preloaded convenience libraries if test -n "$dlprefiles"; then gentop=$output_objdir/${outputname}x func_append generated " $gentop" func_extract_archives $gentop $dlprefiles func_append oldobjs " $func_extract_archives_result" fi # POSIX demands no paths to be encoded in archives. We have # to avoid creating archives with duplicate basenames if we # might have to extract them afterwards, e.g., when creating a # static archive out of a convenience library, or when linking # the entirety of a libtool archive into another (currently # not supported by libtool). if (for obj in $oldobjs do func_basename "$obj" $ECHO "$func_basename_result" done | sort | sort -uc >/dev/null 2>&1); then : else echo "copying selected object files to avoid basename conflicts..." gentop=$output_objdir/${outputname}x func_append generated " $gentop" func_mkdir_p "$gentop" save_oldobjs=$oldobjs oldobjs= counter=1 for obj in $save_oldobjs do func_basename "$obj" objbase=$func_basename_result case " $oldobjs " in " ") oldobjs=$obj ;; *[\ /]"$objbase "*) while :; do # Make sure we don't pick an alternate name that also # overlaps. newobj=lt$counter-$objbase func_arith $counter + 1 counter=$func_arith_result case " $oldobjs " in *[\ /]"$newobj "*) ;; *) if test ! -f "$gentop/$newobj"; then break; fi ;; esac done func_show_eval "ln $obj $gentop/$newobj || cp $obj $gentop/$newobj" func_append oldobjs " $gentop/$newobj" ;; *) func_append oldobjs " $obj" ;; esac done fi func_to_tool_file "$oldlib" func_convert_file_msys_to_w32 tool_oldlib=$func_to_tool_file_result eval cmds=\"$old_archive_cmds\" func_len " $cmds" len=$func_len_result if test "$len" -lt "$max_cmd_len" || test "$max_cmd_len" -le -1; then cmds=$old_archive_cmds elif test -n "$archiver_list_spec"; then func_verbose "using command file archive linking..." for obj in $oldobjs do func_to_tool_file "$obj" $ECHO "$func_to_tool_file_result" done > $output_objdir/$libname.libcmd func_to_tool_file "$output_objdir/$libname.libcmd" oldobjs=" $archiver_list_spec$func_to_tool_file_result" cmds=$old_archive_cmds else # the command line is too long to link in one step, link in parts func_verbose "using piecewise archive linking..." save_RANLIB=$RANLIB RANLIB=: objlist= concat_cmds= save_oldobjs=$oldobjs oldobjs= # Is there a better way of finding the last object in the list? for obj in $save_oldobjs do last_oldobj=$obj done eval test_cmds=\"$old_archive_cmds\" func_len " $test_cmds" len0=$func_len_result len=$len0 for obj in $save_oldobjs do func_len " $obj" func_arith $len + $func_len_result len=$func_arith_result func_append objlist " $obj" if test "$len" -lt "$max_cmd_len"; then : else # the above command should be used before it gets too long oldobjs=$objlist if test "$obj" = "$last_oldobj"; then RANLIB=$save_RANLIB fi test -z "$concat_cmds" || concat_cmds=$concat_cmds~ eval concat_cmds=\"\$concat_cmds$old_archive_cmds\" objlist= len=$len0 fi done RANLIB=$save_RANLIB oldobjs=$objlist if test -z "$oldobjs"; then eval cmds=\"\$concat_cmds\" else eval cmds=\"\$concat_cmds~\$old_archive_cmds\" fi fi fi func_execute_cmds "$cmds" 'exit $?' done test -n "$generated" && \ func_show_eval "${RM}r$generated" # Now create the libtool archive. case $output in *.la) old_library= test yes = "$build_old_libs" && old_library=$libname.$libext func_verbose "creating $output" # Preserve any variables that may affect compiler behavior for var in $variables_saved_for_relink; do if eval test -z \"\${$var+set}\"; then relink_command="{ test -z \"\${$var+set}\" || $lt_unset $var || { $var=; export $var; }; }; $relink_command" elif eval var_value=\$$var; test -z "$var_value"; then relink_command="$var=; export $var; $relink_command" else func_quote_for_eval "$var_value" relink_command="$var=$func_quote_for_eval_result; export $var; $relink_command" fi done # Quote the link command for shipping. relink_command="(cd `pwd`; $SHELL \"$progpath\" $preserve_args --mode=relink $libtool_args @inst_prefix_dir@)" relink_command=`$ECHO "$relink_command" | $SED "$sed_quote_subst"` if test yes = "$hardcode_automatic"; then relink_command= fi # Only create the output if not a dry run. $opt_dry_run || { for installed in no yes; do if test yes = "$installed"; then if test -z "$install_libdir"; then break fi output=$output_objdir/${outputname}i # Replace all uninstalled libtool libraries with the installed ones newdependency_libs= for deplib in $dependency_libs; do case $deplib in *.la) func_basename "$deplib" name=$func_basename_result func_resolve_sysroot "$deplib" eval libdir=`$SED -n -e 's/^libdir=\(.*\)$/\1/p' $func_resolve_sysroot_result` test -z "$libdir" && \ func_fatal_error "'$deplib' is not a valid libtool archive" func_append newdependency_libs " ${lt_sysroot:+=}$libdir/$name" ;; -L*) func_stripname -L '' "$deplib" func_replace_sysroot "$func_stripname_result" func_append newdependency_libs " -L$func_replace_sysroot_result" ;; -R*) func_stripname -R '' "$deplib" func_replace_sysroot "$func_stripname_result" func_append newdependency_libs " -R$func_replace_sysroot_result" ;; *) func_append newdependency_libs " $deplib" ;; esac done dependency_libs=$newdependency_libs newdlfiles= for lib in $dlfiles; do case $lib in *.la) func_basename "$lib" name=$func_basename_result eval libdir=`$SED -n -e 's/^libdir=\(.*\)$/\1/p' $lib` test -z "$libdir" && \ func_fatal_error "'$lib' is not a valid libtool archive" func_append newdlfiles " ${lt_sysroot:+=}$libdir/$name" ;; *) func_append newdlfiles " $lib" ;; esac done dlfiles=$newdlfiles newdlprefiles= for lib in $dlprefiles; do case $lib in *.la) # Only pass preopened files to the pseudo-archive (for # eventual linking with the app. that links it) if we # didn't already link the preopened objects directly into # the library: func_basename "$lib" name=$func_basename_result eval libdir=`$SED -n -e 's/^libdir=\(.*\)$/\1/p' $lib` test -z "$libdir" && \ func_fatal_error "'$lib' is not a valid libtool archive" func_append newdlprefiles " ${lt_sysroot:+=}$libdir/$name" ;; esac done dlprefiles=$newdlprefiles else newdlfiles= for lib in $dlfiles; do case $lib in [\\/]* | [A-Za-z]:[\\/]*) abs=$lib ;; *) abs=`pwd`"/$lib" ;; esac func_append newdlfiles " $abs" done dlfiles=$newdlfiles newdlprefiles= for lib in $dlprefiles; do case $lib in [\\/]* | [A-Za-z]:[\\/]*) abs=$lib ;; *) abs=`pwd`"/$lib" ;; esac func_append newdlprefiles " $abs" done dlprefiles=$newdlprefiles fi $RM $output # place dlname in correct position for cygwin # In fact, it would be nice if we could use this code for all target # systems that can't hard-code library paths into their executables # and that have no shared library path variable independent of PATH, # but it turns out we can't easily determine that from inspecting # libtool variables, so we have to hard-code the OSs to which it # applies here; at the moment, that means platforms that use the PE # object format with DLL files. See the long comment at the top of # tests/bindir.at for full details. tdlname=$dlname case $host,$output,$installed,$module,$dlname in *cygwin*,*lai,yes,no,*.dll | *mingw*,*lai,yes,no,*.dll | *cegcc*,*lai,yes,no,*.dll) # If a -bindir argument was supplied, place the dll there. if test -n "$bindir"; then func_relative_path "$install_libdir" "$bindir" tdlname=$func_relative_path_result/$dlname else # Otherwise fall back on heuristic. tdlname=../bin/$dlname fi ;; esac $ECHO > $output "\ # $outputname - a libtool library file # Generated by $PROGRAM (GNU $PACKAGE) $VERSION # # Please DO NOT delete this file! # It is necessary for linking the library. # The name that we can dlopen(3). dlname='$tdlname' # Names of this library. library_names='$library_names' # The name of the static archive. old_library='$old_library' # Linker flags that cannot go in dependency_libs. inherited_linker_flags='$new_inherited_linker_flags' # Libraries that this one depends upon. dependency_libs='$dependency_libs' # Names of additional weak libraries provided by this library weak_library_names='$weak_libs' # Version information for $libname. current=$current age=$age revision=$revision # Is this an already installed library? installed=$installed # Should we warn about portability when linking against -modules? shouldnotlink=$module # Files to dlopen/dlpreopen dlopen='$dlfiles' dlpreopen='$dlprefiles' # Directory that this library needs to be installed in: libdir='$install_libdir'" if test no,yes = "$installed,$need_relink"; then $ECHO >> $output "\ relink_command=\"$relink_command\"" fi done } # Do a symbolic link so that the libtool archive can be found in # LD_LIBRARY_PATH before the program is installed. func_show_eval '( cd "$output_objdir" && $RM "$outputname" && $LN_S "../$outputname" "$outputname" )' 'exit $?' ;; esac exit $EXIT_SUCCESS } if test link = "$opt_mode" || test relink = "$opt_mode"; then func_mode_link ${1+"$@"} fi # func_mode_uninstall arg... func_mode_uninstall () { $debug_cmd RM=$nonopt files= rmforce=false exit_status=0 # This variable tells wrapper scripts just to set variables rather # than running their programs. libtool_install_magic=$magic for arg do case $arg in -f) func_append RM " $arg"; rmforce=: ;; -*) func_append RM " $arg" ;; *) func_append files " $arg" ;; esac done test -z "$RM" && \ func_fatal_help "you must specify an RM program" rmdirs= for file in $files; do func_dirname "$file" "" "." dir=$func_dirname_result if test . = "$dir"; then odir=$objdir else odir=$dir/$objdir fi func_basename "$file" name=$func_basename_result test uninstall = "$opt_mode" && odir=$dir # Remember odir for removal later, being careful to avoid duplicates if test clean = "$opt_mode"; then case " $rmdirs " in *" $odir "*) ;; *) func_append rmdirs " $odir" ;; esac fi # Don't error if the file doesn't exist and rm -f was used. if { test -L "$file"; } >/dev/null 2>&1 || { test -h "$file"; } >/dev/null 2>&1 || test -f "$file"; then : elif test -d "$file"; then exit_status=1 continue elif $rmforce; then continue fi rmfiles=$file case $name in *.la) # Possibly a libtool archive, so verify it. if func_lalib_p "$file"; then func_source $dir/$name # Delete the libtool libraries and symlinks. for n in $library_names; do func_append rmfiles " $odir/$n" done test -n "$old_library" && func_append rmfiles " $odir/$old_library" case $opt_mode in clean) case " $library_names " in *" $dlname "*) ;; *) test -n "$dlname" && func_append rmfiles " $odir/$dlname" ;; esac test -n "$libdir" && func_append rmfiles " $odir/$name $odir/${name}i" ;; uninstall) if test -n "$library_names"; then # Do each command in the postuninstall commands. func_execute_cmds "$postuninstall_cmds" '$rmforce || exit_status=1' fi if test -n "$old_library"; then # Do each command in the old_postuninstall commands. func_execute_cmds "$old_postuninstall_cmds" '$rmforce || exit_status=1' fi # FIXME: should reinstall the best remaining shared library. ;; esac fi ;; *.lo) # Possibly a libtool object, so verify it. if func_lalib_p "$file"; then # Read the .lo file func_source $dir/$name # Add PIC object to the list of files to remove. if test -n "$pic_object" && test none != "$pic_object"; then func_append rmfiles " $dir/$pic_object" fi # Add non-PIC object to the list of files to remove. if test -n "$non_pic_object" && test none != "$non_pic_object"; then func_append rmfiles " $dir/$non_pic_object" fi fi ;; *) if test clean = "$opt_mode"; then noexename=$name case $file in *.exe) func_stripname '' '.exe' "$file" file=$func_stripname_result func_stripname '' '.exe' "$name" noexename=$func_stripname_result # $file with .exe has already been added to rmfiles, # add $file without .exe func_append rmfiles " $file" ;; esac # Do a test to see if this is a libtool program. if func_ltwrapper_p "$file"; then if func_ltwrapper_executable_p "$file"; then func_ltwrapper_scriptname "$file" relink_command= func_source $func_ltwrapper_scriptname_result func_append rmfiles " $func_ltwrapper_scriptname_result" else relink_command= func_source $dir/$noexename fi # note $name still contains .exe if it was in $file originally # as does the version of $file that was added into $rmfiles func_append rmfiles " $odir/$name $odir/${name}S.$objext" if test yes = "$fast_install" && test -n "$relink_command"; then func_append rmfiles " $odir/lt-$name" fi if test "X$noexename" != "X$name"; then func_append rmfiles " $odir/lt-$noexename.c" fi fi fi ;; esac func_show_eval "$RM $rmfiles" 'exit_status=1' done # Try to remove the $objdir's in the directories where we deleted files for dir in $rmdirs; do if test -d "$dir"; then func_show_eval "rmdir $dir >/dev/null 2>&1" fi done exit $exit_status } if test uninstall = "$opt_mode" || test clean = "$opt_mode"; then func_mode_uninstall ${1+"$@"} fi test -z "$opt_mode" && { help=$generic_help func_fatal_help "you must specify a MODE" } test -z "$exec_cmd" && \ func_fatal_help "invalid operation mode '$opt_mode'" if test -n "$exec_cmd"; then eval exec "$exec_cmd" exit $EXIT_FAILURE fi exit $exit_status # The TAGs below are defined such that we never get into a situation # where we disable both kinds of libraries. Given conflicting # choices, we go for a static library, that is the most portable, # since we can't tell whether shared libraries were disabled because # the user asked for that or because the platform doesn't support # them. This is particularly important on AIX, because we don't # support having both static and shared libraries enabled at the same # time on that platform, so we default to a shared-only configuration. # If a disable-shared tag is given, we'll fallback to a static-only # configuration. But we'll never go from static-only to shared-only. # ### BEGIN LIBTOOL TAG CONFIG: disable-shared build_libtool_libs=no build_old_libs=yes # ### END LIBTOOL TAG CONFIG: disable-shared # ### BEGIN LIBTOOL TAG CONFIG: disable-static build_old_libs=`case $build_libtool_libs in yes) echo no;; *) echo yes;; esac` # ### END LIBTOOL TAG CONFIG: disable-static # Local Variables: # mode:shell-script # sh-indentation:2 # End: xrdp-0.9.5/libpainter/AUTHORS000644 001751 001751 00000000000 13017426060 015610 0ustar00metameta000000 000000 xrdp-0.9.5/libpainter/compile000755 001751 001751 00000016326 13220730741 016140 0ustar00metameta000000 000000 #! /bin/sh # Wrapper for compilers which do not understand '-c -o'. scriptversion=2016-01-11.22; # UTC # Copyright (C) 1999-2017 Free Software Foundation, Inc. # Written by Tom Tromey . # # 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 2, 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. # # You should have received a copy of the GNU General Public License # along with this program. If not, see . # As a special exception to the GNU General Public License, if you # distribute this file as part of a program that contains a # configuration script generated by Autoconf, you may include it under # the same distribution terms that you use for the rest of that program. # This file is maintained in Automake, please report # bugs to or send patches to # . nl=' ' # We need space, tab and new line, in precisely that order. Quoting is # there to prevent tools from complaining about whitespace usage. IFS=" "" $nl" file_conv= # func_file_conv build_file lazy # Convert a $build file to $host form and store it in $file # Currently only supports Windows hosts. If the determined conversion # type is listed in (the comma separated) LAZY, no conversion will # take place. func_file_conv () { file=$1 case $file in / | /[!/]*) # absolute file, and not a UNC file if test -z "$file_conv"; then # lazily determine how to convert abs files case `uname -s` in MINGW*) file_conv=mingw ;; CYGWIN*) file_conv=cygwin ;; *) file_conv=wine ;; esac fi case $file_conv/,$2, in *,$file_conv,*) ;; mingw/*) file=`cmd //C echo "$file " | sed -e 's/"\(.*\) " *$/\1/'` ;; cygwin/*) file=`cygpath -m "$file" || echo "$file"` ;; wine/*) file=`winepath -w "$file" || echo "$file"` ;; esac ;; esac } # func_cl_dashL linkdir # Make cl look for libraries in LINKDIR func_cl_dashL () { func_file_conv "$1" if test -z "$lib_path"; then lib_path=$file else lib_path="$lib_path;$file" fi linker_opts="$linker_opts -LIBPATH:$file" } # func_cl_dashl library # Do a library search-path lookup for cl func_cl_dashl () { lib=$1 found=no save_IFS=$IFS IFS=';' for dir in $lib_path $LIB do IFS=$save_IFS if $shared && test -f "$dir/$lib.dll.lib"; then found=yes lib=$dir/$lib.dll.lib break fi if test -f "$dir/$lib.lib"; then found=yes lib=$dir/$lib.lib break fi if test -f "$dir/lib$lib.a"; then found=yes lib=$dir/lib$lib.a break fi done IFS=$save_IFS if test "$found" != yes; then lib=$lib.lib fi } # func_cl_wrapper cl arg... # Adjust compile command to suit cl func_cl_wrapper () { # Assume a capable shell lib_path= shared=: linker_opts= for arg do if test -n "$eat"; then eat= else case $1 in -o) # configure might choose to run compile as 'compile cc -o foo foo.c'. eat=1 case $2 in *.o | *.[oO][bB][jJ]) func_file_conv "$2" set x "$@" -Fo"$file" shift ;; *) func_file_conv "$2" set x "$@" -Fe"$file" shift ;; esac ;; -I) eat=1 func_file_conv "$2" mingw set x "$@" -I"$file" shift ;; -I*) func_file_conv "${1#-I}" mingw set x "$@" -I"$file" shift ;; -l) eat=1 func_cl_dashl "$2" set x "$@" "$lib" shift ;; -l*) func_cl_dashl "${1#-l}" set x "$@" "$lib" shift ;; -L) eat=1 func_cl_dashL "$2" ;; -L*) func_cl_dashL "${1#-L}" ;; -static) shared=false ;; -Wl,*) arg=${1#-Wl,} save_ifs="$IFS"; IFS=',' for flag in $arg; do IFS="$save_ifs" linker_opts="$linker_opts $flag" done IFS="$save_ifs" ;; -Xlinker) eat=1 linker_opts="$linker_opts $2" ;; -*) set x "$@" "$1" shift ;; *.cc | *.CC | *.cxx | *.CXX | *.[cC]++) func_file_conv "$1" set x "$@" -Tp"$file" shift ;; *.c | *.cpp | *.CPP | *.lib | *.LIB | *.Lib | *.OBJ | *.obj | *.[oO]) func_file_conv "$1" mingw set x "$@" "$file" shift ;; *) set x "$@" "$1" shift ;; esac fi shift done if test -n "$linker_opts"; then linker_opts="-link$linker_opts" fi exec "$@" $linker_opts exit 1 } eat= case $1 in '') echo "$0: No command. Try '$0 --help' for more information." 1>&2 exit 1; ;; -h | --h*) cat <<\EOF Usage: compile [--help] [--version] PROGRAM [ARGS] Wrapper for compilers which do not understand '-c -o'. Remove '-o dest.o' from ARGS, run PROGRAM with the remaining arguments, and rename the output as expected. If you are trying to build a whole package this is not the right script to run: please start by reading the file 'INSTALL'. Report bugs to . EOF exit $? ;; -v | --v*) echo "compile $scriptversion" exit $? ;; cl | *[/\\]cl | cl.exe | *[/\\]cl.exe | \ icl | *[/\\]icl | icl.exe | *[/\\]icl.exe ) func_cl_wrapper "$@" # Doesn't return... ;; esac ofile= cfile= for arg do if test -n "$eat"; then eat= else case $1 in -o) # configure might choose to run compile as 'compile cc -o foo foo.c'. # So we strip '-o arg' only if arg is an object. eat=1 case $2 in *.o | *.obj) ofile=$2 ;; *) set x "$@" -o "$2" shift ;; esac ;; *.c) cfile=$1 set x "$@" "$1" shift ;; *) set x "$@" "$1" shift ;; esac fi shift done if test -z "$ofile" || test -z "$cfile"; then # If no '-o' option was seen then we might have been invoked from a # pattern rule where we don't need one. That is ok -- this is a # normal compilation that the losing compiler can handle. If no # '.c' file was seen then we are probably linking. That is also # ok. exec "$@" fi # Name of file we expect compiler to create. cofile=`echo "$cfile" | sed 's|^.*[\\/]||; s|^[a-zA-Z]:||; s/\.c$/.o/'` # Create the lock directory. # Note: use '[/\\:.-]' here to ensure that we don't use the same name # that we are using for the .o file. Also, base the name on the expected # object file name, since that is what matters with a parallel build. lockdir=`echo "$cofile" | sed -e 's|[/\\:.-]|_|g'`.d while true; do if mkdir "$lockdir" >/dev/null 2>&1; then break fi sleep 1 done # FIXME: race condition here if user kills between mkdir and trap. trap "rmdir '$lockdir'; exit 1" 1 2 15 # Run the compile. "$@" ret=$? if test -f "$cofile"; then test "$cofile" = "$ofile" || mv "$cofile" "$ofile" elif test -f "${cofile}bj"; then test "${cofile}bj" = "$ofile" || mv "${cofile}bj" "$ofile" fi rmdir "$lockdir" exit $ret # Local Variables: # mode: shell-script # sh-indentation: 2 # eval: (add-hook 'write-file-hooks 'time-stamp) # time-stamp-start: "scriptversion=" # time-stamp-format: "%:y-%02m-%02d.%02H" # time-stamp-time-zone: "UTC0" # time-stamp-end: "; # UTC" # End: xrdp-0.9.5/libpainter/include/Makefile.in000644 001751 001751 00000040266 13220730741 020252 0ustar00metameta000000 000000 # Makefile.in generated by automake 1.15.1 from Makefile.am. # @configure_input@ # Copyright (C) 1994-2017 Free Software Foundation, Inc. # This Makefile.in is free software; the Free Software Foundation # gives unlimited permission to copy and/or distribute it, # with or without modifications, as long as this notice is preserved. # This program is distributed in the hope that it will be useful, # but WITHOUT ANY WARRANTY, to the extent permitted by law; without # even the implied warranty of MERCHANTABILITY or FITNESS FOR A # PARTICULAR PURPOSE. @SET_MAKE@ VPATH = @srcdir@ am__is_gnu_make = { \ if test -z '$(MAKELEVEL)'; then \ false; \ elif test -n '$(MAKE_HOST)'; then \ true; \ elif test -n '$(MAKE_VERSION)' && test -n '$(CURDIR)'; then \ true; \ else \ false; \ fi; \ } am__make_running_with_option = \ case $${target_option-} in \ ?) ;; \ *) echo "am__make_running_with_option: internal error: invalid" \ "target option '$${target_option-}' specified" >&2; \ exit 1;; \ esac; \ has_opt=no; \ sane_makeflags=$$MAKEFLAGS; \ if $(am__is_gnu_make); then \ sane_makeflags=$$MFLAGS; \ else \ case $$MAKEFLAGS in \ *\\[\ \ ]*) \ bs=\\; \ sane_makeflags=`printf '%s\n' "$$MAKEFLAGS" \ | sed "s/$$bs$$bs[$$bs $$bs ]*//g"`;; \ esac; \ fi; \ skip_next=no; \ strip_trailopt () \ { \ flg=`printf '%s\n' "$$flg" | sed "s/$$1.*$$//"`; \ }; \ for flg in $$sane_makeflags; do \ test $$skip_next = yes && { skip_next=no; continue; }; \ case $$flg in \ *=*|--*) continue;; \ -*I) strip_trailopt 'I'; skip_next=yes;; \ -*I?*) strip_trailopt 'I';; \ -*O) strip_trailopt 'O'; skip_next=yes;; \ -*O?*) strip_trailopt 'O';; \ -*l) strip_trailopt 'l'; skip_next=yes;; \ -*l?*) strip_trailopt 'l';; \ -[dEDm]) skip_next=yes;; \ -[JT]) skip_next=yes;; \ esac; \ case $$flg in \ *$$target_option*) has_opt=yes; break;; \ esac; \ done; \ test $$has_opt = yes am__make_dryrun = (target_option=n; $(am__make_running_with_option)) am__make_keepgoing = (target_option=k; $(am__make_running_with_option)) pkgdatadir = $(datadir)/@PACKAGE@ pkgincludedir = $(includedir)/@PACKAGE@ pkglibdir = $(libdir)/@PACKAGE@ pkglibexecdir = $(libexecdir)/@PACKAGE@ am__cd = CDPATH="$${ZSH_VERSION+.}$(PATH_SEPARATOR)" && cd install_sh_DATA = $(install_sh) -c -m 644 install_sh_PROGRAM = $(install_sh) -c install_sh_SCRIPT = $(install_sh) -c INSTALL_HEADER = $(INSTALL_DATA) transform = $(program_transform_name) NORMAL_INSTALL = : PRE_INSTALL = : POST_INSTALL = : NORMAL_UNINSTALL = : PRE_UNINSTALL = : POST_UNINSTALL = : build_triplet = @build@ host_triplet = @host@ subdir = include ACLOCAL_M4 = $(top_srcdir)/aclocal.m4 am__aclocal_m4_deps = $(top_srcdir)/m4/ax_append_compile_flags.m4 \ $(top_srcdir)/m4/ax_append_flag.m4 \ $(top_srcdir)/m4/ax_cflags_warn_all.m4 \ $(top_srcdir)/m4/ax_check_compile_flag.m4 \ $(top_srcdir)/m4/ax_require_defined.m4 \ $(top_srcdir)/m4/libtool.m4 $(top_srcdir)/m4/ltoptions.m4 \ $(top_srcdir)/m4/ltsugar.m4 $(top_srcdir)/m4/ltversion.m4 \ $(top_srcdir)/m4/lt~obsolete.m4 $(top_srcdir)/m4/pkg.m4 \ $(top_srcdir)/configure.ac am__configure_deps = $(am__aclocal_m4_deps) $(CONFIGURE_DEPENDENCIES) \ $(ACLOCAL_M4) DIST_COMMON = $(srcdir)/Makefile.am $(include_HEADERS) \ $(am__DIST_COMMON) mkinstalldirs = $(install_sh) -d CONFIG_HEADER = $(top_builddir)/config_ac.h CONFIG_CLEAN_FILES = CONFIG_CLEAN_VPATH_FILES = AM_V_P = $(am__v_P_@AM_V@) am__v_P_ = $(am__v_P_@AM_DEFAULT_V@) am__v_P_0 = false am__v_P_1 = : AM_V_GEN = $(am__v_GEN_@AM_V@) am__v_GEN_ = $(am__v_GEN_@AM_DEFAULT_V@) am__v_GEN_0 = @echo " GEN " $@; am__v_GEN_1 = AM_V_at = $(am__v_at_@AM_V@) am__v_at_ = $(am__v_at_@AM_DEFAULT_V@) am__v_at_0 = @ am__v_at_1 = SOURCES = DIST_SOURCES = am__can_run_installinfo = \ case $$AM_UPDATE_INFO_DIR in \ n|no|NO) false;; \ *) (install-info --version) >/dev/null 2>&1;; \ esac am__vpath_adj_setup = srcdirstrip=`echo "$(srcdir)" | sed 's|.|.|g'`; am__vpath_adj = case $$p in \ $(srcdir)/*) f=`echo "$$p" | sed "s|^$$srcdirstrip/||"`;; \ *) f=$$p;; \ esac; am__strip_dir = f=`echo $$p | sed -e 's|^.*/||'`; am__install_max = 40 am__nobase_strip_setup = \ srcdirstrip=`echo "$(srcdir)" | sed 's/[].[^$$\\*|]/\\\\&/g'` am__nobase_strip = \ for p in $$list; do echo "$$p"; done | sed -e "s|$$srcdirstrip/||" am__nobase_list = $(am__nobase_strip_setup); \ for p in $$list; do echo "$$p $$p"; done | \ sed "s| $$srcdirstrip/| |;"' / .*\//!s/ .*/ ./; s,\( .*\)/[^/]*$$,\1,' | \ $(AWK) 'BEGIN { files["."] = "" } { files[$$2] = files[$$2] " " $$1; \ if (++n[$$2] == $(am__install_max)) \ { print $$2, files[$$2]; n[$$2] = 0; files[$$2] = "" } } \ END { for (dir in files) print dir, files[dir] }' am__base_list = \ sed '$$!N;$$!N;$$!N;$$!N;$$!N;$$!N;$$!N;s/\n/ /g' | \ sed '$$!N;$$!N;$$!N;$$!N;s/\n/ /g' am__uninstall_files_from_dir = { \ test -z "$$files" \ || { test ! -d "$$dir" && test ! -f "$$dir" && test ! -r "$$dir"; } \ || { echo " ( cd '$$dir' && rm -f" $$files ")"; \ $(am__cd) "$$dir" && rm -f $$files; }; \ } am__installdirs = "$(DESTDIR)$(includedir)" HEADERS = $(include_HEADERS) am__tagged_files = $(HEADERS) $(SOURCES) $(TAGS_FILES) $(LISP) # Read a list of newline-separated strings from the standard input, # and print each of them once, without duplicates. Input order is # *not* preserved. am__uniquify_input = $(AWK) '\ BEGIN { nonempty = 0; } \ { items[$$0] = 1; nonempty = 1; } \ END { if (nonempty) { for (i in items) print i; }; } \ ' # Make sure the list of sources is unique. This is necessary because, # e.g., the same source file might be shared among _SOURCES variables # for different programs/libraries. am__define_uniq_tagged_files = \ list='$(am__tagged_files)'; \ unique=`for i in $$list; do \ if test -f "$$i"; then echo $$i; else echo $(srcdir)/$$i; fi; \ done | $(am__uniquify_input)` ETAGS = etags CTAGS = ctags am__DIST_COMMON = $(srcdir)/Makefile.in DISTFILES = $(DIST_COMMON) $(DIST_SOURCES) $(TEXINFOS) $(EXTRA_DIST) ACLOCAL = @ACLOCAL@ AMTAR = @AMTAR@ AM_DEFAULT_VERBOSITY = @AM_DEFAULT_VERBOSITY@ AR = @AR@ AUTOCONF = @AUTOCONF@ AUTOHEADER = @AUTOHEADER@ AUTOMAKE = @AUTOMAKE@ AWK = @AWK@ CC = @CC@ CCDEPMODE = @CCDEPMODE@ CFLAGS = @CFLAGS@ CPP = @CPP@ CPPFLAGS = @CPPFLAGS@ CYGPATH_W = @CYGPATH_W@ DEFS = @DEFS@ DEPDIR = @DEPDIR@ DLLTOOL = @DLLTOOL@ DSYMUTIL = @DSYMUTIL@ DUMPBIN = @DUMPBIN@ ECHO_C = @ECHO_C@ ECHO_N = @ECHO_N@ ECHO_T = @ECHO_T@ EGREP = @EGREP@ EXEEXT = @EXEEXT@ FGREP = @FGREP@ GREP = @GREP@ INSTALL = @INSTALL@ INSTALL_DATA = @INSTALL_DATA@ INSTALL_PROGRAM = @INSTALL_PROGRAM@ INSTALL_SCRIPT = @INSTALL_SCRIPT@ INSTALL_STRIP_PROGRAM = @INSTALL_STRIP_PROGRAM@ LD = @LD@ LDFLAGS = @LDFLAGS@ LIBOBJS = @LIBOBJS@ LIBS = @LIBS@ LIBTOOL = @LIBTOOL@ LIPO = @LIPO@ LN_S = @LN_S@ LTLIBOBJS = @LTLIBOBJS@ LT_SYS_LIBRARY_PATH = @LT_SYS_LIBRARY_PATH@ MAKEINFO = @MAKEINFO@ MANIFEST_TOOL = @MANIFEST_TOOL@ MKDIR_P = @MKDIR_P@ NM = @NM@ NMEDIT = @NMEDIT@ OBJDUMP = @OBJDUMP@ OBJEXT = @OBJEXT@ OTOOL = @OTOOL@ OTOOL64 = @OTOOL64@ PACKAGE = @PACKAGE@ PACKAGE_BUGREPORT = @PACKAGE_BUGREPORT@ PACKAGE_NAME = @PACKAGE_NAME@ PACKAGE_STRING = @PACKAGE_STRING@ PACKAGE_TARNAME = @PACKAGE_TARNAME@ PACKAGE_URL = @PACKAGE_URL@ PACKAGE_VERSION = @PACKAGE_VERSION@ PATH_SEPARATOR = @PATH_SEPARATOR@ RANLIB = @RANLIB@ SED = @SED@ SET_MAKE = @SET_MAKE@ SHELL = @SHELL@ STRIP = @STRIP@ VERSION = @VERSION@ abs_builddir = @abs_builddir@ abs_srcdir = @abs_srcdir@ abs_top_builddir = @abs_top_builddir@ abs_top_srcdir = @abs_top_srcdir@ ac_ct_AR = @ac_ct_AR@ ac_ct_CC = @ac_ct_CC@ ac_ct_DUMPBIN = @ac_ct_DUMPBIN@ am__include = @am__include@ am__leading_dot = @am__leading_dot@ am__quote = @am__quote@ am__tar = @am__tar@ am__untar = @am__untar@ bindir = @bindir@ build = @build@ build_alias = @build_alias@ build_cpu = @build_cpu@ build_os = @build_os@ build_vendor = @build_vendor@ builddir = @builddir@ datadir = @datadir@ datarootdir = @datarootdir@ docdir = @docdir@ dvidir = @dvidir@ exec_prefix = @exec_prefix@ host = @host@ host_alias = @host_alias@ host_cpu = @host_cpu@ host_os = @host_os@ host_vendor = @host_vendor@ htmldir = @htmldir@ includedir = @includedir@ infodir = @infodir@ install_sh = @install_sh@ libdir = @libdir@ libexecdir = @libexecdir@ localedir = @localedir@ localstatedir = @localstatedir@ mandir = @mandir@ mkdir_p = @mkdir_p@ oldincludedir = @oldincludedir@ pdfdir = @pdfdir@ pkgconfigdir = @pkgconfigdir@ prefix = @prefix@ program_transform_name = @program_transform_name@ psdir = @psdir@ sbindir = @sbindir@ sharedstatedir = @sharedstatedir@ srcdir = @srcdir@ sysconfdir = @sysconfdir@ target_alias = @target_alias@ top_build_prefix = @top_build_prefix@ top_builddir = @top_builddir@ top_srcdir = @top_srcdir@ EXTRA_DIST = include_HEADERS = painter.h all: all-am .SUFFIXES: $(srcdir)/Makefile.in: $(srcdir)/Makefile.am $(am__configure_deps) @for dep in $?; do \ case '$(am__configure_deps)' in \ *$$dep*) \ ( cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh ) \ && { if test -f $@; then exit 0; else break; fi; }; \ exit 1;; \ esac; \ done; \ echo ' cd $(top_srcdir) && $(AUTOMAKE) --foreign include/Makefile'; \ $(am__cd) $(top_srcdir) && \ $(AUTOMAKE) --foreign include/Makefile Makefile: $(srcdir)/Makefile.in $(top_builddir)/config.status @case '$?' in \ *config.status*) \ cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh;; \ *) \ echo ' cd $(top_builddir) && $(SHELL) ./config.status $(subdir)/$@ $(am__depfiles_maybe)'; \ cd $(top_builddir) && $(SHELL) ./config.status $(subdir)/$@ $(am__depfiles_maybe);; \ esac; $(top_builddir)/config.status: $(top_srcdir)/configure $(CONFIG_STATUS_DEPENDENCIES) cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh $(top_srcdir)/configure: $(am__configure_deps) cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh $(ACLOCAL_M4): $(am__aclocal_m4_deps) cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh $(am__aclocal_m4_deps): mostlyclean-libtool: -rm -f *.lo clean-libtool: -rm -rf .libs _libs install-includeHEADERS: $(include_HEADERS) @$(NORMAL_INSTALL) @list='$(include_HEADERS)'; test -n "$(includedir)" || list=; \ if test -n "$$list"; then \ echo " $(MKDIR_P) '$(DESTDIR)$(includedir)'"; \ $(MKDIR_P) "$(DESTDIR)$(includedir)" || exit 1; \ fi; \ for p in $$list; do \ if test -f "$$p"; then d=; else d="$(srcdir)/"; fi; \ echo "$$d$$p"; \ done | $(am__base_list) | \ while read files; do \ echo " $(INSTALL_HEADER) $$files '$(DESTDIR)$(includedir)'"; \ $(INSTALL_HEADER) $$files "$(DESTDIR)$(includedir)" || exit $$?; \ done uninstall-includeHEADERS: @$(NORMAL_UNINSTALL) @list='$(include_HEADERS)'; test -n "$(includedir)" || list=; \ files=`for p in $$list; do echo $$p; done | sed -e 's|^.*/||'`; \ dir='$(DESTDIR)$(includedir)'; $(am__uninstall_files_from_dir) ID: $(am__tagged_files) $(am__define_uniq_tagged_files); mkid -fID $$unique tags: tags-am TAGS: tags tags-am: $(TAGS_DEPENDENCIES) $(am__tagged_files) set x; \ here=`pwd`; \ $(am__define_uniq_tagged_files); \ shift; \ if test -z "$(ETAGS_ARGS)$$*$$unique"; then :; else \ test -n "$$unique" || unique=$$empty_fix; \ if test $$# -gt 0; then \ $(ETAGS) $(ETAGSFLAGS) $(AM_ETAGSFLAGS) $(ETAGS_ARGS) \ "$$@" $$unique; \ else \ $(ETAGS) $(ETAGSFLAGS) $(AM_ETAGSFLAGS) $(ETAGS_ARGS) \ $$unique; \ fi; \ fi ctags: ctags-am CTAGS: ctags ctags-am: $(TAGS_DEPENDENCIES) $(am__tagged_files) $(am__define_uniq_tagged_files); \ test -z "$(CTAGS_ARGS)$$unique" \ || $(CTAGS) $(CTAGSFLAGS) $(AM_CTAGSFLAGS) $(CTAGS_ARGS) \ $$unique GTAGS: here=`$(am__cd) $(top_builddir) && pwd` \ && $(am__cd) $(top_srcdir) \ && gtags -i $(GTAGS_ARGS) "$$here" cscopelist: cscopelist-am cscopelist-am: $(am__tagged_files) list='$(am__tagged_files)'; \ case "$(srcdir)" in \ [\\/]* | ?:[\\/]*) sdir="$(srcdir)" ;; \ *) sdir=$(subdir)/$(srcdir) ;; \ esac; \ for i in $$list; do \ if test -f "$$i"; then \ echo "$(subdir)/$$i"; \ else \ echo "$$sdir/$$i"; \ fi; \ done >> $(top_builddir)/cscope.files distclean-tags: -rm -f TAGS ID GTAGS GRTAGS GSYMS GPATH tags distdir: $(DISTFILES) @srcdirstrip=`echo "$(srcdir)" | sed 's/[].[^$$\\*]/\\\\&/g'`; \ topsrcdirstrip=`echo "$(top_srcdir)" | sed 's/[].[^$$\\*]/\\\\&/g'`; \ list='$(DISTFILES)'; \ dist_files=`for file in $$list; do echo $$file; done | \ sed -e "s|^$$srcdirstrip/||;t" \ -e "s|^$$topsrcdirstrip/|$(top_builddir)/|;t"`; \ case $$dist_files in \ */*) $(MKDIR_P) `echo "$$dist_files" | \ sed '/\//!d;s|^|$(distdir)/|;s,/[^/]*$$,,' | \ sort -u` ;; \ esac; \ for file in $$dist_files; do \ if test -f $$file || test -d $$file; then d=.; else d=$(srcdir); fi; \ if test -d $$d/$$file; then \ dir=`echo "/$$file" | sed -e 's,/[^/]*$$,,'`; \ if test -d "$(distdir)/$$file"; then \ find "$(distdir)/$$file" -type d ! -perm -700 -exec chmod u+rwx {} \;; \ fi; \ if test -d $(srcdir)/$$file && test $$d != $(srcdir); then \ cp -fpR $(srcdir)/$$file "$(distdir)$$dir" || exit 1; \ find "$(distdir)/$$file" -type d ! -perm -700 -exec chmod u+rwx {} \;; \ fi; \ cp -fpR $$d/$$file "$(distdir)$$dir" || exit 1; \ else \ test -f "$(distdir)/$$file" \ || cp -p $$d/$$file "$(distdir)/$$file" \ || exit 1; \ fi; \ done check-am: all-am check: check-am all-am: Makefile $(HEADERS) installdirs: for dir in "$(DESTDIR)$(includedir)"; do \ test -z "$$dir" || $(MKDIR_P) "$$dir"; \ done install: install-am install-exec: install-exec-am install-data: install-data-am uninstall: uninstall-am install-am: all-am @$(MAKE) $(AM_MAKEFLAGS) install-exec-am install-data-am installcheck: installcheck-am install-strip: if test -z '$(STRIP)'; then \ $(MAKE) $(AM_MAKEFLAGS) INSTALL_PROGRAM="$(INSTALL_STRIP_PROGRAM)" \ install_sh_PROGRAM="$(INSTALL_STRIP_PROGRAM)" INSTALL_STRIP_FLAG=-s \ install; \ else \ $(MAKE) $(AM_MAKEFLAGS) INSTALL_PROGRAM="$(INSTALL_STRIP_PROGRAM)" \ install_sh_PROGRAM="$(INSTALL_STRIP_PROGRAM)" INSTALL_STRIP_FLAG=-s \ "INSTALL_PROGRAM_ENV=STRIPPROG='$(STRIP)'" install; \ fi mostlyclean-generic: clean-generic: distclean-generic: -test -z "$(CONFIG_CLEAN_FILES)" || rm -f $(CONFIG_CLEAN_FILES) -test . = "$(srcdir)" || test -z "$(CONFIG_CLEAN_VPATH_FILES)" || rm -f $(CONFIG_CLEAN_VPATH_FILES) maintainer-clean-generic: @echo "This command is intended for maintainers to use" @echo "it deletes files that may require special tools to rebuild." clean: clean-am clean-am: clean-generic clean-libtool mostlyclean-am distclean: distclean-am -rm -f Makefile distclean-am: clean-am distclean-generic distclean-tags dvi: dvi-am dvi-am: html: html-am html-am: info: info-am info-am: install-data-am: install-includeHEADERS install-dvi: install-dvi-am install-dvi-am: install-exec-am: install-html: install-html-am install-html-am: install-info: install-info-am install-info-am: install-man: install-pdf: install-pdf-am install-pdf-am: install-ps: install-ps-am install-ps-am: installcheck-am: maintainer-clean: maintainer-clean-am -rm -f Makefile maintainer-clean-am: distclean-am maintainer-clean-generic mostlyclean: mostlyclean-am mostlyclean-am: mostlyclean-generic mostlyclean-libtool pdf: pdf-am pdf-am: ps: ps-am ps-am: uninstall-am: uninstall-includeHEADERS .MAKE: install-am install-strip .PHONY: CTAGS GTAGS TAGS all all-am check check-am clean clean-generic \ clean-libtool cscopelist-am ctags ctags-am distclean \ distclean-generic distclean-libtool distclean-tags distdir dvi \ dvi-am html html-am info info-am install install-am \ install-data install-data-am install-dvi install-dvi-am \ install-exec install-exec-am install-html install-html-am \ install-includeHEADERS install-info install-info-am \ install-man install-pdf install-pdf-am install-ps \ install-ps-am install-strip installcheck installcheck-am \ installdirs maintainer-clean maintainer-clean-generic \ mostlyclean mostlyclean-generic mostlyclean-libtool pdf pdf-am \ ps ps-am tags tags-am uninstall uninstall-am \ uninstall-includeHEADERS .PRECIOUS: Makefile # Tell versions [3.59,3.63) of GNU make to not export all variables. # Otherwise a system limit (for SysV at least) may be exceeded. .NOEXPORT: xrdp-0.9.5/libpainter/include/painter.h000644 001751 001751 00000007664 13035113356 020026 0ustar00metameta000000 000000 /** * painter main header * * Copyright 2015-2016 Jay Sorg * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ #if !defined(__PAINTER_H) #define __PAINTER_H #define LIBPAINTER_VERSION_MAJOR 0 #define LIBPAINTER_VERSION_MINOR 1 #define LIBPAINTER_VERSION_MICRO 0 #define PT_FORMAT_a8b8g8r8 \ ((32 << 24) | (3 << 16) | (8 << 12) | (8 << 8) | (8 << 4) | 8) #define PT_FORMAT_a8r8g8b8 \ ((32 << 24) | (2 << 16) | (8 << 12) | (8 << 8) | (8 << 4) | 8) #define PT_FORMAT_r5g6b5 \ ((16 << 24) | (2 << 16) | (0 << 12) | (5 << 8) | (6 << 4) | 5) #define PT_FORMAT_a1r5g5b5 \ ((16 << 24) | (2 << 16) | (1 << 12) | (5 << 8) | (5 << 4) | 5) #define PT_FORMAT_r3g3b2 \ ((8 << 24) | (2 << 16) | (0 << 12) | (3 << 8) | (3 << 4) | 2) #define PT_FORMAT_c1 \ ((1 << 24) | (4 << 16) | (0 << 12) | (0 << 8) | (0 << 4) | 0) #define PT_FORMAT_c8 \ ((8 << 24) | (4 << 16) | (0 << 12) | (0 << 8) | (0 << 4) | 0) struct painter_bitmap { int format; int width; int stride_bytes; int height; char *data; }; #define PT_ERROR_NONE 0 #define PT_ERROR_OUT_OF_MEM 1 #define PT_ERROR_PARAM 2 #define PT_ERROR_NOT_IMP 3 #define PT_PATTERN_MODE_NORMAL 0 #define PT_PATTERN_MODE_OPAQUE 1 #define PT_LINE_FLAGS_NONE 0 /* reverse Windows X11 */ /* polish */ #define PT_ROP_0 0x00 /* 0 BLACKNESS GXclear */ #define PT_ROP_DSon 0x11 /* DSon NOTSRCERASE GXnor */ #define PT_ROP_DSna 0x22 /* DSna GXandInverted */ #define PT_ROP_Sn 0x33 /* Sn NOTSRCCOPY GXcopyInverted */ #define PT_ROP_SDna 0x44 /* SDna SRCERASE GXandReverse */ #define PT_ROP_Dn 0x55 /* Dn DSTINVERT GXinvert */ #define PT_ROP_DSx 0x66 /* DSx SRCINVERT GXxor */ #define PT_ROP_DSan 0x77 /* DSan GXnand */ #define PT_ROP_DSa 0x88 /* DSa SRCAND GXand */ #define PT_ROP_DSxn 0x99 /* DSxn GXequiv */ #define PT_ROP_D 0xAA /* D GXnoop */ #define PT_ROP_DSno 0xBB /* DSno MERGEPAINT GXorInverted */ #define PT_ROP_S 0xCC /* S SRCCOPY GXcopy */ #define PT_ROP_SDno 0xDD /* SDno GXorReverse */ #define PT_ROP_DSo 0xEE /* DSo GXor */ #define PT_ROP_1 0xFF /* 1 WHITENESS GXset */ int painter_create(void **handle); int painter_delete(void *handle); int painter_set_fgcolor(void *handle, int color); int painter_set_bgcolor(void *handle, int color); int painter_set_rop(void *handle, int rop); int painter_set_pattern_mode(void *handle, int mode); int painter_set_pattern_origin(void *handle, int x, int y); int painter_set_clip(void *handle, int x, int y, int cx, int cy); int painter_clear_clip(void *handle); int painter_fill_rect(void *handle, struct painter_bitmap *dst, int x, int y, int cx, int cy); int painter_fill_pattern(void *handle, struct painter_bitmap *dst, struct painter_bitmap *pat, int patx, int paty, int x, int y, int cx, int cy); int painter_copy(void *handle, struct painter_bitmap *dst, int x, int y, int cx, int cy, struct painter_bitmap *src, int srcx, int srcy); int painter_line(void *handle, struct painter_bitmap *dst, int x1, int y1, int x2, int y2, int width, int flags); int painter_get_version(int *major, int *minor, int *micro); #endif xrdp-0.9.5/libpainter/include/Makefile.am000644 001751 001751 00000000053 13035113356 020230 0ustar00metameta000000 000000 EXTRA_DIST = include_HEADERS = painter.h xrdp-0.9.5/libpainter/src/painter.c000644 001751 001751 00000026426 13061652764 017174 0ustar00metameta000000 000000 /** * painter main * * Copyright 2015-2016 Jay Sorg * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ #if defined(HAVE_CONFIG_H) #include #endif #include #include #include #include "painter.h" #include "painter_utils.h" /*****************************************************************************/ int painter_create(void **handle) { struct painter *pt; if (handle == NULL) { return PT_ERROR_PARAM; } *handle = calloc(1, sizeof(struct painter)); if (*handle == NULL) { return PT_ERROR_OUT_OF_MEM; } pt = (struct painter *) *handle; pt->rop = PT_ROP_S; return PT_ERROR_NONE; } /*****************************************************************************/ int painter_delete(void *handle) { if (handle == NULL) { return PT_ERROR_NONE; } free(handle); return PT_ERROR_NONE; } /*****************************************************************************/ int painter_set_fgcolor(void *handle, int color) { struct painter *pt; pt = (struct painter *) handle; pt->fgcolor = color; return PT_ERROR_NONE; } /*****************************************************************************/ int painter_set_bgcolor(void *handle, int color) { struct painter *pt; pt = (struct painter *) handle; pt->bgcolor = color; return PT_ERROR_NONE; } /*****************************************************************************/ int painter_set_rop(void *handle, int rop) { struct painter *pt; pt = (struct painter *) handle; pt->rop = rop; return PT_ERROR_NONE; } /*****************************************************************************/ int painter_set_pattern_mode(void *handle, int mode) { struct painter *pt; pt = (struct painter *) handle; pt->pattern_mode = mode; return PT_ERROR_NONE; } /*****************************************************************************/ int painter_set_pattern_origin(void *handle, int x, int y) { struct painter *pt; pt = (struct painter *) handle; pt->origin_x = x; pt->origin_y = y; return PT_ERROR_NONE; } /*****************************************************************************/ int painter_set_clip(void *handle, int x, int y, int cx, int cy) { struct painter *pt; pt = (struct painter *) handle; pt->clip.x1 = x; pt->clip.y1 = y; pt->clip.x2 = x + cx; pt->clip.y2 = y + cy; pt->clip_valid = 1; return PT_ERROR_NONE; } /*****************************************************************************/ int painter_clear_clip(void *handle) { struct painter *pt; pt = (struct painter *) handle; pt->clip_valid = 0; return PT_ERROR_NONE; } /*****************************************************************************/ int painter_fill_rect(void *handle, struct painter_bitmap *dst, int x, int y, int cx, int cy) { int index; int jndex; int bpp; int *dst32; short *dst16; struct painter *pt; pt = (struct painter *) handle; if (pt->rop == PT_ROP_S) { if (painter_warp_coords(pt, &x, &y, &cx, &cy, NULL, NULL)) { bpp = dst->format >> 24; if (bpp == 32) { for (jndex = 0; jndex < cy; jndex++) { dst32 = (int *) bitmap_get_ptr(dst, x, y + jndex); if (dst32 != NULL) { for (index = 0; index < cx; index++) { *(dst32++) = pt->fgcolor; } } } return PT_ERROR_NONE; } else if (bpp == 16) { for (jndex = 0; jndex < cy; jndex++) { dst16 = (short *) bitmap_get_ptr(dst, x, y + jndex); if (dst16 != NULL) { for (index = 0; index < cx; index++) { *(dst16++) = pt->fgcolor; } } } return PT_ERROR_NONE; } } } for (jndex = 0; jndex < cy; jndex++) { for (index = 0; index < cx; index++) { painter_set_pixel(pt, dst, x + index, y + jndex, pt->fgcolor, dst->format); } } return PT_ERROR_NONE; } /*****************************************************************************/ int painter_fill_pattern(void *handle, struct painter_bitmap *dst, struct painter_bitmap *pat, int patx, int paty, int x, int y, int cx, int cy) { int index; int jndex; int pixel; int lx; int ly; struct painter *pt; pt = (struct painter *) handle; if (pt->pattern_mode == PT_PATTERN_MODE_OPAQUE) { for (jndex = 0; jndex < cy; jndex++) { for (index = 0; index < cx; index++) { lx = (patx + index + pt->origin_x) % pat->width; ly = (paty + jndex + pt->origin_y) % pat->height; pixel = bitmap_get_pixel(pat, lx, ly); if (pixel != 0) { painter_set_pixel(pt, dst, x + index, y + jndex, pt->fgcolor, dst->format); } else { painter_set_pixel(pt, dst, x + index, y + jndex, pt->bgcolor, dst->format); } } } } else { for (jndex = 0; jndex < cy; jndex++) { for (index = 0; index < cx; index++) { lx = (patx + index + pt->origin_x) % pat->width; ly = (paty + jndex + pt->origin_y) % pat->height; pixel = bitmap_get_pixel(pat, lx, ly); if (pixel != 0) { painter_set_pixel(pt, dst, x + index, y + jndex, pt->fgcolor, dst->format); } } } } return PT_ERROR_NONE; } /*****************************************************************************/ int painter_copy(void *handle, struct painter_bitmap *dst, int x, int y, int cx, int cy, struct painter_bitmap *src, int srcx, int srcy) { int index; int jndex; int pixel; int bpp; struct painter *pt; char *src_ptr; char *dst_ptr; pt = (struct painter *) handle; if (pt->rop == PT_ROP_S) { if (src->format == dst->format) { bpp = src->format >> 24; if (painter_warp_coords(pt, &x, &y, &cx, &cy, &srcx, &srcy)) { /* straight right or down */ if ((srcy < y) || ((srcy == y) && (srcx < x))) { for (jndex = cy - 1; jndex >= 0; jndex--) { dst_ptr = bitmap_get_ptr(dst, x, y + jndex); src_ptr = bitmap_get_ptr(src, srcx, srcy + jndex); if ((src_ptr != NULL) && (dst_ptr != NULL)) { memmove(dst_ptr, src_ptr, cx * (bpp / 8)); } } } else { for (jndex = 0; jndex < cy; jndex++) { dst_ptr = bitmap_get_ptr(dst, x, y + jndex); src_ptr = bitmap_get_ptr(src, srcx, srcy + jndex); if ((src_ptr != NULL) && (dst_ptr != NULL)) { memcpy(dst_ptr, src_ptr, cx * (bpp / 8)); } } } } return PT_ERROR_NONE; } } /* straight right or down */ if ((srcy < y) || ((srcy == y) && (srcx < x))) { for (jndex = cy - 1; jndex >= 0; jndex--) { for (index = cx - 1; index >= 0; index--) { pixel = painter_get_pixel(pt, src, srcx + index, srcy + jndex); painter_set_pixel(pt, dst, x + index, y + jndex, pixel, src->format); } } } else { for (jndex = 0; jndex < cy; jndex++) { for (index = 0; index < cx; index++) { pixel = painter_get_pixel(pt, src, srcx + index, srcy + jndex); painter_set_pixel(pt, dst, x + index, y + jndex, pixel, src->format); } } } return PT_ERROR_NONE; } /*****************************************************************************/ /* Bresenham's line drawing algorithm */ int painter_line(void *handle, struct painter_bitmap *dst, int x1, int y1, int x2, int y2, int width, int flags) { int dx; int dy; int incx; int incy; int dpr; int dpru; int p; struct painter *pt; pt = (struct painter *) handle; if (x1 > x2) { dx = x1 - x2; incx = -1; } else { dx = x2 - x1; incx = 1; } if (y1 > y2) { dy = y1 - y2; incy = -1; } else { dy = y2 - y1; incy = 1; } if (dx >= dy) { dpr = dy << 1; dpru = dpr - (dx << 1); p = dpr - dx; for (; dx >= 0; dx--) { if (x1 != x2 || y1 != y2) { painter_set_pixel(pt, dst, x1, y1, pt->fgcolor, dst->format); } if (p > 0) { x1 += incx; y1 += incy; p += dpru; } else { x1 += incx; p += dpr; } } } else { dpr = dx << 1; dpru = dpr - (dy << 1); p = dpr - dy; for (; dy >= 0; dy--) { if (x1 != x2 || y1 != y2) { painter_set_pixel(pt, dst, x1, y1, pt->fgcolor, dst->format); } if (p > 0) { x1 += incx; y1 += incy; p += dpru; } else { y1 += incy; p += dpr; } } } return PT_ERROR_NONE; } /*****************************************************************************/ int painter_get_version(int *major, int *minor, int *micro) { *major = LIBPAINTER_VERSION_MAJOR; *minor = LIBPAINTER_VERSION_MINOR; *micro = LIBPAINTER_VERSION_MICRO; return 0; } xrdp-0.9.5/libpainter/src/painter_utils.h000644 001751 001751 00000006717 12772745511 020423 0ustar00metameta000000 000000 /** * painter utils header * * Copyright 2015-2016 Jay Sorg * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ #if !defined(__PAINTER_UTILS_H) #define __PAINTER_UTILS_H #define SPLIT_a8r8g8b8(_c, _a, _r, _g, _b) \ do { \ _a = ((_c) & 0xff000000) >> 24; \ _r = ((_c) & 0x00ff0000) >> 16; \ _g = ((_c) & 0x0000ff00) >> 8; \ _b = ((_c) & 0x000000ff) >> 0; \ } while (0) #define SPLIT_a8b8g8r8(_c, _a, _r, _g, _b) \ do { \ _a = ((_c) & 0xff000000) >> 24; \ _b = ((_c) & 0x00ff0000) >> 16; \ _g = ((_c) & 0x0000ff00) >> 8; \ _r = ((_c) & 0x000000ff) >> 0; \ } while (0) #define SPLIT_a1r5g5b5(_c, _a, _r, _g, _b) \ do { \ _a = (((_c) >> 15) & 1) * 0xff; \ _r = (((_c) >> 7) & 0xf8) | (((_c) >> 12) & 0x7); \ _g = (((_c) >> 2) & 0xf8) | (((_c) >> 8) & 0x7); \ _b = (((_c) << 3) & 0xf8) | (((_c) >> 2) & 0x7); \ } while (0) #define SPLIT_r5g6b5(_c, _a, _r, _g, _b) \ do { \ _a = 0xff; \ _r = (((_c) >> 8) & 0xf8) | (((_c) >> 13) & 0x7); \ _g = (((_c) >> 3) & 0xfc) | (((_c) >> 9) & 0x3); \ _b = (((_c) << 3) & 0xf8) | (((_c) >> 2) & 0x7); \ } while (0) #define SPLIT_r3g3b2(_c, _a, _r, _g, _b) \ do { \ _a = 0xff; \ _r = 0; \ _g = 0; \ _b = 0; \ } while (0) #define MAKE_a1r5g5b5(_c, _a, _r, _g, _b) \ do { \ _c = (((_a) & 0xff) >> 7) << 15 | \ (((_r) & 0xff) >> 3) << 10 | \ (((_g) & 0xff) >> 3) << 5 | \ (((_b) & 0xff) >> 3) << 0; \ } while (0) #define MAKE_r5g6b5(_c, _a, _r, _g, _b) \ do { \ _c = \ (((_r) & 0xff) >> 3) << 11 | \ (((_g) & 0xff) >> 2) << 5 | \ (((_b) & 0xff) >> 3) << 0; \ } while (0) #define MAKE_a8r8g8b8(_c, _a, _r, _g, _b) \ do { \ _c = ((_a) & 0xff) << 24 | \ ((_r) & 0xff) << 16 | \ ((_g) & 0xff) << 8 | \ ((_b) & 0xff) << 0; \ } while (0) #define MAKE_a8b8g8r8(_c, _a, _r, _g, _b) \ do { \ _c = ((_a) & 0xff) << 24 | \ ((_b) & 0xff) << 16 | \ ((_g) & 0xff) << 8 | \ ((_r) & 0xff) << 0; \ } while (0) struct painter_rect { short x1; short y1; short x2; short y2; }; struct painter { int rop; int fgcolor; int bgcolor; int pattern_mode; int clip_valid; int pad0; struct painter_rect clip; int origin_x; int origin_y; int palette[256]; }; int painter_rop(int rop, int src, int dst); int painter_get_pixel(struct painter *painter, struct painter_bitmap *bitmap, int x, int y); int painter_set_pixel(struct painter *painter, struct painter_bitmap *dst, int x, int y, int pixel, int pixel_format); int painter_warp_coords(struct painter *painter, int *x, int *y, int *cx, int *cy, int *srcx, int *srcy); char * bitmap_get_ptr(struct painter_bitmap *bitmap, int x, int y); int bitmap_get_pixel(struct painter_bitmap *bitmap, int x, int y); int bitmap_set_pixel(struct painter_bitmap *bitmap, int x, int y, int pixel); #endif xrdp-0.9.5/libpainter/src/Makefile.in000644 001751 001751 00000050271 13220730741 017413 0ustar00metameta000000 000000 # Makefile.in generated by automake 1.15.1 from Makefile.am. # @configure_input@ # Copyright (C) 1994-2017 Free Software Foundation, Inc. # This Makefile.in is free software; the Free Software Foundation # gives unlimited permission to copy and/or distribute it, # with or without modifications, as long as this notice is preserved. # This program is distributed in the hope that it will be useful, # but WITHOUT ANY WARRANTY, to the extent permitted by law; without # even the implied warranty of MERCHANTABILITY or FITNESS FOR A # PARTICULAR PURPOSE. @SET_MAKE@ VPATH = @srcdir@ am__is_gnu_make = { \ if test -z '$(MAKELEVEL)'; then \ false; \ elif test -n '$(MAKE_HOST)'; then \ true; \ elif test -n '$(MAKE_VERSION)' && test -n '$(CURDIR)'; then \ true; \ else \ false; \ fi; \ } am__make_running_with_option = \ case $${target_option-} in \ ?) ;; \ *) echo "am__make_running_with_option: internal error: invalid" \ "target option '$${target_option-}' specified" >&2; \ exit 1;; \ esac; \ has_opt=no; \ sane_makeflags=$$MAKEFLAGS; \ if $(am__is_gnu_make); then \ sane_makeflags=$$MFLAGS; \ else \ case $$MAKEFLAGS in \ *\\[\ \ ]*) \ bs=\\; \ sane_makeflags=`printf '%s\n' "$$MAKEFLAGS" \ | sed "s/$$bs$$bs[$$bs $$bs ]*//g"`;; \ esac; \ fi; \ skip_next=no; \ strip_trailopt () \ { \ flg=`printf '%s\n' "$$flg" | sed "s/$$1.*$$//"`; \ }; \ for flg in $$sane_makeflags; do \ test $$skip_next = yes && { skip_next=no; continue; }; \ case $$flg in \ *=*|--*) continue;; \ -*I) strip_trailopt 'I'; skip_next=yes;; \ -*I?*) strip_trailopt 'I';; \ -*O) strip_trailopt 'O'; skip_next=yes;; \ -*O?*) strip_trailopt 'O';; \ -*l) strip_trailopt 'l'; skip_next=yes;; \ -*l?*) strip_trailopt 'l';; \ -[dEDm]) skip_next=yes;; \ -[JT]) skip_next=yes;; \ esac; \ case $$flg in \ *$$target_option*) has_opt=yes; break;; \ esac; \ done; \ test $$has_opt = yes am__make_dryrun = (target_option=n; $(am__make_running_with_option)) am__make_keepgoing = (target_option=k; $(am__make_running_with_option)) pkgdatadir = $(datadir)/@PACKAGE@ pkgincludedir = $(includedir)/@PACKAGE@ pkglibdir = $(libdir)/@PACKAGE@ pkglibexecdir = $(libexecdir)/@PACKAGE@ am__cd = CDPATH="$${ZSH_VERSION+.}$(PATH_SEPARATOR)" && cd install_sh_DATA = $(install_sh) -c -m 644 install_sh_PROGRAM = $(install_sh) -c install_sh_SCRIPT = $(install_sh) -c INSTALL_HEADER = $(INSTALL_DATA) transform = $(program_transform_name) NORMAL_INSTALL = : PRE_INSTALL = : POST_INSTALL = : NORMAL_UNINSTALL = : PRE_UNINSTALL = : POST_UNINSTALL = : build_triplet = @build@ host_triplet = @host@ subdir = src ACLOCAL_M4 = $(top_srcdir)/aclocal.m4 am__aclocal_m4_deps = $(top_srcdir)/m4/ax_append_compile_flags.m4 \ $(top_srcdir)/m4/ax_append_flag.m4 \ $(top_srcdir)/m4/ax_cflags_warn_all.m4 \ $(top_srcdir)/m4/ax_check_compile_flag.m4 \ $(top_srcdir)/m4/ax_require_defined.m4 \ $(top_srcdir)/m4/libtool.m4 $(top_srcdir)/m4/ltoptions.m4 \ $(top_srcdir)/m4/ltsugar.m4 $(top_srcdir)/m4/ltversion.m4 \ $(top_srcdir)/m4/lt~obsolete.m4 $(top_srcdir)/m4/pkg.m4 \ $(top_srcdir)/configure.ac am__configure_deps = $(am__aclocal_m4_deps) $(CONFIGURE_DEPENDENCIES) \ $(ACLOCAL_M4) DIST_COMMON = $(srcdir)/Makefile.am $(am__DIST_COMMON) mkinstalldirs = $(install_sh) -d CONFIG_HEADER = $(top_builddir)/config_ac.h CONFIG_CLEAN_FILES = CONFIG_CLEAN_VPATH_FILES = am__vpath_adj_setup = srcdirstrip=`echo "$(srcdir)" | sed 's|.|.|g'`; am__vpath_adj = case $$p in \ $(srcdir)/*) f=`echo "$$p" | sed "s|^$$srcdirstrip/||"`;; \ *) f=$$p;; \ esac; am__strip_dir = f=`echo $$p | sed -e 's|^.*/||'`; am__install_max = 40 am__nobase_strip_setup = \ srcdirstrip=`echo "$(srcdir)" | sed 's/[].[^$$\\*|]/\\\\&/g'` am__nobase_strip = \ for p in $$list; do echo "$$p"; done | sed -e "s|$$srcdirstrip/||" am__nobase_list = $(am__nobase_strip_setup); \ for p in $$list; do echo "$$p $$p"; done | \ sed "s| $$srcdirstrip/| |;"' / .*\//!s/ .*/ ./; s,\( .*\)/[^/]*$$,\1,' | \ $(AWK) 'BEGIN { files["."] = "" } { files[$$2] = files[$$2] " " $$1; \ if (++n[$$2] == $(am__install_max)) \ { print $$2, files[$$2]; n[$$2] = 0; files[$$2] = "" } } \ END { for (dir in files) print dir, files[dir] }' am__base_list = \ sed '$$!N;$$!N;$$!N;$$!N;$$!N;$$!N;$$!N;s/\n/ /g' | \ sed '$$!N;$$!N;$$!N;$$!N;s/\n/ /g' am__uninstall_files_from_dir = { \ test -z "$$files" \ || { test ! -d "$$dir" && test ! -f "$$dir" && test ! -r "$$dir"; } \ || { echo " ( cd '$$dir' && rm -f" $$files ")"; \ $(am__cd) "$$dir" && rm -f $$files; }; \ } am__installdirs = "$(DESTDIR)$(libdir)" LTLIBRARIES = $(lib_LTLIBRARIES) libpainter_la_DEPENDENCIES = am_libpainter_la_OBJECTS = painter.lo painter_utils.lo libpainter_la_OBJECTS = $(am_libpainter_la_OBJECTS) AM_V_lt = $(am__v_lt_@AM_V@) am__v_lt_ = $(am__v_lt_@AM_DEFAULT_V@) am__v_lt_0 = --silent am__v_lt_1 = libpainter_la_LINK = $(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) \ $(LIBTOOLFLAGS) --mode=link $(CCLD) $(AM_CFLAGS) $(CFLAGS) \ $(libpainter_la_LDFLAGS) $(LDFLAGS) -o $@ AM_V_P = $(am__v_P_@AM_V@) am__v_P_ = $(am__v_P_@AM_DEFAULT_V@) am__v_P_0 = false am__v_P_1 = : AM_V_GEN = $(am__v_GEN_@AM_V@) am__v_GEN_ = $(am__v_GEN_@AM_DEFAULT_V@) am__v_GEN_0 = @echo " GEN " $@; am__v_GEN_1 = AM_V_at = $(am__v_at_@AM_V@) am__v_at_ = $(am__v_at_@AM_DEFAULT_V@) am__v_at_0 = @ am__v_at_1 = DEFAULT_INCLUDES = -I.@am__isrc@ -I$(top_builddir) depcomp = $(SHELL) $(top_srcdir)/depcomp am__depfiles_maybe = depfiles am__mv = mv -f COMPILE = $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) \ $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) LTCOMPILE = $(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) \ $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) \ $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) \ $(AM_CFLAGS) $(CFLAGS) AM_V_CC = $(am__v_CC_@AM_V@) am__v_CC_ = $(am__v_CC_@AM_DEFAULT_V@) am__v_CC_0 = @echo " CC " $@; am__v_CC_1 = CCLD = $(CC) LINK = $(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) \ $(LIBTOOLFLAGS) --mode=link $(CCLD) $(AM_CFLAGS) $(CFLAGS) \ $(AM_LDFLAGS) $(LDFLAGS) -o $@ AM_V_CCLD = $(am__v_CCLD_@AM_V@) am__v_CCLD_ = $(am__v_CCLD_@AM_DEFAULT_V@) am__v_CCLD_0 = @echo " CCLD " $@; am__v_CCLD_1 = SOURCES = $(libpainter_la_SOURCES) DIST_SOURCES = $(libpainter_la_SOURCES) am__can_run_installinfo = \ case $$AM_UPDATE_INFO_DIR in \ n|no|NO) false;; \ *) (install-info --version) >/dev/null 2>&1;; \ esac am__tagged_files = $(HEADERS) $(SOURCES) $(TAGS_FILES) $(LISP) # Read a list of newline-separated strings from the standard input, # and print each of them once, without duplicates. Input order is # *not* preserved. am__uniquify_input = $(AWK) '\ BEGIN { nonempty = 0; } \ { items[$$0] = 1; nonempty = 1; } \ END { if (nonempty) { for (i in items) print i; }; } \ ' # Make sure the list of sources is unique. This is necessary because, # e.g., the same source file might be shared among _SOURCES variables # for different programs/libraries. am__define_uniq_tagged_files = \ list='$(am__tagged_files)'; \ unique=`for i in $$list; do \ if test -f "$$i"; then echo $$i; else echo $(srcdir)/$$i; fi; \ done | $(am__uniquify_input)` ETAGS = etags CTAGS = ctags am__DIST_COMMON = $(srcdir)/Makefile.in $(top_srcdir)/depcomp DISTFILES = $(DIST_COMMON) $(DIST_SOURCES) $(TEXINFOS) $(EXTRA_DIST) ACLOCAL = @ACLOCAL@ AMTAR = @AMTAR@ AM_DEFAULT_VERBOSITY = @AM_DEFAULT_VERBOSITY@ AR = @AR@ AUTOCONF = @AUTOCONF@ AUTOHEADER = @AUTOHEADER@ AUTOMAKE = @AUTOMAKE@ AWK = @AWK@ CC = @CC@ CCDEPMODE = @CCDEPMODE@ CFLAGS = @CFLAGS@ CPP = @CPP@ CPPFLAGS = @CPPFLAGS@ CYGPATH_W = @CYGPATH_W@ DEFS = @DEFS@ DEPDIR = @DEPDIR@ DLLTOOL = @DLLTOOL@ DSYMUTIL = @DSYMUTIL@ DUMPBIN = @DUMPBIN@ ECHO_C = @ECHO_C@ ECHO_N = @ECHO_N@ ECHO_T = @ECHO_T@ EGREP = @EGREP@ EXEEXT = @EXEEXT@ FGREP = @FGREP@ GREP = @GREP@ INSTALL = @INSTALL@ INSTALL_DATA = @INSTALL_DATA@ INSTALL_PROGRAM = @INSTALL_PROGRAM@ INSTALL_SCRIPT = @INSTALL_SCRIPT@ INSTALL_STRIP_PROGRAM = @INSTALL_STRIP_PROGRAM@ LD = @LD@ LDFLAGS = @LDFLAGS@ LIBOBJS = @LIBOBJS@ LIBS = @LIBS@ LIBTOOL = @LIBTOOL@ LIPO = @LIPO@ LN_S = @LN_S@ LTLIBOBJS = @LTLIBOBJS@ LT_SYS_LIBRARY_PATH = @LT_SYS_LIBRARY_PATH@ MAKEINFO = @MAKEINFO@ MANIFEST_TOOL = @MANIFEST_TOOL@ MKDIR_P = @MKDIR_P@ NM = @NM@ NMEDIT = @NMEDIT@ OBJDUMP = @OBJDUMP@ OBJEXT = @OBJEXT@ OTOOL = @OTOOL@ OTOOL64 = @OTOOL64@ PACKAGE = @PACKAGE@ PACKAGE_BUGREPORT = @PACKAGE_BUGREPORT@ PACKAGE_NAME = @PACKAGE_NAME@ PACKAGE_STRING = @PACKAGE_STRING@ PACKAGE_TARNAME = @PACKAGE_TARNAME@ PACKAGE_URL = @PACKAGE_URL@ PACKAGE_VERSION = @PACKAGE_VERSION@ PATH_SEPARATOR = @PATH_SEPARATOR@ RANLIB = @RANLIB@ SED = @SED@ SET_MAKE = @SET_MAKE@ SHELL = @SHELL@ STRIP = @STRIP@ VERSION = @VERSION@ abs_builddir = @abs_builddir@ abs_srcdir = @abs_srcdir@ abs_top_builddir = @abs_top_builddir@ abs_top_srcdir = @abs_top_srcdir@ ac_ct_AR = @ac_ct_AR@ ac_ct_CC = @ac_ct_CC@ ac_ct_DUMPBIN = @ac_ct_DUMPBIN@ am__include = @am__include@ am__leading_dot = @am__leading_dot@ am__quote = @am__quote@ am__tar = @am__tar@ am__untar = @am__untar@ bindir = @bindir@ build = @build@ build_alias = @build_alias@ build_cpu = @build_cpu@ build_os = @build_os@ build_vendor = @build_vendor@ builddir = @builddir@ datadir = @datadir@ datarootdir = @datarootdir@ docdir = @docdir@ dvidir = @dvidir@ exec_prefix = @exec_prefix@ host = @host@ host_alias = @host_alias@ host_cpu = @host_cpu@ host_os = @host_os@ host_vendor = @host_vendor@ htmldir = @htmldir@ includedir = @includedir@ infodir = @infodir@ install_sh = @install_sh@ libdir = @libdir@ libexecdir = @libexecdir@ localedir = @localedir@ localstatedir = @localstatedir@ mandir = @mandir@ mkdir_p = @mkdir_p@ oldincludedir = @oldincludedir@ pdfdir = @pdfdir@ pkgconfigdir = @pkgconfigdir@ prefix = @prefix@ program_transform_name = @program_transform_name@ psdir = @psdir@ sbindir = @sbindir@ sharedstatedir = @sharedstatedir@ srcdir = @srcdir@ sysconfdir = @sysconfdir@ target_alias = @target_alias@ top_build_prefix = @top_build_prefix@ top_builddir = @top_builddir@ top_srcdir = @top_srcdir@ EXTRA_DIST = EXTRA_PAINTER_DEFINES = EXTRA_PAINTER_INCLUDES = EXTRA_PAINTER_LIBS = EXTRA_PAINTER_FLAGS = AM_CFLAGS = \ -I$(top_srcdir)/include \ $(EXTRA_PAINTER_FLAGS) lib_LTLIBRARIES = libpainter.la libpainter_la_LDFLAGS = libpainter_ladir = $(moduledir) libpainter_la_SOURCES = painter.c painter_utils.c painter_utils.h libpainter_la_LIBADD = all: all-am .SUFFIXES: .SUFFIXES: .c .lo .o .obj $(srcdir)/Makefile.in: $(srcdir)/Makefile.am $(am__configure_deps) @for dep in $?; do \ case '$(am__configure_deps)' in \ *$$dep*) \ ( cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh ) \ && { if test -f $@; then exit 0; else break; fi; }; \ exit 1;; \ esac; \ done; \ echo ' cd $(top_srcdir) && $(AUTOMAKE) --foreign src/Makefile'; \ $(am__cd) $(top_srcdir) && \ $(AUTOMAKE) --foreign src/Makefile Makefile: $(srcdir)/Makefile.in $(top_builddir)/config.status @case '$?' in \ *config.status*) \ cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh;; \ *) \ echo ' cd $(top_builddir) && $(SHELL) ./config.status $(subdir)/$@ $(am__depfiles_maybe)'; \ cd $(top_builddir) && $(SHELL) ./config.status $(subdir)/$@ $(am__depfiles_maybe);; \ esac; $(top_builddir)/config.status: $(top_srcdir)/configure $(CONFIG_STATUS_DEPENDENCIES) cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh $(top_srcdir)/configure: $(am__configure_deps) cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh $(ACLOCAL_M4): $(am__aclocal_m4_deps) cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh $(am__aclocal_m4_deps): install-libLTLIBRARIES: $(lib_LTLIBRARIES) @$(NORMAL_INSTALL) @list='$(lib_LTLIBRARIES)'; test -n "$(libdir)" || list=; \ list2=; for p in $$list; do \ if test -f $$p; then \ list2="$$list2 $$p"; \ else :; fi; \ done; \ test -z "$$list2" || { \ echo " $(MKDIR_P) '$(DESTDIR)$(libdir)'"; \ $(MKDIR_P) "$(DESTDIR)$(libdir)" || exit 1; \ echo " $(LIBTOOL) $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=install $(INSTALL) $(INSTALL_STRIP_FLAG) $$list2 '$(DESTDIR)$(libdir)'"; \ $(LIBTOOL) $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=install $(INSTALL) $(INSTALL_STRIP_FLAG) $$list2 "$(DESTDIR)$(libdir)"; \ } uninstall-libLTLIBRARIES: @$(NORMAL_UNINSTALL) @list='$(lib_LTLIBRARIES)'; test -n "$(libdir)" || list=; \ for p in $$list; do \ $(am__strip_dir) \ echo " $(LIBTOOL) $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=uninstall rm -f '$(DESTDIR)$(libdir)/$$f'"; \ $(LIBTOOL) $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=uninstall rm -f "$(DESTDIR)$(libdir)/$$f"; \ done clean-libLTLIBRARIES: -test -z "$(lib_LTLIBRARIES)" || rm -f $(lib_LTLIBRARIES) @list='$(lib_LTLIBRARIES)'; \ locs=`for p in $$list; do echo $$p; done | \ sed 's|^[^/]*$$|.|; s|/[^/]*$$||; s|$$|/so_locations|' | \ sort -u`; \ test -z "$$locs" || { \ echo rm -f $${locs}; \ rm -f $${locs}; \ } libpainter.la: $(libpainter_la_OBJECTS) $(libpainter_la_DEPENDENCIES) $(EXTRA_libpainter_la_DEPENDENCIES) $(AM_V_CCLD)$(libpainter_la_LINK) -rpath $(libdir) $(libpainter_la_OBJECTS) $(libpainter_la_LIBADD) $(LIBS) mostlyclean-compile: -rm -f *.$(OBJEXT) distclean-compile: -rm -f *.tab.c @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/painter.Plo@am__quote@ @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/painter_utils.Plo@am__quote@ .c.o: @am__fastdepCC_TRUE@ $(AM_V_CC)$(COMPILE) -MT $@ -MD -MP -MF $(DEPDIR)/$*.Tpo -c -o $@ $< @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) $(DEPDIR)/$*.Tpo $(DEPDIR)/$*.Po @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='$<' object='$@' libtool=no @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(COMPILE) -c -o $@ $< .c.obj: @am__fastdepCC_TRUE@ $(AM_V_CC)$(COMPILE) -MT $@ -MD -MP -MF $(DEPDIR)/$*.Tpo -c -o $@ `$(CYGPATH_W) '$<'` @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) $(DEPDIR)/$*.Tpo $(DEPDIR)/$*.Po @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='$<' object='$@' libtool=no @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(COMPILE) -c -o $@ `$(CYGPATH_W) '$<'` .c.lo: @am__fastdepCC_TRUE@ $(AM_V_CC)$(LTCOMPILE) -MT $@ -MD -MP -MF $(DEPDIR)/$*.Tpo -c -o $@ $< @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) $(DEPDIR)/$*.Tpo $(DEPDIR)/$*.Plo @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='$<' object='$@' libtool=yes @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(LTCOMPILE) -c -o $@ $< mostlyclean-libtool: -rm -f *.lo clean-libtool: -rm -rf .libs _libs ID: $(am__tagged_files) $(am__define_uniq_tagged_files); mkid -fID $$unique tags: tags-am TAGS: tags tags-am: $(TAGS_DEPENDENCIES) $(am__tagged_files) set x; \ here=`pwd`; \ $(am__define_uniq_tagged_files); \ shift; \ if test -z "$(ETAGS_ARGS)$$*$$unique"; then :; else \ test -n "$$unique" || unique=$$empty_fix; \ if test $$# -gt 0; then \ $(ETAGS) $(ETAGSFLAGS) $(AM_ETAGSFLAGS) $(ETAGS_ARGS) \ "$$@" $$unique; \ else \ $(ETAGS) $(ETAGSFLAGS) $(AM_ETAGSFLAGS) $(ETAGS_ARGS) \ $$unique; \ fi; \ fi ctags: ctags-am CTAGS: ctags ctags-am: $(TAGS_DEPENDENCIES) $(am__tagged_files) $(am__define_uniq_tagged_files); \ test -z "$(CTAGS_ARGS)$$unique" \ || $(CTAGS) $(CTAGSFLAGS) $(AM_CTAGSFLAGS) $(CTAGS_ARGS) \ $$unique GTAGS: here=`$(am__cd) $(top_builddir) && pwd` \ && $(am__cd) $(top_srcdir) \ && gtags -i $(GTAGS_ARGS) "$$here" cscopelist: cscopelist-am cscopelist-am: $(am__tagged_files) list='$(am__tagged_files)'; \ case "$(srcdir)" in \ [\\/]* | ?:[\\/]*) sdir="$(srcdir)" ;; \ *) sdir=$(subdir)/$(srcdir) ;; \ esac; \ for i in $$list; do \ if test -f "$$i"; then \ echo "$(subdir)/$$i"; \ else \ echo "$$sdir/$$i"; \ fi; \ done >> $(top_builddir)/cscope.files distclean-tags: -rm -f TAGS ID GTAGS GRTAGS GSYMS GPATH tags distdir: $(DISTFILES) @srcdirstrip=`echo "$(srcdir)" | sed 's/[].[^$$\\*]/\\\\&/g'`; \ topsrcdirstrip=`echo "$(top_srcdir)" | sed 's/[].[^$$\\*]/\\\\&/g'`; \ list='$(DISTFILES)'; \ dist_files=`for file in $$list; do echo $$file; done | \ sed -e "s|^$$srcdirstrip/||;t" \ -e "s|^$$topsrcdirstrip/|$(top_builddir)/|;t"`; \ case $$dist_files in \ */*) $(MKDIR_P) `echo "$$dist_files" | \ sed '/\//!d;s|^|$(distdir)/|;s,/[^/]*$$,,' | \ sort -u` ;; \ esac; \ for file in $$dist_files; do \ if test -f $$file || test -d $$file; then d=.; else d=$(srcdir); fi; \ if test -d $$d/$$file; then \ dir=`echo "/$$file" | sed -e 's,/[^/]*$$,,'`; \ if test -d "$(distdir)/$$file"; then \ find "$(distdir)/$$file" -type d ! -perm -700 -exec chmod u+rwx {} \;; \ fi; \ if test -d $(srcdir)/$$file && test $$d != $(srcdir); then \ cp -fpR $(srcdir)/$$file "$(distdir)$$dir" || exit 1; \ find "$(distdir)/$$file" -type d ! -perm -700 -exec chmod u+rwx {} \;; \ fi; \ cp -fpR $$d/$$file "$(distdir)$$dir" || exit 1; \ else \ test -f "$(distdir)/$$file" \ || cp -p $$d/$$file "$(distdir)/$$file" \ || exit 1; \ fi; \ done check-am: all-am check: check-am all-am: Makefile $(LTLIBRARIES) installdirs: for dir in "$(DESTDIR)$(libdir)"; do \ test -z "$$dir" || $(MKDIR_P) "$$dir"; \ done install: install-am install-exec: install-exec-am install-data: install-data-am uninstall: uninstall-am install-am: all-am @$(MAKE) $(AM_MAKEFLAGS) install-exec-am install-data-am installcheck: installcheck-am install-strip: if test -z '$(STRIP)'; then \ $(MAKE) $(AM_MAKEFLAGS) INSTALL_PROGRAM="$(INSTALL_STRIP_PROGRAM)" \ install_sh_PROGRAM="$(INSTALL_STRIP_PROGRAM)" INSTALL_STRIP_FLAG=-s \ install; \ else \ $(MAKE) $(AM_MAKEFLAGS) INSTALL_PROGRAM="$(INSTALL_STRIP_PROGRAM)" \ install_sh_PROGRAM="$(INSTALL_STRIP_PROGRAM)" INSTALL_STRIP_FLAG=-s \ "INSTALL_PROGRAM_ENV=STRIPPROG='$(STRIP)'" install; \ fi mostlyclean-generic: clean-generic: distclean-generic: -test -z "$(CONFIG_CLEAN_FILES)" || rm -f $(CONFIG_CLEAN_FILES) -test . = "$(srcdir)" || test -z "$(CONFIG_CLEAN_VPATH_FILES)" || rm -f $(CONFIG_CLEAN_VPATH_FILES) maintainer-clean-generic: @echo "This command is intended for maintainers to use" @echo "it deletes files that may require special tools to rebuild." clean: clean-am clean-am: clean-generic clean-libLTLIBRARIES clean-libtool \ mostlyclean-am distclean: distclean-am -rm -rf ./$(DEPDIR) -rm -f Makefile distclean-am: clean-am distclean-compile distclean-generic \ distclean-tags dvi: dvi-am dvi-am: html: html-am html-am: info: info-am info-am: install-data-am: install-dvi: install-dvi-am install-dvi-am: install-exec-am: install-libLTLIBRARIES install-html: install-html-am install-html-am: install-info: install-info-am install-info-am: install-man: install-pdf: install-pdf-am install-pdf-am: install-ps: install-ps-am install-ps-am: installcheck-am: maintainer-clean: maintainer-clean-am -rm -rf ./$(DEPDIR) -rm -f Makefile maintainer-clean-am: distclean-am maintainer-clean-generic mostlyclean: mostlyclean-am mostlyclean-am: mostlyclean-compile mostlyclean-generic \ mostlyclean-libtool pdf: pdf-am pdf-am: ps: ps-am ps-am: uninstall-am: uninstall-libLTLIBRARIES .MAKE: install-am install-strip .PHONY: CTAGS GTAGS TAGS all all-am check check-am clean clean-generic \ clean-libLTLIBRARIES clean-libtool cscopelist-am ctags \ ctags-am distclean distclean-compile distclean-generic \ distclean-libtool distclean-tags distdir dvi dvi-am html \ html-am info info-am install install-am install-data \ install-data-am install-dvi install-dvi-am install-exec \ install-exec-am install-html install-html-am install-info \ install-info-am install-libLTLIBRARIES install-man install-pdf \ install-pdf-am install-ps install-ps-am install-strip \ installcheck installcheck-am installdirs maintainer-clean \ maintainer-clean-generic mostlyclean mostlyclean-compile \ mostlyclean-generic mostlyclean-libtool pdf pdf-am ps ps-am \ tags tags-am uninstall uninstall-am uninstall-libLTLIBRARIES .PRECIOUS: Makefile # Tell versions [3.59,3.63) of GNU make to not export all variables. # Otherwise a system limit (for SysV at least) may be exceeded. .NOEXPORT: xrdp-0.9.5/libpainter/src/Makefile.am000644 001751 001751 00000000545 13035113356 017402 0ustar00metameta000000 000000 EXTRA_DIST = EXTRA_PAINTER_DEFINES = EXTRA_PAINTER_INCLUDES = EXTRA_PAINTER_LIBS = EXTRA_PAINTER_FLAGS = AM_CFLAGS = \ -I$(top_srcdir)/include \ $(EXTRA_PAINTER_FLAGS) lib_LTLIBRARIES = libpainter.la libpainter_la_LDFLAGS = libpainter_ladir = $(moduledir) libpainter_la_SOURCES = painter.c painter_utils.c painter_utils.h libpainter_la_LIBADD = xrdp-0.9.5/libpainter/src/painter_utils.c000644 001751 001751 00000020174 13061652764 020406 0ustar00metameta000000 000000 /** * painter utils * * Copyright 2015-2016 Jay Sorg * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ #if defined(HAVE_CONFIG_H) #include #endif #include #include #include #include "painter.h" #include "painter_utils.h" /*****************************************************************************/ /* do a raster op */ int do_rop(int rop, int src, int dst) { switch (rop) { case PT_ROP_0: return 0; case PT_ROP_DSon: return ~(src | dst); case PT_ROP_DSna: return (~src) & dst; case PT_ROP_Sn: return ~src; case PT_ROP_SDna: return src & (~dst); case PT_ROP_Dn: return ~(dst); case PT_ROP_DSx: return src ^ dst; case PT_ROP_DSan: return ~(src & dst); case PT_ROP_DSa: return src & dst; case PT_ROP_DSxn: return ~(src) ^ dst; case PT_ROP_D: return dst; case PT_ROP_DSno: return (~src) | dst; case PT_ROP_S: return src; case PT_ROP_SDno: return src | (~dst); case PT_ROP_DSo: return src | dst; case PT_ROP_1: return ~0; } return dst; } /*****************************************************************************/ char * bitmap_get_ptr(struct painter_bitmap *bitmap, int x, int y) { char *p; int bpp; int Bpp; if ((x >= 0) && (x < bitmap->width) && (y >= 0) && (y < bitmap->height)) { bpp = bitmap->format >> 24; if (bpp < 8) { p = bitmap->data + (y * bitmap->stride_bytes) + (x / 8); return p; } else { Bpp = (bpp + 7) / 8; p = bitmap->data + (y * bitmap->stride_bytes) + (x * Bpp); return p; } } else { return NULL; } } /*****************************************************************************/ int bitmap_get_pixel(struct painter_bitmap *bitmap, int x, int y) { char *ptr; int rv; ptr = bitmap_get_ptr(bitmap, x, y); if (ptr == NULL) { return 0; } switch (bitmap->format) { case PT_FORMAT_c1: rv = *((unsigned char *) ptr); rv = (rv & (0x80 >> (x % 8))) != 0; return rv; case PT_FORMAT_c8: return *((unsigned char *) ptr); case PT_FORMAT_r3g3b2: return *((unsigned char *) ptr); case PT_FORMAT_a1r5g5b5: return *((unsigned short *) ptr); case PT_FORMAT_r5g6b5: return *((unsigned short *) ptr); case PT_FORMAT_a8r8g8b8: return *((unsigned int *) ptr); case PT_FORMAT_a8b8g8r8: return *((unsigned int *) ptr); } return 0; } /*****************************************************************************/ int bitmap_set_pixel(struct painter_bitmap *bitmap, int x, int y, int pixel) { char *ptr; ptr = bitmap_get_ptr(bitmap, x, y); if (ptr == NULL) { return 0; } switch (bitmap->format) { case PT_FORMAT_r3g3b2: *((unsigned char *) ptr) = pixel; break; case PT_FORMAT_a1r5g5b5: *((unsigned short *) ptr) = pixel; break; case PT_FORMAT_r5g6b5: *((unsigned short *) ptr) = pixel; break; case PT_FORMAT_a8r8g8b8: *((unsigned int *) ptr) = pixel; break; case PT_FORMAT_a8b8g8r8: *((unsigned int *) ptr) = pixel; break; } return 0; } /*****************************************************************************/ int pixel_convert(int pixel, int src_format, int dst_format, int *palette) { int a; int r; int g; int b; int rv; if (src_format == dst_format) { return pixel; } a = 0; r = 0; g = 0; b = 0; switch (src_format) { case PT_FORMAT_r3g3b2: SPLIT_r3g3b2(pixel, a, r, g, b); break; case PT_FORMAT_a1r5g5b5: SPLIT_a1r5g5b5(pixel, a, r, g, b); break; case PT_FORMAT_r5g6b5: SPLIT_r5g6b5(pixel, a, r, g, b); break; case PT_FORMAT_a8r8g8b8: SPLIT_a8r8g8b8(pixel, a, r, g, b); break; case PT_FORMAT_a8b8g8r8: SPLIT_a8b8g8r8(pixel, a, r, g, b); break; } rv = 0; switch (dst_format) { case PT_FORMAT_a1r5g5b5: MAKE_a1r5g5b5(rv, a, r, g, b); break; case PT_FORMAT_r5g6b5: MAKE_r5g6b5(rv, a, r, g, b); break; case PT_FORMAT_a8r8g8b8: MAKE_a8r8g8b8(rv, a, r, g, b); break; case PT_FORMAT_a8b8g8r8: MAKE_a8b8g8r8(rv, a, r, g, b); break; } return rv; } /*****************************************************************************/ int painter_get_pixel(struct painter *painter, struct painter_bitmap *bitmap, int x, int y) { int rv; rv = 0; if ((x >= 0) && (x < bitmap->width) && (y >= 0) && (y < bitmap->height)) { switch (bitmap->format) { case PT_FORMAT_c1: rv = bitmap_get_pixel(bitmap, x, y); rv = rv ? painter->fgcolor : painter->bgcolor; break; case PT_FORMAT_c8: rv = bitmap_get_pixel(bitmap, x, y); rv = painter->palette[rv & 0xff]; break; default: rv = bitmap_get_pixel(bitmap, x, y); break; } } return rv; } /*****************************************************************************/ int painter_set_pixel(struct painter *painter, struct painter_bitmap *bitmap, int x, int y, int pixel, int pixel_format) { if ((painter->clip_valid == 0) || ((x >= painter->clip.x1) && (x < painter->clip.x2) && (y >= painter->clip.y1) && (y < painter->clip.y2))) { if ((x >= 0) && (x < bitmap->width) && (y >= 0) && (y < bitmap->height)) { pixel = pixel_convert(pixel, pixel_format, bitmap->format, painter->palette); if (painter->rop != PT_ROP_S) { pixel = do_rop(painter->rop, pixel, bitmap_get_pixel(bitmap, x, y)); } bitmap_set_pixel(bitmap, x, y, pixel); } } return 0; } /*****************************************************************************/ /* return true if there is something to draw */ int painter_warp_coords(struct painter *painter, int *x, int *y, int *cx, int *cy, int *srcx, int *srcy) { int dx; int dy; int lx; int ly; int lcx; int lcy; lx = *x; ly = *y; lcx = *cx; lcy = *cy; dx = 0; dy = 0; if (painter->clip_valid) { if (painter->clip.x1 > lx) { dx = painter->clip.x1 - lx; } if (painter->clip.y1 > ly) { dy = painter->clip.y1 - ly; } if (lx + lcx > painter->clip.x2) { lcx = (lcx - ((lx + lcx) - painter->clip.x2)); } if (*y + lcy > painter->clip.y2) { lcy = (lcy - ((ly + lcy) - painter->clip.y2)); } } lcx = lcx - dx; lcy = lcy - dy; if (lcx <= 0) { return 0; } if (lcy <= 0) { return 0; } lx = lx + dx; ly = ly + dy; if (srcx != 0) { *srcx = *srcx + dx; } if (srcy != 0) { *srcy = *srcy + dy; } *x = lx; *y = ly; *cx = lcx; *cy = lcy; return 1; } xrdp-0.9.5/libpainter/m4/lt~obsolete.m4000644 001751 001751 00000013774 13220730731 017721 0ustar00metameta000000 000000 # lt~obsolete.m4 -- aclocal satisfying obsolete definitions. -*-Autoconf-*- # # Copyright (C) 2004-2005, 2007, 2009, 2011-2015 Free Software # Foundation, Inc. # Written by Scott James Remnant, 2004. # # This file is free software; the Free Software Foundation gives # unlimited permission to copy and/or distribute it, with or without # modifications, as long as this notice is preserved. # serial 5 lt~obsolete.m4 # These exist entirely to fool aclocal when bootstrapping libtool. # # In the past libtool.m4 has provided macros via AC_DEFUN (or AU_DEFUN), # which have later been changed to m4_define as they aren't part of the # exported API, or moved to Autoconf or Automake where they belong. # # The trouble is, aclocal is a bit thick. It'll see the old AC_DEFUN # in /usr/share/aclocal/libtool.m4 and remember it, then when it sees us # using a macro with the same name in our local m4/libtool.m4 it'll # pull the old libtool.m4 in (it doesn't see our shiny new m4_define # and doesn't know about Autoconf macros at all.) # # So we provide this file, which has a silly filename so it's always # included after everything else. This provides aclocal with the # AC_DEFUNs it wants, but when m4 processes it, it doesn't do anything # because those macros already exist, or will be overwritten later. # We use AC_DEFUN over AU_DEFUN for compatibility with aclocal-1.6. # # Anytime we withdraw an AC_DEFUN or AU_DEFUN, remember to add it here. # Yes, that means every name once taken will need to remain here until # we give up compatibility with versions before 1.7, at which point # we need to keep only those names which we still refer to. # This is to help aclocal find these macros, as it can't see m4_define. AC_DEFUN([LTOBSOLETE_VERSION], [m4_if([1])]) m4_ifndef([AC_LIBTOOL_LINKER_OPTION], [AC_DEFUN([AC_LIBTOOL_LINKER_OPTION])]) m4_ifndef([AC_PROG_EGREP], [AC_DEFUN([AC_PROG_EGREP])]) m4_ifndef([_LT_AC_PROG_ECHO_BACKSLASH], [AC_DEFUN([_LT_AC_PROG_ECHO_BACKSLASH])]) m4_ifndef([_LT_AC_SHELL_INIT], [AC_DEFUN([_LT_AC_SHELL_INIT])]) m4_ifndef([_LT_AC_SYS_LIBPATH_AIX], [AC_DEFUN([_LT_AC_SYS_LIBPATH_AIX])]) m4_ifndef([_LT_PROG_LTMAIN], [AC_DEFUN([_LT_PROG_LTMAIN])]) m4_ifndef([_LT_AC_TAGVAR], [AC_DEFUN([_LT_AC_TAGVAR])]) m4_ifndef([AC_LTDL_ENABLE_INSTALL], [AC_DEFUN([AC_LTDL_ENABLE_INSTALL])]) m4_ifndef([AC_LTDL_PREOPEN], [AC_DEFUN([AC_LTDL_PREOPEN])]) m4_ifndef([_LT_AC_SYS_COMPILER], [AC_DEFUN([_LT_AC_SYS_COMPILER])]) m4_ifndef([_LT_AC_LOCK], [AC_DEFUN([_LT_AC_LOCK])]) m4_ifndef([AC_LIBTOOL_SYS_OLD_ARCHIVE], [AC_DEFUN([AC_LIBTOOL_SYS_OLD_ARCHIVE])]) m4_ifndef([_LT_AC_TRY_DLOPEN_SELF], [AC_DEFUN([_LT_AC_TRY_DLOPEN_SELF])]) m4_ifndef([AC_LIBTOOL_PROG_CC_C_O], [AC_DEFUN([AC_LIBTOOL_PROG_CC_C_O])]) m4_ifndef([AC_LIBTOOL_SYS_HARD_LINK_LOCKS], [AC_DEFUN([AC_LIBTOOL_SYS_HARD_LINK_LOCKS])]) m4_ifndef([AC_LIBTOOL_OBJDIR], [AC_DEFUN([AC_LIBTOOL_OBJDIR])]) m4_ifndef([AC_LTDL_OBJDIR], [AC_DEFUN([AC_LTDL_OBJDIR])]) m4_ifndef([AC_LIBTOOL_PROG_LD_HARDCODE_LIBPATH], [AC_DEFUN([AC_LIBTOOL_PROG_LD_HARDCODE_LIBPATH])]) m4_ifndef([AC_LIBTOOL_SYS_LIB_STRIP], [AC_DEFUN([AC_LIBTOOL_SYS_LIB_STRIP])]) m4_ifndef([AC_PATH_MAGIC], [AC_DEFUN([AC_PATH_MAGIC])]) m4_ifndef([AC_PROG_LD_GNU], [AC_DEFUN([AC_PROG_LD_GNU])]) m4_ifndef([AC_PROG_LD_RELOAD_FLAG], [AC_DEFUN([AC_PROG_LD_RELOAD_FLAG])]) m4_ifndef([AC_DEPLIBS_CHECK_METHOD], [AC_DEFUN([AC_DEPLIBS_CHECK_METHOD])]) m4_ifndef([AC_LIBTOOL_PROG_COMPILER_NO_RTTI], [AC_DEFUN([AC_LIBTOOL_PROG_COMPILER_NO_RTTI])]) m4_ifndef([AC_LIBTOOL_SYS_GLOBAL_SYMBOL_PIPE], [AC_DEFUN([AC_LIBTOOL_SYS_GLOBAL_SYMBOL_PIPE])]) m4_ifndef([AC_LIBTOOL_PROG_COMPILER_PIC], [AC_DEFUN([AC_LIBTOOL_PROG_COMPILER_PIC])]) m4_ifndef([AC_LIBTOOL_PROG_LD_SHLIBS], [AC_DEFUN([AC_LIBTOOL_PROG_LD_SHLIBS])]) m4_ifndef([AC_LIBTOOL_POSTDEP_PREDEP], [AC_DEFUN([AC_LIBTOOL_POSTDEP_PREDEP])]) m4_ifndef([LT_AC_PROG_EGREP], [AC_DEFUN([LT_AC_PROG_EGREP])]) m4_ifndef([LT_AC_PROG_SED], [AC_DEFUN([LT_AC_PROG_SED])]) m4_ifndef([_LT_CC_BASENAME], [AC_DEFUN([_LT_CC_BASENAME])]) m4_ifndef([_LT_COMPILER_BOILERPLATE], [AC_DEFUN([_LT_COMPILER_BOILERPLATE])]) m4_ifndef([_LT_LINKER_BOILERPLATE], [AC_DEFUN([_LT_LINKER_BOILERPLATE])]) m4_ifndef([_AC_PROG_LIBTOOL], [AC_DEFUN([_AC_PROG_LIBTOOL])]) m4_ifndef([AC_LIBTOOL_SETUP], [AC_DEFUN([AC_LIBTOOL_SETUP])]) m4_ifndef([_LT_AC_CHECK_DLFCN], [AC_DEFUN([_LT_AC_CHECK_DLFCN])]) m4_ifndef([AC_LIBTOOL_SYS_DYNAMIC_LINKER], [AC_DEFUN([AC_LIBTOOL_SYS_DYNAMIC_LINKER])]) m4_ifndef([_LT_AC_TAGCONFIG], [AC_DEFUN([_LT_AC_TAGCONFIG])]) m4_ifndef([AC_DISABLE_FAST_INSTALL], [AC_DEFUN([AC_DISABLE_FAST_INSTALL])]) m4_ifndef([_LT_AC_LANG_CXX], [AC_DEFUN([_LT_AC_LANG_CXX])]) m4_ifndef([_LT_AC_LANG_F77], [AC_DEFUN([_LT_AC_LANG_F77])]) m4_ifndef([_LT_AC_LANG_GCJ], [AC_DEFUN([_LT_AC_LANG_GCJ])]) m4_ifndef([AC_LIBTOOL_LANG_C_CONFIG], [AC_DEFUN([AC_LIBTOOL_LANG_C_CONFIG])]) m4_ifndef([_LT_AC_LANG_C_CONFIG], [AC_DEFUN([_LT_AC_LANG_C_CONFIG])]) m4_ifndef([AC_LIBTOOL_LANG_CXX_CONFIG], [AC_DEFUN([AC_LIBTOOL_LANG_CXX_CONFIG])]) m4_ifndef([_LT_AC_LANG_CXX_CONFIG], [AC_DEFUN([_LT_AC_LANG_CXX_CONFIG])]) m4_ifndef([AC_LIBTOOL_LANG_F77_CONFIG], [AC_DEFUN([AC_LIBTOOL_LANG_F77_CONFIG])]) m4_ifndef([_LT_AC_LANG_F77_CONFIG], [AC_DEFUN([_LT_AC_LANG_F77_CONFIG])]) m4_ifndef([AC_LIBTOOL_LANG_GCJ_CONFIG], [AC_DEFUN([AC_LIBTOOL_LANG_GCJ_CONFIG])]) m4_ifndef([_LT_AC_LANG_GCJ_CONFIG], [AC_DEFUN([_LT_AC_LANG_GCJ_CONFIG])]) m4_ifndef([AC_LIBTOOL_LANG_RC_CONFIG], [AC_DEFUN([AC_LIBTOOL_LANG_RC_CONFIG])]) m4_ifndef([_LT_AC_LANG_RC_CONFIG], [AC_DEFUN([_LT_AC_LANG_RC_CONFIG])]) m4_ifndef([AC_LIBTOOL_CONFIG], [AC_DEFUN([AC_LIBTOOL_CONFIG])]) m4_ifndef([_LT_AC_FILE_LTDLL_C], [AC_DEFUN([_LT_AC_FILE_LTDLL_C])]) m4_ifndef([_LT_REQUIRED_DARWIN_CHECKS], [AC_DEFUN([_LT_REQUIRED_DARWIN_CHECKS])]) m4_ifndef([_LT_AC_PROG_CXXCPP], [AC_DEFUN([_LT_AC_PROG_CXXCPP])]) m4_ifndef([_LT_PREPARE_SED_QUOTE_VARS], [AC_DEFUN([_LT_PREPARE_SED_QUOTE_VARS])]) m4_ifndef([_LT_PROG_ECHO_BACKSLASH], [AC_DEFUN([_LT_PROG_ECHO_BACKSLASH])]) m4_ifndef([_LT_PROG_F77], [AC_DEFUN([_LT_PROG_F77])]) m4_ifndef([_LT_PROG_FC], [AC_DEFUN([_LT_PROG_FC])]) m4_ifndef([_LT_PROG_CXX], [AC_DEFUN([_LT_PROG_CXX])]) xrdp-0.9.5/libpainter/m4/ax_require_defined.m4000644 001751 001751 00000002302 13127342056 021157 0ustar00metameta000000 000000 # =========================================================================== # https://www.gnu.org/software/autoconf-archive/ax_require_defined.html # =========================================================================== # # SYNOPSIS # # AX_REQUIRE_DEFINED(MACRO) # # DESCRIPTION # # AX_REQUIRE_DEFINED is a simple helper for making sure other macros have # been defined and thus are available for use. This avoids random issues # where a macro isn't expanded. Instead the configure script emits a # non-fatal: # # ./configure: line 1673: AX_CFLAGS_WARN_ALL: command not found # # It's like AC_REQUIRE except it doesn't expand the required macro. # # Here's an example: # # AX_REQUIRE_DEFINED([AX_CHECK_LINK_FLAG]) # # LICENSE # # Copyright (c) 2014 Mike Frysinger # # Copying and distribution of this file, with or without modification, are # permitted in any medium without royalty provided the copyright notice # and this notice are preserved. This file is offered as-is, without any # warranty. #serial 2 AC_DEFUN([AX_REQUIRE_DEFINED], [dnl m4_ifndef([$1], [m4_fatal([macro ]$1[ is not defined; is a m4 file missing?])]) ])dnl AX_REQUIRE_DEFINED xrdp-0.9.5/libpainter/m4/ax_check_compile_flag.m4000644 001751 001751 00000006403 13127342056 021611 0ustar00metameta000000 000000 # =========================================================================== # https://www.gnu.org/software/autoconf-archive/ax_check_compile_flag.html # =========================================================================== # # SYNOPSIS # # AX_CHECK_COMPILE_FLAG(FLAG, [ACTION-SUCCESS], [ACTION-FAILURE], [EXTRA-FLAGS], [INPUT]) # # DESCRIPTION # # Check whether the given FLAG works with the current language's compiler # or gives an error. (Warnings, however, are ignored) # # ACTION-SUCCESS/ACTION-FAILURE are shell commands to execute on # success/failure. # # If EXTRA-FLAGS is defined, it is added to the current language's default # flags (e.g. CFLAGS) when the check is done. The check is thus made with # the flags: "CFLAGS EXTRA-FLAGS FLAG". This can for example be used to # force the compiler to issue an error when a bad flag is given. # # INPUT gives an alternative input source to AC_COMPILE_IFELSE. # # NOTE: Implementation based on AX_CFLAGS_GCC_OPTION. Please keep this # macro in sync with AX_CHECK_{PREPROC,LINK}_FLAG. # # LICENSE # # Copyright (c) 2008 Guido U. Draheim # Copyright (c) 2011 Maarten Bosmans # # 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. # # You should have received a copy of the GNU General Public License along # with this program. If not, see . # # As a special exception, the respective Autoconf Macro's copyright owner # gives unlimited permission to copy, distribute and modify the configure # scripts that are the output of Autoconf when processing the Macro. You # need not follow the terms of the GNU General Public License when using # or distributing such scripts, even though portions of the text of the # Macro appear in them. The GNU General Public License (GPL) does govern # all other use of the material that constitutes the Autoconf Macro. # # This special exception to the GPL applies to versions of the Autoconf # Macro released by the Autoconf Archive. When you make and distribute a # modified version of the Autoconf Macro, you may extend this special # exception to the GPL to apply to your modified version as well. #serial 5 AC_DEFUN([AX_CHECK_COMPILE_FLAG], [AC_PREREQ(2.64)dnl for _AC_LANG_PREFIX and AS_VAR_IF AS_VAR_PUSHDEF([CACHEVAR],[ax_cv_check_[]_AC_LANG_ABBREV[]flags_$4_$1])dnl AC_CACHE_CHECK([whether _AC_LANG compiler accepts $1], CACHEVAR, [ ax_check_save_flags=$[]_AC_LANG_PREFIX[]FLAGS _AC_LANG_PREFIX[]FLAGS="$[]_AC_LANG_PREFIX[]FLAGS $4 $1" AC_COMPILE_IFELSE([m4_default([$5],[AC_LANG_PROGRAM()])], [AS_VAR_SET(CACHEVAR,[yes])], [AS_VAR_SET(CACHEVAR,[no])]) _AC_LANG_PREFIX[]FLAGS=$ax_check_save_flags]) AS_VAR_IF(CACHEVAR,yes, [m4_default([$2], :)], [m4_default([$3], :)]) AS_VAR_POPDEF([CACHEVAR])dnl ])dnl AX_CHECK_COMPILE_FLAGS xrdp-0.9.5/libpainter/m4/ax_cflags_warn_all.m4000644 001751 001751 00000011703 13127342056 021150 0ustar00metameta000000 000000 # =========================================================================== # https://www.gnu.org/software/autoconf-archive/ax_cflags_warn_all.html # =========================================================================== # # SYNOPSIS # # AX_CFLAGS_WARN_ALL [(shellvar [,default, [A/NA]])] # AX_CXXFLAGS_WARN_ALL [(shellvar [,default, [A/NA]])] # AX_FCFLAGS_WARN_ALL [(shellvar [,default, [A/NA]])] # # DESCRIPTION # # Try to find a compiler option that enables most reasonable warnings. # # For the GNU compiler it will be -Wall (and -ansi -pedantic) The result # is added to the shellvar being CFLAGS, CXXFLAGS, or FCFLAGS by default. # # Currently this macro knows about the GCC, Solaris, Digital Unix, AIX, # HP-UX, IRIX, NEC SX-5 (Super-UX 10), Cray J90 (Unicos 10.0.0.8), and # Intel compilers. For a given compiler, the Fortran flags are much more # experimental than their C equivalents. # # - $1 shell-variable-to-add-to : CFLAGS, CXXFLAGS, or FCFLAGS # - $2 add-value-if-not-found : nothing # - $3 action-if-found : add value to shellvariable # - $4 action-if-not-found : nothing # # NOTE: These macros depend on AX_APPEND_FLAG. # # LICENSE # # Copyright (c) 2008 Guido U. Draheim # Copyright (c) 2010 Rhys Ulerich # # 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. # # You should have received a copy of the GNU General Public License along # with this program. If not, see . # # As a special exception, the respective Autoconf Macro's copyright owner # gives unlimited permission to copy, distribute and modify the configure # scripts that are the output of Autoconf when processing the Macro. You # need not follow the terms of the GNU General Public License when using # or distributing such scripts, even though portions of the text of the # Macro appear in them. The GNU General Public License (GPL) does govern # all other use of the material that constitutes the Autoconf Macro. # # This special exception to the GPL applies to versions of the Autoconf # Macro released by the Autoconf Archive. When you make and distribute a # modified version of the Autoconf Macro, you may extend this special # exception to the GPL to apply to your modified version as well. #serial 16 AC_DEFUN([AX_FLAGS_WARN_ALL],[dnl AS_VAR_PUSHDEF([FLAGS],[_AC_LANG_PREFIX[]FLAGS])dnl AS_VAR_PUSHDEF([VAR],[ac_cv_[]_AC_LANG_ABBREV[]flags_warn_all])dnl AC_CACHE_CHECK([m4_ifval($1,$1,FLAGS) for maximum warnings], VAR,[VAR="no, unknown" ac_save_[]FLAGS="$[]FLAGS" for ac_arg dnl in "-warn all % -warn all" dnl Intel "-pedantic % -Wall" dnl GCC "-xstrconst % -v" dnl Solaris C "-std1 % -verbose -w0 -warnprotos" dnl Digital Unix "-qlanglvl=ansi % -qsrcmsg -qinfo=all:noppt:noppc:noobs:nocnd" dnl AIX "-ansi -ansiE % -fullwarn" dnl IRIX "+ESlit % +w1" dnl HP-UX C "-Xc % -pvctl[,]fullmsg" dnl NEC SX-5 (Super-UX 10) "-h conform % -h msglevel 2" dnl Cray C (Unicos) # do FLAGS="$ac_save_[]FLAGS "`echo $ac_arg | sed -e 's,%%.*,,' -e 's,%,,'` AC_COMPILE_IFELSE([AC_LANG_PROGRAM], [VAR=`echo $ac_arg | sed -e 's,.*% *,,'` ; break]) done FLAGS="$ac_save_[]FLAGS" ]) AS_VAR_POPDEF([FLAGS])dnl AX_REQUIRE_DEFINED([AX_APPEND_FLAG]) case ".$VAR" in .ok|.ok,*) m4_ifvaln($3,$3) ;; .|.no|.no,*) m4_default($4,[m4_ifval($2,[AX_APPEND_FLAG([$2], [$1])])]) ;; *) m4_default($3,[AX_APPEND_FLAG([$VAR], [$1])]) ;; esac AS_VAR_POPDEF([VAR])dnl ])dnl AX_FLAGS_WARN_ALL dnl implementation tactics: dnl the for-argument contains a list of options. The first part of dnl these does only exist to detect the compiler - usually it is dnl a global option to enable -ansi or -extrawarnings. All other dnl compilers will fail about it. That was needed since a lot of dnl compilers will give false positives for some option-syntax dnl like -Woption or -Xoption as they think of it is a pass-through dnl to later compile stages or something. The "%" is used as a dnl delimiter. A non-option comment can be given after "%%" marks dnl which will be shown but not added to the respective C/CXXFLAGS. AC_DEFUN([AX_CFLAGS_WARN_ALL],[dnl AC_LANG_PUSH([C]) AX_FLAGS_WARN_ALL([$1], [$2], [$3], [$4]) AC_LANG_POP([C]) ]) AC_DEFUN([AX_CXXFLAGS_WARN_ALL],[dnl AC_LANG_PUSH([C++]) AX_FLAGS_WARN_ALL([$1], [$2], [$3], [$4]) AC_LANG_POP([C++]) ]) AC_DEFUN([AX_FCFLAGS_WARN_ALL],[dnl AC_LANG_PUSH([Fortran]) AX_FLAGS_WARN_ALL([$1], [$2], [$3], [$4]) AC_LANG_POP([Fortran]) ]) xrdp-0.9.5/libpainter/m4/ltsugar.m4000644 001751 001751 00000010440 13220730731 017013 0ustar00metameta000000 000000 # ltsugar.m4 -- libtool m4 base layer. -*-Autoconf-*- # # Copyright (C) 2004-2005, 2007-2008, 2011-2015 Free Software # Foundation, Inc. # Written by Gary V. Vaughan, 2004 # # This file is free software; the Free Software Foundation gives # unlimited permission to copy and/or distribute it, with or without # modifications, as long as this notice is preserved. # serial 6 ltsugar.m4 # This is to help aclocal find these macros, as it can't see m4_define. AC_DEFUN([LTSUGAR_VERSION], [m4_if([0.1])]) # lt_join(SEP, ARG1, [ARG2...]) # ----------------------------- # Produce ARG1SEPARG2...SEPARGn, omitting [] arguments and their # associated separator. # Needed until we can rely on m4_join from Autoconf 2.62, since all earlier # versions in m4sugar had bugs. m4_define([lt_join], [m4_if([$#], [1], [], [$#], [2], [[$2]], [m4_if([$2], [], [], [[$2]_])$0([$1], m4_shift(m4_shift($@)))])]) m4_define([_lt_join], [m4_if([$#$2], [2], [], [m4_if([$2], [], [], [[$1$2]])$0([$1], m4_shift(m4_shift($@)))])]) # lt_car(LIST) # lt_cdr(LIST) # ------------ # Manipulate m4 lists. # These macros are necessary as long as will still need to support # Autoconf-2.59, which quotes differently. m4_define([lt_car], [[$1]]) m4_define([lt_cdr], [m4_if([$#], 0, [m4_fatal([$0: cannot be called without arguments])], [$#], 1, [], [m4_dquote(m4_shift($@))])]) m4_define([lt_unquote], $1) # lt_append(MACRO-NAME, STRING, [SEPARATOR]) # ------------------------------------------ # Redefine MACRO-NAME to hold its former content plus 'SEPARATOR''STRING'. # Note that neither SEPARATOR nor STRING are expanded; they are appended # to MACRO-NAME as is (leaving the expansion for when MACRO-NAME is invoked). # No SEPARATOR is output if MACRO-NAME was previously undefined (different # than defined and empty). # # This macro is needed until we can rely on Autoconf 2.62, since earlier # versions of m4sugar mistakenly expanded SEPARATOR but not STRING. m4_define([lt_append], [m4_define([$1], m4_ifdef([$1], [m4_defn([$1])[$3]])[$2])]) # lt_combine(SEP, PREFIX-LIST, INFIX, SUFFIX1, [SUFFIX2...]) # ---------------------------------------------------------- # Produce a SEP delimited list of all paired combinations of elements of # PREFIX-LIST with SUFFIX1 through SUFFIXn. Each element of the list # has the form PREFIXmINFIXSUFFIXn. # Needed until we can rely on m4_combine added in Autoconf 2.62. m4_define([lt_combine], [m4_if(m4_eval([$# > 3]), [1], [m4_pushdef([_Lt_sep], [m4_define([_Lt_sep], m4_defn([lt_car]))])]]dnl [[m4_foreach([_Lt_prefix], [$2], [m4_foreach([_Lt_suffix], ]m4_dquote(m4_dquote(m4_shift(m4_shift(m4_shift($@)))))[, [_Lt_sep([$1])[]m4_defn([_Lt_prefix])[$3]m4_defn([_Lt_suffix])])])])]) # lt_if_append_uniq(MACRO-NAME, VARNAME, [SEPARATOR], [UNIQ], [NOT-UNIQ]) # ----------------------------------------------------------------------- # Iff MACRO-NAME does not yet contain VARNAME, then append it (delimited # by SEPARATOR if supplied) and expand UNIQ, else NOT-UNIQ. m4_define([lt_if_append_uniq], [m4_ifdef([$1], [m4_if(m4_index([$3]m4_defn([$1])[$3], [$3$2$3]), [-1], [lt_append([$1], [$2], [$3])$4], [$5])], [lt_append([$1], [$2], [$3])$4])]) # lt_dict_add(DICT, KEY, VALUE) # ----------------------------- m4_define([lt_dict_add], [m4_define([$1($2)], [$3])]) # lt_dict_add_subkey(DICT, KEY, SUBKEY, VALUE) # -------------------------------------------- m4_define([lt_dict_add_subkey], [m4_define([$1($2:$3)], [$4])]) # lt_dict_fetch(DICT, KEY, [SUBKEY]) # ---------------------------------- m4_define([lt_dict_fetch], [m4_ifval([$3], m4_ifdef([$1($2:$3)], [m4_defn([$1($2:$3)])]), m4_ifdef([$1($2)], [m4_defn([$1($2)])]))]) # lt_if_dict_fetch(DICT, KEY, [SUBKEY], VALUE, IF-TRUE, [IF-FALSE]) # ----------------------------------------------------------------- m4_define([lt_if_dict_fetch], [m4_if(lt_dict_fetch([$1], [$2], [$3]), [$4], [$5], [$6])]) # lt_dict_filter(DICT, [SUBKEY], VALUE, [SEPARATOR], KEY, [...]) # -------------------------------------------------------------- m4_define([lt_dict_filter], [m4_if([$5], [], [], [lt_join(m4_quote(m4_default([$4], [[, ]])), lt_unquote(m4_split(m4_normalize(m4_foreach(_Lt_key, lt_car([m4_shiftn(4, $@)]), [lt_if_dict_fetch([$1], _Lt_key, [$2], [$3], [_Lt_key ])])))))])[]dnl ]) xrdp-0.9.5/libpainter/m4/libtool.m4000644 001751 001751 00001125073 13220730731 017010 0ustar00metameta000000 000000 # libtool.m4 - Configure libtool for the host system. -*-Autoconf-*- # # Copyright (C) 1996-2001, 2003-2015 Free Software Foundation, Inc. # Written by Gordon Matzigkeit, 1996 # # This file is free software; the Free Software Foundation gives # unlimited permission to copy and/or distribute it, with or without # modifications, as long as this notice is preserved. m4_define([_LT_COPYING], [dnl # Copyright (C) 2014 Free Software Foundation, Inc. # This is free software; see the source for copying conditions. There is NO # warranty; not even for MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. # GNU Libtool 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 2 of of the License, or # (at your option) any later version. # # As a special exception to the GNU General Public License, if you # distribute this file as part of a program or library that is built # using GNU Libtool, you may include this file under the same # distribution terms that you use for the rest of that program. # # GNU Libtool 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. # # You should have received a copy of the GNU General Public License # along with this program. If not, see . ]) # serial 58 LT_INIT # LT_PREREQ(VERSION) # ------------------ # Complain and exit if this libtool version is less that VERSION. m4_defun([LT_PREREQ], [m4_if(m4_version_compare(m4_defn([LT_PACKAGE_VERSION]), [$1]), -1, [m4_default([$3], [m4_fatal([Libtool version $1 or higher is required], 63)])], [$2])]) # _LT_CHECK_BUILDDIR # ------------------ # Complain if the absolute build directory name contains unusual characters m4_defun([_LT_CHECK_BUILDDIR], [case `pwd` in *\ * | *\ *) AC_MSG_WARN([Libtool does not cope well with whitespace in `pwd`]) ;; esac ]) # LT_INIT([OPTIONS]) # ------------------ AC_DEFUN([LT_INIT], [AC_PREREQ([2.62])dnl We use AC_PATH_PROGS_FEATURE_CHECK AC_REQUIRE([AC_CONFIG_AUX_DIR_DEFAULT])dnl AC_BEFORE([$0], [LT_LANG])dnl AC_BEFORE([$0], [LT_OUTPUT])dnl AC_BEFORE([$0], [LTDL_INIT])dnl m4_require([_LT_CHECK_BUILDDIR])dnl dnl Autoconf doesn't catch unexpanded LT_ macros by default: m4_pattern_forbid([^_?LT_[A-Z_]+$])dnl m4_pattern_allow([^(_LT_EOF|LT_DLGLOBAL|LT_DLLAZY_OR_NOW|LT_MULTI_MODULE)$])dnl dnl aclocal doesn't pull ltoptions.m4, ltsugar.m4, or ltversion.m4 dnl unless we require an AC_DEFUNed macro: AC_REQUIRE([LTOPTIONS_VERSION])dnl AC_REQUIRE([LTSUGAR_VERSION])dnl AC_REQUIRE([LTVERSION_VERSION])dnl AC_REQUIRE([LTOBSOLETE_VERSION])dnl m4_require([_LT_PROG_LTMAIN])dnl _LT_SHELL_INIT([SHELL=${CONFIG_SHELL-/bin/sh}]) dnl Parse OPTIONS _LT_SET_OPTIONS([$0], [$1]) # This can be used to rebuild libtool when needed LIBTOOL_DEPS=$ltmain # Always use our own libtool. LIBTOOL='$(SHELL) $(top_builddir)/libtool' AC_SUBST(LIBTOOL)dnl _LT_SETUP # Only expand once: m4_define([LT_INIT]) ])# LT_INIT # Old names: AU_ALIAS([AC_PROG_LIBTOOL], [LT_INIT]) AU_ALIAS([AM_PROG_LIBTOOL], [LT_INIT]) dnl aclocal-1.4 backwards compatibility: dnl AC_DEFUN([AC_PROG_LIBTOOL], []) dnl AC_DEFUN([AM_PROG_LIBTOOL], []) # _LT_PREPARE_CC_BASENAME # ----------------------- m4_defun([_LT_PREPARE_CC_BASENAME], [ # Calculate cc_basename. Skip known compiler wrappers and cross-prefix. func_cc_basename () { for cc_temp in @S|@*""; do case $cc_temp in compile | *[[\\/]]compile | ccache | *[[\\/]]ccache ) ;; distcc | *[[\\/]]distcc | purify | *[[\\/]]purify ) ;; \-*) ;; *) break;; esac done func_cc_basename_result=`$ECHO "$cc_temp" | $SED "s%.*/%%; s%^$host_alias-%%"` } ])# _LT_PREPARE_CC_BASENAME # _LT_CC_BASENAME(CC) # ------------------- # It would be clearer to call AC_REQUIREs from _LT_PREPARE_CC_BASENAME, # but that macro is also expanded into generated libtool script, which # arranges for $SED and $ECHO to be set by different means. m4_defun([_LT_CC_BASENAME], [m4_require([_LT_PREPARE_CC_BASENAME])dnl AC_REQUIRE([_LT_DECL_SED])dnl AC_REQUIRE([_LT_PROG_ECHO_BACKSLASH])dnl func_cc_basename $1 cc_basename=$func_cc_basename_result ]) # _LT_FILEUTILS_DEFAULTS # ---------------------- # It is okay to use these file commands and assume they have been set # sensibly after 'm4_require([_LT_FILEUTILS_DEFAULTS])'. m4_defun([_LT_FILEUTILS_DEFAULTS], [: ${CP="cp -f"} : ${MV="mv -f"} : ${RM="rm -f"} ])# _LT_FILEUTILS_DEFAULTS # _LT_SETUP # --------- m4_defun([_LT_SETUP], [AC_REQUIRE([AC_CANONICAL_HOST])dnl AC_REQUIRE([AC_CANONICAL_BUILD])dnl AC_REQUIRE([_LT_PREPARE_SED_QUOTE_VARS])dnl AC_REQUIRE([_LT_PROG_ECHO_BACKSLASH])dnl _LT_DECL([], [PATH_SEPARATOR], [1], [The PATH separator for the build system])dnl dnl _LT_DECL([], [host_alias], [0], [The host system])dnl _LT_DECL([], [host], [0])dnl _LT_DECL([], [host_os], [0])dnl dnl _LT_DECL([], [build_alias], [0], [The build system])dnl _LT_DECL([], [build], [0])dnl _LT_DECL([], [build_os], [0])dnl dnl AC_REQUIRE([AC_PROG_CC])dnl AC_REQUIRE([LT_PATH_LD])dnl AC_REQUIRE([LT_PATH_NM])dnl dnl AC_REQUIRE([AC_PROG_LN_S])dnl test -z "$LN_S" && LN_S="ln -s" _LT_DECL([], [LN_S], [1], [Whether we need soft or hard links])dnl dnl AC_REQUIRE([LT_CMD_MAX_LEN])dnl _LT_DECL([objext], [ac_objext], [0], [Object file suffix (normally "o")])dnl _LT_DECL([], [exeext], [0], [Executable file suffix (normally "")])dnl dnl m4_require([_LT_FILEUTILS_DEFAULTS])dnl m4_require([_LT_CHECK_SHELL_FEATURES])dnl m4_require([_LT_PATH_CONVERSION_FUNCTIONS])dnl m4_require([_LT_CMD_RELOAD])dnl m4_require([_LT_CHECK_MAGIC_METHOD])dnl m4_require([_LT_CHECK_SHAREDLIB_FROM_LINKLIB])dnl m4_require([_LT_CMD_OLD_ARCHIVE])dnl m4_require([_LT_CMD_GLOBAL_SYMBOLS])dnl m4_require([_LT_WITH_SYSROOT])dnl m4_require([_LT_CMD_TRUNCATE])dnl _LT_CONFIG_LIBTOOL_INIT([ # See if we are running on zsh, and set the options that allow our # commands through without removal of \ escapes INIT. if test -n "\${ZSH_VERSION+set}"; then setopt NO_GLOB_SUBST fi ]) if test -n "${ZSH_VERSION+set}"; then setopt NO_GLOB_SUBST fi _LT_CHECK_OBJDIR m4_require([_LT_TAG_COMPILER])dnl case $host_os in aix3*) # AIX sometimes has problems with the GCC collect2 program. For some # reason, if we set the COLLECT_NAMES environment variable, the problems # vanish in a puff of smoke. if test set != "${COLLECT_NAMES+set}"; then COLLECT_NAMES= export COLLECT_NAMES fi ;; esac # Global variables: ofile=libtool can_build_shared=yes # All known linkers require a '.a' archive for static linking (except MSVC, # which needs '.lib'). libext=a with_gnu_ld=$lt_cv_prog_gnu_ld old_CC=$CC old_CFLAGS=$CFLAGS # Set sane defaults for various variables test -z "$CC" && CC=cc test -z "$LTCC" && LTCC=$CC test -z "$LTCFLAGS" && LTCFLAGS=$CFLAGS test -z "$LD" && LD=ld test -z "$ac_objext" && ac_objext=o _LT_CC_BASENAME([$compiler]) # Only perform the check for file, if the check method requires it test -z "$MAGIC_CMD" && MAGIC_CMD=file case $deplibs_check_method in file_magic*) if test "$file_magic_cmd" = '$MAGIC_CMD'; then _LT_PATH_MAGIC fi ;; esac # Use C for the default configuration in the libtool script LT_SUPPORTED_TAG([CC]) _LT_LANG_C_CONFIG _LT_LANG_DEFAULT_CONFIG _LT_CONFIG_COMMANDS ])# _LT_SETUP # _LT_PREPARE_SED_QUOTE_VARS # -------------------------- # Define a few sed substitution that help us do robust quoting. m4_defun([_LT_PREPARE_SED_QUOTE_VARS], [# Backslashify metacharacters that are still active within # double-quoted strings. sed_quote_subst='s/\([["`$\\]]\)/\\\1/g' # Same as above, but do not quote variable references. double_quote_subst='s/\([["`\\]]\)/\\\1/g' # Sed substitution to delay expansion of an escaped shell variable in a # double_quote_subst'ed string. delay_variable_subst='s/\\\\\\\\\\\$/\\\\\\$/g' # Sed substitution to delay expansion of an escaped single quote. delay_single_quote_subst='s/'\''/'\'\\\\\\\'\''/g' # Sed substitution to avoid accidental globbing in evaled expressions no_glob_subst='s/\*/\\\*/g' ]) # _LT_PROG_LTMAIN # --------------- # Note that this code is called both from 'configure', and 'config.status' # now that we use AC_CONFIG_COMMANDS to generate libtool. Notably, # 'config.status' has no value for ac_aux_dir unless we are using Automake, # so we pass a copy along to make sure it has a sensible value anyway. m4_defun([_LT_PROG_LTMAIN], [m4_ifdef([AC_REQUIRE_AUX_FILE], [AC_REQUIRE_AUX_FILE([ltmain.sh])])dnl _LT_CONFIG_LIBTOOL_INIT([ac_aux_dir='$ac_aux_dir']) ltmain=$ac_aux_dir/ltmain.sh ])# _LT_PROG_LTMAIN ## ------------------------------------- ## ## Accumulate code for creating libtool. ## ## ------------------------------------- ## # So that we can recreate a full libtool script including additional # tags, we accumulate the chunks of code to send to AC_CONFIG_COMMANDS # in macros and then make a single call at the end using the 'libtool' # label. # _LT_CONFIG_LIBTOOL_INIT([INIT-COMMANDS]) # ---------------------------------------- # Register INIT-COMMANDS to be passed to AC_CONFIG_COMMANDS later. m4_define([_LT_CONFIG_LIBTOOL_INIT], [m4_ifval([$1], [m4_append([_LT_OUTPUT_LIBTOOL_INIT], [$1 ])])]) # Initialize. m4_define([_LT_OUTPUT_LIBTOOL_INIT]) # _LT_CONFIG_LIBTOOL([COMMANDS]) # ------------------------------ # Register COMMANDS to be passed to AC_CONFIG_COMMANDS later. m4_define([_LT_CONFIG_LIBTOOL], [m4_ifval([$1], [m4_append([_LT_OUTPUT_LIBTOOL_COMMANDS], [$1 ])])]) # Initialize. m4_define([_LT_OUTPUT_LIBTOOL_COMMANDS]) # _LT_CONFIG_SAVE_COMMANDS([COMMANDS], [INIT_COMMANDS]) # ----------------------------------------------------- m4_defun([_LT_CONFIG_SAVE_COMMANDS], [_LT_CONFIG_LIBTOOL([$1]) _LT_CONFIG_LIBTOOL_INIT([$2]) ]) # _LT_FORMAT_COMMENT([COMMENT]) # ----------------------------- # Add leading comment marks to the start of each line, and a trailing # full-stop to the whole comment if one is not present already. m4_define([_LT_FORMAT_COMMENT], [m4_ifval([$1], [ m4_bpatsubst([m4_bpatsubst([$1], [^ *], [# ])], [['`$\]], [\\\&])]m4_bmatch([$1], [[!?.]$], [], [.]) )]) ## ------------------------ ## ## FIXME: Eliminate VARNAME ## ## ------------------------ ## # _LT_DECL([CONFIGNAME], VARNAME, VALUE, [DESCRIPTION], [IS-TAGGED?]) # ------------------------------------------------------------------- # CONFIGNAME is the name given to the value in the libtool script. # VARNAME is the (base) name used in the configure script. # VALUE may be 0, 1 or 2 for a computed quote escaped value based on # VARNAME. Any other value will be used directly. m4_define([_LT_DECL], [lt_if_append_uniq([lt_decl_varnames], [$2], [, ], [lt_dict_add_subkey([lt_decl_dict], [$2], [libtool_name], [m4_ifval([$1], [$1], [$2])]) lt_dict_add_subkey([lt_decl_dict], [$2], [value], [$3]) m4_ifval([$4], [lt_dict_add_subkey([lt_decl_dict], [$2], [description], [$4])]) lt_dict_add_subkey([lt_decl_dict], [$2], [tagged?], [m4_ifval([$5], [yes], [no])])]) ]) # _LT_TAGDECL([CONFIGNAME], VARNAME, VALUE, [DESCRIPTION]) # -------------------------------------------------------- m4_define([_LT_TAGDECL], [_LT_DECL([$1], [$2], [$3], [$4], [yes])]) # lt_decl_tag_varnames([SEPARATOR], [VARNAME1...]) # ------------------------------------------------ m4_define([lt_decl_tag_varnames], [_lt_decl_filter([tagged?], [yes], $@)]) # _lt_decl_filter(SUBKEY, VALUE, [SEPARATOR], [VARNAME1..]) # --------------------------------------------------------- m4_define([_lt_decl_filter], [m4_case([$#], [0], [m4_fatal([$0: too few arguments: $#])], [1], [m4_fatal([$0: too few arguments: $#: $1])], [2], [lt_dict_filter([lt_decl_dict], [$1], [$2], [], lt_decl_varnames)], [3], [lt_dict_filter([lt_decl_dict], [$1], [$2], [$3], lt_decl_varnames)], [lt_dict_filter([lt_decl_dict], $@)])[]dnl ]) # lt_decl_quote_varnames([SEPARATOR], [VARNAME1...]) # -------------------------------------------------- m4_define([lt_decl_quote_varnames], [_lt_decl_filter([value], [1], $@)]) # lt_decl_dquote_varnames([SEPARATOR], [VARNAME1...]) # --------------------------------------------------- m4_define([lt_decl_dquote_varnames], [_lt_decl_filter([value], [2], $@)]) # lt_decl_varnames_tagged([SEPARATOR], [VARNAME1...]) # --------------------------------------------------- m4_define([lt_decl_varnames_tagged], [m4_assert([$# <= 2])dnl _$0(m4_quote(m4_default([$1], [[, ]])), m4_ifval([$2], [[$2]], [m4_dquote(lt_decl_tag_varnames)]), m4_split(m4_normalize(m4_quote(_LT_TAGS)), [ ]))]) m4_define([_lt_decl_varnames_tagged], [m4_ifval([$3], [lt_combine([$1], [$2], [_], $3)])]) # lt_decl_all_varnames([SEPARATOR], [VARNAME1...]) # ------------------------------------------------ m4_define([lt_decl_all_varnames], [_$0(m4_quote(m4_default([$1], [[, ]])), m4_if([$2], [], m4_quote(lt_decl_varnames), m4_quote(m4_shift($@))))[]dnl ]) m4_define([_lt_decl_all_varnames], [lt_join($@, lt_decl_varnames_tagged([$1], lt_decl_tag_varnames([[, ]], m4_shift($@))))dnl ]) # _LT_CONFIG_STATUS_DECLARE([VARNAME]) # ------------------------------------ # Quote a variable value, and forward it to 'config.status' so that its # declaration there will have the same value as in 'configure'. VARNAME # must have a single quote delimited value for this to work. m4_define([_LT_CONFIG_STATUS_DECLARE], [$1='`$ECHO "$][$1" | $SED "$delay_single_quote_subst"`']) # _LT_CONFIG_STATUS_DECLARATIONS # ------------------------------ # We delimit libtool config variables with single quotes, so when # we write them to config.status, we have to be sure to quote all # embedded single quotes properly. In configure, this macro expands # each variable declared with _LT_DECL (and _LT_TAGDECL) into: # # ='`$ECHO "$" | $SED "$delay_single_quote_subst"`' m4_defun([_LT_CONFIG_STATUS_DECLARATIONS], [m4_foreach([_lt_var], m4_quote(lt_decl_all_varnames), [m4_n([_LT_CONFIG_STATUS_DECLARE(_lt_var)])])]) # _LT_LIBTOOL_TAGS # ---------------- # Output comment and list of tags supported by the script m4_defun([_LT_LIBTOOL_TAGS], [_LT_FORMAT_COMMENT([The names of the tagged configurations supported by this script])dnl available_tags='_LT_TAGS'dnl ]) # _LT_LIBTOOL_DECLARE(VARNAME, [TAG]) # ----------------------------------- # Extract the dictionary values for VARNAME (optionally with TAG) and # expand to a commented shell variable setting: # # # Some comment about what VAR is for. # visible_name=$lt_internal_name m4_define([_LT_LIBTOOL_DECLARE], [_LT_FORMAT_COMMENT(m4_quote(lt_dict_fetch([lt_decl_dict], [$1], [description])))[]dnl m4_pushdef([_libtool_name], m4_quote(lt_dict_fetch([lt_decl_dict], [$1], [libtool_name])))[]dnl m4_case(m4_quote(lt_dict_fetch([lt_decl_dict], [$1], [value])), [0], [_libtool_name=[$]$1], [1], [_libtool_name=$lt_[]$1], [2], [_libtool_name=$lt_[]$1], [_libtool_name=lt_dict_fetch([lt_decl_dict], [$1], [value])])[]dnl m4_ifval([$2], [_$2])[]m4_popdef([_libtool_name])[]dnl ]) # _LT_LIBTOOL_CONFIG_VARS # ----------------------- # Produce commented declarations of non-tagged libtool config variables # suitable for insertion in the LIBTOOL CONFIG section of the 'libtool' # script. Tagged libtool config variables (even for the LIBTOOL CONFIG # section) are produced by _LT_LIBTOOL_TAG_VARS. m4_defun([_LT_LIBTOOL_CONFIG_VARS], [m4_foreach([_lt_var], m4_quote(_lt_decl_filter([tagged?], [no], [], lt_decl_varnames)), [m4_n([_LT_LIBTOOL_DECLARE(_lt_var)])])]) # _LT_LIBTOOL_TAG_VARS(TAG) # ------------------------- m4_define([_LT_LIBTOOL_TAG_VARS], [m4_foreach([_lt_var], m4_quote(lt_decl_tag_varnames), [m4_n([_LT_LIBTOOL_DECLARE(_lt_var, [$1])])])]) # _LT_TAGVAR(VARNAME, [TAGNAME]) # ------------------------------ m4_define([_LT_TAGVAR], [m4_ifval([$2], [$1_$2], [$1])]) # _LT_CONFIG_COMMANDS # ------------------- # Send accumulated output to $CONFIG_STATUS. Thanks to the lists of # variables for single and double quote escaping we saved from calls # to _LT_DECL, we can put quote escaped variables declarations # into 'config.status', and then the shell code to quote escape them in # for loops in 'config.status'. Finally, any additional code accumulated # from calls to _LT_CONFIG_LIBTOOL_INIT is expanded. m4_defun([_LT_CONFIG_COMMANDS], [AC_PROVIDE_IFELSE([LT_OUTPUT], dnl If the libtool generation code has been placed in $CONFIG_LT, dnl instead of duplicating it all over again into config.status, dnl then we will have config.status run $CONFIG_LT later, so it dnl needs to know what name is stored there: [AC_CONFIG_COMMANDS([libtool], [$SHELL $CONFIG_LT || AS_EXIT(1)], [CONFIG_LT='$CONFIG_LT'])], dnl If the libtool generation code is destined for config.status, dnl expand the accumulated commands and init code now: [AC_CONFIG_COMMANDS([libtool], [_LT_OUTPUT_LIBTOOL_COMMANDS], [_LT_OUTPUT_LIBTOOL_COMMANDS_INIT])]) ])#_LT_CONFIG_COMMANDS # Initialize. m4_define([_LT_OUTPUT_LIBTOOL_COMMANDS_INIT], [ # The HP-UX ksh and POSIX shell print the target directory to stdout # if CDPATH is set. (unset CDPATH) >/dev/null 2>&1 && unset CDPATH sed_quote_subst='$sed_quote_subst' double_quote_subst='$double_quote_subst' delay_variable_subst='$delay_variable_subst' _LT_CONFIG_STATUS_DECLARATIONS LTCC='$LTCC' LTCFLAGS='$LTCFLAGS' compiler='$compiler_DEFAULT' # A function that is used when there is no print builtin or printf. func_fallback_echo () { eval 'cat <<_LTECHO_EOF \$[]1 _LTECHO_EOF' } # Quote evaled strings. for var in lt_decl_all_varnames([[ \ ]], lt_decl_quote_varnames); do case \`eval \\\\\$ECHO \\\\""\\\\\$\$var"\\\\"\` in *[[\\\\\\\`\\"\\\$]]*) eval "lt_\$var=\\\\\\"\\\`\\\$ECHO \\"\\\$\$var\\" | \\\$SED \\"\\\$sed_quote_subst\\"\\\`\\\\\\"" ## exclude from sc_prohibit_nested_quotes ;; *) eval "lt_\$var=\\\\\\"\\\$\$var\\\\\\"" ;; esac done # Double-quote double-evaled strings. for var in lt_decl_all_varnames([[ \ ]], lt_decl_dquote_varnames); do case \`eval \\\\\$ECHO \\\\""\\\\\$\$var"\\\\"\` in *[[\\\\\\\`\\"\\\$]]*) eval "lt_\$var=\\\\\\"\\\`\\\$ECHO \\"\\\$\$var\\" | \\\$SED -e \\"\\\$double_quote_subst\\" -e \\"\\\$sed_quote_subst\\" -e \\"\\\$delay_variable_subst\\"\\\`\\\\\\"" ## exclude from sc_prohibit_nested_quotes ;; *) eval "lt_\$var=\\\\\\"\\\$\$var\\\\\\"" ;; esac done _LT_OUTPUT_LIBTOOL_INIT ]) # _LT_GENERATED_FILE_INIT(FILE, [COMMENT]) # ------------------------------------ # Generate a child script FILE with all initialization necessary to # reuse the environment learned by the parent script, and make the # file executable. If COMMENT is supplied, it is inserted after the # '#!' sequence but before initialization text begins. After this # macro, additional text can be appended to FILE to form the body of # the child script. The macro ends with non-zero status if the # file could not be fully written (such as if the disk is full). m4_ifdef([AS_INIT_GENERATED], [m4_defun([_LT_GENERATED_FILE_INIT],[AS_INIT_GENERATED($@)])], [m4_defun([_LT_GENERATED_FILE_INIT], [m4_require([AS_PREPARE])]dnl [m4_pushdef([AS_MESSAGE_LOG_FD])]dnl [lt_write_fail=0 cat >$1 <<_ASEOF || lt_write_fail=1 #! $SHELL # Generated by $as_me. $2 SHELL=\${CONFIG_SHELL-$SHELL} export SHELL _ASEOF cat >>$1 <<\_ASEOF || lt_write_fail=1 AS_SHELL_SANITIZE _AS_PREPARE exec AS_MESSAGE_FD>&1 _ASEOF test 0 = "$lt_write_fail" && chmod +x $1[]dnl m4_popdef([AS_MESSAGE_LOG_FD])])])# _LT_GENERATED_FILE_INIT # LT_OUTPUT # --------- # This macro allows early generation of the libtool script (before # AC_OUTPUT is called), incase it is used in configure for compilation # tests. AC_DEFUN([LT_OUTPUT], [: ${CONFIG_LT=./config.lt} AC_MSG_NOTICE([creating $CONFIG_LT]) _LT_GENERATED_FILE_INIT(["$CONFIG_LT"], [# Run this file to recreate a libtool stub with the current configuration.]) cat >>"$CONFIG_LT" <<\_LTEOF lt_cl_silent=false exec AS_MESSAGE_LOG_FD>>config.log { echo AS_BOX([Running $as_me.]) } >&AS_MESSAGE_LOG_FD lt_cl_help="\ '$as_me' creates a local libtool stub from the current configuration, for use in further configure time tests before the real libtool is generated. Usage: $[0] [[OPTIONS]] -h, --help print this help, then exit -V, --version print version number, then exit -q, --quiet do not print progress messages -d, --debug don't remove temporary files Report bugs to ." lt_cl_version="\ m4_ifset([AC_PACKAGE_NAME], [AC_PACKAGE_NAME ])config.lt[]dnl m4_ifset([AC_PACKAGE_VERSION], [ AC_PACKAGE_VERSION]) configured by $[0], generated by m4_PACKAGE_STRING. Copyright (C) 2011 Free Software Foundation, Inc. This config.lt script is free software; the Free Software Foundation gives unlimited permision to copy, distribute and modify it." while test 0 != $[#] do case $[1] in --version | --v* | -V ) echo "$lt_cl_version"; exit 0 ;; --help | --h* | -h ) echo "$lt_cl_help"; exit 0 ;; --debug | --d* | -d ) debug=: ;; --quiet | --q* | --silent | --s* | -q ) lt_cl_silent=: ;; -*) AC_MSG_ERROR([unrecognized option: $[1] Try '$[0] --help' for more information.]) ;; *) AC_MSG_ERROR([unrecognized argument: $[1] Try '$[0] --help' for more information.]) ;; esac shift done if $lt_cl_silent; then exec AS_MESSAGE_FD>/dev/null fi _LTEOF cat >>"$CONFIG_LT" <<_LTEOF _LT_OUTPUT_LIBTOOL_COMMANDS_INIT _LTEOF cat >>"$CONFIG_LT" <<\_LTEOF AC_MSG_NOTICE([creating $ofile]) _LT_OUTPUT_LIBTOOL_COMMANDS AS_EXIT(0) _LTEOF chmod +x "$CONFIG_LT" # configure is writing to config.log, but config.lt does its own redirection, # appending to config.log, which fails on DOS, as config.log is still kept # open by configure. Here we exec the FD to /dev/null, effectively closing # config.log, so it can be properly (re)opened and appended to by config.lt. lt_cl_success=: test yes = "$silent" && lt_config_lt_args="$lt_config_lt_args --quiet" exec AS_MESSAGE_LOG_FD>/dev/null $SHELL "$CONFIG_LT" $lt_config_lt_args || lt_cl_success=false exec AS_MESSAGE_LOG_FD>>config.log $lt_cl_success || AS_EXIT(1) ])# LT_OUTPUT # _LT_CONFIG(TAG) # --------------- # If TAG is the built-in tag, create an initial libtool script with a # default configuration from the untagged config vars. Otherwise add code # to config.status for appending the configuration named by TAG from the # matching tagged config vars. m4_defun([_LT_CONFIG], [m4_require([_LT_FILEUTILS_DEFAULTS])dnl _LT_CONFIG_SAVE_COMMANDS([ m4_define([_LT_TAG], m4_if([$1], [], [C], [$1]))dnl m4_if(_LT_TAG, [C], [ # See if we are running on zsh, and set the options that allow our # commands through without removal of \ escapes. if test -n "${ZSH_VERSION+set}"; then setopt NO_GLOB_SUBST fi cfgfile=${ofile}T trap "$RM \"$cfgfile\"; exit 1" 1 2 15 $RM "$cfgfile" cat <<_LT_EOF >> "$cfgfile" #! $SHELL # Generated automatically by $as_me ($PACKAGE) $VERSION # Libtool was configured on host `(hostname || uname -n) 2>/dev/null | sed 1q`: # NOTE: Changes made to this file will be lost: look at ltmain.sh. # Provide generalized library-building support services. # Written by Gordon Matzigkeit, 1996 _LT_COPYING _LT_LIBTOOL_TAGS # Configured defaults for sys_lib_dlsearch_path munging. : \${LT_SYS_LIBRARY_PATH="$configure_time_lt_sys_library_path"} # ### BEGIN LIBTOOL CONFIG _LT_LIBTOOL_CONFIG_VARS _LT_LIBTOOL_TAG_VARS # ### END LIBTOOL CONFIG _LT_EOF cat <<'_LT_EOF' >> "$cfgfile" # ### BEGIN FUNCTIONS SHARED WITH CONFIGURE _LT_PREPARE_MUNGE_PATH_LIST _LT_PREPARE_CC_BASENAME # ### END FUNCTIONS SHARED WITH CONFIGURE _LT_EOF case $host_os in aix3*) cat <<\_LT_EOF >> "$cfgfile" # AIX sometimes has problems with the GCC collect2 program. For some # reason, if we set the COLLECT_NAMES environment variable, the problems # vanish in a puff of smoke. if test set != "${COLLECT_NAMES+set}"; then COLLECT_NAMES= export COLLECT_NAMES fi _LT_EOF ;; esac _LT_PROG_LTMAIN # We use sed instead of cat because bash on DJGPP gets confused if # if finds mixed CR/LF and LF-only lines. Since sed operates in # text mode, it properly converts lines to CR/LF. This bash problem # is reportedly fixed, but why not run on old versions too? sed '$q' "$ltmain" >> "$cfgfile" \ || (rm -f "$cfgfile"; exit 1) mv -f "$cfgfile" "$ofile" || (rm -f "$ofile" && cp "$cfgfile" "$ofile" && rm -f "$cfgfile") chmod +x "$ofile" ], [cat <<_LT_EOF >> "$ofile" dnl Unfortunately we have to use $1 here, since _LT_TAG is not expanded dnl in a comment (ie after a #). # ### BEGIN LIBTOOL TAG CONFIG: $1 _LT_LIBTOOL_TAG_VARS(_LT_TAG) # ### END LIBTOOL TAG CONFIG: $1 _LT_EOF ])dnl /m4_if ], [m4_if([$1], [], [ PACKAGE='$PACKAGE' VERSION='$VERSION' RM='$RM' ofile='$ofile'], []) ])dnl /_LT_CONFIG_SAVE_COMMANDS ])# _LT_CONFIG # LT_SUPPORTED_TAG(TAG) # --------------------- # Trace this macro to discover what tags are supported by the libtool # --tag option, using: # autoconf --trace 'LT_SUPPORTED_TAG:$1' AC_DEFUN([LT_SUPPORTED_TAG], []) # C support is built-in for now m4_define([_LT_LANG_C_enabled], []) m4_define([_LT_TAGS], []) # LT_LANG(LANG) # ------------- # Enable libtool support for the given language if not already enabled. AC_DEFUN([LT_LANG], [AC_BEFORE([$0], [LT_OUTPUT])dnl m4_case([$1], [C], [_LT_LANG(C)], [C++], [_LT_LANG(CXX)], [Go], [_LT_LANG(GO)], [Java], [_LT_LANG(GCJ)], [Fortran 77], [_LT_LANG(F77)], [Fortran], [_LT_LANG(FC)], [Windows Resource], [_LT_LANG(RC)], [m4_ifdef([_LT_LANG_]$1[_CONFIG], [_LT_LANG($1)], [m4_fatal([$0: unsupported language: "$1"])])])dnl ])# LT_LANG # _LT_LANG(LANGNAME) # ------------------ m4_defun([_LT_LANG], [m4_ifdef([_LT_LANG_]$1[_enabled], [], [LT_SUPPORTED_TAG([$1])dnl m4_append([_LT_TAGS], [$1 ])dnl m4_define([_LT_LANG_]$1[_enabled], [])dnl _LT_LANG_$1_CONFIG($1)])dnl ])# _LT_LANG m4_ifndef([AC_PROG_GO], [ ############################################################ # NOTE: This macro has been submitted for inclusion into # # GNU Autoconf as AC_PROG_GO. When it is available in # # a released version of Autoconf we should remove this # # macro and use it instead. # ############################################################ m4_defun([AC_PROG_GO], [AC_LANG_PUSH(Go)dnl AC_ARG_VAR([GOC], [Go compiler command])dnl AC_ARG_VAR([GOFLAGS], [Go compiler flags])dnl _AC_ARG_VAR_LDFLAGS()dnl AC_CHECK_TOOL(GOC, gccgo) if test -z "$GOC"; then if test -n "$ac_tool_prefix"; then AC_CHECK_PROG(GOC, [${ac_tool_prefix}gccgo], [${ac_tool_prefix}gccgo]) fi fi if test -z "$GOC"; then AC_CHECK_PROG(GOC, gccgo, gccgo, false) fi ])#m4_defun ])#m4_ifndef # _LT_LANG_DEFAULT_CONFIG # ----------------------- m4_defun([_LT_LANG_DEFAULT_CONFIG], [AC_PROVIDE_IFELSE([AC_PROG_CXX], [LT_LANG(CXX)], [m4_define([AC_PROG_CXX], defn([AC_PROG_CXX])[LT_LANG(CXX)])]) AC_PROVIDE_IFELSE([AC_PROG_F77], [LT_LANG(F77)], [m4_define([AC_PROG_F77], defn([AC_PROG_F77])[LT_LANG(F77)])]) AC_PROVIDE_IFELSE([AC_PROG_FC], [LT_LANG(FC)], [m4_define([AC_PROG_FC], defn([AC_PROG_FC])[LT_LANG(FC)])]) dnl The call to [A][M_PROG_GCJ] is quoted like that to stop aclocal dnl pulling things in needlessly. AC_PROVIDE_IFELSE([AC_PROG_GCJ], [LT_LANG(GCJ)], [AC_PROVIDE_IFELSE([A][M_PROG_GCJ], [LT_LANG(GCJ)], [AC_PROVIDE_IFELSE([LT_PROG_GCJ], [LT_LANG(GCJ)], [m4_ifdef([AC_PROG_GCJ], [m4_define([AC_PROG_GCJ], defn([AC_PROG_GCJ])[LT_LANG(GCJ)])]) m4_ifdef([A][M_PROG_GCJ], [m4_define([A][M_PROG_GCJ], defn([A][M_PROG_GCJ])[LT_LANG(GCJ)])]) m4_ifdef([LT_PROG_GCJ], [m4_define([LT_PROG_GCJ], defn([LT_PROG_GCJ])[LT_LANG(GCJ)])])])])]) AC_PROVIDE_IFELSE([AC_PROG_GO], [LT_LANG(GO)], [m4_define([AC_PROG_GO], defn([AC_PROG_GO])[LT_LANG(GO)])]) AC_PROVIDE_IFELSE([LT_PROG_RC], [LT_LANG(RC)], [m4_define([LT_PROG_RC], defn([LT_PROG_RC])[LT_LANG(RC)])]) ])# _LT_LANG_DEFAULT_CONFIG # Obsolete macros: AU_DEFUN([AC_LIBTOOL_CXX], [LT_LANG(C++)]) AU_DEFUN([AC_LIBTOOL_F77], [LT_LANG(Fortran 77)]) AU_DEFUN([AC_LIBTOOL_FC], [LT_LANG(Fortran)]) AU_DEFUN([AC_LIBTOOL_GCJ], [LT_LANG(Java)]) AU_DEFUN([AC_LIBTOOL_RC], [LT_LANG(Windows Resource)]) dnl aclocal-1.4 backwards compatibility: dnl AC_DEFUN([AC_LIBTOOL_CXX], []) dnl AC_DEFUN([AC_LIBTOOL_F77], []) dnl AC_DEFUN([AC_LIBTOOL_FC], []) dnl AC_DEFUN([AC_LIBTOOL_GCJ], []) dnl AC_DEFUN([AC_LIBTOOL_RC], []) # _LT_TAG_COMPILER # ---------------- m4_defun([_LT_TAG_COMPILER], [AC_REQUIRE([AC_PROG_CC])dnl _LT_DECL([LTCC], [CC], [1], [A C compiler])dnl _LT_DECL([LTCFLAGS], [CFLAGS], [1], [LTCC compiler flags])dnl _LT_TAGDECL([CC], [compiler], [1], [A language specific compiler])dnl _LT_TAGDECL([with_gcc], [GCC], [0], [Is the compiler the GNU compiler?])dnl # If no C compiler was specified, use CC. LTCC=${LTCC-"$CC"} # If no C compiler flags were specified, use CFLAGS. LTCFLAGS=${LTCFLAGS-"$CFLAGS"} # Allow CC to be a program name with arguments. compiler=$CC ])# _LT_TAG_COMPILER # _LT_COMPILER_BOILERPLATE # ------------------------ # Check for compiler boilerplate output or warnings with # the simple compiler test code. m4_defun([_LT_COMPILER_BOILERPLATE], [m4_require([_LT_DECL_SED])dnl ac_outfile=conftest.$ac_objext echo "$lt_simple_compile_test_code" >conftest.$ac_ext eval "$ac_compile" 2>&1 >/dev/null | $SED '/^$/d; /^ *+/d' >conftest.err _lt_compiler_boilerplate=`cat conftest.err` $RM conftest* ])# _LT_COMPILER_BOILERPLATE # _LT_LINKER_BOILERPLATE # ---------------------- # Check for linker boilerplate output or warnings with # the simple link test code. m4_defun([_LT_LINKER_BOILERPLATE], [m4_require([_LT_DECL_SED])dnl ac_outfile=conftest.$ac_objext echo "$lt_simple_link_test_code" >conftest.$ac_ext eval "$ac_link" 2>&1 >/dev/null | $SED '/^$/d; /^ *+/d' >conftest.err _lt_linker_boilerplate=`cat conftest.err` $RM -r conftest* ])# _LT_LINKER_BOILERPLATE # _LT_REQUIRED_DARWIN_CHECKS # ------------------------- m4_defun_once([_LT_REQUIRED_DARWIN_CHECKS],[ case $host_os in rhapsody* | darwin*) AC_CHECK_TOOL([DSYMUTIL], [dsymutil], [:]) AC_CHECK_TOOL([NMEDIT], [nmedit], [:]) AC_CHECK_TOOL([LIPO], [lipo], [:]) AC_CHECK_TOOL([OTOOL], [otool], [:]) AC_CHECK_TOOL([OTOOL64], [otool64], [:]) _LT_DECL([], [DSYMUTIL], [1], [Tool to manipulate archived DWARF debug symbol files on Mac OS X]) _LT_DECL([], [NMEDIT], [1], [Tool to change global to local symbols on Mac OS X]) _LT_DECL([], [LIPO], [1], [Tool to manipulate fat objects and archives on Mac OS X]) _LT_DECL([], [OTOOL], [1], [ldd/readelf like tool for Mach-O binaries on Mac OS X]) _LT_DECL([], [OTOOL64], [1], [ldd/readelf like tool for 64 bit Mach-O binaries on Mac OS X 10.4]) AC_CACHE_CHECK([for -single_module linker flag],[lt_cv_apple_cc_single_mod], [lt_cv_apple_cc_single_mod=no if test -z "$LT_MULTI_MODULE"; then # By default we will add the -single_module flag. You can override # by either setting the environment variable LT_MULTI_MODULE # non-empty at configure time, or by adding -multi_module to the # link flags. rm -rf libconftest.dylib* echo "int foo(void){return 1;}" > conftest.c echo "$LTCC $LTCFLAGS $LDFLAGS -o libconftest.dylib \ -dynamiclib -Wl,-single_module conftest.c" >&AS_MESSAGE_LOG_FD $LTCC $LTCFLAGS $LDFLAGS -o libconftest.dylib \ -dynamiclib -Wl,-single_module conftest.c 2>conftest.err _lt_result=$? # If there is a non-empty error log, and "single_module" # appears in it, assume the flag caused a linker warning if test -s conftest.err && $GREP single_module conftest.err; then cat conftest.err >&AS_MESSAGE_LOG_FD # Otherwise, if the output was created with a 0 exit code from # the compiler, it worked. elif test -f libconftest.dylib && test 0 = "$_lt_result"; then lt_cv_apple_cc_single_mod=yes else cat conftest.err >&AS_MESSAGE_LOG_FD fi rm -rf libconftest.dylib* rm -f conftest.* fi]) AC_CACHE_CHECK([for -exported_symbols_list linker flag], [lt_cv_ld_exported_symbols_list], [lt_cv_ld_exported_symbols_list=no save_LDFLAGS=$LDFLAGS echo "_main" > conftest.sym LDFLAGS="$LDFLAGS -Wl,-exported_symbols_list,conftest.sym" AC_LINK_IFELSE([AC_LANG_PROGRAM([],[])], [lt_cv_ld_exported_symbols_list=yes], [lt_cv_ld_exported_symbols_list=no]) LDFLAGS=$save_LDFLAGS ]) AC_CACHE_CHECK([for -force_load linker flag],[lt_cv_ld_force_load], [lt_cv_ld_force_load=no cat > conftest.c << _LT_EOF int forced_loaded() { return 2;} _LT_EOF echo "$LTCC $LTCFLAGS -c -o conftest.o conftest.c" >&AS_MESSAGE_LOG_FD $LTCC $LTCFLAGS -c -o conftest.o conftest.c 2>&AS_MESSAGE_LOG_FD echo "$AR cru libconftest.a conftest.o" >&AS_MESSAGE_LOG_FD $AR cru libconftest.a conftest.o 2>&AS_MESSAGE_LOG_FD echo "$RANLIB libconftest.a" >&AS_MESSAGE_LOG_FD $RANLIB libconftest.a 2>&AS_MESSAGE_LOG_FD cat > conftest.c << _LT_EOF int main() { return 0;} _LT_EOF echo "$LTCC $LTCFLAGS $LDFLAGS -o conftest conftest.c -Wl,-force_load,./libconftest.a" >&AS_MESSAGE_LOG_FD $LTCC $LTCFLAGS $LDFLAGS -o conftest conftest.c -Wl,-force_load,./libconftest.a 2>conftest.err _lt_result=$? if test -s conftest.err && $GREP force_load conftest.err; then cat conftest.err >&AS_MESSAGE_LOG_FD elif test -f conftest && test 0 = "$_lt_result" && $GREP forced_load conftest >/dev/null 2>&1; then lt_cv_ld_force_load=yes else cat conftest.err >&AS_MESSAGE_LOG_FD fi rm -f conftest.err libconftest.a conftest conftest.c rm -rf conftest.dSYM ]) case $host_os in rhapsody* | darwin1.[[012]]) _lt_dar_allow_undefined='$wl-undefined ${wl}suppress' ;; darwin1.*) _lt_dar_allow_undefined='$wl-flat_namespace $wl-undefined ${wl}suppress' ;; darwin*) # darwin 5.x on # if running on 10.5 or later, the deployment target defaults # to the OS version, if on x86, and 10.4, the deployment # target defaults to 10.4. Don't you love it? case ${MACOSX_DEPLOYMENT_TARGET-10.0},$host in 10.0,*86*-darwin8*|10.0,*-darwin[[91]]*) _lt_dar_allow_undefined='$wl-undefined ${wl}dynamic_lookup' ;; 10.[[012]][[,.]]*) _lt_dar_allow_undefined='$wl-flat_namespace $wl-undefined ${wl}suppress' ;; 10.*) _lt_dar_allow_undefined='$wl-undefined ${wl}dynamic_lookup' ;; esac ;; esac if test yes = "$lt_cv_apple_cc_single_mod"; then _lt_dar_single_mod='$single_module' fi if test yes = "$lt_cv_ld_exported_symbols_list"; then _lt_dar_export_syms=' $wl-exported_symbols_list,$output_objdir/$libname-symbols.expsym' else _lt_dar_export_syms='~$NMEDIT -s $output_objdir/$libname-symbols.expsym $lib' fi if test : != "$DSYMUTIL" && test no = "$lt_cv_ld_force_load"; then _lt_dsymutil='~$DSYMUTIL $lib || :' else _lt_dsymutil= fi ;; esac ]) # _LT_DARWIN_LINKER_FEATURES([TAG]) # --------------------------------- # Checks for linker and compiler features on darwin m4_defun([_LT_DARWIN_LINKER_FEATURES], [ m4_require([_LT_REQUIRED_DARWIN_CHECKS]) _LT_TAGVAR(archive_cmds_need_lc, $1)=no _LT_TAGVAR(hardcode_direct, $1)=no _LT_TAGVAR(hardcode_automatic, $1)=yes _LT_TAGVAR(hardcode_shlibpath_var, $1)=unsupported if test yes = "$lt_cv_ld_force_load"; then _LT_TAGVAR(whole_archive_flag_spec, $1)='`for conv in $convenience\"\"; do test -n \"$conv\" && new_convenience=\"$new_convenience $wl-force_load,$conv\"; done; func_echo_all \"$new_convenience\"`' m4_case([$1], [F77], [_LT_TAGVAR(compiler_needs_object, $1)=yes], [FC], [_LT_TAGVAR(compiler_needs_object, $1)=yes]) else _LT_TAGVAR(whole_archive_flag_spec, $1)='' fi _LT_TAGVAR(link_all_deplibs, $1)=yes _LT_TAGVAR(allow_undefined_flag, $1)=$_lt_dar_allow_undefined case $cc_basename in ifort*|nagfor*) _lt_dar_can_shared=yes ;; *) _lt_dar_can_shared=$GCC ;; esac if test yes = "$_lt_dar_can_shared"; then output_verbose_link_cmd=func_echo_all _LT_TAGVAR(archive_cmds, $1)="\$CC -dynamiclib \$allow_undefined_flag -o \$lib \$libobjs \$deplibs \$compiler_flags -install_name \$rpath/\$soname \$verstring $_lt_dar_single_mod$_lt_dsymutil" _LT_TAGVAR(module_cmds, $1)="\$CC \$allow_undefined_flag -o \$lib -bundle \$libobjs \$deplibs \$compiler_flags$_lt_dsymutil" _LT_TAGVAR(archive_expsym_cmds, $1)="sed 's|^|_|' < \$export_symbols > \$output_objdir/\$libname-symbols.expsym~\$CC -dynamiclib \$allow_undefined_flag -o \$lib \$libobjs \$deplibs \$compiler_flags -install_name \$rpath/\$soname \$verstring $_lt_dar_single_mod$_lt_dar_export_syms$_lt_dsymutil" _LT_TAGVAR(module_expsym_cmds, $1)="sed -e 's|^|_|' < \$export_symbols > \$output_objdir/\$libname-symbols.expsym~\$CC \$allow_undefined_flag -o \$lib -bundle \$libobjs \$deplibs \$compiler_flags$_lt_dar_export_syms$_lt_dsymutil" m4_if([$1], [CXX], [ if test yes != "$lt_cv_apple_cc_single_mod"; then _LT_TAGVAR(archive_cmds, $1)="\$CC -r -keep_private_externs -nostdlib -o \$lib-master.o \$libobjs~\$CC -dynamiclib \$allow_undefined_flag -o \$lib \$lib-master.o \$deplibs \$compiler_flags -install_name \$rpath/\$soname \$verstring$_lt_dsymutil" _LT_TAGVAR(archive_expsym_cmds, $1)="sed 's|^|_|' < \$export_symbols > \$output_objdir/\$libname-symbols.expsym~\$CC -r -keep_private_externs -nostdlib -o \$lib-master.o \$libobjs~\$CC -dynamiclib \$allow_undefined_flag -o \$lib \$lib-master.o \$deplibs \$compiler_flags -install_name \$rpath/\$soname \$verstring$_lt_dar_export_syms$_lt_dsymutil" fi ],[]) else _LT_TAGVAR(ld_shlibs, $1)=no fi ]) # _LT_SYS_MODULE_PATH_AIX([TAGNAME]) # ---------------------------------- # Links a minimal program and checks the executable # for the system default hardcoded library path. In most cases, # this is /usr/lib:/lib, but when the MPI compilers are used # the location of the communication and MPI libs are included too. # If we don't find anything, use the default library path according # to the aix ld manual. # Store the results from the different compilers for each TAGNAME. # Allow to override them for all tags through lt_cv_aix_libpath. m4_defun([_LT_SYS_MODULE_PATH_AIX], [m4_require([_LT_DECL_SED])dnl if test set = "${lt_cv_aix_libpath+set}"; then aix_libpath=$lt_cv_aix_libpath else AC_CACHE_VAL([_LT_TAGVAR([lt_cv_aix_libpath_], [$1])], [AC_LINK_IFELSE([AC_LANG_PROGRAM],[ lt_aix_libpath_sed='[ /Import File Strings/,/^$/ { /^0/ { s/^0 *\([^ ]*\) *$/\1/ p } }]' _LT_TAGVAR([lt_cv_aix_libpath_], [$1])=`dump -H conftest$ac_exeext 2>/dev/null | $SED -n -e "$lt_aix_libpath_sed"` # Check for a 64-bit object if we didn't find anything. if test -z "$_LT_TAGVAR([lt_cv_aix_libpath_], [$1])"; then _LT_TAGVAR([lt_cv_aix_libpath_], [$1])=`dump -HX64 conftest$ac_exeext 2>/dev/null | $SED -n -e "$lt_aix_libpath_sed"` fi],[]) if test -z "$_LT_TAGVAR([lt_cv_aix_libpath_], [$1])"; then _LT_TAGVAR([lt_cv_aix_libpath_], [$1])=/usr/lib:/lib fi ]) aix_libpath=$_LT_TAGVAR([lt_cv_aix_libpath_], [$1]) fi ])# _LT_SYS_MODULE_PATH_AIX # _LT_SHELL_INIT(ARG) # ------------------- m4_define([_LT_SHELL_INIT], [m4_divert_text([M4SH-INIT], [$1 ])])# _LT_SHELL_INIT # _LT_PROG_ECHO_BACKSLASH # ----------------------- # Find how we can fake an echo command that does not interpret backslash. # In particular, with Autoconf 2.60 or later we add some code to the start # of the generated configure script that will find a shell with a builtin # printf (that we can use as an echo command). m4_defun([_LT_PROG_ECHO_BACKSLASH], [ECHO='\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\' ECHO=$ECHO$ECHO$ECHO$ECHO$ECHO ECHO=$ECHO$ECHO$ECHO$ECHO$ECHO$ECHO AC_MSG_CHECKING([how to print strings]) # Test print first, because it will be a builtin if present. if test "X`( print -r -- -n ) 2>/dev/null`" = X-n && \ test "X`print -r -- $ECHO 2>/dev/null`" = "X$ECHO"; then ECHO='print -r --' elif test "X`printf %s $ECHO 2>/dev/null`" = "X$ECHO"; then ECHO='printf %s\n' else # Use this function as a fallback that always works. func_fallback_echo () { eval 'cat <<_LTECHO_EOF $[]1 _LTECHO_EOF' } ECHO='func_fallback_echo' fi # func_echo_all arg... # Invoke $ECHO with all args, space-separated. func_echo_all () { $ECHO "$*" } case $ECHO in printf*) AC_MSG_RESULT([printf]) ;; print*) AC_MSG_RESULT([print -r]) ;; *) AC_MSG_RESULT([cat]) ;; esac m4_ifdef([_AS_DETECT_SUGGESTED], [_AS_DETECT_SUGGESTED([ test -n "${ZSH_VERSION+set}${BASH_VERSION+set}" || ( ECHO='\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\' ECHO=$ECHO$ECHO$ECHO$ECHO$ECHO ECHO=$ECHO$ECHO$ECHO$ECHO$ECHO$ECHO PATH=/empty FPATH=/empty; export PATH FPATH test "X`printf %s $ECHO`" = "X$ECHO" \ || test "X`print -r -- $ECHO`" = "X$ECHO" )])]) _LT_DECL([], [SHELL], [1], [Shell to use when invoking shell scripts]) _LT_DECL([], [ECHO], [1], [An echo program that protects backslashes]) ])# _LT_PROG_ECHO_BACKSLASH # _LT_WITH_SYSROOT # ---------------- AC_DEFUN([_LT_WITH_SYSROOT], [AC_MSG_CHECKING([for sysroot]) AC_ARG_WITH([sysroot], [AS_HELP_STRING([--with-sysroot@<:@=DIR@:>@], [Search for dependent libraries within DIR (or the compiler's sysroot if not specified).])], [], [with_sysroot=no]) dnl lt_sysroot will always be passed unquoted. We quote it here dnl in case the user passed a directory name. lt_sysroot= case $with_sysroot in #( yes) if test yes = "$GCC"; then lt_sysroot=`$CC --print-sysroot 2>/dev/null` fi ;; #( /*) lt_sysroot=`echo "$with_sysroot" | sed -e "$sed_quote_subst"` ;; #( no|'') ;; #( *) AC_MSG_RESULT([$with_sysroot]) AC_MSG_ERROR([The sysroot must be an absolute path.]) ;; esac AC_MSG_RESULT([${lt_sysroot:-no}]) _LT_DECL([], [lt_sysroot], [0], [The root where to search for ]dnl [dependent libraries, and where our libraries should be installed.])]) # _LT_ENABLE_LOCK # --------------- m4_defun([_LT_ENABLE_LOCK], [AC_ARG_ENABLE([libtool-lock], [AS_HELP_STRING([--disable-libtool-lock], [avoid locking (might break parallel builds)])]) test no = "$enable_libtool_lock" || enable_libtool_lock=yes # Some flags need to be propagated to the compiler or linker for good # libtool support. case $host in ia64-*-hpux*) # Find out what ABI is being produced by ac_compile, and set mode # options accordingly. echo 'int i;' > conftest.$ac_ext if AC_TRY_EVAL(ac_compile); then case `/usr/bin/file conftest.$ac_objext` in *ELF-32*) HPUX_IA64_MODE=32 ;; *ELF-64*) HPUX_IA64_MODE=64 ;; esac fi rm -rf conftest* ;; *-*-irix6*) # Find out what ABI is being produced by ac_compile, and set linker # options accordingly. echo '[#]line '$LINENO' "configure"' > conftest.$ac_ext if AC_TRY_EVAL(ac_compile); then if test yes = "$lt_cv_prog_gnu_ld"; then case `/usr/bin/file conftest.$ac_objext` in *32-bit*) LD="${LD-ld} -melf32bsmip" ;; *N32*) LD="${LD-ld} -melf32bmipn32" ;; *64-bit*) LD="${LD-ld} -melf64bmip" ;; esac else case `/usr/bin/file conftest.$ac_objext` in *32-bit*) LD="${LD-ld} -32" ;; *N32*) LD="${LD-ld} -n32" ;; *64-bit*) LD="${LD-ld} -64" ;; esac fi fi rm -rf conftest* ;; mips64*-*linux*) # Find out what ABI is being produced by ac_compile, and set linker # options accordingly. echo '[#]line '$LINENO' "configure"' > conftest.$ac_ext if AC_TRY_EVAL(ac_compile); then emul=elf case `/usr/bin/file conftest.$ac_objext` in *32-bit*) emul="${emul}32" ;; *64-bit*) emul="${emul}64" ;; esac case `/usr/bin/file conftest.$ac_objext` in *MSB*) emul="${emul}btsmip" ;; *LSB*) emul="${emul}ltsmip" ;; esac case `/usr/bin/file conftest.$ac_objext` in *N32*) emul="${emul}n32" ;; esac LD="${LD-ld} -m $emul" fi rm -rf conftest* ;; x86_64-*kfreebsd*-gnu|x86_64-*linux*|powerpc*-*linux*| \ s390*-*linux*|s390*-*tpf*|sparc*-*linux*) # Find out what ABI is being produced by ac_compile, and set linker # options accordingly. Note that the listed cases only cover the # situations where additional linker options are needed (such as when # doing 32-bit compilation for a host where ld defaults to 64-bit, or # vice versa); the common cases where no linker options are needed do # not appear in the list. echo 'int i;' > conftest.$ac_ext if AC_TRY_EVAL(ac_compile); then case `/usr/bin/file conftest.o` in *32-bit*) case $host in x86_64-*kfreebsd*-gnu) LD="${LD-ld} -m elf_i386_fbsd" ;; x86_64-*linux*) case `/usr/bin/file conftest.o` in *x86-64*) LD="${LD-ld} -m elf32_x86_64" ;; *) LD="${LD-ld} -m elf_i386" ;; esac ;; powerpc64le-*linux*) LD="${LD-ld} -m elf32lppclinux" ;; powerpc64-*linux*) LD="${LD-ld} -m elf32ppclinux" ;; s390x-*linux*) LD="${LD-ld} -m elf_s390" ;; sparc64-*linux*) LD="${LD-ld} -m elf32_sparc" ;; esac ;; *64-bit*) case $host in x86_64-*kfreebsd*-gnu) LD="${LD-ld} -m elf_x86_64_fbsd" ;; x86_64-*linux*) LD="${LD-ld} -m elf_x86_64" ;; powerpcle-*linux*) LD="${LD-ld} -m elf64lppc" ;; powerpc-*linux*) LD="${LD-ld} -m elf64ppc" ;; s390*-*linux*|s390*-*tpf*) LD="${LD-ld} -m elf64_s390" ;; sparc*-*linux*) LD="${LD-ld} -m elf64_sparc" ;; esac ;; esac fi rm -rf conftest* ;; *-*-sco3.2v5*) # On SCO OpenServer 5, we need -belf to get full-featured binaries. SAVE_CFLAGS=$CFLAGS CFLAGS="$CFLAGS -belf" AC_CACHE_CHECK([whether the C compiler needs -belf], lt_cv_cc_needs_belf, [AC_LANG_PUSH(C) AC_LINK_IFELSE([AC_LANG_PROGRAM([[]],[[]])],[lt_cv_cc_needs_belf=yes],[lt_cv_cc_needs_belf=no]) AC_LANG_POP]) if test yes != "$lt_cv_cc_needs_belf"; then # this is probably gcc 2.8.0, egcs 1.0 or newer; no need for -belf CFLAGS=$SAVE_CFLAGS fi ;; *-*solaris*) # Find out what ABI is being produced by ac_compile, and set linker # options accordingly. echo 'int i;' > conftest.$ac_ext if AC_TRY_EVAL(ac_compile); then case `/usr/bin/file conftest.o` in *64-bit*) case $lt_cv_prog_gnu_ld in yes*) case $host in i?86-*-solaris*|x86_64-*-solaris*) LD="${LD-ld} -m elf_x86_64" ;; sparc*-*-solaris*) LD="${LD-ld} -m elf64_sparc" ;; esac # GNU ld 2.21 introduced _sol2 emulations. Use them if available. if ${LD-ld} -V | grep _sol2 >/dev/null 2>&1; then LD=${LD-ld}_sol2 fi ;; *) if ${LD-ld} -64 -r -o conftest2.o conftest.o >/dev/null 2>&1; then LD="${LD-ld} -64" fi ;; esac ;; esac fi rm -rf conftest* ;; esac need_locks=$enable_libtool_lock ])# _LT_ENABLE_LOCK # _LT_PROG_AR # ----------- m4_defun([_LT_PROG_AR], [AC_CHECK_TOOLS(AR, [ar], false) : ${AR=ar} : ${AR_FLAGS=cru} _LT_DECL([], [AR], [1], [The archiver]) _LT_DECL([], [AR_FLAGS], [1], [Flags to create an archive]) AC_CACHE_CHECK([for archiver @FILE support], [lt_cv_ar_at_file], [lt_cv_ar_at_file=no AC_COMPILE_IFELSE([AC_LANG_PROGRAM], [echo conftest.$ac_objext > conftest.lst lt_ar_try='$AR $AR_FLAGS libconftest.a @conftest.lst >&AS_MESSAGE_LOG_FD' AC_TRY_EVAL([lt_ar_try]) if test 0 -eq "$ac_status"; then # Ensure the archiver fails upon bogus file names. rm -f conftest.$ac_objext libconftest.a AC_TRY_EVAL([lt_ar_try]) if test 0 -ne "$ac_status"; then lt_cv_ar_at_file=@ fi fi rm -f conftest.* libconftest.a ]) ]) if test no = "$lt_cv_ar_at_file"; then archiver_list_spec= else archiver_list_spec=$lt_cv_ar_at_file fi _LT_DECL([], [archiver_list_spec], [1], [How to feed a file listing to the archiver]) ])# _LT_PROG_AR # _LT_CMD_OLD_ARCHIVE # ------------------- m4_defun([_LT_CMD_OLD_ARCHIVE], [_LT_PROG_AR AC_CHECK_TOOL(STRIP, strip, :) test -z "$STRIP" && STRIP=: _LT_DECL([], [STRIP], [1], [A symbol stripping program]) AC_CHECK_TOOL(RANLIB, ranlib, :) test -z "$RANLIB" && RANLIB=: _LT_DECL([], [RANLIB], [1], [Commands used to install an old-style archive]) # Determine commands to create old-style static archives. old_archive_cmds='$AR $AR_FLAGS $oldlib$oldobjs' old_postinstall_cmds='chmod 644 $oldlib' old_postuninstall_cmds= if test -n "$RANLIB"; then case $host_os in bitrig* | openbsd*) old_postinstall_cmds="$old_postinstall_cmds~\$RANLIB -t \$tool_oldlib" ;; *) old_postinstall_cmds="$old_postinstall_cmds~\$RANLIB \$tool_oldlib" ;; esac old_archive_cmds="$old_archive_cmds~\$RANLIB \$tool_oldlib" fi case $host_os in darwin*) lock_old_archive_extraction=yes ;; *) lock_old_archive_extraction=no ;; esac _LT_DECL([], [old_postinstall_cmds], [2]) _LT_DECL([], [old_postuninstall_cmds], [2]) _LT_TAGDECL([], [old_archive_cmds], [2], [Commands used to build an old-style archive]) _LT_DECL([], [lock_old_archive_extraction], [0], [Whether to use a lock for old archive extraction]) ])# _LT_CMD_OLD_ARCHIVE # _LT_COMPILER_OPTION(MESSAGE, VARIABLE-NAME, FLAGS, # [OUTPUT-FILE], [ACTION-SUCCESS], [ACTION-FAILURE]) # ---------------------------------------------------------------- # Check whether the given compiler option works AC_DEFUN([_LT_COMPILER_OPTION], [m4_require([_LT_FILEUTILS_DEFAULTS])dnl m4_require([_LT_DECL_SED])dnl AC_CACHE_CHECK([$1], [$2], [$2=no m4_if([$4], , [ac_outfile=conftest.$ac_objext], [ac_outfile=$4]) echo "$lt_simple_compile_test_code" > conftest.$ac_ext lt_compiler_flag="$3" ## exclude from sc_useless_quotes_in_assignment # Insert the option either (1) after the last *FLAGS variable, or # (2) before a word containing "conftest.", or (3) at the end. # Note that $ac_compile itself does not contain backslashes and begins # with a dollar sign (not a hyphen), so the echo should work correctly. # The option is referenced via a variable to avoid confusing sed. lt_compile=`echo "$ac_compile" | $SED \ -e 's:.*FLAGS}\{0,1\} :&$lt_compiler_flag :; t' \ -e 's: [[^ ]]*conftest\.: $lt_compiler_flag&:; t' \ -e 's:$: $lt_compiler_flag:'` (eval echo "\"\$as_me:$LINENO: $lt_compile\"" >&AS_MESSAGE_LOG_FD) (eval "$lt_compile" 2>conftest.err) ac_status=$? cat conftest.err >&AS_MESSAGE_LOG_FD echo "$as_me:$LINENO: \$? = $ac_status" >&AS_MESSAGE_LOG_FD if (exit $ac_status) && test -s "$ac_outfile"; then # The compiler can only warn and ignore the option if not recognized # So say no if there are warnings other than the usual output. $ECHO "$_lt_compiler_boilerplate" | $SED '/^$/d' >conftest.exp $SED '/^$/d; /^ *+/d' conftest.err >conftest.er2 if test ! -s conftest.er2 || diff conftest.exp conftest.er2 >/dev/null; then $2=yes fi fi $RM conftest* ]) if test yes = "[$]$2"; then m4_if([$5], , :, [$5]) else m4_if([$6], , :, [$6]) fi ])# _LT_COMPILER_OPTION # Old name: AU_ALIAS([AC_LIBTOOL_COMPILER_OPTION], [_LT_COMPILER_OPTION]) dnl aclocal-1.4 backwards compatibility: dnl AC_DEFUN([AC_LIBTOOL_COMPILER_OPTION], []) # _LT_LINKER_OPTION(MESSAGE, VARIABLE-NAME, FLAGS, # [ACTION-SUCCESS], [ACTION-FAILURE]) # ---------------------------------------------------- # Check whether the given linker option works AC_DEFUN([_LT_LINKER_OPTION], [m4_require([_LT_FILEUTILS_DEFAULTS])dnl m4_require([_LT_DECL_SED])dnl AC_CACHE_CHECK([$1], [$2], [$2=no save_LDFLAGS=$LDFLAGS LDFLAGS="$LDFLAGS $3" echo "$lt_simple_link_test_code" > conftest.$ac_ext if (eval $ac_link 2>conftest.err) && test -s conftest$ac_exeext; then # The linker can only warn and ignore the option if not recognized # So say no if there are warnings if test -s conftest.err; then # Append any errors to the config.log. cat conftest.err 1>&AS_MESSAGE_LOG_FD $ECHO "$_lt_linker_boilerplate" | $SED '/^$/d' > conftest.exp $SED '/^$/d; /^ *+/d' conftest.err >conftest.er2 if diff conftest.exp conftest.er2 >/dev/null; then $2=yes fi else $2=yes fi fi $RM -r conftest* LDFLAGS=$save_LDFLAGS ]) if test yes = "[$]$2"; then m4_if([$4], , :, [$4]) else m4_if([$5], , :, [$5]) fi ])# _LT_LINKER_OPTION # Old name: AU_ALIAS([AC_LIBTOOL_LINKER_OPTION], [_LT_LINKER_OPTION]) dnl aclocal-1.4 backwards compatibility: dnl AC_DEFUN([AC_LIBTOOL_LINKER_OPTION], []) # LT_CMD_MAX_LEN #--------------- AC_DEFUN([LT_CMD_MAX_LEN], [AC_REQUIRE([AC_CANONICAL_HOST])dnl # find the maximum length of command line arguments AC_MSG_CHECKING([the maximum length of command line arguments]) AC_CACHE_VAL([lt_cv_sys_max_cmd_len], [dnl i=0 teststring=ABCD case $build_os in msdosdjgpp*) # On DJGPP, this test can blow up pretty badly due to problems in libc # (any single argument exceeding 2000 bytes causes a buffer overrun # during glob expansion). Even if it were fixed, the result of this # check would be larger than it should be. lt_cv_sys_max_cmd_len=12288; # 12K is about right ;; gnu*) # Under GNU Hurd, this test is not required because there is # no limit to the length of command line arguments. # Libtool will interpret -1 as no limit whatsoever lt_cv_sys_max_cmd_len=-1; ;; cygwin* | mingw* | cegcc*) # On Win9x/ME, this test blows up -- it succeeds, but takes # about 5 minutes as the teststring grows exponentially. # Worse, since 9x/ME are not pre-emptively multitasking, # you end up with a "frozen" computer, even though with patience # the test eventually succeeds (with a max line length of 256k). # Instead, let's just punt: use the minimum linelength reported by # all of the supported platforms: 8192 (on NT/2K/XP). lt_cv_sys_max_cmd_len=8192; ;; mint*) # On MiNT this can take a long time and run out of memory. lt_cv_sys_max_cmd_len=8192; ;; amigaos*) # On AmigaOS with pdksh, this test takes hours, literally. # So we just punt and use a minimum line length of 8192. lt_cv_sys_max_cmd_len=8192; ;; bitrig* | darwin* | dragonfly* | freebsd* | netbsd* | openbsd*) # This has been around since 386BSD, at least. Likely further. if test -x /sbin/sysctl; then lt_cv_sys_max_cmd_len=`/sbin/sysctl -n kern.argmax` elif test -x /usr/sbin/sysctl; then lt_cv_sys_max_cmd_len=`/usr/sbin/sysctl -n kern.argmax` else lt_cv_sys_max_cmd_len=65536 # usable default for all BSDs fi # And add a safety zone lt_cv_sys_max_cmd_len=`expr $lt_cv_sys_max_cmd_len \/ 4` lt_cv_sys_max_cmd_len=`expr $lt_cv_sys_max_cmd_len \* 3` ;; interix*) # We know the value 262144 and hardcode it with a safety zone (like BSD) lt_cv_sys_max_cmd_len=196608 ;; os2*) # The test takes a long time on OS/2. lt_cv_sys_max_cmd_len=8192 ;; osf*) # Dr. Hans Ekkehard Plesser reports seeing a kernel panic running configure # due to this test when exec_disable_arg_limit is 1 on Tru64. It is not # nice to cause kernel panics so lets avoid the loop below. # First set a reasonable default. lt_cv_sys_max_cmd_len=16384 # if test -x /sbin/sysconfig; then case `/sbin/sysconfig -q proc exec_disable_arg_limit` in *1*) lt_cv_sys_max_cmd_len=-1 ;; esac fi ;; sco3.2v5*) lt_cv_sys_max_cmd_len=102400 ;; sysv5* | sco5v6* | sysv4.2uw2*) kargmax=`grep ARG_MAX /etc/conf/cf.d/stune 2>/dev/null` if test -n "$kargmax"; then lt_cv_sys_max_cmd_len=`echo $kargmax | sed 's/.*[[ ]]//'` else lt_cv_sys_max_cmd_len=32768 fi ;; *) lt_cv_sys_max_cmd_len=`(getconf ARG_MAX) 2> /dev/null` if test -n "$lt_cv_sys_max_cmd_len" && \ test undefined != "$lt_cv_sys_max_cmd_len"; then lt_cv_sys_max_cmd_len=`expr $lt_cv_sys_max_cmd_len \/ 4` lt_cv_sys_max_cmd_len=`expr $lt_cv_sys_max_cmd_len \* 3` else # Make teststring a little bigger before we do anything with it. # a 1K string should be a reasonable start. for i in 1 2 3 4 5 6 7 8; do teststring=$teststring$teststring done SHELL=${SHELL-${CONFIG_SHELL-/bin/sh}} # If test is not a shell built-in, we'll probably end up computing a # maximum length that is only half of the actual maximum length, but # we can't tell. while { test X`env echo "$teststring$teststring" 2>/dev/null` \ = "X$teststring$teststring"; } >/dev/null 2>&1 && test 17 != "$i" # 1/2 MB should be enough do i=`expr $i + 1` teststring=$teststring$teststring done # Only check the string length outside the loop. lt_cv_sys_max_cmd_len=`expr "X$teststring" : ".*" 2>&1` teststring= # Add a significant safety factor because C++ compilers can tack on # massive amounts of additional arguments before passing them to the # linker. It appears as though 1/2 is a usable value. lt_cv_sys_max_cmd_len=`expr $lt_cv_sys_max_cmd_len \/ 2` fi ;; esac ]) if test -n "$lt_cv_sys_max_cmd_len"; then AC_MSG_RESULT($lt_cv_sys_max_cmd_len) else AC_MSG_RESULT(none) fi max_cmd_len=$lt_cv_sys_max_cmd_len _LT_DECL([], [max_cmd_len], [0], [What is the maximum length of a command?]) ])# LT_CMD_MAX_LEN # Old name: AU_ALIAS([AC_LIBTOOL_SYS_MAX_CMD_LEN], [LT_CMD_MAX_LEN]) dnl aclocal-1.4 backwards compatibility: dnl AC_DEFUN([AC_LIBTOOL_SYS_MAX_CMD_LEN], []) # _LT_HEADER_DLFCN # ---------------- m4_defun([_LT_HEADER_DLFCN], [AC_CHECK_HEADERS([dlfcn.h], [], [], [AC_INCLUDES_DEFAULT])dnl ])# _LT_HEADER_DLFCN # _LT_TRY_DLOPEN_SELF (ACTION-IF-TRUE, ACTION-IF-TRUE-W-USCORE, # ACTION-IF-FALSE, ACTION-IF-CROSS-COMPILING) # ---------------------------------------------------------------- m4_defun([_LT_TRY_DLOPEN_SELF], [m4_require([_LT_HEADER_DLFCN])dnl if test yes = "$cross_compiling"; then : [$4] else lt_dlunknown=0; lt_dlno_uscore=1; lt_dlneed_uscore=2 lt_status=$lt_dlunknown cat > conftest.$ac_ext <<_LT_EOF [#line $LINENO "configure" #include "confdefs.h" #if HAVE_DLFCN_H #include #endif #include #ifdef RTLD_GLOBAL # define LT_DLGLOBAL RTLD_GLOBAL #else # ifdef DL_GLOBAL # define LT_DLGLOBAL DL_GLOBAL # else # define LT_DLGLOBAL 0 # endif #endif /* We may have to define LT_DLLAZY_OR_NOW in the command line if we find out it does not work in some platform. */ #ifndef LT_DLLAZY_OR_NOW # ifdef RTLD_LAZY # define LT_DLLAZY_OR_NOW RTLD_LAZY # else # ifdef DL_LAZY # define LT_DLLAZY_OR_NOW DL_LAZY # else # ifdef RTLD_NOW # define LT_DLLAZY_OR_NOW RTLD_NOW # else # ifdef DL_NOW # define LT_DLLAZY_OR_NOW DL_NOW # else # define LT_DLLAZY_OR_NOW 0 # endif # endif # endif # endif #endif /* When -fvisibility=hidden is used, assume the code has been annotated correspondingly for the symbols needed. */ #if defined __GNUC__ && (((__GNUC__ == 3) && (__GNUC_MINOR__ >= 3)) || (__GNUC__ > 3)) int fnord () __attribute__((visibility("default"))); #endif int fnord () { return 42; } int main () { void *self = dlopen (0, LT_DLGLOBAL|LT_DLLAZY_OR_NOW); int status = $lt_dlunknown; if (self) { if (dlsym (self,"fnord")) status = $lt_dlno_uscore; else { if (dlsym( self,"_fnord")) status = $lt_dlneed_uscore; else puts (dlerror ()); } /* dlclose (self); */ } else puts (dlerror ()); return status; }] _LT_EOF if AC_TRY_EVAL(ac_link) && test -s "conftest$ac_exeext" 2>/dev/null; then (./conftest; exit; ) >&AS_MESSAGE_LOG_FD 2>/dev/null lt_status=$? case x$lt_status in x$lt_dlno_uscore) $1 ;; x$lt_dlneed_uscore) $2 ;; x$lt_dlunknown|x*) $3 ;; esac else : # compilation failed $3 fi fi rm -fr conftest* ])# _LT_TRY_DLOPEN_SELF # LT_SYS_DLOPEN_SELF # ------------------ AC_DEFUN([LT_SYS_DLOPEN_SELF], [m4_require([_LT_HEADER_DLFCN])dnl if test yes != "$enable_dlopen"; then enable_dlopen=unknown enable_dlopen_self=unknown enable_dlopen_self_static=unknown else lt_cv_dlopen=no lt_cv_dlopen_libs= case $host_os in beos*) lt_cv_dlopen=load_add_on lt_cv_dlopen_libs= lt_cv_dlopen_self=yes ;; mingw* | pw32* | cegcc*) lt_cv_dlopen=LoadLibrary lt_cv_dlopen_libs= ;; cygwin*) lt_cv_dlopen=dlopen lt_cv_dlopen_libs= ;; darwin*) # if libdl is installed we need to link against it AC_CHECK_LIB([dl], [dlopen], [lt_cv_dlopen=dlopen lt_cv_dlopen_libs=-ldl],[ lt_cv_dlopen=dyld lt_cv_dlopen_libs= lt_cv_dlopen_self=yes ]) ;; tpf*) # Don't try to run any link tests for TPF. We know it's impossible # because TPF is a cross-compiler, and we know how we open DSOs. lt_cv_dlopen=dlopen lt_cv_dlopen_libs= lt_cv_dlopen_self=no ;; *) AC_CHECK_FUNC([shl_load], [lt_cv_dlopen=shl_load], [AC_CHECK_LIB([dld], [shl_load], [lt_cv_dlopen=shl_load lt_cv_dlopen_libs=-ldld], [AC_CHECK_FUNC([dlopen], [lt_cv_dlopen=dlopen], [AC_CHECK_LIB([dl], [dlopen], [lt_cv_dlopen=dlopen lt_cv_dlopen_libs=-ldl], [AC_CHECK_LIB([svld], [dlopen], [lt_cv_dlopen=dlopen lt_cv_dlopen_libs=-lsvld], [AC_CHECK_LIB([dld], [dld_link], [lt_cv_dlopen=dld_link lt_cv_dlopen_libs=-ldld]) ]) ]) ]) ]) ]) ;; esac if test no = "$lt_cv_dlopen"; then enable_dlopen=no else enable_dlopen=yes fi case $lt_cv_dlopen in dlopen) save_CPPFLAGS=$CPPFLAGS test yes = "$ac_cv_header_dlfcn_h" && CPPFLAGS="$CPPFLAGS -DHAVE_DLFCN_H" save_LDFLAGS=$LDFLAGS wl=$lt_prog_compiler_wl eval LDFLAGS=\"\$LDFLAGS $export_dynamic_flag_spec\" save_LIBS=$LIBS LIBS="$lt_cv_dlopen_libs $LIBS" AC_CACHE_CHECK([whether a program can dlopen itself], lt_cv_dlopen_self, [dnl _LT_TRY_DLOPEN_SELF( lt_cv_dlopen_self=yes, lt_cv_dlopen_self=yes, lt_cv_dlopen_self=no, lt_cv_dlopen_self=cross) ]) if test yes = "$lt_cv_dlopen_self"; then wl=$lt_prog_compiler_wl eval LDFLAGS=\"\$LDFLAGS $lt_prog_compiler_static\" AC_CACHE_CHECK([whether a statically linked program can dlopen itself], lt_cv_dlopen_self_static, [dnl _LT_TRY_DLOPEN_SELF( lt_cv_dlopen_self_static=yes, lt_cv_dlopen_self_static=yes, lt_cv_dlopen_self_static=no, lt_cv_dlopen_self_static=cross) ]) fi CPPFLAGS=$save_CPPFLAGS LDFLAGS=$save_LDFLAGS LIBS=$save_LIBS ;; esac case $lt_cv_dlopen_self in yes|no) enable_dlopen_self=$lt_cv_dlopen_self ;; *) enable_dlopen_self=unknown ;; esac case $lt_cv_dlopen_self_static in yes|no) enable_dlopen_self_static=$lt_cv_dlopen_self_static ;; *) enable_dlopen_self_static=unknown ;; esac fi _LT_DECL([dlopen_support], [enable_dlopen], [0], [Whether dlopen is supported]) _LT_DECL([dlopen_self], [enable_dlopen_self], [0], [Whether dlopen of programs is supported]) _LT_DECL([dlopen_self_static], [enable_dlopen_self_static], [0], [Whether dlopen of statically linked programs is supported]) ])# LT_SYS_DLOPEN_SELF # Old name: AU_ALIAS([AC_LIBTOOL_DLOPEN_SELF], [LT_SYS_DLOPEN_SELF]) dnl aclocal-1.4 backwards compatibility: dnl AC_DEFUN([AC_LIBTOOL_DLOPEN_SELF], []) # _LT_COMPILER_C_O([TAGNAME]) # --------------------------- # Check to see if options -c and -o are simultaneously supported by compiler. # This macro does not hard code the compiler like AC_PROG_CC_C_O. m4_defun([_LT_COMPILER_C_O], [m4_require([_LT_DECL_SED])dnl m4_require([_LT_FILEUTILS_DEFAULTS])dnl m4_require([_LT_TAG_COMPILER])dnl AC_CACHE_CHECK([if $compiler supports -c -o file.$ac_objext], [_LT_TAGVAR(lt_cv_prog_compiler_c_o, $1)], [_LT_TAGVAR(lt_cv_prog_compiler_c_o, $1)=no $RM -r conftest 2>/dev/null mkdir conftest cd conftest mkdir out echo "$lt_simple_compile_test_code" > conftest.$ac_ext lt_compiler_flag="-o out/conftest2.$ac_objext" # Insert the option either (1) after the last *FLAGS variable, or # (2) before a word containing "conftest.", or (3) at the end. # Note that $ac_compile itself does not contain backslashes and begins # with a dollar sign (not a hyphen), so the echo should work correctly. lt_compile=`echo "$ac_compile" | $SED \ -e 's:.*FLAGS}\{0,1\} :&$lt_compiler_flag :; t' \ -e 's: [[^ ]]*conftest\.: $lt_compiler_flag&:; t' \ -e 's:$: $lt_compiler_flag:'` (eval echo "\"\$as_me:$LINENO: $lt_compile\"" >&AS_MESSAGE_LOG_FD) (eval "$lt_compile" 2>out/conftest.err) ac_status=$? cat out/conftest.err >&AS_MESSAGE_LOG_FD echo "$as_me:$LINENO: \$? = $ac_status" >&AS_MESSAGE_LOG_FD if (exit $ac_status) && test -s out/conftest2.$ac_objext then # The compiler can only warn and ignore the option if not recognized # So say no if there are warnings $ECHO "$_lt_compiler_boilerplate" | $SED '/^$/d' > out/conftest.exp $SED '/^$/d; /^ *+/d' out/conftest.err >out/conftest.er2 if test ! -s out/conftest.er2 || diff out/conftest.exp out/conftest.er2 >/dev/null; then _LT_TAGVAR(lt_cv_prog_compiler_c_o, $1)=yes fi fi chmod u+w . 2>&AS_MESSAGE_LOG_FD $RM conftest* # SGI C++ compiler will create directory out/ii_files/ for # template instantiation test -d out/ii_files && $RM out/ii_files/* && rmdir out/ii_files $RM out/* && rmdir out cd .. $RM -r conftest $RM conftest* ]) _LT_TAGDECL([compiler_c_o], [lt_cv_prog_compiler_c_o], [1], [Does compiler simultaneously support -c and -o options?]) ])# _LT_COMPILER_C_O # _LT_COMPILER_FILE_LOCKS([TAGNAME]) # ---------------------------------- # Check to see if we can do hard links to lock some files if needed m4_defun([_LT_COMPILER_FILE_LOCKS], [m4_require([_LT_ENABLE_LOCK])dnl m4_require([_LT_FILEUTILS_DEFAULTS])dnl _LT_COMPILER_C_O([$1]) hard_links=nottested if test no = "$_LT_TAGVAR(lt_cv_prog_compiler_c_o, $1)" && test no != "$need_locks"; then # do not overwrite the value of need_locks provided by the user AC_MSG_CHECKING([if we can lock with hard links]) hard_links=yes $RM conftest* ln conftest.a conftest.b 2>/dev/null && hard_links=no touch conftest.a ln conftest.a conftest.b 2>&5 || hard_links=no ln conftest.a conftest.b 2>/dev/null && hard_links=no AC_MSG_RESULT([$hard_links]) if test no = "$hard_links"; then AC_MSG_WARN(['$CC' does not support '-c -o', so 'make -j' may be unsafe]) need_locks=warn fi else need_locks=no fi _LT_DECL([], [need_locks], [1], [Must we lock files when doing compilation?]) ])# _LT_COMPILER_FILE_LOCKS # _LT_CHECK_OBJDIR # ---------------- m4_defun([_LT_CHECK_OBJDIR], [AC_CACHE_CHECK([for objdir], [lt_cv_objdir], [rm -f .libs 2>/dev/null mkdir .libs 2>/dev/null if test -d .libs; then lt_cv_objdir=.libs else # MS-DOS does not allow filenames that begin with a dot. lt_cv_objdir=_libs fi rmdir .libs 2>/dev/null]) objdir=$lt_cv_objdir _LT_DECL([], [objdir], [0], [The name of the directory that contains temporary libtool files])dnl m4_pattern_allow([LT_OBJDIR])dnl AC_DEFINE_UNQUOTED([LT_OBJDIR], "$lt_cv_objdir/", [Define to the sub-directory where libtool stores uninstalled libraries.]) ])# _LT_CHECK_OBJDIR # _LT_LINKER_HARDCODE_LIBPATH([TAGNAME]) # -------------------------------------- # Check hardcoding attributes. m4_defun([_LT_LINKER_HARDCODE_LIBPATH], [AC_MSG_CHECKING([how to hardcode library paths into programs]) _LT_TAGVAR(hardcode_action, $1)= if test -n "$_LT_TAGVAR(hardcode_libdir_flag_spec, $1)" || test -n "$_LT_TAGVAR(runpath_var, $1)" || test yes = "$_LT_TAGVAR(hardcode_automatic, $1)"; then # We can hardcode non-existent directories. if test no != "$_LT_TAGVAR(hardcode_direct, $1)" && # If the only mechanism to avoid hardcoding is shlibpath_var, we # have to relink, otherwise we might link with an installed library # when we should be linking with a yet-to-be-installed one ## test no != "$_LT_TAGVAR(hardcode_shlibpath_var, $1)" && test no != "$_LT_TAGVAR(hardcode_minus_L, $1)"; then # Linking always hardcodes the temporary library directory. _LT_TAGVAR(hardcode_action, $1)=relink else # We can link without hardcoding, and we can hardcode nonexisting dirs. _LT_TAGVAR(hardcode_action, $1)=immediate fi else # We cannot hardcode anything, or else we can only hardcode existing # directories. _LT_TAGVAR(hardcode_action, $1)=unsupported fi AC_MSG_RESULT([$_LT_TAGVAR(hardcode_action, $1)]) if test relink = "$_LT_TAGVAR(hardcode_action, $1)" || test yes = "$_LT_TAGVAR(inherit_rpath, $1)"; then # Fast installation is not supported enable_fast_install=no elif test yes = "$shlibpath_overrides_runpath" || test no = "$enable_shared"; then # Fast installation is not necessary enable_fast_install=needless fi _LT_TAGDECL([], [hardcode_action], [0], [How to hardcode a shared library path into an executable]) ])# _LT_LINKER_HARDCODE_LIBPATH # _LT_CMD_STRIPLIB # ---------------- m4_defun([_LT_CMD_STRIPLIB], [m4_require([_LT_DECL_EGREP]) striplib= old_striplib= AC_MSG_CHECKING([whether stripping libraries is possible]) if test -n "$STRIP" && $STRIP -V 2>&1 | $GREP "GNU strip" >/dev/null; then test -z "$old_striplib" && old_striplib="$STRIP --strip-debug" test -z "$striplib" && striplib="$STRIP --strip-unneeded" AC_MSG_RESULT([yes]) else # FIXME - insert some real tests, host_os isn't really good enough case $host_os in darwin*) if test -n "$STRIP"; then striplib="$STRIP -x" old_striplib="$STRIP -S" AC_MSG_RESULT([yes]) else AC_MSG_RESULT([no]) fi ;; *) AC_MSG_RESULT([no]) ;; esac fi _LT_DECL([], [old_striplib], [1], [Commands to strip libraries]) _LT_DECL([], [striplib], [1]) ])# _LT_CMD_STRIPLIB # _LT_PREPARE_MUNGE_PATH_LIST # --------------------------- # Make sure func_munge_path_list() is defined correctly. m4_defun([_LT_PREPARE_MUNGE_PATH_LIST], [[# func_munge_path_list VARIABLE PATH # ----------------------------------- # VARIABLE is name of variable containing _space_ separated list of # directories to be munged by the contents of PATH, which is string # having a format: # "DIR[:DIR]:" # string "DIR[ DIR]" will be prepended to VARIABLE # ":DIR[:DIR]" # string "DIR[ DIR]" will be appended to VARIABLE # "DIRP[:DIRP]::[DIRA:]DIRA" # string "DIRP[ DIRP]" will be prepended to VARIABLE and string # "DIRA[ DIRA]" will be appended to VARIABLE # "DIR[:DIR]" # VARIABLE will be replaced by "DIR[ DIR]" func_munge_path_list () { case x@S|@2 in x) ;; *:) eval @S|@1=\"`$ECHO @S|@2 | $SED 's/:/ /g'` \@S|@@S|@1\" ;; x:*) eval @S|@1=\"\@S|@@S|@1 `$ECHO @S|@2 | $SED 's/:/ /g'`\" ;; *::*) eval @S|@1=\"\@S|@@S|@1\ `$ECHO @S|@2 | $SED -e 's/.*:://' -e 's/:/ /g'`\" eval @S|@1=\"`$ECHO @S|@2 | $SED -e 's/::.*//' -e 's/:/ /g'`\ \@S|@@S|@1\" ;; *) eval @S|@1=\"`$ECHO @S|@2 | $SED 's/:/ /g'`\" ;; esac } ]])# _LT_PREPARE_PATH_LIST # _LT_SYS_DYNAMIC_LINKER([TAG]) # ----------------------------- # PORTME Fill in your ld.so characteristics m4_defun([_LT_SYS_DYNAMIC_LINKER], [AC_REQUIRE([AC_CANONICAL_HOST])dnl m4_require([_LT_DECL_EGREP])dnl m4_require([_LT_FILEUTILS_DEFAULTS])dnl m4_require([_LT_DECL_OBJDUMP])dnl m4_require([_LT_DECL_SED])dnl m4_require([_LT_CHECK_SHELL_FEATURES])dnl m4_require([_LT_PREPARE_MUNGE_PATH_LIST])dnl AC_MSG_CHECKING([dynamic linker characteristics]) m4_if([$1], [], [ if test yes = "$GCC"; then case $host_os in darwin*) lt_awk_arg='/^libraries:/,/LR/' ;; *) lt_awk_arg='/^libraries:/' ;; esac case $host_os in mingw* | cegcc*) lt_sed_strip_eq='s|=\([[A-Za-z]]:\)|\1|g' ;; *) lt_sed_strip_eq='s|=/|/|g' ;; esac lt_search_path_spec=`$CC -print-search-dirs | awk $lt_awk_arg | $SED -e "s/^libraries://" -e $lt_sed_strip_eq` case $lt_search_path_spec in *\;*) # if the path contains ";" then we assume it to be the separator # otherwise default to the standard path separator (i.e. ":") - it is # assumed that no part of a normal pathname contains ";" but that should # okay in the real world where ";" in dirpaths is itself problematic. lt_search_path_spec=`$ECHO "$lt_search_path_spec" | $SED 's/;/ /g'` ;; *) lt_search_path_spec=`$ECHO "$lt_search_path_spec" | $SED "s/$PATH_SEPARATOR/ /g"` ;; esac # Ok, now we have the path, separated by spaces, we can step through it # and add multilib dir if necessary... lt_tmp_lt_search_path_spec= lt_multi_os_dir=/`$CC $CPPFLAGS $CFLAGS $LDFLAGS -print-multi-os-directory 2>/dev/null` # ...but if some path component already ends with the multilib dir we assume # that all is fine and trust -print-search-dirs as is (GCC 4.2? or newer). case "$lt_multi_os_dir; $lt_search_path_spec " in "/; "* | "/.; "* | "/./; "* | *"$lt_multi_os_dir "* | *"$lt_multi_os_dir/ "*) lt_multi_os_dir= ;; esac for lt_sys_path in $lt_search_path_spec; do if test -d "$lt_sys_path$lt_multi_os_dir"; then lt_tmp_lt_search_path_spec="$lt_tmp_lt_search_path_spec $lt_sys_path$lt_multi_os_dir" elif test -n "$lt_multi_os_dir"; then test -d "$lt_sys_path" && \ lt_tmp_lt_search_path_spec="$lt_tmp_lt_search_path_spec $lt_sys_path" fi done lt_search_path_spec=`$ECHO "$lt_tmp_lt_search_path_spec" | awk ' BEGIN {RS = " "; FS = "/|\n";} { lt_foo = ""; lt_count = 0; for (lt_i = NF; lt_i > 0; lt_i--) { if ($lt_i != "" && $lt_i != ".") { if ($lt_i == "..") { lt_count++; } else { if (lt_count == 0) { lt_foo = "/" $lt_i lt_foo; } else { lt_count--; } } } } if (lt_foo != "") { lt_freq[[lt_foo]]++; } if (lt_freq[[lt_foo]] == 1) { print lt_foo; } }'` # AWK program above erroneously prepends '/' to C:/dos/paths # for these hosts. case $host_os in mingw* | cegcc*) lt_search_path_spec=`$ECHO "$lt_search_path_spec" |\ $SED 's|/\([[A-Za-z]]:\)|\1|g'` ;; esac sys_lib_search_path_spec=`$ECHO "$lt_search_path_spec" | $lt_NL2SP` else sys_lib_search_path_spec="/lib /usr/lib /usr/local/lib" fi]) library_names_spec= libname_spec='lib$name' soname_spec= shrext_cmds=.so postinstall_cmds= postuninstall_cmds= finish_cmds= finish_eval= shlibpath_var= shlibpath_overrides_runpath=unknown version_type=none dynamic_linker="$host_os ld.so" sys_lib_dlsearch_path_spec="/lib /usr/lib" need_lib_prefix=unknown hardcode_into_libs=no # when you set need_version to no, make sure it does not cause -set_version # flags to be left without arguments need_version=unknown AC_ARG_VAR([LT_SYS_LIBRARY_PATH], [User-defined run-time library search path.]) case $host_os in aix3*) version_type=linux # correct to gnu/linux during the next big refactor library_names_spec='$libname$release$shared_ext$versuffix $libname.a' shlibpath_var=LIBPATH # AIX 3 has no versioning support, so we append a major version to the name. soname_spec='$libname$release$shared_ext$major' ;; aix[[4-9]]*) version_type=linux # correct to gnu/linux during the next big refactor need_lib_prefix=no need_version=no hardcode_into_libs=yes if test ia64 = "$host_cpu"; then # AIX 5 supports IA64 library_names_spec='$libname$release$shared_ext$major $libname$release$shared_ext$versuffix $libname$shared_ext' shlibpath_var=LD_LIBRARY_PATH else # With GCC up to 2.95.x, collect2 would create an import file # for dependence libraries. The import file would start with # the line '#! .'. This would cause the generated library to # depend on '.', always an invalid library. This was fixed in # development snapshots of GCC prior to 3.0. case $host_os in aix4 | aix4.[[01]] | aix4.[[01]].*) if { echo '#if __GNUC__ > 2 || (__GNUC__ == 2 && __GNUC_MINOR__ >= 97)' echo ' yes ' echo '#endif'; } | $CC -E - | $GREP yes > /dev/null; then : else can_build_shared=no fi ;; esac # Using Import Files as archive members, it is possible to support # filename-based versioning of shared library archives on AIX. While # this would work for both with and without runtime linking, it will # prevent static linking of such archives. So we do filename-based # shared library versioning with .so extension only, which is used # when both runtime linking and shared linking is enabled. # Unfortunately, runtime linking may impact performance, so we do # not want this to be the default eventually. Also, we use the # versioned .so libs for executables only if there is the -brtl # linker flag in LDFLAGS as well, or --with-aix-soname=svr4 only. # To allow for filename-based versioning support, we need to create # libNAME.so.V as an archive file, containing: # *) an Import File, referring to the versioned filename of the # archive as well as the shared archive member, telling the # bitwidth (32 or 64) of that shared object, and providing the # list of exported symbols of that shared object, eventually # decorated with the 'weak' keyword # *) the shared object with the F_LOADONLY flag set, to really avoid # it being seen by the linker. # At run time we better use the real file rather than another symlink, # but for link time we create the symlink libNAME.so -> libNAME.so.V case $with_aix_soname,$aix_use_runtimelinking in # AIX (on Power*) has no versioning support, so currently we cannot hardcode correct # soname into executable. Probably we can add versioning support to # collect2, so additional links can be useful in future. aix,yes) # traditional libtool dynamic_linker='AIX unversionable lib.so' # If using run time linking (on AIX 4.2 or later) use lib.so # instead of lib.a to let people know that these are not # typical AIX shared libraries. library_names_spec='$libname$release$shared_ext$versuffix $libname$release$shared_ext$major $libname$shared_ext' ;; aix,no) # traditional AIX only dynamic_linker='AIX lib.a[(]lib.so.V[)]' # We preserve .a as extension for shared libraries through AIX4.2 # and later when we are not doing run time linking. library_names_spec='$libname$release.a $libname.a' soname_spec='$libname$release$shared_ext$major' ;; svr4,*) # full svr4 only dynamic_linker="AIX lib.so.V[(]$shared_archive_member_spec.o[)]" library_names_spec='$libname$release$shared_ext$major $libname$shared_ext' # We do not specify a path in Import Files, so LIBPATH fires. shlibpath_overrides_runpath=yes ;; *,yes) # both, prefer svr4 dynamic_linker="AIX lib.so.V[(]$shared_archive_member_spec.o[)], lib.a[(]lib.so.V[)]" library_names_spec='$libname$release$shared_ext$major $libname$shared_ext' # unpreferred sharedlib libNAME.a needs extra handling postinstall_cmds='test -n "$linkname" || linkname="$realname"~func_stripname "" ".so" "$linkname"~$install_shared_prog "$dir/$func_stripname_result.$libext" "$destdir/$func_stripname_result.$libext"~test -z "$tstripme" || test -z "$striplib" || $striplib "$destdir/$func_stripname_result.$libext"' postuninstall_cmds='for n in $library_names $old_library; do :; done~func_stripname "" ".so" "$n"~test "$func_stripname_result" = "$n" || func_append rmfiles " $odir/$func_stripname_result.$libext"' # We do not specify a path in Import Files, so LIBPATH fires. shlibpath_overrides_runpath=yes ;; *,no) # both, prefer aix dynamic_linker="AIX lib.a[(]lib.so.V[)], lib.so.V[(]$shared_archive_member_spec.o[)]" library_names_spec='$libname$release.a $libname.a' soname_spec='$libname$release$shared_ext$major' # unpreferred sharedlib libNAME.so.V and symlink libNAME.so need extra handling postinstall_cmds='test -z "$dlname" || $install_shared_prog $dir/$dlname $destdir/$dlname~test -z "$tstripme" || test -z "$striplib" || $striplib $destdir/$dlname~test -n "$linkname" || linkname=$realname~func_stripname "" ".a" "$linkname"~(cd "$destdir" && $LN_S -f $dlname $func_stripname_result.so)' postuninstall_cmds='test -z "$dlname" || func_append rmfiles " $odir/$dlname"~for n in $old_library $library_names; do :; done~func_stripname "" ".a" "$n"~func_append rmfiles " $odir/$func_stripname_result.so"' ;; esac shlibpath_var=LIBPATH fi ;; amigaos*) case $host_cpu in powerpc) # Since July 2007 AmigaOS4 officially supports .so libraries. # When compiling the executable, add -use-dynld -Lsobjs: to the compileline. library_names_spec='$libname$release$shared_ext$versuffix $libname$release$shared_ext$major $libname$shared_ext' ;; m68k) library_names_spec='$libname.ixlibrary $libname.a' # Create ${libname}_ixlibrary.a entries in /sys/libs. finish_eval='for lib in `ls $libdir/*.ixlibrary 2>/dev/null`; do libname=`func_echo_all "$lib" | $SED '\''s%^.*/\([[^/]]*\)\.ixlibrary$%\1%'\''`; $RM /sys/libs/${libname}_ixlibrary.a; $show "cd /sys/libs && $LN_S $lib ${libname}_ixlibrary.a"; cd /sys/libs && $LN_S $lib ${libname}_ixlibrary.a || exit 1; done' ;; esac ;; beos*) library_names_spec='$libname$shared_ext' dynamic_linker="$host_os ld.so" shlibpath_var=LIBRARY_PATH ;; bsdi[[45]]*) version_type=linux # correct to gnu/linux during the next big refactor need_version=no library_names_spec='$libname$release$shared_ext$versuffix $libname$release$shared_ext$major $libname$shared_ext' soname_spec='$libname$release$shared_ext$major' finish_cmds='PATH="\$PATH:/sbin" ldconfig $libdir' shlibpath_var=LD_LIBRARY_PATH sys_lib_search_path_spec="/shlib /usr/lib /usr/X11/lib /usr/contrib/lib /lib /usr/local/lib" sys_lib_dlsearch_path_spec="/shlib /usr/lib /usr/local/lib" # the default ld.so.conf also contains /usr/contrib/lib and # /usr/X11R6/lib (/usr/X11 is a link to /usr/X11R6), but let us allow # libtool to hard-code these into programs ;; cygwin* | mingw* | pw32* | cegcc*) version_type=windows shrext_cmds=.dll need_version=no need_lib_prefix=no case $GCC,$cc_basename in yes,*) # gcc library_names_spec='$libname.dll.a' # DLL is installed to $(libdir)/../bin by postinstall_cmds postinstall_cmds='base_file=`basename \$file`~ dlpath=`$SHELL 2>&1 -c '\''. $dir/'\''\$base_file'\''i; echo \$dlname'\''`~ dldir=$destdir/`dirname \$dlpath`~ test -d \$dldir || mkdir -p \$dldir~ $install_prog $dir/$dlname \$dldir/$dlname~ chmod a+x \$dldir/$dlname~ if test -n '\''$stripme'\'' && test -n '\''$striplib'\''; then eval '\''$striplib \$dldir/$dlname'\'' || exit \$?; fi' postuninstall_cmds='dldll=`$SHELL 2>&1 -c '\''. $file; echo \$dlname'\''`~ dlpath=$dir/\$dldll~ $RM \$dlpath' shlibpath_overrides_runpath=yes case $host_os in cygwin*) # Cygwin DLLs use 'cyg' prefix rather than 'lib' soname_spec='`echo $libname | sed -e 's/^lib/cyg/'``echo $release | $SED -e 's/[[.]]/-/g'`$versuffix$shared_ext' m4_if([$1], [],[ sys_lib_search_path_spec="$sys_lib_search_path_spec /usr/lib/w32api"]) ;; mingw* | cegcc*) # MinGW DLLs use traditional 'lib' prefix soname_spec='$libname`echo $release | $SED -e 's/[[.]]/-/g'`$versuffix$shared_ext' ;; pw32*) # pw32 DLLs use 'pw' prefix rather than 'lib' library_names_spec='`echo $libname | sed -e 's/^lib/pw/'``echo $release | $SED -e 's/[[.]]/-/g'`$versuffix$shared_ext' ;; esac dynamic_linker='Win32 ld.exe' ;; *,cl*) # Native MSVC libname_spec='$name' soname_spec='$libname`echo $release | $SED -e 's/[[.]]/-/g'`$versuffix$shared_ext' library_names_spec='$libname.dll.lib' case $build_os in mingw*) sys_lib_search_path_spec= lt_save_ifs=$IFS IFS=';' for lt_path in $LIB do IFS=$lt_save_ifs # Let DOS variable expansion print the short 8.3 style file name. lt_path=`cd "$lt_path" 2>/dev/null && cmd //C "for %i in (".") do @echo %~si"` sys_lib_search_path_spec="$sys_lib_search_path_spec $lt_path" done IFS=$lt_save_ifs # Convert to MSYS style. sys_lib_search_path_spec=`$ECHO "$sys_lib_search_path_spec" | sed -e 's|\\\\|/|g' -e 's| \\([[a-zA-Z]]\\):| /\\1|g' -e 's|^ ||'` ;; cygwin*) # Convert to unix form, then to dos form, then back to unix form # but this time dos style (no spaces!) so that the unix form looks # like /cygdrive/c/PROGRA~1:/cygdr... sys_lib_search_path_spec=`cygpath --path --unix "$LIB"` sys_lib_search_path_spec=`cygpath --path --dos "$sys_lib_search_path_spec" 2>/dev/null` sys_lib_search_path_spec=`cygpath --path --unix "$sys_lib_search_path_spec" | $SED -e "s/$PATH_SEPARATOR/ /g"` ;; *) sys_lib_search_path_spec=$LIB if $ECHO "$sys_lib_search_path_spec" | [$GREP ';[c-zC-Z]:/' >/dev/null]; then # It is most probably a Windows format PATH. sys_lib_search_path_spec=`$ECHO "$sys_lib_search_path_spec" | $SED -e 's/;/ /g'` else sys_lib_search_path_spec=`$ECHO "$sys_lib_search_path_spec" | $SED -e "s/$PATH_SEPARATOR/ /g"` fi # FIXME: find the short name or the path components, as spaces are # common. (e.g. "Program Files" -> "PROGRA~1") ;; esac # DLL is installed to $(libdir)/../bin by postinstall_cmds postinstall_cmds='base_file=`basename \$file`~ dlpath=`$SHELL 2>&1 -c '\''. $dir/'\''\$base_file'\''i; echo \$dlname'\''`~ dldir=$destdir/`dirname \$dlpath`~ test -d \$dldir || mkdir -p \$dldir~ $install_prog $dir/$dlname \$dldir/$dlname' postuninstall_cmds='dldll=`$SHELL 2>&1 -c '\''. $file; echo \$dlname'\''`~ dlpath=$dir/\$dldll~ $RM \$dlpath' shlibpath_overrides_runpath=yes dynamic_linker='Win32 link.exe' ;; *) # Assume MSVC wrapper library_names_spec='$libname`echo $release | $SED -e 's/[[.]]/-/g'`$versuffix$shared_ext $libname.lib' dynamic_linker='Win32 ld.exe' ;; esac # FIXME: first we should search . and the directory the executable is in shlibpath_var=PATH ;; darwin* | rhapsody*) dynamic_linker="$host_os dyld" version_type=darwin need_lib_prefix=no need_version=no library_names_spec='$libname$release$major$shared_ext $libname$shared_ext' soname_spec='$libname$release$major$shared_ext' shlibpath_overrides_runpath=yes shlibpath_var=DYLD_LIBRARY_PATH shrext_cmds='`test .$module = .yes && echo .so || echo .dylib`' m4_if([$1], [],[ sys_lib_search_path_spec="$sys_lib_search_path_spec /usr/local/lib"]) sys_lib_dlsearch_path_spec='/usr/local/lib /lib /usr/lib' ;; dgux*) version_type=linux # correct to gnu/linux during the next big refactor need_lib_prefix=no need_version=no library_names_spec='$libname$release$shared_ext$versuffix $libname$release$shared_ext$major $libname$shared_ext' soname_spec='$libname$release$shared_ext$major' shlibpath_var=LD_LIBRARY_PATH ;; freebsd* | dragonfly*) # DragonFly does not have aout. When/if they implement a new # versioning mechanism, adjust this. if test -x /usr/bin/objformat; then objformat=`/usr/bin/objformat` else case $host_os in freebsd[[23]].*) objformat=aout ;; *) objformat=elf ;; esac fi version_type=freebsd-$objformat case $version_type in freebsd-elf*) library_names_spec='$libname$release$shared_ext$versuffix $libname$release$shared_ext$major $libname$shared_ext' soname_spec='$libname$release$shared_ext$major' need_version=no need_lib_prefix=no ;; freebsd-*) library_names_spec='$libname$release$shared_ext$versuffix $libname$shared_ext$versuffix' need_version=yes ;; esac shlibpath_var=LD_LIBRARY_PATH case $host_os in freebsd2.*) shlibpath_overrides_runpath=yes ;; freebsd3.[[01]]* | freebsdelf3.[[01]]*) shlibpath_overrides_runpath=yes hardcode_into_libs=yes ;; freebsd3.[[2-9]]* | freebsdelf3.[[2-9]]* | \ freebsd4.[[0-5]] | freebsdelf4.[[0-5]] | freebsd4.1.1 | freebsdelf4.1.1) shlibpath_overrides_runpath=no hardcode_into_libs=yes ;; *) # from 4.6 on, and DragonFly shlibpath_overrides_runpath=yes hardcode_into_libs=yes ;; esac ;; haiku*) version_type=linux # correct to gnu/linux during the next big refactor need_lib_prefix=no need_version=no dynamic_linker="$host_os runtime_loader" library_names_spec='$libname$release$shared_ext$versuffix $libname$release$shared_ext$major $libname$shared_ext' soname_spec='$libname$release$shared_ext$major' shlibpath_var=LIBRARY_PATH shlibpath_overrides_runpath=no sys_lib_dlsearch_path_spec='/boot/home/config/lib /boot/common/lib /boot/system/lib' hardcode_into_libs=yes ;; hpux9* | hpux10* | hpux11*) # Give a soname corresponding to the major version so that dld.sl refuses to # link against other versions. version_type=sunos need_lib_prefix=no need_version=no case $host_cpu in ia64*) shrext_cmds='.so' hardcode_into_libs=yes dynamic_linker="$host_os dld.so" shlibpath_var=LD_LIBRARY_PATH shlibpath_overrides_runpath=yes # Unless +noenvvar is specified. library_names_spec='$libname$release$shared_ext$versuffix $libname$release$shared_ext$major $libname$shared_ext' soname_spec='$libname$release$shared_ext$major' if test 32 = "$HPUX_IA64_MODE"; then sys_lib_search_path_spec="/usr/lib/hpux32 /usr/local/lib/hpux32 /usr/local/lib" sys_lib_dlsearch_path_spec=/usr/lib/hpux32 else sys_lib_search_path_spec="/usr/lib/hpux64 /usr/local/lib/hpux64" sys_lib_dlsearch_path_spec=/usr/lib/hpux64 fi ;; hppa*64*) shrext_cmds='.sl' hardcode_into_libs=yes dynamic_linker="$host_os dld.sl" shlibpath_var=LD_LIBRARY_PATH # How should we handle SHLIB_PATH shlibpath_overrides_runpath=yes # Unless +noenvvar is specified. library_names_spec='$libname$release$shared_ext$versuffix $libname$release$shared_ext$major $libname$shared_ext' soname_spec='$libname$release$shared_ext$major' sys_lib_search_path_spec="/usr/lib/pa20_64 /usr/ccs/lib/pa20_64" sys_lib_dlsearch_path_spec=$sys_lib_search_path_spec ;; *) shrext_cmds='.sl' dynamic_linker="$host_os dld.sl" shlibpath_var=SHLIB_PATH shlibpath_overrides_runpath=no # +s is required to enable SHLIB_PATH library_names_spec='$libname$release$shared_ext$versuffix $libname$release$shared_ext$major $libname$shared_ext' soname_spec='$libname$release$shared_ext$major' ;; esac # HP-UX runs *really* slowly unless shared libraries are mode 555, ... postinstall_cmds='chmod 555 $lib' # or fails outright, so override atomically: install_override_mode=555 ;; interix[[3-9]]*) version_type=linux # correct to gnu/linux during the next big refactor need_lib_prefix=no need_version=no library_names_spec='$libname$release$shared_ext$versuffix $libname$release$shared_ext$major $libname$shared_ext' soname_spec='$libname$release$shared_ext$major' dynamic_linker='Interix 3.x ld.so.1 (PE, like ELF)' shlibpath_var=LD_LIBRARY_PATH shlibpath_overrides_runpath=no hardcode_into_libs=yes ;; irix5* | irix6* | nonstopux*) case $host_os in nonstopux*) version_type=nonstopux ;; *) if test yes = "$lt_cv_prog_gnu_ld"; then version_type=linux # correct to gnu/linux during the next big refactor else version_type=irix fi ;; esac need_lib_prefix=no need_version=no soname_spec='$libname$release$shared_ext$major' library_names_spec='$libname$release$shared_ext$versuffix $libname$release$shared_ext$major $libname$release$shared_ext $libname$shared_ext' case $host_os in irix5* | nonstopux*) libsuff= shlibsuff= ;; *) case $LD in # libtool.m4 will add one of these switches to LD *-32|*"-32 "|*-melf32bsmip|*"-melf32bsmip ") libsuff= shlibsuff= libmagic=32-bit;; *-n32|*"-n32 "|*-melf32bmipn32|*"-melf32bmipn32 ") libsuff=32 shlibsuff=N32 libmagic=N32;; *-64|*"-64 "|*-melf64bmip|*"-melf64bmip ") libsuff=64 shlibsuff=64 libmagic=64-bit;; *) libsuff= shlibsuff= libmagic=never-match;; esac ;; esac shlibpath_var=LD_LIBRARY${shlibsuff}_PATH shlibpath_overrides_runpath=no sys_lib_search_path_spec="/usr/lib$libsuff /lib$libsuff /usr/local/lib$libsuff" sys_lib_dlsearch_path_spec="/usr/lib$libsuff /lib$libsuff" hardcode_into_libs=yes ;; # No shared lib support for Linux oldld, aout, or coff. linux*oldld* | linux*aout* | linux*coff*) dynamic_linker=no ;; linux*android*) version_type=none # Android doesn't support versioned libraries. need_lib_prefix=no need_version=no library_names_spec='$libname$release$shared_ext' soname_spec='$libname$release$shared_ext' finish_cmds= shlibpath_var=LD_LIBRARY_PATH shlibpath_overrides_runpath=yes # This implies no fast_install, which is unacceptable. # Some rework will be needed to allow for fast_install # before this can be enabled. hardcode_into_libs=yes dynamic_linker='Android linker' # Don't embed -rpath directories since the linker doesn't support them. _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='-L$libdir' ;; # This must be glibc/ELF. linux* | k*bsd*-gnu | kopensolaris*-gnu | gnu*) version_type=linux # correct to gnu/linux during the next big refactor need_lib_prefix=no need_version=no library_names_spec='$libname$release$shared_ext$versuffix $libname$release$shared_ext$major $libname$shared_ext' soname_spec='$libname$release$shared_ext$major' finish_cmds='PATH="\$PATH:/sbin" ldconfig -n $libdir' shlibpath_var=LD_LIBRARY_PATH shlibpath_overrides_runpath=no # Some binutils ld are patched to set DT_RUNPATH AC_CACHE_VAL([lt_cv_shlibpath_overrides_runpath], [lt_cv_shlibpath_overrides_runpath=no save_LDFLAGS=$LDFLAGS save_libdir=$libdir eval "libdir=/foo; wl=\"$_LT_TAGVAR(lt_prog_compiler_wl, $1)\"; \ LDFLAGS=\"\$LDFLAGS $_LT_TAGVAR(hardcode_libdir_flag_spec, $1)\"" AC_LINK_IFELSE([AC_LANG_PROGRAM([],[])], [AS_IF([ ($OBJDUMP -p conftest$ac_exeext) 2>/dev/null | grep "RUNPATH.*$libdir" >/dev/null], [lt_cv_shlibpath_overrides_runpath=yes])]) LDFLAGS=$save_LDFLAGS libdir=$save_libdir ]) shlibpath_overrides_runpath=$lt_cv_shlibpath_overrides_runpath # This implies no fast_install, which is unacceptable. # Some rework will be needed to allow for fast_install # before this can be enabled. hardcode_into_libs=yes # Ideally, we could use ldconfig to report *all* directores which are # searched for libraries, however this is still not possible. Aside from not # being certain /sbin/ldconfig is available, command # 'ldconfig -N -X -v | grep ^/' on 64bit Fedora does not report /usr/lib64, # even though it is searched at run-time. Try to do the best guess by # appending ld.so.conf contents (and includes) to the search path. if test -f /etc/ld.so.conf; then lt_ld_extra=`awk '/^include / { system(sprintf("cd /etc; cat %s 2>/dev/null", \[$]2)); skip = 1; } { if (!skip) print \[$]0; skip = 0; }' < /etc/ld.so.conf | $SED -e 's/#.*//;/^[ ]*hwcap[ ]/d;s/[:, ]/ /g;s/=[^=]*$//;s/=[^= ]* / /g;s/"//g;/^$/d' | tr '\n' ' '` sys_lib_dlsearch_path_spec="/lib /usr/lib $lt_ld_extra" fi # We used to test for /lib/ld.so.1 and disable shared libraries on # powerpc, because MkLinux only supported shared libraries with the # GNU dynamic linker. Since this was broken with cross compilers, # most powerpc-linux boxes support dynamic linking these days and # people can always --disable-shared, the test was removed, and we # assume the GNU/Linux dynamic linker is in use. dynamic_linker='GNU/Linux ld.so' ;; netbsd*) version_type=sunos need_lib_prefix=no need_version=no if echo __ELF__ | $CC -E - | $GREP __ELF__ >/dev/null; then library_names_spec='$libname$release$shared_ext$versuffix $libname$shared_ext$versuffix' finish_cmds='PATH="\$PATH:/sbin" ldconfig -m $libdir' dynamic_linker='NetBSD (a.out) ld.so' else library_names_spec='$libname$release$shared_ext$versuffix $libname$release$shared_ext$major $libname$shared_ext' soname_spec='$libname$release$shared_ext$major' dynamic_linker='NetBSD ld.elf_so' fi shlibpath_var=LD_LIBRARY_PATH shlibpath_overrides_runpath=yes hardcode_into_libs=yes ;; newsos6) version_type=linux # correct to gnu/linux during the next big refactor library_names_spec='$libname$release$shared_ext$versuffix $libname$release$shared_ext$major $libname$shared_ext' shlibpath_var=LD_LIBRARY_PATH shlibpath_overrides_runpath=yes ;; *nto* | *qnx*) version_type=qnx need_lib_prefix=no need_version=no library_names_spec='$libname$release$shared_ext$versuffix $libname$release$shared_ext$major $libname$shared_ext' soname_spec='$libname$release$shared_ext$major' shlibpath_var=LD_LIBRARY_PATH shlibpath_overrides_runpath=no hardcode_into_libs=yes dynamic_linker='ldqnx.so' ;; openbsd* | bitrig*) version_type=sunos sys_lib_dlsearch_path_spec=/usr/lib need_lib_prefix=no if test -z "`echo __ELF__ | $CC -E - | $GREP __ELF__`"; then need_version=no else need_version=yes fi library_names_spec='$libname$release$shared_ext$versuffix $libname$shared_ext$versuffix' finish_cmds='PATH="\$PATH:/sbin" ldconfig -m $libdir' shlibpath_var=LD_LIBRARY_PATH shlibpath_overrides_runpath=yes ;; os2*) libname_spec='$name' version_type=windows shrext_cmds=.dll need_version=no need_lib_prefix=no # OS/2 can only load a DLL with a base name of 8 characters or less. soname_spec='`test -n "$os2dllname" && libname="$os2dllname"; v=$($ECHO $release$versuffix | tr -d .-); n=$($ECHO $libname | cut -b -$((8 - ${#v})) | tr . _); $ECHO $n$v`$shared_ext' library_names_spec='${libname}_dll.$libext' dynamic_linker='OS/2 ld.exe' shlibpath_var=BEGINLIBPATH sys_lib_search_path_spec="/lib /usr/lib /usr/local/lib" sys_lib_dlsearch_path_spec=$sys_lib_search_path_spec postinstall_cmds='base_file=`basename \$file`~ dlpath=`$SHELL 2>&1 -c '\''. $dir/'\''\$base_file'\''i; $ECHO \$dlname'\''`~ dldir=$destdir/`dirname \$dlpath`~ test -d \$dldir || mkdir -p \$dldir~ $install_prog $dir/$dlname \$dldir/$dlname~ chmod a+x \$dldir/$dlname~ if test -n '\''$stripme'\'' && test -n '\''$striplib'\''; then eval '\''$striplib \$dldir/$dlname'\'' || exit \$?; fi' postuninstall_cmds='dldll=`$SHELL 2>&1 -c '\''. $file; $ECHO \$dlname'\''`~ dlpath=$dir/\$dldll~ $RM \$dlpath' ;; osf3* | osf4* | osf5*) version_type=osf need_lib_prefix=no need_version=no soname_spec='$libname$release$shared_ext$major' library_names_spec='$libname$release$shared_ext$versuffix $libname$release$shared_ext$major $libname$shared_ext' shlibpath_var=LD_LIBRARY_PATH sys_lib_search_path_spec="/usr/shlib /usr/ccs/lib /usr/lib/cmplrs/cc /usr/lib /usr/local/lib /var/shlib" sys_lib_dlsearch_path_spec=$sys_lib_search_path_spec ;; rdos*) dynamic_linker=no ;; solaris*) version_type=linux # correct to gnu/linux during the next big refactor need_lib_prefix=no need_version=no library_names_spec='$libname$release$shared_ext$versuffix $libname$release$shared_ext$major $libname$shared_ext' soname_spec='$libname$release$shared_ext$major' shlibpath_var=LD_LIBRARY_PATH shlibpath_overrides_runpath=yes hardcode_into_libs=yes # ldd complains unless libraries are executable postinstall_cmds='chmod +x $lib' ;; sunos4*) version_type=sunos library_names_spec='$libname$release$shared_ext$versuffix $libname$shared_ext$versuffix' finish_cmds='PATH="\$PATH:/usr/etc" ldconfig $libdir' shlibpath_var=LD_LIBRARY_PATH shlibpath_overrides_runpath=yes if test yes = "$with_gnu_ld"; then need_lib_prefix=no fi need_version=yes ;; sysv4 | sysv4.3*) version_type=linux # correct to gnu/linux during the next big refactor library_names_spec='$libname$release$shared_ext$versuffix $libname$release$shared_ext$major $libname$shared_ext' soname_spec='$libname$release$shared_ext$major' shlibpath_var=LD_LIBRARY_PATH case $host_vendor in sni) shlibpath_overrides_runpath=no need_lib_prefix=no runpath_var=LD_RUN_PATH ;; siemens) need_lib_prefix=no ;; motorola) need_lib_prefix=no need_version=no shlibpath_overrides_runpath=no sys_lib_search_path_spec='/lib /usr/lib /usr/ccs/lib' ;; esac ;; sysv4*MP*) if test -d /usr/nec; then version_type=linux # correct to gnu/linux during the next big refactor library_names_spec='$libname$shared_ext.$versuffix $libname$shared_ext.$major $libname$shared_ext' soname_spec='$libname$shared_ext.$major' shlibpath_var=LD_LIBRARY_PATH fi ;; sysv5* | sco3.2v5* | sco5v6* | unixware* | OpenUNIX* | sysv4*uw2*) version_type=sco need_lib_prefix=no need_version=no library_names_spec='$libname$release$shared_ext$versuffix $libname$release$shared_ext $libname$shared_ext' soname_spec='$libname$release$shared_ext$major' shlibpath_var=LD_LIBRARY_PATH shlibpath_overrides_runpath=yes hardcode_into_libs=yes if test yes = "$with_gnu_ld"; then sys_lib_search_path_spec='/usr/local/lib /usr/gnu/lib /usr/ccs/lib /usr/lib /lib' else sys_lib_search_path_spec='/usr/ccs/lib /usr/lib' case $host_os in sco3.2v5*) sys_lib_search_path_spec="$sys_lib_search_path_spec /lib" ;; esac fi sys_lib_dlsearch_path_spec='/usr/lib' ;; tpf*) # TPF is a cross-target only. Preferred cross-host = GNU/Linux. version_type=linux # correct to gnu/linux during the next big refactor need_lib_prefix=no need_version=no library_names_spec='$libname$release$shared_ext$versuffix $libname$release$shared_ext$major $libname$shared_ext' shlibpath_var=LD_LIBRARY_PATH shlibpath_overrides_runpath=no hardcode_into_libs=yes ;; uts4*) version_type=linux # correct to gnu/linux during the next big refactor library_names_spec='$libname$release$shared_ext$versuffix $libname$release$shared_ext$major $libname$shared_ext' soname_spec='$libname$release$shared_ext$major' shlibpath_var=LD_LIBRARY_PATH ;; *) dynamic_linker=no ;; esac AC_MSG_RESULT([$dynamic_linker]) test no = "$dynamic_linker" && can_build_shared=no variables_saved_for_relink="PATH $shlibpath_var $runpath_var" if test yes = "$GCC"; then variables_saved_for_relink="$variables_saved_for_relink GCC_EXEC_PREFIX COMPILER_PATH LIBRARY_PATH" fi if test set = "${lt_cv_sys_lib_search_path_spec+set}"; then sys_lib_search_path_spec=$lt_cv_sys_lib_search_path_spec fi if test set = "${lt_cv_sys_lib_dlsearch_path_spec+set}"; then sys_lib_dlsearch_path_spec=$lt_cv_sys_lib_dlsearch_path_spec fi # remember unaugmented sys_lib_dlsearch_path content for libtool script decls... configure_time_dlsearch_path=$sys_lib_dlsearch_path_spec # ... but it needs LT_SYS_LIBRARY_PATH munging for other configure-time code func_munge_path_list sys_lib_dlsearch_path_spec "$LT_SYS_LIBRARY_PATH" # to be used as default LT_SYS_LIBRARY_PATH value in generated libtool configure_time_lt_sys_library_path=$LT_SYS_LIBRARY_PATH _LT_DECL([], [variables_saved_for_relink], [1], [Variables whose values should be saved in libtool wrapper scripts and restored at link time]) _LT_DECL([], [need_lib_prefix], [0], [Do we need the "lib" prefix for modules?]) _LT_DECL([], [need_version], [0], [Do we need a version for libraries?]) _LT_DECL([], [version_type], [0], [Library versioning type]) _LT_DECL([], [runpath_var], [0], [Shared library runtime path variable]) _LT_DECL([], [shlibpath_var], [0],[Shared library path variable]) _LT_DECL([], [shlibpath_overrides_runpath], [0], [Is shlibpath searched before the hard-coded library search path?]) _LT_DECL([], [libname_spec], [1], [Format of library name prefix]) _LT_DECL([], [library_names_spec], [1], [[List of archive names. First name is the real one, the rest are links. The last name is the one that the linker finds with -lNAME]]) _LT_DECL([], [soname_spec], [1], [[The coded name of the library, if different from the real name]]) _LT_DECL([], [install_override_mode], [1], [Permission mode override for installation of shared libraries]) _LT_DECL([], [postinstall_cmds], [2], [Command to use after installation of a shared archive]) _LT_DECL([], [postuninstall_cmds], [2], [Command to use after uninstallation of a shared archive]) _LT_DECL([], [finish_cmds], [2], [Commands used to finish a libtool library installation in a directory]) _LT_DECL([], [finish_eval], [1], [[As "finish_cmds", except a single script fragment to be evaled but not shown]]) _LT_DECL([], [hardcode_into_libs], [0], [Whether we should hardcode library paths into libraries]) _LT_DECL([], [sys_lib_search_path_spec], [2], [Compile-time system search path for libraries]) _LT_DECL([sys_lib_dlsearch_path_spec], [configure_time_dlsearch_path], [2], [Detected run-time system search path for libraries]) _LT_DECL([], [configure_time_lt_sys_library_path], [2], [Explicit LT_SYS_LIBRARY_PATH set during ./configure time]) ])# _LT_SYS_DYNAMIC_LINKER # _LT_PATH_TOOL_PREFIX(TOOL) # -------------------------- # find a file program that can recognize shared library AC_DEFUN([_LT_PATH_TOOL_PREFIX], [m4_require([_LT_DECL_EGREP])dnl AC_MSG_CHECKING([for $1]) AC_CACHE_VAL(lt_cv_path_MAGIC_CMD, [case $MAGIC_CMD in [[\\/*] | ?:[\\/]*]) lt_cv_path_MAGIC_CMD=$MAGIC_CMD # Let the user override the test with a path. ;; *) lt_save_MAGIC_CMD=$MAGIC_CMD lt_save_ifs=$IFS; IFS=$PATH_SEPARATOR dnl $ac_dummy forces splitting on constant user-supplied paths. dnl POSIX.2 word splitting is done only on the output of word expansions, dnl not every word. This closes a longstanding sh security hole. ac_dummy="m4_if([$2], , $PATH, [$2])" for ac_dir in $ac_dummy; do IFS=$lt_save_ifs test -z "$ac_dir" && ac_dir=. if test -f "$ac_dir/$1"; then lt_cv_path_MAGIC_CMD=$ac_dir/"$1" if test -n "$file_magic_test_file"; then case $deplibs_check_method in "file_magic "*) file_magic_regex=`expr "$deplibs_check_method" : "file_magic \(.*\)"` MAGIC_CMD=$lt_cv_path_MAGIC_CMD if eval $file_magic_cmd \$file_magic_test_file 2> /dev/null | $EGREP "$file_magic_regex" > /dev/null; then : else cat <<_LT_EOF 1>&2 *** Warning: the command libtool uses to detect shared libraries, *** $file_magic_cmd, produces output that libtool cannot recognize. *** The result is that libtool may fail to recognize shared libraries *** as such. This will affect the creation of libtool libraries that *** depend on shared libraries, but programs linked with such libtool *** libraries will work regardless of this problem. Nevertheless, you *** may want to report the problem to your system manager and/or to *** bug-libtool@gnu.org _LT_EOF fi ;; esac fi break fi done IFS=$lt_save_ifs MAGIC_CMD=$lt_save_MAGIC_CMD ;; esac]) MAGIC_CMD=$lt_cv_path_MAGIC_CMD if test -n "$MAGIC_CMD"; then AC_MSG_RESULT($MAGIC_CMD) else AC_MSG_RESULT(no) fi _LT_DECL([], [MAGIC_CMD], [0], [Used to examine libraries when file_magic_cmd begins with "file"])dnl ])# _LT_PATH_TOOL_PREFIX # Old name: AU_ALIAS([AC_PATH_TOOL_PREFIX], [_LT_PATH_TOOL_PREFIX]) dnl aclocal-1.4 backwards compatibility: dnl AC_DEFUN([AC_PATH_TOOL_PREFIX], []) # _LT_PATH_MAGIC # -------------- # find a file program that can recognize a shared library m4_defun([_LT_PATH_MAGIC], [_LT_PATH_TOOL_PREFIX(${ac_tool_prefix}file, /usr/bin$PATH_SEPARATOR$PATH) if test -z "$lt_cv_path_MAGIC_CMD"; then if test -n "$ac_tool_prefix"; then _LT_PATH_TOOL_PREFIX(file, /usr/bin$PATH_SEPARATOR$PATH) else MAGIC_CMD=: fi fi ])# _LT_PATH_MAGIC # LT_PATH_LD # ---------- # find the pathname to the GNU or non-GNU linker AC_DEFUN([LT_PATH_LD], [AC_REQUIRE([AC_PROG_CC])dnl AC_REQUIRE([AC_CANONICAL_HOST])dnl AC_REQUIRE([AC_CANONICAL_BUILD])dnl m4_require([_LT_DECL_SED])dnl m4_require([_LT_DECL_EGREP])dnl m4_require([_LT_PROG_ECHO_BACKSLASH])dnl AC_ARG_WITH([gnu-ld], [AS_HELP_STRING([--with-gnu-ld], [assume the C compiler uses GNU ld @<:@default=no@:>@])], [test no = "$withval" || with_gnu_ld=yes], [with_gnu_ld=no])dnl ac_prog=ld if test yes = "$GCC"; then # Check if gcc -print-prog-name=ld gives a path. AC_MSG_CHECKING([for ld used by $CC]) case $host in *-*-mingw*) # gcc leaves a trailing carriage return, which upsets mingw ac_prog=`($CC -print-prog-name=ld) 2>&5 | tr -d '\015'` ;; *) ac_prog=`($CC -print-prog-name=ld) 2>&5` ;; esac case $ac_prog in # Accept absolute paths. [[\\/]]* | ?:[[\\/]]*) re_direlt='/[[^/]][[^/]]*/\.\./' # Canonicalize the pathname of ld ac_prog=`$ECHO "$ac_prog"| $SED 's%\\\\%/%g'` while $ECHO "$ac_prog" | $GREP "$re_direlt" > /dev/null 2>&1; do ac_prog=`$ECHO $ac_prog| $SED "s%$re_direlt%/%"` done test -z "$LD" && LD=$ac_prog ;; "") # If it fails, then pretend we aren't using GCC. ac_prog=ld ;; *) # If it is relative, then search for the first ld in PATH. with_gnu_ld=unknown ;; esac elif test yes = "$with_gnu_ld"; then AC_MSG_CHECKING([for GNU ld]) else AC_MSG_CHECKING([for non-GNU ld]) fi AC_CACHE_VAL(lt_cv_path_LD, [if test -z "$LD"; then lt_save_ifs=$IFS; IFS=$PATH_SEPARATOR for ac_dir in $PATH; do IFS=$lt_save_ifs test -z "$ac_dir" && ac_dir=. if test -f "$ac_dir/$ac_prog" || test -f "$ac_dir/$ac_prog$ac_exeext"; then lt_cv_path_LD=$ac_dir/$ac_prog # Check to see if the program is GNU ld. I'd rather use --version, # but apparently some variants of GNU ld only accept -v. # Break only if it was the GNU/non-GNU ld that we prefer. case `"$lt_cv_path_LD" -v 2>&1 &1 conftest.i cat conftest.i conftest.i >conftest2.i : ${lt_DD:=$DD} AC_PATH_PROGS_FEATURE_CHECK([lt_DD], [dd], [if "$ac_path_lt_DD" bs=32 count=1 conftest.out 2>/dev/null; then cmp -s conftest.i conftest.out \ && ac_cv_path_lt_DD="$ac_path_lt_DD" ac_path_lt_DD_found=: fi]) rm -f conftest.i conftest2.i conftest.out]) ])# _LT_PATH_DD # _LT_CMD_TRUNCATE # ---------------- # find command to truncate a binary pipe m4_defun([_LT_CMD_TRUNCATE], [m4_require([_LT_PATH_DD]) AC_CACHE_CHECK([how to truncate binary pipes], [lt_cv_truncate_bin], [printf 0123456789abcdef0123456789abcdef >conftest.i cat conftest.i conftest.i >conftest2.i lt_cv_truncate_bin= if "$ac_cv_path_lt_DD" bs=32 count=1 conftest.out 2>/dev/null; then cmp -s conftest.i conftest.out \ && lt_cv_truncate_bin="$ac_cv_path_lt_DD bs=4096 count=1" fi rm -f conftest.i conftest2.i conftest.out test -z "$lt_cv_truncate_bin" && lt_cv_truncate_bin="$SED -e 4q"]) _LT_DECL([lt_truncate_bin], [lt_cv_truncate_bin], [1], [Command to truncate a binary pipe]) ])# _LT_CMD_TRUNCATE # _LT_CHECK_MAGIC_METHOD # ---------------------- # how to check for library dependencies # -- PORTME fill in with the dynamic library characteristics m4_defun([_LT_CHECK_MAGIC_METHOD], [m4_require([_LT_DECL_EGREP]) m4_require([_LT_DECL_OBJDUMP]) AC_CACHE_CHECK([how to recognize dependent libraries], lt_cv_deplibs_check_method, [lt_cv_file_magic_cmd='$MAGIC_CMD' lt_cv_file_magic_test_file= lt_cv_deplibs_check_method='unknown' # Need to set the preceding variable on all platforms that support # interlibrary dependencies. # 'none' -- dependencies not supported. # 'unknown' -- same as none, but documents that we really don't know. # 'pass_all' -- all dependencies passed with no checks. # 'test_compile' -- check by making test program. # 'file_magic [[regex]]' -- check by looking for files in library path # that responds to the $file_magic_cmd with a given extended regex. # If you have 'file' or equivalent on your system and you're not sure # whether 'pass_all' will *always* work, you probably want this one. case $host_os in aix[[4-9]]*) lt_cv_deplibs_check_method=pass_all ;; beos*) lt_cv_deplibs_check_method=pass_all ;; bsdi[[45]]*) lt_cv_deplibs_check_method='file_magic ELF [[0-9]][[0-9]]*-bit [[ML]]SB (shared object|dynamic lib)' lt_cv_file_magic_cmd='/usr/bin/file -L' lt_cv_file_magic_test_file=/shlib/libc.so ;; cygwin*) # func_win32_libid is a shell function defined in ltmain.sh lt_cv_deplibs_check_method='file_magic ^x86 archive import|^x86 DLL' lt_cv_file_magic_cmd='func_win32_libid' ;; mingw* | pw32*) # Base MSYS/MinGW do not provide the 'file' command needed by # func_win32_libid shell function, so use a weaker test based on 'objdump', # unless we find 'file', for example because we are cross-compiling. if ( file / ) >/dev/null 2>&1; then lt_cv_deplibs_check_method='file_magic ^x86 archive import|^x86 DLL' lt_cv_file_magic_cmd='func_win32_libid' else # Keep this pattern in sync with the one in func_win32_libid. lt_cv_deplibs_check_method='file_magic file format (pei*-i386(.*architecture: i386)?|pe-arm-wince|pe-x86-64)' lt_cv_file_magic_cmd='$OBJDUMP -f' fi ;; cegcc*) # use the weaker test based on 'objdump'. See mingw*. lt_cv_deplibs_check_method='file_magic file format pe-arm-.*little(.*architecture: arm)?' lt_cv_file_magic_cmd='$OBJDUMP -f' ;; darwin* | rhapsody*) lt_cv_deplibs_check_method=pass_all ;; freebsd* | dragonfly*) if echo __ELF__ | $CC -E - | $GREP __ELF__ > /dev/null; then case $host_cpu in i*86 ) # Not sure whether the presence of OpenBSD here was a mistake. # Let's accept both of them until this is cleared up. lt_cv_deplibs_check_method='file_magic (FreeBSD|OpenBSD|DragonFly)/i[[3-9]]86 (compact )?demand paged shared library' lt_cv_file_magic_cmd=/usr/bin/file lt_cv_file_magic_test_file=`echo /usr/lib/libc.so.*` ;; esac else lt_cv_deplibs_check_method=pass_all fi ;; haiku*) lt_cv_deplibs_check_method=pass_all ;; hpux10.20* | hpux11*) lt_cv_file_magic_cmd=/usr/bin/file case $host_cpu in ia64*) lt_cv_deplibs_check_method='file_magic (s[[0-9]][[0-9]][[0-9]]|ELF-[[0-9]][[0-9]]) shared object file - IA64' lt_cv_file_magic_test_file=/usr/lib/hpux32/libc.so ;; hppa*64*) [lt_cv_deplibs_check_method='file_magic (s[0-9][0-9][0-9]|ELF[ -][0-9][0-9])(-bit)?( [LM]SB)? shared object( file)?[, -]* PA-RISC [0-9]\.[0-9]'] lt_cv_file_magic_test_file=/usr/lib/pa20_64/libc.sl ;; *) lt_cv_deplibs_check_method='file_magic (s[[0-9]][[0-9]][[0-9]]|PA-RISC[[0-9]]\.[[0-9]]) shared library' lt_cv_file_magic_test_file=/usr/lib/libc.sl ;; esac ;; interix[[3-9]]*) # PIC code is broken on Interix 3.x, that's why |\.a not |_pic\.a here lt_cv_deplibs_check_method='match_pattern /lib[[^/]]+(\.so|\.a)$' ;; irix5* | irix6* | nonstopux*) case $LD in *-32|*"-32 ") libmagic=32-bit;; *-n32|*"-n32 ") libmagic=N32;; *-64|*"-64 ") libmagic=64-bit;; *) libmagic=never-match;; esac lt_cv_deplibs_check_method=pass_all ;; # This must be glibc/ELF. linux* | k*bsd*-gnu | kopensolaris*-gnu | gnu*) lt_cv_deplibs_check_method=pass_all ;; netbsd*) if echo __ELF__ | $CC -E - | $GREP __ELF__ > /dev/null; then lt_cv_deplibs_check_method='match_pattern /lib[[^/]]+(\.so\.[[0-9]]+\.[[0-9]]+|_pic\.a)$' else lt_cv_deplibs_check_method='match_pattern /lib[[^/]]+(\.so|_pic\.a)$' fi ;; newos6*) lt_cv_deplibs_check_method='file_magic ELF [[0-9]][[0-9]]*-bit [[ML]]SB (executable|dynamic lib)' lt_cv_file_magic_cmd=/usr/bin/file lt_cv_file_magic_test_file=/usr/lib/libnls.so ;; *nto* | *qnx*) lt_cv_deplibs_check_method=pass_all ;; openbsd* | bitrig*) if test -z "`echo __ELF__ | $CC -E - | $GREP __ELF__`"; then lt_cv_deplibs_check_method='match_pattern /lib[[^/]]+(\.so\.[[0-9]]+\.[[0-9]]+|\.so|_pic\.a)$' else lt_cv_deplibs_check_method='match_pattern /lib[[^/]]+(\.so\.[[0-9]]+\.[[0-9]]+|_pic\.a)$' fi ;; osf3* | osf4* | osf5*) lt_cv_deplibs_check_method=pass_all ;; rdos*) lt_cv_deplibs_check_method=pass_all ;; solaris*) lt_cv_deplibs_check_method=pass_all ;; sysv5* | sco3.2v5* | sco5v6* | unixware* | OpenUNIX* | sysv4*uw2*) lt_cv_deplibs_check_method=pass_all ;; sysv4 | sysv4.3*) case $host_vendor in motorola) lt_cv_deplibs_check_method='file_magic ELF [[0-9]][[0-9]]*-bit [[ML]]SB (shared object|dynamic lib) M[[0-9]][[0-9]]* Version [[0-9]]' lt_cv_file_magic_test_file=`echo /usr/lib/libc.so*` ;; ncr) lt_cv_deplibs_check_method=pass_all ;; sequent) lt_cv_file_magic_cmd='/bin/file' lt_cv_deplibs_check_method='file_magic ELF [[0-9]][[0-9]]*-bit [[LM]]SB (shared object|dynamic lib )' ;; sni) lt_cv_file_magic_cmd='/bin/file' lt_cv_deplibs_check_method="file_magic ELF [[0-9]][[0-9]]*-bit [[LM]]SB dynamic lib" lt_cv_file_magic_test_file=/lib/libc.so ;; siemens) lt_cv_deplibs_check_method=pass_all ;; pc) lt_cv_deplibs_check_method=pass_all ;; esac ;; tpf*) lt_cv_deplibs_check_method=pass_all ;; os2*) lt_cv_deplibs_check_method=pass_all ;; esac ]) file_magic_glob= want_nocaseglob=no if test "$build" = "$host"; then case $host_os in mingw* | pw32*) if ( shopt | grep nocaseglob ) >/dev/null 2>&1; then want_nocaseglob=yes else file_magic_glob=`echo aAbBcCdDeEfFgGhHiIjJkKlLmMnNoOpPqQrRsStTuUvVwWxXyYzZ | $SED -e "s/\(..\)/s\/[[\1]]\/[[\1]]\/g;/g"` fi ;; esac fi file_magic_cmd=$lt_cv_file_magic_cmd deplibs_check_method=$lt_cv_deplibs_check_method test -z "$deplibs_check_method" && deplibs_check_method=unknown _LT_DECL([], [deplibs_check_method], [1], [Method to check whether dependent libraries are shared objects]) _LT_DECL([], [file_magic_cmd], [1], [Command to use when deplibs_check_method = "file_magic"]) _LT_DECL([], [file_magic_glob], [1], [How to find potential files when deplibs_check_method = "file_magic"]) _LT_DECL([], [want_nocaseglob], [1], [Find potential files using nocaseglob when deplibs_check_method = "file_magic"]) ])# _LT_CHECK_MAGIC_METHOD # LT_PATH_NM # ---------- # find the pathname to a BSD- or MS-compatible name lister AC_DEFUN([LT_PATH_NM], [AC_REQUIRE([AC_PROG_CC])dnl AC_CACHE_CHECK([for BSD- or MS-compatible name lister (nm)], lt_cv_path_NM, [if test -n "$NM"; then # Let the user override the test. lt_cv_path_NM=$NM else lt_nm_to_check=${ac_tool_prefix}nm if test -n "$ac_tool_prefix" && test "$build" = "$host"; then lt_nm_to_check="$lt_nm_to_check nm" fi for lt_tmp_nm in $lt_nm_to_check; do lt_save_ifs=$IFS; IFS=$PATH_SEPARATOR for ac_dir in $PATH /usr/ccs/bin/elf /usr/ccs/bin /usr/ucb /bin; do IFS=$lt_save_ifs test -z "$ac_dir" && ac_dir=. tmp_nm=$ac_dir/$lt_tmp_nm if test -f "$tmp_nm" || test -f "$tmp_nm$ac_exeext"; then # Check to see if the nm accepts a BSD-compat flag. # Adding the 'sed 1q' prevents false positives on HP-UX, which says: # nm: unknown option "B" ignored # Tru64's nm complains that /dev/null is an invalid object file # MSYS converts /dev/null to NUL, MinGW nm treats NUL as empty case $build_os in mingw*) lt_bad_file=conftest.nm/nofile ;; *) lt_bad_file=/dev/null ;; esac case `"$tmp_nm" -B $lt_bad_file 2>&1 | sed '1q'` in *$lt_bad_file* | *'Invalid file or object type'*) lt_cv_path_NM="$tmp_nm -B" break 2 ;; *) case `"$tmp_nm" -p /dev/null 2>&1 | sed '1q'` in */dev/null*) lt_cv_path_NM="$tmp_nm -p" break 2 ;; *) lt_cv_path_NM=${lt_cv_path_NM="$tmp_nm"} # keep the first match, but continue # so that we can try to find one that supports BSD flags ;; esac ;; esac fi done IFS=$lt_save_ifs done : ${lt_cv_path_NM=no} fi]) if test no != "$lt_cv_path_NM"; then NM=$lt_cv_path_NM else # Didn't find any BSD compatible name lister, look for dumpbin. if test -n "$DUMPBIN"; then : # Let the user override the test. else AC_CHECK_TOOLS(DUMPBIN, [dumpbin "link -dump"], :) case `$DUMPBIN -symbols -headers /dev/null 2>&1 | sed '1q'` in *COFF*) DUMPBIN="$DUMPBIN -symbols -headers" ;; *) DUMPBIN=: ;; esac fi AC_SUBST([DUMPBIN]) if test : != "$DUMPBIN"; then NM=$DUMPBIN fi fi test -z "$NM" && NM=nm AC_SUBST([NM]) _LT_DECL([], [NM], [1], [A BSD- or MS-compatible name lister])dnl AC_CACHE_CHECK([the name lister ($NM) interface], [lt_cv_nm_interface], [lt_cv_nm_interface="BSD nm" echo "int some_variable = 0;" > conftest.$ac_ext (eval echo "\"\$as_me:$LINENO: $ac_compile\"" >&AS_MESSAGE_LOG_FD) (eval "$ac_compile" 2>conftest.err) cat conftest.err >&AS_MESSAGE_LOG_FD (eval echo "\"\$as_me:$LINENO: $NM \\\"conftest.$ac_objext\\\"\"" >&AS_MESSAGE_LOG_FD) (eval "$NM \"conftest.$ac_objext\"" 2>conftest.err > conftest.out) cat conftest.err >&AS_MESSAGE_LOG_FD (eval echo "\"\$as_me:$LINENO: output\"" >&AS_MESSAGE_LOG_FD) cat conftest.out >&AS_MESSAGE_LOG_FD if $GREP 'External.*some_variable' conftest.out > /dev/null; then lt_cv_nm_interface="MS dumpbin" fi rm -f conftest*]) ])# LT_PATH_NM # Old names: AU_ALIAS([AM_PROG_NM], [LT_PATH_NM]) AU_ALIAS([AC_PROG_NM], [LT_PATH_NM]) dnl aclocal-1.4 backwards compatibility: dnl AC_DEFUN([AM_PROG_NM], []) dnl AC_DEFUN([AC_PROG_NM], []) # _LT_CHECK_SHAREDLIB_FROM_LINKLIB # -------------------------------- # how to determine the name of the shared library # associated with a specific link library. # -- PORTME fill in with the dynamic library characteristics m4_defun([_LT_CHECK_SHAREDLIB_FROM_LINKLIB], [m4_require([_LT_DECL_EGREP]) m4_require([_LT_DECL_OBJDUMP]) m4_require([_LT_DECL_DLLTOOL]) AC_CACHE_CHECK([how to associate runtime and link libraries], lt_cv_sharedlib_from_linklib_cmd, [lt_cv_sharedlib_from_linklib_cmd='unknown' case $host_os in cygwin* | mingw* | pw32* | cegcc*) # two different shell functions defined in ltmain.sh; # decide which one to use based on capabilities of $DLLTOOL case `$DLLTOOL --help 2>&1` in *--identify-strict*) lt_cv_sharedlib_from_linklib_cmd=func_cygming_dll_for_implib ;; *) lt_cv_sharedlib_from_linklib_cmd=func_cygming_dll_for_implib_fallback ;; esac ;; *) # fallback: assume linklib IS sharedlib lt_cv_sharedlib_from_linklib_cmd=$ECHO ;; esac ]) sharedlib_from_linklib_cmd=$lt_cv_sharedlib_from_linklib_cmd test -z "$sharedlib_from_linklib_cmd" && sharedlib_from_linklib_cmd=$ECHO _LT_DECL([], [sharedlib_from_linklib_cmd], [1], [Command to associate shared and link libraries]) ])# _LT_CHECK_SHAREDLIB_FROM_LINKLIB # _LT_PATH_MANIFEST_TOOL # ---------------------- # locate the manifest tool m4_defun([_LT_PATH_MANIFEST_TOOL], [AC_CHECK_TOOL(MANIFEST_TOOL, mt, :) test -z "$MANIFEST_TOOL" && MANIFEST_TOOL=mt AC_CACHE_CHECK([if $MANIFEST_TOOL is a manifest tool], [lt_cv_path_mainfest_tool], [lt_cv_path_mainfest_tool=no echo "$as_me:$LINENO: $MANIFEST_TOOL '-?'" >&AS_MESSAGE_LOG_FD $MANIFEST_TOOL '-?' 2>conftest.err > conftest.out cat conftest.err >&AS_MESSAGE_LOG_FD if $GREP 'Manifest Tool' conftest.out > /dev/null; then lt_cv_path_mainfest_tool=yes fi rm -f conftest*]) if test yes != "$lt_cv_path_mainfest_tool"; then MANIFEST_TOOL=: fi _LT_DECL([], [MANIFEST_TOOL], [1], [Manifest tool])dnl ])# _LT_PATH_MANIFEST_TOOL # _LT_DLL_DEF_P([FILE]) # --------------------- # True iff FILE is a Windows DLL '.def' file. # Keep in sync with func_dll_def_p in the libtool script AC_DEFUN([_LT_DLL_DEF_P], [dnl test DEF = "`$SED -n dnl -e '\''s/^[[ ]]*//'\'' dnl Strip leading whitespace -e '\''/^\(;.*\)*$/d'\'' dnl Delete empty lines and comments -e '\''s/^\(EXPORTS\|LIBRARY\)\([[ ]].*\)*$/DEF/p'\'' dnl -e q dnl Only consider the first "real" line $1`" dnl ])# _LT_DLL_DEF_P # LT_LIB_M # -------- # check for math library AC_DEFUN([LT_LIB_M], [AC_REQUIRE([AC_CANONICAL_HOST])dnl LIBM= case $host in *-*-beos* | *-*-cegcc* | *-*-cygwin* | *-*-haiku* | *-*-pw32* | *-*-darwin*) # These system don't have libm, or don't need it ;; *-ncr-sysv4.3*) AC_CHECK_LIB(mw, _mwvalidcheckl, LIBM=-lmw) AC_CHECK_LIB(m, cos, LIBM="$LIBM -lm") ;; *) AC_CHECK_LIB(m, cos, LIBM=-lm) ;; esac AC_SUBST([LIBM]) ])# LT_LIB_M # Old name: AU_ALIAS([AC_CHECK_LIBM], [LT_LIB_M]) dnl aclocal-1.4 backwards compatibility: dnl AC_DEFUN([AC_CHECK_LIBM], []) # _LT_COMPILER_NO_RTTI([TAGNAME]) # ------------------------------- m4_defun([_LT_COMPILER_NO_RTTI], [m4_require([_LT_TAG_COMPILER])dnl _LT_TAGVAR(lt_prog_compiler_no_builtin_flag, $1)= if test yes = "$GCC"; then case $cc_basename in nvcc*) _LT_TAGVAR(lt_prog_compiler_no_builtin_flag, $1)=' -Xcompiler -fno-builtin' ;; *) _LT_TAGVAR(lt_prog_compiler_no_builtin_flag, $1)=' -fno-builtin' ;; esac _LT_COMPILER_OPTION([if $compiler supports -fno-rtti -fno-exceptions], lt_cv_prog_compiler_rtti_exceptions, [-fno-rtti -fno-exceptions], [], [_LT_TAGVAR(lt_prog_compiler_no_builtin_flag, $1)="$_LT_TAGVAR(lt_prog_compiler_no_builtin_flag, $1) -fno-rtti -fno-exceptions"]) fi _LT_TAGDECL([no_builtin_flag], [lt_prog_compiler_no_builtin_flag], [1], [Compiler flag to turn off builtin functions]) ])# _LT_COMPILER_NO_RTTI # _LT_CMD_GLOBAL_SYMBOLS # ---------------------- m4_defun([_LT_CMD_GLOBAL_SYMBOLS], [AC_REQUIRE([AC_CANONICAL_HOST])dnl AC_REQUIRE([AC_PROG_CC])dnl AC_REQUIRE([AC_PROG_AWK])dnl AC_REQUIRE([LT_PATH_NM])dnl AC_REQUIRE([LT_PATH_LD])dnl m4_require([_LT_DECL_SED])dnl m4_require([_LT_DECL_EGREP])dnl m4_require([_LT_TAG_COMPILER])dnl # Check for command to grab the raw symbol name followed by C symbol from nm. AC_MSG_CHECKING([command to parse $NM output from $compiler object]) AC_CACHE_VAL([lt_cv_sys_global_symbol_pipe], [ # These are sane defaults that work on at least a few old systems. # [They come from Ultrix. What could be older than Ultrix?!! ;)] # Character class describing NM global symbol codes. symcode='[[BCDEGRST]]' # Regexp to match symbols that can be accessed directly from C. sympat='\([[_A-Za-z]][[_A-Za-z0-9]]*\)' # Define system-specific variables. case $host_os in aix*) symcode='[[BCDT]]' ;; cygwin* | mingw* | pw32* | cegcc*) symcode='[[ABCDGISTW]]' ;; hpux*) if test ia64 = "$host_cpu"; then symcode='[[ABCDEGRST]]' fi ;; irix* | nonstopux*) symcode='[[BCDEGRST]]' ;; osf*) symcode='[[BCDEGQRST]]' ;; solaris*) symcode='[[BDRT]]' ;; sco3.2v5*) symcode='[[DT]]' ;; sysv4.2uw2*) symcode='[[DT]]' ;; sysv5* | sco5v6* | unixware* | OpenUNIX*) symcode='[[ABDT]]' ;; sysv4) symcode='[[DFNSTU]]' ;; esac # If we're using GNU nm, then use its standard symbol codes. case `$NM -V 2>&1` in *GNU* | *'with BFD'*) symcode='[[ABCDGIRSTW]]' ;; esac if test "$lt_cv_nm_interface" = "MS dumpbin"; then # Gets list of data symbols to import. lt_cv_sys_global_symbol_to_import="sed -n -e 's/^I .* \(.*\)$/\1/p'" # Adjust the below global symbol transforms to fixup imported variables. lt_cdecl_hook=" -e 's/^I .* \(.*\)$/extern __declspec(dllimport) char \1;/p'" lt_c_name_hook=" -e 's/^I .* \(.*\)$/ {\"\1\", (void *) 0},/p'" lt_c_name_lib_hook="\ -e 's/^I .* \(lib.*\)$/ {\"\1\", (void *) 0},/p'\ -e 's/^I .* \(.*\)$/ {\"lib\1\", (void *) 0},/p'" else # Disable hooks by default. lt_cv_sys_global_symbol_to_import= lt_cdecl_hook= lt_c_name_hook= lt_c_name_lib_hook= fi # Transform an extracted symbol line into a proper C declaration. # Some systems (esp. on ia64) link data and code symbols differently, # so use this general approach. lt_cv_sys_global_symbol_to_cdecl="sed -n"\ $lt_cdecl_hook\ " -e 's/^T .* \(.*\)$/extern int \1();/p'"\ " -e 's/^$symcode$symcode* .* \(.*\)$/extern char \1;/p'" # Transform an extracted symbol line into symbol name and symbol address lt_cv_sys_global_symbol_to_c_name_address="sed -n"\ $lt_c_name_hook\ " -e 's/^: \(.*\) .*$/ {\"\1\", (void *) 0},/p'"\ " -e 's/^$symcode$symcode* .* \(.*\)$/ {\"\1\", (void *) \&\1},/p'" # Transform an extracted symbol line into symbol name with lib prefix and # symbol address. lt_cv_sys_global_symbol_to_c_name_address_lib_prefix="sed -n"\ $lt_c_name_lib_hook\ " -e 's/^: \(.*\) .*$/ {\"\1\", (void *) 0},/p'"\ " -e 's/^$symcode$symcode* .* \(lib.*\)$/ {\"\1\", (void *) \&\1},/p'"\ " -e 's/^$symcode$symcode* .* \(.*\)$/ {\"lib\1\", (void *) \&\1},/p'" # Handle CRLF in mingw tool chain opt_cr= case $build_os in mingw*) opt_cr=`$ECHO 'x\{0,1\}' | tr x '\015'` # option cr in regexp ;; esac # Try without a prefix underscore, then with it. for ac_symprfx in "" "_"; do # Transform symcode, sympat, and symprfx into a raw symbol and a C symbol. symxfrm="\\1 $ac_symprfx\\2 \\2" # Write the raw and C identifiers. if test "$lt_cv_nm_interface" = "MS dumpbin"; then # Fake it for dumpbin and say T for any non-static function, # D for any global variable and I for any imported variable. # Also find C++ and __fastcall symbols from MSVC++, # which start with @ or ?. lt_cv_sys_global_symbol_pipe="$AWK ['"\ " {last_section=section; section=\$ 3};"\ " /^COFF SYMBOL TABLE/{for(i in hide) delete hide[i]};"\ " /Section length .*#relocs.*(pick any)/{hide[last_section]=1};"\ " /^ *Symbol name *: /{split(\$ 0,sn,\":\"); si=substr(sn[2],2)};"\ " /^ *Type *: code/{print \"T\",si,substr(si,length(prfx))};"\ " /^ *Type *: data/{print \"I\",si,substr(si,length(prfx))};"\ " \$ 0!~/External *\|/{next};"\ " / 0+ UNDEF /{next}; / UNDEF \([^|]\)*()/{next};"\ " {if(hide[section]) next};"\ " {f=\"D\"}; \$ 0~/\(\).*\|/{f=\"T\"};"\ " {split(\$ 0,a,/\||\r/); split(a[2],s)};"\ " s[1]~/^[@?]/{print f,s[1],s[1]; next};"\ " s[1]~prfx {split(s[1],t,\"@\"); print f,t[1],substr(t[1],length(prfx))}"\ " ' prfx=^$ac_symprfx]" else lt_cv_sys_global_symbol_pipe="sed -n -e 's/^.*[[ ]]\($symcode$symcode*\)[[ ]][[ ]]*$ac_symprfx$sympat$opt_cr$/$symxfrm/p'" fi lt_cv_sys_global_symbol_pipe="$lt_cv_sys_global_symbol_pipe | sed '/ __gnu_lto/d'" # Check to see that the pipe works correctly. pipe_works=no rm -f conftest* cat > conftest.$ac_ext <<_LT_EOF #ifdef __cplusplus extern "C" { #endif char nm_test_var; void nm_test_func(void); void nm_test_func(void){} #ifdef __cplusplus } #endif int main(){nm_test_var='a';nm_test_func();return(0);} _LT_EOF if AC_TRY_EVAL(ac_compile); then # Now try to grab the symbols. nlist=conftest.nm if AC_TRY_EVAL(NM conftest.$ac_objext \| "$lt_cv_sys_global_symbol_pipe" \> $nlist) && test -s "$nlist"; then # Try sorting and uniquifying the output. if sort "$nlist" | uniq > "$nlist"T; then mv -f "$nlist"T "$nlist" else rm -f "$nlist"T fi # Make sure that we snagged all the symbols we need. if $GREP ' nm_test_var$' "$nlist" >/dev/null; then if $GREP ' nm_test_func$' "$nlist" >/dev/null; then cat <<_LT_EOF > conftest.$ac_ext /* Keep this code in sync between libtool.m4, ltmain, lt_system.h, and tests. */ #if defined _WIN32 || defined __CYGWIN__ || defined _WIN32_WCE /* DATA imports from DLLs on WIN32 can't be const, because runtime relocations are performed -- see ld's documentation on pseudo-relocs. */ # define LT@&t@_DLSYM_CONST #elif defined __osf__ /* This system does not cope well with relocations in const data. */ # define LT@&t@_DLSYM_CONST #else # define LT@&t@_DLSYM_CONST const #endif #ifdef __cplusplus extern "C" { #endif _LT_EOF # Now generate the symbol file. eval "$lt_cv_sys_global_symbol_to_cdecl"' < "$nlist" | $GREP -v main >> conftest.$ac_ext' cat <<_LT_EOF >> conftest.$ac_ext /* The mapping between symbol names and symbols. */ LT@&t@_DLSYM_CONST struct { const char *name; void *address; } lt__PROGRAM__LTX_preloaded_symbols[[]] = { { "@PROGRAM@", (void *) 0 }, _LT_EOF $SED "s/^$symcode$symcode* .* \(.*\)$/ {\"\1\", (void *) \&\1},/" < "$nlist" | $GREP -v main >> conftest.$ac_ext cat <<\_LT_EOF >> conftest.$ac_ext {0, (void *) 0} }; /* This works around a problem in FreeBSD linker */ #ifdef FREEBSD_WORKAROUND static const void *lt_preloaded_setup() { return lt__PROGRAM__LTX_preloaded_symbols; } #endif #ifdef __cplusplus } #endif _LT_EOF # Now try linking the two files. mv conftest.$ac_objext conftstm.$ac_objext lt_globsym_save_LIBS=$LIBS lt_globsym_save_CFLAGS=$CFLAGS LIBS=conftstm.$ac_objext CFLAGS="$CFLAGS$_LT_TAGVAR(lt_prog_compiler_no_builtin_flag, $1)" if AC_TRY_EVAL(ac_link) && test -s conftest$ac_exeext; then pipe_works=yes fi LIBS=$lt_globsym_save_LIBS CFLAGS=$lt_globsym_save_CFLAGS else echo "cannot find nm_test_func in $nlist" >&AS_MESSAGE_LOG_FD fi else echo "cannot find nm_test_var in $nlist" >&AS_MESSAGE_LOG_FD fi else echo "cannot run $lt_cv_sys_global_symbol_pipe" >&AS_MESSAGE_LOG_FD fi else echo "$progname: failed program was:" >&AS_MESSAGE_LOG_FD cat conftest.$ac_ext >&5 fi rm -rf conftest* conftst* # Do not use the global_symbol_pipe unless it works. if test yes = "$pipe_works"; then break else lt_cv_sys_global_symbol_pipe= fi done ]) if test -z "$lt_cv_sys_global_symbol_pipe"; then lt_cv_sys_global_symbol_to_cdecl= fi if test -z "$lt_cv_sys_global_symbol_pipe$lt_cv_sys_global_symbol_to_cdecl"; then AC_MSG_RESULT(failed) else AC_MSG_RESULT(ok) fi # Response file support. if test "$lt_cv_nm_interface" = "MS dumpbin"; then nm_file_list_spec='@' elif $NM --help 2>/dev/null | grep '[[@]]FILE' >/dev/null; then nm_file_list_spec='@' fi _LT_DECL([global_symbol_pipe], [lt_cv_sys_global_symbol_pipe], [1], [Take the output of nm and produce a listing of raw symbols and C names]) _LT_DECL([global_symbol_to_cdecl], [lt_cv_sys_global_symbol_to_cdecl], [1], [Transform the output of nm in a proper C declaration]) _LT_DECL([global_symbol_to_import], [lt_cv_sys_global_symbol_to_import], [1], [Transform the output of nm into a list of symbols to manually relocate]) _LT_DECL([global_symbol_to_c_name_address], [lt_cv_sys_global_symbol_to_c_name_address], [1], [Transform the output of nm in a C name address pair]) _LT_DECL([global_symbol_to_c_name_address_lib_prefix], [lt_cv_sys_global_symbol_to_c_name_address_lib_prefix], [1], [Transform the output of nm in a C name address pair when lib prefix is needed]) _LT_DECL([nm_interface], [lt_cv_nm_interface], [1], [The name lister interface]) _LT_DECL([], [nm_file_list_spec], [1], [Specify filename containing input files for $NM]) ]) # _LT_CMD_GLOBAL_SYMBOLS # _LT_COMPILER_PIC([TAGNAME]) # --------------------------- m4_defun([_LT_COMPILER_PIC], [m4_require([_LT_TAG_COMPILER])dnl _LT_TAGVAR(lt_prog_compiler_wl, $1)= _LT_TAGVAR(lt_prog_compiler_pic, $1)= _LT_TAGVAR(lt_prog_compiler_static, $1)= m4_if([$1], [CXX], [ # C++ specific cases for pic, static, wl, etc. if test yes = "$GXX"; then _LT_TAGVAR(lt_prog_compiler_wl, $1)='-Wl,' _LT_TAGVAR(lt_prog_compiler_static, $1)='-static' case $host_os in aix*) # All AIX code is PIC. if test ia64 = "$host_cpu"; then # AIX 5 now supports IA64 processor _LT_TAGVAR(lt_prog_compiler_static, $1)='-Bstatic' fi _LT_TAGVAR(lt_prog_compiler_pic, $1)='-fPIC' ;; amigaos*) case $host_cpu in powerpc) # see comment about AmigaOS4 .so support _LT_TAGVAR(lt_prog_compiler_pic, $1)='-fPIC' ;; m68k) # FIXME: we need at least 68020 code to build shared libraries, but # adding the '-m68020' flag to GCC prevents building anything better, # like '-m68040'. _LT_TAGVAR(lt_prog_compiler_pic, $1)='-m68020 -resident32 -malways-restore-a4' ;; esac ;; beos* | irix5* | irix6* | nonstopux* | osf3* | osf4* | osf5*) # PIC is the default for these OSes. ;; mingw* | cygwin* | os2* | pw32* | cegcc*) # This hack is so that the source file can tell whether it is being # built for inclusion in a dll (and should export symbols for example). # Although the cygwin gcc ignores -fPIC, still need this for old-style # (--disable-auto-import) libraries m4_if([$1], [GCJ], [], [_LT_TAGVAR(lt_prog_compiler_pic, $1)='-DDLL_EXPORT']) case $host_os in os2*) _LT_TAGVAR(lt_prog_compiler_static, $1)='$wl-static' ;; esac ;; darwin* | rhapsody*) # PIC is the default on this platform # Common symbols not allowed in MH_DYLIB files _LT_TAGVAR(lt_prog_compiler_pic, $1)='-fno-common' ;; *djgpp*) # DJGPP does not support shared libraries at all _LT_TAGVAR(lt_prog_compiler_pic, $1)= ;; haiku*) # PIC is the default for Haiku. # The "-static" flag exists, but is broken. _LT_TAGVAR(lt_prog_compiler_static, $1)= ;; interix[[3-9]]*) # Interix 3.x gcc -fpic/-fPIC options generate broken code. # Instead, we relocate shared libraries at runtime. ;; sysv4*MP*) if test -d /usr/nec; then _LT_TAGVAR(lt_prog_compiler_pic, $1)=-Kconform_pic fi ;; hpux*) # PIC is the default for 64-bit PA HP-UX, but not for 32-bit # PA HP-UX. On IA64 HP-UX, PIC is the default but the pic flag # sets the default TLS model and affects inlining. case $host_cpu in hppa*64*) ;; *) _LT_TAGVAR(lt_prog_compiler_pic, $1)='-fPIC' ;; esac ;; *qnx* | *nto*) # QNX uses GNU C++, but need to define -shared option too, otherwise # it will coredump. _LT_TAGVAR(lt_prog_compiler_pic, $1)='-fPIC -shared' ;; *) _LT_TAGVAR(lt_prog_compiler_pic, $1)='-fPIC' ;; esac else case $host_os in aix[[4-9]]*) # All AIX code is PIC. if test ia64 = "$host_cpu"; then # AIX 5 now supports IA64 processor _LT_TAGVAR(lt_prog_compiler_static, $1)='-Bstatic' else _LT_TAGVAR(lt_prog_compiler_static, $1)='-bnso -bI:/lib/syscalls.exp' fi ;; chorus*) case $cc_basename in cxch68*) # Green Hills C++ Compiler # _LT_TAGVAR(lt_prog_compiler_static, $1)="--no_auto_instantiation -u __main -u __premain -u _abort -r $COOL_DIR/lib/libOrb.a $MVME_DIR/lib/CC/libC.a $MVME_DIR/lib/classix/libcx.s.a" ;; esac ;; mingw* | cygwin* | os2* | pw32* | cegcc*) # This hack is so that the source file can tell whether it is being # built for inclusion in a dll (and should export symbols for example). m4_if([$1], [GCJ], [], [_LT_TAGVAR(lt_prog_compiler_pic, $1)='-DDLL_EXPORT']) ;; dgux*) case $cc_basename in ec++*) _LT_TAGVAR(lt_prog_compiler_pic, $1)='-KPIC' ;; ghcx*) # Green Hills C++ Compiler _LT_TAGVAR(lt_prog_compiler_pic, $1)='-pic' ;; *) ;; esac ;; freebsd* | dragonfly*) # FreeBSD uses GNU C++ ;; hpux9* | hpux10* | hpux11*) case $cc_basename in CC*) _LT_TAGVAR(lt_prog_compiler_wl, $1)='-Wl,' _LT_TAGVAR(lt_prog_compiler_static, $1)='$wl-a ${wl}archive' if test ia64 != "$host_cpu"; then _LT_TAGVAR(lt_prog_compiler_pic, $1)='+Z' fi ;; aCC*) _LT_TAGVAR(lt_prog_compiler_wl, $1)='-Wl,' _LT_TAGVAR(lt_prog_compiler_static, $1)='$wl-a ${wl}archive' case $host_cpu in hppa*64*|ia64*) # +Z the default ;; *) _LT_TAGVAR(lt_prog_compiler_pic, $1)='+Z' ;; esac ;; *) ;; esac ;; interix*) # This is c89, which is MS Visual C++ (no shared libs) # Anyone wants to do a port? ;; irix5* | irix6* | nonstopux*) case $cc_basename in CC*) _LT_TAGVAR(lt_prog_compiler_wl, $1)='-Wl,' _LT_TAGVAR(lt_prog_compiler_static, $1)='-non_shared' # CC pic flag -KPIC is the default. ;; *) ;; esac ;; linux* | k*bsd*-gnu | kopensolaris*-gnu | gnu*) case $cc_basename in KCC*) # KAI C++ Compiler _LT_TAGVAR(lt_prog_compiler_wl, $1)='--backend -Wl,' _LT_TAGVAR(lt_prog_compiler_pic, $1)='-fPIC' ;; ecpc* ) # old Intel C++ for x86_64, which still supported -KPIC. _LT_TAGVAR(lt_prog_compiler_wl, $1)='-Wl,' _LT_TAGVAR(lt_prog_compiler_pic, $1)='-KPIC' _LT_TAGVAR(lt_prog_compiler_static, $1)='-static' ;; icpc* ) # Intel C++, used to be incompatible with GCC. # ICC 10 doesn't accept -KPIC any more. _LT_TAGVAR(lt_prog_compiler_wl, $1)='-Wl,' _LT_TAGVAR(lt_prog_compiler_pic, $1)='-fPIC' _LT_TAGVAR(lt_prog_compiler_static, $1)='-static' ;; pgCC* | pgcpp*) # Portland Group C++ compiler _LT_TAGVAR(lt_prog_compiler_wl, $1)='-Wl,' _LT_TAGVAR(lt_prog_compiler_pic, $1)='-fpic' _LT_TAGVAR(lt_prog_compiler_static, $1)='-Bstatic' ;; cxx*) # Compaq C++ # Make sure the PIC flag is empty. It appears that all Alpha # Linux and Compaq Tru64 Unix objects are PIC. _LT_TAGVAR(lt_prog_compiler_pic, $1)= _LT_TAGVAR(lt_prog_compiler_static, $1)='-non_shared' ;; xlc* | xlC* | bgxl[[cC]]* | mpixl[[cC]]*) # IBM XL 8.0, 9.0 on PPC and BlueGene _LT_TAGVAR(lt_prog_compiler_wl, $1)='-Wl,' _LT_TAGVAR(lt_prog_compiler_pic, $1)='-qpic' _LT_TAGVAR(lt_prog_compiler_static, $1)='-qstaticlink' ;; *) case `$CC -V 2>&1 | sed 5q` in *Sun\ C*) # Sun C++ 5.9 _LT_TAGVAR(lt_prog_compiler_pic, $1)='-KPIC' _LT_TAGVAR(lt_prog_compiler_static, $1)='-Bstatic' _LT_TAGVAR(lt_prog_compiler_wl, $1)='-Qoption ld ' ;; esac ;; esac ;; lynxos*) ;; m88k*) ;; mvs*) case $cc_basename in cxx*) _LT_TAGVAR(lt_prog_compiler_pic, $1)='-W c,exportall' ;; *) ;; esac ;; netbsd*) ;; *qnx* | *nto*) # QNX uses GNU C++, but need to define -shared option too, otherwise # it will coredump. _LT_TAGVAR(lt_prog_compiler_pic, $1)='-fPIC -shared' ;; osf3* | osf4* | osf5*) case $cc_basename in KCC*) _LT_TAGVAR(lt_prog_compiler_wl, $1)='--backend -Wl,' ;; RCC*) # Rational C++ 2.4.1 _LT_TAGVAR(lt_prog_compiler_pic, $1)='-pic' ;; cxx*) # Digital/Compaq C++ _LT_TAGVAR(lt_prog_compiler_wl, $1)='-Wl,' # Make sure the PIC flag is empty. It appears that all Alpha # Linux and Compaq Tru64 Unix objects are PIC. _LT_TAGVAR(lt_prog_compiler_pic, $1)= _LT_TAGVAR(lt_prog_compiler_static, $1)='-non_shared' ;; *) ;; esac ;; psos*) ;; solaris*) case $cc_basename in CC* | sunCC*) # Sun C++ 4.2, 5.x and Centerline C++ _LT_TAGVAR(lt_prog_compiler_pic, $1)='-KPIC' _LT_TAGVAR(lt_prog_compiler_static, $1)='-Bstatic' _LT_TAGVAR(lt_prog_compiler_wl, $1)='-Qoption ld ' ;; gcx*) # Green Hills C++ Compiler _LT_TAGVAR(lt_prog_compiler_pic, $1)='-PIC' ;; *) ;; esac ;; sunos4*) case $cc_basename in CC*) # Sun C++ 4.x _LT_TAGVAR(lt_prog_compiler_pic, $1)='-pic' _LT_TAGVAR(lt_prog_compiler_static, $1)='-Bstatic' ;; lcc*) # Lucid _LT_TAGVAR(lt_prog_compiler_pic, $1)='-pic' ;; *) ;; esac ;; sysv5* | unixware* | sco3.2v5* | sco5v6* | OpenUNIX*) case $cc_basename in CC*) _LT_TAGVAR(lt_prog_compiler_wl, $1)='-Wl,' _LT_TAGVAR(lt_prog_compiler_pic, $1)='-KPIC' _LT_TAGVAR(lt_prog_compiler_static, $1)='-Bstatic' ;; esac ;; tandem*) case $cc_basename in NCC*) # NonStop-UX NCC 3.20 _LT_TAGVAR(lt_prog_compiler_pic, $1)='-KPIC' ;; *) ;; esac ;; vxworks*) ;; *) _LT_TAGVAR(lt_prog_compiler_can_build_shared, $1)=no ;; esac fi ], [ if test yes = "$GCC"; then _LT_TAGVAR(lt_prog_compiler_wl, $1)='-Wl,' _LT_TAGVAR(lt_prog_compiler_static, $1)='-static' case $host_os in aix*) # All AIX code is PIC. if test ia64 = "$host_cpu"; then # AIX 5 now supports IA64 processor _LT_TAGVAR(lt_prog_compiler_static, $1)='-Bstatic' fi _LT_TAGVAR(lt_prog_compiler_pic, $1)='-fPIC' ;; amigaos*) case $host_cpu in powerpc) # see comment about AmigaOS4 .so support _LT_TAGVAR(lt_prog_compiler_pic, $1)='-fPIC' ;; m68k) # FIXME: we need at least 68020 code to build shared libraries, but # adding the '-m68020' flag to GCC prevents building anything better, # like '-m68040'. _LT_TAGVAR(lt_prog_compiler_pic, $1)='-m68020 -resident32 -malways-restore-a4' ;; esac ;; beos* | irix5* | irix6* | nonstopux* | osf3* | osf4* | osf5*) # PIC is the default for these OSes. ;; mingw* | cygwin* | pw32* | os2* | cegcc*) # This hack is so that the source file can tell whether it is being # built for inclusion in a dll (and should export symbols for example). # Although the cygwin gcc ignores -fPIC, still need this for old-style # (--disable-auto-import) libraries m4_if([$1], [GCJ], [], [_LT_TAGVAR(lt_prog_compiler_pic, $1)='-DDLL_EXPORT']) case $host_os in os2*) _LT_TAGVAR(lt_prog_compiler_static, $1)='$wl-static' ;; esac ;; darwin* | rhapsody*) # PIC is the default on this platform # Common symbols not allowed in MH_DYLIB files _LT_TAGVAR(lt_prog_compiler_pic, $1)='-fno-common' ;; haiku*) # PIC is the default for Haiku. # The "-static" flag exists, but is broken. _LT_TAGVAR(lt_prog_compiler_static, $1)= ;; hpux*) # PIC is the default for 64-bit PA HP-UX, but not for 32-bit # PA HP-UX. On IA64 HP-UX, PIC is the default but the pic flag # sets the default TLS model and affects inlining. case $host_cpu in hppa*64*) # +Z the default ;; *) _LT_TAGVAR(lt_prog_compiler_pic, $1)='-fPIC' ;; esac ;; interix[[3-9]]*) # Interix 3.x gcc -fpic/-fPIC options generate broken code. # Instead, we relocate shared libraries at runtime. ;; msdosdjgpp*) # Just because we use GCC doesn't mean we suddenly get shared libraries # on systems that don't support them. _LT_TAGVAR(lt_prog_compiler_can_build_shared, $1)=no enable_shared=no ;; *nto* | *qnx*) # QNX uses GNU C++, but need to define -shared option too, otherwise # it will coredump. _LT_TAGVAR(lt_prog_compiler_pic, $1)='-fPIC -shared' ;; sysv4*MP*) if test -d /usr/nec; then _LT_TAGVAR(lt_prog_compiler_pic, $1)=-Kconform_pic fi ;; *) _LT_TAGVAR(lt_prog_compiler_pic, $1)='-fPIC' ;; esac case $cc_basename in nvcc*) # Cuda Compiler Driver 2.2 _LT_TAGVAR(lt_prog_compiler_wl, $1)='-Xlinker ' if test -n "$_LT_TAGVAR(lt_prog_compiler_pic, $1)"; then _LT_TAGVAR(lt_prog_compiler_pic, $1)="-Xcompiler $_LT_TAGVAR(lt_prog_compiler_pic, $1)" fi ;; esac else # PORTME Check for flag to pass linker flags through the system compiler. case $host_os in aix*) _LT_TAGVAR(lt_prog_compiler_wl, $1)='-Wl,' if test ia64 = "$host_cpu"; then # AIX 5 now supports IA64 processor _LT_TAGVAR(lt_prog_compiler_static, $1)='-Bstatic' else _LT_TAGVAR(lt_prog_compiler_static, $1)='-bnso -bI:/lib/syscalls.exp' fi ;; darwin* | rhapsody*) # PIC is the default on this platform # Common symbols not allowed in MH_DYLIB files _LT_TAGVAR(lt_prog_compiler_pic, $1)='-fno-common' case $cc_basename in nagfor*) # NAG Fortran compiler _LT_TAGVAR(lt_prog_compiler_wl, $1)='-Wl,-Wl,,' _LT_TAGVAR(lt_prog_compiler_pic, $1)='-PIC' _LT_TAGVAR(lt_prog_compiler_static, $1)='-Bstatic' ;; esac ;; mingw* | cygwin* | pw32* | os2* | cegcc*) # This hack is so that the source file can tell whether it is being # built for inclusion in a dll (and should export symbols for example). m4_if([$1], [GCJ], [], [_LT_TAGVAR(lt_prog_compiler_pic, $1)='-DDLL_EXPORT']) case $host_os in os2*) _LT_TAGVAR(lt_prog_compiler_static, $1)='$wl-static' ;; esac ;; hpux9* | hpux10* | hpux11*) _LT_TAGVAR(lt_prog_compiler_wl, $1)='-Wl,' # PIC is the default for IA64 HP-UX and 64-bit HP-UX, but # not for PA HP-UX. case $host_cpu in hppa*64*|ia64*) # +Z the default ;; *) _LT_TAGVAR(lt_prog_compiler_pic, $1)='+Z' ;; esac # Is there a better lt_prog_compiler_static that works with the bundled CC? _LT_TAGVAR(lt_prog_compiler_static, $1)='$wl-a ${wl}archive' ;; irix5* | irix6* | nonstopux*) _LT_TAGVAR(lt_prog_compiler_wl, $1)='-Wl,' # PIC (with -KPIC) is the default. _LT_TAGVAR(lt_prog_compiler_static, $1)='-non_shared' ;; linux* | k*bsd*-gnu | kopensolaris*-gnu | gnu*) case $cc_basename in # old Intel for x86_64, which still supported -KPIC. ecc*) _LT_TAGVAR(lt_prog_compiler_wl, $1)='-Wl,' _LT_TAGVAR(lt_prog_compiler_pic, $1)='-KPIC' _LT_TAGVAR(lt_prog_compiler_static, $1)='-static' ;; # icc used to be incompatible with GCC. # ICC 10 doesn't accept -KPIC any more. icc* | ifort*) _LT_TAGVAR(lt_prog_compiler_wl, $1)='-Wl,' _LT_TAGVAR(lt_prog_compiler_pic, $1)='-fPIC' _LT_TAGVAR(lt_prog_compiler_static, $1)='-static' ;; # Lahey Fortran 8.1. lf95*) _LT_TAGVAR(lt_prog_compiler_wl, $1)='-Wl,' _LT_TAGVAR(lt_prog_compiler_pic, $1)='--shared' _LT_TAGVAR(lt_prog_compiler_static, $1)='--static' ;; nagfor*) # NAG Fortran compiler _LT_TAGVAR(lt_prog_compiler_wl, $1)='-Wl,-Wl,,' _LT_TAGVAR(lt_prog_compiler_pic, $1)='-PIC' _LT_TAGVAR(lt_prog_compiler_static, $1)='-Bstatic' ;; tcc*) # Fabrice Bellard et al's Tiny C Compiler _LT_TAGVAR(lt_prog_compiler_wl, $1)='-Wl,' _LT_TAGVAR(lt_prog_compiler_pic, $1)='-fPIC' _LT_TAGVAR(lt_prog_compiler_static, $1)='-static' ;; pgcc* | pgf77* | pgf90* | pgf95* | pgfortran*) # Portland Group compilers (*not* the Pentium gcc compiler, # which looks to be a dead project) _LT_TAGVAR(lt_prog_compiler_wl, $1)='-Wl,' _LT_TAGVAR(lt_prog_compiler_pic, $1)='-fpic' _LT_TAGVAR(lt_prog_compiler_static, $1)='-Bstatic' ;; ccc*) _LT_TAGVAR(lt_prog_compiler_wl, $1)='-Wl,' # All Alpha code is PIC. _LT_TAGVAR(lt_prog_compiler_static, $1)='-non_shared' ;; xl* | bgxl* | bgf* | mpixl*) # IBM XL C 8.0/Fortran 10.1, 11.1 on PPC and BlueGene _LT_TAGVAR(lt_prog_compiler_wl, $1)='-Wl,' _LT_TAGVAR(lt_prog_compiler_pic, $1)='-qpic' _LT_TAGVAR(lt_prog_compiler_static, $1)='-qstaticlink' ;; *) case `$CC -V 2>&1 | sed 5q` in *Sun\ Ceres\ Fortran* | *Sun*Fortran*\ [[1-7]].* | *Sun*Fortran*\ 8.[[0-3]]*) # Sun Fortran 8.3 passes all unrecognized flags to the linker _LT_TAGVAR(lt_prog_compiler_pic, $1)='-KPIC' _LT_TAGVAR(lt_prog_compiler_static, $1)='-Bstatic' _LT_TAGVAR(lt_prog_compiler_wl, $1)='' ;; *Sun\ F* | *Sun*Fortran*) _LT_TAGVAR(lt_prog_compiler_pic, $1)='-KPIC' _LT_TAGVAR(lt_prog_compiler_static, $1)='-Bstatic' _LT_TAGVAR(lt_prog_compiler_wl, $1)='-Qoption ld ' ;; *Sun\ C*) # Sun C 5.9 _LT_TAGVAR(lt_prog_compiler_pic, $1)='-KPIC' _LT_TAGVAR(lt_prog_compiler_static, $1)='-Bstatic' _LT_TAGVAR(lt_prog_compiler_wl, $1)='-Wl,' ;; *Intel*\ [[CF]]*Compiler*) _LT_TAGVAR(lt_prog_compiler_wl, $1)='-Wl,' _LT_TAGVAR(lt_prog_compiler_pic, $1)='-fPIC' _LT_TAGVAR(lt_prog_compiler_static, $1)='-static' ;; *Portland\ Group*) _LT_TAGVAR(lt_prog_compiler_wl, $1)='-Wl,' _LT_TAGVAR(lt_prog_compiler_pic, $1)='-fpic' _LT_TAGVAR(lt_prog_compiler_static, $1)='-Bstatic' ;; esac ;; esac ;; newsos6) _LT_TAGVAR(lt_prog_compiler_pic, $1)='-KPIC' _LT_TAGVAR(lt_prog_compiler_static, $1)='-Bstatic' ;; *nto* | *qnx*) # QNX uses GNU C++, but need to define -shared option too, otherwise # it will coredump. _LT_TAGVAR(lt_prog_compiler_pic, $1)='-fPIC -shared' ;; osf3* | osf4* | osf5*) _LT_TAGVAR(lt_prog_compiler_wl, $1)='-Wl,' # All OSF/1 code is PIC. _LT_TAGVAR(lt_prog_compiler_static, $1)='-non_shared' ;; rdos*) _LT_TAGVAR(lt_prog_compiler_static, $1)='-non_shared' ;; solaris*) _LT_TAGVAR(lt_prog_compiler_pic, $1)='-KPIC' _LT_TAGVAR(lt_prog_compiler_static, $1)='-Bstatic' case $cc_basename in f77* | f90* | f95* | sunf77* | sunf90* | sunf95*) _LT_TAGVAR(lt_prog_compiler_wl, $1)='-Qoption ld ';; *) _LT_TAGVAR(lt_prog_compiler_wl, $1)='-Wl,';; esac ;; sunos4*) _LT_TAGVAR(lt_prog_compiler_wl, $1)='-Qoption ld ' _LT_TAGVAR(lt_prog_compiler_pic, $1)='-PIC' _LT_TAGVAR(lt_prog_compiler_static, $1)='-Bstatic' ;; sysv4 | sysv4.2uw2* | sysv4.3*) _LT_TAGVAR(lt_prog_compiler_wl, $1)='-Wl,' _LT_TAGVAR(lt_prog_compiler_pic, $1)='-KPIC' _LT_TAGVAR(lt_prog_compiler_static, $1)='-Bstatic' ;; sysv4*MP*) if test -d /usr/nec; then _LT_TAGVAR(lt_prog_compiler_pic, $1)='-Kconform_pic' _LT_TAGVAR(lt_prog_compiler_static, $1)='-Bstatic' fi ;; sysv5* | unixware* | sco3.2v5* | sco5v6* | OpenUNIX*) _LT_TAGVAR(lt_prog_compiler_wl, $1)='-Wl,' _LT_TAGVAR(lt_prog_compiler_pic, $1)='-KPIC' _LT_TAGVAR(lt_prog_compiler_static, $1)='-Bstatic' ;; unicos*) _LT_TAGVAR(lt_prog_compiler_wl, $1)='-Wl,' _LT_TAGVAR(lt_prog_compiler_can_build_shared, $1)=no ;; uts4*) _LT_TAGVAR(lt_prog_compiler_pic, $1)='-pic' _LT_TAGVAR(lt_prog_compiler_static, $1)='-Bstatic' ;; *) _LT_TAGVAR(lt_prog_compiler_can_build_shared, $1)=no ;; esac fi ]) case $host_os in # For platforms that do not support PIC, -DPIC is meaningless: *djgpp*) _LT_TAGVAR(lt_prog_compiler_pic, $1)= ;; *) _LT_TAGVAR(lt_prog_compiler_pic, $1)="$_LT_TAGVAR(lt_prog_compiler_pic, $1)@&t@m4_if([$1],[],[ -DPIC],[m4_if([$1],[CXX],[ -DPIC],[])])" ;; esac AC_CACHE_CHECK([for $compiler option to produce PIC], [_LT_TAGVAR(lt_cv_prog_compiler_pic, $1)], [_LT_TAGVAR(lt_cv_prog_compiler_pic, $1)=$_LT_TAGVAR(lt_prog_compiler_pic, $1)]) _LT_TAGVAR(lt_prog_compiler_pic, $1)=$_LT_TAGVAR(lt_cv_prog_compiler_pic, $1) # # Check to make sure the PIC flag actually works. # if test -n "$_LT_TAGVAR(lt_prog_compiler_pic, $1)"; then _LT_COMPILER_OPTION([if $compiler PIC flag $_LT_TAGVAR(lt_prog_compiler_pic, $1) works], [_LT_TAGVAR(lt_cv_prog_compiler_pic_works, $1)], [$_LT_TAGVAR(lt_prog_compiler_pic, $1)@&t@m4_if([$1],[],[ -DPIC],[m4_if([$1],[CXX],[ -DPIC],[])])], [], [case $_LT_TAGVAR(lt_prog_compiler_pic, $1) in "" | " "*) ;; *) _LT_TAGVAR(lt_prog_compiler_pic, $1)=" $_LT_TAGVAR(lt_prog_compiler_pic, $1)" ;; esac], [_LT_TAGVAR(lt_prog_compiler_pic, $1)= _LT_TAGVAR(lt_prog_compiler_can_build_shared, $1)=no]) fi _LT_TAGDECL([pic_flag], [lt_prog_compiler_pic], [1], [Additional compiler flags for building library objects]) _LT_TAGDECL([wl], [lt_prog_compiler_wl], [1], [How to pass a linker flag through the compiler]) # # Check to make sure the static flag actually works. # wl=$_LT_TAGVAR(lt_prog_compiler_wl, $1) eval lt_tmp_static_flag=\"$_LT_TAGVAR(lt_prog_compiler_static, $1)\" _LT_LINKER_OPTION([if $compiler static flag $lt_tmp_static_flag works], _LT_TAGVAR(lt_cv_prog_compiler_static_works, $1), $lt_tmp_static_flag, [], [_LT_TAGVAR(lt_prog_compiler_static, $1)=]) _LT_TAGDECL([link_static_flag], [lt_prog_compiler_static], [1], [Compiler flag to prevent dynamic linking]) ])# _LT_COMPILER_PIC # _LT_LINKER_SHLIBS([TAGNAME]) # ---------------------------- # See if the linker supports building shared libraries. m4_defun([_LT_LINKER_SHLIBS], [AC_REQUIRE([LT_PATH_LD])dnl AC_REQUIRE([LT_PATH_NM])dnl m4_require([_LT_PATH_MANIFEST_TOOL])dnl m4_require([_LT_FILEUTILS_DEFAULTS])dnl m4_require([_LT_DECL_EGREP])dnl m4_require([_LT_DECL_SED])dnl m4_require([_LT_CMD_GLOBAL_SYMBOLS])dnl m4_require([_LT_TAG_COMPILER])dnl AC_MSG_CHECKING([whether the $compiler linker ($LD) supports shared libraries]) m4_if([$1], [CXX], [ _LT_TAGVAR(export_symbols_cmds, $1)='$NM $libobjs $convenience | $global_symbol_pipe | $SED '\''s/.* //'\'' | sort | uniq > $export_symbols' _LT_TAGVAR(exclude_expsyms, $1)=['_GLOBAL_OFFSET_TABLE_|_GLOBAL__F[ID]_.*'] case $host_os in aix[[4-9]]*) # If we're using GNU nm, then we don't want the "-C" option. # -C means demangle to GNU nm, but means don't demangle to AIX nm. # Without the "-l" option, or with the "-B" option, AIX nm treats # weak defined symbols like other global defined symbols, whereas # GNU nm marks them as "W". # While the 'weak' keyword is ignored in the Export File, we need # it in the Import File for the 'aix-soname' feature, so we have # to replace the "-B" option with "-P" for AIX nm. if $NM -V 2>&1 | $GREP 'GNU' > /dev/null; then _LT_TAGVAR(export_symbols_cmds, $1)='$NM -Bpg $libobjs $convenience | awk '\''{ if (((\$ 2 == "T") || (\$ 2 == "D") || (\$ 2 == "B") || (\$ 2 == "W")) && ([substr](\$ 3,1,1) != ".")) { if (\$ 2 == "W") { print \$ 3 " weak" } else { print \$ 3 } } }'\'' | sort -u > $export_symbols' else _LT_TAGVAR(export_symbols_cmds, $1)='`func_echo_all $NM | $SED -e '\''s/B\([[^B]]*\)$/P\1/'\''` -PCpgl $libobjs $convenience | awk '\''{ if (((\$ 2 == "T") || (\$ 2 == "D") || (\$ 2 == "B") || (\$ 2 == "W") || (\$ 2 == "V") || (\$ 2 == "Z")) && ([substr](\$ 1,1,1) != ".")) { if ((\$ 2 == "W") || (\$ 2 == "V") || (\$ 2 == "Z")) { print \$ 1 " weak" } else { print \$ 1 } } }'\'' | sort -u > $export_symbols' fi ;; pw32*) _LT_TAGVAR(export_symbols_cmds, $1)=$ltdll_cmds ;; cygwin* | mingw* | cegcc*) case $cc_basename in cl*) _LT_TAGVAR(exclude_expsyms, $1)='_NULL_IMPORT_DESCRIPTOR|_IMPORT_DESCRIPTOR_.*' ;; *) _LT_TAGVAR(export_symbols_cmds, $1)='$NM $libobjs $convenience | $global_symbol_pipe | $SED -e '\''/^[[BCDGRS]][[ ]]/s/.*[[ ]]\([[^ ]]*\)/\1 DATA/;s/^.*[[ ]]__nm__\([[^ ]]*\)[[ ]][[^ ]]*/\1 DATA/;/^I[[ ]]/d;/^[[AITW]][[ ]]/s/.* //'\'' | sort | uniq > $export_symbols' _LT_TAGVAR(exclude_expsyms, $1)=['[_]+GLOBAL_OFFSET_TABLE_|[_]+GLOBAL__[FID]_.*|[_]+head_[A-Za-z0-9_]+_dll|[A-Za-z0-9_]+_dll_iname'] ;; esac ;; *) _LT_TAGVAR(export_symbols_cmds, $1)='$NM $libobjs $convenience | $global_symbol_pipe | $SED '\''s/.* //'\'' | sort | uniq > $export_symbols' ;; esac ], [ runpath_var= _LT_TAGVAR(allow_undefined_flag, $1)= _LT_TAGVAR(always_export_symbols, $1)=no _LT_TAGVAR(archive_cmds, $1)= _LT_TAGVAR(archive_expsym_cmds, $1)= _LT_TAGVAR(compiler_needs_object, $1)=no _LT_TAGVAR(enable_shared_with_static_runtimes, $1)=no _LT_TAGVAR(export_dynamic_flag_spec, $1)= _LT_TAGVAR(export_symbols_cmds, $1)='$NM $libobjs $convenience | $global_symbol_pipe | $SED '\''s/.* //'\'' | sort | uniq > $export_symbols' _LT_TAGVAR(hardcode_automatic, $1)=no _LT_TAGVAR(hardcode_direct, $1)=no _LT_TAGVAR(hardcode_direct_absolute, $1)=no _LT_TAGVAR(hardcode_libdir_flag_spec, $1)= _LT_TAGVAR(hardcode_libdir_separator, $1)= _LT_TAGVAR(hardcode_minus_L, $1)=no _LT_TAGVAR(hardcode_shlibpath_var, $1)=unsupported _LT_TAGVAR(inherit_rpath, $1)=no _LT_TAGVAR(link_all_deplibs, $1)=unknown _LT_TAGVAR(module_cmds, $1)= _LT_TAGVAR(module_expsym_cmds, $1)= _LT_TAGVAR(old_archive_from_new_cmds, $1)= _LT_TAGVAR(old_archive_from_expsyms_cmds, $1)= _LT_TAGVAR(thread_safe_flag_spec, $1)= _LT_TAGVAR(whole_archive_flag_spec, $1)= # include_expsyms should be a list of space-separated symbols to be *always* # included in the symbol list _LT_TAGVAR(include_expsyms, $1)= # exclude_expsyms can be an extended regexp of symbols to exclude # it will be wrapped by ' (' and ')$', so one must not match beginning or # end of line. Example: 'a|bc|.*d.*' will exclude the symbols 'a' and 'bc', # as well as any symbol that contains 'd'. _LT_TAGVAR(exclude_expsyms, $1)=['_GLOBAL_OFFSET_TABLE_|_GLOBAL__F[ID]_.*'] # Although _GLOBAL_OFFSET_TABLE_ is a valid symbol C name, most a.out # platforms (ab)use it in PIC code, but their linkers get confused if # the symbol is explicitly referenced. Since portable code cannot # rely on this symbol name, it's probably fine to never include it in # preloaded symbol tables. # Exclude shared library initialization/finalization symbols. dnl Note also adjust exclude_expsyms for C++ above. extract_expsyms_cmds= case $host_os in cygwin* | mingw* | pw32* | cegcc*) # FIXME: the MSVC++ port hasn't been tested in a loooong time # When not using gcc, we currently assume that we are using # Microsoft Visual C++. if test yes != "$GCC"; then with_gnu_ld=no fi ;; interix*) # we just hope/assume this is gcc and not c89 (= MSVC++) with_gnu_ld=yes ;; openbsd* | bitrig*) with_gnu_ld=no ;; esac _LT_TAGVAR(ld_shlibs, $1)=yes # On some targets, GNU ld is compatible enough with the native linker # that we're better off using the native interface for both. lt_use_gnu_ld_interface=no if test yes = "$with_gnu_ld"; then case $host_os in aix*) # The AIX port of GNU ld has always aspired to compatibility # with the native linker. However, as the warning in the GNU ld # block says, versions before 2.19.5* couldn't really create working # shared libraries, regardless of the interface used. case `$LD -v 2>&1` in *\ \(GNU\ Binutils\)\ 2.19.5*) ;; *\ \(GNU\ Binutils\)\ 2.[[2-9]]*) ;; *\ \(GNU\ Binutils\)\ [[3-9]]*) ;; *) lt_use_gnu_ld_interface=yes ;; esac ;; *) lt_use_gnu_ld_interface=yes ;; esac fi if test yes = "$lt_use_gnu_ld_interface"; then # If archive_cmds runs LD, not CC, wlarc should be empty wlarc='$wl' # Set some defaults for GNU ld with shared library support. These # are reset later if shared libraries are not supported. Putting them # here allows them to be overridden if necessary. runpath_var=LD_RUN_PATH _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='$wl-rpath $wl$libdir' _LT_TAGVAR(export_dynamic_flag_spec, $1)='$wl--export-dynamic' # ancient GNU ld didn't support --whole-archive et. al. if $LD --help 2>&1 | $GREP 'no-whole-archive' > /dev/null; then _LT_TAGVAR(whole_archive_flag_spec, $1)=$wlarc'--whole-archive$convenience '$wlarc'--no-whole-archive' else _LT_TAGVAR(whole_archive_flag_spec, $1)= fi supports_anon_versioning=no case `$LD -v | $SED -e 's/([^)]\+)\s\+//' 2>&1` in *GNU\ gold*) supports_anon_versioning=yes ;; *\ [[01]].* | *\ 2.[[0-9]].* | *\ 2.10.*) ;; # catch versions < 2.11 *\ 2.11.93.0.2\ *) supports_anon_versioning=yes ;; # RH7.3 ... *\ 2.11.92.0.12\ *) supports_anon_versioning=yes ;; # Mandrake 8.2 ... *\ 2.11.*) ;; # other 2.11 versions *) supports_anon_versioning=yes ;; esac # See if GNU ld supports shared libraries. case $host_os in aix[[3-9]]*) # On AIX/PPC, the GNU linker is very broken if test ia64 != "$host_cpu"; then _LT_TAGVAR(ld_shlibs, $1)=no cat <<_LT_EOF 1>&2 *** Warning: the GNU linker, at least up to release 2.19, is reported *** to be unable to reliably create shared libraries on AIX. *** Therefore, libtool is disabling shared libraries support. If you *** really care for shared libraries, you may want to install binutils *** 2.20 or above, or modify your PATH so that a non-GNU linker is found. *** You will then need to restart the configuration process. _LT_EOF fi ;; amigaos*) case $host_cpu in powerpc) # see comment about AmigaOS4 .so support _LT_TAGVAR(archive_cmds, $1)='$CC -shared $libobjs $deplibs $compiler_flags $wl-soname $wl$soname -o $lib' _LT_TAGVAR(archive_expsym_cmds, $1)='' ;; m68k) _LT_TAGVAR(archive_cmds, $1)='$RM $output_objdir/a2ixlibrary.data~$ECHO "#define NAME $libname" > $output_objdir/a2ixlibrary.data~$ECHO "#define LIBRARY_ID 1" >> $output_objdir/a2ixlibrary.data~$ECHO "#define VERSION $major" >> $output_objdir/a2ixlibrary.data~$ECHO "#define REVISION $revision" >> $output_objdir/a2ixlibrary.data~$AR $AR_FLAGS $lib $libobjs~$RANLIB $lib~(cd $output_objdir && a2ixlibrary -32)' _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='-L$libdir' _LT_TAGVAR(hardcode_minus_L, $1)=yes ;; esac ;; beos*) if $LD --help 2>&1 | $GREP ': supported targets:.* elf' > /dev/null; then _LT_TAGVAR(allow_undefined_flag, $1)=unsupported # Joseph Beckenbach says some releases of gcc # support --undefined. This deserves some investigation. FIXME _LT_TAGVAR(archive_cmds, $1)='$CC -nostart $libobjs $deplibs $compiler_flags $wl-soname $wl$soname -o $lib' else _LT_TAGVAR(ld_shlibs, $1)=no fi ;; cygwin* | mingw* | pw32* | cegcc*) # _LT_TAGVAR(hardcode_libdir_flag_spec, $1) is actually meaningless, # as there is no search path for DLLs. _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='-L$libdir' _LT_TAGVAR(export_dynamic_flag_spec, $1)='$wl--export-all-symbols' _LT_TAGVAR(allow_undefined_flag, $1)=unsupported _LT_TAGVAR(always_export_symbols, $1)=no _LT_TAGVAR(enable_shared_with_static_runtimes, $1)=yes _LT_TAGVAR(export_symbols_cmds, $1)='$NM $libobjs $convenience | $global_symbol_pipe | $SED -e '\''/^[[BCDGRS]][[ ]]/s/.*[[ ]]\([[^ ]]*\)/\1 DATA/;s/^.*[[ ]]__nm__\([[^ ]]*\)[[ ]][[^ ]]*/\1 DATA/;/^I[[ ]]/d;/^[[AITW]][[ ]]/s/.* //'\'' | sort | uniq > $export_symbols' _LT_TAGVAR(exclude_expsyms, $1)=['[_]+GLOBAL_OFFSET_TABLE_|[_]+GLOBAL__[FID]_.*|[_]+head_[A-Za-z0-9_]+_dll|[A-Za-z0-9_]+_dll_iname'] if $LD --help 2>&1 | $GREP 'auto-import' > /dev/null; then _LT_TAGVAR(archive_cmds, $1)='$CC -shared $libobjs $deplibs $compiler_flags -o $output_objdir/$soname $wl--enable-auto-image-base -Xlinker --out-implib -Xlinker $lib' # If the export-symbols file already is a .def file, use it as # is; otherwise, prepend EXPORTS... _LT_TAGVAR(archive_expsym_cmds, $1)='if _LT_DLL_DEF_P([$export_symbols]); then cp $export_symbols $output_objdir/$soname.def; else echo EXPORTS > $output_objdir/$soname.def; cat $export_symbols >> $output_objdir/$soname.def; fi~ $CC -shared $output_objdir/$soname.def $libobjs $deplibs $compiler_flags -o $output_objdir/$soname $wl--enable-auto-image-base -Xlinker --out-implib -Xlinker $lib' else _LT_TAGVAR(ld_shlibs, $1)=no fi ;; haiku*) _LT_TAGVAR(archive_cmds, $1)='$CC -shared $libobjs $deplibs $compiler_flags $wl-soname $wl$soname -o $lib' _LT_TAGVAR(link_all_deplibs, $1)=yes ;; os2*) _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='-L$libdir' _LT_TAGVAR(hardcode_minus_L, $1)=yes _LT_TAGVAR(allow_undefined_flag, $1)=unsupported shrext_cmds=.dll _LT_TAGVAR(archive_cmds, $1)='$ECHO "LIBRARY ${soname%$shared_ext} INITINSTANCE TERMINSTANCE" > $output_objdir/$libname.def~ $ECHO "DESCRIPTION \"$libname\"" >> $output_objdir/$libname.def~ $ECHO "DATA MULTIPLE NONSHARED" >> $output_objdir/$libname.def~ $ECHO EXPORTS >> $output_objdir/$libname.def~ emxexp $libobjs | $SED /"_DLL_InitTerm"/d >> $output_objdir/$libname.def~ $CC -Zdll -Zcrtdll -o $output_objdir/$soname $libobjs $deplibs $compiler_flags $output_objdir/$libname.def~ emximp -o $lib $output_objdir/$libname.def' _LT_TAGVAR(archive_expsym_cmds, $1)='$ECHO "LIBRARY ${soname%$shared_ext} INITINSTANCE TERMINSTANCE" > $output_objdir/$libname.def~ $ECHO "DESCRIPTION \"$libname\"" >> $output_objdir/$libname.def~ $ECHO "DATA MULTIPLE NONSHARED" >> $output_objdir/$libname.def~ $ECHO EXPORTS >> $output_objdir/$libname.def~ prefix_cmds="$SED"~ if test EXPORTS = "`$SED 1q $export_symbols`"; then prefix_cmds="$prefix_cmds -e 1d"; fi~ prefix_cmds="$prefix_cmds -e \"s/^\(.*\)$/_\1/g\""~ cat $export_symbols | $prefix_cmds >> $output_objdir/$libname.def~ $CC -Zdll -Zcrtdll -o $output_objdir/$soname $libobjs $deplibs $compiler_flags $output_objdir/$libname.def~ emximp -o $lib $output_objdir/$libname.def' _LT_TAGVAR(old_archive_From_new_cmds, $1)='emximp -o $output_objdir/${libname}_dll.a $output_objdir/$libname.def' _LT_TAGVAR(enable_shared_with_static_runtimes, $1)=yes ;; interix[[3-9]]*) _LT_TAGVAR(hardcode_direct, $1)=no _LT_TAGVAR(hardcode_shlibpath_var, $1)=no _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='$wl-rpath,$libdir' _LT_TAGVAR(export_dynamic_flag_spec, $1)='$wl-E' # Hack: On Interix 3.x, we cannot compile PIC because of a broken gcc. # Instead, shared libraries are loaded at an image base (0x10000000 by # default) and relocated if they conflict, which is a slow very memory # consuming and fragmenting process. To avoid this, we pick a random, # 256 KiB-aligned image base between 0x50000000 and 0x6FFC0000 at link # time. Moving up from 0x10000000 also allows more sbrk(2) space. _LT_TAGVAR(archive_cmds, $1)='$CC -shared $pic_flag $libobjs $deplibs $compiler_flags $wl-h,$soname $wl--image-base,`expr ${RANDOM-$$} % 4096 / 2 \* 262144 + 1342177280` -o $lib' _LT_TAGVAR(archive_expsym_cmds, $1)='sed "s|^|_|" $export_symbols >$output_objdir/$soname.expsym~$CC -shared $pic_flag $libobjs $deplibs $compiler_flags $wl-h,$soname $wl--retain-symbols-file,$output_objdir/$soname.expsym $wl--image-base,`expr ${RANDOM-$$} % 4096 / 2 \* 262144 + 1342177280` -o $lib' ;; gnu* | linux* | tpf* | k*bsd*-gnu | kopensolaris*-gnu) tmp_diet=no if test linux-dietlibc = "$host_os"; then case $cc_basename in diet\ *) tmp_diet=yes;; # linux-dietlibc with static linking (!diet-dyn) esac fi if $LD --help 2>&1 | $EGREP ': supported targets:.* elf' > /dev/null \ && test no = "$tmp_diet" then tmp_addflag=' $pic_flag' tmp_sharedflag='-shared' case $cc_basename,$host_cpu in pgcc*) # Portland Group C compiler _LT_TAGVAR(whole_archive_flag_spec, $1)='$wl--whole-archive`for conv in $convenience\"\"; do test -n \"$conv\" && new_convenience=\"$new_convenience,$conv\"; done; func_echo_all \"$new_convenience\"` $wl--no-whole-archive' tmp_addflag=' $pic_flag' ;; pgf77* | pgf90* | pgf95* | pgfortran*) # Portland Group f77 and f90 compilers _LT_TAGVAR(whole_archive_flag_spec, $1)='$wl--whole-archive`for conv in $convenience\"\"; do test -n \"$conv\" && new_convenience=\"$new_convenience,$conv\"; done; func_echo_all \"$new_convenience\"` $wl--no-whole-archive' tmp_addflag=' $pic_flag -Mnomain' ;; ecc*,ia64* | icc*,ia64*) # Intel C compiler on ia64 tmp_addflag=' -i_dynamic' ;; efc*,ia64* | ifort*,ia64*) # Intel Fortran compiler on ia64 tmp_addflag=' -i_dynamic -nofor_main' ;; ifc* | ifort*) # Intel Fortran compiler tmp_addflag=' -nofor_main' ;; lf95*) # Lahey Fortran 8.1 _LT_TAGVAR(whole_archive_flag_spec, $1)= tmp_sharedflag='--shared' ;; nagfor*) # NAGFOR 5.3 tmp_sharedflag='-Wl,-shared' ;; xl[[cC]]* | bgxl[[cC]]* | mpixl[[cC]]*) # IBM XL C 8.0 on PPC (deal with xlf below) tmp_sharedflag='-qmkshrobj' tmp_addflag= ;; nvcc*) # Cuda Compiler Driver 2.2 _LT_TAGVAR(whole_archive_flag_spec, $1)='$wl--whole-archive`for conv in $convenience\"\"; do test -n \"$conv\" && new_convenience=\"$new_convenience,$conv\"; done; func_echo_all \"$new_convenience\"` $wl--no-whole-archive' _LT_TAGVAR(compiler_needs_object, $1)=yes ;; esac case `$CC -V 2>&1 | sed 5q` in *Sun\ C*) # Sun C 5.9 _LT_TAGVAR(whole_archive_flag_spec, $1)='$wl--whole-archive`new_convenience=; for conv in $convenience\"\"; do test -z \"$conv\" || new_convenience=\"$new_convenience,$conv\"; done; func_echo_all \"$new_convenience\"` $wl--no-whole-archive' _LT_TAGVAR(compiler_needs_object, $1)=yes tmp_sharedflag='-G' ;; *Sun\ F*) # Sun Fortran 8.3 tmp_sharedflag='-G' ;; esac _LT_TAGVAR(archive_cmds, $1)='$CC '"$tmp_sharedflag""$tmp_addflag"' $libobjs $deplibs $compiler_flags $wl-soname $wl$soname -o $lib' if test yes = "$supports_anon_versioning"; then _LT_TAGVAR(archive_expsym_cmds, $1)='echo "{ global:" > $output_objdir/$libname.ver~ cat $export_symbols | sed -e "s/\(.*\)/\1;/" >> $output_objdir/$libname.ver~ echo "local: *; };" >> $output_objdir/$libname.ver~ $CC '"$tmp_sharedflag""$tmp_addflag"' $libobjs $deplibs $compiler_flags $wl-soname $wl$soname $wl-version-script $wl$output_objdir/$libname.ver -o $lib' fi case $cc_basename in tcc*) _LT_TAGVAR(export_dynamic_flag_spec, $1)='-rdynamic' ;; xlf* | bgf* | bgxlf* | mpixlf*) # IBM XL Fortran 10.1 on PPC cannot create shared libs itself _LT_TAGVAR(whole_archive_flag_spec, $1)='--whole-archive$convenience --no-whole-archive' _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='$wl-rpath $wl$libdir' _LT_TAGVAR(archive_cmds, $1)='$LD -shared $libobjs $deplibs $linker_flags -soname $soname -o $lib' if test yes = "$supports_anon_versioning"; then _LT_TAGVAR(archive_expsym_cmds, $1)='echo "{ global:" > $output_objdir/$libname.ver~ cat $export_symbols | sed -e "s/\(.*\)/\1;/" >> $output_objdir/$libname.ver~ echo "local: *; };" >> $output_objdir/$libname.ver~ $LD -shared $libobjs $deplibs $linker_flags -soname $soname -version-script $output_objdir/$libname.ver -o $lib' fi ;; esac else _LT_TAGVAR(ld_shlibs, $1)=no fi ;; netbsd*) if echo __ELF__ | $CC -E - | $GREP __ELF__ >/dev/null; then _LT_TAGVAR(archive_cmds, $1)='$LD -Bshareable $libobjs $deplibs $linker_flags -o $lib' wlarc= else _LT_TAGVAR(archive_cmds, $1)='$CC -shared $pic_flag $libobjs $deplibs $compiler_flags $wl-soname $wl$soname -o $lib' _LT_TAGVAR(archive_expsym_cmds, $1)='$CC -shared $pic_flag $libobjs $deplibs $compiler_flags $wl-soname $wl$soname $wl-retain-symbols-file $wl$export_symbols -o $lib' fi ;; solaris*) if $LD -v 2>&1 | $GREP 'BFD 2\.8' > /dev/null; then _LT_TAGVAR(ld_shlibs, $1)=no cat <<_LT_EOF 1>&2 *** Warning: The releases 2.8.* of the GNU linker cannot reliably *** create shared libraries on Solaris systems. Therefore, libtool *** is disabling shared libraries support. We urge you to upgrade GNU *** binutils to release 2.9.1 or newer. Another option is to modify *** your PATH or compiler configuration so that the native linker is *** used, and then restart. _LT_EOF elif $LD --help 2>&1 | $GREP ': supported targets:.* elf' > /dev/null; then _LT_TAGVAR(archive_cmds, $1)='$CC -shared $pic_flag $libobjs $deplibs $compiler_flags $wl-soname $wl$soname -o $lib' _LT_TAGVAR(archive_expsym_cmds, $1)='$CC -shared $pic_flag $libobjs $deplibs $compiler_flags $wl-soname $wl$soname $wl-retain-symbols-file $wl$export_symbols -o $lib' else _LT_TAGVAR(ld_shlibs, $1)=no fi ;; sysv5* | sco3.2v5* | sco5v6* | unixware* | OpenUNIX*) case `$LD -v 2>&1` in *\ [[01]].* | *\ 2.[[0-9]].* | *\ 2.1[[0-5]].*) _LT_TAGVAR(ld_shlibs, $1)=no cat <<_LT_EOF 1>&2 *** Warning: Releases of the GNU linker prior to 2.16.91.0.3 cannot *** reliably create shared libraries on SCO systems. Therefore, libtool *** is disabling shared libraries support. We urge you to upgrade GNU *** binutils to release 2.16.91.0.3 or newer. Another option is to modify *** your PATH or compiler configuration so that the native linker is *** used, and then restart. _LT_EOF ;; *) # For security reasons, it is highly recommended that you always # use absolute paths for naming shared libraries, and exclude the # DT_RUNPATH tag from executables and libraries. But doing so # requires that you compile everything twice, which is a pain. if $LD --help 2>&1 | $GREP ': supported targets:.* elf' > /dev/null; then _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='$wl-rpath $wl$libdir' _LT_TAGVAR(archive_cmds, $1)='$CC -shared $libobjs $deplibs $compiler_flags $wl-soname $wl$soname -o $lib' _LT_TAGVAR(archive_expsym_cmds, $1)='$CC -shared $libobjs $deplibs $compiler_flags $wl-soname $wl$soname $wl-retain-symbols-file $wl$export_symbols -o $lib' else _LT_TAGVAR(ld_shlibs, $1)=no fi ;; esac ;; sunos4*) _LT_TAGVAR(archive_cmds, $1)='$LD -assert pure-text -Bshareable -o $lib $libobjs $deplibs $linker_flags' wlarc= _LT_TAGVAR(hardcode_direct, $1)=yes _LT_TAGVAR(hardcode_shlibpath_var, $1)=no ;; *) if $LD --help 2>&1 | $GREP ': supported targets:.* elf' > /dev/null; then _LT_TAGVAR(archive_cmds, $1)='$CC -shared $pic_flag $libobjs $deplibs $compiler_flags $wl-soname $wl$soname -o $lib' _LT_TAGVAR(archive_expsym_cmds, $1)='$CC -shared $pic_flag $libobjs $deplibs $compiler_flags $wl-soname $wl$soname $wl-retain-symbols-file $wl$export_symbols -o $lib' else _LT_TAGVAR(ld_shlibs, $1)=no fi ;; esac if test no = "$_LT_TAGVAR(ld_shlibs, $1)"; then runpath_var= _LT_TAGVAR(hardcode_libdir_flag_spec, $1)= _LT_TAGVAR(export_dynamic_flag_spec, $1)= _LT_TAGVAR(whole_archive_flag_spec, $1)= fi else # PORTME fill in a description of your system's linker (not GNU ld) case $host_os in aix3*) _LT_TAGVAR(allow_undefined_flag, $1)=unsupported _LT_TAGVAR(always_export_symbols, $1)=yes _LT_TAGVAR(archive_expsym_cmds, $1)='$LD -o $output_objdir/$soname $libobjs $deplibs $linker_flags -bE:$export_symbols -T512 -H512 -bM:SRE~$AR $AR_FLAGS $lib $output_objdir/$soname' # Note: this linker hardcodes the directories in LIBPATH if there # are no directories specified by -L. _LT_TAGVAR(hardcode_minus_L, $1)=yes if test yes = "$GCC" && test -z "$lt_prog_compiler_static"; then # Neither direct hardcoding nor static linking is supported with a # broken collect2. _LT_TAGVAR(hardcode_direct, $1)=unsupported fi ;; aix[[4-9]]*) if test ia64 = "$host_cpu"; then # On IA64, the linker does run time linking by default, so we don't # have to do anything special. aix_use_runtimelinking=no exp_sym_flag='-Bexport' no_entry_flag= else # If we're using GNU nm, then we don't want the "-C" option. # -C means demangle to GNU nm, but means don't demangle to AIX nm. # Without the "-l" option, or with the "-B" option, AIX nm treats # weak defined symbols like other global defined symbols, whereas # GNU nm marks them as "W". # While the 'weak' keyword is ignored in the Export File, we need # it in the Import File for the 'aix-soname' feature, so we have # to replace the "-B" option with "-P" for AIX nm. if $NM -V 2>&1 | $GREP 'GNU' > /dev/null; then _LT_TAGVAR(export_symbols_cmds, $1)='$NM -Bpg $libobjs $convenience | awk '\''{ if (((\$ 2 == "T") || (\$ 2 == "D") || (\$ 2 == "B") || (\$ 2 == "W")) && ([substr](\$ 3,1,1) != ".")) { if (\$ 2 == "W") { print \$ 3 " weak" } else { print \$ 3 } } }'\'' | sort -u > $export_symbols' else _LT_TAGVAR(export_symbols_cmds, $1)='`func_echo_all $NM | $SED -e '\''s/B\([[^B]]*\)$/P\1/'\''` -PCpgl $libobjs $convenience | awk '\''{ if (((\$ 2 == "T") || (\$ 2 == "D") || (\$ 2 == "B") || (\$ 2 == "W") || (\$ 2 == "V") || (\$ 2 == "Z")) && ([substr](\$ 1,1,1) != ".")) { if ((\$ 2 == "W") || (\$ 2 == "V") || (\$ 2 == "Z")) { print \$ 1 " weak" } else { print \$ 1 } } }'\'' | sort -u > $export_symbols' fi aix_use_runtimelinking=no # Test if we are trying to use run time linking or normal # AIX style linking. If -brtl is somewhere in LDFLAGS, we # have runtime linking enabled, and use it for executables. # For shared libraries, we enable/disable runtime linking # depending on the kind of the shared library created - # when "with_aix_soname,aix_use_runtimelinking" is: # "aix,no" lib.a(lib.so.V) shared, rtl:no, for executables # "aix,yes" lib.so shared, rtl:yes, for executables # lib.a static archive # "both,no" lib.so.V(shr.o) shared, rtl:yes # lib.a(lib.so.V) shared, rtl:no, for executables # "both,yes" lib.so.V(shr.o) shared, rtl:yes, for executables # lib.a(lib.so.V) shared, rtl:no # "svr4,*" lib.so.V(shr.o) shared, rtl:yes, for executables # lib.a static archive case $host_os in aix4.[[23]]|aix4.[[23]].*|aix[[5-9]]*) for ld_flag in $LDFLAGS; do if (test x-brtl = "x$ld_flag" || test x-Wl,-brtl = "x$ld_flag"); then aix_use_runtimelinking=yes break fi done if test svr4,no = "$with_aix_soname,$aix_use_runtimelinking"; then # With aix-soname=svr4, we create the lib.so.V shared archives only, # so we don't have lib.a shared libs to link our executables. # We have to force runtime linking in this case. aix_use_runtimelinking=yes LDFLAGS="$LDFLAGS -Wl,-brtl" fi ;; esac exp_sym_flag='-bexport' no_entry_flag='-bnoentry' fi # When large executables or shared objects are built, AIX ld can # have problems creating the table of contents. If linking a library # or program results in "error TOC overflow" add -mminimal-toc to # CXXFLAGS/CFLAGS for g++/gcc. In the cases where that is not # enough to fix the problem, add -Wl,-bbigtoc to LDFLAGS. _LT_TAGVAR(archive_cmds, $1)='' _LT_TAGVAR(hardcode_direct, $1)=yes _LT_TAGVAR(hardcode_direct_absolute, $1)=yes _LT_TAGVAR(hardcode_libdir_separator, $1)=':' _LT_TAGVAR(link_all_deplibs, $1)=yes _LT_TAGVAR(file_list_spec, $1)='$wl-f,' case $with_aix_soname,$aix_use_runtimelinking in aix,*) ;; # traditional, no import file svr4,* | *,yes) # use import file # The Import File defines what to hardcode. _LT_TAGVAR(hardcode_direct, $1)=no _LT_TAGVAR(hardcode_direct_absolute, $1)=no ;; esac if test yes = "$GCC"; then case $host_os in aix4.[[012]]|aix4.[[012]].*) # We only want to do this on AIX 4.2 and lower, the check # below for broken collect2 doesn't work under 4.3+ collect2name=`$CC -print-prog-name=collect2` if test -f "$collect2name" && strings "$collect2name" | $GREP resolve_lib_name >/dev/null then # We have reworked collect2 : else # We have old collect2 _LT_TAGVAR(hardcode_direct, $1)=unsupported # It fails to find uninstalled libraries when the uninstalled # path is not listed in the libpath. Setting hardcode_minus_L # to unsupported forces relinking _LT_TAGVAR(hardcode_minus_L, $1)=yes _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='-L$libdir' _LT_TAGVAR(hardcode_libdir_separator, $1)= fi ;; esac shared_flag='-shared' if test yes = "$aix_use_runtimelinking"; then shared_flag="$shared_flag "'$wl-G' fi # Need to ensure runtime linking is disabled for the traditional # shared library, or the linker may eventually find shared libraries # /with/ Import File - we do not want to mix them. shared_flag_aix='-shared' shared_flag_svr4='-shared $wl-G' else # not using gcc if test ia64 = "$host_cpu"; then # VisualAge C++, Version 5.5 for AIX 5L for IA-64, Beta 3 Release # chokes on -Wl,-G. The following line is correct: shared_flag='-G' else if test yes = "$aix_use_runtimelinking"; then shared_flag='$wl-G' else shared_flag='$wl-bM:SRE' fi shared_flag_aix='$wl-bM:SRE' shared_flag_svr4='$wl-G' fi fi _LT_TAGVAR(export_dynamic_flag_spec, $1)='$wl-bexpall' # It seems that -bexpall does not export symbols beginning with # underscore (_), so it is better to generate a list of symbols to export. _LT_TAGVAR(always_export_symbols, $1)=yes if test aix,yes = "$with_aix_soname,$aix_use_runtimelinking"; then # Warning - without using the other runtime loading flags (-brtl), # -berok will link without error, but may produce a broken library. _LT_TAGVAR(allow_undefined_flag, $1)='-berok' # Determine the default libpath from the value encoded in an # empty executable. _LT_SYS_MODULE_PATH_AIX([$1]) _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='$wl-blibpath:$libdir:'"$aix_libpath" _LT_TAGVAR(archive_expsym_cmds, $1)='$CC -o $output_objdir/$soname $libobjs $deplibs $wl'$no_entry_flag' $compiler_flags `if test -n "$allow_undefined_flag"; then func_echo_all "$wl$allow_undefined_flag"; else :; fi` $wl'$exp_sym_flag:\$export_symbols' '$shared_flag else if test ia64 = "$host_cpu"; then _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='$wl-R $libdir:/usr/lib:/lib' _LT_TAGVAR(allow_undefined_flag, $1)="-z nodefs" _LT_TAGVAR(archive_expsym_cmds, $1)="\$CC $shared_flag"' -o $output_objdir/$soname $libobjs $deplibs '"\$wl$no_entry_flag"' $compiler_flags $wl$allow_undefined_flag '"\$wl$exp_sym_flag:\$export_symbols" else # Determine the default libpath from the value encoded in an # empty executable. _LT_SYS_MODULE_PATH_AIX([$1]) _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='$wl-blibpath:$libdir:'"$aix_libpath" # Warning - without using the other run time loading flags, # -berok will link without error, but may produce a broken library. _LT_TAGVAR(no_undefined_flag, $1)=' $wl-bernotok' _LT_TAGVAR(allow_undefined_flag, $1)=' $wl-berok' if test yes = "$with_gnu_ld"; then # We only use this code for GNU lds that support --whole-archive. _LT_TAGVAR(whole_archive_flag_spec, $1)='$wl--whole-archive$convenience $wl--no-whole-archive' else # Exported symbols can be pulled into shared objects from archives _LT_TAGVAR(whole_archive_flag_spec, $1)='$convenience' fi _LT_TAGVAR(archive_cmds_need_lc, $1)=yes _LT_TAGVAR(archive_expsym_cmds, $1)='$RM -r $output_objdir/$realname.d~$MKDIR $output_objdir/$realname.d' # -brtl affects multiple linker settings, -berok does not and is overridden later compiler_flags_filtered='`func_echo_all "$compiler_flags " | $SED -e "s%-brtl\\([[, ]]\\)%-berok\\1%g"`' if test svr4 != "$with_aix_soname"; then # This is similar to how AIX traditionally builds its shared libraries. _LT_TAGVAR(archive_expsym_cmds, $1)="$_LT_TAGVAR(archive_expsym_cmds, $1)"'~$CC '$shared_flag_aix' -o $output_objdir/$realname.d/$soname $libobjs $deplibs $wl-bnoentry '$compiler_flags_filtered'$wl-bE:$export_symbols$allow_undefined_flag~$AR $AR_FLAGS $output_objdir/$libname$release.a $output_objdir/$realname.d/$soname' fi if test aix != "$with_aix_soname"; then _LT_TAGVAR(archive_expsym_cmds, $1)="$_LT_TAGVAR(archive_expsym_cmds, $1)"'~$CC '$shared_flag_svr4' -o $output_objdir/$realname.d/$shared_archive_member_spec.o $libobjs $deplibs $wl-bnoentry '$compiler_flags_filtered'$wl-bE:$export_symbols$allow_undefined_flag~$STRIP -e $output_objdir/$realname.d/$shared_archive_member_spec.o~( func_echo_all "#! $soname($shared_archive_member_spec.o)"; if test shr_64 = "$shared_archive_member_spec"; then func_echo_all "# 64"; else func_echo_all "# 32"; fi; cat $export_symbols ) > $output_objdir/$realname.d/$shared_archive_member_spec.imp~$AR $AR_FLAGS $output_objdir/$soname $output_objdir/$realname.d/$shared_archive_member_spec.o $output_objdir/$realname.d/$shared_archive_member_spec.imp' else # used by -dlpreopen to get the symbols _LT_TAGVAR(archive_expsym_cmds, $1)="$_LT_TAGVAR(archive_expsym_cmds, $1)"'~$MV $output_objdir/$realname.d/$soname $output_objdir' fi _LT_TAGVAR(archive_expsym_cmds, $1)="$_LT_TAGVAR(archive_expsym_cmds, $1)"'~$RM -r $output_objdir/$realname.d' fi fi ;; amigaos*) case $host_cpu in powerpc) # see comment about AmigaOS4 .so support _LT_TAGVAR(archive_cmds, $1)='$CC -shared $libobjs $deplibs $compiler_flags $wl-soname $wl$soname -o $lib' _LT_TAGVAR(archive_expsym_cmds, $1)='' ;; m68k) _LT_TAGVAR(archive_cmds, $1)='$RM $output_objdir/a2ixlibrary.data~$ECHO "#define NAME $libname" > $output_objdir/a2ixlibrary.data~$ECHO "#define LIBRARY_ID 1" >> $output_objdir/a2ixlibrary.data~$ECHO "#define VERSION $major" >> $output_objdir/a2ixlibrary.data~$ECHO "#define REVISION $revision" >> $output_objdir/a2ixlibrary.data~$AR $AR_FLAGS $lib $libobjs~$RANLIB $lib~(cd $output_objdir && a2ixlibrary -32)' _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='-L$libdir' _LT_TAGVAR(hardcode_minus_L, $1)=yes ;; esac ;; bsdi[[45]]*) _LT_TAGVAR(export_dynamic_flag_spec, $1)=-rdynamic ;; cygwin* | mingw* | pw32* | cegcc*) # When not using gcc, we currently assume that we are using # Microsoft Visual C++. # hardcode_libdir_flag_spec is actually meaningless, as there is # no search path for DLLs. case $cc_basename in cl*) # Native MSVC _LT_TAGVAR(hardcode_libdir_flag_spec, $1)=' ' _LT_TAGVAR(allow_undefined_flag, $1)=unsupported _LT_TAGVAR(always_export_symbols, $1)=yes _LT_TAGVAR(file_list_spec, $1)='@' # Tell ltmain to make .lib files, not .a files. libext=lib # Tell ltmain to make .dll files, not .so files. shrext_cmds=.dll # FIXME: Setting linknames here is a bad hack. _LT_TAGVAR(archive_cmds, $1)='$CC -o $output_objdir/$soname $libobjs $compiler_flags $deplibs -Wl,-DLL,-IMPLIB:"$tool_output_objdir$libname.dll.lib"~linknames=' _LT_TAGVAR(archive_expsym_cmds, $1)='if _LT_DLL_DEF_P([$export_symbols]); then cp "$export_symbols" "$output_objdir/$soname.def"; echo "$tool_output_objdir$soname.def" > "$output_objdir/$soname.exp"; else $SED -e '\''s/^/-link -EXPORT:/'\'' < $export_symbols > $output_objdir/$soname.exp; fi~ $CC -o $tool_output_objdir$soname $libobjs $compiler_flags $deplibs "@$tool_output_objdir$soname.exp" -Wl,-DLL,-IMPLIB:"$tool_output_objdir$libname.dll.lib"~ linknames=' # The linker will not automatically build a static lib if we build a DLL. # _LT_TAGVAR(old_archive_from_new_cmds, $1)='true' _LT_TAGVAR(enable_shared_with_static_runtimes, $1)=yes _LT_TAGVAR(exclude_expsyms, $1)='_NULL_IMPORT_DESCRIPTOR|_IMPORT_DESCRIPTOR_.*' _LT_TAGVAR(export_symbols_cmds, $1)='$NM $libobjs $convenience | $global_symbol_pipe | $SED -e '\''/^[[BCDGRS]][[ ]]/s/.*[[ ]]\([[^ ]]*\)/\1,DATA/'\'' | $SED -e '\''/^[[AITW]][[ ]]/s/.*[[ ]]//'\'' | sort | uniq > $export_symbols' # Don't use ranlib _LT_TAGVAR(old_postinstall_cmds, $1)='chmod 644 $oldlib' _LT_TAGVAR(postlink_cmds, $1)='lt_outputfile="@OUTPUT@"~ lt_tool_outputfile="@TOOL_OUTPUT@"~ case $lt_outputfile in *.exe|*.EXE) ;; *) lt_outputfile=$lt_outputfile.exe lt_tool_outputfile=$lt_tool_outputfile.exe ;; esac~ if test : != "$MANIFEST_TOOL" && test -f "$lt_outputfile.manifest"; then $MANIFEST_TOOL -manifest "$lt_tool_outputfile.manifest" -outputresource:"$lt_tool_outputfile" || exit 1; $RM "$lt_outputfile.manifest"; fi' ;; *) # Assume MSVC wrapper _LT_TAGVAR(hardcode_libdir_flag_spec, $1)=' ' _LT_TAGVAR(allow_undefined_flag, $1)=unsupported # Tell ltmain to make .lib files, not .a files. libext=lib # Tell ltmain to make .dll files, not .so files. shrext_cmds=.dll # FIXME: Setting linknames here is a bad hack. _LT_TAGVAR(archive_cmds, $1)='$CC -o $lib $libobjs $compiler_flags `func_echo_all "$deplibs" | $SED '\''s/ -lc$//'\''` -link -dll~linknames=' # The linker will automatically build a .lib file if we build a DLL. _LT_TAGVAR(old_archive_from_new_cmds, $1)='true' # FIXME: Should let the user specify the lib program. _LT_TAGVAR(old_archive_cmds, $1)='lib -OUT:$oldlib$oldobjs$old_deplibs' _LT_TAGVAR(enable_shared_with_static_runtimes, $1)=yes ;; esac ;; darwin* | rhapsody*) _LT_DARWIN_LINKER_FEATURES($1) ;; dgux*) _LT_TAGVAR(archive_cmds, $1)='$LD -G -h $soname -o $lib $libobjs $deplibs $linker_flags' _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='-L$libdir' _LT_TAGVAR(hardcode_shlibpath_var, $1)=no ;; # FreeBSD 2.2.[012] allows us to include c++rt0.o to get C++ constructor # support. Future versions do this automatically, but an explicit c++rt0.o # does not break anything, and helps significantly (at the cost of a little # extra space). freebsd2.2*) _LT_TAGVAR(archive_cmds, $1)='$LD -Bshareable -o $lib $libobjs $deplibs $linker_flags /usr/lib/c++rt0.o' _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='-R$libdir' _LT_TAGVAR(hardcode_direct, $1)=yes _LT_TAGVAR(hardcode_shlibpath_var, $1)=no ;; # Unfortunately, older versions of FreeBSD 2 do not have this feature. freebsd2.*) _LT_TAGVAR(archive_cmds, $1)='$LD -Bshareable -o $lib $libobjs $deplibs $linker_flags' _LT_TAGVAR(hardcode_direct, $1)=yes _LT_TAGVAR(hardcode_minus_L, $1)=yes _LT_TAGVAR(hardcode_shlibpath_var, $1)=no ;; # FreeBSD 3 and greater uses gcc -shared to do shared libraries. freebsd* | dragonfly*) _LT_TAGVAR(archive_cmds, $1)='$CC -shared $pic_flag -o $lib $libobjs $deplibs $compiler_flags' _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='-R$libdir' _LT_TAGVAR(hardcode_direct, $1)=yes _LT_TAGVAR(hardcode_shlibpath_var, $1)=no ;; hpux9*) if test yes = "$GCC"; then _LT_TAGVAR(archive_cmds, $1)='$RM $output_objdir/$soname~$CC -shared $pic_flag $wl+b $wl$install_libdir -o $output_objdir/$soname $libobjs $deplibs $compiler_flags~test "x$output_objdir/$soname" = "x$lib" || mv $output_objdir/$soname $lib' else _LT_TAGVAR(archive_cmds, $1)='$RM $output_objdir/$soname~$LD -b +b $install_libdir -o $output_objdir/$soname $libobjs $deplibs $linker_flags~test "x$output_objdir/$soname" = "x$lib" || mv $output_objdir/$soname $lib' fi _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='$wl+b $wl$libdir' _LT_TAGVAR(hardcode_libdir_separator, $1)=: _LT_TAGVAR(hardcode_direct, $1)=yes # hardcode_minus_L: Not really in the search PATH, # but as the default location of the library. _LT_TAGVAR(hardcode_minus_L, $1)=yes _LT_TAGVAR(export_dynamic_flag_spec, $1)='$wl-E' ;; hpux10*) if test yes,no = "$GCC,$with_gnu_ld"; then _LT_TAGVAR(archive_cmds, $1)='$CC -shared $pic_flag $wl+h $wl$soname $wl+b $wl$install_libdir -o $lib $libobjs $deplibs $compiler_flags' else _LT_TAGVAR(archive_cmds, $1)='$LD -b +h $soname +b $install_libdir -o $lib $libobjs $deplibs $linker_flags' fi if test no = "$with_gnu_ld"; then _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='$wl+b $wl$libdir' _LT_TAGVAR(hardcode_libdir_separator, $1)=: _LT_TAGVAR(hardcode_direct, $1)=yes _LT_TAGVAR(hardcode_direct_absolute, $1)=yes _LT_TAGVAR(export_dynamic_flag_spec, $1)='$wl-E' # hardcode_minus_L: Not really in the search PATH, # but as the default location of the library. _LT_TAGVAR(hardcode_minus_L, $1)=yes fi ;; hpux11*) if test yes,no = "$GCC,$with_gnu_ld"; then case $host_cpu in hppa*64*) _LT_TAGVAR(archive_cmds, $1)='$CC -shared $wl+h $wl$soname -o $lib $libobjs $deplibs $compiler_flags' ;; ia64*) _LT_TAGVAR(archive_cmds, $1)='$CC -shared $pic_flag $wl+h $wl$soname $wl+nodefaultrpath -o $lib $libobjs $deplibs $compiler_flags' ;; *) _LT_TAGVAR(archive_cmds, $1)='$CC -shared $pic_flag $wl+h $wl$soname $wl+b $wl$install_libdir -o $lib $libobjs $deplibs $compiler_flags' ;; esac else case $host_cpu in hppa*64*) _LT_TAGVAR(archive_cmds, $1)='$CC -b $wl+h $wl$soname -o $lib $libobjs $deplibs $compiler_flags' ;; ia64*) _LT_TAGVAR(archive_cmds, $1)='$CC -b $wl+h $wl$soname $wl+nodefaultrpath -o $lib $libobjs $deplibs $compiler_flags' ;; *) m4_if($1, [], [ # Older versions of the 11.00 compiler do not understand -b yet # (HP92453-01 A.11.01.20 doesn't, HP92453-01 B.11.X.35175-35176.GP does) _LT_LINKER_OPTION([if $CC understands -b], _LT_TAGVAR(lt_cv_prog_compiler__b, $1), [-b], [_LT_TAGVAR(archive_cmds, $1)='$CC -b $wl+h $wl$soname $wl+b $wl$install_libdir -o $lib $libobjs $deplibs $compiler_flags'], [_LT_TAGVAR(archive_cmds, $1)='$LD -b +h $soname +b $install_libdir -o $lib $libobjs $deplibs $linker_flags'])], [_LT_TAGVAR(archive_cmds, $1)='$CC -b $wl+h $wl$soname $wl+b $wl$install_libdir -o $lib $libobjs $deplibs $compiler_flags']) ;; esac fi if test no = "$with_gnu_ld"; then _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='$wl+b $wl$libdir' _LT_TAGVAR(hardcode_libdir_separator, $1)=: case $host_cpu in hppa*64*|ia64*) _LT_TAGVAR(hardcode_direct, $1)=no _LT_TAGVAR(hardcode_shlibpath_var, $1)=no ;; *) _LT_TAGVAR(hardcode_direct, $1)=yes _LT_TAGVAR(hardcode_direct_absolute, $1)=yes _LT_TAGVAR(export_dynamic_flag_spec, $1)='$wl-E' # hardcode_minus_L: Not really in the search PATH, # but as the default location of the library. _LT_TAGVAR(hardcode_minus_L, $1)=yes ;; esac fi ;; irix5* | irix6* | nonstopux*) if test yes = "$GCC"; then _LT_TAGVAR(archive_cmds, $1)='$CC -shared $pic_flag $libobjs $deplibs $compiler_flags $wl-soname $wl$soname `test -n "$verstring" && func_echo_all "$wl-set_version $wl$verstring"` $wl-update_registry $wl$output_objdir/so_locations -o $lib' # Try to use the -exported_symbol ld option, if it does not # work, assume that -exports_file does not work either and # implicitly export all symbols. # This should be the same for all languages, so no per-tag cache variable. AC_CACHE_CHECK([whether the $host_os linker accepts -exported_symbol], [lt_cv_irix_exported_symbol], [save_LDFLAGS=$LDFLAGS LDFLAGS="$LDFLAGS -shared $wl-exported_symbol ${wl}foo $wl-update_registry $wl/dev/null" AC_LINK_IFELSE( [AC_LANG_SOURCE( [AC_LANG_CASE([C], [[int foo (void) { return 0; }]], [C++], [[int foo (void) { return 0; }]], [Fortran 77], [[ subroutine foo end]], [Fortran], [[ subroutine foo end]])])], [lt_cv_irix_exported_symbol=yes], [lt_cv_irix_exported_symbol=no]) LDFLAGS=$save_LDFLAGS]) if test yes = "$lt_cv_irix_exported_symbol"; then _LT_TAGVAR(archive_expsym_cmds, $1)='$CC -shared $pic_flag $libobjs $deplibs $compiler_flags $wl-soname $wl$soname `test -n "$verstring" && func_echo_all "$wl-set_version $wl$verstring"` $wl-update_registry $wl$output_objdir/so_locations $wl-exports_file $wl$export_symbols -o $lib' fi else _LT_TAGVAR(archive_cmds, $1)='$CC -shared $libobjs $deplibs $compiler_flags -soname $soname `test -n "$verstring" && func_echo_all "-set_version $verstring"` -update_registry $output_objdir/so_locations -o $lib' _LT_TAGVAR(archive_expsym_cmds, $1)='$CC -shared $libobjs $deplibs $compiler_flags -soname $soname `test -n "$verstring" && func_echo_all "-set_version $verstring"` -update_registry $output_objdir/so_locations -exports_file $export_symbols -o $lib' fi _LT_TAGVAR(archive_cmds_need_lc, $1)='no' _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='$wl-rpath $wl$libdir' _LT_TAGVAR(hardcode_libdir_separator, $1)=: _LT_TAGVAR(inherit_rpath, $1)=yes _LT_TAGVAR(link_all_deplibs, $1)=yes ;; linux*) case $cc_basename in tcc*) # Fabrice Bellard et al's Tiny C Compiler _LT_TAGVAR(ld_shlibs, $1)=yes _LT_TAGVAR(archive_cmds, $1)='$CC -shared $pic_flag -o $lib $libobjs $deplibs $compiler_flags' ;; esac ;; netbsd*) if echo __ELF__ | $CC -E - | $GREP __ELF__ >/dev/null; then _LT_TAGVAR(archive_cmds, $1)='$LD -Bshareable -o $lib $libobjs $deplibs $linker_flags' # a.out else _LT_TAGVAR(archive_cmds, $1)='$LD -shared -o $lib $libobjs $deplibs $linker_flags' # ELF fi _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='-R$libdir' _LT_TAGVAR(hardcode_direct, $1)=yes _LT_TAGVAR(hardcode_shlibpath_var, $1)=no ;; newsos6) _LT_TAGVAR(archive_cmds, $1)='$LD -G -h $soname -o $lib $libobjs $deplibs $linker_flags' _LT_TAGVAR(hardcode_direct, $1)=yes _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='$wl-rpath $wl$libdir' _LT_TAGVAR(hardcode_libdir_separator, $1)=: _LT_TAGVAR(hardcode_shlibpath_var, $1)=no ;; *nto* | *qnx*) ;; openbsd* | bitrig*) if test -f /usr/libexec/ld.so; then _LT_TAGVAR(hardcode_direct, $1)=yes _LT_TAGVAR(hardcode_shlibpath_var, $1)=no _LT_TAGVAR(hardcode_direct_absolute, $1)=yes if test -z "`echo __ELF__ | $CC -E - | $GREP __ELF__`"; then _LT_TAGVAR(archive_cmds, $1)='$CC -shared $pic_flag -o $lib $libobjs $deplibs $compiler_flags' _LT_TAGVAR(archive_expsym_cmds, $1)='$CC -shared $pic_flag -o $lib $libobjs $deplibs $compiler_flags $wl-retain-symbols-file,$export_symbols' _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='$wl-rpath,$libdir' _LT_TAGVAR(export_dynamic_flag_spec, $1)='$wl-E' else _LT_TAGVAR(archive_cmds, $1)='$CC -shared $pic_flag -o $lib $libobjs $deplibs $compiler_flags' _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='$wl-rpath,$libdir' fi else _LT_TAGVAR(ld_shlibs, $1)=no fi ;; os2*) _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='-L$libdir' _LT_TAGVAR(hardcode_minus_L, $1)=yes _LT_TAGVAR(allow_undefined_flag, $1)=unsupported shrext_cmds=.dll _LT_TAGVAR(archive_cmds, $1)='$ECHO "LIBRARY ${soname%$shared_ext} INITINSTANCE TERMINSTANCE" > $output_objdir/$libname.def~ $ECHO "DESCRIPTION \"$libname\"" >> $output_objdir/$libname.def~ $ECHO "DATA MULTIPLE NONSHARED" >> $output_objdir/$libname.def~ $ECHO EXPORTS >> $output_objdir/$libname.def~ emxexp $libobjs | $SED /"_DLL_InitTerm"/d >> $output_objdir/$libname.def~ $CC -Zdll -Zcrtdll -o $output_objdir/$soname $libobjs $deplibs $compiler_flags $output_objdir/$libname.def~ emximp -o $lib $output_objdir/$libname.def' _LT_TAGVAR(archive_expsym_cmds, $1)='$ECHO "LIBRARY ${soname%$shared_ext} INITINSTANCE TERMINSTANCE" > $output_objdir/$libname.def~ $ECHO "DESCRIPTION \"$libname\"" >> $output_objdir/$libname.def~ $ECHO "DATA MULTIPLE NONSHARED" >> $output_objdir/$libname.def~ $ECHO EXPORTS >> $output_objdir/$libname.def~ prefix_cmds="$SED"~ if test EXPORTS = "`$SED 1q $export_symbols`"; then prefix_cmds="$prefix_cmds -e 1d"; fi~ prefix_cmds="$prefix_cmds -e \"s/^\(.*\)$/_\1/g\""~ cat $export_symbols | $prefix_cmds >> $output_objdir/$libname.def~ $CC -Zdll -Zcrtdll -o $output_objdir/$soname $libobjs $deplibs $compiler_flags $output_objdir/$libname.def~ emximp -o $lib $output_objdir/$libname.def' _LT_TAGVAR(old_archive_From_new_cmds, $1)='emximp -o $output_objdir/${libname}_dll.a $output_objdir/$libname.def' _LT_TAGVAR(enable_shared_with_static_runtimes, $1)=yes ;; osf3*) if test yes = "$GCC"; then _LT_TAGVAR(allow_undefined_flag, $1)=' $wl-expect_unresolved $wl\*' _LT_TAGVAR(archive_cmds, $1)='$CC -shared$allow_undefined_flag $libobjs $deplibs $compiler_flags $wl-soname $wl$soname `test -n "$verstring" && func_echo_all "$wl-set_version $wl$verstring"` $wl-update_registry $wl$output_objdir/so_locations -o $lib' else _LT_TAGVAR(allow_undefined_flag, $1)=' -expect_unresolved \*' _LT_TAGVAR(archive_cmds, $1)='$CC -shared$allow_undefined_flag $libobjs $deplibs $compiler_flags -soname $soname `test -n "$verstring" && func_echo_all "-set_version $verstring"` -update_registry $output_objdir/so_locations -o $lib' fi _LT_TAGVAR(archive_cmds_need_lc, $1)='no' _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='$wl-rpath $wl$libdir' _LT_TAGVAR(hardcode_libdir_separator, $1)=: ;; osf4* | osf5*) # as osf3* with the addition of -msym flag if test yes = "$GCC"; then _LT_TAGVAR(allow_undefined_flag, $1)=' $wl-expect_unresolved $wl\*' _LT_TAGVAR(archive_cmds, $1)='$CC -shared$allow_undefined_flag $pic_flag $libobjs $deplibs $compiler_flags $wl-msym $wl-soname $wl$soname `test -n "$verstring" && func_echo_all "$wl-set_version $wl$verstring"` $wl-update_registry $wl$output_objdir/so_locations -o $lib' _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='$wl-rpath $wl$libdir' else _LT_TAGVAR(allow_undefined_flag, $1)=' -expect_unresolved \*' _LT_TAGVAR(archive_cmds, $1)='$CC -shared$allow_undefined_flag $libobjs $deplibs $compiler_flags -msym -soname $soname `test -n "$verstring" && func_echo_all "-set_version $verstring"` -update_registry $output_objdir/so_locations -o $lib' _LT_TAGVAR(archive_expsym_cmds, $1)='for i in `cat $export_symbols`; do printf "%s %s\\n" -exported_symbol "\$i" >> $lib.exp; done; printf "%s\\n" "-hidden">> $lib.exp~ $CC -shared$allow_undefined_flag $wl-input $wl$lib.exp $compiler_flags $libobjs $deplibs -soname $soname `test -n "$verstring" && $ECHO "-set_version $verstring"` -update_registry $output_objdir/so_locations -o $lib~$RM $lib.exp' # Both c and cxx compiler support -rpath directly _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='-rpath $libdir' fi _LT_TAGVAR(archive_cmds_need_lc, $1)='no' _LT_TAGVAR(hardcode_libdir_separator, $1)=: ;; solaris*) _LT_TAGVAR(no_undefined_flag, $1)=' -z defs' if test yes = "$GCC"; then wlarc='$wl' _LT_TAGVAR(archive_cmds, $1)='$CC -shared $pic_flag $wl-z ${wl}text $wl-h $wl$soname -o $lib $libobjs $deplibs $compiler_flags' _LT_TAGVAR(archive_expsym_cmds, $1)='echo "{ global:" > $lib.exp~cat $export_symbols | $SED -e "s/\(.*\)/\1;/" >> $lib.exp~echo "local: *; };" >> $lib.exp~ $CC -shared $pic_flag $wl-z ${wl}text $wl-M $wl$lib.exp $wl-h $wl$soname -o $lib $libobjs $deplibs $compiler_flags~$RM $lib.exp' else case `$CC -V 2>&1` in *"Compilers 5.0"*) wlarc='' _LT_TAGVAR(archive_cmds, $1)='$LD -G$allow_undefined_flag -h $soname -o $lib $libobjs $deplibs $linker_flags' _LT_TAGVAR(archive_expsym_cmds, $1)='echo "{ global:" > $lib.exp~cat $export_symbols | $SED -e "s/\(.*\)/\1;/" >> $lib.exp~echo "local: *; };" >> $lib.exp~ $LD -G$allow_undefined_flag -M $lib.exp -h $soname -o $lib $libobjs $deplibs $linker_flags~$RM $lib.exp' ;; *) wlarc='$wl' _LT_TAGVAR(archive_cmds, $1)='$CC -G$allow_undefined_flag -h $soname -o $lib $libobjs $deplibs $compiler_flags' _LT_TAGVAR(archive_expsym_cmds, $1)='echo "{ global:" > $lib.exp~cat $export_symbols | $SED -e "s/\(.*\)/\1;/" >> $lib.exp~echo "local: *; };" >> $lib.exp~ $CC -G$allow_undefined_flag -M $lib.exp -h $soname -o $lib $libobjs $deplibs $compiler_flags~$RM $lib.exp' ;; esac fi _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='-R$libdir' _LT_TAGVAR(hardcode_shlibpath_var, $1)=no case $host_os in solaris2.[[0-5]] | solaris2.[[0-5]].*) ;; *) # The compiler driver will combine and reorder linker options, # but understands '-z linker_flag'. GCC discards it without '$wl', # but is careful enough not to reorder. # Supported since Solaris 2.6 (maybe 2.5.1?) if test yes = "$GCC"; then _LT_TAGVAR(whole_archive_flag_spec, $1)='$wl-z ${wl}allextract$convenience $wl-z ${wl}defaultextract' else _LT_TAGVAR(whole_archive_flag_spec, $1)='-z allextract$convenience -z defaultextract' fi ;; esac _LT_TAGVAR(link_all_deplibs, $1)=yes ;; sunos4*) if test sequent = "$host_vendor"; then # Use $CC to link under sequent, because it throws in some extra .o # files that make .init and .fini sections work. _LT_TAGVAR(archive_cmds, $1)='$CC -G $wl-h $soname -o $lib $libobjs $deplibs $compiler_flags' else _LT_TAGVAR(archive_cmds, $1)='$LD -assert pure-text -Bstatic -o $lib $libobjs $deplibs $linker_flags' fi _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='-L$libdir' _LT_TAGVAR(hardcode_direct, $1)=yes _LT_TAGVAR(hardcode_minus_L, $1)=yes _LT_TAGVAR(hardcode_shlibpath_var, $1)=no ;; sysv4) case $host_vendor in sni) _LT_TAGVAR(archive_cmds, $1)='$LD -G -h $soname -o $lib $libobjs $deplibs $linker_flags' _LT_TAGVAR(hardcode_direct, $1)=yes # is this really true??? ;; siemens) ## LD is ld it makes a PLAMLIB ## CC just makes a GrossModule. _LT_TAGVAR(archive_cmds, $1)='$LD -G -o $lib $libobjs $deplibs $linker_flags' _LT_TAGVAR(reload_cmds, $1)='$CC -r -o $output$reload_objs' _LT_TAGVAR(hardcode_direct, $1)=no ;; motorola) _LT_TAGVAR(archive_cmds, $1)='$LD -G -h $soname -o $lib $libobjs $deplibs $linker_flags' _LT_TAGVAR(hardcode_direct, $1)=no #Motorola manual says yes, but my tests say they lie ;; esac runpath_var='LD_RUN_PATH' _LT_TAGVAR(hardcode_shlibpath_var, $1)=no ;; sysv4.3*) _LT_TAGVAR(archive_cmds, $1)='$LD -G -h $soname -o $lib $libobjs $deplibs $linker_flags' _LT_TAGVAR(hardcode_shlibpath_var, $1)=no _LT_TAGVAR(export_dynamic_flag_spec, $1)='-Bexport' ;; sysv4*MP*) if test -d /usr/nec; then _LT_TAGVAR(archive_cmds, $1)='$LD -G -h $soname -o $lib $libobjs $deplibs $linker_flags' _LT_TAGVAR(hardcode_shlibpath_var, $1)=no runpath_var=LD_RUN_PATH hardcode_runpath_var=yes _LT_TAGVAR(ld_shlibs, $1)=yes fi ;; sysv4*uw2* | sysv5OpenUNIX* | sysv5UnixWare7.[[01]].[[10]]* | unixware7* | sco3.2v5.0.[[024]]*) _LT_TAGVAR(no_undefined_flag, $1)='$wl-z,text' _LT_TAGVAR(archive_cmds_need_lc, $1)=no _LT_TAGVAR(hardcode_shlibpath_var, $1)=no runpath_var='LD_RUN_PATH' if test yes = "$GCC"; then _LT_TAGVAR(archive_cmds, $1)='$CC -shared $wl-h,$soname -o $lib $libobjs $deplibs $compiler_flags' _LT_TAGVAR(archive_expsym_cmds, $1)='$CC -shared $wl-Bexport:$export_symbols $wl-h,$soname -o $lib $libobjs $deplibs $compiler_flags' else _LT_TAGVAR(archive_cmds, $1)='$CC -G $wl-h,$soname -o $lib $libobjs $deplibs $compiler_flags' _LT_TAGVAR(archive_expsym_cmds, $1)='$CC -G $wl-Bexport:$export_symbols $wl-h,$soname -o $lib $libobjs $deplibs $compiler_flags' fi ;; sysv5* | sco3.2v5* | sco5v6*) # Note: We CANNOT use -z defs as we might desire, because we do not # link with -lc, and that would cause any symbols used from libc to # always be unresolved, which means just about no library would # ever link correctly. If we're not using GNU ld we use -z text # though, which does catch some bad symbols but isn't as heavy-handed # as -z defs. _LT_TAGVAR(no_undefined_flag, $1)='$wl-z,text' _LT_TAGVAR(allow_undefined_flag, $1)='$wl-z,nodefs' _LT_TAGVAR(archive_cmds_need_lc, $1)=no _LT_TAGVAR(hardcode_shlibpath_var, $1)=no _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='$wl-R,$libdir' _LT_TAGVAR(hardcode_libdir_separator, $1)=':' _LT_TAGVAR(link_all_deplibs, $1)=yes _LT_TAGVAR(export_dynamic_flag_spec, $1)='$wl-Bexport' runpath_var='LD_RUN_PATH' if test yes = "$GCC"; then _LT_TAGVAR(archive_cmds, $1)='$CC -shared $wl-h,$soname -o $lib $libobjs $deplibs $compiler_flags' _LT_TAGVAR(archive_expsym_cmds, $1)='$CC -shared $wl-Bexport:$export_symbols $wl-h,$soname -o $lib $libobjs $deplibs $compiler_flags' else _LT_TAGVAR(archive_cmds, $1)='$CC -G $wl-h,$soname -o $lib $libobjs $deplibs $compiler_flags' _LT_TAGVAR(archive_expsym_cmds, $1)='$CC -G $wl-Bexport:$export_symbols $wl-h,$soname -o $lib $libobjs $deplibs $compiler_flags' fi ;; uts4*) _LT_TAGVAR(archive_cmds, $1)='$LD -G -h $soname -o $lib $libobjs $deplibs $linker_flags' _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='-L$libdir' _LT_TAGVAR(hardcode_shlibpath_var, $1)=no ;; *) _LT_TAGVAR(ld_shlibs, $1)=no ;; esac if test sni = "$host_vendor"; then case $host in sysv4 | sysv4.2uw2* | sysv4.3* | sysv5*) _LT_TAGVAR(export_dynamic_flag_spec, $1)='$wl-Blargedynsym' ;; esac fi fi ]) AC_MSG_RESULT([$_LT_TAGVAR(ld_shlibs, $1)]) test no = "$_LT_TAGVAR(ld_shlibs, $1)" && can_build_shared=no _LT_TAGVAR(with_gnu_ld, $1)=$with_gnu_ld _LT_DECL([], [libext], [0], [Old archive suffix (normally "a")])dnl _LT_DECL([], [shrext_cmds], [1], [Shared library suffix (normally ".so")])dnl _LT_DECL([], [extract_expsyms_cmds], [2], [The commands to extract the exported symbol list from a shared archive]) # # Do we need to explicitly link libc? # case "x$_LT_TAGVAR(archive_cmds_need_lc, $1)" in x|xyes) # Assume -lc should be added _LT_TAGVAR(archive_cmds_need_lc, $1)=yes if test yes,yes = "$GCC,$enable_shared"; then case $_LT_TAGVAR(archive_cmds, $1) in *'~'*) # FIXME: we may have to deal with multi-command sequences. ;; '$CC '*) # Test whether the compiler implicitly links with -lc since on some # systems, -lgcc has to come before -lc. If gcc already passes -lc # to ld, don't add -lc before -lgcc. AC_CACHE_CHECK([whether -lc should be explicitly linked in], [lt_cv_]_LT_TAGVAR(archive_cmds_need_lc, $1), [$RM conftest* echo "$lt_simple_compile_test_code" > conftest.$ac_ext if AC_TRY_EVAL(ac_compile) 2>conftest.err; then soname=conftest lib=conftest libobjs=conftest.$ac_objext deplibs= wl=$_LT_TAGVAR(lt_prog_compiler_wl, $1) pic_flag=$_LT_TAGVAR(lt_prog_compiler_pic, $1) compiler_flags=-v linker_flags=-v verstring= output_objdir=. libname=conftest lt_save_allow_undefined_flag=$_LT_TAGVAR(allow_undefined_flag, $1) _LT_TAGVAR(allow_undefined_flag, $1)= if AC_TRY_EVAL(_LT_TAGVAR(archive_cmds, $1) 2\>\&1 \| $GREP \" -lc \" \>/dev/null 2\>\&1) then lt_cv_[]_LT_TAGVAR(archive_cmds_need_lc, $1)=no else lt_cv_[]_LT_TAGVAR(archive_cmds_need_lc, $1)=yes fi _LT_TAGVAR(allow_undefined_flag, $1)=$lt_save_allow_undefined_flag else cat conftest.err 1>&5 fi $RM conftest* ]) _LT_TAGVAR(archive_cmds_need_lc, $1)=$lt_cv_[]_LT_TAGVAR(archive_cmds_need_lc, $1) ;; esac fi ;; esac _LT_TAGDECL([build_libtool_need_lc], [archive_cmds_need_lc], [0], [Whether or not to add -lc for building shared libraries]) _LT_TAGDECL([allow_libtool_libs_with_static_runtimes], [enable_shared_with_static_runtimes], [0], [Whether or not to disallow shared libs when runtime libs are static]) _LT_TAGDECL([], [export_dynamic_flag_spec], [1], [Compiler flag to allow reflexive dlopens]) _LT_TAGDECL([], [whole_archive_flag_spec], [1], [Compiler flag to generate shared objects directly from archives]) _LT_TAGDECL([], [compiler_needs_object], [1], [Whether the compiler copes with passing no objects directly]) _LT_TAGDECL([], [old_archive_from_new_cmds], [2], [Create an old-style archive from a shared archive]) _LT_TAGDECL([], [old_archive_from_expsyms_cmds], [2], [Create a temporary old-style archive to link instead of a shared archive]) _LT_TAGDECL([], [archive_cmds], [2], [Commands used to build a shared archive]) _LT_TAGDECL([], [archive_expsym_cmds], [2]) _LT_TAGDECL([], [module_cmds], [2], [Commands used to build a loadable module if different from building a shared archive.]) _LT_TAGDECL([], [module_expsym_cmds], [2]) _LT_TAGDECL([], [with_gnu_ld], [1], [Whether we are building with GNU ld or not]) _LT_TAGDECL([], [allow_undefined_flag], [1], [Flag that allows shared libraries with undefined symbols to be built]) _LT_TAGDECL([], [no_undefined_flag], [1], [Flag that enforces no undefined symbols]) _LT_TAGDECL([], [hardcode_libdir_flag_spec], [1], [Flag to hardcode $libdir into a binary during linking. This must work even if $libdir does not exist]) _LT_TAGDECL([], [hardcode_libdir_separator], [1], [Whether we need a single "-rpath" flag with a separated argument]) _LT_TAGDECL([], [hardcode_direct], [0], [Set to "yes" if using DIR/libNAME$shared_ext during linking hardcodes DIR into the resulting binary]) _LT_TAGDECL([], [hardcode_direct_absolute], [0], [Set to "yes" if using DIR/libNAME$shared_ext during linking hardcodes DIR into the resulting binary and the resulting library dependency is "absolute", i.e impossible to change by setting $shlibpath_var if the library is relocated]) _LT_TAGDECL([], [hardcode_minus_L], [0], [Set to "yes" if using the -LDIR flag during linking hardcodes DIR into the resulting binary]) _LT_TAGDECL([], [hardcode_shlibpath_var], [0], [Set to "yes" if using SHLIBPATH_VAR=DIR during linking hardcodes DIR into the resulting binary]) _LT_TAGDECL([], [hardcode_automatic], [0], [Set to "yes" if building a shared library automatically hardcodes DIR into the library and all subsequent libraries and executables linked against it]) _LT_TAGDECL([], [inherit_rpath], [0], [Set to yes if linker adds runtime paths of dependent libraries to runtime path list]) _LT_TAGDECL([], [link_all_deplibs], [0], [Whether libtool must link a program against all its dependency libraries]) _LT_TAGDECL([], [always_export_symbols], [0], [Set to "yes" if exported symbols are required]) _LT_TAGDECL([], [export_symbols_cmds], [2], [The commands to list exported symbols]) _LT_TAGDECL([], [exclude_expsyms], [1], [Symbols that should not be listed in the preloaded symbols]) _LT_TAGDECL([], [include_expsyms], [1], [Symbols that must always be exported]) _LT_TAGDECL([], [prelink_cmds], [2], [Commands necessary for linking programs (against libraries) with templates]) _LT_TAGDECL([], [postlink_cmds], [2], [Commands necessary for finishing linking programs]) _LT_TAGDECL([], [file_list_spec], [1], [Specify filename containing input files]) dnl FIXME: Not yet implemented dnl _LT_TAGDECL([], [thread_safe_flag_spec], [1], dnl [Compiler flag to generate thread safe objects]) ])# _LT_LINKER_SHLIBS # _LT_LANG_C_CONFIG([TAG]) # ------------------------ # Ensure that the configuration variables for a C compiler are suitably # defined. These variables are subsequently used by _LT_CONFIG to write # the compiler configuration to 'libtool'. m4_defun([_LT_LANG_C_CONFIG], [m4_require([_LT_DECL_EGREP])dnl lt_save_CC=$CC AC_LANG_PUSH(C) # Source file extension for C test sources. ac_ext=c # Object file extension for compiled C test sources. objext=o _LT_TAGVAR(objext, $1)=$objext # Code to be used in simple compile tests lt_simple_compile_test_code="int some_variable = 0;" # Code to be used in simple link tests lt_simple_link_test_code='int main(){return(0);}' _LT_TAG_COMPILER # Save the default compiler, since it gets overwritten when the other # tags are being tested, and _LT_TAGVAR(compiler, []) is a NOP. compiler_DEFAULT=$CC # save warnings/boilerplate of simple test code _LT_COMPILER_BOILERPLATE _LT_LINKER_BOILERPLATE ## CAVEAT EMPTOR: ## There is no encapsulation within the following macros, do not change ## the running order or otherwise move them around unless you know exactly ## what you are doing... if test -n "$compiler"; then _LT_COMPILER_NO_RTTI($1) _LT_COMPILER_PIC($1) _LT_COMPILER_C_O($1) _LT_COMPILER_FILE_LOCKS($1) _LT_LINKER_SHLIBS($1) _LT_SYS_DYNAMIC_LINKER($1) _LT_LINKER_HARDCODE_LIBPATH($1) LT_SYS_DLOPEN_SELF _LT_CMD_STRIPLIB # Report what library types will actually be built AC_MSG_CHECKING([if libtool supports shared libraries]) AC_MSG_RESULT([$can_build_shared]) AC_MSG_CHECKING([whether to build shared libraries]) test no = "$can_build_shared" && enable_shared=no # On AIX, shared libraries and static libraries use the same namespace, and # are all built from PIC. case $host_os in aix3*) test yes = "$enable_shared" && enable_static=no if test -n "$RANLIB"; then archive_cmds="$archive_cmds~\$RANLIB \$lib" postinstall_cmds='$RANLIB $lib' fi ;; aix[[4-9]]*) if test ia64 != "$host_cpu"; then case $enable_shared,$with_aix_soname,$aix_use_runtimelinking in yes,aix,yes) ;; # shared object as lib.so file only yes,svr4,*) ;; # shared object as lib.so archive member only yes,*) enable_static=no ;; # shared object in lib.a archive as well esac fi ;; esac AC_MSG_RESULT([$enable_shared]) AC_MSG_CHECKING([whether to build static libraries]) # Make sure either enable_shared or enable_static is yes. test yes = "$enable_shared" || enable_static=yes AC_MSG_RESULT([$enable_static]) _LT_CONFIG($1) fi AC_LANG_POP CC=$lt_save_CC ])# _LT_LANG_C_CONFIG # _LT_LANG_CXX_CONFIG([TAG]) # -------------------------- # Ensure that the configuration variables for a C++ compiler are suitably # defined. These variables are subsequently used by _LT_CONFIG to write # the compiler configuration to 'libtool'. m4_defun([_LT_LANG_CXX_CONFIG], [m4_require([_LT_FILEUTILS_DEFAULTS])dnl m4_require([_LT_DECL_EGREP])dnl m4_require([_LT_PATH_MANIFEST_TOOL])dnl if test -n "$CXX" && ( test no != "$CXX" && ( (test g++ = "$CXX" && `g++ -v >/dev/null 2>&1` ) || (test g++ != "$CXX"))); then AC_PROG_CXXCPP else _lt_caught_CXX_error=yes fi AC_LANG_PUSH(C++) _LT_TAGVAR(archive_cmds_need_lc, $1)=no _LT_TAGVAR(allow_undefined_flag, $1)= _LT_TAGVAR(always_export_symbols, $1)=no _LT_TAGVAR(archive_expsym_cmds, $1)= _LT_TAGVAR(compiler_needs_object, $1)=no _LT_TAGVAR(export_dynamic_flag_spec, $1)= _LT_TAGVAR(hardcode_direct, $1)=no _LT_TAGVAR(hardcode_direct_absolute, $1)=no _LT_TAGVAR(hardcode_libdir_flag_spec, $1)= _LT_TAGVAR(hardcode_libdir_separator, $1)= _LT_TAGVAR(hardcode_minus_L, $1)=no _LT_TAGVAR(hardcode_shlibpath_var, $1)=unsupported _LT_TAGVAR(hardcode_automatic, $1)=no _LT_TAGVAR(inherit_rpath, $1)=no _LT_TAGVAR(module_cmds, $1)= _LT_TAGVAR(module_expsym_cmds, $1)= _LT_TAGVAR(link_all_deplibs, $1)=unknown _LT_TAGVAR(old_archive_cmds, $1)=$old_archive_cmds _LT_TAGVAR(reload_flag, $1)=$reload_flag _LT_TAGVAR(reload_cmds, $1)=$reload_cmds _LT_TAGVAR(no_undefined_flag, $1)= _LT_TAGVAR(whole_archive_flag_spec, $1)= _LT_TAGVAR(enable_shared_with_static_runtimes, $1)=no # Source file extension for C++ test sources. ac_ext=cpp # Object file extension for compiled C++ test sources. objext=o _LT_TAGVAR(objext, $1)=$objext # No sense in running all these tests if we already determined that # the CXX compiler isn't working. Some variables (like enable_shared) # are currently assumed to apply to all compilers on this platform, # and will be corrupted by setting them based on a non-working compiler. if test yes != "$_lt_caught_CXX_error"; then # Code to be used in simple compile tests lt_simple_compile_test_code="int some_variable = 0;" # Code to be used in simple link tests lt_simple_link_test_code='int main(int, char *[[]]) { return(0); }' # ltmain only uses $CC for tagged configurations so make sure $CC is set. _LT_TAG_COMPILER # save warnings/boilerplate of simple test code _LT_COMPILER_BOILERPLATE _LT_LINKER_BOILERPLATE # Allow CC to be a program name with arguments. lt_save_CC=$CC lt_save_CFLAGS=$CFLAGS lt_save_LD=$LD lt_save_GCC=$GCC GCC=$GXX lt_save_with_gnu_ld=$with_gnu_ld lt_save_path_LD=$lt_cv_path_LD if test -n "${lt_cv_prog_gnu_ldcxx+set}"; then lt_cv_prog_gnu_ld=$lt_cv_prog_gnu_ldcxx else $as_unset lt_cv_prog_gnu_ld fi if test -n "${lt_cv_path_LDCXX+set}"; then lt_cv_path_LD=$lt_cv_path_LDCXX else $as_unset lt_cv_path_LD fi test -z "${LDCXX+set}" || LD=$LDCXX CC=${CXX-"c++"} CFLAGS=$CXXFLAGS compiler=$CC _LT_TAGVAR(compiler, $1)=$CC _LT_CC_BASENAME([$compiler]) if test -n "$compiler"; then # We don't want -fno-exception when compiling C++ code, so set the # no_builtin_flag separately if test yes = "$GXX"; then _LT_TAGVAR(lt_prog_compiler_no_builtin_flag, $1)=' -fno-builtin' else _LT_TAGVAR(lt_prog_compiler_no_builtin_flag, $1)= fi if test yes = "$GXX"; then # Set up default GNU C++ configuration LT_PATH_LD # Check if GNU C++ uses GNU ld as the underlying linker, since the # archiving commands below assume that GNU ld is being used. if test yes = "$with_gnu_ld"; then _LT_TAGVAR(archive_cmds, $1)='$CC $pic_flag -shared -nostdlib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags $wl-soname $wl$soname -o $lib' _LT_TAGVAR(archive_expsym_cmds, $1)='$CC $pic_flag -shared -nostdlib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags $wl-soname $wl$soname $wl-retain-symbols-file $wl$export_symbols -o $lib' _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='$wl-rpath $wl$libdir' _LT_TAGVAR(export_dynamic_flag_spec, $1)='$wl--export-dynamic' # If archive_cmds runs LD, not CC, wlarc should be empty # XXX I think wlarc can be eliminated in ltcf-cxx, but I need to # investigate it a little bit more. (MM) wlarc='$wl' # ancient GNU ld didn't support --whole-archive et. al. if eval "`$CC -print-prog-name=ld` --help 2>&1" | $GREP 'no-whole-archive' > /dev/null; then _LT_TAGVAR(whole_archive_flag_spec, $1)=$wlarc'--whole-archive$convenience '$wlarc'--no-whole-archive' else _LT_TAGVAR(whole_archive_flag_spec, $1)= fi else with_gnu_ld=no wlarc= # A generic and very simple default shared library creation # command for GNU C++ for the case where it uses the native # linker, instead of GNU ld. If possible, this setting should # overridden to take advantage of the native linker features on # the platform it is being used on. _LT_TAGVAR(archive_cmds, $1)='$CC -shared -nostdlib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags -o $lib' fi # Commands to make compiler produce verbose output that lists # what "hidden" libraries, object files and flags are used when # linking a shared library. output_verbose_link_cmd='$CC -shared $CFLAGS -v conftest.$objext 2>&1 | $GREP -v "^Configured with:" | $GREP "\-L"' else GXX=no with_gnu_ld=no wlarc= fi # PORTME: fill in a description of your system's C++ link characteristics AC_MSG_CHECKING([whether the $compiler linker ($LD) supports shared libraries]) _LT_TAGVAR(ld_shlibs, $1)=yes case $host_os in aix3*) # FIXME: insert proper C++ library support _LT_TAGVAR(ld_shlibs, $1)=no ;; aix[[4-9]]*) if test ia64 = "$host_cpu"; then # On IA64, the linker does run time linking by default, so we don't # have to do anything special. aix_use_runtimelinking=no exp_sym_flag='-Bexport' no_entry_flag= else aix_use_runtimelinking=no # Test if we are trying to use run time linking or normal # AIX style linking. If -brtl is somewhere in LDFLAGS, we # have runtime linking enabled, and use it for executables. # For shared libraries, we enable/disable runtime linking # depending on the kind of the shared library created - # when "with_aix_soname,aix_use_runtimelinking" is: # "aix,no" lib.a(lib.so.V) shared, rtl:no, for executables # "aix,yes" lib.so shared, rtl:yes, for executables # lib.a static archive # "both,no" lib.so.V(shr.o) shared, rtl:yes # lib.a(lib.so.V) shared, rtl:no, for executables # "both,yes" lib.so.V(shr.o) shared, rtl:yes, for executables # lib.a(lib.so.V) shared, rtl:no # "svr4,*" lib.so.V(shr.o) shared, rtl:yes, for executables # lib.a static archive case $host_os in aix4.[[23]]|aix4.[[23]].*|aix[[5-9]]*) for ld_flag in $LDFLAGS; do case $ld_flag in *-brtl*) aix_use_runtimelinking=yes break ;; esac done if test svr4,no = "$with_aix_soname,$aix_use_runtimelinking"; then # With aix-soname=svr4, we create the lib.so.V shared archives only, # so we don't have lib.a shared libs to link our executables. # We have to force runtime linking in this case. aix_use_runtimelinking=yes LDFLAGS="$LDFLAGS -Wl,-brtl" fi ;; esac exp_sym_flag='-bexport' no_entry_flag='-bnoentry' fi # When large executables or shared objects are built, AIX ld can # have problems creating the table of contents. If linking a library # or program results in "error TOC overflow" add -mminimal-toc to # CXXFLAGS/CFLAGS for g++/gcc. In the cases where that is not # enough to fix the problem, add -Wl,-bbigtoc to LDFLAGS. _LT_TAGVAR(archive_cmds, $1)='' _LT_TAGVAR(hardcode_direct, $1)=yes _LT_TAGVAR(hardcode_direct_absolute, $1)=yes _LT_TAGVAR(hardcode_libdir_separator, $1)=':' _LT_TAGVAR(link_all_deplibs, $1)=yes _LT_TAGVAR(file_list_spec, $1)='$wl-f,' case $with_aix_soname,$aix_use_runtimelinking in aix,*) ;; # no import file svr4,* | *,yes) # use import file # The Import File defines what to hardcode. _LT_TAGVAR(hardcode_direct, $1)=no _LT_TAGVAR(hardcode_direct_absolute, $1)=no ;; esac if test yes = "$GXX"; then case $host_os in aix4.[[012]]|aix4.[[012]].*) # We only want to do this on AIX 4.2 and lower, the check # below for broken collect2 doesn't work under 4.3+ collect2name=`$CC -print-prog-name=collect2` if test -f "$collect2name" && strings "$collect2name" | $GREP resolve_lib_name >/dev/null then # We have reworked collect2 : else # We have old collect2 _LT_TAGVAR(hardcode_direct, $1)=unsupported # It fails to find uninstalled libraries when the uninstalled # path is not listed in the libpath. Setting hardcode_minus_L # to unsupported forces relinking _LT_TAGVAR(hardcode_minus_L, $1)=yes _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='-L$libdir' _LT_TAGVAR(hardcode_libdir_separator, $1)= fi esac shared_flag='-shared' if test yes = "$aix_use_runtimelinking"; then shared_flag=$shared_flag' $wl-G' fi # Need to ensure runtime linking is disabled for the traditional # shared library, or the linker may eventually find shared libraries # /with/ Import File - we do not want to mix them. shared_flag_aix='-shared' shared_flag_svr4='-shared $wl-G' else # not using gcc if test ia64 = "$host_cpu"; then # VisualAge C++, Version 5.5 for AIX 5L for IA-64, Beta 3 Release # chokes on -Wl,-G. The following line is correct: shared_flag='-G' else if test yes = "$aix_use_runtimelinking"; then shared_flag='$wl-G' else shared_flag='$wl-bM:SRE' fi shared_flag_aix='$wl-bM:SRE' shared_flag_svr4='$wl-G' fi fi _LT_TAGVAR(export_dynamic_flag_spec, $1)='$wl-bexpall' # It seems that -bexpall does not export symbols beginning with # underscore (_), so it is better to generate a list of symbols to # export. _LT_TAGVAR(always_export_symbols, $1)=yes if test aix,yes = "$with_aix_soname,$aix_use_runtimelinking"; then # Warning - without using the other runtime loading flags (-brtl), # -berok will link without error, but may produce a broken library. # The "-G" linker flag allows undefined symbols. _LT_TAGVAR(no_undefined_flag, $1)='-bernotok' # Determine the default libpath from the value encoded in an empty # executable. _LT_SYS_MODULE_PATH_AIX([$1]) _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='$wl-blibpath:$libdir:'"$aix_libpath" _LT_TAGVAR(archive_expsym_cmds, $1)='$CC -o $output_objdir/$soname $libobjs $deplibs $wl'$no_entry_flag' $compiler_flags `if test -n "$allow_undefined_flag"; then func_echo_all "$wl$allow_undefined_flag"; else :; fi` $wl'$exp_sym_flag:\$export_symbols' '$shared_flag else if test ia64 = "$host_cpu"; then _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='$wl-R $libdir:/usr/lib:/lib' _LT_TAGVAR(allow_undefined_flag, $1)="-z nodefs" _LT_TAGVAR(archive_expsym_cmds, $1)="\$CC $shared_flag"' -o $output_objdir/$soname $libobjs $deplibs '"\$wl$no_entry_flag"' $compiler_flags $wl$allow_undefined_flag '"\$wl$exp_sym_flag:\$export_symbols" else # Determine the default libpath from the value encoded in an # empty executable. _LT_SYS_MODULE_PATH_AIX([$1]) _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='$wl-blibpath:$libdir:'"$aix_libpath" # Warning - without using the other run time loading flags, # -berok will link without error, but may produce a broken library. _LT_TAGVAR(no_undefined_flag, $1)=' $wl-bernotok' _LT_TAGVAR(allow_undefined_flag, $1)=' $wl-berok' if test yes = "$with_gnu_ld"; then # We only use this code for GNU lds that support --whole-archive. _LT_TAGVAR(whole_archive_flag_spec, $1)='$wl--whole-archive$convenience $wl--no-whole-archive' else # Exported symbols can be pulled into shared objects from archives _LT_TAGVAR(whole_archive_flag_spec, $1)='$convenience' fi _LT_TAGVAR(archive_cmds_need_lc, $1)=yes _LT_TAGVAR(archive_expsym_cmds, $1)='$RM -r $output_objdir/$realname.d~$MKDIR $output_objdir/$realname.d' # -brtl affects multiple linker settings, -berok does not and is overridden later compiler_flags_filtered='`func_echo_all "$compiler_flags " | $SED -e "s%-brtl\\([[, ]]\\)%-berok\\1%g"`' if test svr4 != "$with_aix_soname"; then # This is similar to how AIX traditionally builds its shared # libraries. Need -bnortl late, we may have -brtl in LDFLAGS. _LT_TAGVAR(archive_expsym_cmds, $1)="$_LT_TAGVAR(archive_expsym_cmds, $1)"'~$CC '$shared_flag_aix' -o $output_objdir/$realname.d/$soname $libobjs $deplibs $wl-bnoentry '$compiler_flags_filtered'$wl-bE:$export_symbols$allow_undefined_flag~$AR $AR_FLAGS $output_objdir/$libname$release.a $output_objdir/$realname.d/$soname' fi if test aix != "$with_aix_soname"; then _LT_TAGVAR(archive_expsym_cmds, $1)="$_LT_TAGVAR(archive_expsym_cmds, $1)"'~$CC '$shared_flag_svr4' -o $output_objdir/$realname.d/$shared_archive_member_spec.o $libobjs $deplibs $wl-bnoentry '$compiler_flags_filtered'$wl-bE:$export_symbols$allow_undefined_flag~$STRIP -e $output_objdir/$realname.d/$shared_archive_member_spec.o~( func_echo_all "#! $soname($shared_archive_member_spec.o)"; if test shr_64 = "$shared_archive_member_spec"; then func_echo_all "# 64"; else func_echo_all "# 32"; fi; cat $export_symbols ) > $output_objdir/$realname.d/$shared_archive_member_spec.imp~$AR $AR_FLAGS $output_objdir/$soname $output_objdir/$realname.d/$shared_archive_member_spec.o $output_objdir/$realname.d/$shared_archive_member_spec.imp' else # used by -dlpreopen to get the symbols _LT_TAGVAR(archive_expsym_cmds, $1)="$_LT_TAGVAR(archive_expsym_cmds, $1)"'~$MV $output_objdir/$realname.d/$soname $output_objdir' fi _LT_TAGVAR(archive_expsym_cmds, $1)="$_LT_TAGVAR(archive_expsym_cmds, $1)"'~$RM -r $output_objdir/$realname.d' fi fi ;; beos*) if $LD --help 2>&1 | $GREP ': supported targets:.* elf' > /dev/null; then _LT_TAGVAR(allow_undefined_flag, $1)=unsupported # Joseph Beckenbach says some releases of gcc # support --undefined. This deserves some investigation. FIXME _LT_TAGVAR(archive_cmds, $1)='$CC -nostart $libobjs $deplibs $compiler_flags $wl-soname $wl$soname -o $lib' else _LT_TAGVAR(ld_shlibs, $1)=no fi ;; chorus*) case $cc_basename in *) # FIXME: insert proper C++ library support _LT_TAGVAR(ld_shlibs, $1)=no ;; esac ;; cygwin* | mingw* | pw32* | cegcc*) case $GXX,$cc_basename in ,cl* | no,cl*) # Native MSVC # hardcode_libdir_flag_spec is actually meaningless, as there is # no search path for DLLs. _LT_TAGVAR(hardcode_libdir_flag_spec, $1)=' ' _LT_TAGVAR(allow_undefined_flag, $1)=unsupported _LT_TAGVAR(always_export_symbols, $1)=yes _LT_TAGVAR(file_list_spec, $1)='@' # Tell ltmain to make .lib files, not .a files. libext=lib # Tell ltmain to make .dll files, not .so files. shrext_cmds=.dll # FIXME: Setting linknames here is a bad hack. _LT_TAGVAR(archive_cmds, $1)='$CC -o $output_objdir/$soname $libobjs $compiler_flags $deplibs -Wl,-DLL,-IMPLIB:"$tool_output_objdir$libname.dll.lib"~linknames=' _LT_TAGVAR(archive_expsym_cmds, $1)='if _LT_DLL_DEF_P([$export_symbols]); then cp "$export_symbols" "$output_objdir/$soname.def"; echo "$tool_output_objdir$soname.def" > "$output_objdir/$soname.exp"; else $SED -e '\''s/^/-link -EXPORT:/'\'' < $export_symbols > $output_objdir/$soname.exp; fi~ $CC -o $tool_output_objdir$soname $libobjs $compiler_flags $deplibs "@$tool_output_objdir$soname.exp" -Wl,-DLL,-IMPLIB:"$tool_output_objdir$libname.dll.lib"~ linknames=' # The linker will not automatically build a static lib if we build a DLL. # _LT_TAGVAR(old_archive_from_new_cmds, $1)='true' _LT_TAGVAR(enable_shared_with_static_runtimes, $1)=yes # Don't use ranlib _LT_TAGVAR(old_postinstall_cmds, $1)='chmod 644 $oldlib' _LT_TAGVAR(postlink_cmds, $1)='lt_outputfile="@OUTPUT@"~ lt_tool_outputfile="@TOOL_OUTPUT@"~ case $lt_outputfile in *.exe|*.EXE) ;; *) lt_outputfile=$lt_outputfile.exe lt_tool_outputfile=$lt_tool_outputfile.exe ;; esac~ func_to_tool_file "$lt_outputfile"~ if test : != "$MANIFEST_TOOL" && test -f "$lt_outputfile.manifest"; then $MANIFEST_TOOL -manifest "$lt_tool_outputfile.manifest" -outputresource:"$lt_tool_outputfile" || exit 1; $RM "$lt_outputfile.manifest"; fi' ;; *) # g++ # _LT_TAGVAR(hardcode_libdir_flag_spec, $1) is actually meaningless, # as there is no search path for DLLs. _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='-L$libdir' _LT_TAGVAR(export_dynamic_flag_spec, $1)='$wl--export-all-symbols' _LT_TAGVAR(allow_undefined_flag, $1)=unsupported _LT_TAGVAR(always_export_symbols, $1)=no _LT_TAGVAR(enable_shared_with_static_runtimes, $1)=yes if $LD --help 2>&1 | $GREP 'auto-import' > /dev/null; then _LT_TAGVAR(archive_cmds, $1)='$CC -shared -nostdlib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags -o $output_objdir/$soname $wl--enable-auto-image-base -Xlinker --out-implib -Xlinker $lib' # If the export-symbols file already is a .def file, use it as # is; otherwise, prepend EXPORTS... _LT_TAGVAR(archive_expsym_cmds, $1)='if _LT_DLL_DEF_P([$export_symbols]); then cp $export_symbols $output_objdir/$soname.def; else echo EXPORTS > $output_objdir/$soname.def; cat $export_symbols >> $output_objdir/$soname.def; fi~ $CC -shared -nostdlib $output_objdir/$soname.def $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags -o $output_objdir/$soname $wl--enable-auto-image-base -Xlinker --out-implib -Xlinker $lib' else _LT_TAGVAR(ld_shlibs, $1)=no fi ;; esac ;; darwin* | rhapsody*) _LT_DARWIN_LINKER_FEATURES($1) ;; os2*) _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='-L$libdir' _LT_TAGVAR(hardcode_minus_L, $1)=yes _LT_TAGVAR(allow_undefined_flag, $1)=unsupported shrext_cmds=.dll _LT_TAGVAR(archive_cmds, $1)='$ECHO "LIBRARY ${soname%$shared_ext} INITINSTANCE TERMINSTANCE" > $output_objdir/$libname.def~ $ECHO "DESCRIPTION \"$libname\"" >> $output_objdir/$libname.def~ $ECHO "DATA MULTIPLE NONSHARED" >> $output_objdir/$libname.def~ $ECHO EXPORTS >> $output_objdir/$libname.def~ emxexp $libobjs | $SED /"_DLL_InitTerm"/d >> $output_objdir/$libname.def~ $CC -Zdll -Zcrtdll -o $output_objdir/$soname $libobjs $deplibs $compiler_flags $output_objdir/$libname.def~ emximp -o $lib $output_objdir/$libname.def' _LT_TAGVAR(archive_expsym_cmds, $1)='$ECHO "LIBRARY ${soname%$shared_ext} INITINSTANCE TERMINSTANCE" > $output_objdir/$libname.def~ $ECHO "DESCRIPTION \"$libname\"" >> $output_objdir/$libname.def~ $ECHO "DATA MULTIPLE NONSHARED" >> $output_objdir/$libname.def~ $ECHO EXPORTS >> $output_objdir/$libname.def~ prefix_cmds="$SED"~ if test EXPORTS = "`$SED 1q $export_symbols`"; then prefix_cmds="$prefix_cmds -e 1d"; fi~ prefix_cmds="$prefix_cmds -e \"s/^\(.*\)$/_\1/g\""~ cat $export_symbols | $prefix_cmds >> $output_objdir/$libname.def~ $CC -Zdll -Zcrtdll -o $output_objdir/$soname $libobjs $deplibs $compiler_flags $output_objdir/$libname.def~ emximp -o $lib $output_objdir/$libname.def' _LT_TAGVAR(old_archive_From_new_cmds, $1)='emximp -o $output_objdir/${libname}_dll.a $output_objdir/$libname.def' _LT_TAGVAR(enable_shared_with_static_runtimes, $1)=yes ;; dgux*) case $cc_basename in ec++*) # FIXME: insert proper C++ library support _LT_TAGVAR(ld_shlibs, $1)=no ;; ghcx*) # Green Hills C++ Compiler # FIXME: insert proper C++ library support _LT_TAGVAR(ld_shlibs, $1)=no ;; *) # FIXME: insert proper C++ library support _LT_TAGVAR(ld_shlibs, $1)=no ;; esac ;; freebsd2.*) # C++ shared libraries reported to be fairly broken before # switch to ELF _LT_TAGVAR(ld_shlibs, $1)=no ;; freebsd-elf*) _LT_TAGVAR(archive_cmds_need_lc, $1)=no ;; freebsd* | dragonfly*) # FreeBSD 3 and later use GNU C++ and GNU ld with standard ELF # conventions _LT_TAGVAR(ld_shlibs, $1)=yes ;; haiku*) _LT_TAGVAR(archive_cmds, $1)='$CC -shared $libobjs $deplibs $compiler_flags $wl-soname $wl$soname -o $lib' _LT_TAGVAR(link_all_deplibs, $1)=yes ;; hpux9*) _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='$wl+b $wl$libdir' _LT_TAGVAR(hardcode_libdir_separator, $1)=: _LT_TAGVAR(export_dynamic_flag_spec, $1)='$wl-E' _LT_TAGVAR(hardcode_direct, $1)=yes _LT_TAGVAR(hardcode_minus_L, $1)=yes # Not in the search PATH, # but as the default # location of the library. case $cc_basename in CC*) # FIXME: insert proper C++ library support _LT_TAGVAR(ld_shlibs, $1)=no ;; aCC*) _LT_TAGVAR(archive_cmds, $1)='$RM $output_objdir/$soname~$CC -b $wl+b $wl$install_libdir -o $output_objdir/$soname $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags~test "x$output_objdir/$soname" = "x$lib" || mv $output_objdir/$soname $lib' # Commands to make compiler produce verbose output that lists # what "hidden" libraries, object files and flags are used when # linking a shared library. # # There doesn't appear to be a way to prevent this compiler from # explicitly linking system object files so we need to strip them # from the output so that they don't get included in the library # dependencies. output_verbose_link_cmd='templist=`($CC -b $CFLAGS -v conftest.$objext 2>&1) | $EGREP "\-L"`; list= ; for z in $templist; do case $z in conftest.$objext) list="$list $z";; *.$objext);; *) list="$list $z";;esac; done; func_echo_all "$list"' ;; *) if test yes = "$GXX"; then _LT_TAGVAR(archive_cmds, $1)='$RM $output_objdir/$soname~$CC -shared -nostdlib $pic_flag $wl+b $wl$install_libdir -o $output_objdir/$soname $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags~test "x$output_objdir/$soname" = "x$lib" || mv $output_objdir/$soname $lib' else # FIXME: insert proper C++ library support _LT_TAGVAR(ld_shlibs, $1)=no fi ;; esac ;; hpux10*|hpux11*) if test no = "$with_gnu_ld"; then _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='$wl+b $wl$libdir' _LT_TAGVAR(hardcode_libdir_separator, $1)=: case $host_cpu in hppa*64*|ia64*) ;; *) _LT_TAGVAR(export_dynamic_flag_spec, $1)='$wl-E' ;; esac fi case $host_cpu in hppa*64*|ia64*) _LT_TAGVAR(hardcode_direct, $1)=no _LT_TAGVAR(hardcode_shlibpath_var, $1)=no ;; *) _LT_TAGVAR(hardcode_direct, $1)=yes _LT_TAGVAR(hardcode_direct_absolute, $1)=yes _LT_TAGVAR(hardcode_minus_L, $1)=yes # Not in the search PATH, # but as the default # location of the library. ;; esac case $cc_basename in CC*) # FIXME: insert proper C++ library support _LT_TAGVAR(ld_shlibs, $1)=no ;; aCC*) case $host_cpu in hppa*64*) _LT_TAGVAR(archive_cmds, $1)='$CC -b $wl+h $wl$soname -o $lib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags' ;; ia64*) _LT_TAGVAR(archive_cmds, $1)='$CC -b $wl+h $wl$soname $wl+nodefaultrpath -o $lib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags' ;; *) _LT_TAGVAR(archive_cmds, $1)='$CC -b $wl+h $wl$soname $wl+b $wl$install_libdir -o $lib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags' ;; esac # Commands to make compiler produce verbose output that lists # what "hidden" libraries, object files and flags are used when # linking a shared library. # # There doesn't appear to be a way to prevent this compiler from # explicitly linking system object files so we need to strip them # from the output so that they don't get included in the library # dependencies. output_verbose_link_cmd='templist=`($CC -b $CFLAGS -v conftest.$objext 2>&1) | $GREP "\-L"`; list= ; for z in $templist; do case $z in conftest.$objext) list="$list $z";; *.$objext);; *) list="$list $z";;esac; done; func_echo_all "$list"' ;; *) if test yes = "$GXX"; then if test no = "$with_gnu_ld"; then case $host_cpu in hppa*64*) _LT_TAGVAR(archive_cmds, $1)='$CC -shared -nostdlib -fPIC $wl+h $wl$soname -o $lib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags' ;; ia64*) _LT_TAGVAR(archive_cmds, $1)='$CC -shared -nostdlib $pic_flag $wl+h $wl$soname $wl+nodefaultrpath -o $lib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags' ;; *) _LT_TAGVAR(archive_cmds, $1)='$CC -shared -nostdlib $pic_flag $wl+h $wl$soname $wl+b $wl$install_libdir -o $lib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags' ;; esac fi else # FIXME: insert proper C++ library support _LT_TAGVAR(ld_shlibs, $1)=no fi ;; esac ;; interix[[3-9]]*) _LT_TAGVAR(hardcode_direct, $1)=no _LT_TAGVAR(hardcode_shlibpath_var, $1)=no _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='$wl-rpath,$libdir' _LT_TAGVAR(export_dynamic_flag_spec, $1)='$wl-E' # Hack: On Interix 3.x, we cannot compile PIC because of a broken gcc. # Instead, shared libraries are loaded at an image base (0x10000000 by # default) and relocated if they conflict, which is a slow very memory # consuming and fragmenting process. To avoid this, we pick a random, # 256 KiB-aligned image base between 0x50000000 and 0x6FFC0000 at link # time. Moving up from 0x10000000 also allows more sbrk(2) space. _LT_TAGVAR(archive_cmds, $1)='$CC -shared $pic_flag $libobjs $deplibs $compiler_flags $wl-h,$soname $wl--image-base,`expr ${RANDOM-$$} % 4096 / 2 \* 262144 + 1342177280` -o $lib' _LT_TAGVAR(archive_expsym_cmds, $1)='sed "s|^|_|" $export_symbols >$output_objdir/$soname.expsym~$CC -shared $pic_flag $libobjs $deplibs $compiler_flags $wl-h,$soname $wl--retain-symbols-file,$output_objdir/$soname.expsym $wl--image-base,`expr ${RANDOM-$$} % 4096 / 2 \* 262144 + 1342177280` -o $lib' ;; irix5* | irix6*) case $cc_basename in CC*) # SGI C++ _LT_TAGVAR(archive_cmds, $1)='$CC -shared -all -multigot $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags -soname $soname `test -n "$verstring" && func_echo_all "-set_version $verstring"` -update_registry $output_objdir/so_locations -o $lib' # Archives containing C++ object files must be created using # "CC -ar", where "CC" is the IRIX C++ compiler. This is # necessary to make sure instantiated templates are included # in the archive. _LT_TAGVAR(old_archive_cmds, $1)='$CC -ar -WR,-u -o $oldlib $oldobjs' ;; *) if test yes = "$GXX"; then if test no = "$with_gnu_ld"; then _LT_TAGVAR(archive_cmds, $1)='$CC -shared $pic_flag -nostdlib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags $wl-soname $wl$soname `test -n "$verstring" && func_echo_all "$wl-set_version $wl$verstring"` $wl-update_registry $wl$output_objdir/so_locations -o $lib' else _LT_TAGVAR(archive_cmds, $1)='$CC -shared $pic_flag -nostdlib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags $wl-soname $wl$soname `test -n "$verstring" && func_echo_all "$wl-set_version $wl$verstring"` -o $lib' fi fi _LT_TAGVAR(link_all_deplibs, $1)=yes ;; esac _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='$wl-rpath $wl$libdir' _LT_TAGVAR(hardcode_libdir_separator, $1)=: _LT_TAGVAR(inherit_rpath, $1)=yes ;; linux* | k*bsd*-gnu | kopensolaris*-gnu | gnu*) case $cc_basename in KCC*) # Kuck and Associates, Inc. (KAI) C++ Compiler # KCC will only create a shared library if the output file # ends with ".so" (or ".sl" for HP-UX), so rename the library # to its proper name (with version) after linking. _LT_TAGVAR(archive_cmds, $1)='tempext=`echo $shared_ext | $SED -e '\''s/\([[^()0-9A-Za-z{}]]\)/\\\\\1/g'\''`; templib=`echo $lib | $SED -e "s/\$tempext\..*/.so/"`; $CC $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags --soname $soname -o \$templib; mv \$templib $lib' _LT_TAGVAR(archive_expsym_cmds, $1)='tempext=`echo $shared_ext | $SED -e '\''s/\([[^()0-9A-Za-z{}]]\)/\\\\\1/g'\''`; templib=`echo $lib | $SED -e "s/\$tempext\..*/.so/"`; $CC $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags --soname $soname -o \$templib $wl-retain-symbols-file,$export_symbols; mv \$templib $lib' # Commands to make compiler produce verbose output that lists # what "hidden" libraries, object files and flags are used when # linking a shared library. # # There doesn't appear to be a way to prevent this compiler from # explicitly linking system object files so we need to strip them # from the output so that they don't get included in the library # dependencies. output_verbose_link_cmd='templist=`$CC $CFLAGS -v conftest.$objext -o libconftest$shared_ext 2>&1 | $GREP "ld"`; rm -f libconftest$shared_ext; list= ; for z in $templist; do case $z in conftest.$objext) list="$list $z";; *.$objext);; *) list="$list $z";;esac; done; func_echo_all "$list"' _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='$wl-rpath,$libdir' _LT_TAGVAR(export_dynamic_flag_spec, $1)='$wl--export-dynamic' # Archives containing C++ object files must be created using # "CC -Bstatic", where "CC" is the KAI C++ compiler. _LT_TAGVAR(old_archive_cmds, $1)='$CC -Bstatic -o $oldlib $oldobjs' ;; icpc* | ecpc* ) # Intel C++ with_gnu_ld=yes # version 8.0 and above of icpc choke on multiply defined symbols # if we add $predep_objects and $postdep_objects, however 7.1 and # earlier do not add the objects themselves. case `$CC -V 2>&1` in *"Version 7."*) _LT_TAGVAR(archive_cmds, $1)='$CC -shared $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags $wl-soname $wl$soname -o $lib' _LT_TAGVAR(archive_expsym_cmds, $1)='$CC -shared $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags $wl-soname $wl$soname $wl-retain-symbols-file $wl$export_symbols -o $lib' ;; *) # Version 8.0 or newer tmp_idyn= case $host_cpu in ia64*) tmp_idyn=' -i_dynamic';; esac _LT_TAGVAR(archive_cmds, $1)='$CC -shared'"$tmp_idyn"' $libobjs $deplibs $compiler_flags $wl-soname $wl$soname -o $lib' _LT_TAGVAR(archive_expsym_cmds, $1)='$CC -shared'"$tmp_idyn"' $libobjs $deplibs $compiler_flags $wl-soname $wl$soname $wl-retain-symbols-file $wl$export_symbols -o $lib' ;; esac _LT_TAGVAR(archive_cmds_need_lc, $1)=no _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='$wl-rpath,$libdir' _LT_TAGVAR(export_dynamic_flag_spec, $1)='$wl--export-dynamic' _LT_TAGVAR(whole_archive_flag_spec, $1)='$wl--whole-archive$convenience $wl--no-whole-archive' ;; pgCC* | pgcpp*) # Portland Group C++ compiler case `$CC -V` in *pgCC\ [[1-5]].* | *pgcpp\ [[1-5]].*) _LT_TAGVAR(prelink_cmds, $1)='tpldir=Template.dir~ rm -rf $tpldir~ $CC --prelink_objects --instantiation_dir $tpldir $objs $libobjs $compile_deplibs~ compile_command="$compile_command `find $tpldir -name \*.o | sort | $NL2SP`"' _LT_TAGVAR(old_archive_cmds, $1)='tpldir=Template.dir~ rm -rf $tpldir~ $CC --prelink_objects --instantiation_dir $tpldir $oldobjs$old_deplibs~ $AR $AR_FLAGS $oldlib$oldobjs$old_deplibs `find $tpldir -name \*.o | sort | $NL2SP`~ $RANLIB $oldlib' _LT_TAGVAR(archive_cmds, $1)='tpldir=Template.dir~ rm -rf $tpldir~ $CC --prelink_objects --instantiation_dir $tpldir $predep_objects $libobjs $deplibs $convenience $postdep_objects~ $CC -shared $pic_flag $predep_objects $libobjs $deplibs `find $tpldir -name \*.o | sort | $NL2SP` $postdep_objects $compiler_flags $wl-soname $wl$soname -o $lib' _LT_TAGVAR(archive_expsym_cmds, $1)='tpldir=Template.dir~ rm -rf $tpldir~ $CC --prelink_objects --instantiation_dir $tpldir $predep_objects $libobjs $deplibs $convenience $postdep_objects~ $CC -shared $pic_flag $predep_objects $libobjs $deplibs `find $tpldir -name \*.o | sort | $NL2SP` $postdep_objects $compiler_flags $wl-soname $wl$soname $wl-retain-symbols-file $wl$export_symbols -o $lib' ;; *) # Version 6 and above use weak symbols _LT_TAGVAR(archive_cmds, $1)='$CC -shared $pic_flag $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags $wl-soname $wl$soname -o $lib' _LT_TAGVAR(archive_expsym_cmds, $1)='$CC -shared $pic_flag $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags $wl-soname $wl$soname $wl-retain-symbols-file $wl$export_symbols -o $lib' ;; esac _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='$wl--rpath $wl$libdir' _LT_TAGVAR(export_dynamic_flag_spec, $1)='$wl--export-dynamic' _LT_TAGVAR(whole_archive_flag_spec, $1)='$wl--whole-archive`for conv in $convenience\"\"; do test -n \"$conv\" && new_convenience=\"$new_convenience,$conv\"; done; func_echo_all \"$new_convenience\"` $wl--no-whole-archive' ;; cxx*) # Compaq C++ _LT_TAGVAR(archive_cmds, $1)='$CC -shared $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags $wl-soname $wl$soname -o $lib' _LT_TAGVAR(archive_expsym_cmds, $1)='$CC -shared $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags $wl-soname $wl$soname -o $lib $wl-retain-symbols-file $wl$export_symbols' runpath_var=LD_RUN_PATH _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='-rpath $libdir' _LT_TAGVAR(hardcode_libdir_separator, $1)=: # Commands to make compiler produce verbose output that lists # what "hidden" libraries, object files and flags are used when # linking a shared library. # # There doesn't appear to be a way to prevent this compiler from # explicitly linking system object files so we need to strip them # from the output so that they don't get included in the library # dependencies. output_verbose_link_cmd='templist=`$CC -shared $CFLAGS -v conftest.$objext 2>&1 | $GREP "ld"`; templist=`func_echo_all "$templist" | $SED "s/\(^.*ld.*\)\( .*ld .*$\)/\1/"`; list= ; for z in $templist; do case $z in conftest.$objext) list="$list $z";; *.$objext);; *) list="$list $z";;esac; done; func_echo_all "X$list" | $Xsed' ;; xl* | mpixl* | bgxl*) # IBM XL 8.0 on PPC, with GNU ld _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='$wl-rpath $wl$libdir' _LT_TAGVAR(export_dynamic_flag_spec, $1)='$wl--export-dynamic' _LT_TAGVAR(archive_cmds, $1)='$CC -qmkshrobj $libobjs $deplibs $compiler_flags $wl-soname $wl$soname -o $lib' if test yes = "$supports_anon_versioning"; then _LT_TAGVAR(archive_expsym_cmds, $1)='echo "{ global:" > $output_objdir/$libname.ver~ cat $export_symbols | sed -e "s/\(.*\)/\1;/" >> $output_objdir/$libname.ver~ echo "local: *; };" >> $output_objdir/$libname.ver~ $CC -qmkshrobj $libobjs $deplibs $compiler_flags $wl-soname $wl$soname $wl-version-script $wl$output_objdir/$libname.ver -o $lib' fi ;; *) case `$CC -V 2>&1 | sed 5q` in *Sun\ C*) # Sun C++ 5.9 _LT_TAGVAR(no_undefined_flag, $1)=' -zdefs' _LT_TAGVAR(archive_cmds, $1)='$CC -G$allow_undefined_flag -h$soname -o $lib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags' _LT_TAGVAR(archive_expsym_cmds, $1)='$CC -G$allow_undefined_flag -h$soname -o $lib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags $wl-retain-symbols-file $wl$export_symbols' _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='-R$libdir' _LT_TAGVAR(whole_archive_flag_spec, $1)='$wl--whole-archive`new_convenience=; for conv in $convenience\"\"; do test -z \"$conv\" || new_convenience=\"$new_convenience,$conv\"; done; func_echo_all \"$new_convenience\"` $wl--no-whole-archive' _LT_TAGVAR(compiler_needs_object, $1)=yes # Not sure whether something based on # $CC $CFLAGS -v conftest.$objext -o libconftest$shared_ext 2>&1 # would be better. output_verbose_link_cmd='func_echo_all' # Archives containing C++ object files must be created using # "CC -xar", where "CC" is the Sun C++ compiler. This is # necessary to make sure instantiated templates are included # in the archive. _LT_TAGVAR(old_archive_cmds, $1)='$CC -xar -o $oldlib $oldobjs' ;; esac ;; esac ;; lynxos*) # FIXME: insert proper C++ library support _LT_TAGVAR(ld_shlibs, $1)=no ;; m88k*) # FIXME: insert proper C++ library support _LT_TAGVAR(ld_shlibs, $1)=no ;; mvs*) case $cc_basename in cxx*) # FIXME: insert proper C++ library support _LT_TAGVAR(ld_shlibs, $1)=no ;; *) # FIXME: insert proper C++ library support _LT_TAGVAR(ld_shlibs, $1)=no ;; esac ;; netbsd*) if echo __ELF__ | $CC -E - | $GREP __ELF__ >/dev/null; then _LT_TAGVAR(archive_cmds, $1)='$LD -Bshareable -o $lib $predep_objects $libobjs $deplibs $postdep_objects $linker_flags' wlarc= _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='-R$libdir' _LT_TAGVAR(hardcode_direct, $1)=yes _LT_TAGVAR(hardcode_shlibpath_var, $1)=no fi # Workaround some broken pre-1.5 toolchains output_verbose_link_cmd='$CC -shared $CFLAGS -v conftest.$objext 2>&1 | $GREP conftest.$objext | $SED -e "s:-lgcc -lc -lgcc::"' ;; *nto* | *qnx*) _LT_TAGVAR(ld_shlibs, $1)=yes ;; openbsd* | bitrig*) if test -f /usr/libexec/ld.so; then _LT_TAGVAR(hardcode_direct, $1)=yes _LT_TAGVAR(hardcode_shlibpath_var, $1)=no _LT_TAGVAR(hardcode_direct_absolute, $1)=yes _LT_TAGVAR(archive_cmds, $1)='$CC -shared $pic_flag $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags -o $lib' _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='$wl-rpath,$libdir' if test -z "`echo __ELF__ | $CC -E - | grep __ELF__`"; then _LT_TAGVAR(archive_expsym_cmds, $1)='$CC -shared $pic_flag $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags $wl-retain-symbols-file,$export_symbols -o $lib' _LT_TAGVAR(export_dynamic_flag_spec, $1)='$wl-E' _LT_TAGVAR(whole_archive_flag_spec, $1)=$wlarc'--whole-archive$convenience '$wlarc'--no-whole-archive' fi output_verbose_link_cmd=func_echo_all else _LT_TAGVAR(ld_shlibs, $1)=no fi ;; osf3* | osf4* | osf5*) case $cc_basename in KCC*) # Kuck and Associates, Inc. (KAI) C++ Compiler # KCC will only create a shared library if the output file # ends with ".so" (or ".sl" for HP-UX), so rename the library # to its proper name (with version) after linking. _LT_TAGVAR(archive_cmds, $1)='tempext=`echo $shared_ext | $SED -e '\''s/\([[^()0-9A-Za-z{}]]\)/\\\\\1/g'\''`; templib=`echo "$lib" | $SED -e "s/\$tempext\..*/.so/"`; $CC $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags --soname $soname -o \$templib; mv \$templib $lib' _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='$wl-rpath,$libdir' _LT_TAGVAR(hardcode_libdir_separator, $1)=: # Archives containing C++ object files must be created using # the KAI C++ compiler. case $host in osf3*) _LT_TAGVAR(old_archive_cmds, $1)='$CC -Bstatic -o $oldlib $oldobjs' ;; *) _LT_TAGVAR(old_archive_cmds, $1)='$CC -o $oldlib $oldobjs' ;; esac ;; RCC*) # Rational C++ 2.4.1 # FIXME: insert proper C++ library support _LT_TAGVAR(ld_shlibs, $1)=no ;; cxx*) case $host in osf3*) _LT_TAGVAR(allow_undefined_flag, $1)=' $wl-expect_unresolved $wl\*' _LT_TAGVAR(archive_cmds, $1)='$CC -shared$allow_undefined_flag $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags $wl-soname $soname `test -n "$verstring" && func_echo_all "$wl-set_version $verstring"` -update_registry $output_objdir/so_locations -o $lib' _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='$wl-rpath $wl$libdir' ;; *) _LT_TAGVAR(allow_undefined_flag, $1)=' -expect_unresolved \*' _LT_TAGVAR(archive_cmds, $1)='$CC -shared$allow_undefined_flag $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags -msym -soname $soname `test -n "$verstring" && func_echo_all "-set_version $verstring"` -update_registry $output_objdir/so_locations -o $lib' _LT_TAGVAR(archive_expsym_cmds, $1)='for i in `cat $export_symbols`; do printf "%s %s\\n" -exported_symbol "\$i" >> $lib.exp; done~ echo "-hidden">> $lib.exp~ $CC -shared$allow_undefined_flag $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags -msym -soname $soname $wl-input $wl$lib.exp `test -n "$verstring" && $ECHO "-set_version $verstring"` -update_registry $output_objdir/so_locations -o $lib~ $RM $lib.exp' _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='-rpath $libdir' ;; esac _LT_TAGVAR(hardcode_libdir_separator, $1)=: # Commands to make compiler produce verbose output that lists # what "hidden" libraries, object files and flags are used when # linking a shared library. # # There doesn't appear to be a way to prevent this compiler from # explicitly linking system object files so we need to strip them # from the output so that they don't get included in the library # dependencies. output_verbose_link_cmd='templist=`$CC -shared $CFLAGS -v conftest.$objext 2>&1 | $GREP "ld" | $GREP -v "ld:"`; templist=`func_echo_all "$templist" | $SED "s/\(^.*ld.*\)\( .*ld.*$\)/\1/"`; list= ; for z in $templist; do case $z in conftest.$objext) list="$list $z";; *.$objext);; *) list="$list $z";;esac; done; func_echo_all "$list"' ;; *) if test yes,no = "$GXX,$with_gnu_ld"; then _LT_TAGVAR(allow_undefined_flag, $1)=' $wl-expect_unresolved $wl\*' case $host in osf3*) _LT_TAGVAR(archive_cmds, $1)='$CC -shared -nostdlib $allow_undefined_flag $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags $wl-soname $wl$soname `test -n "$verstring" && func_echo_all "$wl-set_version $wl$verstring"` $wl-update_registry $wl$output_objdir/so_locations -o $lib' ;; *) _LT_TAGVAR(archive_cmds, $1)='$CC -shared $pic_flag -nostdlib $allow_undefined_flag $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags $wl-msym $wl-soname $wl$soname `test -n "$verstring" && func_echo_all "$wl-set_version $wl$verstring"` $wl-update_registry $wl$output_objdir/so_locations -o $lib' ;; esac _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='$wl-rpath $wl$libdir' _LT_TAGVAR(hardcode_libdir_separator, $1)=: # Commands to make compiler produce verbose output that lists # what "hidden" libraries, object files and flags are used when # linking a shared library. output_verbose_link_cmd='$CC -shared $CFLAGS -v conftest.$objext 2>&1 | $GREP -v "^Configured with:" | $GREP "\-L"' else # FIXME: insert proper C++ library support _LT_TAGVAR(ld_shlibs, $1)=no fi ;; esac ;; psos*) # FIXME: insert proper C++ library support _LT_TAGVAR(ld_shlibs, $1)=no ;; sunos4*) case $cc_basename in CC*) # Sun C++ 4.x # FIXME: insert proper C++ library support _LT_TAGVAR(ld_shlibs, $1)=no ;; lcc*) # Lucid # FIXME: insert proper C++ library support _LT_TAGVAR(ld_shlibs, $1)=no ;; *) # FIXME: insert proper C++ library support _LT_TAGVAR(ld_shlibs, $1)=no ;; esac ;; solaris*) case $cc_basename in CC* | sunCC*) # Sun C++ 4.2, 5.x and Centerline C++ _LT_TAGVAR(archive_cmds_need_lc,$1)=yes _LT_TAGVAR(no_undefined_flag, $1)=' -zdefs' _LT_TAGVAR(archive_cmds, $1)='$CC -G$allow_undefined_flag -h$soname -o $lib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags' _LT_TAGVAR(archive_expsym_cmds, $1)='echo "{ global:" > $lib.exp~cat $export_symbols | $SED -e "s/\(.*\)/\1;/" >> $lib.exp~echo "local: *; };" >> $lib.exp~ $CC -G$allow_undefined_flag $wl-M $wl$lib.exp -h$soname -o $lib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags~$RM $lib.exp' _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='-R$libdir' _LT_TAGVAR(hardcode_shlibpath_var, $1)=no case $host_os in solaris2.[[0-5]] | solaris2.[[0-5]].*) ;; *) # The compiler driver will combine and reorder linker options, # but understands '-z linker_flag'. # Supported since Solaris 2.6 (maybe 2.5.1?) _LT_TAGVAR(whole_archive_flag_spec, $1)='-z allextract$convenience -z defaultextract' ;; esac _LT_TAGVAR(link_all_deplibs, $1)=yes output_verbose_link_cmd='func_echo_all' # Archives containing C++ object files must be created using # "CC -xar", where "CC" is the Sun C++ compiler. This is # necessary to make sure instantiated templates are included # in the archive. _LT_TAGVAR(old_archive_cmds, $1)='$CC -xar -o $oldlib $oldobjs' ;; gcx*) # Green Hills C++ Compiler _LT_TAGVAR(archive_cmds, $1)='$CC -shared $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags $wl-h $wl$soname -o $lib' # The C++ compiler must be used to create the archive. _LT_TAGVAR(old_archive_cmds, $1)='$CC $LDFLAGS -archive -o $oldlib $oldobjs' ;; *) # GNU C++ compiler with Solaris linker if test yes,no = "$GXX,$with_gnu_ld"; then _LT_TAGVAR(no_undefined_flag, $1)=' $wl-z ${wl}defs' if $CC --version | $GREP -v '^2\.7' > /dev/null; then _LT_TAGVAR(archive_cmds, $1)='$CC -shared $pic_flag -nostdlib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags $wl-h $wl$soname -o $lib' _LT_TAGVAR(archive_expsym_cmds, $1)='echo "{ global:" > $lib.exp~cat $export_symbols | $SED -e "s/\(.*\)/\1;/" >> $lib.exp~echo "local: *; };" >> $lib.exp~ $CC -shared $pic_flag -nostdlib $wl-M $wl$lib.exp $wl-h $wl$soname -o $lib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags~$RM $lib.exp' # Commands to make compiler produce verbose output that lists # what "hidden" libraries, object files and flags are used when # linking a shared library. output_verbose_link_cmd='$CC -shared $CFLAGS -v conftest.$objext 2>&1 | $GREP -v "^Configured with:" | $GREP "\-L"' else # g++ 2.7 appears to require '-G' NOT '-shared' on this # platform. _LT_TAGVAR(archive_cmds, $1)='$CC -G -nostdlib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags $wl-h $wl$soname -o $lib' _LT_TAGVAR(archive_expsym_cmds, $1)='echo "{ global:" > $lib.exp~cat $export_symbols | $SED -e "s/\(.*\)/\1;/" >> $lib.exp~echo "local: *; };" >> $lib.exp~ $CC -G -nostdlib $wl-M $wl$lib.exp $wl-h $wl$soname -o $lib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags~$RM $lib.exp' # Commands to make compiler produce verbose output that lists # what "hidden" libraries, object files and flags are used when # linking a shared library. output_verbose_link_cmd='$CC -G $CFLAGS -v conftest.$objext 2>&1 | $GREP -v "^Configured with:" | $GREP "\-L"' fi _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='$wl-R $wl$libdir' case $host_os in solaris2.[[0-5]] | solaris2.[[0-5]].*) ;; *) _LT_TAGVAR(whole_archive_flag_spec, $1)='$wl-z ${wl}allextract$convenience $wl-z ${wl}defaultextract' ;; esac fi ;; esac ;; sysv4*uw2* | sysv5OpenUNIX* | sysv5UnixWare7.[[01]].[[10]]* | unixware7* | sco3.2v5.0.[[024]]*) _LT_TAGVAR(no_undefined_flag, $1)='$wl-z,text' _LT_TAGVAR(archive_cmds_need_lc, $1)=no _LT_TAGVAR(hardcode_shlibpath_var, $1)=no runpath_var='LD_RUN_PATH' case $cc_basename in CC*) _LT_TAGVAR(archive_cmds, $1)='$CC -G $wl-h,$soname -o $lib $libobjs $deplibs $compiler_flags' _LT_TAGVAR(archive_expsym_cmds, $1)='$CC -G $wl-Bexport:$export_symbols $wl-h,$soname -o $lib $libobjs $deplibs $compiler_flags' ;; *) _LT_TAGVAR(archive_cmds, $1)='$CC -shared $wl-h,$soname -o $lib $libobjs $deplibs $compiler_flags' _LT_TAGVAR(archive_expsym_cmds, $1)='$CC -shared $wl-Bexport:$export_symbols $wl-h,$soname -o $lib $libobjs $deplibs $compiler_flags' ;; esac ;; sysv5* | sco3.2v5* | sco5v6*) # Note: We CANNOT use -z defs as we might desire, because we do not # link with -lc, and that would cause any symbols used from libc to # always be unresolved, which means just about no library would # ever link correctly. If we're not using GNU ld we use -z text # though, which does catch some bad symbols but isn't as heavy-handed # as -z defs. _LT_TAGVAR(no_undefined_flag, $1)='$wl-z,text' _LT_TAGVAR(allow_undefined_flag, $1)='$wl-z,nodefs' _LT_TAGVAR(archive_cmds_need_lc, $1)=no _LT_TAGVAR(hardcode_shlibpath_var, $1)=no _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='$wl-R,$libdir' _LT_TAGVAR(hardcode_libdir_separator, $1)=':' _LT_TAGVAR(link_all_deplibs, $1)=yes _LT_TAGVAR(export_dynamic_flag_spec, $1)='$wl-Bexport' runpath_var='LD_RUN_PATH' case $cc_basename in CC*) _LT_TAGVAR(archive_cmds, $1)='$CC -G $wl-h,$soname -o $lib $libobjs $deplibs $compiler_flags' _LT_TAGVAR(archive_expsym_cmds, $1)='$CC -G $wl-Bexport:$export_symbols $wl-h,$soname -o $lib $libobjs $deplibs $compiler_flags' _LT_TAGVAR(old_archive_cmds, $1)='$CC -Tprelink_objects $oldobjs~ '"$_LT_TAGVAR(old_archive_cmds, $1)" _LT_TAGVAR(reload_cmds, $1)='$CC -Tprelink_objects $reload_objs~ '"$_LT_TAGVAR(reload_cmds, $1)" ;; *) _LT_TAGVAR(archive_cmds, $1)='$CC -shared $wl-h,$soname -o $lib $libobjs $deplibs $compiler_flags' _LT_TAGVAR(archive_expsym_cmds, $1)='$CC -shared $wl-Bexport:$export_symbols $wl-h,$soname -o $lib $libobjs $deplibs $compiler_flags' ;; esac ;; tandem*) case $cc_basename in NCC*) # NonStop-UX NCC 3.20 # FIXME: insert proper C++ library support _LT_TAGVAR(ld_shlibs, $1)=no ;; *) # FIXME: insert proper C++ library support _LT_TAGVAR(ld_shlibs, $1)=no ;; esac ;; vxworks*) # FIXME: insert proper C++ library support _LT_TAGVAR(ld_shlibs, $1)=no ;; *) # FIXME: insert proper C++ library support _LT_TAGVAR(ld_shlibs, $1)=no ;; esac AC_MSG_RESULT([$_LT_TAGVAR(ld_shlibs, $1)]) test no = "$_LT_TAGVAR(ld_shlibs, $1)" && can_build_shared=no _LT_TAGVAR(GCC, $1)=$GXX _LT_TAGVAR(LD, $1)=$LD ## CAVEAT EMPTOR: ## There is no encapsulation within the following macros, do not change ## the running order or otherwise move them around unless you know exactly ## what you are doing... _LT_SYS_HIDDEN_LIBDEPS($1) _LT_COMPILER_PIC($1) _LT_COMPILER_C_O($1) _LT_COMPILER_FILE_LOCKS($1) _LT_LINKER_SHLIBS($1) _LT_SYS_DYNAMIC_LINKER($1) _LT_LINKER_HARDCODE_LIBPATH($1) _LT_CONFIG($1) fi # test -n "$compiler" CC=$lt_save_CC CFLAGS=$lt_save_CFLAGS LDCXX=$LD LD=$lt_save_LD GCC=$lt_save_GCC with_gnu_ld=$lt_save_with_gnu_ld lt_cv_path_LDCXX=$lt_cv_path_LD lt_cv_path_LD=$lt_save_path_LD lt_cv_prog_gnu_ldcxx=$lt_cv_prog_gnu_ld lt_cv_prog_gnu_ld=$lt_save_with_gnu_ld fi # test yes != "$_lt_caught_CXX_error" AC_LANG_POP ])# _LT_LANG_CXX_CONFIG # _LT_FUNC_STRIPNAME_CNF # ---------------------- # func_stripname_cnf prefix suffix name # strip PREFIX and SUFFIX off of NAME. # PREFIX and SUFFIX must not contain globbing or regex special # characters, hashes, percent signs, but SUFFIX may contain a leading # dot (in which case that matches only a dot). # # This function is identical to the (non-XSI) version of func_stripname, # except this one can be used by m4 code that may be executed by configure, # rather than the libtool script. m4_defun([_LT_FUNC_STRIPNAME_CNF],[dnl AC_REQUIRE([_LT_DECL_SED]) AC_REQUIRE([_LT_PROG_ECHO_BACKSLASH]) func_stripname_cnf () { case @S|@2 in .*) func_stripname_result=`$ECHO "@S|@3" | $SED "s%^@S|@1%%; s%\\\\@S|@2\$%%"`;; *) func_stripname_result=`$ECHO "@S|@3" | $SED "s%^@S|@1%%; s%@S|@2\$%%"`;; esac } # func_stripname_cnf ])# _LT_FUNC_STRIPNAME_CNF # _LT_SYS_HIDDEN_LIBDEPS([TAGNAME]) # --------------------------------- # Figure out "hidden" library dependencies from verbose # compiler output when linking a shared library. # Parse the compiler output and extract the necessary # objects, libraries and library flags. m4_defun([_LT_SYS_HIDDEN_LIBDEPS], [m4_require([_LT_FILEUTILS_DEFAULTS])dnl AC_REQUIRE([_LT_FUNC_STRIPNAME_CNF])dnl # Dependencies to place before and after the object being linked: _LT_TAGVAR(predep_objects, $1)= _LT_TAGVAR(postdep_objects, $1)= _LT_TAGVAR(predeps, $1)= _LT_TAGVAR(postdeps, $1)= _LT_TAGVAR(compiler_lib_search_path, $1)= dnl we can't use the lt_simple_compile_test_code here, dnl because it contains code intended for an executable, dnl not a library. It's possible we should let each dnl tag define a new lt_????_link_test_code variable, dnl but it's only used here... m4_if([$1], [], [cat > conftest.$ac_ext <<_LT_EOF int a; void foo (void) { a = 0; } _LT_EOF ], [$1], [CXX], [cat > conftest.$ac_ext <<_LT_EOF class Foo { public: Foo (void) { a = 0; } private: int a; }; _LT_EOF ], [$1], [F77], [cat > conftest.$ac_ext <<_LT_EOF subroutine foo implicit none integer*4 a a=0 return end _LT_EOF ], [$1], [FC], [cat > conftest.$ac_ext <<_LT_EOF subroutine foo implicit none integer a a=0 return end _LT_EOF ], [$1], [GCJ], [cat > conftest.$ac_ext <<_LT_EOF public class foo { private int a; public void bar (void) { a = 0; } }; _LT_EOF ], [$1], [GO], [cat > conftest.$ac_ext <<_LT_EOF package foo func foo() { } _LT_EOF ]) _lt_libdeps_save_CFLAGS=$CFLAGS case "$CC $CFLAGS " in #( *\ -flto*\ *) CFLAGS="$CFLAGS -fno-lto" ;; *\ -fwhopr*\ *) CFLAGS="$CFLAGS -fno-whopr" ;; *\ -fuse-linker-plugin*\ *) CFLAGS="$CFLAGS -fno-use-linker-plugin" ;; esac dnl Parse the compiler output and extract the necessary dnl objects, libraries and library flags. if AC_TRY_EVAL(ac_compile); then # Parse the compiler output and extract the necessary # objects, libraries and library flags. # Sentinel used to keep track of whether or not we are before # the conftest object file. pre_test_object_deps_done=no for p in `eval "$output_verbose_link_cmd"`; do case $prev$p in -L* | -R* | -l*) # Some compilers place space between "-{L,R}" and the path. # Remove the space. if test x-L = "$p" || test x-R = "$p"; then prev=$p continue fi # Expand the sysroot to ease extracting the directories later. if test -z "$prev"; then case $p in -L*) func_stripname_cnf '-L' '' "$p"; prev=-L; p=$func_stripname_result ;; -R*) func_stripname_cnf '-R' '' "$p"; prev=-R; p=$func_stripname_result ;; -l*) func_stripname_cnf '-l' '' "$p"; prev=-l; p=$func_stripname_result ;; esac fi case $p in =*) func_stripname_cnf '=' '' "$p"; p=$lt_sysroot$func_stripname_result ;; esac if test no = "$pre_test_object_deps_done"; then case $prev in -L | -R) # Internal compiler library paths should come after those # provided the user. The postdeps already come after the # user supplied libs so there is no need to process them. if test -z "$_LT_TAGVAR(compiler_lib_search_path, $1)"; then _LT_TAGVAR(compiler_lib_search_path, $1)=$prev$p else _LT_TAGVAR(compiler_lib_search_path, $1)="${_LT_TAGVAR(compiler_lib_search_path, $1)} $prev$p" fi ;; # The "-l" case would never come before the object being # linked, so don't bother handling this case. esac else if test -z "$_LT_TAGVAR(postdeps, $1)"; then _LT_TAGVAR(postdeps, $1)=$prev$p else _LT_TAGVAR(postdeps, $1)="${_LT_TAGVAR(postdeps, $1)} $prev$p" fi fi prev= ;; *.lto.$objext) ;; # Ignore GCC LTO objects *.$objext) # This assumes that the test object file only shows up # once in the compiler output. if test "$p" = "conftest.$objext"; then pre_test_object_deps_done=yes continue fi if test no = "$pre_test_object_deps_done"; then if test -z "$_LT_TAGVAR(predep_objects, $1)"; then _LT_TAGVAR(predep_objects, $1)=$p else _LT_TAGVAR(predep_objects, $1)="$_LT_TAGVAR(predep_objects, $1) $p" fi else if test -z "$_LT_TAGVAR(postdep_objects, $1)"; then _LT_TAGVAR(postdep_objects, $1)=$p else _LT_TAGVAR(postdep_objects, $1)="$_LT_TAGVAR(postdep_objects, $1) $p" fi fi ;; *) ;; # Ignore the rest. esac done # Clean up. rm -f a.out a.exe else echo "libtool.m4: error: problem compiling $1 test program" fi $RM -f confest.$objext CFLAGS=$_lt_libdeps_save_CFLAGS # PORTME: override above test on systems where it is broken m4_if([$1], [CXX], [case $host_os in interix[[3-9]]*) # Interix 3.5 installs completely hosed .la files for C++, so rather than # hack all around it, let's just trust "g++" to DTRT. _LT_TAGVAR(predep_objects,$1)= _LT_TAGVAR(postdep_objects,$1)= _LT_TAGVAR(postdeps,$1)= ;; esac ]) case " $_LT_TAGVAR(postdeps, $1) " in *" -lc "*) _LT_TAGVAR(archive_cmds_need_lc, $1)=no ;; esac _LT_TAGVAR(compiler_lib_search_dirs, $1)= if test -n "${_LT_TAGVAR(compiler_lib_search_path, $1)}"; then _LT_TAGVAR(compiler_lib_search_dirs, $1)=`echo " ${_LT_TAGVAR(compiler_lib_search_path, $1)}" | $SED -e 's! -L! !g' -e 's!^ !!'` fi _LT_TAGDECL([], [compiler_lib_search_dirs], [1], [The directories searched by this compiler when creating a shared library]) _LT_TAGDECL([], [predep_objects], [1], [Dependencies to place before and after the objects being linked to create a shared library]) _LT_TAGDECL([], [postdep_objects], [1]) _LT_TAGDECL([], [predeps], [1]) _LT_TAGDECL([], [postdeps], [1]) _LT_TAGDECL([], [compiler_lib_search_path], [1], [The library search path used internally by the compiler when linking a shared library]) ])# _LT_SYS_HIDDEN_LIBDEPS # _LT_LANG_F77_CONFIG([TAG]) # -------------------------- # Ensure that the configuration variables for a Fortran 77 compiler are # suitably defined. These variables are subsequently used by _LT_CONFIG # to write the compiler configuration to 'libtool'. m4_defun([_LT_LANG_F77_CONFIG], [AC_LANG_PUSH(Fortran 77) if test -z "$F77" || test no = "$F77"; then _lt_disable_F77=yes fi _LT_TAGVAR(archive_cmds_need_lc, $1)=no _LT_TAGVAR(allow_undefined_flag, $1)= _LT_TAGVAR(always_export_symbols, $1)=no _LT_TAGVAR(archive_expsym_cmds, $1)= _LT_TAGVAR(export_dynamic_flag_spec, $1)= _LT_TAGVAR(hardcode_direct, $1)=no _LT_TAGVAR(hardcode_direct_absolute, $1)=no _LT_TAGVAR(hardcode_libdir_flag_spec, $1)= _LT_TAGVAR(hardcode_libdir_separator, $1)= _LT_TAGVAR(hardcode_minus_L, $1)=no _LT_TAGVAR(hardcode_automatic, $1)=no _LT_TAGVAR(inherit_rpath, $1)=no _LT_TAGVAR(module_cmds, $1)= _LT_TAGVAR(module_expsym_cmds, $1)= _LT_TAGVAR(link_all_deplibs, $1)=unknown _LT_TAGVAR(old_archive_cmds, $1)=$old_archive_cmds _LT_TAGVAR(reload_flag, $1)=$reload_flag _LT_TAGVAR(reload_cmds, $1)=$reload_cmds _LT_TAGVAR(no_undefined_flag, $1)= _LT_TAGVAR(whole_archive_flag_spec, $1)= _LT_TAGVAR(enable_shared_with_static_runtimes, $1)=no # Source file extension for f77 test sources. ac_ext=f # Object file extension for compiled f77 test sources. objext=o _LT_TAGVAR(objext, $1)=$objext # No sense in running all these tests if we already determined that # the F77 compiler isn't working. Some variables (like enable_shared) # are currently assumed to apply to all compilers on this platform, # and will be corrupted by setting them based on a non-working compiler. if test yes != "$_lt_disable_F77"; then # Code to be used in simple compile tests lt_simple_compile_test_code="\ subroutine t return end " # Code to be used in simple link tests lt_simple_link_test_code="\ program t end " # ltmain only uses $CC for tagged configurations so make sure $CC is set. _LT_TAG_COMPILER # save warnings/boilerplate of simple test code _LT_COMPILER_BOILERPLATE _LT_LINKER_BOILERPLATE # Allow CC to be a program name with arguments. lt_save_CC=$CC lt_save_GCC=$GCC lt_save_CFLAGS=$CFLAGS CC=${F77-"f77"} CFLAGS=$FFLAGS compiler=$CC _LT_TAGVAR(compiler, $1)=$CC _LT_CC_BASENAME([$compiler]) GCC=$G77 if test -n "$compiler"; then AC_MSG_CHECKING([if libtool supports shared libraries]) AC_MSG_RESULT([$can_build_shared]) AC_MSG_CHECKING([whether to build shared libraries]) test no = "$can_build_shared" && enable_shared=no # On AIX, shared libraries and static libraries use the same namespace, and # are all built from PIC. case $host_os in aix3*) test yes = "$enable_shared" && enable_static=no if test -n "$RANLIB"; then archive_cmds="$archive_cmds~\$RANLIB \$lib" postinstall_cmds='$RANLIB $lib' fi ;; aix[[4-9]]*) if test ia64 != "$host_cpu"; then case $enable_shared,$with_aix_soname,$aix_use_runtimelinking in yes,aix,yes) ;; # shared object as lib.so file only yes,svr4,*) ;; # shared object as lib.so archive member only yes,*) enable_static=no ;; # shared object in lib.a archive as well esac fi ;; esac AC_MSG_RESULT([$enable_shared]) AC_MSG_CHECKING([whether to build static libraries]) # Make sure either enable_shared or enable_static is yes. test yes = "$enable_shared" || enable_static=yes AC_MSG_RESULT([$enable_static]) _LT_TAGVAR(GCC, $1)=$G77 _LT_TAGVAR(LD, $1)=$LD ## CAVEAT EMPTOR: ## There is no encapsulation within the following macros, do not change ## the running order or otherwise move them around unless you know exactly ## what you are doing... _LT_COMPILER_PIC($1) _LT_COMPILER_C_O($1) _LT_COMPILER_FILE_LOCKS($1) _LT_LINKER_SHLIBS($1) _LT_SYS_DYNAMIC_LINKER($1) _LT_LINKER_HARDCODE_LIBPATH($1) _LT_CONFIG($1) fi # test -n "$compiler" GCC=$lt_save_GCC CC=$lt_save_CC CFLAGS=$lt_save_CFLAGS fi # test yes != "$_lt_disable_F77" AC_LANG_POP ])# _LT_LANG_F77_CONFIG # _LT_LANG_FC_CONFIG([TAG]) # ------------------------- # Ensure that the configuration variables for a Fortran compiler are # suitably defined. These variables are subsequently used by _LT_CONFIG # to write the compiler configuration to 'libtool'. m4_defun([_LT_LANG_FC_CONFIG], [AC_LANG_PUSH(Fortran) if test -z "$FC" || test no = "$FC"; then _lt_disable_FC=yes fi _LT_TAGVAR(archive_cmds_need_lc, $1)=no _LT_TAGVAR(allow_undefined_flag, $1)= _LT_TAGVAR(always_export_symbols, $1)=no _LT_TAGVAR(archive_expsym_cmds, $1)= _LT_TAGVAR(export_dynamic_flag_spec, $1)= _LT_TAGVAR(hardcode_direct, $1)=no _LT_TAGVAR(hardcode_direct_absolute, $1)=no _LT_TAGVAR(hardcode_libdir_flag_spec, $1)= _LT_TAGVAR(hardcode_libdir_separator, $1)= _LT_TAGVAR(hardcode_minus_L, $1)=no _LT_TAGVAR(hardcode_automatic, $1)=no _LT_TAGVAR(inherit_rpath, $1)=no _LT_TAGVAR(module_cmds, $1)= _LT_TAGVAR(module_expsym_cmds, $1)= _LT_TAGVAR(link_all_deplibs, $1)=unknown _LT_TAGVAR(old_archive_cmds, $1)=$old_archive_cmds _LT_TAGVAR(reload_flag, $1)=$reload_flag _LT_TAGVAR(reload_cmds, $1)=$reload_cmds _LT_TAGVAR(no_undefined_flag, $1)= _LT_TAGVAR(whole_archive_flag_spec, $1)= _LT_TAGVAR(enable_shared_with_static_runtimes, $1)=no # Source file extension for fc test sources. ac_ext=${ac_fc_srcext-f} # Object file extension for compiled fc test sources. objext=o _LT_TAGVAR(objext, $1)=$objext # No sense in running all these tests if we already determined that # the FC compiler isn't working. Some variables (like enable_shared) # are currently assumed to apply to all compilers on this platform, # and will be corrupted by setting them based on a non-working compiler. if test yes != "$_lt_disable_FC"; then # Code to be used in simple compile tests lt_simple_compile_test_code="\ subroutine t return end " # Code to be used in simple link tests lt_simple_link_test_code="\ program t end " # ltmain only uses $CC for tagged configurations so make sure $CC is set. _LT_TAG_COMPILER # save warnings/boilerplate of simple test code _LT_COMPILER_BOILERPLATE _LT_LINKER_BOILERPLATE # Allow CC to be a program name with arguments. lt_save_CC=$CC lt_save_GCC=$GCC lt_save_CFLAGS=$CFLAGS CC=${FC-"f95"} CFLAGS=$FCFLAGS compiler=$CC GCC=$ac_cv_fc_compiler_gnu _LT_TAGVAR(compiler, $1)=$CC _LT_CC_BASENAME([$compiler]) if test -n "$compiler"; then AC_MSG_CHECKING([if libtool supports shared libraries]) AC_MSG_RESULT([$can_build_shared]) AC_MSG_CHECKING([whether to build shared libraries]) test no = "$can_build_shared" && enable_shared=no # On AIX, shared libraries and static libraries use the same namespace, and # are all built from PIC. case $host_os in aix3*) test yes = "$enable_shared" && enable_static=no if test -n "$RANLIB"; then archive_cmds="$archive_cmds~\$RANLIB \$lib" postinstall_cmds='$RANLIB $lib' fi ;; aix[[4-9]]*) if test ia64 != "$host_cpu"; then case $enable_shared,$with_aix_soname,$aix_use_runtimelinking in yes,aix,yes) ;; # shared object as lib.so file only yes,svr4,*) ;; # shared object as lib.so archive member only yes,*) enable_static=no ;; # shared object in lib.a archive as well esac fi ;; esac AC_MSG_RESULT([$enable_shared]) AC_MSG_CHECKING([whether to build static libraries]) # Make sure either enable_shared or enable_static is yes. test yes = "$enable_shared" || enable_static=yes AC_MSG_RESULT([$enable_static]) _LT_TAGVAR(GCC, $1)=$ac_cv_fc_compiler_gnu _LT_TAGVAR(LD, $1)=$LD ## CAVEAT EMPTOR: ## There is no encapsulation within the following macros, do not change ## the running order or otherwise move them around unless you know exactly ## what you are doing... _LT_SYS_HIDDEN_LIBDEPS($1) _LT_COMPILER_PIC($1) _LT_COMPILER_C_O($1) _LT_COMPILER_FILE_LOCKS($1) _LT_LINKER_SHLIBS($1) _LT_SYS_DYNAMIC_LINKER($1) _LT_LINKER_HARDCODE_LIBPATH($1) _LT_CONFIG($1) fi # test -n "$compiler" GCC=$lt_save_GCC CC=$lt_save_CC CFLAGS=$lt_save_CFLAGS fi # test yes != "$_lt_disable_FC" AC_LANG_POP ])# _LT_LANG_FC_CONFIG # _LT_LANG_GCJ_CONFIG([TAG]) # -------------------------- # Ensure that the configuration variables for the GNU Java Compiler compiler # are suitably defined. These variables are subsequently used by _LT_CONFIG # to write the compiler configuration to 'libtool'. m4_defun([_LT_LANG_GCJ_CONFIG], [AC_REQUIRE([LT_PROG_GCJ])dnl AC_LANG_SAVE # Source file extension for Java test sources. ac_ext=java # Object file extension for compiled Java test sources. objext=o _LT_TAGVAR(objext, $1)=$objext # Code to be used in simple compile tests lt_simple_compile_test_code="class foo {}" # Code to be used in simple link tests lt_simple_link_test_code='public class conftest { public static void main(String[[]] argv) {}; }' # ltmain only uses $CC for tagged configurations so make sure $CC is set. _LT_TAG_COMPILER # save warnings/boilerplate of simple test code _LT_COMPILER_BOILERPLATE _LT_LINKER_BOILERPLATE # Allow CC to be a program name with arguments. lt_save_CC=$CC lt_save_CFLAGS=$CFLAGS lt_save_GCC=$GCC GCC=yes CC=${GCJ-"gcj"} CFLAGS=$GCJFLAGS compiler=$CC _LT_TAGVAR(compiler, $1)=$CC _LT_TAGVAR(LD, $1)=$LD _LT_CC_BASENAME([$compiler]) # GCJ did not exist at the time GCC didn't implicitly link libc in. _LT_TAGVAR(archive_cmds_need_lc, $1)=no _LT_TAGVAR(old_archive_cmds, $1)=$old_archive_cmds _LT_TAGVAR(reload_flag, $1)=$reload_flag _LT_TAGVAR(reload_cmds, $1)=$reload_cmds ## CAVEAT EMPTOR: ## There is no encapsulation within the following macros, do not change ## the running order or otherwise move them around unless you know exactly ## what you are doing... if test -n "$compiler"; then _LT_COMPILER_NO_RTTI($1) _LT_COMPILER_PIC($1) _LT_COMPILER_C_O($1) _LT_COMPILER_FILE_LOCKS($1) _LT_LINKER_SHLIBS($1) _LT_LINKER_HARDCODE_LIBPATH($1) _LT_CONFIG($1) fi AC_LANG_RESTORE GCC=$lt_save_GCC CC=$lt_save_CC CFLAGS=$lt_save_CFLAGS ])# _LT_LANG_GCJ_CONFIG # _LT_LANG_GO_CONFIG([TAG]) # -------------------------- # Ensure that the configuration variables for the GNU Go compiler # are suitably defined. These variables are subsequently used by _LT_CONFIG # to write the compiler configuration to 'libtool'. m4_defun([_LT_LANG_GO_CONFIG], [AC_REQUIRE([LT_PROG_GO])dnl AC_LANG_SAVE # Source file extension for Go test sources. ac_ext=go # Object file extension for compiled Go test sources. objext=o _LT_TAGVAR(objext, $1)=$objext # Code to be used in simple compile tests lt_simple_compile_test_code="package main; func main() { }" # Code to be used in simple link tests lt_simple_link_test_code='package main; func main() { }' # ltmain only uses $CC for tagged configurations so make sure $CC is set. _LT_TAG_COMPILER # save warnings/boilerplate of simple test code _LT_COMPILER_BOILERPLATE _LT_LINKER_BOILERPLATE # Allow CC to be a program name with arguments. lt_save_CC=$CC lt_save_CFLAGS=$CFLAGS lt_save_GCC=$GCC GCC=yes CC=${GOC-"gccgo"} CFLAGS=$GOFLAGS compiler=$CC _LT_TAGVAR(compiler, $1)=$CC _LT_TAGVAR(LD, $1)=$LD _LT_CC_BASENAME([$compiler]) # Go did not exist at the time GCC didn't implicitly link libc in. _LT_TAGVAR(archive_cmds_need_lc, $1)=no _LT_TAGVAR(old_archive_cmds, $1)=$old_archive_cmds _LT_TAGVAR(reload_flag, $1)=$reload_flag _LT_TAGVAR(reload_cmds, $1)=$reload_cmds ## CAVEAT EMPTOR: ## There is no encapsulation within the following macros, do not change ## the running order or otherwise move them around unless you know exactly ## what you are doing... if test -n "$compiler"; then _LT_COMPILER_NO_RTTI($1) _LT_COMPILER_PIC($1) _LT_COMPILER_C_O($1) _LT_COMPILER_FILE_LOCKS($1) _LT_LINKER_SHLIBS($1) _LT_LINKER_HARDCODE_LIBPATH($1) _LT_CONFIG($1) fi AC_LANG_RESTORE GCC=$lt_save_GCC CC=$lt_save_CC CFLAGS=$lt_save_CFLAGS ])# _LT_LANG_GO_CONFIG # _LT_LANG_RC_CONFIG([TAG]) # ------------------------- # Ensure that the configuration variables for the Windows resource compiler # are suitably defined. These variables are subsequently used by _LT_CONFIG # to write the compiler configuration to 'libtool'. m4_defun([_LT_LANG_RC_CONFIG], [AC_REQUIRE([LT_PROG_RC])dnl AC_LANG_SAVE # Source file extension for RC test sources. ac_ext=rc # Object file extension for compiled RC test sources. objext=o _LT_TAGVAR(objext, $1)=$objext # Code to be used in simple compile tests lt_simple_compile_test_code='sample MENU { MENUITEM "&Soup", 100, CHECKED }' # Code to be used in simple link tests lt_simple_link_test_code=$lt_simple_compile_test_code # ltmain only uses $CC for tagged configurations so make sure $CC is set. _LT_TAG_COMPILER # save warnings/boilerplate of simple test code _LT_COMPILER_BOILERPLATE _LT_LINKER_BOILERPLATE # Allow CC to be a program name with arguments. lt_save_CC=$CC lt_save_CFLAGS=$CFLAGS lt_save_GCC=$GCC GCC= CC=${RC-"windres"} CFLAGS= compiler=$CC _LT_TAGVAR(compiler, $1)=$CC _LT_CC_BASENAME([$compiler]) _LT_TAGVAR(lt_cv_prog_compiler_c_o, $1)=yes if test -n "$compiler"; then : _LT_CONFIG($1) fi GCC=$lt_save_GCC AC_LANG_RESTORE CC=$lt_save_CC CFLAGS=$lt_save_CFLAGS ])# _LT_LANG_RC_CONFIG # LT_PROG_GCJ # ----------- AC_DEFUN([LT_PROG_GCJ], [m4_ifdef([AC_PROG_GCJ], [AC_PROG_GCJ], [m4_ifdef([A][M_PROG_GCJ], [A][M_PROG_GCJ], [AC_CHECK_TOOL(GCJ, gcj,) test set = "${GCJFLAGS+set}" || GCJFLAGS="-g -O2" AC_SUBST(GCJFLAGS)])])[]dnl ]) # Old name: AU_ALIAS([LT_AC_PROG_GCJ], [LT_PROG_GCJ]) dnl aclocal-1.4 backwards compatibility: dnl AC_DEFUN([LT_AC_PROG_GCJ], []) # LT_PROG_GO # ---------- AC_DEFUN([LT_PROG_GO], [AC_CHECK_TOOL(GOC, gccgo,) ]) # LT_PROG_RC # ---------- AC_DEFUN([LT_PROG_RC], [AC_CHECK_TOOL(RC, windres,) ]) # Old name: AU_ALIAS([LT_AC_PROG_RC], [LT_PROG_RC]) dnl aclocal-1.4 backwards compatibility: dnl AC_DEFUN([LT_AC_PROG_RC], []) # _LT_DECL_EGREP # -------------- # If we don't have a new enough Autoconf to choose the best grep # available, choose the one first in the user's PATH. m4_defun([_LT_DECL_EGREP], [AC_REQUIRE([AC_PROG_EGREP])dnl AC_REQUIRE([AC_PROG_FGREP])dnl test -z "$GREP" && GREP=grep _LT_DECL([], [GREP], [1], [A grep program that handles long lines]) _LT_DECL([], [EGREP], [1], [An ERE matcher]) _LT_DECL([], [FGREP], [1], [A literal string matcher]) dnl Non-bleeding-edge autoconf doesn't subst GREP, so do it here too AC_SUBST([GREP]) ]) # _LT_DECL_OBJDUMP # -------------- # If we don't have a new enough Autoconf to choose the best objdump # available, choose the one first in the user's PATH. m4_defun([_LT_DECL_OBJDUMP], [AC_CHECK_TOOL(OBJDUMP, objdump, false) test -z "$OBJDUMP" && OBJDUMP=objdump _LT_DECL([], [OBJDUMP], [1], [An object symbol dumper]) AC_SUBST([OBJDUMP]) ]) # _LT_DECL_DLLTOOL # ---------------- # Ensure DLLTOOL variable is set. m4_defun([_LT_DECL_DLLTOOL], [AC_CHECK_TOOL(DLLTOOL, dlltool, false) test -z "$DLLTOOL" && DLLTOOL=dlltool _LT_DECL([], [DLLTOOL], [1], [DLL creation program]) AC_SUBST([DLLTOOL]) ]) # _LT_DECL_SED # ------------ # Check for a fully-functional sed program, that truncates # as few characters as possible. Prefer GNU sed if found. m4_defun([_LT_DECL_SED], [AC_PROG_SED test -z "$SED" && SED=sed Xsed="$SED -e 1s/^X//" _LT_DECL([], [SED], [1], [A sed program that does not truncate output]) _LT_DECL([], [Xsed], ["\$SED -e 1s/^X//"], [Sed that helps us avoid accidentally triggering echo(1) options like -n]) ])# _LT_DECL_SED m4_ifndef([AC_PROG_SED], [ ############################################################ # NOTE: This macro has been submitted for inclusion into # # GNU Autoconf as AC_PROG_SED. When it is available in # # a released version of Autoconf we should remove this # # macro and use it instead. # ############################################################ m4_defun([AC_PROG_SED], [AC_MSG_CHECKING([for a sed that does not truncate output]) AC_CACHE_VAL(lt_cv_path_SED, [# Loop through the user's path and test for sed and gsed. # Then use that list of sed's as ones to test for truncation. as_save_IFS=$IFS; IFS=$PATH_SEPARATOR for as_dir in $PATH do IFS=$as_save_IFS test -z "$as_dir" && as_dir=. for lt_ac_prog in sed gsed; do for ac_exec_ext in '' $ac_executable_extensions; do if $as_executable_p "$as_dir/$lt_ac_prog$ac_exec_ext"; then lt_ac_sed_list="$lt_ac_sed_list $as_dir/$lt_ac_prog$ac_exec_ext" fi done done done IFS=$as_save_IFS lt_ac_max=0 lt_ac_count=0 # Add /usr/xpg4/bin/sed as it is typically found on Solaris # along with /bin/sed that truncates output. for lt_ac_sed in $lt_ac_sed_list /usr/xpg4/bin/sed; do test ! -f "$lt_ac_sed" && continue cat /dev/null > conftest.in lt_ac_count=0 echo $ECHO_N "0123456789$ECHO_C" >conftest.in # Check for GNU sed and select it if it is found. if "$lt_ac_sed" --version 2>&1 < /dev/null | grep 'GNU' > /dev/null; then lt_cv_path_SED=$lt_ac_sed break fi while true; do cat conftest.in conftest.in >conftest.tmp mv conftest.tmp conftest.in cp conftest.in conftest.nl echo >>conftest.nl $lt_ac_sed -e 's/a$//' < conftest.nl >conftest.out || break cmp -s conftest.out conftest.nl || break # 10000 chars as input seems more than enough test 10 -lt "$lt_ac_count" && break lt_ac_count=`expr $lt_ac_count + 1` if test "$lt_ac_count" -gt "$lt_ac_max"; then lt_ac_max=$lt_ac_count lt_cv_path_SED=$lt_ac_sed fi done done ]) SED=$lt_cv_path_SED AC_SUBST([SED]) AC_MSG_RESULT([$SED]) ])#AC_PROG_SED ])#m4_ifndef # Old name: AU_ALIAS([LT_AC_PROG_SED], [AC_PROG_SED]) dnl aclocal-1.4 backwards compatibility: dnl AC_DEFUN([LT_AC_PROG_SED], []) # _LT_CHECK_SHELL_FEATURES # ------------------------ # Find out whether the shell is Bourne or XSI compatible, # or has some other useful features. m4_defun([_LT_CHECK_SHELL_FEATURES], [if ( (MAIL=60; unset MAIL) || exit) >/dev/null 2>&1; then lt_unset=unset else lt_unset=false fi _LT_DECL([], [lt_unset], [0], [whether the shell understands "unset"])dnl # test EBCDIC or ASCII case `echo X|tr X '\101'` in A) # ASCII based system # \n is not interpreted correctly by Solaris 8 /usr/ucb/tr lt_SP2NL='tr \040 \012' lt_NL2SP='tr \015\012 \040\040' ;; *) # EBCDIC based system lt_SP2NL='tr \100 \n' lt_NL2SP='tr \r\n \100\100' ;; esac _LT_DECL([SP2NL], [lt_SP2NL], [1], [turn spaces into newlines])dnl _LT_DECL([NL2SP], [lt_NL2SP], [1], [turn newlines into spaces])dnl ])# _LT_CHECK_SHELL_FEATURES # _LT_PATH_CONVERSION_FUNCTIONS # ----------------------------- # Determine what file name conversion functions should be used by # func_to_host_file (and, implicitly, by func_to_host_path). These are needed # for certain cross-compile configurations and native mingw. m4_defun([_LT_PATH_CONVERSION_FUNCTIONS], [AC_REQUIRE([AC_CANONICAL_HOST])dnl AC_REQUIRE([AC_CANONICAL_BUILD])dnl AC_MSG_CHECKING([how to convert $build file names to $host format]) AC_CACHE_VAL(lt_cv_to_host_file_cmd, [case $host in *-*-mingw* ) case $build in *-*-mingw* ) # actually msys lt_cv_to_host_file_cmd=func_convert_file_msys_to_w32 ;; *-*-cygwin* ) lt_cv_to_host_file_cmd=func_convert_file_cygwin_to_w32 ;; * ) # otherwise, assume *nix lt_cv_to_host_file_cmd=func_convert_file_nix_to_w32 ;; esac ;; *-*-cygwin* ) case $build in *-*-mingw* ) # actually msys lt_cv_to_host_file_cmd=func_convert_file_msys_to_cygwin ;; *-*-cygwin* ) lt_cv_to_host_file_cmd=func_convert_file_noop ;; * ) # otherwise, assume *nix lt_cv_to_host_file_cmd=func_convert_file_nix_to_cygwin ;; esac ;; * ) # unhandled hosts (and "normal" native builds) lt_cv_to_host_file_cmd=func_convert_file_noop ;; esac ]) to_host_file_cmd=$lt_cv_to_host_file_cmd AC_MSG_RESULT([$lt_cv_to_host_file_cmd]) _LT_DECL([to_host_file_cmd], [lt_cv_to_host_file_cmd], [0], [convert $build file names to $host format])dnl AC_MSG_CHECKING([how to convert $build file names to toolchain format]) AC_CACHE_VAL(lt_cv_to_tool_file_cmd, [#assume ordinary cross tools, or native build. lt_cv_to_tool_file_cmd=func_convert_file_noop case $host in *-*-mingw* ) case $build in *-*-mingw* ) # actually msys lt_cv_to_tool_file_cmd=func_convert_file_msys_to_w32 ;; esac ;; esac ]) to_tool_file_cmd=$lt_cv_to_tool_file_cmd AC_MSG_RESULT([$lt_cv_to_tool_file_cmd]) _LT_DECL([to_tool_file_cmd], [lt_cv_to_tool_file_cmd], [0], [convert $build files to toolchain format])dnl ])# _LT_PATH_CONVERSION_FUNCTIONS xrdp-0.9.5/libpainter/m4/ltversion.m4000644 001751 001751 00000001273 13220730731 017363 0ustar00metameta000000 000000 # ltversion.m4 -- version numbers -*- Autoconf -*- # # Copyright (C) 2004, 2011-2015 Free Software Foundation, Inc. # Written by Scott James Remnant, 2004 # # This file is free software; the Free Software Foundation gives # unlimited permission to copy and/or distribute it, with or without # modifications, as long as this notice is preserved. # @configure_input@ # serial 4179 ltversion.m4 # This file is part of GNU Libtool m4_define([LT_PACKAGE_VERSION], [2.4.6]) m4_define([LT_PACKAGE_REVISION], [2.4.6]) AC_DEFUN([LTVERSION_VERSION], [macro_version='2.4.6' macro_revision='2.4.6' _LT_DECL(, macro_version, 0, [Which release of libtool.m4 was used?]) _LT_DECL(, macro_revision, 0) ]) xrdp-0.9.5/libpainter/m4/ltoptions.m4000644 001751 001751 00000034262 13220730731 017375 0ustar00metameta000000 000000 # Helper functions for option handling. -*- Autoconf -*- # # Copyright (C) 2004-2005, 2007-2009, 2011-2015 Free Software # Foundation, Inc. # Written by Gary V. Vaughan, 2004 # # This file is free software; the Free Software Foundation gives # unlimited permission to copy and/or distribute it, with or without # modifications, as long as this notice is preserved. # serial 8 ltoptions.m4 # This is to help aclocal find these macros, as it can't see m4_define. AC_DEFUN([LTOPTIONS_VERSION], [m4_if([1])]) # _LT_MANGLE_OPTION(MACRO-NAME, OPTION-NAME) # ------------------------------------------ m4_define([_LT_MANGLE_OPTION], [[_LT_OPTION_]m4_bpatsubst($1__$2, [[^a-zA-Z0-9_]], [_])]) # _LT_SET_OPTION(MACRO-NAME, OPTION-NAME) # --------------------------------------- # Set option OPTION-NAME for macro MACRO-NAME, and if there is a # matching handler defined, dispatch to it. Other OPTION-NAMEs are # saved as a flag. m4_define([_LT_SET_OPTION], [m4_define(_LT_MANGLE_OPTION([$1], [$2]))dnl m4_ifdef(_LT_MANGLE_DEFUN([$1], [$2]), _LT_MANGLE_DEFUN([$1], [$2]), [m4_warning([Unknown $1 option '$2'])])[]dnl ]) # _LT_IF_OPTION(MACRO-NAME, OPTION-NAME, IF-SET, [IF-NOT-SET]) # ------------------------------------------------------------ # Execute IF-SET if OPTION is set, IF-NOT-SET otherwise. m4_define([_LT_IF_OPTION], [m4_ifdef(_LT_MANGLE_OPTION([$1], [$2]), [$3], [$4])]) # _LT_UNLESS_OPTIONS(MACRO-NAME, OPTION-LIST, IF-NOT-SET) # ------------------------------------------------------- # Execute IF-NOT-SET unless all options in OPTION-LIST for MACRO-NAME # are set. m4_define([_LT_UNLESS_OPTIONS], [m4_foreach([_LT_Option], m4_split(m4_normalize([$2])), [m4_ifdef(_LT_MANGLE_OPTION([$1], _LT_Option), [m4_define([$0_found])])])[]dnl m4_ifdef([$0_found], [m4_undefine([$0_found])], [$3 ])[]dnl ]) # _LT_SET_OPTIONS(MACRO-NAME, OPTION-LIST) # ---------------------------------------- # OPTION-LIST is a space-separated list of Libtool options associated # with MACRO-NAME. If any OPTION has a matching handler declared with # LT_OPTION_DEFINE, dispatch to that macro; otherwise complain about # the unknown option and exit. m4_defun([_LT_SET_OPTIONS], [# Set options m4_foreach([_LT_Option], m4_split(m4_normalize([$2])), [_LT_SET_OPTION([$1], _LT_Option)]) m4_if([$1],[LT_INIT],[ dnl dnl Simply set some default values (i.e off) if boolean options were not dnl specified: _LT_UNLESS_OPTIONS([LT_INIT], [dlopen], [enable_dlopen=no ]) _LT_UNLESS_OPTIONS([LT_INIT], [win32-dll], [enable_win32_dll=no ]) dnl dnl If no reference was made to various pairs of opposing options, then dnl we run the default mode handler for the pair. For example, if neither dnl 'shared' nor 'disable-shared' was passed, we enable building of shared dnl archives by default: _LT_UNLESS_OPTIONS([LT_INIT], [shared disable-shared], [_LT_ENABLE_SHARED]) _LT_UNLESS_OPTIONS([LT_INIT], [static disable-static], [_LT_ENABLE_STATIC]) _LT_UNLESS_OPTIONS([LT_INIT], [pic-only no-pic], [_LT_WITH_PIC]) _LT_UNLESS_OPTIONS([LT_INIT], [fast-install disable-fast-install], [_LT_ENABLE_FAST_INSTALL]) _LT_UNLESS_OPTIONS([LT_INIT], [aix-soname=aix aix-soname=both aix-soname=svr4], [_LT_WITH_AIX_SONAME([aix])]) ]) ])# _LT_SET_OPTIONS ## --------------------------------- ## ## Macros to handle LT_INIT options. ## ## --------------------------------- ## # _LT_MANGLE_DEFUN(MACRO-NAME, OPTION-NAME) # ----------------------------------------- m4_define([_LT_MANGLE_DEFUN], [[_LT_OPTION_DEFUN_]m4_bpatsubst(m4_toupper([$1__$2]), [[^A-Z0-9_]], [_])]) # LT_OPTION_DEFINE(MACRO-NAME, OPTION-NAME, CODE) # ----------------------------------------------- m4_define([LT_OPTION_DEFINE], [m4_define(_LT_MANGLE_DEFUN([$1], [$2]), [$3])[]dnl ])# LT_OPTION_DEFINE # dlopen # ------ LT_OPTION_DEFINE([LT_INIT], [dlopen], [enable_dlopen=yes ]) AU_DEFUN([AC_LIBTOOL_DLOPEN], [_LT_SET_OPTION([LT_INIT], [dlopen]) AC_DIAGNOSE([obsolete], [$0: Remove this warning and the call to _LT_SET_OPTION when you put the 'dlopen' option into LT_INIT's first parameter.]) ]) dnl aclocal-1.4 backwards compatibility: dnl AC_DEFUN([AC_LIBTOOL_DLOPEN], []) # win32-dll # --------- # Declare package support for building win32 dll's. LT_OPTION_DEFINE([LT_INIT], [win32-dll], [enable_win32_dll=yes case $host in *-*-cygwin* | *-*-mingw* | *-*-pw32* | *-*-cegcc*) AC_CHECK_TOOL(AS, as, false) AC_CHECK_TOOL(DLLTOOL, dlltool, false) AC_CHECK_TOOL(OBJDUMP, objdump, false) ;; esac test -z "$AS" && AS=as _LT_DECL([], [AS], [1], [Assembler program])dnl test -z "$DLLTOOL" && DLLTOOL=dlltool _LT_DECL([], [DLLTOOL], [1], [DLL creation program])dnl test -z "$OBJDUMP" && OBJDUMP=objdump _LT_DECL([], [OBJDUMP], [1], [Object dumper program])dnl ])# win32-dll AU_DEFUN([AC_LIBTOOL_WIN32_DLL], [AC_REQUIRE([AC_CANONICAL_HOST])dnl _LT_SET_OPTION([LT_INIT], [win32-dll]) AC_DIAGNOSE([obsolete], [$0: Remove this warning and the call to _LT_SET_OPTION when you put the 'win32-dll' option into LT_INIT's first parameter.]) ]) dnl aclocal-1.4 backwards compatibility: dnl AC_DEFUN([AC_LIBTOOL_WIN32_DLL], []) # _LT_ENABLE_SHARED([DEFAULT]) # ---------------------------- # implement the --enable-shared flag, and supports the 'shared' and # 'disable-shared' LT_INIT options. # DEFAULT is either 'yes' or 'no'. If omitted, it defaults to 'yes'. m4_define([_LT_ENABLE_SHARED], [m4_define([_LT_ENABLE_SHARED_DEFAULT], [m4_if($1, no, no, yes)])dnl AC_ARG_ENABLE([shared], [AS_HELP_STRING([--enable-shared@<:@=PKGS@:>@], [build shared libraries @<:@default=]_LT_ENABLE_SHARED_DEFAULT[@:>@])], [p=${PACKAGE-default} case $enableval in yes) enable_shared=yes ;; no) enable_shared=no ;; *) enable_shared=no # Look at the argument we got. We use all the common list separators. lt_save_ifs=$IFS; IFS=$IFS$PATH_SEPARATOR, for pkg in $enableval; do IFS=$lt_save_ifs if test "X$pkg" = "X$p"; then enable_shared=yes fi done IFS=$lt_save_ifs ;; esac], [enable_shared=]_LT_ENABLE_SHARED_DEFAULT) _LT_DECL([build_libtool_libs], [enable_shared], [0], [Whether or not to build shared libraries]) ])# _LT_ENABLE_SHARED LT_OPTION_DEFINE([LT_INIT], [shared], [_LT_ENABLE_SHARED([yes])]) LT_OPTION_DEFINE([LT_INIT], [disable-shared], [_LT_ENABLE_SHARED([no])]) # Old names: AC_DEFUN([AC_ENABLE_SHARED], [_LT_SET_OPTION([LT_INIT], m4_if([$1], [no], [disable-])[shared]) ]) AC_DEFUN([AC_DISABLE_SHARED], [_LT_SET_OPTION([LT_INIT], [disable-shared]) ]) AU_DEFUN([AM_ENABLE_SHARED], [AC_ENABLE_SHARED($@)]) AU_DEFUN([AM_DISABLE_SHARED], [AC_DISABLE_SHARED($@)]) dnl aclocal-1.4 backwards compatibility: dnl AC_DEFUN([AM_ENABLE_SHARED], []) dnl AC_DEFUN([AM_DISABLE_SHARED], []) # _LT_ENABLE_STATIC([DEFAULT]) # ---------------------------- # implement the --enable-static flag, and support the 'static' and # 'disable-static' LT_INIT options. # DEFAULT is either 'yes' or 'no'. If omitted, it defaults to 'yes'. m4_define([_LT_ENABLE_STATIC], [m4_define([_LT_ENABLE_STATIC_DEFAULT], [m4_if($1, no, no, yes)])dnl AC_ARG_ENABLE([static], [AS_HELP_STRING([--enable-static@<:@=PKGS@:>@], [build static libraries @<:@default=]_LT_ENABLE_STATIC_DEFAULT[@:>@])], [p=${PACKAGE-default} case $enableval in yes) enable_static=yes ;; no) enable_static=no ;; *) enable_static=no # Look at the argument we got. We use all the common list separators. lt_save_ifs=$IFS; IFS=$IFS$PATH_SEPARATOR, for pkg in $enableval; do IFS=$lt_save_ifs if test "X$pkg" = "X$p"; then enable_static=yes fi done IFS=$lt_save_ifs ;; esac], [enable_static=]_LT_ENABLE_STATIC_DEFAULT) _LT_DECL([build_old_libs], [enable_static], [0], [Whether or not to build static libraries]) ])# _LT_ENABLE_STATIC LT_OPTION_DEFINE([LT_INIT], [static], [_LT_ENABLE_STATIC([yes])]) LT_OPTION_DEFINE([LT_INIT], [disable-static], [_LT_ENABLE_STATIC([no])]) # Old names: AC_DEFUN([AC_ENABLE_STATIC], [_LT_SET_OPTION([LT_INIT], m4_if([$1], [no], [disable-])[static]) ]) AC_DEFUN([AC_DISABLE_STATIC], [_LT_SET_OPTION([LT_INIT], [disable-static]) ]) AU_DEFUN([AM_ENABLE_STATIC], [AC_ENABLE_STATIC($@)]) AU_DEFUN([AM_DISABLE_STATIC], [AC_DISABLE_STATIC($@)]) dnl aclocal-1.4 backwards compatibility: dnl AC_DEFUN([AM_ENABLE_STATIC], []) dnl AC_DEFUN([AM_DISABLE_STATIC], []) # _LT_ENABLE_FAST_INSTALL([DEFAULT]) # ---------------------------------- # implement the --enable-fast-install flag, and support the 'fast-install' # and 'disable-fast-install' LT_INIT options. # DEFAULT is either 'yes' or 'no'. If omitted, it defaults to 'yes'. m4_define([_LT_ENABLE_FAST_INSTALL], [m4_define([_LT_ENABLE_FAST_INSTALL_DEFAULT], [m4_if($1, no, no, yes)])dnl AC_ARG_ENABLE([fast-install], [AS_HELP_STRING([--enable-fast-install@<:@=PKGS@:>@], [optimize for fast installation @<:@default=]_LT_ENABLE_FAST_INSTALL_DEFAULT[@:>@])], [p=${PACKAGE-default} case $enableval in yes) enable_fast_install=yes ;; no) enable_fast_install=no ;; *) enable_fast_install=no # Look at the argument we got. We use all the common list separators. lt_save_ifs=$IFS; IFS=$IFS$PATH_SEPARATOR, for pkg in $enableval; do IFS=$lt_save_ifs if test "X$pkg" = "X$p"; then enable_fast_install=yes fi done IFS=$lt_save_ifs ;; esac], [enable_fast_install=]_LT_ENABLE_FAST_INSTALL_DEFAULT) _LT_DECL([fast_install], [enable_fast_install], [0], [Whether or not to optimize for fast installation])dnl ])# _LT_ENABLE_FAST_INSTALL LT_OPTION_DEFINE([LT_INIT], [fast-install], [_LT_ENABLE_FAST_INSTALL([yes])]) LT_OPTION_DEFINE([LT_INIT], [disable-fast-install], [_LT_ENABLE_FAST_INSTALL([no])]) # Old names: AU_DEFUN([AC_ENABLE_FAST_INSTALL], [_LT_SET_OPTION([LT_INIT], m4_if([$1], [no], [disable-])[fast-install]) AC_DIAGNOSE([obsolete], [$0: Remove this warning and the call to _LT_SET_OPTION when you put the 'fast-install' option into LT_INIT's first parameter.]) ]) AU_DEFUN([AC_DISABLE_FAST_INSTALL], [_LT_SET_OPTION([LT_INIT], [disable-fast-install]) AC_DIAGNOSE([obsolete], [$0: Remove this warning and the call to _LT_SET_OPTION when you put the 'disable-fast-install' option into LT_INIT's first parameter.]) ]) dnl aclocal-1.4 backwards compatibility: dnl AC_DEFUN([AC_ENABLE_FAST_INSTALL], []) dnl AC_DEFUN([AM_DISABLE_FAST_INSTALL], []) # _LT_WITH_AIX_SONAME([DEFAULT]) # ---------------------------------- # implement the --with-aix-soname flag, and support the `aix-soname=aix' # and `aix-soname=both' and `aix-soname=svr4' LT_INIT options. DEFAULT # is either `aix', `both' or `svr4'. If omitted, it defaults to `aix'. m4_define([_LT_WITH_AIX_SONAME], [m4_define([_LT_WITH_AIX_SONAME_DEFAULT], [m4_if($1, svr4, svr4, m4_if($1, both, both, aix))])dnl shared_archive_member_spec= case $host,$enable_shared in power*-*-aix[[5-9]]*,yes) AC_MSG_CHECKING([which variant of shared library versioning to provide]) AC_ARG_WITH([aix-soname], [AS_HELP_STRING([--with-aix-soname=aix|svr4|both], [shared library versioning (aka "SONAME") variant to provide on AIX, @<:@default=]_LT_WITH_AIX_SONAME_DEFAULT[@:>@.])], [case $withval in aix|svr4|both) ;; *) AC_MSG_ERROR([Unknown argument to --with-aix-soname]) ;; esac lt_cv_with_aix_soname=$with_aix_soname], [AC_CACHE_VAL([lt_cv_with_aix_soname], [lt_cv_with_aix_soname=]_LT_WITH_AIX_SONAME_DEFAULT) with_aix_soname=$lt_cv_with_aix_soname]) AC_MSG_RESULT([$with_aix_soname]) if test aix != "$with_aix_soname"; then # For the AIX way of multilib, we name the shared archive member # based on the bitwidth used, traditionally 'shr.o' or 'shr_64.o', # and 'shr.imp' or 'shr_64.imp', respectively, for the Import File. # Even when GNU compilers ignore OBJECT_MODE but need '-maix64' flag, # the AIX toolchain works better with OBJECT_MODE set (default 32). if test 64 = "${OBJECT_MODE-32}"; then shared_archive_member_spec=shr_64 else shared_archive_member_spec=shr fi fi ;; *) with_aix_soname=aix ;; esac _LT_DECL([], [shared_archive_member_spec], [0], [Shared archive member basename, for filename based shared library versioning on AIX])dnl ])# _LT_WITH_AIX_SONAME LT_OPTION_DEFINE([LT_INIT], [aix-soname=aix], [_LT_WITH_AIX_SONAME([aix])]) LT_OPTION_DEFINE([LT_INIT], [aix-soname=both], [_LT_WITH_AIX_SONAME([both])]) LT_OPTION_DEFINE([LT_INIT], [aix-soname=svr4], [_LT_WITH_AIX_SONAME([svr4])]) # _LT_WITH_PIC([MODE]) # -------------------- # implement the --with-pic flag, and support the 'pic-only' and 'no-pic' # LT_INIT options. # MODE is either 'yes' or 'no'. If omitted, it defaults to 'both'. m4_define([_LT_WITH_PIC], [AC_ARG_WITH([pic], [AS_HELP_STRING([--with-pic@<:@=PKGS@:>@], [try to use only PIC/non-PIC objects @<:@default=use both@:>@])], [lt_p=${PACKAGE-default} case $withval in yes|no) pic_mode=$withval ;; *) pic_mode=default # Look at the argument we got. We use all the common list separators. lt_save_ifs=$IFS; IFS=$IFS$PATH_SEPARATOR, for lt_pkg in $withval; do IFS=$lt_save_ifs if test "X$lt_pkg" = "X$lt_p"; then pic_mode=yes fi done IFS=$lt_save_ifs ;; esac], [pic_mode=m4_default([$1], [default])]) _LT_DECL([], [pic_mode], [0], [What type of objects to build])dnl ])# _LT_WITH_PIC LT_OPTION_DEFINE([LT_INIT], [pic-only], [_LT_WITH_PIC([yes])]) LT_OPTION_DEFINE([LT_INIT], [no-pic], [_LT_WITH_PIC([no])]) # Old name: AU_DEFUN([AC_LIBTOOL_PICMODE], [_LT_SET_OPTION([LT_INIT], [pic-only]) AC_DIAGNOSE([obsolete], [$0: Remove this warning and the call to _LT_SET_OPTION when you put the 'pic-only' option into LT_INIT's first parameter.]) ]) dnl aclocal-1.4 backwards compatibility: dnl AC_DEFUN([AC_LIBTOOL_PICMODE], []) ## ----------------- ## ## LTDL_INIT Options ## ## ----------------- ## m4_define([_LTDL_MODE], []) LT_OPTION_DEFINE([LTDL_INIT], [nonrecursive], [m4_define([_LTDL_MODE], [nonrecursive])]) LT_OPTION_DEFINE([LTDL_INIT], [recursive], [m4_define([_LTDL_MODE], [recursive])]) LT_OPTION_DEFINE([LTDL_INIT], [subproject], [m4_define([_LTDL_MODE], [subproject])]) m4_define([_LTDL_TYPE], []) LT_OPTION_DEFINE([LTDL_INIT], [installable], [m4_define([_LTDL_TYPE], [installable])]) LT_OPTION_DEFINE([LTDL_INIT], [convenience], [m4_define([_LTDL_TYPE], [convenience])]) xrdp-0.9.5/libpainter/m4/ax_append_compile_flags.m4000644 001751 001751 00000005660 13127342056 022172 0ustar00metameta000000 000000 # ============================================================================ # https://www.gnu.org/software/autoconf-archive/ax_append_compile_flags.html # ============================================================================ # # SYNOPSIS # # AX_APPEND_COMPILE_FLAGS([FLAG1 FLAG2 ...], [FLAGS-VARIABLE], [EXTRA-FLAGS], [INPUT]) # # DESCRIPTION # # For every FLAG1, FLAG2 it is checked whether the compiler works with the # flag. If it does, the flag is added FLAGS-VARIABLE # # If FLAGS-VARIABLE is not specified, the current language's flags (e.g. # CFLAGS) is used. During the check the flag is always added to the # current language's flags. # # If EXTRA-FLAGS is defined, it is added to the current language's default # flags (e.g. CFLAGS) when the check is done. The check is thus made with # the flags: "CFLAGS EXTRA-FLAGS FLAG". This can for example be used to # force the compiler to issue an error when a bad flag is given. # # INPUT gives an alternative input source to AC_COMPILE_IFELSE. # # NOTE: This macro depends on the AX_APPEND_FLAG and # AX_CHECK_COMPILE_FLAG. Please keep this macro in sync with # AX_APPEND_LINK_FLAGS. # # LICENSE # # Copyright (c) 2011 Maarten Bosmans # # 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. # # You should have received a copy of the GNU General Public License along # with this program. If not, see . # # As a special exception, the respective Autoconf Macro's copyright owner # gives unlimited permission to copy, distribute and modify the configure # scripts that are the output of Autoconf when processing the Macro. You # need not follow the terms of the GNU General Public License when using # or distributing such scripts, even though portions of the text of the # Macro appear in them. The GNU General Public License (GPL) does govern # all other use of the material that constitutes the Autoconf Macro. # # This special exception to the GPL applies to versions of the Autoconf # Macro released by the Autoconf Archive. When you make and distribute a # modified version of the Autoconf Macro, you may extend this special # exception to the GPL to apply to your modified version as well. #serial 6 AC_DEFUN([AX_APPEND_COMPILE_FLAGS], [AX_REQUIRE_DEFINED([AX_CHECK_COMPILE_FLAG]) AX_REQUIRE_DEFINED([AX_APPEND_FLAG]) for flag in $1; do AX_CHECK_COMPILE_FLAG([$flag], [AX_APPEND_FLAG([$flag], [$2])], [], [$3], [$4]) done ])dnl AX_APPEND_COMPILE_FLAGS xrdp-0.9.5/libpainter/m4/pkg.m4000644 001751 001751 00000024011 13035113356 016114 0ustar00metameta000000 000000 dnl pkg.m4 - Macros to locate and utilise pkg-config. -*- Autoconf -*- dnl serial 11 (pkg-config-0.29.1) dnl dnl Copyright © 2004 Scott James Remnant . dnl Copyright © 2012-2015 Dan Nicholson dnl dnl This program is free software; you can redistribute it and/or modify dnl it under the terms of the GNU General Public License as published by dnl the Free Software Foundation; either version 2 of the License, or dnl (at your option) any later version. dnl dnl This program is distributed in the hope that it will be useful, but dnl WITHOUT ANY WARRANTY; without even the implied warranty of dnl MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU dnl General Public License for more details. dnl dnl You should have received a copy of the GNU General Public License dnl along with this program; if not, write to the Free Software dnl Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA dnl 02111-1307, USA. dnl dnl As a special exception to the GNU General Public License, if you dnl distribute this file as part of a program that contains a dnl configuration script generated by Autoconf, you may include it under dnl the same distribution terms that you use for the rest of that dnl program. dnl PKG_PREREQ(MIN-VERSION) dnl ----------------------- dnl Since: 0.29 dnl dnl Verify that the version of the pkg-config macros are at least dnl MIN-VERSION. Unlike PKG_PROG_PKG_CONFIG, which checks the user's dnl installed version of pkg-config, this checks the developer's version dnl of pkg.m4 when generating configure. dnl dnl To ensure that this macro is defined, also add: dnl m4_ifndef([PKG_PREREQ], dnl [m4_fatal([must install pkg-config 0.29 or later before running autoconf/autogen])]) dnl dnl See the "Since" comment for each macro you use to see what version dnl of the macros you require. m4_defun([PKG_PREREQ], [m4_define([PKG_MACROS_VERSION], [0.29.1]) m4_if(m4_version_compare(PKG_MACROS_VERSION, [$1]), -1, [m4_fatal([pkg.m4 version $1 or higher is required but ]PKG_MACROS_VERSION[ found])]) ])dnl PKG_PREREQ dnl PKG_PROG_PKG_CONFIG([MIN-VERSION]) dnl ---------------------------------- dnl Since: 0.16 dnl dnl Search for the pkg-config tool and set the PKG_CONFIG variable to dnl first found in the path. Checks that the version of pkg-config found dnl is at least MIN-VERSION. If MIN-VERSION is not specified, 0.9.0 is dnl used since that's the first version where most current features of dnl pkg-config existed. AC_DEFUN([PKG_PROG_PKG_CONFIG], [m4_pattern_forbid([^_?PKG_[A-Z_]+$]) m4_pattern_allow([^PKG_CONFIG(_(PATH|LIBDIR|SYSROOT_DIR|ALLOW_SYSTEM_(CFLAGS|LIBS)))?$]) m4_pattern_allow([^PKG_CONFIG_(DISABLE_UNINSTALLED|TOP_BUILD_DIR|DEBUG_SPEW)$]) AC_ARG_VAR([PKG_CONFIG], [path to pkg-config utility]) AC_ARG_VAR([PKG_CONFIG_PATH], [directories to add to pkg-config's search path]) AC_ARG_VAR([PKG_CONFIG_LIBDIR], [path overriding pkg-config's built-in search path]) if test "x$ac_cv_env_PKG_CONFIG_set" != "xset"; then AC_PATH_TOOL([PKG_CONFIG], [pkg-config]) fi if test -n "$PKG_CONFIG"; then _pkg_min_version=m4_default([$1], [0.9.0]) AC_MSG_CHECKING([pkg-config is at least version $_pkg_min_version]) if $PKG_CONFIG --atleast-pkgconfig-version $_pkg_min_version; then AC_MSG_RESULT([yes]) else AC_MSG_RESULT([no]) PKG_CONFIG="" fi fi[]dnl ])dnl PKG_PROG_PKG_CONFIG dnl PKG_CHECK_EXISTS(MODULES, [ACTION-IF-FOUND], [ACTION-IF-NOT-FOUND]) dnl ------------------------------------------------------------------- dnl Since: 0.18 dnl dnl Check to see whether a particular set of modules exists. Similar to dnl PKG_CHECK_MODULES(), but does not set variables or print errors. dnl dnl Please remember that m4 expands AC_REQUIRE([PKG_PROG_PKG_CONFIG]) dnl only at the first occurence in configure.ac, so if the first place dnl it's called might be skipped (such as if it is within an "if", you dnl have to call PKG_CHECK_EXISTS manually AC_DEFUN([PKG_CHECK_EXISTS], [AC_REQUIRE([PKG_PROG_PKG_CONFIG])dnl if test -n "$PKG_CONFIG" && \ AC_RUN_LOG([$PKG_CONFIG --exists --print-errors "$1"]); then m4_default([$2], [:]) m4_ifvaln([$3], [else $3])dnl fi]) dnl _PKG_CONFIG([VARIABLE], [COMMAND], [MODULES]) dnl --------------------------------------------- dnl Internal wrapper calling pkg-config via PKG_CONFIG and setting dnl pkg_failed based on the result. m4_define([_PKG_CONFIG], [if test -n "$$1"; then pkg_cv_[]$1="$$1" elif test -n "$PKG_CONFIG"; then PKG_CHECK_EXISTS([$3], [pkg_cv_[]$1=`$PKG_CONFIG --[]$2 "$3" 2>/dev/null` test "x$?" != "x0" && pkg_failed=yes ], [pkg_failed=yes]) else pkg_failed=untried fi[]dnl ])dnl _PKG_CONFIG dnl _PKG_SHORT_ERRORS_SUPPORTED dnl --------------------------- dnl Internal check to see if pkg-config supports short errors. AC_DEFUN([_PKG_SHORT_ERRORS_SUPPORTED], [AC_REQUIRE([PKG_PROG_PKG_CONFIG]) if $PKG_CONFIG --atleast-pkgconfig-version 0.20; then _pkg_short_errors_supported=yes else _pkg_short_errors_supported=no fi[]dnl ])dnl _PKG_SHORT_ERRORS_SUPPORTED dnl PKG_CHECK_MODULES(VARIABLE-PREFIX, MODULES, [ACTION-IF-FOUND], dnl [ACTION-IF-NOT-FOUND]) dnl -------------------------------------------------------------- dnl Since: 0.4.0 dnl dnl Note that if there is a possibility the first call to dnl PKG_CHECK_MODULES might not happen, you should be sure to include an dnl explicit call to PKG_PROG_PKG_CONFIG in your configure.ac AC_DEFUN([PKG_CHECK_MODULES], [AC_REQUIRE([PKG_PROG_PKG_CONFIG])dnl AC_ARG_VAR([$1][_CFLAGS], [C compiler flags for $1, overriding pkg-config])dnl AC_ARG_VAR([$1][_LIBS], [linker flags for $1, overriding pkg-config])dnl pkg_failed=no AC_MSG_CHECKING([for $1]) _PKG_CONFIG([$1][_CFLAGS], [cflags], [$2]) _PKG_CONFIG([$1][_LIBS], [libs], [$2]) m4_define([_PKG_TEXT], [Alternatively, you may set the environment variables $1[]_CFLAGS and $1[]_LIBS to avoid the need to call pkg-config. See the pkg-config man page for more details.]) if test $pkg_failed = yes; then AC_MSG_RESULT([no]) _PKG_SHORT_ERRORS_SUPPORTED if test $_pkg_short_errors_supported = yes; then $1[]_PKG_ERRORS=`$PKG_CONFIG --short-errors --print-errors --cflags --libs "$2" 2>&1` else $1[]_PKG_ERRORS=`$PKG_CONFIG --print-errors --cflags --libs "$2" 2>&1` fi # Put the nasty error message in config.log where it belongs echo "$$1[]_PKG_ERRORS" >&AS_MESSAGE_LOG_FD m4_default([$4], [AC_MSG_ERROR( [Package requirements ($2) were not met: $$1_PKG_ERRORS Consider adjusting the PKG_CONFIG_PATH environment variable if you installed software in a non-standard prefix. _PKG_TEXT])[]dnl ]) elif test $pkg_failed = untried; then AC_MSG_RESULT([no]) m4_default([$4], [AC_MSG_FAILURE( [The pkg-config script could not be found or is too old. Make sure it is in your PATH or set the PKG_CONFIG environment variable to the full path to pkg-config. _PKG_TEXT To get pkg-config, see .])[]dnl ]) else $1[]_CFLAGS=$pkg_cv_[]$1[]_CFLAGS $1[]_LIBS=$pkg_cv_[]$1[]_LIBS AC_MSG_RESULT([yes]) $3 fi[]dnl ])dnl PKG_CHECK_MODULES dnl PKG_CHECK_MODULES_STATIC(VARIABLE-PREFIX, MODULES, [ACTION-IF-FOUND], dnl [ACTION-IF-NOT-FOUND]) dnl --------------------------------------------------------------------- dnl Since: 0.29 dnl dnl Checks for existence of MODULES and gathers its build flags with dnl static libraries enabled. Sets VARIABLE-PREFIX_CFLAGS from --cflags dnl and VARIABLE-PREFIX_LIBS from --libs. dnl dnl Note that if there is a possibility the first call to dnl PKG_CHECK_MODULES_STATIC might not happen, you should be sure to dnl include an explicit call to PKG_PROG_PKG_CONFIG in your dnl configure.ac. AC_DEFUN([PKG_CHECK_MODULES_STATIC], [AC_REQUIRE([PKG_PROG_PKG_CONFIG])dnl _save_PKG_CONFIG=$PKG_CONFIG PKG_CONFIG="$PKG_CONFIG --static" PKG_CHECK_MODULES($@) PKG_CONFIG=$_save_PKG_CONFIG[]dnl ])dnl PKG_CHECK_MODULES_STATIC dnl PKG_INSTALLDIR([DIRECTORY]) dnl ------------------------- dnl Since: 0.27 dnl dnl Substitutes the variable pkgconfigdir as the location where a module dnl should install pkg-config .pc files. By default the directory is dnl $libdir/pkgconfig, but the default can be changed by passing dnl DIRECTORY. The user can override through the --with-pkgconfigdir dnl parameter. AC_DEFUN([PKG_INSTALLDIR], [m4_pushdef([pkg_default], [m4_default([$1], ['${libdir}/pkgconfig'])]) m4_pushdef([pkg_description], [pkg-config installation directory @<:@]pkg_default[@:>@]) AC_ARG_WITH([pkgconfigdir], [AS_HELP_STRING([--with-pkgconfigdir], pkg_description)],, [with_pkgconfigdir=]pkg_default) AC_SUBST([pkgconfigdir], [$with_pkgconfigdir]) m4_popdef([pkg_default]) m4_popdef([pkg_description]) ])dnl PKG_INSTALLDIR dnl PKG_NOARCH_INSTALLDIR([DIRECTORY]) dnl -------------------------------- dnl Since: 0.27 dnl dnl Substitutes the variable noarch_pkgconfigdir as the location where a dnl module should install arch-independent pkg-config .pc files. By dnl default the directory is $datadir/pkgconfig, but the default can be dnl changed by passing DIRECTORY. The user can override through the dnl --with-noarch-pkgconfigdir parameter. AC_DEFUN([PKG_NOARCH_INSTALLDIR], [m4_pushdef([pkg_default], [m4_default([$1], ['${datadir}/pkgconfig'])]) m4_pushdef([pkg_description], [pkg-config arch-independent installation directory @<:@]pkg_default[@:>@]) AC_ARG_WITH([noarch-pkgconfigdir], [AS_HELP_STRING([--with-noarch-pkgconfigdir], pkg_description)],, [with_noarch_pkgconfigdir=]pkg_default) AC_SUBST([noarch_pkgconfigdir], [$with_noarch_pkgconfigdir]) m4_popdef([pkg_default]) m4_popdef([pkg_description]) ])dnl PKG_NOARCH_INSTALLDIR dnl PKG_CHECK_VAR(VARIABLE, MODULE, CONFIG-VARIABLE, dnl [ACTION-IF-FOUND], [ACTION-IF-NOT-FOUND]) dnl ------------------------------------------- dnl Since: 0.28 dnl dnl Retrieves the value of the pkg-config variable for the given module. AC_DEFUN([PKG_CHECK_VAR], [AC_REQUIRE([PKG_PROG_PKG_CONFIG])dnl AC_ARG_VAR([$1], [value of $3 for $2, overriding pkg-config])dnl _PKG_CONFIG([$1], [variable="][$3]["], [$2]) AS_VAR_COPY([$1], [pkg_cv_][$1]) AS_VAR_IF([$1], [""], [$5], [$4])dnl ])dnl PKG_CHECK_VAR xrdp-0.9.5/libpainter/m4/ax_append_flag.m4000644 001751 001751 00000005333 13127342056 020274 0ustar00metameta000000 000000 # =========================================================================== # https://www.gnu.org/software/autoconf-archive/ax_append_flag.html # =========================================================================== # # SYNOPSIS # # AX_APPEND_FLAG(FLAG, [FLAGS-VARIABLE]) # # DESCRIPTION # # FLAG is appended to the FLAGS-VARIABLE shell variable, with a space # added in between. # # If FLAGS-VARIABLE is not specified, the current language's flags (e.g. # CFLAGS) is used. FLAGS-VARIABLE is not changed if it already contains # FLAG. If FLAGS-VARIABLE is unset in the shell, it is set to exactly # FLAG. # # NOTE: Implementation based on AX_CFLAGS_GCC_OPTION. # # LICENSE # # Copyright (c) 2008 Guido U. Draheim # Copyright (c) 2011 Maarten Bosmans # # 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. # # You should have received a copy of the GNU General Public License along # with this program. If not, see . # # As a special exception, the respective Autoconf Macro's copyright owner # gives unlimited permission to copy, distribute and modify the configure # scripts that are the output of Autoconf when processing the Macro. You # need not follow the terms of the GNU General Public License when using # or distributing such scripts, even though portions of the text of the # Macro appear in them. The GNU General Public License (GPL) does govern # all other use of the material that constitutes the Autoconf Macro. # # This special exception to the GPL applies to versions of the Autoconf # Macro released by the Autoconf Archive. When you make and distribute a # modified version of the Autoconf Macro, you may extend this special # exception to the GPL to apply to your modified version as well. #serial 7 AC_DEFUN([AX_APPEND_FLAG], [dnl AC_PREREQ(2.64)dnl for _AC_LANG_PREFIX and AS_VAR_SET_IF AS_VAR_PUSHDEF([FLAGS], [m4_default($2,_AC_LANG_PREFIX[FLAGS])]) AS_VAR_SET_IF(FLAGS,[ AS_CASE([" AS_VAR_GET(FLAGS) "], [*" $1 "*], [AC_RUN_LOG([: FLAGS already contains $1])], [ AS_VAR_APPEND(FLAGS,[" $1"]) AC_RUN_LOG([: FLAGS="$FLAGS"]) ]) ], [ AS_VAR_SET(FLAGS,[$1]) AC_RUN_LOG([: FLAGS="$FLAGS"]) ]) AS_VAR_POPDEF([FLAGS])dnl ])dnl AX_APPEND_FLAG xrdp-0.9.5/libpainter/pkgconfig/libpainter.pc.in000644 001751 001751 00000000351 13035113356 021603 0ustar00metameta000000 000000 prefix=@prefix@ exec_prefix=@exec_prefix@ libdir=@libdir@ includedir=@includedir@ Name: libpainter Description: Library for manipulating memory bitmaps. Version: @PACKAGE_VERSION@ Libs: -L${libdir} -lpainter Cflags: -I${includedir} xrdp-0.9.5/libpainter/pkgconfig/Makefile.am000644 001751 001751 00000000037 13035113356 020556 0ustar00metameta000000 000000 pkgconfig_DATA = libpainter.pc xrdp-0.9.5/libpainter/pkgconfig/libpainter-uninstalled.pc.in000644 001751 001751 00000000437 13035113356 024130 0ustar00metameta000000 000000 abs_top_srcdir=@abs_top_srcdir@ abs_top_builddir=@abs_top_builddir@ includedir=${abs_top_srcdir}/include libdir=${abs_top_builddir}/src Name: libpainter Description: Library for manipulating memory bitmaps. Version: @PACKAGE_VERSION@ Libs: -L${libdir} -lpainter Cflags: -I${includedir} xrdp-0.9.5/libpainter/pkgconfig/Makefile.in000644 001751 001751 00000035046 13220730741 020576 0ustar00metameta000000 000000 # Makefile.in generated by automake 1.15.1 from Makefile.am. # @configure_input@ # Copyright (C) 1994-2017 Free Software Foundation, Inc. # This Makefile.in is free software; the Free Software Foundation # gives unlimited permission to copy and/or distribute it, # with or without modifications, as long as this notice is preserved. # This program is distributed in the hope that it will be useful, # but WITHOUT ANY WARRANTY, to the extent permitted by law; without # even the implied warranty of MERCHANTABILITY or FITNESS FOR A # PARTICULAR PURPOSE. @SET_MAKE@ VPATH = @srcdir@ am__is_gnu_make = { \ if test -z '$(MAKELEVEL)'; then \ false; \ elif test -n '$(MAKE_HOST)'; then \ true; \ elif test -n '$(MAKE_VERSION)' && test -n '$(CURDIR)'; then \ true; \ else \ false; \ fi; \ } am__make_running_with_option = \ case $${target_option-} in \ ?) ;; \ *) echo "am__make_running_with_option: internal error: invalid" \ "target option '$${target_option-}' specified" >&2; \ exit 1;; \ esac; \ has_opt=no; \ sane_makeflags=$$MAKEFLAGS; \ if $(am__is_gnu_make); then \ sane_makeflags=$$MFLAGS; \ else \ case $$MAKEFLAGS in \ *\\[\ \ ]*) \ bs=\\; \ sane_makeflags=`printf '%s\n' "$$MAKEFLAGS" \ | sed "s/$$bs$$bs[$$bs $$bs ]*//g"`;; \ esac; \ fi; \ skip_next=no; \ strip_trailopt () \ { \ flg=`printf '%s\n' "$$flg" | sed "s/$$1.*$$//"`; \ }; \ for flg in $$sane_makeflags; do \ test $$skip_next = yes && { skip_next=no; continue; }; \ case $$flg in \ *=*|--*) continue;; \ -*I) strip_trailopt 'I'; skip_next=yes;; \ -*I?*) strip_trailopt 'I';; \ -*O) strip_trailopt 'O'; skip_next=yes;; \ -*O?*) strip_trailopt 'O';; \ -*l) strip_trailopt 'l'; skip_next=yes;; \ -*l?*) strip_trailopt 'l';; \ -[dEDm]) skip_next=yes;; \ -[JT]) skip_next=yes;; \ esac; \ case $$flg in \ *$$target_option*) has_opt=yes; break;; \ esac; \ done; \ test $$has_opt = yes am__make_dryrun = (target_option=n; $(am__make_running_with_option)) am__make_keepgoing = (target_option=k; $(am__make_running_with_option)) pkgdatadir = $(datadir)/@PACKAGE@ pkgincludedir = $(includedir)/@PACKAGE@ pkglibdir = $(libdir)/@PACKAGE@ pkglibexecdir = $(libexecdir)/@PACKAGE@ am__cd = CDPATH="$${ZSH_VERSION+.}$(PATH_SEPARATOR)" && cd install_sh_DATA = $(install_sh) -c -m 644 install_sh_PROGRAM = $(install_sh) -c install_sh_SCRIPT = $(install_sh) -c INSTALL_HEADER = $(INSTALL_DATA) transform = $(program_transform_name) NORMAL_INSTALL = : PRE_INSTALL = : POST_INSTALL = : NORMAL_UNINSTALL = : PRE_UNINSTALL = : POST_UNINSTALL = : build_triplet = @build@ host_triplet = @host@ subdir = pkgconfig ACLOCAL_M4 = $(top_srcdir)/aclocal.m4 am__aclocal_m4_deps = $(top_srcdir)/m4/ax_append_compile_flags.m4 \ $(top_srcdir)/m4/ax_append_flag.m4 \ $(top_srcdir)/m4/ax_cflags_warn_all.m4 \ $(top_srcdir)/m4/ax_check_compile_flag.m4 \ $(top_srcdir)/m4/ax_require_defined.m4 \ $(top_srcdir)/m4/libtool.m4 $(top_srcdir)/m4/ltoptions.m4 \ $(top_srcdir)/m4/ltsugar.m4 $(top_srcdir)/m4/ltversion.m4 \ $(top_srcdir)/m4/lt~obsolete.m4 $(top_srcdir)/m4/pkg.m4 \ $(top_srcdir)/configure.ac am__configure_deps = $(am__aclocal_m4_deps) $(CONFIGURE_DEPENDENCIES) \ $(ACLOCAL_M4) DIST_COMMON = $(srcdir)/Makefile.am $(am__DIST_COMMON) mkinstalldirs = $(install_sh) -d CONFIG_HEADER = $(top_builddir)/config_ac.h CONFIG_CLEAN_FILES = libpainter.pc libpainter-uninstalled.pc CONFIG_CLEAN_VPATH_FILES = AM_V_P = $(am__v_P_@AM_V@) am__v_P_ = $(am__v_P_@AM_DEFAULT_V@) am__v_P_0 = false am__v_P_1 = : AM_V_GEN = $(am__v_GEN_@AM_V@) am__v_GEN_ = $(am__v_GEN_@AM_DEFAULT_V@) am__v_GEN_0 = @echo " GEN " $@; am__v_GEN_1 = AM_V_at = $(am__v_at_@AM_V@) am__v_at_ = $(am__v_at_@AM_DEFAULT_V@) am__v_at_0 = @ am__v_at_1 = SOURCES = DIST_SOURCES = am__can_run_installinfo = \ case $$AM_UPDATE_INFO_DIR in \ n|no|NO) false;; \ *) (install-info --version) >/dev/null 2>&1;; \ esac am__vpath_adj_setup = srcdirstrip=`echo "$(srcdir)" | sed 's|.|.|g'`; am__vpath_adj = case $$p in \ $(srcdir)/*) f=`echo "$$p" | sed "s|^$$srcdirstrip/||"`;; \ *) f=$$p;; \ esac; am__strip_dir = f=`echo $$p | sed -e 's|^.*/||'`; am__install_max = 40 am__nobase_strip_setup = \ srcdirstrip=`echo "$(srcdir)" | sed 's/[].[^$$\\*|]/\\\\&/g'` am__nobase_strip = \ for p in $$list; do echo "$$p"; done | sed -e "s|$$srcdirstrip/||" am__nobase_list = $(am__nobase_strip_setup); \ for p in $$list; do echo "$$p $$p"; done | \ sed "s| $$srcdirstrip/| |;"' / .*\//!s/ .*/ ./; s,\( .*\)/[^/]*$$,\1,' | \ $(AWK) 'BEGIN { files["."] = "" } { files[$$2] = files[$$2] " " $$1; \ if (++n[$$2] == $(am__install_max)) \ { print $$2, files[$$2]; n[$$2] = 0; files[$$2] = "" } } \ END { for (dir in files) print dir, files[dir] }' am__base_list = \ sed '$$!N;$$!N;$$!N;$$!N;$$!N;$$!N;$$!N;s/\n/ /g' | \ sed '$$!N;$$!N;$$!N;$$!N;s/\n/ /g' am__uninstall_files_from_dir = { \ test -z "$$files" \ || { test ! -d "$$dir" && test ! -f "$$dir" && test ! -r "$$dir"; } \ || { echo " ( cd '$$dir' && rm -f" $$files ")"; \ $(am__cd) "$$dir" && rm -f $$files; }; \ } am__installdirs = "$(DESTDIR)$(pkgconfigdir)" DATA = $(pkgconfig_DATA) am__tagged_files = $(HEADERS) $(SOURCES) $(TAGS_FILES) $(LISP) am__DIST_COMMON = $(srcdir)/Makefile.in \ $(srcdir)/libpainter-uninstalled.pc.in \ $(srcdir)/libpainter.pc.in DISTFILES = $(DIST_COMMON) $(DIST_SOURCES) $(TEXINFOS) $(EXTRA_DIST) ACLOCAL = @ACLOCAL@ AMTAR = @AMTAR@ AM_DEFAULT_VERBOSITY = @AM_DEFAULT_VERBOSITY@ AR = @AR@ AUTOCONF = @AUTOCONF@ AUTOHEADER = @AUTOHEADER@ AUTOMAKE = @AUTOMAKE@ AWK = @AWK@ CC = @CC@ CCDEPMODE = @CCDEPMODE@ CFLAGS = @CFLAGS@ CPP = @CPP@ CPPFLAGS = @CPPFLAGS@ CYGPATH_W = @CYGPATH_W@ DEFS = @DEFS@ DEPDIR = @DEPDIR@ DLLTOOL = @DLLTOOL@ DSYMUTIL = @DSYMUTIL@ DUMPBIN = @DUMPBIN@ ECHO_C = @ECHO_C@ ECHO_N = @ECHO_N@ ECHO_T = @ECHO_T@ EGREP = @EGREP@ EXEEXT = @EXEEXT@ FGREP = @FGREP@ GREP = @GREP@ INSTALL = @INSTALL@ INSTALL_DATA = @INSTALL_DATA@ INSTALL_PROGRAM = @INSTALL_PROGRAM@ INSTALL_SCRIPT = @INSTALL_SCRIPT@ INSTALL_STRIP_PROGRAM = @INSTALL_STRIP_PROGRAM@ LD = @LD@ LDFLAGS = @LDFLAGS@ LIBOBJS = @LIBOBJS@ LIBS = @LIBS@ LIBTOOL = @LIBTOOL@ LIPO = @LIPO@ LN_S = @LN_S@ LTLIBOBJS = @LTLIBOBJS@ LT_SYS_LIBRARY_PATH = @LT_SYS_LIBRARY_PATH@ MAKEINFO = @MAKEINFO@ MANIFEST_TOOL = @MANIFEST_TOOL@ MKDIR_P = @MKDIR_P@ NM = @NM@ NMEDIT = @NMEDIT@ OBJDUMP = @OBJDUMP@ OBJEXT = @OBJEXT@ OTOOL = @OTOOL@ OTOOL64 = @OTOOL64@ PACKAGE = @PACKAGE@ PACKAGE_BUGREPORT = @PACKAGE_BUGREPORT@ PACKAGE_NAME = @PACKAGE_NAME@ PACKAGE_STRING = @PACKAGE_STRING@ PACKAGE_TARNAME = @PACKAGE_TARNAME@ PACKAGE_URL = @PACKAGE_URL@ PACKAGE_VERSION = @PACKAGE_VERSION@ PATH_SEPARATOR = @PATH_SEPARATOR@ RANLIB = @RANLIB@ SED = @SED@ SET_MAKE = @SET_MAKE@ SHELL = @SHELL@ STRIP = @STRIP@ VERSION = @VERSION@ abs_builddir = @abs_builddir@ abs_srcdir = @abs_srcdir@ abs_top_builddir = @abs_top_builddir@ abs_top_srcdir = @abs_top_srcdir@ ac_ct_AR = @ac_ct_AR@ ac_ct_CC = @ac_ct_CC@ ac_ct_DUMPBIN = @ac_ct_DUMPBIN@ am__include = @am__include@ am__leading_dot = @am__leading_dot@ am__quote = @am__quote@ am__tar = @am__tar@ am__untar = @am__untar@ bindir = @bindir@ build = @build@ build_alias = @build_alias@ build_cpu = @build_cpu@ build_os = @build_os@ build_vendor = @build_vendor@ builddir = @builddir@ datadir = @datadir@ datarootdir = @datarootdir@ docdir = @docdir@ dvidir = @dvidir@ exec_prefix = @exec_prefix@ host = @host@ host_alias = @host_alias@ host_cpu = @host_cpu@ host_os = @host_os@ host_vendor = @host_vendor@ htmldir = @htmldir@ includedir = @includedir@ infodir = @infodir@ install_sh = @install_sh@ libdir = @libdir@ libexecdir = @libexecdir@ localedir = @localedir@ localstatedir = @localstatedir@ mandir = @mandir@ mkdir_p = @mkdir_p@ oldincludedir = @oldincludedir@ pdfdir = @pdfdir@ pkgconfigdir = @pkgconfigdir@ prefix = @prefix@ program_transform_name = @program_transform_name@ psdir = @psdir@ sbindir = @sbindir@ sharedstatedir = @sharedstatedir@ srcdir = @srcdir@ sysconfdir = @sysconfdir@ target_alias = @target_alias@ top_build_prefix = @top_build_prefix@ top_builddir = @top_builddir@ top_srcdir = @top_srcdir@ pkgconfig_DATA = libpainter.pc all: all-am .SUFFIXES: $(srcdir)/Makefile.in: $(srcdir)/Makefile.am $(am__configure_deps) @for dep in $?; do \ case '$(am__configure_deps)' in \ *$$dep*) \ ( cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh ) \ && { if test -f $@; then exit 0; else break; fi; }; \ exit 1;; \ esac; \ done; \ echo ' cd $(top_srcdir) && $(AUTOMAKE) --foreign pkgconfig/Makefile'; \ $(am__cd) $(top_srcdir) && \ $(AUTOMAKE) --foreign pkgconfig/Makefile Makefile: $(srcdir)/Makefile.in $(top_builddir)/config.status @case '$?' in \ *config.status*) \ cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh;; \ *) \ echo ' cd $(top_builddir) && $(SHELL) ./config.status $(subdir)/$@ $(am__depfiles_maybe)'; \ cd $(top_builddir) && $(SHELL) ./config.status $(subdir)/$@ $(am__depfiles_maybe);; \ esac; $(top_builddir)/config.status: $(top_srcdir)/configure $(CONFIG_STATUS_DEPENDENCIES) cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh $(top_srcdir)/configure: $(am__configure_deps) cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh $(ACLOCAL_M4): $(am__aclocal_m4_deps) cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh $(am__aclocal_m4_deps): libpainter.pc: $(top_builddir)/config.status $(srcdir)/libpainter.pc.in cd $(top_builddir) && $(SHELL) ./config.status $(subdir)/$@ libpainter-uninstalled.pc: $(top_builddir)/config.status $(srcdir)/libpainter-uninstalled.pc.in cd $(top_builddir) && $(SHELL) ./config.status $(subdir)/$@ mostlyclean-libtool: -rm -f *.lo clean-libtool: -rm -rf .libs _libs install-pkgconfigDATA: $(pkgconfig_DATA) @$(NORMAL_INSTALL) @list='$(pkgconfig_DATA)'; test -n "$(pkgconfigdir)" || list=; \ if test -n "$$list"; then \ echo " $(MKDIR_P) '$(DESTDIR)$(pkgconfigdir)'"; \ $(MKDIR_P) "$(DESTDIR)$(pkgconfigdir)" || exit 1; \ fi; \ for p in $$list; do \ if test -f "$$p"; then d=; else d="$(srcdir)/"; fi; \ echo "$$d$$p"; \ done | $(am__base_list) | \ while read files; do \ echo " $(INSTALL_DATA) $$files '$(DESTDIR)$(pkgconfigdir)'"; \ $(INSTALL_DATA) $$files "$(DESTDIR)$(pkgconfigdir)" || exit $$?; \ done uninstall-pkgconfigDATA: @$(NORMAL_UNINSTALL) @list='$(pkgconfig_DATA)'; test -n "$(pkgconfigdir)" || list=; \ files=`for p in $$list; do echo $$p; done | sed -e 's|^.*/||'`; \ dir='$(DESTDIR)$(pkgconfigdir)'; $(am__uninstall_files_from_dir) tags TAGS: ctags CTAGS: cscope cscopelist: distdir: $(DISTFILES) @srcdirstrip=`echo "$(srcdir)" | sed 's/[].[^$$\\*]/\\\\&/g'`; \ topsrcdirstrip=`echo "$(top_srcdir)" | sed 's/[].[^$$\\*]/\\\\&/g'`; \ list='$(DISTFILES)'; \ dist_files=`for file in $$list; do echo $$file; done | \ sed -e "s|^$$srcdirstrip/||;t" \ -e "s|^$$topsrcdirstrip/|$(top_builddir)/|;t"`; \ case $$dist_files in \ */*) $(MKDIR_P) `echo "$$dist_files" | \ sed '/\//!d;s|^|$(distdir)/|;s,/[^/]*$$,,' | \ sort -u` ;; \ esac; \ for file in $$dist_files; do \ if test -f $$file || test -d $$file; then d=.; else d=$(srcdir); fi; \ if test -d $$d/$$file; then \ dir=`echo "/$$file" | sed -e 's,/[^/]*$$,,'`; \ if test -d "$(distdir)/$$file"; then \ find "$(distdir)/$$file" -type d ! -perm -700 -exec chmod u+rwx {} \;; \ fi; \ if test -d $(srcdir)/$$file && test $$d != $(srcdir); then \ cp -fpR $(srcdir)/$$file "$(distdir)$$dir" || exit 1; \ find "$(distdir)/$$file" -type d ! -perm -700 -exec chmod u+rwx {} \;; \ fi; \ cp -fpR $$d/$$file "$(distdir)$$dir" || exit 1; \ else \ test -f "$(distdir)/$$file" \ || cp -p $$d/$$file "$(distdir)/$$file" \ || exit 1; \ fi; \ done check-am: all-am check: check-am all-am: Makefile $(DATA) installdirs: for dir in "$(DESTDIR)$(pkgconfigdir)"; do \ test -z "$$dir" || $(MKDIR_P) "$$dir"; \ done install: install-am install-exec: install-exec-am install-data: install-data-am uninstall: uninstall-am install-am: all-am @$(MAKE) $(AM_MAKEFLAGS) install-exec-am install-data-am installcheck: installcheck-am install-strip: if test -z '$(STRIP)'; then \ $(MAKE) $(AM_MAKEFLAGS) INSTALL_PROGRAM="$(INSTALL_STRIP_PROGRAM)" \ install_sh_PROGRAM="$(INSTALL_STRIP_PROGRAM)" INSTALL_STRIP_FLAG=-s \ install; \ else \ $(MAKE) $(AM_MAKEFLAGS) INSTALL_PROGRAM="$(INSTALL_STRIP_PROGRAM)" \ install_sh_PROGRAM="$(INSTALL_STRIP_PROGRAM)" INSTALL_STRIP_FLAG=-s \ "INSTALL_PROGRAM_ENV=STRIPPROG='$(STRIP)'" install; \ fi mostlyclean-generic: clean-generic: distclean-generic: -test -z "$(CONFIG_CLEAN_FILES)" || rm -f $(CONFIG_CLEAN_FILES) -test . = "$(srcdir)" || test -z "$(CONFIG_CLEAN_VPATH_FILES)" || rm -f $(CONFIG_CLEAN_VPATH_FILES) maintainer-clean-generic: @echo "This command is intended for maintainers to use" @echo "it deletes files that may require special tools to rebuild." clean: clean-am clean-am: clean-generic clean-libtool mostlyclean-am distclean: distclean-am -rm -f Makefile distclean-am: clean-am distclean-generic dvi: dvi-am dvi-am: html: html-am html-am: info: info-am info-am: install-data-am: install-pkgconfigDATA install-dvi: install-dvi-am install-dvi-am: install-exec-am: install-html: install-html-am install-html-am: install-info: install-info-am install-info-am: install-man: install-pdf: install-pdf-am install-pdf-am: install-ps: install-ps-am install-ps-am: installcheck-am: maintainer-clean: maintainer-clean-am -rm -f Makefile maintainer-clean-am: distclean-am maintainer-clean-generic mostlyclean: mostlyclean-am mostlyclean-am: mostlyclean-generic mostlyclean-libtool pdf: pdf-am pdf-am: ps: ps-am ps-am: uninstall-am: uninstall-pkgconfigDATA .MAKE: install-am install-strip .PHONY: all all-am check check-am clean clean-generic clean-libtool \ cscopelist-am ctags-am distclean distclean-generic \ distclean-libtool distdir dvi dvi-am html html-am info info-am \ install install-am install-data install-data-am install-dvi \ install-dvi-am install-exec install-exec-am install-html \ install-html-am install-info install-info-am install-man \ install-pdf install-pdf-am install-pkgconfigDATA install-ps \ install-ps-am install-strip installcheck installcheck-am \ installdirs maintainer-clean maintainer-clean-generic \ mostlyclean mostlyclean-generic mostlyclean-libtool pdf pdf-am \ ps ps-am tags-am uninstall uninstall-am \ uninstall-pkgconfigDATA .PRECIOUS: Makefile # Tell versions [3.59,3.63) of GNU make to not export all variables. # Otherwise a system limit (for SysV at least) may be exceeded. .NOEXPORT: xrdp-0.9.5/libpainter/tests/Makefile.in000644 001751 001751 00000047062 13220730741 017772 0ustar00metameta000000 000000 # Makefile.in generated by automake 1.15.1 from Makefile.am. # @configure_input@ # Copyright (C) 1994-2017 Free Software Foundation, Inc. # This Makefile.in is free software; the Free Software Foundation # gives unlimited permission to copy and/or distribute it, # with or without modifications, as long as this notice is preserved. # This program is distributed in the hope that it will be useful, # but WITHOUT ANY WARRANTY, to the extent permitted by law; without # even the implied warranty of MERCHANTABILITY or FITNESS FOR A # PARTICULAR PURPOSE. @SET_MAKE@ VPATH = @srcdir@ am__is_gnu_make = { \ if test -z '$(MAKELEVEL)'; then \ false; \ elif test -n '$(MAKE_HOST)'; then \ true; \ elif test -n '$(MAKE_VERSION)' && test -n '$(CURDIR)'; then \ true; \ else \ false; \ fi; \ } am__make_running_with_option = \ case $${target_option-} in \ ?) ;; \ *) echo "am__make_running_with_option: internal error: invalid" \ "target option '$${target_option-}' specified" >&2; \ exit 1;; \ esac; \ has_opt=no; \ sane_makeflags=$$MAKEFLAGS; \ if $(am__is_gnu_make); then \ sane_makeflags=$$MFLAGS; \ else \ case $$MAKEFLAGS in \ *\\[\ \ ]*) \ bs=\\; \ sane_makeflags=`printf '%s\n' "$$MAKEFLAGS" \ | sed "s/$$bs$$bs[$$bs $$bs ]*//g"`;; \ esac; \ fi; \ skip_next=no; \ strip_trailopt () \ { \ flg=`printf '%s\n' "$$flg" | sed "s/$$1.*$$//"`; \ }; \ for flg in $$sane_makeflags; do \ test $$skip_next = yes && { skip_next=no; continue; }; \ case $$flg in \ *=*|--*) continue;; \ -*I) strip_trailopt 'I'; skip_next=yes;; \ -*I?*) strip_trailopt 'I';; \ -*O) strip_trailopt 'O'; skip_next=yes;; \ -*O?*) strip_trailopt 'O';; \ -*l) strip_trailopt 'l'; skip_next=yes;; \ -*l?*) strip_trailopt 'l';; \ -[dEDm]) skip_next=yes;; \ -[JT]) skip_next=yes;; \ esac; \ case $$flg in \ *$$target_option*) has_opt=yes; break;; \ esac; \ done; \ test $$has_opt = yes am__make_dryrun = (target_option=n; $(am__make_running_with_option)) am__make_keepgoing = (target_option=k; $(am__make_running_with_option)) pkgdatadir = $(datadir)/@PACKAGE@ pkgincludedir = $(includedir)/@PACKAGE@ pkglibdir = $(libdir)/@PACKAGE@ pkglibexecdir = $(libexecdir)/@PACKAGE@ am__cd = CDPATH="$${ZSH_VERSION+.}$(PATH_SEPARATOR)" && cd install_sh_DATA = $(install_sh) -c -m 644 install_sh_PROGRAM = $(install_sh) -c install_sh_SCRIPT = $(install_sh) -c INSTALL_HEADER = $(INSTALL_DATA) transform = $(program_transform_name) NORMAL_INSTALL = : PRE_INSTALL = : POST_INSTALL = : NORMAL_UNINSTALL = : PRE_UNINSTALL = : POST_UNINSTALL = : build_triplet = @build@ host_triplet = @host@ bin_PROGRAMS = paintertest$(EXEEXT) subdir = tests ACLOCAL_M4 = $(top_srcdir)/aclocal.m4 am__aclocal_m4_deps = $(top_srcdir)/m4/ax_append_compile_flags.m4 \ $(top_srcdir)/m4/ax_append_flag.m4 \ $(top_srcdir)/m4/ax_cflags_warn_all.m4 \ $(top_srcdir)/m4/ax_check_compile_flag.m4 \ $(top_srcdir)/m4/ax_require_defined.m4 \ $(top_srcdir)/m4/libtool.m4 $(top_srcdir)/m4/ltoptions.m4 \ $(top_srcdir)/m4/ltsugar.m4 $(top_srcdir)/m4/ltversion.m4 \ $(top_srcdir)/m4/lt~obsolete.m4 $(top_srcdir)/m4/pkg.m4 \ $(top_srcdir)/configure.ac am__configure_deps = $(am__aclocal_m4_deps) $(CONFIGURE_DEPENDENCIES) \ $(ACLOCAL_M4) DIST_COMMON = $(srcdir)/Makefile.am $(am__DIST_COMMON) mkinstalldirs = $(install_sh) -d CONFIG_HEADER = $(top_builddir)/config_ac.h CONFIG_CLEAN_FILES = CONFIG_CLEAN_VPATH_FILES = am__installdirs = "$(DESTDIR)$(bindir)" PROGRAMS = $(bin_PROGRAMS) am_paintertest_OBJECTS = paintertest.$(OBJEXT) paintertest_OBJECTS = $(am_paintertest_OBJECTS) am__DEPENDENCIES_1 = paintertest_DEPENDENCIES = $(top_builddir)/src/libpainter.la \ $(am__DEPENDENCIES_1) AM_V_lt = $(am__v_lt_@AM_V@) am__v_lt_ = $(am__v_lt_@AM_DEFAULT_V@) am__v_lt_0 = --silent am__v_lt_1 = paintertest_LINK = $(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) \ $(LIBTOOLFLAGS) --mode=link $(CCLD) $(AM_CFLAGS) $(CFLAGS) \ $(paintertest_LDFLAGS) $(LDFLAGS) -o $@ AM_V_P = $(am__v_P_@AM_V@) am__v_P_ = $(am__v_P_@AM_DEFAULT_V@) am__v_P_0 = false am__v_P_1 = : AM_V_GEN = $(am__v_GEN_@AM_V@) am__v_GEN_ = $(am__v_GEN_@AM_DEFAULT_V@) am__v_GEN_0 = @echo " GEN " $@; am__v_GEN_1 = AM_V_at = $(am__v_at_@AM_V@) am__v_at_ = $(am__v_at_@AM_DEFAULT_V@) am__v_at_0 = @ am__v_at_1 = DEFAULT_INCLUDES = -I.@am__isrc@ -I$(top_builddir) depcomp = $(SHELL) $(top_srcdir)/depcomp am__depfiles_maybe = depfiles am__mv = mv -f COMPILE = $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) \ $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) LTCOMPILE = $(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) \ $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) \ $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) \ $(AM_CFLAGS) $(CFLAGS) AM_V_CC = $(am__v_CC_@AM_V@) am__v_CC_ = $(am__v_CC_@AM_DEFAULT_V@) am__v_CC_0 = @echo " CC " $@; am__v_CC_1 = CCLD = $(CC) LINK = $(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) \ $(LIBTOOLFLAGS) --mode=link $(CCLD) $(AM_CFLAGS) $(CFLAGS) \ $(AM_LDFLAGS) $(LDFLAGS) -o $@ AM_V_CCLD = $(am__v_CCLD_@AM_V@) am__v_CCLD_ = $(am__v_CCLD_@AM_DEFAULT_V@) am__v_CCLD_0 = @echo " CCLD " $@; am__v_CCLD_1 = SOURCES = $(paintertest_SOURCES) DIST_SOURCES = $(paintertest_SOURCES) am__can_run_installinfo = \ case $$AM_UPDATE_INFO_DIR in \ n|no|NO) false;; \ *) (install-info --version) >/dev/null 2>&1;; \ esac am__tagged_files = $(HEADERS) $(SOURCES) $(TAGS_FILES) $(LISP) # Read a list of newline-separated strings from the standard input, # and print each of them once, without duplicates. Input order is # *not* preserved. am__uniquify_input = $(AWK) '\ BEGIN { nonempty = 0; } \ { items[$$0] = 1; nonempty = 1; } \ END { if (nonempty) { for (i in items) print i; }; } \ ' # Make sure the list of sources is unique. This is necessary because, # e.g., the same source file might be shared among _SOURCES variables # for different programs/libraries. am__define_uniq_tagged_files = \ list='$(am__tagged_files)'; \ unique=`for i in $$list; do \ if test -f "$$i"; then echo $$i; else echo $(srcdir)/$$i; fi; \ done | $(am__uniquify_input)` ETAGS = etags CTAGS = ctags am__DIST_COMMON = $(srcdir)/Makefile.in $(top_srcdir)/depcomp DISTFILES = $(DIST_COMMON) $(DIST_SOURCES) $(TEXINFOS) $(EXTRA_DIST) ACLOCAL = @ACLOCAL@ AMTAR = @AMTAR@ AM_DEFAULT_VERBOSITY = @AM_DEFAULT_VERBOSITY@ AR = @AR@ AUTOCONF = @AUTOCONF@ AUTOHEADER = @AUTOHEADER@ AUTOMAKE = @AUTOMAKE@ AWK = @AWK@ CC = @CC@ CCDEPMODE = @CCDEPMODE@ CFLAGS = @CFLAGS@ CPP = @CPP@ CPPFLAGS = @CPPFLAGS@ CYGPATH_W = @CYGPATH_W@ DEFS = @DEFS@ DEPDIR = @DEPDIR@ DLLTOOL = @DLLTOOL@ DSYMUTIL = @DSYMUTIL@ DUMPBIN = @DUMPBIN@ ECHO_C = @ECHO_C@ ECHO_N = @ECHO_N@ ECHO_T = @ECHO_T@ EGREP = @EGREP@ EXEEXT = @EXEEXT@ FGREP = @FGREP@ GREP = @GREP@ INSTALL = @INSTALL@ INSTALL_DATA = @INSTALL_DATA@ INSTALL_PROGRAM = @INSTALL_PROGRAM@ INSTALL_SCRIPT = @INSTALL_SCRIPT@ INSTALL_STRIP_PROGRAM = @INSTALL_STRIP_PROGRAM@ LD = @LD@ LDFLAGS = @LDFLAGS@ LIBOBJS = @LIBOBJS@ LIBS = @LIBS@ LIBTOOL = @LIBTOOL@ LIPO = @LIPO@ LN_S = @LN_S@ LTLIBOBJS = @LTLIBOBJS@ LT_SYS_LIBRARY_PATH = @LT_SYS_LIBRARY_PATH@ MAKEINFO = @MAKEINFO@ MANIFEST_TOOL = @MANIFEST_TOOL@ MKDIR_P = @MKDIR_P@ NM = @NM@ NMEDIT = @NMEDIT@ OBJDUMP = @OBJDUMP@ OBJEXT = @OBJEXT@ OTOOL = @OTOOL@ OTOOL64 = @OTOOL64@ PACKAGE = @PACKAGE@ PACKAGE_BUGREPORT = @PACKAGE_BUGREPORT@ PACKAGE_NAME = @PACKAGE_NAME@ PACKAGE_STRING = @PACKAGE_STRING@ PACKAGE_TARNAME = @PACKAGE_TARNAME@ PACKAGE_URL = @PACKAGE_URL@ PACKAGE_VERSION = @PACKAGE_VERSION@ PATH_SEPARATOR = @PATH_SEPARATOR@ RANLIB = @RANLIB@ SED = @SED@ SET_MAKE = @SET_MAKE@ SHELL = @SHELL@ STRIP = @STRIP@ VERSION = @VERSION@ abs_builddir = @abs_builddir@ abs_srcdir = @abs_srcdir@ abs_top_builddir = @abs_top_builddir@ abs_top_srcdir = @abs_top_srcdir@ ac_ct_AR = @ac_ct_AR@ ac_ct_CC = @ac_ct_CC@ ac_ct_DUMPBIN = @ac_ct_DUMPBIN@ am__include = @am__include@ am__leading_dot = @am__leading_dot@ am__quote = @am__quote@ am__tar = @am__tar@ am__untar = @am__untar@ bindir = @bindir@ build = @build@ build_alias = @build_alias@ build_cpu = @build_cpu@ build_os = @build_os@ build_vendor = @build_vendor@ builddir = @builddir@ datadir = @datadir@ datarootdir = @datarootdir@ docdir = @docdir@ dvidir = @dvidir@ exec_prefix = @exec_prefix@ host = @host@ host_alias = @host_alias@ host_cpu = @host_cpu@ host_os = @host_os@ host_vendor = @host_vendor@ htmldir = @htmldir@ includedir = @includedir@ infodir = @infodir@ install_sh = @install_sh@ libdir = @libdir@ libexecdir = @libexecdir@ localedir = @localedir@ localstatedir = @localstatedir@ mandir = @mandir@ mkdir_p = @mkdir_p@ oldincludedir = @oldincludedir@ pdfdir = @pdfdir@ pkgconfigdir = @pkgconfigdir@ prefix = @prefix@ program_transform_name = @program_transform_name@ psdir = @psdir@ sbindir = @sbindir@ sharedstatedir = @sharedstatedir@ srcdir = @srcdir@ sysconfdir = @sysconfdir@ target_alias = @target_alias@ top_build_prefix = @top_build_prefix@ top_builddir = @top_builddir@ top_srcdir = @top_srcdir@ EXTRA_DIST = EXTRA_INCLUDES = EXTRA_LIBS = EXTRA_FLAGS = AM_CPPFLAGS = \ -I$(top_srcdir)/include \ $(EXTRA_INCLUDES) paintertest_SOURCES = paintertest.c paintertest_LDADD = \ $(top_builddir)/src/libpainter.la $(EXTRA_LIBS) paintertest_LDFLAGS = $(EXTRA_FLAGS) all: all-am .SUFFIXES: .SUFFIXES: .c .lo .o .obj $(srcdir)/Makefile.in: $(srcdir)/Makefile.am $(am__configure_deps) @for dep in $?; do \ case '$(am__configure_deps)' in \ *$$dep*) \ ( cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh ) \ && { if test -f $@; then exit 0; else break; fi; }; \ exit 1;; \ esac; \ done; \ echo ' cd $(top_srcdir) && $(AUTOMAKE) --foreign tests/Makefile'; \ $(am__cd) $(top_srcdir) && \ $(AUTOMAKE) --foreign tests/Makefile Makefile: $(srcdir)/Makefile.in $(top_builddir)/config.status @case '$?' in \ *config.status*) \ cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh;; \ *) \ echo ' cd $(top_builddir) && $(SHELL) ./config.status $(subdir)/$@ $(am__depfiles_maybe)'; \ cd $(top_builddir) && $(SHELL) ./config.status $(subdir)/$@ $(am__depfiles_maybe);; \ esac; $(top_builddir)/config.status: $(top_srcdir)/configure $(CONFIG_STATUS_DEPENDENCIES) cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh $(top_srcdir)/configure: $(am__configure_deps) cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh $(ACLOCAL_M4): $(am__aclocal_m4_deps) cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh $(am__aclocal_m4_deps): install-binPROGRAMS: $(bin_PROGRAMS) @$(NORMAL_INSTALL) @list='$(bin_PROGRAMS)'; test -n "$(bindir)" || list=; \ if test -n "$$list"; then \ echo " $(MKDIR_P) '$(DESTDIR)$(bindir)'"; \ $(MKDIR_P) "$(DESTDIR)$(bindir)" || exit 1; \ fi; \ for p in $$list; do echo "$$p $$p"; done | \ sed 's/$(EXEEXT)$$//' | \ while read p p1; do if test -f $$p \ || test -f $$p1 \ ; then echo "$$p"; echo "$$p"; else :; fi; \ done | \ sed -e 'p;s,.*/,,;n;h' \ -e 's|.*|.|' \ -e 'p;x;s,.*/,,;s/$(EXEEXT)$$//;$(transform);s/$$/$(EXEEXT)/' | \ sed 'N;N;N;s,\n, ,g' | \ $(AWK) 'BEGIN { files["."] = ""; dirs["."] = 1 } \ { d=$$3; if (dirs[d] != 1) { print "d", d; dirs[d] = 1 } \ if ($$2 == $$4) files[d] = files[d] " " $$1; \ else { print "f", $$3 "/" $$4, $$1; } } \ END { for (d in files) print "f", d, files[d] }' | \ while read type dir files; do \ if test "$$dir" = .; then dir=; else dir=/$$dir; fi; \ test -z "$$files" || { \ echo " $(INSTALL_PROGRAM_ENV) $(LIBTOOL) $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=install $(INSTALL_PROGRAM) $$files '$(DESTDIR)$(bindir)$$dir'"; \ $(INSTALL_PROGRAM_ENV) $(LIBTOOL) $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=install $(INSTALL_PROGRAM) $$files "$(DESTDIR)$(bindir)$$dir" || exit $$?; \ } \ ; done uninstall-binPROGRAMS: @$(NORMAL_UNINSTALL) @list='$(bin_PROGRAMS)'; test -n "$(bindir)" || list=; \ files=`for p in $$list; do echo "$$p"; done | \ sed -e 'h;s,^.*/,,;s/$(EXEEXT)$$//;$(transform)' \ -e 's/$$/$(EXEEXT)/' \ `; \ test -n "$$list" || exit 0; \ echo " ( cd '$(DESTDIR)$(bindir)' && rm -f" $$files ")"; \ cd "$(DESTDIR)$(bindir)" && rm -f $$files clean-binPROGRAMS: @list='$(bin_PROGRAMS)'; test -n "$$list" || exit 0; \ echo " rm -f" $$list; \ rm -f $$list || exit $$?; \ test -n "$(EXEEXT)" || exit 0; \ list=`for p in $$list; do echo "$$p"; done | sed 's/$(EXEEXT)$$//'`; \ echo " rm -f" $$list; \ rm -f $$list paintertest$(EXEEXT): $(paintertest_OBJECTS) $(paintertest_DEPENDENCIES) $(EXTRA_paintertest_DEPENDENCIES) @rm -f paintertest$(EXEEXT) $(AM_V_CCLD)$(paintertest_LINK) $(paintertest_OBJECTS) $(paintertest_LDADD) $(LIBS) mostlyclean-compile: -rm -f *.$(OBJEXT) distclean-compile: -rm -f *.tab.c @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/paintertest.Po@am__quote@ .c.o: @am__fastdepCC_TRUE@ $(AM_V_CC)$(COMPILE) -MT $@ -MD -MP -MF $(DEPDIR)/$*.Tpo -c -o $@ $< @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) $(DEPDIR)/$*.Tpo $(DEPDIR)/$*.Po @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='$<' object='$@' libtool=no @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(COMPILE) -c -o $@ $< .c.obj: @am__fastdepCC_TRUE@ $(AM_V_CC)$(COMPILE) -MT $@ -MD -MP -MF $(DEPDIR)/$*.Tpo -c -o $@ `$(CYGPATH_W) '$<'` @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) $(DEPDIR)/$*.Tpo $(DEPDIR)/$*.Po @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='$<' object='$@' libtool=no @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(COMPILE) -c -o $@ `$(CYGPATH_W) '$<'` .c.lo: @am__fastdepCC_TRUE@ $(AM_V_CC)$(LTCOMPILE) -MT $@ -MD -MP -MF $(DEPDIR)/$*.Tpo -c -o $@ $< @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) $(DEPDIR)/$*.Tpo $(DEPDIR)/$*.Plo @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='$<' object='$@' libtool=yes @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(LTCOMPILE) -c -o $@ $< mostlyclean-libtool: -rm -f *.lo clean-libtool: -rm -rf .libs _libs ID: $(am__tagged_files) $(am__define_uniq_tagged_files); mkid -fID $$unique tags: tags-am TAGS: tags tags-am: $(TAGS_DEPENDENCIES) $(am__tagged_files) set x; \ here=`pwd`; \ $(am__define_uniq_tagged_files); \ shift; \ if test -z "$(ETAGS_ARGS)$$*$$unique"; then :; else \ test -n "$$unique" || unique=$$empty_fix; \ if test $$# -gt 0; then \ $(ETAGS) $(ETAGSFLAGS) $(AM_ETAGSFLAGS) $(ETAGS_ARGS) \ "$$@" $$unique; \ else \ $(ETAGS) $(ETAGSFLAGS) $(AM_ETAGSFLAGS) $(ETAGS_ARGS) \ $$unique; \ fi; \ fi ctags: ctags-am CTAGS: ctags ctags-am: $(TAGS_DEPENDENCIES) $(am__tagged_files) $(am__define_uniq_tagged_files); \ test -z "$(CTAGS_ARGS)$$unique" \ || $(CTAGS) $(CTAGSFLAGS) $(AM_CTAGSFLAGS) $(CTAGS_ARGS) \ $$unique GTAGS: here=`$(am__cd) $(top_builddir) && pwd` \ && $(am__cd) $(top_srcdir) \ && gtags -i $(GTAGS_ARGS) "$$here" cscopelist: cscopelist-am cscopelist-am: $(am__tagged_files) list='$(am__tagged_files)'; \ case "$(srcdir)" in \ [\\/]* | ?:[\\/]*) sdir="$(srcdir)" ;; \ *) sdir=$(subdir)/$(srcdir) ;; \ esac; \ for i in $$list; do \ if test -f "$$i"; then \ echo "$(subdir)/$$i"; \ else \ echo "$$sdir/$$i"; \ fi; \ done >> $(top_builddir)/cscope.files distclean-tags: -rm -f TAGS ID GTAGS GRTAGS GSYMS GPATH tags distdir: $(DISTFILES) @srcdirstrip=`echo "$(srcdir)" | sed 's/[].[^$$\\*]/\\\\&/g'`; \ topsrcdirstrip=`echo "$(top_srcdir)" | sed 's/[].[^$$\\*]/\\\\&/g'`; \ list='$(DISTFILES)'; \ dist_files=`for file in $$list; do echo $$file; done | \ sed -e "s|^$$srcdirstrip/||;t" \ -e "s|^$$topsrcdirstrip/|$(top_builddir)/|;t"`; \ case $$dist_files in \ */*) $(MKDIR_P) `echo "$$dist_files" | \ sed '/\//!d;s|^|$(distdir)/|;s,/[^/]*$$,,' | \ sort -u` ;; \ esac; \ for file in $$dist_files; do \ if test -f $$file || test -d $$file; then d=.; else d=$(srcdir); fi; \ if test -d $$d/$$file; then \ dir=`echo "/$$file" | sed -e 's,/[^/]*$$,,'`; \ if test -d "$(distdir)/$$file"; then \ find "$(distdir)/$$file" -type d ! -perm -700 -exec chmod u+rwx {} \;; \ fi; \ if test -d $(srcdir)/$$file && test $$d != $(srcdir); then \ cp -fpR $(srcdir)/$$file "$(distdir)$$dir" || exit 1; \ find "$(distdir)/$$file" -type d ! -perm -700 -exec chmod u+rwx {} \;; \ fi; \ cp -fpR $$d/$$file "$(distdir)$$dir" || exit 1; \ else \ test -f "$(distdir)/$$file" \ || cp -p $$d/$$file "$(distdir)/$$file" \ || exit 1; \ fi; \ done check-am: all-am check: check-am all-am: Makefile $(PROGRAMS) installdirs: for dir in "$(DESTDIR)$(bindir)"; do \ test -z "$$dir" || $(MKDIR_P) "$$dir"; \ done install: install-am install-exec: install-exec-am install-data: install-data-am uninstall: uninstall-am install-am: all-am @$(MAKE) $(AM_MAKEFLAGS) install-exec-am install-data-am installcheck: installcheck-am install-strip: if test -z '$(STRIP)'; then \ $(MAKE) $(AM_MAKEFLAGS) INSTALL_PROGRAM="$(INSTALL_STRIP_PROGRAM)" \ install_sh_PROGRAM="$(INSTALL_STRIP_PROGRAM)" INSTALL_STRIP_FLAG=-s \ install; \ else \ $(MAKE) $(AM_MAKEFLAGS) INSTALL_PROGRAM="$(INSTALL_STRIP_PROGRAM)" \ install_sh_PROGRAM="$(INSTALL_STRIP_PROGRAM)" INSTALL_STRIP_FLAG=-s \ "INSTALL_PROGRAM_ENV=STRIPPROG='$(STRIP)'" install; \ fi mostlyclean-generic: clean-generic: distclean-generic: -test -z "$(CONFIG_CLEAN_FILES)" || rm -f $(CONFIG_CLEAN_FILES) -test . = "$(srcdir)" || test -z "$(CONFIG_CLEAN_VPATH_FILES)" || rm -f $(CONFIG_CLEAN_VPATH_FILES) maintainer-clean-generic: @echo "This command is intended for maintainers to use" @echo "it deletes files that may require special tools to rebuild." clean: clean-am clean-am: clean-binPROGRAMS clean-generic clean-libtool mostlyclean-am distclean: distclean-am -rm -rf ./$(DEPDIR) -rm -f Makefile distclean-am: clean-am distclean-compile distclean-generic \ distclean-tags dvi: dvi-am dvi-am: html: html-am html-am: info: info-am info-am: install-data-am: install-dvi: install-dvi-am install-dvi-am: install-exec-am: install-binPROGRAMS install-html: install-html-am install-html-am: install-info: install-info-am install-info-am: install-man: install-pdf: install-pdf-am install-pdf-am: install-ps: install-ps-am install-ps-am: installcheck-am: maintainer-clean: maintainer-clean-am -rm -rf ./$(DEPDIR) -rm -f Makefile maintainer-clean-am: distclean-am maintainer-clean-generic mostlyclean: mostlyclean-am mostlyclean-am: mostlyclean-compile mostlyclean-generic \ mostlyclean-libtool pdf: pdf-am pdf-am: ps: ps-am ps-am: uninstall-am: uninstall-binPROGRAMS .MAKE: install-am install-strip .PHONY: CTAGS GTAGS TAGS all all-am check check-am clean \ clean-binPROGRAMS clean-generic clean-libtool cscopelist-am \ ctags ctags-am distclean distclean-compile distclean-generic \ distclean-libtool distclean-tags distdir dvi dvi-am html \ html-am info info-am install install-am install-binPROGRAMS \ install-data install-data-am install-dvi install-dvi-am \ install-exec install-exec-am install-html install-html-am \ install-info install-info-am install-man install-pdf \ install-pdf-am install-ps install-ps-am install-strip \ installcheck installcheck-am installdirs maintainer-clean \ maintainer-clean-generic mostlyclean mostlyclean-compile \ mostlyclean-generic mostlyclean-libtool pdf pdf-am ps ps-am \ tags tags-am uninstall uninstall-am uninstall-binPROGRAMS .PRECIOUS: Makefile # Tell versions [3.59,3.63) of GNU make to not export all variables. # Otherwise a system limit (for SysV at least) may be exceeded. .NOEXPORT: xrdp-0.9.5/libpainter/tests/paintertest.c000644 001751 001751 00000000250 13061652764 020432 0ustar00metameta000000 000000 #if defined(HAVE_CONFIG_H) #include #endif #include #include #include int main(int argc, char **argv) { return 0; } xrdp-0.9.5/libpainter/tests/Makefile.am000644 001751 001751 00000000454 13061652764 017766 0ustar00metameta000000 000000 EXTRA_DIST = EXTRA_INCLUDES = EXTRA_LIBS = EXTRA_FLAGS = AM_CPPFLAGS = \ -I$(top_srcdir)/include \ $(EXTRA_INCLUDES) bin_PROGRAMS = paintertest paintertest_SOURCES = paintertest.c paintertest_LDADD = \ $(top_builddir)/src/libpainter.la $(EXTRA_LIBS) paintertest_LDFLAGS = $(EXTRA_FLAGS) xrdp-0.9.5/genkeymap/evdev-map.c000644 001751 001751 00000006446 13125122133 016435 0ustar00metameta000000 000000 /* -*- Mode: C; indent-tabs-mode: t; c-basic-offset: 4; tab-width: 4 -*- */ /* * evdev-map.c * Copyright (C) MichaÅ‚ Górny 2014 * * You may redistribute it and/or modify it under the terms of the * GNU General Public License, as published by the Free Software * Foundation; either version 2 of the License, or (at your option) * any later version. * * main.cc 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. * * You should have received a copy of the GNU General Public License * along with main.cc. If not, write to: * The Free Software Foundation, Inc., * 51 Franklin Street, Fifth Floor * Boston, MA 02110-1301, USA * * xfree86(base)->evdev keycode mapping */ int xfree86_to_evdev[137-8+1] = { /* MDSW */ 203, /* ESC */ 9, /* AE01 */ 10, /* AE02 */ 11, /* AE03 */ 12, /* AE04 */ 13, /* AE05 */ 14, /* AE06 */ 15, /* AE07 */ 16, /* AE08 */ 17, /* AE09 */ 18, /* AE10 */ 19, /* AE11 */ 20, /* AE12 */ 21, /* BKSP */ 22, /* TAB */ 23, /* AD01 */ 24, /* AD02 */ 25, /* AD03 */ 26, /* AD04 */ 27, /* AD05 */ 28, /* AD06 */ 29, /* AD07 */ 30, /* AD08 */ 31, /* AD09 */ 32, /* AD10 */ 33, /* AD11 */ 34, /* AD12 */ 35, /* RTRN */ 36, /* LCTL */ 37, /* AC01 */ 38, /* AC02 */ 39, /* AC03 */ 40, /* AC04 */ 41, /* AC05 */ 42, /* AC06 */ 43, /* AC07 */ 44, /* AC08 */ 45, /* AC09 */ 46, /* AC10 */ 47, /* AC11 */ 48, /* TLDE */ 49, /* LFSH */ 50, /* BKSL */ 51, /* AB01 */ 52, /* AB02 */ 53, /* AB03 */ 54, /* AB04 */ 55, /* AB05 */ 56, /* AB06 */ 57, /* AB07 */ 58, /* AB08 */ 59, /* AB09 */ 60, /* AB10 */ 61, /* RTSH */ 62, /* KPMU */ 63, /* LALT */ 64, /* SPCE */ 65, /* CAPS */ 66, /* FK01 */ 67, /* FK02 */ 68, /* FK03 */ 69, /* FK04 */ 70, /* FK05 */ 71, /* FK06 */ 72, /* FK07 */ 73, /* FK08 */ 74, /* FK09 */ 75, /* FK10 */ 76, /* NMLK */ 77, /* SCLK */ 78, /* KP7 */ 79, /* KP8 */ 80, /* KP9 */ 81, /* KPSU */ 82, /* KP4 */ 83, /* KP5 */ 84, /* KP6 */ 85, /* KPAD */ 86, /* KP1 */ 87, /* KP2 */ 88, /* KP3 */ 89, /* KP0 */ 90, /* KPDL */ 91, /* SYRQ */ 107, /* II5D */ 0, /* LSGT */ 94, /* FK11 */ 95, /* FK12 */ 96, /* HOME */ 110, /* UP */ 111, /* PGUP */ 112, /* LEFT */ 113, /* II65 */ 0, /* RGHT */ 114, /* END */ 115, /* DOWN */ 116, /* PGDN */ 117, /* INS */ 118, /* DELE */ 119, /* KPEN */ 104, /* RCTL */ 105, /* PAUS */ 127, /* PRSC */ 107, /* KPDV */ 106, /* RALT */ 108, /* BRK */ 419, /* LWIN */ 133, /* RWIN */ 134, /* MENU */ 0, /* FK13 */ 191, /* FK14 */ 192, /* FK15 */ 193, /* FK16 */ 194, /* FK17 */ 195, /* KPDC */ 0, /* LVL3 */ 92, /* ALT */ 204, /* KPEQ */ 125, /* SUPR */ 206, /* HYPR */ 207, /* XFER */ 0, /* I02 */ 0, /* NFER */ 0, /* I04 */ 0, /* AE13 */ 132, /* I06 */ 0, /* I07 */ 0, 0, 0 }; xrdp-0.9.5/genkeymap/genkeymap.c000644 001751 001751 00000010165 13174271344 016537 0ustar00metameta000000 000000 /* -*- Mode: C; indent-tabs-mode: t; c-basic-offset: 4; tab-width: 4 -*- */ /* * genkeymap.c * Copyright (C) Ãdám Wallner 2008 * * You may redistribute it and/or modify it under the terms of the * GNU General Public License, as published by the Free Software * Foundation; either version 2 of the License, or (at your option) * any later version. * * main.cc 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. * * You should have received a copy of the GNU General Public License * along with main.cc. If not, write to: * The Free Software Foundation, Inc., * 51 Franklin Street, Fifth Floor * Boston, MA 02110-1301, USA Updated Jay Sorg 2009 cs Czech 0x405 de German 0x407 en-us US English 0x409 fr French 0x40c it Italian 0x410 br Portuguese (Brazil) 0x416 ru Russian 0x419 se Swedish 0x41d en-uk UK English 0x809 */ #if defined(HAVE_CONFIG_H) #include #endif #include #include #include #include #include #include #include extern int xfree86_to_evdev[137-8]; int main(int argc, char **argv) { const char *programname; char text[256]; char *displayname = NULL; char *outfname; const char *sections[8] = { "noshift", "shift", "altgr", "shiftaltgr", "capslock", "capslockaltgr", "shiftcapslock", "shiftcapslockaltgr" }; int states[8] = {0, 1, 0x80, 0x81, 2, 0x82, 3, 0x83}; int i; int idx; int char_count; int nbytes = 0; int unicode; Display *dpy; KeySym ks; FILE *outf; XKeyPressedEvent e; wchar_t wtext[256]; XkbDescPtr kbdesc; char *symatom; int is_evdev; setlocale(LC_CTYPE, ""); programname = argv[0]; if (argc != 2) { fprintf(stderr, "Usage: %s out_filename\n", programname); fprintf(stderr, "Example: %s /etc/xrdp/km-00000409.ini\n", programname); return 1; } outfname = argv[1]; dpy = XOpenDisplay(displayname); if (!dpy) { fprintf(stderr, "%s: unable to open display '%s'\n", programname, XDisplayName(displayname)); return 1; } /* check whether evdev is used */ kbdesc = XkbAllocKeyboard(); if (!kbdesc) { fprintf(stderr, "%s: unable to allocate keyboard desc\n", programname); XCloseDisplay(dpy); return 1; } if (XkbGetNames(dpy, XkbKeycodesNameMask, kbdesc) != Success) { fprintf(stderr, "%s: unable to obtain keycode name for keyboard\n", programname); XkbFreeKeyboard(kbdesc, 0, True); XCloseDisplay(dpy); return 1; } symatom = XGetAtomName(dpy, kbdesc->names->keycodes); is_evdev = !strncmp(symatom, "evdev", 5); XFree(symatom); XkbFreeKeyboard(kbdesc, 0, True); outf = fopen(outfname, "w"); if (outf == NULL) { fprintf(stderr, "%s: unable to create file '%s'\n", programname, outfname); XCloseDisplay(dpy); return 1; } memset(&e, 0, sizeof(e)); e.type = KeyPress; e.serial = 16; e.send_event = True; e.display = dpy; e.same_screen = True; for (idx = 0; idx < 8; idx++) /* Sections and states */ { fprintf(outf, "[%s]\n", sections[idx]); e.state = states[idx]; for (i = 8; i <= 137; i++) /* Keycodes */ { if (is_evdev) e.keycode = xfree86_to_evdev[i-8]; else e.keycode = i; nbytes = XLookupString(&e, text, 255, &ks, NULL); text[nbytes] = 0; char_count = mbstowcs(wtext, text, 255); unicode = 0; if (char_count == 1) { unicode = wtext[0]; } fprintf(outf, "Key%d=%d:%d\n", i, (int) ks, unicode); } if (idx != 7) { fprintf(outf, "\n"); } } XCloseDisplay(dpy); fclose(outf); return 0; } xrdp-0.9.5/genkeymap/Makefile.am000644 001751 001751 00000000406 13133557325 016445 0ustar00metameta000000 000000 EXTRA_DIST = \ dump-keymaps.sh \ readme.txt AM_CFLAGS = $(X_CFLAGS) bin_PROGRAMS = \ xrdp-genkeymap xrdp_genkeymap_SOURCES = genkeymap.c evdev-map.c xrdp_genkeymap_LDFLAGS = \ $(X_LIBS) xrdp_genkeymap_LDADD = \ $(X_PRE_LIBS) -lX11 $(X_EXTRA_LIBS) xrdp-0.9.5/genkeymap/dump-keymaps.sh000755 001751 001751 00000002374 13220727201 017357 0ustar00metameta000000 000000 #!/bin/sh which setxkbmap if test $? -ne 0 then echo "error, setxkbmap not found" exit 1 fi # English - US 'en-us' 0x00000409 setxkbmap -model pc104 -layout us ./xrdp-genkeymap ../instfiles/km-00000409.ini # English - US 'dvorak' 0x00010409 setxkbmap -model pc104 -layout dvorak ./xrdp-genkeymap ../instfiles/km-00010409.ini # English - UK 'en-GB' 0x00000809 setxkbmap -model pc105 -layout gb ./xrdp-genkeymap ../instfiles/km-00000809.ini # German 'de' 0x00000407 setxkbmap -model pc104 -layout de ./xrdp-genkeymap ../instfiles/km-00000407.ini # Italian 'it' 0x00000410 setxkbmap -model pc104 -layout it ./xrdp-genkeymap ../instfiles/km-00000410.ini # Japanese 'jp' 0x00000411 setxkbmap -model pc105 -layout jp -variant OADG109A ./xrdp-genkeymap ../instfiles/km-00000411.ini # Polish 'pl' 0x00000415 setxkbmap -model pc104 -layout pl ./xrdp-genkeymap ../instfiles/km-00000415.ini # Russia 'ru' 0x00000419 setxkbmap -model pc104 -layout ru ./xrdp-genkeymap ../instfiles/km-00000419.ini # Sweden 'se' 0x0000041d setxkbmap -model pc104 -layout se ./xrdp-genkeymap ../instfiles/km-0000041d.ini # Portuguese -PT 'pt-pt' 0x00000816 setxkbmap -model pc104 -layout pt ./xrdp-genkeymap ../instfiles/km-00000816.ini # set back to en-us setxkbmap -model pc104 -layout us xrdp-0.9.5/genkeymap/readme.txt000644 001751 001751 00000002202 13127114621 016372 0ustar00metameta000000 000000 Creating a new keymap file. --------------------------- The names of the files are of the format; km-xxxxxxxx.ini where the xxxxxxxx is replaced by the hex number of the layout of interest. The files have 8 sections; [noshift], [shift], [altgr], [shiftaltgr], [capslock], [capslockaltgr], [shiftcapslock], [shiftcapslockaltgr] In each section there are multiple lines for each key. An example line looks like; Key10=49:49 In this line, 10 is the X11 scancode, the first 49 is the keysym value, the second 49 if the unicode value of the key. This is the definition for the 'noshift' '1' key on a en-us keyboard. In this case, the keysym and the unicode value are the same. Here is an example where they are not; This is the definition for the backspace key; Key22=65288:8 And this is the star on the keypad; Key63=65450:42 To create a new file run "xrdp-genkeymap " Example: ./xrdp-genkeymap /etc/xrdp/km-00000409.ini Note: You need to have enough rights to be able to write to the /etc/xrdp directory. Alternatively, create the keymap file in a directory of your choice, then copy or move it over to /etc/xrdp using sudo/su. xrdp-0.9.5/genkeymap/Makefile.in000644 001751 001751 00000050755 13220730774 016470 0ustar00metameta000000 000000 # Makefile.in generated by automake 1.15.1 from Makefile.am. # @configure_input@ # Copyright (C) 1994-2017 Free Software Foundation, Inc. # This Makefile.in is free software; the Free Software Foundation # gives unlimited permission to copy and/or distribute it, # with or without modifications, as long as this notice is preserved. # This program is distributed in the hope that it will be useful, # but WITHOUT ANY WARRANTY, to the extent permitted by law; without # even the implied warranty of MERCHANTABILITY or FITNESS FOR A # PARTICULAR PURPOSE. @SET_MAKE@ VPATH = @srcdir@ am__is_gnu_make = { \ if test -z '$(MAKELEVEL)'; then \ false; \ elif test -n '$(MAKE_HOST)'; then \ true; \ elif test -n '$(MAKE_VERSION)' && test -n '$(CURDIR)'; then \ true; \ else \ false; \ fi; \ } am__make_running_with_option = \ case $${target_option-} in \ ?) ;; \ *) echo "am__make_running_with_option: internal error: invalid" \ "target option '$${target_option-}' specified" >&2; \ exit 1;; \ esac; \ has_opt=no; \ sane_makeflags=$$MAKEFLAGS; \ if $(am__is_gnu_make); then \ sane_makeflags=$$MFLAGS; \ else \ case $$MAKEFLAGS in \ *\\[\ \ ]*) \ bs=\\; \ sane_makeflags=`printf '%s\n' "$$MAKEFLAGS" \ | sed "s/$$bs$$bs[$$bs $$bs ]*//g"`;; \ esac; \ fi; \ skip_next=no; \ strip_trailopt () \ { \ flg=`printf '%s\n' "$$flg" | sed "s/$$1.*$$//"`; \ }; \ for flg in $$sane_makeflags; do \ test $$skip_next = yes && { skip_next=no; continue; }; \ case $$flg in \ *=*|--*) continue;; \ -*I) strip_trailopt 'I'; skip_next=yes;; \ -*I?*) strip_trailopt 'I';; \ -*O) strip_trailopt 'O'; skip_next=yes;; \ -*O?*) strip_trailopt 'O';; \ -*l) strip_trailopt 'l'; skip_next=yes;; \ -*l?*) strip_trailopt 'l';; \ -[dEDm]) skip_next=yes;; \ -[JT]) skip_next=yes;; \ esac; \ case $$flg in \ *$$target_option*) has_opt=yes; break;; \ esac; \ done; \ test $$has_opt = yes am__make_dryrun = (target_option=n; $(am__make_running_with_option)) am__make_keepgoing = (target_option=k; $(am__make_running_with_option)) pkgdatadir = $(datadir)/@PACKAGE@ pkgincludedir = $(includedir)/@PACKAGE@ pkglibdir = $(libdir)/@PACKAGE@ pkglibexecdir = $(libexecdir)/@PACKAGE@ am__cd = CDPATH="$${ZSH_VERSION+.}$(PATH_SEPARATOR)" && cd install_sh_DATA = $(install_sh) -c -m 644 install_sh_PROGRAM = $(install_sh) -c install_sh_SCRIPT = $(install_sh) -c INSTALL_HEADER = $(INSTALL_DATA) transform = $(program_transform_name) NORMAL_INSTALL = : PRE_INSTALL = : POST_INSTALL = : NORMAL_UNINSTALL = : PRE_UNINSTALL = : POST_UNINSTALL = : build_triplet = @build@ host_triplet = @host@ bin_PROGRAMS = xrdp-genkeymap$(EXEEXT) subdir = genkeymap ACLOCAL_M4 = $(top_srcdir)/aclocal.m4 am__aclocal_m4_deps = $(top_srcdir)/m4/ax_append_compile_flags.m4 \ $(top_srcdir)/m4/ax_append_flag.m4 \ $(top_srcdir)/m4/ax_cflags_warn_all.m4 \ $(top_srcdir)/m4/ax_check_compile_flag.m4 \ $(top_srcdir)/m4/ax_gcc_func_attribute.m4 \ $(top_srcdir)/m4/ax_require_defined.m4 \ $(top_srcdir)/m4/ax_type_socklen_t.m4 \ $(top_srcdir)/m4/libtool.m4 $(top_srcdir)/m4/ltoptions.m4 \ $(top_srcdir)/m4/ltsugar.m4 $(top_srcdir)/m4/ltversion.m4 \ $(top_srcdir)/m4/lt~obsolete.m4 $(top_srcdir)/m4/pkg.m4 \ $(top_srcdir)/configure.ac am__configure_deps = $(am__aclocal_m4_deps) $(CONFIGURE_DEPENDENCIES) \ $(ACLOCAL_M4) DIST_COMMON = $(srcdir)/Makefile.am $(am__DIST_COMMON) mkinstalldirs = $(install_sh) -d CONFIG_HEADER = $(top_builddir)/config_ac.h CONFIG_CLEAN_FILES = CONFIG_CLEAN_VPATH_FILES = am__installdirs = "$(DESTDIR)$(bindir)" PROGRAMS = $(bin_PROGRAMS) am_xrdp_genkeymap_OBJECTS = genkeymap.$(OBJEXT) evdev-map.$(OBJEXT) xrdp_genkeymap_OBJECTS = $(am_xrdp_genkeymap_OBJECTS) am__DEPENDENCIES_1 = xrdp_genkeymap_DEPENDENCIES = $(am__DEPENDENCIES_1) \ $(am__DEPENDENCIES_1) AM_V_lt = $(am__v_lt_@AM_V@) am__v_lt_ = $(am__v_lt_@AM_DEFAULT_V@) am__v_lt_0 = --silent am__v_lt_1 = xrdp_genkeymap_LINK = $(LIBTOOL) $(AM_V_lt) --tag=CC \ $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=link $(CCLD) \ $(AM_CFLAGS) $(CFLAGS) $(xrdp_genkeymap_LDFLAGS) $(LDFLAGS) -o \ $@ AM_V_P = $(am__v_P_@AM_V@) am__v_P_ = $(am__v_P_@AM_DEFAULT_V@) am__v_P_0 = false am__v_P_1 = : AM_V_GEN = $(am__v_GEN_@AM_V@) am__v_GEN_ = $(am__v_GEN_@AM_DEFAULT_V@) am__v_GEN_0 = @echo " GEN " $@; am__v_GEN_1 = AM_V_at = $(am__v_at_@AM_V@) am__v_at_ = $(am__v_at_@AM_DEFAULT_V@) am__v_at_0 = @ am__v_at_1 = DEFAULT_INCLUDES = -I.@am__isrc@ -I$(top_builddir) depcomp = $(SHELL) $(top_srcdir)/depcomp am__depfiles_maybe = depfiles am__mv = mv -f COMPILE = $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) \ $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) LTCOMPILE = $(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) \ $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) \ $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) \ $(AM_CFLAGS) $(CFLAGS) AM_V_CC = $(am__v_CC_@AM_V@) am__v_CC_ = $(am__v_CC_@AM_DEFAULT_V@) am__v_CC_0 = @echo " CC " $@; am__v_CC_1 = CCLD = $(CC) LINK = $(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) \ $(LIBTOOLFLAGS) --mode=link $(CCLD) $(AM_CFLAGS) $(CFLAGS) \ $(AM_LDFLAGS) $(LDFLAGS) -o $@ AM_V_CCLD = $(am__v_CCLD_@AM_V@) am__v_CCLD_ = $(am__v_CCLD_@AM_DEFAULT_V@) am__v_CCLD_0 = @echo " CCLD " $@; am__v_CCLD_1 = SOURCES = $(xrdp_genkeymap_SOURCES) DIST_SOURCES = $(xrdp_genkeymap_SOURCES) am__can_run_installinfo = \ case $$AM_UPDATE_INFO_DIR in \ n|no|NO) false;; \ *) (install-info --version) >/dev/null 2>&1;; \ esac am__tagged_files = $(HEADERS) $(SOURCES) $(TAGS_FILES) $(LISP) # Read a list of newline-separated strings from the standard input, # and print each of them once, without duplicates. Input order is # *not* preserved. am__uniquify_input = $(AWK) '\ BEGIN { nonempty = 0; } \ { items[$$0] = 1; nonempty = 1; } \ END { if (nonempty) { for (i in items) print i; }; } \ ' # Make sure the list of sources is unique. This is necessary because, # e.g., the same source file might be shared among _SOURCES variables # for different programs/libraries. am__define_uniq_tagged_files = \ list='$(am__tagged_files)'; \ unique=`for i in $$list; do \ if test -f "$$i"; then echo $$i; else echo $(srcdir)/$$i; fi; \ done | $(am__uniquify_input)` ETAGS = etags CTAGS = ctags am__DIST_COMMON = $(srcdir)/Makefile.in $(top_srcdir)/depcomp DISTFILES = $(DIST_COMMON) $(DIST_SOURCES) $(TEXINFOS) $(EXTRA_DIST) ACLOCAL = @ACLOCAL@ AMTAR = @AMTAR@ AM_DEFAULT_VERBOSITY = @AM_DEFAULT_VERBOSITY@ AR = @AR@ AUTOCONF = @AUTOCONF@ AUTOHEADER = @AUTOHEADER@ AUTOMAKE = @AUTOMAKE@ AWK = @AWK@ CC = @CC@ CCDEPMODE = @CCDEPMODE@ CFLAGS = @CFLAGS@ CPP = @CPP@ CPPFLAGS = @CPPFLAGS@ CYGPATH_W = @CYGPATH_W@ DEFS = @DEFS@ DEPDIR = @DEPDIR@ DLLTOOL = @DLLTOOL@ DLOPEN_LIBS = @DLOPEN_LIBS@ DSYMUTIL = @DSYMUTIL@ DUMPBIN = @DUMPBIN@ ECHO_C = @ECHO_C@ ECHO_N = @ECHO_N@ ECHO_T = @ECHO_T@ EGREP = @EGREP@ EXEEXT = @EXEEXT@ FDKAAC_CFLAGS = @FDKAAC_CFLAGS@ FDKAAC_LIBS = @FDKAAC_LIBS@ FGREP = @FGREP@ FREERDP_CFLAGS = @FREERDP_CFLAGS@ FREERDP_LIBS = @FREERDP_LIBS@ FUSE_CFLAGS = @FUSE_CFLAGS@ FUSE_LIBS = @FUSE_LIBS@ GREP = @GREP@ INSTALL = @INSTALL@ INSTALL_DATA = @INSTALL_DATA@ INSTALL_PROGRAM = @INSTALL_PROGRAM@ INSTALL_SCRIPT = @INSTALL_SCRIPT@ INSTALL_STRIP_PROGRAM = @INSTALL_STRIP_PROGRAM@ LD = @LD@ LDFLAGS = @LDFLAGS@ LIBOBJS = @LIBOBJS@ LIBS = @LIBS@ LIBTOOL = @LIBTOOL@ LIPO = @LIPO@ LN_S = @LN_S@ LTLIBOBJS = @LTLIBOBJS@ LT_SYS_LIBRARY_PATH = @LT_SYS_LIBRARY_PATH@ MAKEINFO = @MAKEINFO@ MANIFEST_TOOL = @MANIFEST_TOOL@ MKDIR_P = @MKDIR_P@ NM = @NM@ NMEDIT = @NMEDIT@ OBJDUMP = @OBJDUMP@ OBJEXT = @OBJEXT@ OPENSSL = @OPENSSL@ OPENSSL_CFLAGS = @OPENSSL_CFLAGS@ OPENSSL_LIBS = @OPENSSL_LIBS@ OTOOL = @OTOOL@ OTOOL64 = @OTOOL64@ PACKAGE = @PACKAGE@ PACKAGE_BUGREPORT = @PACKAGE_BUGREPORT@ PACKAGE_NAME = @PACKAGE_NAME@ PACKAGE_STRING = @PACKAGE_STRING@ PACKAGE_TARNAME = @PACKAGE_TARNAME@ PACKAGE_URL = @PACKAGE_URL@ PACKAGE_VERSION = @PACKAGE_VERSION@ PAM_RULES = @PAM_RULES@ PATH_SEPARATOR = @PATH_SEPARATOR@ PIXMAN_CFLAGS = @PIXMAN_CFLAGS@ PIXMAN_LIBS = @PIXMAN_LIBS@ PKG_CONFIG = @PKG_CONFIG@ PKG_CONFIG_LIBDIR = @PKG_CONFIG_LIBDIR@ PKG_CONFIG_PATH = @PKG_CONFIG_PATH@ RANLIB = @RANLIB@ SED = @SED@ SET_MAKE = @SET_MAKE@ SHELL = @SHELL@ STRIP = @STRIP@ TurboJpegIncDir = @TurboJpegIncDir@ TurboJpegLibDir = @TurboJpegLibDir@ VERSION = @VERSION@ XMKMF = @XMKMF@ X_CFLAGS = @X_CFLAGS@ X_EXTRA_LIBS = @X_EXTRA_LIBS@ X_LIBS = @X_LIBS@ X_PRE_LIBS = @X_PRE_LIBS@ abs_builddir = @abs_builddir@ abs_srcdir = @abs_srcdir@ abs_top_builddir = @abs_top_builddir@ abs_top_srcdir = @abs_top_srcdir@ ac_ct_AR = @ac_ct_AR@ ac_ct_CC = @ac_ct_CC@ ac_ct_DUMPBIN = @ac_ct_DUMPBIN@ am__include = @am__include@ am__leading_dot = @am__leading_dot@ am__quote = @am__quote@ am__tar = @am__tar@ am__untar = @am__untar@ bindir = @bindir@ build = @build@ build_alias = @build_alias@ build_cpu = @build_cpu@ build_os = @build_os@ build_vendor = @build_vendor@ builddir = @builddir@ datadir = @datadir@ datarootdir = @datarootdir@ docdir = @docdir@ dvidir = @dvidir@ exec_prefix = @exec_prefix@ host = @host@ host_alias = @host_alias@ host_cpu = @host_cpu@ host_os = @host_os@ host_vendor = @host_vendor@ htmldir = @htmldir@ includedir = @includedir@ infodir = @infodir@ install_sh = @install_sh@ libdir = @libdir@ libexecdir = @libexecdir@ localedir = @localedir@ localstatedir = @localstatedir@ mandir = @mandir@ mkdir_p = @mkdir_p@ moduledir = @moduledir@ oldincludedir = @oldincludedir@ pdfdir = @pdfdir@ pkgconfigdir = @pkgconfigdir@ prefix = @prefix@ program_transform_name = @program_transform_name@ psdir = @psdir@ sbindir = @sbindir@ sharedstatedir = @sharedstatedir@ socketdir = @socketdir@ srcdir = @srcdir@ subdirs = @subdirs@ sysconfdir = @sysconfdir@ systemdsystemunitdir = @systemdsystemunitdir@ target_alias = @target_alias@ top_build_prefix = @top_build_prefix@ top_builddir = @top_builddir@ top_srcdir = @top_srcdir@ EXTRA_DIST = \ dump-keymaps.sh \ readme.txt AM_CFLAGS = $(X_CFLAGS) xrdp_genkeymap_SOURCES = genkeymap.c evdev-map.c xrdp_genkeymap_LDFLAGS = \ $(X_LIBS) xrdp_genkeymap_LDADD = \ $(X_PRE_LIBS) -lX11 $(X_EXTRA_LIBS) all: all-am .SUFFIXES: .SUFFIXES: .c .lo .o .obj $(srcdir)/Makefile.in: $(srcdir)/Makefile.am $(am__configure_deps) @for dep in $?; do \ case '$(am__configure_deps)' in \ *$$dep*) \ ( cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh ) \ && { if test -f $@; then exit 0; else break; fi; }; \ exit 1;; \ esac; \ done; \ echo ' cd $(top_srcdir) && $(AUTOMAKE) --foreign genkeymap/Makefile'; \ $(am__cd) $(top_srcdir) && \ $(AUTOMAKE) --foreign genkeymap/Makefile Makefile: $(srcdir)/Makefile.in $(top_builddir)/config.status @case '$?' in \ *config.status*) \ cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh;; \ *) \ echo ' cd $(top_builddir) && $(SHELL) ./config.status $(subdir)/$@ $(am__depfiles_maybe)'; \ cd $(top_builddir) && $(SHELL) ./config.status $(subdir)/$@ $(am__depfiles_maybe);; \ esac; $(top_builddir)/config.status: $(top_srcdir)/configure $(CONFIG_STATUS_DEPENDENCIES) cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh $(top_srcdir)/configure: $(am__configure_deps) cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh $(ACLOCAL_M4): $(am__aclocal_m4_deps) cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh $(am__aclocal_m4_deps): install-binPROGRAMS: $(bin_PROGRAMS) @$(NORMAL_INSTALL) @list='$(bin_PROGRAMS)'; test -n "$(bindir)" || list=; \ if test -n "$$list"; then \ echo " $(MKDIR_P) '$(DESTDIR)$(bindir)'"; \ $(MKDIR_P) "$(DESTDIR)$(bindir)" || exit 1; \ fi; \ for p in $$list; do echo "$$p $$p"; done | \ sed 's/$(EXEEXT)$$//' | \ while read p p1; do if test -f $$p \ || test -f $$p1 \ ; then echo "$$p"; echo "$$p"; else :; fi; \ done | \ sed -e 'p;s,.*/,,;n;h' \ -e 's|.*|.|' \ -e 'p;x;s,.*/,,;s/$(EXEEXT)$$//;$(transform);s/$$/$(EXEEXT)/' | \ sed 'N;N;N;s,\n, ,g' | \ $(AWK) 'BEGIN { files["."] = ""; dirs["."] = 1 } \ { d=$$3; if (dirs[d] != 1) { print "d", d; dirs[d] = 1 } \ if ($$2 == $$4) files[d] = files[d] " " $$1; \ else { print "f", $$3 "/" $$4, $$1; } } \ END { for (d in files) print "f", d, files[d] }' | \ while read type dir files; do \ if test "$$dir" = .; then dir=; else dir=/$$dir; fi; \ test -z "$$files" || { \ echo " $(INSTALL_PROGRAM_ENV) $(LIBTOOL) $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=install $(INSTALL_PROGRAM) $$files '$(DESTDIR)$(bindir)$$dir'"; \ $(INSTALL_PROGRAM_ENV) $(LIBTOOL) $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=install $(INSTALL_PROGRAM) $$files "$(DESTDIR)$(bindir)$$dir" || exit $$?; \ } \ ; done uninstall-binPROGRAMS: @$(NORMAL_UNINSTALL) @list='$(bin_PROGRAMS)'; test -n "$(bindir)" || list=; \ files=`for p in $$list; do echo "$$p"; done | \ sed -e 'h;s,^.*/,,;s/$(EXEEXT)$$//;$(transform)' \ -e 's/$$/$(EXEEXT)/' \ `; \ test -n "$$list" || exit 0; \ echo " ( cd '$(DESTDIR)$(bindir)' && rm -f" $$files ")"; \ cd "$(DESTDIR)$(bindir)" && rm -f $$files clean-binPROGRAMS: @list='$(bin_PROGRAMS)'; test -n "$$list" || exit 0; \ echo " rm -f" $$list; \ rm -f $$list || exit $$?; \ test -n "$(EXEEXT)" || exit 0; \ list=`for p in $$list; do echo "$$p"; done | sed 's/$(EXEEXT)$$//'`; \ echo " rm -f" $$list; \ rm -f $$list xrdp-genkeymap$(EXEEXT): $(xrdp_genkeymap_OBJECTS) $(xrdp_genkeymap_DEPENDENCIES) $(EXTRA_xrdp_genkeymap_DEPENDENCIES) @rm -f xrdp-genkeymap$(EXEEXT) $(AM_V_CCLD)$(xrdp_genkeymap_LINK) $(xrdp_genkeymap_OBJECTS) $(xrdp_genkeymap_LDADD) $(LIBS) mostlyclean-compile: -rm -f *.$(OBJEXT) distclean-compile: -rm -f *.tab.c @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/evdev-map.Po@am__quote@ @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/genkeymap.Po@am__quote@ .c.o: @am__fastdepCC_TRUE@ $(AM_V_CC)$(COMPILE) -MT $@ -MD -MP -MF $(DEPDIR)/$*.Tpo -c -o $@ $< @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) $(DEPDIR)/$*.Tpo $(DEPDIR)/$*.Po @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='$<' object='$@' libtool=no @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(COMPILE) -c -o $@ $< .c.obj: @am__fastdepCC_TRUE@ $(AM_V_CC)$(COMPILE) -MT $@ -MD -MP -MF $(DEPDIR)/$*.Tpo -c -o $@ `$(CYGPATH_W) '$<'` @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) $(DEPDIR)/$*.Tpo $(DEPDIR)/$*.Po @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='$<' object='$@' libtool=no @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(COMPILE) -c -o $@ `$(CYGPATH_W) '$<'` .c.lo: @am__fastdepCC_TRUE@ $(AM_V_CC)$(LTCOMPILE) -MT $@ -MD -MP -MF $(DEPDIR)/$*.Tpo -c -o $@ $< @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) $(DEPDIR)/$*.Tpo $(DEPDIR)/$*.Plo @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='$<' object='$@' libtool=yes @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(LTCOMPILE) -c -o $@ $< mostlyclean-libtool: -rm -f *.lo clean-libtool: -rm -rf .libs _libs ID: $(am__tagged_files) $(am__define_uniq_tagged_files); mkid -fID $$unique tags: tags-am TAGS: tags tags-am: $(TAGS_DEPENDENCIES) $(am__tagged_files) set x; \ here=`pwd`; \ $(am__define_uniq_tagged_files); \ shift; \ if test -z "$(ETAGS_ARGS)$$*$$unique"; then :; else \ test -n "$$unique" || unique=$$empty_fix; \ if test $$# -gt 0; then \ $(ETAGS) $(ETAGSFLAGS) $(AM_ETAGSFLAGS) $(ETAGS_ARGS) \ "$$@" $$unique; \ else \ $(ETAGS) $(ETAGSFLAGS) $(AM_ETAGSFLAGS) $(ETAGS_ARGS) \ $$unique; \ fi; \ fi ctags: ctags-am CTAGS: ctags ctags-am: $(TAGS_DEPENDENCIES) $(am__tagged_files) $(am__define_uniq_tagged_files); \ test -z "$(CTAGS_ARGS)$$unique" \ || $(CTAGS) $(CTAGSFLAGS) $(AM_CTAGSFLAGS) $(CTAGS_ARGS) \ $$unique GTAGS: here=`$(am__cd) $(top_builddir) && pwd` \ && $(am__cd) $(top_srcdir) \ && gtags -i $(GTAGS_ARGS) "$$here" cscopelist: cscopelist-am cscopelist-am: $(am__tagged_files) list='$(am__tagged_files)'; \ case "$(srcdir)" in \ [\\/]* | ?:[\\/]*) sdir="$(srcdir)" ;; \ *) sdir=$(subdir)/$(srcdir) ;; \ esac; \ for i in $$list; do \ if test -f "$$i"; then \ echo "$(subdir)/$$i"; \ else \ echo "$$sdir/$$i"; \ fi; \ done >> $(top_builddir)/cscope.files distclean-tags: -rm -f TAGS ID GTAGS GRTAGS GSYMS GPATH tags distdir: $(DISTFILES) @srcdirstrip=`echo "$(srcdir)" | sed 's/[].[^$$\\*]/\\\\&/g'`; \ topsrcdirstrip=`echo "$(top_srcdir)" | sed 's/[].[^$$\\*]/\\\\&/g'`; \ list='$(DISTFILES)'; \ dist_files=`for file in $$list; do echo $$file; done | \ sed -e "s|^$$srcdirstrip/||;t" \ -e "s|^$$topsrcdirstrip/|$(top_builddir)/|;t"`; \ case $$dist_files in \ */*) $(MKDIR_P) `echo "$$dist_files" | \ sed '/\//!d;s|^|$(distdir)/|;s,/[^/]*$$,,' | \ sort -u` ;; \ esac; \ for file in $$dist_files; do \ if test -f $$file || test -d $$file; then d=.; else d=$(srcdir); fi; \ if test -d $$d/$$file; then \ dir=`echo "/$$file" | sed -e 's,/[^/]*$$,,'`; \ if test -d "$(distdir)/$$file"; then \ find "$(distdir)/$$file" -type d ! -perm -700 -exec chmod u+rwx {} \;; \ fi; \ if test -d $(srcdir)/$$file && test $$d != $(srcdir); then \ cp -fpR $(srcdir)/$$file "$(distdir)$$dir" || exit 1; \ find "$(distdir)/$$file" -type d ! -perm -700 -exec chmod u+rwx {} \;; \ fi; \ cp -fpR $$d/$$file "$(distdir)$$dir" || exit 1; \ else \ test -f "$(distdir)/$$file" \ || cp -p $$d/$$file "$(distdir)/$$file" \ || exit 1; \ fi; \ done check-am: all-am check: check-am all-am: Makefile $(PROGRAMS) installdirs: for dir in "$(DESTDIR)$(bindir)"; do \ test -z "$$dir" || $(MKDIR_P) "$$dir"; \ done install: install-am install-exec: install-exec-am install-data: install-data-am uninstall: uninstall-am install-am: all-am @$(MAKE) $(AM_MAKEFLAGS) install-exec-am install-data-am installcheck: installcheck-am install-strip: if test -z '$(STRIP)'; then \ $(MAKE) $(AM_MAKEFLAGS) INSTALL_PROGRAM="$(INSTALL_STRIP_PROGRAM)" \ install_sh_PROGRAM="$(INSTALL_STRIP_PROGRAM)" INSTALL_STRIP_FLAG=-s \ install; \ else \ $(MAKE) $(AM_MAKEFLAGS) INSTALL_PROGRAM="$(INSTALL_STRIP_PROGRAM)" \ install_sh_PROGRAM="$(INSTALL_STRIP_PROGRAM)" INSTALL_STRIP_FLAG=-s \ "INSTALL_PROGRAM_ENV=STRIPPROG='$(STRIP)'" install; \ fi mostlyclean-generic: clean-generic: distclean-generic: -test -z "$(CONFIG_CLEAN_FILES)" || rm -f $(CONFIG_CLEAN_FILES) -test . = "$(srcdir)" || test -z "$(CONFIG_CLEAN_VPATH_FILES)" || rm -f $(CONFIG_CLEAN_VPATH_FILES) maintainer-clean-generic: @echo "This command is intended for maintainers to use" @echo "it deletes files that may require special tools to rebuild." clean: clean-am clean-am: clean-binPROGRAMS clean-generic clean-libtool mostlyclean-am distclean: distclean-am -rm -rf ./$(DEPDIR) -rm -f Makefile distclean-am: clean-am distclean-compile distclean-generic \ distclean-tags dvi: dvi-am dvi-am: html: html-am html-am: info: info-am info-am: install-data-am: install-dvi: install-dvi-am install-dvi-am: install-exec-am: install-binPROGRAMS install-html: install-html-am install-html-am: install-info: install-info-am install-info-am: install-man: install-pdf: install-pdf-am install-pdf-am: install-ps: install-ps-am install-ps-am: installcheck-am: maintainer-clean: maintainer-clean-am -rm -rf ./$(DEPDIR) -rm -f Makefile maintainer-clean-am: distclean-am maintainer-clean-generic mostlyclean: mostlyclean-am mostlyclean-am: mostlyclean-compile mostlyclean-generic \ mostlyclean-libtool pdf: pdf-am pdf-am: ps: ps-am ps-am: uninstall-am: uninstall-binPROGRAMS .MAKE: install-am install-strip .PHONY: CTAGS GTAGS TAGS all all-am check check-am clean \ clean-binPROGRAMS clean-generic clean-libtool cscopelist-am \ ctags ctags-am distclean distclean-compile distclean-generic \ distclean-libtool distclean-tags distdir dvi dvi-am html \ html-am info info-am install install-am install-binPROGRAMS \ install-data install-data-am install-dvi install-dvi-am \ install-exec install-exec-am install-html install-html-am \ install-info install-info-am install-man install-pdf \ install-pdf-am install-ps install-ps-am install-strip \ installcheck installcheck-am installdirs maintainer-clean \ maintainer-clean-generic mostlyclean mostlyclean-compile \ mostlyclean-generic mostlyclean-libtool pdf pdf-am ps ps-am \ tags tags-am uninstall uninstall-am uninstall-binPROGRAMS .PRECIOUS: Makefile # Tell versions [3.59,3.63) of GNU make to not export all variables. # Otherwise a system limit (for SysV at least) may be exceeded. .NOEXPORT: xrdp-0.9.5/m4/ax_append_compile_flags.m4000644 001751 001751 00000005654 13127114621 020037 0ustar00metameta000000 000000 # =========================================================================== # http://www.gnu.org/software/autoconf-archive/ax_append_compile_flags.html # =========================================================================== # # SYNOPSIS # # AX_APPEND_COMPILE_FLAGS([FLAG1 FLAG2 ...], [FLAGS-VARIABLE], [EXTRA-FLAGS], [INPUT]) # # DESCRIPTION # # For every FLAG1, FLAG2 it is checked whether the compiler works with the # flag. If it does, the flag is added FLAGS-VARIABLE # # If FLAGS-VARIABLE is not specified, the current language's flags (e.g. # CFLAGS) is used. During the check the flag is always added to the # current language's flags. # # If EXTRA-FLAGS is defined, it is added to the current language's default # flags (e.g. CFLAGS) when the check is done. The check is thus made with # the flags: "CFLAGS EXTRA-FLAGS FLAG". This can for example be used to # force the compiler to issue an error when a bad flag is given. # # INPUT gives an alternative input source to AC_COMPILE_IFELSE. # # NOTE: This macro depends on the AX_APPEND_FLAG and # AX_CHECK_COMPILE_FLAG. Please keep this macro in sync with # AX_APPEND_LINK_FLAGS. # # LICENSE # # Copyright (c) 2011 Maarten Bosmans # # 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. # # You should have received a copy of the GNU General Public License along # with this program. If not, see . # # As a special exception, the respective Autoconf Macro's copyright owner # gives unlimited permission to copy, distribute and modify the configure # scripts that are the output of Autoconf when processing the Macro. You # need not follow the terms of the GNU General Public License when using # or distributing such scripts, even though portions of the text of the # Macro appear in them. The GNU General Public License (GPL) does govern # all other use of the material that constitutes the Autoconf Macro. # # This special exception to the GPL applies to versions of the Autoconf # Macro released by the Autoconf Archive. When you make and distribute a # modified version of the Autoconf Macro, you may extend this special # exception to the GPL to apply to your modified version as well. #serial 5 AC_DEFUN([AX_APPEND_COMPILE_FLAGS], [AX_REQUIRE_DEFINED([AX_CHECK_COMPILE_FLAG]) AX_REQUIRE_DEFINED([AX_APPEND_FLAG]) for flag in $1; do AX_CHECK_COMPILE_FLAG([$flag], [AX_APPEND_FLAG([$flag], [$2])], [], [$3], [$4]) done ])dnl AX_APPEND_COMPILE_FLAGS xrdp-0.9.5/m4/libtool.m4000644 001751 001751 00001125073 13220730762 014663 0ustar00metameta000000 000000 # libtool.m4 - Configure libtool for the host system. -*-Autoconf-*- # # Copyright (C) 1996-2001, 2003-2015 Free Software Foundation, Inc. # Written by Gordon Matzigkeit, 1996 # # This file is free software; the Free Software Foundation gives # unlimited permission to copy and/or distribute it, with or without # modifications, as long as this notice is preserved. m4_define([_LT_COPYING], [dnl # Copyright (C) 2014 Free Software Foundation, Inc. # This is free software; see the source for copying conditions. There is NO # warranty; not even for MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. # GNU Libtool 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 2 of of the License, or # (at your option) any later version. # # As a special exception to the GNU General Public License, if you # distribute this file as part of a program or library that is built # using GNU Libtool, you may include this file under the same # distribution terms that you use for the rest of that program. # # GNU Libtool 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. # # You should have received a copy of the GNU General Public License # along with this program. If not, see . ]) # serial 58 LT_INIT # LT_PREREQ(VERSION) # ------------------ # Complain and exit if this libtool version is less that VERSION. m4_defun([LT_PREREQ], [m4_if(m4_version_compare(m4_defn([LT_PACKAGE_VERSION]), [$1]), -1, [m4_default([$3], [m4_fatal([Libtool version $1 or higher is required], 63)])], [$2])]) # _LT_CHECK_BUILDDIR # ------------------ # Complain if the absolute build directory name contains unusual characters m4_defun([_LT_CHECK_BUILDDIR], [case `pwd` in *\ * | *\ *) AC_MSG_WARN([Libtool does not cope well with whitespace in `pwd`]) ;; esac ]) # LT_INIT([OPTIONS]) # ------------------ AC_DEFUN([LT_INIT], [AC_PREREQ([2.62])dnl We use AC_PATH_PROGS_FEATURE_CHECK AC_REQUIRE([AC_CONFIG_AUX_DIR_DEFAULT])dnl AC_BEFORE([$0], [LT_LANG])dnl AC_BEFORE([$0], [LT_OUTPUT])dnl AC_BEFORE([$0], [LTDL_INIT])dnl m4_require([_LT_CHECK_BUILDDIR])dnl dnl Autoconf doesn't catch unexpanded LT_ macros by default: m4_pattern_forbid([^_?LT_[A-Z_]+$])dnl m4_pattern_allow([^(_LT_EOF|LT_DLGLOBAL|LT_DLLAZY_OR_NOW|LT_MULTI_MODULE)$])dnl dnl aclocal doesn't pull ltoptions.m4, ltsugar.m4, or ltversion.m4 dnl unless we require an AC_DEFUNed macro: AC_REQUIRE([LTOPTIONS_VERSION])dnl AC_REQUIRE([LTSUGAR_VERSION])dnl AC_REQUIRE([LTVERSION_VERSION])dnl AC_REQUIRE([LTOBSOLETE_VERSION])dnl m4_require([_LT_PROG_LTMAIN])dnl _LT_SHELL_INIT([SHELL=${CONFIG_SHELL-/bin/sh}]) dnl Parse OPTIONS _LT_SET_OPTIONS([$0], [$1]) # This can be used to rebuild libtool when needed LIBTOOL_DEPS=$ltmain # Always use our own libtool. LIBTOOL='$(SHELL) $(top_builddir)/libtool' AC_SUBST(LIBTOOL)dnl _LT_SETUP # Only expand once: m4_define([LT_INIT]) ])# LT_INIT # Old names: AU_ALIAS([AC_PROG_LIBTOOL], [LT_INIT]) AU_ALIAS([AM_PROG_LIBTOOL], [LT_INIT]) dnl aclocal-1.4 backwards compatibility: dnl AC_DEFUN([AC_PROG_LIBTOOL], []) dnl AC_DEFUN([AM_PROG_LIBTOOL], []) # _LT_PREPARE_CC_BASENAME # ----------------------- m4_defun([_LT_PREPARE_CC_BASENAME], [ # Calculate cc_basename. Skip known compiler wrappers and cross-prefix. func_cc_basename () { for cc_temp in @S|@*""; do case $cc_temp in compile | *[[\\/]]compile | ccache | *[[\\/]]ccache ) ;; distcc | *[[\\/]]distcc | purify | *[[\\/]]purify ) ;; \-*) ;; *) break;; esac done func_cc_basename_result=`$ECHO "$cc_temp" | $SED "s%.*/%%; s%^$host_alias-%%"` } ])# _LT_PREPARE_CC_BASENAME # _LT_CC_BASENAME(CC) # ------------------- # It would be clearer to call AC_REQUIREs from _LT_PREPARE_CC_BASENAME, # but that macro is also expanded into generated libtool script, which # arranges for $SED and $ECHO to be set by different means. m4_defun([_LT_CC_BASENAME], [m4_require([_LT_PREPARE_CC_BASENAME])dnl AC_REQUIRE([_LT_DECL_SED])dnl AC_REQUIRE([_LT_PROG_ECHO_BACKSLASH])dnl func_cc_basename $1 cc_basename=$func_cc_basename_result ]) # _LT_FILEUTILS_DEFAULTS # ---------------------- # It is okay to use these file commands and assume they have been set # sensibly after 'm4_require([_LT_FILEUTILS_DEFAULTS])'. m4_defun([_LT_FILEUTILS_DEFAULTS], [: ${CP="cp -f"} : ${MV="mv -f"} : ${RM="rm -f"} ])# _LT_FILEUTILS_DEFAULTS # _LT_SETUP # --------- m4_defun([_LT_SETUP], [AC_REQUIRE([AC_CANONICAL_HOST])dnl AC_REQUIRE([AC_CANONICAL_BUILD])dnl AC_REQUIRE([_LT_PREPARE_SED_QUOTE_VARS])dnl AC_REQUIRE([_LT_PROG_ECHO_BACKSLASH])dnl _LT_DECL([], [PATH_SEPARATOR], [1], [The PATH separator for the build system])dnl dnl _LT_DECL([], [host_alias], [0], [The host system])dnl _LT_DECL([], [host], [0])dnl _LT_DECL([], [host_os], [0])dnl dnl _LT_DECL([], [build_alias], [0], [The build system])dnl _LT_DECL([], [build], [0])dnl _LT_DECL([], [build_os], [0])dnl dnl AC_REQUIRE([AC_PROG_CC])dnl AC_REQUIRE([LT_PATH_LD])dnl AC_REQUIRE([LT_PATH_NM])dnl dnl AC_REQUIRE([AC_PROG_LN_S])dnl test -z "$LN_S" && LN_S="ln -s" _LT_DECL([], [LN_S], [1], [Whether we need soft or hard links])dnl dnl AC_REQUIRE([LT_CMD_MAX_LEN])dnl _LT_DECL([objext], [ac_objext], [0], [Object file suffix (normally "o")])dnl _LT_DECL([], [exeext], [0], [Executable file suffix (normally "")])dnl dnl m4_require([_LT_FILEUTILS_DEFAULTS])dnl m4_require([_LT_CHECK_SHELL_FEATURES])dnl m4_require([_LT_PATH_CONVERSION_FUNCTIONS])dnl m4_require([_LT_CMD_RELOAD])dnl m4_require([_LT_CHECK_MAGIC_METHOD])dnl m4_require([_LT_CHECK_SHAREDLIB_FROM_LINKLIB])dnl m4_require([_LT_CMD_OLD_ARCHIVE])dnl m4_require([_LT_CMD_GLOBAL_SYMBOLS])dnl m4_require([_LT_WITH_SYSROOT])dnl m4_require([_LT_CMD_TRUNCATE])dnl _LT_CONFIG_LIBTOOL_INIT([ # See if we are running on zsh, and set the options that allow our # commands through without removal of \ escapes INIT. if test -n "\${ZSH_VERSION+set}"; then setopt NO_GLOB_SUBST fi ]) if test -n "${ZSH_VERSION+set}"; then setopt NO_GLOB_SUBST fi _LT_CHECK_OBJDIR m4_require([_LT_TAG_COMPILER])dnl case $host_os in aix3*) # AIX sometimes has problems with the GCC collect2 program. For some # reason, if we set the COLLECT_NAMES environment variable, the problems # vanish in a puff of smoke. if test set != "${COLLECT_NAMES+set}"; then COLLECT_NAMES= export COLLECT_NAMES fi ;; esac # Global variables: ofile=libtool can_build_shared=yes # All known linkers require a '.a' archive for static linking (except MSVC, # which needs '.lib'). libext=a with_gnu_ld=$lt_cv_prog_gnu_ld old_CC=$CC old_CFLAGS=$CFLAGS # Set sane defaults for various variables test -z "$CC" && CC=cc test -z "$LTCC" && LTCC=$CC test -z "$LTCFLAGS" && LTCFLAGS=$CFLAGS test -z "$LD" && LD=ld test -z "$ac_objext" && ac_objext=o _LT_CC_BASENAME([$compiler]) # Only perform the check for file, if the check method requires it test -z "$MAGIC_CMD" && MAGIC_CMD=file case $deplibs_check_method in file_magic*) if test "$file_magic_cmd" = '$MAGIC_CMD'; then _LT_PATH_MAGIC fi ;; esac # Use C for the default configuration in the libtool script LT_SUPPORTED_TAG([CC]) _LT_LANG_C_CONFIG _LT_LANG_DEFAULT_CONFIG _LT_CONFIG_COMMANDS ])# _LT_SETUP # _LT_PREPARE_SED_QUOTE_VARS # -------------------------- # Define a few sed substitution that help us do robust quoting. m4_defun([_LT_PREPARE_SED_QUOTE_VARS], [# Backslashify metacharacters that are still active within # double-quoted strings. sed_quote_subst='s/\([["`$\\]]\)/\\\1/g' # Same as above, but do not quote variable references. double_quote_subst='s/\([["`\\]]\)/\\\1/g' # Sed substitution to delay expansion of an escaped shell variable in a # double_quote_subst'ed string. delay_variable_subst='s/\\\\\\\\\\\$/\\\\\\$/g' # Sed substitution to delay expansion of an escaped single quote. delay_single_quote_subst='s/'\''/'\'\\\\\\\'\''/g' # Sed substitution to avoid accidental globbing in evaled expressions no_glob_subst='s/\*/\\\*/g' ]) # _LT_PROG_LTMAIN # --------------- # Note that this code is called both from 'configure', and 'config.status' # now that we use AC_CONFIG_COMMANDS to generate libtool. Notably, # 'config.status' has no value for ac_aux_dir unless we are using Automake, # so we pass a copy along to make sure it has a sensible value anyway. m4_defun([_LT_PROG_LTMAIN], [m4_ifdef([AC_REQUIRE_AUX_FILE], [AC_REQUIRE_AUX_FILE([ltmain.sh])])dnl _LT_CONFIG_LIBTOOL_INIT([ac_aux_dir='$ac_aux_dir']) ltmain=$ac_aux_dir/ltmain.sh ])# _LT_PROG_LTMAIN ## ------------------------------------- ## ## Accumulate code for creating libtool. ## ## ------------------------------------- ## # So that we can recreate a full libtool script including additional # tags, we accumulate the chunks of code to send to AC_CONFIG_COMMANDS # in macros and then make a single call at the end using the 'libtool' # label. # _LT_CONFIG_LIBTOOL_INIT([INIT-COMMANDS]) # ---------------------------------------- # Register INIT-COMMANDS to be passed to AC_CONFIG_COMMANDS later. m4_define([_LT_CONFIG_LIBTOOL_INIT], [m4_ifval([$1], [m4_append([_LT_OUTPUT_LIBTOOL_INIT], [$1 ])])]) # Initialize. m4_define([_LT_OUTPUT_LIBTOOL_INIT]) # _LT_CONFIG_LIBTOOL([COMMANDS]) # ------------------------------ # Register COMMANDS to be passed to AC_CONFIG_COMMANDS later. m4_define([_LT_CONFIG_LIBTOOL], [m4_ifval([$1], [m4_append([_LT_OUTPUT_LIBTOOL_COMMANDS], [$1 ])])]) # Initialize. m4_define([_LT_OUTPUT_LIBTOOL_COMMANDS]) # _LT_CONFIG_SAVE_COMMANDS([COMMANDS], [INIT_COMMANDS]) # ----------------------------------------------------- m4_defun([_LT_CONFIG_SAVE_COMMANDS], [_LT_CONFIG_LIBTOOL([$1]) _LT_CONFIG_LIBTOOL_INIT([$2]) ]) # _LT_FORMAT_COMMENT([COMMENT]) # ----------------------------- # Add leading comment marks to the start of each line, and a trailing # full-stop to the whole comment if one is not present already. m4_define([_LT_FORMAT_COMMENT], [m4_ifval([$1], [ m4_bpatsubst([m4_bpatsubst([$1], [^ *], [# ])], [['`$\]], [\\\&])]m4_bmatch([$1], [[!?.]$], [], [.]) )]) ## ------------------------ ## ## FIXME: Eliminate VARNAME ## ## ------------------------ ## # _LT_DECL([CONFIGNAME], VARNAME, VALUE, [DESCRIPTION], [IS-TAGGED?]) # ------------------------------------------------------------------- # CONFIGNAME is the name given to the value in the libtool script. # VARNAME is the (base) name used in the configure script. # VALUE may be 0, 1 or 2 for a computed quote escaped value based on # VARNAME. Any other value will be used directly. m4_define([_LT_DECL], [lt_if_append_uniq([lt_decl_varnames], [$2], [, ], [lt_dict_add_subkey([lt_decl_dict], [$2], [libtool_name], [m4_ifval([$1], [$1], [$2])]) lt_dict_add_subkey([lt_decl_dict], [$2], [value], [$3]) m4_ifval([$4], [lt_dict_add_subkey([lt_decl_dict], [$2], [description], [$4])]) lt_dict_add_subkey([lt_decl_dict], [$2], [tagged?], [m4_ifval([$5], [yes], [no])])]) ]) # _LT_TAGDECL([CONFIGNAME], VARNAME, VALUE, [DESCRIPTION]) # -------------------------------------------------------- m4_define([_LT_TAGDECL], [_LT_DECL([$1], [$2], [$3], [$4], [yes])]) # lt_decl_tag_varnames([SEPARATOR], [VARNAME1...]) # ------------------------------------------------ m4_define([lt_decl_tag_varnames], [_lt_decl_filter([tagged?], [yes], $@)]) # _lt_decl_filter(SUBKEY, VALUE, [SEPARATOR], [VARNAME1..]) # --------------------------------------------------------- m4_define([_lt_decl_filter], [m4_case([$#], [0], [m4_fatal([$0: too few arguments: $#])], [1], [m4_fatal([$0: too few arguments: $#: $1])], [2], [lt_dict_filter([lt_decl_dict], [$1], [$2], [], lt_decl_varnames)], [3], [lt_dict_filter([lt_decl_dict], [$1], [$2], [$3], lt_decl_varnames)], [lt_dict_filter([lt_decl_dict], $@)])[]dnl ]) # lt_decl_quote_varnames([SEPARATOR], [VARNAME1...]) # -------------------------------------------------- m4_define([lt_decl_quote_varnames], [_lt_decl_filter([value], [1], $@)]) # lt_decl_dquote_varnames([SEPARATOR], [VARNAME1...]) # --------------------------------------------------- m4_define([lt_decl_dquote_varnames], [_lt_decl_filter([value], [2], $@)]) # lt_decl_varnames_tagged([SEPARATOR], [VARNAME1...]) # --------------------------------------------------- m4_define([lt_decl_varnames_tagged], [m4_assert([$# <= 2])dnl _$0(m4_quote(m4_default([$1], [[, ]])), m4_ifval([$2], [[$2]], [m4_dquote(lt_decl_tag_varnames)]), m4_split(m4_normalize(m4_quote(_LT_TAGS)), [ ]))]) m4_define([_lt_decl_varnames_tagged], [m4_ifval([$3], [lt_combine([$1], [$2], [_], $3)])]) # lt_decl_all_varnames([SEPARATOR], [VARNAME1...]) # ------------------------------------------------ m4_define([lt_decl_all_varnames], [_$0(m4_quote(m4_default([$1], [[, ]])), m4_if([$2], [], m4_quote(lt_decl_varnames), m4_quote(m4_shift($@))))[]dnl ]) m4_define([_lt_decl_all_varnames], [lt_join($@, lt_decl_varnames_tagged([$1], lt_decl_tag_varnames([[, ]], m4_shift($@))))dnl ]) # _LT_CONFIG_STATUS_DECLARE([VARNAME]) # ------------------------------------ # Quote a variable value, and forward it to 'config.status' so that its # declaration there will have the same value as in 'configure'. VARNAME # must have a single quote delimited value for this to work. m4_define([_LT_CONFIG_STATUS_DECLARE], [$1='`$ECHO "$][$1" | $SED "$delay_single_quote_subst"`']) # _LT_CONFIG_STATUS_DECLARATIONS # ------------------------------ # We delimit libtool config variables with single quotes, so when # we write them to config.status, we have to be sure to quote all # embedded single quotes properly. In configure, this macro expands # each variable declared with _LT_DECL (and _LT_TAGDECL) into: # # ='`$ECHO "$" | $SED "$delay_single_quote_subst"`' m4_defun([_LT_CONFIG_STATUS_DECLARATIONS], [m4_foreach([_lt_var], m4_quote(lt_decl_all_varnames), [m4_n([_LT_CONFIG_STATUS_DECLARE(_lt_var)])])]) # _LT_LIBTOOL_TAGS # ---------------- # Output comment and list of tags supported by the script m4_defun([_LT_LIBTOOL_TAGS], [_LT_FORMAT_COMMENT([The names of the tagged configurations supported by this script])dnl available_tags='_LT_TAGS'dnl ]) # _LT_LIBTOOL_DECLARE(VARNAME, [TAG]) # ----------------------------------- # Extract the dictionary values for VARNAME (optionally with TAG) and # expand to a commented shell variable setting: # # # Some comment about what VAR is for. # visible_name=$lt_internal_name m4_define([_LT_LIBTOOL_DECLARE], [_LT_FORMAT_COMMENT(m4_quote(lt_dict_fetch([lt_decl_dict], [$1], [description])))[]dnl m4_pushdef([_libtool_name], m4_quote(lt_dict_fetch([lt_decl_dict], [$1], [libtool_name])))[]dnl m4_case(m4_quote(lt_dict_fetch([lt_decl_dict], [$1], [value])), [0], [_libtool_name=[$]$1], [1], [_libtool_name=$lt_[]$1], [2], [_libtool_name=$lt_[]$1], [_libtool_name=lt_dict_fetch([lt_decl_dict], [$1], [value])])[]dnl m4_ifval([$2], [_$2])[]m4_popdef([_libtool_name])[]dnl ]) # _LT_LIBTOOL_CONFIG_VARS # ----------------------- # Produce commented declarations of non-tagged libtool config variables # suitable for insertion in the LIBTOOL CONFIG section of the 'libtool' # script. Tagged libtool config variables (even for the LIBTOOL CONFIG # section) are produced by _LT_LIBTOOL_TAG_VARS. m4_defun([_LT_LIBTOOL_CONFIG_VARS], [m4_foreach([_lt_var], m4_quote(_lt_decl_filter([tagged?], [no], [], lt_decl_varnames)), [m4_n([_LT_LIBTOOL_DECLARE(_lt_var)])])]) # _LT_LIBTOOL_TAG_VARS(TAG) # ------------------------- m4_define([_LT_LIBTOOL_TAG_VARS], [m4_foreach([_lt_var], m4_quote(lt_decl_tag_varnames), [m4_n([_LT_LIBTOOL_DECLARE(_lt_var, [$1])])])]) # _LT_TAGVAR(VARNAME, [TAGNAME]) # ------------------------------ m4_define([_LT_TAGVAR], [m4_ifval([$2], [$1_$2], [$1])]) # _LT_CONFIG_COMMANDS # ------------------- # Send accumulated output to $CONFIG_STATUS. Thanks to the lists of # variables for single and double quote escaping we saved from calls # to _LT_DECL, we can put quote escaped variables declarations # into 'config.status', and then the shell code to quote escape them in # for loops in 'config.status'. Finally, any additional code accumulated # from calls to _LT_CONFIG_LIBTOOL_INIT is expanded. m4_defun([_LT_CONFIG_COMMANDS], [AC_PROVIDE_IFELSE([LT_OUTPUT], dnl If the libtool generation code has been placed in $CONFIG_LT, dnl instead of duplicating it all over again into config.status, dnl then we will have config.status run $CONFIG_LT later, so it dnl needs to know what name is stored there: [AC_CONFIG_COMMANDS([libtool], [$SHELL $CONFIG_LT || AS_EXIT(1)], [CONFIG_LT='$CONFIG_LT'])], dnl If the libtool generation code is destined for config.status, dnl expand the accumulated commands and init code now: [AC_CONFIG_COMMANDS([libtool], [_LT_OUTPUT_LIBTOOL_COMMANDS], [_LT_OUTPUT_LIBTOOL_COMMANDS_INIT])]) ])#_LT_CONFIG_COMMANDS # Initialize. m4_define([_LT_OUTPUT_LIBTOOL_COMMANDS_INIT], [ # The HP-UX ksh and POSIX shell print the target directory to stdout # if CDPATH is set. (unset CDPATH) >/dev/null 2>&1 && unset CDPATH sed_quote_subst='$sed_quote_subst' double_quote_subst='$double_quote_subst' delay_variable_subst='$delay_variable_subst' _LT_CONFIG_STATUS_DECLARATIONS LTCC='$LTCC' LTCFLAGS='$LTCFLAGS' compiler='$compiler_DEFAULT' # A function that is used when there is no print builtin or printf. func_fallback_echo () { eval 'cat <<_LTECHO_EOF \$[]1 _LTECHO_EOF' } # Quote evaled strings. for var in lt_decl_all_varnames([[ \ ]], lt_decl_quote_varnames); do case \`eval \\\\\$ECHO \\\\""\\\\\$\$var"\\\\"\` in *[[\\\\\\\`\\"\\\$]]*) eval "lt_\$var=\\\\\\"\\\`\\\$ECHO \\"\\\$\$var\\" | \\\$SED \\"\\\$sed_quote_subst\\"\\\`\\\\\\"" ## exclude from sc_prohibit_nested_quotes ;; *) eval "lt_\$var=\\\\\\"\\\$\$var\\\\\\"" ;; esac done # Double-quote double-evaled strings. for var in lt_decl_all_varnames([[ \ ]], lt_decl_dquote_varnames); do case \`eval \\\\\$ECHO \\\\""\\\\\$\$var"\\\\"\` in *[[\\\\\\\`\\"\\\$]]*) eval "lt_\$var=\\\\\\"\\\`\\\$ECHO \\"\\\$\$var\\" | \\\$SED -e \\"\\\$double_quote_subst\\" -e \\"\\\$sed_quote_subst\\" -e \\"\\\$delay_variable_subst\\"\\\`\\\\\\"" ## exclude from sc_prohibit_nested_quotes ;; *) eval "lt_\$var=\\\\\\"\\\$\$var\\\\\\"" ;; esac done _LT_OUTPUT_LIBTOOL_INIT ]) # _LT_GENERATED_FILE_INIT(FILE, [COMMENT]) # ------------------------------------ # Generate a child script FILE with all initialization necessary to # reuse the environment learned by the parent script, and make the # file executable. If COMMENT is supplied, it is inserted after the # '#!' sequence but before initialization text begins. After this # macro, additional text can be appended to FILE to form the body of # the child script. The macro ends with non-zero status if the # file could not be fully written (such as if the disk is full). m4_ifdef([AS_INIT_GENERATED], [m4_defun([_LT_GENERATED_FILE_INIT],[AS_INIT_GENERATED($@)])], [m4_defun([_LT_GENERATED_FILE_INIT], [m4_require([AS_PREPARE])]dnl [m4_pushdef([AS_MESSAGE_LOG_FD])]dnl [lt_write_fail=0 cat >$1 <<_ASEOF || lt_write_fail=1 #! $SHELL # Generated by $as_me. $2 SHELL=\${CONFIG_SHELL-$SHELL} export SHELL _ASEOF cat >>$1 <<\_ASEOF || lt_write_fail=1 AS_SHELL_SANITIZE _AS_PREPARE exec AS_MESSAGE_FD>&1 _ASEOF test 0 = "$lt_write_fail" && chmod +x $1[]dnl m4_popdef([AS_MESSAGE_LOG_FD])])])# _LT_GENERATED_FILE_INIT # LT_OUTPUT # --------- # This macro allows early generation of the libtool script (before # AC_OUTPUT is called), incase it is used in configure for compilation # tests. AC_DEFUN([LT_OUTPUT], [: ${CONFIG_LT=./config.lt} AC_MSG_NOTICE([creating $CONFIG_LT]) _LT_GENERATED_FILE_INIT(["$CONFIG_LT"], [# Run this file to recreate a libtool stub with the current configuration.]) cat >>"$CONFIG_LT" <<\_LTEOF lt_cl_silent=false exec AS_MESSAGE_LOG_FD>>config.log { echo AS_BOX([Running $as_me.]) } >&AS_MESSAGE_LOG_FD lt_cl_help="\ '$as_me' creates a local libtool stub from the current configuration, for use in further configure time tests before the real libtool is generated. Usage: $[0] [[OPTIONS]] -h, --help print this help, then exit -V, --version print version number, then exit -q, --quiet do not print progress messages -d, --debug don't remove temporary files Report bugs to ." lt_cl_version="\ m4_ifset([AC_PACKAGE_NAME], [AC_PACKAGE_NAME ])config.lt[]dnl m4_ifset([AC_PACKAGE_VERSION], [ AC_PACKAGE_VERSION]) configured by $[0], generated by m4_PACKAGE_STRING. Copyright (C) 2011 Free Software Foundation, Inc. This config.lt script is free software; the Free Software Foundation gives unlimited permision to copy, distribute and modify it." while test 0 != $[#] do case $[1] in --version | --v* | -V ) echo "$lt_cl_version"; exit 0 ;; --help | --h* | -h ) echo "$lt_cl_help"; exit 0 ;; --debug | --d* | -d ) debug=: ;; --quiet | --q* | --silent | --s* | -q ) lt_cl_silent=: ;; -*) AC_MSG_ERROR([unrecognized option: $[1] Try '$[0] --help' for more information.]) ;; *) AC_MSG_ERROR([unrecognized argument: $[1] Try '$[0] --help' for more information.]) ;; esac shift done if $lt_cl_silent; then exec AS_MESSAGE_FD>/dev/null fi _LTEOF cat >>"$CONFIG_LT" <<_LTEOF _LT_OUTPUT_LIBTOOL_COMMANDS_INIT _LTEOF cat >>"$CONFIG_LT" <<\_LTEOF AC_MSG_NOTICE([creating $ofile]) _LT_OUTPUT_LIBTOOL_COMMANDS AS_EXIT(0) _LTEOF chmod +x "$CONFIG_LT" # configure is writing to config.log, but config.lt does its own redirection, # appending to config.log, which fails on DOS, as config.log is still kept # open by configure. Here we exec the FD to /dev/null, effectively closing # config.log, so it can be properly (re)opened and appended to by config.lt. lt_cl_success=: test yes = "$silent" && lt_config_lt_args="$lt_config_lt_args --quiet" exec AS_MESSAGE_LOG_FD>/dev/null $SHELL "$CONFIG_LT" $lt_config_lt_args || lt_cl_success=false exec AS_MESSAGE_LOG_FD>>config.log $lt_cl_success || AS_EXIT(1) ])# LT_OUTPUT # _LT_CONFIG(TAG) # --------------- # If TAG is the built-in tag, create an initial libtool script with a # default configuration from the untagged config vars. Otherwise add code # to config.status for appending the configuration named by TAG from the # matching tagged config vars. m4_defun([_LT_CONFIG], [m4_require([_LT_FILEUTILS_DEFAULTS])dnl _LT_CONFIG_SAVE_COMMANDS([ m4_define([_LT_TAG], m4_if([$1], [], [C], [$1]))dnl m4_if(_LT_TAG, [C], [ # See if we are running on zsh, and set the options that allow our # commands through without removal of \ escapes. if test -n "${ZSH_VERSION+set}"; then setopt NO_GLOB_SUBST fi cfgfile=${ofile}T trap "$RM \"$cfgfile\"; exit 1" 1 2 15 $RM "$cfgfile" cat <<_LT_EOF >> "$cfgfile" #! $SHELL # Generated automatically by $as_me ($PACKAGE) $VERSION # Libtool was configured on host `(hostname || uname -n) 2>/dev/null | sed 1q`: # NOTE: Changes made to this file will be lost: look at ltmain.sh. # Provide generalized library-building support services. # Written by Gordon Matzigkeit, 1996 _LT_COPYING _LT_LIBTOOL_TAGS # Configured defaults for sys_lib_dlsearch_path munging. : \${LT_SYS_LIBRARY_PATH="$configure_time_lt_sys_library_path"} # ### BEGIN LIBTOOL CONFIG _LT_LIBTOOL_CONFIG_VARS _LT_LIBTOOL_TAG_VARS # ### END LIBTOOL CONFIG _LT_EOF cat <<'_LT_EOF' >> "$cfgfile" # ### BEGIN FUNCTIONS SHARED WITH CONFIGURE _LT_PREPARE_MUNGE_PATH_LIST _LT_PREPARE_CC_BASENAME # ### END FUNCTIONS SHARED WITH CONFIGURE _LT_EOF case $host_os in aix3*) cat <<\_LT_EOF >> "$cfgfile" # AIX sometimes has problems with the GCC collect2 program. For some # reason, if we set the COLLECT_NAMES environment variable, the problems # vanish in a puff of smoke. if test set != "${COLLECT_NAMES+set}"; then COLLECT_NAMES= export COLLECT_NAMES fi _LT_EOF ;; esac _LT_PROG_LTMAIN # We use sed instead of cat because bash on DJGPP gets confused if # if finds mixed CR/LF and LF-only lines. Since sed operates in # text mode, it properly converts lines to CR/LF. This bash problem # is reportedly fixed, but why not run on old versions too? sed '$q' "$ltmain" >> "$cfgfile" \ || (rm -f "$cfgfile"; exit 1) mv -f "$cfgfile" "$ofile" || (rm -f "$ofile" && cp "$cfgfile" "$ofile" && rm -f "$cfgfile") chmod +x "$ofile" ], [cat <<_LT_EOF >> "$ofile" dnl Unfortunately we have to use $1 here, since _LT_TAG is not expanded dnl in a comment (ie after a #). # ### BEGIN LIBTOOL TAG CONFIG: $1 _LT_LIBTOOL_TAG_VARS(_LT_TAG) # ### END LIBTOOL TAG CONFIG: $1 _LT_EOF ])dnl /m4_if ], [m4_if([$1], [], [ PACKAGE='$PACKAGE' VERSION='$VERSION' RM='$RM' ofile='$ofile'], []) ])dnl /_LT_CONFIG_SAVE_COMMANDS ])# _LT_CONFIG # LT_SUPPORTED_TAG(TAG) # --------------------- # Trace this macro to discover what tags are supported by the libtool # --tag option, using: # autoconf --trace 'LT_SUPPORTED_TAG:$1' AC_DEFUN([LT_SUPPORTED_TAG], []) # C support is built-in for now m4_define([_LT_LANG_C_enabled], []) m4_define([_LT_TAGS], []) # LT_LANG(LANG) # ------------- # Enable libtool support for the given language if not already enabled. AC_DEFUN([LT_LANG], [AC_BEFORE([$0], [LT_OUTPUT])dnl m4_case([$1], [C], [_LT_LANG(C)], [C++], [_LT_LANG(CXX)], [Go], [_LT_LANG(GO)], [Java], [_LT_LANG(GCJ)], [Fortran 77], [_LT_LANG(F77)], [Fortran], [_LT_LANG(FC)], [Windows Resource], [_LT_LANG(RC)], [m4_ifdef([_LT_LANG_]$1[_CONFIG], [_LT_LANG($1)], [m4_fatal([$0: unsupported language: "$1"])])])dnl ])# LT_LANG # _LT_LANG(LANGNAME) # ------------------ m4_defun([_LT_LANG], [m4_ifdef([_LT_LANG_]$1[_enabled], [], [LT_SUPPORTED_TAG([$1])dnl m4_append([_LT_TAGS], [$1 ])dnl m4_define([_LT_LANG_]$1[_enabled], [])dnl _LT_LANG_$1_CONFIG($1)])dnl ])# _LT_LANG m4_ifndef([AC_PROG_GO], [ ############################################################ # NOTE: This macro has been submitted for inclusion into # # GNU Autoconf as AC_PROG_GO. When it is available in # # a released version of Autoconf we should remove this # # macro and use it instead. # ############################################################ m4_defun([AC_PROG_GO], [AC_LANG_PUSH(Go)dnl AC_ARG_VAR([GOC], [Go compiler command])dnl AC_ARG_VAR([GOFLAGS], [Go compiler flags])dnl _AC_ARG_VAR_LDFLAGS()dnl AC_CHECK_TOOL(GOC, gccgo) if test -z "$GOC"; then if test -n "$ac_tool_prefix"; then AC_CHECK_PROG(GOC, [${ac_tool_prefix}gccgo], [${ac_tool_prefix}gccgo]) fi fi if test -z "$GOC"; then AC_CHECK_PROG(GOC, gccgo, gccgo, false) fi ])#m4_defun ])#m4_ifndef # _LT_LANG_DEFAULT_CONFIG # ----------------------- m4_defun([_LT_LANG_DEFAULT_CONFIG], [AC_PROVIDE_IFELSE([AC_PROG_CXX], [LT_LANG(CXX)], [m4_define([AC_PROG_CXX], defn([AC_PROG_CXX])[LT_LANG(CXX)])]) AC_PROVIDE_IFELSE([AC_PROG_F77], [LT_LANG(F77)], [m4_define([AC_PROG_F77], defn([AC_PROG_F77])[LT_LANG(F77)])]) AC_PROVIDE_IFELSE([AC_PROG_FC], [LT_LANG(FC)], [m4_define([AC_PROG_FC], defn([AC_PROG_FC])[LT_LANG(FC)])]) dnl The call to [A][M_PROG_GCJ] is quoted like that to stop aclocal dnl pulling things in needlessly. AC_PROVIDE_IFELSE([AC_PROG_GCJ], [LT_LANG(GCJ)], [AC_PROVIDE_IFELSE([A][M_PROG_GCJ], [LT_LANG(GCJ)], [AC_PROVIDE_IFELSE([LT_PROG_GCJ], [LT_LANG(GCJ)], [m4_ifdef([AC_PROG_GCJ], [m4_define([AC_PROG_GCJ], defn([AC_PROG_GCJ])[LT_LANG(GCJ)])]) m4_ifdef([A][M_PROG_GCJ], [m4_define([A][M_PROG_GCJ], defn([A][M_PROG_GCJ])[LT_LANG(GCJ)])]) m4_ifdef([LT_PROG_GCJ], [m4_define([LT_PROG_GCJ], defn([LT_PROG_GCJ])[LT_LANG(GCJ)])])])])]) AC_PROVIDE_IFELSE([AC_PROG_GO], [LT_LANG(GO)], [m4_define([AC_PROG_GO], defn([AC_PROG_GO])[LT_LANG(GO)])]) AC_PROVIDE_IFELSE([LT_PROG_RC], [LT_LANG(RC)], [m4_define([LT_PROG_RC], defn([LT_PROG_RC])[LT_LANG(RC)])]) ])# _LT_LANG_DEFAULT_CONFIG # Obsolete macros: AU_DEFUN([AC_LIBTOOL_CXX], [LT_LANG(C++)]) AU_DEFUN([AC_LIBTOOL_F77], [LT_LANG(Fortran 77)]) AU_DEFUN([AC_LIBTOOL_FC], [LT_LANG(Fortran)]) AU_DEFUN([AC_LIBTOOL_GCJ], [LT_LANG(Java)]) AU_DEFUN([AC_LIBTOOL_RC], [LT_LANG(Windows Resource)]) dnl aclocal-1.4 backwards compatibility: dnl AC_DEFUN([AC_LIBTOOL_CXX], []) dnl AC_DEFUN([AC_LIBTOOL_F77], []) dnl AC_DEFUN([AC_LIBTOOL_FC], []) dnl AC_DEFUN([AC_LIBTOOL_GCJ], []) dnl AC_DEFUN([AC_LIBTOOL_RC], []) # _LT_TAG_COMPILER # ---------------- m4_defun([_LT_TAG_COMPILER], [AC_REQUIRE([AC_PROG_CC])dnl _LT_DECL([LTCC], [CC], [1], [A C compiler])dnl _LT_DECL([LTCFLAGS], [CFLAGS], [1], [LTCC compiler flags])dnl _LT_TAGDECL([CC], [compiler], [1], [A language specific compiler])dnl _LT_TAGDECL([with_gcc], [GCC], [0], [Is the compiler the GNU compiler?])dnl # If no C compiler was specified, use CC. LTCC=${LTCC-"$CC"} # If no C compiler flags were specified, use CFLAGS. LTCFLAGS=${LTCFLAGS-"$CFLAGS"} # Allow CC to be a program name with arguments. compiler=$CC ])# _LT_TAG_COMPILER # _LT_COMPILER_BOILERPLATE # ------------------------ # Check for compiler boilerplate output or warnings with # the simple compiler test code. m4_defun([_LT_COMPILER_BOILERPLATE], [m4_require([_LT_DECL_SED])dnl ac_outfile=conftest.$ac_objext echo "$lt_simple_compile_test_code" >conftest.$ac_ext eval "$ac_compile" 2>&1 >/dev/null | $SED '/^$/d; /^ *+/d' >conftest.err _lt_compiler_boilerplate=`cat conftest.err` $RM conftest* ])# _LT_COMPILER_BOILERPLATE # _LT_LINKER_BOILERPLATE # ---------------------- # Check for linker boilerplate output or warnings with # the simple link test code. m4_defun([_LT_LINKER_BOILERPLATE], [m4_require([_LT_DECL_SED])dnl ac_outfile=conftest.$ac_objext echo "$lt_simple_link_test_code" >conftest.$ac_ext eval "$ac_link" 2>&1 >/dev/null | $SED '/^$/d; /^ *+/d' >conftest.err _lt_linker_boilerplate=`cat conftest.err` $RM -r conftest* ])# _LT_LINKER_BOILERPLATE # _LT_REQUIRED_DARWIN_CHECKS # ------------------------- m4_defun_once([_LT_REQUIRED_DARWIN_CHECKS],[ case $host_os in rhapsody* | darwin*) AC_CHECK_TOOL([DSYMUTIL], [dsymutil], [:]) AC_CHECK_TOOL([NMEDIT], [nmedit], [:]) AC_CHECK_TOOL([LIPO], [lipo], [:]) AC_CHECK_TOOL([OTOOL], [otool], [:]) AC_CHECK_TOOL([OTOOL64], [otool64], [:]) _LT_DECL([], [DSYMUTIL], [1], [Tool to manipulate archived DWARF debug symbol files on Mac OS X]) _LT_DECL([], [NMEDIT], [1], [Tool to change global to local symbols on Mac OS X]) _LT_DECL([], [LIPO], [1], [Tool to manipulate fat objects and archives on Mac OS X]) _LT_DECL([], [OTOOL], [1], [ldd/readelf like tool for Mach-O binaries on Mac OS X]) _LT_DECL([], [OTOOL64], [1], [ldd/readelf like tool for 64 bit Mach-O binaries on Mac OS X 10.4]) AC_CACHE_CHECK([for -single_module linker flag],[lt_cv_apple_cc_single_mod], [lt_cv_apple_cc_single_mod=no if test -z "$LT_MULTI_MODULE"; then # By default we will add the -single_module flag. You can override # by either setting the environment variable LT_MULTI_MODULE # non-empty at configure time, or by adding -multi_module to the # link flags. rm -rf libconftest.dylib* echo "int foo(void){return 1;}" > conftest.c echo "$LTCC $LTCFLAGS $LDFLAGS -o libconftest.dylib \ -dynamiclib -Wl,-single_module conftest.c" >&AS_MESSAGE_LOG_FD $LTCC $LTCFLAGS $LDFLAGS -o libconftest.dylib \ -dynamiclib -Wl,-single_module conftest.c 2>conftest.err _lt_result=$? # If there is a non-empty error log, and "single_module" # appears in it, assume the flag caused a linker warning if test -s conftest.err && $GREP single_module conftest.err; then cat conftest.err >&AS_MESSAGE_LOG_FD # Otherwise, if the output was created with a 0 exit code from # the compiler, it worked. elif test -f libconftest.dylib && test 0 = "$_lt_result"; then lt_cv_apple_cc_single_mod=yes else cat conftest.err >&AS_MESSAGE_LOG_FD fi rm -rf libconftest.dylib* rm -f conftest.* fi]) AC_CACHE_CHECK([for -exported_symbols_list linker flag], [lt_cv_ld_exported_symbols_list], [lt_cv_ld_exported_symbols_list=no save_LDFLAGS=$LDFLAGS echo "_main" > conftest.sym LDFLAGS="$LDFLAGS -Wl,-exported_symbols_list,conftest.sym" AC_LINK_IFELSE([AC_LANG_PROGRAM([],[])], [lt_cv_ld_exported_symbols_list=yes], [lt_cv_ld_exported_symbols_list=no]) LDFLAGS=$save_LDFLAGS ]) AC_CACHE_CHECK([for -force_load linker flag],[lt_cv_ld_force_load], [lt_cv_ld_force_load=no cat > conftest.c << _LT_EOF int forced_loaded() { return 2;} _LT_EOF echo "$LTCC $LTCFLAGS -c -o conftest.o conftest.c" >&AS_MESSAGE_LOG_FD $LTCC $LTCFLAGS -c -o conftest.o conftest.c 2>&AS_MESSAGE_LOG_FD echo "$AR cru libconftest.a conftest.o" >&AS_MESSAGE_LOG_FD $AR cru libconftest.a conftest.o 2>&AS_MESSAGE_LOG_FD echo "$RANLIB libconftest.a" >&AS_MESSAGE_LOG_FD $RANLIB libconftest.a 2>&AS_MESSAGE_LOG_FD cat > conftest.c << _LT_EOF int main() { return 0;} _LT_EOF echo "$LTCC $LTCFLAGS $LDFLAGS -o conftest conftest.c -Wl,-force_load,./libconftest.a" >&AS_MESSAGE_LOG_FD $LTCC $LTCFLAGS $LDFLAGS -o conftest conftest.c -Wl,-force_load,./libconftest.a 2>conftest.err _lt_result=$? if test -s conftest.err && $GREP force_load conftest.err; then cat conftest.err >&AS_MESSAGE_LOG_FD elif test -f conftest && test 0 = "$_lt_result" && $GREP forced_load conftest >/dev/null 2>&1; then lt_cv_ld_force_load=yes else cat conftest.err >&AS_MESSAGE_LOG_FD fi rm -f conftest.err libconftest.a conftest conftest.c rm -rf conftest.dSYM ]) case $host_os in rhapsody* | darwin1.[[012]]) _lt_dar_allow_undefined='$wl-undefined ${wl}suppress' ;; darwin1.*) _lt_dar_allow_undefined='$wl-flat_namespace $wl-undefined ${wl}suppress' ;; darwin*) # darwin 5.x on # if running on 10.5 or later, the deployment target defaults # to the OS version, if on x86, and 10.4, the deployment # target defaults to 10.4. Don't you love it? case ${MACOSX_DEPLOYMENT_TARGET-10.0},$host in 10.0,*86*-darwin8*|10.0,*-darwin[[91]]*) _lt_dar_allow_undefined='$wl-undefined ${wl}dynamic_lookup' ;; 10.[[012]][[,.]]*) _lt_dar_allow_undefined='$wl-flat_namespace $wl-undefined ${wl}suppress' ;; 10.*) _lt_dar_allow_undefined='$wl-undefined ${wl}dynamic_lookup' ;; esac ;; esac if test yes = "$lt_cv_apple_cc_single_mod"; then _lt_dar_single_mod='$single_module' fi if test yes = "$lt_cv_ld_exported_symbols_list"; then _lt_dar_export_syms=' $wl-exported_symbols_list,$output_objdir/$libname-symbols.expsym' else _lt_dar_export_syms='~$NMEDIT -s $output_objdir/$libname-symbols.expsym $lib' fi if test : != "$DSYMUTIL" && test no = "$lt_cv_ld_force_load"; then _lt_dsymutil='~$DSYMUTIL $lib || :' else _lt_dsymutil= fi ;; esac ]) # _LT_DARWIN_LINKER_FEATURES([TAG]) # --------------------------------- # Checks for linker and compiler features on darwin m4_defun([_LT_DARWIN_LINKER_FEATURES], [ m4_require([_LT_REQUIRED_DARWIN_CHECKS]) _LT_TAGVAR(archive_cmds_need_lc, $1)=no _LT_TAGVAR(hardcode_direct, $1)=no _LT_TAGVAR(hardcode_automatic, $1)=yes _LT_TAGVAR(hardcode_shlibpath_var, $1)=unsupported if test yes = "$lt_cv_ld_force_load"; then _LT_TAGVAR(whole_archive_flag_spec, $1)='`for conv in $convenience\"\"; do test -n \"$conv\" && new_convenience=\"$new_convenience $wl-force_load,$conv\"; done; func_echo_all \"$new_convenience\"`' m4_case([$1], [F77], [_LT_TAGVAR(compiler_needs_object, $1)=yes], [FC], [_LT_TAGVAR(compiler_needs_object, $1)=yes]) else _LT_TAGVAR(whole_archive_flag_spec, $1)='' fi _LT_TAGVAR(link_all_deplibs, $1)=yes _LT_TAGVAR(allow_undefined_flag, $1)=$_lt_dar_allow_undefined case $cc_basename in ifort*|nagfor*) _lt_dar_can_shared=yes ;; *) _lt_dar_can_shared=$GCC ;; esac if test yes = "$_lt_dar_can_shared"; then output_verbose_link_cmd=func_echo_all _LT_TAGVAR(archive_cmds, $1)="\$CC -dynamiclib \$allow_undefined_flag -o \$lib \$libobjs \$deplibs \$compiler_flags -install_name \$rpath/\$soname \$verstring $_lt_dar_single_mod$_lt_dsymutil" _LT_TAGVAR(module_cmds, $1)="\$CC \$allow_undefined_flag -o \$lib -bundle \$libobjs \$deplibs \$compiler_flags$_lt_dsymutil" _LT_TAGVAR(archive_expsym_cmds, $1)="sed 's|^|_|' < \$export_symbols > \$output_objdir/\$libname-symbols.expsym~\$CC -dynamiclib \$allow_undefined_flag -o \$lib \$libobjs \$deplibs \$compiler_flags -install_name \$rpath/\$soname \$verstring $_lt_dar_single_mod$_lt_dar_export_syms$_lt_dsymutil" _LT_TAGVAR(module_expsym_cmds, $1)="sed -e 's|^|_|' < \$export_symbols > \$output_objdir/\$libname-symbols.expsym~\$CC \$allow_undefined_flag -o \$lib -bundle \$libobjs \$deplibs \$compiler_flags$_lt_dar_export_syms$_lt_dsymutil" m4_if([$1], [CXX], [ if test yes != "$lt_cv_apple_cc_single_mod"; then _LT_TAGVAR(archive_cmds, $1)="\$CC -r -keep_private_externs -nostdlib -o \$lib-master.o \$libobjs~\$CC -dynamiclib \$allow_undefined_flag -o \$lib \$lib-master.o \$deplibs \$compiler_flags -install_name \$rpath/\$soname \$verstring$_lt_dsymutil" _LT_TAGVAR(archive_expsym_cmds, $1)="sed 's|^|_|' < \$export_symbols > \$output_objdir/\$libname-symbols.expsym~\$CC -r -keep_private_externs -nostdlib -o \$lib-master.o \$libobjs~\$CC -dynamiclib \$allow_undefined_flag -o \$lib \$lib-master.o \$deplibs \$compiler_flags -install_name \$rpath/\$soname \$verstring$_lt_dar_export_syms$_lt_dsymutil" fi ],[]) else _LT_TAGVAR(ld_shlibs, $1)=no fi ]) # _LT_SYS_MODULE_PATH_AIX([TAGNAME]) # ---------------------------------- # Links a minimal program and checks the executable # for the system default hardcoded library path. In most cases, # this is /usr/lib:/lib, but when the MPI compilers are used # the location of the communication and MPI libs are included too. # If we don't find anything, use the default library path according # to the aix ld manual. # Store the results from the different compilers for each TAGNAME. # Allow to override them for all tags through lt_cv_aix_libpath. m4_defun([_LT_SYS_MODULE_PATH_AIX], [m4_require([_LT_DECL_SED])dnl if test set = "${lt_cv_aix_libpath+set}"; then aix_libpath=$lt_cv_aix_libpath else AC_CACHE_VAL([_LT_TAGVAR([lt_cv_aix_libpath_], [$1])], [AC_LINK_IFELSE([AC_LANG_PROGRAM],[ lt_aix_libpath_sed='[ /Import File Strings/,/^$/ { /^0/ { s/^0 *\([^ ]*\) *$/\1/ p } }]' _LT_TAGVAR([lt_cv_aix_libpath_], [$1])=`dump -H conftest$ac_exeext 2>/dev/null | $SED -n -e "$lt_aix_libpath_sed"` # Check for a 64-bit object if we didn't find anything. if test -z "$_LT_TAGVAR([lt_cv_aix_libpath_], [$1])"; then _LT_TAGVAR([lt_cv_aix_libpath_], [$1])=`dump -HX64 conftest$ac_exeext 2>/dev/null | $SED -n -e "$lt_aix_libpath_sed"` fi],[]) if test -z "$_LT_TAGVAR([lt_cv_aix_libpath_], [$1])"; then _LT_TAGVAR([lt_cv_aix_libpath_], [$1])=/usr/lib:/lib fi ]) aix_libpath=$_LT_TAGVAR([lt_cv_aix_libpath_], [$1]) fi ])# _LT_SYS_MODULE_PATH_AIX # _LT_SHELL_INIT(ARG) # ------------------- m4_define([_LT_SHELL_INIT], [m4_divert_text([M4SH-INIT], [$1 ])])# _LT_SHELL_INIT # _LT_PROG_ECHO_BACKSLASH # ----------------------- # Find how we can fake an echo command that does not interpret backslash. # In particular, with Autoconf 2.60 or later we add some code to the start # of the generated configure script that will find a shell with a builtin # printf (that we can use as an echo command). m4_defun([_LT_PROG_ECHO_BACKSLASH], [ECHO='\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\' ECHO=$ECHO$ECHO$ECHO$ECHO$ECHO ECHO=$ECHO$ECHO$ECHO$ECHO$ECHO$ECHO AC_MSG_CHECKING([how to print strings]) # Test print first, because it will be a builtin if present. if test "X`( print -r -- -n ) 2>/dev/null`" = X-n && \ test "X`print -r -- $ECHO 2>/dev/null`" = "X$ECHO"; then ECHO='print -r --' elif test "X`printf %s $ECHO 2>/dev/null`" = "X$ECHO"; then ECHO='printf %s\n' else # Use this function as a fallback that always works. func_fallback_echo () { eval 'cat <<_LTECHO_EOF $[]1 _LTECHO_EOF' } ECHO='func_fallback_echo' fi # func_echo_all arg... # Invoke $ECHO with all args, space-separated. func_echo_all () { $ECHO "$*" } case $ECHO in printf*) AC_MSG_RESULT([printf]) ;; print*) AC_MSG_RESULT([print -r]) ;; *) AC_MSG_RESULT([cat]) ;; esac m4_ifdef([_AS_DETECT_SUGGESTED], [_AS_DETECT_SUGGESTED([ test -n "${ZSH_VERSION+set}${BASH_VERSION+set}" || ( ECHO='\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\' ECHO=$ECHO$ECHO$ECHO$ECHO$ECHO ECHO=$ECHO$ECHO$ECHO$ECHO$ECHO$ECHO PATH=/empty FPATH=/empty; export PATH FPATH test "X`printf %s $ECHO`" = "X$ECHO" \ || test "X`print -r -- $ECHO`" = "X$ECHO" )])]) _LT_DECL([], [SHELL], [1], [Shell to use when invoking shell scripts]) _LT_DECL([], [ECHO], [1], [An echo program that protects backslashes]) ])# _LT_PROG_ECHO_BACKSLASH # _LT_WITH_SYSROOT # ---------------- AC_DEFUN([_LT_WITH_SYSROOT], [AC_MSG_CHECKING([for sysroot]) AC_ARG_WITH([sysroot], [AS_HELP_STRING([--with-sysroot@<:@=DIR@:>@], [Search for dependent libraries within DIR (or the compiler's sysroot if not specified).])], [], [with_sysroot=no]) dnl lt_sysroot will always be passed unquoted. We quote it here dnl in case the user passed a directory name. lt_sysroot= case $with_sysroot in #( yes) if test yes = "$GCC"; then lt_sysroot=`$CC --print-sysroot 2>/dev/null` fi ;; #( /*) lt_sysroot=`echo "$with_sysroot" | sed -e "$sed_quote_subst"` ;; #( no|'') ;; #( *) AC_MSG_RESULT([$with_sysroot]) AC_MSG_ERROR([The sysroot must be an absolute path.]) ;; esac AC_MSG_RESULT([${lt_sysroot:-no}]) _LT_DECL([], [lt_sysroot], [0], [The root where to search for ]dnl [dependent libraries, and where our libraries should be installed.])]) # _LT_ENABLE_LOCK # --------------- m4_defun([_LT_ENABLE_LOCK], [AC_ARG_ENABLE([libtool-lock], [AS_HELP_STRING([--disable-libtool-lock], [avoid locking (might break parallel builds)])]) test no = "$enable_libtool_lock" || enable_libtool_lock=yes # Some flags need to be propagated to the compiler or linker for good # libtool support. case $host in ia64-*-hpux*) # Find out what ABI is being produced by ac_compile, and set mode # options accordingly. echo 'int i;' > conftest.$ac_ext if AC_TRY_EVAL(ac_compile); then case `/usr/bin/file conftest.$ac_objext` in *ELF-32*) HPUX_IA64_MODE=32 ;; *ELF-64*) HPUX_IA64_MODE=64 ;; esac fi rm -rf conftest* ;; *-*-irix6*) # Find out what ABI is being produced by ac_compile, and set linker # options accordingly. echo '[#]line '$LINENO' "configure"' > conftest.$ac_ext if AC_TRY_EVAL(ac_compile); then if test yes = "$lt_cv_prog_gnu_ld"; then case `/usr/bin/file conftest.$ac_objext` in *32-bit*) LD="${LD-ld} -melf32bsmip" ;; *N32*) LD="${LD-ld} -melf32bmipn32" ;; *64-bit*) LD="${LD-ld} -melf64bmip" ;; esac else case `/usr/bin/file conftest.$ac_objext` in *32-bit*) LD="${LD-ld} -32" ;; *N32*) LD="${LD-ld} -n32" ;; *64-bit*) LD="${LD-ld} -64" ;; esac fi fi rm -rf conftest* ;; mips64*-*linux*) # Find out what ABI is being produced by ac_compile, and set linker # options accordingly. echo '[#]line '$LINENO' "configure"' > conftest.$ac_ext if AC_TRY_EVAL(ac_compile); then emul=elf case `/usr/bin/file conftest.$ac_objext` in *32-bit*) emul="${emul}32" ;; *64-bit*) emul="${emul}64" ;; esac case `/usr/bin/file conftest.$ac_objext` in *MSB*) emul="${emul}btsmip" ;; *LSB*) emul="${emul}ltsmip" ;; esac case `/usr/bin/file conftest.$ac_objext` in *N32*) emul="${emul}n32" ;; esac LD="${LD-ld} -m $emul" fi rm -rf conftest* ;; x86_64-*kfreebsd*-gnu|x86_64-*linux*|powerpc*-*linux*| \ s390*-*linux*|s390*-*tpf*|sparc*-*linux*) # Find out what ABI is being produced by ac_compile, and set linker # options accordingly. Note that the listed cases only cover the # situations where additional linker options are needed (such as when # doing 32-bit compilation for a host where ld defaults to 64-bit, or # vice versa); the common cases where no linker options are needed do # not appear in the list. echo 'int i;' > conftest.$ac_ext if AC_TRY_EVAL(ac_compile); then case `/usr/bin/file conftest.o` in *32-bit*) case $host in x86_64-*kfreebsd*-gnu) LD="${LD-ld} -m elf_i386_fbsd" ;; x86_64-*linux*) case `/usr/bin/file conftest.o` in *x86-64*) LD="${LD-ld} -m elf32_x86_64" ;; *) LD="${LD-ld} -m elf_i386" ;; esac ;; powerpc64le-*linux*) LD="${LD-ld} -m elf32lppclinux" ;; powerpc64-*linux*) LD="${LD-ld} -m elf32ppclinux" ;; s390x-*linux*) LD="${LD-ld} -m elf_s390" ;; sparc64-*linux*) LD="${LD-ld} -m elf32_sparc" ;; esac ;; *64-bit*) case $host in x86_64-*kfreebsd*-gnu) LD="${LD-ld} -m elf_x86_64_fbsd" ;; x86_64-*linux*) LD="${LD-ld} -m elf_x86_64" ;; powerpcle-*linux*) LD="${LD-ld} -m elf64lppc" ;; powerpc-*linux*) LD="${LD-ld} -m elf64ppc" ;; s390*-*linux*|s390*-*tpf*) LD="${LD-ld} -m elf64_s390" ;; sparc*-*linux*) LD="${LD-ld} -m elf64_sparc" ;; esac ;; esac fi rm -rf conftest* ;; *-*-sco3.2v5*) # On SCO OpenServer 5, we need -belf to get full-featured binaries. SAVE_CFLAGS=$CFLAGS CFLAGS="$CFLAGS -belf" AC_CACHE_CHECK([whether the C compiler needs -belf], lt_cv_cc_needs_belf, [AC_LANG_PUSH(C) AC_LINK_IFELSE([AC_LANG_PROGRAM([[]],[[]])],[lt_cv_cc_needs_belf=yes],[lt_cv_cc_needs_belf=no]) AC_LANG_POP]) if test yes != "$lt_cv_cc_needs_belf"; then # this is probably gcc 2.8.0, egcs 1.0 or newer; no need for -belf CFLAGS=$SAVE_CFLAGS fi ;; *-*solaris*) # Find out what ABI is being produced by ac_compile, and set linker # options accordingly. echo 'int i;' > conftest.$ac_ext if AC_TRY_EVAL(ac_compile); then case `/usr/bin/file conftest.o` in *64-bit*) case $lt_cv_prog_gnu_ld in yes*) case $host in i?86-*-solaris*|x86_64-*-solaris*) LD="${LD-ld} -m elf_x86_64" ;; sparc*-*-solaris*) LD="${LD-ld} -m elf64_sparc" ;; esac # GNU ld 2.21 introduced _sol2 emulations. Use them if available. if ${LD-ld} -V | grep _sol2 >/dev/null 2>&1; then LD=${LD-ld}_sol2 fi ;; *) if ${LD-ld} -64 -r -o conftest2.o conftest.o >/dev/null 2>&1; then LD="${LD-ld} -64" fi ;; esac ;; esac fi rm -rf conftest* ;; esac need_locks=$enable_libtool_lock ])# _LT_ENABLE_LOCK # _LT_PROG_AR # ----------- m4_defun([_LT_PROG_AR], [AC_CHECK_TOOLS(AR, [ar], false) : ${AR=ar} : ${AR_FLAGS=cru} _LT_DECL([], [AR], [1], [The archiver]) _LT_DECL([], [AR_FLAGS], [1], [Flags to create an archive]) AC_CACHE_CHECK([for archiver @FILE support], [lt_cv_ar_at_file], [lt_cv_ar_at_file=no AC_COMPILE_IFELSE([AC_LANG_PROGRAM], [echo conftest.$ac_objext > conftest.lst lt_ar_try='$AR $AR_FLAGS libconftest.a @conftest.lst >&AS_MESSAGE_LOG_FD' AC_TRY_EVAL([lt_ar_try]) if test 0 -eq "$ac_status"; then # Ensure the archiver fails upon bogus file names. rm -f conftest.$ac_objext libconftest.a AC_TRY_EVAL([lt_ar_try]) if test 0 -ne "$ac_status"; then lt_cv_ar_at_file=@ fi fi rm -f conftest.* libconftest.a ]) ]) if test no = "$lt_cv_ar_at_file"; then archiver_list_spec= else archiver_list_spec=$lt_cv_ar_at_file fi _LT_DECL([], [archiver_list_spec], [1], [How to feed a file listing to the archiver]) ])# _LT_PROG_AR # _LT_CMD_OLD_ARCHIVE # ------------------- m4_defun([_LT_CMD_OLD_ARCHIVE], [_LT_PROG_AR AC_CHECK_TOOL(STRIP, strip, :) test -z "$STRIP" && STRIP=: _LT_DECL([], [STRIP], [1], [A symbol stripping program]) AC_CHECK_TOOL(RANLIB, ranlib, :) test -z "$RANLIB" && RANLIB=: _LT_DECL([], [RANLIB], [1], [Commands used to install an old-style archive]) # Determine commands to create old-style static archives. old_archive_cmds='$AR $AR_FLAGS $oldlib$oldobjs' old_postinstall_cmds='chmod 644 $oldlib' old_postuninstall_cmds= if test -n "$RANLIB"; then case $host_os in bitrig* | openbsd*) old_postinstall_cmds="$old_postinstall_cmds~\$RANLIB -t \$tool_oldlib" ;; *) old_postinstall_cmds="$old_postinstall_cmds~\$RANLIB \$tool_oldlib" ;; esac old_archive_cmds="$old_archive_cmds~\$RANLIB \$tool_oldlib" fi case $host_os in darwin*) lock_old_archive_extraction=yes ;; *) lock_old_archive_extraction=no ;; esac _LT_DECL([], [old_postinstall_cmds], [2]) _LT_DECL([], [old_postuninstall_cmds], [2]) _LT_TAGDECL([], [old_archive_cmds], [2], [Commands used to build an old-style archive]) _LT_DECL([], [lock_old_archive_extraction], [0], [Whether to use a lock for old archive extraction]) ])# _LT_CMD_OLD_ARCHIVE # _LT_COMPILER_OPTION(MESSAGE, VARIABLE-NAME, FLAGS, # [OUTPUT-FILE], [ACTION-SUCCESS], [ACTION-FAILURE]) # ---------------------------------------------------------------- # Check whether the given compiler option works AC_DEFUN([_LT_COMPILER_OPTION], [m4_require([_LT_FILEUTILS_DEFAULTS])dnl m4_require([_LT_DECL_SED])dnl AC_CACHE_CHECK([$1], [$2], [$2=no m4_if([$4], , [ac_outfile=conftest.$ac_objext], [ac_outfile=$4]) echo "$lt_simple_compile_test_code" > conftest.$ac_ext lt_compiler_flag="$3" ## exclude from sc_useless_quotes_in_assignment # Insert the option either (1) after the last *FLAGS variable, or # (2) before a word containing "conftest.", or (3) at the end. # Note that $ac_compile itself does not contain backslashes and begins # with a dollar sign (not a hyphen), so the echo should work correctly. # The option is referenced via a variable to avoid confusing sed. lt_compile=`echo "$ac_compile" | $SED \ -e 's:.*FLAGS}\{0,1\} :&$lt_compiler_flag :; t' \ -e 's: [[^ ]]*conftest\.: $lt_compiler_flag&:; t' \ -e 's:$: $lt_compiler_flag:'` (eval echo "\"\$as_me:$LINENO: $lt_compile\"" >&AS_MESSAGE_LOG_FD) (eval "$lt_compile" 2>conftest.err) ac_status=$? cat conftest.err >&AS_MESSAGE_LOG_FD echo "$as_me:$LINENO: \$? = $ac_status" >&AS_MESSAGE_LOG_FD if (exit $ac_status) && test -s "$ac_outfile"; then # The compiler can only warn and ignore the option if not recognized # So say no if there are warnings other than the usual output. $ECHO "$_lt_compiler_boilerplate" | $SED '/^$/d' >conftest.exp $SED '/^$/d; /^ *+/d' conftest.err >conftest.er2 if test ! -s conftest.er2 || diff conftest.exp conftest.er2 >/dev/null; then $2=yes fi fi $RM conftest* ]) if test yes = "[$]$2"; then m4_if([$5], , :, [$5]) else m4_if([$6], , :, [$6]) fi ])# _LT_COMPILER_OPTION # Old name: AU_ALIAS([AC_LIBTOOL_COMPILER_OPTION], [_LT_COMPILER_OPTION]) dnl aclocal-1.4 backwards compatibility: dnl AC_DEFUN([AC_LIBTOOL_COMPILER_OPTION], []) # _LT_LINKER_OPTION(MESSAGE, VARIABLE-NAME, FLAGS, # [ACTION-SUCCESS], [ACTION-FAILURE]) # ---------------------------------------------------- # Check whether the given linker option works AC_DEFUN([_LT_LINKER_OPTION], [m4_require([_LT_FILEUTILS_DEFAULTS])dnl m4_require([_LT_DECL_SED])dnl AC_CACHE_CHECK([$1], [$2], [$2=no save_LDFLAGS=$LDFLAGS LDFLAGS="$LDFLAGS $3" echo "$lt_simple_link_test_code" > conftest.$ac_ext if (eval $ac_link 2>conftest.err) && test -s conftest$ac_exeext; then # The linker can only warn and ignore the option if not recognized # So say no if there are warnings if test -s conftest.err; then # Append any errors to the config.log. cat conftest.err 1>&AS_MESSAGE_LOG_FD $ECHO "$_lt_linker_boilerplate" | $SED '/^$/d' > conftest.exp $SED '/^$/d; /^ *+/d' conftest.err >conftest.er2 if diff conftest.exp conftest.er2 >/dev/null; then $2=yes fi else $2=yes fi fi $RM -r conftest* LDFLAGS=$save_LDFLAGS ]) if test yes = "[$]$2"; then m4_if([$4], , :, [$4]) else m4_if([$5], , :, [$5]) fi ])# _LT_LINKER_OPTION # Old name: AU_ALIAS([AC_LIBTOOL_LINKER_OPTION], [_LT_LINKER_OPTION]) dnl aclocal-1.4 backwards compatibility: dnl AC_DEFUN([AC_LIBTOOL_LINKER_OPTION], []) # LT_CMD_MAX_LEN #--------------- AC_DEFUN([LT_CMD_MAX_LEN], [AC_REQUIRE([AC_CANONICAL_HOST])dnl # find the maximum length of command line arguments AC_MSG_CHECKING([the maximum length of command line arguments]) AC_CACHE_VAL([lt_cv_sys_max_cmd_len], [dnl i=0 teststring=ABCD case $build_os in msdosdjgpp*) # On DJGPP, this test can blow up pretty badly due to problems in libc # (any single argument exceeding 2000 bytes causes a buffer overrun # during glob expansion). Even if it were fixed, the result of this # check would be larger than it should be. lt_cv_sys_max_cmd_len=12288; # 12K is about right ;; gnu*) # Under GNU Hurd, this test is not required because there is # no limit to the length of command line arguments. # Libtool will interpret -1 as no limit whatsoever lt_cv_sys_max_cmd_len=-1; ;; cygwin* | mingw* | cegcc*) # On Win9x/ME, this test blows up -- it succeeds, but takes # about 5 minutes as the teststring grows exponentially. # Worse, since 9x/ME are not pre-emptively multitasking, # you end up with a "frozen" computer, even though with patience # the test eventually succeeds (with a max line length of 256k). # Instead, let's just punt: use the minimum linelength reported by # all of the supported platforms: 8192 (on NT/2K/XP). lt_cv_sys_max_cmd_len=8192; ;; mint*) # On MiNT this can take a long time and run out of memory. lt_cv_sys_max_cmd_len=8192; ;; amigaos*) # On AmigaOS with pdksh, this test takes hours, literally. # So we just punt and use a minimum line length of 8192. lt_cv_sys_max_cmd_len=8192; ;; bitrig* | darwin* | dragonfly* | freebsd* | netbsd* | openbsd*) # This has been around since 386BSD, at least. Likely further. if test -x /sbin/sysctl; then lt_cv_sys_max_cmd_len=`/sbin/sysctl -n kern.argmax` elif test -x /usr/sbin/sysctl; then lt_cv_sys_max_cmd_len=`/usr/sbin/sysctl -n kern.argmax` else lt_cv_sys_max_cmd_len=65536 # usable default for all BSDs fi # And add a safety zone lt_cv_sys_max_cmd_len=`expr $lt_cv_sys_max_cmd_len \/ 4` lt_cv_sys_max_cmd_len=`expr $lt_cv_sys_max_cmd_len \* 3` ;; interix*) # We know the value 262144 and hardcode it with a safety zone (like BSD) lt_cv_sys_max_cmd_len=196608 ;; os2*) # The test takes a long time on OS/2. lt_cv_sys_max_cmd_len=8192 ;; osf*) # Dr. Hans Ekkehard Plesser reports seeing a kernel panic running configure # due to this test when exec_disable_arg_limit is 1 on Tru64. It is not # nice to cause kernel panics so lets avoid the loop below. # First set a reasonable default. lt_cv_sys_max_cmd_len=16384 # if test -x /sbin/sysconfig; then case `/sbin/sysconfig -q proc exec_disable_arg_limit` in *1*) lt_cv_sys_max_cmd_len=-1 ;; esac fi ;; sco3.2v5*) lt_cv_sys_max_cmd_len=102400 ;; sysv5* | sco5v6* | sysv4.2uw2*) kargmax=`grep ARG_MAX /etc/conf/cf.d/stune 2>/dev/null` if test -n "$kargmax"; then lt_cv_sys_max_cmd_len=`echo $kargmax | sed 's/.*[[ ]]//'` else lt_cv_sys_max_cmd_len=32768 fi ;; *) lt_cv_sys_max_cmd_len=`(getconf ARG_MAX) 2> /dev/null` if test -n "$lt_cv_sys_max_cmd_len" && \ test undefined != "$lt_cv_sys_max_cmd_len"; then lt_cv_sys_max_cmd_len=`expr $lt_cv_sys_max_cmd_len \/ 4` lt_cv_sys_max_cmd_len=`expr $lt_cv_sys_max_cmd_len \* 3` else # Make teststring a little bigger before we do anything with it. # a 1K string should be a reasonable start. for i in 1 2 3 4 5 6 7 8; do teststring=$teststring$teststring done SHELL=${SHELL-${CONFIG_SHELL-/bin/sh}} # If test is not a shell built-in, we'll probably end up computing a # maximum length that is only half of the actual maximum length, but # we can't tell. while { test X`env echo "$teststring$teststring" 2>/dev/null` \ = "X$teststring$teststring"; } >/dev/null 2>&1 && test 17 != "$i" # 1/2 MB should be enough do i=`expr $i + 1` teststring=$teststring$teststring done # Only check the string length outside the loop. lt_cv_sys_max_cmd_len=`expr "X$teststring" : ".*" 2>&1` teststring= # Add a significant safety factor because C++ compilers can tack on # massive amounts of additional arguments before passing them to the # linker. It appears as though 1/2 is a usable value. lt_cv_sys_max_cmd_len=`expr $lt_cv_sys_max_cmd_len \/ 2` fi ;; esac ]) if test -n "$lt_cv_sys_max_cmd_len"; then AC_MSG_RESULT($lt_cv_sys_max_cmd_len) else AC_MSG_RESULT(none) fi max_cmd_len=$lt_cv_sys_max_cmd_len _LT_DECL([], [max_cmd_len], [0], [What is the maximum length of a command?]) ])# LT_CMD_MAX_LEN # Old name: AU_ALIAS([AC_LIBTOOL_SYS_MAX_CMD_LEN], [LT_CMD_MAX_LEN]) dnl aclocal-1.4 backwards compatibility: dnl AC_DEFUN([AC_LIBTOOL_SYS_MAX_CMD_LEN], []) # _LT_HEADER_DLFCN # ---------------- m4_defun([_LT_HEADER_DLFCN], [AC_CHECK_HEADERS([dlfcn.h], [], [], [AC_INCLUDES_DEFAULT])dnl ])# _LT_HEADER_DLFCN # _LT_TRY_DLOPEN_SELF (ACTION-IF-TRUE, ACTION-IF-TRUE-W-USCORE, # ACTION-IF-FALSE, ACTION-IF-CROSS-COMPILING) # ---------------------------------------------------------------- m4_defun([_LT_TRY_DLOPEN_SELF], [m4_require([_LT_HEADER_DLFCN])dnl if test yes = "$cross_compiling"; then : [$4] else lt_dlunknown=0; lt_dlno_uscore=1; lt_dlneed_uscore=2 lt_status=$lt_dlunknown cat > conftest.$ac_ext <<_LT_EOF [#line $LINENO "configure" #include "confdefs.h" #if HAVE_DLFCN_H #include #endif #include #ifdef RTLD_GLOBAL # define LT_DLGLOBAL RTLD_GLOBAL #else # ifdef DL_GLOBAL # define LT_DLGLOBAL DL_GLOBAL # else # define LT_DLGLOBAL 0 # endif #endif /* We may have to define LT_DLLAZY_OR_NOW in the command line if we find out it does not work in some platform. */ #ifndef LT_DLLAZY_OR_NOW # ifdef RTLD_LAZY # define LT_DLLAZY_OR_NOW RTLD_LAZY # else # ifdef DL_LAZY # define LT_DLLAZY_OR_NOW DL_LAZY # else # ifdef RTLD_NOW # define LT_DLLAZY_OR_NOW RTLD_NOW # else # ifdef DL_NOW # define LT_DLLAZY_OR_NOW DL_NOW # else # define LT_DLLAZY_OR_NOW 0 # endif # endif # endif # endif #endif /* When -fvisibility=hidden is used, assume the code has been annotated correspondingly for the symbols needed. */ #if defined __GNUC__ && (((__GNUC__ == 3) && (__GNUC_MINOR__ >= 3)) || (__GNUC__ > 3)) int fnord () __attribute__((visibility("default"))); #endif int fnord () { return 42; } int main () { void *self = dlopen (0, LT_DLGLOBAL|LT_DLLAZY_OR_NOW); int status = $lt_dlunknown; if (self) { if (dlsym (self,"fnord")) status = $lt_dlno_uscore; else { if (dlsym( self,"_fnord")) status = $lt_dlneed_uscore; else puts (dlerror ()); } /* dlclose (self); */ } else puts (dlerror ()); return status; }] _LT_EOF if AC_TRY_EVAL(ac_link) && test -s "conftest$ac_exeext" 2>/dev/null; then (./conftest; exit; ) >&AS_MESSAGE_LOG_FD 2>/dev/null lt_status=$? case x$lt_status in x$lt_dlno_uscore) $1 ;; x$lt_dlneed_uscore) $2 ;; x$lt_dlunknown|x*) $3 ;; esac else : # compilation failed $3 fi fi rm -fr conftest* ])# _LT_TRY_DLOPEN_SELF # LT_SYS_DLOPEN_SELF # ------------------ AC_DEFUN([LT_SYS_DLOPEN_SELF], [m4_require([_LT_HEADER_DLFCN])dnl if test yes != "$enable_dlopen"; then enable_dlopen=unknown enable_dlopen_self=unknown enable_dlopen_self_static=unknown else lt_cv_dlopen=no lt_cv_dlopen_libs= case $host_os in beos*) lt_cv_dlopen=load_add_on lt_cv_dlopen_libs= lt_cv_dlopen_self=yes ;; mingw* | pw32* | cegcc*) lt_cv_dlopen=LoadLibrary lt_cv_dlopen_libs= ;; cygwin*) lt_cv_dlopen=dlopen lt_cv_dlopen_libs= ;; darwin*) # if libdl is installed we need to link against it AC_CHECK_LIB([dl], [dlopen], [lt_cv_dlopen=dlopen lt_cv_dlopen_libs=-ldl],[ lt_cv_dlopen=dyld lt_cv_dlopen_libs= lt_cv_dlopen_self=yes ]) ;; tpf*) # Don't try to run any link tests for TPF. We know it's impossible # because TPF is a cross-compiler, and we know how we open DSOs. lt_cv_dlopen=dlopen lt_cv_dlopen_libs= lt_cv_dlopen_self=no ;; *) AC_CHECK_FUNC([shl_load], [lt_cv_dlopen=shl_load], [AC_CHECK_LIB([dld], [shl_load], [lt_cv_dlopen=shl_load lt_cv_dlopen_libs=-ldld], [AC_CHECK_FUNC([dlopen], [lt_cv_dlopen=dlopen], [AC_CHECK_LIB([dl], [dlopen], [lt_cv_dlopen=dlopen lt_cv_dlopen_libs=-ldl], [AC_CHECK_LIB([svld], [dlopen], [lt_cv_dlopen=dlopen lt_cv_dlopen_libs=-lsvld], [AC_CHECK_LIB([dld], [dld_link], [lt_cv_dlopen=dld_link lt_cv_dlopen_libs=-ldld]) ]) ]) ]) ]) ]) ;; esac if test no = "$lt_cv_dlopen"; then enable_dlopen=no else enable_dlopen=yes fi case $lt_cv_dlopen in dlopen) save_CPPFLAGS=$CPPFLAGS test yes = "$ac_cv_header_dlfcn_h" && CPPFLAGS="$CPPFLAGS -DHAVE_DLFCN_H" save_LDFLAGS=$LDFLAGS wl=$lt_prog_compiler_wl eval LDFLAGS=\"\$LDFLAGS $export_dynamic_flag_spec\" save_LIBS=$LIBS LIBS="$lt_cv_dlopen_libs $LIBS" AC_CACHE_CHECK([whether a program can dlopen itself], lt_cv_dlopen_self, [dnl _LT_TRY_DLOPEN_SELF( lt_cv_dlopen_self=yes, lt_cv_dlopen_self=yes, lt_cv_dlopen_self=no, lt_cv_dlopen_self=cross) ]) if test yes = "$lt_cv_dlopen_self"; then wl=$lt_prog_compiler_wl eval LDFLAGS=\"\$LDFLAGS $lt_prog_compiler_static\" AC_CACHE_CHECK([whether a statically linked program can dlopen itself], lt_cv_dlopen_self_static, [dnl _LT_TRY_DLOPEN_SELF( lt_cv_dlopen_self_static=yes, lt_cv_dlopen_self_static=yes, lt_cv_dlopen_self_static=no, lt_cv_dlopen_self_static=cross) ]) fi CPPFLAGS=$save_CPPFLAGS LDFLAGS=$save_LDFLAGS LIBS=$save_LIBS ;; esac case $lt_cv_dlopen_self in yes|no) enable_dlopen_self=$lt_cv_dlopen_self ;; *) enable_dlopen_self=unknown ;; esac case $lt_cv_dlopen_self_static in yes|no) enable_dlopen_self_static=$lt_cv_dlopen_self_static ;; *) enable_dlopen_self_static=unknown ;; esac fi _LT_DECL([dlopen_support], [enable_dlopen], [0], [Whether dlopen is supported]) _LT_DECL([dlopen_self], [enable_dlopen_self], [0], [Whether dlopen of programs is supported]) _LT_DECL([dlopen_self_static], [enable_dlopen_self_static], [0], [Whether dlopen of statically linked programs is supported]) ])# LT_SYS_DLOPEN_SELF # Old name: AU_ALIAS([AC_LIBTOOL_DLOPEN_SELF], [LT_SYS_DLOPEN_SELF]) dnl aclocal-1.4 backwards compatibility: dnl AC_DEFUN([AC_LIBTOOL_DLOPEN_SELF], []) # _LT_COMPILER_C_O([TAGNAME]) # --------------------------- # Check to see if options -c and -o are simultaneously supported by compiler. # This macro does not hard code the compiler like AC_PROG_CC_C_O. m4_defun([_LT_COMPILER_C_O], [m4_require([_LT_DECL_SED])dnl m4_require([_LT_FILEUTILS_DEFAULTS])dnl m4_require([_LT_TAG_COMPILER])dnl AC_CACHE_CHECK([if $compiler supports -c -o file.$ac_objext], [_LT_TAGVAR(lt_cv_prog_compiler_c_o, $1)], [_LT_TAGVAR(lt_cv_prog_compiler_c_o, $1)=no $RM -r conftest 2>/dev/null mkdir conftest cd conftest mkdir out echo "$lt_simple_compile_test_code" > conftest.$ac_ext lt_compiler_flag="-o out/conftest2.$ac_objext" # Insert the option either (1) after the last *FLAGS variable, or # (2) before a word containing "conftest.", or (3) at the end. # Note that $ac_compile itself does not contain backslashes and begins # with a dollar sign (not a hyphen), so the echo should work correctly. lt_compile=`echo "$ac_compile" | $SED \ -e 's:.*FLAGS}\{0,1\} :&$lt_compiler_flag :; t' \ -e 's: [[^ ]]*conftest\.: $lt_compiler_flag&:; t' \ -e 's:$: $lt_compiler_flag:'` (eval echo "\"\$as_me:$LINENO: $lt_compile\"" >&AS_MESSAGE_LOG_FD) (eval "$lt_compile" 2>out/conftest.err) ac_status=$? cat out/conftest.err >&AS_MESSAGE_LOG_FD echo "$as_me:$LINENO: \$? = $ac_status" >&AS_MESSAGE_LOG_FD if (exit $ac_status) && test -s out/conftest2.$ac_objext then # The compiler can only warn and ignore the option if not recognized # So say no if there are warnings $ECHO "$_lt_compiler_boilerplate" | $SED '/^$/d' > out/conftest.exp $SED '/^$/d; /^ *+/d' out/conftest.err >out/conftest.er2 if test ! -s out/conftest.er2 || diff out/conftest.exp out/conftest.er2 >/dev/null; then _LT_TAGVAR(lt_cv_prog_compiler_c_o, $1)=yes fi fi chmod u+w . 2>&AS_MESSAGE_LOG_FD $RM conftest* # SGI C++ compiler will create directory out/ii_files/ for # template instantiation test -d out/ii_files && $RM out/ii_files/* && rmdir out/ii_files $RM out/* && rmdir out cd .. $RM -r conftest $RM conftest* ]) _LT_TAGDECL([compiler_c_o], [lt_cv_prog_compiler_c_o], [1], [Does compiler simultaneously support -c and -o options?]) ])# _LT_COMPILER_C_O # _LT_COMPILER_FILE_LOCKS([TAGNAME]) # ---------------------------------- # Check to see if we can do hard links to lock some files if needed m4_defun([_LT_COMPILER_FILE_LOCKS], [m4_require([_LT_ENABLE_LOCK])dnl m4_require([_LT_FILEUTILS_DEFAULTS])dnl _LT_COMPILER_C_O([$1]) hard_links=nottested if test no = "$_LT_TAGVAR(lt_cv_prog_compiler_c_o, $1)" && test no != "$need_locks"; then # do not overwrite the value of need_locks provided by the user AC_MSG_CHECKING([if we can lock with hard links]) hard_links=yes $RM conftest* ln conftest.a conftest.b 2>/dev/null && hard_links=no touch conftest.a ln conftest.a conftest.b 2>&5 || hard_links=no ln conftest.a conftest.b 2>/dev/null && hard_links=no AC_MSG_RESULT([$hard_links]) if test no = "$hard_links"; then AC_MSG_WARN(['$CC' does not support '-c -o', so 'make -j' may be unsafe]) need_locks=warn fi else need_locks=no fi _LT_DECL([], [need_locks], [1], [Must we lock files when doing compilation?]) ])# _LT_COMPILER_FILE_LOCKS # _LT_CHECK_OBJDIR # ---------------- m4_defun([_LT_CHECK_OBJDIR], [AC_CACHE_CHECK([for objdir], [lt_cv_objdir], [rm -f .libs 2>/dev/null mkdir .libs 2>/dev/null if test -d .libs; then lt_cv_objdir=.libs else # MS-DOS does not allow filenames that begin with a dot. lt_cv_objdir=_libs fi rmdir .libs 2>/dev/null]) objdir=$lt_cv_objdir _LT_DECL([], [objdir], [0], [The name of the directory that contains temporary libtool files])dnl m4_pattern_allow([LT_OBJDIR])dnl AC_DEFINE_UNQUOTED([LT_OBJDIR], "$lt_cv_objdir/", [Define to the sub-directory where libtool stores uninstalled libraries.]) ])# _LT_CHECK_OBJDIR # _LT_LINKER_HARDCODE_LIBPATH([TAGNAME]) # -------------------------------------- # Check hardcoding attributes. m4_defun([_LT_LINKER_HARDCODE_LIBPATH], [AC_MSG_CHECKING([how to hardcode library paths into programs]) _LT_TAGVAR(hardcode_action, $1)= if test -n "$_LT_TAGVAR(hardcode_libdir_flag_spec, $1)" || test -n "$_LT_TAGVAR(runpath_var, $1)" || test yes = "$_LT_TAGVAR(hardcode_automatic, $1)"; then # We can hardcode non-existent directories. if test no != "$_LT_TAGVAR(hardcode_direct, $1)" && # If the only mechanism to avoid hardcoding is shlibpath_var, we # have to relink, otherwise we might link with an installed library # when we should be linking with a yet-to-be-installed one ## test no != "$_LT_TAGVAR(hardcode_shlibpath_var, $1)" && test no != "$_LT_TAGVAR(hardcode_minus_L, $1)"; then # Linking always hardcodes the temporary library directory. _LT_TAGVAR(hardcode_action, $1)=relink else # We can link without hardcoding, and we can hardcode nonexisting dirs. _LT_TAGVAR(hardcode_action, $1)=immediate fi else # We cannot hardcode anything, or else we can only hardcode existing # directories. _LT_TAGVAR(hardcode_action, $1)=unsupported fi AC_MSG_RESULT([$_LT_TAGVAR(hardcode_action, $1)]) if test relink = "$_LT_TAGVAR(hardcode_action, $1)" || test yes = "$_LT_TAGVAR(inherit_rpath, $1)"; then # Fast installation is not supported enable_fast_install=no elif test yes = "$shlibpath_overrides_runpath" || test no = "$enable_shared"; then # Fast installation is not necessary enable_fast_install=needless fi _LT_TAGDECL([], [hardcode_action], [0], [How to hardcode a shared library path into an executable]) ])# _LT_LINKER_HARDCODE_LIBPATH # _LT_CMD_STRIPLIB # ---------------- m4_defun([_LT_CMD_STRIPLIB], [m4_require([_LT_DECL_EGREP]) striplib= old_striplib= AC_MSG_CHECKING([whether stripping libraries is possible]) if test -n "$STRIP" && $STRIP -V 2>&1 | $GREP "GNU strip" >/dev/null; then test -z "$old_striplib" && old_striplib="$STRIP --strip-debug" test -z "$striplib" && striplib="$STRIP --strip-unneeded" AC_MSG_RESULT([yes]) else # FIXME - insert some real tests, host_os isn't really good enough case $host_os in darwin*) if test -n "$STRIP"; then striplib="$STRIP -x" old_striplib="$STRIP -S" AC_MSG_RESULT([yes]) else AC_MSG_RESULT([no]) fi ;; *) AC_MSG_RESULT([no]) ;; esac fi _LT_DECL([], [old_striplib], [1], [Commands to strip libraries]) _LT_DECL([], [striplib], [1]) ])# _LT_CMD_STRIPLIB # _LT_PREPARE_MUNGE_PATH_LIST # --------------------------- # Make sure func_munge_path_list() is defined correctly. m4_defun([_LT_PREPARE_MUNGE_PATH_LIST], [[# func_munge_path_list VARIABLE PATH # ----------------------------------- # VARIABLE is name of variable containing _space_ separated list of # directories to be munged by the contents of PATH, which is string # having a format: # "DIR[:DIR]:" # string "DIR[ DIR]" will be prepended to VARIABLE # ":DIR[:DIR]" # string "DIR[ DIR]" will be appended to VARIABLE # "DIRP[:DIRP]::[DIRA:]DIRA" # string "DIRP[ DIRP]" will be prepended to VARIABLE and string # "DIRA[ DIRA]" will be appended to VARIABLE # "DIR[:DIR]" # VARIABLE will be replaced by "DIR[ DIR]" func_munge_path_list () { case x@S|@2 in x) ;; *:) eval @S|@1=\"`$ECHO @S|@2 | $SED 's/:/ /g'` \@S|@@S|@1\" ;; x:*) eval @S|@1=\"\@S|@@S|@1 `$ECHO @S|@2 | $SED 's/:/ /g'`\" ;; *::*) eval @S|@1=\"\@S|@@S|@1\ `$ECHO @S|@2 | $SED -e 's/.*:://' -e 's/:/ /g'`\" eval @S|@1=\"`$ECHO @S|@2 | $SED -e 's/::.*//' -e 's/:/ /g'`\ \@S|@@S|@1\" ;; *) eval @S|@1=\"`$ECHO @S|@2 | $SED 's/:/ /g'`\" ;; esac } ]])# _LT_PREPARE_PATH_LIST # _LT_SYS_DYNAMIC_LINKER([TAG]) # ----------------------------- # PORTME Fill in your ld.so characteristics m4_defun([_LT_SYS_DYNAMIC_LINKER], [AC_REQUIRE([AC_CANONICAL_HOST])dnl m4_require([_LT_DECL_EGREP])dnl m4_require([_LT_FILEUTILS_DEFAULTS])dnl m4_require([_LT_DECL_OBJDUMP])dnl m4_require([_LT_DECL_SED])dnl m4_require([_LT_CHECK_SHELL_FEATURES])dnl m4_require([_LT_PREPARE_MUNGE_PATH_LIST])dnl AC_MSG_CHECKING([dynamic linker characteristics]) m4_if([$1], [], [ if test yes = "$GCC"; then case $host_os in darwin*) lt_awk_arg='/^libraries:/,/LR/' ;; *) lt_awk_arg='/^libraries:/' ;; esac case $host_os in mingw* | cegcc*) lt_sed_strip_eq='s|=\([[A-Za-z]]:\)|\1|g' ;; *) lt_sed_strip_eq='s|=/|/|g' ;; esac lt_search_path_spec=`$CC -print-search-dirs | awk $lt_awk_arg | $SED -e "s/^libraries://" -e $lt_sed_strip_eq` case $lt_search_path_spec in *\;*) # if the path contains ";" then we assume it to be the separator # otherwise default to the standard path separator (i.e. ":") - it is # assumed that no part of a normal pathname contains ";" but that should # okay in the real world where ";" in dirpaths is itself problematic. lt_search_path_spec=`$ECHO "$lt_search_path_spec" | $SED 's/;/ /g'` ;; *) lt_search_path_spec=`$ECHO "$lt_search_path_spec" | $SED "s/$PATH_SEPARATOR/ /g"` ;; esac # Ok, now we have the path, separated by spaces, we can step through it # and add multilib dir if necessary... lt_tmp_lt_search_path_spec= lt_multi_os_dir=/`$CC $CPPFLAGS $CFLAGS $LDFLAGS -print-multi-os-directory 2>/dev/null` # ...but if some path component already ends with the multilib dir we assume # that all is fine and trust -print-search-dirs as is (GCC 4.2? or newer). case "$lt_multi_os_dir; $lt_search_path_spec " in "/; "* | "/.; "* | "/./; "* | *"$lt_multi_os_dir "* | *"$lt_multi_os_dir/ "*) lt_multi_os_dir= ;; esac for lt_sys_path in $lt_search_path_spec; do if test -d "$lt_sys_path$lt_multi_os_dir"; then lt_tmp_lt_search_path_spec="$lt_tmp_lt_search_path_spec $lt_sys_path$lt_multi_os_dir" elif test -n "$lt_multi_os_dir"; then test -d "$lt_sys_path" && \ lt_tmp_lt_search_path_spec="$lt_tmp_lt_search_path_spec $lt_sys_path" fi done lt_search_path_spec=`$ECHO "$lt_tmp_lt_search_path_spec" | awk ' BEGIN {RS = " "; FS = "/|\n";} { lt_foo = ""; lt_count = 0; for (lt_i = NF; lt_i > 0; lt_i--) { if ($lt_i != "" && $lt_i != ".") { if ($lt_i == "..") { lt_count++; } else { if (lt_count == 0) { lt_foo = "/" $lt_i lt_foo; } else { lt_count--; } } } } if (lt_foo != "") { lt_freq[[lt_foo]]++; } if (lt_freq[[lt_foo]] == 1) { print lt_foo; } }'` # AWK program above erroneously prepends '/' to C:/dos/paths # for these hosts. case $host_os in mingw* | cegcc*) lt_search_path_spec=`$ECHO "$lt_search_path_spec" |\ $SED 's|/\([[A-Za-z]]:\)|\1|g'` ;; esac sys_lib_search_path_spec=`$ECHO "$lt_search_path_spec" | $lt_NL2SP` else sys_lib_search_path_spec="/lib /usr/lib /usr/local/lib" fi]) library_names_spec= libname_spec='lib$name' soname_spec= shrext_cmds=.so postinstall_cmds= postuninstall_cmds= finish_cmds= finish_eval= shlibpath_var= shlibpath_overrides_runpath=unknown version_type=none dynamic_linker="$host_os ld.so" sys_lib_dlsearch_path_spec="/lib /usr/lib" need_lib_prefix=unknown hardcode_into_libs=no # when you set need_version to no, make sure it does not cause -set_version # flags to be left without arguments need_version=unknown AC_ARG_VAR([LT_SYS_LIBRARY_PATH], [User-defined run-time library search path.]) case $host_os in aix3*) version_type=linux # correct to gnu/linux during the next big refactor library_names_spec='$libname$release$shared_ext$versuffix $libname.a' shlibpath_var=LIBPATH # AIX 3 has no versioning support, so we append a major version to the name. soname_spec='$libname$release$shared_ext$major' ;; aix[[4-9]]*) version_type=linux # correct to gnu/linux during the next big refactor need_lib_prefix=no need_version=no hardcode_into_libs=yes if test ia64 = "$host_cpu"; then # AIX 5 supports IA64 library_names_spec='$libname$release$shared_ext$major $libname$release$shared_ext$versuffix $libname$shared_ext' shlibpath_var=LD_LIBRARY_PATH else # With GCC up to 2.95.x, collect2 would create an import file # for dependence libraries. The import file would start with # the line '#! .'. This would cause the generated library to # depend on '.', always an invalid library. This was fixed in # development snapshots of GCC prior to 3.0. case $host_os in aix4 | aix4.[[01]] | aix4.[[01]].*) if { echo '#if __GNUC__ > 2 || (__GNUC__ == 2 && __GNUC_MINOR__ >= 97)' echo ' yes ' echo '#endif'; } | $CC -E - | $GREP yes > /dev/null; then : else can_build_shared=no fi ;; esac # Using Import Files as archive members, it is possible to support # filename-based versioning of shared library archives on AIX. While # this would work for both with and without runtime linking, it will # prevent static linking of such archives. So we do filename-based # shared library versioning with .so extension only, which is used # when both runtime linking and shared linking is enabled. # Unfortunately, runtime linking may impact performance, so we do # not want this to be the default eventually. Also, we use the # versioned .so libs for executables only if there is the -brtl # linker flag in LDFLAGS as well, or --with-aix-soname=svr4 only. # To allow for filename-based versioning support, we need to create # libNAME.so.V as an archive file, containing: # *) an Import File, referring to the versioned filename of the # archive as well as the shared archive member, telling the # bitwidth (32 or 64) of that shared object, and providing the # list of exported symbols of that shared object, eventually # decorated with the 'weak' keyword # *) the shared object with the F_LOADONLY flag set, to really avoid # it being seen by the linker. # At run time we better use the real file rather than another symlink, # but for link time we create the symlink libNAME.so -> libNAME.so.V case $with_aix_soname,$aix_use_runtimelinking in # AIX (on Power*) has no versioning support, so currently we cannot hardcode correct # soname into executable. Probably we can add versioning support to # collect2, so additional links can be useful in future. aix,yes) # traditional libtool dynamic_linker='AIX unversionable lib.so' # If using run time linking (on AIX 4.2 or later) use lib.so # instead of lib.a to let people know that these are not # typical AIX shared libraries. library_names_spec='$libname$release$shared_ext$versuffix $libname$release$shared_ext$major $libname$shared_ext' ;; aix,no) # traditional AIX only dynamic_linker='AIX lib.a[(]lib.so.V[)]' # We preserve .a as extension for shared libraries through AIX4.2 # and later when we are not doing run time linking. library_names_spec='$libname$release.a $libname.a' soname_spec='$libname$release$shared_ext$major' ;; svr4,*) # full svr4 only dynamic_linker="AIX lib.so.V[(]$shared_archive_member_spec.o[)]" library_names_spec='$libname$release$shared_ext$major $libname$shared_ext' # We do not specify a path in Import Files, so LIBPATH fires. shlibpath_overrides_runpath=yes ;; *,yes) # both, prefer svr4 dynamic_linker="AIX lib.so.V[(]$shared_archive_member_spec.o[)], lib.a[(]lib.so.V[)]" library_names_spec='$libname$release$shared_ext$major $libname$shared_ext' # unpreferred sharedlib libNAME.a needs extra handling postinstall_cmds='test -n "$linkname" || linkname="$realname"~func_stripname "" ".so" "$linkname"~$install_shared_prog "$dir/$func_stripname_result.$libext" "$destdir/$func_stripname_result.$libext"~test -z "$tstripme" || test -z "$striplib" || $striplib "$destdir/$func_stripname_result.$libext"' postuninstall_cmds='for n in $library_names $old_library; do :; done~func_stripname "" ".so" "$n"~test "$func_stripname_result" = "$n" || func_append rmfiles " $odir/$func_stripname_result.$libext"' # We do not specify a path in Import Files, so LIBPATH fires. shlibpath_overrides_runpath=yes ;; *,no) # both, prefer aix dynamic_linker="AIX lib.a[(]lib.so.V[)], lib.so.V[(]$shared_archive_member_spec.o[)]" library_names_spec='$libname$release.a $libname.a' soname_spec='$libname$release$shared_ext$major' # unpreferred sharedlib libNAME.so.V and symlink libNAME.so need extra handling postinstall_cmds='test -z "$dlname" || $install_shared_prog $dir/$dlname $destdir/$dlname~test -z "$tstripme" || test -z "$striplib" || $striplib $destdir/$dlname~test -n "$linkname" || linkname=$realname~func_stripname "" ".a" "$linkname"~(cd "$destdir" && $LN_S -f $dlname $func_stripname_result.so)' postuninstall_cmds='test -z "$dlname" || func_append rmfiles " $odir/$dlname"~for n in $old_library $library_names; do :; done~func_stripname "" ".a" "$n"~func_append rmfiles " $odir/$func_stripname_result.so"' ;; esac shlibpath_var=LIBPATH fi ;; amigaos*) case $host_cpu in powerpc) # Since July 2007 AmigaOS4 officially supports .so libraries. # When compiling the executable, add -use-dynld -Lsobjs: to the compileline. library_names_spec='$libname$release$shared_ext$versuffix $libname$release$shared_ext$major $libname$shared_ext' ;; m68k) library_names_spec='$libname.ixlibrary $libname.a' # Create ${libname}_ixlibrary.a entries in /sys/libs. finish_eval='for lib in `ls $libdir/*.ixlibrary 2>/dev/null`; do libname=`func_echo_all "$lib" | $SED '\''s%^.*/\([[^/]]*\)\.ixlibrary$%\1%'\''`; $RM /sys/libs/${libname}_ixlibrary.a; $show "cd /sys/libs && $LN_S $lib ${libname}_ixlibrary.a"; cd /sys/libs && $LN_S $lib ${libname}_ixlibrary.a || exit 1; done' ;; esac ;; beos*) library_names_spec='$libname$shared_ext' dynamic_linker="$host_os ld.so" shlibpath_var=LIBRARY_PATH ;; bsdi[[45]]*) version_type=linux # correct to gnu/linux during the next big refactor need_version=no library_names_spec='$libname$release$shared_ext$versuffix $libname$release$shared_ext$major $libname$shared_ext' soname_spec='$libname$release$shared_ext$major' finish_cmds='PATH="\$PATH:/sbin" ldconfig $libdir' shlibpath_var=LD_LIBRARY_PATH sys_lib_search_path_spec="/shlib /usr/lib /usr/X11/lib /usr/contrib/lib /lib /usr/local/lib" sys_lib_dlsearch_path_spec="/shlib /usr/lib /usr/local/lib" # the default ld.so.conf also contains /usr/contrib/lib and # /usr/X11R6/lib (/usr/X11 is a link to /usr/X11R6), but let us allow # libtool to hard-code these into programs ;; cygwin* | mingw* | pw32* | cegcc*) version_type=windows shrext_cmds=.dll need_version=no need_lib_prefix=no case $GCC,$cc_basename in yes,*) # gcc library_names_spec='$libname.dll.a' # DLL is installed to $(libdir)/../bin by postinstall_cmds postinstall_cmds='base_file=`basename \$file`~ dlpath=`$SHELL 2>&1 -c '\''. $dir/'\''\$base_file'\''i; echo \$dlname'\''`~ dldir=$destdir/`dirname \$dlpath`~ test -d \$dldir || mkdir -p \$dldir~ $install_prog $dir/$dlname \$dldir/$dlname~ chmod a+x \$dldir/$dlname~ if test -n '\''$stripme'\'' && test -n '\''$striplib'\''; then eval '\''$striplib \$dldir/$dlname'\'' || exit \$?; fi' postuninstall_cmds='dldll=`$SHELL 2>&1 -c '\''. $file; echo \$dlname'\''`~ dlpath=$dir/\$dldll~ $RM \$dlpath' shlibpath_overrides_runpath=yes case $host_os in cygwin*) # Cygwin DLLs use 'cyg' prefix rather than 'lib' soname_spec='`echo $libname | sed -e 's/^lib/cyg/'``echo $release | $SED -e 's/[[.]]/-/g'`$versuffix$shared_ext' m4_if([$1], [],[ sys_lib_search_path_spec="$sys_lib_search_path_spec /usr/lib/w32api"]) ;; mingw* | cegcc*) # MinGW DLLs use traditional 'lib' prefix soname_spec='$libname`echo $release | $SED -e 's/[[.]]/-/g'`$versuffix$shared_ext' ;; pw32*) # pw32 DLLs use 'pw' prefix rather than 'lib' library_names_spec='`echo $libname | sed -e 's/^lib/pw/'``echo $release | $SED -e 's/[[.]]/-/g'`$versuffix$shared_ext' ;; esac dynamic_linker='Win32 ld.exe' ;; *,cl*) # Native MSVC libname_spec='$name' soname_spec='$libname`echo $release | $SED -e 's/[[.]]/-/g'`$versuffix$shared_ext' library_names_spec='$libname.dll.lib' case $build_os in mingw*) sys_lib_search_path_spec= lt_save_ifs=$IFS IFS=';' for lt_path in $LIB do IFS=$lt_save_ifs # Let DOS variable expansion print the short 8.3 style file name. lt_path=`cd "$lt_path" 2>/dev/null && cmd //C "for %i in (".") do @echo %~si"` sys_lib_search_path_spec="$sys_lib_search_path_spec $lt_path" done IFS=$lt_save_ifs # Convert to MSYS style. sys_lib_search_path_spec=`$ECHO "$sys_lib_search_path_spec" | sed -e 's|\\\\|/|g' -e 's| \\([[a-zA-Z]]\\):| /\\1|g' -e 's|^ ||'` ;; cygwin*) # Convert to unix form, then to dos form, then back to unix form # but this time dos style (no spaces!) so that the unix form looks # like /cygdrive/c/PROGRA~1:/cygdr... sys_lib_search_path_spec=`cygpath --path --unix "$LIB"` sys_lib_search_path_spec=`cygpath --path --dos "$sys_lib_search_path_spec" 2>/dev/null` sys_lib_search_path_spec=`cygpath --path --unix "$sys_lib_search_path_spec" | $SED -e "s/$PATH_SEPARATOR/ /g"` ;; *) sys_lib_search_path_spec=$LIB if $ECHO "$sys_lib_search_path_spec" | [$GREP ';[c-zC-Z]:/' >/dev/null]; then # It is most probably a Windows format PATH. sys_lib_search_path_spec=`$ECHO "$sys_lib_search_path_spec" | $SED -e 's/;/ /g'` else sys_lib_search_path_spec=`$ECHO "$sys_lib_search_path_spec" | $SED -e "s/$PATH_SEPARATOR/ /g"` fi # FIXME: find the short name or the path components, as spaces are # common. (e.g. "Program Files" -> "PROGRA~1") ;; esac # DLL is installed to $(libdir)/../bin by postinstall_cmds postinstall_cmds='base_file=`basename \$file`~ dlpath=`$SHELL 2>&1 -c '\''. $dir/'\''\$base_file'\''i; echo \$dlname'\''`~ dldir=$destdir/`dirname \$dlpath`~ test -d \$dldir || mkdir -p \$dldir~ $install_prog $dir/$dlname \$dldir/$dlname' postuninstall_cmds='dldll=`$SHELL 2>&1 -c '\''. $file; echo \$dlname'\''`~ dlpath=$dir/\$dldll~ $RM \$dlpath' shlibpath_overrides_runpath=yes dynamic_linker='Win32 link.exe' ;; *) # Assume MSVC wrapper library_names_spec='$libname`echo $release | $SED -e 's/[[.]]/-/g'`$versuffix$shared_ext $libname.lib' dynamic_linker='Win32 ld.exe' ;; esac # FIXME: first we should search . and the directory the executable is in shlibpath_var=PATH ;; darwin* | rhapsody*) dynamic_linker="$host_os dyld" version_type=darwin need_lib_prefix=no need_version=no library_names_spec='$libname$release$major$shared_ext $libname$shared_ext' soname_spec='$libname$release$major$shared_ext' shlibpath_overrides_runpath=yes shlibpath_var=DYLD_LIBRARY_PATH shrext_cmds='`test .$module = .yes && echo .so || echo .dylib`' m4_if([$1], [],[ sys_lib_search_path_spec="$sys_lib_search_path_spec /usr/local/lib"]) sys_lib_dlsearch_path_spec='/usr/local/lib /lib /usr/lib' ;; dgux*) version_type=linux # correct to gnu/linux during the next big refactor need_lib_prefix=no need_version=no library_names_spec='$libname$release$shared_ext$versuffix $libname$release$shared_ext$major $libname$shared_ext' soname_spec='$libname$release$shared_ext$major' shlibpath_var=LD_LIBRARY_PATH ;; freebsd* | dragonfly*) # DragonFly does not have aout. When/if they implement a new # versioning mechanism, adjust this. if test -x /usr/bin/objformat; then objformat=`/usr/bin/objformat` else case $host_os in freebsd[[23]].*) objformat=aout ;; *) objformat=elf ;; esac fi version_type=freebsd-$objformat case $version_type in freebsd-elf*) library_names_spec='$libname$release$shared_ext$versuffix $libname$release$shared_ext$major $libname$shared_ext' soname_spec='$libname$release$shared_ext$major' need_version=no need_lib_prefix=no ;; freebsd-*) library_names_spec='$libname$release$shared_ext$versuffix $libname$shared_ext$versuffix' need_version=yes ;; esac shlibpath_var=LD_LIBRARY_PATH case $host_os in freebsd2.*) shlibpath_overrides_runpath=yes ;; freebsd3.[[01]]* | freebsdelf3.[[01]]*) shlibpath_overrides_runpath=yes hardcode_into_libs=yes ;; freebsd3.[[2-9]]* | freebsdelf3.[[2-9]]* | \ freebsd4.[[0-5]] | freebsdelf4.[[0-5]] | freebsd4.1.1 | freebsdelf4.1.1) shlibpath_overrides_runpath=no hardcode_into_libs=yes ;; *) # from 4.6 on, and DragonFly shlibpath_overrides_runpath=yes hardcode_into_libs=yes ;; esac ;; haiku*) version_type=linux # correct to gnu/linux during the next big refactor need_lib_prefix=no need_version=no dynamic_linker="$host_os runtime_loader" library_names_spec='$libname$release$shared_ext$versuffix $libname$release$shared_ext$major $libname$shared_ext' soname_spec='$libname$release$shared_ext$major' shlibpath_var=LIBRARY_PATH shlibpath_overrides_runpath=no sys_lib_dlsearch_path_spec='/boot/home/config/lib /boot/common/lib /boot/system/lib' hardcode_into_libs=yes ;; hpux9* | hpux10* | hpux11*) # Give a soname corresponding to the major version so that dld.sl refuses to # link against other versions. version_type=sunos need_lib_prefix=no need_version=no case $host_cpu in ia64*) shrext_cmds='.so' hardcode_into_libs=yes dynamic_linker="$host_os dld.so" shlibpath_var=LD_LIBRARY_PATH shlibpath_overrides_runpath=yes # Unless +noenvvar is specified. library_names_spec='$libname$release$shared_ext$versuffix $libname$release$shared_ext$major $libname$shared_ext' soname_spec='$libname$release$shared_ext$major' if test 32 = "$HPUX_IA64_MODE"; then sys_lib_search_path_spec="/usr/lib/hpux32 /usr/local/lib/hpux32 /usr/local/lib" sys_lib_dlsearch_path_spec=/usr/lib/hpux32 else sys_lib_search_path_spec="/usr/lib/hpux64 /usr/local/lib/hpux64" sys_lib_dlsearch_path_spec=/usr/lib/hpux64 fi ;; hppa*64*) shrext_cmds='.sl' hardcode_into_libs=yes dynamic_linker="$host_os dld.sl" shlibpath_var=LD_LIBRARY_PATH # How should we handle SHLIB_PATH shlibpath_overrides_runpath=yes # Unless +noenvvar is specified. library_names_spec='$libname$release$shared_ext$versuffix $libname$release$shared_ext$major $libname$shared_ext' soname_spec='$libname$release$shared_ext$major' sys_lib_search_path_spec="/usr/lib/pa20_64 /usr/ccs/lib/pa20_64" sys_lib_dlsearch_path_spec=$sys_lib_search_path_spec ;; *) shrext_cmds='.sl' dynamic_linker="$host_os dld.sl" shlibpath_var=SHLIB_PATH shlibpath_overrides_runpath=no # +s is required to enable SHLIB_PATH library_names_spec='$libname$release$shared_ext$versuffix $libname$release$shared_ext$major $libname$shared_ext' soname_spec='$libname$release$shared_ext$major' ;; esac # HP-UX runs *really* slowly unless shared libraries are mode 555, ... postinstall_cmds='chmod 555 $lib' # or fails outright, so override atomically: install_override_mode=555 ;; interix[[3-9]]*) version_type=linux # correct to gnu/linux during the next big refactor need_lib_prefix=no need_version=no library_names_spec='$libname$release$shared_ext$versuffix $libname$release$shared_ext$major $libname$shared_ext' soname_spec='$libname$release$shared_ext$major' dynamic_linker='Interix 3.x ld.so.1 (PE, like ELF)' shlibpath_var=LD_LIBRARY_PATH shlibpath_overrides_runpath=no hardcode_into_libs=yes ;; irix5* | irix6* | nonstopux*) case $host_os in nonstopux*) version_type=nonstopux ;; *) if test yes = "$lt_cv_prog_gnu_ld"; then version_type=linux # correct to gnu/linux during the next big refactor else version_type=irix fi ;; esac need_lib_prefix=no need_version=no soname_spec='$libname$release$shared_ext$major' library_names_spec='$libname$release$shared_ext$versuffix $libname$release$shared_ext$major $libname$release$shared_ext $libname$shared_ext' case $host_os in irix5* | nonstopux*) libsuff= shlibsuff= ;; *) case $LD in # libtool.m4 will add one of these switches to LD *-32|*"-32 "|*-melf32bsmip|*"-melf32bsmip ") libsuff= shlibsuff= libmagic=32-bit;; *-n32|*"-n32 "|*-melf32bmipn32|*"-melf32bmipn32 ") libsuff=32 shlibsuff=N32 libmagic=N32;; *-64|*"-64 "|*-melf64bmip|*"-melf64bmip ") libsuff=64 shlibsuff=64 libmagic=64-bit;; *) libsuff= shlibsuff= libmagic=never-match;; esac ;; esac shlibpath_var=LD_LIBRARY${shlibsuff}_PATH shlibpath_overrides_runpath=no sys_lib_search_path_spec="/usr/lib$libsuff /lib$libsuff /usr/local/lib$libsuff" sys_lib_dlsearch_path_spec="/usr/lib$libsuff /lib$libsuff" hardcode_into_libs=yes ;; # No shared lib support for Linux oldld, aout, or coff. linux*oldld* | linux*aout* | linux*coff*) dynamic_linker=no ;; linux*android*) version_type=none # Android doesn't support versioned libraries. need_lib_prefix=no need_version=no library_names_spec='$libname$release$shared_ext' soname_spec='$libname$release$shared_ext' finish_cmds= shlibpath_var=LD_LIBRARY_PATH shlibpath_overrides_runpath=yes # This implies no fast_install, which is unacceptable. # Some rework will be needed to allow for fast_install # before this can be enabled. hardcode_into_libs=yes dynamic_linker='Android linker' # Don't embed -rpath directories since the linker doesn't support them. _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='-L$libdir' ;; # This must be glibc/ELF. linux* | k*bsd*-gnu | kopensolaris*-gnu | gnu*) version_type=linux # correct to gnu/linux during the next big refactor need_lib_prefix=no need_version=no library_names_spec='$libname$release$shared_ext$versuffix $libname$release$shared_ext$major $libname$shared_ext' soname_spec='$libname$release$shared_ext$major' finish_cmds='PATH="\$PATH:/sbin" ldconfig -n $libdir' shlibpath_var=LD_LIBRARY_PATH shlibpath_overrides_runpath=no # Some binutils ld are patched to set DT_RUNPATH AC_CACHE_VAL([lt_cv_shlibpath_overrides_runpath], [lt_cv_shlibpath_overrides_runpath=no save_LDFLAGS=$LDFLAGS save_libdir=$libdir eval "libdir=/foo; wl=\"$_LT_TAGVAR(lt_prog_compiler_wl, $1)\"; \ LDFLAGS=\"\$LDFLAGS $_LT_TAGVAR(hardcode_libdir_flag_spec, $1)\"" AC_LINK_IFELSE([AC_LANG_PROGRAM([],[])], [AS_IF([ ($OBJDUMP -p conftest$ac_exeext) 2>/dev/null | grep "RUNPATH.*$libdir" >/dev/null], [lt_cv_shlibpath_overrides_runpath=yes])]) LDFLAGS=$save_LDFLAGS libdir=$save_libdir ]) shlibpath_overrides_runpath=$lt_cv_shlibpath_overrides_runpath # This implies no fast_install, which is unacceptable. # Some rework will be needed to allow for fast_install # before this can be enabled. hardcode_into_libs=yes # Ideally, we could use ldconfig to report *all* directores which are # searched for libraries, however this is still not possible. Aside from not # being certain /sbin/ldconfig is available, command # 'ldconfig -N -X -v | grep ^/' on 64bit Fedora does not report /usr/lib64, # even though it is searched at run-time. Try to do the best guess by # appending ld.so.conf contents (and includes) to the search path. if test -f /etc/ld.so.conf; then lt_ld_extra=`awk '/^include / { system(sprintf("cd /etc; cat %s 2>/dev/null", \[$]2)); skip = 1; } { if (!skip) print \[$]0; skip = 0; }' < /etc/ld.so.conf | $SED -e 's/#.*//;/^[ ]*hwcap[ ]/d;s/[:, ]/ /g;s/=[^=]*$//;s/=[^= ]* / /g;s/"//g;/^$/d' | tr '\n' ' '` sys_lib_dlsearch_path_spec="/lib /usr/lib $lt_ld_extra" fi # We used to test for /lib/ld.so.1 and disable shared libraries on # powerpc, because MkLinux only supported shared libraries with the # GNU dynamic linker. Since this was broken with cross compilers, # most powerpc-linux boxes support dynamic linking these days and # people can always --disable-shared, the test was removed, and we # assume the GNU/Linux dynamic linker is in use. dynamic_linker='GNU/Linux ld.so' ;; netbsd*) version_type=sunos need_lib_prefix=no need_version=no if echo __ELF__ | $CC -E - | $GREP __ELF__ >/dev/null; then library_names_spec='$libname$release$shared_ext$versuffix $libname$shared_ext$versuffix' finish_cmds='PATH="\$PATH:/sbin" ldconfig -m $libdir' dynamic_linker='NetBSD (a.out) ld.so' else library_names_spec='$libname$release$shared_ext$versuffix $libname$release$shared_ext$major $libname$shared_ext' soname_spec='$libname$release$shared_ext$major' dynamic_linker='NetBSD ld.elf_so' fi shlibpath_var=LD_LIBRARY_PATH shlibpath_overrides_runpath=yes hardcode_into_libs=yes ;; newsos6) version_type=linux # correct to gnu/linux during the next big refactor library_names_spec='$libname$release$shared_ext$versuffix $libname$release$shared_ext$major $libname$shared_ext' shlibpath_var=LD_LIBRARY_PATH shlibpath_overrides_runpath=yes ;; *nto* | *qnx*) version_type=qnx need_lib_prefix=no need_version=no library_names_spec='$libname$release$shared_ext$versuffix $libname$release$shared_ext$major $libname$shared_ext' soname_spec='$libname$release$shared_ext$major' shlibpath_var=LD_LIBRARY_PATH shlibpath_overrides_runpath=no hardcode_into_libs=yes dynamic_linker='ldqnx.so' ;; openbsd* | bitrig*) version_type=sunos sys_lib_dlsearch_path_spec=/usr/lib need_lib_prefix=no if test -z "`echo __ELF__ | $CC -E - | $GREP __ELF__`"; then need_version=no else need_version=yes fi library_names_spec='$libname$release$shared_ext$versuffix $libname$shared_ext$versuffix' finish_cmds='PATH="\$PATH:/sbin" ldconfig -m $libdir' shlibpath_var=LD_LIBRARY_PATH shlibpath_overrides_runpath=yes ;; os2*) libname_spec='$name' version_type=windows shrext_cmds=.dll need_version=no need_lib_prefix=no # OS/2 can only load a DLL with a base name of 8 characters or less. soname_spec='`test -n "$os2dllname" && libname="$os2dllname"; v=$($ECHO $release$versuffix | tr -d .-); n=$($ECHO $libname | cut -b -$((8 - ${#v})) | tr . _); $ECHO $n$v`$shared_ext' library_names_spec='${libname}_dll.$libext' dynamic_linker='OS/2 ld.exe' shlibpath_var=BEGINLIBPATH sys_lib_search_path_spec="/lib /usr/lib /usr/local/lib" sys_lib_dlsearch_path_spec=$sys_lib_search_path_spec postinstall_cmds='base_file=`basename \$file`~ dlpath=`$SHELL 2>&1 -c '\''. $dir/'\''\$base_file'\''i; $ECHO \$dlname'\''`~ dldir=$destdir/`dirname \$dlpath`~ test -d \$dldir || mkdir -p \$dldir~ $install_prog $dir/$dlname \$dldir/$dlname~ chmod a+x \$dldir/$dlname~ if test -n '\''$stripme'\'' && test -n '\''$striplib'\''; then eval '\''$striplib \$dldir/$dlname'\'' || exit \$?; fi' postuninstall_cmds='dldll=`$SHELL 2>&1 -c '\''. $file; $ECHO \$dlname'\''`~ dlpath=$dir/\$dldll~ $RM \$dlpath' ;; osf3* | osf4* | osf5*) version_type=osf need_lib_prefix=no need_version=no soname_spec='$libname$release$shared_ext$major' library_names_spec='$libname$release$shared_ext$versuffix $libname$release$shared_ext$major $libname$shared_ext' shlibpath_var=LD_LIBRARY_PATH sys_lib_search_path_spec="/usr/shlib /usr/ccs/lib /usr/lib/cmplrs/cc /usr/lib /usr/local/lib /var/shlib" sys_lib_dlsearch_path_spec=$sys_lib_search_path_spec ;; rdos*) dynamic_linker=no ;; solaris*) version_type=linux # correct to gnu/linux during the next big refactor need_lib_prefix=no need_version=no library_names_spec='$libname$release$shared_ext$versuffix $libname$release$shared_ext$major $libname$shared_ext' soname_spec='$libname$release$shared_ext$major' shlibpath_var=LD_LIBRARY_PATH shlibpath_overrides_runpath=yes hardcode_into_libs=yes # ldd complains unless libraries are executable postinstall_cmds='chmod +x $lib' ;; sunos4*) version_type=sunos library_names_spec='$libname$release$shared_ext$versuffix $libname$shared_ext$versuffix' finish_cmds='PATH="\$PATH:/usr/etc" ldconfig $libdir' shlibpath_var=LD_LIBRARY_PATH shlibpath_overrides_runpath=yes if test yes = "$with_gnu_ld"; then need_lib_prefix=no fi need_version=yes ;; sysv4 | sysv4.3*) version_type=linux # correct to gnu/linux during the next big refactor library_names_spec='$libname$release$shared_ext$versuffix $libname$release$shared_ext$major $libname$shared_ext' soname_spec='$libname$release$shared_ext$major' shlibpath_var=LD_LIBRARY_PATH case $host_vendor in sni) shlibpath_overrides_runpath=no need_lib_prefix=no runpath_var=LD_RUN_PATH ;; siemens) need_lib_prefix=no ;; motorola) need_lib_prefix=no need_version=no shlibpath_overrides_runpath=no sys_lib_search_path_spec='/lib /usr/lib /usr/ccs/lib' ;; esac ;; sysv4*MP*) if test -d /usr/nec; then version_type=linux # correct to gnu/linux during the next big refactor library_names_spec='$libname$shared_ext.$versuffix $libname$shared_ext.$major $libname$shared_ext' soname_spec='$libname$shared_ext.$major' shlibpath_var=LD_LIBRARY_PATH fi ;; sysv5* | sco3.2v5* | sco5v6* | unixware* | OpenUNIX* | sysv4*uw2*) version_type=sco need_lib_prefix=no need_version=no library_names_spec='$libname$release$shared_ext$versuffix $libname$release$shared_ext $libname$shared_ext' soname_spec='$libname$release$shared_ext$major' shlibpath_var=LD_LIBRARY_PATH shlibpath_overrides_runpath=yes hardcode_into_libs=yes if test yes = "$with_gnu_ld"; then sys_lib_search_path_spec='/usr/local/lib /usr/gnu/lib /usr/ccs/lib /usr/lib /lib' else sys_lib_search_path_spec='/usr/ccs/lib /usr/lib' case $host_os in sco3.2v5*) sys_lib_search_path_spec="$sys_lib_search_path_spec /lib" ;; esac fi sys_lib_dlsearch_path_spec='/usr/lib' ;; tpf*) # TPF is a cross-target only. Preferred cross-host = GNU/Linux. version_type=linux # correct to gnu/linux during the next big refactor need_lib_prefix=no need_version=no library_names_spec='$libname$release$shared_ext$versuffix $libname$release$shared_ext$major $libname$shared_ext' shlibpath_var=LD_LIBRARY_PATH shlibpath_overrides_runpath=no hardcode_into_libs=yes ;; uts4*) version_type=linux # correct to gnu/linux during the next big refactor library_names_spec='$libname$release$shared_ext$versuffix $libname$release$shared_ext$major $libname$shared_ext' soname_spec='$libname$release$shared_ext$major' shlibpath_var=LD_LIBRARY_PATH ;; *) dynamic_linker=no ;; esac AC_MSG_RESULT([$dynamic_linker]) test no = "$dynamic_linker" && can_build_shared=no variables_saved_for_relink="PATH $shlibpath_var $runpath_var" if test yes = "$GCC"; then variables_saved_for_relink="$variables_saved_for_relink GCC_EXEC_PREFIX COMPILER_PATH LIBRARY_PATH" fi if test set = "${lt_cv_sys_lib_search_path_spec+set}"; then sys_lib_search_path_spec=$lt_cv_sys_lib_search_path_spec fi if test set = "${lt_cv_sys_lib_dlsearch_path_spec+set}"; then sys_lib_dlsearch_path_spec=$lt_cv_sys_lib_dlsearch_path_spec fi # remember unaugmented sys_lib_dlsearch_path content for libtool script decls... configure_time_dlsearch_path=$sys_lib_dlsearch_path_spec # ... but it needs LT_SYS_LIBRARY_PATH munging for other configure-time code func_munge_path_list sys_lib_dlsearch_path_spec "$LT_SYS_LIBRARY_PATH" # to be used as default LT_SYS_LIBRARY_PATH value in generated libtool configure_time_lt_sys_library_path=$LT_SYS_LIBRARY_PATH _LT_DECL([], [variables_saved_for_relink], [1], [Variables whose values should be saved in libtool wrapper scripts and restored at link time]) _LT_DECL([], [need_lib_prefix], [0], [Do we need the "lib" prefix for modules?]) _LT_DECL([], [need_version], [0], [Do we need a version for libraries?]) _LT_DECL([], [version_type], [0], [Library versioning type]) _LT_DECL([], [runpath_var], [0], [Shared library runtime path variable]) _LT_DECL([], [shlibpath_var], [0],[Shared library path variable]) _LT_DECL([], [shlibpath_overrides_runpath], [0], [Is shlibpath searched before the hard-coded library search path?]) _LT_DECL([], [libname_spec], [1], [Format of library name prefix]) _LT_DECL([], [library_names_spec], [1], [[List of archive names. First name is the real one, the rest are links. The last name is the one that the linker finds with -lNAME]]) _LT_DECL([], [soname_spec], [1], [[The coded name of the library, if different from the real name]]) _LT_DECL([], [install_override_mode], [1], [Permission mode override for installation of shared libraries]) _LT_DECL([], [postinstall_cmds], [2], [Command to use after installation of a shared archive]) _LT_DECL([], [postuninstall_cmds], [2], [Command to use after uninstallation of a shared archive]) _LT_DECL([], [finish_cmds], [2], [Commands used to finish a libtool library installation in a directory]) _LT_DECL([], [finish_eval], [1], [[As "finish_cmds", except a single script fragment to be evaled but not shown]]) _LT_DECL([], [hardcode_into_libs], [0], [Whether we should hardcode library paths into libraries]) _LT_DECL([], [sys_lib_search_path_spec], [2], [Compile-time system search path for libraries]) _LT_DECL([sys_lib_dlsearch_path_spec], [configure_time_dlsearch_path], [2], [Detected run-time system search path for libraries]) _LT_DECL([], [configure_time_lt_sys_library_path], [2], [Explicit LT_SYS_LIBRARY_PATH set during ./configure time]) ])# _LT_SYS_DYNAMIC_LINKER # _LT_PATH_TOOL_PREFIX(TOOL) # -------------------------- # find a file program that can recognize shared library AC_DEFUN([_LT_PATH_TOOL_PREFIX], [m4_require([_LT_DECL_EGREP])dnl AC_MSG_CHECKING([for $1]) AC_CACHE_VAL(lt_cv_path_MAGIC_CMD, [case $MAGIC_CMD in [[\\/*] | ?:[\\/]*]) lt_cv_path_MAGIC_CMD=$MAGIC_CMD # Let the user override the test with a path. ;; *) lt_save_MAGIC_CMD=$MAGIC_CMD lt_save_ifs=$IFS; IFS=$PATH_SEPARATOR dnl $ac_dummy forces splitting on constant user-supplied paths. dnl POSIX.2 word splitting is done only on the output of word expansions, dnl not every word. This closes a longstanding sh security hole. ac_dummy="m4_if([$2], , $PATH, [$2])" for ac_dir in $ac_dummy; do IFS=$lt_save_ifs test -z "$ac_dir" && ac_dir=. if test -f "$ac_dir/$1"; then lt_cv_path_MAGIC_CMD=$ac_dir/"$1" if test -n "$file_magic_test_file"; then case $deplibs_check_method in "file_magic "*) file_magic_regex=`expr "$deplibs_check_method" : "file_magic \(.*\)"` MAGIC_CMD=$lt_cv_path_MAGIC_CMD if eval $file_magic_cmd \$file_magic_test_file 2> /dev/null | $EGREP "$file_magic_regex" > /dev/null; then : else cat <<_LT_EOF 1>&2 *** Warning: the command libtool uses to detect shared libraries, *** $file_magic_cmd, produces output that libtool cannot recognize. *** The result is that libtool may fail to recognize shared libraries *** as such. This will affect the creation of libtool libraries that *** depend on shared libraries, but programs linked with such libtool *** libraries will work regardless of this problem. Nevertheless, you *** may want to report the problem to your system manager and/or to *** bug-libtool@gnu.org _LT_EOF fi ;; esac fi break fi done IFS=$lt_save_ifs MAGIC_CMD=$lt_save_MAGIC_CMD ;; esac]) MAGIC_CMD=$lt_cv_path_MAGIC_CMD if test -n "$MAGIC_CMD"; then AC_MSG_RESULT($MAGIC_CMD) else AC_MSG_RESULT(no) fi _LT_DECL([], [MAGIC_CMD], [0], [Used to examine libraries when file_magic_cmd begins with "file"])dnl ])# _LT_PATH_TOOL_PREFIX # Old name: AU_ALIAS([AC_PATH_TOOL_PREFIX], [_LT_PATH_TOOL_PREFIX]) dnl aclocal-1.4 backwards compatibility: dnl AC_DEFUN([AC_PATH_TOOL_PREFIX], []) # _LT_PATH_MAGIC # -------------- # find a file program that can recognize a shared library m4_defun([_LT_PATH_MAGIC], [_LT_PATH_TOOL_PREFIX(${ac_tool_prefix}file, /usr/bin$PATH_SEPARATOR$PATH) if test -z "$lt_cv_path_MAGIC_CMD"; then if test -n "$ac_tool_prefix"; then _LT_PATH_TOOL_PREFIX(file, /usr/bin$PATH_SEPARATOR$PATH) else MAGIC_CMD=: fi fi ])# _LT_PATH_MAGIC # LT_PATH_LD # ---------- # find the pathname to the GNU or non-GNU linker AC_DEFUN([LT_PATH_LD], [AC_REQUIRE([AC_PROG_CC])dnl AC_REQUIRE([AC_CANONICAL_HOST])dnl AC_REQUIRE([AC_CANONICAL_BUILD])dnl m4_require([_LT_DECL_SED])dnl m4_require([_LT_DECL_EGREP])dnl m4_require([_LT_PROG_ECHO_BACKSLASH])dnl AC_ARG_WITH([gnu-ld], [AS_HELP_STRING([--with-gnu-ld], [assume the C compiler uses GNU ld @<:@default=no@:>@])], [test no = "$withval" || with_gnu_ld=yes], [with_gnu_ld=no])dnl ac_prog=ld if test yes = "$GCC"; then # Check if gcc -print-prog-name=ld gives a path. AC_MSG_CHECKING([for ld used by $CC]) case $host in *-*-mingw*) # gcc leaves a trailing carriage return, which upsets mingw ac_prog=`($CC -print-prog-name=ld) 2>&5 | tr -d '\015'` ;; *) ac_prog=`($CC -print-prog-name=ld) 2>&5` ;; esac case $ac_prog in # Accept absolute paths. [[\\/]]* | ?:[[\\/]]*) re_direlt='/[[^/]][[^/]]*/\.\./' # Canonicalize the pathname of ld ac_prog=`$ECHO "$ac_prog"| $SED 's%\\\\%/%g'` while $ECHO "$ac_prog" | $GREP "$re_direlt" > /dev/null 2>&1; do ac_prog=`$ECHO $ac_prog| $SED "s%$re_direlt%/%"` done test -z "$LD" && LD=$ac_prog ;; "") # If it fails, then pretend we aren't using GCC. ac_prog=ld ;; *) # If it is relative, then search for the first ld in PATH. with_gnu_ld=unknown ;; esac elif test yes = "$with_gnu_ld"; then AC_MSG_CHECKING([for GNU ld]) else AC_MSG_CHECKING([for non-GNU ld]) fi AC_CACHE_VAL(lt_cv_path_LD, [if test -z "$LD"; then lt_save_ifs=$IFS; IFS=$PATH_SEPARATOR for ac_dir in $PATH; do IFS=$lt_save_ifs test -z "$ac_dir" && ac_dir=. if test -f "$ac_dir/$ac_prog" || test -f "$ac_dir/$ac_prog$ac_exeext"; then lt_cv_path_LD=$ac_dir/$ac_prog # Check to see if the program is GNU ld. I'd rather use --version, # but apparently some variants of GNU ld only accept -v. # Break only if it was the GNU/non-GNU ld that we prefer. case `"$lt_cv_path_LD" -v 2>&1 &1 conftest.i cat conftest.i conftest.i >conftest2.i : ${lt_DD:=$DD} AC_PATH_PROGS_FEATURE_CHECK([lt_DD], [dd], [if "$ac_path_lt_DD" bs=32 count=1 conftest.out 2>/dev/null; then cmp -s conftest.i conftest.out \ && ac_cv_path_lt_DD="$ac_path_lt_DD" ac_path_lt_DD_found=: fi]) rm -f conftest.i conftest2.i conftest.out]) ])# _LT_PATH_DD # _LT_CMD_TRUNCATE # ---------------- # find command to truncate a binary pipe m4_defun([_LT_CMD_TRUNCATE], [m4_require([_LT_PATH_DD]) AC_CACHE_CHECK([how to truncate binary pipes], [lt_cv_truncate_bin], [printf 0123456789abcdef0123456789abcdef >conftest.i cat conftest.i conftest.i >conftest2.i lt_cv_truncate_bin= if "$ac_cv_path_lt_DD" bs=32 count=1 conftest.out 2>/dev/null; then cmp -s conftest.i conftest.out \ && lt_cv_truncate_bin="$ac_cv_path_lt_DD bs=4096 count=1" fi rm -f conftest.i conftest2.i conftest.out test -z "$lt_cv_truncate_bin" && lt_cv_truncate_bin="$SED -e 4q"]) _LT_DECL([lt_truncate_bin], [lt_cv_truncate_bin], [1], [Command to truncate a binary pipe]) ])# _LT_CMD_TRUNCATE # _LT_CHECK_MAGIC_METHOD # ---------------------- # how to check for library dependencies # -- PORTME fill in with the dynamic library characteristics m4_defun([_LT_CHECK_MAGIC_METHOD], [m4_require([_LT_DECL_EGREP]) m4_require([_LT_DECL_OBJDUMP]) AC_CACHE_CHECK([how to recognize dependent libraries], lt_cv_deplibs_check_method, [lt_cv_file_magic_cmd='$MAGIC_CMD' lt_cv_file_magic_test_file= lt_cv_deplibs_check_method='unknown' # Need to set the preceding variable on all platforms that support # interlibrary dependencies. # 'none' -- dependencies not supported. # 'unknown' -- same as none, but documents that we really don't know. # 'pass_all' -- all dependencies passed with no checks. # 'test_compile' -- check by making test program. # 'file_magic [[regex]]' -- check by looking for files in library path # that responds to the $file_magic_cmd with a given extended regex. # If you have 'file' or equivalent on your system and you're not sure # whether 'pass_all' will *always* work, you probably want this one. case $host_os in aix[[4-9]]*) lt_cv_deplibs_check_method=pass_all ;; beos*) lt_cv_deplibs_check_method=pass_all ;; bsdi[[45]]*) lt_cv_deplibs_check_method='file_magic ELF [[0-9]][[0-9]]*-bit [[ML]]SB (shared object|dynamic lib)' lt_cv_file_magic_cmd='/usr/bin/file -L' lt_cv_file_magic_test_file=/shlib/libc.so ;; cygwin*) # func_win32_libid is a shell function defined in ltmain.sh lt_cv_deplibs_check_method='file_magic ^x86 archive import|^x86 DLL' lt_cv_file_magic_cmd='func_win32_libid' ;; mingw* | pw32*) # Base MSYS/MinGW do not provide the 'file' command needed by # func_win32_libid shell function, so use a weaker test based on 'objdump', # unless we find 'file', for example because we are cross-compiling. if ( file / ) >/dev/null 2>&1; then lt_cv_deplibs_check_method='file_magic ^x86 archive import|^x86 DLL' lt_cv_file_magic_cmd='func_win32_libid' else # Keep this pattern in sync with the one in func_win32_libid. lt_cv_deplibs_check_method='file_magic file format (pei*-i386(.*architecture: i386)?|pe-arm-wince|pe-x86-64)' lt_cv_file_magic_cmd='$OBJDUMP -f' fi ;; cegcc*) # use the weaker test based on 'objdump'. See mingw*. lt_cv_deplibs_check_method='file_magic file format pe-arm-.*little(.*architecture: arm)?' lt_cv_file_magic_cmd='$OBJDUMP -f' ;; darwin* | rhapsody*) lt_cv_deplibs_check_method=pass_all ;; freebsd* | dragonfly*) if echo __ELF__ | $CC -E - | $GREP __ELF__ > /dev/null; then case $host_cpu in i*86 ) # Not sure whether the presence of OpenBSD here was a mistake. # Let's accept both of them until this is cleared up. lt_cv_deplibs_check_method='file_magic (FreeBSD|OpenBSD|DragonFly)/i[[3-9]]86 (compact )?demand paged shared library' lt_cv_file_magic_cmd=/usr/bin/file lt_cv_file_magic_test_file=`echo /usr/lib/libc.so.*` ;; esac else lt_cv_deplibs_check_method=pass_all fi ;; haiku*) lt_cv_deplibs_check_method=pass_all ;; hpux10.20* | hpux11*) lt_cv_file_magic_cmd=/usr/bin/file case $host_cpu in ia64*) lt_cv_deplibs_check_method='file_magic (s[[0-9]][[0-9]][[0-9]]|ELF-[[0-9]][[0-9]]) shared object file - IA64' lt_cv_file_magic_test_file=/usr/lib/hpux32/libc.so ;; hppa*64*) [lt_cv_deplibs_check_method='file_magic (s[0-9][0-9][0-9]|ELF[ -][0-9][0-9])(-bit)?( [LM]SB)? shared object( file)?[, -]* PA-RISC [0-9]\.[0-9]'] lt_cv_file_magic_test_file=/usr/lib/pa20_64/libc.sl ;; *) lt_cv_deplibs_check_method='file_magic (s[[0-9]][[0-9]][[0-9]]|PA-RISC[[0-9]]\.[[0-9]]) shared library' lt_cv_file_magic_test_file=/usr/lib/libc.sl ;; esac ;; interix[[3-9]]*) # PIC code is broken on Interix 3.x, that's why |\.a not |_pic\.a here lt_cv_deplibs_check_method='match_pattern /lib[[^/]]+(\.so|\.a)$' ;; irix5* | irix6* | nonstopux*) case $LD in *-32|*"-32 ") libmagic=32-bit;; *-n32|*"-n32 ") libmagic=N32;; *-64|*"-64 ") libmagic=64-bit;; *) libmagic=never-match;; esac lt_cv_deplibs_check_method=pass_all ;; # This must be glibc/ELF. linux* | k*bsd*-gnu | kopensolaris*-gnu | gnu*) lt_cv_deplibs_check_method=pass_all ;; netbsd*) if echo __ELF__ | $CC -E - | $GREP __ELF__ > /dev/null; then lt_cv_deplibs_check_method='match_pattern /lib[[^/]]+(\.so\.[[0-9]]+\.[[0-9]]+|_pic\.a)$' else lt_cv_deplibs_check_method='match_pattern /lib[[^/]]+(\.so|_pic\.a)$' fi ;; newos6*) lt_cv_deplibs_check_method='file_magic ELF [[0-9]][[0-9]]*-bit [[ML]]SB (executable|dynamic lib)' lt_cv_file_magic_cmd=/usr/bin/file lt_cv_file_magic_test_file=/usr/lib/libnls.so ;; *nto* | *qnx*) lt_cv_deplibs_check_method=pass_all ;; openbsd* | bitrig*) if test -z "`echo __ELF__ | $CC -E - | $GREP __ELF__`"; then lt_cv_deplibs_check_method='match_pattern /lib[[^/]]+(\.so\.[[0-9]]+\.[[0-9]]+|\.so|_pic\.a)$' else lt_cv_deplibs_check_method='match_pattern /lib[[^/]]+(\.so\.[[0-9]]+\.[[0-9]]+|_pic\.a)$' fi ;; osf3* | osf4* | osf5*) lt_cv_deplibs_check_method=pass_all ;; rdos*) lt_cv_deplibs_check_method=pass_all ;; solaris*) lt_cv_deplibs_check_method=pass_all ;; sysv5* | sco3.2v5* | sco5v6* | unixware* | OpenUNIX* | sysv4*uw2*) lt_cv_deplibs_check_method=pass_all ;; sysv4 | sysv4.3*) case $host_vendor in motorola) lt_cv_deplibs_check_method='file_magic ELF [[0-9]][[0-9]]*-bit [[ML]]SB (shared object|dynamic lib) M[[0-9]][[0-9]]* Version [[0-9]]' lt_cv_file_magic_test_file=`echo /usr/lib/libc.so*` ;; ncr) lt_cv_deplibs_check_method=pass_all ;; sequent) lt_cv_file_magic_cmd='/bin/file' lt_cv_deplibs_check_method='file_magic ELF [[0-9]][[0-9]]*-bit [[LM]]SB (shared object|dynamic lib )' ;; sni) lt_cv_file_magic_cmd='/bin/file' lt_cv_deplibs_check_method="file_magic ELF [[0-9]][[0-9]]*-bit [[LM]]SB dynamic lib" lt_cv_file_magic_test_file=/lib/libc.so ;; siemens) lt_cv_deplibs_check_method=pass_all ;; pc) lt_cv_deplibs_check_method=pass_all ;; esac ;; tpf*) lt_cv_deplibs_check_method=pass_all ;; os2*) lt_cv_deplibs_check_method=pass_all ;; esac ]) file_magic_glob= want_nocaseglob=no if test "$build" = "$host"; then case $host_os in mingw* | pw32*) if ( shopt | grep nocaseglob ) >/dev/null 2>&1; then want_nocaseglob=yes else file_magic_glob=`echo aAbBcCdDeEfFgGhHiIjJkKlLmMnNoOpPqQrRsStTuUvVwWxXyYzZ | $SED -e "s/\(..\)/s\/[[\1]]\/[[\1]]\/g;/g"` fi ;; esac fi file_magic_cmd=$lt_cv_file_magic_cmd deplibs_check_method=$lt_cv_deplibs_check_method test -z "$deplibs_check_method" && deplibs_check_method=unknown _LT_DECL([], [deplibs_check_method], [1], [Method to check whether dependent libraries are shared objects]) _LT_DECL([], [file_magic_cmd], [1], [Command to use when deplibs_check_method = "file_magic"]) _LT_DECL([], [file_magic_glob], [1], [How to find potential files when deplibs_check_method = "file_magic"]) _LT_DECL([], [want_nocaseglob], [1], [Find potential files using nocaseglob when deplibs_check_method = "file_magic"]) ])# _LT_CHECK_MAGIC_METHOD # LT_PATH_NM # ---------- # find the pathname to a BSD- or MS-compatible name lister AC_DEFUN([LT_PATH_NM], [AC_REQUIRE([AC_PROG_CC])dnl AC_CACHE_CHECK([for BSD- or MS-compatible name lister (nm)], lt_cv_path_NM, [if test -n "$NM"; then # Let the user override the test. lt_cv_path_NM=$NM else lt_nm_to_check=${ac_tool_prefix}nm if test -n "$ac_tool_prefix" && test "$build" = "$host"; then lt_nm_to_check="$lt_nm_to_check nm" fi for lt_tmp_nm in $lt_nm_to_check; do lt_save_ifs=$IFS; IFS=$PATH_SEPARATOR for ac_dir in $PATH /usr/ccs/bin/elf /usr/ccs/bin /usr/ucb /bin; do IFS=$lt_save_ifs test -z "$ac_dir" && ac_dir=. tmp_nm=$ac_dir/$lt_tmp_nm if test -f "$tmp_nm" || test -f "$tmp_nm$ac_exeext"; then # Check to see if the nm accepts a BSD-compat flag. # Adding the 'sed 1q' prevents false positives on HP-UX, which says: # nm: unknown option "B" ignored # Tru64's nm complains that /dev/null is an invalid object file # MSYS converts /dev/null to NUL, MinGW nm treats NUL as empty case $build_os in mingw*) lt_bad_file=conftest.nm/nofile ;; *) lt_bad_file=/dev/null ;; esac case `"$tmp_nm" -B $lt_bad_file 2>&1 | sed '1q'` in *$lt_bad_file* | *'Invalid file or object type'*) lt_cv_path_NM="$tmp_nm -B" break 2 ;; *) case `"$tmp_nm" -p /dev/null 2>&1 | sed '1q'` in */dev/null*) lt_cv_path_NM="$tmp_nm -p" break 2 ;; *) lt_cv_path_NM=${lt_cv_path_NM="$tmp_nm"} # keep the first match, but continue # so that we can try to find one that supports BSD flags ;; esac ;; esac fi done IFS=$lt_save_ifs done : ${lt_cv_path_NM=no} fi]) if test no != "$lt_cv_path_NM"; then NM=$lt_cv_path_NM else # Didn't find any BSD compatible name lister, look for dumpbin. if test -n "$DUMPBIN"; then : # Let the user override the test. else AC_CHECK_TOOLS(DUMPBIN, [dumpbin "link -dump"], :) case `$DUMPBIN -symbols -headers /dev/null 2>&1 | sed '1q'` in *COFF*) DUMPBIN="$DUMPBIN -symbols -headers" ;; *) DUMPBIN=: ;; esac fi AC_SUBST([DUMPBIN]) if test : != "$DUMPBIN"; then NM=$DUMPBIN fi fi test -z "$NM" && NM=nm AC_SUBST([NM]) _LT_DECL([], [NM], [1], [A BSD- or MS-compatible name lister])dnl AC_CACHE_CHECK([the name lister ($NM) interface], [lt_cv_nm_interface], [lt_cv_nm_interface="BSD nm" echo "int some_variable = 0;" > conftest.$ac_ext (eval echo "\"\$as_me:$LINENO: $ac_compile\"" >&AS_MESSAGE_LOG_FD) (eval "$ac_compile" 2>conftest.err) cat conftest.err >&AS_MESSAGE_LOG_FD (eval echo "\"\$as_me:$LINENO: $NM \\\"conftest.$ac_objext\\\"\"" >&AS_MESSAGE_LOG_FD) (eval "$NM \"conftest.$ac_objext\"" 2>conftest.err > conftest.out) cat conftest.err >&AS_MESSAGE_LOG_FD (eval echo "\"\$as_me:$LINENO: output\"" >&AS_MESSAGE_LOG_FD) cat conftest.out >&AS_MESSAGE_LOG_FD if $GREP 'External.*some_variable' conftest.out > /dev/null; then lt_cv_nm_interface="MS dumpbin" fi rm -f conftest*]) ])# LT_PATH_NM # Old names: AU_ALIAS([AM_PROG_NM], [LT_PATH_NM]) AU_ALIAS([AC_PROG_NM], [LT_PATH_NM]) dnl aclocal-1.4 backwards compatibility: dnl AC_DEFUN([AM_PROG_NM], []) dnl AC_DEFUN([AC_PROG_NM], []) # _LT_CHECK_SHAREDLIB_FROM_LINKLIB # -------------------------------- # how to determine the name of the shared library # associated with a specific link library. # -- PORTME fill in with the dynamic library characteristics m4_defun([_LT_CHECK_SHAREDLIB_FROM_LINKLIB], [m4_require([_LT_DECL_EGREP]) m4_require([_LT_DECL_OBJDUMP]) m4_require([_LT_DECL_DLLTOOL]) AC_CACHE_CHECK([how to associate runtime and link libraries], lt_cv_sharedlib_from_linklib_cmd, [lt_cv_sharedlib_from_linklib_cmd='unknown' case $host_os in cygwin* | mingw* | pw32* | cegcc*) # two different shell functions defined in ltmain.sh; # decide which one to use based on capabilities of $DLLTOOL case `$DLLTOOL --help 2>&1` in *--identify-strict*) lt_cv_sharedlib_from_linklib_cmd=func_cygming_dll_for_implib ;; *) lt_cv_sharedlib_from_linklib_cmd=func_cygming_dll_for_implib_fallback ;; esac ;; *) # fallback: assume linklib IS sharedlib lt_cv_sharedlib_from_linklib_cmd=$ECHO ;; esac ]) sharedlib_from_linklib_cmd=$lt_cv_sharedlib_from_linklib_cmd test -z "$sharedlib_from_linklib_cmd" && sharedlib_from_linklib_cmd=$ECHO _LT_DECL([], [sharedlib_from_linklib_cmd], [1], [Command to associate shared and link libraries]) ])# _LT_CHECK_SHAREDLIB_FROM_LINKLIB # _LT_PATH_MANIFEST_TOOL # ---------------------- # locate the manifest tool m4_defun([_LT_PATH_MANIFEST_TOOL], [AC_CHECK_TOOL(MANIFEST_TOOL, mt, :) test -z "$MANIFEST_TOOL" && MANIFEST_TOOL=mt AC_CACHE_CHECK([if $MANIFEST_TOOL is a manifest tool], [lt_cv_path_mainfest_tool], [lt_cv_path_mainfest_tool=no echo "$as_me:$LINENO: $MANIFEST_TOOL '-?'" >&AS_MESSAGE_LOG_FD $MANIFEST_TOOL '-?' 2>conftest.err > conftest.out cat conftest.err >&AS_MESSAGE_LOG_FD if $GREP 'Manifest Tool' conftest.out > /dev/null; then lt_cv_path_mainfest_tool=yes fi rm -f conftest*]) if test yes != "$lt_cv_path_mainfest_tool"; then MANIFEST_TOOL=: fi _LT_DECL([], [MANIFEST_TOOL], [1], [Manifest tool])dnl ])# _LT_PATH_MANIFEST_TOOL # _LT_DLL_DEF_P([FILE]) # --------------------- # True iff FILE is a Windows DLL '.def' file. # Keep in sync with func_dll_def_p in the libtool script AC_DEFUN([_LT_DLL_DEF_P], [dnl test DEF = "`$SED -n dnl -e '\''s/^[[ ]]*//'\'' dnl Strip leading whitespace -e '\''/^\(;.*\)*$/d'\'' dnl Delete empty lines and comments -e '\''s/^\(EXPORTS\|LIBRARY\)\([[ ]].*\)*$/DEF/p'\'' dnl -e q dnl Only consider the first "real" line $1`" dnl ])# _LT_DLL_DEF_P # LT_LIB_M # -------- # check for math library AC_DEFUN([LT_LIB_M], [AC_REQUIRE([AC_CANONICAL_HOST])dnl LIBM= case $host in *-*-beos* | *-*-cegcc* | *-*-cygwin* | *-*-haiku* | *-*-pw32* | *-*-darwin*) # These system don't have libm, or don't need it ;; *-ncr-sysv4.3*) AC_CHECK_LIB(mw, _mwvalidcheckl, LIBM=-lmw) AC_CHECK_LIB(m, cos, LIBM="$LIBM -lm") ;; *) AC_CHECK_LIB(m, cos, LIBM=-lm) ;; esac AC_SUBST([LIBM]) ])# LT_LIB_M # Old name: AU_ALIAS([AC_CHECK_LIBM], [LT_LIB_M]) dnl aclocal-1.4 backwards compatibility: dnl AC_DEFUN([AC_CHECK_LIBM], []) # _LT_COMPILER_NO_RTTI([TAGNAME]) # ------------------------------- m4_defun([_LT_COMPILER_NO_RTTI], [m4_require([_LT_TAG_COMPILER])dnl _LT_TAGVAR(lt_prog_compiler_no_builtin_flag, $1)= if test yes = "$GCC"; then case $cc_basename in nvcc*) _LT_TAGVAR(lt_prog_compiler_no_builtin_flag, $1)=' -Xcompiler -fno-builtin' ;; *) _LT_TAGVAR(lt_prog_compiler_no_builtin_flag, $1)=' -fno-builtin' ;; esac _LT_COMPILER_OPTION([if $compiler supports -fno-rtti -fno-exceptions], lt_cv_prog_compiler_rtti_exceptions, [-fno-rtti -fno-exceptions], [], [_LT_TAGVAR(lt_prog_compiler_no_builtin_flag, $1)="$_LT_TAGVAR(lt_prog_compiler_no_builtin_flag, $1) -fno-rtti -fno-exceptions"]) fi _LT_TAGDECL([no_builtin_flag], [lt_prog_compiler_no_builtin_flag], [1], [Compiler flag to turn off builtin functions]) ])# _LT_COMPILER_NO_RTTI # _LT_CMD_GLOBAL_SYMBOLS # ---------------------- m4_defun([_LT_CMD_GLOBAL_SYMBOLS], [AC_REQUIRE([AC_CANONICAL_HOST])dnl AC_REQUIRE([AC_PROG_CC])dnl AC_REQUIRE([AC_PROG_AWK])dnl AC_REQUIRE([LT_PATH_NM])dnl AC_REQUIRE([LT_PATH_LD])dnl m4_require([_LT_DECL_SED])dnl m4_require([_LT_DECL_EGREP])dnl m4_require([_LT_TAG_COMPILER])dnl # Check for command to grab the raw symbol name followed by C symbol from nm. AC_MSG_CHECKING([command to parse $NM output from $compiler object]) AC_CACHE_VAL([lt_cv_sys_global_symbol_pipe], [ # These are sane defaults that work on at least a few old systems. # [They come from Ultrix. What could be older than Ultrix?!! ;)] # Character class describing NM global symbol codes. symcode='[[BCDEGRST]]' # Regexp to match symbols that can be accessed directly from C. sympat='\([[_A-Za-z]][[_A-Za-z0-9]]*\)' # Define system-specific variables. case $host_os in aix*) symcode='[[BCDT]]' ;; cygwin* | mingw* | pw32* | cegcc*) symcode='[[ABCDGISTW]]' ;; hpux*) if test ia64 = "$host_cpu"; then symcode='[[ABCDEGRST]]' fi ;; irix* | nonstopux*) symcode='[[BCDEGRST]]' ;; osf*) symcode='[[BCDEGQRST]]' ;; solaris*) symcode='[[BDRT]]' ;; sco3.2v5*) symcode='[[DT]]' ;; sysv4.2uw2*) symcode='[[DT]]' ;; sysv5* | sco5v6* | unixware* | OpenUNIX*) symcode='[[ABDT]]' ;; sysv4) symcode='[[DFNSTU]]' ;; esac # If we're using GNU nm, then use its standard symbol codes. case `$NM -V 2>&1` in *GNU* | *'with BFD'*) symcode='[[ABCDGIRSTW]]' ;; esac if test "$lt_cv_nm_interface" = "MS dumpbin"; then # Gets list of data symbols to import. lt_cv_sys_global_symbol_to_import="sed -n -e 's/^I .* \(.*\)$/\1/p'" # Adjust the below global symbol transforms to fixup imported variables. lt_cdecl_hook=" -e 's/^I .* \(.*\)$/extern __declspec(dllimport) char \1;/p'" lt_c_name_hook=" -e 's/^I .* \(.*\)$/ {\"\1\", (void *) 0},/p'" lt_c_name_lib_hook="\ -e 's/^I .* \(lib.*\)$/ {\"\1\", (void *) 0},/p'\ -e 's/^I .* \(.*\)$/ {\"lib\1\", (void *) 0},/p'" else # Disable hooks by default. lt_cv_sys_global_symbol_to_import= lt_cdecl_hook= lt_c_name_hook= lt_c_name_lib_hook= fi # Transform an extracted symbol line into a proper C declaration. # Some systems (esp. on ia64) link data and code symbols differently, # so use this general approach. lt_cv_sys_global_symbol_to_cdecl="sed -n"\ $lt_cdecl_hook\ " -e 's/^T .* \(.*\)$/extern int \1();/p'"\ " -e 's/^$symcode$symcode* .* \(.*\)$/extern char \1;/p'" # Transform an extracted symbol line into symbol name and symbol address lt_cv_sys_global_symbol_to_c_name_address="sed -n"\ $lt_c_name_hook\ " -e 's/^: \(.*\) .*$/ {\"\1\", (void *) 0},/p'"\ " -e 's/^$symcode$symcode* .* \(.*\)$/ {\"\1\", (void *) \&\1},/p'" # Transform an extracted symbol line into symbol name with lib prefix and # symbol address. lt_cv_sys_global_symbol_to_c_name_address_lib_prefix="sed -n"\ $lt_c_name_lib_hook\ " -e 's/^: \(.*\) .*$/ {\"\1\", (void *) 0},/p'"\ " -e 's/^$symcode$symcode* .* \(lib.*\)$/ {\"\1\", (void *) \&\1},/p'"\ " -e 's/^$symcode$symcode* .* \(.*\)$/ {\"lib\1\", (void *) \&\1},/p'" # Handle CRLF in mingw tool chain opt_cr= case $build_os in mingw*) opt_cr=`$ECHO 'x\{0,1\}' | tr x '\015'` # option cr in regexp ;; esac # Try without a prefix underscore, then with it. for ac_symprfx in "" "_"; do # Transform symcode, sympat, and symprfx into a raw symbol and a C symbol. symxfrm="\\1 $ac_symprfx\\2 \\2" # Write the raw and C identifiers. if test "$lt_cv_nm_interface" = "MS dumpbin"; then # Fake it for dumpbin and say T for any non-static function, # D for any global variable and I for any imported variable. # Also find C++ and __fastcall symbols from MSVC++, # which start with @ or ?. lt_cv_sys_global_symbol_pipe="$AWK ['"\ " {last_section=section; section=\$ 3};"\ " /^COFF SYMBOL TABLE/{for(i in hide) delete hide[i]};"\ " /Section length .*#relocs.*(pick any)/{hide[last_section]=1};"\ " /^ *Symbol name *: /{split(\$ 0,sn,\":\"); si=substr(sn[2],2)};"\ " /^ *Type *: code/{print \"T\",si,substr(si,length(prfx))};"\ " /^ *Type *: data/{print \"I\",si,substr(si,length(prfx))};"\ " \$ 0!~/External *\|/{next};"\ " / 0+ UNDEF /{next}; / UNDEF \([^|]\)*()/{next};"\ " {if(hide[section]) next};"\ " {f=\"D\"}; \$ 0~/\(\).*\|/{f=\"T\"};"\ " {split(\$ 0,a,/\||\r/); split(a[2],s)};"\ " s[1]~/^[@?]/{print f,s[1],s[1]; next};"\ " s[1]~prfx {split(s[1],t,\"@\"); print f,t[1],substr(t[1],length(prfx))}"\ " ' prfx=^$ac_symprfx]" else lt_cv_sys_global_symbol_pipe="sed -n -e 's/^.*[[ ]]\($symcode$symcode*\)[[ ]][[ ]]*$ac_symprfx$sympat$opt_cr$/$symxfrm/p'" fi lt_cv_sys_global_symbol_pipe="$lt_cv_sys_global_symbol_pipe | sed '/ __gnu_lto/d'" # Check to see that the pipe works correctly. pipe_works=no rm -f conftest* cat > conftest.$ac_ext <<_LT_EOF #ifdef __cplusplus extern "C" { #endif char nm_test_var; void nm_test_func(void); void nm_test_func(void){} #ifdef __cplusplus } #endif int main(){nm_test_var='a';nm_test_func();return(0);} _LT_EOF if AC_TRY_EVAL(ac_compile); then # Now try to grab the symbols. nlist=conftest.nm if AC_TRY_EVAL(NM conftest.$ac_objext \| "$lt_cv_sys_global_symbol_pipe" \> $nlist) && test -s "$nlist"; then # Try sorting and uniquifying the output. if sort "$nlist" | uniq > "$nlist"T; then mv -f "$nlist"T "$nlist" else rm -f "$nlist"T fi # Make sure that we snagged all the symbols we need. if $GREP ' nm_test_var$' "$nlist" >/dev/null; then if $GREP ' nm_test_func$' "$nlist" >/dev/null; then cat <<_LT_EOF > conftest.$ac_ext /* Keep this code in sync between libtool.m4, ltmain, lt_system.h, and tests. */ #if defined _WIN32 || defined __CYGWIN__ || defined _WIN32_WCE /* DATA imports from DLLs on WIN32 can't be const, because runtime relocations are performed -- see ld's documentation on pseudo-relocs. */ # define LT@&t@_DLSYM_CONST #elif defined __osf__ /* This system does not cope well with relocations in const data. */ # define LT@&t@_DLSYM_CONST #else # define LT@&t@_DLSYM_CONST const #endif #ifdef __cplusplus extern "C" { #endif _LT_EOF # Now generate the symbol file. eval "$lt_cv_sys_global_symbol_to_cdecl"' < "$nlist" | $GREP -v main >> conftest.$ac_ext' cat <<_LT_EOF >> conftest.$ac_ext /* The mapping between symbol names and symbols. */ LT@&t@_DLSYM_CONST struct { const char *name; void *address; } lt__PROGRAM__LTX_preloaded_symbols[[]] = { { "@PROGRAM@", (void *) 0 }, _LT_EOF $SED "s/^$symcode$symcode* .* \(.*\)$/ {\"\1\", (void *) \&\1},/" < "$nlist" | $GREP -v main >> conftest.$ac_ext cat <<\_LT_EOF >> conftest.$ac_ext {0, (void *) 0} }; /* This works around a problem in FreeBSD linker */ #ifdef FREEBSD_WORKAROUND static const void *lt_preloaded_setup() { return lt__PROGRAM__LTX_preloaded_symbols; } #endif #ifdef __cplusplus } #endif _LT_EOF # Now try linking the two files. mv conftest.$ac_objext conftstm.$ac_objext lt_globsym_save_LIBS=$LIBS lt_globsym_save_CFLAGS=$CFLAGS LIBS=conftstm.$ac_objext CFLAGS="$CFLAGS$_LT_TAGVAR(lt_prog_compiler_no_builtin_flag, $1)" if AC_TRY_EVAL(ac_link) && test -s conftest$ac_exeext; then pipe_works=yes fi LIBS=$lt_globsym_save_LIBS CFLAGS=$lt_globsym_save_CFLAGS else echo "cannot find nm_test_func in $nlist" >&AS_MESSAGE_LOG_FD fi else echo "cannot find nm_test_var in $nlist" >&AS_MESSAGE_LOG_FD fi else echo "cannot run $lt_cv_sys_global_symbol_pipe" >&AS_MESSAGE_LOG_FD fi else echo "$progname: failed program was:" >&AS_MESSAGE_LOG_FD cat conftest.$ac_ext >&5 fi rm -rf conftest* conftst* # Do not use the global_symbol_pipe unless it works. if test yes = "$pipe_works"; then break else lt_cv_sys_global_symbol_pipe= fi done ]) if test -z "$lt_cv_sys_global_symbol_pipe"; then lt_cv_sys_global_symbol_to_cdecl= fi if test -z "$lt_cv_sys_global_symbol_pipe$lt_cv_sys_global_symbol_to_cdecl"; then AC_MSG_RESULT(failed) else AC_MSG_RESULT(ok) fi # Response file support. if test "$lt_cv_nm_interface" = "MS dumpbin"; then nm_file_list_spec='@' elif $NM --help 2>/dev/null | grep '[[@]]FILE' >/dev/null; then nm_file_list_spec='@' fi _LT_DECL([global_symbol_pipe], [lt_cv_sys_global_symbol_pipe], [1], [Take the output of nm and produce a listing of raw symbols and C names]) _LT_DECL([global_symbol_to_cdecl], [lt_cv_sys_global_symbol_to_cdecl], [1], [Transform the output of nm in a proper C declaration]) _LT_DECL([global_symbol_to_import], [lt_cv_sys_global_symbol_to_import], [1], [Transform the output of nm into a list of symbols to manually relocate]) _LT_DECL([global_symbol_to_c_name_address], [lt_cv_sys_global_symbol_to_c_name_address], [1], [Transform the output of nm in a C name address pair]) _LT_DECL([global_symbol_to_c_name_address_lib_prefix], [lt_cv_sys_global_symbol_to_c_name_address_lib_prefix], [1], [Transform the output of nm in a C name address pair when lib prefix is needed]) _LT_DECL([nm_interface], [lt_cv_nm_interface], [1], [The name lister interface]) _LT_DECL([], [nm_file_list_spec], [1], [Specify filename containing input files for $NM]) ]) # _LT_CMD_GLOBAL_SYMBOLS # _LT_COMPILER_PIC([TAGNAME]) # --------------------------- m4_defun([_LT_COMPILER_PIC], [m4_require([_LT_TAG_COMPILER])dnl _LT_TAGVAR(lt_prog_compiler_wl, $1)= _LT_TAGVAR(lt_prog_compiler_pic, $1)= _LT_TAGVAR(lt_prog_compiler_static, $1)= m4_if([$1], [CXX], [ # C++ specific cases for pic, static, wl, etc. if test yes = "$GXX"; then _LT_TAGVAR(lt_prog_compiler_wl, $1)='-Wl,' _LT_TAGVAR(lt_prog_compiler_static, $1)='-static' case $host_os in aix*) # All AIX code is PIC. if test ia64 = "$host_cpu"; then # AIX 5 now supports IA64 processor _LT_TAGVAR(lt_prog_compiler_static, $1)='-Bstatic' fi _LT_TAGVAR(lt_prog_compiler_pic, $1)='-fPIC' ;; amigaos*) case $host_cpu in powerpc) # see comment about AmigaOS4 .so support _LT_TAGVAR(lt_prog_compiler_pic, $1)='-fPIC' ;; m68k) # FIXME: we need at least 68020 code to build shared libraries, but # adding the '-m68020' flag to GCC prevents building anything better, # like '-m68040'. _LT_TAGVAR(lt_prog_compiler_pic, $1)='-m68020 -resident32 -malways-restore-a4' ;; esac ;; beos* | irix5* | irix6* | nonstopux* | osf3* | osf4* | osf5*) # PIC is the default for these OSes. ;; mingw* | cygwin* | os2* | pw32* | cegcc*) # This hack is so that the source file can tell whether it is being # built for inclusion in a dll (and should export symbols for example). # Although the cygwin gcc ignores -fPIC, still need this for old-style # (--disable-auto-import) libraries m4_if([$1], [GCJ], [], [_LT_TAGVAR(lt_prog_compiler_pic, $1)='-DDLL_EXPORT']) case $host_os in os2*) _LT_TAGVAR(lt_prog_compiler_static, $1)='$wl-static' ;; esac ;; darwin* | rhapsody*) # PIC is the default on this platform # Common symbols not allowed in MH_DYLIB files _LT_TAGVAR(lt_prog_compiler_pic, $1)='-fno-common' ;; *djgpp*) # DJGPP does not support shared libraries at all _LT_TAGVAR(lt_prog_compiler_pic, $1)= ;; haiku*) # PIC is the default for Haiku. # The "-static" flag exists, but is broken. _LT_TAGVAR(lt_prog_compiler_static, $1)= ;; interix[[3-9]]*) # Interix 3.x gcc -fpic/-fPIC options generate broken code. # Instead, we relocate shared libraries at runtime. ;; sysv4*MP*) if test -d /usr/nec; then _LT_TAGVAR(lt_prog_compiler_pic, $1)=-Kconform_pic fi ;; hpux*) # PIC is the default for 64-bit PA HP-UX, but not for 32-bit # PA HP-UX. On IA64 HP-UX, PIC is the default but the pic flag # sets the default TLS model and affects inlining. case $host_cpu in hppa*64*) ;; *) _LT_TAGVAR(lt_prog_compiler_pic, $1)='-fPIC' ;; esac ;; *qnx* | *nto*) # QNX uses GNU C++, but need to define -shared option too, otherwise # it will coredump. _LT_TAGVAR(lt_prog_compiler_pic, $1)='-fPIC -shared' ;; *) _LT_TAGVAR(lt_prog_compiler_pic, $1)='-fPIC' ;; esac else case $host_os in aix[[4-9]]*) # All AIX code is PIC. if test ia64 = "$host_cpu"; then # AIX 5 now supports IA64 processor _LT_TAGVAR(lt_prog_compiler_static, $1)='-Bstatic' else _LT_TAGVAR(lt_prog_compiler_static, $1)='-bnso -bI:/lib/syscalls.exp' fi ;; chorus*) case $cc_basename in cxch68*) # Green Hills C++ Compiler # _LT_TAGVAR(lt_prog_compiler_static, $1)="--no_auto_instantiation -u __main -u __premain -u _abort -r $COOL_DIR/lib/libOrb.a $MVME_DIR/lib/CC/libC.a $MVME_DIR/lib/classix/libcx.s.a" ;; esac ;; mingw* | cygwin* | os2* | pw32* | cegcc*) # This hack is so that the source file can tell whether it is being # built for inclusion in a dll (and should export symbols for example). m4_if([$1], [GCJ], [], [_LT_TAGVAR(lt_prog_compiler_pic, $1)='-DDLL_EXPORT']) ;; dgux*) case $cc_basename in ec++*) _LT_TAGVAR(lt_prog_compiler_pic, $1)='-KPIC' ;; ghcx*) # Green Hills C++ Compiler _LT_TAGVAR(lt_prog_compiler_pic, $1)='-pic' ;; *) ;; esac ;; freebsd* | dragonfly*) # FreeBSD uses GNU C++ ;; hpux9* | hpux10* | hpux11*) case $cc_basename in CC*) _LT_TAGVAR(lt_prog_compiler_wl, $1)='-Wl,' _LT_TAGVAR(lt_prog_compiler_static, $1)='$wl-a ${wl}archive' if test ia64 != "$host_cpu"; then _LT_TAGVAR(lt_prog_compiler_pic, $1)='+Z' fi ;; aCC*) _LT_TAGVAR(lt_prog_compiler_wl, $1)='-Wl,' _LT_TAGVAR(lt_prog_compiler_static, $1)='$wl-a ${wl}archive' case $host_cpu in hppa*64*|ia64*) # +Z the default ;; *) _LT_TAGVAR(lt_prog_compiler_pic, $1)='+Z' ;; esac ;; *) ;; esac ;; interix*) # This is c89, which is MS Visual C++ (no shared libs) # Anyone wants to do a port? ;; irix5* | irix6* | nonstopux*) case $cc_basename in CC*) _LT_TAGVAR(lt_prog_compiler_wl, $1)='-Wl,' _LT_TAGVAR(lt_prog_compiler_static, $1)='-non_shared' # CC pic flag -KPIC is the default. ;; *) ;; esac ;; linux* | k*bsd*-gnu | kopensolaris*-gnu | gnu*) case $cc_basename in KCC*) # KAI C++ Compiler _LT_TAGVAR(lt_prog_compiler_wl, $1)='--backend -Wl,' _LT_TAGVAR(lt_prog_compiler_pic, $1)='-fPIC' ;; ecpc* ) # old Intel C++ for x86_64, which still supported -KPIC. _LT_TAGVAR(lt_prog_compiler_wl, $1)='-Wl,' _LT_TAGVAR(lt_prog_compiler_pic, $1)='-KPIC' _LT_TAGVAR(lt_prog_compiler_static, $1)='-static' ;; icpc* ) # Intel C++, used to be incompatible with GCC. # ICC 10 doesn't accept -KPIC any more. _LT_TAGVAR(lt_prog_compiler_wl, $1)='-Wl,' _LT_TAGVAR(lt_prog_compiler_pic, $1)='-fPIC' _LT_TAGVAR(lt_prog_compiler_static, $1)='-static' ;; pgCC* | pgcpp*) # Portland Group C++ compiler _LT_TAGVAR(lt_prog_compiler_wl, $1)='-Wl,' _LT_TAGVAR(lt_prog_compiler_pic, $1)='-fpic' _LT_TAGVAR(lt_prog_compiler_static, $1)='-Bstatic' ;; cxx*) # Compaq C++ # Make sure the PIC flag is empty. It appears that all Alpha # Linux and Compaq Tru64 Unix objects are PIC. _LT_TAGVAR(lt_prog_compiler_pic, $1)= _LT_TAGVAR(lt_prog_compiler_static, $1)='-non_shared' ;; xlc* | xlC* | bgxl[[cC]]* | mpixl[[cC]]*) # IBM XL 8.0, 9.0 on PPC and BlueGene _LT_TAGVAR(lt_prog_compiler_wl, $1)='-Wl,' _LT_TAGVAR(lt_prog_compiler_pic, $1)='-qpic' _LT_TAGVAR(lt_prog_compiler_static, $1)='-qstaticlink' ;; *) case `$CC -V 2>&1 | sed 5q` in *Sun\ C*) # Sun C++ 5.9 _LT_TAGVAR(lt_prog_compiler_pic, $1)='-KPIC' _LT_TAGVAR(lt_prog_compiler_static, $1)='-Bstatic' _LT_TAGVAR(lt_prog_compiler_wl, $1)='-Qoption ld ' ;; esac ;; esac ;; lynxos*) ;; m88k*) ;; mvs*) case $cc_basename in cxx*) _LT_TAGVAR(lt_prog_compiler_pic, $1)='-W c,exportall' ;; *) ;; esac ;; netbsd*) ;; *qnx* | *nto*) # QNX uses GNU C++, but need to define -shared option too, otherwise # it will coredump. _LT_TAGVAR(lt_prog_compiler_pic, $1)='-fPIC -shared' ;; osf3* | osf4* | osf5*) case $cc_basename in KCC*) _LT_TAGVAR(lt_prog_compiler_wl, $1)='--backend -Wl,' ;; RCC*) # Rational C++ 2.4.1 _LT_TAGVAR(lt_prog_compiler_pic, $1)='-pic' ;; cxx*) # Digital/Compaq C++ _LT_TAGVAR(lt_prog_compiler_wl, $1)='-Wl,' # Make sure the PIC flag is empty. It appears that all Alpha # Linux and Compaq Tru64 Unix objects are PIC. _LT_TAGVAR(lt_prog_compiler_pic, $1)= _LT_TAGVAR(lt_prog_compiler_static, $1)='-non_shared' ;; *) ;; esac ;; psos*) ;; solaris*) case $cc_basename in CC* | sunCC*) # Sun C++ 4.2, 5.x and Centerline C++ _LT_TAGVAR(lt_prog_compiler_pic, $1)='-KPIC' _LT_TAGVAR(lt_prog_compiler_static, $1)='-Bstatic' _LT_TAGVAR(lt_prog_compiler_wl, $1)='-Qoption ld ' ;; gcx*) # Green Hills C++ Compiler _LT_TAGVAR(lt_prog_compiler_pic, $1)='-PIC' ;; *) ;; esac ;; sunos4*) case $cc_basename in CC*) # Sun C++ 4.x _LT_TAGVAR(lt_prog_compiler_pic, $1)='-pic' _LT_TAGVAR(lt_prog_compiler_static, $1)='-Bstatic' ;; lcc*) # Lucid _LT_TAGVAR(lt_prog_compiler_pic, $1)='-pic' ;; *) ;; esac ;; sysv5* | unixware* | sco3.2v5* | sco5v6* | OpenUNIX*) case $cc_basename in CC*) _LT_TAGVAR(lt_prog_compiler_wl, $1)='-Wl,' _LT_TAGVAR(lt_prog_compiler_pic, $1)='-KPIC' _LT_TAGVAR(lt_prog_compiler_static, $1)='-Bstatic' ;; esac ;; tandem*) case $cc_basename in NCC*) # NonStop-UX NCC 3.20 _LT_TAGVAR(lt_prog_compiler_pic, $1)='-KPIC' ;; *) ;; esac ;; vxworks*) ;; *) _LT_TAGVAR(lt_prog_compiler_can_build_shared, $1)=no ;; esac fi ], [ if test yes = "$GCC"; then _LT_TAGVAR(lt_prog_compiler_wl, $1)='-Wl,' _LT_TAGVAR(lt_prog_compiler_static, $1)='-static' case $host_os in aix*) # All AIX code is PIC. if test ia64 = "$host_cpu"; then # AIX 5 now supports IA64 processor _LT_TAGVAR(lt_prog_compiler_static, $1)='-Bstatic' fi _LT_TAGVAR(lt_prog_compiler_pic, $1)='-fPIC' ;; amigaos*) case $host_cpu in powerpc) # see comment about AmigaOS4 .so support _LT_TAGVAR(lt_prog_compiler_pic, $1)='-fPIC' ;; m68k) # FIXME: we need at least 68020 code to build shared libraries, but # adding the '-m68020' flag to GCC prevents building anything better, # like '-m68040'. _LT_TAGVAR(lt_prog_compiler_pic, $1)='-m68020 -resident32 -malways-restore-a4' ;; esac ;; beos* | irix5* | irix6* | nonstopux* | osf3* | osf4* | osf5*) # PIC is the default for these OSes. ;; mingw* | cygwin* | pw32* | os2* | cegcc*) # This hack is so that the source file can tell whether it is being # built for inclusion in a dll (and should export symbols for example). # Although the cygwin gcc ignores -fPIC, still need this for old-style # (--disable-auto-import) libraries m4_if([$1], [GCJ], [], [_LT_TAGVAR(lt_prog_compiler_pic, $1)='-DDLL_EXPORT']) case $host_os in os2*) _LT_TAGVAR(lt_prog_compiler_static, $1)='$wl-static' ;; esac ;; darwin* | rhapsody*) # PIC is the default on this platform # Common symbols not allowed in MH_DYLIB files _LT_TAGVAR(lt_prog_compiler_pic, $1)='-fno-common' ;; haiku*) # PIC is the default for Haiku. # The "-static" flag exists, but is broken. _LT_TAGVAR(lt_prog_compiler_static, $1)= ;; hpux*) # PIC is the default for 64-bit PA HP-UX, but not for 32-bit # PA HP-UX. On IA64 HP-UX, PIC is the default but the pic flag # sets the default TLS model and affects inlining. case $host_cpu in hppa*64*) # +Z the default ;; *) _LT_TAGVAR(lt_prog_compiler_pic, $1)='-fPIC' ;; esac ;; interix[[3-9]]*) # Interix 3.x gcc -fpic/-fPIC options generate broken code. # Instead, we relocate shared libraries at runtime. ;; msdosdjgpp*) # Just because we use GCC doesn't mean we suddenly get shared libraries # on systems that don't support them. _LT_TAGVAR(lt_prog_compiler_can_build_shared, $1)=no enable_shared=no ;; *nto* | *qnx*) # QNX uses GNU C++, but need to define -shared option too, otherwise # it will coredump. _LT_TAGVAR(lt_prog_compiler_pic, $1)='-fPIC -shared' ;; sysv4*MP*) if test -d /usr/nec; then _LT_TAGVAR(lt_prog_compiler_pic, $1)=-Kconform_pic fi ;; *) _LT_TAGVAR(lt_prog_compiler_pic, $1)='-fPIC' ;; esac case $cc_basename in nvcc*) # Cuda Compiler Driver 2.2 _LT_TAGVAR(lt_prog_compiler_wl, $1)='-Xlinker ' if test -n "$_LT_TAGVAR(lt_prog_compiler_pic, $1)"; then _LT_TAGVAR(lt_prog_compiler_pic, $1)="-Xcompiler $_LT_TAGVAR(lt_prog_compiler_pic, $1)" fi ;; esac else # PORTME Check for flag to pass linker flags through the system compiler. case $host_os in aix*) _LT_TAGVAR(lt_prog_compiler_wl, $1)='-Wl,' if test ia64 = "$host_cpu"; then # AIX 5 now supports IA64 processor _LT_TAGVAR(lt_prog_compiler_static, $1)='-Bstatic' else _LT_TAGVAR(lt_prog_compiler_static, $1)='-bnso -bI:/lib/syscalls.exp' fi ;; darwin* | rhapsody*) # PIC is the default on this platform # Common symbols not allowed in MH_DYLIB files _LT_TAGVAR(lt_prog_compiler_pic, $1)='-fno-common' case $cc_basename in nagfor*) # NAG Fortran compiler _LT_TAGVAR(lt_prog_compiler_wl, $1)='-Wl,-Wl,,' _LT_TAGVAR(lt_prog_compiler_pic, $1)='-PIC' _LT_TAGVAR(lt_prog_compiler_static, $1)='-Bstatic' ;; esac ;; mingw* | cygwin* | pw32* | os2* | cegcc*) # This hack is so that the source file can tell whether it is being # built for inclusion in a dll (and should export symbols for example). m4_if([$1], [GCJ], [], [_LT_TAGVAR(lt_prog_compiler_pic, $1)='-DDLL_EXPORT']) case $host_os in os2*) _LT_TAGVAR(lt_prog_compiler_static, $1)='$wl-static' ;; esac ;; hpux9* | hpux10* | hpux11*) _LT_TAGVAR(lt_prog_compiler_wl, $1)='-Wl,' # PIC is the default for IA64 HP-UX and 64-bit HP-UX, but # not for PA HP-UX. case $host_cpu in hppa*64*|ia64*) # +Z the default ;; *) _LT_TAGVAR(lt_prog_compiler_pic, $1)='+Z' ;; esac # Is there a better lt_prog_compiler_static that works with the bundled CC? _LT_TAGVAR(lt_prog_compiler_static, $1)='$wl-a ${wl}archive' ;; irix5* | irix6* | nonstopux*) _LT_TAGVAR(lt_prog_compiler_wl, $1)='-Wl,' # PIC (with -KPIC) is the default. _LT_TAGVAR(lt_prog_compiler_static, $1)='-non_shared' ;; linux* | k*bsd*-gnu | kopensolaris*-gnu | gnu*) case $cc_basename in # old Intel for x86_64, which still supported -KPIC. ecc*) _LT_TAGVAR(lt_prog_compiler_wl, $1)='-Wl,' _LT_TAGVAR(lt_prog_compiler_pic, $1)='-KPIC' _LT_TAGVAR(lt_prog_compiler_static, $1)='-static' ;; # icc used to be incompatible with GCC. # ICC 10 doesn't accept -KPIC any more. icc* | ifort*) _LT_TAGVAR(lt_prog_compiler_wl, $1)='-Wl,' _LT_TAGVAR(lt_prog_compiler_pic, $1)='-fPIC' _LT_TAGVAR(lt_prog_compiler_static, $1)='-static' ;; # Lahey Fortran 8.1. lf95*) _LT_TAGVAR(lt_prog_compiler_wl, $1)='-Wl,' _LT_TAGVAR(lt_prog_compiler_pic, $1)='--shared' _LT_TAGVAR(lt_prog_compiler_static, $1)='--static' ;; nagfor*) # NAG Fortran compiler _LT_TAGVAR(lt_prog_compiler_wl, $1)='-Wl,-Wl,,' _LT_TAGVAR(lt_prog_compiler_pic, $1)='-PIC' _LT_TAGVAR(lt_prog_compiler_static, $1)='-Bstatic' ;; tcc*) # Fabrice Bellard et al's Tiny C Compiler _LT_TAGVAR(lt_prog_compiler_wl, $1)='-Wl,' _LT_TAGVAR(lt_prog_compiler_pic, $1)='-fPIC' _LT_TAGVAR(lt_prog_compiler_static, $1)='-static' ;; pgcc* | pgf77* | pgf90* | pgf95* | pgfortran*) # Portland Group compilers (*not* the Pentium gcc compiler, # which looks to be a dead project) _LT_TAGVAR(lt_prog_compiler_wl, $1)='-Wl,' _LT_TAGVAR(lt_prog_compiler_pic, $1)='-fpic' _LT_TAGVAR(lt_prog_compiler_static, $1)='-Bstatic' ;; ccc*) _LT_TAGVAR(lt_prog_compiler_wl, $1)='-Wl,' # All Alpha code is PIC. _LT_TAGVAR(lt_prog_compiler_static, $1)='-non_shared' ;; xl* | bgxl* | bgf* | mpixl*) # IBM XL C 8.0/Fortran 10.1, 11.1 on PPC and BlueGene _LT_TAGVAR(lt_prog_compiler_wl, $1)='-Wl,' _LT_TAGVAR(lt_prog_compiler_pic, $1)='-qpic' _LT_TAGVAR(lt_prog_compiler_static, $1)='-qstaticlink' ;; *) case `$CC -V 2>&1 | sed 5q` in *Sun\ Ceres\ Fortran* | *Sun*Fortran*\ [[1-7]].* | *Sun*Fortran*\ 8.[[0-3]]*) # Sun Fortran 8.3 passes all unrecognized flags to the linker _LT_TAGVAR(lt_prog_compiler_pic, $1)='-KPIC' _LT_TAGVAR(lt_prog_compiler_static, $1)='-Bstatic' _LT_TAGVAR(lt_prog_compiler_wl, $1)='' ;; *Sun\ F* | *Sun*Fortran*) _LT_TAGVAR(lt_prog_compiler_pic, $1)='-KPIC' _LT_TAGVAR(lt_prog_compiler_static, $1)='-Bstatic' _LT_TAGVAR(lt_prog_compiler_wl, $1)='-Qoption ld ' ;; *Sun\ C*) # Sun C 5.9 _LT_TAGVAR(lt_prog_compiler_pic, $1)='-KPIC' _LT_TAGVAR(lt_prog_compiler_static, $1)='-Bstatic' _LT_TAGVAR(lt_prog_compiler_wl, $1)='-Wl,' ;; *Intel*\ [[CF]]*Compiler*) _LT_TAGVAR(lt_prog_compiler_wl, $1)='-Wl,' _LT_TAGVAR(lt_prog_compiler_pic, $1)='-fPIC' _LT_TAGVAR(lt_prog_compiler_static, $1)='-static' ;; *Portland\ Group*) _LT_TAGVAR(lt_prog_compiler_wl, $1)='-Wl,' _LT_TAGVAR(lt_prog_compiler_pic, $1)='-fpic' _LT_TAGVAR(lt_prog_compiler_static, $1)='-Bstatic' ;; esac ;; esac ;; newsos6) _LT_TAGVAR(lt_prog_compiler_pic, $1)='-KPIC' _LT_TAGVAR(lt_prog_compiler_static, $1)='-Bstatic' ;; *nto* | *qnx*) # QNX uses GNU C++, but need to define -shared option too, otherwise # it will coredump. _LT_TAGVAR(lt_prog_compiler_pic, $1)='-fPIC -shared' ;; osf3* | osf4* | osf5*) _LT_TAGVAR(lt_prog_compiler_wl, $1)='-Wl,' # All OSF/1 code is PIC. _LT_TAGVAR(lt_prog_compiler_static, $1)='-non_shared' ;; rdos*) _LT_TAGVAR(lt_prog_compiler_static, $1)='-non_shared' ;; solaris*) _LT_TAGVAR(lt_prog_compiler_pic, $1)='-KPIC' _LT_TAGVAR(lt_prog_compiler_static, $1)='-Bstatic' case $cc_basename in f77* | f90* | f95* | sunf77* | sunf90* | sunf95*) _LT_TAGVAR(lt_prog_compiler_wl, $1)='-Qoption ld ';; *) _LT_TAGVAR(lt_prog_compiler_wl, $1)='-Wl,';; esac ;; sunos4*) _LT_TAGVAR(lt_prog_compiler_wl, $1)='-Qoption ld ' _LT_TAGVAR(lt_prog_compiler_pic, $1)='-PIC' _LT_TAGVAR(lt_prog_compiler_static, $1)='-Bstatic' ;; sysv4 | sysv4.2uw2* | sysv4.3*) _LT_TAGVAR(lt_prog_compiler_wl, $1)='-Wl,' _LT_TAGVAR(lt_prog_compiler_pic, $1)='-KPIC' _LT_TAGVAR(lt_prog_compiler_static, $1)='-Bstatic' ;; sysv4*MP*) if test -d /usr/nec; then _LT_TAGVAR(lt_prog_compiler_pic, $1)='-Kconform_pic' _LT_TAGVAR(lt_prog_compiler_static, $1)='-Bstatic' fi ;; sysv5* | unixware* | sco3.2v5* | sco5v6* | OpenUNIX*) _LT_TAGVAR(lt_prog_compiler_wl, $1)='-Wl,' _LT_TAGVAR(lt_prog_compiler_pic, $1)='-KPIC' _LT_TAGVAR(lt_prog_compiler_static, $1)='-Bstatic' ;; unicos*) _LT_TAGVAR(lt_prog_compiler_wl, $1)='-Wl,' _LT_TAGVAR(lt_prog_compiler_can_build_shared, $1)=no ;; uts4*) _LT_TAGVAR(lt_prog_compiler_pic, $1)='-pic' _LT_TAGVAR(lt_prog_compiler_static, $1)='-Bstatic' ;; *) _LT_TAGVAR(lt_prog_compiler_can_build_shared, $1)=no ;; esac fi ]) case $host_os in # For platforms that do not support PIC, -DPIC is meaningless: *djgpp*) _LT_TAGVAR(lt_prog_compiler_pic, $1)= ;; *) _LT_TAGVAR(lt_prog_compiler_pic, $1)="$_LT_TAGVAR(lt_prog_compiler_pic, $1)@&t@m4_if([$1],[],[ -DPIC],[m4_if([$1],[CXX],[ -DPIC],[])])" ;; esac AC_CACHE_CHECK([for $compiler option to produce PIC], [_LT_TAGVAR(lt_cv_prog_compiler_pic, $1)], [_LT_TAGVAR(lt_cv_prog_compiler_pic, $1)=$_LT_TAGVAR(lt_prog_compiler_pic, $1)]) _LT_TAGVAR(lt_prog_compiler_pic, $1)=$_LT_TAGVAR(lt_cv_prog_compiler_pic, $1) # # Check to make sure the PIC flag actually works. # if test -n "$_LT_TAGVAR(lt_prog_compiler_pic, $1)"; then _LT_COMPILER_OPTION([if $compiler PIC flag $_LT_TAGVAR(lt_prog_compiler_pic, $1) works], [_LT_TAGVAR(lt_cv_prog_compiler_pic_works, $1)], [$_LT_TAGVAR(lt_prog_compiler_pic, $1)@&t@m4_if([$1],[],[ -DPIC],[m4_if([$1],[CXX],[ -DPIC],[])])], [], [case $_LT_TAGVAR(lt_prog_compiler_pic, $1) in "" | " "*) ;; *) _LT_TAGVAR(lt_prog_compiler_pic, $1)=" $_LT_TAGVAR(lt_prog_compiler_pic, $1)" ;; esac], [_LT_TAGVAR(lt_prog_compiler_pic, $1)= _LT_TAGVAR(lt_prog_compiler_can_build_shared, $1)=no]) fi _LT_TAGDECL([pic_flag], [lt_prog_compiler_pic], [1], [Additional compiler flags for building library objects]) _LT_TAGDECL([wl], [lt_prog_compiler_wl], [1], [How to pass a linker flag through the compiler]) # # Check to make sure the static flag actually works. # wl=$_LT_TAGVAR(lt_prog_compiler_wl, $1) eval lt_tmp_static_flag=\"$_LT_TAGVAR(lt_prog_compiler_static, $1)\" _LT_LINKER_OPTION([if $compiler static flag $lt_tmp_static_flag works], _LT_TAGVAR(lt_cv_prog_compiler_static_works, $1), $lt_tmp_static_flag, [], [_LT_TAGVAR(lt_prog_compiler_static, $1)=]) _LT_TAGDECL([link_static_flag], [lt_prog_compiler_static], [1], [Compiler flag to prevent dynamic linking]) ])# _LT_COMPILER_PIC # _LT_LINKER_SHLIBS([TAGNAME]) # ---------------------------- # See if the linker supports building shared libraries. m4_defun([_LT_LINKER_SHLIBS], [AC_REQUIRE([LT_PATH_LD])dnl AC_REQUIRE([LT_PATH_NM])dnl m4_require([_LT_PATH_MANIFEST_TOOL])dnl m4_require([_LT_FILEUTILS_DEFAULTS])dnl m4_require([_LT_DECL_EGREP])dnl m4_require([_LT_DECL_SED])dnl m4_require([_LT_CMD_GLOBAL_SYMBOLS])dnl m4_require([_LT_TAG_COMPILER])dnl AC_MSG_CHECKING([whether the $compiler linker ($LD) supports shared libraries]) m4_if([$1], [CXX], [ _LT_TAGVAR(export_symbols_cmds, $1)='$NM $libobjs $convenience | $global_symbol_pipe | $SED '\''s/.* //'\'' | sort | uniq > $export_symbols' _LT_TAGVAR(exclude_expsyms, $1)=['_GLOBAL_OFFSET_TABLE_|_GLOBAL__F[ID]_.*'] case $host_os in aix[[4-9]]*) # If we're using GNU nm, then we don't want the "-C" option. # -C means demangle to GNU nm, but means don't demangle to AIX nm. # Without the "-l" option, or with the "-B" option, AIX nm treats # weak defined symbols like other global defined symbols, whereas # GNU nm marks them as "W". # While the 'weak' keyword is ignored in the Export File, we need # it in the Import File for the 'aix-soname' feature, so we have # to replace the "-B" option with "-P" for AIX nm. if $NM -V 2>&1 | $GREP 'GNU' > /dev/null; then _LT_TAGVAR(export_symbols_cmds, $1)='$NM -Bpg $libobjs $convenience | awk '\''{ if (((\$ 2 == "T") || (\$ 2 == "D") || (\$ 2 == "B") || (\$ 2 == "W")) && ([substr](\$ 3,1,1) != ".")) { if (\$ 2 == "W") { print \$ 3 " weak" } else { print \$ 3 } } }'\'' | sort -u > $export_symbols' else _LT_TAGVAR(export_symbols_cmds, $1)='`func_echo_all $NM | $SED -e '\''s/B\([[^B]]*\)$/P\1/'\''` -PCpgl $libobjs $convenience | awk '\''{ if (((\$ 2 == "T") || (\$ 2 == "D") || (\$ 2 == "B") || (\$ 2 == "W") || (\$ 2 == "V") || (\$ 2 == "Z")) && ([substr](\$ 1,1,1) != ".")) { if ((\$ 2 == "W") || (\$ 2 == "V") || (\$ 2 == "Z")) { print \$ 1 " weak" } else { print \$ 1 } } }'\'' | sort -u > $export_symbols' fi ;; pw32*) _LT_TAGVAR(export_symbols_cmds, $1)=$ltdll_cmds ;; cygwin* | mingw* | cegcc*) case $cc_basename in cl*) _LT_TAGVAR(exclude_expsyms, $1)='_NULL_IMPORT_DESCRIPTOR|_IMPORT_DESCRIPTOR_.*' ;; *) _LT_TAGVAR(export_symbols_cmds, $1)='$NM $libobjs $convenience | $global_symbol_pipe | $SED -e '\''/^[[BCDGRS]][[ ]]/s/.*[[ ]]\([[^ ]]*\)/\1 DATA/;s/^.*[[ ]]__nm__\([[^ ]]*\)[[ ]][[^ ]]*/\1 DATA/;/^I[[ ]]/d;/^[[AITW]][[ ]]/s/.* //'\'' | sort | uniq > $export_symbols' _LT_TAGVAR(exclude_expsyms, $1)=['[_]+GLOBAL_OFFSET_TABLE_|[_]+GLOBAL__[FID]_.*|[_]+head_[A-Za-z0-9_]+_dll|[A-Za-z0-9_]+_dll_iname'] ;; esac ;; *) _LT_TAGVAR(export_symbols_cmds, $1)='$NM $libobjs $convenience | $global_symbol_pipe | $SED '\''s/.* //'\'' | sort | uniq > $export_symbols' ;; esac ], [ runpath_var= _LT_TAGVAR(allow_undefined_flag, $1)= _LT_TAGVAR(always_export_symbols, $1)=no _LT_TAGVAR(archive_cmds, $1)= _LT_TAGVAR(archive_expsym_cmds, $1)= _LT_TAGVAR(compiler_needs_object, $1)=no _LT_TAGVAR(enable_shared_with_static_runtimes, $1)=no _LT_TAGVAR(export_dynamic_flag_spec, $1)= _LT_TAGVAR(export_symbols_cmds, $1)='$NM $libobjs $convenience | $global_symbol_pipe | $SED '\''s/.* //'\'' | sort | uniq > $export_symbols' _LT_TAGVAR(hardcode_automatic, $1)=no _LT_TAGVAR(hardcode_direct, $1)=no _LT_TAGVAR(hardcode_direct_absolute, $1)=no _LT_TAGVAR(hardcode_libdir_flag_spec, $1)= _LT_TAGVAR(hardcode_libdir_separator, $1)= _LT_TAGVAR(hardcode_minus_L, $1)=no _LT_TAGVAR(hardcode_shlibpath_var, $1)=unsupported _LT_TAGVAR(inherit_rpath, $1)=no _LT_TAGVAR(link_all_deplibs, $1)=unknown _LT_TAGVAR(module_cmds, $1)= _LT_TAGVAR(module_expsym_cmds, $1)= _LT_TAGVAR(old_archive_from_new_cmds, $1)= _LT_TAGVAR(old_archive_from_expsyms_cmds, $1)= _LT_TAGVAR(thread_safe_flag_spec, $1)= _LT_TAGVAR(whole_archive_flag_spec, $1)= # include_expsyms should be a list of space-separated symbols to be *always* # included in the symbol list _LT_TAGVAR(include_expsyms, $1)= # exclude_expsyms can be an extended regexp of symbols to exclude # it will be wrapped by ' (' and ')$', so one must not match beginning or # end of line. Example: 'a|bc|.*d.*' will exclude the symbols 'a' and 'bc', # as well as any symbol that contains 'd'. _LT_TAGVAR(exclude_expsyms, $1)=['_GLOBAL_OFFSET_TABLE_|_GLOBAL__F[ID]_.*'] # Although _GLOBAL_OFFSET_TABLE_ is a valid symbol C name, most a.out # platforms (ab)use it in PIC code, but their linkers get confused if # the symbol is explicitly referenced. Since portable code cannot # rely on this symbol name, it's probably fine to never include it in # preloaded symbol tables. # Exclude shared library initialization/finalization symbols. dnl Note also adjust exclude_expsyms for C++ above. extract_expsyms_cmds= case $host_os in cygwin* | mingw* | pw32* | cegcc*) # FIXME: the MSVC++ port hasn't been tested in a loooong time # When not using gcc, we currently assume that we are using # Microsoft Visual C++. if test yes != "$GCC"; then with_gnu_ld=no fi ;; interix*) # we just hope/assume this is gcc and not c89 (= MSVC++) with_gnu_ld=yes ;; openbsd* | bitrig*) with_gnu_ld=no ;; esac _LT_TAGVAR(ld_shlibs, $1)=yes # On some targets, GNU ld is compatible enough with the native linker # that we're better off using the native interface for both. lt_use_gnu_ld_interface=no if test yes = "$with_gnu_ld"; then case $host_os in aix*) # The AIX port of GNU ld has always aspired to compatibility # with the native linker. However, as the warning in the GNU ld # block says, versions before 2.19.5* couldn't really create working # shared libraries, regardless of the interface used. case `$LD -v 2>&1` in *\ \(GNU\ Binutils\)\ 2.19.5*) ;; *\ \(GNU\ Binutils\)\ 2.[[2-9]]*) ;; *\ \(GNU\ Binutils\)\ [[3-9]]*) ;; *) lt_use_gnu_ld_interface=yes ;; esac ;; *) lt_use_gnu_ld_interface=yes ;; esac fi if test yes = "$lt_use_gnu_ld_interface"; then # If archive_cmds runs LD, not CC, wlarc should be empty wlarc='$wl' # Set some defaults for GNU ld with shared library support. These # are reset later if shared libraries are not supported. Putting them # here allows them to be overridden if necessary. runpath_var=LD_RUN_PATH _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='$wl-rpath $wl$libdir' _LT_TAGVAR(export_dynamic_flag_spec, $1)='$wl--export-dynamic' # ancient GNU ld didn't support --whole-archive et. al. if $LD --help 2>&1 | $GREP 'no-whole-archive' > /dev/null; then _LT_TAGVAR(whole_archive_flag_spec, $1)=$wlarc'--whole-archive$convenience '$wlarc'--no-whole-archive' else _LT_TAGVAR(whole_archive_flag_spec, $1)= fi supports_anon_versioning=no case `$LD -v | $SED -e 's/([^)]\+)\s\+//' 2>&1` in *GNU\ gold*) supports_anon_versioning=yes ;; *\ [[01]].* | *\ 2.[[0-9]].* | *\ 2.10.*) ;; # catch versions < 2.11 *\ 2.11.93.0.2\ *) supports_anon_versioning=yes ;; # RH7.3 ... *\ 2.11.92.0.12\ *) supports_anon_versioning=yes ;; # Mandrake 8.2 ... *\ 2.11.*) ;; # other 2.11 versions *) supports_anon_versioning=yes ;; esac # See if GNU ld supports shared libraries. case $host_os in aix[[3-9]]*) # On AIX/PPC, the GNU linker is very broken if test ia64 != "$host_cpu"; then _LT_TAGVAR(ld_shlibs, $1)=no cat <<_LT_EOF 1>&2 *** Warning: the GNU linker, at least up to release 2.19, is reported *** to be unable to reliably create shared libraries on AIX. *** Therefore, libtool is disabling shared libraries support. If you *** really care for shared libraries, you may want to install binutils *** 2.20 or above, or modify your PATH so that a non-GNU linker is found. *** You will then need to restart the configuration process. _LT_EOF fi ;; amigaos*) case $host_cpu in powerpc) # see comment about AmigaOS4 .so support _LT_TAGVAR(archive_cmds, $1)='$CC -shared $libobjs $deplibs $compiler_flags $wl-soname $wl$soname -o $lib' _LT_TAGVAR(archive_expsym_cmds, $1)='' ;; m68k) _LT_TAGVAR(archive_cmds, $1)='$RM $output_objdir/a2ixlibrary.data~$ECHO "#define NAME $libname" > $output_objdir/a2ixlibrary.data~$ECHO "#define LIBRARY_ID 1" >> $output_objdir/a2ixlibrary.data~$ECHO "#define VERSION $major" >> $output_objdir/a2ixlibrary.data~$ECHO "#define REVISION $revision" >> $output_objdir/a2ixlibrary.data~$AR $AR_FLAGS $lib $libobjs~$RANLIB $lib~(cd $output_objdir && a2ixlibrary -32)' _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='-L$libdir' _LT_TAGVAR(hardcode_minus_L, $1)=yes ;; esac ;; beos*) if $LD --help 2>&1 | $GREP ': supported targets:.* elf' > /dev/null; then _LT_TAGVAR(allow_undefined_flag, $1)=unsupported # Joseph Beckenbach says some releases of gcc # support --undefined. This deserves some investigation. FIXME _LT_TAGVAR(archive_cmds, $1)='$CC -nostart $libobjs $deplibs $compiler_flags $wl-soname $wl$soname -o $lib' else _LT_TAGVAR(ld_shlibs, $1)=no fi ;; cygwin* | mingw* | pw32* | cegcc*) # _LT_TAGVAR(hardcode_libdir_flag_spec, $1) is actually meaningless, # as there is no search path for DLLs. _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='-L$libdir' _LT_TAGVAR(export_dynamic_flag_spec, $1)='$wl--export-all-symbols' _LT_TAGVAR(allow_undefined_flag, $1)=unsupported _LT_TAGVAR(always_export_symbols, $1)=no _LT_TAGVAR(enable_shared_with_static_runtimes, $1)=yes _LT_TAGVAR(export_symbols_cmds, $1)='$NM $libobjs $convenience | $global_symbol_pipe | $SED -e '\''/^[[BCDGRS]][[ ]]/s/.*[[ ]]\([[^ ]]*\)/\1 DATA/;s/^.*[[ ]]__nm__\([[^ ]]*\)[[ ]][[^ ]]*/\1 DATA/;/^I[[ ]]/d;/^[[AITW]][[ ]]/s/.* //'\'' | sort | uniq > $export_symbols' _LT_TAGVAR(exclude_expsyms, $1)=['[_]+GLOBAL_OFFSET_TABLE_|[_]+GLOBAL__[FID]_.*|[_]+head_[A-Za-z0-9_]+_dll|[A-Za-z0-9_]+_dll_iname'] if $LD --help 2>&1 | $GREP 'auto-import' > /dev/null; then _LT_TAGVAR(archive_cmds, $1)='$CC -shared $libobjs $deplibs $compiler_flags -o $output_objdir/$soname $wl--enable-auto-image-base -Xlinker --out-implib -Xlinker $lib' # If the export-symbols file already is a .def file, use it as # is; otherwise, prepend EXPORTS... _LT_TAGVAR(archive_expsym_cmds, $1)='if _LT_DLL_DEF_P([$export_symbols]); then cp $export_symbols $output_objdir/$soname.def; else echo EXPORTS > $output_objdir/$soname.def; cat $export_symbols >> $output_objdir/$soname.def; fi~ $CC -shared $output_objdir/$soname.def $libobjs $deplibs $compiler_flags -o $output_objdir/$soname $wl--enable-auto-image-base -Xlinker --out-implib -Xlinker $lib' else _LT_TAGVAR(ld_shlibs, $1)=no fi ;; haiku*) _LT_TAGVAR(archive_cmds, $1)='$CC -shared $libobjs $deplibs $compiler_flags $wl-soname $wl$soname -o $lib' _LT_TAGVAR(link_all_deplibs, $1)=yes ;; os2*) _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='-L$libdir' _LT_TAGVAR(hardcode_minus_L, $1)=yes _LT_TAGVAR(allow_undefined_flag, $1)=unsupported shrext_cmds=.dll _LT_TAGVAR(archive_cmds, $1)='$ECHO "LIBRARY ${soname%$shared_ext} INITINSTANCE TERMINSTANCE" > $output_objdir/$libname.def~ $ECHO "DESCRIPTION \"$libname\"" >> $output_objdir/$libname.def~ $ECHO "DATA MULTIPLE NONSHARED" >> $output_objdir/$libname.def~ $ECHO EXPORTS >> $output_objdir/$libname.def~ emxexp $libobjs | $SED /"_DLL_InitTerm"/d >> $output_objdir/$libname.def~ $CC -Zdll -Zcrtdll -o $output_objdir/$soname $libobjs $deplibs $compiler_flags $output_objdir/$libname.def~ emximp -o $lib $output_objdir/$libname.def' _LT_TAGVAR(archive_expsym_cmds, $1)='$ECHO "LIBRARY ${soname%$shared_ext} INITINSTANCE TERMINSTANCE" > $output_objdir/$libname.def~ $ECHO "DESCRIPTION \"$libname\"" >> $output_objdir/$libname.def~ $ECHO "DATA MULTIPLE NONSHARED" >> $output_objdir/$libname.def~ $ECHO EXPORTS >> $output_objdir/$libname.def~ prefix_cmds="$SED"~ if test EXPORTS = "`$SED 1q $export_symbols`"; then prefix_cmds="$prefix_cmds -e 1d"; fi~ prefix_cmds="$prefix_cmds -e \"s/^\(.*\)$/_\1/g\""~ cat $export_symbols | $prefix_cmds >> $output_objdir/$libname.def~ $CC -Zdll -Zcrtdll -o $output_objdir/$soname $libobjs $deplibs $compiler_flags $output_objdir/$libname.def~ emximp -o $lib $output_objdir/$libname.def' _LT_TAGVAR(old_archive_From_new_cmds, $1)='emximp -o $output_objdir/${libname}_dll.a $output_objdir/$libname.def' _LT_TAGVAR(enable_shared_with_static_runtimes, $1)=yes ;; interix[[3-9]]*) _LT_TAGVAR(hardcode_direct, $1)=no _LT_TAGVAR(hardcode_shlibpath_var, $1)=no _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='$wl-rpath,$libdir' _LT_TAGVAR(export_dynamic_flag_spec, $1)='$wl-E' # Hack: On Interix 3.x, we cannot compile PIC because of a broken gcc. # Instead, shared libraries are loaded at an image base (0x10000000 by # default) and relocated if they conflict, which is a slow very memory # consuming and fragmenting process. To avoid this, we pick a random, # 256 KiB-aligned image base between 0x50000000 and 0x6FFC0000 at link # time. Moving up from 0x10000000 also allows more sbrk(2) space. _LT_TAGVAR(archive_cmds, $1)='$CC -shared $pic_flag $libobjs $deplibs $compiler_flags $wl-h,$soname $wl--image-base,`expr ${RANDOM-$$} % 4096 / 2 \* 262144 + 1342177280` -o $lib' _LT_TAGVAR(archive_expsym_cmds, $1)='sed "s|^|_|" $export_symbols >$output_objdir/$soname.expsym~$CC -shared $pic_flag $libobjs $deplibs $compiler_flags $wl-h,$soname $wl--retain-symbols-file,$output_objdir/$soname.expsym $wl--image-base,`expr ${RANDOM-$$} % 4096 / 2 \* 262144 + 1342177280` -o $lib' ;; gnu* | linux* | tpf* | k*bsd*-gnu | kopensolaris*-gnu) tmp_diet=no if test linux-dietlibc = "$host_os"; then case $cc_basename in diet\ *) tmp_diet=yes;; # linux-dietlibc with static linking (!diet-dyn) esac fi if $LD --help 2>&1 | $EGREP ': supported targets:.* elf' > /dev/null \ && test no = "$tmp_diet" then tmp_addflag=' $pic_flag' tmp_sharedflag='-shared' case $cc_basename,$host_cpu in pgcc*) # Portland Group C compiler _LT_TAGVAR(whole_archive_flag_spec, $1)='$wl--whole-archive`for conv in $convenience\"\"; do test -n \"$conv\" && new_convenience=\"$new_convenience,$conv\"; done; func_echo_all \"$new_convenience\"` $wl--no-whole-archive' tmp_addflag=' $pic_flag' ;; pgf77* | pgf90* | pgf95* | pgfortran*) # Portland Group f77 and f90 compilers _LT_TAGVAR(whole_archive_flag_spec, $1)='$wl--whole-archive`for conv in $convenience\"\"; do test -n \"$conv\" && new_convenience=\"$new_convenience,$conv\"; done; func_echo_all \"$new_convenience\"` $wl--no-whole-archive' tmp_addflag=' $pic_flag -Mnomain' ;; ecc*,ia64* | icc*,ia64*) # Intel C compiler on ia64 tmp_addflag=' -i_dynamic' ;; efc*,ia64* | ifort*,ia64*) # Intel Fortran compiler on ia64 tmp_addflag=' -i_dynamic -nofor_main' ;; ifc* | ifort*) # Intel Fortran compiler tmp_addflag=' -nofor_main' ;; lf95*) # Lahey Fortran 8.1 _LT_TAGVAR(whole_archive_flag_spec, $1)= tmp_sharedflag='--shared' ;; nagfor*) # NAGFOR 5.3 tmp_sharedflag='-Wl,-shared' ;; xl[[cC]]* | bgxl[[cC]]* | mpixl[[cC]]*) # IBM XL C 8.0 on PPC (deal with xlf below) tmp_sharedflag='-qmkshrobj' tmp_addflag= ;; nvcc*) # Cuda Compiler Driver 2.2 _LT_TAGVAR(whole_archive_flag_spec, $1)='$wl--whole-archive`for conv in $convenience\"\"; do test -n \"$conv\" && new_convenience=\"$new_convenience,$conv\"; done; func_echo_all \"$new_convenience\"` $wl--no-whole-archive' _LT_TAGVAR(compiler_needs_object, $1)=yes ;; esac case `$CC -V 2>&1 | sed 5q` in *Sun\ C*) # Sun C 5.9 _LT_TAGVAR(whole_archive_flag_spec, $1)='$wl--whole-archive`new_convenience=; for conv in $convenience\"\"; do test -z \"$conv\" || new_convenience=\"$new_convenience,$conv\"; done; func_echo_all \"$new_convenience\"` $wl--no-whole-archive' _LT_TAGVAR(compiler_needs_object, $1)=yes tmp_sharedflag='-G' ;; *Sun\ F*) # Sun Fortran 8.3 tmp_sharedflag='-G' ;; esac _LT_TAGVAR(archive_cmds, $1)='$CC '"$tmp_sharedflag""$tmp_addflag"' $libobjs $deplibs $compiler_flags $wl-soname $wl$soname -o $lib' if test yes = "$supports_anon_versioning"; then _LT_TAGVAR(archive_expsym_cmds, $1)='echo "{ global:" > $output_objdir/$libname.ver~ cat $export_symbols | sed -e "s/\(.*\)/\1;/" >> $output_objdir/$libname.ver~ echo "local: *; };" >> $output_objdir/$libname.ver~ $CC '"$tmp_sharedflag""$tmp_addflag"' $libobjs $deplibs $compiler_flags $wl-soname $wl$soname $wl-version-script $wl$output_objdir/$libname.ver -o $lib' fi case $cc_basename in tcc*) _LT_TAGVAR(export_dynamic_flag_spec, $1)='-rdynamic' ;; xlf* | bgf* | bgxlf* | mpixlf*) # IBM XL Fortran 10.1 on PPC cannot create shared libs itself _LT_TAGVAR(whole_archive_flag_spec, $1)='--whole-archive$convenience --no-whole-archive' _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='$wl-rpath $wl$libdir' _LT_TAGVAR(archive_cmds, $1)='$LD -shared $libobjs $deplibs $linker_flags -soname $soname -o $lib' if test yes = "$supports_anon_versioning"; then _LT_TAGVAR(archive_expsym_cmds, $1)='echo "{ global:" > $output_objdir/$libname.ver~ cat $export_symbols | sed -e "s/\(.*\)/\1;/" >> $output_objdir/$libname.ver~ echo "local: *; };" >> $output_objdir/$libname.ver~ $LD -shared $libobjs $deplibs $linker_flags -soname $soname -version-script $output_objdir/$libname.ver -o $lib' fi ;; esac else _LT_TAGVAR(ld_shlibs, $1)=no fi ;; netbsd*) if echo __ELF__ | $CC -E - | $GREP __ELF__ >/dev/null; then _LT_TAGVAR(archive_cmds, $1)='$LD -Bshareable $libobjs $deplibs $linker_flags -o $lib' wlarc= else _LT_TAGVAR(archive_cmds, $1)='$CC -shared $pic_flag $libobjs $deplibs $compiler_flags $wl-soname $wl$soname -o $lib' _LT_TAGVAR(archive_expsym_cmds, $1)='$CC -shared $pic_flag $libobjs $deplibs $compiler_flags $wl-soname $wl$soname $wl-retain-symbols-file $wl$export_symbols -o $lib' fi ;; solaris*) if $LD -v 2>&1 | $GREP 'BFD 2\.8' > /dev/null; then _LT_TAGVAR(ld_shlibs, $1)=no cat <<_LT_EOF 1>&2 *** Warning: The releases 2.8.* of the GNU linker cannot reliably *** create shared libraries on Solaris systems. Therefore, libtool *** is disabling shared libraries support. We urge you to upgrade GNU *** binutils to release 2.9.1 or newer. Another option is to modify *** your PATH or compiler configuration so that the native linker is *** used, and then restart. _LT_EOF elif $LD --help 2>&1 | $GREP ': supported targets:.* elf' > /dev/null; then _LT_TAGVAR(archive_cmds, $1)='$CC -shared $pic_flag $libobjs $deplibs $compiler_flags $wl-soname $wl$soname -o $lib' _LT_TAGVAR(archive_expsym_cmds, $1)='$CC -shared $pic_flag $libobjs $deplibs $compiler_flags $wl-soname $wl$soname $wl-retain-symbols-file $wl$export_symbols -o $lib' else _LT_TAGVAR(ld_shlibs, $1)=no fi ;; sysv5* | sco3.2v5* | sco5v6* | unixware* | OpenUNIX*) case `$LD -v 2>&1` in *\ [[01]].* | *\ 2.[[0-9]].* | *\ 2.1[[0-5]].*) _LT_TAGVAR(ld_shlibs, $1)=no cat <<_LT_EOF 1>&2 *** Warning: Releases of the GNU linker prior to 2.16.91.0.3 cannot *** reliably create shared libraries on SCO systems. Therefore, libtool *** is disabling shared libraries support. We urge you to upgrade GNU *** binutils to release 2.16.91.0.3 or newer. Another option is to modify *** your PATH or compiler configuration so that the native linker is *** used, and then restart. _LT_EOF ;; *) # For security reasons, it is highly recommended that you always # use absolute paths for naming shared libraries, and exclude the # DT_RUNPATH tag from executables and libraries. But doing so # requires that you compile everything twice, which is a pain. if $LD --help 2>&1 | $GREP ': supported targets:.* elf' > /dev/null; then _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='$wl-rpath $wl$libdir' _LT_TAGVAR(archive_cmds, $1)='$CC -shared $libobjs $deplibs $compiler_flags $wl-soname $wl$soname -o $lib' _LT_TAGVAR(archive_expsym_cmds, $1)='$CC -shared $libobjs $deplibs $compiler_flags $wl-soname $wl$soname $wl-retain-symbols-file $wl$export_symbols -o $lib' else _LT_TAGVAR(ld_shlibs, $1)=no fi ;; esac ;; sunos4*) _LT_TAGVAR(archive_cmds, $1)='$LD -assert pure-text -Bshareable -o $lib $libobjs $deplibs $linker_flags' wlarc= _LT_TAGVAR(hardcode_direct, $1)=yes _LT_TAGVAR(hardcode_shlibpath_var, $1)=no ;; *) if $LD --help 2>&1 | $GREP ': supported targets:.* elf' > /dev/null; then _LT_TAGVAR(archive_cmds, $1)='$CC -shared $pic_flag $libobjs $deplibs $compiler_flags $wl-soname $wl$soname -o $lib' _LT_TAGVAR(archive_expsym_cmds, $1)='$CC -shared $pic_flag $libobjs $deplibs $compiler_flags $wl-soname $wl$soname $wl-retain-symbols-file $wl$export_symbols -o $lib' else _LT_TAGVAR(ld_shlibs, $1)=no fi ;; esac if test no = "$_LT_TAGVAR(ld_shlibs, $1)"; then runpath_var= _LT_TAGVAR(hardcode_libdir_flag_spec, $1)= _LT_TAGVAR(export_dynamic_flag_spec, $1)= _LT_TAGVAR(whole_archive_flag_spec, $1)= fi else # PORTME fill in a description of your system's linker (not GNU ld) case $host_os in aix3*) _LT_TAGVAR(allow_undefined_flag, $1)=unsupported _LT_TAGVAR(always_export_symbols, $1)=yes _LT_TAGVAR(archive_expsym_cmds, $1)='$LD -o $output_objdir/$soname $libobjs $deplibs $linker_flags -bE:$export_symbols -T512 -H512 -bM:SRE~$AR $AR_FLAGS $lib $output_objdir/$soname' # Note: this linker hardcodes the directories in LIBPATH if there # are no directories specified by -L. _LT_TAGVAR(hardcode_minus_L, $1)=yes if test yes = "$GCC" && test -z "$lt_prog_compiler_static"; then # Neither direct hardcoding nor static linking is supported with a # broken collect2. _LT_TAGVAR(hardcode_direct, $1)=unsupported fi ;; aix[[4-9]]*) if test ia64 = "$host_cpu"; then # On IA64, the linker does run time linking by default, so we don't # have to do anything special. aix_use_runtimelinking=no exp_sym_flag='-Bexport' no_entry_flag= else # If we're using GNU nm, then we don't want the "-C" option. # -C means demangle to GNU nm, but means don't demangle to AIX nm. # Without the "-l" option, or with the "-B" option, AIX nm treats # weak defined symbols like other global defined symbols, whereas # GNU nm marks them as "W". # While the 'weak' keyword is ignored in the Export File, we need # it in the Import File for the 'aix-soname' feature, so we have # to replace the "-B" option with "-P" for AIX nm. if $NM -V 2>&1 | $GREP 'GNU' > /dev/null; then _LT_TAGVAR(export_symbols_cmds, $1)='$NM -Bpg $libobjs $convenience | awk '\''{ if (((\$ 2 == "T") || (\$ 2 == "D") || (\$ 2 == "B") || (\$ 2 == "W")) && ([substr](\$ 3,1,1) != ".")) { if (\$ 2 == "W") { print \$ 3 " weak" } else { print \$ 3 } } }'\'' | sort -u > $export_symbols' else _LT_TAGVAR(export_symbols_cmds, $1)='`func_echo_all $NM | $SED -e '\''s/B\([[^B]]*\)$/P\1/'\''` -PCpgl $libobjs $convenience | awk '\''{ if (((\$ 2 == "T") || (\$ 2 == "D") || (\$ 2 == "B") || (\$ 2 == "W") || (\$ 2 == "V") || (\$ 2 == "Z")) && ([substr](\$ 1,1,1) != ".")) { if ((\$ 2 == "W") || (\$ 2 == "V") || (\$ 2 == "Z")) { print \$ 1 " weak" } else { print \$ 1 } } }'\'' | sort -u > $export_symbols' fi aix_use_runtimelinking=no # Test if we are trying to use run time linking or normal # AIX style linking. If -brtl is somewhere in LDFLAGS, we # have runtime linking enabled, and use it for executables. # For shared libraries, we enable/disable runtime linking # depending on the kind of the shared library created - # when "with_aix_soname,aix_use_runtimelinking" is: # "aix,no" lib.a(lib.so.V) shared, rtl:no, for executables # "aix,yes" lib.so shared, rtl:yes, for executables # lib.a static archive # "both,no" lib.so.V(shr.o) shared, rtl:yes # lib.a(lib.so.V) shared, rtl:no, for executables # "both,yes" lib.so.V(shr.o) shared, rtl:yes, for executables # lib.a(lib.so.V) shared, rtl:no # "svr4,*" lib.so.V(shr.o) shared, rtl:yes, for executables # lib.a static archive case $host_os in aix4.[[23]]|aix4.[[23]].*|aix[[5-9]]*) for ld_flag in $LDFLAGS; do if (test x-brtl = "x$ld_flag" || test x-Wl,-brtl = "x$ld_flag"); then aix_use_runtimelinking=yes break fi done if test svr4,no = "$with_aix_soname,$aix_use_runtimelinking"; then # With aix-soname=svr4, we create the lib.so.V shared archives only, # so we don't have lib.a shared libs to link our executables. # We have to force runtime linking in this case. aix_use_runtimelinking=yes LDFLAGS="$LDFLAGS -Wl,-brtl" fi ;; esac exp_sym_flag='-bexport' no_entry_flag='-bnoentry' fi # When large executables or shared objects are built, AIX ld can # have problems creating the table of contents. If linking a library # or program results in "error TOC overflow" add -mminimal-toc to # CXXFLAGS/CFLAGS for g++/gcc. In the cases where that is not # enough to fix the problem, add -Wl,-bbigtoc to LDFLAGS. _LT_TAGVAR(archive_cmds, $1)='' _LT_TAGVAR(hardcode_direct, $1)=yes _LT_TAGVAR(hardcode_direct_absolute, $1)=yes _LT_TAGVAR(hardcode_libdir_separator, $1)=':' _LT_TAGVAR(link_all_deplibs, $1)=yes _LT_TAGVAR(file_list_spec, $1)='$wl-f,' case $with_aix_soname,$aix_use_runtimelinking in aix,*) ;; # traditional, no import file svr4,* | *,yes) # use import file # The Import File defines what to hardcode. _LT_TAGVAR(hardcode_direct, $1)=no _LT_TAGVAR(hardcode_direct_absolute, $1)=no ;; esac if test yes = "$GCC"; then case $host_os in aix4.[[012]]|aix4.[[012]].*) # We only want to do this on AIX 4.2 and lower, the check # below for broken collect2 doesn't work under 4.3+ collect2name=`$CC -print-prog-name=collect2` if test -f "$collect2name" && strings "$collect2name" | $GREP resolve_lib_name >/dev/null then # We have reworked collect2 : else # We have old collect2 _LT_TAGVAR(hardcode_direct, $1)=unsupported # It fails to find uninstalled libraries when the uninstalled # path is not listed in the libpath. Setting hardcode_minus_L # to unsupported forces relinking _LT_TAGVAR(hardcode_minus_L, $1)=yes _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='-L$libdir' _LT_TAGVAR(hardcode_libdir_separator, $1)= fi ;; esac shared_flag='-shared' if test yes = "$aix_use_runtimelinking"; then shared_flag="$shared_flag "'$wl-G' fi # Need to ensure runtime linking is disabled for the traditional # shared library, or the linker may eventually find shared libraries # /with/ Import File - we do not want to mix them. shared_flag_aix='-shared' shared_flag_svr4='-shared $wl-G' else # not using gcc if test ia64 = "$host_cpu"; then # VisualAge C++, Version 5.5 for AIX 5L for IA-64, Beta 3 Release # chokes on -Wl,-G. The following line is correct: shared_flag='-G' else if test yes = "$aix_use_runtimelinking"; then shared_flag='$wl-G' else shared_flag='$wl-bM:SRE' fi shared_flag_aix='$wl-bM:SRE' shared_flag_svr4='$wl-G' fi fi _LT_TAGVAR(export_dynamic_flag_spec, $1)='$wl-bexpall' # It seems that -bexpall does not export symbols beginning with # underscore (_), so it is better to generate a list of symbols to export. _LT_TAGVAR(always_export_symbols, $1)=yes if test aix,yes = "$with_aix_soname,$aix_use_runtimelinking"; then # Warning - without using the other runtime loading flags (-brtl), # -berok will link without error, but may produce a broken library. _LT_TAGVAR(allow_undefined_flag, $1)='-berok' # Determine the default libpath from the value encoded in an # empty executable. _LT_SYS_MODULE_PATH_AIX([$1]) _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='$wl-blibpath:$libdir:'"$aix_libpath" _LT_TAGVAR(archive_expsym_cmds, $1)='$CC -o $output_objdir/$soname $libobjs $deplibs $wl'$no_entry_flag' $compiler_flags `if test -n "$allow_undefined_flag"; then func_echo_all "$wl$allow_undefined_flag"; else :; fi` $wl'$exp_sym_flag:\$export_symbols' '$shared_flag else if test ia64 = "$host_cpu"; then _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='$wl-R $libdir:/usr/lib:/lib' _LT_TAGVAR(allow_undefined_flag, $1)="-z nodefs" _LT_TAGVAR(archive_expsym_cmds, $1)="\$CC $shared_flag"' -o $output_objdir/$soname $libobjs $deplibs '"\$wl$no_entry_flag"' $compiler_flags $wl$allow_undefined_flag '"\$wl$exp_sym_flag:\$export_symbols" else # Determine the default libpath from the value encoded in an # empty executable. _LT_SYS_MODULE_PATH_AIX([$1]) _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='$wl-blibpath:$libdir:'"$aix_libpath" # Warning - without using the other run time loading flags, # -berok will link without error, but may produce a broken library. _LT_TAGVAR(no_undefined_flag, $1)=' $wl-bernotok' _LT_TAGVAR(allow_undefined_flag, $1)=' $wl-berok' if test yes = "$with_gnu_ld"; then # We only use this code for GNU lds that support --whole-archive. _LT_TAGVAR(whole_archive_flag_spec, $1)='$wl--whole-archive$convenience $wl--no-whole-archive' else # Exported symbols can be pulled into shared objects from archives _LT_TAGVAR(whole_archive_flag_spec, $1)='$convenience' fi _LT_TAGVAR(archive_cmds_need_lc, $1)=yes _LT_TAGVAR(archive_expsym_cmds, $1)='$RM -r $output_objdir/$realname.d~$MKDIR $output_objdir/$realname.d' # -brtl affects multiple linker settings, -berok does not and is overridden later compiler_flags_filtered='`func_echo_all "$compiler_flags " | $SED -e "s%-brtl\\([[, ]]\\)%-berok\\1%g"`' if test svr4 != "$with_aix_soname"; then # This is similar to how AIX traditionally builds its shared libraries. _LT_TAGVAR(archive_expsym_cmds, $1)="$_LT_TAGVAR(archive_expsym_cmds, $1)"'~$CC '$shared_flag_aix' -o $output_objdir/$realname.d/$soname $libobjs $deplibs $wl-bnoentry '$compiler_flags_filtered'$wl-bE:$export_symbols$allow_undefined_flag~$AR $AR_FLAGS $output_objdir/$libname$release.a $output_objdir/$realname.d/$soname' fi if test aix != "$with_aix_soname"; then _LT_TAGVAR(archive_expsym_cmds, $1)="$_LT_TAGVAR(archive_expsym_cmds, $1)"'~$CC '$shared_flag_svr4' -o $output_objdir/$realname.d/$shared_archive_member_spec.o $libobjs $deplibs $wl-bnoentry '$compiler_flags_filtered'$wl-bE:$export_symbols$allow_undefined_flag~$STRIP -e $output_objdir/$realname.d/$shared_archive_member_spec.o~( func_echo_all "#! $soname($shared_archive_member_spec.o)"; if test shr_64 = "$shared_archive_member_spec"; then func_echo_all "# 64"; else func_echo_all "# 32"; fi; cat $export_symbols ) > $output_objdir/$realname.d/$shared_archive_member_spec.imp~$AR $AR_FLAGS $output_objdir/$soname $output_objdir/$realname.d/$shared_archive_member_spec.o $output_objdir/$realname.d/$shared_archive_member_spec.imp' else # used by -dlpreopen to get the symbols _LT_TAGVAR(archive_expsym_cmds, $1)="$_LT_TAGVAR(archive_expsym_cmds, $1)"'~$MV $output_objdir/$realname.d/$soname $output_objdir' fi _LT_TAGVAR(archive_expsym_cmds, $1)="$_LT_TAGVAR(archive_expsym_cmds, $1)"'~$RM -r $output_objdir/$realname.d' fi fi ;; amigaos*) case $host_cpu in powerpc) # see comment about AmigaOS4 .so support _LT_TAGVAR(archive_cmds, $1)='$CC -shared $libobjs $deplibs $compiler_flags $wl-soname $wl$soname -o $lib' _LT_TAGVAR(archive_expsym_cmds, $1)='' ;; m68k) _LT_TAGVAR(archive_cmds, $1)='$RM $output_objdir/a2ixlibrary.data~$ECHO "#define NAME $libname" > $output_objdir/a2ixlibrary.data~$ECHO "#define LIBRARY_ID 1" >> $output_objdir/a2ixlibrary.data~$ECHO "#define VERSION $major" >> $output_objdir/a2ixlibrary.data~$ECHO "#define REVISION $revision" >> $output_objdir/a2ixlibrary.data~$AR $AR_FLAGS $lib $libobjs~$RANLIB $lib~(cd $output_objdir && a2ixlibrary -32)' _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='-L$libdir' _LT_TAGVAR(hardcode_minus_L, $1)=yes ;; esac ;; bsdi[[45]]*) _LT_TAGVAR(export_dynamic_flag_spec, $1)=-rdynamic ;; cygwin* | mingw* | pw32* | cegcc*) # When not using gcc, we currently assume that we are using # Microsoft Visual C++. # hardcode_libdir_flag_spec is actually meaningless, as there is # no search path for DLLs. case $cc_basename in cl*) # Native MSVC _LT_TAGVAR(hardcode_libdir_flag_spec, $1)=' ' _LT_TAGVAR(allow_undefined_flag, $1)=unsupported _LT_TAGVAR(always_export_symbols, $1)=yes _LT_TAGVAR(file_list_spec, $1)='@' # Tell ltmain to make .lib files, not .a files. libext=lib # Tell ltmain to make .dll files, not .so files. shrext_cmds=.dll # FIXME: Setting linknames here is a bad hack. _LT_TAGVAR(archive_cmds, $1)='$CC -o $output_objdir/$soname $libobjs $compiler_flags $deplibs -Wl,-DLL,-IMPLIB:"$tool_output_objdir$libname.dll.lib"~linknames=' _LT_TAGVAR(archive_expsym_cmds, $1)='if _LT_DLL_DEF_P([$export_symbols]); then cp "$export_symbols" "$output_objdir/$soname.def"; echo "$tool_output_objdir$soname.def" > "$output_objdir/$soname.exp"; else $SED -e '\''s/^/-link -EXPORT:/'\'' < $export_symbols > $output_objdir/$soname.exp; fi~ $CC -o $tool_output_objdir$soname $libobjs $compiler_flags $deplibs "@$tool_output_objdir$soname.exp" -Wl,-DLL,-IMPLIB:"$tool_output_objdir$libname.dll.lib"~ linknames=' # The linker will not automatically build a static lib if we build a DLL. # _LT_TAGVAR(old_archive_from_new_cmds, $1)='true' _LT_TAGVAR(enable_shared_with_static_runtimes, $1)=yes _LT_TAGVAR(exclude_expsyms, $1)='_NULL_IMPORT_DESCRIPTOR|_IMPORT_DESCRIPTOR_.*' _LT_TAGVAR(export_symbols_cmds, $1)='$NM $libobjs $convenience | $global_symbol_pipe | $SED -e '\''/^[[BCDGRS]][[ ]]/s/.*[[ ]]\([[^ ]]*\)/\1,DATA/'\'' | $SED -e '\''/^[[AITW]][[ ]]/s/.*[[ ]]//'\'' | sort | uniq > $export_symbols' # Don't use ranlib _LT_TAGVAR(old_postinstall_cmds, $1)='chmod 644 $oldlib' _LT_TAGVAR(postlink_cmds, $1)='lt_outputfile="@OUTPUT@"~ lt_tool_outputfile="@TOOL_OUTPUT@"~ case $lt_outputfile in *.exe|*.EXE) ;; *) lt_outputfile=$lt_outputfile.exe lt_tool_outputfile=$lt_tool_outputfile.exe ;; esac~ if test : != "$MANIFEST_TOOL" && test -f "$lt_outputfile.manifest"; then $MANIFEST_TOOL -manifest "$lt_tool_outputfile.manifest" -outputresource:"$lt_tool_outputfile" || exit 1; $RM "$lt_outputfile.manifest"; fi' ;; *) # Assume MSVC wrapper _LT_TAGVAR(hardcode_libdir_flag_spec, $1)=' ' _LT_TAGVAR(allow_undefined_flag, $1)=unsupported # Tell ltmain to make .lib files, not .a files. libext=lib # Tell ltmain to make .dll files, not .so files. shrext_cmds=.dll # FIXME: Setting linknames here is a bad hack. _LT_TAGVAR(archive_cmds, $1)='$CC -o $lib $libobjs $compiler_flags `func_echo_all "$deplibs" | $SED '\''s/ -lc$//'\''` -link -dll~linknames=' # The linker will automatically build a .lib file if we build a DLL. _LT_TAGVAR(old_archive_from_new_cmds, $1)='true' # FIXME: Should let the user specify the lib program. _LT_TAGVAR(old_archive_cmds, $1)='lib -OUT:$oldlib$oldobjs$old_deplibs' _LT_TAGVAR(enable_shared_with_static_runtimes, $1)=yes ;; esac ;; darwin* | rhapsody*) _LT_DARWIN_LINKER_FEATURES($1) ;; dgux*) _LT_TAGVAR(archive_cmds, $1)='$LD -G -h $soname -o $lib $libobjs $deplibs $linker_flags' _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='-L$libdir' _LT_TAGVAR(hardcode_shlibpath_var, $1)=no ;; # FreeBSD 2.2.[012] allows us to include c++rt0.o to get C++ constructor # support. Future versions do this automatically, but an explicit c++rt0.o # does not break anything, and helps significantly (at the cost of a little # extra space). freebsd2.2*) _LT_TAGVAR(archive_cmds, $1)='$LD -Bshareable -o $lib $libobjs $deplibs $linker_flags /usr/lib/c++rt0.o' _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='-R$libdir' _LT_TAGVAR(hardcode_direct, $1)=yes _LT_TAGVAR(hardcode_shlibpath_var, $1)=no ;; # Unfortunately, older versions of FreeBSD 2 do not have this feature. freebsd2.*) _LT_TAGVAR(archive_cmds, $1)='$LD -Bshareable -o $lib $libobjs $deplibs $linker_flags' _LT_TAGVAR(hardcode_direct, $1)=yes _LT_TAGVAR(hardcode_minus_L, $1)=yes _LT_TAGVAR(hardcode_shlibpath_var, $1)=no ;; # FreeBSD 3 and greater uses gcc -shared to do shared libraries. freebsd* | dragonfly*) _LT_TAGVAR(archive_cmds, $1)='$CC -shared $pic_flag -o $lib $libobjs $deplibs $compiler_flags' _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='-R$libdir' _LT_TAGVAR(hardcode_direct, $1)=yes _LT_TAGVAR(hardcode_shlibpath_var, $1)=no ;; hpux9*) if test yes = "$GCC"; then _LT_TAGVAR(archive_cmds, $1)='$RM $output_objdir/$soname~$CC -shared $pic_flag $wl+b $wl$install_libdir -o $output_objdir/$soname $libobjs $deplibs $compiler_flags~test "x$output_objdir/$soname" = "x$lib" || mv $output_objdir/$soname $lib' else _LT_TAGVAR(archive_cmds, $1)='$RM $output_objdir/$soname~$LD -b +b $install_libdir -o $output_objdir/$soname $libobjs $deplibs $linker_flags~test "x$output_objdir/$soname" = "x$lib" || mv $output_objdir/$soname $lib' fi _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='$wl+b $wl$libdir' _LT_TAGVAR(hardcode_libdir_separator, $1)=: _LT_TAGVAR(hardcode_direct, $1)=yes # hardcode_minus_L: Not really in the search PATH, # but as the default location of the library. _LT_TAGVAR(hardcode_minus_L, $1)=yes _LT_TAGVAR(export_dynamic_flag_spec, $1)='$wl-E' ;; hpux10*) if test yes,no = "$GCC,$with_gnu_ld"; then _LT_TAGVAR(archive_cmds, $1)='$CC -shared $pic_flag $wl+h $wl$soname $wl+b $wl$install_libdir -o $lib $libobjs $deplibs $compiler_flags' else _LT_TAGVAR(archive_cmds, $1)='$LD -b +h $soname +b $install_libdir -o $lib $libobjs $deplibs $linker_flags' fi if test no = "$with_gnu_ld"; then _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='$wl+b $wl$libdir' _LT_TAGVAR(hardcode_libdir_separator, $1)=: _LT_TAGVAR(hardcode_direct, $1)=yes _LT_TAGVAR(hardcode_direct_absolute, $1)=yes _LT_TAGVAR(export_dynamic_flag_spec, $1)='$wl-E' # hardcode_minus_L: Not really in the search PATH, # but as the default location of the library. _LT_TAGVAR(hardcode_minus_L, $1)=yes fi ;; hpux11*) if test yes,no = "$GCC,$with_gnu_ld"; then case $host_cpu in hppa*64*) _LT_TAGVAR(archive_cmds, $1)='$CC -shared $wl+h $wl$soname -o $lib $libobjs $deplibs $compiler_flags' ;; ia64*) _LT_TAGVAR(archive_cmds, $1)='$CC -shared $pic_flag $wl+h $wl$soname $wl+nodefaultrpath -o $lib $libobjs $deplibs $compiler_flags' ;; *) _LT_TAGVAR(archive_cmds, $1)='$CC -shared $pic_flag $wl+h $wl$soname $wl+b $wl$install_libdir -o $lib $libobjs $deplibs $compiler_flags' ;; esac else case $host_cpu in hppa*64*) _LT_TAGVAR(archive_cmds, $1)='$CC -b $wl+h $wl$soname -o $lib $libobjs $deplibs $compiler_flags' ;; ia64*) _LT_TAGVAR(archive_cmds, $1)='$CC -b $wl+h $wl$soname $wl+nodefaultrpath -o $lib $libobjs $deplibs $compiler_flags' ;; *) m4_if($1, [], [ # Older versions of the 11.00 compiler do not understand -b yet # (HP92453-01 A.11.01.20 doesn't, HP92453-01 B.11.X.35175-35176.GP does) _LT_LINKER_OPTION([if $CC understands -b], _LT_TAGVAR(lt_cv_prog_compiler__b, $1), [-b], [_LT_TAGVAR(archive_cmds, $1)='$CC -b $wl+h $wl$soname $wl+b $wl$install_libdir -o $lib $libobjs $deplibs $compiler_flags'], [_LT_TAGVAR(archive_cmds, $1)='$LD -b +h $soname +b $install_libdir -o $lib $libobjs $deplibs $linker_flags'])], [_LT_TAGVAR(archive_cmds, $1)='$CC -b $wl+h $wl$soname $wl+b $wl$install_libdir -o $lib $libobjs $deplibs $compiler_flags']) ;; esac fi if test no = "$with_gnu_ld"; then _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='$wl+b $wl$libdir' _LT_TAGVAR(hardcode_libdir_separator, $1)=: case $host_cpu in hppa*64*|ia64*) _LT_TAGVAR(hardcode_direct, $1)=no _LT_TAGVAR(hardcode_shlibpath_var, $1)=no ;; *) _LT_TAGVAR(hardcode_direct, $1)=yes _LT_TAGVAR(hardcode_direct_absolute, $1)=yes _LT_TAGVAR(export_dynamic_flag_spec, $1)='$wl-E' # hardcode_minus_L: Not really in the search PATH, # but as the default location of the library. _LT_TAGVAR(hardcode_minus_L, $1)=yes ;; esac fi ;; irix5* | irix6* | nonstopux*) if test yes = "$GCC"; then _LT_TAGVAR(archive_cmds, $1)='$CC -shared $pic_flag $libobjs $deplibs $compiler_flags $wl-soname $wl$soname `test -n "$verstring" && func_echo_all "$wl-set_version $wl$verstring"` $wl-update_registry $wl$output_objdir/so_locations -o $lib' # Try to use the -exported_symbol ld option, if it does not # work, assume that -exports_file does not work either and # implicitly export all symbols. # This should be the same for all languages, so no per-tag cache variable. AC_CACHE_CHECK([whether the $host_os linker accepts -exported_symbol], [lt_cv_irix_exported_symbol], [save_LDFLAGS=$LDFLAGS LDFLAGS="$LDFLAGS -shared $wl-exported_symbol ${wl}foo $wl-update_registry $wl/dev/null" AC_LINK_IFELSE( [AC_LANG_SOURCE( [AC_LANG_CASE([C], [[int foo (void) { return 0; }]], [C++], [[int foo (void) { return 0; }]], [Fortran 77], [[ subroutine foo end]], [Fortran], [[ subroutine foo end]])])], [lt_cv_irix_exported_symbol=yes], [lt_cv_irix_exported_symbol=no]) LDFLAGS=$save_LDFLAGS]) if test yes = "$lt_cv_irix_exported_symbol"; then _LT_TAGVAR(archive_expsym_cmds, $1)='$CC -shared $pic_flag $libobjs $deplibs $compiler_flags $wl-soname $wl$soname `test -n "$verstring" && func_echo_all "$wl-set_version $wl$verstring"` $wl-update_registry $wl$output_objdir/so_locations $wl-exports_file $wl$export_symbols -o $lib' fi else _LT_TAGVAR(archive_cmds, $1)='$CC -shared $libobjs $deplibs $compiler_flags -soname $soname `test -n "$verstring" && func_echo_all "-set_version $verstring"` -update_registry $output_objdir/so_locations -o $lib' _LT_TAGVAR(archive_expsym_cmds, $1)='$CC -shared $libobjs $deplibs $compiler_flags -soname $soname `test -n "$verstring" && func_echo_all "-set_version $verstring"` -update_registry $output_objdir/so_locations -exports_file $export_symbols -o $lib' fi _LT_TAGVAR(archive_cmds_need_lc, $1)='no' _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='$wl-rpath $wl$libdir' _LT_TAGVAR(hardcode_libdir_separator, $1)=: _LT_TAGVAR(inherit_rpath, $1)=yes _LT_TAGVAR(link_all_deplibs, $1)=yes ;; linux*) case $cc_basename in tcc*) # Fabrice Bellard et al's Tiny C Compiler _LT_TAGVAR(ld_shlibs, $1)=yes _LT_TAGVAR(archive_cmds, $1)='$CC -shared $pic_flag -o $lib $libobjs $deplibs $compiler_flags' ;; esac ;; netbsd*) if echo __ELF__ | $CC -E - | $GREP __ELF__ >/dev/null; then _LT_TAGVAR(archive_cmds, $1)='$LD -Bshareable -o $lib $libobjs $deplibs $linker_flags' # a.out else _LT_TAGVAR(archive_cmds, $1)='$LD -shared -o $lib $libobjs $deplibs $linker_flags' # ELF fi _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='-R$libdir' _LT_TAGVAR(hardcode_direct, $1)=yes _LT_TAGVAR(hardcode_shlibpath_var, $1)=no ;; newsos6) _LT_TAGVAR(archive_cmds, $1)='$LD -G -h $soname -o $lib $libobjs $deplibs $linker_flags' _LT_TAGVAR(hardcode_direct, $1)=yes _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='$wl-rpath $wl$libdir' _LT_TAGVAR(hardcode_libdir_separator, $1)=: _LT_TAGVAR(hardcode_shlibpath_var, $1)=no ;; *nto* | *qnx*) ;; openbsd* | bitrig*) if test -f /usr/libexec/ld.so; then _LT_TAGVAR(hardcode_direct, $1)=yes _LT_TAGVAR(hardcode_shlibpath_var, $1)=no _LT_TAGVAR(hardcode_direct_absolute, $1)=yes if test -z "`echo __ELF__ | $CC -E - | $GREP __ELF__`"; then _LT_TAGVAR(archive_cmds, $1)='$CC -shared $pic_flag -o $lib $libobjs $deplibs $compiler_flags' _LT_TAGVAR(archive_expsym_cmds, $1)='$CC -shared $pic_flag -o $lib $libobjs $deplibs $compiler_flags $wl-retain-symbols-file,$export_symbols' _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='$wl-rpath,$libdir' _LT_TAGVAR(export_dynamic_flag_spec, $1)='$wl-E' else _LT_TAGVAR(archive_cmds, $1)='$CC -shared $pic_flag -o $lib $libobjs $deplibs $compiler_flags' _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='$wl-rpath,$libdir' fi else _LT_TAGVAR(ld_shlibs, $1)=no fi ;; os2*) _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='-L$libdir' _LT_TAGVAR(hardcode_minus_L, $1)=yes _LT_TAGVAR(allow_undefined_flag, $1)=unsupported shrext_cmds=.dll _LT_TAGVAR(archive_cmds, $1)='$ECHO "LIBRARY ${soname%$shared_ext} INITINSTANCE TERMINSTANCE" > $output_objdir/$libname.def~ $ECHO "DESCRIPTION \"$libname\"" >> $output_objdir/$libname.def~ $ECHO "DATA MULTIPLE NONSHARED" >> $output_objdir/$libname.def~ $ECHO EXPORTS >> $output_objdir/$libname.def~ emxexp $libobjs | $SED /"_DLL_InitTerm"/d >> $output_objdir/$libname.def~ $CC -Zdll -Zcrtdll -o $output_objdir/$soname $libobjs $deplibs $compiler_flags $output_objdir/$libname.def~ emximp -o $lib $output_objdir/$libname.def' _LT_TAGVAR(archive_expsym_cmds, $1)='$ECHO "LIBRARY ${soname%$shared_ext} INITINSTANCE TERMINSTANCE" > $output_objdir/$libname.def~ $ECHO "DESCRIPTION \"$libname\"" >> $output_objdir/$libname.def~ $ECHO "DATA MULTIPLE NONSHARED" >> $output_objdir/$libname.def~ $ECHO EXPORTS >> $output_objdir/$libname.def~ prefix_cmds="$SED"~ if test EXPORTS = "`$SED 1q $export_symbols`"; then prefix_cmds="$prefix_cmds -e 1d"; fi~ prefix_cmds="$prefix_cmds -e \"s/^\(.*\)$/_\1/g\""~ cat $export_symbols | $prefix_cmds >> $output_objdir/$libname.def~ $CC -Zdll -Zcrtdll -o $output_objdir/$soname $libobjs $deplibs $compiler_flags $output_objdir/$libname.def~ emximp -o $lib $output_objdir/$libname.def' _LT_TAGVAR(old_archive_From_new_cmds, $1)='emximp -o $output_objdir/${libname}_dll.a $output_objdir/$libname.def' _LT_TAGVAR(enable_shared_with_static_runtimes, $1)=yes ;; osf3*) if test yes = "$GCC"; then _LT_TAGVAR(allow_undefined_flag, $1)=' $wl-expect_unresolved $wl\*' _LT_TAGVAR(archive_cmds, $1)='$CC -shared$allow_undefined_flag $libobjs $deplibs $compiler_flags $wl-soname $wl$soname `test -n "$verstring" && func_echo_all "$wl-set_version $wl$verstring"` $wl-update_registry $wl$output_objdir/so_locations -o $lib' else _LT_TAGVAR(allow_undefined_flag, $1)=' -expect_unresolved \*' _LT_TAGVAR(archive_cmds, $1)='$CC -shared$allow_undefined_flag $libobjs $deplibs $compiler_flags -soname $soname `test -n "$verstring" && func_echo_all "-set_version $verstring"` -update_registry $output_objdir/so_locations -o $lib' fi _LT_TAGVAR(archive_cmds_need_lc, $1)='no' _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='$wl-rpath $wl$libdir' _LT_TAGVAR(hardcode_libdir_separator, $1)=: ;; osf4* | osf5*) # as osf3* with the addition of -msym flag if test yes = "$GCC"; then _LT_TAGVAR(allow_undefined_flag, $1)=' $wl-expect_unresolved $wl\*' _LT_TAGVAR(archive_cmds, $1)='$CC -shared$allow_undefined_flag $pic_flag $libobjs $deplibs $compiler_flags $wl-msym $wl-soname $wl$soname `test -n "$verstring" && func_echo_all "$wl-set_version $wl$verstring"` $wl-update_registry $wl$output_objdir/so_locations -o $lib' _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='$wl-rpath $wl$libdir' else _LT_TAGVAR(allow_undefined_flag, $1)=' -expect_unresolved \*' _LT_TAGVAR(archive_cmds, $1)='$CC -shared$allow_undefined_flag $libobjs $deplibs $compiler_flags -msym -soname $soname `test -n "$verstring" && func_echo_all "-set_version $verstring"` -update_registry $output_objdir/so_locations -o $lib' _LT_TAGVAR(archive_expsym_cmds, $1)='for i in `cat $export_symbols`; do printf "%s %s\\n" -exported_symbol "\$i" >> $lib.exp; done; printf "%s\\n" "-hidden">> $lib.exp~ $CC -shared$allow_undefined_flag $wl-input $wl$lib.exp $compiler_flags $libobjs $deplibs -soname $soname `test -n "$verstring" && $ECHO "-set_version $verstring"` -update_registry $output_objdir/so_locations -o $lib~$RM $lib.exp' # Both c and cxx compiler support -rpath directly _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='-rpath $libdir' fi _LT_TAGVAR(archive_cmds_need_lc, $1)='no' _LT_TAGVAR(hardcode_libdir_separator, $1)=: ;; solaris*) _LT_TAGVAR(no_undefined_flag, $1)=' -z defs' if test yes = "$GCC"; then wlarc='$wl' _LT_TAGVAR(archive_cmds, $1)='$CC -shared $pic_flag $wl-z ${wl}text $wl-h $wl$soname -o $lib $libobjs $deplibs $compiler_flags' _LT_TAGVAR(archive_expsym_cmds, $1)='echo "{ global:" > $lib.exp~cat $export_symbols | $SED -e "s/\(.*\)/\1;/" >> $lib.exp~echo "local: *; };" >> $lib.exp~ $CC -shared $pic_flag $wl-z ${wl}text $wl-M $wl$lib.exp $wl-h $wl$soname -o $lib $libobjs $deplibs $compiler_flags~$RM $lib.exp' else case `$CC -V 2>&1` in *"Compilers 5.0"*) wlarc='' _LT_TAGVAR(archive_cmds, $1)='$LD -G$allow_undefined_flag -h $soname -o $lib $libobjs $deplibs $linker_flags' _LT_TAGVAR(archive_expsym_cmds, $1)='echo "{ global:" > $lib.exp~cat $export_symbols | $SED -e "s/\(.*\)/\1;/" >> $lib.exp~echo "local: *; };" >> $lib.exp~ $LD -G$allow_undefined_flag -M $lib.exp -h $soname -o $lib $libobjs $deplibs $linker_flags~$RM $lib.exp' ;; *) wlarc='$wl' _LT_TAGVAR(archive_cmds, $1)='$CC -G$allow_undefined_flag -h $soname -o $lib $libobjs $deplibs $compiler_flags' _LT_TAGVAR(archive_expsym_cmds, $1)='echo "{ global:" > $lib.exp~cat $export_symbols | $SED -e "s/\(.*\)/\1;/" >> $lib.exp~echo "local: *; };" >> $lib.exp~ $CC -G$allow_undefined_flag -M $lib.exp -h $soname -o $lib $libobjs $deplibs $compiler_flags~$RM $lib.exp' ;; esac fi _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='-R$libdir' _LT_TAGVAR(hardcode_shlibpath_var, $1)=no case $host_os in solaris2.[[0-5]] | solaris2.[[0-5]].*) ;; *) # The compiler driver will combine and reorder linker options, # but understands '-z linker_flag'. GCC discards it without '$wl', # but is careful enough not to reorder. # Supported since Solaris 2.6 (maybe 2.5.1?) if test yes = "$GCC"; then _LT_TAGVAR(whole_archive_flag_spec, $1)='$wl-z ${wl}allextract$convenience $wl-z ${wl}defaultextract' else _LT_TAGVAR(whole_archive_flag_spec, $1)='-z allextract$convenience -z defaultextract' fi ;; esac _LT_TAGVAR(link_all_deplibs, $1)=yes ;; sunos4*) if test sequent = "$host_vendor"; then # Use $CC to link under sequent, because it throws in some extra .o # files that make .init and .fini sections work. _LT_TAGVAR(archive_cmds, $1)='$CC -G $wl-h $soname -o $lib $libobjs $deplibs $compiler_flags' else _LT_TAGVAR(archive_cmds, $1)='$LD -assert pure-text -Bstatic -o $lib $libobjs $deplibs $linker_flags' fi _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='-L$libdir' _LT_TAGVAR(hardcode_direct, $1)=yes _LT_TAGVAR(hardcode_minus_L, $1)=yes _LT_TAGVAR(hardcode_shlibpath_var, $1)=no ;; sysv4) case $host_vendor in sni) _LT_TAGVAR(archive_cmds, $1)='$LD -G -h $soname -o $lib $libobjs $deplibs $linker_flags' _LT_TAGVAR(hardcode_direct, $1)=yes # is this really true??? ;; siemens) ## LD is ld it makes a PLAMLIB ## CC just makes a GrossModule. _LT_TAGVAR(archive_cmds, $1)='$LD -G -o $lib $libobjs $deplibs $linker_flags' _LT_TAGVAR(reload_cmds, $1)='$CC -r -o $output$reload_objs' _LT_TAGVAR(hardcode_direct, $1)=no ;; motorola) _LT_TAGVAR(archive_cmds, $1)='$LD -G -h $soname -o $lib $libobjs $deplibs $linker_flags' _LT_TAGVAR(hardcode_direct, $1)=no #Motorola manual says yes, but my tests say they lie ;; esac runpath_var='LD_RUN_PATH' _LT_TAGVAR(hardcode_shlibpath_var, $1)=no ;; sysv4.3*) _LT_TAGVAR(archive_cmds, $1)='$LD -G -h $soname -o $lib $libobjs $deplibs $linker_flags' _LT_TAGVAR(hardcode_shlibpath_var, $1)=no _LT_TAGVAR(export_dynamic_flag_spec, $1)='-Bexport' ;; sysv4*MP*) if test -d /usr/nec; then _LT_TAGVAR(archive_cmds, $1)='$LD -G -h $soname -o $lib $libobjs $deplibs $linker_flags' _LT_TAGVAR(hardcode_shlibpath_var, $1)=no runpath_var=LD_RUN_PATH hardcode_runpath_var=yes _LT_TAGVAR(ld_shlibs, $1)=yes fi ;; sysv4*uw2* | sysv5OpenUNIX* | sysv5UnixWare7.[[01]].[[10]]* | unixware7* | sco3.2v5.0.[[024]]*) _LT_TAGVAR(no_undefined_flag, $1)='$wl-z,text' _LT_TAGVAR(archive_cmds_need_lc, $1)=no _LT_TAGVAR(hardcode_shlibpath_var, $1)=no runpath_var='LD_RUN_PATH' if test yes = "$GCC"; then _LT_TAGVAR(archive_cmds, $1)='$CC -shared $wl-h,$soname -o $lib $libobjs $deplibs $compiler_flags' _LT_TAGVAR(archive_expsym_cmds, $1)='$CC -shared $wl-Bexport:$export_symbols $wl-h,$soname -o $lib $libobjs $deplibs $compiler_flags' else _LT_TAGVAR(archive_cmds, $1)='$CC -G $wl-h,$soname -o $lib $libobjs $deplibs $compiler_flags' _LT_TAGVAR(archive_expsym_cmds, $1)='$CC -G $wl-Bexport:$export_symbols $wl-h,$soname -o $lib $libobjs $deplibs $compiler_flags' fi ;; sysv5* | sco3.2v5* | sco5v6*) # Note: We CANNOT use -z defs as we might desire, because we do not # link with -lc, and that would cause any symbols used from libc to # always be unresolved, which means just about no library would # ever link correctly. If we're not using GNU ld we use -z text # though, which does catch some bad symbols but isn't as heavy-handed # as -z defs. _LT_TAGVAR(no_undefined_flag, $1)='$wl-z,text' _LT_TAGVAR(allow_undefined_flag, $1)='$wl-z,nodefs' _LT_TAGVAR(archive_cmds_need_lc, $1)=no _LT_TAGVAR(hardcode_shlibpath_var, $1)=no _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='$wl-R,$libdir' _LT_TAGVAR(hardcode_libdir_separator, $1)=':' _LT_TAGVAR(link_all_deplibs, $1)=yes _LT_TAGVAR(export_dynamic_flag_spec, $1)='$wl-Bexport' runpath_var='LD_RUN_PATH' if test yes = "$GCC"; then _LT_TAGVAR(archive_cmds, $1)='$CC -shared $wl-h,$soname -o $lib $libobjs $deplibs $compiler_flags' _LT_TAGVAR(archive_expsym_cmds, $1)='$CC -shared $wl-Bexport:$export_symbols $wl-h,$soname -o $lib $libobjs $deplibs $compiler_flags' else _LT_TAGVAR(archive_cmds, $1)='$CC -G $wl-h,$soname -o $lib $libobjs $deplibs $compiler_flags' _LT_TAGVAR(archive_expsym_cmds, $1)='$CC -G $wl-Bexport:$export_symbols $wl-h,$soname -o $lib $libobjs $deplibs $compiler_flags' fi ;; uts4*) _LT_TAGVAR(archive_cmds, $1)='$LD -G -h $soname -o $lib $libobjs $deplibs $linker_flags' _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='-L$libdir' _LT_TAGVAR(hardcode_shlibpath_var, $1)=no ;; *) _LT_TAGVAR(ld_shlibs, $1)=no ;; esac if test sni = "$host_vendor"; then case $host in sysv4 | sysv4.2uw2* | sysv4.3* | sysv5*) _LT_TAGVAR(export_dynamic_flag_spec, $1)='$wl-Blargedynsym' ;; esac fi fi ]) AC_MSG_RESULT([$_LT_TAGVAR(ld_shlibs, $1)]) test no = "$_LT_TAGVAR(ld_shlibs, $1)" && can_build_shared=no _LT_TAGVAR(with_gnu_ld, $1)=$with_gnu_ld _LT_DECL([], [libext], [0], [Old archive suffix (normally "a")])dnl _LT_DECL([], [shrext_cmds], [1], [Shared library suffix (normally ".so")])dnl _LT_DECL([], [extract_expsyms_cmds], [2], [The commands to extract the exported symbol list from a shared archive]) # # Do we need to explicitly link libc? # case "x$_LT_TAGVAR(archive_cmds_need_lc, $1)" in x|xyes) # Assume -lc should be added _LT_TAGVAR(archive_cmds_need_lc, $1)=yes if test yes,yes = "$GCC,$enable_shared"; then case $_LT_TAGVAR(archive_cmds, $1) in *'~'*) # FIXME: we may have to deal with multi-command sequences. ;; '$CC '*) # Test whether the compiler implicitly links with -lc since on some # systems, -lgcc has to come before -lc. If gcc already passes -lc # to ld, don't add -lc before -lgcc. AC_CACHE_CHECK([whether -lc should be explicitly linked in], [lt_cv_]_LT_TAGVAR(archive_cmds_need_lc, $1), [$RM conftest* echo "$lt_simple_compile_test_code" > conftest.$ac_ext if AC_TRY_EVAL(ac_compile) 2>conftest.err; then soname=conftest lib=conftest libobjs=conftest.$ac_objext deplibs= wl=$_LT_TAGVAR(lt_prog_compiler_wl, $1) pic_flag=$_LT_TAGVAR(lt_prog_compiler_pic, $1) compiler_flags=-v linker_flags=-v verstring= output_objdir=. libname=conftest lt_save_allow_undefined_flag=$_LT_TAGVAR(allow_undefined_flag, $1) _LT_TAGVAR(allow_undefined_flag, $1)= if AC_TRY_EVAL(_LT_TAGVAR(archive_cmds, $1) 2\>\&1 \| $GREP \" -lc \" \>/dev/null 2\>\&1) then lt_cv_[]_LT_TAGVAR(archive_cmds_need_lc, $1)=no else lt_cv_[]_LT_TAGVAR(archive_cmds_need_lc, $1)=yes fi _LT_TAGVAR(allow_undefined_flag, $1)=$lt_save_allow_undefined_flag else cat conftest.err 1>&5 fi $RM conftest* ]) _LT_TAGVAR(archive_cmds_need_lc, $1)=$lt_cv_[]_LT_TAGVAR(archive_cmds_need_lc, $1) ;; esac fi ;; esac _LT_TAGDECL([build_libtool_need_lc], [archive_cmds_need_lc], [0], [Whether or not to add -lc for building shared libraries]) _LT_TAGDECL([allow_libtool_libs_with_static_runtimes], [enable_shared_with_static_runtimes], [0], [Whether or not to disallow shared libs when runtime libs are static]) _LT_TAGDECL([], [export_dynamic_flag_spec], [1], [Compiler flag to allow reflexive dlopens]) _LT_TAGDECL([], [whole_archive_flag_spec], [1], [Compiler flag to generate shared objects directly from archives]) _LT_TAGDECL([], [compiler_needs_object], [1], [Whether the compiler copes with passing no objects directly]) _LT_TAGDECL([], [old_archive_from_new_cmds], [2], [Create an old-style archive from a shared archive]) _LT_TAGDECL([], [old_archive_from_expsyms_cmds], [2], [Create a temporary old-style archive to link instead of a shared archive]) _LT_TAGDECL([], [archive_cmds], [2], [Commands used to build a shared archive]) _LT_TAGDECL([], [archive_expsym_cmds], [2]) _LT_TAGDECL([], [module_cmds], [2], [Commands used to build a loadable module if different from building a shared archive.]) _LT_TAGDECL([], [module_expsym_cmds], [2]) _LT_TAGDECL([], [with_gnu_ld], [1], [Whether we are building with GNU ld or not]) _LT_TAGDECL([], [allow_undefined_flag], [1], [Flag that allows shared libraries with undefined symbols to be built]) _LT_TAGDECL([], [no_undefined_flag], [1], [Flag that enforces no undefined symbols]) _LT_TAGDECL([], [hardcode_libdir_flag_spec], [1], [Flag to hardcode $libdir into a binary during linking. This must work even if $libdir does not exist]) _LT_TAGDECL([], [hardcode_libdir_separator], [1], [Whether we need a single "-rpath" flag with a separated argument]) _LT_TAGDECL([], [hardcode_direct], [0], [Set to "yes" if using DIR/libNAME$shared_ext during linking hardcodes DIR into the resulting binary]) _LT_TAGDECL([], [hardcode_direct_absolute], [0], [Set to "yes" if using DIR/libNAME$shared_ext during linking hardcodes DIR into the resulting binary and the resulting library dependency is "absolute", i.e impossible to change by setting $shlibpath_var if the library is relocated]) _LT_TAGDECL([], [hardcode_minus_L], [0], [Set to "yes" if using the -LDIR flag during linking hardcodes DIR into the resulting binary]) _LT_TAGDECL([], [hardcode_shlibpath_var], [0], [Set to "yes" if using SHLIBPATH_VAR=DIR during linking hardcodes DIR into the resulting binary]) _LT_TAGDECL([], [hardcode_automatic], [0], [Set to "yes" if building a shared library automatically hardcodes DIR into the library and all subsequent libraries and executables linked against it]) _LT_TAGDECL([], [inherit_rpath], [0], [Set to yes if linker adds runtime paths of dependent libraries to runtime path list]) _LT_TAGDECL([], [link_all_deplibs], [0], [Whether libtool must link a program against all its dependency libraries]) _LT_TAGDECL([], [always_export_symbols], [0], [Set to "yes" if exported symbols are required]) _LT_TAGDECL([], [export_symbols_cmds], [2], [The commands to list exported symbols]) _LT_TAGDECL([], [exclude_expsyms], [1], [Symbols that should not be listed in the preloaded symbols]) _LT_TAGDECL([], [include_expsyms], [1], [Symbols that must always be exported]) _LT_TAGDECL([], [prelink_cmds], [2], [Commands necessary for linking programs (against libraries) with templates]) _LT_TAGDECL([], [postlink_cmds], [2], [Commands necessary for finishing linking programs]) _LT_TAGDECL([], [file_list_spec], [1], [Specify filename containing input files]) dnl FIXME: Not yet implemented dnl _LT_TAGDECL([], [thread_safe_flag_spec], [1], dnl [Compiler flag to generate thread safe objects]) ])# _LT_LINKER_SHLIBS # _LT_LANG_C_CONFIG([TAG]) # ------------------------ # Ensure that the configuration variables for a C compiler are suitably # defined. These variables are subsequently used by _LT_CONFIG to write # the compiler configuration to 'libtool'. m4_defun([_LT_LANG_C_CONFIG], [m4_require([_LT_DECL_EGREP])dnl lt_save_CC=$CC AC_LANG_PUSH(C) # Source file extension for C test sources. ac_ext=c # Object file extension for compiled C test sources. objext=o _LT_TAGVAR(objext, $1)=$objext # Code to be used in simple compile tests lt_simple_compile_test_code="int some_variable = 0;" # Code to be used in simple link tests lt_simple_link_test_code='int main(){return(0);}' _LT_TAG_COMPILER # Save the default compiler, since it gets overwritten when the other # tags are being tested, and _LT_TAGVAR(compiler, []) is a NOP. compiler_DEFAULT=$CC # save warnings/boilerplate of simple test code _LT_COMPILER_BOILERPLATE _LT_LINKER_BOILERPLATE ## CAVEAT EMPTOR: ## There is no encapsulation within the following macros, do not change ## the running order or otherwise move them around unless you know exactly ## what you are doing... if test -n "$compiler"; then _LT_COMPILER_NO_RTTI($1) _LT_COMPILER_PIC($1) _LT_COMPILER_C_O($1) _LT_COMPILER_FILE_LOCKS($1) _LT_LINKER_SHLIBS($1) _LT_SYS_DYNAMIC_LINKER($1) _LT_LINKER_HARDCODE_LIBPATH($1) LT_SYS_DLOPEN_SELF _LT_CMD_STRIPLIB # Report what library types will actually be built AC_MSG_CHECKING([if libtool supports shared libraries]) AC_MSG_RESULT([$can_build_shared]) AC_MSG_CHECKING([whether to build shared libraries]) test no = "$can_build_shared" && enable_shared=no # On AIX, shared libraries and static libraries use the same namespace, and # are all built from PIC. case $host_os in aix3*) test yes = "$enable_shared" && enable_static=no if test -n "$RANLIB"; then archive_cmds="$archive_cmds~\$RANLIB \$lib" postinstall_cmds='$RANLIB $lib' fi ;; aix[[4-9]]*) if test ia64 != "$host_cpu"; then case $enable_shared,$with_aix_soname,$aix_use_runtimelinking in yes,aix,yes) ;; # shared object as lib.so file only yes,svr4,*) ;; # shared object as lib.so archive member only yes,*) enable_static=no ;; # shared object in lib.a archive as well esac fi ;; esac AC_MSG_RESULT([$enable_shared]) AC_MSG_CHECKING([whether to build static libraries]) # Make sure either enable_shared or enable_static is yes. test yes = "$enable_shared" || enable_static=yes AC_MSG_RESULT([$enable_static]) _LT_CONFIG($1) fi AC_LANG_POP CC=$lt_save_CC ])# _LT_LANG_C_CONFIG # _LT_LANG_CXX_CONFIG([TAG]) # -------------------------- # Ensure that the configuration variables for a C++ compiler are suitably # defined. These variables are subsequently used by _LT_CONFIG to write # the compiler configuration to 'libtool'. m4_defun([_LT_LANG_CXX_CONFIG], [m4_require([_LT_FILEUTILS_DEFAULTS])dnl m4_require([_LT_DECL_EGREP])dnl m4_require([_LT_PATH_MANIFEST_TOOL])dnl if test -n "$CXX" && ( test no != "$CXX" && ( (test g++ = "$CXX" && `g++ -v >/dev/null 2>&1` ) || (test g++ != "$CXX"))); then AC_PROG_CXXCPP else _lt_caught_CXX_error=yes fi AC_LANG_PUSH(C++) _LT_TAGVAR(archive_cmds_need_lc, $1)=no _LT_TAGVAR(allow_undefined_flag, $1)= _LT_TAGVAR(always_export_symbols, $1)=no _LT_TAGVAR(archive_expsym_cmds, $1)= _LT_TAGVAR(compiler_needs_object, $1)=no _LT_TAGVAR(export_dynamic_flag_spec, $1)= _LT_TAGVAR(hardcode_direct, $1)=no _LT_TAGVAR(hardcode_direct_absolute, $1)=no _LT_TAGVAR(hardcode_libdir_flag_spec, $1)= _LT_TAGVAR(hardcode_libdir_separator, $1)= _LT_TAGVAR(hardcode_minus_L, $1)=no _LT_TAGVAR(hardcode_shlibpath_var, $1)=unsupported _LT_TAGVAR(hardcode_automatic, $1)=no _LT_TAGVAR(inherit_rpath, $1)=no _LT_TAGVAR(module_cmds, $1)= _LT_TAGVAR(module_expsym_cmds, $1)= _LT_TAGVAR(link_all_deplibs, $1)=unknown _LT_TAGVAR(old_archive_cmds, $1)=$old_archive_cmds _LT_TAGVAR(reload_flag, $1)=$reload_flag _LT_TAGVAR(reload_cmds, $1)=$reload_cmds _LT_TAGVAR(no_undefined_flag, $1)= _LT_TAGVAR(whole_archive_flag_spec, $1)= _LT_TAGVAR(enable_shared_with_static_runtimes, $1)=no # Source file extension for C++ test sources. ac_ext=cpp # Object file extension for compiled C++ test sources. objext=o _LT_TAGVAR(objext, $1)=$objext # No sense in running all these tests if we already determined that # the CXX compiler isn't working. Some variables (like enable_shared) # are currently assumed to apply to all compilers on this platform, # and will be corrupted by setting them based on a non-working compiler. if test yes != "$_lt_caught_CXX_error"; then # Code to be used in simple compile tests lt_simple_compile_test_code="int some_variable = 0;" # Code to be used in simple link tests lt_simple_link_test_code='int main(int, char *[[]]) { return(0); }' # ltmain only uses $CC for tagged configurations so make sure $CC is set. _LT_TAG_COMPILER # save warnings/boilerplate of simple test code _LT_COMPILER_BOILERPLATE _LT_LINKER_BOILERPLATE # Allow CC to be a program name with arguments. lt_save_CC=$CC lt_save_CFLAGS=$CFLAGS lt_save_LD=$LD lt_save_GCC=$GCC GCC=$GXX lt_save_with_gnu_ld=$with_gnu_ld lt_save_path_LD=$lt_cv_path_LD if test -n "${lt_cv_prog_gnu_ldcxx+set}"; then lt_cv_prog_gnu_ld=$lt_cv_prog_gnu_ldcxx else $as_unset lt_cv_prog_gnu_ld fi if test -n "${lt_cv_path_LDCXX+set}"; then lt_cv_path_LD=$lt_cv_path_LDCXX else $as_unset lt_cv_path_LD fi test -z "${LDCXX+set}" || LD=$LDCXX CC=${CXX-"c++"} CFLAGS=$CXXFLAGS compiler=$CC _LT_TAGVAR(compiler, $1)=$CC _LT_CC_BASENAME([$compiler]) if test -n "$compiler"; then # We don't want -fno-exception when compiling C++ code, so set the # no_builtin_flag separately if test yes = "$GXX"; then _LT_TAGVAR(lt_prog_compiler_no_builtin_flag, $1)=' -fno-builtin' else _LT_TAGVAR(lt_prog_compiler_no_builtin_flag, $1)= fi if test yes = "$GXX"; then # Set up default GNU C++ configuration LT_PATH_LD # Check if GNU C++ uses GNU ld as the underlying linker, since the # archiving commands below assume that GNU ld is being used. if test yes = "$with_gnu_ld"; then _LT_TAGVAR(archive_cmds, $1)='$CC $pic_flag -shared -nostdlib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags $wl-soname $wl$soname -o $lib' _LT_TAGVAR(archive_expsym_cmds, $1)='$CC $pic_flag -shared -nostdlib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags $wl-soname $wl$soname $wl-retain-symbols-file $wl$export_symbols -o $lib' _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='$wl-rpath $wl$libdir' _LT_TAGVAR(export_dynamic_flag_spec, $1)='$wl--export-dynamic' # If archive_cmds runs LD, not CC, wlarc should be empty # XXX I think wlarc can be eliminated in ltcf-cxx, but I need to # investigate it a little bit more. (MM) wlarc='$wl' # ancient GNU ld didn't support --whole-archive et. al. if eval "`$CC -print-prog-name=ld` --help 2>&1" | $GREP 'no-whole-archive' > /dev/null; then _LT_TAGVAR(whole_archive_flag_spec, $1)=$wlarc'--whole-archive$convenience '$wlarc'--no-whole-archive' else _LT_TAGVAR(whole_archive_flag_spec, $1)= fi else with_gnu_ld=no wlarc= # A generic and very simple default shared library creation # command for GNU C++ for the case where it uses the native # linker, instead of GNU ld. If possible, this setting should # overridden to take advantage of the native linker features on # the platform it is being used on. _LT_TAGVAR(archive_cmds, $1)='$CC -shared -nostdlib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags -o $lib' fi # Commands to make compiler produce verbose output that lists # what "hidden" libraries, object files and flags are used when # linking a shared library. output_verbose_link_cmd='$CC -shared $CFLAGS -v conftest.$objext 2>&1 | $GREP -v "^Configured with:" | $GREP "\-L"' else GXX=no with_gnu_ld=no wlarc= fi # PORTME: fill in a description of your system's C++ link characteristics AC_MSG_CHECKING([whether the $compiler linker ($LD) supports shared libraries]) _LT_TAGVAR(ld_shlibs, $1)=yes case $host_os in aix3*) # FIXME: insert proper C++ library support _LT_TAGVAR(ld_shlibs, $1)=no ;; aix[[4-9]]*) if test ia64 = "$host_cpu"; then # On IA64, the linker does run time linking by default, so we don't # have to do anything special. aix_use_runtimelinking=no exp_sym_flag='-Bexport' no_entry_flag= else aix_use_runtimelinking=no # Test if we are trying to use run time linking or normal # AIX style linking. If -brtl is somewhere in LDFLAGS, we # have runtime linking enabled, and use it for executables. # For shared libraries, we enable/disable runtime linking # depending on the kind of the shared library created - # when "with_aix_soname,aix_use_runtimelinking" is: # "aix,no" lib.a(lib.so.V) shared, rtl:no, for executables # "aix,yes" lib.so shared, rtl:yes, for executables # lib.a static archive # "both,no" lib.so.V(shr.o) shared, rtl:yes # lib.a(lib.so.V) shared, rtl:no, for executables # "both,yes" lib.so.V(shr.o) shared, rtl:yes, for executables # lib.a(lib.so.V) shared, rtl:no # "svr4,*" lib.so.V(shr.o) shared, rtl:yes, for executables # lib.a static archive case $host_os in aix4.[[23]]|aix4.[[23]].*|aix[[5-9]]*) for ld_flag in $LDFLAGS; do case $ld_flag in *-brtl*) aix_use_runtimelinking=yes break ;; esac done if test svr4,no = "$with_aix_soname,$aix_use_runtimelinking"; then # With aix-soname=svr4, we create the lib.so.V shared archives only, # so we don't have lib.a shared libs to link our executables. # We have to force runtime linking in this case. aix_use_runtimelinking=yes LDFLAGS="$LDFLAGS -Wl,-brtl" fi ;; esac exp_sym_flag='-bexport' no_entry_flag='-bnoentry' fi # When large executables or shared objects are built, AIX ld can # have problems creating the table of contents. If linking a library # or program results in "error TOC overflow" add -mminimal-toc to # CXXFLAGS/CFLAGS for g++/gcc. In the cases where that is not # enough to fix the problem, add -Wl,-bbigtoc to LDFLAGS. _LT_TAGVAR(archive_cmds, $1)='' _LT_TAGVAR(hardcode_direct, $1)=yes _LT_TAGVAR(hardcode_direct_absolute, $1)=yes _LT_TAGVAR(hardcode_libdir_separator, $1)=':' _LT_TAGVAR(link_all_deplibs, $1)=yes _LT_TAGVAR(file_list_spec, $1)='$wl-f,' case $with_aix_soname,$aix_use_runtimelinking in aix,*) ;; # no import file svr4,* | *,yes) # use import file # The Import File defines what to hardcode. _LT_TAGVAR(hardcode_direct, $1)=no _LT_TAGVAR(hardcode_direct_absolute, $1)=no ;; esac if test yes = "$GXX"; then case $host_os in aix4.[[012]]|aix4.[[012]].*) # We only want to do this on AIX 4.2 and lower, the check # below for broken collect2 doesn't work under 4.3+ collect2name=`$CC -print-prog-name=collect2` if test -f "$collect2name" && strings "$collect2name" | $GREP resolve_lib_name >/dev/null then # We have reworked collect2 : else # We have old collect2 _LT_TAGVAR(hardcode_direct, $1)=unsupported # It fails to find uninstalled libraries when the uninstalled # path is not listed in the libpath. Setting hardcode_minus_L # to unsupported forces relinking _LT_TAGVAR(hardcode_minus_L, $1)=yes _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='-L$libdir' _LT_TAGVAR(hardcode_libdir_separator, $1)= fi esac shared_flag='-shared' if test yes = "$aix_use_runtimelinking"; then shared_flag=$shared_flag' $wl-G' fi # Need to ensure runtime linking is disabled for the traditional # shared library, or the linker may eventually find shared libraries # /with/ Import File - we do not want to mix them. shared_flag_aix='-shared' shared_flag_svr4='-shared $wl-G' else # not using gcc if test ia64 = "$host_cpu"; then # VisualAge C++, Version 5.5 for AIX 5L for IA-64, Beta 3 Release # chokes on -Wl,-G. The following line is correct: shared_flag='-G' else if test yes = "$aix_use_runtimelinking"; then shared_flag='$wl-G' else shared_flag='$wl-bM:SRE' fi shared_flag_aix='$wl-bM:SRE' shared_flag_svr4='$wl-G' fi fi _LT_TAGVAR(export_dynamic_flag_spec, $1)='$wl-bexpall' # It seems that -bexpall does not export symbols beginning with # underscore (_), so it is better to generate a list of symbols to # export. _LT_TAGVAR(always_export_symbols, $1)=yes if test aix,yes = "$with_aix_soname,$aix_use_runtimelinking"; then # Warning - without using the other runtime loading flags (-brtl), # -berok will link without error, but may produce a broken library. # The "-G" linker flag allows undefined symbols. _LT_TAGVAR(no_undefined_flag, $1)='-bernotok' # Determine the default libpath from the value encoded in an empty # executable. _LT_SYS_MODULE_PATH_AIX([$1]) _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='$wl-blibpath:$libdir:'"$aix_libpath" _LT_TAGVAR(archive_expsym_cmds, $1)='$CC -o $output_objdir/$soname $libobjs $deplibs $wl'$no_entry_flag' $compiler_flags `if test -n "$allow_undefined_flag"; then func_echo_all "$wl$allow_undefined_flag"; else :; fi` $wl'$exp_sym_flag:\$export_symbols' '$shared_flag else if test ia64 = "$host_cpu"; then _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='$wl-R $libdir:/usr/lib:/lib' _LT_TAGVAR(allow_undefined_flag, $1)="-z nodefs" _LT_TAGVAR(archive_expsym_cmds, $1)="\$CC $shared_flag"' -o $output_objdir/$soname $libobjs $deplibs '"\$wl$no_entry_flag"' $compiler_flags $wl$allow_undefined_flag '"\$wl$exp_sym_flag:\$export_symbols" else # Determine the default libpath from the value encoded in an # empty executable. _LT_SYS_MODULE_PATH_AIX([$1]) _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='$wl-blibpath:$libdir:'"$aix_libpath" # Warning - without using the other run time loading flags, # -berok will link without error, but may produce a broken library. _LT_TAGVAR(no_undefined_flag, $1)=' $wl-bernotok' _LT_TAGVAR(allow_undefined_flag, $1)=' $wl-berok' if test yes = "$with_gnu_ld"; then # We only use this code for GNU lds that support --whole-archive. _LT_TAGVAR(whole_archive_flag_spec, $1)='$wl--whole-archive$convenience $wl--no-whole-archive' else # Exported symbols can be pulled into shared objects from archives _LT_TAGVAR(whole_archive_flag_spec, $1)='$convenience' fi _LT_TAGVAR(archive_cmds_need_lc, $1)=yes _LT_TAGVAR(archive_expsym_cmds, $1)='$RM -r $output_objdir/$realname.d~$MKDIR $output_objdir/$realname.d' # -brtl affects multiple linker settings, -berok does not and is overridden later compiler_flags_filtered='`func_echo_all "$compiler_flags " | $SED -e "s%-brtl\\([[, ]]\\)%-berok\\1%g"`' if test svr4 != "$with_aix_soname"; then # This is similar to how AIX traditionally builds its shared # libraries. Need -bnortl late, we may have -brtl in LDFLAGS. _LT_TAGVAR(archive_expsym_cmds, $1)="$_LT_TAGVAR(archive_expsym_cmds, $1)"'~$CC '$shared_flag_aix' -o $output_objdir/$realname.d/$soname $libobjs $deplibs $wl-bnoentry '$compiler_flags_filtered'$wl-bE:$export_symbols$allow_undefined_flag~$AR $AR_FLAGS $output_objdir/$libname$release.a $output_objdir/$realname.d/$soname' fi if test aix != "$with_aix_soname"; then _LT_TAGVAR(archive_expsym_cmds, $1)="$_LT_TAGVAR(archive_expsym_cmds, $1)"'~$CC '$shared_flag_svr4' -o $output_objdir/$realname.d/$shared_archive_member_spec.o $libobjs $deplibs $wl-bnoentry '$compiler_flags_filtered'$wl-bE:$export_symbols$allow_undefined_flag~$STRIP -e $output_objdir/$realname.d/$shared_archive_member_spec.o~( func_echo_all "#! $soname($shared_archive_member_spec.o)"; if test shr_64 = "$shared_archive_member_spec"; then func_echo_all "# 64"; else func_echo_all "# 32"; fi; cat $export_symbols ) > $output_objdir/$realname.d/$shared_archive_member_spec.imp~$AR $AR_FLAGS $output_objdir/$soname $output_objdir/$realname.d/$shared_archive_member_spec.o $output_objdir/$realname.d/$shared_archive_member_spec.imp' else # used by -dlpreopen to get the symbols _LT_TAGVAR(archive_expsym_cmds, $1)="$_LT_TAGVAR(archive_expsym_cmds, $1)"'~$MV $output_objdir/$realname.d/$soname $output_objdir' fi _LT_TAGVAR(archive_expsym_cmds, $1)="$_LT_TAGVAR(archive_expsym_cmds, $1)"'~$RM -r $output_objdir/$realname.d' fi fi ;; beos*) if $LD --help 2>&1 | $GREP ': supported targets:.* elf' > /dev/null; then _LT_TAGVAR(allow_undefined_flag, $1)=unsupported # Joseph Beckenbach says some releases of gcc # support --undefined. This deserves some investigation. FIXME _LT_TAGVAR(archive_cmds, $1)='$CC -nostart $libobjs $deplibs $compiler_flags $wl-soname $wl$soname -o $lib' else _LT_TAGVAR(ld_shlibs, $1)=no fi ;; chorus*) case $cc_basename in *) # FIXME: insert proper C++ library support _LT_TAGVAR(ld_shlibs, $1)=no ;; esac ;; cygwin* | mingw* | pw32* | cegcc*) case $GXX,$cc_basename in ,cl* | no,cl*) # Native MSVC # hardcode_libdir_flag_spec is actually meaningless, as there is # no search path for DLLs. _LT_TAGVAR(hardcode_libdir_flag_spec, $1)=' ' _LT_TAGVAR(allow_undefined_flag, $1)=unsupported _LT_TAGVAR(always_export_symbols, $1)=yes _LT_TAGVAR(file_list_spec, $1)='@' # Tell ltmain to make .lib files, not .a files. libext=lib # Tell ltmain to make .dll files, not .so files. shrext_cmds=.dll # FIXME: Setting linknames here is a bad hack. _LT_TAGVAR(archive_cmds, $1)='$CC -o $output_objdir/$soname $libobjs $compiler_flags $deplibs -Wl,-DLL,-IMPLIB:"$tool_output_objdir$libname.dll.lib"~linknames=' _LT_TAGVAR(archive_expsym_cmds, $1)='if _LT_DLL_DEF_P([$export_symbols]); then cp "$export_symbols" "$output_objdir/$soname.def"; echo "$tool_output_objdir$soname.def" > "$output_objdir/$soname.exp"; else $SED -e '\''s/^/-link -EXPORT:/'\'' < $export_symbols > $output_objdir/$soname.exp; fi~ $CC -o $tool_output_objdir$soname $libobjs $compiler_flags $deplibs "@$tool_output_objdir$soname.exp" -Wl,-DLL,-IMPLIB:"$tool_output_objdir$libname.dll.lib"~ linknames=' # The linker will not automatically build a static lib if we build a DLL. # _LT_TAGVAR(old_archive_from_new_cmds, $1)='true' _LT_TAGVAR(enable_shared_with_static_runtimes, $1)=yes # Don't use ranlib _LT_TAGVAR(old_postinstall_cmds, $1)='chmod 644 $oldlib' _LT_TAGVAR(postlink_cmds, $1)='lt_outputfile="@OUTPUT@"~ lt_tool_outputfile="@TOOL_OUTPUT@"~ case $lt_outputfile in *.exe|*.EXE) ;; *) lt_outputfile=$lt_outputfile.exe lt_tool_outputfile=$lt_tool_outputfile.exe ;; esac~ func_to_tool_file "$lt_outputfile"~ if test : != "$MANIFEST_TOOL" && test -f "$lt_outputfile.manifest"; then $MANIFEST_TOOL -manifest "$lt_tool_outputfile.manifest" -outputresource:"$lt_tool_outputfile" || exit 1; $RM "$lt_outputfile.manifest"; fi' ;; *) # g++ # _LT_TAGVAR(hardcode_libdir_flag_spec, $1) is actually meaningless, # as there is no search path for DLLs. _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='-L$libdir' _LT_TAGVAR(export_dynamic_flag_spec, $1)='$wl--export-all-symbols' _LT_TAGVAR(allow_undefined_flag, $1)=unsupported _LT_TAGVAR(always_export_symbols, $1)=no _LT_TAGVAR(enable_shared_with_static_runtimes, $1)=yes if $LD --help 2>&1 | $GREP 'auto-import' > /dev/null; then _LT_TAGVAR(archive_cmds, $1)='$CC -shared -nostdlib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags -o $output_objdir/$soname $wl--enable-auto-image-base -Xlinker --out-implib -Xlinker $lib' # If the export-symbols file already is a .def file, use it as # is; otherwise, prepend EXPORTS... _LT_TAGVAR(archive_expsym_cmds, $1)='if _LT_DLL_DEF_P([$export_symbols]); then cp $export_symbols $output_objdir/$soname.def; else echo EXPORTS > $output_objdir/$soname.def; cat $export_symbols >> $output_objdir/$soname.def; fi~ $CC -shared -nostdlib $output_objdir/$soname.def $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags -o $output_objdir/$soname $wl--enable-auto-image-base -Xlinker --out-implib -Xlinker $lib' else _LT_TAGVAR(ld_shlibs, $1)=no fi ;; esac ;; darwin* | rhapsody*) _LT_DARWIN_LINKER_FEATURES($1) ;; os2*) _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='-L$libdir' _LT_TAGVAR(hardcode_minus_L, $1)=yes _LT_TAGVAR(allow_undefined_flag, $1)=unsupported shrext_cmds=.dll _LT_TAGVAR(archive_cmds, $1)='$ECHO "LIBRARY ${soname%$shared_ext} INITINSTANCE TERMINSTANCE" > $output_objdir/$libname.def~ $ECHO "DESCRIPTION \"$libname\"" >> $output_objdir/$libname.def~ $ECHO "DATA MULTIPLE NONSHARED" >> $output_objdir/$libname.def~ $ECHO EXPORTS >> $output_objdir/$libname.def~ emxexp $libobjs | $SED /"_DLL_InitTerm"/d >> $output_objdir/$libname.def~ $CC -Zdll -Zcrtdll -o $output_objdir/$soname $libobjs $deplibs $compiler_flags $output_objdir/$libname.def~ emximp -o $lib $output_objdir/$libname.def' _LT_TAGVAR(archive_expsym_cmds, $1)='$ECHO "LIBRARY ${soname%$shared_ext} INITINSTANCE TERMINSTANCE" > $output_objdir/$libname.def~ $ECHO "DESCRIPTION \"$libname\"" >> $output_objdir/$libname.def~ $ECHO "DATA MULTIPLE NONSHARED" >> $output_objdir/$libname.def~ $ECHO EXPORTS >> $output_objdir/$libname.def~ prefix_cmds="$SED"~ if test EXPORTS = "`$SED 1q $export_symbols`"; then prefix_cmds="$prefix_cmds -e 1d"; fi~ prefix_cmds="$prefix_cmds -e \"s/^\(.*\)$/_\1/g\""~ cat $export_symbols | $prefix_cmds >> $output_objdir/$libname.def~ $CC -Zdll -Zcrtdll -o $output_objdir/$soname $libobjs $deplibs $compiler_flags $output_objdir/$libname.def~ emximp -o $lib $output_objdir/$libname.def' _LT_TAGVAR(old_archive_From_new_cmds, $1)='emximp -o $output_objdir/${libname}_dll.a $output_objdir/$libname.def' _LT_TAGVAR(enable_shared_with_static_runtimes, $1)=yes ;; dgux*) case $cc_basename in ec++*) # FIXME: insert proper C++ library support _LT_TAGVAR(ld_shlibs, $1)=no ;; ghcx*) # Green Hills C++ Compiler # FIXME: insert proper C++ library support _LT_TAGVAR(ld_shlibs, $1)=no ;; *) # FIXME: insert proper C++ library support _LT_TAGVAR(ld_shlibs, $1)=no ;; esac ;; freebsd2.*) # C++ shared libraries reported to be fairly broken before # switch to ELF _LT_TAGVAR(ld_shlibs, $1)=no ;; freebsd-elf*) _LT_TAGVAR(archive_cmds_need_lc, $1)=no ;; freebsd* | dragonfly*) # FreeBSD 3 and later use GNU C++ and GNU ld with standard ELF # conventions _LT_TAGVAR(ld_shlibs, $1)=yes ;; haiku*) _LT_TAGVAR(archive_cmds, $1)='$CC -shared $libobjs $deplibs $compiler_flags $wl-soname $wl$soname -o $lib' _LT_TAGVAR(link_all_deplibs, $1)=yes ;; hpux9*) _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='$wl+b $wl$libdir' _LT_TAGVAR(hardcode_libdir_separator, $1)=: _LT_TAGVAR(export_dynamic_flag_spec, $1)='$wl-E' _LT_TAGVAR(hardcode_direct, $1)=yes _LT_TAGVAR(hardcode_minus_L, $1)=yes # Not in the search PATH, # but as the default # location of the library. case $cc_basename in CC*) # FIXME: insert proper C++ library support _LT_TAGVAR(ld_shlibs, $1)=no ;; aCC*) _LT_TAGVAR(archive_cmds, $1)='$RM $output_objdir/$soname~$CC -b $wl+b $wl$install_libdir -o $output_objdir/$soname $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags~test "x$output_objdir/$soname" = "x$lib" || mv $output_objdir/$soname $lib' # Commands to make compiler produce verbose output that lists # what "hidden" libraries, object files and flags are used when # linking a shared library. # # There doesn't appear to be a way to prevent this compiler from # explicitly linking system object files so we need to strip them # from the output so that they don't get included in the library # dependencies. output_verbose_link_cmd='templist=`($CC -b $CFLAGS -v conftest.$objext 2>&1) | $EGREP "\-L"`; list= ; for z in $templist; do case $z in conftest.$objext) list="$list $z";; *.$objext);; *) list="$list $z";;esac; done; func_echo_all "$list"' ;; *) if test yes = "$GXX"; then _LT_TAGVAR(archive_cmds, $1)='$RM $output_objdir/$soname~$CC -shared -nostdlib $pic_flag $wl+b $wl$install_libdir -o $output_objdir/$soname $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags~test "x$output_objdir/$soname" = "x$lib" || mv $output_objdir/$soname $lib' else # FIXME: insert proper C++ library support _LT_TAGVAR(ld_shlibs, $1)=no fi ;; esac ;; hpux10*|hpux11*) if test no = "$with_gnu_ld"; then _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='$wl+b $wl$libdir' _LT_TAGVAR(hardcode_libdir_separator, $1)=: case $host_cpu in hppa*64*|ia64*) ;; *) _LT_TAGVAR(export_dynamic_flag_spec, $1)='$wl-E' ;; esac fi case $host_cpu in hppa*64*|ia64*) _LT_TAGVAR(hardcode_direct, $1)=no _LT_TAGVAR(hardcode_shlibpath_var, $1)=no ;; *) _LT_TAGVAR(hardcode_direct, $1)=yes _LT_TAGVAR(hardcode_direct_absolute, $1)=yes _LT_TAGVAR(hardcode_minus_L, $1)=yes # Not in the search PATH, # but as the default # location of the library. ;; esac case $cc_basename in CC*) # FIXME: insert proper C++ library support _LT_TAGVAR(ld_shlibs, $1)=no ;; aCC*) case $host_cpu in hppa*64*) _LT_TAGVAR(archive_cmds, $1)='$CC -b $wl+h $wl$soname -o $lib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags' ;; ia64*) _LT_TAGVAR(archive_cmds, $1)='$CC -b $wl+h $wl$soname $wl+nodefaultrpath -o $lib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags' ;; *) _LT_TAGVAR(archive_cmds, $1)='$CC -b $wl+h $wl$soname $wl+b $wl$install_libdir -o $lib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags' ;; esac # Commands to make compiler produce verbose output that lists # what "hidden" libraries, object files and flags are used when # linking a shared library. # # There doesn't appear to be a way to prevent this compiler from # explicitly linking system object files so we need to strip them # from the output so that they don't get included in the library # dependencies. output_verbose_link_cmd='templist=`($CC -b $CFLAGS -v conftest.$objext 2>&1) | $GREP "\-L"`; list= ; for z in $templist; do case $z in conftest.$objext) list="$list $z";; *.$objext);; *) list="$list $z";;esac; done; func_echo_all "$list"' ;; *) if test yes = "$GXX"; then if test no = "$with_gnu_ld"; then case $host_cpu in hppa*64*) _LT_TAGVAR(archive_cmds, $1)='$CC -shared -nostdlib -fPIC $wl+h $wl$soname -o $lib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags' ;; ia64*) _LT_TAGVAR(archive_cmds, $1)='$CC -shared -nostdlib $pic_flag $wl+h $wl$soname $wl+nodefaultrpath -o $lib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags' ;; *) _LT_TAGVAR(archive_cmds, $1)='$CC -shared -nostdlib $pic_flag $wl+h $wl$soname $wl+b $wl$install_libdir -o $lib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags' ;; esac fi else # FIXME: insert proper C++ library support _LT_TAGVAR(ld_shlibs, $1)=no fi ;; esac ;; interix[[3-9]]*) _LT_TAGVAR(hardcode_direct, $1)=no _LT_TAGVAR(hardcode_shlibpath_var, $1)=no _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='$wl-rpath,$libdir' _LT_TAGVAR(export_dynamic_flag_spec, $1)='$wl-E' # Hack: On Interix 3.x, we cannot compile PIC because of a broken gcc. # Instead, shared libraries are loaded at an image base (0x10000000 by # default) and relocated if they conflict, which is a slow very memory # consuming and fragmenting process. To avoid this, we pick a random, # 256 KiB-aligned image base between 0x50000000 and 0x6FFC0000 at link # time. Moving up from 0x10000000 also allows more sbrk(2) space. _LT_TAGVAR(archive_cmds, $1)='$CC -shared $pic_flag $libobjs $deplibs $compiler_flags $wl-h,$soname $wl--image-base,`expr ${RANDOM-$$} % 4096 / 2 \* 262144 + 1342177280` -o $lib' _LT_TAGVAR(archive_expsym_cmds, $1)='sed "s|^|_|" $export_symbols >$output_objdir/$soname.expsym~$CC -shared $pic_flag $libobjs $deplibs $compiler_flags $wl-h,$soname $wl--retain-symbols-file,$output_objdir/$soname.expsym $wl--image-base,`expr ${RANDOM-$$} % 4096 / 2 \* 262144 + 1342177280` -o $lib' ;; irix5* | irix6*) case $cc_basename in CC*) # SGI C++ _LT_TAGVAR(archive_cmds, $1)='$CC -shared -all -multigot $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags -soname $soname `test -n "$verstring" && func_echo_all "-set_version $verstring"` -update_registry $output_objdir/so_locations -o $lib' # Archives containing C++ object files must be created using # "CC -ar", where "CC" is the IRIX C++ compiler. This is # necessary to make sure instantiated templates are included # in the archive. _LT_TAGVAR(old_archive_cmds, $1)='$CC -ar -WR,-u -o $oldlib $oldobjs' ;; *) if test yes = "$GXX"; then if test no = "$with_gnu_ld"; then _LT_TAGVAR(archive_cmds, $1)='$CC -shared $pic_flag -nostdlib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags $wl-soname $wl$soname `test -n "$verstring" && func_echo_all "$wl-set_version $wl$verstring"` $wl-update_registry $wl$output_objdir/so_locations -o $lib' else _LT_TAGVAR(archive_cmds, $1)='$CC -shared $pic_flag -nostdlib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags $wl-soname $wl$soname `test -n "$verstring" && func_echo_all "$wl-set_version $wl$verstring"` -o $lib' fi fi _LT_TAGVAR(link_all_deplibs, $1)=yes ;; esac _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='$wl-rpath $wl$libdir' _LT_TAGVAR(hardcode_libdir_separator, $1)=: _LT_TAGVAR(inherit_rpath, $1)=yes ;; linux* | k*bsd*-gnu | kopensolaris*-gnu | gnu*) case $cc_basename in KCC*) # Kuck and Associates, Inc. (KAI) C++ Compiler # KCC will only create a shared library if the output file # ends with ".so" (or ".sl" for HP-UX), so rename the library # to its proper name (with version) after linking. _LT_TAGVAR(archive_cmds, $1)='tempext=`echo $shared_ext | $SED -e '\''s/\([[^()0-9A-Za-z{}]]\)/\\\\\1/g'\''`; templib=`echo $lib | $SED -e "s/\$tempext\..*/.so/"`; $CC $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags --soname $soname -o \$templib; mv \$templib $lib' _LT_TAGVAR(archive_expsym_cmds, $1)='tempext=`echo $shared_ext | $SED -e '\''s/\([[^()0-9A-Za-z{}]]\)/\\\\\1/g'\''`; templib=`echo $lib | $SED -e "s/\$tempext\..*/.so/"`; $CC $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags --soname $soname -o \$templib $wl-retain-symbols-file,$export_symbols; mv \$templib $lib' # Commands to make compiler produce verbose output that lists # what "hidden" libraries, object files and flags are used when # linking a shared library. # # There doesn't appear to be a way to prevent this compiler from # explicitly linking system object files so we need to strip them # from the output so that they don't get included in the library # dependencies. output_verbose_link_cmd='templist=`$CC $CFLAGS -v conftest.$objext -o libconftest$shared_ext 2>&1 | $GREP "ld"`; rm -f libconftest$shared_ext; list= ; for z in $templist; do case $z in conftest.$objext) list="$list $z";; *.$objext);; *) list="$list $z";;esac; done; func_echo_all "$list"' _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='$wl-rpath,$libdir' _LT_TAGVAR(export_dynamic_flag_spec, $1)='$wl--export-dynamic' # Archives containing C++ object files must be created using # "CC -Bstatic", where "CC" is the KAI C++ compiler. _LT_TAGVAR(old_archive_cmds, $1)='$CC -Bstatic -o $oldlib $oldobjs' ;; icpc* | ecpc* ) # Intel C++ with_gnu_ld=yes # version 8.0 and above of icpc choke on multiply defined symbols # if we add $predep_objects and $postdep_objects, however 7.1 and # earlier do not add the objects themselves. case `$CC -V 2>&1` in *"Version 7."*) _LT_TAGVAR(archive_cmds, $1)='$CC -shared $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags $wl-soname $wl$soname -o $lib' _LT_TAGVAR(archive_expsym_cmds, $1)='$CC -shared $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags $wl-soname $wl$soname $wl-retain-symbols-file $wl$export_symbols -o $lib' ;; *) # Version 8.0 or newer tmp_idyn= case $host_cpu in ia64*) tmp_idyn=' -i_dynamic';; esac _LT_TAGVAR(archive_cmds, $1)='$CC -shared'"$tmp_idyn"' $libobjs $deplibs $compiler_flags $wl-soname $wl$soname -o $lib' _LT_TAGVAR(archive_expsym_cmds, $1)='$CC -shared'"$tmp_idyn"' $libobjs $deplibs $compiler_flags $wl-soname $wl$soname $wl-retain-symbols-file $wl$export_symbols -o $lib' ;; esac _LT_TAGVAR(archive_cmds_need_lc, $1)=no _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='$wl-rpath,$libdir' _LT_TAGVAR(export_dynamic_flag_spec, $1)='$wl--export-dynamic' _LT_TAGVAR(whole_archive_flag_spec, $1)='$wl--whole-archive$convenience $wl--no-whole-archive' ;; pgCC* | pgcpp*) # Portland Group C++ compiler case `$CC -V` in *pgCC\ [[1-5]].* | *pgcpp\ [[1-5]].*) _LT_TAGVAR(prelink_cmds, $1)='tpldir=Template.dir~ rm -rf $tpldir~ $CC --prelink_objects --instantiation_dir $tpldir $objs $libobjs $compile_deplibs~ compile_command="$compile_command `find $tpldir -name \*.o | sort | $NL2SP`"' _LT_TAGVAR(old_archive_cmds, $1)='tpldir=Template.dir~ rm -rf $tpldir~ $CC --prelink_objects --instantiation_dir $tpldir $oldobjs$old_deplibs~ $AR $AR_FLAGS $oldlib$oldobjs$old_deplibs `find $tpldir -name \*.o | sort | $NL2SP`~ $RANLIB $oldlib' _LT_TAGVAR(archive_cmds, $1)='tpldir=Template.dir~ rm -rf $tpldir~ $CC --prelink_objects --instantiation_dir $tpldir $predep_objects $libobjs $deplibs $convenience $postdep_objects~ $CC -shared $pic_flag $predep_objects $libobjs $deplibs `find $tpldir -name \*.o | sort | $NL2SP` $postdep_objects $compiler_flags $wl-soname $wl$soname -o $lib' _LT_TAGVAR(archive_expsym_cmds, $1)='tpldir=Template.dir~ rm -rf $tpldir~ $CC --prelink_objects --instantiation_dir $tpldir $predep_objects $libobjs $deplibs $convenience $postdep_objects~ $CC -shared $pic_flag $predep_objects $libobjs $deplibs `find $tpldir -name \*.o | sort | $NL2SP` $postdep_objects $compiler_flags $wl-soname $wl$soname $wl-retain-symbols-file $wl$export_symbols -o $lib' ;; *) # Version 6 and above use weak symbols _LT_TAGVAR(archive_cmds, $1)='$CC -shared $pic_flag $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags $wl-soname $wl$soname -o $lib' _LT_TAGVAR(archive_expsym_cmds, $1)='$CC -shared $pic_flag $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags $wl-soname $wl$soname $wl-retain-symbols-file $wl$export_symbols -o $lib' ;; esac _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='$wl--rpath $wl$libdir' _LT_TAGVAR(export_dynamic_flag_spec, $1)='$wl--export-dynamic' _LT_TAGVAR(whole_archive_flag_spec, $1)='$wl--whole-archive`for conv in $convenience\"\"; do test -n \"$conv\" && new_convenience=\"$new_convenience,$conv\"; done; func_echo_all \"$new_convenience\"` $wl--no-whole-archive' ;; cxx*) # Compaq C++ _LT_TAGVAR(archive_cmds, $1)='$CC -shared $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags $wl-soname $wl$soname -o $lib' _LT_TAGVAR(archive_expsym_cmds, $1)='$CC -shared $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags $wl-soname $wl$soname -o $lib $wl-retain-symbols-file $wl$export_symbols' runpath_var=LD_RUN_PATH _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='-rpath $libdir' _LT_TAGVAR(hardcode_libdir_separator, $1)=: # Commands to make compiler produce verbose output that lists # what "hidden" libraries, object files and flags are used when # linking a shared library. # # There doesn't appear to be a way to prevent this compiler from # explicitly linking system object files so we need to strip them # from the output so that they don't get included in the library # dependencies. output_verbose_link_cmd='templist=`$CC -shared $CFLAGS -v conftest.$objext 2>&1 | $GREP "ld"`; templist=`func_echo_all "$templist" | $SED "s/\(^.*ld.*\)\( .*ld .*$\)/\1/"`; list= ; for z in $templist; do case $z in conftest.$objext) list="$list $z";; *.$objext);; *) list="$list $z";;esac; done; func_echo_all "X$list" | $Xsed' ;; xl* | mpixl* | bgxl*) # IBM XL 8.0 on PPC, with GNU ld _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='$wl-rpath $wl$libdir' _LT_TAGVAR(export_dynamic_flag_spec, $1)='$wl--export-dynamic' _LT_TAGVAR(archive_cmds, $1)='$CC -qmkshrobj $libobjs $deplibs $compiler_flags $wl-soname $wl$soname -o $lib' if test yes = "$supports_anon_versioning"; then _LT_TAGVAR(archive_expsym_cmds, $1)='echo "{ global:" > $output_objdir/$libname.ver~ cat $export_symbols | sed -e "s/\(.*\)/\1;/" >> $output_objdir/$libname.ver~ echo "local: *; };" >> $output_objdir/$libname.ver~ $CC -qmkshrobj $libobjs $deplibs $compiler_flags $wl-soname $wl$soname $wl-version-script $wl$output_objdir/$libname.ver -o $lib' fi ;; *) case `$CC -V 2>&1 | sed 5q` in *Sun\ C*) # Sun C++ 5.9 _LT_TAGVAR(no_undefined_flag, $1)=' -zdefs' _LT_TAGVAR(archive_cmds, $1)='$CC -G$allow_undefined_flag -h$soname -o $lib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags' _LT_TAGVAR(archive_expsym_cmds, $1)='$CC -G$allow_undefined_flag -h$soname -o $lib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags $wl-retain-symbols-file $wl$export_symbols' _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='-R$libdir' _LT_TAGVAR(whole_archive_flag_spec, $1)='$wl--whole-archive`new_convenience=; for conv in $convenience\"\"; do test -z \"$conv\" || new_convenience=\"$new_convenience,$conv\"; done; func_echo_all \"$new_convenience\"` $wl--no-whole-archive' _LT_TAGVAR(compiler_needs_object, $1)=yes # Not sure whether something based on # $CC $CFLAGS -v conftest.$objext -o libconftest$shared_ext 2>&1 # would be better. output_verbose_link_cmd='func_echo_all' # Archives containing C++ object files must be created using # "CC -xar", where "CC" is the Sun C++ compiler. This is # necessary to make sure instantiated templates are included # in the archive. _LT_TAGVAR(old_archive_cmds, $1)='$CC -xar -o $oldlib $oldobjs' ;; esac ;; esac ;; lynxos*) # FIXME: insert proper C++ library support _LT_TAGVAR(ld_shlibs, $1)=no ;; m88k*) # FIXME: insert proper C++ library support _LT_TAGVAR(ld_shlibs, $1)=no ;; mvs*) case $cc_basename in cxx*) # FIXME: insert proper C++ library support _LT_TAGVAR(ld_shlibs, $1)=no ;; *) # FIXME: insert proper C++ library support _LT_TAGVAR(ld_shlibs, $1)=no ;; esac ;; netbsd*) if echo __ELF__ | $CC -E - | $GREP __ELF__ >/dev/null; then _LT_TAGVAR(archive_cmds, $1)='$LD -Bshareable -o $lib $predep_objects $libobjs $deplibs $postdep_objects $linker_flags' wlarc= _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='-R$libdir' _LT_TAGVAR(hardcode_direct, $1)=yes _LT_TAGVAR(hardcode_shlibpath_var, $1)=no fi # Workaround some broken pre-1.5 toolchains output_verbose_link_cmd='$CC -shared $CFLAGS -v conftest.$objext 2>&1 | $GREP conftest.$objext | $SED -e "s:-lgcc -lc -lgcc::"' ;; *nto* | *qnx*) _LT_TAGVAR(ld_shlibs, $1)=yes ;; openbsd* | bitrig*) if test -f /usr/libexec/ld.so; then _LT_TAGVAR(hardcode_direct, $1)=yes _LT_TAGVAR(hardcode_shlibpath_var, $1)=no _LT_TAGVAR(hardcode_direct_absolute, $1)=yes _LT_TAGVAR(archive_cmds, $1)='$CC -shared $pic_flag $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags -o $lib' _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='$wl-rpath,$libdir' if test -z "`echo __ELF__ | $CC -E - | grep __ELF__`"; then _LT_TAGVAR(archive_expsym_cmds, $1)='$CC -shared $pic_flag $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags $wl-retain-symbols-file,$export_symbols -o $lib' _LT_TAGVAR(export_dynamic_flag_spec, $1)='$wl-E' _LT_TAGVAR(whole_archive_flag_spec, $1)=$wlarc'--whole-archive$convenience '$wlarc'--no-whole-archive' fi output_verbose_link_cmd=func_echo_all else _LT_TAGVAR(ld_shlibs, $1)=no fi ;; osf3* | osf4* | osf5*) case $cc_basename in KCC*) # Kuck and Associates, Inc. (KAI) C++ Compiler # KCC will only create a shared library if the output file # ends with ".so" (or ".sl" for HP-UX), so rename the library # to its proper name (with version) after linking. _LT_TAGVAR(archive_cmds, $1)='tempext=`echo $shared_ext | $SED -e '\''s/\([[^()0-9A-Za-z{}]]\)/\\\\\1/g'\''`; templib=`echo "$lib" | $SED -e "s/\$tempext\..*/.so/"`; $CC $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags --soname $soname -o \$templib; mv \$templib $lib' _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='$wl-rpath,$libdir' _LT_TAGVAR(hardcode_libdir_separator, $1)=: # Archives containing C++ object files must be created using # the KAI C++ compiler. case $host in osf3*) _LT_TAGVAR(old_archive_cmds, $1)='$CC -Bstatic -o $oldlib $oldobjs' ;; *) _LT_TAGVAR(old_archive_cmds, $1)='$CC -o $oldlib $oldobjs' ;; esac ;; RCC*) # Rational C++ 2.4.1 # FIXME: insert proper C++ library support _LT_TAGVAR(ld_shlibs, $1)=no ;; cxx*) case $host in osf3*) _LT_TAGVAR(allow_undefined_flag, $1)=' $wl-expect_unresolved $wl\*' _LT_TAGVAR(archive_cmds, $1)='$CC -shared$allow_undefined_flag $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags $wl-soname $soname `test -n "$verstring" && func_echo_all "$wl-set_version $verstring"` -update_registry $output_objdir/so_locations -o $lib' _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='$wl-rpath $wl$libdir' ;; *) _LT_TAGVAR(allow_undefined_flag, $1)=' -expect_unresolved \*' _LT_TAGVAR(archive_cmds, $1)='$CC -shared$allow_undefined_flag $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags -msym -soname $soname `test -n "$verstring" && func_echo_all "-set_version $verstring"` -update_registry $output_objdir/so_locations -o $lib' _LT_TAGVAR(archive_expsym_cmds, $1)='for i in `cat $export_symbols`; do printf "%s %s\\n" -exported_symbol "\$i" >> $lib.exp; done~ echo "-hidden">> $lib.exp~ $CC -shared$allow_undefined_flag $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags -msym -soname $soname $wl-input $wl$lib.exp `test -n "$verstring" && $ECHO "-set_version $verstring"` -update_registry $output_objdir/so_locations -o $lib~ $RM $lib.exp' _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='-rpath $libdir' ;; esac _LT_TAGVAR(hardcode_libdir_separator, $1)=: # Commands to make compiler produce verbose output that lists # what "hidden" libraries, object files and flags are used when # linking a shared library. # # There doesn't appear to be a way to prevent this compiler from # explicitly linking system object files so we need to strip them # from the output so that they don't get included in the library # dependencies. output_verbose_link_cmd='templist=`$CC -shared $CFLAGS -v conftest.$objext 2>&1 | $GREP "ld" | $GREP -v "ld:"`; templist=`func_echo_all "$templist" | $SED "s/\(^.*ld.*\)\( .*ld.*$\)/\1/"`; list= ; for z in $templist; do case $z in conftest.$objext) list="$list $z";; *.$objext);; *) list="$list $z";;esac; done; func_echo_all "$list"' ;; *) if test yes,no = "$GXX,$with_gnu_ld"; then _LT_TAGVAR(allow_undefined_flag, $1)=' $wl-expect_unresolved $wl\*' case $host in osf3*) _LT_TAGVAR(archive_cmds, $1)='$CC -shared -nostdlib $allow_undefined_flag $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags $wl-soname $wl$soname `test -n "$verstring" && func_echo_all "$wl-set_version $wl$verstring"` $wl-update_registry $wl$output_objdir/so_locations -o $lib' ;; *) _LT_TAGVAR(archive_cmds, $1)='$CC -shared $pic_flag -nostdlib $allow_undefined_flag $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags $wl-msym $wl-soname $wl$soname `test -n "$verstring" && func_echo_all "$wl-set_version $wl$verstring"` $wl-update_registry $wl$output_objdir/so_locations -o $lib' ;; esac _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='$wl-rpath $wl$libdir' _LT_TAGVAR(hardcode_libdir_separator, $1)=: # Commands to make compiler produce verbose output that lists # what "hidden" libraries, object files and flags are used when # linking a shared library. output_verbose_link_cmd='$CC -shared $CFLAGS -v conftest.$objext 2>&1 | $GREP -v "^Configured with:" | $GREP "\-L"' else # FIXME: insert proper C++ library support _LT_TAGVAR(ld_shlibs, $1)=no fi ;; esac ;; psos*) # FIXME: insert proper C++ library support _LT_TAGVAR(ld_shlibs, $1)=no ;; sunos4*) case $cc_basename in CC*) # Sun C++ 4.x # FIXME: insert proper C++ library support _LT_TAGVAR(ld_shlibs, $1)=no ;; lcc*) # Lucid # FIXME: insert proper C++ library support _LT_TAGVAR(ld_shlibs, $1)=no ;; *) # FIXME: insert proper C++ library support _LT_TAGVAR(ld_shlibs, $1)=no ;; esac ;; solaris*) case $cc_basename in CC* | sunCC*) # Sun C++ 4.2, 5.x and Centerline C++ _LT_TAGVAR(archive_cmds_need_lc,$1)=yes _LT_TAGVAR(no_undefined_flag, $1)=' -zdefs' _LT_TAGVAR(archive_cmds, $1)='$CC -G$allow_undefined_flag -h$soname -o $lib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags' _LT_TAGVAR(archive_expsym_cmds, $1)='echo "{ global:" > $lib.exp~cat $export_symbols | $SED -e "s/\(.*\)/\1;/" >> $lib.exp~echo "local: *; };" >> $lib.exp~ $CC -G$allow_undefined_flag $wl-M $wl$lib.exp -h$soname -o $lib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags~$RM $lib.exp' _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='-R$libdir' _LT_TAGVAR(hardcode_shlibpath_var, $1)=no case $host_os in solaris2.[[0-5]] | solaris2.[[0-5]].*) ;; *) # The compiler driver will combine and reorder linker options, # but understands '-z linker_flag'. # Supported since Solaris 2.6 (maybe 2.5.1?) _LT_TAGVAR(whole_archive_flag_spec, $1)='-z allextract$convenience -z defaultextract' ;; esac _LT_TAGVAR(link_all_deplibs, $1)=yes output_verbose_link_cmd='func_echo_all' # Archives containing C++ object files must be created using # "CC -xar", where "CC" is the Sun C++ compiler. This is # necessary to make sure instantiated templates are included # in the archive. _LT_TAGVAR(old_archive_cmds, $1)='$CC -xar -o $oldlib $oldobjs' ;; gcx*) # Green Hills C++ Compiler _LT_TAGVAR(archive_cmds, $1)='$CC -shared $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags $wl-h $wl$soname -o $lib' # The C++ compiler must be used to create the archive. _LT_TAGVAR(old_archive_cmds, $1)='$CC $LDFLAGS -archive -o $oldlib $oldobjs' ;; *) # GNU C++ compiler with Solaris linker if test yes,no = "$GXX,$with_gnu_ld"; then _LT_TAGVAR(no_undefined_flag, $1)=' $wl-z ${wl}defs' if $CC --version | $GREP -v '^2\.7' > /dev/null; then _LT_TAGVAR(archive_cmds, $1)='$CC -shared $pic_flag -nostdlib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags $wl-h $wl$soname -o $lib' _LT_TAGVAR(archive_expsym_cmds, $1)='echo "{ global:" > $lib.exp~cat $export_symbols | $SED -e "s/\(.*\)/\1;/" >> $lib.exp~echo "local: *; };" >> $lib.exp~ $CC -shared $pic_flag -nostdlib $wl-M $wl$lib.exp $wl-h $wl$soname -o $lib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags~$RM $lib.exp' # Commands to make compiler produce verbose output that lists # what "hidden" libraries, object files and flags are used when # linking a shared library. output_verbose_link_cmd='$CC -shared $CFLAGS -v conftest.$objext 2>&1 | $GREP -v "^Configured with:" | $GREP "\-L"' else # g++ 2.7 appears to require '-G' NOT '-shared' on this # platform. _LT_TAGVAR(archive_cmds, $1)='$CC -G -nostdlib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags $wl-h $wl$soname -o $lib' _LT_TAGVAR(archive_expsym_cmds, $1)='echo "{ global:" > $lib.exp~cat $export_symbols | $SED -e "s/\(.*\)/\1;/" >> $lib.exp~echo "local: *; };" >> $lib.exp~ $CC -G -nostdlib $wl-M $wl$lib.exp $wl-h $wl$soname -o $lib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags~$RM $lib.exp' # Commands to make compiler produce verbose output that lists # what "hidden" libraries, object files and flags are used when # linking a shared library. output_verbose_link_cmd='$CC -G $CFLAGS -v conftest.$objext 2>&1 | $GREP -v "^Configured with:" | $GREP "\-L"' fi _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='$wl-R $wl$libdir' case $host_os in solaris2.[[0-5]] | solaris2.[[0-5]].*) ;; *) _LT_TAGVAR(whole_archive_flag_spec, $1)='$wl-z ${wl}allextract$convenience $wl-z ${wl}defaultextract' ;; esac fi ;; esac ;; sysv4*uw2* | sysv5OpenUNIX* | sysv5UnixWare7.[[01]].[[10]]* | unixware7* | sco3.2v5.0.[[024]]*) _LT_TAGVAR(no_undefined_flag, $1)='$wl-z,text' _LT_TAGVAR(archive_cmds_need_lc, $1)=no _LT_TAGVAR(hardcode_shlibpath_var, $1)=no runpath_var='LD_RUN_PATH' case $cc_basename in CC*) _LT_TAGVAR(archive_cmds, $1)='$CC -G $wl-h,$soname -o $lib $libobjs $deplibs $compiler_flags' _LT_TAGVAR(archive_expsym_cmds, $1)='$CC -G $wl-Bexport:$export_symbols $wl-h,$soname -o $lib $libobjs $deplibs $compiler_flags' ;; *) _LT_TAGVAR(archive_cmds, $1)='$CC -shared $wl-h,$soname -o $lib $libobjs $deplibs $compiler_flags' _LT_TAGVAR(archive_expsym_cmds, $1)='$CC -shared $wl-Bexport:$export_symbols $wl-h,$soname -o $lib $libobjs $deplibs $compiler_flags' ;; esac ;; sysv5* | sco3.2v5* | sco5v6*) # Note: We CANNOT use -z defs as we might desire, because we do not # link with -lc, and that would cause any symbols used from libc to # always be unresolved, which means just about no library would # ever link correctly. If we're not using GNU ld we use -z text # though, which does catch some bad symbols but isn't as heavy-handed # as -z defs. _LT_TAGVAR(no_undefined_flag, $1)='$wl-z,text' _LT_TAGVAR(allow_undefined_flag, $1)='$wl-z,nodefs' _LT_TAGVAR(archive_cmds_need_lc, $1)=no _LT_TAGVAR(hardcode_shlibpath_var, $1)=no _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='$wl-R,$libdir' _LT_TAGVAR(hardcode_libdir_separator, $1)=':' _LT_TAGVAR(link_all_deplibs, $1)=yes _LT_TAGVAR(export_dynamic_flag_spec, $1)='$wl-Bexport' runpath_var='LD_RUN_PATH' case $cc_basename in CC*) _LT_TAGVAR(archive_cmds, $1)='$CC -G $wl-h,$soname -o $lib $libobjs $deplibs $compiler_flags' _LT_TAGVAR(archive_expsym_cmds, $1)='$CC -G $wl-Bexport:$export_symbols $wl-h,$soname -o $lib $libobjs $deplibs $compiler_flags' _LT_TAGVAR(old_archive_cmds, $1)='$CC -Tprelink_objects $oldobjs~ '"$_LT_TAGVAR(old_archive_cmds, $1)" _LT_TAGVAR(reload_cmds, $1)='$CC -Tprelink_objects $reload_objs~ '"$_LT_TAGVAR(reload_cmds, $1)" ;; *) _LT_TAGVAR(archive_cmds, $1)='$CC -shared $wl-h,$soname -o $lib $libobjs $deplibs $compiler_flags' _LT_TAGVAR(archive_expsym_cmds, $1)='$CC -shared $wl-Bexport:$export_symbols $wl-h,$soname -o $lib $libobjs $deplibs $compiler_flags' ;; esac ;; tandem*) case $cc_basename in NCC*) # NonStop-UX NCC 3.20 # FIXME: insert proper C++ library support _LT_TAGVAR(ld_shlibs, $1)=no ;; *) # FIXME: insert proper C++ library support _LT_TAGVAR(ld_shlibs, $1)=no ;; esac ;; vxworks*) # FIXME: insert proper C++ library support _LT_TAGVAR(ld_shlibs, $1)=no ;; *) # FIXME: insert proper C++ library support _LT_TAGVAR(ld_shlibs, $1)=no ;; esac AC_MSG_RESULT([$_LT_TAGVAR(ld_shlibs, $1)]) test no = "$_LT_TAGVAR(ld_shlibs, $1)" && can_build_shared=no _LT_TAGVAR(GCC, $1)=$GXX _LT_TAGVAR(LD, $1)=$LD ## CAVEAT EMPTOR: ## There is no encapsulation within the following macros, do not change ## the running order or otherwise move them around unless you know exactly ## what you are doing... _LT_SYS_HIDDEN_LIBDEPS($1) _LT_COMPILER_PIC($1) _LT_COMPILER_C_O($1) _LT_COMPILER_FILE_LOCKS($1) _LT_LINKER_SHLIBS($1) _LT_SYS_DYNAMIC_LINKER($1) _LT_LINKER_HARDCODE_LIBPATH($1) _LT_CONFIG($1) fi # test -n "$compiler" CC=$lt_save_CC CFLAGS=$lt_save_CFLAGS LDCXX=$LD LD=$lt_save_LD GCC=$lt_save_GCC with_gnu_ld=$lt_save_with_gnu_ld lt_cv_path_LDCXX=$lt_cv_path_LD lt_cv_path_LD=$lt_save_path_LD lt_cv_prog_gnu_ldcxx=$lt_cv_prog_gnu_ld lt_cv_prog_gnu_ld=$lt_save_with_gnu_ld fi # test yes != "$_lt_caught_CXX_error" AC_LANG_POP ])# _LT_LANG_CXX_CONFIG # _LT_FUNC_STRIPNAME_CNF # ---------------------- # func_stripname_cnf prefix suffix name # strip PREFIX and SUFFIX off of NAME. # PREFIX and SUFFIX must not contain globbing or regex special # characters, hashes, percent signs, but SUFFIX may contain a leading # dot (in which case that matches only a dot). # # This function is identical to the (non-XSI) version of func_stripname, # except this one can be used by m4 code that may be executed by configure, # rather than the libtool script. m4_defun([_LT_FUNC_STRIPNAME_CNF],[dnl AC_REQUIRE([_LT_DECL_SED]) AC_REQUIRE([_LT_PROG_ECHO_BACKSLASH]) func_stripname_cnf () { case @S|@2 in .*) func_stripname_result=`$ECHO "@S|@3" | $SED "s%^@S|@1%%; s%\\\\@S|@2\$%%"`;; *) func_stripname_result=`$ECHO "@S|@3" | $SED "s%^@S|@1%%; s%@S|@2\$%%"`;; esac } # func_stripname_cnf ])# _LT_FUNC_STRIPNAME_CNF # _LT_SYS_HIDDEN_LIBDEPS([TAGNAME]) # --------------------------------- # Figure out "hidden" library dependencies from verbose # compiler output when linking a shared library. # Parse the compiler output and extract the necessary # objects, libraries and library flags. m4_defun([_LT_SYS_HIDDEN_LIBDEPS], [m4_require([_LT_FILEUTILS_DEFAULTS])dnl AC_REQUIRE([_LT_FUNC_STRIPNAME_CNF])dnl # Dependencies to place before and after the object being linked: _LT_TAGVAR(predep_objects, $1)= _LT_TAGVAR(postdep_objects, $1)= _LT_TAGVAR(predeps, $1)= _LT_TAGVAR(postdeps, $1)= _LT_TAGVAR(compiler_lib_search_path, $1)= dnl we can't use the lt_simple_compile_test_code here, dnl because it contains code intended for an executable, dnl not a library. It's possible we should let each dnl tag define a new lt_????_link_test_code variable, dnl but it's only used here... m4_if([$1], [], [cat > conftest.$ac_ext <<_LT_EOF int a; void foo (void) { a = 0; } _LT_EOF ], [$1], [CXX], [cat > conftest.$ac_ext <<_LT_EOF class Foo { public: Foo (void) { a = 0; } private: int a; }; _LT_EOF ], [$1], [F77], [cat > conftest.$ac_ext <<_LT_EOF subroutine foo implicit none integer*4 a a=0 return end _LT_EOF ], [$1], [FC], [cat > conftest.$ac_ext <<_LT_EOF subroutine foo implicit none integer a a=0 return end _LT_EOF ], [$1], [GCJ], [cat > conftest.$ac_ext <<_LT_EOF public class foo { private int a; public void bar (void) { a = 0; } }; _LT_EOF ], [$1], [GO], [cat > conftest.$ac_ext <<_LT_EOF package foo func foo() { } _LT_EOF ]) _lt_libdeps_save_CFLAGS=$CFLAGS case "$CC $CFLAGS " in #( *\ -flto*\ *) CFLAGS="$CFLAGS -fno-lto" ;; *\ -fwhopr*\ *) CFLAGS="$CFLAGS -fno-whopr" ;; *\ -fuse-linker-plugin*\ *) CFLAGS="$CFLAGS -fno-use-linker-plugin" ;; esac dnl Parse the compiler output and extract the necessary dnl objects, libraries and library flags. if AC_TRY_EVAL(ac_compile); then # Parse the compiler output and extract the necessary # objects, libraries and library flags. # Sentinel used to keep track of whether or not we are before # the conftest object file. pre_test_object_deps_done=no for p in `eval "$output_verbose_link_cmd"`; do case $prev$p in -L* | -R* | -l*) # Some compilers place space between "-{L,R}" and the path. # Remove the space. if test x-L = "$p" || test x-R = "$p"; then prev=$p continue fi # Expand the sysroot to ease extracting the directories later. if test -z "$prev"; then case $p in -L*) func_stripname_cnf '-L' '' "$p"; prev=-L; p=$func_stripname_result ;; -R*) func_stripname_cnf '-R' '' "$p"; prev=-R; p=$func_stripname_result ;; -l*) func_stripname_cnf '-l' '' "$p"; prev=-l; p=$func_stripname_result ;; esac fi case $p in =*) func_stripname_cnf '=' '' "$p"; p=$lt_sysroot$func_stripname_result ;; esac if test no = "$pre_test_object_deps_done"; then case $prev in -L | -R) # Internal compiler library paths should come after those # provided the user. The postdeps already come after the # user supplied libs so there is no need to process them. if test -z "$_LT_TAGVAR(compiler_lib_search_path, $1)"; then _LT_TAGVAR(compiler_lib_search_path, $1)=$prev$p else _LT_TAGVAR(compiler_lib_search_path, $1)="${_LT_TAGVAR(compiler_lib_search_path, $1)} $prev$p" fi ;; # The "-l" case would never come before the object being # linked, so don't bother handling this case. esac else if test -z "$_LT_TAGVAR(postdeps, $1)"; then _LT_TAGVAR(postdeps, $1)=$prev$p else _LT_TAGVAR(postdeps, $1)="${_LT_TAGVAR(postdeps, $1)} $prev$p" fi fi prev= ;; *.lto.$objext) ;; # Ignore GCC LTO objects *.$objext) # This assumes that the test object file only shows up # once in the compiler output. if test "$p" = "conftest.$objext"; then pre_test_object_deps_done=yes continue fi if test no = "$pre_test_object_deps_done"; then if test -z "$_LT_TAGVAR(predep_objects, $1)"; then _LT_TAGVAR(predep_objects, $1)=$p else _LT_TAGVAR(predep_objects, $1)="$_LT_TAGVAR(predep_objects, $1) $p" fi else if test -z "$_LT_TAGVAR(postdep_objects, $1)"; then _LT_TAGVAR(postdep_objects, $1)=$p else _LT_TAGVAR(postdep_objects, $1)="$_LT_TAGVAR(postdep_objects, $1) $p" fi fi ;; *) ;; # Ignore the rest. esac done # Clean up. rm -f a.out a.exe else echo "libtool.m4: error: problem compiling $1 test program" fi $RM -f confest.$objext CFLAGS=$_lt_libdeps_save_CFLAGS # PORTME: override above test on systems where it is broken m4_if([$1], [CXX], [case $host_os in interix[[3-9]]*) # Interix 3.5 installs completely hosed .la files for C++, so rather than # hack all around it, let's just trust "g++" to DTRT. _LT_TAGVAR(predep_objects,$1)= _LT_TAGVAR(postdep_objects,$1)= _LT_TAGVAR(postdeps,$1)= ;; esac ]) case " $_LT_TAGVAR(postdeps, $1) " in *" -lc "*) _LT_TAGVAR(archive_cmds_need_lc, $1)=no ;; esac _LT_TAGVAR(compiler_lib_search_dirs, $1)= if test -n "${_LT_TAGVAR(compiler_lib_search_path, $1)}"; then _LT_TAGVAR(compiler_lib_search_dirs, $1)=`echo " ${_LT_TAGVAR(compiler_lib_search_path, $1)}" | $SED -e 's! -L! !g' -e 's!^ !!'` fi _LT_TAGDECL([], [compiler_lib_search_dirs], [1], [The directories searched by this compiler when creating a shared library]) _LT_TAGDECL([], [predep_objects], [1], [Dependencies to place before and after the objects being linked to create a shared library]) _LT_TAGDECL([], [postdep_objects], [1]) _LT_TAGDECL([], [predeps], [1]) _LT_TAGDECL([], [postdeps], [1]) _LT_TAGDECL([], [compiler_lib_search_path], [1], [The library search path used internally by the compiler when linking a shared library]) ])# _LT_SYS_HIDDEN_LIBDEPS # _LT_LANG_F77_CONFIG([TAG]) # -------------------------- # Ensure that the configuration variables for a Fortran 77 compiler are # suitably defined. These variables are subsequently used by _LT_CONFIG # to write the compiler configuration to 'libtool'. m4_defun([_LT_LANG_F77_CONFIG], [AC_LANG_PUSH(Fortran 77) if test -z "$F77" || test no = "$F77"; then _lt_disable_F77=yes fi _LT_TAGVAR(archive_cmds_need_lc, $1)=no _LT_TAGVAR(allow_undefined_flag, $1)= _LT_TAGVAR(always_export_symbols, $1)=no _LT_TAGVAR(archive_expsym_cmds, $1)= _LT_TAGVAR(export_dynamic_flag_spec, $1)= _LT_TAGVAR(hardcode_direct, $1)=no _LT_TAGVAR(hardcode_direct_absolute, $1)=no _LT_TAGVAR(hardcode_libdir_flag_spec, $1)= _LT_TAGVAR(hardcode_libdir_separator, $1)= _LT_TAGVAR(hardcode_minus_L, $1)=no _LT_TAGVAR(hardcode_automatic, $1)=no _LT_TAGVAR(inherit_rpath, $1)=no _LT_TAGVAR(module_cmds, $1)= _LT_TAGVAR(module_expsym_cmds, $1)= _LT_TAGVAR(link_all_deplibs, $1)=unknown _LT_TAGVAR(old_archive_cmds, $1)=$old_archive_cmds _LT_TAGVAR(reload_flag, $1)=$reload_flag _LT_TAGVAR(reload_cmds, $1)=$reload_cmds _LT_TAGVAR(no_undefined_flag, $1)= _LT_TAGVAR(whole_archive_flag_spec, $1)= _LT_TAGVAR(enable_shared_with_static_runtimes, $1)=no # Source file extension for f77 test sources. ac_ext=f # Object file extension for compiled f77 test sources. objext=o _LT_TAGVAR(objext, $1)=$objext # No sense in running all these tests if we already determined that # the F77 compiler isn't working. Some variables (like enable_shared) # are currently assumed to apply to all compilers on this platform, # and will be corrupted by setting them based on a non-working compiler. if test yes != "$_lt_disable_F77"; then # Code to be used in simple compile tests lt_simple_compile_test_code="\ subroutine t return end " # Code to be used in simple link tests lt_simple_link_test_code="\ program t end " # ltmain only uses $CC for tagged configurations so make sure $CC is set. _LT_TAG_COMPILER # save warnings/boilerplate of simple test code _LT_COMPILER_BOILERPLATE _LT_LINKER_BOILERPLATE # Allow CC to be a program name with arguments. lt_save_CC=$CC lt_save_GCC=$GCC lt_save_CFLAGS=$CFLAGS CC=${F77-"f77"} CFLAGS=$FFLAGS compiler=$CC _LT_TAGVAR(compiler, $1)=$CC _LT_CC_BASENAME([$compiler]) GCC=$G77 if test -n "$compiler"; then AC_MSG_CHECKING([if libtool supports shared libraries]) AC_MSG_RESULT([$can_build_shared]) AC_MSG_CHECKING([whether to build shared libraries]) test no = "$can_build_shared" && enable_shared=no # On AIX, shared libraries and static libraries use the same namespace, and # are all built from PIC. case $host_os in aix3*) test yes = "$enable_shared" && enable_static=no if test -n "$RANLIB"; then archive_cmds="$archive_cmds~\$RANLIB \$lib" postinstall_cmds='$RANLIB $lib' fi ;; aix[[4-9]]*) if test ia64 != "$host_cpu"; then case $enable_shared,$with_aix_soname,$aix_use_runtimelinking in yes,aix,yes) ;; # shared object as lib.so file only yes,svr4,*) ;; # shared object as lib.so archive member only yes,*) enable_static=no ;; # shared object in lib.a archive as well esac fi ;; esac AC_MSG_RESULT([$enable_shared]) AC_MSG_CHECKING([whether to build static libraries]) # Make sure either enable_shared or enable_static is yes. test yes = "$enable_shared" || enable_static=yes AC_MSG_RESULT([$enable_static]) _LT_TAGVAR(GCC, $1)=$G77 _LT_TAGVAR(LD, $1)=$LD ## CAVEAT EMPTOR: ## There is no encapsulation within the following macros, do not change ## the running order or otherwise move them around unless you know exactly ## what you are doing... _LT_COMPILER_PIC($1) _LT_COMPILER_C_O($1) _LT_COMPILER_FILE_LOCKS($1) _LT_LINKER_SHLIBS($1) _LT_SYS_DYNAMIC_LINKER($1) _LT_LINKER_HARDCODE_LIBPATH($1) _LT_CONFIG($1) fi # test -n "$compiler" GCC=$lt_save_GCC CC=$lt_save_CC CFLAGS=$lt_save_CFLAGS fi # test yes != "$_lt_disable_F77" AC_LANG_POP ])# _LT_LANG_F77_CONFIG # _LT_LANG_FC_CONFIG([TAG]) # ------------------------- # Ensure that the configuration variables for a Fortran compiler are # suitably defined. These variables are subsequently used by _LT_CONFIG # to write the compiler configuration to 'libtool'. m4_defun([_LT_LANG_FC_CONFIG], [AC_LANG_PUSH(Fortran) if test -z "$FC" || test no = "$FC"; then _lt_disable_FC=yes fi _LT_TAGVAR(archive_cmds_need_lc, $1)=no _LT_TAGVAR(allow_undefined_flag, $1)= _LT_TAGVAR(always_export_symbols, $1)=no _LT_TAGVAR(archive_expsym_cmds, $1)= _LT_TAGVAR(export_dynamic_flag_spec, $1)= _LT_TAGVAR(hardcode_direct, $1)=no _LT_TAGVAR(hardcode_direct_absolute, $1)=no _LT_TAGVAR(hardcode_libdir_flag_spec, $1)= _LT_TAGVAR(hardcode_libdir_separator, $1)= _LT_TAGVAR(hardcode_minus_L, $1)=no _LT_TAGVAR(hardcode_automatic, $1)=no _LT_TAGVAR(inherit_rpath, $1)=no _LT_TAGVAR(module_cmds, $1)= _LT_TAGVAR(module_expsym_cmds, $1)= _LT_TAGVAR(link_all_deplibs, $1)=unknown _LT_TAGVAR(old_archive_cmds, $1)=$old_archive_cmds _LT_TAGVAR(reload_flag, $1)=$reload_flag _LT_TAGVAR(reload_cmds, $1)=$reload_cmds _LT_TAGVAR(no_undefined_flag, $1)= _LT_TAGVAR(whole_archive_flag_spec, $1)= _LT_TAGVAR(enable_shared_with_static_runtimes, $1)=no # Source file extension for fc test sources. ac_ext=${ac_fc_srcext-f} # Object file extension for compiled fc test sources. objext=o _LT_TAGVAR(objext, $1)=$objext # No sense in running all these tests if we already determined that # the FC compiler isn't working. Some variables (like enable_shared) # are currently assumed to apply to all compilers on this platform, # and will be corrupted by setting them based on a non-working compiler. if test yes != "$_lt_disable_FC"; then # Code to be used in simple compile tests lt_simple_compile_test_code="\ subroutine t return end " # Code to be used in simple link tests lt_simple_link_test_code="\ program t end " # ltmain only uses $CC for tagged configurations so make sure $CC is set. _LT_TAG_COMPILER # save warnings/boilerplate of simple test code _LT_COMPILER_BOILERPLATE _LT_LINKER_BOILERPLATE # Allow CC to be a program name with arguments. lt_save_CC=$CC lt_save_GCC=$GCC lt_save_CFLAGS=$CFLAGS CC=${FC-"f95"} CFLAGS=$FCFLAGS compiler=$CC GCC=$ac_cv_fc_compiler_gnu _LT_TAGVAR(compiler, $1)=$CC _LT_CC_BASENAME([$compiler]) if test -n "$compiler"; then AC_MSG_CHECKING([if libtool supports shared libraries]) AC_MSG_RESULT([$can_build_shared]) AC_MSG_CHECKING([whether to build shared libraries]) test no = "$can_build_shared" && enable_shared=no # On AIX, shared libraries and static libraries use the same namespace, and # are all built from PIC. case $host_os in aix3*) test yes = "$enable_shared" && enable_static=no if test -n "$RANLIB"; then archive_cmds="$archive_cmds~\$RANLIB \$lib" postinstall_cmds='$RANLIB $lib' fi ;; aix[[4-9]]*) if test ia64 != "$host_cpu"; then case $enable_shared,$with_aix_soname,$aix_use_runtimelinking in yes,aix,yes) ;; # shared object as lib.so file only yes,svr4,*) ;; # shared object as lib.so archive member only yes,*) enable_static=no ;; # shared object in lib.a archive as well esac fi ;; esac AC_MSG_RESULT([$enable_shared]) AC_MSG_CHECKING([whether to build static libraries]) # Make sure either enable_shared or enable_static is yes. test yes = "$enable_shared" || enable_static=yes AC_MSG_RESULT([$enable_static]) _LT_TAGVAR(GCC, $1)=$ac_cv_fc_compiler_gnu _LT_TAGVAR(LD, $1)=$LD ## CAVEAT EMPTOR: ## There is no encapsulation within the following macros, do not change ## the running order or otherwise move them around unless you know exactly ## what you are doing... _LT_SYS_HIDDEN_LIBDEPS($1) _LT_COMPILER_PIC($1) _LT_COMPILER_C_O($1) _LT_COMPILER_FILE_LOCKS($1) _LT_LINKER_SHLIBS($1) _LT_SYS_DYNAMIC_LINKER($1) _LT_LINKER_HARDCODE_LIBPATH($1) _LT_CONFIG($1) fi # test -n "$compiler" GCC=$lt_save_GCC CC=$lt_save_CC CFLAGS=$lt_save_CFLAGS fi # test yes != "$_lt_disable_FC" AC_LANG_POP ])# _LT_LANG_FC_CONFIG # _LT_LANG_GCJ_CONFIG([TAG]) # -------------------------- # Ensure that the configuration variables for the GNU Java Compiler compiler # are suitably defined. These variables are subsequently used by _LT_CONFIG # to write the compiler configuration to 'libtool'. m4_defun([_LT_LANG_GCJ_CONFIG], [AC_REQUIRE([LT_PROG_GCJ])dnl AC_LANG_SAVE # Source file extension for Java test sources. ac_ext=java # Object file extension for compiled Java test sources. objext=o _LT_TAGVAR(objext, $1)=$objext # Code to be used in simple compile tests lt_simple_compile_test_code="class foo {}" # Code to be used in simple link tests lt_simple_link_test_code='public class conftest { public static void main(String[[]] argv) {}; }' # ltmain only uses $CC for tagged configurations so make sure $CC is set. _LT_TAG_COMPILER # save warnings/boilerplate of simple test code _LT_COMPILER_BOILERPLATE _LT_LINKER_BOILERPLATE # Allow CC to be a program name with arguments. lt_save_CC=$CC lt_save_CFLAGS=$CFLAGS lt_save_GCC=$GCC GCC=yes CC=${GCJ-"gcj"} CFLAGS=$GCJFLAGS compiler=$CC _LT_TAGVAR(compiler, $1)=$CC _LT_TAGVAR(LD, $1)=$LD _LT_CC_BASENAME([$compiler]) # GCJ did not exist at the time GCC didn't implicitly link libc in. _LT_TAGVAR(archive_cmds_need_lc, $1)=no _LT_TAGVAR(old_archive_cmds, $1)=$old_archive_cmds _LT_TAGVAR(reload_flag, $1)=$reload_flag _LT_TAGVAR(reload_cmds, $1)=$reload_cmds ## CAVEAT EMPTOR: ## There is no encapsulation within the following macros, do not change ## the running order or otherwise move them around unless you know exactly ## what you are doing... if test -n "$compiler"; then _LT_COMPILER_NO_RTTI($1) _LT_COMPILER_PIC($1) _LT_COMPILER_C_O($1) _LT_COMPILER_FILE_LOCKS($1) _LT_LINKER_SHLIBS($1) _LT_LINKER_HARDCODE_LIBPATH($1) _LT_CONFIG($1) fi AC_LANG_RESTORE GCC=$lt_save_GCC CC=$lt_save_CC CFLAGS=$lt_save_CFLAGS ])# _LT_LANG_GCJ_CONFIG # _LT_LANG_GO_CONFIG([TAG]) # -------------------------- # Ensure that the configuration variables for the GNU Go compiler # are suitably defined. These variables are subsequently used by _LT_CONFIG # to write the compiler configuration to 'libtool'. m4_defun([_LT_LANG_GO_CONFIG], [AC_REQUIRE([LT_PROG_GO])dnl AC_LANG_SAVE # Source file extension for Go test sources. ac_ext=go # Object file extension for compiled Go test sources. objext=o _LT_TAGVAR(objext, $1)=$objext # Code to be used in simple compile tests lt_simple_compile_test_code="package main; func main() { }" # Code to be used in simple link tests lt_simple_link_test_code='package main; func main() { }' # ltmain only uses $CC for tagged configurations so make sure $CC is set. _LT_TAG_COMPILER # save warnings/boilerplate of simple test code _LT_COMPILER_BOILERPLATE _LT_LINKER_BOILERPLATE # Allow CC to be a program name with arguments. lt_save_CC=$CC lt_save_CFLAGS=$CFLAGS lt_save_GCC=$GCC GCC=yes CC=${GOC-"gccgo"} CFLAGS=$GOFLAGS compiler=$CC _LT_TAGVAR(compiler, $1)=$CC _LT_TAGVAR(LD, $1)=$LD _LT_CC_BASENAME([$compiler]) # Go did not exist at the time GCC didn't implicitly link libc in. _LT_TAGVAR(archive_cmds_need_lc, $1)=no _LT_TAGVAR(old_archive_cmds, $1)=$old_archive_cmds _LT_TAGVAR(reload_flag, $1)=$reload_flag _LT_TAGVAR(reload_cmds, $1)=$reload_cmds ## CAVEAT EMPTOR: ## There is no encapsulation within the following macros, do not change ## the running order or otherwise move them around unless you know exactly ## what you are doing... if test -n "$compiler"; then _LT_COMPILER_NO_RTTI($1) _LT_COMPILER_PIC($1) _LT_COMPILER_C_O($1) _LT_COMPILER_FILE_LOCKS($1) _LT_LINKER_SHLIBS($1) _LT_LINKER_HARDCODE_LIBPATH($1) _LT_CONFIG($1) fi AC_LANG_RESTORE GCC=$lt_save_GCC CC=$lt_save_CC CFLAGS=$lt_save_CFLAGS ])# _LT_LANG_GO_CONFIG # _LT_LANG_RC_CONFIG([TAG]) # ------------------------- # Ensure that the configuration variables for the Windows resource compiler # are suitably defined. These variables are subsequently used by _LT_CONFIG # to write the compiler configuration to 'libtool'. m4_defun([_LT_LANG_RC_CONFIG], [AC_REQUIRE([LT_PROG_RC])dnl AC_LANG_SAVE # Source file extension for RC test sources. ac_ext=rc # Object file extension for compiled RC test sources. objext=o _LT_TAGVAR(objext, $1)=$objext # Code to be used in simple compile tests lt_simple_compile_test_code='sample MENU { MENUITEM "&Soup", 100, CHECKED }' # Code to be used in simple link tests lt_simple_link_test_code=$lt_simple_compile_test_code # ltmain only uses $CC for tagged configurations so make sure $CC is set. _LT_TAG_COMPILER # save warnings/boilerplate of simple test code _LT_COMPILER_BOILERPLATE _LT_LINKER_BOILERPLATE # Allow CC to be a program name with arguments. lt_save_CC=$CC lt_save_CFLAGS=$CFLAGS lt_save_GCC=$GCC GCC= CC=${RC-"windres"} CFLAGS= compiler=$CC _LT_TAGVAR(compiler, $1)=$CC _LT_CC_BASENAME([$compiler]) _LT_TAGVAR(lt_cv_prog_compiler_c_o, $1)=yes if test -n "$compiler"; then : _LT_CONFIG($1) fi GCC=$lt_save_GCC AC_LANG_RESTORE CC=$lt_save_CC CFLAGS=$lt_save_CFLAGS ])# _LT_LANG_RC_CONFIG # LT_PROG_GCJ # ----------- AC_DEFUN([LT_PROG_GCJ], [m4_ifdef([AC_PROG_GCJ], [AC_PROG_GCJ], [m4_ifdef([A][M_PROG_GCJ], [A][M_PROG_GCJ], [AC_CHECK_TOOL(GCJ, gcj,) test set = "${GCJFLAGS+set}" || GCJFLAGS="-g -O2" AC_SUBST(GCJFLAGS)])])[]dnl ]) # Old name: AU_ALIAS([LT_AC_PROG_GCJ], [LT_PROG_GCJ]) dnl aclocal-1.4 backwards compatibility: dnl AC_DEFUN([LT_AC_PROG_GCJ], []) # LT_PROG_GO # ---------- AC_DEFUN([LT_PROG_GO], [AC_CHECK_TOOL(GOC, gccgo,) ]) # LT_PROG_RC # ---------- AC_DEFUN([LT_PROG_RC], [AC_CHECK_TOOL(RC, windres,) ]) # Old name: AU_ALIAS([LT_AC_PROG_RC], [LT_PROG_RC]) dnl aclocal-1.4 backwards compatibility: dnl AC_DEFUN([LT_AC_PROG_RC], []) # _LT_DECL_EGREP # -------------- # If we don't have a new enough Autoconf to choose the best grep # available, choose the one first in the user's PATH. m4_defun([_LT_DECL_EGREP], [AC_REQUIRE([AC_PROG_EGREP])dnl AC_REQUIRE([AC_PROG_FGREP])dnl test -z "$GREP" && GREP=grep _LT_DECL([], [GREP], [1], [A grep program that handles long lines]) _LT_DECL([], [EGREP], [1], [An ERE matcher]) _LT_DECL([], [FGREP], [1], [A literal string matcher]) dnl Non-bleeding-edge autoconf doesn't subst GREP, so do it here too AC_SUBST([GREP]) ]) # _LT_DECL_OBJDUMP # -------------- # If we don't have a new enough Autoconf to choose the best objdump # available, choose the one first in the user's PATH. m4_defun([_LT_DECL_OBJDUMP], [AC_CHECK_TOOL(OBJDUMP, objdump, false) test -z "$OBJDUMP" && OBJDUMP=objdump _LT_DECL([], [OBJDUMP], [1], [An object symbol dumper]) AC_SUBST([OBJDUMP]) ]) # _LT_DECL_DLLTOOL # ---------------- # Ensure DLLTOOL variable is set. m4_defun([_LT_DECL_DLLTOOL], [AC_CHECK_TOOL(DLLTOOL, dlltool, false) test -z "$DLLTOOL" && DLLTOOL=dlltool _LT_DECL([], [DLLTOOL], [1], [DLL creation program]) AC_SUBST([DLLTOOL]) ]) # _LT_DECL_SED # ------------ # Check for a fully-functional sed program, that truncates # as few characters as possible. Prefer GNU sed if found. m4_defun([_LT_DECL_SED], [AC_PROG_SED test -z "$SED" && SED=sed Xsed="$SED -e 1s/^X//" _LT_DECL([], [SED], [1], [A sed program that does not truncate output]) _LT_DECL([], [Xsed], ["\$SED -e 1s/^X//"], [Sed that helps us avoid accidentally triggering echo(1) options like -n]) ])# _LT_DECL_SED m4_ifndef([AC_PROG_SED], [ ############################################################ # NOTE: This macro has been submitted for inclusion into # # GNU Autoconf as AC_PROG_SED. When it is available in # # a released version of Autoconf we should remove this # # macro and use it instead. # ############################################################ m4_defun([AC_PROG_SED], [AC_MSG_CHECKING([for a sed that does not truncate output]) AC_CACHE_VAL(lt_cv_path_SED, [# Loop through the user's path and test for sed and gsed. # Then use that list of sed's as ones to test for truncation. as_save_IFS=$IFS; IFS=$PATH_SEPARATOR for as_dir in $PATH do IFS=$as_save_IFS test -z "$as_dir" && as_dir=. for lt_ac_prog in sed gsed; do for ac_exec_ext in '' $ac_executable_extensions; do if $as_executable_p "$as_dir/$lt_ac_prog$ac_exec_ext"; then lt_ac_sed_list="$lt_ac_sed_list $as_dir/$lt_ac_prog$ac_exec_ext" fi done done done IFS=$as_save_IFS lt_ac_max=0 lt_ac_count=0 # Add /usr/xpg4/bin/sed as it is typically found on Solaris # along with /bin/sed that truncates output. for lt_ac_sed in $lt_ac_sed_list /usr/xpg4/bin/sed; do test ! -f "$lt_ac_sed" && continue cat /dev/null > conftest.in lt_ac_count=0 echo $ECHO_N "0123456789$ECHO_C" >conftest.in # Check for GNU sed and select it if it is found. if "$lt_ac_sed" --version 2>&1 < /dev/null | grep 'GNU' > /dev/null; then lt_cv_path_SED=$lt_ac_sed break fi while true; do cat conftest.in conftest.in >conftest.tmp mv conftest.tmp conftest.in cp conftest.in conftest.nl echo >>conftest.nl $lt_ac_sed -e 's/a$//' < conftest.nl >conftest.out || break cmp -s conftest.out conftest.nl || break # 10000 chars as input seems more than enough test 10 -lt "$lt_ac_count" && break lt_ac_count=`expr $lt_ac_count + 1` if test "$lt_ac_count" -gt "$lt_ac_max"; then lt_ac_max=$lt_ac_count lt_cv_path_SED=$lt_ac_sed fi done done ]) SED=$lt_cv_path_SED AC_SUBST([SED]) AC_MSG_RESULT([$SED]) ])#AC_PROG_SED ])#m4_ifndef # Old name: AU_ALIAS([LT_AC_PROG_SED], [AC_PROG_SED]) dnl aclocal-1.4 backwards compatibility: dnl AC_DEFUN([LT_AC_PROG_SED], []) # _LT_CHECK_SHELL_FEATURES # ------------------------ # Find out whether the shell is Bourne or XSI compatible, # or has some other useful features. m4_defun([_LT_CHECK_SHELL_FEATURES], [if ( (MAIL=60; unset MAIL) || exit) >/dev/null 2>&1; then lt_unset=unset else lt_unset=false fi _LT_DECL([], [lt_unset], [0], [whether the shell understands "unset"])dnl # test EBCDIC or ASCII case `echo X|tr X '\101'` in A) # ASCII based system # \n is not interpreted correctly by Solaris 8 /usr/ucb/tr lt_SP2NL='tr \040 \012' lt_NL2SP='tr \015\012 \040\040' ;; *) # EBCDIC based system lt_SP2NL='tr \100 \n' lt_NL2SP='tr \r\n \100\100' ;; esac _LT_DECL([SP2NL], [lt_SP2NL], [1], [turn spaces into newlines])dnl _LT_DECL([NL2SP], [lt_NL2SP], [1], [turn newlines into spaces])dnl ])# _LT_CHECK_SHELL_FEATURES # _LT_PATH_CONVERSION_FUNCTIONS # ----------------------------- # Determine what file name conversion functions should be used by # func_to_host_file (and, implicitly, by func_to_host_path). These are needed # for certain cross-compile configurations and native mingw. m4_defun([_LT_PATH_CONVERSION_FUNCTIONS], [AC_REQUIRE([AC_CANONICAL_HOST])dnl AC_REQUIRE([AC_CANONICAL_BUILD])dnl AC_MSG_CHECKING([how to convert $build file names to $host format]) AC_CACHE_VAL(lt_cv_to_host_file_cmd, [case $host in *-*-mingw* ) case $build in *-*-mingw* ) # actually msys lt_cv_to_host_file_cmd=func_convert_file_msys_to_w32 ;; *-*-cygwin* ) lt_cv_to_host_file_cmd=func_convert_file_cygwin_to_w32 ;; * ) # otherwise, assume *nix lt_cv_to_host_file_cmd=func_convert_file_nix_to_w32 ;; esac ;; *-*-cygwin* ) case $build in *-*-mingw* ) # actually msys lt_cv_to_host_file_cmd=func_convert_file_msys_to_cygwin ;; *-*-cygwin* ) lt_cv_to_host_file_cmd=func_convert_file_noop ;; * ) # otherwise, assume *nix lt_cv_to_host_file_cmd=func_convert_file_nix_to_cygwin ;; esac ;; * ) # unhandled hosts (and "normal" native builds) lt_cv_to_host_file_cmd=func_convert_file_noop ;; esac ]) to_host_file_cmd=$lt_cv_to_host_file_cmd AC_MSG_RESULT([$lt_cv_to_host_file_cmd]) _LT_DECL([to_host_file_cmd], [lt_cv_to_host_file_cmd], [0], [convert $build file names to $host format])dnl AC_MSG_CHECKING([how to convert $build file names to toolchain format]) AC_CACHE_VAL(lt_cv_to_tool_file_cmd, [#assume ordinary cross tools, or native build. lt_cv_to_tool_file_cmd=func_convert_file_noop case $host in *-*-mingw* ) case $build in *-*-mingw* ) # actually msys lt_cv_to_tool_file_cmd=func_convert_file_msys_to_w32 ;; esac ;; esac ]) to_tool_file_cmd=$lt_cv_to_tool_file_cmd AC_MSG_RESULT([$lt_cv_to_tool_file_cmd]) _LT_DECL([to_tool_file_cmd], [lt_cv_to_tool_file_cmd], [0], [convert $build files to toolchain format])dnl ])# _LT_PATH_CONVERSION_FUNCTIONS xrdp-0.9.5/m4/ax_append_flag.m4000644 001751 001751 00000005331 13127114621 016134 0ustar00metameta000000 000000 # =========================================================================== # http://www.gnu.org/software/autoconf-archive/ax_append_flag.html # =========================================================================== # # SYNOPSIS # # AX_APPEND_FLAG(FLAG, [FLAGS-VARIABLE]) # # DESCRIPTION # # FLAG is appended to the FLAGS-VARIABLE shell variable, with a space # added in between. # # If FLAGS-VARIABLE is not specified, the current language's flags (e.g. # CFLAGS) is used. FLAGS-VARIABLE is not changed if it already contains # FLAG. If FLAGS-VARIABLE is unset in the shell, it is set to exactly # FLAG. # # NOTE: Implementation based on AX_CFLAGS_GCC_OPTION. # # LICENSE # # Copyright (c) 2008 Guido U. Draheim # Copyright (c) 2011 Maarten Bosmans # # 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. # # You should have received a copy of the GNU General Public License along # with this program. If not, see . # # As a special exception, the respective Autoconf Macro's copyright owner # gives unlimited permission to copy, distribute and modify the configure # scripts that are the output of Autoconf when processing the Macro. You # need not follow the terms of the GNU General Public License when using # or distributing such scripts, even though portions of the text of the # Macro appear in them. The GNU General Public License (GPL) does govern # all other use of the material that constitutes the Autoconf Macro. # # This special exception to the GPL applies to versions of the Autoconf # Macro released by the Autoconf Archive. When you make and distribute a # modified version of the Autoconf Macro, you may extend this special # exception to the GPL to apply to your modified version as well. #serial 6 AC_DEFUN([AX_APPEND_FLAG], [dnl AC_PREREQ(2.64)dnl for _AC_LANG_PREFIX and AS_VAR_SET_IF AS_VAR_PUSHDEF([FLAGS], [m4_default($2,_AC_LANG_PREFIX[FLAGS])]) AS_VAR_SET_IF(FLAGS,[ AS_CASE([" AS_VAR_GET(FLAGS) "], [*" $1 "*], [AC_RUN_LOG([: FLAGS already contains $1])], [ AS_VAR_APPEND(FLAGS,[" $1"]) AC_RUN_LOG([: FLAGS="$FLAGS"]) ]) ], [ AS_VAR_SET(FLAGS,[$1]) AC_RUN_LOG([: FLAGS="$FLAGS"]) ]) AS_VAR_POPDEF([FLAGS])dnl ])dnl AX_APPEND_FLAG xrdp-0.9.5/m4/ltoptions.m4000644 001751 001751 00000034262 13220730762 015250 0ustar00metameta000000 000000 # Helper functions for option handling. -*- Autoconf -*- # # Copyright (C) 2004-2005, 2007-2009, 2011-2015 Free Software # Foundation, Inc. # Written by Gary V. Vaughan, 2004 # # This file is free software; the Free Software Foundation gives # unlimited permission to copy and/or distribute it, with or without # modifications, as long as this notice is preserved. # serial 8 ltoptions.m4 # This is to help aclocal find these macros, as it can't see m4_define. AC_DEFUN([LTOPTIONS_VERSION], [m4_if([1])]) # _LT_MANGLE_OPTION(MACRO-NAME, OPTION-NAME) # ------------------------------------------ m4_define([_LT_MANGLE_OPTION], [[_LT_OPTION_]m4_bpatsubst($1__$2, [[^a-zA-Z0-9_]], [_])]) # _LT_SET_OPTION(MACRO-NAME, OPTION-NAME) # --------------------------------------- # Set option OPTION-NAME for macro MACRO-NAME, and if there is a # matching handler defined, dispatch to it. Other OPTION-NAMEs are # saved as a flag. m4_define([_LT_SET_OPTION], [m4_define(_LT_MANGLE_OPTION([$1], [$2]))dnl m4_ifdef(_LT_MANGLE_DEFUN([$1], [$2]), _LT_MANGLE_DEFUN([$1], [$2]), [m4_warning([Unknown $1 option '$2'])])[]dnl ]) # _LT_IF_OPTION(MACRO-NAME, OPTION-NAME, IF-SET, [IF-NOT-SET]) # ------------------------------------------------------------ # Execute IF-SET if OPTION is set, IF-NOT-SET otherwise. m4_define([_LT_IF_OPTION], [m4_ifdef(_LT_MANGLE_OPTION([$1], [$2]), [$3], [$4])]) # _LT_UNLESS_OPTIONS(MACRO-NAME, OPTION-LIST, IF-NOT-SET) # ------------------------------------------------------- # Execute IF-NOT-SET unless all options in OPTION-LIST for MACRO-NAME # are set. m4_define([_LT_UNLESS_OPTIONS], [m4_foreach([_LT_Option], m4_split(m4_normalize([$2])), [m4_ifdef(_LT_MANGLE_OPTION([$1], _LT_Option), [m4_define([$0_found])])])[]dnl m4_ifdef([$0_found], [m4_undefine([$0_found])], [$3 ])[]dnl ]) # _LT_SET_OPTIONS(MACRO-NAME, OPTION-LIST) # ---------------------------------------- # OPTION-LIST is a space-separated list of Libtool options associated # with MACRO-NAME. If any OPTION has a matching handler declared with # LT_OPTION_DEFINE, dispatch to that macro; otherwise complain about # the unknown option and exit. m4_defun([_LT_SET_OPTIONS], [# Set options m4_foreach([_LT_Option], m4_split(m4_normalize([$2])), [_LT_SET_OPTION([$1], _LT_Option)]) m4_if([$1],[LT_INIT],[ dnl dnl Simply set some default values (i.e off) if boolean options were not dnl specified: _LT_UNLESS_OPTIONS([LT_INIT], [dlopen], [enable_dlopen=no ]) _LT_UNLESS_OPTIONS([LT_INIT], [win32-dll], [enable_win32_dll=no ]) dnl dnl If no reference was made to various pairs of opposing options, then dnl we run the default mode handler for the pair. For example, if neither dnl 'shared' nor 'disable-shared' was passed, we enable building of shared dnl archives by default: _LT_UNLESS_OPTIONS([LT_INIT], [shared disable-shared], [_LT_ENABLE_SHARED]) _LT_UNLESS_OPTIONS([LT_INIT], [static disable-static], [_LT_ENABLE_STATIC]) _LT_UNLESS_OPTIONS([LT_INIT], [pic-only no-pic], [_LT_WITH_PIC]) _LT_UNLESS_OPTIONS([LT_INIT], [fast-install disable-fast-install], [_LT_ENABLE_FAST_INSTALL]) _LT_UNLESS_OPTIONS([LT_INIT], [aix-soname=aix aix-soname=both aix-soname=svr4], [_LT_WITH_AIX_SONAME([aix])]) ]) ])# _LT_SET_OPTIONS ## --------------------------------- ## ## Macros to handle LT_INIT options. ## ## --------------------------------- ## # _LT_MANGLE_DEFUN(MACRO-NAME, OPTION-NAME) # ----------------------------------------- m4_define([_LT_MANGLE_DEFUN], [[_LT_OPTION_DEFUN_]m4_bpatsubst(m4_toupper([$1__$2]), [[^A-Z0-9_]], [_])]) # LT_OPTION_DEFINE(MACRO-NAME, OPTION-NAME, CODE) # ----------------------------------------------- m4_define([LT_OPTION_DEFINE], [m4_define(_LT_MANGLE_DEFUN([$1], [$2]), [$3])[]dnl ])# LT_OPTION_DEFINE # dlopen # ------ LT_OPTION_DEFINE([LT_INIT], [dlopen], [enable_dlopen=yes ]) AU_DEFUN([AC_LIBTOOL_DLOPEN], [_LT_SET_OPTION([LT_INIT], [dlopen]) AC_DIAGNOSE([obsolete], [$0: Remove this warning and the call to _LT_SET_OPTION when you put the 'dlopen' option into LT_INIT's first parameter.]) ]) dnl aclocal-1.4 backwards compatibility: dnl AC_DEFUN([AC_LIBTOOL_DLOPEN], []) # win32-dll # --------- # Declare package support for building win32 dll's. LT_OPTION_DEFINE([LT_INIT], [win32-dll], [enable_win32_dll=yes case $host in *-*-cygwin* | *-*-mingw* | *-*-pw32* | *-*-cegcc*) AC_CHECK_TOOL(AS, as, false) AC_CHECK_TOOL(DLLTOOL, dlltool, false) AC_CHECK_TOOL(OBJDUMP, objdump, false) ;; esac test -z "$AS" && AS=as _LT_DECL([], [AS], [1], [Assembler program])dnl test -z "$DLLTOOL" && DLLTOOL=dlltool _LT_DECL([], [DLLTOOL], [1], [DLL creation program])dnl test -z "$OBJDUMP" && OBJDUMP=objdump _LT_DECL([], [OBJDUMP], [1], [Object dumper program])dnl ])# win32-dll AU_DEFUN([AC_LIBTOOL_WIN32_DLL], [AC_REQUIRE([AC_CANONICAL_HOST])dnl _LT_SET_OPTION([LT_INIT], [win32-dll]) AC_DIAGNOSE([obsolete], [$0: Remove this warning and the call to _LT_SET_OPTION when you put the 'win32-dll' option into LT_INIT's first parameter.]) ]) dnl aclocal-1.4 backwards compatibility: dnl AC_DEFUN([AC_LIBTOOL_WIN32_DLL], []) # _LT_ENABLE_SHARED([DEFAULT]) # ---------------------------- # implement the --enable-shared flag, and supports the 'shared' and # 'disable-shared' LT_INIT options. # DEFAULT is either 'yes' or 'no'. If omitted, it defaults to 'yes'. m4_define([_LT_ENABLE_SHARED], [m4_define([_LT_ENABLE_SHARED_DEFAULT], [m4_if($1, no, no, yes)])dnl AC_ARG_ENABLE([shared], [AS_HELP_STRING([--enable-shared@<:@=PKGS@:>@], [build shared libraries @<:@default=]_LT_ENABLE_SHARED_DEFAULT[@:>@])], [p=${PACKAGE-default} case $enableval in yes) enable_shared=yes ;; no) enable_shared=no ;; *) enable_shared=no # Look at the argument we got. We use all the common list separators. lt_save_ifs=$IFS; IFS=$IFS$PATH_SEPARATOR, for pkg in $enableval; do IFS=$lt_save_ifs if test "X$pkg" = "X$p"; then enable_shared=yes fi done IFS=$lt_save_ifs ;; esac], [enable_shared=]_LT_ENABLE_SHARED_DEFAULT) _LT_DECL([build_libtool_libs], [enable_shared], [0], [Whether or not to build shared libraries]) ])# _LT_ENABLE_SHARED LT_OPTION_DEFINE([LT_INIT], [shared], [_LT_ENABLE_SHARED([yes])]) LT_OPTION_DEFINE([LT_INIT], [disable-shared], [_LT_ENABLE_SHARED([no])]) # Old names: AC_DEFUN([AC_ENABLE_SHARED], [_LT_SET_OPTION([LT_INIT], m4_if([$1], [no], [disable-])[shared]) ]) AC_DEFUN([AC_DISABLE_SHARED], [_LT_SET_OPTION([LT_INIT], [disable-shared]) ]) AU_DEFUN([AM_ENABLE_SHARED], [AC_ENABLE_SHARED($@)]) AU_DEFUN([AM_DISABLE_SHARED], [AC_DISABLE_SHARED($@)]) dnl aclocal-1.4 backwards compatibility: dnl AC_DEFUN([AM_ENABLE_SHARED], []) dnl AC_DEFUN([AM_DISABLE_SHARED], []) # _LT_ENABLE_STATIC([DEFAULT]) # ---------------------------- # implement the --enable-static flag, and support the 'static' and # 'disable-static' LT_INIT options. # DEFAULT is either 'yes' or 'no'. If omitted, it defaults to 'yes'. m4_define([_LT_ENABLE_STATIC], [m4_define([_LT_ENABLE_STATIC_DEFAULT], [m4_if($1, no, no, yes)])dnl AC_ARG_ENABLE([static], [AS_HELP_STRING([--enable-static@<:@=PKGS@:>@], [build static libraries @<:@default=]_LT_ENABLE_STATIC_DEFAULT[@:>@])], [p=${PACKAGE-default} case $enableval in yes) enable_static=yes ;; no) enable_static=no ;; *) enable_static=no # Look at the argument we got. We use all the common list separators. lt_save_ifs=$IFS; IFS=$IFS$PATH_SEPARATOR, for pkg in $enableval; do IFS=$lt_save_ifs if test "X$pkg" = "X$p"; then enable_static=yes fi done IFS=$lt_save_ifs ;; esac], [enable_static=]_LT_ENABLE_STATIC_DEFAULT) _LT_DECL([build_old_libs], [enable_static], [0], [Whether or not to build static libraries]) ])# _LT_ENABLE_STATIC LT_OPTION_DEFINE([LT_INIT], [static], [_LT_ENABLE_STATIC([yes])]) LT_OPTION_DEFINE([LT_INIT], [disable-static], [_LT_ENABLE_STATIC([no])]) # Old names: AC_DEFUN([AC_ENABLE_STATIC], [_LT_SET_OPTION([LT_INIT], m4_if([$1], [no], [disable-])[static]) ]) AC_DEFUN([AC_DISABLE_STATIC], [_LT_SET_OPTION([LT_INIT], [disable-static]) ]) AU_DEFUN([AM_ENABLE_STATIC], [AC_ENABLE_STATIC($@)]) AU_DEFUN([AM_DISABLE_STATIC], [AC_DISABLE_STATIC($@)]) dnl aclocal-1.4 backwards compatibility: dnl AC_DEFUN([AM_ENABLE_STATIC], []) dnl AC_DEFUN([AM_DISABLE_STATIC], []) # _LT_ENABLE_FAST_INSTALL([DEFAULT]) # ---------------------------------- # implement the --enable-fast-install flag, and support the 'fast-install' # and 'disable-fast-install' LT_INIT options. # DEFAULT is either 'yes' or 'no'. If omitted, it defaults to 'yes'. m4_define([_LT_ENABLE_FAST_INSTALL], [m4_define([_LT_ENABLE_FAST_INSTALL_DEFAULT], [m4_if($1, no, no, yes)])dnl AC_ARG_ENABLE([fast-install], [AS_HELP_STRING([--enable-fast-install@<:@=PKGS@:>@], [optimize for fast installation @<:@default=]_LT_ENABLE_FAST_INSTALL_DEFAULT[@:>@])], [p=${PACKAGE-default} case $enableval in yes) enable_fast_install=yes ;; no) enable_fast_install=no ;; *) enable_fast_install=no # Look at the argument we got. We use all the common list separators. lt_save_ifs=$IFS; IFS=$IFS$PATH_SEPARATOR, for pkg in $enableval; do IFS=$lt_save_ifs if test "X$pkg" = "X$p"; then enable_fast_install=yes fi done IFS=$lt_save_ifs ;; esac], [enable_fast_install=]_LT_ENABLE_FAST_INSTALL_DEFAULT) _LT_DECL([fast_install], [enable_fast_install], [0], [Whether or not to optimize for fast installation])dnl ])# _LT_ENABLE_FAST_INSTALL LT_OPTION_DEFINE([LT_INIT], [fast-install], [_LT_ENABLE_FAST_INSTALL([yes])]) LT_OPTION_DEFINE([LT_INIT], [disable-fast-install], [_LT_ENABLE_FAST_INSTALL([no])]) # Old names: AU_DEFUN([AC_ENABLE_FAST_INSTALL], [_LT_SET_OPTION([LT_INIT], m4_if([$1], [no], [disable-])[fast-install]) AC_DIAGNOSE([obsolete], [$0: Remove this warning and the call to _LT_SET_OPTION when you put the 'fast-install' option into LT_INIT's first parameter.]) ]) AU_DEFUN([AC_DISABLE_FAST_INSTALL], [_LT_SET_OPTION([LT_INIT], [disable-fast-install]) AC_DIAGNOSE([obsolete], [$0: Remove this warning and the call to _LT_SET_OPTION when you put the 'disable-fast-install' option into LT_INIT's first parameter.]) ]) dnl aclocal-1.4 backwards compatibility: dnl AC_DEFUN([AC_ENABLE_FAST_INSTALL], []) dnl AC_DEFUN([AM_DISABLE_FAST_INSTALL], []) # _LT_WITH_AIX_SONAME([DEFAULT]) # ---------------------------------- # implement the --with-aix-soname flag, and support the `aix-soname=aix' # and `aix-soname=both' and `aix-soname=svr4' LT_INIT options. DEFAULT # is either `aix', `both' or `svr4'. If omitted, it defaults to `aix'. m4_define([_LT_WITH_AIX_SONAME], [m4_define([_LT_WITH_AIX_SONAME_DEFAULT], [m4_if($1, svr4, svr4, m4_if($1, both, both, aix))])dnl shared_archive_member_spec= case $host,$enable_shared in power*-*-aix[[5-9]]*,yes) AC_MSG_CHECKING([which variant of shared library versioning to provide]) AC_ARG_WITH([aix-soname], [AS_HELP_STRING([--with-aix-soname=aix|svr4|both], [shared library versioning (aka "SONAME") variant to provide on AIX, @<:@default=]_LT_WITH_AIX_SONAME_DEFAULT[@:>@.])], [case $withval in aix|svr4|both) ;; *) AC_MSG_ERROR([Unknown argument to --with-aix-soname]) ;; esac lt_cv_with_aix_soname=$with_aix_soname], [AC_CACHE_VAL([lt_cv_with_aix_soname], [lt_cv_with_aix_soname=]_LT_WITH_AIX_SONAME_DEFAULT) with_aix_soname=$lt_cv_with_aix_soname]) AC_MSG_RESULT([$with_aix_soname]) if test aix != "$with_aix_soname"; then # For the AIX way of multilib, we name the shared archive member # based on the bitwidth used, traditionally 'shr.o' or 'shr_64.o', # and 'shr.imp' or 'shr_64.imp', respectively, for the Import File. # Even when GNU compilers ignore OBJECT_MODE but need '-maix64' flag, # the AIX toolchain works better with OBJECT_MODE set (default 32). if test 64 = "${OBJECT_MODE-32}"; then shared_archive_member_spec=shr_64 else shared_archive_member_spec=shr fi fi ;; *) with_aix_soname=aix ;; esac _LT_DECL([], [shared_archive_member_spec], [0], [Shared archive member basename, for filename based shared library versioning on AIX])dnl ])# _LT_WITH_AIX_SONAME LT_OPTION_DEFINE([LT_INIT], [aix-soname=aix], [_LT_WITH_AIX_SONAME([aix])]) LT_OPTION_DEFINE([LT_INIT], [aix-soname=both], [_LT_WITH_AIX_SONAME([both])]) LT_OPTION_DEFINE([LT_INIT], [aix-soname=svr4], [_LT_WITH_AIX_SONAME([svr4])]) # _LT_WITH_PIC([MODE]) # -------------------- # implement the --with-pic flag, and support the 'pic-only' and 'no-pic' # LT_INIT options. # MODE is either 'yes' or 'no'. If omitted, it defaults to 'both'. m4_define([_LT_WITH_PIC], [AC_ARG_WITH([pic], [AS_HELP_STRING([--with-pic@<:@=PKGS@:>@], [try to use only PIC/non-PIC objects @<:@default=use both@:>@])], [lt_p=${PACKAGE-default} case $withval in yes|no) pic_mode=$withval ;; *) pic_mode=default # Look at the argument we got. We use all the common list separators. lt_save_ifs=$IFS; IFS=$IFS$PATH_SEPARATOR, for lt_pkg in $withval; do IFS=$lt_save_ifs if test "X$lt_pkg" = "X$lt_p"; then pic_mode=yes fi done IFS=$lt_save_ifs ;; esac], [pic_mode=m4_default([$1], [default])]) _LT_DECL([], [pic_mode], [0], [What type of objects to build])dnl ])# _LT_WITH_PIC LT_OPTION_DEFINE([LT_INIT], [pic-only], [_LT_WITH_PIC([yes])]) LT_OPTION_DEFINE([LT_INIT], [no-pic], [_LT_WITH_PIC([no])]) # Old name: AU_DEFUN([AC_LIBTOOL_PICMODE], [_LT_SET_OPTION([LT_INIT], [pic-only]) AC_DIAGNOSE([obsolete], [$0: Remove this warning and the call to _LT_SET_OPTION when you put the 'pic-only' option into LT_INIT's first parameter.]) ]) dnl aclocal-1.4 backwards compatibility: dnl AC_DEFUN([AC_LIBTOOL_PICMODE], []) ## ----------------- ## ## LTDL_INIT Options ## ## ----------------- ## m4_define([_LTDL_MODE], []) LT_OPTION_DEFINE([LTDL_INIT], [nonrecursive], [m4_define([_LTDL_MODE], [nonrecursive])]) LT_OPTION_DEFINE([LTDL_INIT], [recursive], [m4_define([_LTDL_MODE], [recursive])]) LT_OPTION_DEFINE([LTDL_INIT], [subproject], [m4_define([_LTDL_MODE], [subproject])]) m4_define([_LTDL_TYPE], []) LT_OPTION_DEFINE([LTDL_INIT], [installable], [m4_define([_LTDL_TYPE], [installable])]) LT_OPTION_DEFINE([LTDL_INIT], [convenience], [m4_define([_LTDL_TYPE], [convenience])]) xrdp-0.9.5/m4/lt~obsolete.m4000644 001751 001751 00000013774 13220730762 015574 0ustar00metameta000000 000000 # lt~obsolete.m4 -- aclocal satisfying obsolete definitions. -*-Autoconf-*- # # Copyright (C) 2004-2005, 2007, 2009, 2011-2015 Free Software # Foundation, Inc. # Written by Scott James Remnant, 2004. # # This file is free software; the Free Software Foundation gives # unlimited permission to copy and/or distribute it, with or without # modifications, as long as this notice is preserved. # serial 5 lt~obsolete.m4 # These exist entirely to fool aclocal when bootstrapping libtool. # # In the past libtool.m4 has provided macros via AC_DEFUN (or AU_DEFUN), # which have later been changed to m4_define as they aren't part of the # exported API, or moved to Autoconf or Automake where they belong. # # The trouble is, aclocal is a bit thick. It'll see the old AC_DEFUN # in /usr/share/aclocal/libtool.m4 and remember it, then when it sees us # using a macro with the same name in our local m4/libtool.m4 it'll # pull the old libtool.m4 in (it doesn't see our shiny new m4_define # and doesn't know about Autoconf macros at all.) # # So we provide this file, which has a silly filename so it's always # included after everything else. This provides aclocal with the # AC_DEFUNs it wants, but when m4 processes it, it doesn't do anything # because those macros already exist, or will be overwritten later. # We use AC_DEFUN over AU_DEFUN for compatibility with aclocal-1.6. # # Anytime we withdraw an AC_DEFUN or AU_DEFUN, remember to add it here. # Yes, that means every name once taken will need to remain here until # we give up compatibility with versions before 1.7, at which point # we need to keep only those names which we still refer to. # This is to help aclocal find these macros, as it can't see m4_define. AC_DEFUN([LTOBSOLETE_VERSION], [m4_if([1])]) m4_ifndef([AC_LIBTOOL_LINKER_OPTION], [AC_DEFUN([AC_LIBTOOL_LINKER_OPTION])]) m4_ifndef([AC_PROG_EGREP], [AC_DEFUN([AC_PROG_EGREP])]) m4_ifndef([_LT_AC_PROG_ECHO_BACKSLASH], [AC_DEFUN([_LT_AC_PROG_ECHO_BACKSLASH])]) m4_ifndef([_LT_AC_SHELL_INIT], [AC_DEFUN([_LT_AC_SHELL_INIT])]) m4_ifndef([_LT_AC_SYS_LIBPATH_AIX], [AC_DEFUN([_LT_AC_SYS_LIBPATH_AIX])]) m4_ifndef([_LT_PROG_LTMAIN], [AC_DEFUN([_LT_PROG_LTMAIN])]) m4_ifndef([_LT_AC_TAGVAR], [AC_DEFUN([_LT_AC_TAGVAR])]) m4_ifndef([AC_LTDL_ENABLE_INSTALL], [AC_DEFUN([AC_LTDL_ENABLE_INSTALL])]) m4_ifndef([AC_LTDL_PREOPEN], [AC_DEFUN([AC_LTDL_PREOPEN])]) m4_ifndef([_LT_AC_SYS_COMPILER], [AC_DEFUN([_LT_AC_SYS_COMPILER])]) m4_ifndef([_LT_AC_LOCK], [AC_DEFUN([_LT_AC_LOCK])]) m4_ifndef([AC_LIBTOOL_SYS_OLD_ARCHIVE], [AC_DEFUN([AC_LIBTOOL_SYS_OLD_ARCHIVE])]) m4_ifndef([_LT_AC_TRY_DLOPEN_SELF], [AC_DEFUN([_LT_AC_TRY_DLOPEN_SELF])]) m4_ifndef([AC_LIBTOOL_PROG_CC_C_O], [AC_DEFUN([AC_LIBTOOL_PROG_CC_C_O])]) m4_ifndef([AC_LIBTOOL_SYS_HARD_LINK_LOCKS], [AC_DEFUN([AC_LIBTOOL_SYS_HARD_LINK_LOCKS])]) m4_ifndef([AC_LIBTOOL_OBJDIR], [AC_DEFUN([AC_LIBTOOL_OBJDIR])]) m4_ifndef([AC_LTDL_OBJDIR], [AC_DEFUN([AC_LTDL_OBJDIR])]) m4_ifndef([AC_LIBTOOL_PROG_LD_HARDCODE_LIBPATH], [AC_DEFUN([AC_LIBTOOL_PROG_LD_HARDCODE_LIBPATH])]) m4_ifndef([AC_LIBTOOL_SYS_LIB_STRIP], [AC_DEFUN([AC_LIBTOOL_SYS_LIB_STRIP])]) m4_ifndef([AC_PATH_MAGIC], [AC_DEFUN([AC_PATH_MAGIC])]) m4_ifndef([AC_PROG_LD_GNU], [AC_DEFUN([AC_PROG_LD_GNU])]) m4_ifndef([AC_PROG_LD_RELOAD_FLAG], [AC_DEFUN([AC_PROG_LD_RELOAD_FLAG])]) m4_ifndef([AC_DEPLIBS_CHECK_METHOD], [AC_DEFUN([AC_DEPLIBS_CHECK_METHOD])]) m4_ifndef([AC_LIBTOOL_PROG_COMPILER_NO_RTTI], [AC_DEFUN([AC_LIBTOOL_PROG_COMPILER_NO_RTTI])]) m4_ifndef([AC_LIBTOOL_SYS_GLOBAL_SYMBOL_PIPE], [AC_DEFUN([AC_LIBTOOL_SYS_GLOBAL_SYMBOL_PIPE])]) m4_ifndef([AC_LIBTOOL_PROG_COMPILER_PIC], [AC_DEFUN([AC_LIBTOOL_PROG_COMPILER_PIC])]) m4_ifndef([AC_LIBTOOL_PROG_LD_SHLIBS], [AC_DEFUN([AC_LIBTOOL_PROG_LD_SHLIBS])]) m4_ifndef([AC_LIBTOOL_POSTDEP_PREDEP], [AC_DEFUN([AC_LIBTOOL_POSTDEP_PREDEP])]) m4_ifndef([LT_AC_PROG_EGREP], [AC_DEFUN([LT_AC_PROG_EGREP])]) m4_ifndef([LT_AC_PROG_SED], [AC_DEFUN([LT_AC_PROG_SED])]) m4_ifndef([_LT_CC_BASENAME], [AC_DEFUN([_LT_CC_BASENAME])]) m4_ifndef([_LT_COMPILER_BOILERPLATE], [AC_DEFUN([_LT_COMPILER_BOILERPLATE])]) m4_ifndef([_LT_LINKER_BOILERPLATE], [AC_DEFUN([_LT_LINKER_BOILERPLATE])]) m4_ifndef([_AC_PROG_LIBTOOL], [AC_DEFUN([_AC_PROG_LIBTOOL])]) m4_ifndef([AC_LIBTOOL_SETUP], [AC_DEFUN([AC_LIBTOOL_SETUP])]) m4_ifndef([_LT_AC_CHECK_DLFCN], [AC_DEFUN([_LT_AC_CHECK_DLFCN])]) m4_ifndef([AC_LIBTOOL_SYS_DYNAMIC_LINKER], [AC_DEFUN([AC_LIBTOOL_SYS_DYNAMIC_LINKER])]) m4_ifndef([_LT_AC_TAGCONFIG], [AC_DEFUN([_LT_AC_TAGCONFIG])]) m4_ifndef([AC_DISABLE_FAST_INSTALL], [AC_DEFUN([AC_DISABLE_FAST_INSTALL])]) m4_ifndef([_LT_AC_LANG_CXX], [AC_DEFUN([_LT_AC_LANG_CXX])]) m4_ifndef([_LT_AC_LANG_F77], [AC_DEFUN([_LT_AC_LANG_F77])]) m4_ifndef([_LT_AC_LANG_GCJ], [AC_DEFUN([_LT_AC_LANG_GCJ])]) m4_ifndef([AC_LIBTOOL_LANG_C_CONFIG], [AC_DEFUN([AC_LIBTOOL_LANG_C_CONFIG])]) m4_ifndef([_LT_AC_LANG_C_CONFIG], [AC_DEFUN([_LT_AC_LANG_C_CONFIG])]) m4_ifndef([AC_LIBTOOL_LANG_CXX_CONFIG], [AC_DEFUN([AC_LIBTOOL_LANG_CXX_CONFIG])]) m4_ifndef([_LT_AC_LANG_CXX_CONFIG], [AC_DEFUN([_LT_AC_LANG_CXX_CONFIG])]) m4_ifndef([AC_LIBTOOL_LANG_F77_CONFIG], [AC_DEFUN([AC_LIBTOOL_LANG_F77_CONFIG])]) m4_ifndef([_LT_AC_LANG_F77_CONFIG], [AC_DEFUN([_LT_AC_LANG_F77_CONFIG])]) m4_ifndef([AC_LIBTOOL_LANG_GCJ_CONFIG], [AC_DEFUN([AC_LIBTOOL_LANG_GCJ_CONFIG])]) m4_ifndef([_LT_AC_LANG_GCJ_CONFIG], [AC_DEFUN([_LT_AC_LANG_GCJ_CONFIG])]) m4_ifndef([AC_LIBTOOL_LANG_RC_CONFIG], [AC_DEFUN([AC_LIBTOOL_LANG_RC_CONFIG])]) m4_ifndef([_LT_AC_LANG_RC_CONFIG], [AC_DEFUN([_LT_AC_LANG_RC_CONFIG])]) m4_ifndef([AC_LIBTOOL_CONFIG], [AC_DEFUN([AC_LIBTOOL_CONFIG])]) m4_ifndef([_LT_AC_FILE_LTDLL_C], [AC_DEFUN([_LT_AC_FILE_LTDLL_C])]) m4_ifndef([_LT_REQUIRED_DARWIN_CHECKS], [AC_DEFUN([_LT_REQUIRED_DARWIN_CHECKS])]) m4_ifndef([_LT_AC_PROG_CXXCPP], [AC_DEFUN([_LT_AC_PROG_CXXCPP])]) m4_ifndef([_LT_PREPARE_SED_QUOTE_VARS], [AC_DEFUN([_LT_PREPARE_SED_QUOTE_VARS])]) m4_ifndef([_LT_PROG_ECHO_BACKSLASH], [AC_DEFUN([_LT_PROG_ECHO_BACKSLASH])]) m4_ifndef([_LT_PROG_F77], [AC_DEFUN([_LT_PROG_F77])]) m4_ifndef([_LT_PROG_FC], [AC_DEFUN([_LT_PROG_FC])]) m4_ifndef([_LT_PROG_CXX], [AC_DEFUN([_LT_PROG_CXX])]) xrdp-0.9.5/m4/ax_gcc_func_attribute.m4000644 001751 001751 00000017073 13127114621 017534 0ustar00metameta000000 000000 # =========================================================================== # http://www.gnu.org/software/autoconf-archive/ax_gcc_func_attribute.html # =========================================================================== # # SYNOPSIS # # AX_GCC_FUNC_ATTRIBUTE(ATTRIBUTE) # # DESCRIPTION # # This macro checks if the compiler supports one of GCC's function # attributes; many other compilers also provide function attributes with # the same syntax. Compiler warnings are used to detect supported # attributes as unsupported ones are ignored by default so quieting # warnings when using this macro will yield false positives. # # The ATTRIBUTE parameter holds the name of the attribute to be checked. # # If ATTRIBUTE is supported define HAVE_FUNC_ATTRIBUTE_. # # The macro caches its result in the ax_cv_have_func_attribute_ # variable. # # The macro currently supports the following function attributes: # # alias # aligned # alloc_size # always_inline # artificial # cold # const # constructor # constructor_priority for constructor attribute with priority # deprecated # destructor # dllexport # dllimport # error # externally_visible # flatten # format # format_arg # gnu_inline # hot # ifunc # leaf # malloc # noclone # noinline # nonnull # noreturn # nothrow # optimize # pure # unused # used # visibility # warning # warn_unused_result # weak # weakref # # Unsuppored function attributes will be tested with a prototype returning # an int and not accepting any arguments and the result of the check might # be wrong or meaningless so use with care. # # LICENSE # # Copyright (c) 2013 Gabriele Svelto # # Copying and distribution of this file, with or without modification, are # permitted in any medium without royalty provided the copyright notice # and this notice are preserved. This file is offered as-is, without any # warranty. #serial 3 AC_DEFUN([AX_GCC_FUNC_ATTRIBUTE], [ AS_VAR_PUSHDEF([ac_var], [ax_cv_have_func_attribute_$1]) AC_CACHE_CHECK([for __attribute__(($1))], [ac_var], [ AC_LINK_IFELSE([AC_LANG_PROGRAM([ m4_case([$1], [alias], [ int foo( void ) { return 0; } int bar( void ) __attribute__(($1("foo"))); ], [aligned], [ int foo( void ) __attribute__(($1(32))); ], [alloc_size], [ void *foo(int a) __attribute__(($1(1))); ], [always_inline], [ inline __attribute__(($1)) int foo( void ) { return 0; } ], [artificial], [ inline __attribute__(($1)) int foo( void ) { return 0; } ], [cold], [ int foo( void ) __attribute__(($1)); ], [const], [ int foo( void ) __attribute__(($1)); ], [constructor_priority], [ int foo( void ) __attribute__((__constructor__(65535/2))); ], [constructor], [ int foo( void ) __attribute__(($1)); ], [deprecated], [ int foo( void ) __attribute__(($1(""))); ], [destructor], [ int foo( void ) __attribute__(($1)); ], [dllexport], [ __attribute__(($1)) int foo( void ) { return 0; } ], [dllimport], [ int foo( void ) __attribute__(($1)); ], [error], [ int foo( void ) __attribute__(($1(""))); ], [externally_visible], [ int foo( void ) __attribute__(($1)); ], [flatten], [ int foo( void ) __attribute__(($1)); ], [format], [ int foo(const char *p, ...) __attribute__(($1(printf, 1, 2))); ], [format_arg], [ char *foo(const char *p) __attribute__(($1(1))); ], [gnu_inline], [ inline __attribute__(($1)) int foo( void ) { return 0; } ], [hot], [ int foo( void ) __attribute__(($1)); ], [ifunc], [ int my_foo( void ) { return 0; } static int (*resolve_foo(void))(void) { return my_foo; } int foo( void ) __attribute__(($1("resolve_foo"))); ], [leaf], [ __attribute__(($1)) int foo( void ) { return 0; } ], [malloc], [ void *foo( void ) __attribute__(($1)); ], [noclone], [ int foo( void ) __attribute__(($1)); ], [noinline], [ __attribute__(($1)) int foo( void ) { return 0; } ], [nonnull], [ int foo(char *p) __attribute__(($1(1))); ], [noreturn], [ void foo( void ) __attribute__(($1)); ], [nothrow], [ int foo( void ) __attribute__(($1)); ], [optimize], [ __attribute__(($1(3))) int foo( void ) { return 0; } ], [pure], [ int foo( void ) __attribute__(($1)); ], [unused], [ int foo( void ) __attribute__(($1)); ], [used], [ int foo( void ) __attribute__(($1)); ], [visibility], [ int foo_def( void ) __attribute__(($1("default"))); int foo_hid( void ) __attribute__(($1("hidden"))); int foo_int( void ) __attribute__(($1("internal"))); int foo_pro( void ) __attribute__(($1("protected"))); ], [warning], [ int foo( void ) __attribute__(($1(""))); ], [warn_unused_result], [ int foo( void ) __attribute__(($1)); ], [weak], [ int foo( void ) __attribute__(($1)); ], [weakref], [ static int foo( void ) { return 0; } static int bar( void ) __attribute__(($1("foo"))); ], [ m4_warn([syntax], [Unsupported attribute $1, the test may fail]) int foo( void ) __attribute__(($1)); ] )], []) ], dnl GCC doesn't exit with an error if an unknown attribute is dnl provided but only outputs a warning, so accept the attribute dnl only if no warning were issued. [AS_IF([test -s conftest.err], [AS_VAR_SET([ac_var], [no])], [AS_VAR_SET([ac_var], [yes])])], [AS_VAR_SET([ac_var], [no])]) ]) AS_IF([test yes = AS_VAR_GET([ac_var])], [AC_DEFINE_UNQUOTED(AS_TR_CPP(HAVE_FUNC_ATTRIBUTE_$1), 1, [Define to 1 if the system has the `$1' function attribute])], []) AS_VAR_POPDEF([ac_var]) ]) xrdp-0.9.5/m4/ltversion.m4000644 001751 001751 00000001273 13220730762 015236 0ustar00metameta000000 000000 # ltversion.m4 -- version numbers -*- Autoconf -*- # # Copyright (C) 2004, 2011-2015 Free Software Foundation, Inc. # Written by Scott James Remnant, 2004 # # This file is free software; the Free Software Foundation gives # unlimited permission to copy and/or distribute it, with or without # modifications, as long as this notice is preserved. # @configure_input@ # serial 4179 ltversion.m4 # This file is part of GNU Libtool m4_define([LT_PACKAGE_VERSION], [2.4.6]) m4_define([LT_PACKAGE_REVISION], [2.4.6]) AC_DEFUN([LTVERSION_VERSION], [macro_version='2.4.6' macro_revision='2.4.6' _LT_DECL(, macro_version, 0, [Which release of libtool.m4 was used?]) _LT_DECL(, macro_revision, 0) ]) xrdp-0.9.5/m4/.gitignore000644 001751 001751 00000000022 13127114621 014722 0ustar00metameta000000 000000 libtool.m4 lt*.m4 xrdp-0.9.5/m4/ax_cflags_warn_all.m4000644 001751 001751 00000011701 13127114621 017010 0ustar00metameta000000 000000 # =========================================================================== # http://www.gnu.org/software/autoconf-archive/ax_cflags_warn_all.html # =========================================================================== # # SYNOPSIS # # AX_CFLAGS_WARN_ALL [(shellvar [,default, [A/NA]])] # AX_CXXFLAGS_WARN_ALL [(shellvar [,default, [A/NA]])] # AX_FCFLAGS_WARN_ALL [(shellvar [,default, [A/NA]])] # # DESCRIPTION # # Try to find a compiler option that enables most reasonable warnings. # # For the GNU compiler it will be -Wall (and -ansi -pedantic) The result # is added to the shellvar being CFLAGS, CXXFLAGS, or FCFLAGS by default. # # Currently this macro knows about the GCC, Solaris, Digital Unix, AIX, # HP-UX, IRIX, NEC SX-5 (Super-UX 10), Cray J90 (Unicos 10.0.0.8), and # Intel compilers. For a given compiler, the Fortran flags are much more # experimental than their C equivalents. # # - $1 shell-variable-to-add-to : CFLAGS, CXXFLAGS, or FCFLAGS # - $2 add-value-if-not-found : nothing # - $3 action-if-found : add value to shellvariable # - $4 action-if-not-found : nothing # # NOTE: These macros depend on AX_APPEND_FLAG. # # LICENSE # # Copyright (c) 2008 Guido U. Draheim # Copyright (c) 2010 Rhys Ulerich # # 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. # # You should have received a copy of the GNU General Public License along # with this program. If not, see . # # As a special exception, the respective Autoconf Macro's copyright owner # gives unlimited permission to copy, distribute and modify the configure # scripts that are the output of Autoconf when processing the Macro. You # need not follow the terms of the GNU General Public License when using # or distributing such scripts, even though portions of the text of the # Macro appear in them. The GNU General Public License (GPL) does govern # all other use of the material that constitutes the Autoconf Macro. # # This special exception to the GPL applies to versions of the Autoconf # Macro released by the Autoconf Archive. When you make and distribute a # modified version of the Autoconf Macro, you may extend this special # exception to the GPL to apply to your modified version as well. #serial 15 AC_DEFUN([AX_FLAGS_WARN_ALL],[dnl AS_VAR_PUSHDEF([FLAGS],[_AC_LANG_PREFIX[]FLAGS])dnl AS_VAR_PUSHDEF([VAR],[ac_cv_[]_AC_LANG_ABBREV[]flags_warn_all])dnl AC_CACHE_CHECK([m4_ifval($1,$1,FLAGS) for maximum warnings], VAR,[VAR="no, unknown" ac_save_[]FLAGS="$[]FLAGS" for ac_arg dnl in "-warn all % -warn all" dnl Intel "-pedantic % -Wall" dnl GCC "-xstrconst % -v" dnl Solaris C "-std1 % -verbose -w0 -warnprotos" dnl Digital Unix "-qlanglvl=ansi % -qsrcmsg -qinfo=all:noppt:noppc:noobs:nocnd" dnl AIX "-ansi -ansiE % -fullwarn" dnl IRIX "+ESlit % +w1" dnl HP-UX C "-Xc % -pvctl[,]fullmsg" dnl NEC SX-5 (Super-UX 10) "-h conform % -h msglevel 2" dnl Cray C (Unicos) # do FLAGS="$ac_save_[]FLAGS "`echo $ac_arg | sed -e 's,%%.*,,' -e 's,%,,'` AC_COMPILE_IFELSE([AC_LANG_PROGRAM], [VAR=`echo $ac_arg | sed -e 's,.*% *,,'` ; break]) done FLAGS="$ac_save_[]FLAGS" ]) AS_VAR_POPDEF([FLAGS])dnl AX_REQUIRE_DEFINED([AX_APPEND_FLAG]) case ".$VAR" in .ok|.ok,*) m4_ifvaln($3,$3) ;; .|.no|.no,*) m4_default($4,[m4_ifval($2,[AX_APPEND_FLAG([$2], [$1])])]) ;; *) m4_default($3,[AX_APPEND_FLAG([$VAR], [$1])]) ;; esac AS_VAR_POPDEF([VAR])dnl ])dnl AX_FLAGS_WARN_ALL dnl implementation tactics: dnl the for-argument contains a list of options. The first part of dnl these does only exist to detect the compiler - usually it is dnl a global option to enable -ansi or -extrawarnings. All other dnl compilers will fail about it. That was needed since a lot of dnl compilers will give false positives for some option-syntax dnl like -Woption or -Xoption as they think of it is a pass-through dnl to later compile stages or something. The "%" is used as a dnl delimiter. A non-option comment can be given after "%%" marks dnl which will be shown but not added to the respective C/CXXFLAGS. AC_DEFUN([AX_CFLAGS_WARN_ALL],[dnl AC_LANG_PUSH([C]) AX_FLAGS_WARN_ALL([$1], [$2], [$3], [$4]) AC_LANG_POP([C]) ]) AC_DEFUN([AX_CXXFLAGS_WARN_ALL],[dnl AC_LANG_PUSH([C++]) AX_FLAGS_WARN_ALL([$1], [$2], [$3], [$4]) AC_LANG_POP([C++]) ]) AC_DEFUN([AX_FCFLAGS_WARN_ALL],[dnl AC_LANG_PUSH([Fortran]) AX_FLAGS_WARN_ALL([$1], [$2], [$3], [$4]) AC_LANG_POP([Fortran]) ]) xrdp-0.9.5/m4/pkg.m4000644 001751 001751 00000024011 13133557325 013772 0ustar00metameta000000 000000 dnl pkg.m4 - Macros to locate and utilise pkg-config. -*- Autoconf -*- dnl serial 11 (pkg-config-0.29.1) dnl dnl Copyright © 2004 Scott James Remnant . dnl Copyright © 2012-2015 Dan Nicholson dnl dnl This program is free software; you can redistribute it and/or modify dnl it under the terms of the GNU General Public License as published by dnl the Free Software Foundation; either version 2 of the License, or dnl (at your option) any later version. dnl dnl This program is distributed in the hope that it will be useful, but dnl WITHOUT ANY WARRANTY; without even the implied warranty of dnl MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU dnl General Public License for more details. dnl dnl You should have received a copy of the GNU General Public License dnl along with this program; if not, write to the Free Software dnl Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA dnl 02111-1307, USA. dnl dnl As a special exception to the GNU General Public License, if you dnl distribute this file as part of a program that contains a dnl configuration script generated by Autoconf, you may include it under dnl the same distribution terms that you use for the rest of that dnl program. dnl PKG_PREREQ(MIN-VERSION) dnl ----------------------- dnl Since: 0.29 dnl dnl Verify that the version of the pkg-config macros are at least dnl MIN-VERSION. Unlike PKG_PROG_PKG_CONFIG, which checks the user's dnl installed version of pkg-config, this checks the developer's version dnl of pkg.m4 when generating configure. dnl dnl To ensure that this macro is defined, also add: dnl m4_ifndef([PKG_PREREQ], dnl [m4_fatal([must install pkg-config 0.29 or later before running autoconf/autogen])]) dnl dnl See the "Since" comment for each macro you use to see what version dnl of the macros you require. m4_defun([PKG_PREREQ], [m4_define([PKG_MACROS_VERSION], [0.29.1]) m4_if(m4_version_compare(PKG_MACROS_VERSION, [$1]), -1, [m4_fatal([pkg.m4 version $1 or higher is required but ]PKG_MACROS_VERSION[ found])]) ])dnl PKG_PREREQ dnl PKG_PROG_PKG_CONFIG([MIN-VERSION]) dnl ---------------------------------- dnl Since: 0.16 dnl dnl Search for the pkg-config tool and set the PKG_CONFIG variable to dnl first found in the path. Checks that the version of pkg-config found dnl is at least MIN-VERSION. If MIN-VERSION is not specified, 0.9.0 is dnl used since that's the first version where most current features of dnl pkg-config existed. AC_DEFUN([PKG_PROG_PKG_CONFIG], [m4_pattern_forbid([^_?PKG_[A-Z_]+$]) m4_pattern_allow([^PKG_CONFIG(_(PATH|LIBDIR|SYSROOT_DIR|ALLOW_SYSTEM_(CFLAGS|LIBS)))?$]) m4_pattern_allow([^PKG_CONFIG_(DISABLE_UNINSTALLED|TOP_BUILD_DIR|DEBUG_SPEW)$]) AC_ARG_VAR([PKG_CONFIG], [path to pkg-config utility]) AC_ARG_VAR([PKG_CONFIG_PATH], [directories to add to pkg-config's search path]) AC_ARG_VAR([PKG_CONFIG_LIBDIR], [path overriding pkg-config's built-in search path]) if test "x$ac_cv_env_PKG_CONFIG_set" != "xset"; then AC_PATH_TOOL([PKG_CONFIG], [pkg-config]) fi if test -n "$PKG_CONFIG"; then _pkg_min_version=m4_default([$1], [0.9.0]) AC_MSG_CHECKING([pkg-config is at least version $_pkg_min_version]) if $PKG_CONFIG --atleast-pkgconfig-version $_pkg_min_version; then AC_MSG_RESULT([yes]) else AC_MSG_RESULT([no]) PKG_CONFIG="" fi fi[]dnl ])dnl PKG_PROG_PKG_CONFIG dnl PKG_CHECK_EXISTS(MODULES, [ACTION-IF-FOUND], [ACTION-IF-NOT-FOUND]) dnl ------------------------------------------------------------------- dnl Since: 0.18 dnl dnl Check to see whether a particular set of modules exists. Similar to dnl PKG_CHECK_MODULES(), but does not set variables or print errors. dnl dnl Please remember that m4 expands AC_REQUIRE([PKG_PROG_PKG_CONFIG]) dnl only at the first occurence in configure.ac, so if the first place dnl it's called might be skipped (such as if it is within an "if", you dnl have to call PKG_CHECK_EXISTS manually AC_DEFUN([PKG_CHECK_EXISTS], [AC_REQUIRE([PKG_PROG_PKG_CONFIG])dnl if test -n "$PKG_CONFIG" && \ AC_RUN_LOG([$PKG_CONFIG --exists --print-errors "$1"]); then m4_default([$2], [:]) m4_ifvaln([$3], [else $3])dnl fi]) dnl _PKG_CONFIG([VARIABLE], [COMMAND], [MODULES]) dnl --------------------------------------------- dnl Internal wrapper calling pkg-config via PKG_CONFIG and setting dnl pkg_failed based on the result. m4_define([_PKG_CONFIG], [if test -n "$$1"; then pkg_cv_[]$1="$$1" elif test -n "$PKG_CONFIG"; then PKG_CHECK_EXISTS([$3], [pkg_cv_[]$1=`$PKG_CONFIG --[]$2 "$3" 2>/dev/null` test "x$?" != "x0" && pkg_failed=yes ], [pkg_failed=yes]) else pkg_failed=untried fi[]dnl ])dnl _PKG_CONFIG dnl _PKG_SHORT_ERRORS_SUPPORTED dnl --------------------------- dnl Internal check to see if pkg-config supports short errors. AC_DEFUN([_PKG_SHORT_ERRORS_SUPPORTED], [AC_REQUIRE([PKG_PROG_PKG_CONFIG]) if $PKG_CONFIG --atleast-pkgconfig-version 0.20; then _pkg_short_errors_supported=yes else _pkg_short_errors_supported=no fi[]dnl ])dnl _PKG_SHORT_ERRORS_SUPPORTED dnl PKG_CHECK_MODULES(VARIABLE-PREFIX, MODULES, [ACTION-IF-FOUND], dnl [ACTION-IF-NOT-FOUND]) dnl -------------------------------------------------------------- dnl Since: 0.4.0 dnl dnl Note that if there is a possibility the first call to dnl PKG_CHECK_MODULES might not happen, you should be sure to include an dnl explicit call to PKG_PROG_PKG_CONFIG in your configure.ac AC_DEFUN([PKG_CHECK_MODULES], [AC_REQUIRE([PKG_PROG_PKG_CONFIG])dnl AC_ARG_VAR([$1][_CFLAGS], [C compiler flags for $1, overriding pkg-config])dnl AC_ARG_VAR([$1][_LIBS], [linker flags for $1, overriding pkg-config])dnl pkg_failed=no AC_MSG_CHECKING([for $1]) _PKG_CONFIG([$1][_CFLAGS], [cflags], [$2]) _PKG_CONFIG([$1][_LIBS], [libs], [$2]) m4_define([_PKG_TEXT], [Alternatively, you may set the environment variables $1[]_CFLAGS and $1[]_LIBS to avoid the need to call pkg-config. See the pkg-config man page for more details.]) if test $pkg_failed = yes; then AC_MSG_RESULT([no]) _PKG_SHORT_ERRORS_SUPPORTED if test $_pkg_short_errors_supported = yes; then $1[]_PKG_ERRORS=`$PKG_CONFIG --short-errors --print-errors --cflags --libs "$2" 2>&1` else $1[]_PKG_ERRORS=`$PKG_CONFIG --print-errors --cflags --libs "$2" 2>&1` fi # Put the nasty error message in config.log where it belongs echo "$$1[]_PKG_ERRORS" >&AS_MESSAGE_LOG_FD m4_default([$4], [AC_MSG_ERROR( [Package requirements ($2) were not met: $$1_PKG_ERRORS Consider adjusting the PKG_CONFIG_PATH environment variable if you installed software in a non-standard prefix. _PKG_TEXT])[]dnl ]) elif test $pkg_failed = untried; then AC_MSG_RESULT([no]) m4_default([$4], [AC_MSG_FAILURE( [The pkg-config script could not be found or is too old. Make sure it is in your PATH or set the PKG_CONFIG environment variable to the full path to pkg-config. _PKG_TEXT To get pkg-config, see .])[]dnl ]) else $1[]_CFLAGS=$pkg_cv_[]$1[]_CFLAGS $1[]_LIBS=$pkg_cv_[]$1[]_LIBS AC_MSG_RESULT([yes]) $3 fi[]dnl ])dnl PKG_CHECK_MODULES dnl PKG_CHECK_MODULES_STATIC(VARIABLE-PREFIX, MODULES, [ACTION-IF-FOUND], dnl [ACTION-IF-NOT-FOUND]) dnl --------------------------------------------------------------------- dnl Since: 0.29 dnl dnl Checks for existence of MODULES and gathers its build flags with dnl static libraries enabled. Sets VARIABLE-PREFIX_CFLAGS from --cflags dnl and VARIABLE-PREFIX_LIBS from --libs. dnl dnl Note that if there is a possibility the first call to dnl PKG_CHECK_MODULES_STATIC might not happen, you should be sure to dnl include an explicit call to PKG_PROG_PKG_CONFIG in your dnl configure.ac. AC_DEFUN([PKG_CHECK_MODULES_STATIC], [AC_REQUIRE([PKG_PROG_PKG_CONFIG])dnl _save_PKG_CONFIG=$PKG_CONFIG PKG_CONFIG="$PKG_CONFIG --static" PKG_CHECK_MODULES($@) PKG_CONFIG=$_save_PKG_CONFIG[]dnl ])dnl PKG_CHECK_MODULES_STATIC dnl PKG_INSTALLDIR([DIRECTORY]) dnl ------------------------- dnl Since: 0.27 dnl dnl Substitutes the variable pkgconfigdir as the location where a module dnl should install pkg-config .pc files. By default the directory is dnl $libdir/pkgconfig, but the default can be changed by passing dnl DIRECTORY. The user can override through the --with-pkgconfigdir dnl parameter. AC_DEFUN([PKG_INSTALLDIR], [m4_pushdef([pkg_default], [m4_default([$1], ['${libdir}/pkgconfig'])]) m4_pushdef([pkg_description], [pkg-config installation directory @<:@]pkg_default[@:>@]) AC_ARG_WITH([pkgconfigdir], [AS_HELP_STRING([--with-pkgconfigdir], pkg_description)],, [with_pkgconfigdir=]pkg_default) AC_SUBST([pkgconfigdir], [$with_pkgconfigdir]) m4_popdef([pkg_default]) m4_popdef([pkg_description]) ])dnl PKG_INSTALLDIR dnl PKG_NOARCH_INSTALLDIR([DIRECTORY]) dnl -------------------------------- dnl Since: 0.27 dnl dnl Substitutes the variable noarch_pkgconfigdir as the location where a dnl module should install arch-independent pkg-config .pc files. By dnl default the directory is $datadir/pkgconfig, but the default can be dnl changed by passing DIRECTORY. The user can override through the dnl --with-noarch-pkgconfigdir parameter. AC_DEFUN([PKG_NOARCH_INSTALLDIR], [m4_pushdef([pkg_default], [m4_default([$1], ['${datadir}/pkgconfig'])]) m4_pushdef([pkg_description], [pkg-config arch-independent installation directory @<:@]pkg_default[@:>@]) AC_ARG_WITH([noarch-pkgconfigdir], [AS_HELP_STRING([--with-noarch-pkgconfigdir], pkg_description)],, [with_noarch_pkgconfigdir=]pkg_default) AC_SUBST([noarch_pkgconfigdir], [$with_noarch_pkgconfigdir]) m4_popdef([pkg_default]) m4_popdef([pkg_description]) ])dnl PKG_NOARCH_INSTALLDIR dnl PKG_CHECK_VAR(VARIABLE, MODULE, CONFIG-VARIABLE, dnl [ACTION-IF-FOUND], [ACTION-IF-NOT-FOUND]) dnl ------------------------------------------- dnl Since: 0.28 dnl dnl Retrieves the value of the pkg-config variable for the given module. AC_DEFUN([PKG_CHECK_VAR], [AC_REQUIRE([PKG_PROG_PKG_CONFIG])dnl AC_ARG_VAR([$1], [value of $3 for $2, overriding pkg-config])dnl _PKG_CONFIG([$1], [variable="][$3]["], [$2]) AS_VAR_COPY([$1], [pkg_cv_][$1]) AS_VAR_IF([$1], [""], [$5], [$4])dnl ])dnl PKG_CHECK_VAR xrdp-0.9.5/m4/ax_type_socklen_t.m4000644 001751 001751 00000004612 13174271344 016727 0ustar00metameta000000 000000 # =========================================================================== # http://www.gnu.org/software/autoconf-archive/ax_type_socklen_t.html # =========================================================================== # # SYNOPSIS # # AX_TYPE_SOCKLEN_T # # DESCRIPTION # # Check whether sys/socket.h defines type socklen_t. Please note that some # systems require sys/types.h to be included before sys/socket.h can be # compiled. # # LICENSE # # Copyright (c) 2008 Lars Brinkhoff # # 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 2 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. # # You should have received a copy of the GNU General Public License along # with this program. If not, see . # # As a special exception, the respective Autoconf Macro's copyright owner # gives unlimited permission to copy, distribute and modify the configure # scripts that are the output of Autoconf when processing the Macro. You # need not follow the terms of the GNU General Public License when using # or distributing such scripts, even though portions of the text of the # Macro appear in them. The GNU General Public License (GPL) does govern # all other use of the material that constitutes the Autoconf Macro. # # This special exception to the GPL applies to versions of the Autoconf # Macro released by the Autoconf Archive. When you make and distribute a # modified version of the Autoconf Macro, you may extend this special # exception to the GPL to apply to your modified version as well. #serial 6 AU_ALIAS([TYPE_SOCKLEN_T], [AX_TYPE_SOCKLEN_T]) AC_DEFUN([AX_TYPE_SOCKLEN_T], [AC_CACHE_CHECK([for socklen_t], ac_cv_ax_type_socklen_t, [ AC_TRY_COMPILE( [#include #include ], [socklen_t len = (socklen_t) 42; return (!len);], ac_cv_ax_type_socklen_t=yes, ac_cv_ax_type_socklen_t=no) ]) if test $ac_cv_ax_type_socklen_t != yes; then AC_DEFINE(socklen_t, int, [Substitute for socklen_t]) fi ]) xrdp-0.9.5/m4/ltsugar.m4000644 001751 001751 00000010440 13220730762 014666 0ustar00metameta000000 000000 # ltsugar.m4 -- libtool m4 base layer. -*-Autoconf-*- # # Copyright (C) 2004-2005, 2007-2008, 2011-2015 Free Software # Foundation, Inc. # Written by Gary V. Vaughan, 2004 # # This file is free software; the Free Software Foundation gives # unlimited permission to copy and/or distribute it, with or without # modifications, as long as this notice is preserved. # serial 6 ltsugar.m4 # This is to help aclocal find these macros, as it can't see m4_define. AC_DEFUN([LTSUGAR_VERSION], [m4_if([0.1])]) # lt_join(SEP, ARG1, [ARG2...]) # ----------------------------- # Produce ARG1SEPARG2...SEPARGn, omitting [] arguments and their # associated separator. # Needed until we can rely on m4_join from Autoconf 2.62, since all earlier # versions in m4sugar had bugs. m4_define([lt_join], [m4_if([$#], [1], [], [$#], [2], [[$2]], [m4_if([$2], [], [], [[$2]_])$0([$1], m4_shift(m4_shift($@)))])]) m4_define([_lt_join], [m4_if([$#$2], [2], [], [m4_if([$2], [], [], [[$1$2]])$0([$1], m4_shift(m4_shift($@)))])]) # lt_car(LIST) # lt_cdr(LIST) # ------------ # Manipulate m4 lists. # These macros are necessary as long as will still need to support # Autoconf-2.59, which quotes differently. m4_define([lt_car], [[$1]]) m4_define([lt_cdr], [m4_if([$#], 0, [m4_fatal([$0: cannot be called without arguments])], [$#], 1, [], [m4_dquote(m4_shift($@))])]) m4_define([lt_unquote], $1) # lt_append(MACRO-NAME, STRING, [SEPARATOR]) # ------------------------------------------ # Redefine MACRO-NAME to hold its former content plus 'SEPARATOR''STRING'. # Note that neither SEPARATOR nor STRING are expanded; they are appended # to MACRO-NAME as is (leaving the expansion for when MACRO-NAME is invoked). # No SEPARATOR is output if MACRO-NAME was previously undefined (different # than defined and empty). # # This macro is needed until we can rely on Autoconf 2.62, since earlier # versions of m4sugar mistakenly expanded SEPARATOR but not STRING. m4_define([lt_append], [m4_define([$1], m4_ifdef([$1], [m4_defn([$1])[$3]])[$2])]) # lt_combine(SEP, PREFIX-LIST, INFIX, SUFFIX1, [SUFFIX2...]) # ---------------------------------------------------------- # Produce a SEP delimited list of all paired combinations of elements of # PREFIX-LIST with SUFFIX1 through SUFFIXn. Each element of the list # has the form PREFIXmINFIXSUFFIXn. # Needed until we can rely on m4_combine added in Autoconf 2.62. m4_define([lt_combine], [m4_if(m4_eval([$# > 3]), [1], [m4_pushdef([_Lt_sep], [m4_define([_Lt_sep], m4_defn([lt_car]))])]]dnl [[m4_foreach([_Lt_prefix], [$2], [m4_foreach([_Lt_suffix], ]m4_dquote(m4_dquote(m4_shift(m4_shift(m4_shift($@)))))[, [_Lt_sep([$1])[]m4_defn([_Lt_prefix])[$3]m4_defn([_Lt_suffix])])])])]) # lt_if_append_uniq(MACRO-NAME, VARNAME, [SEPARATOR], [UNIQ], [NOT-UNIQ]) # ----------------------------------------------------------------------- # Iff MACRO-NAME does not yet contain VARNAME, then append it (delimited # by SEPARATOR if supplied) and expand UNIQ, else NOT-UNIQ. m4_define([lt_if_append_uniq], [m4_ifdef([$1], [m4_if(m4_index([$3]m4_defn([$1])[$3], [$3$2$3]), [-1], [lt_append([$1], [$2], [$3])$4], [$5])], [lt_append([$1], [$2], [$3])$4])]) # lt_dict_add(DICT, KEY, VALUE) # ----------------------------- m4_define([lt_dict_add], [m4_define([$1($2)], [$3])]) # lt_dict_add_subkey(DICT, KEY, SUBKEY, VALUE) # -------------------------------------------- m4_define([lt_dict_add_subkey], [m4_define([$1($2:$3)], [$4])]) # lt_dict_fetch(DICT, KEY, [SUBKEY]) # ---------------------------------- m4_define([lt_dict_fetch], [m4_ifval([$3], m4_ifdef([$1($2:$3)], [m4_defn([$1($2:$3)])]), m4_ifdef([$1($2)], [m4_defn([$1($2)])]))]) # lt_if_dict_fetch(DICT, KEY, [SUBKEY], VALUE, IF-TRUE, [IF-FALSE]) # ----------------------------------------------------------------- m4_define([lt_if_dict_fetch], [m4_if(lt_dict_fetch([$1], [$2], [$3]), [$4], [$5], [$6])]) # lt_dict_filter(DICT, [SUBKEY], VALUE, [SEPARATOR], KEY, [...]) # -------------------------------------------------------------- m4_define([lt_dict_filter], [m4_if([$5], [], [], [lt_join(m4_quote(m4_default([$4], [[, ]])), lt_unquote(m4_split(m4_normalize(m4_foreach(_Lt_key, lt_car([m4_shiftn(4, $@)]), [lt_if_dict_fetch([$1], _Lt_key, [$2], [$3], [_Lt_key ])])))))])[]dnl ]) xrdp-0.9.5/m4/ax_require_defined.m4000644 001751 001751 00000002301 13127114621 017020 0ustar00metameta000000 000000 # =========================================================================== # http://www.gnu.org/software/autoconf-archive/ax_require_defined.html # =========================================================================== # # SYNOPSIS # # AX_REQUIRE_DEFINED(MACRO) # # DESCRIPTION # # AX_REQUIRE_DEFINED is a simple helper for making sure other macros have # been defined and thus are available for use. This avoids random issues # where a macro isn't expanded. Instead the configure script emits a # non-fatal: # # ./configure: line 1673: AX_CFLAGS_WARN_ALL: command not found # # It's like AC_REQUIRE except it doesn't expand the required macro. # # Here's an example: # # AX_REQUIRE_DEFINED([AX_CHECK_LINK_FLAG]) # # LICENSE # # Copyright (c) 2014 Mike Frysinger # # Copying and distribution of this file, with or without modification, are # permitted in any medium without royalty provided the copyright notice # and this notice are preserved. This file is offered as-is, without any # warranty. #serial 1 AC_DEFUN([AX_REQUIRE_DEFINED], [dnl m4_ifndef([$1], [m4_fatal([macro ]$1[ is not defined; is a m4 file missing?])]) ])dnl AX_REQUIRE_DEFINED xrdp-0.9.5/m4/ax_check_compile_flag.m4000644 001751 001751 00000006402 13127114621 017452 0ustar00metameta000000 000000 # =========================================================================== # http://www.gnu.org/software/autoconf-archive/ax_check_compile_flag.html # =========================================================================== # # SYNOPSIS # # AX_CHECK_COMPILE_FLAG(FLAG, [ACTION-SUCCESS], [ACTION-FAILURE], [EXTRA-FLAGS], [INPUT]) # # DESCRIPTION # # Check whether the given FLAG works with the current language's compiler # or gives an error. (Warnings, however, are ignored) # # ACTION-SUCCESS/ACTION-FAILURE are shell commands to execute on # success/failure. # # If EXTRA-FLAGS is defined, it is added to the current language's default # flags (e.g. CFLAGS) when the check is done. The check is thus made with # the flags: "CFLAGS EXTRA-FLAGS FLAG". This can for example be used to # force the compiler to issue an error when a bad flag is given. # # INPUT gives an alternative input source to AC_COMPILE_IFELSE. # # NOTE: Implementation based on AX_CFLAGS_GCC_OPTION. Please keep this # macro in sync with AX_CHECK_{PREPROC,LINK}_FLAG. # # LICENSE # # Copyright (c) 2008 Guido U. Draheim # Copyright (c) 2011 Maarten Bosmans # # 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. # # You should have received a copy of the GNU General Public License along # with this program. If not, see . # # As a special exception, the respective Autoconf Macro's copyright owner # gives unlimited permission to copy, distribute and modify the configure # scripts that are the output of Autoconf when processing the Macro. You # need not follow the terms of the GNU General Public License when using # or distributing such scripts, even though portions of the text of the # Macro appear in them. The GNU General Public License (GPL) does govern # all other use of the material that constitutes the Autoconf Macro. # # This special exception to the GPL applies to versions of the Autoconf # Macro released by the Autoconf Archive. When you make and distribute a # modified version of the Autoconf Macro, you may extend this special # exception to the GPL to apply to your modified version as well. #serial 4 AC_DEFUN([AX_CHECK_COMPILE_FLAG], [AC_PREREQ(2.64)dnl for _AC_LANG_PREFIX and AS_VAR_IF AS_VAR_PUSHDEF([CACHEVAR],[ax_cv_check_[]_AC_LANG_ABBREV[]flags_$4_$1])dnl AC_CACHE_CHECK([whether _AC_LANG compiler accepts $1], CACHEVAR, [ ax_check_save_flags=$[]_AC_LANG_PREFIX[]FLAGS _AC_LANG_PREFIX[]FLAGS="$[]_AC_LANG_PREFIX[]FLAGS $4 $1" AC_COMPILE_IFELSE([m4_default([$5],[AC_LANG_PROGRAM()])], [AS_VAR_SET(CACHEVAR,[yes])], [AS_VAR_SET(CACHEVAR,[no])]) _AC_LANG_PREFIX[]FLAGS=$ax_check_save_flags]) AS_VAR_IF(CACHEVAR,yes, [m4_default([$2], :)], [m4_default([$3], :)]) AS_VAR_POPDEF([CACHEVAR])dnl ])dnl AX_CHECK_COMPILE_FLAGS xrdp-0.9.5/fontdump/.gitignore000644 001751 001751 00000000012 13127114621 016235 0ustar00metameta000000 000000 !Makefile xrdp-0.9.5/fontdump/Makefile000644 001751 001751 00000000472 13127114621 015717 0ustar00metameta000000 000000 OBJS = fontdump.obj os_calls.obj #CFLAGS = -O2 -I../common CFLAGS = -O2 -I../common -DUNICODE -D_UNICODE LDFLAGS = -W -efontdump.exe all: fontdump1 fontdump1: $(OBJS) $(CC) $(LDFLAGS) $(OBJS) clean: del $(OBJS) fontdump.exe *.tds os_calls.obj: ../common/os_calls.c $(CC) $(CFLAGS) -c ../common/os_calls.c xrdp-0.9.5/fontdump/fontdump.c000644 001751 001751 00000035023 13127114621 016257 0ustar00metameta000000 000000 /** * xrdp: A Remote Desktop Protocol server. * * Copyright (C) Jay Sorg 2004-2012 * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ #include #include #include #include #include #include #include "os_calls.h" #include "arch.h" static HINSTANCE g_instance = 0; static HWND g_wnd = 0; static HWND g_lb = 0; static HWND g_exit_button = 0; static HWND g_go_button = 0; static HWND g_font_list = 0; static char g_font_name[512] = ""; static int g_font_size = 10; static HFONT g_font = 0; static int g_running = 0; #define FONT_DATASIZE(_w, _h) (((_h * ((_w + 7) / 8)) + 3) & ~3) /*****************************************************************************/ int check_messages(void) { MSG msg; while (PeekMessage(&msg, 0, 0, 0, PM_NOREMOVE)) { GetMessage(&msg, NULL, 0, 0); TranslateMessage(&msg); DispatchMessage(&msg); } return 0; } /*****************************************************************************/ static int msg(char *msg1, ...) { va_list ap; char text1[512]; va_start(ap, msg1); vsnprintf(text1, 511, msg1, ap); SendMessageA(g_lb, LB_ADDSTRING, 0, (LPARAM)text1); va_end(ap); return 0; } /*****************************************************************************/ static int show_last_error(void) { LPVOID lpMsgBuf; FormatMessageA(FORMAT_MESSAGE_ALLOCATE_BUFFER | FORMAT_MESSAGE_FROM_SYSTEM, NULL, GetLastError(), MAKELANGID(LANG_NEUTRAL, SUBLANG_DEFAULT), (LPSTR)&lpMsgBuf, 0, NULL); msg("GetLastError - %s", lpMsgBuf); LocalFree(lpMsgBuf); return 0; } /*****************************************************************************/ static int font_dump(void) { HDC dc; HDC dc1; RECT rect; HBRUSH brush; HGDIOBJ saved; HBITMAP bitmap; BITMAPINFO bi; char *bits; ABC abc; SIZE sz; char filename[256]; TCHAR text[256]; char zero1; char *bmtext; int bmtextindex; int fd; int x1; int strlen1; int index1; int index2; int len; int pixel; int red; int green; int blue; int width; int height; int roller; int outlen; tui8 b1; short x2; if (g_running) { return 0; } g_running = 1; msg("starting"); g_font_name[0] = 0; SendMessageA(g_font_list, WM_GETTEXT, 255, (LPARAM)g_font_name); if (g_strlen(g_font_name) == 0) { msg("error font not set"); g_running = 0; return 1; } dc = GetDC(g_wnd); height = -MulDiv(g_font_size, GetDeviceCaps(dc, LOGPIXELSY), 72); g_font = CreateFontA(height, 0, 0, 0, FW_DONTCARE, 0, 0, 0, 0, 0, 0, 0, 0, g_font_name); ReleaseDC(g_wnd, dc); if (g_font == 0) { msg("error - Font creation failed"); } zero1 = 0; g_snprintf(filename, 255, "%s-%d.fv1", g_font_name, g_font_size); msg("creating file %s", filename); g_file_delete(filename); fd = g_file_open(filename); g_file_write(fd, "FNT1", 4); strlen1 = g_strlen(g_font_name); g_file_write(fd, g_font_name, strlen1); x1 = strlen1; while (x1 < 32) { g_file_write(fd, &zero1, 1); x1++; } x2 = g_font_size; /* font size */ g_file_write(fd, (char *)&x2, 2); x2 = 1; /* style */ g_file_write(fd, (char *)&x2, 2); /* pad */ index1 = 0; while (index1 < 8) { g_file_write(fd, &zero1, 1); index1++; } for (x1 = 32; x1 < 0x4e00; x1++) { check_messages(); dc = GetWindowDC(g_wnd); saved = SelectObject(dc, g_font); if (!GetCharABCWidths(dc, x1, x1, &abc)) { show_last_error(); } text[0] = (TCHAR)x1; text[1] = 0; if (!GetTextExtentPoint32(dc, text, 1, &sz)) { show_last_error(); } SelectObject(dc, saved); ReleaseDC(g_wnd, dc); if ((sz.cx > 0) && (sz.cy > 0)) { dc = GetWindowDC(g_wnd); saved = SelectObject(dc, g_font); SetBkColor(dc, RGB(255, 255, 255)); if (!ExtTextOut(dc, 50, 50, ETO_OPAQUE, 0, text, 1, 0)) { show_last_error(); } SelectObject(dc, saved); ReleaseDC(g_wnd, dc); Sleep(10); /* width */ x2 = abc.abcB; g_file_write(fd, (char *)&x2, 2); /* height */ x2 = sz.cy; g_file_write(fd, (char *)&x2, 2); /* baseline */ x2 = -sz.cy; g_file_write(fd, (char *)&x2, 2); /* offset */ x2 = abc.abcA; g_file_write(fd, (char *)&x2, 2); /* incby */ x2 = sz.cx; g_file_write(fd, (char *)&x2, 2); /* pad */ index1 = 0; while (index1 < 6) { g_file_write(fd, &zero1, 1); index1++; } dc = GetWindowDC(g_wnd); rect.left = 50 + abc.abcA; rect.top = 50; rect.right = rect.left + abc.abcB; rect.bottom = rect.top + sz.cy; memset(&bi, 0, sizeof(bi)); width = (abc.abcB + 7) & (~7); height = sz.cy; bi.bmiHeader.biSize = sizeof(bi.bmiHeader); bi.bmiHeader.biWidth = width; bi.bmiHeader.biHeight = height; bi.bmiHeader.biPlanes = 1; bi.bmiHeader.biBitCount = 32; bitmap = CreateDIBSection(dc, &bi, DIB_RGB_COLORS, (void *)&bits, 0, 0); if (bitmap == 0) { msg("error - CreateDIBSection failed"); } else { memset(bits, 0, width * height * 4); dc1 = CreateCompatibleDC(dc); SelectObject(dc1, bitmap); if (!BitBlt(dc1, 0, 0, width, height, dc, rect.left, rect.top, SRCCOPY)) { show_last_error(); } bmtext = (char *)g_malloc(width * height + 16, 1); bmtextindex = 0; for (index1 = (height - 1); index1 >= 0; index1--) { for (index2 = 0; index2 < width; index2++) { pixel = ((int *)bits)[index1 * width + index2]; red = (pixel >> 16) & 0xff; green = (pixel >> 8) & 0xff; blue = (pixel >> 0) & 0xff; if (red == 0 && green == 0 && blue == 0) { bmtext[bmtextindex] = '1'; bmtextindex++; } else { bmtext[bmtextindex] = '0'; bmtextindex++; } } } outlen = 0; b1 = 0; roller = 0; len = g_strlen(bmtext); for (index2 = 0; index2 < len; index2++) { if (bmtext[index2] == '1') { switch (roller) { case 0: b1 = b1 | 0x80; break; case 1: b1 = b1 | 0x40; break; case 2: b1 = b1 | 0x20; break; case 3: b1 = b1 | 0x10; break; case 4: b1 = b1 | 0x08; break; case 5: b1 = b1 | 0x04; break; case 6: b1 = b1 | 0x02; break; case 7: b1 = b1 | 0x01; break; } } roller++; if (roller == 8) { roller = 0; g_file_write(fd, &b1, 1); outlen++; b1 = 0; } } while ((outlen % 4) != 0) { g_file_write(fd, &zero1, 1); outlen++; } free(bmtext); DeleteDC(dc1); DeleteObject(bitmap); } if (sz.cx != (long)(abc.abcA + abc.abcB + abc.abcC)) { msg("error - width not right 1"); } brush = CreateSolidBrush(RGB(255, 255, 255)); FillRect(dc, &rect, brush); DeleteObject(brush); ReleaseDC(g_wnd, dc); } else { /* write out a blank glyph here */ /* width */ x2 = 1; g_file_write(fd, (char *)&x2, 2); /* height */ x2 = 1; g_file_write(fd, (char *)&x2, 2); /* baseline */ x2 = 0; g_file_write(fd, (char *)&x2, 2); /* offset */ x2 = 0; g_file_write(fd, (char *)&x2, 2); /* incby */ x2 = 1; g_file_write(fd, (char *)&x2, 2); /* pad */ index1 = 0; while (index1 < 6) { g_file_write(fd, &zero1, 1); index1++; } /* blank bitmap */ index1 = 0; while (index1 < 4) { g_file_write(fd, &zero1, 1); index1++; } } } g_file_close(fd); msg("done"); g_running = 0; return 0; } /*****************************************************************************/ static LRESULT CALLBACK wnd_proc(HWND hWnd, UINT message, WPARAM wParam, LPARAM lParam) { PAINTSTRUCT ps; HBRUSH brush; RECT rect; switch (message) { case WM_PAINT: BeginPaint(hWnd, &ps); brush = CreateSolidBrush(RGB(255, 255, 255)); rect = ps.rcPaint; FillRect(ps.hdc, &rect, brush); DeleteObject(brush); EndPaint(hWnd, &ps); break; case WM_CLOSE: DestroyWindow(g_wnd); g_wnd = 0; break; case WM_DESTROY: PostQuitMessage(0); break; case WM_TIMER: KillTimer(g_wnd, 1); font_dump(); break; case WM_COMMAND: if ((HWND)lParam == g_exit_button) { PostMessage(g_wnd, WM_CLOSE, 0, 0); } else if ((HWND)lParam == g_go_button) { while (SendMessage(g_lb, LB_GETCOUNT, 0, 0) > 0) { SendMessage(g_lb, LB_DELETESTRING, 0, 0); } SetTimer(g_wnd, 1, 1000, 0); } break; } return DefWindowProc(hWnd, message, wParam, lParam); } /*****************************************************************************/ static int create_window(void) { WNDCLASS wc; DWORD style; HDC dc; int height; int left; int top; ZeroMemory(&wc, sizeof(wc)); wc.lpfnWndProc = wnd_proc; /* points to window procedure */ /* name of window class */ wc.lpszClassName = _T("fontdump"); wc.hCursor = LoadCursor(0, IDC_ARROW); /* Register the window class. */ if (!RegisterClass(&wc)) { return 0; /* Failed to register window class */ } style = WS_OVERLAPPED | WS_CAPTION | WS_POPUP | WS_MINIMIZEBOX | WS_SYSMENU | WS_SIZEBOX | WS_MAXIMIZEBOX; left = GetSystemMetrics(SM_CXSCREEN) / 2 - 640 / 2; top = GetSystemMetrics(SM_CYSCREEN) / 2 - 480 / 2; g_wnd = CreateWindow(wc.lpszClassName, _T("fontdump"), style, left, top, 640, 480, (HWND) NULL, (HMENU) NULL, g_instance, (LPVOID) NULL); style = WS_CHILD | WS_VISIBLE | WS_BORDER; g_lb = CreateWindow(_T("LISTBOX"), _T("LISTBOX1"), style, 200, 10, 400, 400, g_wnd, 0, g_instance, 0); style = WS_CHILD | WS_VISIBLE; g_exit_button = CreateWindow(_T("BUTTON"), _T("Exit"), style, 540, 410, 75, 25, g_wnd, 0, g_instance, 0); g_go_button = CreateWindow(_T("BUTTON"), _T("Go"), style, 440, 410, 75, 25, g_wnd, 0, g_instance, 0); style = WS_CHILD | WS_VISIBLE | CBS_DROPDOWN; g_font_list = CreateWindow(_T("COMBOBOX"), _T("COMBOBOX1"), style, 50, 250, 125, 125, g_wnd, 0, g_instance, 0); ShowWindow(g_wnd, SW_SHOWNORMAL); PostMessage(g_wnd, WM_SETFONT, (WPARAM)g_font, 0); SendMessageA(g_font_list, CB_ADDSTRING, 0, (LPARAM)"Tahoma"); SendMessageA(g_font_list, CB_ADDSTRING, 0, (LPARAM)"DejaVu Serif"); SendMessageA(g_font_list, CB_ADDSTRING, 0, (LPARAM)"DejaVu Sans"); SendMessageA(g_font_list, CB_ADDSTRING, 0, (LPARAM)"Arial"); SendMessageA(g_font_list, CB_ADDSTRING, 0, (LPARAM)"Comic Sans MS"); return 0; } /*****************************************************************************/ static int main_loop(void) { MSG msg; while (GetMessage(&msg, NULL, 0, 0)) { TranslateMessage(&msg); DispatchMessage(&msg); } return (int)(msg.wParam); } /*****************************************************************************/ int WINAPI WinMain(HINSTANCE hInstance, HINSTANCE hPrevInstance, LPSTR lpCmdLine, int nCmdShow) { g_instance = hInstance; create_window(); return main_loop(); } xrdp-0.9.5/xrdpvr/xrdpvr_internal.h000644 001751 001751 00000020320 13125122134 017330 0ustar00metameta000000 000000 /** * xrdp: A Remote Desktop Protocol server. * * Copyright (C) Laxmikant Rashinkar 2012-2013 LK.Rashinkar@gmail.com * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. * * a program that uses xrdpapi and ffmpeg to redirect media streams * to a FreeRDP client where it is decompressed and played locally * */ #ifndef __XRDPVR_INTERNAL_H__ #define __XRDPVR_INTERNAL_H__ #include #include #include #include #include #if LIBAVCODEC_VERSION_MAJOR == 52 && LIBAVCODEC_VERSION_MINOR == 20 #define DISTRO_DEBIAN6 #endif #if LIBAVCODEC_VERSION_MAJOR == 52 && LIBAVCODEC_VERSION_MINOR == 72 #define DISTRO_UBUNTU1104 #endif #if LIBAVCODEC_VERSION_MAJOR == 53 && LIBAVCODEC_VERSION_MINOR == 35 #define DISTRO_UBUNTU1204 #endif #if !defined(DISTRO_DEBIAN6) && !defined(DISTRO_UBUNTU1104) && !defined(DISTRO_UBUNTU1204) #warning unsupported distro #endif #ifdef DISTRO_UBUNTU1204 #define CODEC_TYPE_VIDEO AVMEDIA_TYPE_VIDEO #define CODEC_TYPE_AUDIO AVMEDIA_TYPE_AUDIO #define PKT_FLAG_KEY AV_PKT_FLAG_KEY #endif #define MAX_BUFSIZE (1024 * 1024 * 8) #define CMD_SET_VIDEO_FORMAT 1 #define CMD_SET_AUDIO_FORMAT 2 #define CMD_SEND_VIDEO_DATA 3 #define CMD_SEND_AUDIO_DATA 4 #define CMD_CREATE_META_DATA_FILE 5 #define CMD_CLOSE_META_DATA_FILE 6 #define CMD_WRITE_META_DATA 7 #define CMD_DEINIT_XRDPVR 8 #define CMD_SET_GEOMETRY 9 #define CMD_SET_VOLUME 10 #define CMD_INIT_XRDPVR 11 /* max number of bytes we can send in one pkt */ #define MAX_PDU_SIZE 1600 typedef uint8_t u8; typedef uint16_t u16; typedef uint32_t u32; typedef struct stream { u8 *data; u8 *p; u32 size; int from_buf; } STREAM; /** * create and init a new stream * * @param _s stream to create and init * @param _len number of bytes to store in stream ******************************************************************************/ #define stream_new(_s, _len) \ do \ { \ (_s) = (STREAM *) calloc(1, sizeof(STREAM)); \ (_s)->data = (u8 *) calloc(1, (_len)); \ (_s)->p = (_s)->data; \ (_s)->size = (_len); \ (_s)->from_buf = 0; \ } while (0) /** * create a stream from an existing buffer ******************************************************************************/ #define stream_from_buffer(_s, _buf, _buf_len) \ do \ { \ (_s) = (STREAM *) calloc(1, sizeof(STREAM)); \ (_s)->data = (u8 *) (_buf); \ (_s)->p = (_s)->data; \ (_s)->size = (_buf_len); \ (_s)->from_buf = 1; \ } while (0) /** * release stream resources, including stream itself * note: release _s->data only if we allocated it * * @param _s the stream whose resources are to be released ******************************************************************************/ #define stream_free(_s) \ do \ { \ if (!(_s)->from_buf) \ { \ free((_s)->data); \ } \ free((_s)); \ (_s) = NULL; \ } while (0) /** return number of bytes in stream */ #define stream_length(_s) (int) ((_s)->p - (_s)->data) /** insert a 8 bit value into stream */ #define stream_ins_u8(_s, _val) \ do \ { \ *(_s)->p++ = (unsigned char) (_val); \ } while(0) /** insert a 16 bit value into stream */ #define stream_ins_u16_le(_s, _val) \ do \ { \ *(_s)->p++ = (unsigned char) ((_val) >> 0); \ *(_s)->p++ = (unsigned char) ((_val) >> 8); \ } while (0) /** insert a 32 bit value into stream */ #define stream_ins_u32_le(_s, _val) \ do \ { \ *(_s)->p++ = (unsigned char) ((_val) >> 0); \ *(_s)->p++ = (unsigned char) ((_val) >> 8); \ *(_s)->p++ = (unsigned char) ((_val) >> 16); \ *(_s)->p++ = (unsigned char) ((_val) >> 24); \ } while (0) /** insert a 64 bit value into stream */ #define stream_ins_u64_le(_s, _val) \ do \ { \ *(_s)->p++ = (unsigned char) ((_val) >> 0); \ *(_s)->p++ = (unsigned char) ((_val) >> 8); \ *(_s)->p++ = (unsigned char) ((_val) >> 16); \ *(_s)->p++ = (unsigned char) ((_val) >> 24); \ *(_s)->p++ = (unsigned char) ((_val) >> 32); \ *(_s)->p++ = (unsigned char) ((_val) >> 40); \ *(_s)->p++ = (unsigned char) ((_val) >> 48); \ *(_s)->p++ = (unsigned char) ((_val) >> 56); \ } while (0) /** insert array of chars into stream */ #define stream_ins_byte_array(_s, _ba, _count) \ do \ { \ memcpy((_s)->p, (_ba), (_count)); \ (_s)->p += (_count); \ } while (0) /** extract a 8 bit value from stream */ #define stream_ext_u8(_s, _v) \ do \ { \ (_v) = (u8) *(_s)->p++; \ } while (0) /** extract a 16 bit value from stream */ #define stream_ext_u16_le(_s, _v) \ do \ { \ (_v) = (u16) ((_s)->p[1] << 8 | (_s)->p[0]); \ (_s)->p += 2; \ } while (0) /** extract a 32 bit value from stream */ #define stream_ext_u32_le(_s, _v) \ do \ { \ (_v) = (u32) ((_s)->p[3] << 24 | \ (_s)->p[2] << 16 | \ (_s)->p[1] << 8 | \ (_s)->p[0]); \ (_s)->p += 4; \ } while (0) typedef struct _player_state_info { AVFormatContext *p_format_ctx; AVCodecContext *p_audio_codec_ctx; AVCodecContext *p_video_codec_ctx; AVCodec *p_audio_codec; AVCodec *p_video_codec; int audio_stream_index; int video_stream_index; double audioTimeout; double videoTimeout; /* LK_TODO delete this after we fix the problem */ AVFrame *frame; AVPacket avpkt; AVBitStreamFilterContext *bsfc; } PLAYER_STATE_INFO; static int xrdpvr_read_from_client(void *channel, STREAM *s, int bytes, int timeout); static int xrdpvr_write_to_client(void *channel, STREAM *s); #endif /* __XRDPVR_INTERNAL_H__ */ xrdp-0.9.5/xrdpvr/xrdpvr.h000644 001751 001751 00000005156 13125122134 015446 0ustar00metameta000000 000000 /** * xrdp: A Remote Desktop Protocol server. * * Copyright (C) Laxmikant Rashinkar 2012-2013 LK.Rashinkar@gmail.com * Copyright (C) Jay Sorg 2013 jay.sorg@gmail.com * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. * * a program that uses xrdpapi and ffmpeg to redirect media streams * to a FreeRDP client where it is decompressed and played locally * */ #ifndef __XRDPVR_H__ #define __XRDPVR_H__ #include #ifdef __cplusplus extern "C" { #endif int xrdpvr_init_player(void *channel, int stream_id, char *filename); int xrdpvr_deinit_player(void *channel, int stream_id); int xrdpvr_play_media(void *channel, int stream_id, char *filename); int xrdpvr_set_geometry(void *channel, int stream_id, int xpos, int ypos, int width, int height); int xrdpvr_set_video_format(void *channel, uint32_t stream_id, int format, int width, int height); int xrdpvr_set_audio_format(void *channel, uint32_t stream_id, int format, char *extradata, int extradata_size, int sample_rate, int bit_rate, int channels, int block_align); int xrdpvr_send_video_data(void *channel, uint32_t stream_id, uint32_t data_len, uint8_t *data); int xrdpvr_send_audio_data(void *channel, uint32_t stream_id, uint32_t data_len, uint8_t *data); int xrdpvr_create_metadata_file(void *channel, char *filename); int xrdpvr_play_frame(void *channel, int stream_id, int *vdoTimeout, int *audioTimeout); void xrdpvr_get_media_duration(int64_t *start_time, int64_t *duration); int xrdpvr_seek_media(int64_t pos, int backward); int xrdpvr_get_frame(void **av_pkt_ret, int *is_video_frame, int *delay_in_us); int send_audio_pkt(void *channel, int stream_id, void *pkt_p); int send_video_pkt(void *channel, int stream_id, void *pkt_p); int xrdpvr_set_volume(void *channel, int volume); int xrdpvr_send_init(void *channel); int xrdpvr_read_ack(void *channel, int *frame); #ifdef __cplusplus } #endif #endif /* __XRDPVR_H__ */ xrdp-0.9.5/xrdpvr/Makefile.in000644 001751 001751 00000051107 13220730775 016026 0ustar00metameta000000 000000 # Makefile.in generated by automake 1.15.1 from Makefile.am. # @configure_input@ # Copyright (C) 1994-2017 Free Software Foundation, Inc. # This Makefile.in is free software; the Free Software Foundation # gives unlimited permission to copy and/or distribute it, # with or without modifications, as long as this notice is preserved. # This program is distributed in the hope that it will be useful, # but WITHOUT ANY WARRANTY, to the extent permitted by law; without # even the implied warranty of MERCHANTABILITY or FITNESS FOR A # PARTICULAR PURPOSE. @SET_MAKE@ VPATH = @srcdir@ am__is_gnu_make = { \ if test -z '$(MAKELEVEL)'; then \ false; \ elif test -n '$(MAKE_HOST)'; then \ true; \ elif test -n '$(MAKE_VERSION)' && test -n '$(CURDIR)'; then \ true; \ else \ false; \ fi; \ } am__make_running_with_option = \ case $${target_option-} in \ ?) ;; \ *) echo "am__make_running_with_option: internal error: invalid" \ "target option '$${target_option-}' specified" >&2; \ exit 1;; \ esac; \ has_opt=no; \ sane_makeflags=$$MAKEFLAGS; \ if $(am__is_gnu_make); then \ sane_makeflags=$$MFLAGS; \ else \ case $$MAKEFLAGS in \ *\\[\ \ ]*) \ bs=\\; \ sane_makeflags=`printf '%s\n' "$$MAKEFLAGS" \ | sed "s/$$bs$$bs[$$bs $$bs ]*//g"`;; \ esac; \ fi; \ skip_next=no; \ strip_trailopt () \ { \ flg=`printf '%s\n' "$$flg" | sed "s/$$1.*$$//"`; \ }; \ for flg in $$sane_makeflags; do \ test $$skip_next = yes && { skip_next=no; continue; }; \ case $$flg in \ *=*|--*) continue;; \ -*I) strip_trailopt 'I'; skip_next=yes;; \ -*I?*) strip_trailopt 'I';; \ -*O) strip_trailopt 'O'; skip_next=yes;; \ -*O?*) strip_trailopt 'O';; \ -*l) strip_trailopt 'l'; skip_next=yes;; \ -*l?*) strip_trailopt 'l';; \ -[dEDm]) skip_next=yes;; \ -[JT]) skip_next=yes;; \ esac; \ case $$flg in \ *$$target_option*) has_opt=yes; break;; \ esac; \ done; \ test $$has_opt = yes am__make_dryrun = (target_option=n; $(am__make_running_with_option)) am__make_keepgoing = (target_option=k; $(am__make_running_with_option)) pkgdatadir = $(datadir)/@PACKAGE@ pkgincludedir = $(includedir)/@PACKAGE@ pkglibdir = $(libdir)/@PACKAGE@ pkglibexecdir = $(libexecdir)/@PACKAGE@ am__cd = CDPATH="$${ZSH_VERSION+.}$(PATH_SEPARATOR)" && cd install_sh_DATA = $(install_sh) -c -m 644 install_sh_PROGRAM = $(install_sh) -c install_sh_SCRIPT = $(install_sh) -c INSTALL_HEADER = $(INSTALL_DATA) transform = $(program_transform_name) NORMAL_INSTALL = : PRE_INSTALL = : POST_INSTALL = : NORMAL_UNINSTALL = : PRE_UNINSTALL = : POST_UNINSTALL = : build_triplet = @build@ host_triplet = @host@ subdir = xrdpvr ACLOCAL_M4 = $(top_srcdir)/aclocal.m4 am__aclocal_m4_deps = $(top_srcdir)/m4/ax_append_compile_flags.m4 \ $(top_srcdir)/m4/ax_append_flag.m4 \ $(top_srcdir)/m4/ax_cflags_warn_all.m4 \ $(top_srcdir)/m4/ax_check_compile_flag.m4 \ $(top_srcdir)/m4/ax_gcc_func_attribute.m4 \ $(top_srcdir)/m4/ax_require_defined.m4 \ $(top_srcdir)/m4/ax_type_socklen_t.m4 \ $(top_srcdir)/m4/libtool.m4 $(top_srcdir)/m4/ltoptions.m4 \ $(top_srcdir)/m4/ltsugar.m4 $(top_srcdir)/m4/ltversion.m4 \ $(top_srcdir)/m4/lt~obsolete.m4 $(top_srcdir)/m4/pkg.m4 \ $(top_srcdir)/configure.ac am__configure_deps = $(am__aclocal_m4_deps) $(CONFIGURE_DEPENDENCIES) \ $(ACLOCAL_M4) DIST_COMMON = $(srcdir)/Makefile.am $(am__DIST_COMMON) mkinstalldirs = $(install_sh) -d CONFIG_HEADER = $(top_builddir)/config_ac.h CONFIG_CLEAN_FILES = CONFIG_CLEAN_VPATH_FILES = am__vpath_adj_setup = srcdirstrip=`echo "$(srcdir)" | sed 's|.|.|g'`; am__vpath_adj = case $$p in \ $(srcdir)/*) f=`echo "$$p" | sed "s|^$$srcdirstrip/||"`;; \ *) f=$$p;; \ esac; am__strip_dir = f=`echo $$p | sed -e 's|^.*/||'`; am__install_max = 40 am__nobase_strip_setup = \ srcdirstrip=`echo "$(srcdir)" | sed 's/[].[^$$\\*|]/\\\\&/g'` am__nobase_strip = \ for p in $$list; do echo "$$p"; done | sed -e "s|$$srcdirstrip/||" am__nobase_list = $(am__nobase_strip_setup); \ for p in $$list; do echo "$$p $$p"; done | \ sed "s| $$srcdirstrip/| |;"' / .*\//!s/ .*/ ./; s,\( .*\)/[^/]*$$,\1,' | \ $(AWK) 'BEGIN { files["."] = "" } { files[$$2] = files[$$2] " " $$1; \ if (++n[$$2] == $(am__install_max)) \ { print $$2, files[$$2]; n[$$2] = 0; files[$$2] = "" } } \ END { for (dir in files) print dir, files[dir] }' am__base_list = \ sed '$$!N;$$!N;$$!N;$$!N;$$!N;$$!N;$$!N;s/\n/ /g' | \ sed '$$!N;$$!N;$$!N;$$!N;s/\n/ /g' am__uninstall_files_from_dir = { \ test -z "$$files" \ || { test ! -d "$$dir" && test ! -f "$$dir" && test ! -r "$$dir"; } \ || { echo " ( cd '$$dir' && rm -f" $$files ")"; \ $(am__cd) "$$dir" && rm -f $$files; }; \ } am__installdirs = "$(DESTDIR)$(moduledir)" LTLIBRARIES = $(module_LTLIBRARIES) libxrdpvr_la_LIBADD = am_libxrdpvr_la_OBJECTS = xrdpvr.lo libxrdpvr_la_OBJECTS = $(am_libxrdpvr_la_OBJECTS) AM_V_lt = $(am__v_lt_@AM_V@) am__v_lt_ = $(am__v_lt_@AM_DEFAULT_V@) am__v_lt_0 = --silent am__v_lt_1 = AM_V_P = $(am__v_P_@AM_V@) am__v_P_ = $(am__v_P_@AM_DEFAULT_V@) am__v_P_0 = false am__v_P_1 = : AM_V_GEN = $(am__v_GEN_@AM_V@) am__v_GEN_ = $(am__v_GEN_@AM_DEFAULT_V@) am__v_GEN_0 = @echo " GEN " $@; am__v_GEN_1 = AM_V_at = $(am__v_at_@AM_V@) am__v_at_ = $(am__v_at_@AM_DEFAULT_V@) am__v_at_0 = @ am__v_at_1 = DEFAULT_INCLUDES = -I.@am__isrc@ -I$(top_builddir) depcomp = $(SHELL) $(top_srcdir)/depcomp am__depfiles_maybe = depfiles am__mv = mv -f COMPILE = $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) \ $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) LTCOMPILE = $(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) \ $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) \ $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) \ $(AM_CFLAGS) $(CFLAGS) AM_V_CC = $(am__v_CC_@AM_V@) am__v_CC_ = $(am__v_CC_@AM_DEFAULT_V@) am__v_CC_0 = @echo " CC " $@; am__v_CC_1 = CCLD = $(CC) LINK = $(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) \ $(LIBTOOLFLAGS) --mode=link $(CCLD) $(AM_CFLAGS) $(CFLAGS) \ $(AM_LDFLAGS) $(LDFLAGS) -o $@ AM_V_CCLD = $(am__v_CCLD_@AM_V@) am__v_CCLD_ = $(am__v_CCLD_@AM_DEFAULT_V@) am__v_CCLD_0 = @echo " CCLD " $@; am__v_CCLD_1 = SOURCES = $(libxrdpvr_la_SOURCES) DIST_SOURCES = $(libxrdpvr_la_SOURCES) am__can_run_installinfo = \ case $$AM_UPDATE_INFO_DIR in \ n|no|NO) false;; \ *) (install-info --version) >/dev/null 2>&1;; \ esac am__tagged_files = $(HEADERS) $(SOURCES) $(TAGS_FILES) $(LISP) # Read a list of newline-separated strings from the standard input, # and print each of them once, without duplicates. Input order is # *not* preserved. am__uniquify_input = $(AWK) '\ BEGIN { nonempty = 0; } \ { items[$$0] = 1; nonempty = 1; } \ END { if (nonempty) { for (i in items) print i; }; } \ ' # Make sure the list of sources is unique. This is necessary because, # e.g., the same source file might be shared among _SOURCES variables # for different programs/libraries. am__define_uniq_tagged_files = \ list='$(am__tagged_files)'; \ unique=`for i in $$list; do \ if test -f "$$i"; then echo $$i; else echo $(srcdir)/$$i; fi; \ done | $(am__uniquify_input)` ETAGS = etags CTAGS = ctags am__DIST_COMMON = $(srcdir)/Makefile.in $(top_srcdir)/depcomp DISTFILES = $(DIST_COMMON) $(DIST_SOURCES) $(TEXINFOS) $(EXTRA_DIST) ACLOCAL = @ACLOCAL@ AMTAR = @AMTAR@ AM_DEFAULT_VERBOSITY = @AM_DEFAULT_VERBOSITY@ AR = @AR@ AUTOCONF = @AUTOCONF@ AUTOHEADER = @AUTOHEADER@ AUTOMAKE = @AUTOMAKE@ AWK = @AWK@ CC = @CC@ CCDEPMODE = @CCDEPMODE@ CFLAGS = @CFLAGS@ CPP = @CPP@ CPPFLAGS = @CPPFLAGS@ CYGPATH_W = @CYGPATH_W@ DEFS = @DEFS@ DEPDIR = @DEPDIR@ DLLTOOL = @DLLTOOL@ DLOPEN_LIBS = @DLOPEN_LIBS@ DSYMUTIL = @DSYMUTIL@ DUMPBIN = @DUMPBIN@ ECHO_C = @ECHO_C@ ECHO_N = @ECHO_N@ ECHO_T = @ECHO_T@ EGREP = @EGREP@ EXEEXT = @EXEEXT@ FDKAAC_CFLAGS = @FDKAAC_CFLAGS@ FDKAAC_LIBS = @FDKAAC_LIBS@ FGREP = @FGREP@ FREERDP_CFLAGS = @FREERDP_CFLAGS@ FREERDP_LIBS = @FREERDP_LIBS@ FUSE_CFLAGS = @FUSE_CFLAGS@ FUSE_LIBS = @FUSE_LIBS@ GREP = @GREP@ INSTALL = @INSTALL@ INSTALL_DATA = @INSTALL_DATA@ INSTALL_PROGRAM = @INSTALL_PROGRAM@ INSTALL_SCRIPT = @INSTALL_SCRIPT@ INSTALL_STRIP_PROGRAM = @INSTALL_STRIP_PROGRAM@ LD = @LD@ LDFLAGS = @LDFLAGS@ LIBOBJS = @LIBOBJS@ LIBS = @LIBS@ LIBTOOL = @LIBTOOL@ LIPO = @LIPO@ LN_S = @LN_S@ LTLIBOBJS = @LTLIBOBJS@ LT_SYS_LIBRARY_PATH = @LT_SYS_LIBRARY_PATH@ MAKEINFO = @MAKEINFO@ MANIFEST_TOOL = @MANIFEST_TOOL@ MKDIR_P = @MKDIR_P@ NM = @NM@ NMEDIT = @NMEDIT@ OBJDUMP = @OBJDUMP@ OBJEXT = @OBJEXT@ OPENSSL = @OPENSSL@ OPENSSL_CFLAGS = @OPENSSL_CFLAGS@ OPENSSL_LIBS = @OPENSSL_LIBS@ OTOOL = @OTOOL@ OTOOL64 = @OTOOL64@ PACKAGE = @PACKAGE@ PACKAGE_BUGREPORT = @PACKAGE_BUGREPORT@ PACKAGE_NAME = @PACKAGE_NAME@ PACKAGE_STRING = @PACKAGE_STRING@ PACKAGE_TARNAME = @PACKAGE_TARNAME@ PACKAGE_URL = @PACKAGE_URL@ PACKAGE_VERSION = @PACKAGE_VERSION@ PAM_RULES = @PAM_RULES@ PATH_SEPARATOR = @PATH_SEPARATOR@ PIXMAN_CFLAGS = @PIXMAN_CFLAGS@ PIXMAN_LIBS = @PIXMAN_LIBS@ PKG_CONFIG = @PKG_CONFIG@ PKG_CONFIG_LIBDIR = @PKG_CONFIG_LIBDIR@ PKG_CONFIG_PATH = @PKG_CONFIG_PATH@ RANLIB = @RANLIB@ SED = @SED@ SET_MAKE = @SET_MAKE@ SHELL = @SHELL@ STRIP = @STRIP@ TurboJpegIncDir = @TurboJpegIncDir@ TurboJpegLibDir = @TurboJpegLibDir@ VERSION = @VERSION@ XMKMF = @XMKMF@ X_CFLAGS = @X_CFLAGS@ X_EXTRA_LIBS = @X_EXTRA_LIBS@ X_LIBS = @X_LIBS@ X_PRE_LIBS = @X_PRE_LIBS@ abs_builddir = @abs_builddir@ abs_srcdir = @abs_srcdir@ abs_top_builddir = @abs_top_builddir@ abs_top_srcdir = @abs_top_srcdir@ ac_ct_AR = @ac_ct_AR@ ac_ct_CC = @ac_ct_CC@ ac_ct_DUMPBIN = @ac_ct_DUMPBIN@ am__include = @am__include@ am__leading_dot = @am__leading_dot@ am__quote = @am__quote@ am__tar = @am__tar@ am__untar = @am__untar@ bindir = @bindir@ build = @build@ build_alias = @build_alias@ build_cpu = @build_cpu@ build_os = @build_os@ build_vendor = @build_vendor@ builddir = @builddir@ datadir = @datadir@ datarootdir = @datarootdir@ docdir = @docdir@ dvidir = @dvidir@ exec_prefix = @exec_prefix@ host = @host@ host_alias = @host_alias@ host_cpu = @host_cpu@ host_os = @host_os@ host_vendor = @host_vendor@ htmldir = @htmldir@ includedir = @includedir@ infodir = @infodir@ install_sh = @install_sh@ libdir = @libdir@ libexecdir = @libexecdir@ localedir = @localedir@ localstatedir = @localstatedir@ mandir = @mandir@ mkdir_p = @mkdir_p@ moduledir = @moduledir@ oldincludedir = @oldincludedir@ pdfdir = @pdfdir@ pkgconfigdir = @pkgconfigdir@ prefix = @prefix@ program_transform_name = @program_transform_name@ psdir = @psdir@ sbindir = @sbindir@ sharedstatedir = @sharedstatedir@ socketdir = @socketdir@ srcdir = @srcdir@ subdirs = @subdirs@ sysconfdir = @sysconfdir@ systemdsystemunitdir = @systemdsystemunitdir@ target_alias = @target_alias@ top_build_prefix = @top_build_prefix@ top_builddir = @top_builddir@ top_srcdir = @top_srcdir@ module_LTLIBRARIES = \ libxrdpvr.la libxrdpvr_la_SOURCES = \ xrdpvr.c \ xrdpvr.h \ xrdpvr_internal.h all: all-am .SUFFIXES: .SUFFIXES: .c .lo .o .obj $(srcdir)/Makefile.in: $(srcdir)/Makefile.am $(am__configure_deps) @for dep in $?; do \ case '$(am__configure_deps)' in \ *$$dep*) \ ( cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh ) \ && { if test -f $@; then exit 0; else break; fi; }; \ exit 1;; \ esac; \ done; \ echo ' cd $(top_srcdir) && $(AUTOMAKE) --foreign xrdpvr/Makefile'; \ $(am__cd) $(top_srcdir) && \ $(AUTOMAKE) --foreign xrdpvr/Makefile Makefile: $(srcdir)/Makefile.in $(top_builddir)/config.status @case '$?' in \ *config.status*) \ cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh;; \ *) \ echo ' cd $(top_builddir) && $(SHELL) ./config.status $(subdir)/$@ $(am__depfiles_maybe)'; \ cd $(top_builddir) && $(SHELL) ./config.status $(subdir)/$@ $(am__depfiles_maybe);; \ esac; $(top_builddir)/config.status: $(top_srcdir)/configure $(CONFIG_STATUS_DEPENDENCIES) cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh $(top_srcdir)/configure: $(am__configure_deps) cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh $(ACLOCAL_M4): $(am__aclocal_m4_deps) cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh $(am__aclocal_m4_deps): install-moduleLTLIBRARIES: $(module_LTLIBRARIES) @$(NORMAL_INSTALL) @list='$(module_LTLIBRARIES)'; test -n "$(moduledir)" || list=; \ list2=; for p in $$list; do \ if test -f $$p; then \ list2="$$list2 $$p"; \ else :; fi; \ done; \ test -z "$$list2" || { \ echo " $(MKDIR_P) '$(DESTDIR)$(moduledir)'"; \ $(MKDIR_P) "$(DESTDIR)$(moduledir)" || exit 1; \ echo " $(LIBTOOL) $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=install $(INSTALL) $(INSTALL_STRIP_FLAG) $$list2 '$(DESTDIR)$(moduledir)'"; \ $(LIBTOOL) $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=install $(INSTALL) $(INSTALL_STRIP_FLAG) $$list2 "$(DESTDIR)$(moduledir)"; \ } uninstall-moduleLTLIBRARIES: @$(NORMAL_UNINSTALL) @list='$(module_LTLIBRARIES)'; test -n "$(moduledir)" || list=; \ for p in $$list; do \ $(am__strip_dir) \ echo " $(LIBTOOL) $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=uninstall rm -f '$(DESTDIR)$(moduledir)/$$f'"; \ $(LIBTOOL) $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=uninstall rm -f "$(DESTDIR)$(moduledir)/$$f"; \ done clean-moduleLTLIBRARIES: -test -z "$(module_LTLIBRARIES)" || rm -f $(module_LTLIBRARIES) @list='$(module_LTLIBRARIES)'; \ locs=`for p in $$list; do echo $$p; done | \ sed 's|^[^/]*$$|.|; s|/[^/]*$$||; s|$$|/so_locations|' | \ sort -u`; \ test -z "$$locs" || { \ echo rm -f $${locs}; \ rm -f $${locs}; \ } libxrdpvr.la: $(libxrdpvr_la_OBJECTS) $(libxrdpvr_la_DEPENDENCIES) $(EXTRA_libxrdpvr_la_DEPENDENCIES) $(AM_V_CCLD)$(LINK) -rpath $(moduledir) $(libxrdpvr_la_OBJECTS) $(libxrdpvr_la_LIBADD) $(LIBS) mostlyclean-compile: -rm -f *.$(OBJEXT) distclean-compile: -rm -f *.tab.c @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/xrdpvr.Plo@am__quote@ .c.o: @am__fastdepCC_TRUE@ $(AM_V_CC)$(COMPILE) -MT $@ -MD -MP -MF $(DEPDIR)/$*.Tpo -c -o $@ $< @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) $(DEPDIR)/$*.Tpo $(DEPDIR)/$*.Po @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='$<' object='$@' libtool=no @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(COMPILE) -c -o $@ $< .c.obj: @am__fastdepCC_TRUE@ $(AM_V_CC)$(COMPILE) -MT $@ -MD -MP -MF $(DEPDIR)/$*.Tpo -c -o $@ `$(CYGPATH_W) '$<'` @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) $(DEPDIR)/$*.Tpo $(DEPDIR)/$*.Po @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='$<' object='$@' libtool=no @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(COMPILE) -c -o $@ `$(CYGPATH_W) '$<'` .c.lo: @am__fastdepCC_TRUE@ $(AM_V_CC)$(LTCOMPILE) -MT $@ -MD -MP -MF $(DEPDIR)/$*.Tpo -c -o $@ $< @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) $(DEPDIR)/$*.Tpo $(DEPDIR)/$*.Plo @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='$<' object='$@' libtool=yes @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(LTCOMPILE) -c -o $@ $< mostlyclean-libtool: -rm -f *.lo clean-libtool: -rm -rf .libs _libs ID: $(am__tagged_files) $(am__define_uniq_tagged_files); mkid -fID $$unique tags: tags-am TAGS: tags tags-am: $(TAGS_DEPENDENCIES) $(am__tagged_files) set x; \ here=`pwd`; \ $(am__define_uniq_tagged_files); \ shift; \ if test -z "$(ETAGS_ARGS)$$*$$unique"; then :; else \ test -n "$$unique" || unique=$$empty_fix; \ if test $$# -gt 0; then \ $(ETAGS) $(ETAGSFLAGS) $(AM_ETAGSFLAGS) $(ETAGS_ARGS) \ "$$@" $$unique; \ else \ $(ETAGS) $(ETAGSFLAGS) $(AM_ETAGSFLAGS) $(ETAGS_ARGS) \ $$unique; \ fi; \ fi ctags: ctags-am CTAGS: ctags ctags-am: $(TAGS_DEPENDENCIES) $(am__tagged_files) $(am__define_uniq_tagged_files); \ test -z "$(CTAGS_ARGS)$$unique" \ || $(CTAGS) $(CTAGSFLAGS) $(AM_CTAGSFLAGS) $(CTAGS_ARGS) \ $$unique GTAGS: here=`$(am__cd) $(top_builddir) && pwd` \ && $(am__cd) $(top_srcdir) \ && gtags -i $(GTAGS_ARGS) "$$here" cscopelist: cscopelist-am cscopelist-am: $(am__tagged_files) list='$(am__tagged_files)'; \ case "$(srcdir)" in \ [\\/]* | ?:[\\/]*) sdir="$(srcdir)" ;; \ *) sdir=$(subdir)/$(srcdir) ;; \ esac; \ for i in $$list; do \ if test -f "$$i"; then \ echo "$(subdir)/$$i"; \ else \ echo "$$sdir/$$i"; \ fi; \ done >> $(top_builddir)/cscope.files distclean-tags: -rm -f TAGS ID GTAGS GRTAGS GSYMS GPATH tags distdir: $(DISTFILES) @srcdirstrip=`echo "$(srcdir)" | sed 's/[].[^$$\\*]/\\\\&/g'`; \ topsrcdirstrip=`echo "$(top_srcdir)" | sed 's/[].[^$$\\*]/\\\\&/g'`; \ list='$(DISTFILES)'; \ dist_files=`for file in $$list; do echo $$file; done | \ sed -e "s|^$$srcdirstrip/||;t" \ -e "s|^$$topsrcdirstrip/|$(top_builddir)/|;t"`; \ case $$dist_files in \ */*) $(MKDIR_P) `echo "$$dist_files" | \ sed '/\//!d;s|^|$(distdir)/|;s,/[^/]*$$,,' | \ sort -u` ;; \ esac; \ for file in $$dist_files; do \ if test -f $$file || test -d $$file; then d=.; else d=$(srcdir); fi; \ if test -d $$d/$$file; then \ dir=`echo "/$$file" | sed -e 's,/[^/]*$$,,'`; \ if test -d "$(distdir)/$$file"; then \ find "$(distdir)/$$file" -type d ! -perm -700 -exec chmod u+rwx {} \;; \ fi; \ if test -d $(srcdir)/$$file && test $$d != $(srcdir); then \ cp -fpR $(srcdir)/$$file "$(distdir)$$dir" || exit 1; \ find "$(distdir)/$$file" -type d ! -perm -700 -exec chmod u+rwx {} \;; \ fi; \ cp -fpR $$d/$$file "$(distdir)$$dir" || exit 1; \ else \ test -f "$(distdir)/$$file" \ || cp -p $$d/$$file "$(distdir)/$$file" \ || exit 1; \ fi; \ done check-am: all-am check: check-am all-am: Makefile $(LTLIBRARIES) installdirs: for dir in "$(DESTDIR)$(moduledir)"; do \ test -z "$$dir" || $(MKDIR_P) "$$dir"; \ done install: install-am install-exec: install-exec-am install-data: install-data-am uninstall: uninstall-am install-am: all-am @$(MAKE) $(AM_MAKEFLAGS) install-exec-am install-data-am installcheck: installcheck-am install-strip: if test -z '$(STRIP)'; then \ $(MAKE) $(AM_MAKEFLAGS) INSTALL_PROGRAM="$(INSTALL_STRIP_PROGRAM)" \ install_sh_PROGRAM="$(INSTALL_STRIP_PROGRAM)" INSTALL_STRIP_FLAG=-s \ install; \ else \ $(MAKE) $(AM_MAKEFLAGS) INSTALL_PROGRAM="$(INSTALL_STRIP_PROGRAM)" \ install_sh_PROGRAM="$(INSTALL_STRIP_PROGRAM)" INSTALL_STRIP_FLAG=-s \ "INSTALL_PROGRAM_ENV=STRIPPROG='$(STRIP)'" install; \ fi mostlyclean-generic: clean-generic: distclean-generic: -test -z "$(CONFIG_CLEAN_FILES)" || rm -f $(CONFIG_CLEAN_FILES) -test . = "$(srcdir)" || test -z "$(CONFIG_CLEAN_VPATH_FILES)" || rm -f $(CONFIG_CLEAN_VPATH_FILES) maintainer-clean-generic: @echo "This command is intended for maintainers to use" @echo "it deletes files that may require special tools to rebuild." clean: clean-am clean-am: clean-generic clean-libtool clean-moduleLTLIBRARIES \ mostlyclean-am distclean: distclean-am -rm -rf ./$(DEPDIR) -rm -f Makefile distclean-am: clean-am distclean-compile distclean-generic \ distclean-tags dvi: dvi-am dvi-am: html: html-am html-am: info: info-am info-am: install-data-am: install-moduleLTLIBRARIES install-dvi: install-dvi-am install-dvi-am: install-exec-am: install-html: install-html-am install-html-am: install-info: install-info-am install-info-am: install-man: install-pdf: install-pdf-am install-pdf-am: install-ps: install-ps-am install-ps-am: installcheck-am: maintainer-clean: maintainer-clean-am -rm -rf ./$(DEPDIR) -rm -f Makefile maintainer-clean-am: distclean-am maintainer-clean-generic mostlyclean: mostlyclean-am mostlyclean-am: mostlyclean-compile mostlyclean-generic \ mostlyclean-libtool pdf: pdf-am pdf-am: ps: ps-am ps-am: uninstall-am: uninstall-moduleLTLIBRARIES .MAKE: install-am install-strip .PHONY: CTAGS GTAGS TAGS all all-am check check-am clean clean-generic \ clean-libtool clean-moduleLTLIBRARIES cscopelist-am ctags \ ctags-am distclean distclean-compile distclean-generic \ distclean-libtool distclean-tags distdir dvi dvi-am html \ html-am info info-am install install-am install-data \ install-data-am install-dvi install-dvi-am install-exec \ install-exec-am install-html install-html-am install-info \ install-info-am install-man install-moduleLTLIBRARIES \ install-pdf install-pdf-am install-ps install-ps-am \ install-strip installcheck installcheck-am installdirs \ maintainer-clean maintainer-clean-generic mostlyclean \ mostlyclean-compile mostlyclean-generic mostlyclean-libtool \ pdf pdf-am ps ps-am tags tags-am uninstall uninstall-am \ uninstall-moduleLTLIBRARIES .PRECIOUS: Makefile # Tell versions [3.59,3.63) of GNU make to not export all variables. # Otherwise a system limit (for SysV at least) may be exceeded. .NOEXPORT: xrdp-0.9.5/xrdpvr/xrdpvr.c000644 001751 001751 00000066040 13206666623 015460 0ustar00metameta000000 000000 /** * xrdp: A Remote Desktop Protocol server. * * Copyright (C) Laxmikant Rashinkar 2012-2013 LK.Rashinkar@gmail.com * Copyright (C) Jay Sorg 2013 jay.sorg@gmail.com * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. * * a program that uses xrdpapi and ffmpeg to redirect media streams * to a FreeRDP client where it is decompressed and played locally * */ #if defined(HAVE_CONFIG_H) #include #endif #include "xrdpvr.h" #include "xrdpvr_internal.h" /* globals */ PLAYER_STATE_INFO g_psi; int g_video_index = -1; int g_audio_index = -1; /*****************************************************************************/ /* produce a hex dump */ void hexdump(char *p, int len) { unsigned char *line; int i; int thisline; int offset; line = (unsigned char *)p; offset = 0; while (offset < len) { printf("%04x ", offset); thisline = len - offset; if (thisline > 16) { thisline = 16; } for (i = 0; i < thisline; i++) { printf("%02x ", line[i]); } for (; i < 16; i++) { printf(" "); } for (i = 0; i < thisline; i++) { printf("%c", (line[i] >= 0x20 && line[i] < 0x7f) ? line[i] : '.'); } printf("\n"); offset += thisline; line += thisline; } } /** * initialize the media player * * @param channel opaque handle returned by WTSVirtualChannelOpenEx * @param stream_id unique identification number for this stream * @param filename media file to play * * @return 0 on success, -1 on error *****************************************************************************/ int xrdpvr_init_player(void *channel, int stream_id, char *filename) { printf("xrdpvr_init_player:\n"); if ((channel == NULL) || (stream_id <= 0) || (filename == NULL)) { return -1; } xrdpvr_send_init(channel); } /** * de-initialize the media player * * @param channel opaque handle returned by WTSVirtualChannelOpenEx * @param stream_id unique identification number for this stream * * @return 0 on success, -1 on error *****************************************************************************/ int xrdpvr_deinit_player(void *channel, int stream_id) { STREAM *s; char *cptr; int rv; int len; if ((channel == NULL) || (stream_id <= 0)) { return -1; } /* do local clean up */ if (g_psi.frame != 0) { av_free(g_psi.frame); g_psi.frame = 0; } if (g_psi.p_audio_codec_ctx != 0) { avcodec_close(g_psi.p_audio_codec_ctx); g_psi.p_audio_codec_ctx = 0; } if (g_psi.p_video_codec_ctx != 0) { avcodec_close(g_psi.p_video_codec_ctx); g_psi.p_video_codec_ctx = 0; } //avformat_close_input(&g_psi.p_format_ctx); if (g_psi.p_format_ctx != 0) { av_close_input_file(g_psi.p_format_ctx); g_psi.p_format_ctx = 0; } /* do remote cleanup */ stream_new(s, MAX_PDU_SIZE); stream_ins_u32_le(s, 0); /* number of bytes to follow */ stream_ins_u32_le(s, CMD_DEINIT_XRDPVR); stream_ins_u32_le(s, stream_id); /* insert number of bytes in stream */ len = stream_length(s) - 4; cptr = s->p; s->p = s->data; stream_ins_u32_le(s, len); s->p = cptr; /* write data to virtual channel */ rv = xrdpvr_write_to_client(channel, s); stream_free(s); return 0; } /** * play the media * * @param channel opaque handle returned by WTSVirtualChannelOpenEx * @param stream_id unique identification number for this stream * @param filename media file to play * * @return 0 on success, -1 on error *****************************************************************************/ int xrdpvr_play_media(void *channel, int stream_id, char *filename) { int i; printf("$$$$$$ xrdpvr_play_media: setting audioTimeout & " "videoTimeout to -1\n"); g_psi.videoTimeout = -1; g_psi.audioTimeout = -1; /* register all available fileformats and codecs */ av_register_all(); /* open media file - this will read just the header */ //if (avformat_open_input(&g_psi.p_format_ctx, filename, NULL, NULL)) if (av_open_input_file(&g_psi.p_format_ctx, filename, NULL, 0, NULL)) { printf("ERROR opening %s\n", filename); return -1; } /* now get the real stream info */ //if (avformat_find_stream_info(g_psi.p_format_ctx, NULL) < 0) if (av_find_stream_info(g_psi.p_format_ctx) < 0) { printf("ERROR reading stream info\n"); return -1; } #if 1 /* print media info to standard out */ av_dump_format(g_psi.p_format_ctx, 0, filename, 0); #endif printf("nb_streams %d\n", g_psi.p_format_ctx->nb_streams); g_audio_index = -1; g_video_index = -1; /* find first audio / video stream */ for (i = 0; i < g_psi.p_format_ctx->nb_streams; i++) { if (g_psi.p_format_ctx->streams[i]->codec->codec_type == CODEC_TYPE_VIDEO && g_psi.p_format_ctx->streams[i]->codec->codec_id == CODEC_ID_H264 && g_video_index < 0) { g_video_index = i; } if (g_psi.p_format_ctx->streams[i]->codec->codec_type == CODEC_TYPE_AUDIO && g_psi.p_format_ctx->streams[i]->codec->codec_id == CODEC_ID_AAC && g_audio_index < 0) { g_audio_index = i; } } if ((g_audio_index < 0) || (g_video_index < 0)) { /* close file and return with error */ printf("ERROR: no audio/video stream found in %s\n", filename); //avformat_close_input(&g_psi.p_format_ctx); av_close_input_file(g_psi.p_format_ctx); return -1; } g_psi.audio_stream_index = g_audio_index; g_psi.video_stream_index = g_video_index; /* get pointers to codex contexts for both streams */ g_psi.p_audio_codec_ctx = g_psi.p_format_ctx->streams[g_audio_index]->codec; g_psi.p_video_codec_ctx = g_psi.p_format_ctx->streams[g_video_index]->codec; /* find decoder for audio stream */ g_psi.p_audio_codec = avcodec_find_decoder(g_psi.p_audio_codec_ctx->codec_id); if (g_psi.p_audio_codec == NULL) { printf("ERROR: audio codec not supported\n"); } /* find decoder for video stream */ g_psi.p_video_codec = avcodec_find_decoder(g_psi.p_video_codec_ctx->codec_id); if (g_psi.p_video_codec == NULL) { printf("ERROR: video codec not supported\n"); } /* open decoder for audio stream */ //if (avcodec_open2(g_psi.p_audio_codec_ctx, g_psi.p_audio_codec, // NULL) < 0) if (avcodec_open(g_psi.p_audio_codec_ctx, g_psi.p_audio_codec) < 0) { printf("ERROR: could not open audio decoder\n"); return -1; } printf("%d\n", g_psi.p_audio_codec_ctx->extradata_size); hexdump(g_psi.p_audio_codec_ctx->extradata, g_psi.p_audio_codec_ctx->extradata_size); printf("%d %d %d %d\n", g_psi.p_audio_codec_ctx->sample_rate, g_psi.p_audio_codec_ctx->bit_rate, g_psi.p_audio_codec_ctx->channels, g_psi.p_audio_codec_ctx->block_align); /* open decoder for video stream */ //if (avcodec_open2(g_psi.p_video_codec_ctx, g_psi.p_video_codec, // NULL) < 0) if (avcodec_open(g_psi.p_video_codec_ctx, g_psi.p_video_codec) < 0) { printf("ERROR: could not open video decoder\n"); return -1; } g_psi.bsfc = av_bitstream_filter_init("h264_mp4toannexb"); printf("g_psi.bsfc %p\n", g_psi.bsfc); if (xrdpvr_set_video_format(channel, 101, 0, g_psi.p_video_codec_ctx->width, g_psi.p_video_codec_ctx->height)) { printf("xrdpvr_set_video_format() failed\n"); return -1; } printf("xrdpvr_play_media: calling xrdpvr_set_audio_format\n"); if (xrdpvr_set_audio_format(channel, 101, 0, g_psi.p_audio_codec_ctx->extradata, g_psi.p_audio_codec_ctx->extradata_size, g_psi.p_audio_codec_ctx->sample_rate, g_psi.p_audio_codec_ctx->bit_rate, g_psi.p_audio_codec_ctx->channels, g_psi.p_audio_codec_ctx->block_align)) { printf("xrdpvr_set_audio_format() failed\n"); return 1; } return 0; } static int firstAudioPkt = 1; static int firstVideoPkt = 1; /******************************************************************************/ int xrdpvr_get_frame(void **av_pkt_ret, int *is_video_frame, int *delay_in_us) { AVPacket *av_pkt; double dts; int error; AVBitStreamFilterContext *bsfc; AVPacket new_pkt; //printf("xrdpvr_get_frame:\n"); /* alloc an AVPacket */ if ((av_pkt = (AVPacket *) malloc(sizeof(AVPacket))) == NULL) return -1; /* read one frame into AVPacket */ if (av_read_frame(g_psi.p_format_ctx, av_pkt) < 0) { free(av_pkt); return -1; } if (av_pkt->stream_index == g_audio_index) { /* got an audio packet */ dts = av_pkt->dts; dts *= av_q2d(g_psi.p_format_ctx->streams[g_audio_index]->time_base); if (g_psi.audioTimeout < 0) { *delay_in_us = 1000 * 5; g_psi.audioTimeout = dts; } else { *delay_in_us = (int) ((dts - g_psi.audioTimeout) * 1000000); g_psi.audioTimeout = dts; } *is_video_frame = 0; if (firstAudioPkt) { firstAudioPkt = 0; } } else if (av_pkt->stream_index == g_video_index) { bsfc = g_psi.bsfc; while (bsfc != 0) { new_pkt = *av_pkt; error = av_bitstream_filter_filter(bsfc, g_psi.p_video_codec_ctx, 0, &new_pkt.data, &new_pkt.size, av_pkt->data, av_pkt->size, av_pkt->flags & PKT_FLAG_KEY); if (error > 0) { av_free_packet(av_pkt); new_pkt.destruct = av_destruct_packet; } else if (error < 0) { printf("bitstream filter error\n"); } *av_pkt = new_pkt; bsfc = bsfc->next; } dts = av_pkt->dts; dts *= av_q2d(g_psi.p_format_ctx->streams[g_video_index]->time_base); if (g_psi.videoTimeout < 0) { *delay_in_us = 1000 * 5; g_psi.videoTimeout = dts; } else { *delay_in_us = (int) ((dts - g_psi.videoTimeout) * 1000000); g_psi.videoTimeout = dts; } *is_video_frame = 1; if (firstVideoPkt) { firstVideoPkt = 0; } } *av_pkt_ret = av_pkt; return 0; } /******************************************************************************/ int send_audio_pkt(void *channel, int stream_id, void *pkt_p) { AVPacket *av_pkt = (AVPacket *) pkt_p; xrdpvr_send_audio_data(channel, stream_id, av_pkt->size, av_pkt->data); av_free_packet(av_pkt); free(av_pkt); } /******************************************************************************/ int send_video_pkt(void *channel, int stream_id, void *pkt_p) { AVPacket *av_pkt = (AVPacket *) pkt_p; xrdpvr_send_video_data(channel, stream_id, av_pkt->size, av_pkt->data); av_free_packet(av_pkt); free(av_pkt); } /******************************************************************************/ int xrdpvr_play_frame(void *channel, int stream_id, int *videoTimeout, int *audioTimeout) { AVPacket av_pkt; double dts; int delay_in_us; int error; AVBitStreamFilterContext *bsfc; AVPacket new_pkt; //printf("xrdpvr_play_frame:\n"); if (av_read_frame(g_psi.p_format_ctx, &av_pkt) < 0) { printf("xrdpvr_play_frame: av_read_frame failed\n"); return -1; } if (av_pkt.stream_index == g_audio_index) { xrdpvr_send_audio_data(channel, stream_id, av_pkt.size, av_pkt.data); dts = av_pkt.dts; dts *= av_q2d(g_psi.p_format_ctx->streams[g_audio_index]->time_base); *audioTimeout = (int) ((dts - g_psi.audioTimeout) * 1000000); *videoTimeout = -1; if (g_psi.audioTimeout > dts) { g_psi.audioTimeout = dts; delay_in_us = 1000 * 40; } else { delay_in_us = (int) ((dts - g_psi.audioTimeout) * 1000000); g_psi.audioTimeout = dts; } printf("audio delay: %d\n", delay_in_us); usleep(delay_in_us); //usleep(1000 * 1); } else if (av_pkt.stream_index == g_video_index) { bsfc = g_psi.bsfc; while (bsfc != 0) { new_pkt= av_pkt; error = av_bitstream_filter_filter(bsfc, g_psi.p_video_codec_ctx, 0, &new_pkt.data, &new_pkt.size, av_pkt.data, av_pkt.size, av_pkt.flags & PKT_FLAG_KEY); if (error > 0) { av_free_packet(&av_pkt); new_pkt.destruct = av_destruct_packet; } else if (error < 0) { printf("bitstream filter error\n"); } av_pkt = new_pkt; bsfc = bsfc->next; } xrdpvr_send_video_data(channel, stream_id, av_pkt.size, av_pkt.data); dts = av_pkt.dts; dts *= av_q2d(g_psi.p_format_ctx->streams[g_video_index]->time_base); *videoTimeout = (int) ((dts - g_psi.videoTimeout) * 1000000); *audioTimeout = -1; if (g_psi.videoTimeout > dts) { g_psi.videoTimeout = dts; delay_in_us = 1000 * 40; } else { delay_in_us = (int) ((dts - g_psi.videoTimeout) * 1000000); g_psi.videoTimeout = dts; } printf("video delay: %d\n", delay_in_us); usleep(delay_in_us); } av_free_packet(&av_pkt); return 0; } /******************************************************************************/ int xrdpvr_seek_media(int64_t pos, int backward) { int64_t seek_target; int seek_flag; printf("xrdpvr_seek_media() entered\n"); g_psi.audioTimeout = -1; g_psi.videoTimeout = -1; seek_flag = (backward) ? AVSEEK_FLAG_BACKWARD : 0; seek_target = av_rescale_q(pos * AV_TIME_BASE, AV_TIME_BASE_Q, g_psi.p_format_ctx->streams[g_video_index]->time_base); if (av_seek_frame(g_psi.p_format_ctx, g_video_index, seek_target, seek_flag) < 0) { printf("media seek error\n"); return -1; } printf("xrdpvr_seek_media: success\n"); return 0; } /******************************************************************************/ void xrdpvr_get_media_duration(int64_t *start_time, int64_t *duration) { *start_time = g_psi.p_format_ctx->start_time / AV_TIME_BASE; *duration = g_psi.p_format_ctx->duration / AV_TIME_BASE; } /******************************************************************************/ int xrdpvr_set_geometry(void *channel, int stream_id, int xpos, int ypos, int width, int height) { STREAM *s; char *cptr; int rv; int len; printf("xrdpvr_set_geometry: entered; x=%d y=%d\n", xpos, ypos); stream_new(s, MAX_PDU_SIZE); stream_ins_u32_le(s, 0); /* number of bytes to follow */ stream_ins_u32_le(s, CMD_SET_GEOMETRY); stream_ins_u32_le(s, stream_id); stream_ins_u32_le(s, xpos); stream_ins_u32_le(s, ypos); stream_ins_u32_le(s, width); stream_ins_u32_le(s, height); /* insert number of bytes in stream */ len = stream_length(s) - 4; cptr = s->p; s->p = s->data; stream_ins_u32_le(s, len); s->p = cptr; /* write data to virtual channel */ rv = xrdpvr_write_to_client(channel, s); stream_free(s); return rv; } /** * set video format * * @param channel opaque handle returned by WTSVirtualChannelOpenEx * @param stream_id unique identification number for this stream * * @return 0 on success, -1 on error *****************************************************************************/ int xrdpvr_set_video_format(void *channel, uint32_t stream_id, int format, int width, int height) { STREAM *s; char *cptr; int rv; int len; width = (width + 15) & ~15; stream_new(s, MAX_PDU_SIZE); stream_ins_u32_le(s, 0); /* number of bytes to follow */ stream_ins_u32_le(s, CMD_SET_VIDEO_FORMAT); stream_ins_u32_le(s, stream_id); stream_ins_u32_le(s, format); stream_ins_u32_le(s, width); stream_ins_u32_le(s, height); /* insert number of bytes in stream */ len = stream_length(s) - 4; cptr = s->p; s->p = s->data; stream_ins_u32_le(s, len); s->p = cptr; /* write data to virtual channel */ rv = xrdpvr_write_to_client(channel, s); stream_free(s); return rv; } /** * set audio format * * @param channel opaque handle returned by WTSVirtualChannelOpenEx * @param stream_id unique identification number for this stream * * @return 0 on success, -1 on error *****************************************************************************/ int xrdpvr_set_audio_format(void *channel, uint32_t stream_id, int format, char *extradata, int extradata_size, int sample_rate, int bit_rate, int channels, int block_align) { STREAM *s; char *cptr; int rv; int len; stream_new(s, MAX_PDU_SIZE); printf("extradata_size %d sample_rate %d bit_rate %d channels %d " "block_align %d\n", extradata_size, sample_rate, bit_rate, channels, block_align); stream_ins_u32_le(s, 0); /* number of bytes to follow */ stream_ins_u32_le(s, CMD_SET_AUDIO_FORMAT); stream_ins_u32_le(s, stream_id); stream_ins_u32_le(s, format); stream_ins_u32_le(s, extradata_size); memcpy(s->p, extradata, extradata_size); s->p += extradata_size; stream_ins_u32_le(s, sample_rate); stream_ins_u32_le(s, bit_rate); stream_ins_u32_le(s, channels); stream_ins_u32_le(s, block_align); /* insert number of bytes in stream */ len = stream_length(s) - 4; cptr = s->p; s->p = s->data; stream_ins_u32_le(s, len); s->p = cptr; /* write data to virtual channel */ rv = xrdpvr_write_to_client(channel, s); stream_free(s); return rv; } /** * send video data to client * * @param channel opaque handle returned by WTSVirtualChannelOpenEx * @param stream_id unique identification number for this stream * @param data_len number of bytes to send * @param data video data to send * * @return 0 on success, -1 on error *****************************************************************************/ int xrdpvr_send_video_data(void *channel, uint32_t stream_id, uint32_t data_len, uint8_t *data) { STREAM *s; char *cptr; int rv; int len; //printf("xrdpvr_send_video_data:\n"); stream_new(s, MAX_PDU_SIZE + data_len); stream_ins_u32_le(s, 0); /* number of bytes to follow */ stream_ins_u32_le(s, CMD_SEND_VIDEO_DATA); stream_ins_u32_le(s, stream_id); stream_ins_u32_le(s, data_len); stream_ins_byte_array(s, data, data_len); /* insert number of bytes in stream */ len = stream_length(s) - 4; cptr = s->p; s->p = s->data; stream_ins_u32_le(s, len); s->p = cptr; /* write data to virtual channel */ rv = xrdpvr_write_to_client(channel, s); stream_free(s); #ifdef DEBUG_FRAGMENTS printf("### sent %d + 4 bytes video data to client\n", len); #endif return rv; } /** * send audio data to client * * @param channel opaque handle returned by WTSVirtualChannelOpenEx * @param stream_id unique identification number for this stream * @param data_len number of bytes to send * @param data audio data to send * * @return 0 on success, -1 on error *****************************************************************************/ int xrdpvr_send_audio_data(void *channel, uint32_t stream_id, uint32_t data_len, uint8_t *data) { STREAM *s; char *cptr; int rv; int len; //printf("xrdpvr_send_audio_data:\n"); stream_new(s, MAX_PDU_SIZE + data_len); stream_ins_u32_le(s, 0); /* number of bytes to follow */ stream_ins_u32_le(s, CMD_SEND_AUDIO_DATA); stream_ins_u32_le(s, stream_id); stream_ins_u32_le(s, data_len); stream_ins_byte_array(s, data, data_len); /* insert number of bytes in stream */ len = stream_length(s) - 4; cptr = s->p; s->p = s->data; stream_ins_u32_le(s, len); s->p = cptr; /* write data to virtual channel */ rv = xrdpvr_write_to_client(channel, s); stream_free(s); return rv; } /** * send media meta-data to client * * @param channel opaque handle returned by WTSVirtualChannelOpenEx * @param filename media file * * @return 0 on success, -1 on error *****************************************************************************/ int xrdpvr_create_metadata_file(void *channel, char *filename) { STREAM *s; char *cptr; int rv; int len; int fd; if ((fd = open(filename , O_RDONLY)) < 0) { return -1; } stream_new(s, MAX_PDU_SIZE + 1048576); /* send CMD_CREATE_META_DATA_FILE */ stream_ins_u32_le(s, 4); /* number of bytes to follow */ stream_ins_u32_le(s, CMD_CREATE_META_DATA_FILE); if (xrdpvr_write_to_client(channel, s)) { close(fd); return -1; } /* read first 1MB of file and send to client */ s->p = s->data; stream_ins_u32_le(s, 0); /* number of bytes to follow */ stream_ins_u32_le(s, CMD_WRITE_META_DATA); stream_ins_u32_le(s, 0); /* number of bytes to follow */ if ((rv = read(fd, s->p, 1048576)) <= 0) { close(fd); return -1; } s->p += rv; /* insert number of bytes in stream */ len = stream_length(s) - 4; cptr = s->p; s->p = s->data; stream_ins_u32_le(s, len); /* number of bytes in this cmd */ s->p += 4; stream_ins_u32_le(s, rv); /* number of metadata bytes */ s->p = cptr; /* write data to virtual channel */ rv = xrdpvr_write_to_client(channel, s); /* send CMD_CLOSE_META_DATA_FILE */ s->p = s->data; stream_ins_u32_le(s, 4); /* number of bytes to follow */ stream_ins_u32_le(s, CMD_CLOSE_META_DATA_FILE); if (xrdpvr_write_to_client(channel, s)) { close(fd); return -1; } stream_free(s); return rv; } /** ******************************************************************************/ static int xrdpvr_read_from_client(void *channel, STREAM *s, int bytes, int timeout) { unsigned int bytes_read; int total_read; int ok; //printf("xrdpvr_read_from_client:\n"); total_read = 0; while (total_read < bytes) { //printf("xrdpvr_read_from_client: loop\n"); bytes_read = bytes - total_read; ok = WTSVirtualChannelRead(channel, timeout, s->p, bytes_read, &bytes_read); //printf("xrdpvr_read_from_client: loop ok %d\n", ok); if (ok) { //printf("xrdpvr_read_from_client: bytes_read %d\n", bytes_read); total_read += bytes_read; s->p += bytes_read; } } return 0; } /** * write data to a xrdpvr client * * @param channel opaque handle returned by WTSVirtualChannelOpenEx * @param s structure containing data to write * * @return 0 on success, -1 on failure ******************************************************************************/ static int xrdpvr_write_to_client(void *channel, STREAM *s) { int bytes_to_send; int bytes_written; int index = 0; int rv; if ((channel == NULL) || (s == NULL)) { return -1; } bytes_to_send = stream_length(s); while (1) { rv = WTSVirtualChannelWrite(channel, &s->data[index], bytes_to_send, &bytes_written); if (rv == 0) { return -1; } index += bytes_written; bytes_to_send -= bytes_written; if ((rv == 0) && (bytes_to_send == 0)) { return 0; } usleep(1000 * 3); } } /** * write set volume to a xrdpvr client * * @param channel opaque handle returned by WTSVirtualChannelOpenEx * @param volume volume 0x0000 to 0xffff * * @return 0 on success, -1 on failure ******************************************************************************/ int xrdpvr_set_volume(void *channel, int volume) { STREAM *s; char *cptr; int rv; int len; stream_new(s, MAX_BUFSIZE); stream_ins_u32_le(s, 0); /* number of bytes to follow */ stream_ins_u32_le(s, CMD_SET_VOLUME); stream_ins_u32_le(s, volume); /* insert number of bytes in stream */ len = stream_length(s) - 4; cptr = s->p; s->p = s->data; stream_ins_u32_le(s, len); s->p = cptr; /* write data to virtual channel */ rv = xrdpvr_write_to_client(channel, s); stream_free(s); return rv; } int xrdpvr_send_init(void *channel) { STREAM *s; char *cptr; int rv; int len; printf("xrdpvr_send_init:\n"); stream_new(s, MAX_BUFSIZE); stream_ins_u32_le(s, 0); /* number of bytes to follow */ stream_ins_u32_le(s, CMD_INIT_XRDPVR); /* insert number of bytes in stream */ len = stream_length(s) - 4; cptr = s->p; s->p = s->data; stream_ins_u32_le(s, len); s->p = cptr; /* write data to virtual channel */ rv = xrdpvr_write_to_client(channel, s); stream_free(s); return rv; } int xrdpvr_read_ack(void *channel, int *frame) { STREAM *s; stream_new(s, MAX_PDU_SIZE); xrdpvr_read_from_client(channel, s, 4, 1000); s->p = s->data; stream_ext_u32_le(s, *frame); stream_free(s); return 0; } xrdp-0.9.5/xrdpvr/Makefile.am000644 001751 001751 00000000156 13136030131 015774 0ustar00metameta000000 000000 module_LTLIBRARIES = \ libxrdpvr.la libxrdpvr_la_SOURCES = \ xrdpvr.c \ xrdpvr.h \ xrdpvr_internal.h xrdp-0.9.5/tcutils/utils.h000644 001751 001751 00000012262 13125122134 015417 0ustar00metameta000000 000000 #ifndef UTILS_H #define UTILS_H #include #include #include #include #include /* * stream definition and macros to access them; * all definitions default to little endian */ typedef struct stream { char* data; /* holds stream data */ char* pos; /* current read/write position */ int size; /* number of bytes in data */ } STREAM; #define qstream_new(_s, _size) \ do \ { \ (_s).data = (char *) malloc(_size); \ (_s).pos = (_s).data; \ (_s).size = (_size); \ } \ while (0) #define qstream_new_zero(_s, _size) \ do \ { \ (_s).data = (char *) calloc((_size), 1); \ (_s).pos = (_s).data; \ (_s).size = (_size); \ } \ while (0) #define qstream_free(_s) \ do \ { \ if ((_s)->data) \ free((_s)->data); \ } \ while (0) #define qstream_set_pos(_s, _p) \ do \ { \ (_s)->pos = (_s)->data + (_p); \ } \ while (0) #define qstream_inc_pos(_s, _v) \ do \ { \ (_s)->pos += (_v); \ } \ while (0) #define qstream_rd_u8(_s, _v) \ do \ { \ (_v) = *((unsigned char *) ((_s)->pos)); \ (_s)->pos++; \ } \ while (0) #define qstream_rd_u16(_s, _v) \ do \ { \ (_v) = (unsigned short) \ ( \ (*((unsigned char *) ((_s)->pos + 0)) << 0) | \ (*((unsigned char *) ((_s)->pos + 1)) << 8) \ ); \ (_s)->pos += 2; \ } while (0) #define qstream_rd_u32(_s, _v) \ do \ { \ (_v) = (unsigned int) \ ( \ (*((unsigned char *) ((_s)->pos + 0)) << 0) | \ (*((unsigned char *) ((_s)->pos + 1)) << 8) | \ (*((unsigned char *) ((_s)->pos + 2)) << 16) | \ (*((unsigned char *) ((_s)->pos + 3)) << 24) \ ); \ (_s)->pos += 4; \ } while (0) #define qstream_wr_u8(_s, _v) \ do \ { \ *((_s)->pos) = (unsigned char) (_v); \ (_s)->pos++; \ } while (0) #define qstream_wr_u16(_s, _v) \ do \ { \ *((_s)->pos) = (unsigned char) ((_v) >> 0); \ (_s)->pos++; \ *((_s)->pos) = (unsigned char) ((_v) >> 8); \ (_s)->pos++; \ } while (0) #define qstream_wr_u32(_s, _v) \ do \ { \ *((_s)->pos) = (unsigned char) ((_v) >> 0); \ (_s)->pos++; \ *((_s)->pos) = (unsigned char) ((_v) >> 8); \ (_s)->pos++; \ *((_s)->pos) = (unsigned char) ((_v) >> 16); \ (_s)->pos++; \ *((_s)->pos) = (unsigned char) ((_v) >> 24); \ (_s)->pos++; \ } while (0) /* list of commands we support; this list should match the one in */ /* NeutrinoRDP channels/tcutils/tcutils_main.h */ enum TCU_COMMANDS { TCU_CMD_GET_MOUNT_LIST = 1, TCU_CMD_UNMOUNT_DEVICE }; /* umount error codes */ enum TCU_UMOUNT_ERROR { UMOUNT_SUCCESS = 0, UMOUNT_BUSY, UMOUNT_NOT_MOUNTED, UMOUNT_OP_NOT_PERMITTED, UMOUNT_PERMISSION_DENIED, UMOUNT_UNKNOWN }; class Utils { public: Utils(); static int getMountList(void *wtsChannel, QList *itemList); static int unmountDevice(void *wtsChannel, QString device, QStatusBar *statusBar); }; #endif // UTILS_H xrdp-0.9.5/tcutils/mainwindow.h000644 001751 001751 00000002210 13125122134 016423 0ustar00metameta000000 000000 #ifndef MAINWINDOW_H #define MAINWINDOW_H #include #include #include #include #include #include #include #include #include #include #include #include //#include #include "utils.h" namespace Ui { class MainWindow; } class MainWindow : public QMainWindow { Q_OBJECT public: explicit MainWindow(QWidget *parent = 0); ~MainWindow(); private: Ui::MainWindow *ui; void *wtsChannel; QSystemTrayIcon *trayIcon; QMenu *trayMenu; bool okToQuit; QRect savedGeometry; QStatusBar *statusBar; QList itemList; void setupSystemTray(); int initWtsChannel(); int deinitWtsChannel(); void setStatusMsg(QString msg); void closeEvent(QCloseEvent * event); private slots: void onBtnRefreshClicked(); void onBtnUnmountClicked(); void onActionQuit(); void onActionLaunch(); void onSystemTrayClicked(QSystemTrayIcon::ActivationReason); }; #endif // MAINWINDOW_H xrdp-0.9.5/tcutils/tcutils.pro.user000644 001751 001751 00000065527 13125122134 017310 0ustar00metameta000000 000000 ProjectExplorer.Project.ActiveTarget 0 ProjectExplorer.Project.EditorSettings true false Cpp CppGlobal QmlJS QmlJSGlobal 2 System true 4 true 1 true 2 true 0 8 true 1 true true true true ProjectExplorer.Project.PluginSettings ProjectExplorer.Project.Target.0 Desktop Desktop Qt4ProjectManager.Target.DesktopTarget 0 0 0 ProjectExplorer.ToolChain.Gcc:/usr/bin/g++.x86-linux-generic-elf-32bit./usr/bin/gdb qmake QtProjectManager.QMakeBuildStep false true false Make Qt4ProjectManager.MakeStep false 2 Build ProjectExplorer.BuildSteps.Build Make Qt4ProjectManager.MakeStep true clean 1 Clean ProjectExplorer.BuildSteps.Clean 2 false Qt 4.8.1 in PATH (System) Release Qt4ProjectManager.Qt4BuildConfiguration 0 /home/lk/projects/jtech/nlabs_xrdp_tcutils/tcutils-build-desktop-Qt_4_8_1_in_PATH__System__Release 1 true ProjectExplorer.ToolChain.Gcc:/usr/bin/g++.x86-linux-generic-elf-32bit./usr/bin/gdb qmake QtProjectManager.QMakeBuildStep false true false Make Qt4ProjectManager.MakeStep false 2 Build ProjectExplorer.BuildSteps.Build Make Qt4ProjectManager.MakeStep true clean 1 Clean ProjectExplorer.BuildSteps.Clean 2 false Qt 4.8.1 in PATH (System) Debug Qt4ProjectManager.Qt4BuildConfiguration 2 /home/lk/projects/jtech/nlabs_xrdp_tcutils/tcutils-build-desktop-Qt_4_8_1_in_PATH__System__Debug 1 true ProjectExplorer.ToolChain.Gcc:/usr/bin/g++.x86-linux-generic-elf-32bit./usr/bin/gdb qmake QtProjectManager.QMakeBuildStep false true false Make Qt4ProjectManager.MakeStep false 2 Build ProjectExplorer.BuildSteps.Build Make Qt4ProjectManager.MakeStep true clean 1 Clean ProjectExplorer.BuildSteps.Clean 2 false Qt 4.8.1 (System) Release Qt4ProjectManager.Qt4BuildConfiguration 0 /home/lk/projects/jtech/nlabs_xrdp_tcutils/tcutils-build-desktop-Qt_4_8_1__System__Release 2 true ProjectExplorer.ToolChain.Gcc:/usr/bin/g++.x86-linux-generic-elf-32bit./usr/bin/gdb qmake QtProjectManager.QMakeBuildStep false true false Make Qt4ProjectManager.MakeStep false 2 Build ProjectExplorer.BuildSteps.Build Make Qt4ProjectManager.MakeStep true clean 1 Clean ProjectExplorer.BuildSteps.Clean 2 false Qt 4.8.1 (System) Debug Qt4ProjectManager.Qt4BuildConfiguration 2 /home/lk/projects/jtech/nlabs_xrdp_tcutils/tcutils-build-desktop-Qt_4_8_1__System__Debug 2 true 4 0 Deploy ProjectExplorer.BuildSteps.Deploy 1 No deployment ProjectExplorer.DefaultDeployConfiguration 1 true true false false false false false false false false true true 0.01 0.01 10 10 true true 25 25 true true valgrind valgrind 0 1 2 3 4 5 6 7 8 9 10 11 12 13 14 0 1 2 3 4 5 6 7 8 9 10 11 12 13 14 tcutils Qt4ProjectManager.Qt4RunConfiguration 2 tcutils.pro false false 3768 true false false 1 ProjectExplorer.Project.TargetCount 1 ProjectExplorer.Project.Updater.EnvironmentId {9a0d9632-2baf-44e0-864a-a12692180779} ProjectExplorer.Project.Updater.FileVersion 10 xrdp-0.9.5/tcutils/resources/000755 001751 001751 00000000000 13125122134 016115 5ustar00metameta000000 000000 xrdp-0.9.5/tcutils/README.txt000644 001751 001751 00000001216 13174271344 015615 0ustar00metameta000000 000000 A QT based utility program for thin clients using xrdp and NeutrinoRDP This program sends commands to NeutrinoRDP to do something useful on the client end (such as unmounting a USB drive, or powering down the client) Required packages to build tcutils: ----------------------------------- libqt4-gui qt4-dev-tools to build tcutils: ----------------- qmake make To run tcutils: --------------- include xrdpapi/.libs in your LD_LIBRARY_PATH Example: -------- export LD_LIBRARY_PATH=../xrdpapi/.libs run tcutils inside the xfreerdp session this is how we run xfreerdp: ---------------------------- ./xfreerdp --sec rdp --plugin tcutils 192.168.2.149 xrdp-0.9.5/tcutils/resources.qrc000644 001751 001751 00000000157 13125122134 016627 0ustar00metameta000000 000000 resources/images/tools.gif xrdp-0.9.5/tcutils/main.cpp000644 001751 001751 00000000266 13125122134 015537 0ustar00metameta000000 000000 #include #include "mainwindow.h" int main(int argc, char *argv[]) { QApplication a(argc, argv); MainWindow w; w.show(); return a.exec(); } xrdp-0.9.5/tcutils/mainwindow.ui000644 001751 001751 00000004551 13125122134 016623 0ustar00metameta000000 000000 MainWindow 0 0 541 355 TC Utils 0 0 511 291 0 Tab 1 10 10 321 221 350 60 141 27 Unmount device 350 10 141 27 Get device list Tab 2 0 0 541 25 TopToolBarArea false xrdp-0.9.5/tcutils/utils.cpp000644 001751 001751 00000012521 13206666623 015770 0ustar00metameta000000 000000 #include "utils.h" Utils::Utils() { } int Utils::getMountList(void *wtsChannel, QList *itemList) { QListWidgetItem *item; STREAM s; quint32 bytesToSend; quint32 bytesWritten; quint32 bytesRead; quint32 cmdLen; quint32 cmd; int rv; int i; int nentries; char buf[2048]; if (!wtsChannel) return -1; qstream_new(s, 1024 * 8); /* * command format: * 4 bytes cmd_len length of this command * 1 byte cmd TCU_CMD_GET_MOUNT_LIST */ /* setup command */ qstream_wr_u32(&s, 1); qstream_wr_u8(&s, TCU_CMD_GET_MOUNT_LIST); bytesToSend = 5; /* send command */ rv = WTSVirtualChannelWrite(wtsChannel, s.data, bytesToSend, &bytesWritten); if (rv == 0) { QMessageBox::information(NULL, "Get device list", "\nError sending " "command to client"); return -1; } qstream_set_pos(&s, 0); /* reuse stream */ /* get response */ /* * response format * 4 bytes cmd_len length of this command * 4 bytes cmd TCU_CMD_GET_MOUNT_LIST * 1 byte nentries number of entries in this pkt * n bytes entry_list nentries null terminated strings */ rv = WTSVirtualChannelRead(wtsChannel, 1000 * 5, s.data, 1024 * 8, &bytesRead); if (rv == 0 || bytesRead == 0) goto error; /* did we get the entire cmd? */ qstream_rd_u32(&s, cmdLen); if (cmdLen != bytesRead - 4) goto error; /* did we get the right response? */ qstream_rd_u32(&s, cmd); if (cmd != TCU_CMD_GET_MOUNT_LIST) goto error; qstream_rd_u8(&s, nentries); if (nentries == 0) goto done; for (i = 0; i < nentries; i++) { strcpy(buf, s.pos); qstream_inc_pos(&s, strlen(buf) + 1); item = new QListWidgetItem; item->setText(QString(buf)); itemList->append(item); } done: qstream_free(&s); return 0; error: qstream_free(&s); return -1; } int Utils::unmountDevice(void *wtsChannel, QString device, QStatusBar *statusBar) { STREAM s; quint32 bytesRead; quint32 cmdLen; quint32 cmd; quint32 bytesWritten; int bytesToSend; int rv; int seconds = 0; char status; char* buf; if (!wtsChannel) return -1; qstream_new(s, 1024); buf = device.toAscii().data(); /* * command format: * 4 bytes cmd_len length of this command * 4 bytes cmd TCU_CMD_UNMOUNT_DEVICE * n bytes device null terminated device name */ /* setup command */ bytesToSend = 4 + 4 + device.count() + 1; qstream_wr_u32(&s, bytesToSend - 4); qstream_wr_u32(&s, TCU_CMD_UNMOUNT_DEVICE); strcpy(s.pos, buf); /* send command */ rv = WTSVirtualChannelWrite(wtsChannel, s.data, bytesToSend, &bytesWritten); if (rv == 0) { QMessageBox::information(NULL, "Unmount device", "\nError sending " "command to client"); return -1; } qstream_set_pos(&s, 0); /* reuse stream */ /* get response */ /* * command format * 4 bytes cmd_len number of bytes in this pkt * 4 bytes cmd TCU_CMD_UNMOUNT_DEVICE * 1 byte status operation status code */ while (1) { rv = WTSVirtualChannelRead(wtsChannel, 1000 * 1, s.data, 1024, &bytesRead); if (rv == 0) goto error; if (bytesRead) break; statusBar->showMessage("Waiting for client to unmount device: " + QString::number(++seconds) + " seconds", 30000); } statusBar->showMessage(""); /* did we get the entire pkt? */ qstream_rd_u32(&s, cmdLen); if (cmdLen != bytesRead - 4) goto error; /* did we get the right response? */ qstream_rd_u32(&s, cmd); if (cmd != TCU_CMD_UNMOUNT_DEVICE) goto error; /* get status */ qstream_rd_u8(&s, status); switch(status) { case UMOUNT_SUCCESS: goto done; break; case UMOUNT_BUSY: QMessageBox::information(NULL, "Unmount error", "\nCannot unmount device " "because it is in use"); break; case UMOUNT_NOT_MOUNTED: QMessageBox::information(NULL, "Unmount error", "\nCannot unmount device " "because it is not mounted"); break; case UMOUNT_OP_NOT_PERMITTED: QMessageBox::information(NULL, "Unmount error", "\nOperation not " "permitted. The device may be in use"); break; case UMOUNT_PERMISSION_DENIED: QMessageBox::information(NULL, "Unmount error", "\nYou don't have " "permission to unmount this device"); break; case UMOUNT_UNKNOWN: QMessageBox::information(NULL, "Unmount error", "Cannot unmount " "device, an unknown error has occurred. The " "drive may be in use or you do not have " "permission to unmount it"); break; } goto error; done: qstream_free(&s); return 0; error: qstream_free(&s); return -1; } xrdp-0.9.5/tcutils/mainwindow.cpp000644 001751 001751 00000013601 13125122134 016764 0ustar00metameta000000 000000 #include "mainwindow.h" #include "ui_mainwindow.h" MainWindow::MainWindow(QWidget *parent) : QMainWindow(parent), ui(new Ui::MainWindow) { ui->setupUi(this); wtsChannel = NULL; okToQuit = false; savedGeometry = this->geometry(); /* setup tab to unmount drives */ ui->tabWidget->setTabText(0, "Unmount drives"); connect(ui->btnRefresh, SIGNAL(clicked()), this, SLOT(onBtnRefreshClicked())); connect(ui->btnUnmount, SIGNAL(clicked()), this, SLOT(onBtnUnmountClicked())); ui->tabWidget->setTabText(1, ""); if (initWtsChannel()) { okToQuit = true; QTimer::singleShot(10, qApp, SLOT(quit())); return; } setupSystemTray(); /* set up status bar to display messages */ statusBar = new QStatusBar; this->setStatusBar(statusBar); setStatusMsg("Connected to client"); } MainWindow::~MainWindow() { delete ui; } void MainWindow::setupSystemTray() { trayMenu = new QMenu(this); trayMenu->addAction("Launch Thinclient Utils", this, SLOT(onActionLaunch())); trayMenu->addSeparator(); trayMenu->addAction("Quit", this, SLOT(onActionQuit())); trayIcon = new QSystemTrayIcon; trayIcon->setContextMenu(trayMenu); trayIcon->setIcon(QIcon(":/images/resources/images/tools.gif")); trayIcon->show(); trayIcon->showMessage("TCutils", "Click on the tcutils icon to launch tcutils", QSystemTrayIcon::Information, 3000); connect(trayIcon, SIGNAL(activated(QSystemTrayIcon::ActivationReason)), this, SLOT(onSystemTrayClicked(QSystemTrayIcon::ActivationReason))); } /** * *****************************************************************************/ int MainWindow::initWtsChannel() { /* init the channel just once */ if (wtsChannel) return 0; /* open a WTS channel and connect to remote client */ wtsChannel = WTSVirtualChannelOpenEx(WTS_CURRENT_SESSION, "tcutils", 0); if (wtsChannel == NULL) { QMessageBox::information(this, "Open virtual channel", "Error " "connecting to remote client. This program " "can only be used when connected via " "NeutrinoRDP.\n\nClick ok to close this " "application"); return -1; } return 0; } /** * *****************************************************************************/ int MainWindow::deinitWtsChannel() { if (!wtsChannel) return -1; WTSVirtualChannelClose(wtsChannel); return 0; } /** * Display a msg on the status bar * * @param msg message to display in status bar *****************************************************************************/ void MainWindow::setStatusMsg(QString msg) { statusBar->showMessage(msg, 30000); } /** * *****************************************************************************/ void MainWindow::closeEvent(QCloseEvent *event) { if (!okToQuit) { savedGeometry = this->geometry(); this->hide(); event->ignore(); return; } if (wtsChannel) deinitWtsChannel(); event->accept(); } /****************************************************************************** ** ** ** slots go here ** ** ** ******************************************************************************/ #if 1 void MainWindow::onBtnRefreshClicked() { int i; /* clear drive list */ if (itemList.count()) { for (i = 0; i < itemList.count(); i++) ui->listWidget->removeItemWidget(itemList.at(i)); itemList.clear(); } ui->listWidget->clear(); if (Utils::getMountList(wtsChannel, &itemList)) { QMessageBox::information(this, "Get device list", "\nError getting " "device list from client"); return; } if (itemList.count() == 0) { QMessageBox::information(this, "Get device list", "\nNo devices found!"); return; } /* add mount point to list widget */ for (i = 0; i < itemList.count(); i++) ui->listWidget->insertItem(i, itemList.at(i)); } #else void MainWindow::onBtnRefreshClicked() { QListWidgetItem *item; int i; int j; /* clear drive list */ if (itemList.count()) { for (i = 0; i < itemList.count(); i++) ui->listWidget->removeItemWidget(itemList.at(i)); itemList.clear(); } ui->listWidget->clear(); QDir dir(QDir::homePath() + "/xrdp_client"); QStringList sl = dir.entryList(); for (i = 0, j = 0; i < sl.count(); i++) { /* skip files starting with . */ if (sl.at(i).startsWith(".")) continue; /* add mount point to list widget */ item = new QListWidgetItem; item->setText(sl.at(i)); ui->listWidget->insertItem(j++, item); itemList.append(item); } } #endif void MainWindow::onBtnUnmountClicked() { QListWidgetItem *item = ui->listWidget->currentItem(); if (!item) { QMessageBox::information(this, "Unmount device", "\nNo device selected. " "You must select a device to unmount"); return; } if (Utils::unmountDevice(wtsChannel, item->text(), statusBar) == 0) { delete ui->listWidget->takeItem(itemList.indexOf(item)); itemList.removeOne(item); } } void MainWindow::onActionQuit() { okToQuit = true; this->close(); } void MainWindow::onActionLaunch() { this->show(); this->setGeometry(savedGeometry); } void MainWindow::onSystemTrayClicked(QSystemTrayIcon::ActivationReason) { trayMenu->popup(QCursor::pos()); } xrdp-0.9.5/tcutils/resources/images/000755 001751 001751 00000000000 13125122134 017362 5ustar00metameta000000 000000 xrdp-0.9.5/tcutils/resources/images/tools.gif000644 001751 001751 00000042545 13125122134 021223 0ustar00metameta000000 000000 GIF89a«·çÿ"&š*•$).’2q#3d7l4–"1–7e%;Z(5“8š,8p9•$:‡=Ÿ>™*@e$?A}!Bn%=™)@p,>{Aœ$Bx F™F )@—CžD™+@žE“$DŒ!C¦I„#E¡I£)C«*Hw"IŠK™&G0E•+IKŸJ¬=Go(H¤1HŠ(IŸ.J‡N•L§)J˜'NyM¡*J PQ«%O„7J‚,Os,J§R¥SŸ!N£ O*M•*N"O¤3N}-Mœ)PŒ2O†#QŸ%P¥0L±Vœ0N¤U¨0OŸ&P³&R¡TµV£(Q­U¯&T› [­%U–1Q›(S¢)S¨)T£8SƒW«4S–*U¤1U‘Y¦Z ,U«`°2c¸@c@bšHbƒFc‰Da¥Ib’Pa”@f°7i²Scž:j¹Pm…RnXq™Xs”Tr«^q¦e|•a{¬c}¥kz­d¡`€¿h}Ôx†»o‰¹qгs‹®u¨‚Á‚•Å|™¸|™Äx™Ù|™Îˆ˜ºŒ§¸Ž¤ÒŽ¦Çœ¥É–²äš³Ï¤±Ð”µÚŸ´Û¥³à¤´ð¥¿ó°ÁÔ±¿ë·¾í«Ãë­Äá¹ÇÔ¶Íö»ÐðÀÎý¸×íÍÓëÃÖð¿ØÿÅÞýÍÜþ·ãÿÔäþÝåëÑëÿÝêÿñíäËöþðìÿäðþÝóÿëïÿñï÷æóôðòïíôééõïøñðñõäïô÷íõþçøÿÿñþõõÿâûÿûôÿßýúÛþÿùøîðùÿù÷ûÿ÷ðîûü÷ùöÿöýíýðþøöõúýÿúêìÿøêÿþúþæôþùùþíýûÿ÷þóñÿÿÿüúùþÿüþûÿþõÿýÿþÿüÿÿÿ!þCreated with GIMP!ù ÿ,«·þ»xè%H—.c¾(\Ȱᘇ#JœH±¢Eˆ 3jÜȱ!“ CŠdB¤¤É’9RªtÁÒÅŒ3^®à@³¦M2èÔé€ÀA¾LØ‘áÅ£H“^,Ê”ãȧ Ož2De–)cja³+Mœ;KX€@0JЃM*]ËöhÚ· ¡B•j’jÕ”Xs蘡cï &¼Þk„‡²Ѿm˸ñC¸på>¥[òˆ]«)ûjþ XpMœ €ÈPö‹.Yà:^MQë×®!¿•<’2‘#–©bÖ¬pgÏp&=0Šé,©³^þ6lÙii‹´;÷nÞ:|.¼‡3g¼þ<´’ÅÊFæèÓKjëºgëî£rX¬Á–áŸk´«T²Ë6Û´ÈI Ô^ÛDnCÜpCK-yË­`ã’+±rTl±Åp¬¡ñÆsL¯pÈk…½XÙ”²œþ -HT•$RŒ”ÄÌ 3Ì’Ã3yñÄ®ñŠè…w,4Ç!«±èÑ-"›–²Ìúû¯H¹ôrÌS'q^ ; ñr<ãëExà*/°ÃAq³¦öÚiËáÈp [ü¦Œdu-KeõþÞR­t³Ö:sÝu_ƒ'žc lÆÀ:Úîãa@9­=6´s+VvÈÄÁ¸Ù0ÄR”núÌIHú 9$á·LÝnÍZ×ëzìío«!¬î¼ë{ï‘Sîöxc‡¬9ta ~â6¢n9,è:^ÛÆøì´Ãv±Å” ëý÷Þ¿ëvÉ”î BË6±<ó~^Ñ$óC¼ï§ :LUõ_ŸTö¬Â!°V !èP7¸a]qà¯èÀÀX‹J—» ÁÀ+•!^ËÙˆÎyÁZ9‚lp…*\á„6 IRh‚2]!R`Ié¸U=ÙíÎ)Þ ˆn0þn(l„+°a•ˆ,¦Ä/ÉÁ{ „ ä …*vP_&kÈ»ÐA‚„'Gƒ6€Â÷}mBPÈ€®‡Ô+.øÀj¨?¤à0‡‚HÃÌÐÃ(vŒgØ® /졈ÜØHDBYИô@/8aè EÇhÐ< é ¼³„€rpAH).p¡¯¼7à‚=¬€–xY_ò×¶Ü6e„öøª,Ô ‹#Iàà1È@Äà‡jŠÁФ€zP‡:Ì [ØBÆ@-„! ÜRF.Äž!u|DÜŽ™#¤`þ ô‰ LÀYà‚ꮢÊh…—6ñå/]S!”eÈ‚&¹†@b -hÁ"¡ TÔbÏ Æ7¨!yˆƒÏHÆ0†±ŠSd"H@7•°DÀ¡D ƒ%J–Å…X)”‘j# K¸ "¡Š^(ƒø˜Æ3˜‘ L\€-Ý\Є]欗kY¨käàG•azXÃ6Q€„G˜âÉø>ôAW|Øõxµë]åj×o$CŸ`Dz@†5Èó L`ŽF¥ ¨AE¨¨H†LÔ‚võÆ;ôŽwTãv&Dð)"Ž/¡#X•"V5Ô {Pþ!ˆºL°"òЫ>ºtØã·½ý­pýAÜslVv5©0\ш¢b<íé~º90s $è+œa×sxƒ·îo>ô×sàC¢cé60%Õ&4¬¬ÚŶ÷9ìAì~¤#ÄUÇ5¾!Vˆ Iø€®œå¬"´û½.è¨F‚¼ h`‡ULCç®=ôázÐ#ÀxU2;¦üÛu¬ƒ®uÕ«I©Qr”Ä5œèö¡0¸!%„Aþ#T@Õ³èÀ=Èû[v8æà?è¡ËÃ>¸âp€Á.P˜ÂVPqµ¦k­zõw‚¨"D@Vp÷Øà‡;Ðag{øãô±? Le{ #í+3z Sd‘øÃ± Q‚k󥎧 ‚1 DЃòP‹¹†Ãvv2í1åm¸CÏMî+>ÒBà/hR¢ýFãÒ’.­ A" ÕЀ+pûk”î v©‰ëjßúÃĽ2rñA \˜âû¤hð†fú! Eâ))bÉ Õ Ã à@F C®ïð­þK¼:³׿Ç:°Ñs¨C¤òp…öP‚)4i,!·¹ͳ_ÅÊÌ=¶Â Ä0‡üA%µ+=²q+ù鿸?ð`jã`P‚Ä .LœëØ•·Ùâ_Crà†/A ‘@ÕÏÁd cØÎwÔ·A\`YòpF)Þð/DÀ}:hÉ ¸UnGO${?7³ÃÀJ¡`0f©®'ßãÚÐÔŸŽäš´@ÁATL‰aáxPˆE¸ÁìÃ6_CÂ`6œFxÃ/ðñ º¯ØX‡žÓ¡÷‘ûãÆ}Ç3‘‰P cXÁ">þ’š1ºÑ;|Ž+&y-s =h.æºYÏ×£¨ýÓÙáŽmlcÉø`Æ-pЃ9¬¡*pi·g@XV=&yhƒ(d¶{<@Jb@÷Y®¶ VF\Ë×|›õö  @FD0S‚l&á+ ~çÖ5e‡ ˜ øP ¢§|üðy¨æwò§d'¶dÏ€ ž0ƒA¾R°bfÀ@‚Ð@®ÂGRÃrvºÇµ’Lð 0WÖ``RWzV`y5 T ‘P ±¤PA DPD°0%0#À‚<71ê†6£„ØU ÜuèàéÀþægüÐds†eÂ%uúð ¦°EpFÄŽB¯’G¯²C¯’‡ 1;i U˜{I ŠT-@ 8†áµÄEþPryu^â€zÐ~À,pnp.àDP5@‡3p‡y~‘ca` ¦AO$À ˜¥Y)Ç|RçƒMÖwûàë`W¼- aU°Ž˜ˆk`kñHŠô˜spÁF;ç¦)cà_`´€Þ€rpNFû0pò@ «ðü§5 eÂe’A ȈSˈ‡z(~=';@=àiòà ÞPb‡X`¿…eN– Mfþeú ²€8ЂP+lP¶â+ó…¯ò*CC/úøhüHpPPÕ †ÈáňôÐ Þ€ÉÀ mP= [-<n6@‘Mb‘LjŒD°‘ÍèxÏiVÀp€dÐؘYLvb¢öttE<ød‘È s ‡°5 @æä(Ã3_•'ŒbÙ³+ò\`¬@uÊwbî`gI‹úð SJÏò9Wà•ó“sH–.ÀŒ™–]C[0Œ ˜5 ç0`ØÀPG\Ùàd}u ) ”@ 5ðÀ,®Å+àá.Ɖ{ØD‘~ Ì[÷Pu¹oŸG×€—þ€$àÑAAÐ<à><?e¢70‡txšéŒ‘cmyy™ ø@wûà+pü¦d³8gfø `ð@„LÄ9ÇI+º<Ž“€]Ü ‘4€ ©ÓY¿Ub÷ÀØà À€bp{À$Š-–13zQ&3žE°0&P/šï i‚°uÐÎð úPˆæ€g§ô°ˆJ&ŽÙ¦¿!(þAîf9ß3_c˜/E)~š’€ ¹EðgÍ÷[üPÜàw߀ ~°$tWà@À~ ep,°eÔg°!P«º_±’²º8V 0` ú€ƒú ‹%&j,™`Ó¦¡S' `ñ”ð+{AO>v˲<“.“r(ŽâL0k°Œð ÇE¨VötùàðPÉêâ@9`/p@ðbDðR:À6€‰M°0ó,ÐUpµå",2öòPj™@^t§Ø`ÿÖ|hûºƒ©ö¡¬÷+Qè*)ë;w;¼´£·<åZç$/z‘y¡ˆ¸£G¤Š Ø ¬þ ^ð#ppc@0^€<ÀDðJ®$mÔh ‹ºõÒ@ÔºÀ Þ `øÙw_z»¹ËÚ@p(€#¿*K…Ã{ÀÅë(Ïè(A@¿6 úÀ¸cXgJ–¸S÷zfï =`‰26BaàgBQ[`þô€Ы kÀß#¿„ ;@ °†¿³[»ü郸kjyFS‰ Jt»=';·Ì©-›N®e‚ V˜ð °¨dÁU‹æ ÿ‹¡vrøp "9°ú F€g0H)Q›  ~ç+ò’ Eð ›Õ cK¶þ<üˆ>ˆe%fχ¿ k`ï’€¾[/KŒ·|˜(‘8nàÔØ- ø0¥6e½p‰\â úpìðß.DЪßq°lÉa ¿PR¢ rðtœCF£;Gœ. ô„Ð:º[ø È_š¡XVw*çw‡ dü­*ÉòÕs”$f6t°uðP5àPjè°Ÿ×í WÏ  ¥ð Ïð…Û€ øP "ðLpBà.€”k ð À~F Àðˈ9V£Aƒ E›€ïàÇþ0»d;zKFȵˆŸ¤, (àgÓ.˜ø(‘Fþ²Ú,Éã;X‚>Ž2[ Ÿ öàÐ’NÖñÐWà  ð ö` áÊÐ;9°H7ð˜m\ 6hÑáP ù×Y°xî)Šy61ÝÀ„ þƒÌwŸ€ÌÑϬŸÛWßð JPlwÒhã*ïhÇKœcD@A~Ð` se÷G^3 aV ˜@ƒbKª„íjß ™*|€o rWŸÀe ‘¸b‹(¸§6™$@DÐC)ðÍpŸ}WÏ uiÝw÷çrTÙ‰ 5 Š‹pÒÖ·xÀ¶×ý8CPŽ Ï@WÙ°gúþ`%%°p yðp£Ð =€³Ùì Å` J o Ê`WÕö`b•i¿HzQ¦]_Åb LI…Á|ÉG\°Öu§¿¿¥çõ -P‰àÊ–Ððb×;¶Òzm/A9¸0 sµïG~F ²ðh€€ó¶‘€vðlÔ¶ò  é×±0 b¾eb€jáà >¢÷ßjÐ.ðA³Jðv0 ÈûIÛ}7`Jö€'¿°TdŠpF>ܯRÜÄ{ÜN4dÌðë`óÀ võ ©ð>ð€°€Y#E“þp¶ ã`WV ̆YÕ`ãð…‚ž¬AX Ì \°x/JäFN˜t ˆ°PY*zO9å ¾Ÿåv6pr  Ûpðði®Í9Ö&f>E ¬ çrv5  " ’P ô™[È5Rv€v€ðíÿKR7øtm®ˆî°Yª*h€ßpâ6•ŽÒY°sT© ìöÇwê¢êú–¡sfÐø ðF@éòDv-æwë-2X EðÌ eëÞ0 ’ €0 º[rF¨Q‰«P(Ð ;*Ž©Æ§Ô†`º›ÈÅ EÐW“ží /] þ)-€ P¥±®fjSŽm-Ùd‹øo­¦Îí`r5 fC˜:fïv‹ïX¢ïÍ’­ ßPbð°ÆE €º`·¡¢–¸øà 8à’à ð½ ð§Ì”IàÚ0g6­40 òØî/ˆ6òž`•°©œuá%rÝwò7êNç[÷©»tÅb¿ Úc +Ö¥1•TÀÌÄÚC1Y[²UH8‘@Ÿï€wð° öË >€•ð_LÖ£¢Æwçe út 9´xé |iÐ6 ½j(fF¾n@@H£ÿÕY¢gÖä^Ô®ÖYЗ öÌ`h„ºˆHþ†½€ù q5ŠãJ®Á{AYùŽã6dó޵RQÐE·§â>†ö‹®@€ 8èÖ^™yõ`¡ ðñÐ=Xá…gÁž|Ìl¡ uJ–­a~]z‹­/§?t‹÷å\ß. bø0Q!¨T¨K•R·ªFêö2åxþ^F©8aØä ‚hNPâ\¾óçÖ<~ú¨É …£Â°˜çôu‹íyp©„ @ÈÅ%ÄøÉ‹v¶ñ›ž\Â%’ŠÂ„^Ðì!δ“J#Ád­•LÚg›mö1é¿™Þ¡ðÀZhÁŽLlyF|fn1!í F|~¹ nØ# ªªÂŽ:î¸ëì;ª@”#Š0èÈb‡:Y‹­“F‚§ž{|,F4V‘Ç|äñQ^¹þÀX…™ØÞŠËA"±™éœizñ¡9.páŒLØìCñ¶Ø¢0œñK{prgÇ’Óç™7M‰d‰:!c =áÂ7ÀÈC—Vz'%?íAœèÁÇG^* ƒ+®ØÊJ+¹ÃŽ+ˆ¦ü.+e $‹5ê@šoÔ‰í&{ö©§npŧ4$p†qÉ hôeXÒOz´ÑÇu¦!e‚;Y¸!„DPa†F9³b % ýŽØkŒV‘¥íMVzPbS)£‹&†Ã%4Èccµg‘…éžwñ)1bˆã e_vR;ê¬Äí<3 å€ÃˆUŸþùæEÆpÚ‡ŸzÞJîq¥œehyDG~@Âfðñ¦i†\ìÍû~©D„tƒ¤(B„"\øW"8”ˆ¤Uð™f¦øÞë-ú— ÈÐŽ.‚ÐòŒ3¼‚ˆAYU–«-Eg{$7îžlïÑa0ä—aV–*ì&âjÊ2²b#Ž*Ø #…FÀ@æGKsrç8š†³'}A¡ŽV”h ЀÅ=j-µ‡xæ9zo| rÆ”d`a@ )¸¨aí¶#‚#04 óöÉÇâRZ'¸Þ9çÞ@Dp7 )„B²rƒ*+jH„bñ±¢í$%è‰ÑþêAõBRƒ<ã26¼L‘@½í­a?Ò;qpb1A=Ìô‘Æ(ðñxS1X!F%¡E¸t`ÌÀ–¶\Á÷ üÂ7Ú \†þä–t¸CwÊ@A#à€9) ‡‹Ìs†$sÇ岵¦Ä÷؉Õ‚D! rPÄò—ž5e 4sRxä +ƒè‚Œ€‰cäêŒyK%gâ’Ý-%ÌxÅ/ÞSœá ‡E £/4ñD(ÂE‰pƒ¸@3°A J ]vÅnšù4Ìt¤C/ñ„à€³ÏÁ! s‹tÆ7a 8€…KDYœp'49’ꈨ@M¤;—i%e1Áƒ¡L0£RÂñ4š ¹D'zÓ‡Þ¡»”ŒC%@¢:¡ŠF´ m˜Cl þƒ$£¯Üè €ƒŒ CRÃüði©œof|¶Žp¼©[€gVvyÓ4”A æ¡HÈІ ¢ø =pÇEätÃ%¿¨À”P9ásí|ŠUÔÈN"„ORŸ¸ÚlVrœ€¾H©'<”Kl'' G5høaÄB2˜ ‚0Á/°üZ„îv°…-AIÕp]È×ȆÑ£oƇá8‡8hAAL…]ÁÎT<£.í =À+Ü+Ú-f}dõ 0b›ˆ,t!t\ƒS¬’³3ä€Fa(üâœØÊ& µdNŠ[\sì„a¿aÆ.H‘þLà•E°˜ lЇ ÁCoF;j pè°ƒÄ ÷À‘¨ ªoqú‹ BZfć,$Y Ç Ñ±…5ˆÁ® Æ‹Tk’-zs'|caŒ0œ‰ÎN9]êâPˆ.$â§øË;ŽãœŒi8@ÊG%ÚÒt¬ƒ6òHF,<ñìrT nP„¢"ÐA¼ÀÇ6È“ÀQx”Q§Ž¢DÆpü¡øhbúDßœ¼ÃS²@(a7ôZ âYCî0”3¨¡)ixæè‚±`†Ý²%Lã¼…6kù…1CBå+`Ésâ°>ðU#q?Ö þ¨–¬@ZMJ€´½x£Œ¨ R#lá eĆú&ÊAP/¾ò5.è(«/àvàE®f2̾ȃ(œáëªø W˜Â¼Ð•o‹™^0Äî@€Xø…–3 ÉNò#¿ü¢Fƒá¶‡o'% ª›B¤0ZÈÃæ÷h1InÕîÔ'UÉ«t‡P$hLàà ²ào+ á»N¶'‚$ä  §¥,uPjˆ»ŠcÀ{•ä1Ю2 Kè(oy´Âœ5È!è(YA .]€ýËÎ (µ+=à@ýa޽½ €t7Ôþ ‡8D¼Ð'8áqA.ÜëX£˜ê©U´òÄꘆ±xC ¸À‡/È ÇïÂñ™p„#4ùGÂE“0„!¸=rŸû-í¾‚”ïôŽìɇ,ˆá ¦Óº‘’s´4Š·¬`:ú×;M°„X!á4†¾è€ Ÿ EŠB „8„°‚=@¹¸ƒ È߈5“QŒ½Q1Äx¬×( ÉyØ…9ƒ"ƒ=8‚ðj‚.PAåcÁ¤¾¬¾‡³»À¾îó¾¼ ¿1P„PI ƒ0…6ù‹©†WH{"+ˆ?ûcBÓi–|P‰-š7ç²þ¤åh>¸(AÈJ3Ј$uX³õ!ÛCClh1ˆÉ‚eº(‚\Á´C¤>·+5[ªÁîû¾* ‚^“:xxr(ŒÂ8… B "ˆ?:hÂI„ƒ1Û2hUø–@•ž ¡#I’,`7hHFh4(y Ôš/ZCCÜ)ª·R‡gÈX‚¤°‚/ƒ=h‚ Ãä³CÄC=œÁ>¼Að“ 9X„@\„# =˜ƒ6È„[Hdˆ„„,?H,%œÄ&4ƒ4Ø‚@ÐÄÁ9Y9 [ÙzÀ#|Ø•@˜„+xCh‚A¨Æe(Dþ|¯âp /®1Ƚ‰Œd@‚h„5(¯.ðçFb,FåÃÃÜC”;üÃð[/à3(70‹9¨ƒ¨ƒ9(§¯“Š%\Âq´?3X@8 9(‚ Ô§|`·ª#“É^P èƒX„.x$4@…b(yø'v ÈÆP ƒ\ ²šj@‚FHt¬§å µ1`¤ÈŠd‚‹DF>ÜH?ÄÁfTû9iê3@¸¬ÈKØ€AD$q”D˜¬?¥ "pƒ=¸?hYp“þÓ‹‚$Ä0“ÌùΉÖ»9Ø‚C舄]ø†sØåy©äK²]Ѐþ%H1xÃ.¸¨`‘‚Ë:4˳¼SBx2œ0è ëÈ36РçlBϨ ªXŠ5h`… A ±¢7CŒ!Ô#¸"#à)€ 0„4…‚h‡Ôr7¬S ù^¨.È‚,èE¼û‚/‚þ P²¬Íã{Aë£;X˜&å>MþÐ1€ŠÄòÃQN똈¡Ðq<º8вr\Š,@P…‚R ȇzL˜Aù„Xø\(…FƒØ8.¨ƒ(#P‚%ðÇ:¨2¨0/¸,ˆIý¨ ÒÁÒ&Pâç£>&¶þ\kÍØ%ÕØmMP îȉaÓ¥Ðâ-^ŠCPRÀšª(°šEäȉip… €E„5…'à²^ ĉV ¶b 6R%v>ækb?Æ`ë‹b)v*îàEmKÄÊâ)ñâ³UŠ'Ø?0Ów¨")c3¶½kg … @`Í/€¼ë‚Åc<6bèM>>vb'†b%%ä%5d EdfTäEÞŽF_Æ«Š'Ø‚,ð x…ÿ«3F±B[×’Yh%@ˆÄ‚hö‚/°‚ÞS.b=^AVdWdXŽåR›åT¾â[ÆåÖ-Ðy88=à.ƒ?ø†¡búšEœþ(´™ð [1ð®*7,ø‚,0Ç^ÄæTÞã%îf@~åËåq¶âDv”sÆ0ò˜¼—18Ø‚ƒíñ„yÞ¡z¶çLFŽ3z€\hAð‚Ù.hlÎæ#Þf…†¾!ðæod)†èZž80;g¯°èdÁh5˜h„؃ðyȆvacúØ›o8¸R,ƒ~‚'¸æSFèšîã›Îéogºëé"–hΠht¾è˜02 …MP„ ‚M(‡xØ¡ø”ê’Î å‚ u‡R 2zZi…`™ëU¶é?¾é†ÞiYîÚ)¥ìÊnëêHÙÉ;ñË‚AH¹&‡þR=(P‚¼fwÐ_·êk«$ÏV¨€:0Î/¸Ò&¸ãS¾Zå{¾Ý~ìÛ)øq w»¹Ë>»cRàÖ\[Ww[Ž(1îø‹¿µíŠþ‹:ƒ@“†ÊÉA}È à‚ÆêŽ¸pŒ›@C¸’†š"¡‰f@2hÛ-˜ƒ_î‚ïÚ`H™¾2eYÚ«Z2É¥à”çø^wÊž¸u¦Ž”„od5ˆ‚B 묀P8·Õ’jHA¨Æh(‡þ;±óIxÓ´4Ô† †8‹¿ø,p³/&»—uA¦%Z:µ°7 û•çð–wù‘ƒ]°x‚,(:À®@ y¨LæÝyI 1PFÀ{[A1cø{n(“À‡[hF _þ/øz`¾ããzq÷ú¯{F){þ²gy´/爃hºc[@esƒ3°€ƒ9HLqð‘n°½”À†Åˆ¾¥IØ„˜€×Ø"3z5æã8y¸… ƒ"H‚#€ÞnàPùoÖüÍï|Ï?{Ð}ˆøR­.vE6A„1b9PÖ÷@Ã3”q !Y@‚"PˆцÄPŒâ(È „O§ß}“ÇŠ(†la"D/^@bñ"Æ5Ú0áñ#‡"E–(9æ$Ê”*W²L©æ%L5a®\ñâe 3i¶¬”…Ž¥#EÀÔ‡Ÿ¾kù ôgO_SP×éû¦J'N”’þ›StöÆÚkÊiÔ´þö5ݧï7| &°¸ãÅa–,M®L´ñï?‚i¸d‰–Š«Œ 3ŒÍ3^^Z© NË"ýúv´¾¥hêÓ·N ¶Ó¥ñqª;ƒ™SÓôyëU-î´ëN Ü-Pß9|•Ä$‘‚×ÊÞ¾€3 &lÂ0tÄŒ§+v ó¤/g¶Ÿ ÓN2= çéÔ³£¥šöwš­¿wïÔqš©HН¼Ñ.íOýYìÝ–›{¼åã;èÀUŸ50ÁD{UaCEËY$XÎA7’Ò±ôˆ!‚hÝKÔdÅO”ÆlôQE{±Œ$#zþf©÷[i DV8ú8sI=<1¤x×=õÌSO‘U5ngíO8Þ£A t4±HVèQÇÌ:þ¸“ŽË<Ú¶?»öM&ä[Ѭüº°;ï»ó ß¼8uaL1ÅrèÑC¨ÈsþÞ;ºÃr©ÓR•;R9{Ï=ô¼å ~è±!.¢bÐ ‰2ïèÎðÔÓº?Þ¿¥:6R¿KM)Dr˜ô®w¿3Lð„7<UÆ cˆ‰e.óÀõ¡<È‚p°ŠpuÓ›Þäªf¹|ü‡OÑ=R(bˆ \艴„0Dá EÁˆÆñQÒ˜ýAªcZ©3‡ÖŽb• äL 9Ð l ‘œ.˜A bp@Á)]ø"»P0–È bŸlâ+Ô ;!D!ªp<È!8¨>øS*Q‰p@‹²G>Îb®ø¬æÁ ÆP†  þ$ 4ìBRð†òLã¦1ÇYTã¾?’„<ò¤{zô^(à EÐA Fà„ä€5ØnP‚œ ˆ¹%bº˜]Z ŒalI·°>a gƒv†C”¡ rLž€G|XcdŠå¢Ò£±Ò‡þ@Gð LP„€P|5GŽá p C ~aKfmjëpŸm¶ÉMPFÅ7îˆ1ì@C8áSà€+a)KZŽ—¸Ô¥"êK0ÞÉŒhTcw¬ 3ÔÀ „؃ à@$ã(ê"YH Eù§j€ÌZ&åƒe`¢4¨ä°:¨2aƒ ÄP‡àâþ(îëj8¹¶*¥&>ÌÀÄB„€  ­,BnМÀ¡}/%:Ñ.Üé YÖ:m† ¡ ‚‚à€ˆüaøø†Êâ•òãb,-äò!XÑPå®ßÀ„áh<µˆ|….Ô@ C}…yøs¿ Q°‘³nöÁ÷tã<¥À€ Ø@7xí :àÕ¯z ¬½ëßBÔ+d¡ieÃÂ@ì`(È„2Ž‚¸aRužìk÷xdMÑð<у9ì ‚°A„ÊDÖ§DO ‘€RhJ³`©£š’šuÀ‡=ÓÀ.0 ÕËþ3pÁk7°‚Ù–¢bhnCÔÀËXE606€ˆ:ààɸ/ü ~€p,·±Øoöh쩇*úÀî#z =À!¼tPA˜—1BÆ C8/R”Â8Úìãvô›ÜÀ‡¾¢íÑ}…ñ‡ $aZ4Á n  ˜À¾-‚¨Û“ää pÃ|E$¢—pR¬º½nCÄþñë´D\B~”&.™@ÁÖ B„t°BÀ³§“8R2‹p&!.PàhþÆ;¨»R©H´jé†ûf ˆ`+€²”©Là\y¬dÕrˆ¼+˜a ÃêöÀ„"^þA×Xäæ7ÿHÄ¢bŠrCçxtA`«ÒfLc›¸á{ƒ äÀ8$@vÅG8”¨!çÆ7ëhª£ºj˜¢6ã nPå[v¨À`Í@D±,F_-°WGpŠ\=7ÜÁ€Á'ä!ð8SoÄÙai"ý,”’…dË–Äa 4Bu¤#Íš»Í; •Œ¿0‡ Ø)cÙ†9«.²d/…G±Åh )|`àmß½KxxÞõ&˜ª…`3l! L‚"а qÜbƒôÇ6²7g÷¼·)‘‹Ãł޷àƒÜ`¨ƒ«\LGòvã_ QdÑ‚b 5XäT†/À¾ ÇžýnÚalÀ d¼Á”z ÈzŒJËœÅåeûƒÜ€4T.é\ôñœ<ÈDUˆ›þtð¼ÁÈÃ}IöhƒImXLÇxžTpÓÔ­ƒm„,€ÁPB 4Ü›ÔÐñ±xA:íV^ôÖA¨ÑÈ~,ÁÅlèCþà]S|P уgüHÁà‘Zmu áÅÛƒ0AâUß5LxäÇ/œ‡ùµ:5 C.ô‚鼋60×:ìQ EIaÉ.TÀ˜Á‹É"¨Ý6PÈARæ…:\µ¼‹2 t@,îœAfe¼ W©NàT” @2¼Ã>D‰=œÃ7l ˆ¤V·ˆÁØA³„þI¦ÎnœUx0´ B‹…ȱµ¡:5Á%dB\4A˜ ÜP%ÀŸ|ôÓ@l`©NýtÏ>àc>ú7xŒ< Ã8À@ÆkƼfWž‰©™&²Ú!05ø"ÚƒÖt<üÂX@@kÎçkB@vz%uúRÀXA¤& E:ÀC:Ø>ôOìKTtÁ €&Q®HiœÃy Cà™Ð ¸MæçþYçvfçœ `gÜ€ð˜QFšhùS´ˆŠ? bh:J_…<€XåÊç|²f}Þ'ˆ†Ñy—¬A€vÃã¤C8à&(Áž`Á,èDPå8¼…Á¹K\¨C2ä,A š iˆ^§šÞçÄår§ œÁ ˆLäQöÆ{VTÔc*?ä>¨ÂˆÀ¤á)0À}2f-Ž|"ˆˆ#ȃ7 \:l&ôÀ„A1Og`éýÓXŒ›8dhtWäÀèÀ™¢©šb'›JA­¡d^‰€Ê“5PÏ·­nð)4 >èÂðÁh•þôjD%ª¢f'£‚àD±¡”èwD‚W¬?¸*TÀˆ}j´@&œÇZ0ÅZVÅ©n×ÀAHÁÐ š¦ãšÎ*­­ò¤t‹$ƒESkÇÔ¨=¤Ð»äÂt@Ü@tÀ²þ¨8€³.j´Ž¨A¶i,Á3L‹Ôé/ A ËLЄˆq"=œ…uyƒ7ÈCÔÔÀ$Ü@´ê´é¼Ö+šdç½Nž(ؼÀð«DÂÇZƒXìRîiÁîÃ&ÝU/,l8€ 0A!„¬À HÆFk½ZÐVÔ€Ñqç O œ©èG5¼ÁMŽü†rõ<@ DÌ€¡JìÄ:«…„m´ŽmžÁ „$(‰>XÃÚÄ# øÈ ØÁ2–ânn 5dBB b>æÑq¨.c²ilÆe­ƒœ¨ LÄ HЀ¼‚û :œFÊ}“=`=œÇ7üTåΔnDu­ü¢îr8o´Þ@ç Á¨ÃÇzƒûXƒ:ˆÃ*à ´€ü)<ƒ7XRÔ˜Ð]}Â×M@"M,o›ÚocBoWþÁ½Ö áõöEÜ€\ Ä#詢؃5 5 ]tÀÔp¸/üÊïü&jêjðÍ€¤èÄ‚gd¡‚àƒ<ì!.ø©Æ3”Â,ýe‡­dº©!s¥ß+ÁŒpöjD"3¨\¬Å>¼ñ7Îå6ÃQ¨ïìÒ„@˜¸ïûÚ–èp×&êôpŸÌ€ tKP@2Uô#Rp&Óöˆš¨ý•ð'_gopl.G´VL/$ÁØÀTµüxʬ–lÉ/ XxÀèñ€À @À.dþü²€2²—™€«ò²„‹7”mÐîûXƒÛPÅ9`˜*ÀÔ@˜àCÆj|ò›’(`Œ2)ç þBQµò l€ŠÒ@€âC54ÎÉ–ôU–¼‰‡‰@€¤1ÿ12+ó ×ï'[ D‘kÉ@ Ü7ÌnùBEºDT°%5䂈@¨Àƒl7^燢³‡òrôW Á $±²”ð p€ |@h€*Dr®UÏ4øsÄÁ¼@ ä10ClV&42'ó2;tWFDÇó 0 „54ƒ=ØŒª=\Ã]±‚Û¸€Ml€'ïVeTþ\ÃuØÞg¿ô…kUÑ è€ØôkÝÀ‚F@øAØû>ðB°À À0+u˜Ôð45k>5Cç@`\¶e£óx½¤ Ø€](ÁäÁ0X’|l’Lá¨3|B ¤@7nÀ4ÁìA¯!DÇu\ÏuvÖÊ^g¯kõµ^÷kå@¼ÜÀ,AØÂi¿:D÷;Ô‚È€06ŒÀ/od×°dÇ2/Cß4y_¶…XHñËM—pdL€(ì‚À)—À 2”B@ tWKñy/Ç}Š2Eÿï ÷ ¸ tD”‰€ ð®+4‹Q=ƒ*P¡Þp/×V¡þów³ü.€‡‹7 Àp·eÿ·‰_Ä A¸Áp·DÂ'Ä‚0 ƒ0Ђ+4B A 8.@ôç͉_D€/Ǹ‘ ±¸§-¹§¹ ¨¨<$´1C*HdÀœ!VF”AN¶ø„¸ˆ¸^ù‰Ûš4M Ák€Ð@ PÀŽ;.\ÿ8£ùF‘9 3ùG,9 °€Dù1€1jyÀÀï|²˜“ù›¹F ùyoÀ€œv|A Ѐ§ŸQ Á¨Ü€ ü¤ž ¥¯s­º«3ùº•d?@¡ú¡?@†dBs-¤¸¤O:‰—øþªÿEX¶ªyAÖò aÕkÅ¥Fè€pÖD‰êù°‹r«»º’Ãú€·»›0l ãzl¤šn‡¸2‡ø.°ëµ°W»E¸Ál€ °¹v|À‡ØØ § \0®NûÃû_ÔÊŸº¶o;·œ”B$Ãêú®ƒy˜£û Æ{š‘{¿¨‰…œ:›7ÁîèÀv”‰™wDÑîP»¥÷Kñ¶Ï@ÂÇz»9| Á.ÙR$¯?µx8C34Ư»Æ#ùzw<†XÈO6A‰bgÞ»<¶ûýæCö/‹€çtè ¾á}yÚW<â ýн¶·>¶7~¿Ä¾ìcUV9?õoD×¹îk{àw¾ç>d?ñsxx[|Ð'¿òú™§ÿˆÏ@õ«I_÷ua•L·?õ_‘úÇ|Â{?¾ë?dG<ø?@8p°€`Á&°á€!>œ1‘bE‹+\äиþ‘cG3t€t1ÒÅ “'otT¹R%I—uÄ”©#b͈pæÔ¹g‡€f°0ÔB£† TªÔ Á„ .´)ÑbUŠY¶ ic†™³† û’$È™1§Úä¹3hP¢ Ä•[ôíR¦M>=µaÄ‘7>ÎX!˜ð`ÂWèÈ¡˜ñbÇŒCΈѵëÙ™3fΡ™ócÇ3>†dišio®X‹³-oåέkw`ÓyØËw!ˆ%>lP!BÅ`3Ž'G¾ü¸Wç:žG'=1dõ˜Ž1‹Öš»‹˜Ò•+/±b|yò€§G¿^½‡îá{h;_è[¸rä׿ÿ)þ‚þuãm€À7>`!BXÁ„!ŒPB(¬Ð §³È² ­ªê %„ð·I,ÑD=HQÅékë(£àÚOFþþCÀF,¡tzèC RÈ!'šªCÔ¦2È™lrÅ[ÌàE-˜ÑÊ„nÄ1G¸ €6ø±D%É$±šŽD²¦2#lòÄ'UŒ’¾)©¬ÒJº1ÇðÒK7à „NðƒCMTQ6,Ò¦4Õ„HHEuÓD9[´OÓºîÔO/·ä²O@… Và` -ÒWeÔ„HiMkÒW--Sú6ÝT NÐk7Eí’ÔFot„U …•RYk6¢[)Í•Ä]çëÕ>¥î6·PEõ3A_(Á×,pÕÙE•Ö]jeN±uK[¢¸ÑÛoy+¶X/_xas3ðéƒuŽ5Dw¥M8Qyç­×Þ¤”²€6<Ý÷©~ýu¡;xrdp-0.9.5/docs/Makefile.in000644 001751 001751 00000045730 13220730773 015434 0ustar00metameta000000 000000 # Makefile.in generated by automake 1.15.1 from Makefile.am. # @configure_input@ # Copyright (C) 1994-2017 Free Software Foundation, Inc. # This Makefile.in is free software; the Free Software Foundation # gives unlimited permission to copy and/or distribute it, # with or without modifications, as long as this notice is preserved. # This program is distributed in the hope that it will be useful, # but WITHOUT ANY WARRANTY, to the extent permitted by law; without # even the implied warranty of MERCHANTABILITY or FITNESS FOR A # PARTICULAR PURPOSE. @SET_MAKE@ VPATH = @srcdir@ am__is_gnu_make = { \ if test -z '$(MAKELEVEL)'; then \ false; \ elif test -n '$(MAKE_HOST)'; then \ true; \ elif test -n '$(MAKE_VERSION)' && test -n '$(CURDIR)'; then \ true; \ else \ false; \ fi; \ } am__make_running_with_option = \ case $${target_option-} in \ ?) ;; \ *) echo "am__make_running_with_option: internal error: invalid" \ "target option '$${target_option-}' specified" >&2; \ exit 1;; \ esac; \ has_opt=no; \ sane_makeflags=$$MAKEFLAGS; \ if $(am__is_gnu_make); then \ sane_makeflags=$$MFLAGS; \ else \ case $$MAKEFLAGS in \ *\\[\ \ ]*) \ bs=\\; \ sane_makeflags=`printf '%s\n' "$$MAKEFLAGS" \ | sed "s/$$bs$$bs[$$bs $$bs ]*//g"`;; \ esac; \ fi; \ skip_next=no; \ strip_trailopt () \ { \ flg=`printf '%s\n' "$$flg" | sed "s/$$1.*$$//"`; \ }; \ for flg in $$sane_makeflags; do \ test $$skip_next = yes && { skip_next=no; continue; }; \ case $$flg in \ *=*|--*) continue;; \ -*I) strip_trailopt 'I'; skip_next=yes;; \ -*I?*) strip_trailopt 'I';; \ -*O) strip_trailopt 'O'; skip_next=yes;; \ -*O?*) strip_trailopt 'O';; \ -*l) strip_trailopt 'l'; skip_next=yes;; \ -*l?*) strip_trailopt 'l';; \ -[dEDm]) skip_next=yes;; \ -[JT]) skip_next=yes;; \ esac; \ case $$flg in \ *$$target_option*) has_opt=yes; break;; \ esac; \ done; \ test $$has_opt = yes am__make_dryrun = (target_option=n; $(am__make_running_with_option)) am__make_keepgoing = (target_option=k; $(am__make_running_with_option)) pkgdatadir = $(datadir)/@PACKAGE@ pkgincludedir = $(includedir)/@PACKAGE@ pkglibdir = $(libdir)/@PACKAGE@ pkglibexecdir = $(libexecdir)/@PACKAGE@ am__cd = CDPATH="$${ZSH_VERSION+.}$(PATH_SEPARATOR)" && cd install_sh_DATA = $(install_sh) -c -m 644 install_sh_PROGRAM = $(install_sh) -c install_sh_SCRIPT = $(install_sh) -c INSTALL_HEADER = $(INSTALL_DATA) transform = $(program_transform_name) NORMAL_INSTALL = : PRE_INSTALL = : POST_INSTALL = : NORMAL_UNINSTALL = : PRE_UNINSTALL = : POST_UNINSTALL = : build_triplet = @build@ host_triplet = @host@ subdir = docs ACLOCAL_M4 = $(top_srcdir)/aclocal.m4 am__aclocal_m4_deps = $(top_srcdir)/m4/ax_append_compile_flags.m4 \ $(top_srcdir)/m4/ax_append_flag.m4 \ $(top_srcdir)/m4/ax_cflags_warn_all.m4 \ $(top_srcdir)/m4/ax_check_compile_flag.m4 \ $(top_srcdir)/m4/ax_gcc_func_attribute.m4 \ $(top_srcdir)/m4/ax_require_defined.m4 \ $(top_srcdir)/m4/ax_type_socklen_t.m4 \ $(top_srcdir)/m4/libtool.m4 $(top_srcdir)/m4/ltoptions.m4 \ $(top_srcdir)/m4/ltsugar.m4 $(top_srcdir)/m4/ltversion.m4 \ $(top_srcdir)/m4/lt~obsolete.m4 $(top_srcdir)/m4/pkg.m4 \ $(top_srcdir)/configure.ac am__configure_deps = $(am__aclocal_m4_deps) $(CONFIGURE_DEPENDENCIES) \ $(ACLOCAL_M4) DIST_COMMON = $(srcdir)/Makefile.am $(am__DIST_COMMON) mkinstalldirs = $(install_sh) -d CONFIG_HEADER = $(top_builddir)/config_ac.h CONFIG_CLEAN_FILES = CONFIG_CLEAN_VPATH_FILES = AM_V_P = $(am__v_P_@AM_V@) am__v_P_ = $(am__v_P_@AM_DEFAULT_V@) am__v_P_0 = false am__v_P_1 = : AM_V_GEN = $(am__v_GEN_@AM_V@) am__v_GEN_ = $(am__v_GEN_@AM_DEFAULT_V@) am__v_GEN_0 = @echo " GEN " $@; am__v_GEN_1 = AM_V_at = $(am__v_at_@AM_V@) am__v_at_ = $(am__v_at_@AM_DEFAULT_V@) am__v_at_0 = @ am__v_at_1 = SOURCES = DIST_SOURCES = RECURSIVE_TARGETS = all-recursive check-recursive cscopelist-recursive \ ctags-recursive dvi-recursive html-recursive info-recursive \ install-data-recursive install-dvi-recursive \ install-exec-recursive install-html-recursive \ install-info-recursive install-pdf-recursive \ install-ps-recursive install-recursive installcheck-recursive \ installdirs-recursive pdf-recursive ps-recursive \ tags-recursive uninstall-recursive am__can_run_installinfo = \ case $$AM_UPDATE_INFO_DIR in \ n|no|NO) false;; \ *) (install-info --version) >/dev/null 2>&1;; \ esac RECURSIVE_CLEAN_TARGETS = mostlyclean-recursive clean-recursive \ distclean-recursive maintainer-clean-recursive am__recursive_targets = \ $(RECURSIVE_TARGETS) \ $(RECURSIVE_CLEAN_TARGETS) \ $(am__extra_recursive_targets) AM_RECURSIVE_TARGETS = $(am__recursive_targets:-recursive=) TAGS CTAGS \ distdir am__tagged_files = $(HEADERS) $(SOURCES) $(TAGS_FILES) $(LISP) # Read a list of newline-separated strings from the standard input, # and print each of them once, without duplicates. Input order is # *not* preserved. am__uniquify_input = $(AWK) '\ BEGIN { nonempty = 0; } \ { items[$$0] = 1; nonempty = 1; } \ END { if (nonempty) { for (i in items) print i; }; } \ ' # Make sure the list of sources is unique. This is necessary because, # e.g., the same source file might be shared among _SOURCES variables # for different programs/libraries. am__define_uniq_tagged_files = \ list='$(am__tagged_files)'; \ unique=`for i in $$list; do \ if test -f "$$i"; then echo $$i; else echo $(srcdir)/$$i; fi; \ done | $(am__uniquify_input)` ETAGS = etags CTAGS = ctags DIST_SUBDIRS = $(SUBDIRS) am__DIST_COMMON = $(srcdir)/Makefile.in DISTFILES = $(DIST_COMMON) $(DIST_SOURCES) $(TEXINFOS) $(EXTRA_DIST) am__relativize = \ dir0=`pwd`; \ sed_first='s,^\([^/]*\)/.*$$,\1,'; \ sed_rest='s,^[^/]*/*,,'; \ sed_last='s,^.*/\([^/]*\)$$,\1,'; \ sed_butlast='s,/*[^/]*$$,,'; \ while test -n "$$dir1"; do \ first=`echo "$$dir1" | sed -e "$$sed_first"`; \ if test "$$first" != "."; then \ if test "$$first" = ".."; then \ dir2=`echo "$$dir0" | sed -e "$$sed_last"`/"$$dir2"; \ dir0=`echo "$$dir0" | sed -e "$$sed_butlast"`; \ else \ first2=`echo "$$dir2" | sed -e "$$sed_first"`; \ if test "$$first2" = "$$first"; then \ dir2=`echo "$$dir2" | sed -e "$$sed_rest"`; \ else \ dir2="../$$dir2"; \ fi; \ dir0="$$dir0"/"$$first"; \ fi; \ fi; \ dir1=`echo "$$dir1" | sed -e "$$sed_rest"`; \ done; \ reldir="$$dir2" ACLOCAL = @ACLOCAL@ AMTAR = @AMTAR@ AM_DEFAULT_VERBOSITY = @AM_DEFAULT_VERBOSITY@ AR = @AR@ AUTOCONF = @AUTOCONF@ AUTOHEADER = @AUTOHEADER@ AUTOMAKE = @AUTOMAKE@ AWK = @AWK@ CC = @CC@ CCDEPMODE = @CCDEPMODE@ CFLAGS = @CFLAGS@ CPP = @CPP@ CPPFLAGS = @CPPFLAGS@ CYGPATH_W = @CYGPATH_W@ DEFS = @DEFS@ DEPDIR = @DEPDIR@ DLLTOOL = @DLLTOOL@ DLOPEN_LIBS = @DLOPEN_LIBS@ DSYMUTIL = @DSYMUTIL@ DUMPBIN = @DUMPBIN@ ECHO_C = @ECHO_C@ ECHO_N = @ECHO_N@ ECHO_T = @ECHO_T@ EGREP = @EGREP@ EXEEXT = @EXEEXT@ FDKAAC_CFLAGS = @FDKAAC_CFLAGS@ FDKAAC_LIBS = @FDKAAC_LIBS@ FGREP = @FGREP@ FREERDP_CFLAGS = @FREERDP_CFLAGS@ FREERDP_LIBS = @FREERDP_LIBS@ FUSE_CFLAGS = @FUSE_CFLAGS@ FUSE_LIBS = @FUSE_LIBS@ GREP = @GREP@ INSTALL = @INSTALL@ INSTALL_DATA = @INSTALL_DATA@ INSTALL_PROGRAM = @INSTALL_PROGRAM@ INSTALL_SCRIPT = @INSTALL_SCRIPT@ INSTALL_STRIP_PROGRAM = @INSTALL_STRIP_PROGRAM@ LD = @LD@ LDFLAGS = @LDFLAGS@ LIBOBJS = @LIBOBJS@ LIBS = @LIBS@ LIBTOOL = @LIBTOOL@ LIPO = @LIPO@ LN_S = @LN_S@ LTLIBOBJS = @LTLIBOBJS@ LT_SYS_LIBRARY_PATH = @LT_SYS_LIBRARY_PATH@ MAKEINFO = @MAKEINFO@ MANIFEST_TOOL = @MANIFEST_TOOL@ MKDIR_P = @MKDIR_P@ NM = @NM@ NMEDIT = @NMEDIT@ OBJDUMP = @OBJDUMP@ OBJEXT = @OBJEXT@ OPENSSL = @OPENSSL@ OPENSSL_CFLAGS = @OPENSSL_CFLAGS@ OPENSSL_LIBS = @OPENSSL_LIBS@ OTOOL = @OTOOL@ OTOOL64 = @OTOOL64@ PACKAGE = @PACKAGE@ PACKAGE_BUGREPORT = @PACKAGE_BUGREPORT@ PACKAGE_NAME = @PACKAGE_NAME@ PACKAGE_STRING = @PACKAGE_STRING@ PACKAGE_TARNAME = @PACKAGE_TARNAME@ PACKAGE_URL = @PACKAGE_URL@ PACKAGE_VERSION = @PACKAGE_VERSION@ PAM_RULES = @PAM_RULES@ PATH_SEPARATOR = @PATH_SEPARATOR@ PIXMAN_CFLAGS = @PIXMAN_CFLAGS@ PIXMAN_LIBS = @PIXMAN_LIBS@ PKG_CONFIG = @PKG_CONFIG@ PKG_CONFIG_LIBDIR = @PKG_CONFIG_LIBDIR@ PKG_CONFIG_PATH = @PKG_CONFIG_PATH@ RANLIB = @RANLIB@ SED = @SED@ SET_MAKE = @SET_MAKE@ SHELL = @SHELL@ STRIP = @STRIP@ TurboJpegIncDir = @TurboJpegIncDir@ TurboJpegLibDir = @TurboJpegLibDir@ VERSION = @VERSION@ XMKMF = @XMKMF@ X_CFLAGS = @X_CFLAGS@ X_EXTRA_LIBS = @X_EXTRA_LIBS@ X_LIBS = @X_LIBS@ X_PRE_LIBS = @X_PRE_LIBS@ abs_builddir = @abs_builddir@ abs_srcdir = @abs_srcdir@ abs_top_builddir = @abs_top_builddir@ abs_top_srcdir = @abs_top_srcdir@ ac_ct_AR = @ac_ct_AR@ ac_ct_CC = @ac_ct_CC@ ac_ct_DUMPBIN = @ac_ct_DUMPBIN@ am__include = @am__include@ am__leading_dot = @am__leading_dot@ am__quote = @am__quote@ am__tar = @am__tar@ am__untar = @am__untar@ bindir = @bindir@ build = @build@ build_alias = @build_alias@ build_cpu = @build_cpu@ build_os = @build_os@ build_vendor = @build_vendor@ builddir = @builddir@ datadir = @datadir@ datarootdir = @datarootdir@ docdir = @docdir@ dvidir = @dvidir@ exec_prefix = @exec_prefix@ host = @host@ host_alias = @host_alias@ host_cpu = @host_cpu@ host_os = @host_os@ host_vendor = @host_vendor@ htmldir = @htmldir@ includedir = @includedir@ infodir = @infodir@ install_sh = @install_sh@ libdir = @libdir@ libexecdir = @libexecdir@ localedir = @localedir@ localstatedir = @localstatedir@ mandir = @mandir@ mkdir_p = @mkdir_p@ moduledir = @moduledir@ oldincludedir = @oldincludedir@ pdfdir = @pdfdir@ pkgconfigdir = @pkgconfigdir@ prefix = @prefix@ program_transform_name = @program_transform_name@ psdir = @psdir@ sbindir = @sbindir@ sharedstatedir = @sharedstatedir@ socketdir = @socketdir@ srcdir = @srcdir@ subdirs = @subdirs@ sysconfdir = @sysconfdir@ systemdsystemunitdir = @systemdsystemunitdir@ target_alias = @target_alias@ top_build_prefix = @top_build_prefix@ top_builddir = @top_builddir@ top_srcdir = @top_srcdir@ SUBDIRS = \ man all: all-recursive .SUFFIXES: $(srcdir)/Makefile.in: $(srcdir)/Makefile.am $(am__configure_deps) @for dep in $?; do \ case '$(am__configure_deps)' in \ *$$dep*) \ ( cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh ) \ && { if test -f $@; then exit 0; else break; fi; }; \ exit 1;; \ esac; \ done; \ echo ' cd $(top_srcdir) && $(AUTOMAKE) --foreign docs/Makefile'; \ $(am__cd) $(top_srcdir) && \ $(AUTOMAKE) --foreign docs/Makefile Makefile: $(srcdir)/Makefile.in $(top_builddir)/config.status @case '$?' in \ *config.status*) \ cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh;; \ *) \ echo ' cd $(top_builddir) && $(SHELL) ./config.status $(subdir)/$@ $(am__depfiles_maybe)'; \ cd $(top_builddir) && $(SHELL) ./config.status $(subdir)/$@ $(am__depfiles_maybe);; \ esac; $(top_builddir)/config.status: $(top_srcdir)/configure $(CONFIG_STATUS_DEPENDENCIES) cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh $(top_srcdir)/configure: $(am__configure_deps) cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh $(ACLOCAL_M4): $(am__aclocal_m4_deps) cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh $(am__aclocal_m4_deps): mostlyclean-libtool: -rm -f *.lo clean-libtool: -rm -rf .libs _libs # This directory's subdirectories are mostly independent; you can cd # into them and run 'make' without going through this Makefile. # To change the values of 'make' variables: instead of editing Makefiles, # (1) if the variable is set in 'config.status', edit 'config.status' # (which will cause the Makefiles to be regenerated when you run 'make'); # (2) otherwise, pass the desired values on the 'make' command line. $(am__recursive_targets): @fail=; \ if $(am__make_keepgoing); then \ failcom='fail=yes'; \ else \ failcom='exit 1'; \ fi; \ dot_seen=no; \ target=`echo $@ | sed s/-recursive//`; \ case "$@" in \ distclean-* | maintainer-clean-*) list='$(DIST_SUBDIRS)' ;; \ *) list='$(SUBDIRS)' ;; \ esac; \ for subdir in $$list; do \ echo "Making $$target in $$subdir"; \ if test "$$subdir" = "."; then \ dot_seen=yes; \ local_target="$$target-am"; \ else \ local_target="$$target"; \ fi; \ ($(am__cd) $$subdir && $(MAKE) $(AM_MAKEFLAGS) $$local_target) \ || eval $$failcom; \ done; \ if test "$$dot_seen" = "no"; then \ $(MAKE) $(AM_MAKEFLAGS) "$$target-am" || exit 1; \ fi; test -z "$$fail" ID: $(am__tagged_files) $(am__define_uniq_tagged_files); mkid -fID $$unique tags: tags-recursive TAGS: tags tags-am: $(TAGS_DEPENDENCIES) $(am__tagged_files) set x; \ here=`pwd`; \ if ($(ETAGS) --etags-include --version) >/dev/null 2>&1; then \ include_option=--etags-include; \ empty_fix=.; \ else \ include_option=--include; \ empty_fix=; \ fi; \ list='$(SUBDIRS)'; for subdir in $$list; do \ if test "$$subdir" = .; then :; else \ test ! -f $$subdir/TAGS || \ set "$$@" "$$include_option=$$here/$$subdir/TAGS"; \ fi; \ done; \ $(am__define_uniq_tagged_files); \ shift; \ if test -z "$(ETAGS_ARGS)$$*$$unique"; then :; else \ test -n "$$unique" || unique=$$empty_fix; \ if test $$# -gt 0; then \ $(ETAGS) $(ETAGSFLAGS) $(AM_ETAGSFLAGS) $(ETAGS_ARGS) \ "$$@" $$unique; \ else \ $(ETAGS) $(ETAGSFLAGS) $(AM_ETAGSFLAGS) $(ETAGS_ARGS) \ $$unique; \ fi; \ fi ctags: ctags-recursive CTAGS: ctags ctags-am: $(TAGS_DEPENDENCIES) $(am__tagged_files) $(am__define_uniq_tagged_files); \ test -z "$(CTAGS_ARGS)$$unique" \ || $(CTAGS) $(CTAGSFLAGS) $(AM_CTAGSFLAGS) $(CTAGS_ARGS) \ $$unique GTAGS: here=`$(am__cd) $(top_builddir) && pwd` \ && $(am__cd) $(top_srcdir) \ && gtags -i $(GTAGS_ARGS) "$$here" cscopelist: cscopelist-recursive cscopelist-am: $(am__tagged_files) list='$(am__tagged_files)'; \ case "$(srcdir)" in \ [\\/]* | ?:[\\/]*) sdir="$(srcdir)" ;; \ *) sdir=$(subdir)/$(srcdir) ;; \ esac; \ for i in $$list; do \ if test -f "$$i"; then \ echo "$(subdir)/$$i"; \ else \ echo "$$sdir/$$i"; \ fi; \ done >> $(top_builddir)/cscope.files distclean-tags: -rm -f TAGS ID GTAGS GRTAGS GSYMS GPATH tags distdir: $(DISTFILES) @srcdirstrip=`echo "$(srcdir)" | sed 's/[].[^$$\\*]/\\\\&/g'`; \ topsrcdirstrip=`echo "$(top_srcdir)" | sed 's/[].[^$$\\*]/\\\\&/g'`; \ list='$(DISTFILES)'; \ dist_files=`for file in $$list; do echo $$file; done | \ sed -e "s|^$$srcdirstrip/||;t" \ -e "s|^$$topsrcdirstrip/|$(top_builddir)/|;t"`; \ case $$dist_files in \ */*) $(MKDIR_P) `echo "$$dist_files" | \ sed '/\//!d;s|^|$(distdir)/|;s,/[^/]*$$,,' | \ sort -u` ;; \ esac; \ for file in $$dist_files; do \ if test -f $$file || test -d $$file; then d=.; else d=$(srcdir); fi; \ if test -d $$d/$$file; then \ dir=`echo "/$$file" | sed -e 's,/[^/]*$$,,'`; \ if test -d "$(distdir)/$$file"; then \ find "$(distdir)/$$file" -type d ! -perm -700 -exec chmod u+rwx {} \;; \ fi; \ if test -d $(srcdir)/$$file && test $$d != $(srcdir); then \ cp -fpR $(srcdir)/$$file "$(distdir)$$dir" || exit 1; \ find "$(distdir)/$$file" -type d ! -perm -700 -exec chmod u+rwx {} \;; \ fi; \ cp -fpR $$d/$$file "$(distdir)$$dir" || exit 1; \ else \ test -f "$(distdir)/$$file" \ || cp -p $$d/$$file "$(distdir)/$$file" \ || exit 1; \ fi; \ done @list='$(DIST_SUBDIRS)'; for subdir in $$list; do \ if test "$$subdir" = .; then :; else \ $(am__make_dryrun) \ || test -d "$(distdir)/$$subdir" \ || $(MKDIR_P) "$(distdir)/$$subdir" \ || exit 1; \ dir1=$$subdir; dir2="$(distdir)/$$subdir"; \ $(am__relativize); \ new_distdir=$$reldir; \ dir1=$$subdir; dir2="$(top_distdir)"; \ $(am__relativize); \ new_top_distdir=$$reldir; \ echo " (cd $$subdir && $(MAKE) $(AM_MAKEFLAGS) top_distdir="$$new_top_distdir" distdir="$$new_distdir" \\"; \ echo " am__remove_distdir=: am__skip_length_check=: am__skip_mode_fix=: distdir)"; \ ($(am__cd) $$subdir && \ $(MAKE) $(AM_MAKEFLAGS) \ top_distdir="$$new_top_distdir" \ distdir="$$new_distdir" \ am__remove_distdir=: \ am__skip_length_check=: \ am__skip_mode_fix=: \ distdir) \ || exit 1; \ fi; \ done check-am: all-am check: check-recursive all-am: Makefile installdirs: installdirs-recursive installdirs-am: install: install-recursive install-exec: install-exec-recursive install-data: install-data-recursive uninstall: uninstall-recursive install-am: all-am @$(MAKE) $(AM_MAKEFLAGS) install-exec-am install-data-am installcheck: installcheck-recursive install-strip: if test -z '$(STRIP)'; then \ $(MAKE) $(AM_MAKEFLAGS) INSTALL_PROGRAM="$(INSTALL_STRIP_PROGRAM)" \ install_sh_PROGRAM="$(INSTALL_STRIP_PROGRAM)" INSTALL_STRIP_FLAG=-s \ install; \ else \ $(MAKE) $(AM_MAKEFLAGS) INSTALL_PROGRAM="$(INSTALL_STRIP_PROGRAM)" \ install_sh_PROGRAM="$(INSTALL_STRIP_PROGRAM)" INSTALL_STRIP_FLAG=-s \ "INSTALL_PROGRAM_ENV=STRIPPROG='$(STRIP)'" install; \ fi mostlyclean-generic: clean-generic: distclean-generic: -test -z "$(CONFIG_CLEAN_FILES)" || rm -f $(CONFIG_CLEAN_FILES) -test . = "$(srcdir)" || test -z "$(CONFIG_CLEAN_VPATH_FILES)" || rm -f $(CONFIG_CLEAN_VPATH_FILES) maintainer-clean-generic: @echo "This command is intended for maintainers to use" @echo "it deletes files that may require special tools to rebuild." clean: clean-recursive clean-am: clean-generic clean-libtool mostlyclean-am distclean: distclean-recursive -rm -f Makefile distclean-am: clean-am distclean-generic distclean-tags dvi: dvi-recursive dvi-am: html: html-recursive html-am: info: info-recursive info-am: install-data-am: install-dvi: install-dvi-recursive install-dvi-am: install-exec-am: install-html: install-html-recursive install-html-am: install-info: install-info-recursive install-info-am: install-man: install-pdf: install-pdf-recursive install-pdf-am: install-ps: install-ps-recursive install-ps-am: installcheck-am: maintainer-clean: maintainer-clean-recursive -rm -f Makefile maintainer-clean-am: distclean-am maintainer-clean-generic mostlyclean: mostlyclean-recursive mostlyclean-am: mostlyclean-generic mostlyclean-libtool pdf: pdf-recursive pdf-am: ps: ps-recursive ps-am: uninstall-am: .MAKE: $(am__recursive_targets) install-am install-strip .PHONY: $(am__recursive_targets) CTAGS GTAGS TAGS all all-am check \ check-am clean clean-generic clean-libtool cscopelist-am ctags \ ctags-am distclean distclean-generic distclean-libtool \ distclean-tags distdir dvi dvi-am html html-am info info-am \ install install-am install-data install-data-am install-dvi \ install-dvi-am install-exec install-exec-am install-html \ install-html-am install-info install-info-am install-man \ install-pdf install-pdf-am install-ps install-ps-am \ install-strip installcheck installcheck-am installdirs \ installdirs-am maintainer-clean maintainer-clean-generic \ mostlyclean mostlyclean-generic mostlyclean-libtool pdf pdf-am \ ps ps-am tags tags-am uninstall uninstall-am .PRECIOUS: Makefile # Tell versions [3.59,3.63) of GNU make to not export all variables. # Otherwise a system limit (for SysV at least) may be exceeded. .NOEXPORT: xrdp-0.9.5/docs/Makefile.am000644 001751 001751 00000000023 12477501376 015415 0ustar00metameta000000 000000 SUBDIRS = \ man xrdp-0.9.5/docs/man/000755 001751 001751 00000000000 13220731021 014114 5ustar00metameta000000 000000 xrdp-0.9.5/docs/man/xrdp-genkeymap.8.in000644 001751 001751 00000002465 13133557325 017574 0ustar00metameta000000 000000 .TH "xrdp\-genkeymap" "8" "@PACKAGE_VERSION@" "xrdp team" "" .de URL . \\$2 \(laURL: \\$1 \(ra\\$3 .. .if \n[.g] .mso www.tmac .SH "NAME" \fBxrdp\-genkeymap\fR \- key map generator for XRDP .SH "SYNTAX" .B xrdp\-genkeymap .I file .SH "DESCRIPTION" \fBxrdp\-genkeymap\fR extracts the key map used by the currently running X session to generated a mapping from Remote Desktop Protocol (RDP) key codes to X keysyms and Unicode code points. .SH OPTIONS .TP .I outfile The key map information is stored in the file named \fIoutfile\fP. .SH "FILES" .TP .I @sysconfdir@/xrdp/km-XXXXXXXX.ini Files containing the keyboard mapping for language \fIXXXXXXXX\fP, which is a 8 digit hexadecimal number identifying the country and language code. .RS 8 .TP .B 00000405 cs Czech .TP .B 00000407 de German .TP .B 00000409 en-us US English .TP .B 0000040c fr French .TP .B 00000410 it Italian .TP .B 00000416 br Portuguese (Brazil) .TP .B 00000419 ru Russian .TP .B 0000041d se Swedish .TP .B 00000809 en-uk UK English .RE .SH "AUTHORS" Jay Sorg .br Simone Fedele .SH "SEE ALSO" .BR xrdp (8), .BR setxkbmap (1), .BR unicode (7), .URL "https://github.com/FreeRDP/FreeRDP/wiki/Keyboard" "Description of Keyboard Input mapping" . for more info on \fBxrdp\fR see http://www.xrdp.org/ xrdp-0.9.5/docs/man/xrdp-sesrun.8.in000644 001751 001751 00000001677 13133557325 017137 0ustar00metameta000000 000000 .TH "xrdp\-sesrun" "8" "@PACKAGE_VERSION@" "xrdp team" "" .SH "NAME" xrdp\-sesrun \- \fBsesman\fR(8) session launcher .SH "SYNTAX" .B xrdp\-sesrun .I server username password width height bpp .SH "DESCRIPTION" \fBxrdp\-sesrun\fR starts a session using \fBxrdp\-sesman\fR(8). .br This is a tool useful for testing, it simply behaves like xrdp when some user logs in a new session and authenticates, thus starting a new session. .SH "OPTIONS" .TP .I server Server on which sesman is running .TP .I username user name of the session being started .TP .I password user password .TP .I width Screen width .TP .I height Screen height .TP .I bpp Session color depth .SH "FILES" @bindir@/sesman .br @bindir@/sesrun .SH "AUTHORS" Jay Sorg .br Simone Fedele .SH "SEE ALSO" .BR xrdp\-sesman (8), .BR sesman.ini (5), .BR xrdp (8), .BR xrdp.ini (5) for more info on \fBxrdp\fR see http://www.xrdp.org/ xrdp-0.9.5/docs/man/xrdp.ini.5.in000644 001751 001751 00000027415 13206666623 016376 0ustar00metameta000000 000000 .TH "xrdp.ini" "5" "@PACKAGE_VERSION@" "xrdp team" "" .SH "NAME" \fBxrdp.ini\fR \- Configuration file for \fBxrdp\fR(8) .SH "DESCRIPTION" This is the man page for \fBxrdp.ini\fR, \fBxrdp\fR(8) configuration file. It is composed by a number of sections, each one composed by a section name, enclosed by square brackets, followed by a list of \fI\fR=\fI\fR lines. \fBxrdp.ini\fR supports the following sections: .TP \fB[Globals]\fP \- sets some global configuration settings for \fBxrdp\fR(8). .TP \fB[Logging]\fP \- logging subsystem parameters .TP \fB[Channels]\fP \- channel subsystem parameters .LP All options and values (except for file names and paths) are case insensitive, and are described in detail below. .SH "GLOBALS" The options to be specified in the \fB[Globals]\fR section are the following: .TP \fBaddress\fP=\fIip address\fP Specify xrdp listening address. If not specified, defaults to 0.0.0.0 (all interfaces). .TP \fBautorun\fP=\fIsession_name\fP Section name for automatic login. If set and the client supplies valid username and password, the user will be logged in automatically using the connection specified by \fIsession_name\fP. If \fIsession_name\fP is empty, the \fBLOGIN DOMAIN\fR from the client with be used to select the section. If no domain name is supplied, the first suitable section will be used for automatic login. .TP \fBbitmap_cache\fR=\fI[true|false]\fR If set to \fB1\fR, \fBtrue\fR or \fByes\fR this option enables bitmap caching in \fBxrdp\fR(8). .TP \fBbitmap_compression\fR=\fI[true|false]\fR If set to \fB1\fR, \fBtrue\fR or \fByes\fR this option enables bitmap compression in \fBxrdp\fR(8). .TP \fBbulk_compression\fP=\fI[true|false]\fP If set to \fB1\fR, \fBtrue\fR or \fByes\fR this option enables compression of bulk data in \fBxrdp\fR(8). .TP \fBcertificate\fP=\fI/path/to/certificate\fP .TP \fBkey_file\fP=\fI/path/to/private_key\fP Set location of TLS certificate and private key. They must be written in PEM format. If not specified, defaults to \fB@sysconfdir@/xrdp/cert.pem\fP, \fB@sysconfdir@/xrdp/key.pem\fP. This parameter is effective only if \fBsecurity_layer\fP is set to \fBtls\fP or \fBnegotiate\fP. .TP \fBchannel_code\fP=\fI[true|false]\fP If set to \fB0\fR, \fBfalse\fR or \fBno\fR this option disables all channels \fBxrdp\fR(8). See section \fBCHANNELS\fP below for more fine grained options. .TP \fBcrypt_level\fP=\fI[low|medium|high|fips]\fP .\" Regulate encryption level of Standard RDP Security. This parameter is effective only if \fBsecurity_layer\fP is set to \fBrdp\fP or \fBnegotiate\fP. Encryption in Standard RDP Security is controlled by two settings: \fIEncryption Level\fP and \fIEncryption Method\fP. The only supported \fIEncryption Method\fP are \fB40BIT_ENCRYPTION\fP and \fB128BIT_ENCRYPTION\fP. \fB56BIT_ENCRYPTION\fP is not supported. This option controls the \fIEncryption Level\fP: .RS 8 .TP .B low All data sent from the client to the server is protected by encryption based on the maximum key strength supported by the client. .I This is the only level that the traffic sent by the server to client is not encrypted. .TP .B medium All data sent between the client and the server is protected by encryption based on the maximum key strength supported by the client (client compatible). .TP .B high All data sent between the client and the server is protected by encryption based on the server's maximum key strength (sever compatible). .TP .B fips All data sent between the client and server is protected using Federal Information Processing Standard 140-1 validated encryption methods. .I This level is required for Windows clients (mstsc.exe) if the client's group policy .I enforces FIPS-compliance mode. .RE .TP \fBfork\fP=\fI[true|false]\fP If set to \fB1\fR, \fBtrue\fR or \fByes\fR for each incoming connection \fBxrdp\fR(8) forks a sub-process instead of using threads. .TP \fBhidelogwindow\fP=\fI[true|false]\fP If set to \fB1\fP, \fBtrue\fP or \fByes\fP, \fBxrdp\fP will not show a window for log messages. If not specified, defaults to \fBfalse\fP. .TP \fBmax_bpp\fP=\fI[8|15|16|24|32]\fP Limit the color depth by specifying the maximum number of bits per pixel. If not specified or set to \fB0\fP, unlimited. .TP \fBpamerrortxt\fP=\fIerror_text\fP Specify text passed to PAM when authentication failed. The maximum length is \fB256\fP. .TP \fBport\fP=\fIport\fP Specify TCP port to listen on for incoming connections. The default for RDP is \fB3389\fP. .TP \fBrequire_credentials\fP=\fI[true|false]\fP If set to \fB1\fP, \fBtrue\fP or \fByes\fP, \fBxrdp\fP requires clients to include username and password initial connection phase. In other words, xrdp doesn't allow clients to show login screen if set to true. If not specified, defaults to \fBfalse\fP. .TP \fBsecurity_layer\fP=\fI[tls|rdp|negotiate]\fP Regulate security methods. If not specified, defaults to \fBnegotiate\fP. .RS 8 .TP .B tls Enhanced RDP Security is used. All security operations (encryption, decryption, data integrity verification, and server authentication) are implemented by TLS. .TP .B rdp Standard RDP Security, which is not safe from man-in-the-middle attack, is used. The encryption level of Standard RDP Security is controlled by \fBcrypt_level\fP. .TP .B negotiate Negotiate these security methods with clients. .RE .TP \fBssl_protocols\fP=\fI[SSLv3] [TLSv1] [TLSv1.1] [TLSv1.2]\fP Enables the specified SSL/TLS protocols. Each value should be separated by comma. SSLv2 is always disabled. At least one protocol should be given to accept TLS connections. This parameter is effective only if \fBsecurity_layer\fP is set to \fBtls\fP or \fBnegotiate\fP. .TP \fBtcp_keepalive\fP=\fI[true|false]\fP Regulate if the listening socket uses socket option \fBSO_KEEPALIVE\fP. If set to \fB1\fP, \fBtrue\fP or \fByes\fP and the network connection disappears without closing messages, the connection will be closed. .TP \fBtcp_nodelay\fP=\fI[true|false]\fP Regulate if the listening socket uses socket option \fBTCP_NODELAY\fP. If set to \fB1\fP, \fBtrue\fP or \fByes\fP, no buffering will be performed in the TCP stack. .TP \fBtcp_send_buffer_bytes\fP=\fIbuffer_size\fP .TP \fBtcp_recv_buffer_bytes\fP=\fIbuffer_size\fP Specify send/recv buffer sizes in bytes. The default value depends on operating system. .TP \fBtls_ciphers\fP=\fIcipher_suite\fP Specifies TLS cipher suite. The format of this parameter is equivalent to which \fBopenssl\fP(1) ciphers subcommand accepts. (ex. $ openssl ciphers 'HIGH:!ADH:!SHA1') This parameter is effective only if \fBsecurity_layer\fP is set to \fBtls\fP or \fBnegotiate\fP. .TP \fBuse_fastpath\fP=\fI[input|output|both|none]\fP If not specified, defaults to \fBnone\fP. .TP \fBblack\fP=\fI000000\fP .TP \fBgrey\fP=\fIc0c0c0\fP .TP \fBdark_grey\fP=\fI808080\fP .TP \fBblue\fP=\fI0000ff\fP .TP \fBdark_blue\fP=\fI00007f\fP .TP \fBwhite\fP=\fIffffff\fP .TP \fBred\fP=\fIff0000\fP .TP \fBgreen\fP=\fI00ff00\fP .TP \fBbackground\fP=\fI000000\fP These options override the colors used internally by \fBxrdp\fP(8) to draw the login and log windows. Colors are defined using a hexadecimal (hex) notation for the combination of Red, Green, and Blue color values (RGB). The lowest value that can be given to one of the light sources is 0 (hex 00). The highest value is 255 (hex FF). .SH "LOGGING" The following parameters can be used in the \fB[Logging]\fR section: .TP \fBLogFile\fR=\fI@localstatedir@/log/sesman.log\fR This options contains the path to logfile. It can be either absolute or relative.\fR .TP \fBLogLevel\fR=\fIlevel\fR This option can have one of the following values: \fBCORE\fR or \fB0\fR \- Log only core messages. these messages are _always_ logged, regardless the logging level selected. \fBERROR\fR or \fB1\fR \- Log only error messages \fBWARNING\fR, \fBWARN\fR or \fB2\fR \- Logs warnings and error messages \fBINFO\fR or \fB3\fR \- Logs errors, warnings and informational messages \fBDEBUG\fR or \fB4\fR \- Log everything. If \fBsesman\fR is compiled in debug mode, this options will output many more low\-level message, useful for developers .TP \fBEnableSyslog\fR=\fI[true|false]\fR If set to \fB1\fR, \fBtrue\fR or \fByes\fR this option enables logging to syslog. Otherwise syslog is disabled. .TP \fBSyslogLevel\fR=\fIlevel\fR This option sets the logging level for syslog. It can have the same values of \fBLogLevel\fR. If \fBSyslogLevel\fR is greater than \fBLogLevel\fR, its value is lowered to that of \fBLogLevel\fR. .SH "CHANNELS" The Remote Desktop Protocol supports several channels, which are used to transfer additional data like sound, clipboard data and others. Channel names not listed here will be blocked by \fBxrdp\fP. Not all channels are supported in all cases, so setting a value to \fItrue\fP is a prerequisite, but does not force its use. .br Channels can also be enabled or disabled on a per connection basis by prefixing each setting with \fBchannel.\fP in the channel section. .TP \fBrdpdr\fP=\fI[true|false]\fP If set to \fB1\fR, \fBtrue\fR or \fByes\fR using the RDP channel for device redirection is allowed. .TP \fBrdpsnd\fP=\fI[true|false]\fP If set to \fB1\fR, \fBtrue\fR or \fByes\fR using the RDP channel for sound is allowed. .TP \fBdrdynvc\fP=\fI[true|false]\fP If set to \fB1\fR, \fBtrue\fR or \fByes\fR using the RDP channel to initiate additional dynamic virtual channels is allowed. .TP \fBcliprdr\fP=\fI[true|false]\fP If set to \fB1\fR, \fBtrue\fR or \fByes\fR using the RDP channel for clipboard redirection is allowed. .TP \fBrail\fP=\fI[true|false]\fP If set to \fB1\fR, \fBtrue\fR or \fByes\fR using the RDP channel for remote applications integrated locally (RAIL) is allowed. .TP \fBxrdpvr\fP=\fI[true|false]\fP If set to \fB1\fR, \fBtrue\fR or \fByes\fR using the RDP channel for XRDP Video streaming is allowed. .SH "CONNECTIONS" A connection section is made of a section name, enclosed in square brackets, and the following entries: .TP \fBname\fR=\fI\fR The name displayed in \fBxrdp\fR(8) login window's combo box. .TP \fBlib\fR=\fI../vnc/libvnc.so\fR Sets the library to be used with this connection. .TP \fBusername\fR=\fI\fR|\fI{base64}\fR|\fIask\fR Specifies the username used for authenticating in the connection. If set to \fIask\fR, user name should be provided in the login window. If the username includes comment out symbols such as '!', '#', or ';', the username can be provided in base64 form prefixing "{base64}". .TP \fBpassword\fR=\fI\fR|\fI{base64}\fR|\fIask\fR Specifies the password used for authenticating in the connection. If set to \fIask\fR, password should be provided in the login window. This parameter can be provided in base64 form as well as username. See also examples below. .TP \fBip\fR=\fI127.0.0.1\fR Specifies the ip address of the host to connect to. .TP \fBport\fR=\fI\fR|\fI\-1\fR Specifies the port number to connect to. If set to \fI\-1\fR, the default port for the specified library is used. .TP \fBxserverbpp\fR=\fI\fR Specifies color depth of the backend X server. The default is the color depth of the client. Only Xvnc and X11rdp use that setting. Xorg runs at \fI24\fR bpp. .TP \fBcode\fR=\fI\fR|\fI0\fR Specifies the session type. The default, \fI0\fR, is Xvnc, \fI10\fR is X11rdp, and \fI20\fR is Xorg with xorgxrdp modules. .SH "EXAMPLES" This is an example \fBxrdp.ini\fR: .nf [Globals] bitmap_cache=true bitmap_compression=true [Xorg] name=Xorg lib=libxup.so username=ask password=ask ip=127.0.0.1 port=-1 code=20 [vnc-any] name=vnc-any lib=libvnc.so ip=ask port=ask5900 username=na password={base64}cGFzc3dvcmQhCg== .fi .SH "FILES" @sysconfdir@/xrdp/xrdp.ini .SH "SEE ALSO" .BR xrdp (8), .BR sesman (8), .BR sesrun (8), .BR sesman.ini (5) for more info on \fBxrdp\fR see http://www.xrdp.org/ xrdp-0.9.5/docs/man/xrdp-chansrv.8.in000644 001751 001751 00000002127 13206023530 017236 0ustar00metameta000000 000000 .TH "xrdp\-chansrv" "8" "@PACKAGE_VERSION@" "xrdp team" "" .SH "NAME" \fBxrdp\-chansrv\fR \- \fBxrdp\fR channel server .SH "SYNTAX" .B xrdp\-chansrv .SH "DESCRIPTION" \fBxrdp\-chansrv\fR is the \fBxrdp\fR(8) channel server, which manages the Remote Desktop Protocol (RDP) sub-channels. This program is only forked internally by \fBxrdp\-sesman\fP(8). .br Currently \fBxrdp\-chansrv\fP knows about the following channels: .RE 8 .TP .B cliprdr Clipboard Redirection .TP .B rdpsnd Remote Desktop Protocol Sound .TP .B rdpdr Remote Desktop Protocol Device Redirection .TP .B rail Remote Applications Integrated Locally .TP .B drdynvc Dynamic Virtual Channel .RS .SH FILES .TP .I @socketdir@/xrdp_chansrv_socket_* UNIX socket used by external programs to implement channels. .TP .I @socketdir@/xrdp_api_* UNIX socket used by \fBxrdp\-chansrv\fP to communicate with \fBxrdp\-sesman\fP. .TP .I $XDG_DATA_HOME/xrdp/xrdp-chansrv.%s.log Log file used by \fBxrdp\-chansrv\fP(8). \fB%s\fP is display number. .SH "SEE ALSO" .BR xrdp\-sesman (8), .BR sesman.ini (5). for more info on \fBxrdp\fR see http://www.xrdp.org/ xrdp-0.9.5/docs/man/xrdp-sesadmin.8.in000644 001751 001751 00000002130 13133557325 017404 0ustar00metameta000000 000000 .TH "xrdp-sesadmin" "8" "@PACKAGE_VERSION@" "xrdp team" .SH NAME xrdp\-sesadmin \- console XRDP sessions administration tool .SH SYNOPSIS .B xrdp\-sesadmin .RI [ options ] .BI -c= command .SH DESCRIPTION This manual page documents briefly the .B xrdp\-sesadmin command. .PP \fBxrdp\-sesadmin\fP is a console program to administer running XRDP sessions. .SH OPTIONS A summary of options is included below. .TP .BI \-u= username \fIUsername\fP for authentication on the server. Defaults to \fBroot\fP. .TP .BI \-p= password The \fIpassword\fP to authenticate with. The default is to ask for the password interactively. .TP .BI \-s= server The host address of the \fIserver\fP to connect to. Defaults to \fBlocalhost\fP. .TP .BI \-i= port The TCP \fIport\fP number to connect to. Defaults to \fB3350\fP. .TP .BI \-c= command Specifies the \fIcommand\fP to execute on the server. Valid commands are: .RS 4 .TP .B list List currently active sessions. .TP .BI kill: sid Kills the session specified the given \fIsession id\fP. (not yet implemented). .RE .SH FILES xrdp\-sesadmin.log .SH SEE ALSO .BR xrdp (8). xrdp-0.9.5/docs/man/xrdp-keygen.8.in000644 001751 001751 00000002262 13133557325 017071 0ustar00metameta000000 000000 .\" Hey, EMACS: -*- nroff -*- .\"- .\" Copyright © 2007, 2008 Vincent Bernat .\" License: GPL-2+ .\"- .TH xrdp\-keygen 8 "@PACKAGE_VERSION@" "xrdp team" .SH NAME xrdp\-keygen \- xrdp RSA key generation utility .SH SYNOPSIS .B xrdp\-keygen xrdp < \fIoutfile\fP | \fBauto\fP > .br .B xrdp\-keygen test .SH DESCRIPTION \fBxrdp\-keygen\fP generates the file .I @sysconfdir@/xrdp/rsakeys.ini which contains the RSA key pair used to perform authentication to remote clients. The public key is self-signed. .SH OPTIONS This program takes one of the following options: .TP \fBxrdp\fP \fIoutfile\fP Generate a new key pair. The key data is stored in the file named \fIoutfile\fP. .br If \fBauto\fP is used as \fIoutfile\fP, the default file \fI@sysconfdir@/xrdp/rsakeys.ini\fP gets created if it does not yet exists. .TP .B test Generate a test key pair and print information to standard output. .SH FILES .TP .I @sysconfdir@/xrdp/rsakeys.ini RSA public and private key pair used to identify this XRDP server. .SH SEE ALSO .BR xrdp (8), .BR xrdp\-sesman (8). .SH AUTHOR This manual page was originally written by Vincent Bernat . xrdp-0.9.5/docs/man/xrdp-sesman.8.in000644 001751 001751 00000001766 13133557325 017105 0ustar00metameta000000 000000 .TH "xrdp\-sesman" "8" "@PACKAGE_VERSION@" "xrdp team" "" .SH "NAME" xrdp\-sesman \- \fBxrdp\fR(8) session manager .SH "SYNTAX" .B xrdp\-sesman .RB [ \-\-nodaemon | \-\-kill | \-\-help ] .SH "DESCRIPTION" \fBxrdp\-sesman\fR is \fBxrdp\fR(8) session manager. .br It manages user sessions by authenticating the user and starting the appropriate Xserver. .SH "OPTIONS" .TP \fB\-n\fR, \fB\-\-nodaemon\fR Starts \fBxrdp\-sesman\fR in foreground instead of starting it as a daemon. .TP \fB\-k\fR, \fB\-\-kill\fR Kills running \fBxrdp\-sesman\fR daemon. .TP \fB\-h\fR, \fB\-\-help\fR Output help information and exit. .SH "FILES" @bindir@/sesman .br @bindir@/sesrun .br @sysconfdir@/xrdp/sesman.ini .br @localstatedir@/log/sesman.log .br @localstatedir@/run/sesman.pid .SH "AUTHORS" Jay Sorg .br Simone Fedele .SH "SEE ALSO" .BR sesman.ini (5), .BR xrdp\-sesrun (8), .BR xrdp (8), .BR xrdp.ini (5) for more info on \fBxrdp\fR see http://www.xrdp.org/ xrdp-0.9.5/docs/man/Makefile.in000644 001751 001751 00000047564 13220730773 016216 0ustar00metameta000000 000000 # Makefile.in generated by automake 1.15.1 from Makefile.am. # @configure_input@ # Copyright (C) 1994-2017 Free Software Foundation, Inc. # This Makefile.in is free software; the Free Software Foundation # gives unlimited permission to copy and/or distribute it, # with or without modifications, as long as this notice is preserved. # This program is distributed in the hope that it will be useful, # but WITHOUT ANY WARRANTY, to the extent permitted by law; without # even the implied warranty of MERCHANTABILITY or FITNESS FOR A # PARTICULAR PURPOSE. @SET_MAKE@ VPATH = @srcdir@ am__is_gnu_make = { \ if test -z '$(MAKELEVEL)'; then \ false; \ elif test -n '$(MAKE_HOST)'; then \ true; \ elif test -n '$(MAKE_VERSION)' && test -n '$(CURDIR)'; then \ true; \ else \ false; \ fi; \ } am__make_running_with_option = \ case $${target_option-} in \ ?) ;; \ *) echo "am__make_running_with_option: internal error: invalid" \ "target option '$${target_option-}' specified" >&2; \ exit 1;; \ esac; \ has_opt=no; \ sane_makeflags=$$MAKEFLAGS; \ if $(am__is_gnu_make); then \ sane_makeflags=$$MFLAGS; \ else \ case $$MAKEFLAGS in \ *\\[\ \ ]*) \ bs=\\; \ sane_makeflags=`printf '%s\n' "$$MAKEFLAGS" \ | sed "s/$$bs$$bs[$$bs $$bs ]*//g"`;; \ esac; \ fi; \ skip_next=no; \ strip_trailopt () \ { \ flg=`printf '%s\n' "$$flg" | sed "s/$$1.*$$//"`; \ }; \ for flg in $$sane_makeflags; do \ test $$skip_next = yes && { skip_next=no; continue; }; \ case $$flg in \ *=*|--*) continue;; \ -*I) strip_trailopt 'I'; skip_next=yes;; \ -*I?*) strip_trailopt 'I';; \ -*O) strip_trailopt 'O'; skip_next=yes;; \ -*O?*) strip_trailopt 'O';; \ -*l) strip_trailopt 'l'; skip_next=yes;; \ -*l?*) strip_trailopt 'l';; \ -[dEDm]) skip_next=yes;; \ -[JT]) skip_next=yes;; \ esac; \ case $$flg in \ *$$target_option*) has_opt=yes; break;; \ esac; \ done; \ test $$has_opt = yes am__make_dryrun = (target_option=n; $(am__make_running_with_option)) am__make_keepgoing = (target_option=k; $(am__make_running_with_option)) pkgdatadir = $(datadir)/@PACKAGE@ pkgincludedir = $(includedir)/@PACKAGE@ pkglibdir = $(libdir)/@PACKAGE@ pkglibexecdir = $(libexecdir)/@PACKAGE@ am__cd = CDPATH="$${ZSH_VERSION+.}$(PATH_SEPARATOR)" && cd install_sh_DATA = $(install_sh) -c -m 644 install_sh_PROGRAM = $(install_sh) -c install_sh_SCRIPT = $(install_sh) -c INSTALL_HEADER = $(INSTALL_DATA) transform = $(program_transform_name) NORMAL_INSTALL = : PRE_INSTALL = : POST_INSTALL = : NORMAL_UNINSTALL = : PRE_UNINSTALL = : POST_UNINSTALL = : build_triplet = @build@ host_triplet = @host@ subdir = docs/man ACLOCAL_M4 = $(top_srcdir)/aclocal.m4 am__aclocal_m4_deps = $(top_srcdir)/m4/ax_append_compile_flags.m4 \ $(top_srcdir)/m4/ax_append_flag.m4 \ $(top_srcdir)/m4/ax_cflags_warn_all.m4 \ $(top_srcdir)/m4/ax_check_compile_flag.m4 \ $(top_srcdir)/m4/ax_gcc_func_attribute.m4 \ $(top_srcdir)/m4/ax_require_defined.m4 \ $(top_srcdir)/m4/ax_type_socklen_t.m4 \ $(top_srcdir)/m4/libtool.m4 $(top_srcdir)/m4/ltoptions.m4 \ $(top_srcdir)/m4/ltsugar.m4 $(top_srcdir)/m4/ltversion.m4 \ $(top_srcdir)/m4/lt~obsolete.m4 $(top_srcdir)/m4/pkg.m4 \ $(top_srcdir)/configure.ac am__configure_deps = $(am__aclocal_m4_deps) $(CONFIGURE_DEPENDENCIES) \ $(ACLOCAL_M4) DIST_COMMON = $(srcdir)/Makefile.am $(am__DIST_COMMON) mkinstalldirs = $(install_sh) -d CONFIG_HEADER = $(top_builddir)/config_ac.h CONFIG_CLEAN_FILES = CONFIG_CLEAN_VPATH_FILES = AM_V_P = $(am__v_P_@AM_V@) am__v_P_ = $(am__v_P_@AM_DEFAULT_V@) am__v_P_0 = false am__v_P_1 = : AM_V_GEN = $(am__v_GEN_@AM_V@) am__v_GEN_ = $(am__v_GEN_@AM_DEFAULT_V@) am__v_GEN_0 = @echo " GEN " $@; am__v_GEN_1 = AM_V_at = $(am__v_at_@AM_V@) am__v_at_ = $(am__v_at_@AM_DEFAULT_V@) am__v_at_0 = @ am__v_at_1 = SOURCES = DIST_SOURCES = am__can_run_installinfo = \ case $$AM_UPDATE_INFO_DIR in \ n|no|NO) false;; \ *) (install-info --version) >/dev/null 2>&1;; \ esac am__vpath_adj_setup = srcdirstrip=`echo "$(srcdir)" | sed 's|.|.|g'`; am__vpath_adj = case $$p in \ $(srcdir)/*) f=`echo "$$p" | sed "s|^$$srcdirstrip/||"`;; \ *) f=$$p;; \ esac; am__strip_dir = f=`echo $$p | sed -e 's|^.*/||'`; am__install_max = 40 am__nobase_strip_setup = \ srcdirstrip=`echo "$(srcdir)" | sed 's/[].[^$$\\*|]/\\\\&/g'` am__nobase_strip = \ for p in $$list; do echo "$$p"; done | sed -e "s|$$srcdirstrip/||" am__nobase_list = $(am__nobase_strip_setup); \ for p in $$list; do echo "$$p $$p"; done | \ sed "s| $$srcdirstrip/| |;"' / .*\//!s/ .*/ ./; s,\( .*\)/[^/]*$$,\1,' | \ $(AWK) 'BEGIN { files["."] = "" } { files[$$2] = files[$$2] " " $$1; \ if (++n[$$2] == $(am__install_max)) \ { print $$2, files[$$2]; n[$$2] = 0; files[$$2] = "" } } \ END { for (dir in files) print dir, files[dir] }' am__base_list = \ sed '$$!N;$$!N;$$!N;$$!N;$$!N;$$!N;$$!N;s/\n/ /g' | \ sed '$$!N;$$!N;$$!N;$$!N;s/\n/ /g' am__uninstall_files_from_dir = { \ test -z "$$files" \ || { test ! -d "$$dir" && test ! -f "$$dir" && test ! -r "$$dir"; } \ || { echo " ( cd '$$dir' && rm -f" $$files ")"; \ $(am__cd) "$$dir" && rm -f $$files; }; \ } man1dir = $(mandir)/man1 am__installdirs = "$(DESTDIR)$(man1dir)" "$(DESTDIR)$(man5dir)" \ "$(DESTDIR)$(man8dir)" man5dir = $(mandir)/man5 man8dir = $(mandir)/man8 NROFF = nroff MANS = $(man_MANS) am__tagged_files = $(HEADERS) $(SOURCES) $(TAGS_FILES) $(LISP) am__DIST_COMMON = $(srcdir)/Makefile.in DISTFILES = $(DIST_COMMON) $(DIST_SOURCES) $(TEXINFOS) $(EXTRA_DIST) ACLOCAL = @ACLOCAL@ AMTAR = @AMTAR@ AM_DEFAULT_VERBOSITY = @AM_DEFAULT_VERBOSITY@ AR = @AR@ AUTOCONF = @AUTOCONF@ AUTOHEADER = @AUTOHEADER@ AUTOMAKE = @AUTOMAKE@ AWK = @AWK@ CC = @CC@ CCDEPMODE = @CCDEPMODE@ CFLAGS = @CFLAGS@ CPP = @CPP@ CPPFLAGS = @CPPFLAGS@ CYGPATH_W = @CYGPATH_W@ DEFS = @DEFS@ DEPDIR = @DEPDIR@ DLLTOOL = @DLLTOOL@ DLOPEN_LIBS = @DLOPEN_LIBS@ DSYMUTIL = @DSYMUTIL@ DUMPBIN = @DUMPBIN@ ECHO_C = @ECHO_C@ ECHO_N = @ECHO_N@ ECHO_T = @ECHO_T@ EGREP = @EGREP@ EXEEXT = @EXEEXT@ FDKAAC_CFLAGS = @FDKAAC_CFLAGS@ FDKAAC_LIBS = @FDKAAC_LIBS@ FGREP = @FGREP@ FREERDP_CFLAGS = @FREERDP_CFLAGS@ FREERDP_LIBS = @FREERDP_LIBS@ FUSE_CFLAGS = @FUSE_CFLAGS@ FUSE_LIBS = @FUSE_LIBS@ GREP = @GREP@ INSTALL = @INSTALL@ INSTALL_DATA = @INSTALL_DATA@ INSTALL_PROGRAM = @INSTALL_PROGRAM@ INSTALL_SCRIPT = @INSTALL_SCRIPT@ INSTALL_STRIP_PROGRAM = @INSTALL_STRIP_PROGRAM@ LD = @LD@ LDFLAGS = @LDFLAGS@ LIBOBJS = @LIBOBJS@ LIBS = @LIBS@ LIBTOOL = @LIBTOOL@ LIPO = @LIPO@ LN_S = @LN_S@ LTLIBOBJS = @LTLIBOBJS@ LT_SYS_LIBRARY_PATH = @LT_SYS_LIBRARY_PATH@ MAKEINFO = @MAKEINFO@ MANIFEST_TOOL = @MANIFEST_TOOL@ MKDIR_P = @MKDIR_P@ NM = @NM@ NMEDIT = @NMEDIT@ OBJDUMP = @OBJDUMP@ OBJEXT = @OBJEXT@ OPENSSL = @OPENSSL@ OPENSSL_CFLAGS = @OPENSSL_CFLAGS@ OPENSSL_LIBS = @OPENSSL_LIBS@ OTOOL = @OTOOL@ OTOOL64 = @OTOOL64@ PACKAGE = @PACKAGE@ PACKAGE_BUGREPORT = @PACKAGE_BUGREPORT@ PACKAGE_NAME = @PACKAGE_NAME@ PACKAGE_STRING = @PACKAGE_STRING@ PACKAGE_TARNAME = @PACKAGE_TARNAME@ PACKAGE_URL = @PACKAGE_URL@ PACKAGE_VERSION = @PACKAGE_VERSION@ PAM_RULES = @PAM_RULES@ PATH_SEPARATOR = @PATH_SEPARATOR@ PIXMAN_CFLAGS = @PIXMAN_CFLAGS@ PIXMAN_LIBS = @PIXMAN_LIBS@ PKG_CONFIG = @PKG_CONFIG@ PKG_CONFIG_LIBDIR = @PKG_CONFIG_LIBDIR@ PKG_CONFIG_PATH = @PKG_CONFIG_PATH@ RANLIB = @RANLIB@ SED = @SED@ SET_MAKE = @SET_MAKE@ SHELL = @SHELL@ STRIP = @STRIP@ TurboJpegIncDir = @TurboJpegIncDir@ TurboJpegLibDir = @TurboJpegLibDir@ VERSION = @VERSION@ XMKMF = @XMKMF@ X_CFLAGS = @X_CFLAGS@ X_EXTRA_LIBS = @X_EXTRA_LIBS@ X_LIBS = @X_LIBS@ X_PRE_LIBS = @X_PRE_LIBS@ abs_builddir = @abs_builddir@ abs_srcdir = @abs_srcdir@ abs_top_builddir = @abs_top_builddir@ abs_top_srcdir = @abs_top_srcdir@ ac_ct_AR = @ac_ct_AR@ ac_ct_CC = @ac_ct_CC@ ac_ct_DUMPBIN = @ac_ct_DUMPBIN@ am__include = @am__include@ am__leading_dot = @am__leading_dot@ am__quote = @am__quote@ am__tar = @am__tar@ am__untar = @am__untar@ bindir = @bindir@ build = @build@ build_alias = @build_alias@ build_cpu = @build_cpu@ build_os = @build_os@ build_vendor = @build_vendor@ builddir = @builddir@ datadir = @datadir@ datarootdir = @datarootdir@ docdir = @docdir@ dvidir = @dvidir@ exec_prefix = @exec_prefix@ host = @host@ host_alias = @host_alias@ host_cpu = @host_cpu@ host_os = @host_os@ host_vendor = @host_vendor@ htmldir = @htmldir@ includedir = @includedir@ infodir = @infodir@ install_sh = @install_sh@ libdir = @libdir@ libexecdir = @libexecdir@ localedir = @localedir@ localstatedir = @localstatedir@ mandir = @mandir@ mkdir_p = @mkdir_p@ moduledir = @moduledir@ oldincludedir = @oldincludedir@ pdfdir = @pdfdir@ pkgconfigdir = @pkgconfigdir@ prefix = @prefix@ program_transform_name = @program_transform_name@ psdir = @psdir@ sbindir = @sbindir@ sharedstatedir = @sharedstatedir@ socketdir = @socketdir@ srcdir = @srcdir@ subdirs = @subdirs@ sysconfdir = @sysconfdir@ systemdsystemunitdir = @systemdsystemunitdir@ target_alias = @target_alias@ top_build_prefix = @top_build_prefix@ top_builddir = @top_builddir@ top_srcdir = @top_srcdir@ man_MANS = \ xrdp-dis.1 \ sesman.ini.5 \ xrdp.ini.5 \ xrdp.8 \ xrdp-chansrv.8 \ xrdp-genkeymap.8 \ xrdp-keygen.8 \ xrdp-sesadmin.8 \ xrdp-sesman.8 \ xrdp-sesrun.8 EXTRA_DIST = $(man_MANS:=.in) SUBST_VARS = sed \ -e 's|@PACKAGE_VERSION[@]|$(PACKAGE_VERSION)|g' \ -e 's|@bindir[@]|$(bindir)|g' \ -e 's|@localstatedir[@]|$(localstatedir)|g' \ -e 's|@sysconfdir[@]|$(sysconfdir)|g' \ -e 's|@socketdir[@]|$(socketdir)|g' subst_verbose = $(subst_verbose_@AM_V@) subst_verbose_ = $(subst_verbose_@AM_DEFAULT_V@) subst_verbose_0 = @echo " SUBST $@"; SUFFIXES = .in CLEANFILES = $(man_MANS) all: all-am .SUFFIXES: .SUFFIXES: .in $(srcdir)/Makefile.in: $(srcdir)/Makefile.am $(am__configure_deps) @for dep in $?; do \ case '$(am__configure_deps)' in \ *$$dep*) \ ( cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh ) \ && { if test -f $@; then exit 0; else break; fi; }; \ exit 1;; \ esac; \ done; \ echo ' cd $(top_srcdir) && $(AUTOMAKE) --foreign docs/man/Makefile'; \ $(am__cd) $(top_srcdir) && \ $(AUTOMAKE) --foreign docs/man/Makefile Makefile: $(srcdir)/Makefile.in $(top_builddir)/config.status @case '$?' in \ *config.status*) \ cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh;; \ *) \ echo ' cd $(top_builddir) && $(SHELL) ./config.status $(subdir)/$@ $(am__depfiles_maybe)'; \ cd $(top_builddir) && $(SHELL) ./config.status $(subdir)/$@ $(am__depfiles_maybe);; \ esac; $(top_builddir)/config.status: $(top_srcdir)/configure $(CONFIG_STATUS_DEPENDENCIES) cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh $(top_srcdir)/configure: $(am__configure_deps) cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh $(ACLOCAL_M4): $(am__aclocal_m4_deps) cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh $(am__aclocal_m4_deps): mostlyclean-libtool: -rm -f *.lo clean-libtool: -rm -rf .libs _libs install-man1: $(man_MANS) @$(NORMAL_INSTALL) @list1=''; \ list2='$(man_MANS)'; \ test -n "$(man1dir)" \ && test -n "`echo $$list1$$list2`" \ || exit 0; \ echo " $(MKDIR_P) '$(DESTDIR)$(man1dir)'"; \ $(MKDIR_P) "$(DESTDIR)$(man1dir)" || exit 1; \ { for i in $$list1; do echo "$$i"; done; \ if test -n "$$list2"; then \ for i in $$list2; do echo "$$i"; done \ | sed -n '/\.1[a-z]*$$/p'; \ fi; \ } | while read p; do \ if test -f $$p; then d=; else d="$(srcdir)/"; fi; \ echo "$$d$$p"; echo "$$p"; \ done | \ sed -e 'n;s,.*/,,;p;h;s,.*\.,,;s,^[^1][0-9a-z]*$$,1,;x' \ -e 's,\.[0-9a-z]*$$,,;$(transform);G;s,\n,.,' | \ sed 'N;N;s,\n, ,g' | { \ list=; while read file base inst; do \ if test "$$base" = "$$inst"; then list="$$list $$file"; else \ echo " $(INSTALL_DATA) '$$file' '$(DESTDIR)$(man1dir)/$$inst'"; \ $(INSTALL_DATA) "$$file" "$(DESTDIR)$(man1dir)/$$inst" || exit $$?; \ fi; \ done; \ for i in $$list; do echo "$$i"; done | $(am__base_list) | \ while read files; do \ test -z "$$files" || { \ echo " $(INSTALL_DATA) $$files '$(DESTDIR)$(man1dir)'"; \ $(INSTALL_DATA) $$files "$(DESTDIR)$(man1dir)" || exit $$?; }; \ done; } uninstall-man1: @$(NORMAL_UNINSTALL) @list=''; test -n "$(man1dir)" || exit 0; \ files=`{ for i in $$list; do echo "$$i"; done; \ l2='$(man_MANS)'; for i in $$l2; do echo "$$i"; done | \ sed -n '/\.1[a-z]*$$/p'; \ } | sed -e 's,.*/,,;h;s,.*\.,,;s,^[^1][0-9a-z]*$$,1,;x' \ -e 's,\.[0-9a-z]*$$,,;$(transform);G;s,\n,.,'`; \ dir='$(DESTDIR)$(man1dir)'; $(am__uninstall_files_from_dir) install-man5: $(man_MANS) @$(NORMAL_INSTALL) @list1=''; \ list2='$(man_MANS)'; \ test -n "$(man5dir)" \ && test -n "`echo $$list1$$list2`" \ || exit 0; \ echo " $(MKDIR_P) '$(DESTDIR)$(man5dir)'"; \ $(MKDIR_P) "$(DESTDIR)$(man5dir)" || exit 1; \ { for i in $$list1; do echo "$$i"; done; \ if test -n "$$list2"; then \ for i in $$list2; do echo "$$i"; done \ | sed -n '/\.5[a-z]*$$/p'; \ fi; \ } | while read p; do \ if test -f $$p; then d=; else d="$(srcdir)/"; fi; \ echo "$$d$$p"; echo "$$p"; \ done | \ sed -e 'n;s,.*/,,;p;h;s,.*\.,,;s,^[^5][0-9a-z]*$$,5,;x' \ -e 's,\.[0-9a-z]*$$,,;$(transform);G;s,\n,.,' | \ sed 'N;N;s,\n, ,g' | { \ list=; while read file base inst; do \ if test "$$base" = "$$inst"; then list="$$list $$file"; else \ echo " $(INSTALL_DATA) '$$file' '$(DESTDIR)$(man5dir)/$$inst'"; \ $(INSTALL_DATA) "$$file" "$(DESTDIR)$(man5dir)/$$inst" || exit $$?; \ fi; \ done; \ for i in $$list; do echo "$$i"; done | $(am__base_list) | \ while read files; do \ test -z "$$files" || { \ echo " $(INSTALL_DATA) $$files '$(DESTDIR)$(man5dir)'"; \ $(INSTALL_DATA) $$files "$(DESTDIR)$(man5dir)" || exit $$?; }; \ done; } uninstall-man5: @$(NORMAL_UNINSTALL) @list=''; test -n "$(man5dir)" || exit 0; \ files=`{ for i in $$list; do echo "$$i"; done; \ l2='$(man_MANS)'; for i in $$l2; do echo "$$i"; done | \ sed -n '/\.5[a-z]*$$/p'; \ } | sed -e 's,.*/,,;h;s,.*\.,,;s,^[^5][0-9a-z]*$$,5,;x' \ -e 's,\.[0-9a-z]*$$,,;$(transform);G;s,\n,.,'`; \ dir='$(DESTDIR)$(man5dir)'; $(am__uninstall_files_from_dir) install-man8: $(man_MANS) @$(NORMAL_INSTALL) @list1=''; \ list2='$(man_MANS)'; \ test -n "$(man8dir)" \ && test -n "`echo $$list1$$list2`" \ || exit 0; \ echo " $(MKDIR_P) '$(DESTDIR)$(man8dir)'"; \ $(MKDIR_P) "$(DESTDIR)$(man8dir)" || exit 1; \ { for i in $$list1; do echo "$$i"; done; \ if test -n "$$list2"; then \ for i in $$list2; do echo "$$i"; done \ | sed -n '/\.8[a-z]*$$/p'; \ fi; \ } | while read p; do \ if test -f $$p; then d=; else d="$(srcdir)/"; fi; \ echo "$$d$$p"; echo "$$p"; \ done | \ sed -e 'n;s,.*/,,;p;h;s,.*\.,,;s,^[^8][0-9a-z]*$$,8,;x' \ -e 's,\.[0-9a-z]*$$,,;$(transform);G;s,\n,.,' | \ sed 'N;N;s,\n, ,g' | { \ list=; while read file base inst; do \ if test "$$base" = "$$inst"; then list="$$list $$file"; else \ echo " $(INSTALL_DATA) '$$file' '$(DESTDIR)$(man8dir)/$$inst'"; \ $(INSTALL_DATA) "$$file" "$(DESTDIR)$(man8dir)/$$inst" || exit $$?; \ fi; \ done; \ for i in $$list; do echo "$$i"; done | $(am__base_list) | \ while read files; do \ test -z "$$files" || { \ echo " $(INSTALL_DATA) $$files '$(DESTDIR)$(man8dir)'"; \ $(INSTALL_DATA) $$files "$(DESTDIR)$(man8dir)" || exit $$?; }; \ done; } uninstall-man8: @$(NORMAL_UNINSTALL) @list=''; test -n "$(man8dir)" || exit 0; \ files=`{ for i in $$list; do echo "$$i"; done; \ l2='$(man_MANS)'; for i in $$l2; do echo "$$i"; done | \ sed -n '/\.8[a-z]*$$/p'; \ } | sed -e 's,.*/,,;h;s,.*\.,,;s,^[^8][0-9a-z]*$$,8,;x' \ -e 's,\.[0-9a-z]*$$,,;$(transform);G;s,\n,.,'`; \ dir='$(DESTDIR)$(man8dir)'; $(am__uninstall_files_from_dir) tags TAGS: ctags CTAGS: cscope cscopelist: distdir: $(DISTFILES) @srcdirstrip=`echo "$(srcdir)" | sed 's/[].[^$$\\*]/\\\\&/g'`; \ topsrcdirstrip=`echo "$(top_srcdir)" | sed 's/[].[^$$\\*]/\\\\&/g'`; \ list='$(DISTFILES)'; \ dist_files=`for file in $$list; do echo $$file; done | \ sed -e "s|^$$srcdirstrip/||;t" \ -e "s|^$$topsrcdirstrip/|$(top_builddir)/|;t"`; \ case $$dist_files in \ */*) $(MKDIR_P) `echo "$$dist_files" | \ sed '/\//!d;s|^|$(distdir)/|;s,/[^/]*$$,,' | \ sort -u` ;; \ esac; \ for file in $$dist_files; do \ if test -f $$file || test -d $$file; then d=.; else d=$(srcdir); fi; \ if test -d $$d/$$file; then \ dir=`echo "/$$file" | sed -e 's,/[^/]*$$,,'`; \ if test -d "$(distdir)/$$file"; then \ find "$(distdir)/$$file" -type d ! -perm -700 -exec chmod u+rwx {} \;; \ fi; \ if test -d $(srcdir)/$$file && test $$d != $(srcdir); then \ cp -fpR $(srcdir)/$$file "$(distdir)$$dir" || exit 1; \ find "$(distdir)/$$file" -type d ! -perm -700 -exec chmod u+rwx {} \;; \ fi; \ cp -fpR $$d/$$file "$(distdir)$$dir" || exit 1; \ else \ test -f "$(distdir)/$$file" \ || cp -p $$d/$$file "$(distdir)/$$file" \ || exit 1; \ fi; \ done check-am: all-am check: check-am all-am: Makefile $(MANS) installdirs: for dir in "$(DESTDIR)$(man1dir)" "$(DESTDIR)$(man5dir)" "$(DESTDIR)$(man8dir)"; do \ test -z "$$dir" || $(MKDIR_P) "$$dir"; \ done install: install-am install-exec: install-exec-am install-data: install-data-am uninstall: uninstall-am install-am: all-am @$(MAKE) $(AM_MAKEFLAGS) install-exec-am install-data-am installcheck: installcheck-am install-strip: if test -z '$(STRIP)'; then \ $(MAKE) $(AM_MAKEFLAGS) INSTALL_PROGRAM="$(INSTALL_STRIP_PROGRAM)" \ install_sh_PROGRAM="$(INSTALL_STRIP_PROGRAM)" INSTALL_STRIP_FLAG=-s \ install; \ else \ $(MAKE) $(AM_MAKEFLAGS) INSTALL_PROGRAM="$(INSTALL_STRIP_PROGRAM)" \ install_sh_PROGRAM="$(INSTALL_STRIP_PROGRAM)" INSTALL_STRIP_FLAG=-s \ "INSTALL_PROGRAM_ENV=STRIPPROG='$(STRIP)'" install; \ fi mostlyclean-generic: clean-generic: -test -z "$(CLEANFILES)" || rm -f $(CLEANFILES) distclean-generic: -test -z "$(CONFIG_CLEAN_FILES)" || rm -f $(CONFIG_CLEAN_FILES) -test . = "$(srcdir)" || test -z "$(CONFIG_CLEAN_VPATH_FILES)" || rm -f $(CONFIG_CLEAN_VPATH_FILES) maintainer-clean-generic: @echo "This command is intended for maintainers to use" @echo "it deletes files that may require special tools to rebuild." clean: clean-am clean-am: clean-generic clean-libtool mostlyclean-am distclean: distclean-am -rm -f Makefile distclean-am: clean-am distclean-generic dvi: dvi-am dvi-am: html: html-am html-am: info: info-am info-am: install-data-am: install-man install-dvi: install-dvi-am install-dvi-am: install-exec-am: install-html: install-html-am install-html-am: install-info: install-info-am install-info-am: install-man: install-man1 install-man5 install-man8 install-pdf: install-pdf-am install-pdf-am: install-ps: install-ps-am install-ps-am: installcheck-am: maintainer-clean: maintainer-clean-am -rm -f Makefile maintainer-clean-am: distclean-am maintainer-clean-generic mostlyclean: mostlyclean-am mostlyclean-am: mostlyclean-generic mostlyclean-libtool pdf: pdf-am pdf-am: ps: ps-am ps-am: uninstall-am: uninstall-man uninstall-man: uninstall-man1 uninstall-man5 uninstall-man8 .MAKE: install-am install-strip .PHONY: all all-am check check-am clean clean-generic clean-libtool \ cscopelist-am ctags-am distclean distclean-generic \ distclean-libtool distdir dvi dvi-am html html-am info info-am \ install install-am install-data install-data-am install-dvi \ install-dvi-am install-exec install-exec-am install-html \ install-html-am install-info install-info-am install-man \ install-man1 install-man5 install-man8 install-pdf \ install-pdf-am install-ps install-ps-am install-strip \ installcheck installcheck-am installdirs maintainer-clean \ maintainer-clean-generic mostlyclean mostlyclean-generic \ mostlyclean-libtool pdf pdf-am ps ps-am tags-am uninstall \ uninstall-am uninstall-man uninstall-man1 uninstall-man5 \ uninstall-man8 .PRECIOUS: Makefile .in: $(subst_verbose)$(SUBST_VARS) $< > $@ # Tell versions [3.59,3.63) of GNU make to not export all variables. # Otherwise a system limit (for SysV at least) may be exceeded. .NOEXPORT: xrdp-0.9.5/docs/man/xrdp-dis.1.in000644 001751 001751 00000001037 13174271344 016355 0ustar00metameta000000 000000 .TH "xrdp-dis" "1" "@PACKAGE_VERSION@" "xrdp team" .SH NAME xrdp\-dis \- xrdp disconnect utility .SH SYNOPSIS .B xrdp\-dis .SH DESCRIPTION .PP \fBxrdp\-dis\fP is run with no parameters to disconnect your xrdp session. .SH ENVIRONMENT .TP .B DISPLAY to get the default host and display number. .SH FILES .TP .I @socketdir@/xrdp_disconnect_display_* UNIX socket used to communicate with the \fBxrdp\fP(8) session manager. .SH KNOWN ISSUES .TP This utility doesn't support disconnecting xorgxrdp sessions so far. .SH SEE ALSO .BR xrdp (8). xrdp-0.9.5/docs/man/sesman.ini.5.in000644 001751 001751 00000014507 13174271344 016701 0ustar00metameta000000 000000 .\" .TH "sesman.ini" "5" "@PACKAGE_VERSION@" "xrdp team" "" .SH "NAME" \fBsesman.ini\fR \- Configuration file for \fBxrdp-sesman\fR(8) .SH "DESCRIPTION" \fBsesman.ini\fR consists of several sections. Each section starts with the section name in square brackets, followed by a list of \fIparameter\fR=\fIvalue\fR lines. Following sections are recognized: .TP \fB[Globals]\fR Global configuration .TP \fB[Logging]\fR Logging subsystem .TP \fB[Sessions]\fR Session management .TP \fB[Security]\fR Access control .TP \fB[X11rdp]\fR, \fB[Xvnc]\fR, \fB[Xorg]\fR X11 server settings for supported servers .TP \fB[Chansrv]\fR Settings for xrdp-chansrv(8) .TP \fB[SessionVariables]\fR Environment variables for the session .LP All parameters and values (except for file names and paths) are case insensitive, and are described in detail below. If any parameter is specified more than once, the last entry will be used. Options specified outside their proper section will be \fIignored\fR. .SH "GLOBALS" Following parameters can be used in the \fB[Globals]\fR section. .TP \fBListenAddress\fR=\fIip address\fR xrdp-sesman listening address. If not specified, defaults to \fI0.0.0.0\fR (all interfaces). .TP \fBListenPort\fR=\fIport number\fR xrdp-sesman listening port. If not specified, defaults to \fI3350\fR. .TP \fBEnableUserWindowManager\fR=\fI[true|false]\fR If set to \fB1\fR, \fBtrue\fR or \fByes\fR, this option enables user specific startup script. That is, xrdp-sesman will execute the script specified by \fBUserWindowManager\fR if it exists. .TP \fBUserWindowManager\fR=\fIfilename\fR Name of the startup script relative to the user's home directory. If present and enabled by \fBEnableUserWindowManager\fR, that script is executed instead of \fBDefaultWindowManager\fR. .TP \fBDefaultWindowManager\fR=\fIfilename\fR Full path to the default startup script used by xrdp-sesman to start a session if the user script is disabled or missing. .SH "LOGGING" Following parameters can be used in the \fB[Logging]\fR section. .TP \fBLogFile\fR=\fIfilename\fR Log file path. It can be either absolute or relative. If not specified, defaults to \fI./sesman.log\fR .TP \fBLogLevel\fR=\fIlevel\fR This option can have one of the following values: \fBCORE\fR or \fB0\fR \- Log only core messages. Those messages are logged \fIregardless\fR of the selected logging level. \fBERROR\fR or \fB1\fR \- Log only error messages. \fBWARNING\fR, \fBWARN\fR or \fB2\fR \- Logs warnings and error messages. \fBINFO\fR or \fB3\fR \- Log errors, warnings and informational messages. \fBDEBUG\fR or \fB4\fR \- Log everything. If xrdp-sesman is compiled in debug mode, this options will output many more low\-level messages. .TP \fBEnableSyslog\fR=\fI[true|false]\fR If set to \fB1\fR, \fBtrue\fR or \fByes\fR, this option enables logging to syslog. .TP \fBSyslogLevel\fR=\fIlevel\fR Logging level for syslog. It can have the same values as \fBLogLevel\fR. If \fBSyslogLevel\fR and \fBLogLevel\fR differ, the least verbose setting takes effect for syslog. .SH "SESSIONS" Following parameters can be used in the \fB[Sessions]\fR section. .TP \fBX11DisplayOffset\fR=\fInumber\fR The first X display number available for xrdp-sesman. This prevents xrdp-sesman from interfering with real X11 servers. If not specified, defaults to \fI10\fR. .TP \fBMaxSessions\fR=\fInumber\fR Sets the maximum number of simultaneous sessions. If not set or set to \fI0\fR, unlimited session are allowed. .TP \fBKillDisconnected\fR=\fI[true|false]\fR If set to \fB1\fR, \fBtrue\fR or \fByes\fR, every session will be killed within 60 seconds after the user disconnects. .TP \fBDisconnectedTimeLimit\fR=\fInumber\fR Sets the time limit (in seconds) before a disconnected session is killed. If set to \fI0\fR, automatic killing is disabled. .TP \fBPolicy\fR=\fI[Default|UBD|UBI|UBC|UBDI|UBDC]\fR Session allocation policy. By default, a new session is created for the combination when using Xrdp, and for the combination when using Xvnc. This behavior can be changed by setting session policy to: .br .br \fBUBD\fR - session per .br \fBUBI\fR - session per .br \fBUBC\fR - session per .br \fBUBDI\fR - session per .br \fBUBDC\fR - session per .br .br Note that the \fBUser\fR and \fBBitPerPixel\fR criteria cannot be turned off. For Xvnc connections, \fBDisplaySize\fR is always enabled as well. .br .SH "SECURITY" Following parameters can be used in the \fB[Security]\fR section. .TP \fBAllowRootLogin\fR=\fI[true|false]\fR If set to \fB1\fR, \fBtrue\fR or \fByes\fR, enables root login on the terminal server. .TP \fBMaxLoginRetry\fR=\fInumber\fR The number of login attempts that are allowed on terminal server. If set to \fI0\fR, unlimited attempts are allowed. If not specified, defaults to \fI3\fR. .TP \fBTerminalServerUsers\fR=\fIgroup\fR Only the users belonging to the specified group are allowed to login on terminal server. If unset or set to an invalid or non\-existent group, login for all users is enabled. .TP \fBTerminalServerAdmins\fR=\fIgroup\fR \fIThis option is currently ignored!\fR Only members of this group can have session management rights. .TP \fBAlwaysGroupCheck\fR=\fI[true|false]\fR If set to \fB1\fR, \fBtrue\fR or \fByes\fR, require group membership even if the group specified in \fBTerminalServerUsers\fR doesn't exist. .SH "X11 SERVER" Following parameters can be used in the \fB[X11rdp]\fR, \fB[Xvnc]\fR and \fB[Xorg]\fR sections. .TP \fBparam\fR=\fIstring\fR Multiple \fIparam\fR lines are supported. This first line specifies the path to the X11 server executable. Following lines specify command line arguments passed to the X11 server. .SH "CHANSRV" Following parameters can be used in the \fB[Chansrv]\fR section. .TP \fBFuseMountName\fR=\fIstring\fR Directory for drive redirection, relative to the user home directory. Created if it doesn't exist. If not specified, defaults to \fIxrdp_client\fR. .SH "SESSIONS VARIABLES" All entries in the \fB[SessionVariables]\fR section are set as environment variables in the user's session. .SH "FILES" @sysconfdir@/xrdp/sesman.ini .SH "SEE ALSO" .BR xrdp-sesman (8), .BR xrdp-sesrun (8), .BR xrdp (8), .BR xrdp.ini (5) For more info on \fBxrdp\fR see http://www.xrdp.org/ xrdp-0.9.5/docs/man/Makefile.am000644 001751 001751 00000001236 13174271344 016171 0ustar00metameta000000 000000 man_MANS = \ xrdp-dis.1 \ sesman.ini.5 \ xrdp.ini.5 \ xrdp.8 \ xrdp-chansrv.8 \ xrdp-genkeymap.8 \ xrdp-keygen.8 \ xrdp-sesadmin.8 \ xrdp-sesman.8 \ xrdp-sesrun.8 EXTRA_DIST = $(man_MANS:=.in) SUBST_VARS = sed \ -e 's|@PACKAGE_VERSION[@]|$(PACKAGE_VERSION)|g' \ -e 's|@bindir[@]|$(bindir)|g' \ -e 's|@localstatedir[@]|$(localstatedir)|g' \ -e 's|@sysconfdir[@]|$(sysconfdir)|g' \ -e 's|@socketdir[@]|$(socketdir)|g' subst_verbose = $(subst_verbose_@AM_V@) subst_verbose_ = $(subst_verbose_@AM_DEFAULT_V@) subst_verbose_0 = @echo " SUBST $@"; SUFFIXES = .in .in: $(subst_verbose)$(SUBST_VARS) $< > $@ CLEANFILES = $(man_MANS) xrdp-0.9.5/docs/man/xrdp.8.in000644 001751 001751 00000002454 13133557325 015614 0ustar00metameta000000 000000 .TH "xrdp" "8" "@PACKAGE_VERSION@" "xrdp team" "" .SH "NAME" \fBxrdp\fR \- a Remote Desktop Protocol (RDP) server .SH "SYNTAX" xrdp [ \-\-nodaemon | \-\-kill | \-\-help ] .SH "DESCRIPTION" \fBxrdp\fR is a Remote Desktop Protocol (RDP) Server. .br Unlike Windows NT/2000/2003 server, \fBxrdp\fR will not display a Windows desktop but an X window desktop to the user. It can also be used as a VNC\->RDP bridge. .SH "OPTIONS" .TP \fB\-n\fR, \fB\-\-nodaemon\fR Start \fBxrdp\fR in foreground instead of starting it as a daemon. .TP \fB\-k\fR, \fB\-\-kill\fR Kill running \fBxrdp\fR daemon. .TP \fB\-h\fR, \fB\-\-help\fR Output help information and exit. .TP \fB\-p\fR, \fB\-\-port\fR Specify TCP port to listen to. This overrides \fIport\fR setting in \fIxrdp.ini\fR file. .TP \fB\-f\fR, \fB\-\-fork\fR Fork a new process on a new connection. If not enabled, use a new thread for every connection. This overrides \fIfork\fR setting in \fIxrdp.ini\fR file. .SH "FILES" @bindir@/xrdp .br @sysconfdir@/xrdp/xrdp.ini .br @localstatedir@/log/xrdp.log .br @localstatedir@/run/xrdp.pid .SH "AUTHORS" Jay Sorg .br Simone Fedele .SH "SEE ALSO" .BR xrdp.ini (5), .BR sesman (8), .BR sesman.ini (5), .BR sesrun (8) for more info on \fBxrdp\fR see http://www.xrdp.org/ xrdp-0.9.5/mc/mc.h000644 001751 001751 00000010346 13133557325 013604 0ustar00metameta000000 000000 /** * xrdp: A Remote Desktop Protocol server. * * Copyright (C) Jay Sorg 2004-2013 * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. * * media center */ /* include other h files */ #include "arch.h" #include "parse.h" #include "os_calls.h" #include "defines.h" #define CURRENT_MOD_VER 3 struct mod { int size; /* size of this struct */ int version; /* internal version */ /* client functions */ int (*mod_start)(struct mod* v, int w, int h, int bpp); int (*mod_connect)(struct mod* v); int (*mod_event)(struct mod* v, int msg, long param1, long param2, long param3, long param4); int (*mod_signal)(struct mod* v); int (*mod_end)(struct mod* v); int (*mod_set_param)(struct mod *v, const char *name, const char *value); int (*mod_session_change)(struct mod* v, int, int); int (*mod_get_wait_objs)(struct mod* v, tbus* read_objs, int* rcount, tbus* write_objs, int* wcount, int* timeout); int (*mod_check_wait_objs)(struct mod* v); tintptr mod_dumby[100 - 9]; /* align, 100 minus the number of mod functions above */ /* server functions */ int (*server_begin_update)(struct mod* v); int (*server_end_update)(struct mod* v); int (*server_fill_rect)(struct mod* v, int x, int y, int cx, int cy); int (*server_screen_blt)(struct mod* v, int x, int y, int cx, int cy, int srcx, int srcy); int (*server_paint_rect)(struct mod* v, int x, int y, int cx, int cy, char* data, int width, int height, int srcx, int srcy); int (*server_set_cursor)(struct mod* v, int x, int y, char* data, char* mask); int (*server_palette)(struct mod* v, int* palette); int (*server_msg)(struct mod* v, char* msg, int code); int (*server_is_term)(struct mod* v); int (*server_set_clip)(struct mod* v, int x, int y, int cx, int cy); int (*server_reset_clip)(struct mod* v); int (*server_set_fgcolor)(struct mod* v, int fgcolor); int (*server_set_bgcolor)(struct mod* v, int bgcolor); int (*server_set_opcode)(struct mod* v, int opcode); int (*server_set_mixmode)(struct mod* v, int mixmode); int (*server_set_brush)(struct mod* v, int x_origin, int y_origin, int style, char* pattern); int (*server_set_pen)(struct mod* v, int style, int width); int (*server_draw_line)(struct mod* v, int x1, int y1, int x2, int y2); int (*server_add_char)(struct mod* v, int font, int character, int offset, int baseline, int width, int height, char* data); int (*server_draw_text)(struct mod* v, int font, int flags, int mixmode, int clip_left, int clip_top, int clip_right, int clip_bottom, int box_left, int box_top, int box_right, int box_bottom, int x, int y, char* data, int data_len); int (*server_reset)(struct mod* v, int width, int height, int bpp); int (*server_query_channel)(struct mod* v, int index, char* channel_name, int* channel_flags); int (*server_get_channel_id)(struct mod* v, const char *name); int (*server_send_to_channel)(struct mod* v, int channel_id, char* data, int data_len, int total_data_len, int flags); int (*server_bell_trigger)(struct mod* v); tintptr server_dumby[100 - 25]; /* align, 100 minus the number of server functions above */ /* common */ tintptr handle; /* pointer to self as long */ tintptr wm; tintptr painter; tintptr si; /* mod data */ int sck; int width; int height; int bpp; }; xrdp-0.9.5/mc/Makefile.am000644 001751 001751 00000000657 13133557325 015074 0ustar00metameta000000 000000 AM_CPPFLAGS = \ -DXRDP_CFG_PATH=\"${sysconfdir}/xrdp\" \ -DXRDP_SBIN_PATH=\"${sbindir}\" \ -DXRDP_SHARE_PATH=\"${datadir}/xrdp\" \ -DXRDP_PID_PATH=\"${localstatedir}/run\" \ -I$(top_srcdir)/common if XRDP_DEBUG AM_CPPFLAGS += -DXRDP_DEBUG endif module_LTLIBRARIES = \ libmc.la libmc_la_SOURCES = \ mc.c \ mc.h libmc_la_LIBADD = \ $(top_builddir)/common/libcommon.la libmc_la_LDFLAGS = -avoid-version -module xrdp-0.9.5/mc/mc.c000644 001751 001751 00000005672 13174271344 013604 0ustar00metameta000000 000000 /** * xrdp: A Remote Desktop Protocol server. * * Copyright (C) Jay Sorg 2004-2013 * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. * * media center */ #if defined(HAVE_CONFIG_H) #include #endif #include "mc.h" /*****************************************************************************/ /* return error */ int lib_mod_start(struct mod *mod, int w, int h, int bpp) { LIB_DEBUG(mod, "in lib_mod_start"); mod->width = w; mod->height = h; mod->bpp = bpp; LIB_DEBUG(mod, "out lib_mod_start"); return 0; } /******************************************************************************/ /* return error */ int lib_mod_connect(struct mod *mod) { LIB_DEBUG(mod, "in lib_mod_connect"); LIB_DEBUG(mod, "out lib_mod_connect"); return 0; } /******************************************************************************/ /* return error */ int lib_mod_event(struct mod *mod, int msg, long param1, long param2, long param3, long param4) { LIB_DEBUG(mod, "in lib_mod_event"); LIB_DEBUG(mod, "out lib_mod_event"); return 0; } /******************************************************************************/ /* return error */ int lib_mod_signal(struct mod *mod) { LIB_DEBUG(mod, "in lib_mod_signal"); LIB_DEBUG(mod, "out lib_mod_signal"); return 0; } /******************************************************************************/ /* return error */ int lib_mod_end(struct mod *mod) { return 0; } /******************************************************************************/ /* return error */ int lib_mod_set_param(struct mod *mod, const char *name, const char *value) { return 0; } /******************************************************************************/ tintptr EXPORT_CC mod_init(void) { struct mod *mod; mod = (struct mod *)g_malloc(sizeof(struct mod), 1); mod->size = sizeof(struct mod); mod->version = CURRENT_MOD_VER; mod->handle = (tintptr) mod; mod->mod_connect = lib_mod_connect; mod->mod_start = lib_mod_start; mod->mod_event = lib_mod_event; mod->mod_signal = lib_mod_signal; mod->mod_end = lib_mod_end; mod->mod_set_param = lib_mod_set_param; return (tintptr) mod; } /******************************************************************************/ int EXPORT_CC mod_exit(tintptr handle) { struct mod *mod = (struct mod *) handle; if (mod == 0) { return 0; } g_free(mod); return 0; } xrdp-0.9.5/mc/Makefile.in000644 001751 001751 00000052041 13220730774 015075 0ustar00metameta000000 000000 # Makefile.in generated by automake 1.15.1 from Makefile.am. # @configure_input@ # Copyright (C) 1994-2017 Free Software Foundation, Inc. # This Makefile.in is free software; the Free Software Foundation # gives unlimited permission to copy and/or distribute it, # with or without modifications, as long as this notice is preserved. # This program is distributed in the hope that it will be useful, # but WITHOUT ANY WARRANTY, to the extent permitted by law; without # even the implied warranty of MERCHANTABILITY or FITNESS FOR A # PARTICULAR PURPOSE. @SET_MAKE@ VPATH = @srcdir@ am__is_gnu_make = { \ if test -z '$(MAKELEVEL)'; then \ false; \ elif test -n '$(MAKE_HOST)'; then \ true; \ elif test -n '$(MAKE_VERSION)' && test -n '$(CURDIR)'; then \ true; \ else \ false; \ fi; \ } am__make_running_with_option = \ case $${target_option-} in \ ?) ;; \ *) echo "am__make_running_with_option: internal error: invalid" \ "target option '$${target_option-}' specified" >&2; \ exit 1;; \ esac; \ has_opt=no; \ sane_makeflags=$$MAKEFLAGS; \ if $(am__is_gnu_make); then \ sane_makeflags=$$MFLAGS; \ else \ case $$MAKEFLAGS in \ *\\[\ \ ]*) \ bs=\\; \ sane_makeflags=`printf '%s\n' "$$MAKEFLAGS" \ | sed "s/$$bs$$bs[$$bs $$bs ]*//g"`;; \ esac; \ fi; \ skip_next=no; \ strip_trailopt () \ { \ flg=`printf '%s\n' "$$flg" | sed "s/$$1.*$$//"`; \ }; \ for flg in $$sane_makeflags; do \ test $$skip_next = yes && { skip_next=no; continue; }; \ case $$flg in \ *=*|--*) continue;; \ -*I) strip_trailopt 'I'; skip_next=yes;; \ -*I?*) strip_trailopt 'I';; \ -*O) strip_trailopt 'O'; skip_next=yes;; \ -*O?*) strip_trailopt 'O';; \ -*l) strip_trailopt 'l'; skip_next=yes;; \ -*l?*) strip_trailopt 'l';; \ -[dEDm]) skip_next=yes;; \ -[JT]) skip_next=yes;; \ esac; \ case $$flg in \ *$$target_option*) has_opt=yes; break;; \ esac; \ done; \ test $$has_opt = yes am__make_dryrun = (target_option=n; $(am__make_running_with_option)) am__make_keepgoing = (target_option=k; $(am__make_running_with_option)) pkgdatadir = $(datadir)/@PACKAGE@ pkgincludedir = $(includedir)/@PACKAGE@ pkglibdir = $(libdir)/@PACKAGE@ pkglibexecdir = $(libexecdir)/@PACKAGE@ am__cd = CDPATH="$${ZSH_VERSION+.}$(PATH_SEPARATOR)" && cd install_sh_DATA = $(install_sh) -c -m 644 install_sh_PROGRAM = $(install_sh) -c install_sh_SCRIPT = $(install_sh) -c INSTALL_HEADER = $(INSTALL_DATA) transform = $(program_transform_name) NORMAL_INSTALL = : PRE_INSTALL = : POST_INSTALL = : NORMAL_UNINSTALL = : PRE_UNINSTALL = : POST_UNINSTALL = : build_triplet = @build@ host_triplet = @host@ @XRDP_DEBUG_TRUE@am__append_1 = -DXRDP_DEBUG subdir = mc ACLOCAL_M4 = $(top_srcdir)/aclocal.m4 am__aclocal_m4_deps = $(top_srcdir)/m4/ax_append_compile_flags.m4 \ $(top_srcdir)/m4/ax_append_flag.m4 \ $(top_srcdir)/m4/ax_cflags_warn_all.m4 \ $(top_srcdir)/m4/ax_check_compile_flag.m4 \ $(top_srcdir)/m4/ax_gcc_func_attribute.m4 \ $(top_srcdir)/m4/ax_require_defined.m4 \ $(top_srcdir)/m4/ax_type_socklen_t.m4 \ $(top_srcdir)/m4/libtool.m4 $(top_srcdir)/m4/ltoptions.m4 \ $(top_srcdir)/m4/ltsugar.m4 $(top_srcdir)/m4/ltversion.m4 \ $(top_srcdir)/m4/lt~obsolete.m4 $(top_srcdir)/m4/pkg.m4 \ $(top_srcdir)/configure.ac am__configure_deps = $(am__aclocal_m4_deps) $(CONFIGURE_DEPENDENCIES) \ $(ACLOCAL_M4) DIST_COMMON = $(srcdir)/Makefile.am $(am__DIST_COMMON) mkinstalldirs = $(install_sh) -d CONFIG_HEADER = $(top_builddir)/config_ac.h CONFIG_CLEAN_FILES = CONFIG_CLEAN_VPATH_FILES = am__vpath_adj_setup = srcdirstrip=`echo "$(srcdir)" | sed 's|.|.|g'`; am__vpath_adj = case $$p in \ $(srcdir)/*) f=`echo "$$p" | sed "s|^$$srcdirstrip/||"`;; \ *) f=$$p;; \ esac; am__strip_dir = f=`echo $$p | sed -e 's|^.*/||'`; am__install_max = 40 am__nobase_strip_setup = \ srcdirstrip=`echo "$(srcdir)" | sed 's/[].[^$$\\*|]/\\\\&/g'` am__nobase_strip = \ for p in $$list; do echo "$$p"; done | sed -e "s|$$srcdirstrip/||" am__nobase_list = $(am__nobase_strip_setup); \ for p in $$list; do echo "$$p $$p"; done | \ sed "s| $$srcdirstrip/| |;"' / .*\//!s/ .*/ ./; s,\( .*\)/[^/]*$$,\1,' | \ $(AWK) 'BEGIN { files["."] = "" } { files[$$2] = files[$$2] " " $$1; \ if (++n[$$2] == $(am__install_max)) \ { print $$2, files[$$2]; n[$$2] = 0; files[$$2] = "" } } \ END { for (dir in files) print dir, files[dir] }' am__base_list = \ sed '$$!N;$$!N;$$!N;$$!N;$$!N;$$!N;$$!N;s/\n/ /g' | \ sed '$$!N;$$!N;$$!N;$$!N;s/\n/ /g' am__uninstall_files_from_dir = { \ test -z "$$files" \ || { test ! -d "$$dir" && test ! -f "$$dir" && test ! -r "$$dir"; } \ || { echo " ( cd '$$dir' && rm -f" $$files ")"; \ $(am__cd) "$$dir" && rm -f $$files; }; \ } am__installdirs = "$(DESTDIR)$(moduledir)" LTLIBRARIES = $(module_LTLIBRARIES) libmc_la_DEPENDENCIES = $(top_builddir)/common/libcommon.la am_libmc_la_OBJECTS = mc.lo libmc_la_OBJECTS = $(am_libmc_la_OBJECTS) AM_V_lt = $(am__v_lt_@AM_V@) am__v_lt_ = $(am__v_lt_@AM_DEFAULT_V@) am__v_lt_0 = --silent am__v_lt_1 = libmc_la_LINK = $(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) \ $(LIBTOOLFLAGS) --mode=link $(CCLD) $(AM_CFLAGS) $(CFLAGS) \ $(libmc_la_LDFLAGS) $(LDFLAGS) -o $@ AM_V_P = $(am__v_P_@AM_V@) am__v_P_ = $(am__v_P_@AM_DEFAULT_V@) am__v_P_0 = false am__v_P_1 = : AM_V_GEN = $(am__v_GEN_@AM_V@) am__v_GEN_ = $(am__v_GEN_@AM_DEFAULT_V@) am__v_GEN_0 = @echo " GEN " $@; am__v_GEN_1 = AM_V_at = $(am__v_at_@AM_V@) am__v_at_ = $(am__v_at_@AM_DEFAULT_V@) am__v_at_0 = @ am__v_at_1 = DEFAULT_INCLUDES = -I.@am__isrc@ -I$(top_builddir) depcomp = $(SHELL) $(top_srcdir)/depcomp am__depfiles_maybe = depfiles am__mv = mv -f COMPILE = $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) \ $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) LTCOMPILE = $(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) \ $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) \ $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) \ $(AM_CFLAGS) $(CFLAGS) AM_V_CC = $(am__v_CC_@AM_V@) am__v_CC_ = $(am__v_CC_@AM_DEFAULT_V@) am__v_CC_0 = @echo " CC " $@; am__v_CC_1 = CCLD = $(CC) LINK = $(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) \ $(LIBTOOLFLAGS) --mode=link $(CCLD) $(AM_CFLAGS) $(CFLAGS) \ $(AM_LDFLAGS) $(LDFLAGS) -o $@ AM_V_CCLD = $(am__v_CCLD_@AM_V@) am__v_CCLD_ = $(am__v_CCLD_@AM_DEFAULT_V@) am__v_CCLD_0 = @echo " CCLD " $@; am__v_CCLD_1 = SOURCES = $(libmc_la_SOURCES) DIST_SOURCES = $(libmc_la_SOURCES) am__can_run_installinfo = \ case $$AM_UPDATE_INFO_DIR in \ n|no|NO) false;; \ *) (install-info --version) >/dev/null 2>&1;; \ esac am__tagged_files = $(HEADERS) $(SOURCES) $(TAGS_FILES) $(LISP) # Read a list of newline-separated strings from the standard input, # and print each of them once, without duplicates. Input order is # *not* preserved. am__uniquify_input = $(AWK) '\ BEGIN { nonempty = 0; } \ { items[$$0] = 1; nonempty = 1; } \ END { if (nonempty) { for (i in items) print i; }; } \ ' # Make sure the list of sources is unique. This is necessary because, # e.g., the same source file might be shared among _SOURCES variables # for different programs/libraries. am__define_uniq_tagged_files = \ list='$(am__tagged_files)'; \ unique=`for i in $$list; do \ if test -f "$$i"; then echo $$i; else echo $(srcdir)/$$i; fi; \ done | $(am__uniquify_input)` ETAGS = etags CTAGS = ctags am__DIST_COMMON = $(srcdir)/Makefile.in $(top_srcdir)/depcomp DISTFILES = $(DIST_COMMON) $(DIST_SOURCES) $(TEXINFOS) $(EXTRA_DIST) ACLOCAL = @ACLOCAL@ AMTAR = @AMTAR@ AM_DEFAULT_VERBOSITY = @AM_DEFAULT_VERBOSITY@ AR = @AR@ AUTOCONF = @AUTOCONF@ AUTOHEADER = @AUTOHEADER@ AUTOMAKE = @AUTOMAKE@ AWK = @AWK@ CC = @CC@ CCDEPMODE = @CCDEPMODE@ CFLAGS = @CFLAGS@ CPP = @CPP@ CPPFLAGS = @CPPFLAGS@ CYGPATH_W = @CYGPATH_W@ DEFS = @DEFS@ DEPDIR = @DEPDIR@ DLLTOOL = @DLLTOOL@ DLOPEN_LIBS = @DLOPEN_LIBS@ DSYMUTIL = @DSYMUTIL@ DUMPBIN = @DUMPBIN@ ECHO_C = @ECHO_C@ ECHO_N = @ECHO_N@ ECHO_T = @ECHO_T@ EGREP = @EGREP@ EXEEXT = @EXEEXT@ FDKAAC_CFLAGS = @FDKAAC_CFLAGS@ FDKAAC_LIBS = @FDKAAC_LIBS@ FGREP = @FGREP@ FREERDP_CFLAGS = @FREERDP_CFLAGS@ FREERDP_LIBS = @FREERDP_LIBS@ FUSE_CFLAGS = @FUSE_CFLAGS@ FUSE_LIBS = @FUSE_LIBS@ GREP = @GREP@ INSTALL = @INSTALL@ INSTALL_DATA = @INSTALL_DATA@ INSTALL_PROGRAM = @INSTALL_PROGRAM@ INSTALL_SCRIPT = @INSTALL_SCRIPT@ INSTALL_STRIP_PROGRAM = @INSTALL_STRIP_PROGRAM@ LD = @LD@ LDFLAGS = @LDFLAGS@ LIBOBJS = @LIBOBJS@ LIBS = @LIBS@ LIBTOOL = @LIBTOOL@ LIPO = @LIPO@ LN_S = @LN_S@ LTLIBOBJS = @LTLIBOBJS@ LT_SYS_LIBRARY_PATH = @LT_SYS_LIBRARY_PATH@ MAKEINFO = @MAKEINFO@ MANIFEST_TOOL = @MANIFEST_TOOL@ MKDIR_P = @MKDIR_P@ NM = @NM@ NMEDIT = @NMEDIT@ OBJDUMP = @OBJDUMP@ OBJEXT = @OBJEXT@ OPENSSL = @OPENSSL@ OPENSSL_CFLAGS = @OPENSSL_CFLAGS@ OPENSSL_LIBS = @OPENSSL_LIBS@ OTOOL = @OTOOL@ OTOOL64 = @OTOOL64@ PACKAGE = @PACKAGE@ PACKAGE_BUGREPORT = @PACKAGE_BUGREPORT@ PACKAGE_NAME = @PACKAGE_NAME@ PACKAGE_STRING = @PACKAGE_STRING@ PACKAGE_TARNAME = @PACKAGE_TARNAME@ PACKAGE_URL = @PACKAGE_URL@ PACKAGE_VERSION = @PACKAGE_VERSION@ PAM_RULES = @PAM_RULES@ PATH_SEPARATOR = @PATH_SEPARATOR@ PIXMAN_CFLAGS = @PIXMAN_CFLAGS@ PIXMAN_LIBS = @PIXMAN_LIBS@ PKG_CONFIG = @PKG_CONFIG@ PKG_CONFIG_LIBDIR = @PKG_CONFIG_LIBDIR@ PKG_CONFIG_PATH = @PKG_CONFIG_PATH@ RANLIB = @RANLIB@ SED = @SED@ SET_MAKE = @SET_MAKE@ SHELL = @SHELL@ STRIP = @STRIP@ TurboJpegIncDir = @TurboJpegIncDir@ TurboJpegLibDir = @TurboJpegLibDir@ VERSION = @VERSION@ XMKMF = @XMKMF@ X_CFLAGS = @X_CFLAGS@ X_EXTRA_LIBS = @X_EXTRA_LIBS@ X_LIBS = @X_LIBS@ X_PRE_LIBS = @X_PRE_LIBS@ abs_builddir = @abs_builddir@ abs_srcdir = @abs_srcdir@ abs_top_builddir = @abs_top_builddir@ abs_top_srcdir = @abs_top_srcdir@ ac_ct_AR = @ac_ct_AR@ ac_ct_CC = @ac_ct_CC@ ac_ct_DUMPBIN = @ac_ct_DUMPBIN@ am__include = @am__include@ am__leading_dot = @am__leading_dot@ am__quote = @am__quote@ am__tar = @am__tar@ am__untar = @am__untar@ bindir = @bindir@ build = @build@ build_alias = @build_alias@ build_cpu = @build_cpu@ build_os = @build_os@ build_vendor = @build_vendor@ builddir = @builddir@ datadir = @datadir@ datarootdir = @datarootdir@ docdir = @docdir@ dvidir = @dvidir@ exec_prefix = @exec_prefix@ host = @host@ host_alias = @host_alias@ host_cpu = @host_cpu@ host_os = @host_os@ host_vendor = @host_vendor@ htmldir = @htmldir@ includedir = @includedir@ infodir = @infodir@ install_sh = @install_sh@ libdir = @libdir@ libexecdir = @libexecdir@ localedir = @localedir@ localstatedir = @localstatedir@ mandir = @mandir@ mkdir_p = @mkdir_p@ moduledir = @moduledir@ oldincludedir = @oldincludedir@ pdfdir = @pdfdir@ pkgconfigdir = @pkgconfigdir@ prefix = @prefix@ program_transform_name = @program_transform_name@ psdir = @psdir@ sbindir = @sbindir@ sharedstatedir = @sharedstatedir@ socketdir = @socketdir@ srcdir = @srcdir@ subdirs = @subdirs@ sysconfdir = @sysconfdir@ systemdsystemunitdir = @systemdsystemunitdir@ target_alias = @target_alias@ top_build_prefix = @top_build_prefix@ top_builddir = @top_builddir@ top_srcdir = @top_srcdir@ AM_CPPFLAGS = -DXRDP_CFG_PATH=\"${sysconfdir}/xrdp\" \ -DXRDP_SBIN_PATH=\"${sbindir}\" \ -DXRDP_SHARE_PATH=\"${datadir}/xrdp\" \ -DXRDP_PID_PATH=\"${localstatedir}/run\" \ -I$(top_srcdir)/common $(am__append_1) module_LTLIBRARIES = \ libmc.la libmc_la_SOURCES = \ mc.c \ mc.h libmc_la_LIBADD = \ $(top_builddir)/common/libcommon.la libmc_la_LDFLAGS = -avoid-version -module all: all-am .SUFFIXES: .SUFFIXES: .c .lo .o .obj $(srcdir)/Makefile.in: $(srcdir)/Makefile.am $(am__configure_deps) @for dep in $?; do \ case '$(am__configure_deps)' in \ *$$dep*) \ ( cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh ) \ && { if test -f $@; then exit 0; else break; fi; }; \ exit 1;; \ esac; \ done; \ echo ' cd $(top_srcdir) && $(AUTOMAKE) --foreign mc/Makefile'; \ $(am__cd) $(top_srcdir) && \ $(AUTOMAKE) --foreign mc/Makefile Makefile: $(srcdir)/Makefile.in $(top_builddir)/config.status @case '$?' in \ *config.status*) \ cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh;; \ *) \ echo ' cd $(top_builddir) && $(SHELL) ./config.status $(subdir)/$@ $(am__depfiles_maybe)'; \ cd $(top_builddir) && $(SHELL) ./config.status $(subdir)/$@ $(am__depfiles_maybe);; \ esac; $(top_builddir)/config.status: $(top_srcdir)/configure $(CONFIG_STATUS_DEPENDENCIES) cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh $(top_srcdir)/configure: $(am__configure_deps) cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh $(ACLOCAL_M4): $(am__aclocal_m4_deps) cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh $(am__aclocal_m4_deps): install-moduleLTLIBRARIES: $(module_LTLIBRARIES) @$(NORMAL_INSTALL) @list='$(module_LTLIBRARIES)'; test -n "$(moduledir)" || list=; \ list2=; for p in $$list; do \ if test -f $$p; then \ list2="$$list2 $$p"; \ else :; fi; \ done; \ test -z "$$list2" || { \ echo " $(MKDIR_P) '$(DESTDIR)$(moduledir)'"; \ $(MKDIR_P) "$(DESTDIR)$(moduledir)" || exit 1; \ echo " $(LIBTOOL) $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=install $(INSTALL) $(INSTALL_STRIP_FLAG) $$list2 '$(DESTDIR)$(moduledir)'"; \ $(LIBTOOL) $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=install $(INSTALL) $(INSTALL_STRIP_FLAG) $$list2 "$(DESTDIR)$(moduledir)"; \ } uninstall-moduleLTLIBRARIES: @$(NORMAL_UNINSTALL) @list='$(module_LTLIBRARIES)'; test -n "$(moduledir)" || list=; \ for p in $$list; do \ $(am__strip_dir) \ echo " $(LIBTOOL) $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=uninstall rm -f '$(DESTDIR)$(moduledir)/$$f'"; \ $(LIBTOOL) $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=uninstall rm -f "$(DESTDIR)$(moduledir)/$$f"; \ done clean-moduleLTLIBRARIES: -test -z "$(module_LTLIBRARIES)" || rm -f $(module_LTLIBRARIES) @list='$(module_LTLIBRARIES)'; \ locs=`for p in $$list; do echo $$p; done | \ sed 's|^[^/]*$$|.|; s|/[^/]*$$||; s|$$|/so_locations|' | \ sort -u`; \ test -z "$$locs" || { \ echo rm -f $${locs}; \ rm -f $${locs}; \ } libmc.la: $(libmc_la_OBJECTS) $(libmc_la_DEPENDENCIES) $(EXTRA_libmc_la_DEPENDENCIES) $(AM_V_CCLD)$(libmc_la_LINK) -rpath $(moduledir) $(libmc_la_OBJECTS) $(libmc_la_LIBADD) $(LIBS) mostlyclean-compile: -rm -f *.$(OBJEXT) distclean-compile: -rm -f *.tab.c @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/mc.Plo@am__quote@ .c.o: @am__fastdepCC_TRUE@ $(AM_V_CC)$(COMPILE) -MT $@ -MD -MP -MF $(DEPDIR)/$*.Tpo -c -o $@ $< @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) $(DEPDIR)/$*.Tpo $(DEPDIR)/$*.Po @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='$<' object='$@' libtool=no @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(COMPILE) -c -o $@ $< .c.obj: @am__fastdepCC_TRUE@ $(AM_V_CC)$(COMPILE) -MT $@ -MD -MP -MF $(DEPDIR)/$*.Tpo -c -o $@ `$(CYGPATH_W) '$<'` @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) $(DEPDIR)/$*.Tpo $(DEPDIR)/$*.Po @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='$<' object='$@' libtool=no @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(COMPILE) -c -o $@ `$(CYGPATH_W) '$<'` .c.lo: @am__fastdepCC_TRUE@ $(AM_V_CC)$(LTCOMPILE) -MT $@ -MD -MP -MF $(DEPDIR)/$*.Tpo -c -o $@ $< @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) $(DEPDIR)/$*.Tpo $(DEPDIR)/$*.Plo @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='$<' object='$@' libtool=yes @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(LTCOMPILE) -c -o $@ $< mostlyclean-libtool: -rm -f *.lo clean-libtool: -rm -rf .libs _libs ID: $(am__tagged_files) $(am__define_uniq_tagged_files); mkid -fID $$unique tags: tags-am TAGS: tags tags-am: $(TAGS_DEPENDENCIES) $(am__tagged_files) set x; \ here=`pwd`; \ $(am__define_uniq_tagged_files); \ shift; \ if test -z "$(ETAGS_ARGS)$$*$$unique"; then :; else \ test -n "$$unique" || unique=$$empty_fix; \ if test $$# -gt 0; then \ $(ETAGS) $(ETAGSFLAGS) $(AM_ETAGSFLAGS) $(ETAGS_ARGS) \ "$$@" $$unique; \ else \ $(ETAGS) $(ETAGSFLAGS) $(AM_ETAGSFLAGS) $(ETAGS_ARGS) \ $$unique; \ fi; \ fi ctags: ctags-am CTAGS: ctags ctags-am: $(TAGS_DEPENDENCIES) $(am__tagged_files) $(am__define_uniq_tagged_files); \ test -z "$(CTAGS_ARGS)$$unique" \ || $(CTAGS) $(CTAGSFLAGS) $(AM_CTAGSFLAGS) $(CTAGS_ARGS) \ $$unique GTAGS: here=`$(am__cd) $(top_builddir) && pwd` \ && $(am__cd) $(top_srcdir) \ && gtags -i $(GTAGS_ARGS) "$$here" cscopelist: cscopelist-am cscopelist-am: $(am__tagged_files) list='$(am__tagged_files)'; \ case "$(srcdir)" in \ [\\/]* | ?:[\\/]*) sdir="$(srcdir)" ;; \ *) sdir=$(subdir)/$(srcdir) ;; \ esac; \ for i in $$list; do \ if test -f "$$i"; then \ echo "$(subdir)/$$i"; \ else \ echo "$$sdir/$$i"; \ fi; \ done >> $(top_builddir)/cscope.files distclean-tags: -rm -f TAGS ID GTAGS GRTAGS GSYMS GPATH tags distdir: $(DISTFILES) @srcdirstrip=`echo "$(srcdir)" | sed 's/[].[^$$\\*]/\\\\&/g'`; \ topsrcdirstrip=`echo "$(top_srcdir)" | sed 's/[].[^$$\\*]/\\\\&/g'`; \ list='$(DISTFILES)'; \ dist_files=`for file in $$list; do echo $$file; done | \ sed -e "s|^$$srcdirstrip/||;t" \ -e "s|^$$topsrcdirstrip/|$(top_builddir)/|;t"`; \ case $$dist_files in \ */*) $(MKDIR_P) `echo "$$dist_files" | \ sed '/\//!d;s|^|$(distdir)/|;s,/[^/]*$$,,' | \ sort -u` ;; \ esac; \ for file in $$dist_files; do \ if test -f $$file || test -d $$file; then d=.; else d=$(srcdir); fi; \ if test -d $$d/$$file; then \ dir=`echo "/$$file" | sed -e 's,/[^/]*$$,,'`; \ if test -d "$(distdir)/$$file"; then \ find "$(distdir)/$$file" -type d ! -perm -700 -exec chmod u+rwx {} \;; \ fi; \ if test -d $(srcdir)/$$file && test $$d != $(srcdir); then \ cp -fpR $(srcdir)/$$file "$(distdir)$$dir" || exit 1; \ find "$(distdir)/$$file" -type d ! -perm -700 -exec chmod u+rwx {} \;; \ fi; \ cp -fpR $$d/$$file "$(distdir)$$dir" || exit 1; \ else \ test -f "$(distdir)/$$file" \ || cp -p $$d/$$file "$(distdir)/$$file" \ || exit 1; \ fi; \ done check-am: all-am check: check-am all-am: Makefile $(LTLIBRARIES) installdirs: for dir in "$(DESTDIR)$(moduledir)"; do \ test -z "$$dir" || $(MKDIR_P) "$$dir"; \ done install: install-am install-exec: install-exec-am install-data: install-data-am uninstall: uninstall-am install-am: all-am @$(MAKE) $(AM_MAKEFLAGS) install-exec-am install-data-am installcheck: installcheck-am install-strip: if test -z '$(STRIP)'; then \ $(MAKE) $(AM_MAKEFLAGS) INSTALL_PROGRAM="$(INSTALL_STRIP_PROGRAM)" \ install_sh_PROGRAM="$(INSTALL_STRIP_PROGRAM)" INSTALL_STRIP_FLAG=-s \ install; \ else \ $(MAKE) $(AM_MAKEFLAGS) INSTALL_PROGRAM="$(INSTALL_STRIP_PROGRAM)" \ install_sh_PROGRAM="$(INSTALL_STRIP_PROGRAM)" INSTALL_STRIP_FLAG=-s \ "INSTALL_PROGRAM_ENV=STRIPPROG='$(STRIP)'" install; \ fi mostlyclean-generic: clean-generic: distclean-generic: -test -z "$(CONFIG_CLEAN_FILES)" || rm -f $(CONFIG_CLEAN_FILES) -test . = "$(srcdir)" || test -z "$(CONFIG_CLEAN_VPATH_FILES)" || rm -f $(CONFIG_CLEAN_VPATH_FILES) maintainer-clean-generic: @echo "This command is intended for maintainers to use" @echo "it deletes files that may require special tools to rebuild." clean: clean-am clean-am: clean-generic clean-libtool clean-moduleLTLIBRARIES \ mostlyclean-am distclean: distclean-am -rm -rf ./$(DEPDIR) -rm -f Makefile distclean-am: clean-am distclean-compile distclean-generic \ distclean-tags dvi: dvi-am dvi-am: html: html-am html-am: info: info-am info-am: install-data-am: install-moduleLTLIBRARIES install-dvi: install-dvi-am install-dvi-am: install-exec-am: install-html: install-html-am install-html-am: install-info: install-info-am install-info-am: install-man: install-pdf: install-pdf-am install-pdf-am: install-ps: install-ps-am install-ps-am: installcheck-am: maintainer-clean: maintainer-clean-am -rm -rf ./$(DEPDIR) -rm -f Makefile maintainer-clean-am: distclean-am maintainer-clean-generic mostlyclean: mostlyclean-am mostlyclean-am: mostlyclean-compile mostlyclean-generic \ mostlyclean-libtool pdf: pdf-am pdf-am: ps: ps-am ps-am: uninstall-am: uninstall-moduleLTLIBRARIES .MAKE: install-am install-strip .PHONY: CTAGS GTAGS TAGS all all-am check check-am clean clean-generic \ clean-libtool clean-moduleLTLIBRARIES cscopelist-am ctags \ ctags-am distclean distclean-compile distclean-generic \ distclean-libtool distclean-tags distdir dvi dvi-am html \ html-am info info-am install install-am install-data \ install-data-am install-dvi install-dvi-am install-exec \ install-exec-am install-html install-html-am install-info \ install-info-am install-man install-moduleLTLIBRARIES \ install-pdf install-pdf-am install-ps install-ps-am \ install-strip installcheck installcheck-am installdirs \ maintainer-clean maintainer-clean-generic mostlyclean \ mostlyclean-compile mostlyclean-generic mostlyclean-libtool \ pdf pdf-am ps ps-am tags tags-am uninstall uninstall-am \ uninstall-moduleLTLIBRARIES .PRECIOUS: Makefile # Tell versions [3.59,3.63) of GNU make to not export all variables. # Otherwise a system limit (for SysV at least) may be exceeded. .NOEXPORT: xrdp-0.9.5/libxrdp/xrdp_jpeg_compress.c000644 001751 001751 00000031664 13201006747 020141 0ustar00metameta000000 000000 /** * xrdp: A Remote Desktop Protocol server. * * Copyright (C) Jay Sorg 2004-2014 * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. * * jpeg compressor */ #if defined(HAVE_CONFIG_H) #include #endif #include "libxrdp.h" #if defined(XRDP_TJPEG) /* turbo jpeg */ #include #include #include #include #include "log.h" /*****************************************************************************/ int xrdp_jpeg_compress(void *handle, char *in_data, int width, int height, struct stream *s, int bpp, int byte_limit, int start_line, struct stream *temp_s, int e, int quality) { int error; int i; int j; unsigned int pixel; unsigned int *src32; unsigned int *dst32; unsigned long cdata_bytes; unsigned char *src_buf; unsigned char *dst_buf; char *temp_buf; tjhandle tj_han; if (bpp != 24) { g_writeln("xrdp_jpeg_compress: bpp wrong %d", bpp); return height; } if (handle == 0) { g_writeln("xrdp_jpeg_compress: handle is nil"); return height; } tj_han = (tjhandle) handle; cdata_bytes = byte_limit; src_buf = (unsigned char *) in_data; dst_buf = (unsigned char *) (s->p); temp_buf = 0; if (e == 0) { src_buf = (unsigned char*)in_data; } else { temp_buf = (char *) g_malloc((width + e) * height * 4, 0); dst32 = (unsigned int *) temp_buf; src32 = (unsigned int *) in_data; for (j = 0; j < height; j++) { for (i = 0; i < width; i++) { pixel = *src32; src32++; *dst32 = pixel; dst32++; } if (width > 0) { for (i = 0; i < e; i++) { *dst32 = pixel; dst32++; } } } src_buf = (unsigned char *) temp_buf; } dst_buf = (unsigned char*)(s->p); error = tjCompress(tj_han, src_buf, width + e, (width + e) * 4, height, TJPF_XBGR, dst_buf, &cdata_bytes, TJSAMP_420, quality, 0); if (error != 0) { log_message(LOG_LEVEL_ERROR, "xrdp_jpeg_compress: tjCompress error: %s", tjGetErrorStr()); } s->p += cdata_bytes; g_free(temp_buf); return height; } /** * Compress a rectangular area (aka inner rectangle) inside our * frame buffer (inp_data) *****************************************************************************/ int xrdp_codec_jpeg_compress(void *handle, int format, /* input data format */ char *inp_data, /* input data */ int width, /* width of inp_data */ int height, /* height of inp_data */ int stride, /* inp_data stride, in bytes*/ int x, /* x loc in inp_data */ int y, /* y loc in inp_data */ int cx, /* width of area to compress */ int cy, /* height of area to compress */ int quality, /* higher numbers compress less */ char *out_data, /* dest for jpg image */ int *io_len /* length of out_data and on return */ /* len of compressed data */ ) { tjhandle tj_han; int error; int bpp; char *src_ptr; unsigned long lio_len; /* * note: for now we assume that format is always XBGR and ignore format */ if (handle == 0) { g_writeln("xrdp_codec_jpeg_compress: handle is nil"); return height; } tj_han = (tjhandle) handle; /* get bytes per pixel */ bpp = stride / width; /* start of inner rect in inp_data */ src_ptr = inp_data + (y * stride + x * bpp); lio_len = *io_len; /* compress inner rect */ /* notes * TJPF_RGB no works, zero bytes * TJPF_BGR no works, not zero but no open * TJPF_RGBX no works, zero bytes * TJPF_BGRX no works, off scaled image * TJPF_XBGR works * TJPF_XRGB no works, zero bytes * TJPF_RGBA no works, zero bytes * TJPF_BGRA no works, zero bytes * TJPF_ABGR no works, zero bytes * TJPF_ARGB no works, zero bytes */ error = tjCompress(tj_han, /* opaque handle */ (unsigned char *) src_ptr, /* source buf */ cx, /* width of area to compress */ stride, /* pitch */ cy, /* height of area to compress */ TJPF_XBGR, /* pixel size */ (unsigned char *) out_data, /* dest buf */ &lio_len, /* inner_buf length & compressed_size */ TJSAMP_420, /* jpeg sub sample */ quality, /* jpeg quality */ 0 /* flags */ ); if (error != 0) { log_message(LOG_LEVEL_ERROR, "xrdp_codec_jpeg_compress: tjCompress error: %s", tjGetErrorStr()); } *io_len = lio_len; return height; } /*****************************************************************************/ void * xrdp_jpeg_init(void) { tjhandle tj_han; tj_han = tjInitCompress(); return tj_han; } /*****************************************************************************/ int xrdp_jpeg_deinit(void *handle) { tjhandle tj_han; if (handle == 0) { return 0; } tj_han = (tjhandle) handle; tjDestroy(tj_han); return 0; } #elif defined(XRDP_JPEG) /* libjpeg */ #include #include #include #include #define JP_QUALITY 75 struct mydata_comp { JOCTET *cb; int cb_bytes; int total_done; int overwrite; }; /*****************************************************************************/ /* called at beginning */ static void my_init_destination(j_compress_ptr cinfo) { struct mydata_comp *md; md = (struct mydata_comp *)(cinfo->client_data); md->total_done = 0; md->overwrite = 0; cinfo->dest->next_output_byte = md->cb; cinfo->dest->free_in_buffer = md->cb_bytes; } /*****************************************************************************/ /* called when buffer is full and we need more space */ static int my_empty_output_buffer(j_compress_ptr cinfo) { struct mydata_comp *md; int chunk_bytes; md = (struct mydata_comp *)(cinfo->client_data); chunk_bytes = md->cb_bytes; md->total_done += chunk_bytes; cinfo->dest->next_output_byte = md->cb; cinfo->dest->free_in_buffer = md->cb_bytes; md->overwrite = 1; return 1; } /*****************************************************************************/ /* called at end */ static void my_term_destination(j_compress_ptr cinfo) { struct mydata_comp *md; int chunk_bytes; md = (struct mydata_comp *)(cinfo->client_data); chunk_bytes = md->cb_bytes - cinfo->dest->free_in_buffer; md->total_done += chunk_bytes; } /*****************************************************************************/ static int jp_do_compress(JOCTET *data, int width, int height, int bpp, int quality, JOCTET *comp_data, int *comp_data_bytes) { struct jpeg_compress_struct cinfo; struct jpeg_error_mgr jerr; struct jpeg_destination_mgr dst_mgr; struct mydata_comp md; JSAMPROW row_pointer[4]; int Bpp; Bpp = (bpp + 7) / 8; memset(&cinfo, 0, sizeof(cinfo)); cinfo.err = jpeg_std_error(&jerr); jpeg_create_compress(&cinfo); memset(&md, 0, sizeof(md)); md.cb = comp_data, md.cb_bytes = *comp_data_bytes; cinfo.client_data = &md; memset(&dst_mgr, 0, sizeof(dst_mgr)); dst_mgr.init_destination = my_init_destination; dst_mgr.empty_output_buffer = my_empty_output_buffer; dst_mgr.term_destination = my_term_destination; cinfo.dest = &dst_mgr; cinfo.image_width = width; cinfo.image_height = height; cinfo.input_components = Bpp; cinfo.in_color_space = JCS_RGB; jpeg_set_defaults(&cinfo); cinfo.num_components = 3; cinfo.dct_method = JDCT_FLOAT; jpeg_set_quality(&cinfo, quality, 1); jpeg_start_compress(&cinfo, 1); while (cinfo.next_scanline + 3 < cinfo.image_height) { row_pointer[0] = data; data += width * Bpp; row_pointer[1] = data; data += width * Bpp; row_pointer[2] = data; data += width * Bpp; row_pointer[3] = data; data += width * Bpp; jpeg_write_scanlines(&cinfo, row_pointer, 4); } while (cinfo.next_scanline < cinfo.image_height) { row_pointer[0] = data; data += width * Bpp; jpeg_write_scanlines(&cinfo, row_pointer, 1); } jpeg_finish_compress(&cinfo); *comp_data_bytes = md.total_done; jpeg_destroy_compress(&cinfo); if (md.overwrite) { return 1; } return 0; } /*****************************************************************************/ static int jpeg_compress(char *in_data, int width, int height, struct stream *s, struct stream *temp_s, int bpp, int byte_limit, int e, int quality) { JOCTET *data; tui32 *src32; tui8 *dst8; tui32 pixel; int red; int blue; int green; int j; int i; int cdata_bytes; data = (JOCTET *) temp_s->data; dst8 = data; if (bpp == 24) { src32 = (tui32 *)in_data; for (j = 0; j < height; j++) { for (i = 0; i < width; i++) { pixel = src32[i + j * width]; SPLITCOLOR32(red, green, blue, pixel); *(dst8++) = blue; *(dst8++) = green; *(dst8++) = red; } if (width > 0) { for (i = 0; i < e; i++) { *(dst8++) = blue; *(dst8++) = green; *(dst8++) = red; } } } } else { g_writeln("bpp wrong %d", bpp); } cdata_bytes = byte_limit; jp_do_compress(data, width + e, height, 24, quality, (JOCTET *) s->p, &cdata_bytes); s->p += cdata_bytes; return cdata_bytes; } /*****************************************************************************/ int xrdp_jpeg_compress(void *handle, char *in_data, int width, int height, struct stream *s, int bpp, int byte_limit, int start_line, struct stream *temp_s, int e, int quality) { jpeg_compress(in_data, width, height, s, temp_s, bpp, byte_limit, e, quality); return height; } /*****************************************************************************/ int xrdp_codec_jpeg_compress(void *handle, int format, char *inp_data, int width, int height, int stride, int x, int y, int cx, int cy, int quality, char *out_data, int *io_len) { return 0; } /*****************************************************************************/ void * xrdp_jpeg_init(void) { return 0; } /*****************************************************************************/ int xrdp_jpeg_deinit(void *handle) { return 0; } #else /*****************************************************************************/ int xrdp_jpeg_compress(void *handle, char *in_data, int width, int height, struct stream *s, int bpp, int byte_limit, int start_line, struct stream *temp_s, int e, int quality) { return height; } /*****************************************************************************/ int xrdp_codec_jpeg_compress(void *handle, int format, char *inp_data, int width, int height, int stride, int x, int y, int cx, int cy, int quality, char *out_data, int *io_len) { return 0; } /*****************************************************************************/ void * xrdp_jpeg_init(void) { return 0; } /*****************************************************************************/ int xrdp_jpeg_deinit(void *handle) { return 0; } #endif xrdp-0.9.5/libxrdp/libxrdp.h000644 001751 001751 00000043452 13174271344 015721 0ustar00metameta000000 000000 /** * xrdp: A Remote Desktop Protocol server. * * Copyright (C) Jay Sorg 2004-2014 * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. * * libxrdp header */ #if !defined(LIBXRDP_H) #define LIBXRDP_H #include "arch.h" #include "parse.h" #include "trans.h" #include "xrdp_constants.h" #include "defines.h" #include "os_calls.h" #include "ssl_calls.h" #include "list.h" #include "file.h" #include "libxrdpinc.h" #include "xrdp_client_info.h" /* iso */ struct xrdp_iso { struct xrdp_mcs *mcs_layer; /* owner */ int rdpNegData; /* bool */ int requestedProtocol; int selectedProtocol; int failureCode; struct trans *trans; }; /* used in mcs */ struct mcs_channel_item { char name[16]; int flags; int chanid; }; /* mcs */ struct xrdp_mcs { struct xrdp_sec *sec_layer; /* owner */ struct xrdp_iso *iso_layer; int userid; int chanid; struct stream *client_mcs_data; struct stream *server_mcs_data; struct list *channel_list; }; /* fastpath */ struct xrdp_fastpath { struct xrdp_sec *sec_layer; /* owner */ struct trans *trans; struct xrdp_session *session; int numEvents; int secFlags; }; /* Encryption Methods */ #define CRYPT_METHOD_NONE 0x00000000 #define CRYPT_METHOD_40BIT 0x00000001 #define CRYPT_METHOD_128BIT 0x00000002 #define CRYPT_METHOD_56BIT 0x00000008 #define CRYPT_METHOD_FIPS 0x00000010 /* Encryption Levels */ #define CRYPT_LEVEL_NONE 0x00000000 #define CRYPT_LEVEL_LOW 0x00000001 #define CRYPT_LEVEL_CLIENT_COMPATIBLE 0x00000002 #define CRYPT_LEVEL_HIGH 0x00000003 #define CRYPT_LEVEL_FIPS 0x00000004 /* sec */ struct xrdp_sec { struct xrdp_rdp *rdp_layer; /* owner */ struct xrdp_mcs *mcs_layer; struct xrdp_fastpath *fastpath_layer; struct xrdp_channel *chan_layer; char server_random[32]; char client_random[256]; char client_crypt_random[256 + 8]; /* 64 + 8, 256 + 8 */ struct stream client_mcs_data; struct stream server_mcs_data; int decrypt_use_count; int encrypt_use_count; char decrypt_key[16]; char encrypt_key[16]; char decrypt_update_key[16]; char encrypt_update_key[16]; int crypt_method; int rc4_key_len; /* 8 = 40 bit, 16 = 128 bit */ int crypt_level; char sign_key[16]; void *decrypt_rc4_info; void *encrypt_rc4_info; char pub_exp[4]; char pub_mod[256]; char pub_sig[64]; char pri_exp[256]; int rsa_key_bytes; /* 64 or 256 , 0 = no rdp security */ char fips_encrypt_key[24]; char fips_decrypt_key[24]; char fips_sign_key[20]; void *encrypt_fips_info; void *decrypt_fips_info; void *sign_fips_info; int is_security_header_present; /* boolean */ }; /* channel */ struct xrdp_channel { struct xrdp_sec *sec_layer; struct xrdp_mcs *mcs_layer; }; /* rdp */ struct xrdp_rdp { struct xrdp_session *session; struct xrdp_sec *sec_layer; int share_id; int mcs_channel; struct xrdp_client_info client_info; struct xrdp_mppc_enc *mppc_enc; void *rfx_enc; }; /* state */ struct xrdp_orders_state { int last_order; /* last order sent */ int clip_left; /* RDP_ORDER_BOUNDS, RDP_ORDER_LASTBOUNDS */ int clip_top; int clip_right; int clip_bottom; int rect_x; /* RDP_ORDER_RECT */ int rect_y; int rect_cx; int rect_cy; int rect_color; int scr_blt_x; /* RDP_ORDER_SCREENBLT */ int scr_blt_y; int scr_blt_cx; int scr_blt_cy; int scr_blt_rop; int scr_blt_srcx; int scr_blt_srcy; int pat_blt_x; /* RDP_ORDER_PATBLT */ int pat_blt_y; int pat_blt_cx; int pat_blt_cy; int pat_blt_rop; int pat_blt_bg_color; int pat_blt_fg_color; struct xrdp_brush pat_blt_brush; int dest_blt_x; /* RDP_ORDER_DESTBLT */ int dest_blt_y; int dest_blt_cx; int dest_blt_cy; int dest_blt_rop; int line_mix_mode; /* RDP_ORDER_LINE */ int line_startx; int line_starty; int line_endx; int line_endy; int line_bg_color; int line_rop; struct xrdp_pen line_pen; int mem_blt_color_table; /* RDP_ORDER_MEMBLT */ int mem_blt_cache_id; int mem_blt_x; int mem_blt_y; int mem_blt_cx; int mem_blt_cy; int mem_blt_rop; int mem_blt_srcx; int mem_blt_srcy; int mem_blt_cache_idx; int text_font; /* RDP_ORDER_TEXT2 */ int text_flags; int text_unknown; int text_mixmode; int text_fg_color; int text_bg_color; int text_clip_left; int text_clip_top; int text_clip_right; int text_clip_bottom; int text_box_left; int text_box_top; int text_box_right; int text_box_bottom; int text_x; int text_y; int text_len; char *text_data; int com_blt_srcidx; /* RDP_ORDER_COMPOSITE */ /* 2 */ int com_blt_srcformat; /* 2 */ int com_blt_srcwidth; /* 2 */ int com_blt_srcrepeat; /* 1 */ int com_blt_srctransform[10]; /* 40 */ int com_blt_mskflags; /* 1 */ int com_blt_mskidx; /* 2 */ int com_blt_mskformat; /* 2 */ int com_blt_mskwidth; /* 2 */ int com_blt_mskrepeat; /* 1 */ int com_blt_op; /* 1 */ int com_blt_srcx; /* 2 */ int com_blt_srcy; /* 2 */ int com_blt_mskx; /* 2 */ int com_blt_msky; /* 2 */ int com_blt_dstx; /* 2 */ int com_blt_dsty; /* 2 */ int com_blt_width; /* 2 */ int com_blt_height; /* 2 */ int com_blt_dstformat; /* 2 */ }; /* orders */ struct xrdp_orders { struct stream *out_s; struct xrdp_rdp *rdp_layer; struct xrdp_session *session; struct xrdp_wm *wm; char *order_count_ptr; /* pointer to count, set when sending */ int order_count; int order_level; /* inc for every call to xrdp_orders_init */ struct xrdp_orders_state orders_state; void *jpeg_han; int rfx_min_pixel; /* shared */ struct stream *s; struct stream *temp_s; }; #define PROTO_RDP_40 1 #define PROTO_RDP_50 2 struct xrdp_mppc_enc { int protocol_type; /* PROTO_RDP_40, PROTO_RDP_50 etc */ char *historyBuffer; /* contains uncompressed data */ char *outputBuffer; /* contains compressed data */ char *outputBufferPlus; int historyOffset; /* next free slot in historyBuffer */ int buf_len; /* length of historyBuffer, protocol dependent */ int bytes_in_opb; /* compressed bytes available in outputBuffer */ int flags; /* PACKET_COMPRESSED, PACKET_AT_FRONT, PACKET_FLUSHED etc */ int flagsHold; int first_pkt; /* this is the first pkt passing through enc */ tui16 *hash_table; }; int compress_rdp(struct xrdp_mppc_enc *enc, tui8 *srcData, int len); struct xrdp_mppc_enc * mppc_enc_new(int protocol_type); void mppc_enc_free(struct xrdp_mppc_enc *enc); /* xrdp_tcp.c */ struct xrdp_tcp * xrdp_tcp_create(struct xrdp_iso *owner, struct trans *trans); void xrdp_tcp_delete(struct xrdp_tcp *self); int xrdp_tcp_init(struct xrdp_tcp *self, struct stream *s); int xrdp_tcp_recv(struct xrdp_tcp *self, struct stream *s, int len); int xrdp_tcp_send(struct xrdp_tcp *self, struct stream *s); /* xrdp_iso.c */ struct xrdp_iso * xrdp_iso_create(struct xrdp_mcs *owner, struct trans *trans); void xrdp_iso_delete(struct xrdp_iso *self); int xrdp_iso_init(struct xrdp_iso *self, struct stream *s); int xrdp_iso_recv(struct xrdp_iso *self, struct stream *s); int xrdp_iso_send(struct xrdp_iso *self, struct stream *s); int xrdp_iso_incoming(struct xrdp_iso *self); int xrdp_iso_detect_tpkt(struct xrdp_iso *self, struct stream *s); /* xrdp_mcs.c */ struct xrdp_mcs * xrdp_mcs_create(struct xrdp_sec *owner, struct trans *trans, struct stream *client_mcs_data, struct stream *server_mcs_data); void xrdp_mcs_delete(struct xrdp_mcs *self); int xrdp_mcs_init(struct xrdp_mcs *self, struct stream *s); int xrdp_mcs_recv(struct xrdp_mcs *self, struct stream *s, int *chan); int xrdp_mcs_send(struct xrdp_mcs *self, struct stream *s, int chan); int xrdp_mcs_incoming(struct xrdp_mcs *self); int xrdp_mcs_disconnect(struct xrdp_mcs *self); /* xrdp_sec.c */ struct xrdp_sec * xrdp_sec_create(struct xrdp_rdp *owner, struct trans *trans); void xrdp_sec_delete(struct xrdp_sec *self); int xrdp_sec_init(struct xrdp_sec *self, struct stream *s); int xrdp_sec_get_fastpath_bytes(struct xrdp_sec *self); int xrdp_sec_init_fastpath(struct xrdp_sec *self, struct stream *s); int xrdp_sec_send_fastpath(struct xrdp_sec *self, struct stream *s); int xrdp_sec_recv_fastpath(struct xrdp_sec *self, struct stream *s); int xrdp_sec_recv(struct xrdp_sec *self, struct stream *s, int *chan); int xrdp_sec_send(struct xrdp_sec *self, struct stream *s, int chan); int xrdp_sec_process_mcs_data(struct xrdp_sec *self); int xrdp_sec_incoming(struct xrdp_sec *self); int xrdp_sec_disconnect(struct xrdp_sec *self); /* xrdp_rdp.c */ struct xrdp_rdp * xrdp_rdp_create(struct xrdp_session *session, struct trans *trans); void xrdp_rdp_delete(struct xrdp_rdp *self); int xrdp_rdp_init(struct xrdp_rdp *self, struct stream *s); int xrdp_rdp_init_data(struct xrdp_rdp *self, struct stream *s); int xrdp_rdp_get_fastpath_bytes(struct xrdp_rdp *self); int xrdp_rdp_init_fastpath(struct xrdp_rdp *self, struct stream *s); int xrdp_rdp_recv(struct xrdp_rdp *self, struct stream *s, int *code); int xrdp_rdp_send(struct xrdp_rdp *self, struct stream *s, int pdu_type); int xrdp_rdp_send_data(struct xrdp_rdp *self, struct stream *s, int data_pdu_type); int xrdp_rdp_send_fastpath(struct xrdp_rdp *self, struct stream *s, int data_pdu_type); int xrdp_rdp_send_data_update_sync(struct xrdp_rdp *self); int xrdp_rdp_incoming(struct xrdp_rdp *self); int xrdp_rdp_process_data(struct xrdp_rdp *self, struct stream *s); int xrdp_rdp_disconnect(struct xrdp_rdp *self); int xrdp_rdp_send_deactivate(struct xrdp_rdp *self); int xrdp_rdp_send_session_info(struct xrdp_rdp *self, const char *data, int data_bytes); /* xrdp_orders.c */ struct xrdp_orders * xrdp_orders_create(struct xrdp_session *session, struct xrdp_rdp *rdp_layer); void xrdp_orders_delete(struct xrdp_orders *self); int xrdp_orders_reset(struct xrdp_orders *self); int xrdp_orders_init(struct xrdp_orders *self); int xrdp_orders_send(struct xrdp_orders *self); int xrdp_orders_force_send(struct xrdp_orders *self); int xrdp_orders_check(struct xrdp_orders *self, int max_size); int xrdp_orders_rect(struct xrdp_orders *self, int x, int y, int cx, int cy, int color, struct xrdp_rect *rect); int xrdp_orders_screen_blt(struct xrdp_orders *self, int x, int y, int cx, int cy, int srcx, int srcy, int rop, struct xrdp_rect *rect); int xrdp_orders_pat_blt(struct xrdp_orders *self, int x, int y, int cx, int cy, int rop, int bg_color, int fg_color, struct xrdp_brush *brush, struct xrdp_rect *rect); int xrdp_orders_dest_blt(struct xrdp_orders *self, int x, int y, int cx, int cy, int rop, struct xrdp_rect *rect); int xrdp_orders_line(struct xrdp_orders *self, int mix_mode, int startx, int starty, int endx, int endy, int rop, int bg_color, struct xrdp_pen *pen, struct xrdp_rect *rect); int xrdp_orders_mem_blt(struct xrdp_orders *self, int cache_id, int color_table, int x, int y, int cx, int cy, int rop, int srcx, int srcy, int cache_idx, struct xrdp_rect *rect); int xrdp_orders_composite_blt(struct xrdp_orders *self, int srcidx, int srcformat, int srcwidth, int srcrepeat, int *srctransform, int mskflags, int mskidx, int mskformat, int mskwidth, int mskrepeat, int op, int srcx, int srcy, int mskx, int msky, int dstx, int dsty, int width, int height, int dstformat, struct xrdp_rect *rect); int xrdp_orders_text(struct xrdp_orders *self, int font, int flags, int mixmode, int fg_color, int bg_color, int clip_left, int clip_top, int clip_right, int clip_bottom, int box_left, int box_top, int box_right, int box_bottom, int x, int y, char *data, int data_len, struct xrdp_rect *rect); int xrdp_orders_send_palette(struct xrdp_orders *self, int *palette, int cache_id); int xrdp_orders_send_raw_bitmap(struct xrdp_orders *self, int width, int height, int bpp, char *data, int cache_id, int cache_idx); int xrdp_orders_send_bitmap(struct xrdp_orders *self, int width, int height, int bpp, char *data, int cache_id, int cache_idx); int xrdp_orders_send_font(struct xrdp_orders *self, struct xrdp_font_char *font_char, int font_index, int char_index); int xrdp_orders_send_raw_bitmap2(struct xrdp_orders *self, int width, int height, int bpp, char *data, int cache_id, int cache_idx); int xrdp_orders_send_bitmap2(struct xrdp_orders *self, int width, int height, int bpp, char *data, int cache_id, int cache_idx, int hints); int xrdp_orders_send_bitmap3(struct xrdp_orders *self, int width, int height, int bpp, char *data, int cache_id, int cache_idx, int hints); int xrdp_orders_send_brush(struct xrdp_orders *self, int width, int height, int bpp, int type, int size, char *data, int cache_id); int xrdp_orders_send_create_os_surface(struct xrdp_orders *self, int id, int width, int height, struct list *del_list); int xrdp_orders_send_switch_os_surface(struct xrdp_orders *self, int id); /* xrdp_bitmap_compress.c */ int xrdp_bitmap_compress(char *in_data, int width, int height, struct stream *s, int bpp, int byte_limit, int start_line, struct stream *temp_s, int e); int xrdp_bitmap32_compress(char *in_data, int width, int height, struct stream *s, int bpp, int byte_limit, int start_line, struct stream *temp_s, int e, int flags); int xrdp_jpeg_compress(void *handle, char *in_data, int width, int height, struct stream *s, int bpp, int byte_limit, int start_line, struct stream *temp_s, int e, int quality); int xrdp_codec_jpeg_compress(void *handle, int format, /* input data format */ char *inp_data, /* input data */ int width, /* width of inp_data */ int height, /* height of inp_data */ int stride, /* inp_data stride, in bytes*/ int x, /* x loc in inp_data */ int y, /* y loc in inp_data */ int cx, /* width of area to compress */ int cy, /* height of area to compress */ int quality, /* higher numbers compress less */ char *out_data, /* dest for jpg image */ int *io_len /* length of out_data and on return */ /* len of compressed data */ ); void * xrdp_jpeg_init(void); int xrdp_jpeg_deinit(void *handle); /* xrdp_channel.c */ struct xrdp_channel* xrdp_channel_create(struct xrdp_sec *owner, struct xrdp_mcs *mcs_layer); void xrdp_channel_delete(struct xrdp_channel *self); int xrdp_channel_init(struct xrdp_channel *self, struct stream *s); int xrdp_channel_send(struct xrdp_channel *self, struct stream *s, int channel_id, int total_data_len, int flags); int xrdp_channel_process(struct xrdp_channel *self, struct stream *s, int chanid); /* xrdp_fastpath.c */ struct xrdp_fastpath * xrdp_fastpath_create(struct xrdp_sec *owner, struct trans *trans); void xrdp_fastpath_delete(struct xrdp_fastpath *self); int xrdp_fastpath_recv(struct xrdp_fastpath *self, struct stream *s); int xrdp_fastpath_process_input_event(struct xrdp_fastpath *self, struct stream *s); int xrdp_fastpath_init(struct xrdp_fastpath *self, struct stream *s); int xrdp_fastpath_send(struct xrdp_fastpath *self, struct stream *s); /* xrdp_caps.c */ int xrdp_caps_send_demand_active(struct xrdp_rdp *self); int xrdp_caps_process_confirm_active(struct xrdp_rdp *self, struct stream *s); #endif xrdp-0.9.5/libxrdp/xrdp_iso.c000644 001751 001751 00000025633 13206023530 016064 0ustar00metameta000000 000000 /** * xrdp: A Remote Desktop Protocol server. * * Copyright (C) Jay Sorg 2004-2014 * Copyright (C) Idan Freiberg 2013-2014 * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. * * iso layer */ #if defined(HAVE_CONFIG_H) #include #endif #include "libxrdp.h" #include "log.h" #define LOG_LEVEL 1 #define LLOG(_level, _args) \ do { if (_level < LOG_LEVEL) { g_write _args ; } } while (0) #define LLOGLN(_level, _args) \ do { if (_level < LOG_LEVEL) { g_writeln _args ; } } while (0) #define LHEXDUMP(_level, _args) \ do { if (_level < LOG_LEVEL) { g_hexdump _args ; } } while (0) /*****************************************************************************/ struct xrdp_iso * xrdp_iso_create(struct xrdp_mcs *owner, struct trans *trans) { struct xrdp_iso *self; LLOGLN(10, (" in xrdp_iso_create")); self = (struct xrdp_iso *) g_malloc(sizeof(struct xrdp_iso), 1); self->mcs_layer = owner; self->trans = trans; LLOGLN(10, (" out xrdp_iso_create")); return self; } /*****************************************************************************/ void xrdp_iso_delete(struct xrdp_iso *self) { if (self == 0) { return; } g_free(self); } /*****************************************************************************/ /* returns error */ static int xrdp_iso_negotiate_security(struct xrdp_iso *self) { int rv = 0; struct xrdp_client_info *client_info = &(self->mcs_layer->sec_layer->rdp_layer->client_info); self->selectedProtocol = client_info->security_layer; switch (client_info->security_layer) { case PROTOCOL_RDP: break; case PROTOCOL_SSL: if (self->requestedProtocol & PROTOCOL_SSL) { if (!g_file_readable(client_info->certificate) || !g_file_readable(client_info->key_file)) { /* certificate or privkey is not readable */ log_message(LOG_LEVEL_DEBUG, "No readable certificates or " "private keys, cannot accept TLS connections"); self->failureCode = SSL_CERT_NOT_ON_SERVER; rv = 1; /* error */ } else { self->selectedProtocol = PROTOCOL_SSL; } } else { self->failureCode = SSL_REQUIRED_BY_SERVER; rv = 1; /* error */ } break; case PROTOCOL_HYBRID: case PROTOCOL_HYBRID_EX: default: if ((self->requestedProtocol & PROTOCOL_SSL) && g_file_readable(client_info->certificate) && g_file_readable(client_info->key_file)) { /* that's a patch since we don't support CredSSP for now */ self->selectedProtocol = PROTOCOL_SSL; } else { self->selectedProtocol = PROTOCOL_RDP; } break; } log_message(LOG_LEVEL_DEBUG, "Security layer: requested %d, selected %d", self->requestedProtocol, self->selectedProtocol); return rv; } /*****************************************************************************/ /* returns error */ static int xrdp_iso_process_rdp_neg_req(struct xrdp_iso *self, struct stream *s) { int flags; int len; in_uint8(s, flags); if (flags != 0x0 && flags != 0x8 && flags != 0x1) { LLOGLN(10, ("xrdp_iso_process_rdpNegReq: error, flags: %x",flags)); return 1; } in_uint16_le(s, len); if (len != 8) { LLOGLN(10, ("xrdp_iso_process_rdpNegReq: error, length: %x",len)); return 1; } in_uint32_le(s, self->requestedProtocol); if (self->requestedProtocol > 0xb) { LLOGLN(10, ("xrdp_iso_process_rdpNegReq: error, requestedProtocol: %x", self->requestedProtocol)); return 1; } return 0; } /*****************************************************************************/ /* returns error */ static int xrdp_iso_recv_msg(struct xrdp_iso *self, struct stream *s, int *code, int *len) { int ver; int plen; *code = 0; *len = 0; if (s != self->trans->in_s) { LLOGLN(10, ("xrdp_iso_recv_msg error logic")); } in_uint8(s, ver); if (ver != 3) { LLOGLN(10, ("xrdp_iso_recv_msg: bad ver")); LHEXDUMP(10, (s->data, 4)); return 1; } in_uint8s(s, 1); in_uint16_be(s, plen); if (plen < 4) { return 1; } if (!s_check_rem(s, 2)) { return 1; } in_uint8(s, *len); in_uint8(s, *code); if (*code == ISO_PDU_DT) { if (!s_check_rem(s, 1)) { return 1; } in_uint8s(s, 1); } else { if (!s_check_rem(s, 5)) { return 1; } in_uint8s(s, 5); } return 0; } /*****************************************************************************/ /* returns error */ int xrdp_iso_recv(struct xrdp_iso *self, struct stream *s) { int code; int len; LLOGLN(10, (" in xrdp_iso_recv")); if (xrdp_iso_recv_msg(self, s, &code, &len) != 0) { LLOGLN(10, (" out xrdp_iso_recv xrdp_iso_recv_msg return non zero")); return 1; } if (code != ISO_PDU_DT || len != 2) { LLOGLN(10, (" out xrdp_iso_recv code != ISO_PDU_DT or length != 2")); return 1; } LLOGLN(10, (" out xrdp_iso_recv")); return 0; } /*****************************************************************************/ static int xrdp_iso_send_cc(struct xrdp_iso *self) { struct stream *s; char *holdp; char *len_ptr; char *len_indicator_ptr; int len; int len_indicator; make_stream(s); init_stream(s, 8192); holdp = s->p; /* tpkt */ out_uint8(s, 3); /* version */ out_uint8(s, 0); /* pad */ len_ptr = s->p; out_uint16_be(s, 0); /* length, set later */ /* iso */ len_indicator_ptr = s->p; out_uint8(s, 0); /* length indicator, set later */ out_uint8(s, ISO_PDU_CC); /* Connection Confirm PDU */ out_uint16_be(s, 0); out_uint16_be(s, 0x1234); out_uint8(s, 0); /* rdpNegData */ if (self->rdpNegData) { if (self->failureCode) { out_uint8(s, RDP_NEG_FAILURE); out_uint8(s, 0); /* no flags */ out_uint16_le(s, 8); /* must be 8 */ out_uint32_le(s, self->failureCode); /* failure code */ } else { out_uint8(s, RDP_NEG_RSP); //TODO: hardcoded flags out_uint8(s, EXTENDED_CLIENT_DATA_SUPPORTED); /* flags */ out_uint16_le(s, 8); /* must be 8 */ out_uint32_le(s, self->selectedProtocol); /* selected protocol */ } } s_mark_end(s); len = (int) (s->end - holdp); len_indicator = (int) (s->end - len_indicator_ptr) - 1; len_ptr[0] = len >> 8; len_ptr[1] = len; len_indicator_ptr[0] = len_indicator; if (trans_write_copy_s(self->trans, s) != 0) { free_stream(s); return 1; } free_stream(s); return 0; } /*****************************************************************************/ /* returns error */ int xrdp_iso_incoming(struct xrdp_iso *self) { int rv = 0; int code; int len; int cookie_index; int cc_type; char text[256]; char *pend; struct stream *s; LLOGLN(10, (" in xrdp_iso_incoming")); s = libxrdp_force_read(self->trans); if (s == 0) { return 1; } if (xrdp_iso_recv_msg(self, s, &code, &len) != 0) { LLOGLN(0, ("xrdp_iso_incoming: xrdp_iso_recv_msg returned non zero")); return 1; } if ((code != ISO_PDU_CR) || (len < 6)) { return 1; } /* process connection request */ pend = s->p + (len - 6); cookie_index = 0; while (s->p < pend) { in_uint8(s, cc_type); switch (cc_type) { default: break; case RDP_NEG_REQ: /* rdpNegReq 1 */ self->rdpNegData = 1; if (xrdp_iso_process_rdp_neg_req(self, s) != 0) { LLOGLN(0, ("xrdp_iso_incoming: xrdp_iso_process_rdpNegReq returned non zero")); return 1; } break; case RDP_CORRELATION_INFO: /* rdpCorrelationInfo 6 */ // TODO in_uint8s(s, 1 + 2 + 16 + 16); break; case 'C': /* Cookie routingToken */ while (s->p < pend) { text[cookie_index] = cc_type; cookie_index++; if (cookie_index > 255) { cookie_index = 255; } if ((s->p[0] == 0x0D) && (s->p[1] == 0x0A)) { in_uint8s(s, 2); text[cookie_index] = 0; cookie_index = 0; if (g_strlen(text) > 0) { } break; } in_uint8(s, cc_type); } break; } } /* negotiate client-server security layer */ rv = xrdp_iso_negotiate_security(self); /* send connection confirm back to client */ if (xrdp_iso_send_cc(self) != 0) { LLOGLN(0, ("xrdp_iso_incoming: xrdp_iso_send_cc returned non zero")); return 1; } LLOGLN(10, (" out xrdp_iso_incoming")); return rv; } /*****************************************************************************/ /* returns error */ int xrdp_iso_init(struct xrdp_iso *self, struct stream *s) { init_stream(s, 8192 * 4); /* 32 KB */ s_push_layer(s, iso_hdr, 7); return 0; } /*****************************************************************************/ /* returns error */ int xrdp_iso_send(struct xrdp_iso *self, struct stream *s) { int len; LLOGLN(10, (" in xrdp_iso_send")); s_pop_layer(s, iso_hdr); len = (int) (s->end - s->p); out_uint8(s, 3); out_uint8(s, 0); out_uint16_be(s, len); out_uint8(s, 2); out_uint8(s, ISO_PDU_DT); out_uint8(s, 0x80); if (trans_write_copy_s(self->trans, s) != 0) { return 1; } LLOGLN(10, (" out xrdp_iso_send")); return 0; } xrdp-0.9.5/libxrdp/xrdp_rdp.c000644 001751 001751 00000113756 13206023530 016063 0ustar00metameta000000 000000 /** * xrdp: A Remote Desktop Protocol server. * * Copyright (C) Jay Sorg 2004-2014 * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. * * rdp layer */ #if defined(HAVE_CONFIG_H) #include #endif #include "libxrdp.h" #include "log.h" #include "ssl_calls.h" #if defined(XRDP_NEUTRINORDP) #include #include #endif #define LOG_LEVEL 1 #define LLOG(_level, _args) \ do { if (_level < LOG_LEVEL) { g_write _args ; } } while (0) #define LLOGLN(_level, _args) \ do { if (_level < LOG_LEVEL) { g_writeln _args ; } } while (0) #define FASTPATH_FRAG_SIZE (16 * 1024 - 128) /*****************************************************************************/ static int xrdp_rdp_read_config(struct xrdp_client_info *client_info) { int index = 0; struct list *items = (struct list *)NULL; struct list *values = (struct list *)NULL; char *item = NULL; char *value = NULL; char cfg_file[256]; int pos; char *tmp = NULL; int tmp_length = 0; /* initialize (zero out) local variables: */ g_memset(cfg_file, 0, sizeof(char) * 256); items = list_create(); items->auto_free = 1; values = list_create(); values->auto_free = 1; g_snprintf(cfg_file, 255, "%s/xrdp.ini", XRDP_CFG_PATH); DEBUG(("cfg_file %s", cfg_file)); file_by_name_read_section(cfg_file, "globals", items, values); for (index = 0; index < items->count; index++) { item = (char *)list_get_item(items, index); value = (char *)list_get_item(values, index); DEBUG(("item %s value %s", item, value)); if (g_strcasecmp(item, "bitmap_cache") == 0) { client_info->use_bitmap_cache = g_text2bool(value); } else if (g_strcasecmp(item, "bitmap_compression") == 0) { client_info->use_bitmap_comp = g_text2bool(value); } else if (g_strcasecmp(item, "bulk_compression") == 0) { client_info->use_bulk_comp = g_text2bool(value); } else if (g_strcasecmp(item, "crypt_level") == 0) { if (g_strcasecmp(value, "none") == 0) { client_info->crypt_level = 0; } else if (g_strcasecmp(value, "low") == 0) { client_info->crypt_level = 1; } else if (g_strcasecmp(value, "medium") == 0) { client_info->crypt_level = 2; } else if (g_strcasecmp(value, "high") == 0) { client_info->crypt_level = 3; } else if (g_strcasecmp(value, "fips") == 0) { client_info->crypt_level = 4; } else { log_message(LOG_LEVEL_ALWAYS,"Warning: Your configured crypt level is " "undefined, 'high' will be used"); client_info->crypt_level = 3; } } else if (g_strcasecmp(item, "allow_channels") == 0) { client_info->channels_allowed = g_text2bool(value); if (client_info->channels_allowed == 0) { log_message(LOG_LEVEL_DEBUG,"Info - All channels are disabled"); } } else if (g_strcasecmp(item, "allow_multimon") == 0) { client_info->multimon = g_text2bool(value); if (client_info->multimon == 0) { log_message(LOG_LEVEL_DEBUG,"Info - Multi monitor server support disabled"); } } else if (g_strcasecmp(item, "max_bpp") == 0) { client_info->max_bpp = g_atoi(value); } else if (g_strcasecmp(item, "rfx_min_pixel") == 0) { client_info->rfx_min_pixel = g_atoi(value); } else if (g_strcasecmp(item, "new_cursors") == 0) { client_info->pointer_flags = g_text2bool(value) == 0 ? 2 : 0; } else if (g_strcasecmp(item, "require_credentials") == 0) { client_info->require_credentials = g_text2bool(value); } else if (g_strcasecmp(item, "use_fastpath") == 0) { if (g_strcasecmp(value, "output") == 0) { client_info->use_fast_path = 1; } else if (g_strcasecmp(value, "input") == 0) { client_info->use_fast_path = 2; } else if (g_strcasecmp(value, "both") == 0) { client_info->use_fast_path = 3; } else if (g_strcasecmp(value, "none") == 0) { client_info->use_fast_path = 0; } else { log_message(LOG_LEVEL_ALWAYS,"Warning: Your configured fastpath level is " "undefined, fastpath will not be used"); client_info->use_fast_path = 0; } } else if (g_strcasecmp(item, "ssl_protocols") == 0) { /* put leading/trailing comma to properly detect "TLSv1" without regex */ tmp_length = g_strlen(value) + 3; tmp = g_new(char, tmp_length); g_snprintf(tmp, tmp_length, "%s%s%s", ",", value, ","); /* replace all spaces with comma */ /* to accept space after comma */ while ((pos = g_pos(tmp, " ")) != -1) { tmp[pos] = ','; } ssl_get_protocols_from_string(tmp, &(client_info->ssl_protocols)); g_free(tmp); } else if (g_strcasecmp(item, "tls_ciphers") == 0) { client_info->tls_ciphers = g_strdup(value); } else if (g_strcasecmp(item, "security_layer") == 0) { if (g_strcasecmp(value, "rdp") == 0) { client_info->security_layer = PROTOCOL_RDP; } else if (g_strcasecmp(value, "tls") == 0) { client_info->security_layer = PROTOCOL_SSL; } else if (g_strcasecmp(value, "hybrid") == 0) { client_info->security_layer = PROTOCOL_SSL | PROTOCOL_HYBRID; } else if (g_strcasecmp(value, "negotiate") == 0) { client_info->security_layer = PROTOCOL_SSL | PROTOCOL_HYBRID | PROTOCOL_HYBRID_EX; } else { log_message(LOG_LEVEL_ERROR, "security_layer=%s is not " "recognized, will use security_layer=negotiate", value); client_info->security_layer = PROTOCOL_SSL | PROTOCOL_HYBRID | PROTOCOL_HYBRID_EX; } } else if (g_strcasecmp(item, "certificate") == 0) { g_memset(client_info->certificate, 0, sizeof(char) * 1024); if (g_strlen(value) == 0) { /* default certificate path */ g_snprintf(client_info->certificate, 1023, "%s/cert.pem", XRDP_CFG_PATH); log_message(LOG_LEVEL_INFO, "Using default X.509 certificate: %s", client_info->certificate); } else if (value[0] != '/') { /* default certificate path */ g_snprintf(client_info->certificate, 1023, "%s/cert.pem", XRDP_CFG_PATH); log_message(LOG_LEVEL_WARNING, "X.509 certificate should use absolute path, using " "default instead: %s", client_info->certificate); } else { /* use user defined certificate */ g_strncpy(client_info->certificate, value, 1023); } if (!g_file_readable(client_info->certificate)) { log_message(LOG_LEVEL_ERROR, "Cannot read certificate file %s: %s", client_info->certificate, g_get_strerror()); } } else if (g_strcasecmp(item, "key_file") == 0) { g_memset(client_info->key_file, 0, sizeof(char) * 1024); if (g_strlen(value) == 0) { /* default key_file path */ g_snprintf(client_info->key_file, 1023, "%s/key.pem", XRDP_CFG_PATH); log_message(LOG_LEVEL_INFO, "Using default X.509 key file: %s", client_info->key_file); } else if (value[0] != '/') { /* default key_file path */ g_snprintf(client_info->key_file, 1023, "%s/key.pem", XRDP_CFG_PATH); log_message(LOG_LEVEL_WARNING, "X.509 key file should use absolute path, using " "default instead: %s", client_info->key_file); } else { /* use user defined key_file */ g_strncpy(client_info->key_file, value, 1023); } if (!g_file_readable(client_info->key_file)) { log_message(LOG_LEVEL_ERROR, "Cannot read private key file %s: %s", client_info->key_file, g_get_strerror()); } } } list_delete(items); list_delete(values); return 0; } #if defined(XRDP_NEUTRINORDP) /*****************************************************************************/ static void cpuid(tui32 info, tui32 *eax, tui32 *ebx, tui32 *ecx, tui32 *edx) { #ifdef __GNUC__ #if defined(__i386__) || defined(__x86_64__) __asm volatile ( /* The EBX (or RBX register on x86_64) is used for the PIC base address and must not be corrupted by our inline assembly. */ #if defined(__i386__) "mov %%ebx, %%esi;" "cpuid;" "xchg %%ebx, %%esi;" #else "mov %%rbx, %%rsi;" "cpuid;" "xchg %%rbx, %%rsi;" #endif : "=a" (*eax), "=S" (*ebx), "=c" (*ecx), "=d" (*edx) : "0" (info) ); #endif #endif } /*****************************************************************************/ static tui32 xrdp_rdp_detect_cpu(void) { tui32 eax; tui32 ebx; tui32 ecx; tui32 edx; tui32 cpu_opt; eax = 0; ebx = 0; ecx = 0; edx = 0; cpu_opt = 0; cpuid(1, &eax, &ebx, &ecx, &edx); if (edx & (1 << 26)) { DEBUG(("SSE2 detected")); cpu_opt |= CPU_SSE2; } return cpu_opt; } #endif /*****************************************************************************/ struct xrdp_rdp * xrdp_rdp_create(struct xrdp_session *session, struct trans *trans) { struct xrdp_rdp *self = (struct xrdp_rdp *)NULL; int bytes; DEBUG(("in xrdp_rdp_create")); self = (struct xrdp_rdp *)g_malloc(sizeof(struct xrdp_rdp), 1); self->session = session; self->share_id = 66538; /* read ini settings */ xrdp_rdp_read_config(&self->client_info); /* create sec layer */ self->sec_layer = xrdp_sec_create(self, trans); /* default 8 bit v1 color bitmap cache entries and size */ self->client_info.cache1_entries = 600; self->client_info.cache1_size = 256; self->client_info.cache2_entries = 300; self->client_info.cache2_size = 1024; self->client_info.cache3_entries = 262; self->client_info.cache3_size = 4096; /* load client ip info */ bytes = sizeof(self->client_info.client_ip) - 1; g_write_ip_address(trans->sck, self->client_info.client_ip, bytes); self->mppc_enc = mppc_enc_new(PROTO_RDP_50); #if defined(XRDP_NEUTRINORDP) self->rfx_enc = rfx_context_new(); rfx_context_set_cpu_opt(self->rfx_enc, xrdp_rdp_detect_cpu()); #endif self->client_info.size = sizeof(self->client_info); DEBUG(("out xrdp_rdp_create")); return self; } /*****************************************************************************/ void xrdp_rdp_delete(struct xrdp_rdp *self) { if (self == 0) { return; } xrdp_sec_delete(self->sec_layer); mppc_enc_free(self->mppc_enc); #if defined(XRDP_NEUTRINORDP) rfx_context_free((RFX_CONTEXT *)(self->rfx_enc)); #endif g_free(self->client_info.tls_ciphers); g_free(self); } /*****************************************************************************/ int xrdp_rdp_init(struct xrdp_rdp *self, struct stream *s) { if (xrdp_sec_init(self->sec_layer, s) != 0) { return 1; } s_push_layer(s, rdp_hdr, 6); return 0; } /*****************************************************************************/ int xrdp_rdp_init_data(struct xrdp_rdp *self, struct stream *s) { if (xrdp_sec_init(self->sec_layer, s) != 0) { return 1; } s_push_layer(s, rdp_hdr, 18); return 0; } /*****************************************************************************/ /* returns error */ int xrdp_rdp_recv(struct xrdp_rdp *self, struct stream *s, int *code) { int error = 0; int len = 0; int pdu_code = 0; int chan = 0; const tui8 *header; DEBUG(("in xrdp_rdp_recv")); if (s->next_packet == 0 || s->next_packet >= s->end) { /* check for fastpath first */ header = (const tui8 *) (s->p); if (header[0] != 0x3) { if (xrdp_sec_recv_fastpath(self->sec_layer, s) != 0) { return 1; } /* next_packet gets set in xrdp_sec_recv_fastpath */ *code = 2; // special code for fastpath input DEBUG(("out (fastpath) xrdp_rdp_recv")); return 0; } /* not fastpath, do tpkt */ chan = 0; error = xrdp_sec_recv(self->sec_layer, s, &chan); if (error == -1) /* special code for send demand active */ { s->next_packet = 0; *code = -1; DEBUG(("out (1) xrdp_rdp_recv")); return 0; } if (error != 0) { DEBUG(("out xrdp_rdp_recv error")); g_writeln("xrdp_rdp_recv: xrdp_sec_recv failed"); return 1; } if ((chan != MCS_GLOBAL_CHANNEL) && (chan > 0)) { if (chan > MCS_GLOBAL_CHANNEL) { if (xrdp_channel_process(self->sec_layer->chan_layer, s, chan) != 0) { g_writeln("xrdp_channel_process returned unhandled error") ; } } else { if (chan != 1) { g_writeln("Wrong channel Id to be handled by xrdp_channel_process %d", chan); } } s->next_packet = 0; *code = 0; DEBUG(("out (2) xrdp_rdp_recv")); return 0; } s->next_packet = s->p; } else { DEBUG(("xrdp_rdp_recv stream not touched")) s->p = s->next_packet; } if (!s_check_rem(s, 6)) { s->next_packet = 0; *code = 0; DEBUG(("out (3) xrdp_rdp_recv")); len = (int)(s->end - s->p); g_writeln("xrdp_rdp_recv: bad RDP packet, length [%d]", len); return 0; } else { in_uint16_le(s, len); /*g_writeln("New len received : %d next packet: %d s_end: %d",len,s->next_packet,s->end); */ in_uint16_le(s, pdu_code); *code = pdu_code & 0xf; in_uint8s(s, 2); /* mcs user id */ s->next_packet += len; DEBUG(("out (4) xrdp_rdp_recv")); return 0; } } /*****************************************************************************/ int xrdp_rdp_send(struct xrdp_rdp *self, struct stream *s, int pdu_type) { int len = 0; DEBUG(("in xrdp_rdp_send")); s_pop_layer(s, rdp_hdr); len = s->end - s->p; out_uint16_le(s, len); out_uint16_le(s, 0x10 | pdu_type); out_uint16_le(s, self->mcs_channel); if (xrdp_sec_send(self->sec_layer, s, MCS_GLOBAL_CHANNEL) != 0) { DEBUG(("out xrdp_rdp_send error")); return 1; } DEBUG(("out xrdp_rdp_send")); return 0; } /*****************************************************************************/ int xrdp_rdp_send_data(struct xrdp_rdp *self, struct stream *s, int data_pdu_type) { int len; int ctype; int clen; int dlen; int pdulen; int pdutype; int tocomplen; int iso_offset; int mcs_offset; int sec_offset; int rdp_offset; struct stream ls; struct xrdp_mppc_enc *mppc_enc; DEBUG(("in xrdp_rdp_send_data")); s_pop_layer(s, rdp_hdr); len = (int)(s->end - s->p); pdutype = 0x10 | RDP_PDU_DATA; pdulen = len; dlen = len; ctype = 0; clen = len; tocomplen = pdulen - 18; if (self->client_info.rdp_compression && self->session->up_and_running) { mppc_enc = self->mppc_enc; if (compress_rdp(mppc_enc, (tui8 *)(s->p + 18), tocomplen)) { DEBUG(("mppc_encode ok flags 0x%x bytes_in_opb %d historyOffset %d " "tocomplen %d", mppc_enc->flags, mppc_enc->bytes_in_opb, mppc_enc->historyOffset, tocomplen)); clen = mppc_enc->bytes_in_opb + 18; pdulen = clen; ctype = mppc_enc->flags; iso_offset = (int)(s->iso_hdr - s->data); mcs_offset = (int)(s->mcs_hdr - s->data); sec_offset = (int)(s->sec_hdr - s->data); rdp_offset = (int)(s->rdp_hdr - s->data); /* outputBuffer has 64 bytes preceding it */ ls.data = mppc_enc->outputBuffer - (rdp_offset + 18); ls.p = ls.data + rdp_offset; ls.end = ls.p + clen; ls.size = clen; ls.iso_hdr = ls.data + iso_offset; ls.mcs_hdr = ls.data + mcs_offset; ls.sec_hdr = ls.data + sec_offset; ls.rdp_hdr = ls.data + rdp_offset; ls.channel_hdr = 0; ls.next_packet = 0; s = &ls; } else { LLOGLN(10, ("xrdp_rdp_send_data: mppc_encode not ok " "type %d flags %d", mppc_enc->protocol_type, mppc_enc->flags)); } } out_uint16_le(s, pdulen); out_uint16_le(s, pdutype); out_uint16_le(s, self->mcs_channel); out_uint32_le(s, self->share_id); out_uint8(s, 0); out_uint8(s, 1); out_uint16_le(s, dlen); out_uint8(s, data_pdu_type); out_uint8(s, ctype); out_uint16_le(s, clen); if (xrdp_sec_send(self->sec_layer, s, MCS_GLOBAL_CHANNEL) != 0) { DEBUG(("out xrdp_rdp_send_data error")); return 1; } DEBUG(("out xrdp_rdp_send_data")); return 0; } /*****************************************************************************/ /* returns the fastpath rdp byte count */ int xrdp_rdp_get_fastpath_bytes(struct xrdp_rdp *self) { if (self->client_info.rdp_compression) { return 4; } return 3; } /*****************************************************************************/ int xrdp_rdp_init_fastpath(struct xrdp_rdp *self, struct stream *s) { if (xrdp_sec_init_fastpath(self->sec_layer, s) != 0) { return 1; } if (self->client_info.rdp_compression) { s_push_layer(s, rdp_hdr, 4); } else { s_push_layer(s, rdp_hdr, 3); } return 0; } /*****************************************************************************/ /* returns error */ /* 2.2.9.1.2.1 Fast-Path Update (TS_FP_UPDATE) * http://msdn.microsoft.com/en-us/library/cc240622.aspx */ int xrdp_rdp_send_fastpath(struct xrdp_rdp *self, struct stream *s, int data_pdu_type) { int updateHeader; int updateCode; int fragmentation; int compression; int comp_type; int comp_len; int no_comp_len; int send_len; int cont; int header_bytes; int sec_bytes; int to_comp_len; int sec_offset; int rdp_offset; struct stream frag_s; struct stream comp_s; struct stream send_s; struct xrdp_mppc_enc *mppc_enc; LLOGLN(10, ("xrdp_rdp_send_fastpath:")); s_pop_layer(s, rdp_hdr); updateCode = data_pdu_type; if (self->client_info.rdp_compression) { compression = 2; header_bytes = 4; } else { compression = 0; header_bytes = 3; } sec_bytes = xrdp_sec_get_fastpath_bytes(self->sec_layer); fragmentation = 0; frag_s = *s; sec_offset = (int)(frag_s.sec_hdr - frag_s.data); rdp_offset = (int)(frag_s.rdp_hdr - frag_s.data); cont = 1; while (cont) { comp_type = 0; send_s = frag_s; no_comp_len = (int)(frag_s.end - frag_s.p); if (no_comp_len > FASTPATH_FRAG_SIZE) { no_comp_len = FASTPATH_FRAG_SIZE; if (fragmentation == 0) { fragmentation = 2; /* FASTPATH_FRAGMENT_FIRST */ } else if (fragmentation == 2) { fragmentation = 3; /* FASTPATH_FRAGMENT_NEXT */ } } else { if (fragmentation != 0) { fragmentation = 1; /* FASTPATH_FRAGMENT_LAST */ } } send_len = no_comp_len; LLOGLN(10, ("xrdp_rdp_send_fastpath: no_comp_len %d fragmentation %d", no_comp_len, fragmentation)); if ((compression != 0) && (no_comp_len > header_bytes + 16)) { to_comp_len = no_comp_len - header_bytes; mppc_enc = self->mppc_enc; if (compress_rdp(mppc_enc, (tui8 *)(frag_s.p + header_bytes), to_comp_len)) { comp_len = mppc_enc->bytes_in_opb + header_bytes; LLOGLN(10, ("xrdp_rdp_send_fastpath: no_comp_len %d " "comp_len %d", no_comp_len, comp_len)); send_len = comp_len; comp_type = mppc_enc->flags; /* outputBuffer has 64 bytes preceding it */ g_memset(&comp_s, 0, sizeof(comp_s)); comp_s.data = mppc_enc->outputBuffer - (rdp_offset + header_bytes); comp_s.p = comp_s.data + rdp_offset; comp_s.end = comp_s.p + send_len; comp_s.size = send_len; comp_s.sec_hdr = comp_s.data + sec_offset; comp_s.rdp_hdr = comp_s.data + rdp_offset; send_s = comp_s; } else { LLOGLN(10, ("xrdp_rdp_send_fastpath: mppc_encode not ok " "type %d flags %d", mppc_enc->protocol_type, mppc_enc->flags)); } } updateHeader = (updateCode & 15) | ((fragmentation & 3) << 4) | ((compression & 3) << 6); out_uint8(&send_s, updateHeader); if (compression != 0) { out_uint8(&send_s, comp_type); } send_len -= header_bytes; out_uint16_le(&send_s, send_len); send_s.end = send_s.p + send_len; if (xrdp_sec_send_fastpath(self->sec_layer, &send_s) != 0) { LLOGLN(0, ("xrdp_rdp_send_fastpath: xrdp_fastpath_send failed")); return 1; } frag_s.p += no_comp_len; cont = frag_s.p < frag_s.end; frag_s.p -= header_bytes; frag_s.sec_hdr = frag_s.p - sec_bytes; frag_s.data = frag_s.sec_hdr; } return 0; } /*****************************************************************************/ int xrdp_rdp_send_data_update_sync(struct xrdp_rdp *self) { struct stream *s = (struct stream *)NULL; make_stream(s); init_stream(s, 8192); DEBUG(("in xrdp_rdp_send_data_update_sync")); if (self->client_info.use_fast_path & 1) /* fastpath output supported */ { LLOGLN(10, ("xrdp_rdp_send_data_update_sync: fastpath")); if (xrdp_rdp_init_fastpath(self, s) != 0) { free_stream(s); return 1; } } else /* slowpath */ { if (xrdp_rdp_init_data(self, s) != 0) { DEBUG(("out xrdp_rdp_send_data_update_sync error")); free_stream(s); return 1; } out_uint16_le(s, RDP_UPDATE_SYNCHRONIZE); out_uint16_le(s, 0); /* pad */ } s_mark_end(s); if (self->client_info.use_fast_path & 1) /* fastpath output supported */ { if (xrdp_rdp_send_fastpath(self, s, FASTPATH_UPDATETYPE_SYNCHRONIZE) != 0) { free_stream(s); return 1; } } else /* slowpath */ { if (xrdp_rdp_send_data(self, s, RDP_DATA_PDU_UPDATE) != 0) { DEBUG(("out xrdp_rdp_send_data_update_sync error")); free_stream(s); return 1; } } DEBUG(("out xrdp_rdp_send_data_update_sync")); free_stream(s); return 0; } /*****************************************************************************/ int xrdp_rdp_incoming(struct xrdp_rdp *self) { struct xrdp_iso *iso; iso = self->sec_layer->mcs_layer->iso_layer; DEBUG(("in xrdp_rdp_incoming")); if (xrdp_sec_incoming(self->sec_layer) != 0) { return 1; } self->mcs_channel = self->sec_layer->mcs_layer->userid + MCS_USERCHANNEL_BASE; DEBUG(("out xrdp_rdp_incoming mcs channel %d", self->mcs_channel)); g_strncpy(self->client_info.client_addr, iso->trans->addr, sizeof(self->client_info.client_addr) - 1); g_strncpy(self->client_info.client_port, iso->trans->port, sizeof(self->client_info.client_port) - 1); /* log TLS version and cipher of TLS connections */ if (iso->selectedProtocol > PROTOCOL_RDP) { log_message(LOG_LEVEL_INFO, "TLS connection established from %s port %s: %s with cipher %s", self->client_info.client_addr, self->client_info.client_port, iso->trans->ssl_protocol, iso->trans->cipher_name); } /* log non-TLS connections */ else { log_message(LOG_LEVEL_INFO, "Non-TLS connection established from %s port %s: " "encrypted with standard RDP security", self->client_info.client_addr, self->client_info.client_port); } return 0; } /*****************************************************************************/ static int xrdp_rdp_process_data_pointer(struct xrdp_rdp *self, struct stream *s) { return 0; } /*****************************************************************************/ /* RDP_DATA_PDU_INPUT */ static int xrdp_rdp_process_data_input(struct xrdp_rdp *self, struct stream *s) { int num_events; int index; int msg_type; int device_flags; int param1; int param2; int time; if (!s_check_rem(s, 4)) { return 1; } in_uint16_le(s, num_events); in_uint8s(s, 2); /* pad */ DEBUG(("in xrdp_rdp_process_data_input %d events", num_events)); for (index = 0; index < num_events; index++) { if (!s_check_rem(s, 12)) { return 1; } in_uint32_le(s, time); in_uint16_le(s, msg_type); in_uint16_le(s, device_flags); in_sint16_le(s, param1); in_sint16_le(s, param2); DEBUG(("xrdp_rdp_process_data_input event %4.4x flags %4.4x param1 %d " "param2 %d time %d", msg_type, device_flags, param1, param2, time)); if (self->session->callback != 0) { /* msg_type can be RDP_INPUT_SYNCHRONIZE - 0 RDP_INPUT_SCANCODE - 4 RDP_INPUT_MOUSE - 0x8001 RDP_INPUT_MOUSEX - 0x8002 */ /* call to xrdp_wm.c : callback */ self->session->callback(self->session->id, msg_type, param1, param2, device_flags, time); } } DEBUG(("out xrdp_rdp_process_data_input")); return 0; } /*****************************************************************************/ static int xrdp_rdp_send_synchronise(struct xrdp_rdp *self) { struct stream *s; make_stream(s); init_stream(s, 8192); if (xrdp_rdp_init_data(self, s) != 0) { free_stream(s); return 1; } out_uint16_le(s, 1); /* messageType (2 bytes) */ out_uint16_le(s, 1002); /* targetUser (2 bytes) */ s_mark_end(s); if (xrdp_rdp_send_data(self, s, RDP_DATA_PDU_SYNCHRONISE) != 0) { free_stream(s); return 1; } free_stream(s); return 0; } /*****************************************************************************/ static int xrdp_rdp_send_control(struct xrdp_rdp *self, int action) { struct stream *s; make_stream(s); init_stream(s, 8192); if (xrdp_rdp_init_data(self, s) != 0) { free_stream(s); return 1; } out_uint16_le(s, action); out_uint16_le(s, 0); /* userid */ out_uint32_le(s, 1002); /* control id */ s_mark_end(s); if (xrdp_rdp_send_data(self, s, RDP_DATA_PDU_CONTROL) != 0) { free_stream(s); return 1; } free_stream(s); return 0; } /*****************************************************************************/ static int xrdp_rdp_process_data_control(struct xrdp_rdp *self, struct stream *s) { int action; DEBUG(("xrdp_rdp_process_data_control")); in_uint16_le(s, action); in_uint8s(s, 2); /* user id */ in_uint8s(s, 4); /* control id */ if (action == RDP_CTL_REQUEST_CONTROL) { DEBUG(("xrdp_rdp_process_data_control got RDP_CTL_REQUEST_CONTROL")); DEBUG(("xrdp_rdp_process_data_control calling xrdp_rdp_send_synchronise")); xrdp_rdp_send_synchronise(self); DEBUG(("xrdp_rdp_process_data_control sending RDP_CTL_COOPERATE")); xrdp_rdp_send_control(self, RDP_CTL_COOPERATE); DEBUG(("xrdp_rdp_process_data_control sending RDP_CTL_GRANT_CONTROL")); xrdp_rdp_send_control(self, RDP_CTL_GRANT_CONTROL); } else { DEBUG(("xrdp_rdp_process_data_control unknown action")); } return 0; } /*****************************************************************************/ static int xrdp_rdp_process_data_sync(struct xrdp_rdp *self) { DEBUG(("xrdp_rdp_process_data_sync")); return 0; } /*****************************************************************************/ static int xrdp_rdp_process_screen_update(struct xrdp_rdp *self, struct stream *s) { int left; int top; int right; int bottom; int cx; int cy; in_uint8s(s, 4); /* op */ in_uint16_le(s, left); in_uint16_le(s, top); in_uint16_le(s, right); in_uint16_le(s, bottom); cx = (right - left) + 1; cy = (bottom - top) + 1; if (self->session->callback != 0) { self->session->callback(self->session->id, 0x4444, left, top, cx, cy); } return 0; } /*****************************************************************************/ static int xrdp_rdp_send_fontmap(struct xrdp_rdp *self) { struct stream *s; make_stream(s); init_stream(s, 8192); if (xrdp_rdp_init_data(self, s) != 0) { free_stream(s); return 1; } out_uint16_le(s, 0); /* numberEntries */ out_uint16_le(s, 0); /* totalNumEntries */ out_uint16_le(s, 0x3); /* mapFlags (sequence flags) */ out_uint16_le(s, 0x4); /* entrySize */ s_mark_end(s); if (xrdp_rdp_send_data(self, s, 0x28) != 0) { free_stream(s); return 1; } free_stream(s); return 0; } /*****************************************************************************/ static int xrdp_rdp_process_data_font(struct xrdp_rdp *self, struct stream *s) { int seq; DEBUG(("in xrdp_rdp_process_data_font")); in_uint8s(s, 2); /* NumberFonts: 0x0, SHOULD be set to 0 */ in_uint8s(s, 2); /* TotalNumberFonts: 0x0, SHOULD be set to 0 */ in_uint16_le(s, seq); /* ListFlags */ /* 419 client sends Seq 1, then 2 */ /* 2600 clients sends only Seq 3 */ if (seq == 2 || seq == 3) /* after second font message, we are up and */ { /* running */ DEBUG(("sending fontmap")); xrdp_rdp_send_fontmap(self); self->session->up_and_running = 1; g_writeln("yeah, up_and_running"); DEBUG(("up_and_running set")); xrdp_rdp_send_data_update_sync(self); } DEBUG(("out xrdp_rdp_process_data_font")); return 0; } /*****************************************************************************/ /* sent 37 pdu */ static int xrdp_rdp_send_disconnect_query_response(struct xrdp_rdp *self) { struct stream *s; make_stream(s); init_stream(s, 8192); if (xrdp_rdp_init_data(self, s) != 0) { free_stream(s); return 1; } s_mark_end(s); if (xrdp_rdp_send_data(self, s, 37) != 0) { free_stream(s); return 1; } free_stream(s); return 0; } #if 0 /* not used */ /*****************************************************************************/ /* sent RDP_DATA_PDU_DISCONNECT 47 pdu */ static int xrdp_rdp_send_disconnect_reason(struct xrdp_rdp *self, int reason) { struct stream *s; make_stream(s); init_stream(s, 8192); if (xrdp_rdp_init_data(self, s) != 0) { free_stream(s); return 1; } out_uint32_le(s, reason); s_mark_end(s); if (xrdp_rdp_send_data(self, s, RDP_DATA_PDU_DISCONNECT) != 0) { free_stream(s); return 1; } free_stream(s); return 0; } #endif /*****************************************************************************/ static int xrdp_rdp_process_frame_ack(struct xrdp_rdp *self, struct stream *s) { int frame_id; //g_writeln("xrdp_rdp_process_frame_ack:"); in_uint32_le(s, frame_id); //g_writeln(" frame_id %d", frame_id); if (self->session->callback != 0) { /* call to xrdp_wm.c : callback */ self->session->callback(self->session->id, 0x5557, frame_id, 0, 0, 0); } return 0; } /*****************************************************************************/ /* RDP_PDU_DATA */ int xrdp_rdp_process_data(struct xrdp_rdp *self, struct stream *s) { int data_type; in_uint8s(s, 6); in_uint8s(s, 2); /* len */ in_uint8(s, data_type); in_uint8s(s, 1); /* ctype */ in_uint8s(s, 2); /* clen */ DEBUG(("xrdp_rdp_process_data code %d", data_type)); switch (data_type) { case RDP_DATA_PDU_POINTER: /* 27(0x1b) */ xrdp_rdp_process_data_pointer(self, s); break; case RDP_DATA_PDU_INPUT: /* 28(0x1c) */ xrdp_rdp_process_data_input(self, s); break; case RDP_DATA_PDU_CONTROL: /* 20(0x14) */ xrdp_rdp_process_data_control(self, s); break; case RDP_DATA_PDU_SYNCHRONISE: /* 31(0x1f) */ xrdp_rdp_process_data_sync(self); break; case 33: /* 33(0x21) ?? Invalidate an area I think */ xrdp_rdp_process_screen_update(self, s); break; case 35: /* 35(0x23) */ /* 35 ?? this comes when minimizing a full screen mstsc.exe 2600 */ /* I think this is saying the client no longer wants screen */ /* updates and it will issue a 33 above to catch up */ /* so minimized apps don't take bandwidth */ break; case 36: /* 36(0x24) ?? disconnect query? */ /* when this message comes, send a 37 back so the client */ /* is sure the connection is alive and it can ask if user */ /* really wants to disconnect */ xrdp_rdp_send_disconnect_query_response(self); /* send a 37 back */ break; case RDP_DATA_PDU_FONT2: /* 39(0x27) */ xrdp_rdp_process_data_font(self, s); break; case 56: /* PDUTYPE2_FRAME_ACKNOWLEDGE 0x38 */ xrdp_rdp_process_frame_ack(self, s); break; default: g_writeln("unknown in xrdp_rdp_process_data %d", data_type); break; } return 0; } /*****************************************************************************/ int xrdp_rdp_disconnect(struct xrdp_rdp *self) { int rv; DEBUG(("in xrdp_rdp_disconnect")); rv = xrdp_sec_disconnect(self->sec_layer); DEBUG(("out xrdp_rdp_disconnect")); return rv; } /*****************************************************************************/ int xrdp_rdp_send_deactivate(struct xrdp_rdp *self) { struct stream *s; DEBUG(("in xrdp_rdp_send_deactivate")); make_stream(s); init_stream(s, 8192); if (xrdp_rdp_init(self, s) != 0) { free_stream(s); DEBUG(("out xrdp_rdp_send_deactivate error")); return 1; } s_mark_end(s); if (xrdp_rdp_send(self, s, RDP_PDU_DEACTIVATE) != 0) { free_stream(s); DEBUG(("out xrdp_rdp_send_deactivate error")); return 1; } free_stream(s); DEBUG(("out xrdp_rdp_send_deactivate")); return 0; } /*****************************************************************************/ int xrdp_rdp_send_session_info(struct xrdp_rdp *self, const char *data, int data_bytes) { struct stream *s; LLOGLN(0, ("xrdp_rdp_send_session_info: data_bytes %d", data_bytes)); make_stream(s); init_stream(s, 8192); if (xrdp_rdp_init_data(self, s) != 0) { free_stream(s); return 1; } if (s_check_rem_out(s, data_bytes)) { out_uint8a(s, data, data_bytes); } else { free_stream(s); return 1; } s_mark_end(s); if (xrdp_rdp_send_data(self, s, RDP_DATA_PDU_LOGON) != 0) { free_stream(s); return 1; } free_stream(s); return 0; } xrdp-0.9.5/libxrdp/libxrdpinc.h000644 001751 001751 00000022330 13174271344 016403 0ustar00metameta000000 000000 /** * xrdp: A Remote Desktop Protocol server. * * Copyright (C) Jay Sorg 2004-2014 * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. * * header file for use with libxrdp.so / xrdp.dll */ #ifndef LIBXRDPINC_H #define LIBXRDPINC_H #include "xrdp_rail.h" /* struct xrdp_client_info moved to xrdp_client_info.h */ struct xrdp_brush { int x_origin; int y_origin; int style; char pattern[8]; }; struct xrdp_pen { int style; int width; int color; }; /* 2.2.2.2.1.2.5.1 Cache Glyph Data (TS_CACHE_GLYPH_DATA) */ struct xrdp_font_char { int offset; /* x */ int baseline; /* y */ int width; /* cx */ int height; /* cy */ int incby; int bpp; char *data; }; struct xrdp_rect { int left; int top; int right; int bottom; }; struct xrdp_session { tintptr id; struct trans *trans; int (*callback)(intptr_t id, int msg, intptr_t param1, intptr_t param2, intptr_t param3, intptr_t param4); void *rdp; void *orders; struct xrdp_client_info *client_info; int up_and_running; int (*is_term)(void); int in_process_data; /* inc / dec libxrdp_process_data calls */ struct source_info si; }; struct xrdp_session * libxrdp_init(tbus id, struct trans *trans); int libxrdp_exit(struct xrdp_session *session); int libxrdp_disconnect(struct xrdp_session *session); int libxrdp_process_incoming(struct xrdp_session *session); int EXPORT_CC libxrdp_get_pdu_bytes(const char *aheader); struct stream * libxrdp_force_read(struct trans *trans); int libxrdp_process_data(struct xrdp_session *session, struct stream *s); int libxrdp_send_palette(struct xrdp_session *session, int *palette); int libxrdp_send_bell(struct xrdp_session *session); int libxrdp_send_bitmap(struct xrdp_session *session, int width, int height, int bpp, char *data, int x, int y, int cx, int cy); int libxrdp_send_pointer(struct xrdp_session *session, int cache_idx, char *data, char *mask, int x, int y, int bpp); int libxrdp_set_pointer(struct xrdp_session *session, int cache_idx); int libxrdp_orders_init(struct xrdp_session *session); int libxrdp_orders_send(struct xrdp_session *session); int libxrdp_orders_force_send(struct xrdp_session *session); int libxrdp_orders_rect(struct xrdp_session *session, int x, int y, int cx, int cy, int color, struct xrdp_rect *rect); int libxrdp_orders_screen_blt(struct xrdp_session *session, int x, int y, int cx, int cy, int srcx, int srcy, int rop, struct xrdp_rect *rect); int libxrdp_orders_pat_blt(struct xrdp_session *session, int x, int y, int cx, int cy, int rop, int bg_color, int fg_color, struct xrdp_brush *brush, struct xrdp_rect *rect); int libxrdp_orders_dest_blt(struct xrdp_session *session, int x, int y, int cx, int cy, int rop, struct xrdp_rect *rect); int libxrdp_orders_line(struct xrdp_session *session, int mix_mode, int startx, int starty, int endx, int endy, int rop, int bg_color, struct xrdp_pen *pen, struct xrdp_rect *rect); int libxrdp_orders_mem_blt(struct xrdp_session *session, int cache_id, int color_table, int x, int y, int cx, int cy, int rop, int srcx, int srcy, int cache_idx, struct xrdp_rect *rect); int libxrdp_orders_composite_blt(struct xrdp_session *session, int srcidx, int srcformat, int srcwidth, int srcrepeat, int *srctransform, int mskflags, int mskidx, int mskformat, int mskwidth, int mskrepeat, int op, int srcx, int srcy, int mskx, int msky, int dstx, int dsty, int width, int height, int dstformat, struct xrdp_rect *rect); int libxrdp_orders_text(struct xrdp_session *session, int font, int flags, int mixmode, int fg_color, int bg_color, int clip_left, int clip_top, int clip_right, int clip_bottom, int box_left, int box_top, int box_right, int box_bottom, int x, int y, char *data, int data_len, struct xrdp_rect *rect); int libxrdp_orders_send_palette(struct xrdp_session *session, int *palette, int cache_id); int libxrdp_orders_send_raw_bitmap(struct xrdp_session *session, int width, int height, int bpp, char *data, int cache_id, int cache_idx); int libxrdp_orders_send_bitmap(struct xrdp_session *session, int width, int height, int bpp, char *data, int cache_id, int cache_idx); int libxrdp_orders_send_font(struct xrdp_session *session, struct xrdp_font_char *font_char, int font_index, int char_index); int libxrdp_reset(struct xrdp_session *session, int width, int height, int bpp); int libxrdp_orders_send_raw_bitmap2(struct xrdp_session *session, int width, int height, int bpp, char *data, int cache_id, int cache_idx); int libxrdp_orders_send_bitmap2(struct xrdp_session *session, int width, int height, int bpp, char *data, int cache_id, int cache_idx, int hints); int libxrdp_orders_send_bitmap3(struct xrdp_session *session, int width, int height, int bpp, char *data, int cache_id, int cache_idx, int hints); int libxrdp_query_channel(struct xrdp_session *session, int index, char *channel_name, int *channel_flags); int libxrdp_get_channel_id(struct xrdp_session *session, const char *name); int libxrdp_send_to_channel(struct xrdp_session *session, int channel_id, char *data, int data_len, int total_data_len, int flags); int libxrdp_orders_send_brush(struct xrdp_session *session, int width, int height, int bpp, int type, int size, char *data, int cache_id); int libxrdp_orders_send_create_os_surface(struct xrdp_session *session, int id, int width, int height, struct list *del_list); int libxrdp_orders_send_switch_os_surface(struct xrdp_session *session, int id); int libxrdp_window_new_update(struct xrdp_session *session, int window_id, struct rail_window_state_order *window_state, int flags); int libxrdp_window_delete(struct xrdp_session *session, int window_id); int libxrdp_window_icon(struct xrdp_session *session, int window_id, int cache_entry, int cache_id, struct rail_icon_info *icon_info, int flags); int libxrdp_window_cached_icon(struct xrdp_session *session, int window_id, int cache_entry, int cache_id, int flags); int libxrdp_notify_new_update(struct xrdp_session *session, int window_id, int notify_id, struct rail_notify_state_order *notify_state, int flags); int libxrdp_notify_delete(struct xrdp_session *session, int window_id, int notify_id); int libxrdp_monitored_desktop(struct xrdp_session *session, struct rail_monitored_desktop_order *mdo, int flags); int libxrdp_codec_jpeg_compress(struct xrdp_session *session, int format, char *inp_data, int width, int height, int stride, int x, int y, int cx, int cy, int quality, char *out_data, int *io_len); int libxrdp_fastpath_send_surface(struct xrdp_session *session, char *data_pad, int pad_bytes, int data_bytes, int destLeft, int dst_Top, int destRight, int destBottom, int bpp, int codecID, int width, int height); int EXPORT_CC libxrdp_fastpath_send_frame_marker(struct xrdp_session *session, int frame_action, int frame_id); int EXPORT_CC libxrdp_send_session_info(struct xrdp_session *session, const char *data, int data_bytes); #endif xrdp-0.9.5/libxrdp/xrdp_orders_rail.h000644 001751 001751 00000003731 13174271344 017613 0ustar00metameta000000 000000 /** * xrdp: A Remote Desktop Protocol server. * * Copyright (C) Jay Sorg 2012-2014 * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ #if !defined(_XRDP_ORDERS_RAIL_H) #define _XRDP_ORDERS_RAIL_H int xrdp_orders_send_window_delete(struct xrdp_orders *self, int window_id); int xrdp_orders_send_window_cached_icon(struct xrdp_orders *self, int window_id, int cache_entry, int cache_id, int flags); int xrdp_orders_send_window_icon(struct xrdp_orders *self, int window_id, int cache_entry, int cache_id, struct rail_icon_info *icon_info, int flags); int xrdp_orders_send_window_new_update(struct xrdp_orders *self, int window_id, struct rail_window_state_order *window_state, int flags); int xrdp_orders_send_notify_delete(struct xrdp_orders *self, int window_id, int notify_id); int xrdp_orders_send_notify_new_update(struct xrdp_orders *self, int window_id, int notify_id, struct rail_notify_state_order *notify_state, int flags); int xrdp_orders_send_monitored_desktop(struct xrdp_orders *self, struct rail_monitored_desktop_order *mdo, int flags); #endif xrdp-0.9.5/libxrdp/xrdp_orders.c000644 001751 001751 00000234731 13206023530 016571 0ustar00metameta000000 000000 /** * xrdp: A Remote Desktop Protocol server. * * Copyright (C) Jay Sorg 2004-2013 * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. * * orders */ #if defined(HAVE_CONFIG_H) #include #endif #include "libxrdp.h" #if defined(XRDP_NEUTRINORDP) #include #endif #define LLOG_LEVEL 2 #define LLOGLN(_log_level, _params) \ { \ if (_log_level < LLOG_LEVEL) \ { \ g_write("xrdp_orders.c [%10.10u]: ", g_time3()); \ g_writeln _params ; \ } \ } #define MAX_ORDERS_SIZE(_client_info) \ (MAX((_client_info)->max_fastpath_frag_bytes, 16 * 1024) - 256); /*****************************************************************************/ struct xrdp_orders * xrdp_orders_create(struct xrdp_session *session, struct xrdp_rdp *rdp_layer) { struct xrdp_orders *self; self = (struct xrdp_orders *)g_malloc(sizeof(struct xrdp_orders), 1); self->session = session; self->rdp_layer = rdp_layer; make_stream(self->out_s); init_stream(self->out_s, 32 * 1024); self->orders_state.clip_right = 1; /* silly rdp right clip */ self->orders_state.clip_bottom = 1; /* silly rdp bottom clip */ self->jpeg_han = xrdp_jpeg_init(); self->rfx_min_pixel = rdp_layer->client_info.rfx_min_pixel; if (self->rfx_min_pixel == 0) { self->rfx_min_pixel = 64 * 32; } make_stream(self->s); make_stream(self->temp_s); return self; } /*****************************************************************************/ void xrdp_orders_delete(struct xrdp_orders *self) { if (self == 0) { return; } xrdp_jpeg_deinit(self->jpeg_han); free_stream(self->out_s); free_stream(self->s); free_stream(self->temp_s); g_free(self->orders_state.text_data); g_free(self); } /*****************************************************************************/ /* set all values to zero */ /* returns error */ int xrdp_orders_reset(struct xrdp_orders *self) { if (xrdp_orders_force_send(self) != 0) { return 1; } g_free(self->orders_state.text_data); g_memset(&(self->orders_state), 0, sizeof(self->orders_state)); self->order_count_ptr = 0; self->order_count = 0; self->order_level = 0; self->orders_state.clip_right = 1; /* silly rdp right clip */ self->orders_state.clip_bottom = 1; /* silly rdp bottom clip */ return 0; } /*****************************************************************************/ /* returns error */ int xrdp_orders_init(struct xrdp_orders *self) { self->order_level++; if (self->order_level == 1) { self->order_count = 0; if (self->rdp_layer->client_info.use_fast_path & 1) { LLOGLN(10, ("xrdp_orders_init: fastpath")); if (xrdp_rdp_init_fastpath(self->rdp_layer, self->out_s) != 0) { return 1; } self->order_count_ptr = self->out_s->p; out_uint8s(self->out_s, 2); /* number of orders, set later */ } else { LLOGLN(10, ("xrdp_orders_init: slowpath")); if (xrdp_rdp_init_data(self->rdp_layer, self->out_s) != 0) { return 1; } out_uint16_le(self->out_s, RDP_UPDATE_ORDERS); out_uint8s(self->out_s, 2); /* pad */ self->order_count_ptr = self->out_s->p; out_uint8s(self->out_s, 2); /* number of orders, set later */ out_uint8s(self->out_s, 2); /* pad */ } } return 0; } /*****************************************************************************/ /* returns error */ int xrdp_orders_send(struct xrdp_orders *self) { int rv; rv = 0; if (self->order_level > 0) { self->order_level--; if ((self->order_level == 0) && (self->order_count > 0)) { s_mark_end(self->out_s); DEBUG(("xrdp_orders_send sending %d orders", self->order_count)); self->order_count_ptr[0] = self->order_count; self->order_count_ptr[1] = self->order_count >> 8; self->order_count = 0; if (self->rdp_layer->client_info.use_fast_path & 1) { if (xrdp_rdp_send_fastpath(self->rdp_layer, self->out_s, 0) != 0) { rv = 1; } } else { if (xrdp_rdp_send_data(self->rdp_layer, self->out_s, RDP_DATA_PDU_UPDATE) != 0) { rv = 1; } } } } return rv; } /*****************************************************************************/ /* returns error */ int xrdp_orders_force_send(struct xrdp_orders *self) { if (self == 0) { return 1; } if ((self->order_level > 0) && (self->order_count > 0)) { s_mark_end(self->out_s); DEBUG(("xrdp_orders_force_send sending %d orders", self->order_count)); self->order_count_ptr[0] = self->order_count; self->order_count_ptr[1] = self->order_count >> 8; if (self->rdp_layer->client_info.use_fast_path & 1) { if (xrdp_rdp_send_fastpath(self->rdp_layer, self->out_s, FASTPATH_UPDATETYPE_ORDERS) != 0) { return 1; } } else { if (xrdp_rdp_send_data(self->rdp_layer, self->out_s, RDP_DATA_PDU_UPDATE) != 0) { return 1; } } } self->order_count = 0; self->order_level = 0; return 0; } /*****************************************************************************/ /* check if the current order will fit in packet size of 16384, if not */ /* send what we got and init a new one */ /* returns error */ int xrdp_orders_check(struct xrdp_orders *self, int max_size) { int size; int max_order_size; struct xrdp_client_info *ci; ci = &(self->rdp_layer->client_info); max_order_size = MAX_ORDERS_SIZE(ci); if (self->order_level < 1) { if (max_size > max_order_size) { return 1; } else { xrdp_orders_init(self); return 0; } } size = (int)(self->out_s->p - self->order_count_ptr); if (size < 0) { g_writeln("error in xrdp_orders_check, size too small: %d bytes", size); return 1; } if (size > max_order_size) { /* this suggests someone calls this function without passing the correct max_size so we end up putting more into the buffer than we indicate we can */ g_writeln("error in xrdp_orders_check, size too big: %d bytes", size); /* We where getting called with size already greater than max_order_size Which I suspect was because the sending of text did not include the text len to check the buffer size. So attempt to send the data anyway. Lets write the data anyway, somewhere else may barf. */ /* return 1; */ } if ((size + max_size + 100) > max_order_size) { xrdp_orders_force_send(self); xrdp_orders_init(self); } return 0; } /*****************************************************************************/ /* check if rect is the same as the last one sent */ /* returns boolean */ static int xrdp_orders_last_bounds(struct xrdp_orders *self, struct xrdp_rect *rect) { if (rect == 0) { return 0; } if ((rect->left == self->orders_state.clip_left) && (rect->top == self->orders_state.clip_top) && (rect->right == self->orders_state.clip_right) && (rect->bottom == self->orders_state.clip_bottom)) { return 1; } return 0; } /*****************************************************************************/ /* check if all coords are within 256 bytes */ /* returns boolean */ static int xrdp_orders_send_delta(struct xrdp_orders *self, int *vals, int count) { int i; for (i = 0; i < count; i += 2) { if (g_abs(vals[i] - vals[i + 1]) >= 128) { return 0; } } return 1; } /*****************************************************************************/ /* returns error */ static int xrdp_orders_out_bounds(struct xrdp_orders *self, struct xrdp_rect *rect) { char *bounds_flags_ptr; int bounds_flags; bounds_flags = 0; bounds_flags_ptr = self->out_s->p; out_uint8s(self->out_s, 1); /* left */ if (rect->left == self->orders_state.clip_left) { } else if (g_abs(rect->left - self->orders_state.clip_left) < 128) { bounds_flags |= 0x10; } else { bounds_flags |= 0x01; } /* top */ if (rect->top == self->orders_state.clip_top) { } else if (g_abs(rect->top - self->orders_state.clip_top) < 128) { bounds_flags |= 0x20; } else { bounds_flags |= 0x02; } /* right */ if (rect->right == self->orders_state.clip_right) { } else if (g_abs(rect->right - self->orders_state.clip_right) < 128) { bounds_flags |= 0x40; } else { bounds_flags |= 0x04; } /* bottom */ if (rect->bottom == self->orders_state.clip_bottom) { } else if (g_abs(rect->bottom - self->orders_state.clip_bottom) < 128) { bounds_flags |= 0x80; } else { bounds_flags |= 0x08; } /* left */ if (bounds_flags & 0x01) { out_uint16_le(self->out_s, rect->left); } else if (bounds_flags & 0x10) { out_uint8(self->out_s, rect->left - self->orders_state.clip_left); } self->orders_state.clip_left = rect->left; /* top */ if (bounds_flags & 0x02) { out_uint16_le(self->out_s, rect->top); } else if (bounds_flags & 0x20) { out_uint8(self->out_s, rect->top - self->orders_state.clip_top); } self->orders_state.clip_top = rect->top; /* right */ if (bounds_flags & 0x04) { /* silly rdp right clip */ out_uint16_le(self->out_s, rect->right - 1); } else if (bounds_flags & 0x40) { out_uint8(self->out_s, rect->right - self->orders_state.clip_right); } self->orders_state.clip_right = rect->right; /* bottom */ if (bounds_flags & 0x08) { /* silly rdp bottom clip */ out_uint16_le(self->out_s, rect->bottom - 1); } else if (bounds_flags & 0x80) { out_uint8(self->out_s, rect->bottom - self->orders_state.clip_bottom); } self->orders_state.clip_bottom = rect->bottom; /* set flags */ *bounds_flags_ptr = bounds_flags; return 0; } /*****************************************************************************/ /* returns error */ static int xrdp_order_pack_small_or_tiny(struct xrdp_orders *self, char *order_flags_ptr, int orders_flags, char *present_ptr, int present, int present_size) { int move_up_count = 0; int index = 0; int size = 0; int keep_looking = 1; move_up_count = 0; keep_looking = 1; for (index = present_size - 1; index >= 0; index--) { if (keep_looking) { if (((present >> (index * 8)) & 0xff) == 0) { move_up_count++; } else { keep_looking = 0; } } present_ptr[index] = present >> (index * 8); } if (move_up_count > 0) { /* move_up_count should be 0, 1, 2, or 3 shifting it 6 will make it RDP_ORDER_TINY(0x80) or RDP_ORDER_SMALL(0x40) or both */ orders_flags |= move_up_count << 6; size = (int)(self->out_s->p - present_ptr); size -= present_size; for (index = 0; index < size; index++) { present_ptr[index + (present_size - move_up_count)] = present_ptr[index + present_size]; } self->out_s->p -= move_up_count; } order_flags_ptr[0] = orders_flags; return 0; } /*****************************************************************************/ /* returns error */ /* send a solid rect to client */ /* max size 23 */ int xrdp_orders_rect(struct xrdp_orders *self, int x, int y, int cx, int cy, int color, struct xrdp_rect *rect) { int order_flags; int vals[8]; int present; char *present_ptr; char *order_flags_ptr; if (xrdp_orders_check(self, 23) != 0) { return 1; } self->order_count++; order_flags = RDP_ORDER_STANDARD; if (self->orders_state.last_order != RDP_ORDER_RECT) { order_flags |= RDP_ORDER_CHANGE; } self->orders_state.last_order = RDP_ORDER_RECT; if (rect != 0) { /* if clip is present, still check if it's needed */ if (x < rect->left || y < rect->top || x + cx > rect->right || y + cy > rect->bottom) { order_flags |= RDP_ORDER_BOUNDS; if (xrdp_orders_last_bounds(self, rect)) { order_flags |= RDP_ORDER_LASTBOUNDS; } } } vals[0] = x; vals[1] = self->orders_state.rect_x; vals[2] = y; vals[3] = self->orders_state.rect_y; vals[4] = cx; vals[5] = self->orders_state.rect_cx; vals[6] = cy; vals[7] = self->orders_state.rect_cy; if (xrdp_orders_send_delta(self, vals, 8)) { order_flags |= RDP_ORDER_DELTA; } /* order_flags, set later, 1 byte */ order_flags_ptr = self->out_s->p; out_uint8s(self->out_s, 1); if (order_flags & RDP_ORDER_CHANGE) { out_uint8(self->out_s, self->orders_state.last_order); } present = 0; /* present, set later, 1 byte */ present_ptr = self->out_s->p; out_uint8s(self->out_s, 1); if ((order_flags & RDP_ORDER_BOUNDS) && !(order_flags & RDP_ORDER_LASTBOUNDS)) { xrdp_orders_out_bounds(self, rect); } if (x != self->orders_state.rect_x) { present |= 0x01; if (order_flags & RDP_ORDER_DELTA) { out_uint8(self->out_s, x - self->orders_state.rect_x); } else { out_uint16_le(self->out_s, x); } self->orders_state.rect_x = x; } if (y != self->orders_state.rect_y) { present |= 0x02; if (order_flags & RDP_ORDER_DELTA) { out_uint8(self->out_s, y - self->orders_state.rect_y); } else { out_uint16_le(self->out_s, y); } self->orders_state.rect_y = y; } if (cx != self->orders_state.rect_cx) { present |= 0x04; if (order_flags & RDP_ORDER_DELTA) { out_uint8(self->out_s, cx - self->orders_state.rect_cx); } else { out_uint16_le(self->out_s, cx); } self->orders_state.rect_cx = cx; } if (cy != self->orders_state.rect_cy) { present |= 0x08; if (order_flags & RDP_ORDER_DELTA) { out_uint8(self->out_s, cy - self->orders_state.rect_cy); } else { out_uint16_le(self->out_s, cy); } self->orders_state.rect_cy = cy; } if ((color & 0xff) != (self->orders_state.rect_color & 0xff)) { present |= 0x10; self->orders_state.rect_color = (self->orders_state.rect_color & 0xffff00) | (color & 0xff); out_uint8(self->out_s, color); } if ((color & 0xff00) != (self->orders_state.rect_color & 0xff00)) { present |= 0x20; self->orders_state.rect_color = (self->orders_state.rect_color & 0xff00ff) | (color & 0xff00); out_uint8(self->out_s, color >> 8); } if ((color & 0xff0000) != (self->orders_state.rect_color & 0xff0000)) { present |= 0x40; self->orders_state.rect_color = (self->orders_state.rect_color & 0x00ffff) | (color & 0xff0000); out_uint8(self->out_s, color >> 16); } xrdp_order_pack_small_or_tiny(self, order_flags_ptr, order_flags, present_ptr, present, 1); return 0; } /*****************************************************************************/ /* returns error */ /* send a screen blt order */ /* max size 25 */ int xrdp_orders_screen_blt(struct xrdp_orders *self, int x, int y, int cx, int cy, int srcx, int srcy, int rop, struct xrdp_rect *rect) { int order_flags = 0; int vals[12] = {0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0}; int present = 0; char *present_ptr = (char *)NULL; char *order_flags_ptr = (char *)NULL; if (xrdp_orders_check(self, 25) != 0) { return 1; } self->order_count++; order_flags = RDP_ORDER_STANDARD; if (self->orders_state.last_order != RDP_ORDER_SCREENBLT) { order_flags |= RDP_ORDER_CHANGE; } self->orders_state.last_order = RDP_ORDER_SCREENBLT; if (rect != 0) { /* if clip is present, still check if it's needed */ if (x < rect->left || y < rect->top || x + cx > rect->right || y + cy > rect->bottom) { order_flags |= RDP_ORDER_BOUNDS; if (xrdp_orders_last_bounds(self, rect)) { order_flags |= RDP_ORDER_LASTBOUNDS; } } } vals[0] = x; vals[1] = self->orders_state.scr_blt_x; vals[2] = y; vals[3] = self->orders_state.scr_blt_y; vals[4] = cx; vals[5] = self->orders_state.scr_blt_cx; vals[6] = cy; vals[7] = self->orders_state.scr_blt_cy; vals[8] = srcx; vals[9] = self->orders_state.scr_blt_srcx; vals[10] = srcy; vals[11] = self->orders_state.scr_blt_srcy; if (xrdp_orders_send_delta(self, vals, 12)) { order_flags |= RDP_ORDER_DELTA; } /* order_flags, set later, 1 byte */ order_flags_ptr = self->out_s->p; out_uint8s(self->out_s, 1); if (order_flags & RDP_ORDER_CHANGE) { out_uint8(self->out_s, self->orders_state.last_order); } present = 0; /* present, set later, 1 byte */ present_ptr = self->out_s->p; out_uint8s(self->out_s, 1); if ((order_flags & RDP_ORDER_BOUNDS) && !(order_flags & RDP_ORDER_LASTBOUNDS)) { xrdp_orders_out_bounds(self, rect); } if (x != self->orders_state.scr_blt_x) { present |= 0x01; if (order_flags & RDP_ORDER_DELTA) { out_uint8(self->out_s, x - self->orders_state.scr_blt_x); } else { out_uint16_le(self->out_s, x); } self->orders_state.scr_blt_x = x; } if (y != self->orders_state.scr_blt_y) { present |= 0x02; if (order_flags & RDP_ORDER_DELTA) { out_uint8(self->out_s, y - self->orders_state.scr_blt_y); } else { out_uint16_le(self->out_s, y); } self->orders_state.scr_blt_y = y; } if (cx != self->orders_state.scr_blt_cx) { present |= 0x04; if (order_flags & RDP_ORDER_DELTA) { out_uint8(self->out_s, cx - self->orders_state.scr_blt_cx); } else { out_uint16_le(self->out_s, cx); } self->orders_state.scr_blt_cx = cx; } if (cy != self->orders_state.scr_blt_cy) { present |= 0x08; if (order_flags & RDP_ORDER_DELTA) { out_uint8(self->out_s, cy - self->orders_state.scr_blt_cy); } else { out_uint16_le(self->out_s, cy); } self->orders_state.scr_blt_cy = cy; } if (rop != self->orders_state.scr_blt_rop) { present |= 0x10; out_uint8(self->out_s, rop); self->orders_state.scr_blt_rop = rop; } if (srcx != self->orders_state.scr_blt_srcx) { present |= 0x20; if (order_flags & RDP_ORDER_DELTA) { out_uint8(self->out_s, srcx - self->orders_state.scr_blt_srcx); } else { out_uint16_le(self->out_s, srcx); } self->orders_state.scr_blt_srcx = srcx; } if (srcy != self->orders_state.scr_blt_srcy) { present |= 0x40; if (order_flags & RDP_ORDER_DELTA) { out_uint8(self->out_s, srcy - self->orders_state.scr_blt_srcy); } else { out_uint16_le(self->out_s, srcy); } self->orders_state.scr_blt_srcy = srcy; } xrdp_order_pack_small_or_tiny(self, order_flags_ptr, order_flags, present_ptr, present, 1); return 0; } /*****************************************************************************/ /* returns error */ /* send a pat blt order */ /* max size 39 */ int xrdp_orders_pat_blt(struct xrdp_orders *self, int x, int y, int cx, int cy, int rop, int bg_color, int fg_color, struct xrdp_brush *brush, struct xrdp_rect *rect) { int order_flags; int present; int vals[8]; char *present_ptr; char *order_flags_ptr; struct xrdp_brush blank_brush; if (xrdp_orders_check(self, 39) != 0) { return 1; } self->order_count++; order_flags = RDP_ORDER_STANDARD; if (self->orders_state.last_order != RDP_ORDER_PATBLT) { order_flags |= RDP_ORDER_CHANGE; } self->orders_state.last_order = RDP_ORDER_PATBLT; if (rect != 0) { /* if clip is present, still check if it's needed */ if (x < rect->left || y < rect->top || x + cx > rect->right || y + cy > rect->bottom) { order_flags |= RDP_ORDER_BOUNDS; if (xrdp_orders_last_bounds(self, rect)) { order_flags |= RDP_ORDER_LASTBOUNDS; } } } vals[0] = x; vals[1] = self->orders_state.pat_blt_x; vals[2] = y; vals[3] = self->orders_state.pat_blt_y; vals[4] = cx; vals[5] = self->orders_state.pat_blt_cx; vals[6] = cy; vals[7] = self->orders_state.pat_blt_cy; if (xrdp_orders_send_delta(self, vals, 8)) { order_flags |= RDP_ORDER_DELTA; } /* order_flags, set later, 1 byte */ order_flags_ptr = self->out_s->p; out_uint8s(self->out_s, 1); if (order_flags & RDP_ORDER_CHANGE) { out_uint8(self->out_s, self->orders_state.last_order); } present = 0; /* present, set later, 2 bytes */ present_ptr = self->out_s->p; out_uint8s(self->out_s, 2); if ((order_flags & RDP_ORDER_BOUNDS) && !(order_flags & RDP_ORDER_LASTBOUNDS)) { xrdp_orders_out_bounds(self, rect); } if (x != self->orders_state.pat_blt_x) { present |= 0x0001; if (order_flags & RDP_ORDER_DELTA) { out_uint8(self->out_s, x - self->orders_state.pat_blt_x); } else { out_uint16_le(self->out_s, x); } self->orders_state.pat_blt_x = x; } if (y != self->orders_state.pat_blt_y) { present |= 0x0002; if (order_flags & RDP_ORDER_DELTA) { out_uint8(self->out_s, y - self->orders_state.pat_blt_y); } else { out_uint16_le(self->out_s, y); } self->orders_state.pat_blt_y = y; } if (cx != self->orders_state.pat_blt_cx) { present |= 0x0004; if (order_flags & RDP_ORDER_DELTA) { out_uint8(self->out_s, cx - self->orders_state.pat_blt_cx); } else { out_uint16_le(self->out_s, cx); } self->orders_state.pat_blt_cx = cx; } if (cy != self->orders_state.pat_blt_cy) { present |= 0x0008; if (order_flags & RDP_ORDER_DELTA) { out_uint8(self->out_s, cy - self->orders_state.pat_blt_cy); } else { out_uint16_le(self->out_s, cy); } self->orders_state.pat_blt_cy = cy; } if (rop != self->orders_state.pat_blt_rop) { present |= 0x0010; /* PATCOPY PATPAINT PATINVERT DSTINVERT BLACKNESS WHITENESS */ out_uint8(self->out_s, rop); self->orders_state.pat_blt_rop = rop; } if (bg_color != self->orders_state.pat_blt_bg_color) { present |= 0x0020; out_uint8(self->out_s, bg_color); out_uint8(self->out_s, bg_color >> 8); out_uint8(self->out_s, bg_color >> 16); self->orders_state.pat_blt_bg_color = bg_color; } if (fg_color != self->orders_state.pat_blt_fg_color) { present |= 0x0040; out_uint8(self->out_s, fg_color); out_uint8(self->out_s, fg_color >> 8); out_uint8(self->out_s, fg_color >> 16); self->orders_state.pat_blt_fg_color = fg_color; } if (brush == 0) /* if nil use blank one */ { /* todo can we just set style to zero */ g_memset(&blank_brush, 0, sizeof(struct xrdp_brush)); brush = &blank_brush; } if (brush->x_origin != self->orders_state.pat_blt_brush.x_origin) { present |= 0x0080; out_uint8(self->out_s, brush->x_origin); self->orders_state.pat_blt_brush.x_origin = brush->x_origin; } if (brush->y_origin != self->orders_state.pat_blt_brush.y_origin) { present |= 0x0100; out_uint8(self->out_s, brush->y_origin); self->orders_state.pat_blt_brush.y_origin = brush->y_origin; } if (brush->style != self->orders_state.pat_blt_brush.style) { present |= 0x0200; out_uint8(self->out_s, brush->style); self->orders_state.pat_blt_brush.style = brush->style; } if (brush->pattern[0] != self->orders_state.pat_blt_brush.pattern[0]) { present |= 0x0400; out_uint8(self->out_s, brush->pattern[0]); self->orders_state.pat_blt_brush.pattern[0] = brush->pattern[0]; } if (g_memcmp(brush->pattern + 1, self->orders_state.pat_blt_brush.pattern + 1, 7) != 0) { present |= 0x0800; out_uint8a(self->out_s, brush->pattern + 1, 7); g_memcpy(self->orders_state.pat_blt_brush.pattern + 1, brush->pattern + 1, 7); } xrdp_order_pack_small_or_tiny(self, order_flags_ptr, order_flags, present_ptr, present, 2); return 0; } /*****************************************************************************/ /* returns error */ /* send a dest blt order */ /* max size 21 */ int xrdp_orders_dest_blt(struct xrdp_orders *self, int x, int y, int cx, int cy, int rop, struct xrdp_rect *rect) { int order_flags; int vals[8]; int present; char *present_ptr; char *order_flags_ptr; if (xrdp_orders_check(self, 21) != 0) { return 1; } self->order_count++; order_flags = RDP_ORDER_STANDARD; if (self->orders_state.last_order != RDP_ORDER_DESTBLT) { order_flags |= RDP_ORDER_CHANGE; } self->orders_state.last_order = RDP_ORDER_DESTBLT; if (rect != 0) { /* if clip is present, still check if it's needed */ if (x < rect->left || y < rect->top || x + cx > rect->right || y + cy > rect->bottom) { order_flags |= RDP_ORDER_BOUNDS; if (xrdp_orders_last_bounds(self, rect)) { order_flags |= RDP_ORDER_LASTBOUNDS; } } } vals[0] = x; vals[1] = self->orders_state.dest_blt_x; vals[2] = y; vals[3] = self->orders_state.dest_blt_y; vals[4] = cx; vals[5] = self->orders_state.dest_blt_cx; vals[6] = cy; vals[7] = self->orders_state.dest_blt_cy; if (xrdp_orders_send_delta(self, vals, 8)) { order_flags |= RDP_ORDER_DELTA; } /* order_flags, set later, 1 byte */ order_flags_ptr = self->out_s->p; out_uint8s(self->out_s, 1); if (order_flags & RDP_ORDER_CHANGE) { out_uint8(self->out_s, self->orders_state.last_order); } present = 0; /* present, set later, 1 byte */ present_ptr = self->out_s->p; out_uint8s(self->out_s, 1); if ((order_flags & RDP_ORDER_BOUNDS) && !(order_flags & RDP_ORDER_LASTBOUNDS)) { xrdp_orders_out_bounds(self, rect); } if (x != self->orders_state.dest_blt_x) { present |= 0x01; if (order_flags & RDP_ORDER_DELTA) { out_uint8(self->out_s, x - self->orders_state.dest_blt_x); } else { out_uint16_le(self->out_s, x); } self->orders_state.dest_blt_x = x; } if (y != self->orders_state.dest_blt_y) { present |= 0x02; if (order_flags & RDP_ORDER_DELTA) { out_uint8(self->out_s, y - self->orders_state.dest_blt_y); } else { out_uint16_le(self->out_s, y); } self->orders_state.dest_blt_y = y; } if (cx != self->orders_state.dest_blt_cx) { present |= 0x04; if (order_flags & RDP_ORDER_DELTA) { out_uint8(self->out_s, cx - self->orders_state.dest_blt_cx); } else { out_uint16_le(self->out_s, cx); } self->orders_state.dest_blt_cx = cx; } if (cy != self->orders_state.dest_blt_cy) { present |= 0x08; if (order_flags & RDP_ORDER_DELTA) { out_uint8(self->out_s, cy - self->orders_state.dest_blt_cy); } else { out_uint16_le(self->out_s, cy); } self->orders_state.dest_blt_cy = cy; } if (rop != self->orders_state.dest_blt_rop) { present |= 0x10; out_uint8(self->out_s, rop); self->orders_state.dest_blt_rop = rop; } xrdp_order_pack_small_or_tiny(self, order_flags_ptr, order_flags, present_ptr, present, 1); return 0; } /*****************************************************************************/ /* returns error */ /* send a line order */ /* max size 32 */ int xrdp_orders_line(struct xrdp_orders *self, int mix_mode, int startx, int starty, int endx, int endy, int rop, int bg_color, struct xrdp_pen *pen, struct xrdp_rect *rect) { int order_flags = 0; int vals[8] = {0, 0, 0, 0, 0, 0, 0, 0}; int present = 0; char *present_ptr = (char *)NULL; char *order_flags_ptr = (char *)NULL; struct xrdp_pen blank_pen; g_memset(&blank_pen, 0, sizeof(struct xrdp_pen)); /* if mix mode or rop are out of range, mstsc build 6000+ will parse the orders wrong */ if ((mix_mode < 1) || (mix_mode > 2)) /* TRANSPARENT(1) or OPAQUE(2) */ { mix_mode = 1; } if ((rop < 1) || (rop > 0x10)) { rop = 0x0d; /* R2_COPYPEN */ } if (xrdp_orders_check(self, 32) != 0) { return 1; } self->order_count++; order_flags = RDP_ORDER_STANDARD; if (self->orders_state.last_order != RDP_ORDER_LINE) { order_flags |= RDP_ORDER_CHANGE; } self->orders_state.last_order = RDP_ORDER_LINE; if (rect != 0) { /* if clip is present, still check if it's needed */ if (MIN(endx, startx) < rect->left || MIN(endy, starty) < rect->top || MAX(endx, startx) >= rect->right || MAX(endy, starty) >= rect->bottom) { order_flags |= RDP_ORDER_BOUNDS; if (xrdp_orders_last_bounds(self, rect)) { order_flags |= RDP_ORDER_LASTBOUNDS; } } } vals[0] = startx; vals[1] = self->orders_state.line_startx; vals[2] = starty; vals[3] = self->orders_state.line_starty; vals[4] = endx; vals[5] = self->orders_state.line_endx; vals[6] = endy; vals[7] = self->orders_state.line_endy; if (xrdp_orders_send_delta(self, vals, 8)) { order_flags |= RDP_ORDER_DELTA; } /* order_flags, set later, 1 byte */ order_flags_ptr = self->out_s->p; out_uint8s(self->out_s, 1); if (order_flags & RDP_ORDER_CHANGE) { out_uint8(self->out_s, self->orders_state.last_order); } present = 0; /* present, set later, 2 bytes */ present_ptr = self->out_s->p; out_uint8s(self->out_s, 2); if ((order_flags & RDP_ORDER_BOUNDS) && !(order_flags & RDP_ORDER_LASTBOUNDS)) { xrdp_orders_out_bounds(self, rect); } if (mix_mode != self->orders_state.line_mix_mode) { present |= 0x0001; out_uint16_le(self->out_s, mix_mode); self->orders_state.line_mix_mode = mix_mode; } if (startx != self->orders_state.line_startx) { present |= 0x0002; if (order_flags & RDP_ORDER_DELTA) { out_uint8(self->out_s, startx - self->orders_state.line_startx); } else { out_uint16_le(self->out_s, startx); } self->orders_state.line_startx = startx; } if (starty != self->orders_state.line_starty) { present |= 0x0004; if (order_flags & RDP_ORDER_DELTA) { out_uint8(self->out_s, starty - self->orders_state.line_starty); } else { out_uint16_le(self->out_s, starty); } self->orders_state.line_starty = starty; } if (endx != self->orders_state.line_endx) { present |= 0x0008; if (order_flags & RDP_ORDER_DELTA) { out_uint8(self->out_s, endx - self->orders_state.line_endx); } else { out_uint16_le(self->out_s, endx); } self->orders_state.line_endx = endx; } if (endy != self->orders_state.line_endy) { present |= 0x0010; if (order_flags & RDP_ORDER_DELTA) { out_uint8(self->out_s, endy - self->orders_state.line_endy); } else { out_uint16_le(self->out_s, endy); } self->orders_state.line_endy = endy; } if (bg_color != self->orders_state.line_bg_color) { present |= 0x0020; out_uint8(self->out_s, bg_color); out_uint8(self->out_s, bg_color >> 8); out_uint8(self->out_s, bg_color >> 16); self->orders_state.line_bg_color = bg_color; } if (rop != self->orders_state.line_rop) { present |= 0x0040; out_uint8(self->out_s, rop); self->orders_state.line_rop = rop; } if (pen == 0) { g_memset(&blank_pen, 0, sizeof(struct xrdp_pen)); pen = &blank_pen; } if (pen->style != self->orders_state.line_pen.style) { present |= 0x0080; out_uint8(self->out_s, pen->style); self->orders_state.line_pen.style = pen->style; } if (pen->width != self->orders_state.line_pen.width) { present |= 0x0100; out_uint8(self->out_s, pen->width); self->orders_state.line_pen.width = pen->width; } if (pen->color != self->orders_state.line_pen.color) { present |= 0x0200; out_uint8(self->out_s, pen->color); out_uint8(self->out_s, pen->color >> 8); out_uint8(self->out_s, pen->color >> 16); self->orders_state.line_pen.color = pen->color; } xrdp_order_pack_small_or_tiny(self, order_flags_ptr, order_flags, present_ptr, present, 2); return 0; } /*****************************************************************************/ /* returns error */ /* send a mem blt order */ /* max size 30 */ int xrdp_orders_mem_blt(struct xrdp_orders *self, int cache_id, int color_table, int x, int y, int cx, int cy, int rop, int srcx, int srcy, int cache_idx, struct xrdp_rect *rect) { int order_flags = 0; int vals[12] = {0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0}; int present = 0; char *present_ptr = (char *)NULL; char *order_flags_ptr = (char *)NULL; if (xrdp_orders_check(self, 30) != 0) { return 1; } self->order_count++; order_flags = RDP_ORDER_STANDARD; if (self->orders_state.last_order != RDP_ORDER_MEMBLT) { order_flags |= RDP_ORDER_CHANGE; } self->orders_state.last_order = RDP_ORDER_MEMBLT; if (rect != 0) { /* if clip is present, still check if it's needed */ if (x < rect->left || y < rect->top || x + cx > rect->right || y + cy > rect->bottom) { order_flags |= RDP_ORDER_BOUNDS; if (xrdp_orders_last_bounds(self, rect)) { order_flags |= RDP_ORDER_LASTBOUNDS; } } } vals[0] = x; vals[1] = self->orders_state.mem_blt_x; vals[2] = y; vals[3] = self->orders_state.mem_blt_y; vals[4] = cx; vals[5] = self->orders_state.mem_blt_cx; vals[6] = cy; vals[7] = self->orders_state.mem_blt_cy; vals[8] = srcx; vals[9] = self->orders_state.mem_blt_srcx; vals[10] = srcy; vals[11] = self->orders_state.mem_blt_srcy; if (xrdp_orders_send_delta(self, vals, 12)) { order_flags |= RDP_ORDER_DELTA; } /* order_flags, set later, 1 byte */ order_flags_ptr = self->out_s->p; out_uint8s(self->out_s, 1); if (order_flags & RDP_ORDER_CHANGE) { out_uint8(self->out_s, self->orders_state.last_order); } present = 0; /* present, set later, 2 bytes */ present_ptr = self->out_s->p; out_uint8s(self->out_s, 2); if ((order_flags & RDP_ORDER_BOUNDS) && !(order_flags & RDP_ORDER_LASTBOUNDS)) { xrdp_orders_out_bounds(self, rect); } if (cache_id != self->orders_state.mem_blt_cache_id || color_table != self->orders_state.mem_blt_color_table) { present |= 0x0001; out_uint8(self->out_s, cache_id); out_uint8(self->out_s, color_table); self->orders_state.mem_blt_cache_id = cache_id; self->orders_state.mem_blt_color_table = color_table; } if (x != self->orders_state.mem_blt_x) { present |= 0x0002; if (order_flags & RDP_ORDER_DELTA) { out_uint8(self->out_s, x - self->orders_state.mem_blt_x); } else { out_uint16_le(self->out_s, x); } self->orders_state.mem_blt_x = x; } if (y != self->orders_state.mem_blt_y) { present |= 0x0004; if (order_flags & RDP_ORDER_DELTA) { out_uint8(self->out_s, y - self->orders_state.mem_blt_y); } else { out_uint16_le(self->out_s, y); } self->orders_state.mem_blt_y = y; } if (cx != self->orders_state.mem_blt_cx) { present |= 0x0008; if (order_flags & RDP_ORDER_DELTA) { out_uint8(self->out_s, cx - self->orders_state.mem_blt_cx); } else { out_uint16_le(self->out_s, cx); } self->orders_state.mem_blt_cx = cx; } if (cy != self->orders_state.mem_blt_cy) { present |= 0x0010; if (order_flags & RDP_ORDER_DELTA) { out_uint8(self->out_s, cy - self->orders_state.mem_blt_cy); } else { out_uint16_le(self->out_s, cy); } self->orders_state.mem_blt_cy = cy; } if (rop != self->orders_state.mem_blt_rop) { present |= 0x0020; out_uint8(self->out_s, rop); self->orders_state.mem_blt_rop = rop; } if (srcx != self->orders_state.mem_blt_srcx) { present |= 0x0040; if (order_flags & RDP_ORDER_DELTA) { out_uint8(self->out_s, srcx - self->orders_state.mem_blt_srcx); } else { out_uint16_le(self->out_s, srcx); } self->orders_state.mem_blt_srcx = srcx; } if (srcy != self->orders_state.mem_blt_srcy) { present |= 0x0080; if (order_flags & RDP_ORDER_DELTA) { out_uint8(self->out_s, srcy - self->orders_state.mem_blt_srcy); } else { out_uint16_le(self->out_s, srcy); } self->orders_state.mem_blt_srcy = srcy; } if (cache_idx != self->orders_state.mem_blt_cache_idx) { present |= 0x0100; out_uint16_le(self->out_s, cache_idx); self->orders_state.mem_blt_cache_idx = cache_idx; } xrdp_order_pack_small_or_tiny(self, order_flags_ptr, order_flags, present_ptr, present, 2); return 0; } /*****************************************************************************/ /* returns error */ int xrdp_orders_composite_blt(struct xrdp_orders* self, int srcidx, int srcformat, int srcwidth, int srcrepeat, int* srctransform, int mskflags, int mskidx, int mskformat, int mskwidth, int mskrepeat, int op, int srcx, int srcy, int mskx, int msky, int dstx, int dsty, int width, int height, int dstformat, struct xrdp_rect* rect) { int order_flags; int vals[20]; int present; char* present_ptr; char* order_flags_ptr; if (xrdp_orders_check(self, 80) != 0) { return 1; } self->order_count++; order_flags = RDP_ORDER_STANDARD; if (self->orders_state.last_order != RDP_ORDER_COMPOSITE) { order_flags |= RDP_ORDER_CHANGE; } self->orders_state.last_order = RDP_ORDER_COMPOSITE; if (rect != 0) { /* if clip is present, still check if it's needed */ if (dstx < rect->left || dsty < rect->top || dstx + width > rect->right || dsty + height > rect->bottom) { order_flags |= RDP_ORDER_BOUNDS; if (xrdp_orders_last_bounds(self, rect)) { order_flags |= RDP_ORDER_LASTBOUNDS; } } } vals[0] = srcx; vals[1] = self->orders_state.com_blt_srcx; vals[2] = srcy; vals[3] = self->orders_state.com_blt_srcy; vals[4] = mskx; vals[5] = self->orders_state.com_blt_mskx; vals[6] = msky; vals[7] = self->orders_state.com_blt_msky; vals[8] = dstx; vals[9] = self->orders_state.com_blt_dstx; vals[10] = dsty; vals[11] = self->orders_state.com_blt_dsty; vals[12] = width; vals[13] = self->orders_state.com_blt_width; vals[14] = height; vals[15] = self->orders_state.com_blt_height; vals[16] = srcwidth; vals[17] = self->orders_state.com_blt_srcwidth; vals[18] = mskwidth; vals[19] = self->orders_state.com_blt_mskwidth; if (xrdp_orders_send_delta(self, vals, 20)) { order_flags |= RDP_ORDER_DELTA; } /* order_flags, set later, 1 byte */ order_flags_ptr = self->out_s->p; out_uint8s(self->out_s, 1); if (order_flags & RDP_ORDER_CHANGE) { out_uint8(self->out_s, self->orders_state.last_order); } present = 0; /* present, set later, 3 bytes */ present_ptr = self->out_s->p; out_uint8s(self->out_s, 3); if ((order_flags & RDP_ORDER_BOUNDS) && !(order_flags & RDP_ORDER_LASTBOUNDS)) { xrdp_orders_out_bounds(self, rect); } if (srcidx != self->orders_state.com_blt_srcidx) { present |= 0x000001; out_uint16_le(self->out_s, srcidx); self->orders_state.com_blt_srcidx = srcidx; } if (srcformat != self->orders_state.com_blt_srcformat) { present |= 0x000002; out_uint32_le(self->out_s, srcformat); self->orders_state.com_blt_srcformat = srcformat; } if (srcwidth != self->orders_state.com_blt_srcwidth) { present |= 0x000004; if (order_flags & RDP_ORDER_DELTA) { out_uint8(self->out_s, srcwidth - self->orders_state.com_blt_srcwidth); } else { out_uint16_le(self->out_s, srcwidth); } self->orders_state.com_blt_srcwidth = srcwidth; } if (srcrepeat != self->orders_state.com_blt_srcrepeat) { present |= 0x000008; out_uint8(self->out_s, srcrepeat); self->orders_state.com_blt_srcrepeat = srcrepeat; } if (srctransform != 0) { if (srctransform[0] != self->orders_state.com_blt_srctransform[0]) { present |= 0x000010; out_uint32_le(self->out_s, srctransform[0]); self->orders_state.com_blt_srctransform[0] = srctransform[0]; } if (g_memcmp(&(srctransform[1]), &(self->orders_state.com_blt_srctransform[1]), 36) != 0) { present |= 0x000020; out_uint32_le(self->out_s, srctransform[1]); out_uint32_le(self->out_s, srctransform[2]); out_uint32_le(self->out_s, srctransform[3]); out_uint32_le(self->out_s, srctransform[4]); out_uint32_le(self->out_s, srctransform[5]); out_uint32_le(self->out_s, srctransform[6]); out_uint32_le(self->out_s, srctransform[7]); out_uint32_le(self->out_s, srctransform[8]); out_uint32_le(self->out_s, srctransform[9]); } } else { if (self->orders_state.com_blt_srctransform[0] != 0) { present |= 0x000010; out_uint32_le(self->out_s, 0); self->orders_state.com_blt_srctransform[0] = 0; } } if (mskflags != self->orders_state.com_blt_mskflags) { present |= 0x000040; out_uint8(self->out_s, mskflags); self->orders_state.com_blt_mskflags = mskflags; } if (mskidx != self->orders_state.com_blt_mskidx) { present |= 0x000080; out_uint16_le(self->out_s, mskidx); self->orders_state.com_blt_mskidx = mskidx; } if (mskformat != self->orders_state.com_blt_mskformat) { present |= 0x000100; out_uint32_le(self->out_s, mskformat); self->orders_state.com_blt_mskformat = mskformat; } if (mskwidth != self->orders_state.com_blt_mskwidth) { present |= 0x000200; if (order_flags & RDP_ORDER_DELTA) { out_uint8(self->out_s, mskwidth - self->orders_state.com_blt_mskwidth); } else { out_uint16_le(self->out_s, mskwidth); } self->orders_state.com_blt_mskwidth = mskwidth; } if (mskrepeat != self->orders_state.com_blt_mskrepeat) { present |= 0x000400; out_uint8(self->out_s, mskrepeat); self->orders_state.com_blt_mskrepeat = mskrepeat; } if (op != self->orders_state.com_blt_op) { present |= 0x000800; out_uint8(self->out_s, op); self->orders_state.com_blt_op = op; } if (srcx != self->orders_state.com_blt_srcx) { present |= 0x001000; if (order_flags & RDP_ORDER_DELTA) { out_uint8(self->out_s, srcx - self->orders_state.com_blt_srcx); } else { out_uint16_le(self->out_s, srcx); } self->orders_state.com_blt_srcx = srcx; } if (srcy != self->orders_state.com_blt_srcy) { present |= 0x002000; if (order_flags & RDP_ORDER_DELTA) { out_uint8(self->out_s, srcy - self->orders_state.com_blt_srcy); } else { out_uint16_le(self->out_s, srcy); } self->orders_state.com_blt_srcy = srcy; } if (mskx != self->orders_state.com_blt_mskx) { present |= 0x004000; if (order_flags & RDP_ORDER_DELTA) { out_uint8(self->out_s, mskx - self->orders_state.com_blt_mskx); } else { out_uint16_le(self->out_s, mskx); } self->orders_state.com_blt_mskx = mskx; } if (msky != self->orders_state.com_blt_msky) { present |= 0x008000; if (order_flags & RDP_ORDER_DELTA) { out_uint8(self->out_s, msky - self->orders_state.com_blt_msky); } else { out_uint16_le(self->out_s, msky); } self->orders_state.com_blt_msky = msky; } if (dstx != self->orders_state.com_blt_dstx) { present |= 0x010000; if (order_flags & RDP_ORDER_DELTA) { out_uint8(self->out_s, dstx - self->orders_state.com_blt_dstx); } else { out_uint16_le(self->out_s, dstx); } self->orders_state.com_blt_dstx = dstx; } if (dsty != self->orders_state.com_blt_dsty) { present |= 0x020000; if (order_flags & RDP_ORDER_DELTA) { out_uint8(self->out_s, dsty - self->orders_state.com_blt_dsty); } else { out_uint16_le(self->out_s, dsty); } self->orders_state.com_blt_dsty = dsty; } if (width != self->orders_state.com_blt_width) { present |= 0x040000; if (order_flags & RDP_ORDER_DELTA) { out_uint8(self->out_s, width - self->orders_state.com_blt_width); } else { out_uint16_le(self->out_s, width); } self->orders_state.com_blt_width = width; } if (height != self->orders_state.com_blt_height) { present |= 0x080000; if (order_flags & RDP_ORDER_DELTA) { out_uint8(self->out_s, height - self->orders_state.com_blt_height); } else { out_uint16_le(self->out_s, height); } self->orders_state.com_blt_height = height; } if (dstformat != self->orders_state.com_blt_dstformat) { present |= 0x100000; out_uint32_le(self->out_s, dstformat); self->orders_state.com_blt_dstformat = dstformat; } xrdp_order_pack_small_or_tiny(self, order_flags_ptr, order_flags, present_ptr, present, 3); return 0; } /*****************************************************************************/ /* returns error */ int xrdp_orders_text(struct xrdp_orders *self, int font, int flags, int mixmode, int fg_color, int bg_color, int clip_left, int clip_top, int clip_right, int clip_bottom, int box_left, int box_top, int box_right, int box_bottom, int x, int y, char *data, int data_len, struct xrdp_rect *rect) { int order_flags = 0; int present = 0; char *present_ptr = (char *)NULL; char *order_flags_ptr = (char *)NULL; if (xrdp_orders_check(self, 44 + data_len) != 0) { return 1; } self->order_count++; order_flags = RDP_ORDER_STANDARD; if (self->orders_state.last_order != RDP_ORDER_TEXT2) { order_flags |= RDP_ORDER_CHANGE; } self->orders_state.last_order = RDP_ORDER_TEXT2; if (rect != 0) { /* if clip is present, still check if it's needed */ if ((box_right - box_left > 1 && (box_left < rect->left || box_top < rect->top || box_right > rect->right || box_bottom > rect->bottom)) || (clip_left < rect->left || clip_top < rect->top || clip_right > rect->right || clip_bottom > rect->bottom)) { order_flags |= RDP_ORDER_BOUNDS; if (xrdp_orders_last_bounds(self, rect)) { order_flags |= RDP_ORDER_LASTBOUNDS; } } } /* order_flags, set later, 1 byte */ order_flags_ptr = self->out_s->p; out_uint8s(self->out_s, 1); if (order_flags & RDP_ORDER_CHANGE) { out_uint8(self->out_s, self->orders_state.last_order); } present = 0; /* present, set later, 3 bytes */ present_ptr = self->out_s->p; out_uint8s(self->out_s, 3); if ((order_flags & RDP_ORDER_BOUNDS) && !(order_flags & RDP_ORDER_LASTBOUNDS)) { xrdp_orders_out_bounds(self, rect); } if (font != self->orders_state.text_font) { present |= 0x000001; out_uint8(self->out_s, font); self->orders_state.text_font = font; } if (flags != self->orders_state.text_flags) { present |= 0x000002; out_uint8(self->out_s, flags); self->orders_state.text_flags = flags; } /* unknown */ if (mixmode != self->orders_state.text_mixmode) { present |= 0x000008; out_uint8(self->out_s, mixmode); self->orders_state.text_mixmode = mixmode; } if (fg_color != self->orders_state.text_fg_color) { present |= 0x000010; out_uint8(self->out_s, fg_color); out_uint8(self->out_s, fg_color >> 8); out_uint8(self->out_s, fg_color >> 16); self->orders_state.text_fg_color = fg_color; } if (bg_color != self->orders_state.text_bg_color) { present |= 0x000020; out_uint8(self->out_s, bg_color); out_uint8(self->out_s, bg_color >> 8); out_uint8(self->out_s, bg_color >> 16); self->orders_state.text_bg_color = bg_color; } if (clip_left != self->orders_state.text_clip_left) { present |= 0x000040; out_uint16_le(self->out_s, clip_left); self->orders_state.text_clip_left = clip_left; } if (clip_top != self->orders_state.text_clip_top) { present |= 0x000080; out_uint16_le(self->out_s, clip_top); self->orders_state.text_clip_top = clip_top; } if (clip_right != self->orders_state.text_clip_right) { present |= 0x000100; out_uint16_le(self->out_s, clip_right); self->orders_state.text_clip_right = clip_right; } if (clip_bottom != self->orders_state.text_clip_bottom) { present |= 0x000200; out_uint16_le(self->out_s, clip_bottom); self->orders_state.text_clip_bottom = clip_bottom; } if (box_left != self->orders_state.text_box_left) { present |= 0x000400; out_uint16_le(self->out_s, box_left); self->orders_state.text_box_left = box_left; } if (box_top != self->orders_state.text_box_top) { present |= 0x000800; out_uint16_le(self->out_s, box_top); self->orders_state.text_box_top = box_top; } if (box_right != self->orders_state.text_box_right) { present |= 0x001000; out_uint16_le(self->out_s, box_right); self->orders_state.text_box_right = box_right; } if (box_bottom != self->orders_state.text_box_bottom) { present |= 0x002000; out_uint16_le(self->out_s, box_bottom); self->orders_state.text_box_bottom = box_bottom; } if (x != self->orders_state.text_x) { present |= 0x080000; out_uint16_le(self->out_s, x); self->orders_state.text_x = x; } if (y != self->orders_state.text_y) { present |= 0x100000; out_uint16_le(self->out_s, y); self->orders_state.text_y = y; } { /* always send text */ present |= 0x200000; out_uint8(self->out_s, data_len); out_uint8a(self->out_s, data, data_len); } xrdp_order_pack_small_or_tiny(self, order_flags_ptr, order_flags, present_ptr, present, 3); return 0; } /*****************************************************************************/ /* returns error */ /* when a palette gets sent, send the main palette too */ int xrdp_orders_send_palette(struct xrdp_orders *self, int *palette, int cache_id) { int order_flags; int len; int i; if (xrdp_orders_check(self, 2000) != 0) { return 1; } self->order_count++; order_flags = RDP_ORDER_STANDARD | RDP_ORDER_SECONDARY; out_uint8(self->out_s, order_flags); len = 1027 - 7; /* length after type minus 7 */ out_uint16_le(self->out_s, len); out_uint16_le(self->out_s, 0); /* flags */ out_uint8(self->out_s, RDP_ORDER_COLCACHE); /* type */ out_uint8(self->out_s, cache_id); out_uint16_le(self->out_s, 256); /* num colors */ for (i = 0; i < 256; i++) { out_uint8(self->out_s, palette[i]); out_uint8(self->out_s, palette[i] >> 8); out_uint8(self->out_s, palette[i] >> 16); out_uint8(self->out_s, 0); } return 0; } /*****************************************************************************/ /* returns error */ /* max size width * height * Bpp + 16 */ int xrdp_orders_send_raw_bitmap(struct xrdp_orders *self, int width, int height, int bpp, char *data, int cache_id, int cache_idx) { int order_flags = 0; int len = 0; int bufsize = 0; int Bpp = 0; int i = 0; int j = 0; int pixel = 0; int e = 0; int max_order_size; struct xrdp_client_info *ci; if (width > 64) { g_writeln("error, width > 64"); return 1; } if (height > 64) { g_writeln("error, height > 64"); return 1; } e = width % 4; if (e != 0) { e = 4 - e; } Bpp = (bpp + 7) / 8; bufsize = (width + e) * height * Bpp; ci = &(self->rdp_layer->client_info); max_order_size = MAX_ORDERS_SIZE(ci); while (bufsize + 16 > max_order_size) { height--; bufsize = (width + e) * height * Bpp; } if (xrdp_orders_check(self, bufsize + 16) != 0) { return 1; } self->order_count++; order_flags = RDP_ORDER_STANDARD | RDP_ORDER_SECONDARY; out_uint8(self->out_s, order_flags); len = (bufsize + 9) - 7; /* length after type minus 7 */ out_uint16_le(self->out_s, len); out_uint16_le(self->out_s, 8); /* flags */ out_uint8(self->out_s, RDP_ORDER_RAW_BMPCACHE); /* type */ out_uint8(self->out_s, cache_id); out_uint8s(self->out_s, 1); /* pad */ out_uint8(self->out_s, width + e); out_uint8(self->out_s, height); out_uint8(self->out_s, bpp); out_uint16_le(self->out_s, bufsize); out_uint16_le(self->out_s, cache_idx); if (Bpp == 4) { for (i = height - 1; i >= 0; i--) { for (j = 0; j < width; j++) { pixel = GETPIXEL32(data, j, i, width); out_uint8(self->out_s, pixel); out_uint8(self->out_s, pixel >> 8); out_uint8(self->out_s, pixel >> 16); out_uint8(self->out_s, pixel >> 24); } out_uint8s(self->out_s, Bpp * e); } } else if (Bpp == 3) { for (i = height - 1; i >= 0; i--) { for (j = 0; j < width; j++) { pixel = GETPIXEL32(data, j, i, width); out_uint8(self->out_s, pixel); out_uint8(self->out_s, pixel >> 8); out_uint8(self->out_s, pixel >> 16); } out_uint8s(self->out_s, Bpp * e); } } else if (Bpp == 2) { for (i = height - 1; i >= 0; i--) { for (j = 0; j < width; j++) { pixel = GETPIXEL16(data, j, i, width); out_uint8(self->out_s, pixel); out_uint8(self->out_s, pixel >> 8); } out_uint8s(self->out_s, Bpp * e); } } else if (Bpp == 1) { for (i = height - 1; i >= 0; i--) { for (j = 0; j < width; j++) { pixel = GETPIXEL8(data, j, i, width); out_uint8(self->out_s, pixel); } out_uint8s(self->out_s, Bpp * e); } } return 0; } /*****************************************************************************/ /* returns error */ /* max size width * height * Bpp + 16 */ int xrdp_orders_send_bitmap(struct xrdp_orders *self, int width, int height, int bpp, char *data, int cache_id, int cache_idx) { int order_flags = 0; int len = 0; int bufsize = 0; int Bpp = 0; int i = 0; int lines_sending = 0; int e = 0; struct stream *s = NULL; struct stream *temp_s = NULL; char *p = NULL; int max_order_size; struct xrdp_client_info *ci; if (width > 64) { g_writeln("error, width > 64"); return 1; } if (height > 64) { g_writeln("error, height > 64"); return 1; } ci = &(self->rdp_layer->client_info); max_order_size = MAX_ORDERS_SIZE(ci); e = width % 4; if (e != 0) { e = 4 - e; } s = self->s; init_stream(s, 16384 * 2); temp_s = self->temp_s; init_stream(temp_s, 16384 * 2); p = s->p; i = height; if (bpp > 24) { lines_sending = xrdp_bitmap32_compress(data, width, height, s, bpp, max_order_size, i - 1, temp_s, e, 0x10); } else { lines_sending = xrdp_bitmap_compress(data, width, height, s, bpp, max_order_size, i - 1, temp_s, e); } if (lines_sending != height) { height = lines_sending; } bufsize = (int)(s->p - p); Bpp = (bpp + 7) / 8; if (xrdp_orders_check(self, bufsize + 16) != 0) { return 1; } self->order_count++; order_flags = RDP_ORDER_STANDARD | RDP_ORDER_SECONDARY; out_uint8(self->out_s, order_flags); if (self->rdp_layer->client_info.op2) { len = (bufsize + 9) - 7; /* length after type minus 7 */ out_uint16_le(self->out_s, len); out_uint16_le(self->out_s, 1024); /* flags */ } else { len = (bufsize + 9 + 8) - 7; /* length after type minus 7 */ out_uint16_le(self->out_s, len); out_uint16_le(self->out_s, 8); /* flags */ } out_uint8(self->out_s, RDP_ORDER_BMPCACHE); /* type */ out_uint8(self->out_s, cache_id); out_uint8s(self->out_s, 1); /* pad */ out_uint8(self->out_s, width + e); out_uint8(self->out_s, height); out_uint8(self->out_s, bpp); out_uint16_le(self->out_s, bufsize/* + 8*/); out_uint16_le(self->out_s, cache_idx); if (!self->rdp_layer->client_info.op2) { out_uint8s(self->out_s, 2); /* pad */ out_uint16_le(self->out_s, bufsize); out_uint16_le(self->out_s, (width + e) * Bpp); /* line size */ out_uint16_le(self->out_s, (width + e) * Bpp * height); /* final size */ } out_uint8a(self->out_s, s->data, bufsize); return 0; } /*****************************************************************************/ /* returns error */ /* max size datasize + 18*/ /* todo, only sends one for now */ int xrdp_orders_send_font(struct xrdp_orders *self, struct xrdp_font_char *font_char, int font_index, int char_index) { int order_flags = 0; int datasize = 0; int len = 0; int flags; if (font_char->bpp == 8) /* alpha font */ { datasize = ((font_char->width + 3) & ~3) * font_char->height; flags = 8 | 0x4000; } else { datasize = FONT_DATASIZE(font_char); flags = 8; } if (xrdp_orders_check(self, datasize + 18) != 0) { return 1; } self->order_count++; order_flags = RDP_ORDER_STANDARD | RDP_ORDER_SECONDARY; out_uint8(self->out_s, order_flags); len = (datasize + 12) - 7; /* length after type minus 7 */ out_uint16_le(self->out_s, len); out_uint16_le(self->out_s, flags); out_uint8(self->out_s, RDP_ORDER_FONTCACHE); /* type */ out_uint8(self->out_s, font_index); out_uint8(self->out_s, 1); /* num of chars */ out_uint16_le(self->out_s, char_index); out_uint16_le(self->out_s, font_char->offset); out_uint16_le(self->out_s, font_char->baseline); out_uint16_le(self->out_s, font_char->width); out_uint16_le(self->out_s, font_char->height); out_uint8a(self->out_s, font_char->data, datasize); return 0; } /*****************************************************************************/ /* returns error */ /* max size width * height * Bpp + 14 */ int xrdp_orders_send_raw_bitmap2(struct xrdp_orders *self, int width, int height, int bpp, char *data, int cache_id, int cache_idx) { int order_flags = 0; int len = 0; int bufsize = 0; int Bpp = 0; int i = 0; int j = 0; int pixel = 0; int e = 0; int max_order_size; struct xrdp_client_info *ci; if (width > 64) { g_writeln("error, width > 64"); return 1; } if (height > 64) { g_writeln("error, height > 64"); return 1; } ci = &(self->rdp_layer->client_info); max_order_size = MAX_ORDERS_SIZE(ci); e = width % 4; if (e != 0) { e = 4 - e; } Bpp = (bpp + 7) / 8; bufsize = (width + e) * height * Bpp; while (bufsize + 14 > max_order_size) { height--; bufsize = (width + e) * height * Bpp; } if (xrdp_orders_check(self, bufsize + 14) != 0) { return 1; } self->order_count++; order_flags = RDP_ORDER_STANDARD | RDP_ORDER_SECONDARY; out_uint8(self->out_s, order_flags); len = (bufsize + 6) - 7; /* length after type minus 7 */ out_uint16_le(self->out_s, len); i = (((Bpp + 2) << 3) & 0x38) | (cache_id & 7); out_uint16_le(self->out_s, i); /* flags */ out_uint8(self->out_s, RDP_ORDER_RAW_BMPCACHE2); /* type */ out_uint8(self->out_s, width + e); out_uint8(self->out_s, height); out_uint16_be(self->out_s, bufsize | 0x4000); i = ((cache_idx >> 8) & 0xff) | 0x80; out_uint8(self->out_s, i); i = cache_idx & 0xff; out_uint8(self->out_s, i); if (Bpp == 4) { for (i = height - 1; i >= 0; i--) { for (j = 0; j < width; j++) { pixel = GETPIXEL32(data, j, i, width); out_uint8(self->out_s, pixel); out_uint8(self->out_s, pixel >> 8); out_uint8(self->out_s, pixel >> 16); out_uint8(self->out_s, pixel >> 24); } out_uint8s(self->out_s, Bpp * e); } } else if (Bpp == 3) { for (i = height - 1; i >= 0; i--) { for (j = 0; j < width; j++) { pixel = GETPIXEL32(data, j, i, width); out_uint8(self->out_s, pixel); out_uint8(self->out_s, pixel >> 8); out_uint8(self->out_s, pixel >> 16); } out_uint8s(self->out_s, Bpp * e); } } else if (Bpp == 2) { for (i = height - 1; i >= 0; i--) { for (j = 0; j < width; j++) { pixel = GETPIXEL16(data, j, i, width); out_uint8(self->out_s, pixel); out_uint8(self->out_s, pixel >> 8); } out_uint8s(self->out_s, Bpp * e); } } else if (Bpp == 1) { for (i = height - 1; i >= 0; i--) { for (j = 0; j < width; j++) { pixel = GETPIXEL8(data, j, i, width); out_uint8(self->out_s, pixel); } out_uint8s(self->out_s, Bpp * e); } } return 0; } /*****************************************************************************/ /* returns error */ /* max size width * height * Bpp + 14 */ int xrdp_orders_send_bitmap2(struct xrdp_orders *self, int width, int height, int bpp, char *data, int cache_id, int cache_idx, int hints) { int order_flags = 0; int len = 0; int bufsize = 0; int Bpp = 0; int i = 0; int lines_sending = 0; int e = 0; struct stream *s = NULL; struct stream *temp_s = NULL; char *p = NULL; int max_order_size; struct xrdp_client_info *ci; if (width > 64) { g_writeln("error, width > 64"); return 1; } if (height > 64) { g_writeln("error, height > 64"); return 1; } ci = &(self->rdp_layer->client_info); max_order_size = MAX_ORDERS_SIZE(ci); e = width % 4; if (e != 0) { e = 4 - e; } s = self->s; init_stream(s, 16384 * 2); temp_s = self->temp_s; init_stream(temp_s, 16384 * 2); p = s->p; i = height; if (bpp > 24) { lines_sending = xrdp_bitmap32_compress(data, width, height, s, bpp, max_order_size, i - 1, temp_s, e, 0x10); } else { lines_sending = xrdp_bitmap_compress(data, width, height, s, bpp, max_order_size, i - 1, temp_s, e); } if (lines_sending != height) { height = lines_sending; } bufsize = (int)(s->p - p); Bpp = (bpp + 7) / 8; if (xrdp_orders_check(self, bufsize + 14) != 0) { return 1; } self->order_count++; order_flags = RDP_ORDER_STANDARD | RDP_ORDER_SECONDARY; out_uint8(self->out_s, order_flags); len = (bufsize + 6) - 7; /* length after type minus 7 */ out_uint16_le(self->out_s, len); i = (((Bpp + 2) << 3) & 0x38) | (cache_id & 7); i = i | (0x08 << 7); /* CBR2_NO_BITMAP_COMPRESSION_HDR */ out_uint16_le(self->out_s, i); /* flags */ out_uint8(self->out_s, RDP_ORDER_BMPCACHE2); /* type */ out_uint8(self->out_s, width + e); out_uint8(self->out_s, height); out_uint16_be(self->out_s, bufsize | 0x4000); i = ((cache_idx >> 8) & 0xff) | 0x80; out_uint8(self->out_s, i); i = cache_idx & 0xff; out_uint8(self->out_s, i); out_uint8a(self->out_s, s->data, bufsize); return 0; } #if defined(XRDP_JPEG) /*****************************************************************************/ static int xrdp_orders_send_as_jpeg(struct xrdp_orders *self, int width, int height, int bpp, int hints) { if (hints & 1) { return 0; } if (bpp != 24) { return 0; } if (width * height < 64) { return 0; } return 1; } #endif #if defined(XRDP_NEUTRINORDP) /*****************************************************************************/ /* secondary drawing order (bitmap v3) using remotefx compression */ static int xrdp_orders_send_as_rfx(struct xrdp_orders *self, int width, int height, int bpp, int hints) { if (hints & 1) { return 0; } if (bpp != 24) { return 0; } LLOGLN(10, ("width %d height %d rfx_min_pixel %d", width, height, self->rfx_min_pixel)); if (width * height < self->rfx_min_pixel) { return 0; } return 1; } #endif #if defined(XRDP_JPEG) || defined(XRDP_NEUTRINORDP) /*****************************************************************************/ static int xrdp_orders_out_v3(struct xrdp_orders *self, int cache_id, int cache_idx, char *buf, int bufsize, int width, int height, int bpp, int codec_id) { int Bpp; int order_flags; int len; int i; Bpp = (bpp + 7) / 8; if (xrdp_orders_check(self, bufsize + 30) != 0) { return 1; } self->order_count++; order_flags = RDP_ORDER_STANDARD | RDP_ORDER_SECONDARY; out_uint8(self->out_s, order_flags); len = (bufsize + 22) - 7; /* length after type minus 7 */ out_uint16_le(self->out_s, len); i = (((Bpp + 2) << 3) & 0x38) | (cache_id & 7); out_uint16_le(self->out_s, i); /* flags */ out_uint8(self->out_s, RDP_ORDER_BMPCACHE3); /* type */ /* cache index */ out_uint16_le(self->out_s, cache_idx); /* persistent cache key 1/2 */ out_uint32_le(self->out_s, 0); out_uint32_le(self->out_s, 0); /* bitmap data */ out_uint8(self->out_s, bpp); out_uint8(self->out_s, 0); /* reserved */ out_uint8(self->out_s, 0); /* reserved */ out_uint8(self->out_s, codec_id); out_uint16_le(self->out_s, width); out_uint16_le(self->out_s, height); out_uint32_le(self->out_s, bufsize); out_uint8a(self->out_s, buf, bufsize); return 0; } #endif /*****************************************************************************/ /* secondary drawing order (bitmap v3) using remotefx compression */ int xrdp_orders_send_bitmap3(struct xrdp_orders *self, int width, int height, int bpp, char *data, int cache_id, int cache_idx, int hints) { struct xrdp_client_info *ci; #if defined(XRDP_JPEG) || defined(XRDP_NEUTRINORDP) int bufsize; struct stream *xr_s; /* xrdp stream */ #endif #if defined(XRDP_JPEG) int e; int quality; struct stream *temp_s; /* xrdp stream */ #endif #if defined(XRDP_NEUTRINORDP) STREAM *fr_s; /* FreeRDP stream */ RFX_CONTEXT *context; RFX_RECT rect; #endif ci = &(self->rdp_layer->client_info); if (ci->v3_codec_id == 0) { return 2; } if (ci->v3_codec_id == ci->rfx_codec_id) { #if defined(XRDP_NEUTRINORDP) if (!xrdp_orders_send_as_rfx(self, width, height, bpp, hints)) { return 2; } LLOGLN(10, ("xrdp_orders_send_bitmap3: rfx")); context = (RFX_CONTEXT *)(self->rdp_layer->rfx_enc); make_stream(xr_s); init_stream(xr_s, 16384); fr_s = stream_new(0); stream_attach(fr_s, (tui8 *)(xr_s->data), 16384); rect.x = 0; rect.y = 0; rect.width = width; rect.height = height; rfx_compose_message(context, fr_s, &rect, 1, (tui8 *)data, width, height, width * 4); bufsize = stream_get_length(fr_s); xrdp_orders_out_v3(self, cache_id, cache_idx, (char *)(fr_s->data), bufsize, width, height, bpp, ci->v3_codec_id); stream_detach(fr_s); stream_free(fr_s); free_stream(xr_s); return 0; #else return 2; #endif } else if (ci->v3_codec_id == ci->jpeg_codec_id) { #if defined(XRDP_JPEG) if (!xrdp_orders_send_as_jpeg(self, width, height, bpp, hints)) { LLOGLN(10, ("xrdp_orders_send_bitmap3: jpeg skipped")); return 2; } LLOGLN(10, ("xrdp_orders_send_bitmap3: jpeg")); e = width % 4; if (e != 0) { e = 4 - e; } make_stream(xr_s); init_stream(xr_s, 16384); make_stream(temp_s); init_stream(temp_s, 16384); quality = ci->jpeg_prop[0]; xrdp_jpeg_compress(self->jpeg_han, data, width, height, xr_s, bpp, 16384, height - 1, temp_s, e, quality); s_mark_end(xr_s); bufsize = (int)(xr_s->end - xr_s->data); xrdp_orders_out_v3(self, cache_id, cache_idx, (char *)(xr_s->data), bufsize, width + e, height, bpp, ci->v3_codec_id); free_stream(xr_s); free_stream(temp_s); return 0; #else return 2; #endif } else { g_writeln("xrdp_orders_send_bitmap3: todo unknown codec"); return 1; } return 0; } /*****************************************************************************/ /* returns error */ /* send a brush cache entry */ int xrdp_orders_send_brush(struct xrdp_orders *self, int width, int height, int bpp, int type, int size, char *data, int cache_id) { int order_flags = 0; int len = 0; if (xrdp_orders_check(self, size + 12) != 0) { return 1; } self->order_count++; order_flags = RDP_ORDER_STANDARD | RDP_ORDER_SECONDARY; out_uint8(self->out_s, order_flags); len = (size + 6) - 7; /* length after type minus 7 */ out_uint16_le(self->out_s, len); out_uint16_le(self->out_s, 0); /* flags */ out_uint8(self->out_s, RDP_ORDER_BRUSHCACHE); /* type */ out_uint8(self->out_s, cache_id); out_uint8(self->out_s, bpp); out_uint8(self->out_s, width); out_uint8(self->out_s, height); out_uint8(self->out_s, type); out_uint8(self->out_s, size); out_uint8a(self->out_s, data, size); return 0; } /*****************************************************************************/ /* returns error */ /* send an off screen bitmap entry */ int xrdp_orders_send_create_os_surface(struct xrdp_orders *self, int id, int width, int height, struct list *del_list) { int order_flags; int cache_id; int flags; int index; int bytes; int num_del_list; bytes = 7; num_del_list = del_list->count; if (num_del_list > 0) { bytes += 2; bytes += num_del_list * 2; } if (xrdp_orders_check(self, bytes) != 0) { return 1; } self->order_count++; order_flags = RDP_ORDER_SECONDARY; order_flags |= 1 << 2; /* type RDP_ORDER_ALTSEC_CREATE_OFFSCR_BITMAP */ out_uint8(self->out_s, order_flags); cache_id = id & 0x7fff; LLOGLN(10, ("xrdp_orders_send_create_os_surface: cache_id %d", cache_id)); flags = cache_id; if (num_del_list > 0) { flags |= 0x8000; } out_uint16_le(self->out_s, flags); out_uint16_le(self->out_s, width); out_uint16_le(self->out_s, height); if (num_del_list > 0) { /* delete list */ out_uint16_le(self->out_s, num_del_list); for (index = 0; index < num_del_list; index++) { cache_id = list_get_item(del_list, index) & 0x7fff; out_uint16_le(self->out_s, cache_id); } } return 0; } /*****************************************************************************/ /* returns error */ int xrdp_orders_send_switch_os_surface(struct xrdp_orders *self, int id) { int order_flags; int cache_id; if (xrdp_orders_check(self, 3) != 0) { return 1; } self->order_count++; order_flags = RDP_ORDER_SECONDARY; order_flags |= 0 << 2; /* type RDP_ORDER_ALTSEC_SWITCH_SURFACE */ out_uint8(self->out_s, order_flags); cache_id = id & 0xffff; out_uint16_le(self->out_s, cache_id); return 0; } xrdp-0.9.5/libxrdp/xrdp_bitmap_compress.c000644 001751 001751 00000144066 13174271344 020477 0ustar00metameta000000 000000 /** * xrdp: A Remote Desktop Protocol server. * * Copyright (C) Jay Sorg 2004-2014 * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. * * bitmap compressor * This is the original RDP bitmap compression algorithm. Pixel based. * This does not do 32 bpp compression, nscodec, rfx, etc */ #if defined(HAVE_CONFIG_H) #include #endif #include "libxrdp.h" #define BC_MAX_BYTES (16 * 1024) /*****************************************************************************/ #define IN_PIXEL8(in_ptr, in_x, in_y, in_w, in_last_pixel, in_pixel); \ do { \ if (in_ptr == 0) \ { \ in_pixel = 0; \ } \ else if (in_x < in_w) \ { \ in_pixel = GETPIXEL8(in_ptr, in_x, in_y, in_w); \ } \ else \ { \ in_pixel = in_last_pixel; \ } \ } while (0) /*****************************************************************************/ #define IN_PIXEL16(in_ptr, in_x, in_y, in_w, in_last_pixel, in_pixel); \ do { \ if (in_ptr == 0) \ { \ in_pixel = 0; \ } \ else if (in_x < in_w) \ { \ in_pixel = GETPIXEL16(in_ptr, in_x, in_y, in_w); \ } \ else \ { \ in_pixel = in_last_pixel; \ } \ } while (0) /*****************************************************************************/ #define IN_PIXEL32(in_ptr, in_x, in_y, in_w, in_last_pixel, in_pixel); \ do { \ if (in_ptr == 0) \ { \ in_pixel = 0; \ } \ else if (in_x < in_w) \ { \ in_pixel = GETPIXEL32(in_ptr, in_x, in_y, in_w); \ } \ else \ { \ in_pixel = in_last_pixel; \ } \ } while (0) /*****************************************************************************/ /* color */ #define OUT_COLOR_COUNT1(in_count, in_s, in_data) \ do { \ if (in_count > 0) \ { \ if (in_count < 32) \ { \ temp = (0x3 << 5) | in_count; \ out_uint8(in_s, temp); \ out_uint8(in_s, in_data); \ } \ else if (in_count < 256 + 32) \ { \ out_uint8(in_s, 0x60); \ temp = in_count - 32; \ out_uint8(in_s, temp); \ out_uint8(in_s, in_data); \ } \ else \ { \ out_uint8(in_s, 0xf3); \ out_uint16_le(in_s, in_count); \ out_uint8(in_s, in_data); \ } \ } \ in_count = 0; \ } while (0) /*****************************************************************************/ /* color */ #define OUT_COLOR_COUNT2(in_count, in_s, in_data) \ do { \ if (in_count > 0) \ { \ if (in_count < 32) \ { \ temp = (0x3 << 5) | in_count; \ out_uint8(in_s, temp); \ out_uint16_le(in_s, in_data); \ } \ else if (in_count < 256 + 32) \ { \ out_uint8(in_s, 0x60); \ temp = in_count - 32; \ out_uint8(in_s, temp); \ out_uint16_le(in_s, in_data); \ } \ else \ { \ out_uint8(in_s, 0xf3); \ out_uint16_le(in_s, in_count); \ out_uint16_le(in_s, in_data); \ } \ } \ in_count = 0; \ } while (0) /*****************************************************************************/ /* color */ #define OUT_COLOR_COUNT3(in_count, in_s, in_data) \ do { \ if (in_count > 0) \ { \ if (in_count < 32) \ { \ temp = (0x3 << 5) | in_count; \ out_uint8(in_s, temp); \ out_uint8(in_s, in_data & 0xff); \ out_uint8(in_s, (in_data >> 8) & 0xff); \ out_uint8(in_s, (in_data >> 16) & 0xff); \ } \ else if (in_count < 256 + 32) \ { \ out_uint8(in_s, 0x60); \ temp = in_count - 32; \ out_uint8(in_s, temp); \ out_uint8(in_s, in_data & 0xff); \ out_uint8(in_s, (in_data >> 8) & 0xff); \ out_uint8(in_s, (in_data >> 16) & 0xff); \ } \ else \ { \ out_uint8(in_s, 0xf3); \ out_uint16_le(in_s, in_count); \ out_uint8(in_s, in_data & 0xff); \ out_uint8(in_s, (in_data >> 8) & 0xff); \ out_uint8(in_s, (in_data >> 16) & 0xff); \ } \ } \ in_count = 0; \ } while (0) /*****************************************************************************/ /* copy */ #define OUT_COPY_COUNT1(in_count, in_s, in_data) \ do { \ if (in_count > 0) \ { \ if (in_count < 32) \ { \ temp = (0x4 << 5) | in_count; \ out_uint8(in_s, temp); \ out_uint8a(in_s, in_data->data, in_count); \ } \ else if (in_count < 256 + 32) \ { \ out_uint8(in_s, 0x80); \ temp = in_count - 32; \ out_uint8(in_s, temp); \ out_uint8a(in_s, in_data->data, in_count); \ } \ else \ { \ out_uint8(in_s, 0xf4); \ out_uint16_le(in_s, in_count); \ out_uint8a(in_s, in_data->data, in_count); \ } \ } \ in_count = 0; \ init_stream(in_data, 0); \ } while (0) /*****************************************************************************/ /* copy */ #define OUT_COPY_COUNT2(in_count, in_s, in_data) \ do { \ if (in_count > 0) \ { \ if (in_count < 32) \ { \ temp = (0x4 << 5) | in_count; \ out_uint8(in_s, temp); \ temp = in_count * 2; \ out_uint8a(in_s, in_data->data, temp); \ } \ else if (in_count < 256 + 32) \ { \ out_uint8(in_s, 0x80); \ temp = in_count - 32; \ out_uint8(in_s, temp); \ temp = in_count * 2; \ out_uint8a(in_s, in_data->data, temp); \ } \ else \ { \ out_uint8(in_s, 0xf4); \ out_uint16_le(in_s, in_count); \ temp = in_count * 2; \ out_uint8a(in_s, in_data->data, temp); \ } \ } \ in_count = 0; \ init_stream(in_data, 0); \ } while (0) /*****************************************************************************/ /* copy */ #define OUT_COPY_COUNT3(in_count, in_s, in_data) \ do { \ if (in_count > 0) \ { \ if (in_count < 32) \ { \ temp = (0x4 << 5) | in_count; \ out_uint8(in_s, temp); \ temp = in_count * 3; \ out_uint8a(in_s, in_data->end, temp); \ } \ else if (in_count < 256 + 32) \ { \ out_uint8(in_s, 0x80); \ temp = in_count - 32; \ out_uint8(in_s, temp); \ temp = in_count * 3; \ out_uint8a(in_s, in_data->end, temp); \ } \ else \ { \ out_uint8(in_s, 0xf4); \ out_uint16_le(in_s, in_count); \ temp = in_count * 3; \ out_uint8a(in_s, in_data->end, temp); \ } \ } \ in_count = 0; \ init_stream(in_data, 0); \ } while (0) /*****************************************************************************/ /* bicolor */ #define OUT_BICOLOR_COUNT1(in_count, in_s, in_color1, in_color2) \ do { \ if (in_count > 0) \ { \ if (in_count / 2 < 16) \ { \ temp = (0xe << 4) | (in_count / 2); \ out_uint8(in_s, temp); \ out_uint8(in_s, in_color1); \ out_uint8(in_s, in_color2); \ } \ else if (in_count / 2 < 256 + 16) \ { \ out_uint8(in_s, 0xe0); \ temp = in_count / 2 - 16; \ out_uint8(in_s, temp); \ out_uint8(in_s, in_color1); \ out_uint8(in_s, in_color2); \ } \ else \ { \ out_uint8(in_s, 0xf8); \ temp = in_count / 2; \ out_uint16_le(in_s, temp); \ out_uint8(in_s, in_color1); \ out_uint8(in_s, in_color2); \ } \ } \ in_count = 0; \ } while (0) /*****************************************************************************/ /* bicolor */ #define OUT_BICOLOR_COUNT2(in_count, in_s, in_color1, in_color2) \ do { \ if (in_count > 0) \ { \ if (in_count / 2 < 16) \ { \ temp = (0xe << 4) | (in_count / 2); \ out_uint8(in_s, temp); \ out_uint16_le(in_s, in_color1); \ out_uint16_le(in_s, in_color2); \ } \ else if (in_count / 2 < 256 + 16) \ { \ out_uint8(in_s, 0xe0); \ temp = in_count / 2 - 16; \ out_uint8(in_s, temp); \ out_uint16_le(in_s, in_color1); \ out_uint16_le(in_s, in_color2); \ } \ else \ { \ out_uint8(in_s, 0xf8); \ temp = in_count / 2; \ out_uint16_le(in_s, temp); \ out_uint16_le(in_s, in_color1); \ out_uint16_le(in_s, in_color2); \ } \ } \ in_count = 0; \ } while (0) /*****************************************************************************/ /* bicolor */ #define OUT_BICOLOR_COUNT3(in_count, in_s, in_color1, in_color2) \ do { \ if (in_count > 0) \ { \ if (in_count / 2 < 16) \ { \ temp = (0xe << 4) | (in_count / 2); \ out_uint8(in_s, temp); \ out_uint8(in_s, in_color1 & 0xff); \ out_uint8(in_s, (in_color1 >> 8) & 0xff); \ out_uint8(in_s, (in_color1 >> 16) & 0xff); \ out_uint8(in_s, in_color2 & 0xff); \ out_uint8(in_s, (in_color2 >> 8) & 0xff); \ out_uint8(in_s, (in_color2 >> 16) & 0xff); \ } \ else if (in_count / 2 < 256 + 16) \ { \ out_uint8(in_s, 0xe0); \ temp = in_count / 2 - 16; \ out_uint8(in_s, temp); \ out_uint8(in_s, in_color1 & 0xff); \ out_uint8(in_s, (in_color1 >> 8) & 0xff); \ out_uint8(in_s, (in_color1 >> 16) & 0xff); \ out_uint8(in_s, in_color2 & 0xff); \ out_uint8(in_s, (in_color2 >> 8) & 0xff); \ out_uint8(in_s, (in_color2 >> 16) & 0xff); \ } \ else \ { \ out_uint8(in_s, 0xf8); \ temp = in_count / 2; \ out_uint16_le(in_s, temp); \ out_uint8(in_s, in_color1 & 0xff); \ out_uint8(in_s, (in_color1 >> 8) & 0xff); \ out_uint8(in_s, (in_color1 >> 16) & 0xff); \ out_uint8(in_s, in_color2 & 0xff); \ out_uint8(in_s, (in_color2 >> 8) & 0xff); \ out_uint8(in_s, (in_color2 >> 16) & 0xff); \ } \ } \ in_count = 0; \ } while (0) /*****************************************************************************/ /* fill */ #define OUT_FILL_COUNT1(in_count, in_s) \ do { \ if (in_count > 0) \ { \ if (in_count < 32) \ { \ out_uint8(in_s, in_count); \ } \ else if (in_count < 256 + 32) \ { \ out_uint8(in_s, 0x0); \ temp = in_count - 32; \ out_uint8(in_s, temp); \ } \ else \ { \ out_uint8(in_s, 0xf0); \ out_uint16_le(in_s, in_count); \ } \ } \ in_count = 0; \ } while (0) /*****************************************************************************/ /* fill */ #define OUT_FILL_COUNT2(in_count, in_s) \ do { \ if (in_count > 0) \ { \ if (in_count < 32) \ { \ out_uint8(in_s, in_count); \ } \ else if (in_count < 256 + 32) \ { \ out_uint8(in_s, 0x0); \ temp = in_count - 32; \ out_uint8(in_s, temp); \ } \ else \ { \ out_uint8(in_s, 0xf0); \ out_uint16_le(in_s, in_count); \ } \ } \ in_count = 0; \ } while (0) /*****************************************************************************/ /* fill */ #define OUT_FILL_COUNT3(in_count, in_s) \ do { \ if (in_count > 0) \ { \ if (in_count < 32) \ { \ out_uint8(in_s, in_count); \ } \ else if (in_count < 256 + 32) \ { \ out_uint8(in_s, 0x0); \ temp = in_count - 32; \ out_uint8(in_s, temp); \ } \ else \ { \ out_uint8(in_s, 0xf0); \ out_uint16_le(in_s, in_count); \ } \ } \ in_count = 0; \ } while (0) /*****************************************************************************/ /* mix */ #define OUT_MIX_COUNT1(in_count, in_s) \ do { \ if (in_count > 0) \ { \ if (in_count < 32) \ { \ temp = (0x1 << 5) | in_count; \ out_uint8(in_s, temp); \ } \ else if (in_count < 256 + 32) \ { \ out_uint8(in_s, 0x20); \ temp = in_count - 32; \ out_uint8(in_s, temp); \ } \ else \ { \ out_uint8(in_s, 0xf1); \ out_uint16_le(in_s, in_count); \ } \ } \ in_count = 0; \ } while (0) /*****************************************************************************/ /* mix */ #define OUT_MIX_COUNT2(in_count, in_s) \ do { \ if (in_count > 0) \ { \ if (in_count < 32) \ { \ temp = (0x1 << 5) | in_count; \ out_uint8(in_s, temp); \ } \ else if (in_count < 256 + 32) \ { \ out_uint8(in_s, 0x20); \ temp = in_count - 32; \ out_uint8(in_s, temp); \ } \ else \ { \ out_uint8(in_s, 0xf1); \ out_uint16_le(in_s, in_count); \ } \ } \ in_count = 0; \ } while (0) /*****************************************************************************/ /* mix */ #define OUT_MIX_COUNT3(in_count, in_s) \ do { \ if (in_count > 0) \ { \ if (in_count < 32) \ { \ temp = (0x1 << 5) | in_count; \ out_uint8(in_s, temp); \ } \ else if (in_count < 256 + 32) \ { \ out_uint8(in_s, 0x20); \ temp = in_count - 32; \ out_uint8(in_s, temp); \ } \ else \ { \ out_uint8(in_s, 0xf1); \ out_uint16_le(in_s, in_count); \ } \ } \ in_count = 0; \ } while (0) /*****************************************************************************/ /* fom */ #define OUT_FOM_COUNT1(in_count, in_s, in_mask, in_mask_len) \ do { \ if (in_count > 0) \ { \ if ((in_count % 8) == 0 && in_count < 249) \ { \ temp = (0x2 << 5) | (in_count / 8); \ out_uint8(in_s, temp); \ out_uint8a(in_s, in_mask, in_mask_len); \ } \ else if (in_count < 256) \ { \ out_uint8(in_s, 0x40); \ temp = in_count - 1; \ out_uint8(in_s, temp); \ out_uint8a(in_s, in_mask, in_mask_len); \ } \ else \ { \ out_uint8(in_s, 0xf2); \ out_uint16_le(in_s, in_count); \ out_uint8a(in_s, in_mask, in_mask_len); \ } \ } \ in_count = 0; \ } while (0) /*****************************************************************************/ /* fom */ #define OUT_FOM_COUNT2(in_count, in_s, in_mask, in_mask_len) \ do { \ if (in_count > 0) \ { \ if ((in_count % 8) == 0 && in_count < 249) \ { \ temp = (0x2 << 5) | (in_count / 8); \ out_uint8(in_s, temp); \ out_uint8a(in_s, in_mask, in_mask_len); \ } \ else if (in_count < 256) \ { \ out_uint8(in_s, 0x40); \ temp = in_count - 1; \ out_uint8(in_s, temp); \ out_uint8a(in_s, in_mask, in_mask_len); \ } \ else \ { \ out_uint8(in_s, 0xf2); \ out_uint16_le(in_s, in_count); \ out_uint8a(in_s, in_mask, in_mask_len); \ } \ } \ in_count = 0; \ } while (0) /*****************************************************************************/ /* fill or mix (fom) */ #define OUT_FOM_COUNT3(in_count, in_s, in_mask, in_mask_len) \ do { \ if (in_count > 0) \ { \ if ((in_count % 8) == 0 && in_count < 249) \ { \ temp = (0x2 << 5) | (in_count / 8); \ out_uint8(in_s, temp); \ out_uint8a(in_s, in_mask, in_mask_len); \ } \ else if (in_count < 256) \ { \ out_uint8(in_s, 0x40); \ temp = in_count - 1; \ out_uint8(in_s, temp); \ out_uint8a(in_s, in_mask, in_mask_len); \ } \ else \ { \ out_uint8(in_s, 0xf2); \ out_uint16_le(in_s, in_count); \ out_uint8a(in_s, in_mask, in_mask_len); \ } \ } \ in_count = 0; \ } while (0) /*****************************************************************************/ #define TEST_FILL \ ((last_line == 0 && pixel == 0) || \ (last_line != 0 && pixel == ypixel)) #define TEST_MIX \ ((last_line == 0 && pixel == mix) || \ (last_line != 0 && pixel == (ypixel ^ mix))) #define TEST_FOM (TEST_FILL || TEST_MIX) #define TEST_COLOR (pixel == last_pixel) #define TEST_BICOLOR \ ( \ (pixel != last_pixel) && \ ( \ (!bicolor_spin && pixel == bicolor1 && last_pixel == bicolor2) || \ (bicolor_spin && pixel == bicolor2 && last_pixel == bicolor1) \ ) \ ) #define RESET_COUNTS \ do { \ bicolor_count = 0; \ fill_count = 0; \ color_count = 0; \ mix_count = 0; \ fom_count = 0; \ fom_mask_len = 0; \ bicolor_spin = 0; \ } while (0) /*****************************************************************************/ int xrdp_bitmap_compress(char *in_data, int width, int height, struct stream *s, int bpp, int byte_limit, int start_line, struct stream *temp_s, int e) { char *line; char *last_line; char fom_mask[8192]; /* good for up to 64K bitmap */ int lines_sent; int pixel; int count; int color_count; int last_pixel; int bicolor_count; int bicolor1; int bicolor2; int bicolor_spin; int end; int i; int out_count; int ypixel; int last_ypixel; int fill_count; int mix_count; int mix; int fom_count; int fom_mask_len; int temp; /* used in macros */ init_stream(temp_s, 0); fom_mask_len = 0; last_line = 0; lines_sent = 0; end = width + e; count = 0; color_count = 0; last_pixel = 0; last_ypixel = 0; bicolor_count = 0; bicolor1 = 0; bicolor2 = 0; bicolor_spin = 0; fill_count = 0; mix_count = 0; fom_count = 0; if (bpp == 8) { mix = 0xff; out_count = end; line = in_data + width * start_line; while (start_line >= 0 && out_count <= BC_MAX_BYTES) { i = (s->p - s->data) + count; if (i - color_count >= byte_limit && i - bicolor_count >= byte_limit && i - fill_count >= byte_limit && i - mix_count >= byte_limit && i - fom_count >= byte_limit) { break; } out_count += end; for (i = 0; i < end; i++) { /* read next pixel */ IN_PIXEL8(line, i, 0, width, last_pixel, pixel); IN_PIXEL8(last_line, i, 0, width, last_ypixel, ypixel); if (!TEST_FILL) { if (fill_count > 3 && fill_count >= color_count && fill_count >= bicolor_count && fill_count >= mix_count && fill_count >= fom_count) { count -= fill_count; OUT_COPY_COUNT1(count, s, temp_s); OUT_FILL_COUNT1(fill_count, s); RESET_COUNTS; } fill_count = 0; } if (!TEST_MIX) { if (mix_count > 3 && mix_count >= fill_count && mix_count >= bicolor_count && mix_count >= color_count && mix_count >= fom_count) { count -= mix_count; OUT_COPY_COUNT1(count, s, temp_s); OUT_MIX_COUNT1(mix_count, s); RESET_COUNTS; } mix_count = 0; } if (!TEST_COLOR) { if (color_count > 3 && color_count >= fill_count && color_count >= bicolor_count && color_count >= mix_count && color_count >= fom_count) { count -= color_count; OUT_COPY_COUNT1(count, s, temp_s); OUT_COLOR_COUNT1(color_count, s, last_pixel); RESET_COUNTS; } color_count = 0; } if (!TEST_BICOLOR) { if (bicolor_count > 3 && bicolor_count >= fill_count && bicolor_count >= color_count && bicolor_count >= mix_count && bicolor_count >= fom_count) { if ((bicolor_count % 2) == 0) { count -= bicolor_count; OUT_COPY_COUNT1(count, s, temp_s); OUT_BICOLOR_COUNT1(bicolor_count, s, bicolor1, bicolor2); } else { bicolor_count--; count -= bicolor_count; OUT_COPY_COUNT1(count, s, temp_s); OUT_BICOLOR_COUNT1(bicolor_count, s, bicolor2, bicolor1); } RESET_COUNTS; } bicolor_count = 0; bicolor1 = last_pixel; bicolor2 = pixel; bicolor_spin = 0; } if (!TEST_FOM) { if (fom_count > 3 && fom_count >= fill_count && fom_count >= color_count && fom_count >= mix_count && fom_count >= bicolor_count) { count -= fom_count; OUT_COPY_COUNT1(count, s, temp_s); OUT_FOM_COUNT1(fom_count, s, fom_mask, fom_mask_len); RESET_COUNTS; } fom_count = 0; fom_mask_len = 0; } if (TEST_FILL) { fill_count++; } if (TEST_MIX) { mix_count++; } if (TEST_COLOR) { color_count++; } if (TEST_BICOLOR) { bicolor_spin = !bicolor_spin; bicolor_count++; } if (TEST_FOM) { if ((fom_count % 8) == 0) { fom_mask[fom_mask_len] = 0; fom_mask_len++; } if (pixel == (ypixel ^ mix)) { fom_mask[fom_mask_len - 1] |= (1 << (fom_count % 8)); } fom_count++; } out_uint8(temp_s, pixel); count++; last_pixel = pixel; last_ypixel = ypixel; } /* can't take fix, mix, or fom past first line */ if (last_line == 0) { if (fill_count > 3 && fill_count >= color_count && fill_count >= bicolor_count && fill_count >= mix_count && fill_count >= fom_count) { count -= fill_count; OUT_COPY_COUNT1(count, s, temp_s); OUT_FILL_COUNT1(fill_count, s); RESET_COUNTS; } fill_count = 0; if (mix_count > 3 && mix_count >= fill_count && mix_count >= bicolor_count && mix_count >= color_count && mix_count >= fom_count) { count -= mix_count; OUT_COPY_COUNT1(count, s, temp_s); OUT_MIX_COUNT1(mix_count, s); RESET_COUNTS; } mix_count = 0; if (fom_count > 3 && fom_count >= fill_count && fom_count >= color_count && fom_count >= mix_count && fom_count >= bicolor_count) { count -= fom_count; OUT_COPY_COUNT1(count, s, temp_s); OUT_FOM_COUNT1(fom_count, s, fom_mask, fom_mask_len); RESET_COUNTS; } fom_count = 0; fom_mask_len = 0; } last_line = line; line = line - width; start_line--; lines_sent++; } if (fill_count > 3 && fill_count >= color_count && fill_count >= bicolor_count && fill_count >= mix_count && fill_count >= fom_count) { count -= fill_count; OUT_COPY_COUNT1(count, s, temp_s); OUT_FILL_COUNT1(fill_count, s); } else if (mix_count > 3 && mix_count >= color_count && mix_count >= bicolor_count && mix_count >= fill_count && mix_count >= fom_count) { count -= mix_count; OUT_COPY_COUNT1(count, s, temp_s); OUT_MIX_COUNT1(mix_count, s); } else if (color_count > 3 && color_count >= mix_count && color_count >= bicolor_count && color_count >= fill_count && color_count >= fom_count) { count -= color_count; OUT_COPY_COUNT1(count, s, temp_s); OUT_COLOR_COUNT1(color_count, s, last_pixel); } else if (bicolor_count > 3 && bicolor_count >= mix_count && bicolor_count >= color_count && bicolor_count >= fill_count && bicolor_count >= fom_count) { if ((bicolor_count % 2) == 0) { count -= bicolor_count; OUT_COPY_COUNT1(count, s, temp_s); OUT_BICOLOR_COUNT1(bicolor_count, s, bicolor1, bicolor2); } else { bicolor_count--; count -= bicolor_count; OUT_COPY_COUNT1(count, s, temp_s); OUT_BICOLOR_COUNT1(bicolor_count, s, bicolor2, bicolor1); } count -= bicolor_count; OUT_COPY_COUNT1(count, s, temp_s); OUT_BICOLOR_COUNT1(bicolor_count, s, bicolor1, bicolor2); } else if (fom_count > 3 && fom_count >= mix_count && fom_count >= color_count && fom_count >= fill_count && fom_count >= bicolor_count) { count -= fom_count; OUT_COPY_COUNT1(count, s, temp_s); OUT_FOM_COUNT1(fom_count, s, fom_mask, fom_mask_len); } else { OUT_COPY_COUNT1(count, s, temp_s); } } else if ((bpp == 15) || (bpp == 16)) { mix = (bpp == 15) ? 0xba1f : 0xffff; out_count = end * 2; line = in_data + width * start_line * 2; while (start_line >= 0 && out_count <= BC_MAX_BYTES) { i = (s->p - s->data) + count * 2; if (i - (color_count * 2) >= byte_limit && i - (bicolor_count * 2) >= byte_limit && i - (fill_count * 2) >= byte_limit && i - (mix_count * 2) >= byte_limit && i - (fom_count * 2) >= byte_limit) { break; } out_count += end * 2; for (i = 0; i < end; i++) { /* read next pixel */ IN_PIXEL16(line, i, 0, width, last_pixel, pixel); IN_PIXEL16(last_line, i, 0, width, last_ypixel, ypixel); if (!TEST_FILL) { if (fill_count > 3 && fill_count >= color_count && fill_count >= bicolor_count && fill_count >= mix_count && fill_count >= fom_count) { count -= fill_count; OUT_COPY_COUNT2(count, s, temp_s); OUT_FILL_COUNT2(fill_count, s); RESET_COUNTS; } fill_count = 0; } if (!TEST_MIX) { if (mix_count > 3 && mix_count >= fill_count && mix_count >= bicolor_count && mix_count >= color_count && mix_count >= fom_count) { count -= mix_count; OUT_COPY_COUNT2(count, s, temp_s); OUT_MIX_COUNT2(mix_count, s); RESET_COUNTS; } mix_count = 0; } if (!TEST_COLOR) { if (color_count > 3 && color_count >= fill_count && color_count >= bicolor_count && color_count >= mix_count && color_count >= fom_count) { count -= color_count; OUT_COPY_COUNT2(count, s, temp_s); OUT_COLOR_COUNT2(color_count, s, last_pixel); RESET_COUNTS; } color_count = 0; } if (!TEST_BICOLOR) { if (bicolor_count > 3 && bicolor_count >= fill_count && bicolor_count >= color_count && bicolor_count >= mix_count && bicolor_count >= fom_count) { if ((bicolor_count % 2) == 0) { count -= bicolor_count; OUT_COPY_COUNT2(count, s, temp_s); OUT_BICOLOR_COUNT2(bicolor_count, s, bicolor1, bicolor2); } else { bicolor_count--; count -= bicolor_count; OUT_COPY_COUNT2(count, s, temp_s); OUT_BICOLOR_COUNT2(bicolor_count, s, bicolor2, bicolor1); } RESET_COUNTS; } bicolor_count = 0; bicolor1 = last_pixel; bicolor2 = pixel; bicolor_spin = 0; } if (!TEST_FOM) { if (fom_count > 3 && fom_count >= fill_count && fom_count >= color_count && fom_count >= mix_count && fom_count >= bicolor_count) { count -= fom_count; OUT_COPY_COUNT2(count, s, temp_s); OUT_FOM_COUNT2(fom_count, s, fom_mask, fom_mask_len); RESET_COUNTS; } fom_count = 0; fom_mask_len = 0; } if (TEST_FILL) { fill_count++; } if (TEST_MIX) { mix_count++; } if (TEST_COLOR) { color_count++; } if (TEST_BICOLOR) { bicolor_spin = !bicolor_spin; bicolor_count++; } if (TEST_FOM) { if ((fom_count % 8) == 0) { fom_mask[fom_mask_len] = 0; fom_mask_len++; } if (pixel == (ypixel ^ mix)) { fom_mask[fom_mask_len - 1] |= (1 << (fom_count % 8)); } fom_count++; } out_uint16_le(temp_s, pixel); count++; last_pixel = pixel; last_ypixel = ypixel; } /* can't take fix, mix, or fom past first line */ if (last_line == 0) { if (fill_count > 3 && fill_count >= color_count && fill_count >= bicolor_count && fill_count >= mix_count && fill_count >= fom_count) { count -= fill_count; OUT_COPY_COUNT2(count, s, temp_s); OUT_FILL_COUNT2(fill_count, s); RESET_COUNTS; } fill_count = 0; if (mix_count > 3 && mix_count >= fill_count && mix_count >= bicolor_count && mix_count >= color_count && mix_count >= fom_count) { count -= mix_count; OUT_COPY_COUNT2(count, s, temp_s); OUT_MIX_COUNT2(mix_count, s); RESET_COUNTS; } mix_count = 0; if (fom_count > 3 && fom_count >= fill_count && fom_count >= color_count && fom_count >= mix_count && fom_count >= bicolor_count) { count -= fom_count; OUT_COPY_COUNT2(count, s, temp_s); OUT_FOM_COUNT2(fom_count, s, fom_mask, fom_mask_len); RESET_COUNTS; } fom_count = 0; fom_mask_len = 0; } last_line = line; line = line - width * 2; start_line--; lines_sent++; } if (fill_count > 3 && fill_count >= color_count && fill_count >= bicolor_count && fill_count >= mix_count && fill_count >= fom_count) { count -= fill_count; OUT_COPY_COUNT2(count, s, temp_s); OUT_FILL_COUNT2(fill_count, s); } else if (mix_count > 3 && mix_count >= color_count && mix_count >= bicolor_count && mix_count >= fill_count && mix_count >= fom_count) { count -= mix_count; OUT_COPY_COUNT2(count, s, temp_s); OUT_MIX_COUNT2(mix_count, s); } else if (color_count > 3 && color_count >= mix_count && color_count >= bicolor_count && color_count >= fill_count && color_count >= fom_count) { count -= color_count; OUT_COPY_COUNT2(count, s, temp_s); OUT_COLOR_COUNT2(color_count, s, last_pixel); } else if (bicolor_count > 3 && bicolor_count >= mix_count && bicolor_count >= color_count && bicolor_count >= fill_count && bicolor_count >= fom_count) { if ((bicolor_count % 2) == 0) { count -= bicolor_count; OUT_COPY_COUNT2(count, s, temp_s); OUT_BICOLOR_COUNT2(bicolor_count, s, bicolor1, bicolor2); } else { bicolor_count--; count -= bicolor_count; OUT_COPY_COUNT2(count, s, temp_s); OUT_BICOLOR_COUNT2(bicolor_count, s, bicolor2, bicolor1); } count -= bicolor_count; OUT_COPY_COUNT2(count, s, temp_s); OUT_BICOLOR_COUNT2(bicolor_count, s, bicolor1, bicolor2); } else if (fom_count > 3 && fom_count >= mix_count && fom_count >= color_count && fom_count >= fill_count && fom_count >= bicolor_count) { count -= fom_count; OUT_COPY_COUNT2(count, s, temp_s); OUT_FOM_COUNT2(fom_count, s, fom_mask, fom_mask_len); } else { OUT_COPY_COUNT2(count, s, temp_s); } } else if (bpp == 24) { mix = 0xffffff; out_count = end * 3; line = in_data + width * start_line * 4; while (start_line >= 0 && out_count <= BC_MAX_BYTES) { i = (s->p - s->data) + count * 3; if (i - (color_count * 3) >= byte_limit && i - (bicolor_count * 3) >= byte_limit && i - (fill_count * 3) >= byte_limit && i - (mix_count * 3) >= byte_limit && i - (fom_count * 3) >= byte_limit) { break; } out_count += end * 3; for (i = 0; i < end; i++) { /* read next pixel */ IN_PIXEL32(line, i, 0, width, last_pixel, pixel); IN_PIXEL32(last_line, i, 0, width, last_ypixel, ypixel); if (!TEST_FILL) { if (fill_count > 3 && fill_count >= color_count && fill_count >= bicolor_count && fill_count >= mix_count && fill_count >= fom_count) { count -= fill_count; OUT_COPY_COUNT3(count, s, temp_s); OUT_FILL_COUNT3(fill_count, s); RESET_COUNTS; } fill_count = 0; } if (!TEST_MIX) { if (mix_count > 3 && mix_count >= fill_count && mix_count >= bicolor_count && mix_count >= color_count && mix_count >= fom_count) { count -= mix_count; OUT_COPY_COUNT3(count, s, temp_s); OUT_MIX_COUNT3(mix_count, s); RESET_COUNTS; } mix_count = 0; } if (!TEST_COLOR) { if (color_count > 3 && color_count >= fill_count && color_count >= bicolor_count && color_count >= mix_count && color_count >= fom_count) { count -= color_count; OUT_COPY_COUNT3(count, s, temp_s); OUT_COLOR_COUNT3(color_count, s, last_pixel); RESET_COUNTS; } color_count = 0; } if (!TEST_BICOLOR) { if (bicolor_count > 3 && bicolor_count >= fill_count && bicolor_count >= color_count && bicolor_count >= mix_count && bicolor_count >= fom_count) { if ((bicolor_count % 2) == 0) { count -= bicolor_count; OUT_COPY_COUNT3(count, s, temp_s); OUT_BICOLOR_COUNT3(bicolor_count, s, bicolor1, bicolor2); } else { bicolor_count--; count -= bicolor_count; OUT_COPY_COUNT3(count, s, temp_s); OUT_BICOLOR_COUNT3(bicolor_count, s, bicolor2, bicolor1); } RESET_COUNTS; } bicolor_count = 0; bicolor1 = last_pixel; bicolor2 = pixel; bicolor_spin = 0; } if (!TEST_FOM) { if (fom_count > 3 && fom_count >= fill_count && fom_count >= color_count && fom_count >= mix_count && fom_count >= bicolor_count) { count -= fom_count; OUT_COPY_COUNT3(count, s, temp_s); OUT_FOM_COUNT3(fom_count, s, fom_mask, fom_mask_len); RESET_COUNTS; } fom_count = 0; fom_mask_len = 0; } if (TEST_FILL) { fill_count++; } if (TEST_MIX) { mix_count++; } if (TEST_COLOR) { color_count++; } if (TEST_BICOLOR) { bicolor_spin = !bicolor_spin; bicolor_count++; } if (TEST_FOM) { if ((fom_count % 8) == 0) { fom_mask[fom_mask_len] = 0; fom_mask_len++; } if (pixel == (ypixel ^ mix)) { fom_mask[fom_mask_len - 1] |= (1 << (fom_count % 8)); } fom_count++; } out_uint8(temp_s, pixel & 0xff); out_uint8(temp_s, (pixel >> 8) & 0xff); out_uint8(temp_s, (pixel >> 16) & 0xff); count++; last_pixel = pixel; last_ypixel = ypixel; } /* can't take fix, mix, or fom past first line */ if (last_line == 0) { if (fill_count > 3 && fill_count >= color_count && fill_count >= bicolor_count && fill_count >= mix_count && fill_count >= fom_count) { count -= fill_count; OUT_COPY_COUNT3(count, s, temp_s); OUT_FILL_COUNT3(fill_count, s); RESET_COUNTS; } fill_count = 0; if (mix_count > 3 && mix_count >= fill_count && mix_count >= bicolor_count && mix_count >= color_count && mix_count >= fom_count) { count -= mix_count; OUT_COPY_COUNT3(count, s, temp_s); OUT_MIX_COUNT3(mix_count, s); RESET_COUNTS; } mix_count = 0; if (fom_count > 3 && fom_count >= fill_count && fom_count >= color_count && fom_count >= mix_count && fom_count >= bicolor_count) { count -= fom_count; OUT_COPY_COUNT3(count, s, temp_s); OUT_FOM_COUNT3(fom_count, s, fom_mask, fom_mask_len); RESET_COUNTS; } fom_count = 0; fom_mask_len = 0; } last_line = line; line = line - width * 4; start_line--; lines_sent++; } if (fill_count > 3 && fill_count >= color_count && fill_count >= bicolor_count && fill_count >= mix_count && fill_count >= fom_count) { count -= fill_count; OUT_COPY_COUNT3(count, s, temp_s); OUT_FILL_COUNT3(fill_count, s); } else if (mix_count > 3 && mix_count >= color_count && mix_count >= bicolor_count && mix_count >= fill_count && mix_count >= fom_count) { count -= mix_count; OUT_COPY_COUNT3(count, s, temp_s); OUT_MIX_COUNT3(mix_count, s); } else if (color_count > 3 && color_count >= mix_count && color_count >= bicolor_count && color_count >= fill_count && color_count >= fom_count) { count -= color_count; OUT_COPY_COUNT3(count, s, temp_s); OUT_COLOR_COUNT3(color_count, s, last_pixel); } else if (bicolor_count > 3 && bicolor_count >= mix_count && bicolor_count >= color_count && bicolor_count >= fill_count && bicolor_count >= fom_count) { if ((bicolor_count % 2) == 0) { count -= bicolor_count; OUT_COPY_COUNT3(count, s, temp_s); OUT_BICOLOR_COUNT3(bicolor_count, s, bicolor1, bicolor2); } else { bicolor_count--; count -= bicolor_count; OUT_COPY_COUNT3(count, s, temp_s); OUT_BICOLOR_COUNT3(bicolor_count, s, bicolor2, bicolor1); } count -= bicolor_count; OUT_COPY_COUNT3(count, s, temp_s); OUT_BICOLOR_COUNT3(bicolor_count, s, bicolor1, bicolor2); } else if (fom_count > 3 && fom_count >= mix_count && fom_count >= color_count && fom_count >= fill_count && fom_count >= bicolor_count) { count -= fom_count; OUT_COPY_COUNT3(count, s, temp_s); OUT_FOM_COUNT3(fom_count, s, fom_mask, fom_mask_len); } else { OUT_COPY_COUNT3(count, s, temp_s); } } return lines_sent; } xrdp-0.9.5/libxrdp/libxrdp.c000644 001751 001751 00000135114 13201006747 015703 0ustar00metameta000000 000000 /** * xrdp: A Remote Desktop Protocol server. * * Copyright (C) Jay Sorg 2004-2013 * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. * * this is the interface to libxrdp */ #if defined(HAVE_CONFIG_H) #include #endif #include "libxrdp.h" #include "xrdp_orders_rail.h" #define LOG_LEVEL 1 #define LLOG(_level, _args) \ do { if (_level < LOG_LEVEL) { g_write _args ; } } while (0) #define LLOGLN(_level, _args) \ do { if (_level < LOG_LEVEL) { g_writeln _args ; } } while (0) #define MAX_BITMAP_BUF_SIZE (16 * 1024) /* 16K */ /******************************************************************************/ struct xrdp_session *EXPORT_CC libxrdp_init(tbus id, struct trans *trans) { struct xrdp_session *session; session = (struct xrdp_session *)g_malloc(sizeof(struct xrdp_session), 1); session->id = id; session->trans = trans; session->rdp = xrdp_rdp_create(session, trans); session->orders = xrdp_orders_create(session, (struct xrdp_rdp *)session->rdp); session->client_info = &(((struct xrdp_rdp *)session->rdp)->client_info); return session; } /******************************************************************************/ int EXPORT_CC libxrdp_exit(struct xrdp_session *session) { if (session == 0) { return 0; } xrdp_orders_delete((struct xrdp_orders *)session->orders); xrdp_rdp_delete((struct xrdp_rdp *)session->rdp); g_free(session); return 0; } /******************************************************************************/ int EXPORT_CC libxrdp_disconnect(struct xrdp_session *session) { return xrdp_rdp_disconnect((struct xrdp_rdp *)session->rdp); } /******************************************************************************/ int EXPORT_CC libxrdp_process_incoming(struct xrdp_session *session) { int rv; rv = xrdp_rdp_incoming((struct xrdp_rdp *)(session->rdp)); return rv; } /*****************************************************************************/ int EXPORT_CC libxrdp_get_pdu_bytes(const char *aheader) { int rv; const tui8 *header; rv = -1; header = (const tui8 *) aheader; if (header[0] == 0x03) { /* TPKT */ rv = (header[2] << 8) | header[3]; } else { /* Fast-Path */ if (header[1] & 0x80) { rv = ((header[1] & 0x7F) << 8) | header[2]; } else { rv = header[1]; } } return rv; } /******************************************************************************/ /* only used during connection */ struct stream * libxrdp_force_read(struct trans* trans) { int bytes; struct stream *s; s = trans->in_s; init_stream(s, 32 * 1024); if (trans_force_read(trans, 4) != 0) { g_writeln("libxrdp_force_read: error"); return 0; } bytes = libxrdp_get_pdu_bytes(s->data); if (bytes < 1) { g_writeln("libxrdp_force_read: error"); return 0; } if (bytes > 32 * 1024) { g_writeln("libxrdp_force_read: error"); return 0; } if (trans_force_read(trans, bytes - 4) != 0) { g_writeln("libxrdp_force_read: error"); return 0; } return s; } /******************************************************************************/ int EXPORT_CC libxrdp_process_data(struct xrdp_session *session, struct stream *s) { int cont; int rv; int code; int term; int dead_lock_counter; int do_read; struct xrdp_rdp *rdp; do_read = s == 0; if (do_read && session->up_and_running) { g_writeln("libxrdp_process_data: error logic"); return 1; } if (session->in_process_data != 0) { g_writeln("libxrdp_process_data: error reentry"); return 1; } session->in_process_data++; term = 0; cont = 1; rv = 0; dead_lock_counter = 0; rdp = (struct xrdp_rdp *) (session->rdp); while ((cont || !session->up_and_running) && !term) { if (session->is_term != 0) { if (session->is_term()) { term = 1; break; } } code = 0; if (do_read) { if (s == 0) { s = libxrdp_force_read(session->trans); } else { if ((s->next_packet == 0) || (s->next_packet >= s->end)) { s = libxrdp_force_read(session->trans); } } if (s == 0) { g_writeln("libxrdp_process_data: libxrdp_force_read failed"); rv = 1; break; } } if (xrdp_rdp_recv(rdp, s, &code) != 0) { g_writeln("libxrdp_process_data: xrdp_rdp_recv failed"); rv = 1; break; } DEBUG(("libxrdp_process_data code %d", code)); switch (code) { case -1: xrdp_caps_send_demand_active(rdp); session->up_and_running = 0; break; case 0: dead_lock_counter++; break; case RDP_PDU_CONFIRM_ACTIVE: /* 3 */ xrdp_caps_process_confirm_active(rdp, s); break; case RDP_PDU_DATA: /* 7 */ if (xrdp_rdp_process_data(rdp, s) != 0) { DEBUG(("libxrdp_process_data returned non zero")); cont = 0; term = 1; } break; case 2: /* FASTPATH_INPUT_EVENT */ if (xrdp_fastpath_process_input_event(rdp->sec_layer->fastpath_layer, s) != 0) { DEBUG(("libxrdp_process_data returned non zero")); cont = 0; term = 1; } break; default: g_writeln("unknown in libxrdp_process_data: code= %d", code); dead_lock_counter++; break; } if (dead_lock_counter > 100000) { /*This situation can happen and this is a workaround*/ cont = 0; g_writeln("Serious programming error: we were locked in a deadly loop"); g_writeln("Remaining: %d", (int) (s->end - s->next_packet)); s->next_packet = 0; } if (cont) { cont = (s->next_packet != 0) && (s->next_packet < s->end); } } session->in_process_data--; return rv; } /******************************************************************************/ int EXPORT_CC libxrdp_send_palette(struct xrdp_session *session, int *palette) { int rv; int i = 0; int color = 0; struct stream *s = (struct stream *)NULL; if (session->client_info->bpp > 8) { return 0; } DEBUG(("libxrdp_send_palette sending palette")); /* clear orders */ libxrdp_orders_force_send(session); make_stream(s); init_stream(s, 8192); if (session->client_info->use_fast_path & 1) /* fastpath output supported */ { LLOGLN(10, ("libxrdp_send_palette: fastpath")); if (xrdp_rdp_init_fastpath((struct xrdp_rdp *)session->rdp, s) != 0) { free_stream(s); return 1; } } else { LLOGLN(10, ("libxrdp_send_palette: slowpath")); xrdp_rdp_init_data((struct xrdp_rdp *)session->rdp, s); } /* TS_UPDATE_PALETTE_DATA */ out_uint16_le(s, RDP_UPDATE_PALETTE); out_uint16_le(s, 0); out_uint16_le(s, 256); /* # of colors */ out_uint16_le(s, 0); for (i = 0; i < 256; i++) { color = palette[i]; out_uint8(s, color >> 16); out_uint8(s, color >> 8); out_uint8(s, color); } s_mark_end(s); if (session->client_info->use_fast_path & 1) /* fastpath output supported */ { if (xrdp_rdp_send_fastpath((struct xrdp_rdp *)session->rdp, s, FASTPATH_UPDATETYPE_PALETTE) != 0) { free_stream(s); return 1; } } else { xrdp_rdp_send_data((struct xrdp_rdp *)session->rdp, s, RDP_DATA_PDU_UPDATE); } free_stream(s); /* send the orders palette too */ rv = libxrdp_orders_init(session); if (rv == 0) { rv = libxrdp_orders_send_palette(session, palette, 0); } if (rv == 0) { rv = libxrdp_orders_send(session); } return rv; } /******************************************************************************/ int EXPORT_CC libxrdp_send_bell(struct xrdp_session *session) { struct stream *s = (struct stream *)NULL; DEBUG(("libxrdp_send_bell sending bell signal")); /* see MS documentation: Server play sound PDU, TS_PLAY_SOUND_PDU_DATA */ make_stream(s); init_stream(s, 8192); if (xrdp_rdp_init_data((struct xrdp_rdp *)session->rdp, s) != 0) { free_stream(s); return 1; } out_uint32_le(s, 440); /* frequency */ out_uint32_le(s, 100); /* duration (ms) */ s_mark_end(s); if (xrdp_rdp_send_data((struct xrdp_rdp *)session->rdp, s, RDP_DATA_PDU_PLAY_SOUND) != 0) { free_stream(s); return 1; } free_stream(s); return 0; } /*****************************************************************************/ int EXPORT_CC libxrdp_send_bitmap(struct xrdp_session *session, int width, int height, int bpp, char *data, int x, int y, int cx, int cy) { int line_bytes = 0; int i = 0; int j = 0; int k; int total_lines = 0; int lines_sending = 0; int Bpp = 0; int e = 0; int bufsize = 0; int total_bufsize = 0; int num_updates = 0; int line_pad_bytes; int server_line_bytes; char *p_num_updates = (char *)NULL; char *p = (char *)NULL; char *q = (char *)NULL; struct stream *s = (struct stream *)NULL; struct stream *temp_s = (struct stream *)NULL; tui32 pixel; LLOGLN(10, ("libxrdp_send_bitmap: sending bitmap")); Bpp = (bpp + 7) / 8; e = (4 - width) & 3; switch (bpp) { case 15: case 16: server_line_bytes = width * 2; break; case 24: case 32: server_line_bytes = width * 4; break; default: /* 8 bpp */ server_line_bytes = width; break; } line_bytes = width * Bpp; line_pad_bytes = line_bytes + e * Bpp; LLOGLN(10, ("libxrdp_send_bitmap: bpp %d Bpp %d line_bytes %d " "server_line_bytes %d", bpp, Bpp, line_bytes, server_line_bytes)); make_stream(s); init_stream(s, MAX_BITMAP_BUF_SIZE); if (session->client_info->use_bitmap_comp) { LLOGLN(10, ("libxrdp_send_bitmap: compression")); make_stream(temp_s); init_stream(temp_s, 65536); i = 0; if (cy <= height) { i = cy; } while (i > 0) { LLOGLN(10, ("libxrdp_send_bitmap: i %d", i)); total_bufsize = 0; num_updates = 0; xrdp_rdp_init_data((struct xrdp_rdp *)session->rdp, s); out_uint16_le(s, RDP_UPDATE_BITMAP); p_num_updates = s->p; out_uint8s(s, 2); /* num_updates set later */ do { if (session->client_info->op1) { s_push_layer(s, channel_hdr, 18); } else { s_push_layer(s, channel_hdr, 26); } p = s->p; if (bpp > 24) { LLOGLN(10, ("libxrdp_send_bitmap: 32 bpp")); lines_sending = xrdp_bitmap32_compress(data, width, height, s, 32, (MAX_BITMAP_BUF_SIZE - 100) - total_bufsize, i - 1, temp_s, e, 0x10); LLOGLN(10, ("libxrdp_send_bitmap: i %d lines_sending %d", i, lines_sending)); } else { lines_sending = xrdp_bitmap_compress(data, width, height, s, bpp, (MAX_BITMAP_BUF_SIZE - 100) - total_bufsize, i - 1, temp_s, e); LLOGLN(10, ("libxrdp_send_bitmap: i %d lines_sending %d", i, lines_sending)); } if (lines_sending == 0) { break; } num_updates++; bufsize = s->p - p; total_bufsize += bufsize; i = i - lines_sending; s_mark_end(s); s_pop_layer(s, channel_hdr); out_uint16_le(s, x); /* left */ out_uint16_le(s, y + i); /* top */ out_uint16_le(s, (x + cx) - 1); /* right */ out_uint16_le(s, (y + i + lines_sending) - 1); /* bottom */ out_uint16_le(s, width + e); /* width */ out_uint16_le(s, lines_sending); /* height */ out_uint16_le(s, bpp); /* bpp */ if (session->client_info->op1) { out_uint16_le(s, 0x401); /* compress */ out_uint16_le(s, bufsize); /* compressed size */ j = (width + e) * Bpp; j = j * lines_sending; total_bufsize += 18; /* bytes since pop layer */ } else { out_uint16_le(s, 0x1); /* compress */ out_uint16_le(s, bufsize + 8); out_uint8s(s, 2); /* pad */ out_uint16_le(s, bufsize); /* compressed size */ j = (width + e) * Bpp; out_uint16_le(s, j); /* line size */ j = j * lines_sending; out_uint16_le(s, j); /* final size */ total_bufsize += 26; /* bytes since pop layer */ } LLOGLN(10, ("libxrdp_send_bitmap: decompressed pixels %d " "decompressed bytes %d compressed bytes %d", lines_sending * (width + e), line_pad_bytes * lines_sending, bufsize)); if (j > MAX_BITMAP_BUF_SIZE) { LLOGLN(0, ("libxrdp_send_bitmap: error, decompressed " "size too big: %d bytes", j)); } if (bufsize > MAX_BITMAP_BUF_SIZE) { LLOGLN(0, ("libxrdp_send_bitmap: error, compressed size " "too big: %d bytes", bufsize)); } s->p = s->end; } while (total_bufsize < MAX_BITMAP_BUF_SIZE && i > 0); LLOGLN(10, ("libxrdp_send_bitmap: num_updates %d total_bufsize %d", num_updates, total_bufsize)); p_num_updates[0] = num_updates; p_num_updates[1] = num_updates >> 8; xrdp_rdp_send_data((struct xrdp_rdp *)session->rdp, s, RDP_DATA_PDU_UPDATE); if (total_bufsize > MAX_BITMAP_BUF_SIZE) { LLOGLN(0, ("libxrdp_send_bitmap: error, total compressed " "size too big: %d bytes", total_bufsize)); } } free_stream(temp_s); } else { LLOGLN(10, ("libxrdp_send_bitmap: no compression")); total_lines = height; i = 0; p = data; if (line_bytes > 0 && total_lines > 0) { while (i < total_lines) { lines_sending = (MAX_BITMAP_BUF_SIZE - 100) / line_pad_bytes; if (i + lines_sending > total_lines) { lines_sending = total_lines - i; } if (lines_sending == 0) { LLOGLN(0, ("libxrdp_send_bitmap: error, lines_sending == zero")); break; } p += server_line_bytes * lines_sending; xrdp_rdp_init_data((struct xrdp_rdp *)session->rdp, s); out_uint16_le(s, RDP_UPDATE_BITMAP); out_uint16_le(s, 1); /* num updates */ out_uint16_le(s, x); out_uint16_le(s, y + i); out_uint16_le(s, (x + cx) - 1); out_uint16_le(s, (y + i + lines_sending) - 1); out_uint16_le(s, width + e); out_uint16_le(s, lines_sending); out_uint16_le(s, bpp); /* bpp */ out_uint16_le(s, 0); /* compress */ out_uint16_le(s, line_pad_bytes * lines_sending); /* bufsize */ q = p; switch (bpp) { case 8: for (j = 0; j < lines_sending; j++) { q = q - line_bytes; out_uint8a(s, q, line_bytes); out_uint8s(s, e); } break; case 15: case 16: for (j = 0; j < lines_sending; j++) { q = q - server_line_bytes; for (k = 0; k < width; k++) { pixel = *((tui16*)(q + k * 2)); out_uint16_le(s, pixel); } out_uint8s(s, e * 2); } break; case 24: for (j = 0; j < lines_sending; j++) { q = q - server_line_bytes; for (k = 0; k < width; k++) { pixel = *((tui32*)(q + k * 4)); out_uint8(s, pixel); out_uint8(s, pixel >> 8); out_uint8(s, pixel >> 16); } out_uint8s(s, e * 3); } break; case 32: for (j = 0; j < lines_sending; j++) { q = q - server_line_bytes; for (k = 0; k < width; k++) { pixel = *((int*)(q + k * 4)); out_uint32_le(s, pixel); } out_uint8s(s, e * 4); } break; } s_mark_end(s); xrdp_rdp_send_data((struct xrdp_rdp *)session->rdp, s, RDP_DATA_PDU_UPDATE); i = i + lines_sending; } } } free_stream(s); return 0; } /*****************************************************************************/ int EXPORT_CC libxrdp_send_pointer(struct xrdp_session *session, int cache_idx, char *data, char *mask, int x, int y, int bpp) { struct stream *s; char *p; tui16 *p16; tui32 *p32; int i; int j; int data_bytes; DEBUG(("libxrdp_send_pointer sending cursor")); if (bpp == 0) { bpp = 24; } /* error check */ if ((session->client_info->pointer_flags & 1) == 0) { if (bpp != 24) { g_writeln("libxrdp_send_pointer: error client does not support " "new cursors and bpp is %d", bpp); return 1; } } if ((bpp == 15) && (bpp != 16) && (bpp != 24) && (bpp != 32)) { g_writeln("libxrdp_send_pointer: error"); return 1; } make_stream(s); init_stream(s, 8192); if (session->client_info->use_fast_path & 1) /* fastpath output supported */ { LLOGLN(10, ("libxrdp_send_pointer: fastpath")); if (xrdp_rdp_init_fastpath((struct xrdp_rdp *)session->rdp, s) != 0) { free_stream(s); return 1; } if ((session->client_info->pointer_flags & 1) == 0) { data_bytes = 3072; } else { data_bytes = ((bpp + 7) / 8) * 32 * 32; out_uint16_le(s, bpp); } } else /* slowpath */ { LLOGLN(10, ("libxrdp_send_pointer: slowpath")); xrdp_rdp_init_data((struct xrdp_rdp *)session->rdp, s); if ((session->client_info->pointer_flags & 1) == 0) { out_uint16_le(s, RDP_POINTER_COLOR); out_uint16_le(s, 0); /* pad */ data_bytes = 3072; } else { out_uint16_le(s, RDP_POINTER_POINTER); out_uint16_le(s, 0); /* pad */ out_uint16_le(s, bpp); data_bytes = ((bpp + 7) / 8) * 32 * 32; } } out_uint16_le(s, cache_idx); /* cache_idx */ out_uint16_le(s, x); out_uint16_le(s, y); out_uint16_le(s, 32); out_uint16_le(s, 32); out_uint16_le(s, 128); out_uint16_le(s, data_bytes); switch (bpp) { //case 15: /* coverity: this is logically dead code */ case 16: p16 = (tui16 *) data; for (i = 0; i < 32; i++) { for (j = 0; j < 32; j++) { out_uint16_le(s, *p16); p16++; } } break; case 24: p = data; for (i = 0; i < 32; i++) { for (j = 0; j < 32; j++) { out_uint8(s, *p); p++; out_uint8(s, *p); p++; out_uint8(s, *p); p++; } } break; case 32: p32 = (tui32 *) data; for (i = 0; i < 32; i++) { for (j = 0; j < 32; j++) { out_uint32_le(s, *p32); p32++; } } break; } out_uint8a(s, mask, 128); /* mask */ out_uint8(s, 0); /* pad */ s_mark_end(s); if (session->client_info->use_fast_path & 1) /* fastpath output supported */ { if ((session->client_info->pointer_flags & 1) == 0) { if (xrdp_rdp_send_fastpath((struct xrdp_rdp *)session->rdp, s, FASTPATH_UPDATETYPE_COLOR) != 0) { free_stream(s); return 1; } } else { if (xrdp_rdp_send_fastpath((struct xrdp_rdp *)session->rdp, s, FASTPATH_UPDATETYPE_POINTER) != 0) { free_stream(s); return 1; } } } else { xrdp_rdp_send_data((struct xrdp_rdp *)session->rdp, s, RDP_DATA_PDU_POINTER); } free_stream(s); return 0; } /*****************************************************************************/ int EXPORT_CC libxrdp_set_pointer(struct xrdp_session *session, int cache_idx) { struct stream *s; DEBUG(("libxrdp_set_pointer sending cursor index")); make_stream(s); init_stream(s, 8192); if (session->client_info->use_fast_path & 1) /* fastpath output supported */ { LLOGLN(10, ("libxrdp_send_pointer: fastpath")); if (xrdp_rdp_init_fastpath((struct xrdp_rdp *)session->rdp, s) != 0) { return 1; } } else { LLOGLN(10, ("libxrdp_send_pointer: slowpath")); xrdp_rdp_init_data((struct xrdp_rdp *)session->rdp, s); out_uint16_le(s, RDP_POINTER_CACHED); out_uint16_le(s, 0); /* pad */ } out_uint16_le(s, cache_idx); /* cache_idx */ s_mark_end(s); if (session->client_info->use_fast_path & 1) /* fastpath output supported */ { if (xrdp_rdp_send_fastpath((struct xrdp_rdp *)session->rdp, s, FASTPATH_UPDATETYPE_CACHED) != 0) { free_stream(s); return 1; } } else { xrdp_rdp_send_data((struct xrdp_rdp *)session->rdp, s, RDP_DATA_PDU_POINTER); } free_stream(s); return 0; } /******************************************************************************/ int EXPORT_CC libxrdp_orders_init(struct xrdp_session *session) { return xrdp_orders_init((struct xrdp_orders *)session->orders); } /******************************************************************************/ int EXPORT_CC libxrdp_orders_send(struct xrdp_session *session) { return xrdp_orders_send((struct xrdp_orders *)session->orders); } /******************************************************************************/ int EXPORT_CC libxrdp_orders_force_send(struct xrdp_session *session) { return xrdp_orders_force_send((struct xrdp_orders *)session->orders); } /******************************************************************************/ int EXPORT_CC libxrdp_orders_rect(struct xrdp_session *session, int x, int y, int cx, int cy, int color, struct xrdp_rect *rect) { return xrdp_orders_rect((struct xrdp_orders *)session->orders, x, y, cx, cy, color, rect); } /******************************************************************************/ int EXPORT_CC libxrdp_orders_screen_blt(struct xrdp_session *session, int x, int y, int cx, int cy, int srcx, int srcy, int rop, struct xrdp_rect *rect) { return xrdp_orders_screen_blt((struct xrdp_orders *)session->orders, x, y, cx, cy, srcx, srcy, rop, rect); } /******************************************************************************/ int EXPORT_CC libxrdp_orders_pat_blt(struct xrdp_session *session, int x, int y, int cx, int cy, int rop, int bg_color, int fg_color, struct xrdp_brush *brush, struct xrdp_rect *rect) { return xrdp_orders_pat_blt((struct xrdp_orders *)session->orders, x, y, cx, cy, rop, bg_color, fg_color, brush, rect); } /******************************************************************************/ int EXPORT_CC libxrdp_orders_dest_blt(struct xrdp_session *session, int x, int y, int cx, int cy, int rop, struct xrdp_rect *rect) { return xrdp_orders_dest_blt((struct xrdp_orders *)session->orders, x, y, cx, cy, rop, rect); } /******************************************************************************/ int EXPORT_CC libxrdp_orders_line(struct xrdp_session *session, int mix_mode, int startx, int starty, int endx, int endy, int rop, int bg_color, struct xrdp_pen *pen, struct xrdp_rect *rect) { return xrdp_orders_line((struct xrdp_orders *)session->orders, mix_mode, startx, starty, endx, endy, rop, bg_color, pen, rect); } /******************************************************************************/ int EXPORT_CC libxrdp_orders_mem_blt(struct xrdp_session *session, int cache_id, int color_table, int x, int y, int cx, int cy, int rop, int srcx, int srcy, int cache_idx, struct xrdp_rect *rect) { return xrdp_orders_mem_blt((struct xrdp_orders *)session->orders, cache_id, color_table, x, y, cx, cy, rop, srcx, srcy, cache_idx, rect); } /******************************************************************************/ int libxrdp_orders_composite_blt(struct xrdp_session* session, int srcidx, int srcformat, int srcwidth, int srcrepeat, int* srctransform, int mskflags, int mskidx, int mskformat, int mskwidth, int mskrepeat, int op, int srcx, int srcy, int mskx, int msky, int dstx, int dsty, int width, int height, int dstformat, struct xrdp_rect* rect) { return xrdp_orders_composite_blt((struct xrdp_orders*)session->orders, srcidx, srcformat, srcwidth, srcrepeat, srctransform, mskflags, mskidx, mskformat, mskwidth, mskrepeat, op, srcx, srcy, mskx, msky, dstx, dsty, width, height, dstformat, rect); } /******************************************************************************/ int EXPORT_CC libxrdp_orders_text(struct xrdp_session *session, int font, int flags, int mixmode, int fg_color, int bg_color, int clip_left, int clip_top, int clip_right, int clip_bottom, int box_left, int box_top, int box_right, int box_bottom, int x, int y, char *data, int data_len, struct xrdp_rect *rect) { return xrdp_orders_text((struct xrdp_orders *)session->orders, font, flags, mixmode, fg_color, bg_color, clip_left, clip_top, clip_right, clip_bottom, box_left, box_top, box_right, box_bottom, x, y, data, data_len, rect); } /******************************************************************************/ int EXPORT_CC libxrdp_orders_send_palette(struct xrdp_session *session, int *palette, int cache_id) { return xrdp_orders_send_palette((struct xrdp_orders *)session->orders, palette, cache_id); } /*****************************************************************************/ int EXPORT_CC libxrdp_orders_send_raw_bitmap(struct xrdp_session *session, int width, int height, int bpp, char *data, int cache_id, int cache_idx) { return xrdp_orders_send_raw_bitmap((struct xrdp_orders *)session->orders, width, height, bpp, data, cache_id, cache_idx); } /*****************************************************************************/ int EXPORT_CC libxrdp_orders_send_bitmap(struct xrdp_session *session, int width, int height, int bpp, char *data, int cache_id, int cache_idx) { return xrdp_orders_send_bitmap((struct xrdp_orders *)session->orders, width, height, bpp, data, cache_id, cache_idx); } /*****************************************************************************/ int EXPORT_CC libxrdp_orders_send_font(struct xrdp_session *session, struct xrdp_font_char *font_char, int font_index, int char_index) { return xrdp_orders_send_font((struct xrdp_orders *)session->orders, font_char, font_index, char_index); } /*****************************************************************************/ int EXPORT_CC libxrdp_reset(struct xrdp_session *session, int width, int height, int bpp) { if (session->client_info != 0) { /* older client can't resize */ if (session->client_info->build <= 419) { return 0; } /* if same, don't need to do anything */ if (session->client_info->width == width && session->client_info->height == height && session->client_info->bpp == bpp) { return 0; } session->client_info->width = width; session->client_info->height = height; session->client_info->bpp = bpp; } else { return 1; } /* this will send any lingering orders */ if (xrdp_orders_reset((struct xrdp_orders *)session->orders) != 0) { return 1; } /* shut down the rdp client */ if (xrdp_rdp_send_deactivate((struct xrdp_rdp *)session->rdp) != 0) { return 1; } /* this should do the resizing */ if (xrdp_caps_send_demand_active((struct xrdp_rdp *)session->rdp) != 0) { return 1; } return 0; } /*****************************************************************************/ int EXPORT_CC libxrdp_orders_send_raw_bitmap2(struct xrdp_session *session, int width, int height, int bpp, char *data, int cache_id, int cache_idx) { return xrdp_orders_send_raw_bitmap2((struct xrdp_orders *)session->orders, width, height, bpp, data, cache_id, cache_idx); } /*****************************************************************************/ int EXPORT_CC libxrdp_orders_send_bitmap2(struct xrdp_session *session, int width, int height, int bpp, char *data, int cache_id, int cache_idx, int hints) { return xrdp_orders_send_bitmap2((struct xrdp_orders *)session->orders, width, height, bpp, data, cache_id, cache_idx, hints); } /*****************************************************************************/ int EXPORT_CC libxrdp_orders_send_bitmap3(struct xrdp_session *session, int width, int height, int bpp, char *data, int cache_id, int cache_idx, int hints) { return xrdp_orders_send_bitmap3((struct xrdp_orders *)session->orders, width, height, bpp, data, cache_id, cache_idx, hints); } /*****************************************************************************/ /* returns error */ /* this function gets the channel name and its flags, index is zero based. either channel_name or channel_flags can be passed in nil if they are not needed */ int EXPORT_CC libxrdp_query_channel(struct xrdp_session *session, int index, char *channel_name, int *channel_flags) { int count = 0; struct xrdp_rdp *rdp = (struct xrdp_rdp *)NULL; struct xrdp_mcs *mcs = (struct xrdp_mcs *)NULL; struct mcs_channel_item *channel_item = (struct mcs_channel_item *)NULL; rdp = (struct xrdp_rdp *)session->rdp; mcs = rdp->sec_layer->mcs_layer; if (mcs->channel_list == NULL) { g_writeln("libxrdp_query_channel - No channel initialized"); return 1 ; } count = mcs->channel_list->count; if (index < 0 || index >= count) { DEBUG(("libxrdp_query_channel - Channel out of range %d", index)); return 1; } channel_item = (struct mcs_channel_item *) list_get_item(mcs->channel_list, index); if (channel_item == 0) { /* this should not happen */ g_writeln("libxrdp_query_channel - channel item is 0"); return 1; } if (channel_name != 0) { g_strncpy(channel_name, channel_item->name, 8); DEBUG(("libxrdp_query_channel - Channel %d name %s", index, channel_name)); } if (channel_flags != 0) { *channel_flags = channel_item->flags; } return 0; } /*****************************************************************************/ /* returns a zero based index of the channel, -1 if error or it doesn't exist */ int EXPORT_CC libxrdp_get_channel_id(struct xrdp_session *session, const char *name) { int index = 0; int count = 0; struct xrdp_rdp *rdp = NULL; struct xrdp_mcs *mcs = NULL; struct mcs_channel_item *channel_item = NULL; rdp = (struct xrdp_rdp *)session->rdp; mcs = rdp->sec_layer->mcs_layer; if (mcs->channel_list == NULL) { g_writeln("libxrdp_get_channel_id No channel initialized"); return -1 ; } count = mcs->channel_list->count; for (index = 0; index < count; index++) { channel_item = (struct mcs_channel_item *) list_get_item(mcs->channel_list, index); if (channel_item != 0) { if (g_strcasecmp(name, channel_item->name) == 0) { return index; } } } return -1; } /*****************************************************************************/ int EXPORT_CC libxrdp_send_to_channel(struct xrdp_session *session, int channel_id, char *data, int data_len, int total_data_len, int flags) { struct xrdp_rdp *rdp = NULL; struct xrdp_sec *sec = NULL; struct xrdp_channel *chan = NULL; struct stream *s = NULL; rdp = (struct xrdp_rdp *)session->rdp; sec = rdp->sec_layer; chan = sec->chan_layer; make_stream(s); init_stream(s, data_len + 1024); /* this should be big enough */ if (xrdp_channel_init(chan, s) != 0) { free_stream(s); return 1; } /* here we make a copy of the data */ out_uint8a(s, data, data_len); s_mark_end(s); if (xrdp_channel_send(chan, s, channel_id, total_data_len, flags) != 0) { g_writeln("libxrdp_send_to_channel: error, server channel data NOT sent to client channel"); free_stream(s); return 1; } free_stream(s); return 0; } /*****************************************************************************/ int EXPORT_CC libxrdp_orders_send_brush(struct xrdp_session *session, int width, int height, int bpp, int type, int size, char *data, int cache_id) { return xrdp_orders_send_brush((struct xrdp_orders *)session->orders, width, height, bpp, type, size, data, cache_id); } /*****************************************************************************/ int EXPORT_CC libxrdp_orders_send_create_os_surface(struct xrdp_session *session, int id, int width, int height, struct list *del_list) { return xrdp_orders_send_create_os_surface ((struct xrdp_orders *)(session->orders), id, width, height, del_list); } /*****************************************************************************/ int EXPORT_CC libxrdp_orders_send_switch_os_surface(struct xrdp_session *session, int id) { return xrdp_orders_send_switch_os_surface ((struct xrdp_orders *)(session->orders), id); } /*****************************************************************************/ int EXPORT_CC libxrdp_window_new_update(struct xrdp_session *session, int window_id, struct rail_window_state_order *window_state, int flags) { struct xrdp_orders *orders; orders = (struct xrdp_orders *)(session->orders); return xrdp_orders_send_window_new_update(orders, window_id, window_state, flags); } /*****************************************************************************/ int EXPORT_CC libxrdp_window_delete(struct xrdp_session *session, int window_id) { struct xrdp_orders *orders; orders = (struct xrdp_orders *)(session->orders); return xrdp_orders_send_window_delete(orders, window_id); } /*****************************************************************************/ int EXPORT_CC libxrdp_window_icon(struct xrdp_session *session, int window_id, int cache_entry, int cache_id, struct rail_icon_info *icon_info, int flags) { struct xrdp_orders *orders; orders = (struct xrdp_orders *)(session->orders); return xrdp_orders_send_window_icon(orders, window_id, cache_entry, cache_id, icon_info, flags); } /*****************************************************************************/ int EXPORT_CC libxrdp_window_cached_icon(struct xrdp_session *session, int window_id, int cache_entry, int cache_id, int flags) { struct xrdp_orders *orders; orders = (struct xrdp_orders *)(session->orders); return xrdp_orders_send_window_cached_icon(orders, window_id, cache_entry, cache_id, flags); } /*****************************************************************************/ int EXPORT_CC libxrdp_notify_new_update(struct xrdp_session *session, int window_id, int notify_id, struct rail_notify_state_order *notify_state, int flags) { struct xrdp_orders *orders; orders = (struct xrdp_orders *)(session->orders); return xrdp_orders_send_notify_new_update(orders, window_id, notify_id, notify_state, flags); } /*****************************************************************************/ int libxrdp_notify_delete(struct xrdp_session *session, int window_id, int notify_id) { struct xrdp_orders *orders; orders = (struct xrdp_orders *)(session->orders); return xrdp_orders_send_notify_delete(orders, window_id, notify_id); } /*****************************************************************************/ int libxrdp_monitored_desktop(struct xrdp_session *session, struct rail_monitored_desktop_order *mdo, int flags) { struct xrdp_orders *orders; orders = (struct xrdp_orders *)(session->orders); return xrdp_orders_send_monitored_desktop(orders, mdo, flags); } /*****************************************************************************/ int EXPORT_CC libxrdp_codec_jpeg_compress(struct xrdp_session *session, int format, char *inp_data, int width, int height, int stride, int x, int y, int cx, int cy, int quality, char *out_data, int *io_len) { struct xrdp_orders *orders; void* jpeg_han; orders = (struct xrdp_orders *)(session->orders); jpeg_han = orders->jpeg_han; return xrdp_codec_jpeg_compress(jpeg_han, format, inp_data, width, height, stride, x, y, cx, cy, quality, out_data, io_len); } /*****************************************************************************/ int EXPORT_CC libxrdp_fastpath_send_surface(struct xrdp_session *session, char* data_pad, int pad_bytes, int data_bytes, int destLeft, int destTop, int destRight, int destBottom, int bpp, int codecID, int width, int height) { struct stream ls; struct stream *s; struct xrdp_rdp *rdp; int sec_bytes; int rdp_bytes; int max_bytes; int cmd_bytes; LLOGLN(10, ("libxrdp_fastpath_send_surface:")); if ((session->client_info->use_fast_path & 1) == 0) { return 1; } max_bytes = session->client_info->max_fastpath_frag_bytes; if (max_bytes < 32 * 1024) { max_bytes = 32 * 1024; } rdp = (struct xrdp_rdp *) (session->rdp); rdp_bytes = xrdp_rdp_get_fastpath_bytes(rdp); sec_bytes = xrdp_sec_get_fastpath_bytes(rdp->sec_layer); cmd_bytes = 10 + 12; if (data_bytes + rdp_bytes + sec_bytes + cmd_bytes > max_bytes) { return 1; } if (sec_bytes + rdp_bytes + cmd_bytes > pad_bytes) { return 1; } g_memset(&ls, 0, sizeof(ls)); s = &ls; s->data = (data_pad + pad_bytes) - (rdp_bytes + sec_bytes + cmd_bytes); s->sec_hdr = s->data; s->rdp_hdr = s->sec_hdr + sec_bytes; s->end = data_pad + pad_bytes + data_bytes; s->p = s->data + (rdp_bytes + sec_bytes); /* TS_SURFCMD_STREAM_SURF_BITS */ out_uint16_le(s, CMDTYPE_STREAM_SURFACE_BITS); out_uint16_le(s, destLeft); out_uint16_le(s, destTop); out_uint16_le(s, destRight); out_uint16_le(s, destBottom); /* TS_BITMAP_DATA_EX */ out_uint8(s, bpp); out_uint8(s, 0); out_uint8(s, 0); out_uint8(s, codecID); out_uint16_le(s, width); out_uint16_le(s, height); out_uint32_le(s, data_bytes); /* 4 = FASTPATH_UPDATETYPE_SURFCMDS */ if (xrdp_rdp_send_fastpath(rdp, s, 4) != 0) { return 1; } return 0; } /*****************************************************************************/ int EXPORT_CC libxrdp_fastpath_send_frame_marker(struct xrdp_session *session, int frame_action, int frame_id) { struct stream *s; struct xrdp_rdp *rdp; LLOGLN(10, ("libxrdp_fastpath_send_frame_marker:")); if ((session->client_info->use_fast_path & 1) == 0) { return 1; } if (session->client_info->use_frame_acks == 0) { return 1; } rdp = (struct xrdp_rdp *) (session->rdp); make_stream(s); init_stream(s, 8192); xrdp_rdp_init_fastpath(rdp, s); out_uint16_le(s, 0x0004); /* CMDTYPE_FRAME_MARKER */ out_uint16_le(s, frame_action); out_uint32_le(s, frame_id); s_mark_end(s); /* 4 = FASTPATH_UPDATETYPE_SURFCMDS */ if (xrdp_rdp_send_fastpath(rdp, s, 4) != 0) { free_stream(s); return 1; } free_stream(s); return 0; } /*****************************************************************************/ int EXPORT_CC libxrdp_send_session_info(struct xrdp_session *session, const char *data, int data_bytes) { struct xrdp_rdp *rdp; LLOGLN(10, ("libxrdp_send_session_info:")); rdp = (struct xrdp_rdp *) (session->rdp); return xrdp_rdp_send_session_info(rdp, data, data_bytes); } xrdp-0.9.5/libxrdp/xrdp_fastpath.c000644 001751 001751 00000023616 13201006747 017111 0ustar00metameta000000 000000 /** * xrdp: A Remote Desktop Protocol server. * * Copyright (C) Jay Sorg 2012-2014 * Copyright (C) Idan Freiberg 2013-2014 * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ #if defined(HAVE_CONFIG_H) #include #endif #include "libxrdp.h" /*****************************************************************************/ struct xrdp_fastpath * xrdp_fastpath_create(struct xrdp_sec *owner, struct trans *trans) { struct xrdp_fastpath *self; DEBUG((" in xrdp_fastpath_create")); self = (struct xrdp_fastpath *)g_malloc(sizeof(struct xrdp_fastpath), 1); self->sec_layer = owner; self->trans = trans; self->session = owner->rdp_layer->session; DEBUG((" out xrdp_fastpath_create")); return self; } /*****************************************************************************/ void xrdp_fastpath_delete(struct xrdp_fastpath *self) { if (self == 0) { return; } g_free(self); } /*****************************************************************************/ /* returns error */ int xrdp_fastpath_reset(struct xrdp_fastpath *self) { return 0; } /*****************************************************************************/ int xrdp_fastpath_recv(struct xrdp_fastpath *self, struct stream *s) { int fp_hdr; int len = 0; /* unused */ int byte; char *holdp; DEBUG((" in xrdp_fastpath_recv")); holdp = s->p; if (!s_check_rem(s, 2)) { return 1; } in_uint8(s, fp_hdr); /* fpInputHeader (1 byte) */ in_uint8(s, byte); /* length 1 (1 byte) */ self->numEvents = (fp_hdr & 0x3C) >> 2; self->secFlags = (fp_hdr & 0xC0) >> 6; if (byte & 0x80) { byte &= ~(0x80); len = (byte << 8); if (!s_check_rem(s, 1)) { return 1; } in_uint8(s, byte); /* length 2 (1 byte) */ len += byte; } else { len = byte; } s->next_packet = holdp + len; DEBUG((" out xrdp_fastpath_recv")); return 0; } /*****************************************************************************/ /* no fragmentation */ int xrdp_fastpath_init(struct xrdp_fastpath *self, struct stream *s) { int bytes; bytes = self->session->client_info->max_fastpath_frag_bytes; if (bytes < 32 * 1024) { bytes = 32 * 1024; } init_stream(s, bytes); return 0; } /*****************************************************************************/ static int xrdp_fastpath_session_callback(struct xrdp_fastpath *self, int msg, long param1, long param2, long param3, long param4) { if (self->session->callback != 0) { /* msg_type can be RDP_INPUT_SYNCHRONIZE - 0 RDP_INPUT_SCANCODE - 4 RDP_INPUT_MOUSE - 0x8001 RDP_INPUT_MOUSEX - 0x8002 */ /* call to xrdp_wm.c : callback */ self->session->callback(self->session->id, msg, param1, param2, param3, param4); } return 0; } /*****************************************************************************/ /* no fragmentation */ int xrdp_fastpath_send(struct xrdp_fastpath *self, struct stream *s) { if (trans_write_copy_s(self->trans, s) != 0) { return 1; } xrdp_fastpath_session_callback(self, 0x5556, 0, 0, 0, 0); return 0; } /*****************************************************************************/ /* FASTPATH_INPUT_EVENT_SCANCODE */ static int xrdp_fastpath_process_EVENT_SCANCODE(struct xrdp_fastpath *self, int eventFlags, struct stream *s) { int flags; int code; flags = 0; if (!s_check_rem(s, 1)) { return 1; } in_uint8(s, code); /* keyCode (1 byte) */ if ((eventFlags & FASTPATH_INPUT_KBDFLAGS_RELEASE)) { flags |= KBD_FLAG_UP; } else { flags |= KBD_FLAG_DOWN; } if ((eventFlags & FASTPATH_INPUT_KBDFLAGS_EXTENDED)) flags |= KBD_FLAG_EXT; xrdp_fastpath_session_callback(self, RDP_INPUT_SCANCODE, code, 0, flags, 0); return 0; } /*****************************************************************************/ /* FASTPATH_INPUT_EVENT_MOUSE */ static int xrdp_fastpath_process_EVENT_MOUSE(struct xrdp_fastpath *self, int eventFlags, struct stream *s) { int pointerFlags; int xPos; int yPos; /* eventFlags MUST be zeroed out */ if (eventFlags != 0) { return 1; } if (!s_check_rem(s, 2 + 2 + 2)) { return 1; } in_uint16_le(s, pointerFlags); /* pointerFlags (2 bytes) */ in_uint16_le(s, xPos); /* xPos (2 bytes) */ in_uint16_le(s, yPos); /* yPos (2 bytes) */ xrdp_fastpath_session_callback(self, RDP_INPUT_MOUSE, xPos, yPos, pointerFlags, 0); return 0; } /*****************************************************************************/ /* FASTPATH_INPUT_EVENT_MOUSEX */ static int xrdp_fastpath_process_EVENT_MOUSEX(struct xrdp_fastpath *self, int eventFlags, struct stream *s) { int pointerFlags; int xPos; int yPos; /* eventFlags MUST be zeroed out */ if (eventFlags != 0) { return 1; } if (!s_check_rem(s, 2 + 2 + 2)) { return 1; } in_uint16_le(s, pointerFlags); /* pointerFlags (2 bytes) */ in_uint16_le(s, xPos); /* xPos (2 bytes) */ in_uint16_le(s, yPos); /* yPos (2 bytes) */ xrdp_fastpath_session_callback(self, RDP_INPUT_MOUSEX, xPos, yPos, pointerFlags, 0); return 0; } /*****************************************************************************/ /* FASTPATH_INPUT_EVENT_SYNC */ static int xrdp_fastpath_process_EVENT_SYNC(struct xrdp_fastpath *self, int eventFlags, struct stream *s) { /* * The eventCode bitfield (3 bits in size) MUST be set to * FASTPATH_INPUT_EVENT_SYNC (3). * The eventFlags bitfield (5 bits in size) contains flags * indicating the "on" * status of the keyboard toggle keys. */ xrdp_fastpath_session_callback(self, RDP_INPUT_SYNCHRONIZE, eventFlags, 0, 0, 0); return 0; } /*****************************************************************************/ /* FASTPATH_INPUT_EVENT_UNICODE */ static int xrdp_fastpath_process_EVENT_UNICODE(struct xrdp_fastpath *self, int eventFlags, struct stream *s) { int flags; int code; flags = 0; if (!s_check_rem(s, 2)) { return 1; } in_uint16_le(s, code); /* unicode (2 byte) */ if (eventFlags & FASTPATH_INPUT_KBDFLAGS_RELEASE) { flags |= KBD_FLAG_UP; } else { flags |= KBD_FLAG_DOWN; } if (eventFlags & FASTPATH_INPUT_KBDFLAGS_EXTENDED) { flags |= KBD_FLAG_EXT; } xrdp_fastpath_session_callback(self, RDP_INPUT_UNICODE, code, 0, flags, 0); return 0; } /*****************************************************************************/ /* FASTPATH_INPUT_EVENT */ int xrdp_fastpath_process_input_event(struct xrdp_fastpath *self, struct stream *s) { int i; int eventHeader; int eventCode; int eventFlags; /* process fastpath input events */ for (i = 0; i < self->numEvents; i++) { if (!s_check_rem(s, 1)) { return 1; } in_uint8(s, eventHeader); eventFlags = (eventHeader & 0x1F); eventCode = (eventHeader >> 5); switch (eventCode) { case FASTPATH_INPUT_EVENT_SCANCODE: if (xrdp_fastpath_process_EVENT_SCANCODE(self, eventFlags, s) != 0) { return 1; } break; case FASTPATH_INPUT_EVENT_MOUSE: if (xrdp_fastpath_process_EVENT_MOUSE(self, eventFlags, s) != 0) { return 1; } break; case FASTPATH_INPUT_EVENT_MOUSEX: if (xrdp_fastpath_process_EVENT_MOUSEX(self, eventFlags, s) != 0) { return 1; } break; case FASTPATH_INPUT_EVENT_SYNC: if (xrdp_fastpath_process_EVENT_SYNC(self, eventFlags, s) != 0) { return 1; } break; case FASTPATH_INPUT_EVENT_UNICODE: if (xrdp_fastpath_process_EVENT_UNICODE(self, eventFlags, s) != 0) { return 1; } break; default: g_writeln("xrdp_fastpath_process_input_event: unknown " "eventCode %d", eventCode); break; } } return 0; } xrdp-0.9.5/libxrdp/xrdp_caps.c000644 001751 001751 00000104725 13220727201 016222 0ustar00metameta000000 000000 /** * xrdp: A Remote Desktop Protocol server. * * Copyright (C) Jay Sorg 2004-2014 * Copyright (C) Idan Freiberg 2004-2014 * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. * * RDP Capability Sets */ #if defined(HAVE_CONFIG_H) #include #endif #include "libxrdp.h" /*****************************************************************************/ static int xrdp_caps_send_monitorlayout(struct xrdp_rdp *self) { struct stream *s; int i; make_stream(s); init_stream(s, 8192); if (xrdp_rdp_init_data(self, s) != 0) { free_stream(s); return 1; } out_uint32_le(s, self->client_info.monitorCount); /* monitorCount (4 bytes) */ /* TODO: validate for allowed monitors in terminal server (maybe by config?) */ for (i = 0; i < self->client_info.monitorCount; i++) { out_uint32_le(s, self->client_info.minfo[i].left); out_uint32_le(s, self->client_info.minfo[i].top); out_uint32_le(s, self->client_info.minfo[i].right); out_uint32_le(s, self->client_info.minfo[i].bottom); out_uint32_le(s, self->client_info.minfo[i].is_primary); } s_mark_end(s); if (xrdp_rdp_send_data(self, s, 0x37) != 0) { free_stream(s); return 1; } free_stream(s); return 0; } /*****************************************************************************/ static int xrdp_caps_process_general(struct xrdp_rdp *self, struct stream *s, int len) { int extraFlags; int client_does_fastpath_output; if (len < 10 + 2) { g_writeln("xrdp_caps_process_general: error"); return 1; } in_uint16_le(s, self->client_info.client_os_major); /* osMajorType (2 bytes) */ in_uint16_le(s, self->client_info.client_os_minor); /* osMinorType (2 bytes) */ in_uint8s(s, 6); in_uint16_le(s, extraFlags); /* extraFlags (2 bytes) */ self->client_info.op1 = extraFlags & NO_BITMAP_COMPRESSION_HDR; /* use_compact_packets is pretty much 'use rdp5' */ self->client_info.use_compact_packets = (extraFlags != 0); /* op2 is a boolean to use compact bitmap headers in bitmap cache */ /* set it to same as 'use rdp5' boolean */ self->client_info.op2 = self->client_info.use_compact_packets; /* FASTPATH_OUTPUT_SUPPORTED 0x0001 */ client_does_fastpath_output = extraFlags & FASTPATH_OUTPUT_SUPPORTED; if ((self->client_info.use_fast_path & 1) && !client_does_fastpath_output) { /* server supports fast path output and client does not, turn it off */ self->client_info.use_fast_path &= ~1; } return 0; } /*****************************************************************************/ static int xrdp_caps_process_order(struct xrdp_rdp *self, struct stream *s, int len) { int i; char order_caps[32]; int ex_flags; int cap_flags; DEBUG(("order capabilities")); if (len < 20 + 2 + 2 + 2 + 2 + 2 + 2 + 32 + 2 + 2 + 4 + 4 + 4 + 4) { g_writeln("xrdp_caps_process_order: error"); return 1; } in_uint8s(s, 20); /* Terminal desc, pad */ in_uint8s(s, 2); /* Cache X granularity */ in_uint8s(s, 2); /* Cache Y granularity */ in_uint8s(s, 2); /* Pad */ in_uint8s(s, 2); /* Max order level */ in_uint8s(s, 2); /* Number of fonts */ in_uint16_le(s, cap_flags); /* Capability flags */ in_uint8a(s, order_caps, 32); /* Orders supported */ g_memcpy(self->client_info.orders, order_caps, 32); DEBUG(("dest blt-0 %d", order_caps[0])); DEBUG(("pat blt-1 %d", order_caps[1])); DEBUG(("screen blt-2 %d", order_caps[2])); DEBUG(("memblt-3-13 %d %d", order_caps[3], order_caps[13])); DEBUG(("triblt-4-14 %d %d", order_caps[4], order_caps[14])); DEBUG(("line-8 %d", order_caps[8])); DEBUG(("line-9 %d", order_caps[9])); DEBUG(("rect-10 %d", order_caps[10])); DEBUG(("desksave-11 %d", order_caps[11])); DEBUG(("polygon-20 %d", order_caps[20])); DEBUG(("polygon2-21 %d", order_caps[21])); DEBUG(("polyline-22 %d", order_caps[22])); DEBUG(("ellipse-25 %d", order_caps[25])); DEBUG(("ellipse2-26 %d", order_caps[26])); DEBUG(("text2-27 %d", order_caps[27])); DEBUG(("order_caps dump")); #if defined(XRDP_DEBUG) g_hexdump(order_caps, 32); #endif in_uint8s(s, 2); /* Text capability flags */ /* read extended order support flags */ in_uint16_le(s, ex_flags); /* Ex flags */ if (cap_flags & 0x80) /* ORDER_FLAGS_EXTRA_SUPPORT */ { self->client_info.order_flags_ex = ex_flags; if (ex_flags & XR_ORDERFLAGS_EX_CACHE_BITMAP_REV3_SUPPORT) { g_writeln("xrdp_caps_process_order: bitmap cache v3 supported"); self->client_info.bitmap_cache_version |= 4; } } in_uint8s(s, 4); /* Pad */ in_uint32_le(s, i); /* desktop cache size, usually 0x38400 */ self->client_info.desktop_cache = i; DEBUG(("desktop cache size %d", i)); in_uint8s(s, 4); /* Unknown */ in_uint8s(s, 4); /* Unknown */ /* check if libpainter should be used for drawing, instead of orders */ if (!(order_caps[TS_NEG_DSTBLT_INDEX] && order_caps[TS_NEG_PATBLT_INDEX] && order_caps[TS_NEG_SCRBLT_INDEX] && order_caps[TS_NEG_MEMBLT_INDEX])) { g_writeln("xrdp_caps_process_order: not enough orders supported by client, using painter."); self->client_info.no_orders_supported = 1; } return 0; } /*****************************************************************************/ /* get the bitmap cache size */ static int xrdp_caps_process_bmpcache(struct xrdp_rdp *self, struct stream *s, int len) { int i; if (len < 24 + 2 + 2 + 2 + 2 + 2 + 2) { g_writeln("xrdp_caps_process_bmpcache: error"); return 1; } self->client_info.bitmap_cache_version |= 1; in_uint8s(s, 24); /* cache 1 */ in_uint16_le(s, i); i = MIN(i, XRDP_MAX_BITMAP_CACHE_IDX); i = MAX(i, 0); self->client_info.cache1_entries = i; in_uint16_le(s, self->client_info.cache1_size); /* cache 2 */ in_uint16_le(s, i); i = MIN(i, XRDP_MAX_BITMAP_CACHE_IDX); i = MAX(i, 0); self->client_info.cache2_entries = i; in_uint16_le(s, self->client_info.cache2_size); /* cache 3 */ in_uint16_le(s, i); i = MIN(i, XRDP_MAX_BITMAP_CACHE_IDX); i = MAX(i, 0); self->client_info.cache3_entries = i; in_uint16_le(s, self->client_info.cache3_size); DEBUG(("cache1 entries %d size %d", self->client_info.cache1_entries, self->client_info.cache1_size)); DEBUG(("cache2 entries %d size %d", self->client_info.cache2_entries, self->client_info.cache2_size)); DEBUG(("cache3 entries %d size %d", self->client_info.cache3_entries, self->client_info.cache3_size)); return 0; } /*****************************************************************************/ /* get the bitmap cache size */ static int xrdp_caps_process_bmpcache2(struct xrdp_rdp *self, struct stream *s, int len) { int Bpp = 0; int i = 0; if (len < 2 + 2 + 4 + 4 + 4) { g_writeln("xrdp_caps_process_bmpcache2: error"); return 1; } self->client_info.bitmap_cache_version |= 2; Bpp = (self->client_info.bpp + 7) / 8; in_uint16_le(s, i); /* cache flags */ self->client_info.bitmap_cache_persist_enable = i; in_uint8s(s, 2); /* number of caches in set, 3 */ in_uint32_le(s, i); i = MIN(i, XRDP_MAX_BITMAP_CACHE_IDX); i = MAX(i, 0); self->client_info.cache1_entries = i; self->client_info.cache1_size = 256 * Bpp; in_uint32_le(s, i); i = MIN(i, XRDP_MAX_BITMAP_CACHE_IDX); i = MAX(i, 0); self->client_info.cache2_entries = i; self->client_info.cache2_size = 1024 * Bpp; in_uint32_le(s, i); i = i & 0x7fffffff; i = MIN(i, XRDP_MAX_BITMAP_CACHE_IDX); i = MAX(i, 0); self->client_info.cache3_entries = i; self->client_info.cache3_size = 4096 * Bpp; DEBUG(("cache1 entries %d size %d", self->client_info.cache1_entries, self->client_info.cache1_size)); DEBUG(("cache2 entries %d size %d", self->client_info.cache2_entries, self->client_info.cache2_size)); DEBUG(("cache3 entries %d size %d", self->client_info.cache3_entries, self->client_info.cache3_size)); return 0; } /*****************************************************************************/ static int xrdp_caps_process_cache_v3_codec_id(struct xrdp_rdp *self, struct stream *s, int len) { int codec_id; if (len < 1) { g_writeln("xrdp_caps_process_cache_v3_codec_id: error"); return 1; } in_uint8(s, codec_id); g_writeln("xrdp_caps_process_cache_v3_codec_id: cache_v3_codec_id %d", codec_id); self->client_info.v3_codec_id = codec_id; return 0; } /*****************************************************************************/ /* get the number of client cursor cache */ static int xrdp_caps_process_pointer(struct xrdp_rdp *self, struct stream *s, int len) { int i; int colorPointerFlag; int no_new_cursor; if (len < 2 + 2 + 2) { g_writeln("xrdp_caps_process_pointer: error"); return 1; } no_new_cursor = self->client_info.pointer_flags & 2; in_uint16_le(s, colorPointerFlag); self->client_info.pointer_flags = colorPointerFlag; in_uint16_le(s, i); i = MIN(i, 32); self->client_info.pointer_cache_entries = i; if (colorPointerFlag & 1) { g_writeln("xrdp_caps_process_pointer: client supports " "new(color) cursor"); in_uint16_le(s, i); i = MIN(i, 32); self->client_info.pointer_cache_entries = i; } else { g_writeln("xrdp_caps_process_pointer: client does not support " "new(color) cursor"); } if (no_new_cursor) { g_writeln("xrdp_caps_process_pointer: new(color) cursor is " "disabled by config"); self->client_info.pointer_flags = 0; } return 0; } /*****************************************************************************/ static int xrdp_caps_process_input(struct xrdp_rdp *self, struct stream *s, int len) { int inputFlags; int client_does_fastpath_input; in_uint16_le(s, inputFlags); client_does_fastpath_input = (inputFlags & INPUT_FLAG_FASTPATH_INPUT) || (inputFlags & INPUT_FLAG_FASTPATH_INPUT2); if ((self->client_info.use_fast_path & 2) && !client_does_fastpath_input) { self->client_info.use_fast_path &= ~2; } return 0; } /*****************************************************************************/ /* get the type of client brush cache */ int xrdp_caps_process_brushcache(struct xrdp_rdp *self, struct stream *s, int len) { int code; if (len < 4) { g_writeln("xrdp_caps_process_brushcache: error"); return 1; } in_uint32_le(s, code); self->client_info.brush_cache_code = code; return 0; } /*****************************************************************************/ int xrdp_caps_process_offscreen_bmpcache(struct xrdp_rdp *self, struct stream *s, int len) { int i32; if (len < 4 + 2 + 2) { g_writeln("xrdp_caps_process_offscreen_bmpcache: error"); return 1; } in_uint32_le(s, i32); self->client_info.offscreen_support_level = i32; in_uint16_le(s, i32); self->client_info.offscreen_cache_size = i32 * 1024; in_uint16_le(s, i32); self->client_info.offscreen_cache_entries = i32; g_writeln("xrdp_process_offscreen_bmpcache: support level %d " "cache size %d MB cache entries %d", self->client_info.offscreen_support_level, self->client_info.offscreen_cache_size, self->client_info.offscreen_cache_entries); return 0; } /*****************************************************************************/ int xrdp_caps_process_rail(struct xrdp_rdp *self, struct stream *s, int len) { int i32; if (len < 4) { g_writeln("xrdp_caps_process_rail: error"); return 1; } in_uint32_le(s, i32); self->client_info.rail_support_level = i32; g_writeln("xrdp_process_capset_rail: rail_support_level %d", self->client_info.rail_support_level); return 0; } /*****************************************************************************/ static int xrdp_caps_process_window(struct xrdp_rdp *self, struct stream *s, int len) { int i32; if (len < 4 + 1 + 2) { g_writeln("xrdp_caps_process_window: error"); return 1; } in_uint32_le(s, i32); self->client_info.wnd_support_level = i32; in_uint8(s, i32); self->client_info.wnd_num_icon_caches = i32; in_uint16_le(s, i32); self->client_info.wnd_num_icon_cache_entries = i32; g_writeln("xrdp_process_capset_window wnd_support_level %d " "wnd_num_icon_caches %d wnd_num_icon_cache_entries %d", self->client_info.wnd_support_level, self->client_info.wnd_num_icon_caches, self->client_info.wnd_num_icon_cache_entries); return 0; } /*****************************************************************************/ static int xrdp_caps_process_codecs(struct xrdp_rdp *self, struct stream *s, int len) { int codec_id; int codec_count; int index; int codec_properties_length; int i1; char *codec_guid; char *next_guid; if (len < 1) { g_writeln("xrdp_caps_process_codecs: error"); return 1; } in_uint8(s, codec_count); len--; for (index = 0; index < codec_count; index++) { codec_guid = s->p; if (len < 16 + 1 + 2) { g_writeln("xrdp_caps_process_codecs: error"); return 1; } in_uint8s(s, 16); in_uint8(s, codec_id); in_uint16_le(s, codec_properties_length); len -= 16 + 1 + 2; if (len < codec_properties_length) { g_writeln("xrdp_caps_process_codecs: error"); return 1; } len -= codec_properties_length; next_guid = s->p + codec_properties_length; if (g_memcmp(codec_guid, XR_CODEC_GUID_NSCODEC, 16) == 0) { g_writeln("xrdp_caps_process_codecs: nscodec, codec id %d, properties len %d", codec_id, codec_properties_length); self->client_info.ns_codec_id = codec_id; i1 = MIN(64, codec_properties_length); g_memcpy(self->client_info.ns_prop, s->p, i1); self->client_info.ns_prop_len = i1; } else if (g_memcmp(codec_guid, XR_CODEC_GUID_REMOTEFX, 16) == 0) { g_writeln("xrdp_caps_process_codecs: RemoteFX, codec id %d, properties len %d", codec_id, codec_properties_length); self->client_info.rfx_codec_id = codec_id; i1 = MIN(64, codec_properties_length); g_memcpy(self->client_info.rfx_prop, s->p, i1); self->client_info.rfx_prop_len = i1; } else if (g_memcmp(codec_guid, XR_CODEC_GUID_JPEG, 16) == 0) { g_writeln("xrdp_caps_process_codecs: jpeg, codec id %d, properties len %d", codec_id, codec_properties_length); self->client_info.jpeg_codec_id = codec_id; i1 = MIN(64, codec_properties_length); g_memcpy(self->client_info.jpeg_prop, s->p, i1); self->client_info.jpeg_prop_len = i1; /* make sure that requested quality is between 0 to 100 */ if (self->client_info.jpeg_prop[0] < 0 || self->client_info.jpeg_prop[0] > 100) { g_writeln(" Warning: the requested jpeg quality (%d) is invalid," " falling back to default", self->client_info.jpeg_prop[0]); self->client_info.jpeg_prop[0] = 75; /* use default */ } g_writeln(" jpeg quality set to %d", self->client_info.jpeg_prop[0]); } else if (g_memcmp(codec_guid, XR_CODEC_GUID_H264, 16) == 0) { g_writeln("xrdp_caps_process_codecs: h264, codec id %d, properties len %d", codec_id, codec_properties_length); self->client_info.h264_codec_id = codec_id; i1 = MIN(64, codec_properties_length); g_memcpy(self->client_info.h264_prop, s->p, i1); self->client_info.h264_prop_len = i1; } else { g_writeln("xrdp_caps_process_codecs: unknown codec id %d", codec_id); } s->p = next_guid; } return 0; } /*****************************************************************************/ static int xrdp_caps_process_multifragmentupdate(struct xrdp_rdp *self, struct stream *s, int len) { int MaxRequestSize; in_uint32_le(s, MaxRequestSize); self->client_info.max_fastpath_frag_bytes = MaxRequestSize; return 0; } /*****************************************************************************/ static int xrdp_caps_process_frame_ack(struct xrdp_rdp *self, struct stream *s, int len) { g_writeln("xrdp_caps_process_frame_ack:"); self->client_info.use_frame_acks = 1; in_uint32_le(s, self->client_info.max_unacknowledged_frame_count); if (self->client_info.max_unacknowledged_frame_count < 0) { g_writeln(" invalid max_unacknowledged_frame_count value (%d), setting to 0", self->client_info.max_unacknowledged_frame_count); self->client_info.max_unacknowledged_frame_count = 0; } g_writeln(" max_unacknowledged_frame_count %d", self->client_info.max_unacknowledged_frame_count); return 0; } /*****************************************************************************/ static int xrdp_caps_process_surface_cmds(struct xrdp_rdp *self, struct stream *s, int len) { int cmdFlags; g_writeln("xrdp_caps_process_surface_cmds:"); in_uint32_le(s, cmdFlags); in_uint8s(s, 4); /* reserved */ g_writeln(" cmdFlags 0x%08x", cmdFlags); return 0; } /*****************************************************************************/ int xrdp_caps_process_confirm_active(struct xrdp_rdp *self, struct stream *s) { int cap_len; int source_len; int num_caps; int index; int type; int len; char *p; DEBUG(("in xrdp_caps_process_confirm_active")); in_uint8s(s, 4); /* rdp_shareid */ in_uint8s(s, 2); /* userid */ in_uint16_le(s, source_len); /* sizeof RDP_SOURCE */ in_uint16_le(s, cap_len); in_uint8s(s, source_len); in_uint16_le(s, num_caps); in_uint8s(s, 2); /* pad */ if ((cap_len < 0) || (cap_len > 1024 * 1024)) { return 1; } for (index = 0; index < num_caps; index++) { p = s->p; if (!s_check_rem(s, 4)) { g_writeln("xrdp_caps_process_confirm_active: error 1"); return 1; } in_uint16_le(s, type); in_uint16_le(s, len); if ((len < 4) || !s_check_rem(s, len - 4)) { g_writeln("xrdp_caps_process_confirm_active: error: len %d, " "remaining %d", len, (int) (s->end - s->p)); return 1; } len -= 4; switch (type) { case RDP_CAPSET_GENERAL: DEBUG(("RDP_CAPSET_GENERAL")); xrdp_caps_process_general(self, s, len); break; case RDP_CAPSET_BITMAP: DEBUG(("RDP_CAPSET_BITMAP")); break; case RDP_CAPSET_ORDER: DEBUG(("RDP_CAPSET_ORDER")); xrdp_caps_process_order(self, s, len); break; case RDP_CAPSET_BMPCACHE: DEBUG(("RDP_CAPSET_BMPCACHE")); xrdp_caps_process_bmpcache(self, s, len); break; case RDP_CAPSET_CONTROL: DEBUG(("RDP_CAPSET_CONTROL")); break; case 6: xrdp_caps_process_cache_v3_codec_id(self, s, len); break; case RDP_CAPSET_ACTIVATE: DEBUG(("RDP_CAPSET_ACTIVATE")); break; case RDP_CAPSET_POINTER: DEBUG(("RDP_CAPSET_POINTER")); xrdp_caps_process_pointer(self, s, len); break; case RDP_CAPSET_SHARE: DEBUG(("RDP_CAPSET_SHARE")); break; case RDP_CAPSET_COLCACHE: DEBUG(("RDP_CAPSET_COLCACHE")); break; case RDP_CAPSET_SOUND: DEBUG(("--0x0C")); break; case RDP_CAPSET_INPUT: xrdp_caps_process_input(self, s, len); break; case RDP_CAPSET_FONT: DEBUG(("--0x0D")); break; case RDP_CAPSET_BRUSHCACHE: xrdp_caps_process_brushcache(self, s, len); break; case RDP_CAPSET_GLYPHCACHE: DEBUG(("--0x11")); break; case RDP_CAPSET_OFFSCREENCACHE: DEBUG(("CAPSET_TYPE_OFFSCREEN_CACHE")); xrdp_caps_process_offscreen_bmpcache(self, s, len); break; case RDP_CAPSET_BMPCACHE2: DEBUG(("RDP_CAPSET_BMPCACHE2")); xrdp_caps_process_bmpcache2(self, s, len); break; case RDP_CAPSET_VIRCHAN: DEBUG(("--0x14")); break; case RDP_CAPSET_DRAWNINEGRIDCACHE: DEBUG(("--0x15")); break; case RDP_CAPSET_DRAWGDIPLUS: DEBUG(("--0x16")); break; case RDP_CAPSET_RAIL: xrdp_caps_process_rail(self, s, len); break; case RDP_CAPSET_WINDOW: xrdp_caps_process_window(self, s, len); break; case RDP_CAPSET_MULTIFRAGMENT: xrdp_caps_process_multifragmentupdate(self, s, len); break; case RDP_CAPSET_SURFCMDS: xrdp_caps_process_surface_cmds(self, s, len); break; case RDP_CAPSET_BMPCODECS: xrdp_caps_process_codecs(self, s, len); break; case RDP_CAPSET_FRAME_ACKNOWLEDGE: xrdp_caps_process_frame_ack(self, s, len); break; default: g_writeln("unknown in xrdp_caps_process_confirm_active %d", type); break; } s->p = p + len + 4; } if (self->client_info.no_orders_supported && (self->client_info.offscreen_support_level != 0)) { g_writeln("xrdp_caps_process_confirm_active: not enough orders " "supported by client, client wants off screen bitmap but " "offscreen bitmaps disabled"); self->client_info.offscreen_support_level = 0; self->client_info.offscreen_cache_size = 0; self->client_info.offscreen_cache_entries = 0; } DEBUG(("out xrdp_caps_process_confirm_active")); return 0; } /*****************************************************************************/ int xrdp_caps_send_demand_active(struct xrdp_rdp *self) { struct stream *s; int caps_count; int caps_size; int codec_caps_count; int codec_caps_size; int flags; char *caps_count_ptr; char *caps_size_ptr; char *caps_ptr; char *codec_caps_count_ptr; char *codec_caps_size_ptr; make_stream(s); init_stream(s, 8192); DEBUG(("in xrdp_caps_send_demand_active")); if (xrdp_rdp_init(self, s) != 0) { free_stream(s); return 1; } caps_count = 0; out_uint32_le(s, self->share_id); out_uint16_le(s, 4); /* 4 chars for RDP\0 */ /* 2 bytes size after num caps, set later */ caps_size_ptr = s->p; out_uint8s(s, 2); out_uint8a(s, "RDP", 4); /* 4 byte num caps, set later */ caps_count_ptr = s->p; out_uint8s(s, 4); caps_ptr = s->p; /* Output share capability set */ caps_count++; out_uint16_le(s, RDP_CAPSET_SHARE); out_uint16_le(s, RDP_CAPLEN_SHARE); out_uint16_le(s, self->mcs_channel); out_uint16_be(s, 0xb5e2); /* 0x73e1 */ /* Output general capability set */ caps_count++; out_uint16_le(s, RDP_CAPSET_GENERAL); /* 1 */ out_uint16_le(s, RDP_CAPLEN_GENERAL); /* 24(0x18) */ out_uint16_le(s, 1); /* OS major type */ out_uint16_le(s, 3); /* OS minor type */ out_uint16_le(s, 0x200); /* Protocol version */ out_uint16_le(s, 0); /* pad */ out_uint16_le(s, 0); /* Compression types */ /* NO_BITMAP_COMPRESSION_HDR 0x0400 FASTPATH_OUTPUT_SUPPORTED 0x0001 */ if (self->client_info.use_fast_path & 1) { out_uint16_le(s, 0x401); } else { out_uint16_le(s, 0x400); } out_uint16_le(s, 0); /* Update capability */ out_uint16_le(s, 0); /* Remote unshare capability */ out_uint16_le(s, 0); /* Compression level */ out_uint16_le(s, 0); /* Pad */ /* Output bitmap capability set */ caps_count++; out_uint16_le(s, RDP_CAPSET_BITMAP); /* 2 */ out_uint16_le(s, RDP_CAPLEN_BITMAP); /* 28(0x1c) */ out_uint16_le(s, self->client_info.bpp); /* Preferred BPP */ out_uint16_le(s, 1); /* Receive 1 BPP */ out_uint16_le(s, 1); /* Receive 4 BPP */ out_uint16_le(s, 1); /* Receive 8 BPP */ out_uint16_le(s, self->client_info.width); /* width */ out_uint16_le(s, self->client_info.height); /* height */ out_uint16_le(s, 0); /* Pad */ out_uint16_le(s, 1); /* Allow resize */ out_uint16_le(s, 1); /* bitmap compression */ out_uint16_le(s, 0); /* unknown */ out_uint16_le(s, 0); /* unknown */ out_uint16_le(s, 0); /* pad */ /* Output font capability set */ caps_count++; out_uint16_le(s, RDP_CAPSET_FONT); /* 14 */ out_uint16_le(s, RDP_CAPLEN_FONT); /* 4 */ /* Output order capability set */ caps_count++; out_uint16_le(s, RDP_CAPSET_ORDER); /* 3 */ out_uint16_le(s, RDP_CAPLEN_ORDER); /* 88(0x58) */ out_uint8s(s, 16); out_uint32_be(s, 0x40420f00); out_uint16_le(s, 1); /* Cache X granularity */ out_uint16_le(s, 20); /* Cache Y granularity */ out_uint16_le(s, 0); /* Pad */ out_uint16_le(s, 1); /* Max order level */ out_uint16_le(s, 0x2f); /* Number of fonts */ out_uint16_le(s, 0x22); /* Capability flags */ /* caps */ out_uint8(s, 1); /* NEG_DSTBLT_INDEX 0x00 0 */ out_uint8(s, 1); /* NEG_PATBLT_INDEX 0x01 1 */ out_uint8(s, 1); /* NEG_SCRBLT_INDEX 0x02 2 */ out_uint8(s, 1); /* NEG_MEMBLT_INDEX 0x03 3 */ out_uint8(s, 0); /* NEG_MEM3BLT_INDEX 0x04 4 */ out_uint8(s, 0); /* NEG_ATEXTOUT_INDEX 0x05 5 */ out_uint8(s, 0); /* NEG_AEXTTEXTOUT_INDEX 0x06 6 */ out_uint8(s, 0); /* NEG_DRAWNINEGRID_INDEX 0x07 7 */ out_uint8(s, 1); /* NEG_LINETO_INDEX 0x08 8 */ out_uint8(s, 0); /* NEG_MULTI_DRAWNINEGRID_INDEX 0x09 9 */ out_uint8(s, 1); /* NEG_OPAQUE_RECT_INDEX 0x0A 10 */ out_uint8(s, 0); /* NEG_SAVEBITMAP_INDEX 0x0B 11 */ out_uint8(s, 0); /* NEG_WTEXTOUT_INDEX 0x0C 12 */ out_uint8(s, 0); /* NEG_MEMBLT_V2_INDEX 0x0D 13 */ out_uint8(s, 0); /* NEG_MEM3BLT_V2_INDEX 0x0E 14 */ out_uint8(s, 0); /* NEG_MULTIDSTBLT_INDEX 0x0F 15 */ out_uint8(s, 0); /* NEG_MULTIPATBLT_INDEX 0x10 16 */ out_uint8(s, 0); /* NEG_MULTISCRBLT_INDEX 0x11 17 */ out_uint8(s, 1); /* NEG_MULTIOPAQUERECT_INDEX 0x12 18 */ out_uint8(s, 0); /* NEG_FAST_INDEX_INDEX 0x13 19 */ out_uint8(s, 0); /* NEG_POLYGON_SC_INDEX 0x14 20 */ out_uint8(s, 0); /* NEG_POLYGON_CB_INDEX 0x15 21 */ out_uint8(s, 0); /* NEG_POLYLINE_INDEX 0x16 22 */ out_uint8(s, 0); /* unused 0x17 23 */ out_uint8(s, 0); /* NEG_FAST_GLYPH_INDEX 0x18 24 */ out_uint8(s, 0); /* NEG_ELLIPSE_SC_INDEX 0x19 25 */ out_uint8(s, 0); /* NEG_ELLIPSE_CB_INDEX 0x1A 26 */ out_uint8(s, 1); /* NEG_GLYPH_INDEX_INDEX 0x1B 27 */ out_uint8(s, 0); /* NEG_GLYPH_WEXTTEXTOUT_INDEX 0x1C 28 */ out_uint8(s, 0); /* NEG_GLYPH_WLONGTEXTOUT_INDEX 0x1D 29 */ out_uint8(s, 0); /* NEG_GLYPH_WLONGEXTTEXTOUT_INDEX 0x1E 30 */ out_uint8(s, 0); /* unused 0x1F 31 */ out_uint16_le(s, 0x6a1); /* declare support of bitmap cache rev3 */ out_uint16_le(s, XR_ORDERFLAGS_EX_CACHE_BITMAP_REV3_SUPPORT); out_uint32_le(s, 0x0f4240); /* desk save */ out_uint32_le(s, 0x0f4240); /* desk save */ out_uint32_le(s, 1); /* ? */ out_uint32_le(s, 0); /* ? */ /* Output bmpcodecs capability set */ caps_count++; out_uint16_le(s, RDP_CAPSET_BMPCODECS); codec_caps_size_ptr = s->p; out_uint8s(s, 2); /* cap len set later */ codec_caps_count = 0; codec_caps_count_ptr = s->p; out_uint8s(s, 1); /* bitmapCodecCount set later */ /* nscodec */ codec_caps_count++; out_uint8a(s, XR_CODEC_GUID_NSCODEC, 16); out_uint8(s, 1); /* codec id, must be 1 */ out_uint16_le(s, 3); /* codecPropertiesLength */ out_uint8(s, 0x01); /* fAllowDynamicFidelity */ out_uint8(s, 0x01); /* fAllowSubsampling */ out_uint8(s, 0x03); /* colorLossLevel */ #if defined(XRDP_RFXCODEC) || defined(XRDP_NEUTRINORDP) /* remotefx */ codec_caps_count++; out_uint8a(s, XR_CODEC_GUID_REMOTEFX, 16); out_uint8(s, 0); /* codec id, client sets */ out_uint16_le(s, 4); /* codecPropertiesLength */ out_uint32_le(s, 0); /* reserved */ /* image remotefx */ codec_caps_count++; out_uint8a(s, XR_CODEC_GUID_IMAGE_REMOTEFX, 16); out_uint8(s, 0); /* codec id, client sets */ out_uint16_le(s, 4); /* codecPropertiesLength */ out_uint32_le(s, 0); /* reserved */ #endif /* jpeg */ codec_caps_count++; out_uint8a(s, XR_CODEC_GUID_JPEG, 16); out_uint8(s, 0); /* codec id, client sets */ out_uint16_le(s, 1); /* codecPropertiesLength */ out_uint8(s, 75); /* jpeg compression ratio */ /* calculate and set size and count */ codec_caps_size = (int)(s->p - codec_caps_size_ptr); codec_caps_size += 2; /* 2 bytes for RDP_CAPSET_BMPCODECS above */ codec_caps_size_ptr[0] = codec_caps_size; codec_caps_size_ptr[1] = codec_caps_size >> 8; codec_caps_count_ptr[0] = codec_caps_count; /* Output color cache capability set */ caps_count++; out_uint16_le(s, RDP_CAPSET_COLCACHE); out_uint16_le(s, RDP_CAPLEN_COLCACHE); out_uint16_le(s, 6); /* cache size */ out_uint16_le(s, 0); /* pad */ /* Output pointer capability set */ caps_count++; out_uint16_le(s, RDP_CAPSET_POINTER); out_uint16_le(s, RDP_CAPLEN_POINTER); out_uint16_le(s, 1); /* Colour pointer */ out_uint16_le(s, 0x19); /* Cache size */ out_uint16_le(s, 0x19); /* Cache size */ /* Output input capability set */ caps_count++; out_uint16_le(s, RDP_CAPSET_INPUT); /* 13(0xd) */ out_uint16_le(s, RDP_CAPLEN_INPUT); /* 88(0x58) */ flags = INPUT_FLAG_SCANCODES | INPUT_FLAG_MOUSEX | INPUT_FLAG_UNICODE | TS_INPUT_FLAG_MOUSE_HWHEEL; if (self->client_info.use_fast_path & 2) { flags |= INPUT_FLAG_FASTPATH_INPUT | INPUT_FLAG_FASTPATH_INPUT2; } out_uint16_le(s, flags); out_uint8s(s, 82); /* Remote Programs Capability Set */ caps_count++; out_uint16_le(s, 0x0017); /* CAPSETTYPE_RAIL */ out_uint16_le(s, 8); out_uint32_le(s, 3); /* TS_RAIL_LEVEL_SUPPORTED TS_RAIL_LEVEL_DOCKED_LANGBAR_SUPPORTED */ /* Window List Capability Set */ caps_count++; out_uint16_le(s, 0x0018); /* CAPSETTYPE_WINDOW */ out_uint16_le(s, 11); out_uint32_le(s, 2); /* TS_WINDOW_LEVEL_SUPPORTED_EX */ out_uint8(s, 3); /* NumIconCaches */ out_uint16_le(s, 12); /* NumIconCacheEntries */ /* 6 - bitmap cache v3 codecid */ caps_count++; out_uint16_le(s, 0x0006); out_uint16_le(s, 5); out_uint8(s, 0); /* client sets */ if (self->client_info.use_fast_path & FASTPATH_OUTPUT_SUPPORTED) /* fastpath output on */ { /* multifragment update */ caps_count++; out_uint16_le(s, RDP_CAPSET_MULTIFRAGMENT); /* 26 CAPSETTYPE_MULTIFRAGMENTUPDATE */ out_uint16_le(s, RDP_CAPLEN_MULTIFRAGMENT); out_uint32_le(s, 3 * 1024 * 1024); /* 3MB */ /* frame acks */ caps_count++; out_uint16_le(s, RDP_CAPSET_FRAME_ACKNOWLEDGE); /* CAPSETTYPE_FRAME_ACKNOWLEDGE */ out_uint16_le(s, RDP_CAPLEN_FRAME_ACKNOWLEDGE); out_uint32_le(s, 2); /* 2 frames in flight */ /* surface commands */ caps_count++; out_uint16_le(s, RDP_CAPSET_SURFCMDS); /* CAPSETTYPE_SURFACE_COMMANDS */ out_uint16_le(s, RDP_CAPLEN_SURFCMDS); /* lengthCapability */ out_uint32_le(s, (SURFCMDS_SETSURFACEBITS | SURFCMDS_FRAMEMARKER | SURFCMDS_STREAMSUFRACEBITS)); /* cmdFlags */ out_uint32_le(s, 0); /* reserved */ } out_uint8s(s, 4); /* pad */ s_mark_end(s); caps_size = (int)(s->end - caps_ptr); caps_size_ptr[0] = caps_size; caps_size_ptr[1] = caps_size >> 8; caps_count_ptr[0] = caps_count; caps_count_ptr[1] = caps_count >> 8; caps_count_ptr[2] = caps_count >> 16; caps_count_ptr[3] = caps_count >> 24; if (xrdp_rdp_send(self, s, RDP_PDU_DEMAND_ACTIVE) != 0) { free_stream(s); return 1; } DEBUG(("out (1) xrdp_caps_send_demand_active")); /* send Monitor Layout PDU for dual monitor */ if (self->client_info.monitorCount > 0 && self->client_info.multimon == 1) { DEBUG(("xrdp_caps_send_demand_active: sending monitor layout pdu")); if (xrdp_caps_send_monitorlayout(self) != 0) { g_writeln("xrdp_caps_send_demand_active: error sending monitor layout pdu"); } } free_stream(s); return 0; } xrdp-0.9.5/libxrdp/xrdp_sec.c000644 001751 001751 00000221662 13220727201 016046 0ustar00metameta000000 000000 /** * xrdp: A Remote Desktop Protocol server. * * Copyright (C) Jay Sorg 2004-2014 * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. * * secure layer */ #if defined(HAVE_CONFIG_H) #include #endif #include "libxrdp.h" #include "log.h" #define LOG_LEVEL 1 #define LLOG(_level, _args) \ do { if (_level < LOG_LEVEL) { g_write _args ; } } while (0) #define LLOGLN(_level, _args) \ do { if (_level < LOG_LEVEL) { g_writeln _args ; } } while (0) #define LHEXDUMP(_level, _args) \ do { if (_level < LOG_LEVEL) { g_hexdump _args ; } } while (0) /* some compilers need unsigned char to avoid warnings */ static tui8 g_pad_54[40] = { 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54 }; /* some compilers need unsigned char to avoid warnings */ static tui8 g_pad_92[48] = { 92, 92, 92, 92, 92, 92, 92, 92, 92, 92, 92, 92, 92, 92, 92, 92, 92, 92, 92, 92, 92, 92, 92, 92, 92, 92, 92, 92, 92, 92, 92, 92, 92, 92, 92, 92, 92, 92, 92, 92, 92, 92, 92, 92, 92, 92, 92, 92 }; /* some compilers need unsigned char to avoid warnings */ static tui8 g_lic1[322] = { 0x80, 0x00, 0x3e, 0x01, 0x01, 0x02, 0x3e, 0x01, 0x7b, 0x3c, 0x31, 0xa6, 0xae, 0xe8, 0x74, 0xf6, 0xb4, 0xa5, 0x03, 0x90, 0xe7, 0xc2, 0xc7, 0x39, 0xba, 0x53, 0x1c, 0x30, 0x54, 0x6e, 0x90, 0x05, 0xd0, 0x05, 0xce, 0x44, 0x18, 0x91, 0x83, 0x81, 0x00, 0x00, 0x04, 0x00, 0x2c, 0x00, 0x00, 0x00, 0x4d, 0x00, 0x69, 0x00, 0x63, 0x00, 0x72, 0x00, 0x6f, 0x00, 0x73, 0x00, 0x6f, 0x00, 0x66, 0x00, 0x74, 0x00, 0x20, 0x00, 0x43, 0x00, 0x6f, 0x00, 0x72, 0x00, 0x70, 0x00, 0x6f, 0x00, 0x72, 0x00, 0x61, 0x00, 0x74, 0x00, 0x69, 0x00, 0x6f, 0x00, 0x6e, 0x00, 0x00, 0x00, 0x08, 0x00, 0x00, 0x00, 0x32, 0x00, 0x33, 0x00, 0x36, 0x00, 0x00, 0x00, 0x0d, 0x00, 0x04, 0x00, 0x01, 0x00, 0x00, 0x00, 0x03, 0x00, 0xb8, 0x00, 0x01, 0x00, 0x00, 0x00, 0x01, 0x00, 0x00, 0x00, 0x01, 0x00, 0x00, 0x00, 0x06, 0x00, 0x5c, 0x00, 0x52, 0x53, 0x41, 0x31, 0x48, 0x00, 0x00, 0x00, 0x00, 0x02, 0x00, 0x00, 0x3f, 0x00, 0x00, 0x00, 0x01, 0x00, 0x01, 0x00, 0x01, 0xc7, 0xc9, 0xf7, 0x8e, 0x5a, 0x38, 0xe4, 0x29, 0xc3, 0x00, 0x95, 0x2d, 0xdd, 0x4c, 0x3e, 0x50, 0x45, 0x0b, 0x0d, 0x9e, 0x2a, 0x5d, 0x18, 0x63, 0x64, 0xc4, 0x2c, 0xf7, 0x8f, 0x29, 0xd5, 0x3f, 0xc5, 0x35, 0x22, 0x34, 0xff, 0xad, 0x3a, 0xe6, 0xe3, 0x95, 0x06, 0xae, 0x55, 0x82, 0xe3, 0xc8, 0xc7, 0xb4, 0xa8, 0x47, 0xc8, 0x50, 0x71, 0x74, 0x29, 0x53, 0x89, 0x6d, 0x9c, 0xed, 0x70, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x08, 0x00, 0x48, 0x00, 0xa8, 0xf4, 0x31, 0xb9, 0xab, 0x4b, 0xe6, 0xb4, 0xf4, 0x39, 0x89, 0xd6, 0xb1, 0xda, 0xf6, 0x1e, 0xec, 0xb1, 0xf0, 0x54, 0x3b, 0x5e, 0x3e, 0x6a, 0x71, 0xb4, 0xf7, 0x75, 0xc8, 0x16, 0x2f, 0x24, 0x00, 0xde, 0xe9, 0x82, 0x99, 0x5f, 0x33, 0x0b, 0xa9, 0xa6, 0x94, 0xaf, 0xcb, 0x11, 0xc3, 0xf2, 0xdb, 0x09, 0x42, 0x68, 0x29, 0x56, 0x58, 0x01, 0x56, 0xdb, 0x59, 0x03, 0x69, 0xdb, 0x7d, 0x37, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x01, 0x00, 0x00, 0x00, 0x0e, 0x00, 0x0e, 0x00, 0x6d, 0x69, 0x63, 0x72, 0x6f, 0x73, 0x6f, 0x66, 0x74, 0x2e, 0x63, 0x6f, 0x6d, 0x00 }; /* some compilers need unsigned char to avoid warnings */ static tui8 g_lic2[20] = { 0x80, 0x00, 0x10, 0x00, 0xff, 0x02, 0x10, 0x00, 0x07, 0x00, 0x00, 0x00, 0x02, 0x00, 0x00, 0x00, 0x28, 0x14, 0x00, 0x00 }; /* mce */ /* some compilers need unsigned char to avoid warnings */ static tui8 g_lic3[20] = { 0x80, 0x02, 0x10, 0x00, 0xff, 0x03, 0x10, 0x00, 0x07, 0x00, 0x00, 0x00, 0x02, 0x00, 0x00, 0x00, 0xf3, 0x99, 0x00, 0x00 }; static const tui8 g_fips_reverse_table[256] = { 0x00, 0x80, 0x40, 0xc0, 0x20, 0xa0, 0x60, 0xe0, 0x10, 0x90, 0x50, 0xd0, 0x30, 0xb0, 0x70, 0xf0, 0x08, 0x88, 0x48, 0xc8, 0x28, 0xa8, 0x68, 0xe8, 0x18, 0x98, 0x58, 0xd8, 0x38, 0xb8, 0x78, 0xf8, 0x04, 0x84, 0x44, 0xc4, 0x24, 0xa4, 0x64, 0xe4, 0x14, 0x94, 0x54, 0xd4, 0x34, 0xb4, 0x74, 0xf4, 0x0c, 0x8c, 0x4c, 0xcc, 0x2c, 0xac, 0x6c, 0xec, 0x1c, 0x9c, 0x5c, 0xdc, 0x3c, 0xbc, 0x7c, 0xfc, 0x02, 0x82, 0x42, 0xc2, 0x22, 0xa2, 0x62, 0xe2, 0x12, 0x92, 0x52, 0xd2, 0x32, 0xb2, 0x72, 0xf2, 0x0a, 0x8a, 0x4a, 0xca, 0x2a, 0xaa, 0x6a, 0xea, 0x1a, 0x9a, 0x5a, 0xda, 0x3a, 0xba, 0x7a, 0xfa, 0x06, 0x86, 0x46, 0xc6, 0x26, 0xa6, 0x66, 0xe6, 0x16, 0x96, 0x56, 0xd6, 0x36, 0xb6, 0x76, 0xf6, 0x0e, 0x8e, 0x4e, 0xce, 0x2e, 0xae, 0x6e, 0xee, 0x1e, 0x9e, 0x5e, 0xde, 0x3e, 0xbe, 0x7e, 0xfe, 0x01, 0x81, 0x41, 0xc1, 0x21, 0xa1, 0x61, 0xe1, 0x11, 0x91, 0x51, 0xd1, 0x31, 0xb1, 0x71, 0xf1, 0x09, 0x89, 0x49, 0xc9, 0x29, 0xa9, 0x69, 0xe9, 0x19, 0x99, 0x59, 0xd9, 0x39, 0xb9, 0x79, 0xf9, 0x05, 0x85, 0x45, 0xc5, 0x25, 0xa5, 0x65, 0xe5, 0x15, 0x95, 0x55, 0xd5, 0x35, 0xb5, 0x75, 0xf5, 0x0d, 0x8d, 0x4d, 0xcd, 0x2d, 0xad, 0x6d, 0xed, 0x1d, 0x9d, 0x5d, 0xdd, 0x3d, 0xbd, 0x7d, 0xfd, 0x03, 0x83, 0x43, 0xc3, 0x23, 0xa3, 0x63, 0xe3, 0x13, 0x93, 0x53, 0xd3, 0x33, 0xb3, 0x73, 0xf3, 0x0b, 0x8b, 0x4b, 0xcb, 0x2b, 0xab, 0x6b, 0xeb, 0x1b, 0x9b, 0x5b, 0xdb, 0x3b, 0xbb, 0x7b, 0xfb, 0x07, 0x87, 0x47, 0xc7, 0x27, 0xa7, 0x67, 0xe7, 0x17, 0x97, 0x57, 0xd7, 0x37, 0xb7, 0x77, 0xf7, 0x0f, 0x8f, 0x4f, 0xcf, 0x2f, 0xaf, 0x6f, 0xef, 0x1f, 0x9f, 0x5f, 0xdf, 0x3f, 0xbf, 0x7f, 0xff }; static const tui8 g_fips_oddparity_table[256] = { 0x01, 0x01, 0x02, 0x02, 0x04, 0x04, 0x07, 0x07, 0x08, 0x08, 0x0b, 0x0b, 0x0d, 0x0d, 0x0e, 0x0e, 0x10, 0x10, 0x13, 0x13, 0x15, 0x15, 0x16, 0x16, 0x19, 0x19, 0x1a, 0x1a, 0x1c, 0x1c, 0x1f, 0x1f, 0x20, 0x20, 0x23, 0x23, 0x25, 0x25, 0x26, 0x26, 0x29, 0x29, 0x2a, 0x2a, 0x2c, 0x2c, 0x2f, 0x2f, 0x31, 0x31, 0x32, 0x32, 0x34, 0x34, 0x37, 0x37, 0x38, 0x38, 0x3b, 0x3b, 0x3d, 0x3d, 0x3e, 0x3e, 0x40, 0x40, 0x43, 0x43, 0x45, 0x45, 0x46, 0x46, 0x49, 0x49, 0x4a, 0x4a, 0x4c, 0x4c, 0x4f, 0x4f, 0x51, 0x51, 0x52, 0x52, 0x54, 0x54, 0x57, 0x57, 0x58, 0x58, 0x5b, 0x5b, 0x5d, 0x5d, 0x5e, 0x5e, 0x61, 0x61, 0x62, 0x62, 0x64, 0x64, 0x67, 0x67, 0x68, 0x68, 0x6b, 0x6b, 0x6d, 0x6d, 0x6e, 0x6e, 0x70, 0x70, 0x73, 0x73, 0x75, 0x75, 0x76, 0x76, 0x79, 0x79, 0x7a, 0x7a, 0x7c, 0x7c, 0x7f, 0x7f, 0x80, 0x80, 0x83, 0x83, 0x85, 0x85, 0x86, 0x86, 0x89, 0x89, 0x8a, 0x8a, 0x8c, 0x8c, 0x8f, 0x8f, 0x91, 0x91, 0x92, 0x92, 0x94, 0x94, 0x97, 0x97, 0x98, 0x98, 0x9b, 0x9b, 0x9d, 0x9d, 0x9e, 0x9e, 0xa1, 0xa1, 0xa2, 0xa2, 0xa4, 0xa4, 0xa7, 0xa7, 0xa8, 0xa8, 0xab, 0xab, 0xad, 0xad, 0xae, 0xae, 0xb0, 0xb0, 0xb3, 0xb3, 0xb5, 0xb5, 0xb6, 0xb6, 0xb9, 0xb9, 0xba, 0xba, 0xbc, 0xbc, 0xbf, 0xbf, 0xc1, 0xc1, 0xc2, 0xc2, 0xc4, 0xc4, 0xc7, 0xc7, 0xc8, 0xc8, 0xcb, 0xcb, 0xcd, 0xcd, 0xce, 0xce, 0xd0, 0xd0, 0xd3, 0xd3, 0xd5, 0xd5, 0xd6, 0xd6, 0xd9, 0xd9, 0xda, 0xda, 0xdc, 0xdc, 0xdf, 0xdf, 0xe0, 0xe0, 0xe3, 0xe3, 0xe5, 0xe5, 0xe6, 0xe6, 0xe9, 0xe9, 0xea, 0xea, 0xec, 0xec, 0xef, 0xef, 0xf1, 0xf1, 0xf2, 0xf2, 0xf4, 0xf4, 0xf7, 0xf7, 0xf8, 0xf8, 0xfb, 0xfb, 0xfd, 0xfd, 0xfe, 0xfe }; static const tui8 g_fips_ivec[8] = { 0x12, 0x34, 0x56, 0x78, 0x90, 0xAB, 0xCD, 0xEF }; /*****************************************************************************/ static void hex_str_to_bin(char *in, char *out, int out_len) { int in_index; int in_len; int out_index; int val; char hex[16]; in_len = g_strlen(in); out_index = 0; in_index = 0; while (in_index <= (in_len - 4)) { if ((in[in_index] == '0') && (in[in_index + 1] == 'x')) { hex[0] = in[in_index + 2]; hex[1] = in[in_index + 3]; hex[2] = 0; if (out_index < out_len) { val = g_htoi(hex); out[out_index] = val; } out_index++; } in_index++; } } /*****************************************************************************/ static void xrdp_load_keyboard_layout(struct xrdp_client_info *client_info) { int fd; int index = 0; int bytes; struct list *names = (struct list *)NULL; struct list *items = (struct list *)NULL; struct list *values = (struct list *)NULL; char *item = (char *)NULL; char *value = (char *)NULL; char *q = (char *)NULL; char keyboard_cfg_file[256] = { 0 }; char rdp_layout[256] = { 0 }; LLOGLN(0, ("xrdp_load_keyboard_layout: keyboard_type [%d] keyboard_subtype [%d]", client_info->keyboard_type, client_info->keyboard_subtype)); /* infer model/variant */ /* TODO specify different X11 keyboard models/variants */ g_memset(client_info->model, 0, sizeof(client_info->model)); g_memset(client_info->variant, 0, sizeof(client_info->variant)); g_strncpy(client_info->layout, "us", sizeof(client_info->layout) - 1); if (client_info->keyboard_subtype == 3) { /* macintosh keyboard */ bytes = sizeof(client_info->variant); g_strncpy(client_info->variant, "mac", bytes - 1); } else if (client_info->keyboard_subtype == 0) { /* default - standard subtype */ client_info->keyboard_subtype = 1; } g_snprintf(keyboard_cfg_file, 255, "%s/xrdp_keyboard.ini", XRDP_CFG_PATH); LLOGLN(10, ("keyboard_cfg_file %s", keyboard_cfg_file)); fd = g_file_open(keyboard_cfg_file); if (fd > 0) { int section_found = -1; char section_rdp_layouts[256] = { 0 }; char section_layouts_map[256] = { 0 }; names = list_create(); names->auto_free = 1; items = list_create(); items->auto_free = 1; values = list_create(); values->auto_free = 1; file_read_sections(fd, names); for (index = 0; index < names->count; index++) { q = (char *)list_get_item(names, index); if (g_strncasecmp("default", q, 8) != 0) { int i; file_read_section(fd, q, items, values); for (i = 0; i < items->count; i++) { item = (char *)list_get_item(items, i); value = (char *)list_get_item(values, i); LLOGLN(10, ("xrdp_load_keyboard_layout: item %s value %s", item, value)); if (g_strcasecmp(item, "keyboard_type") == 0) { int v = g_atoi(value); if (v == client_info->keyboard_type) { section_found = index; } } else if (g_strcasecmp(item, "keyboard_subtype") == 0) { int v = g_atoi(value); if (v != client_info->keyboard_subtype && section_found == index) { section_found = -1; break; } } else if (g_strcasecmp(item, "rdp_layouts") == 0) { if (section_found != -1 && section_found == index) { g_strncpy(section_rdp_layouts, value, 255); } } else if (g_strcasecmp(item, "layouts_map") == 0) { if (section_found != -1 && section_found == index) { g_strncpy(section_layouts_map, value, 255); } } else if (g_strcasecmp(item, "model") == 0) { if (section_found != -1 && section_found == index) { bytes = sizeof(client_info->model); g_memset(client_info->model, 0, bytes); g_strncpy(client_info->model, value, bytes - 1); } } else if (g_strcasecmp(item, "variant") == 0) { if (section_found != -1 && section_found == index) { bytes = sizeof(client_info->variant); g_memset(client_info->variant, 0, bytes); g_strncpy(client_info->variant, value, bytes - 1); } } else if (g_strcasecmp(item, "options") == 0) { if (section_found != -1 && section_found == index) { bytes = sizeof(client_info->options); g_memset(client_info->options, 0, bytes); g_strncpy(client_info->options, value, bytes - 1); } } else { /* * mixing items from different sections will result in * skipping over current section. */ LLOGLN(10, ("xrdp_load_keyboard_layout: skipping " "configuration item - %s, continuing to next " "section", item)); break; } } list_clear(items); list_clear(values); } } if (section_found == -1) { g_memset(section_rdp_layouts, 0, sizeof(char) * 256); g_memset(section_layouts_map, 0, sizeof(char) * 256); // read default section file_read_section(fd, "default", items, values); for (index = 0; index < items->count; index++) { item = (char *)list_get_item(items, index); value = (char *)list_get_item(values, index); if (g_strcasecmp(item, "rdp_layouts") == 0) { g_strncpy(section_rdp_layouts, value, 255); } else if (g_strcasecmp(item, "layouts_map") == 0) { g_strncpy(section_layouts_map, value, 255); } } list_clear(items); list_clear(values); } /* load the map */ file_read_section(fd, section_rdp_layouts, items, values); for (index = 0; index < items->count; index++) { int rdp_layout_id; item = (char *)list_get_item(items, index); value = (char *)list_get_item(values, index); rdp_layout_id = g_htoi(value); if (rdp_layout_id == client_info->keylayout) { g_strncpy(rdp_layout, item, 255); break; } } list_clear(items); list_clear(values); file_read_section(fd, section_layouts_map, items, values); for (index = 0; index < items->count; index++) { item = (char *)list_get_item(items, index); value = (char *)list_get_item(values, index); if (g_strcasecmp(item, rdp_layout) == 0) { bytes = sizeof(client_info->layout); g_strncpy(client_info->layout, value, bytes - 1); break; } } list_delete(names); list_delete(items); list_delete(values); LLOGLN(0, ("xrdp_load_keyboard_layout: model [%s] variant [%s] " "layout [%s] options [%s]", client_info->model, client_info->variant, client_info->layout, client_info->options)); g_file_close(fd); } else { LLOGLN(0, ("xrdp_load_keyboard_layout: error opening %s", keyboard_cfg_file)); } } /*****************************************************************************/ struct xrdp_sec * xrdp_sec_create(struct xrdp_rdp *owner, struct trans *trans) { struct xrdp_sec *self; DEBUG((" in xrdp_sec_create")); self = (struct xrdp_sec *) g_malloc(sizeof(struct xrdp_sec), 1); self->rdp_layer = owner; self->crypt_method = CRYPT_METHOD_NONE; /* set later */ self->crypt_level = CRYPT_LEVEL_NONE; self->mcs_layer = xrdp_mcs_create(self, trans, &(self->client_mcs_data), &(self->server_mcs_data)); self->fastpath_layer = xrdp_fastpath_create(self, trans); self->chan_layer = xrdp_channel_create(self, self->mcs_layer); self->is_security_header_present = 1; DEBUG((" out xrdp_sec_create")); return self; } /*****************************************************************************/ void xrdp_sec_delete(struct xrdp_sec *self) { if (self == 0) { g_writeln("xrdp_sec_delete: self is null"); return; } xrdp_channel_delete(self->chan_layer); xrdp_mcs_delete(self->mcs_layer); xrdp_fastpath_delete(self->fastpath_layer); ssl_rc4_info_delete(self->decrypt_rc4_info); /* TODO clear all data */ ssl_rc4_info_delete(self->encrypt_rc4_info); /* TODO clear all data */ ssl_des3_info_delete(self->decrypt_fips_info); ssl_des3_info_delete(self->encrypt_fips_info); ssl_hmac_info_delete(self->sign_fips_info); g_free(self->client_mcs_data.data); g_free(self->server_mcs_data.data); /* Crypto information must always be cleared */ g_memset(self, 0, sizeof(struct xrdp_sec)); g_free(self); } /*****************************************************************************/ /* returns error */ int xrdp_sec_init(struct xrdp_sec *self, struct stream *s) { if (xrdp_mcs_init(self->mcs_layer, s) != 0) { return 1; } if (self->crypt_level > CRYPT_LEVEL_NONE) /* RDP encryption */ { if (self->crypt_level == CRYPT_LEVEL_FIPS) { s_push_layer(s, sec_hdr, 4 + 4 + 8); } else if (self->crypt_level > CRYPT_LEVEL_LOW) { s_push_layer(s, sec_hdr, 4 + 8); } else if (self->crypt_level) { s_push_layer(s, sec_hdr, 4); } } return 0; } /*****************************************************************************/ /* Reduce key entropy from 64 to 40 bits */ static void xrdp_sec_make_40bit(char *key) { key[0] = 0xd1; key[1] = 0x26; key[2] = 0x9e; } /*****************************************************************************/ /* returns error */ /* update an encryption key */ static int xrdp_sec_update(char *key, char *update_key, int key_len) { char shasig[20]; void *sha1_info; void *md5_info; void *rc4_info; sha1_info = ssl_sha1_info_create(); md5_info = ssl_md5_info_create(); rc4_info = ssl_rc4_info_create(); ssl_sha1_clear(sha1_info); ssl_sha1_transform(sha1_info, update_key, key_len); ssl_sha1_transform(sha1_info, (char *)g_pad_54, 40); ssl_sha1_transform(sha1_info, key, key_len); ssl_sha1_complete(sha1_info, shasig); ssl_md5_clear(md5_info); ssl_md5_transform(md5_info, update_key, key_len); ssl_md5_transform(md5_info, (char *)g_pad_92, 48); ssl_md5_transform(md5_info, shasig, 20); ssl_md5_complete(md5_info, key); ssl_rc4_set_key(rc4_info, key, key_len); ssl_rc4_crypt(rc4_info, key, key_len); if (key_len == 8) { xrdp_sec_make_40bit(key); } ssl_sha1_info_delete(sha1_info); ssl_md5_info_delete(md5_info); ssl_rc4_info_delete(rc4_info); return 0; } /*****************************************************************************/ static void xrdp_sec_fips_decrypt(struct xrdp_sec *self, char *data, int len) { LLOGLN(10, ("xrdp_sec_fips_decrypt:")); ssl_des3_decrypt(self->decrypt_fips_info, len, data, data); self->decrypt_use_count++; } /*****************************************************************************/ static void xrdp_sec_decrypt(struct xrdp_sec *self, char *data, int len) { LLOGLN(10, ("xrdp_sec_decrypt:")); if (self->decrypt_use_count == 4096) { xrdp_sec_update(self->decrypt_key, self->decrypt_update_key, self->rc4_key_len); ssl_rc4_set_key(self->decrypt_rc4_info, self->decrypt_key, self->rc4_key_len); self->decrypt_use_count = 0; } ssl_rc4_crypt(self->decrypt_rc4_info, data, len); self->decrypt_use_count++; } /*****************************************************************************/ static void xrdp_sec_fips_encrypt(struct xrdp_sec *self, char *data, int len) { LLOGLN(10, ("xrdp_sec_fips_encrypt:")); ssl_des3_encrypt(self->encrypt_fips_info, len, data, data); self->encrypt_use_count++; } /*****************************************************************************/ static void xrdp_sec_encrypt(struct xrdp_sec *self, char *data, int len) { LLOGLN(10, ("xrdp_sec_encrypt:")); if (self->encrypt_use_count == 4096) { xrdp_sec_update(self->encrypt_key, self->encrypt_update_key, self->rc4_key_len); ssl_rc4_set_key(self->encrypt_rc4_info, self->encrypt_key, self->rc4_key_len); self->encrypt_use_count = 0; } ssl_rc4_crypt(self->encrypt_rc4_info, data, len); self->encrypt_use_count++; } /***************************************************************************** * convert utf-16 encoded string from stream into utf-8 string. * note: src_bytes doesn't include the null-terminator char. */ static int unicode_utf16_in(struct stream *s, int src_bytes, char *dst, int dst_len) { twchar *src; int num_chars; int i; int bytes; LLOGLN(10, ("unicode_utf16_in: uni_len %d, dst_len %d", src_bytes, dst_len)); if (src_bytes == 0) { if (!s_check_rem(s, 2)) { return 1; } in_uint8s(s, 2); /* null terminator */ return 0; } bytes = src_bytes + 2; /* include the null terminator */ src = g_new0(twchar, bytes); for (i = 0; i < bytes / 2; ++i) { if (!s_check_rem(s, 2)) { g_free(src); return 1; } in_uint16_le(s, src[i]); } num_chars = g_wcstombs(dst, src, dst_len); if (num_chars < 0) { g_memset(dst, '\0', dst_len); } LLOGLN(10, ("unicode_utf16_in: num_chars %d, dst %s", num_chars, dst)); g_free(src); return 0; } /*****************************************************************************/ /* returns error */ static int xrdp_sec_process_logon_info(struct xrdp_sec *self, struct stream *s) { int flags = 0; int len_domain = 0; int len_user = 0; int len_password = 0; int len_program = 0; int len_directory = 0; int len_ip = 0; int len_dll = 0; char tmpdata[256]; /* initialize (zero out) local variables */ g_memset(tmpdata, 0, sizeof(char) * 256); if (!s_check_rem(s, 8)) { return 1; } in_uint8s(s, 4); in_uint32_le(s, flags); DEBUG(("in xrdp_sec_process_logon_info flags $%x", flags)); /* this is the first test that the decrypt is working */ if ((flags & RDP_LOGON_NORMAL) != RDP_LOGON_NORMAL) /* 0x33 */ { /* must be or error */ DEBUG(("xrdp_sec_process_logon_info: flags wrong, major error")); LLOGLN(0, ("xrdp_sec_process_logon_info: flags wrong, likely decrypt " "not working")); return 1; } if (flags & RDP_LOGON_LEAVE_AUDIO) { self->rdp_layer->client_info.sound_code = 1; DEBUG(("flag RDP_LOGON_LEAVE_AUDIO found")); } if ((flags & RDP_LOGON_AUTO) && (!self->rdp_layer->client_info.is_mce)) /* todo, for now not allowing autologon and mce both */ { self->rdp_layer->client_info.rdp_autologin = 1; DEBUG(("flag RDP_LOGON_AUTO found")); } if (flags & RDP_COMPRESSION) { DEBUG(("flag RDP_COMPRESSION found")); if (self->rdp_layer->client_info.use_bulk_comp) { DEBUG(("flag RDP_COMPRESSION set")); self->rdp_layer->client_info.rdp_compression = 1; } else { DEBUG(("flag RDP_COMPRESSION not set")); } } if (!s_check_rem(s, 2)) { return 1; } in_uint16_le(s, len_domain); if (len_domain > 511) { DEBUG(("ERROR [xrdp_sec_process_logon_info()]: len_domain > 511")); return 1; } if (!s_check_rem(s, 2)) { return 1; } in_uint16_le(s, len_user); /* * Microsoft's itap client running on Mac OS/Android * always sends autologon credentials, even when user has not * configured any */ if (len_user == 0) { self->rdp_layer->client_info.rdp_autologin = 0; } if (len_user > 511) { DEBUG(("ERROR [xrdp_sec_process_logon_info()]: len_user > 511")); return 1; } if (!s_check_rem(s, 2)) { return 1; } in_uint16_le(s, len_password); if (len_password > 511) { DEBUG(("ERROR [xrdp_sec_process_logon_info()]: len_password > 511")); return 1; } if (!s_check_rem(s, 2)) { return 1; } in_uint16_le(s, len_program); if (len_program > 511) { DEBUG(("ERROR [xrdp_sec_process_logon_info()]: len_program > 511")); return 1; } if (!s_check_rem(s, 2)) { return 1; } in_uint16_le(s, len_directory); if (len_directory > 511) { DEBUG(("ERROR [xrdp_sec_process_logon_info()]: len_directory > 511")); return 1; } if (unicode_utf16_in(s, len_domain, self->rdp_layer->client_info.domain, sizeof(self->rdp_layer->client_info.domain) - 1) != 0) { return 1; } DEBUG(("domain %s", self->rdp_layer->client_info.domain)); if (unicode_utf16_in(s, len_user, self->rdp_layer->client_info.username, sizeof(self->rdp_layer->client_info.username) - 1) != 0) { return 1; } DEBUG(("username %s", self->rdp_layer->client_info.username)); if (flags & RDP_LOGON_AUTO) { if (unicode_utf16_in(s, len_password, self->rdp_layer->client_info.password, sizeof(self->rdp_layer->client_info.password) - 1) != 0) { return 1; } DEBUG(("flag RDP_LOGON_AUTO found")); } else { if (!s_check_rem(s, len_password + 2)) { return 1; } in_uint8s(s, len_password + 2); if (self->rdp_layer->client_info.require_credentials) { g_writeln("xrdp_sec_process_logon_info: credentials on cmd line is mandatory"); return 1; /* credentials on cmd line is mandatory */ } } if (unicode_utf16_in(s, len_program, self->rdp_layer->client_info.program, sizeof(self->rdp_layer->client_info.program) - 1) != 0) { return 1; } DEBUG(("program %s", self->rdp_layer->client_info.program)); if (unicode_utf16_in(s, len_directory, self->rdp_layer->client_info.directory, sizeof(self->rdp_layer->client_info.directory) - 1) != 0) { return 1; } DEBUG(("directory %s", self->rdp_layer->client_info.directory)); if (flags & RDP_LOGON_BLOB) { if (!s_check_rem(s, 4)) { return 1; } in_uint8s(s, 2); /* unknown */ in_uint16_le(s, len_ip); if (unicode_utf16_in(s, len_ip - 2, tmpdata, sizeof(tmpdata) - 1) != 0) { return 1; } if (!s_check_rem(s, 2)) { return 1; } in_uint16_le(s, len_dll); if (unicode_utf16_in(s, len_dll - 2, tmpdata, sizeof(tmpdata) - 1) != 0) { return 1; } if (!s_check_rem(s, 4 + 62 + 22 + 62 + 26 + 4)) { return 1; } in_uint8s(s, 4); /* len of timezone */ in_uint8s(s, 62); /* skip */ in_uint8s(s, 22); /* skip misc. */ in_uint8s(s, 62); /* skip */ in_uint8s(s, 26); /* skip stuff */ in_uint32_le(s, self->rdp_layer->client_info.rdp5_performanceflags); } DEBUG(("out xrdp_sec_process_logon_info")); return 0; } /*****************************************************************************/ /* returns error */ static int xrdp_sec_send_lic_initial(struct xrdp_sec *self) { struct stream *s; LLOGLN(10, ("xrdp_sec_send_lic_initial:")); make_stream(s); init_stream(s, 8192); if (xrdp_mcs_init(self->mcs_layer, s) != 0) { free_stream(s); return 1; } out_uint8a(s, g_lic1, 322); s_mark_end(s); if (xrdp_mcs_send(self->mcs_layer, s, MCS_GLOBAL_CHANNEL) != 0) { free_stream(s); return 1; } free_stream(s); return 0; } /*****************************************************************************/ /* returns error */ static int xrdp_sec_send_lic_response(struct xrdp_sec *self) { struct stream *s; make_stream(s); init_stream(s, 8192); if (xrdp_mcs_init(self->mcs_layer, s) != 0) { free_stream(s); return 1; } out_uint8a(s, g_lic2, 20); s_mark_end(s); if (xrdp_mcs_send(self->mcs_layer, s, MCS_GLOBAL_CHANNEL) != 0) { free_stream(s); return 1; } free_stream(s); return 0; } /*****************************************************************************/ /* returns error */ static int xrdp_sec_send_media_lic_response(struct xrdp_sec *self) { struct stream *s; make_stream(s); init_stream(s, 8192); if (xrdp_mcs_init(self->mcs_layer, s) != 0) { free_stream(s); return 1; } out_uint8a(s, g_lic3, sizeof(g_lic3)); s_mark_end(s); if (xrdp_mcs_send(self->mcs_layer, s, MCS_GLOBAL_CHANNEL) != 0) { free_stream(s); return 1; } free_stream(s); return 0; } /*****************************************************************************/ static void xrdp_sec_rsa_op(struct xrdp_sec *self, char *out, char *in, int in_bytes, char *mod, char *exp) { ssl_mod_exp(out, self->rsa_key_bytes, in, in_bytes, mod, self->rsa_key_bytes, exp, self->rsa_key_bytes); } /*****************************************************************************/ static void xrdp_sec_hash_48(char *out, char *in, char *salt1, char *salt2, int salt) { int i; void *sha1_info; void *md5_info; char pad[4]; char sha1_sig[20]; char md5_sig[16]; sha1_info = ssl_sha1_info_create(); md5_info = ssl_md5_info_create(); for (i = 0; i < 3; i++) { g_memset(pad, salt + i, 4); ssl_sha1_clear(sha1_info); ssl_sha1_transform(sha1_info, pad, i + 1); ssl_sha1_transform(sha1_info, in, 48); ssl_sha1_transform(sha1_info, salt1, 32); ssl_sha1_transform(sha1_info, salt2, 32); ssl_sha1_complete(sha1_info, sha1_sig); ssl_md5_clear(md5_info); ssl_md5_transform(md5_info, in, 48); ssl_md5_transform(md5_info, sha1_sig, 20); ssl_md5_complete(md5_info, md5_sig); g_memcpy(out + i * 16, md5_sig, 16); } ssl_sha1_info_delete(sha1_info); ssl_md5_info_delete(md5_info); } /*****************************************************************************/ static void xrdp_sec_hash_16(char *out, char *in, char *salt1, char *salt2) { void *md5_info; md5_info = ssl_md5_info_create(); ssl_md5_clear(md5_info); ssl_md5_transform(md5_info, in, 16); ssl_md5_transform(md5_info, salt1, 32); ssl_md5_transform(md5_info, salt2, 32); ssl_md5_complete(md5_info, out); ssl_md5_info_delete(md5_info); } /*****************************************************************************/ static void fips_expand_key_bits(const char *in, char *out) { tui8 buf[32]; tui8 c; int i; int b; int p; int r; /* reverse every byte in the key */ for (i = 0; i < 21; i++) { c = in[i]; buf[i] = g_fips_reverse_table[c]; } /* insert a zero-bit after every 7th bit */ for (i = 0, b = 0; i < 24; i++, b += 7) { p = b / 8; r = b % 8; if (r == 0) { out[i] = buf[p] & 0xfe; } else { /* c is accumulator */ c = buf[p] << r; c |= buf[p + 1] >> (8 - r); out[i] = c & 0xfe; } } /* reverse every byte */ /* alter lsb so the byte has odd parity */ for (i = 0; i < 24; i++) { c = out[i]; c = g_fips_reverse_table[c]; out[i] = g_fips_oddparity_table[c]; } } /****************************************************************************/ static void xrdp_sec_fips_establish_keys(struct xrdp_sec *self) { char server_encrypt_key[32]; char server_decrypt_key[32]; const char *fips_ivec; void *sha1; LLOGLN(0, ("xrdp_sec_fips_establish_keys:")); sha1 = ssl_sha1_info_create(); ssl_sha1_clear(sha1); ssl_sha1_transform(sha1, self->client_random + 16, 16); ssl_sha1_transform(sha1, self->server_random + 16, 16); ssl_sha1_complete(sha1, server_decrypt_key); server_decrypt_key[20] = server_decrypt_key[0]; fips_expand_key_bits(server_decrypt_key, self->fips_decrypt_key); ssl_sha1_info_delete(sha1); sha1 = ssl_sha1_info_create(); ssl_sha1_clear(sha1); ssl_sha1_transform(sha1, self->client_random, 16); ssl_sha1_transform(sha1, self->server_random, 16); ssl_sha1_complete(sha1, server_encrypt_key); server_encrypt_key[20] = server_encrypt_key[0]; fips_expand_key_bits(server_encrypt_key, self->fips_encrypt_key); ssl_sha1_info_delete(sha1); sha1 = ssl_sha1_info_create(); ssl_sha1_clear(sha1); ssl_sha1_transform(sha1, server_encrypt_key, 20); ssl_sha1_transform(sha1, server_decrypt_key, 20); ssl_sha1_complete(sha1, self->fips_sign_key); ssl_sha1_info_delete(sha1); fips_ivec = (const char *) g_fips_ivec; self->encrypt_fips_info = ssl_des3_encrypt_info_create(self->fips_encrypt_key, fips_ivec); self->decrypt_fips_info = ssl_des3_decrypt_info_create(self->fips_decrypt_key, fips_ivec); self->sign_fips_info = ssl_hmac_info_create(); } /****************************************************************************/ static void xrdp_sec_establish_keys(struct xrdp_sec *self) { char session_key[48]; char temp_hash[48]; char input[48]; LLOGLN(0, ("xrdp_sec_establish_keys:")); g_memcpy(input, self->client_random, 24); g_memcpy(input + 24, self->server_random, 24); xrdp_sec_hash_48(temp_hash, input, self->client_random, self->server_random, 65); xrdp_sec_hash_48(session_key, temp_hash, self->client_random, self->server_random, 88); g_memcpy(self->sign_key, session_key, 16); xrdp_sec_hash_16(self->encrypt_key, session_key + 16, self->client_random, self->server_random); xrdp_sec_hash_16(self->decrypt_key, session_key + 32, self->client_random, self->server_random); if (self->crypt_method == CRYPT_METHOD_40BIT) { xrdp_sec_make_40bit(self->sign_key); xrdp_sec_make_40bit(self->encrypt_key); xrdp_sec_make_40bit(self->decrypt_key); self->rc4_key_len = 8; } else { self->rc4_key_len = 16; } g_memcpy(self->decrypt_update_key, self->decrypt_key, 16); g_memcpy(self->encrypt_update_key, self->encrypt_key, 16); ssl_rc4_set_key(self->decrypt_rc4_info, self->decrypt_key, self->rc4_key_len); ssl_rc4_set_key(self->encrypt_rc4_info, self->encrypt_key, self->rc4_key_len); } /*****************************************************************************/ /* returns error */ int xrdp_sec_recv_fastpath(struct xrdp_sec *self, struct stream *s) { int ver; int len; int pad; LLOGLN(10, ("xrdp_sec_recv_fastpath:")); if (xrdp_fastpath_recv(self->fastpath_layer, s) != 0) { return 1; } if (self->fastpath_layer->secFlags & FASTPATH_INPUT_ENCRYPTED) { if (self->crypt_level == CRYPT_LEVEL_FIPS) { if (!s_check_rem(s, 12)) { return 1; } in_uint16_le(s, len); in_uint8(s, ver); /* length (2 bytes) */ if (len != 0x10) /* length MUST set to 0x10 */ { return 1; } in_uint8(s, pad); LLOGLN(10, ("xrdp_sec_recv_fastpath: len %d ver %d pad %d", len, ver, pad)); in_uint8s(s, 8); /* dataSignature (8 bytes), skip for now */ LLOGLN(10, ("xrdp_sec_recv_fastpath: data len %d", (int)(s->end - s->p))); xrdp_sec_fips_decrypt(self, s->p, (int)(s->end - s->p)); s->end -= pad; } else { if (!s_check_rem(s, 8)) { return 1; } in_uint8s(s, 8); /* dataSignature (8 bytes), skip for now */ xrdp_sec_decrypt(self, s->p, (int)(s->end - s->p)); } } if (self->fastpath_layer->numEvents == 0) { /** * If numberEvents is not provided in fpInputHeader, it will be provided * as one additional byte here. */ if (!s_check_rem(s, 8)) { return 1; } in_uint8(s, self->fastpath_layer->numEvents); /* numEvents (1 byte) (optional) */ } return 0; } /*****************************************************************************/ /* returns error */ int xrdp_sec_recv(struct xrdp_sec *self, struct stream *s, int *chan) { int flags; int len; int ver; int pad; DEBUG((" in xrdp_sec_recv")); if (xrdp_mcs_recv(self->mcs_layer, s, chan) != 0) { DEBUG((" out xrdp_sec_recv : error")); g_writeln("xrdp_sec_recv: xrdp_mcs_recv failed"); return 1; } if (!s_check_rem(s, 4)) { return 1; } if (!(self->is_security_header_present)) { return 0; } in_uint32_le(s, flags); DEBUG((" in xrdp_sec_recv flags $%x", flags)); if (flags & SEC_ENCRYPT) /* 0x08 */ { if (self->crypt_level == CRYPT_LEVEL_FIPS) { if (!s_check_rem(s, 12)) { return 1; } in_uint16_le(s, len); in_uint8(s, ver); if ((len != 16) || (ver != 1)) { return 1; } in_uint8(s, pad); LLOGLN(10, ("xrdp_sec_recv: len %d ver %d pad %d", len, ver, pad)); in_uint8s(s, 8); /* signature(8) */ LLOGLN(10, ("xrdp_sec_recv: data len %d", (int)(s->end - s->p))); xrdp_sec_fips_decrypt(self, s->p, (int)(s->end - s->p)); s->end -= pad; } else if (self->crypt_level > CRYPT_LEVEL_NONE) { if (!s_check_rem(s, 8)) { return 1; } in_uint8s(s, 8); /* signature(8) */ xrdp_sec_decrypt(self, s->p, (int)(s->end - s->p)); } } if (flags & SEC_CLIENT_RANDOM) /* 0x01 */ { if (!s_check_rem(s, 4)) { return 1; } in_uint32_le(s, len); /* 512, 2048 bit */ if ((len != 64 + 8) && (len != 256 + 8)) { return 1; } if (!s_check_rem(s, len - 8)) { return 1; } in_uint8a(s, self->client_crypt_random, len - 8); xrdp_sec_rsa_op(self, self->client_random, self->client_crypt_random, len - 8, self->pub_mod, self->pri_exp); LLOGLN(10, ("xrdp_sec_recv: client random - len %d", len)); LHEXDUMP(10, (self->client_random, 256)); LHEXDUMP(10, (self->client_crypt_random, len - 8)); if (self->crypt_level == CRYPT_LEVEL_FIPS) { xrdp_sec_fips_establish_keys(self); } else if (self->crypt_method != CRYPT_METHOD_NONE) { xrdp_sec_establish_keys(self); } *chan = 1; /* just set a non existing channel and exit */ DEBUG((" out xrdp_sec_recv")); return 0; } if (flags & SEC_LOGON_INFO) /* 0x40 */ { if (xrdp_sec_process_logon_info(self, s) != 0) { DEBUG((" out xrdp_sec_recv error")); return 1; } if (self->rdp_layer->client_info.is_mce) { if (xrdp_sec_send_media_lic_response(self) != 0) { DEBUG((" out xrdp_sec_recv error")); return 1; } DEBUG((" out xrdp_sec_recv")); return -1; /* special error that means send demand active */ } if (xrdp_sec_send_lic_initial(self) != 0) { DEBUG((" out xrdp_sec_recv error")); return 1; } *chan = 1; /* just set a non existing channel and exit */ DEBUG((" out xrdp_sec_recv")); return 0; } if (flags & SEC_LICENCE_NEG) /* 0x80 */ { if (xrdp_sec_send_lic_response(self) != 0) { DEBUG((" out xrdp_sec_recv error")); return 1; } if (self->crypt_level == CRYPT_LEVEL_NONE && self->crypt_method == CRYPT_METHOD_NONE) { /* in tls mode, no more security header from now on */ self->is_security_header_present = 0; } DEBUG((" out xrdp_sec_recv")); return -1; /* special error that means send demand active */ } DEBUG((" out xrdp_sec_recv")); return 0; } /*****************************************************************************/ /* Output a uint32 into a buffer (little-endian) */ static void buf_out_uint32(char *buffer, int value) { buffer[0] = (value) & 0xff; buffer[1] = (value >> 8) & 0xff; buffer[2] = (value >> 16) & 0xff; buffer[3] = (value >> 24) & 0xff; } /*****************************************************************************/ /* Generate a MAC hash (5.2.3.1), using a combination of SHA1 and MD5 */ static void xrdp_sec_fips_sign(struct xrdp_sec *self, char *out, int out_len, char *data, int data_len) { char buf[20]; char lenhdr[4]; buf_out_uint32(lenhdr, self->encrypt_use_count); ssl_hmac_sha1_init(self->sign_fips_info, self->fips_sign_key, 20); ssl_hmac_transform(self->sign_fips_info, data, data_len); ssl_hmac_transform(self->sign_fips_info, lenhdr, 4); ssl_hmac_complete(self->sign_fips_info, buf, 20); g_memcpy(out, buf, out_len); } /*****************************************************************************/ /* Generate a MAC hash (5.2.3.1), using a combination of SHA1 and MD5 */ static void xrdp_sec_sign(struct xrdp_sec *self, char *out, int out_len, char *data, int data_len) { char shasig[20]; char md5sig[16]; char lenhdr[4]; void *sha1_info; void *md5_info; buf_out_uint32(lenhdr, data_len); sha1_info = ssl_sha1_info_create(); md5_info = ssl_md5_info_create(); ssl_sha1_clear(sha1_info); ssl_sha1_transform(sha1_info, self->sign_key, self->rc4_key_len); ssl_sha1_transform(sha1_info, (char *)g_pad_54, 40); ssl_sha1_transform(sha1_info, lenhdr, 4); ssl_sha1_transform(sha1_info, data, data_len); ssl_sha1_complete(sha1_info, shasig); ssl_md5_clear(md5_info); ssl_md5_transform(md5_info, self->sign_key, self->rc4_key_len); ssl_md5_transform(md5_info, (char *)g_pad_92, 48); ssl_md5_transform(md5_info, shasig, 20); ssl_md5_complete(md5_info, md5sig); g_memcpy(out, md5sig, out_len); ssl_sha1_info_delete(sha1_info); ssl_md5_info_delete(md5_info); } /*****************************************************************************/ /* returns error */ int xrdp_sec_send(struct xrdp_sec *self, struct stream *s, int chan) { int datalen; int pad; LLOGLN(10, ("xrdp_sec_send:")); DEBUG((" in xrdp_sec_send")); s_pop_layer(s, sec_hdr); if (self->crypt_level > CRYPT_LEVEL_NONE) { if (self->crypt_level == CRYPT_LEVEL_FIPS) { LLOGLN(10, ("xrdp_sec_send: fips")); out_uint32_le(s, SEC_ENCRYPT); datalen = (int)((s->end - s->p) - 12); out_uint16_le(s, 16); /* crypto header size */ out_uint8(s, 1); /* fips version */ pad = (8 - (datalen % 8)) & 7; g_memset(s->end, 0, pad); s->end += pad; out_uint8(s, pad); /* fips pad */ xrdp_sec_fips_sign(self, s->p, 8, s->p + 8, datalen); xrdp_sec_fips_encrypt(self, s->p + 8, datalen + pad); } else if (self->crypt_level > CRYPT_LEVEL_LOW) { out_uint32_le(s, SEC_ENCRYPT); datalen = (int)((s->end - s->p) - 8); xrdp_sec_sign(self, s->p, 8, s->p + 8, datalen); xrdp_sec_encrypt(self, s->p + 8, datalen); } else { out_uint32_le(s, 0); } } if (xrdp_mcs_send(self->mcs_layer, s, chan) != 0) { return 1; } DEBUG((" out xrdp_sec_send")); return 0; } /*****************************************************************************/ /* returns the fastpath sec byte count */ int xrdp_sec_get_fastpath_bytes(struct xrdp_sec *self) { if (self->crypt_level == CRYPT_LEVEL_FIPS) { return 3 + 4 + 8; } else if (self->crypt_level > CRYPT_LEVEL_LOW) { return 3 + 8; } return 3; } /*****************************************************************************/ /* returns error */ int xrdp_sec_init_fastpath(struct xrdp_sec *self, struct stream *s) { if (xrdp_fastpath_init(self->fastpath_layer, s) != 0) { return 1; } if (self->crypt_level == CRYPT_LEVEL_FIPS) { s_push_layer(s, sec_hdr, 3 + 4 + 8); } else if (self->crypt_level > CRYPT_LEVEL_LOW) { s_push_layer(s, sec_hdr, 3 + 8); } else { s_push_layer(s, sec_hdr, 3); } return 0; } /*****************************************************************************/ /* returns error */ /* 2.2.9.1.2 Server Fast-Path Update PDU (TS_FP_UPDATE_PDU) * http://msdn.microsoft.com/en-us/library/cc240621.aspx */ int xrdp_sec_send_fastpath(struct xrdp_sec *self, struct stream *s) { int secFlags; int fpOutputHeader; int datalen; int pdulen; int pad; int error; char save[8]; LLOGLN(10, ("xrdp_sec_send_fastpath:")); error = 0; s_pop_layer(s, sec_hdr); if (self->crypt_level == CRYPT_LEVEL_FIPS) { LLOGLN(10, ("xrdp_sec_send_fastpath: fips")); pdulen = (int)(s->end - s->p); datalen = pdulen - 15; pad = (8 - (datalen % 8)) & 7; secFlags = 0x2; fpOutputHeader = secFlags << 6; out_uint8(s, fpOutputHeader); pdulen += pad; pdulen |= 0x8000; out_uint16_be(s, pdulen); out_uint16_le(s, 16); /* crypto header size */ out_uint8(s, 1); /* fips version */ s->end += pad; out_uint8(s, pad); /* fips pad */ xrdp_sec_fips_sign(self, s->p, 8, s->p + 8, datalen); g_memcpy(save, s->p + 8 + datalen, pad); g_memset(s->p + 8 + datalen, 0, pad); xrdp_sec_fips_encrypt(self, s->p + 8, datalen + pad); error = xrdp_fastpath_send(self->fastpath_layer, s); g_memcpy(s->p + 8 + datalen, save, pad); } else if (self->crypt_level > CRYPT_LEVEL_LOW) { LLOGLN(10, ("xrdp_sec_send_fastpath: crypt")); pdulen = (int)(s->end - s->p); datalen = pdulen - 11; secFlags = 0x2; fpOutputHeader = secFlags << 6; out_uint8(s, fpOutputHeader); pdulen |= 0x8000; out_uint16_be(s, pdulen); xrdp_sec_sign(self, s->p, 8, s->p + 8, datalen); xrdp_sec_encrypt(self, s->p + 8, datalen); error = xrdp_fastpath_send(self->fastpath_layer, s); } else { LLOGLN(10, ("xrdp_sec_send_fastpath: no crypt")); pdulen = (int)(s->end - s->p); LLOGLN(10, ("xrdp_sec_send_fastpath: pdulen %d", pdulen)); secFlags = 0x0; fpOutputHeader = secFlags << 6; out_uint8(s, fpOutputHeader); pdulen |= 0x8000; out_uint16_be(s, pdulen); error = xrdp_fastpath_send(self->fastpath_layer, s); } if (error != 0) { return 1; } return 0; } /*****************************************************************************/ /* http://msdn.microsoft.com/en-us/library/cc240510.aspx 2.2.1.3.2 Client Core Data (TS_UD_CS_CORE) */ static int xrdp_sec_process_mcs_data_CS_CORE(struct xrdp_sec* self, struct stream* s) { int colorDepth; int postBeta2ColorDepth; int highColorDepth; int supportedColorDepths; int earlyCapabilityFlags; char clientName[INFO_CLIENT_NAME_BYTES / 2] = { '\0' }; in_uint8s(s, 4); /* version */ in_uint16_le(s, self->rdp_layer->client_info.width); in_uint16_le(s, self->rdp_layer->client_info.height); in_uint16_le(s, colorDepth); g_writeln("colorDepth 0x%4.4x (0xca00 4bpp 0xca01 8bpp)", colorDepth); switch (colorDepth) { case RNS_UD_COLOR_4BPP: self->rdp_layer->client_info.bpp = 4; break; case RNS_UD_COLOR_8BPP: self->rdp_layer->client_info.bpp = 8; break; } in_uint8s(s, 2); /* SASSequence */ in_uint8s(s, 4); /* keyboardLayout */ in_uint8s(s, 4); /* clientBuild */ unicode_utf16_in(s, INFO_CLIENT_NAME_BYTES - 2, clientName, sizeof(clientName) - 1); /* clientName */ log_message(LOG_LEVEL_INFO, "connected client computer name: %s", clientName); in_uint8s(s, 4); /* keyboardType */ in_uint8s(s, 4); /* keyboardSubType */ in_uint8s(s, 4); /* keyboardFunctionKey */ in_uint8s(s, 64); /* imeFileName */ in_uint16_le(s, postBeta2ColorDepth); g_writeln("postBeta2ColorDepth 0x%4.4x (0xca00 4bpp 0xca01 8bpp " "0xca02 15bpp 0xca03 16bpp 0xca04 24bpp)", postBeta2ColorDepth); switch (postBeta2ColorDepth) { case RNS_UD_COLOR_4BPP: self->rdp_layer->client_info.bpp = 4; break; case RNS_UD_COLOR_8BPP : self->rdp_layer->client_info.bpp = 8; break; case RNS_UD_COLOR_16BPP_555: self->rdp_layer->client_info.bpp = 15; break; case RNS_UD_COLOR_16BPP_565: self->rdp_layer->client_info.bpp = 16; break; case RNS_UD_COLOR_24BPP: self->rdp_layer->client_info.bpp = 24; break; } if (!s_check_rem(s, 2)) { return 0; } in_uint8s(s, 2); /* clientProductId */ if (!s_check_rem(s, 4)) { return 0; } in_uint8s(s, 4); /* serialNumber */ if (!s_check_rem(s, 2)) { return 0; } in_uint16_le(s, highColorDepth); g_writeln("highColorDepth 0x%4.4x (0x0004 4bpp 0x0008 8bpp 0x000f 15bpp " "0x0010 16 bpp 0x0018 24bpp)", highColorDepth); self->rdp_layer->client_info.bpp = highColorDepth; if (!s_check_rem(s, 2)) { return 0; } in_uint16_le(s, supportedColorDepths); g_writeln("supportedColorDepths 0x%4.4x (0x0001 24bpp 0x0002 16bpp " "0x0004 15bpp 0x0008 32bpp)", supportedColorDepths); if (!s_check_rem(s, 2)) { return 0; } in_uint16_le(s, earlyCapabilityFlags); self->rdp_layer->client_info.mcs_early_capability_flags = earlyCapabilityFlags; g_writeln("earlyCapabilityFlags 0x%4.4x (0x0002 want32)", earlyCapabilityFlags); if ((earlyCapabilityFlags & 0x0002) && (supportedColorDepths & 0x0008)) { self->rdp_layer->client_info.bpp = 32; } if (!s_check_rem(s, 64)) { return 0; } in_uint8s(s, 64); /* clientDigProductId */ if (!s_check_rem(s, 1)) { return 0; } in_uint8(s, self->rdp_layer->client_info.mcs_connection_type); /* connectionType */ g_writeln("got client client connection type 0x%8.8x", self->rdp_layer->client_info.mcs_connection_type); if (!s_check_rem(s, 1)) { return 0; } in_uint8s(s, 1); /* pad1octet */ if (!s_check_rem(s, 4)) { return 0; } in_uint8s(s, 4); /* serverSelectedProtocol */ if (!s_check_rem(s, 4)) { return 0; } in_uint8s(s, 4); /* desktopPhysicalWidth */ if (!s_check_rem(s, 4)) { return 0; } in_uint8s(s, 4); /* desktopPhysicalHeight */ if (!s_check_rem(s, 2)) { return 0; } in_uint8s(s, 2); /* reserved */ return 0; } /*****************************************************************************/ static int xrdp_sec_process_mcs_data_CS_SECURITY(struct xrdp_sec *self, struct stream* s) { int crypt_method; int found; g_writeln("xrdp_sec_process_mcs_data_CS_SECURITY:"); in_uint32_le(s, crypt_method); if (crypt_method & CRYPT_METHOD_40BIT) { g_writeln(" client supports 40 bit encryption"); } if (crypt_method & CRYPT_METHOD_128BIT) { g_writeln(" client supports 128 bit encryption"); } if (crypt_method & CRYPT_METHOD_56BIT) { g_writeln(" client supports 56 bit encryption"); } if (crypt_method & CRYPT_METHOD_FIPS) { g_writeln(" client supports fips encryption"); } found = 0; if ((found == 0) && (self->crypt_method & CRYPT_METHOD_FIPS) && (self->crypt_level == CRYPT_LEVEL_FIPS)) { if (crypt_method & CRYPT_METHOD_FIPS) { g_writeln(" client and server support fips, using fips"); self->crypt_method = CRYPT_METHOD_FIPS; self->crypt_level = CRYPT_LEVEL_FIPS; found = 1; } } if ((found == 0) && (self->crypt_method & CRYPT_METHOD_128BIT) && (self->crypt_level == CRYPT_LEVEL_HIGH)) { if (crypt_method & CRYPT_METHOD_128BIT) { g_writeln(" client and server support high crypt, using " "high crypt"); self->crypt_method = CRYPT_METHOD_128BIT; self->crypt_level = CRYPT_LEVEL_HIGH; found = 1; } } if ((found == 0) && (self->crypt_method & CRYPT_METHOD_40BIT) && (self->crypt_level == CRYPT_LEVEL_CLIENT_COMPATIBLE)) { if (crypt_method & CRYPT_METHOD_40BIT) { g_writeln(" client and server support medium crypt, using " "medium crypt"); self->crypt_method = CRYPT_METHOD_40BIT; self->crypt_level = CRYPT_LEVEL_CLIENT_COMPATIBLE; found = 1; } } if ((found == 0) && (self->crypt_method & CRYPT_METHOD_40BIT) && (self->crypt_level == CRYPT_LEVEL_LOW)) { if (crypt_method & CRYPT_METHOD_40BIT) { g_writeln(" client and server support low crypt, using " "low crypt"); self->crypt_method = CRYPT_METHOD_40BIT; self->crypt_level = CRYPT_LEVEL_LOW; found = 1; } } if ((found == 0) && (self->crypt_level == CRYPT_LEVEL_NONE)) { if (crypt_method == CRYPT_METHOD_NONE) { g_writeln(" client and server support none crypt, using " "none crypt"); self->crypt_method = CRYPT_METHOD_NONE; self->crypt_level = CRYPT_LEVEL_NONE; found = 1; } } // if (found == 0) // { // g_writeln(" can not find client / server agreed encryption method"); // return 1; // } return 0; } /*****************************************************************************/ /* this adds the mcs channels in the list of channels to be used when creating the server mcs data */ static int xrdp_sec_process_mcs_data_channels(struct xrdp_sec *self, struct stream *s) { int num_channels; int index; struct xrdp_client_info *client_info = (struct xrdp_client_info *)NULL; client_info = &(self->rdp_layer->client_info); DEBUG(("processing channels, channels_allowed is %d", client_info->channels_allowed)); /* this is an option set in xrdp.ini */ if (client_info->channels_allowed != 1) /* are channels on? */ { g_writeln("xrdp_sec_process_mcs_data_channels: all channels are disabled by configuration"); return 0; } if (!s_check_rem(s, 4)) { return 1; } in_uint32_le(s, num_channels); if (num_channels > 31) { return 1; } for (index = 0; index < num_channels; index++) { struct mcs_channel_item *channel_item; channel_item = (struct mcs_channel_item *) g_malloc(sizeof(struct mcs_channel_item), 1); if (!s_check_rem(s, 12)) { g_free(channel_item); return 1; } in_uint8a(s, channel_item->name, 8); if (g_strlen(channel_item->name) == 0) { log_message(LOG_LEVEL_WARNING, "xrdp_sec_process_mcs_data_channels: got an empty channel name, ignoring it"); g_free(channel_item); continue; } in_uint32_le(s, channel_item->flags); channel_item->chanid = MCS_GLOBAL_CHANNEL + (index + 1); list_add_item(self->mcs_layer->channel_list, (tintptr) channel_item); DEBUG(("got channel flags %8.8x name %s", channel_item->flags, channel_item->name)); } return 0; } /*****************************************************************************/ /* reads the client monitors data */ static int xrdp_sec_process_mcs_data_monitors(struct xrdp_sec *self, struct stream *s) { int index; int monitorCount; int flags; int x1; int y1; int x2; int y2; int got_primary; struct xrdp_client_info *client_info = (struct xrdp_client_info *)NULL; client_info = &(self->rdp_layer->client_info); LLOGLN(10, ("xrdp_sec_process_mcs_data_monitors: processing monitors data, allow_multimon is %d", client_info->multimon)); /* this is an option set in xrdp.ini */ if (client_info->multimon != 1) /* are multi-monitors allowed ? */ { LLOGLN(0, ("[INFO] xrdp_sec_process_mcs_data_monitors: multimon is not " "allowed, skipping")); return 0; } in_uint32_le(s, flags); /* flags */ //verify flags - must be 0x0 if (flags != 0) { LLOGLN(0, ("[ERROR] xrdp_sec_process_mcs_data_monitors: flags MUST be " "zero, detected: %d", flags)); return 1; } in_uint32_le(s, monitorCount); //verify monitorCount - max 16 if (monitorCount > 16) { LLOGLN(0, ("[ERROR] xrdp_sec_process_mcs_data_monitors: max allowed " "monitors is 16, detected: %d", monitorCount)); return 1; } LLOGLN(10, ("xrdp_sec_process_mcs_data_monitors: monitorCount= %d", monitorCount)); client_info->monitorCount = monitorCount; x1 = 0; y1 = 0; x2 = 0; y2 = 0; got_primary = 0; /* Add client_monitor_data to client_info struct, will later pass to X11rdp */ for (index = 0; index < monitorCount; index++) { in_uint32_le(s, client_info->minfo[index].left); in_uint32_le(s, client_info->minfo[index].top); in_uint32_le(s, client_info->minfo[index].right); in_uint32_le(s, client_info->minfo[index].bottom); in_uint32_le(s, client_info->minfo[index].is_primary); if (index == 0) { x1 = client_info->minfo[index].left; y1 = client_info->minfo[index].top; x2 = client_info->minfo[index].right; y2 = client_info->minfo[index].bottom; } else { x1 = MIN(x1, client_info->minfo[index].left); y1 = MIN(y1, client_info->minfo[index].top); x2 = MAX(x2, client_info->minfo[index].right); y2 = MAX(y2, client_info->minfo[index].bottom); } if (client_info->minfo[index].is_primary) { got_primary = 1; } LLOGLN(10, ("xrdp_sec_process_mcs_data_monitors: got a monitor [%d]: left= %d, top= %d, right= %d, bottom= %d, is_primary?= %d", index, client_info->minfo[index].left, client_info->minfo[index].top, client_info->minfo[index].right, client_info->minfo[index].bottom, client_info->minfo[index].is_primary)); } if (!got_primary) { /* no primary monitor was set, choose the leftmost monitor as primary */ for (index = 0; index < monitorCount; index++) { if (client_info->minfo[index].left == x1 && client_info->minfo[index].top == y1) { client_info->minfo[index].is_primary = 1; break; } } } /* set wm geometry */ if ((x2 > x1) && (y2 > y1)) { client_info->width = (x2 - x1) + 1; client_info->height = (y2 - y1) + 1; } /* make sure virtual desktop size is ok */ if (client_info->width > 0x7FFE || client_info->width < 0xC8 || client_info->height > 0x7FFE || client_info->height < 0xC8) { LLOGLN(0, ("[ERROR] xrdp_sec_process_mcs_data_monitors: error, virtual desktop width / height is too large")); return 1; /* error */ } /* keep a copy of non negative monitor info values for xrdp_wm usage */ for (index = 0; index < monitorCount; index++) { client_info->minfo_wm[index].left = client_info->minfo[index].left - x1; client_info->minfo_wm[index].top = client_info->minfo[index].top - y1; client_info->minfo_wm[index].right = client_info->minfo[index].right - x1; client_info->minfo_wm[index].bottom = client_info->minfo[index].bottom - y1; client_info->minfo_wm[index].is_primary = client_info->minfo[index].is_primary; } return 0; } /*****************************************************************************/ /* process client mcs data, we need some things in here to create the server mcs data */ int xrdp_sec_process_mcs_data(struct xrdp_sec *self) { struct stream *s = (struct stream *)NULL; char *hold_p = (char *)NULL; int tag = 0; int size = 0; s = &(self->client_mcs_data); /* set p to beginning */ s->p = s->data; /* skip header */ if (!s_check_rem(s, 23)) { return 1; } in_uint8s(s, 23); while (s_check_rem(s, 4)) { hold_p = s->p; in_uint16_le(s, tag); in_uint16_le(s, size); if ((size < 4) || (!s_check_rem(s, size - 4))) { LLOGLN(0, ("error in xrdp_sec_process_mcs_data tag %d size %d", tag, size)); break; } LLOGLN(10, ("xrdp_sec_process_mcs_data: 0x%8.8x", tag)); switch (tag) { case SEC_TAG_CLI_INFO: /* CS_CORE 0xC001 */ if (xrdp_sec_process_mcs_data_CS_CORE(self, s) != 0) { return 1; } break; case SEC_TAG_CLI_CRYPT: /* CS_SECURITY 0xC002 */ if (xrdp_sec_process_mcs_data_CS_SECURITY(self, s) != 0) { return 1; } break; case SEC_TAG_CLI_CHANNELS: /* CS_NET 0xC003 */ if (xrdp_sec_process_mcs_data_channels(self, s) != 0) { return 1; } break; case SEC_TAG_CLI_4: /* CS_CLUSTER 0xC004 */ break; case SEC_TAG_CLI_MONITOR: /* CS_MONITOR 0xC005 */ if (xrdp_sec_process_mcs_data_monitors(self, s) != 0) { return 1; } break; /* CS_MCS_MSGCHANNEL 0xC006 CS_MONITOR_EX 0xC008 CS_MULTITRANSPORT 0xC00A SC_CORE 0x0C01 SC_SECURITY 0x0C02 SC_NET 0x0C03 SC_MCS_MSGCHANNEL 0x0C04 SC_MULTITRANSPORT 0x0C08 */ default: LLOGLN(0, ("error unknown xrdp_sec_process_mcs_data " "tag 0x%4.4x size %d", tag, size)); break; } s->p = hold_p + size; } if (self->rdp_layer->client_info.max_bpp > 0) { if (self->rdp_layer->client_info.bpp > self->rdp_layer->client_info.max_bpp) { LLOGLN(0, ("xrdp_rdp_parse_client_mcs_data: client asked " "for %dbpp connection but configuration is limited " "to %dbpp", self->rdp_layer->client_info.bpp, self->rdp_layer->client_info.max_bpp)); self->rdp_layer->client_info.bpp = self->rdp_layer->client_info.max_bpp; } } /* set p to beginning */ s->p = s->data; return 0; } /*****************************************************************************/ /* process the mcs client data we received from the mcs layer */ static int xrdp_sec_in_mcs_data(struct xrdp_sec *self) { struct stream *s = (struct stream *)NULL; struct xrdp_client_info *client_info = (struct xrdp_client_info *)NULL; int index = 0; char c = 0; client_info = &(self->rdp_layer->client_info); s = &(self->client_mcs_data); /* get hostname, it's unicode */ s->p = s->data; if (!s_check_rem(s, 47)) { return 1; } in_uint8s(s, 47); g_memset(client_info->hostname, 0, 32); c = 1; index = 0; while (index < 16 && c != 0) { if (!s_check_rem(s, 2)) { return 1; } in_uint8(s, c); in_uint8s(s, 1); client_info->hostname[index] = c; index++; } /* get build */ s->p = s->data; if (!s_check_rem(s, 43 + 4)) { return 1; } in_uint8s(s, 43); in_uint32_le(s, client_info->build); /* get keylayout */ s->p = s->data; if (!s_check_rem(s, 39 + 4)) { return 1; } in_uint8s(s, 39); in_uint32_le(s, client_info->keylayout); /* get keyboard type / subtype */ s->p = s->data; if (!s_check_rem(s, 79 + 8)) { return 1; } in_uint8s(s, 79); in_uint32_le(s, client_info->keyboard_type); in_uint32_le(s, client_info->keyboard_subtype); xrdp_load_keyboard_layout(client_info); s->p = s->data; return 0; } /*****************************************************************************/ /* returns error */ int xrdp_sec_init_rdp_security(struct xrdp_sec *self) { switch (self->rdp_layer->client_info.crypt_level) { case 0: /* none */ self->crypt_method = CRYPT_METHOD_NONE; self->crypt_level = CRYPT_LEVEL_NONE; break; case 1: /* low */ self->crypt_method = CRYPT_METHOD_40BIT; self->crypt_level = CRYPT_LEVEL_LOW; break; case 2: /* medium */ self->crypt_method = CRYPT_METHOD_40BIT; self->crypt_level = CRYPT_LEVEL_CLIENT_COMPATIBLE; break; case 3: /* high */ self->crypt_method = CRYPT_METHOD_128BIT; self->crypt_level = CRYPT_LEVEL_HIGH; break; case 4: /* fips */ self->crypt_method = CRYPT_METHOD_FIPS; self->crypt_level = CRYPT_LEVEL_FIPS; break; default: g_writeln("Fatal : Illegal crypt_level"); break ; } if (self->decrypt_rc4_info != NULL) { g_writeln("xrdp_sec_init_rdp_security: decrypt_rc4_info already created !!!"); } else { self->decrypt_rc4_info = ssl_rc4_info_create(); } if (self->encrypt_rc4_info != NULL) { g_writeln("xrdp_sec_init_rdp_security: encrypt_rc4_info already created !!!"); } else { self->encrypt_rc4_info = ssl_rc4_info_create(); } return 0; } /*****************************************************************************/ int xrdp_sec_incoming(struct xrdp_sec *self) { struct list *items = NULL; struct list *values = NULL; struct xrdp_iso *iso; int index = 0; char *item = NULL; char *value = NULL; char key_file[256]; DEBUG((" in xrdp_sec_incoming:")); iso = self->mcs_layer->iso_layer; /* negotiate security layer */ if (xrdp_iso_incoming(iso) != 0) { DEBUG(("xrdp_sec_incoming: xrdp_iso_incoming failed")); return 1; } /* initialize selected security layer */ if (iso->selectedProtocol > PROTOCOL_RDP) { /* init tls security */ DEBUG((" in xrdp_sec_incoming: init tls security")); if (trans_set_tls_mode(self->mcs_layer->iso_layer->trans, self->rdp_layer->client_info.key_file, self->rdp_layer->client_info.certificate, self->rdp_layer->client_info.ssl_protocols, self->rdp_layer->client_info.tls_ciphers) != 0) { g_writeln("xrdp_sec_incoming: trans_set_tls_mode failed"); return 1; } self->crypt_level = CRYPT_LEVEL_NONE; self->crypt_method = CRYPT_METHOD_NONE; self->rsa_key_bytes = 0; } else { /* init rdp security */ DEBUG((" in xrdp_sec_incoming: init rdp security")); if (xrdp_sec_init_rdp_security(self) != 0) { DEBUG(("xrdp_sec_incoming: xrdp_sec_init_rdp_security failed")); return 1; } if (self->crypt_method != CRYPT_METHOD_NONE) { g_memset(key_file, 0, sizeof(char) * 256); g_random(self->server_random, 32); items = list_create(); items->auto_free = 1; values = list_create(); values->auto_free = 1; g_snprintf(key_file, 255, "%s/rsakeys.ini", XRDP_CFG_PATH); if (file_by_name_read_section(key_file, "keys", items, values) != 0) { /* this is a show stopper */ log_message(LOG_LEVEL_ALWAYS, "XRDP cannot read file: %s " "(check permissions)", key_file); list_delete(items); list_delete(values); return 1; } for (index = 0; index < items->count; index++) { item = (char *)list_get_item(items, index); value = (char *)list_get_item(values, index); if (g_strcasecmp(item, "pub_exp") == 0) { hex_str_to_bin(value, self->pub_exp, 4); } else if (g_strcasecmp(item, "pub_mod") == 0) { self->rsa_key_bytes = (g_strlen(value) + 1) / 5; g_writeln("pub_mod bytes %d", self->rsa_key_bytes); hex_str_to_bin(value, self->pub_mod, self->rsa_key_bytes); } else if (g_strcasecmp(item, "pub_sig") == 0) { hex_str_to_bin(value, self->pub_sig, 64); } else if (g_strcasecmp(item, "pri_exp") == 0) { self->rsa_key_bytes = (g_strlen(value) + 1) / 5; g_writeln("pri_exp %d", self->rsa_key_bytes); hex_str_to_bin(value, self->pri_exp, self->rsa_key_bytes); } } if (self->rsa_key_bytes <= 64) { g_writeln("warning, RSA key len 512 " "bits or less, consider creating a 2048 bit key"); log_message(LOG_LEVEL_WARNING, "warning, RSA key len 512 " "bits or less, consider creating a 2048 bit key"); } list_delete(items); list_delete(values); } } /* negotiate mcs layer */ if (xrdp_mcs_incoming(self->mcs_layer) != 0) { return 1; } #ifdef XRDP_DEBUG g_writeln("client mcs data received"); g_hexdump(self->client_mcs_data.data, (int)(self->client_mcs_data.end - self->client_mcs_data.data)); g_writeln("server mcs data sent"); g_hexdump(self->server_mcs_data.data, (int)(self->server_mcs_data.end - self->server_mcs_data.data)); #endif DEBUG((" out xrdp_sec_incoming")); if (xrdp_sec_in_mcs_data(self) != 0) { return 1; } LLOGLN(10, ("xrdp_sec_incoming: out")); return 0; } /*****************************************************************************/ int xrdp_sec_disconnect(struct xrdp_sec *self) { int rv; DEBUG((" in xrdp_sec_disconnect")); rv = xrdp_mcs_disconnect(self->mcs_layer); DEBUG((" out xrdp_sec_disconnect")); return rv; } xrdp-0.9.5/libxrdp/Makefile.in000644 001751 001751 00000056421 13220730774 016150 0ustar00metameta000000 000000 # Makefile.in generated by automake 1.15.1 from Makefile.am. # @configure_input@ # Copyright (C) 1994-2017 Free Software Foundation, Inc. # This Makefile.in is free software; the Free Software Foundation # gives unlimited permission to copy and/or distribute it, # with or without modifications, as long as this notice is preserved. # This program is distributed in the hope that it will be useful, # but WITHOUT ANY WARRANTY, to the extent permitted by law; without # even the implied warranty of MERCHANTABILITY or FITNESS FOR A # PARTICULAR PURPOSE. @SET_MAKE@ VPATH = @srcdir@ am__is_gnu_make = { \ if test -z '$(MAKELEVEL)'; then \ false; \ elif test -n '$(MAKE_HOST)'; then \ true; \ elif test -n '$(MAKE_VERSION)' && test -n '$(CURDIR)'; then \ true; \ else \ false; \ fi; \ } am__make_running_with_option = \ case $${target_option-} in \ ?) ;; \ *) echo "am__make_running_with_option: internal error: invalid" \ "target option '$${target_option-}' specified" >&2; \ exit 1;; \ esac; \ has_opt=no; \ sane_makeflags=$$MAKEFLAGS; \ if $(am__is_gnu_make); then \ sane_makeflags=$$MFLAGS; \ else \ case $$MAKEFLAGS in \ *\\[\ \ ]*) \ bs=\\; \ sane_makeflags=`printf '%s\n' "$$MAKEFLAGS" \ | sed "s/$$bs$$bs[$$bs $$bs ]*//g"`;; \ esac; \ fi; \ skip_next=no; \ strip_trailopt () \ { \ flg=`printf '%s\n' "$$flg" | sed "s/$$1.*$$//"`; \ }; \ for flg in $$sane_makeflags; do \ test $$skip_next = yes && { skip_next=no; continue; }; \ case $$flg in \ *=*|--*) continue;; \ -*I) strip_trailopt 'I'; skip_next=yes;; \ -*I?*) strip_trailopt 'I';; \ -*O) strip_trailopt 'O'; skip_next=yes;; \ -*O?*) strip_trailopt 'O';; \ -*l) strip_trailopt 'l'; skip_next=yes;; \ -*l?*) strip_trailopt 'l';; \ -[dEDm]) skip_next=yes;; \ -[JT]) skip_next=yes;; \ esac; \ case $$flg in \ *$$target_option*) has_opt=yes; break;; \ esac; \ done; \ test $$has_opt = yes am__make_dryrun = (target_option=n; $(am__make_running_with_option)) am__make_keepgoing = (target_option=k; $(am__make_running_with_option)) pkgdatadir = $(datadir)/@PACKAGE@ pkgincludedir = $(includedir)/@PACKAGE@ pkglibdir = $(libdir)/@PACKAGE@ pkglibexecdir = $(libexecdir)/@PACKAGE@ am__cd = CDPATH="$${ZSH_VERSION+.}$(PATH_SEPARATOR)" && cd install_sh_DATA = $(install_sh) -c -m 644 install_sh_PROGRAM = $(install_sh) -c install_sh_SCRIPT = $(install_sh) -c INSTALL_HEADER = $(INSTALL_DATA) transform = $(program_transform_name) NORMAL_INSTALL = : PRE_INSTALL = : POST_INSTALL = : NORMAL_UNINSTALL = : PRE_UNINSTALL = : POST_UNINSTALL = : build_triplet = @build@ host_triplet = @host@ @XRDP_DEBUG_TRUE@am__append_1 = -DXRDP_DEBUG @XRDP_NEUTRINORDP_TRUE@am__append_2 = -DXRDP_NEUTRINORDP @XRDP_NEUTRINORDP_TRUE@am__append_3 = $(FREERDP_LIBS) @XRDP_RFXCODEC_TRUE@am__append_4 = -DXRDP_RFXCODEC @XRDP_TJPEG_TRUE@am__append_5 = -DXRDP_JPEG -DXRDP_TJPEG @TurboJpegIncDir@ @XRDP_TJPEG_TRUE@am__append_6 = @TurboJpegLibDir@ @XRDP_TJPEG_TRUE@am__append_7 = -lturbojpeg @XRDP_JPEG_TRUE@@XRDP_TJPEG_FALSE@am__append_8 = -DXRDP_JPEG @XRDP_JPEG_TRUE@@XRDP_TJPEG_FALSE@am__append_9 = -ljpeg subdir = libxrdp ACLOCAL_M4 = $(top_srcdir)/aclocal.m4 am__aclocal_m4_deps = $(top_srcdir)/m4/ax_append_compile_flags.m4 \ $(top_srcdir)/m4/ax_append_flag.m4 \ $(top_srcdir)/m4/ax_cflags_warn_all.m4 \ $(top_srcdir)/m4/ax_check_compile_flag.m4 \ $(top_srcdir)/m4/ax_gcc_func_attribute.m4 \ $(top_srcdir)/m4/ax_require_defined.m4 \ $(top_srcdir)/m4/ax_type_socklen_t.m4 \ $(top_srcdir)/m4/libtool.m4 $(top_srcdir)/m4/ltoptions.m4 \ $(top_srcdir)/m4/ltsugar.m4 $(top_srcdir)/m4/ltversion.m4 \ $(top_srcdir)/m4/lt~obsolete.m4 $(top_srcdir)/m4/pkg.m4 \ $(top_srcdir)/configure.ac am__configure_deps = $(am__aclocal_m4_deps) $(CONFIGURE_DEPENDENCIES) \ $(ACLOCAL_M4) DIST_COMMON = $(srcdir)/Makefile.am $(am__DIST_COMMON) mkinstalldirs = $(install_sh) -d CONFIG_HEADER = $(top_builddir)/config_ac.h CONFIG_CLEAN_FILES = CONFIG_CLEAN_VPATH_FILES = am__vpath_adj_setup = srcdirstrip=`echo "$(srcdir)" | sed 's|.|.|g'`; am__vpath_adj = case $$p in \ $(srcdir)/*) f=`echo "$$p" | sed "s|^$$srcdirstrip/||"`;; \ *) f=$$p;; \ esac; am__strip_dir = f=`echo $$p | sed -e 's|^.*/||'`; am__install_max = 40 am__nobase_strip_setup = \ srcdirstrip=`echo "$(srcdir)" | sed 's/[].[^$$\\*|]/\\\\&/g'` am__nobase_strip = \ for p in $$list; do echo "$$p"; done | sed -e "s|$$srcdirstrip/||" am__nobase_list = $(am__nobase_strip_setup); \ for p in $$list; do echo "$$p $$p"; done | \ sed "s| $$srcdirstrip/| |;"' / .*\//!s/ .*/ ./; s,\( .*\)/[^/]*$$,\1,' | \ $(AWK) 'BEGIN { files["."] = "" } { files[$$2] = files[$$2] " " $$1; \ if (++n[$$2] == $(am__install_max)) \ { print $$2, files[$$2]; n[$$2] = 0; files[$$2] = "" } } \ END { for (dir in files) print dir, files[dir] }' am__base_list = \ sed '$$!N;$$!N;$$!N;$$!N;$$!N;$$!N;$$!N;s/\n/ /g' | \ sed '$$!N;$$!N;$$!N;$$!N;s/\n/ /g' am__uninstall_files_from_dir = { \ test -z "$$files" \ || { test ! -d "$$dir" && test ! -f "$$dir" && test ! -r "$$dir"; } \ || { echo " ( cd '$$dir' && rm -f" $$files ")"; \ $(am__cd) "$$dir" && rm -f $$files; }; \ } am__installdirs = "$(DESTDIR)$(moduledir)" LTLIBRARIES = $(module_LTLIBRARIES) am__DEPENDENCIES_1 = @XRDP_NEUTRINORDP_TRUE@am__DEPENDENCIES_2 = $(am__DEPENDENCIES_1) am__DEPENDENCIES_3 = $(am__DEPENDENCIES_2) $(am__DEPENDENCIES_1) \ $(am__DEPENDENCIES_1) libxrdp_la_DEPENDENCIES = $(top_builddir)/common/libcommon.la \ $(am__DEPENDENCIES_3) am_libxrdp_la_OBJECTS = libxrdp.lo xrdp_bitmap32_compress.lo \ xrdp_bitmap_compress.lo xrdp_caps.lo xrdp_channel.lo \ xrdp_fastpath.lo xrdp_iso.lo xrdp_jpeg_compress.lo xrdp_mcs.lo \ xrdp_mppc_enc.lo xrdp_orders.lo xrdp_orders_rail.lo \ xrdp_rdp.lo xrdp_sec.lo libxrdp_la_OBJECTS = $(am_libxrdp_la_OBJECTS) AM_V_lt = $(am__v_lt_@AM_V@) am__v_lt_ = $(am__v_lt_@AM_DEFAULT_V@) am__v_lt_0 = --silent am__v_lt_1 = AM_V_P = $(am__v_P_@AM_V@) am__v_P_ = $(am__v_P_@AM_DEFAULT_V@) am__v_P_0 = false am__v_P_1 = : AM_V_GEN = $(am__v_GEN_@AM_V@) am__v_GEN_ = $(am__v_GEN_@AM_DEFAULT_V@) am__v_GEN_0 = @echo " GEN " $@; am__v_GEN_1 = AM_V_at = $(am__v_at_@AM_V@) am__v_at_ = $(am__v_at_@AM_DEFAULT_V@) am__v_at_0 = @ am__v_at_1 = DEFAULT_INCLUDES = -I.@am__isrc@ -I$(top_builddir) depcomp = $(SHELL) $(top_srcdir)/depcomp am__depfiles_maybe = depfiles am__mv = mv -f COMPILE = $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) \ $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) LTCOMPILE = $(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) \ $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) \ $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) \ $(AM_CFLAGS) $(CFLAGS) AM_V_CC = $(am__v_CC_@AM_V@) am__v_CC_ = $(am__v_CC_@AM_DEFAULT_V@) am__v_CC_0 = @echo " CC " $@; am__v_CC_1 = CCLD = $(CC) LINK = $(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) \ $(LIBTOOLFLAGS) --mode=link $(CCLD) $(AM_CFLAGS) $(CFLAGS) \ $(AM_LDFLAGS) $(LDFLAGS) -o $@ AM_V_CCLD = $(am__v_CCLD_@AM_V@) am__v_CCLD_ = $(am__v_CCLD_@AM_DEFAULT_V@) am__v_CCLD_0 = @echo " CCLD " $@; am__v_CCLD_1 = SOURCES = $(libxrdp_la_SOURCES) DIST_SOURCES = $(libxrdp_la_SOURCES) am__can_run_installinfo = \ case $$AM_UPDATE_INFO_DIR in \ n|no|NO) false;; \ *) (install-info --version) >/dev/null 2>&1;; \ esac am__tagged_files = $(HEADERS) $(SOURCES) $(TAGS_FILES) $(LISP) # Read a list of newline-separated strings from the standard input, # and print each of them once, without duplicates. Input order is # *not* preserved. am__uniquify_input = $(AWK) '\ BEGIN { nonempty = 0; } \ { items[$$0] = 1; nonempty = 1; } \ END { if (nonempty) { for (i in items) print i; }; } \ ' # Make sure the list of sources is unique. This is necessary because, # e.g., the same source file might be shared among _SOURCES variables # for different programs/libraries. am__define_uniq_tagged_files = \ list='$(am__tagged_files)'; \ unique=`for i in $$list; do \ if test -f "$$i"; then echo $$i; else echo $(srcdir)/$$i; fi; \ done | $(am__uniquify_input)` ETAGS = etags CTAGS = ctags am__DIST_COMMON = $(srcdir)/Makefile.in $(top_srcdir)/depcomp DISTFILES = $(DIST_COMMON) $(DIST_SOURCES) $(TEXINFOS) $(EXTRA_DIST) ACLOCAL = @ACLOCAL@ AMTAR = @AMTAR@ AM_DEFAULT_VERBOSITY = @AM_DEFAULT_VERBOSITY@ AR = @AR@ AUTOCONF = @AUTOCONF@ AUTOHEADER = @AUTOHEADER@ AUTOMAKE = @AUTOMAKE@ AWK = @AWK@ CC = @CC@ CCDEPMODE = @CCDEPMODE@ CFLAGS = @CFLAGS@ CPP = @CPP@ CPPFLAGS = @CPPFLAGS@ CYGPATH_W = @CYGPATH_W@ DEFS = @DEFS@ DEPDIR = @DEPDIR@ DLLTOOL = @DLLTOOL@ DLOPEN_LIBS = @DLOPEN_LIBS@ DSYMUTIL = @DSYMUTIL@ DUMPBIN = @DUMPBIN@ ECHO_C = @ECHO_C@ ECHO_N = @ECHO_N@ ECHO_T = @ECHO_T@ EGREP = @EGREP@ EXEEXT = @EXEEXT@ FDKAAC_CFLAGS = @FDKAAC_CFLAGS@ FDKAAC_LIBS = @FDKAAC_LIBS@ FGREP = @FGREP@ FREERDP_CFLAGS = @FREERDP_CFLAGS@ FREERDP_LIBS = @FREERDP_LIBS@ FUSE_CFLAGS = @FUSE_CFLAGS@ FUSE_LIBS = @FUSE_LIBS@ GREP = @GREP@ INSTALL = @INSTALL@ INSTALL_DATA = @INSTALL_DATA@ INSTALL_PROGRAM = @INSTALL_PROGRAM@ INSTALL_SCRIPT = @INSTALL_SCRIPT@ INSTALL_STRIP_PROGRAM = @INSTALL_STRIP_PROGRAM@ LD = @LD@ LDFLAGS = @LDFLAGS@ LIBOBJS = @LIBOBJS@ LIBS = @LIBS@ LIBTOOL = @LIBTOOL@ LIPO = @LIPO@ LN_S = @LN_S@ LTLIBOBJS = @LTLIBOBJS@ LT_SYS_LIBRARY_PATH = @LT_SYS_LIBRARY_PATH@ MAKEINFO = @MAKEINFO@ MANIFEST_TOOL = @MANIFEST_TOOL@ MKDIR_P = @MKDIR_P@ NM = @NM@ NMEDIT = @NMEDIT@ OBJDUMP = @OBJDUMP@ OBJEXT = @OBJEXT@ OPENSSL = @OPENSSL@ OPENSSL_CFLAGS = @OPENSSL_CFLAGS@ OPENSSL_LIBS = @OPENSSL_LIBS@ OTOOL = @OTOOL@ OTOOL64 = @OTOOL64@ PACKAGE = @PACKAGE@ PACKAGE_BUGREPORT = @PACKAGE_BUGREPORT@ PACKAGE_NAME = @PACKAGE_NAME@ PACKAGE_STRING = @PACKAGE_STRING@ PACKAGE_TARNAME = @PACKAGE_TARNAME@ PACKAGE_URL = @PACKAGE_URL@ PACKAGE_VERSION = @PACKAGE_VERSION@ PAM_RULES = @PAM_RULES@ PATH_SEPARATOR = @PATH_SEPARATOR@ PIXMAN_CFLAGS = @PIXMAN_CFLAGS@ PIXMAN_LIBS = @PIXMAN_LIBS@ PKG_CONFIG = @PKG_CONFIG@ PKG_CONFIG_LIBDIR = @PKG_CONFIG_LIBDIR@ PKG_CONFIG_PATH = @PKG_CONFIG_PATH@ RANLIB = @RANLIB@ SED = @SED@ SET_MAKE = @SET_MAKE@ SHELL = @SHELL@ STRIP = @STRIP@ TurboJpegIncDir = @TurboJpegIncDir@ TurboJpegLibDir = @TurboJpegLibDir@ VERSION = @VERSION@ XMKMF = @XMKMF@ X_CFLAGS = @X_CFLAGS@ X_EXTRA_LIBS = @X_EXTRA_LIBS@ X_LIBS = @X_LIBS@ X_PRE_LIBS = @X_PRE_LIBS@ abs_builddir = @abs_builddir@ abs_srcdir = @abs_srcdir@ abs_top_builddir = @abs_top_builddir@ abs_top_srcdir = @abs_top_srcdir@ ac_ct_AR = @ac_ct_AR@ ac_ct_CC = @ac_ct_CC@ ac_ct_DUMPBIN = @ac_ct_DUMPBIN@ am__include = @am__include@ am__leading_dot = @am__leading_dot@ am__quote = @am__quote@ am__tar = @am__tar@ am__untar = @am__untar@ bindir = @bindir@ build = @build@ build_alias = @build_alias@ build_cpu = @build_cpu@ build_os = @build_os@ build_vendor = @build_vendor@ builddir = @builddir@ datadir = @datadir@ datarootdir = @datarootdir@ docdir = @docdir@ dvidir = @dvidir@ exec_prefix = @exec_prefix@ host = @host@ host_alias = @host_alias@ host_cpu = @host_cpu@ host_os = @host_os@ host_vendor = @host_vendor@ htmldir = @htmldir@ includedir = @includedir@ infodir = @infodir@ install_sh = @install_sh@ libdir = @libdir@ libexecdir = @libexecdir@ localedir = @localedir@ localstatedir = @localstatedir@ mandir = @mandir@ mkdir_p = @mkdir_p@ moduledir = @moduledir@ oldincludedir = @oldincludedir@ pdfdir = @pdfdir@ pkgconfigdir = @pkgconfigdir@ prefix = @prefix@ program_transform_name = @program_transform_name@ psdir = @psdir@ sbindir = @sbindir@ sharedstatedir = @sharedstatedir@ socketdir = @socketdir@ srcdir = @srcdir@ subdirs = @subdirs@ sysconfdir = @sysconfdir@ systemdsystemunitdir = @systemdsystemunitdir@ target_alias = @target_alias@ top_build_prefix = @top_build_prefix@ top_builddir = @top_builddir@ top_srcdir = @top_srcdir@ EXTRA_DIST = \ xrdp_surface.c AM_CPPFLAGS = -DXRDP_CFG_PATH=\"${sysconfdir}/xrdp\" \ -DXRDP_SBIN_PATH=\"${sbindir}\" \ -DXRDP_SHARE_PATH=\"${datadir}/xrdp\" \ -DXRDP_PID_PATH=\"${localstatedir}/run\" \ -I$(top_srcdir)/common $(am__append_1) $(am__append_2) \ $(am__append_4) $(am__append_5) $(am__append_8) AM_CFLAGS = $(OPENSSL_CFLAGS) AM_LDFLAGS = $(am__append_6) LIBXRDP_EXTRA_LIBS = $(am__append_3) $(am__append_7) $(am__append_9) module_LTLIBRARIES = \ libxrdp.la libxrdp_la_SOURCES = \ libxrdp.c \ libxrdp.h \ libxrdpinc.h \ xrdp_bitmap32_compress.c \ xrdp_bitmap_compress.c \ xrdp_caps.c \ xrdp_channel.c \ xrdp_fastpath.c \ xrdp_iso.c \ xrdp_jpeg_compress.c \ xrdp_mcs.c \ xrdp_mppc_enc.c \ xrdp_orders.c \ xrdp_orders_rail.c \ xrdp_orders_rail.h \ xrdp_rdp.c \ xrdp_sec.c libxrdp_la_LIBADD = \ $(top_builddir)/common/libcommon.la \ $(LIBXRDP_EXTRA_LIBS) all: all-am .SUFFIXES: .SUFFIXES: .c .lo .o .obj $(srcdir)/Makefile.in: $(srcdir)/Makefile.am $(am__configure_deps) @for dep in $?; do \ case '$(am__configure_deps)' in \ *$$dep*) \ ( cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh ) \ && { if test -f $@; then exit 0; else break; fi; }; \ exit 1;; \ esac; \ done; \ echo ' cd $(top_srcdir) && $(AUTOMAKE) --foreign libxrdp/Makefile'; \ $(am__cd) $(top_srcdir) && \ $(AUTOMAKE) --foreign libxrdp/Makefile Makefile: $(srcdir)/Makefile.in $(top_builddir)/config.status @case '$?' in \ *config.status*) \ cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh;; \ *) \ echo ' cd $(top_builddir) && $(SHELL) ./config.status $(subdir)/$@ $(am__depfiles_maybe)'; \ cd $(top_builddir) && $(SHELL) ./config.status $(subdir)/$@ $(am__depfiles_maybe);; \ esac; $(top_builddir)/config.status: $(top_srcdir)/configure $(CONFIG_STATUS_DEPENDENCIES) cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh $(top_srcdir)/configure: $(am__configure_deps) cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh $(ACLOCAL_M4): $(am__aclocal_m4_deps) cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh $(am__aclocal_m4_deps): install-moduleLTLIBRARIES: $(module_LTLIBRARIES) @$(NORMAL_INSTALL) @list='$(module_LTLIBRARIES)'; test -n "$(moduledir)" || list=; \ list2=; for p in $$list; do \ if test -f $$p; then \ list2="$$list2 $$p"; \ else :; fi; \ done; \ test -z "$$list2" || { \ echo " $(MKDIR_P) '$(DESTDIR)$(moduledir)'"; \ $(MKDIR_P) "$(DESTDIR)$(moduledir)" || exit 1; \ echo " $(LIBTOOL) $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=install $(INSTALL) $(INSTALL_STRIP_FLAG) $$list2 '$(DESTDIR)$(moduledir)'"; \ $(LIBTOOL) $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=install $(INSTALL) $(INSTALL_STRIP_FLAG) $$list2 "$(DESTDIR)$(moduledir)"; \ } uninstall-moduleLTLIBRARIES: @$(NORMAL_UNINSTALL) @list='$(module_LTLIBRARIES)'; test -n "$(moduledir)" || list=; \ for p in $$list; do \ $(am__strip_dir) \ echo " $(LIBTOOL) $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=uninstall rm -f '$(DESTDIR)$(moduledir)/$$f'"; \ $(LIBTOOL) $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=uninstall rm -f "$(DESTDIR)$(moduledir)/$$f"; \ done clean-moduleLTLIBRARIES: -test -z "$(module_LTLIBRARIES)" || rm -f $(module_LTLIBRARIES) @list='$(module_LTLIBRARIES)'; \ locs=`for p in $$list; do echo $$p; done | \ sed 's|^[^/]*$$|.|; s|/[^/]*$$||; s|$$|/so_locations|' | \ sort -u`; \ test -z "$$locs" || { \ echo rm -f $${locs}; \ rm -f $${locs}; \ } libxrdp.la: $(libxrdp_la_OBJECTS) $(libxrdp_la_DEPENDENCIES) $(EXTRA_libxrdp_la_DEPENDENCIES) $(AM_V_CCLD)$(LINK) -rpath $(moduledir) $(libxrdp_la_OBJECTS) $(libxrdp_la_LIBADD) $(LIBS) mostlyclean-compile: -rm -f *.$(OBJEXT) distclean-compile: -rm -f *.tab.c @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/libxrdp.Plo@am__quote@ @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/xrdp_bitmap32_compress.Plo@am__quote@ @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/xrdp_bitmap_compress.Plo@am__quote@ @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/xrdp_caps.Plo@am__quote@ @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/xrdp_channel.Plo@am__quote@ @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/xrdp_fastpath.Plo@am__quote@ @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/xrdp_iso.Plo@am__quote@ @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/xrdp_jpeg_compress.Plo@am__quote@ @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/xrdp_mcs.Plo@am__quote@ @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/xrdp_mppc_enc.Plo@am__quote@ @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/xrdp_orders.Plo@am__quote@ @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/xrdp_orders_rail.Plo@am__quote@ @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/xrdp_rdp.Plo@am__quote@ @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/xrdp_sec.Plo@am__quote@ .c.o: @am__fastdepCC_TRUE@ $(AM_V_CC)$(COMPILE) -MT $@ -MD -MP -MF $(DEPDIR)/$*.Tpo -c -o $@ $< @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) $(DEPDIR)/$*.Tpo $(DEPDIR)/$*.Po @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='$<' object='$@' libtool=no @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(COMPILE) -c -o $@ $< .c.obj: @am__fastdepCC_TRUE@ $(AM_V_CC)$(COMPILE) -MT $@ -MD -MP -MF $(DEPDIR)/$*.Tpo -c -o $@ `$(CYGPATH_W) '$<'` @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) $(DEPDIR)/$*.Tpo $(DEPDIR)/$*.Po @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='$<' object='$@' libtool=no @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(COMPILE) -c -o $@ `$(CYGPATH_W) '$<'` .c.lo: @am__fastdepCC_TRUE@ $(AM_V_CC)$(LTCOMPILE) -MT $@ -MD -MP -MF $(DEPDIR)/$*.Tpo -c -o $@ $< @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) $(DEPDIR)/$*.Tpo $(DEPDIR)/$*.Plo @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='$<' object='$@' libtool=yes @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(LTCOMPILE) -c -o $@ $< mostlyclean-libtool: -rm -f *.lo clean-libtool: -rm -rf .libs _libs ID: $(am__tagged_files) $(am__define_uniq_tagged_files); mkid -fID $$unique tags: tags-am TAGS: tags tags-am: $(TAGS_DEPENDENCIES) $(am__tagged_files) set x; \ here=`pwd`; \ $(am__define_uniq_tagged_files); \ shift; \ if test -z "$(ETAGS_ARGS)$$*$$unique"; then :; else \ test -n "$$unique" || unique=$$empty_fix; \ if test $$# -gt 0; then \ $(ETAGS) $(ETAGSFLAGS) $(AM_ETAGSFLAGS) $(ETAGS_ARGS) \ "$$@" $$unique; \ else \ $(ETAGS) $(ETAGSFLAGS) $(AM_ETAGSFLAGS) $(ETAGS_ARGS) \ $$unique; \ fi; \ fi ctags: ctags-am CTAGS: ctags ctags-am: $(TAGS_DEPENDENCIES) $(am__tagged_files) $(am__define_uniq_tagged_files); \ test -z "$(CTAGS_ARGS)$$unique" \ || $(CTAGS) $(CTAGSFLAGS) $(AM_CTAGSFLAGS) $(CTAGS_ARGS) \ $$unique GTAGS: here=`$(am__cd) $(top_builddir) && pwd` \ && $(am__cd) $(top_srcdir) \ && gtags -i $(GTAGS_ARGS) "$$here" cscopelist: cscopelist-am cscopelist-am: $(am__tagged_files) list='$(am__tagged_files)'; \ case "$(srcdir)" in \ [\\/]* | ?:[\\/]*) sdir="$(srcdir)" ;; \ *) sdir=$(subdir)/$(srcdir) ;; \ esac; \ for i in $$list; do \ if test -f "$$i"; then \ echo "$(subdir)/$$i"; \ else \ echo "$$sdir/$$i"; \ fi; \ done >> $(top_builddir)/cscope.files distclean-tags: -rm -f TAGS ID GTAGS GRTAGS GSYMS GPATH tags distdir: $(DISTFILES) @srcdirstrip=`echo "$(srcdir)" | sed 's/[].[^$$\\*]/\\\\&/g'`; \ topsrcdirstrip=`echo "$(top_srcdir)" | sed 's/[].[^$$\\*]/\\\\&/g'`; \ list='$(DISTFILES)'; \ dist_files=`for file in $$list; do echo $$file; done | \ sed -e "s|^$$srcdirstrip/||;t" \ -e "s|^$$topsrcdirstrip/|$(top_builddir)/|;t"`; \ case $$dist_files in \ */*) $(MKDIR_P) `echo "$$dist_files" | \ sed '/\//!d;s|^|$(distdir)/|;s,/[^/]*$$,,' | \ sort -u` ;; \ esac; \ for file in $$dist_files; do \ if test -f $$file || test -d $$file; then d=.; else d=$(srcdir); fi; \ if test -d $$d/$$file; then \ dir=`echo "/$$file" | sed -e 's,/[^/]*$$,,'`; \ if test -d "$(distdir)/$$file"; then \ find "$(distdir)/$$file" -type d ! -perm -700 -exec chmod u+rwx {} \;; \ fi; \ if test -d $(srcdir)/$$file && test $$d != $(srcdir); then \ cp -fpR $(srcdir)/$$file "$(distdir)$$dir" || exit 1; \ find "$(distdir)/$$file" -type d ! -perm -700 -exec chmod u+rwx {} \;; \ fi; \ cp -fpR $$d/$$file "$(distdir)$$dir" || exit 1; \ else \ test -f "$(distdir)/$$file" \ || cp -p $$d/$$file "$(distdir)/$$file" \ || exit 1; \ fi; \ done check-am: all-am check: check-am all-am: Makefile $(LTLIBRARIES) installdirs: for dir in "$(DESTDIR)$(moduledir)"; do \ test -z "$$dir" || $(MKDIR_P) "$$dir"; \ done install: install-am install-exec: install-exec-am install-data: install-data-am uninstall: uninstall-am install-am: all-am @$(MAKE) $(AM_MAKEFLAGS) install-exec-am install-data-am installcheck: installcheck-am install-strip: if test -z '$(STRIP)'; then \ $(MAKE) $(AM_MAKEFLAGS) INSTALL_PROGRAM="$(INSTALL_STRIP_PROGRAM)" \ install_sh_PROGRAM="$(INSTALL_STRIP_PROGRAM)" INSTALL_STRIP_FLAG=-s \ install; \ else \ $(MAKE) $(AM_MAKEFLAGS) INSTALL_PROGRAM="$(INSTALL_STRIP_PROGRAM)" \ install_sh_PROGRAM="$(INSTALL_STRIP_PROGRAM)" INSTALL_STRIP_FLAG=-s \ "INSTALL_PROGRAM_ENV=STRIPPROG='$(STRIP)'" install; \ fi mostlyclean-generic: clean-generic: distclean-generic: -test -z "$(CONFIG_CLEAN_FILES)" || rm -f $(CONFIG_CLEAN_FILES) -test . = "$(srcdir)" || test -z "$(CONFIG_CLEAN_VPATH_FILES)" || rm -f $(CONFIG_CLEAN_VPATH_FILES) maintainer-clean-generic: @echo "This command is intended for maintainers to use" @echo "it deletes files that may require special tools to rebuild." clean: clean-am clean-am: clean-generic clean-libtool clean-moduleLTLIBRARIES \ mostlyclean-am distclean: distclean-am -rm -rf ./$(DEPDIR) -rm -f Makefile distclean-am: clean-am distclean-compile distclean-generic \ distclean-tags dvi: dvi-am dvi-am: html: html-am html-am: info: info-am info-am: install-data-am: install-moduleLTLIBRARIES install-dvi: install-dvi-am install-dvi-am: install-exec-am: install-html: install-html-am install-html-am: install-info: install-info-am install-info-am: install-man: install-pdf: install-pdf-am install-pdf-am: install-ps: install-ps-am install-ps-am: installcheck-am: maintainer-clean: maintainer-clean-am -rm -rf ./$(DEPDIR) -rm -f Makefile maintainer-clean-am: distclean-am maintainer-clean-generic mostlyclean: mostlyclean-am mostlyclean-am: mostlyclean-compile mostlyclean-generic \ mostlyclean-libtool pdf: pdf-am pdf-am: ps: ps-am ps-am: uninstall-am: uninstall-moduleLTLIBRARIES .MAKE: install-am install-strip .PHONY: CTAGS GTAGS TAGS all all-am check check-am clean clean-generic \ clean-libtool clean-moduleLTLIBRARIES cscopelist-am ctags \ ctags-am distclean distclean-compile distclean-generic \ distclean-libtool distclean-tags distdir dvi dvi-am html \ html-am info info-am install install-am install-data \ install-data-am install-dvi install-dvi-am install-exec \ install-exec-am install-html install-html-am install-info \ install-info-am install-man install-moduleLTLIBRARIES \ install-pdf install-pdf-am install-ps install-ps-am \ install-strip installcheck installcheck-am installdirs \ maintainer-clean maintainer-clean-generic mostlyclean \ mostlyclean-compile mostlyclean-generic mostlyclean-libtool \ pdf pdf-am ps ps-am tags tags-am uninstall uninstall-am \ uninstall-moduleLTLIBRARIES .PRECIOUS: Makefile # Tell versions [3.59,3.63) of GNU make to not export all variables. # Otherwise a system limit (for SysV at least) may be exceeded. .NOEXPORT: xrdp-0.9.5/libxrdp/xrdp_mcs.c000644 001751 001751 00000064170 13201006747 016061 0ustar00metameta000000 000000 /** * xrdp: A Remote Desktop Protocol server. * * Copyright (C) Jay Sorg 2004-2014 * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. * * mcs layer */ #if defined(HAVE_CONFIG_H) #include #endif #include "libxrdp.h" #include "log.h" /*****************************************************************************/ struct xrdp_mcs * xrdp_mcs_create(struct xrdp_sec *owner, struct trans *trans, struct stream *client_mcs_data, struct stream *server_mcs_data) { struct xrdp_mcs *self; DEBUG((" in xrdp_mcs_create")); self = (struct xrdp_mcs *)g_malloc(sizeof(struct xrdp_mcs), 1); self->sec_layer = owner; self->userid = 1; self->chanid = 1001; self->client_mcs_data = client_mcs_data; self->server_mcs_data = server_mcs_data; self->iso_layer = xrdp_iso_create(self, trans); self->channel_list = list_create(); DEBUG((" out xrdp_mcs_create")); return self; } /*****************************************************************************/ void xrdp_mcs_delete(struct xrdp_mcs *self) { struct mcs_channel_item *channel_item; int index; int count; if (self == 0) { return; } /* here we have to free the channel items and anything in them */ count = self->channel_list->count; for (index = count - 1; index >= 0; index--) { channel_item = (struct mcs_channel_item *) list_get_item(self->channel_list, index); g_free(channel_item); } list_delete(self->channel_list); xrdp_iso_delete(self->iso_layer); /* make sure we get null pointer exception if struct is used again. */ DEBUG(("xrdp_mcs_delete processed")) g_memset(self, 0, sizeof(struct xrdp_mcs)) ; g_free(self); } /*****************************************************************************/ /* This function sends channel join confirm */ /* returns error = 1 ok = 0 */ static int xrdp_mcs_send_cjcf(struct xrdp_mcs *self, int userid, int chanid) { struct stream *s; DEBUG((" in xrdp_mcs_send_cjcf")); make_stream(s); init_stream(s, 8192); if (xrdp_iso_init(self->iso_layer, s) != 0) { free_stream(s); DEBUG((" out xrdp_mcs_send_cjcf error")); return 1; } out_uint8(s, (MCS_CJCF << 2) | 2); out_uint8(s, 0); out_uint16_be(s, userid); out_uint16_be(s, chanid); /* TODO Explain why we send this two times */ out_uint16_be(s, chanid); s_mark_end(s); if (xrdp_iso_send(self->iso_layer, s) != 0) { free_stream(s); DEBUG((" out xrdp_mcs_send_cjcf error")); return 1; } free_stream(s); DEBUG((" out xrdp_mcs_send_cjcf")); return 0; } /*****************************************************************************/ /* returns error */ int xrdp_mcs_recv(struct xrdp_mcs *self, struct stream *s, int *chan) { int appid; int opcode; int len; int userid; int chanid; DEBUG((" in xrdp_mcs_recv")); while (1) { if (xrdp_iso_recv(self->iso_layer, s) != 0) { DEBUG((" out xrdp_mcs_recv, xrdp_iso_recv return non zero")); g_writeln("xrdp_mcs_recv: xrdp_iso_recv failed"); return 1; } if (!s_check_rem(s, 1)) { return 1; } in_uint8(s, opcode); appid = opcode >> 2; if (appid == MCS_DPUM) /* Disconnect Provider Ultimatum */ { g_writeln("received Disconnect Provider Ultimatum"); DEBUG((" out xrdp_mcs_recv appid != MCS_DPUM")); return 1; } /* this is channels getting added from the client */ if (appid == MCS_CJRQ) { if (!s_check_rem(s, 4)) { return 1; } in_uint16_be(s, userid); in_uint16_be(s, chanid); log_message(LOG_LEVEL_DEBUG,"MCS_CJRQ - channel join request received"); DEBUG(("xrdp_mcs_recv adding channel %4.4x", chanid)); if (xrdp_mcs_send_cjcf(self, userid, chanid) != 0) { log_message(LOG_LEVEL_ERROR,"Non handled error from xrdp_mcs_send_cjcf") ; } s = libxrdp_force_read(self->iso_layer->trans); if (s == 0) { g_writeln("xrdp_mcs_recv: libxrdp_force_read failed"); return 1; } continue; } if (appid == MCS_SDRQ || appid == MCS_SDIN) { break; } else { log_message(LOG_LEVEL_DEBUG,"Received an unhandled appid:%d",appid); } break; } if (appid != MCS_SDRQ) { DEBUG((" out xrdp_mcs_recv err got 0x%x need MCS_SDRQ", appid)); return 1; } if (!s_check_rem(s, 6)) { return 1; } in_uint8s(s, 2); in_uint16_be(s, *chan); in_uint8s(s, 1); in_uint8(s, len); if (len & 0x80) { if (!s_check_rem(s, 1)) { return 1; } in_uint8s(s, 1); } DEBUG((" out xrdp_mcs_recv")); return 0; } /*****************************************************************************/ /* returns error */ static int xrdp_mcs_ber_parse_header(struct xrdp_mcs *self, struct stream *s, int tag_val, int *len) { int tag; int l; int i; if (tag_val > 0xff) { if (!s_check_rem(s, 2)) { return 1; } in_uint16_be(s, tag); } else { if (!s_check_rem(s, 1)) { return 1; } in_uint8(s, tag); } if (tag != tag_val) { return 1; } if (!s_check_rem(s, 1)) { return 1; } in_uint8(s, l); if (l & 0x80) { l = l & ~0x80; *len = 0; while (l > 0) { if (!s_check_rem(s, 1)) { return 1; } in_uint8(s, i); *len = (*len << 8) | i; l--; } } else { *len = l; } if (s_check(s)) { return 0; } else { return 1; } } /*****************************************************************************/ /* returns error */ static int xrdp_mcs_parse_domain_params(struct xrdp_mcs *self, struct stream *s) { int len; if (xrdp_mcs_ber_parse_header(self, s, MCS_TAG_DOMAIN_PARAMS, &len) != 0) { return 1; } if ((len < 0) || !s_check_rem(s, len)) { return 1; } in_uint8s(s, len); if (s_check(s)) { return 0; } else { return 1; } } /*****************************************************************************/ /* returns error */ static int xrdp_mcs_recv_connect_initial(struct xrdp_mcs *self) { int len; struct stream *s; s = libxrdp_force_read(self->iso_layer->trans); if (s == 0) { return 1; } if (xrdp_iso_recv(self->iso_layer, s) != 0) { return 1; } if (xrdp_mcs_ber_parse_header(self, s, MCS_CONNECT_INITIAL, &len) != 0) { return 1; } if (xrdp_mcs_ber_parse_header(self, s, BER_TAG_OCTET_STRING, &len) != 0) { return 1; } if ((len < 0) || !s_check_rem(s, len)) { return 1; } in_uint8s(s, len); if (xrdp_mcs_ber_parse_header(self, s, BER_TAG_OCTET_STRING, &len) != 0) { return 1; } if ((len < 0) || !s_check_rem(s, len)) { return 1; } in_uint8s(s, len); if (xrdp_mcs_ber_parse_header(self, s, BER_TAG_BOOLEAN, &len) != 0) { return 1; } if ((len < 0) || !s_check_rem(s, len)) { return 1; } in_uint8s(s, len); if (xrdp_mcs_parse_domain_params(self, s) != 0) { return 1; } if (xrdp_mcs_parse_domain_params(self, s) != 0) { return 1; } if (xrdp_mcs_parse_domain_params(self, s) != 0) { return 1; } if (xrdp_mcs_ber_parse_header(self, s, BER_TAG_OCTET_STRING, &len) != 0) { return 1; } /* mcs data can not be zero length */ if ((len <= 0) || (len > 16 * 1024)) { return 1; } if (!s_check_rem(s, len)) { return 1; } /* make a copy of client mcs data */ init_stream(self->client_mcs_data, len); out_uint8a(self->client_mcs_data, s->p, len); in_uint8s(s, len); s_mark_end(self->client_mcs_data); if (s_check_end(s)) { return 0; } else { return 1; } } /*****************************************************************************/ /* returns error */ static int xrdp_mcs_recv_edrq(struct xrdp_mcs *self) { int opcode; struct stream *s; DEBUG((" in xrdp_mcs_recv_edrq")); s = libxrdp_force_read(self->iso_layer->trans); if (s == 0) { return 1; } if (xrdp_iso_recv(self->iso_layer, s) != 0) { return 1; } if (!s_check_rem(s, 1)) { return 1; } in_uint8(s, opcode); if ((opcode >> 2) != MCS_EDRQ) { return 1; } if (!s_check_rem(s, 4)) { return 1; } in_uint8s(s, 2); in_uint8s(s, 2); if (opcode & 2) { if (!s_check_rem(s, 2)) { return 1; } in_uint16_be(s, self->userid); } if (!(s_check_end(s))) { return 1; } DEBUG((" out xrdp_mcs_recv_edrq")); return 0; } /*****************************************************************************/ /* returns error */ static int xrdp_mcs_recv_aurq(struct xrdp_mcs *self) { int opcode; struct stream *s; DEBUG((" in xrdp_mcs_recv_aurq")); s = libxrdp_force_read(self->iso_layer->trans); if (s == 0) { return 1; } if (xrdp_iso_recv(self->iso_layer, s) != 0) { return 1; } if (!s_check_rem(s, 1)) { return 1; } in_uint8(s, opcode); if ((opcode >> 2) != MCS_AURQ) { return 1; } if (opcode & 2) { if (!s_check_rem(s, 2)) { return 1; } in_uint16_be(s, self->userid); } if (!(s_check_end(s))) { return 1; } DEBUG((" out xrdp_mcs_recv_aurq")); return 0; } /*****************************************************************************/ /* returns error */ static int xrdp_mcs_send_aucf(struct xrdp_mcs *self) { struct stream *s; DEBUG((" in xrdp_mcs_send_aucf")); make_stream(s); init_stream(s, 8192); if (xrdp_iso_init(self->iso_layer, s) != 0) { free_stream(s); DEBUG((" out xrdp_mcs_send_aucf error")); return 1; } out_uint8(s, ((MCS_AUCF << 2) | 2)); out_uint8s(s, 1); out_uint16_be(s, self->userid); s_mark_end(s); if (xrdp_iso_send(self->iso_layer, s) != 0) { free_stream(s); DEBUG((" out xrdp_mcs_send_aucf error")); return 1; } free_stream(s); DEBUG((" out xrdp_mcs_send_aucf")); return 0; } /*****************************************************************************/ /* returns error */ static int xrdp_mcs_recv_cjrq(struct xrdp_mcs *self) { int opcode; struct stream *s; s = libxrdp_force_read(self->iso_layer->trans); if (s == 0) { return 1; } if (xrdp_iso_recv(self->iso_layer, s) != 0) { return 1; } if (!s_check_rem(s, 1)) { return 1; } in_uint8(s, opcode); if ((opcode >> 2) != MCS_CJRQ) { return 1; } if (!s_check_rem(s, 4)) { return 1; } in_uint8s(s, 4); if (opcode & 2) { if (!s_check_rem(s, 2)) { return 1; } in_uint8s(s, 2); } if (!(s_check_end(s))) { return 1; } return 0; } /*****************************************************************************/ /* returns error */ static int xrdp_mcs_ber_out_header(struct xrdp_mcs *self, struct stream *s, int tag_val, int len) { if (tag_val > 0xff) { out_uint16_be(s, tag_val); } else { out_uint8(s, tag_val); } if (len >= 0x80) { out_uint8(s, 0x82); out_uint16_be(s, len); } else { out_uint8(s, len); } return 0; } /*****************************************************************************/ /* returns error */ static int xrdp_mcs_ber_out_int8(struct xrdp_mcs *self, struct stream *s, int value) { xrdp_mcs_ber_out_header(self, s, BER_TAG_INTEGER, 1); out_uint8(s, value); return 0; } #if 0 /* not used */ /*****************************************************************************/ /* returns error */ static int xrdp_mcs_ber_out_int16(struct xrdp_mcs *self, struct stream *s, int value) { xrdp_mcs_ber_out_header(self, s, BER_TAG_INTEGER, 2); out_uint8(s, (value >> 8)); out_uint8(s, value); return 0; } #endif /*****************************************************************************/ /* returns error */ static int xrdp_mcs_ber_out_int24(struct xrdp_mcs *self, struct stream *s, int value) { xrdp_mcs_ber_out_header(self, s, BER_TAG_INTEGER, 3); out_uint8(s, (value >> 16)); out_uint8(s, (value >> 8)); out_uint8(s, value); return 0; } /*****************************************************************************/ /* returns error */ static int xrdp_mcs_out_domain_params(struct xrdp_mcs *self, struct stream *s, int max_channels, int max_users, int max_tokens, int max_pdu_size) { xrdp_mcs_ber_out_header(self, s, MCS_TAG_DOMAIN_PARAMS, 26); xrdp_mcs_ber_out_int8(self, s, max_channels); xrdp_mcs_ber_out_int8(self, s, max_users); xrdp_mcs_ber_out_int8(self, s, max_tokens); xrdp_mcs_ber_out_int8(self, s, 1); xrdp_mcs_ber_out_int8(self, s, 0); xrdp_mcs_ber_out_int8(self, s, 1); xrdp_mcs_ber_out_int24(self, s, max_pdu_size); xrdp_mcs_ber_out_int8(self, s, 2); return 0; } /*****************************************************************************/ /* prepare server gcc data to send in mcs response msg */ int xrdp_mcs_out_gcc_data(struct xrdp_sec *self) { struct stream *s; int num_channels_even; int num_channels; int index; int channel; int gcc_size; char* gcc_size_ptr; char* ud_ptr; num_channels = self->mcs_layer->channel_list->count; num_channels_even = num_channels + (num_channels & 1); s = &(self->server_mcs_data); init_stream(s, 8192); out_uint16_be(s, 5); /* AsnBerObjectIdentifier */ out_uint16_be(s, 0x14); out_uint8(s, 0x7c); out_uint16_be(s, 1); /* -- */ out_uint8(s, 0x2a); /* ConnectPDULen */ out_uint8(s, 0x14); out_uint8(s, 0x76); out_uint8(s, 0x0a); out_uint8(s, 1); out_uint8(s, 1); out_uint8(s, 0); out_uint16_le(s, 0xc001); out_uint8(s, 0); out_uint8(s, 0x4d); /* M */ out_uint8(s, 0x63); /* c */ out_uint8(s, 0x44); /* D */ out_uint8(s, 0x6e); /* n */ /* GCC Response Total Length - 2 bytes , set later */ gcc_size_ptr = s->p; /* RDPGCCUserDataResponseLength */ out_uint8s(s, 2); ud_ptr = s->p; /* User Data */ out_uint16_le(s, SEC_TAG_SRV_INFO); if (self->mcs_layer->iso_layer->rdpNegData) { out_uint16_le(s, 12); /* len */ } else { out_uint16_le(s, 8); /* len */ } out_uint8(s, 4); /* 4 = rdp5 1 = rdp4 */ out_uint8(s, 0); out_uint8(s, 8); out_uint8(s, 0); if (self->mcs_layer->iso_layer->rdpNegData) { /* RequestedProtocol */ out_uint32_le(s, self->mcs_layer->iso_layer->requestedProtocol); } out_uint16_le(s, SEC_TAG_SRV_CHANNELS); out_uint16_le(s, 8 + (num_channels_even * 2)); /* len */ out_uint16_le(s, MCS_GLOBAL_CHANNEL); /* 1003, 0x03eb main channel */ out_uint16_le(s, num_channels); /* number of other channels */ for (index = 0; index < num_channels_even; index++) { if (index < num_channels) { channel = MCS_GLOBAL_CHANNEL + (index + 1); out_uint16_le(s, channel); } else { out_uint16_le(s, 0); } } if (self->rsa_key_bytes == 64) { g_writeln("xrdp_sec_out_mcs_data: using 512 bit RSA key"); out_uint16_le(s, SEC_TAG_SRV_CRYPT); out_uint16_le(s, 0x00ec); /* len is 236 */ out_uint32_le(s, self->crypt_method); out_uint32_le(s, self->crypt_level); out_uint32_le(s, 32); /* 32 bytes random len */ out_uint32_le(s, 0xb8); /* 184 bytes rsa info(certificate) len */ out_uint8a(s, self->server_random, 32); /* here to end is certificate */ /* HKEY_LOCAL_MACHINE\SYSTEM\CurrentControlSet\Services\ */ /* TermService\Parameters\Certificate */ out_uint32_le(s, 1); out_uint32_le(s, 1); out_uint32_le(s, 1); out_uint16_le(s, SEC_TAG_PUBKEY); /* 0x0006 */ out_uint16_le(s, 0x005c); /* 92 bytes length of SEC_TAG_PUBKEY */ out_uint32_le(s, SEC_RSA_MAGIC); /* 0x31415352 'RSA1' */ out_uint32_le(s, 0x0048); /* 72 bytes modulus len */ out_uint32_be(s, 0x00020000); /* bit len */ out_uint32_be(s, 0x3f000000); /* data len */ out_uint8a(s, self->pub_exp, 4); /* pub exp */ out_uint8a(s, self->pub_mod, 64); /* pub mod */ out_uint8s(s, 8); /* pad */ out_uint16_le(s, SEC_TAG_KEYSIG); /* 0x0008 */ out_uint16_le(s, 72); /* len */ out_uint8a(s, self->pub_sig, 64); /* pub sig */ out_uint8s(s, 8); /* pad */ } else if (self->rsa_key_bytes == 256) { g_writeln("xrdp_sec_out_mcs_data: using 2048 bit RSA key"); out_uint16_le(s, SEC_TAG_SRV_CRYPT); out_uint16_le(s, 0x01ac); /* len is 428 */ out_uint32_le(s, self->crypt_method); out_uint32_le(s, self->crypt_level); out_uint32_le(s, 32); /* 32 bytes random len */ out_uint32_le(s, 0x178); /* 376 bytes rsa info(certificate) len */ out_uint8a(s, self->server_random, 32); /* here to end is certificate */ /* HKEY_LOCAL_MACHINE\SYSTEM\CurrentControlSet\Services\ */ /* TermService\Parameters\Certificate */ out_uint32_le(s, 1); out_uint32_le(s, 1); out_uint32_le(s, 1); out_uint16_le(s, SEC_TAG_PUBKEY); /* 0x0006 */ out_uint16_le(s, 0x011c); /* 284 bytes length of SEC_TAG_PUBKEY */ out_uint32_le(s, SEC_RSA_MAGIC); /* 0x31415352 'RSA1' */ out_uint32_le(s, 0x0108); /* 264 bytes modulus len */ out_uint32_be(s, 0x00080000); /* bit len */ out_uint32_be(s, 0xff000000); /* data len */ out_uint8a(s, self->pub_exp, 4); /* pub exp */ out_uint8a(s, self->pub_mod, 256); /* pub mod */ out_uint8s(s, 8); /* pad */ out_uint16_le(s, SEC_TAG_KEYSIG); /* 0x0008 */ out_uint16_le(s, 72); /* len */ out_uint8a(s, self->pub_sig, 64); /* pub sig */ out_uint8s(s, 8); /* pad */ } else if (self->rsa_key_bytes == 0) /* no security */ { g_writeln("xrdp_sec_out_mcs_data: using no security"); out_uint16_le(s, SEC_TAG_SRV_CRYPT); out_uint16_le(s, 12); /* len is 12 */ out_uint32_le(s, self->crypt_method); out_uint32_le(s, self->crypt_level); } else { g_writeln("xrdp_sec_out_mcs_data: error"); } /* end certificate */ s_mark_end(s); gcc_size = (int)(s->end - ud_ptr) | 0x8000; gcc_size_ptr[0] = gcc_size >> 8; gcc_size_ptr[1] = gcc_size; return 0; } /*****************************************************************************/ /* returns error */ static int xrdp_mcs_send_connect_response(struct xrdp_mcs *self) { int data_len; struct stream *s; DEBUG((" in xrdp_mcs_send_connect_response")); make_stream(s); init_stream(s, 8192); data_len = (int) (self->server_mcs_data->end - self->server_mcs_data->data); xrdp_iso_init(self->iso_layer, s); //TODO: we should calculate the whole length include MCS_CONNECT_RESPONSE xrdp_mcs_ber_out_header(self, s, MCS_CONNECT_RESPONSE, data_len > 0x80 ? data_len + 38 : data_len + 36); xrdp_mcs_ber_out_header(self, s, BER_TAG_RESULT, 1); out_uint8(s, 0); xrdp_mcs_ber_out_header(self, s, BER_TAG_INTEGER, 1); out_uint8(s, 0); xrdp_mcs_out_domain_params(self, s, 22, 3, 0, 0xfff8); xrdp_mcs_ber_out_header(self, s, BER_TAG_OCTET_STRING, data_len); /* mcs data */ out_uint8a(s, self->server_mcs_data->data, data_len); s_mark_end(s); if (xrdp_iso_send(self->iso_layer, s) != 0) { free_stream(s); DEBUG((" out xrdp_mcs_send_connect_response error")); return 1; } free_stream(s); DEBUG((" out xrdp_mcs_send_connect_response")); return 0; } /*****************************************************************************/ /* returns error */ int xrdp_mcs_incoming(struct xrdp_mcs *self) { int index; DEBUG((" in xrdp_mcs_incoming")); if (xrdp_mcs_recv_connect_initial(self) != 0) { return 1; } /* in xrdp_sec.c */ if (xrdp_sec_process_mcs_data(self->sec_layer) != 0) { return 1; } if (xrdp_mcs_out_gcc_data(self->sec_layer) != 0) { return 1; } if (xrdp_mcs_send_connect_response(self) != 0) { return 1; } if (xrdp_mcs_recv_edrq(self) != 0) { return 1; } if (xrdp_mcs_recv_aurq(self) != 0) { return 1; } if (xrdp_mcs_send_aucf(self) != 0) { return 1; } for (index = 0; index < self->channel_list->count + 2; index++) { if (xrdp_mcs_recv_cjrq(self) != 0) { return 1; } if (xrdp_mcs_send_cjcf(self, self->userid, self->userid + MCS_USERCHANNEL_BASE + index) != 0) { return 1; } } DEBUG((" out xrdp_mcs_incoming")); return 0; } /*****************************************************************************/ /* returns error */ int xrdp_mcs_init(struct xrdp_mcs *self, struct stream *s) { xrdp_iso_init(self->iso_layer, s); s_push_layer(s, mcs_hdr, 8); return 0; } /*****************************************************************************/ /* returns error */ /* Inform the callback that an mcs packet has been sent. This is needed so the module can send any high priority mcs packets like audio. */ static int xrdp_mcs_call_callback(struct xrdp_mcs *self) { int rv; struct xrdp_session *session; rv = 0; /* if there is a callback, call it here */ session = self->sec_layer->rdp_layer->session; if (session != 0) { if (session->callback != 0) { /* in xrdp_wm.c */ rv = session->callback(session->id, 0x5556, 0, 0, 0, 0); } else { g_writeln("in xrdp_mcs_send, session->callback is nil"); } } else { g_writeln("in xrdp_mcs_send, session is nil"); } return rv; } /*****************************************************************************/ /* returns error */ int xrdp_mcs_send(struct xrdp_mcs *self, struct stream *s, int chan) { int len; char *lp; //static int max_len = 0; DEBUG((" in xrdp_mcs_send")); s_pop_layer(s, mcs_hdr); len = (s->end - s->p) - 8; if (len > 8192 * 2) { g_writeln("error in xrdp_mcs_send, size too big: %d bytes", len); } //if (len > max_len) //{ // max_len = len; // g_printf("mcs max length is %d\r\n", max_len); //} //g_printf("mcs length %d max length is %d\r\n", len, max_len); //g_printf("mcs length %d\r\n", len); out_uint8(s, MCS_SDIN << 2); out_uint16_be(s, self->userid); out_uint16_be(s, chan); out_uint8(s, 0x70); if (len >= 128) { len = len | 0x8000; out_uint16_be(s, len); } else { out_uint8(s, len); /* move everything up one byte */ lp = s->p; while (lp < s->end) { lp[0] = lp[1]; lp++; } s->end--; } if (xrdp_iso_send(self->iso_layer, s) != 0) { DEBUG((" out xrdp_mcs_send error")); return 1; } /* todo, do we need to call this for every mcs packet, maybe every 5 or so */ if (chan == MCS_GLOBAL_CHANNEL) { xrdp_mcs_call_callback(self); } DEBUG((" out xrdp_mcs_send")); return 0; } /** * Internal help function to close the socket * @param self */ void close_rdp_socket(struct xrdp_mcs *self) { if (self->iso_layer != 0) { if (self->iso_layer->trans != 0) { trans_shutdown_tls_mode(self->iso_layer->trans); g_tcp_close(self->iso_layer->trans->sck); self->iso_layer->trans->sck = 0 ; g_writeln("xrdp_mcs_disconnect - socket closed"); return; } } g_writeln("Failed to close socket"); } /*****************************************************************************/ /* returns error */ int xrdp_mcs_disconnect(struct xrdp_mcs *self) { struct stream *s; DEBUG((" in xrdp_mcs_disconnect")); make_stream(s); init_stream(s, 8192); if (xrdp_iso_init(self->iso_layer, s) != 0) { free_stream(s); close_rdp_socket(self); DEBUG((" out xrdp_mcs_disconnect error - 1")); return 1; } out_uint8(s, (MCS_DPUM << 2) | 1); out_uint8(s, 0x80); s_mark_end(s); if (xrdp_iso_send(self->iso_layer, s) != 0) { free_stream(s); close_rdp_socket(self); DEBUG((" out xrdp_mcs_disconnect error - 2")); return 1; } free_stream(s); close_rdp_socket(self); DEBUG(("xrdp_mcs_disconnect - close sent")); return 0; } xrdp-0.9.5/libxrdp/Makefile.am000644 001751 001751 00000002266 13174271344 016136 0ustar00metameta000000 000000 EXTRA_DIST = \ xrdp_surface.c AM_CPPFLAGS = \ -DXRDP_CFG_PATH=\"${sysconfdir}/xrdp\" \ -DXRDP_SBIN_PATH=\"${sbindir}\" \ -DXRDP_SHARE_PATH=\"${datadir}/xrdp\" \ -DXRDP_PID_PATH=\"${localstatedir}/run\" \ -I$(top_srcdir)/common AM_CFLAGS = $(OPENSSL_CFLAGS) AM_LDFLAGS = LIBXRDP_EXTRA_LIBS = if XRDP_DEBUG AM_CPPFLAGS += -DXRDP_DEBUG endif if XRDP_NEUTRINORDP AM_CPPFLAGS += -DXRDP_NEUTRINORDP LIBXRDP_EXTRA_LIBS += $(FREERDP_LIBS) endif if XRDP_RFXCODEC AM_CPPFLAGS += -DXRDP_RFXCODEC endif if XRDP_TJPEG AM_CPPFLAGS += -DXRDP_JPEG -DXRDP_TJPEG @TurboJpegIncDir@ AM_LDFLAGS += @TurboJpegLibDir@ LIBXRDP_EXTRA_LIBS += -lturbojpeg else if XRDP_JPEG AM_CPPFLAGS += -DXRDP_JPEG LIBXRDP_EXTRA_LIBS += -ljpeg endif endif module_LTLIBRARIES = \ libxrdp.la libxrdp_la_SOURCES = \ libxrdp.c \ libxrdp.h \ libxrdpinc.h \ xrdp_bitmap32_compress.c \ xrdp_bitmap_compress.c \ xrdp_caps.c \ xrdp_channel.c \ xrdp_fastpath.c \ xrdp_iso.c \ xrdp_jpeg_compress.c \ xrdp_mcs.c \ xrdp_mppc_enc.c \ xrdp_orders.c \ xrdp_orders_rail.c \ xrdp_orders_rail.h \ xrdp_rdp.c \ xrdp_sec.c libxrdp_la_LIBADD = \ $(top_builddir)/common/libcommon.la \ $(LIBXRDP_EXTRA_LIBS) xrdp-0.9.5/libxrdp/xrdp_surface.c000644 001751 001751 00000012075 13174271344 016732 0ustar00metameta000000 000000 /** * xrdp: A Remote Desktop Protocol server. * * Copyright (C) Jay Sorg 2012-2013 * Copyright (C) Kevin Zhou 2012 * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ #if defined(HAVE_CONFIG_H) #include #endif #include "libxrdp.h" #include "freerdp/codec/rfx.h" /*****************************************************************************/ struct xrdp_surface * xrdp_surface_create(struct xrdp_session *session, struct xrdp_fastpath *fastpath) { struct xrdp_surface *self; self = (struct xrdp_surface *)g_malloc(sizeof(struct xrdp_surface), 1); self->session = session; self->fastpath = fastpath; self->rfx_context = rfx_context_new(); self->s = stream_new(16384); return self; } /*****************************************************************************/ void xrdp_surface_delete(struct xrdp_surface *self) { STREAM *s; RFX_CONTEXT *rfx_context; if (self == 0) { return; } s = (STREAM *)(self->s); rfx_context = (RFX_CONTEXT *)(self->rfx_context); free_stream(self->out_s); stream_free(s); rfx_context_free(rfx_context); g_free(self); } /*****************************************************************************/ /* returns error */ int xrdp_surface_reset(struct xrdp_surface *self) { return 0; } /*****************************************************************************/ int xrdp_surface_init(struct xrdp_surface *self) { int width; int height; RFX_CONTEXT *rfx_context; rfx_context = (RFX_CONTEXT *)(self->rfx_context); width = self->session->client_info->width; height = self->session->client_info->height; rfx_context->mode = self->session->client_info->rfx_entropy; rfx_context->width = width; rfx_context->height = height; make_stream(self->out_s); init_stream(self->out_s, 2 * 3 * width * height + 22); return 0; } /*****************************************************************************/ int xrdp_surface_send_surface_bits(struct xrdp_surface *self, int bpp, char *data, int x, int y, int cx, int cy) { RFX_RECT rect; char *buf; int Bpp; int i; int j; int codecId; uint32 bitmapDataLength; STREAM *s; RFX_CONTEXT *rfx_context; s = (STREAM *)(self->s); rfx_context = (RFX_CONTEXT *)(self->rfx_context); if ((bpp == 24) || (bpp == 32)) { } else { g_writeln("bpp = %d is not supported\n", bpp); return 1; } Bpp = 4; rect.x = 0; rect.y = 0; rect.width = cx; rect.height = cy; init_stream(self->out_s, 0); stream_set_pos(s, 0); rfx_compose_message(rfx_context, s, &rect, 1, data, cx, cy, Bpp * cx); codecId = self->session->client_info->rfx_codecId; /* surface_bits_command */ out_uint16_le(self->out_s, CMDTYPE_STREAM_SURFACE_BITS); /* cmdType */ out_uint16_le(self->out_s, x); /* destLeft */ out_uint16_le(self->out_s, y); /* destTop */ out_uint16_le(self->out_s, x + cx); /* destRight */ out_uint16_le(self->out_s, y + cy); /* destBottom */ out_uint8(self->out_s, 32); /* bpp */ out_uint8(self->out_s, 0); /* reserved1 */ out_uint8(self->out_s, 0); /* reserved2 */ out_uint8(self->out_s, codecId); /* codecId */ out_uint16_le(self->out_s, cx); /* width */ out_uint16_le(self->out_s, cy); /* height */ bitmapDataLength = stream_get_length(s); out_uint32_le(self->out_s, bitmapDataLength); /* bitmapDataLength */ /* rfx bit stream */ out_uint8p(self->out_s, s->data, bitmapDataLength); s_mark_end(self->out_s); return xrdp_fastpath_send_update_pdu(self->fastpath, FASTPATH_UPDATETYPE_SURFCMDS, self->out_s); } /*****************************************************************************/ int xrdp_surface_send_frame_marker(struct xrdp_surface *self, uint16 frameAction, uint32 frameId) { init_stream(self->out_s, 0); out_uint16_le(self->out_s, CMDTYPE_FRAME_MARKER); out_uint16_le(self->out_s, frameAction); out_uint32_le(self->out_s, frameId); s_mark_end(self->out_s); return xrdp_fastpath_send_update_pdu(self->fastpath, FASTPATH_UPDATETYPE_SURFCMDS, self->out_s); } xrdp-0.9.5/libxrdp/xrdp_mppc_enc.c000644 001751 001751 00000072657 13174271344 017102 0ustar00metameta000000 000000 /** * FreeRDP: A Remote Desktop Protocol Implementation * Implements Microsoft Point to Point Compression (MPPC) protocol * * Copyright 2012-2013 Laxmikant Rashinkar * Copyright 2012-2013 Jay Sorg * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ #if defined(HAVE_CONFIG_H) #include #endif #include "libxrdp.h" #define MPPC_ENC_DEBUG 0 #if MPPC_ENC_DEBUG #define DLOG(_args) g_printf _args #else #define DLOG(_args) do { } while (0) #endif /* local defines */ #define RDP_40_HIST_BUF_LEN (1024 * 8) /* RDP 4.0 uses 8K history buf */ #define RDP_50_HIST_BUF_LEN (1024 * 64) /* RDP 5.0 uses 64K history buf */ /* Compression Types */ #define PACKET_COMPRESSED 0x20 #define PACKET_AT_FRONT 0x40 #define PACKET_FLUSHED 0x80 #define PACKET_COMPR_TYPE_8K 0x00 #define PACKET_COMPR_TYPE_64K 0x01 #define PACKET_COMPR_TYPE_RDP6 0x02 #define PACKET_COMPR_TYPE_RDP61 0x03 #define CompressionTypeMask 0x0F #define CRC_INIT 0xFFFF #define CRC(_crcval, _newchar) _crcval = \ ((_crcval) >> 8) ^ g_crc_table[((_crcval) ^ (_newchar)) & 0x00ff] /* CRC16 defs */ static const tui16 g_crc_table[256] = { 0x0000, 0x1189, 0x2312, 0x329b, 0x4624, 0x57ad, 0x6536, 0x74bf, 0x8c48, 0x9dc1, 0xaf5a, 0xbed3, 0xca6c, 0xdbe5, 0xe97e, 0xf8f7, 0x1081, 0x0108, 0x3393, 0x221a, 0x56a5, 0x472c, 0x75b7, 0x643e, 0x9cc9, 0x8d40, 0xbfdb, 0xae52, 0xdaed, 0xcb64, 0xf9ff, 0xe876, 0x2102, 0x308b, 0x0210, 0x1399, 0x6726, 0x76af, 0x4434, 0x55bd, 0xad4a, 0xbcc3, 0x8e58, 0x9fd1, 0xeb6e, 0xfae7, 0xc87c, 0xd9f5, 0x3183, 0x200a, 0x1291, 0x0318, 0x77a7, 0x662e, 0x54b5, 0x453c, 0xbdcb, 0xac42, 0x9ed9, 0x8f50, 0xfbef, 0xea66, 0xd8fd, 0xc974, 0x4204, 0x538d, 0x6116, 0x709f, 0x0420, 0x15a9, 0x2732, 0x36bb, 0xce4c, 0xdfc5, 0xed5e, 0xfcd7, 0x8868, 0x99e1, 0xab7a, 0xbaf3, 0x5285, 0x430c, 0x7197, 0x601e, 0x14a1, 0x0528, 0x37b3, 0x263a, 0xdecd, 0xcf44, 0xfddf, 0xec56, 0x98e9, 0x8960, 0xbbfb, 0xaa72, 0x6306, 0x728f, 0x4014, 0x519d, 0x2522, 0x34ab, 0x0630, 0x17b9, 0xef4e, 0xfec7, 0xcc5c, 0xddd5, 0xa96a, 0xb8e3, 0x8a78, 0x9bf1, 0x7387, 0x620e, 0x5095, 0x411c, 0x35a3, 0x242a, 0x16b1, 0x0738, 0xffcf, 0xee46, 0xdcdd, 0xcd54, 0xb9eb, 0xa862, 0x9af9, 0x8b70, 0x8408, 0x9581, 0xa71a, 0xb693, 0xc22c, 0xd3a5, 0xe13e, 0xf0b7, 0x0840, 0x19c9, 0x2b52, 0x3adb, 0x4e64, 0x5fed, 0x6d76, 0x7cff, 0x9489, 0x8500, 0xb79b, 0xa612, 0xd2ad, 0xc324, 0xf1bf, 0xe036, 0x18c1, 0x0948, 0x3bd3, 0x2a5a, 0x5ee5, 0x4f6c, 0x7df7, 0x6c7e, 0xa50a, 0xb483, 0x8618, 0x9791, 0xe32e, 0xf2a7, 0xc03c, 0xd1b5, 0x2942, 0x38cb, 0x0a50, 0x1bd9, 0x6f66, 0x7eef, 0x4c74, 0x5dfd, 0xb58b, 0xa402, 0x9699, 0x8710, 0xf3af, 0xe226, 0xd0bd, 0xc134, 0x39c3, 0x284a, 0x1ad1, 0x0b58, 0x7fe7, 0x6e6e, 0x5cf5, 0x4d7c, 0xc60c, 0xd785, 0xe51e, 0xf497, 0x8028, 0x91a1, 0xa33a, 0xb2b3, 0x4a44, 0x5bcd, 0x6956, 0x78df, 0x0c60, 0x1de9, 0x2f72, 0x3efb, 0xd68d, 0xc704, 0xf59f, 0xe416, 0x90a9, 0x8120, 0xb3bb, 0xa232, 0x5ac5, 0x4b4c, 0x79d7, 0x685e, 0x1ce1, 0x0d68, 0x3ff3, 0x2e7a, 0xe70e, 0xf687, 0xc41c, 0xd595, 0xa12a, 0xb0a3, 0x8238, 0x93b1, 0x6b46, 0x7acf, 0x4854, 0x59dd, 0x2d62, 0x3ceb, 0x0e70, 0x1ff9, 0xf78f, 0xe606, 0xd49d, 0xc514, 0xb1ab, 0xa022, 0x92b9, 0x8330, 0x7bc7, 0x6a4e, 0x58d5, 0x495c, 0x3de3, 0x2c6a, 0x1ef1, 0x0f78 }; /***************************************************************************** insert 2 bits into outputBuffer ******************************************************************************/ #define insert_2_bits(_data) \ do \ { \ if ((bits_left >= 3) && (bits_left <= 8)) \ { \ i = bits_left - 2; \ outputBuffer[opb_index] |= _data << i; \ bits_left = i; \ } \ else \ { \ i = 2 - bits_left; \ j = 8 - i; \ outputBuffer[opb_index++] |= _data >> i; \ outputBuffer[opb_index] |= _data << j; \ bits_left = j; \ } \ } while (0) /***************************************************************************** insert 3 bits into outputBuffer ******************************************************************************/ #define insert_3_bits(_data) \ do \ { \ if ((bits_left >= 4) && (bits_left <= 8)) \ { \ i = bits_left - 3; \ outputBuffer[opb_index] |= _data << i; \ bits_left = i; \ } \ else \ { \ i = 3 - bits_left; \ j = 8 - i; \ outputBuffer[opb_index++] |= _data >> i; \ outputBuffer[opb_index] |= _data << j; \ bits_left = j; \ } \ } while (0) /***************************************************************************** insert 4 bits into outputBuffer ******************************************************************************/ #define insert_4_bits(_data) \ do \ { \ if ((bits_left >= 5) && (bits_left <= 8)) \ { \ i = bits_left - 4; \ outputBuffer[opb_index] |= _data << i; \ bits_left = i; \ } \ else \ { \ i = 4 - bits_left; \ j = 8 - i; \ outputBuffer[opb_index++] |= _data >> i; \ outputBuffer[opb_index] |= _data << j; \ bits_left = j; \ } \ } while (0) /***************************************************************************** insert 5 bits into outputBuffer ******************************************************************************/ #define insert_5_bits(_data) \ do \ { \ if ((bits_left >= 6) && (bits_left <= 8)) \ { \ i = bits_left - 5; \ outputBuffer[opb_index] |= _data << i; \ bits_left = i; \ } \ else \ { \ i = 5 - bits_left; \ j = 8 - i; \ outputBuffer[opb_index++] |= _data >> i; \ outputBuffer[opb_index] |= _data << j; \ bits_left = j; \ } \ } while (0) /***************************************************************************** insert 6 bits into outputBuffer ******************************************************************************/ #define insert_6_bits(_data) \ do \ { \ if ((bits_left >= 7) && (bits_left <= 8)) \ { \ i = bits_left - 6; \ outputBuffer[opb_index] |= (_data << i); \ bits_left = i; \ } \ else \ { \ i = 6 - bits_left; \ j = 8 - i; \ outputBuffer[opb_index++] |= (_data >> i); \ outputBuffer[opb_index] |= (_data << j); \ bits_left = j; \ } \ } while (0) /***************************************************************************** insert 7 bits into outputBuffer ******************************************************************************/ #define insert_7_bits(_data) \ do \ { \ if (bits_left == 8) \ { \ outputBuffer[opb_index] |= _data << 1; \ bits_left = 1; \ } \ else \ { \ i = 7 - bits_left; \ j = 8 - i; \ outputBuffer[opb_index++] |= _data >> i; \ outputBuffer[opb_index] |= _data << j; \ bits_left = j; \ } \ } while (0) /***************************************************************************** insert 8 bits into outputBuffer ******************************************************************************/ #define insert_8_bits(_data) \ do \ { \ if (bits_left == 8) \ { \ outputBuffer[opb_index++] |= _data; \ bits_left = 8; \ } \ else \ { \ i = 8 - bits_left; \ j = 8 - i; \ outputBuffer[opb_index++] |= _data >> i; \ outputBuffer[opb_index] |= _data << j; \ bits_left = j; \ } \ } while (0) /***************************************************************************** insert 9 bits into outputBuffer ******************************************************************************/ #define insert_9_bits(_data16) \ do \ { \ i = 9 - bits_left; \ j = 8 - i; \ outputBuffer[opb_index++] |= (char) (_data16 >> i); \ outputBuffer[opb_index] |= (char) (_data16 << j); \ bits_left = j; \ if (bits_left == 0) \ { \ opb_index++; \ bits_left = 8; \ } \ } while (0) /***************************************************************************** insert 10 bits into outputBuffer ******************************************************************************/ #define insert_10_bits(_data16) \ do \ { \ i = 10 - bits_left; \ if ((bits_left >= 3) && (bits_left <= 8)) \ { \ j = 8 - i; \ outputBuffer[opb_index++] |= (char) (_data16 >> i); \ outputBuffer[opb_index] |= (char) (_data16 << j); \ bits_left = j; \ } \ else \ { \ j = i - 8; \ k = 8 - j; \ outputBuffer[opb_index++] |= (char) (_data16 >> i); \ outputBuffer[opb_index++] |= (char) (_data16 >> j); \ outputBuffer[opb_index] |= (char) (_data16 << k); \ bits_left = k; \ } \ } while (0) /***************************************************************************** insert 11 bits into outputBuffer ******************************************************************************/ #define insert_11_bits(_data16) \ do \ { \ i = 11 - bits_left; \ if ((bits_left >= 4) && (bits_left <= 8)) \ { \ j = 8 - i; \ outputBuffer[opb_index++] |= (char) (_data16 >> i); \ outputBuffer[opb_index] |= (char) (_data16 << j); \ bits_left = j; \ } \ else \ { \ j = i - 8; \ k = 8 - j; \ outputBuffer[opb_index++] |= (char) (_data16 >> i); \ outputBuffer[opb_index++] |= (char) (_data16 >> j); \ outputBuffer[opb_index] |= (char) (_data16 << k); \ bits_left = k; \ } \ } while (0) /***************************************************************************** insert 12 bits into outputBuffer ******************************************************************************/ #define insert_12_bits(_data16) \ do \ { \ i = 12 - bits_left; \ if ((bits_left >= 5) && (bits_left <= 8)) \ { \ j = 8 - i; \ outputBuffer[opb_index++] |= (char) (_data16 >> i); \ outputBuffer[opb_index] |= (char) (_data16 << j); \ bits_left = j; \ } \ else \ { \ j = i - 8; \ k = 8 - j; \ outputBuffer[opb_index++] |= (char) (_data16 >> i); \ outputBuffer[opb_index++] |= (char) (_data16 >> j); \ outputBuffer[opb_index] |= (char) (_data16 << k); \ bits_left = k; \ } \ } while (0) /***************************************************************************** insert 13 bits into outputBuffer ******************************************************************************/ #define insert_13_bits(_data16) \ do \ { \ i = 13 - bits_left; \ if ((bits_left >= 6) && (bits_left <= 8)) \ { \ j = 8 - i; \ outputBuffer[opb_index++] |= (char) (_data16 >> i); \ outputBuffer[opb_index] |= (char) (_data16 << j); \ bits_left = j; \ } \ else \ { \ j = i - 8; \ k = 8 - j; \ outputBuffer[opb_index++] |= (char) (_data16 >> i); \ outputBuffer[opb_index++] |= (char) (_data16 >> j); \ outputBuffer[opb_index] |= (char) (_data16 << k); \ bits_left = k; \ } \ } while (0) /***************************************************************************** insert 14 bits into outputBuffer ******************************************************************************/ #define insert_14_bits(_data16) \ do \ { \ i = 14 - bits_left; \ if ((bits_left >= 7) && (bits_left <= 8)) \ { \ j = 8 - i; \ outputBuffer[opb_index++] |= (char) (_data16 >> i); \ outputBuffer[opb_index] |= (char) (_data16 << j); \ bits_left = j; \ } \ else \ { \ j = i - 8; \ k = 8 - j; \ outputBuffer[opb_index++] |= (char) (_data16 >> i); \ outputBuffer[opb_index++] |= (char) (_data16 >> j); \ outputBuffer[opb_index] |= (char) (_data16 << k); \ bits_left = k; \ } \ } while (0) /***************************************************************************** insert 15 bits into outputBuffer ******************************************************************************/ #define insert_15_bits(_data16) \ do \ { \ i = 15 - bits_left; \ if (bits_left == 8) \ { \ j = 8 - i; \ outputBuffer[opb_index++] |= (char) (_data16 >> i); \ outputBuffer[opb_index] |= (char) (_data16 << j); \ bits_left = j; \ } \ else \ { \ j = i - 8; \ k = 8 - j; \ outputBuffer[opb_index++] |= (char) (_data16 >> i); \ outputBuffer[opb_index++] |= (char) (_data16 >> j); \ outputBuffer[opb_index] |= (char) (_data16 << k); \ bits_left = k; \ } \ } while (0) /***************************************************************************** insert 16 bits into outputBuffer ******************************************************************************/ #define insert_16_bits(_data16) \ do \ { \ i = 16 - bits_left; \ j = i - 8; \ k = 8 - j; \ outputBuffer[opb_index++] |= (char) (_data16 >> i); \ outputBuffer[opb_index++] |= (char) (_data16 >> j); \ outputBuffer[opb_index] |= (char) (_data16 << k); \ bits_left = k; \ } while (0) /** * Initialize mppc_enc structure * * @param protocol_type PROTO_RDP_40 or PROTO_RDP_50 * * @return struct xrdp_mppc_enc* or nil on failure */ struct xrdp_mppc_enc * mppc_enc_new(int protocol_type) { struct xrdp_mppc_enc *enc; enc = (struct xrdp_mppc_enc *) g_malloc(sizeof(struct xrdp_mppc_enc), 1); if (enc == 0) { return 0; } switch (protocol_type) { case PROTO_RDP_40: enc->protocol_type = PROTO_RDP_40; enc->buf_len = RDP_40_HIST_BUF_LEN; break; case PROTO_RDP_50: enc->protocol_type = PROTO_RDP_50; enc->buf_len = RDP_50_HIST_BUF_LEN; break; default: g_free(enc); return 0; } enc->flagsHold = PACKET_AT_FRONT; enc->historyBuffer = (char *) g_malloc(enc->buf_len, 1); if (enc->historyBuffer == 0) { g_free(enc); return 0; } enc->outputBufferPlus = (char *) g_malloc(enc->buf_len + 64, 1); if (enc->outputBufferPlus == 0) { g_free(enc->historyBuffer); g_free(enc); return 0; } enc->outputBuffer = enc->outputBufferPlus + 64; enc->hash_table = (tui16 *) g_malloc(enc->buf_len * 2, 1); if (enc->hash_table == 0) { g_free(enc->historyBuffer); g_free(enc->outputBufferPlus); g_free(enc); return 0; } return enc; } /** * deinit mppc_enc structure * * @param enc struct to be deinited */ void mppc_enc_free(struct xrdp_mppc_enc *enc) { if (enc == 0) { return; } g_free(enc->historyBuffer); g_free(enc->outputBufferPlus); g_free(enc->hash_table); g_free(enc); } /** * encode (compress) data using RDP 4.0 protocol * * @param enc encoder state info * @param srcData uncompressed data * @param len length of srcData * * @return TRUE on success, FALSE on failure */ static int compress_rdp_4(struct xrdp_mppc_enc *enc, tui8 *srcData, int len) { /* RDP 4.0 encoding not yet implemented */ return 0; } /** * encode (compress) data using RDP 5.0 protocol using hash table * * @param enc encoder state info * @param srcData uncompressed data * @param len length of srcData * * @return TRUE on success, FALSE on failure */ static int compress_rdp_5(struct xrdp_mppc_enc *enc, tui8 *srcData, int len) { char *outputBuffer; /* points to enc->outputBuffer */ char *hptr_end; /* points to end of history data */ char *historyPointer; /* points to first byte of srcData in * historyBuffer */ char *hbuf_start; /* points to start of history buffer */ char *cptr1; char *cptr2; int opb_index; /* index into outputBuffer */ int bits_left; /* unused bits in current byte in outputBuffer */ tui32 copy_offset; /* pattern match starts here... */ tui32 lom; /* ...and matches this many bytes */ int last_crc_index; /* don't compute CRC beyond this index */ tui16 *hash_table; /* hash table for pattern matching */ tui32 i; tui32 j; tui32 k; tui32 x; tui8 data; tui16 data16; tui32 historyOffset; tui16 crc; tui32 ctr; tui32 saved_ctr; tui32 data_end; tui8 byte_val; crc = 0; opb_index = 0; bits_left = 8; copy_offset = 0; hash_table = enc->hash_table; hbuf_start = enc->historyBuffer; outputBuffer = enc->outputBuffer; g_memset(outputBuffer, 0, len); enc->flags = PACKET_COMPR_TYPE_64K; if ((enc->historyOffset + len) >= enc->buf_len - 3) { /* historyBuffer cannot hold srcData - rewind it */ enc->historyOffset = 0; g_memset(hash_table, 0, enc->buf_len * 2); g_memset(enc->historyBuffer, 0, enc->buf_len); // added enc->flagsHold |= PACKET_AT_FRONT | PACKET_FLUSHED; } /* point to next free byte in historyBuffer */ historyOffset = enc->historyOffset; /* add / append new data to historyBuffer */ g_memcpy(&(enc->historyBuffer[historyOffset]), srcData, len); /* point to start of data to be compressed */ historyPointer = &(enc->historyBuffer[historyOffset]); ctr = copy_offset = lom = 0; /* if we are at start of history buffer, do not attempt to compress */ /* first 2 bytes, because minimum LoM is 3 */ if (historyOffset == 0) { /* encode first two bytes as literals */ for (x = 0; x < 2; x++) { data = *(historyPointer + x); DLOG(("%.2x ", (tui8) data)); if (data & 0x80) { /* insert encoded literal */ insert_2_bits(0x02); data &= 0x7f; insert_7_bits(data); } else { /* insert literal */ insert_8_bits(data); } } /* store hash for first two entries in historyBuffer */ crc = CRC_INIT; byte_val = enc->historyBuffer[0]; CRC(crc, byte_val); byte_val = enc->historyBuffer[1]; CRC(crc, byte_val); byte_val = enc->historyBuffer[2]; CRC(crc, byte_val); hash_table[crc] = 0; crc = CRC_INIT; byte_val = enc->historyBuffer[1]; CRC(crc, byte_val); byte_val = enc->historyBuffer[2]; CRC(crc, byte_val); byte_val = enc->historyBuffer[3]; CRC(crc, byte_val); hash_table[crc] = 1; /* first two bytes have already been processed */ ctr = 2; } enc->historyOffset += len; /* point to last byte in new data */ hptr_end = &(enc->historyBuffer[enc->historyOffset - 1]); /* do not compute CRC beyond this */ last_crc_index = enc->historyOffset - 3; /* do not search for pattern match beyond this */ data_end = len - 2; /* start compressing data */ while (ctr < data_end) { cptr1 = historyPointer + ctr; crc = CRC_INIT; byte_val = *cptr1; CRC(crc, byte_val); byte_val = *(cptr1 + 1); CRC(crc, byte_val); byte_val = *(cptr1 + 2); CRC(crc, byte_val); /* cptr2 points to start of pattern match */ cptr2 = hbuf_start + hash_table[crc]; copy_offset = cptr1 - cptr2; /* save current entry */ hash_table[crc] = cptr1 - hbuf_start; /* double check that we have a pattern match */ if ((*cptr1 != *cptr2) || (*(cptr1 + 1) != *(cptr2 + 1)) || (*(cptr1 + 2) != *(cptr2 + 2))) { /* no match found; encode literal byte */ data = *cptr1; DLOG(("%.2x ", data)); if (data < 0x80) { /* literal byte < 0x80 */ insert_8_bits(data); } else { /* literal byte >= 0x80 */ insert_2_bits(0x02); data &= 0x7f; insert_7_bits(data); } ctr++; continue; } /* we have a match - compute Length of Match */ cptr1 += 3; cptr2 += 3; lom = 3; while ((cptr1 <= hptr_end) && (*(cptr1++) == *(cptr2++))) { lom++; } saved_ctr = ctr + lom; DLOG(("<%d: %ld,%d> ", (historyPointer + ctr) - hbuf_start, copy_offset, lom)); /* compute CRC for matching segment and store in hash table */ cptr1 = historyPointer + ctr; if (cptr1 + lom > hbuf_start + last_crc_index) { /* we have gone beyond last_crc_index - go back */ j = last_crc_index - (cptr1 - hbuf_start); } else { j = lom - 1; } ctr++; for (i = 0; i < j; i++) { cptr1 = historyPointer + ctr; /* compute CRC on triplet */ crc = CRC_INIT; byte_val = *(cptr1++); CRC(crc, byte_val); byte_val = *(cptr1++); CRC(crc, byte_val); byte_val = *(cptr1++); CRC(crc, byte_val); /* save current entry */ hash_table[crc] = (cptr1 - 3) - hbuf_start; /* point to next triplet */ ctr++; } ctr = saved_ctr; /* encode copy_offset and insert into output buffer */ if (copy_offset <= 63) /* (copy_offset >= 0) is always true */ { /* insert binary header */ data = 0x1f; insert_5_bits(data); /* insert 6 bits of copy_offset */ data = (char) (copy_offset & 0x3f); insert_6_bits(data); } else if ((copy_offset >= 64) && (copy_offset <= 319)) { /* insert binary header */ data = 0x1e; insert_5_bits(data); /* insert 8 bits of copy offset */ data = (char) (copy_offset - 64); insert_8_bits(data); } else if ((copy_offset >= 320) && (copy_offset <= 2367)) { /* insert binary header */ data = 0x0e; insert_4_bits(data); /* insert 11 bits of copy offset */ data16 = copy_offset - 320;; insert_11_bits(data16); } else { /* copy_offset is 2368+ */ /* insert binary header */ data = 0x06; insert_3_bits(data); /* insert 16 bits of copy offset */ data16 = copy_offset - 2368;; insert_16_bits(data16); } /* encode length of match and insert into output buffer */ if (lom == 3) { /* binary header is 'zero'; since outputBuffer is zero */ /* filled, all we have to do is update bits_left */ bits_left--; if (bits_left == 0) { opb_index++; bits_left = 8; } } else if ((lom >= 4) && (lom <= 7)) { /* insert binary header */ data = 0x02; insert_2_bits(data); /* insert lower 2 bits of LoM */ data = (char) (lom - 4); insert_2_bits(data); } else if ((lom >= 8) && (lom <= 15)) { /* insert binary header */ data = 0x06; insert_3_bits(data); /* insert lower 3 bits of LoM */ data = (char) (lom - 8); insert_3_bits(data); } else if ((lom >= 16) && (lom <= 31)) { /* insert binary header */ data = 0x0e; insert_4_bits(data); /* insert lower 4 bits of LoM */ data = (char) (lom - 16); insert_4_bits(data); } else if ((lom >= 32) && (lom <= 63)) { /* insert binary header */ data = 0x1e; insert_5_bits(data); /* insert lower 5 bits of LoM */ data = (char) (lom - 32); insert_5_bits(data); } else if ((lom >= 64) && (lom <= 127)) { /* insert binary header */ data = 0x3e; insert_6_bits(data); /* insert lower 6 bits of LoM */ data = (char) (lom - 64); insert_6_bits(data); } else if ((lom >= 128) && (lom <= 255)) { /* insert binary header */ data = 0x7e; insert_7_bits(data); /* insert lower 7 bits of LoM */ data = (char) (lom - 128); insert_7_bits(data); } else if ((lom >= 256) && (lom <= 511)) { /* insert binary header */ data = 0xfe; insert_8_bits(data); /* insert lower 8 bits of LoM */ data = (char) (lom - 256); insert_8_bits(data); } else if ((lom >= 512) && (lom <= 1023)) { /* insert binary header */ data16 = 0x1fe; insert_9_bits(data16); /* insert lower 9 bits of LoM */ data16 = lom - 512; insert_9_bits(data16); } else if ((lom >= 1024) && (lom <= 2047)) { /* insert binary header */ data16 = 0x3fe; insert_10_bits(data16); /* insert 10 lower bits of LoM */ data16 = lom - 1024; insert_10_bits(data16); } else if ((lom >= 2048) && (lom <= 4095)) { /* insert binary header */ data16 = 0x7fe; insert_11_bits(data16); /* insert 11 lower bits of LoM */ data16 = lom - 2048; insert_11_bits(data16); } else if ((lom >= 4096) && (lom <= 8191)) { /* insert binary header */ data16 = 0xffe; insert_12_bits(data16); /* insert 12 lower bits of LoM */ data16 = lom - 4096; insert_12_bits(data16); } else if ((lom >= 8192) && (lom <= 16383)) { /* insert binary header */ data16 = 0x1ffe; insert_13_bits(data16); /* insert 13 lower bits of LoM */ data16 = lom - 8192; insert_13_bits(data16); } else if ((lom >= 16384) && (lom <= 32767)) { /* insert binary header */ data16 = 0x3ffe; insert_14_bits(data16); /* insert 14 lower bits of LoM */ data16 = lom - 16384; insert_14_bits(data16); } else if ((lom >= 32768) && (lom <= 65535)) { /* insert binary header */ data16 = 0x7ffe; insert_15_bits(data16); /* insert 15 lower bits of LoM */ data16 = lom - 32768; insert_15_bits(data16); } } /* end while (ctr < data_end) */ /* add remaining data to the output */ while (len - ctr > 0) { data = srcData[ctr]; DLOG(("%.2x ", data)); if (data < 0x80) { /* literal byte < 0x80 */ insert_8_bits(data); } else { /* literal byte >= 0x80 */ insert_2_bits(0x02); data &= 0x7f; insert_7_bits(data); } ctr++; } /* if bits_left != 8, increment opb_index, which is zero indexed */ if (bits_left != 8) { opb_index++; } if (opb_index > len) { /* compressed data longer than uncompressed data */ /* give up */ enc->historyOffset = 0; g_memset(hash_table, 0, enc->buf_len * 2); g_memset(enc->historyBuffer, 0, enc->buf_len); enc->flagsHold |= PACKET_AT_FRONT | PACKET_FLUSHED; return 0; } enc->flags |= PACKET_COMPRESSED; enc->bytes_in_opb = opb_index; enc->flags |= enc->flagsHold; enc->flagsHold = 0; DLOG(("\n")); //g_writeln("compression ratio: %f", (float) len / (float) enc->bytes_in_opb); return 1; } /** * encode (compress) data * * @param enc encoder state info * @param srcData uncompressed data * @param len length of srcData * * @return TRUE on success, FALSE on failure */ int compress_rdp(struct xrdp_mppc_enc *enc, tui8 *srcData, int len) { if ((enc == 0) || (srcData == 0) || (len <= 0) || (len > enc->buf_len)) { return 0; } switch (enc->protocol_type) { case PROTO_RDP_40: return compress_rdp_4(enc, srcData, len); break; case PROTO_RDP_50: return compress_rdp_5(enc, srcData, len); break; } return 0; } xrdp-0.9.5/libxrdp/xrdp_bitmap32_compress.c000644 001751 001751 00000035653 13201006747 020637 0ustar00metameta000000 000000 /** * xrdp: A Remote Desktop Protocol server. * * Copyright (C) Jay Sorg 2014 * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. * * planar bitmap compressor * 32 bpp compression */ /* RDP 6.0 Bitmap Compression http://msdn.microsoft.com/en-us/library/cc241877.aspx */ #if defined(HAVE_CONFIG_H) #include #endif #include "libxrdp.h" #define FLAGS_RLE 0x10 #define FLAGS_NOALPHA 0x20 #define LLOG_LEVEL 1 #define LLOGLN(_level, _args) \ do { if (_level < LLOG_LEVEL) { g_writeln _args ; } } while (0) #define LHEXDUMP(_level, _args) \ do { if (_level < LLOG_LEVEL) { g_hexdump _args ; } } while (0) /*****************************************************************************/ /* split RGB */ static int fsplit3(char *in_data, int start_line, int width, int e, char *r_data, char *g_data, char *b_data) { #if defined(L_ENDIAN) int rp; int gp; int bp; #endif int index; int out_index; int pixel; int cy; int *ptr32; cy = 0; out_index = 0; while (start_line >= 0) { ptr32 = (int *) (in_data + start_line * width * 4); index = 0; #if defined(L_ENDIAN) while (index + 4 <= width) { pixel = *ptr32; ptr32++; rp = (pixel >> 16) & 0x000000ff; gp = (pixel >> 8) & 0x000000ff; bp = (pixel >> 0) & 0x000000ff; pixel = *ptr32; ptr32++; rp |= (pixel >> 8) & 0x0000ff00; gp |= (pixel << 0) & 0x0000ff00; bp |= (pixel << 8) & 0x0000ff00; pixel = *ptr32; ptr32++; rp |= (pixel >> 0) & 0x00ff0000; gp |= (pixel << 8) & 0x00ff0000; bp |= (pixel << 16) & 0x00ff0000; pixel = *ptr32; ptr32++; rp |= (pixel << 8) & 0xff000000; gp |= (pixel << 16) & 0xff000000; bp |= (pixel << 24) & 0xff000000; *((int*)(r_data + out_index)) = rp; *((int*)(g_data + out_index)) = gp; *((int*)(b_data + out_index)) = bp; out_index += 4; index += 4; } #endif while (index < width) { pixel = *ptr32; ptr32++; r_data[out_index] = pixel >> 16; g_data[out_index] = pixel >> 8; b_data[out_index] = pixel >> 0; out_index++; index++; } for (index = 0; index < e; index++) { r_data[out_index] = r_data[out_index - 1]; g_data[out_index] = g_data[out_index - 1]; b_data[out_index] = b_data[out_index - 1]; out_index++; } start_line--; cy++; if (out_index + width + e > 64 * 64) { break; } } return cy; } /*****************************************************************************/ /* split ARGB */ static int fsplit4(char *in_data, int start_line, int width, int e, char *a_data, char *r_data, char *g_data, char *b_data) { #if defined(L_ENDIAN) int ap; int rp; int gp; int bp; #endif int index; int out_index; int pixel; int cy; int *ptr32; cy = 0; out_index = 0; while (start_line >= 0) { ptr32 = (int *) (in_data + start_line * width * 4); index = 0; #if defined(L_ENDIAN) while (index + 4 <= width) { pixel = *ptr32; ptr32++; ap = (pixel >> 24) & 0x000000ff; rp = (pixel >> 16) & 0x000000ff; gp = (pixel >> 8) & 0x000000ff; bp = (pixel >> 0) & 0x000000ff; pixel = *ptr32; ptr32++; ap |= (pixel >> 16) & 0x0000ff00; rp |= (pixel >> 8) & 0x0000ff00; gp |= (pixel << 0) & 0x0000ff00; bp |= (pixel << 8) & 0x0000ff00; pixel = *ptr32; ptr32++; ap |= (pixel >> 8) & 0x00ff0000; rp |= (pixel >> 0) & 0x00ff0000; gp |= (pixel << 8) & 0x00ff0000; bp |= (pixel << 16) & 0x00ff0000; pixel = *ptr32; ptr32++; ap |= (pixel << 0) & 0xff000000; rp |= (pixel << 8) & 0xff000000; gp |= (pixel << 16) & 0xff000000; bp |= (pixel << 24) & 0xff000000; *((int*)(a_data + out_index)) = ap; *((int*)(r_data + out_index)) = rp; *((int*)(g_data + out_index)) = gp; *((int*)(b_data + out_index)) = bp; out_index += 4; index += 4; } #endif while (index < width) { pixel = *ptr32; ptr32++; a_data[out_index] = pixel >> 24; r_data[out_index] = pixel >> 16; g_data[out_index] = pixel >> 8; b_data[out_index] = pixel >> 0; out_index++; index++; } for (index = 0; index < e; index++) { a_data[out_index] = a_data[out_index - 1]; r_data[out_index] = r_data[out_index - 1]; g_data[out_index] = g_data[out_index - 1]; b_data[out_index] = b_data[out_index - 1]; out_index++; } start_line--; cy++; if (out_index + width + e > 64 * 64) { break; } } return cy; } /*****************************************************************************/ #define DELTA_ONE \ do { \ delta = src8[cx] - src8[0]; \ is_neg = (delta >> 7) & 1; \ dst8[cx] = (((delta ^ -is_neg) + is_neg) << 1) - is_neg; \ src8++; \ dst8++; \ } while (0) /*****************************************************************************/ static int fdelta(char *in_plane, char *out_plane, int cx, int cy) { char delta; char is_neg; char *src8; char *dst8; char *src8_end; g_memcpy(out_plane, in_plane, cx); src8 = in_plane; dst8 = out_plane; src8_end = src8 + (cx * cy - cx); while (src8 + 8 <= src8_end) { DELTA_ONE; DELTA_ONE; DELTA_ONE; DELTA_ONE; DELTA_ONE; DELTA_ONE; DELTA_ONE; DELTA_ONE; } while (src8 < src8_end) { DELTA_ONE; } return 0; } /*****************************************************************************/ static int fout(int collen, int replen, char *colptr, struct stream *s) { int code; int lcollen; int lreplen; int cont; LLOGLN(10, ("fout: collen %d replen %d", collen, replen)); cont = collen > 13; while (cont) { lcollen = collen; if (lcollen > 15) { lcollen = 15; } code = lcollen << 4; out_uint8(s, code); out_uint8a(s, colptr, lcollen); colptr += lcollen; collen -= lcollen; cont = collen > 13; } cont = (collen > 0) || (replen > 0); while (cont) { lreplen = replen; if ((collen == 0) && (lreplen > 15)) { /* big run */ if (lreplen > 47) { lreplen = 47; } LLOGLN(10, ("fout: big run lreplen %d", lreplen)); replen -= lreplen; code = ((lreplen & 0xF) << 4) | ((lreplen & 0xF0) >> 4); out_uint8(s, code); colptr += lreplen; } else { if (lreplen > 15) { lreplen = 15; } replen -= lreplen; if (lreplen < 3) { collen += lreplen; lreplen = 0; } code = (collen << 4) | lreplen; out_uint8(s, code); out_uint8a(s, colptr, collen); colptr += collen + lreplen; collen = 0; } cont = replen > 0; } return 0; } /*****************************************************************************/ static int fpack(char *plane, int cx, int cy, struct stream *s) { char *ptr8; char *colptr; char *lend; char *holdp; int jndex; int collen; int replen; LLOGLN(10, ("fpack:")); holdp = s->p; for (jndex = 0; jndex < cy; jndex++) { LLOGLN(10, ("line start line %d cx %d cy %d", jndex, cx, cy)); ptr8 = plane + jndex * cx; LHEXDUMP(10, (ptr8, cx)); lend = ptr8 + (cx - 1); colptr = ptr8; if (colptr[0] == 0) { collen = 0; replen = 1; } else { collen = 1; replen = 0; } while (ptr8 < lend) { if (ptr8[0] == ptr8[1]) { replen++; } else { if (replen > 0) { if (replen < 3) { collen += replen + 1; replen = 0; } else { fout(collen, replen, colptr, s); colptr = ptr8 + 1; replen = 0; collen = 1; } } else { collen++; } } ptr8++; } /* end of line */ fout(collen, replen, colptr, s); } return (int) (s->p - holdp); } /*****************************************************************************/ static int foutraw3(struct stream *s, int bytes, int header, char *r_data, char *g_data, char *b_data) { out_uint8(s, header); out_uint8a(s, r_data, bytes); out_uint8a(s, g_data, bytes); out_uint8a(s, b_data, bytes); /* pad if no RLE */ out_uint8(s, 0x00); return 0; } /*****************************************************************************/ static int foutraw4(struct stream *s, int bytes, int header, char *a_data, char *r_data, char *g_data, char *b_data) { out_uint8(s, header); out_uint8a(s, a_data, bytes); out_uint8a(s, r_data, bytes); out_uint8a(s, g_data, bytes); out_uint8a(s, b_data, bytes); /* pad if no RLE */ out_uint8(s, 0x00); return 0; } /*****************************************************************************/ /* returns the number of lines compressed */ int xrdp_bitmap32_compress(char *in_data, int width, int height, struct stream *s, int bpp, int byte_limit, int start_line, struct stream *temp_s, int e, int flags) { char *a_data; char *r_data; char *g_data; char *b_data; char *sa_data; char *sr_data; char *sg_data; char *sb_data; char *hold_p; int a_bytes; int r_bytes; int g_bytes; int b_bytes; int cx; int cy; int max_bytes; int total_bytes; int header; LLOGLN(10, ("xrdp_bitmap32_compress:")); max_bytes = 4 * 1024; /* need max 8, 4K planes for work */ if (max_bytes * 8 > temp_s->size) { return 0; } header = flags & 0xFF; cx = width + e; sa_data = temp_s->data; sr_data = sa_data + max_bytes; sg_data = sr_data + max_bytes; sb_data = sg_data + max_bytes; a_data = sb_data + max_bytes; r_data = a_data + max_bytes; g_data = r_data + max_bytes; b_data = g_data + max_bytes; hold_p = s->p; if (header & FLAGS_NOALPHA) { cy = fsplit3(in_data, start_line, width, e, sr_data, sg_data, sb_data); if (header & FLAGS_RLE) { fdelta(sr_data, r_data, cx, cy); fdelta(sg_data, g_data, cx, cy); fdelta(sb_data, b_data, cx, cy); while (cy > 0) { s->p = hold_p; out_uint8(s, header); r_bytes = fpack(r_data, cx, cy, s); g_bytes = fpack(g_data, cx, cy, s); b_bytes = fpack(b_data, cx, cy, s); max_bytes = cx * cy * 3; total_bytes = r_bytes + g_bytes + b_bytes; if (total_bytes > max_bytes) { if (2 + max_bytes <= byte_limit) { s->p = hold_p; foutraw3(s, cx * cy, FLAGS_NOALPHA, sr_data, sg_data, sb_data); break; } } if (1 + total_bytes <= byte_limit) { break; } cy--; } } else { while (cy > 0) { max_bytes = cx * cy * 3; if (2 + max_bytes <= byte_limit) { s->p = hold_p; foutraw3(s, cx * cy, FLAGS_NOALPHA, sr_data, sg_data, sb_data); break; } cy--; } } } else { cy = fsplit4(in_data, start_line, width, e, sa_data, sr_data, sg_data, sb_data); if (header & FLAGS_RLE) { fdelta(sa_data, a_data, cx, cy); fdelta(sr_data, r_data, cx, cy); fdelta(sg_data, g_data, cx, cy); fdelta(sb_data, b_data, cx, cy); while (cy > 0) { s->p = hold_p; out_uint8(s, header); a_bytes = fpack(a_data, cx, cy, s); r_bytes = fpack(r_data, cx, cy, s); g_bytes = fpack(g_data, cx, cy, s); b_bytes = fpack(b_data, cx, cy, s); max_bytes = cx * cy * 4; total_bytes = a_bytes + r_bytes + g_bytes + b_bytes; if (total_bytes > max_bytes) { if (2 + max_bytes <= byte_limit) { s->p = hold_p; foutraw4(s, cx * cy, 0, sa_data, sr_data, sg_data, sb_data); break; } } if (1 + total_bytes <= byte_limit) { break; } cy--; } } else { while (cy > 0) { max_bytes = cx * cy * 4; if (2 + max_bytes <= byte_limit) { s->p = hold_p; foutraw4(s, cx * cy, 0, sa_data, sr_data, sg_data, sb_data); break; } cy--; } } } return cy; } xrdp-0.9.5/libxrdp/xrdp_orders_rail.c000644 001751 001751 00000052117 13174271344 017610 0ustar00metameta000000 000000 /** * xrdp: A Remote Desktop Protocol server. * * Copyright (C) Jay Sorg 2012-2013 * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ #if defined(HAVE_CONFIG_H) #include #endif #include "libxrdp.h" #include "xrdp_rail.h" /* [MS-RDPERP]: Remote Desktop Protocol: Remote Programs Virtual Channel Extension http://msdn.microsoft.com/en-us/library/cc242568(v=prot.10) */ /*****************************************************************************/ /* RAIL */ /* returns error */ int xrdp_orders_send_window_delete(struct xrdp_orders *self, int window_id) { int order_size; int order_flags; int field_present_flags; order_size = 11; if (xrdp_orders_check(self, order_size) != 0) { return 1; } self->order_count++; order_flags = RDP_ORDER_SECONDARY; order_flags |= 0xb << 2; /* type TS_ALTSEC_WINDOW */ out_uint8(self->out_s, order_flags); /* orderSize (2 bytes) */ out_uint16_le(self->out_s, order_size); /* FieldsPresentFlags (4 bytes) */ field_present_flags = WINDOW_ORDER_TYPE_WINDOW | WINDOW_ORDER_STATE_DELETED; out_uint32_le(self->out_s, field_present_flags); /* windowId (4 bytes) */ out_uint32_le(self->out_s, window_id); return 0; } /*****************************************************************************/ /* RAIL */ /* returns error */ /* flags can contain WINDOW_ORDER_STATE_NEW and/or WINDOW_ORDER_FIELD_ICON_BIG */ int xrdp_orders_send_window_cached_icon(struct xrdp_orders *self, int window_id, int cache_entry, int cache_id, int flags) { int order_size; int order_flags; int field_present_flags; order_size = 14; if (xrdp_orders_check(self, order_size) != 0) { return 1; } self->order_count++; order_flags = RDP_ORDER_SECONDARY; order_flags |= 0xb << 2; /* type TS_ALTSEC_WINDOW */ out_uint8(self->out_s, order_flags); /* orderSize (2 bytes) */ out_uint16_le(self->out_s, order_size); /* FieldsPresentFlags (4 bytes) */ field_present_flags = flags | WINDOW_ORDER_TYPE_WINDOW | WINDOW_ORDER_CACHED_ICON; out_uint32_le(self->out_s, field_present_flags); /* windowId (4 bytes) */ out_uint32_le(self->out_s, window_id); /* CacheEntry (2 bytes) */ out_uint16_le(self->out_s, cache_entry); /* CacheId (1 byte) */ out_uint8(self->out_s, cache_id); return 0; } /*****************************************************************************/ /* RAIL */ /* returns error */ static int xrdp_orders_send_ts_icon(struct stream *s, int cache_entry, int cache_id, struct rail_icon_info *icon_info) { int use_cmap; use_cmap = 0; if ((icon_info->bpp == 1) || (icon_info->bpp == 2) || (icon_info->bpp == 4)) { use_cmap = 1; } /* TS_ICON_INFO */ out_uint16_le(s, cache_entry); out_uint8(s, cache_id); out_uint8(s, icon_info->bpp); out_uint16_le(s, icon_info->width); out_uint16_le(s, icon_info->height); if (use_cmap) { out_uint16_le(s, icon_info->cmap_bytes); } out_uint16_le(s, icon_info->mask_bytes); out_uint16_le(s, icon_info->data_bytes); out_uint8p(s, icon_info->mask, icon_info->mask_bytes); if (use_cmap) { out_uint8p(s, icon_info->cmap, icon_info->cmap_bytes); } out_uint8p(s, icon_info->data, icon_info->data_bytes); return 0; } /*****************************************************************************/ /* RAIL */ /* returns error */ /* flags can contain WINDOW_ORDER_STATE_NEW and/or WINDOW_ORDER_FIELD_ICON_BIG */ int xrdp_orders_send_window_icon(struct xrdp_orders *self, int window_id, int cache_entry, int cache_id, struct rail_icon_info *icon_info, int flags) { int order_size; int order_flags; int field_present_flags; int use_cmap; use_cmap = 0; if ((icon_info->bpp == 1) || (icon_info->bpp == 2) || (icon_info->bpp == 4)) { use_cmap = 1; } order_size = 23 + icon_info->mask_bytes + icon_info->data_bytes; if (use_cmap) { order_size += icon_info->cmap_bytes + 2; } if (xrdp_orders_check(self, order_size) != 0) { return 1; } self->order_count++; order_flags = RDP_ORDER_SECONDARY; order_flags |= 0xb << 2; /* type TS_ALTSEC_WINDOW */ out_uint8(self->out_s, order_flags); /* orderSize (2 bytes) */ out_uint16_le(self->out_s, order_size); /* FieldsPresentFlags (4 bytes) */ field_present_flags = flags | WINDOW_ORDER_TYPE_WINDOW | WINDOW_ORDER_ICON; out_uint32_le(self->out_s, field_present_flags); /* windowId (4 bytes) */ out_uint32_le(self->out_s, window_id); xrdp_orders_send_ts_icon(self->out_s, cache_entry, cache_id, icon_info); return 0; } /*****************************************************************************/ /* returns error */ static int xrdp_orders_send_as_unicode(struct stream *s, const char *text) { int str_chars; int index; int i32; int len; twchar *wdst; len = g_strlen(text) + 1; wdst = (twchar *) g_malloc(sizeof(twchar) * len, 1); if (wdst == 0) { return 1; } str_chars = g_mbstowcs(wdst, text, len); if (str_chars > 0) { i32 = str_chars * 2; out_uint16_le(s, i32); for (index = 0; index < str_chars; index++) { i32 = wdst[index]; out_uint16_le(s, i32); } } else { out_uint16_le(s, 0); } g_free(wdst); return 0; } /*****************************************************************************/ static int xrdp_orders_get_unicode_bytes(const char *text) { int num_chars; num_chars = g_mbstowcs(0, text, 0); if (num_chars < 0) { /* g_mbstowcs failed, we ignore that text by returning zero bytes */ num_chars = 0; } else { /* calculate the number of bytes of the resulting null-terminated wide-string */ num_chars = (num_chars + 1) * 2; } return num_chars; } /*****************************************************************************/ /* RAIL */ /* returns error */ /* flags can contain WINDOW_ORDER_STATE_NEW */ int xrdp_orders_send_window_new_update(struct xrdp_orders *self, int window_id, struct rail_window_state_order *window_state, int flags) { int order_size; int order_flags; int field_present_flags; int index; order_size = 11; field_present_flags = flags | WINDOW_ORDER_TYPE_WINDOW; if (field_present_flags & WINDOW_ORDER_FIELD_OWNER) { /* ownerWindowId (4 bytes) */ order_size += 4; } if (field_present_flags & WINDOW_ORDER_FIELD_STYLE) { /* style (4 bytes) */ order_size += 4; /* extendedStyle (4 bytes) */ order_size += 4; } if (field_present_flags & WINDOW_ORDER_FIELD_SHOW) { /* showState (1 byte) */ order_size += 1; } if (field_present_flags & WINDOW_ORDER_FIELD_TITLE) { /* titleInfo */ order_size += xrdp_orders_get_unicode_bytes(window_state->title_info); } if (field_present_flags & WINDOW_ORDER_FIELD_CLIENT_AREA_OFFSET) { /* clientOffsetX (4 bytes) */ order_size += 4; /* clientOffsetY (4 bytes) */ order_size += 4; } if (field_present_flags & WINDOW_ORDER_FIELD_CLIENT_AREA_SIZE) { /* clientAreaWidth (4 bytes) */ order_size += 4; /* clientAreaHeight (4 bytes) */ order_size += 4; } if (field_present_flags & WINDOW_ORDER_FIELD_RP_CONTENT) { /* RPContent (1 byte) */ order_size += 1; } if (field_present_flags & WINDOW_ORDER_FIELD_ROOT_PARENT) { /* rootParentHandle (4 bytes) */ order_size += 4; } if (field_present_flags & WINDOW_ORDER_FIELD_WND_OFFSET) { /* windowOffsetX (4 bytes) */ order_size += 4; /* windowOffsetY (4 bytes) */ order_size += 4; } if (field_present_flags & WINDOW_ORDER_FIELD_WND_CLIENT_DELTA) { /* windowClientDeltaX (4 bytes) */ order_size += 4; /* windowClientDeltaY (4 bytes) */ order_size += 4; } if (field_present_flags & WINDOW_ORDER_FIELD_WND_SIZE) { /* windowWidth (4 bytes) */ order_size += 4; /* windowHeight (4 bytes) */ order_size += 4; } if (field_present_flags & WINDOW_ORDER_FIELD_WND_RECTS) { /* numWindowRects (2 bytes) */ order_size += 2; order_size += 8 * window_state->num_window_rects; } if (field_present_flags & WINDOW_ORDER_FIELD_VIS_OFFSET) { /* visibleOffsetX (4 bytes) */ order_size += 4; /* visibleOffsetY (4 bytes) */ order_size += 4; } if (field_present_flags & WINDOW_ORDER_FIELD_VISIBILITY) { /* numVisibilityRects (2 bytes) */ order_size += 2; order_size += 8 * window_state->num_visibility_rects; } if (order_size < 12) { /* no flags set */ return 0; } if (xrdp_orders_check(self, order_size) != 0) { return 1; } self->order_count++; order_flags = RDP_ORDER_SECONDARY; order_flags |= 0xb << 2; /* type TS_ALTSEC_WINDOW */ out_uint8(self->out_s, order_flags); /* orderSize (2 bytes) */ out_uint16_le(self->out_s, order_size); /* FieldsPresentFlags (4 bytes) */ out_uint32_le(self->out_s, field_present_flags); /* windowId (4 bytes) */ out_uint32_le(self->out_s, window_id); if (field_present_flags & WINDOW_ORDER_FIELD_OWNER) { /* ownerWindowId (4 bytes) */ out_uint32_le(self->out_s, window_state->owner_window_id); } if (field_present_flags & WINDOW_ORDER_FIELD_STYLE) { /* style (4 bytes) */ out_uint32_le(self->out_s, window_state->style); /* extendedStyle (4 bytes) */ out_uint32_le(self->out_s, window_state->extended_style); } if (field_present_flags & WINDOW_ORDER_FIELD_SHOW) { /* showState (1 byte) */ out_uint8(self->out_s, window_state->show_state); } if (field_present_flags & WINDOW_ORDER_FIELD_TITLE) { /* titleInfo */ xrdp_orders_send_as_unicode(self->out_s, window_state->title_info); } if (field_present_flags & WINDOW_ORDER_FIELD_CLIENT_AREA_OFFSET) { /* clientOffsetX (4 bytes) */ out_uint32_le(self->out_s, window_state->client_offset_x); /* clientOffsetY (4 bytes) */ out_uint32_le(self->out_s, window_state->client_offset_y); } if (field_present_flags & WINDOW_ORDER_FIELD_CLIENT_AREA_SIZE) { /* clientAreaWidth (4 bytes) */ out_uint32_le(self->out_s, window_state->client_area_width); /* clientAreaHeight (4 bytes) */ out_uint32_le(self->out_s, window_state->client_area_height); } if (field_present_flags & WINDOW_ORDER_FIELD_RP_CONTENT) { /* RPContent (1 byte) */ out_uint8(self->out_s, window_state->rp_content); } if (field_present_flags & WINDOW_ORDER_FIELD_ROOT_PARENT) { /* rootParentHandle (4 bytes) */ out_uint32_le(self->out_s, window_state->root_parent_handle); } if (field_present_flags & WINDOW_ORDER_FIELD_WND_OFFSET) { /* windowOffsetX (4 bytes) */ out_uint32_le(self->out_s, window_state->window_offset_x); /* windowOffsetY (4 bytes) */ out_uint32_le(self->out_s, window_state->window_offset_y); } if (field_present_flags & WINDOW_ORDER_FIELD_WND_CLIENT_DELTA) { /* windowClientDeltaX (4 bytes) */ out_uint32_le(self->out_s, window_state->window_client_delta_x); /* windowClientDeltaY (4 bytes) */ out_uint32_le(self->out_s, window_state->window_client_delta_y); } if (field_present_flags & WINDOW_ORDER_FIELD_WND_SIZE) { /* windowWidth (4 bytes) */ out_uint32_le(self->out_s, window_state->window_width); /* windowHeight (4 bytes) */ out_uint32_le(self->out_s, window_state->window_height); } if (field_present_flags & WINDOW_ORDER_FIELD_WND_RECTS) { /* numWindowRects (2 bytes) */ out_uint16_le(self->out_s, window_state->num_window_rects); for (index = 0; index < window_state->num_window_rects; index++) { out_uint16_le(self->out_s, window_state->window_rects[index].left); out_uint16_le(self->out_s, window_state->window_rects[index].top); out_uint16_le(self->out_s, window_state->window_rects[index].right); out_uint16_le(self->out_s, window_state->window_rects[index].bottom); } } if (field_present_flags & WINDOW_ORDER_FIELD_VIS_OFFSET) { /* visibleOffsetX (4 bytes) */ out_uint32_le(self->out_s, window_state->visible_offset_x); /* visibleOffsetY (4 bytes) */ out_uint32_le(self->out_s, window_state->visible_offset_y); } if (field_present_flags & WINDOW_ORDER_FIELD_VISIBILITY) { /* numVisibilityRects (2 bytes) */ out_uint16_le(self->out_s, window_state->num_visibility_rects); for (index = 0; index < window_state->num_visibility_rects; index++) { out_uint16_le(self->out_s, window_state->visibility_rects[index].left); out_uint16_le(self->out_s, window_state->visibility_rects[index].top); out_uint16_le(self->out_s, window_state->visibility_rects[index].right); out_uint16_le(self->out_s, window_state->visibility_rects[index].bottom); } } return 0; } /*****************************************************************************/ /* RAIL */ /* returns error */ int xrdp_orders_send_notify_delete(struct xrdp_orders *self, int window_id, int notify_id) { int order_size; int order_flags; int field_present_flags; order_size = 15; if (xrdp_orders_check(self, order_size) != 0) { return 1; } self->order_count++; order_flags = RDP_ORDER_SECONDARY; order_flags |= 0xb << 2; /* type TS_ALTSEC_WINDOW */ out_uint8(self->out_s, order_flags); /* orderSize (2 bytes) */ out_uint16_le(self->out_s, order_size); /* FieldsPresentFlags (4 bytes) */ field_present_flags = WINDOW_ORDER_TYPE_NOTIFY | WINDOW_ORDER_STATE_DELETED; out_uint32_le(self->out_s, field_present_flags); /* windowId (4 bytes) */ out_uint32_le(self->out_s, window_id); /* notifyIconId (4 bytes) */ out_uint32_le(self->out_s, notify_id); return 0; } /*****************************************************************************/ /* RAIL */ /* returns error */ /* flags can contain WINDOW_ORDER_STATE_NEW */ int xrdp_orders_send_notify_new_update(struct xrdp_orders *self, int window_id, int notify_id, struct rail_notify_state_order *notify_state, int flags) { int order_size; int order_flags; int field_present_flags; int use_cmap; order_size = 15; field_present_flags = flags | WINDOW_ORDER_TYPE_NOTIFY; if (field_present_flags & WINDOW_ORDER_FIELD_NOTIFY_VERSION) { /* Version (4 bytes) */ order_size += 4; } if (field_present_flags & WINDOW_ORDER_FIELD_NOTIFY_TIP) { /* ToolTip (variable) UNICODE_STRING */ order_size += xrdp_orders_get_unicode_bytes(notify_state->tool_tip); } if (field_present_flags & WINDOW_ORDER_FIELD_NOTIFY_INFO_TIP) { /* InfoTip (variable) TS_NOTIFY_ICON_INFOTIP */ /* UNICODE_STRING */ order_size += xrdp_orders_get_unicode_bytes(notify_state->infotip.title); /* UNICODE_STRING */ order_size += xrdp_orders_get_unicode_bytes(notify_state->infotip.text); /* Timeout (4 bytes) */ /* InfoFlags (4 bytes) */ order_size += 8; } if (field_present_flags & WINDOW_ORDER_FIELD_NOTIFY_STATE) { /* State (4 bytes) */ order_size += 4; } if (field_present_flags & WINDOW_ORDER_ICON) { /* Icon (variable) */ use_cmap = 0; if ((notify_state->icon_info.bpp == 1) || (notify_state->icon_info.bpp == 2) || (notify_state->icon_info.bpp == 4)) { use_cmap = 1; } order_size += 12 + notify_state->icon_info.mask_bytes + notify_state->icon_info.data_bytes; if (use_cmap) { order_size += notify_state->icon_info.cmap_bytes + 2; } } if (field_present_flags & WINDOW_ORDER_CACHED_ICON) { /* CachedIcon (3 bytes) */ order_size += 3; } if (xrdp_orders_check(self, order_size) != 0) { return 1; } self->order_count++; order_flags = RDP_ORDER_SECONDARY; order_flags |= 0xb << 2; /* type TS_ALTSEC_WINDOW */ out_uint8(self->out_s, order_flags); /* orderSize (2 bytes) */ out_uint16_le(self->out_s, order_size); /* FieldsPresentFlags (4 bytes) */ out_uint32_le(self->out_s, field_present_flags); /* windowId (4 bytes) */ out_uint32_le(self->out_s, window_id); /* notifyIconId (4 bytes) */ out_uint32_le(self->out_s, notify_id); if (field_present_flags & WINDOW_ORDER_FIELD_NOTIFY_VERSION) { /* Version (4 bytes) */ out_uint32_le(self->out_s, notify_state->version); } if (field_present_flags & WINDOW_ORDER_FIELD_NOTIFY_TIP) { /* ToolTip (variable) UNICODE_STRING */ xrdp_orders_send_as_unicode(self->out_s, notify_state->tool_tip); } if (field_present_flags & WINDOW_ORDER_FIELD_NOTIFY_INFO_TIP) { /* InfoTip (variable) TS_NOTIFY_ICON_INFOTIP */ out_uint32_le(self->out_s, notify_state->infotip.timeout); out_uint32_le(self->out_s, notify_state->infotip.flags); xrdp_orders_send_as_unicode(self->out_s, notify_state->infotip.text); xrdp_orders_send_as_unicode(self->out_s, notify_state->infotip.title); } if (field_present_flags & WINDOW_ORDER_FIELD_NOTIFY_STATE) { /* State (4 bytes) */ out_uint32_le(self->out_s, notify_state->state); } if (field_present_flags & WINDOW_ORDER_ICON) { /* Icon (variable) */ xrdp_orders_send_ts_icon(self->out_s, notify_state->icon_cache_entry, notify_state->icon_cache_id, ¬ify_state->icon_info); } if (field_present_flags & WINDOW_ORDER_CACHED_ICON) { /* CacheEntry (2 bytes) */ out_uint16_le(self->out_s, notify_state->icon_cache_entry); /* CacheId (1 byte) */ out_uint8(self->out_s, notify_state->icon_cache_id); } return 0; } /*****************************************************************************/ /* RAIL */ /* returns error */ /* used for both Non-Monitored Desktop and Actively Monitored Desktop */ int xrdp_orders_send_monitored_desktop(struct xrdp_orders *self, struct rail_monitored_desktop_order *mdo, int flags) { int order_size; int order_flags; int field_present_flags; int index; order_size = 7; field_present_flags = flags | WINDOW_ORDER_TYPE_DESKTOP; if (field_present_flags & WINDOW_ORDER_FIELD_DESKTOP_ACTIVE_WND) { /* ActiveWindowId (4 bytes) */ order_size += 4; } if (field_present_flags & WINDOW_ORDER_FIELD_DESKTOP_ZORDER) { /* NumWindowIds (1 byte) */ order_size += 1; /* WindowIds (variable) */ order_size += mdo->num_window_ids * 4; } if (xrdp_orders_check(self, order_size) != 0) { return 1; } self->order_count++; order_flags = RDP_ORDER_SECONDARY; order_flags |= 0xb << 2; /* type TS_ALTSEC_WINDOW */ out_uint8(self->out_s, order_flags); /* orderSize (2 bytes) */ out_uint16_le(self->out_s, order_size); /* FieldsPresentFlags (4 bytes) */ out_uint32_le(self->out_s, field_present_flags); if (field_present_flags & WINDOW_ORDER_FIELD_DESKTOP_ACTIVE_WND) { /* ActiveWindowId (4 bytes) */ out_uint32_le(self->out_s, mdo->active_window_id); } if (field_present_flags & WINDOW_ORDER_FIELD_DESKTOP_ZORDER) { /* NumWindowIds (1 byte) */ out_uint8(self->out_s, mdo->num_window_ids); /* WindowIds (variable) */ for (index = 0; index < mdo->num_window_ids; index++) { out_uint32_le(self->out_s, mdo->window_ids[index]); } } return 0; } xrdp-0.9.5/libxrdp/xrdp_channel.c000644 001751 001751 00000013757 13201006747 016714 0ustar00metameta000000 000000 /** * xrdp: A Remote Desktop Protocol server. * * Copyright (C) Jay Sorg 2006-2013 * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. * * channel layer */ #if defined(HAVE_CONFIG_H) #include #endif #include "libxrdp.h" /* todo, move these to constants.h */ //#define CHANNEL_CHUNK_LENGTH 1600 /* todo, why is this so small? */ #define CHANNEL_CHUNK_LENGTH 8192 #define CHANNEL_FLAG_FIRST 0x01 #define CHANNEL_FLAG_LAST 0x02 #define CHANNEL_FLAG_SHOW_PROTOCOL 0x10 /*****************************************************************************/ /* returns pointer or nil on error */ static struct mcs_channel_item * xrdp_channel_get_item(struct xrdp_channel *self, int channel_id) { struct mcs_channel_item *channel; if (self->mcs_layer->channel_list == NULL) { g_writeln("xrdp_channel_get_item - No channel initialized"); return NULL ; } channel = (struct mcs_channel_item *) list_get_item(self->mcs_layer->channel_list, channel_id); return channel; } /*****************************************************************************/ struct xrdp_channel * xrdp_channel_create(struct xrdp_sec *owner, struct xrdp_mcs *mcs_layer) { struct xrdp_channel *self; self = (struct xrdp_channel *)g_malloc(sizeof(struct xrdp_channel), 1); self->sec_layer = owner; self->mcs_layer = mcs_layer; return self; } /*****************************************************************************/ /* returns error */ void xrdp_channel_delete(struct xrdp_channel *self) { if (self == 0) { return; } g_memset(self, 0, sizeof(struct xrdp_channel)); g_free(self); } /*****************************************************************************/ /* returns error */ int xrdp_channel_init(struct xrdp_channel *self, struct stream *s) { if (xrdp_sec_init(self->sec_layer, s) != 0) { return 1; } s_push_layer(s, channel_hdr, 8); return 0; } /*****************************************************************************/ /* returns error */ /* This sends data out to the secure layer. */ int xrdp_channel_send(struct xrdp_channel *self, struct stream *s, int channel_id, int total_data_len, int flags) { struct mcs_channel_item *channel; channel = xrdp_channel_get_item(self, channel_id); if (channel == NULL) { g_writeln("xrdp_channel_send - no such channel"); return 1; } s_pop_layer(s, channel_hdr); out_uint32_le(s, total_data_len); /* * According to 2.2.1.3.4.1 Channel Definition Structure (CHANNEL_DEF): * CHANNEL_OPTION_SHOW_PROTOCOL 0x00200000 * The value of this flag MUST be ignored by the server. The * visibility of the Channel PDU Header (section 2.2.6.1.1) is * determined by the CHANNEL_FLAG_SHOW_PROTOCOL * (0x00000010) flag as defined in the flags field (section * 2.2.6.1.1). * * That's flag makes MSTSC crash when using RAIL channel. */ // if (channel->flags & XR_CHANNEL_OPTION_SHOW_PROTOCOL) // { // flags |= CHANNEL_FLAG_SHOW_PROTOCOL; // } out_uint32_le(s, flags); if (xrdp_sec_send(self->sec_layer, s, channel->chanid) != 0) { g_writeln("xrdp_channel_send - failure sending data"); return 1; } return 0; } /*****************************************************************************/ /* returns error */ /* this will inform the callback, whatever it is that some channel data is ready. the default for this is a call to xrdp_wm.c. */ static int xrdp_channel_call_callback(struct xrdp_channel *self, struct stream *s, int channel_id, int total_data_len, int flags) { struct xrdp_session *session; int rv; int size; rv = 0; session = self->sec_layer->rdp_layer->session; if (session != 0) { if (session->callback != 0) { size = (int)(s->end - s->p); /* in xrdp_wm.c */ rv = session->callback(session->id, 0x5555, MAKELONG(channel_id, flags), size, (tbus)(s->p), total_data_len); } else { g_writeln("in xrdp_channel_call_callback, session->callback is nil"); } } else { g_writeln("in xrdp_channel_call_callback, session is nil"); } return rv; } /*****************************************************************************/ /* returns error */ /* This is called from the secure layer to process an incoming non global channel packet. 'chanid' passed in here is the mcs channel id so it MCS_GLOBAL_CHANNEL plus something. */ int xrdp_channel_process(struct xrdp_channel *self, struct stream *s, int chanid) { int length; int flags; int rv; int channel_id; struct mcs_channel_item *channel; /* this assumes that the channels are in order of chanid(mcs channel id) but they should be, see xrdp_sec_process_mcs_data_channels the first channel should be MCS_GLOBAL_CHANNEL + 1, second one should be MCS_GLOBAL_CHANNEL + 2, and so on */ channel_id = (chanid - MCS_GLOBAL_CHANNEL) - 1; channel = xrdp_channel_get_item(self, channel_id); if (channel == NULL) { g_writeln("xrdp_channel_process, channel not found"); return 1; } rv = 0; in_uint32_le(s, length); in_uint32_le(s, flags); rv = xrdp_channel_call_callback(self, s, channel_id, length, flags); return rv; } xrdp-0.9.5/vrplayer/main.cpp000644 001751 001751 00000000360 13125122134 015707 0ustar00metameta000000 000000 #include #include "mainwindow.h" int main(int argc, char *argv[]) { QApplication::setGraphicsSystem(QLatin1String("native")); QApplication a(argc, argv); MainWindow w; w.show(); return a.exec(); } xrdp-0.9.5/vrplayer/playvideo.h000644 001751 001751 00000003120 13125122134 016421 0ustar00metameta000000 000000 #ifndef PLAYVIDEO_H #define PLAYVIDEO_H #ifdef __cplusplus #define __STDC_CONSTANT_MACROS #ifdef _STDINT_H #undef _STDINT_H #endif #include #endif #include #include #include #include "mediapacket.h" #include "xrdpvr.h" #include "xrdpapi.h" /* ffmpeg related stuff */ extern "C" { #include #include } #define VCR_PLAY 1 #define VCR_PAUSE 2 #define VCR_STOP 3 #define VCR_REWIND 4 #define VCR_POWER_OFF 5 class PlayVideo : public QObject { Q_OBJECT public: explicit PlayVideo(QObject *parent = 0, QQueue *videoQueue = 0, QMutex *sendMutex = 0, void *channel = 0, int stream_id = 101, int fps = 24); //void onMediaSeek(int value); //void setVcrOp(int op); //void onMediaRestarted(); public slots: void play(); //signals: // void onElapsedtime(int val); /* in hundredth of a sec */ private: QQueue *videoQueue; // int vcrFlag; // QMutex vcrMutex; QMutex *sendMutex; // QMutex posMutex; // int64_t la_seekPos; /* locked access; must hold posMutex */ void *channel; int stream_id; int fps; // int64_t elapsedTime; /* elapsed time in usecs since play started */ // int64_t pausedTime; /* time at which stream was paused */ // bool isStopped; // void updateMediaPos(); // void clearVideoQ(); }; #endif // PLAYVIDEO_H xrdp-0.9.5/vrplayer/decoder.h000644 001751 001751 00000001223 13125122134 016034 0ustar00metameta000000 000000 #ifndef DECODER_H #define DECODER_H #include #include #include #ifdef __cplusplus #define __STDC_CONSTANT_MACROS #ifdef _STDINT_H #undef _STDINT_H #endif #include #endif #include #include #include /* LK_TODO is this required? */ class Decoder : public QObject { Q_OBJECT public: explicit Decoder(QObject *parent = 0); int init(QString filename); //int deinit(); //int setWindow(QRectangle rect); private: void *channel; QRect mainWindowGeometry; signals: public slots: void onGeometryChanged(QRect *geometry); }; #endif // DECODER_H xrdp-0.9.5/vrplayer/decoderthread.h000644 001751 001751 00000004060 13125122134 017226 0ustar00metameta000000 000000 #ifndef DECODERTHREAD_H #define DECODERTHREAD_H #ifdef __cplusplus #define __STDC_CONSTANT_MACROS #ifdef _STDINT_H #undef _STDINT_H #endif #include #endif #include #include #include #include #include #include #include #include #include #include #include #include /* ffmpeg related stuff */ extern "C" { #include #include } class DecoderThread : public QObject { Q_OBJECT public: /* public methods */ DecoderThread(); void setFilename(QString filename); void stopPlayer(); void pausePlayer(); void resumePlayer(); void oneTimeDeinit(); void close(); void run(); void startMediaPlay(); public slots: void on_mediaSeek(int value); private: /* private variables */ QQueue audioQueue; QQueue videoQueue; QTimer *videoTimer; QTimer *audioTimer; QTimer *pktTimer; QString filename; void *channel; int stream_id; QRect geometry; int64_t elapsedTime; /* elapsed time in usecs since play started */ QMutex mutex; int64_t la_seekPos; /* locked access; must hold mutex */ PlayVideo *playVideo; QThread *playVideoThread; PlayAudio *playAudio; QThread *playAudioThread; /* private functions */ int sendMetadataFile(); int sendAudioFormat(); int sendVideoFormat(); int sendGeometry(); void updateSlider(); private slots: /* private slots */ void audioTimerCallback(); void videoTimerCallback(); void pktTimerCallback(); signals: /* private signals */ void on_progressUpdate(int percent); void on_decoderErrorMsg(QString title, QString msg); void on_mediaDurationInSeconds(int duration); void on_elapsedtime(int val); /* in hundredth of a sec */ }; #endif // DECODERTHREAD_H xrdp-0.9.5/vrplayer/playaudio.cpp000644 001751 001751 00000003453 13125122134 016760 0ustar00metameta000000 000000 #include #include "playaudio.h" #include PlayAudio::PlayAudio(QObject *parent, QQueue *audioQueue, QMutex *sendMutex, void *channel, int stream_id) : QObject(parent) { this->audioQueue = audioQueue; this->sendMutex = sendMutex; this->channel = channel; this->stream_id = stream_id; this->vcrFlag = 0; } void PlayAudio::play() { MediaPacket *pkt; while (1) { vcrMutex.lock(); switch (vcrFlag) { case VCR_PLAY: vcrFlag = 0; vcrMutex.unlock(); continue; break; case VCR_PAUSE: vcrMutex.unlock(); usleep(1000 * 100); continue; break; case VCR_STOP: vcrMutex.unlock(); clearAudioQ(); usleep(1000 * 100); continue; break; default: vcrMutex.unlock(); goto label1; break; } label1: printf("audio\n"); if (audioQueue->isEmpty()) { qDebug() << "PlayAudio::play: GOT EMPTY"; usleep(1000 * 10); continue; } printf(""); pkt = audioQueue->dequeue(); sendMutex->lock(); send_audio_pkt(channel, stream_id, pkt->av_pkt); sendMutex->unlock(); usleep(pkt->delay_in_us); delete pkt; } } void PlayAudio::setVcrOp(int op) { vcrMutex.lock(); this->vcrFlag = op; vcrMutex.unlock(); } void PlayAudio::clearAudioQ() { MediaPacket *pkt; while (!audioQueue->isEmpty()) { pkt = audioQueue->dequeue(); av_free_packet((AVPacket *) pkt->av_pkt); delete pkt; } } xrdp-0.9.5/vrplayer/mediapacket.cpp000644 001751 001751 00000000153 13125122134 017232 0ustar00metameta000000 000000 #include "mediapacket.h" MediaPacket::MediaPacket() { av_pkt = 0; delay_in_us = 0; seq = 0; } xrdp-0.9.5/vrplayer/README.txt000644 001751 001751 00000001220 13174271344 015765 0ustar00metameta000000 000000 A QT based media player that runs on a RDP server and redirects audio/video to the client where it is decoded and rendered locally Required packages to build vrplayer: ------------------------------------ libqt4-gui qt4-dev-tools libavutil-dev libavformat-dev to build vrplayer ----------------- cd ../xrdpvr make cd .. qmake make To run vrplayer --------------- include xrdpapi/.libs and xrdpvr/.libs in your LD_LIBRARY_PATH Example: -------- export LD_LIBRARY_PATH=../xrdpapi/.libs:../xrdpvr/.libs run vrplayer inside the xfreerdp session this is how we run xfreerdp: ---------------------------- ./xfreerdp --sec rdp --plugin xrdpvr 192.168.2.149 xrdp-0.9.5/vrplayer/mainwindow.h000644 001751 001751 00000005535 13127114621 016621 0ustar00metameta000000 000000 #ifndef MAINWINDOW_H #define MAINWINDOW_H #ifdef __cplusplus #define __STDC_CONSTANT_MACROS #ifdef _STDINT_H #undef _STDINT_H #endif #include #endif #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include "xrdpapi.h" #include "xrdpvr.h" #include "decoder.h" #include "ourinterface.h" #include "playvideo.h" #include "dlgabout.h" /* ffmpeg related stuff */ extern "C" { #include #include } #define VCR_PLAY 1 #define VCR_PAUSE 2 #define VCR_STOP 3 #define VCR_REWIND 4 #define VCR_POWER_OFF 5 namespace Ui { class MainWindow; } class MainWindow : public QMainWindow { Q_OBJECT public: explicit MainWindow(QWidget *parent = 0); ~MainWindow(); signals: void onGeometryChanged(int x, int y, int width, int height); public slots: void onSliderValueChanged(int value); private slots: void on_actionOpen_Media_File_triggered(); void on_actionExit_triggered(); void onBtnPlayClicked(bool flag); void onBtnRewindClicked(bool flag); void onBtnStopClicked(bool flag); void onMediaDurationInSeconds(int duration); void onElapsedTime(int secs); void onSliderActionTriggered(int value); void onMoveCompleted(); void on_actionAbout_triggered(); void onVolSliderValueChanged(int value); protected: void resizeEvent(QResizeEvent *e); void closeEvent(QCloseEvent *e); void moveEvent(QMoveEvent *e); private: Ui::MainWindow *ui; /* for UI */ QLabel *lblCurrentPos; QLabel *lblDuration; QLabel *lblVideo; QHBoxLayout *hboxLayoutTop; QHBoxLayout *hboxLayoutMiddle; QHBoxLayout *hboxLayoutBottom; QVBoxLayout *vboxLayout; QPushButton *btnPlay; QPushButton *btnStop; QPushButton *btnRewind; QSlider *slider; QSlider *volSlider; QWidget *window; bool acceptSliderMove; QTimer *moveResizeTimer; /* private stuff */ OurInterface *interface; //PlayVideo *playVideo; DemuxMedia *demuxMedia; QString filename; bool oneTimeInitSuccess; bool remoteClientInited; void *channel; int stream_id; int64_t elapsedTime; /* elapsed time in usecs since play started */ int vcrFlag; bool gotMediaOnCmdline; /* private methods */ void setupUI(); void openMediaFile(); void getVdoGeometry(QRect *rect); void clearDisplay(); }; #endif // MAINWINDOW_H xrdp-0.9.5/vrplayer/dlgabout.h000644 001751 001751 00000000464 13125122134 016236 0ustar00metameta000000 000000 #ifndef DLGABOUT_H #define DLGABOUT_H #include namespace Ui { class DlgAbout; } class DlgAbout : public QDialog { Q_OBJECT public: explicit DlgAbout(QWidget *parent = 0); ~DlgAbout(); private: Ui::DlgAbout *ui; private slots: void onOk(); }; #endif // DLGABOUT_H xrdp-0.9.5/vrplayer/decoder.cpp000644 001751 001751 00000003675 13125122134 016404 0ustar00metameta000000 000000 #include "decoder.h" Decoder::Decoder(QObject *parent) : QObject(parent) { channel = NULL; } /* * inititialize the decoder * * @return 0 on success, -1 on failure *****************************************************************************/ int Decoder::init(QString filename) { printf("Decoder::init\n"); if (channel) return -1; /* open a virtual channel and connect to remote client */ channel = WTSVirtualChannelOpenEx(WTS_CURRENT_SESSION, "xrdpvr", 0); if (channel == NULL) { qDebug() << "WTSVirtualChannelOpenEx() failed\n"; return -1; } /* initialize the player */ if (xrdpvr_init_player(channel, 101, filename.toAscii().data())) { fprintf(stderr, "failed to initialize the player\n"); return -1; } #if 1 sleep(1); qDebug() << "sleeping 1"; xrdpvr_set_geometry(channel, 101, mainWindowGeometry.x(), mainWindowGeometry.y(), mainWindowGeometry.width(), mainWindowGeometry.height()); qDebug() << "set geometry to:" << mainWindowGeometry.x() << "" << mainWindowGeometry.y() << "" << mainWindowGeometry.width() << "" << mainWindowGeometry.height(); #endif /* send compressed media data to client; client will decompress */ /* the media and play it locally */ xrdpvr_play_media(channel, 101, filename.toAscii().data()); /* perform clean up */ xrdpvr_deinit_player(channel, 101); WTSVirtualChannelClose(channel); return 0; } void Decoder::onGeometryChanged(QRect *g) { #if 1 mainWindowGeometry.setX(g->x()); mainWindowGeometry.setY(g->y()); mainWindowGeometry.setWidth(g->width()); mainWindowGeometry.setHeight(g->height()); #else if (!channel) return; xrdpvr_set_geometry(channel, 101, g->x(), g->y(), g->width(), g->height()); qDebug() << "sent geometry"; #endif } xrdp-0.9.5/vrplayer/demuxmedia.h000644 001751 001751 00000003114 13125122134 016552 0ustar00metameta000000 000000 #ifndef DEMUXMEDIA_H #define DEMUXMEDIA_H #ifdef __cplusplus #define __STDC_CONSTANT_MACROS #ifdef _STDINT_H #undef _STDINT_H #endif #include #endif #include #include #include #include #include #include "mediapacket.h" #include "playaudio.h" #include "playvideo.h" /* ffmpeg related stuff */ extern "C" { #include #include } #define VCR_PLAY 1 #define VCR_PAUSE 2 #define VCR_STOP 3 #define VCR_REWIND 4 #define VCR_POWER_OFF 5 class DemuxMedia : public QObject { Q_OBJECT public: explicit DemuxMedia(QObject *parent = 0, QQueue *videoQueue = 0, void *channel = 0, int stream_id = 101); void setVcrOp(int op); int clear(); public slots: void startDemuxing(); void onMediaSeek(int value); private: QMutex vcrMutex; int vcrFlag; void *channel; int stream_id; QMutex sendMutex; QMutex posMutex; int64_t elapsedTime; /* elapsed time in usecs since play started */ int64_t pausedTime; /* time at which stream was paused */ int64_t la_seekPos; /* locked access; must hold posMutex */ bool isStopped; QQueue *videoQueue; PlayVideo *playVideo; QThread *playVideoThread; void updateMediaPos(); signals: void onMediaRestarted(); signals: void onElapsedtime(int val); /* in hundredth of a sec */ }; #endif // DEMUXMEDIA_H xrdp-0.9.5/vrplayer/mainwindow.ui000644 001751 001751 00000003502 13125122134 016773 0ustar00metameta000000 000000 MainWindow 0 0 800 600 MainWindow 0 0 800 25 File Help TopToolBarArea false Open Media File Exit application Exit application About xrdp-0.9.5/vrplayer/dlgabout.ui000644 001751 001751 00000001641 13125122134 016422 0ustar00metameta000000 000000 DlgAbout 0 0 288 168 Dialog 70 60 151 17 VRPlayer v1.6 180 120 94 27 OK xrdp-0.9.5/vrplayer/mediapacket.h000644 001751 001751 00000000261 13125122134 016677 0ustar00metameta000000 000000 #ifndef MEDIAPACKET_H #define MEDIAPACKET_H class MediaPacket { public: MediaPacket(); void *av_pkt; int delay_in_us; int seq; }; #endif // MEDIAPACKET_H xrdp-0.9.5/vrplayer/mainwindow.cpp000644 001751 001751 00000034307 13125122134 017147 0ustar00metameta000000 000000 #include "mainwindow.h" #include "ui_mainwindow.h" /* * TODO * o should we use tick marks in QSlider? * o check for memory leaks * o double click should make it full screen * o when opening files, pause video */ MainWindow::MainWindow(QWidget *parent) : QMainWindow(parent), ui(new Ui::MainWindow) { gotMediaOnCmdline = false; moveResizeTimer = NULL; /* connect to remote client */ interface = new OurInterface(); if (interface->oneTimeInit()) { oneTimeInitSuccess = false; /* connection to remote client failed; error msg has */ /* already been displayed so it's ok to close app now */ QTimer::singleShot(1000, this, SLOT(close())); } else { oneTimeInitSuccess = true; } remoteClientInited = false; ui->setupUi(this); acceptSliderMove = false; setupUI(); vcrFlag = 0; connect(this, SIGNAL(onGeometryChanged(int,int,int,int)), interface, SLOT(onGeometryChanged(int,int,int,int))); connect(interface, SIGNAL(onMediaDurationInSeconds(int)), this, SLOT(onMediaDurationInSeconds(int))); /* if media file is specified on cmd line, use it */ QStringList args = QApplication::arguments(); if (args.count() > 1) { if (QFile::exists(args.at(1))) { interface->setFilename(args.at(1)); filename = args.at(1); gotMediaOnCmdline = true; on_actionOpen_Media_File_triggered(); } else { QMessageBox::warning(this, "Invalid media file specified", "\nThe media file\n\n" + args.at(1) + "\n\ndoes not exist"); } } } MainWindow::~MainWindow() { delete ui; //if (moveResizeTimer) // delete moveResizeTimer; } void MainWindow::closeEvent(QCloseEvent *event) { if (oneTimeInitSuccess) { interface->deInitRemoteClient(); } else { QMessageBox::warning(this, "Closing application", "This is not an xrdp session with xrdpvr"); } event->accept(); } void MainWindow::resizeEvent(QResizeEvent *) { //if (vcrFlag != VCR_PLAY) { QRect rect; getVdoGeometry(&rect); interface->sendGeometry(rect); //return; } //interface->setVcrOp(VCR_PAUSE); //vcrFlag = VCR_PAUSE; //if (!moveResizeTimer) //{ // moveResizeTimer = new QTimer; // connect(moveResizeTimer, SIGNAL(timeout()), // this, SLOT(onMoveCompleted())); //} //lblVideo->setStyleSheet("QLabel { background-color : black; color : blue; }"); //moveResizeTimer->start(1000); } void MainWindow::moveEvent(QMoveEvent *) { //if (vcrFlag != VCR_PLAY) { QRect rect; getVdoGeometry(&rect); interface->sendGeometry(rect); //return; } //interface->setVcrOp(VCR_PAUSE); //vcrFlag = VCR_PAUSE; //if (!moveResizeTimer) //{ // moveResizeTimer = new QTimer; // connect(moveResizeTimer, SIGNAL(timeout()), // this, SLOT(onMoveCompleted())); //} //lblVideo->setStyleSheet("QLabel { background-color : black; color : blue; }"); //moveResizeTimer->start(1000); } void MainWindow::onVolSliderValueChanged(int value) { int volume; volume = (value * 0xffff) / 100; if (interface != 0) { interface->setVolume(volume); } qDebug() << "vol = " << volume; } void MainWindow::setupUI() { this->setWindowTitle("vrplayer"); /* setup area to display video */ lblVideo = new QLabel(); lblVideo->setMinimumWidth(320); lblVideo->setMinimumHeight(200); QPalette palette = lblVideo->palette(); palette.setColor(lblVideo->backgroundRole(), QColor(0x00, 0x00, 0x01, 0xff)); palette.setColor(lblVideo->foregroundRole(), QColor(0x00, 0x00, 0x01, 0xff)); lblVideo->setAutoFillBackground(true); lblVideo->setPalette(palette); hboxLayoutTop = new QHBoxLayout; hboxLayoutTop->addWidget(lblVideo); /* setup label to display current pos in media */ lblCurrentPos = new QLabel("00:00:00"); lblCurrentPos->setMinimumHeight(20); lblCurrentPos->setMaximumHeight(20); /* setup slider to seek into media */ slider = new QSlider(); slider->setOrientation(Qt::Horizontal); slider->setMinimumHeight(20); slider->setMaximumHeight(20); connect(slider, SIGNAL(actionTriggered(int)), this, SLOT(onSliderActionTriggered(int))); connect(slider, SIGNAL(valueChanged(int)), this, SLOT(onSliderValueChanged(int))); /* setup label to display media duration */ lblDuration = new QLabel("00:00:00"); lblDuration->setMinimumHeight(20); lblDuration->setMaximumHeight(20); /* add above three widgets to mid layout */ hboxLayoutMiddle = new QHBoxLayout; hboxLayoutMiddle->addWidget(lblCurrentPos); hboxLayoutMiddle->addWidget(slider); hboxLayoutMiddle->addWidget(lblDuration); /* setup play button */ btnPlay = new QPushButton("Play"); btnPlay->setMinimumHeight(40); btnPlay->setMaximumHeight(40); btnPlay->setMinimumWidth(40); btnPlay->setMaximumWidth(40); btnPlay->setCheckable(true); connect(btnPlay, SIGNAL(clicked(bool)), this, SLOT(onBtnPlayClicked(bool))); /* setup stop button */ btnStop = new QPushButton("Stop"); btnStop->setMinimumHeight(40); btnStop->setMaximumHeight(40); btnStop->setMinimumWidth(40); btnStop->setMaximumWidth(40); connect(btnStop, SIGNAL(clicked(bool)), this, SLOT(onBtnStopClicked(bool))); /* setup rewind button */ btnRewind = new QPushButton("R"); btnRewind->setMinimumHeight(40); btnRewind->setMaximumHeight(40); btnRewind->setMinimumWidth(40); btnRewind->setMaximumWidth(40); connect(btnRewind, SIGNAL(clicked(bool)), this, SLOT(onBtnRewindClicked(bool))); /* setup volume control slider */ volSlider = new QSlider(); volSlider->setOrientation(Qt::Horizontal); volSlider->setMinimumWidth(100); volSlider->setMaximumWidth(100); volSlider->setMinimum(0); volSlider->setMaximum(100); volSlider->setValue(20); volSlider->setTickPosition(QSlider::TicksAbove); volSlider->setTickInterval(10); connect(volSlider, SIGNAL(valueChanged(int)), this, SLOT(onVolSliderValueChanged(int))); /* add buttons to bottom panel */ hboxLayoutBottom = new QHBoxLayout; hboxLayoutBottom->addWidget(btnPlay); hboxLayoutBottom->addWidget(btnStop); hboxLayoutBottom->addWidget(volSlider); //hboxLayoutBottom->addWidget(btnRewind); hboxLayoutBottom->addStretch(); /* add all three layouts to one vertical layout */ vboxLayout = new QVBoxLayout; vboxLayout->addLayout(hboxLayoutTop); vboxLayout->addLayout(hboxLayoutMiddle); vboxLayout->addLayout(hboxLayoutBottom); /* add all of them to central widget */ window = new QWidget; window->setLayout(vboxLayout); this->setCentralWidget(window); } void MainWindow::openMediaFile() { /* TODO take last stored value from QSettings */ if (filename.length() == 0) { /* no previous selection - open user's home folder TODO */ // TODO filename = QFileDialog::getOpenFileName(this, "Select Media File", "/"); //filename = QFileDialog::getOpenFileName(this, "Select Media File", // QDir::currentPath()); filename = QFileDialog::getOpenFileName(this, "Select Media File", QDir::currentPath(), "Media *.mov *.mp4 *.mkv (*.mov *.mp4 *.mkv)"); } else { /* show last selected file */ filename = QFileDialog::getOpenFileName(this, "Select Media File", filename); } interface->setFilename(filename); } void MainWindow::getVdoGeometry(QRect *rect) { int x; int y; int width; int height; QPoint pt; pt = lblVideo->mapToGlobal(QPoint(0, 0)); x = pt.x(); y = pt.y(); width = lblVideo->width(); height = lblVideo->height(); rect->setX(x); rect->setY(y); rect->setWidth(width); rect->setHeight(height); } void MainWindow::clearDisplay() { /* TODO: this needs to be set after video actually stops * a few frames come after this */ lblVideo->update(); } /******************************************************************************* * actions and slots go here * ******************************************************************************/ void MainWindow::on_actionOpen_Media_File_triggered() { if (vcrFlag != 0) { onBtnStopClicked(true); } /* if media was specified on cmd line, use it just once */ if (gotMediaOnCmdline) { gotMediaOnCmdline = false; } else { openMediaFile(); } if (filename.length() == 0) { /* cancel btn was clicked */ return; } if (remoteClientInited) { remoteClientInited = false; interface->deInitRemoteClient(); if (interface->initRemoteClient() != 0) { QMessageBox::question(this, "vrplayer", "Unsupported codec", QMessageBox::Ok); return; } } else { if (interface->initRemoteClient() != 0) { QMessageBox::question(this, "vrplayer", "Unsupported codec", QMessageBox::Ok); return; } } demuxMedia = interface->getDemuxMediaInstance(); if (demuxMedia) { connect(demuxMedia, SIGNAL(onElapsedtime(int)), this, SLOT(onElapsedTime(int))); } remoteClientInited = true; interface->playMedia(); //if (vcrFlag != 0) { interface->setVcrOp(VCR_PLAY); btnPlay->setText("Pause"); vcrFlag = VCR_PLAY; } } void MainWindow::on_actionExit_triggered() { clearDisplay(); this->close(); } void MainWindow::onBtnPlayClicked(bool) { if (vcrFlag == 0) { /* first time play button3 has been clicked */ on_actionOpen_Media_File_triggered(); btnPlay->setText("Pause"); vcrFlag = VCR_PLAY; } else if (vcrFlag == VCR_PLAY) { /* btn clicked while in play mode - enter pause mode */ btnPlay->setText("Play"); interface->setVcrOp(VCR_PAUSE); vcrFlag = VCR_PAUSE; } else if (vcrFlag == VCR_PAUSE) { /* btn clicked while in pause mode - enter play mode */ btnPlay->setText("Pause"); interface->setVcrOp(VCR_PLAY); vcrFlag = VCR_PLAY; } else if (vcrFlag == VCR_STOP) { /* btn clicked while stopped - enter play mode */ btnPlay->setText("Play"); interface->setVcrOp(VCR_PLAY); vcrFlag = VCR_PLAY; } } void MainWindow::onBtnRewindClicked(bool) { //if (playVideo) // playVideo->onMediaSeek(0); } void MainWindow::onBtnStopClicked(bool) { vcrFlag = VCR_STOP; btnPlay->setText("Play"); interface->setVcrOp(VCR_STOP); /* reset slider */ slider->setSliderPosition(0); lblCurrentPos->setText("00:00:00"); /* clear screen by filling it with black */ usleep(500 * 1000); clearDisplay(); btnPlay->setChecked(false); } void MainWindow::onMediaDurationInSeconds(int duration) { int hours = 0; int minutes = 0; int secs = 0; char buf[20]; /* setup progress bar */ slider->setMinimum(0); slider->setMaximum(duration * 100); /* in hundredth of a sec */ slider->setValue(0); slider->setSliderPosition(0); lblCurrentPos->setText("00:00:00"); //qDebug() << "media_duration=" << duration << " in hundredth of a sec:" << duration * 100; /* convert from seconds to hours:minutes:seconds */ hours = duration / 3600; if (hours) duration -= (hours * 3600); minutes = duration / 60; if (minutes) duration -= minutes * 60; secs = duration; sprintf(buf, "%.2d:%.2d:%.2d", hours, minutes, secs); lblDuration->setText(QString(buf)); } /** * time elapsed in 1/100th sec units since play started ******************************************************************************/ void MainWindow::onElapsedTime(int val) { int hours = 0; int minutes = 0; int secs = 0; int duration = 0; char buf[20]; if (vcrFlag == VCR_STOP) return; /* if slider bar is down, do not update */ if (slider->isSliderDown()) return; /* update progress bar */ if (val >= slider->maximum()) val = 0; slider->setSliderPosition(val); /* convert from seconds to hours:minutes:seconds */ duration = val / 100; hours = duration / 3600; if (hours) duration -= (hours * 3600); minutes = duration / 60; if (minutes) duration -= minutes * 60; secs = duration; /* update current position in progress bar */ sprintf(buf, "%.2d:%.2d:%.2d", hours, minutes, secs); lblCurrentPos->setText(QString(buf)); } void MainWindow::onSliderValueChanged(int value) { if (acceptSliderMove) { acceptSliderMove = false; if (demuxMedia != NULL) { demuxMedia->onMediaSeek(value / 100); } } } void MainWindow::onSliderActionTriggered(int action) { switch (action) { case QAbstractSlider::SliderPageStepAdd: acceptSliderMove = true; break; case QAbstractSlider::SliderPageStepSub: acceptSliderMove = true; break; case QAbstractSlider::SliderMove: if (slider->isSliderDown()) acceptSliderMove = true; break; } } // not called void MainWindow::onMoveCompleted() { QRect rect; getVdoGeometry(&rect); interface->sendGeometry(rect); interface->setVcrOp(VCR_PLAY); vcrFlag = VCR_PLAY; //moveResizeTimer->stop(); } void MainWindow::on_actionAbout_triggered() { #if 0 QMessageBox msgBox; msgBox.setText("VRPlayer version 1.2"); msgBox.setStandardButtons(QMessageBox::Ok); msgBox.setDefaultButton(QMessageBox::Ok); msgBox.exec(); #else DlgAbout *dlgabt = new DlgAbout(this); dlgabt->exec(); #endif } xrdp-0.9.5/vrplayer/playaudio.h000644 001751 001751 00000002177 13125122134 016427 0ustar00metameta000000 000000 #ifndef PLAYAUDIO_H #define PLAYAUDIO_H #ifdef __cplusplus #define __STDC_CONSTANT_MACROS #ifdef _STDINT_H #undef _STDINT_H #endif #include #endif #include #include #include #include "mediapacket.h" #include "xrdpvr.h" /* ffmpeg related stuff */ extern "C" { #include #include } #define VCR_PLAY 1 #define VCR_PAUSE 2 #define VCR_STOP 3 #define VCR_REWIND 4 #define VCR_POWER_OFF 5 class PlayAudio : public QObject { Q_OBJECT public: explicit PlayAudio(QObject *parent = 0, QQueue *audioQueue = 0, QMutex *sendMutex = 0, void *channel = 0, int stream_id = 101); void setVcrOp(int op); public slots: void play(); private: QQueue *audioQueue; QMutex *sendMutex; QMutex vcrMutex; int vcrFlag; void *channel; int stream_id; void clearAudioQ(); }; #endif // PLAYAUDIO_H xrdp-0.9.5/vrplayer/vrplayer.pro000644 001751 001751 00000001465 13125122134 016654 0ustar00metameta000000 000000 #------------------------------------------------- # # Project created by QtCreator 2012-11-13T11:52:36 # #------------------------------------------------- QT += core gui TARGET = vrplayer TEMPLATE = app SOURCES += main.cpp\ playvideo.cpp \ mainwindow.cpp \ mediapacket.cpp \ playaudio.cpp \ demuxmedia.cpp \ ourinterface.cpp \ dlgabout.cpp HEADERS += mainwindow.h \ mediapacket.h \ playvideo.h \ playaudio.h \ demuxmedia.h \ ourinterface.h \ dlgabout.h FORMS += mainwindow.ui \ dlgabout.ui # added by LK INCLUDEPATH += ../xrdpvr INCLUDEPATH += ../xrdpapi LIBS += -Wl,-rpath LIBS += -Wl,/usr/local/lib/xrdp LIBS += -L../xrdpvr/.libs -lxrdpvr LIBS += -L../xrdpapi/.libs -lxrdpapi LIBS += -L/usr/lib/x86_64-linux-gnu -lavformat -lavcodec -lavutil xrdp-0.9.5/vrplayer/demuxmedia.cpp000644 001751 001751 00000007373 13125122134 017120 0ustar00metameta000000 000000 #include #include "demuxmedia.h" DemuxMedia::DemuxMedia(QObject *parent, QQueue *videoQueue, void *channel, int stream_id) : QObject(parent) { this->channel = channel; this->stream_id = stream_id; this->vcrFlag = 0; this->elapsedTime = 0; this->la_seekPos = -1; this->isStopped = 0; this->pausedTime = 0; this->videoQueue = videoQueue; playVideo = new PlayVideo(NULL, videoQueue, &sendMutex, channel, 101, 24); playVideoThread = new QThread(this); connect(playVideoThread, SIGNAL(started()), playVideo, SLOT(play())); playVideo->moveToThread(playVideoThread); playVideoThread->start(); } void DemuxMedia::setVcrOp(int op) { vcrMutex.lock(); vcrFlag = op; vcrMutex.unlock(); if (op == VCR_STOP) { clear(); } } int DemuxMedia::clear() { sendMutex.lock(); videoQueue->clear(); sendMutex.unlock(); return 0; } void DemuxMedia::startDemuxing() { MediaPacket *mediaPkt; int is_video_frame; int rv; while (1) { vcrMutex.lock(); switch (vcrFlag) { case VCR_PLAY: vcrFlag = 0; vcrMutex.unlock(); if (pausedTime) { elapsedTime = av_gettime() - pausedTime; pausedTime = 0; } isStopped = false; continue; break; case VCR_PAUSE: vcrMutex.unlock(); if (!pausedTime) { /* save amount of video played so far */ pausedTime = av_gettime() - elapsedTime; } usleep(1000 * 100); isStopped = false; continue; break; case VCR_STOP: vcrMutex.unlock(); if (isStopped) { usleep(1000 * 100); continue; } elapsedTime = 0; pausedTime = 0; la_seekPos = -1; xrdpvr_seek_media(0, 0); isStopped = true; continue; break; default: vcrMutex.unlock(); break; } mediaPkt = new MediaPacket; rv = xrdpvr_get_frame(&mediaPkt->av_pkt, &is_video_frame, &mediaPkt->delay_in_us); if (rv < 0) { /* looks like we reached end of file */ delete mediaPkt; usleep(1000 * 100); xrdpvr_seek_media(0, 0); this->elapsedTime = 0; continue; } if (is_video_frame) { sendMutex.lock(); #if 1 videoQueue->enqueue(mediaPkt); #else send_video_pkt(channel, stream_id, mediaPkt->av_pkt); delete mediaPkt; #endif sendMutex.unlock(); } else { int frame; sendMutex.lock(); send_audio_pkt(channel, stream_id, mediaPkt->av_pkt); sendMutex.unlock(); xrdpvr_read_ack(channel, &frame); delete mediaPkt; } updateMediaPos(); if (elapsedTime == 0) { elapsedTime = av_gettime(); } /* time elapsed in 1/100th sec units since play started */ emit onElapsedtime((av_gettime() - elapsedTime) / 10000); } /* end while (1) */ } void DemuxMedia::onMediaSeek(int value) { posMutex.lock(); la_seekPos = value; posMutex.unlock(); } void DemuxMedia::updateMediaPos() { posMutex.lock(); if (la_seekPos >= 0) { xrdpvr_seek_media(la_seekPos, 0); elapsedTime = av_gettime() - la_seekPos * 1000000; la_seekPos = -1; } posMutex.unlock(); } xrdp-0.9.5/vrplayer/ourinterface.cpp000644 001751 001751 00000013457 13125122134 017464 0ustar00metameta000000 000000 #include "ourinterface.h" OurInterface::OurInterface(QObject *parent) : QObject(parent) { channel = NULL; savedGeometry.setX(0); savedGeometry.setY(0); savedGeometry.setWidth(0); savedGeometry.setHeight(0); stream_id = 101; demuxMedia = 0; //elapsedTime = 0; } int OurInterface::oneTimeInit() { /* connect to remote client */ if (openVirtualChannel()) return -1; /* register all formats/codecs */ av_register_all(); return 0; } void OurInterface::oneTimeDeinit() { /* clean up resources */ closeVirtualChannel(); } /* returns error */ int OurInterface::initRemoteClient() { int64_t start_time; int64_t duration; //elapsedTime = 0; if (sendMetadataFile()) return 1; if (sendVideoFormat()) return 1; if (sendAudioFormat()) return 1; if (sendGeometry(savedGeometry)) return 1; if (xrdpvr_play_media(channel, 101, filename.toAscii().data()) != 0) { return 1; } xrdpvr_get_media_duration(&start_time, &duration); //qDebug() << "ourInterface:initRemoteClient: emit onMediaDurationInSecs: dur=" << duration; emit onMediaDurationInSeconds(duration); /* LK_TODO this needs to be undone in deinitRemoteClient() */ if (!demuxMedia) { demuxMedia = new DemuxMedia(NULL, &videoQueue, channel, stream_id); demuxMediaThread = new QThread(this); connect(demuxMediaThread, SIGNAL(started()), demuxMedia, SLOT(startDemuxing())); demuxMedia->moveToThread(demuxMediaThread); //playVideo = demuxMedia->getPlayVideoInstance(); } return 0; } void OurInterface::deInitRemoteClient() { /* perform clean up */ xrdpvr_deinit_player(channel, 101); } /** * @brief Open a virtual connection to remote client * * @return 0 on success, -1 on failure ******************************************************************************/ int OurInterface::openVirtualChannel() { /* is channel already open? */ if (channel) return -1; printf("OurInterface::openVirtualChannel:\n"); /* open a virtual channel and connect to remote client */ channel = WTSVirtualChannelOpenEx(WTS_CURRENT_SESSION, "xrdpvr", 0); if (channel == NULL) { emit on_ErrorMsg("Connection failure", "Error connecting to remote client. Application will close now"); return -1; } return 0; } int OurInterface::closeVirtualChannel() { /* channel must be opened first */ if (!channel) return -1; WTSVirtualChannelClose(channel); return 0; } /** * @brief this is a temp hack while we figure out how to set up the right * context for avcodec_decode_video2() on the server side; the workaround * is to send the first 1MB of the media file to the server end which * reads this file and sets up its context * * @return 0 on success, -1 on failure ******************************************************************************/ int OurInterface::sendMetadataFile() { if (xrdpvr_init_player(channel, 101, filename.toAscii().data())) { fprintf(stderr, "failed to initialize the player\n"); return -1; } #if 0 if (xrdpvr_create_metadata_file(channel, filename.toAscii().data())) { emit on_ErrorMsg("I/O Error", "An error occurred while sending data to remote client"); return -1; } #endif return 0; } int OurInterface::sendVideoFormat() { #if 0 if (xrdpvr_set_video_format(channel, stream_id)) { emit on_ErrorMsg("I/O Error", "Error sending video format to remote client"); return -1; } #endif return 0; } int OurInterface::sendAudioFormat() { #if 0 if (xrdpvr_set_audio_format(channel, stream_id)) { emit on_ErrorMsg("I/O Error", "Error sending audio format to remote client"); return -1; } #endif return 0; } int OurInterface::sendGeometry(QRect rect) { int rv; savedGeometry.setX(rect.x()); savedGeometry.setY(rect.y()); savedGeometry.setWidth(rect.width()); savedGeometry.setHeight(rect.height()); rv = xrdpvr_set_geometry(channel, stream_id, savedGeometry.x(), savedGeometry.y(), savedGeometry.width(), savedGeometry.height()); if (rv) { emit on_ErrorMsg("I/O Error", "Error sending screen geometry to remote client"); return -1; } return 0; } void OurInterface::onGeometryChanged(int x, int y, int width, int height) { savedGeometry.setX(x); savedGeometry.setY(y); savedGeometry.setWidth(width); savedGeometry.setHeight(height); #if 0 qDebug() << "OurInterface:signal" << "" << savedGeometry.x() << "" << savedGeometry.y() << "" << savedGeometry.width() << "" << savedGeometry.height(); #endif if (channel) { xrdpvr_set_geometry(channel, 101, savedGeometry.x(), savedGeometry.y(), savedGeometry.width(), savedGeometry.height()); } } void OurInterface::setFilename(QString filename) { this->filename = filename; } void OurInterface::playMedia() { demuxMediaThread->start(); } //PlayVideo * OurInterface::getPlayVideoInstance() //{ // return this->playVideo; //} DemuxMedia * OurInterface::getDemuxMediaInstance() { return this->demuxMedia; } void OurInterface::setVcrOp(int op) { if (demuxMedia) demuxMedia->setVcrOp(op); } int OurInterface::setVolume(int volume) { printf("OurInterface::setVolume\n"); if (xrdpvr_set_volume(channel, volume)) { emit on_ErrorMsg("I/O Error", "Error sending volume to remote client"); return -1; } return 0; } xrdp-0.9.5/vrplayer/dlgabout.cpp000644 001751 001751 00000000471 13125122134 016567 0ustar00metameta000000 000000 #include "dlgabout.h" #include "ui_dlgabout.h" DlgAbout::DlgAbout(QWidget *parent) : QDialog(parent), ui(new Ui::DlgAbout) { ui->setupUi(this); connect(ui->okButton, SIGNAL(clicked()), this, SLOT(onOk())); } DlgAbout::~DlgAbout() { delete ui; } void DlgAbout::onOk() { this->done(0); } xrdp-0.9.5/vrplayer/playvideo.cpp000644 001751 001751 00000002716 13125122134 016766 0ustar00metameta000000 000000 #include #include #include "playvideo.h" #include PlayVideo::PlayVideo(QObject *parent, QQueue *videoQueue, QMutex *sendMutex, void *channel, int stream_id, int fps) : QObject(parent) { this->videoQueue = videoQueue; this->channel = channel; this->sendMutex = sendMutex; this->stream_id = stream_id; this->fps = fps; } /** ******************************************************************************/ static int get_mstime(void) { struct timeval tp; gettimeofday(&tp, 0); return (tp.tv_sec * 1000) + (tp.tv_usec / 1000); } void PlayVideo::play() { MediaPacket *pkt; int now_time; int sleep_time; int last_display_time; last_display_time = 0; while (1) { sendMutex->lock(); if (videoQueue->isEmpty()) { sendMutex->unlock(); usleep(10 * 1000); continue; } pkt = videoQueue->dequeue(); send_video_pkt(channel, stream_id, pkt->av_pkt); sendMutex->unlock(); now_time = get_mstime(); sleep_time = now_time - last_display_time; if (sleep_time > (1000 / fps)) { sleep_time = (1000 / fps); } if (sleep_time > 0) { usleep(sleep_time * 1000); } last_display_time = now_time; delete pkt; } } xrdp-0.9.5/vrplayer/decoderthread.cpp000644 001751 001751 00000014673 13127114621 017600 0ustar00metameta000000 000000 // not used #include "decoderthread.h" /* * TODO: * o need to maintain aspect ratio while resizing * o clicking in the middle of the slider bar should move the slider to the middle * o need to be able to rewind the move when it is done playing * o need to be able to load another move and play it w/o restarting player * o pause button needs to work * o need images for btns */ DecoderThread::DecoderThread() { channel = NULL; geometry.setX(0); geometry.setY(0); geometry.setWidth(0); geometry.setHeight(0); stream_id = 101; elapsedTime = 0; la_seekPos = -1; videoTimer = NULL; audioTimer = NULL; } void DecoderThread::run() { /* need a media file */ if (filename.length() == 0) { emit on_decoderErrorMsg("No media file", "Please select a media file to play"); return; } } void DecoderThread::startMediaPlay() { MediaPacket *mediaPkt; int is_video_frame; int rv; /* setup video timer; each time this timer fires, it sends */ /* one video pkt to the client then resets the callback duration */ videoTimer = new QTimer; connect(videoTimer, SIGNAL(timeout()), this, SLOT(videoTimerCallback())); //videoTimer->start(1500); /* setup audio timer; does the same as above, but with audio pkts */ audioTimer = new QTimer; connect(audioTimer, SIGNAL(timeout()), this, SLOT(audioTimerCallback())); //audioTimer->start(500); /* setup pktTimer; each time this timer fires, it reads AVPackets */ /* and puts them into audio/video Queues */ pktTimer = new QTimer; connect(pktTimer, SIGNAL(timeout()), this, SLOT(pktTimerCallback())); while (1) { /* fill the audio/video queues with initial data; thereafter */ /* data will be filled by pktTimerCallback() */ if ((audioQueue.count() >= 3000) || (videoQueue.count() >= 3000)) { //pktTimer->start(50); //videoTimer->start(1500); //audioTimer->start(500); playVideo = new PlayVideo(NULL, &videoQueue, channel, 101); playVideoThread = new QThread(this); connect(playVideoThread, SIGNAL(started()), playVideo, SLOT(play())); playVideo->moveToThread(playVideoThread); playVideoThread->start(); playAudio = new PlayAudio(NULL, &audioQueue, channel, 101); playAudioThread = new QThread(this); connect(playAudioThread, SIGNAL(started()), playAudio, SLOT(play())); playAudio->moveToThread(playAudioThread); playAudioThread->start(); return; } mediaPkt = new MediaPacket; rv = xrdpvr_get_frame(&mediaPkt->av_pkt, &is_video_frame, &mediaPkt->delay_in_us); if (rv < 0) { /* looks like we reached end of file */ break; } if (is_video_frame) videoQueue.enqueue(mediaPkt); else audioQueue.enqueue(mediaPkt); } /* end while (1) */ } void DecoderThread::on_mediaSeek(int value) { mutex.lock(); la_seekPos = value; mutex.unlock(); qDebug() << "media seek value=" << value; /* pktTimer stops at end of media; need to restart it */ if (!pktTimer->isActive()) { updateSlider(); pktTimer->start(100); } } void DecoderThread::setFilename(QString filename) { this->filename = filename; } void DecoderThread::stopPlayer() { pktTimer->stop(); audioQueue.clear(); videoQueue.clear(); } void DecoderThread::pausePlayer() { pktTimer->stop(); } void DecoderThread::resumePlayer() { pktTimer->start(100); } void DecoderThread::close() { } void DecoderThread::audioTimerCallback() { MediaPacket *pkt; int delayInMs; if (audioQueue.isEmpty()) { qDebug() << "audioTimerCallback: got empty"; audioTimer->setInterval(100); return; } pkt = audioQueue.dequeue(); delayInMs = (int) ((float) pkt->delay_in_us / 1000.0); send_audio_pkt(channel, 101, pkt->av_pkt); delete pkt; //qDebug() << "audioTimerCallback: delay :" << delayInMs; audioTimer->setInterval(delayInMs); } void DecoderThread::videoTimerCallback() { MediaPacket *pkt; int delayInMs; if (videoQueue.isEmpty()) { qDebug() << "videoTimerCallback: GOT EMPTY"; videoTimer->setInterval(100); return; } pkt = videoQueue.dequeue(); delayInMs = (int) 10; // ((float) pkt->delay_in_us / 1000.0); send_video_pkt(channel, 101, pkt->av_pkt); delete pkt; updateSlider(); //qDebug() << "videoTimerCallback: delay :" << delayInMs; videoTimer->setInterval(delayInMs); } void DecoderThread::pktTimerCallback() { MediaPacket *mediaPkt; int is_video_frame; int rv; while (1) { qDebug() << "pktTimerCallback: audioCount=" << audioQueue.count() << "videoCount=" << videoQueue.count(); #if 1 if ((audioQueue.count() >= 20) || (videoQueue.count() >= 20)) return; #else if (videoQueue.count() >= 60) return; #endif mediaPkt = new MediaPacket; rv = xrdpvr_get_frame(&mediaPkt->av_pkt, &is_video_frame, &mediaPkt->delay_in_us); if (rv < 0) { /* looks like we reached end of file */ qDebug() << "###### looks like we reached EOF"; pktTimer->stop(); // LK_TODO set some flag so audio/video timer also stop when q is empty return; } if (is_video_frame) videoQueue.enqueue(mediaPkt); else audioQueue.enqueue(mediaPkt); } } void DecoderThread::updateSlider() { if (elapsedTime == 0) elapsedTime = av_gettime(); /* time elapsed in 1/100th sec units since play started */ emit on_elapsedtime((av_gettime() - elapsedTime) / 10000); mutex.lock(); if (la_seekPos >= 0) { qDebug() << "seeking to" << la_seekPos; //audioTimer->stop(); //videoTimer->stop(); xrdpvr_seek_media(la_seekPos, 0); elapsedTime = av_gettime() - la_seekPos * 1000000; //audioTimer->start(10); //videoTimer->start(10); la_seekPos = -1; } mutex.unlock(); } xrdp-0.9.5/vrplayer/ourinterface.h000644 001751 001751 00000003113 13125122134 017115 0ustar00metameta000000 000000 #ifndef OURINTERFACE_H #define OURINTERFACE_H #ifdef __cplusplus #define __STDC_CONSTANT_MACROS #ifdef _STDINT_H #undef _STDINT_H #endif #include #endif #include #include #include // LK_TODO #include "xrdpvr.h" #include "xrdpapi.h" #include "demuxmedia.h" #include "playvideo.h" /* ffmpeg related stuff */ extern "C" { #include #include } class OurInterface : public QObject { Q_OBJECT public: explicit OurInterface(QObject *parent = 0); /* public methods */ int oneTimeInit(); void oneTimeDeinit(); int initRemoteClient(); void deInitRemoteClient(); int sendGeometry(QRect rect); void setFilename(QString filename); void playMedia(); //PlayVideo *getPlayVideoInstance(); DemuxMedia *getDemuxMediaInstance(); void setVcrOp(int op); int setVolume(int volume); public slots: void onGeometryChanged(int x, int y, int width, int height); signals: void on_ErrorMsg(QString title, QString msg); void onMediaDurationInSeconds(int duration); private: /* private stuff */ QQueue videoQueue; DemuxMedia *demuxMedia; QThread *demuxMediaThread; //PlayVideo *playVideo; QString filename; void *channel; int stream_id; QRect savedGeometry; /* private methods */ int openVirtualChannel(); int closeVirtualChannel(); int sendMetadataFile(); int sendVideoFormat(); int sendAudioFormat(); }; #endif // INTERFACE_H xrdp-0.9.5/pkgconfig/Makefile.am000644 001751 001751 00000000067 13133557325 016437 0ustar00metameta000000 000000 pkgconfigdir = @pkgconfigdir@ pkgconfig_DATA = xrdp.pc xrdp-0.9.5/pkgconfig/xrdp-uninstalled.pc.in000644 001751 001751 00000000274 13133557325 020631 0ustar00metameta000000 000000 abs_top_srcdir=@abs_top_srcdir@ includedir=${abs_top_srcdir}/common Name: xrdp Description: An open source Remote Desktop Protocol (RDP) server Version: @VERSION@ Cflags: -I${includedir} xrdp-0.9.5/pkgconfig/Makefile.in000644 001751 001751 00000036507 13220730774 016456 0ustar00metameta000000 000000 # Makefile.in generated by automake 1.15.1 from Makefile.am. # @configure_input@ # Copyright (C) 1994-2017 Free Software Foundation, Inc. # This Makefile.in is free software; the Free Software Foundation # gives unlimited permission to copy and/or distribute it, # with or without modifications, as long as this notice is preserved. # This program is distributed in the hope that it will be useful, # but WITHOUT ANY WARRANTY, to the extent permitted by law; without # even the implied warranty of MERCHANTABILITY or FITNESS FOR A # PARTICULAR PURPOSE. @SET_MAKE@ VPATH = @srcdir@ am__is_gnu_make = { \ if test -z '$(MAKELEVEL)'; then \ false; \ elif test -n '$(MAKE_HOST)'; then \ true; \ elif test -n '$(MAKE_VERSION)' && test -n '$(CURDIR)'; then \ true; \ else \ false; \ fi; \ } am__make_running_with_option = \ case $${target_option-} in \ ?) ;; \ *) echo "am__make_running_with_option: internal error: invalid" \ "target option '$${target_option-}' specified" >&2; \ exit 1;; \ esac; \ has_opt=no; \ sane_makeflags=$$MAKEFLAGS; \ if $(am__is_gnu_make); then \ sane_makeflags=$$MFLAGS; \ else \ case $$MAKEFLAGS in \ *\\[\ \ ]*) \ bs=\\; \ sane_makeflags=`printf '%s\n' "$$MAKEFLAGS" \ | sed "s/$$bs$$bs[$$bs $$bs ]*//g"`;; \ esac; \ fi; \ skip_next=no; \ strip_trailopt () \ { \ flg=`printf '%s\n' "$$flg" | sed "s/$$1.*$$//"`; \ }; \ for flg in $$sane_makeflags; do \ test $$skip_next = yes && { skip_next=no; continue; }; \ case $$flg in \ *=*|--*) continue;; \ -*I) strip_trailopt 'I'; skip_next=yes;; \ -*I?*) strip_trailopt 'I';; \ -*O) strip_trailopt 'O'; skip_next=yes;; \ -*O?*) strip_trailopt 'O';; \ -*l) strip_trailopt 'l'; skip_next=yes;; \ -*l?*) strip_trailopt 'l';; \ -[dEDm]) skip_next=yes;; \ -[JT]) skip_next=yes;; \ esac; \ case $$flg in \ *$$target_option*) has_opt=yes; break;; \ esac; \ done; \ test $$has_opt = yes am__make_dryrun = (target_option=n; $(am__make_running_with_option)) am__make_keepgoing = (target_option=k; $(am__make_running_with_option)) pkgdatadir = $(datadir)/@PACKAGE@ pkgincludedir = $(includedir)/@PACKAGE@ pkglibdir = $(libdir)/@PACKAGE@ pkglibexecdir = $(libexecdir)/@PACKAGE@ am__cd = CDPATH="$${ZSH_VERSION+.}$(PATH_SEPARATOR)" && cd install_sh_DATA = $(install_sh) -c -m 644 install_sh_PROGRAM = $(install_sh) -c install_sh_SCRIPT = $(install_sh) -c INSTALL_HEADER = $(INSTALL_DATA) transform = $(program_transform_name) NORMAL_INSTALL = : PRE_INSTALL = : POST_INSTALL = : NORMAL_UNINSTALL = : PRE_UNINSTALL = : POST_UNINSTALL = : build_triplet = @build@ host_triplet = @host@ subdir = pkgconfig ACLOCAL_M4 = $(top_srcdir)/aclocal.m4 am__aclocal_m4_deps = $(top_srcdir)/m4/ax_append_compile_flags.m4 \ $(top_srcdir)/m4/ax_append_flag.m4 \ $(top_srcdir)/m4/ax_cflags_warn_all.m4 \ $(top_srcdir)/m4/ax_check_compile_flag.m4 \ $(top_srcdir)/m4/ax_gcc_func_attribute.m4 \ $(top_srcdir)/m4/ax_require_defined.m4 \ $(top_srcdir)/m4/ax_type_socklen_t.m4 \ $(top_srcdir)/m4/libtool.m4 $(top_srcdir)/m4/ltoptions.m4 \ $(top_srcdir)/m4/ltsugar.m4 $(top_srcdir)/m4/ltversion.m4 \ $(top_srcdir)/m4/lt~obsolete.m4 $(top_srcdir)/m4/pkg.m4 \ $(top_srcdir)/configure.ac am__configure_deps = $(am__aclocal_m4_deps) $(CONFIGURE_DEPENDENCIES) \ $(ACLOCAL_M4) DIST_COMMON = $(srcdir)/Makefile.am $(am__DIST_COMMON) mkinstalldirs = $(install_sh) -d CONFIG_HEADER = $(top_builddir)/config_ac.h CONFIG_CLEAN_FILES = xrdp.pc xrdp-uninstalled.pc CONFIG_CLEAN_VPATH_FILES = AM_V_P = $(am__v_P_@AM_V@) am__v_P_ = $(am__v_P_@AM_DEFAULT_V@) am__v_P_0 = false am__v_P_1 = : AM_V_GEN = $(am__v_GEN_@AM_V@) am__v_GEN_ = $(am__v_GEN_@AM_DEFAULT_V@) am__v_GEN_0 = @echo " GEN " $@; am__v_GEN_1 = AM_V_at = $(am__v_at_@AM_V@) am__v_at_ = $(am__v_at_@AM_DEFAULT_V@) am__v_at_0 = @ am__v_at_1 = SOURCES = DIST_SOURCES = am__can_run_installinfo = \ case $$AM_UPDATE_INFO_DIR in \ n|no|NO) false;; \ *) (install-info --version) >/dev/null 2>&1;; \ esac am__vpath_adj_setup = srcdirstrip=`echo "$(srcdir)" | sed 's|.|.|g'`; am__vpath_adj = case $$p in \ $(srcdir)/*) f=`echo "$$p" | sed "s|^$$srcdirstrip/||"`;; \ *) f=$$p;; \ esac; am__strip_dir = f=`echo $$p | sed -e 's|^.*/||'`; am__install_max = 40 am__nobase_strip_setup = \ srcdirstrip=`echo "$(srcdir)" | sed 's/[].[^$$\\*|]/\\\\&/g'` am__nobase_strip = \ for p in $$list; do echo "$$p"; done | sed -e "s|$$srcdirstrip/||" am__nobase_list = $(am__nobase_strip_setup); \ for p in $$list; do echo "$$p $$p"; done | \ sed "s| $$srcdirstrip/| |;"' / .*\//!s/ .*/ ./; s,\( .*\)/[^/]*$$,\1,' | \ $(AWK) 'BEGIN { files["."] = "" } { files[$$2] = files[$$2] " " $$1; \ if (++n[$$2] == $(am__install_max)) \ { print $$2, files[$$2]; n[$$2] = 0; files[$$2] = "" } } \ END { for (dir in files) print dir, files[dir] }' am__base_list = \ sed '$$!N;$$!N;$$!N;$$!N;$$!N;$$!N;$$!N;s/\n/ /g' | \ sed '$$!N;$$!N;$$!N;$$!N;s/\n/ /g' am__uninstall_files_from_dir = { \ test -z "$$files" \ || { test ! -d "$$dir" && test ! -f "$$dir" && test ! -r "$$dir"; } \ || { echo " ( cd '$$dir' && rm -f" $$files ")"; \ $(am__cd) "$$dir" && rm -f $$files; }; \ } am__installdirs = "$(DESTDIR)$(pkgconfigdir)" DATA = $(pkgconfig_DATA) am__tagged_files = $(HEADERS) $(SOURCES) $(TAGS_FILES) $(LISP) am__DIST_COMMON = $(srcdir)/Makefile.in \ $(srcdir)/xrdp-uninstalled.pc.in $(srcdir)/xrdp.pc.in DISTFILES = $(DIST_COMMON) $(DIST_SOURCES) $(TEXINFOS) $(EXTRA_DIST) ACLOCAL = @ACLOCAL@ AMTAR = @AMTAR@ AM_DEFAULT_VERBOSITY = @AM_DEFAULT_VERBOSITY@ AR = @AR@ AUTOCONF = @AUTOCONF@ AUTOHEADER = @AUTOHEADER@ AUTOMAKE = @AUTOMAKE@ AWK = @AWK@ CC = @CC@ CCDEPMODE = @CCDEPMODE@ CFLAGS = @CFLAGS@ CPP = @CPP@ CPPFLAGS = @CPPFLAGS@ CYGPATH_W = @CYGPATH_W@ DEFS = @DEFS@ DEPDIR = @DEPDIR@ DLLTOOL = @DLLTOOL@ DLOPEN_LIBS = @DLOPEN_LIBS@ DSYMUTIL = @DSYMUTIL@ DUMPBIN = @DUMPBIN@ ECHO_C = @ECHO_C@ ECHO_N = @ECHO_N@ ECHO_T = @ECHO_T@ EGREP = @EGREP@ EXEEXT = @EXEEXT@ FDKAAC_CFLAGS = @FDKAAC_CFLAGS@ FDKAAC_LIBS = @FDKAAC_LIBS@ FGREP = @FGREP@ FREERDP_CFLAGS = @FREERDP_CFLAGS@ FREERDP_LIBS = @FREERDP_LIBS@ FUSE_CFLAGS = @FUSE_CFLAGS@ FUSE_LIBS = @FUSE_LIBS@ GREP = @GREP@ INSTALL = @INSTALL@ INSTALL_DATA = @INSTALL_DATA@ INSTALL_PROGRAM = @INSTALL_PROGRAM@ INSTALL_SCRIPT = @INSTALL_SCRIPT@ INSTALL_STRIP_PROGRAM = @INSTALL_STRIP_PROGRAM@ LD = @LD@ LDFLAGS = @LDFLAGS@ LIBOBJS = @LIBOBJS@ LIBS = @LIBS@ LIBTOOL = @LIBTOOL@ LIPO = @LIPO@ LN_S = @LN_S@ LTLIBOBJS = @LTLIBOBJS@ LT_SYS_LIBRARY_PATH = @LT_SYS_LIBRARY_PATH@ MAKEINFO = @MAKEINFO@ MANIFEST_TOOL = @MANIFEST_TOOL@ MKDIR_P = @MKDIR_P@ NM = @NM@ NMEDIT = @NMEDIT@ OBJDUMP = @OBJDUMP@ OBJEXT = @OBJEXT@ OPENSSL = @OPENSSL@ OPENSSL_CFLAGS = @OPENSSL_CFLAGS@ OPENSSL_LIBS = @OPENSSL_LIBS@ OTOOL = @OTOOL@ OTOOL64 = @OTOOL64@ PACKAGE = @PACKAGE@ PACKAGE_BUGREPORT = @PACKAGE_BUGREPORT@ PACKAGE_NAME = @PACKAGE_NAME@ PACKAGE_STRING = @PACKAGE_STRING@ PACKAGE_TARNAME = @PACKAGE_TARNAME@ PACKAGE_URL = @PACKAGE_URL@ PACKAGE_VERSION = @PACKAGE_VERSION@ PAM_RULES = @PAM_RULES@ PATH_SEPARATOR = @PATH_SEPARATOR@ PIXMAN_CFLAGS = @PIXMAN_CFLAGS@ PIXMAN_LIBS = @PIXMAN_LIBS@ PKG_CONFIG = @PKG_CONFIG@ PKG_CONFIG_LIBDIR = @PKG_CONFIG_LIBDIR@ PKG_CONFIG_PATH = @PKG_CONFIG_PATH@ RANLIB = @RANLIB@ SED = @SED@ SET_MAKE = @SET_MAKE@ SHELL = @SHELL@ STRIP = @STRIP@ TurboJpegIncDir = @TurboJpegIncDir@ TurboJpegLibDir = @TurboJpegLibDir@ VERSION = @VERSION@ XMKMF = @XMKMF@ X_CFLAGS = @X_CFLAGS@ X_EXTRA_LIBS = @X_EXTRA_LIBS@ X_LIBS = @X_LIBS@ X_PRE_LIBS = @X_PRE_LIBS@ abs_builddir = @abs_builddir@ abs_srcdir = @abs_srcdir@ abs_top_builddir = @abs_top_builddir@ abs_top_srcdir = @abs_top_srcdir@ ac_ct_AR = @ac_ct_AR@ ac_ct_CC = @ac_ct_CC@ ac_ct_DUMPBIN = @ac_ct_DUMPBIN@ am__include = @am__include@ am__leading_dot = @am__leading_dot@ am__quote = @am__quote@ am__tar = @am__tar@ am__untar = @am__untar@ bindir = @bindir@ build = @build@ build_alias = @build_alias@ build_cpu = @build_cpu@ build_os = @build_os@ build_vendor = @build_vendor@ builddir = @builddir@ datadir = @datadir@ datarootdir = @datarootdir@ docdir = @docdir@ dvidir = @dvidir@ exec_prefix = @exec_prefix@ host = @host@ host_alias = @host_alias@ host_cpu = @host_cpu@ host_os = @host_os@ host_vendor = @host_vendor@ htmldir = @htmldir@ includedir = @includedir@ infodir = @infodir@ install_sh = @install_sh@ libdir = @libdir@ libexecdir = @libexecdir@ localedir = @localedir@ localstatedir = @localstatedir@ mandir = @mandir@ mkdir_p = @mkdir_p@ moduledir = @moduledir@ oldincludedir = @oldincludedir@ pdfdir = @pdfdir@ pkgconfigdir = @pkgconfigdir@ prefix = @prefix@ program_transform_name = @program_transform_name@ psdir = @psdir@ sbindir = @sbindir@ sharedstatedir = @sharedstatedir@ socketdir = @socketdir@ srcdir = @srcdir@ subdirs = @subdirs@ sysconfdir = @sysconfdir@ systemdsystemunitdir = @systemdsystemunitdir@ target_alias = @target_alias@ top_build_prefix = @top_build_prefix@ top_builddir = @top_builddir@ top_srcdir = @top_srcdir@ pkgconfig_DATA = xrdp.pc all: all-am .SUFFIXES: $(srcdir)/Makefile.in: $(srcdir)/Makefile.am $(am__configure_deps) @for dep in $?; do \ case '$(am__configure_deps)' in \ *$$dep*) \ ( cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh ) \ && { if test -f $@; then exit 0; else break; fi; }; \ exit 1;; \ esac; \ done; \ echo ' cd $(top_srcdir) && $(AUTOMAKE) --foreign pkgconfig/Makefile'; \ $(am__cd) $(top_srcdir) && \ $(AUTOMAKE) --foreign pkgconfig/Makefile Makefile: $(srcdir)/Makefile.in $(top_builddir)/config.status @case '$?' in \ *config.status*) \ cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh;; \ *) \ echo ' cd $(top_builddir) && $(SHELL) ./config.status $(subdir)/$@ $(am__depfiles_maybe)'; \ cd $(top_builddir) && $(SHELL) ./config.status $(subdir)/$@ $(am__depfiles_maybe);; \ esac; $(top_builddir)/config.status: $(top_srcdir)/configure $(CONFIG_STATUS_DEPENDENCIES) cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh $(top_srcdir)/configure: $(am__configure_deps) cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh $(ACLOCAL_M4): $(am__aclocal_m4_deps) cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh $(am__aclocal_m4_deps): xrdp.pc: $(top_builddir)/config.status $(srcdir)/xrdp.pc.in cd $(top_builddir) && $(SHELL) ./config.status $(subdir)/$@ xrdp-uninstalled.pc: $(top_builddir)/config.status $(srcdir)/xrdp-uninstalled.pc.in cd $(top_builddir) && $(SHELL) ./config.status $(subdir)/$@ mostlyclean-libtool: -rm -f *.lo clean-libtool: -rm -rf .libs _libs install-pkgconfigDATA: $(pkgconfig_DATA) @$(NORMAL_INSTALL) @list='$(pkgconfig_DATA)'; test -n "$(pkgconfigdir)" || list=; \ if test -n "$$list"; then \ echo " $(MKDIR_P) '$(DESTDIR)$(pkgconfigdir)'"; \ $(MKDIR_P) "$(DESTDIR)$(pkgconfigdir)" || exit 1; \ fi; \ for p in $$list; do \ if test -f "$$p"; then d=; else d="$(srcdir)/"; fi; \ echo "$$d$$p"; \ done | $(am__base_list) | \ while read files; do \ echo " $(INSTALL_DATA) $$files '$(DESTDIR)$(pkgconfigdir)'"; \ $(INSTALL_DATA) $$files "$(DESTDIR)$(pkgconfigdir)" || exit $$?; \ done uninstall-pkgconfigDATA: @$(NORMAL_UNINSTALL) @list='$(pkgconfig_DATA)'; test -n "$(pkgconfigdir)" || list=; \ files=`for p in $$list; do echo $$p; done | sed -e 's|^.*/||'`; \ dir='$(DESTDIR)$(pkgconfigdir)'; $(am__uninstall_files_from_dir) tags TAGS: ctags CTAGS: cscope cscopelist: distdir: $(DISTFILES) @srcdirstrip=`echo "$(srcdir)" | sed 's/[].[^$$\\*]/\\\\&/g'`; \ topsrcdirstrip=`echo "$(top_srcdir)" | sed 's/[].[^$$\\*]/\\\\&/g'`; \ list='$(DISTFILES)'; \ dist_files=`for file in $$list; do echo $$file; done | \ sed -e "s|^$$srcdirstrip/||;t" \ -e "s|^$$topsrcdirstrip/|$(top_builddir)/|;t"`; \ case $$dist_files in \ */*) $(MKDIR_P) `echo "$$dist_files" | \ sed '/\//!d;s|^|$(distdir)/|;s,/[^/]*$$,,' | \ sort -u` ;; \ esac; \ for file in $$dist_files; do \ if test -f $$file || test -d $$file; then d=.; else d=$(srcdir); fi; \ if test -d $$d/$$file; then \ dir=`echo "/$$file" | sed -e 's,/[^/]*$$,,'`; \ if test -d "$(distdir)/$$file"; then \ find "$(distdir)/$$file" -type d ! -perm -700 -exec chmod u+rwx {} \;; \ fi; \ if test -d $(srcdir)/$$file && test $$d != $(srcdir); then \ cp -fpR $(srcdir)/$$file "$(distdir)$$dir" || exit 1; \ find "$(distdir)/$$file" -type d ! -perm -700 -exec chmod u+rwx {} \;; \ fi; \ cp -fpR $$d/$$file "$(distdir)$$dir" || exit 1; \ else \ test -f "$(distdir)/$$file" \ || cp -p $$d/$$file "$(distdir)/$$file" \ || exit 1; \ fi; \ done check-am: all-am check: check-am all-am: Makefile $(DATA) installdirs: for dir in "$(DESTDIR)$(pkgconfigdir)"; do \ test -z "$$dir" || $(MKDIR_P) "$$dir"; \ done install: install-am install-exec: install-exec-am install-data: install-data-am uninstall: uninstall-am install-am: all-am @$(MAKE) $(AM_MAKEFLAGS) install-exec-am install-data-am installcheck: installcheck-am install-strip: if test -z '$(STRIP)'; then \ $(MAKE) $(AM_MAKEFLAGS) INSTALL_PROGRAM="$(INSTALL_STRIP_PROGRAM)" \ install_sh_PROGRAM="$(INSTALL_STRIP_PROGRAM)" INSTALL_STRIP_FLAG=-s \ install; \ else \ $(MAKE) $(AM_MAKEFLAGS) INSTALL_PROGRAM="$(INSTALL_STRIP_PROGRAM)" \ install_sh_PROGRAM="$(INSTALL_STRIP_PROGRAM)" INSTALL_STRIP_FLAG=-s \ "INSTALL_PROGRAM_ENV=STRIPPROG='$(STRIP)'" install; \ fi mostlyclean-generic: clean-generic: distclean-generic: -test -z "$(CONFIG_CLEAN_FILES)" || rm -f $(CONFIG_CLEAN_FILES) -test . = "$(srcdir)" || test -z "$(CONFIG_CLEAN_VPATH_FILES)" || rm -f $(CONFIG_CLEAN_VPATH_FILES) maintainer-clean-generic: @echo "This command is intended for maintainers to use" @echo "it deletes files that may require special tools to rebuild." clean: clean-am clean-am: clean-generic clean-libtool mostlyclean-am distclean: distclean-am -rm -f Makefile distclean-am: clean-am distclean-generic dvi: dvi-am dvi-am: html: html-am html-am: info: info-am info-am: install-data-am: install-pkgconfigDATA install-dvi: install-dvi-am install-dvi-am: install-exec-am: install-html: install-html-am install-html-am: install-info: install-info-am install-info-am: install-man: install-pdf: install-pdf-am install-pdf-am: install-ps: install-ps-am install-ps-am: installcheck-am: maintainer-clean: maintainer-clean-am -rm -f Makefile maintainer-clean-am: distclean-am maintainer-clean-generic mostlyclean: mostlyclean-am mostlyclean-am: mostlyclean-generic mostlyclean-libtool pdf: pdf-am pdf-am: ps: ps-am ps-am: uninstall-am: uninstall-pkgconfigDATA .MAKE: install-am install-strip .PHONY: all all-am check check-am clean clean-generic clean-libtool \ cscopelist-am ctags-am distclean distclean-generic \ distclean-libtool distdir dvi dvi-am html html-am info info-am \ install install-am install-data install-data-am install-dvi \ install-dvi-am install-exec install-exec-am install-html \ install-html-am install-info install-info-am install-man \ install-pdf install-pdf-am install-pkgconfigDATA install-ps \ install-ps-am install-strip installcheck installcheck-am \ installdirs maintainer-clean maintainer-clean-generic \ mostlyclean mostlyclean-generic mostlyclean-libtool pdf pdf-am \ ps ps-am tags-am uninstall uninstall-am \ uninstall-pkgconfigDATA .PRECIOUS: Makefile # Tell versions [3.59,3.63) of GNU make to not export all variables. # Otherwise a system limit (for SysV at least) may be exceeded. .NOEXPORT: xrdp-0.9.5/pkgconfig/xrdp.pc.in000644 001751 001751 00000000312 13133557325 016302 0ustar00metameta000000 000000 prefix=@prefix@ exec_prefix=@exec_prefix@ libdir=@libdir@ includedir=@includedir@ Name: xrdp Description: An open source Remote Desktop Protocol (RDP) server Version: @VERSION@ Cflags: -I${includedir} xrdp-0.9.5/xrdpapi/vrplayer.c000644 001751 001751 00000005212 13174271344 016107 0ustar00metameta000000 000000 /** * xrdp: A Remote Desktop Protocol server. * * Copyright (C) Laxmikant Rashinkar 2012-2013 LK.Rashinkar@gmail.com * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. * * a program that uses xrdpapi and ffmpeg to redirect media streams * to a FreeRDP client where it is decompressed and played locally * */ /****************************************************************************** * build instructions: make -f vrplayer.mk * setup environment: export LD_LIBRARY_PATH=".libs:../xrdpvr/.libs" * run vrplayer: vrplayer *****************************************************************************/ #if defined(HAVE_CONFIG_H) #include #endif #ifdef __WIN32__ #include #endif #include #include #include #include #include #include #include "xrdpapi.h" #include "xrdpvr.h" void extract_32(uint32_t *value, char *buf) { *value = ((buf[3] << 24) & 0xff000000) | ((buf[2] << 16) & 0x00ff0000) | ((buf[1] << 8) & 0x0000ff00) | (buf[0] & 0x000000ff); } int main(int argc, char **argv) { char *data; char *data1; void *channel; int written = 0; int rv; int first_time = 1; int length; int bytes_read; if (argc < 2) { printf("usage: vrplayer >\n"); return 1; } /* open a virtual channel and connect to remote client */ channel = WTSVirtualChannelOpenEx(WTS_CURRENT_SESSION, "xrdpvr", 0); if (channel == NULL) { fprintf(stderr, "WTSVirtualChannelOpenEx() failed\n"); return 1; } /* initialize the player */ if (xrdpvr_init_player(channel, 101, argv[1])) { fprintf(stderr, "failed to initialize the player\n"); return 1; } /* send compressed media data to client; client will decompress */ /* the media and play it locally */ xrdpvr_play_media(channel, 101, argv[1]); /* perform clean up */ xrdpvr_deinit_player(channel, 101); WTSVirtualChannelClose(channel); return 0; } xrdp-0.9.5/xrdpapi/Makefile.in000644 001751 001751 00000051322 13220730775 016147 0ustar00metameta000000 000000 # Makefile.in generated by automake 1.15.1 from Makefile.am. # @configure_input@ # Copyright (C) 1994-2017 Free Software Foundation, Inc. # This Makefile.in is free software; the Free Software Foundation # gives unlimited permission to copy and/or distribute it, # with or without modifications, as long as this notice is preserved. # This program is distributed in the hope that it will be useful, # but WITHOUT ANY WARRANTY, to the extent permitted by law; without # even the implied warranty of MERCHANTABILITY or FITNESS FOR A # PARTICULAR PURPOSE. @SET_MAKE@ VPATH = @srcdir@ am__is_gnu_make = { \ if test -z '$(MAKELEVEL)'; then \ false; \ elif test -n '$(MAKE_HOST)'; then \ true; \ elif test -n '$(MAKE_VERSION)' && test -n '$(CURDIR)'; then \ true; \ else \ false; \ fi; \ } am__make_running_with_option = \ case $${target_option-} in \ ?) ;; \ *) echo "am__make_running_with_option: internal error: invalid" \ "target option '$${target_option-}' specified" >&2; \ exit 1;; \ esac; \ has_opt=no; \ sane_makeflags=$$MAKEFLAGS; \ if $(am__is_gnu_make); then \ sane_makeflags=$$MFLAGS; \ else \ case $$MAKEFLAGS in \ *\\[\ \ ]*) \ bs=\\; \ sane_makeflags=`printf '%s\n' "$$MAKEFLAGS" \ | sed "s/$$bs$$bs[$$bs $$bs ]*//g"`;; \ esac; \ fi; \ skip_next=no; \ strip_trailopt () \ { \ flg=`printf '%s\n' "$$flg" | sed "s/$$1.*$$//"`; \ }; \ for flg in $$sane_makeflags; do \ test $$skip_next = yes && { skip_next=no; continue; }; \ case $$flg in \ *=*|--*) continue;; \ -*I) strip_trailopt 'I'; skip_next=yes;; \ -*I?*) strip_trailopt 'I';; \ -*O) strip_trailopt 'O'; skip_next=yes;; \ -*O?*) strip_trailopt 'O';; \ -*l) strip_trailopt 'l'; skip_next=yes;; \ -*l?*) strip_trailopt 'l';; \ -[dEDm]) skip_next=yes;; \ -[JT]) skip_next=yes;; \ esac; \ case $$flg in \ *$$target_option*) has_opt=yes; break;; \ esac; \ done; \ test $$has_opt = yes am__make_dryrun = (target_option=n; $(am__make_running_with_option)) am__make_keepgoing = (target_option=k; $(am__make_running_with_option)) pkgdatadir = $(datadir)/@PACKAGE@ pkgincludedir = $(includedir)/@PACKAGE@ pkglibdir = $(libdir)/@PACKAGE@ pkglibexecdir = $(libexecdir)/@PACKAGE@ am__cd = CDPATH="$${ZSH_VERSION+.}$(PATH_SEPARATOR)" && cd install_sh_DATA = $(install_sh) -c -m 644 install_sh_PROGRAM = $(install_sh) -c install_sh_SCRIPT = $(install_sh) -c INSTALL_HEADER = $(INSTALL_DATA) transform = $(program_transform_name) NORMAL_INSTALL = : PRE_INSTALL = : POST_INSTALL = : NORMAL_UNINSTALL = : PRE_UNINSTALL = : POST_UNINSTALL = : build_triplet = @build@ host_triplet = @host@ subdir = xrdpapi ACLOCAL_M4 = $(top_srcdir)/aclocal.m4 am__aclocal_m4_deps = $(top_srcdir)/m4/ax_append_compile_flags.m4 \ $(top_srcdir)/m4/ax_append_flag.m4 \ $(top_srcdir)/m4/ax_cflags_warn_all.m4 \ $(top_srcdir)/m4/ax_check_compile_flag.m4 \ $(top_srcdir)/m4/ax_gcc_func_attribute.m4 \ $(top_srcdir)/m4/ax_require_defined.m4 \ $(top_srcdir)/m4/ax_type_socklen_t.m4 \ $(top_srcdir)/m4/libtool.m4 $(top_srcdir)/m4/ltoptions.m4 \ $(top_srcdir)/m4/ltsugar.m4 $(top_srcdir)/m4/ltversion.m4 \ $(top_srcdir)/m4/lt~obsolete.m4 $(top_srcdir)/m4/pkg.m4 \ $(top_srcdir)/configure.ac am__configure_deps = $(am__aclocal_m4_deps) $(CONFIGURE_DEPENDENCIES) \ $(ACLOCAL_M4) DIST_COMMON = $(srcdir)/Makefile.am $(am__DIST_COMMON) mkinstalldirs = $(install_sh) -d CONFIG_HEADER = $(top_builddir)/config_ac.h CONFIG_CLEAN_FILES = CONFIG_CLEAN_VPATH_FILES = am__vpath_adj_setup = srcdirstrip=`echo "$(srcdir)" | sed 's|.|.|g'`; am__vpath_adj = case $$p in \ $(srcdir)/*) f=`echo "$$p" | sed "s|^$$srcdirstrip/||"`;; \ *) f=$$p;; \ esac; am__strip_dir = f=`echo $$p | sed -e 's|^.*/||'`; am__install_max = 40 am__nobase_strip_setup = \ srcdirstrip=`echo "$(srcdir)" | sed 's/[].[^$$\\*|]/\\\\&/g'` am__nobase_strip = \ for p in $$list; do echo "$$p"; done | sed -e "s|$$srcdirstrip/||" am__nobase_list = $(am__nobase_strip_setup); \ for p in $$list; do echo "$$p $$p"; done | \ sed "s| $$srcdirstrip/| |;"' / .*\//!s/ .*/ ./; s,\( .*\)/[^/]*$$,\1,' | \ $(AWK) 'BEGIN { files["."] = "" } { files[$$2] = files[$$2] " " $$1; \ if (++n[$$2] == $(am__install_max)) \ { print $$2, files[$$2]; n[$$2] = 0; files[$$2] = "" } } \ END { for (dir in files) print dir, files[dir] }' am__base_list = \ sed '$$!N;$$!N;$$!N;$$!N;$$!N;$$!N;$$!N;s/\n/ /g' | \ sed '$$!N;$$!N;$$!N;$$!N;s/\n/ /g' am__uninstall_files_from_dir = { \ test -z "$$files" \ || { test ! -d "$$dir" && test ! -f "$$dir" && test ! -r "$$dir"; } \ || { echo " ( cd '$$dir' && rm -f" $$files ")"; \ $(am__cd) "$$dir" && rm -f $$files; }; \ } am__installdirs = "$(DESTDIR)$(moduledir)" LTLIBRARIES = $(module_LTLIBRARIES) libxrdpapi_la_LIBADD = am_libxrdpapi_la_OBJECTS = xrdpapi.lo libxrdpapi_la_OBJECTS = $(am_libxrdpapi_la_OBJECTS) AM_V_lt = $(am__v_lt_@AM_V@) am__v_lt_ = $(am__v_lt_@AM_DEFAULT_V@) am__v_lt_0 = --silent am__v_lt_1 = AM_V_P = $(am__v_P_@AM_V@) am__v_P_ = $(am__v_P_@AM_DEFAULT_V@) am__v_P_0 = false am__v_P_1 = : AM_V_GEN = $(am__v_GEN_@AM_V@) am__v_GEN_ = $(am__v_GEN_@AM_DEFAULT_V@) am__v_GEN_0 = @echo " GEN " $@; am__v_GEN_1 = AM_V_at = $(am__v_at_@AM_V@) am__v_at_ = $(am__v_at_@AM_DEFAULT_V@) am__v_at_0 = @ am__v_at_1 = DEFAULT_INCLUDES = -I.@am__isrc@ -I$(top_builddir) depcomp = $(SHELL) $(top_srcdir)/depcomp am__depfiles_maybe = depfiles am__mv = mv -f COMPILE = $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) \ $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) LTCOMPILE = $(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) \ $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) \ $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) \ $(AM_CFLAGS) $(CFLAGS) AM_V_CC = $(am__v_CC_@AM_V@) am__v_CC_ = $(am__v_CC_@AM_DEFAULT_V@) am__v_CC_0 = @echo " CC " $@; am__v_CC_1 = CCLD = $(CC) LINK = $(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) \ $(LIBTOOLFLAGS) --mode=link $(CCLD) $(AM_CFLAGS) $(CFLAGS) \ $(AM_LDFLAGS) $(LDFLAGS) -o $@ AM_V_CCLD = $(am__v_CCLD_@AM_V@) am__v_CCLD_ = $(am__v_CCLD_@AM_DEFAULT_V@) am__v_CCLD_0 = @echo " CCLD " $@; am__v_CCLD_1 = SOURCES = $(libxrdpapi_la_SOURCES) DIST_SOURCES = $(libxrdpapi_la_SOURCES) am__can_run_installinfo = \ case $$AM_UPDATE_INFO_DIR in \ n|no|NO) false;; \ *) (install-info --version) >/dev/null 2>&1;; \ esac am__tagged_files = $(HEADERS) $(SOURCES) $(TAGS_FILES) $(LISP) # Read a list of newline-separated strings from the standard input, # and print each of them once, without duplicates. Input order is # *not* preserved. am__uniquify_input = $(AWK) '\ BEGIN { nonempty = 0; } \ { items[$$0] = 1; nonempty = 1; } \ END { if (nonempty) { for (i in items) print i; }; } \ ' # Make sure the list of sources is unique. This is necessary because, # e.g., the same source file might be shared among _SOURCES variables # for different programs/libraries. am__define_uniq_tagged_files = \ list='$(am__tagged_files)'; \ unique=`for i in $$list; do \ if test -f "$$i"; then echo $$i; else echo $(srcdir)/$$i; fi; \ done | $(am__uniquify_input)` ETAGS = etags CTAGS = ctags am__DIST_COMMON = $(srcdir)/Makefile.in $(top_srcdir)/depcomp DISTFILES = $(DIST_COMMON) $(DIST_SOURCES) $(TEXINFOS) $(EXTRA_DIST) ACLOCAL = @ACLOCAL@ AMTAR = @AMTAR@ AM_DEFAULT_VERBOSITY = @AM_DEFAULT_VERBOSITY@ AR = @AR@ AUTOCONF = @AUTOCONF@ AUTOHEADER = @AUTOHEADER@ AUTOMAKE = @AUTOMAKE@ AWK = @AWK@ CC = @CC@ CCDEPMODE = @CCDEPMODE@ CFLAGS = @CFLAGS@ CPP = @CPP@ CPPFLAGS = @CPPFLAGS@ CYGPATH_W = @CYGPATH_W@ DEFS = @DEFS@ DEPDIR = @DEPDIR@ DLLTOOL = @DLLTOOL@ DLOPEN_LIBS = @DLOPEN_LIBS@ DSYMUTIL = @DSYMUTIL@ DUMPBIN = @DUMPBIN@ ECHO_C = @ECHO_C@ ECHO_N = @ECHO_N@ ECHO_T = @ECHO_T@ EGREP = @EGREP@ EXEEXT = @EXEEXT@ FDKAAC_CFLAGS = @FDKAAC_CFLAGS@ FDKAAC_LIBS = @FDKAAC_LIBS@ FGREP = @FGREP@ FREERDP_CFLAGS = @FREERDP_CFLAGS@ FREERDP_LIBS = @FREERDP_LIBS@ FUSE_CFLAGS = @FUSE_CFLAGS@ FUSE_LIBS = @FUSE_LIBS@ GREP = @GREP@ INSTALL = @INSTALL@ INSTALL_DATA = @INSTALL_DATA@ INSTALL_PROGRAM = @INSTALL_PROGRAM@ INSTALL_SCRIPT = @INSTALL_SCRIPT@ INSTALL_STRIP_PROGRAM = @INSTALL_STRIP_PROGRAM@ LD = @LD@ LDFLAGS = @LDFLAGS@ LIBOBJS = @LIBOBJS@ LIBS = @LIBS@ LIBTOOL = @LIBTOOL@ LIPO = @LIPO@ LN_S = @LN_S@ LTLIBOBJS = @LTLIBOBJS@ LT_SYS_LIBRARY_PATH = @LT_SYS_LIBRARY_PATH@ MAKEINFO = @MAKEINFO@ MANIFEST_TOOL = @MANIFEST_TOOL@ MKDIR_P = @MKDIR_P@ NM = @NM@ NMEDIT = @NMEDIT@ OBJDUMP = @OBJDUMP@ OBJEXT = @OBJEXT@ OPENSSL = @OPENSSL@ OPENSSL_CFLAGS = @OPENSSL_CFLAGS@ OPENSSL_LIBS = @OPENSSL_LIBS@ OTOOL = @OTOOL@ OTOOL64 = @OTOOL64@ PACKAGE = @PACKAGE@ PACKAGE_BUGREPORT = @PACKAGE_BUGREPORT@ PACKAGE_NAME = @PACKAGE_NAME@ PACKAGE_STRING = @PACKAGE_STRING@ PACKAGE_TARNAME = @PACKAGE_TARNAME@ PACKAGE_URL = @PACKAGE_URL@ PACKAGE_VERSION = @PACKAGE_VERSION@ PAM_RULES = @PAM_RULES@ PATH_SEPARATOR = @PATH_SEPARATOR@ PIXMAN_CFLAGS = @PIXMAN_CFLAGS@ PIXMAN_LIBS = @PIXMAN_LIBS@ PKG_CONFIG = @PKG_CONFIG@ PKG_CONFIG_LIBDIR = @PKG_CONFIG_LIBDIR@ PKG_CONFIG_PATH = @PKG_CONFIG_PATH@ RANLIB = @RANLIB@ SED = @SED@ SET_MAKE = @SET_MAKE@ SHELL = @SHELL@ STRIP = @STRIP@ TurboJpegIncDir = @TurboJpegIncDir@ TurboJpegLibDir = @TurboJpegLibDir@ VERSION = @VERSION@ XMKMF = @XMKMF@ X_CFLAGS = @X_CFLAGS@ X_EXTRA_LIBS = @X_EXTRA_LIBS@ X_LIBS = @X_LIBS@ X_PRE_LIBS = @X_PRE_LIBS@ abs_builddir = @abs_builddir@ abs_srcdir = @abs_srcdir@ abs_top_builddir = @abs_top_builddir@ abs_top_srcdir = @abs_top_srcdir@ ac_ct_AR = @ac_ct_AR@ ac_ct_CC = @ac_ct_CC@ ac_ct_DUMPBIN = @ac_ct_DUMPBIN@ am__include = @am__include@ am__leading_dot = @am__leading_dot@ am__quote = @am__quote@ am__tar = @am__tar@ am__untar = @am__untar@ bindir = @bindir@ build = @build@ build_alias = @build_alias@ build_cpu = @build_cpu@ build_os = @build_os@ build_vendor = @build_vendor@ builddir = @builddir@ datadir = @datadir@ datarootdir = @datarootdir@ docdir = @docdir@ dvidir = @dvidir@ exec_prefix = @exec_prefix@ host = @host@ host_alias = @host_alias@ host_cpu = @host_cpu@ host_os = @host_os@ host_vendor = @host_vendor@ htmldir = @htmldir@ includedir = @includedir@ infodir = @infodir@ install_sh = @install_sh@ libdir = @libdir@ libexecdir = @libexecdir@ localedir = @localedir@ localstatedir = @localstatedir@ mandir = @mandir@ mkdir_p = @mkdir_p@ moduledir = @moduledir@ oldincludedir = @oldincludedir@ pdfdir = @pdfdir@ pkgconfigdir = @pkgconfigdir@ prefix = @prefix@ program_transform_name = @program_transform_name@ psdir = @psdir@ sbindir = @sbindir@ sharedstatedir = @sharedstatedir@ socketdir = @socketdir@ srcdir = @srcdir@ subdirs = @subdirs@ sysconfdir = @sysconfdir@ systemdsystemunitdir = @systemdsystemunitdir@ target_alias = @target_alias@ top_build_prefix = @top_build_prefix@ top_builddir = @top_builddir@ top_srcdir = @top_srcdir@ EXTRA_DIST = \ simple.c \ vrplayer.c \ vrplayer.mk AM_CPPFLAGS = \ -DXRDP_SOCKET_PATH=\"${socketdir}\" \ -I$(top_srcdir)/common module_LTLIBRARIES = \ libxrdpapi.la libxrdpapi_la_SOURCES = \ xrdpapi.c \ xrdpapi.h all: all-am .SUFFIXES: .SUFFIXES: .c .lo .o .obj $(srcdir)/Makefile.in: $(srcdir)/Makefile.am $(am__configure_deps) @for dep in $?; do \ case '$(am__configure_deps)' in \ *$$dep*) \ ( cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh ) \ && { if test -f $@; then exit 0; else break; fi; }; \ exit 1;; \ esac; \ done; \ echo ' cd $(top_srcdir) && $(AUTOMAKE) --foreign xrdpapi/Makefile'; \ $(am__cd) $(top_srcdir) && \ $(AUTOMAKE) --foreign xrdpapi/Makefile Makefile: $(srcdir)/Makefile.in $(top_builddir)/config.status @case '$?' in \ *config.status*) \ cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh;; \ *) \ echo ' cd $(top_builddir) && $(SHELL) ./config.status $(subdir)/$@ $(am__depfiles_maybe)'; \ cd $(top_builddir) && $(SHELL) ./config.status $(subdir)/$@ $(am__depfiles_maybe);; \ esac; $(top_builddir)/config.status: $(top_srcdir)/configure $(CONFIG_STATUS_DEPENDENCIES) cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh $(top_srcdir)/configure: $(am__configure_deps) cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh $(ACLOCAL_M4): $(am__aclocal_m4_deps) cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh $(am__aclocal_m4_deps): install-moduleLTLIBRARIES: $(module_LTLIBRARIES) @$(NORMAL_INSTALL) @list='$(module_LTLIBRARIES)'; test -n "$(moduledir)" || list=; \ list2=; for p in $$list; do \ if test -f $$p; then \ list2="$$list2 $$p"; \ else :; fi; \ done; \ test -z "$$list2" || { \ echo " $(MKDIR_P) '$(DESTDIR)$(moduledir)'"; \ $(MKDIR_P) "$(DESTDIR)$(moduledir)" || exit 1; \ echo " $(LIBTOOL) $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=install $(INSTALL) $(INSTALL_STRIP_FLAG) $$list2 '$(DESTDIR)$(moduledir)'"; \ $(LIBTOOL) $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=install $(INSTALL) $(INSTALL_STRIP_FLAG) $$list2 "$(DESTDIR)$(moduledir)"; \ } uninstall-moduleLTLIBRARIES: @$(NORMAL_UNINSTALL) @list='$(module_LTLIBRARIES)'; test -n "$(moduledir)" || list=; \ for p in $$list; do \ $(am__strip_dir) \ echo " $(LIBTOOL) $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=uninstall rm -f '$(DESTDIR)$(moduledir)/$$f'"; \ $(LIBTOOL) $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=uninstall rm -f "$(DESTDIR)$(moduledir)/$$f"; \ done clean-moduleLTLIBRARIES: -test -z "$(module_LTLIBRARIES)" || rm -f $(module_LTLIBRARIES) @list='$(module_LTLIBRARIES)'; \ locs=`for p in $$list; do echo $$p; done | \ sed 's|^[^/]*$$|.|; s|/[^/]*$$||; s|$$|/so_locations|' | \ sort -u`; \ test -z "$$locs" || { \ echo rm -f $${locs}; \ rm -f $${locs}; \ } libxrdpapi.la: $(libxrdpapi_la_OBJECTS) $(libxrdpapi_la_DEPENDENCIES) $(EXTRA_libxrdpapi_la_DEPENDENCIES) $(AM_V_CCLD)$(LINK) -rpath $(moduledir) $(libxrdpapi_la_OBJECTS) $(libxrdpapi_la_LIBADD) $(LIBS) mostlyclean-compile: -rm -f *.$(OBJEXT) distclean-compile: -rm -f *.tab.c @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/xrdpapi.Plo@am__quote@ .c.o: @am__fastdepCC_TRUE@ $(AM_V_CC)$(COMPILE) -MT $@ -MD -MP -MF $(DEPDIR)/$*.Tpo -c -o $@ $< @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) $(DEPDIR)/$*.Tpo $(DEPDIR)/$*.Po @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='$<' object='$@' libtool=no @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(COMPILE) -c -o $@ $< .c.obj: @am__fastdepCC_TRUE@ $(AM_V_CC)$(COMPILE) -MT $@ -MD -MP -MF $(DEPDIR)/$*.Tpo -c -o $@ `$(CYGPATH_W) '$<'` @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) $(DEPDIR)/$*.Tpo $(DEPDIR)/$*.Po @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='$<' object='$@' libtool=no @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(COMPILE) -c -o $@ `$(CYGPATH_W) '$<'` .c.lo: @am__fastdepCC_TRUE@ $(AM_V_CC)$(LTCOMPILE) -MT $@ -MD -MP -MF $(DEPDIR)/$*.Tpo -c -o $@ $< @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) $(DEPDIR)/$*.Tpo $(DEPDIR)/$*.Plo @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='$<' object='$@' libtool=yes @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(LTCOMPILE) -c -o $@ $< mostlyclean-libtool: -rm -f *.lo clean-libtool: -rm -rf .libs _libs ID: $(am__tagged_files) $(am__define_uniq_tagged_files); mkid -fID $$unique tags: tags-am TAGS: tags tags-am: $(TAGS_DEPENDENCIES) $(am__tagged_files) set x; \ here=`pwd`; \ $(am__define_uniq_tagged_files); \ shift; \ if test -z "$(ETAGS_ARGS)$$*$$unique"; then :; else \ test -n "$$unique" || unique=$$empty_fix; \ if test $$# -gt 0; then \ $(ETAGS) $(ETAGSFLAGS) $(AM_ETAGSFLAGS) $(ETAGS_ARGS) \ "$$@" $$unique; \ else \ $(ETAGS) $(ETAGSFLAGS) $(AM_ETAGSFLAGS) $(ETAGS_ARGS) \ $$unique; \ fi; \ fi ctags: ctags-am CTAGS: ctags ctags-am: $(TAGS_DEPENDENCIES) $(am__tagged_files) $(am__define_uniq_tagged_files); \ test -z "$(CTAGS_ARGS)$$unique" \ || $(CTAGS) $(CTAGSFLAGS) $(AM_CTAGSFLAGS) $(CTAGS_ARGS) \ $$unique GTAGS: here=`$(am__cd) $(top_builddir) && pwd` \ && $(am__cd) $(top_srcdir) \ && gtags -i $(GTAGS_ARGS) "$$here" cscopelist: cscopelist-am cscopelist-am: $(am__tagged_files) list='$(am__tagged_files)'; \ case "$(srcdir)" in \ [\\/]* | ?:[\\/]*) sdir="$(srcdir)" ;; \ *) sdir=$(subdir)/$(srcdir) ;; \ esac; \ for i in $$list; do \ if test -f "$$i"; then \ echo "$(subdir)/$$i"; \ else \ echo "$$sdir/$$i"; \ fi; \ done >> $(top_builddir)/cscope.files distclean-tags: -rm -f TAGS ID GTAGS GRTAGS GSYMS GPATH tags distdir: $(DISTFILES) @srcdirstrip=`echo "$(srcdir)" | sed 's/[].[^$$\\*]/\\\\&/g'`; \ topsrcdirstrip=`echo "$(top_srcdir)" | sed 's/[].[^$$\\*]/\\\\&/g'`; \ list='$(DISTFILES)'; \ dist_files=`for file in $$list; do echo $$file; done | \ sed -e "s|^$$srcdirstrip/||;t" \ -e "s|^$$topsrcdirstrip/|$(top_builddir)/|;t"`; \ case $$dist_files in \ */*) $(MKDIR_P) `echo "$$dist_files" | \ sed '/\//!d;s|^|$(distdir)/|;s,/[^/]*$$,,' | \ sort -u` ;; \ esac; \ for file in $$dist_files; do \ if test -f $$file || test -d $$file; then d=.; else d=$(srcdir); fi; \ if test -d $$d/$$file; then \ dir=`echo "/$$file" | sed -e 's,/[^/]*$$,,'`; \ if test -d "$(distdir)/$$file"; then \ find "$(distdir)/$$file" -type d ! -perm -700 -exec chmod u+rwx {} \;; \ fi; \ if test -d $(srcdir)/$$file && test $$d != $(srcdir); then \ cp -fpR $(srcdir)/$$file "$(distdir)$$dir" || exit 1; \ find "$(distdir)/$$file" -type d ! -perm -700 -exec chmod u+rwx {} \;; \ fi; \ cp -fpR $$d/$$file "$(distdir)$$dir" || exit 1; \ else \ test -f "$(distdir)/$$file" \ || cp -p $$d/$$file "$(distdir)/$$file" \ || exit 1; \ fi; \ done check-am: all-am check: check-am all-am: Makefile $(LTLIBRARIES) installdirs: for dir in "$(DESTDIR)$(moduledir)"; do \ test -z "$$dir" || $(MKDIR_P) "$$dir"; \ done install: install-am install-exec: install-exec-am install-data: install-data-am uninstall: uninstall-am install-am: all-am @$(MAKE) $(AM_MAKEFLAGS) install-exec-am install-data-am installcheck: installcheck-am install-strip: if test -z '$(STRIP)'; then \ $(MAKE) $(AM_MAKEFLAGS) INSTALL_PROGRAM="$(INSTALL_STRIP_PROGRAM)" \ install_sh_PROGRAM="$(INSTALL_STRIP_PROGRAM)" INSTALL_STRIP_FLAG=-s \ install; \ else \ $(MAKE) $(AM_MAKEFLAGS) INSTALL_PROGRAM="$(INSTALL_STRIP_PROGRAM)" \ install_sh_PROGRAM="$(INSTALL_STRIP_PROGRAM)" INSTALL_STRIP_FLAG=-s \ "INSTALL_PROGRAM_ENV=STRIPPROG='$(STRIP)'" install; \ fi mostlyclean-generic: clean-generic: distclean-generic: -test -z "$(CONFIG_CLEAN_FILES)" || rm -f $(CONFIG_CLEAN_FILES) -test . = "$(srcdir)" || test -z "$(CONFIG_CLEAN_VPATH_FILES)" || rm -f $(CONFIG_CLEAN_VPATH_FILES) maintainer-clean-generic: @echo "This command is intended for maintainers to use" @echo "it deletes files that may require special tools to rebuild." clean: clean-am clean-am: clean-generic clean-libtool clean-moduleLTLIBRARIES \ mostlyclean-am distclean: distclean-am -rm -rf ./$(DEPDIR) -rm -f Makefile distclean-am: clean-am distclean-compile distclean-generic \ distclean-tags dvi: dvi-am dvi-am: html: html-am html-am: info: info-am info-am: install-data-am: install-moduleLTLIBRARIES install-dvi: install-dvi-am install-dvi-am: install-exec-am: install-html: install-html-am install-html-am: install-info: install-info-am install-info-am: install-man: install-pdf: install-pdf-am install-pdf-am: install-ps: install-ps-am install-ps-am: installcheck-am: maintainer-clean: maintainer-clean-am -rm -rf ./$(DEPDIR) -rm -f Makefile maintainer-clean-am: distclean-am maintainer-clean-generic mostlyclean: mostlyclean-am mostlyclean-am: mostlyclean-compile mostlyclean-generic \ mostlyclean-libtool pdf: pdf-am pdf-am: ps: ps-am ps-am: uninstall-am: uninstall-moduleLTLIBRARIES .MAKE: install-am install-strip .PHONY: CTAGS GTAGS TAGS all all-am check check-am clean clean-generic \ clean-libtool clean-moduleLTLIBRARIES cscopelist-am ctags \ ctags-am distclean distclean-compile distclean-generic \ distclean-libtool distclean-tags distdir dvi dvi-am html \ html-am info info-am install install-am install-data \ install-data-am install-dvi install-dvi-am install-exec \ install-exec-am install-html install-html-am install-info \ install-info-am install-man install-moduleLTLIBRARIES \ install-pdf install-pdf-am install-ps install-ps-am \ install-strip installcheck installcheck-am installdirs \ maintainer-clean maintainer-clean-generic mostlyclean \ mostlyclean-compile mostlyclean-generic mostlyclean-libtool \ pdf pdf-am ps ps-am tags tags-am uninstall uninstall-am \ uninstall-moduleLTLIBRARIES .PRECIOUS: Makefile # Tell versions [3.59,3.63) of GNU make to not export all variables. # Otherwise a system limit (for SysV at least) may be exceeded. .NOEXPORT: xrdp-0.9.5/xrdpapi/simple.c000644 001751 001751 00000010454 13174271344 015540 0ustar00metameta000000 000000 /** * xrdp: A Remote Desktop Protocol server. * * Copyright (C) Jay Sorg 2012-2013 * Copyright (C) Laxmikant Rashinkar 2012-2013 * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. * * sample program to demonstrate use of xrdpapi * */ /* * build instructions: * gcc simple.c -o simple -L./.libs -lxrdpapi */ #if defined(HAVE_CONFIG_H) #include #endif #ifdef __WIN32__ #include #endif #include "xrdpapi.h" #include #include #include #include #include /* forward declarations */ int run_echo_test(void); int run_tsmf_test(void); int main(int argc, char **argv) { if (argc < 2) { printf("usage: simple \n"); return 1; } if (strcasecmp(argv[1], "echo") == 0) { return run_echo_test(); } else if (strcasecmp(argv[1], "tsmf") == 0) { return run_tsmf_test(); } else { printf("usage: simple \n"); return 1; } } /** * perform an ECHO test with a Microsoft Windows RDP client * * A Microsoft Windows RDP client echos data written * to a dynamic virtual channel named ECHO * * NOTE: THIS TEST WILL FAIL IF CONNECTED FROM A NON * WINDOWS RDP CLIENT * * @return 0 on success, -1 on failure */ int run_echo_test(void) { char out_buf[8192]; char in_buf[1700]; void *channel; int bytes_left; int rv; int count; int pkt_count; int i; int bytes_written; int bytes_read; unsigned char c; unsigned char *rd_ptr; unsigned char *wr_ptr; /* fill out_buf[] with incremental values */ for (i = 0, c = 0; i < 8192; i++, c++) { out_buf[i] = c; } /* open a virtual channel named ECHO */ channel = WTSVirtualChannelOpenEx(WTS_CURRENT_SESSION, "ECHO", WTS_CHANNEL_OPTION_DYNAMIC_PRI_LOW); if (channel == NULL) { printf("### WTSVirtualChannelOpenEx() failed!\n"); return -1; } bytes_left = 8192; wr_ptr = out_buf; rd_ptr = out_buf; pkt_count = 1; while (bytes_left > 0) { /* write data to virtual channel */ count = (bytes_left > 1700) ? 1700 : bytes_left; rv = WTSVirtualChannelWrite(channel, wr_ptr, count, &bytes_written); if ((rv == 0) || (bytes_written == 0)) { printf("### WTSVirtualChannelWrite() failed\n"); return -1; } count = bytes_written; while (count) { /* read back the echo */ rv = WTSVirtualChannelRead(channel, 5000, in_buf, count, &bytes_read); if ((rv == 0) || (bytes_read == 0)) { printf("### WTSVirtualChannelRead() failed\n"); return -1; } /* validate the echo */ for (i = 0; i < bytes_read; i++, rd_ptr++) { if (*rd_ptr != (unsigned char) in_buf[i]) { printf("### data mismatch: expected 0x%x got 0x%x\n", (unsigned char) *rd_ptr, (unsigned char) in_buf[i]); return -1; } } count -= bytes_read; } bytes_left -= bytes_written; wr_ptr += bytes_written; printf("### pkt %d passed echo test\n", pkt_count++); } WTSVirtualChannelClose(channel); return 0; } int run_tsmf_test(void) { void *channel; printf("this test not yet implemented!\n"); return 1; /* open virtual channel */ channel = WTSVirtualChannelOpenEx(WTS_CURRENT_SESSION, "TSMF", WTS_CHANNEL_OPTION_DYNAMIC_PRI_LOW); if (channel == NULL) { printf("### WTSVirtualChannelOpenEx() failed!\n"); return 1; } WTSVirtualChannelClose(channel); return 0; } xrdp-0.9.5/xrdpapi/xrdpapi.c000644 001751 001751 00000030760 13206666623 015724 0ustar00metameta000000 000000 /** * xrdp: A Remote Desktop Protocol server. * * Copyright (C) Jay Sorg 2012-2013 * Copyright (C) Laxmikant Rashinkar 2012-2013 * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ #if defined(HAVE_CONFIG_H) #include #endif #define LOG_LEVEL 1 #define LLOG(_level, _args) \ do { if (_level < LOG_LEVEL) { ErrorF _args ; } } while (0) #define LLOGLN(_level, _args) \ do { if (_level < LOG_LEVEL) { printf _args ; printf("\n"); } } while (0) #include #include #include #include #include #include #include #include #include #include #include #include "xrdp_sockets.h" #include "xrdpapi.h" struct wts_obj { int fd; int status; char name[9]; char dname[128]; int display_num; uint32_t flags; }; /* helper functions used by WTSxxx API - do not invoke directly */ static int get_display_num_from_display(char *display_text); static int send_init(struct wts_obj *wts); static int can_send(int sck, int millis); static int can_recv(int sck, int millis); static const unsigned char g_xrdpapi_magic[12] = { 0x78, 0x32, 0x10, 0x67, 0x00, 0x92, 0x30, 0x56, 0xff, 0xd8, 0xa9, 0x1f }; /* * Opens a handle to the server end of a specified virtual channel - this * call is deprecated - use WTSVirtualChannelOpenEx() instead * * @param hServer * @param SessionId - current session ID; *must* be WTS_CURRENT_SERVER_HANDLE * @param pVirtualName - virtual channel name when using SVC * - name of endpoint listener when using DVC * * @return a valid pointer on success, NULL on error ******************************************************************************/ void * WTSVirtualChannelOpen(void *hServer, unsigned int SessionId, const char *pVirtualName) { if (hServer != WTS_CURRENT_SERVER_HANDLE) { return 0; } return WTSVirtualChannelOpenEx(SessionId, pVirtualName, 0); } /* * Opens a handle to the server end of a specified virtual channel * * @param SessionId - current session ID; *must* be WTS_CURRENT_SERVER_HANDLE * @param pVirtualName - virtual channel name when using SVC * - name of endpoint listener when using DVC * @param flags - type of channel and channel priority if DVC * * @return a valid pointer on success, NULL on error ******************************************************************************/ void * WTSVirtualChannelOpenEx(unsigned int SessionId, const char *pVirtualName, unsigned int flags) { struct wts_obj *wts; char *display_text; int bytes; unsigned long llong; struct sockaddr_un s; if (SessionId != WTS_CURRENT_SESSION) { LLOGLN(0, ("WTSVirtualChannelOpenEx: bad SessionId")); return 0; } wts = (struct wts_obj *) calloc(1, sizeof(struct wts_obj)); wts->fd = -1; wts->flags = flags; display_text = getenv("DISPLAY"); if (display_text != 0) { wts->display_num = get_display_num_from_display(display_text); } if (wts->display_num <= 0) { LLOGLN(0, ("WTSVirtualChannelOpenEx: fatal error; display is 0")); free(wts); return NULL; } /* we use unix domain socket to communicate with chansrv */ if ((wts->fd = socket(AF_UNIX, SOCK_STREAM, 0)) < 0) { free(wts); return NULL; } /* set non blocking */ llong = fcntl(wts->fd, F_GETFL); llong = llong | O_NONBLOCK; if (fcntl(wts->fd, F_SETFL, llong) < 0) { LLOGLN(10, ("WTSVirtualChannelOpenEx: set non-block mode failed")); } /* connect to chansrv session */ memset(&s, 0, sizeof(struct sockaddr_un)); s.sun_family = AF_UNIX; bytes = sizeof(s.sun_path); snprintf(s.sun_path, bytes - 1, CHANSRV_API_STR, wts->display_num); s.sun_path[bytes - 1] = 0; bytes = sizeof(struct sockaddr_un); if (connect(wts->fd, (struct sockaddr *) &s, bytes) == 0) { LLOGLN(10, ("WTSVirtualChannelOpenEx: connected ok, name %s", pVirtualName)); strncpy(wts->name, pVirtualName, 8); /* wait for connection to complete and send init */ if (send_init(wts) == 0) { /* all ok */ wts->status = 1; } } return wts; } /* * Prevent receiving SIGPIPE on disconnect using either MSG_NOSIGNAL (Linux) * or SO_NOSIGPIPE (Mac OS X) */ #if !defined(MSG_NOSIGNAL) #define MSG_NOSIGNAL 0 #endif /*****************************************************************************/ static int mysend(int sck, const void* adata, int bytes) { int sent; int error; const char* data; #if defined(SO_NOSIGPIPE) const int on = 1; setsockopt(sck, SOL_SOCKET, SO_NOSIGPIPE, &on, sizeof(on)); #endif data = (const char*)adata; sent = 0; while (sent < bytes) { if (can_send(sck, 100)) { error = send(sck, data + sent, bytes - sent, MSG_NOSIGNAL); if (error < 1) { return -1; } sent += error; } } return sent; } /* * write data to client connection * * @return 1 on success, 0 on error *****************************************************************************/ int WTSVirtualChannelWrite(void *hChannelHandle, const char *Buffer, unsigned int Length, unsigned int *pBytesWritten) { struct wts_obj *wts; int rv; int header[4]; wts = (struct wts_obj *) hChannelHandle; *pBytesWritten = 0; if (wts == 0) { LLOGLN(10, ("WTSVirtualChannelWrite: wts is NULL")); return 0; } if (wts->status != 1) { LLOGLN(10, ("WTSVirtualChannelWrite: wts->status != 1")); return 0; } if (!can_send(wts->fd, 0)) { return 1; /* can't write now, ok to try again */ } rv = 0; memcpy(header, g_xrdpapi_magic, 12); header[3] = Length; if (mysend(wts->fd, header, 16) == 16) { rv = mysend(wts->fd, Buffer, Length); } else { LLOGLN(0, ("WTSVirtualChannelWrite: header write failed")); return 0; } LLOGLN(10, ("WTSVirtualChannelWrite: mysend() returned %d", rv)); if (rv >= 0) { /* success, but zero bytes may have been written */ *pBytesWritten = rv; return 1; } #if 0 /* coverity: this is dead code */ /* error, but is it ok to try again? */ if ((rv == EWOULDBLOCK) || (rv == EAGAIN) || (rv == EINPROGRESS)) { return 0; /* failed to send, but should try again */ } #endif /* fatal error */ return 0; } /* * read data from a client connection * * @return 1 on success, 0 on error *****************************************************************************/ int WTSVirtualChannelRead(void *hChannelHandle, unsigned int TimeOut, char *Buffer, unsigned int BufferSize, unsigned int *pBytesRead) { struct wts_obj *wts; int rv; int lerrno; wts = (struct wts_obj *)hChannelHandle; if (wts == 0) { return 0; } if (wts->status != 1) { return 0; } if (can_recv(wts->fd, TimeOut)) { rv = recv(wts->fd, Buffer, BufferSize, 0); if (rv == -1) { lerrno = errno; if ((lerrno == EWOULDBLOCK) || (lerrno == EAGAIN) || (lerrno == EINPROGRESS)) { *pBytesRead = 0; return 1; } return 0; } else if (rv == 0) { return 0; } else if (rv > 0) { *pBytesRead = rv; return 1; } } *pBytesRead = 0; return 1; } /*****************************************************************************/ int WTSVirtualChannelClose(void *hChannelHandle) { struct wts_obj *wts; wts = (struct wts_obj *)hChannelHandle; if (wts == 0) { return 0; } if (wts->fd != -1) { close(wts->fd); } free(wts); return 1; } /*****************************************************************************/ int WTSVirtualChannelQuery(void *hChannelHandle, WTS_VIRTUAL_CLASS WtsVirtualClass, void **ppBuffer, unsigned int *pBytesReturned) { struct wts_obj *wts; wts = (struct wts_obj *)hChannelHandle; if (wts == 0) { return 0; } if (wts->status != 1) { return 0; } if (WtsVirtualClass == WTSVirtualFileHandle) { *pBytesReturned = 4; *ppBuffer = malloc(4); memcpy(*ppBuffer, &(wts->fd), 4); } return 1; } /*****************************************************************************/ void WTSFreeMemory(void *pMemory) { if (pMemory != 0) { free(pMemory); } } /***************************************************************************** ** ** ** ** ** Helper functions used by WTSxxx API - do not invoke directly ** ** ** ** ** *****************************************************************************/ /* * check if socket is in a writable state - i.e will not block on write * * @param sck socket to check * @param millis timeout value in milliseconds * * @return 0 if write will block * @return 1 if write will not block ******************************************************************************/ static int can_send(int sck, int millis) { struct timeval time; fd_set wfds; int select_rv; /* setup for a select call */ FD_ZERO(&wfds); FD_SET(sck, &wfds); time.tv_sec = millis / 1000; time.tv_usec = (millis * 1000) % 1000000; /* check if it is ok to write to specified socket */ select_rv = select(sck + 1, 0, &wfds, 0, &time); return (select_rv > 0) ? 1 : 0; } /*****************************************************************************/ static int can_recv(int sck, int millis) { struct timeval time; fd_set rfds; int select_rv; FD_ZERO(&rfds); FD_SET(sck, &rfds); time.tv_sec = millis / 1000; time.tv_usec = (millis * 1000) % 1000000; select_rv = select(sck + 1, &rfds, 0, 0, &time); if (select_rv > 0) { return 1; } return 0; } /*****************************************************************************/ static int send_init(struct wts_obj *wts) { char initmsg[64]; memset(initmsg, 0, 64); /* insert channel name */ strncpy(initmsg, wts->name, 8); /* insert open mode flags */ initmsg[16] = (wts->flags >> 0) & 0xff; initmsg[17] = (wts->flags >> 8) & 0xff; initmsg[18] = (wts->flags >> 16) & 0xff; initmsg[19] = (wts->flags >> 24) & 0xff; if (!can_send(wts->fd, 500)) { LLOGLN(10, ("send_init: send() will block!")); return 1; } if (send(wts->fd, initmsg, 64, 0) != 64) { LLOGLN(10, ("send_init: send() failed!")); return 1; } LLOGLN(10, ("send_init: sent ok!")); return 0; } /*****************************************************************************/ static int get_display_num_from_display(char *display_text) { int index; int mode; int disp_index; char disp[256]; index = 0; disp_index = 0; mode = 0; while (display_text[index] != 0) { if (display_text[index] == ':') { mode = 1; } else if (display_text[index] == '.') { mode = 2; } else if (mode == 1) { disp[disp_index] = display_text[index]; disp_index++; } index++; } disp[disp_index] = 0; return atoi(disp); } xrdp-0.9.5/xrdpapi/Makefile.am000644 001751 001751 00000000350 13174271344 016131 0ustar00metameta000000 000000 EXTRA_DIST = \ simple.c \ vrplayer.c \ vrplayer.mk AM_CPPFLAGS = \ -DXRDP_SOCKET_PATH=\"${socketdir}\" \ -I$(top_srcdir)/common module_LTLIBRARIES = \ libxrdpapi.la libxrdpapi_la_SOURCES = \ xrdpapi.c \ xrdpapi.h xrdp-0.9.5/xrdpapi/vrplayer.mk000644 001751 001751 00000000232 13125122134 016255 0ustar00metameta000000 000000 CFLAGS = -I../xrdpvr LIBS = -L./.libs -L../xrdpvr/.libs -lxrdpapi -lxrdpvr -lavformat vrplayer: vrplayer.o gcc $(CFLAGS) vrplayer.c -o vrplayer $(LIBS) xrdp-0.9.5/xrdpapi/xrdpapi.h000644 001751 001751 00000005110 13125122134 015700 0ustar00metameta000000 000000 /** * xrdp: A Remote Desktop Protocol server. * * Copyright (C) Jay Sorg 2012-2013 * Copyright (C) Thomas Goddard 2012-2013 * Copyright (C) Laxmikant Rashinkar 2012-2013 * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ /* * xrdpapi header, do not use os_calls.h, arch.h or any xrdp internal headers * this file is included in 3rd party apps */ #if !defined(XRDPAPI_H_) #define XRDPAPI_H_ #ifdef __cplusplus extern "C" { #endif #define WTS_CURRENT_SERVER_HANDLE 0x00000000 #define WTS_CURRENT_SESSION 0xffffffff #define WTS_CHANNEL_OPTION_STATIC 0x00000000 #define WTS_CHANNEL_OPTION_DYNAMIC 0x00000001 #define WTS_CHANNEL_OPTION_DYNAMIC_NO_COMPRESS 0x00000001 #define WTS_CHANNEL_OPTION_DYNAMIC_PRI_LOW 0x00000001 #define WTS_CHANNEL_OPTION_DYNAMIC_PRI_MED 0x00000002 #define WTS_CHANNEL_OPTION_DYNAMIC_PRI_HIGH 0x00000003 #define WTS_CHANNEL_OPTION_DYNAMIC_PRI_REAL 0x00000004 typedef enum _WTS_VIRTUAL_CLASS { WTSVirtualClientData, WTSVirtualFileHandle } WTS_VIRTUAL_CLASS; /* * Reference: * http://msdn.microsoft.com/en-us/library/windows/desktop/aa383464(v=vs.85).aspx */ void *WTSVirtualChannelOpen(void *hServer, unsigned int SessionId, const char *pVirtualName); void *WTSVirtualChannelOpenEx(unsigned int SessionId, const char *pVirtualName, unsigned int flags); int WTSVirtualChannelWrite(void *hChannelHandle, const char *Buffer, unsigned int Length, unsigned int *pBytesWritten); int WTSVirtualChannelRead(void *hChannelHandle, unsigned int TimeOut, char *Buffer, unsigned int BufferSize, unsigned int *pBytesRead); int WTSVirtualChannelClose(void *hChannelHandle); int WTSVirtualChannelQuery(void *hChannelHandle, WTS_VIRTUAL_CLASS WtsVirtualClass, void **ppBuffer, unsigned int *pBytesReturned); void WTSFreeMemory(void *pMemory); #ifdef __cplusplus } #endif #endif /* XRDPAPI_H_ */ xrdp-0.9.5/sesman/tools/000755 001751 001751 00000000000 13220731020 015036 5ustar00metameta000000 000000 xrdp-0.9.5/sesman/scp_v0.h000644 001751 001751 00000002014 13174271344 015256 0ustar00metameta000000 000000 /** * xrdp: A Remote Desktop Protocol server. * * Copyright (C) Jay Sorg 2004-2013 * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ /** * * @file scp_v0.h * @brief scp version 0 declarations * @author Simone Fedele * */ #ifndef SCP_V0_H #define SCP_V0_H #include "libscp.h" /** * * @brief processes the stream using scp version 0 * @param in_sck connection socket * @param in_s input stream * @param out_s output stream * */ void scp_v0_process(struct SCP_CONNECTION* c, struct SCP_SESSION* s); #endif xrdp-0.9.5/sesman/chansrv/000755 001751 001751 00000000000 13220731020 015342 5ustar00metameta000000 000000 xrdp-0.9.5/sesman/access.c000644 001751 001751 00000006270 13201006747 015322 0ustar00metameta000000 000000 /** * xrdp: A Remote Desktop Protocol server. * * Copyright (C) Jay Sorg 2004-2015 * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ /** * * @file access.c * @brief User access control code * @author Simone Fedele * */ #if defined(HAVE_CONFIG_H) #include #endif #include "sesman.h" extern struct config_sesman *g_cfg; /* in sesman.c */ /******************************************************************************/ int access_login_allowed(const char *user) { int gid; int ok; if ((0 == g_strncmp(user, "root", 5)) && (0 == g_cfg->sec.allow_root)) { log_message(LOG_LEVEL_WARNING, "ROOT login attempted, but root login is disabled"); return 0; } if ((0 == g_cfg->sec.ts_users_enable) && (0==g_cfg->sec.ts_always_group_check)) { LOG_DBG("Terminal Server Users group is disabled, allowing authentication", 1); return 1; } if (0 != g_getuser_info(user, &gid, 0, 0, 0, 0)) { log_message(LOG_LEVEL_ERROR, "Cannot read user info! - login denied"); return 0; } if (g_cfg->sec.ts_users == gid) { log_message(LOG_LEVEL_DEBUG,"ts_users is user's primary group"); return 1; } if (0 != g_check_user_in_group(user, g_cfg->sec.ts_users, &ok)) { log_message(LOG_LEVEL_ERROR, "Cannot read group info! - login denied"); return 0; } if (ok) { return 1; } log_message(LOG_LEVEL_INFO, "login denied for user %s", user); return 0; } /******************************************************************************/ int access_login_mng_allowed(const char *user) { int gid; int ok; if ((0 == g_strncmp(user, "root", 5)) && (0 == g_cfg->sec.allow_root)) { log_message(LOG_LEVEL_WARNING, "[MNG] ROOT login attempted, but root login is disabled"); return 0; } if (0 == g_cfg->sec.ts_admins_enable) { LOG_DBG("[MNG] Terminal Server Admin group is disabled, " "allowing authentication", 1); return 1; } if (0 != g_getuser_info(user, &gid, 0, 0, 0, 0)) { log_message(LOG_LEVEL_ERROR, "[MNG] Cannot read user info! - login denied"); return 0; } if (g_cfg->sec.ts_admins == gid) { LOG_DBG("[MNG] ts_users is user's primary group"); return 1; } if (0 != g_check_user_in_group(user, g_cfg->sec.ts_admins, &ok)) { log_message(LOG_LEVEL_ERROR, "[MNG] Cannot read group info! - login denied"); return 0; } if (ok) { return 1; } log_message(LOG_LEVEL_INFO, "[MNG] login denied for user %s", user); return 0; } xrdp-0.9.5/sesman/verify_user_pam_userpass.c000644 001751 001751 00000004712 13174271344 021212 0ustar00metameta000000 000000 /** * xrdp: A Remote Desktop Protocol server. * * Copyright (C) Jay Sorg 2004-2013 * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ /** * * @file verify_user_pam_userpass.c * @brief Authenticate user using pam_userpass module * @author Jay Sorg * */ #if defined(HAVE_CONFIG_H) #include #endif #include "arch.h" #include "os_calls.h" #include #define SERVICE "xrdp" /******************************************************************************/ /* returns boolean */ int auth_userpass(const char *user, const char *pass, int *errorcode) { pam_handle_t *pamh; pam_userpass_t userpass; struct pam_conv conv = {pam_userpass_conv, &userpass}; const void *template1; int status; userpass.user = user; userpass.pass = pass; if (pam_start(SERVICE, user, &conv, &pamh) != PAM_SUCCESS) { return 0; } status = pam_authenticate(pamh, 0); if (status != PAM_SUCCESS) { pam_end(pamh, status); return 0; } status = pam_acct_mgmt(pamh, 0); if (status != PAM_SUCCESS) { pam_end(pamh, status); return 0; } status = pam_get_item(pamh, PAM_USER, &template1); if (status != PAM_SUCCESS) { pam_end(pamh, status); return 0; } if (pam_end(pamh, PAM_SUCCESS) != PAM_SUCCESS) { return 0; } return 1; } /******************************************************************************/ /* returns error */ int auth_start_session(long in_val, int in_display) { return 0; } /******************************************************************************/ /* returns error */ int auth_stop_session(long in_val) { return 0; } /******************************************************************************/ int auth_end(long in_val) { return 0; } /******************************************************************************/ int auth_set_env(long in_val) { return 0; } xrdp-0.9.5/sesman/Makefile.am000644 001751 001751 00000002634 13206666623 015763 0ustar00metameta000000 000000 EXTRA_DIST = \ Doxyfile AM_CPPFLAGS = \ -DXRDP_SYSCONF_PATH=\"${sysconfdir}\" \ -DXRDP_CFG_PATH=\"${sysconfdir}/xrdp\" \ -DXRDP_SBIN_PATH=\"${sbindir}\" \ -DXRDP_SHARE_PATH=\"${datadir}/xrdp\" \ -DXRDP_PID_PATH=\"${localstatedir}/run\" \ -DXRDP_SOCKET_PATH=\"${socketdir}\" \ -I$(top_srcdir)/common \ -I$(top_srcdir)/sesman/libscp if XRDP_DEBUG AM_CPPFLAGS += -DXRDP_DEBUG endif if SESMAN_NOPAM AUTH_C = verify_user.c AUTH_LIB = -lcrypt else if SESMAN_BSD AUTH_C = verify_user_bsd.c AUTH_LIB = else if SESMAN_PAMUSERPASS AUTH_C = verify_user_pam_userpass.c AUTH_LIB = -lpam -lpam_userpass else if SESMAN_KERBEROS AUTH_C = verify_user_kerberos.c AUTH_LIB = -lkrb5 else AUTH_C = verify_user_pam.c AUTH_LIB = -lpam endif endif endif endif sbin_PROGRAMS = \ xrdp-sesman xrdp_sesman_SOURCES = \ access.c \ access.h \ auth.h \ config.c \ config.h \ env.c \ env.h \ scp.c \ scp.h \ scp_v0.c \ scp_v0.h \ scp_v1.c \ scp_v1.h \ scp_v1_mng.c \ scp_v1_mng.h \ sesman.c \ sesman.h \ session.c \ session.h \ sig.c \ sig.h \ xauth.c \ xauth.h \ $(AUTH_C) xrdp_sesman_LDADD = \ $(top_builddir)/common/libcommon.la \ $(top_builddir)/sesman/libscp/libscp.la \ $(AUTH_LIB) \ -lpthread sesmansysconfdir=$(sysconfdir)/xrdp dist_sesmansysconf_DATA = \ sesman.ini dist_sesmansysconf_SCRIPTS = \ startwm.sh \ reconnectwm.sh SUBDIRS = \ libscp \ tools \ chansrv xrdp-0.9.5/sesman/session.c000644 001751 001751 00000112064 13215625636 015554 0ustar00metameta000000 000000 /** * xrdp: A Remote Desktop Protocol server. * * Copyright (C) Jay Sorg 2004-2015 * * BSD process grouping by: * Copyright (c) 1995 Tatu Ylonen , Espoo, Finland. * Copyright (c) 2000-2001 Markus Friedl. * Copyright (c) 2011-2015 Koichiro Iwao, Kyushu Institute of Technology. * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ /** * * @file session.c * @brief Session management code * @author Jay Sorg, Simone Fedele * */ #if defined(HAVE_CONFIG_H) #include "config_ac.h" #endif #ifdef HAVE_SYS_PRCTL_H #include #endif #include "sesman.h" #include "libscp_types.h" #include "xauth.h" #include "xrdp_sockets.h" #ifndef PR_SET_NO_NEW_PRIVS #define PR_SET_NO_NEW_PRIVS 38 #endif extern unsigned char g_fixedkey[8]; extern struct config_sesman *g_cfg; /* in sesman.c */ extern int g_sck; /* in sesman.c */ struct session_chain *g_sessions; int g_session_count; extern tbus g_term_event; /* in sesman.c */ /** * Creates a string consisting of all parameters that is hosted in the param list * @param self * @param outstr, allocate this buffer before you use this function * @param len the allocated len for outstr * @return */ char * dumpItemsToString(struct list *self, char *outstr, int len) { int index; int totalLen = 0; g_memset(outstr, 0, len); if (self->count == 0) { g_writeln("List is empty"); } for (index = 0; index < self->count; index++) { /* +1 = one space*/ totalLen = totalLen + g_strlen((char *)list_get_item(self, index)) + 1; if (len > totalLen) { g_strcat(outstr, (char *)list_get_item(self, index)); g_strcat(outstr, " "); } } return outstr ; } /******************************************************************************/ struct session_item * session_get_bydata(const char *name, int width, int height, int bpp, int type, const char *client_ip) { struct session_chain *tmp; enum SESMAN_CFG_SESS_POLICY policy = g_cfg->sess.policy; tmp = g_sessions; /* convert from SCP_SESSION_TYPE namespace to SESMAN_SESSION_TYPE namespace */ switch (type) { case SCP_SESSION_TYPE_XVNC: /* 0 */ type = SESMAN_SESSION_TYPE_XVNC; /* 2 */ /* Xvnc cannot resize */ policy = (enum SESMAN_CFG_SESS_POLICY) (policy | SESMAN_CFG_SESS_POLICY_D); break; case SCP_SESSION_TYPE_XRDP: /* 1 */ type = SESMAN_SESSION_TYPE_XRDP; /* 1 */ break; case SCP_SESSION_TYPE_XORG: type = SESMAN_SESSION_TYPE_XORG; break; default: return 0; } #if 0 log_message(LOG_LEVEL_INFO, "session_get_bydata: search policy %d U %s W %d H %d bpp %d T %d IP %s", policy, name, width, height, bpp, type, client_ip); #endif while (tmp != 0) { #if 0 log_message(LOG_LEVEL_INFO, "session_get_bydata: try %p U %s W %d H %d bpp %d T %d IP %s", tmp->item, tmp->item->name, tmp->item->width, tmp->item->height, tmp->item->bpp, tmp->item->type, tmp->item->client_ip); #endif if (g_strncmp(name, tmp->item->name, 255) == 0 && (!(policy & SESMAN_CFG_SESS_POLICY_D) || (tmp->item->width == width && tmp->item->height == height)) && (!(policy & SESMAN_CFG_SESS_POLICY_I) || (g_strncmp_d(client_ip, tmp->item->client_ip, ':', 255) == 0)) && (!(policy & SESMAN_CFG_SESS_POLICY_C) || (g_strncmp(client_ip, tmp->item->client_ip, 255) == 0)) && tmp->item->bpp == bpp && tmp->item->type == type) { return tmp->item; } tmp = tmp->next; } return 0; } /******************************************************************************/ /** * * @brief checks if there's a server running on a display * @param display the display to check * @return 0 if there isn't a display running, nonzero otherwise * */ static int x_server_running_check_ports(int display) { char text[256]; int x_running; int sck; g_sprintf(text, "/tmp/.X11-unix/X%d", display); x_running = g_file_exist(text); if (!x_running) { g_sprintf(text, "/tmp/.X%d-lock", display); x_running = g_file_exist(text); } if (!x_running) /* check 59xx */ { if ((sck = g_tcp_socket()) != -1) { g_sprintf(text, "59%2.2d", display); x_running = g_tcp_bind(sck, text); g_tcp_close(sck); } } if (!x_running) /* check 60xx */ { if ((sck = g_tcp_socket()) != -1) { g_sprintf(text, "60%2.2d", display); x_running = g_tcp_bind(sck, text); g_tcp_close(sck); } } if (!x_running) /* check 62xx */ { if ((sck = g_tcp_socket()) != -1) { g_sprintf(text, "62%2.2d", display); x_running = g_tcp_bind(sck, text); g_tcp_close(sck); } } if (!x_running) { g_sprintf(text, XRDP_CHANSRV_STR, display); x_running = g_file_exist(text); } if (!x_running) { g_sprintf(text, CHANSRV_PORT_OUT_STR, display); x_running = g_file_exist(text); } if (!x_running) { g_sprintf(text, CHANSRV_PORT_IN_STR, display); x_running = g_file_exist(text); } if (!x_running) { g_sprintf(text, CHANSRV_API_STR, display); x_running = g_file_exist(text); } if (!x_running) { g_sprintf(text, XRDP_X11RDP_STR, display); x_running = g_file_exist(text); } return x_running; } /******************************************************************************/ /** * * @brief checks if there's a server running on a display * @param display the display to check * @return 0 if there isn't a display running, nonzero otherwise * */ static int x_server_running(int display) { char text[256]; int x_running; g_sprintf(text, "/tmp/.X11-unix/X%d", display); x_running = g_file_exist(text); if (!x_running) { g_sprintf(text, "/tmp/.X%d-lock", display); x_running = g_file_exist(text); } return x_running; } /******************************************************************************/ /* called with the main thread returns boolean */ static int session_is_display_in_chain(int display) { struct session_chain *chain; struct session_item *item; chain = g_sessions; while (chain != 0) { item = chain->item; if (item->display == display) { return 1; } chain = chain->next; } return 0; } /******************************************************************************/ /* called with the main thread */ static int session_get_avail_display_from_chain(void) { int display; display = g_cfg->sess.x11_display_offset; while ((display - g_cfg->sess.x11_display_offset) <= g_cfg->sess.max_sessions) { if (!session_is_display_in_chain(display)) { if (!x_server_running_check_ports(display)) { return display; } } display++; } log_message(LOG_LEVEL_ERROR, "X server -- no display in range is available"); return 0; } /******************************************************************************/ static int wait_for_xserver(int display) { int i; /* give X a bit to start */ /* wait up to 10 secs for x server to start */ i = 0; while (!x_server_running(display)) { i++; if (i > 40) { log_message(LOG_LEVEL_ERROR, "X server for display %d startup timeout", display); break; } g_sleep(250); } return 0; } /******************************************************************************/ static int session_start_chansrv(char *username, int display) { struct list *chansrv_params; char exe_path[262]; int chansrv_pid; chansrv_pid = g_fork(); if (chansrv_pid == 0) { chansrv_params = list_create(); chansrv_params->auto_free = 1; /* building parameters */ g_snprintf(exe_path, sizeof(exe_path), "%s/xrdp-chansrv", XRDP_SBIN_PATH); list_add_item(chansrv_params, (intptr_t) g_strdup(exe_path)); list_add_item(chansrv_params, 0); /* mandatory */ env_set_user(username, 0, display, g_cfg->session_variables1, g_cfg->session_variables2); /* executing chansrv */ g_execvp(exe_path, (char **) (chansrv_params->items)); /* should not get here */ log_message(LOG_LEVEL_ALWAYS, "error starting chansrv " "- user %s - pid %d", username, g_getpid()); list_delete(chansrv_params); g_exit(1); } return chansrv_pid; } /******************************************************************************/ /* called with the main thread */ static int session_start_fork(tbus data, tui8 type, struct SCP_CONNECTION *c, struct SCP_SESSION *s) { int display = 0; int pid = 0; int i = 0; char geometry[32]; char depth[32]; char screen[32]; /* display number */ char text[256]; char execvpparams[2048]; char *xserver; /* absolute/relative path to Xorg/X11rdp/Xvnc */ char *passwd_file; char **pp1 = (char **)NULL; struct session_chain *temp = (struct session_chain *)NULL; struct list *xserver_params = (struct list *)NULL; struct tm stime; time_t ltime; char authfile[256]; /* The filename for storing xauth informations */ int chansrv_pid; int display_pid; int window_manager_pid; /* initialize (zero out) local variables: */ g_memset(<ime, 0, sizeof(time_t)); g_memset(&stime, 0, sizeof(struct tm)); g_memset(geometry, 0, sizeof(char) * 32); g_memset(depth, 0, sizeof(char) * 32); g_memset(screen, 0, sizeof(char) * 32); g_memset(text, 0, sizeof(char) * 256); passwd_file = 0; /* check to limit concurrent sessions */ if (g_session_count >= g_cfg->sess.max_sessions) { log_message(LOG_LEVEL_INFO, "max concurrent session limit " "exceeded. login for user %s denied", s->username); return 0; } temp = (struct session_chain *)g_malloc(sizeof(struct session_chain), 0); if (temp == 0) { log_message(LOG_LEVEL_ERROR, "cannot create new chain " "element - user %s", s->username); return 0; } temp->item = (struct session_item *)g_malloc(sizeof(struct session_item), 0); if (temp->item == 0) { g_free(temp); log_message(LOG_LEVEL_ERROR, "cannot create new session " "item - user %s", s->username); return 0; } display = session_get_avail_display_from_chain(); if (display == 0) { g_free(temp->item); g_free(temp); return 0; } pid = g_fork(); /* parent is fork from tcp accept, child forks X and wm, then becomes scp */ if (pid == -1) { } else if (pid == 0) { log_message(LOG_LEVEL_INFO, "calling auth_start_session from pid %d", g_getpid()); auth_start_session(data, display); g_delete_wait_obj(g_term_event); g_tcp_close(g_sck); g_tcp_close(c->in_sck); g_sprintf(geometry, "%dx%d", s->width, s->height); g_sprintf(depth, "%d", s->bpp); g_sprintf(screen, ":%d", display); #if defined(__FreeBSD__) || defined(__FreeBSD_kernel__) /* * FreeBSD bug * ports/157282: effective login name is not set by xrdp-sesman * http://www.freebsd.org/cgi/query-pr.cgi?pr=157282 * * from: * $OpenBSD: session.c,v 1.252 2010/03/07 11:57:13 dtucker Exp $ * with some ideas about BSD process grouping to xrdp */ /** * Create a new session and process group since the 4.4BSD * setlogin() affects the entire process group */ if (g_setsid() < 0) { log_message(LOG_LEVEL_ERROR, "setsid failed - pid %d", g_getpid()); } if (g_setlogin(s->username) < 0) { log_message(LOG_LEVEL_ERROR, "setlogin failed for user %s - pid %d", s->username, g_getpid()); } #endif window_manager_pid = g_fork(); /* parent becomes X, child forks wm, and waits, todo */ if (window_manager_pid == -1) { } else if (window_manager_pid == 0) { wait_for_xserver(display); env_set_user(s->username, 0, display, g_cfg->session_variables1, g_cfg->session_variables2); if (x_server_running(display)) { auth_set_env(data); if (s->directory != 0) { if (s->directory[0] != 0) { g_set_current_dir(s->directory); } } if (s->program != 0) { if (s->program[0] != 0) { g_execlp3(s->program, s->program, 0); log_message(LOG_LEVEL_ALWAYS, "error starting program %s for user %s - pid %d", s->program, s->username, g_getpid()); } } /* try to execute user window manager if enabled */ if (g_cfg->enable_user_wm) { g_sprintf(text, "%s/%s", g_getenv("HOME"), g_cfg->user_wm); if (g_file_exist(text)) { g_execlp3(text, g_cfg->user_wm, 0); log_message(LOG_LEVEL_ALWAYS, "error starting user " "wm for user %s - pid %d", s->username, g_getpid()); /* logging parameters */ log_message(LOG_LEVEL_DEBUG, "errno: %d, " "description: %s", g_get_errno(), g_get_strerror()); log_message(LOG_LEVEL_DEBUG, "execlp3 parameter " "list:"); log_message(LOG_LEVEL_DEBUG, " argv[0] = %s", text); log_message(LOG_LEVEL_DEBUG, " argv[1] = %s", g_cfg->user_wm); } } /* if we're here something happened to g_execlp3 so we try running the default window manager */ g_sprintf(text, "%s/%s", XRDP_CFG_PATH, g_cfg->default_wm); g_execlp3(text, g_cfg->default_wm, 0); log_message(LOG_LEVEL_ALWAYS, "error starting default " "wm for user %s - pid %d", s->username, g_getpid()); /* logging parameters */ log_message(LOG_LEVEL_DEBUG, "errno: %d, description: " "%s", g_get_errno(), g_get_strerror()); log_message(LOG_LEVEL_DEBUG, "execlp3 parameter list:"); log_message(LOG_LEVEL_DEBUG, " argv[0] = %s", text); log_message(LOG_LEVEL_DEBUG, " argv[1] = %s", g_cfg->default_wm); /* still a problem starting window manager just start xterm */ g_execlp3("xterm", "xterm", 0); /* should not get here */ log_message(LOG_LEVEL_ALWAYS, "error starting xterm " "for user %s - pid %d", s->username, g_getpid()); /* logging parameters */ log_message(LOG_LEVEL_DEBUG, "errno: %d, description: " "%s", g_get_errno(), g_get_strerror()); } else { log_message(LOG_LEVEL_ERROR, "another Xserver might " "already be active on display %d - see log", display); } log_message(LOG_LEVEL_DEBUG, "aborting connection..."); g_exit(0); } else { display_pid = g_fork(); /* parent becomes scp, child becomes X */ if (display_pid == -1) { } else if (display_pid == 0) /* child */ { if (type == SESMAN_SESSION_TYPE_XVNC) { env_set_user(s->username, &passwd_file, display, g_cfg->session_variables1, g_cfg->session_variables2); } else { env_set_user(s->username, 0, display, g_cfg->session_variables1, g_cfg->session_variables2); } g_snprintf(text, 255, "%d", g_cfg->sess.max_idle_time); g_setenv("XRDP_SESMAN_MAX_IDLE_TIME", text, 1); g_snprintf(text, 255, "%d", g_cfg->sess.max_disc_time); g_setenv("XRDP_SESMAN_MAX_DISC_TIME", text, 1); g_snprintf(text, 255, "%d", g_cfg->sess.kill_disconnected); g_setenv("XRDP_SESMAN_KILL_DISCONNECTED", text, 1); g_setenv("XRDP_SOCKET_PATH", XRDP_SOCKET_PATH, 1); /* prepare the Xauthority stuff */ if (g_getenv("XAUTHORITY") != NULL) { g_snprintf(authfile, 255, "%s", g_getenv("XAUTHORITY")); } else { g_snprintf(authfile, 255, "%s", ".Xauthority"); } /* Add the entry in XAUTHORITY file or exit if error */ if (add_xauth_cookie(display, authfile) != 0) { g_exit(1); } if (type == SESMAN_SESSION_TYPE_XORG) { #ifdef HAVE_SYS_PRCTL_H /* * Make sure Xorg doesn't run setuid root. Root access is not * needed. Xorg can fail when run as root and the user has no * console permissions. * PR_SET_NO_NEW_PRIVS requires Linux kernel 3.5 and newer. */ if (prctl(PR_SET_NO_NEW_PRIVS, 1, 0, 0, 0) < 0) { log_message(LOG_LEVEL_WARNING, "Failed to disable setuid on X server: %s", g_get_strerror()); } #endif xserver_params = list_create(); xserver_params->auto_free = 1; /* get path of Xorg from config */ xserver = g_strdup((const char *)list_get_item(g_cfg->xorg_params, 0)); /* these are the must have parameters */ list_add_item(xserver_params, (tintptr) g_strdup(xserver)); list_add_item(xserver_params, (tintptr) g_strdup(screen)); list_add_item(xserver_params, (tintptr) g_strdup("-auth")); list_add_item(xserver_params, (tintptr) g_strdup(authfile)); /* additional parameters from sesman.ini file */ list_append_list_strdup(g_cfg->xorg_params, xserver_params, 1); /* make sure it ends with a zero */ list_add_item(xserver_params, 0); pp1 = (char **) xserver_params->items; log_message(LOG_LEVEL_INFO, "%s", dumpItemsToString(xserver_params, execvpparams, 2048)); /* some args are passed via env vars */ g_sprintf(geometry, "%d", s->width); g_setenv("XRDP_START_WIDTH", geometry, 1); g_sprintf(geometry, "%d", s->height); g_setenv("XRDP_START_HEIGHT", geometry, 1); /* fire up Xorg */ g_execvp(xserver, pp1); } else if (type == SESMAN_SESSION_TYPE_XVNC) { char guid_str[64]; g_bytes_to_hexstr(s->guid, 16, guid_str, 64); env_check_password_file(passwd_file, guid_str); xserver_params = list_create(); xserver_params->auto_free = 1; /* get path of Xvnc from config */ xserver = g_strdup((const char *)list_get_item(g_cfg->vnc_params, 0)); /* these are the must have parameters */ list_add_item(xserver_params, (tintptr)g_strdup(xserver)); list_add_item(xserver_params, (tintptr)g_strdup(screen)); list_add_item(xserver_params, (tintptr)g_strdup("-auth")); list_add_item(xserver_params, (tintptr)g_strdup(authfile)); list_add_item(xserver_params, (tintptr)g_strdup("-geometry")); list_add_item(xserver_params, (tintptr)g_strdup(geometry)); list_add_item(xserver_params, (tintptr)g_strdup("-depth")); list_add_item(xserver_params, (tintptr)g_strdup(depth)); list_add_item(xserver_params, (tintptr)g_strdup("-rfbauth")); list_add_item(xserver_params, (tintptr)g_strdup(passwd_file)); g_free(passwd_file); /* additional parameters from sesman.ini file */ //config_read_xserver_params(SESMAN_SESSION_TYPE_XVNC, // xserver_params); list_append_list_strdup(g_cfg->vnc_params, xserver_params, 1); /* make sure it ends with a zero */ list_add_item(xserver_params, 0); pp1 = (char **)xserver_params->items; log_message(LOG_LEVEL_INFO, "%s", dumpItemsToString(xserver_params, execvpparams, 2048)); g_execvp(xserver, pp1); } else if (type == SESMAN_SESSION_TYPE_XRDP) { xserver_params = list_create(); xserver_params->auto_free = 1; /* get path of X11rdp from config */ xserver = g_strdup((const char *)list_get_item(g_cfg->rdp_params, 0)); /* these are the must have parameters */ list_add_item(xserver_params, (tintptr)g_strdup(xserver)); list_add_item(xserver_params, (tintptr)g_strdup(screen)); list_add_item(xserver_params, (tintptr)g_strdup("-auth")); list_add_item(xserver_params, (tintptr)g_strdup(authfile)); list_add_item(xserver_params, (tintptr)g_strdup("-geometry")); list_add_item(xserver_params, (tintptr)g_strdup(geometry)); list_add_item(xserver_params, (tintptr)g_strdup("-depth")); list_add_item(xserver_params, (tintptr)g_strdup(depth)); /* additional parameters from sesman.ini file */ //config_read_xserver_params(SESMAN_SESSION_TYPE_XRDP, // xserver_params); list_append_list_strdup(g_cfg->rdp_params, xserver_params, 1); /* make sure it ends with a zero */ list_add_item(xserver_params, 0); pp1 = (char **)xserver_params->items; log_message(LOG_LEVEL_INFO, "%s", dumpItemsToString(xserver_params, execvpparams, 2048)); g_execvp(xserver, pp1); } else { log_message(LOG_LEVEL_ALWAYS, "bad session type - " "user %s - pid %d", s->username, g_getpid()); g_exit(1); } /* should not get here */ log_message(LOG_LEVEL_ALWAYS, "error starting X server " "- user %s - pid %d", s->username, g_getpid()); /* logging parameters */ log_message(LOG_LEVEL_DEBUG, "errno: %d, description: " "%s", g_get_errno(), g_get_strerror()); log_message(LOG_LEVEL_DEBUG, "execve parameter list size: " "%d", (xserver_params)->count); for (i = 0; i < (xserver_params->count); i++) { log_message(LOG_LEVEL_DEBUG, " argv[%d] = %s", i, (char *)list_get_item(xserver_params, i)); } list_delete(xserver_params); g_exit(1); } else { wait_for_xserver(display); chansrv_pid = session_start_chansrv(s->username, display); log_message(LOG_LEVEL_ALWAYS, "waiting for window manager " "(pid %d) to exit", window_manager_pid); g_waitpid(window_manager_pid); log_message(LOG_LEVEL_ALWAYS, "window manager (pid %d) did " "exit, cleaning up session", window_manager_pid); log_message(LOG_LEVEL_INFO, "calling auth_stop_session and " "auth_end from pid %d", g_getpid()); auth_stop_session(data); auth_end(data); g_sigterm(display_pid); g_sigterm(chansrv_pid); cleanup_sockets(display); g_deinit(); g_exit(0); } } } else { temp->item->pid = pid; temp->item->display = display; temp->item->width = s->width; temp->item->height = s->height; temp->item->bpp = s->bpp; temp->item->data = data; g_strncpy(temp->item->client_ip, s->client_ip, 255); /* store client ip data */ g_strncpy(temp->item->name, s->username, 255); g_memcpy(temp->item->guid, s->guid, 16); ltime = g_time1(); localtime_r(<ime, &stime); temp->item->connect_time.year = (tui16)(stime.tm_year + 1900); temp->item->connect_time.month = (tui8)(stime.tm_mon + 1); temp->item->connect_time.day = (tui8)stime.tm_mday; temp->item->connect_time.hour = (tui8)stime.tm_hour; temp->item->connect_time.minute = (tui8)stime.tm_min; zero_time(&(temp->item->disconnect_time)); zero_time(&(temp->item->idle_time)); temp->item->type = type; temp->item->status = SESMAN_SESSION_STATUS_ACTIVE; temp->next = g_sessions; g_sessions = temp; g_session_count++; return display; } g_free(temp->item); g_free(temp); return display; } /******************************************************************************/ /* called with the main thread */ static int session_reconnect_fork(int display, char *username) { int pid; char text[256]; pid = g_fork(); if (pid == -1) { } else if (pid == 0) { env_set_user(username, 0, display, g_cfg->session_variables1, g_cfg->session_variables2); g_snprintf(text, 255, "%s/%s", XRDP_CFG_PATH, "reconnectwm.sh"); if (g_file_exist(text)) { g_execlp3(text, g_cfg->default_wm, 0); } g_exit(0); } return display; } /******************************************************************************/ /* called by a worker thread, ask the main thread to call session_sync_start and wait till done */ int session_start(long data, tui8 type, struct SCP_CONNECTION *c, struct SCP_SESSION *s) { return session_start_fork(data, type, c, s); } /******************************************************************************/ /* called by a worker thread, ask the main thread to call session_sync_start and wait till done */ int session_reconnect(int display, char *username) { return session_reconnect_fork(display, username); } /******************************************************************************/ int session_kill(int pid) { struct session_chain *tmp; struct session_chain *prev; tmp = g_sessions; prev = 0; while (tmp != 0) { if (tmp->item == 0) { log_message(LOG_LEVEL_ERROR, "session descriptor for " "pid %d is null!", pid); if (prev == 0) { /* prev does no exist, so it's the first element - so we set g_sessions */ g_sessions = tmp->next; } else { prev->next = tmp->next; } return SESMAN_SESSION_KILL_NULLITEM; } if (tmp->item->pid == pid) { /* deleting the session */ log_message(LOG_LEVEL_INFO, "++ terminated session: username %s, display :%d.0, session_pid %d, ip %s", tmp->item->name, tmp->item->display, tmp->item->pid, tmp->item->client_ip); g_free(tmp->item); if (prev == 0) { /* prev does no exist, so it's the first element - so we set g_sessions */ g_sessions = tmp->next; } else { prev->next = tmp->next; } g_free(tmp); g_session_count--; return SESMAN_SESSION_KILL_OK; } /* go on */ prev = tmp; tmp = tmp->next; } return SESMAN_SESSION_KILL_NOTFOUND; } /******************************************************************************/ void session_sigkill_all(void) { struct session_chain *tmp; tmp = g_sessions; while (tmp != 0) { if (tmp->item == 0) { log_message(LOG_LEVEL_ERROR, "found null session " "descriptor!"); } else { g_sigterm(tmp->item->pid); } /* go on */ tmp = tmp->next; } } /******************************************************************************/ struct session_item * session_get_bypid(int pid) { struct session_chain *tmp; struct session_item *dummy; dummy = g_new0(struct session_item, 1); if (0 == dummy) { log_message(LOG_LEVEL_ERROR, "session_get_bypid: out of memory"); return 0; } tmp = g_sessions; while (tmp != 0) { if (tmp->item == 0) { log_message(LOG_LEVEL_ERROR, "session descriptor for " "pid %d is null!", pid); g_free(dummy); return 0; } if (tmp->item->pid == pid) { g_memcpy(dummy, tmp->item, sizeof(struct session_item)); return dummy; } /* go on */ tmp = tmp->next; } g_free(dummy); return 0; } /******************************************************************************/ struct SCP_DISCONNECTED_SESSION * session_get_byuser(const char *user, int *cnt, unsigned char flags) { struct session_chain *tmp; struct SCP_DISCONNECTED_SESSION *sess; int count; int index; count = 0; tmp = g_sessions; while (tmp != 0) { LOG_DBG("user: %s", user); if ((NULL == user) || (!g_strncasecmp(user, tmp->item->name, 256))) { LOG_DBG("session_get_byuser: status=%d, flags=%d, " "result=%d", (tmp->item->status), flags, ((tmp->item->status) & flags)); if ((tmp->item->status) & flags) { count++; } } /* go on */ tmp = tmp->next; } if (count == 0) { (*cnt) = 0; return 0; } /* malloc() an array of disconnected sessions */ sess = g_new0(struct SCP_DISCONNECTED_SESSION, count); if (sess == 0) { (*cnt) = 0; return 0; } tmp = g_sessions; index = 0; while (tmp != 0) { /* #warning FIXME: we should get only disconnected sessions! */ if ((NULL == user) || (!g_strncasecmp(user, tmp->item->name, 256))) { if ((tmp->item->status) & flags) { (sess[index]).SID = tmp->item->pid; (sess[index]).type = tmp->item->type; (sess[index]).height = tmp->item->height; (sess[index]).width = tmp->item->width; (sess[index]).bpp = tmp->item->bpp; /* #warning FIXME: setting idle times and such */ /*(sess[index]).connect_time.year = tmp->item->connect_time.year; (sess[index]).connect_time.month = tmp->item->connect_time.month; (sess[index]).connect_time.day = tmp->item->connect_time.day; (sess[index]).connect_time.hour = tmp->item->connect_time.hour; (sess[index]).connect_time.minute = tmp->item->connect_time.minute; (sess[index]).disconnect_time.year = tmp->item->disconnect_time.year; (sess[index]).disconnect_time.month = tmp->item->disconnect_time.month; (sess[index]).disconnect_time.day = tmp->item->disconnect_time.day; (sess[index]).disconnect_time.hour = tmp->item->disconnect_time.hour; (sess[index]).disconnect_time.minute = tmp->item->disconnect_time.minute; (sess[index]).idle_time.year = tmp->item->idle_time.year; (sess[index]).idle_time.month = tmp->item->idle_time.month; (sess[index]).idle_time.day = tmp->item->idle_time.day; (sess[index]).idle_time.hour = tmp->item->idle_time.hour; (sess[index]).idle_time.minute = tmp->item->idle_time.minute;*/ (sess[index]).conn_year = tmp->item->connect_time.year; (sess[index]).conn_month = tmp->item->connect_time.month; (sess[index]).conn_day = tmp->item->connect_time.day; (sess[index]).conn_hour = tmp->item->connect_time.hour; (sess[index]).conn_minute = tmp->item->connect_time.minute; (sess[index]).idle_days = tmp->item->idle_time.day; (sess[index]).idle_hours = tmp->item->idle_time.hour; (sess[index]).idle_minutes = tmp->item->idle_time.minute; index++; } } /* go on */ tmp = tmp->next; } (*cnt) = count; return sess; } /******************************************************************************/ int cleanup_sockets(int display) { log_message(LOG_LEVEL_DEBUG, "cleanup_sockets:"); char file[256]; int error; error = 0; g_snprintf(file, 255, CHANSRV_PORT_OUT_STR, display); if (g_file_exist(file)) { log_message(LOG_LEVEL_DEBUG, "cleanup_sockets: deleting %s", file); if (g_file_delete(file) == 0) { log_message(LOG_LEVEL_DEBUG, "cleanup_sockets: failed to delete %s", file); error++; } } g_snprintf(file, 255, CHANSRV_PORT_IN_STR, display); if (g_file_exist(file)) { log_message(LOG_LEVEL_DEBUG, "cleanup_sockets: deleting %s", file); if (g_file_delete(file) == 0) { log_message(LOG_LEVEL_DEBUG, "cleanup_sockets: failed to delete %s", file); error++; } } g_snprintf(file, 255, XRDP_CHANSRV_STR, display); if (g_file_exist(file)) { log_message(LOG_LEVEL_DEBUG, "cleanup_sockets: deleting %s", file); if (g_file_delete(file) == 0) { log_message(LOG_LEVEL_DEBUG, "cleanup_sockets: failed to delete %s", file); error++; } } g_snprintf(file, 255, CHANSRV_API_STR, display); if (g_file_exist(file)) { log_message(LOG_LEVEL_DEBUG, "cleanup_sockets: deleting %s", file); if (g_file_delete(file) == 0) { log_message(LOG_LEVEL_DEBUG, "cleanup_sockets: failed to delete %s", file); error++; } } return error; } xrdp-0.9.5/sesman/sesman.ini000644 001751 001751 00000004747 13220727201 015707 0ustar00metameta000000 000000 [Globals] ListenAddress=127.0.0.1 ListenPort=3350 EnableUserWindowManager=true UserWindowManager=startwm.sh DefaultWindowManager=startwm.sh [Security] AllowRootLogin=true MaxLoginRetry=4 TerminalServerUsers=tsusers TerminalServerAdmins=tsadmins ; When AlwaysGroupCheck=false access will be permitted ; if the group TerminalServerUsers is not defined. AlwaysGroupCheck=false [Sessions] ;; X11DisplayOffset - x11 display number offset ; Type: integer ; Default: 10 X11DisplayOffset=10 ;; MaxSessions - maximum number of connections to an xrdp server ; Type: integer ; Default: 0 MaxSessions=50 ;; KillDisconnected - kill disconnected sessions ; Type: boolean ; Default: false ; if 1, true, or yes, kill session after 60 seconds KillDisconnected=false ;; DisconnectedTimeLimit - when to kill idle sessions ; Type: integer ; Default: 0 ; if not zero, the seconds before a disconnected session is killed ; min 60 seconds DisconnectedTimeLimit=0 ;; Policy - session allocation policy ; Type: enum [ "Default" | "UBD" | "UBI" | "UBC" | "UBDI" | "UBDC" ] ; Default: Xrdp: and Xvnc: ; "UBD" session per ; "UBI" session per ; "UBC" session per ; "UBDI" session per ; "UBDC" session per Policy=Default [Logging] LogFile=xrdp-sesman.log LogLevel=DEBUG EnableSyslog=1 SyslogLevel=DEBUG ; ; Session definitions - startup command-line parameters for each session type ; [Xorg] ; Specify the path of non-suid Xorg executable. It might differ depending ; on your distribution and version. The typical path is shown as follows: ; ; Fedora 26 or later : param=/usr/libexec/Xorg ; Debian 9 or later : param=/usr/lib/xorg/Xorg ; Ubuntu 16.04 or later : param=/usr/lib/xorg/Xorg ; Arch Linux : param=/usr/bin/Xorg or param=Xorg ; CentOS 7 : param=/usr/bin/Xorg or param=Xorg ; param=Xorg ; Leave the rest paramaters as-is unless you understand what will happen. param=-config param=xrdp/xorg.conf param=-noreset param=-nolisten param=tcp param=-logfile param=.xorgxrdp.%s.log [X11rdp] param=X11rdp param=-bs param=-nolisten param=tcp param=-uds [Xvnc] param=Xvnc param=-bs param=-nolisten param=tcp param=-localhost param=-dpi param=96 [Chansrv] ; drive redirection, defaults to xrdp_client if not set FuseMountName=thinclient_drives [SessionVariables] PULSE_SCRIPT=/etc/xrdp/pulse/default.pa xrdp-0.9.5/sesman/scp_v1.h000644 001751 001751 00000001767 13174271344 015275 0ustar00metameta000000 000000 /** * xrdp: A Remote Desktop Protocol server. * * Copyright (C) Jay Sorg 2004-2013 * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ /** * * @file scp_v1.h * @brief scp version 1 declarations * @author Simone Fedele * */ #ifndef SCP_V1_H #define SCP_V1_H /** * * @brief processes the stream using scp version 1 * @param in_sck connection socket * @param in_s input stream * @param out_s output stream * */ void scp_v1_process(struct SCP_CONNECTION* c, struct SCP_SESSION* s); #endif xrdp-0.9.5/sesman/config.c000644 001751 001751 00000035043 13215625636 015337 0ustar00metameta000000 000000 /** * xrdp: A Remote Desktop Protocol server. * * Copyright (C) Jay Sorg 2004-2013 * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ /** * * @file config.c * @brief User authentication code * @author Simone Fedele @< simo [at] esseemme [dot] org @> * */ #if defined(HAVE_CONFIG_H) #include #endif #include "arch.h" #include "list.h" #include "file.h" #include "sesman.h" #include "log.h" extern struct config_sesman *g_cfg; /* in sesman.c */ /******************************************************************************/ int config_read(struct config_sesman *cfg) { int fd; struct list *sec; struct list *param_n; struct list *param_v; char cfg_file[256]; g_snprintf(cfg_file, 255, "%s/sesman.ini", XRDP_CFG_PATH); fd = g_file_open(cfg_file); if (-1 == fd) { //if (g_cfg->log.fd >= 0) //{ /* logging is already active */ log_message(LOG_LEVEL_ALWAYS, "error opening %s in \ config_read", cfg_file); //} //else //{ g_printf("error opening %s in config_read", cfg_file); //} return 1; } g_memset(cfg, 0, sizeof(struct config_sesman)); sec = list_create(); sec->auto_free = 1; file_read_sections(fd, sec); param_n = list_create(); param_n->auto_free = 1; param_v = list_create(); param_v->auto_free = 1; /* read global config */ config_read_globals(fd, cfg, param_n, param_v); /* read Xvnc/X11rdp/XOrg parameter list */ config_read_vnc_params(fd, cfg, param_n, param_v); config_read_rdp_params(fd, cfg, param_n, param_v); config_read_xorg_params(fd, cfg, param_n, param_v); /* read logging config */ // config_read_logging(fd, &(cfg->log), param_n, param_v); /* read security config */ config_read_security(fd, &(cfg->sec), param_n, param_v); /* read session config */ config_read_sessions(fd, &(cfg->sess), param_n, param_v); config_read_session_variables(fd, cfg, param_n, param_v); /* cleanup */ list_delete(sec); list_delete(param_v); list_delete(param_n); g_file_close(fd); return 0; } /******************************************************************************/ int config_read_globals(int file, struct config_sesman *cf, struct list *param_n, struct list *param_v) { int i; char *buf; list_clear(param_v); list_clear(param_n); /* resetting the struct */ cf->listen_address[0] = '\0'; cf->listen_port[0] = '\0'; cf->enable_user_wm = 0; cf->user_wm[0] = '\0'; cf->default_wm[0] = '\0'; cf->auth_file_path = 0; file_read_section(file, SESMAN_CFG_GLOBALS, param_n, param_v); for (i = 0; i < param_n->count; i++) { buf = (char *)list_get_item(param_n, i); if (0 == g_strcasecmp(buf, SESMAN_CFG_DEFWM)) { g_strncpy(cf->default_wm, (char *)list_get_item(param_v, i), 31); } else if (0 == g_strcasecmp(buf, SESMAN_CFG_USERWM)) { g_strncpy(cf->user_wm, (char *)list_get_item(param_v, i), 31); } else if (0 == g_strcasecmp(buf, SESMAN_CFG_ENABLE_USERWM)) { cf->enable_user_wm = g_text2bool((char *)list_get_item(param_v, i)); } else if (0 == g_strcasecmp(buf, SESMAN_CFG_PORT)) { g_strncpy(cf->listen_port, (char *)list_get_item(param_v, i), 15); } else if (0 == g_strcasecmp(buf, SESMAN_CFG_ADDRESS)) { g_strncpy(cf->listen_address, (char *)list_get_item(param_v, i), 31); } else if (0 == g_strcasecmp(buf, SESMAN_CFG_AUTH_FILE_PATH)) { cf->auth_file_path = g_strdup((char *)list_get_item(param_v, i)); } } /* checking for missing required parameters */ if ('\0' == cf->listen_address[0]) { g_strncpy(cf->listen_address, "0.0.0.0", 8); } if ('\0' == cf->listen_port[0]) { g_strncpy(cf->listen_port, "3350", 5); } if ('\0' == cf->user_wm[0]) { cf->enable_user_wm = 0; } if ('\0' == cf->default_wm[0]) { g_strncpy(cf->default_wm, "startwm.sh", 11); } /* showing read config */ g_printf("sesman config:\r\n"); g_printf("\tListenAddress: %s\r\n", cf->listen_address); g_printf("\tListenPort: %s\r\n", cf->listen_port); g_printf("\tEnableUserWindowManager: %i\r\n", cf->enable_user_wm); g_printf("\tUserWindowManager: %s\r\n", cf->user_wm); g_printf("\tDefaultWindowManager: %s\r\n", cf->default_wm); g_printf("\tAuthFilePath: %s\r\n", ((cf->auth_file_path) ? (cf->auth_file_path) : ("disabled"))); return 0; } /******************************************************************************/ int config_read_security(int file, struct config_security *sc, struct list *param_n, struct list *param_v) { int i; int gid; char *buf; list_clear(param_v); list_clear(param_n); /* setting defaults */ sc->allow_root = 0; sc->login_retry = 3; sc->ts_users_enable = 0; sc->ts_admins_enable = 0; file_read_section(file, SESMAN_CFG_SECURITY, param_n, param_v); for (i = 0; i < param_n->count; i++) { buf = (char *)list_get_item(param_n, i); if (0 == g_strcasecmp(buf, SESMAN_CFG_SEC_ALLOW_ROOT)) { sc->allow_root = g_text2bool((char *)list_get_item(param_v, i)); } if (0 == g_strcasecmp(buf, SESMAN_CFG_SEC_LOGIN_RETRY)) { sc->login_retry = g_atoi((char *)list_get_item(param_v, i)); } if (0 == g_strcasecmp(buf, SESMAN_CFG_SEC_USR_GROUP)) { if (g_getgroup_info((char *)list_get_item(param_v, i), &gid) == 0) { sc->ts_users_enable = 1; sc->ts_users = gid; } } if (0 == g_strcasecmp(buf, SESMAN_CFG_SEC_ADM_GROUP)) { if (g_getgroup_info((char *)list_get_item(param_v, i), &gid) == 0) { sc->ts_admins_enable = 1; sc->ts_admins = gid; } } if (0 == g_strcasecmp(buf, SESMAN_CFG_SEC_ALWAYSGROUPCHECK)) { sc->ts_always_group_check = g_text2bool((char *)list_get_item(param_v, i)); } } /* printing security config */ g_printf("security configuration:\r\n"); g_printf("\tAllowRootLogin: %i\r\n", sc->allow_root); g_printf("\tMaxLoginRetry: %i\r\n", sc->login_retry); g_printf("\tAlwaysGroupCheck: %i\r\n", sc->ts_always_group_check); if (sc->ts_users_enable) { g_printf("\tTSUsersGroup: %i\r\n", sc->ts_users); } else { g_printf("\tNo TSUsersGroup defined\r\n"); } if (sc->ts_admins_enable) { g_printf("\tTSAdminsGroup: %i\r\n", sc->ts_admins); } else { g_printf("\tNo TSAdminsGroup defined\r\n"); } return 0; } /******************************************************************************/ int config_read_sessions(int file, struct config_sessions *se, struct list *param_n, struct list *param_v) { int i; char *buf; list_clear(param_v); list_clear(param_n); /* setting defaults */ se->x11_display_offset = 10; se->max_sessions = 0; se->max_idle_time = 0; se->max_disc_time = 0; se->kill_disconnected = 0; se->policy = SESMAN_CFG_SESS_POLICY_DFLT; file_read_section(file, SESMAN_CFG_SESSIONS, param_n, param_v); for (i = 0; i < param_n->count; i++) { buf = (char *)list_get_item(param_n, i); if (0 == g_strcasecmp(buf, SESMAN_CFG_SESS_X11DISPLAYOFFSET)) { se->x11_display_offset = g_atoi((char *)list_get_item(param_v, i)); } if (0 == g_strcasecmp(buf, SESMAN_CFG_SESS_MAX)) { se->max_sessions = g_atoi((char *)list_get_item(param_v, i)); } if (0 == g_strcasecmp(buf, SESMAN_CFG_SESS_KILL_DISC)) { se->kill_disconnected = g_text2bool((char *)list_get_item(param_v, i)); } if (0 == g_strcasecmp(buf, SESMAN_CFG_SESS_IDLE_LIMIT)) { se->max_idle_time = g_atoi((char *)list_get_item(param_v, i)); } if (0 == g_strcasecmp(buf, SESMAN_CFG_SESS_DISC_LIMIT)) { se->max_disc_time = g_atoi((char *)list_get_item(param_v, i)); } if (0 == g_strcasecmp(buf, SESMAN_CFG_SESS_POLICY_S)) { char *value = (char *)list_get_item(param_v, i); if (0 == g_strcasecmp(value, SESMAN_CFG_SESS_POLICY_DFLT_S)) { se->policy = SESMAN_CFG_SESS_POLICY_DFLT; } else if (0 == g_strcasecmp(value, SESMAN_CFG_SESS_POLICY_UBD_S)) { se->policy = SESMAN_CFG_SESS_POLICY_UBD; } else if (0 == g_strcasecmp(value, SESMAN_CFG_SESS_POLICY_UBI_S)) { se->policy = SESMAN_CFG_SESS_POLICY_UBI; } else if (0 == g_strcasecmp(value, SESMAN_CFG_SESS_POLICY_UBC_S)) { se->policy = SESMAN_CFG_SESS_POLICY_UBC; } else if (0 == g_strcasecmp(value, SESMAN_CFG_SESS_POLICY_UBDI_S)) { se->policy = SESMAN_CFG_SESS_POLICY_UBDI; } else if (0 == g_strcasecmp(value, SESMAN_CFG_SESS_POLICY_UBDC_S)) { se->policy = SESMAN_CFG_SESS_POLICY_UBDC; } else /* silently ignore typos */ { se->policy = SESMAN_CFG_SESS_POLICY_DFLT; } } } /* printing session config */ g_printf("session configuration:\r\n"); g_printf("\tMaxSessions: %i\r\n", se->max_sessions); g_printf("\tX11DisplayOffset: %i\r\n", se->x11_display_offset); g_printf("\tKillDisconnected: %i\r\n", se->kill_disconnected); g_printf("\tIdleTimeLimit: %i\r\n", se->max_idle_time); g_printf("\tDisconnectedTimeLimit: %i\r\n", se->max_disc_time); g_printf("\tPolicy: %i\r\n", se->policy); return 0; } /******************************************************************************/ int config_read_rdp_params(int file, struct config_sesman *cs, struct list *param_n, struct list *param_v) { int i; list_clear(param_v); list_clear(param_n); cs->rdp_params = list_create(); cs->rdp_params->auto_free = 1; file_read_section(file, SESMAN_CFG_RDP_PARAMS, param_n, param_v); for (i = 0; i < param_n->count; i++) { list_add_item(cs->rdp_params, (long)g_strdup((char *)list_get_item(param_v, i))); } /* printing X11rdp parameters */ g_printf("X11rdp parameters:\r\n"); for (i = 0; i < cs->rdp_params->count; i++) { g_printf("\tParameter %02d %s\r\n", i, (char *)list_get_item(cs->rdp_params, i)); } return 0; } /******************************************************************************/ int config_read_xorg_params(int file, struct config_sesman *cs, struct list *param_n, struct list *param_v) { int i; list_clear(param_v); list_clear(param_n); cs->xorg_params = list_create(); cs->xorg_params->auto_free = 1; file_read_section(file, SESMAN_CFG_XORG_PARAMS, param_n, param_v); for (i = 0; i < param_n->count; i++) { list_add_item(cs->xorg_params, (long) g_strdup((char *) list_get_item(param_v, i))); } /* printing XOrg parameters */ g_printf("XOrg parameters:\r\n"); for (i = 0; i < cs->xorg_params->count; i++) { g_printf("\tParameter %02d %s\r\n", i, (char *) list_get_item(cs->xorg_params, i)); } return 0; } /******************************************************************************/ int config_read_vnc_params(int file, struct config_sesman *cs, struct list *param_n, struct list *param_v) { int i; list_clear(param_v); list_clear(param_n); cs->vnc_params = list_create(); cs->vnc_params->auto_free = 1; file_read_section(file, SESMAN_CFG_VNC_PARAMS, param_n, param_v); for (i = 0; i < param_n->count; i++) { list_add_item(cs->vnc_params, (long)g_strdup((char *)list_get_item(param_v, i))); } /* printing Xvnc parameters */ g_printf("Xvnc parameters:\r\n"); for (i = 0; i < cs->vnc_params->count; i++) { g_printf("\tParameter %02d %s\r\n", i, (char *)list_get_item(cs->vnc_params, i)); } return 0; } /******************************************************************************/ int config_read_session_variables(int file, struct config_sesman *cs, struct list *param_n, struct list *param_v) { int i; list_clear(param_v); list_clear(param_n); cs->session_variables1 = list_create(); cs->session_variables1->auto_free = 1; cs->session_variables2 = list_create(); cs->session_variables2->auto_free = 1; file_read_section(file, SESMAN_CFG_SESSION_VARIABLES, param_n, param_v); for (i = 0; i < param_n->count; i++) { list_add_item(cs->session_variables1, (tintptr) g_strdup((char *) list_get_item(param_n, i))); list_add_item(cs->session_variables2, (tintptr) g_strdup((char *) list_get_item(param_v, i))); } /* printing session variables */ g_writeln("%s parameters:", SESMAN_CFG_SESSION_VARIABLES); for (i = 0; i < cs->session_variables1->count; i++) { g_writeln(" Parameter %02d %s=%s", i, (char *) list_get_item(cs->session_variables1, i), (char *) list_get_item(cs->session_variables2, i)); } return 0; } void config_free(struct config_sesman *cs) { list_delete(cs->rdp_params); list_delete(cs->vnc_params); list_delete(cs->xorg_params); list_delete(cs->session_variables1); list_delete(cs->session_variables2); g_free(cs); } xrdp-0.9.5/sesman/env.c000644 001751 001751 00000015657 13206023530 014654 0ustar00metameta000000 000000 /** * xrdp: A Remote Desktop Protocol server. * * Copyright (C) Jay Sorg 2004-2013 * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ /** * * @file env.c * @brief User environment handling code * @author Jay Sorg * */ #if defined(HAVE_CONFIG_H) #include #endif #include #include "list.h" #include "sesman.h" #include "ssl_calls.h" extern unsigned char g_fixedkey[8]; /* in sesman.c */ extern struct config_sesman *g_cfg; /* in sesman.c */ /******************************************************************************/ int env_check_password_file(const char *filename, const char *passwd) { char encryptedPasswd[16]; char key[24]; char passwd_hash[20]; char passwd_hash_text[40]; int fd; int passwd_bytes; void *des; void *sha1; /* create password hash from password */ passwd_bytes = g_strlen(passwd); sha1 = ssl_sha1_info_create(); ssl_sha1_transform(sha1, "xrdp_vnc", 8); ssl_sha1_transform(sha1, passwd, passwd_bytes); ssl_sha1_transform(sha1, passwd, passwd_bytes); ssl_sha1_complete(sha1, passwd_hash); ssl_sha1_info_delete(sha1); g_snprintf(passwd_hash_text, 39, "%2.2x%2.2x%2.2x%2.2x", (tui8)passwd_hash[0], (tui8)passwd_hash[1], (tui8)passwd_hash[2], (tui8)passwd_hash[3]); passwd_hash_text[39] = 0; passwd = passwd_hash_text; /* create file from password */ g_memset(encryptedPasswd, 0, sizeof(encryptedPasswd)); g_strncpy(encryptedPasswd, passwd, 8); g_memset(key, 0, sizeof(key)); g_mirror_memcpy(key, g_fixedkey, 8); des = ssl_des3_encrypt_info_create(key, 0); ssl_des3_encrypt(des, 8, encryptedPasswd, encryptedPasswd); ssl_des3_info_delete(des); fd = g_file_open_ex(filename, 0, 1, 1, 1); if (fd == -1) { log_message(LOG_LEVEL_WARNING, "Cannot write VNC password hash to file %s: %s", filename, g_get_strerror()); return 1; } g_file_write(fd, encryptedPasswd, 8); g_file_close(fd); return 0; } /******************************************************************************/ /* its the responsibility of the caller to free passwd_file */ int env_set_user(const char *username, char **passwd_file, int display, const struct list *env_names, const struct list *env_values) { int error; int pw_uid; int pw_gid; int uid; int index; int len; char *name; char *value; char *pw_shell; char *pw_dir; char text[256]; pw_shell = 0; pw_dir = 0; error = g_getuser_info(username, &pw_gid, &pw_uid, &pw_shell, &pw_dir, 0); if (error == 0) { g_rm_temp_dir(); error = g_setgid(pw_gid); if (error == 0) { error = g_initgroups(username, pw_gid); } if (error == 0) { uid = pw_uid; error = g_setuid(uid); } g_mk_socket_path(0); if (error == 0) { g_clearenv(); g_setenv("SHELL", pw_shell, 1); g_setenv("PATH", "/sbin:/bin:/usr/bin:/usr/local/bin", 1); g_setenv("USER", username, 1); g_setenv("LOGNAME", username, 1); g_sprintf(text, "%d", uid); g_setenv("UID", text, 1); g_setenv("HOME", pw_dir, 1); g_set_current_dir(pw_dir); g_sprintf(text, ":%d.0", display); g_setenv("DISPLAY", text, 1); g_setenv("XRDP_SESSION", "1", 1); /* XRDP_SOCKET_PATH should be set even here, chansrv uses this */ g_setenv("XRDP_SOCKET_PATH", XRDP_SOCKET_PATH, 1); if ((env_names != 0) && (env_values != 0) && (env_names->count == env_values->count)) { for (index = 0; index < env_names->count; index++) { name = (char *) list_get_item(env_names, index), value = (char *) list_get_item(env_values, index), g_setenv(name, value, 1); } } if (passwd_file != 0) { if (0 == g_cfg->auth_file_path) { /* if no auth_file_path is set, then we go for $HOME/.vnc/sesman_username_passwd:DISPLAY */ if (!g_directory_exist(".vnc")) { if (g_mkdir(".vnc") < 0) { log_message(LOG_LEVEL_ERROR, "Error creating .vnc directory: %s", g_get_strerror()); } } len = g_snprintf(NULL, 0, "%s/.vnc/sesman_%s_passwd:%d", pw_dir, username, display); *passwd_file = (char *) g_malloc(len + 1, 1); if (*passwd_file != NULL) { /* Try legacy name first, remove if found */ g_sprintf(*passwd_file, "%s/.vnc/sesman_%s_passwd", pw_dir, username); if (g_file_exist(*passwd_file)) { log_message(LOG_LEVEL_WARNING, "Removing insecure " "password file %s", *passwd_file); g_file_delete(*passwd_file); } g_sprintf(*passwd_file, "%s/.vnc/sesman_%s_passwd:%d", pw_dir, username, display); } } else { /* we use auth_file_path as requested */ len = g_snprintf(NULL, 0, g_cfg->auth_file_path, username); *passwd_file = (char *) g_malloc(len + 1, 1); if (*passwd_file != NULL) { g_sprintf(*passwd_file, g_cfg->auth_file_path, username); } } if (*passwd_file != NULL) { LOG_DBG("pass file: %s", *passwd_file); } } g_free(pw_dir); g_free(pw_shell); } } else { log_message(LOG_LEVEL_ERROR, "error getting user info for user %s", username); } return error; } xrdp-0.9.5/sesman/auth.h000644 001751 001751 00000003733 13174271344 015036 0ustar00metameta000000 000000 /** * xrdp: A Remote Desktop Protocol server. * * Copyright (C) Jay Sorg 2004-2012 * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ /** * * @file auth.h * @brief User authentication definitions * @author Jay Sorg * */ #ifndef AUTH_H #define AUTH_H /** * * @brief Validates user's password * @param user user's login name * @param pass user's password * @return non-zero handle on success, 0 on failure * */ long auth_userpass(const char *user, const char *pass, int *errorcode); /** * * @brief FIXME * @param in_val * @param in_display * @return 0 on success, 1 on failure * */ int auth_start_session(long in_val, int in_display); /** * * @brief FIXME * @param in_val * @return 0 on success, 1 on failure * */ int auth_stop_session(long in_val); /** * * @brief FIXME * @param in_val * @return 0 on success, 1 on failure * */ int auth_end(long in_val); /** * * @brief FIXME * @param in_val * @return 0 on success, 1 on failure * */ int auth_set_env(long in_val); #define AUTH_PWD_CHG_OK 0 #define AUTH_PWD_CHG_CHANGE 1 #define AUTH_PWD_CHG_CHANGE_MANDATORY 2 #define AUTH_PWD_CHG_NOT_NOW 3 #define AUTH_PWD_CHG_ERROR 4 /** * * @brief FIXME * @param in_val * @return 0 on success, 1 on failure * */ int auth_check_pwd_chg(const char *user); /** * * @brief FIXME * @param in_val * @return 0 on success, 1 on failure * */ int auth_change_pwd(const char *user, const char *newpwd); #endif xrdp-0.9.5/sesman/sesman.c000644 001751 001751 00000027274 13206023530 015350 0ustar00metameta000000 000000 /** * xrdp: A Remote Desktop Protocol server. * * Copyright (C) Jay Sorg 2004-2015 * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ /** * * @file sesman.c * @brief Main program file * @author Jay Sorg * */ #if defined(HAVE_CONFIG_H) #include #endif #include "sesman.h" int g_sck; int g_pid; unsigned char g_fixedkey[8] = { 23, 82, 107, 6, 35, 78, 88, 7 }; struct config_sesman *g_cfg; /* defined in config.h */ tintptr g_term_event = 0; /******************************************************************************/ int sesman_listen_test(struct config_sesman *cfg) { int error; int sck; int rv = 0; sck = g_tcp_socket(); if (sck < 0) { return 1; } log_message(LOG_LEVEL_DEBUG, "Testing if xrdp-sesman can listen on %s port %s.", cfg->listen_address, cfg->listen_port); g_tcp_set_non_blocking(sck); error = scp_tcp_bind(sck, cfg->listen_address, cfg->listen_port); if (error == 0) { /* try to listen */ error = g_tcp_listen(sck); if (error == 0) { /* if listen succeeded, stop listen immediately */ g_sck_close(sck); } else { rv = 1; } } else { rv = 1; } return rv; } /******************************************************************************/ /** * * @brief Starts sesman main loop * */ int sesman_main_loop(void) { int in_sck; int error; int robjs_count; int cont; int rv = 0; tbus sck_obj; tbus robjs[8]; g_sck = g_tcp_socket(); if (g_sck < 0) { log_message(LOG_LEVEL_ERROR, "error opening socket, g_tcp_socket() failed..."); return 1; } g_tcp_set_non_blocking(g_sck); error = scp_tcp_bind(g_sck, g_cfg->listen_address, g_cfg->listen_port); if (error == 0) { error = g_tcp_listen(g_sck); if (error == 0) { log_message(LOG_LEVEL_INFO, "listening to port %s on %s", g_cfg->listen_port, g_cfg->listen_address); sck_obj = g_create_wait_obj_from_socket(g_sck, 0); cont = 1; while (cont) { /* build the wait obj list */ robjs_count = 0; robjs[robjs_count++] = sck_obj; robjs[robjs_count++] = g_term_event; /* wait */ if (g_obj_wait(robjs, robjs_count, 0, 0, -1) != 0) { /* error, should not get here */ g_sleep(100); } if (g_is_wait_obj_set(g_term_event)) /* term */ { break; } if (g_is_wait_obj_set(sck_obj)) /* incoming connection */ { in_sck = g_tcp_accept(g_sck); if ((in_sck == -1) && g_tcp_last_error_would_block(g_sck)) { /* should not get here */ g_sleep(100); } else if (in_sck == -1) { /* error, should not get here */ break; } else { /* we've got a connection, so we pass it to scp code */ LOG_DBG("new connection"); scp_process_start((void*)(tintptr)in_sck); g_sck_close(in_sck); } } } g_delete_wait_obj_from_socket(sck_obj); } else { log_message(LOG_LEVEL_ERROR, "listen error %d (%s)", g_get_errno(), g_get_strerror()); rv = 1; } } else { log_message(LOG_LEVEL_ERROR, "bind error on " "port '%s': %d (%s)", g_cfg->listen_port, g_get_errno(), g_get_strerror()); rv = 1; } g_tcp_close(g_sck); return rv; } /******************************************************************************/ void print_usage(int retcode) { g_printf("xrdp-sesman - xrdp session manager\n\n"); g_printf("Usage: xrdp-sesman [options]\n"); g_printf(" -n, --nodaemon run as foreground process\n"); g_printf(" -k, --kill kill running xrdp-sesman\n"); g_printf(" -h, --help show this help\n"); g_deinit(); g_exit(retcode); } /******************************************************************************/ int main(int argc, char **argv) { int fd; enum logReturns log_error; int error; int daemon = 1; int pid; char pid_s[32]; char text[256]; char pid_file[256]; char cfg_file[256]; g_init("xrdp-sesman"); g_snprintf(pid_file, 255, "%s/xrdp-sesman.pid", XRDP_PID_PATH); if (1 == argc) { /* no options on command line. normal startup */ g_printf("starting sesman...\n"); daemon = 1; } else if ((2 == argc) && ((0 == g_strcasecmp(argv[1], "--nodaemon")) || (0 == g_strcasecmp(argv[1], "-nodaemon")) || (0 == g_strcasecmp(argv[1], "-n")) || (0 == g_strcasecmp(argv[1], "-ns")))) { /* starts sesman not daemonized */ g_printf("starting sesman in foreground...\n"); daemon = 0; } else if ((2 == argc) && ((0 == g_strcasecmp(argv[1], "--help")) || (0 == g_strcasecmp(argv[1], "-help")) || (0 == g_strcasecmp(argv[1], "-h")))) { print_usage(0); } else if ((2 == argc) && ((0 == g_strcasecmp(argv[1], "--kill")) || (0 == g_strcasecmp(argv[1], "-kill")) || (0 == g_strcasecmp(argv[1], "-k")))) { /* killing running sesman */ /* check if sesman is running */ if (!g_file_exist(pid_file)) { g_printf("sesman is not running (pid file not found - %s)\n", pid_file); g_deinit(); g_exit(1); } fd = g_file_open(pid_file); if (-1 == fd) { g_printf("error opening pid file[%s]: %s\n", pid_file, g_get_strerror()); return 1; } g_memset(pid_s, 0, sizeof(pid_s)); error = g_file_read(fd, pid_s, 31); if (-1 == error) { g_printf("error reading pid file: %s\n", g_get_strerror()); g_file_close(fd); g_deinit(); g_exit(error); } g_file_close(fd); pid = g_atoi(pid_s); error = g_sigterm(pid); if (0 != error) { g_printf("error killing sesman: %s\n", g_get_strerror()); } else { g_file_delete(pid_file); } g_deinit(); g_exit(error); } else { /* there's something strange on the command line */ g_printf("Error: invalid command line arguments\n\n"); print_usage(1); } if (g_file_exist(pid_file)) { g_printf("xrdp-sesman is already running.\n"); g_printf("if it's not running, try removing "); g_printf("%s", pid_file); g_printf("\n"); g_deinit(); g_exit(1); } /* reading config */ g_cfg = g_new0(struct config_sesman, 1); if (0 == g_cfg) { g_printf("error creating config: quitting.\n"); g_deinit(); g_exit(1); } //g_cfg->log.fd = -1; /* don't use logging before reading its config */ if (0 != config_read(g_cfg)) { g_printf("error reading config: %s\nquitting.\n", g_get_strerror()); g_deinit(); g_exit(1); } g_snprintf(cfg_file, 255, "%s/sesman.ini", XRDP_CFG_PATH); /* starting logging subsystem */ log_error = log_start(cfg_file, "xrdp-sesman"); if (log_error != LOG_STARTUP_OK) { switch (log_error) { case LOG_ERROR_MALLOC: g_writeln("error on malloc. cannot start logging. quitting."); break; case LOG_ERROR_FILE_OPEN: g_writeln("error opening log file [%s]. quitting.", getLogFile(text, 255)); break; default: g_writeln("error"); break; } g_deinit(); g_exit(1); } /* libscp initialization */ scp_init(); if (daemon) { /* start of daemonizing code */ g_pid = g_fork(); if (0 != g_pid) { if (sesman_listen_test(g_cfg) != 0) { log_message(LOG_LEVEL_ERROR, "Failed to start xrdp-sesman daemon, " "possibly address already in use."); g_deinit(); g_exit(1); } g_deinit(); g_exit(0); } g_file_close(0); g_file_close(1); g_file_close(2); if (g_file_open("/dev/null") < 0) { } if (g_file_open("/dev/null") < 0) { } if (g_file_open("/dev/null") < 0) { } } /* signal handling */ g_pid = g_getpid(); /* old style signal handling is now managed synchronously by a * separate thread. uncomment this block if you need old style * signal handling and comment out thread_sighandler_start() * going back to old style for the time being * problem with the sigaddset functions in sig.c - jts */ #if 1 g_signal_hang_up(sig_sesman_reload_cfg); /* SIGHUP */ g_signal_user_interrupt(sig_sesman_shutdown); /* SIGINT */ g_signal_terminate(sig_sesman_shutdown); /* SIGTERM */ g_signal_child_stop(sig_sesman_session_end); /* SIGCHLD */ #endif #if 0 thread_sighandler_start(); #endif if (daemon) { /* writing pid file */ fd = g_file_open(pid_file); if (-1 == fd) { log_message(LOG_LEVEL_ERROR, "error opening pid file[%s]: %s", pid_file, g_get_strerror()); log_end(); g_deinit(); g_exit(1); } g_sprintf(pid_s, "%d", g_pid); g_file_write(fd, pid_s, g_strlen(pid_s)); g_file_close(fd); } /* start program main loop */ log_message(LOG_LEVEL_INFO, "starting xrdp-sesman with pid %d", g_pid); /* make sure the socket directory exists */ g_mk_socket_path("xrdp-sesman"); /* make sure the /tmp/.X11-unix directory exists */ if (!g_directory_exist("/tmp/.X11-unix")) { if (!g_create_dir("/tmp/.X11-unix")) { log_message(LOG_LEVEL_ERROR, "sesman.c: error creating dir /tmp/.X11-unix"); } g_chmod_hex("/tmp/.X11-unix", 0x1777); } g_snprintf(text, 255, "xrdp_sesman_%8.8x_main_term", g_pid); g_term_event = g_create_wait_obj(text); error = sesman_main_loop(); /* clean up PID file on exit */ if (daemon) { g_file_delete(pid_file); } g_delete_wait_obj(g_term_event); if (!daemon) { log_end(); } g_deinit(); g_exit(error); return 0; } xrdp-0.9.5/sesman/libscp/000755 001751 001751 00000000000 13220731020 015152 5ustar00metameta000000 000000 xrdp-0.9.5/sesman/scp_v1_mng.c000644 001751 001751 00000010310 13206023530 016075 0ustar00metameta000000 000000 /** * xrdp: A Remote Desktop Protocol server. * * Copyright (C) Jay Sorg 2004-2013 * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ /** * * @file scp_v1_mng.c * @brief scp version 1 implementation - management * @author Jay Sorg, Simone Fedele * */ #if defined(HAVE_CONFIG_H) #include #endif #include "sesman.h" #include "libscp.h" extern struct config_sesman *g_cfg; /* in sesman.c */ static void parseCommonStates(enum SCP_SERVER_STATES_E e, const char *f); /******************************************************************************/ void scp_v1_mng_process(struct SCP_CONNECTION *c, struct SCP_SESSION *s) { long data; enum SCP_SERVER_STATES_E e; struct SCP_DISCONNECTED_SESSION *slist = 0; int scount; int end = 0; data = auth_userpass(s->username, s->password,NULL); /*LOG_DBG("user: %s\npass: %s", s->username, s->password);*/ if (!data) { scp_v1s_mng_deny_connection(c, "Login failed"); log_message(LOG_LEVEL_INFO, "[MNG] Login failed for user %s. Connection terminated", s->username); auth_end(data); return; } /* testing if login is allowed */ if (0 == access_login_mng_allowed(s->username)) { scp_v1s_mng_deny_connection(c, "Access to Terminal Server not allowed."); log_message(LOG_LEVEL_INFO, "[MNG] User %s not allowed on TS. Connection terminated", s->username); auth_end(data); return; } e = scp_v1s_mng_allow_connection(c, s); end = 1; while (end) { switch (e) { case SCP_SERVER_STATE_MNG_ACTION: log_message(LOG_LEVEL_INFO, "Connection cancelled after session listing"); break; case SCP_SERVER_STATE_MNG_LISTREQ: /* list disconnected sessions */ slist = session_get_byuser(NULL, &scount, SESMAN_SESSION_STATUS_ALL); LOG_DBG("sessions on TS: %d (slist: %x)", scount, slist); if (0 == slist) { log_message(LOG_LEVEL_INFO, "No sessions on Terminal Server"); } e = scp_v1s_mng_list_sessions(c, s, scount, slist); g_free(slist); break; default: /* we check the other errors */ parseCommonStates(e, "scp_v1s_mng_list_sessions()"); end = 0; break; } } /* cleanup */ auth_end(data); } static void parseCommonStates(enum SCP_SERVER_STATES_E e, const char *f) { switch (e) { case SCP_SERVER_STATE_VERSION_ERR: LOG_DBG("version error") case SCP_SERVER_STATE_SIZE_ERR: /* an unknown scp version was requested, so we shut down the */ /* connection (and log the fact) */ log_message(LOG_LEVEL_WARNING, "protocol violation. connection closed."); break; case SCP_SERVER_STATE_NETWORK_ERR: log_message(LOG_LEVEL_WARNING, "libscp network error."); break; case SCP_SERVER_STATE_SEQUENCE_ERR: log_message(LOG_LEVEL_WARNING, "libscp sequence error."); break; case SCP_SERVER_STATE_INTERNAL_ERR: /* internal error occurred (eg. malloc() error, ecc.) */ log_message(LOG_LEVEL_ERROR, "libscp internal error occurred."); break; default: /* dummy: scp_v1s_request_password won't generate any other */ /* error other than the ones before */ log_message(LOG_LEVEL_ALWAYS, "unknown return from %s", f); break; } } xrdp-0.9.5/sesman/Makefile.in000644 001751 001751 00000100443 13220730774 015764 0ustar00metameta000000 000000 # Makefile.in generated by automake 1.15.1 from Makefile.am. # @configure_input@ # Copyright (C) 1994-2017 Free Software Foundation, Inc. # This Makefile.in is free software; the Free Software Foundation # gives unlimited permission to copy and/or distribute it, # with or without modifications, as long as this notice is preserved. # This program is distributed in the hope that it will be useful, # but WITHOUT ANY WARRANTY, to the extent permitted by law; without # even the implied warranty of MERCHANTABILITY or FITNESS FOR A # PARTICULAR PURPOSE. @SET_MAKE@ VPATH = @srcdir@ am__is_gnu_make = { \ if test -z '$(MAKELEVEL)'; then \ false; \ elif test -n '$(MAKE_HOST)'; then \ true; \ elif test -n '$(MAKE_VERSION)' && test -n '$(CURDIR)'; then \ true; \ else \ false; \ fi; \ } am__make_running_with_option = \ case $${target_option-} in \ ?) ;; \ *) echo "am__make_running_with_option: internal error: invalid" \ "target option '$${target_option-}' specified" >&2; \ exit 1;; \ esac; \ has_opt=no; \ sane_makeflags=$$MAKEFLAGS; \ if $(am__is_gnu_make); then \ sane_makeflags=$$MFLAGS; \ else \ case $$MAKEFLAGS in \ *\\[\ \ ]*) \ bs=\\; \ sane_makeflags=`printf '%s\n' "$$MAKEFLAGS" \ | sed "s/$$bs$$bs[$$bs $$bs ]*//g"`;; \ esac; \ fi; \ skip_next=no; \ strip_trailopt () \ { \ flg=`printf '%s\n' "$$flg" | sed "s/$$1.*$$//"`; \ }; \ for flg in $$sane_makeflags; do \ test $$skip_next = yes && { skip_next=no; continue; }; \ case $$flg in \ *=*|--*) continue;; \ -*I) strip_trailopt 'I'; skip_next=yes;; \ -*I?*) strip_trailopt 'I';; \ -*O) strip_trailopt 'O'; skip_next=yes;; \ -*O?*) strip_trailopt 'O';; \ -*l) strip_trailopt 'l'; skip_next=yes;; \ -*l?*) strip_trailopt 'l';; \ -[dEDm]) skip_next=yes;; \ -[JT]) skip_next=yes;; \ esac; \ case $$flg in \ *$$target_option*) has_opt=yes; break;; \ esac; \ done; \ test $$has_opt = yes am__make_dryrun = (target_option=n; $(am__make_running_with_option)) am__make_keepgoing = (target_option=k; $(am__make_running_with_option)) pkgdatadir = $(datadir)/@PACKAGE@ pkgincludedir = $(includedir)/@PACKAGE@ pkglibdir = $(libdir)/@PACKAGE@ pkglibexecdir = $(libexecdir)/@PACKAGE@ am__cd = CDPATH="$${ZSH_VERSION+.}$(PATH_SEPARATOR)" && cd install_sh_DATA = $(install_sh) -c -m 644 install_sh_PROGRAM = $(install_sh) -c install_sh_SCRIPT = $(install_sh) -c INSTALL_HEADER = $(INSTALL_DATA) transform = $(program_transform_name) NORMAL_INSTALL = : PRE_INSTALL = : POST_INSTALL = : NORMAL_UNINSTALL = : PRE_UNINSTALL = : POST_UNINSTALL = : build_triplet = @build@ host_triplet = @host@ @XRDP_DEBUG_TRUE@am__append_1 = -DXRDP_DEBUG sbin_PROGRAMS = xrdp-sesman$(EXEEXT) subdir = sesman ACLOCAL_M4 = $(top_srcdir)/aclocal.m4 am__aclocal_m4_deps = $(top_srcdir)/m4/ax_append_compile_flags.m4 \ $(top_srcdir)/m4/ax_append_flag.m4 \ $(top_srcdir)/m4/ax_cflags_warn_all.m4 \ $(top_srcdir)/m4/ax_check_compile_flag.m4 \ $(top_srcdir)/m4/ax_gcc_func_attribute.m4 \ $(top_srcdir)/m4/ax_require_defined.m4 \ $(top_srcdir)/m4/ax_type_socklen_t.m4 \ $(top_srcdir)/m4/libtool.m4 $(top_srcdir)/m4/ltoptions.m4 \ $(top_srcdir)/m4/ltsugar.m4 $(top_srcdir)/m4/ltversion.m4 \ $(top_srcdir)/m4/lt~obsolete.m4 $(top_srcdir)/m4/pkg.m4 \ $(top_srcdir)/configure.ac am__configure_deps = $(am__aclocal_m4_deps) $(CONFIGURE_DEPENDENCIES) \ $(ACLOCAL_M4) DIST_COMMON = $(srcdir)/Makefile.am $(dist_sesmansysconf_SCRIPTS) \ $(dist_sesmansysconf_DATA) $(am__DIST_COMMON) mkinstalldirs = $(install_sh) -d CONFIG_HEADER = $(top_builddir)/config_ac.h CONFIG_CLEAN_FILES = CONFIG_CLEAN_VPATH_FILES = am__installdirs = "$(DESTDIR)$(sbindir)" \ "$(DESTDIR)$(sesmansysconfdir)" \ "$(DESTDIR)$(sesmansysconfdir)" PROGRAMS = $(sbin_PROGRAMS) am__xrdp_sesman_SOURCES_DIST = access.c access.h auth.h config.c \ config.h env.c env.h scp.c scp.h scp_v0.c scp_v0.h scp_v1.c \ scp_v1.h scp_v1_mng.c scp_v1_mng.h sesman.c sesman.h session.c \ session.h sig.c sig.h xauth.c xauth.h verify_user_pam.c \ verify_user_kerberos.c verify_user_pam_userpass.c \ verify_user_bsd.c verify_user.c @SESMAN_BSD_FALSE@@SESMAN_KERBEROS_FALSE@@SESMAN_NOPAM_FALSE@@SESMAN_PAMUSERPASS_FALSE@am__objects_1 = verify_user_pam.$(OBJEXT) @SESMAN_BSD_FALSE@@SESMAN_KERBEROS_TRUE@@SESMAN_NOPAM_FALSE@@SESMAN_PAMUSERPASS_FALSE@am__objects_1 = verify_user_kerberos.$(OBJEXT) @SESMAN_BSD_FALSE@@SESMAN_NOPAM_FALSE@@SESMAN_PAMUSERPASS_TRUE@am__objects_1 = verify_user_pam_userpass.$(OBJEXT) @SESMAN_BSD_TRUE@@SESMAN_NOPAM_FALSE@am__objects_1 = verify_user_bsd.$(OBJEXT) @SESMAN_NOPAM_TRUE@am__objects_1 = verify_user.$(OBJEXT) am_xrdp_sesman_OBJECTS = access.$(OBJEXT) config.$(OBJEXT) \ env.$(OBJEXT) scp.$(OBJEXT) scp_v0.$(OBJEXT) scp_v1.$(OBJEXT) \ scp_v1_mng.$(OBJEXT) sesman.$(OBJEXT) session.$(OBJEXT) \ sig.$(OBJEXT) xauth.$(OBJEXT) $(am__objects_1) xrdp_sesman_OBJECTS = $(am_xrdp_sesman_OBJECTS) am__DEPENDENCIES_1 = xrdp_sesman_DEPENDENCIES = $(top_builddir)/common/libcommon.la \ $(top_builddir)/sesman/libscp/libscp.la $(am__DEPENDENCIES_1) AM_V_lt = $(am__v_lt_@AM_V@) am__v_lt_ = $(am__v_lt_@AM_DEFAULT_V@) am__v_lt_0 = --silent am__v_lt_1 = am__vpath_adj_setup = srcdirstrip=`echo "$(srcdir)" | sed 's|.|.|g'`; am__vpath_adj = case $$p in \ $(srcdir)/*) f=`echo "$$p" | sed "s|^$$srcdirstrip/||"`;; \ *) f=$$p;; \ esac; am__strip_dir = f=`echo $$p | sed -e 's|^.*/||'`; am__install_max = 40 am__nobase_strip_setup = \ srcdirstrip=`echo "$(srcdir)" | sed 's/[].[^$$\\*|]/\\\\&/g'` am__nobase_strip = \ for p in $$list; do echo "$$p"; done | sed -e "s|$$srcdirstrip/||" am__nobase_list = $(am__nobase_strip_setup); \ for p in $$list; do echo "$$p $$p"; done | \ sed "s| $$srcdirstrip/| |;"' / .*\//!s/ .*/ ./; s,\( .*\)/[^/]*$$,\1,' | \ $(AWK) 'BEGIN { files["."] = "" } { files[$$2] = files[$$2] " " $$1; \ if (++n[$$2] == $(am__install_max)) \ { print $$2, files[$$2]; n[$$2] = 0; files[$$2] = "" } } \ END { for (dir in files) print dir, files[dir] }' am__base_list = \ sed '$$!N;$$!N;$$!N;$$!N;$$!N;$$!N;$$!N;s/\n/ /g' | \ sed '$$!N;$$!N;$$!N;$$!N;s/\n/ /g' am__uninstall_files_from_dir = { \ test -z "$$files" \ || { test ! -d "$$dir" && test ! -f "$$dir" && test ! -r "$$dir"; } \ || { echo " ( cd '$$dir' && rm -f" $$files ")"; \ $(am__cd) "$$dir" && rm -f $$files; }; \ } SCRIPTS = $(dist_sesmansysconf_SCRIPTS) AM_V_P = $(am__v_P_@AM_V@) am__v_P_ = $(am__v_P_@AM_DEFAULT_V@) am__v_P_0 = false am__v_P_1 = : AM_V_GEN = $(am__v_GEN_@AM_V@) am__v_GEN_ = $(am__v_GEN_@AM_DEFAULT_V@) am__v_GEN_0 = @echo " GEN " $@; am__v_GEN_1 = AM_V_at = $(am__v_at_@AM_V@) am__v_at_ = $(am__v_at_@AM_DEFAULT_V@) am__v_at_0 = @ am__v_at_1 = DEFAULT_INCLUDES = -I.@am__isrc@ -I$(top_builddir) depcomp = $(SHELL) $(top_srcdir)/depcomp am__depfiles_maybe = depfiles am__mv = mv -f COMPILE = $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) \ $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) LTCOMPILE = $(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) \ $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) \ $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) \ $(AM_CFLAGS) $(CFLAGS) AM_V_CC = $(am__v_CC_@AM_V@) am__v_CC_ = $(am__v_CC_@AM_DEFAULT_V@) am__v_CC_0 = @echo " CC " $@; am__v_CC_1 = CCLD = $(CC) LINK = $(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) \ $(LIBTOOLFLAGS) --mode=link $(CCLD) $(AM_CFLAGS) $(CFLAGS) \ $(AM_LDFLAGS) $(LDFLAGS) -o $@ AM_V_CCLD = $(am__v_CCLD_@AM_V@) am__v_CCLD_ = $(am__v_CCLD_@AM_DEFAULT_V@) am__v_CCLD_0 = @echo " CCLD " $@; am__v_CCLD_1 = SOURCES = $(xrdp_sesman_SOURCES) DIST_SOURCES = $(am__xrdp_sesman_SOURCES_DIST) RECURSIVE_TARGETS = all-recursive check-recursive cscopelist-recursive \ ctags-recursive dvi-recursive html-recursive info-recursive \ install-data-recursive install-dvi-recursive \ install-exec-recursive install-html-recursive \ install-info-recursive install-pdf-recursive \ install-ps-recursive install-recursive installcheck-recursive \ installdirs-recursive pdf-recursive ps-recursive \ tags-recursive uninstall-recursive am__can_run_installinfo = \ case $$AM_UPDATE_INFO_DIR in \ n|no|NO) false;; \ *) (install-info --version) >/dev/null 2>&1;; \ esac DATA = $(dist_sesmansysconf_DATA) RECURSIVE_CLEAN_TARGETS = mostlyclean-recursive clean-recursive \ distclean-recursive maintainer-clean-recursive am__recursive_targets = \ $(RECURSIVE_TARGETS) \ $(RECURSIVE_CLEAN_TARGETS) \ $(am__extra_recursive_targets) AM_RECURSIVE_TARGETS = $(am__recursive_targets:-recursive=) TAGS CTAGS \ distdir am__tagged_files = $(HEADERS) $(SOURCES) $(TAGS_FILES) $(LISP) # Read a list of newline-separated strings from the standard input, # and print each of them once, without duplicates. Input order is # *not* preserved. am__uniquify_input = $(AWK) '\ BEGIN { nonempty = 0; } \ { items[$$0] = 1; nonempty = 1; } \ END { if (nonempty) { for (i in items) print i; }; } \ ' # Make sure the list of sources is unique. This is necessary because, # e.g., the same source file might be shared among _SOURCES variables # for different programs/libraries. am__define_uniq_tagged_files = \ list='$(am__tagged_files)'; \ unique=`for i in $$list; do \ if test -f "$$i"; then echo $$i; else echo $(srcdir)/$$i; fi; \ done | $(am__uniquify_input)` ETAGS = etags CTAGS = ctags DIST_SUBDIRS = $(SUBDIRS) am__DIST_COMMON = $(srcdir)/Makefile.in $(top_srcdir)/depcomp DISTFILES = $(DIST_COMMON) $(DIST_SOURCES) $(TEXINFOS) $(EXTRA_DIST) am__relativize = \ dir0=`pwd`; \ sed_first='s,^\([^/]*\)/.*$$,\1,'; \ sed_rest='s,^[^/]*/*,,'; \ sed_last='s,^.*/\([^/]*\)$$,\1,'; \ sed_butlast='s,/*[^/]*$$,,'; \ while test -n "$$dir1"; do \ first=`echo "$$dir1" | sed -e "$$sed_first"`; \ if test "$$first" != "."; then \ if test "$$first" = ".."; then \ dir2=`echo "$$dir0" | sed -e "$$sed_last"`/"$$dir2"; \ dir0=`echo "$$dir0" | sed -e "$$sed_butlast"`; \ else \ first2=`echo "$$dir2" | sed -e "$$sed_first"`; \ if test "$$first2" = "$$first"; then \ dir2=`echo "$$dir2" | sed -e "$$sed_rest"`; \ else \ dir2="../$$dir2"; \ fi; \ dir0="$$dir0"/"$$first"; \ fi; \ fi; \ dir1=`echo "$$dir1" | sed -e "$$sed_rest"`; \ done; \ reldir="$$dir2" ACLOCAL = @ACLOCAL@ AMTAR = @AMTAR@ AM_DEFAULT_VERBOSITY = @AM_DEFAULT_VERBOSITY@ AR = @AR@ AUTOCONF = @AUTOCONF@ AUTOHEADER = @AUTOHEADER@ AUTOMAKE = @AUTOMAKE@ AWK = @AWK@ CC = @CC@ CCDEPMODE = @CCDEPMODE@ CFLAGS = @CFLAGS@ CPP = @CPP@ CPPFLAGS = @CPPFLAGS@ CYGPATH_W = @CYGPATH_W@ DEFS = @DEFS@ DEPDIR = @DEPDIR@ DLLTOOL = @DLLTOOL@ DLOPEN_LIBS = @DLOPEN_LIBS@ DSYMUTIL = @DSYMUTIL@ DUMPBIN = @DUMPBIN@ ECHO_C = @ECHO_C@ ECHO_N = @ECHO_N@ ECHO_T = @ECHO_T@ EGREP = @EGREP@ EXEEXT = @EXEEXT@ FDKAAC_CFLAGS = @FDKAAC_CFLAGS@ FDKAAC_LIBS = @FDKAAC_LIBS@ FGREP = @FGREP@ FREERDP_CFLAGS = @FREERDP_CFLAGS@ FREERDP_LIBS = @FREERDP_LIBS@ FUSE_CFLAGS = @FUSE_CFLAGS@ FUSE_LIBS = @FUSE_LIBS@ GREP = @GREP@ INSTALL = @INSTALL@ INSTALL_DATA = @INSTALL_DATA@ INSTALL_PROGRAM = @INSTALL_PROGRAM@ INSTALL_SCRIPT = @INSTALL_SCRIPT@ INSTALL_STRIP_PROGRAM = @INSTALL_STRIP_PROGRAM@ LD = @LD@ LDFLAGS = @LDFLAGS@ LIBOBJS = @LIBOBJS@ LIBS = @LIBS@ LIBTOOL = @LIBTOOL@ LIPO = @LIPO@ LN_S = @LN_S@ LTLIBOBJS = @LTLIBOBJS@ LT_SYS_LIBRARY_PATH = @LT_SYS_LIBRARY_PATH@ MAKEINFO = @MAKEINFO@ MANIFEST_TOOL = @MANIFEST_TOOL@ MKDIR_P = @MKDIR_P@ NM = @NM@ NMEDIT = @NMEDIT@ OBJDUMP = @OBJDUMP@ OBJEXT = @OBJEXT@ OPENSSL = @OPENSSL@ OPENSSL_CFLAGS = @OPENSSL_CFLAGS@ OPENSSL_LIBS = @OPENSSL_LIBS@ OTOOL = @OTOOL@ OTOOL64 = @OTOOL64@ PACKAGE = @PACKAGE@ PACKAGE_BUGREPORT = @PACKAGE_BUGREPORT@ PACKAGE_NAME = @PACKAGE_NAME@ PACKAGE_STRING = @PACKAGE_STRING@ PACKAGE_TARNAME = @PACKAGE_TARNAME@ PACKAGE_URL = @PACKAGE_URL@ PACKAGE_VERSION = @PACKAGE_VERSION@ PAM_RULES = @PAM_RULES@ PATH_SEPARATOR = @PATH_SEPARATOR@ PIXMAN_CFLAGS = @PIXMAN_CFLAGS@ PIXMAN_LIBS = @PIXMAN_LIBS@ PKG_CONFIG = @PKG_CONFIG@ PKG_CONFIG_LIBDIR = @PKG_CONFIG_LIBDIR@ PKG_CONFIG_PATH = @PKG_CONFIG_PATH@ RANLIB = @RANLIB@ SED = @SED@ SET_MAKE = @SET_MAKE@ SHELL = @SHELL@ STRIP = @STRIP@ TurboJpegIncDir = @TurboJpegIncDir@ TurboJpegLibDir = @TurboJpegLibDir@ VERSION = @VERSION@ XMKMF = @XMKMF@ X_CFLAGS = @X_CFLAGS@ X_EXTRA_LIBS = @X_EXTRA_LIBS@ X_LIBS = @X_LIBS@ X_PRE_LIBS = @X_PRE_LIBS@ abs_builddir = @abs_builddir@ abs_srcdir = @abs_srcdir@ abs_top_builddir = @abs_top_builddir@ abs_top_srcdir = @abs_top_srcdir@ ac_ct_AR = @ac_ct_AR@ ac_ct_CC = @ac_ct_CC@ ac_ct_DUMPBIN = @ac_ct_DUMPBIN@ am__include = @am__include@ am__leading_dot = @am__leading_dot@ am__quote = @am__quote@ am__tar = @am__tar@ am__untar = @am__untar@ bindir = @bindir@ build = @build@ build_alias = @build_alias@ build_cpu = @build_cpu@ build_os = @build_os@ build_vendor = @build_vendor@ builddir = @builddir@ datadir = @datadir@ datarootdir = @datarootdir@ docdir = @docdir@ dvidir = @dvidir@ exec_prefix = @exec_prefix@ host = @host@ host_alias = @host_alias@ host_cpu = @host_cpu@ host_os = @host_os@ host_vendor = @host_vendor@ htmldir = @htmldir@ includedir = @includedir@ infodir = @infodir@ install_sh = @install_sh@ libdir = @libdir@ libexecdir = @libexecdir@ localedir = @localedir@ localstatedir = @localstatedir@ mandir = @mandir@ mkdir_p = @mkdir_p@ moduledir = @moduledir@ oldincludedir = @oldincludedir@ pdfdir = @pdfdir@ pkgconfigdir = @pkgconfigdir@ prefix = @prefix@ program_transform_name = @program_transform_name@ psdir = @psdir@ sbindir = @sbindir@ sharedstatedir = @sharedstatedir@ socketdir = @socketdir@ srcdir = @srcdir@ subdirs = @subdirs@ sysconfdir = @sysconfdir@ systemdsystemunitdir = @systemdsystemunitdir@ target_alias = @target_alias@ top_build_prefix = @top_build_prefix@ top_builddir = @top_builddir@ top_srcdir = @top_srcdir@ EXTRA_DIST = \ Doxyfile AM_CPPFLAGS = -DXRDP_SYSCONF_PATH=\"${sysconfdir}\" \ -DXRDP_CFG_PATH=\"${sysconfdir}/xrdp\" \ -DXRDP_SBIN_PATH=\"${sbindir}\" \ -DXRDP_SHARE_PATH=\"${datadir}/xrdp\" \ -DXRDP_PID_PATH=\"${localstatedir}/run\" \ -DXRDP_SOCKET_PATH=\"${socketdir}\" -I$(top_srcdir)/common \ -I$(top_srcdir)/sesman/libscp $(am__append_1) @SESMAN_BSD_FALSE@@SESMAN_KERBEROS_FALSE@@SESMAN_NOPAM_FALSE@@SESMAN_PAMUSERPASS_FALSE@AUTH_C = verify_user_pam.c @SESMAN_BSD_FALSE@@SESMAN_KERBEROS_TRUE@@SESMAN_NOPAM_FALSE@@SESMAN_PAMUSERPASS_FALSE@AUTH_C = verify_user_kerberos.c @SESMAN_BSD_FALSE@@SESMAN_NOPAM_FALSE@@SESMAN_PAMUSERPASS_TRUE@AUTH_C = verify_user_pam_userpass.c @SESMAN_BSD_TRUE@@SESMAN_NOPAM_FALSE@AUTH_C = verify_user_bsd.c @SESMAN_NOPAM_TRUE@AUTH_C = verify_user.c @SESMAN_BSD_FALSE@@SESMAN_KERBEROS_FALSE@@SESMAN_NOPAM_FALSE@@SESMAN_PAMUSERPASS_FALSE@AUTH_LIB = -lpam @SESMAN_BSD_FALSE@@SESMAN_KERBEROS_TRUE@@SESMAN_NOPAM_FALSE@@SESMAN_PAMUSERPASS_FALSE@AUTH_LIB = -lkrb5 @SESMAN_BSD_FALSE@@SESMAN_NOPAM_FALSE@@SESMAN_PAMUSERPASS_TRUE@AUTH_LIB = -lpam -lpam_userpass @SESMAN_BSD_TRUE@@SESMAN_NOPAM_FALSE@AUTH_LIB = @SESMAN_NOPAM_TRUE@AUTH_LIB = -lcrypt xrdp_sesman_SOURCES = \ access.c \ access.h \ auth.h \ config.c \ config.h \ env.c \ env.h \ scp.c \ scp.h \ scp_v0.c \ scp_v0.h \ scp_v1.c \ scp_v1.h \ scp_v1_mng.c \ scp_v1_mng.h \ sesman.c \ sesman.h \ session.c \ session.h \ sig.c \ sig.h \ xauth.c \ xauth.h \ $(AUTH_C) xrdp_sesman_LDADD = \ $(top_builddir)/common/libcommon.la \ $(top_builddir)/sesman/libscp/libscp.la \ $(AUTH_LIB) \ -lpthread sesmansysconfdir = $(sysconfdir)/xrdp dist_sesmansysconf_DATA = \ sesman.ini dist_sesmansysconf_SCRIPTS = \ startwm.sh \ reconnectwm.sh SUBDIRS = \ libscp \ tools \ chansrv all: all-recursive .SUFFIXES: .SUFFIXES: .c .lo .o .obj $(srcdir)/Makefile.in: $(srcdir)/Makefile.am $(am__configure_deps) @for dep in $?; do \ case '$(am__configure_deps)' in \ *$$dep*) \ ( cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh ) \ && { if test -f $@; then exit 0; else break; fi; }; \ exit 1;; \ esac; \ done; \ echo ' cd $(top_srcdir) && $(AUTOMAKE) --foreign sesman/Makefile'; \ $(am__cd) $(top_srcdir) && \ $(AUTOMAKE) --foreign sesman/Makefile Makefile: $(srcdir)/Makefile.in $(top_builddir)/config.status @case '$?' in \ *config.status*) \ cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh;; \ *) \ echo ' cd $(top_builddir) && $(SHELL) ./config.status $(subdir)/$@ $(am__depfiles_maybe)'; \ cd $(top_builddir) && $(SHELL) ./config.status $(subdir)/$@ $(am__depfiles_maybe);; \ esac; $(top_builddir)/config.status: $(top_srcdir)/configure $(CONFIG_STATUS_DEPENDENCIES) cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh $(top_srcdir)/configure: $(am__configure_deps) cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh $(ACLOCAL_M4): $(am__aclocal_m4_deps) cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh $(am__aclocal_m4_deps): install-sbinPROGRAMS: $(sbin_PROGRAMS) @$(NORMAL_INSTALL) @list='$(sbin_PROGRAMS)'; test -n "$(sbindir)" || list=; \ if test -n "$$list"; then \ echo " $(MKDIR_P) '$(DESTDIR)$(sbindir)'"; \ $(MKDIR_P) "$(DESTDIR)$(sbindir)" || exit 1; \ fi; \ for p in $$list; do echo "$$p $$p"; done | \ sed 's/$(EXEEXT)$$//' | \ while read p p1; do if test -f $$p \ || test -f $$p1 \ ; then echo "$$p"; echo "$$p"; else :; fi; \ done | \ sed -e 'p;s,.*/,,;n;h' \ -e 's|.*|.|' \ -e 'p;x;s,.*/,,;s/$(EXEEXT)$$//;$(transform);s/$$/$(EXEEXT)/' | \ sed 'N;N;N;s,\n, ,g' | \ $(AWK) 'BEGIN { files["."] = ""; dirs["."] = 1 } \ { d=$$3; if (dirs[d] != 1) { print "d", d; dirs[d] = 1 } \ if ($$2 == $$4) files[d] = files[d] " " $$1; \ else { print "f", $$3 "/" $$4, $$1; } } \ END { for (d in files) print "f", d, files[d] }' | \ while read type dir files; do \ if test "$$dir" = .; then dir=; else dir=/$$dir; fi; \ test -z "$$files" || { \ echo " $(INSTALL_PROGRAM_ENV) $(LIBTOOL) $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=install $(INSTALL_PROGRAM) $$files '$(DESTDIR)$(sbindir)$$dir'"; \ $(INSTALL_PROGRAM_ENV) $(LIBTOOL) $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=install $(INSTALL_PROGRAM) $$files "$(DESTDIR)$(sbindir)$$dir" || exit $$?; \ } \ ; done uninstall-sbinPROGRAMS: @$(NORMAL_UNINSTALL) @list='$(sbin_PROGRAMS)'; test -n "$(sbindir)" || list=; \ files=`for p in $$list; do echo "$$p"; done | \ sed -e 'h;s,^.*/,,;s/$(EXEEXT)$$//;$(transform)' \ -e 's/$$/$(EXEEXT)/' \ `; \ test -n "$$list" || exit 0; \ echo " ( cd '$(DESTDIR)$(sbindir)' && rm -f" $$files ")"; \ cd "$(DESTDIR)$(sbindir)" && rm -f $$files clean-sbinPROGRAMS: @list='$(sbin_PROGRAMS)'; test -n "$$list" || exit 0; \ echo " rm -f" $$list; \ rm -f $$list || exit $$?; \ test -n "$(EXEEXT)" || exit 0; \ list=`for p in $$list; do echo "$$p"; done | sed 's/$(EXEEXT)$$//'`; \ echo " rm -f" $$list; \ rm -f $$list xrdp-sesman$(EXEEXT): $(xrdp_sesman_OBJECTS) $(xrdp_sesman_DEPENDENCIES) $(EXTRA_xrdp_sesman_DEPENDENCIES) @rm -f xrdp-sesman$(EXEEXT) $(AM_V_CCLD)$(LINK) $(xrdp_sesman_OBJECTS) $(xrdp_sesman_LDADD) $(LIBS) install-dist_sesmansysconfSCRIPTS: $(dist_sesmansysconf_SCRIPTS) @$(NORMAL_INSTALL) @list='$(dist_sesmansysconf_SCRIPTS)'; test -n "$(sesmansysconfdir)" || list=; \ if test -n "$$list"; then \ echo " $(MKDIR_P) '$(DESTDIR)$(sesmansysconfdir)'"; \ $(MKDIR_P) "$(DESTDIR)$(sesmansysconfdir)" || exit 1; \ fi; \ for p in $$list; do \ if test -f "$$p"; then d=; else d="$(srcdir)/"; fi; \ if test -f "$$d$$p"; then echo "$$d$$p"; echo "$$p"; else :; fi; \ done | \ sed -e 'p;s,.*/,,;n' \ -e 'h;s|.*|.|' \ -e 'p;x;s,.*/,,;$(transform)' | sed 'N;N;N;s,\n, ,g' | \ $(AWK) 'BEGIN { files["."] = ""; dirs["."] = 1; } \ { d=$$3; if (dirs[d] != 1) { print "d", d; dirs[d] = 1 } \ if ($$2 == $$4) { files[d] = files[d] " " $$1; \ if (++n[d] == $(am__install_max)) { \ print "f", d, files[d]; n[d] = 0; files[d] = "" } } \ else { print "f", d "/" $$4, $$1 } } \ END { for (d in files) print "f", d, files[d] }' | \ while read type dir files; do \ if test "$$dir" = .; then dir=; else dir=/$$dir; fi; \ test -z "$$files" || { \ echo " $(INSTALL_SCRIPT) $$files '$(DESTDIR)$(sesmansysconfdir)$$dir'"; \ $(INSTALL_SCRIPT) $$files "$(DESTDIR)$(sesmansysconfdir)$$dir" || exit $$?; \ } \ ; done uninstall-dist_sesmansysconfSCRIPTS: @$(NORMAL_UNINSTALL) @list='$(dist_sesmansysconf_SCRIPTS)'; test -n "$(sesmansysconfdir)" || exit 0; \ files=`for p in $$list; do echo "$$p"; done | \ sed -e 's,.*/,,;$(transform)'`; \ dir='$(DESTDIR)$(sesmansysconfdir)'; $(am__uninstall_files_from_dir) mostlyclean-compile: -rm -f *.$(OBJEXT) distclean-compile: -rm -f *.tab.c @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/access.Po@am__quote@ @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/config.Po@am__quote@ @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/env.Po@am__quote@ @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/scp.Po@am__quote@ @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/scp_v0.Po@am__quote@ @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/scp_v1.Po@am__quote@ @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/scp_v1_mng.Po@am__quote@ @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/sesman.Po@am__quote@ @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/session.Po@am__quote@ @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/sig.Po@am__quote@ @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/verify_user.Po@am__quote@ @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/verify_user_bsd.Po@am__quote@ @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/verify_user_kerberos.Po@am__quote@ @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/verify_user_pam.Po@am__quote@ @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/verify_user_pam_userpass.Po@am__quote@ @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/xauth.Po@am__quote@ .c.o: @am__fastdepCC_TRUE@ $(AM_V_CC)$(COMPILE) -MT $@ -MD -MP -MF $(DEPDIR)/$*.Tpo -c -o $@ $< @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) $(DEPDIR)/$*.Tpo $(DEPDIR)/$*.Po @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='$<' object='$@' libtool=no @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(COMPILE) -c -o $@ $< .c.obj: @am__fastdepCC_TRUE@ $(AM_V_CC)$(COMPILE) -MT $@ -MD -MP -MF $(DEPDIR)/$*.Tpo -c -o $@ `$(CYGPATH_W) '$<'` @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) $(DEPDIR)/$*.Tpo $(DEPDIR)/$*.Po @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='$<' object='$@' libtool=no @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(COMPILE) -c -o $@ `$(CYGPATH_W) '$<'` .c.lo: @am__fastdepCC_TRUE@ $(AM_V_CC)$(LTCOMPILE) -MT $@ -MD -MP -MF $(DEPDIR)/$*.Tpo -c -o $@ $< @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) $(DEPDIR)/$*.Tpo $(DEPDIR)/$*.Plo @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='$<' object='$@' libtool=yes @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(LTCOMPILE) -c -o $@ $< mostlyclean-libtool: -rm -f *.lo clean-libtool: -rm -rf .libs _libs install-dist_sesmansysconfDATA: $(dist_sesmansysconf_DATA) @$(NORMAL_INSTALL) @list='$(dist_sesmansysconf_DATA)'; test -n "$(sesmansysconfdir)" || list=; \ if test -n "$$list"; then \ echo " $(MKDIR_P) '$(DESTDIR)$(sesmansysconfdir)'"; \ $(MKDIR_P) "$(DESTDIR)$(sesmansysconfdir)" || exit 1; \ fi; \ for p in $$list; do \ if test -f "$$p"; then d=; else d="$(srcdir)/"; fi; \ echo "$$d$$p"; \ done | $(am__base_list) | \ while read files; do \ echo " $(INSTALL_DATA) $$files '$(DESTDIR)$(sesmansysconfdir)'"; \ $(INSTALL_DATA) $$files "$(DESTDIR)$(sesmansysconfdir)" || exit $$?; \ done uninstall-dist_sesmansysconfDATA: @$(NORMAL_UNINSTALL) @list='$(dist_sesmansysconf_DATA)'; test -n "$(sesmansysconfdir)" || list=; \ files=`for p in $$list; do echo $$p; done | sed -e 's|^.*/||'`; \ dir='$(DESTDIR)$(sesmansysconfdir)'; $(am__uninstall_files_from_dir) # This directory's subdirectories are mostly independent; you can cd # into them and run 'make' without going through this Makefile. # To change the values of 'make' variables: instead of editing Makefiles, # (1) if the variable is set in 'config.status', edit 'config.status' # (which will cause the Makefiles to be regenerated when you run 'make'); # (2) otherwise, pass the desired values on the 'make' command line. $(am__recursive_targets): @fail=; \ if $(am__make_keepgoing); then \ failcom='fail=yes'; \ else \ failcom='exit 1'; \ fi; \ dot_seen=no; \ target=`echo $@ | sed s/-recursive//`; \ case "$@" in \ distclean-* | maintainer-clean-*) list='$(DIST_SUBDIRS)' ;; \ *) list='$(SUBDIRS)' ;; \ esac; \ for subdir in $$list; do \ echo "Making $$target in $$subdir"; \ if test "$$subdir" = "."; then \ dot_seen=yes; \ local_target="$$target-am"; \ else \ local_target="$$target"; \ fi; \ ($(am__cd) $$subdir && $(MAKE) $(AM_MAKEFLAGS) $$local_target) \ || eval $$failcom; \ done; \ if test "$$dot_seen" = "no"; then \ $(MAKE) $(AM_MAKEFLAGS) "$$target-am" || exit 1; \ fi; test -z "$$fail" ID: $(am__tagged_files) $(am__define_uniq_tagged_files); mkid -fID $$unique tags: tags-recursive TAGS: tags tags-am: $(TAGS_DEPENDENCIES) $(am__tagged_files) set x; \ here=`pwd`; \ if ($(ETAGS) --etags-include --version) >/dev/null 2>&1; then \ include_option=--etags-include; \ empty_fix=.; \ else \ include_option=--include; \ empty_fix=; \ fi; \ list='$(SUBDIRS)'; for subdir in $$list; do \ if test "$$subdir" = .; then :; else \ test ! -f $$subdir/TAGS || \ set "$$@" "$$include_option=$$here/$$subdir/TAGS"; \ fi; \ done; \ $(am__define_uniq_tagged_files); \ shift; \ if test -z "$(ETAGS_ARGS)$$*$$unique"; then :; else \ test -n "$$unique" || unique=$$empty_fix; \ if test $$# -gt 0; then \ $(ETAGS) $(ETAGSFLAGS) $(AM_ETAGSFLAGS) $(ETAGS_ARGS) \ "$$@" $$unique; \ else \ $(ETAGS) $(ETAGSFLAGS) $(AM_ETAGSFLAGS) $(ETAGS_ARGS) \ $$unique; \ fi; \ fi ctags: ctags-recursive CTAGS: ctags ctags-am: $(TAGS_DEPENDENCIES) $(am__tagged_files) $(am__define_uniq_tagged_files); \ test -z "$(CTAGS_ARGS)$$unique" \ || $(CTAGS) $(CTAGSFLAGS) $(AM_CTAGSFLAGS) $(CTAGS_ARGS) \ $$unique GTAGS: here=`$(am__cd) $(top_builddir) && pwd` \ && $(am__cd) $(top_srcdir) \ && gtags -i $(GTAGS_ARGS) "$$here" cscopelist: cscopelist-recursive cscopelist-am: $(am__tagged_files) list='$(am__tagged_files)'; \ case "$(srcdir)" in \ [\\/]* | ?:[\\/]*) sdir="$(srcdir)" ;; \ *) sdir=$(subdir)/$(srcdir) ;; \ esac; \ for i in $$list; do \ if test -f "$$i"; then \ echo "$(subdir)/$$i"; \ else \ echo "$$sdir/$$i"; \ fi; \ done >> $(top_builddir)/cscope.files distclean-tags: -rm -f TAGS ID GTAGS GRTAGS GSYMS GPATH tags distdir: $(DISTFILES) @srcdirstrip=`echo "$(srcdir)" | sed 's/[].[^$$\\*]/\\\\&/g'`; \ topsrcdirstrip=`echo "$(top_srcdir)" | sed 's/[].[^$$\\*]/\\\\&/g'`; \ list='$(DISTFILES)'; \ dist_files=`for file in $$list; do echo $$file; done | \ sed -e "s|^$$srcdirstrip/||;t" \ -e "s|^$$topsrcdirstrip/|$(top_builddir)/|;t"`; \ case $$dist_files in \ */*) $(MKDIR_P) `echo "$$dist_files" | \ sed '/\//!d;s|^|$(distdir)/|;s,/[^/]*$$,,' | \ sort -u` ;; \ esac; \ for file in $$dist_files; do \ if test -f $$file || test -d $$file; then d=.; else d=$(srcdir); fi; \ if test -d $$d/$$file; then \ dir=`echo "/$$file" | sed -e 's,/[^/]*$$,,'`; \ if test -d "$(distdir)/$$file"; then \ find "$(distdir)/$$file" -type d ! -perm -700 -exec chmod u+rwx {} \;; \ fi; \ if test -d $(srcdir)/$$file && test $$d != $(srcdir); then \ cp -fpR $(srcdir)/$$file "$(distdir)$$dir" || exit 1; \ find "$(distdir)/$$file" -type d ! -perm -700 -exec chmod u+rwx {} \;; \ fi; \ cp -fpR $$d/$$file "$(distdir)$$dir" || exit 1; \ else \ test -f "$(distdir)/$$file" \ || cp -p $$d/$$file "$(distdir)/$$file" \ || exit 1; \ fi; \ done @list='$(DIST_SUBDIRS)'; for subdir in $$list; do \ if test "$$subdir" = .; then :; else \ $(am__make_dryrun) \ || test -d "$(distdir)/$$subdir" \ || $(MKDIR_P) "$(distdir)/$$subdir" \ || exit 1; \ dir1=$$subdir; dir2="$(distdir)/$$subdir"; \ $(am__relativize); \ new_distdir=$$reldir; \ dir1=$$subdir; dir2="$(top_distdir)"; \ $(am__relativize); \ new_top_distdir=$$reldir; \ echo " (cd $$subdir && $(MAKE) $(AM_MAKEFLAGS) top_distdir="$$new_top_distdir" distdir="$$new_distdir" \\"; \ echo " am__remove_distdir=: am__skip_length_check=: am__skip_mode_fix=: distdir)"; \ ($(am__cd) $$subdir && \ $(MAKE) $(AM_MAKEFLAGS) \ top_distdir="$$new_top_distdir" \ distdir="$$new_distdir" \ am__remove_distdir=: \ am__skip_length_check=: \ am__skip_mode_fix=: \ distdir) \ || exit 1; \ fi; \ done check-am: all-am check: check-recursive all-am: Makefile $(PROGRAMS) $(SCRIPTS) $(DATA) installdirs: installdirs-recursive installdirs-am: for dir in "$(DESTDIR)$(sbindir)" "$(DESTDIR)$(sesmansysconfdir)" "$(DESTDIR)$(sesmansysconfdir)"; do \ test -z "$$dir" || $(MKDIR_P) "$$dir"; \ done install: install-recursive install-exec: install-exec-recursive install-data: install-data-recursive uninstall: uninstall-recursive install-am: all-am @$(MAKE) $(AM_MAKEFLAGS) install-exec-am install-data-am installcheck: installcheck-recursive install-strip: if test -z '$(STRIP)'; then \ $(MAKE) $(AM_MAKEFLAGS) INSTALL_PROGRAM="$(INSTALL_STRIP_PROGRAM)" \ install_sh_PROGRAM="$(INSTALL_STRIP_PROGRAM)" INSTALL_STRIP_FLAG=-s \ install; \ else \ $(MAKE) $(AM_MAKEFLAGS) INSTALL_PROGRAM="$(INSTALL_STRIP_PROGRAM)" \ install_sh_PROGRAM="$(INSTALL_STRIP_PROGRAM)" INSTALL_STRIP_FLAG=-s \ "INSTALL_PROGRAM_ENV=STRIPPROG='$(STRIP)'" install; \ fi mostlyclean-generic: clean-generic: distclean-generic: -test -z "$(CONFIG_CLEAN_FILES)" || rm -f $(CONFIG_CLEAN_FILES) -test . = "$(srcdir)" || test -z "$(CONFIG_CLEAN_VPATH_FILES)" || rm -f $(CONFIG_CLEAN_VPATH_FILES) maintainer-clean-generic: @echo "This command is intended for maintainers to use" @echo "it deletes files that may require special tools to rebuild." clean: clean-recursive clean-am: clean-generic clean-libtool clean-sbinPROGRAMS \ mostlyclean-am distclean: distclean-recursive -rm -rf ./$(DEPDIR) -rm -f Makefile distclean-am: clean-am distclean-compile distclean-generic \ distclean-tags dvi: dvi-recursive dvi-am: html: html-recursive html-am: info: info-recursive info-am: install-data-am: install-dist_sesmansysconfDATA \ install-dist_sesmansysconfSCRIPTS install-dvi: install-dvi-recursive install-dvi-am: install-exec-am: install-sbinPROGRAMS install-html: install-html-recursive install-html-am: install-info: install-info-recursive install-info-am: install-man: install-pdf: install-pdf-recursive install-pdf-am: install-ps: install-ps-recursive install-ps-am: installcheck-am: maintainer-clean: maintainer-clean-recursive -rm -rf ./$(DEPDIR) -rm -f Makefile maintainer-clean-am: distclean-am maintainer-clean-generic mostlyclean: mostlyclean-recursive mostlyclean-am: mostlyclean-compile mostlyclean-generic \ mostlyclean-libtool pdf: pdf-recursive pdf-am: ps: ps-recursive ps-am: uninstall-am: uninstall-dist_sesmansysconfDATA \ uninstall-dist_sesmansysconfSCRIPTS uninstall-sbinPROGRAMS .MAKE: $(am__recursive_targets) install-am install-strip .PHONY: $(am__recursive_targets) CTAGS GTAGS TAGS all all-am check \ check-am clean clean-generic clean-libtool clean-sbinPROGRAMS \ cscopelist-am ctags ctags-am distclean distclean-compile \ distclean-generic distclean-libtool distclean-tags distdir dvi \ dvi-am html html-am info info-am install install-am \ install-data install-data-am install-dist_sesmansysconfDATA \ install-dist_sesmansysconfSCRIPTS install-dvi install-dvi-am \ install-exec install-exec-am install-html install-html-am \ install-info install-info-am install-man install-pdf \ install-pdf-am install-ps install-ps-am install-sbinPROGRAMS \ install-strip installcheck installcheck-am installdirs \ installdirs-am maintainer-clean maintainer-clean-generic \ mostlyclean mostlyclean-compile mostlyclean-generic \ mostlyclean-libtool pdf pdf-am ps ps-am tags tags-am uninstall \ uninstall-am uninstall-dist_sesmansysconfDATA \ uninstall-dist_sesmansysconfSCRIPTS uninstall-sbinPROGRAMS .PRECIOUS: Makefile # Tell versions [3.59,3.63) of GNU make to not export all variables. # Otherwise a system limit (for SysV at least) may be exceeded. .NOEXPORT: xrdp-0.9.5/sesman/sig.c000644 001751 001751 00000012005 13201006747 014634 0ustar00metameta000000 000000 /** * xrdp: A Remote Desktop Protocol server. * * Copyright (C) Jay Sorg 2004-2013 * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ /** * * @file sig.c * @brief signal handling functions * @author Jay Sorg, Simone Fedele * */ #if defined(HAVE_CONFIG_H) #include #endif #include #include "sesman.h" extern int g_sck; extern int g_pid; extern struct config_sesman *g_cfg; /* in sesman.c */ extern tbus g_term_event; /******************************************************************************/ void sig_sesman_shutdown(int sig) { char pid_file[256]; log_message(LOG_LEVEL_INFO, "shutting down sesman %d", 1); if (g_getpid() != g_pid) { LOG_DBG("g_getpid() [%d] differs from g_pid [%d]", (g_getpid()), g_pid); return; } LOG_DBG(" - getting signal %d pid %d", sig, g_getpid()); g_set_wait_obj(g_term_event); session_sigkill_all(); g_snprintf(pid_file, 255, "%s/xrdp-sesman.pid", XRDP_PID_PATH); g_file_delete(pid_file); } /******************************************************************************/ void sig_sesman_reload_cfg(int sig) { int error; struct config_sesman *cfg; char cfg_file[256]; log_message(LOG_LEVEL_WARNING, "receiving SIGHUP %d", 1); if (g_getpid() != g_pid) { LOG_DBG("g_getpid() [%d] differs from g_pid [%d]", g_getpid(), g_pid); return; } cfg = g_new0(struct config_sesman, 1); if (0 == cfg) { log_message(LOG_LEVEL_ERROR, "error creating new config: - keeping old cfg"); return; } if (config_read(cfg) != 0) { log_message(LOG_LEVEL_ERROR, "error reading config - keeping old cfg"); g_free(cfg); return; } /* stop logging subsystem */ log_end(); /* free old config data */ config_free(g_cfg); /* replace old config with newly read one */ g_cfg = cfg; g_snprintf(cfg_file, 255, "%s/sesman.ini", XRDP_CFG_PATH); /* start again logging subsystem */ error = log_start(cfg_file, "xrdp-sesman"); if (error != LOG_STARTUP_OK) { char buf[256]; switch (error) { case LOG_ERROR_MALLOC: g_printf("error on malloc. cannot restart logging. log stops here, sorry.\n"); break; case LOG_ERROR_FILE_OPEN: g_printf("error reopening log file [%s]. log stops here, sorry.\n", getLogFile(buf, 255)); break; } } log_message(LOG_LEVEL_INFO, "configuration reloaded, log subsystem restarted"); } /******************************************************************************/ void sig_sesman_session_end(int sig) { int pid; if (g_getpid() != g_pid) { return; } pid = g_waitchild(); if (pid > 0) { session_kill(pid); } } /******************************************************************************/ void * sig_handler_thread(void *arg) { int recv_signal; sigset_t sigmask; sigset_t oldmask; sigset_t waitmask; /* mask signals to be able to wait for them... */ sigfillset(&sigmask); /* it is a good idea not to block SIGILL SIGSEGV */ /* SIGFPE -- see sigaction(2) NOTES */ pthread_sigmask(SIG_BLOCK, &sigmask, &oldmask); /* building the signal wait mask... */ sigemptyset(&waitmask); sigaddset(&waitmask, SIGHUP); sigaddset(&waitmask, SIGCHLD); sigaddset(&waitmask, SIGTERM); sigaddset(&waitmask, SIGINT); // sigaddset(&waitmask, SIGFPE); // sigaddset(&waitmask, SIGILL); // sigaddset(&waitmask, SIGSEGV); do { LOG_DBG("calling sigwait()"); sigwait(&waitmask, &recv_signal); switch (recv_signal) { case SIGHUP: //reload cfg //we must stop & restart logging, or copy logging cfg!!!! LOG_DBG("sesman received SIGHUP"); //return 0; break; case SIGCHLD: /* a session died */ LOG_DBG("sesman received SIGCHLD"); sig_sesman_session_end(SIGCHLD); break; case SIGINT: /* we die */ LOG_DBG("sesman received SIGINT"); sig_sesman_shutdown(recv_signal); break; case SIGTERM: /* we die */ LOG_DBG("sesman received SIGTERM"); sig_sesman_shutdown(recv_signal); break; } } while (1); return 0; } xrdp-0.9.5/sesman/xauth.h000644 001751 001751 00000002203 13174271344 015215 0ustar00metameta000000 000000 /** * xrdp: A Remote Desktop Protocol server. * * Copyright (C) Emmanuel Blindauer 2016 * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ /** * * @file xauth.c * @brief XAUTHORITY handling code * */ #ifndef XAUTH_H #define XAUTH_H /** * * @brief create the XAUTHORITY file for the user according to the display and the cookie * xauth uses XAUTHORITY if defined, ~/.Xauthority otherwise * @param display The session display * @param file If not NULL, write the authorization in the file instead of default location * @return 0 if adding the cookie is ok */ int add_xauth_cookie(int display, const char *file); #endif xrdp-0.9.5/sesman/scp.h000644 001751 001751 00000002074 13174271344 014657 0ustar00metameta000000 000000 /** * xrdp: A Remote Desktop Protocol server. * * Copyright (C) Jay Sorg 2004-2013 * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ /** * * @file scp.h * @brief scp (sesman control protocol) common definitions * @author Simone Fedele * */ #ifndef SCP_H #define SCP_H #include "scp_v0.h" #include "scp_v1.h" #include "scp_v1_mng.h" /** * * @brief Starts a an scp protocol thread. * Starts a an scp protocol thread. * But does only version control.... * @param socket the connection socket * */ void* scp_process_start(void* sck); #endif xrdp-0.9.5/sesman/scp_v1.c000644 001751 001751 00000017652 13174271344 015270 0ustar00metameta000000 000000 /** * xrdp: A Remote Desktop Protocol server. * * Copyright (C) Jay Sorg 2004-2015 * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ /** * * @file scp_v1.c * @brief scp version 1 implementation * @author Jay Sorg, Simone Fedele * */ #if defined(HAVE_CONFIG_H) #include #endif #include "sesman.h" //#include "libscp_types.h" #include "libscp.h" extern struct config_sesman *g_cfg; /* in sesman.c */ static void parseCommonStates(enum SCP_SERVER_STATES_E e, const char *f); /******************************************************************************/ void scp_v1_process(struct SCP_CONNECTION *c, struct SCP_SESSION *s) { long data; int display = 0; int retries; int current_try; enum SCP_SERVER_STATES_E e; struct SCP_DISCONNECTED_SESSION *slist; struct session_item *sitem; int scount; SCP_SID sid; bool_t do_auth_end = 1; retries = g_cfg->sec.login_retry; current_try = retries; data = auth_userpass(s->username, s->password,NULL); /*LOG_DBG("user: %s\npass: %s", s->username, s->password);*/ while ((!data) && ((retries == 0) || (current_try > 0))) { LOG_DBG("data %d - retry %d - currenttry %d - expr %d", data, retries, current_try, ((!data) && ((retries == 0) || (current_try > 0)))); e = scp_v1s_request_password(c, s, "Wrong username and/or password"); switch (e) { case SCP_SERVER_STATE_OK: /* all ok, we got new username and password */ data = auth_userpass(s->username, s->password,NULL); /* one try less */ if (current_try > 0) { current_try--; } break; default: /* we check the other errors */ parseCommonStates(e, "scp_v1s_list_sessions()"); return; //break; } } if (!data) { scp_v1s_deny_connection(c, "Login failed"); log_message( LOG_LEVEL_INFO, "Login failed for user %s. Connection terminated", s->username); return; } /* testing if login is allowed*/ if (0 == access_login_allowed(s->username)) { scp_v1s_deny_connection(c, "Access to Terminal Server not allowed."); log_message(LOG_LEVEL_INFO, "User %s not allowed on TS. Connection terminated", s->username); return; } //check if we need password change /* list disconnected sessions */ slist = session_get_byuser(s->username, &scount, SESMAN_SESSION_STATUS_DISCONNECTED); if (scount == 0) { /* no disconnected sessions - start a new one */ log_message(LOG_LEVEL_DEBUG, "No disconnected sessions for this user " "- we create a new one"); if (0 != s->client_ip) { log_message(LOG_LEVEL_INFO, "++ created session (access granted): username %s, ip %s", s->username, s->client_ip); } else { log_message(LOG_LEVEL_INFO, "++ created session (access granted): username %s", s->username); } if (SCP_SESSION_TYPE_XVNC == s->type) { log_message(LOG_LEVEL_INFO, "starting Xvnc session..."); display = session_start(data, SESMAN_SESSION_TYPE_XVNC, c, s); } else if (SCP_SESSION_TYPE_XRDP == s->type) { log_message(LOG_LEVEL_INFO, "starting X11rdp session..."); display = session_start(data, SESMAN_SESSION_TYPE_XRDP, c, s); } else if (SCP_SESSION_TYPE_XORG == s->type) { log_message(LOG_LEVEL_INFO, "starting Xorg session..."); display = session_start(data, SESMAN_SESSION_TYPE_XORG, c, s); } /* if the session started up ok, auth_end will be called on sig child */ do_auth_end = display == 0; e = scp_v1s_connect_new_session(c, display); switch (e) { case SCP_SERVER_STATE_OK: /* all ok, we got new username and password */ break; default: /* we check the other errors */ parseCommonStates(e, "scp_v1s_connect_new_session()"); break; } } else { /* one or more disconnected sessions - listing */ e = scp_v1s_list_sessions(c, scount, slist, &sid); switch (e) { /*case SCP_SERVER_STATE_FORCE_NEW:*/ /* we should check for MaxSessions */ case SCP_SERVER_STATE_SELECTION_CANCEL: log_message( LOG_LEVEL_INFO, "Connection cancelled after session listing"); break; case SCP_SERVER_STATE_OK: /* ok, reconnecting... */ sitem = session_get_bypid(sid); if (0 == sitem) { e = scp_v1s_connection_error(c, "Internal error"); log_message(LOG_LEVEL_INFO, "Cannot find session item on the chain"); } else { display = sitem->display; /*e=scp_v1s_reconnect_session(c, sitem, display);*/ e = scp_v1s_reconnect_session(c, display); if (0 != s->client_ip) { log_message(LOG_LEVEL_INFO, "++ reconnected session: username %s, display :%d.0, session_pid %d, ip %s", s->username, display, sitem->pid, s->client_ip); } else { log_message(LOG_LEVEL_INFO, "++ reconnected session: username %s, display :%d.0, session_pid %d", s->username, display, sitem->pid); } g_free(sitem); } break; default: /* we check the other errors */ parseCommonStates(e, "scp_v1s_list_sessions()"); break; } } /* resource management */ if ((e == SCP_SERVER_STATE_OK) && (s->rsr)) { /* here goes scp resource sharing code */ } /* cleanup */ if (do_auth_end) { auth_end(data); } g_free(slist); } static void parseCommonStates(enum SCP_SERVER_STATES_E e, const char *f) { switch (e) { case SCP_SERVER_STATE_VERSION_ERR: LOG_DBG("version error") case SCP_SERVER_STATE_SIZE_ERR: /* an unknown scp version was requested, so we shut down the */ /* connection (and log the fact) */ log_message(LOG_LEVEL_WARNING, "protocol violation. connection closed."); break; case SCP_SERVER_STATE_NETWORK_ERR: log_message(LOG_LEVEL_WARNING, "libscp network error."); break; case SCP_SERVER_STATE_SEQUENCE_ERR: log_message(LOG_LEVEL_WARNING, "libscp sequence error."); break; case SCP_SERVER_STATE_INTERNAL_ERR: /* internal error occurred (eg. malloc() error, ecc.) */ log_message(LOG_LEVEL_ERROR, "libscp internal error occurred."); break; default: /* dummy: scp_v1s_request_password won't generate any other */ /* error other than the ones before */ log_message(LOG_LEVEL_ALWAYS, "unknown return from %s", f); break; } } xrdp-0.9.5/sesman/config.h000644 001751 001751 00000022533 13215625636 015344 0ustar00metameta000000 000000 /** * xrdp: A Remote Desktop Protocol server. * * Copyright (C) Jay Sorg 2004-2013 * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ /** * * @file config.h * @brief User authentication definitions * @author Simone Fedele @< simo [at] esseemme [dot] org @> * */ #ifndef CONFIG_H #define CONFIG_H #include "arch.h" #include "list.h" #include "log.h" #define SESMAN_CFG_GLOBALS "Globals" #define SESMAN_CFG_DEFWM "DefaultWindowManager" #define SESMAN_CFG_ADDRESS "ListenAddress" #define SESMAN_CFG_PORT "ListenPort" #define SESMAN_CFG_ENABLE_USERWM "EnableUserWindowManager" #define SESMAN_CFG_USERWM "UserWindowManager" #define SESMAN_CFG_MAX_SESSION "MaxSessions" #define SESMAN_CFG_AUTH_FILE_PATH "AuthFilePath" #define SESMAN_CFG_RDP_PARAMS "X11rdp" #define SESMAN_CFG_XORG_PARAMS "Xorg" #define SESMAN_CFG_VNC_PARAMS "Xvnc" #define SESMAN_CFG_SESSION_VARIABLES "SessionVariables" /* #define SESMAN_CFG_LOGGING "Logging" #define SESMAN_CFG_LOG_FILE "LogFile" #define SESMAN_CFG_LOG_LEVEL "LogLevel" #define SESMAN_CFG_LOG_ENABLE_SYSLOG "EnableSyslog" #define SESMAN_CFG_LOG_SYSLOG_LEVEL "SyslogLevel" */ #define SESMAN_CFG_SECURITY "Security" #define SESMAN_CFG_SEC_LOGIN_RETRY "MaxLoginRetry" #define SESMAN_CFG_SEC_ALLOW_ROOT "AllowRootLogin" #define SESMAN_CFG_SEC_USR_GROUP "TerminalServerUsers" #define SESMAN_CFG_SEC_ADM_GROUP "TerminalServerAdmins" #define SESMAN_CFG_SEC_ALWAYSGROUPCHECK "AlwaysGroupCheck" #define SESMAN_CFG_SESSIONS "Sessions" #define SESMAN_CFG_SESS_MAX "MaxSessions" #define SESMAN_CFG_SESS_KILL_DISC "KillDisconnected" #define SESMAN_CFG_SESS_IDLE_LIMIT "IdleTimeLimit" #define SESMAN_CFG_SESS_DISC_LIMIT "DisconnectedTimeLimit" #define SESMAN_CFG_SESS_X11DISPLAYOFFSET "X11DisplayOffset" #define SESMAN_CFG_SESS_POLICY_S "Policy" #define SESMAN_CFG_SESS_POLICY_DFLT_S "Default" #define SESMAN_CFG_SESS_POLICY_UBD_S "UBD" #define SESMAN_CFG_SESS_POLICY_UBI_S "UBI" #define SESMAN_CFG_SESS_POLICY_UBC_S "UBC" #define SESMAN_CFG_SESS_POLICY_UBDI_S "UBDI" #define SESMAN_CFG_SESS_POLICY_UBDC_S "UBDC" enum SESMAN_CFG_SESS_POLICY_BITS { SESMAN_CFG_SESS_POLICY_D = 0x01, SESMAN_CFG_SESS_POLICY_I = 0x02, SESMAN_CFG_SESS_POLICY_C = 0x04 }; enum SESMAN_CFG_SESS_POLICY { SESMAN_CFG_SESS_POLICY_DFLT = 0, SESMAN_CFG_SESS_POLICY_UBD = SESMAN_CFG_SESS_POLICY_D, SESMAN_CFG_SESS_POLICY_UBI = SESMAN_CFG_SESS_POLICY_I, SESMAN_CFG_SESS_POLICY_UBC = SESMAN_CFG_SESS_POLICY_C, SESMAN_CFG_SESS_POLICY_UBDI = SESMAN_CFG_SESS_POLICY_D | SESMAN_CFG_SESS_POLICY_I, SESMAN_CFG_SESS_POLICY_UBDC = SESMAN_CFG_SESS_POLICY_D | SESMAN_CFG_SESS_POLICY_C }; /** * * @struct config_security * @brief struct that contains sesman access control configuration * */ struct config_security { /** * @var allow_root * @brief allow root login on TS */ int allow_root; /** * @var login_retry * @brief maximum login attempts */ int login_retry; /** * @var ts_users * @brief Terminal Server Users group */ int ts_users_enable; int ts_users; /** * @var ts_admins * @brief Terminal Server Administrators group */ int ts_admins_enable; int ts_admins; /** * @var ts_always_group_check * @brief if the Groups are not found deny access */ int ts_always_group_check; }; /** * * @struct config_sessions * @brief struct that contains sesman session handling configuration * */ struct config_sessions { /** * @var x11_display_offset * @brief X11 TCP port offset. default value: 10 */ int x11_display_offset; /** * @var max_sessions * @brief maximum number of allowed sessions. 0 for unlimited */ int max_sessions; /** * @var max_idle_time * @brief maximum idle time for each session */ int max_idle_time; /** * @var max_disc_time * @brief maximum disconnected time for each session */ int max_disc_time; /** * @var kill_disconnected * @brief enables automatic killing of disconnected session */ int kill_disconnected; /** * @var policy * @brief session allocation policy */ enum SESMAN_CFG_SESS_POLICY policy; }; /** * * @struct config_sesman * @brief struct that contains sesman configuration * * This struct contains all of sesman configuration parameters\n * Every parameter in [globals] is a member of this struct, other * sections options are embedded in this struct as member structures * */ struct config_sesman { /** * @var listen_address * @brief Listening address */ char listen_address[32]; /** * @var listen_port * @brief Listening port */ char listen_port[16]; /** * @var enable_user_wm * @brief Flag that enables user specific wm */ int enable_user_wm; /** * @var default_wm * @brief Default window manager */ char default_wm[32]; /** * @var user_wm * @brief Default window manager */ char user_wm[32]; /** * @var auth_file_path * @brief Auth file path */ char* auth_file_path; /** * @var vnc_params * @brief Xvnc additional parameter list */ struct list* vnc_params; /** * @var rdp_params * @brief X11rdp additional parameter list */ struct list* rdp_params; /** * @var xorg_params * @brief Xorg additional parameter list */ struct list* xorg_params; /** * @var log * @brief Log configuration struct */ //struct log_config log; /** * @var sec * @brief Security configuration options struct */ struct config_security sec; /** * @var sess * @brief Session configuration options struct */ struct config_sessions sess; struct list* session_variables1; struct list* session_variables2; }; /** * * @brief Reads sesman configuration * @param cfg pointer to configuration object to be replaced * @return 0 on success, 1 on failure * */ int config_read(struct config_sesman* cfg); /** * * @brief Reads sesman [global] configuration section * @param file configuration file descriptor * @param cf pointer to a config struct * @param param_n parameter name list * @param param_v parameter value list * @return 0 on success, 1 on failure * */ int config_read_globals(int file, struct config_sesman* cf, struct list* param_n, struct list* param_v); /** * * @brief Reads sesman [logging] configuration section * @param file configuration file descriptor * @param lc pointer to a log_config struct * @param param_n parameter name list * @param param_v parameter value list * @return 0 on success, 1 on failure * */ int config_read_logging(int file, struct log_config* lc, struct list* param_n, struct list* param_v); /** * * @brief Reads sesman [Security] configuration section * @param file configuration file descriptor * @param sc pointer to a config_security struct * @param param_n parameter name list * @param param_v parameter value list * @return 0 on success, 1 on failure * */ int config_read_security(int file, struct config_security* sc, struct list* param_n, struct list* param_v); /** * * @brief Reads sesman [Sessions] configuration section * @param file configuration file descriptor * @param ss pointer to a config_sessions struct * @param param_n parameter name list * @param param_v parameter value list * @return 0 on success, 1 on failure * */ int config_read_sessions(int file, struct config_sessions* ss, struct list* param_n, struct list* param_v); /** * * @brief Reads sesman [X11rdp] configuration section * @param file configuration file descriptor * @param cs pointer to a config_sesman struct * @param param_n parameter name list * @param param_v parameter value list * @return 0 on success, 1 on failure * */ int config_read_rdp_params(int file, struct config_sesman* cs, struct list* param_n, struct list* param_v); /** * * @brief Reads sesman [XOrg] configuration section * @param file configuration file descriptor * @param cs pointer to a config_sesman struct * @param param_n parameter name list * @param param_v parameter value list * @return 0 on success, 1 on failure * */ int config_read_xorg_params(int file, struct config_sesman* cs, struct list* param_n, struct list* param_v); /** * * @brief Reads sesman [Xvnc] configuration section * @param file configuration file descriptor * @param cs pointer to a config_sesman struct * @param param_n parameter name list * @param param_v parameter value list * @return 0 on success, 1 on failure * */ int config_read_vnc_params(int file, struct config_sesman* cs, struct list* param_n, struct list* param_v); int config_read_session_variables(int file, struct config_sesman *cs, struct list *param_n, struct list *param_v); void config_free(struct config_sesman *cs); #endif xrdp-0.9.5/sesman/env.h000644 001751 001751 00000002656 13174271344 014670 0ustar00metameta000000 000000 /** * xrdp: A Remote Desktop Protocol server. * * Copyright (C) Jay Sorg 2004-2013 * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ /** * * @file env.h * @brief User environment handling code declarations * @author Jay Sorg * */ #ifndef ENV_H #define ENV_H #include "list.h" /** * * @brief Creates vnc password file * @param filename VNC password file name * @param password The password to be encrypted * @return 0 on success, 1 on error * */ int env_check_password_file(const char *filename, const char *password); /** * * @brief Sets user environment ($PATH, $HOME, $UID, and others) * @param username Username * @param passwd_file VNC password file * @param display The session display * @return 0 on success, g_getuser_info() error codes on error * */ int env_set_user(const char *username, char **passwd_file, int display, const struct list *env_names, const struct list *env_values); #endif xrdp-0.9.5/sesman/session.h000644 001751 001751 00000006635 13206023530 015550 0ustar00metameta000000 000000 /** * xrdp: A Remote Desktop Protocol server. * * Copyright (C) Jay Sorg 2004-2013 * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ /** * * @file session.h * @brief Session management definitions * @author Jay Sorg, Simone Fedele * */ #ifndef SESSION_H #define SESSION_H #include "libscp_types.h" #define SESMAN_SESSION_TYPE_XRDP 1 #define SESMAN_SESSION_TYPE_XVNC 2 #define SESMAN_SESSION_TYPE_XORG 3 #define SESMAN_SESSION_STATUS_ACTIVE 0x01 #define SESMAN_SESSION_STATUS_IDLE 0x02 #define SESMAN_SESSION_STATUS_DISCONNECTED 0x04 /* future expansion #define SESMAN_SESSION_STATUS_REMCONTROL 0x08 */ #define SESMAN_SESSION_STATUS_ALL 0xFF #define SESMAN_SESSION_KILL_OK 0 #define SESMAN_SESSION_KILL_NULLITEM 1 #define SESMAN_SESSION_KILL_NOTFOUND 2 struct session_date { tui16 year; tui8 month; tui8 day; tui8 hour; tui8 minute; }; #define zero_time(s) { (s)->year=0; (s)->month=0; (s)->day=0; (s)->hour=0; (s)->minute=0; } struct session_item { char name[256]; int pid; /* pid of sesman waiting for wm to end */ int display; int width; int height; int bpp; long data; /* status info */ unsigned char status; unsigned char type; /* time data */ struct session_date connect_time; struct session_date disconnect_time; struct session_date idle_time; char client_ip[256]; tui8 guid[16]; }; struct session_chain { struct session_chain* next; struct session_item* item; }; /** * * @brief finds a session matching the supplied parameters * @return session data or 0 * */ struct session_item* session_get_bydata(const char *name, int width, int height, int bpp, int type, const char *client_ip); #ifndef session_find_item #define session_find_item(a, b, c, d, e, f) session_get_bydata(a, b, c, d, e, f); #endif /** * * @brief starts a session * @return 0 on error, display number if success * */ int session_start(long data, tui8 type, struct SCP_CONNECTION *c, struct SCP_SESSION *s); int session_reconnect(int display, char* username); /** * * @brief kills a session * @param pid the pid of the session to be killed * @return * */ int session_kill(int pid); /** * * @brief sends sigkill to all sessions * @return * */ void session_sigkill_all(void); /** * * @brief retrieves a session's descriptor * @param pid the session pid * @return a pointer to the session descriptor on success, NULL otherwise * */ struct session_item* session_get_bypid(int pid); /** * * @brief retrieves a session's descriptor * @param pid the session pid * @return a pointer to the session descriptor on success, NULL otherwise * */ struct SCP_DISCONNECTED_SESSION* session_get_byuser(const char *user, int *cnt, unsigned char flags); /** * * @brief delete socket files * @param display number * @return non-zero value (number of errors) if failed */ int cleanup_sockets(int display); #endif xrdp-0.9.5/sesman/access.h000644 001751 001751 00000002320 13174271344 015325 0ustar00metameta000000 000000 /** * xrdp: A Remote Desktop Protocol server. * * Copyright (C) Jay Sorg 2004-2013 * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ /** * * @file access.h * @brief User access control definitions * @author Simone Fedele * */ #ifndef ACCESS_H #define ACCESS_H /** * * @brief Checks if the user is allowed to access the terminal server * @param user the user to check * @return 0 if access is denied, !=0 if allowed * */ int access_login_allowed(const char *user); /** * * @brief Checks if the user is allowed to access the terminal server for management * @param user the user to check * @return 0 if access is denied, !=0 if allowed * */ int access_login_mng_allowed(const char *user); #endif xrdp-0.9.5/sesman/scp_v0.c000644 001751 001751 00000012467 13174271344 015266 0ustar00metameta000000 000000 /** * xrdp: A Remote Desktop Protocol server. * * Copyright (C) Jay Sorg 2004-2015 * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ /** * * @file scp_v0.c * @brief scp version 0 implementation * @author Jay Sorg, Simone Fedele * */ #if defined(HAVE_CONFIG_H) #include #endif #include "sesman.h" extern struct config_sesman *g_cfg; /* in sesman.c */ /******************************************************************************/ void scp_v0_process(struct SCP_CONNECTION *c, struct SCP_SESSION *s) { int display = 0; tbus data; struct session_item *s_item; int errorcode = 0; bool_t do_auth_end = 1; data = auth_userpass(s->username, s->password, &errorcode); if (s->type == SCP_GW_AUTHENTICATION) { /* this is just authentication in a gateway situation */ /* g_writeln("SCP_GW_AUTHENTICATION message received"); */ if (data) { if (1 == access_login_allowed(s->username)) { /* the user is member of the correct groups. */ scp_v0s_replyauthentication(c, errorcode); log_message(LOG_LEVEL_INFO, "Access permitted for user: %s", s->username); /* g_writeln("Connection allowed"); */ } else { scp_v0s_replyauthentication(c, 32 + 3); /* all first 32 are reserved for PAM errors */ log_message(LOG_LEVEL_INFO, "Username okey but group problem for " "user: %s", s->username); /* g_writeln("user password ok, but group problem"); */ } } else { /* g_writeln("username or password error"); */ log_message(LOG_LEVEL_INFO, "Username or password error for user: %s", s->username); scp_v0s_replyauthentication(c, errorcode); } } else if (data) { s_item = session_get_bydata(s->username, s->width, s->height, s->bpp, s->type, s->client_ip); if (s_item != 0) { display = s_item->display; g_memcpy(s->guid, s_item->guid, 16); if (0 != s->client_ip) { log_message( LOG_LEVEL_INFO, "++ reconnected session: username %s, " "display :%d.0, session_pid %d, ip %s", s->username, display, s_item->pid, s->client_ip); } else { log_message(LOG_LEVEL_INFO, "++ reconnected session: username %s, " "display :%d.0, session_pid %d", s->username, display, s_item->pid); } session_reconnect(display, s->username); } else { LOG_DBG("pre auth"); if (1 == access_login_allowed(s->username)) { tui8 guid[16]; g_random((char*)guid, 16); scp_session_set_guid(s, guid); if (0 != s->client_ip) { log_message(LOG_LEVEL_INFO, "++ created session (access granted): " "username %s, ip %s", s->username, s->client_ip); } else { log_message(LOG_LEVEL_INFO, "++ created session (access granted): " "username %s", s->username); } if (SCP_SESSION_TYPE_XVNC == s->type) { log_message( LOG_LEVEL_INFO, "starting Xvnc session..."); display = session_start(data, SESMAN_SESSION_TYPE_XVNC, c, s); } else if (SCP_SESSION_TYPE_XRDP == s->type) { log_message(LOG_LEVEL_INFO, "starting X11rdp session..."); display = session_start(data, SESMAN_SESSION_TYPE_XRDP, c, s); } else if (SCP_SESSION_TYPE_XORG == s->type) { /* type is SCP_SESSION_TYPE_XORG */ log_message(LOG_LEVEL_INFO, "starting Xorg session..."); display = session_start(data, SESMAN_SESSION_TYPE_XORG, c, s); } /* if the session started up ok, auth_end will be called on sig child */ do_auth_end = display == 0; } else { display = 0; } } if (display == 0) { scp_v0s_deny_connection(c); } else { scp_v0s_allow_connection(c, display, s->guid); } } else { scp_v0s_deny_connection(c); } if (do_auth_end) { auth_end(data); } } xrdp-0.9.5/sesman/Doxyfile000644 001751 001751 00000020214 12251743072 015420 0ustar00metameta000000 000000 # Doxyfile 1.4.4 #--------------------------------------------------------------------------- # Project related configuration options #--------------------------------------------------------------------------- PROJECT_NAME = xrdp/sesman PROJECT_NUMBER = 0.2.0 OUTPUT_DIRECTORY = ../docs/sesman CREATE_SUBDIRS = NO OUTPUT_LANGUAGE = English USE_WINDOWS_ENCODING = NO BRIEF_MEMBER_DESC = YES REPEAT_BRIEF = NO ABBREVIATE_BRIEF = ALWAYS_DETAILED_SEC = NO INLINE_INHERITED_MEMB = NO FULL_PATH_NAMES = YES STRIP_FROM_PATH = STRIP_FROM_INC_PATH = SHORT_NAMES = NO JAVADOC_AUTOBRIEF = NO MULTILINE_CPP_IS_BRIEF = NO DETAILS_AT_TOP = NO INHERIT_DOCS = YES DISTRIBUTE_GROUP_DOC = NO SEPARATE_MEMBER_PAGES = NO TAB_SIZE = 8 ALIASES = OPTIMIZE_OUTPUT_FOR_C = YES OPTIMIZE_OUTPUT_JAVA = NO SUBGROUPING = YES #--------------------------------------------------------------------------- # Build related configuration options #--------------------------------------------------------------------------- EXTRACT_ALL = YES EXTRACT_PRIVATE = NO EXTRACT_STATIC = NO EXTRACT_LOCAL_CLASSES = NO EXTRACT_LOCAL_METHODS = NO HIDE_UNDOC_MEMBERS = YES HIDE_UNDOC_CLASSES = YES HIDE_FRIEND_COMPOUNDS = NO HIDE_IN_BODY_DOCS = NO INTERNAL_DOCS = NO CASE_SENSE_NAMES = YES HIDE_SCOPE_NAMES = NO SHOW_INCLUDE_FILES = YES INLINE_INFO = YES SORT_MEMBER_DOCS = YES SORT_BRIEF_DOCS = NO SORT_BY_SCOPE_NAME = NO GENERATE_TODOLIST = YES GENERATE_TESTLIST = YES GENERATE_BUGLIST = YES GENERATE_DEPRECATEDLIST= YES ENABLED_SECTIONS = MAX_INITIALIZER_LINES = 30 SHOW_USED_FILES = YES SHOW_DIRECTORIES = YES FILE_VERSION_FILTER = #--------------------------------------------------------------------------- # configuration options related to warning and progress messages #--------------------------------------------------------------------------- QUIET = NO WARNINGS = YES WARN_IF_UNDOCUMENTED = YES WARN_IF_DOC_ERROR = YES WARN_NO_PARAMDOC = NO WARN_FORMAT = "$file:$line: $text" WARN_LOGFILE = #--------------------------------------------------------------------------- # configuration options related to the input files #--------------------------------------------------------------------------- INPUT = FILE_PATTERNS = RECURSIVE = NO EXCLUDE = EXCLUDE_SYMLINKS = NO EXCLUDE_PATTERNS = EXAMPLE_PATH = EXAMPLE_PATTERNS = EXAMPLE_RECURSIVE = NO IMAGE_PATH = INPUT_FILTER = FILTER_PATTERNS = FILTER_SOURCE_FILES = NO #--------------------------------------------------------------------------- # configuration options related to source browsing #--------------------------------------------------------------------------- SOURCE_BROWSER = YES INLINE_SOURCES = NO STRIP_CODE_COMMENTS = YES REFERENCED_BY_RELATION = YES REFERENCES_RELATION = YES USE_HTAGS = NO VERBATIM_HEADERS = YES #--------------------------------------------------------------------------- # configuration options related to the alphabetical class index #--------------------------------------------------------------------------- ALPHABETICAL_INDEX = YES COLS_IN_ALPHA_INDEX = 5 IGNORE_PREFIX = #--------------------------------------------------------------------------- # configuration options related to the HTML output #--------------------------------------------------------------------------- GENERATE_HTML = YES HTML_OUTPUT = html HTML_FILE_EXTENSION = .html HTML_HEADER = HTML_FOOTER = HTML_STYLESHEET = HTML_ALIGN_MEMBERS = YES GENERATE_HTMLHELP = NO CHM_FILE = HHC_LOCATION = GENERATE_CHI = NO BINARY_TOC = NO TOC_EXPAND = NO DISABLE_INDEX = NO ENUM_VALUES_PER_LINE = 4 GENERATE_TREEVIEW = NO TREEVIEW_WIDTH = 250 #--------------------------------------------------------------------------- # configuration options related to the LaTeX output #--------------------------------------------------------------------------- GENERATE_LATEX = NO LATEX_OUTPUT = latex LATEX_CMD_NAME = latex MAKEINDEX_CMD_NAME = makeindex COMPACT_LATEX = NO PAPER_TYPE = a4wide EXTRA_PACKAGES = LATEX_HEADER = PDF_HYPERLINKS = NO USE_PDFLATEX = NO LATEX_BATCHMODE = NO LATEX_HIDE_INDICES = NO #--------------------------------------------------------------------------- # configuration options related to the RTF output #--------------------------------------------------------------------------- GENERATE_RTF = NO RTF_OUTPUT = rtf COMPACT_RTF = NO RTF_HYPERLINKS = NO RTF_STYLESHEET_FILE = RTF_EXTENSIONS_FILE = #--------------------------------------------------------------------------- # configuration options related to the man page output #--------------------------------------------------------------------------- GENERATE_MAN = NO MAN_OUTPUT = man MAN_EXTENSION = .3 MAN_LINKS = NO #--------------------------------------------------------------------------- # configuration options related to the XML output #--------------------------------------------------------------------------- GENERATE_XML = NO XML_OUTPUT = xml XML_SCHEMA = XML_DTD = XML_PROGRAMLISTING = YES #--------------------------------------------------------------------------- # configuration options for the AutoGen Definitions output #--------------------------------------------------------------------------- GENERATE_AUTOGEN_DEF = NO #--------------------------------------------------------------------------- # configuration options related to the Perl module output #--------------------------------------------------------------------------- GENERATE_PERLMOD = NO PERLMOD_LATEX = NO PERLMOD_PRETTY = YES PERLMOD_MAKEVAR_PREFIX = #--------------------------------------------------------------------------- # Configuration options related to the preprocessor #--------------------------------------------------------------------------- ENABLE_PREPROCESSING = YES MACRO_EXPANSION = NO EXPAND_ONLY_PREDEF = NO SEARCH_INCLUDES = NO INCLUDE_PATH = INCLUDE_FILE_PATTERNS = PREDEFINED = EXPAND_AS_DEFINED = SKIP_FUNCTION_MACROS = NO #--------------------------------------------------------------------------- # Configuration::additions related to external references #--------------------------------------------------------------------------- TAGFILES = GENERATE_TAGFILE = ALLEXTERNALS = NO EXTERNAL_GROUPS = YES PERL_PATH = /usr/bin/perl #--------------------------------------------------------------------------- # Configuration options related to the dot tool #--------------------------------------------------------------------------- CLASS_DIAGRAMS = NO HIDE_UNDOC_RELATIONS = YES HAVE_DOT = NO CLASS_GRAPH = YES COLLABORATION_GRAPH = YES GROUP_GRAPHS = YES UML_LOOK = NO TEMPLATE_RELATIONS = NO INCLUDE_GRAPH = YES INCLUDED_BY_GRAPH = YES CALL_GRAPH = NO GRAPHICAL_HIERARCHY = YES DIRECTORY_GRAPH = YES DOT_IMAGE_FORMAT = png DOT_PATH = DOTFILE_DIRS = MAX_DOT_GRAPH_WIDTH = 1024 MAX_DOT_GRAPH_HEIGHT = 1024 MAX_DOT_GRAPH_DEPTH = 0 DOT_TRANSPARENT = NO DOT_MULTI_TARGETS = NO GENERATE_LEGEND = YES DOT_CLEANUP = YES #--------------------------------------------------------------------------- # Configuration::additions related to the search engine #--------------------------------------------------------------------------- SEARCHENGINE = NO xrdp-0.9.5/sesman/verify_user_pam.c000644 001751 001751 00000017717 13206666623 017302 0ustar00metameta000000 000000 /** * xrdp: A Remote Desktop Protocol server. * * Copyright (C) Jay Sorg 2004-2013 * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ /** * * @file verify_user_pam.c * @brief Authenticate user using pam * @author Jay Sorg * */ #if defined(HAVE_CONFIG_H) #include #endif #include "arch.h" #include "os_calls.h" #include #include struct t_user_pass { char user[256]; char pass[256]; }; struct t_auth_info { struct t_user_pass user_pass; int session_opened; int did_setcred; struct pam_conv pamc; pam_handle_t *ph; }; /******************************************************************************/ static int verify_pam_conv(int num_msg, const struct pam_message **msg, struct pam_response **resp, void *appdata_ptr) { int i; struct pam_response *reply; struct t_user_pass *user_pass; reply = g_new0(struct pam_response, num_msg); for (i = 0; i < num_msg; i++) { switch (msg[i]->msg_style) { case PAM_PROMPT_ECHO_ON: /* username */ user_pass = (struct t_user_pass *) appdata_ptr; reply[i].resp = g_strdup(user_pass->user); reply[i].resp_retcode = PAM_SUCCESS; break; case PAM_PROMPT_ECHO_OFF: /* password */ user_pass = (struct t_user_pass *) appdata_ptr; reply[i].resp = g_strdup(user_pass->pass); reply[i].resp_retcode = PAM_SUCCESS; break; default: g_printf("unknown in verify_pam_conv\r\n"); g_free(reply); return PAM_CONV_ERR; } } *resp = reply; return PAM_SUCCESS; } /******************************************************************************/ static void get_service_name(char *service_name) { service_name[0] = 0; if (g_file_exist("/etc/pam.d/xrdp-sesman") || g_file_exist(XRDP_SYSCONF_PATH "/pam.d/xrdp-sesman")) { g_strncpy(service_name, "xrdp-sesman", 255); } else { g_strncpy(service_name, "gdm", 255); } } /******************************************************************************/ /* returns long, zero is no go Stores the detailed error code in the errorcode variable*/ long auth_userpass(const char *user, const char *pass, int *errorcode) { int error; struct t_auth_info *auth_info; char service_name[256]; get_service_name(service_name); auth_info = g_new0(struct t_auth_info, 1); g_strncpy(auth_info->user_pass.user, user, 255); g_strncpy(auth_info->user_pass.pass, pass, 255); auth_info->pamc.conv = &verify_pam_conv; auth_info->pamc.appdata_ptr = &(auth_info->user_pass); error = pam_start(service_name, 0, &(auth_info->pamc), &(auth_info->ph)); if (error != PAM_SUCCESS) { if (errorcode != NULL) { *errorcode = error; } g_printf("pam_start failed: %s\r\n", pam_strerror(auth_info->ph, error)); pam_end(auth_info->ph, error); g_free(auth_info); return 0; } error = pam_set_item(auth_info->ph, PAM_TTY, service_name); if (error != PAM_SUCCESS) { g_printf("pam_set_item failed: %s\r\n", pam_strerror(auth_info->ph, error)); } error = pam_authenticate(auth_info->ph, 0); if (error != PAM_SUCCESS) { if (errorcode != NULL) { *errorcode = error; } g_printf("pam_authenticate failed: %s\r\n", pam_strerror(auth_info->ph, error)); pam_end(auth_info->ph, error); g_free(auth_info); return 0; } /* From man page: The pam_acct_mgmt function is used to determine if the users account is valid. It checks for authentication token and account expiration and verifies access restrictions. It is typically called after the user has been authenticated. */ error = pam_acct_mgmt(auth_info->ph, 0); if (error != PAM_SUCCESS) { if (errorcode != NULL) { *errorcode = error; } g_printf("pam_acct_mgmt failed: %s\r\n", pam_strerror(auth_info->ph, error)); pam_end(auth_info->ph, error); g_free(auth_info); return 0; } return (long)auth_info; } /******************************************************************************/ /* returns error */ int auth_start_session(long in_val, int in_display) { struct t_auth_info *auth_info; int error; char display[256]; g_sprintf(display, ":%d", in_display); auth_info = (struct t_auth_info *)in_val; error = pam_set_item(auth_info->ph, PAM_TTY, display); if (error != PAM_SUCCESS) { g_printf("pam_set_item failed: %s\r\n", pam_strerror(auth_info->ph, error)); return 1; } error = pam_setcred(auth_info->ph, PAM_ESTABLISH_CRED); if (error != PAM_SUCCESS) { g_printf("pam_setcred failed: %s\r\n", pam_strerror(auth_info->ph, error)); return 1; } auth_info->did_setcred = 1; error = pam_open_session(auth_info->ph, 0); if (error != PAM_SUCCESS) { g_printf("pam_open_session failed: %s\r\n", pam_strerror(auth_info->ph, error)); return 1; } auth_info->session_opened = 1; return 0; } /******************************************************************************/ /* returns error */ int auth_stop_session(long in_val) { struct t_auth_info *auth_info; int error; auth_info = (struct t_auth_info *)in_val; error = pam_close_session(auth_info->ph, 0); if (error != PAM_SUCCESS) { g_printf("pam_close_session failed: %s\r\n", pam_strerror(auth_info->ph, error)); return 1; } auth_info->session_opened = 0; return 0; } /******************************************************************************/ /* returns error */ /* cleanup */ int auth_end(long in_val) { struct t_auth_info *auth_info; auth_info = (struct t_auth_info *)in_val; if (auth_info != 0) { if (auth_info->ph != 0) { if (auth_info->session_opened) { pam_close_session(auth_info->ph, 0); } if (auth_info->did_setcred) { pam_setcred(auth_info->ph, PAM_DELETE_CRED); } pam_end(auth_info->ph, PAM_SUCCESS); auth_info->ph = 0; } } g_free(auth_info); return 0; } /******************************************************************************/ /* returns error */ /* set any pam env vars */ int auth_set_env(long in_val) { struct t_auth_info *auth_info; char **pam_envlist; char **pam_env; char item[256]; char value[256]; int eq_pos; auth_info = (struct t_auth_info *)in_val; if (auth_info != 0) { /* export PAM environment */ pam_envlist = pam_getenvlist(auth_info->ph); if (pam_envlist != NULL) { for (pam_env = pam_envlist; *pam_env != NULL; ++pam_env) { eq_pos = g_pos(*pam_env, "="); if (eq_pos >= 0 && eq_pos < 250) { g_strncpy(item, *pam_env, eq_pos); g_strncpy(value, (*pam_env) + eq_pos + 1, 255); g_setenv(item, value, 1); } g_free(*pam_env); } g_free(pam_envlist); } } return 0; } xrdp-0.9.5/sesman/sig.h000644 001751 001751 00000002322 13174271344 014650 0ustar00metameta000000 000000 /** * xrdp: A Remote Desktop Protocol server. * * Copyright (C) Jay Sorg 2004-2013 * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ /** * * @file sig.h * @brief Signal handling function declarations * @author Jay Sorg, Simone Fedele * */ #ifndef SIG_H #define SIG_H /** * * @brief Shutdown signal code * @param sig The received signal * */ void sig_sesman_shutdown(int sig); /** * * @brief SIGHUP handling code * @param sig The received signal * */ void sig_sesman_reload_cfg(int sig); /** * * @brief SIGCHLD handling code * @param sig The received signal * */ void sig_sesman_session_end(int sig); /** * * @brief signal handling thread * */ void* sig_handler_thread(void* arg); #endif xrdp-0.9.5/sesman/reconnectwm.sh000755 001751 001751 00000000104 13206023530 016560 0ustar00metameta000000 000000 #!/bin/sh # Write procedures here you want to execute on reconnect xrdp-0.9.5/sesman/xauth.c000644 001751 001751 00000003050 13174271344 015211 0ustar00metameta000000 000000 /** * xrdp: A Remote Desktop Protocol server. * * Copyright (C) Emmanuel Blindauer 2016 * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ /** * * @file xauth.c * @brief XAUTHORITY handling code * */ #if defined(HAVE_CONFIG_H) #include #endif #include #include "log.h" #include "os_calls.h" /******************************************************************************/ int add_xauth_cookie(int display, const char *file) { FILE *dp; char cookie_str[33]; char cookie_bin[16]; char xauth_str[256]; int ret; g_random(cookie_bin, 16); g_bytes_to_hexstr(cookie_bin, 16, cookie_str, 33); g_sprintf(xauth_str, "xauth -q -f %s add :%d . %s", file, display, cookie_str); dp = popen(xauth_str, "r"); if (dp == NULL) { log_message(LOG_LEVEL_ERROR, "Unable to launch xauth"); return 1; } ret = pclose(dp); if (ret < 0) { log_message(LOG_LEVEL_ERROR, "An error occurred while running xauth"); return 1; } return 0; } xrdp-0.9.5/sesman/scp.c000644 001751 001751 00000006470 13174271344 014656 0ustar00metameta000000 000000 /** * xrdp: A Remote Desktop Protocol server. * * Copyright (C) Jay Sorg 2004-2015 * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ /** * * @file scp.c * @brief scp (sesman control protocol) common code * scp (sesman control protocol) common code * This code controls which version is being used and starts the * appropriate process * @author Jay Sorg, Simone Fedele * */ #if defined(HAVE_CONFIG_H) #include #endif #include "sesman.h" extern struct config_sesman *g_cfg; /* in sesman.c */ /******************************************************************************/ void * scp_process_start(void *sck) { struct SCP_CONNECTION scon; struct SCP_SESSION *sdata = NULL; scon.in_sck = (int)(tintptr)sck; LOG_DBG("started scp thread on socket %d", scon.in_sck); make_stream(scon.in_s); make_stream(scon.out_s); init_stream(scon.in_s, 8192); init_stream(scon.out_s, 8192); switch (scp_vXs_accept(&scon, &(sdata))) { case SCP_SERVER_STATE_OK: if (sdata->version == 0) { /* starts processing an scp v0 connection */ LOG_DBG("accept ok, go on with scp v0"); scp_v0_process(&scon, sdata); } else { LOG_DBG("accept ok, go on with scp v1"); /*LOG_DBG("user: %s\npass: %s",sdata->username, sdata->password);*/ scp_v1_process(&scon, sdata); } break; case SCP_SERVER_STATE_START_MANAGE: /* starting a management session */ log_message(LOG_LEVEL_WARNING, "starting a sesman management session..."); scp_v1_mng_process(&scon, sdata); break; case SCP_SERVER_STATE_VERSION_ERR: /* an unknown scp version was requested, so we shut down the */ /* connection (and log the fact) */ log_message(LOG_LEVEL_WARNING, "unknown protocol version specified. connection refused."); break; case SCP_SERVER_STATE_NETWORK_ERR: log_message(LOG_LEVEL_WARNING, "libscp network error."); break; case SCP_SERVER_STATE_SEQUENCE_ERR: log_message(LOG_LEVEL_WARNING, "libscp sequence error."); break; case SCP_SERVER_STATE_INTERNAL_ERR: /* internal error occurred (eg. malloc() error, ecc.) */ log_message(LOG_LEVEL_ERROR, "libscp internal error occurred."); break; default: log_message(LOG_LEVEL_ALWAYS, "unknown return from scp_vXs_accept()"); break; } free_stream(scon.in_s); free_stream(scon.out_s); if (sdata) { scp_session_destroy(sdata); } return 0; } xrdp-0.9.5/sesman/scp_v1_mng.h000644 001751 001751 00000002020 13174271344 016115 0ustar00metameta000000 000000 /** * xrdp: A Remote Desktop Protocol server. * * Copyright (C) Jay Sorg 2004-2013 * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ /** * * @file scp_v1.h * @brief scp version 1 declarations - management * @author Simone Fedele * */ #ifndef SCP_V1_MNG_H #define SCP_V1_MNG_H /** * * @brief processes the stream using scp version 1 * @param in_sck connection socket * @param in_s input stream * @param out_s output stream * */ void scp_v1_mng_process(struct SCP_CONNECTION* c, struct SCP_SESSION* s); #endif xrdp-0.9.5/sesman/startwm.sh000755 001751 001751 00000003704 13174271344 015762 0ustar00metameta000000 000000 #!/bin/sh # Execution sequence for interactive login shell - pseudocode # # IF /etc/profile is readable THEN # execute ~/.bash_profile # END IF # IF ~/.bash_profile is readable THEN # execute ~/.bash_profile # ELSE # IF ~/.bash_login is readable THEN # execute ~/.bash_login # ELSE # IF ~/.profile is readable THEN # execute ~/.profile # END IF # END IF # END IF pre_start() { if [ -r /etc/profile ]; then . /etc/profile fi if [ -r ~/.bash_profile ]; then . ~/.bash_profile else if [ -r ~/.bash_login ]; then . ~/.bash_login else if [ -r ~/.profile ]; then . ~/.profile fi fi fi return 0 } # When loging out from the interactive shell, the execution sequence is: # # IF ~/.bash_logout exists THEN # execute ~/.bash_logout # END IF post_start() { if [ -r ~/.bash_logout ]; then . ~/.bash_logout fi return 0 } #start the window manager wm_start() { if [ -r /etc/default/locale ]; then . /etc/default/locale export LANG LANGUAGE fi # debian if [ -r /etc/X11/Xsession ]; then pre_start . /etc/X11/Xsession post_start exit 0 fi # el if [ -r /etc/X11/xinit/Xsession ]; then pre_start . /etc/X11/xinit/Xsession post_start exit 0 fi # suse if [ -r /etc/X11/xdm/Xsession ]; then # since the following script run a user login shell, # do not execute the pseudo login shell scripts . /etc/X11/xdm/Xsession exit 0 fi pre_start xterm post_start } #. /etc/environment #export PATH=$PATH #export LANG=$LANG # change PATH to be what your environment needs usually what is in # /etc/environment #PATH="/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/sbin:/bin:/usr/games" #export PATH=$PATH # for PATH and LANG from /etc/environment # pam will auto process the environment file if /etc/pam.d/xrdp-sesman # includes # auth required pam_env.so readenv=1 wm_start exit 1 xrdp-0.9.5/sesman/sesman.h000644 001751 001751 00000001750 13174271344 015360 0ustar00metameta000000 000000 /** * xrdp: A Remote Desktop Protocol server. * * Copyright (C) Jay Sorg 2004-2013 * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ /** * * @file sesman.h * @brief Main include file * @author Jay Sorg * */ #ifndef SESMAN_H #define SESMAN_H #include "arch.h" #include "parse.h" #include "os_calls.h" #include "log.h" #include "env.h" #include "auth.h" #include "config.h" #include "sig.h" #include "session.h" #include "access.h" #include "scp.h" #include "libscp.h" #endif xrdp-0.9.5/sesman/verify_user_kerberos.c000644 001751 001751 00000024745 13174271344 020334 0ustar00metameta000000 000000 /** * xrdp: A Remote Desktop Protocol server. * * Copyright (C) Jay Sorg 2004-2013 * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ /** * * @file verify_user_kerberos.c * @brief Authenticate user using kerberos * @author Jay Sorg * */ #if defined(HAVE_CONFIG_H) #include #endif #include "arch.h" #include "os_calls.h" #include typedef enum { INIT_PW, INIT_KT, RENEW, VALIDATE } action_type; struct k_opts { /* in seconds */ krb5_deltat starttime; krb5_deltat lifetime; krb5_deltat rlife; int forwardable; int proxiable; int addresses; int not_forwardable; int not_proxiable; int no_addresses; int verbose; char *principal_name; char *service_name; char *keytab_name; char *k5_cache_name; char *k4_cache_name; action_type action; }; struct k5_data { krb5_context ctx; krb5_ccache cc; krb5_principal me; char *name; }; struct user_info { const char *name; const char *pass; }; /******************************************************************************/ /* returns boolean */ static int k5_begin(struct k_opts *opts, struct k5_data *k5, struct user_info *u_info) { krb5_error_code code = 0; code = krb5_init_context(&k5->ctx); if (code != 0) { g_printf("krb5_init_context failed in k5_begin\n"); return 0; } if (opts->k5_cache_name) { code = krb5_cc_resolve(k5->ctx, opts->k5_cache_name, &k5->cc); if (code != 0) { g_printf("krb5_cc_resolve failed in k5_begin\n"); return 0; } } else { code = krb5_cc_default(k5->ctx, &k5->cc); if (code != 0) { g_printf("krb5_cc_default failed in k5_begin\n"); return 0; } } if (opts->principal_name) { /* Use specified name */ code = krb5_parse_name(k5->ctx, opts->principal_name, &k5->me); if (code != 0) { g_printf("krb5_parse_name failed in k5_begin\n"); return 0; } } else { /* No principal name specified */ if (opts->action == INIT_KT) { /* Use the default host/service name */ code = krb5_sname_to_principal(k5->ctx, NULL, NULL, KRB5_NT_SRV_HST, &k5->me); if (code != 0) { g_printf("krb5_sname_to_principal failed in k5_begin\n"); return 0; } } else { /* Get default principal from cache if one exists */ code = krb5_cc_get_principal(k5->ctx, k5->cc, &k5->me); if (code != 0) { code = krb5_parse_name(k5->ctx, u_info->name, &k5->me); if (code != 0) { g_printf("krb5_parse_name failed in k5_begin\n"); return 0; } } } } code = krb5_unparse_name(k5->ctx, k5->me, &k5->name); if (code != 0) { g_printf("krb5_unparse_name failed in k5_begin\n"); return 0; } opts->principal_name = k5->name; return 1; } /******************************************************************************/ static void k5_end(struct k5_data *k5) { if (k5->name) { krb5_free_unparsed_name(k5->ctx, k5->name); } if (k5->me) { krb5_free_principal(k5->ctx, k5->me); } if (k5->cc) { krb5_cc_close(k5->ctx, k5->cc); } if (k5->ctx) { krb5_free_context(k5->ctx); } g_memset(k5, 0, sizeof(struct k5_data)); } /******************************************************************************/ static krb5_error_code KRB5_CALLCONV kinit_prompter(krb5_context ctx, void *data, const char *name, const char *banner, int num_prompts, krb5_prompt prompts[]) { int i; krb5_prompt_type *types; krb5_error_code rc; struct user_info *u_info; u_info = (struct user_info *)data; rc = 0; types = krb5_get_prompt_types(ctx); for (i = 0; i < num_prompts; i++) { if (types[i] == KRB5_PROMPT_TYPE_PASSWORD || types[i] == KRB5_PROMPT_TYPE_NEW_PASSWORD_AGAIN) { g_strncpy(prompts[i].reply->data, u_info->pass, 255); } } return rc; } /******************************************************************************/ /* returns boolean */ static int k5_kinit(struct k_opts *opts, struct k5_data *k5, struct user_info *u_info) { const char *doing; int notix = 1; krb5_keytab keytab = 0; krb5_creds my_creds; krb5_error_code code = 0; krb5_get_init_creds_opt options; krb5_address **addresses; krb5_get_init_creds_opt_init(&options); g_memset(&my_creds, 0, sizeof(my_creds)); /* From this point on, we can goto cleanup because my_creds is initialized. */ if (opts->lifetime) { krb5_get_init_creds_opt_set_tkt_life(&options, opts->lifetime); } if (opts->rlife) { krb5_get_init_creds_opt_set_renew_life(&options, opts->rlife); } if (opts->forwardable) { krb5_get_init_creds_opt_set_forwardable(&options, 1); } if (opts->not_forwardable) { krb5_get_init_creds_opt_set_forwardable(&options, 0); } if (opts->proxiable) { krb5_get_init_creds_opt_set_proxiable(&options, 1); } if (opts->not_proxiable) { krb5_get_init_creds_opt_set_proxiable(&options, 0); } if (opts->addresses) { addresses = NULL; code = krb5_os_localaddr(k5->ctx, &addresses); if (code != 0) { g_printf("krb5_os_localaddr failed in k5_kinit\n"); goto cleanup; } krb5_get_init_creds_opt_set_address_list(&options, addresses); } if (opts->no_addresses) { krb5_get_init_creds_opt_set_address_list(&options, NULL); } if ((opts->action == INIT_KT) && opts->keytab_name) { code = krb5_kt_resolve(k5->ctx, opts->keytab_name, &keytab); if (code != 0) { g_printf("krb5_kt_resolve failed in k5_kinit\n"); goto cleanup; } } switch (opts->action) { case INIT_PW: code = krb5_get_init_creds_password(k5->ctx, &my_creds, k5->me, 0, kinit_prompter, u_info, opts->starttime, opts->service_name, &options); break; case INIT_KT: code = krb5_get_init_creds_keytab(k5->ctx, &my_creds, k5->me, keytab, opts->starttime, opts->service_name, &options); break; case VALIDATE: code = krb5_get_validated_creds(k5->ctx, &my_creds, k5->me, k5->cc, opts->service_name); break; case RENEW: code = krb5_get_renewed_creds(k5->ctx, &my_creds, k5->me, k5->cc, opts->service_name); break; } if (code != 0) { doing = 0; switch (opts->action) { case INIT_PW: case INIT_KT: doing = "getting initial credentials"; break; case VALIDATE: doing = "validating credentials"; break; case RENEW: doing = "renewing credentials"; break; } if (code == KRB5KRB_AP_ERR_BAD_INTEGRITY) { g_printf("sesman: Password incorrect while %s in k5_kinit\n", doing); } else { g_printf("sesman: error while %s in k5_kinit\n", doing); } goto cleanup; } if (!opts->lifetime) { /* We need to figure out what lifetime to use for Kerberos 4. */ opts->lifetime = my_creds.times.endtime - my_creds.times.authtime; } code = krb5_cc_initialize(k5->ctx, k5->cc, k5->me); if (code != 0) { g_printf("krb5_cc_initialize failed in k5_kinit\n"); goto cleanup; } code = krb5_cc_store_cred(k5->ctx, k5->cc, &my_creds); if (code != 0) { g_printf("krb5_cc_store_cred failed in k5_kinit\n"); goto cleanup; } notix = 0; cleanup: if (my_creds.client == k5->me) { my_creds.client = 0; } krb5_free_cred_contents(k5->ctx, &my_creds); if (keytab) { krb5_kt_close(k5->ctx, keytab); } return notix ? 0 : 1; } /******************************************************************************/ /* returns boolean */ int auth_userpass(const char *user, const char *pass, int *errorcode) { struct k_opts opts; struct k5_data k5; struct user_info u_info; int got_k5; int authed_k5; g_memset(&opts, 0, sizeof(opts)); opts.action = INIT_PW; g_memset(&k5, 0, sizeof(k5)); g_memset(&u_info, 0, sizeof(u_info)); u_info.name = user; u_info.pass = pass; authed_k5 = 0; got_k5 = k5_begin(&opts, &k5, &u_info); if (got_k5) { authed_k5 = k5_kinit(&opts, &k5, &u_info); k5_end(&k5); } return authed_k5; } /******************************************************************************/ /* returns error */ int auth_start_session(long in_val, int in_display) { return 0; } /******************************************************************************/ /* returns error */ int auth_stop_session(long in_val) { return 0; } /******************************************************************************/ int auth_end(long in_val) { return 0; } /******************************************************************************/ int auth_set_env(long in_val) { return 0; } xrdp-0.9.5/sesman/verify_user_bsd.c000644 001751 001751 00000004633 13174271344 017262 0ustar00metameta000000 000000 /** * xrdp: A Remote Desktop Protocol server. * * Copyright (C) Jay Sorg 2005-2014 * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ /** * * @file verify_user_bsd.c * @brief Authenticate user using BSD password system * @author Renaud Allard * */ #if defined(HAVE_CONFIG_H) #include #endif #include "sesman.h" #define _XOPEN_SOURCE #include #include #include #include #include #include #include #ifndef SECS_PER_DAY #define SECS_PER_DAY (24L*3600L) #endif extern struct config_sesman* g_cfg; /* in sesman.c */ /******************************************************************************/ /* returns boolean */ long auth_userpass(const char *user, const char *pass, int *errorcode) { int ret = auth_userokay(user, NULL, "auth-xrdp", pass); return ret; } /******************************************************************************/ /* returns error */ int auth_start_session(long in_val, int in_display) { return 0; } /******************************************************************************/ int auth_end(long in_val) { return 0; } /******************************************************************************/ int auth_set_env(long in_val) { return 0; } /******************************************************************************/ int auth_check_pwd_chg(const char *user) { return 0; } int auth_change_pwd(const char *user, const char *newpwd) { return 0; } int auth_stop_session(long in_val) { return 0; } /** * * @brief Password encryption * @param pwd Old password * @param pln Plaintext new password * @param crp Crypted new password * */ static int auth_crypt_pwd(const char *pwd, const char *pln, char *crp) { return 0; } /** * * @return 1 if the account is disabled, 0 otherwise * */ static int auth_account_disabled(struct spwd* stp) { return 0; } xrdp-0.9.5/sesman/verify_user.c000644 001751 001751 00000015251 13174271344 016430 0ustar00metameta000000 000000 /** * xrdp: A Remote Desktop Protocol server. * * Copyright (C) Jay Sorg 2004-2013 * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ /** * * @file verify_user.c * @brief Authenticate user using standard unix passwd/shadow system * @author Jay Sorg, Simone Fedele * */ #if defined(HAVE_CONFIG_H) #include #endif #include "sesman.h" #include #include #include #include #include #include #ifndef SECS_PER_DAY #define SECS_PER_DAY (24L*3600L) #endif extern struct config_sesman *g_cfg; /* in sesman.c */ static int auth_crypt_pwd(const char *pwd, const char *pln, char *crp); static int auth_account_disabled(struct spwd *stp); /******************************************************************************/ /* returns boolean */ long auth_userpass(const char *user, const char *pass, int *errorcode) { const char *encr; const char *epass; struct passwd *spw; struct spwd *stp; spw = getpwnam(user); if (spw == 0) { return 0; } if (g_strncmp(spw->pw_passwd, "x", 3) == 0) { /* the system is using shadow */ stp = getspnam(user); if (stp == 0) { return 0; } if (1 == auth_account_disabled(stp)) { log_message(LOG_LEVEL_INFO, "account %s is disabled", user); return 0; } encr = stp->sp_pwdp; } else { /* old system with only passwd */ encr = spw->pw_passwd; } epass = crypt(pass, encr); if (epass == 0) { return 0; } return (strcmp(encr, epass) == 0); } /******************************************************************************/ /* returns error */ int auth_start_session(long in_val, int in_display) { return 0; } /******************************************************************************/ /* returns error */ int auth_stop_session(long in_val) { return 0; } /******************************************************************************/ int auth_end(long in_val) { return 0; } /******************************************************************************/ int auth_set_env(long in_val) { return 0; } /******************************************************************************/ int auth_check_pwd_chg(const char *user) { struct passwd *spw; struct spwd *stp; int now; long today; spw = getpwnam(user); if (spw == 0) { return AUTH_PWD_CHG_ERROR; } if (g_strncmp(spw->pw_passwd, "x", 3) != 0) { /* old system with only passwd */ return AUTH_PWD_CHG_OK; } /* the system is using shadow */ stp = getspnam(user); if (stp == 0) { return AUTH_PWD_CHG_ERROR; } /* check if we need a pwd change */ now = g_time1(); today = now / SECS_PER_DAY; if (stp->sp_expire == -1) { return AUTH_PWD_CHG_OK; } if (today >= (stp->sp_lstchg + stp->sp_max - stp->sp_warn)) { return AUTH_PWD_CHG_CHANGE; } if (today >= (stp->sp_lstchg + stp->sp_max)) { return AUTH_PWD_CHG_CHANGE_MANDATORY; } if (today < ((stp->sp_lstchg) + (stp->sp_min))) { /* cannot change pwd for now */ return AUTH_PWD_CHG_NOT_NOW; } return AUTH_PWD_CHG_OK; } int auth_change_pwd(const char *user, const char *newpwd) { struct passwd *spw; struct spwd *stp; char hash[35] = ""; long today; FILE *fd; if (0 != lckpwdf()) { return 1; } /* open passwd */ spw = getpwnam(user); if (spw == 0) { return 1; } if (g_strncmp(spw->pw_passwd, "x", 3) != 0) { /* old system with only passwd */ if (auth_crypt_pwd(spw->pw_passwd, newpwd, hash) != 0) { ulckpwdf(); return 1; } spw->pw_passwd = g_strdup(hash); fd = fopen("/etc/passwd", "rw"); putpwent(spw, fd); } else { /* the system is using shadow */ stp = getspnam(user); if (stp == 0) { return 1; } /* old system with only passwd */ if (auth_crypt_pwd(stp->sp_pwdp, newpwd, hash) != 0) { ulckpwdf(); return 1; } stp->sp_pwdp = g_strdup(hash); today = g_time1() / SECS_PER_DAY; stp->sp_lstchg = today; stp->sp_expire = today + stp->sp_max + stp->sp_inact; fd = fopen("/etc/shadow", "rw"); putspent(stp, fd); } ulckpwdf(); return 0; } /** * * @brief Password encryption * @param pwd Old password * @param pln Plaintext new password * @param crp Crypted new password * */ static int auth_crypt_pwd(const char *pwd, const char *pln, char *crp) { char salt[13] = "$1$"; int saltcnt = 0; char *encr; if (g_strncmp(pwd, "$1$", 3) == 0) { /* gnu style crypt(); */ saltcnt = 3; while ((pwd[saltcnt] != '$') && (saltcnt < 11)) { salt[saltcnt] = pwd[saltcnt]; saltcnt++; } salt[saltcnt] = '$'; salt[saltcnt + 1] = '\0'; } else { /* classic two char salt */ salt[0] = pwd[0]; salt[1] = pwd[1]; salt[2] = '\0'; } encr = crypt(pln, salt); g_strncpy(crp, encr, 34); return 0; } /** * * @return 1 if the account is disabled, 0 otherwise * */ static int auth_account_disabled(struct spwd *stp) { int today; if (0 == stp) { /* if an invalid struct was passed we assume a disabled account */ return 1; } today = g_time1() / SECS_PER_DAY; LOG_DBG("last %d", stp->sp_lstchg); LOG_DBG("min %d", stp->sp_min); LOG_DBG("max %d", stp->sp_max); LOG_DBG("inact %d", stp->sp_inact); LOG_DBG("warn %d", stp->sp_warn); LOG_DBG("expire %d", stp->sp_expire); LOG_DBG("today %d", today); if ((stp->sp_expire != -1) && (today >= stp->sp_expire)) { return 1; } if ((stp->sp_max >= 0) && (stp->sp_inact >= 0) && (stp->sp_lstchg > 0) && (today >= (stp->sp_lstchg + stp->sp_max + stp->sp_inact))) { return 1; } return 0; } xrdp-0.9.5/sesman/libscp/libscp_v1c_mng.h000644 001751 001751 00000002667 13133557325 020245 0ustar00metameta000000 000000 /** * xrdp: A Remote Desktop Protocol server. * * Copyright (C) Jay Sorg 2004-2012 * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ /** * * @file libscp_v1c_mng.h * @brief libscp version 1 client api declarations - session management * @author Simone Fedele * */ #ifndef LIBSCP_V1C_MNG_H #define LIBSCP_V1C_MNG_H #include "libscp.h" /* client API */ /* 001 */ enum SCP_CLIENT_STATES_E scp_v1c_mng_connect(struct SCP_CONNECTION* c, struct SCP_SESSION* s); /* 004 * / enum SCP_CLIENT_STATES_E scp_v1c_resend_credentials(struct SCP_CONNECTION* c, struct SCP_SESSION* s); / * 021 * / enum SCP_CLIENT_STATES_E scp_v1c_pwd_change(struct SCP_CONNECTION* c, char* newpass); / * 022 * / enum SCP_CLIENT_STATES_E scp_v1c_pwd_change_cancel(struct SCP_CONNECTION* c); */ /* 041 */ enum SCP_CLIENT_STATES_E scp_v1c_mng_get_session_list(struct SCP_CONNECTION* c, int* scount, struct SCP_DISCONNECTED_SESSION** s); #endif xrdp-0.9.5/sesman/libscp/Makefile.am000644 001751 001751 00000001606 13133557325 017232 0ustar00metameta000000 000000 AM_CPPFLAGS = \ -DXRDP_CFG_PATH=\"${sysconfdir}/xrdp\" \ -DXRDP_SBIN_PATH=\"${sbindir}\" \ -DXRDP_SHARE_PATH=\"${datadir}/xrdp\" \ -DXRDP_PID_PATH=\"${localstatedir}/run\" \ -I$(top_srcdir)/common if XRDP_DEBUG AM_CPPFLAGS += -DXRDP_DEBUG endif module_LTLIBRARIES = \ libscp.la libscp_la_SOURCES = \ libscp.h \ libscp_commands.h \ libscp_commands_mng.h \ libscp_connection.c \ libscp_connection.h \ libscp_init.c \ libscp_init.h \ libscp_lock.c \ libscp_lock.h \ libscp_session.c \ libscp_session.h \ libscp_tcp.c \ libscp_tcp.h \ libscp_types.h \ libscp_types_mng.h \ libscp_v0.c \ libscp_v0.h \ libscp_v1c.c \ libscp_v1c.h \ libscp_v1c_mng.c \ libscp_v1c_mng.h \ libscp_v1s.c \ libscp_v1s.h \ libscp_v1s_mng.c \ libscp_v1s_mng.h \ libscp_vX.c \ libscp_vX.h libscp_la_LIBADD = \ $(top_builddir)/common/libcommon.la \ -lpthread xrdp-0.9.5/sesman/libscp/libscp_vX.h000644 001751 001751 00000002326 13127114621 017267 0ustar00metameta000000 000000 /** * xrdp: A Remote Desktop Protocol server. * * Copyright (C) Jay Sorg 2004-2012 * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ /** * * @file libscp_vX.h * @brief libscp version neutral code header * @author Simone Fedele * */ #ifndef LIBSCP_VX_H #define LIBSCP_VX_H #include "libscp_types.h" #include "libscp_v0.h" #include "libscp_v1s.h" /* server API */ /** * * @brief version neutral server accept function * @param c connection descriptor * @param s session descriptor pointer address. * it will return a newly allocated descriptor. * It this memory needs to be g_free()d * */ enum SCP_SERVER_STATES_E scp_vXs_accept(struct SCP_CONNECTION* c, struct SCP_SESSION** s); #endif xrdp-0.9.5/sesman/libscp/libscp_commands_mng.h000644 001751 001751 00000002125 13125122134 021325 0ustar00metameta000000 000000 /** * xrdp: A Remote Desktop Protocol server. * * Copyright (C) Jay Sorg 2004-2012 * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ /** * * @file libscp_commands_mng.h * @brief libscp data types definitions * @author Simone Fedele * */ #ifndef LIBSCP_COMMANDS_MNG_H #define LIBSCP_COMMANDS_MNG_H #define SCP_CMD_MNG_LOGIN 0x0001 #define SCP_CMD_MNG_LOGIN_ALLOW 0x0002 #define SCP_CMD_MNG_LOGIN_DENY 0x0003 #define SCP_CMD_MNG_CMD_ERROR 0x0004 #define SCP_CMD_MNG_LIST_REQ 0x0005 #define SCP_CMD_MNG_LIST 0x0006 #define SCP_CMD_MNG_ACTION 0x0007 #endif xrdp-0.9.5/sesman/libscp/libscp_session.h000644 001751 001751 00000004531 13165063445 020366 0ustar00metameta000000 000000 /** * xrdp: A Remote Desktop Protocol server. * * Copyright (C) Jay Sorg 2004-2012 * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ /** * * @file libscp_session.h * @brief SCP_SESSION handling code * @author Simone Fedele * */ #ifndef LIBSCP_SESSION_H #define LIBSCP_SESSION_H #include "libscp.h" /** * * @brief creates a new connection * @param sck the connection socket * * @return a struct SCP_SESSION* object on success, NULL otherwise * */ struct SCP_SESSION* scp_session_create(void); int scp_session_set_type(struct SCP_SESSION* s, tui8 type); int scp_session_set_version(struct SCP_SESSION* s, tui32 version); int scp_session_set_height(struct SCP_SESSION* s, tui16 h); int scp_session_set_width(struct SCP_SESSION* s, tui16 w); int scp_session_set_bpp(struct SCP_SESSION* s, tui8 bpp); int scp_session_set_rsr(struct SCP_SESSION* s, tui8 rsr); int scp_session_set_locale(struct SCP_SESSION* s, const char *str); int scp_session_set_username(struct SCP_SESSION* s, const char *str); int scp_session_set_password(struct SCP_SESSION* s, const char *str); int scp_session_set_domain(struct SCP_SESSION* s, const char *str); int scp_session_set_program(struct SCP_SESSION* s, const char *str); int scp_session_set_directory(struct SCP_SESSION* s, const char *str); int scp_session_set_client_ip(struct SCP_SESSION* s, const char *str); int scp_session_set_hostname(struct SCP_SESSION* s, const char *str); int scp_session_set_addr(struct SCP_SESSION* s, int type, const void* addr); int scp_session_set_display(struct SCP_SESSION* s, SCP_DISPLAY display); int scp_session_set_errstr(struct SCP_SESSION* s, const char *str); int scp_session_set_guid(struct SCP_SESSION *s, const tui8 *guid); /** * * @brief destroys a session object * @param s the object to be destroyed * */ void scp_session_destroy(struct SCP_SESSION* s); #endif xrdp-0.9.5/sesman/libscp/libscp_v1s_mng.c000644 001751 001751 00000023264 13206023530 020237 0ustar00metameta000000 000000 /** * xrdp: A Remote Desktop Protocol server. * * Copyright (C) Jay Sorg 2004-2012 * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ /** * * @file libscp_v1s_mng.c * @brief libscp version 1 server api code - session management * @author Simone Fedele * */ #if defined(HAVE_CONFIG_H) #include #endif #ifndef LIBSCP_V1S_MNG_C #define LIBSCP_V1S_MNG_C #include "libscp_v1s_mng.h" //extern struct log_config* s_log; static enum SCP_SERVER_STATES_E _scp_v1s_mng_check_response(struct SCP_CONNECTION *c, struct SCP_SESSION *s); /* server API */ enum SCP_SERVER_STATES_E scp_v1s_mng_accept(struct SCP_CONNECTION *c, struct SCP_SESSION **s) { struct SCP_SESSION *session; tui32 ipaddr; tui16 cmd; tui8 sz; char buf[257]; /* reading command */ in_uint16_be(c->in_s, cmd); if (cmd != 1) /* manager login */ { return SCP_SERVER_STATE_SEQUENCE_ERR; } session = scp_session_create(); if (0 == session) { return SCP_SERVER_STATE_INTERNAL_ERR; } scp_session_set_version(session, 1); scp_session_set_type(session, SCP_SESSION_TYPE_MANAGE); /* reading username */ in_uint8(c->in_s, sz); buf[sz] = '\0'; in_uint8a(c->in_s, buf, sz); if (0 != scp_session_set_username(session, buf)) { scp_session_destroy(session); return SCP_SERVER_STATE_INTERNAL_ERR; } /* reading password */ in_uint8(c->in_s, sz); buf[sz] = '\0'; in_uint8a(c->in_s, buf, sz); if (0 != scp_session_set_password(session, buf)) { scp_session_destroy(session); return SCP_SERVER_STATE_INTERNAL_ERR; } /* reading remote address */ in_uint8(c->in_s, sz); if (sz == SCP_ADDRESS_TYPE_IPV4) { in_uint32_be(c->in_s, ipaddr); scp_session_set_addr(session, sz, &ipaddr); } else if (sz == SCP_ADDRESS_TYPE_IPV6) { in_uint8a(c->in_s, buf, 16); scp_session_set_addr(session, sz, buf); } /* reading hostname */ in_uint8(c->in_s, sz); buf[sz] = '\0'; in_uint8a(c->in_s, buf, sz); if (0 != scp_session_set_hostname(session, buf)) { scp_session_destroy(session); return SCP_SERVER_STATE_INTERNAL_ERR; } /* returning the struct */ (*s) = session; return SCP_SERVER_STATE_START_MANAGE; } /* 002 */ enum SCP_SERVER_STATES_E scp_v1s_mng_allow_connection(struct SCP_CONNECTION *c, struct SCP_SESSION *s) { init_stream(c->out_s, c->out_s->size); out_uint32_be(c->out_s, 1); /* packet size: 4 + 4 + 2 + 2 */ /* version + size + cmdset + cmd */ out_uint32_be(c->out_s, 12); out_uint16_be(c->out_s, SCP_COMMAND_SET_MANAGE); out_uint16_be(c->out_s, SCP_CMD_MNG_LOGIN_ALLOW); if (0 != scp_tcp_force_send(c->in_sck, c->out_s->data, 12)) { return SCP_SERVER_STATE_NETWORK_ERR; } return _scp_v1s_mng_check_response(c, s); } /* 003 */ enum SCP_SERVER_STATES_E scp_v1s_mng_deny_connection(struct SCP_CONNECTION *c, const char *reason) { int rlen; init_stream(c->out_s, c->out_s->size); /* forcing message not to exceed 64k */ rlen = g_strlen(reason); if (rlen > 65535) { rlen = 65535; } out_uint32_be(c->out_s, 1); /* packet size: 4 + 4 + 2 + 2 + 2 + strlen(reason)*/ /* version + size + cmdset + cmd + msglen + msg */ out_uint32_be(c->out_s, rlen + 14); out_uint16_be(c->out_s, SCP_COMMAND_SET_MANAGE); out_uint16_be(c->out_s, SCP_CMD_MNG_LOGIN_DENY); out_uint16_be(c->out_s, rlen); out_uint8p(c->out_s, reason, rlen); if (0 != scp_tcp_force_send(c->in_sck, c->out_s->data, rlen + 14)) { return SCP_SERVER_STATE_NETWORK_ERR; } return SCP_SERVER_STATE_END; } /* 006 */ enum SCP_SERVER_STATES_E scp_v1s_mng_list_sessions(struct SCP_CONNECTION *c, struct SCP_SESSION *s, int sescnt, struct SCP_DISCONNECTED_SESSION *ds) { tui32 version = 1; tui32 size = 12; tui16 cmd = SCP_CMD_MNG_LIST; int pktcnt; int idx; int sidx; int pidx; struct SCP_DISCONNECTED_SESSION *cds; /* calculating the number of packets to send */ if (sescnt == 0) { pktcnt = 1; } else { pktcnt = sescnt / SCP_SERVER_MAX_LIST_SIZE; if ((sescnt % SCP_SERVER_MAX_LIST_SIZE) != 0) { pktcnt++; } } for (idx = 0; idx < pktcnt; idx++) { /* ok, we send session session list */ init_stream(c->out_s, c->out_s->size); /* size: ver+size+cmdset+cmd+sescnt+continue+count */ size = 4 + 4 + 2 + 2 + 4 + 1 + 1; /* header */ s_push_layer(c->out_s, channel_hdr, 8); out_uint16_be(c->out_s, SCP_COMMAND_SET_MANAGE); out_uint16_be(c->out_s, cmd); /* session count */ out_uint32_be(c->out_s, sescnt); /* setting the continue flag */ if ((idx + 1)*SCP_SERVER_MAX_LIST_SIZE >= sescnt) { out_uint8(c->out_s, 0); /* setting session count for this packet */ pidx = sescnt - (idx * SCP_SERVER_MAX_LIST_SIZE); out_uint8(c->out_s, pidx); } else { out_uint8(c->out_s, 1); /* setting session count for this packet */ pidx = SCP_SERVER_MAX_LIST_SIZE; out_uint8(c->out_s, pidx); } /* adding session descriptors */ for (sidx = 0; sidx < pidx; sidx++) { /* shortcut to the current session to send */ cds = ds + ((idx) * SCP_SERVER_MAX_LIST_SIZE) + sidx; /* session data */ out_uint32_be(c->out_s, cds->SID); /* session id */ out_uint8(c->out_s, cds->type); out_uint16_be(c->out_s, cds->height); out_uint16_be(c->out_s, cds->width); out_uint8(c->out_s, cds->bpp); out_uint8(c->out_s, cds->idle_days); out_uint8(c->out_s, cds->idle_hours); out_uint8(c->out_s, cds->idle_minutes); size += 13; out_uint16_be(c->out_s, cds->conn_year); out_uint8(c->out_s, cds->conn_month); out_uint8(c->out_s, cds->conn_day); out_uint8(c->out_s, cds->conn_hour); out_uint8(c->out_s, cds->conn_minute); out_uint8(c->out_s, cds->addr_type); size += 7; if (cds->addr_type == SCP_ADDRESS_TYPE_IPV4) { in_uint32_be(c->out_s, cds->ipv4addr); size += 4; } else if (cds->addr_type == SCP_ADDRESS_TYPE_IPV6) { in_uint8a(c->out_s, cds->ipv6addr, 16); size += 16; } } s_pop_layer(c->out_s, channel_hdr); out_uint32_be(c->out_s, version); out_uint32_be(c->out_s, size); if (0 != scp_tcp_force_send(c->in_sck, c->out_s->data, size)) { log_message(LOG_LEVEL_WARNING, "[v1s_mng:%d] connection aborted: network error", __LINE__); return SCP_SERVER_STATE_NETWORK_ERR; } } return _scp_v1s_mng_check_response(c, s); } static enum SCP_SERVER_STATES_E _scp_v1s_mng_check_response(struct SCP_CONNECTION *c, struct SCP_SESSION *s) { tui32 version; tui32 size; tui16 cmd; // tui8 dim; // char buf[257]; init_stream(c->in_s, c->in_s->size); if (0 != scp_tcp_force_recv(c->in_sck, c->in_s->data, 8)) { log_message(LOG_LEVEL_WARNING, "[v1s_mng:%d] connection aborted: network error", __LINE__); return SCP_SERVER_STATE_NETWORK_ERR; } in_uint32_be(c->in_s, version); if (version != 1) { log_message(LOG_LEVEL_WARNING, "[v1s_mng:%d] connection aborted: version error", __LINE__); return SCP_SERVER_STATE_VERSION_ERR; } in_uint32_be(c->in_s, size); init_stream(c->in_s, c->in_s->size); /* read the rest of the packet */ if (0 != scp_tcp_force_recv(c->in_sck, c->in_s->data, size - 8)) { log_message(LOG_LEVEL_WARNING, "[v1s_mng:%d] connection aborted: network error", __LINE__); return SCP_SERVER_STATE_NETWORK_ERR; } in_uint16_be(c->in_s, cmd); if (cmd != SCP_COMMAND_SET_MANAGE) { log_message(LOG_LEVEL_WARNING, "[v1s_mng:%d] connection aborted: sequence error", __LINE__); return SCP_SERVER_STATE_SEQUENCE_ERR; } in_uint16_be(c->in_s, cmd); if (cmd == SCP_CMD_MNG_LIST_REQ) /* request session list */ { log_message(LOG_LEVEL_INFO, "[v1s_mng:%d] request session list", __LINE__); return SCP_SERVER_STATE_MNG_LISTREQ; } else if (cmd == SCP_CMD_MNG_ACTION) /* execute an action */ { /*in_uint8(c->in_s, dim); buf[dim]='\0'; in_uint8a(c->in_s, buf, dim); scp_session_set_errstr(s, buf);*/ log_message(LOG_LEVEL_INFO, "[v1s_mng:%d] action request", __LINE__); return SCP_SERVER_STATE_MNG_ACTION; } /* else if (cmd == 20) / * password change * / { in_uint16_be(c->in_s, s->display); return SCP_SERVER_STATE_OK; } else if (cmd == 40) / * session list * / { return SCP_SERVER_STATE_SESSION_LIST; }*/ log_message(LOG_LEVEL_WARNING, "[v1s_mng:%d] connection aborted: sequence error", __LINE__); return SCP_SERVER_STATE_SEQUENCE_ERR; } #endif xrdp-0.9.5/sesman/libscp/libscp_init.h000644 001751 001751 00000002137 13174271344 017645 0ustar00metameta000000 000000 /** * xrdp: A Remote Desktop Protocol server. * * Copyright (C) Jay Sorg 2004-2012 * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ /** * * @file libscp_init.h * @brief libscp initialization code header * @author Simone Fedele * */ #ifndef LIBSCP_INIT_H #define LIBSCP_INIT_H #include "log.h" #include "libscp.h" /** * * @brief version neutral server accept function * @param c connection descriptor * @param s session descriptor pointer address. * it will return a newly allocated descriptor. * It this memory needs to be g_free()d * */ int scp_init(void); #endif xrdp-0.9.5/sesman/libscp/libscp_v0.h000644 001751 001751 00000004034 13133557325 017226 0ustar00metameta000000 000000 /** * xrdp: A Remote Desktop Protocol server. * * Copyright (C) Jay Sorg 2004-2012 * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ /** * * @file libscp_v0.h * @brief libscp version 0 declarations * @author Simone Fedele * */ #ifndef LIBSCP_V0_H #define LIBSCP_V0_H #include "libscp.h" /* client API */ /** * * @brief connects to sesman using scp v0 * @param c connection descriptor * @param s session descriptor * @param d display * */ enum SCP_CLIENT_STATES_E scp_v0c_connect(struct SCP_CONNECTION* c, struct SCP_SESSION* s); /* server API */ /** * * @brief processes the stream using scp version 0 * @param c connection descriptor * @param s session descriptor * @param skipVchk if set to !0 skips the version control (to be used after * scp_vXs_accept() ) * */ enum SCP_SERVER_STATES_E scp_v0s_accept(struct SCP_CONNECTION* c, struct SCP_SESSION** s, int skipVchk); /** * * @brief allows the connection to TS, returning the display port * @param c connection descriptor * */ enum SCP_SERVER_STATES_E scp_v0s_allow_connection(struct SCP_CONNECTION* c, SCP_DISPLAY d, const tui8 *guid); /** * * @brief denies the connection to TS * @param c connection descriptor * */ enum SCP_SERVER_STATES_E scp_v0s_deny_connection(struct SCP_CONNECTION* c); /** * @brief send reply to an authentication request * @param c connection descriptor * @param value the reply code 0 means ok * @return */ enum SCP_SERVER_STATES_E scp_v0s_replyauthentication(struct SCP_CONNECTION* c, unsigned short int value); #endif xrdp-0.9.5/sesman/libscp/libscp_v1c.h000644 001751 001751 00000003164 13125122134 017360 0ustar00metameta000000 000000 /** * xrdp: A Remote Desktop Protocol server. * * Copyright (C) Jay Sorg 2004-2012 * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ /** * * @file libscp_v1c.h * @brief libscp version 1 client api declarations * @author Simone Fedele * */ #ifndef LIBSCP_V1C_H #define LIBSCP_V1C_H #include "libscp.h" /* client API */ /* 001 */ enum SCP_CLIENT_STATES_E scp_v1c_connect(struct SCP_CONNECTION* c, struct SCP_SESSION* s); /* 004 */ enum SCP_CLIENT_STATES_E scp_v1c_resend_credentials(struct SCP_CONNECTION* c, struct SCP_SESSION* s); /* 021 */ enum SCP_CLIENT_STATES_E scp_v1c_pwd_change(struct SCP_CONNECTION* c, char* newpass); /* 022 */ enum SCP_CLIENT_STATES_E scp_v1c_pwd_change_cancel(struct SCP_CONNECTION* c); /* 041 */ enum SCP_CLIENT_STATES_E scp_v1c_get_session_list(struct SCP_CONNECTION* c, int* scount, struct SCP_DISCONNECTED_SESSION** s); /* 043 */ enum SCP_CLIENT_STATES_E scp_v1c_select_session(struct SCP_CONNECTION* c, struct SCP_SESSION* s, SCP_SID sid); /* 044 */ enum SCP_CLIENT_STATES_E scp_v1c_select_session_cancel(struct SCP_CONNECTION* c); #endif xrdp-0.9.5/sesman/libscp/Makefile.in000644 001751 001751 00000054456 13220730775 017255 0ustar00metameta000000 000000 # Makefile.in generated by automake 1.15.1 from Makefile.am. # @configure_input@ # Copyright (C) 1994-2017 Free Software Foundation, Inc. # This Makefile.in is free software; the Free Software Foundation # gives unlimited permission to copy and/or distribute it, # with or without modifications, as long as this notice is preserved. # This program is distributed in the hope that it will be useful, # but WITHOUT ANY WARRANTY, to the extent permitted by law; without # even the implied warranty of MERCHANTABILITY or FITNESS FOR A # PARTICULAR PURPOSE. @SET_MAKE@ VPATH = @srcdir@ am__is_gnu_make = { \ if test -z '$(MAKELEVEL)'; then \ false; \ elif test -n '$(MAKE_HOST)'; then \ true; \ elif test -n '$(MAKE_VERSION)' && test -n '$(CURDIR)'; then \ true; \ else \ false; \ fi; \ } am__make_running_with_option = \ case $${target_option-} in \ ?) ;; \ *) echo "am__make_running_with_option: internal error: invalid" \ "target option '$${target_option-}' specified" >&2; \ exit 1;; \ esac; \ has_opt=no; \ sane_makeflags=$$MAKEFLAGS; \ if $(am__is_gnu_make); then \ sane_makeflags=$$MFLAGS; \ else \ case $$MAKEFLAGS in \ *\\[\ \ ]*) \ bs=\\; \ sane_makeflags=`printf '%s\n' "$$MAKEFLAGS" \ | sed "s/$$bs$$bs[$$bs $$bs ]*//g"`;; \ esac; \ fi; \ skip_next=no; \ strip_trailopt () \ { \ flg=`printf '%s\n' "$$flg" | sed "s/$$1.*$$//"`; \ }; \ for flg in $$sane_makeflags; do \ test $$skip_next = yes && { skip_next=no; continue; }; \ case $$flg in \ *=*|--*) continue;; \ -*I) strip_trailopt 'I'; skip_next=yes;; \ -*I?*) strip_trailopt 'I';; \ -*O) strip_trailopt 'O'; skip_next=yes;; \ -*O?*) strip_trailopt 'O';; \ -*l) strip_trailopt 'l'; skip_next=yes;; \ -*l?*) strip_trailopt 'l';; \ -[dEDm]) skip_next=yes;; \ -[JT]) skip_next=yes;; \ esac; \ case $$flg in \ *$$target_option*) has_opt=yes; break;; \ esac; \ done; \ test $$has_opt = yes am__make_dryrun = (target_option=n; $(am__make_running_with_option)) am__make_keepgoing = (target_option=k; $(am__make_running_with_option)) pkgdatadir = $(datadir)/@PACKAGE@ pkgincludedir = $(includedir)/@PACKAGE@ pkglibdir = $(libdir)/@PACKAGE@ pkglibexecdir = $(libexecdir)/@PACKAGE@ am__cd = CDPATH="$${ZSH_VERSION+.}$(PATH_SEPARATOR)" && cd install_sh_DATA = $(install_sh) -c -m 644 install_sh_PROGRAM = $(install_sh) -c install_sh_SCRIPT = $(install_sh) -c INSTALL_HEADER = $(INSTALL_DATA) transform = $(program_transform_name) NORMAL_INSTALL = : PRE_INSTALL = : POST_INSTALL = : NORMAL_UNINSTALL = : PRE_UNINSTALL = : POST_UNINSTALL = : build_triplet = @build@ host_triplet = @host@ @XRDP_DEBUG_TRUE@am__append_1 = -DXRDP_DEBUG subdir = sesman/libscp ACLOCAL_M4 = $(top_srcdir)/aclocal.m4 am__aclocal_m4_deps = $(top_srcdir)/m4/ax_append_compile_flags.m4 \ $(top_srcdir)/m4/ax_append_flag.m4 \ $(top_srcdir)/m4/ax_cflags_warn_all.m4 \ $(top_srcdir)/m4/ax_check_compile_flag.m4 \ $(top_srcdir)/m4/ax_gcc_func_attribute.m4 \ $(top_srcdir)/m4/ax_require_defined.m4 \ $(top_srcdir)/m4/ax_type_socklen_t.m4 \ $(top_srcdir)/m4/libtool.m4 $(top_srcdir)/m4/ltoptions.m4 \ $(top_srcdir)/m4/ltsugar.m4 $(top_srcdir)/m4/ltversion.m4 \ $(top_srcdir)/m4/lt~obsolete.m4 $(top_srcdir)/m4/pkg.m4 \ $(top_srcdir)/configure.ac am__configure_deps = $(am__aclocal_m4_deps) $(CONFIGURE_DEPENDENCIES) \ $(ACLOCAL_M4) DIST_COMMON = $(srcdir)/Makefile.am $(am__DIST_COMMON) mkinstalldirs = $(install_sh) -d CONFIG_HEADER = $(top_builddir)/config_ac.h CONFIG_CLEAN_FILES = CONFIG_CLEAN_VPATH_FILES = am__vpath_adj_setup = srcdirstrip=`echo "$(srcdir)" | sed 's|.|.|g'`; am__vpath_adj = case $$p in \ $(srcdir)/*) f=`echo "$$p" | sed "s|^$$srcdirstrip/||"`;; \ *) f=$$p;; \ esac; am__strip_dir = f=`echo $$p | sed -e 's|^.*/||'`; am__install_max = 40 am__nobase_strip_setup = \ srcdirstrip=`echo "$(srcdir)" | sed 's/[].[^$$\\*|]/\\\\&/g'` am__nobase_strip = \ for p in $$list; do echo "$$p"; done | sed -e "s|$$srcdirstrip/||" am__nobase_list = $(am__nobase_strip_setup); \ for p in $$list; do echo "$$p $$p"; done | \ sed "s| $$srcdirstrip/| |;"' / .*\//!s/ .*/ ./; s,\( .*\)/[^/]*$$,\1,' | \ $(AWK) 'BEGIN { files["."] = "" } { files[$$2] = files[$$2] " " $$1; \ if (++n[$$2] == $(am__install_max)) \ { print $$2, files[$$2]; n[$$2] = 0; files[$$2] = "" } } \ END { for (dir in files) print dir, files[dir] }' am__base_list = \ sed '$$!N;$$!N;$$!N;$$!N;$$!N;$$!N;$$!N;s/\n/ /g' | \ sed '$$!N;$$!N;$$!N;$$!N;s/\n/ /g' am__uninstall_files_from_dir = { \ test -z "$$files" \ || { test ! -d "$$dir" && test ! -f "$$dir" && test ! -r "$$dir"; } \ || { echo " ( cd '$$dir' && rm -f" $$files ")"; \ $(am__cd) "$$dir" && rm -f $$files; }; \ } am__installdirs = "$(DESTDIR)$(moduledir)" LTLIBRARIES = $(module_LTLIBRARIES) libscp_la_DEPENDENCIES = $(top_builddir)/common/libcommon.la am_libscp_la_OBJECTS = libscp_connection.lo libscp_init.lo \ libscp_lock.lo libscp_session.lo libscp_tcp.lo libscp_v0.lo \ libscp_v1c.lo libscp_v1c_mng.lo libscp_v1s.lo \ libscp_v1s_mng.lo libscp_vX.lo libscp_la_OBJECTS = $(am_libscp_la_OBJECTS) AM_V_lt = $(am__v_lt_@AM_V@) am__v_lt_ = $(am__v_lt_@AM_DEFAULT_V@) am__v_lt_0 = --silent am__v_lt_1 = AM_V_P = $(am__v_P_@AM_V@) am__v_P_ = $(am__v_P_@AM_DEFAULT_V@) am__v_P_0 = false am__v_P_1 = : AM_V_GEN = $(am__v_GEN_@AM_V@) am__v_GEN_ = $(am__v_GEN_@AM_DEFAULT_V@) am__v_GEN_0 = @echo " GEN " $@; am__v_GEN_1 = AM_V_at = $(am__v_at_@AM_V@) am__v_at_ = $(am__v_at_@AM_DEFAULT_V@) am__v_at_0 = @ am__v_at_1 = DEFAULT_INCLUDES = -I.@am__isrc@ -I$(top_builddir) depcomp = $(SHELL) $(top_srcdir)/depcomp am__depfiles_maybe = depfiles am__mv = mv -f COMPILE = $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) \ $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) LTCOMPILE = $(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) \ $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) \ $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) \ $(AM_CFLAGS) $(CFLAGS) AM_V_CC = $(am__v_CC_@AM_V@) am__v_CC_ = $(am__v_CC_@AM_DEFAULT_V@) am__v_CC_0 = @echo " CC " $@; am__v_CC_1 = CCLD = $(CC) LINK = $(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) \ $(LIBTOOLFLAGS) --mode=link $(CCLD) $(AM_CFLAGS) $(CFLAGS) \ $(AM_LDFLAGS) $(LDFLAGS) -o $@ AM_V_CCLD = $(am__v_CCLD_@AM_V@) am__v_CCLD_ = $(am__v_CCLD_@AM_DEFAULT_V@) am__v_CCLD_0 = @echo " CCLD " $@; am__v_CCLD_1 = SOURCES = $(libscp_la_SOURCES) DIST_SOURCES = $(libscp_la_SOURCES) am__can_run_installinfo = \ case $$AM_UPDATE_INFO_DIR in \ n|no|NO) false;; \ *) (install-info --version) >/dev/null 2>&1;; \ esac am__tagged_files = $(HEADERS) $(SOURCES) $(TAGS_FILES) $(LISP) # Read a list of newline-separated strings from the standard input, # and print each of them once, without duplicates. Input order is # *not* preserved. am__uniquify_input = $(AWK) '\ BEGIN { nonempty = 0; } \ { items[$$0] = 1; nonempty = 1; } \ END { if (nonempty) { for (i in items) print i; }; } \ ' # Make sure the list of sources is unique. This is necessary because, # e.g., the same source file might be shared among _SOURCES variables # for different programs/libraries. am__define_uniq_tagged_files = \ list='$(am__tagged_files)'; \ unique=`for i in $$list; do \ if test -f "$$i"; then echo $$i; else echo $(srcdir)/$$i; fi; \ done | $(am__uniquify_input)` ETAGS = etags CTAGS = ctags am__DIST_COMMON = $(srcdir)/Makefile.in $(top_srcdir)/depcomp DISTFILES = $(DIST_COMMON) $(DIST_SOURCES) $(TEXINFOS) $(EXTRA_DIST) ACLOCAL = @ACLOCAL@ AMTAR = @AMTAR@ AM_DEFAULT_VERBOSITY = @AM_DEFAULT_VERBOSITY@ AR = @AR@ AUTOCONF = @AUTOCONF@ AUTOHEADER = @AUTOHEADER@ AUTOMAKE = @AUTOMAKE@ AWK = @AWK@ CC = @CC@ CCDEPMODE = @CCDEPMODE@ CFLAGS = @CFLAGS@ CPP = @CPP@ CPPFLAGS = @CPPFLAGS@ CYGPATH_W = @CYGPATH_W@ DEFS = @DEFS@ DEPDIR = @DEPDIR@ DLLTOOL = @DLLTOOL@ DLOPEN_LIBS = @DLOPEN_LIBS@ DSYMUTIL = @DSYMUTIL@ DUMPBIN = @DUMPBIN@ ECHO_C = @ECHO_C@ ECHO_N = @ECHO_N@ ECHO_T = @ECHO_T@ EGREP = @EGREP@ EXEEXT = @EXEEXT@ FDKAAC_CFLAGS = @FDKAAC_CFLAGS@ FDKAAC_LIBS = @FDKAAC_LIBS@ FGREP = @FGREP@ FREERDP_CFLAGS = @FREERDP_CFLAGS@ FREERDP_LIBS = @FREERDP_LIBS@ FUSE_CFLAGS = @FUSE_CFLAGS@ FUSE_LIBS = @FUSE_LIBS@ GREP = @GREP@ INSTALL = @INSTALL@ INSTALL_DATA = @INSTALL_DATA@ INSTALL_PROGRAM = @INSTALL_PROGRAM@ INSTALL_SCRIPT = @INSTALL_SCRIPT@ INSTALL_STRIP_PROGRAM = @INSTALL_STRIP_PROGRAM@ LD = @LD@ LDFLAGS = @LDFLAGS@ LIBOBJS = @LIBOBJS@ LIBS = @LIBS@ LIBTOOL = @LIBTOOL@ LIPO = @LIPO@ LN_S = @LN_S@ LTLIBOBJS = @LTLIBOBJS@ LT_SYS_LIBRARY_PATH = @LT_SYS_LIBRARY_PATH@ MAKEINFO = @MAKEINFO@ MANIFEST_TOOL = @MANIFEST_TOOL@ MKDIR_P = @MKDIR_P@ NM = @NM@ NMEDIT = @NMEDIT@ OBJDUMP = @OBJDUMP@ OBJEXT = @OBJEXT@ OPENSSL = @OPENSSL@ OPENSSL_CFLAGS = @OPENSSL_CFLAGS@ OPENSSL_LIBS = @OPENSSL_LIBS@ OTOOL = @OTOOL@ OTOOL64 = @OTOOL64@ PACKAGE = @PACKAGE@ PACKAGE_BUGREPORT = @PACKAGE_BUGREPORT@ PACKAGE_NAME = @PACKAGE_NAME@ PACKAGE_STRING = @PACKAGE_STRING@ PACKAGE_TARNAME = @PACKAGE_TARNAME@ PACKAGE_URL = @PACKAGE_URL@ PACKAGE_VERSION = @PACKAGE_VERSION@ PAM_RULES = @PAM_RULES@ PATH_SEPARATOR = @PATH_SEPARATOR@ PIXMAN_CFLAGS = @PIXMAN_CFLAGS@ PIXMAN_LIBS = @PIXMAN_LIBS@ PKG_CONFIG = @PKG_CONFIG@ PKG_CONFIG_LIBDIR = @PKG_CONFIG_LIBDIR@ PKG_CONFIG_PATH = @PKG_CONFIG_PATH@ RANLIB = @RANLIB@ SED = @SED@ SET_MAKE = @SET_MAKE@ SHELL = @SHELL@ STRIP = @STRIP@ TurboJpegIncDir = @TurboJpegIncDir@ TurboJpegLibDir = @TurboJpegLibDir@ VERSION = @VERSION@ XMKMF = @XMKMF@ X_CFLAGS = @X_CFLAGS@ X_EXTRA_LIBS = @X_EXTRA_LIBS@ X_LIBS = @X_LIBS@ X_PRE_LIBS = @X_PRE_LIBS@ abs_builddir = @abs_builddir@ abs_srcdir = @abs_srcdir@ abs_top_builddir = @abs_top_builddir@ abs_top_srcdir = @abs_top_srcdir@ ac_ct_AR = @ac_ct_AR@ ac_ct_CC = @ac_ct_CC@ ac_ct_DUMPBIN = @ac_ct_DUMPBIN@ am__include = @am__include@ am__leading_dot = @am__leading_dot@ am__quote = @am__quote@ am__tar = @am__tar@ am__untar = @am__untar@ bindir = @bindir@ build = @build@ build_alias = @build_alias@ build_cpu = @build_cpu@ build_os = @build_os@ build_vendor = @build_vendor@ builddir = @builddir@ datadir = @datadir@ datarootdir = @datarootdir@ docdir = @docdir@ dvidir = @dvidir@ exec_prefix = @exec_prefix@ host = @host@ host_alias = @host_alias@ host_cpu = @host_cpu@ host_os = @host_os@ host_vendor = @host_vendor@ htmldir = @htmldir@ includedir = @includedir@ infodir = @infodir@ install_sh = @install_sh@ libdir = @libdir@ libexecdir = @libexecdir@ localedir = @localedir@ localstatedir = @localstatedir@ mandir = @mandir@ mkdir_p = @mkdir_p@ moduledir = @moduledir@ oldincludedir = @oldincludedir@ pdfdir = @pdfdir@ pkgconfigdir = @pkgconfigdir@ prefix = @prefix@ program_transform_name = @program_transform_name@ psdir = @psdir@ sbindir = @sbindir@ sharedstatedir = @sharedstatedir@ socketdir = @socketdir@ srcdir = @srcdir@ subdirs = @subdirs@ sysconfdir = @sysconfdir@ systemdsystemunitdir = @systemdsystemunitdir@ target_alias = @target_alias@ top_build_prefix = @top_build_prefix@ top_builddir = @top_builddir@ top_srcdir = @top_srcdir@ AM_CPPFLAGS = -DXRDP_CFG_PATH=\"${sysconfdir}/xrdp\" \ -DXRDP_SBIN_PATH=\"${sbindir}\" \ -DXRDP_SHARE_PATH=\"${datadir}/xrdp\" \ -DXRDP_PID_PATH=\"${localstatedir}/run\" \ -I$(top_srcdir)/common $(am__append_1) module_LTLIBRARIES = \ libscp.la libscp_la_SOURCES = \ libscp.h \ libscp_commands.h \ libscp_commands_mng.h \ libscp_connection.c \ libscp_connection.h \ libscp_init.c \ libscp_init.h \ libscp_lock.c \ libscp_lock.h \ libscp_session.c \ libscp_session.h \ libscp_tcp.c \ libscp_tcp.h \ libscp_types.h \ libscp_types_mng.h \ libscp_v0.c \ libscp_v0.h \ libscp_v1c.c \ libscp_v1c.h \ libscp_v1c_mng.c \ libscp_v1c_mng.h \ libscp_v1s.c \ libscp_v1s.h \ libscp_v1s_mng.c \ libscp_v1s_mng.h \ libscp_vX.c \ libscp_vX.h libscp_la_LIBADD = \ $(top_builddir)/common/libcommon.la \ -lpthread all: all-am .SUFFIXES: .SUFFIXES: .c .lo .o .obj $(srcdir)/Makefile.in: $(srcdir)/Makefile.am $(am__configure_deps) @for dep in $?; do \ case '$(am__configure_deps)' in \ *$$dep*) \ ( cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh ) \ && { if test -f $@; then exit 0; else break; fi; }; \ exit 1;; \ esac; \ done; \ echo ' cd $(top_srcdir) && $(AUTOMAKE) --foreign sesman/libscp/Makefile'; \ $(am__cd) $(top_srcdir) && \ $(AUTOMAKE) --foreign sesman/libscp/Makefile Makefile: $(srcdir)/Makefile.in $(top_builddir)/config.status @case '$?' in \ *config.status*) \ cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh;; \ *) \ echo ' cd $(top_builddir) && $(SHELL) ./config.status $(subdir)/$@ $(am__depfiles_maybe)'; \ cd $(top_builddir) && $(SHELL) ./config.status $(subdir)/$@ $(am__depfiles_maybe);; \ esac; $(top_builddir)/config.status: $(top_srcdir)/configure $(CONFIG_STATUS_DEPENDENCIES) cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh $(top_srcdir)/configure: $(am__configure_deps) cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh $(ACLOCAL_M4): $(am__aclocal_m4_deps) cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh $(am__aclocal_m4_deps): install-moduleLTLIBRARIES: $(module_LTLIBRARIES) @$(NORMAL_INSTALL) @list='$(module_LTLIBRARIES)'; test -n "$(moduledir)" || list=; \ list2=; for p in $$list; do \ if test -f $$p; then \ list2="$$list2 $$p"; \ else :; fi; \ done; \ test -z "$$list2" || { \ echo " $(MKDIR_P) '$(DESTDIR)$(moduledir)'"; \ $(MKDIR_P) "$(DESTDIR)$(moduledir)" || exit 1; \ echo " $(LIBTOOL) $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=install $(INSTALL) $(INSTALL_STRIP_FLAG) $$list2 '$(DESTDIR)$(moduledir)'"; \ $(LIBTOOL) $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=install $(INSTALL) $(INSTALL_STRIP_FLAG) $$list2 "$(DESTDIR)$(moduledir)"; \ } uninstall-moduleLTLIBRARIES: @$(NORMAL_UNINSTALL) @list='$(module_LTLIBRARIES)'; test -n "$(moduledir)" || list=; \ for p in $$list; do \ $(am__strip_dir) \ echo " $(LIBTOOL) $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=uninstall rm -f '$(DESTDIR)$(moduledir)/$$f'"; \ $(LIBTOOL) $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=uninstall rm -f "$(DESTDIR)$(moduledir)/$$f"; \ done clean-moduleLTLIBRARIES: -test -z "$(module_LTLIBRARIES)" || rm -f $(module_LTLIBRARIES) @list='$(module_LTLIBRARIES)'; \ locs=`for p in $$list; do echo $$p; done | \ sed 's|^[^/]*$$|.|; s|/[^/]*$$||; s|$$|/so_locations|' | \ sort -u`; \ test -z "$$locs" || { \ echo rm -f $${locs}; \ rm -f $${locs}; \ } libscp.la: $(libscp_la_OBJECTS) $(libscp_la_DEPENDENCIES) $(EXTRA_libscp_la_DEPENDENCIES) $(AM_V_CCLD)$(LINK) -rpath $(moduledir) $(libscp_la_OBJECTS) $(libscp_la_LIBADD) $(LIBS) mostlyclean-compile: -rm -f *.$(OBJEXT) distclean-compile: -rm -f *.tab.c @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/libscp_connection.Plo@am__quote@ @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/libscp_init.Plo@am__quote@ @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/libscp_lock.Plo@am__quote@ @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/libscp_session.Plo@am__quote@ @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/libscp_tcp.Plo@am__quote@ @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/libscp_v0.Plo@am__quote@ @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/libscp_v1c.Plo@am__quote@ @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/libscp_v1c_mng.Plo@am__quote@ @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/libscp_v1s.Plo@am__quote@ @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/libscp_v1s_mng.Plo@am__quote@ @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/libscp_vX.Plo@am__quote@ .c.o: @am__fastdepCC_TRUE@ $(AM_V_CC)$(COMPILE) -MT $@ -MD -MP -MF $(DEPDIR)/$*.Tpo -c -o $@ $< @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) $(DEPDIR)/$*.Tpo $(DEPDIR)/$*.Po @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='$<' object='$@' libtool=no @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(COMPILE) -c -o $@ $< .c.obj: @am__fastdepCC_TRUE@ $(AM_V_CC)$(COMPILE) -MT $@ -MD -MP -MF $(DEPDIR)/$*.Tpo -c -o $@ `$(CYGPATH_W) '$<'` @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) $(DEPDIR)/$*.Tpo $(DEPDIR)/$*.Po @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='$<' object='$@' libtool=no @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(COMPILE) -c -o $@ `$(CYGPATH_W) '$<'` .c.lo: @am__fastdepCC_TRUE@ $(AM_V_CC)$(LTCOMPILE) -MT $@ -MD -MP -MF $(DEPDIR)/$*.Tpo -c -o $@ $< @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) $(DEPDIR)/$*.Tpo $(DEPDIR)/$*.Plo @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='$<' object='$@' libtool=yes @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(LTCOMPILE) -c -o $@ $< mostlyclean-libtool: -rm -f *.lo clean-libtool: -rm -rf .libs _libs ID: $(am__tagged_files) $(am__define_uniq_tagged_files); mkid -fID $$unique tags: tags-am TAGS: tags tags-am: $(TAGS_DEPENDENCIES) $(am__tagged_files) set x; \ here=`pwd`; \ $(am__define_uniq_tagged_files); \ shift; \ if test -z "$(ETAGS_ARGS)$$*$$unique"; then :; else \ test -n "$$unique" || unique=$$empty_fix; \ if test $$# -gt 0; then \ $(ETAGS) $(ETAGSFLAGS) $(AM_ETAGSFLAGS) $(ETAGS_ARGS) \ "$$@" $$unique; \ else \ $(ETAGS) $(ETAGSFLAGS) $(AM_ETAGSFLAGS) $(ETAGS_ARGS) \ $$unique; \ fi; \ fi ctags: ctags-am CTAGS: ctags ctags-am: $(TAGS_DEPENDENCIES) $(am__tagged_files) $(am__define_uniq_tagged_files); \ test -z "$(CTAGS_ARGS)$$unique" \ || $(CTAGS) $(CTAGSFLAGS) $(AM_CTAGSFLAGS) $(CTAGS_ARGS) \ $$unique GTAGS: here=`$(am__cd) $(top_builddir) && pwd` \ && $(am__cd) $(top_srcdir) \ && gtags -i $(GTAGS_ARGS) "$$here" cscopelist: cscopelist-am cscopelist-am: $(am__tagged_files) list='$(am__tagged_files)'; \ case "$(srcdir)" in \ [\\/]* | ?:[\\/]*) sdir="$(srcdir)" ;; \ *) sdir=$(subdir)/$(srcdir) ;; \ esac; \ for i in $$list; do \ if test -f "$$i"; then \ echo "$(subdir)/$$i"; \ else \ echo "$$sdir/$$i"; \ fi; \ done >> $(top_builddir)/cscope.files distclean-tags: -rm -f TAGS ID GTAGS GRTAGS GSYMS GPATH tags distdir: $(DISTFILES) @srcdirstrip=`echo "$(srcdir)" | sed 's/[].[^$$\\*]/\\\\&/g'`; \ topsrcdirstrip=`echo "$(top_srcdir)" | sed 's/[].[^$$\\*]/\\\\&/g'`; \ list='$(DISTFILES)'; \ dist_files=`for file in $$list; do echo $$file; done | \ sed -e "s|^$$srcdirstrip/||;t" \ -e "s|^$$topsrcdirstrip/|$(top_builddir)/|;t"`; \ case $$dist_files in \ */*) $(MKDIR_P) `echo "$$dist_files" | \ sed '/\//!d;s|^|$(distdir)/|;s,/[^/]*$$,,' | \ sort -u` ;; \ esac; \ for file in $$dist_files; do \ if test -f $$file || test -d $$file; then d=.; else d=$(srcdir); fi; \ if test -d $$d/$$file; then \ dir=`echo "/$$file" | sed -e 's,/[^/]*$$,,'`; \ if test -d "$(distdir)/$$file"; then \ find "$(distdir)/$$file" -type d ! -perm -700 -exec chmod u+rwx {} \;; \ fi; \ if test -d $(srcdir)/$$file && test $$d != $(srcdir); then \ cp -fpR $(srcdir)/$$file "$(distdir)$$dir" || exit 1; \ find "$(distdir)/$$file" -type d ! -perm -700 -exec chmod u+rwx {} \;; \ fi; \ cp -fpR $$d/$$file "$(distdir)$$dir" || exit 1; \ else \ test -f "$(distdir)/$$file" \ || cp -p $$d/$$file "$(distdir)/$$file" \ || exit 1; \ fi; \ done check-am: all-am check: check-am all-am: Makefile $(LTLIBRARIES) installdirs: for dir in "$(DESTDIR)$(moduledir)"; do \ test -z "$$dir" || $(MKDIR_P) "$$dir"; \ done install: install-am install-exec: install-exec-am install-data: install-data-am uninstall: uninstall-am install-am: all-am @$(MAKE) $(AM_MAKEFLAGS) install-exec-am install-data-am installcheck: installcheck-am install-strip: if test -z '$(STRIP)'; then \ $(MAKE) $(AM_MAKEFLAGS) INSTALL_PROGRAM="$(INSTALL_STRIP_PROGRAM)" \ install_sh_PROGRAM="$(INSTALL_STRIP_PROGRAM)" INSTALL_STRIP_FLAG=-s \ install; \ else \ $(MAKE) $(AM_MAKEFLAGS) INSTALL_PROGRAM="$(INSTALL_STRIP_PROGRAM)" \ install_sh_PROGRAM="$(INSTALL_STRIP_PROGRAM)" INSTALL_STRIP_FLAG=-s \ "INSTALL_PROGRAM_ENV=STRIPPROG='$(STRIP)'" install; \ fi mostlyclean-generic: clean-generic: distclean-generic: -test -z "$(CONFIG_CLEAN_FILES)" || rm -f $(CONFIG_CLEAN_FILES) -test . = "$(srcdir)" || test -z "$(CONFIG_CLEAN_VPATH_FILES)" || rm -f $(CONFIG_CLEAN_VPATH_FILES) maintainer-clean-generic: @echo "This command is intended for maintainers to use" @echo "it deletes files that may require special tools to rebuild." clean: clean-am clean-am: clean-generic clean-libtool clean-moduleLTLIBRARIES \ mostlyclean-am distclean: distclean-am -rm -rf ./$(DEPDIR) -rm -f Makefile distclean-am: clean-am distclean-compile distclean-generic \ distclean-tags dvi: dvi-am dvi-am: html: html-am html-am: info: info-am info-am: install-data-am: install-moduleLTLIBRARIES install-dvi: install-dvi-am install-dvi-am: install-exec-am: install-html: install-html-am install-html-am: install-info: install-info-am install-info-am: install-man: install-pdf: install-pdf-am install-pdf-am: install-ps: install-ps-am install-ps-am: installcheck-am: maintainer-clean: maintainer-clean-am -rm -rf ./$(DEPDIR) -rm -f Makefile maintainer-clean-am: distclean-am maintainer-clean-generic mostlyclean: mostlyclean-am mostlyclean-am: mostlyclean-compile mostlyclean-generic \ mostlyclean-libtool pdf: pdf-am pdf-am: ps: ps-am ps-am: uninstall-am: uninstall-moduleLTLIBRARIES .MAKE: install-am install-strip .PHONY: CTAGS GTAGS TAGS all all-am check check-am clean clean-generic \ clean-libtool clean-moduleLTLIBRARIES cscopelist-am ctags \ ctags-am distclean distclean-compile distclean-generic \ distclean-libtool distclean-tags distdir dvi dvi-am html \ html-am info info-am install install-am install-data \ install-data-am install-dvi install-dvi-am install-exec \ install-exec-am install-html install-html-am install-info \ install-info-am install-man install-moduleLTLIBRARIES \ install-pdf install-pdf-am install-ps install-ps-am \ install-strip installcheck installcheck-am installdirs \ maintainer-clean maintainer-clean-generic mostlyclean \ mostlyclean-compile mostlyclean-generic mostlyclean-libtool \ pdf pdf-am ps ps-am tags tags-am uninstall uninstall-am \ uninstall-moduleLTLIBRARIES .PRECIOUS: Makefile # Tell versions [3.59,3.63) of GNU make to not export all variables. # Otherwise a system limit (for SysV at least) may be exceeded. .NOEXPORT: xrdp-0.9.5/sesman/libscp/libscp_types_mng.h000644 001751 001751 00000002015 13125122134 020666 0ustar00metameta000000 000000 /** * xrdp: A Remote Desktop Protocol server. * * Copyright (C) Jay Sorg 2004-2012 * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ /** * * @file libscp_types_mng.h * @brief libscp data types definitions * @author Simone Fedele * */ #ifndef LIBSCP_TYPES_MNG_H #define LIBSCP_TYPES_MNG_H #include "os_calls.h" #include "parse.h" #include "arch.h" #include "log.h" enum SCP_MNG_COMMAND { SCP_MNG_CMD_KILL, SCP_MNG_CMD_DISCONNECT }; struct SCP_MNG_DATA { enum SCP_MNG_COMMAND cmd; SCP_SID sid; }; #endif xrdp-0.9.5/sesman/libscp/libscp_connection.c000644 001751 001751 00000002675 13174271344 021043 0ustar00metameta000000 000000 /** * xrdp: A Remote Desktop Protocol server. * * Copyright (C) Jay Sorg 2004-2012 * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ /** * * @file libscp_connection.c * @brief SCP_CONNECTION handling code * @author Simone Fedele * */ #if defined(HAVE_CONFIG_H) #include #endif #include "libscp_connection.h" //extern struct log_config* s_log; struct SCP_CONNECTION * scp_connection_create(int sck) { struct SCP_CONNECTION *conn; conn = g_new(struct SCP_CONNECTION, 1); if (0 == conn) { log_message(LOG_LEVEL_ERROR, "[connection:%d] connection create: malloc error", __LINE__); return 0; } conn->in_sck = sck; make_stream(conn->in_s); init_stream(conn->in_s, 8196); make_stream(conn->out_s); init_stream(conn->out_s, 8196); return conn; } void scp_connection_destroy(struct SCP_CONNECTION *c) { free_stream(c->in_s); free_stream(c->out_s); g_free(c); } xrdp-0.9.5/sesman/libscp/libscp_v1s.c000644 001751 001751 00000050211 13174271344 017402 0ustar00metameta000000 000000 /** * xrdp: A Remote Desktop Protocol server. * * Copyright (C) Jay Sorg 2004-2012 * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ /** * * @file libscp_v1s.c * @brief libscp version 1 server api code * @author Simone Fedele * */ #if defined(HAVE_CONFIG_H) #include #endif #ifndef LIBSCP_V1S_C #define LIBSCP_V1S_C #include "libscp_v1s.h" //extern struct log_config* s_log; /* server API */ enum SCP_SERVER_STATES_E scp_v1s_accept(struct SCP_CONNECTION *c, struct SCP_SESSION **s, int skipVchk) { struct SCP_SESSION *session; tui32 version; tui32 size; tui16 cmdset; tui16 cmd; tui8 sz; char buf[257]; if (!skipVchk) { if (0 == scp_tcp_force_recv(c->in_sck, c->in_s->data, 8)) { in_uint32_be(c->in_s, version); if (version != 1) { log_message(LOG_LEVEL_WARNING, "[v1s:%d] connection aborted: version error", __LINE__); return SCP_SERVER_STATE_VERSION_ERR; } } else { log_message(LOG_LEVEL_WARNING, "[v1s:%d] connection aborted: network error", __LINE__); return SCP_SERVER_STATE_NETWORK_ERR; } } in_uint32_be(c->in_s, size); if (size < 12) { log_message(LOG_LEVEL_WARNING, "[v1s:%d] connection aborted: size error", __LINE__); return SCP_SERVER_STATE_SIZE_ERR; } init_stream(c->in_s, c->in_s->size); if (0 != scp_tcp_force_recv(c->in_sck, c->in_s->data, (size - 8))) { log_message(LOG_LEVEL_WARNING, "[v1s:%d] connection aborted: network error", __LINE__); return SCP_SERVER_STATE_NETWORK_ERR; } /* reading command set */ in_uint16_be(c->in_s, cmdset); /* if we are starting a management session */ if (cmdset == SCP_COMMAND_SET_MANAGE) { log_message(LOG_LEVEL_DEBUG, "[v1s:%d] requested management connection", __LINE__); /* should return SCP_SERVER_STATE_START_MANAGE */ return scp_v1s_mng_accept(c, s); } /* if we started with resource sharing... */ if (cmdset == SCP_COMMAND_SET_RSR) { log_message(LOG_LEVEL_WARNING, "[v1s:%d] connection aborted: sequence error", __LINE__); return SCP_SERVER_STATE_SEQUENCE_ERR; } /* reading command */ in_uint16_be(c->in_s, cmd); if (cmd != 1) { log_message(LOG_LEVEL_WARNING, "[v1s:%d] connection aborted: sequence error", __LINE__); return SCP_SERVER_STATE_SEQUENCE_ERR; } session = scp_session_create(); if (0 == session) { log_message(LOG_LEVEL_WARNING, "[v1s:%d] connection aborted: internal error (malloc returned NULL)", __LINE__); return SCP_SERVER_STATE_INTERNAL_ERR; } scp_session_set_version(session, 1); in_uint8(c->in_s, sz); if ((sz != SCP_SESSION_TYPE_XVNC) && (sz != SCP_SESSION_TYPE_XRDP)) { scp_session_destroy(session); log_message(LOG_LEVEL_WARNING, "[v1s:%d] connection aborted: unknown session type", __LINE__); return SCP_SERVER_STATE_SESSION_TYPE_ERR; } scp_session_set_type(session, sz); in_uint16_be(c->in_s, cmd); scp_session_set_height(session, cmd); in_uint16_be(c->in_s, cmd); scp_session_set_height(session, cmd); in_uint8(c->in_s, sz); if (0 != scp_session_set_bpp(session, sz)) { scp_session_destroy(session); log_message(LOG_LEVEL_WARNING, "[v1s:%d] connection aborted: unsupported bpp: %d", __LINE__, sz); return SCP_SERVER_STATE_INTERNAL_ERR; } in_uint8(c->in_s, sz); scp_session_set_rsr(session, sz); in_uint8a(c->in_s, buf, 17); buf[17] = '\0'; scp_session_set_locale(session, buf); in_uint8(c->in_s, sz); if (sz == SCP_ADDRESS_TYPE_IPV4) { in_uint32_be(c->in_s, size); scp_session_set_addr(session, sz, &size); } else if (sz == SCP_ADDRESS_TYPE_IPV6) { in_uint8a(c->in_s, buf, 16); scp_session_set_addr(session, sz, buf); } buf[256] = '\0'; /* reading hostname */ in_uint8(c->in_s, sz); buf[sz] = '\0'; in_uint8a(c->in_s, buf, sz); if (0 != scp_session_set_hostname(session, buf)) { scp_session_destroy(session); log_message(LOG_LEVEL_WARNING, "[v1s:%d] connection aborted: internal error", __LINE__); return SCP_SERVER_STATE_INTERNAL_ERR; } /* reading username */ in_uint8(c->in_s, sz); buf[sz] = '\0'; in_uint8a(c->in_s, buf, sz); if (0 != scp_session_set_username(session, buf)) { scp_session_destroy(session); log_message(LOG_LEVEL_WARNING, "[v1s:%d] connection aborted: internal error", __LINE__); return SCP_SERVER_STATE_INTERNAL_ERR; } /* reading password */ in_uint8(c->in_s, sz); buf[sz] = '\0'; in_uint8a(c->in_s, buf, sz); if (0 != scp_session_set_password(session, buf)) { scp_session_destroy(session); log_message(LOG_LEVEL_WARNING, "[v1s:%d] connection aborted: internal error", __LINE__); return SCP_SERVER_STATE_INTERNAL_ERR; } /* returning the struct */ (*s) = session; return SCP_SERVER_STATE_OK; } enum SCP_SERVER_STATES_E scp_v1s_deny_connection(struct SCP_CONNECTION *c, const char *reason) { int rlen; init_stream(c->out_s, c->out_s->size); /* forcing message not to exceed 64k */ rlen = g_strlen(reason); if (rlen > 65535) { rlen = 65535; } out_uint32_be(c->out_s, 1); /* packet size: 4 + 4 + 2 + 2 + 2 + strlen(reason)*/ /* version + size + cmdset + cmd + msglen + msg */ out_uint32_be(c->out_s, rlen + 14); out_uint16_be(c->out_s, SCP_COMMAND_SET_DEFAULT); out_uint16_be(c->out_s, 2); out_uint16_be(c->out_s, rlen); out_uint8p(c->out_s, reason, rlen); if (0 != scp_tcp_force_send(c->in_sck, c->out_s->data, rlen + 14)) { log_message(LOG_LEVEL_WARNING, "[v1s:%d] connection aborted: network error", __LINE__); return SCP_SERVER_STATE_NETWORK_ERR; } return SCP_SERVER_STATE_END; } enum SCP_SERVER_STATES_E scp_v1s_request_password(struct SCP_CONNECTION *c, struct SCP_SESSION *s, const char *reason) { tui8 sz; tui32 version; tui32 size; tui16 cmdset; tui16 cmd; int rlen; char buf[257]; init_stream(c->in_s, c->in_s->size); init_stream(c->out_s, c->out_s->size); /* forcing message not to exceed 64k */ rlen = g_strlen(reason); if (rlen > 65535) { rlen = 65535; } /* send password request */ version = 1; cmd = 3; out_uint32_be(c->out_s, version); /* version */ out_uint32_be(c->out_s, 14 + rlen); /* size */ out_uint16_be(c->out_s, SCP_COMMAND_SET_DEFAULT); /* cmdset */ out_uint16_be(c->out_s, cmd); /* cmd */ out_uint16_be(c->out_s, rlen); out_uint8p(c->out_s, reason, rlen); if (0 != scp_tcp_force_send(c->in_sck, c->out_s->data, 14 + rlen)) { log_message(LOG_LEVEL_WARNING, "[v1s:%d] connection aborted: network error", __LINE__); return SCP_SERVER_STATE_NETWORK_ERR; } /* receive password & username */ if (0 != scp_tcp_force_recv(c->in_sck, c->in_s->data, 8)) { log_message(LOG_LEVEL_WARNING, "[v1s:%d] connection aborted: network error", __LINE__); return SCP_SERVER_STATE_NETWORK_ERR; } in_uint32_be(c->in_s, version); if (version != 1) { log_message(LOG_LEVEL_WARNING, "[v1s:%d] connection aborted: version error", __LINE__); return SCP_SERVER_STATE_VERSION_ERR; } in_uint32_be(c->in_s, size); if (size < 12) { log_message(LOG_LEVEL_WARNING, "[v1s:%d] connection aborted: size error", __LINE__); return SCP_SERVER_STATE_SIZE_ERR; } init_stream(c->in_s, c->in_s->size); if (0 != scp_tcp_force_recv(c->in_sck, c->in_s->data, (size - 8))) { log_message(LOG_LEVEL_WARNING, "[v1s:%d] connection aborted: network error", __LINE__); return SCP_SERVER_STATE_NETWORK_ERR; } in_uint16_be(c->in_s, cmdset); if (cmdset != SCP_COMMAND_SET_DEFAULT) { log_message(LOG_LEVEL_WARNING, "[v1s:%d] connection aborted: sequence error", __LINE__); return SCP_SERVER_STATE_SEQUENCE_ERR; } in_uint16_be(c->in_s, cmd); if (cmd != 4) { log_message(LOG_LEVEL_WARNING, "[v1s:%d] connection aborted: sequence error", __LINE__); return SCP_SERVER_STATE_SEQUENCE_ERR; } buf[256] = '\0'; /* reading username */ in_uint8(c->in_s, sz); buf[sz] = '\0'; in_uint8a(c->in_s, buf, sz); if (0 != scp_session_set_username(s, buf)) { log_message(LOG_LEVEL_WARNING, "[v1s:%d] connection aborted: internal error", __LINE__); return SCP_SERVER_STATE_INTERNAL_ERR; } /* reading password */ in_uint8(c->in_s, sz); buf[sz] = '\0'; in_uint8a(c->in_s, buf, sz); if (0 != scp_session_set_password(s, buf)) { log_message(LOG_LEVEL_WARNING, "[v1s:%d] connection aborted: internal error", __LINE__); return SCP_SERVER_STATE_INTERNAL_ERR; } return SCP_SERVER_STATE_OK; } /* 020 */ enum SCP_SERVER_STATES_E scp_v1s_request_pwd_change(struct SCP_CONNECTION *c, char *reason, char *npw) { return SCP_SERVER_STATE_INTERNAL_ERR; } /* 023 */ enum SCP_SERVER_STATES_E scp_v1s_pwd_change_error(struct SCP_CONNECTION *c, char *error, int retry, char *npw) { return SCP_SERVER_STATE_INTERNAL_ERR; } /* 030 */ enum SCP_SERVER_STATES_E scp_v1s_connect_new_session(struct SCP_CONNECTION *c, SCP_DISPLAY d) { /* send password request */ tui32 version = 1; tui32 size = 14; tui16 cmd = 30; init_stream(c->out_s, c->out_s->size); out_uint32_be(c->out_s, version); /* version */ out_uint32_be(c->out_s, size); /* size */ out_uint16_be(c->out_s, SCP_COMMAND_SET_DEFAULT); /* cmdset */ out_uint16_be(c->out_s, cmd); /* cmd */ out_uint16_be(c->out_s, d); /* display */ if (0 != scp_tcp_force_send(c->in_sck, c->out_s->data, 14)) { log_message(LOG_LEVEL_WARNING, "[v1s:%d] connection aborted: network error", __LINE__); return SCP_SERVER_STATE_NETWORK_ERR; } return SCP_SERVER_STATE_OK; } /* 032 */ enum SCP_SERVER_STATES_E scp_v1s_connection_error(struct SCP_CONNECTION *c, const char *error) { tui16 len; len = g_strlen(error); init_stream(c->out_s, c->out_s->size); out_uint32_be(c->out_s, 1); /* packet size: 4 + 4 + 2 + 2 + len */ /* version + size + cmdset + cmd */ out_uint32_be(c->out_s, (12 + len)); out_uint16_be(c->out_s, SCP_COMMAND_SET_DEFAULT); out_uint16_be(c->out_s, SCP_CMD_CONN_ERROR); if (0 != scp_tcp_force_send(c->in_sck, c->out_s->data, (12 + len))) { return SCP_SERVER_STATE_NETWORK_ERR; } return SCP_SERVER_STATE_END; } /* 040 */ enum SCP_SERVER_STATES_E scp_v1s_list_sessions(struct SCP_CONNECTION *c, int sescnt, struct SCP_DISCONNECTED_SESSION *ds, SCP_SID *sid) { tui32 version = 1; tui32 size = 12; tui16 cmd = 40; int pktcnt; int idx; int sidx; int pidx; struct SCP_DISCONNECTED_SESSION *cds; /* first we send a notice that we have some disconnected sessions */ init_stream(c->out_s, c->out_s->size); out_uint32_be(c->out_s, version); /* version */ out_uint32_be(c->out_s, size); /* size */ out_uint16_be(c->out_s, SCP_COMMAND_SET_DEFAULT); /* cmdset */ out_uint16_be(c->out_s, cmd); /* cmd */ if (0 != scp_tcp_force_send(c->in_sck, c->out_s->data, size)) { log_message(LOG_LEVEL_WARNING, "[v1s:%d] connection aborted: network error", __LINE__); return SCP_SERVER_STATE_NETWORK_ERR; } /* then we wait for client ack */ /* * Maybe this message could say if the session should be resized on * server side or client side. */ init_stream(c->in_s, c->in_s->size); if (0 != scp_tcp_force_recv(c->in_sck, c->in_s->data, 8)) { log_message(LOG_LEVEL_WARNING, "[v1s:%d] connection aborted: network error", __LINE__); return SCP_SERVER_STATE_NETWORK_ERR; } in_uint32_be(c->in_s, version); if (version != 1) { log_message(LOG_LEVEL_WARNING, "[v1s:%d] connection aborted: version error", __LINE__); return SCP_SERVER_STATE_VERSION_ERR; } in_uint32_be(c->in_s, size); if (size < 12) { log_message(LOG_LEVEL_WARNING, "[v1s:%d] connection aborted: size error", __LINE__); return SCP_SERVER_STATE_SIZE_ERR; } init_stream(c->in_s, c->in_s->size); if (0 != scp_tcp_force_recv(c->in_sck, c->in_s->data, (size - 8))) { log_message(LOG_LEVEL_WARNING, "[v1s:%d] connection aborted: network error", __LINE__); return SCP_SERVER_STATE_NETWORK_ERR; } in_uint16_be(c->in_s, cmd); if (cmd != SCP_COMMAND_SET_DEFAULT) { log_message(LOG_LEVEL_WARNING, "[v1s:%d] connection aborted: sequence error", __LINE__); return SCP_SERVER_STATE_SEQUENCE_ERR; } in_uint16_be(c->in_s, cmd); if (cmd != 41) { log_message(LOG_LEVEL_WARNING, "[v1s:%d] connection aborted: sequence error", __LINE__); return SCP_SERVER_STATE_SEQUENCE_ERR; } /* calculating the number of packets to send */ pktcnt = sescnt / SCP_SERVER_MAX_LIST_SIZE; if ((sescnt % SCP_SERVER_MAX_LIST_SIZE) != 0) { pktcnt++; } for (idx = 0; idx < pktcnt; idx++) { /* ok, we send session session list */ init_stream(c->out_s, c->out_s->size); /* size: ver+size+cmdset+cmd+sescnt+continue+count */ size = 4 + 4 + 2 + 2 + 4 + 1 + 1; /* header */ cmd = 42; s_push_layer(c->out_s, channel_hdr, 8); out_uint16_be(c->out_s, SCP_COMMAND_SET_DEFAULT); out_uint16_be(c->out_s, cmd); /* session count */ out_uint32_be(c->out_s, sescnt); /* setting the continue flag */ if ((idx + 1)*SCP_SERVER_MAX_LIST_SIZE >= sescnt) { out_uint8(c->out_s, 0); /* setting session count for this packet */ pidx = sescnt - (idx * SCP_SERVER_MAX_LIST_SIZE); out_uint8(c->out_s, pidx); } else { out_uint8(c->out_s, 1); /* setting session count for this packet */ pidx = SCP_SERVER_MAX_LIST_SIZE; out_uint8(c->out_s, pidx); } /* adding session descriptors */ for (sidx = 0; sidx < pidx; sidx++) { /* shortcut to the current session to send */ cds = ds + ((idx) * SCP_SERVER_MAX_LIST_SIZE) + sidx; /* session data */ out_uint32_be(c->out_s, cds->SID); /* session id */ out_uint8(c->out_s, cds->type); out_uint16_be(c->out_s, cds->height); out_uint16_be(c->out_s, cds->width); out_uint8(c->out_s, cds->bpp); out_uint8(c->out_s, cds->idle_days); out_uint8(c->out_s, cds->idle_hours); out_uint8(c->out_s, cds->idle_minutes); size += 13; out_uint16_be(c->out_s, cds->conn_year); out_uint8(c->out_s, cds->conn_month); out_uint8(c->out_s, cds->conn_day); out_uint8(c->out_s, cds->conn_hour); out_uint8(c->out_s, cds->conn_minute); out_uint8(c->out_s, cds->addr_type); size += 7; if (cds->addr_type == SCP_ADDRESS_TYPE_IPV4) { in_uint32_be(c->out_s, cds->ipv4addr); size += 4; } else if (cds->addr_type == SCP_ADDRESS_TYPE_IPV6) { in_uint8a(c->out_s, cds->ipv6addr, 16); size += 16; } } s_pop_layer(c->out_s, channel_hdr); out_uint32_be(c->out_s, version); out_uint32_be(c->out_s, size); if (0 != scp_tcp_force_send(c->in_sck, c->out_s->data, size)) { log_message(LOG_LEVEL_WARNING, "[v1s:%d] connection aborted: network error", __LINE__); return SCP_SERVER_STATE_NETWORK_ERR; } } /* we get the response */ init_stream(c->in_s, c->in_s->size); if (0 != scp_tcp_force_recv(c->in_sck, c->in_s->data, (8))) { log_message(LOG_LEVEL_WARNING, "[v1s:%d] connection aborted: network error", __LINE__); return SCP_SERVER_STATE_NETWORK_ERR; } in_uint32_be(c->in_s, version); if (version != 1) { log_message(LOG_LEVEL_WARNING, "[v1s:%d] connection aborted: version error", __LINE__); return SCP_SERVER_STATE_VERSION_ERR; } in_uint32_be(c->in_s, size); if (size < 12) { log_message(LOG_LEVEL_WARNING, "[v1s:%d] connection aborted: size error", __LINE__); return SCP_SERVER_STATE_SIZE_ERR; } /* rest of the packet */ init_stream(c->in_s, c->in_s->size); if (0 != scp_tcp_force_recv(c->in_sck, c->in_s->data, (size - 8))) { log_message(LOG_LEVEL_WARNING, "[v1s:%d] connection aborted: network error", __LINE__); return SCP_SERVER_STATE_NETWORK_ERR; } in_uint16_be(c->in_s, cmd); if (cmd != SCP_COMMAND_SET_DEFAULT) { log_message(LOG_LEVEL_WARNING, "[v1s:%d] connection aborted: sequence error", __LINE__); return SCP_SERVER_STATE_SEQUENCE_ERR; } in_uint16_be(c->in_s, cmd); if (cmd == 43) { /* select session */ in_uint32_be(c->in_s, (*sid)); /* checking sid value */ for (idx = 0; idx < sescnt; idx++) { /* the sid is valid */ if (ds[idx].SID == (*sid)) { /* ok, session selected */ return SCP_SERVER_STATE_OK; } } /* if we got here, the requested sid wasn't one from the list we sent */ /* we should kill the connection */ log_message(LOG_LEVEL_WARNING, "[v1s:%d] connection aborted: internal error (no such session in list)", __LINE__); return SCP_SERVER_STATE_INTERNAL_ERR; } else if (cmd == 44) { /* cancel connection */ return SCP_SERVER_STATE_SELECTION_CANCEL; } // else if (cmd == 45) // { // /* force new connection */ // return SCP_SERVER_STATE_FORCE_NEW; // } else { /* wrong response */ log_message(LOG_LEVEL_WARNING, "[v1s:%d] connection aborted: sequence error", __LINE__); return SCP_SERVER_STATE_SEQUENCE_ERR; } return SCP_SERVER_STATE_OK; } /* 046 was: 031 struct SCP_DISCONNECTED_SESSION* ds, */ enum SCP_SERVER_STATES_E scp_v1s_reconnect_session(struct SCP_CONNECTION *c, SCP_DISPLAY d) { tui32 version = 1; tui32 size = 14; tui16 cmd = 46; /* ok, we send session data and display */ init_stream(c->out_s, c->out_s->size); /* header */ out_uint32_be(c->out_s, version); out_uint32_be(c->out_s, size); out_uint16_be(c->out_s, SCP_COMMAND_SET_DEFAULT); out_uint16_be(c->out_s, cmd); /* session data */ out_uint16_be(c->out_s, d); /* session display */ /*out_uint8(c->out_s, ds->type); out_uint16_be(c->out_s, ds->height); out_uint16_be(c->out_s, ds->width); out_uint8(c->out_s, ds->bpp); out_uint8(c->out_s, ds->idle_days); out_uint8(c->out_s, ds->idle_hours); out_uint8(c->out_s, ds->idle_minutes);*/ /* these last three are not really needed... */ if (0 != scp_tcp_force_send(c->in_sck, c->out_s->data, size)) { log_message(LOG_LEVEL_WARNING, "[v1s:%d] connection aborted: network error", __LINE__); return SCP_SERVER_STATE_NETWORK_ERR; } return SCP_SERVER_STATE_OK; } #endif xrdp-0.9.5/sesman/libscp/libscp_tcp.c000644 001751 001751 00000005410 13174271344 017460 0ustar00metameta000000 000000 /** * xrdp: A Remote Desktop Protocol server. * * Copyright (C) Jay Sorg 2004-2012 * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ /** * * @file tcp.c * @brief Tcp stream functions * @author Jay Sorg, Simone Fedele * */ #if defined(HAVE_CONFIG_H) #include #endif #include "libscp_tcp.h" extern struct log_config *s_log; /*****************************************************************************/ int scp_tcp_force_recv(int sck, char *data, int len) { int rcvd; int block; LOG_DBG("scp_tcp_force_recv()"); block = scp_lock_fork_critical_section_start(); while (len > 0) { rcvd = g_tcp_recv(sck, data, len, 0); if (rcvd == -1) { if (g_tcp_last_error_would_block(sck)) { g_sleep(1); } else { scp_lock_fork_critical_section_end(block); return 1; } } else if (rcvd == 0) { scp_lock_fork_critical_section_end(block); return 1; } else { data += rcvd; len -= rcvd; } } scp_lock_fork_critical_section_end(block); return 0; } /*****************************************************************************/ int scp_tcp_force_send(int sck, char *data, int len) { int sent; int block; LOG_DBG("scp_tcp_force_send()"); block = scp_lock_fork_critical_section_start(); while (len > 0) { sent = g_tcp_send(sck, data, len, 0); if (sent == -1) { if (g_tcp_last_error_would_block(sck)) { g_sleep(1); } else { scp_lock_fork_critical_section_end(block); return 1; } } else if (sent == 0) { scp_lock_fork_critical_section_end(block); return 1; } else { data += sent; len -= sent; } } scp_lock_fork_critical_section_end(block); return 0; } /*****************************************************************************/ int scp_tcp_bind(int sck, char *addr, char *port) { return g_tcp_bind_address(sck, port, addr); } xrdp-0.9.5/sesman/libscp/libscp.h000644 001751 001751 00000002137 13174271344 016622 0ustar00metameta000000 000000 /** * xrdp: A Remote Desktop Protocol server. * * Copyright (C) Jay Sorg 2004-2012 * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ /** * * @file libscp.h * @brief libscp main header * @author Simone Fedele * */ #ifndef LIBSCP_H #define LIBSCP_H #include "libscp_types.h" #include "libscp_commands.h" #include "libscp_connection.h" #include "libscp_session.h" #include "libscp_init.h" #include "libscp_tcp.h" #include "libscp_lock.h" #include "libscp_vX.h" #include "libscp_v0.h" #include "libscp_v1s.h" #include "libscp_v1c.h" #include "libscp_v1s_mng.h" #include "libscp_v1c_mng.h" #endif xrdp-0.9.5/sesman/libscp/libscp_lock.c000644 001751 001751 00000010360 13174271344 017622 0ustar00metameta000000 000000 /** * xrdp: A Remote Desktop Protocol server. * * Copyright (C) Jay Sorg 2004-2012 * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. * * session manager * linux only */ #if defined(HAVE_CONFIG_H) #include #endif #include "libscp_lock.h" #include "thread_calls.h" #include pthread_mutex_t lock_fork; /* this lock protects the counters */ pthread_mutexattr_t lock_fork_attr; /* mutex attributes */ tbus lock_fork_req; /* semaphore on which the process that are going to fork suspend on */ tbus lock_fork_wait; /* semaphore on which the suspended process wait on */ int lock_fork_forkers_count; /* threads that want to fork */ int lock_fork_blockers_count; /* threads that are blocking fork */ int lock_fork_waiting_count; /* threads suspended until the fork finishes */ void scp_lock_init(void) { /* initializing fork lock */ pthread_mutexattr_init(&lock_fork_attr); pthread_mutex_init(&lock_fork, &lock_fork_attr); lock_fork_req = tc_sem_create(0); lock_fork_wait = tc_sem_create(0); /* here we don't use locking because lock_init() should be called BEFORE */ /* any thread is created */ lock_fork_blockers_count = 0; lock_fork_waiting_count = 0; lock_fork_forkers_count = 0; } /******************************************************************************/ void scp_lock_fork_request(void) { /* lock mutex */ pthread_mutex_lock(&lock_fork); if (lock_fork_blockers_count == 0) { /* if no one is blocking fork(), then we're allowed to fork */ tc_sem_inc(lock_fork_req); } lock_fork_forkers_count++; pthread_mutex_unlock(&lock_fork); /* we wait to be allowed to fork() */ tc_sem_dec(lock_fork_req); } /******************************************************************************/ void scp_lock_fork_release(void) { pthread_mutex_lock(&lock_fork); lock_fork_forkers_count--; /* if there's someone else that want to fork, we let him fork() */ if (lock_fork_forkers_count > 0) { tc_sem_inc(lock_fork_req); } for (; lock_fork_waiting_count > 0; lock_fork_waiting_count--) { /* waking up the other processes */ tc_sem_inc(lock_fork_wait); } pthread_mutex_unlock(&lock_fork); } /******************************************************************************/ void scp_lock_fork_critical_section_end(int blocking) { //LOG_DBG("lock_fork_critical_section_end()",0); /* lock mutex */ pthread_mutex_lock(&lock_fork); if (blocking == LIBSCP_LOCK_FORK_BLOCKER) { lock_fork_blockers_count--; } /* if there's someone who wants to fork and we're the last blocking */ /* then we let him go */ if ((lock_fork_blockers_count == 0) && (lock_fork_forkers_count > 0)) { tc_sem_inc(lock_fork_req); } pthread_mutex_unlock(&lock_fork); } /******************************************************************************/ int scp_lock_fork_critical_section_start(void) { //LOG_DBG("lock_fork_critical_section_start()",0); do { pthread_mutex_lock(&lock_fork); /* someone requested to fork */ if (lock_fork_forkers_count > 0) { lock_fork_waiting_count++; pthread_mutex_unlock(&lock_fork); /* we wait until the fork finishes */ tc_sem_dec(lock_fork_wait); } else { /* no fork, so we can go on... */ lock_fork_blockers_count++; pthread_mutex_unlock(&lock_fork); return LIBSCP_LOCK_FORK_BLOCKER; } } while (1); /* we'll never get here */ return LIBSCP_LOCK_FORK_WAITING; } xrdp-0.9.5/sesman/libscp/libscp_init.c000644 001751 001751 00000002074 13174271344 017640 0ustar00metameta000000 000000 /** * xrdp: A Remote Desktop Protocol server. * * Copyright (C) Jay Sorg 2004-2012 * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ /** * * @file libscp_init.c * @brief libscp initialization code * @author Simone Fedele * */ #if defined(HAVE_CONFIG_H) #include #endif #include "libscp_init.h" //struct log_config* s_log; /* server API */ int scp_init(void) { /* if (0 == log) { return 1; } */ //s_log = log; scp_lock_init(); log_message(LOG_LEVEL_DEBUG, "libscp initialized"); return 0; } xrdp-0.9.5/sesman/libscp/libscp_v0.c000644 001751 001751 00000033227 13220727201 017214 0ustar00metameta000000 000000 /** * xrdp: A Remote Desktop Protocol server. * * Copyright (C) Jay Sorg 2004-2012 * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ /** * * @file libscp_v0.c * @brief libscp version 0 code * @author Simone Fedele * */ #if defined(HAVE_CONFIG_H) #include #endif #include "libscp_v0.h" #include "os_calls.h" extern struct log_config *s_log; /* client API */ /******************************************************************************/ enum SCP_CLIENT_STATES_E scp_v0c_connect(struct SCP_CONNECTION *c, struct SCP_SESSION *s) { tui32 version; tui32 size; tui16 sz; init_stream(c->in_s, c->in_s->size); init_stream(c->out_s, c->in_s->size); LOG_DBG("[v0:%d] starting connection", __LINE__); g_tcp_set_non_blocking(c->in_sck); g_tcp_set_no_delay(c->in_sck); s_push_layer(c->out_s, channel_hdr, 8); /* code */ if (s->type == SCP_SESSION_TYPE_XVNC) { out_uint16_be(c->out_s, 0); } else if (s->type == SCP_SESSION_TYPE_XRDP) { out_uint16_be(c->out_s, 10); } else if (s->type == SCP_SESSION_TYPE_XORG) { out_uint16_be(c->out_s, 20); } else { log_message(LOG_LEVEL_WARNING, "[v0:%d] connection aborted: network error", __LINE__); return SCP_CLIENT_STATE_INTERNAL_ERR; } sz = g_strlen(s->username); out_uint16_be(c->out_s, sz); out_uint8a(c->out_s, s->username, sz); sz = g_strlen(s->password); out_uint16_be(c->out_s, sz); out_uint8a(c->out_s, s->password, sz); out_uint16_be(c->out_s, s->width); out_uint16_be(c->out_s, s->height); out_uint16_be(c->out_s, s->bpp); s_mark_end(c->out_s); s_pop_layer(c->out_s, channel_hdr); /* version */ out_uint32_be(c->out_s, 0); /* size */ out_uint32_be(c->out_s, c->out_s->end - c->out_s->data); if (0 != scp_tcp_force_send(c->in_sck, c->out_s->data, c->out_s->end - c->out_s->data)) { log_message(LOG_LEVEL_WARNING, "[v0:%d] connection aborted: network error", __LINE__); return SCP_CLIENT_STATE_NETWORK_ERR; } if (0 != scp_tcp_force_recv(c->in_sck, c->in_s->data, 8)) { log_message(LOG_LEVEL_WARNING, "[v0:%d] connection aborted: network error", __LINE__); return SCP_CLIENT_STATE_NETWORK_ERR; } in_uint32_be(c->in_s, version); if (0 != version) { log_message(LOG_LEVEL_WARNING, "[v0:%d] connection aborted: version error", __LINE__); return SCP_CLIENT_STATE_VERSION_ERR; } in_uint32_be(c->in_s, size); if (size < 14) { log_message(LOG_LEVEL_WARNING, "[v0:%d] connection aborted: packet size error", __LINE__); return SCP_CLIENT_STATE_SIZE_ERR; } /* getting payload */ init_stream(c->in_s, c->in_s->size); if (0 != scp_tcp_force_recv(c->in_sck, c->in_s->data, size - 8)) { log_message(LOG_LEVEL_WARNING, "[v0:%d] connection aborted: network error", __LINE__); return SCP_CLIENT_STATE_NETWORK_ERR; } /* check code */ in_uint16_be(c->in_s, sz); if (3 != sz) { log_message(LOG_LEVEL_WARNING, "[v0:%d] connection aborted: sequence error", __LINE__); return SCP_CLIENT_STATE_SEQUENCE_ERR; } /* message payload */ in_uint16_be(c->in_s, sz); if (1 != sz) { log_message(LOG_LEVEL_WARNING, "[v0:%d] connection aborted: connection denied", __LINE__); return SCP_CLIENT_STATE_CONNECTION_DENIED; } in_uint16_be(c->in_s, sz); s->display = sz; LOG_DBG("[v0:%d] connection terminated", __LINE__); return SCP_CLIENT_STATE_END; } /* server API */ /******************************************************************************/ enum SCP_SERVER_STATES_E scp_v0s_accept(struct SCP_CONNECTION *c, struct SCP_SESSION **s, int skipVchk) { tui32 version = 0; tui32 size; struct SCP_SESSION *session = 0; tui16 sz; tui32 code = 0; char *buf = 0; if (!skipVchk) { LOG_DBG("[v0:%d] starting connection", __LINE__); if (0 == scp_tcp_force_recv(c->in_sck, c->in_s->data, 8)) { c->in_s->end = c->in_s->data + 8; in_uint32_be(c->in_s, version); if (version != 0) { log_message(LOG_LEVEL_WARNING, "[v0:%d] connection aborted: version error", __LINE__); return SCP_SERVER_STATE_VERSION_ERR; } } else { log_message(LOG_LEVEL_WARNING, "[v0:%d] connection aborted: network error", __LINE__); return SCP_SERVER_STATE_NETWORK_ERR; } } in_uint32_be(c->in_s, size); init_stream(c->in_s, 8196); if (0 != scp_tcp_force_recv(c->in_sck, c->in_s->data, size - 8)) { log_message(LOG_LEVEL_WARNING, "[v0:%d] connection aborted: network error", __LINE__); return SCP_SERVER_STATE_NETWORK_ERR; } c->in_s->end = c->in_s->data + (size - 8); in_uint16_be(c->in_s, code); if (code == 0 || code == 10 || code == 20) { session = scp_session_create(); if (0 == session) { log_message(LOG_LEVEL_WARNING, "[v0:%d] connection aborted: network error", __LINE__); return SCP_SERVER_STATE_INTERNAL_ERR; } scp_session_set_version(session, version); if (code == 0) { scp_session_set_type(session, SCP_SESSION_TYPE_XVNC); } else if (code == 10) { scp_session_set_type(session, SCP_SESSION_TYPE_XRDP); } else if (code == 20) { scp_session_set_type(session, SCP_SESSION_TYPE_XORG); } /* reading username */ in_uint16_be(c->in_s, sz); buf = g_new0(char, sz + 1); in_uint8a(c->in_s, buf, sz); buf[sz] = '\0'; if (0 != scp_session_set_username(session, buf)) { scp_session_destroy(session); log_message(LOG_LEVEL_WARNING, "[v0:%d] connection aborted: error setting username", __LINE__); g_free(buf); return SCP_SERVER_STATE_INTERNAL_ERR; } g_free(buf); /* reading password */ in_uint16_be(c->in_s, sz); buf = g_new0(char, sz + 1); in_uint8a(c->in_s, buf, sz); buf[sz] = '\0'; if (0 != scp_session_set_password(session, buf)) { scp_session_destroy(session); log_message(LOG_LEVEL_WARNING, "[v0:%d] connection aborted: error setting password", __LINE__); g_free(buf); return SCP_SERVER_STATE_INTERNAL_ERR; } g_free(buf); /* width */ in_uint16_be(c->in_s, sz); scp_session_set_width(session, sz); /* height */ in_uint16_be(c->in_s, sz); scp_session_set_height(session, sz); /* bpp */ in_uint16_be(c->in_s, sz); if (0 != scp_session_set_bpp(session, (tui8)sz)) { scp_session_destroy(session); log_message(LOG_LEVEL_WARNING, "[v0:%d] connection aborted: unsupported bpp: %d", __LINE__, (tui8)sz); return SCP_SERVER_STATE_INTERNAL_ERR; } if (s_check_rem(c->in_s, 2)) { /* reading domain */ in_uint16_be(c->in_s, sz); if (sz > 0) { buf = g_new0(char, sz + 1); in_uint8a(c->in_s, buf, sz); buf[sz] = '\0'; scp_session_set_domain(session, buf); g_free(buf); } } if (s_check_rem(c->in_s, 2)) { /* reading program */ in_uint16_be(c->in_s, sz); if (sz > 0) { buf = g_new0(char, sz + 1); in_uint8a(c->in_s, buf, sz); buf[sz] = '\0'; scp_session_set_program(session, buf); g_free(buf); } } if (s_check_rem(c->in_s, 2)) { /* reading directory */ in_uint16_be(c->in_s, sz); if (sz > 0) { buf = g_new0(char, sz + 1); in_uint8a(c->in_s, buf, sz); buf[sz] = '\0'; scp_session_set_directory(session, buf); g_free(buf); } } if (s_check_rem(c->in_s, 2)) { /* reading client IP address */ in_uint16_be(c->in_s, sz); if (sz > 0) { buf = g_new0(char, sz + 1); in_uint8a(c->in_s, buf, sz); buf[sz] = '\0'; scp_session_set_client_ip(session, buf); g_free(buf); } } } else if (code == SCP_GW_AUTHENTICATION) { /* g_writeln("Command is SCP_GW_AUTHENTICATION"); */ session = scp_session_create(); if (0 == session) { /* until syslog merge log_message(s_log, LOG_LEVEL_WARNING, "[v0:%d] connection aborted: network error", __LINE__);*/ return SCP_SERVER_STATE_INTERNAL_ERR; } scp_session_set_version(session, version); scp_session_set_type(session, SCP_GW_AUTHENTICATION); /* reading username */ in_uint16_be(c->in_s, sz); buf = g_new0(char, sz + 1); in_uint8a(c->in_s, buf, sz); buf[sz] = '\0'; /* g_writeln("Received user name: %s",buf); */ if (0 != scp_session_set_username(session, buf)) { scp_session_destroy(session); /* until syslog merge log_message(s_log, LOG_LEVEL_WARNING, "[v0:%d] connection aborted: error setting username", __LINE__);*/ g_free(buf); return SCP_SERVER_STATE_INTERNAL_ERR; } g_free(buf); /* reading password */ in_uint16_be(c->in_s, sz); buf = g_new0(char, sz + 1); in_uint8a(c->in_s, buf, sz); buf[sz] = '\0'; /* g_writeln("Received password: %s",buf); */ if (0 != scp_session_set_password(session, buf)) { scp_session_destroy(session); /* until syslog merge log_message(s_log, LOG_LEVEL_WARNING, "[v0:%d] connection aborted: error setting password", __LINE__); */ g_free(buf); return SCP_SERVER_STATE_INTERNAL_ERR; } g_free(buf); } else { log_message(LOG_LEVEL_WARNING, "[v0:%d] connection aborted: sequence error", __LINE__); return SCP_SERVER_STATE_SEQUENCE_ERR; } (*s) = session; return SCP_SERVER_STATE_OK; } /******************************************************************************/ enum SCP_SERVER_STATES_E scp_v0s_allow_connection(struct SCP_CONNECTION *c, SCP_DISPLAY d, const tui8 *guid) { int msg_size; msg_size = guid == 0 ? 14 : 14 + 16; out_uint32_be(c->out_s, 0); /* version */ out_uint32_be(c->out_s, msg_size); /* size */ out_uint16_be(c->out_s, 3); /* cmd */ out_uint16_be(c->out_s, 1); /* data */ out_uint16_be(c->out_s, d); /* data */ if (msg_size > 14) { out_uint8a(c->out_s, guid, 16); } s_mark_end(c->out_s); if (0 != scp_tcp_force_send(c->in_sck, c->out_s->data, c->out_s->end - c->out_s->data)) { log_message(LOG_LEVEL_WARNING, "[v0:%d] connection aborted: network error", __LINE__); return SCP_SERVER_STATE_NETWORK_ERR; } LOG_DBG("[v0:%d] connection terminated (allowed)", __LINE__); return SCP_SERVER_STATE_OK; } /******************************************************************************/ enum SCP_SERVER_STATES_E scp_v0s_deny_connection(struct SCP_CONNECTION *c) { out_uint32_be(c->out_s, 0); /* version */ out_uint32_be(c->out_s, 14); /* size */ out_uint16_be(c->out_s, 3); /* cmd */ out_uint16_be(c->out_s, 0); /* data = 0 - means NOT ok*/ out_uint16_be(c->out_s, 0); /* reserved for display number*/ s_mark_end(c->out_s); if (0 != scp_tcp_force_send(c->in_sck, c->out_s->data, c->out_s->end - c->out_s->data)) { log_message(LOG_LEVEL_WARNING, "[v0:%d] connection aborted: network error", __LINE__); return SCP_SERVER_STATE_NETWORK_ERR; } LOG_DBG("[v0:%d] connection terminated (denied)", __LINE__); return SCP_SERVER_STATE_OK; } /******************************************************************************/ enum SCP_SERVER_STATES_E scp_v0s_replyauthentication(struct SCP_CONNECTION *c, unsigned short int value) { out_uint32_be(c->out_s, 0); /* version */ out_uint32_be(c->out_s, 14); /* size */ /* cmd SCP_GW_AUTHENTICATION means authentication reply */ out_uint16_be(c->out_s, SCP_GW_AUTHENTICATION); out_uint16_be(c->out_s, value); /* reply code */ out_uint16_be(c->out_s, 0); /* dummy data */ s_mark_end(c->out_s); /* g_writeln("Total number of bytes that will be sent %d",c->out_s->end - c->out_s->data);*/ if (0 != scp_tcp_force_send(c->in_sck, c->out_s->data, c->out_s->end - c->out_s->data)) { /* until syslog merge log_message(s_log, LOG_LEVEL_WARNING, "[v0:%d] connection aborted: network error", __LINE__); */ return SCP_SERVER_STATE_NETWORK_ERR; } /* until syslog merge LOG_DBG(s_log, "[v0:%d] connection terminated (scp_v0s_deny_authentication)", __LINE__);*/ return SCP_SERVER_STATE_OK; } xrdp-0.9.5/sesman/libscp/libscp_v1c.c000644 001751 001751 00000030643 13174271344 017371 0ustar00metameta000000 000000 /** * xrdp: A Remote Desktop Protocol server. * * Copyright (C) Jay Sorg 2004-2012 * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ /** * * @file libscp_v1c.c * @brief libscp version 1 client api code * @author Simone Fedele * */ #if defined(HAVE_CONFIG_H) #include #endif #include "libscp_v1c.h" #include #include static enum SCP_CLIENT_STATES_E _scp_v1c_check_response(struct SCP_CONNECTION *c, struct SCP_SESSION *s); /* client API */ /* 001 */ enum SCP_CLIENT_STATES_E scp_v1c_connect(struct SCP_CONNECTION *c, struct SCP_SESSION *s) { tui8 sz; tui32 size; init_stream(c->out_s, c->out_s->size); init_stream(c->in_s, c->in_s->size); size = 19 + 17 + 4 + g_strlen(s->hostname) + g_strlen(s->username) + g_strlen(s->password); if (s->addr_type == SCP_ADDRESS_TYPE_IPV4) { size = size + 4; } else { size = size + 16; } /* sending request */ /* header */ out_uint32_be(c->out_s, 1); /* version */ out_uint32_be(c->out_s, size); out_uint16_be(c->out_s, SCP_COMMAND_SET_DEFAULT); out_uint16_be(c->out_s, 1); /* body */ out_uint8(c->out_s, s->type); out_uint16_be(c->out_s, s->height); out_uint16_be(c->out_s, s->width); out_uint8(c->out_s, s->bpp); out_uint8(c->out_s, s->rsr); out_uint8p(c->out_s, s->locale, 17); out_uint8(c->out_s, s->addr_type); if (s->addr_type == SCP_ADDRESS_TYPE_IPV4) { out_uint32_be(c->out_s, s->ipv4addr); } else if (s->addr_type == SCP_ADDRESS_TYPE_IPV6) { out_uint8p(c->out_s, s->ipv6addr, 16); } sz = g_strlen(s->hostname); out_uint8(c->out_s, sz); out_uint8p(c->out_s, s->hostname, sz); sz = g_strlen(s->username); out_uint8(c->out_s, sz); out_uint8p(c->out_s, s->username, sz); sz = g_strlen(s->password); out_uint8(c->out_s, sz); out_uint8p(c->out_s, s->password, sz); if (0 != scp_tcp_force_send(c->in_sck, c->out_s->data, size)) { return SCP_CLIENT_STATE_NETWORK_ERR; } /* wait for response */ return _scp_v1c_check_response(c, s); } /* 004 */ enum SCP_CLIENT_STATES_E scp_v1c_resend_credentials(struct SCP_CONNECTION *c, struct SCP_SESSION *s) { tui8 sz; tui32 size; init_stream(c->out_s, c->out_s->size); init_stream(c->in_s, c->in_s->size); size = 12 + 2 + g_strlen(s->username) + g_strlen(s->password); /* sending request */ /* header */ out_uint32_be(c->out_s, 1); /* version */ out_uint32_be(c->out_s, size); out_uint16_be(c->out_s, SCP_COMMAND_SET_DEFAULT); out_uint16_be(c->out_s, 4); /* body */ sz = g_strlen(s->username); out_uint8(c->out_s, sz); out_uint8p(c->out_s, s->username, sz); sz = g_strlen(s->password); out_uint8(c->out_s, sz); out_uint8p(c->out_s, s->password, sz); if (0 != scp_tcp_force_send(c->in_sck, c->out_s->data, size)) { return SCP_CLIENT_STATE_NETWORK_ERR; } /* wait for response */ return _scp_v1c_check_response(c, s); } /* 041 */ enum SCP_CLIENT_STATES_E scp_v1c_get_session_list(struct SCP_CONNECTION *c, int *scount, struct SCP_DISCONNECTED_SESSION **s) { tui32 version = 1; tui32 size = 12; tui16 cmd = 41; tui32 sescnt = 0; /* total session number */ tui32 sestmp = 0; /* additional total session number */ tui8 pktcnt = 0; /* packet session count */ tui32 totalcnt = 0; /* session counter */ tui8 continued = 0; /* continue flag */ int firstpkt = 1; /* "first packet" flag */ int idx; struct SCP_DISCONNECTED_SESSION *ds = 0; init_stream(c->out_s, c->out_s->size); /* we request session list */ out_uint32_be(c->out_s, version); /* version */ out_uint32_be(c->out_s, size); /* size */ out_uint16_be(c->out_s, SCP_COMMAND_SET_DEFAULT); /* cmdset */ out_uint16_be(c->out_s, cmd); /* cmd */ if (0 != scp_tcp_force_send(c->in_sck, c->out_s->data, size)) { return SCP_CLIENT_STATE_NETWORK_ERR; } do { /* then we wait for server response */ init_stream(c->in_s, c->in_s->size); if (0 != scp_tcp_force_recv(c->in_sck, c->in_s->data, 8)) { return SCP_CLIENT_STATE_NETWORK_ERR; } in_uint32_be(c->in_s, version); if (version != 1) { return SCP_CLIENT_STATE_VERSION_ERR; } in_uint32_be(c->in_s, size); if (size < 12) { return SCP_CLIENT_STATE_SIZE_ERR; } init_stream(c->in_s, c->in_s->size); if (0 != scp_tcp_force_recv(c->in_sck, c->in_s->data, size - 8)) { return SCP_CLIENT_STATE_NETWORK_ERR; } in_uint16_be(c->in_s, cmd); if (cmd != SCP_COMMAND_SET_DEFAULT) { return SCP_CLIENT_STATE_SEQUENCE_ERR; } in_uint16_be(c->in_s, cmd); if (cmd != 42) { return SCP_CLIENT_STATE_SEQUENCE_ERR; } if (firstpkt) { firstpkt = 0; in_uint32_be(c->in_s, sescnt); sestmp = sescnt; ds = g_new(struct SCP_DISCONNECTED_SESSION, sescnt); if (ds == 0) { return SCP_CLIENT_STATE_INTERNAL_ERR; } } else { in_uint32_be(c->in_s, sestmp); } in_uint8(c->in_s, continued); in_uint8(c->in_s, pktcnt); for (idx = 0; idx < pktcnt; idx++) { in_uint32_be(c->in_s, (ds[totalcnt]).SID); /* session id */ in_uint8(c->in_s, (ds[totalcnt]).type); in_uint16_be(c->in_s, (ds[totalcnt]).height); in_uint16_be(c->in_s, (ds[totalcnt]).width); in_uint8(c->in_s, (ds[totalcnt]).bpp); in_uint8(c->in_s, (ds[totalcnt]).idle_days); in_uint8(c->in_s, (ds[totalcnt]).idle_hours); in_uint8(c->in_s, (ds[totalcnt]).idle_minutes); in_uint16_be(c->in_s, (ds[totalcnt]).conn_year); in_uint8(c->in_s, (ds[totalcnt]).conn_month); in_uint8(c->in_s, (ds[totalcnt]).conn_day); in_uint8(c->in_s, (ds[totalcnt]).conn_hour); in_uint8(c->in_s, (ds[totalcnt]).conn_minute); in_uint8(c->in_s, (ds[totalcnt]).addr_type); if ((ds[totalcnt]).addr_type == SCP_ADDRESS_TYPE_IPV4) { in_uint32_be(c->in_s, (ds[totalcnt]).ipv4addr); } else if ((ds[totalcnt]).addr_type == SCP_ADDRESS_TYPE_IPV6) { in_uint8a(c->in_s, (ds[totalcnt]).ipv6addr, 16); } totalcnt++; } } while (continued); printf("fine\n"); /* return data... */ (*scount) = sescnt; (*s) = ds; return SCP_CLIENT_STATE_LIST_OK; } /* 043 */ enum SCP_CLIENT_STATES_E scp_v1c_select_session(struct SCP_CONNECTION *c, struct SCP_SESSION *s, SCP_SID sid) { tui32 version = 1; tui32 size = 16; tui16 cmd = 43; init_stream(c->out_s, c->out_s->size); /* sending our selection */ out_uint32_be(c->out_s, version); /* version */ out_uint32_be(c->out_s, size); /* size */ out_uint16_be(c->out_s, SCP_COMMAND_SET_DEFAULT); /* cmdset */ out_uint16_be(c->out_s, cmd); /* cmd */ out_uint32_be(c->out_s, sid); if (0 != scp_tcp_force_send(c->in_sck, c->out_s->data, size)) { return SCP_CLIENT_STATE_NETWORK_ERR; } /* waiting for response.... */ init_stream(c->in_s, c->in_s->size); if (0 != scp_tcp_force_recv(c->in_sck, c->in_s->data, 8)) { return SCP_CLIENT_STATE_NETWORK_ERR; } in_uint32_be(c->in_s, version); if (version != 1) { return SCP_CLIENT_STATE_VERSION_ERR; } in_uint32_be(c->in_s, size); if (size < 12) { return SCP_CLIENT_STATE_SIZE_ERR; } init_stream(c->in_s, c->in_s->size); /* read the rest of the packet */ if (0 != scp_tcp_force_recv(c->in_sck, c->in_s->data, size - 8)) { return SCP_CLIENT_STATE_NETWORK_ERR; } in_uint16_be(c->in_s, cmd); if (cmd != SCP_COMMAND_SET_DEFAULT) { return SCP_CLIENT_STATE_SEQUENCE_ERR; } in_uint16_be(c->in_s, cmd); if (cmd != 46) { return SCP_CLIENT_STATE_SEQUENCE_ERR; } /* session display */ in_uint16_be(c->in_s, (s->display)); /*we don't need to return any data other than the display */ /*because we already sent that */ return SCP_CLIENT_STATE_OK; } /* 044 */ enum SCP_CLIENT_STATES_E scp_v1c_select_session_cancel(struct SCP_CONNECTION *c) { tui32 version = 1; tui32 size = 12; tui16 cmd = 44; init_stream(c->out_s, c->out_s->size); /* sending our selection */ out_uint32_be(c->out_s, version); /* version */ out_uint32_be(c->out_s, size); /* size */ out_uint16_be(c->out_s, SCP_COMMAND_SET_DEFAULT); /* cmdset */ out_uint16_be(c->out_s, cmd); /* cmd */ if (0 != scp_tcp_force_send(c->in_sck, c->out_s->data, size)) { return SCP_CLIENT_STATE_NETWORK_ERR; } return SCP_CLIENT_STATE_END; } static enum SCP_CLIENT_STATES_E _scp_v1c_check_response(struct SCP_CONNECTION *c, struct SCP_SESSION *s) { tui32 version; tui32 size; tui16 cmd; tui16 dim; init_stream(c->in_s, c->in_s->size); if (0 != scp_tcp_force_recv(c->in_sck, c->in_s->data, 8)) { return SCP_CLIENT_STATE_NETWORK_ERR; } in_uint32_be(c->in_s, version); if (version != 1) { return SCP_CLIENT_STATE_VERSION_ERR; } in_uint32_be(c->in_s, size); init_stream(c->in_s, c->in_s->size); /* read the rest of the packet */ if (0 != scp_tcp_force_recv(c->in_sck, c->in_s->data, size - 8)) { return SCP_CLIENT_STATE_NETWORK_ERR; } in_uint16_be(c->in_s, cmd); if (cmd != SCP_COMMAND_SET_DEFAULT) { return SCP_CLIENT_STATE_SEQUENCE_ERR; } in_uint16_be(c->in_s, cmd); if (cmd == 2) /* connection denied */ { in_uint16_be(c->in_s, dim); if (s->errstr != 0) { g_free(s->errstr); } s->errstr = g_new(char, dim + 1); if (s->errstr == 0) { return SCP_CLIENT_STATE_INTERNAL_ERR; } in_uint8a(c->in_s, s->errstr, dim); (s->errstr)[dim] = '\0'; return SCP_CLIENT_STATE_CONNECTION_DENIED; } else if (cmd == 3) /* resend usr/pwd */ { in_uint16_be(c->in_s, dim); if (s->errstr != 0) { g_free(s->errstr); } s->errstr = g_new(char, dim + 1); if (s->errstr == 0) { return SCP_CLIENT_STATE_INTERNAL_ERR; } in_uint8a(c->in_s, s->errstr, dim); (s->errstr)[dim] = '\0'; return SCP_CLIENT_STATE_RESEND_CREDENTIALS; } else if (cmd == 20) /* password change */ { in_uint16_be(c->in_s, dim); if (s->errstr != 0) { g_free(s->errstr); } s->errstr = g_new(char, dim + 1); if (s->errstr == 0) { return SCP_CLIENT_STATE_INTERNAL_ERR; } in_uint8a(c->in_s, s->errstr, dim); (s->errstr)[dim] = '\0'; return SCP_CLIENT_STATE_PWD_CHANGE_REQ; } else if (cmd == 30) /* display */ { in_uint16_be(c->in_s, s->display); return SCP_CLIENT_STATE_OK; } //else if (cmd == 31) /* there's a disconnected session */ //{ // return SCP_CLIENT_STATE_RECONNECT_SINGLE; //} //else if (cmd == 33) /* display of a disconnected session */ //{ // return SCP_CLIENT_STATE_RECONNECT; //} else if (cmd == 40) /* session list */ { return SCP_CLIENT_STATE_SESSION_LIST; } return SCP_CLIENT_STATE_SEQUENCE_ERR; } xrdp-0.9.5/sesman/libscp/libscp_session.c000644 001751 001751 00000023237 13174271344 020364 0ustar00metameta000000 000000 /** * xrdp: A Remote Desktop Protocol server. * * Copyright (C) Jay Sorg 2004-2012 * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ /** * * @file libscp_session.c * @brief SCP_SESSION handling code * @author Simone Fedele * */ #if defined(HAVE_CONFIG_H) #include #endif #include "libscp_session.h" #include #include #include //extern struct log_config* s_log; /*******************************************************************/ struct SCP_SESSION * scp_session_create(void) { struct SCP_SESSION *s; s = (struct SCP_SESSION *)g_malloc(sizeof(struct SCP_SESSION), 1); if (0 == s) { log_message(LOG_LEVEL_ERROR, "[session:%d] session create: malloc error", __LINE__); return 0; } return s; } /*******************************************************************/ int scp_session_set_type(struct SCP_SESSION *s, tui8 type) { switch (type) { case SCP_SESSION_TYPE_XVNC: s->type = SCP_SESSION_TYPE_XVNC; break; case SCP_SESSION_TYPE_XRDP: s->type = SCP_SESSION_TYPE_XRDP; break; case SCP_SESSION_TYPE_XORG: s->type = SCP_SESSION_TYPE_XORG; break; case SCP_GW_AUTHENTICATION: s->type = SCP_GW_AUTHENTICATION; break; case SCP_SESSION_TYPE_MANAGE: s->type = SCP_SESSION_TYPE_MANAGE; s->mng = (struct SCP_MNG_DATA *)g_malloc(sizeof(struct SCP_MNG_DATA), 1); if (NULL == s->mng) { log_message(LOG_LEVEL_ERROR, "[session:%d] set_type: internal error", __LINE__); return 1; } break; default: log_message(LOG_LEVEL_WARNING, "[session:%d] set_type: unknown type", __LINE__); return 1; } return 0; } /*******************************************************************/ int scp_session_set_version(struct SCP_SESSION *s, tui32 version) { switch (version) { case 0: s->version = 0; break; case 1: s->version = 1; break; default: log_message(LOG_LEVEL_WARNING, "[session:%d] set_version: unknown version", __LINE__); return 1; } return 0; } /*******************************************************************/ int scp_session_set_height(struct SCP_SESSION *s, tui16 h) { s->height = h; return 0; } /*******************************************************************/ int scp_session_set_width(struct SCP_SESSION *s, tui16 w) { s->width = w; return 0; } /*******************************************************************/ int scp_session_set_bpp(struct SCP_SESSION *s, tui8 bpp) { switch (bpp) { case 8: case 15: case 16: case 24: case 32: s->bpp = bpp; break; default: return 1; } return 0; } /*******************************************************************/ int scp_session_set_rsr(struct SCP_SESSION *s, tui8 rsr) { if (s->rsr) { s->rsr = 1; } else { s->rsr = 0; } return 0; } /*******************************************************************/ int scp_session_set_locale(struct SCP_SESSION *s, const char *str) { if (0 == str) { log_message(LOG_LEVEL_WARNING, "[session:%d] set_locale: null locale", __LINE__); s->locale[0] = '\0'; return 1; } g_strncpy(s->locale, str, 17); s->locale[17] = '\0'; return 0; } /*******************************************************************/ int scp_session_set_username(struct SCP_SESSION *s, const char *str) { if (0 == str) { log_message(LOG_LEVEL_WARNING, "[session:%d] set_username: null username", __LINE__); return 1; } if (0 != s->username) { g_free(s->username); } s->username = g_strdup(str); if (0 == s->username) { log_message(LOG_LEVEL_WARNING, "[session:%d] set_username: strdup error", __LINE__); return 1; } return 0; } /*******************************************************************/ int scp_session_set_password(struct SCP_SESSION *s, const char *str) { if (0 == str) { log_message(LOG_LEVEL_WARNING, "[session:%d] set_password: null password", __LINE__); return 1; } if (0 != s->password) { g_free(s->password); } s->password = g_strdup(str); if (0 == s->password) { log_message(LOG_LEVEL_WARNING, "[session:%d] set_password: strdup error", __LINE__); return 1; } return 0; } /*******************************************************************/ int scp_session_set_domain(struct SCP_SESSION *s, const char *str) { if (0 == str) { log_message(LOG_LEVEL_WARNING, "[session:%d] set_domain: null domain", __LINE__); return 1; } if (0 != s->domain) { g_free(s->domain); } s->domain = g_strdup(str); if (0 == s->domain) { log_message(LOG_LEVEL_WARNING, "[session:%d] set_domain: strdup error", __LINE__); return 1; } return 0; } /*******************************************************************/ int scp_session_set_program(struct SCP_SESSION *s, const char *str) { if (0 == str) { log_message(LOG_LEVEL_WARNING, "[session:%d] set_program: null program", __LINE__); return 1; } if (0 != s->program) { g_free(s->program); } s->program = g_strdup(str); if (0 == s->program) { log_message(LOG_LEVEL_WARNING, "[session:%d] set_program: strdup error", __LINE__); return 1; } return 0; } /*******************************************************************/ int scp_session_set_directory(struct SCP_SESSION *s, const char *str) { if (0 == str) { log_message(LOG_LEVEL_WARNING, "[session:%d] set_directory: null directory", __LINE__); return 1; } if (0 != s->directory) { g_free(s->directory); } s->directory = g_strdup(str); if (0 == s->directory) { log_message(LOG_LEVEL_WARNING, "[session:%d] set_directory: strdup error", __LINE__); return 1; } return 0; } /*******************************************************************/ int scp_session_set_client_ip(struct SCP_SESSION *s, const char *str) { if (0 == str) { log_message(LOG_LEVEL_WARNING, "[session:%d] set_client_ip: null ip", __LINE__); return 1; } if (0 != s->client_ip) { g_free(s->client_ip); } s->client_ip = g_strdup(str); if (0 == s->client_ip) { log_message(LOG_LEVEL_WARNING, "[session:%d] set_client_ip: strdup error", __LINE__); return 1; } return 0; } /*******************************************************************/ int scp_session_set_hostname(struct SCP_SESSION *s, const char *str) { if (0 == str) { log_message(LOG_LEVEL_WARNING, "[session:%d] set_hostname: null hostname", __LINE__); return 1; } if (0 != s->hostname) { g_free(s->hostname); } s->hostname = g_strdup(str); if (0 == s->hostname) { log_message(LOG_LEVEL_WARNING, "[session:%d] set_hostname: strdup error", __LINE__); return 1; } return 0; } /*******************************************************************/ int scp_session_set_errstr(struct SCP_SESSION *s, const char *str) { if (0 == str) { log_message(LOG_LEVEL_WARNING, "[session:%d] set_errstr: null string", __LINE__); return 1; } if (0 != s->errstr) { g_free(s->errstr); } s->errstr = g_strdup(str); if (0 == s->errstr) { log_message(LOG_LEVEL_WARNING, "[session:%d] set_errstr: strdup error", __LINE__); return 1; } return 0; } /*******************************************************************/ int scp_session_set_display(struct SCP_SESSION *s, SCP_DISPLAY display) { s->display = display; return 0; } /*******************************************************************/ int scp_session_set_addr(struct SCP_SESSION *s, int type, const void *addr) { switch (type) { case SCP_ADDRESS_TYPE_IPV4: g_memcpy(&(s->ipv4addr), addr, 4); break; #ifdef IN6ADDR_ANY_INIT case SCP_ADDRESS_TYPE_IPV6: g_memcpy(s->ipv6addr, addr, 16); break; #endif default: return 1; } return 0; } /*******************************************************************/ int scp_session_set_guid(struct SCP_SESSION *s, const tui8 *guid) { if (0 == guid) { log_message(LOG_LEVEL_WARNING, "[session:%d] set_guid: null guid", __LINE__); return 1; } g_memcpy(s->guid, guid, 16); return 0; } /*******************************************************************/ void scp_session_destroy(struct SCP_SESSION *s) { g_free(s->username); g_free(s->password); g_free(s->hostname); g_free(s->domain); g_free(s->program); g_free(s->directory); g_free(s->client_ip); g_free(s->errstr); g_free(s->mng); g_free(s); } xrdp-0.9.5/sesman/libscp/libscp_v1s_mng.h000644 001751 001751 00000003753 13127114621 020251 0ustar00metameta000000 000000 /** * xrdp: A Remote Desktop Protocol server. * * Copyright (C) Jay Sorg 2004-2012 * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ /** * * @file libscp_v1s_mng.h * @brief libscp version 1 server api declarations - session management * @author Simone Fedele * */ #ifndef LIBSCP_V1S_MNG_H #define LIBSCP_V1S_MNG_H #include "libscp.h" /* server API */ /** * * @brief processes the stream using scp version 1 * @param c connection descriptor * @param s pointer to session descriptor pointer * * this function places in *s the address of a newly allocated SCP_SESSION structure * that should be free()d */ enum SCP_SERVER_STATES_E scp_v1s_mng_accept(struct SCP_CONNECTION* c, struct SCP_SESSION** s); /** * * @brief allows connection to sesman * @param c connection descriptor * */ /* 002 */ enum SCP_SERVER_STATES_E scp_v1s_mng_allow_connection(struct SCP_CONNECTION* c, struct SCP_SESSION* s); /** * * @brief denies connection to sesman * @param c connection descriptor * @param reason pointer to a string containing the reason for denying connection * */ /* 003 */ enum SCP_SERVER_STATES_E scp_v1s_mng_deny_connection(struct SCP_CONNECTION* c, const char *reason); /** * * @brief sends session list * @param c connection descriptor * */ /* 006 */ enum SCP_SERVER_STATES_E scp_v1s_mng_list_sessions(struct SCP_CONNECTION* c, struct SCP_SESSION* s, int sescnt, struct SCP_DISCONNECTED_SESSION* ds); // SCP_SID* sid); #endif xrdp-0.9.5/sesman/libscp/libscp_commands.h000644 001751 001751 00000001633 13125122134 020467 0ustar00metameta000000 000000 /** * xrdp: A Remote Desktop Protocol server. * * Copyright (C) Jay Sorg 2004-2012 * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ /** * * @file libscp_commands.h * @brief libscp data types definitions * @author Simone Fedele * */ #ifndef LIBSCP_COMMANDS_H #define LIBSCP_COMMANDS_H #include "libscp_commands_mng.h" #define SCP_CMD_LOGIN 0x0001 #define SCP_CMD_CONN_ERROR 0xFFFF #endif xrdp-0.9.5/sesman/libscp/libscp_vX.c000644 001751 001751 00000002513 13174271344 017270 0ustar00metameta000000 000000 /** * xrdp: A Remote Desktop Protocol server. * * Copyright (C) Jay Sorg 2004-2012 * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ /** * * @file libscp_vX.c * @brief libscp version neutral code * @author Simone Fedele * */ #if defined(HAVE_CONFIG_H) #include #endif #include "libscp_vX.h" /* server API */ enum SCP_SERVER_STATES_E scp_vXs_accept(struct SCP_CONNECTION *c, struct SCP_SESSION **s) { tui32 version; /* reading version and packet size */ if (0 != scp_tcp_force_recv(c->in_sck, c->in_s->data, 8)) { return SCP_SERVER_STATE_NETWORK_ERR; } in_uint32_be(c->in_s, version); if (version == 0) { return scp_v0s_accept(c, s, 1); } else if (version == 1) { return scp_v1s_accept(c, s, 1); } return SCP_SERVER_STATE_VERSION_ERR; } xrdp-0.9.5/sesman/libscp/libscp_v1c_mng.c000644 001751 001751 00000027515 13174271344 020236 0ustar00metameta000000 000000 /** * xrdp: A Remote Desktop Protocol server. * * Copyright (C) Jay Sorg 2004-2012 * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ /** * * @file libscp_v1c_mng.c * @brief libscp version 1 client api code - session management * @author Simone Fedele * */ #if defined(HAVE_CONFIG_H) #include #endif #include "libscp_v1c_mng.h" #include #include //extern struct log_config* s_log; static enum SCP_CLIENT_STATES_E _scp_v1c_mng_check_response(struct SCP_CONNECTION *c, struct SCP_SESSION *s); /* client API */ /* 001 */ enum SCP_CLIENT_STATES_E scp_v1c_mng_connect(struct SCP_CONNECTION *c, struct SCP_SESSION *s) { tui8 sz; tui32 size; init_stream(c->out_s, c->out_s->size); init_stream(c->in_s, c->in_s->size); size = 12 + 4 + g_strlen(s->hostname) + g_strlen(s->username) + g_strlen(s->password); if (s->addr_type == SCP_ADDRESS_TYPE_IPV4) { size = size + 4; } else { size = size + 16; } /* sending request */ /* header */ out_uint32_be(c->out_s, 1); /* version */ out_uint32_be(c->out_s, size); out_uint16_be(c->out_s, SCP_COMMAND_SET_MANAGE); out_uint16_be(c->out_s, SCP_CMD_MNG_LOGIN); /* data */ sz = g_strlen(s->username); out_uint8(c->out_s, sz); out_uint8p(c->out_s, s->username, sz); sz = g_strlen(s->password); out_uint8(c->out_s, sz); out_uint8p(c->out_s, s->password, sz); /* address */ out_uint8(c->out_s, s->addr_type); if (s->addr_type == SCP_ADDRESS_TYPE_IPV4) { out_uint32_be(c->out_s, s->ipv4addr); } else { out_uint8p(c->out_s, s->ipv6addr, 16); } /* hostname */ sz = g_strlen(s->hostname); out_uint8(c->out_s, sz); out_uint8p(c->out_s, s->hostname, sz); if (0 != scp_tcp_force_send(c->in_sck, c->out_s->data, size)) { log_message(LOG_LEVEL_WARNING, "[v1c_mng:%d] connection aborted: network error", __LINE__); return SCP_CLIENT_STATE_NETWORK_ERR; } /* wait for response */ return _scp_v1c_mng_check_response(c, s); } /* 004 */ enum SCP_CLIENT_STATES_E scp_v1c_mng_get_session_list(struct SCP_CONNECTION *c, int *scount, struct SCP_DISCONNECTED_SESSION **s) { tui32 version = 1; tui32 size = 12; tui16 cmd = SCP_CMD_MNG_LIST_REQ; /* request session list */ tui32 sescnt = 0; /* total session number */ tui32 sestmp = 0; /* additional total session number */ tui8 pktcnt = 0; /* packet session count */ tui32 totalcnt = 0; /* session counter */ tui8 continued = 0; /* continue flag */ int firstpkt = 1; /* "first packet" flag */ int idx; struct SCP_DISCONNECTED_SESSION *ds = 0; // tui8 addr[16]; init_stream(c->out_s, c->out_s->size); /* we request session list */ out_uint32_be(c->out_s, version); /* version */ out_uint32_be(c->out_s, size); /* size */ out_uint16_be(c->out_s, SCP_COMMAND_SET_MANAGE); /* cmdset */ out_uint16_be(c->out_s, cmd); /* cmd */ if (0 != scp_tcp_force_send(c->in_sck, c->out_s->data, size)) { log_message(LOG_LEVEL_WARNING, "[v1c_mng:%d] connection aborted: network error", __LINE__); return SCP_CLIENT_STATE_NETWORK_ERR; } do { /* then we wait for server response */ init_stream(c->in_s, c->in_s->size); if (0 != scp_tcp_force_recv(c->in_sck, c->in_s->data, 8)) { log_message(LOG_LEVEL_WARNING, "[v1c_mng:%d] connection aborted: network error", __LINE__); return SCP_CLIENT_STATE_NETWORK_ERR; } in_uint32_be(c->in_s, version); if (version != 1) { log_message(LOG_LEVEL_WARNING, "[v1c_mng:%d] connection aborted: version error", __LINE__); return SCP_CLIENT_STATE_VERSION_ERR; } in_uint32_be(c->in_s, size); if (size < 12) { log_message(LOG_LEVEL_WARNING, "[v1c_mng:%d] connection aborted: size error", __LINE__); return SCP_CLIENT_STATE_SIZE_ERR; } init_stream(c->in_s, c->in_s->size); if (0 != scp_tcp_force_recv(c->in_sck, c->in_s->data, size - 8)) { log_message(LOG_LEVEL_WARNING, "[v1c_mng:%d] connection aborted: network error", __LINE__); return SCP_CLIENT_STATE_NETWORK_ERR; } in_uint16_be(c->in_s, cmd); if (cmd != SCP_COMMAND_SET_MANAGE) { log_message(LOG_LEVEL_WARNING, "[v1c_mng:%d] connection aborted: sequence error", __LINE__); return SCP_CLIENT_STATE_SEQUENCE_ERR; } in_uint16_be(c->in_s, cmd); if (cmd != SCP_CMD_MNG_LIST) /* session list */ { log_message(LOG_LEVEL_WARNING, "[v1c_mng:%d] connection aborted: sequence error", __LINE__); return SCP_CLIENT_STATE_SEQUENCE_ERR; } if (firstpkt) { firstpkt = 0; in_uint32_be(c->in_s, sescnt); sestmp = sescnt; if (0 == sescnt) { /* return data... */ (*scount) = sescnt; (*s) = NULL; LOG_DBG("[v1c_mng] end list - no session on TS"); return SCP_CLIENT_STATE_LIST_OK; } ds = g_new(struct SCP_DISCONNECTED_SESSION, sescnt); if (ds == 0) { log_message(LOG_LEVEL_WARNING, "[v1c_mng:%d] connection aborted: internal error", __LINE__); return SCP_CLIENT_STATE_INTERNAL_ERR; } } else { in_uint32_be(c->in_s, sestmp); } in_uint8(c->in_s, continued); in_uint8(c->in_s, pktcnt); for (idx = 0; idx < pktcnt; idx++) { in_uint32_be(c->in_s, (ds[totalcnt]).SID); /* session id */ in_uint8(c->in_s, (ds[totalcnt]).type); in_uint16_be(c->in_s, (ds[totalcnt]).height); in_uint16_be(c->in_s, (ds[totalcnt]).width); in_uint8(c->in_s, (ds[totalcnt]).bpp); in_uint8(c->in_s, (ds[totalcnt]).idle_days); in_uint8(c->in_s, (ds[totalcnt]).idle_hours); in_uint8(c->in_s, (ds[totalcnt]).idle_minutes); in_uint16_be(c->in_s, (ds[totalcnt]).conn_year); in_uint8(c->in_s, (ds[totalcnt]).conn_month); in_uint8(c->in_s, (ds[totalcnt]).conn_day); in_uint8(c->in_s, (ds[totalcnt]).conn_hour); in_uint8(c->in_s, (ds[totalcnt]).conn_minute); in_uint8(c->in_s, (ds[totalcnt]).addr_type); if ((ds[totalcnt]).addr_type == SCP_ADDRESS_TYPE_IPV4) { in_uint32_be(c->in_s, (ds[totalcnt]).ipv4addr); } if ((ds[totalcnt]).addr_type == SCP_ADDRESS_TYPE_IPV6) { in_uint8a(c->in_s, (ds[totalcnt]).ipv6addr, 16); } totalcnt++; } } while (continued); /* return data... */ (*scount) = sescnt; (*s) = ds; LOG_DBG("[v1c_mng] end list"); return SCP_CLIENT_STATE_LIST_OK; } /* 043 * / enum SCP_CLIENT_STATES_E scp_v1c_select_session(struct SCP_CONNECTION* c, struct SCP_SESSION* s, SCP_SID sid) { tui32 version = 1; tui32 size = 16; tui16 cmd = 43; init_stream(c->out_s, c->out_s->size); / * sending our selection * / out_uint32_be(c->out_s, version); / * version * / out_uint32_be(c->out_s, size); / * size * / out_uint16_be(c->out_s, SCP_COMMAND_SET_DEFAULT); / * cmdset * / out_uint16_be(c->out_s, cmd); / * cmd * / out_uint32_be(c->out_s, sid); if (0 != scp_tcp_force_send(c->in_sck, c->out_s->data, size)) { return SCP_CLIENT_STATE_NETWORK_ERR; } / * waiting for response.... * / init_stream(c->in_s, c->in_s->size); if (0 != scp_tcp_force_recv(c->in_sck, c->in_s->data, 8)) { return SCP_CLIENT_STATE_NETWORK_ERR; } in_uint32_be(c->in_s, version); if (version != 1) { return SCP_CLIENT_STATE_VERSION_ERR; } in_uint32_be(c->in_s, size); if (size < 12) { return SCP_CLIENT_STATE_SIZE_ERR; } init_stream(c->in_s, c->in_s->size); / * read the rest of the packet * / if (0 != scp_tcp_force_recv(c->in_sck, c->in_s->data, size - 8)) { return SCP_CLIENT_STATE_NETWORK_ERR; } in_uint16_be(c->in_s, cmd); if (cmd != SCP_COMMAND_SET_DEFAULT) { return SCP_CLIENT_STATE_SEQUENCE_ERR; } in_uint16_be(c->in_s, cmd); if (cmd != 46) { return SCP_CLIENT_STATE_SEQUENCE_ERR; } / * session display * / in_uint16_be(c->in_s, (s->display)); / *we don't need to return any data other than the display * / / *because we already sent that * / return SCP_CLIENT_STATE_OK; }*/ /* 044 * / enum SCP_CLIENT_STATES_E scp_v1c_select_session_cancel(struct SCP_CONNECTION* c) { tui32 version = 1; tui32 size = 12; tui16 cmd = 44; init_stream(c->out_s, c->out_s->size); / * sending our selection * / out_uint32_be(c->out_s, version); / * version * / out_uint32_be(c->out_s, size); / * size * / out_uint16_be(c->out_s, SCP_COMMAND_SET_DEFAULT); / * cmdset * / out_uint16_be(c->out_s, cmd); / * cmd * / if (0 != scp_tcp_force_send(c->in_sck, c->out_s->data, size)) { return SCP_CLIENT_STATE_NETWORK_ERR; } return SCP_CLIENT_STATE_END; }*/ static enum SCP_CLIENT_STATES_E _scp_v1c_mng_check_response(struct SCP_CONNECTION *c, struct SCP_SESSION *s) { tui32 version; tui32 size; tui16 cmd; tui8 dim; char buf[257]; init_stream(c->in_s, c->in_s->size); if (0 != scp_tcp_force_recv(c->in_sck, c->in_s->data, 8)) { log_message(LOG_LEVEL_WARNING, "[v1c_mng:%d] connection aborted: network error", __LINE__); return SCP_CLIENT_STATE_NETWORK_ERR; } in_uint32_be(c->in_s, version); if (version != 1) { log_message(LOG_LEVEL_WARNING, "[v1c_mng:%d] connection aborted: version error", __LINE__); return SCP_CLIENT_STATE_VERSION_ERR; } in_uint32_be(c->in_s, size); init_stream(c->in_s, c->in_s->size); /* read the rest of the packet */ if (0 != scp_tcp_force_recv(c->in_sck, c->in_s->data, size - 8)) { log_message(LOG_LEVEL_WARNING, "[v1c_mng:%d] connection aborted: network error", __LINE__); return SCP_CLIENT_STATE_NETWORK_ERR; } in_uint16_be(c->in_s, cmd); if (cmd != SCP_COMMAND_SET_MANAGE) { log_message(LOG_LEVEL_WARNING, "[v1c_mng:%d] connection aborted: sequence error", __LINE__); return SCP_CLIENT_STATE_SEQUENCE_ERR; } in_uint16_be(c->in_s, cmd); if (cmd == SCP_CMD_MNG_LOGIN_ALLOW) /* connection ok */ { log_message(LOG_LEVEL_INFO, "[v1c_mng:%d] connection ok", __LINE__); return SCP_CLIENT_STATE_OK; } else if (cmd == SCP_CMD_MNG_LOGIN_DENY) /* connection denied */ { in_uint8(c->in_s, dim); buf[dim] = '\0'; in_uint8a(c->in_s, buf, dim); scp_session_set_errstr(s, buf); log_message(LOG_LEVEL_INFO, "[v1c_mng:%d] connection denied: %s", __LINE__ , s->errstr); return SCP_CLIENT_STATE_CONNECTION_DENIED; } log_message(LOG_LEVEL_WARNING, "[v1c-mng:%d] connection aborted: sequence error", __LINE__); return SCP_CLIENT_STATE_SEQUENCE_ERR; } xrdp-0.9.5/sesman/libscp/libscp_tcp.h000644 001751 001751 00000003031 13174271344 017462 0ustar00metameta000000 000000 /** * xrdp: A Remote Desktop Protocol server. * * Copyright (C) Jay Sorg 2004-2012 * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ /** * * @file libscp_tcp.h * @brief Tcp stream functions declarations * @author Jay Sorg, Simone Fedele * */ #ifndef LIBSCP_TCP_H #define LIBSCP_TCP_H #include "libscp.h" /** * * @brief Force receiving data from tcp stream * @param sck The socket to read from * @param data Data buffer * @param len Data buffer size * @return 0 on success, 1 on error * */ int scp_tcp_force_recv(int sck, char* data, int len); /** * * @brief Force sending data to tcp stream * @param sck the socket to write to * @param data Data buffer * @param len Data buffer size * @return 0 on success, 1 on error * */ int scp_tcp_force_send(int sck, char* data, int len); /** * * @brief Binds the listening socket * @param sck Listening socket * @param addr Listening address * @param port Listening port * @return 0 on success, -1 on error * */ int scp_tcp_bind(int sck, char* addr, char* port); #endif xrdp-0.9.5/sesman/libscp/libscp_lock.h000644 001751 001751 00000002745 13174271344 017637 0ustar00metameta000000 000000 /** * xrdp: A Remote Desktop Protocol server. * * Copyright (C) Jay Sorg 2004-2012 * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ #ifndef LIBSCP_LOCK_H #define LIBSCP_LOCK_H #include "libscp_types.h" #define LIBSCP_LOCK_FORK_BLOCKER 1 #define LIBSCP_LOCK_FORK_WAITING 0 /** * * @brief initializes all the locks * */ void scp_lock_init(void); /** * * @brief requires to fork a new child process * */ void scp_lock_fork_request(void); /** * * @brief releases a fork() request * */ void scp_lock_fork_release(void); /** * * @brief starts a section that is critical for forking * * starts a section that is critical for forking, that is no one can fork() * while I'm in a critical section. But if someone wanted to fork we have * to wait until he finishes with lock_fork_release() * * @return * */ int scp_lock_fork_critical_section_start(void); /** * * @brief closes the critical section * */ void scp_lock_fork_critical_section_end(int blocking); #endif xrdp-0.9.5/sesman/libscp/libscp_connection.h000644 001751 001751 00000002300 13125122134 021015 0ustar00metameta000000 000000 /** * xrdp: A Remote Desktop Protocol server. * * Copyright (C) Jay Sorg 2004-2012 * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ /** * * @file libscp_connection.h * @brief SCP_CONNECTION handling code * @author Simone Fedele * */ #ifndef LIBSCP_CONNECTION_H #define LIBSCP_CONNECTION_H #include "libscp.h" /** * * @brief creates a new connection * @param sck the connection socket * * @return a struct SCP_CONNECTION* object on success, NULL otherwise * */ struct SCP_CONNECTION* scp_connection_create(int sck); /** * * @brief destroys a struct SCP_CONNECTION* object * @param c the object to be destroyed * */ void scp_connection_destroy(struct SCP_CONNECTION* c); #endif xrdp-0.9.5/sesman/libscp/libscp_v1s.h000644 001751 001751 00000004732 13127114621 017406 0ustar00metameta000000 000000 /** * xrdp: A Remote Desktop Protocol server. * * Copyright (C) Jay Sorg 2004-2012 * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ /** * * @file libscp_v1s.h * @brief libscp version 1 server api declarations * @author Simone Fedele * */ #ifndef LIBSCP_V1S_H #define LIBSCP_V1S_H #include "libscp.h" /* server API */ /** * * @brief processes the stream using scp version 1 * @param c connection descriptor * @param s pointer to session descriptor pointer * @param skipVchk if set to !0 skips the version control (to be used after * scp_vXs_accept() ) * * this function places in *s the address of a newly allocated SCP_SESSION structure * that should be free()d */ enum SCP_SERVER_STATES_E scp_v1s_accept(struct SCP_CONNECTION* c, struct SCP_SESSION** s, int skipVchk); /** * * @brief denies connection to sesman * @param c connection descriptor * @param reason pointer to a string containing the reason for denying connection * */ /* 002 */ enum SCP_SERVER_STATES_E scp_v1s_deny_connection(struct SCP_CONNECTION* c, const char *reason); enum SCP_SERVER_STATES_E scp_v1s_request_password(struct SCP_CONNECTION* c, struct SCP_SESSION* s, const char *reason); /* 020 */ enum SCP_SERVER_STATES_E scp_v1s_request_pwd_change(struct SCP_CONNECTION* c, char* reason, char* npw); /* 023 */ enum SCP_SERVER_STATES_E scp_v1s_pwd_change_error(struct SCP_CONNECTION* c, char* error, int retry, char* npw); /* 030 */ enum SCP_SERVER_STATES_E scp_v1s_connect_new_session(struct SCP_CONNECTION* c, SCP_DISPLAY d); /* 032 */ enum SCP_SERVER_STATES_E scp_v1s_connection_error(struct SCP_CONNECTION* c, const char *error); /* 040 */ enum SCP_SERVER_STATES_E scp_v1s_list_sessions(struct SCP_CONNECTION* c, int sescnt, struct SCP_DISCONNECTED_SESSION* ds, SCP_SID* sid); /* 046 was: 031 struct SCP_DISCONNECTED_SESSION* ds, */ enum SCP_SERVER_STATES_E scp_v1s_reconnect_session(struct SCP_CONNECTION* c, SCP_DISPLAY d); #endif xrdp-0.9.5/sesman/libscp/libscp_types.h000644 001751 001751 00000006516 13165063445 020054 0ustar00metameta000000 000000 /** * xrdp: A Remote Desktop Protocol server. * * Copyright (C) Jay Sorg 2004-2012 * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ /** * * @file libscp_types.h * @brief libscp data types definitions * @author Simone Fedele * */ #ifndef LIBSCP_TYPES_H #define LIBSCP_TYPES_H #include "os_calls.h" #include "parse.h" #include "arch.h" #include "log.h" #define SCP_SID tui32 #define SCP_DISPLAY tui16 #define SCP_RESOURCE_SHARING_REQUEST_YES 0x01 #define SCP_RESOURCE_SHARING_REQUEST_NO 0x00 #define SCP_SESSION_TYPE_XVNC 0x00 #define SCP_SESSION_TYPE_XRDP 0x01 #define SCP_SESSION_TYPE_MANAGE 0x02 #define SCP_SESSION_TYPE_XORG 0x03 /* SCP_GW_AUTHENTICATION can be used when XRDP + sesman act as a gateway * XRDP sends this command to let sesman verify if the user is allowed * to use the gateway */ #define SCP_GW_AUTHENTICATION 0x04 #define SCP_ADDRESS_TYPE_IPV4 0x00 #define SCP_ADDRESS_TYPE_IPV6 0x01 #define SCP_COMMAND_SET_DEFAULT 0x0000 #define SCP_COMMAND_SET_MANAGE 0x0001 #define SCP_COMMAND_SET_RSR 0x0002 #define SCP_SERVER_MAX_LIST_SIZE 100 #include "libscp_types_mng.h" struct SCP_CONNECTION { int in_sck; struct stream* in_s; struct stream* out_s; }; struct SCP_SESSION { tui8 type; tui32 version; tui16 height; tui16 width; tui8 bpp; tui8 rsr; char locale[18]; char* username; char* password; char* hostname; tui8 addr_type; tui32 ipv4addr; tui8 ipv6addr[16]; SCP_DISPLAY display; char* errstr; struct SCP_MNG_DATA* mng; char* domain; char* program; char* directory; char* client_ip; tui8 guid[16]; }; struct SCP_DISCONNECTED_SESSION { tui32 SID; tui8 type; tui8 status; tui16 height; tui16 width; tui8 bpp; tui8 idle_days; tui8 idle_hours; tui8 idle_minutes; tui16 conn_year; tui8 conn_month; tui8 conn_day; tui8 conn_hour; tui8 conn_minute; tui8 addr_type; tui32 ipv4addr; tui8 ipv6addr[16]; }; enum SCP_CLIENT_STATES_E { SCP_CLIENT_STATE_OK, SCP_CLIENT_STATE_NETWORK_ERR, SCP_CLIENT_STATE_VERSION_ERR, SCP_CLIENT_STATE_SEQUENCE_ERR, SCP_CLIENT_STATE_SIZE_ERR, SCP_CLIENT_STATE_INTERNAL_ERR, SCP_CLIENT_STATE_SESSION_LIST, SCP_CLIENT_STATE_LIST_OK, SCP_CLIENT_STATE_RESEND_CREDENTIALS, SCP_CLIENT_STATE_CONNECTION_DENIED, SCP_CLIENT_STATE_PWD_CHANGE_REQ, SCP_CLIENT_STATE_RECONNECT_SINGLE, SCP_CLIENT_STATE_SELECTION_CANCEL, SCP_CLIENT_STATE_END }; enum SCP_SERVER_STATES_E { SCP_SERVER_STATE_OK, SCP_SERVER_STATE_VERSION_ERR, SCP_SERVER_STATE_NETWORK_ERR, SCP_SERVER_STATE_SEQUENCE_ERR, SCP_SERVER_STATE_INTERNAL_ERR, SCP_SERVER_STATE_SESSION_TYPE_ERR, SCP_SERVER_STATE_SIZE_ERR, SCP_SERVER_STATE_SELECTION_CANCEL, /*SCP_SERVER_STATE_FORCE_NEW,*/ SCP_SERVER_STATE_START_MANAGE, SCP_SERVER_STATE_MNG_LISTREQ, SCP_SERVER_STATE_MNG_ACTION, SCP_SERVER_STATE_END }; #endif xrdp-0.9.5/sesman/chansrv/devredir.h000644 001751 001751 00000031027 13174271344 017342 0ustar00metameta000000 000000 /** * xrdp: A Remote Desktop Protocol server. * * xrdp device redirection - we mainly use it for drive redirection * * Copyright (C) Laxmikant Rashinkar 2013 LK.Rashinkar@gmail.com * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ // LK_TODO dev_redir_xxx should become devredir_xxx #if !defined(DEVREDIR_H) #define DEVREDIR_H #include "irp.h" #define USE_SHORT_NAMES_IN_DIR_LISTING FUSE_DATA *devredir_fuse_data_peek(IRP *irp); FUSE_DATA *devredir_fuse_data_dequeue(IRP *irp); int devredir_fuse_data_enqueue(IRP *irp, void *vp); int dev_redir_init(void); int dev_redir_deinit(void); int dev_redir_data_in(struct stream* s, int chan_id, int chan_flags, int length, int total_length); int dev_redir_get_wait_objs(tbus* objs, int* count, int* timeout); int dev_redir_check_wait_objs(void); void dev_redir_send_server_core_cap_req(void); void dev_redir_send_server_clientID_confirm(void); void dev_redir_send_server_user_logged_on(void); void devredir_send_server_device_announce_resp(tui32 device_id); void dev_redir_send_drive_dir_request(IRP *irp, tui32 device_id, tui32 InitialQuery, char *Path); int dev_redir_send_drive_create_request(tui32 device_id, const char *path, tui32 DesiredAccess, tui32 CreateOptions, tui32 CreateDisposition, tui32 completion_id); int dev_redir_send_drive_close_request(tui16 Component, tui16 PacketId, tui32 DeviceId, tui32 FileId, tui32 CompletionId, tui32 MajorFunction, tui32 MinorFunc, int pad_len); void devredir_proc_client_devlist_announce_req(struct stream *s); void dev_redir_proc_client_core_cap_resp(struct stream *s); void dev_redir_proc_device_iocompletion(struct stream *s); void dev_redir_proc_query_dir_response(IRP *irp, struct stream *s, tui32 DeviceId, tui32 CompletionId, tui32 IoStatus); /* misc stuff */ void devredir_insert_DeviceIoRequest(struct stream *s, tui32 DeviceId, tui32 FileId, tui32 CompletionId, tui32 MajorFunction, tui32 MinorFunction); void devredir_cvt_slash(char *path); void devredir_cvt_to_unicode(char *unicode, const char *path); void devredir_cvt_from_unicode_len(char *path, char *unicode, int len); int dev_redir_string_ends_with(char *string, char c); void devredir_insert_RDPDR_header(struct stream *s, tui16 Component, tui16 PacketId); void devredir_proc_cid_rmdir_or_file(IRP *irp, tui32 IoStatus); void devredir_proc_cid_rmdir_or_file_resp(IRP *irp, tui32 IoStatus); void devredir_proc_cid_rename_file(IRP *irp, tui32 IoStatus); void devredir_proc_cid_rename_file_resp(IRP *irp, tui32 IoStatus); /* called from FUSE module */ int dev_redir_get_dir_listing(void *fusep, tui32 device_id, const char *path); int dev_redir_file_open(void *fusep, tui32 device_id, const char *path, int mode, int type, const char *gen_buf); int devredir_file_close(void *fusep, tui32 device_id, tui32 file_id); int devredir_file_read(void *fusep, tui32 device_id, tui32 FileId, tui32 Length, tui64 Offset); int dev_redir_file_write(void *fusep, tui32 DeviceId, tui32 FileId, const char *buf, int Length, tui64 Offset); int devredir_rmdir_or_file(void *fusep, tui32 device_id, const char *path, int mode); /* * RDPDR_HEADER definitions */ /* device redirector core component; most of the packets in this protocol */ /* are sent under this component ID */ #define RDPDR_CTYP_CORE 0x4472 /* printing component. the packets that use this ID are typically about */ /* printer cache management and identifying XPS printers */ #define RDPDR_CTYP_PRN 0x5052 /* Server Announce Request, as specified in section 2.2.2.2 */ #define PAKID_CORE_SERVER_ANNOUNCE 0x496E /* Client Announce Reply and Server Client ID Confirm, as specified in */ /* sections 2.2.2.3 and 2.2.2.6. */ #define PAKID_CORE_CLIENTID_CONFIRM 0x4343 /* Client Name Request, as specified in section 2.2.2.4 */ #define PAKID_CORE_CLIENT_NAME 0x434E /* Client Device List Announce Request, as specified in section 2.2.2.9 */ #define PAKID_CORE_DEVICELIST_ANNOUNCE 0x4441 /* Server Device Announce Response, as specified in section 2.2.2.1 */ #define PAKID_CORE_DEVICE_REPLY 0x6472 /* Device I/O Request, as specified in section 2.2.1.4 */ #define PAKID_CORE_DEVICE_IOREQUEST 0x4952 /* Device I/O Response, as specified in section 2.2.1.5 */ #define PAKID_CORE_DEVICE_IOCOMPLETION 0x4943 /* Server Core Capability Request, as specified in section 2.2.2.7 */ #define PAKID_CORE_SERVER_CAPABILITY 0x5350 /* Client Core Capability Response, as specified in section 2.2.2.8 */ #define PAKID_CORE_CLIENT_CAPABILITY 0x4350 /* Client Drive Device List Remove, as specified in section 2.2.3.2 */ #define PAKID_CORE_DEVICELIST_REMOVE 0x444D /* Add Printer Cachedata, as specified in [MS-RDPEPC] section 2.2.2.3 */ #define PAKID_PRN_CACHE_DATA 0x5043 /* Server User Logged On, as specified in section 2.2.2.5 */ #define PAKID_CORE_USER_LOGGEDON 0x554C /* Server Printer Set XPS Mode, as specified in [MS-RDPEPC] section 2.2.2.2 */ #define PAKID_PRN_USING_XPS 0x5543 /* * Capability header definitions */ #define CAP_GENERAL_TYPE 0x0001 /* General cap set - GENERAL_CAPS_SET */ #define CAP_PRINTER_TYPE 0x0002 /* Print cap set - PRINTER_CAPS_SET */ #define CAP_PORT_TYPE 0x0003 /* Port cap set - PORT_CAPS_SET */ #define CAP_DRIVE_TYPE 0x0004 /* Drive cap set - DRIVE_CAPS_SET */ #define CAP_SMARTCARD_TYPE 0x0005 /* Smart card cap set - SMARTCARD_CAPS_SET */ /* client minor versions */ #define RDP_CLIENT_50 0x0002 #define RDP_CLIENT_51 0x0005 #define RDP_CLIENT_52 0x000a #define RDP_CLIENT_60_61 0x000c /* used in device announce list */ #define RDPDR_DTYP_SERIAL 0x0001 #define RDPDR_DTYP_PARALLEL 0x0002 #define RDPDR_DTYP_PRINT 0x0004 #define RDPDR_DTYP_FILESYSTEM 0x0008 #define RDPDR_DTYP_SMARTCARD 0x0020 /* * DesiredAccess Mask [MS-SMB2] section 2.2.13.1.1 */ #define DA_FILE_READ_DATA 0x00000001 #define DA_FILE_WRITE_DATA 0x00000002 #define DA_FILE_APPEND_DATA 0x00000004 #define DA_FILE_READ_EA 0x00000008 /* rd extended attributes */ #define DA_FILE_WRITE_EA 0x00000010 /* wr extended attributes */ #define DA_FILE_EXECUTE 0x00000020 #define DA_FILE_READ_ATTRIBUTES 0x00000080 #define DA_FILE_WRITE_ATTRIBUTES 0x00000100 #define DA_DELETE 0x00010000 #define DA_READ_CONTROL 0x00020000 /* rd security descriptor */ #define DA_WRITE_DAC 0x00040000 #define DA_WRITE_OWNER 0x00080000 #define DA_SYNCHRONIZE 0x00100000 #define DA_ACCESS_SYSTEM_SECURITY 0x01000000 #define DA_MAXIMUM_ALLOWED 0x02000000 #define DA_GENERIC_ALL 0x10000000 #define DA_GENERIC_EXECUTE 0x20000000 #define DA_GENERIC_WRITE 0x40000000 #define DA_GENERIC_READ 0x80000000 /* * CreateOptions Mask [MS-SMB2] section 2.2.13 SMB2 CREATE Request */ enum CREATE_OPTIONS { CO_FILE_DIRECTORY_FILE = 0x00000001, CO_FILE_WRITE_THROUGH = 0x00000002, CO_FILE_SYNCHRONOUS_IO_NONALERT = 0x00000020, CO_FILE_DELETE_ON_CLOSE = 0x00001000 }; /* * CreateDispositions Mask [MS-SMB2] section 2.2.13 */ #define CD_FILE_SUPERSEDE 0x00000000 #define CD_FILE_OPEN 0x00000001 #define CD_FILE_CREATE 0x00000002 #define CD_FILE_OPEN_IF 0x00000003 #define CD_FILE_OVERWRITE 0x00000004 #define CD_FILE_OVERWRITE_IF 0x00000005 /* * Device I/O Request MajorFunction definitions */ #define IRP_MJ_CREATE 0x00000000 #define IRP_MJ_CLOSE 0x00000002 #define IRP_MJ_READ 0x00000003 #define IRP_MJ_WRITE 0x00000004 #define IRP_MJ_DEVICE_CONTROL 0x0000000E #define IRP_MJ_QUERY_VOLUME_INFORMATION 0x0000000A #define IRP_MJ_SET_VOLUME_INFORMATION 0x0000000B #define IRP_MJ_QUERY_INFORMATION 0x00000005 #define IRP_MJ_SET_INFORMATION 0x00000006 #define IRP_MJ_DIRECTORY_CONTROL 0x0000000C #define IRP_MJ_LOCK_CONTROL 0x00000011 /* * Device I/O Request MinorFunction definitions * * Only valid when MajorFunction code = IRP_MJ_DIRECTORY_CONTROL */ #define IRP_MN_QUERY_DIRECTORY 0x00000001 #define IRP_MN_NOTIFY_CHANGE_DIRECTORY 0x00000002 /* * NTSTATUS codes (used by IoStatus) */ #define NT_STATUS_SUCCESS 0x00000000 #define NT_STATUS_UNSUCCESSFUL 0xC0000001 /* * File system ioctl codes * MS-FSCC section 2.3 FSCTL Structures */ #define FSCTL_DELETE_OBJECT_ID 0x900a0 /* * CompletionID types, used in IRPs to indicate I/O operation */ enum COMPLETION_ID { CID_CREATE_DIR_REQ = 1, CID_DIRECTORY_CONTROL, CID_CREATE_OPEN_REQ, CID_READ, CID_WRITE, CID_CLOSE, CID_FILE_CLOSE, CID_RMDIR_OR_FILE, CID_RMDIR_OR_FILE_RESP, CID_RENAME_FILE, CID_RENAME_FILE_RESP }; enum FS_INFORMATION_CLASS { FileBasicInformation = 0x00000004, /* set atime, mtime, ctime etc */ FileEndOfFileInformation = 0x00000014, /* set EOF info */ FileDispositionInformation = 0x0000000D, /* mark a file for deletion */ FileRenameInformation = 0x0000000A, /* rename a file */ FileAllocationInformation = 0x00000013 /* set file allocation size */ }; /* * constants for drive dir query */ /* Basic information about a file or directory. Basic information is */ /* defined as the file's name, time stamp, and size, or its attributes */ #define FileDirectoryInformation 0x00000001 /* Full information about a file or directory. Full information is defined */ /* as all the basic information, plus extended attribute size. */ #define FileFullDirectoryInformation 0x00000002 /* Basic information plus extended attribute size and short name */ /* about a file or directory. */ #define FileBothDirectoryInformation 0x00000003 /* Detailed information on the names of files in a directory. */ #define FileNamesInformation 0x0000000C /* * NTSTATUS Codes of interest to us */ /* No more files were found which match the file specification */ #define STATUS_NO_MORE_FILES 0x80000006 /* Windows file attributes */ #define W_FILE_ATTRIBUTE_DIRECTORY 0x00000010 #define W_FILE_ATTRIBUTE_READONLY 0x00000001 #define WINDOWS_TO_LINUX_FILE_PERM(_a) \ (((_a) & W_FILE_ATTRIBUTE_DIRECTORY) ? S_IFDIR | 0100 : S_IFREG) |\ (((_a) & W_FILE_ATTRIBUTE_READONLY) ? 0444 : 0644) /* Windows time starts on Jan 1, 1601 */ /* Linux time starts on Jan 1, 1970 */ #define EPOCH_DIFF 11644473600LL #define WINDOWS_TO_LINUX_TIME(_t) ((_t) / 10000000) - EPOCH_DIFF; #define OP_RENAME_FILE 0x01 #endif xrdp-0.9.5/sesman/chansrv/drdynvc.h000644 001751 001751 00000004060 13174271344 017204 0ustar00metameta000000 000000 /** * xrdp: A Remote Desktop Protocol server. * * Copyright (C) Laxmikant Rashinkar 2012 LK.Rashinkar@gmail.com * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ #ifndef _DRDYNVC_H_ #define _DRDYNVC_H_ #include #include #include #include #include "arch.h" #include "chansrv.h" #include "xcommon.h" #include "log.h" #include "os_calls.h" #include "trans.h" /* move this to tsmf.c */ #define TSMF_CHAN_ID 0x1000 /* get number of bytes in stream before s->p */ #define stream_length_before_p(s) (int) ((s)->p - (s)->data) /* get number of bytes in stream after s->p */ #define stream_length_after_p(s) (int) ((s)->end - (s)->p) #define rewind_stream(s) do \ { \ (s)->p = (s)->data; \ (s)->end = (s)->data; \ } while (0) /* max number of bytes we can send in one pkt */ #define MAX_PDU_SIZE 1600 /* commands used to manage dynamic virtual channels */ #define CMD_DVC_OPEN_CHANNEL 0x10 #define CMD_DVC_DATA_FIRST 0x20 #define CMD_DVC_DATA 0x30 #define CMD_DVC_CLOSE_CHANNEL 0x40 #define CMD_DVC_CAPABILITY 0x50 int drdynvc_init(void); int drdynvc_send_open_channel_request(int chan_pri, unsigned int chan_id, char *chan_name); int drdynvc_send_close_channel_request(unsigned int chan_id); int drdynvc_write_data(uint32_t chan_id, char *data, int data_size); int drdynvc_data_in(struct stream* s, int chan_id, int chan_flags, int length, int total_length); #endif xrdp-0.9.5/sesman/chansrv/rail.h000644 001751 001751 00000001722 13174271344 016464 0ustar00metameta000000 000000 /** * xrdp: A Remote Desktop Protocol server. * * Copyright (C) Jay Sorg 2012 * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ #ifndef _RAIL_H_ #define _RAIL_H_ #include "../../common/rail.h" #include "arch.h" #include "parse.h" int rail_init(void); int rail_deinit(void); int rail_data_in(struct stream* s, int chan_id, int chan_flags, int length, int total_length); int rail_xevent(void* xevent); int rail_request_title(int window_id); #endif xrdp-0.9.5/sesman/chansrv/chansrv_fuse.h000644 001751 001751 00000006604 13133557325 020230 0ustar00metameta000000 000000 /** * xrdp: A Remote Desktop Protocol server. * * Copyright (C) Laxmikant Rashinkar 2013 LK.Rashinkar@gmail.com * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ #ifndef _CHANSRV_FUSE_H #define _CHANSRV_FUSE_H /* a file or dir entry in the xrdp file system */ struct xrdp_inode { tui32 parent_inode; /* Parent serial number. */ tui32 inode; /* File serial number. */ tui32 mode; /* File mode. */ tui32 nlink; /* symbolic link count. */ tui32 nentries; /* number of entries in a dir */ tui32 nopen; /* number of simultaneous opens */ tui32 uid; /* User ID of the file's owner. */ tui32 gid; /* Group ID of the file's group. */ size_t size; /* Size of file, in bytes. */ time_t atime; /* Time of last access. */ time_t mtime; /* Time of last modification. */ time_t ctime; /* Time of last status change. */ char name[1024]; /* Dir or filename */ tui32 device_id; /* for file system redirection */ char is_synced; /* dir struct has been read from */ /* remote device, done just once */ int lindex; /* used in clipboard operations */ int is_loc_resource; /* this is not a redirected resource */ int close_in_progress; /* close cmd sent to client */ int stale; /* mark file as stale, ok to remove */ }; typedef struct xrdp_inode XRDP_INODE; // LK_TODO use this instead of using struct xrdp_inode int xfuse_init(void); int xfuse_deinit(void); int xfuse_check_wait_objs(void); int xfuse_get_wait_objs(tbus *objs, int *count, int *timeout); int xfuse_create_share(tui32 share_id, const char *dirname); int xfuse_clear_clip_dir(void); int xfuse_file_contents_range(int stream_id, const char *data, int data_bytes); int xfuse_file_contents_size(int stream_id, int file_size); int xfuse_add_clip_dir_item(const char *filename, int flags, int size, int lindex); /* functions that are invoked from devredir */ int xfuse_devredir_cb_enum_dir(void *vp, struct xrdp_inode *xinode); void xfuse_devredir_cb_enum_dir_done(void *vp, tui32 IoStatus); void xfuse_devredir_cb_open_file(void *vp, tui32 IoStatus, tui32 DeviceId, tui32 FileId); void xfuse_devredir_cb_read_file(void *vp, const char *buf, size_t length); void xfuse_devredir_cb_rmdir_or_file(void *vp, tui32 IoStatus); void xfuse_devredir_cb_rename_file(void *vp, tui32 IoStatus); void xfuse_devredir_cb_file_close(void *vp); #endif xrdp-0.9.5/sesman/chansrv/pcsc/000755 001751 001751 00000000000 13142013036 016275 5ustar00metameta000000 000000 xrdp-0.9.5/sesman/chansrv/xcommon.h000644 001751 001751 00000001750 13174271344 017216 0ustar00metameta000000 000000 /** * xrdp: A Remote Desktop Protocol server. * * Copyright (C) Jay Sorg 2012 * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ #if !defined(XCOMMON_H) #define XCOMMON_H #include "arch.h" #include "parse.h" /* 32 implies long */ #define FORMAT_TO_BYTES(_format) \ (_format) == 32 ? sizeof(long) : (_format) / 8 int xcommon_get_local_time(void); int xcommon_init(void); int xcommon_get_wait_objs(tbus* objs, int* count, int* timeout); int xcommon_check_wait_objs(void); #endif xrdp-0.9.5/sesman/chansrv/wave-format-server.txt000644 001751 001751 00000140405 13127114621 021653 0ustar00metameta000000 000000 Example wave formats from some servers see MMREG.H for defines Windows 7 SP1 example wave data sizes coming from server 8820 wFormatTag=1 nChannels=2 nSamplesPerSec=44100 nAvgBytesPerSec=176400 nBlockAlign=4 wBitsPerSample=16 cbSize=0 #define WAVE_FORMAT_ALAW 0x0006 /* Microsoft Corporation */ wFormatTag=6 nChannels=2 nSamplesPerSec=44100 nAvgBytesPerSec=88200 nBlockAlign=2 wBitsPerSample=8 cbSize=0 #define WAVE_FORMAT_MULAW 0x0007 /* Microsoft Corporation */ wFormatTag=7 nChannels=2 nSamplesPerSec=44100 nAvgBytesPerSec=88200 nBlockAlign=2 wBitsPerSample=8 cbSize=0 #define WAVE_FORMAT_ADPCM 0x0002 /* Microsoft Corporation */ wFormatTag=2 nChannels=2 nSamplesPerSec=44100 nAvgBytesPerSec=44359 nBlockAlign=2048 wBitsPerSample=4 cbSize=32 0000 f4 07 07 00 00 01 00 00 00 02 00 ff 00 00 00 00 ................ 0010 c0 00 40 00 f0 00 00 00 cc 01 30 ff 88 01 18 ff ..@.......0..... #define WAVE_FORMAT_DVI_ADPCM 0x0011 /* Intel Corporation */ wFormatTag=17 nChannels=2 nSamplesPerSec=44100 nAvgBytesPerSec=44251 nBlockAlign=2048 wBitsPerSample=4 cbSize=2 0000 f9 07 .. #define WAVE_FORMAT_ALAW 0x0006 /* Microsoft Corporation */ wFormatTag=6 nChannels=2 nSamplesPerSec=22050 nAvgBytesPerSec=44100 nBlockAlign=2 wBitsPerSample=8 cbSize=0 #define WAVE_FORMAT_ALAW 0x0006 /* Microsoft Corporation */ wFormatTag=6 nChannels=1 nSamplesPerSec=44100 nAvgBytesPerSec=44100 nBlockAlign=1 wBitsPerSample=8 cbSize=0 #define WAVE_FORMAT_MULAW 0x0007 /* Microsoft Corporation */ wFormatTag=7 nChannels=2 nSamplesPerSec=22050 nAvgBytesPerSec=44100 nBlockAlign=2 wBitsPerSample=8 cbSize=0 #define WAVE_FORMAT_MULAW 0x0007 /* Microsoft Corporation */ wFormatTag=7 nChannels=1 nSamplesPerSec=44100 nAvgBytesPerSec=44100 nBlockAlign=1 wBitsPerSample=8 cbSize=0 #define WAVE_FORMAT_ADPCM 0x0002 /* Microsoft Corporation */ wFormatTag=2 nChannels=2 nSamplesPerSec=22050 nAvgBytesPerSec=22311 nBlockAlign=1024 wBitsPerSample=4 cbSize=32 0000 f4 03 07 00 00 01 00 00 00 02 00 ff 00 00 00 00 ................ 0010 c0 00 40 00 f0 00 00 00 cc 01 30 ff 88 01 18 ff ..@.......0..... #define WAVE_FORMAT_DVI_ADPCM 0x0011 /* Intel Corporation */ wFormatTag=17 nChannels=2 nSamplesPerSec=22050 nAvgBytesPerSec=22201 nBlockAlign=1024 wBitsPerSample=4 cbSize=2 0000 f9 03 .. #define WAVE_FORMAT_ADPCM 0x0002 /* Microsoft Corporation */ wFormatTag=2 nChannels=1 nSamplesPerSec=44100 nAvgBytesPerSec=22179 nBlockAlign=1024 wBitsPerSample=4 cbSize=32 0000 f4 07 07 00 00 01 00 00 00 02 00 ff 00 00 00 00 ................ 0010 c0 00 40 00 f0 00 00 00 cc 01 30 ff 88 01 18 ff ..@.......0..... #define WAVE_FORMAT_DVI_ADPCM 0x0011 /* Intel Corporation */ wFormatTag=17 nChannels=1 nSamplesPerSec=44100 nAvgBytesPerSec=22125 nBlockAlign=1024 wBitsPerSample=4 cbSize=2 0000 f9 07 .. #define WAVE_FORMAT_ALAW 0x0006 /* Microsoft Corporation */ wFormatTag=6 nChannels=2 nSamplesPerSec=11025 nAvgBytesPerSec=22050 nBlockAlign=2 wBitsPerSample=8 cbSize=0 #define WAVE_FORMAT_ALAW 0x0006 /* Microsoft Corporation */ wFormatTag=6 nChannels=1 nSamplesPerSec=22050 nAvgBytesPerSec=22050 nBlockAlign=1 wBitsPerSample=8 cbSize=0 #define WAVE_FORMAT_MULAW 0x0007 /* Microsoft Corporation */ wFormatTag=7 nChannels=2 nSamplesPerSec=11025 nAvgBytesPerSec=22050 nBlockAlign=2 wBitsPerSample=8 cbSize=0 #define WAVE_FORMAT_MULAW 0x0007 /* Microsoft Corporation */ wFormatTag=7 nChannels=1 nSamplesPerSec=22050 nAvgBytesPerSec=22050 nBlockAlign=1 wBitsPerSample=8 cbSize=0 #define WAVE_FORMAT_ALAW 0x0006 /* Microsoft Corporation */ wFormatTag=6 nChannels=2 nSamplesPerSec=8000 nAvgBytesPerSec=16000 nBlockAlign=2 wBitsPerSample=8 cbSize=0 #define WAVE_FORMAT_MULAW 0x0007 /* Microsoft Corporation */ wFormatTag=7 nChannels=2 nSamplesPerSec=8000 nAvgBytesPerSec=16000 nBlockAlign=2 wBitsPerSample=8 cbSize=0 #define WAVE_FORMAT_ADPCM 0x0002 /* Microsoft Corporation */ wFormatTag=2 nChannels=2 nSamplesPerSec=11025 nAvgBytesPerSec=11289 nBlockAlign=512 wBitsPerSample=4 cbSize=32 0000 f4 01 07 00 00 01 00 00 00 02 00 ff 00 00 00 00 ................ 0010 c0 00 40 00 f0 00 00 00 cc 01 30 ff 88 01 18 ff ..@.......0..... #define WAVE_FORMAT_DVI_ADPCM 0x0011 /* Intel Corporation */ wFormatTag=17 nChannels=2 nSamplesPerSec=11025 nAvgBytesPerSec=11177 nBlockAlign=512 wBitsPerSample=4 cbSize=2 0000 f9 01 .. #define WAVE_FORMAT_ADPCM 0x0002 /* Microsoft Corporation */ wFormatTag=2 nChannels=1 nSamplesPerSec=22050 nAvgBytesPerSec=11155 nBlockAlign=512 wBitsPerSample=4 cbSize=32 0000 f4 03 07 00 00 01 00 00 00 02 00 ff 00 00 00 00 ................ 0010 c0 00 40 00 f0 00 00 00 cc 01 30 ff 88 01 18 ff ..@.......0..... #define WAVE_FORMAT_DVI_ADPCM 0x0011 /* Intel Corporation */ wFormatTag=17 nChannels=1 nSamplesPerSec=22050 nAvgBytesPerSec=11100 nBlockAlign=512 wBitsPerSample=4 cbSize=2 0000 f9 03 .. #define WAVE_FORMAT_ALAW 0x0006 /* Microsoft Corporation */ wFormatTag=6 nChannels=1 nSamplesPerSec=11025 nAvgBytesPerSec=11025 nBlockAlign=1 wBitsPerSample=8 cbSize=0 #define WAVE_FORMAT_MULAW 0x0007 /* Microsoft Corporation */ wFormatTag=7 nChannels=1 nSamplesPerSec=11025 nAvgBytesPerSec=11025 nBlockAlign=1 wBitsPerSample=8 cbSize=0 wFormatTag=49 nChannels=1 nSamplesPerSec=44100 nAvgBytesPerSec=8957 nBlockAlign=65 wBitsPerSample=0 cbSize=2 0000 40 01 @. #define WAVE_FORMAT_ADPCM 0x0002 /* Microsoft Corporation */ wFormatTag=2 nChannels=2 nSamplesPerSec=8000 nAvgBytesPerSec=8192 nBlockAlign=512 wBitsPerSample=4 cbSize=32 0000 f4 01 07 00 00 01 00 00 00 02 00 ff 00 00 00 00 ................ 0010 c0 00 40 00 f0 00 00 00 cc 01 30 ff 88 01 18 ff ..@.......0..... #define WAVE_FORMAT_DVI_ADPCM 0x0011 /* Intel Corporation */ wFormatTag=17 nChannels=2 nSamplesPerSec=8000 nAvgBytesPerSec=8110 nBlockAlign=512 wBitsPerSample=4 cbSize=2 0000 f9 01 .. #define WAVE_FORMAT_ALAW 0x0006 /* Microsoft Corporation */ wFormatTag=6 nChannels=1 nSamplesPerSec=8000 nAvgBytesPerSec=8000 nBlockAlign=1 wBitsPerSample=8 cbSize=0 #define WAVE_FORMAT_MULAW 0x0007 /* Microsoft Corporation */ wFormatTag=7 nChannels=1 nSamplesPerSec=8000 nAvgBytesPerSec=8000 nBlockAlign=1 wBitsPerSample=8 cbSize=0 wFormatTag=2 nChannels=1 nSamplesPerSec=11025 nAvgBytesPerSec=5644 nBlockAlign=256 wBitsPerSample=4 cbSize=32 0000 f4 01 07 00 00 01 00 00 00 02 00 ff 00 00 00 00 ................ 0010 c0 00 40 00 f0 00 00 00 cc 01 30 ff 88 01 18 ff ..@.......0..... wFormatTag=17 nChannels=1 nSamplesPerSec=11025 nAvgBytesPerSec=5588 nBlockAlign=256 wBitsPerSample=4 cbSize=2 0000 f9 01 .. #define WAVE_FORMAT_GSM610 0x0031 /* Microsoft Corporation */ wFormatTag=49 nChannels=1 nSamplesPerSec=22050 nAvgBytesPerSec=4478 nBlockAlign=65 wBitsPerSample=0 cbSize=2 0000 40 01 @. #define WAVE_FORMAT_ADPCM 0x0002 /* Microsoft Corporation */ wFormatTag=2 nChannels=1 nSamplesPerSec=8000 nAvgBytesPerSec=4096 nBlockAlign=256 wBitsPerSample=4 cbSize=32 0000 f4 01 07 00 00 01 00 00 00 02 00 ff 00 00 00 00 ................ 0010 c0 00 40 00 f0 00 00 00 cc 01 30 ff 88 01 18 ff ..@.......0..... #define WAVE_FORMAT_DVI_ADPCM 0x0011 /* Intel Corporation */ wFormatTag=17 nChannels=1 nSamplesPerSec=8000 nAvgBytesPerSec=4055 nBlockAlign=256 wBitsPerSample=4 cbSize=2 0000 f9 01 .. #define WAVE_FORMAT_GSM610 0x0031 /* Microsoft Corporation */ wFormatTag=49 nChannels=1 nSamplesPerSec=11025 nAvgBytesPerSec=2239 nBlockAlign=65 wBitsPerSample=0 cbSize=2 0000 40 01 @. #define WAVE_FORMAT_GSM610 0x0031 /* Microsoft Corporation */ wFormatTag=49 nChannels=1 nSamplesPerSec=8000 nAvgBytesPerSec=1625 nBlockAlign=65 wBitsPerSample=0 cbSize=2 0000 40 01 @. Windows XP SP3 example wave data sizes coming from server 32512, 16256 wFormatTag=1 nChannels=2 nSamplesPerSec=22050 nAvgBytesPerSec=88200 nBlockAlign=4 wBitsPerSample=16 cbSize=0 #define WAVE_FORMAT_ALAW 0x0006 /* Microsoft Corporation */ wFormatTag=6 nChannels=2 nSamplesPerSec=22050 nAvgBytesPerSec=44100 nBlockAlign=2 wBitsPerSample=8 cbSize=0 #define WAVE_FORMAT_MULAW 0x0007 /* Microsoft Corporation */ wFormatTag=7 nChannels=2 nSamplesPerSec=22050 nAvgBytesPerSec=44100 nBlockAlign=2 wBitsPerSample=8 cbSize=0 #define WAVE_FORMAT_ADPCM 0x0002 /* Microsoft Corporation */ wFormatTag=2 nChannels=2 nSamplesPerSec=22050 nAvgBytesPerSec=22311 nBlockAlign=1024 wBitsPerSample=4 cbSize=32 0000 f4 03 07 00 00 01 00 00 00 02 00 ff 00 00 00 00 ................ 0010 c0 00 40 00 f0 00 00 00 cc 01 30 ff 88 01 18 ff ..@.......0..... #define WAVE_FORMAT_DVI_ADPCM 0x0011 /* Intel Corporation */ wFormatTag=17 nChannels=2 nSamplesPerSec=22050 nAvgBytesPerSec=22201 nBlockAlign=1024 wBitsPerSample=4 cbSize=2 0000 f9 03 .. #define WAVE_FORMAT_ALAW 0x0006 /* Microsoft Corporation */ wFormatTag=6 nChannels=2 nSamplesPerSec=11025 nAvgBytesPerSec=22050 nBlockAlign=2 wBitsPerSample=8 cbSize=0 #define WAVE_FORMAT_ALAW 0x0006 /* Microsoft Corporation */ wFormatTag=6 nChannels=1 nSamplesPerSec=22050 nAvgBytesPerSec=22050 nBlockAlign=1 wBitsPerSample=8 cbSize=0 #define WAVE_FORMAT_MULAW 0x0007 /* Microsoft Corporation */ wFormatTag=7 nChannels=2 nSamplesPerSec=11025 nAvgBytesPerSec=22050 nBlockAlign=2 wBitsPerSample=8 cbSize=0 #define WAVE_FORMAT_MULAW 0x0007 /* Microsoft Corporation */ wFormatTag=7 nChannels=1 nSamplesPerSec=22050 nAvgBytesPerSec=22050 nBlockAlign=1 wBitsPerSample=8 cbSize=0 #define WAVE_FORMAT_ALAW 0x0006 /* Microsoft Corporation */ wFormatTag=6 nChannels=2 nSamplesPerSec=8000 nAvgBytesPerSec=16000 nBlockAlign=2 wBitsPerSample=8 cbSize=0 #define WAVE_FORMAT_MULAW 0x0007 /* Microsoft Corporation */ wFormatTag=7 nChannels=2 nSamplesPerSec=8000 nAvgBytesPerSec=16000 nBlockAlign=2 wBitsPerSample=8 cbSize=0 #define WAVE_FORMAT_ADPCM 0x0002 /* Microsoft Corporation */ wFormatTag=2 nChannels=2 nSamplesPerSec=11025 nAvgBytesPerSec=11289 nBlockAlign=512 wBitsPerSample=4 cbSize=32 0000 f4 01 07 00 00 01 00 00 00 02 00 ff 00 00 00 00 ................ 0010 c0 00 40 00 f0 00 00 00 cc 01 30 ff 88 01 18 ff ..@.......0..... #define WAVE_FORMAT_DVI_ADPCM 0x0011 /* Intel Corporation */ wFormatTag=17 nChannels=2 nSamplesPerSec=11025 nAvgBytesPerSec=11177 nBlockAlign=512 wBitsPerSample=4 cbSize=2 0000 f9 01 .. #define WAVE_FORMAT_ADPCM 0x0002 /* Microsoft Corporation */ wFormatTag=2 nChannels=1 nSamplesPerSec=22050 nAvgBytesPerSec=11155 nBlockAlign=512 wBitsPerSample=4 cbSize=32 0000 f4 03 07 00 00 01 00 00 00 02 00 ff 00 00 00 00 ................ 0010 c0 00 40 00 f0 00 00 00 cc 01 30 ff 88 01 18 ff ..@.......0..... #define WAVE_FORMAT_DVI_ADPCM 0x0011 /* Intel Corporation */ wFormatTag=17 nChannels=1 nSamplesPerSec=22050 nAvgBytesPerSec=11100 nBlockAlign=512 wBitsPerSample=4 cbSize=2 0000 f9 03 .. #define WAVE_FORMAT_ALAW 0x0006 /* Microsoft Corporation */ wFormatTag=6 nChannels=1 nSamplesPerSec=11025 nAvgBytesPerSec=11025 nBlockAlign=1 wBitsPerSample=8 cbSize=0 #define WAVE_FORMAT_MULAW 0x0007 /* Microsoft Corporation */ wFormatTag=7 nChannels=1 nSamplesPerSec=11025 nAvgBytesPerSec=11025 nBlockAlign=1 wBitsPerSample=8 cbSize=0 #define WAVE_FORMAT_ADPCM 0x0002 /* Microsoft Corporation */ wFormatTag=2 nChannels=2 nSamplesPerSec=8000 nAvgBytesPerSec=8192 nBlockAlign=512 wBitsPerSample=4 cbSize=32 0000 f4 01 07 00 00 01 00 00 00 02 00 ff 00 00 00 00 ................ 0010 c0 00 40 00 f0 00 00 00 cc 01 30 ff 88 01 18 ff ..@.......0..... #define WAVE_FORMAT_DVI_ADPCM 0x0011 /* Intel Corporation */ wFormatTag=17 nChannels=2 nSamplesPerSec=8000 nAvgBytesPerSec=8110 nBlockAlign=512 wBitsPerSample=4 cbSize=2 0000 f9 01 .. #define WAVE_FORMAT_ALAW 0x0006 /* Microsoft Corporation */ wFormatTag=6 nChannels=1 nSamplesPerSec=8000 nAvgBytesPerSec=8000 nBlockAlign=1 wBitsPerSample=8 cbSize=0 #define WAVE_FORMAT_MULAW 0x0007 /* Microsoft Corporation */ wFormatTag=7 nChannels=1 nSamplesPerSec=8000 nAvgBytesPerSec=8000 nBlockAlign=1 wBitsPerSample=8 cbSize=0 #define WAVE_FORMAT_MPEGLAYER3 0x0055 /* ISO/MPEG Layer3 Format Tag */ wFormatTag=85 nChannels=2 nSamplesPerSec=22050 nAvgBytesPerSec=7000 nBlockAlign=1 wBitsPerSample=0 cbSize=12 0000 01 00 02 00 00 00 b6 00 01 00 71 05 ..........q. #define WAVE_FORMAT_MPEGLAYER3 0x0055 /* ISO/MPEG Layer3 Format Tag */ wFormatTag=85 nChannels=2 nSamplesPerSec=16000 nAvgBytesPerSec=7000 nBlockAlign=1 wBitsPerSample=0 cbSize=12 0000 01 00 02 00 00 00 fc 00 01 00 71 05 ..........q. #define WAVE_FORMAT_MPEGLAYER3 0x0055 /* ISO/MPEG Layer3 Format Tag */ wFormatTag=85 nChannels=2 nSamplesPerSec=22050 nAvgBytesPerSec=6000 nBlockAlign=1 wBitsPerSample=0 cbSize=12 0000 01 00 02 00 00 00 9c 00 01 00 71 05 ..........q. #define WAVE_FORMAT_MPEGLAYER3 0x0055 /* ISO/MPEG Layer3 Format Tag */ wFormatTag=85 nChannels=2 nSamplesPerSec=16000 nAvgBytesPerSec=6000 nBlockAlign=1 wBitsPerSample=0 cbSize=12 0000 01 00 02 00 00 00 d8 00 01 00 71 05 ..........q. #define WAVE_FORMAT_ADPCM 0x0002 /* Microsoft Corporation */ wFormatTag=2 nChannels=1 nSamplesPerSec=11025 nAvgBytesPerSec=5644 nBlockAlign=256 wBitsPerSample=4 cbSize=32 0000 f4 01 07 00 00 01 00 00 00 02 00 ff 00 00 00 00 ................ 0010 c0 00 40 00 f0 00 00 00 cc 01 30 ff 88 01 18 ff ..@.......0..... #define WAVE_FORMAT_DVI_ADPCM 0x0011 /* Intel Corporation */ wFormatTag=17 nChannels=1 nSamplesPerSec=11025 nAvgBytesPerSec=5588 nBlockAlign=256 wBitsPerSample=4 cbSize=2 0000 f9 01 .. #define WAVE_FORMAT_MPEGLAYER3 0x0055 /* ISO/MPEG Layer3 Format Tag */ wFormatTag=85 nChannels=2 nSamplesPerSec=22050 nAvgBytesPerSec=5000 nBlockAlign=1 wBitsPerSample=0 cbSize=12 0000 01 00 02 00 00 00 82 00 01 00 71 05 ..........q. #define WAVE_FORMAT_MPEGLAYER3 0x0055 /* ISO/MPEG Layer3 Format Tag */ wFormatTag=85 nChannels=2 nSamplesPerSec=16000 nAvgBytesPerSec=5000 nBlockAlign=1 wBitsPerSample=0 cbSize=12 0000 01 00 02 00 00 00 b4 00 01 00 71 05 ..........q. #define WAVE_FORMAT_GSM610 0x0031 /* Microsoft Corporation */ wFormatTag=49 nChannels=1 nSamplesPerSec=22050 nAvgBytesPerSec=4478 nBlockAlign=65 wBitsPerSample=0 cbSize=2 0000 40 01 @. #define WAVE_FORMAT_ADPCM 0x0002 /* Microsoft Corporation */ wFormatTag=2 nChannels=1 nSamplesPerSec=8000 nAvgBytesPerSec=4096 nBlockAlign=256 wBitsPerSample=4 cbSize=32 0000 f4 01 07 00 00 01 00 00 00 02 00 ff 00 00 00 00 ................ 0010 c0 00 40 00 f0 00 00 00 cc 01 30 ff 88 01 18 ff ..@.......0..... #define WAVE_FORMAT_DVI_ADPCM 0x0011 /* Intel Corporation */ wFormatTag=17 nChannels=1 nSamplesPerSec=8000 nAvgBytesPerSec=4055 nBlockAlign=256 wBitsPerSample=4 cbSize=2 0000 f9 01 .. ? wFormatTag=353 nChannels=2 nSamplesPerSec=22050 nAvgBytesPerSec=4005 nBlockAlign=186 wBitsPerSample=16 cbSize=47 0000 00 04 00 00 01 00 ba 00 00 00 46 36 44 43 39 38 ..........F6DC98 0010 33 30 2d 42 43 37 39 2d 31 31 64 32 2d 41 39 44 30-BC79-11d2-A9D 0020 30 2d 30 30 36 30 39 37 39 32 36 30 33 36 00 0-006097926036. #define WAVE_FORMAT_MPEGLAYER3 0x0055 /* ISO/MPEG Layer3 Format Tag */ wFormatTag=85 nChannels=2 nSamplesPerSec=16000 nAvgBytesPerSec=4000 nBlockAlign=1 wBitsPerSample=0 cbSize=12 0000 01 00 02 00 00 00 90 00 01 00 71 05 ..........q. #define WAVE_FORMAT_MPEGLAYER3 0x0055 /* ISO/MPEG Layer3 Format Tag */ wFormatTag=85 nChannels=2 nSamplesPerSec=12000 nAvgBytesPerSec=4000 nBlockAlign=1 wBitsPerSample=0 cbSize=12 0000 01 00 02 00 00 00 c0 00 01 00 71 05 ..........q. #define WAVE_FORMAT_MPEGLAYER3 0x0055 /* ISO/MPEG Layer3 Format Tag */ wFormatTag=85 nChannels=2 nSamplesPerSec=11025 nAvgBytesPerSec=4000 nBlockAlign=1 wBitsPerSample=0 cbSize=12 0000 01 00 02 00 00 00 d0 00 01 00 71 05 ..........q. #define WAVE_FORMAT_MPEGLAYER3 0x0055 /* ISO/MPEG Layer3 Format Tag */ wFormatTag=85 nChannels=2 nSamplesPerSec=8000 nAvgBytesPerSec=4000 nBlockAlign=1 wBitsPerSample=0 cbSize=12 0000 01 00 02 00 00 00 20 01 01 00 71 05 ...... ...q. #define WAVE_FORMAT_MPEGLAYER3 0x0055 /* ISO/MPEG Layer3 Format Tag */ wFormatTag=85 nChannels=1 nSamplesPerSec=22050 nAvgBytesPerSec=4000 nBlockAlign=1 wBitsPerSample=0 cbSize=12 0000 01 00 02 00 00 00 68 00 01 00 71 05 ......h...q. #define WAVE_FORMAT_MPEGLAYER3 0x0055 /* ISO/MPEG Layer3 Format Tag */ wFormatTag=85 nChannels=1 nSamplesPerSec=16000 nAvgBytesPerSec=4000 nBlockAlign=1 wBitsPerSample=0 cbSize=12 0000 01 00 02 00 00 00 90 00 01 00 71 05 ..........q. #define WAVE_FORMAT_MPEGLAYER3 0x0055 /* ISO/MPEG Layer3 Format Tag */ wFormatTag=85 nChannels=2 nSamplesPerSec=12000 nAvgBytesPerSec=3000 nBlockAlign=1 wBitsPerSample=0 cbSize=12 0000 01 00 02 00 00 00 90 00 01 00 71 05 ..........q. #define WAVE_FORMAT_MPEGLAYER3 0x0055 /* ISO/MPEG Layer3 Format Tag */ wFormatTag=85 nChannels=2 nSamplesPerSec=11025 nAvgBytesPerSec=3000 nBlockAlign=1 wBitsPerSample=0 cbSize=12 0000 01 00 02 00 00 00 9c 00 01 00 71 05 ..........q. #define WAVE_FORMAT_MPEGLAYER3 0x0055 /* ISO/MPEG Layer3 Format Tag */ wFormatTag=85 nChannels=2 nSamplesPerSec=8000 nAvgBytesPerSec=3000 nBlockAlign=1 wBitsPerSample=0 cbSize=12 0000 01 00 02 00 00 00 d8 00 01 00 71 05 ..........q. #define WAVE_FORMAT_MPEGLAYER3 0x0055 /* ISO/MPEG Layer3 Format Tag */ wFormatTag=85 nChannels=1 nSamplesPerSec=22050 nAvgBytesPerSec=3000 nBlockAlign=1 wBitsPerSample=0 cbSize=12 0000 01 00 02 00 00 00 4e 00 01 00 71 05 ......N...q. #define WAVE_FORMAT_MPEGLAYER3 0x0055 /* ISO/MPEG Layer3 Format Tag */ wFormatTag=85 nChannels=1 nSamplesPerSec=16000 nAvgBytesPerSec=3000 nBlockAlign=1 wBitsPerSample=0 cbSize=12 0000 01 00 02 00 00 00 6c 00 01 00 71 05 ......l...q. ? wFormatTag=353 nChannels=1 nSamplesPerSec=22050 nAvgBytesPerSec=2519 nBlockAlign=117 wBitsPerSample=16 cbSize=47 0000 00 04 00 00 00 00 75 00 00 00 46 36 44 43 39 38 ......u...F6DC98 0010 33 30 2d 42 43 37 39 2d 31 31 64 32 2d 41 39 44 30-BC79-11d2-A9D 0020 30 2d 30 30 36 30 39 37 39 32 36 30 33 36 00 0-006097926036. ? wFormatTag=353 nChannels=2 nSamplesPerSec=22050 nAvgBytesPerSec=2519 nBlockAlign=117 wBitsPerSample=16 cbSize=47 0000 00 04 00 00 00 00 75 00 00 00 46 36 44 43 39 38 ......u...F6DC98 0010 33 30 2d 42 43 37 39 2d 31 31 64 32 2d 41 39 44 30-BC79-11d2-A9D 0020 30 2d 30 30 36 30 39 37 39 32 36 30 33 36 00 0-006097926036. #define WAVE_FORMAT_MPEGLAYER3 0x0055 /* ISO/MPEG Layer3 Format Tag */ wFormatTag=85 nChannels=2 nSamplesPerSec=12000 nAvgBytesPerSec=2500 nBlockAlign=1 wBitsPerSample=0 cbSize=12 0000 01 00 02 00 00 00 f0 00 02 00 71 05 ..........q. #define WAVE_FORMAT_MPEGLAYER3 0x0055 /* ISO/MPEG Layer3 Format Tag */ wFormatTag=85 nChannels=2 nSamplesPerSec=11025 nAvgBytesPerSec=2500 nBlockAlign=1 wBitsPerSample=0 cbSize=12 0000 01 00 02 00 00 00 04 01 02 00 71 05 ..........q. #define WAVE_FORMAT_MPEGLAYER3 0x0055 /* ISO/MPEG Layer3 Format Tag */ wFormatTag=85 nChannels=2 nSamplesPerSec=8000 nAvgBytesPerSec=2500 nBlockAlign=1 wBitsPerSample=0 cbSize=12 0000 01 00 02 00 00 00 68 01 02 00 71 05 ......h...q. #define WAVE_FORMAT_MPEGLAYER3 0x0055 /* ISO/MPEG Layer3 Format Tag */ wFormatTag=85 nChannels=1 nSamplesPerSec=16000 nAvgBytesPerSec=2500 nBlockAlign=1 wBitsPerSample=0 cbSize=12 0000 01 00 02 00 00 00 b4 00 02 00 71 05 ..........q. #define WAVE_FORMAT_MPEGLAYER3 0x0055 /* ISO/MPEG Layer3 Format Tag */ wFormatTag=85 nChannels=1 nSamplesPerSec=12000 nAvgBytesPerSec=2500 nBlockAlign=1 wBitsPerSample=0 cbSize=12 0000 01 00 02 00 00 00 f0 00 02 00 71 05 ..........q. #define WAVE_FORMAT_MPEGLAYER3 0x0055 /* ISO/MPEG Layer3 Format Tag */ wFormatTag=85 nChannels=1 nSamplesPerSec=11025 nAvgBytesPerSec=2500 nBlockAlign=1 wBitsPerSample=0 cbSize=12 0000 01 00 02 00 00 00 04 01 02 00 71 05 ..........q. #define WAVE_FORMAT_MPEGLAYER3 0x0055 /* ISO/MPEG Layer3 Format Tag */ wFormatTag=85 nChannels=2 nSamplesPerSec=12000 nAvgBytesPerSec=2250 nBlockAlign=1 wBitsPerSample=0 cbSize=12 0000 01 00 02 00 00 00 b0 01 04 00 71 05 ..........q. #define WAVE_FORMAT_MPEGLAYER3 0x0055 /* ISO/MPEG Layer3 Format Tag */ wFormatTag=85 nChannels=2 nSamplesPerSec=11025 nAvgBytesPerSec=2250 nBlockAlign=1 wBitsPerSample=0 cbSize=12 0000 01 00 02 00 00 00 d4 01 04 00 71 05 ..........q. #define WAVE_FORMAT_MPEGLAYER3 0x0055 /* ISO/MPEG Layer3 Format Tag */ wFormatTag=85 nChannels=2 nSamplesPerSec=8000 nAvgBytesPerSec=2250 nBlockAlign=1 wBitsPerSample=0 cbSize=12 0000 01 00 02 00 00 00 88 02 04 00 71 05 ..........q. #define WAVE_FORMAT_MPEGLAYER3 0x0055 /* ISO/MPEG Layer3 Format Tag */ wFormatTag=85 nChannels=1 nSamplesPerSec=16000 nAvgBytesPerSec=2250 nBlockAlign=1 wBitsPerSample=0 cbSize=12 0000 01 00 02 00 00 00 44 01 04 00 71 05 ......D...q. #define WAVE_FORMAT_MPEGLAYER3 0x0055 /* ISO/MPEG Layer3 Format Tag */ wFormatTag=85 nChannels=1 nSamplesPerSec=12000 nAvgBytesPerSec=2250 nBlockAlign=1 wBitsPerSample=0 cbSize=12 0000 01 00 02 00 00 00 b0 01 04 00 71 05 ..........q. #define WAVE_FORMAT_MPEGLAYER3 0x0055 /* ISO/MPEG Layer3 Format Tag */ wFormatTag=85 nChannels=1 nSamplesPerSec=11025 nAvgBytesPerSec=2250 nBlockAlign=1 wBitsPerSample=0 cbSize=12 0000 01 00 02 00 00 00 d4 01 04 00 71 05 ..........q. #define WAVE_FORMAT_GSM610 0x0031 /* Microsoft Corporation */ wFormatTag=49 nChannels=1 nSamplesPerSec=11025 nAvgBytesPerSec=2239 nBlockAlign=65 wBitsPerSample=0 cbSize=2 0000 40 01 @. ? wFormatTag=353 nChannels=1 nSamplesPerSec=16000 nAvgBytesPerSec=2000 nBlockAlign=64 wBitsPerSample=16 cbSize=47 0000 00 02 00 00 00 00 40 00 00 00 46 36 44 43 39 38 ......@...F6DC98 0010 33 30 2d 42 43 37 39 2d 31 31 64 32 2d 41 39 44 30-BC79-11d2-A9D 0020 30 2d 30 30 36 30 39 37 39 32 36 30 33 36 00 0-006097926036. #define WAVE_FORMAT_MPEGLAYER3 0x0055 /* ISO/MPEG Layer3 Format Tag */ wFormatTag=85 nChannels=1 nSamplesPerSec=16000 nAvgBytesPerSec=2000 nBlockAlign=1 wBitsPerSample=0 cbSize=12 0000 01 00 02 00 00 00 48 00 01 00 71 05 ......H...q. #define WAVE_FORMAT_MPEGLAYER3 0x0055 /* ISO/MPEG Layer3 Format Tag */ wFormatTag=85 nChannels=1 nSamplesPerSec=12000 nAvgBytesPerSec=2000 nBlockAlign=1 wBitsPerSample=0 cbSize=12 0000 01 00 02 00 00 00 60 00 01 00 71 05 ......`...q. #define WAVE_FORMAT_MPEGLAYER3 0x0055 /* ISO/MPEG Layer3 Format Tag */ wFormatTag=85 nChannels=1 nSamplesPerSec=11025 nAvgBytesPerSec=2000 nBlockAlign=1 wBitsPerSample=0 cbSize=12 0000 01 00 02 00 00 00 68 00 01 00 71 05 ......h...q. #define WAVE_FORMAT_MPEGLAYER3 0x0055 /* ISO/MPEG Layer3 Format Tag */ wFormatTag=85 nChannels=1 nSamplesPerSec=8000 nAvgBytesPerSec=2000 nBlockAlign=1 wBitsPerSample=0 cbSize=12 0000 01 00 02 00 00 00 90 00 01 00 71 05 ..........q. #define WAVE_FORMAT_GSM610 0x0031 /* Microsoft Corporation */ wFormatTag=49 nChannels=1 nSamplesPerSec=8000 nAvgBytesPerSec=1625 nBlockAlign=65 wBitsPerSample=0 cbSize=2 0000 40 01 @. ? wFormatTag=353 nChannels=2 nSamplesPerSec=8000 nAvgBytesPerSec=1500 nBlockAlign=96 wBitsPerSample=16 cbSize=47 0000 00 02 00 00 00 00 60 00 00 00 46 36 44 43 39 38 ......`...F6DC98 0010 33 30 2d 42 43 37 39 2d 31 31 64 32 2d 41 39 44 30-BC79-11d2-A9D 0020 30 2d 30 30 36 30 39 37 39 32 36 30 33 36 00 0-006097926036. ? wFormatTag=353 nChannels=1 nSamplesPerSec=11025 nAvgBytesPerSec=1249 nBlockAlign=58 wBitsPerSample=16 cbSize=47 0000 00 02 00 00 00 00 3a 00 00 00 46 36 44 43 39 38 ......:...F6DC98 0010 33 30 2d 42 43 37 39 2d 31 31 64 32 2d 41 39 44 30-BC79-11d2-A9D 0020 30 2d 30 30 36 30 39 37 39 32 36 30 33 36 00 0-006097926036. #define WAVE_FORMAT_DSPGROUP_TRUESPEECH 0x0022 /* DSP Group, Inc */ wFormatTag=34 nChannels=1 nSamplesPerSec=8000 nAvgBytesPerSec=1067 nBlockAlign=32 wBitsPerSample=1 cbSize=32 0000 01 00 f0 00 00 00 00 00 00 00 00 00 00 00 00 00 ................ 0010 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 ................ ? wFormatTag=353 nChannels=1 nSamplesPerSec=11025 nAvgBytesPerSec=1012 nBlockAlign=47 wBitsPerSample=16 cbSize=47 0000 00 02 00 00 00 00 2f 00 00 00 46 36 44 43 39 38 ....../...F6DC98 0010 33 30 2d 42 43 37 39 2d 31 31 64 32 2d 41 39 44 30-BC79-11d2-A9D 0020 30 2d 30 30 36 30 39 37 39 32 36 30 33 36 00 0-006097926036. ? wFormatTag=353 nChannels=1 nSamplesPerSec=8000 nAvgBytesPerSec=1000 nBlockAlign=64 wBitsPerSample=16 cbSize=47 0000 00 02 00 00 00 00 40 00 00 00 46 36 44 43 39 38 ......@...F6DC98 0010 33 30 2d 42 43 37 39 2d 31 31 64 32 2d 41 39 44 30-BC79-11d2-A9D 0020 30 2d 30 30 36 30 39 37 39 32 36 30 33 36 00 0-006097926036. #define WAVE_FORMAT_MPEGLAYER3 0x0055 /* ISO/MPEG Layer3 Format Tag */ wFormatTag=85 nChannels=1 nSamplesPerSec=12000 nAvgBytesPerSec=1000 nBlockAlign=1 wBitsPerSample=0 cbSize=12 0000 01 00 02 00 00 00 30 00 01 00 71 05 ......0...q. #define WAVE_FORMAT_MPEGLAYER3 0x0055 /* ISO/MPEG Layer3 Format Tag */ wFormatTag=85 nChannels=1 nSamplesPerSec=11025 nAvgBytesPerSec=1000 nBlockAlign=1 wBitsPerSample=0 cbSize=12 0000 01 00 02 00 00 00 34 00 01 00 71 05 ......4...q. #define WAVE_FORMAT_MPEGLAYER3 0x0055 /* ISO/MPEG Layer3 Format Tag */ wFormatTag=85 nChannels=1 nSamplesPerSec=8000 nAvgBytesPerSec=1000 nBlockAlign=1 wBitsPerSample=0 cbSize=12 0000 01 00 02 00 00 00 48 00 01 00 71 05 ......H...q. ? wFormatTag=66 nChannels=1 nSamplesPerSec=8000 nAvgBytesPerSec=800 nBlockAlign=24 wBitsPerSample=0 cbSize=10 0000 02 00 ce 9a 32 f7 a2 ae de ac ....2..... ? wFormatTag=353 nChannels=1 nSamplesPerSec=8000 nAvgBytesPerSec=750 nBlockAlign=48 wBitsPerSample=16 cbSize=47 0000 00 02 00 00 00 00 30 00 00 00 46 36 44 43 39 38 ......0...F6DC98 0010 33 30 2d 42 43 37 39 2d 31 31 64 32 2d 41 39 44 30-BC79-11d2-A9D 0020 30 2d 30 30 36 30 39 37 39 32 36 30 33 36 00 0-006097926036. ? wFormatTag=66 nChannels=1 nSamplesPerSec=8000 nAvgBytesPerSec=666 nBlockAlign=20 wBitsPerSample=0 cbSize=10 0000 03 00 ce 9a 32 f7 a2 ae de ac ....2..... //*************************************************************** // Windows 7 SP1 x64 Server Formats WAVE_FORMAT_PCM: wFormatTag: 0x0001 nChannels: 2 nSamplesPerSec: 44100 nAvgBytesPerSec: 176400 nBlockAlign: 4 wBitsPerSample: 16 cbSize: 0 WAVE_FORMAT_ADPCM: wFormatTag: 0x0002 nChannels: 2 nSamplesPerSec: 44100 nAvgBytesPerSec: 44359 nBlockAlign: 2048 wBitsPerSample: 4 cbSize: 32 WAVE_FORMAT_DVI_ADPCM: wFormatTag: 0x0011 nChannels: 2 nSamplesPerSec: 44100 nAvgBytesPerSec: 44251 nBlockAlign: 2048 wBitsPerSample: 4 cbSize: 2 WAVE_FORMAT_ALAW: wFormatTag: 0x0006 nChannels: 2 nSamplesPerSec: 22050 nAvgBytesPerSec: 44100 nBlockAlign: 2 wBitsPerSample: 8 cbSize: 0 WAVE_FORMAT_ADPCM: wFormatTag: 0x0002 nChannels: 2 nSamplesPerSec: 22050 nAvgBytesPerSec: 22311 nBlockAlign: 1024 wBitsPerSample: 4 cbSize: 32 WAVE_FORMAT_DVI_ADPCM: wFormatTag: 0x0011 nChannels: 2 nSamplesPerSec: 22050 nAvgBytesPerSec: 22201 nBlockAlign: 1024 wBitsPerSample: 4 cbSize: 2 WAVE_FORMAT_ADPCM: wFormatTag: 0x0002 nChannels: 1 nSamplesPerSec: 44100 nAvgBytesPerSec: 22179 nBlockAlign: 1024 wBitsPerSample: 4 cbSize: 32 WAVE_FORMAT_DVI_ADPCM: wFormatTag: 0x0011 nChannels: 1 nSamplesPerSec: 44100 nAvgBytesPerSec: 22125 nBlockAlign: 1024 wBitsPerSample: 4 cbSize: 2 WAVE_FORMAT_ADPCM: wFormatTag: 0x0002 nChannels: 2 nSamplesPerSec: 11025 nAvgBytesPerSec: 11289 nBlockAlign: 512 wBitsPerSample: 4 cbSize: 32 WAVE_FORMAT_DVI_ADPCM: wFormatTag: 0x0011 nChannels: 2 nSamplesPerSec: 11025 nAvgBytesPerSec: 11177 nBlockAlign: 512 wBitsPerSample: 4 cbSize: 2 WAVE_FORMAT_ADPCM: wFormatTag: 0x0002 nChannels: 1 nSamplesPerSec: 22050 nAvgBytesPerSec: 11155 nBlockAlign: 512 wBitsPerSample: 4 cbSize: 32 WAVE_FORMAT_DVI_ADPCM: wFormatTag: 0x0011 nChannels: 1 nSamplesPerSec: 22050 nAvgBytesPerSec: 11100 nBlockAlign: 512 wBitsPerSample: 4 cbSize: 2 WAVE_FORMAT_GSM610: wFormatTag: 0x0031 nChannels: 1 nSamplesPerSec: 44100 nAvgBytesPerSec: 8957 nBlockAlign: 65 wBitsPerSample: 0 cbSize: 2 WAVE_FORMAT_ADPCM: wFormatTag: 0x0002 nChannels: 2 nSamplesPerSec: 8000 nAvgBytesPerSec: 8192 nBlockAlign: 512 wBitsPerSample: 4 cbSize: 32 WAVE_FORMAT_DVI_ADPCM: wFormatTag: 0x0011 nChannels: 2 nSamplesPerSec: 8000 nAvgBytesPerSec: 8110 nBlockAlign: 512 wBitsPerSample: 4 cbSize: 2 WAVE_FORMAT_ADPCM: wFormatTag: 0x0002 nChannels: 1 nSamplesPerSec: 11025 nAvgBytesPerSec: 5644 nBlockAlign: 256 wBitsPerSample: 4 cbSize: 32 WAVE_FORMAT_DVI_ADPCM: wFormatTag: 0x0011 nChannels: 1 nSamplesPerSec: 11025 nAvgBytesPerSec: 5588 nBlockAlign: 256 wBitsPerSample: 4 cbSize: 2 WAVE_FORMAT_GSM610: wFormatTag: 0x0031 nChannels: 1 nSamplesPerSec: 22050 nAvgBytesPerSec: 4478 nBlockAlign: 65 wBitsPerSample: 0 cbSize: 2 WAVE_FORMAT_ADPCM: wFormatTag: 0x0002 nChannels: 1 nSamplesPerSec: 8000 nAvgBytesPerSec: 4096 nBlockAlign: 256 wBitsPerSample: 4 cbSize: 32 WAVE_FORMAT_DVI_ADPCM: wFormatTag: 0x0011 nChannels: 1 nSamplesPerSec: 8000 nAvgBytesPerSec: 4055 nBlockAlign: 256 wBitsPerSample: 4 cbSize: 2 WAVE_FORMAT_GSM610: wFormatTag: 0x0031 nChannels: 1 nSamplesPerSec: 11025 nAvgBytesPerSec: 2239 nBlockAlign: 65 wBitsPerSample: 0 cbSize: 2 WAVE_FORMAT_GSM610: wFormatTag: 0x0031 nChannels: 1 nSamplesPerSec: 8000 nAvgBytesPerSec: 1625 nBlockAlign: 65 wBitsPerSample: 0 cbSize: 2 //*************************************************************** // Windows 10 10586 x64 Server Formats WAVE_FORMAT_AAC_MS: wFormatTag: 0xA106 nChannels: 2 nSamplesPerSec: 44100 nAvgBytesPerSec: 24000 nBlockAlign: 4 wBitsPerSample: 16 cbSize: 0 WAVE_FORMAT_AAC_MS: wFormatTag: 0xA106 nChannels: 2 nSamplesPerSec: 44100 nAvgBytesPerSec: 20000 nBlockAlign: 4 wBitsPerSample: 16 cbSize: 0 WAVE_FORMAT_AAC_MS: wFormatTag: 0xA106 nChannels: 2 nSamplesPerSec: 44100 nAvgBytesPerSec: 16000 nBlockAlign: 4 wBitsPerSample: 16 cbSize: 0 WAVE_FORMAT_AAC_MS: wFormatTag: 0xA106 nChannels: 2 nSamplesPerSec: 44100 nAvgBytesPerSec: 12000 nBlockAlign: 4 wBitsPerSample: 16 cbSize: 0 WAVE_FORMAT_PCM: wFormatTag: 0x0001 nChannels: 2 nSamplesPerSec: 44100 nAvgBytesPerSec: 176400 nBlockAlign: 4 wBitsPerSample: 16 cbSize: 0 WAVE_FORMAT_ADPCM: wFormatTag: 0x0002 nChannels: 2 nSamplesPerSec: 44100 nAvgBytesPerSec: 44359 nBlockAlign: 2048 wBitsPerSample: 4 cbSize: 32 WAVE_FORMAT_DVI_ADPCM: wFormatTag: 0x0011 nChannels: 2 nSamplesPerSec: 44100 nAvgBytesPerSec: 44251 nBlockAlign: 2048 wBitsPerSample: 4 cbSize: 2 WAVE_FORMAT_ALAW: wFormatTag: 0x0006 nChannels: 2 nSamplesPerSec: 22050 nAvgBytesPerSec: 44100 nBlockAlign: 2 wBitsPerSample: 8 cbSize: 0 WAVE_FORMAT_ADPCM: wFormatTag: 0x0002 nChannels: 2 nSamplesPerSec: 22050 nAvgBytesPerSec: 22311 nBlockAlign: 1024 wBitsPerSample: 4 cbSize: 32 WAVE_FORMAT_DVI_ADPCM: wFormatTag: 0x0011 nChannels: 2 nSamplesPerSec: 22050 nAvgBytesPerSec: 22201 nBlockAlign: 1024 wBitsPerSample: 4 cbSize: 2 WAVE_FORMAT_ADPCM: wFormatTag: 0x0002 nChannels: 1 nSamplesPerSec: 44100 nAvgBytesPerSec: 22179 nBlockAlign: 1024 wBitsPerSample: 4 cbSize: 32 WAVE_FORMAT_DVI_ADPCM: wFormatTag: 0x0011 nChannels: 1 nSamplesPerSec: 44100 nAvgBytesPerSec: 22125 nBlockAlign: 1024 wBitsPerSample: 4 cbSize: 2 WAVE_FORMAT_ADPCM: wFormatTag: 0x0002 nChannels: 2 nSamplesPerSec: 11025 nAvgBytesPerSec: 11289 nBlockAlign: 512 wBitsPerSample: 4 cbSize: 32 WAVE_FORMAT_DVI_ADPCM: wFormatTag: 0x0011 nChannels: 2 nSamplesPerSec: 11025 nAvgBytesPerSec: 11177 nBlockAlign: 512 wBitsPerSample: 4 cbSize: 2 WAVE_FORMAT_ADPCM: wFormatTag: 0x0002 nChannels: 1 nSamplesPerSec: 22050 nAvgBytesPerSec: 11155 nBlockAlign: 512 wBitsPerSample: 4 cbSize: 32 WAVE_FORMAT_DVI_ADPCM: wFormatTag: 0x0011 nChannels: 1 nSamplesPerSec: 22050 nAvgBytesPerSec: 11100 nBlockAlign: 512 wBitsPerSample: 4 cbSize: 2 WAVE_FORMAT_GSM610: wFormatTag: 0x0031 nChannels: 1 nSamplesPerSec: 44100 nAvgBytesPerSec: 8957 nBlockAlign: 65 wBitsPerSample: 0 cbSize: 2 WAVE_FORMAT_ADPCM: wFormatTag: 0x0002 nChannels: 2 nSamplesPerSec: 8000 nAvgBytesPerSec: 8192 nBlockAlign: 512 wBitsPerSample: 4 cbSize: 32 WAVE_FORMAT_DVI_ADPCM: wFormatTag: 0x0011 nChannels: 2 nSamplesPerSec: 8000 nAvgBytesPerSec: 8110 nBlockAlign: 512 wBitsPerSample: 4 cbSize: 2 WAVE_FORMAT_ADPCM: wFormatTag: 0x0002 nChannels: 1 nSamplesPerSec: 11025 nAvgBytesPerSec: 5644 nBlockAlign: 256 wBitsPerSample: 4 cbSize: 32 WAVE_FORMAT_DVI_ADPCM: wFormatTag: 0x0011 nChannels: 1 nSamplesPerSec: 11025 nAvgBytesPerSec: 5588 nBlockAlign: 256 wBitsPerSample: 4 cbSize: 2 WAVE_FORMAT_GSM610: wFormatTag: 0x0031 nChannels: 1 nSamplesPerSec: 22050 nAvgBytesPerSec: 4478 nBlockAlign: 65 wBitsPerSample: 0 cbSize: 2 WAVE_FORMAT_ADPCM: wFormatTag: 0x0002 nChannels: 1 nSamplesPerSec: 8000 nAvgBytesPerSec: 4096 nBlockAlign: 256 wBitsPerSample: 4 cbSize: 32 WAVE_FORMAT_DVI_ADPCM: wFormatTag: 0x0011 nChannels: 1 nSamplesPerSec: 8000 nAvgBytesPerSec: 4055 nBlockAlign: 256 wBitsPerSample: 4 cbSize: 2 WAVE_FORMAT_GSM610: wFormatTag: 0x0031 nChannels: 1 nSamplesPerSec: 11025 nAvgBytesPerSec: 2239 nBlockAlign: 65 wBitsPerSample: 0 cbSize: 2 WAVE_FORMAT_GSM610: wFormatTag: 0x0031 nChannels: 1 nSamplesPerSec: 8000 nAvgBytesPerSec: 1625 nBlockAlign: 65 wBitsPerSample: 0 cbSize: 2 //*************************************************************** // Windows Server 2016 TP4 x64 Server Formats WAVE_FORMAT_AAC_MS: wFormatTag: 0xA106 nChannels: 2 nSamplesPerSec: 44100 nAvgBytesPerSec: 24000 nBlockAlign: 4 wBitsPerSample: 16 cbSize: 0 WAVE_FORMAT_AAC_MS: wFormatTag: 0xA106 nChannels: 2 nSamplesPerSec: 44100 nAvgBytesPerSec: 20000 nBlockAlign: 4 wBitsPerSample: 16 cbSize: 0 WAVE_FORMAT_AAC_MS: wFormatTag: 0xA106 nChannels: 2 nSamplesPerSec: 44100 nAvgBytesPerSec: 16000 nBlockAlign: 4 wBitsPerSample: 16 cbSize: 0 WAVE_FORMAT_AAC_MS: wFormatTag: 0xA106 nChannels: 2 nSamplesPerSec: 44100 nAvgBytesPerSec: 12000 nBlockAlign: 4 wBitsPerSample: 16 cbSize: 0 WAVE_FORMAT_PCM: wFormatTag: 0x0001 nChannels: 2 nSamplesPerSec: 44100 nAvgBytesPerSec: 176400 nBlockAlign: 4 wBitsPerSample: 16 cbSize: 0 WAVE_FORMAT_ADPCM: wFormatTag: 0x0002 nChannels: 2 nSamplesPerSec: 44100 nAvgBytesPerSec: 44359 nBlockAlign: 2048 wBitsPerSample: 4 cbSize: 32 WAVE_FORMAT_DVI_ADPCM: wFormatTag: 0x0011 nChannels: 2 nSamplesPerSec: 44100 nAvgBytesPerSec: 44251 nBlockAlign: 2048 wBitsPerSample: 4 cbSize: 2 WAVE_FORMAT_ALAW: wFormatTag: 0x0006 nChannels: 2 nSamplesPerSec: 22050 nAvgBytesPerSec: 44100 nBlockAlign: 2 wBitsPerSample: 8 cbSize: 0 WAVE_FORMAT_ADPCM: wFormatTag: 0x0002 nChannels: 2 nSamplesPerSec: 22050 nAvgBytesPerSec: 22311 nBlockAlign: 1024 wBitsPerSample: 4 cbSize: 32 WAVE_FORMAT_DVI_ADPCM: wFormatTag: 0x0011 nChannels: 2 nSamplesPerSec: 22050 nAvgBytesPerSec: 22201 nBlockAlign: 1024 wBitsPerSample: 4 cbSize: 2 WAVE_FORMAT_ADPCM: wFormatTag: 0x0002 nChannels: 1 nSamplesPerSec: 44100 nAvgBytesPerSec: 22179 nBlockAlign: 1024 wBitsPerSample: 4 cbSize: 32 WAVE_FORMAT_DVI_ADPCM: wFormatTag: 0x0011 nChannels: 1 nSamplesPerSec: 44100 nAvgBytesPerSec: 22125 nBlockAlign: 1024 wBitsPerSample: 4 cbSize: 2 WAVE_FORMAT_ADPCM: wFormatTag: 0x0002 nChannels: 2 nSamplesPerSec: 11025 nAvgBytesPerSec: 11289 nBlockAlign: 512 wBitsPerSample: 4 cbSize: 32 WAVE_FORMAT_DVI_ADPCM: wFormatTag: 0x0011 nChannels: 2 nSamplesPerSec: 11025 nAvgBytesPerSec: 11177 nBlockAlign: 512 wBitsPerSample: 4 cbSize: 2 WAVE_FORMAT_ADPCM: wFormatTag: 0x0002 nChannels: 1 nSamplesPerSec: 22050 nAvgBytesPerSec: 11155 nBlockAlign: 512 wBitsPerSample: 4 cbSize: 32 WAVE_FORMAT_DVI_ADPCM: wFormatTag: 0x0011 nChannels: 1 nSamplesPerSec: 22050 nAvgBytesPerSec: 11100 nBlockAlign: 512 wBitsPerSample: 4 cbSize: 2 WAVE_FORMAT_GSM610: wFormatTag: 0x0031 nChannels: 1 nSamplesPerSec: 44100 nAvgBytesPerSec: 8957 nBlockAlign: 65 wBitsPerSample: 0 cbSize: 2 WAVE_FORMAT_ADPCM: wFormatTag: 0x0002 nChannels: 2 nSamplesPerSec: 8000 nAvgBytesPerSec: 8192 nBlockAlign: 512 wBitsPerSample: 4 cbSize: 32 WAVE_FORMAT_DVI_ADPCM: wFormatTag: 0x0011 nChannels: 2 nSamplesPerSec: 8000 nAvgBytesPerSec: 8110 nBlockAlign: 512 wBitsPerSample: 4 cbSize: 2 WAVE_FORMAT_ADPCM: wFormatTag: 0x0002 nChannels: 1 nSamplesPerSec: 11025 nAvgBytesPerSec: 5644 nBlockAlign: 256 wBitsPerSample: 4 cbSize: 32 WAVE_FORMAT_DVI_ADPCM: wFormatTag: 0x0011 nChannels: 1 nSamplesPerSec: 11025 nAvgBytesPerSec: 5588 nBlockAlign: 256 wBitsPerSample: 4 cbSize: 2 WAVE_FORMAT_GSM610: wFormatTag: 0x0031 nChannels: 1 nSamplesPerSec: 22050 nAvgBytesPerSec: 4478 nBlockAlign: 65 wBitsPerSample: 0 cbSize: 2 WAVE_FORMAT_ADPCM: wFormatTag: 0x0002 nChannels: 1 nSamplesPerSec: 8000 nAvgBytesPerSec: 4096 nBlockAlign: 256 wBitsPerSample: 4 cbSize: 32 WAVE_FORMAT_DVI_ADPCM: wFormatTag: 0x0011 nChannels: 1 nSamplesPerSec: 8000 nAvgBytesPerSec: 4055 nBlockAlign: 256 wBitsPerSample: 4 cbSize: 2 WAVE_FORMAT_GSM610: wFormatTag: 0x0031 nChannels: 1 nSamplesPerSec: 11025 nAvgBytesPerSec: 2239 nBlockAlign: 65 wBitsPerSample: 0 cbSize: 2 WAVE_FORMAT_GSM610: wFormatTag: 0x0031 nChannels: 1 nSamplesPerSec: 8000 nAvgBytesPerSec: 1625 nBlockAlign: 65 wBitsPerSample: 0 cbSize: 2 //*************************************************************** // Windows XP SP3 x86 Server Formats WAVE_FORMAT_PCM: wFormatTag: 0x0001 nChannels: 2 nSamplesPerSec: 22050 nAvgBytesPerSec: 88200 nBlockAlign: 4 wBitsPerSample: 16 cbSize: 0 WAVE_FORMAT_ALAW: wFormatTag: 0x0006 nChannels: 2 nSamplesPerSec: 22050 nAvgBytesPerSec: 44100 nBlockAlign: 2 wBitsPerSample: 8 cbSize: 0 WAVE_FORMAT_MULAW: wFormatTag: 0x0007 nChannels: 2 nSamplesPerSec: 22050 nAvgBytesPerSec: 44100 nBlockAlign: 2 wBitsPerSample: 8 cbSize: 0 WAVE_FORMAT_ADPCM: wFormatTag: 0x0002 nChannels: 2 nSamplesPerSec: 22050 nAvgBytesPerSec: 22311 nBlockAlign: 1024 wBitsPerSample: 4 cbSize: 32 WAVE_FORMAT_DVI_ADPCM: wFormatTag: 0x0011 nChannels: 2 nSamplesPerSec: 22050 nAvgBytesPerSec: 22201 nBlockAlign: 1024 wBitsPerSample: 4 cbSize: 2 WAVE_FORMAT_ALAW: wFormatTag: 0x0006 nChannels: 2 nSamplesPerSec: 11025 nAvgBytesPerSec: 22050 nBlockAlign: 2 wBitsPerSample: 8 cbSize: 0 WAVE_FORMAT_ALAW: wFormatTag: 0x0006 nChannels: 1 nSamplesPerSec: 22050 nAvgBytesPerSec: 22050 nBlockAlign: 1 wBitsPerSample: 8 cbSize: 0 WAVE_FORMAT_MULAW: wFormatTag: 0x0007 nChannels: 2 nSamplesPerSec: 11025 nAvgBytesPerSec: 22050 nBlockAlign: 2 wBitsPerSample: 8 cbSize: 0 WAVE_FORMAT_MULAW: wFormatTag: 0x0007 nChannels: 1 nSamplesPerSec: 22050 nAvgBytesPerSec: 22050 nBlockAlign: 1 wBitsPerSample: 8 cbSize: 0 WAVE_FORMAT_ALAW: wFormatTag: 0x0006 nChannels: 2 nSamplesPerSec: 8000 nAvgBytesPerSec: 16000 nBlockAlign: 2 wBitsPerSample: 8 cbSize: 0 WAVE_FORMAT_MULAW: wFormatTag: 0x0007 nChannels: 2 nSamplesPerSec: 8000 nAvgBytesPerSec: 16000 nBlockAlign: 2 wBitsPerSample: 8 cbSize: 0 WAVE_FORMAT_ADPCM: wFormatTag: 0x0002 nChannels: 2 nSamplesPerSec: 11025 nAvgBytesPerSec: 11289 nBlockAlign: 512 wBitsPerSample: 4 cbSize: 32 WAVE_FORMAT_DVI_ADPCM: wFormatTag: 0x0011 nChannels: 2 nSamplesPerSec: 11025 nAvgBytesPerSec: 11177 nBlockAlign: 512 wBitsPerSample: 4 cbSize: 2 WAVE_FORMAT_ADPCM: wFormatTag: 0x0002 nChannels: 1 nSamplesPerSec: 22050 nAvgBytesPerSec: 11155 nBlockAlign: 512 wBitsPerSample: 4 cbSize: 32 WAVE_FORMAT_DVI_ADPCM: wFormatTag: 0x0011 nChannels: 1 nSamplesPerSec: 22050 nAvgBytesPerSec: 11100 nBlockAlign: 512 wBitsPerSample: 4 cbSize: 2 WAVE_FORMAT_ALAW: wFormatTag: 0x0006 nChannels: 1 nSamplesPerSec: 11025 nAvgBytesPerSec: 11025 nBlockAlign: 1 wBitsPerSample: 8 cbSize: 0 WAVE_FORMAT_MULAW: wFormatTag: 0x0007 nChannels: 1 nSamplesPerSec: 11025 nAvgBytesPerSec: 11025 nBlockAlign: 1 wBitsPerSample: 8 cbSize: 0 WAVE_FORMAT_ADPCM: wFormatTag: 0x0002 nChannels: 2 nSamplesPerSec: 8000 nAvgBytesPerSec: 8192 nBlockAlign: 512 wBitsPerSample: 4 cbSize: 32 WAVE_FORMAT_DVI_ADPCM: wFormatTag: 0x0011 nChannels: 2 nSamplesPerSec: 8000 nAvgBytesPerSec: 8110 nBlockAlign: 512 wBitsPerSample: 4 cbSize: 2 WAVE_FORMAT_ALAW: wFormatTag: 0x0006 nChannels: 1 nSamplesPerSec: 8000 nAvgBytesPerSec: 8000 nBlockAlign: 1 wBitsPerSample: 8 cbSize: 0 WAVE_FORMAT_MULAW: wFormatTag: 0x0007 nChannels: 1 nSamplesPerSec: 8000 nAvgBytesPerSec: 8000 nBlockAlign: 1 wBitsPerSample: 8 cbSize: 0 WAVE_FORMAT_MPEGLAYER3: wFormatTag: 0x0055 nChannels: 2 nSamplesPerSec: 22050 nAvgBytesPerSec: 7000 nBlockAlign: 1 wBitsPerSample: 0 cbSize: 12 WAVE_FORMAT_MPEGLAYER3: wFormatTag: 0x0055 nChannels: 2 nSamplesPerSec: 16000 nAvgBytesPerSec: 7000 nBlockAlign: 1 wBitsPerSample: 0 cbSize: 12 WAVE_FORMAT_MPEGLAYER3: wFormatTag: 0x0055 nChannels: 2 nSamplesPerSec: 22050 nAvgBytesPerSec: 6000 nBlockAlign: 1 wBitsPerSample: 0 cbSize: 12 WAVE_FORMAT_MPEGLAYER3: wFormatTag: 0x0055 nChannels: 2 nSamplesPerSec: 16000 nAvgBytesPerSec: 6000 nBlockAlign: 1 wBitsPerSample: 0 cbSize: 12 WAVE_FORMAT_ADPCM: wFormatTag: 0x0002 nChannels: 1 nSamplesPerSec: 11025 nAvgBytesPerSec: 5644 nBlockAlign: 256 wBitsPerSample: 4 cbSize: 32 WAVE_FORMAT_DVI_ADPCM: wFormatTag: 0x0011 nChannels: 1 nSamplesPerSec: 11025 nAvgBytesPerSec: 5588 nBlockAlign: 256 wBitsPerSample: 4 cbSize: 2 WAVE_FORMAT_MPEGLAYER3: wFormatTag: 0x0055 nChannels: 2 nSamplesPerSec: 22050 nAvgBytesPerSec: 5000 nBlockAlign: 1 wBitsPerSample: 0 cbSize: 12 WAVE_FORMAT_MPEGLAYER3: wFormatTag: 0x0055 nChannels: 2 nSamplesPerSec: 16000 nAvgBytesPerSec: 5000 nBlockAlign: 1 wBitsPerSample: 0 cbSize: 12 WAVE_FORMAT_GSM610: wFormatTag: 0x0031 nChannels: 1 nSamplesPerSec: 22050 nAvgBytesPerSec: 4478 nBlockAlign: 65 wBitsPerSample: 0 cbSize: 2 WAVE_FORMAT_ADPCM: wFormatTag: 0x0002 nChannels: 1 nSamplesPerSec: 8000 nAvgBytesPerSec: 4096 nBlockAlign: 256 wBitsPerSample: 4 cbSize: 32 WAVE_FORMAT_DVI_ADPCM: wFormatTag: 0x0011 nChannels: 1 nSamplesPerSec: 8000 nAvgBytesPerSec: 4055 nBlockAlign: 256 wBitsPerSample: 4 cbSize: 2 WAVE_FORMAT_WMAUDIO2: wFormatTag: 0x0161 nChannels: 2 nSamplesPerSec: 22050 nAvgBytesPerSec: 4005 nBlockAlign: 186 wBitsPerSample: 16 cbSize: 47 WAVE_FORMAT_MPEGLAYER3: wFormatTag: 0x0055 nChannels: 2 nSamplesPerSec: 16000 nAvgBytesPerSec: 4000 nBlockAlign: 1 wBitsPerSample: 0 cbSize: 12 WAVE_FORMAT_MPEGLAYER3: wFormatTag: 0x0055 nChannels: 2 nSamplesPerSec: 12000 nAvgBytesPerSec: 4000 nBlockAlign: 1 wBitsPerSample: 0 cbSize: 12 WAVE_FORMAT_MPEGLAYER3: wFormatTag: 0x0055 nChannels: 2 nSamplesPerSec: 11025 nAvgBytesPerSec: 4000 nBlockAlign: 1 wBitsPerSample: 0 cbSize: 12 WAVE_FORMAT_MPEGLAYER3: wFormatTag: 0x0055 nChannels: 2 nSamplesPerSec: 8000 nAvgBytesPerSec: 4000 nBlockAlign: 1 wBitsPerSample: 0 cbSize: 12 WAVE_FORMAT_MPEGLAYER3: wFormatTag: 0x0055 nChannels: 1 nSamplesPerSec: 22050 nAvgBytesPerSec: 4000 nBlockAlign: 1 wBitsPerSample: 0 cbSize: 12 WAVE_FORMAT_MPEGLAYER3: wFormatTag: 0x0055 nChannels: 1 nSamplesPerSec: 16000 nAvgBytesPerSec: 4000 nBlockAlign: 1 wBitsPerSample: 0 cbSize: 12 WAVE_FORMAT_MPEGLAYER3: wFormatTag: 0x0055 nChannels: 2 nSamplesPerSec: 12000 nAvgBytesPerSec: 3000 nBlockAlign: 1 wBitsPerSample: 0 cbSize: 12 WAVE_FORMAT_MPEGLAYER3: wFormatTag: 0x0055 nChannels: 2 nSamplesPerSec: 11025 nAvgBytesPerSec: 3000 nBlockAlign: 1 wBitsPerSample: 0 cbSize: 12 WAVE_FORMAT_MPEGLAYER3: wFormatTag: 0x0055 nChannels: 2 nSamplesPerSec: 8000 nAvgBytesPerSec: 3000 nBlockAlign: 1 wBitsPerSample: 0 cbSize: 12 WAVE_FORMAT_MPEGLAYER3: wFormatTag: 0x0055 nChannels: 1 nSamplesPerSec: 22050 nAvgBytesPerSec: 3000 nBlockAlign: 1 wBitsPerSample: 0 cbSize: 12 WAVE_FORMAT_MPEGLAYER3: wFormatTag: 0x0055 nChannels: 1 nSamplesPerSec: 16000 nAvgBytesPerSec: 3000 nBlockAlign: 1 wBitsPerSample: 0 cbSize: 12 WAVE_FORMAT_WMAUDIO2: wFormatTag: 0x0161 nChannels: 1 nSamplesPerSec: 22050 nAvgBytesPerSec: 2519 nBlockAlign: 117 wBitsPerSample: 16 cbSize: 47 WAVE_FORMAT_WMAUDIO2: wFormatTag: 0x0161 nChannels: 2 nSamplesPerSec: 22050 nAvgBytesPerSec: 2519 nBlockAlign: 117 wBitsPerSample: 16 cbSize: 47 WAVE_FORMAT_MPEGLAYER3: wFormatTag: 0x0055 nChannels: 2 nSamplesPerSec: 12000 nAvgBytesPerSec: 2500 nBlockAlign: 1 wBitsPerSample: 0 cbSize: 12 WAVE_FORMAT_MPEGLAYER3: wFormatTag: 0x0055 nChannels: 2 nSamplesPerSec: 11025 nAvgBytesPerSec: 2500 nBlockAlign: 1 wBitsPerSample: 0 cbSize: 12 WAVE_FORMAT_MPEGLAYER3: wFormatTag: 0x0055 nChannels: 2 nSamplesPerSec: 8000 nAvgBytesPerSec: 2500 nBlockAlign: 1 wBitsPerSample: 0 cbSize: 12 WAVE_FORMAT_MPEGLAYER3: wFormatTag: 0x0055 nChannels: 1 nSamplesPerSec: 16000 nAvgBytesPerSec: 2500 nBlockAlign: 1 wBitsPerSample: 0 cbSize: 12 WAVE_FORMAT_MPEGLAYER3: wFormatTag: 0x0055 nChannels: 1 nSamplesPerSec: 12000 nAvgBytesPerSec: 2500 nBlockAlign: 1 wBitsPerSample: 0 cbSize: 12 WAVE_FORMAT_MPEGLAYER3: wFormatTag: 0x0055 nChannels: 1 nSamplesPerSec: 11025 nAvgBytesPerSec: 2500 nBlockAlign: 1 wBitsPerSample: 0 cbSize: 12 WAVE_FORMAT_MPEGLAYER3: wFormatTag: 0x0055 nChannels: 2 nSamplesPerSec: 12000 nAvgBytesPerSec: 2250 nBlockAlign: 1 wBitsPerSample: 0 cbSize: 12 WAVE_FORMAT_MPEGLAYER3: wFormatTag: 0x0055 nChannels: 2 nSamplesPerSec: 11025 nAvgBytesPerSec: 2250 nBlockAlign: 1 wBitsPerSample: 0 cbSize: 12 WAVE_FORMAT_MPEGLAYER3: wFormatTag: 0x0055 nChannels: 2 nSamplesPerSec: 8000 nAvgBytesPerSec: 2250 nBlockAlign: 1 wBitsPerSample: 0 cbSize: 12 WAVE_FORMAT_MPEGLAYER3: wFormatTag: 0x0055 nChannels: 1 nSamplesPerSec: 16000 nAvgBytesPerSec: 2250 nBlockAlign: 1 wBitsPerSample: 0 cbSize: 12 WAVE_FORMAT_MPEGLAYER3: wFormatTag: 0x0055 nChannels: 1 nSamplesPerSec: 12000 nAvgBytesPerSec: 2250 nBlockAlign: 1 wBitsPerSample: 0 cbSize: 12 WAVE_FORMAT_MPEGLAYER3: wFormatTag: 0x0055 nChannels: 1 nSamplesPerSec: 11025 nAvgBytesPerSec: 2250 nBlockAlign: 1 wBitsPerSample: 0 cbSize: 12 WAVE_FORMAT_GSM610: wFormatTag: 0x0031 nChannels: 1 nSamplesPerSec: 11025 nAvgBytesPerSec: 2239 nBlockAlign: 65 wBitsPerSample: 0 cbSize: 2 WAVE_FORMAT_WMAUDIO2: wFormatTag: 0x0161 nChannels: 1 nSamplesPerSec: 16000 nAvgBytesPerSec: 2000 nBlockAlign: 64 wBitsPerSample: 16 cbSize: 47 WAVE_FORMAT_MPEGLAYER3: wFormatTag: 0x0055 nChannels: 1 nSamplesPerSec: 16000 nAvgBytesPerSec: 2000 nBlockAlign: 1 wBitsPerSample: 0 cbSize: 12 WAVE_FORMAT_MPEGLAYER3: wFormatTag: 0x0055 nChannels: 1 nSamplesPerSec: 12000 nAvgBytesPerSec: 2000 nBlockAlign: 1 wBitsPerSample: 0 cbSize: 12 WAVE_FORMAT_MPEGLAYER3: wFormatTag: 0x0055 nChannels: 1 nSamplesPerSec: 11025 nAvgBytesPerSec: 2000 nBlockAlign: 1 wBitsPerSample: 0 cbSize: 12 WAVE_FORMAT_MPEGLAYER3: wFormatTag: 0x0055 nChannels: 1 nSamplesPerSec: 8000 nAvgBytesPerSec: 2000 nBlockAlign: 1 wBitsPerSample: 0 cbSize: 12 WAVE_FORMAT_GSM610: wFormatTag: 0x0031 nChannels: 1 nSamplesPerSec: 8000 nAvgBytesPerSec: 1625 nBlockAlign: 65 wBitsPerSample: 0 cbSize: 2 WAVE_FORMAT_WMAUDIO2: wFormatTag: 0x0161 nChannels: 2 nSamplesPerSec: 8000 nAvgBytesPerSec: 1500 nBlockAlign: 96 wBitsPerSample: 16 cbSize: 47 WAVE_FORMAT_WMAUDIO2: wFormatTag: 0x0161 nChannels: 1 nSamplesPerSec: 11025 nAvgBytesPerSec: 1249 nBlockAlign: 58 wBitsPerSample: 16 cbSize: 47 WAVE_FORMAT_DSPGROUP_TRUESPEECH : wFormatTag: 0x0022 nChannels: 1 nSamplesPerSec: 8000 nAvgBytesPerSec: 1067 nBlockAlign: 32 wBitsPerSample: 1 cbSize: 32 WAVE_FORMAT_WMAUDIO2: wFormatTag: 0x0161 nChannels: 1 nSamplesPerSec: 11025 nAvgBytesPerSec: 1012 nBlockAlign: 47 wBitsPerSample: 16 cbSize: 47 WAVE_FORMAT_WMAUDIO2: wFormatTag: 0x0161 nChannels: 1 nSamplesPerSec: 8000 nAvgBytesPerSec: 1000 nBlockAlign: 64 wBitsPerSample: 16 cbSize: 47 WAVE_FORMAT_MPEGLAYER3: wFormatTag: 0x0055 nChannels: 1 nSamplesPerSec: 12000 nAvgBytesPerSec: 1000 nBlockAlign: 1 wBitsPerSample: 0 cbSize: 12 WAVE_FORMAT_MPEGLAYER3: wFormatTag: 0x0055 nChannels: 1 nSamplesPerSec: 11025 nAvgBytesPerSec: 1000 nBlockAlign: 1 wBitsPerSample: 0 cbSize: 12 WAVE_FORMAT_MPEGLAYER3: wFormatTag: 0x0055 nChannels: 1 nSamplesPerSec: 8000 nAvgBytesPerSec: 1000 nBlockAlign: 1 wBitsPerSample: 0 cbSize: 12 WAVE_FORMAT_MSG723: wFormatTag: 0x0042 nChannels: 1 nSamplesPerSec: 8000 nAvgBytesPerSec: 800 nBlockAlign: 24 wBitsPerSample: 0 cbSize: 10 WAVE_FORMAT_WMAUDIO2: wFormatTag: 0x0161 nChannels: 1 nSamplesPerSec: 8000 nAvgBytesPerSec: 750 nBlockAlign: 48 wBitsPerSample: 16 cbSize: 47 WAVE_FORMAT_MSG723: wFormatTag: 0x0042 nChannels: 1 nSamplesPerSec: 8000 nAvgBytesPerSec: 666 nBlockAlign: 20 wBitsPerSample: 0 cbSize: 10 xrdp-0.9.5/sesman/chansrv/smartcard_pcsc.c000644 001751 001751 00000165212 13174271344 020525 0ustar00metameta000000 000000 /** * xrdp: A Remote Desktop Protocol server. * * Copyright (C) Jay Sorg 2013 jay.sorg@gmail.com * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. * */ /* * smartcard redirection support, PCSC daemon standin * this will act like pcsc daemon * pcsc lib and daemon write struct on unix domain socket for communication */ #if defined(HAVE_CONFIG_H) #include #endif #define JAY_TODO_CONTEXT 0 #define JAY_TODO_WIDE 1 #define PCSC_STANDIN 1 #include "os_calls.h" #include "smartcard.h" #include "log.h" #include "irp.h" #include "devredir.h" #include "trans.h" #include "chansrv.h" #include "list.h" #if PCSC_STANDIN #define LLOG_LEVEL 1 #define LLOGLN(_level, _args) \ do \ { \ if (_level < LLOG_LEVEL) \ { \ g_write("chansrv:smartcard_pcsc [%10.10u]: ", g_time3()); \ g_writeln _args ; \ } \ } \ while (0) extern int g_display_num; /* in chansrv.c */ static int g_autoinc = 0; /* general purpose autoinc */ struct pcsc_card /* item for list of open cards in one context */ { tui32 app_card; /* application card, always 4 bytes */ int card_bytes; /* client card bytes */ char card[16]; /* client card */ }; struct pcsc_context { tui32 app_context; /* application context, always 4 byte */ int context_bytes; /* client context bytes */ char context[16]; /* client context */ struct list *cards; /* these need to be released on close */ }; /*****************************************************************************/ struct pcsc_uds_client { int uds_client_id; /* unique id represents each app */ struct trans *con; /* the connection to the app */ struct list *contexts; /* list of struct pcsc_context */ struct pcsc_context *connect_context; }; static struct list *g_uds_clients = 0; /* struct pcsc_uds_client */ static struct trans *g_lis = 0; static char g_pcsclite_ipc_dir[256] = ""; static char g_pcsclite_ipc_file[256] = ""; /*****************************************************************************/ /* got a new unix domain socket connection */ static struct pcsc_uds_client * create_uds_client(struct trans *con) { struct pcsc_uds_client *uds_client; LLOGLN(10, ("create_uds_client:")); if (con == 0) { return 0; } uds_client = g_new0(struct pcsc_uds_client, 1); if (uds_client == 0) { return 0; } g_autoinc++; uds_client->uds_client_id = g_autoinc; uds_client->con = con; con->callback_data = uds_client; return uds_client; } /*****************************************************************************/ static struct pcsc_uds_client * get_uds_client_by_id(int uds_client_id) { struct pcsc_uds_client *uds_client; int index; LLOGLN(10, ("get_uds_client_by_id:")); if (uds_client_id == 0) { LLOGLN(10, ("get_uds_client_by_id: uds_client_id zero")); return 0; } if (g_uds_clients == 0) { LLOGLN(10, ("get_uds_client_by_id: g_uds_clients is nil")); return 0; } LLOGLN(10, (" count %d", g_uds_clients->count)); for (index = 0; index < g_uds_clients->count; index++) { uds_client = (struct pcsc_uds_client *) list_get_item(g_uds_clients, index); if (uds_client->uds_client_id == uds_client_id) { return uds_client; } } LLOGLN(10, ("get_uds_client_by_id: can't find uds_client_id %d", uds_client_id)); return 0; } /*****************************************************************************/ struct pcsc_context * get_pcsc_context_by_app_context(struct pcsc_uds_client *uds_client, tui32 app_context) { struct pcsc_context *rv; int index; if (uds_client == 0) { return 0; } if (uds_client->contexts == 0) { return 0; } for (index = 0; index < uds_client->contexts->count; index++) { rv = (struct pcsc_context *) list_get_item(uds_client->contexts, index); if (rv->app_context == app_context) { return rv; } } return 0; } /*****************************************************************************/ struct pcsc_card * get_pcsc_card_by_app_card(struct pcsc_uds_client *uds_client, tui32 app_card, struct pcsc_context **acontext) { struct pcsc_card *lcard; struct pcsc_context *lcontext; int index; int index1; LLOGLN(10, ("get_pcsc_card_by_app_card:")); LLOGLN(10, (" app_card %d", app_card)); if (uds_client == 0) { LLOGLN(0, ("get_pcsc_card_by_app_card: error")); return 0; } if (uds_client->contexts == 0) { LLOGLN(0, ("get_pcsc_card_by_app_card: error")); return 0; } for (index = 0; index < uds_client->contexts->count; index++) { lcontext = (struct pcsc_context *) list_get_item(uds_client->contexts, index); if (lcontext != 0) { if (lcontext->cards != 0) { for (index1 = 0; index1 < lcontext->cards->count; index1++) { lcard = (struct pcsc_card *) list_get_item(lcontext->cards, index1); if (lcard != 0) { if (lcard->app_card == app_card) { if (acontext != 0) { *acontext = lcontext; } return lcard; } } } } } } LLOGLN(0, ("get_pcsc_card_by_app_card: error")); return 0; } /*****************************************************************************/ static int free_uds_client(struct pcsc_uds_client *uds_client) { int i; int j; struct pcsc_context *context; struct pcsc_card *card; LLOGLN(10, ("free_uds_client:")); if (uds_client == 0) { return 0; } if (uds_client->contexts != 0) { for (i = 0; i < uds_client->contexts->count; i++) { context = (struct pcsc_context *) list_get_item(uds_client->contexts, i); if (context != 0) { if (context->cards != 0) { for (j = 0; j < context->cards->count; j++) { card = (struct pcsc_card *) list_get_item(context->cards, j); if (card != 0) { /* TODO: send free card to client */ g_free(card); } } list_delete(context->cards); } LLOGLN(10, (" left over context %p", context->context)); scard_send_cancel(0, context->context, context->context_bytes); scard_send_release_context(0, context->context, context->context_bytes); g_free(context); } } list_delete(uds_client->contexts); } trans_delete(uds_client->con); g_free(uds_client); return 0; } /*****************************************************************************/ static struct pcsc_context * uds_client_add_context(struct pcsc_uds_client *uds_client, char *context, int context_bytes) { struct pcsc_context *pcscContext; LLOGLN(10, ("uds_client_add_context:")); pcscContext = (struct pcsc_context *) g_malloc(sizeof(struct pcsc_context), 1); if (pcscContext == 0) { LLOGLN(0, ("uds_client_add_context: error")); return 0; } g_autoinc++; pcscContext->app_context = g_autoinc; pcscContext->context_bytes = context_bytes; g_memcpy(pcscContext->context, context, context_bytes); if (uds_client->contexts == 0) { uds_client->contexts = list_create(); if (uds_client->contexts == 0) { LLOGLN(0, ("uds_client_add_context: error")); return 0; } } list_add_item(uds_client->contexts, (tintptr) pcscContext); return pcscContext; } /*****************************************************************************/ static int uds_client_remove_context(struct pcsc_uds_client *uds_client, struct pcsc_context *acontext) { int index; if (uds_client->contexts == 0) { LLOGLN(0, ("uds_client_remove_context: error")); return 1; } index = list_index_of(uds_client->contexts, (tintptr) acontext); if (index < 0) { LLOGLN(0, ("uds_client_remove_context: error")); return 1; } list_remove_item(uds_client->contexts, index); g_free(acontext); // TODO free cards return 0; } /*****************************************************************************/ static struct pcsc_card * context_add_card(struct pcsc_uds_client *uds_client, struct pcsc_context *acontext, char *card, int card_bytes) { struct pcsc_card *pcscCard; LLOGLN(10, ("context_add_card: card_bytes %d", card_bytes)); pcscCard = (struct pcsc_card *) g_malloc(sizeof(struct pcsc_card), 1); if (pcscCard == 0) { LLOGLN(0, ("context_add_card: error")); return 0; } g_autoinc++; pcscCard->app_card = g_autoinc; pcscCard->card_bytes = card_bytes; g_memcpy(pcscCard->card, card, card_bytes); if (acontext->cards == 0) { acontext->cards = list_create(); if (acontext->cards == 0) { LLOGLN(0, ("context_add_card: error")); return 0; } } list_add_item(acontext->cards, (tintptr) pcscCard); LLOGLN(10, (" new app_card %d", pcscCard->app_card)); return pcscCard; } /*****************************************************************************/ int scard_pcsc_get_wait_objs(tbus *objs, int *count, int *timeout) { struct pcsc_uds_client *uds_client; int index; LLOGLN(10, ("scard_pcsc_get_wait_objs:")); if (g_lis != 0) { trans_get_wait_objs(g_lis, objs, count); } if (g_uds_clients != 0) { for (index = 0; index < g_uds_clients->count; index++) { uds_client = (struct pcsc_uds_client *) list_get_item(g_uds_clients, index); if (uds_client != 0) { trans_get_wait_objs(uds_client->con, objs, count); } } } return 0; } /*****************************************************************************/ int scard_pcsc_check_wait_objs(void) { struct pcsc_uds_client *uds_client; int index; LLOGLN(10, ("scard_pcsc_check_wait_objs:")); if (g_lis != 0) { if (trans_check_wait_objs(g_lis) != 0) { LLOGLN(0, ("scard_pcsc_check_wait_objs: g_lis trans_check_wait_objs error")); } } if (g_uds_clients != 0) { index = 0; while (index < g_uds_clients->count) { uds_client = (struct pcsc_uds_client *) list_get_item(g_uds_clients, index); if (uds_client != 0) { if (trans_check_wait_objs(uds_client->con) != 0) { free_uds_client(uds_client); list_remove_item(g_uds_clients, index); continue; } } index++; } } return 0; } /*****************************************************************************/ /* returns error */ int scard_process_establish_context(struct trans *con, struct stream *in_s) { int dwScope; struct pcsc_uds_client *uds_client; void *user_data; LLOGLN(10, ("scard_process_establish_context:")); uds_client = (struct pcsc_uds_client *) (con->callback_data); in_uint32_le(in_s, dwScope); LLOGLN(10, ("scard_process_establish_context: dwScope 0x%8.8x", dwScope)); user_data = (void *) (tintptr) (uds_client->uds_client_id); scard_send_establish_context(user_data, dwScope); return 0; } /*****************************************************************************/ /* returns error */ int scard_function_establish_context_return(void *user_data, struct stream *in_s, int len, int status) { int bytes; int uds_client_id; int context_bytes; int app_context; char context[16]; struct stream *out_s; struct pcsc_uds_client *uds_client; struct trans *con; struct pcsc_context *lcontext; LLOGLN(10, ("scard_function_establish_context_return:")); LLOGLN(10, (" status 0x%8.8x", status)); uds_client_id = (int) (tintptr) user_data; uds_client = (struct pcsc_uds_client *) get_uds_client_by_id(uds_client_id); if (uds_client == 0) { LLOGLN(0, ("scard_function_establish_context_return: " "get_uds_client_by_id failed")); return 1; } con = uds_client->con; lcontext = 0; app_context = 0; g_memset(context, 0, 16); if (status == 0) { in_uint8s(in_s, 28); in_uint32_le(in_s, context_bytes); if (context_bytes > 16) { LLOGLN(0, ("scard_function_establish_context_return: opps " "context_bytes %d", context_bytes)); g_hexdump(in_s->p, context_bytes); return 1; } in_uint8a(in_s, context, context_bytes); lcontext = uds_client_add_context(uds_client, context, context_bytes); app_context = lcontext->app_context; LLOGLN(10, ("scard_function_establish_context_return: " "app_context %d", app_context)); } out_s = trans_get_out_s(con, 8192); s_push_layer(out_s, iso_hdr, 8); out_uint32_le(out_s, app_context); out_uint32_le(out_s, status); /* SCARD_S_SUCCESS status */ s_mark_end(out_s); bytes = (int) (out_s->end - out_s->data); s_pop_layer(out_s, iso_hdr); out_uint32_le(out_s, bytes - 8); out_uint32_le(out_s, 0x01); /* SCARD_ESTABLISH_CONTEXT 0x01 */ return trans_force_write(con); } /*****************************************************************************/ /* returns error */ int scard_process_release_context(struct trans *con, struct stream *in_s) { int hContext; struct pcsc_uds_client *uds_client; struct pcsc_context *lcontext; void *user_data; LLOGLN(10, ("scard_process_release_context:")); uds_client = (struct pcsc_uds_client *) (con->callback_data); in_uint32_le(in_s, hContext); LLOGLN(10, ("scard_process_release_context: hContext 0x%8.8x", hContext)); user_data = (void *) (tintptr) (uds_client->uds_client_id); lcontext = get_pcsc_context_by_app_context(uds_client, hContext); if (lcontext == 0) { LLOGLN(0, ("scard_process_release_context: " "get_pcsc_context_by_app_context failed")); return 1; } scard_send_release_context(user_data, lcontext->context, lcontext->context_bytes); uds_client_remove_context(uds_client, lcontext); return 0; } /*****************************************************************************/ /* returns error */ int scard_function_release_context_return(void *user_data, struct stream *in_s, int len, int status) { int bytes; int uds_client_id; struct stream *out_s; struct pcsc_uds_client *uds_client; struct trans *con; LLOGLN(10, ("scard_function_release_context_return:")); LLOGLN(10, (" status 0x%8.8x", status)); uds_client_id = (int) (tintptr) user_data; uds_client = (struct pcsc_uds_client *) get_uds_client_by_id(uds_client_id); if (uds_client == 0) { LLOGLN(0, ("scard_function_release_context_return: " "get_uds_client_by_id failed")); return 1; } con = uds_client->con; out_s = trans_get_out_s(con, 8192); s_push_layer(out_s, iso_hdr, 8); out_uint32_le(out_s, status); /* SCARD_S_SUCCESS status */ s_mark_end(out_s); bytes = (int) (out_s->end - out_s->data); s_pop_layer(out_s, iso_hdr); out_uint32_le(out_s, bytes - 8); out_uint32_le(out_s, 0x02); /* SCARD_RELEASE_CONTEXT 0x02 */ return trans_force_write(con); } /*****************************************************************************/ struct pcsc_list_readers { int uds_client_id; int cchReaders; }; /*****************************************************************************/ /* returns error */ int scard_process_list_readers(struct trans *con, struct stream *in_s) { int hContext; int bytes_groups; int cchReaders; char *groups; struct pcsc_uds_client *uds_client; struct pcsc_context *lcontext; struct pcsc_list_readers *pcscListReaders; LLOGLN(10, ("scard_process_list_readers:")); uds_client = (struct pcsc_uds_client *) (con->callback_data); in_uint32_le(in_s, hContext); in_uint32_le(in_s, bytes_groups); groups = (char *) g_malloc(bytes_groups + 1, 1); in_uint8a(in_s, groups, bytes_groups); in_uint32_le(in_s, cchReaders); LLOGLN(10, ("scard_process_list_readers: hContext 0x%8.8x cchReaders %d", hContext, cchReaders)); lcontext = get_pcsc_context_by_app_context(uds_client, hContext); if (lcontext == 0) { LLOGLN(0, ("scard_process_list_readers: " "get_pcsc_context_by_app_context failed")); g_free(groups); return 1; } pcscListReaders = g_new0(struct pcsc_list_readers, 1); pcscListReaders->uds_client_id = uds_client->uds_client_id; pcscListReaders->cchReaders = cchReaders; scard_send_list_readers(pcscListReaders, lcontext->context, lcontext->context_bytes, groups, cchReaders, 1); g_free(groups); return 0; } /*****************************************************************************/ int scard_function_list_readers_return(void *user_data, struct stream *in_s, int len, int status) { struct stream *out_s; int chr; int readers; int rn_index; int index; int bytes; int cchReaders; int llen; int uds_client_id; twchar reader_name[100]; char lreader_name[16][100]; struct pcsc_uds_client *uds_client; struct trans *con; struct pcsc_list_readers *pcscListReaders; LLOGLN(10, ("scard_function_list_readers_return:")); LLOGLN(10, (" status 0x%8.8x", status)); pcscListReaders = (struct pcsc_list_readers *) user_data; if (pcscListReaders == 0) { LLOGLN(0, ("scard_function_list_readers_return: " "pcscListReaders is nil")); return 1; } uds_client_id = pcscListReaders->uds_client_id; cchReaders = pcscListReaders->cchReaders; g_free(pcscListReaders); uds_client = (struct pcsc_uds_client *) get_uds_client_by_id(uds_client_id); if (uds_client == 0) { LLOGLN(0, ("scard_function_list_readers_return: " "get_uds_client_by_id failed, could not find id %d", uds_client_id)); return 1; } con = uds_client->con; g_memset(reader_name, 0, sizeof(reader_name)); g_memset(lreader_name, 0, sizeof(lreader_name)); rn_index = 0; readers = 0; llen = 0; if (status == 0) { in_uint8s(in_s, 28); in_uint32_le(in_s, len); llen = len; if (cchReaders > 0) { while (len > 0) { in_uint16_le(in_s, chr); len -= 2; if (chr == 0) { if (reader_name[0] != 0) { g_wcstombs(lreader_name[readers], reader_name, 99); g_memset(reader_name, 0, sizeof(reader_name)); readers++; } reader_name[0] = 0; rn_index = 0; } else { reader_name[rn_index] = chr; rn_index++; } } } if (rn_index > 0) { if (reader_name[0] != 0) { g_wcstombs(lreader_name[readers], reader_name, 99); g_memset(reader_name, 0, sizeof(reader_name)); readers++; } } } out_s = trans_get_out_s(con, 8192); s_push_layer(out_s, iso_hdr, 8); out_uint32_le(out_s, llen); out_uint32_le(out_s, readers); for (index = 0; index < readers; index++) { out_uint8a(out_s, lreader_name[index], 100); } out_uint32_le(out_s, status); /* SCARD_S_SUCCESS status */ s_mark_end(out_s); bytes = (int) (out_s->end - out_s->data); s_pop_layer(out_s, iso_hdr); out_uint32_le(out_s, bytes - 8); out_uint32_le(out_s, 0x03); /* SCARD_LIST_READERS 0x03 */ return trans_force_write(con); } /*****************************************************************************/ /* returns error */ int scard_process_connect(struct trans *con, struct stream *in_s) { int hContext; READER_STATE rs; struct pcsc_uds_client *uds_client; void *user_data; struct pcsc_context *lcontext; LLOGLN(10, ("scard_process_connect:")); uds_client = (struct pcsc_uds_client *) (con->callback_data); g_memset(&rs, 0, sizeof(rs)); in_uint32_le(in_s, hContext); in_uint8a(in_s, rs.reader_name, 100); in_uint32_le(in_s, rs.dwShareMode); in_uint32_le(in_s, rs.dwPreferredProtocols); LLOGLN(10, ("scard_process_connect: rs.reader_name %s dwShareMode 0x%8.8x " "dwPreferredProtocols 0x%8.8x", rs.reader_name, rs.dwShareMode, rs.dwPreferredProtocols)); user_data = (void *) (tintptr) (uds_client->uds_client_id); lcontext = get_pcsc_context_by_app_context(uds_client, hContext); if (lcontext == 0) { LLOGLN(0, ("scard_process_connect: " "get_pcsc_context_by_app_context failed")); return 1; } uds_client->connect_context = lcontext; scard_send_connect(user_data, lcontext->context, lcontext->context_bytes, 1, &rs); return 0; } /*****************************************************************************/ int scard_function_connect_return(void *user_data, struct stream *in_s, int len, int status) { int dwActiveProtocol; int hCard; int bytes; int uds_client_id; struct stream *out_s; struct pcsc_uds_client *uds_client; struct trans *con; char *card; int card_bytes; struct pcsc_card *lcard; LLOGLN(10, ("scard_function_connect_return:")); LLOGLN(10, (" status 0x%8.8x", status)); uds_client_id = (int) (tintptr) user_data; uds_client = (struct pcsc_uds_client *) get_uds_client_by_id(uds_client_id); if (uds_client == 0) { LLOGLN(0, ("scard_function_connect_return: " "get_uds_client_by_id failed")); return 1; } con = uds_client->con; dwActiveProtocol = 0; hCard = 0; if (status == 0) { in_uint8s(in_s, 36); in_uint32_le(in_s, dwActiveProtocol); if (len > 40) { in_uint32_le(in_s, card_bytes); in_uint8p(in_s, card, card_bytes); lcard = context_add_card(uds_client, uds_client->connect_context, card, card_bytes); hCard = lcard->app_card; LLOGLN(10, (" hCard %d dwActiveProtocol %d", hCard, dwActiveProtocol)); } else { status = 0x8010000F; /* SCARD_E_PROTO_MISMATCH */ } } out_s = trans_get_out_s(con, 8192); s_push_layer(out_s, iso_hdr, 8); out_uint32_le(out_s, hCard); out_uint32_le(out_s, dwActiveProtocol); out_uint32_le(out_s, status); /* SCARD_S_SUCCESS status */ s_mark_end(out_s); bytes = (int) (out_s->end - out_s->data); s_pop_layer(out_s, iso_hdr); out_uint32_le(out_s, bytes - 8); out_uint32_le(out_s, 0x04); /* SCARD_CONNECT 0x04 */ return trans_force_write(con); } /*****************************************************************************/ /* returns error */ int scard_process_disconnect(struct trans *con, struct stream *in_s) { int hCard; int dwDisposition; struct pcsc_uds_client *uds_client; void *user_data; struct pcsc_context *lcontext; struct pcsc_card *lcard; LLOGLN(10, ("scard_process_disconnect:")); uds_client = (struct pcsc_uds_client *) (con->callback_data); in_uint32_le(in_s, hCard); in_uint32_le(in_s, dwDisposition); user_data = (void *) (tintptr) (uds_client->uds_client_id); lcard = get_pcsc_card_by_app_card(uds_client, hCard, &lcontext); if ((lcontext == 0) || (lcard == 0)) { LLOGLN(0, ("scard_process_disconnect: " "get_pcsc_card_by_app_card failed")); return 1; } scard_send_disconnect(user_data, lcontext->context, lcontext->context_bytes, lcard->card, lcard->card_bytes, dwDisposition); return 0; } /*****************************************************************************/ int scard_function_disconnect_return(void *user_data, struct stream *in_s, int len, int status) { int bytes; int uds_client_id; struct stream *out_s; struct pcsc_uds_client *uds_client; struct trans *con; LLOGLN(10, ("scard_function_disconnect_return:")); LLOGLN(10, (" status 0x%8.8x", status)); uds_client_id = (int) (tintptr) user_data; uds_client = (struct pcsc_uds_client *) get_uds_client_by_id(uds_client_id); if (uds_client == 0) { LLOGLN(0, ("scard_function_disconnect_return: " "get_uds_client_by_id failed")); return 1; } con = uds_client->con; out_s = trans_get_out_s(con, 8192); s_push_layer(out_s, iso_hdr, 8); out_uint32_le(out_s, status); /* SCARD_S_SUCCESS status */ s_mark_end(out_s); bytes = (int) (out_s->end - out_s->data); s_pop_layer(out_s, iso_hdr); out_uint32_le(out_s, bytes - 8); out_uint32_le(out_s, 0x06); /* SCARD_DISCONNECT 0x06 */ return trans_force_write(con); } /*****************************************************************************/ /* returns error */ int scard_process_begin_transaction(struct trans *con, struct stream *in_s) { int hCard; struct pcsc_uds_client *uds_client; void *user_data; struct pcsc_card *lcard; struct pcsc_context *lcontext; LLOGLN(10, ("scard_process_begin_transaction:")); uds_client = (struct pcsc_uds_client *) (con->callback_data); in_uint32_le(in_s, hCard); LLOGLN(10, ("scard_process_begin_transaction: hCard 0x%8.8x", hCard)); user_data = (void *) (tintptr) (uds_client->uds_client_id); lcard = get_pcsc_card_by_app_card(uds_client, hCard, &lcontext); if ((lcard == 0) || (lcontext == 0)) { LLOGLN(0, ("scard_process_begin_transaction: " "get_pcsc_card_by_app_card failed")); return 1; } scard_send_begin_transaction(user_data, lcontext->context, lcontext->context_bytes, lcard->card, lcard->card_bytes); return 0; } /*****************************************************************************/ /* returns error */ int scard_function_begin_transaction_return(void *user_data, struct stream *in_s, int len, int status) { struct stream *out_s; int bytes; int uds_client_id; struct pcsc_uds_client *uds_client; struct trans *con; LLOGLN(10, ("scard_function_begin_transaction_return:")); LLOGLN(10, (" status 0x%8.8x", status)); uds_client_id = (int) (tintptr) user_data; uds_client = (struct pcsc_uds_client *) get_uds_client_by_id(uds_client_id); if (uds_client == 0) { LLOGLN(0, ("scard_function_begin_transaction_return: " "get_uds_client_by_id failed")); return 1; } con = uds_client->con; out_s = trans_get_out_s(con, 8192); s_push_layer(out_s, iso_hdr, 8); out_uint32_le(out_s, status); /* SCARD_S_SUCCESS status */ s_mark_end(out_s); bytes = (int) (out_s->end - out_s->data); s_pop_layer(out_s, iso_hdr); out_uint32_le(out_s, bytes - 8); out_uint32_le(out_s, 0x07); /* SCARD_BEGIN_TRANSACTION 0x07 */ return trans_force_write(con); } /*****************************************************************************/ /* returns error */ int scard_process_end_transaction(struct trans *con, struct stream *in_s) { int hCard; int dwDisposition; struct pcsc_uds_client *uds_client; void *user_data; struct pcsc_card *lcard; struct pcsc_context *lcontext; LLOGLN(10, ("scard_process_end_transaction:")); uds_client = (struct pcsc_uds_client *) (con->callback_data); in_uint32_le(in_s, hCard); in_uint32_le(in_s, dwDisposition); LLOGLN(10, ("scard_process_end_transaction: hCard 0x%8.8x", hCard)); user_data = (void *) (tintptr) (uds_client->uds_client_id); lcard = get_pcsc_card_by_app_card(uds_client, hCard, &lcontext); if ((lcard == 0) || (lcontext == 0)) { LLOGLN(0, ("scard_process_end_transaction: " "get_pcsc_card_by_app_card failed")); return 1; } scard_send_end_transaction(user_data, lcontext->context, lcontext->context_bytes, lcard->card, lcard->card_bytes, dwDisposition); return 0; } /*****************************************************************************/ /* returns error */ int scard_function_end_transaction_return(void *user_data, struct stream *in_s, int len, int status) { struct stream *out_s; int bytes; int uds_client_id; struct pcsc_uds_client *uds_client; struct trans *con; LLOGLN(10, ("scard_function_end_transaction_return:")); LLOGLN(10, (" status 0x%8.8x", status)); uds_client_id = (int) (tintptr) user_data; uds_client = (struct pcsc_uds_client *) get_uds_client_by_id(uds_client_id); if (uds_client == 0) { LLOGLN(0, ("scard_function_end_transaction_return: " "get_uds_client_by_id failed")); return 1; } con = uds_client->con; out_s = trans_get_out_s(con, 8192); s_push_layer(out_s, iso_hdr, 8); out_uint32_le(out_s, status); /* SCARD_S_SUCCESS status */ s_mark_end(out_s); bytes = (int) (out_s->end - out_s->data); s_pop_layer(out_s, iso_hdr); out_uint32_le(out_s, bytes - 8); out_uint32_le(out_s, 0x08); /* SCARD_END_TRANSACTION 0x08 */ return trans_force_write(con); } /*****************************************************************************/ /* returns error */ int scard_function_get_attrib_return(void *user_data, struct stream *in_s, int len, int status) { return 0; } /*****************************************************************************/ struct pcsc_transmit { int uds_client_id; struct xrdp_scard_io_request recv_ior; int cbRecvLength; }; /*****************************************************************************/ /* returns error */ int scard_process_transmit(struct trans *con, struct stream *in_s) { int hCard; int recv_bytes; int send_bytes; char *send_data; struct xrdp_scard_io_request send_ior; struct xrdp_scard_io_request recv_ior; struct pcsc_uds_client *uds_client; struct pcsc_card *lcard; struct pcsc_context *lcontext; struct pcsc_transmit *pcscTransmit; LLOGLN(10, ("scard_process_transmit:")); uds_client = (struct pcsc_uds_client *) (con->callback_data); LLOGLN(10, ("scard_process_transmit:")); in_uint32_le(in_s, hCard); in_uint32_le(in_s, send_ior.dwProtocol); in_uint32_le(in_s, send_ior.cbPciLength); in_uint32_le(in_s, send_ior.extra_bytes); in_uint8p(in_s, send_ior.extra_data, send_ior.extra_bytes); in_uint32_le(in_s, send_bytes); in_uint8p(in_s, send_data, send_bytes); in_uint32_le(in_s, recv_ior.dwProtocol); in_uint32_le(in_s, recv_ior.cbPciLength); in_uint32_le(in_s, recv_ior.extra_bytes); in_uint8p(in_s, recv_ior.extra_data, recv_ior.extra_bytes); in_uint32_le(in_s, recv_bytes); LLOGLN(10, ("scard_process_transmit: send dwProtocol %d cbPciLength %d " "recv dwProtocol %d cbPciLength %d send_bytes %d ", send_ior.dwProtocol, send_ior.cbPciLength, recv_ior.dwProtocol, recv_ior.cbPciLength, send_bytes)); LLOGLN(10, ("scard_process_transmit: recv_bytes %d", recv_bytes)); lcard = get_pcsc_card_by_app_card(uds_client, hCard, &lcontext); if ((lcard == 0) || (lcontext == 0)) { LLOGLN(0, ("scard_process_transmit: " "get_pcsc_card_by_app_card failed")); return 1; } pcscTransmit = (struct pcsc_transmit *) g_malloc(sizeof(struct pcsc_transmit), 1); pcscTransmit->uds_client_id = uds_client->uds_client_id; pcscTransmit->recv_ior = recv_ior; pcscTransmit->cbRecvLength = recv_bytes; scard_send_transmit(pcscTransmit, lcontext->context, lcontext->context_bytes, lcard->card, lcard->card_bytes, send_data, send_bytes, recv_bytes, &send_ior, &recv_ior); return 0; } /*****************************************************************************/ /* returns error */ int scard_function_transmit_return(void *user_data, struct stream *in_s, int len, int status) { struct stream *out_s; int bytes; int val; int cbRecvLength; char *recvBuf; struct xrdp_scard_io_request recv_ior; struct pcsc_uds_client *uds_client; struct trans *con; struct pcsc_transmit *pcscTransmit; LLOGLN(10, ("scard_function_transmit_return:")); LLOGLN(10, (" status 0x%8.8x", status)); pcscTransmit = (struct pcsc_transmit *) user_data; recv_ior = pcscTransmit->recv_ior; uds_client = (struct pcsc_uds_client *) get_uds_client_by_id(pcscTransmit->uds_client_id); g_free(pcscTransmit); if (uds_client == 0) { LLOGLN(0, ("scard_function_transmit_return: " "get_uds_client_by_id failed")); return 1; } con = uds_client->con; cbRecvLength = 0; recvBuf = 0; if (status == 0) { in_uint8s(in_s, 20); in_uint32_le(in_s, val); if (val != 0) { /* pioRecvPci */ in_uint8s(in_s, 8); in_uint32_le(in_s, recv_ior.dwProtocol); in_uint32_le(in_s, recv_ior.cbPciLength); recv_ior.cbPciLength += 8; in_uint32_le(in_s, recv_ior.extra_bytes); if (recv_ior.extra_bytes > 0) { in_uint8p(in_s, recv_ior.extra_data, recv_ior.extra_bytes); } } in_uint8s(in_s, 4); in_uint32_le(in_s, val); if (val != 0) { in_uint32_le(in_s, cbRecvLength); in_uint8p(in_s, recvBuf, cbRecvLength); } } LLOGLN(10, ("scard_function_transmit_return: cbRecvLength %d", cbRecvLength)); out_s = trans_get_out_s(con, 8192); s_push_layer(out_s, iso_hdr, 8); out_uint32_le(out_s, recv_ior.dwProtocol); out_uint32_le(out_s, recv_ior.cbPciLength); out_uint32_le(out_s, recv_ior.extra_bytes); out_uint8a(out_s, recv_ior.extra_data, recv_ior.extra_bytes); out_uint32_le(out_s, cbRecvLength); out_uint8a(out_s, recvBuf, cbRecvLength); out_uint32_le(out_s, status); /* SCARD_S_SUCCESS status */ s_mark_end(out_s); bytes = (int) (out_s->end - out_s->data); s_pop_layer(out_s, iso_hdr); out_uint32_le(out_s, bytes - 8); out_uint32_le(out_s, 0x09); /* SCARD_TRANSMIT 0x09 */ return trans_force_write(con); } /*****************************************************************************/ /* returns error */ int scard_process_control(struct trans *con, struct stream *in_s) { int hCard; int send_bytes; int recv_bytes; int control_code; char *send_data; struct pcsc_uds_client *uds_client; void *user_data; struct pcsc_context *lcontext; struct pcsc_card *lcard; LLOGLN(10, ("scard_process_control:")); uds_client = (struct pcsc_uds_client *) (con->callback_data); LLOGLN(10, ("scard_process_control:")); in_uint32_le(in_s, hCard); in_uint32_le(in_s, control_code); in_uint32_le(in_s, send_bytes); in_uint8p(in_s, send_data, send_bytes); in_uint32_le(in_s, recv_bytes); user_data = (void *) (tintptr) (uds_client->uds_client_id); lcard = get_pcsc_card_by_app_card(uds_client, hCard, &lcontext); if ((lcard == 0) || (lcontext == 0)) { LLOGLN(0, ("scard_process_control: " "get_pcsc_card_by_app_card failed")); return 1; } scard_send_control(user_data, lcontext->context, lcontext->context_bytes, lcard->card, lcard->card_bytes, send_data, send_bytes, recv_bytes, control_code); return 0; } /*****************************************************************************/ /* returns error */ int scard_function_control_return(void *user_data, struct stream *in_s, int len, int status) { struct stream *out_s; int bytes; int cbRecvLength; char *recvBuf; int uds_client_id; struct pcsc_uds_client *uds_client; struct trans *con; LLOGLN(10, ("scard_function_control_return:")); LLOGLN(10, (" status 0x%8.8x", status)); uds_client_id = (int) (tintptr) user_data; uds_client = (struct pcsc_uds_client *) get_uds_client_by_id(uds_client_id); if (uds_client == 0) { LLOGLN(0, ("scard_function_control_return: " "get_uds_client_by_id failed")); return 1; } con = uds_client->con; cbRecvLength = 0; recvBuf = 0; if (status == 0) { in_uint8s(in_s, 28); in_uint32_le(in_s, cbRecvLength); in_uint8p(in_s, recvBuf, cbRecvLength); } LLOGLN(10, ("scard_function_control_return: cbRecvLength %d", cbRecvLength)); out_s = trans_get_out_s(con, 8192); s_push_layer(out_s, iso_hdr, 8); out_uint32_le(out_s, cbRecvLength); out_uint8a(out_s, recvBuf, cbRecvLength); out_uint32_le(out_s, status); /* SCARD_S_SUCCESS status */ s_mark_end(out_s); bytes = (int) (out_s->end - out_s->data); s_pop_layer(out_s, iso_hdr); out_uint32_le(out_s, bytes - 8); out_uint32_le(out_s, 0x0A); /* SCARD_CONTROL 0x0A */ return trans_force_write(con); } /*****************************************************************************/ struct pcsc_status { int uds_client_id; int cchReaderLen; }; /*****************************************************************************/ /* returns error */ int scard_process_status(struct trans *con, struct stream *in_s) { int hCard; int cchReaderLen; int cbAtrLen; struct pcsc_uds_client *uds_client; struct pcsc_card *lcard; struct pcsc_context *lcontext; struct pcsc_status *pcscStatus; LLOGLN(10, ("scard_process_status:")); uds_client = (struct pcsc_uds_client *) (con->callback_data); in_uint32_le(in_s, hCard); in_uint32_le(in_s, cchReaderLen); in_uint32_le(in_s, cbAtrLen); LLOGLN(10, ("scard_process_status: hCard 0x%8.8x cchReaderLen %d " "cbAtrLen %d", hCard, cchReaderLen, cbAtrLen)); lcard = get_pcsc_card_by_app_card(uds_client, hCard, &lcontext); if ((lcard == 0) || (lcontext == 0)) { LLOGLN(0, ("scard_process_status: " "get_pcsc_card_by_app_card failed")); return 1; } pcscStatus = (struct pcsc_status *) g_malloc(sizeof(struct pcsc_status), 1); pcscStatus->uds_client_id = uds_client->uds_client_id; pcscStatus->cchReaderLen = cchReaderLen; scard_send_status(pcscStatus, 1, lcontext->context, lcontext->context_bytes, lcard->card, lcard->card_bytes, cchReaderLen, cbAtrLen); return 0; } #define MS_SCARD_UNKNOWN 0 #define MS_SCARD_ABSENT 1 #define MS_SCARD_PRESENT 2 #define MS_SCARD_SWALLOWED 3 #define MS_SCARD_POWERED 4 #define MS_SCARD_NEGOTIABLE 5 #define MS_SCARD_SPECIFIC 6 #define PC_SCARD_UNKNOWN 0x0001 /**< Unknown state */ #define PC_SCARD_ABSENT 0x0002 /**< Card is absent */ #define PC_SCARD_PRESENT 0x0004 /**< Card is present */ #define PC_SCARD_SWALLOWED 0x0008 /**< Card not powered */ #define PC_SCARD_POWERED 0x0010 /**< Card is powered */ #define PC_SCARD_NEGOTIABLE 0x0020 /**< Ready for PTS */ #define PC_SCARD_SPECIFIC 0x0040 /**< PTS has been set */ static int g_ms2pc[] = { PC_SCARD_UNKNOWN, PC_SCARD_ABSENT, PC_SCARD_PRESENT, PC_SCARD_SWALLOWED, PC_SCARD_POWERED, PC_SCARD_NEGOTIABLE, PC_SCARD_SPECIFIC }; /*****************************************************************************/ /* returns error */ int scard_function_status_return(void *user_data, struct stream *in_s, int len, int status) { struct stream *out_s; int index; int bytes; int dwReaderLen; int dwState; int dwProtocol; int dwAtrLen; char attr[32]; twchar reader_name[100]; char lreader_name[100]; int uds_client_id; struct pcsc_uds_client *uds_client; struct trans *con; struct pcsc_status *pcscStatus; LLOGLN(10, ("scard_function_status_return:")); LLOGLN(10, (" status 0x%8.8x", status)); pcscStatus = (struct pcsc_status *) user_data; if (pcscStatus == 0) { LLOGLN(0, ("scard_function_status_return: pcscStatus is nil")); return 1; } uds_client_id = pcscStatus->uds_client_id; uds_client = (struct pcsc_uds_client *) get_uds_client_by_id(uds_client_id); if (uds_client == 0) { LLOGLN(0, ("scard_function_status_return: " "get_uds_client_by_id failed")); g_free(pcscStatus); return 1; } g_free(pcscStatus); con = uds_client->con; dwReaderLen = 0; dwState = 0; dwProtocol = 0; dwAtrLen = 0; lreader_name[0] = 0; if (status == 0) { in_uint8s(in_s, 20); in_uint32_le(in_s, dwReaderLen); in_uint8s(in_s, 4); in_uint32_le(in_s, dwState); dwState = g_ms2pc[dwState % 6]; in_uint32_le(in_s, dwProtocol); in_uint8a(in_s, attr, 32); in_uint32_le(in_s, dwAtrLen); if (dwReaderLen > 0) { in_uint32_le(in_s, dwReaderLen); dwReaderLen /= 2; } else { dwReaderLen = 1; } if (dwReaderLen < 1) { LLOGLN(0, ("scard_function_status_return: dwReaderLen < 1")); dwReaderLen = 1; } if (dwReaderLen > 99) { LLOGLN(0, ("scard_function_status_return: dwReaderLen too big " "0x%8.8x", dwReaderLen)); dwReaderLen = 99; } g_memset(reader_name, 0, sizeof(reader_name)); g_memset(lreader_name, 0, sizeof(lreader_name)); for (index = 0; index < dwReaderLen - 1; index++) { in_uint16_le(in_s, reader_name[index]); } g_wcstombs(lreader_name, reader_name, 99); } LLOGLN(10, ("scard_function_status_return: dwAtrLen %d dwReaderLen %d " "dwProtocol %d dwState %d name %s", dwAtrLen, dwReaderLen, dwProtocol, dwState, lreader_name)); out_s = trans_get_out_s(con, 8192); s_push_layer(out_s, iso_hdr, 8); dwReaderLen = g_strlen(lreader_name); out_uint32_le(out_s, dwReaderLen); out_uint8a(out_s, lreader_name, dwReaderLen); out_uint32_le(out_s, dwState); out_uint32_le(out_s, dwProtocol); out_uint32_le(out_s, dwAtrLen); out_uint8a(out_s, attr, dwAtrLen); out_uint32_le(out_s, status); /* SCARD_S_SUCCESS status */ s_mark_end(out_s); bytes = (int) (out_s->end - out_s->data); s_pop_layer(out_s, iso_hdr); out_uint32_le(out_s, bytes - 8); out_uint32_le(out_s, 0x0B); /* SCARD_STATUS 0x0B */ return trans_force_write(con); } /*****************************************************************************/ /* returns error */ int scard_process_get_status_change(struct trans *con, struct stream *in_s) { int index; int hContext; int dwTimeout; int cReaders; READER_STATE *rsa; struct pcsc_uds_client *uds_client; void *user_data; struct pcsc_context *lcontext; LLOGLN(10, ("scard_process_get_status_change:")); uds_client = (struct pcsc_uds_client *) (con->callback_data); in_uint32_le(in_s, hContext); in_uint32_le(in_s, dwTimeout); in_uint32_le(in_s, cReaders); if ((cReaders < 0) || (cReaders > 16)) { LLOGLN(0, ("scard_process_get_status_change: bad cReaders %d", cReaders)); return 1; } rsa = (READER_STATE *) g_malloc(sizeof(READER_STATE) * cReaders, 1); for (index = 0; index < cReaders; index++) { in_uint8a(in_s, rsa[index].reader_name, 100); LLOGLN(10, ("scard_process_get_status_change: reader_name %s", rsa[index].reader_name)); in_uint32_le(in_s, rsa[index].current_state); LLOGLN(10, ("scard_process_get_status_change: current_state %d", rsa[index].current_state)); in_uint32_le(in_s, rsa[index].event_state); LLOGLN(10, ("scard_process_get_status_change: event_state %d", rsa[index].event_state)); in_uint32_le(in_s, rsa[index].atr_len); LLOGLN(10, ("scard_process_get_status_change: atr_len %d", rsa[index].atr_len)); in_uint8a(in_s, rsa[index].atr, 36); } LLOGLN(10, ("scard_process_get_status_change: hContext 0x%8.8x dwTimeout " "%d cReaders %d", hContext, dwTimeout, cReaders)); user_data = (void *) (tintptr) (uds_client->uds_client_id); lcontext = get_pcsc_context_by_app_context(uds_client, hContext); if (lcontext == 0) { LLOGLN(0, ("scard_process_get_status_change: " "get_pcsc_context_by_app_context failed")); g_free(rsa); return 1; } scard_send_get_status_change(user_data, lcontext->context, lcontext->context_bytes, 1, dwTimeout, cReaders, rsa); g_free(rsa); return 0; } /*****************************************************************************/ int scard_function_get_status_change_return(void *user_data, struct stream *in_s, int len, int status) { int bytes; int index; int cReaders; tui32 current_state; tui32 event_state; tui32 atr_len; /* number of bytes in atr[] */ tui8 atr[36]; struct stream *out_s; int uds_client_id; struct pcsc_uds_client *uds_client; struct trans *con; LLOGLN(10, ("scard_function_get_status_change_return:")); LLOGLN(10, (" status 0x%8.8x", status)); uds_client_id = (int) (tintptr) user_data; uds_client = (struct pcsc_uds_client *) get_uds_client_by_id(uds_client_id); if (uds_client == 0) { LLOGLN(0, ("scard_function_get_status_change_return: " "get_uds_client_by_id failed")); return 1; } con = uds_client->con; out_s = trans_get_out_s(con, 8192); s_push_layer(out_s, iso_hdr, 8); if (status != 0) { out_uint32_le(out_s, 0); /* cReaders */ out_uint32_le(out_s, status); /* SCARD_S_SUCCESS status */ } else { in_uint8s(in_s, 28); in_uint32_le(in_s, cReaders); LLOGLN(10, (" cReaders %d", cReaders)); out_uint32_le(out_s, cReaders); if (cReaders > 0) { for (index = 0; index < cReaders; index++) { in_uint32_le(in_s, current_state); out_uint32_le(out_s, current_state); in_uint32_le(in_s, event_state); out_uint32_le(out_s, event_state); in_uint32_le(in_s, atr_len); out_uint32_le(out_s, atr_len); in_uint8a(in_s, atr, 36); out_uint8a(out_s, atr, 36); } } out_uint32_le(out_s, status); /* SCARD_S_SUCCESS status */ } s_mark_end(out_s); bytes = (int) (out_s->end - out_s->data); s_pop_layer(out_s, iso_hdr); out_uint32_le(out_s, bytes - 8); out_uint32_le(out_s, 0x0C); /* SCARD_ESTABLISH_CONTEXT 0x0C */ return trans_force_write(con); } /*****************************************************************************/ /* returns error */ int scard_process_cancel(struct trans *con, struct stream *in_s) { int hContext; struct pcsc_uds_client *uds_client; void *user_data; struct pcsc_context *lcontext; LLOGLN(10, ("scard_process_cancel:")); uds_client = (struct pcsc_uds_client *) (con->callback_data); in_uint32_le(in_s, hContext); LLOGLN(10, ("scard_process_cancel: hContext 0x%8.8x", hContext)); user_data = (void *) (tintptr) (uds_client->uds_client_id); lcontext = get_pcsc_context_by_app_context(uds_client, hContext); if (lcontext == 0) { LLOGLN(0, ("scard_process_cancel: " "get_pcsc_context_by_app_context failed")); return 1; } scard_send_cancel(user_data, lcontext->context, lcontext->context_bytes); return 0; } /*****************************************************************************/ /* returns error */ int scard_function_cancel_return(void *user_data, struct stream *in_s, int len, int status) { int bytes; int uds_client_id; struct stream *out_s; struct pcsc_uds_client *uds_client; struct trans *con; LLOGLN(10, ("scard_function_cancel_return:")); LLOGLN(10, (" status 0x%8.8x", status)); uds_client_id = (int) (tintptr) user_data; uds_client = (struct pcsc_uds_client *) get_uds_client_by_id(uds_client_id); if (uds_client == 0) { LLOGLN(0, ("scard_function_cancel_return: " "get_uds_client_by_id failed")); return 1; } con = uds_client->con; out_s = trans_get_out_s(con, 8192); s_push_layer(out_s, iso_hdr, 8); out_uint32_le(out_s, status); /* SCARD_S_SUCCESS status */ s_mark_end(out_s); bytes = (int) (out_s->end - out_s->data); s_pop_layer(out_s, iso_hdr); out_uint32_le(out_s, bytes - 8); out_uint32_le(out_s, 0x0D); /* SCARD_CANCEL 0x0D */ return trans_force_write(con); } /*****************************************************************************/ /* returns error */ int scard_function_is_context_valid_return(void *user_data, struct stream *in_s, int len, int status) { return 0; } /*****************************************************************************/ /* returns error */ int scard_function_reconnect_return(void *user_data, struct stream *in_s, int len, int status) { return 0; } /*****************************************************************************/ /* returns error */ int scard_process_msg(struct trans *con, struct stream *in_s, int command) { int rv; LLOGLN(10, ("scard_process_msg: command 0x%4.4x", command)); rv = 0; switch (command) { case 0x01: /* SCARD_ESTABLISH_CONTEXT */ LLOGLN(10, ("scard_process_msg: SCARD_ESTABLISH_CONTEXT")); rv = scard_process_establish_context(con, in_s); break; case 0x02: /* SCARD_RELEASE_CONTEXT */ LLOGLN(10, ("scard_process_msg: SCARD_RELEASE_CONTEXT")); rv = scard_process_release_context(con, in_s); break; case 0x03: /* SCARD_LIST_READERS */ LLOGLN(10, ("scard_process_msg: SCARD_LIST_READERS")); rv = scard_process_list_readers(con, in_s); break; case 0x04: /* SCARD_CONNECT */ LLOGLN(10, ("scard_process_msg: SCARD_CONNECT")); rv = scard_process_connect(con, in_s); break; case 0x05: /* SCARD_RECONNECT */ LLOGLN(0, ("scard_process_msg: SCARD_RECONNECT")); break; case 0x06: /* SCARD_DISCONNECT */ LLOGLN(10, ("scard_process_msg: SCARD_DISCONNECT")); rv = scard_process_disconnect(con, in_s); break; case 0x07: /* SCARD_BEGIN_TRANSACTION */ LLOGLN(10, ("scard_process_msg: SCARD_BEGIN_TRANSACTION")); rv = scard_process_begin_transaction(con, in_s); break; case 0x08: /* SCARD_END_TRANSACTION */ LLOGLN(10, ("scard_process_msg: SCARD_END_TRANSACTION")); rv = scard_process_end_transaction(con, in_s); break; case 0x09: /* SCARD_TRANSMIT */ LLOGLN(10, ("scard_process_msg: SCARD_TRANSMIT")); rv = scard_process_transmit(con, in_s); break; case 0x0A: /* SCARD_CONTROL */ LLOGLN(10, ("scard_process_msg: SCARD_CONTROL")); rv = scard_process_control(con, in_s); break; case 0x0B: /* SCARD_STATUS */ LLOGLN(10, ("scard_process_msg: SCARD_STATUS")); rv = scard_process_status(con, in_s); break; case 0x0C: /* SCARD_GET_STATUS_CHANGE */ LLOGLN(10, ("scard_process_msg: SCARD_GET_STATUS_CHANGE")); rv = scard_process_get_status_change(con, in_s); break; case 0x0D: /* SCARD_CANCEL */ LLOGLN(10, ("scard_process_msg: SCARD_CANCEL")); rv = scard_process_cancel(con, in_s); break; case 0x0E: /* SCARD_CANCEL_TRANSACTION */ LLOGLN(0, ("scard_process_msg: SCARD_CANCEL_TRANSACTION")); break; case 0x0F: /* SCARD_GET_ATTRIB */ LLOGLN(0, ("scard_process_msg: SCARD_GET_ATTRIB")); break; case 0x10: /* SCARD_SET_ATTRIB */ LLOGLN(0, ("scard_process_msg: SCARD_SET_ATTRIB")); break; default: LLOGLN(0, ("scard_process_msg: unknown mtype 0x%4.4x", command)); rv = 1; break; } return rv; } /*****************************************************************************/ /* returns error */ int my_pcsc_trans_data_in(struct trans *trans) { struct stream *s; int size; int command; int error; LLOGLN(10, ("my_pcsc_trans_data_in:")); if (trans == 0) { return 0; } s = trans_get_in_s(trans); in_uint32_le(s, size); in_uint32_le(s, command); LLOGLN(10, ("my_pcsc_trans_data_in: size %d command %d", size, command)); error = trans_force_read(trans, size); if (error == 0) { error = scard_process_msg(trans, s, command); } return error; } /*****************************************************************************/ /* got a new connection from libpcsclite */ int my_pcsc_trans_conn_in(struct trans *trans, struct trans *new_trans) { struct pcsc_uds_client *uds_client; LLOGLN(10, ("my_pcsc_trans_conn_in:")); if (trans == 0) { return 1; } if (trans != g_lis) { return 1; } if (new_trans == 0) { return 1; } uds_client = create_uds_client(new_trans); if (uds_client == 0) { return 1; } uds_client->con->trans_data_in = my_pcsc_trans_data_in; uds_client->con->header_size = 8; if (g_uds_clients == 0) { g_uds_clients = list_create(); } list_add_item(g_uds_clients, (tbus)uds_client); return 0; } /*****************************************************************************/ int scard_pcsc_init(void) { char *home; int disp; int error; LLOGLN(0, ("scard_pcsc_init:")); if (g_lis == 0) { g_lis = trans_create(2, 8192, 8192); home = g_getenv("HOME"); disp = g_display_num; g_snprintf(g_pcsclite_ipc_dir, 255, "%s/.pcsc%d", home, disp); if (g_directory_exist(g_pcsclite_ipc_dir)) { if (!g_remove_dir(g_pcsclite_ipc_dir)) { LLOGLN(0, ("scard_pcsc_init: g_remove_dir failed")); } } if (!g_directory_exist(g_pcsclite_ipc_dir)) { if (!g_create_dir(g_pcsclite_ipc_dir)) { if (!g_directory_exist(g_pcsclite_ipc_dir)) { LLOGLN(0, ("scard_pcsc_init: g_create_dir failed")); } } } g_chmod_hex(g_pcsclite_ipc_dir, 0x1777); g_snprintf(g_pcsclite_ipc_file, 255, "%s/pcscd.comm", g_pcsclite_ipc_dir); g_lis->trans_conn_in = my_pcsc_trans_conn_in; error = trans_listen(g_lis, g_pcsclite_ipc_file); if (error != 0) { LLOGLN(0, ("scard_pcsc_init: trans_listen failed for port %s", g_pcsclite_ipc_file)); return 1; } } return 0; } /*****************************************************************************/ int scard_pcsc_deinit(void) { LLOGLN(0, ("scard_pcsc_deinit:")); if (g_lis != 0) { trans_delete(g_lis); g_lis = 0; } if (g_pcsclite_ipc_dir[0] != 0) { g_file_delete(g_pcsclite_ipc_file); if (!g_remove_dir(g_pcsclite_ipc_dir)) { LLOGLN(0, ("scard_pcsc_deinit: g_remove_dir failed")); } g_pcsclite_ipc_dir[0] = 0; } return 0; } #else int scard_pcsc_get_wait_objs(tbus *objs, int *count, int *timeout) { return 0; } int scard_pcsc_check_wait_objs(void) { return 0; } int scard_pcsc_init(void) { return 0; } int scard_pcsc_deinit(void) { return 0; } #endif xrdp-0.9.5/sesman/chansrv/clipboard_common.h000644 001751 001751 00000010656 13174271344 021052 0ustar00metameta000000 000000 /** * xrdp: A Remote Desktop Protocol server. * * Copyright (C) Jay Sorg 2012-2013 * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ #if !defined(CLIPBOARD_COMMON_H) #define CLIPBOARD_COMMON_H #include "arch.h" #include "parse.h" #define CB_CAPSTYPE_GENERAL 1 #define CB_MONITOR_READY 1 #define CB_FORMAT_LIST 2 #define CB_FORMAT_LIST_RESPONSE 3 #define CB_FORMAT_DATA_REQUEST 4 #define CB_FORMAT_DATA_RESPONSE 5 #define CB_TEMP_DIRECTORY 6 #define CB_CLIP_CAPS 7 #define CB_FILECONTENTS_REQUEST 8 #define CB_FILECONTENTS_RESPONSE 9 #define CB_LOCK_CLIPDATA 10 #define CB_UNLOCK_CLIPDATA 11 #define CB_USE_LONG_FORMAT_NAMES 0x00000002 #define CB_STREAM_FILECLIP_ENABLED 0x00000004 #define CB_FILECLIP_NO_FILE_PATHS 0x00000008 #define CB_CAN_LOCK_CLIPDATA 0x00000010 #define CB_FILECONTENTS_SIZE 0x00000001 #define CB_FILECONTENTS_RANGE 0x00000002 #define CB_FORMAT_RAW 0x0000 #define CB_FORMAT_TEXT 0x0001 #define CB_FORMAT_DIB 0x0008 #define CB_FORMAT_UNICODETEXT 0x000D #define CB_FORMAT_HTML 0xD010 #define CB_FORMAT_PNG 0xD011 #define CB_FORMAT_JPEG 0xD012 #define CB_FORMAT_GIF 0xD013 #define CB_FORMAT_FILE 0xC0BC /* Used by the Format List Response PDU, Format Data Response PDU, and File Contents Response PDU to indicate that the associated request Format List PDU, Format Data Request PDU, and File Contents Request PDU were processed successfully. */ #define CB_RESPONSE_OK 0x0001 /* Used by the Format List Response PDU, Format Data Response PDU, and File Contents Response PDU to indicate that the associated Format List PDU, Format Data Request PDU, and File Contents Request PDU were not processed successfully. */ #define CB_RESPONSE_FAIL 0x0002 /* Used by the Short Format Name variant of the Format List Response PDU to indicate the format names are in ASCII 8. */ #define CB_ASCII_NAMES 0x0004 /* these are the supported general types */ #define XRDP_CB_TEXT 1 #define XRDP_CB_BITMAP 2 #define XRDP_CB_FILE 3 #define CB_FD_ATTRIBUTES 0x00000004 #define CB_FD_FILESIZE 0x00000040 #define CB_FD_WRITESTIME 0x00000020 #define CB_FD_PROGRESSUI 0x00004000 #define CB_FILE_ATTRIBUTE_READONLY 0x00000001 #define CB_FILE_ATTRIBUTE_HIDDEN 0x00000002 #define CB_FILE_ATTRIBUTE_SYSTEM 0x00000004 #define CB_FILE_ATTRIBUTE_DIRECTORY 0x00000010 #define CB_FILE_ATTRIBUTE_ARCHIVE 0x00000020 #define CB_FILE_ATTRIBUTE_NORMAL 0x00000080 struct clip_s2c /* server to client, pasting from linux app to mstsc */ { int incr_in_progress; int total_bytes; char *data; Atom type; /* UTF8_STRING, image/bmp, ... */ Atom property; /* XRDP_CLIP_PROPERTY_ATOM, _QT_SELECTION, ... */ int xrdp_clip_type; /* XRDP_CB_TEXT, XRDP_CB_BITMAP, XRDP_CB_FILE, ... */ int converted; Time clip_time; }; struct clip_c2s /* client to server, pasting from mstsc to linux app */ { int incr_in_progress; int incr_bytes_done; int read_bytes_done; int total_bytes; char *data; Atom type; /* UTF8_STRING, image/bmp, ... */ Atom property; /* XRDP_CLIP_PROPERTY_ATOM, _QT_SELECTION, ... */ Window window; /* Window used in INCR transfer */ int xrdp_clip_type; /* XRDP_CB_TEXT, XRDP_CB_BITMAP, XRDP_CB_FILE, ... */ int converted; int in_request; /* a data request has been sent to client */ int doing_response_ss; /* doing response short circuit */ Time clip_time; }; struct clip_file_desc /* CLIPRDR_FILEDESCRIPTOR */ { tui32 flags; tui32 fileAttributes; tui32 lastWriteTimeLow; tui32 lastWriteTimeHigh; tui32 fileSizeHigh; tui32 fileSizeLow; char cFileName[256]; }; int clipboard_out_unicode(struct stream *s, const char *text, int num_chars); int clipboard_in_unicode(struct stream *s, char *text, int *num_chars); #endif xrdp-0.9.5/sesman/chansrv/Makefile.in000644 001751 001751 00000056351 13220730774 017440 0ustar00metameta000000 000000 # Makefile.in generated by automake 1.15.1 from Makefile.am. # @configure_input@ # Copyright (C) 1994-2017 Free Software Foundation, Inc. # This Makefile.in is free software; the Free Software Foundation # gives unlimited permission to copy and/or distribute it, # with or without modifications, as long as this notice is preserved. # This program is distributed in the hope that it will be useful, # but WITHOUT ANY WARRANTY, to the extent permitted by law; without # even the implied warranty of MERCHANTABILITY or FITNESS FOR A # PARTICULAR PURPOSE. @SET_MAKE@ VPATH = @srcdir@ am__is_gnu_make = { \ if test -z '$(MAKELEVEL)'; then \ false; \ elif test -n '$(MAKE_HOST)'; then \ true; \ elif test -n '$(MAKE_VERSION)' && test -n '$(CURDIR)'; then \ true; \ else \ false; \ fi; \ } am__make_running_with_option = \ case $${target_option-} in \ ?) ;; \ *) echo "am__make_running_with_option: internal error: invalid" \ "target option '$${target_option-}' specified" >&2; \ exit 1;; \ esac; \ has_opt=no; \ sane_makeflags=$$MAKEFLAGS; \ if $(am__is_gnu_make); then \ sane_makeflags=$$MFLAGS; \ else \ case $$MAKEFLAGS in \ *\\[\ \ ]*) \ bs=\\; \ sane_makeflags=`printf '%s\n' "$$MAKEFLAGS" \ | sed "s/$$bs$$bs[$$bs $$bs ]*//g"`;; \ esac; \ fi; \ skip_next=no; \ strip_trailopt () \ { \ flg=`printf '%s\n' "$$flg" | sed "s/$$1.*$$//"`; \ }; \ for flg in $$sane_makeflags; do \ test $$skip_next = yes && { skip_next=no; continue; }; \ case $$flg in \ *=*|--*) continue;; \ -*I) strip_trailopt 'I'; skip_next=yes;; \ -*I?*) strip_trailopt 'I';; \ -*O) strip_trailopt 'O'; skip_next=yes;; \ -*O?*) strip_trailopt 'O';; \ -*l) strip_trailopt 'l'; skip_next=yes;; \ -*l?*) strip_trailopt 'l';; \ -[dEDm]) skip_next=yes;; \ -[JT]) skip_next=yes;; \ esac; \ case $$flg in \ *$$target_option*) has_opt=yes; break;; \ esac; \ done; \ test $$has_opt = yes am__make_dryrun = (target_option=n; $(am__make_running_with_option)) am__make_keepgoing = (target_option=k; $(am__make_running_with_option)) pkgdatadir = $(datadir)/@PACKAGE@ pkgincludedir = $(includedir)/@PACKAGE@ pkglibdir = $(libdir)/@PACKAGE@ pkglibexecdir = $(libexecdir)/@PACKAGE@ am__cd = CDPATH="$${ZSH_VERSION+.}$(PATH_SEPARATOR)" && cd install_sh_DATA = $(install_sh) -c -m 644 install_sh_PROGRAM = $(install_sh) -c install_sh_SCRIPT = $(install_sh) -c INSTALL_HEADER = $(INSTALL_DATA) transform = $(program_transform_name) NORMAL_INSTALL = : PRE_INSTALL = : POST_INSTALL = : NORMAL_UNINSTALL = : PRE_UNINSTALL = : POST_UNINSTALL = : build_triplet = @build@ host_triplet = @host@ @XRDP_DEBUG_TRUE@am__append_1 = -DXRDP_DEBUG @XRDP_FUSE_TRUE@am__append_2 = -DXRDP_FUSE $(FUSE_CFLAGS) @XRDP_FUSE_TRUE@am__append_3 = $(FUSE_LIBS) @XRDP_FDK_AAC_TRUE@am__append_4 = -DXRDP_FDK_AAC $(FDKAAC_CFLAGS) @XRDP_FDK_AAC_TRUE@am__append_5 = $(FDKAAC_LIBS) @XRDP_OPUS_TRUE@am__append_6 = -DXRDP_OPUS @XRDP_OPUS_TRUE@am__append_7 = -lopus @XRDP_MP3LAME_TRUE@am__append_8 = -DXRDP_MP3LAME @XRDP_MP3LAME_TRUE@am__append_9 = -lmp3lame sbin_PROGRAMS = xrdp-chansrv$(EXEEXT) subdir = sesman/chansrv ACLOCAL_M4 = $(top_srcdir)/aclocal.m4 am__aclocal_m4_deps = $(top_srcdir)/m4/ax_append_compile_flags.m4 \ $(top_srcdir)/m4/ax_append_flag.m4 \ $(top_srcdir)/m4/ax_cflags_warn_all.m4 \ $(top_srcdir)/m4/ax_check_compile_flag.m4 \ $(top_srcdir)/m4/ax_gcc_func_attribute.m4 \ $(top_srcdir)/m4/ax_require_defined.m4 \ $(top_srcdir)/m4/ax_type_socklen_t.m4 \ $(top_srcdir)/m4/libtool.m4 $(top_srcdir)/m4/ltoptions.m4 \ $(top_srcdir)/m4/ltsugar.m4 $(top_srcdir)/m4/ltversion.m4 \ $(top_srcdir)/m4/lt~obsolete.m4 $(top_srcdir)/m4/pkg.m4 \ $(top_srcdir)/configure.ac am__configure_deps = $(am__aclocal_m4_deps) $(CONFIGURE_DEPENDENCIES) \ $(ACLOCAL_M4) DIST_COMMON = $(srcdir)/Makefile.am $(am__DIST_COMMON) mkinstalldirs = $(install_sh) -d CONFIG_HEADER = $(top_builddir)/config_ac.h CONFIG_CLEAN_FILES = CONFIG_CLEAN_VPATH_FILES = am__installdirs = "$(DESTDIR)$(sbindir)" PROGRAMS = $(sbin_PROGRAMS) am_xrdp_chansrv_OBJECTS = chansrv.$(OBJEXT) chansrv_common.$(OBJEXT) \ chansrv_fuse.$(OBJEXT) clipboard.$(OBJEXT) \ clipboard_file.$(OBJEXT) devredir.$(OBJEXT) drdynvc.$(OBJEXT) \ fifo.$(OBJEXT) irp.$(OBJEXT) rail.$(OBJEXT) \ smartcard.$(OBJEXT) smartcard_pcsc.$(OBJEXT) sound.$(OBJEXT) \ xcommon.$(OBJEXT) xrdp_chansrv_OBJECTS = $(am_xrdp_chansrv_OBJECTS) am__DEPENDENCIES_1 = @XRDP_FUSE_TRUE@am__DEPENDENCIES_2 = $(am__DEPENDENCIES_1) @XRDP_FDK_AAC_TRUE@am__DEPENDENCIES_3 = $(am__DEPENDENCIES_1) am__DEPENDENCIES_4 = $(am__DEPENDENCIES_2) $(am__DEPENDENCIES_3) \ $(am__DEPENDENCIES_1) $(am__DEPENDENCIES_1) xrdp_chansrv_DEPENDENCIES = $(top_builddir)/common/libcommon.la \ $(am__DEPENDENCIES_1) $(am__DEPENDENCIES_1) \ $(am__DEPENDENCIES_4) AM_V_lt = $(am__v_lt_@AM_V@) am__v_lt_ = $(am__v_lt_@AM_DEFAULT_V@) am__v_lt_0 = --silent am__v_lt_1 = xrdp_chansrv_LINK = $(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) \ $(LIBTOOLFLAGS) --mode=link $(CCLD) $(AM_CFLAGS) $(CFLAGS) \ $(xrdp_chansrv_LDFLAGS) $(LDFLAGS) -o $@ AM_V_P = $(am__v_P_@AM_V@) am__v_P_ = $(am__v_P_@AM_DEFAULT_V@) am__v_P_0 = false am__v_P_1 = : AM_V_GEN = $(am__v_GEN_@AM_V@) am__v_GEN_ = $(am__v_GEN_@AM_DEFAULT_V@) am__v_GEN_0 = @echo " GEN " $@; am__v_GEN_1 = AM_V_at = $(am__v_at_@AM_V@) am__v_at_ = $(am__v_at_@AM_DEFAULT_V@) am__v_at_0 = @ am__v_at_1 = DEFAULT_INCLUDES = -I.@am__isrc@ -I$(top_builddir) depcomp = $(SHELL) $(top_srcdir)/depcomp am__depfiles_maybe = depfiles am__mv = mv -f COMPILE = $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) \ $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) LTCOMPILE = $(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) \ $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) \ $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) \ $(AM_CFLAGS) $(CFLAGS) AM_V_CC = $(am__v_CC_@AM_V@) am__v_CC_ = $(am__v_CC_@AM_DEFAULT_V@) am__v_CC_0 = @echo " CC " $@; am__v_CC_1 = CCLD = $(CC) LINK = $(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) \ $(LIBTOOLFLAGS) --mode=link $(CCLD) $(AM_CFLAGS) $(CFLAGS) \ $(AM_LDFLAGS) $(LDFLAGS) -o $@ AM_V_CCLD = $(am__v_CCLD_@AM_V@) am__v_CCLD_ = $(am__v_CCLD_@AM_DEFAULT_V@) am__v_CCLD_0 = @echo " CCLD " $@; am__v_CCLD_1 = SOURCES = $(xrdp_chansrv_SOURCES) DIST_SOURCES = $(xrdp_chansrv_SOURCES) am__can_run_installinfo = \ case $$AM_UPDATE_INFO_DIR in \ n|no|NO) false;; \ *) (install-info --version) >/dev/null 2>&1;; \ esac am__tagged_files = $(HEADERS) $(SOURCES) $(TAGS_FILES) $(LISP) # Read a list of newline-separated strings from the standard input, # and print each of them once, without duplicates. Input order is # *not* preserved. am__uniquify_input = $(AWK) '\ BEGIN { nonempty = 0; } \ { items[$$0] = 1; nonempty = 1; } \ END { if (nonempty) { for (i in items) print i; }; } \ ' # Make sure the list of sources is unique. This is necessary because, # e.g., the same source file might be shared among _SOURCES variables # for different programs/libraries. am__define_uniq_tagged_files = \ list='$(am__tagged_files)'; \ unique=`for i in $$list; do \ if test -f "$$i"; then echo $$i; else echo $(srcdir)/$$i; fi; \ done | $(am__uniquify_input)` ETAGS = etags CTAGS = ctags am__DIST_COMMON = $(srcdir)/Makefile.in $(top_srcdir)/depcomp DISTFILES = $(DIST_COMMON) $(DIST_SOURCES) $(TEXINFOS) $(EXTRA_DIST) ACLOCAL = @ACLOCAL@ AMTAR = @AMTAR@ AM_DEFAULT_VERBOSITY = @AM_DEFAULT_VERBOSITY@ AR = @AR@ AUTOCONF = @AUTOCONF@ AUTOHEADER = @AUTOHEADER@ AUTOMAKE = @AUTOMAKE@ AWK = @AWK@ CC = @CC@ CCDEPMODE = @CCDEPMODE@ CFLAGS = @CFLAGS@ CPP = @CPP@ CPPFLAGS = @CPPFLAGS@ CYGPATH_W = @CYGPATH_W@ DEFS = @DEFS@ DEPDIR = @DEPDIR@ DLLTOOL = @DLLTOOL@ DLOPEN_LIBS = @DLOPEN_LIBS@ DSYMUTIL = @DSYMUTIL@ DUMPBIN = @DUMPBIN@ ECHO_C = @ECHO_C@ ECHO_N = @ECHO_N@ ECHO_T = @ECHO_T@ EGREP = @EGREP@ EXEEXT = @EXEEXT@ FDKAAC_CFLAGS = @FDKAAC_CFLAGS@ FDKAAC_LIBS = @FDKAAC_LIBS@ FGREP = @FGREP@ FREERDP_CFLAGS = @FREERDP_CFLAGS@ FREERDP_LIBS = @FREERDP_LIBS@ FUSE_CFLAGS = @FUSE_CFLAGS@ FUSE_LIBS = @FUSE_LIBS@ GREP = @GREP@ INSTALL = @INSTALL@ INSTALL_DATA = @INSTALL_DATA@ INSTALL_PROGRAM = @INSTALL_PROGRAM@ INSTALL_SCRIPT = @INSTALL_SCRIPT@ INSTALL_STRIP_PROGRAM = @INSTALL_STRIP_PROGRAM@ LD = @LD@ LDFLAGS = @LDFLAGS@ LIBOBJS = @LIBOBJS@ LIBS = @LIBS@ LIBTOOL = @LIBTOOL@ LIPO = @LIPO@ LN_S = @LN_S@ LTLIBOBJS = @LTLIBOBJS@ LT_SYS_LIBRARY_PATH = @LT_SYS_LIBRARY_PATH@ MAKEINFO = @MAKEINFO@ MANIFEST_TOOL = @MANIFEST_TOOL@ MKDIR_P = @MKDIR_P@ NM = @NM@ NMEDIT = @NMEDIT@ OBJDUMP = @OBJDUMP@ OBJEXT = @OBJEXT@ OPENSSL = @OPENSSL@ OPENSSL_CFLAGS = @OPENSSL_CFLAGS@ OPENSSL_LIBS = @OPENSSL_LIBS@ OTOOL = @OTOOL@ OTOOL64 = @OTOOL64@ PACKAGE = @PACKAGE@ PACKAGE_BUGREPORT = @PACKAGE_BUGREPORT@ PACKAGE_NAME = @PACKAGE_NAME@ PACKAGE_STRING = @PACKAGE_STRING@ PACKAGE_TARNAME = @PACKAGE_TARNAME@ PACKAGE_URL = @PACKAGE_URL@ PACKAGE_VERSION = @PACKAGE_VERSION@ PAM_RULES = @PAM_RULES@ PATH_SEPARATOR = @PATH_SEPARATOR@ PIXMAN_CFLAGS = @PIXMAN_CFLAGS@ PIXMAN_LIBS = @PIXMAN_LIBS@ PKG_CONFIG = @PKG_CONFIG@ PKG_CONFIG_LIBDIR = @PKG_CONFIG_LIBDIR@ PKG_CONFIG_PATH = @PKG_CONFIG_PATH@ RANLIB = @RANLIB@ SED = @SED@ SET_MAKE = @SET_MAKE@ SHELL = @SHELL@ STRIP = @STRIP@ TurboJpegIncDir = @TurboJpegIncDir@ TurboJpegLibDir = @TurboJpegLibDir@ VERSION = @VERSION@ XMKMF = @XMKMF@ X_CFLAGS = @X_CFLAGS@ X_EXTRA_LIBS = @X_EXTRA_LIBS@ X_LIBS = @X_LIBS@ X_PRE_LIBS = @X_PRE_LIBS@ abs_builddir = @abs_builddir@ abs_srcdir = @abs_srcdir@ abs_top_builddir = @abs_top_builddir@ abs_top_srcdir = @abs_top_srcdir@ ac_ct_AR = @ac_ct_AR@ ac_ct_CC = @ac_ct_CC@ ac_ct_DUMPBIN = @ac_ct_DUMPBIN@ am__include = @am__include@ am__leading_dot = @am__leading_dot@ am__quote = @am__quote@ am__tar = @am__tar@ am__untar = @am__untar@ bindir = @bindir@ build = @build@ build_alias = @build_alias@ build_cpu = @build_cpu@ build_os = @build_os@ build_vendor = @build_vendor@ builddir = @builddir@ datadir = @datadir@ datarootdir = @datarootdir@ docdir = @docdir@ dvidir = @dvidir@ exec_prefix = @exec_prefix@ host = @host@ host_alias = @host_alias@ host_cpu = @host_cpu@ host_os = @host_os@ host_vendor = @host_vendor@ htmldir = @htmldir@ includedir = @includedir@ infodir = @infodir@ install_sh = @install_sh@ libdir = @libdir@ libexecdir = @libexecdir@ localedir = @localedir@ localstatedir = @localstatedir@ mandir = @mandir@ mkdir_p = @mkdir_p@ moduledir = @moduledir@ oldincludedir = @oldincludedir@ pdfdir = @pdfdir@ pkgconfigdir = @pkgconfigdir@ prefix = @prefix@ program_transform_name = @program_transform_name@ psdir = @psdir@ sbindir = @sbindir@ sharedstatedir = @sharedstatedir@ socketdir = @socketdir@ srcdir = @srcdir@ subdirs = @subdirs@ sysconfdir = @sysconfdir@ systemdsystemunitdir = @systemdsystemunitdir@ target_alias = @target_alias@ top_build_prefix = @top_build_prefix@ top_builddir = @top_builddir@ top_srcdir = @top_srcdir@ EXTRA_DIST = \ clipboard-notes.txt \ pcsc \ pulse \ wave-format-server.txt AM_CPPFLAGS = -DXRDP_CFG_PATH=\"${sysconfdir}/xrdp\" \ -DXRDP_SBIN_PATH=\"${sbindir}\" \ -DXRDP_SHARE_PATH=\"${datadir}/xrdp\" \ -DXRDP_PID_PATH=\"${localstatedir}/run\" \ -DXRDP_SOCKET_PATH=\"${socketdir}\" -I$(top_srcdir)/common \ $(am__append_1) $(am__append_2) $(am__append_4) \ $(am__append_6) $(am__append_8) CHANSRV_EXTRA_LIBS = $(am__append_3) $(am__append_5) $(am__append_7) \ $(am__append_9) AM_CFLAGS = $(X_CFLAGS) xrdp_chansrv_SOURCES = \ chansrv.c \ chansrv.h \ chansrv_common.c \ chansrv_common.h \ chansrv_fuse.c \ chansrv_fuse.h \ clipboard.c \ clipboard.h \ clipboard_common.h \ clipboard_file.c \ clipboard_file.h \ devredir.c \ devredir.h \ drdynvc.c \ drdynvc.h \ fifo.c \ fifo.h \ irp.c \ irp.h \ mlog.h \ rail.c \ rail.h \ smartcard.c \ smartcard.h \ smartcard_pcsc.c \ smartcard_pcsc.h \ sound.c \ sound.h \ xcommon.c \ xcommon.h xrdp_chansrv_LDFLAGS = \ $(X_LIBS) xrdp_chansrv_LDADD = \ $(top_builddir)/common/libcommon.la \ $(X_PRE_LIBS) -lXfixes -lXrandr -lX11 $(X_EXTRA_LIBS) \ $(CHANSRV_EXTRA_LIBS) all: all-am .SUFFIXES: .SUFFIXES: .c .lo .o .obj $(srcdir)/Makefile.in: $(srcdir)/Makefile.am $(am__configure_deps) @for dep in $?; do \ case '$(am__configure_deps)' in \ *$$dep*) \ ( cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh ) \ && { if test -f $@; then exit 0; else break; fi; }; \ exit 1;; \ esac; \ done; \ echo ' cd $(top_srcdir) && $(AUTOMAKE) --foreign sesman/chansrv/Makefile'; \ $(am__cd) $(top_srcdir) && \ $(AUTOMAKE) --foreign sesman/chansrv/Makefile Makefile: $(srcdir)/Makefile.in $(top_builddir)/config.status @case '$?' in \ *config.status*) \ cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh;; \ *) \ echo ' cd $(top_builddir) && $(SHELL) ./config.status $(subdir)/$@ $(am__depfiles_maybe)'; \ cd $(top_builddir) && $(SHELL) ./config.status $(subdir)/$@ $(am__depfiles_maybe);; \ esac; $(top_builddir)/config.status: $(top_srcdir)/configure $(CONFIG_STATUS_DEPENDENCIES) cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh $(top_srcdir)/configure: $(am__configure_deps) cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh $(ACLOCAL_M4): $(am__aclocal_m4_deps) cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh $(am__aclocal_m4_deps): install-sbinPROGRAMS: $(sbin_PROGRAMS) @$(NORMAL_INSTALL) @list='$(sbin_PROGRAMS)'; test -n "$(sbindir)" || list=; \ if test -n "$$list"; then \ echo " $(MKDIR_P) '$(DESTDIR)$(sbindir)'"; \ $(MKDIR_P) "$(DESTDIR)$(sbindir)" || exit 1; \ fi; \ for p in $$list; do echo "$$p $$p"; done | \ sed 's/$(EXEEXT)$$//' | \ while read p p1; do if test -f $$p \ || test -f $$p1 \ ; then echo "$$p"; echo "$$p"; else :; fi; \ done | \ sed -e 'p;s,.*/,,;n;h' \ -e 's|.*|.|' \ -e 'p;x;s,.*/,,;s/$(EXEEXT)$$//;$(transform);s/$$/$(EXEEXT)/' | \ sed 'N;N;N;s,\n, ,g' | \ $(AWK) 'BEGIN { files["."] = ""; dirs["."] = 1 } \ { d=$$3; if (dirs[d] != 1) { print "d", d; dirs[d] = 1 } \ if ($$2 == $$4) files[d] = files[d] " " $$1; \ else { print "f", $$3 "/" $$4, $$1; } } \ END { for (d in files) print "f", d, files[d] }' | \ while read type dir files; do \ if test "$$dir" = .; then dir=; else dir=/$$dir; fi; \ test -z "$$files" || { \ echo " $(INSTALL_PROGRAM_ENV) $(LIBTOOL) $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=install $(INSTALL_PROGRAM) $$files '$(DESTDIR)$(sbindir)$$dir'"; \ $(INSTALL_PROGRAM_ENV) $(LIBTOOL) $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=install $(INSTALL_PROGRAM) $$files "$(DESTDIR)$(sbindir)$$dir" || exit $$?; \ } \ ; done uninstall-sbinPROGRAMS: @$(NORMAL_UNINSTALL) @list='$(sbin_PROGRAMS)'; test -n "$(sbindir)" || list=; \ files=`for p in $$list; do echo "$$p"; done | \ sed -e 'h;s,^.*/,,;s/$(EXEEXT)$$//;$(transform)' \ -e 's/$$/$(EXEEXT)/' \ `; \ test -n "$$list" || exit 0; \ echo " ( cd '$(DESTDIR)$(sbindir)' && rm -f" $$files ")"; \ cd "$(DESTDIR)$(sbindir)" && rm -f $$files clean-sbinPROGRAMS: @list='$(sbin_PROGRAMS)'; test -n "$$list" || exit 0; \ echo " rm -f" $$list; \ rm -f $$list || exit $$?; \ test -n "$(EXEEXT)" || exit 0; \ list=`for p in $$list; do echo "$$p"; done | sed 's/$(EXEEXT)$$//'`; \ echo " rm -f" $$list; \ rm -f $$list xrdp-chansrv$(EXEEXT): $(xrdp_chansrv_OBJECTS) $(xrdp_chansrv_DEPENDENCIES) $(EXTRA_xrdp_chansrv_DEPENDENCIES) @rm -f xrdp-chansrv$(EXEEXT) $(AM_V_CCLD)$(xrdp_chansrv_LINK) $(xrdp_chansrv_OBJECTS) $(xrdp_chansrv_LDADD) $(LIBS) mostlyclean-compile: -rm -f *.$(OBJEXT) distclean-compile: -rm -f *.tab.c @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/chansrv.Po@am__quote@ @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/chansrv_common.Po@am__quote@ @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/chansrv_fuse.Po@am__quote@ @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/clipboard.Po@am__quote@ @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/clipboard_file.Po@am__quote@ @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/devredir.Po@am__quote@ @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/drdynvc.Po@am__quote@ @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/fifo.Po@am__quote@ @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/irp.Po@am__quote@ @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/rail.Po@am__quote@ @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/smartcard.Po@am__quote@ @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/smartcard_pcsc.Po@am__quote@ @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/sound.Po@am__quote@ @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/xcommon.Po@am__quote@ .c.o: @am__fastdepCC_TRUE@ $(AM_V_CC)$(COMPILE) -MT $@ -MD -MP -MF $(DEPDIR)/$*.Tpo -c -o $@ $< @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) $(DEPDIR)/$*.Tpo $(DEPDIR)/$*.Po @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='$<' object='$@' libtool=no @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(COMPILE) -c -o $@ $< .c.obj: @am__fastdepCC_TRUE@ $(AM_V_CC)$(COMPILE) -MT $@ -MD -MP -MF $(DEPDIR)/$*.Tpo -c -o $@ `$(CYGPATH_W) '$<'` @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) $(DEPDIR)/$*.Tpo $(DEPDIR)/$*.Po @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='$<' object='$@' libtool=no @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(COMPILE) -c -o $@ `$(CYGPATH_W) '$<'` .c.lo: @am__fastdepCC_TRUE@ $(AM_V_CC)$(LTCOMPILE) -MT $@ -MD -MP -MF $(DEPDIR)/$*.Tpo -c -o $@ $< @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) $(DEPDIR)/$*.Tpo $(DEPDIR)/$*.Plo @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='$<' object='$@' libtool=yes @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(LTCOMPILE) -c -o $@ $< mostlyclean-libtool: -rm -f *.lo clean-libtool: -rm -rf .libs _libs ID: $(am__tagged_files) $(am__define_uniq_tagged_files); mkid -fID $$unique tags: tags-am TAGS: tags tags-am: $(TAGS_DEPENDENCIES) $(am__tagged_files) set x; \ here=`pwd`; \ $(am__define_uniq_tagged_files); \ shift; \ if test -z "$(ETAGS_ARGS)$$*$$unique"; then :; else \ test -n "$$unique" || unique=$$empty_fix; \ if test $$# -gt 0; then \ $(ETAGS) $(ETAGSFLAGS) $(AM_ETAGSFLAGS) $(ETAGS_ARGS) \ "$$@" $$unique; \ else \ $(ETAGS) $(ETAGSFLAGS) $(AM_ETAGSFLAGS) $(ETAGS_ARGS) \ $$unique; \ fi; \ fi ctags: ctags-am CTAGS: ctags ctags-am: $(TAGS_DEPENDENCIES) $(am__tagged_files) $(am__define_uniq_tagged_files); \ test -z "$(CTAGS_ARGS)$$unique" \ || $(CTAGS) $(CTAGSFLAGS) $(AM_CTAGSFLAGS) $(CTAGS_ARGS) \ $$unique GTAGS: here=`$(am__cd) $(top_builddir) && pwd` \ && $(am__cd) $(top_srcdir) \ && gtags -i $(GTAGS_ARGS) "$$here" cscopelist: cscopelist-am cscopelist-am: $(am__tagged_files) list='$(am__tagged_files)'; \ case "$(srcdir)" in \ [\\/]* | ?:[\\/]*) sdir="$(srcdir)" ;; \ *) sdir=$(subdir)/$(srcdir) ;; \ esac; \ for i in $$list; do \ if test -f "$$i"; then \ echo "$(subdir)/$$i"; \ else \ echo "$$sdir/$$i"; \ fi; \ done >> $(top_builddir)/cscope.files distclean-tags: -rm -f TAGS ID GTAGS GRTAGS GSYMS GPATH tags distdir: $(DISTFILES) @srcdirstrip=`echo "$(srcdir)" | sed 's/[].[^$$\\*]/\\\\&/g'`; \ topsrcdirstrip=`echo "$(top_srcdir)" | sed 's/[].[^$$\\*]/\\\\&/g'`; \ list='$(DISTFILES)'; \ dist_files=`for file in $$list; do echo $$file; done | \ sed -e "s|^$$srcdirstrip/||;t" \ -e "s|^$$topsrcdirstrip/|$(top_builddir)/|;t"`; \ case $$dist_files in \ */*) $(MKDIR_P) `echo "$$dist_files" | \ sed '/\//!d;s|^|$(distdir)/|;s,/[^/]*$$,,' | \ sort -u` ;; \ esac; \ for file in $$dist_files; do \ if test -f $$file || test -d $$file; then d=.; else d=$(srcdir); fi; \ if test -d $$d/$$file; then \ dir=`echo "/$$file" | sed -e 's,/[^/]*$$,,'`; \ if test -d "$(distdir)/$$file"; then \ find "$(distdir)/$$file" -type d ! -perm -700 -exec chmod u+rwx {} \;; \ fi; \ if test -d $(srcdir)/$$file && test $$d != $(srcdir); then \ cp -fpR $(srcdir)/$$file "$(distdir)$$dir" || exit 1; \ find "$(distdir)/$$file" -type d ! -perm -700 -exec chmod u+rwx {} \;; \ fi; \ cp -fpR $$d/$$file "$(distdir)$$dir" || exit 1; \ else \ test -f "$(distdir)/$$file" \ || cp -p $$d/$$file "$(distdir)/$$file" \ || exit 1; \ fi; \ done check-am: all-am check: check-am all-am: Makefile $(PROGRAMS) installdirs: for dir in "$(DESTDIR)$(sbindir)"; do \ test -z "$$dir" || $(MKDIR_P) "$$dir"; \ done install: install-am install-exec: install-exec-am install-data: install-data-am uninstall: uninstall-am install-am: all-am @$(MAKE) $(AM_MAKEFLAGS) install-exec-am install-data-am installcheck: installcheck-am install-strip: if test -z '$(STRIP)'; then \ $(MAKE) $(AM_MAKEFLAGS) INSTALL_PROGRAM="$(INSTALL_STRIP_PROGRAM)" \ install_sh_PROGRAM="$(INSTALL_STRIP_PROGRAM)" INSTALL_STRIP_FLAG=-s \ install; \ else \ $(MAKE) $(AM_MAKEFLAGS) INSTALL_PROGRAM="$(INSTALL_STRIP_PROGRAM)" \ install_sh_PROGRAM="$(INSTALL_STRIP_PROGRAM)" INSTALL_STRIP_FLAG=-s \ "INSTALL_PROGRAM_ENV=STRIPPROG='$(STRIP)'" install; \ fi mostlyclean-generic: clean-generic: distclean-generic: -test -z "$(CONFIG_CLEAN_FILES)" || rm -f $(CONFIG_CLEAN_FILES) -test . = "$(srcdir)" || test -z "$(CONFIG_CLEAN_VPATH_FILES)" || rm -f $(CONFIG_CLEAN_VPATH_FILES) maintainer-clean-generic: @echo "This command is intended for maintainers to use" @echo "it deletes files that may require special tools to rebuild." clean: clean-am clean-am: clean-generic clean-libtool clean-sbinPROGRAMS \ mostlyclean-am distclean: distclean-am -rm -rf ./$(DEPDIR) -rm -f Makefile distclean-am: clean-am distclean-compile distclean-generic \ distclean-tags dvi: dvi-am dvi-am: html: html-am html-am: info: info-am info-am: install-data-am: install-dvi: install-dvi-am install-dvi-am: install-exec-am: install-sbinPROGRAMS install-html: install-html-am install-html-am: install-info: install-info-am install-info-am: install-man: install-pdf: install-pdf-am install-pdf-am: install-ps: install-ps-am install-ps-am: installcheck-am: maintainer-clean: maintainer-clean-am -rm -rf ./$(DEPDIR) -rm -f Makefile maintainer-clean-am: distclean-am maintainer-clean-generic mostlyclean: mostlyclean-am mostlyclean-am: mostlyclean-compile mostlyclean-generic \ mostlyclean-libtool pdf: pdf-am pdf-am: ps: ps-am ps-am: uninstall-am: uninstall-sbinPROGRAMS .MAKE: install-am install-strip .PHONY: CTAGS GTAGS TAGS all all-am check check-am clean clean-generic \ clean-libtool clean-sbinPROGRAMS cscopelist-am ctags ctags-am \ distclean distclean-compile distclean-generic \ distclean-libtool distclean-tags distdir dvi dvi-am html \ html-am info info-am install install-am install-data \ install-data-am install-dvi install-dvi-am install-exec \ install-exec-am install-html install-html-am install-info \ install-info-am install-man install-pdf install-pdf-am \ install-ps install-ps-am install-sbinPROGRAMS install-strip \ installcheck installcheck-am installdirs maintainer-clean \ maintainer-clean-generic mostlyclean mostlyclean-compile \ mostlyclean-generic mostlyclean-libtool pdf pdf-am ps ps-am \ tags tags-am uninstall uninstall-am uninstall-sbinPROGRAMS .PRECIOUS: Makefile # Tell versions [3.59,3.63) of GNU make to not export all variables. # Otherwise a system limit (for SysV at least) may be exceeded. .NOEXPORT: xrdp-0.9.5/sesman/chansrv/pulse/000755 001751 001751 00000000000 13220727201 016500 5ustar00metameta000000 000000 xrdp-0.9.5/sesman/chansrv/clipboard.h000644 001751 001751 00000001723 13174271344 017475 0ustar00metameta000000 000000 /** * xrdp: A Remote Desktop Protocol server. * * Copyright (C) Jay Sorg 2009-2013 * Copyright (C) Laxmikant Rashinkar 2012-2013 * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ #if !defined(CLIPBOARD_H) #define CLIPBOARD_H #include "arch.h" #include "parse.h" int clipboard_init(void); int clipboard_deinit(void); int clipboard_data_in(struct stream *s, int chan_id, int chan_flags, int length, int total_length); int clipboard_xevent(void *xevent); #endif xrdp-0.9.5/sesman/chansrv/mlog.h000644 001751 001751 00000011005 13133346204 016457 0ustar00metameta000000 000000 /** * xrdp: A Remote Desktop Protocol server. * * Copyright (C) Laxmikant Rashinkar 2013 LK.Rashinkar@gmail.com * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ /* module based logging */ #ifndef _MLOG_H #define _MLOG_H /* * Note1: to enable debug messages, in your .c file, #define LOCAL_DEBUG * BEFORE including this file * * Note2: in your .c file, #define MODULE_NAME, 8 chars long, to print each * log entry with your module name */ #define LOG_ERROR 0 #define LOG_INFO 1 #define LOG_DEBUG_LOW 2 #define LOG_DEBUG_HIGH 3 #define LOG_LEVEL LOG_ERROR /* * print always */ #define log_error(_params...) \ do \ { \ g_write("[%10.10u]: %s %s: %d: ERROR: ", g_time3(), \ MODULE_NAME, __func__, __LINE__); \ g_writeln (_params); \ } \ while(0) #define log_always(_params...) \ do \ { \ g_write("[%10.10u]: %s %s: %d: ALWAYS: ", g_time3(), \ MODULE_NAME, __func__, __LINE__); \ g_writeln (_params); \ } \ while(0) /* * print conditionally */ #ifdef LOCAL_DEBUG #define log_info(_params...) \ do \ { \ if (LOG_INFO <= LOG_LEVEL) \ { \ g_write("[%10.10u]: %s %s: %d: INFO: ", g_time3(), \ MODULE_NAME, __func__, __LINE__); \ g_writeln (_params); \ } \ } \ while(0) #else #define log_info(_params...) #endif #ifdef LOCAL_DEBUG #define log_debug_low(_params...) \ do \ { \ if (LOG_DEBUG_LOW <= LOG_LEVEL) \ { \ g_write("[%10.10u]: %s %s: %d: DEBUG: ", g_time3(), \ MODULE_NAME, __func__, __LINE__); \ g_writeln (_params); \ } \ } \ while(0) #else #define log_debug_low(_params...) #endif #ifdef LOCAL_DEBUG #define log_debug_high(_params...) \ do \ { \ if (LOG_DEBUG_HIGH <= LOG_LEVEL) \ { \ g_write("[%10.10u]: %s %s: %d: DEBUG: ", g_time3(), \ MODULE_NAME, __func__, __LINE__); \ g_writeln (_params); \ } \ } \ while(0) #else #define log_debug_high(_params...) #endif #endif /* #ifndef _MLOG_H */ xrdp-0.9.5/sesman/chansrv/fifo.c000644 001751 001751 00000012707 13174271344 016460 0ustar00metameta000000 000000 /** * xrdp: A Remote Desktop Protocol server. * * Copyright (C) Laxmikant Rashinkar 2013 LK.Rashinkar@gmail.com * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ /* FIFO implementation to store a pointer to a user struct */ /* module based logging */ #if defined(HAVE_CONFIG_H) #include #endif #define MODULE_NAME "FIFO " #define LOCAL_DEBUG #include "fifo.h" #include "mlog.h" #include "os_calls.h" /** * Initialize a FIFO that grows as required * * @param fp pointer to a FIFO * @param num_entries initial size * * @return 0 on success, -1 on failure *****************************************************************************/ int fifo_init(FIFO* fp, int num_entries) { log_debug_high("entered"); /* validate params */ if (!fp) { log_debug_high("invalid parameters"); return -1; } if (num_entries < 1) num_entries = 10; fp->rd_ptr = 0; fp->wr_ptr = 0; fp->user_data = (long *) g_malloc(sizeof(long) * num_entries, 1); if (fp->user_data) { fp->entries = num_entries; log_debug_low("FIFO created; rd_ptr=%d wr_ptr=%d entries=%d", fp->rd_ptr, fp->wr_ptr, fp->entries); return 0; } else { log_error("FIFO create error; system out of memory"); fp->entries = 0; return -1; } } /** * Deinit FIFO and release resources * * @param fp FIFO to deinit * * @return 0 on success, -1 on error *****************************************************************************/ int fifo_deinit(FIFO* fp) { log_debug_high("entered"); if (!fp) { log_debug_high("FIFO is null"); return -1; } if (fp->user_data) { g_free(fp->user_data); fp->user_data = 0; } fp->rd_ptr = 0; fp->wr_ptr = 0; fp->entries = 0; return 0; } /** * Check if FIFO is empty * * @param fp FIFO * * @return 1 if FIFO is empty, 0 otherwise *****************************************************************************/ int fifo_is_empty(FIFO* fp) { log_debug_high("entered"); if (!fp) { log_debug_high("FIFO is null"); return 0; } return (fp->rd_ptr == fp->wr_ptr) ? 1 : 0; } /** * Insert an item at the end * * @param fp FIFO * @param data data to insert into FIFO * * @param 0 on success, -1 on error *****************************************************************************/ int fifo_insert(FIFO* fp, void* data) { long* lp; int next_val; /* next value for wr_ptr */ int i; log_debug_high("entered"); if (!fp) { log_debug_high("FIFO is null"); return -1; } next_val = fp->wr_ptr + 1; if (next_val >= fp->entries) next_val = 0; if (next_val == fp->rd_ptr) { /* FIFO is full, expand it by 10 entries */ lp = (long *) g_malloc(sizeof(long) * (fp->entries + 10), 1); if (!lp) { log_debug_low("FIFO full; cannot expand, no memory"); return -1; } log_debug_low("FIFO full, expanding by 10 entries"); /* copy old data new location */ for (i = 0; i < (fp->entries - 1); i++) { lp[i] = fp->user_data[fp->rd_ptr++]; if (fp->rd_ptr >= fp->entries) fp->rd_ptr = 0; } /* update pointers */ fp->rd_ptr = 0; fp->wr_ptr = fp->entries - 1; next_val = fp->entries; fp->entries += 10; /* free old data */ g_free(fp->user_data); fp->user_data = lp; } log_debug_low("inserting data at index %d", fp->wr_ptr); fp->user_data[fp->wr_ptr] = (long) data; fp->wr_ptr = next_val; return 0; } /** * Remove an item from the head * * @param fp FIFO * * @param data on success, NULL on error *****************************************************************************/ void* fifo_remove(FIFO* fp) { long data; log_debug_high("entered"); if (!fp) { log_debug_high("FIFO is null"); return 0; } if (fp->rd_ptr == fp->wr_ptr) { log_debug_high("FIFO is empty"); return 0; } log_debug_low("removing data at index %d", fp->rd_ptr); data = fp->user_data[fp->rd_ptr++]; if (fp->rd_ptr >= fp->entries) { log_debug_high("FIFO rd_ptr wrapped around"); fp->rd_ptr = 0; } return (void *) data; } /** * Return item from head, but do not remove it * * @param fp FIFO * * @param data on success, NULL on error *****************************************************************************/ void* fifo_peek(FIFO* fp) { log_debug_high("entered"); if (!fp) { log_debug_high("FIFO is null"); return 0; } if (fp->rd_ptr == fp->wr_ptr) { log_debug_high("FIFO is empty"); return 0; } log_debug_low("peeking data at index %d", fp->rd_ptr); return (void *) fp->user_data[fp->rd_ptr]; } xrdp-0.9.5/sesman/chansrv/irp.c000644 001751 001751 00000014401 13174271344 016320 0ustar00metameta000000 000000 /** * xrdp: A Remote Desktop Protocol server. * * Copyright (C) Laxmikant Rashinkar 2013 LK.Rashinkar@gmail.com * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. * */ /* * manage I/O for redirected file system and devices */ #if defined(HAVE_CONFIG_H) #include #endif #include "parse.h" #include "os_calls.h" #include "irp.h" /* module based logging */ #define LOG_ERROR 0 #define LOG_INFO 1 #define LOG_DEBUG 2 #ifndef LOG_LEVEL #define LOG_LEVEL LOG_ERROR #endif #define log_error(_params...) \ { \ g_write("[%10.10u]: IRP %s: %d : ERROR: ", \ g_time3(), __func__, __LINE__); \ g_writeln (_params); \ } #define log_info(_params...) \ { \ if (LOG_INFO <= LOG_LEVEL) \ { \ g_write("[%10.10u]: IRP %s: %d : ", \ g_time3(), __func__, __LINE__); \ g_writeln (_params); \ } \ } #define log_debug(_params...) \ { \ if (LOG_DEBUG <= LOG_LEVEL) \ { \ g_write("[%10.10u]: IRP %s: %d : ", \ g_time3(), __func__, __LINE__); \ g_writeln (_params); \ } \ } IRP *g_irp_head = NULL; /** * Create a new IRP and append to linked list * * @return new IRP or NULL on error *****************************************************************************/ IRP * devredir_irp_new(void) { IRP *irp; IRP *irp_last; log_debug("entered"); /* create new IRP */ irp = g_new0(IRP, 1); if (irp == NULL) { log_error("system out of memory!"); return NULL; } /* insert at end of linked list */ if ((irp_last = devredir_irp_get_last()) == NULL) { /* list is empty, this is the first entry */ g_irp_head = irp; } else { irp_last->next = irp; irp->prev = irp_last; } log_debug("new IRP=%p", irp); return irp; } /** * Clone specified IRP * * @return new IRP or NULL on error *****************************************************************************/ IRP * devredir_irp_clone(IRP *irp) { IRP *new_irp; IRP *prev; IRP *next; if ((new_irp = devredir_irp_new()) == NULL) return NULL; /* save link pointers */ prev = new_irp->prev; next = new_irp->next; /* copy all members */ g_memcpy(new_irp, irp, sizeof(IRP)); /* restore link pointers */ new_irp->prev = prev; new_irp->next = next; return new_irp; } /** * Delete specified IRP from linked list * * @return 0 on success, -1 on failure *****************************************************************************/ int devredir_irp_delete(IRP *irp) { IRP *lirp = g_irp_head; if ((irp == NULL) || (lirp == NULL)) return -1; log_debug("irp=%p completion_id=%d type=%d", irp, irp->CompletionId, irp->completion_type); devredir_irp_dump(); // LK_TODO while (lirp) { if (lirp == irp) break; lirp = lirp->next; } if (lirp == NULL) return -1; /* did not find specified irp */ if (lirp->prev == NULL) { /* we are at head of linked list */ if (lirp->next == NULL) { /* only one element in list */ g_free(lirp); g_irp_head = NULL; devredir_irp_dump(); // LK_TODO return 0; } lirp->next->prev = NULL; g_irp_head = lirp->next; g_free(lirp); } else if (lirp->next == NULL) { /* we are at tail of linked list */ lirp->prev->next = NULL; g_free(lirp); } else { /* we are in between */ lirp->prev->next = lirp->next; lirp->next->prev = lirp->prev; g_free(lirp); } devredir_irp_dump(); // LK_TODO return 0; } /** * Return IRP containing specified completion_id *****************************************************************************/ IRP *devredir_irp_find(tui32 completion_id) { IRP *irp = g_irp_head; while (irp) { if (irp->CompletionId == completion_id) { log_debug("returning irp=%p", irp); return irp; } irp = irp->next; } log_debug("returning irp=NULL"); return NULL; } IRP * devredir_irp_find_by_fileid(tui32 FileId) { IRP *irp = g_irp_head; while (irp) { if (irp->FileId == FileId) { log_debug("returning irp=%p", irp); return irp; } irp = irp->next; } log_debug("returning irp=NULL"); return NULL; } /** * Return last IRP in linked list *****************************************************************************/ IRP * devredir_irp_get_last(void) { IRP *irp = g_irp_head; while (irp) { if (irp->next == NULL) break; irp = irp->next; } log_debug("returning irp=%p", irp); return irp; } void devredir_irp_dump(void) { IRP *irp = g_irp_head; log_debug("------- dumping IRPs --------"); while (irp) { log_debug(" completion_id=%d\tcompletion_type=%d\tFileId=%d", irp->CompletionId, irp->completion_type, irp->FileId); irp = irp->next; } log_debug("------- dumping IRPs done ---"); } xrdp-0.9.5/sesman/chansrv/sound.c000644 001751 001751 00000145477 13220727201 016666 0ustar00metameta000000 000000 /** * xrdp: A Remote Desktop Protocol server. * * Copyright (C) Jay Sorg 2009-2014 * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ #if defined(HAVE_CONFIG_H) #include #endif #include #include #include #include #include #include #include "sound.h" #include "thread_calls.h" #include "defines.h" #include "fifo.h" #include "xrdp_constants.h" #include "xrdp_sockets.h" #include "chansrv_common.h" #if defined(XRDP_FDK_AAC) #include static HANDLE_AACENCODER g_fdk_aac_encoder = 0; #endif #if defined(XRDP_OPUS) #include static OpusEncoder *g_opus_encoder = 0; #endif #if defined(XRDP_MP3LAME) #include static lame_global_flags *g_lame_encoder = 0; #endif extern int g_rdpsnd_chan_id; /* in chansrv.c */ extern int g_display_num; /* in chansrv.c */ /* audio out: sound_server -> xrdp -> NeutrinoRDP */ static struct trans *g_audio_l_trans_out = 0; /* listener */ static struct trans *g_audio_c_trans_out = 0; /* connection */ /* audio in: sound_server <- xrdp <- NeutrinoRDP */ static struct trans *g_audio_l_trans_in = 0; /* listener */ static struct trans *g_audio_c_trans_in = 0; /* connection */ static int g_training_sent_time = 0; static int g_cBlockNo = 0; static int g_bytes_in_stream = 0; static FIFO g_in_fifo; static int g_bytes_in_fifo = 0; static int g_unacked_frames = 0; static struct stream *g_stream_inp = NULL; static struct stream *g_stream_incoming_packet = NULL; #define MAX_BBUF_SIZE (1024 * 16) static char g_buffer[MAX_BBUF_SIZE]; static int g_buf_index = 0; static int g_sent_time[256]; static int g_sent_flag[256]; static int g_bbuf_size = 1024 * 8; /* may change later */ struct xr_wave_format_ex { int wFormatTag; int nChannels; int nSamplesPerSec; int nAvgBytesPerSec; int nBlockAlign; int wBitsPerSample; int cbSize; tui8 *data; }; /* output formats */ static tui8 g_pcm_22050_data[] = { 0 }; static struct xr_wave_format_ex g_pcm_22050 = { WAVE_FORMAT_PCM, /* wFormatTag */ 2, /* num of channels */ 22050, /* samples per sec */ 88200, /* avg bytes per sec */ 4, /* block align */ 16, /* bits per sample */ 0, /* data size */ g_pcm_22050_data /* data */ }; static tui8 g_pcm_44100_data[] = { 0 }; static struct xr_wave_format_ex g_pcm_44100 = { WAVE_FORMAT_PCM, /* wFormatTag */ 2, /* num of channels */ 44100, /* samples per sec */ 176400, /* avg bytes per sec */ 4, /* block align */ 16, /* bits per sample */ 0, /* data size */ g_pcm_44100_data /* data */ }; #if defined(XRDP_FDK_AAC) static tui8 g_fdk_aac_44100_data[] = { 0 }; static struct xr_wave_format_ex g_fdk_aac_44100 = { WAVE_FORMAT_AAC, /* wFormatTag */ 2, /* num of channels */ 44100, /* samples per sec */ 12000, /* avg bytes per sec */ 4, /* block align */ 16, /* bits per sample */ 0, /* data size */ g_fdk_aac_44100_data /* data */ }; #endif #if defined(XRDP_OPUS) static tui8 g_opus_44100_data[] = { 0 }; static struct xr_wave_format_ex g_opus_44100 = { WAVE_FORMAT_OPUS, /* wFormatTag */ 2, /* num of channels */ 44100, /* samples per sec */ 176400, /* avg bytes per sec */ 4, /* block align */ 16, /* bits per sample */ 0, /* data size */ g_opus_44100_data /* data */ }; #endif #if defined(XRDP_MP3LAME) static tui8 g_mp3lame_44100_data[] = { 0x01, 0x00, 0x02, 0x00, 0x00, 0x00, 0xb6, 0x00, 0x01, 0x00, 0x71, 0x05 }; static struct xr_wave_format_ex g_mp3lame_44100 = { WAVE_FORMAT_MPEGLAYER3, /* wFormatTag */ 2, /* num of channels */ 44100, /* samples per sec */ 176400, /* avg bytes per sec */ 4, /* block align */ 0, /* bits per sample */ 12, /* data size */ g_mp3lame_44100_data /* data */ }; #endif static struct xr_wave_format_ex *g_wave_outp_formats[] = { &g_pcm_44100, &g_pcm_22050, #if defined(XRDP_FDK_AAC) &g_fdk_aac_44100, #endif #if defined(XRDP_OPUS) &g_opus_44100, #endif #if defined(XRDP_MP3LAME) &g_mp3lame_44100, #endif 0 }; static int g_client_does_fdk_aac = 0; static int g_client_fdk_aac_index = 0; static int g_client_does_opus = 0; static int g_client_opus_index = 0; static int g_client_does_mp3lame = 0; static int g_client_mp3lame_index = 0; /* index into list from client */ static int g_current_client_format_index = 0; /* index into list from server */ static int g_current_server_format_index = 0; /* input formats */ static tui8 g_pcm_inp_22050_data[] = { 0 }; static struct xr_wave_format_ex g_pcm_inp_22050 = { WAVE_FORMAT_PCM, /* wFormatTag */ 2, /* num of channels */ 22050, /* samples per sec */ 88200, /* avg bytes per sec */ 4, /* block align */ 16, /* bits per sample */ 0, /* data size */ g_pcm_inp_22050_data /* data */ }; static tui8 g_pcm_inp_44100_data[] = { 0 }; static struct xr_wave_format_ex g_pcm_inp_44100 = { WAVE_FORMAT_PCM, /* wFormatTag */ 2, /* num of channels */ 44100, /* samples per sec */ 176400, /* avg bytes per sec */ 4, /* block align */ 16, /* bits per sample */ 0, /* data size */ g_pcm_inp_44100_data /* data */ }; static struct xr_wave_format_ex *g_wave_inp_formats[] = { &g_pcm_inp_44100, &g_pcm_inp_22050, 0 }; static int g_client_input_format_index = 0; static int g_server_input_format_index = 0; /* microphone related */ static int sound_send_server_input_formats(void); static int sound_process_input_format(int aindex, int wFormatTag, int nChannels, int nSamplesPerSec, int nAvgBytesPerSec, int nBlockAlign, int wBitsPerSample, int cbSize, char *data); static int sound_process_input_formats(struct stream *s, int size); static int sound_input_start_recording(void); static int sound_input_stop_recording(void); static int sound_process_input_data(struct stream *s, int bytes); static int sound_sndsrvr_source_data_in(struct trans *trans); static int sound_start_source_listener(void); static int sound_start_sink_listener(void); /*****************************************************************************/ static int sound_send_server_output_formats(void) { struct stream *s; int bytes; int index; int num_formats; char *size_ptr; num_formats = sizeof(g_wave_outp_formats) / sizeof(g_wave_outp_formats[0]) - 1; LOG(10, ("sound_send_server_output_formats: num_formats %d", num_formats)); make_stream(s); init_stream(s, 8182); out_uint16_le(s, SNDC_FORMATS); size_ptr = s->p; out_uint16_le(s, 0); /* size, set later */ out_uint32_le(s, 0); /* dwFlags */ out_uint32_le(s, 0); /* dwVolume */ out_uint32_le(s, 0); /* dwPitch */ out_uint16_le(s, 0); /* wDGramPort */ out_uint16_le(s, num_formats); /* wNumberOfFormats */ out_uint8(s, g_cBlockNo); /* cLastBlockConfirmed */ out_uint16_le(s, 5); /* wVersion */ out_uint8(s, 0); /* bPad */ /* sndFormats */ /* wFormatTag 2 byte offset 0 nChannels 2 byte offset 2 nSamplesPerSec 4 byte offset 4 nAvgBytesPerSec 4 byte offset 8 nBlockAlign 2 byte offset 12 wBitsPerSample 2 byte offset 14 cbSize 2 byte offset 16 data variable offset 18 */ /* examples 01 00 02 00 44 ac 00 00 10 b1 02 00 04 00 10 00 ....D........... 00 00 01 00 02 00 22 56 00 00 88 58 01 00 04 00 10 00 ...."V...X...... 00 00 */ for (index = 0; index < num_formats; index++) { out_uint16_le(s, g_wave_outp_formats[index]->wFormatTag); out_uint16_le(s, g_wave_outp_formats[index]->nChannels); out_uint32_le(s, g_wave_outp_formats[index]->nSamplesPerSec); out_uint32_le(s, g_wave_outp_formats[index]->nAvgBytesPerSec); out_uint16_le(s, g_wave_outp_formats[index]->nBlockAlign); out_uint16_le(s, g_wave_outp_formats[index]->wBitsPerSample); bytes = g_wave_outp_formats[index]->cbSize; out_uint16_le(s, bytes); if (bytes > 0) { out_uint8p(s, g_wave_outp_formats[index]->data, bytes); } } s_mark_end(s); bytes = (int)((s->end - s->data) - 4); size_ptr[0] = bytes; size_ptr[1] = bytes >> 8; bytes = (int)(s->end - s->data); send_channel_data(g_rdpsnd_chan_id, s->data, bytes); free_stream(s); return 0; } /*****************************************************************************/ static int sound_send_training(void) { struct stream *s; int bytes; int time; char *size_ptr; make_stream(s); init_stream(s, 8182); out_uint16_le(s, SNDC_TRAINING); size_ptr = s->p; out_uint16_le(s, 0); /* size, set later */ time = g_time2(); g_training_sent_time = time; out_uint16_le(s, time); out_uint16_le(s, 1024); out_uint8s(s, (1024 - 4)); s_mark_end(s); bytes = (int)((s->end - s->data) - 4); size_ptr[0] = bytes; size_ptr[1] = bytes >> 8; bytes = (int)(s->end - s->data); send_channel_data(g_rdpsnd_chan_id, s->data, bytes); free_stream(s); return 0; } /*****************************************************************************/ static int sound_process_output_format(int aindex, int wFormatTag, int nChannels, int nSamplesPerSec, int nAvgBytesPerSec, int nBlockAlign, int wBitsPerSample, int cbSize, char *data) { LOG(1, ("sound_process_output_format:")); LOG(1, (" wFormatTag %d", wFormatTag)); LOG(1, (" nChannels %d", nChannels)); LOG(1, (" nSamplesPerSec %d", nSamplesPerSec)); LOG(1, (" nAvgBytesPerSec %d", nAvgBytesPerSec)); LOG(1, (" nBlockAlign %d", nBlockAlign)); LOG(1, (" wBitsPerSample %d", wBitsPerSample)); LOG(1, (" cbSize %d", cbSize)); g_hexdump(data, cbSize); /* select CD quality audio */ if (wFormatTag == g_pcm_44100.wFormatTag && nChannels == g_pcm_44100.nChannels && nSamplesPerSec == g_pcm_44100.nSamplesPerSec && nAvgBytesPerSec == g_pcm_44100.nAvgBytesPerSec && nBlockAlign == g_pcm_44100.nBlockAlign && wBitsPerSample == g_pcm_44100.wBitsPerSample) { g_current_client_format_index = aindex; g_current_server_format_index = 0; } #if 0 for (lindex = 0; lindex < NUM_BUILT_IN; lindex++) { if (wFormatTag == g_wave_formats[lindex]->wFormatTag && nChannels == g_wave_formats[lindex]->nChannels && nSamplesPerSec == g_wave_formats[lindex]->nSamplesPerSec && nAvgBytesPerSec == g_wave_formats[lindex]->nAvgBytesPerSec && nBlockAlign == g_wave_formats[lindex]->nBlockAlign && wBitsPerSample == g_wave_formats[lindex]->wBitsPerSample) { g_current_client_format_index = aindex; g_current_server_format_index = lindex; } } #endif switch(wFormatTag) { case WAVE_FORMAT_AAC: LOG(0, ("wFormatTag, fdk aac")); g_client_does_fdk_aac = 1; g_client_fdk_aac_index = aindex; break; case WAVE_FORMAT_MPEGLAYER3: LOG(0, ("wFormatTag, mp3")); g_client_does_mp3lame = 1; g_client_mp3lame_index = aindex; break; case WAVE_FORMAT_OPUS: LOG(0, ("wFormatTag, opus")); g_client_does_opus = 1; g_client_opus_index = aindex; break; } return 0; } /*****************************************************************************/ /* 0000 07 02 26 00 03 00 80 00 ff ff ff ff 00 00 00 00 ..&............. 0010 00 00 01 00 00 02 00 00 01 00 02 00 44 ac 00 00 ............D... 0020 10 b1 02 00 04 00 10 00 00 00 */ static int sound_process_output_formats(struct stream *s, int size) { int num_formats; int index; int wFormatTag; int nChannels; int nSamplesPerSec; int nAvgBytesPerSec; int nBlockAlign; int wBitsPerSample; int cbSize; char *data; if (size < 16) return 1; in_uint8s(s, 14); in_uint16_le(s, num_formats); in_uint8s(s, 4); if (num_formats > 0) { for (index = 0; index < num_formats; index++) { in_uint16_le(s, wFormatTag); in_uint16_le(s, nChannels); in_uint32_le(s, nSamplesPerSec); in_uint32_le(s, nAvgBytesPerSec); in_uint16_le(s, nBlockAlign); in_uint16_le(s, wBitsPerSample); in_uint16_le(s, cbSize); in_uint8p(s, data, cbSize); sound_process_output_format(index, wFormatTag, nChannels, nSamplesPerSec, nAvgBytesPerSec, nBlockAlign, wBitsPerSample, cbSize, data); } sound_send_training(); } return 0; } #if defined(XRDP_FDK_AAC) /*****************************************************************************/ static int sound_wave_compress_fdk_aac(char *data, int data_bytes, int *format_index) { int rv; int cdata_bytes; char *cdata; AACENC_ERROR error; int aot; int sample_rate; int mode; int bitrate; int afterburner; int channel_order; AACENC_InfoStruct info; AACENC_BufDesc in_buf; AACENC_BufDesc out_buf; AACENC_InArgs in_args; AACENC_OutArgs out_args; void *in_buffer; int in_identifier; int in_size; int in_elem_size; void *out_buffer; int out_identifier; int out_size; int out_elem_size; rv = data_bytes; if (g_client_does_fdk_aac == 0) { return rv; } if (g_fdk_aac_encoder == 0) { /* init fdk aac encoder */ LOG(0, ("sound_wave_compress_fdk_aac: using fdk aac")); error = aacEncOpen(&g_fdk_aac_encoder, 0, 2); if (error != AACENC_OK) { LOG(0, ("sound_wave_compress_fdk_aac: aacEncOpen() failed")); return rv; } aot = 2; /* MPEG-4 AAC Low Complexity. */ error = aacEncoder_SetParam(g_fdk_aac_encoder, AACENC_AOT, aot); if (error != AACENC_OK) { LOG(0, ("sound_wave_compress_fdk_aac: aacEncoder_SetParam() " "AACENC_AOT failed")); } sample_rate = g_fdk_aac_44100.nSamplesPerSec; error = aacEncoder_SetParam(g_fdk_aac_encoder, AACENC_SAMPLERATE, sample_rate); if (error != AACENC_OK) { LOG(0, ("sound_wave_compress_fdk_aac: aacEncoder_SetParam() " "AACENC_SAMPLERATE failed")); } mode = MODE_2; error = aacEncoder_SetParam(g_fdk_aac_encoder, AACENC_CHANNELMODE, mode); if (error != AACENC_OK) { LOG(0, ("sound_wave_compress_fdk_aac: aacEncoder_SetParam() " "AACENC_CHANNELMODE failed")); } channel_order = 1; /* WAVE file format channel ordering */ error = aacEncoder_SetParam(g_fdk_aac_encoder, AACENC_CHANNELORDER, channel_order); if (error != AACENC_OK) { LOG(0, ("sound_wave_compress_fdk_aac: aacEncoder_SetParam() " "AACENC_CHANNELORDER failed")); } /* bytes rate to bit rate */ bitrate = g_fdk_aac_44100.nAvgBytesPerSec * 8; error = aacEncoder_SetParam(g_fdk_aac_encoder, AACENC_BITRATE, bitrate); if (error != AACENC_OK) { LOG(0, ("sound_wave_compress_fdk_aac: aacEncoder_SetParam() " "AACENC_BITRATE failed")); } error = aacEncoder_SetParam(g_fdk_aac_encoder, AACENC_TRANSMUX, 0); if (error != AACENC_OK) { LOG(0, ("sound_wave_compress_fdk_aac: aacEncoder_SetParam() " "AACENC_TRANSMUX failed")); } afterburner = 1; error = aacEncoder_SetParam(g_fdk_aac_encoder, AACENC_AFTERBURNER, afterburner); if (error != AACENC_OK) { LOG(0, ("sound_wave_compress_fdk_aac: aacEncoder_SetParam() " "AACENC_AFTERBURNER failed")); } error = aacEncEncode(g_fdk_aac_encoder, NULL, NULL, NULL, NULL); if (error != AACENC_OK) { LOG(0, ("sound_wave_compress_fdk_aac: Unable to initialize " "the encoder")); } g_memset(&info, 0, sizeof(info)); error = aacEncInfo(g_fdk_aac_encoder, &info); if (error != AACENC_OK) { LOG(0, ("sound_wave_compress_fdk_aac: aacEncInfo failed")); } LOG(0, ("sound_wave_compress_fdk_aac:")); LOG(0, (" AACENC_InfoStruct")); LOG(0, (" maxOutBufBytes %d", info.maxOutBufBytes)); LOG(0, (" maxAncBytes %d", info.maxAncBytes)); LOG(0, (" inBufFillLevel %d", info.inBufFillLevel)); LOG(0, (" inputChannels %d", info.inputChannels)); LOG(0, (" frameLength %d", info.frameLength)); LOG(0, (" encoderDelay %d", info.encoderDelay)); LOG(0, (" confBuf")); LOG(0, (" confSize %d", info.confSize)); } rv = data_bytes; cdata_bytes = data_bytes; cdata = (char *) g_malloc(cdata_bytes, 0); if (data_bytes < g_bbuf_size) { g_memset(data + data_bytes, 0, g_bbuf_size - data_bytes); data_bytes = g_bbuf_size; } in_buffer = data; in_identifier = IN_AUDIO_DATA; in_size = data_bytes; in_elem_size = 2; g_memset(&in_args, 0, sizeof(in_args)); in_args.numInSamples = data_bytes / 2; g_memset(&in_buf, 0, sizeof(in_buf)); in_buf.numBufs = 1; in_buf.bufs = &in_buffer; in_buf.bufferIdentifiers = &in_identifier; in_buf.bufSizes = &in_size; in_buf.bufElSizes = &in_elem_size; out_buffer = cdata; out_identifier = OUT_BITSTREAM_DATA; out_size = cdata_bytes; out_elem_size = 1; g_memset(&out_buf, 0, sizeof(out_buf)); out_buf.numBufs = 1; out_buf.bufs = &out_buffer; out_buf.bufferIdentifiers = &out_identifier; out_buf.bufSizes = &out_size; out_buf.bufElSizes = &out_elem_size; g_memset(&out_args, 0, sizeof(out_args)); error = aacEncEncode(g_fdk_aac_encoder, &in_buf, &out_buf, &in_args, &out_args); if (error == AACENC_OK) { cdata_bytes = out_args.numOutBytes; LOG(10, ("sound_wave_compress_fdk_aac: aacEncEncode ok " "cdata_bytes %d", cdata_bytes)); *format_index = g_client_fdk_aac_index; g_memcpy(data, cdata, cdata_bytes); rv = cdata_bytes; } else { LOG(0, ("sound_wave_compress_fdk_aac: aacEncEncode failed")); } g_free(cdata); return rv; } #else /*****************************************************************************/ static int sound_wave_compress_fdk_aac(char *data, int data_bytes, int *format_index) { return data_bytes; } #endif #if defined(XRDP_OPUS) /*****************************************************************************/ static int sound_wave_compress_opus(char *data, int data_bytes, int *format_index) { unsigned char *cdata; int cdata_bytes; int rv; int error; int data_bytes_org; opus_int16 *os16; if (g_client_does_opus == 0) { return data_bytes; } if (g_opus_encoder == 0) { /* NB (narrowband) 8 kHz MB (medium-band) 12 kHz WB (wideband) 16 kHz SWB (super-wideband) 24 kHz FB (fullband) 48 kHz */ g_opus_encoder = opus_encoder_create(48000, 2, OPUS_APPLICATION_AUDIO, &error); if (g_opus_encoder == 0) { LOG(0, ("sound_wave_compress_opus: opus_encoder_create failed")); return data_bytes; } } data_bytes_org = data_bytes; rv = data_bytes; cdata_bytes = data_bytes; cdata = (unsigned char *) g_malloc(cdata_bytes, 0); os16 = (opus_int16 *) data; /* at 48000 we have 2.5 ms 480 5 ms 960 10 ms 1920 20 ms 3840 40 ms 7680 60 ms 11520 */ if (data_bytes < g_bbuf_size) { g_memset(data + data_bytes, 0, g_bbuf_size - data_bytes); data_bytes = g_bbuf_size; } cdata_bytes = opus_encode(g_opus_encoder, os16, data_bytes / 4, cdata, cdata_bytes); if ((cdata_bytes > 0) && (cdata_bytes < data_bytes_org)) { *format_index = g_client_opus_index; g_memcpy(data, cdata, cdata_bytes); rv = cdata_bytes; } g_free(cdata); return rv; } #else /*****************************************************************************/ static int sound_wave_compress_opus(char *data, int data_bytes, int *format_index) { return data_bytes; } #endif #if defined(XRDP_MP3LAME) /*****************************************************************************/ static int sound_wave_compress_mp3lame(char *data, int data_bytes, int *format_index) { int rv; int cdata_bytes; int odata_bytes; unsigned char *cdata; cdata = NULL; rv = data_bytes; if (g_client_does_mp3lame == 0) { return rv; } if (g_lame_encoder == 0) { /* init mp3 lame encoder */ LOG(0, ("sound_wave_compress_mp3lame: using mp3lame")); g_lame_encoder = lame_init(); if (g_lame_encoder == 0) { LOG(0, ("sound_wave_compress_mp3lame: lame_init() failed")); return rv; } lame_set_num_channels(g_lame_encoder, g_mp3lame_44100.nChannels); lame_set_in_samplerate(g_lame_encoder, g_mp3lame_44100.nSamplesPerSec); if (lame_init_params(g_lame_encoder) == -1) { LOG(0, ("sound_wave_compress_mp3lame: lame_init_params() failed")); return rv; } LOG(0, ("sound_wave_compress_mp3lame: lame config:")); LOG(0, (" brate : %d", lame_get_brate(g_lame_encoder))); LOG(0, (" compression ratio: %f", lame_get_compression_ratio(g_lame_encoder))); LOG(0, (" encoder delay : %d", lame_get_encoder_delay(g_lame_encoder))); LOG(0, (" frame size : %d", lame_get_framesize(g_lame_encoder))); LOG(0, (" encoder padding : %d", lame_get_encoder_padding(g_lame_encoder))); LOG(0, (" mode : %d", lame_get_mode(g_lame_encoder))); } odata_bytes = data_bytes; cdata_bytes = data_bytes; cdata = (unsigned char *) g_malloc(cdata_bytes, 0); if (data_bytes < g_bbuf_size) { g_memset(data + data_bytes, 0, g_bbuf_size - data_bytes); data_bytes = g_bbuf_size; } cdata_bytes = lame_encode_buffer_interleaved(g_lame_encoder, (short int *) data, data_bytes / 4, cdata, cdata_bytes); if (cdata_bytes < 0) { LOG(0, ("sound_wave_compress: lame_encode_buffer_interleaved() " "failed, error %d", cdata_bytes)); return rv; } if ((cdata_bytes > 0) && (cdata_bytes < odata_bytes)) { *format_index = g_client_mp3lame_index; g_memcpy(data, cdata, cdata_bytes); rv = cdata_bytes; } g_free(cdata); return rv; } #else /*****************************************************************************/ static int sound_wave_compress_mp3lame(char *data, int data_bytes, int *format_index) { return data_bytes; } #endif /*****************************************************************************/ static int sound_wave_compress(char *data, int data_bytes, int *format_index) { if (g_client_does_fdk_aac) { g_bbuf_size = 4096; return sound_wave_compress_fdk_aac(data, data_bytes, format_index); } else if (g_client_does_opus) { g_bbuf_size = 11520; return sound_wave_compress_opus(data, data_bytes, format_index); } else if (g_client_does_mp3lame) { g_bbuf_size = 11520; return sound_wave_compress_mp3lame(data, data_bytes, format_index); } return data_bytes; } /*****************************************************************************/ /* send wave message to client */ static int sound_send_wave_data_chunk(char *data, int data_bytes) { struct stream *s; int bytes; int time; int format_index; char *size_ptr; LOG(10, ("sound_send_wave_data_chunk: data_bytes %d", data_bytes)); if ((data_bytes < 4) || (data_bytes > 128 * 1024)) { LOG(0, ("sound_send_wave_data_chunk: bad data_bytes %d", data_bytes)); return 1; } LOG(20, ("sound_send_wave_data_chunk: g_sent_flag[%d] = %d", g_cBlockNo + 1, g_sent_flag[(g_cBlockNo + 1) & 0xff])); if (g_sent_flag[(g_cBlockNo + 1) & 0xff] & 1) { LOG(10, ("sound_send_wave_data_chunk: no room")); return 2; } else { LOG(10, ("sound_send_wave_data_chunk: got room")); } /* compress, if available */ format_index = g_current_client_format_index; data_bytes = sound_wave_compress(data, data_bytes, &format_index); /* part one of 2 PDU wave info */ LOG(10, ("sound_send_wave_data_chunk: sending %d bytes", data_bytes)); make_stream(s); init_stream(s, 16 + data_bytes); /* some extra space */ out_uint16_le(s, SNDC_WAVE); size_ptr = s->p; out_uint16_le(s, 0); /* size, set later */ time = g_time2(); out_uint16_le(s, time); out_uint16_le(s, format_index); /* wFormatNo */ g_cBlockNo++; g_unacked_frames++; out_uint8(s, g_cBlockNo); g_sent_time[g_cBlockNo & 0xff] = time; g_sent_flag[g_cBlockNo & 0xff] = 1; LOG(10, ("sound_send_wave_data_chunk: sending time %d, g_cBlockNo %d", time & 0xffff, g_cBlockNo & 0xff)); out_uint8s(s, 3); out_uint8a(s, data, 4); s_mark_end(s); bytes = (int)((s->end - s->data) - 4); bytes += data_bytes; bytes -= 4; size_ptr[0] = bytes; size_ptr[1] = bytes >> 8; bytes = (int)(s->end - s->data); send_channel_data(g_rdpsnd_chan_id, s->data, bytes); /* part two of 2 PDU wave info even is zero, we have to send this */ init_stream(s, data_bytes); out_uint32_le(s, 0); out_uint8a(s, data + 4, data_bytes - 4); s_mark_end(s); bytes = (int)(s->end - s->data); send_channel_data(g_rdpsnd_chan_id, s->data, bytes); free_stream(s); return 0; } /*****************************************************************************/ /* send wave message to client, buffer first */ static int sound_send_wave_data(char *data, int data_bytes) { int space_left; int chunk_bytes; int data_index; int error; int res; LOG(10, ("sound_send_wave_data: sending %d bytes", data_bytes)); data_index = 0; error = 0; while (data_bytes > 0) { space_left = g_bbuf_size - g_buf_index; chunk_bytes = MIN(space_left, data_bytes); if (chunk_bytes < 1) { LOG(10, ("sound_send_wave_data: error")); error = 1; break; } g_memcpy(g_buffer + g_buf_index, data + data_index, chunk_bytes); g_buf_index += chunk_bytes; if (g_buf_index >= g_bbuf_size) { g_buf_index = 0; res = sound_send_wave_data_chunk(g_buffer, g_bbuf_size); if (res == 2) { /* don't need to error on this */ LOG(0, ("sound_send_wave_data: dropped, no room")); break; } else if (res != 0) { LOG(10, ("sound_send_wave_data: error")); error = 1; break; } } data_bytes -= chunk_bytes; data_index += chunk_bytes; } return error; } /*****************************************************************************/ /* send close message to client */ static int sound_send_close(void) { struct stream *s; int bytes; char *size_ptr; LOG(10, ("sound_send_close:")); /* send any left over data */ if (g_buf_index) { if (sound_send_wave_data_chunk(g_buffer, g_buf_index) != 0) { LOG(10, ("sound_send_close: sound_send_wave_data_chunk failed")); return 1; } } g_buf_index = 0; g_memset(g_sent_flag, 0, sizeof(g_sent_flag)); /* send close msg */ make_stream(s); init_stream(s, 8182); out_uint16_le(s, SNDC_CLOSE); size_ptr = s->p; out_uint16_le(s, 0); /* size, set later */ s_mark_end(s); bytes = (int)((s->end - s->data) - 4); size_ptr[0] = bytes; size_ptr[1] = bytes >> 8; bytes = (int)(s->end - s->data); send_channel_data(g_rdpsnd_chan_id, s->data, bytes); free_stream(s); return 0; } /*****************************************************************************/ /* from client */ static int sound_process_training(struct stream *s, int size) { int time_diff; time_diff = g_time2() - g_training_sent_time; LOG(0, ("sound_process_training: round trip time %u", time_diff)); return 0; } /*****************************************************************************/ /* from client */ static int sound_process_wave_confirm(struct stream *s, int size) { int wTimeStamp; int cConfirmedBlockNo; int cleared_count; int time; int time_diff; int block_no; int block_no_clamped; int found; int index; time = g_time2(); in_uint16_le(s, wTimeStamp); in_uint8(s, cConfirmedBlockNo); time_diff = time - g_sent_time[cConfirmedBlockNo & 0xff]; cleared_count = 0; found = 0; block_no = g_cBlockNo; for (index = 0; index < g_unacked_frames; index++) { block_no_clamped = block_no & 0xff; if ((cConfirmedBlockNo == block_no_clamped) || found) { found = 1; if (g_sent_flag[block_no_clamped] & 1) { LOG(10, ("sound_process_wave_confirm: clearing %d", block_no_clamped)); g_sent_flag[block_no_clamped] &= ~1; cleared_count++; } } block_no--; } LOG(10, ("sound_process_wave_confirm: wTimeStamp %d, " "cConfirmedBlockNo %d time diff %d cleared_count %d " "g_unacked_frames %d", wTimeStamp, cConfirmedBlockNo, time_diff, cleared_count, g_unacked_frames)); g_unacked_frames -= cleared_count; return 0; } /*****************************************************************************/ /* process message in from the audio source, eg pulse, alsa on it's way to the client. returns error */ static int process_pcm_message(int id, int size, struct stream *s) { switch (id) { case 0: return sound_send_wave_data(s->p, size); break; case 1: return sound_send_close(); break; default: LOG(10, ("process_pcm_message: unknown id %d", id)); break; } return 1; } /*****************************************************************************/ /* data in from sound_server_sink */ static int sound_sndsrvr_sink_data_in(struct trans *trans) { struct stream *s; int id; int size; int error; if (trans == 0) return 0; if (trans != g_audio_c_trans_out) return 1; s = trans_get_in_s(trans); in_uint32_le(s, id); in_uint32_le(s, size); if ((id & ~3) || (size > 128 * 1024 + 8) || (size < 8)) { LOG(0, ("sound_sndsrvr_sink_data_in: bad message id %d size %d", id, size)); return 1; } LOG(10, ("sound_sndsrvr_sink_data_in: good message id %d size %d", id, size)); error = trans_force_read(trans, size - 8); if (error == 0) { /* here, the entire message block is read in, process it */ error = process_pcm_message(id, size - 8, s); } return error; } /*****************************************************************************/ /* incoming connection on unix domain socket - sound_server_sink -> xrdp */ static int sound_sndsrvr_sink_conn_in(struct trans *trans, struct trans *new_trans) { LOG(0, ("sound_sndsrvr_sink_conn_in:")); if (trans == 0) return 1; if (trans != g_audio_l_trans_out) return 1; if (g_audio_c_trans_out != 0) /* if already set, error */ return 1; if (new_trans == 0) return 1; g_audio_c_trans_out = new_trans; g_audio_c_trans_out->trans_data_in = sound_sndsrvr_sink_data_in; g_audio_c_trans_out->header_size = 8; trans_delete(g_audio_l_trans_out); g_audio_l_trans_out = 0; return 0; } /*****************************************************************************/ /* incoming connection on unix domain socket - sound_server_source -> xrdp */ static int sound_sndsrvr_source_conn_in(struct trans *trans, struct trans *new_trans) { LOG(0, ("sound_sndsrvr_source_conn_in: client connected")); if (trans == 0) return 1; if (trans != g_audio_l_trans_in) return 1; if (g_audio_c_trans_in != 0) /* if already set, error */ return 1; if (new_trans == 0) return 1; g_audio_c_trans_in = new_trans; g_audio_c_trans_in->trans_data_in = sound_sndsrvr_source_data_in; g_audio_c_trans_in->header_size = 8; trans_delete(g_audio_l_trans_in); g_audio_l_trans_in = 0; return 0; } /*****************************************************************************/ int sound_init(void) { LOG(0, ("sound_init:")); g_memset(g_sent_flag, 0, sizeof(g_sent_flag)); g_stream_incoming_packet = NULL; /* init sound output */ sound_send_server_output_formats(); sound_start_sink_listener(); /* init sound input */ sound_send_server_input_formats(); sound_start_source_listener(); /* save data from sound_server_source */ fifo_init(&g_in_fifo, 100); g_client_does_fdk_aac = 0; g_client_fdk_aac_index = 0; g_client_does_opus = 0; g_client_opus_index = 0; g_client_does_mp3lame = 0; g_client_mp3lame_index = 0; return 0; } /*****************************************************************************/ int sound_deinit(void) { LOG(10, ("sound_deinit:")); if (g_audio_l_trans_out != 0) { trans_delete(g_audio_l_trans_out); g_audio_l_trans_out = 0; } if (g_audio_c_trans_out != 0) { trans_delete(g_audio_c_trans_out); g_audio_c_trans_out = 0; } if (g_audio_l_trans_in != 0) { trans_delete(g_audio_l_trans_in); g_audio_l_trans_in = 0; } if (g_audio_c_trans_in != 0) { trans_delete(g_audio_c_trans_in); g_audio_c_trans_in = 0; } #if defined(XRDP_MP3LAME) if (g_lame_encoder) { lame_close(g_lame_encoder); g_lame_encoder = 0; g_client_does_mp3lame = 0; } #endif fifo_deinit(&g_in_fifo); return 0; } /*****************************************************************************/ /* data in from client ( client -> xrdp -> chansrv ) */ int sound_data_in(struct stream *s, int chan_id, int chan_flags, int length, int total_length) { int code; int size; int ok_to_free = 1; if (!read_entire_packet(s, &g_stream_incoming_packet, chan_flags, length, total_length)) { return 0; } in_uint8(g_stream_incoming_packet, code); in_uint8s(g_stream_incoming_packet, 1); in_uint16_le(g_stream_incoming_packet, size); switch (code) { case SNDC_WAVECONFIRM: sound_process_wave_confirm(g_stream_incoming_packet, size); break; case SNDC_TRAINING: sound_process_training(g_stream_incoming_packet, size); break; case SNDC_FORMATS: sound_process_output_formats(g_stream_incoming_packet, size); break; case SNDC_REC_NEGOTIATE: sound_process_input_formats(g_stream_incoming_packet, size); break; case SNDC_REC_DATA: sound_process_input_data(g_stream_incoming_packet, size); ok_to_free = 0; break; default: LOG(10, ("sound_data_in: unknown code %d size %d", code, size)); break; } if (ok_to_free && g_stream_incoming_packet) { xstream_free(g_stream_incoming_packet); g_stream_incoming_packet = NULL; } return 0; } /*****************************************************************************/ int sound_get_wait_objs(tbus *objs, int *count, int *timeout) { int lcount; lcount = *count; if (g_audio_l_trans_out != 0) { objs[lcount] = g_audio_l_trans_out->sck; lcount++; } if (g_audio_c_trans_out != 0) { objs[lcount] = g_audio_c_trans_out->sck; lcount++; } if (g_audio_l_trans_in != 0) { objs[lcount] = g_audio_l_trans_in->sck; lcount++; } if (g_audio_c_trans_in != 0) { objs[lcount] = g_audio_c_trans_in->sck; lcount++; } *count = lcount; return 0; } /*****************************************************************************/ int sound_check_wait_objs(void) { if (g_audio_l_trans_out != 0) { if (trans_check_wait_objs(g_audio_l_trans_out) != 0) { LOG(10, ("sound_check_wait_objs: g_audio_l_trans_out returned non-zero")); trans_delete(g_audio_l_trans_out); g_audio_l_trans_out = 0; } } if (g_audio_c_trans_out != 0) { if (trans_check_wait_objs(g_audio_c_trans_out) != 0) { LOG(10, ("sound_check_wait_objs: g_audio_c_trans_out returned non-zero")); trans_delete(g_audio_c_trans_out); g_audio_c_trans_out = 0; sound_start_sink_listener(); } } if (g_audio_l_trans_in != 0) { if (trans_check_wait_objs(g_audio_l_trans_in) != 0) { LOG(10, ("sound_check_wait_objs: g_audio_l_trans_in returned non-zero")); trans_delete(g_audio_l_trans_in); g_audio_l_trans_in = 0; } } if (g_audio_c_trans_in != 0) { if (trans_check_wait_objs(g_audio_c_trans_in) != 0) { LOG(10, ("sound_check_wait_objs: g_audio_c_trans_in returned non-zero")); trans_delete(g_audio_c_trans_in); g_audio_c_trans_in = 0; sound_start_source_listener(); } } return 0; } /****************************************************************************** ** ** ** Microphone related code ** ** ** ******************************************************************************/ /** * *****************************************************************************/ static int sound_send_server_input_formats(void) { struct stream *s; int bytes; int index; int num_formats; char *size_ptr; num_formats = sizeof(g_wave_inp_formats) / sizeof(g_wave_inp_formats[0]) - 1; LOG(10, ("sound_send_server_input_formats: num_formats %d", num_formats)); make_stream(s); init_stream(s, 8182); out_uint16_le(s, SNDC_REC_NEGOTIATE); size_ptr = s->p; out_uint16_le(s, 0); /* size, set later */ out_uint32_le(s, 0); /* unused */ out_uint32_le(s, 0); /* unused */ out_uint16_le(s, num_formats); /* wNumberOfFormats */ out_uint16_le(s, 5); /* wVersion */ /* wFormatTag 2 byte offset 0 nChannels 2 byte offset 2 nSamplesPerSec 4 byte offset 4 nAvgBytesPerSec 4 byte offset 8 nBlockAlign 2 byte offset 12 wBitsPerSample 2 byte offset 14 cbSize 2 byte offset 16 data variable offset 18 */ for (index = 0; index < num_formats; index++) { out_uint16_le(s, g_wave_inp_formats[index]->wFormatTag); out_uint16_le(s, g_wave_inp_formats[index]->nChannels); out_uint32_le(s, g_wave_inp_formats[index]->nSamplesPerSec); out_uint32_le(s, g_wave_inp_formats[index]->nAvgBytesPerSec); out_uint16_le(s, g_wave_inp_formats[index]->nBlockAlign); out_uint16_le(s, g_wave_inp_formats[index]->wBitsPerSample); bytes = g_wave_inp_formats[index]->cbSize; out_uint16_le(s, bytes); if (bytes > 0) { out_uint8p(s, g_wave_inp_formats[index]->data, bytes); } } s_mark_end(s); bytes = (int)((s->end - s->data) - 4); size_ptr[0] = bytes; size_ptr[1] = bytes >> 8; bytes = (int)(s->end - s->data); send_channel_data(g_rdpsnd_chan_id, s->data, bytes); free_stream(s); return 0; } /** * *****************************************************************************/ static int sound_process_input_format(int aindex, int wFormatTag, int nChannels, int nSamplesPerSec, int nAvgBytesPerSec, int nBlockAlign, int wBitsPerSample, int cbSize, char *data) { LOG(10, ("sound_process_input_format:")); LOG(10, (" wFormatTag %d", wFormatTag)); LOG(10, (" nChannels %d", nChannels)); LOG(10, (" nSamplesPerSec %d", nSamplesPerSec)); LOG(10, (" nAvgBytesPerSec %d", nAvgBytesPerSec)); LOG(10, (" nBlockAlign %d", nBlockAlign)); LOG(10, (" wBitsPerSample %d", wBitsPerSample)); LOG(10, (" cbSize %d", cbSize)); #if 1 /* select CD quality audio */ if (wFormatTag == g_pcm_inp_44100.wFormatTag && nChannels == g_pcm_inp_44100.nChannels && nSamplesPerSec == g_pcm_inp_44100.nSamplesPerSec && nAvgBytesPerSec == g_pcm_inp_44100.nAvgBytesPerSec && nBlockAlign == g_pcm_inp_44100.nBlockAlign && wBitsPerSample == g_pcm_inp_44100.wBitsPerSample) { g_client_input_format_index = aindex; g_server_input_format_index = 0; } #else /* select half of CD quality audio */ if (wFormatTag == g_pcm_inp_22050.wFormatTag && nChannels == g_pcm_inp_22050.nChannels && nSamplesPerSec == g_pcm_inp_22050.nSamplesPerSec && nAvgBytesPerSec == g_pcm_inp_22050.nAvgBytesPerSec && nBlockAlign == g_pcm_inp_22050.nBlockAlign && wBitsPerSample == g_pcm_inp_22050.wBitsPerSample) { g_client_input_format_index = aindex; g_server_input_format_index = 0; } #endif return 0; } /** * *****************************************************************************/ static int sound_process_input_formats(struct stream *s, int size) { int num_formats; int index; int wFormatTag; int nChannels; int nSamplesPerSec; int nAvgBytesPerSec; int nBlockAlign; int wBitsPerSample; int cbSize; char *data; LOG(10, ("sound_process_input_formats: size=%d", size)); in_uint8s(s, 8); /* skip 8 bytes */ in_uint16_le(s, num_formats); in_uint8s(s, 2); /* skip version */ if (num_formats > 0) { for (index = 0; index < num_formats; index++) { in_uint16_le(s, wFormatTag); in_uint16_le(s, nChannels); in_uint32_le(s, nSamplesPerSec); in_uint32_le(s, nAvgBytesPerSec); in_uint16_le(s, nBlockAlign); in_uint16_le(s, wBitsPerSample); in_uint16_le(s, cbSize); in_uint8p(s, data, cbSize); sound_process_input_format(index, wFormatTag, nChannels, nSamplesPerSec, nAvgBytesPerSec, nBlockAlign, wBitsPerSample, cbSize, data); } } return 0; } /** * *****************************************************************************/ static int sound_input_start_recording(void) { struct stream* s; LOG(10, ("sound_input_start_recording:")); /* if there is any data in FIFO, discard it */ while ((s = (struct stream *) fifo_remove(&g_in_fifo)) != NULL) { xstream_free(s); } g_bytes_in_fifo = 0; xstream_new(s, 1024); /* * command format * * 02 bytes command SNDC_REC_START * 02 bytes length * 02 bytes data format received earlier */ out_uint16_le(s, SNDC_REC_START); out_uint16_le(s, 2); out_uint16_le(s, g_client_input_format_index); s_mark_end(s); send_channel_data(g_rdpsnd_chan_id, s->data, 6); xstream_free(s); return 0; } /** * *****************************************************************************/ static int sound_input_stop_recording(void) { struct stream* s; LOG(10, ("sound_input_stop_recording:")); xstream_new(s, 1024); /* * command format * * 02 bytes command SNDC_REC_STOP * 02 bytes length (zero) */ out_uint16_le(s, SNDC_REC_STOP); out_uint16_le(s, 0); s_mark_end(s); send_channel_data(g_rdpsnd_chan_id, s->data, 4); xstream_free(s); return 0; } /** * Process data: xrdp <- client *****************************************************************************/ static int sound_process_input_data(struct stream *s, int bytes) { struct stream *ls; LOG(10, ("sound_process_input_data: bytes %d g_bytes_in_fifo %d", bytes, g_bytes_in_fifo)); #if 0 /* no need to cap anymore */ /* cap data in fifo */ if (g_bytes_in_fifo > 8 * 1024) { return 0; } #endif xstream_new(ls, bytes); g_memcpy(ls->data, s->p, bytes); ls->p += bytes; s_mark_end(ls); fifo_insert(&g_in_fifo, (void *) ls); g_bytes_in_fifo += bytes; return 0; } /** * Got a command from sound_server_source *****************************************************************************/ static int sound_sndsrvr_source_data_in(struct trans *trans) { struct stream *ts = NULL; struct stream *s = NULL; tui16 bytes_req = 0; int bytes_read = 0; int cmd; int i; if (trans == 0) return 0; if (trans != g_audio_c_trans_in) return 1; ts = trans_get_in_s(trans); if (trans_force_read(trans, 3)) log_message(LOG_LEVEL_ERROR, "sound.c: error reading from transport"); ts->p = ts->data + 8; in_uint8(ts, cmd); in_uint16_le(ts, bytes_req); LOG(10, ("sound_sndsrvr_source_data_in: bytes_req %d", bytes_req)); xstream_new(s, bytes_req + 2); if (cmd == PA_CMD_SEND_DATA) { /* set real len later */ out_uint16_le(s, 0); while (bytes_read < bytes_req) { if (g_stream_inp == NULL) { g_stream_inp = (struct stream *) fifo_remove(&g_in_fifo); if (g_stream_inp != NULL) { g_bytes_in_fifo -= g_stream_inp->size; LOG(10, (" g_bytes_in_fifo %d", g_bytes_in_fifo)); } } if (g_stream_inp == NULL) { /* no more data, send what we have */ break; } else { if (g_bytes_in_stream == 0) g_bytes_in_stream = g_stream_inp->size; i = bytes_req - bytes_read; if (i < g_bytes_in_stream) { xstream_copyin(s, &g_stream_inp->data[g_stream_inp->size - g_bytes_in_stream], i); bytes_read += i; g_bytes_in_stream -= i; } else { xstream_copyin(s, &g_stream_inp->data[g_stream_inp->size - g_bytes_in_stream], g_bytes_in_stream); bytes_read += g_bytes_in_stream; g_bytes_in_stream = 0; xstream_free(g_stream_inp); g_stream_inp = NULL; } } } if (bytes_read) { s->data[0] = (char) (bytes_read & 0xff); s->data[1] = (char) ((bytes_read >> 8) & 0xff); } s_mark_end(s); trans_force_write_s(trans, s); } else if (cmd == PA_CMD_START_REC) { sound_input_start_recording(); } else if (cmd == PA_CMD_STOP_REC) { sound_input_stop_recording(); } xstream_free(s); return 0; } /** * Start a listener for microphone redirection connections *****************************************************************************/ static int sound_start_source_listener(void) { char port[1024]; g_audio_l_trans_in = trans_create(TRANS_MODE_UNIX, 128 * 1024, 8192); g_audio_l_trans_in->is_term = g_is_term; g_snprintf(port, 255, CHANSRV_PORT_IN_STR, g_display_num); g_audio_l_trans_in->trans_conn_in = sound_sndsrvr_source_conn_in; if (trans_listen(g_audio_l_trans_in, port) != 0) LOG(0, ("trans_listen failed")); return 0; } /** * Start a listener for speaker redirection connections *****************************************************************************/ static int sound_start_sink_listener(void) { char port[1024]; g_audio_l_trans_out = trans_create(TRANS_MODE_UNIX, 128 * 1024, 8192); g_audio_l_trans_out->is_term = g_is_term; g_snprintf(port, 255, CHANSRV_PORT_OUT_STR, g_display_num); g_audio_l_trans_out->trans_conn_in = sound_sndsrvr_sink_conn_in; if (trans_listen(g_audio_l_trans_out, port) != 0) LOG(0, ("trans_listen failed")); return 0; } xrdp-0.9.5/sesman/chansrv/clipboard_file.h000644 001751 001751 00000002444 13174271344 020475 0ustar00metameta000000 000000 /** * xrdp: A Remote Desktop Protocol server. * * Copyright (C) Jay Sorg 2012 * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ #if !defined(CLIPBOARD_FILE_H) #define CLIPBOARD_FILE_H #include "arch.h" #include "parse.h" int clipboard_send_data_response_for_file(const char *data, int data_size); int clipboard_process_file_request(struct stream *s, int clip_msg_status, int clip_msg_len); int clipboard_process_file_response(struct stream *s, int clip_msg_status, int clip_msg_len); int clipboard_c2s_in_files(struct stream *s, char *file_list); int clipboard_request_file_size(int stream_id, int lindex); int clipboard_request_file_data(int stream_id, int lindex, int offset, int request_bytes); #endif xrdp-0.9.5/sesman/chansrv/chansrv.c000644 001751 001751 00000126546 13220727201 017176 0ustar00metameta000000 000000 /** * xrdp: A Remote Desktop Protocol server. * * Copyright (C) Jay Sorg 2009-2013 * Copyright (C) Laxmikant Rashinkar 2009-2012 * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ #if defined(HAVE_CONFIG_H) #include #endif #include "arch.h" #include "os_calls.h" #include "thread_calls.h" #include "trans.h" #include "chansrv.h" #include "defines.h" #include "sound.h" #include "clipboard.h" #include "devredir.h" #include "list.h" #include "file.h" #include "log.h" #include "rail.h" #include "xcommon.h" #include "chansrv_fuse.h" #include "drdynvc.h" #include "xrdp_sockets.h" static struct trans *g_lis_trans = 0; static struct trans *g_con_trans = 0; static struct trans *g_api_lis_trans = 0; static struct list *g_api_con_trans_list = 0; /* list of apps using api functions */ static struct chan_item g_chan_items[32]; static int g_num_chan_items = 0; static int g_cliprdr_index = -1; static int g_rdpsnd_index = -1; static int g_rdpdr_index = -1; static int g_rail_index = -1; static int g_drdynvc_index = -1; /* state info for dynamic virtual channels */ static struct xrdp_api_data *g_dvc_channels[MAX_DVC_CHANNELS]; static tbus g_term_event = 0; static tbus g_thread_done_event = 0; static int g_use_unix_socket = 0; static const unsigned char g_xrdpapi_magic[12] = { 0x78, 0x32, 0x10, 0x67, 0x00, 0x92, 0x30, 0x56, 0xff, 0xd8, 0xa9, 0x1f }; int g_display_num = 0; int g_cliprdr_chan_id = -1; /* cliprdr */ int g_rdpsnd_chan_id = -1; /* rdpsnd */ int g_rdpdr_chan_id = -1; /* rdpdr */ int g_rail_chan_id = -1; /* rail */ int g_drdynvc_chan_id = -1; /* drdynvc */ char *g_exec_name; tbus g_exec_event; tbus g_exec_mutex; tbus g_exec_sem; int g_exec_pid = 0; #define ARRAYSIZE(x) (sizeof(x)/sizeof(*(x))) /* each time we create a DVC we need a unique DVC channel id */ /* this variable gets bumped up once per DVC we create */ tui32 g_dvc_chan_id = 100; struct timeout_obj { tui32 mstime; void *data; void (*callback)(void *data); struct timeout_obj *next; }; static struct timeout_obj *g_timeout_head = 0; static struct timeout_obj *g_timeout_tail = 0; /*****************************************************************************/ int add_timeout(int msoffset, void (*callback)(void *data), void *data) { struct timeout_obj *tobj; tui32 now; LOG(10, ("add_timeout:")); now = g_time3(); tobj = g_new0(struct timeout_obj, 1); tobj->mstime = now + msoffset; tobj->callback = callback; tobj->data = data; if (g_timeout_tail == 0) { g_timeout_head = tobj; g_timeout_tail = tobj; } else { g_timeout_tail->next = tobj; g_timeout_tail = tobj; } return 0; } /*****************************************************************************/ static int get_timeout(int *timeout) { struct timeout_obj *tobj; tui32 now; int ltimeout; LOG(10, ("get_timeout:")); ltimeout = *timeout; if (ltimeout < 1) { ltimeout = 0; } tobj = g_timeout_head; if (tobj != 0) { now = g_time3(); while (tobj != 0) { LOG(10, (" now %u tobj->mstime %u", now, tobj->mstime)); if (now < tobj->mstime) { ltimeout = tobj->mstime - now; } tobj = tobj->next; } } if (ltimeout > 0) { LOG(10, (" ltimeout %d", ltimeout)); if (*timeout < 1) { *timeout = ltimeout; } else { if (*timeout > ltimeout) { *timeout = ltimeout; } } } return 0; } /*****************************************************************************/ static int check_timeout(void) { struct timeout_obj *tobj; struct timeout_obj *last_tobj; struct timeout_obj *temp_tobj; int count; tui32 now; LOG(10, ("check_timeout:")); count = 0; tobj = g_timeout_head; if (tobj != 0) { last_tobj = 0; while (tobj != 0) { count++; now = g_time3(); if (now >= tobj->mstime) { tobj->callback(tobj->data); if (last_tobj == 0) { g_timeout_head = tobj->next; if (g_timeout_head == 0) { g_timeout_tail = 0; } } else { last_tobj->next = tobj->next; if (g_timeout_tail == tobj) { g_timeout_tail = last_tobj; } } temp_tobj = tobj; tobj = tobj->next; g_free(temp_tobj); } else { last_tobj = tobj; tobj = tobj->next; } } } LOG(10, (" count %d", count)); return 0; } /*****************************************************************************/ int g_is_term(void) { return g_is_wait_obj_set(g_term_event); } /*****************************************************************************/ /* add data to chan_item, on its way to the client */ /* returns error */ static int add_data_to_chan_item(struct chan_item *chan_item, char *data, int size) { struct stream *s; struct chan_out_data *cod; make_stream(s); init_stream(s, size); g_memcpy(s->data, data, size); s->end = s->data + size; cod = (struct chan_out_data *)g_malloc(sizeof(struct chan_out_data), 1); cod->s = s; if (chan_item->tail == 0) { chan_item->tail = cod; chan_item->head = cod; } else { chan_item->tail->next = cod; chan_item->tail = cod; } return 0; } /*****************************************************************************/ /* returns error */ static int send_data_from_chan_item(struct chan_item *chan_item) { struct stream *s; struct chan_out_data *cod; int bytes_left; int size; int chan_flags; int error; if (chan_item->head == 0) { return 0; } cod = chan_item->head; bytes_left = (int)(cod->s->end - cod->s->p); size = MIN(1600, bytes_left); chan_flags = 0; if (cod->s->p == cod->s->data) { chan_flags |= 1; /* first */ } if (cod->s->p + size >= cod->s->end) { chan_flags |= 2; /* last */ } s = trans_get_out_s(g_con_trans, 8192); out_uint32_le(s, 0); /* version */ out_uint32_le(s, 8 + 8 + 2 + 2 + 2 + 4 + size); /* size */ out_uint32_le(s, 8); /* msg id */ out_uint32_le(s, 8 + 2 + 2 + 2 + 4 + size); /* size */ out_uint16_le(s, chan_item->id); out_uint16_le(s, chan_flags); out_uint16_le(s, size); out_uint32_le(s, cod->s->size); out_uint8a(s, cod->s->p, size); s_mark_end(s); LOGM((LOG_LEVEL_DEBUG, "chansrv::send_data_from_chan_item: -- " "size %d chan_flags 0x%8.8x", size, chan_flags)); error = trans_write_copy(g_con_trans); if (error != 0) { return 1; } cod->s->p += size; if (cod->s->p >= cod->s->end) { free_stream(cod->s); chan_item->head = chan_item->head->next; if (chan_item->head == 0) { chan_item->tail = 0; } g_free(cod); } return 0; } /*****************************************************************************/ /* returns error */ static int check_chan_items(void) { int index; for (index = 0; index < g_num_chan_items; index++) { if (g_chan_items[index].head != 0) { send_data_from_chan_item(g_chan_items + index); } } return 0; } /*****************************************************************************/ /* returns error */ int send_channel_data(int chan_id, char *data, int size) { int index; //g_writeln("send_channel_data chan_id %d size %d", chan_id, size); LOGM((LOG_LEVEL_DEBUG, "chansrv::send_channel_data: size %d", size)); if (chan_id == -1) { g_writeln("send_channel_data: error, chan_id is -1"); return 1; } for (index = 0; index < g_num_chan_items; index++) { if (g_chan_items[index].id == chan_id) { add_data_to_chan_item(g_chan_items + index, data, size); check_chan_items(); return 0; } } return 1; } /*****************************************************************************/ /* returns error */ int send_rail_drawing_orders(char* data, int size) { LOGM((LOG_LEVEL_DEBUG, "chansrv::send_rail_drawing_orders: size %d", size)); struct stream* s; int error; s = trans_get_out_s(g_con_trans, 8192); out_uint32_le(s, 0); /* version */ out_uint32_le(s, 8 + 8 + size); /* size */ out_uint32_le(s, 10); /* msg id */ out_uint32_le(s, 8 + size); /* size */ out_uint8a(s, data, size); s_mark_end(s); error = trans_force_write(g_con_trans); if (error != 0) { return 1; } return 0; } /*****************************************************************************/ /* returns error */ static int send_init_response_message(void) { struct stream *s = (struct stream *)NULL; LOGM((LOG_LEVEL_INFO, "send_init_response_message:")); s = trans_get_out_s(g_con_trans, 8192); if (s == 0) { return 1; } out_uint32_le(s, 0); /* version */ out_uint32_le(s, 8 + 8); /* size */ out_uint32_le(s, 2); /* msg id */ out_uint32_le(s, 8); /* size */ s_mark_end(s); return trans_write_copy(g_con_trans); } /*****************************************************************************/ /* returns error */ static int send_channel_setup_response_message(void) { struct stream *s = (struct stream *)NULL; LOGM((LOG_LEVEL_DEBUG, "send_channel_setup_response_message:")); s = trans_get_out_s(g_con_trans, 8192); if (s == 0) { return 1; } out_uint32_le(s, 0); /* version */ out_uint32_le(s, 8 + 8); /* size */ out_uint32_le(s, 4); /* msg id */ out_uint32_le(s, 8); /* size */ s_mark_end(s); return trans_write_copy(g_con_trans); } /*****************************************************************************/ /* returns error */ static int send_channel_data_response_message(void) { struct stream *s = (struct stream *)NULL; LOGM((LOG_LEVEL_DEBUG, "send_channel_data_response_message:")); s = trans_get_out_s(g_con_trans, 8192); if (s == 0) { return 1; } out_uint32_le(s, 0); /* version */ out_uint32_le(s, 8 + 8); /* size */ out_uint32_le(s, 6); /* msg id */ out_uint32_le(s, 8); /* size */ s_mark_end(s); return trans_write_copy(g_con_trans); } /*****************************************************************************/ /* returns error */ static int process_message_init(struct stream *s) { LOGM((LOG_LEVEL_DEBUG, "process_message_init:")); return send_init_response_message(); } /*****************************************************************************/ /* returns error */ static int process_message_channel_setup(struct stream *s) { int num_chans; int index; int rv; struct chan_item *ci; struct chan_out_data *cod; struct chan_out_data *old_cod; g_num_chan_items = 0; g_cliprdr_index = -1; g_rdpsnd_index = -1; g_rdpdr_index = -1; g_rail_index = -1; g_cliprdr_chan_id = -1; g_rdpsnd_chan_id = -1; g_rdpdr_chan_id = -1; g_rail_chan_id = -1; g_drdynvc_chan_id = -1; LOGM((LOG_LEVEL_DEBUG, "process_message_channel_setup:")); in_uint16_le(s, num_chans); LOGM((LOG_LEVEL_DEBUG, "process_message_channel_setup: num_chans %d", num_chans)); for (index = 0; index < num_chans; index++) { ci = &(g_chan_items[g_num_chan_items]); g_memset(ci->name, 0, sizeof(ci->name)); in_uint8a(s, ci->name, 8); in_uint16_le(s, ci->id); /* there might be leftover data from last session after reconnecting so free it */ if (ci->head != 0) { cod = ci->head; while (1) { free_stream(cod->s); old_cod = cod; cod = cod->next; g_free(old_cod); if (ci->tail == old_cod) { break; } } } ci->head = 0; ci->tail = 0; in_uint16_le(s, ci->flags); LOGM((LOG_LEVEL_DEBUG, "process_message_channel_setup: chan name '%s' " "id %d flags %8.8x", ci->name, ci->id, ci->flags)); g_writeln("process_message_channel_setup: chan name '%s' " "id %d flags %8.8x", ci->name, ci->id, ci->flags); if (g_strcasecmp(ci->name, "cliprdr") == 0) { g_cliprdr_index = g_num_chan_items; g_cliprdr_chan_id = ci->id; } else if (g_strcasecmp(ci->name, "rdpsnd") == 0) { g_rdpsnd_index = g_num_chan_items; g_rdpsnd_chan_id = ci->id; } else if (g_strcasecmp(ci->name, "rdpdr") == 0) { g_rdpdr_index = g_num_chan_items; g_rdpdr_chan_id = ci->id; } /* disabled for now */ else if (g_strcasecmp(ci->name, "rail") == 0) { g_rail_index = g_num_chan_items; g_rail_chan_id = ci->id; } else if (g_strcasecmp(ci->name, "drdynvc") == 0) { g_drdynvc_index = g_num_chan_items; // LK_TODO use this g_drdynvc_chan_id = ci->id; // LK_TODO use this } else { LOG(10, ("other %s", ci->name)); } g_num_chan_items++; } rv = send_channel_setup_response_message(); if (g_cliprdr_index >= 0) { clipboard_init(); xfuse_init(); } if (g_rdpsnd_index >= 0) { sound_init(); } if (g_rdpdr_index >= 0) { dev_redir_init(); xfuse_init(); } if (g_rail_index >= 0) { rail_init(); } if (g_drdynvc_index >= 0) { g_memset(&g_dvc_channels[0], 0, sizeof(g_dvc_channels)); drdynvc_init(); } return rv; } /*****************************************************************************/ /* returns error */ static int process_message_channel_data(struct stream *s) { int chan_id = 0; int chan_flags = 0; int rv = 0; int length = 0; int total_length = 0; int index; struct stream *ls; struct trans *ltran; struct xrdp_api_data *api_data; in_uint16_le(s, chan_id); in_uint16_le(s, chan_flags); in_uint16_le(s, length); in_uint32_le(s, total_length); LOGM((LOG_LEVEL_DEBUG, "process_message_channel_data: chan_id %d " "chan_flags %d", chan_id, chan_flags)); LOG(10, ("process_message_channel_data")); rv = send_channel_data_response_message(); if (rv == 0) { if (chan_id == g_cliprdr_chan_id) { rv = clipboard_data_in(s, chan_id, chan_flags, length, total_length); } else if (chan_id == g_rdpsnd_chan_id) { rv = sound_data_in(s, chan_id, chan_flags, length, total_length); } else if (chan_id == g_rdpdr_chan_id) { rv = dev_redir_data_in(s, chan_id, chan_flags, length, total_length); } else if (chan_id == g_rail_chan_id) { rv = rail_data_in(s, chan_id, chan_flags, length, total_length); } else if (chan_id == g_drdynvc_chan_id) { rv = drdynvc_data_in(s, chan_id, chan_flags, length, total_length); } else if (g_api_con_trans_list != 0) { for (index = 0; index < g_api_con_trans_list->count; index++) { ltran = (struct trans *) list_get_item(g_api_con_trans_list, index); if (ltran != 0) { api_data = (struct xrdp_api_data *) (ltran->callback_data); if (api_data != 0) { if (api_data->chan_id == chan_id) { ls = ltran->out_s; if (chan_flags & 1) /* first */ { init_stream(ls, total_length); } out_uint8a(ls, s->p, length); if (chan_flags & 2) /* last */ { s_mark_end(ls); rv = trans_force_write(ltran); } break; } } } } } } return rv; } /*****************************************************************************/ /* returns error */ static int process_message_channel_data_response(struct stream *s) { LOG(10, ("process_message_channel_data_response:")); check_chan_items(); return 0; } /*****************************************************************************/ /* returns error */ static int process_message(void) { struct stream *s = (struct stream *)NULL; int size = 0; int id = 0; int rv = 0; char *next_msg = (char *)NULL; if (g_con_trans == 0) { return 1; } s = trans_get_in_s(g_con_trans); if (s == 0) { return 1; } rv = 0; while (s_check_rem(s, 8)) { next_msg = s->p; in_uint32_le(s, id); in_uint32_le(s, size); next_msg += size; switch (id) { case 1: /* init */ rv = process_message_init(s); break; case 3: /* channel setup */ rv = process_message_channel_setup(s); break; case 5: /* channel data */ rv = process_message_channel_data(s); break; case 7: /* channel data response */ rv = process_message_channel_data_response(s); break; default: LOGM((LOG_LEVEL_ERROR, "process_message: unknown msg %d", id)); break; } if (rv != 0) { break; } s->p = next_msg; } return rv; } /*****************************************************************************/ /* returns error */ int my_trans_data_in(struct trans *trans) { struct stream *s = (struct stream *)NULL; int size = 0; int error = 0; if (trans == 0) { return 0; } if (trans != g_con_trans) { return 1; } LOGM((LOG_LEVEL_DEBUG, "my_trans_data_in:")); s = trans_get_in_s(trans); in_uint8s(s, 4); /* id */ in_uint32_le(s, size); error = trans_force_read(trans, size - 8); if (error == 0) { /* here, the entire message block is read in, process it */ error = process_message(); } return error; } /* * called when WTSVirtualChannelWrite() is invoked in xrdpapi.c * ******************************************************************************/ int my_api_trans_data_in(struct trans *trans) { struct stream *s; int bytes_read; int i32; struct xrdp_api_data *ad; //g_writeln("my_api_trans_data_in:"); LOG(10, ("my_api_trans_data_in:")); if (trans == 0) { return 0; } if (g_api_con_trans_list != 0) { if (list_index_of(g_api_con_trans_list, (tintptr) trans) == -1) { return 1; } } LOGM((LOG_LEVEL_DEBUG, "my_api_trans_data_in:")); s = trans_get_in_s(trans); bytes_read = g_tcp_recv(trans->sck, s->data, 16, 0); if (bytes_read == 16) { if (g_memcmp(s->data, g_xrdpapi_magic, 12) == 0) { in_uint8s(s, 12); in_uint32_le(s, bytes_read); init_stream(s, bytes_read); if (trans_force_read(trans, bytes_read)) log_message(LOG_LEVEL_ERROR, "chansrv.c: error reading from transport"); } else if (g_tcp_select(trans->sck, 0) & 1) { i32 = bytes_read; bytes_read = g_tcp_recv(trans->sck, s->data + bytes_read, 8192 * 4 - bytes_read, 0); if (bytes_read > 0) { bytes_read += i32; } } } //g_writeln("bytes_read %d", bytes_read); if (bytes_read > 0) { LOG(10, ("my_api_trans_data_in: got data %d", bytes_read)); ad = (struct xrdp_api_data *) trans->callback_data; if (ad->dvc_chan_id < 0) { /* writing data to a static virtual channel */ if (send_channel_data(ad->chan_id, s->data, bytes_read) != 0) { LOG(0, ("my_api_trans_data_in: send_channel_data failed")); } } else { /* writing data to a dynamic virtual channel */ drdynvc_write_data(ad->dvc_chan_id, s->data, bytes_read); } } else { ad = (struct xrdp_api_data *) (trans->callback_data); if ((ad != NULL) && (ad->dvc_chan_id > 0)) { /* WTSVirtualChannelClose() was invoked, or connection dropped */ LOG(10, ("my_api_trans_data_in: g_tcp_recv failed or disconnected for DVC")); ad->transp = NULL; ad->is_connected = 0; remove_struct_with_chan_id(ad->dvc_chan_id); } else { LOG(10, ("my_api_trans_data_in: g_tcp_recv failed or disconnected for SVC")); } return 1; } return 0; } /*****************************************************************************/ int my_trans_conn_in(struct trans *trans, struct trans *new_trans) { if (trans == 0) { return 1; } if (trans != g_lis_trans) { return 1; } if (g_con_trans != 0) /* if already set, error */ { return 1; } if (new_trans == 0) { return 1; } LOGM((LOG_LEVEL_DEBUG, "my_trans_conn_in:")); g_con_trans = new_trans; g_con_trans->trans_data_in = my_trans_data_in; g_con_trans->header_size = 8; /* stop listening */ trans_delete(g_lis_trans); g_lis_trans = 0; return 0; } /* * called when WTSVirtualChannelOpenEx is invoked in xrdpapi.c * ******************************************************************************/ int my_api_trans_conn_in(struct trans *trans, struct trans *new_trans) { struct xrdp_api_data *ad; struct stream *s; int error; int index; char chan_pri; if ((trans == 0) || (trans != g_api_lis_trans) || (new_trans == 0)) { return 1; } LOGM((LOG_LEVEL_DEBUG, "my_api_trans_conn_in:")); LOG(10, ("my_api_trans_conn_in: got incoming")); s = trans_get_in_s(new_trans); s->end = s->data; error = trans_force_read(new_trans, 64); if (error != 0) { LOG(0, ("my_api_trans_conn_in: trans_force_read failed")); trans_delete(new_trans); return 1; } s->end = s->data; ad = (struct xrdp_api_data *) g_malloc(sizeof(struct xrdp_api_data), 1); g_memcpy(ad->header, s->data, 64); ad->flags = GGET_UINT32(ad->header, 16); ad->chan_id = -1; ad->dvc_chan_id = -1; if (ad->flags > 0) { /* opening a dynamic virtual channel */ if ((index = find_empty_slot_in_dvc_channels()) < 0) { /* exceeded MAX_DVC_CHANNELS */ LOG(0, ("my_api_trans_conn_in: MAX_DVC_CHANNELS reached; giving up!")) g_free(ad); trans_delete(new_trans); return 1; } g_dvc_channels[index] = ad; chan_pri = 4 - ad->flags; ad->dvc_chan_id = g_dvc_chan_id++; ad->is_connected = 0; ad->transp = new_trans; drdynvc_send_open_channel_request(chan_pri, ad->dvc_chan_id, ad->header); } else { /* opening a static virtual channel */ for (index = 0; index < g_num_chan_items; index++) { LOG(10, ("my_api_trans_conn_in: %s %s", ad->header, g_chan_items[index].name)); if (g_strcasecmp(ad->header, g_chan_items[index].name) == 0) { LOG(10, ("my_api_trans_conn_in: found it at %d", index)); ad->chan_id = g_chan_items[index].id; break; } } if (index == g_num_chan_items) { g_writeln("did not find SVC named %s", ad->header); } } new_trans->callback_data = ad; if (g_api_con_trans_list == 0) { g_api_con_trans_list = list_create(); } new_trans->trans_data_in = my_api_trans_data_in; new_trans->header_size = 0; list_add_item(g_api_con_trans_list, (tintptr) new_trans); return 0; } /*****************************************************************************/ static int setup_listen(void) { char port[256]; int error = 0; if (g_lis_trans != 0) { trans_delete(g_lis_trans); } if (g_use_unix_socket) { g_lis_trans = trans_create(TRANS_MODE_UNIX, 8192, 8192); g_lis_trans->is_term = g_is_term; g_snprintf(port, 255, XRDP_CHANSRV_STR, g_display_num); } else { g_lis_trans = trans_create(TRANS_MODE_TCP, 8192, 8192); g_lis_trans->is_term = g_is_term; g_snprintf(port, 255, "%d", 7200 + g_display_num); } g_lis_trans->trans_conn_in = my_trans_conn_in; error = trans_listen(g_lis_trans, port); if (error != 0) { LOGM((LOG_LEVEL_ERROR, "setup_listen: trans_listen failed for port %s", port)); return 1; } return 0; } /*****************************************************************************/ static int setup_api_listen(void) { char port[256]; int error = 0; g_api_lis_trans = trans_create(TRANS_MODE_UNIX, 8192 * 4, 8192 * 4); g_api_lis_trans->is_term = g_is_term; g_snprintf(port, 255, CHANSRV_API_STR, g_display_num); g_api_lis_trans->trans_conn_in = my_api_trans_conn_in; error = trans_listen(g_api_lis_trans, port); if (error != 0) { LOGM((LOG_LEVEL_ERROR, "setup_api_listen: trans_listen failed for port %s", port)); return 1; } return 0; } /*****************************************************************************/ THREAD_RV THREAD_CC channel_thread_loop(void *in_val) { tbus objs[32]; tbus wobjs[32]; int num_objs; int num_wobjs; int timeout; int error; int index; THREAD_RV rv; struct trans *ltran; LOGM((LOG_LEVEL_INFO, "channel_thread_loop: thread start")); rv = 0; setup_api_listen(); error = setup_listen(); if (error == 0) { timeout = -1; num_objs = 0; num_wobjs = 0; objs[num_objs] = g_term_event; num_objs++; trans_get_wait_objs(g_lis_trans, objs, &num_objs); trans_get_wait_objs(g_api_lis_trans, objs, &num_objs); while (g_obj_wait(objs, num_objs, wobjs, num_wobjs, timeout) == 0) { check_timeout(); if (g_is_wait_obj_set(g_term_event)) { LOGM((LOG_LEVEL_INFO, "channel_thread_loop: g_term_event set")); clipboard_deinit(); sound_deinit(); dev_redir_deinit(); rail_deinit(); break; } if (g_lis_trans != 0) { if (trans_check_wait_objs(g_lis_trans) != 0) { LOGM((LOG_LEVEL_INFO, "channel_thread_loop: " "trans_check_wait_objs error")); } } if (g_con_trans != 0) { if (trans_check_wait_objs(g_con_trans) != 0) { LOGM((LOG_LEVEL_INFO, "channel_thread_loop: " "trans_check_wait_objs error resetting")); clipboard_deinit(); sound_deinit(); dev_redir_deinit(); rail_deinit(); /* delete g_con_trans */ trans_delete(g_con_trans); g_con_trans = 0; /* create new listener */ error = setup_listen(); if (error != 0) { break; } } } if (g_api_lis_trans != 0) { if (trans_check_wait_objs(g_api_lis_trans) != 0) { LOG(0, ("channel_thread_loop: trans_check_wait_objs failed")); } } if (g_api_con_trans_list != 0) { for (index = g_api_con_trans_list->count - 1; index >= 0; index--) { ltran = (struct trans *) list_get_item(g_api_con_trans_list, index); if (ltran != 0) { if (trans_check_wait_objs(ltran) != 0) { list_remove_item(g_api_con_trans_list, index); g_free(ltran->callback_data); trans_delete(ltran); } } } } xcommon_check_wait_objs(); sound_check_wait_objs(); dev_redir_check_wait_objs(); xfuse_check_wait_objs(); timeout = -1; num_objs = 0; num_wobjs = 0; objs[num_objs] = g_term_event; num_objs++; trans_get_wait_objs(g_lis_trans, objs, &num_objs); trans_get_wait_objs_rw(g_con_trans, objs, &num_objs, wobjs, &num_wobjs, &timeout); trans_get_wait_objs(g_api_lis_trans, objs, &num_objs); if (g_api_con_trans_list != 0) { for (index = g_api_con_trans_list->count - 1; index >= 0; index--) { ltran = (struct trans *) list_get_item(g_api_con_trans_list, index); if (ltran != 0) { trans_get_wait_objs(ltran, objs, &num_objs); } } } xcommon_get_wait_objs(objs, &num_objs, &timeout); sound_get_wait_objs(objs, &num_objs, &timeout); dev_redir_get_wait_objs(objs, &num_objs, &timeout); xfuse_get_wait_objs(objs, &num_objs, &timeout); get_timeout(&timeout); } /* end while (g_obj_wait(objs, num_objs, 0, 0, timeout) == 0) */ } trans_delete(g_lis_trans); g_lis_trans = 0; trans_delete(g_con_trans); g_con_trans = 0; trans_delete(g_api_lis_trans); g_api_lis_trans = 0; if (g_api_con_trans_list != 0) { for (index = g_api_con_trans_list->count - 1; index >= 0; index--) { ltran = (struct trans *) list_get_item(g_api_con_trans_list, index); if (ltran != 0) { list_remove_item(g_api_con_trans_list, index); g_free(ltran->callback_data); trans_delete(ltran); } } list_delete(g_api_con_trans_list); } LOGM((LOG_LEVEL_INFO, "channel_thread_loop: thread stop")); g_set_wait_obj(g_thread_done_event); return rv; } /*****************************************************************************/ void term_signal_handler(int sig) { LOGM((LOG_LEVEL_INFO, "term_signal_handler: got signal %d", sig)); g_set_wait_obj(g_term_event); } /*****************************************************************************/ void nil_signal_handler(int sig) { LOGM((LOG_LEVEL_INFO, "nil_signal_handler: got signal %d", sig)); } /*****************************************************************************/ void child_signal_handler(int sig) { int pid; LOG(0, ("child_signal_handler:")); do { pid = g_waitchild(); LOG(0, ("child_signal_handler: child pid %d", pid)); if ((pid == g_exec_pid) && (pid > 0)) { LOG(0, ("child_signal_handler: found pid %d", pid)); //shutdownx(); } } while (pid >= 0); } /*****************************************************************************/ void segfault_signal_handler(int sig) { LOG(0, ("segfault_signal_handler: entered.......")); xfuse_deinit(); exit(0); } /*****************************************************************************/ static int get_display_num_from_display(char *display_text) { int index; int mode; int host_index; int disp_index; int scre_index; char host[256]; char disp[256]; char scre[256]; g_memset(host, 0, 256); g_memset(disp, 0, 256); g_memset(scre, 0, 256); index = 0; host_index = 0; disp_index = 0; scre_index = 0; mode = 0; while (display_text[index] != 0) { if (display_text[index] == ':') { mode = 1; } else if (display_text[index] == '.') { mode = 2; } else if (mode == 0) { host[host_index] = display_text[index]; host_index++; } else if (mode == 1) { disp[disp_index] = display_text[index]; disp_index++; } else if (mode == 2) { scre[scre_index] = display_text[index]; scre_index++; } index++; } host[host_index] = 0; disp[disp_index] = 0; scre[scre_index] = 0; g_display_num = g_atoi(disp); return 0; } /*****************************************************************************/ int main_cleanup(void) { g_delete_wait_obj(g_term_event); g_delete_wait_obj(g_thread_done_event); g_delete_wait_obj(g_exec_event); tc_mutex_delete(g_exec_mutex); g_deinit(); /* os_calls */ return 0; } /*****************************************************************************/ static int read_ini(void) { char filename[256]; struct list *names; struct list *values; char *name; char *value; int index; g_memset(filename, 0, (sizeof(char) * 256)); names = list_create(); names->auto_free = 1; values = list_create(); values->auto_free = 1; g_use_unix_socket = 0; g_snprintf(filename, 255, "%s/sesman.ini", XRDP_CFG_PATH); if (file_by_name_read_section(filename, "Globals", names, values) == 0) { for (index = 0; index < names->count; index++) { name = (char *)list_get_item(names, index); value = (char *)list_get_item(values, index); if (g_strcasecmp(name, "ListenAddress") == 0) { if (g_strcasecmp(value, "127.0.0.1") == 0) { g_use_unix_socket = 1; } } } } list_delete(names); list_delete(values); return 0; } /*****************************************************************************/ static int get_log_path(char *path, int bytes) { char* log_path; int rv; rv = 1; log_path = g_getenv("CHANSRV_LOG_PATH"); if (log_path == 0) { log_path = g_getenv("XDG_DATA_HOME"); if (log_path != 0) { g_snprintf(path, bytes, "%s%s", log_path, "/xrdp"); if (g_directory_exist(path) || (g_mkdir(path) == 0)) { rv = 0; } } } else { g_snprintf(path, bytes, "%s", log_path); if (g_directory_exist(path) || (g_mkdir(path) == 0)) { rv = 0; } } if (rv != 0) { log_path = g_getenv("HOME"); if (log_path != 0) { g_snprintf(path, bytes, "%s%s", log_path, "/.local"); if (g_directory_exist(path) || (g_mkdir(path) == 0)) { g_snprintf(path, bytes, "%s%s", log_path, "/.local/share"); if (g_directory_exist(path) || (g_mkdir(path) == 0)) { g_snprintf(path, bytes, "%s%s", log_path, "/.local/share/xrdp"); if (g_directory_exist(path) || (g_mkdir(path) == 0)) { rv = 0; } } } } } return rv; } /*****************************************************************************/ static enum logLevels get_log_level(const char* level_str, enum logLevels default_level) { static const char* levels[] = { "LOG_LEVEL_ALWAYS", "LOG_LEVEL_ERROR", "LOG_LEVEL_WARNING", "LOG_LEVEL_INFO", "LOG_LEVEL_DEBUG", "LOG_LEVEL_TRACE" }; unsigned int i; if (level_str == NULL || level_str[0] == 0) { return default_level; } for (i = 0; i < ARRAYSIZE(levels); ++i) { if (g_strcasecmp(levels[i], level_str) == 0) { return (enum logLevels) i; } } return default_level; } /*****************************************************************************/ static int run_exec(void) { int pid; LOG(10, ("run_exec:")); pid = g_fork(); if (pid == 0) { trans_delete(g_con_trans); g_close_wait_obj(g_term_event); g_close_wait_obj(g_thread_done_event); g_close_wait_obj(g_exec_event); tc_mutex_delete(g_exec_mutex); tc_sem_delete(g_exec_sem); g_execlp3(g_exec_name, g_exec_name, 0); g_exit(0); } g_exec_pid = pid; tc_sem_inc(g_exec_sem); return 0; } /*****************************************************************************/ int main(int argc, char **argv) { tbus waiters[4]; int pid = 0; char text[256]; char log_path[256]; char *display_text; char log_file[256]; enum logReturns error; struct log_config logconfig; enum logLevels log_level; g_init("xrdp-chansrv"); /* os_calls */ log_path[255] = 0; if (get_log_path(log_path, 255) != 0) { g_writeln("error reading CHANSRV_LOG_PATH and HOME environment variable"); g_deinit(); return 1; } read_ini(); pid = g_getpid(); display_text = g_getenv("DISPLAY"); if (display_text) get_display_num_from_display(display_text); log_level = get_log_level(g_getenv("CHANSRV_LOG_LEVEL"), LOG_LEVEL_INFO); /* starting logging subsystem */ g_memset(&logconfig, 0, sizeof(struct log_config)); logconfig.program_name = "xrdp-chansrv"; g_snprintf(log_file, 255, "%s/xrdp-chansrv.%d.log", log_path, g_display_num); g_writeln("chansrv::main: using log file [%s]", log_file); if (g_file_exist(log_file)) { g_file_delete(log_file); } logconfig.log_file = log_file; logconfig.fd = -1; logconfig.log_level = log_level; logconfig.enable_syslog = 0; logconfig.syslog_level = LOG_LEVEL_ALWAYS; error = log_start_from_param(&logconfig); if (error != LOG_STARTUP_OK) { switch (error) { case LOG_ERROR_MALLOC: g_writeln("error on malloc. cannot start logging. quitting."); break; case LOG_ERROR_FILE_OPEN: g_writeln("error opening log file [%s]. quitting.", getLogFile(text, 255)); break; default: g_writeln("log_start error"); break; } g_deinit(); return 1; } LOGM((LOG_LEVEL_ALWAYS, "main: app started pid %d(0x%8.8x)", pid, pid)); /* set up signal handler */ g_signal_terminate(term_signal_handler); /* SIGTERM */ g_signal_user_interrupt(term_signal_handler); /* SIGINT */ g_signal_pipe(nil_signal_handler); /* SIGPIPE */ g_signal_child_stop(child_signal_handler); /* SIGCHLD */ g_signal_segfault(segfault_signal_handler); LOGM((LOG_LEVEL_INFO, "main: DISPLAY env var set to %s", display_text)); if (g_display_num == 0) { LOGM((LOG_LEVEL_ERROR, "main: error, display is zero")); g_deinit(); return 1; } LOGM((LOG_LEVEL_INFO, "main: using DISPLAY %d", g_display_num)); g_snprintf(text, 255, "xrdp_chansrv_%8.8x_main_term", pid); g_term_event = g_create_wait_obj(text); g_snprintf(text, 255, "xrdp_chansrv_%8.8x_thread_done", pid); g_thread_done_event = g_create_wait_obj(text); g_snprintf(text, 255, "xrdp_chansrv_%8.8x_exec", pid); g_exec_event = g_create_wait_obj(text); g_exec_mutex = tc_mutex_create(); g_exec_sem = tc_sem_create(0); tc_thread_create(channel_thread_loop, 0); while (g_term_event > 0 && !g_is_wait_obj_set(g_term_event)) { waiters[0] = g_term_event; waiters[1] = g_exec_event; if (g_obj_wait(waiters, 2, 0, 0, 0) != 0) { LOGM((LOG_LEVEL_ERROR, "main: error, g_obj_wait failed")); break; } if (g_is_wait_obj_set(g_term_event)) { break; } if (g_is_wait_obj_set(g_exec_event)) { g_reset_wait_obj(g_exec_event); run_exec(); } } while (g_thread_done_event > 0 && !g_is_wait_obj_set(g_thread_done_event)) { /* wait for thread to exit */ if (g_obj_wait(&g_thread_done_event, 1, 0, 0, 0) != 0) { LOGM((LOG_LEVEL_ERROR, "main: error, g_obj_wait failed")); break; } } /* cleanup */ main_cleanup(); LOGM((LOG_LEVEL_INFO, "main: app exiting pid %d(0x%8.8x)", pid, pid)); g_deinit(); return 0; } /* * return unused slot in dvc_channels[] * * @return unused slot index on success, -1 on failure ******************************************************************************/ int find_empty_slot_in_dvc_channels(void) { int i; for (i = 0; i < MAX_DVC_CHANNELS; i++) { if (g_dvc_channels[i] == NULL) { return i; } } return -1; } /* * return struct xrdp_api_data that contains specified dvc_chan_id * * @param dvc_chan_id channel id to look for * * @return xrdp_api_data struct containing dvc_chan_id or NULL on failure ******************************************************************************/ struct xrdp_api_data * struct_from_dvc_chan_id(tui32 dvc_chan_id) { int i; for (i = 0; i < MAX_DVC_CHANNELS; i++) { if (g_dvc_channels[i] != NULL && g_dvc_channels[i]->dvc_chan_id >= 0 && (tui32) g_dvc_channels[i]->dvc_chan_id == dvc_chan_id) { return g_dvc_channels[i]; } } return NULL; } int remove_struct_with_chan_id(tui32 dvc_chan_id) { int i; for (i = 0; i < MAX_DVC_CHANNELS; i++) { if (g_dvc_channels[i] != NULL && g_dvc_channels[i]->dvc_chan_id >= 0 && (tui32) g_dvc_channels[i]->dvc_chan_id == dvc_chan_id) { g_dvc_channels[i] = NULL; return 0; } } return -1; } xrdp-0.9.5/sesman/chansrv/Makefile.am000644 001751 001751 00000002732 13206666623 017426 0ustar00metameta000000 000000 EXTRA_DIST = \ clipboard-notes.txt \ pcsc \ pulse \ wave-format-server.txt AM_CPPFLAGS = \ -DXRDP_CFG_PATH=\"${sysconfdir}/xrdp\" \ -DXRDP_SBIN_PATH=\"${sbindir}\" \ -DXRDP_SHARE_PATH=\"${datadir}/xrdp\" \ -DXRDP_PID_PATH=\"${localstatedir}/run\" \ -DXRDP_SOCKET_PATH=\"${socketdir}\" \ -I$(top_srcdir)/common if XRDP_DEBUG AM_CPPFLAGS += -DXRDP_DEBUG endif CHANSRV_EXTRA_LIBS = if XRDP_FUSE AM_CPPFLAGS += -DXRDP_FUSE $(FUSE_CFLAGS) CHANSRV_EXTRA_LIBS += $(FUSE_LIBS) endif if XRDP_FDK_AAC AM_CPPFLAGS += -DXRDP_FDK_AAC $(FDKAAC_CFLAGS) CHANSRV_EXTRA_LIBS += $(FDKAAC_LIBS) endif if XRDP_OPUS AM_CPPFLAGS += -DXRDP_OPUS CHANSRV_EXTRA_LIBS += -lopus endif if XRDP_MP3LAME AM_CPPFLAGS += -DXRDP_MP3LAME CHANSRV_EXTRA_LIBS += -lmp3lame endif AM_CFLAGS = $(X_CFLAGS) sbin_PROGRAMS = \ xrdp-chansrv xrdp_chansrv_SOURCES = \ chansrv.c \ chansrv.h \ chansrv_common.c \ chansrv_common.h \ chansrv_fuse.c \ chansrv_fuse.h \ clipboard.c \ clipboard.h \ clipboard_common.h \ clipboard_file.c \ clipboard_file.h \ devredir.c \ devredir.h \ drdynvc.c \ drdynvc.h \ fifo.c \ fifo.h \ irp.c \ irp.h \ mlog.h \ rail.c \ rail.h \ smartcard.c \ smartcard.h \ smartcard_pcsc.c \ smartcard_pcsc.h \ sound.c \ sound.h \ xcommon.c \ xcommon.h xrdp_chansrv_LDFLAGS = \ $(X_LIBS) xrdp_chansrv_LDADD = \ $(top_builddir)/common/libcommon.la \ $(X_PRE_LIBS) -lXfixes -lXrandr -lX11 $(X_EXTRA_LIBS) \ $(CHANSRV_EXTRA_LIBS) xrdp-0.9.5/sesman/chansrv/chansrv_common.c000644 001751 001751 00000004042 13174271344 020542 0ustar00metameta000000 000000 /** * xrdp: A Remote Desktop Protocol server. * * Copyright (C) Laxmikant Rashinkar 2009-2014 * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ #if defined(HAVE_CONFIG_H) #include #endif #include "chansrv_common.h" /** * Assemble fragmented incoming packets into one stream * * @param src stream that contains partial data * @param dest stream that contains entire data * @param chan_flags fragmentation flags * @param length bytes in this packet * @param total_length total length of assembled packet * * @return 1 when all data has been assembled, 0 otherwise * * NOTE: it is the responsibility of the caller to free dest stream ****************************************************************************/ int read_entire_packet(struct stream *src, struct stream **dest, int chan_flags, int length, int total_length) { struct stream *ls; if ((chan_flags & 3) == 3) { /* packet not fragmented */ xstream_new(ls, total_length); xstream_copyin(ls, src->p, length); ls->p = ls->data; *dest = ls; return 1; } /* is this the first fragmented packet? */ if (chan_flags & 1) { xstream_new(ls, total_length); *dest = ls; } else { ls = *dest; } xstream_copyin(ls, src->p, length); /* in last packet, chan_flags & 0x02 will be true */ if (chan_flags & 0x02) { /* rewind stream */ ls->p = ls->data; return 1; } return 0; } xrdp-0.9.5/sesman/chansrv/smartcard.c000644 001751 001751 00000224506 13213711022 017501 0ustar00metameta000000 000000 /** * xrdp: A Remote Desktop Protocol server. * * Copyright (C) Laxmikant Rashinkar 2013 LK.Rashinkar@gmail.com * Copyright (C) Jay Sorg 2013 jay.sorg@gmail.com * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. * */ /* * smartcard redirection support */ #if defined(HAVE_CONFIG_H) #include #endif #include #include "os_calls.h" #include "smartcard.h" #include "log.h" #include "irp.h" #include "devredir.h" #include "smartcard_pcsc.h" #include "chansrv.h" /* * TODO * * o ensure that all wide calls are handled correctly * * o need to query client for build number and determine whether we should use * SCREDIR_VERSION_XP or SCREDIR_VERSION_LONGHORN * * o need to call scard_release_resources() * * o why is win 7 sending SCARD_IOCTL_ACCESS_STARTED_EVENT first * 0000 00 01 00 00 04 00 00 00 e0 00 09 00 00 00 00 00 ................ * 0010 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 ................ * 0020 28 b7 9d 02 */ /* * Notes: * * XP and Server 2003 use version SCREDIR_VERSION_XP functions 5 - 58 * Vista and Server 2008 use version SCREDIR_VERSION_LONGHORN functions 5 - 64 * if TS Client's build number is >= 4,034 use SCREDIR_VERSION_LONGHORN */ /* module based logging */ #define LOG_ERROR 0 #define LOG_INFO 1 #define LOG_DEBUG 2 #undef LOG_LEVEL #define LOG_LEVEL LOG_INFO #define log_error(_params...) \ do \ { \ g_write("[%10.10u]: SMART_CARD %s: %d : ERROR: ", \ g_time3(), __func__, __LINE__); \ g_writeln (_params); \ } while (0) #define log_info(_params...) \ do \ { \ if (LOG_INFO <= LOG_LEVEL) \ { \ g_write("[%10.10u]: SMART_CARD %s: %d : ", \ g_time3(), __func__, __LINE__); \ g_writeln (_params); \ } \ } while (0) #define log_debug(_params...) \ do \ { \ if (LOG_DEBUG <= LOG_LEVEL) \ if (2 <= 1) \ { \ g_write("[%10.10u]: SMART_CARD %s: %d : ", \ g_time3(), __func__, __LINE__); \ g_writeln (_params); \ } \ } while (0) /* [MS-RDPESC] 3.1.4 */ #define SCARD_IOCTL_ESTABLISH_CONTEXT 0x00090014 /* EstablishContext */ #define SCARD_IOCTL_RELEASE_CONTEXT 0x00090018 /* ReleaseContext */ #define SCARD_IOCTL_IS_VALID_CONTEXT 0x0009001C /* IsValidContext */ #define SCARD_IOCTL_LIST_READER_GROUPS 0x00090020 /* ListReaderGroups */ #define SCARD_IOCTL_LIST_READERS_A 0x00090028 /* ListReaders ASCII */ #define SCARD_IOCTL_LIST_READERS_W 0x0009002C /* ListReaders Wide */ #define SCARD_IOCTL_INTRODUCE_READER_GROUP 0x00090050 /* IntroduceReaderGroup */ #define SCARD_IOCTL_FORGET_READER_GROUP 0x00090058 /* ForgetReader */ #define SCARD_IOCTL_INTRODUCE_READER 0x00090060 /* IntroduceReader */ #define SCARD_IOCTL_FORGET_READER 0x00090068 /* IntroduceReader */ #define SCARD_IOCTL_ADD_READER_TO_GROUP 0x00090070 /* AddReaderToGroup */ #define SCARD_IOCTL_REMOVE_READER_FROM_GROUP 0x00090078 /* RemoveReaderFromGroup*/ #define SCARD_IOCTL_GET_STATUS_CHANGE_A 0x000900A0 /* GetStatusChangeA */ #define SCARD_IOCTL_GET_STATUS_CHANGE_W 0x000900A4 /* GetStatusChangeW */ #define SCARD_IOCTL_CANCEL 0x000900A8 /* Cancel */ #define SCARD_IOCTL_CONNECT_A 0x000900AC /* ConnectA */ #define SCARD_IOCTL_CONNECT_W 0x000900B0 /* ConnectW */ #define SCARD_IOCTL_RECONNECT 0x000900B4 /* Reconnect */ #define SCARD_IOCTL_DISCONNECT 0x000900B8 /* Disconnect */ #define SCARD_IOCTL_BEGIN_TRANSACTION 0x000900BC /* BeginTransaction */ #define SCARD_IOCTL_END_TRANSACTION 0x000900C0 /* EndTransaction */ #define SCARD_IOCTL_STATE 0x000900C4 /* State */ #define SCARD_IOCTL_STATUS_A 0x000900C8 /* StatusA */ #define SCARD_IOCTL_STATUS_W 0x000900CC /* StatusW */ #define SCARD_IOCTL_TRANSMIT 0x000900D0 /* Transmit */ #define SCARD_IOCTL_CONTROL 0x000900D4 /* Control */ #define SCARD_IOCTL_GETATTRIB 0x000900D8 /* GetAttrib */ #define SCARD_IOCTL_SETATTRIB 0x000900DC /* SetAttrib */ #define SCARD_IOCTL_ACCESS_STARTED_EVENT 0x000900E0 /* SCardAccessStartedEvent */ #define SCARD_IOCTL_LOCATE_CARDS_BY_ATR 0x000900E8 /* LocateCardsByATR */ /* scope used in EstablishContextCall */ #define SCARD_SCOPE_USER 0x00000000 #define SCARD_SCOPE_TERMINAL 0x00000001 #define SCARD_SCOPE_SYSTEM 0x00000002 /* disposition - action to take on card */ #define SCARD_LEAVE_CARD 0x00000000 #define SCARD_RESET_CARD 0x00000001 #define SCARD_UNPOWER_CARD 0x00000002 #define SCARD_EJECT_CARD 0x00000003 #define MAX_SMARTCARDS 16 /* stores info about a smart card */ typedef struct smartcard { tui32 DeviceId; } SMARTCARD; /* globals */ SMARTCARD* smartcards[MAX_SMARTCARDS]; int g_smartcards_inited = 0; static tui32 g_device_id = 0; static int g_scard_index = 0; /* externs */ extern tui32 g_completion_id; extern int g_rdpdr_chan_id; /* in chansrv.c */ /****************************************************************************** ** static functions local to this file ** ******************************************************************************/ static struct stream * scard_make_new_ioctl(IRP *irp, tui32 ioctl); static int scard_add_new_device(tui32 device_id); static int scard_get_free_slot(void); static void scard_release_resources(void); static void scard_send_EstablishContext(IRP *irp, int scope); static void scard_send_ReleaseContext(IRP *irp, char *context, int context_bytes); static void scard_send_IsContextValid(IRP* irp, char *context, int context_bytes); static void scard_send_ListReaders(IRP *irp, char *context, int context_bytes, char *groups, int cchReaders, int wide); static void scard_send_GetStatusChange(IRP *irp, char *context, int context_bytes, int wide, tui32 timeout, tui32 num_readers, READER_STATE *rsa); static void scard_send_Connect(IRP *irp, char *context, int context_bytes, int wide, READER_STATE *rs); static void scard_send_Reconnect(IRP *irp, char *context, int context_bytes, char *card, int card_bytes, READER_STATE *rs); static void scard_send_BeginTransaction(IRP *irp, char *context, int context_bytes, char *card, int card_bytes); static void scard_send_EndTransaction(IRP *irp, char *context, int context_bytes, char *card, int card_bytes, tui32 dwDisposition); static void scard_send_Status(IRP *irp, int wide, char *context, int context_bytes, char *card, int card_bytes, int cchReaderLen, int cbAtrLen); static void scard_send_Disconnect(IRP *irp, char *context, int context_bytes, char *card, int card_bytes, int dwDisposition); static int scard_send_Transmit(IRP *irp, char *context, int context_byte, char *card, int card_bytes, char *send_data, int send_bytes, int recv_bytes, struct xrdp_scard_io_request *send_ior, struct xrdp_scard_io_request *recv_ior); static int scard_send_Control(IRP* irp, char *context, int context_bytes, char *card, int card_bytes, char *send_data, int send_bytes, int recv_bytes, int control_code); static int scard_send_Cancel(IRP *irp, char *context, int context_bytes); static int scard_send_GetAttrib(IRP *irp, char *card, int card_bytes, READER_STATE *rs); /****************************************************************************** ** local callbacks into this module ** ******************************************************************************/ static void scard_handle_EstablishContext_Return(struct stream *s, IRP *irp, tui32 DeviceId, tui32 CompletionId, tui32 IoStatus); static void scard_handle_ReleaseContext_Return(struct stream *s, IRP *irp, tui32 DeviceId, tui32 CompletionId, tui32 IoStatus); static void scard_handle_IsContextValid_Return(struct stream *s, IRP *irp, tui32 DeviceId, tui32 CompletionId, tui32 IoStatus); static void scard_handle_ListReaders_Return(struct stream *s, IRP *irp, tui32 DeviceId, tui32 CompletionId, tui32 IoStatus); static void scard_handle_GetStatusChange_Return(struct stream *s, IRP *irp, tui32 DeviceId, tui32 CompletionId, tui32 IoStatus); static void scard_handle_Connect_Return(struct stream *s, IRP *irp, tui32 DeviceId, tui32 CompletionId, tui32 IoStatus); static void scard_handle_Reconnect_Return(struct stream *s, IRP *irp, tui32 DeviceId, tui32 CompletionId, tui32 IoStatus); static void scard_handle_BeginTransaction_Return(struct stream *s, IRP *irp, tui32 DeviceId, tui32 CompletionId, tui32 IoStatus); static void scard_handle_EndTransaction_Return(struct stream *s, IRP *irp, tui32 DeviceId, tui32 CompletionId, tui32 IoStatus); static void scard_handle_Status_Return(struct stream *s, IRP *irp, tui32 DeviceId, tui32 CompletionId, tui32 IoStatus); static void scard_handle_Disconnect_Return(struct stream *s, IRP *irp, tui32 DeviceId, tui32 CompletionId, tui32 IoStatus); static void scard_handle_Transmit_Return(struct stream *s, IRP *irp, tui32 DeviceId, tui32 CompletionId, tui32 IoStatus); static void scard_handle_Control_Return(struct stream *s, IRP *irp, tui32 DeviceId, tui32 CompletionId, tui32 IoStatus); static void scard_handle_Cancel_Return(struct stream *s, IRP *irp, tui32 DeviceId, tui32 CompletionId, tui32 IoStatus); static void scard_handle_GetAttrib_Return(struct stream *s, IRP *irp, tui32 DeviceId, tui32 CompletionId, tui32 IoStatus); /****************************************************************************** ** ** ** externally accessible functions, defined in smartcard.h ** ** ** ******************************************************************************/ /** *****************************************************************************/ void scard_device_announce(tui32 device_id) { log_debug("entered: device_id=%d", device_id); if (g_smartcards_inited) { log_error("already init"); return; } g_memset(&smartcards, 0, sizeof(smartcards)); g_smartcards_inited = 1; g_device_id = device_id; g_scard_index = scard_add_new_device(device_id); if (g_scard_index < 0) log_debug("scard_add_new_device failed with DeviceId=%d", g_device_id); else log_debug("added smartcard with DeviceId=%d to list", g_device_id); } /** * *****************************************************************************/ int scard_get_wait_objs(tbus *objs, int *count, int *timeout) { return scard_pcsc_get_wait_objs(objs, count, timeout); } /** * *****************************************************************************/ int scard_check_wait_objs(void) { return scard_pcsc_check_wait_objs(); } /** * *****************************************************************************/ int scard_init(void) { LOG(0, ("scard_init:")); return scard_pcsc_init(); } /** * *****************************************************************************/ int scard_deinit(void) { LOG(0, ("scard_deinit:")); scard_pcsc_deinit(); scard_release_resources(); g_smartcards_inited = 0; return 0; } /** * *****************************************************************************/ int scard_send_establish_context(void *user_data, int scope) { IRP *irp; /* setup up IRP */ if ((irp = devredir_irp_new()) == NULL) { log_error("system out of memory"); return 1; } irp->scard_index = g_scard_index; irp->CompletionId = g_completion_id++; irp->DeviceId = g_device_id; irp->callback = scard_handle_EstablishContext_Return; irp->user_data = user_data; /* send IRP to client */ scard_send_EstablishContext(irp, scope); return 0; } /** * Release a previously established Smart Card context *****************************************************************************/ int scard_send_release_context(void *user_data, char *context, int context_bytes) { IRP *irp; /* setup up IRP */ if ((irp = devredir_irp_new()) == NULL) { log_error("system out of memory"); return 1; } irp->scard_index = g_scard_index; irp->CompletionId = g_completion_id++; irp->DeviceId = g_device_id; irp->callback = scard_handle_ReleaseContext_Return; irp->user_data = user_data; /* send IRP to client */ scard_send_ReleaseContext(irp, context, context_bytes); return 0; } /** * Checks if a previously established context is still valid *****************************************************************************/ int scard_send_is_valid_context(void *user_data, char *context, int context_bytes) { IRP *irp; /* setup up IRP */ if ((irp = devredir_irp_new()) == NULL) { log_error("system out of memory"); return 1; } irp->scard_index = g_scard_index; irp->CompletionId = g_completion_id++; irp->DeviceId = g_device_id; irp->callback = scard_handle_IsContextValid_Return; irp->user_data = user_data; /* send IRP to client */ scard_send_IsContextValid(irp, context, context_bytes); return 0; } /** * *****************************************************************************/ int scard_send_list_readers(void *user_data, char *context, int context_bytes, char *groups, int cchReaders, int wide) { IRP *irp; /* setup up IRP */ if ((irp = devredir_irp_new()) == NULL) { log_error("system out of memory"); return 1; } irp->scard_index = g_scard_index; irp->CompletionId = g_completion_id++; irp->DeviceId = g_device_id; irp->callback = scard_handle_ListReaders_Return; irp->user_data = user_data; /* send IRP to client */ scard_send_ListReaders(irp, context, context_bytes, groups, cchReaders, wide); return 0; } /** * Send get change in status command * * @param con connection to client * @param wide TRUE if unicode string * @param timeout timeout in milliseconds, -1 for infinity * @param num_readers number of entries in rsa * @param rsa array of READER_STATEs *****************************************************************************/ int scard_send_get_status_change(void *user_data, char *context, int context_bytes, int wide, tui32 timeout, tui32 num_readers, READER_STATE* rsa) { IRP *irp; /* setup up IRP */ if ((irp = devredir_irp_new()) == NULL) { log_error("system out of memory"); return 1; } irp->scard_index = g_scard_index; irp->CompletionId = g_completion_id++; irp->DeviceId = g_device_id; irp->callback = scard_handle_GetStatusChange_Return; irp->user_data = user_data; /* send IRP to client */ scard_send_GetStatusChange(irp, context, context_bytes, wide, timeout, num_readers, rsa); return 0; } /** * Open a connection to the smart card located in the reader * * @param con connection to client * @param wide TRUE if unicode string *****************************************************************************/ int scard_send_connect(void *user_data, char *context, int context_bytes, int wide, READER_STATE* rs) { IRP *irp; /* setup up IRP */ if ((irp = devredir_irp_new()) == NULL) { log_error("system out of memory"); return 1; } irp->scard_index = g_scard_index; irp->CompletionId = g_completion_id++; irp->DeviceId = g_device_id; irp->callback = scard_handle_Connect_Return; irp->user_data = user_data; /* send IRP to client */ scard_send_Connect(irp, context, context_bytes, wide, rs); return 0; } /** * The reconnect method re-establishes a smart card reader handle. On success, * the handle is valid once again. * * @param con connection to client * @param sc_handle handle to device * @param rs reader state where following fields are set * rs.shared_mode_flag * rs.preferred_protocol * rs.init_type *****************************************************************************/ int scard_send_reconnect(void *user_data, char *context, int context_bytes, char *card, int card_bytes, READER_STATE* rs) { IRP *irp; /* setup up IRP */ if ((irp = devredir_irp_new()) == NULL) { log_error("system out of memory"); return 1; } irp->scard_index = g_scard_index; irp->CompletionId = g_completion_id++; irp->DeviceId = g_device_id; irp->callback = scard_handle_Reconnect_Return; irp->user_data = user_data; /* send IRP to client */ scard_send_Reconnect(irp, context, context_bytes, card, card_bytes, rs); return 0; } /** * Lock smart card reader for exclusive access for specified smart * card reader handle. * * @param con connection to client *****************************************************************************/ int scard_send_begin_transaction(void *user_data, char *context, int context_bytes, char *card, int card_bytes) { IRP *irp; /* setup up IRP */ if ((irp = devredir_irp_new()) == NULL) { log_error("system out of memory"); return 1; } irp->scard_index = g_scard_index; irp->CompletionId = g_completion_id++; irp->DeviceId = g_device_id; irp->callback = scard_handle_BeginTransaction_Return; irp->user_data = user_data; /* send IRP to client */ scard_send_BeginTransaction(irp, context, context_bytes, card, card_bytes); return 0; } /** * Release a smart card reader after being locked by a previously * successful call to Begin Transaction * * @param con connection to client * @param sc_handle handle to smartcard *****************************************************************************/ int scard_send_end_transaction(void *user_data, char *context, int context_bytes, char *card, int card_bytes, tui32 dwDisposition) { IRP *irp; /* setup up IRP */ if ((irp = devredir_irp_new()) == NULL) { log_error("system out of memory"); return 1; } irp->scard_index = g_scard_index; irp->CompletionId = g_completion_id++; irp->DeviceId = g_device_id; irp->callback = scard_handle_EndTransaction_Return; irp->user_data = user_data; /* send IRP to client */ scard_send_EndTransaction(irp, context, context_bytes, card, card_bytes, dwDisposition); return 0; } /** * Get the status of a connection for a valid smart card reader handle * * @param con connection to client * @param wide TRUE if unicode string *****************************************************************************/ int scard_send_status(void *user_data, int wide, char *context, int context_bytes, char *card, int card_bytes, int cchReaderLen, int cbAtrLen) { IRP *irp; /* setup up IRP */ if ((irp = devredir_irp_new()) == NULL) { log_error("system out of memory"); return 1; } irp->scard_index = g_scard_index; irp->CompletionId = g_completion_id++; irp->DeviceId = g_device_id; irp->callback = scard_handle_Status_Return; irp->user_data = user_data; /* send IRP to client */ scard_send_Status(irp, wide, context, context_bytes, card, card_bytes, cchReaderLen, cbAtrLen); return 0; } /** * Release a smart card reader handle that was acquired in ConnectA/ConnectW * * @param con connection to client * @param sc_handle handle to smartcard *****************************************************************************/ int scard_send_disconnect(void *user_data, char *context, int context_bytes, char *card, int card_bytes, int dwDisposition) { IRP *irp; /* setup up IRP */ if ((irp = devredir_irp_new()) == NULL) { log_error("system out of memory"); return 1; } irp->scard_index = g_scard_index; irp->CompletionId = g_completion_id++; irp->DeviceId = g_device_id; irp->callback = scard_handle_Disconnect_Return; irp->user_data = user_data; /* send IRP to client */ scard_send_Disconnect(irp, context, context_bytes, card, card_bytes, dwDisposition); return 0; } /** * The Transmit_Call structure is used to send data to the smart card * associated with a valid context. *****************************************************************************/ int scard_send_transmit(void *user_data, char *context, int context_bytes, char *card, int card_bytes, char *send_data, int send_bytes, int recv_bytes, struct xrdp_scard_io_request *send_ior, struct xrdp_scard_io_request *recv_ior) { IRP *irp; /* setup up IRP */ if ((irp = devredir_irp_new()) == NULL) { log_error("system out of memory"); return 1; } irp->scard_index = g_scard_index; irp->CompletionId = g_completion_id++; irp->DeviceId = g_device_id; irp->callback = scard_handle_Transmit_Return; irp->user_data = user_data; /* send IRP to client */ scard_send_Transmit(irp, context, context_bytes, card, card_bytes, send_data, send_bytes, recv_bytes, send_ior, recv_ior); return 0; } /** * Communicate directly with the smart card reader *****************************************************************************/ int scard_send_control(void *user_data, char* context, int context_bytes, char *card, int card_bytes, char *send_data, int send_bytes, int recv_bytes, int control_code) { IRP *irp; /* setup up IRP */ if ((irp = devredir_irp_new()) == NULL) { log_error("system out of memory"); return 1; } irp->scard_index = g_scard_index; irp->CompletionId = g_completion_id++; irp->DeviceId = g_device_id; irp->callback = scard_handle_Control_Return; irp->user_data = user_data; /* send IRP to client */ scard_send_Control(irp, context, context_bytes, card, card_bytes, send_data, send_bytes, recv_bytes, control_code); return 0; } /** * Cancel any outstanding calls *****************************************************************************/ int scard_send_cancel(void *user_data, char *context, int context_bytes) { IRP *irp; /* setup up IRP */ if ((irp = devredir_irp_new()) == NULL) { log_error("system out of memory"); return 1; } irp->scard_index = g_scard_index; irp->CompletionId = g_completion_id++; irp->DeviceId = g_device_id; irp->callback = scard_handle_Cancel_Return; irp->user_data = user_data; /* send IRP to client */ scard_send_Cancel(irp, context, context_bytes); return 0; } /** * Get reader attributes *****************************************************************************/ int scard_send_get_attrib(void *user_data, char *card, int card_bytes, READER_STATE* rs) { IRP *irp; /* setup up IRP */ if ((irp = devredir_irp_new()) == NULL) { log_error("system out of memory"); return 1; } irp->scard_index = g_scard_index; irp->CompletionId = g_completion_id++; irp->DeviceId = g_device_id; irp->callback = scard_handle_GetAttrib_Return; irp->user_data = user_data; /* send IRP to client */ scard_send_GetAttrib(irp, card, card_bytes, rs); return 0; } /****************************************************************************** ** ** ** static functions local to this file ** ** ** ******************************************************************************/ /** * Crate a new stream and insert specified IOCTL * * @param irp information about the I/O * @param ioctl the IOCTL code * * @return stream with IOCTL inserted in it, NULL on error *****************************************************************************/ static struct stream * scard_make_new_ioctl(IRP *irp, tui32 ioctl) { /* * format of device control request * * DeviceIoRequest * u16 RDPDR_CTYP_CORE * u16 PAKID_CORE_DEVICE_IOREQUEST * u32 DeviceId * u32 FileId * u32 CompletionId * u32 MajorFunction * u32 MinorFunction * * u32 OutputBufferLength SHOULD be 2048 * u32 InputBufferLength * u32 IoControlCode * 20 bytes padding * xx bytes InputBuffer (variable) */ struct stream *s; xstream_new(s, 1024 * 4); devredir_insert_DeviceIoRequest(s, irp->DeviceId, irp->FileId, irp->CompletionId, IRP_MJ_DEVICE_CONTROL, 0); xstream_wr_u32_le(s, 2048); /* OutputBufferLength */ s_push_layer(s, iso_hdr, 4); /* InputBufferLength - insert later */ xstream_wr_u32_le(s, ioctl); /* Ioctl Code */ out_uint8s(s, 20); /* padding */ /* [MS-RPCE] 2.2.6.1 */ xstream_wr_u32_le(s, 0x00081001); /* len 8, LE, v1 */ xstream_wr_u32_le(s, 0xcccccccc); /* filler */ return s; } /** * Create a new smart card device entry and insert it into smartcards[] * * @param device_id DeviceId of new card * * @return index into smartcards[] on success, -1 on failure *****************************************************************************/ static int scard_add_new_device(tui32 device_id) { int index; SMARTCARD *sc; if ((index = scard_get_free_slot()) < 0) { log_error("scard_get_free_slot failed"); return -1; } sc = g_new0(SMARTCARD, 1); if (sc == NULL) { log_error("system out of memory"); return -1; } sc->DeviceId = device_id; smartcards[index] = sc; return index; } /** * Find first unused entry in smartcards * * @return index of first unused entry in smartcards or -1 if smartcards * is full *****************************************************************************/ static int scard_get_free_slot(void) { int i; for (i = 0; i < MAX_SMARTCARDS; i++) { if (smartcards[i] == NULL) { log_debug("found free slot at index %d", i); return i; } } log_error("too many smart card devices; rejecting this one"); return -1; } /** * Release resources prior to shutting down *****************************************************************************/ static void scard_release_resources(void) { int i; for (i = 0; i < MAX_SMARTCARDS; i++) { if (smartcards[i] != NULL) { g_free(smartcards[i]); smartcards[i] = NULL; } } } /** * *****************************************************************************/ static void scard_send_EstablishContext(IRP *irp, int scope) { struct stream *s; int bytes; if ((s = scard_make_new_ioctl(irp, SCARD_IOCTL_ESTABLISH_CONTEXT)) == NULL) { log_error("scard_make_new_ioctl failed"); return; } s_push_layer(s, mcs_hdr, 4); /* bytes, set later */ out_uint32_le(s, 0x00000000); out_uint32_le(s, scope); out_uint32_le(s, 0x00000000); s_mark_end(s); s_pop_layer(s, mcs_hdr); bytes = (int) (s->end - s->p); bytes -= 8; out_uint32_le(s, bytes); s_pop_layer(s, iso_hdr); bytes = (int) (s->end - s->p); bytes -= 28; out_uint32_le(s, bytes); bytes = (int) (s->end - s->data); /* send to client */ send_channel_data(g_rdpdr_chan_id, s->data, bytes); free_stream(s); } /** * Release a previously established Smart Card context *****************************************************************************/ static void scard_send_ReleaseContext(IRP *irp, char *context, int context_bytes) { /* see [MS-RDPESC] 3.1.4.2 */ SMARTCARD *sc; struct stream *s; int bytes; if ((sc = smartcards[irp->scard_index]) == NULL) { log_error("smartcards[%d] is NULL", irp->scard_index); return; } if ((s = scard_make_new_ioctl(irp, SCARD_IOCTL_RELEASE_CONTEXT)) == NULL) { log_error("scard_make_new_ioctl failed"); return; } s_push_layer(s, mcs_hdr, 4); /* bytes, set later */ out_uint32_le(s, 0x00000000); out_uint32_le(s, context_bytes); out_uint32_le(s, 0x00020000); out_uint32_le(s, context_bytes); out_uint8a(s, context, context_bytes); s_mark_end(s); s_pop_layer(s, mcs_hdr); bytes = (int) (s->end - s->p); bytes -= 8; out_uint32_le(s, bytes); s_pop_layer(s, iso_hdr); bytes = (int) (s->end - s->p); bytes -= 28; out_uint32_le(s, bytes); bytes = (int) (s->end - s->data); /* send to client */ send_channel_data(g_rdpdr_chan_id, s->data, bytes); free_stream(s); } /** * Checks if a previously established context is still valid *****************************************************************************/ static void scard_send_IsContextValid(IRP *irp, char *context, int context_bytes) { /* see [MS-RDPESC] 3.1.4.3 */ SMARTCARD *sc; struct stream *s; int bytes; if ((sc = smartcards[irp->scard_index]) == NULL) { log_error("smartcards[%d] is NULL", irp->scard_index); return; } if ((s = scard_make_new_ioctl(irp, SCARD_IOCTL_IS_VALID_CONTEXT)) == NULL) { log_error("scard_make_new_ioctl failed"); return; } /* * command format * * ...... * 20 bytes padding * u32 4 bytes len 8, LE, v1 * u32 4 bytes filler * 16 bytes unused (s->p currently pointed here at unused[0]) * u32 4 bytes context len * u32 4 bytes context */ s_push_layer(s, mcs_hdr, 4); /* bytes, set later */ /* insert context */ out_uint32_le(s, context_bytes); out_uint8a(s, context, context_bytes); s_mark_end(s); s_pop_layer(s, mcs_hdr); bytes = (int) (s->end - s->p); bytes -= 8; out_uint32_le(s, bytes); s_pop_layer(s, iso_hdr); bytes = (int) (s->end - s->p); bytes -= 28; out_uint32_le(s, bytes); bytes = (int) (s->end - s->data); /* send to client */ send_channel_data(g_rdpdr_chan_id, s->data, bytes); free_stream(s); } /** * *****************************************************************************/ static void scard_send_ListReaders(IRP *irp, char *context, int context_bytes, char *groups, int cchReaders, int wide) { /* see [MS-RDPESC] 2.2.2.4 */ SMARTCARD *sc; struct stream *s; int bytes; int bytes_groups; int val; int index; int num_chars; tui32 ioctl; twchar w_groups[100]; if ((sc = smartcards[irp->scard_index]) == NULL) { log_error("smartcards[%d] is NULL", irp->scard_index); return; } ioctl = (wide) ? SCARD_IOCTL_LIST_READERS_W : SCARD_IOCTL_LIST_READERS_A; if ((s = scard_make_new_ioctl(irp, ioctl)) == NULL) { log_error("scard_make_new_ioctl failed"); return; } num_chars = 0; bytes_groups = 0; w_groups[0] = 0; val = 0; if (groups != 0) { if (groups[0] != 0) { num_chars = g_mbstowcs(w_groups, groups, 99); bytes_groups = wide ? (num_chars + 2) * 2 : num_chars + 2; val = 0x00020004; } } s_push_layer(s, mcs_hdr, 4); /* bytes, set later */ out_uint32_le(s, 0x00000000); out_uint32_le(s, context_bytes); out_uint32_le(s, 0x00020000); out_uint32_le(s, bytes_groups); out_uint32_le(s, val); out_uint32_le(s, 0x00000000); out_uint32_le(s, cchReaders); /* insert context */ out_uint32_le(s, context_bytes); out_uint8a(s, context, context_bytes); if (bytes_groups > 0) { if (wide) { out_uint32_le(s, bytes_groups); for (index = 0; index < num_chars; index++) { out_uint16_le(s, w_groups[index]); } out_uint16_le(s, 0); out_uint16_le(s, 0); } else { out_uint32_le(s, bytes_groups); for (index = 0; index < num_chars; index++) { out_uint8(s, w_groups[index]); } out_uint16_le(s, 0); out_uint16_le(s, 0); } } s_mark_end(s); s_pop_layer(s, mcs_hdr); bytes = (int) (s->end - s->p); bytes -= 8; out_uint32_le(s, bytes); s_pop_layer(s, iso_hdr); bytes = (int) (s->end - s->p); bytes -= 28; out_uint32_le(s, bytes); bytes = (int) (s->end - s->data); /* send to client */ send_channel_data(g_rdpdr_chan_id, s->data, bytes); #if 0 g_writeln("scard_send_ListReaders:"); g_hexdump(s->data, bytes); #endif free_stream(s); } /*****************************************************************************/ static int align_s(struct stream *s, int bytes) { int i32; i32 = (int) (s->p - s->data); while ((i32 % bytes) != 0) { out_uint8s(s, 1); i32 = (int) (s->p - s->data); } return 0; } /** * Get change in status * * @param irp I/O resource pkt * @param wide TRUE if unicode string * @param timeout timeout in milliseconds, -1 for infinity * @param num_readers number of entries in rsa * @param rsa array of READER_STATEs *****************************************************************************/ static void scard_send_GetStatusChange(IRP* irp, char *context, int context_bytes, int wide, tui32 timeout, tui32 num_readers, READER_STATE* rsa) { /* see [MS-RDPESC] 2.2.2.11 for ASCII */ /* see [MS-RDPESC] 2.2.2.12 for Wide char */ SMARTCARD *sc; READER_STATE *rs; struct stream *s; tui32 ioctl; int bytes; unsigned int i; int num_chars; int index; twchar w_reader_name[100]; if ((sc = smartcards[irp->scard_index]) == NULL) { log_error("smartcards[%d] is NULL", irp->scard_index); return; } ioctl = (wide) ? SCARD_IOCTL_GET_STATUS_CHANGE_W : SCARD_IOCTL_GET_STATUS_CHANGE_A; if ((s = scard_make_new_ioctl(irp, ioctl)) == NULL) { log_error("scard_make_new_ioctl failed"); return; } s_push_layer(s, mcs_hdr, 4); /* bytes, set later */ out_uint32_le(s, 0x00000000); out_uint32_le(s, context_bytes); out_uint32_le(s, 0x00020000); out_uint32_le(s, timeout); out_uint32_le(s, num_readers); out_uint32_le(s, 0x00020004); /* ? */ /* insert context */ out_uint32_le(s, context_bytes); out_uint8a(s, context, context_bytes); out_uint32_le(s, num_readers); /* insert card reader state */ for (i = 0; i < num_readers; i++) { rs = &rsa[i]; out_uint32_le(s, 0x00020008); /* ? */ out_uint32_le(s, rs->current_state); out_uint32_le(s, rs->event_state); out_uint32_le(s, rs->atr_len); out_uint8p(s, rs->atr, 33); out_uint8s(s, 3); } if (wide) { /* insert card reader names */ for (i = 0; i < num_readers; i++) { rs = &rsa[i]; num_chars = g_mbstowcs(w_reader_name, rs->reader_name, 99); out_uint32_le(s, num_chars + 2); out_uint32_le(s, 0); out_uint32_le(s, num_chars + 2); for (index = 0; index < num_chars; index++) { out_uint16_le(s, w_reader_name[index]); } out_uint16_le(s, 0); out_uint16_le(s, 0); align_s(s, 4); } } else { /* insert card reader names */ for (i = 0; i < num_readers; i++) { rs = &rsa[i]; num_chars = g_mbstowcs(w_reader_name, rs->reader_name, 99); out_uint32_le(s, num_chars + 2); out_uint32_le(s, 0); out_uint32_le(s, num_chars + 2); for (index = 0; index < num_chars; index++) { out_uint8(s, w_reader_name[index]); } out_uint8(s, 0); out_uint8(s, 0); align_s(s, 4); } } s_mark_end(s); s_pop_layer(s, mcs_hdr); bytes = (int) (s->end - s->p); bytes -= 8; out_uint32_le(s, bytes); s_pop_layer(s, iso_hdr); bytes = (int) (s->end - s->p); bytes -= 28; out_uint32_le(s, bytes); bytes = (int) (s->end - s->data); /* send to client */ send_channel_data(g_rdpdr_chan_id, s->data, bytes); #if 0 g_writeln("scard_send_GetStatusChange:"); g_hexdump(s->data, bytes); #endif free_stream(s); } /** * Send connect command * * @param irp I/O resource pkt * @param wide TRUE if unicode string * @param rs reader state *****************************************************************************/ static void scard_send_Connect(IRP* irp, char *context, int context_bytes, int wide, READER_STATE* rs) { /* see [MS-RDPESC] 2.2.2.13 for ASCII */ /* see [MS-RDPESC] 2.2.2.14 for Wide char */ SMARTCARD* sc; struct stream* s; tui32 ioctl; int bytes; int num_chars; int index; twchar w_reader_name[100]; if ((sc = smartcards[irp->scard_index]) == NULL) { log_error("smartcards[%d] is NULL", irp->scard_index); return; } ioctl = (wide) ? SCARD_IOCTL_CONNECT_W : SCARD_IOCTL_CONNECT_A; if ((s = scard_make_new_ioctl(irp, ioctl)) == NULL) { log_error("scard_make_new_ioctl failed"); return; } s_push_layer(s, mcs_hdr, 4); /* bytes, set later */ out_uint32_le(s, 0x00000000); out_uint32_le(s, 0x00020000); out_uint32_le(s, context_bytes); out_uint32_le(s, 0x00020004); out_uint32_le(s, rs->dwShareMode); out_uint32_le(s, rs->dwPreferredProtocols); num_chars = g_mbstowcs(w_reader_name, rs->reader_name, 99); out_uint32_le(s, num_chars + 2); out_uint32_le(s, 0x00000000); out_uint32_le(s, num_chars + 2); if (wide) { for (index = 0; index < num_chars; index++) { out_uint16_le(s, w_reader_name[index]); } out_uint16_le(s, 0); out_uint16_le(s, 0); } else { for (index = 0; index < num_chars; index++) { out_uint8(s, w_reader_name[index]); } out_uint8(s, 0); out_uint8(s, 0); } align_s(s, 4); /* insert context */ out_uint32_le(s, context_bytes); out_uint8a(s, context, context_bytes); out_uint32_le(s, 0); s_mark_end(s); s_pop_layer(s, mcs_hdr); bytes = (int) (s->end - s->p); bytes -= 8; out_uint32_le(s, bytes); s_pop_layer(s, iso_hdr); bytes = (int) (s->end - s->p); bytes -= 28; out_uint32_le(s, bytes); bytes = (int) (s->end - s->data); /* send to client */ send_channel_data(g_rdpdr_chan_id, s->data, bytes); free_stream(s); } /** * The reconnect method re-establishes a smart card reader handle. On success, * the handle is valid once again. * * @param con connection to client * @param sc_handle handle to device * @param rs reader state where following fields are set * rs.shared_mode_flag * rs.preferred_protocol * rs.init_type *****************************************************************************/ static void scard_send_Reconnect(IRP *irp, char *context, int context_bytes, char *card, int card_bytes, READER_STATE *rs) { /* see [MS-RDPESC] 2.2.2.15 */ /* see [MS-RDPESC] 3.1.4.36 */ SMARTCARD *sc; struct stream *s; int bytes; if ((sc = smartcards[irp->scard_index]) == NULL) { log_error("smartcards[%d] is NULL", irp->scard_index); return; } if ((s = scard_make_new_ioctl(irp, SCARD_IOCTL_RECONNECT)) == NULL) { log_error("scard_make_new_ioctl failed"); return; } /* * command format * * ...... * 20 bytes padding * u32 4 bytes len 8, LE, v1 * u32 4 bytes filler * 24 bytes unused (s->p currently pointed here at unused[0]) * u32 4 bytes dwShareMode * u32 4 bytes dwPreferredProtocols * u32 4 bytes dwInitialization * u32 4 bytes context length * u32 4 bytes context * u32 4 bytes handle length * u32 4 bytes handle */ xstream_seek(s, 24); /* TODO */ out_uint32_le(s, rs->dwShareMode); out_uint32_le(s, rs->dwPreferredProtocols); out_uint32_le(s, rs->init_type); out_uint32_le(s, context_bytes); out_uint8a(s, context, context_bytes); out_uint32_le(s, card_bytes); out_uint8a(s, card, card_bytes); s_mark_end(s); s_pop_layer(s, iso_hdr); bytes = (int) (s->end - s->p); bytes -= 28; out_uint32_le(s, bytes); bytes = (int) (s->end - s->data); /* send to client */ send_channel_data(g_rdpdr_chan_id, s->data, bytes); free_stream(s); } /** * Lock smart card reader for exclusive access for specified smart * card reader handle. * * @param con connection to client *****************************************************************************/ static void scard_send_BeginTransaction(IRP *irp, char *context, int context_bytes, char *card, int card_bytes) { /* see [MS-RDPESC] 4.9 */ SMARTCARD *sc; struct stream *s; int bytes; if ((sc = smartcards[irp->scard_index]) == NULL) { log_error("smartcards[%d] is NULL", irp->scard_index); return; } if ((s = scard_make_new_ioctl(irp, SCARD_IOCTL_BEGIN_TRANSACTION)) == NULL) { log_error("scard_make_new_ioctl failed"); return; } s_push_layer(s, mcs_hdr, 4); /* bytes, set later */ out_uint32_le(s, 0x00000000); out_uint32_le(s, context_bytes); out_uint32_le(s, 0x00020000); out_uint32_le(s, card_bytes); out_uint32_le(s, 0x00020004); out_uint32_le(s, 0x00000000); /* insert context */ out_uint32_le(s, context_bytes); out_uint8a(s, context, context_bytes); /* insert card */ out_uint32_le(s, card_bytes); out_uint8a(s, card, card_bytes); out_uint32_le(s, 0x00000000); s_mark_end(s); s_pop_layer(s, mcs_hdr); bytes = (int) (s->end - s->p); bytes -= 8; out_uint32_le(s, bytes); s_pop_layer(s, iso_hdr); bytes = (int) (s->end - s->p); bytes -= 28; out_uint32_le(s, bytes); bytes = (int) (s->end - s->data); /* send to client */ send_channel_data(g_rdpdr_chan_id, s->data, bytes); free_stream(s); } /** * Release a smart card reader after being locked by a previously * successful call to Begin Transaction * * @param con connection to client * @param sc_handle handle to smartcard *****************************************************************************/ static void scard_send_EndTransaction(IRP *irp, char *context, int context_bytes, char *card, int card_bytes, tui32 dwDisposition) { /* see [MS-RDPESC] 3.1.4.32 */ SMARTCARD *sc; struct stream *s; int bytes; if ((sc = smartcards[irp->scard_index]) == NULL) { log_error("smartcards[%d] is NULL", irp->scard_index); return; } if ((s = scard_make_new_ioctl(irp, SCARD_IOCTL_END_TRANSACTION)) == NULL) { log_error("scard_make_new_ioctl failed"); return; } s_push_layer(s, mcs_hdr, 4); /* bytes, set later */ out_uint32_le(s, 0x00000000); out_uint32_le(s, context_bytes); out_uint32_le(s, 0x00020000); out_uint32_le(s, card_bytes); out_uint32_le(s, 0x00020004); out_uint32_le(s, dwDisposition); /* insert context */ out_uint32_le(s, context_bytes); out_uint8a(s, context, context_bytes); /* insert card */ out_uint32_le(s, card_bytes); out_uint8a(s, card, card_bytes); out_uint32_le(s, 0); s_mark_end(s); s_pop_layer(s, mcs_hdr); bytes = (int) (s->end - s->p); bytes -= 8; out_uint32_le(s, bytes); s_pop_layer(s, iso_hdr); bytes = (int) (s->end - s->p); bytes -= 28; out_uint32_le(s, bytes); bytes = (int) (s->end - s->data); /* send to client */ send_channel_data(g_rdpdr_chan_id, s->data, bytes); free_stream(s); } /** * Get the status of a connection for a valid smart card reader handle * * @param con connection to client * @param wide TRUE if unicode string *****************************************************************************/ static void scard_send_Status(IRP *irp, int wide, char *context, int context_bytes, char *card, int card_bytes, int cchReaderLen, int cbAtrLen) { /* see [MS-RDPESC] 2.2.2.18 */ SMARTCARD *sc; struct stream *s; int bytes; tui32 ioctl; if ((sc = smartcards[irp->scard_index]) == NULL) { log_error("smartcards[%d] is NULL", irp->scard_index); return; } ioctl = wide ? SCARD_IOCTL_STATUS_W : SCARD_IOCTL_STATUS_A; if ((s = scard_make_new_ioctl(irp, ioctl)) == NULL) { log_error("scard_make_new_ioctl"); return; } /* 30 00 00 00 00 00 00 00 04 00 00 00 00 00 02 00 04 00 00 00 04 00 02 00 01 00 00 00 00 00 00 00 dwReaderLen 40 00 00 00 dwAtrLen 04 00 00 00 07 00 00 00 04 00 00 00 09 00 00 00 hCard 00 00 00 00 */ s_push_layer(s, mcs_hdr, 4); /* bytes, set later */ out_uint32_le(s, 0x00000000); out_uint32_le(s, context_bytes); out_uint32_le(s, 0x00020000); out_uint32_le(s, card_bytes); out_uint32_le(s, 0x00020004); out_uint32_le(s, 0x00000001); out_uint32_le(s, cchReaderLen); /* readerLen, see [MS-RDPESC] 4.11 */ out_uint32_le(s, cbAtrLen); /* atrLen, see [MS-RDPESC] 4.11 */ /* insert context */ out_uint32_le(s, context_bytes); out_uint8a(s, context, context_bytes); /* insert card */ out_uint32_le(s, card_bytes); out_uint8a(s, card, card_bytes); out_uint32_le(s, 0); s_mark_end(s); s_pop_layer(s, mcs_hdr); bytes = (int) (s->end - s->p); bytes -= 8; out_uint32_le(s, bytes); s_pop_layer(s, iso_hdr); bytes = (int) (s->end - s->p); bytes -= 28; out_uint32_le(s, bytes); bytes = (int) (s->end - s->data); //g_hexdump(s->data, bytes); /* send to client */ send_channel_data(g_rdpdr_chan_id, s->data, bytes); free_stream(s); } /** * Release a smart card reader handle that was acquired in ConnectA/ConnectW * * @param con connection to client * @param sc_handle handle to smartcard *****************************************************************************/ static void scard_send_Disconnect(IRP *irp, char *context, int context_bytes, char *card, int card_bytes, int dwDisposition) { /* see [MS-RDPESC] 3.1.4.30 */ SMARTCARD *sc; struct stream *s; int bytes; if ((sc = smartcards[irp->scard_index]) == NULL) { log_error("smartcards[%d] is NULL", irp->scard_index); return; } if ((s = scard_make_new_ioctl(irp, SCARD_IOCTL_DISCONNECT)) == NULL) { log_error("scard_make_new_ioctl failed"); return; } s_push_layer(s, mcs_hdr, 4); /* bytes, set later */ out_uint32_le(s, 0x00000000); out_uint32_le(s, context_bytes); out_uint32_le(s, 0x00020000); out_uint32_le(s, card_bytes); out_uint32_le(s, 0x00020004); out_uint32_le(s, dwDisposition); /* insert context */ out_uint32_le(s, context_bytes); out_uint8a(s, context, context_bytes); /* insert card */ out_uint32_le(s, card_bytes); out_uint8a(s, card, card_bytes); out_uint32_le(s, 0x00000000); s_mark_end(s); s_pop_layer(s, mcs_hdr); bytes = (int) (s->end - s->p); bytes -= 8; out_uint32_le(s, bytes); s_pop_layer(s, iso_hdr); bytes = (int) (s->end - s->p); bytes -= 28; out_uint32_le(s, bytes); bytes = (int) (s->end - s->data); /* send to client */ send_channel_data(g_rdpdr_chan_id, s->data, bytes); free_stream(s); } /** * The Transmit_Call structure is used to send data to the smart card * associated with a valid context. *****************************************************************************/ static int scard_send_Transmit(IRP *irp, char *context, int context_bytes, char *card, int card_bytes, char *send_data, int send_bytes, int recv_bytes, struct xrdp_scard_io_request *send_ior, struct xrdp_scard_io_request *recv_ior) { /* see [MS-RDPESC] 2.2.2.19 */ SMARTCARD *sc; struct stream *s; int bytes; int val; if ((sc = smartcards[irp->scard_index]) == NULL) { log_error("smartcards[%d] is NULL", irp->scard_index); return 1; } if ((s = scard_make_new_ioctl(irp, SCARD_IOCTL_TRANSMIT)) == NULL) { log_error("scard_make_new_ioctl"); return 1; } log_debug("send_bytes %d recv_bytes %d send dwProtocol %d cbPciLength %d " "extra_bytes %d recv dwProtocol %d cbPciLength %d extra_bytes %d", send_bytes, recv_bytes, send_ior->dwProtocol, send_ior->cbPciLength, send_ior->extra_bytes, recv_ior->dwProtocol, recv_ior->cbPciLength, recv_ior->extra_bytes); /* * command format * * ...... * 20 bytes padding * u32 4 bytes len 8, LE, v1 * u32 4 bytes filler * 12 bytes unused (s->p currently pointed here at unused[0]) * u32 4 bytes map0 * 4 bytes unused * u32 4 bytes map1 * u32 4 bytes dwProtocol * u32 4 bytes cbPciLength * u32 4 bytes map2 * u32 4 bytes cbSendLength * u32 4 bytes map3 * u32 4 bytes map4 * u32 4 bytes map5 * u32 4 bytes map6 * u32 4 bytes cbRecvLength * u32 4 bytes len of sc_handle * u32 4 bytes sc_handle */ //g_writeln("send_bytes %d", send_bytes); //g_writeln("recv_bytes %d", recv_bytes); #if 0 s_push_layer(s, mcs_hdr, 4); /* bytes, set later */ out_uint32_be(s, 0x00000000); out_uint32_be(s, 0x04000000); out_uint32_be(s, 0x00000200); // map 0 out_uint32_be(s, 0x04000000); out_uint32_be(s, 0x04000200); // map 1 out_uint32_be(s, 0x01000000); out_uint32_be(s, 0x00000000); out_uint32_be(s, 0x00000000); //out_uint32_be(s, 0x05000000); out_uint32_le(s, send_bytes); out_uint32_be(s, 0x08000200); out_uint32_be(s, 0x0c000200); out_uint32_be(s, 0x00000000); //out_uint32_be(s, 0x02010000); out_uint32_le(s, recv_bytes); out_uint32_be(s, 0x04000000); out_uint32_be(s, 0x05000000); out_uint32_be(s, 0x04000000); out_uint32_be(s, 0x0b000000); //out_uint32_be(s, 0x05000000); //out_uint32_be(s, 0x00b00704); //out_uint32_be(s, 0x10000000); out_uint32_le(s, send_bytes); out_uint8p(s, send_data, send_bytes); align_s(s, 4); out_uint32_be(s, 0x01000000); out_uint32_be(s, 0x00000000); out_uint32_be(s, 0x00000000); #else //g_printf("send cbPciLength %d\n", send_ior->cbPciLength); //g_printf("send extra_bytes %d\n", send_ior->extra_bytes); //g_printf("recv cbPciLength %d\n", recv_ior->cbPciLength); //g_printf("recv extra_bytes %d\n", recv_ior->extra_bytes); s_push_layer(s, mcs_hdr, 4); /* bytes, set later */ out_uint32_le(s, 0x00000000); out_uint32_le(s, context_bytes); out_uint32_le(s, 0x00020000); /* map0 */ out_uint32_le(s, card_bytes); out_uint32_le(s, 0x00020004); /* map1 */ out_uint32_le(s, send_ior->dwProtocol); out_uint32_le(s, send_ior->cbPciLength - 8); val = send_ior->extra_bytes > 0 ? 1 : 0; out_uint32_le(s, val); /* map2 */ out_uint32_le(s, send_bytes); val = send_bytes > 0 ? 0x00020008 : 0; out_uint32_le(s, val); /* map3 */ val = recv_ior->cbPciLength > 0 ? 0x0002000c : 0; out_uint32_le(s, val); /* map 4 */ out_uint32_le(s, 0); // map5 out_uint32_le(s, recv_bytes); /* map0 */ out_uint32_le(s, context_bytes); out_uint8a(s, context, context_bytes); /* map1 */ out_uint32_le(s, card_bytes); out_uint8a(s, card, card_bytes); if (send_ior->extra_bytes > 0) { out_uint32_le(s, send_ior->extra_bytes); out_uint8a(s, send_ior->extra_data, send_ior->extra_bytes); } if (send_bytes > 0) { out_uint32_le(s, send_bytes); out_uint8a(s, send_data, send_bytes); align_s(s, 4); } if (recv_ior->cbPciLength > 0) { /* map4 */ out_uint32_le(s, recv_ior->dwProtocol); out_uint32_le(s, recv_ior->cbPciLength - 8); val = recv_ior->extra_bytes > 0 ? 1 : 0; out_uint32_le(s, val); /* map6*/ if (val) { out_uint32_le(s, recv_ior->extra_bytes); out_uint8a(s, recv_ior->extra_data, recv_ior->extra_bytes); } } #endif s_mark_end(s); s_pop_layer(s, mcs_hdr); bytes = (int) (s->end - s->p); bytes -= 8; out_uint32_le(s, bytes); s_pop_layer(s, iso_hdr); bytes = (int) (s->end - s->p); bytes -= 28; out_uint32_le(s, bytes); bytes = (int) (s->end - s->data); /* send to client */ send_channel_data(g_rdpdr_chan_id, s->data, bytes); #if 0 g_writeln("scard_send_Transmit:"); g_hexdump(s->data, bytes); #endif free_stream(s); return 0; } /** * Communicate directly with the smart card reader *****************************************************************************/ static int scard_send_Control(IRP *irp, char *context, int context_bytes, char *card, int card_bytes, char *send_data, int send_bytes, int recv_bytes, int control_code) { /* see [MS-RDPESC] 2.2.2.19 */ SMARTCARD *sc; struct stream *s; int bytes; int val; if ((sc = smartcards[irp->scard_index]) == NULL) { log_error("smartcards[%d] is NULL", irp->scard_index); return 1; } if ((s = scard_make_new_ioctl(irp, SCARD_IOCTL_CONTROL)) == NULL) { log_error("scard_make_new_ioctl"); return 1; } s_push_layer(s, mcs_hdr, 4); /* bytes, set later */ out_uint32_le(s, 0x00000000); out_uint32_le(s, context_bytes); out_uint32_le(s, 0x00020000); /* map0 */ out_uint32_le(s, card_bytes); out_uint32_le(s, 0x00020004); /* map1 */ out_uint32_le(s, control_code); out_uint32_le(s, send_bytes); val = send_bytes > 0 ? 0x00020008 : 0; out_uint32_le(s, val); /* map2 */ out_uint32_le(s, 0x00000000); out_uint32_le(s, recv_bytes); out_uint32_le(s, context_bytes); out_uint8a(s, context, context_bytes); out_uint32_le(s, card_bytes); out_uint8a(s, card, card_bytes); if (send_bytes > 0) { out_uint32_le(s, send_bytes); out_uint8a(s, send_data, send_bytes); } else { out_uint32_le(s, 0x00000000); } s_mark_end(s); s_pop_layer(s, mcs_hdr); bytes = (int) (s->end - s->p); bytes -= 8; out_uint32_le(s, bytes); s_pop_layer(s, iso_hdr); bytes = (int) (s->end - s->p); bytes -= 28; out_uint32_le(s, bytes); bytes = (int) (s->end - s->data); //g_hexdump(s->data, bytes); /* send to client */ send_channel_data(g_rdpdr_chan_id, s->data, bytes); free_stream(s); return 0; } /** * Cancel any outstanding calls *****************************************************************************/ static int scard_send_Cancel(IRP *irp, char *context, int context_bytes) { /* see [MS-RDPESC] 3.1.4.27 */ SMARTCARD *sc; struct stream *s; int bytes; if ((sc = smartcards[irp->scard_index]) == NULL) { log_error("smartcards[%d] is NULL", irp->scard_index); return 1; } if ((s = scard_make_new_ioctl(irp, SCARD_IOCTL_CANCEL)) == NULL) { log_error("scard_make_new_ioctl"); return 1; } s_push_layer(s, mcs_hdr, 4); /* bytes, set later */ out_uint32_le(s, 0x00000000); out_uint32_le(s, context_bytes); out_uint32_le(s, 0x00020000); out_uint32_le(s, context_bytes); out_uint8a(s, context, context_bytes); s_mark_end(s); s_pop_layer(s, mcs_hdr); bytes = (int) (s->end - s->p); bytes -= 8; out_uint32_le(s, bytes); s_pop_layer(s, iso_hdr); bytes = (int) (s->end - s->p); bytes -= 28; out_uint32_le(s, bytes); bytes = (int) (s->end - s->data); /* send to client */ send_channel_data(g_rdpdr_chan_id, s->data, bytes); free_stream(s); return 0; } /** * Get reader attributes *****************************************************************************/ static int scard_send_GetAttrib(IRP *irp, char *card, int card_bytes, READER_STATE *rs) { /* see [MS-RDPESC] 2.2.2.21 */ SMARTCARD *sc; struct stream *s; int bytes; if ((sc = smartcards[irp->scard_index]) == NULL) { log_error("smartcards[%d] is NULL", irp->scard_index); return 1; } if ((s = scard_make_new_ioctl(irp, SCARD_IOCTL_GETATTRIB)) == NULL) { log_error("scard_make_new_ioctl"); return 1; } /* * command format * * ...... * 20 bytes padding * u32 4 bytes len 8, LE, v1 * u32 4 bytes filler * 24 bytes unused (s->p currently pointed here at unused[0]) * u32 4 bytes dwAttribId * 4 bytes unused * u32 4 bytes dwAttrLen * 8 bytes unused * u32 4 bytes handle len * u32 4 bytes handle */ xstream_seek(s, 24); /* TODO */ out_uint32_le(s, rs->dwAttribId); out_uint32_le(s, 0); out_uint32_le(s, rs->dwAttrLen); xstream_seek(s, 8); out_uint32_le(s, card_bytes); out_uint8a(s, card, card_bytes); s_mark_end(s); s_pop_layer(s, iso_hdr); bytes = (int) (s->end - s->p); bytes -= 28; out_uint32_le(s, bytes); bytes = (int) (s->end - s->data); /* send to client */ send_channel_data(g_rdpdr_chan_id, s->data, bytes); free_stream(s); return 0; } /****************************************************************************** ** ** ** local callbacks into this module ** ** ** ******************************************************************************/ /** * *****************************************************************************/ static void scard_handle_EstablishContext_Return(struct stream *s, IRP *irp, tui32 DeviceId, tui32 CompletionId, tui32 IoStatus) { tui32 len; log_debug("entered"); /* sanity check */ if ((DeviceId != irp->DeviceId) || (CompletionId != irp->CompletionId)) { log_error("DeviceId/CompletionId do not match those in IRP"); return; } /* get OutputBufferLen */ xstream_rd_u32_le(s, len); scard_function_establish_context_return(irp->user_data, s, len, IoStatus); devredir_irp_delete(irp); log_debug("leaving"); } /** * *****************************************************************************/ static void scard_handle_ReleaseContext_Return(struct stream *s, IRP *irp, tui32 DeviceId, tui32 CompletionId, tui32 IoStatus) { tui32 len; log_debug("entered"); /* sanity check */ if ((DeviceId != irp->DeviceId) || (CompletionId != irp->CompletionId)) { log_error("DeviceId/CompletionId do not match those in IRP"); return; } /* get OutputBufferLen */ xstream_rd_u32_le(s, len); scard_function_release_context_return(irp->user_data, s, len, IoStatus); devredir_irp_delete(irp); log_debug("leaving"); } /** * *****************************************************************************/ static void scard_handle_IsContextValid_Return(struct stream *s, IRP *irp, tui32 DeviceId, tui32 CompletionId, tui32 IoStatus) { tui32 len; log_debug("entered"); /* sanity check */ if ((DeviceId != irp->DeviceId) || (CompletionId != irp->CompletionId)) { log_error("DeviceId/CompletionId do not match those in IRP"); return; } /* get OutputBufferLen */ xstream_rd_u32_le(s, len); scard_function_is_context_valid_return(irp->user_data, s, len, IoStatus); devredir_irp_delete(irp); log_debug("leaving"); } /** * *****************************************************************************/ static void scard_handle_ListReaders_Return(struct stream *s, IRP *irp, tui32 DeviceId, tui32 CompletionId, tui32 IoStatus) { tui32 len; log_debug("entered"); /* sanity check */ if ((DeviceId != irp->DeviceId) || (CompletionId != irp->CompletionId)) { log_error("DeviceId/CompletionId do not match those in IRP"); return; } /* get OutputBufferLen */ xstream_rd_u32_le(s, len); scard_function_list_readers_return(irp->user_data, s, len, IoStatus); devredir_irp_delete(irp); log_debug("leaving"); } /** * *****************************************************************************/ static void scard_handle_GetStatusChange_Return(struct stream *s, IRP *irp, tui32 DeviceId, tui32 CompletionId, tui32 IoStatus) { tui32 len; log_debug("entered"); /* sanity check */ if ((DeviceId != irp->DeviceId) || (CompletionId != irp->CompletionId)) { log_error("DeviceId/CompletionId do not match those in IRP"); return; } /* get OutputBufferLen */ xstream_rd_u32_le(s, len); scard_function_get_status_change_return(irp->user_data, s, len, IoStatus); devredir_irp_delete(irp); log_debug("leaving"); } /** * *****************************************************************************/ static void scard_handle_Connect_Return(struct stream *s, IRP *irp, tui32 DeviceId, tui32 CompletionId, tui32 IoStatus) { tui32 len; log_debug("entered"); /* sanity check */ if ((DeviceId != irp->DeviceId) || (CompletionId != irp->CompletionId)) { log_error("DeviceId/CompletionId do not match those in IRP"); return; } /* get OutputBufferLen */ xstream_rd_u32_le(s, len); scard_function_connect_return(irp->user_data, s, len, IoStatus); devredir_irp_delete(irp); log_debug("leaving"); } /** * *****************************************************************************/ static void scard_handle_Reconnect_Return(struct stream *s, IRP *irp, tui32 DeviceId, tui32 CompletionId, tui32 IoStatus) { tui32 len; log_debug("entered"); /* sanity check */ if ((DeviceId != irp->DeviceId) || (CompletionId != irp->CompletionId)) { log_error("DeviceId/CompletionId do not match those in IRP"); return; } /* get OutputBufferLen */ xstream_rd_u32_le(s, len); scard_function_reconnect_return(irp->user_data, s, len, IoStatus); devredir_irp_delete(irp); log_debug("leaving"); } /** * *****************************************************************************/ static void scard_handle_BeginTransaction_Return(struct stream *s, IRP *irp, tui32 DeviceId, tui32 CompletionId, tui32 IoStatus) { tui32 len; log_debug("entered"); /* sanity check */ if ((DeviceId != irp->DeviceId) || (CompletionId != irp->CompletionId)) { log_error("DeviceId/CompletionId do not match those in IRP"); return; } /* get OutputBufferLen */ xstream_rd_u32_le(s, len); scard_function_begin_transaction_return(irp->user_data, s, len, IoStatus); devredir_irp_delete(irp); log_debug("leaving"); } /** * *****************************************************************************/ static void scard_handle_EndTransaction_Return(struct stream *s, IRP *irp, tui32 DeviceId, tui32 CompletionId, tui32 IoStatus) { tui32 len; log_debug("entered"); /* sanity check */ if ((DeviceId != irp->DeviceId) || (CompletionId != irp->CompletionId)) { log_error("DeviceId/CompletionId do not match those in IRP"); return; } /* get OutputBufferLen */ xstream_rd_u32_le(s, len); scard_function_end_transaction_return(irp->user_data, s, len, IoStatus); devredir_irp_delete(irp); log_debug("leaving"); } /** * *****************************************************************************/ static void scard_handle_Status_Return(struct stream *s, IRP *irp, tui32 DeviceId, tui32 CompletionId, tui32 IoStatus) { tui32 len; log_debug("entered"); /* sanity check */ if ((DeviceId != irp->DeviceId) || (CompletionId != irp->CompletionId)) { log_error("DeviceId/CompletionId do not match those in IRP"); return; } /* get OutputBufferLen */ xstream_rd_u32_le(s, len); scard_function_status_return(irp->user_data, s, len, IoStatus); devredir_irp_delete(irp); log_debug("leaving"); } /** * *****************************************************************************/ static void scard_handle_Disconnect_Return(struct stream *s, IRP *irp, tui32 DeviceId, tui32 CompletionId, tui32 IoStatus) { tui32 len; log_debug("entered"); /* sanity check */ if ((DeviceId != irp->DeviceId) || (CompletionId != irp->CompletionId)) { log_error("DeviceId/CompletionId do not match those in IRP"); return; } /* get OutputBufferLen */ xstream_rd_u32_le(s, len); scard_function_disconnect_return(irp->user_data, s, len, IoStatus); devredir_irp_delete(irp); log_debug("leaving"); } /** * *****************************************************************************/ static void scard_handle_Transmit_Return(struct stream *s, IRP *irp, tui32 DeviceId, tui32 CompletionId, tui32 IoStatus) { tui32 len; log_debug("entered"); /* sanity check */ if ((DeviceId != irp->DeviceId) || (CompletionId != irp->CompletionId)) { log_error("DeviceId/CompletionId do not match those in IRP"); return; } /* get OutputBufferLen */ xstream_rd_u32_le(s, len); scard_function_transmit_return(irp->user_data, s, len, IoStatus); devredir_irp_delete(irp); log_debug("leaving"); } /** * *****************************************************************************/ static void scard_handle_Control_Return(struct stream *s, IRP *irp, tui32 DeviceId, tui32 CompletionId,tui32 IoStatus) { tui32 len; log_debug("entered"); /* sanity check */ if ((DeviceId != irp->DeviceId) || (CompletionId != irp->CompletionId)) { log_error("DeviceId/CompletionId do not match those in IRP"); return; } /* get OutputBufferLen */ xstream_rd_u32_le(s, len); scard_function_control_return(irp->user_data, s, len, IoStatus); devredir_irp_delete(irp); log_debug("leaving"); } /** * *****************************************************************************/ static void scard_handle_Cancel_Return(struct stream *s, IRP *irp, tui32 DeviceId, tui32 CompletionId, tui32 IoStatus) { tui32 len; log_debug("entered"); /* sanity check */ if ((DeviceId != irp->DeviceId) || (CompletionId != irp->CompletionId)) { log_error("DeviceId/CompletionId do not match those in IRP"); return; } /* get OutputBufferLen */ xstream_rd_u32_le(s, len); scard_function_cancel_return(irp->user_data, s, len, IoStatus); devredir_irp_delete(irp); log_debug("leaving"); } /** * *****************************************************************************/ static void scard_handle_GetAttrib_Return(struct stream *s, IRP *irp, tui32 DeviceId, tui32 CompletionId, tui32 IoStatus) { tui32 len; log_debug("entered"); /* sanity check */ if ((DeviceId != irp->DeviceId) || (CompletionId != irp->CompletionId)) { log_error("DeviceId/CompletionId do not match those in IRP"); return; } /* get OutputBufferLen */ xstream_rd_u32_le(s, len); scard_function_get_attrib_return(irp->user_data, s, len, IoStatus); devredir_irp_delete(irp); log_debug("leaving"); } xrdp-0.9.5/sesman/chansrv/smartcard_pcsc.h000644 001751 001751 00000007400 13174271344 020524 0ustar00metameta000000 000000 /** * xrdp: A Remote Desktop Protocol server. * * Copyright (C) Jay Sorg 2013 jay.sorg@gmail.com * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. * */ /* * smartcard redirection support, PCSC daemon standin */ #ifndef _SMARTCARD_PCSC_H #define _SMARTCARD_PCSC_H int scard_pcsc_get_wait_objs(tbus *objs, int *count, int *timeout); int scard_pcsc_check_wait_objs(void); int scard_pcsc_init(void); int scard_pcsc_deinit(void); int scard_function_establish_context_return(void *user_data, struct stream *in_s, int len, int status); int scard_function_release_context_return(void *user_data, struct stream *in_s, int len, int status); int scard_function_list_readers_return(void *user_data, struct stream *in_s, int len, int status); int scard_function_transmit_return(void *user_data, struct stream *in_s, int len, int status); int scard_function_control_return(void *user_data, struct stream *in_s, int len, int status); int scard_function_get_status_change_return(void *user_data, struct stream *in_s, int len, int status); int scard_function_connect_return(void *user_data, struct stream *in_s, int len, int status); int scard_function_status_return(void *user_data, struct stream *in_s, int len, int status); int scard_function_begin_transaction_return(void *user_data, struct stream *in_s, int len, int status); int scard_function_end_transaction_return(void *user_data, struct stream *in_s, int len, int status); int scard_function_is_context_valid_return(void *user_data, struct stream *in_s, int len, int status); int scard_function_reconnect_return(void *user_data, struct stream *in_s, int len, int status); int scard_function_disconnect_return(void *user_data, struct stream *in_s, int len, int status); int scard_function_cancel_return(void *user_data, struct stream *in_s, int len, int status); int scard_function_get_attrib_return(void *user_data, struct stream *in_s, int len, int status); #endif /* end #ifndef _SMARTCARD_PCSC_H */ xrdp-0.9.5/sesman/chansrv/xcommon.c000644 001751 001751 00000011524 13174271344 017211 0ustar00metameta000000 000000 /** * xrdp: A Remote Desktop Protocol server. * * Copyright (C) Jay Sorg 2012 * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ #if defined(HAVE_CONFIG_H) #include #endif #include #include "arch.h" #include "parse.h" #include "os_calls.h" #include "chansrv.h" #include "log.h" #include "clipboard.h" #include "rail.h" /* #undef LOG_LEVEL #define LOG_LEVEL 11 */ extern int g_clip_up; /* in clipboard.c */ extern int g_rail_up; /* in rail.c */ Display *g_display = 0; int g_x_socket = 0; tbus g_x_wait_obj = 0; Screen *g_screen = 0; int g_screen_num = 0; Window g_root_window = 0; Atom g_wm_delete_window_atom = 0; Atom g_wm_protocols_atom = 0; Atom g_utf8_string = 0; Atom g_net_wm_name = 0; Atom g_wm_state = 0; /*****************************************************************************/ static int xcommon_error_handler(Display *dis, XErrorEvent *xer) { char text[256]; XGetErrorText(dis, xer->error_code, text, 255); LOGM((LOG_LEVEL_ERROR, "X error [%s](%d) opcodes %d/%d " "resource 0x%lx", text, xer->error_code, xer->request_code, xer->minor_code, xer->resourceid)); return 0; } /*****************************************************************************/ /* The X server had an internal error. This is the last function called. Do any cleanup that needs to be done on exit, like removing temporary files. Don't worry about memory leaks */ #if 0 static int xcommon_fatal_handler(Display *dis) { return 0; } #endif /*****************************************************************************/ /* returns time in milliseconds this is like g_time2 in os_calls, but not milliseconds since machine was up, something else this is a time value similar to what the xserver uses */ int xcommon_get_local_time(void) { return g_time3(); } /******************************************************************************/ /* this should be called first */ int xcommon_init(void) { if (g_display != 0) { LOG(10, ("xcommon_init: xcommon_init already called")); return 0; } g_display = XOpenDisplay(0); if (g_display == 0) { LOGM((LOG_LEVEL_ERROR, "xcommon_init: error, XOpenDisplay failed")); return 1; } LOG(0, ("xcommon_init: connected to display ok")); /* setting the error handlers can cause problem when shutting down chansrv on some xlibs */ XSetErrorHandler(xcommon_error_handler); //XSetIOErrorHandler(xcommon_fatal_handler); g_x_socket = XConnectionNumber(g_display); if (g_x_socket == 0) { LOGM((LOG_LEVEL_ERROR, "xcommon_init: XConnectionNumber failed")); return 1; } g_x_wait_obj = g_create_wait_obj_from_socket(g_x_socket, 0); g_screen_num = DefaultScreen(g_display); g_screen = ScreenOfDisplay(g_display, g_screen_num); g_root_window = RootWindowOfScreen(g_screen); g_wm_delete_window_atom = XInternAtom(g_display, "WM_DELETE_WINDOW", 0); g_wm_protocols_atom = XInternAtom(g_display, "WM_PROTOCOLS", 0); g_utf8_string = XInternAtom(g_display, "UTF8_STRING", 0); g_net_wm_name = XInternAtom(g_display, "_NET_WM_NAME", 0); g_wm_state = XInternAtom(g_display, "WM_STATE", 0); return 0; } /*****************************************************************************/ /* returns error this is called to get any wait objects for the main loop timeout can be nil */ int xcommon_get_wait_objs(tbus *objs, int *count, int *timeout) { int lcount; if (((!g_clip_up) && (!g_rail_up)) || (objs == 0) || (count == 0)) { return 0; } lcount = *count; objs[lcount] = g_x_wait_obj; lcount++; *count = lcount; return 0; } /*****************************************************************************/ int xcommon_check_wait_objs(void) { XEvent xevent; int clip_rv; int rail_rv; if ((!g_clip_up) && (!g_rail_up)) { return 0; } while (XPending(g_display) > 0) { g_memset(&xevent, 0, sizeof(xevent)); XNextEvent(g_display, &xevent); clip_rv = clipboard_xevent(&xevent); rail_rv = rail_xevent(&xevent); if ((clip_rv == 1) && (rail_rv == 1)) { LOG(10, ("xcommon_check_wait_objs unknown xevent type %d", xevent.type)); } } return 0; } xrdp-0.9.5/sesman/chansrv/clipboard-notes.txt000644 001751 001751 00000005154 13125122133 021200 0ustar00metameta000000 000000 LOG_LEVEL dolphin clipboard_event_selection_owner_notify: clipboard_event_selection_notify: 0x1f7 text/uri-list clipboard_event_selection_notify: 0x1f8 text/x-moz-url clipboard_event_selection_notify: 0x1f3 text/plain clipboard_event_selection_notify: 0xee UTF8_STRING clipboard_event_selection_notify: 0x1f STRING clipboard_event_selection_notify: 0x1a1 TEXT clipboard_event_selection_notify: 0x1a0 COMPOUND_TEXT clipboard_event_selection_notify: 0x1fa application/x-qiconlist clipboard_event_selection_notify: 0xec TARGETS clipboard_event_selection_notify: 0xed MULTIPLE clipboard_event_selection_notify: 0xeb TIMESTAMP clipboard_event_selection_notify: 0x183 SAVE_TARGETS thunar clipboard_event_selection_owner_notify: clipboard_event_selection_notify: 0xeb TIMESTAMP clipboard_event_selection_notify: 0xec TARGETS clipboard_event_selection_notify: 0xed MULTIPLE clipboard_event_selection_notify: 0x204 x-special/gnome-copied-files clipboard_event_selection_notify: 0xee UTF8_STRING clipboard_data_in: clipboard_data_in: 3 pcmanfm clipboard_event_selection_owner_notify: clipboard_event_selection_notify: 0xeb TIMESTAMP clipboard_event_selection_notify: 0xec TARGETS clipboard_event_selection_notify: 0xed MULTIPLE clipboard_event_selection_notify: 0x1f7 text/uri-list clipboard_event_selection_notify: 0x204 x-special/gnome-copied-files clipboard_event_selection_notify: 0x1f9 application/x-kde-cutselection clipboard_event_selection_notify: 0xee UTF8_STRING CAJA clipboard_event_selection_notify: 0x141 TIMESTAMP clipboard_event_selection_notify: 0x130 TARGETS clipboard_event_selection_notify: 0x142 MULTIPLE clipboard_event_selection_notify: 0x143 x-special/mate-copied-files clipboard_event_selection_notify: 0x144 text/uri-list clipboard_event_selection_notify: 0x0 (null) clipboard_event_selection_notify: 0x25 WM_ICON_NAME clipboard_event_selection_notify: 0x47524154 (null) clipboard_event_selection_notify: 0x50000078 (null) clipboard_event_selection_notify: 0x0 (null) clipboard_event_selection_notify: 0x25 WM_ICON_NAME nautilus clipboard_event_selection_notify: 0x141 TIMESTAMP clipboard_event_selection_notify: 0x130 TARGETS clipboard_event_selection_notify: 0x142 MULTIPLE clipboard_event_selection_notify: 0x154 x-special/gnome-copied-files clipboard_event_selection_notify: 0x144 text/uri-list clipboard_event_selection_notify: 0xfb UTF8_STRING clipboard_event_selection_notify: 0x0 (null) clipboard_event_selection_notify: 0x25 WM_ICON_NAME clipboard_event_selection_notify: 0x47524154 (null) clipboard_event_selection_notify: 0x50000078 (null) clipboard_event_selection_notify: 0x0 (null) clipboard_event_selection_notify: 0x25 WM_ICON_NAME xrdp-0.9.5/sesman/chansrv/chansrv_fuse.c000644 001751 001751 00000246540 13213711022 020211 0ustar00metameta000000 000000 /** * xrdp: A Remote Desktop Protocol server. * * Copyright (C) Laxmikant Rashinkar 2013 LK.Rashinkar@gmail.com * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ /* * TODO * o when creating dir/file, ensure it does not already exist * o do not allow dirs to be created in ino==1 except for .clipboard and share mounts * o fix the HACK where I have to use my own buf instead of g_buffer * this is in func xfuse_check_wait_objs() * o if fuse mount point is already mounted, I get segfault * o in open, check for modes such as O_TRUNC, O_APPEND * o copying over an existing file does not work * o after a dir is created, the device cannot be unmounted on the client side * so something is holding it up * o in thunar, when I move a file by dragging to another folder, the file * is getting copied instead of being moved * o unable to edit files in vi * o fuse ops to support * o touch does not work * o chmod must work * o cat >> file is not working * */ //#define USE_SYNC_FLAG /* FUSE mount point */ char g_fuse_root_path[256] = ""; char g_fuse_clipboard_path[256] = ""; /* for clipboard use */ #if defined(HAVE_CONFIG_H) #include #endif #ifndef XRDP_FUSE /****************************************************************************** ** ** ** when FUSE is NOT enabled in xrdp ** ** ** ******************************************************************************/ #include #include #include #include #include "arch.h" #include "chansrv_fuse.h" /* dummy calls when XRDP_FUSE is not defined */ int xfuse_init(void) { return 0; } int xfuse_deinit(void) { return 0; } int xfuse_check_wait_objs(void) { return 0; } int xfuse_get_wait_objs(tbus *objs, int *count, int *timeout) { return 0; } int xfuse_clear_clip_dir(void) { return 0; } int xfuse_file_contents_range(int stream_id, const char *data, int data_bytes) { return 0; } int xfuse_file_contents_size(int stream_id, int file_size) { return 0; } int xfuse_add_clip_dir_item(const char *filename, int flags, int size, int lindex) { return 0; } int xfuse_create_share(tui32 device_id, const char *dirname) { return 0; } void xfuse_devredir_cb_open_file(void *vp, tui32 IoStatus, tui32 DeviceId, tui32 FileId) {} void xfuse_devredir_cb_write_file(void *vp, const char *buf, size_t length) {} void xfuse_devredir_cb_read_file(void *vp, const char *buf, size_t length) {} int xfuse_devredir_cb_enum_dir(void *vp, struct xrdp_inode *xinode) { return 0; } void xfuse_devredir_cb_enum_dir_done(void *vp, tui32 IoStatus) {} void xfuse_devredir_cb_rmdir_or_file(void *vp, tui32 IoStatus) {} void xfuse_devredir_cb_rename_file(void *vp, tui32 IoStatus) {} void xfuse_devredir_cb_file_close(void *vp) {} #else /****************************************************************************** ** ** ** when FUSE is enabled in xrdp ** ** ** ******************************************************************************/ #define FUSE_USE_VERSION 26 #include #include #include #include #include #include #include #include #include #include "arch.h" #include "os_calls.h" #include "clipboard_file.h" #include "chansrv_fuse.h" #include "devredir.h" #include "list.h" #include "fifo.h" #include "file.h" #ifndef EREMOTEIO #define EREMOTEIO EIO #endif #define min(x, y) ((x) < (y) ? (x) : (y)) #define XFUSE_ATTR_TIMEOUT 1.0 #define XFUSE_ENTRY_TIMEOUT 1.0 #define DOTDOT_INODE 0 #define DOT_INODE 0 #define FIRST_INODE 1 /* module based logging */ #define LOG_ERROR 0 #define LOG_INFO 1 #define LOG_DEBUG 2 #define LOG_LEVEL LOG_ERROR #define log_error(_params...) \ { \ g_write("[%10.10u]: FUSE %s: %d : ERROR: ", \ g_time3(), __func__, __LINE__); \ g_writeln (_params); \ } #define log_always(_params...) \ { \ g_write("[%10.10u]: FUSE %s: %d : ALWAYS: ", \ g_time3(), __func__, __LINE__); \ g_writeln (_params); \ } #define log_info(_params...) \ { \ if (LOG_INFO <= LOG_LEVEL) \ { \ g_write("[%10.10u]: FUSE %s: %d : ", \ g_time3(), __func__, __LINE__); \ g_writeln (_params); \ } \ } #define log_debug(_params...) \ { \ if (LOG_DEBUG <= LOG_LEVEL) \ { \ g_write("[%10.10u]: FUSE %s: %d : ", \ g_time3(), __func__, __LINE__); \ g_writeln (_params); \ } \ } #define OP_RENAME_FILE 0x01 /* the xrdp file system in memory */ struct xrdp_fs { struct xrdp_inode **inode_table; /* a table of entries; can grow */ unsigned int max_entries; /* size of inode_table[] */ unsigned int num_entries; /* num entries available in inode_table */ unsigned int next_node; /* next free node number */ }; struct dirbuf { char *p; size_t size; }; struct dirbuf1 { char buf[4096]; int bytes_in_buf; int first_time; }; /* FUSE reply types */ #define RT_FUSE_REPLY_OPEN 1 #define RT_FUSE_REPLY_CREATE 2 struct xfuse_info { struct fuse_file_info *fi; fuse_req_t req; fuse_ino_t inode; fuse_ino_t new_inode; int invoke_fuse; char name[1024]; char new_name[1024]; tui32 device_id; int reply_type; int mode; int type; size_t size; off_t off; struct dirbuf1 dirbuf1; }; typedef struct xfuse_info XFUSE_INFO; struct xfuse_handle { tui32 DeviceId; tui32 FileId; int is_loc_resource; /* this is not a redirected resource */ }; typedef struct xfuse_handle XFUSE_HANDLE; /* used for file data request sent to client */ struct req_list_item { fuse_req_t req; int stream_id; int lindex; int off; int size; }; struct dir_info { /* last index accessed in g_xrdp_fs.inode_table[] */ int index; }; /* queue FUSE opendir commands so we run only one at a time */ struct opendir_req { fuse_req_t req; fuse_ino_t ino; struct fuse_file_info *fi; }; static char g_fuse_mount_name[256] = "xrdp_client"; FIFO g_fifo_opendir; static struct list *g_req_list = 0; static struct xrdp_fs g_xrdp_fs; /* an inst of xrdp file system */ static char *g_mount_point = 0; /* our FUSE mount point */ static struct fuse_lowlevel_ops g_xfuse_ops; /* setup FUSE callbacks */ static int g_xfuse_inited = 0; /* true when FUSE is inited */ static struct fuse_chan *g_ch = 0; static struct fuse_session *g_se = 0; static char *g_buffer = 0; static int g_fd = 0; static tintptr g_bufsize = 0; /* forward declarations for internal access */ static int xfuse_init_xrdp_fs(void); static int xfuse_deinit_xrdp_fs(void); static int xfuse_init_lib(struct fuse_args *args); static int xfuse_is_inode_valid(fuse_ino_t ino); // LK_TODO #if 0 static void xfuse_create_file(fuse_req_t req, fuse_ino_t parent, const char *name, mode_t mode, int type); #endif static void xfuse_dump_fs(void); static tui32 xfuse_get_device_id_for_inode(fuse_ino_t ino, char *full_path); static void fuse_reverse_pathname(char *full_path, char *reverse_path); static struct xrdp_inode * xfuse_get_inode_from_pinode_name(fuse_ino_t pinode, const char *name); static struct xrdp_inode * xfuse_create_file_in_xrdp_fs(tui32 device_id, int pinode, const char *name, int type); static int xfuse_does_file_exist(fuse_ino_t parent, char *name); static int xfuse_delete_file_with_xinode(XRDP_INODE *xinode); static int xfuse_delete_dir_with_xinode(XRDP_INODE *xinode); static int xfuse_recursive_delete_dir_with_xinode(XRDP_INODE *xinode); static void xfuse_update_xrdpfs_size(void); #ifdef USE_SYNC_FLAG static void xfuse_enum_dir(fuse_req_t req, fuse_ino_t ino, size_t size, off_t off, struct fuse_file_info *fi); #endif /* forward declarations for FUSE callbacks */ static void xfuse_cb_lookup(fuse_req_t req, fuse_ino_t parent, const char *name); static void xfuse_cb_getattr(fuse_req_t req, fuse_ino_t ino, struct fuse_file_info *fi); /* this is not a callback, but it's used by xfuse_cb_readdir() */ static int xfuse_dirbuf_add1(fuse_req_t req, struct dirbuf1 *b, const char *name, fuse_ino_t ino); static void xfuse_cb_readdir(fuse_req_t req, fuse_ino_t ino, size_t size, off_t off, struct fuse_file_info *fi); static void xfuse_cb_mkdir(fuse_req_t req, fuse_ino_t parent, const char *name, mode_t mode); static void xfuse_cb_rmdir(fuse_req_t req, fuse_ino_t parent, const char *name); static void xfuse_cb_unlink(fuse_req_t req, fuse_ino_t parent, const char *name); static void xfuse_cb_rename(fuse_req_t req, fuse_ino_t old_parent, const char *old_name, fuse_ino_t new_parent, const char *new_name); /* this is not a callback, but it is used by the above two functions */ static void xfuse_remove_dir_or_file(fuse_req_t req, fuse_ino_t parent, const char *name, int type); static void xfuse_create_dir_or_file(fuse_req_t req, fuse_ino_t parent, const char *name, mode_t mode, struct fuse_file_info *fi, int type); static void xfuse_cb_open(fuse_req_t req, fuse_ino_t ino, struct fuse_file_info *fi); static void xfuse_cb_release(fuse_req_t req, fuse_ino_t ino, struct fuse_file_info *fi); static void xfuse_cb_read(fuse_req_t req, fuse_ino_t ino, size_t size, off_t off, struct fuse_file_info *fi); static void xfuse_cb_write(fuse_req_t req, fuse_ino_t ino, const char *buf, size_t size, off_t off, struct fuse_file_info *fi); static void xfuse_cb_create(fuse_req_t req, fuse_ino_t parent, const char *name, mode_t mode, struct fuse_file_info *fi); #if 0 static void xfuse_cb_fsync(fuse_req_t req, fuse_ino_t ino, int datasync, struct fuse_file_info *fi); #endif static void xfuse_cb_setattr(fuse_req_t req, fuse_ino_t ino, struct stat *attr, int to_set, struct fuse_file_info *fi); static void xfuse_cb_opendir(fuse_req_t req, fuse_ino_t ino, struct fuse_file_info *fi); static int xfuse_proc_opendir_req(fuse_req_t req, fuse_ino_t ino, struct fuse_file_info *fi); static void xfuse_cb_releasedir(fuse_req_t req, fuse_ino_t ino, struct fuse_file_info *fi); /* misc calls */ static void xfuse_mark_as_stale(fuse_ino_t pinode); static void xfuse_delete_stale_entries(fuse_ino_t pinode); /*****************************************************************************/ int load_fuse_config(void) { int index; char cfg_file[256]; struct list *items; struct list *values; char *item; char *value; items = list_create(); items->auto_free = 1; values = list_create(); values->auto_free = 1; g_snprintf(cfg_file, 255, "%s/sesman.ini", XRDP_CFG_PATH); file_by_name_read_section(cfg_file, "Chansrv", items, values); for (index = 0; index < items->count; index++) { item = (char *)list_get_item(items, index); value = (char *)list_get_item(values, index); if (g_strcasecmp(item, "FuseMountName") == 0) { g_strncpy(g_fuse_mount_name, value, 255); } } list_delete(items); list_delete(values); return 0; } /***************************************************************************** ** ** ** public functions - can be called from any code path ** ** ** *****************************************************************************/ /** * Initialize FUSE subsystem * * @return 0 on success, -1 on failure *****************************************************************************/ int xfuse_init(void) { struct fuse_args args = FUSE_ARGS_INIT(0, NULL); /* if already inited, just return */ if (g_xfuse_inited) { log_debug("already inited"); return 1; } if (g_ch != 0) { log_error("g_ch is not zero"); return -1; } load_fuse_config(); /* define FUSE mount point to ~/xrdp_client, ~/thinclient_drives */ g_snprintf(g_fuse_root_path, 255, "%s/%s", g_getenv("HOME"), g_fuse_mount_name); g_snprintf(g_fuse_clipboard_path, 255, "%s/.clipboard", g_fuse_root_path); /* if FUSE mount point does not exist, create it */ if (!g_directory_exist(g_fuse_root_path)) { if (!g_create_dir(g_fuse_root_path)) { log_error("mkdir %s failed. If %s is already mounted, you must " "first unmount it", g_fuse_root_path, g_fuse_root_path); return -1; } } /* setup xrdp file system */ if (xfuse_init_xrdp_fs()) return -1; /* setup FIFOs */ fifo_init(&g_fifo_opendir, 30); /* setup FUSE callbacks */ g_memset(&g_xfuse_ops, 0, sizeof(g_xfuse_ops)); g_xfuse_ops.lookup = xfuse_cb_lookup; g_xfuse_ops.readdir = xfuse_cb_readdir; g_xfuse_ops.mkdir = xfuse_cb_mkdir; g_xfuse_ops.rmdir = xfuse_cb_rmdir; g_xfuse_ops.unlink = xfuse_cb_unlink; g_xfuse_ops.rename = xfuse_cb_rename; g_xfuse_ops.open = xfuse_cb_open; g_xfuse_ops.release = xfuse_cb_release; g_xfuse_ops.read = xfuse_cb_read; g_xfuse_ops.write = xfuse_cb_write; g_xfuse_ops.create = xfuse_cb_create; //g_xfuse_ops.fsync = xfuse_cb_fsync; /* LK_TODO delete this */ g_xfuse_ops.getattr = xfuse_cb_getattr; g_xfuse_ops.setattr = xfuse_cb_setattr; g_xfuse_ops.opendir = xfuse_cb_opendir; g_xfuse_ops.releasedir = xfuse_cb_releasedir; fuse_opt_add_arg(&args, "xrdp-chansrv"); fuse_opt_add_arg(&args, g_fuse_root_path); //fuse_opt_add_arg(&args, "-s"); /* single threaded mode */ //fuse_opt_add_arg(&args, "-d"); /* debug mode */ if (xfuse_init_lib(&args)) { xfuse_deinit(); return -1; } g_xfuse_inited = 1; return 0; } /** * De-initialize FUSE subsystem * * @return 0 on success, -1 on failure *****************************************************************************/ int xfuse_deinit(void) { xfuse_deinit_xrdp_fs(); fifo_deinit(&g_fifo_opendir); if (g_ch != 0) { fuse_session_remove_chan(g_ch); fuse_unmount(g_mount_point, g_ch); g_ch = 0; } if (g_se != 0) { fuse_session_destroy(g_se); g_se = 0; } if (g_buffer != 0) { g_free(g_buffer); g_buffer = 0; } if (g_req_list != 0) { list_delete(g_req_list); g_req_list = 0; } g_xfuse_inited = 0; return 0; } /** * * * @return 0 on success, -1 on failure *****************************************************************************/ int xfuse_check_wait_objs(void) { struct fuse_chan *tmpch; int rval; #define HACK #ifdef HACK char buf[135168]; #endif if (g_ch == 0) return 0; if (g_tcp_select(g_fd, 0) & 1) { tmpch = g_ch; #ifdef HACK rval = fuse_chan_recv(&tmpch, buf, g_bufsize); #else rval = fuse_chan_recv(&tmpch, g_buffer, g_bufsize); #endif if (rval == -EINTR) return -1; if (rval == -ENODEV) return -1; if (rval <= 0) return -1; #ifdef HACK fuse_session_process(g_se, buf, rval, tmpch); #else fuse_session_process(g_se, g_buffer, rval, tmpch); #endif } return 0; } /** * * * @return 0 on success, -1 on failure *****************************************************************************/ int xfuse_get_wait_objs(tbus *objs, int *count, int *timeout) { int lcount; if (g_ch == 0) return 0; lcount = *count; objs[lcount] = g_fd; lcount++; *count = lcount; return 0; } /** * @brief Create specified share directory. * * This code gets called from devredir * * @return 0 on success, -1 on failure *****************************************************************************/ int xfuse_create_share(tui32 device_id, const char *dirname) { #if 0 XFUSE_INFO *fip; #endif XRDP_INODE *xinode; /* tui32 saved_inode; */ if (dirname == NULL || strlen(dirname) == 0) return -1; /* Do we have an inode table yet? */ if (xfuse_init_xrdp_fs()) { return -1; } xinode = g_new0(struct xrdp_inode, 1); if (xinode == NULL) { log_debug("g_new0() failed"); return -1; } /* create directory entry */ xinode->parent_inode = 1; xinode->inode = g_xrdp_fs.next_node++; xinode->mode = 0755 | S_IFDIR; xinode->nlink = 1; xinode->uid = getuid(); xinode->gid = getgid(); xinode->size = 0; xinode->atime = time(0); xinode->mtime = time(0); xinode->ctime = time(0); strcpy(xinode->name, dirname); xinode->device_id = device_id; g_xrdp_fs.num_entries++; /* saved_inode = xinode->inode; */ /* insert it in xrdp fs */ g_xrdp_fs.inode_table[xinode->inode] = xinode; log_debug("created new share named %s at inode_table[%d]", dirname, xinode->inode); /* update nentries in parent inode */ xinode = g_xrdp_fs.inode_table[1]; if (xinode == NULL) return -1; xinode->nentries++; #if 0 fip = g_new0(XFUSE_INFO, 1); if (fip == NULL) { log_error("system out of memory"); return -1; } /* enumerate root dir, do not call FUSE when done */ fip->req = NULL; fip->inode = 1; /* TODO saved_inode; */ strncpy(fip->name, dirname, 1024); fip->name[1023] = 0; fip->device_id = device_id; dev_redir_get_dir_listing((void *) fip, device_id, "\\"); #endif return 0; } /** * Clear all clipboard entries in xrdp_fs * * This function is called by clipboard code * * @return 0 on success, -1 on failure *****************************************************************************/ int xfuse_clear_clip_dir(void) { fuse_ino_t i; XRDP_INODE *xinode; XRDP_INODE *xip; log_debug("entered"); if (g_xrdp_fs.inode_table == NULL) { return 0; } /* xinode for .clipboard */ xip = g_xrdp_fs.inode_table[2]; for (i = FIRST_INODE; i < g_xrdp_fs.num_entries; i++) { if ((xinode = g_xrdp_fs.inode_table[i]) == NULL) continue; if (xinode->parent_inode == 2) { g_xrdp_fs.inode_table[i] = NULL; free(xinode); xip->nentries--; } } return 0; } /** * Return clipboard data to fuse * * @return 0 on success, -1 on failure *****************************************************************************/ int xfuse_file_contents_range(int stream_id, const char *data, int data_bytes) { log_debug("entered: stream_id=%d data_bytes=%d", stream_id, data_bytes); struct req_list_item *rli; if ((rli = (struct req_list_item *) list_get_item(g_req_list, 0)) == NULL) { log_error("range error!"); return -1; } log_debug("lindex=%d off=%d size=%d", rli->lindex, rli->off, rli->size); fuse_reply_buf(rli->req, data, data_bytes); list_remove_item(g_req_list, 0); if (g_req_list->count <= 0) { log_debug("completed all requests"); return 0; } /* send next request */ rli = (struct req_list_item *) list_get_item(g_req_list, 0); if (rli == NULL) { log_error("range error!"); return -1; } log_debug("requesting clipboard file data"); clipboard_request_file_data(rli->stream_id, rli->lindex, rli->off, rli->size); return 0; } /** * Create a file in .clipboard dir * * This function is called by clipboard code * * @return 0 on success, -1 on failure *****************************************************************************/ int xfuse_add_clip_dir_item(const char *filename, int flags, int size, int lindex) { log_debug("entered: filename=%s flags=%d size=%d lindex=%d", filename, flags, size, lindex); /* add entry to xrdp_fs */ XRDP_INODE *xinode = xfuse_create_file_in_xrdp_fs(0, /* device id */ 2, /* parent inode */ filename, S_IFREG); if (xinode == NULL) { log_debug("failed to create file in xrdp filesystem"); return -1; } xinode->size = size; xinode->lindex = lindex; xinode->is_loc_resource = 1; return 0; } /** * * * @return 0 on success, -1 on failure *****************************************************************************/ int xfuse_file_contents_size(int stream_id, int file_size) { log_debug("entered: stream_id=%d file_size=%d", stream_id, file_size); return 0; } /***************************************************************************** ** ** ** private functions - can only be called from within this file ** ** ** *****************************************************************************/ /** * Initialize FUSE library * * @return 0 on success, -1 on failure *****************************************************************************/ static int xfuse_init_lib(struct fuse_args *args) { if (fuse_parse_cmdline(args, &g_mount_point, 0, 0) < 0) { log_error("fuse_parse_cmdline() failed"); fuse_opt_free_args(args); return -1; } if ((g_ch = fuse_mount(g_mount_point, args)) == 0) { log_error("fuse_mount() failed"); fuse_opt_free_args(args); return -1; } g_se = fuse_lowlevel_new(args, &g_xfuse_ops, sizeof(g_xfuse_ops), 0); if (g_se == 0) { log_error("fuse_lowlevel_new() failed"); fuse_unmount(g_mount_point, g_ch); g_ch = 0; fuse_opt_free_args(args); return -1; } fuse_opt_free_args(args); fuse_session_add_chan(g_se, g_ch); g_bufsize = fuse_chan_bufsize(g_ch); g_buffer = g_new0(char, g_bufsize); g_fd = fuse_chan_fd(g_ch); g_req_list = list_create(); g_req_list->auto_free = 1; return 0; } /** * Initialize xrdp file system * * @return 0 on success, -1 on failure * *****************************************************************************/ static int xfuse_init_xrdp_fs(void) { struct xrdp_inode *xino; /* Already called? */ if (g_xrdp_fs.inode_table != NULL) { return 0; } g_xrdp_fs.inode_table = g_new0(struct xrdp_inode *, 4096); if (g_xrdp_fs.inode_table == NULL) { log_error("system out of memory"); return -1; } /* * index 0 is our .. dir */ xino = g_new0(struct xrdp_inode, 1); if (xino == NULL) { log_error("system out of memory"); free(g_xrdp_fs.inode_table); return -1; } g_xrdp_fs.inode_table[0] = xino; xino->parent_inode = 0; xino->inode = 0; xino->mode = S_IFDIR | 0755; xino->nentries = 1; xino->uid = getuid(); xino->gid = getgid(); xino->size = 0; xino->atime = time(0); xino->mtime = time(0); xino->ctime = time(0); strcpy(xino->name, ".."); /* * index 1 is our . dir */ xino = g_new0(struct xrdp_inode, 1); if (xino == NULL) { log_error("system out of memory"); free(g_xrdp_fs.inode_table[0]); free(g_xrdp_fs.inode_table); return -1; } g_xrdp_fs.inode_table[1] = xino; xino->parent_inode = 0; xino->inode = 1; xino->mode = S_IFDIR | 0755; xino->nentries = 1; xino->uid = getuid(); xino->gid = getgid(); xino->size = 0; xino->atime = time(0); xino->mtime = time(0); xino->ctime = time(0); strcpy(xino->name, "."); /* * index 2 is for clipboard use */ xino = g_new0(struct xrdp_inode, 1); if (xino == NULL) { log_error("system out of memory"); free(g_xrdp_fs.inode_table[0]); free(g_xrdp_fs.inode_table[1]); free(g_xrdp_fs.inode_table); return -1; } g_xrdp_fs.inode_table[2] = xino; xino->parent_inode = 1; xino->inode = 2; xino->nentries = 0; xino->mode = S_IFDIR | 0755; xino->uid = getuid(); xino->gid = getgid(); xino->size = 0; xino->atime = time(0); xino->mtime = time(0); xino->ctime = time(0); xino->is_loc_resource = 1; strcpy(xino->name, ".clipboard"); g_xrdp_fs.max_entries = 4096; g_xrdp_fs.num_entries = 3; g_xrdp_fs.next_node = 3; return 0; } /** * zap the xrdp file system * * @return 0 on success, -1 on failure *****************************************************************************/ static int xfuse_deinit_xrdp_fs(void) { return 0; } /** * determine if specified ino exists in xrdp file system * * @return 1 if it does, 0 otherwise *****************************************************************************/ static int xfuse_is_inode_valid(fuse_ino_t ino) { /* is ino present in our table? */ if ((ino < FIRST_INODE) || (ino >= g_xrdp_fs.next_node)) return 0; if (g_xrdp_fs.inode_table[ino] == NULL) return 0; return 1; } /** * @brief Create a directory or regular file. *****************************************************************************/ // LK_TODO #if 0 static void xfuse_create_file(fuse_req_t req, fuse_ino_t parent, const char *name, mode_t mode, int type) { struct xrdp_inode *xinode; struct fuse_entry_param e; log_debug("parent=%ld name=%s", parent, name); /* do we have a valid parent inode? */ if (!xfuse_is_inode_valid(parent)) { log_error("inode %ld is not valid", parent); fuse_reply_err(req, EBADF); } xinode = g_new0(struct xrdp_inode, 1); if (xinode == NULL) { log_error("g_new0() failed"); fuse_reply_err(req, ENOMEM); } /* create directory entry */ xinode->parent_inode = parent; xinode->inode = g_xrdp_fs.next_node++; /* TODO should be thread safe */ xinode->mode = mode | type; xinode->uid = getuid(); xinode->gid = getgid(); xinode->size = 0; xinode->atime = time(0); xinode->mtime = time(0); xinode->ctime = time(0); strcpy(xinode->name, name); g_xrdp_fs.num_entries++; /* insert it in xrdp fs */ g_xrdp_fs.inode_table[xinode->inode] = xinode; xfuse_update_xrdpfs_size(); log_debug("inserted new dir at inode_table[%d]", xinode->inode); xfuse_dump_fs(); log_debug("new inode=%d", xinode->inode); /* setup return value */ memset(&e, 0, sizeof(e)); e.ino = xinode->inode; e.attr_timeout = XFUSE_ATTR_TIMEOUT; e.entry_timeout = XFUSE_ENTRY_TIMEOUT; e.attr.st_ino = xinode->inode; e.attr.st_mode = xinode->mode; e.attr.st_nlink = xinode->nlink; e.attr.st_uid = xinode->uid; e.attr.st_gid = xinode->gid; e.attr.st_size = 0; e.attr.st_atime = xinode->atime; e.attr.st_mtime = xinode->mtime; e.attr.st_ctime = xinode->ctime; e.generation = 1; fuse_reply_entry(req, &e); } #endif static void xfuse_dump_fs(void) { fuse_ino_t i; struct xrdp_inode *xinode; log_debug("found %d entries", g_xrdp_fs.num_entries - FIRST_INODE); #if 0 log_debug("not dumping xrdp fs"); return; #endif for (i = FIRST_INODE; i < g_xrdp_fs.num_entries; i++) { if ((xinode = g_xrdp_fs.inode_table[i]) == NULL) continue; log_debug("pinode=%d inode=%d nentries=%d nopen=%d is_synced=%d name=%s", xinode->parent_inode, xinode->inode, xinode->nentries, xinode->nopen, xinode->is_synced, xinode->name); } log_debug("%s", ""); } /** * Dump contents of xinode structure * * @param xino xinode structure to dump *****************************************************************************/ #if 0 static void xfuse_dump_xrdp_inode(struct xrdp_inode *xino) { log_debug("--- dumping struct xinode ---"); log_debug("name: %s", xino->name); log_debug("parent_inode: %d", xino->parent_inode); log_debug("inode: %d", xino->inode); log_debug("mode: %o", xino->mode); log_debug("nlink: %d", xino->nlink); log_debug("uid: %d", xino->uid); log_debug("gid: %d", xino->gid); log_debug("size: %zd", xino->size); log_debug("device_id: %d", xino->device_id); log_debug("%s", ""); } #endif /** * Return the device_id associated with specified inode and copy the * full path to the specified inode into full_path * * @param ino the inode * @param full_path full path to the inode * * @return the device_id of specified inode *****************************************************************************/ static tui32 xfuse_get_device_id_for_inode(fuse_ino_t ino, char *full_path) { fuse_ino_t parent_inode = 0; fuse_ino_t child_inode = ino; char reverse_path[4096]; /* ino == 1 is a special case; we already know that it is not */ /* associated with any device redirection */ if (ino == 1) { /* just return the device_id for the file in full_path */ log_debug("looking for file with pinode=%ld name=%s", ino, full_path); xfuse_dump_fs(); XRDP_INODE *xinode = xfuse_get_inode_from_pinode_name(ino, full_path); full_path[0] = 0; if (xinode) return xinode->device_id; else return 0; } reverse_path[0] = 0; full_path[0] = 0; while (1) { strcat(reverse_path, g_xrdp_fs.inode_table[child_inode]->name); parent_inode = g_xrdp_fs.inode_table[child_inode]->parent_inode; if (parent_inode == 1) break; strcat(reverse_path, "/"); child_inode = parent_inode; } fuse_reverse_pathname(full_path, reverse_path); return g_xrdp_fs.inode_table[child_inode]->device_id; } /** * Reverse the pathname in 'reverse_path' and insert it into 'full_path' * * Example: abba/music/share1 becomes share1/music/abba * * @param full_path path name in the correct order * @param reverse_path path name in the reverse order *****************************************************************************/ static void fuse_reverse_pathname(char *full_path, char *reverse_path) { char *cptr; full_path[0] = 0; while ((cptr = strrchr(reverse_path, '/')) != NULL) { strcat(full_path, cptr + 1); strcat(full_path, "/"); cptr[0] = 0; } strcat(full_path, reverse_path); } /** * Return the inode that matches the name and parent inode *****************************************************************************/ static struct xrdp_inode * xfuse_get_inode_from_pinode_name(fuse_ino_t pinode, const char *name) { fuse_ino_t i; struct xrdp_inode * xinode; for (i = FIRST_INODE; i < g_xrdp_fs.num_entries; i++) { if ((xinode = g_xrdp_fs.inode_table[i]) == NULL) continue; /* match parent inode */ if (xinode->parent_inode != pinode) continue; /* match name */ if (strcmp(xinode->name, name) != 0) continue; return xinode; } return NULL; } /** * Create file in xrdp file system * * @param pinode the parent inode * @param name filename * * @return XRDP_INODE on success, NULL on failure *****************************************************************************/ static struct xrdp_inode * xfuse_create_file_in_xrdp_fs(tui32 device_id, int pinode, const char *name, int type) { XRDP_INODE *xinode; XRDP_INODE *xinodep; if ((name == NULL) || (strlen(name) == 0)) return NULL; xinode = g_new0(XRDP_INODE, 1); if (xinode == NULL) { log_error("system out of memory"); return NULL; } xinode->parent_inode = pinode; xinode->inode = g_xrdp_fs.next_node++; xinode->nlink = 1; xinode->uid = getuid(); xinode->gid = getgid(); xinode->atime = time(0); xinode->mtime = time(0); xinode->ctime = time(0); xinode->device_id = device_id; xinode->is_synced = 1; strcpy(xinode->name, name); if (type == S_IFDIR) { xinode->mode = 0755 | type; xinode->size = 4096; } else { xinode->mode = 0644 | type; xinode->size = 0; } g_xrdp_fs.inode_table[xinode->inode] = xinode; g_xrdp_fs.num_entries++; /* bump up lookup count in parent dir */ xinodep = g_xrdp_fs.inode_table[pinode]; xinodep->nentries++; xfuse_update_xrdpfs_size(); log_debug("incremented nentries; parent=%d nentries=%d", pinode, xinodep->nentries); return xinode; } /** * Check if specified file exists * * @param parent parent inode of file * @param name filename or dirname * * @return 1 if specified file exists, 0 otherwise *****************************************************************************/ static int xfuse_does_file_exist(fuse_ino_t parent, char *name) { fuse_ino_t i; XRDP_INODE *xinode; for (i = FIRST_INODE; i < g_xrdp_fs.num_entries; i++) { if ((xinode = g_xrdp_fs.inode_table[i]) == NULL) continue; if ((xinode->parent_inode == parent) && (strcmp(xinode->name, name) == 0)) { return 1; } } return 0; } static int xfuse_delete_file_with_xinode(XRDP_INODE *xinode) { /* make sure it is not a dir */ if ((xinode == NULL) || (xinode->mode & S_IFDIR)) return -1; log_always("deleting: inode=%d name=%s", xinode->inode, xinode->name); log_debug("deleting: inode=%d name=%s", xinode->inode, xinode->name); g_xrdp_fs.inode_table[xinode->parent_inode]->nentries--; g_xrdp_fs.inode_table[xinode->inode] = NULL; free(xinode); return 0; } static int xfuse_delete_dir_with_xinode(XRDP_INODE *xinode) { XRDP_INODE *xip; fuse_ino_t i; /* make sure it is not a file */ if ((xinode == NULL) || (xinode->mode & S_IFREG)) return -1; for (i = FIRST_INODE; i < g_xrdp_fs.num_entries; i++) { if ((xip = g_xrdp_fs.inode_table[i]) == NULL) continue; /* look for child inodes */ if (xip->parent_inode == xinode->inode) { /* got one, delete it */ g_xrdp_fs.inode_table[xip->inode] = NULL; free(xip); } } /* our parent will have one less dir */ g_xrdp_fs.inode_table[xinode->parent_inode]->nentries--; g_xrdp_fs.inode_table[xinode->inode] = NULL; free(xinode); return 0; } /** * Recursively delete dir with specified inode *****************************************************************************/ static int xfuse_recursive_delete_dir_with_xinode(XRDP_INODE *xinode) { XRDP_INODE *xip; fuse_ino_t i; /* make sure it is not a file */ if ((xinode == NULL) || (xinode->mode & S_IFREG)) return -1; log_always("recursively deleting dir with inode=%d name=%s", xinode->inode, xinode->name); log_debug("recursively deleting dir with inode=%d name=%s", xinode->inode, xinode->name); for (i = FIRST_INODE; i < g_xrdp_fs.num_entries; i++) { if ((xip = g_xrdp_fs.inode_table[i]) == NULL) continue; /* look for child inodes */ if (xip->parent_inode == xinode->inode) { /* got one */ if (xip->mode & S_IFREG) { /* regular file */ g_xrdp_fs.inode_table[xip->parent_inode]->nentries--; g_xrdp_fs.inode_table[xip->inode] = NULL; free(xip); } else { /* got another dir */ xfuse_recursive_delete_dir_with_xinode(xip); } } } /* our parent will have one less dir */ g_xrdp_fs.inode_table[xinode->parent_inode]->nentries--; g_xrdp_fs.inode_table[xinode->inode] = NULL; free(xinode); return 0; } static void xfuse_update_xrdpfs_size(void) { void *vp; int diff; diff = g_xrdp_fs.max_entries - g_xrdp_fs.num_entries; if (diff > 100) return; /* extend memory */ vp = realloc(g_xrdp_fs.inode_table, (g_xrdp_fs.max_entries + 100) * sizeof(struct xrdp_inode *)); if (vp == NULL) { log_error("system out of memory"); return; } /* zero newly added memory */ memset((char *) vp + g_xrdp_fs.max_entries * sizeof(struct xrdp_inode *), 0, 100 * sizeof(struct xrdp_inode *)); g_xrdp_fs.max_entries += 100; g_xrdp_fs.inode_table = (struct xrdp_inode **) vp; } /****************************************************************************** ** ** ** callbacks for devredir ** ** ** ******************************************************************************/ /** * Add a file or directory to xrdp file system *****************************************************************************/ int xfuse_devredir_cb_enum_dir(void *vp, struct xrdp_inode *xinode) { XFUSE_INFO *fip = (XFUSE_INFO *) vp; XRDP_INODE *xip = NULL; if ((fip == NULL) || (xinode == NULL)) { log_error("fip or xinode are NULL"); return -1; } if (!xfuse_is_inode_valid(fip->inode)) { log_error("inode %ld is not valid", fip->inode); g_free(xinode); return -1; } log_debug("parent_inode=%ld name=%s", fip->inode, xinode->name); /* if filename is . or .. don't add it */ if ((strcmp(xinode->name, ".") == 0) || (strcmp(xinode->name, "..") == 0)) { g_free(xinode); return -1; } xfuse_dump_fs(); if ((xip = xfuse_get_inode_from_pinode_name(fip->inode, xinode->name)) != NULL) { log_debug("inode=%ld name=%s already exists in xrdp_fs; not adding it", fip->inode, xinode->name); g_free(xinode); xip->stale = 0; return -1; } xinode->parent_inode = fip->inode; xinode->inode = g_xrdp_fs.next_node++; xinode->uid = getuid(); xinode->gid = getgid(); xinode->device_id = fip->device_id; g_xrdp_fs.num_entries++; /* insert it in xrdp fs and update lookup count */ g_xrdp_fs.inode_table[xinode->inode] = xinode; g_xrdp_fs.inode_table[fip->inode]->nentries++; xfuse_update_xrdpfs_size(); xfuse_dump_fs(); return 0; } /** *****************************************************************************/ void xfuse_devredir_cb_enum_dir_done(void *vp, tui32 IoStatus) { XFUSE_INFO *fip; struct dir_info *di; struct opendir_req *odreq; log_debug("vp=%p IoStatus=0x%x", vp, IoStatus); fip = (XFUSE_INFO *) vp; if (fip == NULL) { log_debug("fip is NULL"); goto done; } if (IoStatus != 0) { /* command failed */ if (fip->invoke_fuse) fuse_reply_err(fip->req, ENOENT); goto done; } /* do we have a valid inode? */ if (!xfuse_is_inode_valid(fip->inode)) { log_error("inode %ld is not valid", fip->inode); if (fip->invoke_fuse) fuse_reply_err(fip->req, EBADF); goto done; } xfuse_delete_stale_entries(fip->inode); /* this will be used by xfuse_cb_readdir() */ di = g_new0(struct dir_info, 1); di->index = FIRST_INODE; fip->fi->fh = (tintptr) di; fuse_reply_open(fip->req, fip->fi); done: if (fip) free(fip); /* remove current request */ g_free(fifo_remove(&g_fifo_opendir)); while (1) { /* process next request */ odreq = (struct opendir_req *) fifo_peek(&g_fifo_opendir); if (!odreq) return; if (xfuse_proc_opendir_req(odreq->req, odreq->ino, odreq->fi)) g_free(fifo_remove(&g_fifo_opendir)); /* req failed */ else break; /* req has been queued */ } } void xfuse_devredir_cb_open_file(void *vp, tui32 IoStatus, tui32 DeviceId, tui32 FileId) { XFUSE_HANDLE *fh; XRDP_INODE *xinode; XFUSE_INFO *fip = (XFUSE_INFO *) vp; if (fip == NULL) { log_debug("fip is NULL"); goto done; } log_debug("+++ XFUSE_INFO=%p XFUSE_INFO->fi=%p DeviceId=%d FileId=%d", fip, fip->fi, DeviceId, FileId); if (IoStatus != 0) { if (!fip->invoke_fuse) goto done; switch (IoStatus) { case 0xC0000022: fuse_reply_err(fip->req, EACCES); break; case 0xC0000033: case 0xC0000034: fuse_reply_err(fip->req, ENOENT); break; default: fuse_reply_err(fip->req, EIO); break; } goto done; } if (fip->fi != NULL) { fh = g_new0(XFUSE_HANDLE, 1); if (fh == NULL) { log_error("system out of memory"); if (fip->invoke_fuse) fuse_reply_err(fip->req, ENOMEM); free(fip); return; } /* save file handle for later use */ fh->DeviceId = DeviceId; fh->FileId = FileId; fip->fi->fh = (tintptr) fh; log_debug("+++ XFUSE_INFO=%p XFUSE_INFO->fi=%p XFUSE_INFO->fi->fh=0x%llx", fip, fip->fi, (long long) fip->fi->fh); } if (fip->invoke_fuse) { if (fip->reply_type == RT_FUSE_REPLY_OPEN) { log_debug("sending fuse_reply_open(); " "DeviceId=%d FileId=%d req=%p fi=%p", fh->DeviceId, fh->FileId, fip->req, fip->fi); /* update open count */ if ((xinode = g_xrdp_fs.inode_table[fip->inode]) != NULL) xinode->nopen++; fuse_reply_open(fip->req, fip->fi); } else if (fip->reply_type == RT_FUSE_REPLY_CREATE) { struct fuse_entry_param e; // LK_TODO #if 0 if ((xinode = g_xrdp_fs.inode_table[fip->inode]) == NULL) { log_error("inode at inode_table[%ld] is NULL", fip->inode); fuse_reply_err(fip->req, EBADF); goto done; } #else /* create entry in xrdp file system */ xinode = xfuse_create_file_in_xrdp_fs(fip->device_id, fip->inode, fip->name, fip->mode); if (xinode == NULL) { fuse_reply_err(fip->req, ENOMEM); return; } #endif memset(&e, 0, sizeof(struct fuse_entry_param)); e.ino = xinode->inode; e.attr_timeout = XFUSE_ATTR_TIMEOUT; e.entry_timeout = XFUSE_ENTRY_TIMEOUT; e.attr.st_ino = xinode->inode; e.attr.st_mode = xinode->mode; e.attr.st_nlink = xinode->nlink; e.attr.st_uid = xinode->uid; e.attr.st_gid = xinode->gid; e.attr.st_size = xinode->size; e.attr.st_atime = xinode->atime; e.attr.st_mtime = xinode->mtime; e.attr.st_ctime = xinode->ctime; e.generation = 1; if (fip->mode == S_IFDIR) { fuse_reply_entry(fip->req, &e); } else { xinode->nopen++; fuse_reply_create(fip->req, &e, fip->fi); } } else { log_error("invalid reply type: %d", fip->reply_type); } } done: free(fip); } void xfuse_devredir_cb_read_file(void *vp, const char *buf, size_t length) { XFUSE_INFO *fip; fip = (XFUSE_INFO *) vp; if ((fip == NULL) || (fip->req == NULL)) { log_error("fip for fip->req is NULL"); return; } fuse_reply_buf(fip->req, buf, length); free(fip); } void xfuse_devredir_cb_write_file(void *vp, const char *buf, size_t length) { XRDP_INODE *xinode; XFUSE_INFO *fip; fip = (XFUSE_INFO *) vp; if ((fip == NULL) || (fip->req == NULL) || (fip->fi == NULL)) { log_error("fip, fip->req or fip->fi is NULL"); return; } log_debug("+++ XFUSE_INFO=%p, XFUSE_INFO->fi=%p XFUSE_INFO->fi->fh=0x%llx", fip, fip->fi, (long long) fip->fi->fh); fuse_reply_write(fip->req, length); /* update file size */ if ((xinode = g_xrdp_fs.inode_table[fip->inode]) != NULL) xinode->size += length; else log_error("inode at inode_table[%ld] is NULL", fip->inode); free(fip); } void xfuse_devredir_cb_rmdir_or_file(void *vp, tui32 IoStatus) { XFUSE_INFO *fip; XRDP_INODE *xinode; fip = (XFUSE_INFO *) vp; if (fip == NULL) return; if (IoStatus != 0) { fuse_reply_err(fip->req, EBADF); free(fip); return; } /* now delete the item in xrdp fs */ xinode = xfuse_get_inode_from_pinode_name(fip->inode, fip->name); if (xinode == NULL) { fuse_reply_err(fip->req, EBADF); free(fip); return; } g_xrdp_fs.inode_table[xinode->inode] = NULL; free(xinode); /* update parent */ xinode = g_xrdp_fs.inode_table[fip->inode]; xinode->nentries--; fuse_reply_err(fip->req, 0); free(fip); } void xfuse_devredir_cb_rename_file(void *vp, tui32 IoStatus) { XFUSE_INFO *fip; XRDP_INODE *old_xinode; XRDP_INODE *new_xinode; fip = (XFUSE_INFO *) vp; if (fip == NULL) return; if (IoStatus != 0) { fuse_reply_err(fip->req, EEXIST); free(fip); return; } /* * update xrdp file system */ /* if destination dir/file exists, delete it */ if (xfuse_does_file_exist(fip->new_inode, fip->new_name)) { new_xinode = xfuse_get_inode_from_pinode_name(fip->new_inode, fip->new_name); if (new_xinode) { if (new_xinode->mode & S_IFREG) xfuse_delete_file_with_xinode(new_xinode); else xfuse_delete_dir_with_xinode(new_xinode); new_xinode = NULL; } } old_xinode = xfuse_get_inode_from_pinode_name(fip->inode, fip->name); if (old_xinode == NULL) { fuse_reply_err(fip->req, EBADF); free(fip); return; } old_xinode->parent_inode = fip->new_inode; strncpy(old_xinode->name, fip->new_name, 1023); old_xinode->name[1023] = 0; if (fip->inode != fip->new_inode) { /* file has been moved to a different dir */ old_xinode->is_synced = 1; g_xrdp_fs.inode_table[fip->inode]->nentries--; g_xrdp_fs.inode_table[fip->new_inode]->nentries++; } fuse_reply_err(fip->req, 0); free(fip); } void xfuse_devredir_cb_file_close(void *vp) { XFUSE_INFO *fip; XRDP_INODE *xinode; fip = (XFUSE_INFO *) vp; if (fip == NULL) { log_error("fip is NULL"); return; } if (fip->fi == NULL) { log_error("fip->fi is NULL"); return; } log_debug("+++ XFUSE_INFO=%p XFUSE_INFO->fi=%p XFUSE_INFO->fi->fh=0x%llx", fip, fip->fi, (long long) fip->fi->fh); if ((xinode = g_xrdp_fs.inode_table[fip->inode]) == NULL) { log_debug("inode_table[%ld] is NULL", fip->inode); fuse_reply_err(fip->req, EBADF); return; } log_debug("before: inode=%d nopen=%d", xinode->inode, xinode->nopen); if (xinode->nopen > 0) xinode->nopen--; /* LK_TODO */ #if 0 if ((xinode->nopen == 0) && fip->fi && fip->fi->fh) { printf("LK_TODO: ################################ fi=%p fi->fh=0x%llx\n", fip->fi, (long long) fip->fi->fh); free((char *) (tintptr) (fip->fi->fh)); fip->fi->fh = 0; } #endif fuse_reply_err(fip->req, 0); } /****************************************************************************** ** ** ** callbacks for fuse ** ** ** ******************************************************************************/ /** * Look up a directory entry by name and get its attributes * *****************************************************************************/ static void xfuse_cb_lookup(fuse_req_t req, fuse_ino_t parent, const char *name) { XRDP_INODE *xinode; struct fuse_entry_param e; log_debug("looking for parent=%ld name=%s", parent, name); xfuse_dump_fs(); if (!xfuse_is_inode_valid(parent)) { log_error("inode %ld is not valid", parent); fuse_reply_err(req, EBADF); return; } xinode = xfuse_get_inode_from_pinode_name(parent, name); if (xinode == NULL) { log_debug("did not find entry for parent=%ld name=%s", parent, name); fuse_reply_err(req, ENOENT); return; } memset(&e, 0, sizeof(e)); e.ino = xinode->inode; e.attr_timeout = XFUSE_ATTR_TIMEOUT; e.entry_timeout = XFUSE_ENTRY_TIMEOUT; e.attr.st_ino = xinode->inode; e.attr.st_mode = xinode->mode; e.attr.st_nlink = xinode->nlink; e.attr.st_uid = xinode->uid; e.attr.st_gid = xinode->gid; e.attr.st_size = xinode->size; e.attr.st_atime = xinode->atime; e.attr.st_mtime = xinode->mtime; e.attr.st_ctime = xinode->ctime; e.generation = 1; fuse_reply_entry(req, &e); log_debug("found entry for parent=%ld name=%s uid=%d gid=%d", parent, name, xinode->uid, xinode->gid); return; } /** * Get file attributes *****************************************************************************/ static void xfuse_cb_getattr(fuse_req_t req, fuse_ino_t ino, struct fuse_file_info *fi) { struct xrdp_inode *xino; struct stat stbuf; (void) fi; log_debug("req=%p ino=%ld", req, ino); /* if ino is not valid, just return */ if (!xfuse_is_inode_valid(ino)) { log_error("inode %ld is not valid", ino); fuse_reply_err(req, EBADF); return; } xino = g_xrdp_fs.inode_table[ino]; if (!xino) { log_debug("****** invalid ino=%ld", ino); fuse_reply_err(req, EBADF); return; } memset(&stbuf, 0, sizeof(stbuf)); stbuf.st_ino = ino; stbuf.st_mode = xino->mode; stbuf.st_nlink = xino->nlink; stbuf.st_size = xino->size; fuse_reply_attr(req, &stbuf, 1.0); } /** * *****************************************************************************/ #if 0 static void xfuse_dirbuf_add(fuse_req_t req, struct dirbuf *b, const char *name, fuse_ino_t ino) { struct stat stbuf; size_t oldsize = b->size; log_debug("adding ino=%ld name=%s", ino, name); b->size += fuse_add_direntry(req, NULL, 0, name, NULL, 0); b->p = (char *) realloc(b->p, b->size); memset(&stbuf, 0, sizeof(stbuf)); stbuf.st_ino = ino; fuse_add_direntry(req, b->p + oldsize, b->size - oldsize, name, &stbuf, b->size); } #endif static int xfuse_dirbuf_add1(fuse_req_t req, struct dirbuf1 *b, const char *name, fuse_ino_t ino) { struct stat stbuf; int len; len = fuse_add_direntry(req, NULL, 0, name, NULL, 0); if (b->bytes_in_buf + len > 4096) { log_debug("not adding entry because dirbuf overflow would occur"); return -1; } memset(&stbuf, 0, sizeof(stbuf)); stbuf.st_ino = ino; fuse_add_direntry(req, &b->buf[b->bytes_in_buf], /* index where new entry will be added to buf */ 4096 - len, /* remaining size of buf */ name, /* name of entry */ &stbuf, /* file attributes */ b->bytes_in_buf + len /* offset of next entry */ ); b->bytes_in_buf += len; return 0; } /** * *****************************************************************************/ static void xfuse_cb_readdir(fuse_req_t req, fuse_ino_t ino, size_t size, off_t off, struct fuse_file_info *fi) { XRDP_INODE *xinode; XRDP_INODE *ti; struct dir_info *di; struct dirbuf1 b; fuse_ino_t i; int first_time; log_debug("req=%p inode=%ld size=%zd offset=%lld", req, ino, size, (long long) off); /* do we have a valid inode? */ if (!xfuse_is_inode_valid(ino)) { log_error("inode %ld is not valid", ino); fuse_reply_err(req, EBADF); return; } di = (struct dir_info *) (tintptr) (fi->fh); if (di == NULL) { /* something seriously wrong somewhere! */ fuse_reply_buf(req, 0, 0); return; } b.bytes_in_buf = 0; first_time = (di->index == FIRST_INODE) ? 1 : 0; for (i = di->index; i < g_xrdp_fs.num_entries; i++, di->index++) { if ((xinode = g_xrdp_fs.inode_table[i]) == NULL) continue; /* match parent inode */ if (xinode->parent_inode != ino) continue; xinode->is_synced = 1; if (first_time) { first_time = 0; ti = g_xrdp_fs.inode_table[ino]; if (!ti) { log_debug("****** g_xrdp_fs.inode_table[%ld] is NULL", ino); fuse_reply_buf(req, NULL, 0); return; } xfuse_dirbuf_add1(req, &b, ".", ino); xfuse_dirbuf_add1(req, &b, "..", ti->parent_inode); } if (xfuse_dirbuf_add1(req, &b, xinode->name, xinode->inode)) break; /* buffer is full */ } if (b.bytes_in_buf) fuse_reply_buf(req, b.buf, b.bytes_in_buf); else fuse_reply_buf(req, NULL, 0); } /** * Create a directory *****************************************************************************/ static void xfuse_cb_mkdir(fuse_req_t req, fuse_ino_t parent, const char *name, mode_t mode) { XRDP_INODE *xinode; struct fuse_entry_param e; log_debug("entered: parent_inode=%ld name=%s", parent, name); if ((xinode = xfuse_get_inode_from_pinode_name(parent, name)) != NULL) { /* dir already exists, just return it */ memset(&e, 0, sizeof(struct fuse_entry_param)); e.ino = xinode->inode; e.attr_timeout = XFUSE_ATTR_TIMEOUT; e.entry_timeout = XFUSE_ENTRY_TIMEOUT; e.attr.st_ino = xinode->inode; e.attr.st_mode = xinode->mode; e.attr.st_nlink = xinode->nlink; e.attr.st_uid = xinode->uid; e.attr.st_gid = xinode->gid; e.attr.st_size = xinode->size; e.attr.st_atime = xinode->atime; e.attr.st_mtime = xinode->mtime; e.attr.st_ctime = xinode->ctime; e.generation = 1; fuse_reply_entry(req, &e); return; } /* dir does not exist, create it */ xfuse_create_dir_or_file(req, parent, name, mode, NULL, S_IFDIR); } /** * Remove specified dir *****************************************************************************/ static void xfuse_cb_rmdir(fuse_req_t req, fuse_ino_t parent, const char *name) { xfuse_remove_dir_or_file(req, parent, name, 1); } static void xfuse_cb_unlink(fuse_req_t req, fuse_ino_t parent, const char *name) { xfuse_remove_dir_or_file(req, parent, name, 2); } /** * Remove a dir or file * * @param type 1=dir, 2=file *****************************************************************************/ static void xfuse_remove_dir_or_file(fuse_req_t req, fuse_ino_t parent, const char *name, int type) { XFUSE_INFO *fip; XRDP_INODE *xinode; char *cptr; char full_path[4096]; tui32 device_id; log_debug("entered: parent=%ld name=%s", parent, name); /* is parent inode valid? */ if (!xfuse_is_inode_valid(parent)) { log_error("inode %ld is not valid", parent); fuse_reply_err(req, EBADF); return; } if ((xinode = xfuse_get_inode_from_pinode_name(parent, name)) == NULL) { log_error("did not find file with pinode=%ld name=%s", parent, name); fuse_reply_err(req, EBADF); return; } device_id = xfuse_get_device_id_for_inode(parent, full_path); log_debug("path=%s nentries=%d", full_path, xinode->nentries); if ((type == 1) && (xinode->nentries != 0)) { log_debug("cannot rmdir; lookup count is %d", xinode->nentries); fuse_reply_err(req, ENOTEMPTY); return; } else if (type == 2) { if ((xinode->nopen > 1) || ((xinode->nopen == 1) && (xinode->close_in_progress == 0))) { log_debug("cannot unlink; open count is %d", xinode->nopen); fuse_reply_err(req, EBUSY); return; } } strcat(full_path, "/"); strncat(full_path, name, sizeof(full_path) - strlen(full_path) - 1); if (xinode->is_loc_resource) { /* specified file is a local resource */ //XFUSE_HANDLE *fh; log_debug("LK_TODO: this is still a TODO"); fuse_reply_err(req, EINVAL); return; } /* specified file resides on redirected share */ fip = g_new0(XFUSE_INFO, 1); if (fip == NULL) { log_error("system out of memory"); fuse_reply_err(req, ENOMEM); return; } fip->req = req; fip->inode = parent; fip->invoke_fuse = 1; fip->device_id = device_id; strncpy(fip->name, name, 1024); fip->name[1023] = 0; fip->type = type; /* we want path minus 'root node of the share' */ if ((cptr = strchr(full_path, '/')) == NULL) { /* get dev_redir to open the remote file */ if (devredir_rmdir_or_file((void *) fip, device_id, "\\", O_RDWR)) { log_error("failed to send dev_redir_open_file() cmd"); fuse_reply_err(req, EREMOTEIO); free(fip); return; } } else { if (devredir_rmdir_or_file((void *) fip, device_id, cptr, O_RDWR)) { log_error("failed to send dev_redir_get_dir_listing() cmd"); fuse_reply_err(req, EREMOTEIO); free(fip); return; } } } static void xfuse_cb_rename(fuse_req_t req, fuse_ino_t old_parent, const char *old_name, fuse_ino_t new_parent, const char *new_name) { XRDP_INODE *old_xinode; XFUSE_INFO *fip; tui32 new_device_id; char *cptr; char old_full_path[1024]; char new_full_path[1024]; const char *cp; tui32 device_id; log_debug("entered: old_parent=%ld old_name=%s new_parent=%ld new_name=%s", old_parent, old_name, new_parent, new_name); xfuse_dump_fs(); /* is old_parent inode valid? */ if (!xfuse_is_inode_valid(old_parent)) { log_error("inode %ld is not valid", old_parent); fuse_reply_err(req, EINVAL); return; } /* is new_parent inode valid? */ if (!xfuse_is_inode_valid(new_parent)) { log_error("inode %ld is not valid", new_parent); fuse_reply_err(req, EINVAL); return; } if ((old_name == NULL) || (strlen(old_name) == 0)) { fuse_reply_err(req, EINVAL); return; } if ((new_name == NULL) || (strlen(new_name) == 0)) { fuse_reply_err(req, EINVAL); return; } old_xinode = xfuse_get_inode_from_pinode_name(old_parent, old_name); if (old_xinode == NULL) { log_error("did not find file with pinode=%ld name=%s", old_parent, old_name); fuse_reply_err(req, EBADF); return; } /* if file is open, cannot rename */ if (old_xinode->nopen != 0) { fuse_reply_err(req, EBUSY); return; } /* rename across file systems not yet supported */ new_device_id = xfuse_get_device_id_for_inode(new_parent, new_full_path); strcat(new_full_path, "/"); strcat(new_full_path, new_name); if (new_device_id != old_xinode->device_id) { log_error("rename across file systems not supported"); fuse_reply_err(req, EINVAL); return; } if (old_xinode->is_loc_resource) { /* specified file is a local resource */ log_debug("LK_TODO: this is still a TODO"); fuse_reply_err(req, EINVAL); return; } /* resource is on a redirected share */ device_id = old_xinode->device_id; xfuse_get_device_id_for_inode(old_parent, old_full_path); strcat(old_full_path, "/"); strcat(old_full_path, old_name); fip = g_new0(XFUSE_INFO, 1); if (fip == NULL) { log_error("system out of memory"); fuse_reply_err(req, ENOMEM); return; } fip->req = req; fip->inode = old_parent; fip->new_inode = new_parent; strncpy(fip->name, old_name, 1024); strncpy(fip->new_name, new_name, 1024); fip->name[1023] = 0; fip->new_name[1023] = 0; fip->invoke_fuse = 1; fip->device_id = device_id; if ((cp = strchr(new_full_path, '/')) == NULL) cp = "\\"; /* we want path minus 'root node of the share' */ if ((cptr = strchr(old_full_path, '/')) == NULL) { /* get dev_redir to open the remote file */ if (dev_redir_file_open((void *) fip, device_id, "\\", O_RDWR, S_IFREG | OP_RENAME_FILE, cp)) { log_error("failed to send dev_redir_file_open() cmd"); fuse_reply_err(req, EREMOTEIO); free(fip); return; } } else { if (dev_redir_file_open((void *) fip, device_id, cptr, O_RDWR, S_IFREG | OP_RENAME_FILE, cp)) { log_error("failed to send dev_redir_file_open() cmd"); fuse_reply_err(req, EREMOTEIO); free(fip); return; } } } /** * Create a directory or file * * @param req opaque FUSE object * @param parent parent inode * @param name name of dir or file to create * @param mode creation mode * @param fi for storing file handles * @param type S_IFDIR for dir and S_IFREG for file *****************************************************************************/ static void xfuse_create_dir_or_file(fuse_req_t req, fuse_ino_t parent, const char *name, mode_t mode, struct fuse_file_info *fi, int type) { XFUSE_INFO *fip; char *cptr; char full_path[1024]; tui32 device_id; full_path[0] = 0; log_debug("entered: parent_ino=%ld name=%s type=%s", parent, name, (type == S_IFDIR) ? "dir" : "file"); /* name must be valid */ if ((name == NULL) || (strlen(name) == 0)) { log_error("invalid name"); fuse_reply_err(req, EBADF); return; } /* is parent inode valid? */ if ((parent == 1) || (!xfuse_is_inode_valid(parent))) { log_error("inode %ld is not valid", parent); fuse_reply_err(req, EBADF); return; } device_id = xfuse_get_device_id_for_inode(parent, full_path); strcat(full_path, "/"); strcat(full_path, name); XRDP_INODE *xinode = g_xrdp_fs.inode_table[parent]; if (xinode->is_loc_resource) { /* specified file is a local resource */ //XFUSE_HANDLE *fh; log_debug("LK_TODO: this is still a TODO"); fuse_reply_err(req, EINVAL); return; } /* specified file resides on redirected share */ fip = g_new0(XFUSE_INFO, 1); if (fip == NULL) { log_error("system out of memory"); fuse_reply_err(req, ENOMEM); return; } fip->req = req; fip->fi = fi; fip->inode = parent; fip->invoke_fuse = 1; fip->device_id = device_id; fip->mode = type; fip->reply_type = RT_FUSE_REPLY_CREATE; strncpy(fip->name, name, 1024); fip->name[1023] = 0; log_debug("+++ created XFUSE_INFO=%p XFUSE_INFO->fi=%p", fip, fip->fi); /* LK_TODO need to handle open permissions */ /* we want path minus 'root node of the share' */ if ((cptr = strchr(full_path, '/')) == NULL) { /* get dev_redir to open the remote file */ if (dev_redir_file_open((void *) fip, device_id, "\\", O_CREAT, type, NULL)) { log_error("failed to send dev_redir_open_file() cmd"); fuse_reply_err(req, EREMOTEIO); } } else { if (dev_redir_file_open((void *) fip, device_id, cptr, O_CREAT, type, NULL)) { log_error("failed to send dev_redir_get_dir_listing() cmd"); fuse_reply_err(req, EREMOTEIO); } } } /** * Open specified file *****************************************************************************/ static void xfuse_cb_open(fuse_req_t req, fuse_ino_t ino, struct fuse_file_info *fi) { XRDP_INODE *xinode; XFUSE_INFO *fip; char *cptr; char full_path[4096]; tui32 device_id; log_debug("entered: ino=%ld", ino); if (!xfuse_is_inode_valid(ino)) { log_error("inode %ld is not valid", ino); fuse_reply_err(req, EBADF); return; } /* if ino points to a dir, fail the open request */ xinode = g_xrdp_fs.inode_table[ino]; if (!xinode) { log_debug("****** g_xrdp_fs.inode_table[%ld] is NULL", ino); fuse_reply_err(req, EBADF); return; } if (xinode->mode & S_IFDIR) { log_debug("reading a dir not allowed!"); fuse_reply_err(req, EISDIR); return; } device_id = xfuse_get_device_id_for_inode(ino, full_path); if (xinode->is_loc_resource) { /* specified file is a local resource */ XFUSE_HANDLE *fh = g_new0(XFUSE_HANDLE, 1); fh->is_loc_resource = 1; fi->fh = (tintptr) fh; fuse_reply_open(req, fi); return; } /* specified file resides on redirected share */ fip = g_new0(XFUSE_INFO, 1); if (fip == NULL) { log_error("system out of memory"); fuse_reply_err(req, ENOMEM); return; } fip->req = req; fip->inode = ino; fip->invoke_fuse = 1; fip->device_id = device_id; fip->fi = fi; log_debug("LK_TODO: fip->fi = %p", fip->fi); strncpy(fip->name, full_path, 1024); fip->name[1023] = 0; fip->reply_type = RT_FUSE_REPLY_OPEN; /* we want path minus 'root node of the share' */ if ((cptr = strchr(full_path, '/')) == NULL) { /* get dev_redir to open the remote file */ if (dev_redir_file_open((void *) fip, device_id, "\\", fi->flags, S_IFREG, NULL)) { log_error("failed to send dev_redir_open_file() cmd"); fuse_reply_err(req, EREMOTEIO); } } else { if (dev_redir_file_open((void *) fip, device_id, cptr, fi->flags, S_IFREG, NULL)) { log_error("failed to send dev_redir_get_dir_listing() cmd"); fuse_reply_err(req, EREMOTEIO); } } } static void xfuse_cb_release(fuse_req_t req, fuse_ino_t ino, struct fuse_file_info *fi) { XFUSE_INFO *fip = NULL; XFUSE_HANDLE *handle = (XFUSE_HANDLE *) (tintptr) (fi->fh); log_debug("entered: ino=%ld fi=%p fi->fh=0x%llx", ino, fi, (long long) fi->fh); if (!xfuse_is_inode_valid(ino)) { log_error("inode %ld is not valid", ino); fuse_reply_err(req, EBADF); return; } XRDP_INODE *xinode = g_xrdp_fs.inode_table[ino]; if (!xinode) { log_debug("****** g_xrdp_fs.inode_table[%ld] is NULL", ino); fuse_reply_err(req, 0); return; } if (xinode->is_loc_resource) { /* specified file is a local resource */ fuse_reply_err(req, 0); return; } /* specified file resides on redirected share */ log_debug("nopen=%d", xinode->nopen); /* if file is not opened, just return */ if (xinode->nopen == 0) { log_debug("cannot close because file not opened"); fuse_reply_err(req, 0); return; } fip = g_new0(XFUSE_INFO, 1); if (fip == NULL) { log_error("system out of memory"); fuse_reply_err(req, ENOMEM); return; } fip->req = req; fip->inode = ino; fip->invoke_fuse = 1; fip->device_id = handle->DeviceId; fip->fi = fi; log_debug(" +++ created XFUSE_INFO=%p XFUSE_INFO->fi=%p XFUSE_INFO->fi->fh=0x%llx", fip, fip->fi, (long long) fip->fi->fh); fip->fi->fh = 0; xinode->close_in_progress = 1; if (devredir_file_close((void *) fip, fip->device_id, handle->FileId)) { log_error("failed to send devredir_close_file() cmd"); fuse_reply_err(req, EREMOTEIO); } free(handle); } /** *****************************************************************************/ static void xfuse_cb_read(fuse_req_t req, fuse_ino_t ino, size_t size, off_t off, struct fuse_file_info *fi) { XFUSE_HANDLE *fh; XFUSE_INFO *fusep; XRDP_INODE *xinode; struct req_list_item *rli; long handle; log_debug("want_bytes %zd bytes at off %lld", size, (long long) off); if (fi->fh == 0) { fuse_reply_err(req, EINVAL); return; } handle = fi->fh; fh = (XFUSE_HANDLE *) handle; if (fh->is_loc_resource) { /* target file is in .clipboard dir */ log_debug("target file is in .clipboard dir"); if ((xinode = g_xrdp_fs.inode_table[ino]) == NULL) { log_error("ino does not exist in xrdp_fs"); fuse_reply_buf(req, 0, 0); return; } rli = g_new0(struct req_list_item, 1); rli->stream_id = 0; rli->req = req; rli->lindex = xinode->lindex; rli->off = off; rli->size = size; list_add_item(g_req_list, (tbus) rli); if (g_req_list->count == 1) { log_debug("requesting clipboard file data lindex = %d off = %lld size = %zd", rli->lindex, (long long) off, size); clipboard_request_file_data(rli->stream_id, rli->lindex, (int) off, (int) size); } return; } /* target file is on a remote device */ fusep = g_new0(XFUSE_INFO, 1); if (fusep == NULL) { log_error("system out of memory"); fuse_reply_err(req, ENOMEM); return; } fusep->req = req; fusep->inode = ino; fusep->invoke_fuse = 1; fusep->device_id = fh->DeviceId; fusep->fi = fi; devredir_file_read(fusep, fh->DeviceId, fh->FileId, size, off); } /** *****************************************************************************/ static void xfuse_cb_write(fuse_req_t req, fuse_ino_t ino, const char *buf, size_t size, off_t off, struct fuse_file_info *fi) { XFUSE_HANDLE *fh; XFUSE_INFO *fusep; long handle; log_debug("write %zd bytes at off %lld to inode=%ld", size, (long long) off, ino); if (fi->fh == 0) { log_error("file handle fi->fh is NULL"); fuse_reply_err(req, EINVAL); return; } handle = fi->fh; fh = (XFUSE_HANDLE *) handle; if (fh->is_loc_resource) { /* target file is in .clipboard dir */ log_debug("THIS IS STILL A TODO!"); return; } /* target file is on a remote device */ fusep = g_new0(XFUSE_INFO, 1); if (fusep == NULL) { log_error("system out of memory"); fuse_reply_err(req, ENOMEM); return; } fusep->req = req; fusep->inode = ino; fusep->invoke_fuse = 1; fusep->device_id = fh->DeviceId; fusep->fi = fi; log_debug("+++ created XFUSE_INFO=%p XFUSE_INFO->fi=%p XFUSE_INFO->fi->fh=0x%llx", fusep, fusep->fi, (long long) fusep->fi->fh); dev_redir_file_write(fusep, fh->DeviceId, fh->FileId, buf, size, off); log_debug("exiting"); } /** *****************************************************************************/ static void xfuse_cb_create(fuse_req_t req, fuse_ino_t parent, const char *name, mode_t mode, struct fuse_file_info *fi) { log_debug("entered: parent_inode=%ld, name=%s fi=%p", parent, name, fi); xfuse_create_dir_or_file(req, parent, name, mode, fi, S_IFREG); } /** *****************************************************************************/ #if 0 static void xfuse_cb_fsync(fuse_req_t req, fuse_ino_t ino, int datasync, struct fuse_file_info *fi) { log_debug("#################### entered: ino=%ld datasync=%d", ino, datasync); log_debug("function not required"); fuse_reply_err(req, EINVAL); } #endif /** *****************************************************************************/ static void xfuse_cb_setattr(fuse_req_t req, fuse_ino_t ino, struct stat *attr, int to_set, struct fuse_file_info *fi) { XRDP_INODE *xinode; struct stat st; log_debug("entered to_set=0x%x", to_set); if (!xfuse_is_inode_valid(ino)) { log_error("inode %ld is not valid", ino); fuse_reply_err(req, EBADF); return; } if ((xinode = g_xrdp_fs.inode_table[ino]) == NULL) { log_debug("g_xrdp_fs.inode_table[%ld] is NULL", ino); fuse_reply_err(req, EBADF); return; } if (to_set & FUSE_SET_ATTR_MODE) { xinode->mode = attr->st_mode; log_debug("FUSE_SET_ATTR_MODE"); } if (to_set & FUSE_SET_ATTR_UID) { xinode->uid = attr->st_uid; log_debug("FUSE_SET_ATTR_UID"); } if (to_set & FUSE_SET_ATTR_GID) { xinode->gid = attr->st_gid; log_debug("FUSE_SET_ATTR_GID"); } if (to_set & FUSE_SET_ATTR_SIZE) { log_debug("previous file size: %lld", (long long) attr->st_size); xinode->size = attr->st_size; log_debug("returning file size: %zd", xinode->size); } if (to_set & FUSE_SET_ATTR_ATIME) { xinode->atime = attr->st_atime; log_debug("FUSE_SET_ATTR_ATIME"); } if (to_set & FUSE_SET_ATTR_MTIME) { xinode->mtime = attr->st_mtime; log_debug("FUSE_SET_ATTR_MTIME"); } if (to_set & FUSE_SET_ATTR_ATIME_NOW) { xinode->atime = attr->st_atime; log_debug("FUSE_SET_ATTR_ATIME_NOW"); } if (to_set & FUSE_SET_ATTR_MTIME_NOW) { xinode->mtime = attr->st_mtime; log_debug("FUSE_SET_ATTR_MTIME_NOW"); } memset(&st, 0, sizeof(st)); st.st_ino = xinode->inode; st.st_mode = xinode->mode; st.st_size = xinode->size; st.st_uid = xinode->uid; st.st_gid = xinode->gid; st.st_atime = xinode->atime; st.st_mtime = xinode->mtime; st.st_ctime = xinode->ctime; fuse_reply_attr(req, &st, 1.0); /* LK_TODO just faking for now */ } /** * Get dir listing *****************************************************************************/ static void xfuse_cb_opendir(fuse_req_t req, fuse_ino_t ino, struct fuse_file_info *fi) { struct opendir_req *odreq; /* save request */ odreq = g_new(struct opendir_req, 1); odreq->req = req; odreq->ino = ino; odreq->fi = fi; if (fifo_is_empty(&g_fifo_opendir)) { fifo_insert(&g_fifo_opendir, odreq); xfuse_proc_opendir_req(req, ino, fi); } else { /* place req in FIFO; xfuse_devredir_cb_enum_dir_done() will handle it */ fifo_insert(&g_fifo_opendir, odreq); } } /** * Process the next opendir req * * @return 0 of the request was sent for remote lookup, -1 otherwise *****************************************************************************/ static int xfuse_proc_opendir_req(fuse_req_t req, fuse_ino_t ino, struct fuse_file_info *fi) { struct dir_info *di; XRDP_INODE *xinode; XFUSE_INFO *fip; tui32 device_id; char full_path[4096]; char *cptr; log_debug("inode=%ld", ino); if (!xfuse_is_inode_valid(ino)) { log_error("inode %ld is not valid", ino); fuse_reply_err(req, EBADF); g_free(fifo_remove(&g_fifo_opendir)); return -1; } if (ino == 1) goto done; /* special case; enumerate top level dir */ if ((xinode = g_xrdp_fs.inode_table[ino]) == NULL) { log_debug("g_xrdp_fs.inode_table[%ld] is NULL", ino); fuse_reply_err(req, EBADF); g_free(fifo_remove(&g_fifo_opendir)); return -1; } if (xinode->is_loc_resource) goto done; /* enumerate resources on a remote device */ #ifdef USE_SYNC_FLAG if (xinode->is_synced) { xfuse_enum_dir(req, ino, size, off, fi); g_free(fifo_remove(&g_fifo_opendir)); return -1; } else { goto do_remote_lookup; } do_remote_lookup: #endif xfuse_mark_as_stale(ino); log_debug("did not find entry; redirecting call to dev_redir"); device_id = xfuse_get_device_id_for_inode(ino, full_path); log_debug("dev_id=%d ino=%ld full_path=%s", device_id, ino, full_path); fip = g_new0(XFUSE_INFO, 1); if (fip == NULL) { log_error("system out of memory"); fuse_reply_err(req, ENOMEM); g_free(fifo_remove(&g_fifo_opendir)); return -1; } fip->req = req; fip->inode = ino; fip->size = 0; fip->off = 0; fip->fi = fi; fip->dirbuf1.first_time = 1; fip->dirbuf1.bytes_in_buf = 0; fip->invoke_fuse = 1; fip->device_id = device_id; /* we want path minus 'root node of the share' */ if ((cptr = strchr(full_path, '/')) == NULL) { /* enumerate root dir */ if (dev_redir_get_dir_listing((void *) fip, device_id, "\\")) { log_error("failed to send dev_redir_get_dir_listing() cmd"); fuse_reply_buf(req, NULL, 0); } } else { if (dev_redir_get_dir_listing((void *) fip, device_id, cptr)) { log_error("failed to send dev_redir_get_dir_listing() cmd"); fuse_reply_buf(req, NULL, 0); } } return 0; done: di = g_new0(struct dir_info, 1); di->index = FIRST_INODE; fi->fh = (tintptr) di; fuse_reply_open(req, fi); g_free(fifo_remove(&g_fifo_opendir)); return -1; } /** *****************************************************************************/ static void xfuse_cb_releasedir(fuse_req_t req, fuse_ino_t ino, struct fuse_file_info *fi) { struct dir_info *di; di = (struct dir_info *) (tintptr) fi->fh; if (di) free(di); fuse_reply_err(req, 0); } /****************************************************************************** * miscellaneous functions *****************************************************************************/ /** * Mark all files with matching parent inode as stale * * @param pinode the parent inode *****************************************************************************/ static void xfuse_mark_as_stale(fuse_ino_t pinode) { fuse_ino_t i; XRDP_INODE *xinode; if ((pinode < FIRST_INODE) || (pinode >= g_xrdp_fs.num_entries)) return; for (i = FIRST_INODE; i < g_xrdp_fs.num_entries; i++) { if ((xinode = g_xrdp_fs.inode_table[i]) == NULL) continue; /* match parent inode */ if (xinode->parent_inode != pinode) continue; /* got a match */ xinode->stale = 1; } } /** * Delete all files with matching parent inode that are marked as stale * * @param pinode the parent inode *****************************************************************************/ static void xfuse_delete_stale_entries(fuse_ino_t pinode) { fuse_ino_t i; XRDP_INODE *xinode; if ((pinode < FIRST_INODE) || (pinode >= g_xrdp_fs.num_entries)) return; for (i = FIRST_INODE; i < g_xrdp_fs.num_entries; i++) { if ((xinode = g_xrdp_fs.inode_table[i]) == NULL) continue; /* match parent inode */ if (xinode->parent_inode != pinode) continue; /* got a match, but is it stale? */ if (!xinode->stale) continue; /* ok to delete */ if (xinode->mode & S_IFREG) xfuse_delete_file_with_xinode(xinode); else xfuse_recursive_delete_dir_with_xinode(xinode); } } #endif /* end else #ifndef XRDP_FUSE */ xrdp-0.9.5/sesman/chansrv/devredir.c000644 001751 001751 00000142522 13213711022 017322 0ustar00metameta000000 000000 /** * xrdp: A Remote Desktop Protocol server. * * xrdp device redirection - only drive redirection is currently supported * * Copyright (C) Laxmikant Rashinkar 2013 LK.Rashinkar@gmail.com * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ /* * TODO * o there is one difference in the protocol initialization * sequence upon reconnection: if a user is already logged on, * send a SERVER_USER_LOGGED_ON msg as per section 3.3.5.1.5 * * o how to announce / delete a drive after a connection has been * established? * * o need to support multiple drives; * o for multiple drives, we cannot have global device_id's and file_id's * and all functions must be reenterant * o replace printf's with log_xxx * o mark local funcs with static */ #if defined(HAVE_CONFIG_H) #include #endif #include #include #include #include #include #include #include #include "arch.h" #include "parse.h" #include "os_calls.h" #include "log.h" #include "chansrv.h" #include "chansrv_fuse.h" #include "devredir.h" #include "smartcard.h" /* module based logging */ #define LOG_ERROR 0 #define LOG_INFO 1 #define LOG_DEBUG 2 #ifndef LOG_LEVEL #define LOG_LEVEL LOG_ERROR #endif #define log_error(_params...) \ { \ g_write("[%10.10u]: DEV_REDIR %s: %d : ERROR: ", \ g_time3(), __func__, __LINE__); \ g_writeln (_params); \ } #define log_info(_params...) \ { \ if (LOG_INFO <= LOG_LEVEL) \ { \ g_write("[%10.10u]: DEV_REDIR %s: %d : ", \ g_time3(), __func__, __LINE__); \ g_writeln (_params); \ } \ } #define log_debug(_params...) \ { \ if (LOG_DEBUG <= LOG_LEVEL) \ { \ g_write("[%10.10u]: DEV_REDIR %s: %d : ", \ g_time3(), __func__, __LINE__); \ g_writeln (_params); \ } \ } /* globals */ extern int g_rdpdr_chan_id; /* in chansrv.c */ int g_is_printer_redir_supported = 0; int g_is_port_redir_supported = 0; int g_is_drive_redir_supported = 0; int g_is_smartcard_redir_supported = 0; int g_drive_redir_version = 1; char g_full_name_for_filesystem[1024]; tui32 g_completion_id = 1; tui32 g_clientID; /* unique client ID - announced by client */ tui32 g_device_id; /* unique device ID - announced by client */ tui16 g_client_rdp_version; /* returned by client */ struct stream *g_input_stream = NULL; void xfuse_devredir_cb_write_file(void *vp, const char *buf, size_t length); /*****************************************************************************/ int dev_redir_init(void) { struct stream *s; int bytes; int fd; union _u { tui32 clientID; char buf[4]; } u; /* get a random number that will act as a unique clientID */ if ((fd = open("/dev/urandom", O_RDONLY)) != -1) { if (read(fd, u.buf, 4) != 4) { } close(fd); } else { /* /dev/urandom did not work - use address of struct s */ tui64 u64 = (tui64) (tintptr) &s; u.clientID = (tui32) u64; } /* setup stream */ xstream_new(s, 1024); /* initiate drive redirection protocol by sending Server Announce Req */ xstream_wr_u16_le(s, RDPDR_CTYP_CORE); xstream_wr_u16_le(s, PAKID_CORE_SERVER_ANNOUNCE); xstream_wr_u16_le(s, 0x0001); /* server major ver */ xstream_wr_u16_le(s, 0x000C); /* server minor ver - pretend 2 b Win 7 */ xstream_wr_u32_le(s, u.clientID); /* unique ClientID */ /* send data to client */ bytes = xstream_len(s); send_channel_data(g_rdpdr_chan_id, s->data, bytes); xstream_free(s); return 0; } /*****************************************************************************/ int dev_redir_deinit(void) { scard_deinit(); return 0; } /** * @brief process incoming data * * @return 0 on success, -1 on failure *****************************************************************************/ int dev_redir_data_in(struct stream *s, int chan_id, int chan_flags, int length, int total_length) { struct stream *ls; tui16 comp_type; tui16 pktID; tui16 minor_ver; int rv = 0; /* * handle packet fragmentation */ if ((chan_flags & 3) == 3) { /* all data contained in one packet */ ls = s; } else { /* is this is the first packet? */ if (chan_flags & 1) xstream_new(g_input_stream, total_length); xstream_copyin(g_input_stream, s->p, length); /* in last packet, chan_flags & 0x02 will be true */ if ((chan_flags & 2) == 0) return 0; g_input_stream->p = g_input_stream->data; ls = g_input_stream; } /* read header from incoming data */ xstream_rd_u16_le(ls, comp_type); xstream_rd_u16_le(ls, pktID); /* for now we only handle core type, not printers */ if (comp_type != RDPDR_CTYP_CORE) { log_error("invalid component type in response; expected 0x%x got 0x%x", RDPDR_CTYP_CORE, comp_type); rv = -1; goto done; } /* figure out what kind of response we have gotten */ switch (pktID) { case PAKID_CORE_CLIENTID_CONFIRM: xstream_seek(ls, 2); /* major version, we ignore it */ xstream_rd_u16_le(ls, minor_ver); xstream_rd_u32_le(ls, g_clientID); g_client_rdp_version = minor_ver; switch (minor_ver) { case RDP_CLIENT_50: break; case RDP_CLIENT_51: break; case RDP_CLIENT_52: break; case RDP_CLIENT_60_61: break; } // LK_TODO dev_redir_send_server_clientID_confirm(); break; case PAKID_CORE_CLIENT_NAME: /* client is telling us its computer name; do we even care? */ /* let client know login was successful */ dev_redir_send_server_user_logged_on(); usleep(1000 * 100); /* let client know our capabilities */ dev_redir_send_server_core_cap_req(); /* send confirm clientID */ dev_redir_send_server_clientID_confirm(); break; case PAKID_CORE_CLIENT_CAPABILITY: dev_redir_proc_client_core_cap_resp(ls); break; case PAKID_CORE_DEVICELIST_ANNOUNCE: devredir_proc_client_devlist_announce_req(ls); break; case PAKID_CORE_DEVICE_IOCOMPLETION: dev_redir_proc_device_iocompletion(ls); break; default: log_error("got unknown response 0x%x", pktID); break; } done: if (g_input_stream) { xstream_free(g_input_stream); g_input_stream = NULL; } return rv; } /*****************************************************************************/ int dev_redir_get_wait_objs(tbus *objs, int *count, int *timeout) { if (g_is_smartcard_redir_supported) { return scard_get_wait_objs(objs, count, timeout); } return 0; } /*****************************************************************************/ int dev_redir_check_wait_objs(void) { if (g_is_smartcard_redir_supported) { return scard_check_wait_objs(); } return 0; } /** * @brief let client know our capabilities *****************************************************************************/ void dev_redir_send_server_core_cap_req(void) { struct stream *s; int bytes; xstream_new(s, 1024); /* setup header */ xstream_wr_u16_le(s, RDPDR_CTYP_CORE); xstream_wr_u16_le(s, PAKID_CORE_SERVER_CAPABILITY); xstream_wr_u16_le(s, 5); /* num of caps we are sending */ xstream_wr_u16_le(s, 0x0000); /* padding */ /* setup general capability */ xstream_wr_u16_le(s, CAP_GENERAL_TYPE); /* CapabilityType */ xstream_wr_u16_le(s, 44); /* CapabilityLength - len of this */ /* CAPABILITY_SET in bytes, inc */ /* the header */ xstream_wr_u32_le(s, 2); /* Version */ xstream_wr_u32_le(s, 2); /* O.S type */ xstream_wr_u32_le(s, 0); /* O.S version */ xstream_wr_u16_le(s, 1); /* protocol major version */ xstream_wr_u16_le(s, g_client_rdp_version); /* protocol minor version */ xstream_wr_u32_le(s, 0xffff); /* I/O code 1 */ xstream_wr_u32_le(s, 0); /* I/O code 2 */ xstream_wr_u32_le(s, 7); /* Extended PDU */ xstream_wr_u32_le(s, 0); /* extra flags 1 */ xstream_wr_u32_le(s, 0); /* extra flags 2 */ xstream_wr_u32_le(s, 2); /* special type device cap */ /* setup printer capability */ xstream_wr_u16_le(s, CAP_PRINTER_TYPE); xstream_wr_u16_le(s, 8); xstream_wr_u32_le(s, 1); /* setup serial port capability */ xstream_wr_u16_le(s, CAP_PORT_TYPE); xstream_wr_u16_le(s, 8); xstream_wr_u32_le(s, 1); /* setup file system capability */ xstream_wr_u16_le(s, CAP_DRIVE_TYPE); /* CapabilityType */ xstream_wr_u16_le(s, 8); /* CapabilityLength - len of this */ /* CAPABILITY_SET in bytes, inc */ /* the header */ xstream_wr_u32_le(s, 2); /* Version */ /* setup smart card capability */ xstream_wr_u16_le(s, CAP_SMARTCARD_TYPE); xstream_wr_u16_le(s, 8); xstream_wr_u32_le(s, 1); /* send to client */ bytes = xstream_len(s); send_channel_data(g_rdpdr_chan_id, s->data, bytes); xstream_free(s); } void dev_redir_send_server_clientID_confirm(void) { struct stream *s; int bytes; xstream_new(s, 1024); /* setup stream */ xstream_wr_u16_le(s, RDPDR_CTYP_CORE); xstream_wr_u16_le(s, PAKID_CORE_CLIENTID_CONFIRM); xstream_wr_u16_le(s, 0x0001); xstream_wr_u16_le(s, g_client_rdp_version); xstream_wr_u32_le(s, g_clientID); /* send to client */ bytes = xstream_len(s); send_channel_data(g_rdpdr_chan_id, s->data, bytes); xstream_free(s); } void dev_redir_send_server_user_logged_on(void) { struct stream *s; int bytes; xstream_new(s, 1024); /* setup stream */ xstream_wr_u16_le(s, RDPDR_CTYP_CORE); xstream_wr_u16_le(s, PAKID_CORE_USER_LOGGEDON); /* send to client */ bytes = xstream_len(s); send_channel_data(g_rdpdr_chan_id, s->data, bytes); xstream_free(s); } void devredir_send_server_device_announce_resp(tui32 device_id) { struct stream *s; int bytes; xstream_new(s, 1024); /* setup stream */ xstream_wr_u16_le(s, RDPDR_CTYP_CORE); xstream_wr_u16_le(s, PAKID_CORE_DEVICE_REPLY); xstream_wr_u32_le(s, device_id); xstream_wr_u32_le(s, 0); /* ResultCode */ /* send to client */ bytes = xstream_len(s); send_channel_data(g_rdpdr_chan_id, s->data, bytes); xstream_free(s); } /** * @return 0 on success, -1 on failure *****************************************************************************/ int dev_redir_send_drive_create_request(tui32 device_id, const char *path, tui32 DesiredAccess, tui32 CreateOptions, tui32 CreateDisposition, tui32 completion_id) { struct stream *s; int bytes; int len; log_debug("DesiredAccess=0x%x CreateDisposition=0x%x CreateOptions=0x%x", DesiredAccess, CreateDisposition, CreateOptions); /* path in unicode needs this much space */ len = ((g_mbstowcs(NULL, path, 0) * sizeof(twchar)) / 2) + 2; xstream_new(s, 1024 + len); devredir_insert_DeviceIoRequest(s, device_id, 0, completion_id, IRP_MJ_CREATE, 0); xstream_wr_u32_le(s, DesiredAccess); /* DesiredAccess */ xstream_wr_u32_le(s, 0); /* AllocationSize high unused */ xstream_wr_u32_le(s, 0); /* AllocationSize low unused */ xstream_wr_u32_le(s, 0); /* FileAttributes */ xstream_wr_u32_le(s, 3); /* SharedAccess LK_TODO */ xstream_wr_u32_le(s, CreateDisposition); /* CreateDisposition */ xstream_wr_u32_le(s, CreateOptions); /* CreateOptions */ xstream_wr_u32_le(s, len); /* PathLength */ devredir_cvt_to_unicode(s->p, path); /* path in unicode */ xstream_seek(s, len); /* send to client */ bytes = xstream_len(s); send_channel_data(g_rdpdr_chan_id, s->data, bytes); xstream_free(s); return 0; } /** * Close a request previously created by dev_redir_send_drive_create_request() *****************************************************************************/ int dev_redir_send_drive_close_request(tui16 Component, tui16 PacketId, tui32 DeviceId, tui32 FileId, tui32 CompletionId, tui32 MajorFunction, tui32 MinorFunc, int pad_len) { struct stream *s; int bytes; xstream_new(s, 1024); devredir_insert_DeviceIoRequest(s, DeviceId, FileId, CompletionId, MajorFunction, MinorFunc); if (pad_len) xstream_seek(s, pad_len); /* send to client */ bytes = xstream_len(s); send_channel_data(g_rdpdr_chan_id, s->data, bytes); xstream_free(s); log_debug("sent close request; expect CID_FILE_CLOSE"); return 0; } /** * @brief ask client to enumerate directory * * Server Drive Query Directory Request * DR_DRIVE_QUERY_DIRECTORY_REQ * *****************************************************************************/ // LK_TODO Path needs to be Unicode void dev_redir_send_drive_dir_request(IRP *irp, tui32 device_id, tui32 InitialQuery, char *Path) { struct stream *s; int bytes; char upath[4096]; // LK_TODO need to malloc this int path_len = 0; /* during Initial Query, Path cannot be NULL */ if (InitialQuery) { if (Path == NULL) { return; } /* Path in unicode needs this much space */ path_len = ((g_mbstowcs(NULL, Path, 0) * sizeof(twchar)) / 2) + 2; devredir_cvt_to_unicode(upath, Path); } xstream_new(s, 1024 + path_len); irp->completion_type = CID_DIRECTORY_CONTROL; devredir_insert_DeviceIoRequest(s, device_id, irp->FileId, irp->CompletionId, IRP_MJ_DIRECTORY_CONTROL, IRP_MN_QUERY_DIRECTORY); #ifdef USE_SHORT_NAMES_IN_DIR_LISTING xstream_wr_u32_le(s, FileBothDirectoryInformation); /* FsInformationClass */ #else xstream_wr_u32_le(s, FileDirectoryInformation); /* FsInformationClass */ #endif xstream_wr_u8(s, InitialQuery); /* InitialQuery */ if (!InitialQuery) { xstream_wr_u32_le(s, 0); /* PathLength */ xstream_seek(s, 23); } else { xstream_wr_u32_le(s, path_len); /* PathLength */ xstream_seek(s, 23); /* Padding */ xstream_wr_string(s, upath, path_len); } /* send to client */ bytes = xstream_len(s); send_channel_data(g_rdpdr_chan_id, s->data, bytes); xstream_free(s); } /****************************************************************************** ** process data received from client ** ******************************************************************************/ /** * @brief process client's response to our core_capability_req() msg * * @param s stream containing client's response *****************************************************************************/ void dev_redir_proc_client_core_cap_resp(struct stream *s) { int i; tui16 num_caps; tui16 cap_type; tui16 cap_len; tui32 cap_version; char* holdp; xstream_rd_u16_le(s, num_caps); xstream_seek(s, 2); /* padding */ for (i = 0; i < num_caps; i++) { holdp = s->p; xstream_rd_u16_le(s, cap_type); xstream_rd_u16_le(s, cap_len); xstream_rd_u32_le(s, cap_version); switch (cap_type) { case CAP_GENERAL_TYPE: log_debug("got CAP_GENERAL_TYPE"); break; case CAP_PRINTER_TYPE: log_debug("got CAP_PRINTER_TYPE"); g_is_printer_redir_supported = 1; break; case CAP_PORT_TYPE: log_debug("got CAP_PORT_TYPE"); g_is_port_redir_supported = 1; break; case CAP_DRIVE_TYPE: log_debug("got CAP_DRIVE_TYPE"); g_is_drive_redir_supported = 1; if (cap_version == 2) { g_drive_redir_version = 2; } break; case CAP_SMARTCARD_TYPE: log_debug("got CAP_SMARTCARD_TYPE"); g_is_smartcard_redir_supported = 1; scard_init(); break; } s->p = holdp + cap_len; } } void devredir_proc_client_devlist_announce_req(struct stream *s) { unsigned int i; int j; tui32 device_count; tui32 device_type; tui32 device_data_len; char preferred_dos_name[9]; /* get number of devices being announced */ xstream_rd_u32_le(s, device_count); log_debug("num of devices announced: %d", device_count); for (i = 0; i < device_count; i++) { xstream_rd_u32_le(s, device_type); xstream_rd_u32_le(s, g_device_id); switch (device_type) { case RDPDR_DTYP_FILESYSTEM: /* get preferred DOS name */ for (j = 0; j < 8; j++) { preferred_dos_name[j] = *s->p++; } /* DOS names that are 8 chars long are not NULL terminated */ preferred_dos_name[8] = 0; /* get device data len */ xstream_rd_u32_le(s, device_data_len); if (device_data_len) { xstream_rd_string(g_full_name_for_filesystem, s, device_data_len); } log_debug("device_type=FILE_SYSTEM device_id=0x%x dosname=%s " "device_data_len=%d full_name=%s", g_device_id, preferred_dos_name, device_data_len, g_full_name_for_filesystem); devredir_send_server_device_announce_resp(g_device_id); /* create share directory in xrdp file system; */ /* think of this as the mount point for this share */ xfuse_create_share(g_device_id, preferred_dos_name); break; case RDPDR_DTYP_SMARTCARD: /* get preferred DOS name */ for (j = 0; j < 8; j++) { preferred_dos_name[j] = *s->p++; } /* DOS names that are 8 chars long are not NULL terminated */ preferred_dos_name[8] = 0; /* for smart cards, device data len always 0 */ log_debug("device_type=SMARTCARD device_id=0x%x dosname=%s", g_device_id, preferred_dos_name); devredir_send_server_device_announce_resp(g_device_id); scard_device_announce(g_device_id); break; /* we don't yet support these devices */ case RDPDR_DTYP_SERIAL: case RDPDR_DTYP_PARALLEL: case RDPDR_DTYP_PRINT: log_debug("unsupported dev: 0x%x", device_type); break; } } } void dev_redir_proc_device_iocompletion(struct stream *s) { FUSE_DATA *fuse_data = NULL; IRP *irp = NULL; tui32 DeviceId; tui32 CompletionId; tui32 IoStatus; tui32 Length; xstream_rd_u32_le(s, DeviceId); xstream_rd_u32_le(s, CompletionId); xstream_rd_u32_le(s, IoStatus); log_debug("entered: IoStatus=0x%x CompletionId=%d", IoStatus, CompletionId); if ((irp = devredir_irp_find(CompletionId)) == NULL) { log_error("IRP with completion ID %d not found", CompletionId); return; } /* if callback has been set, call it */ if (irp->callback) { (*irp->callback)(s, irp, DeviceId, CompletionId, IoStatus); goto done; } switch (irp->completion_type) { case CID_CREATE_DIR_REQ: log_debug("got CID_CREATE_DIR_REQ"); if (IoStatus != NT_STATUS_SUCCESS) { /* we were trying to create a request to enumerate a dir */ /* that does not exist; let FUSE know */ fuse_data = devredir_fuse_data_dequeue(irp); if (fuse_data) { xfuse_devredir_cb_enum_dir_done(fuse_data->data_ptr, IoStatus); free(fuse_data); } devredir_irp_delete(irp); return; } xstream_rd_u32_le(s, irp->FileId); log_debug("got CID_CREATE_DIR_REQ IoStatus=0x%x FileId=%d", IoStatus, irp->FileId); dev_redir_send_drive_dir_request(irp, DeviceId, 1, irp->pathname); break; case CID_CREATE_OPEN_REQ: xstream_rd_u32_le(s, irp->FileId); log_debug("got CID_CREATE_OPEN_REQ IoStatus=0x%x FileId=%d", IoStatus, irp->FileId); fuse_data = devredir_fuse_data_dequeue(irp); xfuse_devredir_cb_open_file(fuse_data->data_ptr, IoStatus, DeviceId, irp->FileId); if ((irp->type == S_IFDIR) || (IoStatus != NT_STATUS_SUCCESS)) devredir_irp_delete(irp); break; case CID_READ: log_debug("got CID_READ"); xstream_rd_u32_le(s, Length); fuse_data = devredir_fuse_data_dequeue(irp); if (fuse_data == NULL) { log_error("fuse_data is NULL"); } else { xfuse_devredir_cb_read_file(fuse_data->data_ptr, s->p, Length); devredir_irp_delete(irp); } break; case CID_WRITE: log_debug("got CID_WRITE"); xstream_rd_u32_le(s, Length); fuse_data = devredir_fuse_data_dequeue(irp); if (fuse_data == NULL) { log_error("fuse_data is NULL"); } else { xfuse_devredir_cb_write_file(fuse_data->data_ptr, s->p, Length); devredir_irp_delete(irp); } break; case CID_CLOSE: log_debug("got CID_CLOSE"); log_debug("deleting irp with completion_id=%d comp_type=%d", irp->CompletionId, irp->completion_type); devredir_irp_delete(irp); break; case CID_FILE_CLOSE: log_debug("got CID_FILE_CLOSE"); fuse_data = devredir_fuse_data_dequeue(irp); xfuse_devredir_cb_file_close(fuse_data->data_ptr); devredir_irp_delete(irp); break; case CID_DIRECTORY_CONTROL: log_debug("got CID_DIRECTORY_CONTROL"); dev_redir_proc_query_dir_response(irp, s, DeviceId, CompletionId, IoStatus); break; case CID_RMDIR_OR_FILE: log_debug("got CID_RMDIR_OR_FILE"); xstream_rd_u32_le(s, irp->FileId); devredir_proc_cid_rmdir_or_file(irp, IoStatus); return; break; case CID_RMDIR_OR_FILE_RESP: log_debug("got CID_RMDIR_OR_FILE_RESP"); devredir_proc_cid_rmdir_or_file_resp(irp, IoStatus); break; case CID_RENAME_FILE: log_debug("got CID_RENAME_FILE"); xstream_rd_u32_le(s, irp->FileId); devredir_proc_cid_rename_file(irp, IoStatus); return; break; case CID_RENAME_FILE_RESP: log_debug("got CID_RENAME_FILE_RESP"); devredir_proc_cid_rename_file_resp(irp, IoStatus); break; default: log_error("got unknown CompletionID: DeviceId=0x%x " "CompletionId=0x%x IoStatus=0x%x", DeviceId, CompletionId, IoStatus); break; } done: if (fuse_data) { log_debug("free FUSE_DATA=%p", fuse_data); free(fuse_data); } log_debug("exiting"); } void dev_redir_proc_query_dir_response(IRP *irp, struct stream *s_in, tui32 DeviceId, tui32 CompletionId, tui32 IoStatus) { FUSE_DATA *fuse_data = NULL; XRDP_INODE *xinode; tui32 Length; tui64 CreationTime; tui64 LastAccessTime; tui64 LastWriteTime; tui64 EndOfFile; tui32 FileAttributes; tui32 FileNameLength; tui32 status; char filename[256]; unsigned int i = 0; xstream_rd_u32_le(s_in, Length); if ((IoStatus == NT_STATUS_UNSUCCESSFUL) || (IoStatus == STATUS_NO_MORE_FILES)) { status = (IoStatus == STATUS_NO_MORE_FILES) ? 0 : IoStatus; fuse_data = devredir_fuse_data_dequeue(irp); xfuse_devredir_cb_enum_dir_done(fuse_data->data_ptr, status); irp->completion_type = CID_CLOSE; dev_redir_send_drive_close_request(RDPDR_CTYP_CORE, PAKID_CORE_DEVICE_IOREQUEST, DeviceId, irp->FileId, irp->CompletionId, IRP_MJ_CLOSE, 0, 32); free(fuse_data); return; } /* TODO check status for errors */ /* process FILE_DIRECTORY_INFORMATION structures */ while (i < Length) { log_debug("processing FILE_DIRECTORY_INFORMATION structs"); xstream_seek(s_in, 4); /* NextEntryOffset */ xstream_seek(s_in, 4); /* FileIndex */ xstream_rd_u64_le(s_in, CreationTime); xstream_rd_u64_le(s_in, LastAccessTime); xstream_rd_u64_le(s_in, LastWriteTime); xstream_seek(s_in, 8); /* ChangeTime */ xstream_rd_u64_le(s_in, EndOfFile); xstream_seek(s_in, 8); /* AllocationSize */ xstream_rd_u32_le(s_in, FileAttributes); xstream_rd_u32_le(s_in, FileNameLength); #ifdef USE_SHORT_NAMES_IN_DIR_LISTING xstream_seek(s_in, 4); /* EaSize */ xstream_seek(s_in, 1); /* ShortNameLength */ xstream_seek(s_in, 1); /* Reserved */ xstream_seek(s_in, 23); /* ShortName in Unicode */ #endif devredir_cvt_from_unicode_len(filename, s_in->p, FileNameLength); #ifdef USE_SHORT_NAMES_IN_DIR_LISTING i += 70 + 23 + FileNameLength; #else i += 64 + FileNameLength; #endif //log_debug("CreationTime: 0x%llx", CreationTime); //log_debug("LastAccessTime: 0x%llx", LastAccessTime); //log_debug("LastWriteTime: 0x%llx", LastWriteTime); //log_debug("EndOfFile: %lld", EndOfFile); //log_debug("FileAttributes: 0x%x", FileAttributes); #ifdef USE_SHORT_NAMES_IN_DIR_LISTING //log_debug("ShortNameLength: %d", ShortNameLength); #endif //log_debug("FileNameLength: %d", FileNameLength); log_debug("FileName: %s", filename); xinode = g_new0(struct xrdp_inode, 1); if (xinode == NULL) { log_error("system out of memory"); fuse_data = devredir_fuse_data_peek(irp); xfuse_devredir_cb_enum_dir(fuse_data->data_ptr, NULL); return; } strcpy(xinode->name, filename); xinode->size = (size_t) EndOfFile; xinode->mode = WINDOWS_TO_LINUX_FILE_PERM(FileAttributes); xinode->atime = WINDOWS_TO_LINUX_TIME(LastAccessTime); xinode->mtime = WINDOWS_TO_LINUX_TIME(LastWriteTime); xinode->ctime = WINDOWS_TO_LINUX_TIME(CreationTime); /* add this entry to xrdp file system */ fuse_data = devredir_fuse_data_peek(irp); xfuse_devredir_cb_enum_dir(fuse_data->data_ptr, xinode); } dev_redir_send_drive_dir_request(irp, DeviceId, 0, NULL); } /** * FUSE calls this function whenever it wants us to enumerate a dir * * @param fusep opaque data struct that we just pass back to FUSE when done * @param device_id device_id of the redirected share * @param path the dir path to enumerate * * @return 0 on success, -1 on failure *****************************************************************************/ int dev_redir_get_dir_listing(void *fusep, tui32 device_id, const char *path) { tui32 DesiredAccess; tui32 CreateOptions; tui32 CreateDisposition; int rval; IRP *irp; log_debug("fusep=%p", fusep); if ((irp = devredir_irp_new()) == NULL) return -1; strncpy(irp->pathname, path, 255); /* convert / to windows compatible \ */ devredir_cvt_slash(irp->pathname); irp->CompletionId = g_completion_id++; irp->completion_type = CID_CREATE_DIR_REQ; irp->DeviceId = device_id; devredir_fuse_data_enqueue(irp, fusep); DesiredAccess = DA_FILE_READ_DATA | DA_SYNCHRONIZE; CreateOptions = CO_FILE_DIRECTORY_FILE | CO_FILE_SYNCHRONOUS_IO_NONALERT; CreateDisposition = CD_FILE_OPEN; rval = dev_redir_send_drive_create_request(device_id, irp->pathname, DesiredAccess, CreateOptions, CreateDisposition, irp->CompletionId); log_debug("looking for device_id=%d path=%s", device_id, irp->pathname); /* when we get a response to dev_redir_send_drive_create_request(), we */ /* call dev_redir_send_drive_dir_request(), which needs the following */ /* at the end of the path argument */ if (dev_redir_string_ends_with(irp->pathname, '\\')) strcat(irp->pathname, "*"); else strcat(irp->pathname, "\\*"); return rval; } int dev_redir_file_open(void *fusep, tui32 device_id, const char *path, int mode, int type, const char *gen_buf) { tui32 DesiredAccess; tui32 CreateOptions; tui32 CreateDisposition; int rval; IRP *irp; log_debug("device_id=%d path=%s mode=0x%x", device_id, path, mode); if ((irp = devredir_irp_new()) == NULL) return -1; if (type & OP_RENAME_FILE) { irp->completion_type = CID_RENAME_FILE; strncpy(irp->gen_buf, gen_buf, 1023); } else { irp->completion_type = CID_CREATE_OPEN_REQ; } irp->CompletionId = g_completion_id++; irp->DeviceId = device_id; strncpy(irp->pathname, path, 255); devredir_fuse_data_enqueue(irp, fusep); if (mode & O_CREAT) { log_debug("open file in O_CREAT"); DesiredAccess = 0x0016019f; /* got this value from windows */ if (type & S_IFDIR) { log_debug("creating dir"); CreateOptions = CO_FILE_DIRECTORY_FILE | CO_FILE_SYNCHRONOUS_IO_NONALERT; irp->type = S_IFDIR; } else { log_debug("creating file"); CreateOptions = 0x44; /* got this value from windows */ } //CreateDisposition = CD_FILE_CREATE; CreateDisposition = 0x02; /* got this value from windows */ } else { log_debug("open file in O_RDWR"); #if 1 /* without the 0x00000010 rdesktop opens files in */ /* O_RDONLY instead of O_RDWR mode */ if (mode & O_RDWR) DesiredAccess = DA_FILE_READ_DATA | DA_FILE_WRITE_DATA | DA_SYNCHRONIZE | 0x00000010; else DesiredAccess = DA_FILE_READ_DATA | DA_SYNCHRONIZE; CreateOptions = CO_FILE_SYNCHRONOUS_IO_NONALERT; CreateDisposition = CD_FILE_OPEN; // WAS 1 #else /* got this value from windows; the 0x00000010 was added by LK; */ /* without this rdesktop opens files in O_RDONLY instead of */ /* O_RDWR mode */ DesiredAccess = 0x00120089 | 0x00000010; CreateOptions = 0x20060; CreateDisposition = 0x01; #endif } rval = dev_redir_send_drive_create_request(device_id, path, DesiredAccess, CreateOptions, CreateDisposition, irp->CompletionId); return rval; } int devredir_file_close(void *fusep, tui32 device_id, tui32 FileId) { IRP *irp; log_debug("entered: fusep=%p device_id=%d FileId=%d", fusep, device_id, FileId); #if 0 if ((irp = devredir_irp_new()) == NULL) return -1; irp->CompletionId = g_completion_id++; #else if ((irp = devredir_irp_find_by_fileid(FileId)) == NULL) { log_error("no IRP found with FileId = %d", FileId); return -1; } #endif irp->completion_type = CID_FILE_CLOSE; irp->DeviceId = device_id; devredir_fuse_data_enqueue(irp, fusep); return dev_redir_send_drive_close_request(RDPDR_CTYP_CORE, PAKID_CORE_DEVICE_IOREQUEST, device_id, FileId, irp->CompletionId, IRP_MJ_CLOSE, 0, 32); } /** * Remove (delete) a directory or file *****************************************************************************/ int devredir_rmdir_or_file(void *fusep, tui32 device_id, const char *path, int mode) { tui32 DesiredAccess; tui32 CreateOptions; tui32 CreateDisposition; int rval; IRP *irp; if ((irp = devredir_irp_new()) == NULL) return -1; irp->CompletionId = g_completion_id++; irp->completion_type = CID_RMDIR_OR_FILE; irp->DeviceId = device_id; strncpy(irp->pathname, path, 255); devredir_fuse_data_enqueue(irp, fusep); //DesiredAccess = DA_DELETE | DA_FILE_READ_ATTRIBUTES | DA_SYNCHRONIZE; DesiredAccess = 0x00100080; /* got this value from windows */ //CreateOptions = CO_FILE_DELETE_ON_CLOSE | CO_FILE_DIRECTORY_FILE | // CO_FILE_SYNCHRONOUS_IO_NONALERT; CreateOptions = 0x020; /* got this value from windows */ //CreateDisposition = CD_FILE_OPEN; // WAS 1 CreateDisposition = 0x01; /* got this value from windows */ rval = dev_redir_send_drive_create_request(device_id, path, DesiredAccess, CreateOptions, CreateDisposition, irp->CompletionId); return rval; } /** * Read data from previously opened file * * @return 0 on success, -1 on failure *****************************************************************************/ int devredir_file_read(void *fusep, tui32 DeviceId, tui32 FileId, tui32 Length, tui64 Offset) { struct stream *s; IRP *irp; IRP *new_irp; int bytes; xstream_new(s, 1024); if ((irp = devredir_irp_find_by_fileid(FileId)) == NULL) { log_error("no IRP found with FileId = %d", FileId); xfuse_devredir_cb_read_file(fusep, NULL, 0); xstream_free(s); return -1; } /* create a new IRP for this request */ if ((new_irp = devredir_irp_clone(irp)) == NULL) { /* system out of memory */ xfuse_devredir_cb_read_file(fusep, NULL, 0); xstream_free(s); return -1; } new_irp->FileId = 0; new_irp->completion_type = CID_READ; new_irp->CompletionId = g_completion_id++; devredir_fuse_data_enqueue(new_irp, fusep); devredir_insert_DeviceIoRequest(s, DeviceId, FileId, new_irp->CompletionId, IRP_MJ_READ, 0); xstream_wr_u32_le(s, Length); xstream_wr_u64_le(s, Offset); xstream_seek(s, 20); /* send to client */ bytes = xstream_len(s); send_channel_data(g_rdpdr_chan_id, s->data, bytes); xstream_free(s); return 0; } int dev_redir_file_write(void *fusep, tui32 DeviceId, tui32 FileId, const char *buf, int Length, tui64 Offset) { struct stream *s; IRP *irp; IRP *new_irp; int bytes; log_debug("DeviceId=%d FileId=%d Length=%d Offset=%lld", DeviceId, FileId, Length, (long long)Offset); xstream_new(s, 1024 + Length); if ((irp = devredir_irp_find_by_fileid(FileId)) == NULL) { log_error("no IRP found with FileId = %d", FileId); xfuse_devredir_cb_write_file(fusep, NULL, 0); xstream_free(s); return -1; } /* create a new IRP for this request */ if ((new_irp = devredir_irp_clone(irp)) == NULL) { /* system out of memory */ xfuse_devredir_cb_write_file(fusep, NULL, 0); xstream_free(s); return -1; } new_irp->FileId = 0; new_irp->completion_type = CID_WRITE; new_irp->CompletionId = g_completion_id++; devredir_fuse_data_enqueue(new_irp, fusep); devredir_insert_DeviceIoRequest(s, DeviceId, FileId, new_irp->CompletionId, IRP_MJ_WRITE, 0); xstream_wr_u32_le(s, Length); xstream_wr_u64_le(s, Offset); xstream_seek(s, 20); /* padding */ /* now insert real data */ xstream_copyin(s, buf, Length); /* send to client */ bytes = xstream_len(s); send_channel_data(g_rdpdr_chan_id, s->data, bytes); xstream_free(s); return 0; } /****************************************************************************** ** FIFO for FUSE_DATA ** ******************************************************************************/ /** * Return FUSE_DATA at the head of the queue without removing it * * @return FUSE_DATA on success, or NULL on failure *****************************************************************************/ FUSE_DATA * devredir_fuse_data_peek(IRP *irp) { log_debug("returning %p", irp->fd_head); return irp->fd_head; } /** * Return oldest FUSE_DATA from queue * * @return FUSE_DATA on success, NULL on failure *****************************************************************************/ FUSE_DATA * devredir_fuse_data_dequeue(IRP *irp) { FUSE_DATA *head; if ((irp == NULL) || (irp->fd_head == NULL)) { log_debug("+++ returning NULL"); return NULL; } if (irp->fd_head->next == NULL) { /* only one element in queue */ head = irp->fd_head; irp->fd_head = NULL; irp->fd_tail = NULL; log_debug("+++ returning FUSE_DATA=%p containing FUSE_INFO=%p", head, head->data_ptr); return head; } /* more than one element in queue */ head = irp->fd_head; irp->fd_head = head->next; log_debug("+++ returning FUSE_DATA=%p containing FUSE_INFO=%p", head, head->data_ptr); return head; } /** * Insert specified FUSE_DATA at the end of our queue * * @return 0 on success, -1 on failure *****************************************************************************/ int devredir_fuse_data_enqueue(IRP *irp, void *vp) { FUSE_DATA *fd; FUSE_DATA *tail; if (irp == NULL) return -1; fd = g_new0(FUSE_DATA, 1); if (fd == NULL) return -1; fd->data_ptr = vp; fd->next = NULL; if (irp->fd_tail == NULL) { /* queue is empty, insert at head */ irp->fd_head = fd; irp->fd_tail = fd; log_debug("+++ inserted FUSE_DATA=%p containing FUSE_INFO=%p at head", fd, vp); return 0; } /* queue is not empty, insert at tail end */ tail = irp->fd_tail; tail->next = fd; irp->fd_tail = fd; log_debug("+++ inserted FUSE_DATA=%p containing FUSE_INFO=%p at tail", fd, vp); return 0; } /****************************************************************************** ** miscellaneous stuff ** ******************************************************************************/ void devredir_insert_DeviceIoRequest(struct stream *s, tui32 DeviceId, tui32 FileId, tui32 CompletionId, tui32 MajorFunction, tui32 MinorFunction) { /* setup DR_DEVICE_IOREQUEST header */ xstream_wr_u16_le(s, RDPDR_CTYP_CORE); xstream_wr_u16_le(s, PAKID_CORE_DEVICE_IOREQUEST); xstream_wr_u32_le(s, DeviceId); xstream_wr_u32_le(s, FileId); xstream_wr_u32_le(s, CompletionId); xstream_wr_u32_le(s, MajorFunction); xstream_wr_u32_le(s, MinorFunction); } /** * Convert / to windows compatible \ *****************************************************************************/ void devredir_cvt_slash(char *path) { char *cptr = path; while (*cptr != 0) { if (*cptr == '/') *cptr = '\\'; cptr++; } } void devredir_cvt_to_unicode(char *unicode, const char *path) { char *dest; char *src; int rv; int i; rv = g_mbstowcs((twchar *) unicode, path, strlen(path)); /* unicode is typically 4 bytes, but microsoft only uses 2 bytes */ src = unicode + sizeof(twchar); /* skip 1st unicode char */ dest = unicode + 2; /* first char already in place */ for (i = 1; i < rv; i++) { *dest++ = *src++; *dest++ = *src++; src += 2; } *dest++ = 0; *dest++ = 0; } void devredir_cvt_from_unicode_len(char *path, char *unicode, int len) { char *dest; char *dest_saved; char *src; int i; int bytes_to_alloc; int max_bytes; bytes_to_alloc = (((len / 2) * sizeof(twchar)) + sizeof(twchar)); src = unicode; dest = g_new0(char, bytes_to_alloc); dest_saved = dest; for (i = 0; i < len; i += 2) { *dest++ = *src++; *dest++ = *src++; dest += 2; } *dest++ = 0; *dest++ = 0; *dest++ = 0; *dest++ = 0; max_bytes = wcstombs(NULL, (wchar_t *) dest_saved, 0); if (max_bytes > 0) { wcstombs(path, (wchar_t *) dest_saved, max_bytes); path[max_bytes] = 0; } g_free(dest_saved); } int dev_redir_string_ends_with(char *string, char c) { int len; len = strlen(string); return (string[len - 1] == c) ? 1 : 0; } void devredir_insert_RDPDR_header(struct stream *s, tui16 Component, tui16 PacketId) { xstream_wr_u16_le(s, Component); xstream_wr_u16_le(s, PacketId); } void devredir_proc_cid_rmdir_or_file(IRP *irp, tui32 IoStatus) { struct stream *s; int bytes; if (IoStatus != NT_STATUS_SUCCESS) { FUSE_DATA *fuse_data = devredir_fuse_data_dequeue(irp); if (fuse_data) { xfuse_devredir_cb_rmdir_or_file(fuse_data->data_ptr, IoStatus); free(fuse_data); } devredir_irp_delete(irp); return; } xstream_new(s, 1024); irp->completion_type = CID_RMDIR_OR_FILE_RESP; devredir_insert_DeviceIoRequest(s, irp->DeviceId, irp->FileId, irp->CompletionId, IRP_MJ_SET_INFORMATION, 0); xstream_wr_u32_le(s, FileDispositionInformation); xstream_wr_u32_le(s, 0); /* length is zero */ xstream_seek(s, 24); /* padding */ /* send to client */ bytes = xstream_len(s); send_channel_data(g_rdpdr_chan_id, s->data, bytes); xstream_free(s); return; } void devredir_proc_cid_rmdir_or_file_resp(IRP *irp, tui32 IoStatus) { FUSE_DATA *fuse_data; fuse_data = devredir_fuse_data_dequeue(irp); if (fuse_data) { xfuse_devredir_cb_rmdir_or_file(fuse_data->data_ptr, IoStatus); free(fuse_data); } if (IoStatus != NT_STATUS_SUCCESS) { devredir_irp_delete(irp); return; } irp->completion_type = CID_CLOSE; dev_redir_send_drive_close_request(RDPDR_CTYP_CORE, PAKID_CORE_DEVICE_IOREQUEST, irp->DeviceId, irp->FileId, irp->CompletionId, IRP_MJ_CLOSE, 0, 32); } void devredir_proc_cid_rename_file(IRP *irp, tui32 IoStatus) { struct stream *s; int bytes; int sblen; /* SetBuffer length */ int flen; /* FileNameLength */ if (IoStatus != NT_STATUS_SUCCESS) { log_debug("rename returned with IoStatus=0x%x", IoStatus); FUSE_DATA *fuse_data = devredir_fuse_data_dequeue(irp); if (fuse_data) { xfuse_devredir_cb_rename_file(fuse_data->data_ptr, IoStatus); free(fuse_data); } devredir_irp_delete(irp); return; } /* Path in unicode needs this much space */ flen = ((g_mbstowcs(NULL, irp->gen_buf, 0) * sizeof(twchar)) / 2) + 2; sblen = 6 + flen; xstream_new(s, 1024 + flen); irp->completion_type = CID_RENAME_FILE_RESP; devredir_insert_DeviceIoRequest(s, irp->DeviceId, irp->FileId, irp->CompletionId, IRP_MJ_SET_INFORMATION, 0); xstream_wr_u32_le(s, FileRenameInformation); xstream_wr_u32_le(s, sblen); /* number of bytes after padding */ xstream_seek(s, 24); /* padding */ xstream_wr_u8(s, 1); /* ReplaceIfExists */ xstream_wr_u8(s, 0); /* RootDirectory */ xstream_wr_u32_le(s, flen); /* FileNameLength */ /* filename in unicode */ devredir_cvt_to_unicode(s->p, irp->gen_buf); /* UNICODE_TODO */ xstream_seek(s, flen); /* send to client */ bytes = xstream_len(s); send_channel_data(g_rdpdr_chan_id, s->data, bytes); xstream_free(s); return; } void devredir_proc_cid_rename_file_resp(IRP *irp, tui32 IoStatus) { FUSE_DATA *fuse_data; log_debug("entered"); fuse_data = devredir_fuse_data_dequeue(irp); if (fuse_data) { xfuse_devredir_cb_rename_file(fuse_data->data_ptr, IoStatus); free(fuse_data); } if (IoStatus != NT_STATUS_SUCCESS) { devredir_irp_delete(irp); return; } irp->completion_type = CID_CLOSE; dev_redir_send_drive_close_request(RDPDR_CTYP_CORE, PAKID_CORE_DEVICE_IOREQUEST, irp->DeviceId, irp->FileId, irp->CompletionId, IRP_MJ_CLOSE, 0, 32); } xrdp-0.9.5/sesman/chansrv/drdynvc.c000644 001751 001751 00000032074 13174271344 017205 0ustar00metameta000000 000000 /** * xrdp: A Remote Desktop Protocol server. * * Copyright (C) Laxmikant Rashinkar 2012 LK.Rashinkar@gmail.com * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ #if defined(HAVE_CONFIG_H) #include #endif #include "drdynvc.h" extern int g_drdynvc_chan_id; /* in chansrv.c */ int g_drdynvc_inited = 0; static int drdynvc_send_capability_request(uint16_t version); static int drdynvc_process_capability_response(struct stream* s, unsigned char cmd); static int drdynvc_process_open_channel_response(struct stream *s, unsigned char cmd); static int drdynvc_process_close_channel_response(struct stream *s, unsigned char cmd); static int drdynvc_process_data_first(struct stream* s, unsigned char cmd); static int drdynvc_process_data(struct stream* s, unsigned char cmd); static int drdynvc_insert_uint_124(struct stream *s, uint32_t val); static int drdynvc_get_chan_id(struct stream *s, char cmd, uint32_t *chan_id_p); /** * bring up dynamic virtual channel * * @return 0 on success, -1 on response ******************************************************************************/ int drdynvc_init(void) { /* bring up X11 */ xcommon_init(); /* let client know what version of DVC we support */ drdynvc_send_capability_request(2); return 0; } /** * let DVC Manager on client end know what version of protocol we support * client will respond with version that it supports * * @return 0 on success, -1 on response ******************************************************************************/ static int drdynvc_send_capability_request(uint16_t version) { struct stream *s; int bytes_in_stream; /* setup stream */ make_stream(s); init_stream(s, MAX_PDU_SIZE); out_uint8(s, 0x50); /* insert cmd */ out_uint8(s, 0x00); /* insert padding */ out_uint16_le(s, version); /* insert version */ /* channel priority unused for now */ out_uint16_le(s, 0x0000); /* priority charge 0 */ out_uint16_le(s, 0x0000); /* priority charge 1 */ out_uint16_le(s, 0x0000); /* priority charge 2 */ out_uint16_le(s, 0x0000); /* priority charge 3 */ /* send command to client */ bytes_in_stream = stream_length_before_p(s); send_channel_data(g_drdynvc_chan_id, s->data, bytes_in_stream); free_stream(s); return 0; } /** * process capability response received from DVC manager at client end * * @param s stream containing client response * * @return 0 on success, -1 on failure ******************************************************************************/ static int drdynvc_process_capability_response(struct stream *s, unsigned char cmd) { int cap_version; /* skip padding */ in_uint8s(s, 1); /* read client's version */ in_uint16_le(s, cap_version); if ((cap_version != 2) && (cap_version != 3)) { LOG(0, ("drdynvc_process_capability_response: incompatible DVC " "version %d detected", cap_version)); return -1; } LOG(0, ("drdynvc_process_capability_response: DVC version %d selected", cap_version)); g_drdynvc_inited = 1; return 0; } /** * create a new dynamic virtual channel * * @pram channel_id channel id number * @pram channel_name name of channel * * @return 0 on success, -1 on failure ******************************************************************************/ int drdynvc_send_open_channel_request(int chan_pri, unsigned int chan_id, char *chan_name) { struct stream *s; int bytes_in_stream; int cbChId; int name_length; if ((chan_name == NULL) || (strlen(chan_name) == 0)) { LOG(0, ("drdynvc_send_open_channel_request: bad channel name specified")); return -1; } make_stream(s); init_stream(s, MAX_PDU_SIZE); name_length = strlen(chan_name); /* dummy command for now */ out_uint8(s, 0); /* insert channel id */ cbChId = drdynvc_insert_uint_124(s, chan_id); /* insert channel name */ out_uint8a(s, chan_name, name_length + 1); /* insert command */ s->data[0] = CMD_DVC_OPEN_CHANNEL | ((chan_pri << 2) & 0x0c) | cbChId; /* send command */ bytes_in_stream = stream_length_before_p(s); send_channel_data(g_drdynvc_chan_id, s->data, bytes_in_stream); free_stream(s); return 0; } static int drdynvc_process_open_channel_response(struct stream *s, unsigned char cmd) { struct xrdp_api_data *adp; uint32_t chan_id; int creation_status; drdynvc_get_chan_id(s, cmd, &chan_id); in_uint32_le(s, creation_status); /* LK_TODO now do something using useful! */ if (creation_status < 0) { // TODO } else { /* get struct xrdp_api_data containing this channel id */ if ((adp = struct_from_dvc_chan_id(chan_id)) == NULL) { LOG(0, ("drdynvc_process_open_channel_response: error : " "could not find xrdp_api_data containing chan_id %d", chan_id)); return -1; } adp->is_connected = 1; } return 0; } int drdynvc_send_close_channel_request(unsigned int chan_id) { struct stream *s; int bytes_in_stream; int cbChId; make_stream(s); init_stream(s, MAX_PDU_SIZE); /* insert dummy cmd for now */ out_uint8(s, 0); /* insert channel id */ cbChId = drdynvc_insert_uint_124(s, chan_id); /* insert command */ s->data[0] = CMD_DVC_CLOSE_CHANNEL | cbChId; /* send command */ bytes_in_stream = stream_length_before_p(s); send_channel_data(g_drdynvc_chan_id, s->data, bytes_in_stream); free_stream(s); return 0; } static int drdynvc_process_close_channel_response(struct stream *s, unsigned char cmd) { uint32_t chan_id; drdynvc_get_chan_id(s, cmd, &chan_id); /* LK_TODO now do something using useful! */ return 0; } /* * send data to client * * @param chan_id the virtual channel to write to * @param data data to write * @param data_size number of bytes to write * * @return 0 on success, -1 on failure ******************************************************************************/ int drdynvc_write_data(uint32_t chan_id, char *data, int data_size) { struct stream *s; char *saved_ptr; int cbChId; int Len; int bytes_in_stream; int frag_size; if (data == NULL) { LOG(0, ("drdynvc_write_data: data is NULL\n")); return -1; } if (data_size <= 0) { return 0; } make_stream(s); init_stream(s, MAX_PDU_SIZE); /* this is a dummy write */ out_uint8(s, 0); /* insert channel id */ cbChId = drdynvc_insert_uint_124(s, chan_id); /* will data fit into one pkt? */ bytes_in_stream = stream_length_before_p(s); if ((bytes_in_stream + data_size) <= MAX_PDU_SIZE) { /* yes it will - insert data */ out_uint8p(s, data, data_size); /* insert command */ s->data[0] = CMD_DVC_DATA | cbChId; /* write data to client */ bytes_in_stream = stream_length_before_p(s); send_channel_data(g_drdynvc_chan_id, s->data, bytes_in_stream); free_stream(s); return 0; } /* no it won't - fragment it */ saved_ptr = s->p; /* let client know how much data to expect */ Len = drdynvc_insert_uint_124(s, data_size); /* insert data into first fragment */ frag_size = MAX_PDU_SIZE - stream_length_before_p(s); out_uint8p(s, data, frag_size); /* insert command */ s->data[0] = CMD_DVC_DATA_FIRST | Len << 2 | cbChId; /* write first fragment to client */ bytes_in_stream = stream_length_before_p(s); send_channel_data(g_drdynvc_chan_id, s->data, bytes_in_stream); data_size -= frag_size; data += frag_size; s->data[0] = CMD_DVC_DATA | cbChId; s->p = saved_ptr; /* now send rest of the data using CMD_DVC_DATA */ while (data_size > 0) { frag_size = MAX_PDU_SIZE - stream_length_before_p(s); if (frag_size > data_size) { frag_size = data_size; } out_uint8p(s, data, frag_size); bytes_in_stream = stream_length_before_p(s); send_channel_data(g_drdynvc_chan_id, s->data, bytes_in_stream); data_size -= frag_size; data += frag_size; s->p = saved_ptr; } free_stream(s); return 0; } static int drdynvc_process_data_first(struct stream *s, unsigned char cmd) { struct xrdp_api_data *adp; struct stream *ls; uint32_t chan_id; int bytes_in_stream; int Len; drdynvc_get_chan_id(s, cmd, &chan_id); Len = (cmd >> 2) & 0x03; /* skip data_len */ if (Len == 0) { in_uint8s(s, 1); } else if (Len == 1) { in_uint8s(s, 2); } else { in_uint8s(s, 4); } bytes_in_stream = stream_length_after_p(s); /* get struct xrdp_api_data containing this channel id */ if ((adp = struct_from_dvc_chan_id(chan_id)) == NULL) { LOG(0, ("drdynvc_process_data_first: error : " "could not find xrdp_api_data containing chan_id %d", chan_id)); return -1; } ls = trans_get_out_s(adp->transp, MAX_PDU_SIZE); out_uint8p(ls, s->p, bytes_in_stream); s_mark_end(ls); trans_force_write(adp->transp); return 0; } static int drdynvc_process_data(struct stream *s, unsigned char cmd) { struct xrdp_api_data *adp; struct stream *ls; uint32_t chan_id; int bytes_in_stream; drdynvc_get_chan_id(s, cmd, &chan_id); bytes_in_stream = stream_length_after_p(s); /* get struct xrdp_api_data containing this channel id */ if ((adp = struct_from_dvc_chan_id(chan_id)) == NULL) { LOG(0, ("drdynvc_process_data: error : " "could not find xrdp_api_data containing chan_id %d", chan_id)); return -1; } ls = trans_get_out_s(adp->transp, MAX_PDU_SIZE); out_uint8p(ls, s->p, bytes_in_stream); s_mark_end(ls); trans_force_write(adp->transp); return 0; } /** * process incoming data on a dynamic virtual channel * * @pram s stream containing the incoming data * @pram chan_id LK_TODO * @pram chan_flags LK_TODO * @pram length LK_TODO * @pram total_length LK_TODO * * @return 0 on success, -1 on failure ******************************************************************************/ int drdynvc_data_in(struct stream *s, int chan_id, int chan_flags, int length, int total_length) { unsigned char cmd; in_uint8(s, cmd); /* read command */ switch (cmd & 0xf0) { case CMD_DVC_CAPABILITY: drdynvc_process_capability_response(s, cmd); break; case CMD_DVC_OPEN_CHANNEL: drdynvc_process_open_channel_response(s, cmd); break; case CMD_DVC_CLOSE_CHANNEL: drdynvc_process_close_channel_response(s, cmd); break; case CMD_DVC_DATA_FIRST: drdynvc_process_data_first(s, cmd); break; case CMD_DVC_DATA: drdynvc_process_data(s, cmd); break; default: LOG(0, ("drdynvc_data_in: got unknown command 0x%x", cmd)); break; } return 0; } /* * insert a byte, short or 32bit value into specified stream * * @param s stream used for insertion * @param val value to insert * * @return 0 for byte insertions * @return 1 for short insertion * @return 2 for uint32_t insertions ******************************************************************************/ static int drdynvc_insert_uint_124(struct stream *s, uint32_t val) { int ret_val; if (val <= 0xff) { out_uint8(s, val); ret_val = 0; } else if (val <= 0xffff) { out_uint16_le(s, val); ret_val = 1; } else { out_uint32_le(s, val); ret_val = 2; } return ret_val; } /* * extract channel id from stream * * @param s stream containing channel id * @param cmd first byte in stream * @param chan_id return channel id here ******************************************************************************/ static int drdynvc_get_chan_id(struct stream *s, char cmd, uint32_t *chan_id_p) { int cbChId; int chan_id; cbChId = cmd & 0x03; if (cbChId == 0) { in_uint8(s, chan_id); } else if (cbChId == 1) { in_uint16_le(s, chan_id); } else { in_uint32_le(s, chan_id); } *chan_id_p = chan_id; return 0; } xrdp-0.9.5/sesman/chansrv/rail.c000644 001751 001751 00000173257 13174271344 016474 0ustar00metameta000000 000000 /** * xrdp: A Remote Desktop Protocol server. * * Copyright (C) Jay Sorg 2012 * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ /* window manager info http://www.freedesktop.org/wiki/Specifications/wm-spec rail [MS-RDPERP]: Remote Desktop Protocol: Remote Programs Virtual Channel Extension http://msdn.microsoft.com/en-us/library/cc242568(v=prot.20).aspx */ #if defined(HAVE_CONFIG_H) #include #endif #include #include #include #include #include "chansrv.h" #include "rail.h" #include "xcommon.h" #include "log.h" #include "os_calls.h" #include "thread_calls.h" #include "list.h" extern int g_rail_chan_id; /* in chansrv.c */ extern int g_display_num; /* in chansrv.c */ extern char *g_exec_name; /* in chansrv.c */ extern tbus g_exec_event; /* in chansrv.c */ extern tbus g_exec_mutex; /* in chansrv.c */ extern tbus g_exec_sem; /* in chansrv.c */ extern Display *g_display; /* in xcommon.c */ extern Screen *g_screen; /* in xcommon.c */ extern Window g_root_window; /* in xcommon.c */ extern Atom g_wm_delete_window_atom; /* in xcommon.c */ extern Atom g_wm_protocols_atom; /* in xcommon.c */ extern Atom g_utf8_string; /* in xcommon.c */ extern Atom g_net_wm_name; /* in xcommon.c */ extern Atom g_wm_state; /* in xcommon.c */ static Atom g_rwd_atom = 0; int g_rail_up = 0; /* for rail_is_another_wm_running */ static int g_rail_running = 1; /* list of valid rail windows */ static struct list* g_window_list = 0; static int g_got_focus = 0; static int g_focus_counter = 0; static Window g_focus_win = 0; static int g_xrr_event_base = 0; /* non zero means we got extension */ static Cursor g_default_cursor = 0; static char *g_override_window_title = 0; /* used in valid field of struct rail_window_data */ #define RWD_X (1 << 0) #define RWD_Y (1 << 1) #define RWD_WIDTH (1 << 2) #define RWD_HEIGHT (1 << 3) #define RWD_TITLE (1 << 4) struct rail_window_data { int valid; /* bits for which fields are valid */ int x; int y; int width; int height; int title_crc; /* crc of title for compare */ }; /* Indicates a Client Execute PDU from client to server. */ #define TS_RAIL_ORDER_EXEC 0x0001 /* Indicates a Client Activate PDU from client to server. */ #define TS_RAIL_ORDER_ACTIVATE 0x0002 /* Indicates a Client System Parameters Update PDU from client to server or a Server System Parameters Update PDU from server to client. */ #define TS_RAIL_ORDER_SYSPARAM 0x0003 /* Indicates a Client System Command PDU from client to server. */ #define TS_RAIL_ORDER_SYSCOMMAND 0x0004 /* Indicates a bi-directional Handshake PDU. */ #define TS_RAIL_ORDER_HANDSHAKE 0x0005 /* Indicates a Client Notify Event PDU from client to server. */ #define TS_RAIL_ORDER_NOTIFY_EVENT 0x0006 /* Indicates a Client Window Move PDU from client to server. */ #define TS_RAIL_ORDER_WINDOWMOVE 0x0008 /* Indicates a Server Move/Size Start PDU and a Server Move/Size End PDU from server to client. */ #define TS_RAIL_ORDER_LOCALMOVESIZE 0x0009 /* Indicates a Server Min Max Info PDU from server to client. */ #define TS_RAIL_ORDER_MINMAXINFO 0x000a /* Indicates a Client Information PDU from client to server. */ #define TS_RAIL_ORDER_CLIENTSTATUS 0x000b /* Indicates a Client System Menu PDU from client to server. */ #define TS_RAIL_ORDER_SYSMENU 0x000c /* Indicates a Server Language Bar Information PDU from server to client, or a Client Language Bar Information PDU from client to server. */ #define TS_RAIL_ORDER_LANGBARINFO 0x000d /* Indicates a Server Execute Result PDU from server to client. */ #define TS_RAIL_ORDER_EXEC_RESULT 0x0080 /* Indicates a Client Get Application ID PDU from client to server. */ #define TS_RAIL_ORDER_GET_APPID_REQ 0x000E /* Indicates a Server Get Application ID Response PDU from server to client. */ #define TS_RAIL_ORDER_GET_APPID_RESP 0x000F /* Resize the window. */ #define SC_SIZE 0xF000 /* Move the window. */ #define SC_MOVE 0xF010 /* Minimize the window. */ #define SC_MINIMIZE 0xF020 /* Maximize the window. */ #define SC_MAXIMIZE 0xF030 /* Close the window. */ #define SC_CLOSE 0xF060 /* The ALT + SPACE key combination was pressed; display the window's system menu. */ #define SC_KEYMENU 0xF100 /* Restore the window to its original shape and size. */ #define SC_RESTORE 0xF120 /* Perform the default action of the window's system menu. */ #define SC_DEFAULT 0xF160 /* for tooltips */ #define RAIL_STYLE_TOOLTIP (0x80000000) #define RAIL_EXT_STYLE_TOOLTIP (0x00000080 | 0x00000008) /* for normal desktop windows */ #define RAIL_STYLE_NORMAL (0x00C00000 | 0x00080000 | 0x00040000 | 0x00010000 | 0x00020000) #define RAIL_EXT_STYLE_NORMAL (0x00040000) /* for dialogs */ #define RAIL_STYLE_DIALOG (0x80000000) #define RAIL_EXT_STYLE_DIALOG (0x00040000) static int rail_win_get_state(Window win); static int rail_create_window(Window window_id, Window owner_id); static int rail_win_set_state(Window win, unsigned long state); static int rail_show_window(Window window_id, int show_state); static int rail_win_send_text(Window win); /*****************************************************************************/ static int rail_send_key_esc(int window_id) { XEvent event; g_memset(&event, 0, sizeof(event)); event.type = KeyPress; event.xkey.same_screen = True; event.xkey.root = g_root_window; event.xkey.window = window_id; event.xkey.keycode = 9; XSendEvent(g_display, window_id, True, 0xfff, &event); event.type = KeyRelease; XSendEvent(g_display, window_id, True, 0xfff, &event); return 0; } /*****************************************************************************/ static struct rail_window_data* rail_get_window_data(Window window) { unsigned int bytes; Atom actual_type_return; int actual_format_return; unsigned long nitems_return; unsigned long bytes_after_return; unsigned char* prop_return; struct rail_window_data* rv; LOG(10, ("chansrv::rail_get_window_data:")); rv = 0; actual_type_return = 0; actual_format_return = 0; nitems_return = 0; prop_return = 0; bytes = sizeof(struct rail_window_data); XGetWindowProperty(g_display, window, g_rwd_atom, 0, bytes, 0, XA_STRING, &actual_type_return, &actual_format_return, &nitems_return, &bytes_after_return, &prop_return); if (prop_return == 0) { return 0; } if (nitems_return == bytes) { rv = (struct rail_window_data*)prop_return; } return rv; } /*****************************************************************************/ static int rail_set_window_data(Window window, struct rail_window_data* rwd) { int bytes; bytes = sizeof(struct rail_window_data); XChangeProperty(g_display, window, g_rwd_atom, XA_STRING, 8, PropModeReplace, (unsigned char*)rwd, bytes); return 0; } /*****************************************************************************/ /* get the rail window data, if not exist, try to create it and return */ static struct rail_window_data* rail_get_window_data_safe(Window window) { struct rail_window_data* rv; rv = rail_get_window_data(window); if (rv != 0) { return rv; } rv = g_new0(struct rail_window_data, 1); rail_set_window_data(window, rv); g_free(rv); return rail_get_window_data(window); } /******************************************************************************/ static int is_window_valid_child_of_root(unsigned int window_id) { int found; unsigned int i; unsigned int nchild; Window r; Window p; Window *children; found = 0; XQueryTree(g_display, g_root_window, &r, &p, &children, &nchild); for (i = 0; i < nchild; i++) { if (window_id == children[i]) { found = 1; break; } } XFree(children); return found; } /*****************************************************************************/ static int rail_send_init(void) { struct stream *s; int bytes; char *size_ptr; LOG(10, ("chansrv::rail_send_init:")); make_stream(s); init_stream(s, 8182); out_uint16_le(s, TS_RAIL_ORDER_HANDSHAKE); size_ptr = s->p; out_uint16_le(s, 0); /* size, set later */ out_uint32_le(s, 1); /* build number */ s_mark_end(s); bytes = (int)((s->end - s->data) - 4); size_ptr[0] = bytes; size_ptr[1] = bytes >> 8; bytes = (int)(s->end - s->data); send_channel_data(g_rail_chan_id, s->data, bytes); free_stream(s); return 0; } /******************************************************************************/ static int anotherWMRunning(Display *display, XErrorEvent *xe) { g_rail_running = 0; return -1; } /******************************************************************************/ static int rail_is_another_wm_running(void) { XErrorHandler old; g_rail_running = 1; old = XSetErrorHandler((XErrorHandler)anotherWMRunning); XSelectInput(g_display, g_root_window, PropertyChangeMask | StructureNotifyMask | SubstructureRedirectMask | ButtonPressMask | SubstructureNotifyMask | FocusChangeMask | EnterWindowMask | LeaveWindowMask); XSync(g_display, 0); XSetErrorHandler((XErrorHandler)old); g_rail_up = g_rail_running; if (!g_rail_up) { return 1; } return 0; } /*****************************************************************************/ int rail_init(void) { LOG(10, ("chansrv::rail_init:")); xcommon_init(); return 0; } /*****************************************************************************/ int rail_deinit(void) { if (g_rail_up) { list_delete(g_window_list); g_window_list = 0; /* no longer window manager */ XSelectInput(g_display, g_root_window, 0); g_rail_up = 0; } return 0; } int rail_startup(void) { int dummy; int ver_maj; int ver_min; Status st; if (rail_is_another_wm_running()) { log_message(LOG_LEVEL_ERROR, "rail_init: another window manager " "is running"); } list_delete(g_window_list); g_window_list = list_create(); rail_send_init(); g_rail_up = 1; g_rwd_atom = XInternAtom(g_display, "XRDP_RAIL_WINDOW_DATA", 0); if (!XRRQueryExtension(g_display, &g_xrr_event_base, &dummy)) { g_xrr_event_base = 0; log_message(LOG_LEVEL_ERROR, "rail_init: RandR extension not found"); } if (g_xrr_event_base > 0) { LOG(0, ("rail_init: found RandR extension")); st = XRRQueryVersion(g_display, &ver_maj, &ver_min); if (st) { LOG(0, ("rail_init: RandR version major %d minor %d", ver_maj, ver_min)); } XRRSelectInput(g_display, g_root_window, RRScreenChangeNotifyMask); } if (g_default_cursor == 0) { g_default_cursor = XCreateFontCursor(g_display, XC_left_ptr); XDefineCursor(g_display, g_root_window, g_default_cursor); } return 0; } /*****************************************************************************/ static char * read_uni(struct stream *s, int num_chars) { twchar *rchrs; char *rv; int index; int lchars; rchrs = 0; rv = 0; if (num_chars > 0) { rchrs = (twchar *)g_malloc((num_chars + 1) * sizeof(twchar), 0); for (index = 0; index < num_chars; index++) { in_uint16_le(s, rchrs[index]); } rchrs[num_chars] = 0; lchars = g_wcstombs(0, rchrs, 0); if (lchars > 0) { rv = (char *)g_malloc((lchars + 1) * 4, 0); g_wcstombs(rv, rchrs, lchars); rv[lchars] = 0; } } g_free(rchrs); return rv; } /*****************************************************************************/ static int rail_process_exec(struct stream *s, int size) { int flags; int ExeOrFileLength; int WorkingDirLength; int ArgumentsLen; char *ExeOrFile; char *WorkingDir; char *Arguments; LOG(0, ("chansrv::rail_process_exec:")); in_uint16_le(s, flags); in_uint16_le(s, ExeOrFileLength); in_uint16_le(s, WorkingDirLength); in_uint16_le(s, ArgumentsLen); ExeOrFile = read_uni(s, ExeOrFileLength); WorkingDir = read_uni(s, WorkingDirLength); Arguments = read_uni(s, ArgumentsLen); LOG(10, (" flags 0x%8.8x ExeOrFileLength %d WorkingDirLength %d " "ArgumentsLen %d ExeOrFile [%s] WorkingDir [%s] " "Arguments [%s]", flags, ExeOrFileLength, WorkingDirLength, ArgumentsLen, ExeOrFile, WorkingDir, Arguments)); if (g_strlen(ExeOrFile) > 0) { rail_startup(); LOG(10, ("rail_process_exec: pre")); /* ask main thread to fork */ tc_mutex_lock(g_exec_mutex); g_exec_name = ExeOrFile; g_set_wait_obj(g_exec_event); tc_sem_dec(g_exec_sem); tc_mutex_unlock(g_exec_mutex); LOG(10, ("rail_process_exec: post")); } g_free(ExeOrFile); g_free(WorkingDir); g_free(Arguments); return 0; } /******************************************************************************/ static int rail_win_popdown(void) { int rv = 0; int i; unsigned int nchild; Window r; Window p; Window* children; XWindowAttributes window_attributes; /* * Check the tree of current existing X windows and dismiss * the managed rail popups by simulating a esc key, so * that the requested window can be closed properly. */ XQueryTree(g_display, g_root_window, &r, &p, &children, &nchild); for (i = nchild - 1; i >= 0; i--) { XGetWindowAttributes(g_display, children[i], &window_attributes); if (window_attributes.override_redirect && window_attributes.map_state == IsViewable && list_index_of(g_window_list, children[i]) >= 0) { LOG(10, (" dismiss pop up 0x%8.8lx", children[i])); rail_send_key_esc(children[i]); rv = 1; } } XFree(children); return rv; } /******************************************************************************/ static int rail_close_window(int window_id) { XEvent ce; LOG(0, ("chansrv::rail_close_window:")); rail_win_popdown(); g_memset(&ce, 0, sizeof(ce)); ce.xclient.type = ClientMessage; ce.xclient.message_type = g_wm_protocols_atom; ce.xclient.display = g_display; ce.xclient.window = window_id; ce.xclient.format = 32; ce.xclient.data.l[0] = g_wm_delete_window_atom; ce.xclient.data.l[1] = CurrentTime; XSendEvent(g_display, window_id, False, NoEventMask, &ce); return 0; } /*****************************************************************************/ void my_timeout(void* data) { LOG(10, ("my_timeout: g_got_focus %d", g_got_focus)); if (g_focus_counter == (int)(long)data) { LOG(10, ("my_timeout: g_focus_counter %d", g_focus_counter)); rail_win_popdown(); } } /*****************************************************************************/ static int rail_process_activate(struct stream *s, int size) { unsigned int window_id; int enabled; int index; XWindowAttributes window_attributes; Window transient_for = 0; LOG(10, ("chansrv::rail_process_activate:")); in_uint32_le(s, window_id); in_uint8(s, enabled); index = list_index_of(g_window_list, window_id); if (index < 0) { LOG(10, ("chansrv::rail_process_activate: window 0x%8.8x not in list", window_id)); return 0; } g_focus_counter++; g_got_focus = enabled; LOG(10, (" window_id 0x%8.8x enabled %d", window_id, enabled)); XGetWindowAttributes(g_display, window_id, &window_attributes); if (enabled) { if (g_focus_win == window_id) { /* In case that window is unmapped upon minimization and not yet mapped*/ XMapWindow(g_display, window_id); } else { rail_win_popdown(); if (window_attributes.map_state != IsViewable) { /* In case that window is unmapped upon minimization and not yet mapped */ XMapWindow(g_display, window_id); } XGetTransientForHint(g_display, window_id, &transient_for); if (transient_for > 0) { /* Owner window should be raised up as well */ XRaiseWindow(g_display, transient_for); } LOG(10, ("chansrv::rail_process_activate: calling XRaiseWindow 0x%8.8x", window_id)); XRaiseWindow(g_display, window_id); LOG(10, ("chansrv::rail_process_activate: calling XSetInputFocus 0x%8.8x", window_id)); XSetInputFocus(g_display, window_id, RevertToParent, CurrentTime); } LOG(10, ("chansrv::rail_process_activate: calling XRaiseWindow 0x%8.8x", window_id)); XRaiseWindow(g_display, window_id); LOG(10, ("chansrv::rail_process_activate: calling XSetInputFocus 0x%8.8x", window_id)); XSetInputFocus(g_display, window_id, RevertToParent, CurrentTime); } else { LOG(10, (" window attributes: override_redirect %d", window_attributes.override_redirect)); add_timeout(200, my_timeout, (void*)(long)g_focus_counter); } return 0; } /*****************************************************************************/ static int rail_select_input(Window window_id) { XSelectInput(g_display, window_id, PropertyChangeMask | StructureNotifyMask | SubstructureNotifyMask | FocusChangeMask | EnterWindowMask | LeaveWindowMask); XSync(g_display, 0); return 0; } /*****************************************************************************/ static int rail_restore_windows(void) { unsigned int i; unsigned int nchild; Window r; Window p; Window* children; XQueryTree(g_display, g_root_window, &r, &p, &children, &nchild); for (i = 0; i < nchild; i++) { XWindowAttributes window_attributes; XGetWindowAttributes(g_display, children[i], &window_attributes); if (!window_attributes.override_redirect) { rail_select_input(children[i]); if (window_attributes.map_state == IsViewable) { rail_win_set_state(children[i], 0x0); /* WithdrawnState */ rail_create_window(children[i], g_root_window); rail_win_set_state(children[i], 0x1); /* NormalState */ rail_win_send_text(children[i]); } } } XFree(children); return 0; } /*****************************************************************************/ static int rail_process_system_param(struct stream *s, int size) { int system_param; LOG(10, ("chansrv::rail_process_system_param:")); in_uint32_le(s, system_param); LOG(10, (" system_param 0x%8.8x", system_param)); /* * Ask client to re-create the existing rail windows. This is supposed * to be done after handshake and client is initialised properly, we * consider client is ready when it sends "SET_WORKAREA" sysparam. */ if (system_param == 0x0000002F) /*SPI_SET_WORK_AREA*/ { LOG(10, (" restore rail windows")); rail_restore_windows(); } return 0; } /*****************************************************************************/ static int rail_get_property(Display* display, Window target, Atom type, Atom property, unsigned char** data, unsigned long* count) { Atom atom_return; int size; unsigned long nitems, bytes_left; char* prop_name; int ret = XGetWindowProperty(display, target, property, 0l, 1l, False, type, &atom_return, &size, &nitems, &bytes_left, data); if ((ret != Success || nitems < 1) && atom_return == None) { prop_name = XGetAtomName(g_display, property); LOG(10, (" rail_get_property %s: failed", prop_name)); XFree(prop_name); return 1; } if (bytes_left != 0) { XFree(*data); unsigned long remain = ((size / 8) * nitems) + bytes_left; ret = XGetWindowProperty(g_display, target, property, 0l, remain, False, atom_return, &atom_return, &size, &nitems, &bytes_left, data); if (ret != Success) { return 1; } } *count = nitems; return 0; } /*****************************************************************************/ static int rail_win_get_state(Window win) { unsigned long nitems = 0; int rv = -1; char* data = 0; rail_get_property(g_display, win, g_wm_state, g_wm_state, (unsigned char **)&data, &nitems); if (data && nitems > 0) { rv = *(unsigned long *)data; XFree(data); LOG(10, (" rail_win_get_state: %d", rv)); } return rv; } /*****************************************************************************/ static int rail_win_set_state(Window win, unsigned long state) { int old_state; unsigned long data[2] = { state, None }; LOG(10, (" rail_win_set_state: %ld", state)); /* check whether WM_STATE exists */ old_state = rail_win_get_state(win); if (old_state == -1) { /* create WM_STATE property */ XChangeProperty(g_display, win, g_wm_state, g_wm_state, 32, PropModeAppend, (unsigned char *)data, 2); LOG(10, (" rail_win_set_state: create WM_STATE property")); } else { XChangeProperty(g_display, win, g_wm_state, g_wm_state, 32, PropModeReplace, (unsigned char *)data, 2); } return 0; } /*****************************************************************************/ /* *data pointer that needs g_free */ static int rail_win_get_text(Window win, char **data) { int ret = 0; int i = 0; unsigned long nitems = 0; unsigned char *ldata = 0; char *lldata = 0; if (g_override_window_title != 0) { *data = g_strdup(g_override_window_title); return g_strlen(*data); } ret = rail_get_property(g_display, win, g_utf8_string, g_net_wm_name, &ldata, &nitems); if (ret != 0) { /* _NET_WM_NAME isn't set, use WM_NAME (XFetchName) instead */ XFetchName(g_display, win, &lldata); *data = g_strdup(lldata); i = g_strlen(*data); XFree(lldata); return i; } *data = 0; if (ldata) { *data = g_strdup((char *)ldata); i = g_strlen(*data); XFree(ldata); return i; } return i; } /******************************************************************************/ static int rail_minmax_window(int window_id, int max) { LOG(10, ("chansrv::rail_minmax_window 0x%8.8x:", window_id)); if (max) { } else { XUnmapWindow(g_display, window_id); /* change window state to IconicState (3) */ rail_win_set_state(window_id, 0x3); /* * TODO dismiss popups opened so far */ } return 0; } /*****************************************************************************/ static int rail_restore_window(int window_id) { XWindowAttributes window_attributes; LOG(10, ("chansrv::rail_restore_window 0x%8.8x:", window_id)); XGetWindowAttributes(g_display, window_id, &window_attributes); if (window_attributes.map_state != IsViewable) { XMapWindow(g_display, window_id); } LOG(10, ("chansrv::rail_process_activate: calling XRaiseWindow 0x%8.8x", window_id)); XRaiseWindow(g_display, window_id); LOG(10, ("chansrv::rail_process_activate: calling XSetInputFocus 0x%8.8x", window_id)); XSetInputFocus(g_display, window_id, RevertToParent, CurrentTime); return 0; } /*****************************************************************************/ static int rail_process_system_command(struct stream *s, int size) { int window_id; int command; int index; LOG(10, ("chansrv::rail_process_system_command:")); in_uint32_le(s, window_id); in_uint16_le(s, command); index = list_index_of(g_window_list, window_id); if (index < 0) { LOG(10, ("chansrv::rail_process_system_command: window 0x%8.8x not in list", window_id)); return 0; } switch (command) { case SC_SIZE: LOG(10, (" window_id 0x%8.8x SC_SIZE", window_id)); break; case SC_MOVE: LOG(10, (" window_id 0x%8.8x SC_MOVE", window_id)); break; case SC_MINIMIZE: LOG(10, (" window_id 0x%8.8x SC_MINIMIZE", window_id)); rail_minmax_window(window_id, 0); break; case SC_MAXIMIZE: LOG(10, (" window_id 0x%8.8x SC_MAXIMIZE", window_id)); break; case SC_CLOSE: LOG(10, (" window_id 0x%8.8x SC_CLOSE", window_id)); rail_close_window(window_id); break; case SC_KEYMENU: LOG(10, (" window_id 0x%8.8x SC_KEYMENU", window_id)); break; case SC_RESTORE: LOG(10, (" window_id 0x%8.8x SC_RESTORE", window_id)); rail_restore_window(window_id); break; case SC_DEFAULT: LOG(10, (" window_id 0x%8.8x SC_DEFAULT", window_id)); break; default: LOG(10, (" window_id 0x%8.8x unknown command command %d", window_id, command)); break; } return 0; } /*****************************************************************************/ static int rail_process_handshake(struct stream *s, int size) { int build_number; LOG(10, ("chansrv::rail_process_handshake:")); in_uint32_le(s, build_number); LOG(10, (" build_number 0x%8.8x", build_number)); return 0; } /*****************************************************************************/ static int rail_process_notify_event(struct stream *s, int size) { int window_id; int notify_id; int message; LOG(10, ("chansrv::rail_process_notify_event:")); in_uint32_le(s, window_id); in_uint32_le(s, notify_id); in_uint32_le(s, message); LOG(10, (" window_id 0x%8.8x notify_id 0x%8.8x message 0x%8.8x", window_id, notify_id, message)); return 0; } /*****************************************************************************/ static int rail_process_window_move(struct stream *s, int size) { int window_id; int left; int top; int right; int bottom; tsi16 si16; struct rail_window_data* rwd; LOG(10, ("chansrv::rail_process_window_move:")); in_uint32_le(s, window_id); in_uint16_le(s, si16); left = si16; in_uint16_le(s, si16); top = si16; in_uint16_le(s, si16); right = si16; in_uint16_le(s, si16); bottom = si16; LOG(10, (" window_id 0x%8.8x left %d top %d right %d bottom %d width %d height %d", window_id, left, top, right, bottom, right - left, bottom - top)); XMoveResizeWindow(g_display, window_id, left, top, right - left, bottom - top); rwd = (struct rail_window_data*) g_malloc(sizeof(struct rail_window_data), 1); rwd->x = left; rwd->y = top; rwd->width = right - left; rwd->height = bottom - top; rail_set_window_data(window_id, rwd); g_free(rwd); return 0; } /*****************************************************************************/ static int rail_process_local_move_size(struct stream *s, int size) { int window_id; int is_move_size_start; int move_size_type; int pos_x; int pos_y; tsi16 si16; LOG(10, ("chansrv::rail_process_local_move_size:")); in_uint32_le(s, window_id); in_uint16_le(s, is_move_size_start); in_uint16_le(s, move_size_type); in_uint16_le(s, si16); pos_x = si16; in_uint16_le(s, si16); pos_y = si16; LOG(10, (" window_id 0x%8.8x is_move_size_start %d move_size_type %d " "pos_x %d pos_y %d", window_id, is_move_size_start, move_size_type, pos_x, pos_y)); return 0; } /*****************************************************************************/ /* server to client only */ static int rail_process_min_max_info(struct stream *s, int size) { LOG(10, ("chansrv::rail_process_min_max_info:")); return 0; } /*****************************************************************************/ static int rail_process_client_status(struct stream *s, int size) { int flags; LOG(10, ("chansrv::rail_process_client_status:")); in_uint32_le(s, flags); LOG(10, (" flags 0x%8.8x", flags)); return 0; } /*****************************************************************************/ static int rail_process_sys_menu(struct stream *s, int size) { int window_id; int left; int top; tsi16 si16; LOG(10, ("chansrv::rail_process_sys_menu:")); in_uint32_le(s, window_id); in_uint16_le(s, si16); left = si16; in_uint16_le(s, si16); top = si16; LOG(10, (" window_id 0x%8.8x left %d top %d", window_id, left, top)); return 0; } /*****************************************************************************/ static int rail_process_lang_bar_info(struct stream *s, int size) { int language_bar_status; LOG(10, ("chansrv::rail_process_lang_bar_info:")); in_uint32_le(s, language_bar_status); LOG(10, (" language_bar_status 0x%8.8x", language_bar_status)); return 0; } /*****************************************************************************/ static int rail_process_appid_req(struct stream *s, int size) { LOG(10, ("chansrv::rail_process_appid_req:")); return 0; } /*****************************************************************************/ static int rail_process_appid_resp(struct stream *s, int size) { LOG(10, ("chansrv::rail_process_appid_resp:")); return 0; } /*****************************************************************************/ /* server to client only */ static int rail_process_exec_result(struct stream *s, int size) { LOG(10, ("chansrv::rail_process_exec_result:")); return 0; } /*****************************************************************************/ /* data in from client ( client -> xrdp -> chansrv ) */ int rail_data_in(struct stream *s, int chan_id, int chan_flags, int length, int total_length) { int code; int size; LOG(10, ("chansrv::rail_data_in:")); in_uint8(s, code); in_uint8s(s, 1); in_uint16_le(s, size); switch (code) { case TS_RAIL_ORDER_EXEC: /* 1 */ rail_process_exec(s, size); break; case TS_RAIL_ORDER_ACTIVATE: /* 2 */ rail_process_activate(s, size); break; case TS_RAIL_ORDER_SYSPARAM: /* 3 */ rail_process_system_param(s, size); break; case TS_RAIL_ORDER_SYSCOMMAND: /* 4 */ rail_process_system_command(s, size); break; case TS_RAIL_ORDER_HANDSHAKE: /* 5 */ rail_process_handshake(s, size); break; case TS_RAIL_ORDER_NOTIFY_EVENT: /* 6 */ rail_process_notify_event(s, size); break; case TS_RAIL_ORDER_WINDOWMOVE: /* 8 */ rail_process_window_move(s, size); break; case TS_RAIL_ORDER_LOCALMOVESIZE: /* 9 */ rail_process_local_move_size(s, size); break; case TS_RAIL_ORDER_MINMAXINFO: /* 10 */ rail_process_min_max_info(s, size); break; case TS_RAIL_ORDER_CLIENTSTATUS: /* 11 */ rail_process_client_status(s, size); break; case TS_RAIL_ORDER_SYSMENU: /* 12 */ rail_process_sys_menu(s, size); break; case TS_RAIL_ORDER_LANGBARINFO: /* 13 */ rail_process_lang_bar_info(s, size); break; case TS_RAIL_ORDER_GET_APPID_REQ: /* 14 */ rail_process_appid_req(s, size); break; case TS_RAIL_ORDER_GET_APPID_RESP: /* 15 */ rail_process_appid_resp(s, size); break; case TS_RAIL_ORDER_EXEC_RESULT: /* 128 */ rail_process_exec_result(s, size); break; default: LOG(10, ("rail_data_in: unknown code %d size %d", code, size)); break; } XFlush(g_display); return 0; } static const unsigned int g_crc_seed = 0xffffffff; static const unsigned int g_crc_table[256] = { 0x00000000, 0x77073096, 0xee0e612c, 0x990951ba, 0x076dc419, 0x706af48f, 0xe963a535, 0x9e6495a3, 0x0edb8832, 0x79dcb8a4, 0xe0d5e91e, 0x97d2d988, 0x09b64c2b, 0x7eb17cbd, 0xe7b82d07, 0x90bf1d91, 0x1db71064, 0x6ab020f2, 0xf3b97148, 0x84be41de, 0x1adad47d, 0x6ddde4eb, 0xf4d4b551, 0x83d385c7, 0x136c9856, 0x646ba8c0, 0xfd62f97a, 0x8a65c9ec, 0x14015c4f, 0x63066cd9, 0xfa0f3d63, 0x8d080df5, 0x3b6e20c8, 0x4c69105e, 0xd56041e4, 0xa2677172, 0x3c03e4d1, 0x4b04d447, 0xd20d85fd, 0xa50ab56b, 0x35b5a8fa, 0x42b2986c, 0xdbbbc9d6, 0xacbcf940, 0x32d86ce3, 0x45df5c75, 0xdcd60dcf, 0xabd13d59, 0x26d930ac, 0x51de003a, 0xc8d75180, 0xbfd06116, 0x21b4f4b5, 0x56b3c423, 0xcfba9599, 0xb8bda50f, 0x2802b89e, 0x5f058808, 0xc60cd9b2, 0xb10be924, 0x2f6f7c87, 0x58684c11, 0xc1611dab, 0xb6662d3d, 0x76dc4190, 0x01db7106, 0x98d220bc, 0xefd5102a, 0x71b18589, 0x06b6b51f, 0x9fbfe4a5, 0xe8b8d433, 0x7807c9a2, 0x0f00f934, 0x9609a88e, 0xe10e9818, 0x7f6a0dbb, 0x086d3d2d, 0x91646c97, 0xe6635c01, 0x6b6b51f4, 0x1c6c6162, 0x856530d8, 0xf262004e, 0x6c0695ed, 0x1b01a57b, 0x8208f4c1, 0xf50fc457, 0x65b0d9c6, 0x12b7e950, 0x8bbeb8ea, 0xfcb9887c, 0x62dd1ddf, 0x15da2d49, 0x8cd37cf3, 0xfbd44c65, 0x4db26158, 0x3ab551ce, 0xa3bc0074, 0xd4bb30e2, 0x4adfa541, 0x3dd895d7, 0xa4d1c46d, 0xd3d6f4fb, 0x4369e96a, 0x346ed9fc, 0xad678846, 0xda60b8d0, 0x44042d73, 0x33031de5, 0xaa0a4c5f, 0xdd0d7cc9, 0x5005713c, 0x270241aa, 0xbe0b1010, 0xc90c2086, 0x5768b525, 0x206f85b3, 0xb966d409, 0xce61e49f, 0x5edef90e, 0x29d9c998, 0xb0d09822, 0xc7d7a8b4, 0x59b33d17, 0x2eb40d81, 0xb7bd5c3b, 0xc0ba6cad, 0xedb88320, 0x9abfb3b6, 0x03b6e20c, 0x74b1d29a, 0xead54739, 0x9dd277af, 0x04db2615, 0x73dc1683, 0xe3630b12, 0x94643b84, 0x0d6d6a3e, 0x7a6a5aa8, 0xe40ecf0b, 0x9309ff9d, 0x0a00ae27, 0x7d079eb1, 0xf00f9344, 0x8708a3d2, 0x1e01f268, 0x6906c2fe, 0xf762575d, 0x806567cb, 0x196c3671, 0x6e6b06e7, 0xfed41b76, 0x89d32be0, 0x10da7a5a, 0x67dd4acc, 0xf9b9df6f, 0x8ebeeff9, 0x17b7be43, 0x60b08ed5, 0xd6d6a3e8, 0xa1d1937e, 0x38d8c2c4, 0x4fdff252, 0xd1bb67f1, 0xa6bc5767, 0x3fb506dd, 0x48b2364b, 0xd80d2bda, 0xaf0a1b4c, 0x36034af6, 0x41047a60, 0xdf60efc3, 0xa867df55, 0x316e8eef, 0x4669be79, 0xcb61b38c, 0xbc66831a, 0x256fd2a0, 0x5268e236, 0xcc0c7795, 0xbb0b4703, 0x220216b9, 0x5505262f, 0xc5ba3bbe, 0xb2bd0b28, 0x2bb45a92, 0x5cb36a04, 0xc2d7ffa7, 0xb5d0cf31, 0x2cd99e8b, 0x5bdeae1d, 0x9b64c2b0, 0xec63f226, 0x756aa39c, 0x026d930a, 0x9c0906a9, 0xeb0e363f, 0x72076785, 0x05005713, 0x95bf4a82, 0xe2b87a14, 0x7bb12bae, 0x0cb61b38, 0x92d28e9b, 0xe5d5be0d, 0x7cdcefb7, 0x0bdbdf21, 0x86d3d2d4, 0xf1d4e242, 0x68ddb3f8, 0x1fda836e, 0x81be16cd, 0xf6b9265b, 0x6fb077e1, 0x18b74777, 0x88085ae6, 0xff0f6a70, 0x66063bca, 0x11010b5c, 0x8f659eff, 0xf862ae69, 0x616bffd3, 0x166ccf45, 0xa00ae278, 0xd70dd2ee, 0x4e048354, 0x3903b3c2, 0xa7672661, 0xd06016f7, 0x4969474d, 0x3e6e77db, 0xaed16a4a, 0xd9d65adc, 0x40df0b66, 0x37d83bf0, 0xa9bcae53, 0xdebb9ec5, 0x47b2cf7f, 0x30b5ffe9, 0xbdbdf21c, 0xcabac28a, 0x53b39330, 0x24b4a3a6, 0xbad03605, 0xcdd70693, 0x54de5729, 0x23d967bf, 0xb3667a2e, 0xc4614ab8, 0x5d681b02, 0x2a6f2b94, 0xb40bbe37, 0xc30c8ea1, 0x5a05df1b, 0x2d02ef8d }; #define CRC_START(in_crc) (in_crc) = g_crc_seed #define CRC_PASS(in_pixel, in_crc) \ (in_crc) = g_crc_table[((in_crc) ^ (in_pixel)) & 0xff] ^ ((in_crc) >> 8) #define CRC_END(in_crc) (in_crc) = ((in_crc) ^ g_crc_seed) /*****************************************************************************/ static int get_string_crc(const char* text) { int index; int crc; CRC_START(crc); index = 0; while (text[index] != 0) { CRC_PASS(text[index], crc); index++; } CRC_END(crc); return crc; } /*****************************************************************************/ /* returns 0, event handled, 1 unhandled */ static int rail_win_send_text(Window win) { char* data = 0; struct stream* s; int len = 0; int flags; int crc; struct rail_window_data* rwd; LOG(10, ("chansrv::rail_win_send_text:")); len = rail_win_get_text(win, &data); rwd = rail_get_window_data_safe(win); if (rwd != 0) { if (data != 0) { if (rwd->valid & RWD_TITLE) { crc = get_string_crc(data); if (rwd->title_crc == crc) { LOG(10, ("chansrv::rail_win_send_text: skipping, title not changed")); g_free(data); XFree(rwd); return 0; } } } } else { LOG(0, ("chansrv::rail_win_send_text: error rail_get_window_data_safe failed")); g_free(data); return 1; } if (data && len > 0) { LOG(10, ("chansrv::rail_win_send_text: 0x%8.8lx text %s length %d", win, data, len)); make_stream(s); init_stream(s, len + 1024); flags = WINDOW_ORDER_TYPE_WINDOW | WINDOW_ORDER_FIELD_TITLE; out_uint32_le(s, 8); /* update title info */ out_uint32_le(s, win); /* window id */ out_uint32_le(s, flags); /* flags */ out_uint32_le(s, len); /* title size */ out_uint8a(s, data, len); /* title */ s_mark_end(s); send_rail_drawing_orders(s->data, (int)(s->end - s->data)); free_stream(s); /* update rail window data */ rwd->valid |= RWD_TITLE; crc = get_string_crc(data); rwd->title_crc = crc; rail_set_window_data(win, rwd); } g_free(data); XFree(rwd); return 0; } /*****************************************************************************/ static int rail_destroy_window(Window window_id) { struct stream *s; LOG(10, ("chansrv::rail_destroy_window 0x%8.8lx", window_id)); make_stream(s); init_stream(s, 1024); out_uint32_le(s, 4); /* destroy_window */ out_uint32_le(s, window_id); s_mark_end(s); send_rail_drawing_orders(s->data, (int)(s->end - s->data)); free_stream(s); return 0; } /*****************************************************************************/ static int rail_show_window(Window window_id, int show_state) { int flags; struct stream* s; LOG(10, ("chansrv::rail_show_window 0x%8.8lx 0x%x", window_id, show_state)); make_stream(s); init_stream(s, 1024); flags = WINDOW_ORDER_TYPE_WINDOW | WINDOW_ORDER_FIELD_SHOW; out_uint32_le(s, 6); /* show_window */ out_uint32_le(s, window_id); /* window_id */ out_uint32_le(s, flags); /* flags */ out_uint32_le(s, show_state); /* show_state */ s_mark_end(s); send_rail_drawing_orders(s->data, (int)(s->end - s->data)); free_stream(s); return 0; } /*****************************************************************************/ static int rail_create_window(Window window_id, Window owner_id) { int x; int y; tui32 width; tui32 height; tui32 border; Window root; tui32 depth; char* title_bytes = 0; int title_size = 0; XWindowAttributes attributes; int style; int ext_style; int num_window_rects = 1; int num_visibility_rects = 1; int i = 0; int flags; int index; int crc; Window transient_for = 0; struct rail_window_data* rwd; struct stream* s; LOG(10, ("chansrv::rail_create_window 0x%8.8lx", window_id)); rwd = rail_get_window_data_safe(window_id); if (rwd == 0) { LOG(0, ("chansrv::rail_create_window: error rail_get_window_data_safe failed")); return 0; } XGetGeometry(g_display, window_id, &root, &x, &y, &width, &height, &border, &depth); XGetWindowAttributes(g_display, window_id, &attributes); LOG(10, (" x %d y %d width %d height %d border_width %d", x, y, width, height, border)); index = list_index_of(g_window_list, window_id); if (index == -1) { LOG(10, (" create new window")); flags = WINDOW_ORDER_TYPE_WINDOW | WINDOW_ORDER_STATE_NEW; list_add_item(g_window_list, window_id); } else { LOG(10, (" update existing window")); flags = WINDOW_ORDER_TYPE_WINDOW; } title_size = 0; title_bytes = 0; XGetTransientForHint(g_display, window_id, &transient_for); if (attributes.override_redirect) { style = RAIL_STYLE_TOOLTIP; ext_style = RAIL_EXT_STYLE_TOOLTIP; /* for tooltips, we don't grab the window text */ } else if (transient_for > 0) { style = RAIL_STYLE_DIALOG; ext_style = RAIL_EXT_STYLE_DIALOG; owner_id = transient_for; title_size = rail_win_get_text(window_id, &title_bytes); } else { style = RAIL_STYLE_NORMAL; ext_style = RAIL_EXT_STYLE_NORMAL; title_size = rail_win_get_text(window_id, &title_bytes); } make_stream(s); init_stream(s, title_size + 1024 + num_window_rects * 8 + num_visibility_rects * 8); out_uint32_le(s, 2); /* create_window */ out_uint32_le(s, window_id); /* window_id */ out_uint32_le(s, owner_id); /* owner_window_id */ flags |= WINDOW_ORDER_FIELD_OWNER; out_uint32_le(s, style); /* style */ out_uint32_le(s, ext_style); /* extended_style */ flags |= WINDOW_ORDER_FIELD_STYLE; out_uint32_le(s, 0x05); /* show_state */ LOG(10, (" title %s", title_bytes)); flags |= WINDOW_ORDER_FIELD_SHOW; if (title_size > 0) { out_uint16_le(s, title_size); /* title_size */ out_uint8a(s, title_bytes, title_size); /* title */ rwd->valid |= RWD_TITLE; crc = get_string_crc(title_bytes); rwd->title_crc = crc; } else { out_uint16_le(s, 5); /* title_size */ out_uint8a(s, "title", 5); /* title */ rwd->valid |= RWD_TITLE; rwd->title_crc = 0; } LOG(10, (" set title info %d", title_size)); flags |= WINDOW_ORDER_FIELD_TITLE; out_uint32_le(s, 0); /* client_offset_x */ out_uint32_le(s, 0); /* client_offset_y */ flags |= WINDOW_ORDER_FIELD_CLIENT_AREA_OFFSET; out_uint32_le(s, width); /* client_area_width */ out_uint32_le(s, height); /* client_area_height */ flags |= WINDOW_ORDER_FIELD_CLIENT_AREA_SIZE; out_uint32_le(s, 0); /* rp_content */ out_uint32_le(s, g_root_window); /* root_parent_handle */ flags |= WINDOW_ORDER_FIELD_ROOT_PARENT; out_uint32_le(s, x); /* window_offset_x */ out_uint32_le(s, y); /* window_offset_y */ flags |= WINDOW_ORDER_FIELD_WND_OFFSET; out_uint32_le(s, 0); /* window_client_delta_x */ out_uint32_le(s, 0); /* window_client_delta_y */ flags |= WINDOW_ORDER_FIELD_WND_CLIENT_DELTA; out_uint32_le(s, width); /* window_width */ out_uint32_le(s, height); /* window_height */ flags |= WINDOW_ORDER_FIELD_WND_SIZE; out_uint16_le(s, num_window_rects); /* num_window_rects */ for (i = 0; i < num_window_rects; i++) { out_uint16_le(s, 0); /* left */ out_uint16_le(s, 0); /* top */ out_uint16_le(s, width); /* right */ out_uint16_le(s, height); /* bottom */ } flags |= WINDOW_ORDER_FIELD_WND_RECTS; out_uint32_le(s, x); /* visible_offset_x */ out_uint32_le(s, y); /* visible_offset_y */ flags |= WINDOW_ORDER_FIELD_VIS_OFFSET; out_uint16_le(s, num_visibility_rects); /* num_visibility_rects */ for (i = 0; i < num_visibility_rects; i++) { out_uint16_le(s, 0); /* left */ out_uint16_le(s, 0); /* top */ out_uint16_le(s, width); /* right */ out_uint16_le(s, height); /* bottom */ } flags |= WINDOW_ORDER_FIELD_VISIBILITY; out_uint32_le(s, flags); /*flags*/ s_mark_end(s); send_rail_drawing_orders(s->data, (int)(s->end - s->data)); free_stream(s); g_free(title_bytes); rail_set_window_data(window_id, rwd); XFree(rwd); return 0; } /*****************************************************************************/ /* returns 0, event handled, 1 unhandled */ int rail_configure_request_window(XConfigureRequestEvent* config) { int num_window_rects = 1; int num_visibility_rects = 1; int i = 0; int flags; int index; int window_id; int mask; int resized = 0; struct rail_window_data* rwd; struct stream* s; window_id = config->window; mask = config->value_mask; LOG(10, ("chansrv::rail_configure_request_window: mask %d", mask)); if (mask & CWStackMode) { LOG(10, ("chansrv::rail_configure_request_window: CWStackMode " "detail 0x%8.8x above 0x%8.8lx", config->detail, config->above)); if (config->detail == Above) { LOG(10, ("chansrv::rail_configure_request_window: bring to front " "window_id 0x%8.8x", window_id)); /* 0x05 - Show the window in its current size and position. */ rail_show_window(window_id, 5); } } rwd = rail_get_window_data(window_id); if (rwd == 0) { rwd = (struct rail_window_data*)g_malloc(sizeof(struct rail_window_data), 1); rwd->x = config->x; rwd->y = config->y; rwd->width = config->width; rwd->height = config->height; rwd->valid |= RWD_X | RWD_Y | RWD_WIDTH | RWD_HEIGHT; rail_set_window_data(window_id, rwd); g_free(rwd); return 0; } if (!resized) { if (mask & CWX) { if (rwd->valid & RWD_X) { if (rwd->x != config->x) { resized = 1; rwd->x = config->x; } } else { resized = 1; rwd->x = config->x; rwd->valid |= RWD_X; } } } if (!resized) { if (mask & CWY) { if (rwd->valid & RWD_Y) { if (rwd->y != config->y) { resized = 1; rwd->y = config->y; } } else { resized = 1; rwd->y = config->y; rwd->valid |= RWD_Y; } } } if (!resized) { if (mask & CWWidth) { if (rwd->valid & RWD_WIDTH) { if (rwd->width != config->width) { resized = 1; rwd->width = config->width; } } else { resized = 1; rwd->width = config->width; rwd->valid |= RWD_WIDTH; } } } if (!resized) { if (mask & CWHeight) { if (rwd->valid & RWD_HEIGHT) { if (rwd->height != config->height) { resized = 1; rwd->height = config->height; } } else { resized = 1; rwd->height = config->height; rwd->valid |= RWD_HEIGHT; } } } if (resized) { rail_set_window_data(window_id, rwd); XFree(rwd); } else { XFree(rwd); return 0; } LOG(10, ("chansrv::rail_configure_request_window: 0x%8.8x", window_id)); LOG(10, (" x %d y %d width %d height %d border_width %d", config->x, config->y, config->width, config->height, config->border_width)); index = list_index_of(g_window_list, window_id); if (index == -1) { /* window isn't mapped yet */ LOG(0, ("chansrv::rail_configure_request_window: window not mapped")); return 0; } flags = WINDOW_ORDER_TYPE_WINDOW; make_stream(s); init_stream(s, 1024 + num_window_rects * 8 + num_visibility_rects * 8); out_uint32_le(s, 10); /* configure_window */ out_uint32_le(s, window_id); /* window_id */ out_uint32_le(s, 0); /* client_offset_x */ out_uint32_le(s, 0); /* client_offset_y */ flags |= WINDOW_ORDER_FIELD_CLIENT_AREA_OFFSET; out_uint32_le(s, config->width); /* client_area_width */ out_uint32_le(s, config->height); /* client_area_height */ flags |= WINDOW_ORDER_FIELD_CLIENT_AREA_SIZE; out_uint32_le(s, 0); /* rp_content */ out_uint32_le(s, g_root_window); /* root_parent_handle */ flags |= WINDOW_ORDER_FIELD_ROOT_PARENT; out_uint32_le(s, config->x); /* window_offset_x */ out_uint32_le(s, config->y); /* window_offset_y */ flags |= WINDOW_ORDER_FIELD_WND_OFFSET; out_uint32_le(s, 0); /* window_client_delta_x */ out_uint32_le(s, 0); /* window_client_delta_y */ flags |= WINDOW_ORDER_FIELD_WND_CLIENT_DELTA; out_uint32_le(s, config->width); /* window_width */ out_uint32_le(s, config->height); /* window_height */ flags |= WINDOW_ORDER_FIELD_WND_SIZE; out_uint16_le(s, num_window_rects); /* num_window_rects */ for (i = 0; i < num_window_rects; i++) { out_uint16_le(s, 0); /* left */ out_uint16_le(s, 0); /* top */ out_uint16_le(s, config->width); /* right */ out_uint16_le(s, config->height); /* bottom */ } flags |= WINDOW_ORDER_FIELD_WND_RECTS; out_uint32_le(s, config->x); /* visible_offset_x */ out_uint32_le(s, config->y); /* visible_offset_y */ flags |= WINDOW_ORDER_FIELD_VIS_OFFSET; out_uint16_le(s, num_visibility_rects); /* num_visibility_rects */ for (i = 0; i < num_visibility_rects; i++) { out_uint16_le(s, 0); /* left */ out_uint16_le(s, 0); /* top */ out_uint16_le(s, config->width); /* right */ out_uint16_le(s, config->height); /* bottom */ } flags |= WINDOW_ORDER_FIELD_VISIBILITY; out_uint32_le(s, flags); /*flags*/ s_mark_end(s); send_rail_drawing_orders(s->data, (int)(s->end - s->data)); free_stream(s); return 0; } /*****************************************************************************/ /* returns 0, event handled, 1 unhandled */ int rail_configure_window(XConfigureEvent *config) { int num_window_rects = 1; int num_visibility_rects = 1; int i = 0; int flags; int index; int window_id; struct stream* s; window_id = config->window; LOG(10, ("chansrv::rail_configure_window 0x%8.8x", window_id)); LOG(10, (" x %d y %d width %d height %d border_width %d", config->x, config->y, config->width, config->height, config->border_width)); index = list_index_of(g_window_list, window_id); if (index == -1) { /* window isn't mapped yet */ return 0; } flags = WINDOW_ORDER_TYPE_WINDOW; make_stream(s); init_stream(s, 1024 + num_window_rects * 8 + num_visibility_rects * 8); out_uint32_le(s, 10); /* configure_window */ out_uint32_le(s, window_id); /* window_id */ out_uint32_le(s, 0); /* client_offset_x */ out_uint32_le(s, 0); /* client_offset_y */ flags |= WINDOW_ORDER_FIELD_CLIENT_AREA_OFFSET; out_uint32_le(s, config->width); /* client_area_width */ out_uint32_le(s, config->height); /* client_area_height */ flags |= WINDOW_ORDER_FIELD_CLIENT_AREA_SIZE; out_uint32_le(s, 0); /* rp_content */ out_uint32_le(s, g_root_window); /* root_parent_handle */ flags |= WINDOW_ORDER_FIELD_ROOT_PARENT; out_uint32_le(s, config->x); /* window_offset_x */ out_uint32_le(s, config->y); /* window_offset_y */ flags |= WINDOW_ORDER_FIELD_WND_OFFSET; out_uint32_le(s, 0); /* window_client_delta_x */ out_uint32_le(s, 0); /* window_client_delta_y */ flags |= WINDOW_ORDER_FIELD_WND_CLIENT_DELTA; out_uint32_le(s, config->width); /* window_width */ out_uint32_le(s, config->height); /* window_height */ flags |= WINDOW_ORDER_FIELD_WND_SIZE; out_uint16_le(s, num_window_rects); /* num_window_rects */ for (i = 0; i < num_window_rects; i++) { out_uint16_le(s, 0); /* left */ out_uint16_le(s, 0); /* top */ out_uint16_le(s, config->width); /* right */ out_uint16_le(s, config->height); /* bottom */ } flags |= WINDOW_ORDER_FIELD_WND_RECTS; out_uint32_le(s, config->x); /* visible_offset_x */ out_uint32_le(s, config->y); /* visible_offset_y */ flags |= WINDOW_ORDER_FIELD_VIS_OFFSET; out_uint16_le(s, num_visibility_rects); /* num_visibility_rects */ for (i = 0; i < num_visibility_rects; i++) { out_uint16_le(s, 0); /* left */ out_uint16_le(s, 0); /* top */ out_uint16_le(s, config->width); /* right */ out_uint16_le(s, config->height); /* bottom */ } flags |= WINDOW_ORDER_FIELD_VISIBILITY; out_uint32_le(s, flags); /*flags*/ s_mark_end(s); send_rail_drawing_orders(s->data, (int)(s->end - s->data)); free_stream(s); return 0; } /*****************************************************************************/ static int rail_desktop_resize(XEvent *lxevent) { LOG(0, ("rail_desktop_resize:")); return 0; } /*****************************************************************************/ /* returns 0, event handled, 1 unhandled */ int rail_xevent(void *xevent) { XEvent *lxevent; XEvent lastevent; XWindowChanges xwc; int rv; int index; XWindowAttributes wnd_attributes; char* prop_name; LOG(10, ("chansrv::rail_xevent:")); if (!g_rail_up) { return 1; } rv = 1; lxevent = (XEvent *)xevent; switch (lxevent->type) { case PropertyNotify: prop_name = XGetAtomName(g_display, lxevent->xproperty.atom); LOG(10, (" got PropertyNotify window_id 0x%8.8lx %s state new %d", lxevent->xproperty.window, prop_name, lxevent->xproperty.state == PropertyNewValue)); if (list_index_of(g_window_list, lxevent->xproperty.window) < 0) { break; } if (g_strcmp(prop_name, "WM_NAME") == 0 || g_strcmp(prop_name, "_NET_WM_NAME") == 0) { XGetWindowAttributes(g_display, lxevent->xproperty.window, &wnd_attributes); if (wnd_attributes.map_state == IsViewable) { rail_win_send_text(lxevent->xproperty.window); rv = 0; } } XFree(prop_name); break; case ConfigureRequest: LOG(10, (" got ConfigureRequest window_id 0x%8.8lx", lxevent->xconfigurerequest.window)); g_memset(&xwc, 0, sizeof(xwc)); xwc.x = lxevent->xconfigurerequest.x; xwc.y = lxevent->xconfigurerequest.y; xwc.width = lxevent->xconfigurerequest.width; xwc.height = lxevent->xconfigurerequest.height; xwc.border_width = lxevent->xconfigurerequest.border_width; xwc.sibling = lxevent->xconfigurerequest.above; xwc.stack_mode = lxevent->xconfigurerequest.detail; XConfigureWindow(g_display, lxevent->xconfigurerequest.window, lxevent->xconfigurerequest.value_mask, &xwc); rail_configure_request_window(&(lxevent->xconfigurerequest)); rv = 0; break; case CreateNotify: LOG(10, (" got CreateNotify window 0x%8.8lx parent 0x%8.8lx", lxevent->xcreatewindow.window, lxevent->xcreatewindow.parent)); rail_select_input(lxevent->xcreatewindow.window); break; case DestroyNotify: LOG(10, (" got DestroyNotify window 0x%8.8lx event 0x%8.8lx", lxevent->xdestroywindow.window, lxevent->xdestroywindow.event)); if (lxevent->xdestroywindow.window != lxevent->xdestroywindow.event) { break; } index = list_index_of(g_window_list, lxevent->xdestroywindow.window); if (index >= 0) { rail_destroy_window(lxevent->xdestroywindow.window); list_remove_item(g_window_list, index); } rv = 0; break; case MapRequest: LOG(10, (" got MapRequest window 0x%8.8lx", lxevent->xmaprequest.window)); XMapWindow(g_display, lxevent->xmaprequest.window); break; case MapNotify: LOG(10, (" got MapNotify window 0x%8.8lx event 0x%8.8lx", lxevent->xmap.window, lxevent->xmap.event)); if (lxevent->xmap.window != lxevent->xmap.event) { break; } if (!is_window_valid_child_of_root(lxevent->xmap.window)) { break; } XGetWindowAttributes(g_display, lxevent->xmap.window, &wnd_attributes); if (wnd_attributes.map_state == IsViewable) { rail_create_window(lxevent->xmap.window, g_root_window); if (!wnd_attributes.override_redirect) { rail_win_set_state(lxevent->xmap.window, 0x1); /* NormalState */ rail_win_send_text(lxevent->xmap.window); } rv = 0; } break; case UnmapNotify: LOG(10, (" got UnmapNotify 0x%8.8lx", lxevent->xunmap.event)); if (lxevent->xunmap.window != lxevent->xunmap.event) { break; } if (is_window_valid_child_of_root(lxevent->xunmap.window)) { index = list_index_of(g_window_list, lxevent->xunmap.window); LOG(10, (" window 0x%8.8lx is unmapped", lxevent->xunmap.window)); if (index >= 0) { XGetWindowAttributes(g_display, lxevent->xunmap.window, &wnd_attributes); if (wnd_attributes.override_redirect) { // remove popups rail_destroy_window(lxevent->xunmap.window); list_remove_item(g_window_list, index); } else { rail_show_window(lxevent->xunmap.window, 0x0); } rv = 0; } } break; case ConfigureNotify: LOG(10, (" got ConfigureNotify 0x%8.8lx event 0x%8.8lx", lxevent->xconfigure.window, lxevent->xconfigure.event)); rv = 0; if (lxevent->xconfigure.event != lxevent->xconfigure.window || lxevent->xconfigure.override_redirect) { break; } /* skip dup ConfigureNotify */ while (XCheckTypedWindowEvent(g_display, lxevent->xconfigure.window, ConfigureNotify, &lastevent)) { if (lastevent.xconfigure.event == lastevent.xconfigure.window && lxevent->xconfigure.override_redirect == 0) { lxevent = &lastevent; } } #if 0 rail_configure_window(&(lxevent->xconfigure)); #endif break; case FocusIn: LOG(10, (" got FocusIn")); g_focus_win = lxevent->xfocus.window; break; case FocusOut: LOG(10, (" got FocusOut")); break; case ButtonPress: LOG(10, (" got ButtonPress")); break; case EnterNotify: LOG(10, (" got EnterNotify")); break; case LeaveNotify: LOG(10, (" got LeaveNotify")); break; case ReparentNotify: LOG(10, (" got ReparentNotify window 0x%8.8lx parent 0x%8.8lx " "event 0x%8.8lx x %d y %d override redirect %d", lxevent->xreparent.window, lxevent->xreparent.parent, lxevent->xreparent.event, lxevent->xreparent.x, lxevent->xreparent.y, lxevent->xreparent.override_redirect)); if (lxevent->xreparent.window != lxevent->xreparent.event) { break; } if (lxevent->xreparent.parent != g_root_window) { index = list_index_of(g_window_list, lxevent->xreparent.window); if (index >= 0) { rail_destroy_window(lxevent->xreparent.window); list_remove_item(g_window_list, index); } } rv = 0; break; default: if (g_xrr_event_base > 0) { if (lxevent->type == g_xrr_event_base + RRScreenChangeNotify) { rail_desktop_resize(lxevent); rv = 0; break; } } } return rv; } xrdp-0.9.5/sesman/chansrv/chansrv_common.h000644 001751 001751 00000001554 13133346204 020545 0ustar00metameta000000 000000 /** * xrdp: A Remote Desktop Protocol server. * * Copyright (C) Laxmikant Rashinkar 2009-2014 * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ #ifndef _CHANSRV_COMMON_H #define _CHANSRV_COMMON_H #include "parse.h" #include "os_calls.h" int read_entire_packet(struct stream *src, struct stream **dest, int chan_flags, int length, int total_length); #endif xrdp-0.9.5/sesman/chansrv/smartcard.h000644 001751 001751 00000014444 13174271344 017522 0ustar00metameta000000 000000 /** * xrdp: A Remote Desktop Protocol server. * * Copyright (C) Laxmikant Rashinkar 2013 LK.Rashinkar@gmail.com * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. * */ /* * smartcard redirection support */ #ifndef _SMARTCARD_C #define _SMARTCARD_C #include "parse.h" #include "irp.h" #include "trans.h" #define SCARD_SHARE_EXCLUSIVE 0x00000001 #define SCARD_SHARE_SHARED 0x00000002 #define SCARD_SHARE_DIRECT 0x00000003 /* see [MS-RDPESC] 2.2.5 protocol identifier - Table A */ #define SCARD_PROTOCOL_UNDEFINED 0x00000000 #define SCARD_PROTOCOL_T0 0x00000001 #define SCARD_PROTOCOL_T1 0x00000002 #define SCARD_PROTOCOL_Tx 0x00000003 #define SCARD_PROTOCOL_RAW 0x00010000 /* see [MS-RDPESC] 2.2.5 protocol identifier - Table B */ #define SCARD_PROTOCOL_DEFAULT 0x80000000 #define SCARD_PROTOCOL_OPTIMAL 0x00000000 /* initialization type */ #define SCARD_LEAVE_CARD 0x00000000 /* do not do anything */ #define SCARD_RESET_CARD 0x00000001 /* reset smart card */ #define SCARD_UNPOWER_CARD 0x00000002 /* turn off and reset card */ struct xrdp_scard_io_request { tui32 dwProtocol; tui32 cbPciLength; int extra_bytes; char *extra_data; }; typedef struct reader_state { char reader_name[128]; tui32 current_state; tui32 event_state; tui32 atr_len; /* number of bytes in atr[] */ tui8 atr[36]; /* * share mode flag, can be one of: * SCARD_SHARE_EXCLUSIVE app not willing to share smartcard with other apps * SCARD_SHARE_SHARED app willing to share smartcard with other apps * SCARD_SHARE_DIRECT app demands direct control of smart card, hence * it is not available to other readers */ tui32 dwShareMode; /* * This field MUST have a value from Table A which is logically * OR'ed with a value from Table B. */ tui32 dwPreferredProtocols; /* * initialization type, must be one of the initialization type * defined above */ tui32 init_type; /* required by scard_send_transmit(), scard_send_control() */ tui32 map0; tui32 map1; tui32 map2; tui32 map3; tui32 map4; tui32 map5; tui32 map6; tui32 dwProtocol; tui32 cbPciLength; tui32 cbSendLength; tui32 cbRecvLength; tui32 dwControlCode; tui32 cbOutBufferSize; tui32 dwAttribId; tui32 dwAttrLen; } READER_STATE; void scard_device_announce(tui32 device_id); int scard_get_wait_objs(tbus *objs, int *count, int *timeout); int scard_check_wait_objs(void); int scard_init(void); int scard_deinit(void); int scard_send_establish_context(void *user_data, int scope); int scard_send_release_context(void *user_data, char *context, int context_bytes); int scard_send_is_valid_context(void *user_data, char *context, int context_bytes); int scard_send_list_readers(void *user_data, char *context, int context_bytes, char *groups, int cchReaders, int wide); int scard_send_get_status_change(void *user_data, char *context, int context_bytes, int wide, tui32 timeout, tui32 num_readers, READER_STATE* rsa); int scard_send_connect(void *user_data, char *context, int context_bytes, int wide, READER_STATE* rs); int scard_send_reconnect(void *user_data, char *context, int context_bytes, char *card, int card_bytes, READER_STATE* rs); int scard_send_begin_transaction(void *user_data, char *context, int context_bytes, char *card, int card_bytes); int scard_send_end_transaction(void *user_data, char *context, int context_bytes, char *card, int card_bytes, tui32 dwDisposition); int scard_send_status(void *user_data, int wide, char *context, int context_bytes, char *card, int card_bytes, int cchReaderLen, int cbAtrLen); int scard_send_disconnect(void *user_data, char *context, int context_bytes, char *card, int card_bytes, int dwDisposition); int scard_send_transmit(void *user_data, char *context, int context_bytes, char *card, int card_bytes, char *send_data, int send_bytes, int recv_bytes, struct xrdp_scard_io_request *send_ior, struct xrdp_scard_io_request *recv_ior); int scard_send_control(void *user_data, char *context, int context_bytes, char *card, int card_bytes, char *send_data, int send_bytes, int recv_bytes, int control_code); int scard_send_cancel(void *user_data, char *context, int context_bytes); int scard_send_get_attrib(void *user_data, char *card, int card_bytes, READER_STATE* rs); /* * Notes: * SCardTransmit - partially done * SCardControl - partially done * SCardListReaderGroups - not supported * SCardSetAttrib - not supported */ #endif /* end #ifndef _SMARTCARD_C */ xrdp-0.9.5/sesman/chansrv/chansrv.h000644 001751 001751 00000005250 13174271344 017201 0ustar00metameta000000 000000 /** * xrdp: A Remote Desktop Protocol server. * * Copyright (C) Jay Sorg 2009-2013 * Copyright (C) Laxmikant Rashinkar 2009-2013 * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ #if !defined(CHANSRV_H) #define CHANSRV_H #include "arch.h" #include "parse.h" #include "log.h" #define MAX_DVC_CHANNELS 32 struct chan_out_data { struct stream *s; struct chan_out_data *next; }; struct chan_item { int id; int flags; char name[16]; struct chan_out_data *head; struct chan_out_data *tail; }; /* data in struct trans::callback_data */ struct xrdp_api_data { int chan_id; char header[64]; int flags; /* for dynamic virtual channels */ struct trans *transp; int dvc_chan_id; int is_connected; }; int g_is_term(void); int send_channel_data(int chan_id, char *data, int size); int send_rail_drawing_orders(char* data, int size); int main_cleanup(void); int add_timeout(int msoffset, void (*callback)(void* data), void* data); int find_empty_slot_in_dvc_channels(void); struct xrdp_api_data * struct_from_dvc_chan_id(tui32 dvc_chan_id); int remove_struct_with_chan_id(tui32 dvc_chan_id); #define LOG_LEVEL 5 #define LOG(_a, _params) \ { \ if (_a < LOG_LEVEL) \ { \ g_write("xrdp-chansrv [%10.10u]: ", g_time3()); \ g_writeln _params ; \ } \ } #define LOGM(_args) do { log_message _args ; } while (0) #ifndef GSET_UINT8 #define GSET_UINT8(_ptr, _offset, _data) \ *((unsigned char*) (((unsigned char*)(_ptr)) + (_offset))) = (unsigned char)(_data) #define GGET_UINT8(_ptr, _offset) \ (*((unsigned char*) (((unsigned char*)(_ptr)) + (_offset)))) #define GSET_UINT16(_ptr, _offset, _data) \ GSET_UINT8(_ptr, _offset, _data); \ GSET_UINT8(_ptr, (_offset) + 1, (_data) >> 8) #define GGET_UINT16(_ptr, _offset) \ (GGET_UINT8(_ptr, _offset)) | \ ((GGET_UINT8(_ptr, (_offset) + 1)) << 8) #define GSET_UINT32(_ptr, _offset, _data) \ GSET_UINT16(_ptr, _offset, _data); \ GSET_UINT16(_ptr, (_offset) + 2, (_data) >> 16) #define GGET_UINT32(_ptr, _offset) \ (GGET_UINT16(_ptr, _offset)) | \ ((GGET_UINT16(_ptr, (_offset) + 2)) << 16) #endif #endif xrdp-0.9.5/sesman/chansrv/fifo.h000644 001751 001751 00000002033 13133346204 016445 0ustar00metameta000000 000000 /** * xrdp: A Remote Desktop Protocol server. * * Copyright (C) Laxmikant Rashinkar 2013 LK.Rashinkar@gmail.com * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ /* FIFO implementation to store a pointer to a user struct */ typedef struct fifo { long* user_data; int rd_ptr; int wr_ptr; int entries; } FIFO; int fifo_init(FIFO* fp, int num_entries); int fifo_deinit(FIFO* fp); int fifo_is_empty(FIFO* fp); int fifo_insert(FIFO* fp, void* data); void* fifo_remove(FIFO* fp); void* fifo_peek(FIFO* fp); xrdp-0.9.5/sesman/chansrv/irp.h000644 001751 001751 00000004353 13174271344 016332 0ustar00metameta000000 000000 /** * xrdp: A Remote Desktop Protocol server. * * Copyright (C) Laxmikant Rashinkar 2013 LK.Rashinkar@gmail.com * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. * */ /* * manage I/O for redirected file system and devices */ #ifndef __IRP_H #define __IRP_H typedef struct fuse_data FUSE_DATA; struct fuse_data { void *data_ptr; FUSE_DATA *next; }; /* An I/O Resource Packet to track I/O calls */ typedef struct irp IRP; struct irp { tui32 CompletionId; /* unique number */ tui32 DeviceId; /* identifies remote device */ tui32 FileId; /* RDP client provided unique number */ char completion_type; /* describes I/O type */ char pathname[256]; /* absolute pathname */ char gen_buf[1024]; /* for general use */ int type; FUSE_DATA *fd_head; /* point to first FUSE opaque object */ FUSE_DATA *fd_tail; /* point to last FUSE opaque object */ IRP *next; /* point to next IRP */ IRP *prev; /* point to previous IRP */ int scard_index; /* used to smart card to locate dev */ void (*callback)(struct stream *s, IRP *irp, tui32 DeviceId, tui32 CompletionId, tui32 IoStatus); void *user_data; }; IRP * devredir_irp_new(void); IRP * devredir_irp_clone(IRP *irp); int devredir_irp_delete(IRP *irp); IRP * devredir_irp_find(tui32 completion_id); IRP * devredir_irp_find_by_fileid(tui32 FileId); IRP * devredir_irp_get_last(void); void devredir_irp_dump(void); #endif /* end ifndef __IRP_H */ xrdp-0.9.5/sesman/chansrv/sound.h000644 001751 001751 00000003363 13174271344 016670 0ustar00metameta000000 000000 /** * xrdp: A Remote Desktop Protocol server. * * Copyright (C) Jay Sorg 2009-2014 * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ #ifndef _SOUND_H_ #define _SOUND_H_ #include "arch.h" #include "parse.h" #include "os_calls.h" #include "chansrv.h" #include "trans.h" #define SNDC_CLOSE 0x01 #define SNDC_WAVE 0x02 #define SNDC_SETVOLUME 0x03 #define SNDC_SETPITCH 0x04 #define SNDC_WAVECONFIRM 0x05 #define SNDC_TRAINING 0x06 #define SNDC_FORMATS 0x07 #define SNDC_CRYPTKEY 0x08 #define SNDC_WAVEENCRYPT 0x09 #define SNDC_UDPWAVE 0x0A #define SNDC_UDPWAVELAST 0x0B #define SNDC_QUALITYMODE 0x0C /* used for sound input (mic) */ #define SNDC_REC_NEGOTIATE 39 #define SNDC_REC_START 40 #define SNDC_REC_STOP 41 #define SNDC_REC_DATA 42 #define SNDC_REC_SET_VOLUME 43 /* commands recvd from pulseaudio source */ #define PA_CMD_START_REC 1 #define PA_CMD_STOP_REC 2 #define PA_CMD_SEND_DATA 3 int sound_init(void); int sound_deinit(void); int sound_get_wait_objs(tbus* objs, int* count, int* timeout); int sound_check_wait_objs(void); int sound_data_in(struct stream* s, int chan_id, int chan_flags, int length, int total_length); #endif xrdp-0.9.5/sesman/chansrv/clipboard_file.c000644 001751 001751 00000050500 13213711022 020446 0ustar00metameta000000 000000 /** * xrdp: A Remote Desktop Protocol server. * * Copyright (C) Jay Sorg 2012 * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ /* MS-RDPECLIP * http://msdn.microsoft.com/en-us/library/cc241066%28prot.20%29.aspx * * CLIPRDR_FILEDESCRIPTOR * http://msdn.microsoft.com/en-us/library/ff362447%28prot.20%29.aspx */ #if defined(HAVE_CONFIG_H) #include #endif #include #include #include #include #include "arch.h" #include "parse.h" #include "os_calls.h" #include "list.h" #include "chansrv.h" #include "clipboard.h" #include "clipboard_file.h" #include "clipboard_common.h" #include "xcommon.h" #include "chansrv_fuse.h" /* module based logging */ #define LOG_ERROR 0 #define LOG_INFO 1 #define LOG_DEBUG 2 #define LOG_LVL LOG_ERROR #define log_error(_params...) \ { \ g_write("[%10.10u]: CLIPFILE %s: %d : ERROR: ", \ g_time3(), __func__, __LINE__); \ g_writeln (_params); \ } #define log_always(_params...) \ { \ g_write("[%10.10u]: CLIPFILE %s: %d : ALWAYS: ", \ g_time3(), __func__, __LINE__); \ g_writeln (_params); \ } #define log_info(_params...) \ { \ if (LOG_INFO <= LOG_LVL) \ { \ g_write("[%10.10u]: CLIPFILE %s: %d : ", \ g_time3(), __func__, __LINE__); \ g_writeln (_params); \ } \ } #define log_debug(_params...) \ { \ if (LOG_DEBUG <= LOG_LVL) \ { \ g_write("[%10.10u]: CLIPFILE %s: %d : ", \ g_time3(), __func__, __LINE__); \ g_writeln (_params); \ } \ } extern int g_cliprdr_chan_id; /* in chansrv.c */ extern struct clip_s2c g_clip_s2c; /* in clipboard.c */ extern struct clip_c2s g_clip_c2s; /* in clipboard.c */ extern char g_fuse_clipboard_path[]; struct cb_file_info { char pathname[256]; char filename[256]; int flags; int size; tui64 time; }; static struct list *g_files_list = 0; /* used when server is asking for file info from the client */ static int g_file_request_sent_type = 0; /* number of seconds from 1 Jan. 1601 00:00 to 1 Jan 1970 00:00 UTC */ #define CB_EPOCH_DIFF 11644473600LL /*****************************************************************************/ #if 0 static tui64 timeval2wintime(struct timeval *tv) { tui64 result; result = CB_EPOCH_DIFF; result += tv->tv_sec; result *= 10000000LL; result += tv->tv_usec * 10; return result; } #endif /*****************************************************************************/ /* this will replace %20 or any hex with the space or correct char * returns error */ static int clipboard_check_file(char *filename) { char lfilename[256]; char jchr[8]; int lindex; int index; g_memset(lfilename, 0, 256); lindex = 0; index = 0; while (filename[index] != 0) { if (filename[index] == '%') { jchr[0] = filename[index + 1]; jchr[1] = filename[index + 2]; jchr[2] = 0; index += 3; lfilename[lindex] = g_htoi(jchr); lindex++; } else { lfilename[lindex] = filename[index]; lindex++; index++; } } log_debug("[%s] [%s]", filename, lfilename); g_strcpy(filename, lfilename); return 0; } /*****************************************************************************/ static int clipboard_get_file(const char *file, int bytes) { int sindex; int pindex; int flags; char full_fn[256]; /* /etc/xrdp/xrdp.ini */ char filename[256]; /* xrdp.ini */ char pathname[256]; /* /etc/xrdp */ struct cb_file_info *cfi; /* x-special/gnome-copied-files */ if ((g_strncmp(file, "copy", 4) == 0) && (bytes == 4)) { return 0; } if ((g_strncmp(file, "cut", 3) == 0) && (bytes == 3)) { return 0; } sindex = 0; flags = CB_FILE_ATTRIBUTE_ARCHIVE; /* text/uri-list */ /* x-special/gnome-copied-files */ if (g_strncmp(file, "file://", 7) == 0) { sindex = 7; } pindex = bytes; while (pindex > sindex) { if (file[pindex] == '/') { break; } pindex--; } g_memset(pathname, 0, 256); g_memset(filename, 0, 256); g_memcpy(pathname, file + sindex, pindex - sindex); if (pathname[0] == 0) { pathname[0] = '/'; } g_memcpy(filename, file + pindex + 1, (bytes - 1) - pindex); /* this should replace %20 with space */ clipboard_check_file(pathname); clipboard_check_file(filename); g_snprintf(full_fn, 255, "%s/%s", pathname, filename); if (g_directory_exist(full_fn)) { log_error("clipboard_get_file: file [%s] is a directory, " "not supported", full_fn); flags |= CB_FILE_ATTRIBUTE_DIRECTORY; return 1; } if (!g_file_exist(full_fn)) { log_error("clipboard_get_file: file [%s] does not exist", full_fn); return 1; } else { cfi = (struct cb_file_info*)g_malloc(sizeof(struct cb_file_info), 1); list_add_item(g_files_list, (tintptr)cfi); g_strcpy(cfi->filename, filename); g_strcpy(cfi->pathname, pathname); cfi->size = g_file_get_size(full_fn); cfi->flags = flags; cfi->time = (g_time1() + CB_EPOCH_DIFF) * 10000000LL; log_debug("ok filename [%s] pathname [%s] size [%d]", cfi->filename, cfi->pathname, cfi->size); } return 0; } /*****************************************************************************/ static int clipboard_get_files(const char *files, int bytes) { int index; int file_index; char file[512]; file_index = 0; for (index = 0; index < bytes; index++) { if (files[index] == '\n' || files[index] == '\r') { if (file_index > 0) { if (clipboard_get_file(file, file_index) == 0) { } file_index = 0; } } else { file[file_index] = files[index]; file_index++; } } if (file_index > 0) { if (clipboard_get_file(file, file_index) == 0) { } } if (g_files_list->count < 1) { return 1; } return 0; } /*****************************************************************************/ /* server to client */ /* response to client asking for clipboard contents that is file list */ int clipboard_send_data_response_for_file(const char *data, int data_size) { struct stream *s; int size; int rv; int bytes_after_header; int cItems; int flags; int index; tui32 ui32; char fn[256]; struct cb_file_info *cfi; log_debug("clipboard_send_data_response_for_file: data_size %d", data_size); //g_hexdump(data, data_size); if (g_files_list == 0) { g_files_list = list_create(); g_files_list->auto_free = 1; } list_clear(g_files_list); clipboard_get_files(data, data_size); cItems = g_files_list->count; bytes_after_header = cItems * 592 + 4; make_stream(s); init_stream(s, 64 + bytes_after_header); out_uint16_le(s, CB_FORMAT_DATA_RESPONSE); /* 5 CLIPRDR_DATA_RESPONSE */ out_uint16_le(s, CB_RESPONSE_OK); /* 1 status */ out_uint32_le(s, bytes_after_header); out_uint32_le(s, cItems); for (index = 0; index < cItems; index++) { cfi = (struct cb_file_info *)list_get_item(g_files_list, index); flags = CB_FD_ATTRIBUTES | CB_FD_FILESIZE | CB_FD_WRITESTIME | CB_FD_PROGRESSUI; out_uint32_le(s, flags); out_uint8s(s, 32); /* reserved1 */ flags = cfi->flags; out_uint32_le(s, flags); out_uint8s(s, 16); /* reserved2 */ /* file time */ /* 100-nanoseconds intervals since 1 January 1601 */ //out_uint32_le(s, 0x2c305d08); /* 25 October 2009, 21:17 */ //out_uint32_le(s, 0x01ca55f3); ui32 = cfi->time & 0xffffffff; out_uint32_le(s, ui32); ui32 = cfi->time >> 32; out_uint32_le(s, ui32); /* file size */ out_uint32_le(s, 0); out_uint32_le(s, cfi->size); g_snprintf(fn, 255, "%s", cfi->filename); clipboard_out_unicode(s, fn, 256); out_uint8s(s, 8); /* pad */ } out_uint32_le(s, 0); s_mark_end(s); size = (int)(s->end - s->data); rv = send_channel_data(g_cliprdr_chan_id, s->data, size); free_stream(s); return rv; } /*****************************************************************************/ /* send the file size from server to the client */ static int clipboard_send_file_size(int streamId, int lindex) { struct stream *s; int size; int rv; int file_size; struct cb_file_info *cfi; if (g_files_list == 0) { log_error("clipboard_send_file_size: error g_files_list is nil"); return 1; } cfi = (struct cb_file_info *)list_get_item(g_files_list, lindex); if (cfi == 0) { log_error("clipboard_send_file_size: error cfi is nil"); return 1; } file_size = cfi->size; log_debug("clipboard_send_file_size: streamId %d file_size %d", streamId, file_size); make_stream(s); init_stream(s, 8192); out_uint16_le(s, CB_FILECONTENTS_RESPONSE); /* 9 */ out_uint16_le(s, CB_RESPONSE_OK); /* 1 status */ out_uint32_le(s, 12); out_uint32_le(s, streamId); out_uint32_le(s, file_size); out_uint32_le(s, 0); out_uint32_le(s, 0); s_mark_end(s); size = (int)(s->end - s->data); rv = send_channel_data(g_cliprdr_chan_id, s->data, size); free_stream(s); return rv; } /*****************************************************************************/ /* ask the client to send the file size */ int clipboard_request_file_size(int stream_id, int lindex) { struct stream *s; int size; int rv; log_debug("clipboard_request_file_size:"); if (g_file_request_sent_type != 0) { log_error("clipboard_request_file_size: warning, still waiting " "for CB_FILECONTENTS_RESPONSE"); } make_stream(s); init_stream(s, 8192); out_uint16_le(s, CB_FILECONTENTS_REQUEST); /* 8 */ out_uint16_le(s, 0); out_uint32_le(s, 28); out_uint32_le(s, stream_id); out_uint32_le(s, lindex); out_uint32_le(s, CB_FILECONTENTS_SIZE); out_uint32_le(s, 0); /* nPositionLow */ out_uint32_le(s, 0); /* nPositionHigh */ out_uint32_le(s, 0); /* cbRequested */ out_uint32_le(s, 0); /* clipDataId */ out_uint32_le(s, 0); s_mark_end(s); size = (int)(s->end - s->data); rv = send_channel_data(g_cliprdr_chan_id, s->data, size); free_stream(s); g_file_request_sent_type = CB_FILECONTENTS_SIZE; return rv; } /*****************************************************************************/ /* send a chunk of the file from server to client */ static int clipboard_send_file_data(int streamId, int lindex, int nPositionLow, int cbRequested) { struct stream *s; int size; int rv; int fd; char full_fn[256]; struct cb_file_info *cfi; if (g_files_list == 0) { log_error("clipboard_send_file_data: error g_files_list is nil"); return 1; } cfi = (struct cb_file_info *)list_get_item(g_files_list, lindex); if (cfi == 0) { log_error("clipboard_send_file_data: error cfi is nil"); return 1; } log_debug("clipboard_send_file_data: streamId %d lindex %d " "nPositionLow %d cbRequested %d", streamId, lindex, nPositionLow, cbRequested); g_snprintf(full_fn, 255, "%s/%s", cfi->pathname, cfi->filename); fd = g_file_open_ex(full_fn, 1, 0, 0, 0); if (fd == -1) { log_error("clipboard_send_file_data: file open [%s] failed", full_fn); return 1; } if (g_file_seek(fd, nPositionLow) < 0) { log_message(LOG_LEVEL_ERROR, "clipboard_send_file_data: seek error " "in file: %s", full_fn); g_file_close(fd); return 1; } make_stream(s); init_stream(s, cbRequested + 64); size = g_file_read(fd, s->data + 12, cbRequested); if (size < 1) { log_error("clipboard_send_file_data: read error, want %d got %d", cbRequested, size); free_stream(s); g_file_close(fd); return 1; } out_uint16_le(s, CB_FILECONTENTS_RESPONSE); /* 9 */ out_uint16_le(s, CB_RESPONSE_OK); /* 1 status */ out_uint32_le(s, size + 4); out_uint32_le(s, streamId); s->p += size; out_uint32_le(s, 0); s_mark_end(s); size = (int)(s->end - s->data); rv = send_channel_data(g_cliprdr_chan_id, s->data, size); free_stream(s); g_file_close(fd); return rv; } /*****************************************************************************/ /* ask the client to send the file size */ int clipboard_request_file_data(int stream_id, int lindex, int offset, int request_bytes) { struct stream *s; int size; int rv; log_debug("clipboard_request_file_data: stream_id=%d lindex=%d off=%d request_bytes=%d", stream_id, lindex, offset, request_bytes); if (g_file_request_sent_type != 0) { log_error("clipboard_request_file_data: warning, still waiting " "for CB_FILECONTENTS_RESPONSE"); } make_stream(s); init_stream(s, 8192); out_uint16_le(s, CB_FILECONTENTS_REQUEST); /* 8 */ out_uint16_le(s, 0); out_uint32_le(s, 28); out_uint32_le(s, stream_id); out_uint32_le(s, lindex); out_uint32_le(s, CB_FILECONTENTS_RANGE); out_uint32_le(s, offset); /* nPositionLow */ out_uint32_le(s, 0); /* nPositionHigh */ out_uint32_le(s, request_bytes); /* cbRequested */ out_uint32_le(s, 0); /* clipDataId */ out_uint32_le(s, 0); s_mark_end(s); size = (int)(s->end - s->data); rv = send_channel_data(g_cliprdr_chan_id, s->data, size); free_stream(s); g_file_request_sent_type = CB_FILECONTENTS_RANGE; return rv; } /*****************************************************************************/ /* client is asking from info about a file */ int clipboard_process_file_request(struct stream *s, int clip_msg_status, int clip_msg_len) { int streamId; int lindex; int dwFlags; int nPositionLow; int cbRequested; //int clipDataId; log_debug("clipboard_process_file_request:"); //g_hexdump(s->p, clip_msg_len); in_uint32_le(s, streamId); in_uint32_le(s, lindex); in_uint32_le(s, dwFlags); in_uint32_le(s, nPositionLow); in_uint8s(s, 4); /* nPositionHigh */ in_uint32_le(s, cbRequested); //in_uint32_le(s, clipDataId); /* options, used when locking */ if (dwFlags & CB_FILECONTENTS_SIZE) { clipboard_send_file_size(streamId, lindex); } if (dwFlags & CB_FILECONTENTS_RANGE) { clipboard_send_file_data(streamId, lindex, nPositionLow, cbRequested); } return 0; } /*****************************************************************************/ /* server requested info about the file and this is the response it's either the file size or file data */ int clipboard_process_file_response(struct stream *s, int clip_msg_status, int clip_msg_len) { int streamId; int file_size; log_debug("clipboard_process_file_response:"); if (g_file_request_sent_type == CB_FILECONTENTS_SIZE) { g_file_request_sent_type = 0; in_uint32_le(s, streamId); in_uint32_le(s, file_size); log_debug("clipboard_process_file_response: streamId %d " "file_size %d", streamId, file_size); xfuse_file_contents_size(streamId, file_size); } else if (g_file_request_sent_type == CB_FILECONTENTS_RANGE) { g_file_request_sent_type = 0; in_uint32_le(s, streamId); xfuse_file_contents_range(streamId, s->p, clip_msg_len - 4); } else { log_error("clipboard_process_file_response: error"); g_file_request_sent_type = 0; } return 0; } /*****************************************************************************/ /* read in CLIPRDR_FILEDESCRIPTOR */ static int clipboard_c2s_in_file_info(struct stream *s, struct clip_file_desc *cfd) { int num_chars; int ex_bytes; in_uint32_le(s, cfd->flags); in_uint8s(s, 32); /* reserved1 */ in_uint32_le(s, cfd->fileAttributes); in_uint8s(s, 16); /* reserved2 */ in_uint32_le(s, cfd->lastWriteTimeLow); in_uint32_le(s, cfd->lastWriteTimeHigh); in_uint32_le(s, cfd->fileSizeHigh); in_uint32_le(s, cfd->fileSizeLow); num_chars = 256; clipboard_in_unicode(s, cfd->cFileName, &num_chars); ex_bytes = 512 - num_chars * 2; ex_bytes -= 2; in_uint8s(s, ex_bytes); in_uint8s(s, 8); /* pad */ log_debug("clipboard_c2s_in_file_info:"); log_debug(" flags 0x%8.8x", cfd->flags); log_debug(" fileAttributes 0x%8.8x", cfd->fileAttributes); log_debug(" lastWriteTime 0x%8.8x%8.8x", cfd->lastWriteTimeHigh, cfd->lastWriteTimeLow); log_debug(" fileSize 0x%8.8x%8.8x", cfd->fileSizeHigh, cfd->fileSizeLow); log_debug(" num_chars %d cFileName [%s]", num_chars, cfd->cFileName); return 0; } /*****************************************************************************/ int clipboard_c2s_in_files(struct stream *s, char *file_list) { int cItems; int lindex; int str_len; int file_count; struct clip_file_desc *cfd; char *ptr; if (!s_check_rem(s, 4)) { log_error("clipboard_c2s_in_files: parse error"); return 1; } in_uint32_le(s, cItems); if (cItems > 64 * 1024) /* sanity check */ { log_error("clipboard_c2s_in_files: error cItems %d too big", cItems); return 1; } xfuse_clear_clip_dir(); log_debug("clipboard_c2s_in_files: cItems %d", cItems); cfd = (struct clip_file_desc *) g_malloc(sizeof(struct clip_file_desc), 0); file_count = 0; ptr = file_list; for (lindex = 0; lindex < cItems; lindex++) { g_memset(cfd, 0, sizeof(struct clip_file_desc)); clipboard_c2s_in_file_info(s, cfd); if ((g_pos(cfd->cFileName, "\\") >= 0) || (cfd->fileAttributes & CB_FILE_ATTRIBUTE_DIRECTORY)) { log_error("clipboard_c2s_in_files: skipping directory not " "supported [%s]", cfd->cFileName); continue; } if (xfuse_add_clip_dir_item(cfd->cFileName, 0, cfd->fileSizeLow, lindex) == -1) { log_error("clipboard_c2s_in_files: failed to add clip dir item"); continue; } if (file_count > 0) { *ptr = '\n'; ptr++; } file_count++; g_strcpy(ptr, "file://"); ptr += 7; str_len = g_strlen(g_fuse_clipboard_path); g_strcpy(ptr, g_fuse_clipboard_path); ptr += str_len; *ptr = '/'; ptr++; str_len = g_strlen(cfd->cFileName); g_strcpy(ptr, cfd->cFileName); ptr += str_len; } *ptr = 0; g_free(cfd); return 0; } xrdp-0.9.5/sesman/chansrv/clipboard.c000644 001751 001751 00000244267 13213711022 017466 0ustar00metameta000000 000000 /** * xrdp: A Remote Desktop Protocol server. * * Copyright (C) Jay Sorg 2009-2012 * Copyright (C) Laxmikant Rashinkar 2012 * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ /* for help see http://tronche.com/gui/x/icccm/sec-2.html#s-2 .../kde/kdebase/workspace/klipper/clipboardpoll.cpp Revision: Aug 05, 2012: Laxmikant Rashinkar (LK dot Rashinkar at gmail.com) added clipboard support for BMP images http://msdn.microsoft.com/en-us/library/cc241066%28v=prot.20%29.aspx */ /* TARGETS MULTIPLE image/tiff image/jpeg image/x-MS-bmp image/x-bmp image/bmp image/png SAVE_TARGETS TIMESTAMP wininfo - show window info xlsatoms - dump atoms dolphin 1.4 KDE 4.4.5 (debian 6) copy one file text/uri-list text/x-moz-url text/plain UTF8_STRING STRING TEXT COMPOUND_TEXT application/x-qiconlist TARGETS MULTIPLE TIMESTAMP SAVE_TARGETS dolphin 1.6.1 KDE 4.6.5 (kubuntu 11.04) copy one file text/uri-list text/x-moz-url text/plain UTF8_STRING STRING TEXT COMPOUND_TEXT application/x-qiconlist TARGETS MULTIPLE TIMESTAMP SAVE_TARGETS kolourpaint 4.4.5 KDE 4.4.5 copy image area application/x-kolourpaint-selection-400 application/x-qt-image image/png image/bw image/eps image/epsf image/epsi image/pcx image/rgb image/rgba image/sgi image/tga image/bmp image/ico image/jp2 image/jpeg image/jpg image/ppm PIXMAP image/tif image/tiff image/xbm image/xpm image/xv TARGETS MULTIPLE TIMESTAMP SAVE_TARGETS kate 3.4.5 KDE 4.4.5 copy text text/plain UTF8_STRING STRING TEXT COMPOUND_TEXT TARGETS MULTIPLE TIMESTAMP SAVE_TARGETS gimp 2.6.10 copy image area TIMESTAMP TARGETS MULTIPLE SAVE_TARGETS image/png image/bmp image/x-bmp image/x-MS-bmp image/tiff image/x-icon image/x-ico image/x-win-bitmap image/jpeg thunar 1.2.1 copy a file TIMESTAMP TARGETS MULTIPLE x-special/gnome-copied-files UTF8_STRING dolphin 1.6.1 KDE 4.6.5 (kubuntu 11.04) copy two files text/uri-list /home/jay/temp/jetstream1.txt /home/jay/temp/jpeg64x64.jpg 0000 66 69 6c 65 3a 2f 2f 2f 68 6f 6d 65 2f 6a 61 79 file:///home/jay 0010 2f 74 65 6d 70 2f 6a 65 74 73 74 72 65 61 6d 31 /temp/jetstream1 0020 2e 74 78 74 0d 0a 66 69 6c 65 3a 2f 2f 2f 68 6f .txt..file:///ho 0030 6d 65 2f 6a 61 79 2f 74 65 6d 70 2f 6a 70 65 67 me/jay/temp/jpeg 0040 36 34 78 36 34 2e 6a 70 67 64x64.jpg thunar 1.2.1 (kubuntu 11.04) copy two files x-special/gnome-copied-files /home/jay/temp/jetstream1.txt /home/jay/temp/jpeg64x64.jpg 0000 63 6f 70 79 0a 66 69 6c 65 3a 2f 2f 2f 68 6f 6d copy.file:///hom 0010 65 2f 6a 61 79 2f 74 65 6d 70 2f 6a 65 74 73 74 e/jay/temp/jetst 0020 72 65 61 6d 31 2e 74 78 74 0d 0a 66 69 6c 65 3a ream1.txt..file: 0030 2f 2f 2f 68 6f 6d 65 2f 6a 61 79 2f 74 65 6d 70 ///home/jay/temp 0040 2f 6a 70 65 67 36 34 78 36 34 2e 6a 70 67 0d 0a /jpeg64x64.jpg.. */ #if defined(HAVE_CONFIG_H) #include #endif #include #include #include #include "arch.h" #include "parse.h" #include "os_calls.h" #include "chansrv.h" #include "clipboard.h" #include "clipboard_file.h" #include "clipboard_common.h" #include "xcommon.h" #include "chansrv_fuse.h" /* module based logging */ #define LOG_ERROR 0 #define LOG_INFO 1 #define LOG_DEBUG 2 #undef LOG_LEVEL #define LOG_LEVEL LOG_ERROR #define log_error(_params...) \ { \ g_write("[%10.10u]: CLIPBOARD %s: %d : ERROR: ", \ g_time3(), __func__, __LINE__); \ g_writeln (_params); \ } #define log_always(_params...) \ { \ g_write("[%10.10u]: CLIPBOARD %s: %d : ALWAYS: ", \ g_time3(), __func__, __LINE__); \ g_writeln (_params); \ } #define log_info(_params...) \ { \ if (LOG_INFO <= LOG_LEVEL) \ { \ g_write("[%10.10u]: CLIPBOARD %s: %d : ", \ g_time3(), __func__, __LINE__); \ g_writeln (_params); \ } \ } #define log_debug(_params...) \ { \ if (LOG_DEBUG <= LOG_LEVEL) \ { \ g_write("[%10.10u]: CLIPBOARD %s: %d : ", \ g_time3(), __func__, __LINE__); \ g_writeln (_params); \ } \ } static char g_bmp_image_header[] = { /* this is known to work */ //0x42, 0x4d, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 /* THIS IS BEING SENT BY WIN2008 */ 0x42, 0x4d, 0x16, 0x01, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x36, 0x00, 0x00, 0x00 }; extern int g_cliprdr_chan_id; /* in chansrv.c */ extern Display *g_display; /* in xcommon.c */ extern int g_x_socket; /* in xcommon.c */ extern tbus g_x_wait_obj; /* in xcommon.c */ extern Screen *g_screen; /* in xcommon.c */ extern int g_screen_num; /* in xcommon.c */ int g_clip_up = 0; static Atom g_clipboard_atom = 0; /* CLIPBOARD */ static Atom g_clip_property_atom = 0; /* XRDP_CLIP_PROPERTY_ATOM */ static Atom g_timestamp_atom = 0; /* TIMESTAMP */ static Atom g_multiple_atom = 0; /* MULTIPLE */ static Atom g_targets_atom = 0; /* TARGETS */ static Atom g_primary_atom = 0; /* PRIMARY */ static Atom g_secondary_atom = 0; /* SECONDARY */ static Atom g_get_time_atom = 0; /* XRDP_GET_TIME_ATOM */ static Atom g_utf8_atom = 0; /* UTF8_STRING */ static Atom g_image_bmp_atom = 0; /* image/bmp */ static Atom g_file_atom1 = 0; /* text/uri-list */ static Atom g_file_atom2 = 0; /* x-special/gnome-copied-files */ static Atom g_incr_atom = 0; /* INCR */ static Window g_wnd = 0; static int g_xfixes_event_base = 0; static int g_got_selection = 0; /* boolean */ static Time g_selection_time = 0; static struct stream *g_ins = 0; /* for image data */ static XSelectionRequestEvent g_saved_selection_req_event; /* xserver maximum request size in bytes */ static int g_incr_max_req_size = 0; /* server to client, pasting from linux app to mstsc */ struct clip_s2c g_clip_s2c; /* client to server, pasting from mstsc to linux app */ struct clip_c2s g_clip_c2s; /* default version and flags */ static int g_cliprdr_version = 2; static int g_cliprdr_flags = CB_USE_LONG_FORMAT_NAMES | CB_STREAM_FILECLIP_ENABLED | CB_FILECLIP_NO_FILE_PATHS; /* from client to server */ /* last received CLIPRDR_FORMAT_LIST(CLIPRDR_FORMAT_ANNOUNCE) */ static int g_formatIds[16]; static int g_num_formatIds = 0; static int g_file_format_id = -1; static char g_last_atom_name[256] = ""; /*****************************************************************************/ static char* get_atom_text(Atom atom) { char* name; int failed; failed = 0; /* sanity check */ if ((atom < 1) || (atom > 512)) { failed = 1; } if (!failed) { name = XGetAtomName(g_display, atom); if (name == 0) { failed = 1; } } if (failed) { g_snprintf(g_last_atom_name, 255, "unknown atom 0x%8.8x", (int)atom); return g_last_atom_name; } g_strncpy(g_last_atom_name, name, 255); XFree(name); return g_last_atom_name; } /*****************************************************************************/ /* this is one way to get the current time from the x server */ static Time clipboard_get_server_time(void) { XEvent xevent; unsigned char no_text[4]; /* append nothing */ no_text[0] = 0; XChangeProperty(g_display, g_wnd, g_get_time_atom, XA_STRING, 8, PropModeAppend, no_text, 0); /* wait for PropertyNotify */ do { XMaskEvent(g_display, PropertyChangeMask, &xevent); } while (xevent.type != PropertyNotify); return xevent.xproperty.time; } /*****************************************************************************/ static int clipboard_find_format_id(int format_id) { int index; for (index = 0; index < g_num_formatIds; index++) { if (g_formatIds[index] == format_id) { return index; } } return -1; } /*****************************************************************************/ /* returns error */ int clipboard_init(void) { struct stream *s; int size; int rv; int input_mask; int dummy; int ver_maj; int ver_min; Status st; LOG(0, ("clipboard_init:")); if (g_clip_up) { return 0; } xfuse_init(); xcommon_init(); g_incr_max_req_size = XMaxRequestSize(g_display) * 4 - 24; g_memset(&g_clip_c2s, 0, sizeof(g_clip_c2s)); g_memset(&g_clip_s2c, 0, sizeof(g_clip_s2c)); rv = 0; if (rv == 0) { g_clipboard_atom = XInternAtom(g_display, "CLIPBOARD", False); if (g_clipboard_atom == None) { log_error("clipboard_init: XInternAtom failed"); rv = 3; } } if (rv == 0) { if (!XFixesQueryExtension(g_display, &g_xfixes_event_base, &dummy)) { log_error("clipboard_init: no xfixes"); rv = 5; } } if (rv == 0) { log_debug("clipboard_init: g_xfixes_event_base %d", g_xfixes_event_base); st = XFixesQueryVersion(g_display, &ver_maj, &ver_min); log_debug("clipboard_init st %d, maj %d min %d", st, ver_maj, ver_min); g_clip_property_atom = XInternAtom(g_display, "XRDP_CLIP_PROPERTY_ATOM", False); g_get_time_atom = XInternAtom(g_display, "XRDP_GET_TIME_ATOM", False); g_timestamp_atom = XInternAtom(g_display, "TIMESTAMP", False); g_targets_atom = XInternAtom(g_display, "TARGETS", False); g_multiple_atom = XInternAtom(g_display, "MULTIPLE", False); g_primary_atom = XInternAtom(g_display, "PRIMARY", False); g_secondary_atom = XInternAtom(g_display, "SECONDARY", False); g_utf8_atom = XInternAtom(g_display, "UTF8_STRING", False); g_image_bmp_atom = XInternAtom(g_display, "image/bmp", False); g_file_atom1 = XInternAtom(g_display, "text/uri-list", False); g_file_atom2 = XInternAtom(g_display, "x-special/gnome-copied-files", False); g_incr_atom = XInternAtom(g_display, "INCR", False); if (g_image_bmp_atom == None) { log_error("clipboard_init: g_image_bmp_atom was " "not allocated"); } g_wnd = XCreateSimpleWindow(g_display, RootWindowOfScreen(g_screen), 0, 0, 4, 4, 0, 0, 0); input_mask = StructureNotifyMask | PropertyChangeMask; XSelectInput(g_display, g_wnd, input_mask); //XMapWindow(g_display, g_wnd); XFixesSelectSelectionInput(g_display, g_wnd, g_clipboard_atom, XFixesSetSelectionOwnerNotifyMask | XFixesSelectionWindowDestroyNotifyMask | XFixesSelectionClientCloseNotifyMask); } make_stream(s); if (rv == 0) { /* set clipboard caps first */ init_stream(s, 8192); /* CLIPRDR_HEADER */ out_uint16_le(s, CB_CLIP_CAPS); /* msgType */ out_uint16_le(s, 0); /* msgFlags */ out_uint32_le(s, 16); /* dataLen */ out_uint16_le(s, 1); /* cCapabilitiesSets */ out_uint16_le(s, 0); /* pad1 */ /* CLIPRDR_GENERAL_CAPABILITY */ out_uint16_le(s, 1); /* capabilitySetType */ out_uint16_le(s, 12); /* lengthCapability */ out_uint32_le(s, g_cliprdr_version); /* version */ out_uint32_le(s, g_cliprdr_flags); /* generalFlags */ out_uint32_le(s, 0); /* extra 4 bytes ? */ s_mark_end(s); size = (int)(s->end - s->data); log_debug("clipboard_init: data out, sending " "CB_CLIP_CAPS (clip_msg_id = 1)"); rv = send_channel_data(g_cliprdr_chan_id, s->data, size); if (rv != 0) { log_error("clipboard_init: send_channel_data failed " "rv = %d", rv); rv = 4; } } if (rv == 0) { /* report clipboard ready */ init_stream(s, 8192); out_uint16_le(s, CB_MONITOR_READY); /* msgType */ out_uint16_le(s, 0); /* msgFlags */ out_uint32_le(s, 0); /* dataLen */ out_uint32_le(s, 0); /* extra 4 bytes ? */ s_mark_end(s); size = (int)(s->end - s->data); log_debug("clipboard_init: data out, sending " "CB_MONITOR_READY (clip_msg_id = 1)"); rv = send_channel_data(g_cliprdr_chan_id, s->data, size); if (rv != 0) { log_error("clipboard_init: send_channel_data failed " "rv = %d", rv); rv = 4; } } free_stream(s); if (rv == 0) { g_clip_up = 1; make_stream(g_ins); init_stream(g_ins, 8192); } else { log_error("xrdp-chansrv: clipboard_init: error on exit"); } return rv; } /*****************************************************************************/ int clipboard_deinit(void) { LOG(0, ("clipboard_deinit:")); if (g_wnd != 0) { XDestroyWindow(g_display, g_wnd); g_wnd = 0; } xfuse_deinit(); g_free(g_clip_c2s.data); g_clip_c2s.data = 0; g_free(g_clip_s2c.data); g_clip_s2c.data = 0; free_stream(g_ins); g_ins = 0; g_clip_up = 0; return 0; } /*****************************************************************************/ static int clipboard_send_data_request(int format_id) { struct stream *s; int size; int rv; log_debug("clipboard_send_data_request:"); log_debug("clipboard_send_data_request: %d", format_id); g_clip_c2s.in_request = 1; make_stream(s); init_stream(s, 8192); out_uint16_le(s, CB_FORMAT_DATA_REQUEST); /* 4 CLIPRDR_DATA_REQUEST */ out_uint16_le(s, 0); /* status */ out_uint32_le(s, 4); /* length */ out_uint32_le(s, format_id); out_uint32_le(s, 0); s_mark_end(s); size = (int)(s->end - s->data); log_debug("clipboard_send_data_request: data out, sending " "CLIPRDR_DATA_REQUEST (clip_msg_id = 4)"); rv = send_channel_data(g_cliprdr_chan_id, s->data, size); free_stream(s); return rv; } /*****************************************************************************/ static int clipboard_send_format_ack(void) { struct stream *s; int size; int rv; make_stream(s); init_stream(s, 8192); out_uint16_le(s, CB_FORMAT_LIST_RESPONSE); /* 3 CLIPRDR_FORMAT_ACK */ out_uint16_le(s, CB_RESPONSE_OK); /* 1 status */ out_uint32_le(s, 0); /* length */ out_uint32_le(s, 0); /* extra 4 bytes */ s_mark_end(s); size = (int)(s->end - s->data); log_debug("clipboard_send_format_ack: data out, sending " "CLIPRDR_FORMAT_ACK (clip_msg_id = 3)"); rv = send_channel_data(g_cliprdr_chan_id, s->data, size); free_stream(s); return rv; } /*****************************************************************************/ /* returns number of bytes written */ int clipboard_out_unicode(struct stream *s, const char *text, int num_chars) { int index; int lnum_chars; twchar *ltext; if ((num_chars < 1) || (text == 0)) { return 0; } lnum_chars = g_mbstowcs(0, text, num_chars); if (lnum_chars < 0) { return 0; } ltext = (twchar *) g_malloc((num_chars + 1) * sizeof(twchar), 1); g_mbstowcs(ltext, text, num_chars); index = 0; while (index < num_chars) { out_uint16_le(s, ltext[index]); index++; } g_free(ltext); return index * 2; } /*****************************************************************************/ /* returns number of bytes read */ int clipboard_in_unicode(struct stream *s, char *text, int *num_chars) { int index; twchar *ltext; twchar chr; if ((num_chars == 0) || (*num_chars < 1) || (text == 0)) { return 0; } ltext = (twchar *) g_malloc(512 * sizeof(twchar), 1); index = 0; while (s_check_rem(s, 2)) { in_uint16_le(s, chr); if (index < 511) { ltext[index] = chr; } index++; if (chr == 0) { break; } } *num_chars = g_wcstombs(text, ltext, *num_chars); g_free(ltext); return index * 2; } static char windows_native_format[] = { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }; /*****************************************************************************/ static int clipboard_send_format_announce(int xrdp_clip_type) { struct stream *s; int size; int rv; char *holdp; log_debug("clipboard_send_format_announce:"); make_stream(s); init_stream(s, 8192); out_uint16_le(s, CB_FORMAT_LIST); /* 2 CLIPRDR_FORMAT_ANNOUNCE */ out_uint16_le(s, 0); /* status */ holdp = s->p; out_uint32_le(s, 0); /* set later */ if (g_cliprdr_flags & CB_USE_LONG_FORMAT_NAMES) { switch (xrdp_clip_type) { case XRDP_CB_FILE: log_debug("clipboard_send_format_announce: XRDP_CB_FILE"); /* canned response for "file" */ out_uint32_le(s, 0x0000c0bc); clipboard_out_unicode(s, "FileGroupDescriptorW", 21); out_uint32_le(s, 0x0000c0ba); clipboard_out_unicode(s, "FileContents", 13); out_uint32_le(s, 0x0000c0c1); clipboard_out_unicode(s, "DropEffect", 11); break; case XRDP_CB_BITMAP: log_debug("clipboard_send_format_announce: XRDP_CB_BITMAP"); /* canned response for "bitmap" */ out_uint32_le(s, 0x0000c004); clipboard_out_unicode(s, "Native", 7); out_uint32_le(s, 0x00000003); clipboard_out_unicode(s, "", 1); out_uint32_le(s, 0x00000008); clipboard_out_unicode(s, "", 1); out_uint32_le(s, 0x00000011); clipboard_out_unicode(s, "", 1); break; case XRDP_CB_TEXT: log_debug("clipboard_send_format_announce: XRDP_CB_TEXT"); /* canned response for "bitmap" */ out_uint32_le(s, 0x0000000d); clipboard_out_unicode(s, "", 1); out_uint32_le(s, 0x00000010); clipboard_out_unicode(s, "", 1); out_uint32_le(s, 0x00000001); clipboard_out_unicode(s, "", 1); out_uint32_le(s, 0x00000007); clipboard_out_unicode(s, "", 1); break; default: log_debug("clipboard_send_format_announce: unknown " "xrdp_clip_type %d", xrdp_clip_type); break; } } else /* old method */ { switch (xrdp_clip_type) { case XRDP_CB_FILE: log_debug("clipboard_send_format_announce: XRDP_CB_FILE"); /* canned response for "file" */ out_uint32_le(s, 0x0000c0bc); out_uint8p(s, windows_native_format, sizeof(windows_native_format)); out_uint32_le(s, 0x0000c0ba); out_uint8p(s, windows_native_format, sizeof(windows_native_format)); out_uint32_le(s, 0x0000c0c1); out_uint8p(s, windows_native_format, sizeof(windows_native_format)); break; case XRDP_CB_BITMAP: log_debug("clipboard_send_format_announce: XRDP_CB_BITMAP"); /* canned response for "bitmap" */ out_uint32_le(s, 0x0000c004); out_uint8p(s, windows_native_format, sizeof(windows_native_format)); out_uint32_le(s, 0x00000003); out_uint8p(s, windows_native_format, sizeof(windows_native_format)); out_uint32_le(s, 0x00000008); out_uint8p(s, windows_native_format, sizeof(windows_native_format)); out_uint32_le(s, 0x00000011); out_uint8p(s, windows_native_format, sizeof(windows_native_format)); break; case XRDP_CB_TEXT: log_debug("clipboard_send_format_announce: XRDP_CB_TEXT"); /* canned response for "bitmap" */ out_uint32_le(s, 0x0000000d); out_uint8p(s, windows_native_format, sizeof(windows_native_format)); out_uint32_le(s, 0x00000010); out_uint8p(s, windows_native_format, sizeof(windows_native_format)); out_uint32_le(s, 0x00000001); out_uint8p(s, windows_native_format, sizeof(windows_native_format)); out_uint32_le(s, 0x00000007); out_uint8p(s, windows_native_format, sizeof(windows_native_format)); break; default: log_debug("clipboard_send_format_announce: unknown " "xrdp_clip_type %d", xrdp_clip_type); break; } } size = (int)(s->p - holdp); size -= 4; holdp[0] = (size >> 0) & 0xff; holdp[1] = (size >> 8) & 0xff; holdp[2] = (size >> 16) & 0xff; holdp[3] = (size >> 24) & 0xff; out_uint32_le(s, 0); s_mark_end(s); size = (int)(s->end - s->data); //g_hexdump(s->data, size); log_debug("clipboard_send_format_announce: data out, sending " "CLIPRDR_FORMAT_ANNOUNCE (clip_msg_id = 2)"); rv = send_channel_data(g_cliprdr_chan_id, s->data, size); free_stream(s); return rv; } /*****************************************************************************/ static int clipboard_send_data_response_for_image(const char *data, int data_size) { struct stream *s; int size; int rv; log_debug("clipboard_send_data_response_for_image: data_size %d", data_size); make_stream(s); init_stream(s, 64 + data_size); out_uint16_le(s, CB_FORMAT_DATA_RESPONSE); /* 5 CLIPRDR_DATA_RESPONSE */ out_uint16_le(s, CB_RESPONSE_OK); /* 1 status */ out_uint32_le(s, data_size); /* length */ out_uint8p(s, data, data_size); out_uint32_le(s, 0); s_mark_end(s); size = (int)(s->end - s->data); rv = send_channel_data(g_cliprdr_chan_id, s->data, size); free_stream(s); return rv; } /*****************************************************************************/ static int clipboard_send_data_response_for_text(const char *data, int data_size) { struct stream *s; int size; int rv; int num_chars; log_debug("clipboard_send_data_response_for_text: data_size %d", data_size); //g_hexdump(data, data_size); num_chars = g_mbstowcs(0, data, 0); if (num_chars < 0) { log_error("clipboard_send_data_response_for_text: " "bad string"); num_chars = 0; } log_debug("clipboard_send_data_response_for_text: data_size %d " "num_chars %d", data_size, num_chars); make_stream(s); init_stream(s, 64 + num_chars * 2); out_uint16_le(s, CB_FORMAT_DATA_RESPONSE); /* 5 CLIPRDR_DATA_RESPONSE */ out_uint16_le(s, CB_RESPONSE_OK); /* 1 status */ out_uint32_le(s, num_chars * 2 + 2); /* length */ if (clipboard_out_unicode(s, data, num_chars) != num_chars * 2) { log_error("clipboard_send_data_response_for_text: error " "clipboard_out_unicode didn't write right number of bytes"); } out_uint16_le(s, 0); /* nil for string */ out_uint32_le(s, 0); s_mark_end(s); size = (int)(s->end - s->data); log_debug("clipboard_send_data_response_for_text: data out, " "sending CLIPRDR_DATA_RESPONSE (clip_msg_id = 5) size %d " "num_chars %d", size, num_chars); rv = send_channel_data(g_cliprdr_chan_id, s->data, size); free_stream(s); return rv; } /*****************************************************************************/ static int clipboard_send_data_response(int xrdp_clip_type, const char *data, int data_size) { log_debug("clipboard_send_data_response:"); if (data != 0) { if (xrdp_clip_type == XRDP_CB_FILE) { return clipboard_send_data_response_for_file(data, data_size); } else if (xrdp_clip_type == XRDP_CB_BITMAP) { return clipboard_send_data_response_for_image(data, data_size); } else if (xrdp_clip_type == XRDP_CB_TEXT) { return clipboard_send_data_response_for_text(data, data_size); } else { log_debug("clipboard_send_data_response: unknown " "xrdp_clip_type %d", xrdp_clip_type); } } else { log_error("clipboard_send_data_response: data is nil"); } return 0; } /*****************************************************************************/ static int clipboard_set_selection_owner(void) { Window owner; log_debug("clipboard_set_selection_owner:"); g_selection_time = clipboard_get_server_time(); XSetSelectionOwner(g_display, g_clipboard_atom, g_wnd, g_selection_time); owner = XGetSelectionOwner(g_display, g_clipboard_atom); if (owner != g_wnd) { g_got_selection = 0; return 1; } g_got_selection = 1; return 0; } /*****************************************************************************/ static int clipboard_provide_selection_c2s(XSelectionRequestEvent *req, Atom type) { XEvent xev; long val1[2]; log_debug("clipboard_provide_selection_c2s: bytes %d", g_clip_c2s.total_bytes); if (g_clip_c2s.total_bytes < g_incr_max_req_size) { XChangeProperty(g_display, req->requestor, req->property, type, 8, PropModeReplace, (tui8 *)g_clip_c2s.data, g_clip_c2s.total_bytes); g_memset(&xev, 0, sizeof(xev)); xev.xselection.type = SelectionNotify; xev.xselection.send_event = True; xev.xselection.display = req->display; xev.xselection.requestor = req->requestor; xev.xselection.selection = req->selection; xev.xselection.target = req->target; xev.xselection.property = req->property; xev.xselection.time = req->time; XSendEvent(g_display, req->requestor, False, NoEventMask, &xev); } else { /* start the INCR process */ g_clip_c2s.incr_in_progress = 1; g_clip_c2s.incr_bytes_done = 0; g_clip_c2s.type = type; g_clip_c2s.property = req->property; g_clip_c2s.window = req->requestor; log_debug("clipboard_provide_selection_c2s: start INCR property %s " "type %s", get_atom_text(req->property), get_atom_text(type)); val1[0] = g_clip_c2s.total_bytes; val1[1] = 0; XChangeProperty(g_display, req->requestor, req->property, g_incr_atom, 32, PropModeReplace, (tui8 *)val1, 1); /* we need events from that other window */ XSelectInput(g_display, req->requestor, PropertyChangeMask); g_memset(&xev, 0, sizeof(xev)); xev.xselection.type = SelectionNotify; xev.xselection.send_event = True; xev.xselection.display = req->display; xev.xselection.requestor = req->requestor; xev.xselection.selection = req->selection; xev.xselection.target = req->target; xev.xselection.property = req->property; xev.xselection.time = req->time; XSendEvent(g_display, req->requestor, False, NoEventMask, &xev); } return 0; } /*****************************************************************************/ static int clipboard_provide_selection(XSelectionRequestEvent *req, Atom type, int format, char *data, int length) { XEvent xev; int bytes; bytes = FORMAT_TO_BYTES(format); bytes *= length; log_debug("clipboard_provide_selection: bytes %d", bytes); if (bytes < g_incr_max_req_size) { XChangeProperty(g_display, req->requestor, req->property, type, format, PropModeReplace, (tui8 *)data, length); g_memset(&xev, 0, sizeof(xev)); xev.xselection.type = SelectionNotify; xev.xselection.send_event = True; xev.xselection.display = req->display; xev.xselection.requestor = req->requestor; xev.xselection.selection = req->selection; xev.xselection.target = req->target; xev.xselection.property = req->property; xev.xselection.time = req->time; XSendEvent(g_display, req->requestor, False, NoEventMask, &xev); return 0; } return 1; } /*****************************************************************************/ static int clipboard_refuse_selection(XSelectionRequestEvent *req) { XEvent xev; g_memset(&xev, 0, sizeof(xev)); xev.xselection.type = SelectionNotify; xev.xselection.send_event = True; xev.xselection.display = req->display; xev.xselection.requestor = req->requestor; xev.xselection.selection = req->selection; xev.xselection.target = req->target; xev.xselection.property = None; xev.xselection.time = req->time; XSendEvent(g_display, req->requestor, False, NoEventMask, &xev); return 0; } /*****************************************************************************/ /* sent by client or server when its local system clipboard is updated with new clipboard data; contains Clipboard Format ID and name pairs of new Clipboard Formats on the clipboard. */ static int clipboard_process_format_announce(struct stream *s, int clip_msg_status, int clip_msg_len) { int formatId; int count; int bytes; char desc[256]; char *holdp; log_debug("clipboard_process_format_announce: " "CLIPRDR_FORMAT_ANNOUNCE"); log_debug("clipboard_process_format_announce %d", clip_msg_len); clipboard_send_format_ack(); xfuse_clear_clip_dir(); g_clip_c2s.converted = 0; desc[0] = 0; g_num_formatIds = 0; while (clip_msg_len > 3) { in_uint32_le(s, formatId); clip_msg_len -= 4; if (g_cliprdr_flags & CB_USE_LONG_FORMAT_NAMES) { /* CLIPRDR_LONG_FORMAT_NAME */ count = 255; bytes = clipboard_in_unicode(s, desc, &count); clip_msg_len -= bytes; } else { /* CLIPRDR_SHORT_FORMAT_NAME */ /* 32 ASCII 8 characters or 16 Unicode characters */ count = 15; holdp = s->p; clipboard_in_unicode(s, desc, &count); s->p = holdp + 32; desc[15] = 0; clip_msg_len -= 32; } log_debug("clipboard_process_format_announce: formatId 0x%8.8x " "wszFormatName [%s] clip_msg_len %d", formatId, desc, clip_msg_len); if (g_num_formatIds <= 15) { g_formatIds[g_num_formatIds] = formatId; g_num_formatIds++; } if (g_num_formatIds > 15) { log_debug("clipboard_process_format_announce: max formats"); } /* format id for file copy copy seems to keep changing */ /* seen 0x0000c0c8, 0x0000c0ed */ if (g_strcmp(desc, "FileGroupDescriptorW") == 0) { g_file_format_id = formatId; } } if ((g_num_formatIds > 0) && (g_clip_c2s.incr_in_progress == 0) && /* don't interrupt incr */ (g_clip_s2c.incr_in_progress == 0)) { if (clipboard_set_selection_owner() != 0) { log_error("clipboard_process_format_announce: " "XSetSelectionOwner failed"); } } return 0; } /*****************************************************************************/ /* response to CB_FORMAT_LIST; used to indicate whether processing of the Format List PDU was successful */ static int clipboard_process_format_ack(struct stream *s, int clip_msg_status, int clip_msg_len) { log_debug("clipboard_process_format_ack: CLIPRDR_FORMAT_ACK"); log_debug("clipboard_process_format_ack:"); return 0; } /*****************************************************************************/ static int clipboard_send_data_response_failed(void) { struct stream *s; int size; int rv; log_error("clipboard_send_data_response_failed:"); make_stream(s); init_stream(s, 64); out_uint16_le(s, CB_FORMAT_DATA_RESPONSE); /* 5 CLIPRDR_DATA_RESPONSE */ out_uint16_le(s, CB_RESPONSE_FAIL); /* 2 status */ out_uint32_le(s, 0); s_mark_end(s); size = (int)(s->end - s->data); rv = send_channel_data(g_cliprdr_chan_id, s->data, size); free_stream(s); return rv; } /*****************************************************************************/ /* sent from server to client * sent by recipient of CB_FORMAT_LIST; used to request data for one * of the formats that was listed in CB_FORMAT_LIST */ static int clipboard_process_data_request(struct stream *s, int clip_msg_status, int clip_msg_len) { int requestedFormatId; log_debug("clipboard_process_data_request: " "CLIPRDR_DATA_REQUEST"); log_debug("clipboard_process_data_request:"); log_debug(" %d", g_clip_s2c.xrdp_clip_type); in_uint32_le(s, requestedFormatId); switch (requestedFormatId) { case CB_FORMAT_FILE: /* 0xC0BC */ if ((g_clip_s2c.xrdp_clip_type == XRDP_CB_FILE) && g_clip_s2c.converted) { log_debug("clipboard_process_data_request: CB_FORMAT_FILE"); clipboard_send_data_response(XRDP_CB_FILE, g_clip_s2c.data, g_clip_s2c.total_bytes); } else { log_debug("clipboard_process_data_request: CB_FORMAT_FILE, " "calling XConvertSelection to g_utf8_atom"); g_clip_s2c.xrdp_clip_type = XRDP_CB_FILE; XConvertSelection(g_display, g_clipboard_atom, g_clip_s2c.type, g_clip_property_atom, g_wnd, CurrentTime); } break; case CB_FORMAT_DIB: /* 0x0008 */ if ((g_clip_s2c.xrdp_clip_type == XRDP_CB_BITMAP) && g_clip_s2c.converted) { log_debug("clipboard_process_data_request: CB_FORMAT_DIB"); clipboard_send_data_response(XRDP_CB_BITMAP, g_clip_s2c.data, g_clip_s2c.total_bytes); } else { log_debug("clipboard_process_data_request: CB_FORMAT_DIB, " "calling XConvertSelection to g_image_bmp_atom"); g_clip_s2c.xrdp_clip_type = XRDP_CB_BITMAP; XConvertSelection(g_display, g_clipboard_atom, g_image_bmp_atom, g_clip_property_atom, g_wnd, CurrentTime); } break; case CB_FORMAT_UNICODETEXT: /* 0x000D */ if ((g_clip_s2c.xrdp_clip_type == XRDP_CB_TEXT) && g_clip_s2c.converted) { log_debug("clipboard_process_data_request: CB_FORMAT_UNICODETEXT"); clipboard_send_data_response(XRDP_CB_TEXT, g_clip_s2c.data, g_clip_s2c.total_bytes); } else { log_debug("clipboard_process_data_request: CB_FORMAT_UNICODETEXT, " "calling XConvertSelection to g_utf8_atom"); g_clip_s2c.xrdp_clip_type = XRDP_CB_TEXT; XConvertSelection(g_display, g_clipboard_atom, g_utf8_atom, g_clip_property_atom, g_wnd, CurrentTime); } break; default: log_debug("clipboard_process_data_request: unknown type %d", requestedFormatId); clipboard_send_data_response_failed(); break; } return 0; } /*****************************************************************************/ /* client to server */ /* sent as a reply to CB_FORMAT_DATA_REQUEST; used to indicate whether processing of the CB_FORMAT_DATA_REQUEST was successful; if processing was successful, CB_FORMAT_DATA_RESPONSE includes contents of requested clipboard data. */ static int clipboard_process_data_response_for_image(struct stream *s, int clip_msg_status, int clip_msg_len) { XSelectionRequestEvent *lxev; int len; log_debug("clipboard_process_data_response_for_image: " "CLIPRDR_DATA_RESPONSE_FOR_IMAGE"); lxev = &g_saved_selection_req_event; len = (int)(s->end - s->p); if (len < 1) { return 0; } if (g_clip_c2s.type != g_image_bmp_atom) { return 0; } g_free(g_clip_c2s.data); g_clip_c2s.data = (char *) g_malloc(len + 14, 0); if (g_clip_c2s.data == 0) { g_clip_c2s.total_bytes = 0; return 0; } g_clip_c2s.total_bytes = len; g_clip_c2s.read_bytes_done = g_clip_c2s.total_bytes; g_memcpy(g_clip_c2s.data, g_bmp_image_header, 14); in_uint8a(s, g_clip_c2s.data + 14, len); log_debug("clipboard_process_data_response_for_image: calling " "clipboard_provide_selection_c2s"); clipboard_provide_selection_c2s(lxev, lxev->target); return 0; } /*****************************************************************************/ /* client to server */ /* sent as a reply to CB_FORMAT_DATA_REQUEST; used to indicate whether processing of the CB_FORMAT_DATA_REQUEST was successful; if processing was successful, CB_FORMAT_DATA_RESPONSE includes contents of requested clipboard data. */ /*****************************************************************************/ static int clipboard_process_data_response(struct stream *s, int clip_msg_status, int clip_msg_len) { XSelectionRequestEvent *lxev; twchar *wtext; twchar wchr; int len; int index; log_debug("clipboard_process_data_response:"); lxev = &g_saved_selection_req_event; g_clip_c2s.in_request = 0; if (g_clip_c2s.xrdp_clip_type == XRDP_CB_BITMAP) { clipboard_process_data_response_for_image(s, clip_msg_status, clip_msg_len); return 0; } if (g_clip_c2s.xrdp_clip_type == XRDP_CB_FILE) { g_free(g_clip_c2s.data); g_clip_c2s.data = (char *)g_malloc(1024 * 1024, 1); /* text/uri-list */ if (g_clip_c2s.type == g_file_atom1) { clipboard_c2s_in_files(s, g_clip_c2s.data); } /* x-special/gnome-copied-files */ else if (g_clip_c2s.type == g_file_atom2) { g_strcpy(g_clip_c2s.data, "copy\n"); clipboard_c2s_in_files(s, g_clip_c2s.data + 5); } else { log_error("clipboard_process_data_response: error"); } g_clip_c2s.total_bytes = g_strlen(g_clip_c2s.data); g_clip_c2s.read_bytes_done = g_clip_c2s.total_bytes; clipboard_provide_selection_c2s(lxev, lxev->target); return 0; } log_debug("clipboard_process_data_response: " "CLIPRDR_DATA_RESPONSE"); len = (int)(s->end - s->p); if (len < 1) { return 0; } wtext = (twchar *) g_malloc(((len / 2) + 1) * sizeof(twchar), 0); if (wtext == 0) { return 0; } index = 0; while (s_check(s)) { in_uint16_le(s, wchr); wtext[index] = wchr; if (wchr == 0) { break; } index++; } wtext[index] = 0; g_free(g_clip_c2s.data); g_clip_c2s.data = 0; g_clip_c2s.total_bytes = 0; len = g_wcstombs(0, wtext, 0); if (len >= 0) { g_clip_c2s.data = (char *) g_malloc(len + 16, 0); if (g_clip_c2s.data == 0) { g_free(wtext); return 0; } g_wcstombs(g_clip_c2s.data, wtext, len + 1); } if (g_clip_c2s.data != 0) { g_clip_c2s.total_bytes = g_strlen(g_clip_c2s.data); g_clip_c2s.read_bytes_done = g_clip_c2s.total_bytes; clipboard_provide_selection_c2s(lxev, lxev->target); } g_free(wtext); return 0; } /*****************************************************************************/ static int clipboard_process_clip_caps(struct stream *s, int clip_msg_status, int clip_msg_len) { int cCapabilitiesSets; int capabilitySetType; int lengthCapability; int index; int version; int flags; char *holdp; log_debug("clipboard_process_clip_caps:"); //g_hexdump(s->p, s->end - s->p); in_uint16_le(s, cCapabilitiesSets); in_uint8s(s, 2); /* pad */ for (index = 0; index < cCapabilitiesSets; index++) { holdp = s->p; in_uint16_le(s, capabilitySetType); in_uint16_le(s, lengthCapability); switch (capabilitySetType) { case CB_CAPSTYPE_GENERAL: in_uint32_le(s, version); /* version */ in_uint32_le(s, flags); /* generalFlags */ log_debug("clipboard_process_clip_caps: " "g_cliprdr_version %d version %d " "g_cliprdr_flags 0x%x flags 0x%x", g_cliprdr_version, version, g_cliprdr_flags, flags); if (version < g_cliprdr_version) { g_cliprdr_version = version; } g_cliprdr_flags &= flags; break; default: log_debug("clipboard_process_clip_caps: unknown " "capabilitySetType %d", capabilitySetType); break; } s->p = holdp + lengthCapability; } return 0; } /*****************************************************************************/ static int ss_part(char *data, int data_bytes) { int index; char *text; log_debug("ss_part: data_bytes %d read_bytes_done %d " "incr_bytes_done %d", data_bytes, g_clip_c2s.read_bytes_done, g_clip_c2s.incr_bytes_done); /* copy to buffer */ if (g_clip_c2s.type == g_utf8_atom) { /* todo unicode */ text = (char *)g_malloc(data_bytes, 0); index = 0; data_bytes /= 2; while (index < data_bytes) { text[index] = data[index * 2]; index++; } text[index] = 0; g_memcpy(g_clip_c2s.data + g_clip_c2s.read_bytes_done, text, data_bytes); g_clip_c2s.read_bytes_done += data_bytes; g_free(text); } else { g_memcpy(g_clip_c2s.data + g_clip_c2s.read_bytes_done, data, data_bytes); g_clip_c2s.read_bytes_done += data_bytes; } if (g_clip_c2s.incr_in_progress) { log_debug("ss_part: incr_in_progress set"); return 0; } if (g_clip_c2s.read_bytes_done <= g_clip_c2s.incr_bytes_done) { log_debug("ss_part: read_bytes_done < incr_bytes_done"); return 0; } data = g_clip_c2s.data + g_clip_c2s.incr_bytes_done; data_bytes = g_clip_c2s.read_bytes_done - g_clip_c2s.incr_bytes_done; if (data_bytes > g_incr_max_req_size) { data_bytes = g_incr_max_req_size; } g_clip_c2s.incr_bytes_done += data_bytes; XChangeProperty(g_display, g_clip_c2s.window, g_clip_c2s.property, g_clip_c2s.type, 8, PropModeReplace, (tui8 *)data, data_bytes); g_clip_c2s.incr_in_progress = 1; return 0; } /*****************************************************************************/ static int ss_end(void) { char *data; int data_bytes; log_debug("ss_end:"); g_clip_c2s.doing_response_ss = 0; g_clip_c2s.in_request = 0; if (g_clip_c2s.incr_in_progress) { log_debug("ss_end: incr_in_progress set"); return 0; } if (g_clip_c2s.read_bytes_done <= g_clip_c2s.incr_bytes_done) { log_debug("ss_end: read_bytes_done < incr_bytes_done"); return 0; } data = g_clip_c2s.data + g_clip_c2s.incr_bytes_done; data_bytes = g_clip_c2s.read_bytes_done - g_clip_c2s.incr_bytes_done; if (data_bytes > g_incr_max_req_size) { data_bytes = g_incr_max_req_size; } g_clip_c2s.incr_bytes_done += data_bytes; XChangeProperty(g_display, g_clip_c2s.window, g_clip_c2s.property, g_clip_c2s.type, 8, PropModeReplace, (tui8 *)data, data_bytes); g_clip_c2s.incr_in_progress = 1; return 0; } /*****************************************************************************/ static int ss_start(char *data, int data_bytes, int total_bytes) { XEvent xev; XSelectionRequestEvent *req; long val1[2]; int incr_bytes; log_debug("ss_start: data_bytes %d total_bytes %d", data_bytes, total_bytes); req = &g_saved_selection_req_event; incr_bytes = total_bytes; if (req->target == g_image_bmp_atom) { incr_bytes += 14; } else if (req->target == g_utf8_atom) { incr_bytes /= 2; } val1[0] = incr_bytes; /* a guess */ val1[1] = 0; g_clip_c2s.doing_response_ss = 1; g_clip_c2s.incr_bytes_done = 0; g_clip_c2s.read_bytes_done = 0; g_clip_c2s.type = req->target; g_clip_c2s.property = req->property; g_clip_c2s.window = req->requestor; g_free(g_clip_c2s.data); g_clip_c2s.data = (char *)g_malloc(incr_bytes + 64, 0); g_clip_c2s.total_bytes = incr_bytes; XChangeProperty(g_display, req->requestor, req->property, g_incr_atom, 32, PropModeReplace, (tui8 *)val1, 1); /* we need events from that other window */ XSelectInput(g_display, req->requestor, PropertyChangeMask); g_memset(&xev, 0, sizeof(xev)); xev.xselection.type = SelectionNotify; xev.xselection.send_event = True; xev.xselection.display = req->display; xev.xselection.requestor = req->requestor; xev.xselection.selection = req->selection; xev.xselection.target = req->target; xev.xselection.property = req->property; xev.xselection.time = req->time; XSendEvent(g_display, req->requestor, False, NoEventMask, &xev); if (req->target == g_image_bmp_atom) { g_memcpy(g_clip_c2s.data, g_bmp_image_header, 14); g_clip_c2s.read_bytes_done = 14; } g_clip_c2s.incr_in_progress = 1; ss_part(data, data_bytes); return 0; } /*****************************************************************************/ int clipboard_data_in(struct stream *s, int chan_id, int chan_flags, int length, int total_length) { int clip_msg_id; int clip_msg_len; int clip_msg_status; int rv; struct stream *ls; char *holdp; if (!g_clip_up) { log_error("aborting clipboard_data_in - clipboard has not " "been initialized"); /* we return 0 here to indicate no protocol problem occurred */ return 0; } log_debug("clipboard_data_in: chan_id %d " "chan_flags 0x%x length %d total_length %d " "in_request %d g_ins->size %d", chan_id, chan_flags, length, total_length, g_clip_c2s.in_request, g_ins->size); if (g_clip_c2s.doing_response_ss) { ss_part(s->p, length); if ((chan_flags & 3) == 2) { log_debug("clipboard_data_in: calling ss_end"); ss_end(); } return 0; } if (g_clip_c2s.in_request) { if (total_length > 32 * 1024) { if ((chan_flags & 3) == 1) { holdp = s->p; in_uint16_le(s, clip_msg_id); in_uint16_le(s, clip_msg_status); in_uint32_le(s, clip_msg_len); if (clip_msg_id == CB_FORMAT_DATA_RESPONSE) { ss_start(s->p, length - 8, total_length - 8); return 0; } s->p = holdp; } } } if ((chan_flags & 3) == 3) { ls = s; } else { if (chan_flags & 1) { init_stream(g_ins, total_length); } in_uint8a(s, g_ins->end, length); g_ins->end += length; if ((chan_flags & 2) == 0) { return 0; } ls = g_ins; } in_uint16_le(ls, clip_msg_id); in_uint16_le(ls, clip_msg_status); in_uint32_le(ls, clip_msg_len); log_debug("clipboard_data_in: clip_msg_id %d " "clip_msg_status %d clip_msg_len %d", clip_msg_id, clip_msg_status, clip_msg_len); rv = 0; log_debug("clipboard_data_in: %d", clip_msg_id); switch (clip_msg_id) { /* sent by client or server when its local system clipboard is */ /* updated with new clipboard data; contains Clipboard Format ID */ /* and name pairs of new Clipboard Formats on the clipboard. */ case CB_FORMAT_LIST: /* 2 CLIPRDR_FORMAT_ANNOUNCE */ rv = clipboard_process_format_announce(ls, clip_msg_status, clip_msg_len); break; /* response to CB_FORMAT_LIST; used to indicate whether */ /* processing of the Format List PDU was successful */ case CB_FORMAT_LIST_RESPONSE: /* 3 CLIPRDR_FORMAT_ACK */ rv = clipboard_process_format_ack(ls, clip_msg_status, clip_msg_len); break; /* sent by recipient of CB_FORMAT_LIST; used to request data for one */ /* of the formats that was listed in CB_FORMAT_LIST */ case CB_FORMAT_DATA_REQUEST: /* 4 CLIPRDR_DATA_REQUEST */ rv = clipboard_process_data_request(ls, clip_msg_status, clip_msg_len); break; /* sent as a reply to CB_FORMAT_DATA_REQUEST; used to indicate */ /* whether processing of the CB_FORMAT_DATA_REQUEST was */ /* successful; if processing was successful, */ /* CB_FORMAT_DATA_RESPONSE includes contents of requested */ /* clipboard data. */ case CB_FORMAT_DATA_RESPONSE: /* 5 CLIPRDR_DATA_RESPONSE */ rv = clipboard_process_data_response(ls, clip_msg_status, clip_msg_len); break; case CB_CLIP_CAPS: /* 7 */ rv = clipboard_process_clip_caps(ls, clip_msg_status, clip_msg_len); break; case CB_FILECONTENTS_REQUEST: /* 8 */ rv = clipboard_process_file_request(ls, clip_msg_status, clip_msg_len); break; case CB_FILECONTENTS_RESPONSE: /* 9 */ rv = clipboard_process_file_response(ls, clip_msg_status, clip_msg_len); break; default: log_debug("clipboard_data_in: unknown clip_msg_id %d", clip_msg_id); log_error("clipboard_data_in: unknown clip_msg_id %d", clip_msg_id); break; } XFlush(g_display); return rv; } /*****************************************************************************/ /* this happens when a new app copies something to the clipboard 'CLIPBOARD' Atom typedef struct { int type; unsigned long serial; Bool send_event; Display *display; Window window; int subtype; Window owner; Atom selection; Time timestamp; Time selection_timestamp; } XFixesSelectionNotifyEvent; */ static int clipboard_event_selection_owner_notify(XEvent *xevent) { XFixesSelectionNotifyEvent *lxevent; lxevent = (XFixesSelectionNotifyEvent *)xevent; log_debug("clipboard_event_selection_owner_notify: 0x%lx", lxevent->owner); log_debug("clipboard_event_selection_owner_notify: " "window %ld subtype %d owner %ld g_wnd %ld", lxevent->window, lxevent->subtype, lxevent->owner, g_wnd); if (lxevent->owner == g_wnd) { log_debug("clipboard_event_selection_owner_notify: matches g_wnd"); log_debug("clipboard_event_selection_owner_notify: skipping, " "owner == g_wnd"); g_got_selection = 1; return 0; } g_got_selection = 0; if (lxevent->owner != 0) /* nil owner comes when selection */ { /* window is closed */ XConvertSelection(g_display, g_clipboard_atom, g_targets_atom, g_clip_property_atom, g_wnd, lxevent->timestamp); } return 0; } /*****************************************************************************/ /* returns error get a window property from wnd */ static int clipboard_get_window_property(Window wnd, Atom prop, Atom *type, int *fmt, int *n_items, char **xdata, int *xdata_size) { int lfmt; int lxdata_size; unsigned long ln_items; unsigned long llen_after; tui8 *lxdata; Atom ltype; log_debug("clipboard_get_window_property:"); log_debug(" prop %ld name %s", prop, get_atom_text(prop)); lxdata = 0; ltype = 0; XGetWindowProperty(g_display, wnd, prop, 0, 0, 0, AnyPropertyType, <ype, &lfmt, &ln_items, &llen_after, &lxdata); if (lxdata != 0) { XFree(lxdata); } if (ltype == 0) { /* XGetWindowProperty failed */ return 4; } if (llen_after < 1) { /* no data, ok */ return 0; } lxdata = 0; ltype = 0; XGetWindowProperty(g_display, wnd, prop, 0, (llen_after + 3) / 4, 0, AnyPropertyType, <ype, &lfmt, &ln_items, &llen_after, &lxdata); if (ltype == 0) { /* XGetWindowProperty failed */ if (lxdata != 0) { XFree(lxdata); } return 1; } lxdata_size = FORMAT_TO_BYTES(lfmt); lxdata_size *= ln_items; if (lxdata_size < 1) { /* should not happen */ if (lxdata != 0) { XFree(lxdata); } return 2; } if (llen_after > 0) { /* should not happen */ if (lxdata != 0) { XFree(lxdata); } return 3; } if (xdata != 0) { *xdata = (char *) g_malloc(lxdata_size, 0); g_memcpy(*xdata, lxdata, lxdata_size); } if (lxdata != 0) { XFree(lxdata); } if (xdata_size != 0) { *xdata_size = lxdata_size; } if (fmt != 0) { *fmt = (int)lfmt; } if (n_items != 0) { *n_items = (int)ln_items; } if (type != 0) { *type = ltype; } return 0; } /*****************************************************************************/ /* returns error process the SelectionNotify X event, uses XSelectionEvent typedef struct { int type; // SelectionNotify unsigned long serial; // # of last request processed by server Bool send_event; // true if this came from a SendEvent request Display *display; // Display the event was read from Window requestor; Atom selection; Atom target; Atom property; // atom or None Time time; } XSelectionEvent; */ static int clipboard_event_selection_notify(XEvent *xevent) { XSelectionEvent *lxevent; char *data; int data_size; int n_items; int fmt; int rv; int index; int got_string; int got_utf8; int got_bmp_image; int send_format_announce; Atom got_file_atom; Atom atom; Atom *atoms; Atom type; log_debug("clipboard_event_selection_notify:"); data_size = 0; n_items = 0; fmt = 0; got_string = 0; got_utf8 = 0; got_bmp_image = 0; got_file_atom = 0; send_format_announce = 0; rv = 0; data = 0; type = 0; lxevent = (XSelectionEvent *)xevent; if (lxevent->property == None) { log_error("clipboard_event_selection_notify: clip could " "not be converted"); rv = 1; } if (rv == 0) { log_debug("clipboard_event_selection_notify: wnd 0x%lx prop %s", lxevent->requestor, get_atom_text(lxevent->property)); rv = clipboard_get_window_property(lxevent->requestor, lxevent->property, &type, &fmt, &n_items, &data, &data_size); if (rv != 0) { log_error("clipboard_event_selection_notify: " "clipboard_get_window_property failed error %d", rv); return 0; } //g_hexdump(data, data_size); XDeleteProperty(g_display, lxevent->requestor, lxevent->property); if (type == g_incr_atom) { /* nothing more to do here, the data is coming in through PropertyNotify */ log_debug("clipboard_event_selection_notify: type is INCR " "data_size %d property name %s type %s", data_size, get_atom_text(lxevent->property), get_atom_text(lxevent->type)); g_clip_s2c.incr_in_progress = 1; g_clip_s2c.property = lxevent->property; g_clip_s2c.type = lxevent->target; g_clip_s2c.total_bytes = 0; g_free(g_clip_s2c.data); g_clip_s2c.data = 0; //g_hexdump(data, sizeof(long)); g_free(data); return 0; } } if (rv == 0) { if (lxevent->selection == g_clipboard_atom) { if (lxevent->target == g_targets_atom) { /* 32 implies long */ if ((type == XA_ATOM) && (fmt == 32)) { atoms = (Atom *)data; for (index = 0; index < n_items; index++) { atom = atoms[index]; LOGM((LOG_LEVEL_DEBUG, "clipboard_event_selection_notify: 0x%lx %s 0x%lx", atom, get_atom_text(atom), XA_STRING)); log_debug("clipboard_event_selection_notify: 0x%lx %s", atom, get_atom_text(atom)); if (atom == g_utf8_atom) { got_utf8 = 1; } else if (atom == XA_STRING) { got_string = 1; } else if (atom == g_image_bmp_atom) { got_bmp_image = 1; } else if ((atom == g_file_atom1) || (atom == g_file_atom2)) { log_debug("clipboard_event_selection_notify: file"); got_file_atom = atom; } else { log_error("clipboard_event_selection_notify: unknown atom 0x%lx", atom); } } } else { log_error("clipboard_event_selection_notify: error, " "target is 'TARGETS' and type[%ld] or fmt[%d] not right, " "should be type[%ld], fmt[%d]", type, fmt, XA_ATOM, 32); } } else if (lxevent->target == g_utf8_atom) { log_debug("clipboard_event_selection_notify: UTF8_STRING " "data_size %d", data_size); log_debug("clipboard_event_selection_notify: UTF8_STRING " "data_size %d", data_size); if ((g_clip_s2c.incr_in_progress == 0) && (data_size > 0)) { g_free(g_clip_s2c.data); g_clip_s2c.total_bytes = data_size; g_clip_s2c.data = (char *) g_malloc(g_clip_s2c.total_bytes + 1, 0); g_memcpy(g_clip_s2c.data, data, g_clip_s2c.total_bytes); g_clip_s2c.data[g_clip_s2c.total_bytes] = 0; if (g_clip_s2c.xrdp_clip_type == XRDP_CB_FILE) { clipboard_send_data_response_for_file(g_clip_s2c.data, g_clip_s2c.total_bytes); } else { clipboard_send_data_response_for_text(g_clip_s2c.data, g_clip_s2c.total_bytes); } } } else if (lxevent->target == XA_STRING) { log_debug("clipboard_event_selection_notify: XA_STRING " "data_size %d", data_size); log_debug("clipboard_event_selection_notify: XA_STRING " "data_size %d", data_size); if ((g_clip_s2c.incr_in_progress == 0) && (data_size > 0)) { g_free(g_clip_s2c.data); g_clip_s2c.total_bytes = data_size; g_clip_s2c.data = (char *) g_malloc(g_clip_s2c.total_bytes + 1, 0); g_memcpy(g_clip_s2c.data, data, g_clip_s2c.total_bytes); g_clip_s2c.data[g_clip_s2c.total_bytes] = 0; clipboard_send_data_response_for_text(g_clip_s2c.data, g_clip_s2c.total_bytes); } } else if (lxevent->target == g_image_bmp_atom) { log_debug("clipboard_event_selection_notify: image/bmp " "data_size %d", data_size); log_debug("clipboard_event_selection_notify: image/bmp " "data_size %d", data_size); if ((g_clip_s2c.incr_in_progress == 0) && (data_size > 14)) { g_free(g_clip_s2c.data); g_clip_s2c.total_bytes = data_size; g_clip_s2c.data = (char *) g_malloc(data_size, 0); g_memcpy(g_clip_s2c.data, data, data_size); clipboard_send_data_response_for_image(g_clip_s2c.data + 14, data_size - 14); } } else if (lxevent->target == g_file_atom1) { log_debug("clipboard_event_selection_notify: text/uri-list " "data_size %d", data_size); log_debug("clipboard_event_selection_notify: text/uri-list " "data_size %d", data_size); if ((g_clip_s2c.incr_in_progress == 0) && (data_size > 0)) { g_free(g_clip_s2c.data); g_clip_s2c.total_bytes = data_size; g_clip_s2c.data = (char *) g_malloc(g_clip_s2c.total_bytes + 1, 0); g_memcpy(g_clip_s2c.data, data, g_clip_s2c.total_bytes); g_clip_s2c.data[g_clip_s2c.total_bytes] = 0; clipboard_send_data_response_for_file(g_clip_s2c.data, g_clip_s2c.total_bytes); } } else if (lxevent->target == g_file_atom2) { log_debug("clipboard_event_selection_notify: text/uri-list " "data_size %d", data_size); log_debug("clipboard_event_selection_notify: text/uri-list " "data_size %d", data_size); if ((g_clip_s2c.incr_in_progress == 0) && (data_size > 0)) { g_free(g_clip_s2c.data); g_clip_s2c.total_bytes = data_size; g_clip_s2c.data = (char *) g_malloc(g_clip_s2c.total_bytes + 1, 0); g_memcpy(g_clip_s2c.data, data, g_clip_s2c.total_bytes); g_clip_s2c.data[g_clip_s2c.total_bytes] = 0; clipboard_send_data_response_for_file(g_clip_s2c.data, g_clip_s2c.total_bytes); } } else { log_error("clipboard_event_selection_notify: " "unknown target"); } } else { log_error("clipboard_event_selection_notify: " "unknown selection"); } } if (got_file_atom != 0) { /* text/uri-list or x-special/gnome-copied-files */ g_clip_s2c.type = got_file_atom; g_clip_s2c.xrdp_clip_type = XRDP_CB_FILE; g_clip_s2c.converted = 0; g_clip_s2c.clip_time = lxevent->time; send_format_announce = 1; } else if (got_utf8) { g_clip_s2c.type = g_utf8_atom; g_clip_s2c.xrdp_clip_type = XRDP_CB_TEXT; g_clip_s2c.converted = 0; g_clip_s2c.clip_time = lxevent->time; send_format_announce = 1; } else if (got_string) { g_clip_s2c.type = XA_STRING; g_clip_s2c.xrdp_clip_type = XRDP_CB_TEXT; g_clip_s2c.converted = 0; g_clip_s2c.clip_time = lxevent->time; send_format_announce = 1; } else if (got_bmp_image) { g_clip_s2c.type = g_image_bmp_atom; g_clip_s2c.xrdp_clip_type = XRDP_CB_BITMAP; g_clip_s2c.converted = 0; g_clip_s2c.clip_time = lxevent->time; send_format_announce = 1; } if (send_format_announce) { if (clipboard_send_format_announce(g_clip_s2c.xrdp_clip_type) != 0) { rv = 4; } } g_free(data); return rv; } /*****************************************************************************/ /* returns error process the SelectionRequest X event, uses XSelectionRequestEvent typedef struct { int type; // SelectionRequest unsigned long serial; // # of last request processed by server Bool send_event; // true if this came from a SendEvent request Display *display; // Display the event was read from Window owner; Window requestor; Atom selection; Atom target; Atom property; Time time; } XSelectionRequestEvent; */ /* * When XGetWindowProperty and XChangeProperty talk about "format 32" it * doesn't mean a 32bit value, but actually a long. So 32 means 4 bytes on * a 32bit machine and 8 bytes on a 64 machine */ static int clipboard_event_selection_request(XEvent *xevent) { XSelectionRequestEvent *lxev; Atom atom_buf[10]; Atom type; int atom_count; int fmt; int n_items; int xdata_size; char *xdata; lxev = (XSelectionRequestEvent *)xevent; log_debug("clipboard_event_selection_request: 0x%lx", lxev->property); log_debug("clipboard_event_selection_request: g_wnd %ld, " ".requestor %ld .owner %ld .selection %ld '%s' .target %ld .property %ld", g_wnd, lxev->requestor, lxev->owner, lxev->selection, get_atom_text(lxev->selection), lxev->target, lxev->property); if (lxev->property == None) { log_debug("clipboard_event_selection_request: lxev->property " "is None"); log_debug("clipboard_event_selection_request: " "lxev->property is None"); } else if (lxev->target == g_targets_atom) { log_debug("clipboard_event_selection_request: g_targets_atom"); /* requestor is asking what the selection can be converted to */ log_debug("clipboard_event_selection_request: " "g_targets_atom"); atom_buf[0] = g_targets_atom; atom_buf[1] = g_timestamp_atom; atom_buf[2] = g_multiple_atom; atom_buf[3] = XA_STRING; atom_buf[4] = g_utf8_atom; atom_count = 5; if (clipboard_find_format_id(CB_FORMAT_DIB) >= 0) { log_debug(" reporting image/bmp"); atom_buf[atom_count] = g_image_bmp_atom; atom_count++; } if (clipboard_find_format_id(g_file_format_id) >= 0) { log_debug(" reporting text/uri-list"); atom_buf[atom_count] = g_file_atom1; atom_count++; log_debug(" reporting x-special/gnome-copied-files"); atom_buf[atom_count] = g_file_atom2; atom_count++; } atom_buf[atom_count] = 0; log_debug(" reporting %d formats", atom_count); return clipboard_provide_selection(lxev, XA_ATOM, 32, (char *)atom_buf, atom_count); } else if (lxev->target == g_timestamp_atom) { /* requestor is asking the time I got the selection */ log_debug("clipboard_event_selection_request: " "g_timestamp_atom"); atom_buf[0] = g_selection_time; atom_buf[1] = 0; return clipboard_provide_selection(lxev, XA_INTEGER, 32, (char *)atom_buf, 1); } else if (lxev->target == g_multiple_atom) { /* target, property pairs */ log_debug("clipboard_event_selection_request: " "g_multiple_atom"); xdata = 0; if (clipboard_get_window_property(lxev->requestor, lxev->property, &type, &fmt, &n_items, &xdata, &xdata_size) == 0) { log_debug("clipboard_event_selection_request: g_multiple_atom " "n_items %d", n_items); /* todo */ g_free(xdata); } } else if ((lxev->target == XA_STRING) || (lxev->target == g_utf8_atom)) { g_memcpy(&g_saved_selection_req_event, lxev, sizeof(g_saved_selection_req_event)); g_clip_c2s.type = lxev->target; g_clip_c2s.xrdp_clip_type = XRDP_CB_TEXT; clipboard_send_data_request(CB_FORMAT_UNICODETEXT); return 0; } else if (lxev->target == g_image_bmp_atom) { log_debug("clipboard_event_selection_request: image/bmp"); if ((g_clip_c2s.type == lxev->target) && g_clip_c2s.converted) { log_debug("clipboard_event_selection_request: -------------------------------------------"); clipboard_provide_selection_c2s(lxev, lxev->target); return 0; } g_memcpy(&g_saved_selection_req_event, lxev, sizeof(g_saved_selection_req_event)); g_clip_c2s.type = g_image_bmp_atom; g_clip_c2s.xrdp_clip_type = XRDP_CB_BITMAP; clipboard_send_data_request(CB_FORMAT_DIB); return 0; } else if (lxev->target == g_file_atom1) { log_debug("clipboard_event_selection_request: g_file_atom1"); if ((g_clip_c2s.type == lxev->target) && g_clip_c2s.converted) { log_debug("clipboard_event_selection_request: -------------------------------------------"); clipboard_provide_selection_c2s(lxev, lxev->target); return 0; } g_memcpy(&g_saved_selection_req_event, lxev, sizeof(g_saved_selection_req_event)); g_clip_c2s.type = g_file_atom1; g_clip_c2s.xrdp_clip_type = XRDP_CB_FILE; clipboard_send_data_request(g_file_format_id); return 0; } else if (lxev->target == g_file_atom2) { log_debug("clipboard_event_selection_request: g_file_atom2"); if ((g_clip_c2s.type == lxev->target) && g_clip_c2s.converted) { log_debug("clipboard_event_selection_request: -------------------------------------------"); clipboard_provide_selection_c2s(lxev, lxev->target); return 0; } g_memcpy(&g_saved_selection_req_event, lxev, sizeof(g_saved_selection_req_event)); g_clip_c2s.type = g_file_atom2; g_clip_c2s.xrdp_clip_type = XRDP_CB_FILE; clipboard_send_data_request(g_file_format_id); return 0; } else { log_debug("clipboard_event_selection_request: unknown " "target %s", get_atom_text(lxev->target)); LOGM((LOG_LEVEL_ERROR, "clipboard_event_selection_request: unknown " "target %s", get_atom_text(lxev->target))); } clipboard_refuse_selection(lxev); return 0; } /*****************************************************************************/ /* returns error process the SelectionClear X event, uses XSelectionClearEvent typedef struct { int type; // SelectionClear unsigned long serial; // # of last request processed by server Bool send_event; // true if this came from a SendEvent request Display *display; // Display the event was read from Window window; Atom selection; Time time; } XSelectionClearEvent; */ static int clipboard_event_selection_clear(XEvent *xevent) { log_debug("clipboard_event_selection_clear:"); return 0; } /*****************************************************************************/ /* returns error typedef struct { int type; // PropertyNotify unsigned long serial; // # of last request processed by server Bool send_event; // true if this came from a SendEvent request Display *display; // Display the event was read from Window window; Atom atom; Time time; int state; // PropertyNewValue or PropertyDelete } XPropertyEvent; */ static int clipboard_event_property_notify(XEvent *xevent) { Atom actual_type_return; int actual_format_return; unsigned long nitems_returned; unsigned long bytes_left; unsigned char *data; int rv; int format_in_bytes; int new_data_len; int data_bytes; char *cptr; log_debug("clipboard_event_property_notify:"); log_debug("clipboard_event_property_notify: PropertyNotify .window %ld " ".state %d .atom %ld %s", xevent->xproperty.window, xevent->xproperty.state, xevent->xproperty.atom, get_atom_text(xevent->xproperty.atom)); if (g_clip_c2s.incr_in_progress && (xevent->xproperty.window == g_clip_c2s.window) && (xevent->xproperty.atom == g_clip_c2s.property) && (xevent->xproperty.state == PropertyDelete)) { log_debug("clipboard_event_property_notify: INCR PropertyDelete"); /* this is used for when copying a large clipboard to the other app, it will delete the property so we know to send the next one */ if ((g_clip_c2s.data == 0) || (g_clip_c2s.total_bytes < 1)) { log_debug("clipboard_event_property_notify: INCR error"); return 0; } data = (tui8 *)(g_clip_c2s.data + g_clip_c2s.incr_bytes_done); data_bytes = g_clip_c2s.read_bytes_done - g_clip_c2s.incr_bytes_done; if ((data_bytes < 1) && (g_clip_c2s.read_bytes_done < g_clip_c2s.total_bytes)) { g_clip_c2s.incr_in_progress = 0; return 0; } if (data_bytes > g_incr_max_req_size) { data_bytes = g_incr_max_req_size; } g_clip_c2s.incr_bytes_done += data_bytes; log_debug("clipboard_event_property_notify: data_bytes %d", data_bytes); XChangeProperty(xevent->xproperty.display, xevent->xproperty.window, xevent->xproperty.atom, g_clip_c2s.type, 8, PropModeReplace, data, data_bytes); if (data_bytes < 1) { log_debug("clipboard_event_property_notify: INCR done"); g_clip_c2s.incr_in_progress = 0; /* we no longer need property notify */ XSelectInput(xevent->xproperty.display, xevent->xproperty.window, NoEventMask); g_clip_c2s.converted = 1; } } if (g_clip_s2c.incr_in_progress && (xevent->xproperty.window == g_wnd) && (xevent->xproperty.atom == g_clip_s2c.property) && (xevent->xproperty.state == PropertyNewValue)) { log_debug("clipboard_event_property_notify: INCR PropertyNewValue"); rv = XGetWindowProperty(g_display, g_wnd, g_clip_s2c.property, 0, 0, 0, AnyPropertyType, &actual_type_return, &actual_format_return, &nitems_returned, &bytes_left, &data); if (rv != Success) { return 1; } if (data != 0) { XFree(data); data = 0; } if (bytes_left <= 0) { log_debug("clipboard_event_property_notify: INCR done"); /* clipboard INCR cycle has completed */ g_clip_s2c.incr_in_progress = 0; if (g_clip_s2c.type == g_image_bmp_atom) { g_clip_s2c.xrdp_clip_type = XRDP_CB_BITMAP; //g_hexdump(g_last_clip_data, 64); /* skip header */ clipboard_send_data_response(g_clip_s2c.xrdp_clip_type, g_clip_s2c.data + 14, g_clip_s2c.total_bytes - 14); } else if ((g_clip_s2c.type == XA_STRING) || (g_clip_s2c.type == g_utf8_atom)) { g_clip_s2c.xrdp_clip_type = XRDP_CB_TEXT; clipboard_send_data_response(g_clip_s2c.xrdp_clip_type, g_clip_s2c.data, g_clip_s2c.total_bytes); } else { log_error("clipboard_event_property_notify: error unknown type %ld", g_clip_s2c.type); clipboard_send_data_response_failed(); } XDeleteProperty(g_display, g_wnd, g_clip_s2c.property); } else { rv = XGetWindowProperty(g_display, g_wnd, g_clip_s2c.property, 0, bytes_left, 0, AnyPropertyType, &actual_type_return, &actual_format_return, &nitems_returned, &bytes_left, &data); if (rv != Success) { return 1; } format_in_bytes = FORMAT_TO_BYTES(actual_format_return); new_data_len = nitems_returned * format_in_bytes; cptr = (char *) g_malloc(g_clip_s2c.total_bytes + new_data_len, 0); g_memcpy(cptr, g_clip_s2c.data, g_clip_s2c.total_bytes); g_free(g_clip_s2c.data); if (cptr == NULL) { g_clip_s2c.data = 0; /* cannot add any more data */ if (data != 0) { XFree(data); } XDeleteProperty(g_display, g_wnd, g_clip_s2c.property); return 0; } log_debug("clipboard_event_property_notify: new_data_len %d", new_data_len); g_clip_s2c.data = cptr; g_memcpy(g_clip_s2c.data + g_clip_s2c.total_bytes, data, new_data_len); g_clip_s2c.total_bytes += new_data_len; if (data) { XFree(data); } XDeleteProperty(g_display, g_wnd, g_clip_s2c.property); } } return 0; } /*****************************************************************************/ /* returns 0, event handled, 1 unhandled */ int clipboard_xevent(void *xevent) { XEvent *lxevent; if (!g_clip_up) { return 1; } lxevent = (XEvent *)xevent; switch (lxevent->type) { case SelectionNotify: clipboard_event_selection_notify(lxevent); break; case SelectionRequest: clipboard_event_selection_request(lxevent); break; case SelectionClear: clipboard_event_selection_clear(lxevent); break; case MappingNotify: break; case PropertyNotify: clipboard_event_property_notify(lxevent); break; case UnmapNotify: log_debug("chansrv::clipboard_xevent: got UnmapNotify"); break; case ClientMessage: log_debug("chansrv::clipboard_xevent: got ClientMessage"); break; default: if (lxevent->type == g_xfixes_event_base + XFixesSetSelectionOwnerNotify) { log_debug("clipboard_xevent: got XFixesSetSelectionOwnerNotify"); clipboard_event_selection_owner_notify(lxevent); break; } if (lxevent->type == g_xfixes_event_base + XFixesSelectionWindowDestroyNotify) { log_debug("clipboard_xevent: got XFixesSelectionWindowDestroyNotify"); break; } if (lxevent->type == g_xfixes_event_base + XFixesSelectionClientCloseNotify) { log_debug("clipboard_xevent: got XFixesSelectionClientCloseNotify"); break; } /* we didn't handle this message */ return 1; } return 0; } xrdp-0.9.5/sesman/chansrv/pulse/module-xrdp-sink-symdef.h000644 001751 001751 00000001734 13127114621 023347 0ustar00metameta000000 000000 #ifndef MODULE_XRDP_SINK_SYMDEF_H #define MODULE_XRDP_SINK_SYMDEF_H #include #include #include #define pa__init module_xrdp_sink_LTX_pa__init #define pa__done module_xrdp_sink_LTX_pa__done #define pa__get_author module_xrdp_sink_LTX_pa__get_author #define pa__get_description module_xrdp_sink_LTX_pa__get_description #define pa__get_usage module_xrdp_sink_LTX_pa__get_usage #define pa__get_version module_xrdp_sink_LTX_pa__get_version #define pa__get_deprecated module_xrdp_sink_LTX_pa__get_deprecated #define pa__load_once module_xrdp_sink_LTX_pa__load_once #define pa__get_n_used module_xrdp_sink_LTX_pa__get_n_used int pa__init(pa_module*m); void pa__done(pa_module*m); int pa__get_n_used(pa_module*m); const char* pa__get_author(void); const char* pa__get_description(void); const char* pa__get_usage(void); const char* pa__get_version(void); const char* pa__get_deprecated(void); pa_bool_t pa__load_once(void); #endif xrdp-0.9.5/sesman/chansrv/pulse/module-xrdp-source.c000644 001751 001751 00000034110 13174271344 022413 0ustar00metameta000000 000000 /*** This file is part of PulseAudio. Copyright 2004-2008 Lennart Poettering Copyright (C) 2008 Nokia Corporation and/or its subsidiary(-ies). PulseAudio is free software; you can redistribute it and/or modify it under the terms of the GNU Lesser General Public License as published by the Free Software Foundation; either version 2 of the License, or (at your option) any later version. PulseAudio 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. You should have received a copy of the GNU Lesser General Public License along with PulseAudio; if not, write to the Free Software Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA. ***/ #ifdef HAVE_CONFIG_H #include #endif #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include /* defined in pulse/version.h */ #if PA_PROTOCOL_VERSION > 28 /* these used to be defined in pulsecore/macro.h */ typedef bool pa_bool_t; #define FALSE ((pa_bool_t) 0) #define TRUE (!FALSE) #else #endif #include "module-xrdp-source-symdef.h" #include "../../../common/xrdp_sockets.h" PA_MODULE_AUTHOR("Laxmikant Rashinkar"); PA_MODULE_DESCRIPTION("xrdp source"); PA_MODULE_VERSION(PACKAGE_VERSION); PA_MODULE_LOAD_ONCE(FALSE); PA_MODULE_USAGE( "format= " "channels= " "rate= " "source_name= " "channel_map= " "description= " "latency_time="); #define DEFAULT_SOURCE_NAME "xrdp-source" #define DEFAULT_LATENCY_TIME 10 #define MAX_LATENCY_USEC 1000 struct userdata { pa_core *core; pa_module *module; pa_source *source; pa_thread *thread; pa_thread_mq thread_mq; pa_rtpoll *rtpoll; size_t block_size; pa_usec_t block_usec; pa_usec_t timestamp; pa_usec_t latency_time; /* xrdp stuff */ int fd; /* UDS connection to xrdp chansrv */ int display_num; /* X display number */ int want_src_data; }; static const char* const valid_modargs[] = { "rate", "format", "channels", "source_name", "channel_map", "description", "latency_time", NULL }; static int get_display_num_from_display(char *display_text) ; static int source_process_msg(pa_msgobject *o, int code, void *data, int64_t offset, pa_memchunk *chunk) { struct userdata *u = PA_SOURCE(o)->userdata; switch (code) { case PA_SOURCE_MESSAGE_SET_STATE: if (PA_PTR_TO_UINT(data) == PA_SOURCE_RUNNING) u->timestamp = pa_rtclock_now(); break; case PA_SOURCE_MESSAGE_GET_LATENCY: { pa_usec_t now; now = pa_rtclock_now(); *((pa_usec_t*) data) = u->timestamp > now ? u->timestamp - now : 0; return 0; } } return pa_source_process_msg(o, code, data, offset, chunk); } static void source_update_requested_latency_cb(pa_source *s) { struct userdata *u; pa_source_assert_ref(s); u = s->userdata; pa_assert(u); u->block_usec = pa_source_get_requested_latency_within_thread(s); } static int lsend(int fd, char *data, int bytes) { int sent = 0; int error; while (sent < bytes) { error = send(fd, data + sent, bytes - sent, 0); if (error < 1) { return error; } sent += error; } return sent; } static int lrecv(int fd, char *data, int bytes) { int recved = 0; int error; while (recved < bytes) { error = recv(fd, data + recved, bytes - recved, 0); if (error < 1) { return error; } recved += error; } return recved; } static int data_get(struct userdata *u, pa_memchunk *chunk) { int fd; int bytes; int read_bytes; struct sockaddr_un s; char *data; char *socket_dir; char buf[11]; unsigned char ubuf[10]; if (u->fd == 0) { /* connect to xrdp unix domain socket */ fd = socket(PF_LOCAL, SOCK_STREAM, 0); memset(&s, 0, sizeof(s)); s.sun_family = AF_UNIX; bytes = sizeof(s.sun_path) - 1; socket_dir = getenv("XRDP_SOCKET_PATH"); if (socket_dir == NULL || socket_dir[0] == '\0') { socket_dir = "/tmp/.xrdp"; } snprintf(s.sun_path, bytes, "%s/" CHANSRV_PORT_IN_BASE_STR, socket_dir, u->display_num); pa_log_debug("Trying to connect to %s", s.sun_path); if (connect(fd, (struct sockaddr *) &s, sizeof(struct sockaddr_un)) != 0) { pa_log_debug("Connect failed"); close(fd); return -1; } pa_log("Connected ok, fd=%d", fd); pa_log_debug("###### connected to xrdp audio_in socket"); u->fd = fd; } data = (char *) pa_memblock_acquire(chunk->memblock); if (!u->want_src_data) { char buf[12]; buf[0] = 0; buf[1] = 0; buf[2] = 0; buf[3] = 0; buf[4] = 11; buf[5] = 0; buf[6] = 0; buf[7] = 0; buf[8] = 1; buf[9] = 0; buf[10] = 0; if (lsend(u->fd, buf, 11) != 11) { close(u->fd); u->fd = 0; pa_memblock_release(chunk->memblock); return -1; } u->want_src_data = 1; pa_log_debug("###### started recording"); } /* ask for more data */ buf[0] = 0; buf[1] = 0; buf[2] = 0; buf[3] = 0; buf[4] = 11; buf[5] = 0; buf[6] = 0; buf[7] = 0; buf[8] = 3; buf[9] = (unsigned char) chunk->length; buf[10] = (unsigned char) ((chunk->length >> 8) & 0xff); if (lsend(u->fd, buf, 11) != 11) { close(u->fd); u->fd = 0; pa_memblock_release(chunk->memblock); u->want_src_data = 0; return -1; } /* read length of data available */ if (lrecv(u->fd, (char *) ubuf, 2) != 2) { close(u->fd); u->fd = 0; pa_memblock_release(chunk->memblock); u->want_src_data = 0; return -1; } bytes = ((ubuf[1] << 8) & 0xff00) | (ubuf[0] & 0xff); if (bytes == 0) { pa_memblock_release(chunk->memblock); return 0; } /* get data */ read_bytes = lrecv(u->fd, data, bytes); if (read_bytes != bytes) { close(u->fd); u->fd = 0; pa_memblock_release(chunk->memblock); u->want_src_data = 0; return -1; } pa_memblock_release(chunk->memblock); return read_bytes; } static void thread_func(void *userdata) { struct userdata *u = userdata; int bytes; pa_assert(u); pa_thread_mq_install(&u->thread_mq); u->timestamp = pa_rtclock_now(); for (;;) { int ret; /* Generate some null data */ if (u->source->thread_info.state == PA_SOURCE_RUNNING) { pa_usec_t now; pa_memchunk chunk; now = pa_rtclock_now(); if ((chunk.length = pa_usec_to_bytes(now - u->timestamp, &u->source->sample_spec)) > 0) { chunk.length *= 4; chunk.memblock = pa_memblock_new(u->core->mempool, chunk.length); chunk.index = 0; bytes = data_get(u, &chunk); if (bytes > 0) { chunk.length = bytes; pa_source_post(u->source, &chunk); } pa_memblock_unref(chunk.memblock); u->timestamp = now; } pa_rtpoll_set_timer_absolute(u->rtpoll, u->timestamp + u->latency_time * PA_USEC_PER_MSEC); } else { if (u->want_src_data) { /* we don't want source data anymore */ char buf[12]; buf[0] = 0; buf[1] = 0; buf[2] = 0; buf[3] = 0; buf[4] = 11; buf[5] = 0; buf[6] = 0; buf[7] = 0; buf[8] = 2; buf[9] = 0; buf[10] = 0; if (lsend(u->fd, buf, 11) != 11) { close(u->fd); u->fd = 0; } u->want_src_data = 0; pa_log_debug("###### stopped recording"); } pa_rtpoll_set_timer_disabled(u->rtpoll); } /* Hmm, nothing to do. Let's sleep */ #if defined(PA_CHECK_VERSION) && PA_CHECK_VERSION(6, 0, 0) if ((ret = pa_rtpoll_run(u->rtpoll)) < 0) { #else if ((ret = pa_rtpoll_run(u->rtpoll, TRUE)) < 0) { #endif goto fail; } if (ret == 0) goto finish; } fail: /* If this was no regular exit from the loop we have to continue * processing messages until we received PA_MESSAGE_SHUTDOWN */ pa_asyncmsgq_post(u->thread_mq.outq, PA_MSGOBJECT(u->core), PA_CORE_MESSAGE_UNLOAD_MODULE, u->module, 0, NULL, NULL); pa_asyncmsgq_wait_for(u->thread_mq.inq, PA_MESSAGE_SHUTDOWN); finish: pa_log_debug("###### thread shutting down"); } int pa__init(pa_module *m) { struct userdata *u = NULL; pa_sample_spec ss; pa_channel_map map; pa_modargs *ma = NULL; pa_source_new_data data; uint32_t latency_time = DEFAULT_LATENCY_TIME; pa_assert(m); if (!(ma = pa_modargs_new(m->argument, valid_modargs))) { pa_log("Failed to parse module arguments."); goto fail; } #if 1 ss = m->core->default_sample_spec; #else ss.format = PA_SAMPLE_S16LE; ss.rate = 22050; ss.channels = 2; #endif map = m->core->default_channel_map; if (pa_modargs_get_sample_spec_and_channel_map(ma, &ss, &map, PA_CHANNEL_MAP_DEFAULT) < 0) { pa_log("Invalid sample format specification or channel map"); goto fail; } m->userdata = u = pa_xnew0(struct userdata, 1); u->core = m->core; u->module = m; u->rtpoll = pa_rtpoll_new(); pa_thread_mq_init(&u->thread_mq, m->core->mainloop, u->rtpoll); pa_source_new_data_init(&data); data.driver = __FILE__; data.module = m; pa_source_new_data_set_name(&data, pa_modargs_get_value(ma, "source_name", DEFAULT_SOURCE_NAME)); pa_source_new_data_set_sample_spec(&data, &ss); pa_source_new_data_set_channel_map(&data, &map); pa_proplist_sets(data.proplist, PA_PROP_DEVICE_DESCRIPTION, pa_modargs_get_value(ma, "description", "xrdp source")); pa_proplist_sets(data.proplist, PA_PROP_DEVICE_CLASS, "abstract"); u->source = pa_source_new(m->core, &data, PA_SOURCE_LATENCY | PA_SOURCE_DYNAMIC_LATENCY); pa_source_new_data_done(&data); if (!u->source) { pa_log("Failed to create source object."); goto fail; } u->latency_time = DEFAULT_LATENCY_TIME; if (pa_modargs_get_value_u32(ma, "latency_time", &latency_time) < 0) { pa_log("Failed to parse latency_time value."); goto fail; } u->latency_time = latency_time; u->source->parent.process_msg = source_process_msg; u->source->update_requested_latency = source_update_requested_latency_cb; u->source->userdata = u; pa_source_set_asyncmsgq(u->source, u->thread_mq.inq); pa_source_set_rtpoll(u->source, u->rtpoll); pa_source_set_latency_range(u->source, 0, MAX_LATENCY_USEC); u->block_usec = u->source->thread_info.max_latency; u->source->thread_info.max_rewind = pa_usec_to_bytes(u->block_usec, &u->source->sample_spec); #if defined(PA_CHECK_VERSION) #if PA_CHECK_VERSION(0, 9, 22) if (!(u->thread = pa_thread_new("xrdp-source", thread_func, u))) { #else if (!(u->thread = pa_thread_new(thread_func, u))) { #endif #else if (!(u->thread = pa_thread_new(thread_func, u))) #endif pa_log("Failed to create thread."); goto fail; } pa_source_put(u->source); pa_modargs_free(ma); u->display_num = get_display_num_from_display(getenv("DISPLAY")); return 0; fail: if (ma) pa_modargs_free(ma); pa__done(m); return -1; } void pa__done(pa_module*m) { struct userdata *u; pa_assert(m); if (!(u = m->userdata)) return; if (u->source) pa_source_unlink(u->source); if (u->thread) { pa_asyncmsgq_send(u->thread_mq.inq, NULL, PA_MESSAGE_SHUTDOWN, NULL, 0, NULL); pa_thread_free(u->thread); } pa_thread_mq_done(&u->thread_mq); if (u->source) pa_source_unref(u->source); if (u->rtpoll) pa_rtpoll_free(u->rtpoll); pa_xfree(u); } static int get_display_num_from_display(char *display_text) { int index; int mode; int host_index; int disp_index; int scre_index; int display_num; char host[256]; char disp[256]; char scre[256]; if (display_text == NULL) { return 0; } memset(host, 0, 256); memset(disp, 0, 256); memset(scre, 0, 256); index = 0; host_index = 0; disp_index = 0; scre_index = 0; mode = 0; while (display_text[index] != 0) { if (display_text[index] == ':') { mode = 1; } else if (display_text[index] == '.') { mode = 2; } else if (mode == 0) { host[host_index] = display_text[index]; host_index++; } else if (mode == 1) { disp[disp_index] = display_text[index]; disp_index++; } else if (mode == 2) { scre[scre_index] = display_text[index]; scre_index++; } index++; } host[host_index] = 0; disp[disp_index] = 0; scre[scre_index] = 0; display_num = atoi(disp); return display_num; } xrdp-0.9.5/sesman/chansrv/pulse/README.md000644 001751 001751 00000007246 13220727201 017770 0ustar00metameta000000 000000 The latest version of this document can be found at wiki. * https://github.com/neutrinolabs/xrdp/wiki/How-to-set-up-audio-redirection # Overview xrdp supports audio redirection using PulseAudio, which is a sound system for POSIX operating systems. Server to client redirection is compliant to Remote Desktop Procol standard [[MS-RDPEA]](https://msdn.microsoft.com/en-us/library/cc240933.aspx) but client to server redirection implementation is proprietary. Accordingly, server to client redirection is available with many of RDP clients including Microsoft client but client to server redirection requires NeutrinoRDP client, not available with other clients. Here is how to build pulseaudio modules for your distro, so you can have audio support through xrdp. # Prerequisites Prepare xrdp source in your home directory. Of course, you can choose another directory. cd ~ git clone https://github.com/neutrinolabs/xrdp.git In this instruction, pulseaudio version is **10.0**. Replace the version number in this instruction if your environment has different versions. You can find out your pulseaudio version executing the following command: pulseaudio --version # How to build ## Debian 9 / Ubuntu This instruction also should be applicable to Ubuntu family. ### Prerequisites Some build tools and package development tools are required. Make sure install the tools. apt install build-essential dpkg-dev ### Prepare & build Install pulseaudio and requisite packages to build pulseaudio. apt install pulseaudio apt build-dep pulseaudio Fetch the pulseaudio source . You'll see `pulseaudio-10.0` directory in your current directory. apt source pulseaudio Enter into the directory and build the pulseaudio package. cd pulseaudio-10.0 ./configure Finally, let's make. You'll have two .so files `module-xrdp-sink.so` and `module-xrdp-source.so`. cd ~/xrdp/sesman/chansrv/pulse make PULSE_DIR="~/pulseaudio-10.0" ## Other distro First off, find out your pulseaudio version using `pulseaudio --version` command. Download the tarball of the pulseaudio version that you have. * https://freedesktop.org/software/pulseaudio/releases/ After downloading the tarball, extact the tarball and `cd` into the source directory, then run `./configure`. wget https://freedesktop.org/software/pulseaudio/releases/pulseaudio-10.0.tar.xz tar xf pulseaudio-10.0.tar.gz cd pulseaudio-10.0 ./configure If additional packages are required to run `./configure`, install requisite packages depending on your environment. Finally, let's make. You'll have two .so files `module-xrdp-sink.so` and `module-xrdp-source.so`. cd ~/xrdp/sesman/chansrv/pulse make PULSE_DIR="~/pulseaudio-10.0" # Install Install process is not distro specific except for install destination. Install built two .so files into the pulseaudio modules directory. Typically, `/usr/lib/pulse-10.0/modules` for Debian, `/usr/lib64/pulse-10.0/modules` for CentOS 7. Other distro might have different path. Find out the right path for your distro. Look into the directory with `ls` command. You'll see lots of `module-*.so` files. There's the place! cd ~/xrdp/sesman/chansrv/pulse for f in *.so; do install -s -m 644 $f /usr/lib/pulse-10.0/modules; done This command is equivalent to following: install -s -m 644 module-xrdp-sink.so /usr/lib/pulse-10.0/modules install -s -m 644 module-xrdp-source.so /usr/lib/pulse-10.0/modules Well done! Pulseaudio modules should be properly built and installed. # See if it works To see if it works, run `pavumeter` in the xrdp session. Playback any YouTube video in Firefox. You'll see "Showing signal levels of **xrdp sink**" and volume meter moving. xrdp-0.9.5/sesman/chansrv/pulse/module-xrdp-source-symdef.h000644 001751 001751 00000001762 13127114621 023704 0ustar00metameta000000 000000 #ifndef MODULE_XRDP_SOURCE_SYMDEF_H #define MODULE_XRDP_SOURCE_SYMDEF_H #include #include #include #define pa__init module_xrdp_source_LTX_pa__init #define pa__done module_xrdp_source_LTX_pa__done #define pa__get_author module_xrdp_source_LTX_pa__get_author #define pa__get_description module_xrdp_source_LTX_pa__get_description #define pa__get_usage module_xrdp_source_LTX_pa__get_usage #define pa__get_version module_xrdp_source_LTX_pa__get_version #define pa__get_deprecated module_xrdp_source_LTX_pa__get_deprecated #define pa__load_once module_xrdp_source_LTX_pa__load_once #define pa__get_n_used module_xrdp_source_LTX_pa__get_n_used int pa__init(pa_module*m); void pa__done(pa_module*m); int pa__get_n_used(pa_module*m); const char* pa__get_author(void); const char* pa__get_description(void); const char* pa__get_usage(void); const char* pa__get_version(void); const char* pa__get_deprecated(void); pa_bool_t pa__load_once(void); #endif xrdp-0.9.5/sesman/chansrv/pulse/Makefile000644 001751 001751 00000001071 13174271344 020151 0ustar00metameta000000 000000 # # build xrdp pulseaudio modules # # change this to your pulseaudio source directory PULSE_DIR = /tmp/pulseaudio-10.0 CFLAGS = -Wall -O2 -I$(PULSE_DIR) -I$(PULSE_DIR)/src -DHAVE_CONFIG_H -fPIC all: module-xrdp-sink.so module-xrdp-source.so module-xrdp-sink.so: module-xrdp-sink.o $(CC) $(LDFLAGS) -shared -o module-xrdp-sink.so module-xrdp-sink.o module-xrdp-source.so: module-xrdp-source.o $(CC) $(LDFLAGS) -shared -o module-xrdp-source.so module-xrdp-source.o clean: rm -f module-xrdp-sink.o module-xrdp-sink.so module-xrdp-source.o module-xrdp-source.so xrdp-0.9.5/sesman/chansrv/pulse/.gitignore000644 001751 001751 00000000012 13127114621 020463 0ustar00metameta000000 000000 !Makefile xrdp-0.9.5/sesman/chansrv/pulse/module-xrdp-sink.c000644 001751 001751 00000036540 13174271344 022070 0ustar00metameta000000 000000 /** * xrdp: A Remote Desktop Protocol server. * pulse sink * * Copyright (C) Jay Sorg 2013 * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ /* * see pulse-notes.txt */ #ifdef HAVE_CONFIG_H #include #endif #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include /* defined in pulse/version.h */ #if PA_PROTOCOL_VERSION > 28 /* these used to be defined in pulsecore/macro.h */ typedef bool pa_bool_t; #define FALSE ((pa_bool_t) 0) #define TRUE (!FALSE) #else #endif #include "module-xrdp-sink-symdef.h" #include "../../../common/xrdp_sockets.h" PA_MODULE_AUTHOR("Jay Sorg"); PA_MODULE_DESCRIPTION("xrdp sink"); PA_MODULE_VERSION(PACKAGE_VERSION); PA_MODULE_LOAD_ONCE(FALSE); PA_MODULE_USAGE( "sink_name= " "sink_properties= " "format= " "rate= " "channels= " "channel_map="); #define DEFAULT_SINK_NAME "xrdp-sink" #define BLOCK_USEC 30000 //#define BLOCK_USEC (PA_USEC_PER_SEC * 2) struct userdata { pa_core *core; pa_module *module; pa_sink *sink; pa_thread *thread; pa_thread_mq thread_mq; pa_rtpoll *rtpoll; pa_usec_t block_usec; pa_usec_t timestamp; pa_usec_t failed_connect_time; pa_usec_t last_send_time; int fd; /* unix domain socket connection to xrdp chansrv */ int display_num; int skip_bytes; int got_max_latency; }; static const char* const valid_modargs[] = { "sink_name", "sink_properties", "format", "rate", "channels", "channel_map", NULL }; static int close_send(struct userdata *u); static int sink_process_msg(pa_msgobject *o, int code, void *data, int64_t offset, pa_memchunk *chunk) { struct userdata *u = PA_SINK(o)->userdata; pa_usec_t now; long lat; pa_log_debug("sink_process_msg: code %d", code); switch (code) { case PA_SINK_MESSAGE_SET_VOLUME: /* 3 */ break; case PA_SINK_MESSAGE_SET_MUTE: /* 6 */ break; case PA_SINK_MESSAGE_GET_LATENCY: /* 7 */ now = pa_rtclock_now(); lat = u->timestamp > now ? u->timestamp - now : 0ULL; pa_log_debug("sink_process_msg: lat %ld", lat); *((pa_usec_t*) data) = lat; return 0; case PA_SINK_MESSAGE_GET_REQUESTED_LATENCY: /* 8 */ break; case PA_SINK_MESSAGE_SET_STATE: /* 9 */ if (PA_PTR_TO_UINT(data) == PA_SINK_RUNNING) /* 0 */ { pa_log("sink_process_msg: running"); u->timestamp = pa_rtclock_now(); } else { pa_log("sink_process_msg: not running"); close_send(u); } break; } return pa_sink_process_msg(o, code, data, offset, chunk); } static void sink_update_requested_latency_cb(pa_sink *s) { struct userdata *u; size_t nbytes; pa_sink_assert_ref(s); pa_assert_se(u = s->userdata); u->block_usec = BLOCK_USEC; //u->block_usec = pa_sink_get_requested_latency_within_thread(s); pa_log("1 block_usec %llu", (unsigned long long) u->block_usec); u->got_max_latency = 0; if (u->block_usec == (pa_usec_t) -1) { u->block_usec = s->thread_info.max_latency; pa_log_debug("2 block_usec %llu", (unsigned long long) u->block_usec); u->got_max_latency = 1; } nbytes = pa_usec_to_bytes(u->block_usec, &s->sample_spec); pa_sink_set_max_rewind_within_thread(s, nbytes); pa_sink_set_max_request_within_thread(s, nbytes); } static void process_rewind(struct userdata *u, pa_usec_t now) { size_t rewind_nbytes, in_buffer; pa_usec_t delay; pa_assert(u); /* Figure out how much we shall rewind and reset the counter */ rewind_nbytes = u->sink->thread_info.rewind_nbytes; u->sink->thread_info.rewind_nbytes = 0; pa_assert(rewind_nbytes > 0); pa_log_debug("Requested to rewind %lu bytes.", (unsigned long) rewind_nbytes); if (u->timestamp <= now) goto do_nothing; delay = u->timestamp - now; in_buffer = pa_usec_to_bytes(delay, &u->sink->sample_spec); if (in_buffer <= 0) goto do_nothing; if (rewind_nbytes > in_buffer) rewind_nbytes = in_buffer; pa_sink_process_rewind(u->sink, rewind_nbytes); u->timestamp -= pa_bytes_to_usec(rewind_nbytes, &u->sink->sample_spec); u->skip_bytes += rewind_nbytes; pa_log_debug("Rewound %lu bytes.", (unsigned long) rewind_nbytes); return; do_nothing: pa_sink_process_rewind(u->sink, 0); } struct header { int code; int bytes; }; static int get_display_num_from_display(char *display_text) { int index; int mode; int host_index; int disp_index; int scre_index; int display_num; char host[256]; char disp[256]; char scre[256]; if (display_text == NULL) { return 0; } memset(host, 0, 256); memset(disp, 0, 256); memset(scre, 0, 256); index = 0; host_index = 0; disp_index = 0; scre_index = 0; mode = 0; while (display_text[index] != 0) { if (display_text[index] == ':') { mode = 1; } else if (display_text[index] == '.') { mode = 2; } else if (mode == 0) { host[host_index] = display_text[index]; host_index++; } else if (mode == 1) { disp[disp_index] = display_text[index]; disp_index++; } else if (mode == 2) { scre[scre_index] = display_text[index]; scre_index++; } index++; } host[host_index] = 0; disp[disp_index] = 0; scre[scre_index] = 0; display_num = atoi(disp); return display_num; } static int lsend(int fd, char *data, int bytes) { int sent = 0; int error; while (sent < bytes) { error = send(fd, data + sent, bytes - sent, 0); if (error < 1) { return error; } sent += error; } return sent; } static int data_send(struct userdata *u, pa_memchunk *chunk) { char *data; char *socket_dir; int bytes; int sent; int fd; struct header h; struct sockaddr_un s; if (u->fd == 0) { if (u->failed_connect_time != 0) { if (pa_rtclock_now() - u->failed_connect_time < 1000000) { return 0; } } fd = socket(PF_LOCAL, SOCK_STREAM, 0); memset(&s, 0, sizeof(s)); s.sun_family = AF_UNIX; bytes = sizeof(s.sun_path) - 1; socket_dir = getenv("XRDP_SOCKET_PATH"); if (socket_dir == NULL || socket_dir[0] == '\0') { socket_dir = "/tmp/.xrdp"; } snprintf(s.sun_path, bytes, "%s/" CHANSRV_PORT_OUT_BASE_STR, socket_dir, u->display_num); pa_log_debug("trying to connect to %s", s.sun_path); if (connect(fd, (struct sockaddr *)&s, sizeof(struct sockaddr_un)) != 0) { u->failed_connect_time = pa_rtclock_now(); pa_log_debug("Connected failed"); close(fd); return 0; } u->failed_connect_time = 0; pa_log("Connected ok fd %d", fd); u->fd = fd; } bytes = chunk->length; pa_log_debug("bytes %d", bytes); /* from rewind */ if (u->skip_bytes > 0) { if (bytes > u->skip_bytes) { bytes -= u->skip_bytes; u->skip_bytes = 0; } else { u->skip_bytes -= bytes; return bytes; } } h.code = 0; h.bytes = bytes + 8; if (lsend(u->fd, (char*)(&h), 8) != 8) { pa_log("data_send: send failed"); close(u->fd); u->fd = 0; return 0; } else { pa_log_debug("data_send: sent header ok bytes %d", bytes); } data = (char*)pa_memblock_acquire(chunk->memblock); data += chunk->index; sent = lsend(u->fd, data, bytes); pa_memblock_release(chunk->memblock); if (sent != bytes) { pa_log("data_send: send failed sent %d bytes %d", sent, bytes); close(u->fd); u->fd = 0; return 0; } return sent; } static int close_send(struct userdata *u) { struct header h; pa_log("close_send:"); if (u->fd == 0) { return 0; } h.code = 1; h.bytes = 8; if (lsend(u->fd, (char*)(&h), 8) != 8) { pa_log("close_send: send failed"); close(u->fd); u->fd = 0; return 0; } else { pa_log_debug("close_send: sent header ok"); } return 8; } static void process_render(struct userdata *u, pa_usec_t now) { pa_memchunk chunk; int request_bytes; pa_assert(u); if (u->got_max_latency) { return; } pa_log_debug("process_render: u->block_usec %llu", (unsigned long long) u->block_usec); while (u->timestamp < now + u->block_usec) { request_bytes = u->sink->thread_info.max_request; request_bytes = MIN(request_bytes, 16 * 1024); pa_sink_render(u->sink, request_bytes, &chunk); data_send(u, &chunk); pa_memblock_unref(chunk.memblock); u->timestamp += pa_bytes_to_usec(chunk.length, &u->sink->sample_spec); } } static void thread_func(void *userdata) { struct userdata *u = userdata; int ret; pa_usec_t now; pa_assert(u); pa_log_debug("Thread starting up"); pa_thread_mq_install(&u->thread_mq); u->timestamp = pa_rtclock_now(); for (;;) { if (u->sink->thread_info.state == PA_SINK_RUNNING) { now = pa_rtclock_now(); if (u->sink->thread_info.rewind_requested) { if (u->sink->thread_info.rewind_nbytes > 0) { process_rewind(u, now); } else { pa_sink_process_rewind(u->sink, 0); } } if (u->timestamp <= now) { pa_log_debug("thread_func: calling process_render"); process_render(u, now); } pa_rtpoll_set_timer_absolute(u->rtpoll, u->timestamp); } else { pa_rtpoll_set_timer_disabled(u->rtpoll); } #if defined(PA_CHECK_VERSION) && PA_CHECK_VERSION(6, 0, 0) if ((ret = pa_rtpoll_run(u->rtpoll)) < 0) { #else if ((ret = pa_rtpoll_run(u->rtpoll, TRUE)) < 0) { #endif goto fail; } if (ret == 0) { goto finish; } } fail: /* If this was no regular exit from the loop we have to continue * processing messages until we received PA_MESSAGE_SHUTDOWN */ pa_asyncmsgq_post(u->thread_mq.outq, PA_MSGOBJECT(u->core), PA_CORE_MESSAGE_UNLOAD_MODULE, u->module, 0, NULL, NULL); pa_asyncmsgq_wait_for(u->thread_mq.inq, PA_MESSAGE_SHUTDOWN); finish: pa_log_debug("Thread shutting down"); } int pa__init(pa_module*m) { struct userdata *u = NULL; pa_sample_spec ss; pa_channel_map map; pa_modargs *ma = NULL; pa_sink_new_data data; size_t nbytes; pa_assert(m); if (!(ma = pa_modargs_new(m->argument, valid_modargs))) { pa_log("Failed to parse module arguments."); goto fail; } ss = m->core->default_sample_spec; map = m->core->default_channel_map; if (pa_modargs_get_sample_spec_and_channel_map(ma, &ss, &map, PA_CHANNEL_MAP_DEFAULT) < 0) { pa_log("Invalid sample format specification or channel map"); goto fail; } m->userdata = u = pa_xnew0(struct userdata, 1); u->core = m->core; u->module = m; u->rtpoll = pa_rtpoll_new(); pa_thread_mq_init(&u->thread_mq, m->core->mainloop, u->rtpoll); pa_sink_new_data_init(&data); data.driver = __FILE__; data.module = m; pa_sink_new_data_set_name(&data, pa_modargs_get_value(ma, "sink_name", DEFAULT_SINK_NAME)); pa_sink_new_data_set_sample_spec(&data, &ss); pa_sink_new_data_set_channel_map(&data, &map); pa_proplist_sets(data.proplist, PA_PROP_DEVICE_DESCRIPTION, "xrdp sink"); pa_proplist_sets(data.proplist, PA_PROP_DEVICE_CLASS, "abstract"); if (pa_modargs_get_proplist(ma, "sink_properties", data.proplist, PA_UPDATE_REPLACE) < 0) { pa_log("Invalid properties"); pa_sink_new_data_done(&data); goto fail; } u->sink = pa_sink_new(m->core, &data, PA_SINK_LATENCY | PA_SINK_DYNAMIC_LATENCY); pa_sink_new_data_done(&data); if (!u->sink) { pa_log("Failed to create sink object."); goto fail; } u->sink->parent.process_msg = sink_process_msg; u->sink->update_requested_latency = sink_update_requested_latency_cb; u->sink->userdata = u; pa_sink_set_asyncmsgq(u->sink, u->thread_mq.inq); pa_sink_set_rtpoll(u->sink, u->rtpoll); u->block_usec = BLOCK_USEC; pa_log_debug("3 block_usec %llu", (unsigned long long) u->block_usec); nbytes = pa_usec_to_bytes(u->block_usec, &u->sink->sample_spec); pa_sink_set_max_rewind(u->sink, nbytes); pa_sink_set_max_request(u->sink, nbytes); u->display_num = get_display_num_from_display(getenv("DISPLAY")); #if defined(PA_CHECK_VERSION) #if PA_CHECK_VERSION(0, 9, 22) if (!(u->thread = pa_thread_new("xrdp-sink", thread_func, u))) { #else if (!(u->thread = pa_thread_new(thread_func, u))) { #endif #else if (!(u->thread = pa_thread_new(thread_func, u))) { #endif pa_log("Failed to create thread."); goto fail; } pa_sink_put(u->sink); pa_modargs_free(ma); return 0; fail: if (ma) { pa_modargs_free(ma); } pa__done(m); return -1; } int pa__get_n_used(pa_module *m) { struct userdata *u; pa_assert(m); pa_assert_se(u = m->userdata); return pa_sink_linked_by(u->sink); } void pa__done(pa_module*m) { struct userdata *u; pa_assert(m); if (!(u = m->userdata)) { return; } if (u->sink) { pa_sink_unlink(u->sink); } if (u->thread) { pa_asyncmsgq_send(u->thread_mq.inq, NULL, PA_MESSAGE_SHUTDOWN, NULL, 0, NULL); pa_thread_free(u->thread); } pa_thread_mq_done(&u->thread_mq); if (u->sink) { pa_sink_unref(u->sink); } if (u->rtpoll) { pa_rtpoll_free(u->rtpoll); } pa_xfree(u); } xrdp-0.9.5/sesman/chansrv/pulse/README.md~000644 001751 001751 00000010614 13220223122 020150 0ustar00metameta000000 000000 The latest version of this document can be found at wiki. * https://github.com/neutrinolabs/xrdp/wiki/How-to-set-up-audio-redirection # Overview xrdp supports audio redirection using PulseAudio, which is a sound system for POSIX operating systems. Server to client redirection is compliant to Remote Desktop Procol standard [[MS-RDPEA]](https://msdn.microsoft.com/en-us/library/cc240933.aspx) but client to server redirection implementation is proprietary. Accordingly, server to client redirection is available with many of RDP clients including Microsoft client but client to server redirection requires NeutrinoRDP client, not available with other clients. Here is how to build pulseaudio modules for your distro, so you can have audio support through xrdp. # Prerequisites Prepare xrdp source in your home directory. Of course, you can choose another directory. cd ~ git clone https://github.com/neutrinolabs/xrdp.git In this instruction, pulseaudio version is **10.0**. Replace the version number in this instruction if your environment has different versions. You can find out your pulseaudio version executing the following command: pulseaudio --version # How to build ## Debian 9 / Ubuntu This instruction also should be applicable to Ubuntu family. ### Prerequisites Some build tools and package development tools are required. Make sure install the tools. apt install build-essential dpkg-dev ### Prepare & build Install pulseaudio and requisite packages to build pulseaudio. apt install pulseaudio apt build-dep pulseaudio Fetch the pulseaudio source . You'll see `pulseaudio-10.0` directory in your current directory. apt source pulseaudio Enter into the directory and build the pulseaudio package. cd pulseaudio-10.0 dpkg-buildpackage -rfakeroot -uc -b Enter into pulse directory in xrdp source. cd ~/xrdp/sesman/chansrv/pulse nano Makefile Edit the `Makefile`. Replace `/tmp/pulseaudio-10.0` with your pulseaudio source directory. ```diff diff --git a/sesman/chansrv/pulse/Makefile b/sesman/chansrv/pulse/Makefile index 74977221..395ef0a0 100644 --- a/sesman/chansrv/pulse/Makefile +++ b/sesman/chansrv/pulse/Makefile @@ -3,7 +3,7 @@ # # change this to your pulseaudio source directory -PULSE_DIR = /tmp/pulseaudio-10.0 +PULSE_DIR = /home/debian/pulseaudio-10.0 CFLAGS = -Wall -O2 -I$(PULSE_DIR) -I$(PULSE_DIR)/src -DHAVE_CONFIG_H -fPIC all: module-xrdp-sink.so module-xrdp-source.so ``` Finally, let's make. You'll have two .so files `module-xrdp-sink.so` and `module-xrdp-source.so`. make ## Other distro First off, find out your pulseaudio version using `pulseaudio --version` command. Download the tarball of the pulseaudio version that you have. * https://freedesktop.org/software/pulseaudio/releases/ After downloading the tarball, extact the tarball and `cd` into the source directory, then run `./configure`. wget https://freedesktop.org/software/pulseaudio/releases/pulseaudio-10.0.tar.xz tar xf pulseaudio-10.0.tar.gz cd pulseaudio-10.0 ./configure If additional packages are required to run `./configure`, install requisite packages depending on your environment. Next, enter into pulse directory in xrdp source and replace `/tmp/pulseaudio-10.0` in `Makefile` with your pulseaudio source directory. cd ~/xrdp/sesman/chansrv/pulse nano Makefile Finally, let's make. You'll have two .so files `module-xrdp-sink.so` and `module-xrdp-source.so`. make # Install Install process is not distro specific except for install destination. Install built two .so files into the pulseaudio modules directory. Typically, `/usr/lib/pulse-10.0/modules` for Debian, `/usr/lib64/pulse-10.0/modules` for CentOS 7. Other distro might have different path. Find out the right path for your distro. Look into the directory with `ls` command. You'll see lots of `module-*.so` files. There's the place! cd ~/xrdp/sesman/chansrv/pulse for f in *.so; do install -s -m 644 $f /usr/lib/pulse-10.0/modules; done This command is equivalent to following: install -s -m 644 module-xrdp-sink.so /usr/lib/pulse-10.0/modules install -s -m 644 module-xrdp-source.so /usr/lib/pulse-10.0/modules Well done! Pulseaudio modules should be properly built and installed. # See if it works To see if it works, run `pavumeter` in the xrdp session. Playback any YouTube video in Firefox. You'll see "Showing signal levels of **xrdp sink**" and volume meter moving. xrdp-0.9.5/sesman/chansrv/pcsc/xrdp_pcsc.c000644 001751 001751 00000116017 13125122134 020435 0ustar00metameta000000 000000 #include #include #include #include #include #include #include #include #include #include #include #define PCSC_API typedef unsigned char BYTE; typedef BYTE *LPBYTE; #ifdef __APPLE__ typedef int LONG; typedef unsigned int DWORD; #else typedef long LONG; typedef unsigned long DWORD; #endif typedef DWORD *LPDWORD; typedef const void *LPCVOID; typedef const char *LPCSTR; typedef char *LPSTR; typedef void *LPVOID; typedef const BYTE *LPCBYTE; typedef LONG SCARDCONTEXT; typedef SCARDCONTEXT *LPSCARDCONTEXT; typedef LONG SCARDHANDLE; typedef SCARDHANDLE *LPSCARDHANDLE; #define MAX_ATR_SIZE 33 typedef struct _SCARD_READERSTATE { const char *szReader; void *pvUserData; DWORD dwCurrentState; DWORD dwEventState; DWORD cbAtr; unsigned char rgbAtr[MAX_ATR_SIZE]; } SCARD_READERSTATE, *LPSCARD_READERSTATE; typedef struct _SCARD_IO_REQUEST { unsigned long dwProtocol; unsigned long cbPciLength; } SCARD_IO_REQUEST, *PSCARD_IO_REQUEST, *LPSCARD_IO_REQUEST; #define SCARD_PROTOCOL_T0 0x0001 /**< T=0 active protocol. */ #define SCARD_PROTOCOL_T1 0x0002 /**< T=1 active protocol. */ #define SCARD_PROTOCOL_RAW 0x0004 /**< Raw active protocol. */ PCSC_API SCARD_IO_REQUEST g_rgSCardT0Pci = { SCARD_PROTOCOL_T0, 8 }; PCSC_API SCARD_IO_REQUEST g_rgSCardT1Pci = { SCARD_PROTOCOL_T1, 8 }; PCSC_API SCARD_IO_REQUEST g_rgSCardRawPci = { SCARD_PROTOCOL_RAW, 8 }; #define LLOG_LEVEL 5 #define LLOGLN(_level, _args) \ do { if (_level < LLOG_LEVEL) { printf _args ; printf("\n"); } } while (0) #define LHEXDUMP(_level, _args) \ do { if (_level < LLOG_LEVEL) { lhexdump _args ; } } while (0) #define SCARD_ESTABLISH_CONTEXT 0x01 #define SCARD_RELEASE_CONTEXT 0x02 #define SCARD_LIST_READERS 0x03 #define SCARD_CONNECT 0x04 #define SCARD_RECONNECT 0x05 #define SCARD_DISCONNECT 0x06 #define SCARD_BEGIN_TRANSACTION 0x07 #define SCARD_END_TRANSACTION 0x08 #define SCARD_TRANSMIT 0x09 #define SCARD_CONTROL 0x0A #define SCARD_STATUS 0x0B #define SCARD_GET_STATUS_CHANGE 0x0C #define SCARD_CANCEL 0x0D #define SCARD_CANCEL_TRANSACTION 0x0E #define SCARD_GET_ATTRIB 0x0F #define SCARD_SET_ATTRIB 0x10 #define SCARD_S_SUCCESS 0x00000000 #define SCARD_F_INTERNAL_ERROR ((LONG)0x80100001) #define SET_UINT32(_data, _offset, _val) do { \ (((BYTE*)(_data)) + (_offset))[0] = ((_val) >> 0) & 0xff; \ (((BYTE*)(_data)) + (_offset))[1] = ((_val) >> 8) & 0xff; \ (((BYTE*)(_data)) + (_offset))[2] = ((_val) >> 16) & 0xff; \ (((BYTE*)(_data)) + (_offset))[3] = ((_val) >> 24) & 0xff; } while (0) #define GET_UINT32(_data, _offset) \ ((((BYTE*)(_data)) + (_offset))[0] << 0) | \ ((((BYTE*)(_data)) + (_offset))[1] << 8) | \ ((((BYTE*)(_data)) + (_offset))[2] << 16) | \ ((((BYTE*)(_data)) + (_offset))[3] << 24) #define LMIN(_val1, _val2) (_val1) < (_val2) ? (_val1) : (_val2) #define LMAX(_val1, _val2) (_val1) > (_val2) ? (_val1) : (_val2) static int g_sck = -1; /* unix domain socket */ static pthread_mutex_t g_mutex = PTHREAD_MUTEX_INITIALIZER; /* for pcsc_stringify_error */ static char g_error_str[512]; /*****************************************************************************/ /* produce a hex dump */ static void lhexdump(void *p, int len) { unsigned char *line; int i; int thisline; int offset; line = (unsigned char *)p; offset = 0; while (offset < len) { printf("%04x ", offset); thisline = len - offset; if (thisline > 16) { thisline = 16; } for (i = 0; i < thisline; i++) { printf("%02x ", line[i]); } for (; i < 16; i++) { printf(" "); } for (i = 0; i < thisline; i++) { printf("%c", (line[i] >= 0x20 && line[i] < 0x7f) ? line[i] : '.'); } printf("\n"); offset += thisline; line += thisline; } } /*****************************************************************************/ static int get_display_num_from_display(const char *display_text) { int rv; int index; int mode; int host_index; int disp_index; int scre_index; char host[256]; char disp[256]; char scre[256]; memset(host, 0, 256); memset(disp, 0, 256); memset(scre, 0, 256); index = 0; host_index = 0; disp_index = 0; scre_index = 0; mode = 0; while (display_text[index] != 0) { if (display_text[index] == ':') { mode = 1; } else if (display_text[index] == '.') { mode = 2; } else if (mode == 0) { host[host_index] = display_text[index]; host_index++; } else if (mode == 1) { disp[disp_index] = display_text[index]; disp_index++; } else if (mode == 2) { scre[scre_index] = display_text[index]; scre_index++; } index++; } host[host_index] = 0; disp[disp_index] = 0; scre[scre_index] = 0; LLOGLN(10, ("get_display_num_from_display: host [%s] disp [%s] scre [%s]", host, disp, scre)); rv = atoi(disp); return rv; } /*****************************************************************************/ static int connect_to_chansrv(void) { int bytes; int dis; int error; char *xrdp_session; char *xrdp_display; char *home_str; struct sockaddr_un saddr; struct sockaddr *psaddr; if (g_sck != -1) { /* already connected */ return 0; } xrdp_session = getenv("XRDP_SESSION"); if (xrdp_session == NULL) { /* XRDP_SESSION must be set */ LLOGLN(0, ("connect_to_chansrv: error, not xrdp session")); return 1; } xrdp_display = getenv("DISPLAY"); if (xrdp_display == NULL) { /* DISPLAY must be set */ LLOGLN(0, ("connect_to_chansrv: error, display not set")); return 1; } home_str = getenv("HOME"); if (home_str == NULL) { /* HOME must be set */ LLOGLN(0, ("connect_to_chansrv: error, home not set")); return 1; } dis = get_display_num_from_display(xrdp_display); if (dis < 10) { /* DISPLAY must be > 9 */ LLOGLN(0, ("connect_to_chansrv: error, display not > 9 %d", dis)); return 1; } g_sck = socket(PF_LOCAL, SOCK_STREAM, 0); if (g_sck == -1) { LLOGLN(0, ("connect_to_chansrv: error, socket failed")); return 1; } memset(&saddr, 0, sizeof(struct sockaddr_un)); saddr.sun_family = AF_UNIX; bytes = sizeof(saddr.sun_path); snprintf(saddr.sun_path, bytes, "%s/.pcsc%d/pcscd.comm", home_str, dis); saddr.sun_path[bytes - 1] = 0; LLOGLN(10, ("connect_to_chansrv: connecting to %s", saddr.sun_path)); psaddr = (struct sockaddr *) &saddr; bytes = sizeof(struct sockaddr_un); error = connect(g_sck, psaddr, bytes); if (error == 0) { } else { perror("connect_to_chansrv"); close(g_sck); g_sck = -1; LLOGLN(0, ("connect_to_chansrv: error, open %s", saddr.sun_path)); return 1; } return 0; } /*****************************************************************************/ static int send_message(int code, char *data, int bytes) { char header[8]; pthread_mutex_lock(&g_mutex); SET_UINT32(header, 0, bytes); SET_UINT32(header, 4, code); if (send(g_sck, header, 8, 0) != 8) { pthread_mutex_unlock(&g_mutex); return 1; } if (send(g_sck, data, bytes, 0) != bytes) { pthread_mutex_unlock(&g_mutex); return 1; } LLOGLN(10, ("send_message:")); LHEXDUMP(10, (data, bytes)); pthread_mutex_unlock(&g_mutex); return 0; } /*****************************************************************************/ static int get_message(int *code, char *data, int *bytes) { char header[8]; int max_bytes; int error; int recv_rv; int max; int lcode; struct timeval time; fd_set rd_set; LLOGLN(10, ("get_message:")); max = g_sck + 1; while (1) { LLOGLN(10, ("get_message: loop")); time.tv_sec = 1; time.tv_usec = 0; FD_ZERO(&rd_set); FD_SET(((unsigned int)g_sck), &rd_set); error = select(max, &rd_set, 0, 0, &time); if (error == 1) { pthread_mutex_lock(&g_mutex); time.tv_sec = 0; time.tv_usec = 0; FD_ZERO(&rd_set); FD_SET(((unsigned int)g_sck), &rd_set); error = select(max, &rd_set, 0, 0, &time); if (error == 1) { /* just take a look at the next message */ recv_rv = recv(g_sck, header, 8, MSG_PEEK); if (recv_rv == 8) { lcode = GET_UINT32(header, 4); if (lcode == *code) { /* still have mutex lock */ break; } else { LLOGLN(10, ("get_message: lcode %d *code %d", lcode, *code)); } } else if (recv_rv == 0) { pthread_mutex_unlock(&g_mutex); LLOGLN(0, ("get_message: recv_rv 0, disconnect")); return 1; } else { LLOGLN(10, ("get_message: recv_rv %d", recv_rv)); } } else { LLOGLN(10, ("get_message: select return %d", error)); } pthread_mutex_unlock(&g_mutex); usleep(1000); } } if (recv(g_sck, header, 8, 0) != 8) { pthread_mutex_unlock(&g_mutex); return 1; } max_bytes = *bytes; *bytes = GET_UINT32(header, 0); *code = GET_UINT32(header, 4); if (*bytes > max_bytes) { pthread_mutex_unlock(&g_mutex); return 1; } if (recv(g_sck, data, *bytes, 0) != *bytes) { pthread_mutex_unlock(&g_mutex); return 1; } pthread_mutex_unlock(&g_mutex); return 0; } /*****************************************************************************/ PCSC_API LONG SCardEstablishContext(DWORD dwScope, LPCVOID pvReserved1, LPCVOID pvReserved2, LPSCARDCONTEXT phContext) { char msg[256]; DWORD context; int code; int bytes; int status; LLOGLN(10, ("SCardEstablishContext:")); if (g_sck == -1) { if (connect_to_chansrv() != 0) { LLOGLN(0, ("SCardEstablishContext: error, can not connect " "to chansrv")); return SCARD_F_INTERNAL_ERROR; } } SET_UINT32(msg, 0, dwScope); if (send_message(SCARD_ESTABLISH_CONTEXT, msg, 4) != 0) { LLOGLN(0, ("SCardEstablishContext: error, send_message")); return SCARD_F_INTERNAL_ERROR; } bytes = 256; code = SCARD_ESTABLISH_CONTEXT; if (get_message(&code, msg, &bytes) != 0) { LLOGLN(0, ("SCardEstablishContext: error, get_message")); return SCARD_F_INTERNAL_ERROR; } if ((code != SCARD_ESTABLISH_CONTEXT) || (bytes != 8)) { LLOGLN(0, ("SCardEstablishContext: error, bad code")); return SCARD_F_INTERNAL_ERROR; } context = GET_UINT32(msg, 0); status = GET_UINT32(msg, 4); LLOGLN(10, ("SCardEstablishContext: got context 0x%8.8x", (int)context)); *phContext = context; return status; } /*****************************************************************************/ PCSC_API LONG SCardReleaseContext(SCARDCONTEXT hContext) { char msg[256]; int code; int bytes; int status; LLOGLN(10, ("SCardReleaseContext:")); if (g_sck == -1) { LLOGLN(0, ("SCardReleaseContext: error, not connected")); return SCARD_F_INTERNAL_ERROR; } SET_UINT32(msg, 0, hContext); if (send_message(SCARD_RELEASE_CONTEXT, msg, 4) != 0) { LLOGLN(0, ("SCardReleaseContext: error, send_message")); return SCARD_F_INTERNAL_ERROR; } bytes = 256; code = SCARD_RELEASE_CONTEXT; if (get_message(&code, msg, &bytes) != 0) { LLOGLN(0, ("SCardReleaseContext: error, get_message")); return SCARD_F_INTERNAL_ERROR; } if ((code != SCARD_RELEASE_CONTEXT) || (bytes != 4)) { LLOGLN(0, ("SCardReleaseContext: error, bad code")); return SCARD_F_INTERNAL_ERROR; } status = GET_UINT32(msg, 0); LLOGLN(10, ("SCardReleaseContext: got status 0x%8.8x", status)); return status; } /*****************************************************************************/ PCSC_API LONG SCardIsValidContext(SCARDCONTEXT hContext) { LLOGLN(10, ("SCardIsValidContext:")); if (g_sck == -1) { LLOGLN(0, ("SCardIsValidContext: error, not connected")); return SCARD_F_INTERNAL_ERROR; } return SCARD_S_SUCCESS; } /*****************************************************************************/ PCSC_API LONG SCardConnect(SCARDCONTEXT hContext, LPCSTR szReader, DWORD dwShareMode, DWORD dwPreferredProtocols, LPSCARDHANDLE phCard, LPDWORD pdwActiveProtocol) { char msg[256]; int code; int bytes; int status; int offset; LLOGLN(10, ("SCardConnect:")); LLOGLN(10, ("SCardConnect: hContext 0x%8.8x szReader %s dwShareMode %d " "dwPreferredProtocols %d", (int)hContext, szReader, (int)dwShareMode, (int)dwPreferredProtocols)); if (g_sck == -1) { LLOGLN(0, ("SCardConnect: error, not connected")); return SCARD_F_INTERNAL_ERROR; } offset = 0; SET_UINT32(msg, offset, hContext); offset += 4; bytes = strlen(szReader); if (bytes > 99) { LLOGLN(0, ("SCardConnect: error, name too long")); return SCARD_F_INTERNAL_ERROR; } memcpy(msg + offset, szReader, bytes); memset(msg + offset + bytes, 0, 100 - bytes); offset += 100; SET_UINT32(msg, offset, dwShareMode); offset += 4; SET_UINT32(msg, offset, dwPreferredProtocols); offset += 4; if (send_message(SCARD_CONNECT, msg, offset) != 0) { LLOGLN(0, ("SCardConnect: error, send_message")); return SCARD_F_INTERNAL_ERROR; } bytes = 256; code = SCARD_CONNECT; if (get_message(&code, msg, &bytes) != 0) { LLOGLN(0, ("SCardConnect: error, get_message")); return SCARD_F_INTERNAL_ERROR; } if (code != SCARD_CONNECT) { LLOGLN(0, ("SCardConnect: error, bad code")); return SCARD_F_INTERNAL_ERROR; } *phCard = GET_UINT32(msg, 0); *pdwActiveProtocol = GET_UINT32(msg, 4); status = GET_UINT32(msg, 8); LLOGLN(10, ("SCardConnect: got status 0x%8.8x hCard 0x%8.8x " "dwActiveProtocol %d", status, (int)*phCard, (int)*pdwActiveProtocol)); return status; } /*****************************************************************************/ PCSC_API LONG SCardReconnect(SCARDHANDLE hCard, DWORD dwShareMode, DWORD dwPreferredProtocols, DWORD dwInitialization, LPDWORD pdwActiveProtocol) { LLOGLN(0, ("SCardReconnect:")); if (g_sck == -1) { LLOGLN(0, ("SCardReconnect: error, not connected")); return SCARD_F_INTERNAL_ERROR; } return SCARD_S_SUCCESS; } /*****************************************************************************/ PCSC_API LONG SCardDisconnect(SCARDHANDLE hCard, DWORD dwDisposition) { char msg[256]; int code; int bytes; int status; LLOGLN(10, ("SCardDisconnect: hCard 0x%8.8x dwDisposition %d", (int)hCard, (int)dwDisposition)); if (g_sck == -1) { LLOGLN(0, ("SCardDisconnect: error, not connected")); return SCARD_F_INTERNAL_ERROR; } SET_UINT32(msg, 0, hCard); SET_UINT32(msg, 4, dwDisposition); if (send_message(SCARD_DISCONNECT, msg, 8) != 0) { LLOGLN(0, ("SCardDisconnect: error, send_message")); return SCARD_F_INTERNAL_ERROR; } bytes = 256; code = SCARD_DISCONNECT; if (get_message(&code, msg, &bytes) != 0) { LLOGLN(0, ("SCardDisconnect: error, get_message")); return SCARD_F_INTERNAL_ERROR; } if ((code != SCARD_DISCONNECT) || (bytes != 4)) { LLOGLN(0, ("SCardDisconnect: error, bad code")); return SCARD_F_INTERNAL_ERROR; } status = GET_UINT32(msg, 0); LLOGLN(10, ("SCardDisconnect: got status 0x%8.8x", status)); return status; } /*****************************************************************************/ PCSC_API LONG SCardBeginTransaction(SCARDHANDLE hCard) { char msg[256]; int code; int bytes; int status; LLOGLN(10, ("SCardBeginTransaction: hCard 0x%8.8x", (int)hCard)); if (hCard == 0) { LLOGLN(0, ("SCardBeginTransaction: error, bad hCard")); return SCARD_F_INTERNAL_ERROR; } if (g_sck == -1) { LLOGLN(0, ("SCardBeginTransaction: error, not connected")); return SCARD_F_INTERNAL_ERROR; } SET_UINT32(msg, 0, hCard); if (send_message(SCARD_BEGIN_TRANSACTION, msg, 4) != 0) { LLOGLN(0, ("SCardBeginTransaction: error, send_message")); return SCARD_F_INTERNAL_ERROR; } bytes = 256; code = SCARD_BEGIN_TRANSACTION; if (get_message(&code, msg, &bytes) != 0) { LLOGLN(0, ("SCardBeginTransaction: error, get_message")); return SCARD_F_INTERNAL_ERROR; } if ((code != SCARD_BEGIN_TRANSACTION) || (bytes != 4)) { LLOGLN(0, ("SCardBeginTransaction: error, bad code")); return SCARD_F_INTERNAL_ERROR; } status = GET_UINT32(msg, 0); LLOGLN(10, ("SCardBeginTransaction: got status 0x%8.8x", status)); return status; } /*****************************************************************************/ PCSC_API LONG SCardEndTransaction(SCARDHANDLE hCard, DWORD dwDisposition) { char msg[256]; int code; int bytes; int status; LLOGLN(10, ("SCardEndTransaction:")); if (g_sck == -1) { LLOGLN(0, ("SCardEndTransaction: error, not connected")); return SCARD_F_INTERNAL_ERROR; } SET_UINT32(msg, 0, hCard); SET_UINT32(msg, 4, dwDisposition); if (send_message(SCARD_END_TRANSACTION, msg, 8) != 0) { LLOGLN(0, ("SCardEndTransaction: error, send_message")); return SCARD_F_INTERNAL_ERROR; } bytes = 256; code = SCARD_END_TRANSACTION; if (get_message(&code, msg, &bytes) != 0) { LLOGLN(0, ("SCardEndTransaction: error, get_message")); return SCARD_F_INTERNAL_ERROR; } if ((code != SCARD_END_TRANSACTION) || (bytes != 4)) { LLOGLN(0, ("SCardEndTransaction: error, bad code")); return SCARD_F_INTERNAL_ERROR; } status = GET_UINT32(msg, 0); LLOGLN(10, ("SCardEndTransaction: got status 0x%8.8x", status)); return status; } /*****************************************************************************/ PCSC_API LONG SCardStatus(SCARDHANDLE hCard, LPSTR mszReaderName, LPDWORD pcchReaderLen, LPDWORD pdwState, LPDWORD pdwProtocol, LPBYTE pbAtr, LPDWORD pcbAtrLen) { char *msg; int code; int bytes; int status; int offset; int cchReaderLen; int to_copy; LLOGLN(10, ("SCardStatus:")); if (hCard == 0) { LLOGLN(10, ("SCardStatus: error, bad hCard")); return SCARD_F_INTERNAL_ERROR; } if (g_sck == -1) { LLOGLN(0, ("SCardStatus: error, not connected")); return SCARD_F_INTERNAL_ERROR; } LLOGLN(10, (" hCard 0x%8.8x", (int)hCard)); LLOGLN(10, (" cchReaderLen %d", (int)*pcchReaderLen)); LLOGLN(10, (" cbAtrLen %d", (int)*pcbAtrLen)); cchReaderLen = *pcchReaderLen; msg = (char *) malloc(8192); SET_UINT32(msg, 0, hCard); SET_UINT32(msg, 4, cchReaderLen); SET_UINT32(msg, 8, *pcbAtrLen); if (send_message(SCARD_STATUS, msg, 12) != 0) { LLOGLN(0, ("SCardStatus: error, send_message")); free(msg); return SCARD_F_INTERNAL_ERROR; } bytes = 8192; code = SCARD_STATUS; if (get_message(&code, msg, &bytes) != 0) { LLOGLN(0, ("SCardStatus: error, get_message")); free(msg); return SCARD_F_INTERNAL_ERROR; } if (code != SCARD_STATUS) { LLOGLN(0, ("SCardStatus: error, bad code")); free(msg); return SCARD_F_INTERNAL_ERROR; } LLOGLN(10, ("SCardStatus: cchReaderLen in %d", (int)*pcchReaderLen)); offset = 0; *pcchReaderLen = GET_UINT32(msg, offset); LLOGLN(10, ("SCardStatus: cchReaderLen out %d", (int)*pcchReaderLen)); offset += 4; if (cchReaderLen > 0) { to_copy = cchReaderLen - 1; if (*pcchReaderLen < to_copy) { to_copy = *pcchReaderLen; } memcpy(mszReaderName, msg + offset, to_copy); mszReaderName[to_copy] = 0; } LLOGLN(10, ("SCardStatus: mszReaderName out %s", mszReaderName)); offset += *pcchReaderLen; *pdwState = GET_UINT32(msg, offset); if (*pdwState == 1) { *pdwState = 0x34; } LLOGLN(10, ("SCardStatus: dwState %d", (int)*pdwState)); offset += 4; *pdwProtocol = GET_UINT32(msg, offset); LLOGLN(10, ("SCardStatus: dwProtocol %d", (int)*pdwProtocol)); offset += 4; *pcbAtrLen = GET_UINT32(msg, offset); offset += 4; LLOGLN(10, ("SCardStatus: cbAtrLen %d", (int)*pcbAtrLen)); memcpy(pbAtr, msg + offset, *pcbAtrLen); offset += *pcbAtrLen; status = GET_UINT32(msg, offset); LLOGLN(10, ("SCardStatus: status %d", status)); offset += 4; free(msg); return status; } /*****************************************************************************/ PCSC_API LONG SCardGetStatusChange(SCARDCONTEXT hContext, DWORD dwTimeout, LPSCARD_READERSTATE rgReaderStates, DWORD cReaders) { char *msg; const char *rname; int bytes; int code; int index; int offset; int str_len; int status; int dwCurrentState; int dwEventState; int cbAtr; char atr[36]; LLOGLN(10, ("SCardGetStatusChange:")); LLOGLN(10, (" dwTimeout %d cReaders %d", (int)dwTimeout, (int)cReaders)); if (g_sck == -1) { LLOGLN(0, ("SCardGetStatusChange: error, not connected")); return SCARD_F_INTERNAL_ERROR; } msg = (char *) malloc(8192); SET_UINT32(msg, 0, hContext); SET_UINT32(msg, 4, dwTimeout); SET_UINT32(msg, 8, cReaders); offset = 12; for (index = 0; index < cReaders; index++) { rgReaderStates[index].dwCurrentState &= ~2; rgReaderStates[index].dwEventState &= ~2; rname = rgReaderStates[index].szReader; if (strcmp(rname, "\\\\?PnP?\\Notification") == 0) { LLOGLN(10, (" \\\\?PnP?\\Notification present")); dwCurrentState = 0; dwEventState = 0; cbAtr = 0; memset(atr, 0, 36); } else { dwCurrentState = rgReaderStates[index].dwCurrentState; dwEventState = rgReaderStates[index].dwEventState; cbAtr = rgReaderStates[index].cbAtr; memset(atr, 0, 36); memcpy(atr, rgReaderStates[index].rgbAtr, 33); } str_len = strlen(rname); str_len = LMIN(str_len, 99); memset(msg + offset, 0, 100); memcpy(msg + offset, rname, str_len); LLOGLN(10, (" in szReader %s", rname)); offset += 100; LLOGLN(10, (" in dwCurrentState 0x%8.8x", dwCurrentState)); SET_UINT32(msg, offset, dwCurrentState); offset += 4; LLOGLN(10, (" in dwEventState 0x%8.8x", dwEventState)); SET_UINT32(msg, offset, dwEventState); offset += 4; LLOGLN(10, (" in cbAtr %d", cbAtr)); SET_UINT32(msg, offset, cbAtr); offset += 4; memcpy(msg + offset, atr, 36); offset += 36; } if (send_message(SCARD_GET_STATUS_CHANGE, msg, offset) != 0) { LLOGLN(0, ("SCardGetStatusChange: error, send_message")); free(msg); return SCARD_F_INTERNAL_ERROR; } bytes = 8192; code = SCARD_GET_STATUS_CHANGE; if (get_message(&code, msg, &bytes) != 0) { LLOGLN(0, ("SCardGetStatusChange: error, get_message")); free(msg); return SCARD_F_INTERNAL_ERROR; } if (code != SCARD_GET_STATUS_CHANGE) { LLOGLN(0, ("SCardGetStatusChange: error, bad code")); free(msg); return SCARD_F_INTERNAL_ERROR; } cReaders = GET_UINT32(msg, 0); offset = 4; LLOGLN(10, ("SCardGetStatusChange: got back cReaders %d", (int)cReaders)); for (index = 0; index < cReaders; index++) { rname = rgReaderStates[index].szReader; #if 1 if (strcmp(rname, "\\\\?PnP?\\Notification") == 0) { LLOGLN(10, (" out szReader %s", rgReaderStates[index].szReader)); dwCurrentState = GET_UINT32(msg, offset); rgReaderStates[index].dwCurrentState = dwCurrentState; offset += 4; LLOGLN(10, (" out dwCurrentState 0x%8.8x", dwCurrentState)); // disable PnP for now dwEventState = 4; // GET_UINT32(msg, offset); rgReaderStates[index].dwEventState = dwEventState; offset += 4; LLOGLN(10, (" out dwEventState 0x%8.8x", dwEventState)); cbAtr = GET_UINT32(msg, offset); rgReaderStates[index].cbAtr = cbAtr; offset += 4; LLOGLN(10, (" out cbAtr %d", cbAtr)); memcpy(rgReaderStates[index].rgbAtr, msg + offset, 33); offset += 36; } else #endif { LLOGLN(10, (" out szReader %s", rgReaderStates[index].szReader)); dwCurrentState = GET_UINT32(msg, offset); rgReaderStates[index].dwCurrentState = dwCurrentState; offset += 4; LLOGLN(10, (" out dwCurrentState 0x%8.8x", dwCurrentState)); dwEventState = GET_UINT32(msg, offset); rgReaderStates[index].dwEventState = dwEventState; offset += 4; LLOGLN(10, (" out dwEventState 0x%8.8x", dwEventState)); cbAtr = GET_UINT32(msg, offset); rgReaderStates[index].cbAtr = cbAtr; offset += 4; LLOGLN(10, (" out cbAtr %d", cbAtr)); memcpy(rgReaderStates[index].rgbAtr, msg + offset, 33); offset += 36; } } status = GET_UINT32(msg, offset); offset += 4; free(msg); return status; } /*****************************************************************************/ PCSC_API LONG SCardControl(SCARDHANDLE hCard, DWORD dwControlCode, LPCVOID pbSendBuffer, DWORD cbSendLength, LPVOID pbRecvBuffer, DWORD cbRecvLength, LPDWORD lpBytesReturned) { char *msg; int bytes; int code; int offset; int status = 0; LLOGLN(10, ("SCardControl:")); if (g_sck == -1) { LLOGLN(0, ("SCardControl: error, not connected")); return SCARD_F_INTERNAL_ERROR; } LLOGLN(10, (" hCard 0x%8.8x", (int)hCard)); LLOGLN(10, (" dwControlCode 0x%8.8x", (int)dwControlCode)); LLOGLN(10, (" cbSendLength %d", (int)cbSendLength)); LLOGLN(10, (" cbRecvLength %d", (int)cbRecvLength)); /* #define SCARD_CTL_CODE(code) (0x42000000 + (code)) control_code = (control_code & 0x3ffc) >> 2; control_code = SCARD_CTL_CODE(control_code); */ /* PCSC to Windows control code conversion */ dwControlCode = dwControlCode - 0x42000000; dwControlCode = dwControlCode << 2; dwControlCode = dwControlCode | (49 << 16); LLOGLN(10, (" MS dwControlCode 0x%8.8d", (int)dwControlCode)); msg = (char *) malloc(8192); offset = 0; SET_UINT32(msg, offset, hCard); offset += 4; SET_UINT32(msg, offset, dwControlCode); offset += 4; SET_UINT32(msg, offset, cbSendLength); offset += 4; memcpy(msg + offset, pbSendBuffer, cbSendLength); offset += cbSendLength; SET_UINT32(msg, offset, cbRecvLength); offset += 4; if (send_message(SCARD_CONTROL, msg, offset) != 0) { LLOGLN(0, ("SCardControl: error, send_message")); free(msg); return SCARD_F_INTERNAL_ERROR; } bytes = 8192; code = SCARD_CONTROL; if (get_message(&code, msg, &bytes) != 0) { LLOGLN(0, ("SCardControl: error, get_message")); free(msg); return SCARD_F_INTERNAL_ERROR; } if (code != SCARD_CONTROL) { LLOGLN(0, ("SCardControl: error, bad code")); free(msg); return SCARD_F_INTERNAL_ERROR; } offset = 0; *lpBytesReturned = GET_UINT32(msg, offset); LLOGLN(10, (" cbRecvLength %d", (int)*lpBytesReturned)); offset += 4; memcpy(pbRecvBuffer, msg + offset, *lpBytesReturned); offset += *lpBytesReturned; status = GET_UINT32(msg, offset); free(msg); return status; } /*****************************************************************************/ PCSC_API LONG SCardTransmit(SCARDHANDLE hCard, const SCARD_IO_REQUEST *pioSendPci, LPCBYTE pbSendBuffer, DWORD cbSendLength, SCARD_IO_REQUEST *pioRecvPci, LPBYTE pbRecvBuffer, LPDWORD pcbRecvLength) { char *msg; int bytes; int code; int offset; int status; int extra_len; int got_recv_pci; LLOGLN(10, ("SCardTransmit:")); if (g_sck == -1) { LLOGLN(0, ("SCardTransmit: error, not connected")); return SCARD_F_INTERNAL_ERROR; } LLOGLN(10, (" hCard 0x%8.8x", (int)hCard)); LLOGLN(10, (" cbSendLength %d", (int)cbSendLength)); LLOGLN(10, (" cbRecvLength %d", (int)*pcbRecvLength)); LLOGLN(10, (" pioSendPci->dwProtocol %d", (int)(pioSendPci->dwProtocol))); LLOGLN(10, (" pioSendPci->cbPciLength %d", (int)(pioSendPci->cbPciLength))); LLOGLN(10, (" pioRecvPci %p", pioRecvPci)); if (pioRecvPci != 0) { LLOGLN(10, (" pioRecvPci->dwProtocol %d", (int)(pioRecvPci->dwProtocol))); LLOGLN(10, (" pioRecvPci->cbPciLength %d", (int)(pioRecvPci->cbPciLength))); } msg = (char *) malloc(8192); offset = 0; SET_UINT32(msg, offset, hCard); offset += 4; SET_UINT32(msg, offset, pioSendPci->dwProtocol); offset += 4; /* SET_UINT32(msg, offset, pioSendPci->cbPciLength); */ SET_UINT32(msg, offset, 8); offset += 4; /* extra_len = pioSendPci->cbPciLength - 8; */ extra_len = 0; SET_UINT32(msg, offset, extra_len); offset += 4; memcpy(msg + offset, pioSendPci + 1, extra_len); offset += extra_len; SET_UINT32(msg, offset, cbSendLength); offset += 4; memcpy(msg + offset, pbSendBuffer, cbSendLength); offset += cbSendLength; // TODO figure out why recv pci does not work if (1 || (pioRecvPci == 0) || (pioRecvPci->cbPciLength < 8)) { got_recv_pci = 0; SET_UINT32(msg, offset, 0); /* dwProtocol */ offset += 4; SET_UINT32(msg, offset, 0); /* cbPciLength */ offset += 4; SET_UINT32(msg, offset, 0); /* extra_len */ offset += 4; } else { got_recv_pci = 1; SET_UINT32(msg, offset, pioRecvPci->dwProtocol); offset += 4; SET_UINT32(msg, offset, pioRecvPci->cbPciLength); offset += 4; extra_len = pioRecvPci->cbPciLength - 8; SET_UINT32(msg, offset, extra_len); offset += 4; memcpy(msg + offset, pioRecvPci + 1, extra_len); offset += extra_len; } SET_UINT32(msg, offset, *pcbRecvLength); offset += 4; if (send_message(SCARD_TRANSMIT, msg, offset) != 0) { LLOGLN(0, ("SCardTransmit: error, send_message")); free(msg); return SCARD_F_INTERNAL_ERROR; } bytes = 8192; code = SCARD_TRANSMIT; if (get_message(&code, msg, &bytes) != 0) { LLOGLN(0, ("SCardTransmit: error, get_message")); free(msg); return SCARD_F_INTERNAL_ERROR; } if (code != SCARD_TRANSMIT) { LLOGLN(0, ("SCardTransmit: error, bad code")); free(msg); return SCARD_F_INTERNAL_ERROR; } offset = 0; if (got_recv_pci == 0) { offset += 8; extra_len = GET_UINT32(msg, offset); offset += 4; offset += extra_len; } else { pioRecvPci->dwProtocol = GET_UINT32(msg, offset); offset += 4; pioRecvPci->cbPciLength = GET_UINT32(msg, offset); offset += 4; extra_len = GET_UINT32(msg, offset); offset += 4; offset += extra_len; } *pcbRecvLength = GET_UINT32(msg, offset); offset += 4; LLOGLN(10, (" cbRecvLength %d", (int)*pcbRecvLength)); memcpy(pbRecvBuffer, msg + offset, *pcbRecvLength); LHEXDUMP(10, (pbRecvBuffer, *pcbRecvLength)); offset += *pcbRecvLength; status = GET_UINT32(msg, offset); free(msg); return status; } /*****************************************************************************/ PCSC_API LONG SCardListReaderGroups(SCARDCONTEXT hContext, LPSTR mszGroups, LPDWORD pcchGroups) { LLOGLN(10, ("SCardListReaderGroups:")); if (g_sck == -1) { LLOGLN(0, ("SCardListReaderGroups: error, not connected")); return SCARD_F_INTERNAL_ERROR; } return SCARD_S_SUCCESS; } /*****************************************************************************/ PCSC_API LONG SCardListReaders(SCARDCONTEXT hContext, LPCSTR mszGroups, LPSTR mszReaders, LPDWORD pcchReaders) { char* msg; char* reader_names; int reader_names_index; int code; int bytes; int num_readers; int status; int offset; int index; int bytes_groups; int val; int llen; char reader[100]; LLOGLN(10, ("SCardListReaders:")); LLOGLN(10, ("SCardListReaders: mszGroups %s", mszGroups)); LLOGLN(10, ("SCardListReaders: *pcchReaders %d", (int)*pcchReaders)); if (g_sck == -1) { LLOGLN(0, ("SCardListReaders: error, not connected")); return SCARD_F_INTERNAL_ERROR; } if ((mszGroups == NULL) && (mszReaders == NULL)) { *pcchReaders = 0; } msg = (char *) malloc(8192); offset = 0; SET_UINT32(msg, offset, hContext); offset += 4; bytes_groups = 0; if (mszGroups != 0) { bytes_groups = strlen(mszGroups); } SET_UINT32(msg, offset, bytes_groups); offset += 4; memcpy(msg + offset, mszGroups, bytes_groups); offset += bytes_groups; val = *pcchReaders; SET_UINT32(msg, offset, val); offset += 4; if (send_message(SCARD_LIST_READERS, msg, offset) != 0) { LLOGLN(0, ("SCardListReaders: error, send_message")); free(msg); return SCARD_F_INTERNAL_ERROR; } bytes = 8192; code = SCARD_LIST_READERS; if (get_message(&code, msg, &bytes) != 0) { LLOGLN(0, ("SCardListReaders: error, get_message")); free(msg); return SCARD_F_INTERNAL_ERROR; } if (code != SCARD_LIST_READERS) { LLOGLN(0, ("SCardListReaders: error, bad code")); free(msg); return SCARD_F_INTERNAL_ERROR; } offset = 0; llen = GET_UINT32(msg, offset); offset += 4; num_readers = GET_UINT32(msg, offset); offset += 4; LLOGLN(10, ("SCardListReaders: mszReaders %p pcchReaders %p num_readers %d", mszReaders, pcchReaders, num_readers)); reader_names = (char *) malloc(8192); reader_names_index = 0; for (index = 0; index < num_readers; index++) { memcpy(reader, msg + offset, 100); bytes = strlen(reader); memcpy(reader_names + reader_names_index, reader, bytes); reader_names_index += bytes; reader_names[reader_names_index] = 0; reader_names_index++; offset += 100; LLOGLN(10, ("SCardListReaders: readername %s", reader)); } reader_names[reader_names_index] = 0; reader_names_index++; status = GET_UINT32(msg, offset); LLOGLN(10, ("SCardListReaders: status 0x%8.8x", status)); offset += 4; if (mszReaders == 0) { reader_names_index = llen / 2; } if (pcchReaders != 0) { *pcchReaders = reader_names_index; } if (mszReaders != 0) { memcpy(mszReaders, reader_names, reader_names_index); } free(msg); free(reader_names); return status; } /*****************************************************************************/ PCSC_API LONG SCardFreeMemory(SCARDCONTEXT hContext, LPCVOID pvMem) { LLOGLN(0, ("SCardFreeMemory:")); if (g_sck == -1) { LLOGLN(0, ("SCardFreeMemory: error, not connected")); return SCARD_F_INTERNAL_ERROR; } return SCARD_S_SUCCESS; } /*****************************************************************************/ PCSC_API LONG SCardCancel(SCARDCONTEXT hContext) { char msg[256]; int code; int bytes; int status; LLOGLN(10, ("SCardCancel:")); if (g_sck == -1) { LLOGLN(0, ("SCardCancel: error, not connected")); return SCARD_F_INTERNAL_ERROR; } SET_UINT32(msg, 0, hContext); if (send_message(SCARD_CANCEL, msg, 4) != 0) { LLOGLN(0, ("SCardCancel: error, send_message")); return SCARD_F_INTERNAL_ERROR; } bytes = 256; code = SCARD_CANCEL; if (get_message(&code, msg, &bytes) != 0) { LLOGLN(0, ("SCardCancel: error, get_message")); return SCARD_F_INTERNAL_ERROR; } if ((code != SCARD_RELEASE_CONTEXT) || (bytes != 4)) { LLOGLN(0, ("SCardCancel: error, bad code")); return SCARD_F_INTERNAL_ERROR; } status = GET_UINT32(msg, 0); LLOGLN(10, ("SCardCancel: got status 0x%8.8x", status)); return status; } /*****************************************************************************/ PCSC_API LONG SCardGetAttrib(SCARDHANDLE hCard, DWORD dwAttrId, LPBYTE pbAttr, LPDWORD pcbAttrLen) { LLOGLN(0, ("SCardGetAttrib:")); if (g_sck == -1) { LLOGLN(0, ("SCardGetAttrib: error, not connected")); return SCARD_F_INTERNAL_ERROR; } return SCARD_S_SUCCESS; } /*****************************************************************************/ PCSC_API LONG SCardSetAttrib(SCARDHANDLE hCard, DWORD dwAttrId, LPCBYTE pbAttr, DWORD cbAttrLen) { LLOGLN(0, ("SCardSetAttrib:")); if (g_sck == -1) { LLOGLN(0, ("SCardSetAttrib: error, not connected")); return SCARD_F_INTERNAL_ERROR; } return SCARD_S_SUCCESS; } /*****************************************************************************/ PCSC_API char * pcsc_stringify_error(const long code) { LLOGLN(10, ("pcsc_stringify_error: 0x%8.8x", (int)code)); switch (code) { case SCARD_S_SUCCESS: snprintf(g_error_str, 511, "Command successful."); break; case SCARD_F_INTERNAL_ERROR: snprintf(g_error_str, 511, "Internal error."); break; default: snprintf(g_error_str, 511, "error 0x%8.8x", (int)code); break; } g_error_str[511] = 0; return g_error_str; } xrdp-0.9.5/sesman/chansrv/pcsc/wrapper/000755 001751 001751 00000000000 13133557325 017773 5ustar00metameta000000 000000 xrdp-0.9.5/sesman/chansrv/pcsc/.gitignore000644 001751 001751 00000000012 13127114621 020263 0ustar00metameta000000 000000 !Makefile xrdp-0.9.5/sesman/chansrv/pcsc/Makefile000644 001751 001751 00000000266 13125122133 017741 0ustar00metameta000000 000000 OBJS = xrdp_pcsc.o CFLAGS = -Wall -O2 -fPIC all: libpcsclite.so libpcsclite.so: $(OBJS) $(CC) $(LDFLAGS) -shared -o libpcsclite.so $(OBJS) clean: rm -f $(OBJS) libpcsclite.so xrdp-0.9.5/sesman/chansrv/pcsc/dumps/000755 001751 001751 00000000000 13125122134 017426 5ustar00metameta000000 000000 xrdp-0.9.5/sesman/chansrv/pcsc/dumps/scard-end-tranaction.txt000644 001751 001751 00000004127 13125122133 024172 0ustar00metameta000000 000000 TS_SCardEndTransaction: 0000 03 00 00 93 02 f0 80 68 00 01 03 ed f0 80 84 08 .......h........ 0010 00 00 00 51 1c 06 7b 0a 94 e3 7f 70 00 00 00 03 ...Q..{....p.... 0020 00 00 00 72 44 52 49 00 00 00 00 01 00 00 00 02 ...rDRI......... 0030 00 00 00 0e 00 00 00 00 00 00 00 00 08 00 00 38 ...............8 0040 00 00 00 c0 00 09 00 00 00 00 00 00 00 00 00 00 ................ 0050 00 00 00 00 00 00 00 00 00 00 00 01 10 08 00 cc ................ 0060 cc cc cc 28 00 00 00 00 00 00 00 04 00 00 00 00 ...(............ 0070 00 02 00 04 00 00 00 04 00 02 00 00 00 00 00 04 ................ 0080 00 00 00 09 00 00 00 04 00 00 00 0a 00 00 00 00 ................ 0090 00 00 00 ... TS_SCardEndTransaction: 0000 03 00 00 93 02 f0 80 68 00 01 03 ed f0 80 84 08 .......h........ 0010 00 00 00 51 1c 06 7b 0a 94 e3 7f 70 00 00 00 03 ...Q..{....p.... 0020 00 00 00 72 44 52 49 00 00 00 00 01 00 00 00 02 ...rDRI......... 0030 00 00 00 0e 00 00 00 00 00 00 00 00 08 00 00 38 ...............8 0040 00 00 00 c0 00 09 00 00 00 00 00 00 00 00 00 00 ................ 0050 00 00 00 00 00 00 00 00 00 00 00 01 10 08 00 cc ................ 0060 cc cc cc 28 00 00 00 00 00 00 00 04 00 00 00 00 ...(............ 0070 00 02 00 04 00 00 00 04 00 02 00 00 00 00 00 04 ................ 0080 00 00 00 09 00 00 00 04 00 00 00 0a 00 00 00 00 ................ 0090 00 00 00 ... TS_SCardEndTransaction: 0000 03 00 00 93 02 f0 80 68 00 01 03 ed f0 80 84 08 .......h........ 0010 00 00 00 fe 1c ea fb 2e a3 58 a6 70 00 00 00 03 .........X.p.... 0020 00 00 00 72 44 52 49 00 00 00 00 01 00 00 00 03 ...rDRI......... 0030 00 00 00 0e 00 00 00 00 00 00 00 00 08 00 00 38 ...............8 0040 00 00 00 c0 00 09 00 00 00 00 00 00 00 00 00 00 ................ 0050 00 00 00 00 00 00 00 00 00 00 00 01 10 08 00 cc ................ 0060 cc cc cc 28 00 00 00 00 00 00 00 04 00 00 00 00 ...(............ 0070 00 02 00 04 00 00 00 04 00 02 00 00 00 00 00 04 ................ 0080 00 00 00 09 00 00 00 04 00 00 00 0a 00 00 00 00 ................ 0090 00 00 00 ... xrdp-0.9.5/sesman/chansrv/pcsc/dumps/scard-control.txt000644 001751 001751 00000007437 13125122133 022753 0ustar00metameta000000 000000 TS_SCardControl: 0000 03 00 00 a3 02 f0 80 68 00 01 03 ed f0 80 94 08 .......h........ 0010 00 00 00 05 18 7c 3e ca 9f 03 76 80 00 00 00 03 .....|>...v..... 0020 00 00 00 72 44 52 49 00 00 00 00 01 00 00 00 00 ...rDRI......... 0030 00 00 00 0e 00 00 00 00 00 00 00 00 08 00 00 48 ...............H 0040 00 00 00 d4 00 09 00 00 00 00 00 00 00 00 00 00 ................ 0050 00 00 00 00 00 00 00 00 00 00 00 01 10 08 00 cc ................ 0060 cc cc cc 38 00 00 00 00 00 00 00 04 00 00 00 00 ...8............ 0070 00 02 00 04 00 00 00 04 00 02 00 20 35 31 00 00 ........... 51.. 0080 00 00 00 00 00 00 00 00 00 00 00 c8 00 00 00 04 ................ 0090 00 00 00 05 00 00 00 04 00 00 00 06 00 00 00 00 ................ 00a0 00 00 00 ... TS_SCardControl: 0000 03 00 00 a3 02 f0 80 68 00 01 03 ed f0 80 94 08 .......h........ 0010 00 00 00 99 4c 06 de f1 41 78 64 80 00 00 00 03 ....L...Axd..... 0020 00 00 00 72 44 52 49 00 00 00 00 01 00 00 00 01 ...rDRI......... 0030 00 00 00 0e 00 00 00 00 00 00 00 00 08 00 00 48 ...............H 0040 00 00 00 d4 00 09 00 00 00 00 00 00 00 00 00 00 ................ 0050 00 00 00 00 00 00 00 00 00 00 00 01 10 08 00 cc ................ 0060 cc cc cc 38 00 00 00 00 00 00 00 04 00 00 00 00 ...8............ 0070 00 02 00 04 00 00 00 04 00 02 00 20 35 31 00 00 ........... 51.. 0080 00 00 00 00 00 00 00 00 00 00 00 c8 00 00 00 04 ................ 0090 00 00 00 05 00 00 00 04 00 00 00 06 00 00 00 00 ................ 00a0 00 00 00 ... TS_SCardControl: 0000 03 00 00 a3 02 f0 80 68 00 01 03 ed f0 80 94 08 .......h........ 0010 00 00 00 05 18 7c 3e ca 9f 03 76 80 00 00 00 03 .....|>...v..... 0020 00 00 00 72 44 52 49 00 00 00 00 01 00 00 00 00 ...rDRI......... 0030 00 00 00 0e 00 00 00 00 00 00 00 00 08 00 00 48 ...............H 0040 00 00 00 d4 00 09 00 00 00 00 00 00 00 00 00 00 ................ 0050 00 00 00 00 00 00 00 00 00 00 00 01 10 08 00 cc ................ 0060 cc cc cc 38 00 00 00 00 00 00 00 04 00 00 00 00 ...8............ 0070 00 02 00 04 00 00 00 04 00 02 00 20 35 31 00 00 ........... 51.. 0080 00 00 00 00 00 00 00 00 00 00 00 c8 00 00 00 04 ................ 0090 00 00 00 05 00 00 00 04 00 00 00 06 00 00 00 00 ................ 00a0 00 00 00 ... TS_SCardControl: 0000 03 00 00 a3 02 f0 80 68 00 01 03 ed f0 80 94 08 .......h........ 0010 00 00 00 99 4c 06 de f1 41 78 64 80 00 00 00 03 ....L...Axd..... 0020 00 00 00 72 44 52 49 00 00 00 00 01 00 00 00 01 ...rDRI......... 0030 00 00 00 0e 00 00 00 00 00 00 00 00 08 00 00 48 ...............H 0040 00 00 00 d4 00 09 00 00 00 00 00 00 00 00 00 00 ................ 0050 00 00 00 00 00 00 00 00 00 00 00 01 10 08 00 cc ................ 0060 cc cc cc 38 00 00 00 00 00 00 00 04 00 00 00 00 ...8............ 0070 00 02 00 04 00 00 00 04 00 02 00 20 35 31 00 00 ........... 51.. 0080 00 00 00 00 00 00 00 00 00 00 00 c8 00 00 00 04 ................ 0090 00 00 00 05 00 00 00 04 00 00 00 06 00 00 00 00 ................ 00a0 00 00 00 ... TS_SCardControl: 0000 03 00 00 a3 02 f0 80 68 00 01 03 ed f0 80 94 08 .......h........ 0010 00 00 00 87 62 bd 62 13 81 8a d6 80 00 00 00 03 ....b.b......... 0020 00 00 00 72 44 52 49 00 00 00 00 01 00 00 00 01 ...rDRI......... 0030 00 00 00 0e 00 00 00 00 00 00 00 00 08 00 00 48 ...............H 0040 00 00 00 d4 00 09 00 00 00 00 00 00 00 00 00 00 ................ 0050 00 00 00 00 00 00 00 00 00 00 00 01 10 08 00 cc ................ 0060 cc cc cc 38 00 00 00 00 00 00 00 04 00 00 00 00 ...8............ 0070 00 02 00 04 00 00 00 04 00 02 00 20 35 31 00 00 ........... 51.. 0080 00 00 00 00 00 00 00 00 00 00 00 02 01 00 00 04 ................ 0090 00 00 00 07 00 00 00 04 00 00 00 0b 00 00 00 00 ................ 00a0 00 00 00 ... xrdp-0.9.5/sesman/chansrv/pcsc/dumps/scard-status.txt000644 001751 001751 00000017216 13125122134 022613 0ustar00metameta000000 000000 TS_SCardStatus: 0000 03 00 00 9b 02 f0 80 68 00 01 03 ed f0 80 8c 08 .......h........ 0010 00 00 00 0e 8b f9 50 1f 35 28 35 78 00 00 00 03 ......P.5(5x.... 0020 00 00 00 72 44 52 49 00 00 00 00 01 00 00 00 00 ...rDRI......... 0030 00 00 00 0e 00 00 00 00 00 00 00 00 08 00 00 40 ...............@ 0040 00 00 00 cc 00 09 00 00 00 00 00 00 00 00 00 00 ................ 0050 00 00 00 00 00 00 00 00 00 00 00 01 10 08 00 cc ................ 0060 cc cc cc 30 00 00 00 00 00 00 00 04 00 00 00 00 ...0............ 0070 00 02 00 04 00 00 00 04 00 02 00 00 00 00 00 ff ................ 0080 ff ff ff 20 00 00 00 04 00 00 00 05 00 00 00 04 ... ............ 0090 00 00 00 06 00 00 00 00 00 00 00 ........... TS_SCardStatus: 0000 03 00 00 9b 02 f0 80 68 00 01 03 ed f0 80 8c 08 .......h........ 0010 00 00 00 0e 8b f9 50 1f 35 28 35 78 00 00 00 03 ......P.5(5x.... 0020 00 00 00 72 44 52 49 00 00 00 00 01 00 00 00 00 ...rDRI......... 0030 00 00 00 0e 00 00 00 00 00 00 00 00 08 00 00 40 ...............@ 0040 00 00 00 cc 00 09 00 00 00 00 00 00 00 00 00 00 ................ 0050 00 00 00 00 00 00 00 00 00 00 00 01 10 08 00 cc ................ 0060 cc cc cc 30 00 00 00 00 00 00 00 04 00 00 00 00 ...0............ 0070 00 02 00 04 00 00 00 04 00 02 00 00 00 00 00 ff ................ 0080 ff ff ff 20 00 00 00 04 00 00 00 05 00 00 00 04 ... ............ 0090 00 00 00 06 00 00 00 00 00 00 00 ........... TS_SCardStatus: 0000 03 00 00 9b 02 f0 80 68 00 01 03 ed f0 80 8c 08 .......h........ 0010 00 00 00 88 05 07 8b 2a 3c f5 16 78 00 00 00 03 .......*<..x.... 0020 00 00 00 72 44 52 49 00 00 00 00 01 00 00 00 01 ...rDRI......... 0030 00 00 00 0e 00 00 00 00 00 00 00 00 08 00 00 40 ...............@ 0040 00 00 00 cc 00 09 00 00 00 00 00 00 00 00 00 00 ................ 0050 00 00 00 00 00 00 00 00 00 00 00 01 10 08 00 cc ................ 0060 cc cc cc 30 00 00 00 00 00 00 00 04 00 00 00 00 ...0............ 0070 00 02 00 04 00 00 00 04 00 02 00 00 00 00 00 ff ................ 0080 ff ff ff 20 00 00 00 04 00 00 00 05 00 00 00 04 ... ............ 0090 00 00 00 06 00 00 00 00 00 00 00 ........... TS_SCardStatus: 0000 03 00 00 9b 02 f0 80 68 00 01 03 ed f0 80 8c 08 .......h........ 0010 00 00 00 3b cf 96 d8 27 3f cd 9f 78 00 00 00 03 ...;...'?..x.... 0020 00 00 00 72 44 52 49 00 00 00 00 01 00 00 00 01 ...rDRI......... 0030 00 00 00 0e 00 00 00 00 00 00 00 00 08 00 00 40 ...............@ 0040 00 00 00 c8 00 09 00 00 00 00 00 00 00 00 00 00 ................ 0050 00 00 00 00 00 00 00 00 00 00 00 01 10 08 00 cc ................ 0060 cc cc cc 30 00 00 00 00 00 00 00 04 00 00 00 00 ...0............ 0070 00 02 00 04 00 00 00 04 00 02 00 01 00 00 00 00 ................ 0080 00 00 00 40 00 00 00 04 00 00 00 07 00 00 00 04 ...@............ 0090 00 00 00 09 00 00 00 00 00 00 00 ........... TS_SCardStatus: 0000 03 00 00 9b 02 f0 80 68 00 01 03 ed f0 80 8c 08 .......h........ 0010 00 00 00 a3 8c 93 16 6c 49 59 23 78 00 00 00 03 .......lIY#x.... 0020 00 00 00 72 44 52 49 00 00 00 00 01 00 00 00 02 ...rDRI......... 0030 00 00 00 0e 00 00 00 00 00 00 00 00 08 00 00 40 ...............@ 0040 00 00 00 c8 00 09 00 00 00 00 00 00 00 00 00 00 ................ 0050 00 00 00 00 00 00 00 00 00 00 00 01 10 08 00 cc ................ 0060 cc cc cc 30 00 00 00 00 00 00 00 04 00 00 00 00 ...0............ 0070 00 02 00 04 00 00 00 04 00 02 00 01 00 00 00 00 ................ 0080 00 00 00 40 00 00 00 04 00 00 00 07 00 00 00 04 ...@............ 0090 00 00 00 09 00 00 00 00 00 00 00 ........... TS_SCardStatus: 0000 03 00 00 9b 02 f0 80 68 00 01 03 ed f0 80 8c 08 .......h........ 0010 00 00 00 6d d0 36 aa 65 50 4c 88 78 00 00 00 03 ...m.6.ePL.x.... 0020 00 00 00 72 44 52 49 00 00 00 00 01 00 00 00 03 ...rDRI......... 0030 00 00 00 0e 00 00 00 00 00 00 00 00 08 00 00 40 ...............@ 0040 00 00 00 c8 00 09 00 00 00 00 00 00 00 00 00 00 ................ 0050 00 00 00 00 00 00 00 00 00 00 00 01 10 08 00 cc ................ 0060 cc cc cc 30 00 00 00 00 00 00 00 04 00 00 00 00 ...0............ 0070 00 02 00 04 00 00 00 04 00 02 00 01 00 00 00 00 ................ 0080 00 00 00 40 00 00 00 04 00 00 00 07 00 00 00 04 ...@............ 0090 00 00 00 09 00 00 00 00 00 00 00 ........... TS_SCardStatus: 0000 03 00 00 9b 02 f0 80 68 00 01 03 ed f0 80 8c 08 .......h........ 0010 00 00 00 a3 8c 93 16 6c 49 59 23 78 00 00 00 03 .......lIY#x.... 0020 00 00 00 72 44 52 49 00 00 00 00 01 00 00 00 02 ...rDRI......... 0030 00 00 00 0e 00 00 00 00 00 00 00 00 08 00 00 40 ...............@ 0040 00 00 00 c8 00 09 00 00 00 00 00 00 00 00 00 00 ................ 0050 00 00 00 00 00 00 00 00 00 00 00 01 10 08 00 cc ................ 0060 cc cc cc 30 00 00 00 00 00 00 00 04 00 00 00 00 ...0............ 0070 00 02 00 04 00 00 00 04 00 02 00 01 00 00 00 00 ................ 0080 00 00 00 40 00 00 00 04 00 00 00 07 00 00 00 04 ...@............ 0090 00 00 00 09 00 00 00 00 00 00 00 ........... TS_SCardStatus: 0000 03 00 00 9b 02 f0 80 68 00 01 03 ed f0 80 8c 08 .......h........ 0010 00 00 00 6d d0 36 aa 65 50 4c 88 78 00 00 00 03 ...m.6.ePL.x.... 0020 00 00 00 72 44 52 49 00 00 00 00 01 00 00 00 03 ...rDRI......... 0030 00 00 00 0e 00 00 00 00 00 00 00 00 08 00 00 40 ...............@ 0040 00 00 00 c8 00 09 00 00 00 00 00 00 00 00 00 00 ................ 0050 00 00 00 00 00 00 00 00 00 00 00 01 10 08 00 cc ................ 0060 cc cc cc 30 00 00 00 00 00 00 00 04 00 00 00 00 ...0............ 0070 00 02 00 04 00 00 00 04 00 02 00 01 00 00 00 00 ................ 0080 00 00 00 40 00 00 00 04 00 00 00 07 00 00 00 04 ...@............ 0090 00 00 00 09 00 00 00 00 00 00 00 ........... TS_SCardStatus: 0000 03 00 00 9b 02 f0 80 68 00 01 03 ed f0 80 8c 08 .......h........ 0010 00 00 00 6d d0 36 aa 65 50 4c 88 78 00 00 00 03 ...m.6.ePL.x.... 0020 00 00 00 72 44 52 49 00 00 00 00 01 00 00 00 03 ...rDRI......... 0030 00 00 00 0e 00 00 00 00 00 00 00 00 08 00 00 40 ...............@ 0040 00 00 00 c8 00 09 00 00 00 00 00 00 00 00 00 00 ................ 0050 00 00 00 00 00 00 00 00 00 00 00 01 10 08 00 cc ................ 0060 cc cc cc 30 00 00 00 00 00 00 00 04 00 00 00 00 ...0............ 0070 00 02 00 04 00 00 00 04 00 02 00 01 00 00 00 00 ................ 0080 00 00 00 40 00 00 00 04 00 00 00 07 00 00 00 04 ...@............ 0090 00 00 00 09 00 00 00 00 00 00 00 ........... TS_SCardStatus: 0000 03 00 00 9b 02 f0 80 68 00 01 03 ed f0 80 8c 08 .......h........ 0010 00 00 00 a3 8c 93 16 6c 49 59 23 78 00 00 00 03 .......lIY#x.... 0020 00 00 00 72 44 52 49 00 00 00 00 01 00 00 00 02 ...rDRI......... 0030 00 00 00 0e 00 00 00 00 00 00 00 00 08 00 00 40 ...............@ 0040 00 00 00 c8 00 09 00 00 00 00 00 00 00 00 00 00 ................ 0050 00 00 00 00 00 00 00 00 00 00 00 01 10 08 00 cc ................ 0060 cc cc cc 30 00 00 00 00 00 00 00 04 00 00 00 00 ...0............ 0070 00 02 00 04 00 00 00 04 00 02 00 01 00 00 00 00 ................ 0080 00 00 00 40 00 00 00 04 00 00 00 07 00 00 00 04 ...@............ 0090 00 00 00 09 00 00 00 00 00 00 00 ........... TS_SCardStatus: 0000 03 00 00 9b 02 f0 80 68 00 01 03 ed f0 80 8c 08 .......h........ 0010 00 00 00 6d d0 36 aa 65 50 4c 88 78 00 00 00 03 ...m.6.ePL.x.... 0020 00 00 00 72 44 52 49 00 00 00 00 01 00 00 00 03 ...rDRI......... 0030 00 00 00 0e 00 00 00 00 00 00 00 00 08 00 00 40 ...............@ 0040 00 00 00 c8 00 09 00 00 00 00 00 00 00 00 00 00 ................ 0050 00 00 00 00 00 00 00 00 00 00 00 01 10 08 00 cc ................ 0060 cc cc cc 30 00 00 00 00 00 00 00 04 00 00 00 00 ...0............ 0070 00 02 00 04 00 00 00 04 00 02 00 01 00 00 00 00 ................ 0080 00 00 00 40 00 00 00 04 00 00 00 07 00 00 00 04 ...@............ 0090 00 00 00 09 00 00 00 00 00 00 00 ........... xrdp-0.9.5/sesman/chansrv/pcsc/dumps/scard-begin-tranaction.txt000644 001751 001751 00000001312 13125122133 024501 0ustar00metameta000000 000000 TS_SCardBeginTransaction: 0000 03 00 00 93 02 f0 80 68 00 01 03 ed f0 80 84 08 .......h........ 0010 00 00 00 de 14 5c 5a 9e 86 37 2b 70 00 00 00 03 .....\Z..7+p.... 0020 00 00 00 72 44 52 49 00 00 00 00 01 00 00 00 02 ...rDRI......... 0030 00 00 00 0e 00 00 00 00 00 00 00 00 08 00 00 38 ...............8 0040 00 00 00 bc 00 09 00 00 00 00 00 00 00 00 00 00 ................ 0050 00 00 00 00 00 00 00 00 00 00 00 01 10 08 00 cc ................ 0060 cc cc cc 28 00 00 00 00 00 00 00 04 00 00 00 00 ...(............ 0070 00 02 00 04 00 00 00 04 00 02 00 00 00 00 00 04 ................ 0080 00 00 00 02 00 00 00 04 00 00 00 0a 00 00 00 00 ................ 0090 00 00 00 ... xrdp-0.9.5/sesman/chansrv/pcsc/dumps/scard-list-readers.txt000644 001751 001751 00000013535 13125122134 023666 0ustar00metameta000000 000000 TS_SCardListReaders: 0000 03 00 00 b3 02 f0 80 68 00 01 03 ed f0 80 a4 08 .......h........ 0010 00 00 00 07 b5 7d d1 ba 7c 7e e9 90 00 00 00 03 .....}..|~...... 0020 00 00 00 72 44 52 49 00 00 00 00 01 00 00 00 00 ...rDRI......... 0030 00 00 00 0e 00 00 00 00 00 00 00 00 08 00 00 58 ...............X 0040 00 00 00 2c 00 09 00 00 00 00 00 00 00 00 00 00 ...,............ 0050 00 00 00 00 00 00 00 00 00 00 00 01 10 08 00 cc ................ 0060 cc cc cc 48 00 00 00 00 00 00 00 04 00 00 00 00 ...H............ 0070 00 02 00 24 00 00 00 04 00 02 00 00 00 00 00 ff ...$............ 0080 ff ff ff 04 00 00 00 01 00 00 00 24 00 00 00 53 ...........$...S 0090 00 43 00 61 00 72 00 64 00 24 00 41 00 6c 00 6c .C.a.r.d.$.A.l.l 00a0 00 52 00 65 00 61 00 64 00 65 00 72 00 73 00 00 .R.e.a.d.e.r.s.. 00b0 00 00 00 ... TS_SCardListReaders: 0000 03 00 00 8a 02 f0 80 68 00 01 03 ed f0 7c 08 00 .......h.....|.. 0010 00 00 ae 89 33 c1 0d 6b e2 bb 68 00 00 00 03 00 ....3..k..h..... 0020 00 00 72 44 52 49 00 00 00 00 01 00 00 00 01 00 ..rDRI.......... 0030 00 00 0e 00 00 00 00 00 00 00 00 08 00 00 30 00 ..............0. 0040 00 00 28 00 09 00 00 00 00 00 00 00 00 00 00 00 ..(............. 0050 00 00 00 00 00 00 00 00 00 00 01 10 08 00 cc cc ................ 0060 cc cc 20 00 00 00 00 00 00 00 04 00 00 00 00 00 .. ............. 0070 02 00 00 00 00 00 00 00 00 00 00 00 00 00 00 04 ................ 0080 00 00 04 00 00 00 02 00 00 00 .......... TS_SCardListReaders: 0000 03 00 00 8a 02 f0 80 68 00 01 03 ed f0 7c 08 00 .......h.....|.. 0010 00 00 ef be 3f 08 43 ae 89 9b 68 00 00 00 03 00 ....?.C...h..... 0020 00 00 72 44 52 49 00 00 00 00 01 00 00 00 02 00 ..rDRI.......... 0030 00 00 0e 00 00 00 00 00 00 00 00 08 00 00 30 00 ..............0. 0040 00 00 28 00 09 00 00 00 00 00 00 00 00 00 00 00 ..(............. 0050 00 00 00 00 00 00 00 00 00 00 01 10 08 00 cc cc ................ 0060 cc cc 20 00 00 00 00 00 00 00 04 00 00 00 00 00 .. ............. 0070 02 00 00 00 00 00 00 00 00 00 00 00 00 00 00 04 ................ 0080 00 00 04 00 00 00 02 00 00 00 .......... TS_SCardListReaders: 0000 03 00 00 8a 02 f0 80 68 00 01 03 ed f0 7c 08 00 .......h.....|.. 0010 00 00 ae 89 33 c1 0d 6b e2 bb 68 00 00 00 03 00 ....3..k..h..... 0020 00 00 72 44 52 49 00 00 00 00 01 00 00 00 01 00 ..rDRI.......... 0030 00 00 0e 00 00 00 00 00 00 00 00 08 00 00 30 00 ..............0. 0040 00 00 28 00 09 00 00 00 00 00 00 00 00 00 00 00 ..(............. 0050 00 00 00 00 00 00 00 00 00 00 01 10 08 00 cc cc ................ 0060 cc cc 20 00 00 00 00 00 00 00 04 00 00 00 00 00 .. ............. 0070 02 00 00 00 00 00 00 00 00 00 00 00 00 00 00 04 ................ 0080 00 00 04 00 00 00 02 00 00 00 .......... TS_SCardListReaders: 0000 03 00 00 8a 02 f0 80 68 00 01 03 ed f0 7c 08 00 .......h.....|.. 0010 00 00 ae 89 33 c1 0d 6b e2 bb 68 00 00 00 03 00 ....3..k..h..... 0020 00 00 72 44 52 49 00 00 00 00 01 00 00 00 01 00 ..rDRI.......... 0030 00 00 0e 00 00 00 00 00 00 00 00 08 00 00 30 00 ..............0. 0040 00 00 28 00 09 00 00 00 00 00 00 00 00 00 00 00 ..(............. 0050 00 00 00 00 00 00 00 00 00 00 01 10 08 00 cc cc ................ 0060 cc cc 20 00 00 00 00 00 00 00 04 00 00 00 00 00 .. ............. 0070 02 00 00 00 00 00 00 00 00 00 00 00 00 00 00 04 ................ 0080 00 00 04 00 00 00 02 00 00 00 .......... TS_SCardListReaders: 0000 03 00 00 8a 02 f0 80 68 00 01 03 ed f0 7c 08 00 .......h.....|.. 0010 00 00 ae 89 33 c1 0d 6b e2 bb 68 00 00 00 03 00 ....3..k..h..... 0020 00 00 72 44 52 49 00 00 00 00 01 00 00 00 01 00 ..rDRI.......... 0030 00 00 0e 00 00 00 00 00 00 00 00 08 00 00 30 00 ..............0. 0040 00 00 28 00 09 00 00 00 00 00 00 00 00 00 00 00 ..(............. 0050 00 00 00 00 00 00 00 00 00 00 01 10 08 00 cc cc ................ 0060 cc cc 20 00 00 00 00 00 00 00 04 00 00 00 00 00 .. ............. 0070 02 00 00 00 00 00 00 00 00 00 00 00 00 00 00 04 ................ 0080 00 00 04 00 00 00 02 00 00 00 .......... TS_SCardListReaders: 0000 03 00 00 8a 02 f0 80 68 00 01 03 ed f0 7c 08 00 .......h.....|.. 0010 00 00 78 0a 67 31 92 fc d0 29 68 00 00 00 03 00 ..x.g1...)h..... 0020 00 00 72 44 52 49 00 00 00 00 01 00 00 00 03 00 ..rDRI.......... 0030 00 00 0e 00 00 00 00 00 00 00 00 08 00 00 30 00 ..............0. 0040 00 00 28 00 09 00 00 00 00 00 00 00 00 00 00 00 ..(............. 0050 00 00 00 00 00 00 00 00 00 00 01 10 08 00 cc cc ................ 0060 cc cc 20 00 00 00 00 00 00 00 04 00 00 00 00 00 .. ............. 0070 02 00 00 00 00 00 00 00 00 00 00 00 00 00 00 04 ................ 0080 00 00 04 00 00 00 02 00 00 00 .......... TS_SCardListReaders: 0000 03 00 00 8a 02 f0 80 68 00 01 03 ed f0 7c 08 00 .......h.....|.. 0010 00 00 ae 89 33 c1 0d 6b e2 bb 68 00 00 00 03 00 ....3..k..h..... 0020 00 00 72 44 52 49 00 00 00 00 01 00 00 00 01 00 ..rDRI.......... 0030 00 00 0e 00 00 00 00 00 00 00 00 08 00 00 30 00 ..............0. 0040 00 00 28 00 09 00 00 00 00 00 00 00 00 00 00 00 ..(............. 0050 00 00 00 00 00 00 00 00 00 00 01 10 08 00 cc cc ................ 0060 cc cc 20 00 00 00 00 00 00 00 04 00 00 00 00 00 .. ............. 0070 02 00 00 00 00 00 00 00 00 00 00 00 00 00 00 04 ................ 0080 00 00 04 00 00 00 02 00 00 00 .......... TS_SCardListReaders: 0000 03 00 00 8a 02 f0 80 68 00 01 03 ed f0 7c 08 00 .......h.....|.. 0010 00 00 ae 89 33 c1 0d 6b e2 bb 68 00 00 00 03 00 ....3..k..h..... 0020 00 00 72 44 52 49 00 00 00 00 01 00 00 00 01 00 ..rDRI.......... 0030 00 00 0e 00 00 00 00 00 00 00 00 08 00 00 30 00 ..............0. 0040 00 00 28 00 09 00 00 00 00 00 00 00 00 00 00 00 ..(............. 0050 00 00 00 00 00 00 00 00 00 00 01 10 08 00 cc cc ................ 0060 cc cc 20 00 00 00 00 00 00 00 04 00 00 00 00 00 .. ............. 0070 02 00 00 00 00 00 00 00 00 00 00 00 00 00 00 04 ................ 0080 00 00 04 00 00 00 02 00 00 00 xrdp-0.9.5/sesman/chansrv/pcsc/dumps/scard-disconnect.txt000644 001751 001751 00000002610 13125122133 023410 0ustar00metameta000000 000000 TS_SCardDisconnect: 0000 03 00 00 93 02 f0 80 68 00 01 03 ed f0 80 84 08 .......h........ 0010 00 00 00 87 b4 3a 7f a4 2a 6d ad 70 00 00 00 03 .....:..*m.p.... 0020 00 00 00 72 44 52 49 00 00 00 00 01 00 00 00 00 ...rDRI......... 0030 00 00 00 0e 00 00 00 00 00 00 00 00 08 00 00 38 ...............8 0040 00 00 00 b8 00 09 00 00 00 00 00 00 00 00 00 00 ................ 0050 00 00 00 00 00 00 00 00 00 00 00 01 10 08 00 cc ................ 0060 cc cc cc 28 00 00 00 00 00 00 00 04 00 00 00 00 ...(............ 0070 00 02 00 04 00 00 00 04 00 02 00 00 00 00 00 04 ................ 0080 00 00 00 03 00 00 00 04 00 00 00 04 00 00 00 00 ................ 0090 00 00 00 ... TS_SCardDisconnect: 0000 03 00 00 93 02 f0 80 68 00 01 03 ed f0 80 84 08 .......h........ 0010 00 00 00 72 7f fb 24 4e b1 36 c8 70 00 00 00 03 ...r..$N.6.p.... 0020 00 00 00 72 44 52 49 00 00 00 00 01 00 00 00 01 ...rDRI......... 0030 00 00 00 0e 00 00 00 00 00 00 00 00 08 00 00 38 ...............8 0040 00 00 00 b8 00 09 00 00 00 00 00 00 00 00 00 00 ................ 0050 00 00 00 00 00 00 00 00 00 00 00 01 10 08 00 cc ................ 0060 cc cc cc 28 00 00 00 00 00 00 00 04 00 00 00 00 ...(............ 0070 00 02 00 04 00 00 00 04 00 02 00 00 00 00 00 04 ................ 0080 00 00 00 04 00 00 00 04 00 00 00 05 00 00 00 00 ................ 0090 00 00 00 ... xrdp-0.9.5/sesman/chansrv/pcsc/dumps/scard-release-context.txt000644 001751 001751 00000001053 13125122134 024362 0ustar00metameta000000 000000 0000 03 00 00 7a 02 f0 80 68 00 01 03 ed f0 6c 08 00 ...z...h.....l.. 0010 00 00 c9 9d 01 9e ec 30 a3 4c 58 00 00 00 03 00 .......0.LX..... 0020 00 00 72 44 52 49 00 00 00 00 01 00 00 00 01 00 ..rDRI.......... 0030 00 00 0e 00 00 00 00 00 00 00 00 08 00 00 20 00 .............. . 0040 00 00 18 00 09 00 00 00 00 00 00 00 00 00 00 00 ................ 0050 00 00 00 00 00 00 00 00 00 00 01 10 08 00 cc cc ................ 0060 cc cc 10 00 00 00 00 00 00 00 04 00 00 00 00 00 ................ 0070 02 00 04 00 00 00 02 00 00 00 .......... xrdp-0.9.5/sesman/chansrv/pcsc/dumps/scard-get-status-change.txt000644 001751 001751 00000003137 13125122134 024610 0ustar00metameta000000 000000 TS_SCardGetStatusChange: 0000 03 00 01 6b 02 f0 80 68 00 01 03 ed f0 81 5c 08 ...k...h......\. 0010 00 00 00 bf 53 5b 23 43 71 9b 2b 48 01 00 00 03 ....S[#Cq.+H.... 0020 00 00 00 72 44 52 49 00 00 00 00 01 00 00 00 00 ...rDRI......... 0030 00 00 00 0e 00 00 00 00 00 00 00 00 08 00 00 10 ................ 0040 01 00 00 a4 00 09 00 00 00 00 00 00 00 00 00 00 ................ 0050 00 00 00 00 00 00 00 00 00 00 00 01 10 08 00 cc ................ 0060 cc cc cc 00 01 00 00 00 00 00 00 04 00 00 00 00 ................ 0070 00 02 00 ff ff ff ff 02 00 00 00 04 00 02 00 04 ................ 0080 00 00 00 01 00 00 00 02 00 00 00 08 00 02 00 00 ................ 0090 00 01 00 00 00 00 00 00 00 00 00 00 00 00 00 00 ................ 00a0 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 ................ 00b0 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 0c ................ 00c0 00 02 00 10 00 00 00 00 00 00 00 00 00 00 00 00 ................ 00d0 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 ................ 00e0 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 ................ 00f0 00 00 00 15 00 00 00 00 00 00 00 15 00 00 00 5c ...............\ 0100 00 5c 00 3f 00 50 00 6e 00 50 00 3f 00 5c 00 4e .\.?.P.n.P.?.\.N 0110 00 6f 00 74 00 69 00 66 00 69 00 63 00 61 00 74 .o.t.i.f.i.c.a.t 0120 00 69 00 6f 00 6e 00 00 00 00 00 19 00 00 00 00 .i.o.n.......... 0130 00 00 00 19 00 00 00 47 00 65 00 6d 00 70 00 6c .......G.e.m.p.l 0140 00 75 00 73 00 20 00 47 00 65 00 6d 00 50 00 43 .u.s. .G.e.m.P.C 0150 00 20 00 54 00 77 00 69 00 6e 00 20 00 30 00 30 . .T.w.i.n. .0.0 0160 00 20 00 30 00 30 00 00 00 00 00 . .0.0..... xrdp-0.9.5/sesman/chansrv/pcsc/dumps/scard-transmit.txt000644 001751 001751 00000003722 13125122134 023126 0ustar00metameta000000 000000 TS_SCardTransmit: 0000 01 10 08 00 cc cc cc cc 58 00 00 00 00 00 00 00 ........X....... 0010 04 00 00 00 00 00 02 00 04 00 00 00 04 00 02 00 ................ 0020 01 00 00 00 00 00 00 00 00 00 00 00 07 00 00 00 ................ 0030 08 00 02 00 0c 00 02 00 00 00 00 00 02 01 00 00 ................ 0040 04 00 00 00 05 00 00 00 04 00 00 00 0b 00 00 00 ................ 0050 07 00 00 00 00 a4 02 0c 02 ef 0f 00 01 00 00 00 ................ 0060 00 00 00 00 00 00 00 00 ........ TS_SCardTransmit: 0000 01 10 08 00 cc cc cc cc 58 00 00 00 00 00 00 00 ........X....... 0010 04 00 00 00 00 00 02 00 04 00 00 00 04 00 02 00 ................ 0020 01 00 00 00 00 00 00 00 00 00 00 00 05 00 00 00 ................ 0030 08 00 02 00 0c 00 02 00 00 00 00 00 02 01 00 00 ................ 0040 04 00 00 00 05 00 00 00 04 00 00 00 0b 00 00 00 ................ 0050 05 00 00 00 00 b0 07 5b 10 00 00 00 01 00 00 00 .......[........ 0060 00 00 00 00 00 00 00 00 ........ TS_SCardTransmit: 0000 01 10 08 00 cc cc cc cc 58 00 00 00 00 00 00 00 ........X....... 0010 04 00 00 00 00 00 02 00 04 00 00 00 04 00 02 00 ................ 0020 01 00 00 00 00 00 00 00 00 00 00 00 07 00 00 00 ................ 0030 08 00 02 00 0c 00 02 00 00 00 00 00 02 01 00 00 ................ 0040 04 00 00 00 05 00 00 00 04 00 00 00 0b 00 00 00 ................ 0050 07 00 00 00 00 a4 02 0c 02 ef 10 00 01 00 00 00 ................ 0060 00 00 00 00 00 00 00 00 ........ TS_SCardTransmit: 0000 01 10 08 00 cc cc cc cc 58 00 00 00 00 00 00 00 ........X....... 0010 04 00 00 00 00 00 02 00 04 00 00 00 04 00 02 00 ................ 0020 01 00 00 00 00 00 00 00 00 00 00 00 05 00 00 00 ................ 0030 08 00 02 00 0c 00 02 00 00 00 00 00 02 01 00 00 ................ 0040 04 00 00 00 05 00 00 00 04 00 00 00 0b 00 00 00 ................ 0050 05 00 00 00 00 b0 07 04 10 00 00 00 01 00 00 00 ................ 0060 00 00 00 00 00 00 00 00 ........ xrdp-0.9.5/sesman/chansrv/pcsc/dumps/scard-connect.txt000644 001751 001751 00000003466 13125122133 022722 0ustar00metameta000000 000000 TS_SCardConnect: 0000 03 00 00 cb 02 f0 80 68 00 01 03 ed f0 80 bc 08 .......h........ 0010 00 00 00 7b 28 f8 7e 5c c8 16 e8 a8 00 00 00 03 ...{(.~\........ 0020 00 00 00 72 44 52 49 00 00 00 00 01 00 00 00 01 ...rDRI......... 0030 00 00 00 0e 00 00 00 00 00 00 00 00 08 00 00 70 ...............p 0040 00 00 00 b0 00 09 00 00 00 00 00 00 00 00 00 00 ................ 0050 00 00 00 00 00 00 00 00 00 00 00 01 10 08 00 cc ................ 0060 cc cc cc 60 00 00 00 00 00 00 00 00 00 02 00 04 ...`............ 0070 00 00 00 04 00 02 00 02 00 00 00 03 00 00 00 19 ................ 0080 00 00 00 00 00 00 00 19 00 00 00 47 00 65 00 6d ...........G.e.m 0090 00 70 00 6c 00 75 00 73 00 20 00 47 00 65 00 6d .p.l.u.s. .G.e.m 00a0 00 50 00 43 00 20 00 54 00 77 00 69 00 6e 00 20 .P.C. .T.w.i.n. 00b0 00 30 00 30 00 20 00 30 00 30 00 00 00 00 00 04 .0.0. .0.0...... 00c0 00 00 00 01 00 00 00 00 00 00 00 ........... TS_SCardConnect: 0000 03 00 00 cb 02 f0 80 68 00 01 03 ed f0 80 bc 08 .......h........ 0010 00 00 00 7b 28 f8 7e 5c c8 16 e8 a8 00 00 00 03 ...{(.~\........ 0020 00 00 00 72 44 52 49 00 00 00 00 01 00 00 00 01 ...rDRI......... 0030 00 00 00 0e 00 00 00 00 00 00 00 00 08 00 00 70 ...............p 0040 00 00 00 b0 00 09 00 00 00 00 00 00 00 00 00 00 ................ 0050 00 00 00 00 00 00 00 00 00 00 00 01 10 08 00 cc ................ 0060 cc cc cc 60 00 00 00 00 00 00 00 00 00 02 00 04 ...`............ 0070 00 00 00 04 00 02 00 02 00 00 00 03 00 00 00 19 ................ 0080 00 00 00 00 00 00 00 19 00 00 00 47 00 65 00 6d ...........G.e.m 0090 00 70 00 6c 00 75 00 73 00 20 00 47 00 65 00 6d .p.l.u.s. .G.e.m 00a0 00 50 00 43 00 20 00 54 00 77 00 69 00 6e 00 20 .P.C. .T.w.i.n. 00b0 00 30 00 30 00 20 00 30 00 30 00 00 00 00 00 04 .0.0. .0.0...... 00c0 00 00 00 01 00 00 00 00 00 00 00 ........... xrdp-0.9.5/sesman/chansrv/pcsc/dumps/scard-establish-context.txt000644 001751 001751 00000002171 13125122134 024722 0ustar00metameta000000 000000 TS_SCardEstablishContext: 0000 03 00 00 72 02 f0 80 68 00 01 03 ed f0 64 08 00 ...r...h.....d.. 0010 00 00 a7 8d 52 74 fd 96 bc b4 50 00 00 00 03 00 ....Rt....P..... 0020 00 00 72 44 52 49 00 00 00 00 01 00 00 00 00 00 ..rDRI.......... 0030 00 00 0e 00 00 00 00 00 00 00 00 08 00 00 18 00 ................ 0040 00 00 14 00 09 00 00 00 00 00 00 00 00 00 00 00 ................ 0050 00 00 00 00 00 00 00 00 00 00 01 10 08 00 cc cc ................ 0060 cc cc 08 00 00 00 00 00 00 00 02 00 00 00 00 00 ................ 0070 00 00 .. TS_SCardEstablishContext: 0000 03 00 00 72 02 f0 80 68 00 01 03 ed f0 64 08 00 ...r...h.....d.. 0010 00 00 51 f7 43 00 73 65 44 53 50 00 00 00 03 00 ..Q.C.seDSP..... 0020 00 00 72 44 52 49 00 00 00 00 01 00 00 00 00 00 ..rDRI.......... 0030 00 00 0e 00 00 00 00 00 00 00 00 08 00 00 18 00 ................ 0040 00 00 14 00 09 00 00 00 00 00 00 00 00 00 00 00 ................ 0050 00 00 00 00 00 00 00 00 00 00 01 10 08 00 cc cc ................ 0060 cc cc 08 00 00 00 00 00 00 00 00 00 00 00 00 00 ................ 0070 00 00 .. xrdp-0.9.5/sesman/chansrv/pcsc/wrapper/Makefile000755 001751 001751 00000000232 13125122134 021416 0ustar00metameta000000 000000 CC=bcc32.exe CFLAGS=-O2 OBJS=winscard.obj winscard.dll: $(OBJS) $(CC) -ewinscard.dll -tWD $(OBJS) clean: -del winscard.dll -del *.obj -del *.tds xrdp-0.9.5/sesman/chansrv/pcsc/wrapper/winscard-funcs.h000755 001751 001751 00000017516 13133557325 023107 0ustar00metameta000000 000000 #ifndef _WINSCARD_FUNCS_H #define _WINSCARD_FUNCS_H typedef LONG WINAPI (*tSCardEstablishContext)(DWORD dwScope, LPCVOID pvReserved1, LPCVOID pvReserved2, LPSCARDCONTEXT phContext); typedef LONG WINAPI (*tSCardReleaseContext)(SCARDCONTEXT hContext); typedef LONG WINAPI (*tSCardIsValidContext)(SCARDCONTEXT hContext); typedef LONG WINAPI (*tSCardListReaderGroupsA)(SCARDCONTEXT hContext, LPSTR mszGroups, LPDWORD pcchGroups); typedef LONG WINAPI (*tSCardListReaderGroupsW)(SCARDCONTEXT hContext, LPWSTR mszGroups, LPDWORD pcchGroups); typedef LONG WINAPI (*tSCardListReadersA)(SCARDCONTEXT hContext, LPCSTR mszGroups, LPSTR mszReaders, LPDWORD pcchReaders); typedef LONG WINAPI (*tSCardListReadersW)(SCARDCONTEXT hContext, LPCWSTR mszGroups, LPWSTR mszReaders, LPDWORD pcchReaders); typedef LONG WINAPI (*tSCardListCardsA)(SCARDCONTEXT hContext, LPCBYTE pbAtr, LPCGUID rgquidInterfaces, DWORD cguidInterfaceCount, LPSTR mszCards, LPDWORD pcchCards); typedef LONG WINAPI (*tSCardListCardsW)(SCARDCONTEXT hContext, LPCBYTE pbAtr, LPCGUID rgquidInterfaces, DWORD cguidInterfaceCount, LPWSTR mszCards, LPDWORD pcchCards); typedef LONG WINAPI (*tSCardListInterfacesA)(SCARDCONTEXT hContext, LPCSTR szCard, LPGUID pguidInterfaces, LPDWORD pcguidInterfaces); typedef LONG WINAPI (*tSCardListInterfacesW)(SCARDCONTEXT hContext, LPCWSTR szCard, LPGUID pguidInterfaces, LPDWORD pcguidInterfaces); typedef LONG WINAPI (*tSCardGetProviderIdA)(SCARDCONTEXT hContext, LPCSTR szCard, LPGUID pguidProviderId); typedef LONG WINAPI (*tSCardGetProviderIdW)(SCARDCONTEXT hContext, LPCWSTR szCard, LPGUID pguidProviderId); typedef LONG WINAPI (*tSCardGetCardTypeProviderNameA)(SCARDCONTEXT hContext, LPCSTR szCardName, DWORD dwProviderId, LPSTR szProvider, LPDWORD pcchProvider); typedef LONG WINAPI (*tSCardGetCardTypeProviderNameW)(SCARDCONTEXT hContext, LPCWSTR szCardName, DWORD dwProviderId, LPWSTR szProvider, LPDWORD pcchProvider); typedef LONG WINAPI (*tSCardIntroduceReaderGroupA)(SCARDCONTEXT hContext, LPCSTR szGroupName); typedef LONG WINAPI (*tSCardIntroduceReaderGroupW)(SCARDCONTEXT hContext, LPCWSTR szGroupName); typedef LONG WINAPI (*tSCardForgetReaderGroupA)(SCARDCONTEXT hContext, LPCSTR szGroupName); typedef LONG WINAPI (*tSCardForgetReaderGroupW)(SCARDCONTEXT hContext, LPCWSTR szGroupName); typedef LONG WINAPI (*tSCardIntroduceReaderA)(SCARDCONTEXT hContext, LPCSTR szReaderName, LPCSTR szDeviceName); typedef LONG WINAPI (*tSCardIntroduceReaderW)(SCARDCONTEXT hContext, LPCWSTR szReaderName, LPCWSTR szDeviceName); typedef LONG WINAPI (*tSCardForgetReaderA)(SCARDCONTEXT hContext, LPCSTR szReaderName); typedef LONG WINAPI (*tSCardForgetReaderW)(SCARDCONTEXT hContext, LPCWSTR szReaderName); typedef LONG WINAPI (*tSCardAddReaderToGroupA)(SCARDCONTEXT hContext, LPCSTR szReaderName, LPCSTR szGroupName); typedef LONG WINAPI (*tSCardAddReaderToGroupW)(SCARDCONTEXT hContext, LPCWSTR szReaderName, LPCWSTR szGroupName); typedef LONG WINAPI (*tSCardRemoveReaderFromGroupA)(SCARDCONTEXT hContext, LPCSTR szReaderName, LPCSTR szGroupName); typedef LONG WINAPI (*tSCardRemoveReaderFromGroupW)(SCARDCONTEXT hContext, LPCWSTR szReaderName, LPCWSTR szGroupName); typedef LONG WINAPI (*tSCardIntroduceCardTypeA)(SCARDCONTEXT hContext, LPCSTR szCardName, LPCGUID pguidPrimaryProvider, LPCGUID rgguidInterfaces, DWORD dwInterfaceCount, LPCBYTE pbAtr, LPCBYTE pbAtrMask, DWORD cbAtrLen); typedef LONG WINAPI (*tSCardIntroduceCardTypeW)(SCARDCONTEXT hContext, LPCWSTR szCardName, LPCGUID pguidPrimaryProvider, LPCGUID rgguidInterfaces, DWORD dwInterfaceCount, LPCBYTE pbAtr, LPCBYTE pbAtrMask, DWORD cbAtrLen); typedef LONG WINAPI (*tSCardSetCardTypeProviderNameA)(SCARDCONTEXT hContext, LPCSTR szCardName, DWORD dwProviderId, LPCSTR szProvider); typedef LONG WINAPI (*tSCardSetCardTypeProviderNameW)(SCARDCONTEXT hContext, LPCWSTR szCardName, DWORD dwProviderId, LPCWSTR szProvider); typedef LONG WINAPI (*tSCardForgetCardTypeA)(SCARDCONTEXT hContext, LPCSTR szCardName); typedef LONG WINAPI (*tSCardForgetCardTypeW)(SCARDCONTEXT hContext, LPCWSTR szCardName); typedef LONG WINAPI (*tSCardFreeMemory)(SCARDCONTEXT hContext, LPCVOID pvMem); typedef LONG WINAPI (*tSCardLocateCardsA)(SCARDCONTEXT hContext, LPCSTR mszCards, LPSCARD_READERSTATEA rgReaderStates, DWORD cReaders); typedef LONG WINAPI (*tSCardLocateCardsW)(SCARDCONTEXT hContext, LPCWSTR mszCards, LPSCARD_READERSTATEW rgReaderStates, DWORD cReaders); typedef LONG WINAPI (*tSCardGetStatusChangeA)(SCARDCONTEXT hContext, DWORD dwTimeout, LPSCARD_READERSTATEA rgReaderStates, DWORD cReaders); typedef LONG WINAPI (*tSCardGetStatusChangeW)(SCARDCONTEXT hContext, DWORD dwTimeout, LPSCARD_READERSTATEW rgReaderStates, DWORD cReaders); typedef LONG WINAPI (*tSCardCancel)(SCARDCONTEXT hContext); typedef LONG WINAPI (*tSCardConnectA)(SCARDCONTEXT hContext, LPCSTR szReader, DWORD dwShareMode, DWORD dwPreferredProtocols, LPSCARDHANDLE phCard, LPDWORD pdwActiveProtocol); typedef LONG WINAPI (*tSCardConnectW)(SCARDCONTEXT hContext, LPCWSTR szReader, DWORD dwShareMode, DWORD dwPreferredProtocols, LPSCARDHANDLE phCard, LPDWORD pdwActiveProtocol); typedef LONG WINAPI (*tSCardReconnect)(SCARDHANDLE hCard, DWORD dwShareMode, DWORD dwPreferredProtocols, DWORD dwInitialization, LPDWORD pdwActiveProtocol); typedef LONG WINAPI (*tSCardDisconnect)(SCARDHANDLE hCard, DWORD dwDisposition); typedef LONG WINAPI (*tSCardBeginTransaction)(SCARDHANDLE hCard); typedef LONG WINAPI (*tSCardEndTransaction)(SCARDHANDLE hCard, DWORD dwDisposition); typedef LONG WINAPI (*tSCardCancelTransaction)(SCARDHANDLE hCard); typedef LONG WINAPI (*tSCardState)(SCARDHANDLE hCard, LPDWORD pdwState, LPDWORD pdwProtocol, LPBYTE pbAtr, LPDWORD pcbAtrLen); typedef LONG WINAPI (*tSCardStatusA)(SCARDHANDLE hCard, LPSTR szReaderName, LPDWORD pcchReaderLen, LPDWORD pdwState, LPDWORD pdwProtocol, LPBYTE pbAtr, LPDWORD pcbAtrLen); typedef LONG WINAPI (*tSCardStatusW)(SCARDHANDLE hCard, LPWSTR szReaderName, LPDWORD pcchReaderLen, LPDWORD pdwState, LPDWORD pdwProtocol, LPBYTE pbAtr, LPDWORD pcbAtrLen); typedef LONG WINAPI (*tSCardTransmit)(SCARDHANDLE hCard, LPCSCARD_IO_REQUEST pioSendPci, LPCBYTE pbSendBuffer, DWORD cbSendLength, LPSCARD_IO_REQUEST pioRecvPci, LPBYTE pbRecvBuffer, LPDWORD pcbRecvLength); typedef LONG WINAPI (*tSCardControl)(SCARDHANDLE hCard, DWORD dwControlCode, LPCVOID lpInBuffer, DWORD nInBufferSize, LPVOID lpOutBuffer, DWORD nOutBufferSize, LPDWORD lpBytesReturned); typedef LONG WINAPI (*tSCardGetAttrib)(SCARDHANDLE hCard, DWORD dwAttrId, LPBYTE pbAttr, LPDWORD pcbAttrLen); typedef LONG WINAPI (*tSCardSetAttrib)(SCARDHANDLE hCard, DWORD dwAttrId, LPCBYTE pbAttr, DWORD cbAttrLen); #endif xrdp-0.9.5/sesman/chansrv/pcsc/wrapper/winscard.def000755 001751 001751 00000002051 13125122134 022251 0ustar00metameta000000 000000 EXPORTS SCardEstablishContext SCardReleaseContext SCardIsValidContext SCardListReaderGroupsA SCardListReaderGroupsW SCardListReadersA SCardListReadersW SCardListCardsA SCardListCardsW SCardListInterfacesA SCardListInterfacesW SCardGetProviderIdA SCardGetProviderIdW SCardGetCardTypeProviderNameA SCardGetCardTypeProviderNameW SCardIntroduceReaderGroupA SCardIntroduceReaderGroupW SCardForgetReaderGroupA SCardForgetReaderGroupW SCardIntroduceReaderA SCardIntroduceReaderW SCardForgetReaderA SCardForgetReaderW SCardAddReaderToGroupA SCardAddReaderToGroupW SCardRemoveReaderFromGroupA SCardRemoveReaderFromGroupW SCardIntroduceCardTypeA SCardIntroduceCardTypeW SCardSetCardTypeProviderNameA SCardSetCardTypeProviderNameW SCardForgetCardTypeA SCardForgetCardTypeW SCardFreeMemory SCardLocateCardsA SCardLocateCardsW SCardGetStatusChangeA SCardGetStatusChangeW SCardCancel SCardConnectA SCardConnectW SCardReconnect SCardDisconnect SCardBeginTransaction SCardEndTransaction SCardState SCardStatusA SCardStatusW SCardTransmit SCardControl SCardGetAttrib SCardSetAttrib xrdp-0.9.5/sesman/chansrv/pcsc/wrapper/winscard-func-names.txt000755 001751 001751 00000003156 13125122134 024373 0ustar00metameta000000 000000 ClassInstall32 SCardAccessNewReaderEvent SCardReleaseAllEvents SCardReleaseNewReaderEvent SCardAccessStartedEvent done SCardAddReaderToGroupA done SCardAddReaderToGroupW done SCardBeginTransaction done SCardCancel done SCardConnectA done SCardConnectW done SCardControl done SCardDisconnect done SCardEndTransaction done SCardEstablishContext done SCardForgetCardTypeA done SCardForgetCardTypeW done SCardForgetReaderA done SCardForgetReaderGroupA done SCardForgetReaderGroupW done SCardForgetReaderW done SCardFreeMemory done SCardGetAttrib done SCardGetCardTypeProviderNameA done SCardGetCardTypeProviderNameW done SCardGetProviderIdA done SCardGetProviderIdW done SCardGetStatusChangeA done SCardGetStatusChangeW SCardGetTransmitCount done SCardIntroduceCardTypeA done SCardIntroduceCardTypeW done SCardIntroduceReaderA done SCardIntroduceReaderGroupA done SCardIntroduceReaderGroupW done SCardIntroduceReaderW done SCardIsValidContext done SCardListCardsA done SCardListCardsW done SCardListInterfacesA done SCardListInterfacesW done SCardListReaderGroupsA done SCardListReaderGroupsW done SCardListReadersA done SCardListReadersW done SCardLocateCardsA SCardLocateCardsByATRA SCardLocateCardsByATRW done SCardLocateCardsW SCardReadCacheA SCardReadCacheW done SCardReconnect done SCardReleaseContext SCardReleaseStartedEvent done SCardRemoveReaderFromGroupA done SCardRemoveReaderFromGroupW done SCardSetAttrib done SCardSetCardTypeProviderNameA done SCardSetCardTypeProviderNameW done SCardState done SCardStatusA done SCardStatusW done SCardTransmit SCardWriteCacheA SCardWriteCacheW g_rgSCardRawPci g_rgSCardT0Pci g_rgSCardT1Pci xrdp-0.9.5/sesman/chansrv/pcsc/wrapper/winscard.c000755 001751 001751 00000071570 13127114621 021755 0ustar00metameta000000 000000 #include #include #include #include #include #include "winscard-funcs.h" #define LUNUSED(_param) (void) _param static tSCardEstablishContext aSCardEstablishContext; static tSCardReleaseContext aSCardReleaseContext; static tSCardIsValidContext aSCardIsValidContext; static tSCardListReaderGroupsA aSCardListReaderGroupsA; static tSCardListReaderGroupsW aSCardListReaderGroupsW; static tSCardListReadersA aSCardListReadersA; static tSCardListReadersW aSCardListReadersW; static tSCardListCardsA aSCardListCardsA; static tSCardListCardsW aSCardListCardsW; static tSCardListInterfacesA aSCardListInterfacesA; static tSCardListInterfacesW aSCardListInterfacesW; static tSCardGetProviderIdA aSCardGetProviderIdA; static tSCardGetProviderIdW aSCardGetProviderIdW; static tSCardGetCardTypeProviderNameA aSCardGetCardTypeProviderNameA; static tSCardGetCardTypeProviderNameW aSCardGetCardTypeProviderNameW; static tSCardIntroduceReaderGroupA aSCardIntroduceReaderGroupA; static tSCardIntroduceReaderGroupW aSCardIntroduceReaderGroupW; static tSCardForgetReaderGroupA aSCardForgetReaderGroupA; static tSCardForgetReaderGroupW aSCardForgetReaderGroupW; static tSCardIntroduceReaderA aSCardIntroduceReaderA; static tSCardIntroduceReaderW aSCardIntroduceReaderW; static tSCardForgetReaderA aSCardForgetReaderA; static tSCardForgetReaderW aSCardForgetReaderW; static tSCardAddReaderToGroupA aSCardAddReaderToGroupA; static tSCardAddReaderToGroupW aSCardAddReaderToGroupW; static tSCardRemoveReaderFromGroupA aSCardRemoveReaderFromGroupA; static tSCardRemoveReaderFromGroupW aSCardRemoveReaderFromGroupW; static tSCardIntroduceCardTypeA aSCardIntroduceCardTypeA; static tSCardIntroduceCardTypeW aSCardIntroduceCardTypeW; static tSCardSetCardTypeProviderNameA aSCardSetCardTypeProviderNameA; static tSCardSetCardTypeProviderNameW aSCardSetCardTypeProviderNameW; static tSCardForgetCardTypeA aSCardForgetCardTypeA; static tSCardForgetCardTypeW aSCardForgetCardTypeW; static tSCardFreeMemory aSCardFreeMemory; static tSCardLocateCardsA aSCardLocateCardsA; static tSCardLocateCardsW aSCardLocateCardsW; static tSCardGetStatusChangeA aSCardGetStatusChangeA; static tSCardGetStatusChangeW aSCardGetStatusChangeW; static tSCardCancel aSCardCancel; static tSCardConnectA aSCardConnectA; static tSCardConnectW aSCardConnectW; static tSCardReconnect aSCardReconnect; static tSCardDisconnect aSCardDisconnect; static tSCardBeginTransaction aSCardBeginTransaction; static tSCardEndTransaction aSCardEndTransaction; static tSCardCancelTransaction aSCardCancelTransaction; static tSCardState aSCardState; static tSCardStatusA aSCardStatusA; static tSCardStatusW aSCardStatusW; static tSCardTransmit aSCardTransmit; static tSCardControl aSCardControl; static tSCardGetAttrib aSCardGetAttrib; static tSCardSetAttrib aSCardSetAttrib; //__declspec(dllexport) const SCARD_IO_REQUEST g_rgSCardT0Pci = { 0 }; //__declspec(dllexport) const SCARD_IO_REQUEST g_rgSCardT1Pci = { 0 }; //__declspec(dllexport) const SCARD_IO_REQUEST g_rgSCardRawPci = { 0 }; static int g_true = 1; #define LLOGLN(_level, _args) do { if ((_level < 11) && g_true) { writeln _args ; } } while (0) /*****************************************************************************/ static int writeln(const char* format, ...) { va_list ap; char text[256]; va_start(ap, format); vsnprintf(text, 255, format, ap); va_end(ap); OutputDebugString(text); return 0; } #define LLOAD(_func, _type, _name) \ do { \ _func = (_type) GetProcAddress(lib, _name); \ if (_func == 0) \ { \ writeln("LLOAD error %s", _name); \ } \ } while (0) static int g_funcs_loaded = 0; /*****************************************************************************/ static int __fastcall load_funcs(void) { HMODULE lib; if (g_funcs_loaded) { return 0; } g_funcs_loaded = 1; lib = LoadLibrary("winscard-org.dll"); LLOGLN(0, ("load_funcs: lib %p", lib)); LLOAD(aSCardEstablishContext, tSCardEstablishContext, "SCardEstablishContext"); LLOAD(aSCardReleaseContext, tSCardReleaseContext, "SCardReleaseContext"); LLOAD(aSCardIsValidContext, tSCardIsValidContext, "SCardIsValidContext"); LLOAD(aSCardListReaderGroupsA, tSCardListReaderGroupsA, "SCardListReaderGroupsA"); LLOAD(aSCardListReaderGroupsW, tSCardListReaderGroupsW, "SCardListReaderGroupsW"); LLOAD(aSCardListReadersA, tSCardListReadersA, "SCardListReadersA"); LLOAD(aSCardListReadersW, tSCardListReadersW, "SCardListReadersW"); LLOAD(aSCardListCardsA, tSCardListCardsA, "SCardListCardsA"); LLOAD(aSCardListCardsW, tSCardListCardsW, "SCardListCardsW"); LLOAD(aSCardListInterfacesA, tSCardListInterfacesA, "SCardListInterfacesA"); LLOAD(aSCardListInterfacesW, tSCardListInterfacesW, "SCardListInterfacesW"); LLOAD(aSCardGetProviderIdA, tSCardGetProviderIdA, "SCardGetProviderIdA"); LLOAD(aSCardGetProviderIdW, tSCardGetProviderIdW, "SCardGetProviderIdW"); LLOAD(aSCardGetCardTypeProviderNameA, tSCardGetCardTypeProviderNameA, "SCardGetCardTypeProviderNameA"); LLOAD(aSCardGetCardTypeProviderNameW, tSCardGetCardTypeProviderNameW, "SCardGetCardTypeProviderNameW"); LLOAD(aSCardIntroduceReaderGroupA, tSCardIntroduceReaderGroupA, "SCardIntroduceReaderGroupA"); LLOAD(aSCardIntroduceReaderGroupW, tSCardIntroduceReaderGroupW, "SCardIntroduceReaderGroupW"); LLOAD(aSCardForgetReaderGroupA, tSCardForgetReaderGroupA, "SCardForgetReaderGroupA"); LLOAD(aSCardForgetReaderGroupW, tSCardForgetReaderGroupW, "SCardForgetReaderGroupW"); LLOAD(aSCardIntroduceReaderA, tSCardIntroduceReaderA, "SCardIntroduceReaderA"); LLOAD(aSCardIntroduceReaderW, tSCardIntroduceReaderW, "SCardIntroduceReaderW"); LLOAD(aSCardForgetReaderA, tSCardForgetReaderA, "SCardForgetReaderA"); LLOAD(aSCardForgetReaderW, tSCardForgetReaderW, "SCardForgetReaderW"); LLOAD(aSCardAddReaderToGroupA, tSCardAddReaderToGroupA, "SCardAddReaderToGroupA"); LLOAD(aSCardAddReaderToGroupW, tSCardAddReaderToGroupW, "SCardAddReaderToGroupW"); LLOAD(aSCardRemoveReaderFromGroupA, tSCardRemoveReaderFromGroupA, "SCardRemoveReaderFromGroupA"); LLOAD(aSCardRemoveReaderFromGroupW, tSCardRemoveReaderFromGroupW, "SCardRemoveReaderFromGroupW"); LLOAD(aSCardIntroduceCardTypeA, tSCardIntroduceCardTypeA, "SCardIntroduceCardTypeA"); LLOAD(aSCardIntroduceCardTypeW, tSCardIntroduceCardTypeW, "SCardIntroduceCardTypeW"); LLOAD(aSCardSetCardTypeProviderNameA, tSCardSetCardTypeProviderNameA, "SCardSetCardTypeProviderNameA"); LLOAD(aSCardSetCardTypeProviderNameW, tSCardSetCardTypeProviderNameW, "SCardSetCardTypeProviderNameW"); LLOAD(aSCardForgetCardTypeA, tSCardForgetCardTypeA, "SCardForgetCardTypeA"); LLOAD(aSCardForgetCardTypeW, tSCardForgetCardTypeW, "SCardForgetCardTypeW"); LLOAD(aSCardFreeMemory, tSCardFreeMemory, "SCardFreeMemory"); LLOAD(aSCardLocateCardsA, tSCardLocateCardsA, "SCardLocateCardsA"); LLOAD(aSCardLocateCardsW, tSCardLocateCardsW, "SCardLocateCardsW"); LLOAD(aSCardGetStatusChangeA, tSCardGetStatusChangeA, "SCardGetStatusChangeA"); LLOAD(aSCardGetStatusChangeW, tSCardGetStatusChangeW, "SCardGetStatusChangeW"); LLOAD(aSCardCancel, tSCardCancel, "SCardCancel"); LLOAD(aSCardConnectA, tSCardConnectA, "SCardConnectA"); LLOAD(aSCardConnectW, tSCardConnectW, "SCardConnectW"); LLOAD(aSCardReconnect, tSCardReconnect, "SCardReconnect"); LLOAD(aSCardDisconnect, tSCardDisconnect, "SCardDisconnect"); LLOAD(aSCardBeginTransaction, tSCardBeginTransaction, "SCardBeginTransaction"); LLOAD(aSCardEndTransaction, tSCardEndTransaction, "SCardEndTransaction"); LLOAD(aSCardCancelTransaction, tSCardCancelTransaction, "SCardCancelTransaction"); LLOAD(aSCardState, tSCardState, "SCardState"); LLOAD(aSCardStatusA, tSCardStatusA, "SCardStatusA"); LLOAD(aSCardStatusW, tSCardStatusW, "SCardStatusW"); LLOAD(aSCardTransmit, tSCardTransmit, "SCardTransmit"); LLOAD(aSCardControl, tSCardControl, "SCardControl"); LLOAD(aSCardGetAttrib, tSCardGetAttrib, "SCardGetAttrib"); LLOAD(aSCardSetAttrib, tSCardSetAttrib, "SCardSetAttrib"); return 0; } /*****************************************************************************/ BOOL WINAPI DllEntryPoint(HINSTANCE hinstDLL, DWORD fdwReason, LPVOID lpvReserved) { BOOL rv; LUNUSED(hinstDLL); LUNUSED(lpvReserved); LLOGLN(10, ("DllEntryPoint: hinstDLL %p fdwReason %d", hinstDLL, fdwReason)); rv = FALSE; switch (fdwReason) { case DLL_PROCESS_ATTACH: LLOGLN(0, ("DllEntryPoint: DLL_PROCESS_ATTACH")); load_funcs(); rv = TRUE; break; case DLL_THREAD_ATTACH: LLOGLN(10, ("DllEntryPoint: DLL_THREAD_ATTACH")); rv = TRUE; break; case DLL_THREAD_DETACH: LLOGLN(10, ("DllEntryPoint: DLL_THREAD_DETACH")); rv = TRUE; break; case DLL_PROCESS_DETACH: LLOGLN(0, ("DllEntryPoint: DLL_PROCESS_DETACH")); rv = TRUE; break; default: LLOGLN(0, ("DllEntryPoint: unknown fdwReason %d", fdwReason)); break; } return rv; } /*****************************************************************************/ LONG WINAPI SCardEstablishContext(DWORD dwScope, LPCVOID pvReserved1, LPCVOID pvReserved2, LPSCARDCONTEXT phContext) { LLOGLN(0, ("SCardEstablishContext:")); return aSCardEstablishContext(dwScope, pvReserved1, pvReserved2, phContext); } /*****************************************************************************/ LONG WINAPI SCardReleaseContext(SCARDCONTEXT hContext) { LLOGLN(0, ("SCardReleaseContext:")); return aSCardReleaseContext(hContext); } /*****************************************************************************/ LONG WINAPI SCardIsValidContext(SCARDCONTEXT hContext) { LLOGLN(0, ("SCardIsValidContext:")); return aSCardIsValidContext(hContext); } /*****************************************************************************/ LONG WINAPI SCardListReaderGroupsA(SCARDCONTEXT hContext, LPSTR mszGroups, LPDWORD pcchGroups) { LLOGLN(0, ("SCardListReaderGroupsA:")); return aSCardListReaderGroupsA(hContext, mszGroups, pcchGroups); } /*****************************************************************************/ LONG WINAPI SCardListReaderGroupsW(SCARDCONTEXT hContext, LPWSTR mszGroups, LPDWORD pcchGroups) { LLOGLN(0, ("SCardListReaderGroupsW:")); return aSCardListReaderGroupsW(hContext, mszGroups, pcchGroups); } /*****************************************************************************/ LONG WINAPI SCardListReadersA(SCARDCONTEXT hContext, LPCSTR mszGroups, LPSTR mszReaders, LPDWORD pcchReaders) { LLOGLN(0, ("SCardListReadersA:")); return aSCardListReadersA(hContext, mszGroups, mszReaders, pcchReaders); } /*****************************************************************************/ LONG WINAPI SCardListReadersW(SCARDCONTEXT hContext, LPCWSTR mszGroups, LPWSTR mszReaders, LPDWORD pcchReaders) { char text[256]; LONG rv; DWORD cchReaders; text[0] = 0; if (mszGroups != 0) { wcstombs(text, mszGroups, 255); } cchReaders = *pcchReaders; LLOGLN(0, ("SCardListReadersW: mszGroups [%s] cchReaders [%d]", text, *pcchReaders)); rv = aSCardListReadersW(hContext, mszGroups, mszReaders, pcchReaders); text[0] = 0; if (cchReaders > 0) { wcstombs(text, mszReaders, 255); } LLOGLN(0, (" mszReaders [%s] cchReaders [%d]", text, *pcchReaders)); return rv; } /*****************************************************************************/ LONG WINAPI SCardListCardsA(SCARDCONTEXT hContext, LPCBYTE pbAtr, LPCGUID rgquidInterfaces, DWORD cguidInterfaceCount, LPSTR mszCards, LPDWORD pcchCards) { LLOGLN(0, ("SCardListCardsA:")); return aSCardListCardsA(hContext, pbAtr, rgquidInterfaces, cguidInterfaceCount, mszCards, pcchCards); } /*****************************************************************************/ LONG WINAPI SCardListCardsW(SCARDCONTEXT hContext, LPCBYTE pbAtr, LPCGUID rgquidInterfaces, DWORD cguidInterfaceCount, LPWSTR mszCards, LPDWORD pcchCards) { LLOGLN(0, ("SCardListCardsW:")); return aSCardListCardsW(hContext, pbAtr, rgquidInterfaces, cguidInterfaceCount, mszCards, pcchCards); } /*****************************************************************************/ LONG WINAPI SCardListInterfacesA(SCARDCONTEXT hContext, LPCSTR szCard, LPGUID pguidInterfaces, LPDWORD pcguidInterfaces) { LLOGLN(0, ("SCardListInterfacesA:")); return aSCardListInterfacesA(hContext, szCard, pguidInterfaces, pcguidInterfaces); } /*****************************************************************************/ LONG WINAPI SCardListInterfacesW(SCARDCONTEXT hContext, LPCWSTR szCard, LPGUID pguidInterfaces, LPDWORD pcguidInterfaces) { LLOGLN(0, ("SCardListInterfacesW:")); return aSCardListInterfacesW(hContext, szCard, pguidInterfaces, pcguidInterfaces); } /*****************************************************************************/ LONG WINAPI SCardGetProviderIdA(SCARDCONTEXT hContext, LPCSTR szCard, LPGUID pguidProviderId) { LLOGLN(0, ("SCardGetProviderIdA:")); return aSCardGetProviderIdA(hContext, szCard, pguidProviderId); } /****************************************************************************/ LONG WINAPI SCardGetProviderIdW(SCARDCONTEXT hContext, LPCWSTR szCard, LPGUID pguidProviderId) { LLOGLN(0, ("SCardGetProviderIdW:")); return aSCardGetProviderIdW(hContext, szCard, pguidProviderId); } /****************************************************************************/ LONG WINAPI SCardGetCardTypeProviderNameA(SCARDCONTEXT hContext, LPCSTR szCardName, DWORD dwProviderId, LPSTR szProvider, LPDWORD pcchProvider) { LLOGLN(0, ("SCardGetCardTypeProviderNameA:")); return aSCardGetCardTypeProviderNameA(hContext, szCardName, dwProviderId, szProvider, pcchProvider); } /*****************************************************************************/ LONG WINAPI SCardGetCardTypeProviderNameW(SCARDCONTEXT hContext, LPCWSTR szCardName, DWORD dwProviderId, LPWSTR szProvider, LPDWORD pcchProvider) { LLOGLN(0, ("SCardGetCardTypeProviderNameW:")); return aSCardGetCardTypeProviderNameW(hContext, szCardName, dwProviderId, szProvider, pcchProvider); } /*****************************************************************************/ LONG WINAPI SCardIntroduceReaderGroupA(SCARDCONTEXT hContext, LPCSTR szGroupName) { LLOGLN(0, ("SCardIntroduceReaderGroupA:")); return aSCardIntroduceReaderGroupA(hContext, szGroupName); } /*****************************************************************************/ LONG WINAPI SCardIntroduceReaderGroupW(SCARDCONTEXT hContext, LPCWSTR szGroupName) { LLOGLN(0, ("SCardIntroduceReaderGroupW:")); return aSCardIntroduceReaderGroupW(hContext, szGroupName); } /*****************************************************************************/ LONG WINAPI SCardForgetReaderGroupA(SCARDCONTEXT hContext, LPCSTR szGroupName) { LLOGLN(0, ("SCardForgetReaderGroupA:")); return aSCardForgetReaderGroupA(hContext, szGroupName); } /*****************************************************************************/ LONG WINAPI SCardForgetReaderGroupW(SCARDCONTEXT hContext, LPCWSTR szGroupName) { LLOGLN(0, ("SCardForgetReaderGroupW:")); return aSCardForgetReaderGroupW(hContext, szGroupName); } /*****************************************************************************/ LONG WINAPI SCardIntroduceReaderA(SCARDCONTEXT hContext, LPCSTR szReaderName, LPCSTR szDeviceName) { LLOGLN(0, ("SCardIntroduceReaderA:")); return aSCardIntroduceReaderA(hContext, szReaderName, szDeviceName); } /*****************************************************************************/ LONG WINAPI SCardIntroduceReaderW(SCARDCONTEXT hContext, LPCWSTR szReaderName, LPCWSTR szDeviceName) { LLOGLN(0, ("SCardIntroduceReaderW:")); return aSCardIntroduceReaderW(hContext, szReaderName, szDeviceName); } /*****************************************************************************/ LONG WINAPI SCardForgetReaderA(SCARDCONTEXT hContext, LPCSTR szReaderName) { LLOGLN(0, ("SCardForgetReaderA:")); return aSCardForgetReaderA(hContext, szReaderName); } /*****************************************************************************/ LONG WINAPI SCardForgetReaderW(SCARDCONTEXT hContext, LPCWSTR szReaderName) { LLOGLN(0, ("SCardForgetReaderW:")); return aSCardForgetReaderW(hContext, szReaderName); } /*****************************************************************************/ LONG WINAPI SCardAddReaderToGroupA(SCARDCONTEXT hContext, LPCSTR szReaderName, LPCSTR szGroupName) { LLOGLN(0, ("SCardAddReaderToGroupA:")); return aSCardAddReaderToGroupA(hContext, szReaderName, szGroupName); } /*****************************************************************************/ LONG WINAPI SCardAddReaderToGroupW(SCARDCONTEXT hContext, LPCWSTR szReaderName, LPCWSTR szGroupName) { LLOGLN(0, ("SCardAddReaderToGroupW:")); return aSCardAddReaderToGroupW(hContext, szReaderName, szGroupName); } /*****************************************************************************/ LONG WINAPI SCardRemoveReaderFromGroupA(SCARDCONTEXT hContext, LPCSTR szReaderName, LPCSTR szGroupName) { LLOGLN(0, ("SCardRemoveReaderFromGroupA:")); return aSCardRemoveReaderFromGroupA(hContext, szReaderName, szGroupName); } /*****************************************************************************/ LONG WINAPI SCardRemoveReaderFromGroupW(SCARDCONTEXT hContext, LPCWSTR szReaderName, LPCWSTR szGroupName) { LLOGLN(0, ("SCardRemoveReaderFromGroupW:")); return aSCardRemoveReaderFromGroupW(hContext, szReaderName, szGroupName); } /*****************************************************************************/ LONG WINAPI SCardIntroduceCardTypeA(SCARDCONTEXT hContext, LPCSTR szCardName, LPCGUID pguidPrimaryProvider, LPCGUID rgguidInterfaces, DWORD dwInterfaceCount, LPCBYTE pbAtr, LPCBYTE pbAtrMask, DWORD cbAtrLen) { LLOGLN(0, ("SCardIntroduceCardTypeA:")); return aSCardIntroduceCardTypeA(hContext, szCardName, pguidPrimaryProvider, rgguidInterfaces, dwInterfaceCount, pbAtr, pbAtrMask, cbAtrLen); } /*****************************************************************************/ LONG WINAPI SCardIntroduceCardTypeW(SCARDCONTEXT hContext, LPCWSTR szCardName, LPCGUID pguidPrimaryProvider, LPCGUID rgguidInterfaces, DWORD dwInterfaceCount, LPCBYTE pbAtr, LPCBYTE pbAtrMask, DWORD cbAtrLen) { LLOGLN(0, ("SCardIntroduceCardTypeW:")); return aSCardIntroduceCardTypeW(hContext, szCardName, pguidPrimaryProvider, rgguidInterfaces, dwInterfaceCount, pbAtr, pbAtrMask, cbAtrLen); } /*****************************************************************************/ LONG WINAPI SCardSetCardTypeProviderNameA(SCARDCONTEXT hContext, LPCSTR szCardName, DWORD dwProviderId, LPCSTR szProvider) { LLOGLN(0, ("SCardSetCardTypeProviderNameA:")); return aSCardSetCardTypeProviderNameA(hContext, szCardName, dwProviderId, szProvider); } /*****************************************************************************/ LONG WINAPI SCardSetCardTypeProviderNameW(SCARDCONTEXT hContext, LPCWSTR szCardName, DWORD dwProviderId, LPCWSTR szProvider) { LLOGLN(0, ("SCardSetCardTypeProviderNameW:")); return aSCardSetCardTypeProviderNameW(hContext, szCardName, dwProviderId, szProvider); } /*****************************************************************************/ LONG WINAPI SCardForgetCardTypeA(SCARDCONTEXT hContext, LPCSTR szCardName) { LLOGLN(0, ("SCardForgetCardTypeA:")); return aSCardForgetCardTypeA(hContext, szCardName); } /*****************************************************************************/ LONG WINAPI SCardForgetCardTypeW(SCARDCONTEXT hContext, LPCWSTR szCardName) { LLOGLN(0, ("SCardForgetCardTypeW:")); return aSCardForgetCardTypeW(hContext, szCardName); } /*****************************************************************************/ LONG WINAPI SCardFreeMemory(SCARDCONTEXT hContext, LPCVOID pvMem) { LLOGLN(0, ("SCardFreeMemory:")); return aSCardFreeMemory(hContext, pvMem); } /*****************************************************************************/ LONG WINAPI SCardLocateCardsA(SCARDCONTEXT hContext, LPCSTR mszCards, LPSCARD_READERSTATEA rgReaderStates, DWORD cReaders) { LLOGLN(0, ("SCardLocateCardsA:")); return aSCardLocateCardsA(hContext, mszCards, rgReaderStates, cReaders); } /*****************************************************************************/ LONG WINAPI SCardLocateCardsW(SCARDCONTEXT hContext, LPCWSTR mszCards, LPSCARD_READERSTATEW rgReaderStates, DWORD cReaders) { LLOGLN(0, ("SCardLocateCardsW:")); return aSCardLocateCardsW(hContext, mszCards, rgReaderStates, cReaders); } /*****************************************************************************/ LONG WINAPI SCardGetStatusChangeA(SCARDCONTEXT hContext, DWORD dwTimeout, LPSCARD_READERSTATEA rgReaderStates, DWORD cReaders) { LLOGLN(0, ("SCardGetStatusChangeA:")); return aSCardGetStatusChangeA(hContext, dwTimeout, rgReaderStates, cReaders); } /*****************************************************************************/ LONG WINAPI SCardGetStatusChangeW(SCARDCONTEXT hContext, DWORD dwTimeout, LPSCARD_READERSTATEW rgReaderStates, DWORD cReaders) { LLOGLN(0, ("SCardGetStatusChangeW:")); return aSCardGetStatusChangeW(hContext, dwTimeout, rgReaderStates, cReaders); } /*****************************************************************************/ LONG WINAPI SCardCancel(SCARDCONTEXT hContext) { LLOGLN(0, ("SCardCancel:")); return aSCardCancel(hContext); } /*****************************************************************************/ LONG WINAPI SCardConnectA(SCARDCONTEXT hContext, LPCSTR szReader, DWORD dwShareMode, DWORD dwPreferredProtocols, LPSCARDHANDLE phCard, LPDWORD pdwActiveProtocol) { LLOGLN(0, ("SCardConnectA:")); return aSCardConnectA(hContext, szReader, dwShareMode, dwPreferredProtocols, phCard, pdwActiveProtocol); } /*****************************************************************************/ LONG WINAPI SCardConnectW(SCARDCONTEXT hContext, LPCWSTR szReader, DWORD dwShareMode, DWORD dwPreferredProtocols, LPSCARDHANDLE phCard, LPDWORD pdwActiveProtocol) { LLOGLN(0, ("SCardConnectW:")); return aSCardConnectW(hContext, szReader, dwShareMode, dwPreferredProtocols, phCard, pdwActiveProtocol); } /*****************************************************************************/ LONG WINAPI SCardReconnect(SCARDHANDLE hCard, DWORD dwShareMode, DWORD dwPreferredProtocols, DWORD dwInitialization, LPDWORD pdwActiveProtocol) { LLOGLN(0, ("SCardReconnect:")); return SCardReconnect(hCard, dwShareMode, dwPreferredProtocols, dwInitialization, pdwActiveProtocol); } /*****************************************************************************/ LONG WINAPI SCardDisconnect(SCARDHANDLE hCard, DWORD dwDisposition) { LLOGLN(0, ("SCardDisconnect:")); return aSCardDisconnect(hCard, dwDisposition); } /*****************************************************************************/ LONG WINAPI SCardBeginTransaction(SCARDHANDLE hCard) { LLOGLN(0, ("SCardBeginTransaction:")); return aSCardBeginTransaction(hCard); } /*****************************************************************************/ LONG WINAPI SCardEndTransaction(SCARDHANDLE hCard, DWORD dwDisposition) { LLOGLN(0, ("SCardEndTransaction:")); return aSCardEndTransaction(hCard, dwDisposition); } /*****************************************************************************/ LONG WINAPI SCardCancelTransaction(SCARDHANDLE hCard) { LLOGLN(0, ("SCardCancelTransaction:")); return aSCardCancelTransaction(hCard); } /*****************************************************************************/ LONG WINAPI SCardState(SCARDHANDLE hCard, LPDWORD pdwState, LPDWORD pdwProtocol, LPBYTE pbAtr, LPDWORD pcbAtrLen) { LLOGLN(0, ("SCardState:")); return aSCardState(hCard, pdwState, pdwProtocol, pbAtr, pcbAtrLen); } /*****************************************************************************/ LONG WINAPI SCardStatusA(SCARDHANDLE hCard, LPSTR szReaderName, LPDWORD pcchReaderLen, LPDWORD pdwState, LPDWORD pdwProtocol, LPBYTE pbAtr, LPDWORD pcbAtrLen) { LLOGLN(0, ("SCardStatusA:")); return aSCardStatusA(hCard, szReaderName, pcchReaderLen, pdwState, pdwProtocol, pbAtr, pcbAtrLen); } /*****************************************************************************/ LONG WINAPI SCardStatusW(SCARDHANDLE hCard, LPWSTR szReaderName, LPDWORD pcchReaderLen, LPDWORD pdwState, LPDWORD pdwProtocol, LPBYTE pbAtr, LPDWORD pcbAtrLen) { LONG rv; LLOGLN(0, ("SCardStatusW:")); LLOGLN(0, (" cchReaderLen %d", *pcchReaderLen)); LLOGLN(0, (" cbAtrLen %d", *pcbAtrLen)); rv = aSCardStatusW(hCard, szReaderName, pcchReaderLen, pdwState, pdwProtocol, pbAtr, pcbAtrLen); LLOGLN(0, (" rv %d cchReaderLen %d", rv, *pcchReaderLen)); return rv; } /*****************************************************************************/ LONG WINAPI SCardTransmit(SCARDHANDLE hCard, LPCSCARD_IO_REQUEST pioSendPci, LPCBYTE pbSendBuffer, DWORD cbSendLength, LPSCARD_IO_REQUEST pioRecvPci, LPBYTE pbRecvBuffer, LPDWORD pcbRecvLength) { LONG rv; LLOGLN(10, ("SCardTransmit:")); LLOGLN(10, (" hCard %p", hCard)); LLOGLN(10, (" cbSendLength %d", cbSendLength)); LLOGLN(10, (" cbRecvLength %d", *pcbRecvLength)); LLOGLN(10, (" pioSendPci->dwProtocol %d", pioSendPci->dwProtocol)); LLOGLN(10, (" pioSendPci->cbPciLength %d", pioSendPci->cbPciLength)); LLOGLN(10, (" pioRecvPci %p", pioRecvPci)); if (pioRecvPci != NULL) { LLOGLN(10, (" pioRecvPci->dwProtocol %d", pioRecvPci->dwProtocol)); LLOGLN(10, (" pioRecvPci->cbPciLength %d", pioRecvPci->cbPciLength)); } rv = aSCardTransmit(hCard, pioSendPci, pbSendBuffer, cbSendLength, pioRecvPci, pbRecvBuffer, pcbRecvLength); LLOGLN(10, (" rv %d cbRecvLength %d", rv, *pcbRecvLength)); return rv; } /*****************************************************************************/ LONG WINAPI SCardControl(SCARDHANDLE hCard, DWORD dwControlCode, LPCVOID lpInBuffer, DWORD nInBufferSize, LPVOID lpOutBuffer, DWORD nOutBufferSize, LPDWORD lpBytesReturned) { LONG rv; char text[8148]; LLOGLN(10, ("SCardControl:")); LLOGLN(10, (" hCard %p", hCard)); LLOGLN(10, (" dwControlCode 0x%8.8x", dwControlCode)); LLOGLN(10, (" lpInBuffer %p", lpInBuffer)); LLOGLN(10, (" nInBufferSize %d", nInBufferSize)); LLOGLN(10, (" lpOutBuffer %p", lpOutBuffer)); LLOGLN(10, (" nOutBufferSize %d", nOutBufferSize)); LLOGLN(10, (" lpBytesReturned %p", lpBytesReturned)); rv = aSCardControl(hCard, dwControlCode, lpInBuffer, nInBufferSize, lpOutBuffer, nOutBufferSize, lpBytesReturned); LLOGLN(10, (" rv %d BytesReturned %d", rv, *lpBytesReturned)); return rv; } /*****************************************************************************/ LONG WINAPI SCardGetAttrib(SCARDHANDLE hCard, DWORD dwAttrId, LPBYTE pbAttr, LPDWORD pcbAttrLen) { LLOGLN(0, ("SCardGetAttrib:")); return aSCardGetAttrib(hCard, dwAttrId, pbAttr, pcbAttrLen); } /*****************************************************************************/ LONG WINAPI SCardSetAttrib(SCARDHANDLE hCard, DWORD dwAttrId, LPCBYTE pbAttr, DWORD cbAttrLen) { LLOGLN(0, ("SCardSetAttrib:")); return aSCardSetAttrib(hCard, dwAttrId, pbAttr, cbAttrLen); } xrdp-0.9.5/sesman/tools/tcp.c000644 001751 001751 00000006574 13174271344 016024 0ustar00metameta000000 000000 /** * xrdp: A Remote Desktop Protocol server. * * Copyright (C) Jay Sorg 2004-2013 * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ /** * * @file tcp.c * @brief Tcp stream functions * @author Jay Sorg, Simone Fedele * */ #if defined(HAVE_CONFIG_H) #include #endif #include "sesman.h" #include #include #include #include #include /*****************************************************************************/ int tcp_force_recv(int sck, char *data, int len) { int rcvd; //#ifndef LIBSCP_CLIENT // int block; // block = lock_fork_critical_section_start(); //#endif while (len > 0) { rcvd = g_tcp_recv(sck, data, len, 0); if (rcvd == -1) { if (g_tcp_last_error_would_block(sck)) { g_sleep(1); } else { //#ifndef LIBSCP_CLIENT // lock_fork_critical_section_end(block); //#endif return 1; } } else if (rcvd == 0) { //#ifndef LIBSCP_CLIENT // lock_fork_critical_section_end(block); //#endif return 1; } else { data += rcvd; len -= rcvd; } } //#ifndef LIBSCP_CLIENT // lock_fork_critical_section_end(block); //#endif return 0; } /*****************************************************************************/ int tcp_force_send(int sck, char *data, int len) { int sent; //#ifndef LIBSCP_CLIENT // int block; // block = lock_fork_critical_section_start(); //#endif while (len > 0) { sent = g_tcp_send(sck, data, len, 0); if (sent == -1) { if (g_tcp_last_error_would_block(sck)) { g_sleep(1); } else { //#ifndef LIBSCP_CLIENT // lock_fork_critical_section_end(block); //#endif return 1; } } else if (sent == 0) { //#ifndef LIBSCP_CLIENT // lock_fork_critical_section_end(block); //#endif return 1; } else { data += sent; len -= sent; } } //#ifndef LIBSCP_CLIENT // lock_fork_critical_section_end(block); //#endif return 0; } /*****************************************************************************/ int tcp_bind(int sck, char *addr, char *port) { struct sockaddr_in s; memset(&s, 0, sizeof(struct sockaddr_in)); s.sin_family = AF_INET; s.sin_port = htons(atoi(port)); s.sin_addr.s_addr = inet_addr(addr); return bind(sck, (struct sockaddr *)&s, sizeof(struct sockaddr_in)); } xrdp-0.9.5/sesman/tools/sesadmin.c000644 001751 001751 00000013501 13174271344 017025 0ustar00metameta000000 000000 /* * sesadmin.c - an sesman administration tool * (c) 2008 Simone Fedele * * 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 2 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. * * You should have received a copy of the GNU General Public License * along with this program; if not, write to the Free Software * Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA. */ #if defined(HAVE_CONFIG_H) #include #endif #include "arch.h" #include "tcp.h" #include "libscp.h" #include "parse.h" #include "log.h" #include "libscp.h" #include #include char user[257]; char pass[257]; char cmnd[257]; char serv[257]; char port[257]; struct log_config logging; void cmndList(struct SCP_CONNECTION *c); void cmndKill(struct SCP_CONNECTION *c, struct SCP_SESSION *s); void cmndHelp(void); int inputSession(struct SCP_SESSION *s); unsigned int menuSelect(unsigned int choices); int main(int argc, char **argv) { struct SCP_SESSION *s; struct SCP_CONNECTION *c; enum SCP_CLIENT_STATES_E e; //int end; int idx; //int sel; int sock; char *pwd; user[0] = '\0'; pass[0] = '\0'; cmnd[0] = '\0'; serv[0] = '\0'; port[0] = '\0'; logging.program_name = "sesadmin"; logging.log_file = g_strdup("xrdp-sesadmin.log"); logging.log_level = LOG_LEVEL_DEBUG; logging.enable_syslog = 0; log_start_from_param(&logging); for (idx = 0; idx < argc; idx++) { if (0 == g_strncmp(argv[idx], "-u=", 3)) { g_strncpy(user, (argv[idx]) + 3, 256); } else if (0 == g_strncmp(argv[idx], "-p=", 3)) { g_strncpy(pass, (argv[idx]) + 3, 256); } else if (0 == g_strncmp(argv[idx], "-s=", 3)) { g_strncpy(serv, (argv[idx]) + 3, 256); } else if (0 == g_strncmp(argv[idx], "-i=", 3)) { g_strncpy(port, (argv[idx]) + 3, 256); } else if (0 == g_strncmp(argv[idx], "-c=", 3)) { g_strncpy(cmnd, (argv[idx]) + 3, 256); } } if (0 == g_strncmp(serv, "", 1)) { g_strncpy(serv, "localhost", 256); } if (0 == g_strncmp(port, "", 1)) { g_strncpy(port, "3350", 256); } if (0 == g_strncmp(user, "", 1)) { cmndHelp(); return 0; } if (0 == g_strncmp(cmnd, "", 1)) { cmndHelp(); return 0; } if (0 == g_strncmp(pass, "", 1)) { pwd = getpass("password:"); g_strncpy(pass, pwd, 256); /* zeroing the password */ while ((*pwd) != '\0') { (*pwd) = 0x00; pwd++; } } scp_init(); sock = g_tcp_socket(); if (sock < 0) { LOG_DBG("Socket open error, g_tcp_socket() failed"); return 1; } s = scp_session_create(); c = scp_connection_create(sock); LOG_DBG("Connecting to %s:%s with user %s (%s)", serv, port, user, pass); if (0 != g_tcp_connect(sock, serv, port)) { LOG_DBG("g_tcp_connect() error"); return 1; } scp_session_set_type(s, SCP_SESSION_TYPE_MANAGE); scp_session_set_version(s, 1); scp_session_set_username(s, user); scp_session_set_password(s, pass); e = scp_v1c_mng_connect(c, s); if (SCP_CLIENT_STATE_OK != e) { LOG_DBG("libscp error connecting: %s %d", s->errstr, (int)e); } if (0 == g_strncmp(cmnd, "list", 5)) { cmndList(c); } else if (0 == g_strncmp(cmnd, "kill:", 5)) { cmndKill(c, s); } g_tcp_close(sock); scp_session_destroy(s); scp_connection_destroy(c); log_end(); return 0; } void cmndHelp(void) { fprintf(stderr, "sesadmin - a console sesman administration tool\n"); fprintf(stderr, "syntax: sesadmin [] COMMAND [OPTIONS]\n\n"); fprintf(stderr, "-u=: username to connect to sesman [MANDATORY]\n"); fprintf(stderr, "-p=: password to connect to sesman (asked if not given)\n"); fprintf(stderr, "-s=: sesman host (default is localhost)\n"); fprintf(stderr, "-i= : sesman port (default 3350)\n"); fprintf(stderr, "-c= : command to execute on the server [MANDATORY]\n"); fprintf(stderr, " it can be one of those:\n"); fprintf(stderr, " list\n"); fprintf(stderr, " kill:\n"); } static void print_session(const struct SCP_DISCONNECTED_SESSION *s) { printf("Session ID: %d\n", s->SID); printf("\tSession type: %d\n", s->type); printf("\tScreen size: %dx%d, color depth %d\n", s->width, s->height, s->bpp); printf("\tIdle time: %d day(s) %d hour(s) %d minute(s)\n", s->idle_days, s->idle_hours, s->idle_minutes); printf("\tConnected: %04d/%02d/%02d %02d:%02d\n", s->conn_year, s->conn_month, s->conn_day, s->conn_hour, s->conn_minute); } void cmndList(struct SCP_CONNECTION *c) { struct SCP_DISCONNECTED_SESSION *dsl; enum SCP_CLIENT_STATES_E e; int scnt; int idx; e = scp_v1c_mng_get_session_list(c, &scnt, &dsl); if (e != SCP_CLIENT_STATE_LIST_OK) { printf("Error getting session list.\n"); return; } if (scnt > 0) { for (idx = 0; idx < scnt; idx++) { print_session(&dsl[idx]); } } else { printf("No sessions.\n"); } g_free(dsl); } void cmndKill(struct SCP_CONNECTION *c, struct SCP_SESSION *s) { } xrdp-0.9.5/sesman/tools/Makefile.am000644 001751 001751 00000002060 13174271344 017110 0ustar00metameta000000 000000 AM_CPPFLAGS = \ -DXRDP_CFG_PATH=\"${sysconfdir}/xrdp\" \ -DXRDP_SBIN_PATH=\"${sbindir}\" \ -DXRDP_SHARE_PATH=\"${datadir}/xrdp\" \ -DXRDP_PID_PATH=\"${localstatedir}/run\" \ -DXRDP_SOCKET_PATH=\"${socketdir}\" \ -I$(top_srcdir)/common \ -I$(top_srcdir)/sesman/libscp \ -I$(top_srcdir)/sesman if XRDP_DEBUG AM_CPPFLAGS += -DXRDP_DEBUG endif AM_CFLAGS = $(X_CFLAGS) bin_PROGRAMS = \ xrdp-sesrun \ xrdp-sesadmin \ xrdp-dis noinst_PROGRAMS = \ xrdp-sestest \ xrdp-xcon xrdp_sesrun_SOURCES = \ config.c \ sesrun.c \ tcp.c \ tcp.h xrdp_sestest_SOURCES = \ sestest.c xrdp_sesadmin_SOURCES = \ sesadmin.c xrdp_dis_SOURCES = \ dis.c xrdp_xcon_SOURCES = \ xcon.c xrdp_sesrun_LDADD = \ $(top_builddir)/common/libcommon.la xrdp_sestest_LDADD = \ $(top_builddir)/common/libcommon.la \ $(top_builddir)/sesman/libscp/libscp.la xrdp_sesadmin_LDADD = \ $(top_builddir)/common/libcommon.la \ $(top_builddir)/sesman/libscp/libscp.la xrdp_xcon_LDFLAGS = \ $(X_LIBS) xrdp_xcon_LDADD = \ $(X_PRE_LIBS) -lX11 $(X_EXTRA_LIBS) xrdp-0.9.5/sesman/tools/dis.c000644 001751 001751 00000003452 13174271344 016005 0ustar00metameta000000 000000 /** * xrdp: A Remote Desktop Protocol server. * * Copyright (C) Jay Sorg 2004-2013 * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ #if defined(HAVE_CONFIG_H) #include #endif #include #include #include #include #include #include #include "xrdp_sockets.h" int main(int argc, char **argv) { int sck; int dis; struct sockaddr_un sa; size_t len; char *p; char *display; if (argc != 1) { printf("xrdp disconnect utility\n"); printf("run with no parameters to disconnect you xrdp session\n"); return 0; } display = getenv("DISPLAY"); if (display == 0) { printf("display not set\n"); return 1; } dis = strtol(display + 1, &p, 10); memset(&sa, 0, sizeof(sa)); sa.sun_family = AF_UNIX; sprintf(sa.sun_path, XRDP_DISCONNECT_STR, dis); if (access(sa.sun_path, F_OK) != 0) { printf("not in an xrdp session\n"); return 1; } if ((sck = socket(PF_UNIX, SOCK_DGRAM, 0)) < 0) { printf("socket open error\n"); return 1; } len = sizeof(sa); if (sendto(sck, "sig", 4, 0, (struct sockaddr *)&sa, len) > 0) { printf("message sent ok\n"); } return 0; } xrdp-0.9.5/sesman/tools/sestest.c000644 001751 001751 00000015424 13174271344 016722 0ustar00metameta000000 000000 /* * sestest.c - an scp_v1 testing tool * (c) 2008 Simone Fedele * * 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 2 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. * * You should have received a copy of the GNU General Public License * along with this program; if not, write to the Free Software * Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA. */ #if defined(HAVE_CONFIG_H) #include #endif #include "arch.h" #include "tcp.h" #include "libscp.h" #include "parse.h" #include "log.h" #include int inputSession(struct SCP_SESSION *s); unsigned int menuSelect(unsigned int choices); int main(int argc, char **argv) { char buf[256]; struct SCP_SESSION *s; struct SCP_CONNECTION *c; /*struct SCP_DISCONNECTED_SESSION ds;*/ struct SCP_DISCONNECTED_SESSION *dsl; enum SCP_CLIENT_STATES_E e; struct log_config log; int end; int scnt; int idx; int sel; int sock; log.enable_syslog = 0; log.log_level = LOG_LEVEL_DEBUG; log.program_name = "sestest"; log.log_file = g_strdup("sestest.log"); log_start_from_param(&log); scp_init(); sock = g_tcp_socket(); if (sock < 0) return 1; s = scp_session_create(); c = scp_connection_create(sock); if (0 != g_tcp_connect(sock, "localhost", "3350")) { g_printf("error connecting"); return 1; } g_printf("001 - send connect request\n"); scp_session_set_type(s, SCP_SESSION_TYPE_XVNC); scp_session_set_version(s, 1); scp_session_set_height(s, 600); scp_session_set_width(s, 800); scp_session_set_bpp(s, 16); scp_session_set_rsr(s, 0); scp_session_set_locale(s, "it_IT"); scp_session_set_username(s, "prog"); scp_session_set_password(s, "prog"); scp_session_set_hostname(s, "odin"); // scp_session_set_addr(s, SCP_ADDRESS_TYPE_IPV4, "127.0.0.1"); // scp_session_set_display(struct SCP_SESSION* s, SCP_DISPLAY display); // scp_session_set_errstr(struct SCP_SESSION* s, char* str); /*s.type=SCP_SESSION_TYPE_XVNC; s.version=1; s.height=600; s.width=800; s.bpp=8; s.rsr=0; g_strncpy(s.locale,"it_IT 0123456789",18); s.username=g_malloc(256, 1); g_strncpy(s.username,"prog",255); s.password=g_malloc(256,1); g_strncpy(s.password, "prog", 255); g_printf("%s - %s\n", s.username, s.password); s.hostname=g_malloc(256,1); g_strncpy(s.hostname, "odin", 255); s.addr_type=SCP_ADDRESS_TYPE_IPV4; s.ipv4addr=0; s.errstr=0;*/ end = 0; e = scp_v1c_connect(c, s); while (!end) { switch (e) { case SCP_CLIENT_STATE_OK: g_printf("OK : display is %d\n", (short int)s->display); end = 1; break; case SCP_CLIENT_STATE_SESSION_LIST: g_printf("OK : session list needed\n"); e = scp_v1c_get_session_list(c, &scnt, &dsl); break; case SCP_CLIENT_STATE_LIST_OK: g_printf("OK : selecting a session:\n"); for (idx = 0; idx < scnt; idx++) { printf("Session \t%d - %d - %dx%dx%d - %d %d %d - %4d/%2d/%2d@%2d:%2d\n", \ (dsl[idx]).SID, (dsl[idx]).type, (dsl[idx]).width, (dsl[idx]).height, (dsl[idx]).bpp, \ (dsl[idx]).idle_days, (dsl[idx]).idle_hours, (dsl[idx]).idle_minutes, \ (dsl[idx]).conn_year, (dsl[idx]).conn_month, (dsl[idx]).conn_day, (dsl[idx]).conn_hour, (dsl[idx]).conn_minute); } sel = menuSelect(scnt); e = scp_v1c_select_session(c, s, dsl[sel - 1].SID); g_printf("\n return: %d \n", e); break; case SCP_CLIENT_STATE_RESEND_CREDENTIALS: g_printf("ERR: resend credentials - %s\n", s->errstr); g_printf(" username:"); if (scanf("%255s", buf) < 0) { g_writeln("error"); } scp_session_set_username(s, buf); g_printf(" password:"); if (scanf("%255s", buf) < 0) { g_writeln("error"); } scp_session_set_password(s, buf); e = scp_v1c_resend_credentials(c, s); break; case SCP_CLIENT_STATE_CONNECTION_DENIED: g_printf("ERR: connection denied: %s\n", s->errstr); end = 1; break; case SCP_CLIENT_STATE_PWD_CHANGE_REQ: g_printf("OK : password change required\n"); break; /*case SCP_CLIENT_STATE_RECONNECT_SINGLE: g_printf("OK : reconnect to 1 disconnected session\n"); e=scp_v1c_retrieve_session(&c, &s, &ds); g_printf("Session Type: %d on %d\n", ds.type, s.display); g_printf("Session Screen: %dx%dx%d\n", ds.height, ds.width, ds.bpp);*/ break; default: g_printf("protocol error: %d\n", e); end = 1; } } g_tcp_close(sock); scp_session_destroy(s); scp_connection_destroy(c); /*free_stream(c.in_s); free_stream(c.out_s);*/ return 0; } int inputSession(struct SCP_SESSION *s) { unsigned int integer; g_printf("username: "); if (scanf("%255s", s->username) < 0) { g_writeln("error"); } g_printf("password:"); if (scanf("%255s", s->password) < 0) { g_writeln("error"); } g_printf("hostname:"); if (scanf("%255s", s->hostname) < 0) { g_writeln("error"); } g_printf("session type:\n"); g_printf("%d: Xvnc\n", SCP_SESSION_TYPE_XVNC); g_printf("%d: x11rdp\n", SCP_SESSION_TYPE_XRDP); integer = menuSelect(1); if (integer == 1) { s->type = SCP_SESSION_TYPE_XRDP; } else { s->type = SCP_SESSION_TYPE_XVNC; } s->version = 1; s->height = 600; s->width = 800; s->bpp = 8; /* fixed for now */ s->rsr = 0; g_strncpy(s->locale, "it_IT 0123456789", 18); return 0; } tui32 menuSelect(tui32 choices) { tui32 sel; int ret; ret = scanf("%u", &sel); while ((ret == 0) || (sel > choices)) { g_printf("invalid choice."); ret = scanf("%u", &sel); } return sel; } xrdp-0.9.5/sesman/tools/Makefile.in000644 001751 001751 00000057076 13220730775 017142 0ustar00metameta000000 000000 # Makefile.in generated by automake 1.15.1 from Makefile.am. # @configure_input@ # Copyright (C) 1994-2017 Free Software Foundation, Inc. # This Makefile.in is free software; the Free Software Foundation # gives unlimited permission to copy and/or distribute it, # with or without modifications, as long as this notice is preserved. # This program is distributed in the hope that it will be useful, # but WITHOUT ANY WARRANTY, to the extent permitted by law; without # even the implied warranty of MERCHANTABILITY or FITNESS FOR A # PARTICULAR PURPOSE. @SET_MAKE@ VPATH = @srcdir@ am__is_gnu_make = { \ if test -z '$(MAKELEVEL)'; then \ false; \ elif test -n '$(MAKE_HOST)'; then \ true; \ elif test -n '$(MAKE_VERSION)' && test -n '$(CURDIR)'; then \ true; \ else \ false; \ fi; \ } am__make_running_with_option = \ case $${target_option-} in \ ?) ;; \ *) echo "am__make_running_with_option: internal error: invalid" \ "target option '$${target_option-}' specified" >&2; \ exit 1;; \ esac; \ has_opt=no; \ sane_makeflags=$$MAKEFLAGS; \ if $(am__is_gnu_make); then \ sane_makeflags=$$MFLAGS; \ else \ case $$MAKEFLAGS in \ *\\[\ \ ]*) \ bs=\\; \ sane_makeflags=`printf '%s\n' "$$MAKEFLAGS" \ | sed "s/$$bs$$bs[$$bs $$bs ]*//g"`;; \ esac; \ fi; \ skip_next=no; \ strip_trailopt () \ { \ flg=`printf '%s\n' "$$flg" | sed "s/$$1.*$$//"`; \ }; \ for flg in $$sane_makeflags; do \ test $$skip_next = yes && { skip_next=no; continue; }; \ case $$flg in \ *=*|--*) continue;; \ -*I) strip_trailopt 'I'; skip_next=yes;; \ -*I?*) strip_trailopt 'I';; \ -*O) strip_trailopt 'O'; skip_next=yes;; \ -*O?*) strip_trailopt 'O';; \ -*l) strip_trailopt 'l'; skip_next=yes;; \ -*l?*) strip_trailopt 'l';; \ -[dEDm]) skip_next=yes;; \ -[JT]) skip_next=yes;; \ esac; \ case $$flg in \ *$$target_option*) has_opt=yes; break;; \ esac; \ done; \ test $$has_opt = yes am__make_dryrun = (target_option=n; $(am__make_running_with_option)) am__make_keepgoing = (target_option=k; $(am__make_running_with_option)) pkgdatadir = $(datadir)/@PACKAGE@ pkgincludedir = $(includedir)/@PACKAGE@ pkglibdir = $(libdir)/@PACKAGE@ pkglibexecdir = $(libexecdir)/@PACKAGE@ am__cd = CDPATH="$${ZSH_VERSION+.}$(PATH_SEPARATOR)" && cd install_sh_DATA = $(install_sh) -c -m 644 install_sh_PROGRAM = $(install_sh) -c install_sh_SCRIPT = $(install_sh) -c INSTALL_HEADER = $(INSTALL_DATA) transform = $(program_transform_name) NORMAL_INSTALL = : PRE_INSTALL = : POST_INSTALL = : NORMAL_UNINSTALL = : PRE_UNINSTALL = : POST_UNINSTALL = : build_triplet = @build@ host_triplet = @host@ @XRDP_DEBUG_TRUE@am__append_1 = -DXRDP_DEBUG bin_PROGRAMS = xrdp-sesrun$(EXEEXT) xrdp-sesadmin$(EXEEXT) \ xrdp-dis$(EXEEXT) noinst_PROGRAMS = xrdp-sestest$(EXEEXT) xrdp-xcon$(EXEEXT) subdir = sesman/tools ACLOCAL_M4 = $(top_srcdir)/aclocal.m4 am__aclocal_m4_deps = $(top_srcdir)/m4/ax_append_compile_flags.m4 \ $(top_srcdir)/m4/ax_append_flag.m4 \ $(top_srcdir)/m4/ax_cflags_warn_all.m4 \ $(top_srcdir)/m4/ax_check_compile_flag.m4 \ $(top_srcdir)/m4/ax_gcc_func_attribute.m4 \ $(top_srcdir)/m4/ax_require_defined.m4 \ $(top_srcdir)/m4/ax_type_socklen_t.m4 \ $(top_srcdir)/m4/libtool.m4 $(top_srcdir)/m4/ltoptions.m4 \ $(top_srcdir)/m4/ltsugar.m4 $(top_srcdir)/m4/ltversion.m4 \ $(top_srcdir)/m4/lt~obsolete.m4 $(top_srcdir)/m4/pkg.m4 \ $(top_srcdir)/configure.ac am__configure_deps = $(am__aclocal_m4_deps) $(CONFIGURE_DEPENDENCIES) \ $(ACLOCAL_M4) DIST_COMMON = $(srcdir)/Makefile.am $(am__DIST_COMMON) mkinstalldirs = $(install_sh) -d CONFIG_HEADER = $(top_builddir)/config_ac.h CONFIG_CLEAN_FILES = CONFIG_CLEAN_VPATH_FILES = am__installdirs = "$(DESTDIR)$(bindir)" PROGRAMS = $(bin_PROGRAMS) $(noinst_PROGRAMS) am_xrdp_dis_OBJECTS = dis.$(OBJEXT) xrdp_dis_OBJECTS = $(am_xrdp_dis_OBJECTS) xrdp_dis_LDADD = $(LDADD) AM_V_lt = $(am__v_lt_@AM_V@) am__v_lt_ = $(am__v_lt_@AM_DEFAULT_V@) am__v_lt_0 = --silent am__v_lt_1 = am_xrdp_sesadmin_OBJECTS = sesadmin.$(OBJEXT) xrdp_sesadmin_OBJECTS = $(am_xrdp_sesadmin_OBJECTS) xrdp_sesadmin_DEPENDENCIES = $(top_builddir)/common/libcommon.la \ $(top_builddir)/sesman/libscp/libscp.la am_xrdp_sesrun_OBJECTS = config.$(OBJEXT) sesrun.$(OBJEXT) \ tcp.$(OBJEXT) xrdp_sesrun_OBJECTS = $(am_xrdp_sesrun_OBJECTS) xrdp_sesrun_DEPENDENCIES = $(top_builddir)/common/libcommon.la am_xrdp_sestest_OBJECTS = sestest.$(OBJEXT) xrdp_sestest_OBJECTS = $(am_xrdp_sestest_OBJECTS) xrdp_sestest_DEPENDENCIES = $(top_builddir)/common/libcommon.la \ $(top_builddir)/sesman/libscp/libscp.la am_xrdp_xcon_OBJECTS = xcon.$(OBJEXT) xrdp_xcon_OBJECTS = $(am_xrdp_xcon_OBJECTS) am__DEPENDENCIES_1 = xrdp_xcon_DEPENDENCIES = $(am__DEPENDENCIES_1) $(am__DEPENDENCIES_1) xrdp_xcon_LINK = $(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) \ $(LIBTOOLFLAGS) --mode=link $(CCLD) $(AM_CFLAGS) $(CFLAGS) \ $(xrdp_xcon_LDFLAGS) $(LDFLAGS) -o $@ AM_V_P = $(am__v_P_@AM_V@) am__v_P_ = $(am__v_P_@AM_DEFAULT_V@) am__v_P_0 = false am__v_P_1 = : AM_V_GEN = $(am__v_GEN_@AM_V@) am__v_GEN_ = $(am__v_GEN_@AM_DEFAULT_V@) am__v_GEN_0 = @echo " GEN " $@; am__v_GEN_1 = AM_V_at = $(am__v_at_@AM_V@) am__v_at_ = $(am__v_at_@AM_DEFAULT_V@) am__v_at_0 = @ am__v_at_1 = DEFAULT_INCLUDES = -I.@am__isrc@ -I$(top_builddir) depcomp = $(SHELL) $(top_srcdir)/depcomp am__depfiles_maybe = depfiles am__mv = mv -f COMPILE = $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) \ $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) LTCOMPILE = $(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) \ $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) \ $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) \ $(AM_CFLAGS) $(CFLAGS) AM_V_CC = $(am__v_CC_@AM_V@) am__v_CC_ = $(am__v_CC_@AM_DEFAULT_V@) am__v_CC_0 = @echo " CC " $@; am__v_CC_1 = CCLD = $(CC) LINK = $(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) \ $(LIBTOOLFLAGS) --mode=link $(CCLD) $(AM_CFLAGS) $(CFLAGS) \ $(AM_LDFLAGS) $(LDFLAGS) -o $@ AM_V_CCLD = $(am__v_CCLD_@AM_V@) am__v_CCLD_ = $(am__v_CCLD_@AM_DEFAULT_V@) am__v_CCLD_0 = @echo " CCLD " $@; am__v_CCLD_1 = SOURCES = $(xrdp_dis_SOURCES) $(xrdp_sesadmin_SOURCES) \ $(xrdp_sesrun_SOURCES) $(xrdp_sestest_SOURCES) \ $(xrdp_xcon_SOURCES) DIST_SOURCES = $(xrdp_dis_SOURCES) $(xrdp_sesadmin_SOURCES) \ $(xrdp_sesrun_SOURCES) $(xrdp_sestest_SOURCES) \ $(xrdp_xcon_SOURCES) am__can_run_installinfo = \ case $$AM_UPDATE_INFO_DIR in \ n|no|NO) false;; \ *) (install-info --version) >/dev/null 2>&1;; \ esac am__tagged_files = $(HEADERS) $(SOURCES) $(TAGS_FILES) $(LISP) # Read a list of newline-separated strings from the standard input, # and print each of them once, without duplicates. Input order is # *not* preserved. am__uniquify_input = $(AWK) '\ BEGIN { nonempty = 0; } \ { items[$$0] = 1; nonempty = 1; } \ END { if (nonempty) { for (i in items) print i; }; } \ ' # Make sure the list of sources is unique. This is necessary because, # e.g., the same source file might be shared among _SOURCES variables # for different programs/libraries. am__define_uniq_tagged_files = \ list='$(am__tagged_files)'; \ unique=`for i in $$list; do \ if test -f "$$i"; then echo $$i; else echo $(srcdir)/$$i; fi; \ done | $(am__uniquify_input)` ETAGS = etags CTAGS = ctags am__DIST_COMMON = $(srcdir)/Makefile.in $(top_srcdir)/depcomp DISTFILES = $(DIST_COMMON) $(DIST_SOURCES) $(TEXINFOS) $(EXTRA_DIST) ACLOCAL = @ACLOCAL@ AMTAR = @AMTAR@ AM_DEFAULT_VERBOSITY = @AM_DEFAULT_VERBOSITY@ AR = @AR@ AUTOCONF = @AUTOCONF@ AUTOHEADER = @AUTOHEADER@ AUTOMAKE = @AUTOMAKE@ AWK = @AWK@ CC = @CC@ CCDEPMODE = @CCDEPMODE@ CFLAGS = @CFLAGS@ CPP = @CPP@ CPPFLAGS = @CPPFLAGS@ CYGPATH_W = @CYGPATH_W@ DEFS = @DEFS@ DEPDIR = @DEPDIR@ DLLTOOL = @DLLTOOL@ DLOPEN_LIBS = @DLOPEN_LIBS@ DSYMUTIL = @DSYMUTIL@ DUMPBIN = @DUMPBIN@ ECHO_C = @ECHO_C@ ECHO_N = @ECHO_N@ ECHO_T = @ECHO_T@ EGREP = @EGREP@ EXEEXT = @EXEEXT@ FDKAAC_CFLAGS = @FDKAAC_CFLAGS@ FDKAAC_LIBS = @FDKAAC_LIBS@ FGREP = @FGREP@ FREERDP_CFLAGS = @FREERDP_CFLAGS@ FREERDP_LIBS = @FREERDP_LIBS@ FUSE_CFLAGS = @FUSE_CFLAGS@ FUSE_LIBS = @FUSE_LIBS@ GREP = @GREP@ INSTALL = @INSTALL@ INSTALL_DATA = @INSTALL_DATA@ INSTALL_PROGRAM = @INSTALL_PROGRAM@ INSTALL_SCRIPT = @INSTALL_SCRIPT@ INSTALL_STRIP_PROGRAM = @INSTALL_STRIP_PROGRAM@ LD = @LD@ LDFLAGS = @LDFLAGS@ LIBOBJS = @LIBOBJS@ LIBS = @LIBS@ LIBTOOL = @LIBTOOL@ LIPO = @LIPO@ LN_S = @LN_S@ LTLIBOBJS = @LTLIBOBJS@ LT_SYS_LIBRARY_PATH = @LT_SYS_LIBRARY_PATH@ MAKEINFO = @MAKEINFO@ MANIFEST_TOOL = @MANIFEST_TOOL@ MKDIR_P = @MKDIR_P@ NM = @NM@ NMEDIT = @NMEDIT@ OBJDUMP = @OBJDUMP@ OBJEXT = @OBJEXT@ OPENSSL = @OPENSSL@ OPENSSL_CFLAGS = @OPENSSL_CFLAGS@ OPENSSL_LIBS = @OPENSSL_LIBS@ OTOOL = @OTOOL@ OTOOL64 = @OTOOL64@ PACKAGE = @PACKAGE@ PACKAGE_BUGREPORT = @PACKAGE_BUGREPORT@ PACKAGE_NAME = @PACKAGE_NAME@ PACKAGE_STRING = @PACKAGE_STRING@ PACKAGE_TARNAME = @PACKAGE_TARNAME@ PACKAGE_URL = @PACKAGE_URL@ PACKAGE_VERSION = @PACKAGE_VERSION@ PAM_RULES = @PAM_RULES@ PATH_SEPARATOR = @PATH_SEPARATOR@ PIXMAN_CFLAGS = @PIXMAN_CFLAGS@ PIXMAN_LIBS = @PIXMAN_LIBS@ PKG_CONFIG = @PKG_CONFIG@ PKG_CONFIG_LIBDIR = @PKG_CONFIG_LIBDIR@ PKG_CONFIG_PATH = @PKG_CONFIG_PATH@ RANLIB = @RANLIB@ SED = @SED@ SET_MAKE = @SET_MAKE@ SHELL = @SHELL@ STRIP = @STRIP@ TurboJpegIncDir = @TurboJpegIncDir@ TurboJpegLibDir = @TurboJpegLibDir@ VERSION = @VERSION@ XMKMF = @XMKMF@ X_CFLAGS = @X_CFLAGS@ X_EXTRA_LIBS = @X_EXTRA_LIBS@ X_LIBS = @X_LIBS@ X_PRE_LIBS = @X_PRE_LIBS@ abs_builddir = @abs_builddir@ abs_srcdir = @abs_srcdir@ abs_top_builddir = @abs_top_builddir@ abs_top_srcdir = @abs_top_srcdir@ ac_ct_AR = @ac_ct_AR@ ac_ct_CC = @ac_ct_CC@ ac_ct_DUMPBIN = @ac_ct_DUMPBIN@ am__include = @am__include@ am__leading_dot = @am__leading_dot@ am__quote = @am__quote@ am__tar = @am__tar@ am__untar = @am__untar@ bindir = @bindir@ build = @build@ build_alias = @build_alias@ build_cpu = @build_cpu@ build_os = @build_os@ build_vendor = @build_vendor@ builddir = @builddir@ datadir = @datadir@ datarootdir = @datarootdir@ docdir = @docdir@ dvidir = @dvidir@ exec_prefix = @exec_prefix@ host = @host@ host_alias = @host_alias@ host_cpu = @host_cpu@ host_os = @host_os@ host_vendor = @host_vendor@ htmldir = @htmldir@ includedir = @includedir@ infodir = @infodir@ install_sh = @install_sh@ libdir = @libdir@ libexecdir = @libexecdir@ localedir = @localedir@ localstatedir = @localstatedir@ mandir = @mandir@ mkdir_p = @mkdir_p@ moduledir = @moduledir@ oldincludedir = @oldincludedir@ pdfdir = @pdfdir@ pkgconfigdir = @pkgconfigdir@ prefix = @prefix@ program_transform_name = @program_transform_name@ psdir = @psdir@ sbindir = @sbindir@ sharedstatedir = @sharedstatedir@ socketdir = @socketdir@ srcdir = @srcdir@ subdirs = @subdirs@ sysconfdir = @sysconfdir@ systemdsystemunitdir = @systemdsystemunitdir@ target_alias = @target_alias@ top_build_prefix = @top_build_prefix@ top_builddir = @top_builddir@ top_srcdir = @top_srcdir@ AM_CPPFLAGS = -DXRDP_CFG_PATH=\"${sysconfdir}/xrdp\" \ -DXRDP_SBIN_PATH=\"${sbindir}\" \ -DXRDP_SHARE_PATH=\"${datadir}/xrdp\" \ -DXRDP_PID_PATH=\"${localstatedir}/run\" \ -DXRDP_SOCKET_PATH=\"${socketdir}\" -I$(top_srcdir)/common \ -I$(top_srcdir)/sesman/libscp -I$(top_srcdir)/sesman \ $(am__append_1) AM_CFLAGS = $(X_CFLAGS) xrdp_sesrun_SOURCES = \ config.c \ sesrun.c \ tcp.c \ tcp.h xrdp_sestest_SOURCES = \ sestest.c xrdp_sesadmin_SOURCES = \ sesadmin.c xrdp_dis_SOURCES = \ dis.c xrdp_xcon_SOURCES = \ xcon.c xrdp_sesrun_LDADD = \ $(top_builddir)/common/libcommon.la xrdp_sestest_LDADD = \ $(top_builddir)/common/libcommon.la \ $(top_builddir)/sesman/libscp/libscp.la xrdp_sesadmin_LDADD = \ $(top_builddir)/common/libcommon.la \ $(top_builddir)/sesman/libscp/libscp.la xrdp_xcon_LDFLAGS = \ $(X_LIBS) xrdp_xcon_LDADD = \ $(X_PRE_LIBS) -lX11 $(X_EXTRA_LIBS) all: all-am .SUFFIXES: .SUFFIXES: .c .lo .o .obj $(srcdir)/Makefile.in: $(srcdir)/Makefile.am $(am__configure_deps) @for dep in $?; do \ case '$(am__configure_deps)' in \ *$$dep*) \ ( cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh ) \ && { if test -f $@; then exit 0; else break; fi; }; \ exit 1;; \ esac; \ done; \ echo ' cd $(top_srcdir) && $(AUTOMAKE) --foreign sesman/tools/Makefile'; \ $(am__cd) $(top_srcdir) && \ $(AUTOMAKE) --foreign sesman/tools/Makefile Makefile: $(srcdir)/Makefile.in $(top_builddir)/config.status @case '$?' in \ *config.status*) \ cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh;; \ *) \ echo ' cd $(top_builddir) && $(SHELL) ./config.status $(subdir)/$@ $(am__depfiles_maybe)'; \ cd $(top_builddir) && $(SHELL) ./config.status $(subdir)/$@ $(am__depfiles_maybe);; \ esac; $(top_builddir)/config.status: $(top_srcdir)/configure $(CONFIG_STATUS_DEPENDENCIES) cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh $(top_srcdir)/configure: $(am__configure_deps) cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh $(ACLOCAL_M4): $(am__aclocal_m4_deps) cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh $(am__aclocal_m4_deps): install-binPROGRAMS: $(bin_PROGRAMS) @$(NORMAL_INSTALL) @list='$(bin_PROGRAMS)'; test -n "$(bindir)" || list=; \ if test -n "$$list"; then \ echo " $(MKDIR_P) '$(DESTDIR)$(bindir)'"; \ $(MKDIR_P) "$(DESTDIR)$(bindir)" || exit 1; \ fi; \ for p in $$list; do echo "$$p $$p"; done | \ sed 's/$(EXEEXT)$$//' | \ while read p p1; do if test -f $$p \ || test -f $$p1 \ ; then echo "$$p"; echo "$$p"; else :; fi; \ done | \ sed -e 'p;s,.*/,,;n;h' \ -e 's|.*|.|' \ -e 'p;x;s,.*/,,;s/$(EXEEXT)$$//;$(transform);s/$$/$(EXEEXT)/' | \ sed 'N;N;N;s,\n, ,g' | \ $(AWK) 'BEGIN { files["."] = ""; dirs["."] = 1 } \ { d=$$3; if (dirs[d] != 1) { print "d", d; dirs[d] = 1 } \ if ($$2 == $$4) files[d] = files[d] " " $$1; \ else { print "f", $$3 "/" $$4, $$1; } } \ END { for (d in files) print "f", d, files[d] }' | \ while read type dir files; do \ if test "$$dir" = .; then dir=; else dir=/$$dir; fi; \ test -z "$$files" || { \ echo " $(INSTALL_PROGRAM_ENV) $(LIBTOOL) $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=install $(INSTALL_PROGRAM) $$files '$(DESTDIR)$(bindir)$$dir'"; \ $(INSTALL_PROGRAM_ENV) $(LIBTOOL) $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=install $(INSTALL_PROGRAM) $$files "$(DESTDIR)$(bindir)$$dir" || exit $$?; \ } \ ; done uninstall-binPROGRAMS: @$(NORMAL_UNINSTALL) @list='$(bin_PROGRAMS)'; test -n "$(bindir)" || list=; \ files=`for p in $$list; do echo "$$p"; done | \ sed -e 'h;s,^.*/,,;s/$(EXEEXT)$$//;$(transform)' \ -e 's/$$/$(EXEEXT)/' \ `; \ test -n "$$list" || exit 0; \ echo " ( cd '$(DESTDIR)$(bindir)' && rm -f" $$files ")"; \ cd "$(DESTDIR)$(bindir)" && rm -f $$files clean-binPROGRAMS: @list='$(bin_PROGRAMS)'; test -n "$$list" || exit 0; \ echo " rm -f" $$list; \ rm -f $$list || exit $$?; \ test -n "$(EXEEXT)" || exit 0; \ list=`for p in $$list; do echo "$$p"; done | sed 's/$(EXEEXT)$$//'`; \ echo " rm -f" $$list; \ rm -f $$list clean-noinstPROGRAMS: @list='$(noinst_PROGRAMS)'; test -n "$$list" || exit 0; \ echo " rm -f" $$list; \ rm -f $$list || exit $$?; \ test -n "$(EXEEXT)" || exit 0; \ list=`for p in $$list; do echo "$$p"; done | sed 's/$(EXEEXT)$$//'`; \ echo " rm -f" $$list; \ rm -f $$list xrdp-dis$(EXEEXT): $(xrdp_dis_OBJECTS) $(xrdp_dis_DEPENDENCIES) $(EXTRA_xrdp_dis_DEPENDENCIES) @rm -f xrdp-dis$(EXEEXT) $(AM_V_CCLD)$(LINK) $(xrdp_dis_OBJECTS) $(xrdp_dis_LDADD) $(LIBS) xrdp-sesadmin$(EXEEXT): $(xrdp_sesadmin_OBJECTS) $(xrdp_sesadmin_DEPENDENCIES) $(EXTRA_xrdp_sesadmin_DEPENDENCIES) @rm -f xrdp-sesadmin$(EXEEXT) $(AM_V_CCLD)$(LINK) $(xrdp_sesadmin_OBJECTS) $(xrdp_sesadmin_LDADD) $(LIBS) xrdp-sesrun$(EXEEXT): $(xrdp_sesrun_OBJECTS) $(xrdp_sesrun_DEPENDENCIES) $(EXTRA_xrdp_sesrun_DEPENDENCIES) @rm -f xrdp-sesrun$(EXEEXT) $(AM_V_CCLD)$(LINK) $(xrdp_sesrun_OBJECTS) $(xrdp_sesrun_LDADD) $(LIBS) xrdp-sestest$(EXEEXT): $(xrdp_sestest_OBJECTS) $(xrdp_sestest_DEPENDENCIES) $(EXTRA_xrdp_sestest_DEPENDENCIES) @rm -f xrdp-sestest$(EXEEXT) $(AM_V_CCLD)$(LINK) $(xrdp_sestest_OBJECTS) $(xrdp_sestest_LDADD) $(LIBS) xrdp-xcon$(EXEEXT): $(xrdp_xcon_OBJECTS) $(xrdp_xcon_DEPENDENCIES) $(EXTRA_xrdp_xcon_DEPENDENCIES) @rm -f xrdp-xcon$(EXEEXT) $(AM_V_CCLD)$(xrdp_xcon_LINK) $(xrdp_xcon_OBJECTS) $(xrdp_xcon_LDADD) $(LIBS) mostlyclean-compile: -rm -f *.$(OBJEXT) distclean-compile: -rm -f *.tab.c @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/config.Po@am__quote@ @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/dis.Po@am__quote@ @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/sesadmin.Po@am__quote@ @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/sesrun.Po@am__quote@ @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/sestest.Po@am__quote@ @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/tcp.Po@am__quote@ @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/xcon.Po@am__quote@ .c.o: @am__fastdepCC_TRUE@ $(AM_V_CC)$(COMPILE) -MT $@ -MD -MP -MF $(DEPDIR)/$*.Tpo -c -o $@ $< @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) $(DEPDIR)/$*.Tpo $(DEPDIR)/$*.Po @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='$<' object='$@' libtool=no @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(COMPILE) -c -o $@ $< .c.obj: @am__fastdepCC_TRUE@ $(AM_V_CC)$(COMPILE) -MT $@ -MD -MP -MF $(DEPDIR)/$*.Tpo -c -o $@ `$(CYGPATH_W) '$<'` @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) $(DEPDIR)/$*.Tpo $(DEPDIR)/$*.Po @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='$<' object='$@' libtool=no @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(COMPILE) -c -o $@ `$(CYGPATH_W) '$<'` .c.lo: @am__fastdepCC_TRUE@ $(AM_V_CC)$(LTCOMPILE) -MT $@ -MD -MP -MF $(DEPDIR)/$*.Tpo -c -o $@ $< @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) $(DEPDIR)/$*.Tpo $(DEPDIR)/$*.Plo @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='$<' object='$@' libtool=yes @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(LTCOMPILE) -c -o $@ $< mostlyclean-libtool: -rm -f *.lo clean-libtool: -rm -rf .libs _libs ID: $(am__tagged_files) $(am__define_uniq_tagged_files); mkid -fID $$unique tags: tags-am TAGS: tags tags-am: $(TAGS_DEPENDENCIES) $(am__tagged_files) set x; \ here=`pwd`; \ $(am__define_uniq_tagged_files); \ shift; \ if test -z "$(ETAGS_ARGS)$$*$$unique"; then :; else \ test -n "$$unique" || unique=$$empty_fix; \ if test $$# -gt 0; then \ $(ETAGS) $(ETAGSFLAGS) $(AM_ETAGSFLAGS) $(ETAGS_ARGS) \ "$$@" $$unique; \ else \ $(ETAGS) $(ETAGSFLAGS) $(AM_ETAGSFLAGS) $(ETAGS_ARGS) \ $$unique; \ fi; \ fi ctags: ctags-am CTAGS: ctags ctags-am: $(TAGS_DEPENDENCIES) $(am__tagged_files) $(am__define_uniq_tagged_files); \ test -z "$(CTAGS_ARGS)$$unique" \ || $(CTAGS) $(CTAGSFLAGS) $(AM_CTAGSFLAGS) $(CTAGS_ARGS) \ $$unique GTAGS: here=`$(am__cd) $(top_builddir) && pwd` \ && $(am__cd) $(top_srcdir) \ && gtags -i $(GTAGS_ARGS) "$$here" cscopelist: cscopelist-am cscopelist-am: $(am__tagged_files) list='$(am__tagged_files)'; \ case "$(srcdir)" in \ [\\/]* | ?:[\\/]*) sdir="$(srcdir)" ;; \ *) sdir=$(subdir)/$(srcdir) ;; \ esac; \ for i in $$list; do \ if test -f "$$i"; then \ echo "$(subdir)/$$i"; \ else \ echo "$$sdir/$$i"; \ fi; \ done >> $(top_builddir)/cscope.files distclean-tags: -rm -f TAGS ID GTAGS GRTAGS GSYMS GPATH tags distdir: $(DISTFILES) @srcdirstrip=`echo "$(srcdir)" | sed 's/[].[^$$\\*]/\\\\&/g'`; \ topsrcdirstrip=`echo "$(top_srcdir)" | sed 's/[].[^$$\\*]/\\\\&/g'`; \ list='$(DISTFILES)'; \ dist_files=`for file in $$list; do echo $$file; done | \ sed -e "s|^$$srcdirstrip/||;t" \ -e "s|^$$topsrcdirstrip/|$(top_builddir)/|;t"`; \ case $$dist_files in \ */*) $(MKDIR_P) `echo "$$dist_files" | \ sed '/\//!d;s|^|$(distdir)/|;s,/[^/]*$$,,' | \ sort -u` ;; \ esac; \ for file in $$dist_files; do \ if test -f $$file || test -d $$file; then d=.; else d=$(srcdir); fi; \ if test -d $$d/$$file; then \ dir=`echo "/$$file" | sed -e 's,/[^/]*$$,,'`; \ if test -d "$(distdir)/$$file"; then \ find "$(distdir)/$$file" -type d ! -perm -700 -exec chmod u+rwx {} \;; \ fi; \ if test -d $(srcdir)/$$file && test $$d != $(srcdir); then \ cp -fpR $(srcdir)/$$file "$(distdir)$$dir" || exit 1; \ find "$(distdir)/$$file" -type d ! -perm -700 -exec chmod u+rwx {} \;; \ fi; \ cp -fpR $$d/$$file "$(distdir)$$dir" || exit 1; \ else \ test -f "$(distdir)/$$file" \ || cp -p $$d/$$file "$(distdir)/$$file" \ || exit 1; \ fi; \ done check-am: all-am check: check-am all-am: Makefile $(PROGRAMS) installdirs: for dir in "$(DESTDIR)$(bindir)"; do \ test -z "$$dir" || $(MKDIR_P) "$$dir"; \ done install: install-am install-exec: install-exec-am install-data: install-data-am uninstall: uninstall-am install-am: all-am @$(MAKE) $(AM_MAKEFLAGS) install-exec-am install-data-am installcheck: installcheck-am install-strip: if test -z '$(STRIP)'; then \ $(MAKE) $(AM_MAKEFLAGS) INSTALL_PROGRAM="$(INSTALL_STRIP_PROGRAM)" \ install_sh_PROGRAM="$(INSTALL_STRIP_PROGRAM)" INSTALL_STRIP_FLAG=-s \ install; \ else \ $(MAKE) $(AM_MAKEFLAGS) INSTALL_PROGRAM="$(INSTALL_STRIP_PROGRAM)" \ install_sh_PROGRAM="$(INSTALL_STRIP_PROGRAM)" INSTALL_STRIP_FLAG=-s \ "INSTALL_PROGRAM_ENV=STRIPPROG='$(STRIP)'" install; \ fi mostlyclean-generic: clean-generic: distclean-generic: -test -z "$(CONFIG_CLEAN_FILES)" || rm -f $(CONFIG_CLEAN_FILES) -test . = "$(srcdir)" || test -z "$(CONFIG_CLEAN_VPATH_FILES)" || rm -f $(CONFIG_CLEAN_VPATH_FILES) maintainer-clean-generic: @echo "This command is intended for maintainers to use" @echo "it deletes files that may require special tools to rebuild." clean: clean-am clean-am: clean-binPROGRAMS clean-generic clean-libtool \ clean-noinstPROGRAMS mostlyclean-am distclean: distclean-am -rm -rf ./$(DEPDIR) -rm -f Makefile distclean-am: clean-am distclean-compile distclean-generic \ distclean-tags dvi: dvi-am dvi-am: html: html-am html-am: info: info-am info-am: install-data-am: install-dvi: install-dvi-am install-dvi-am: install-exec-am: install-binPROGRAMS install-html: install-html-am install-html-am: install-info: install-info-am install-info-am: install-man: install-pdf: install-pdf-am install-pdf-am: install-ps: install-ps-am install-ps-am: installcheck-am: maintainer-clean: maintainer-clean-am -rm -rf ./$(DEPDIR) -rm -f Makefile maintainer-clean-am: distclean-am maintainer-clean-generic mostlyclean: mostlyclean-am mostlyclean-am: mostlyclean-compile mostlyclean-generic \ mostlyclean-libtool pdf: pdf-am pdf-am: ps: ps-am ps-am: uninstall-am: uninstall-binPROGRAMS .MAKE: install-am install-strip .PHONY: CTAGS GTAGS TAGS all all-am check check-am clean \ clean-binPROGRAMS clean-generic clean-libtool \ clean-noinstPROGRAMS cscopelist-am ctags ctags-am distclean \ distclean-compile distclean-generic distclean-libtool \ distclean-tags distdir dvi dvi-am html html-am info info-am \ install install-am install-binPROGRAMS install-data \ install-data-am install-dvi install-dvi-am install-exec \ install-exec-am install-html install-html-am install-info \ install-info-am install-man install-pdf install-pdf-am \ install-ps install-ps-am install-strip installcheck \ installcheck-am installdirs maintainer-clean \ maintainer-clean-generic mostlyclean mostlyclean-compile \ mostlyclean-generic mostlyclean-libtool pdf pdf-am ps ps-am \ tags tags-am uninstall uninstall-am uninstall-binPROGRAMS .PRECIOUS: Makefile # Tell versions [3.59,3.63) of GNU make to not export all variables. # Otherwise a system limit (for SysV at least) may be exceeded. .NOEXPORT: xrdp-0.9.5/sesman/tools/sesrun.c000644 001751 001751 00000007133 13174271344 016545 0ustar00metameta000000 000000 /** * xrdp: A Remote Desktop Protocol server. * * Copyright (C) Jay Sorg 2004-2013 * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ /** * * @file sesrun.c * @brief An utility to start a session * @author Jay Sorg, Simone Fedele * */ #if defined(HAVE_CONFIG_H) #include #endif #include "sesman.h" #include "tcp.h" struct config_sesman g_cfg; /* config.h */ /******************************************************************************/ int main(int argc, char **argv) { int sck; int code; int i; int size; int version; int width; int height; int bpp; int display; struct stream *in_s; struct stream *out_s; char *username; char *password; long data; if (0 != config_read(&g_cfg)) { g_printf("sesrun: error reading config. quitting.\n"); return 1; } if (argc == 1) { g_printf("xrdp session starter v0.1\n"); g_printf("\nusage:\n"); g_printf("sesrun \n"); } else if (argc == 7) { username = argv[2]; password = argv[3]; width = g_atoi(argv[4]); height = g_atoi(argv[5]); bpp = g_atoi(argv[6]); make_stream(in_s); init_stream(in_s, 8192); make_stream(out_s); init_stream(out_s, 8192); sck = g_tcp_socket(); if (sck < 0) return 1; if (g_tcp_connect(sck, argv[1], g_cfg.listen_port) == 0) { s_push_layer(out_s, channel_hdr, 8); out_uint16_be(out_s, 0); /* code */ i = g_strlen(username); out_uint16_be(out_s, i); out_uint8a(out_s, username, i); i = g_strlen(password); out_uint16_be(out_s, i); out_uint8a(out_s, password, i); out_uint16_be(out_s, width); out_uint16_be(out_s, height); out_uint16_be(out_s, bpp); s_mark_end(out_s); s_pop_layer(out_s, channel_hdr); out_uint32_be(out_s, 0); /* version */ out_uint32_be(out_s, out_s->end - out_s->data); /* size */ tcp_force_send(sck, out_s->data, out_s->end - out_s->data); if (tcp_force_recv(sck, in_s->data, 8) == 0) { in_uint32_be(in_s, version); in_uint32_be(in_s, size); init_stream(in_s, 8192); if (tcp_force_recv(sck, in_s->data, size - 8) == 0) { if (version == 0) { in_uint16_be(in_s, code); if (code == 3) { in_uint16_be(in_s, data); in_uint16_be(in_s, display); g_printf("ok %d display %d\n", (int)data, display); } } } } } else { g_printf("connect error\n"); } g_tcp_close(sck); free_stream(in_s); free_stream(out_s); } return 0; } xrdp-0.9.5/sesman/tools/tcp.h000644 001751 001751 00000002743 13174271344 016023 0ustar00metameta000000 000000 /** * xrdp: A Remote Desktop Protocol server. * * Copyright (C) Jay Sorg 2004-2013 * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ /** * * @file tcp.h * @brief Tcp stream functions declarations * @author Jay Sorg, Simone Fedele * */ #ifndef TCP_H #define TCP_H /** * * @brief Force receiving data from tcp stream * @param sck The socket to read from * @param data Data buffer * @param len Data buffer size * @return 0 on success, 1 on error * */ int tcp_force_recv(int sck, char* data, int len); /** * * @brief Force sending data to tcp stream * @param sck the socket to write to * @param data Data buffer * @param len Data buffer size * @return 0 on success, 1 on error * */ int tcp_force_send(int sck, char* data, int len); /** * * @brief Binds the listening socket * @param sck Listening socket * @param addr Listening address * @param port Listening port * @return 0 on success, -1 on error * */ int tcp_bind(int sck, char* addr, char* port); #endif xrdp-0.9.5/sesman/tools/config.c000644 001751 001751 00000000121 13174271344 016461 0ustar00metameta000000 000000 #if defined(HAVE_CONFIG_H) #include #endif #include "../config.c" xrdp-0.9.5/sesman/tools/xcon.c000644 001751 001751 00000002562 13174271344 016176 0ustar00metameta000000 000000 /** * xrdp: A Remote Desktop Protocol server. * * Copyright (C) Jay Sorg 2004-2013 * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ #if defined(HAVE_CONFIG_H) #include #endif #include #include #include #include #include #include Display *g_display = 0; int g_x_socket = 0; int main(int argc, char **argv) { fd_set rfds; int i1; XEvent xevent; g_display = XOpenDisplay(0); if (g_display == 0) { printf("XOpenDisplay failed\n"); return 0; } g_x_socket = XConnectionNumber(g_display); while (1) { FD_ZERO(&rfds); FD_SET(g_x_socket, &rfds); i1 = select(g_x_socket + 1, &rfds, 0, 0, 0); if (i1 < 0) { break; } XNextEvent(g_display, &xevent); } return 0; } xrdp-0.9.5/xorg/X11R7.6/000755 001751 001751 00000000000 13133557325 014336 5ustar00metameta000000 000000 xrdp-0.9.5/xorg/tests/000755 001751 001751 00000000000 13125122134 014535 5ustar00metameta000000 000000 xrdp-0.9.5/xorg/.gitignore000644 001751 001751 00000000012 13127114621 015360 0ustar00metameta000000 000000 !Makefile xrdp-0.9.5/xorg/debuild/000755 001751 001751 00000000000 13125122134 015003 5ustar00metameta000000 000000 xrdp-0.9.5/xorg/readme.txt000644 001751 001751 00000000024 13124203623 015367 0ustar00metameta000000 000000 xorg server readme xrdp-0.9.5/xorg/debuild/x11rdp-files/000755 001751 001751 00000000000 13125122134 017222 5ustar00metameta000000 000000 xrdp-0.9.5/xorg/debuild/debX11rdp.sh000755 001751 001751 00000001550 13125122134 017075 0ustar00metameta000000 000000 #!/bin/bash # receives version, release number and source directory as arguments VERSION=$1 RELEASE=$2 SRCDIR=$3 PKGDEST=$4 PACKDIR=x11rdp-files DESTDIR=$PACKDIR/opt NAME=x11rdp ARCH=$( dpkg --print-architecture ) sed -i -e "s/DUMMYVERINFO/$VERSION-$RELEASE/" $PACKDIR/DEBIAN/control sed -i -e "s/DUMMYARCHINFO/$ARCH/" $PACKDIR/DEBIAN/control # need a different delimiter, since it has a path sed -i -e "s,DUMMYDIRINFO,$SRCDIR," $PACKDIR/DEBIAN/postinst mkdir -p $DESTDIR cp -Rf $SRCDIR $DESTDIR dpkg-deb --build $PACKDIR $PKGDEST/${NAME}_$VERSION-${RELEASE}_${ARCH}.deb # revert to initial state rm -rf $DESTDIR sed -i -e "s/$VERSION-$RELEASE/DUMMYVERINFO/" $PACKDIR/DEBIAN/control sed -i -e "s/$ARCH/DUMMYARCHINFO/" $PACKDIR/DEBIAN/control # need a different delimiter, since it has a path sed -i -e "s,$SRCDIR,DUMMYDIRINFO," $PACKDIR/DEBIAN/postinst xrdp-0.9.5/xorg/debuild/x11rdp-files/DEBIAN/000755 001751 001751 00000000000 13125122134 020144 5ustar00metameta000000 000000 xrdp-0.9.5/xorg/debuild/x11rdp-files/DEBIAN/control000644 001751 001751 00000000332 13125122134 021545 0ustar00metameta000000 000000 Package: x11rdp Version: DUMMYVERINFO Section: unknown Priority: optional Architecture: DUMMYARCHINFO Maintainer: Angulo Solido Description: X11rdp backend for the xrdp remote access server xrdp-0.9.5/xorg/debuild/x11rdp-files/DEBIAN/postinst000755 001751 001751 00000000677 13125122134 021767 0ustar00metameta000000 000000 #!/bin/bash X11DIR=DUMMYDIRINFO # make the /usr/bin/X11rdp symbolic link if it doesn't exist... if [ ! -e /usr/bin/X11rdp ] then if [ -e $X11DIR/bin/X11rdp ] then ln -s $X11DIR/bin/X11rdp /usr/bin/X11rdp else clear echo "There was a problem... the $X11DIR/bin/X11rdp binary could not be found. Did the compilation complete?" echo "Stopped. Please investigate what went wrong." exit fi fi xrdp-0.9.5/xorg/tests/nx/000755 001751 001751 00000000000 13125122134 015162 5ustar00metameta000000 000000 xrdp-0.9.5/xorg/tests/xdemo/000755 001751 001751 00000000000 13174271344 015665 5ustar00metameta000000 000000 xrdp-0.9.5/xorg/tests/randr/000755 001751 001751 00000000000 13127114621 015647 5ustar00metameta000000 000000 xrdp-0.9.5/xorg/tests/randr/trandr.c000644 001751 001751 00000010273 13127114621 017310 0ustar00metameta000000 000000 /** * xrdp: A Remote Desktop Protocol server. * * Copyright (C) Jay Sorg 2013 * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ #include #include #include #include #include #include #include #include #include #include #include #include #include static int process_randr(Display *disp, Screen *screen, int screenNumber, Window win, int event_base, XEvent *ev) { XRRScreenChangeNotifyEvent *rr_screen_change_notify; switch (ev->type - event_base) { case RRScreenChangeNotify: XRRUpdateConfiguration(ev); rr_screen_change_notify = (XRRScreenChangeNotifyEvent *) ev; printf("RRScreenChangeNotify: width %d height %d\n", rr_screen_change_notify->width, rr_screen_change_notify->height); printf("DisplayWidth %d DisplayHeight %d\n", DisplayWidth(disp, screenNumber), DisplayHeight(disp, screenNumber)); break; } return 0; } int main(int argc, char **argv) { XEvent ev; Display *disp; Window win; Window root_window; Screen *screen; int screenNumber; int eventMask; int white; int black; int rr_event_base; int rr_error_base; int ver_maj; int ver_min; int cont; disp = XOpenDisplay(0); if (disp == 0) { printf("error opening display\n"); return 1; } screenNumber = DefaultScreen(disp); white = WhitePixel(disp, screenNumber); black = BlackPixel(disp, screenNumber); screen = ScreenOfDisplay(disp, screenNumber); root_window = RootWindowOfScreen(screen); eventMask = StructureNotifyMask; XSelectInput(disp, root_window, eventMask); win = XCreateSimpleWindow(disp, root_window, 50, 50, 250, 250, 0, black, white); XMapWindow(disp, win); eventMask = StructureNotifyMask | VisibilityChangeMask; XSelectInput(disp, win, eventMask); eventMask = KeyPressMask | KeyReleaseMask | ButtonPressMask | ButtonReleaseMask | VisibilityChangeMask | FocusChangeMask | StructureNotifyMask | PointerMotionMask | ExposureMask | PropertyChangeMask; XSelectInput(disp, win, eventMask); if (!XRRQueryExtension(disp, &rr_event_base, &rr_error_base)) { printf("error randr\n"); return 1; } XRRQueryVersion(disp, &ver_maj, &ver_min); printf("randr version %d %d\n", ver_maj, ver_min); XRRSelectInput(disp, win, RRScreenChangeNotifyMask); cont = 1; while (cont) { XNextEvent(disp, &ev); switch (ev.type) { case ButtonPress: cont = 0; break; case ClientMessage: printf("ClientMessage\n"); break; case ConfigureNotify: if (ev.xconfigure.window == root_window) { XRRUpdateConfiguration(&ev); printf("ConfigureNotify for root window " "width %d height %d\n", ev.xconfigure.width, ev.xconfigure.height); } break; default: if ((ev.type >= rr_event_base) && (ev.type < rr_event_base + RRNumberEvents)) { printf("randr\n"); process_randr(disp, screen, screenNumber, win, rr_event_base, &ev); } break; } } return 0; } xrdp-0.9.5/xorg/tests/randr/Makefile000644 001751 001751 00000000226 13125122134 017303 0ustar00metameta000000 000000 CFLAGS = -O2 -Wall all: test-randr test-randr: trandr.c gcc $(CFLAGS) trandr.c -o test-randr -lX11 -lXrandr .PHONY clean: rm -f *.o test-randr xrdp-0.9.5/xorg/tests/xdemo/README.txt000644 001751 001751 00000000045 13125122134 017346 0ustar00metameta000000 000000 this is a program to test xwindows xrdp-0.9.5/xorg/tests/xdemo/bmp_parser.c000644 001751 001751 00000013705 13127114621 020161 0ustar00metameta000000 000000 /** * xrdp: A Remote Desktop Protocol server. * * Copyright (C) Laxmikant Rashinkar 2004-2012 * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ #include #include #include #include #include #include #include "common.h" // multi byte values are stored in little endian struct bmp_magic { char magic[2]; }; struct bmp_hdr { uint32_t size; // file size in bytes uint16_t reserved1; uint16_t reserved2; uint32_t offset; // offset to image data, in bytes }; struct dib_hdr { uint32_t hdr_size; int32_t width; int32_t height; uint16_t nplanes; uint16_t bpp; uint32_t compress_type; uint32_t image_size; int32_t hres; int32_t vres; uint32_t ncolors; uint32_t nimpcolors; }; // forward declarations int parse_bmp(char *filename, struct pic_info *pic_info); int parse_bmp_24(struct bmp_hdr *bmp_hdr, struct dib_hdr *dib_hdr, int fd, struct pic_info *pic_info); int parse_bmp(char *filename, struct pic_info *pic_info) { int got_magic; int fd; int rval; struct bmp_magic magic; struct bmp_hdr bmp_hdr; struct dib_hdr dib_hdr; if ((fd = open(filename, O_RDONLY)) < 0) { printf("error opening %s\n", filename); return -1; } // read BMP magic... if ((rval = read(fd, magic.magic, 2)) != 2) { fprintf(stderr, "error reading BMP signature from file %s\n", filename); return -1; } got_magic = 0; // ...and confirm that this is indeed a BMP file if ((magic.magic[0] == 'B') && (magic.magic[1] == 'M')) { // BM – Windows 3.1x, 95, NT, ... etc got_magic = 1; } else if ((magic.magic[0] == 'B') && (magic.magic[1] == 'A')) { // BA – OS/2 struct Bitmap Array got_magic = 1; } else if ((magic.magic[0] == 'C') && (magic.magic[1] == 'I')) { // CI – OS/2 struct Color Icon got_magic = 1; } else if ((magic.magic[0] == 'C') && (magic.magic[1] == 'P')) { // CP – OS/2 const Color Pointer got_magic = 1; } else if ((magic.magic[0] == 'I') && (magic.magic[1] == 'C')) { // IC – OS/2 struct Icon got_magic = 1; } else if ((magic.magic[0] == 'P') && (magic.magic[1] == 'T')) { // PT – OS/2 Pointer got_magic = 1; } if (!got_magic) { fprintf(stderr, "%s is not a valid BMP file\n", filename); return -1; } // read BMP header if ((rval = read(fd, &bmp_hdr, sizeof(bmp_hdr))) < sizeof(bmp_hdr)) { fprintf(stderr, "error BMP header from file %s\n", filename); return -1; } // read DIB header if ((rval = read(fd, &dib_hdr, sizeof(dib_hdr))) < sizeof(dib_hdr)) { fprintf(stderr, "error reading DIB header from file %s\n", filename); return -1; } #if 0 printf("header size: %d\n", dib_hdr.hdr_size); printf("width: %d\n", dib_hdr.width); printf("height: %d\n", dib_hdr.height); printf("num planes: %d\n", dib_hdr.nplanes); printf("bpp: %d\n", dib_hdr.bpp); printf("comp type: %d\n", dib_hdr.compress_type); printf("image size: %d\n", dib_hdr.image_size); printf("hres: %d\n", dib_hdr.hres); printf("vres: %d\n", dib_hdr.vres); printf("ncolors: %d\n", dib_hdr.ncolors); printf("nimpcolors: %d\n", dib_hdr.nimpcolors); #endif if (dib_hdr.compress_type) { printf("TODO: compressed images not yet supported\n"); return -1; } pic_info->width = dib_hdr.width; pic_info->height = dib_hdr.height; if (dib_hdr.bpp == 24) { rval = parse_bmp_24(&bmp_hdr, &dib_hdr, fd, pic_info); } close(fd); return rval; } /** * extract 24bit BMP data from image file * * @return 0 on success * @return -1 on failure */ int parse_bmp_24( struct bmp_hdr *bmp_hdr, struct dib_hdr *dib_hdr, int fd, struct pic_info *pic_info ) { char *file_data; char *ptr_file_data; char *mem_data; char *ptr_mem_data; char *cptr; int w = dib_hdr->width; // picture width int h = dib_hdr->height; // picture height int bpl; // bytes per line int bytes; int i; int j; // bytes per image line = width x bytes_per_pixel + padding i = (w * 3) % 4; j = (i == 0) ? 0 : 4 - i; bpl = w * 3 + j; // 24 bit depth, no alpha channel file_data = (char *) malloc(h * bpl); // point to first line in image data, which is stored in reverse order ptr_file_data = (file_data + dib_hdr->image_size) - bpl; // 24 bit depth, with alpha channel mem_data = (char *) malloc(w * h * 4); ptr_mem_data = mem_data; pic_info->pixel_data = ptr_mem_data; // seek to beginning of pixel data lseek(fd, bmp_hdr->offset, SEEK_SET); // read all pixel data bytes = read(fd, file_data, dib_hdr->image_size); // convert 24bit to 24 bit with alpha and store in reverse for (i = 0; i < h; i ++) { cptr = ptr_file_data; for (j = 0; j < w; j++) { *ptr_mem_data++ = *cptr++; // blue value *ptr_mem_data++ = *cptr++; // green value *ptr_mem_data++ = *cptr++; // red value *ptr_mem_data++ = 0; // alpha channel } ptr_file_data -= bpl; } free(file_data); return 0; } xrdp-0.9.5/xorg/tests/xdemo/Makefile000644 001751 001751 00000000225 13174271344 017324 0ustar00metameta000000 000000 CFLAGS = -Werror -Wall all: xdemo xdemo: xdemo.c bmp_parser.c gcc $(CFLAGS) xdemo.c bmp_parser.c -o xdemo -lX11 .PHONY clean: rm -f *.o xdemo xrdp-0.9.5/xorg/tests/xdemo/yosemite.bmp000644 001751 001751 00007020066 13127114621 020226 0ustar00metameta000000 000000 BM6 6(€À   7UA8R;5M72N82O=7WC8ZB5VB7RC3K@+J7-K9/N94R=8U@8V>8T=5T>2YC+U@*L84I97K95J+YC+XD)N<,G83N=/O<0XC3UB2P=*F3)F3,M9.R>/N;0H50H4/J7/N93P<1N<.K<-M>0S@0T>0Q>1U@.T>&H4-I61H:,N=,Q>*T=+R<'M8#G4)G3'D/&F1"G1&E1'>+%;)#9)#:,(?0(@/+C1)G80J:5L96N;7U@0R=/I8'C3%D4'G6'H4(I1$E2(H4)I6)E2#<+$:'$7(#6'"6& 1#%7&(9('=(":($?-&E3)M9(P8-T;)P8(L7&I6*L;)I:)M;*P>&N=$N;'P>)P>(M=%H7+M<)L8*O8&M7(H5(E2$C-&H3%G4'D1"?09* <,(E4)H5'I5.L<(E3&E0-I5+F5!<,";.'C5'D5&E6(H7'G6(E6)G6,M8(I4*G3)C2)C1(B/)C1&C0$D4 D4'<0)?0.E7)G4%F6&M:$N8#H2#H2!H2$J4&G2(J7*D2';,%4&!0$$6(1$+5&"9*!;+!<+$5#,*,"6#%='&C+&A,%@0$;.-" + 1#%:)$<*%A-%A-$@*)G20L9*>/*)('')*/ 7"9 !9%!3&. .$6$$8%&:)$6%&:)'=+)@.%A+)G1&F1!@.!9*+7)$:-&8+ 1$%6)+,)>.&8)"0#!+ "/##0$&0$"*'()5((;,%?/%?00"'(&')($/"'?-*C1)A/'?-';*&8''3(#/"!/!"2#/.++2%.",+!1# 0". /!#3'!1$!/$.#+ 2$!3&.!)*))#(,.!!+ %)-$+,/!*'%%%" "! $',)+*('$(%!&$$!*%%!#%"  ##$%"%!1!$9&1G55D7 %%3"%;+$C6-A4$E2%N6%J9*K<%G6(H4,J5(H3,Q;+K6$>+-G/-I3(D1%A/(D1(C0+D2'F3(L4/N7*D1+D40L8-I5+G4-G8/G:*@3+@3&?.'E0*J1(K1+M38$%A/'@2)?3'A3%G7$K91W@5U@0J:+A4)>/#=($<*%;-)D3'G2(M3+J5!B--N:7UB&A/%=-(C3*G3+F1.>,%0 -4"4")@.+@/(<*#7$ 4!"6#$7$!5""9&,G21G.(>'';',, .$1#2%$3'!1&0$2%.3!'=+':)1 .1""9*4%0!. (&1 2!!1 */2.'%#"""  ! #".!#3&*##&';-:,+ !')!)) 1 !D4+G7)?/5#;'&K4'>3!<.'D4)J8.O=%C47+ 3&2""@+*Q75^C.T=)O7=cL:]H<+)C5">1 +YC'QA/J@$D6 F63^M'L<:, 7(8)$B3$D5#B0!>*6T?5P9/F30K83P?2R=4V?6XA7SB4N>/J8/K8/N91S>4XB3ZC5R@1N;/P<+Q*N=(E5)G6/S?+S>-Q=-M9*G4(G4*L8&K7,L9.K7/K7/O;,S<0P<.O=)K:-N>-O=.R=/T@1VB.T>)M7'D2*B3+K:-N;)M9$H3!C0"B0'E1+G3(G2%F1+I5)@-&<)(>/+A3(A1*E4*E1)C4.I7/L8.L66S=4R=2L:+G7)I8+J9(H5&G2)F3(D1'F2*E2%>,#:( 6&3$5& 5&!5&&;*'?-#=*-I9#C3'L6,R=.U=-S<&L8&L8*P=+N>,N:/S?+Q<)O:&L7$I5&K<$G6-O?.R>-S='N7&G5)F4(E3$E3$E3&B0!>, :) ;+'B2'D3(G6(H8(G6(E4+G5'B2!:,">,#?/"B1(H7+L;'I8,J:*I8+N8.Q;-O:+I6*G4,I6)E1(E4+J:'J8%@4+H80O=)K7'N:)Q?&N8#F2#F2#K5%L7)K6.P?'D3(>/#5'$6(!4%1#1"!6'"8)#;*":(1// 2 $9')B+(C/+F4)C4$=/"5'"1$%7&%:(#;)(A0$>+#;('A-.J6$<, 0!)'+''#, 6#$?)%<+"4'1%2#"7%"7'%9)&=+(?-&=**C0'C+(E/&A.8*-"(3%$8*%7*$5(*=/.A3-?0(;+(;*(=+(>+'>+)<++>,+=/&7)$1$!,,#. &0#('#1"):,);-%9+!4'(&(''(* 4&&C0)F3'C1&B/%>,&:(%4'!1$ 0"/!1/*-0#0#/"-/ 0!3$ 6 +7)-"0%#5(#5(!3'/!, ++))(-+'$' .!*")*+$""#$#"#(-!-!)% #$!###&'%"###" !"! ,#0"(8)&<*';*!&* %7*,$1#%E2)O9'H8/K=*G6(I5.L8,K8,P;.P:-J61M60L7)F5"A0(D5.H8*C1)H4-O9/L8*C0+D3.J7*E2(D1-G6)C2(A1*D4+F3,J5'F0+I4'B01&A1.H:,B4+F6'H6(N:2W>0O8*D3+C4+D1#=)'@.&>/)C3)H3+M4+G4)H3/N;6TA'C0&>.%8*$;*%;(%3" ,#2%$8'#9')>,(:*':*#6'$6& 2"$5$$8&%=**D0(A,&;(%6%#2%- )5,!"0A2&@2';.#8)'A0(I6*M;&L9$L8)R<4[H#I85&#;+(D2+P9.V=1Y?*C0)F2%F2*N:&I:/PB3Q@3PA4& !B03fM,U?(J9*N:3\D4_I$L/T?.N?*E4-G8,K8.Q>1T?+S:/U>0U?)M7.P8/Q80N;0P81Q82R@1S@.P8/Q81M83K9-E4,E3,H4,I3+I2'I0'G2(I5)G4-G6%@0*C3,G7/K:-L;-N8,J31L8-F5(D5*G6/P81S;0V=/S=-M;+J:)L8-O=-I9'@1(C2.Q=*P<.S>,M9-M:*K8+N:)J6)F2,G3/M9+O7,T;-O,O;+N;/Q=.Q=*P<+U=,U>)N8"?.%=.(D0,H5(G4%C1#A1$?.%C/,G2(D0'I4,J5+B/*@-.E3*D4+F5-J7%D/)>0)D1*M8)L4,I32M9/J81N:,K;)L8&I5$G2*E2%A.)D2&B0(@/&>-"8&4"1#3#!4%"7)"=+%@/-J:&F5&G7(L9*P:.T@*Q<'Q;+T?.WC+O<.S>4ZF.U@,S?%L6$J8(N<1TA5WC.T?)P;$G6)F6'A3&D4!>/"<-$>+#=*'@.+C3(B2'B3&F7'E7(E6)C5&?1"<-"@/#A.!?,%F3&I9#F5'G6'G4+N:+O9*M8(K6)J8+J6+H7!?/)G6(I6#C4)H9,O;*L8&J8$J8&I7%D3%E4#I6%L9"F4)J:(F6(B2$:+"7$!7%1"#6'"5%4##9'$;'4#03!"8&#=)'B/-D4*D4&@2#<.!:*$9&*=*%:'$;)*@.%:+2#)<**E2">.2#*.#!2%+))"4& 5#+@/#9("4& 4( 7*!9*!5'#9*)A/'A/$?)'C-'A*'@-#:)0#($!2$&7)$6((9+*?0+B3.C0"8%&;((>+&;(&;'(:*+=,*<+&8'$4%"0#%3%&3%)3&*. 3D62I< 3'"/#"-"''('%)0##?/"C0#F2'G4%C0$>+!8($6%"5$1 0-"2$2#1%1$.!/.4%4&#=.4$."2%!4'1$#5&. - .!''&'/1# 2$ ) +/"-$(!-'% ##$#'',0# , " !"%*)#"#$#%1$6)!6&"5$-!!('#"*3Q@$E1:+.D8-E5(G31M:3P=,O;-Q=/N:0N60M:(G6)H9%C42P@/D2,I70Q<2M90H52L8-I7.H7/H6/H4+F2+G3/J8+H3'G1)E2%=./" 6()D4,G7(A21K9'H2)L6/R9'D-'A/+E30L5'E1(F1+E5(B2*F2)I1,G3%B-,H5/L8-I6&A0)4* 1#$5&%2$#2%&:,':*#7&-@//B3*=/&8-"1$%4( 3$'<*'@.(D0&B/+A/,:*(6&*<+&<*03" 7&'?-2F42D3,A/)?-)?-+B0%>,6#2!3# -""& - . /! /""0!1!1/, %'#' +((&  $!-! 2&,&!#2%'C29)2"6)$?2#=2, '3# B62''.#7('E5&Q;'T<1]C-Y@-WB"K6%D0%E1&K6.ZC,V@(L60L;-K8!D0 G3)RA0XI5YB#D1<*5%AjU+_H*U>-TB*P;(U1P>0J;.I6-H6,C5/B4-C2*I6,P:.Q;.P:.O:,O9*M7+F2+D0+D1-I1,K4.Q8.O<*M9(K7+N:,Q=-R>(O9'N8(Q8'M7"A, ;*$<)$?-)D5'D4&B2$?/#A.'B0+F4(E2&C1+B0-D0,C0*A2&@0'B.%A-+=,'A-&F.%G/&C-*?,+D2/L9,L8'K7*M9+N<)G3'E1%E/'C/'A-'?+&9( 1 #3!"1$#5&';,%@0&D4*H5'F2%E3$C2*L8/S>+R<(Q<)VA'V?+T?-V@0YD,WA,XC(S>)P>/TC-R?1WB4ZF.VA%K6(F7)B4)D6">. :(!:&$;(*@..D2'@1'C2#A1&B4&C4'A3*D6(C4 ?- =+"?-"A."D0$K6'K6'F3+K9,M8'K5)M5'J4+I8'D4!<-$B0*H3(E5*G7.L:-L9*H5*G6-L;)D4!A0 E3#J9%J8/N?-L=,J: <+7% 6%!4##7%#5%$: &"8%"7&4#9% ;($?+'C/*B3&?1'@2 :+"=*$<)&9&"7%'=+(=/*>/ 3%&9('B0"B1 :*3$%:-%:+ 3&.#$7*$8*)A/*?.!4%!3)#:, 8* 1$!6''B/"<*;%$?)$='$:'#5' 1$'$+#2$&4&&9+%:+'@0+E2#=)%:)"8&!4#!4#$6%%8'%7&$6%$8%)<*+=+*;)'8'0C22G65','$$%'*-0!(@1&A3 ?-%C0'F4%A.%>,%:)%=*&<+&<*)=,$7& 4"$4&"5&,1$-+0 4#4%2#5%3%4&4&2#4%2#!2%.!('''3"4)-"- ,/#, .!0#-! # "&$ !&)'*)"" $ %))$"#%""!(1!4%0""#! $ + 5N?:&'<04C80B4*I52L:4O?.N=+M:-L81N7/L9+K:2SA5UD)F62G5-K80Q>/L90K74Q;0L:5M;5N:1J60K4/L5-L6(G2'F1(B1#8+.#!7))D5*H5(A/#<*9'@aK'H/&C,'D1)F12R7'I3)F2(D1(C0)E1(G2)E1'B.+E3%A/'C0.H86E6+<.)8+,9.(:-,E5)=-00E25H63F86H<0?1&8),?0"7%&>,*C1)D53I:/@/(:)/B1$?*!2!"7%$=)(C/0I3:P95L9/I50I5-F2$=)$=)#:$ 1!(  ', -"/!!0"!0". . -3!6$/!"$$!,+(+&  ''7./&+"$ ", !1$ '!!))C5#=-1!.5'(@2.#',7(;,$=0-",(@20O?+S<(P8,S;0X?,S<&N7(L6*O9,T=.[D+U>+O8.VC2\F*U@,VA+VD5]L2aG(O79%+J92UE-R?#N:(N=%M7"P7*Y@%M;&E6">,<((L6$F1'E2. 3%!;,9*"?/#A,7YA6T:0M5+L6.Q95W>8WA0R<-O:+P;.Q:0Q;/M90K7/G52H6+M72O:4P=1P;1Q<1L7.I40K51M74O90K7.H7.I7,J40Q;/Q?0VC+S;-M8*E1/E1,B/,G3(G3,I2(H3(L7+O:-P:.M6.H2)C-,D/0J3+H0)I0+J4(I2/O:/Q;0R>0R=-P;/S>/T=.S<0O=.L=,F3,G6/G85I:0G6)H5,K6/O:1P<3S>1Q<,L70K7-F30I3/J3.K40P80L:-L8(I3'L4)O:&K7(K5&K4&M4&M4$B/ ;)!;'#>.%C3&C5%C4#A2$B/(B/(A/%A.&B/*?./G3*B/*A/*A/(?-%=(*<+(@*%?)%@)$<((=*(A/(E2(I4*N9,Q>,O?*N9-P:(J4&E1%?+(=+*?,&8'$4##4&"6((@3&C3(F2(E2*F3&B.'A1#A1%F5%J6&Q<(W>'X>(U>)U>+V?+W?,XA'V?*S>-S>*O;*O:-S?*S>.X@!@.*C4'A3%?/ 8%!9&":'&=*+B0+E1&B/&@/%?/$>0%C3$C2&E4$A2#=/#<.$?."A.#H4%K5%G3)H5-J7*H2(H0(F2'C1$=/7($@-&F/*E7-J8-L8.K6*D1+C0*I:+H8&F5$G7&L:"D3)I8-P?-Q?+M<(E4%=-#;(#;(":&#:'$;&$:&&:*4!!;)"?):'"=* 9* 8*7("7)"9'$<($6')@1'A1#<,7'":('D3%C38'9)(G8#>,":*#9+'=.&>-+E2(;* 3# 2"(;+-A2$8)+ 2"'@. :(9&%=*$<*#:'"7&"3$*+ !0!#3##2#$6&1! 6'%@-%>-$<,!6%. 0"2!"4$#6%#9'&=*+E1.F3)A-,B.+A.0G4&?+0")&'$&)*/!6(*?0$9-"8(&>,&?-$<*&<*&8(#=)%>+'?,)@/$:(#9'%9+&9*0 -#3%+ 0'7&"3#/2""6'6(2%3#0!6'6&3$/ -+,+ 6$3%7)/$.!/"1$-!+ 0#, )*(+)$$$!*(&'%"$"(+%"# "$,,%#",#!6&!6&,<0 -#->11P<2K;5K>0L=&C1.I40L30M60O:,K:+I6(D10G5,I73VC1P=4R<1Q83M;3J73H42I3-I2,J3,K3&D,-J4&@-6&!2&"9)*F4&F2)D0.$?-2Q:A]H*E1&A1+I4.Q6*J4,J5+G4-I6(E2)H5+H3)F1"<*6$'A//J91G51G7-A3%5'/D40M90C5"7%0I23J42K61K85G50D10E3&<*)?-';+0F81I:-F41K80K9'B.'9*-A0-D1'B-+H15U<4O<(C0+E1'@,'@,*D0'>("4#!- &)"0""4#/ . $3%0"3!2$0"1" 7)-$#% ,#1!+)+- "$%(-!*#)3# 4%*!*6''H8%<..!(.)##*7';)*D32"$9(-J8,O=&J8(L7+O7/T;*Q7)R8.WA#H2(J5)P8(O6+N5&L7)S=2_G0_G0]G4aL4iQ1XD<-<,>-)J7#H4 A1(K8.W?'N6#C2 >/1"/8$&E22N=!3$0"6'=- @.<'4W?4Q8-K3(K1-Q7/P7-L61O<-P=+P>.N7.P:/Q;,N9+O<*O:-P72Q8-O7.P92P:4I53I64L72N70M6.L9.N<1L;2P:1R=.P@.R?,T)M91N:/M8-M71O;1P<.M9+I3/N8/N50N6/P7-P62K9,H5&F/#E."I3%L8.L7'H2$H0&I2#C. =*$@,$@-&F6(H;$D5#D3"B/&@-,D2&A/$@-'=+*D..D2,B0-@/*=+*>)*>+)<()<'&;%"8#%<*(A/$B.!C.&L6*N<,Q@,S>+R<'L6)J4)D0,C/)D0$=*!7%$<,%@0&D5)F4+G3*E0+F1*C0)B1*D5(F5%H5'P:)W?*[A,T>,S>,R=*Q:&P9(T='O:'M9'L8&L7!H37^L,W>'G3+C5'B3$>,$='!:*!9('?-(B/,F2+G1*C0$=,"=-!>-"D1$H5'@5#:.%<-%?/%C/$H2'N7'K6,J7,F4*F1+H//I6)A1#:,":,$>-&E.-M;)K9*M7)H3'B/,D2+L90N<)I6'K7'K7:(?,.S>,RA(M;'F7*B4+D0+D0)C/'@*!;$$<&&9*%<*&B,#?*8$:&3$2#1$2%1!3 #4'%9,'=.'B2!<*8%#@0(H8'C4!;+'I8F4?(!>*%?.#>,)E2(E0%:' 3!"4!):)->.(:, -"4#*A/"<* :(%;*$;)!9(#:("6$!4#%7&):)#3"$4"!4"2!2 ;,%?/&=.#6*/#."3#4""4$#;''B.)G3-L7)E2*E2-F3*D0 :&!. )+*% (")+1 9'':, /$"1"#5$%7&(:*);*'7(%@+#=*'@,(@.'>,%;* 7)!7( 3#"3$#0#*!5");)110 5&7)5&6&8(#>-7$ 6%1""/"#1#.!+/1"7) 4("3&1$-!- + 0&0# ,!/! 3%,'%#"*)%$!!  #$#"!#**%  "$"%& #$ $*0",!!,>1*I5+C2)=/"9- 9(,B//J10L43O;3O<,H3+F2+D2/O<0TC&F30P91T:8S=1J42G07N8.J40O9/K4+I11N6"='6$#8)%=+*I5)I4%@,,"<-+G4?YF (9*)I5'L0-J4,J51M92N:&E2(I6'H3!@+";)6$$=**C2/L8.J7)@0/!.F30M97L>6N<,F./L2-I10L43H1/G0'@,(?,&:*%6(5H7/H6$C0#D1)G4'B01G85I:3G5/I5*L5*R90O9$B-'B.'B./F21H5/F0+<+*6+'3$!7" 7%!4%1$#4&2 #9$!;- 2##5'5&+"%/0 2 .)"+%  "!#!* ),F5"A.8+#<-(L9"I4#:*'#+- ,)3$7'?('B.%=)(B.+M8&N8+N?+O=-Q;(O5'Q6*X=3_I$F1"A,%F-?%"E+";'7!*Q8+V=(Y?4eN:mX+QA@1!J9"M<&M9*D2!7*)B0#A+"?)(;,!?1(A25#2 4$">/!5'0!;+%I9%L8@)5S:5S:0N40P63R6U@1Q;3O=0L8,G0*G0*K4-Q4O;2N:0J81K9/J6,G2/K4-J4)H5,K7.M8+L7-N9+N;,O9'G2&E0(E2&B1(F4+K5)H3(F2&C1&B/'A/'C-#A,&E1&H6%H6$E4'B/'A0&@.&A-$@,%B.(C,)C--G3-C0-@/(;+'9*-?-(<'&9$&:&&>*&?-&A.$?,-G3+J4,N6,N9-R<.Q;,L9.K8-I6*G2&A-#>-)C3.L8*M7+J7*H5-H5,F5-H6-I6/K7*K7(L8)Q<,S>-UB,PA*P?(N:&M7#J4!H2"D/&D/)D4(G6!F5/ZD-R>)L7(G2(B0$;+%;+6*'<,.E0+G0(F3.J8+E7&@/%@+$@+&C0'F5&=/#=,&B2$C/%D1)H5*J7)I6+J7+I6'E1+I6)G2!;(#7&$7' 6'&@/*H9-L=(E6)C5'A2)C5'H8)K;%J6(H6*D57)!6%'H8.VF-SC2VE1Q>0J9+G4*F3&A-&>')>'(?-*A/)C0$@- =*6#1$/-..%4"%6((:,+>1&<- :,:,!B/%E2#D/?,$D4 @1;+9)#;)'>,.G5'C0!9%8$:&$;('<)':("4%!7(&@1:':%'>'#9&!>(#>+';)%7&+C3)A+$8&%6(#4%"7%"9&*@.$=+%<-!5&"3& 4#%8)'9+(>.(C1+K3-H5)G1&H/(D1'@,%8)!3"0"3#0#-!, -/!!4##6)$5'-"1"!5%#7%'<&'>*%>*'=*&?+&B-'D/'C.!9&"8)4&2%1"/ 8(#9*0!1#2$!5&9+ :,;,:+!;-8*8" 8#"6$2!-*(*2#3$!5%/!!. + (",% 1&1"4&/"* %""%* *#$""&('##%&)'%"(,,"# %%!"%$&#, ,<0)=0+=1+!/#%5(+=.3L85Q;1N62R91Q=&E2-M:0M>0J<+G8,L70T;6N82I33I60H6,I8/P>/U?/N:7P<*A.$;*$<.(B/%I5+M:%>/3%!:,-J6*A0))=,4M9(F0-A02K93O=0O<$?-,E2'D,&B,&@-!=-:)+I4+D3$3&&&4&2E57L83L98L9/C0-?.1F4.G4+B-+?+0A/*:,$:,)B43K80I5-F2$?+.K61R=6WA4O;4J7/E11K7(H3-D6(I7'H30G33F42J91M64L9*<-,=.);)&8$$3!1!!5("6&$7#(;$$9"2 9%$2%$&(*/%-!0 +!) %"$% +!! "&)&4'-E5$E5'K<3`H.$:,!/$( 2%!4'"5( 8*;,!C0,G4/K7,P:*V<.Y@9cN6^I-XA Q8"S8+X>4^H+Q:'F1(D0 =)%C/%9(6#)L4(S9,WA%J7/';+%?.%L4%M5.J7)K5(A0 0$ /$/" =) B3A1?0#?0":-5(. 19%&K8"F5C36R=5R<1N60L50Q9+K1(E+&D*(D-*F0-H5+H4(I4,M92T<2T:3R93T,&B-&A-.I5(E0*C1$=,.D4(>/';,';)(;&&;$(>*'?+*D2&@/(B0*G3,J7+L8(K9)L:)N;+O;+M8-M8)I4(F2(D4-J:0O4Q0'?./G3(G0*M80O>/I;)E4'A."=)$@,%B0&A1%D4%H5$H4&J6,N:)J6+K7.N;,K8*G5+I6+F3#<*#7%%:($<-(B3)H8)H8'D4'B3(B3'@1&B4*G8&G4(E2$=.$8*%;*&F5+SB1YH0VC/T?.P=.P<*K8'E0)B/*A-)A/+D2(C0'C0"<*3 1%0!/!/-"2 '8%&;)&A.=)<*"<+ >. ?. >- <) <- :,6&4% 7&*A/-F4"?+!:%9%9%";'!6#$7$&;+&>.%@/ ;*":'&;($;'#>*#>,*?-.C1/G8&?-%<,$8)#6)%:)#9'&;)%;)&=+*A0*=.%6(#8&';**=.-B3/H5-J4-F3'D.%C,(C/#;(!5& 2!"5&!5& 2# 0$#1$#3&"5&%:(#8'"4&/$0"1!!3!(;)*>+)?,'?+'@,'A-(B.(>+&:'%8'"7( 5'!7)"7(#8&$:,2#0!1"5&5&&@/$@0"@0!;-";-4&4"8$3"0 ,&%+/ / 4%/!0"-"*#)!+ ,-"+$  $(%$#%"! $% )/!+!*+)#'&#!."3%* !!$!(( $% ' 0$!1#"0#"'!-!#2$%7%"9%/J45U?.N;+L:/N:0N=1M>2O@2Q>+O82K82H63J92J:6PA3O?/S>2P<0K7.H4*D3*E7+H7)K8'E2(=-%:*(C2&C06%. "6(.H6)G5'B/.L9/Q=+O;$F2*H5"?)$@,*D3!;,!<-+J8'C-4 &4#*?,9T=6R93L72G43I5-A0-C1*B0,A.%8%+?-0E2)C10M:[G1L9.D30F4,A/+@-$8#"7&(>0(>/(:)#4 -1"'9,"$+$ !&'* - $0$ '"!!+ #6(- '" ! )"5("1% /#5''G4<_I:dK7^G=)"<-%7*'. 5(7)+7'?-%K7.M;2R>4[D*T=1]E>gT3ZG.TA0XC9\G3O<*G6%C2(G5!B0-N<+L;);-+@/'F2G2*S=%E23" 4'7)?)$K3*H5)K5,F5 1&-"8)%F4"E5'I:)H9'C4!9+0"5%'D17[G6_K@lX1[J6R>7S>3P:0K6/O8-L3)D,)D++E/*E1/K4.L6+L7,M72R:3Q74P;5Q=4SA2V@,R;1Y>1V<1R8/M4-J10L5-K4-H4.F4*B0+D2.J61Q:4P>4P<1M9.M8*J6$H2*I5*L7(I4*H4*D1$?+(B0(C0+E3(C/&@-'A.%C3-K9,N7-O7.P8-O8)I7)J6+J7+J5'F0(G/*M:3R?1O<4O;/L8.M71N?1M>.K<-I9)F6-I9,K<*F5,G3+G0+G0-K4+L7+L7+G3)E2,G4)G4)E1'C/*E1(C/&A.%A/$E/#D0#G1%F2'F4%@0"=-";+&=+$:(&=+'B.*G6)F6+E5 ;,%=."<,#8)%:(*=(%<%)A-,F1+F7(B2*D4,H7.M:)L8+J;)J;-P<*N9*M7-N7%G3&H4)H6,L9-M:/O<-R=1T@.P<.M:3R?5UB4T?1S>,R'L8'I5'D1'A/&@.)E2*H5*F3!:(4"0#!6'#6'"5$3#4"*8&-C0%F0A-!>+!:)5)5'8( :* 9*!7(/!0!+=,0F4*D1$?-":(4" 7$5"4"&9''A.%@.":-"9+!7)#6'&>*"=)#>,,D2,D2.H8&?1$<.%;.#9*$:+%=+*>,':)':)-A/0B1&8''<))=++>-/B1.B0+@,&>,#=*%@,%?+#:(!4%"5&%8)%8)2#%8)&7*%9($:(&<*%;) 3&/$- +0)9'&:&(>+$=+'@-*B0'=++>-*;*&9($7'#:,#<.&>06'2$0!1"4%5&#<.$A.#B/#@/%?0 9+0#3#3$4%1$)&'*,-0!0!1#1$*!*"'$#$!"$)%$"$$" &*!0$2" 0%,!+&"($"(/", ""$ &#!%##''&"#%(*&B[H6S>(E4(D43P;/K93M?8UF2Q@%D1/J:1J:2L<7N?5P?1K;/O;2P;.I5*G3+J8-M?)J9(D4%<*"5#.E1*F2#:'3#/"/!2I;,H9&B/)G4$F3$G3)K8*L6&B-)D3*D69+<-)J:+H3#;''=**E12Q;*J1*A-&<),C01H7(?-3K90F3"7$1H43N75S<1T=4V>(H01N7/L5=&Ww`0J<3QB/O>.M:+H4-F1)C30M;6R>0K71L9/J8?*&C/0K86O=/J7+E1(B++D1)B2'>0+;-%3$'0"#6*.!'.#"5&'!(&$&&$.#$$ )' 3#$?,.K7.G70$#   "(/":- 4)2%2$2#*8%2P=.UA4TA/L:!C0#J5&L7!@0/?]M2RA%?0-*9'$D2>`M6UB!=+(), 8'0 5$+F23WB0J8.H6+E2.H32G5.F5/G81M70M8.M8.M81P85T;3N:3P=/O<,O9.U;.X=2U>-P:*I5-G50I7.H6.G3.E30E3,E3,G31N64N<5R?0N;/P;-O8)K1$E1(I4*L6,M8-K7,G3+E3-G4*E2)D0$>+#?*'B4*H61Q=3U=0R:,O8*H7)G5'E2)G2,G4,I42U?8WB4T>3Q>0N;/N.8(5($7%$<*&A.&D6)F7*H8%>0"=-"<,"9*'?,'=')B**E0-I51K<)E5,G6,J9-P;+P<-F8,G8-L<*J6&F0-K5'L8#G3/R>)L8%E3(G4*N:/T@0VB2VB/R>6VC5X@4W@1WA.T>-Q<*L8)L7%I3%H2%G4$E5%E6"G3(I:)I:'E7'F7&F6)N9+O=*N>&J:,N?(K7+M=,H5.K7/R=*Q;.Q-H9&B/&B0*I4&M8(O:'P;$L7(M8+P<,M5+O72V@-R<-L81M:,F5+E3'B/(C1,I6-K8(H8)G7)F6(C3&@0$>.&=*,F4,G7(C3&>-.C1+H3.R=-TB/UB+R=%Q:'U?&P;%L8(K6%D1$C0"@-%C0*H5(D18' 6$ 7)*@0)>0%9&&9$(7'2K:)I8 B19) 5(2&2$8(!;($;*"5& 1#1#*@.-D2(A/%=+!8&5#4" 3""5$':)#@,#;+ 7)"6)#7)$9+&@,(A-/F4-H6*E3*A2$>."<+&@0$>.&<-%<-)?-)<+(;*0B11C2);*(?**@.)?-*@.)=+':("7'!7%&<)'=+$9'%7($9*&9*%8)%8',@/*?-'=+'<*#<( 6$0"+ *+"/&7$%8&%;*;)'@.(>,(:*':)':)(;(*>/(?1%>0(?1-1"/ / 1"8(#>.$B/#A."?/#>.#<-4'5&5' 4'1$((%).!,/1"3%4'0$."&# %#!!!#&%#"!!%$',- "5&+ '"!"$! !'*+' $%&!!! & )"#%#!")?TB:SB 8)#:,*D2%?.*E56QA'B3">+0I:1K;3M=5O?4K<1H:0K8.I6(D0(G23SA4VE?.(B1%=*":'=XD&A-$6$'7'!0$!2%')@2;*(I6*H4'>,&=+(A/4O;+G3,G22G58N<6P<8U>6V?5Z?0Q:.N6/M6)F/*I22R;1L=(F7-M<'G2&C/)B.-I8;WC6Q=$A-.L92M=DcO'E2(H22N:3O<+E3-G/-H2,G4)?0)9,".")5#6$!7' 8(:*/!!)3 $." # **!$+$" &!'!###,"%7)1K99U?=_G9U>&;(*:+(#%$&'(&A1 :'-0$7*(E.)E(-K4.L6,I5'D3">.7)"8*8)0!*=.+A0,G5+Q=+H6%?,(D4)I8!>.1"/-G72RD4&- *I48XB5T>!<(%=)#7$#3*(=0'H7&O:$I56'2#8+#D5&I5&I3&G6.D2&8*1$ 6(!:,!=-'G4.Q=&J6#C0 :''1 '@-.M8,Q;+N;&I75T@6UA2N;.G4-E4-D20F44K92J;/I:/H2-H3/L81O;5T?4S;5Q;3O;4Q>3T>0T=/U<2S<0P;+H50K:0L92M9/J6.G6/G5/G5/I50M60K73P<.M:.O<.P9)K3'K5)O9+P:,M8-K60L80L70M9,J5*G4&A.'@/*E3/M;3Q=3TA0S=-R<-K8*G4)E2*F3,G4,G5*N82S>5U@3Q>/O<.P=/V?0TB,M?/NA/M>,K8-J:,H6*E1'D.(E0+I5(N8+N9"E/*H6*K8+M9'H6&D/*F0)G/'G4&H9(N;%K6 D-"C,&@-%;,5'3$#4%%7)!9&#@,"A3&E5'D4(D3&A/#=,(B2)C1/I2-H1.J4,J51M;-H7+H5-M8,R=(O:-L;-M<-P>+L:(G5)G4&J9(M9-Q;+N8'E1(C3)L70T@2WC-R>.O<2R>3W@0W>-T;-S=-P:/O9*J8)H5%E1%E2%E3'G7%J9'K;'I:&E4+G5+H5,M8,N;(I:(K='L;,S>+N9-I6,I5.Q;,S<0T=-R>,M<(I8#C2'I4-R<)P9*Q;&O8%K6(K7,N9.Q7,R9/W=*P:,M80K8*F7+G8+I6,H5/K8.K7,L:)G5-K:+F4&A/"<+'>++E3/K;-L;+F3.H6+I4'L7'L9)K9%J5&P9'Q>$M9(L:(I5(H4&E1#@-#A.'E2$A."<*"9'$;-.E5(>/(?,+?,)=*+@/1I9*G5$=.!9*4%1" 6% :'"=*#=* 7(!4%#8))@.+C1'?-(>,"8&2 1 3!#7%"8&%@,$=)"7'%8+#;)%?.*E1.E11H6*G4'E2*A2$>)$?*'C-$?,%;*)<.(@/&<**>,/C//D1.D/,C,+B-(A/+C1)?-(=*%7)$5'%7'&9&':)(;+&>/%<-%=*+C1)C1*E3'<(%<'!7$3"+('*.%6%%9(!9&;(%@-#9'#7&%9'$8')=*(=+%:-';.)<0- -+-0!6' ;+&?1"=. =-%A/"=+!:) 6(3%1#+&$#'*- 1!4$2% 5(!3&- +)& ,$ .&(   ""!%$$'#(+# # ""$""+*%#"!" %#$!!()  $'(# &1?11F48M=!3%!-# 3%)>0)@1.G6'@.+C1.E25O<7R@.I8.H82I:/J9.H6(D0)H3?^J+I9%E0.I6%A-*L6-L96"'9((:*2$"7)#>-%C04L62H7)B3&?0%@-'D-$D,&C.(F3"A2?/*P<1Q?.H8)?1*D4-I6+E1*@-&=+,F48S?2N:1M97N(K<*E8+E3!7&*'!6%*B0#:-;,9_M.ZE"I7;*3 @/$H8-N:1N:'G6&?0!:+9)$?0&B3"?0$G3%J5!G3(L7!<)+5!)F2+L50R=4R?<+9[C5UA2O9/G42G10F/6L58O84N:3M<5M70I6-I6.M:.N92Q<3P95Q<3O<1O0T?-O-U=/T@+O?*K=,L;,L70M:0L7,F2.J6)I5+K9)Q:-T=*O9)L8+O;)N9+L;(I4.L3.K5+M:*N>+Q@%L8"F/"D+";)!7' 4'1#%3%'6)#<*#B/#A0$@0%@0)D2(C1*D1+F5+F3.J30L50M7+K61L9/K7+I4-O9)P8&P8(O<+TB,TB,SA)M<'I8'I8(M8,Q:/O:-K7+D4)I5*O;.T@)N9-P;1P<-S:.T;*Q7(N8'I4+I4*J9)H6(I4(I5(H5(H7(M<'L;'I9%E2)G0.K20O92Q@)J<'J;(L<&M9%I3)F2/L71T>.U>0U=,Q=)M:%F7&I8$L6&O8(O6)P9(N8&J4*I6/K9.R9,R8.W=-T>-N90L:-J:/K;.K8,J7.J6,H4)H5.M9+I6*E2%@-#=+";'+F32Q@.O>-L9+H3'I4$I4!D0'F3%F2*Q;)O?(K<-M=,I5,K7(H3">, <*#@-"?,#>+#>+%>0,E5)@1(>,*?-*>+'C-/J2/H2(?*&9'1#5"#9%!=& ?* <(!9)#8("8*'@/'@.'>,%8'"7(2# 2# 1#3$6'#=)"9'%7'';)";($B,+H4-C/0E3'F2$C/'=.*C+(C+'C* <&$9)'8,$=-#:((<)-A/.C0-F/0G/.F2)D0&@.*C0,D1(9,#3'#5$$7&(;**>-!<+ :)%=+)D1'D/ ?*'<'$:#4 1 * * ) .!/ 2!'<+"<)">.!;,6&"7' 7'!8((=*,C1%:*$8+&7*.""0" . . 3$7'%?/&?1"<,9*$A-!=)#?)"5'0!-((''&()1#2#0# 3&/ ,, .!-$#4,"3+)!  #! "&$''""% "#!"#&'+ #'# $" "")#$% !!!'(#"$')!)#4%(=.?PB$ $)7,$5(*?0/E2,A/5H6-E/5Q:4O;-J60K:2I9-D5(B0'B.-I54Q=*G54T<3P:)J4%N8B.&9((?.,D3#>/=*B-,T<4P91L:2L=)D5"@-'I1'G.*J3-K8%E2"G3$K7&H2)E0,E1,G30K42J2+A/":('C0@^IA^J;VB7O=*D2&@.-G5+G4,H5.F7(@0'>.$>/+G8.M<+L70K7-C00F24M9-M8"A-/F21&H3/R@0M>.E5,F2*E0/J31I63F64H3/E0'>(%;&'9&-:(*:/'8./#-!"2%/ ! +/ 1 '&(.. *%# ")'*.! )!,!6( 3%!0**!"0$3D6'9*':-.!!<,%H7+L8%G1)L8)F78(#<)9%"7'#4&$4%+;-%9)&B.(I4(N6)N6!G2$I4+M="G6#M=.\I7]M&F5,L>$F6%C6?(!F/ H2+SA*K=(A5$2&&"/$#<.(J<2"=*6bL2cM%O;#B2<%#H3-S?8WA'C/ ?0$F4$G6"E5(M<C3>.C1%K9#L9&J78(1!='&L5-T<-R=&D0&?/7\D5W?2P53K05I32H23L64O:5N:3M83Q5/L5/K7+G4.H52M91P>3Q@6S@3Q>2TA,T?0V?3X@0U;2T<3T?3SA3P>-O<.M:2J84K93M;1O:/K60K7/M81Q<-Q;-N/P<1O<,K7)F4.K8.J7/O:0N<0N<0M=3P>.M8+R<,T<+U;,T>*R<*N=+J6+G5-J9.M<.P<+R9*S<$J5!E1 =-8(#6)5%4%%8)*=+)?,*D/*E/'B-+E5+E7(G7)K9/K7-M7)L4.Q90P:2N:/M5*K3)H5(L8'L9&M4$K3&O9.WE)UB'P=(P:%G7'J80S@2XA-T:(P6)I6.N;.O;,N6.P8.R72O<.R='O9&I3(J5%L6'K5+L8-L7,K6(J4,N9'P;+Q=(G3(D1*E4.N>*SA,Q@-N='M<)H8*E3)F2&F3'K7.R?,O=.N=.N=)I8(H7'I8)J:&J8)K6)J6'F3*J7*J:+M<*P;*P;0UA0S=1M<3L=3J;3L<3M>-H8,I9-J:3N>1M<.M8*H3%@0'?0$@4)H9.Q=-L9+H5,F6$I3%E0&D/&B.&I3*Q:%K<)O>*M;(H8)J8(F4$=/!;*#<("=)%C.!C.'A.%@-#>+%B+(C++D,&A/,G5-I6)D0&=)#7$"4$';('>,!@+<)#:+#9%$?**E0'B.$:'#6# 6'!6' 6'01 $6$(>.$9''=+&<*!:&&?,+D0'>,'?-*C1+C1)@/'B-)C0(B0"=*%;)%;'"7%"5%"7((>.,E2)B.-C4+C2)A/(@.*F2*E1+?+"6$"5%#8(#=)">* ;'9% ;'#=+%>,#=,#:("7&"1" /".!0#- 0"!0"!3%*>0&?1(C/#9&!0"#2$$6&$7%'=)(?*&<)$:)$9*"5( 2$!3%"5(';-%;*,C/$A1#?.">*"=+&@,$<("1'."-,,+(((/"3$5$2%3&++.3#4)7*1&(! %#%$(#''#"#"!!!!%$&%(( # +!!+"&%(  "%&$ $##%"" ")2$*=.8C6%$0 ,)6&*:)'6)*;/)8*4G46M94M;7N;3J41C1$:(&B/+L8)K8+J8,O:,O90S@.N:";*)>/(I1-I5&?/%?/*H38]D6S:=ZD0N;*I6%B.&C-'D-.O7)L6&J4(G4<(+C5-E3-D.0G1/H1+D0&<*5%&?09SC0M:7WA4S@(G4)G31M:+G4/N:4Q<-D1,@/(@.*B//C1%@*-H1/K4.K2:V>.I2&;) 6#&=)1L70P;,N<2N>,D1*C00M65T<;U=6G8):)(<)(<)(=+$;(-D5&<./"-!"- *'(()*(($ )*#6&0$-"&''"(% '*!""' 4$$5)*  !(#5'#;,#=.4($F7=fT1XF.UA2]F5VB$D/!<(3""6$!3##4)1#"6$*D0*L3-T;'N7&J4'H5+O>(RB$TD.hM6dL0UA/VB$L:#H8#F4$B1$C4 C3#A3,/#0$#6)!7(&D49]L'D5<+!L:+ZD'T>%N9$N7*R<9XE2L:!>- E4$P8*K7#C0%K6!G6%B2>*"E0(O7(M6=(2 9('J5-N;%A/&D4*K=3VB5WA2P81H23I33L60L50L70K8.J61N51M62N90J80K70K50Q>3T?5UA3S>4XA3XA2WB2W@5X@4V>6WB4S@2T@0U@/Q=2N;3N<1N:.Q;0P;0O:3P<2S>.P:3M>0O:.K6+E0+D2*D6*E3'C1+K8/O<-M:+K7-N6.Q9/S;0T<.N;/N<-J7,J5*G2+G1*C0)B2&F3(H6(H5(F3,H8,H8,I6,I7-H6-H6.J7/I7/M81O<0M<-J90O;0O;*P;*R;,U=,V?,S=+O=-O:+J8/M>/Q?+P;+R;'R;#I4B-#>/ 8)4'!8&!7$%;',C-)C,*H/,J1(E/,F4-H7,J8-L9/M9.O8-R9,Q9-N72N;0Q:,L7&I4%J7'N8%M8'N7(P;)R@-TA'M:&J7#E5&I8-R>0XA3[B2[A+O:/R>'L6&L6-R90V.N=%J9(H7*D4)F3'F4*L8-P<-M=+L;)K9'H7(I8'I8*L;'H8%F2$E1(H5)L8)K:+L;+N;*N;*Q;/S=1Q>6SA6S?4P=0M8,I6.L9.K:4O@0M<,L8(G3)E3,F6*E7,H9+J7(E2'D1-G7%F3#B1$@/)E4*K9)N;&M;&L;&I8%E4(H5+K7'A1 :):'$A)&G/$F1&A. =*%B.'C/'C+*C+)D1/K72N:)C0)B/&;)%;(*>*)A.$C.>-!:+#<)'B.+G3'A-!6#!2 4& 5& 4&"4#"5$);*'@0(@.*@.'=+%;((=*%<,6&$<**B0.F3(@.(<**>-'=,'<+':($5%1 3#!6'(=/)B.*C.+B2(@/%=+(A.,C/(?,(?.$9)#7($9*!:&8$ 7#5""7$$9($:(#8&#;)"5&"2$ /!"4%"6)0"- "3%+=.+A0)B1(C-#:'0!"2$#6(!5$%:&&;'*>.&:)$8)#7)#6&%8*&<.%<.$>-,H4%G6&E4#@-%A.)C1(@,#4(0". 4#"6&1".!,- 0#0#. .".#+ - 3%!9*!7,2(."&""  $''&&$''#"!"$&%$$#'#!&(%!$&'#&&""!#" !($#!$)+$6("-  (' +#/%1$)#3&+?,,E05M<-E43K6-@/":((E2.N;'H40Q>.N9,L74T?;XE 9(+A0'E0$?-$:+(B3-J71T>4ZA4YB0S?,J8+F3'?,(G0.N6(I4*I5-J5+F32J80G5-C..F2(C/'B/*<.(:-(;/"8*+C33L:9VC.K8+H52N;3P=6S@6V=9R=1I6*B4"<+%=+*F4.J8'B0-I40K6%@+(7'#6$-C03P83P;,I53M;-C1*D0-J4-M4.J12C4,?,(=)'?('>+6O;2M<#<-$9+"3&- %(+1#3%.""$'- $7))=-&7&!1$% .!,+/##%*!!,"'6)%4(%$3$"<+)F5&=02RC)P>0VD2ZE/ZD1V?)K6'E/(C0'@.#:(!7)5$ =)'H3&O7G0C3#G6 E1!H2*V=-Z@)YC+TA4ZG0VE'I8'C4'G4+G6!B/1YE;eQ8[H/O=)F4$B0-N9>fP4^H.N>=-$J74]H#L7+R>5^G.WA)L9$A.(J78bO>jT$I5"E1&M9*O>*H7%C2!E2*Q;'M7!@- 9( @-&I5$I3%D1'F4-O@/O1S:4U>6V>2V>0X?1W?/Q91N71R:0U?.R5U?7Q?0N:+H4,D2.D6-E:'D1(F3+K8/O<*J7+K8/N71T;1S;3U=0R=0Q<0M9/K7.J5/J8,G40J:*K8&F3+I6-I6.I7-F5+F2)D0(B/*D2,D2-E4.L8*H5*G7,J9'F2(H2*J7,R<0WA.V@-T?,P?*N:+M:-P<0S?,S<*T=)P;#H2"@-%A. 9)3%#9'#:'%>*-H3,H2*H1*K3+J2/J6,G3*F20L8.M:/Q;,R:,S:-O9.N;-P;&I5)L9&K:'N;&P;+S>,T@/UC+O?*K:(G7#H6*P<*S>-W@-YA,Z@+O<.S?)N:)P9*Q;,S=+R<,S=+P:'G2*I5$I5(J8*K9,I9*J9'K:+S@-UC)L:'F3&C1"@1&F8!O9&N9+P<&K7)I6,H5*G4)H5)I6/P=-M:+J6'J9'J9(L;+N=/P?+K:$D1%D2'I5,N;(K8&K7-M>*M;-R;-Q;/S=5XC6ZC5X?1R=.N:0N;2O=6TA5TB.N;-M:/L9/K8.H8+E6)C1&A/(B0-H6&C3&C3'A2)G6(I8(M;*Q?)N<"D3#B/%D1&G4'B0!<)$?+*G0-M5)K3'E2$A.%C0,H4,F1+B/(D/0K74P<(D1)C1*C1+E01E3-F2(E3>. 9-#=+$@-'C0%=,.).1"2#"5$"8&)@.'B2%?-(@.'>,'<)#7$!8*5'%=+.F5+E/%>)%8'(<+&<+&<)';*/02"!4%%;+)A-(A,)A/%>,&<**@.'=+'<*&=/+B4*?0&<,!6%5""3"!4""4$(:)*;*&:("8)#7(!3$ 1#':+%;, 1%/"&9*+@/+C/'B.$A)";%2#!4%'7+"8(%8&&9(+>-':)';*&9('9+$8*&>0$>0&E3*J5#E5#D3@/#A-(B0&@.%8)4$5#$<)$>,#;,!4#/!,, 2$ 1&/#0%-",!#:.9+/&-%, )$($$(- )'%&%**'&    %&(&%# $$!!#######' %'&&$&#!##%"  %&- 0"$!"&!*"* '+!2!%8%%7)(<-.C0,@/)A/'C0+I6)I6/N;+G3-I5=YE5P<"<)+C0)H3)D3'@2*C50K:,J7*O9,Q=)N9+J:)E5";+&J3'K5$G1-N8)I4/M9;V?5O7.G3.H4-H7-I91I8(>.)@0)@0.F41J63M;&B/+G43O<2N<.H67W=--L55W?8W@9U>-H46N:0J7+I4#B,$>($7&':(1F0*B+1K45O:%B/$@.$<-!6'!3$!3" 2$0! 4%5&!3$$.#7("5()B3'?/%9&!5'1""6'1"2#$;,"'%"  '!-!$0#'3' +$)!. 5$:'<'#6*6&>-@/"G4%O:#H1&K5*L6+I6/L90L8,F8&B0$E0+P;2ZD*TA2TC-R?-V?,W@0W?.S:!D4'I9/WE$O='M;1M>1K9-I6)M74bI8iO9iNA.&F5#@/"C/$J6%N:"H4A-%J5A- I4(T>0S@&J6'I59&<(*T>1YD/VA-T@'N9"H4&F4(E6#F3%L7+P;*M;-J:'K6,T>0WA-P:'G50SD(F2*G7.J:0K9/H42N90P8/Q:-N6*J2-H4/H4/F0-H03O82R;/T;2V>1U=2T;4S:5R91N:1O;-N90R<3U=7V=5W?3[B1ZA.S:1Q:3T<-R=+R<,S=0U?/Q<+L72S>.T>+M9-J7,H9.J/O<.N;.N;*J7(H4,M5/O7.N9/P;2V@2V@6U?2Q=2Q?0O-SA-T>)O;,P:.T=,S=+T=(P7$H3#A,%?-#=-7'$9+%>/)C4*E6,J7*G5*L5.L5/L4-H4.I5,H4+M:,P;)O7,S;-Q<-Q<,M=-M<(K6(K6#K6'R=)S>0XB2WC1T@,L;/M>,UB,UB,T?*V?-YA,X>.R?+P<*O;)Q;.U?.V@2ZA.X@-T>*K7+K8*Q;&K:&I7*G7(I7(L;+SA*O>'J8)G4)G5%C3#E6"N9(O:(M9*O;,O<-K8)I6(H6,K8.N;.N;,L9-M<*M<,P?+P?/SA/O>-K7'G5+M8-P<*O<'N7*L=+M;(L7,P:-T>3YD8`I4[E4ZE1V@/R?/O<4TA4SA.Q>0P=/O<0L9,F6'A1#=-#=*(C0,G2*E4&A1'B2%D4&H6-O?+SA-Q@#D1"B/%C0(G2&B.'D2(G4.M9,K7*I2*H5%F3'G4,J7,H3(B.(G31P;3R=$@-(E2+G5*F4-D1'@-(C18)8*"<+$@-%A.7%/)*+.!3"&>,)F2)D4&A.'@.+C1'=*%9&"6(!5'(=,1F4-D/$;*$;-#=)$?+ :&1"/!3#$7($9**A.*B.'<+*?-(>,)?-':)$9&%<..E4*B2,B0#7&':)#2%%4%&8'&8''9(%9()@1&:+$5'$5''<-'>.&5) 1$*>.-B0(B.%=*&B,#=*#9*!8)%:+$9*#6&':*-A/*>-*=,,?,&<-'=/&?1(A4$E3&J4$B1>-"?/(E5*E6&A1$=-#<* ;'#>*&A0!=-#5$1"-. "6)7(6+#9,-!." 8,4'-$0%-! 0#*-'&*.!/!(&&(-"-!."* !!$ $& %**)&"''#!##!## "##$"&($%%'%%&"&! #%%&+'$   ' ) %!!)&/!, ,!)8)+C1*C2,H5+I6*H52P>4P<:VB7S>.I6/J71L8.L7-I6*F44N>0K:(D3,I6-K9/P>0S?!C2 D1(P:'N8*P:2XB0U?5ZDA^E9W>0J5)D11M;7TD,J3,H3)F2/L72Q87V=0K62M92N:3O;%>*+B.*H.,E0*D1&E42QA6Q>%8, 0&, 1$+<0-B3/I9(I6-U=1Y?1V+*=*&A0&?/$<-7'"<,:))%('" &!#!.!"2$",".#**5% ;(#7)#>-#B1%E4+L<%L8%E0%D/ @*"@-$C/&B0&>0#>-&F1+P75[G?cTFkQ2W?/U?+Q<*L:%C2;UE?\M,UC'ZE&VB0WF+E2&B/%I4&V<9kQ-]B(C77+-!0#4'9+5_I)P<(O:0YD/[E$S=)F3#B/'C0%=,&A/%I5+O;0XD0ZE*P<&I5'G4*G8B/!H2(R=0VC0UE0VC2^G6_I,R<0TA2XF+G4/L81L9.J7-F1.I6-L6.O7,L4*J2,G1.G/-C,.F1/I61P=.P;,O9.O8/M53L53J3/J40N80O;-N91O:6R;8WA1XA/YA/T=1Q;2T=1R>-P:+P:+O9/Q<3S>1U@,S=*O;-K91L;6TC2YC1U?-O:/M8.M8)J6+L6-K8/L:-M;0T?0WA2WA1U@2UD4XG0SC/S?2TD1RA/Q>.P=,L:*K6+M4*L4'H3'F2%C1&C1)E1.J70L;/J9-I6'C0(B3(F6+N;)P9*R<+R>.TA*N9,P9,P7,R:+Q;&N4$H0%A-'?-&>-9*#=.%?0&C4)G8)F6,H8(D3*F3)E0+C0)D1-H7*L:*P;*P:)O9)O:'K8'I8(H4(H3'J3%L6&Q<*U?2ZC1X@+O8*L81TB+WA,XC)U@(T=-U?,U?.O<-P<)N:*P<,S>*S=,W>,X>,T=+P:(N:&U@(Q@&L;'H7&F5(K;+R@&J:'I9*H6*G8%E5#E6#K7)N9(L8+S=,R>,P;'K:*M<)K8/O2TB,O?,N>0P>.L8*D1)C1&<.">+(D1)F0)B1#>-%A0%C2'I7*M;,R>)M9&F3&D1$C.(H2,H5*I6*J:+K:)H6-K8-K8+I6(H5*J7*H5'E1&I20P:1P;#B.$E3)I9+H8)A0":)$@-;+9*!;($=,!=*!:(2 ,+,- 4"'@.&E2)C3%?-'A/*C0)A-$<("8'$:)(>,+A/*@."9'!4)4&"<*&A-8%/ .1!2#$7('>+&;($6$)<)(:)*=,'=,#:)+B/-F1*C.'@+#8&$7($5'%6($6($9)#:()@.*@3*>/&7)&9*)@0&@-'7'#5%'=+(@.(@.%>+">+$?,%=.%<,&<+#9&!7)'=-)@.'?-)B-'@+$;*&>/&?1$?0(F5+J56$ :+#?0*G6)G7%B4#A1#A0$A.#?.(C3%?2$9)#7)2" 7(#@/#C0!A1"=.3%0#2%-!1#7) ;-2%*,**1$3%1"-(*,1#1$0#+ $%&$""$)$',-!($&%""!#"$! "%'(&($ "'(''$#!%"#'(##$%&  %"*"$+9,*E30K8.J7-I6*G41N;=ZFA\H6Q=.K58X?,N5.O8-M7-M86SC3P?)E4.H51M8/O93W@!C0(H81T?(J4,L7:\F6\B4[B@bH=]E$@,%?-:UB5S?)G00O8(F20P:+N6(K1.I54Q=-M71L8.'8&-E/2I6,G43S?5VA(D0#3% /" - 0"(>-1L:.T?1XB/W>1W=-O7-L53Q:5R;+G2'F1&@-+;*&8*3"4"'A,1J62L:%>)&=*7%%=**C0/J5/A2.! 1$!8% 5#&(=,- 5'.H88%'9'$>+'@. 9&8% <)7$1$-!)!.!"$+"+'''-#0"/1""<-,H8)C3(D4)K:(C0'B."=)!<)!<)">+!8/%@0#D0%J1-R>*N?&G0+J4'F1<*%C4$D5(F1&C/B-$Q;'V@'P:)F3.I8-M;%N9,VB"H5"<1":/5)!9,,I;%F8.T=)Q:8bKIs^0YD H2$D2$F3!?,$>+(D0%G1.M<-TC.WC/R>)E3&F2)G6!D1(O90[D2^I1[H.YC.\E*W?+S=3YC3[H/J60M82P:0O8-G3-H4-L7.N6-M5.N50J32J20F.-D..H50O>-M9,M7.M8,H3.E/2D/1J1/J4-L9)H5,I61L74Q=1V@/WA,Q;3R>0Q<3Q<.N9,O:*N9,O:3S>1U?2WA,P;0M92L84Q;.U=3YA.O9+K3-M5*L4'G4*H6*H8,J:,P=.U?+T>-S?0TC3XH,P?0TA1SB0RA/S?1R?)M8$I4%K1*O6'M5(L7(K6$F2'D0*F3-I70K;/K8*F2(B3'C3&H4!F2"H4'M9,P?*O9*M6,M6)L6'M7#J2)K3(C.*C0'@.%@/%D/$D/%F1)J6)G3,G5+D6(C1'@-%>*"=+(C3$J7)N9*P:*P:+Q<%J7'G5(E1+I2(I0&L3(R:)T=+T;*Q6*N5*P9,S>+ZD+YC+VA)Q:-R=-S;1Q?1T@.R>+O<-R=&M8%Q7'T9)R;,S=&Q=$WD(V@#M8"C0'E3$G3%L8!G6!C2&C3+H8)I:&I:/U@-P<-R>-VA+T?,Q<(N='L;)L9-O<-Q<&L6,F6*I9*O=-UC.VD(N<(F6&F5'J6)O:+S=&P9(Q;-T=)M8%G2(L:,PA.UE5[K6^L0YD0YC-W@0T>3UC*M=-O>,M;,K7+G3)D1)B2(C2(F2'G0)B/$?+$C.$C/&I4+P:&L8%J6%F2)H3'F1*I4-I7.L<-N?-K=+I;,I5.J7+I5'G4(L7(I6(G4$I1.O:,K6'E3"C1"F4*F9'A1(A.$?-!?,$?-#9*"<+$>.!;+"6'/ , . #2#!4#'A/%E2*B2'@-(A0*D3)C/$@+'=*'=+)?.*A/%;)!5$&5-"4&&<*'>+!7$-.,/ $8)$:'3!%5#):'*<+,?.(>.'>.,B,$=&";$%?)$;)':,$6)$7)$9*#:+&?,'B//D7,@2*<.(<,*A.&A/(9(&9('=+&@.(A0&?-#=-#>.&@0$=.(?,"8$5'&=.$<+(A.*D/'B+%=-%?0(A3'B4*G4)D14" 7)'@0)C5+H9%C4&I9!D3 A/<,!<.#<1'<.$9+7(#A/%I5"K4#J5 @0 9*.!/"/"6&:+<-1$*0"-! 1% 7)5% 4%0".. / 4$7'3$, #'*,&##%(""1$.!*&'%!'%!'')$(##%( -'"#"&%#(& &"! %''",".?2.J7(D1$@- ;)-I61M;EdO5R>+G35S;1S;-R81T<2U=3W?7XD5TB.L;-L8-M70R90P8(D11I99R?0H50H4>YC;ZC6XA:^E3T=$A..G57Q?+F2-C4/F7-E7.J;/N:*J6'F1-M7(G1-F2 2 '5#,A0/B2/G80P<$E/#?("6&%8($7'"7%'E2+O91\C9bH2V<5S;5P;6Q=2T;-L3*J1)G3&=+(5'$6* 4& 6$#<*6P?'@1&;&.B01F4-F4)D1)E0$5& . "0" 4#0-+)2"'@1%;)!39&!8&7%$<*"=+;)!9,&'.>1##&, %#!*$*!, +2"7'5%)1!"A/,B0'=*!8%8&%=+'A/'@7)G9+P:'O6)Q;"G6$C5'A2&:+ 8&-K7/T<(Q6.Q8)I2'J5,L96SC6UD1N>&C4 D4%H8!>0$E6"C2?/ B1-UA&P=&C,&H17]G&O96#,J7*O>'O; F2#B.'F1B,+F7&M;%N9?-$?,%D/&F3&J40X?/\C,ZC(W@/[E0`H*Y@-XA5\G.VD-K8(G4-L80Q91L80L80M<-N<+M9-O;-P;,K7,J3+G0*F21M:,N9.L82J73H51G4,G3.J0/L3-K3,I2*J5/M:0Q>3WB0V@,R<1V=0T;4R;-Q7.R8/O6.L60Q>/TA/R@.N9/K40I24N62W>6WB5P?3M<-J5)K2&E3(C0-E20H5/L;-N?+N=)N=*R=*Q=*N80P;/O=/N=0O>1L=-F6+?/)>.+E4(H3)M5(K2'H/,G3-H4,K6/O:/N9*I4)F0&C-&C-#B+!A)'F/'H9)M=+I8,F4+G3#E0$D1*J6+I6(E3)F2,H5'F1)H5)G5+H7,J7*J6*I2&C-&@,(=,%;-%;.(A2*J8)P;+O;-Q;&M7+H4$C0'F4%H2'M3(O5*Q8,O6+G1-J7,P:+T=/WB.XC+WA*T?.WB0VB&V>.YD.UD.SC.QA-N;)L8%I3'N6(P7)S=,XC,SB(J6+I3*G1'C1(F7&B6"?4$C4,L=*M;)N:+ZD4]E3YA.U>,Q,R<*M7*H5&E2%E3*L<.VA-WB'R:)F5'D6(L;+R>,U>(Q@+P>-VD+O=%B3(D5+K:.O>3XF2[G1\G2]H-YB.U?1V@/O<*H7-I:+J:&F2,I8.H8-H8+E4+F2)C/+C/.E3*D2)G4+J9&G4$D4(G7*J:'J7*M9.O?,O@,P?.P?1O>/I:)C1*F6)I8)K;(J5%G1)G5.K9-L8*I4%B1&C3%D7)E5+E0)F0#D0C2 =.#>.#=+(?-#=(:$"7' 7$ 9$!<'"@+'C3*@1'?2)E6$A2$A/#?+%A-'B-*A.+>-$6%%5$'8+"9*"<,&A/!6%*,+ 2$%:+ 6'3$ 3#%:(*?0*?0*?/*>/)?.&6%-&:+%>.(?1#8,#5(*;+)?+(C-)I1.G4,B0)?-*@1*A3$>0(>,)?,*@-+B/+D0*C/)G1&A.#:+(=/'<-"8'";+&;,':+(<,(A.&A-&@.&@-'B/*E2(D1:'"3'!:, >0'D5(G6&J9(K8!A18(8* 9+(A2(A.(>.)C5&I:$M4V;<^G.S=1V@4S;.O80P=-N:0M8/L5:Y>2O78S?;VB/M84T;6WB7R>&?-)D40J;-C5-F71N>+K:-N=0RB+O='F1:)!9*%7!(A*-B6(B4(H8.L:-E2(;)'A+*G2)D/,E1/M5.S8-Q;,M7)J4.P;5YC2WA6WB-O:,K5/K4+?,'8&$8'%6%!4"8%(C0%9'(B-3O=3OA)G9@ZK4N;#0# *%1%0#()%, 9%)F-&B) 6#'=*!4!"9% ;(!<.1%(##.#%/%&!(,.#.%)!( ))&',6&?+$F1,J2";)#<( ?'#H.+L8,P;/N<.O;!H6#M:)Q?,H;,G7$>-'C0-O<2YH;gQ7YD,I7*L;)K:6P>3N>.K6>&#C/(M;E6$B9&D8#C3 >*(E7$@3<,*O7.Q9!>-%B1/R8*Y?.[C(P:$F6)F7(B3#E1-R?)M<?/$E7(H;'I3%J5/V@0WB*P<)O:,WC*XA*ZB,[C0\J%Q@3K8.I6/H53N65Q=4R>2O>1Q?.P<,Q:+I6/M81N8/L5.L8.M:-O8/O83Q;4O;2L93J72L31M5/L5+H1*H4,K63P=3S=.P:3S>1Q92Q81M90P:/P80L71M80P=/Q>-N:.M8,J3-J23O66T;?XC:PA8M>0K71O7*G4+F2-E0+D1+G5,J;-Q<*Q<,U@*Q=(M8*K6/O<-M:+K8.J7-G4(A/&;('B.$D/)L6*K4)I2-L7/P:.P;,N9/P;/N9-I6'C0$@-!=*!=*%A."C3$E5%B2$>+'@-#?+!>+(E1-K8+I6(F3*G4%K5'K7'J9'I8'I5*L7,L3)G0&B.&A.&A0:)%A/%F3!H3)K7,O:)O9(F2%C0&F3*J5'L4)N5*Q<*K7$A--K7-P>)Q>0XC.XC.XC+U@.VA/T@,W@-VD1ZH0UC-R@/UB-R?'L8'L8%M3*Q:-WA*Q@*N9-L5.J3&B/&B3'B5%A3&D50O@4UF-P?/]H2[E0VA0VA+P>-J:,J:-P=1WA-S=,N9+J6&F4%E5'K:.TC.XD(T=,M:'I;*RB*VA,ZC,WF)P>)R@(L;&C3$@0&G6-QA1XG1\G1\G4_J1ZD-S@3VC2R?.M:.O=1R@*I40M:0J:2L<,I6+I4-G41J65N<-H6)H5)I8$D2!B1&F6+N=*P=+Q;,P@+Q@-TB-SA4UD,L9*G4+J9,M<*K:(H4$B-&D4*I7,O:(J5$F4$F5'G9)J9)J7*M7$F3%D5!C1 @0$@-%?-&A- ;'!:(8&!;(!<("=*$>-&?-'B1(D5$@/:'#=*&B.'C/&?-(@."5#"4%'9("8(9)#=-1!*+ - !3&$9+!5&"6'"4&'<-*@0)@-+@.,?-':)!., 4&$>.)D3)=0&8*,>.+A.-G3*J3,G1*C.-E2+A/*D4&@1*A/-C1.D1,D2.E4.F4,G2&?,$8)&:+(<-&;) 9(%;,'9+%9*";)&B.&B/(D0*E1*E1$>+6##5(6';,$@/)F7*K;+H5#=+7&!8 +'?1"A-%A0+I:$K;G6D2C1 ;)03" 8*6(5%:*8*/!1$8*<+:*8)4'4'4&!4&1$ 6) 7'4%4%1 /,/"- *&!*'#(,"+#&%&(  %$$" !"##$!!$(& !$'##)%8))9,%#(*3&+A2.L;-J=4Q;4N:7L;'?-(H35ZC;[G1Q;4U?>^H-L95UB8U?0N9/O<4TA4R>0P88V-N:3O;#?, 6&/':'0I32H7*E4+J91Q>.I6*B.-K5/L80L92J70L6,L3#F0 A+)H34T?1R<4VA9XD4R=/J7/H6-C0(:(':*+=,+>-/J7%@-(<*,H1>YF0N>-I:3K;6J7(8*!/"$5%"8(2"!/"0#5#%A+/L49% 7'6#!6$":'9&6(&=/*9.%!1&*(' " '.!0$/# 0'*!&$#&$;,-H8)I42S>-N6&B/)E0$J1*R8:_I6\F,N9(M7)Q<&Q=%M:'H8*M;$J5+P;*R<.UB'N:$E1/L<1RA:XH(A36%*L8,U<0\F/ZF(QA/PE'J=$G6 A/;+8+>-1T<-M7.%E4,O8$M8%M7%K6&K6*M;(K8,Q92YAIqY@gQ&K5-O;/T<*Q;+R<(O:"H4)L;$L8&P;-YD-[G,YH$PA4L:2K90H53J64R=3R=-N9,M8.O:,N8.I7-H4.J4.L5-M8)L7/M70Q91V>3U>4O=6L;5O70K41M6-J3,I4+K6+K63S>1R=1R=3P;.J6-F5+I5/N9/I61L:-L9/M:0O:+J5-M7,M5+L47R;:V@7P>7O>0K8-J6-L40O7+J2,J5)H2*I6+Q;-U>.WA+T?+O<)I8,L9-M:(I6,M91N;.K8(D/*G3)I5&F3(G4'E2'M6.S=/U?+Q;*K6/O9/J9'B2$?/ ;* ;*"=,&A2%C2<)1%:(!:&"<*&A/.J7)G4'E1$C1#I3&K6)L;(J9$E2'G2+L7,K6(F3(G2(K5$J2'E2!C/"C0%D1&E2&K6(G5&F3)I6(H5(J3*N5)M8&H5%F5+J9-O?)P@-T>/XC1YD0XC0WB0TA-U?,S?0VD,TC-UC3[I.WF'M;%K5%J3&N6-T>+R@)O9-M80J6)C/'B1&A2'D5*I80PA.N@.PA,YG/VD,S=,UC,R@,K=+H8-O=1XB-T>+O:1O<(I8&H8&L;)N>-UC'Q<,S>(PA*VD*XD*]E+YH(O= G5&I8%@1">-)K:-XC.XD0[F5_J4]H0ZD,N?0QA3UD2U@3WA0V@/L71M:1K81M:*I5)J53M:5P<8TA4R?-K8+L;(H7&G7$H7,Q@)Q<(Q;+O?)Q>*TB/XF/V@(M8'L8*M:,N=/O=(E2#@+$D1)I6*L8"G3$K6 F3'D7&I9&N8%M8#D2%@1C3!B0#A.$?-'C/"=)#>+ ;($@,$>+$?-'?-&D0)G3(D18&5"";$#?+%@.'A/&?,!7( 5%%7%"8&!9'!8*. *+"-"!4(&;-'9)'9)(;,*?0(?.)A/+A.*>+$5%".+ 4%$?/'D3'>.'<*+A/2G5.G5*F3)E.*D--F2&B.)D2'D1-C41F62H91H92I9,E4.F3(<+%8'%5(*<+$9'8)#8*%8+ 3%7&$@,(D1)F2*E0$@+!:& 7% 2&0":*&@0,H9-M:-J7";) 6$ 7%$<+%?- A,>,'F7?0?.>,<-3$.4#(?0 7)2":*8(6(9+8)<*9)7)7)6'9'!4'3& 7)1"1"3$"5#-..!(''')(&++!(  !()&#$ !!"&&% $"!"%#    "$ $# )&0$.9,%6(&@2#@2/L:1H7*<0+(H61ZC1R@/P=8XC8WC/L87RA;WC/K84R?3R?.P;3U=5T>1N75Q=+G31P;3U?9WB0I7,C1-G5/G7*1ZC,W@'M8A/)O:*VA8cL3[D/R<.Q>0P?)I8-J:4O?.F8.F6)L8.^F1hO.^I+SC)K=+M=,M<'H7$C5#B5)I8,L8/N8)I7(K6(N5)K8(I6@-&M7'Q:%Q:)P9,T<.U=+S:*P80R:/T:,P8+N9!C0#C2(G7$J6(Q<)W@*WE)UE*WF0N;1O<5Q?8UA7U@5T?3R=/N9-M7*J5-G5,G3,H1-K4-N9*M9/M7.Q70U;3V<6T>6O<8U<8S=4Q:1O8/P80O:+O90T>3XB/S=3T?.L61L8,I6-L90K9-I5*J42O;1N:-L6,M9+O7*N60T;6V@1P=2P<,K8,N9*O7-R:.T>+Q;'K5*N8*O9+Q;*S>+T?*M<)I8)G3,J7-J7-K8/P=0Q=/M7,L5*K6*J7*H7)G6&K5'M7,R<)L7+K6,H31L=-H8(A2#=-"8) 6($=*&C0#>+%<)'<('@+$>,'A/'C0,H5'E2#A.$B-(F3+J8+I8,G5+F2)J5(G3)I6'H5)N7&N3(I5!D/"@-$>,$@-"E1%H4'G6+K:(I5*L5+N4%D3'F6*L:.Q@-RB/TC,UB,WB.YD/ZE1YE/WB*N>,Q@-T?/YB/YE/YG*UE'N<#F3"F0)M8,S=(Q=,Q<0Q<.M8+G5)E2,K7+K8/P?1RC,P?,PA-YG)P>%K8'N<(M>*H;#C3'K92YD1XB/S?.O;)M<&K;+N>&K;'M;'O:(O:&N?*VC)WB,[C(TC%H7A/%C2%@0%D3*Q?)XB-\F3_J0[F4]H2[F.PA,P@2WF4YE6\G3YA4Q=3O<1N;1M;/N:*L72N:5S>9XE4T@.O;-M<,N?(K:)M<,S=%N9$L7/RB,TB)UC+ZC.XC)P;'N8)P;-N=+I9(D3%A.&D1$D0#E1$I5%K7"H3'B3"C3 H6#J4$C1$<-A-"D0:'&A/(B0#?+"@- =*"=-#>-%>,(A/+H2(F2'A0!8'4"!8% :)&@.'@/+B4#9)5&$6$"7%"7%$9+!2$, .!0$"6)+>.+>-,<*'=-+A0%>+&>+(?,$:'!2# *,1"!;*'D0*C0)B//E3-E3*C1&?.*F/'B+(A,'C.!;)!>,-B30H85L<2J:0K:'B1/C5+@.(:)%7%-@/%9' 6'%8*%6)0#3"$>,'B0*D1*F1'@,%>+!8&2$6'"=,&<-/L7.Q=*I6!>, 8&!:( =+$F3#C.#=+$<.:+9* 8(:+0!.'>-&>/"7)3# :*;+;+9*6(8(7'8*;+<+=)"6)3%3%0!0! 3$/*,-- -!- ,- '. !2$ ,"$"#&()*)!")& #(&#"$       ##0#$8+'8+- ( 4'/I:.E7#8++B4-L<.Q@.K:0M:=XD9UA.K8;VF5R>1L:2N>2P=/O;5W?0P83R;6S;4O<6VB7WF4Q?0H60F4-G6/H8,@0)@/3O=>bI*O7+J6.I7+C12L7(=)$4!&8&+C0'=('C,.M46UA.N9)H3*J7.R=1O;2M82J8,I6+K6+K6*E1;&3Q<>^I4WB"F4/SB7YH2TA5WA9K:4I75L:0F48O=9S@0[@7aH2[D)Q;,L77S>GaO?XD$?+'D/.K3(>($C+%E-'D.,H5%=/"9+,F7&=.2 <)*D2+@0-=2+6+#(!!#!#&(#, :)9*0$))(*"6).I:,M<'K7/R>-U?0SC.P?3ZB9bI*J6/K8*E2:&0YD2[E D-4!9ZG.WB*S?+P;6T>8YI6ZF C0,I6*B3&;0*=1+N;-_G+`G.[F%G75&,I9,I9'D43PA:VH.N='G6'H7,Q:.V=/X@(H4(J7%K5%M6)S=-YA1WC$K6 I4B-%I5&I6+K4.K6+I4(D1+G5-I8-Q;+S?-ZF*ZF+YE/]H/N;0P=0S?4TA7R?7S>6S;3O82N8/I6.K70L80L60M60P;-N:+J8,K51Q74T95S;6S=4R;5T<5V>1S;1S;-Q9.R9.T:0V?2U?2R=4P<0K6-K7.M:/J7.L5)M41N:/M8/O:.O:+P:+Q;,S:.V<-T=+N9)J6+M:,N7,Q;-S@-S@*L8'G2(J5)N9)O:*O;-N:)F3+F3*F2/J6-L7/Q0Q=,L8&H5)G4'E3)G5,L7'I3)I4)I4,G3*E1-H6-G5)B2(?.#9(#8(%8'%>,"=)%@,+D0*E1)D1(C0(D1)E2'B/&B/*C0(C1)G6*I8-J7.I5)M7*J8*I9'G7%J6(N7)N8%G2$@-%<*$>,%E3&J8(K;)I8&F3-L7.L5*H6)J7.TA.SB3XG1XG.YF-YG,YF,ZG0ZH-VD,P@*O?,R>.XB0YD,VD$P?&M;#E2%F1&K7&O;,R=-T?1VB0S?.O<.N;+M9+N:1SB/TB*O>-SB-UD+O>(L7)O<*L<)F8'F7#E63YE3ZE2VB5UD/R?.P@,O?)L;'L8'M7"F3$I:,SC&N;*T<%K:&B0"?,%B.)D1%G3+WA)ZB,ZE1]H.YE1]K1]K,RA+Q?1YE4\G6[E3WB3U=2Q<5Q=3P<.N9+M5.M8/Q;3VB3WC2UA3TB,P@+O>*O;&M9)O:@.,O>,TA,YC,[E.[E,V@(R;+Q<,L;*F6&C3(E3,I5'C2&D4&E4'G5#C.!:* >-#D0&F3%B/#=) ?,#@-!<)&B/'D0&B0&C0%A/#=.9*$?.(B0*I4+F3'>/2$2!5&";)(A/)?0'=."8)"7("2#$7'%8)&8)%6&"1""4$$7''<*(>,+>+-@-.D/+C/%>+!:'%<+ 6%!4%++2!"<)'B0/I7,F4.G5-G5.F4+B0%@+%=)(?,$:)3#!;-(@-.F5/F4.I7,E3#?,.B4*>.)<*+?,)=,!8&!4&'6*#/%+0!#9'+B0+B/+C/%?+!:'8& 5'#<-&@1$?,)G4$I5+L<$@1#<+ 8';( A-"A,8' 8*#=/8)"7(!8+ 1$$5$(?-&>- 6':'&>-(A1 ?/:+1#"6%6&#=.$A1"A/ A,"7*"8*5'2# 4%!3$+)*/2$+*0"0!.1!3$)%%&(')+ (#"&&$! "(*+$## !'0$*$ -$$8((@1 9+'A2+D5,E4.B3/F4>ZD2O:+M54T?0O=1O?7RC1L:5S?.P8&D07U@;XA:XD5T@0SB3R>2K92J8,G51K8)<*(?07S@7YD*N7/N;,E6,C1/J6%;&'9');+%?0*@-'A.4P=5S>.L7!@)*K56YB3T;6Q<*D0&E2/N93R=,J5$E/4XC@dO3T<%G1/P?/SA6ZD=`H>TB2M:4N<7L:2J9/Q>4\E5`H1]F1YB)K6-I5.J62K7-G4%C/2P:1G3%B)0K5%>*6%2#3%&A2#9)&)B/)?.%6(%8,.:/"&!!%&*/!' (8)5'3& 3', )$<.%@0*K:-P?.SA0VB+R<+K<&E6 ?-)D3-"#2&.!3"A/'K8?,!;,6UE/PA,P@(L;1R?6ZF1]E*T;6S>.D3!5''=0%H6&W@.`H.XB$F4;,#A3<-%E53TBAcQ3UB$D6$H5&N6,[?4bJ-U=+R:)O9)O:(M9+R<8[H.TA%M;)Q@(N=D3'E2'C0!>*,J6,M9,Q;0U?*S>'U?(ZA3aG/[@.K81P=,J81P=8SA9T>7R:6Q92L6/G6.K82P;6S<4Q;0O:-M93SB0M74O64Q40O5.O7/P75V>2V=/T;0V,(;*';($>*$@,$@,(C0*H4,H7+H5)E2+E3*D3-F5.H4+H5)M;(L;)M9,M8+P:+L:(F8&D7%E5'J6%L5'I3&A.)=--C4'G6%J9(K:'I8)H8*I4.L5-K7*J7-S>-U@0WE3ZG0]J+ZF*[G/^K,YF.XF0VG,RA/VA-U?,U@'P<$N;"J6&G4&F4%K8$N>(N8,S>1XC1YD/V@1VB/TC-Q@,RA,R@+SA,UB+Q?)N9)J7(M:&I8*G7$C4&J9*S>1ZF5ZG7VG1U@4VD3VD2S?.N:)J4'D1*H:-N?(M80R=)K:'@. :'"<+(C1'L8(YC)ZB+ZC2]H-ZE1^K,\H.VD.VD-XC/XC3WC0Q=0U=1T>4R?3O%J6'L6%G4#C2*L<+R?*V@*YC0]G+XA(R8,R=*K:(E5)F6+J7+H4)D3*E5(B2&A/">*#;'$=)%@,&@+%B+"?(!<*&A.%=*'A/(C1'E2*E3'B1!:-:,&B0(D1)F2*B2%;-1$5'5'$:'*?/)>/%:+$8*"4'&7*(9+(9+(9)'8&&6$%7#+?*0E0-E0,B/2E2,C,&A*!;'8& 7&2#2$,*/!9((B0.I9-I7/I7/I7/H4+A.)B.$:("9&"7(. 7)%>+(A-&A--H4.I5)D0*?2(=-)>++?,+A.#:($5('4($.$)- &9(0C3)=+!9%#<) <( <*)@1*C4%?.4!:&B-*I:&@2%9+/ 2#9'>)!<+:+#?0#@1";+$8++;.,?-*?.$=,(=/$@.+C0(B2 ?.8)* 1 "5'";+7';';' 6(6(5'4$!4%-,!)' 3$2"*,-!4$.0!/(+')*+ ) &'''+&''!"#! "#%%' (!*,*%%# " '.1!4$$@1'=,)8'%6%4G5?YB-L3<`G3ZA0Q@2Q?5P?/I92P;+L4+J75T@2R@8SA0J8-I62M;.E4-C6-I8/Q=5YC2O?.E92M:+G1+C-2D10E5&A24K:!:*?YG-H4+G2)C-0Q9:\D/O7:W>9V@*K83S=4T?/N9)J54ZD>fP6P8,G1+F5+G6.L61O7*C/7UB8TA3I7+E3!E2"E0.R<4ZD3XB.J8*C3(G09T?4N; >*=XF8L<.G08N:*>-!4#3##7'!<,$9($7',C1!6')!8-(:.5:3 ! &'*.+'"'%7)0" 7*!8,#7*0#/C12M=)F6,O>$J9/VD.VC8^G5TF4&/"/#%!%&/!"?1&H6$A0 +6TF0QC4WH0VF2[F/WB)Y@L{`=\C1$9*%E7!I7&W?-_D(S=!G5(K<0UE+P@,R?9bL/WA#G3)K='L<"P3$W:$W@*W<)U:.V>,Q; A.8'=&)N8*Q;-VA1[H%M;*M;&I6%F3*P:,W>*Y@0VB*U@+ZC+]B0]@$N,-E1-F1-I54O;9UA8T@6S>7T@1L9.G30H64Q>0VB+Q=*H6-E30G51J71M7-J5-I2.J4*G0(F2)J5+K7.M91N70M:2M81J30H2.E30I93O;1P93T?1S?.S.O:-R;)R7*P5&J/(F/)E.&@-)D1#G3(H7(E5'B2)E3)E1*E2*I3(L3,P6.O7,F3-D5*E3.J6.J6,J8+I:)G70J:+E7*H5,J41K3/K8.I6*E1&@.'?-)B/)A-)D/*F3&A/'A-)C-'C+'@*)>,(;*'?.'B3(D6(E4)I3-L5)H2+H4.O:0R<+O:.P<.N;-L9*N:+N:)J7(I6'G5(H5)E3(F3*J3(H2+K7(I5$K6)M9(F3(E2-H5.K8,L9(K9,O>0TC,P?4WF,YH*WD,XF-\F+[E-]G)[C+XA/TC0R@.P;,N7/M4(E1)I8#F6(M>'O>,P;-P>.RB1TD2WD4ZD.VG/TD+T>.YC,XD.SB*M<%K9%K4&H2%F4#G6#B5(K<+T?1ZE3YD5UD5WC0\F0aJ0\G/T@/S?)M7.S>1T@.N;2Q?/L<#D4!>,(A-$>**I4.SA,TA1XD1\F+[D'W?,V@.W@.VB-UD+P@0QB1O=,T?,Q=+O:.O9+L7&I2)J5+P=+P?/M@6WF,P@)J6(I5"E1!C0$K5$K2"H30R=,R>-XA-ZC+U>&R;+P<+M;$I7&L8*N8)G5*H5,K8)E2#>*&?,(?0%>*'?-$=/)B5'B0%B/(C3)@1,D5%@2%C4&E6&B4&@08)(B1)C2&B/&?-"<*7'6&!3%#;)&>/(/(;()9(.B32I:0J70K6/N5+E.';,!5'2 0, !0".+1 :''B2(G9-C4/E4*F2,G5(9*&=*(<+':)#6$0!3"$8'%8'&=*)D0'C0'A/(<-+>//@2,>-,=,+<+%;$"7$%4' (*,@0)C/&<-%9*$<(&C,$E4+G4$>+0"*-#=+.L7'B12%''"5'!8':';(#C0#C0#C0&@.'?-0F3$8*)>0'=/#G5-K;#<.";-4')!1! 7&6)/#/$ 4*4% ;-4' 0#!.!-#3(./ 6#1"-!- .!-!+- +,* '.",-/"*(+-!) &(-"/! + ((*(.!*-!)(+--!&#! !$!!   !-!(+8&$=+,?-1>/.:(->,*F12T>3W@,P9/X>4W>,H4-L62P<2L;4O=7R?;X@.,G4,G5'@14L=*E2!<)=XD*E2.L8.L96^D5N86K9.K71T@-O92XD4W@3V<,S93Y?/S;-H9/H6-F21J4-H3(C/:T<8U>6R>4L8*D2:'?.(K50V<.W=.M84G6-E34O;/O7)J38U@=WD.L9;SA,?,&9&#;',H5*J4#C-.N7*F2/",!0%#3)'1'%'($+'%+$!9-$6&"9+!?. @+*F00E5(@1/P?/ZF2aK9dM3YC5ZD.J50",*/#' *(D3 ?,#A/:*0 3U@IoZDnW1]F7`O)XA$X@9kS<&6#(E6+Y@+X?/[D4_I/\E+XC>hU4cM6fO;iRAjT3XE)O8)P?&Q>-VE4WE$@/*S>(V?/ZE&J6 =)7"'@1,L9,R<+Q95\E1^G4U@.S=+V=+Y?)V;+Y=2]L7gS2aK6`G/X=H+-E1*F1-I52P;5Q=4R>3R=5P<1K7.F20H7/M:.P=)L9'C1(=+*D0.I4-J5-K3-K4,I1,G0)D0%A.$@-*E1/J3/K80L61K41I3,F3.H8.L81Q:4T?1UA-S=.W<.W>1V?0U?-P;+P9+Q8/R9%G.(E/)E1(C0(D1#F2,K9)D5(B2'@/,E3.I8*J4*N5+Q7.P:,J8/G7/H5/J60K8/J8+E7*H7.H9.I9*J7(I3.J3/I6*D0'B.&@.'@.&?-$=)%>,$?.$@.%A/(C0&B-'>+(:)$7("9*#>/*F30L83N;0K8,G4-K9/P=-P<-Q;.P;)J3-N;-P<'K6(I6&E2&G3(G4,L70R:-O7.Q<(K7%I5'G4+I6*H5+J7/N;+N:,N:-O;,Q=,R<-S>*UB'Q='P;*T>(U?,[D.\E.YC-R?,M<*J6.M8/N8/N:-M;(J:*M<.QA/Q=.P=.Q@/SB/UA3[G.XH0VF-UB-XD,YE-RB)N>#K9(O;'I7$C2&H8'I:.SA1[F,W@0WA2WB0WC0\F1^I3[F2XC-U@+V@.YB.XB-U@0VB/TA*M:+H4)D0(E0*J7,P@+VD/VC0ZD)U@%P:)N9'M7+Q<,R>%J:*N<-O<(P;)O;'K6*K6(G2)I40M;-O>,O?-K;0P?/TB*F5#B/ A.B-)P9"I3&I7*M9(N9)U@)X@*T>%P:(M8*L;(N;)P;+O9*J:+L<.P>%E3$@.'A/*D4(D/'E0&E3(G7*L6)J7+G4+D3+B2%@0'D5%E6(F7'C3$?/&A0$A/#>,&?-%>, <*6(3%!8&(=-)=/%:,':+$7%'9+.A1*?/-D30E4-B0,A01G90J;0M95R=4S:,F0%;+ 3%/. -#/0 +-";+'C2(E6*A2&=+'C0-G4$7)':(*<+*=,&9(/!3" 9&(<))@-%@-#?+%>+$?/&?/'>.*A/*?.';*"7 ';'(:*#/ 0 +A0-I4&>."8( 9%$A+#A0#<,2#)$*)C1+J8+G6,%+!4$&=*!9' <*(H5#C0&G3+J7)E2,F3&A-&C0&D2,P>,J87'!<,7'1#.!5'.!**1#5%!:,5(+". !1" 2%-13! 5&0$,,++.!,- .!), +01#- ()&#%-!!5)#8*!2%!/",,/ 1"0". *++'4)'4)#"!%!" !"#" #!#)+)':-"9))@-+=+*5& 0"-A32L<4QA.K:6'@`O8RA-F6/K:2N?8RB6RC6R@9V?YG9VB4N=9O>:S?1K8,G5)E2 :'3J;-C2,F4,G6#A+0O;9[DAfM-G1/E3(D21UA.Q;2T@7U?9W?0U:3V=/M5&@1*E30J72N75Q<1O;7Q:2Q:4P<3L84L:+G3(A2)D0/R91^C2[C7XD!:')D1*K4,O83R>,I6-L5G`L,@-$7%)B./K8,J8!C/2S?+H71"2'7)-! $'))!0$!2$+!+"%-<2,B4$<*(A3*F5/K72O8 ;,-P=6]I7cN:dO5\I-T@+O9,I6-@10!-"!5(3+%@2)E66$- .##A15WDFlW:`K,S>%J9-VA)YB0_G4ZE!@.'C40WA,U=)P9'L47hM;nS"P9(L8)I7&F40H4,G4.J5.N83O;/P:/K7.J62J72F30K7/L8,M8*J6&A--A/*E/+H1,K3-M5,K2,J11G1-A.)@.'<+'=+/G0,G50K73N83P80J8.I7-K7/P88ZD0R@.T?.V<.X?0YB0VA-P<*O9/Q;2R<+K5*G2*F3'D1(F3'H4,H7)C3*@2)@1'A.,G7+J6&J3)N7+P:,P?/M:.L9-K8.J7/J:*D5+G4/I8-J:-O=*L8-K4.F2*C.#?+'A/'B0 ;)!6%$9)%:-(=/'>-*A.&?+'<)&8'&6%#3$$6'$@-(D1+G40L9,H5*E5-J:-L;,N;+O9,O7(J0)I6,N:(K6%H4(I5)H6(L6+N8+P:0V@.T>&K5%F3(F3'E2*I6*J7*N:,Q=*O9+Q;)O9.T>,R<(N8'L6&K5)N7&N7+V?,U>.T@)L8)H6+I70N;-S@/TB1VE-P?.R?3VB/R>/Q@,N=*O>/VD0YF*VF+QA+P?(SA-YF/VF'K;'O?(N?*L<'E6&G8)L;-S?/ZD,XA+W@/V@*U?,YC.XB4YE4[F+XA+YB*XA.ZC*W@,XA,U?.R:-M7(E0,J70QA.UE*WD+R@,R@'N9"G3'E2&H3)N8*O;&M8(O9,R<*R=&M8%F3'F2*G3+H3,F8)I:,M,!@.!C0)P;#L8&H7)L;&O9(WA'X@(T=$P8$I4(L;(O<+S>*O:)O?)M=,PA'J9'C3)D4+H7(H2)L4(M8(N9*R:*O;+J7&A//G5*D2'D0$E4%G6(E5%@0$B/<*$?+%=*(B/#A- ;*3$$<**A1,A2*?0,A0(<+*:1+>0+C/-I30J6+E4,E30L<.N=2R@4U@2Q;+G0%=,!6(#4$"0!*"1 !2$,0!7(!<)%@1!9*5#*B0$<*#8)'<*';**>, 3"./ <(&=*'>,!:(;(&?*&@1&A0)A/'@.*@.%<)&9$&='%:'':'&<(,I66V>*E5 9)!:'#=)9*!5(-!''0#*E5.I9#?1++ 0!#9&(;*#:(#=*%C0%F2(K8/N;+H5-I5(D0)J2+N7)L7!>+8%<*:*!7'7)#8+,()3" 7$$<,0##- 2#0#/ 1 5# 5&0"+, .! 1$"4' 2% 2$- +, -0!.+*%$,!#7,!5(,,)*-1 3".&''"+!##$%%"%###! #!#     #!%$(+ 0#.@21/A0(:'&5#!9*B\L(C3,E6.D7/"%?1/G:4M>.L:3S?)E00J82K<+G89O?6$?YG9TB3M;AYGE^I4O;4P<*D3*C08O=3H93L<,I6(I36YA:]E1Q9'C-)E0@]J6YE)O:4S@:UB.M65W?8[B7R>7('A//K85R:5U?7WB5P9/P96T@5O=-F54O?5O@4O;2U=0Z@%Q9@*!9'*F1*M5.T<1V@-M98U>-G2.TB)N=.SC(R1UE)Q?)R<-S>,V?:iQ9cO3\F#J5$H4'F2%D0*V;+Y>B,#F3)F7/N@0J80J8/K80L85P/V=1X@/V>/T@2UA0O=1P<2P=.L9*H5)I3(E0$@,&D0+E3*D4.G9'B2)E5*G6)H4%E2$D1&I5'M:,O9-P<,O;/P@-O>+M<)G3,H6,J9,O>-R=0N:0J8)A/&@.&A-%@,"=*#5$&6&'9+-?2/A1+?.(<)(;)%7'(8''9():*'C/)E2(D2*F3)E2'C/*E6+J9+N:,O9)N6&I0'D2+L8'L8'L8'I5(H5)N8(N8*P:.R=-S='L6&E2(E3)G4(E3,M:)N:'M9,Q=+Q;+Q;-S<+R8+L7%F1&E0#C.%G1&L6)M9&K7'J6)L9-K;.L=(TD'TA,VD'R<-UA0WB0TC-P?*L8+P<-TB-WE+UD(M=%I9*QA-WE0YF'K;'O?,UD,P@+J;)J;(N9,T?/YE,VB+R<*P:*Q@'Q>,T?1UA1V@*V?-W@/XB1XB-U>0V?.U?1U<-P9+L9,N;2XF3\I-ZG,Q@$F5#G7%H7'E4&D2,N9&L5$K5(O9,Q<'K:&H6'F3)F3/K7-I5,I9+L<(L8/M90M:/P<*G8"A/%D/*M7'M9!I9*N>+P?'Q@._H)ZB'P:!K4"H3%I8#M;&Q<*P:*N>(O?)P@(P=$F5+F5)I7*L5*Q7)O<(Q<&R8)P;'J7'C0/H6+E3%A.!C2%C3%B2 >*%B/>+$@,)B.(C0&C0$B/"8&&B.,E30G80G80H6-D0,?4.D5+F10M50M8/J:/L91P>,M<0RA2Q>,K7+I4'C2*B4#6&++"1 ,)+/"$<+)A/$=,":+"6("6'7('?-&=+&<*4".3!$@+&>+"8)6&<(%B,)A/(@.,B/,B/2E2,?,&:%!:$&A)'<),E1+K73U='C2!;*:' ;'5&/$* &%/"&A0.I9/M>/!!4&"9&&:)%;)%<*#@- ?,'G4-K80L95P<4O;-J3-M5%G2 ;(:(<*#?0#=,#:-#8*"2&$/! 16$#9&"8'*)-!5&1$1#5$$6& 3$ 2&-!-!"7)#7*$8*!3$!0")+. 2#.,& %'- $4')&''"& 1# 1$,(( ('!%'&" ##!!&#   #%!'&(0#*:,+*(9(%8'2E2EaL>^I9ZF-Q=6WE=),P70X>:_H0N:(>0,F51L95W=:ZC0Q<,I21Q;:YD3M;5N=9VF?dO7XE0S;-T<2X?+K6)@.)F2-O8/U=2WA7WD6R;0J5-E3*B1'B3*I90J8.H6'@0 #.!/"5'"4'#0$$0#/" 5((>.$9+!8+$>0$?0 =,#8(7'/L<;]L<`L.%C790$I8&K7'M7"D0'D2#=-3L>7YH+R>)K7%B1"@/ B3"C4&I92XF5bN(]EE3D2-M?$D5>.5[J9bM7[K6TF*H;;\N.UE+T=,W>.Y@*Q74XC6^L/WG,WE-VD%L8'P;>lTR‚lJyc3]H#I8"E4$D3#E4#H6$K6*N90WA2]F.I7/I70J72N63L93N9,G3-G3/J63K74K8.F3+E1-G3,G3+F2,F4+H4.K7-J6-H2*C..B,/C0/A03F52I61J41I9,G4+I2+I2,J4*E1(C.$@)$B-%C3&F5+M71U;/Q:/P<.O?/N=1N;/O<+J7)H3+J3)F.'C+'C-+E3-G73M?1O@-N=)J9,J:*F4$B1"B2$H6,M9*M7)J:+N=+O>*N9'I4)I5*J9+P>,P*";'';)&:)*;,/A1/D3.D1);*(:)&8'(;*+>-+@/*D0)B1(B2'A0)C0(C.+H5'F3'I6.R<,P;%H1'E2%E2%K7&K7&H4%F2+R9(N9)M9,O;.Q;*L5(G6*G7'D5*H8-N=+M='N=*P>'M:)O:+R;*P9*I4)G3(C0%C0$C1(J8&I5$H4&K7*N:#E6*H;%O>'R?)U@)V@.YE.XF.WE'N:&I4,O;*Q=,TC)T@(K9&F7(K:,T@-T=-O='O<.YH)M>+O=/TA.V@-WC-WF-SB(K8)I4*K;&N<+S?1VB2U@0T=0VA.T>1V@*Q9,S9*Q7/S<0U>/S@1UD6^J4^I1[F*L<"C1"G5'K;&G7)H8*K:&K6%L6$J5&I6'H7&E5'D3.J71O<,L8,N=*Q<)N9+I4,H6)G6$D5'D3)H3)J5&J9$K=*RC)RB)WD1dM&S='M7!H2!E2 G5"N:-YC)N9-O?&J9&Q='P='K8+J7*J6+N6*P8+N=$J:%L9%J9!C3'C1,F5*E3<(=,#@/"=*!<*!?,>*$?+,E1&B.$C0'F2+E3*H3.K82O=6Q@7R@2L9.G7/I7/K8.K93O;1M8-M:)K8*K;/Q@,K:)F3(L9'G8*D7'<-.."1!- '',"8&';(%>-8'2#0!7'$>+$?,!:(5#04!">("7%2"6&;'$F-&A/'@.(@.)A-0F2+@,)?-%@-(D/*D0,H4*H7/N5'C1:):'8&2$.$,!(&. (@.1L<4SB9+ 5'/1 !8& 6$"9'#:( <*'D1)M90P=1O=/L8&B/,H7#@/#>,:* ?/$D4%A2'<.!6)"6'&5'&5$"6%$;'!:',.!!4&8( 6' 5&3$0!1" 3$.!4&!<.";-!7* 1$#2"-'-! 2$/ ,+# #(* ,! , $ "!,!/! ,,)&!!$)& !!! #$#"%#"#!&(')%. &&("1$2"9O<1I3!7$-"3#& *A0*A.%@-'I2,P71O93N85L;2G92H;-G71M:2K80J7(D1(D1)G37VB0M5:WB2O<0N:8VC,M8)E-1M8 H2&H2=)+M78[D=]E4K:+G24V>4W?2R=.K92M:-H6&@.*E6'E5(H74T;=[E&@/!7)&7+ 1&1$ 6(%9*'<-(=,)?.&?/ ;+7)"@2&G7$F5&F6(G7-M:&J50V@3]F5^I5ZJ+P>1VA.$F7+K<)I92VC/\E-cI.]F*Q?)J9&D5'J75[F.UA.TA2XF;_OAfU1YG(S<-[@1]A,R92VA3[I-ZG1^N+RB)L;)N9,Y@7eOEr\(O;'M8&K8#G6(L=-UD/YH.U?1YC&T<0L9/I71H62I42G4/F3*E0,H4*E11K73I40G1+B,*E.)E/)F0*D4+E4,G5*D2,C1)@-,B-0D11D34G66O;3O91H9(C0#A*'G/'E/)E1*A-'B+$@,(C5(E5&G2+H0(F0*I6,K;/L<1M<*J7'I5(J4)H0+G.,G-,G0.G4/H8.K=.PB,SA/Q@.L;*C4%>0#@0%G6-H2,H5)D4+H8-L:)J7'M7+M9'H7&K9,N:*F2&B/'A/'@.%@,#<(#<)!=&$?+&?-(B0+G3*H21A1->-)<+*@.)A/+C0*C4)C2'A1&@0$@*%B)(C/%D0#G2,O;0S?(I6.K8.N;)N;-U?'J6(H4'M6'K6$F2&H4&F2%F0#E4(G6*G7)F6-L;1Q@+QA+O?(N;)N:,R=,Q;,J7,H5+G3*F6'F5*H8&I5&K7)P;&M8"D4!@4%H6&K7&L6*R=.UD-WG*UD)Q>-Q<-Q<)N;(P?'Q;)K7+H7/O>3YC1W?-K7(N;*VC(O=-S@.V@.XC.WD+TC*O?+H8,F4-H9+O>*T@2WB4V@4S;0V@/U>0VA)P7+S;,T;.R<2UB0TC0WD1\E(V?.T@,N>$E4#H8$L<&M=(H:+L<'L8"G3?-#B2(E5,H8.I:.K6/O<-N;*S=)T>%L6(H3'B1%B3%H8*K9*I5(H4%G7'M@(SD#O>(XE1eNJ4 C-%L7"H3E3%Q>-ZD(N8*H8&J6&O;#M7$L6-M8+L8+L4*M8'I9%F9#E5"E6<- ;-(B1(D48&!=,'A0"<*7%$A-<'"=(+D1%?,$C/(G5-H5)H4.O;2P>4R?4R>/N:2O82N:,J91N?3M;2N8-M:)L9+L='E6#B2,H5(N?,NA.J=3L*N:&F5 @/ >0">.";+">.#B3&G9(C5*<-6'%;-);-*8*(8),E0#<*/ "3%$:+ =-%;,"6'/ / 3$0!.!7) >/ >/!8*#4''5$#0 ,-! 2$0".!*$"(,0#)' ("*!)"2$,",#$$%%""!! "#"! "!" )!!$+ +*($*!$&-1L9.@1')'#"-=0.!);-$@//G6 3"-D,9O<.A3,@3*@2%?-,C4+C4&B0*H56U@8V@;W>=WB0H50H94M;5Q=3P99V?;VC:UA1H5,A/+.D1;XC,I8-I7-L;(K;)L6)E0;&(G3)O67\C4L:,H40O84U,J7"E2/Y;@fM4UA/H;"8,4'"9,$>/%F5,K:$?,&>+(C3(D5>/:+B1!F5(M=,K<0L;&B/:$,U?.VA,UE.XF8bL8`H%G50C5%A1 A0)M<*G95(!A0&F3$A1$<-"4&#/!;,&F3'K5'P:#O:*XG)%6+)A3=YJ'E0!=-"B14QD1M>-H8(F2"J3(Z>/aH2]G.P?2O>0Q=+Q<*Q72ZB-YB6`J)S<C,#O83bH3_B/U;C/2YI,YF)UD*QA+N>)M8)U<-W?D."G1'H5$F2%K7'XB-aK/_I9_M6XG1UE0L6.H6,E3.E41C1,?,,@-.B/+B/+C/+D2*D.'B(*D+-H0*B/.>2,>0/B0*C,)D/'B--B1)A.)B..F20J75O>/F3(?,$;(+C/(A0&A0)?/'A/%B/#B/%E0'E0*A.)C.+H1,K6,J8-J;,K;+K8)F3'C.+F//J2,I6-L9,K;-N=.O<0P<1K;.G:(B4%B3&E4+K8,L7(I4)E1*G3)H3)L7,K:+H9,G8)B4*B3'@-&=.&:,(;,*=-';*$<)'?+(@,*?,&@,'C/(H3&=0&=/$;)*?,-C0,@1,=.';,+B1(B/'=,';*&<,$=,#@-+L9+O:(N6,M:0XC,XC-YC+Q=+J7)E0&A.(F3*F4$@-'A/+B5.G6,H4(H1*M61W?-XB-WA+R<*Q9*N6/Q9-N:-K8-K8)L;.Q@+J;+Q@,VD)O='F6&A1&D4)M8(L8&N9)R=(U?)XB*U@)T>,VB)UD(SC&O@$N7$H3 E3/VD0ZE.U@(L<*N>(N?,TB-UC.WE.U?+V?)SA%K;&G8+F7.N?,SB*VC(VC0XC.S?&S@*VC*V?+U?,T@+Q>4U@6WC1TB,Q@)R= L5%M8(O;#H6'N;,Q=+P<*P=*O;'J6%E2$@-(A/+L8/S@.RA.Q@/Q=-K5'R?)R>*N:'K6&G8&H;'L;,N=*H8&F5$I4+S@&S@ I7,UA0_IJ3D.'E4$E5E4%U?*WA%H5 D3(H8(J:'K<(K;/O>1L=-I7,H4,H6+H8'D6 B39+4$';,%?+ >+%A,*G3)E2'@/)E/&B)#<*&;,!7*#A1)L6+M4/R:+P:)R<.U@1P=1J6.K7+J6-K80M;3M>2L<,L8)L9$F5!A0&B/)D/(K8&M;(Q?-R@"?,9%:%-""("4%$:*(@1"9*-*/!!6%!9'7'3%!4&*,-3!!;)%B.!>(%?+!?+"A.'C0%B/ A0&D5-J9*H5'E3-H7,F7(C2;*7' :)7'7'7'!6' 0#!/!.*C35UC-N76". + 1"#1%3#7#!8&$:**C5*S>'L8*K7#@1#A0 C1$A3@1B."H4'H6)G5'9+%9')?,(?,%>-*A2*C/$7* 2% 6%!>* A2#=.3%1%.!&8*"4%1"$:+&?/9)7&7%&9( 1 !1 #3"!3#1,)%$+0#,++$",.!/"-$"1)#2&($$&'! " #$!#"! !!$! %(,++ & "%"!(%6&'%&"##*  /$/A40$)!8(0C4%6(*>.'<,-?-*A-(A-*F2.K6:YE8TB8N@7OA3M=+F31M:2M;2K<1L;0I:5N?*D5)A3.G4.C0.B7)A22O;DfM,K3%B+/H26S=3U?)O9.Q:/Q:0T;<[G6TA$@/!;,'C0-L:$D5A1#D2&F2$F6%C4 :- 8,.!$>--P9,J8.H:)D29%"C2/XF5]K4]K;fR'K8 9&&7% 1"/##3*+" 4&%D4(I6'H5(E4'?2)E4+G5"?*(I4*N<'O<D*!G0(J5 @./O<+L8*G:,J<*J9"D3&K<%L?#=/ 9,(E7#C4C/$J4'R>0ZE:cN:bL0UA0U@,V@,X@&P8'N9-P?%F8&E8-N>3VE0S@*L;0SC)VA+VA0ZD-UA+VAK6#A2)K:*N="K6&L6)O8-T:3]C2^G0ZC3YE6XE,H4*E1)B.)C/.B0*?-(>,,C1,B0)A/(?0(A-%?()D++E.*C0.B4+@0+A.(>,)A-'=+*B/+C1+E.,F/+F40J8+F4(B.(B/'@-'@0&@2'?.)B0(D1&C/$A-'C/+C/(C.,G3-M7.J9.I:0M<1O=,I6*G4,H3.K72N:.M;.N<+M<(H6)I5(B2*D5*G7)I8(J6,Q:+J8(G6(D3)E3-I8+H6+G7*E6)C4'B2'A/%A-(?.&;+&;)%:(&<*!9'%=*&>+'>+(A.'C/)G3+C4&=/&>-'=*)?-+?0&7)';,)A2(A0$<*!8%"8*#=,#A.%F3)L8*N9*N=0WF/\J/YG1WE)H7(D0%A-+F3-I5%@-&A.*A1.F5/L8+M6*O9-S>-U?1XB1XB,R=*Q9-S<.R>/O<-M:,R?,RA0RA+R@/YG1YG"B2(F5.M=,S@,T@*S@(R?(R?&T?)T@&Q>)RA+RB(N?(M>%L:(J8&I8,TB.WC-S>1TD-RB,SC-UC/VD0UB.W@,S?%I7%J:(J:*L90SC-VD(VC#Q>-VA0V@'UB+YE*V@,U?-TA.SA6VB.O;+L:)L9#H3E/#I3#I4"H4(N;+T=+T=-S>+O;*M:+I6'D1.I60R>-R@,SA-R@0S>,M7*M=&M<&Q;$M8&N;+O?)S@+RA(K:#E4&K:)Q=&M<C2&M8'Q<%N9@,&C4$B1B1$Q:'R=!D0#H4(G7#B4$G8*M<1P>-H5/L74O<+L6)G6'F5!>-6$5&&>/&A0 A/&E1*J6*G4(E2,J5(E. 9'#6)#8+#@0(J51P9.O8,Q<)O:+Q<+J6%@,'B/+G4.J70L91K,%A-'A* 1!#$* 1#)?.-F5&=.0"- 0""5%3$2#1"/ +,/ ":(&@.%@,3 9&<)#A.#?,!;+?.&F5(H5(H4)G3-K9.I:(C27'9*!;+8( 9*"=,!8("2#"3$!5%)B13O=,M6:&+,!-. 2!7&!8 )(B3'J7%D1"?,$>."?/!B1!A3"D4 F2#I4%F4$A1$<.$=,#?,$A,(F2(E3&A.!8* 5'%<,'E0$C35'/"1$#8((=."7();+&<)(>.5&5&$8+$5'"1$$2%#3% 1#-+'&'2&"5&/#.!/"-!)%& %,.!!2%/!%7($3$$3&*)(*  !# "  ## $#&!#%$**+ +" &!!!&&!&.!##$&$%+ !!+*7**>,!6$5F5.';+4N:*E26R>:U@4OA2N?1N>%D1DdP;\F7T<9V?4P92M81I72F53O;:^G?eL=\F9Q>-D3/L87S@3O[H,E3+C3+K8(M='L:3WD+N: A/!A02L;3Q?)G8&D5'F5$A0)A20"."#6*0"4%0N> 9/-E94&#?/7VH;ZI)F6>-3]G5]H)L8'@-/!# -"@/.Q=6\H2UD,L<)H8(G5;'/Q=)N:D2$;&$<(#;):'%C0)M87VH0UD-UC*R@1ZI;bS)H8'B4-F9/J;&G4!G1!I4D1?cONt_?iS3`IH61YF,P?$F6"A5+G<"D6&J:.SA0XB,RA+RA/^G.\E(T?&R<.[F+[D-cP:lX+YG#J7%D0)B/!G1(P;6^H/WB.T@2UC-H4)E.)C-,D,)A0)@0)B1,F5-E6*A1(=0'>-$;(+A-+C0/G5/E7-C3/E3,B/,@-)>+)B.,F/1K4.J2)E/(C/'F5(F5*F3*D2)B4'B3*C2(A0)E1%A-'C/'D/,D2'B/,H4,H4+F4)D6.I60L90N;-J:-K:-L<3O<,L:+K:-O>.N<*J6*D4+F6,H8)J7,P9'N5)H7'D4(D4*E5*D4*D4+F5,F6*F7(F2)G2*I0+D1*@.+@.*?,%=(#='$<+#:+&=.#=-#>.'B2&>0$;,%=+"9'%=,)@0&7*&:-*D4(C3%?/!9)%>.&@0)E6(I5%I6$F2'L=-VE+VD,UD-Q@)I9,G3,G3.M81P;,F4(A1-G30L8/N8-O;+Q=,R@+P>-R@4YG+S?+T?*T>-VB-R>.Q=-U?0YD3XD,TB,XF/XF+N=1SA2VE/[H0\I-ZG*TB)SA&Q>%S@(SB-TD+N@.N@.M@(M=,J=(I;-RA+S@1V@3YH-TD.XG.XF0WE/UC-WA,Q>*I9)J9'N;)U@/XF/ZG&V?%S=-VA-U@*YD.\G+WB,U@/UA3WC1Q<*H5&D3&D3"A.%D0"E,$F2%H3)N:-V@(S;,S>+P;+L8*H4*H8/L;*M9+Q=)Q?,SA0VB)L8%D6#I8 P<$V?'V@*U@*YD+XB%O=%K9'M;%J9&J6#D1%G4)O;(L8&C/"@0$A1B1#K6'N9'F3"H4&E5"@0'J9+O<1R=/I50L80L80O:(J5'J6$>+"9&#:(&?1(H7$H8'I6*M9-M:*J7/O:(I3$9( 3%!7(%A1)I52O8,K7(H5*L;*M8$D0!='!=*&A//I7/J80M:0M;*L8,L;&C3!>.:'8%;, E6(O@0RB#?0)D1/E2'8(!, ),!2$-B0/I6*B2!2$."$6**7+%2&,0"-,1"7($>.$>,!;)/4"8&">*!:*3#:*%E2$E1&E0'F1*H4-K8 :+4$8( 9)"<,"=,#?,(B.(>+/C1(=*&?++G6*I3"<(0#+ 1#. 3#7%7%#;)'C0+G4";)"9'!9*!<->,?1"E5"I4$I4%H5&D3(B4%B2"A.'F1+L7&E2%D/"=."<-%?.%@,8*/"+3$%=-'?1!:))=*+=,&<*2#2$"3&!2& 1$#2%#1%"/"*,"'(!/%!5(#7'/" 2% 2%/!*(('',.!0#0 2!!3" .!'&)+& "%!"##! "$"#''!!!&')/$!.$* $,%!$&'# '$!!%$(/B1/+7)&$2$2$)@-5N;:TA/K<.K<4QA+J63R?&E06R;=YB=YD:T@7SB5Q>3N;7S>8S?:YFFgS;_J4XB5W@6V=+K62N<2Q>2Q>2V@0V@/R:4P82R?.N;*L9-Q2V@5YC<]G8S?/I8/N@*P@*N@+O@.SB&J6&G5'F5:TD.H9+E7-G9%@1 <+1E6., $6)/!(@1*L=+I=!<1(E5EfQEhV+D45%(C4*N<:`N?`N*D3- $* !" %"?/%J7)Q=+SB-RB,M=*L;(K7%J6(L:#I8)>*!4" 5%4%3 $C/3UD$L:'WD1cL9iS7`M2WG(H:(?4$<. >/(N9*N> @.8%9%>lT3kS(TA3]L&L;%I9%G8&G9G7F4*S>/YD+YB.ZH-YC*VA#M8'P;0\G0[F6aL8bQ1[I/VD(Q?&O=!I7(N=.S?+P<%J7/SB,G3+D0(A*+A-*B1+C4(B2&A1'@0)>.'9*%8'$6&&=*+@.-C1.F4/G5/E3,B1+?-,A.)B+)B,*E1+F1*E/'E/&G5*I5*F3-I6+F6+G8+J7.K7-I5*F2)F0(F/)B2(C1&B/&B/&A0%<.$?,*E2.J6+H8(F6-L=1M:/N<,L;+M<+K8+J7,G6(D4&C4&F2)J5%H0&?2#=/*D6*C6*C5*A3,D4)E5*G7(I6*I4%D-,E2-F3)C/'@,(B-%>)$<,%>.#=-"<, :* :*#;'"9)$:,"9*'>/'?0(;.&=/(D3*H8'C1$?,%@0)E5(D4'G6*K7E0$K;)QA)SB(P?#H8)K;.K80N:4U<4S>-K8(D3*F1-L60O<-P?*O>*P>)J:+O=+Q>+SA)SA(R@+XB*Q<)M:/VA1[E2ZD/WF.ZH0ZH4ZI4YH2[I0^K.\I-ZG+UC)R@*R@&SB'SA)P@+O?.N?-K=)N>.O?-O?.TD+S?0V@6^N.YH.XG.XF3YG-R@/WB/R?+I9+I9+R>1_I1`I/]G/^H-[E0^H/^G+\F/^H.YE.VA.T?2WC2R=&G3%D3+H8+I6)I4,I6(G4%G4*O;*R<(Q;+U>)M9+K8*G5*G7-M<-P<$J7#L<+TC-SB&K7'G5"H7 N;$WD)\D-\D+\F)YD)WA$M<'L;)J9$C1'D2)K7*O;'K8'D1'D4&C3#D4#J5&L7'G4"H3'E3(C4(H7,P;0R;'C,)E0/L8.P;'J6%H4&@,9%+C1+H5)J:&L9$G7)K9/R>*M9-L:(G4$<*!6%#<,(H6,L8/J6'C1'C2,H8%B2#A-!A*'D3*F3+F30L9-M;/P<*L;*I8#A2"<-#=,!;(8*@2-RC)I:&B2,G51H5+=-"3$"1"!1#$7&.D1-G4.F7"4%!2&&:.-:.(6*"4'/!- 0"5%!<,#=-";+ 7%/5#:(&A12#1#!:*%B0'E2!?*!@+*E2/L9./ 5&3%!8)$?.'C/+G3.G3,D1"7$#:'*E4)E0";'.!, 1" 2$3$6'#8)&>+*G4,E3"9'"5$4% 9*#A0>1!E5 D1"D0%C1(D4(A2*D3*D2*F2)D1&C0$A-&@2"<-%A/$>*/"-0 4%%=-"=+ <)%:*$;)$9'0!. #0%-/"1$"0$+)*!( %!3(5'%8'!4'!3&!5%-()*(*1#2%/"+- ."+ ""' &$$&(%#!!" #$'$  "&)%"!&- /" .!%/$"$$!!*3E4+  %. .A29P=0H5)A3+D55N?6P>/J7+G3:S?8Q<9S?A\H?_H@eN=cM9XF1P=,O:1R@=XI8RA6P?8S?:ZE;WDDbN@^I>^I=YE7R@:V>5Q;/I70L90K1O=4R?6VC1Q?/WB7VC-H50N9)N;,RB5WH5WF7VD5TA)G3*G65OA7SB/I83M=.H8!<-,E43%0# &+/P=3[G0TD7ZIOu\IqX'Q:@/(D4#=-9*'B1(>/ 0#*%%,!,#5*4'%D4,S?Eo[T{j:_O/SC.TB0XC.T@"H6/SB(G39% :*'>/$>,'B.%K6(T?#U>+_G8hQ.ZB)UA%J9&B3&A2&D2&G3(L8-L80K8*J7"M9)^G3dL*XB)T>-VB,VB+WB,WE7aM9bL1]F*ZC+\F.XA,S<&L6)P9-S=.W@0QA/O>+L;-Q@/[G-[I)SC$K9$H4?,%F6-QA,E3.F4(>-&<,&<*$=+%A.$@-%;));)'7(&7&&8((<*+A..C1-E2.D2.C4/D5-B0,B/*D.'B/)D1,G3)D2&C,+J7,K7.J5/K6.K9.L;-R+";("9&"8)%=.'A1$>/ 9*!9)":'$;+$;,"<-%?/(B1+@/+E4*I5(I4)H4*F2#A2$A2%B2(E5&G6&K7%O>'S@(R@"I8(M;*L<.M;,O9+Q9,Q9*K9(G8'H3-N;-N=)J:+O=(K9'L6-S>+R<)Q>'Q?&TA&S=)P<.R<+S=.YB5\E0YF,XE0^K3[I4\I.[H/[I0]J1[J-UE*R@+P?-VD-UC-VB1XE/TA+P<(Q;.R?/SB,UD'Q@+S?3^M,XG-WF.WE.SB.P@,R@-O>/N?)K;.VB1]F4dL4bK3aJ2aK/`J.bK1cL1`L4^L0WF.S@-Q<4V@/P<-N=-O>)L8+N9,I6+H8*H9(K;)M;*O:)R;%J5'H4)F6'F5(J:,N;!F3 G7&L=*P@/RA&J5#I5#M;*YE+^G*^G)X@,]G-\F'Q?&K:)H9%G3+I6+M9&M9'K;'G7&F5&D3%G7&L7(N:(I6&K7&D2%?/)I5,Q90S9&E/)F2+H7*J8)I6'I5'C/$?,0L9.J7,M8)M8#E6'I6'K7&H2(H5)H7,F38'(E2+N:,N:,F5"<,";,'@0'@0&D0$F/*J8+H9*F4/M:-P<,Q<*L;)G7"<.#<.'@/!;)5%$D40UD#B2!;*'C0.C1)>-'<*!7%&;)%9'(>.(@0.F7#6'$7)#:+*?/,@0,>1):-/#.$ 5'#;+$<- 6'/! 1#4#!:*":+1"0#"8*!<+!<*:' :(/H6%>./ ..+2#";+'C1&B1*G6)C2"8("6&)B1*F1":&- ,!1"3$4&5'#8(*D1.M70J8 6$!5#2#"9*!<,=1$F5#B/!>+!<+(B2'C1-G5,G3(B0(A2'A1%>+$<.9*%@.)@-*/ 0!5'9&;( :(:*!<, :+5$0!/,.1"3$/ . /!+ +"4(6("8&1%1$ 5&1 /,++- 6&2#-&'-+) $#$&&%((#$(+(! #"''"!%,*+.!-8)$ %% #2!1D3(##1%/A42G9+B3+@3-C45M>3N<.K8/N9D[H.C0=UAHbNB^J@`F;]F9XE7S@5R?,R<0S>@^J;UC=XE7UA3R>9SC;VC8VB:YD?[I:UD3T=2P:.K93N?5RA+K8.N>/P<4U=8YA7YE5UD,M?(G7+K8*P94\B;aF1U?5VA<]F>^I:[F4WB.PA-H7.I5-P9*O<3UC5YG8]H:]G5U@-L89VF;ZI'?/!6)6K>"3&()#2&%7+#:- :/'>10Q@GnY@kV:)>.0UE9`O3\J.WE&L;%I:%E27'6%":+&@,"=(,T?-WB%R=)W?-\B/\@(W?'R='N;(K8'E2(E0'L43T=2P<,K89)!I83_I%N9E2"J7#Q;$V>$N<+S=5\E-V>&V=+^G0^G+W@+U>1[E,XA9fOBra?iY+N>+K:,M>6ZH,YF)Q= A+ >+&E4'I;*B1-C4)<.$9,&:(#;(#>*%?+&<)&9&&5$&7%'9')=+-C/+D-/E0,C0.D4/E5/F40F2(C.&@-'A0%A0'C0'C/,I3.J3-J1)G/(I2,M9,T>-R<.O:/O8/P9,N6,H:+H9&C0%@-$=,%;,:&:&#=(%=*%>*(A-'C0*I7-M<(J9&F4$D1!@,&B1(A3&?2(=0(/&@0(C3+F6+E5&A-(E3$D5 @2">0"<.)>/(@1$>. :)8&$:'%=,&?-%A.&B/$=+$;)$=*%=+'=/(@3&@1(D1,E1+G2-N9-O:+L5*I3%D5%C4&D3)G7*L;+O>(U?'T?$P:$M9*O;-P<*L;(N8'O4%L4'L9(J:*O;-Q?+N>,M>)L:*N8*P;.V?.VA)S>$O<#M<%S=-S?0S=1V@0XA5\D7_M/[I/\I-VE-WD*XE,VE.VF3[K.TE'L<)O?-S@/WB.WB+T?+U@*T?)V+N=,N=*N=,P@-S@1YD4]F5aK3aJ5dM0`J,bJ*cM1dK3cO7bP3ZI0TB*M84ZD2WB/RB.UB*P;*R;/L<-K<'F8+J=)K:,O='O8&L6(I4'D4%F6)K<,K9%G5$H8!H8(M=,N=+S;&M7$K9'P>,^I&]E*XB.\F,[E$O=)M=(F7%J5-O;*M:&O:'N<(J9(K9*J9)K;)P;)Q<(J6&L7%C/$>,)I4*O6+N4*I3'F4'E5&E6'F6$E2$@0-K:4Q=.K7-M8,M6#D5%F5+K7"B.#C0)G7,H48&)G4*O;-O=+E5%;,%;.%9,,D5,I51R;.Q?.M=)G4.N;.R>-V>)K;(F7";.)A2(@09'!8(1Q?(L<"A0"=*)E0+@0&?,&?-$>,$=+$=)'<.";,'B1$9*$7'(>0(C0-E3,@2#6+/'/'!4&"6'"6'!6&/!.""6'#;+4%. !2%!6(5&8( 8'7%-C4(;/ 3$-*$+6'">. <-$A1$?/"8)!4&+C3%A+3 - /#0"3% 8+ 7)&;,(A-*L4.G5$;*%8'$7)%<,!:*?1&D4$@-9' 9(+B4$B-)H3$C.#@.%@1&?2'<*!9*"=.'A/'<*,.0!4#9&9'8'+;T]H8R@:TB4P?4RB8RC3P?0Q<2T@7WE:XI1W?4UA/N=7UE5VD)K82L>0L:3R<2R;1Q?*M=$G9)D5,F4-Q:1ZA,W=2[A8`F7^D2X@5]E.T?+E9$;,+F2$J2'M5;WE0YA5^E5\D/V>2VA:\KDeS.M:7S=5P; <(<)+I5"@.(D6'D5"D1 D0'I86TE2N?+H32R?+L?'N<)G7$:+$8,'>1#7*$:.)A4-G8&A1#=/6*4&:)+T? I4>.(@2+RC3]L4_L)SB+Q@*M>0C5#6'2%5%!>*?*)U=1ZD0WB0YB6aG.]@*Z>,[C+ZC)T=%G1 <$)L26YA-N9(E48*&?3C1!@2 >1B4)SA'UC)P-%;($9'%:(%9(%8''8(/8'*6$*:((>++F1(D0)C0-A.1D1-C1-B//A.,?.(@-#?+)B--E2,F4+G3.J5)E-)D1(D0+H7(N8,P>-O=+M;-O<*M8)H5*I8&F5"A1#B4!A1$=,&>,'?-%?+&@+'A*&@,)B/+E5)D4&C0#B-$A*"@+#B.$@.&@.(>.*?0)A1'B2&C3*F6)C3(F5)C3&?-#>.8' 8(%6+$:, 9+8*8)$;,.H2*F3%D4%E7"B3!@/"<-%;-,>1,@1)D4&H6)H5+K70N92P<0L:(C3(E5*G5*J5)K6*P=-TB+V@,UA)P?'N?+SB)R@+O?)I9%H5$K6&L;&G9(OA+M>/L=2R?-S<,Y?*[A+YA+W@(Q;%N;'Q?)S>.ZE1_H-YD-WC1XH8aM8`K3[F,V?*W@*YB,ZD)XB-[F.XC+P?-N?,O>3XF4ZH.WB,XC.[F0WB3ZE4[I3\J.WE&P>.VD+XB"Q9'Q;,O<+I:*H:+L;-Q>/W@/[D/\F6cH6_G8_J2\G2aK/dL/dO0bM7eO4`J/YD.ZE.Y?1XB3[E0WD/UA/U?3VE.O>,J:-M;+L;,O>&N;'L;$F6'G6(H7+M<%K9"D4'G6&G6(L9*P=%P: H3!G5-UC3aI.`E+ZA+YB+VC)P>*P>(M9*Q:)O:%N7$N7&S;$R;&S?$M?"K<&M:,Q;*L7'I9">/%<.*E5+K7,K5(J5'J6%J6$F4#B2"<.)C3,M9,Q=+O8-O:)M7#D3&E3+H8;+$=.)D4,F7)F4*K7,U>)O<(E7'@0$?/$B/,J70N;3P<(R<-R<(K4+K5-P:-R;2M=-H7&C.)E2*F2$@+>*/UA'J6">+%>,$@-(=+%;)&=+&>,,D2+B/,?1&=/'A1%;))=+&>+'@,'?,&>/%9,2'!1( 2#2##5'%4&"."(2&%:,(;.+-!4%6'4$6&7'6&"=- 8(3$. )&- 0"2%6'#9'$7%"9(#>.+@1';."6( 1%!.$#-$ 9)"<+(=+%;,(@3-G:*C1(<*&8'%8'$<*;) ?.%A1%@1"8*%9*)<-';,(@0%@0!A.$A/'@/'8+#;)#?+(>+"1#*,0$2$6( 8*"9+&B2&@08(!:+8(6%1$6&:)&<*!5%4'&9+';,+@.(;*'8*+!*"4&$5( 0#$1!'2"&.!- 4% 3%-+%*17&"7),'%&(- ' $&' !$%)($! %$)(%)2"!2!'%$""!% "! &+%;+'=++B/3I65L:3##45K78I;)4((9,;UG/F5+G-4S81P;4RC9XG4Q=7S?5M:7Q?4P@4P@8T@4R>1P>0P;7S?9T@;V?+H55UE2RD9WF3Q=/K71I96J=,A3&=/+C6,M6.Q;,Q;2ZC1XB,R>1ZB6ZF6UB%A-A^H*I1$=)$;+'A0">,(D22P;.V@8`G2[A.P='>/$5** $8+/L<4R?$>- 6'6(6(2# 3$3#"B2.S?+H5;*%H74VF8PB/E64%1"3$:)%B23P=2N<&@. :*9)!?.?0%A/&C0&G4'E7-E<'PA8cT+WGG3>fP2U@#@0!5)!3&8)@.'H7,V>/\D2^E0W>2Y?.Y>)Y=,[A5aJ0V@&G0)E,)N7.P>A/'G7$F4)J:*T>&T;)Z@1dJ5eQ8hY.XA"G6:* C0'S,#=,"=,$@-'@.(@.*>/)A1'B2'C3*G7)E4%C-(B+'@* ;&8"5 3%4& :* ;,!>,%A/,I4-K8'G6%E7$C4!A0!?/&@1)B0)C3'H6&N8,N;,M:*K6/N:.M;-K:)F6+J7,N83WB-WB)UA-U?,TA*Q?(N>/VE,T@*O>)I8%H4#H4'K:'H8&K;*M<0M>2Q?2XC2\F1_H0ZE,S?*Q<*R=.U?,U@,YC1`H/^H,YD.YH3`M4bL1[F+U@+W@.\D-ZH*YB/]G0[F1WF-RA-SA1YE8^L/XF.YE3`L2\F4^J8`M6^L0XF+TC*UC*T?"I4*M:*M;(J;*I9)I:+N=*P=/VC1YE1]C4]F5\G0ZD3aL3eM.aK/bM0bN1`N.ZH.VE1\C2[D1XC/U@2VC1V@/VF0VD+P>,P?-SA+R@(M<(K;*I9,K;)I9)K;&L7#G1#E0'I4+Q9)O7(O;%K8"G6,TB4bL,aH(XA)YB-WE,TB.SA-R?+R<)O:'L8$K6%O;%R?(R="J=F7 H5(M7&G4$G4#>.$=/+F5*H6)H3%H1)K7(H4 >. 9+#:-)@.+I6)L8)J6*J5(J5'B3&B3*E5#?.$A/(E3,I8)F5+N:+S>'N<'F7&F5$E4(L9+Q<0T@-P<&N7(L6+J5&C/(G1,N80N<-L9)H5,L7,L7$D/#D1%J5"C0%@.(@.$?,$:($:('>,)A/.E4,D2-@0'>.+D2&=*+?,'=*%>*&<)(>++A0)<-$6)1#1#$6(%4&%6&(7(&;+%8')/5$3#0"2$6'8)!;+5'2#+((,/"1%4&2$."5'#<.+B1(?.&=-$9,%7)&6)&?0)@2&=+%<.)C4-F:)C1)A.%9'$8&8& :'=.$@0&@0%;,#7(#5'#8'#<* =-#@0'C1%<,$6(":)$@,$9&,* /!3%3$3$":+'>0)B3#;,3$ 6'!8)6%2%:+#>-&;)%8("7('<-,C2+A0)=+#2%*/ !4&$8)%6("1$- ,2# 6'"3$*)').!4&!3%'#'&)(((  %()%! %))$"#"%&%)0!0+$!"*")##$$!"% 1#+<,);).A.!3$(/A+3I6.?0 &3&1I;1E66P:7S;2N;9RC5M<6M95K83L74O<-L9.P<3M:2N;6R?7VA6U@;XD4N>(D51P@B_Q0I<'>1-H70K:5N?,E6%?/1L:1T=7]D2ZB:bL7_I'O9+O:(I6)F48&FcO.N9&@-#<*&@0&B2*H40P;/R=7YE2T@1N< 3&")!!3'$>.6S?&A.3$2$1#0!/ 2""?.5XD%B0+H45VD<`M5R?,F6":+5&!:+!<,(D42K=6(4%9)$A0'H6)G9(B2'C0'I5(J85RC7dP6aO*T@#K7(N:7[G3PB*B3#/V>0[A2[B,R9$H1C+5XA1V@-S?.U@+Q;&J3+E1'C2>--RB&Q>'TB2]G0_H-^C.dJ5kU:p^)S<-RA.QA,R=%Q=$TC&YB1\E3WB2WB3cK6oW4q^/iT.eP1dQ1`N7eU:eV,Q@/R<)O9/P>'A4)C.(C/)E1&C-/@/'9('8*'6((7)(6*'8'&8'&9($;)'>,)B/)=/'8*&:+%>/$=-(;-+@.(D0)G2+E1+D1+F3-E3*C0,E1+D0)D1&C3*H5+I6+I7(F3*F3(B0&=)(@-)B.&?+&?.'A/(B0+E2)D3*F6*G8$A1'C3&C3&D4)C5(C4$@/)-(D1$A--@2,@1'@0&A1(D4%B1&@,(=)%=(!<'6" 4!2#3$ :( >+ @- A,'J5(J6$F5$E6$D3!A0"?/$@-'C0'E2'K6(P:-P<*L8)J5*L6,M;+N=.M:/P<2WA.V@0^G(YC-T>-R?,R@,RA,Q>*O:*RA)J8'G4%I5$G4(E3$G4)J7/N;4TC4WE0WE0YH/YG,S>+P%I9'L;.SB0ZC4]F0VC0YF5bL4dL3cM0cM)`L*\I*VF-SF.ZC,U@.U@3YE2VC0U@/XG.WE.TB,S@+R?+S@+N>)J;)H:)J;(H9&K:)K7$G3"G3'L6+Q;+Q;)M=(L<&J:*SB2aM,aM)ZB)XB+VC/WE1XE1WC.V@/R?+N:$G7(O>'Q@'O:"I<E6!G5'K5'L7#C/#<+$9+*C4(E4(F3&H/*J3)E27(4''8,)<,'B0'G4*H5)F2*H4'?2#<0(D4'D4&E1(K5,O;,N:*O;&M;#J9&F7)I8%H8+P<+Q=-S?)N:*M9%E2$A.%@-)E2-K81T@-O;+K:(H7)M8$H2'D2'F3&E2-F4+E3%A.(@.&>,(@.(B0*C1+E30D1*C/*D0*?,,>-&>,";'$;'+A.1G4+A.'=+4( 4'%8)%9))>,,@-,B.#8&/4#5#4"+.! 5(4&#:,3$5%/ +(- .!.$3'+%.!%:,-E2,F3(C0$?-&=-)@1&=0$;,":*&A1,G8,I:+H7&?0%8)2#5%7'=,%A1'A1'<-&8)0" 8% 9';("=-(@0#:+"5&$<+(C/&:)+- 1#2#3$5$#<,!8)$:($9)1"0"4%1#7)!=-$?/*>,&8'$9(&=,+C1(C1&=,!5&/ 3"5%#9*"6)"5'/$1$5'3&"0#&'#%(,(&#'''))##()+&"!! #*+ !""&&" #&')1)#"(!. &"&&""&  ' ,!+#0!(%4&+=,2F60@2"*1&+=44J93K84J;5H:2E55K85M:4L81L9/M8/O;,C16O=;UB=ZF8WB@aL*C6/L:9XBKjV%<.$6+.I:2M=0K="?.,L90S>8^E:bI8aH[I9\F/J6+G4.K8*H5.M:0Q<4P@-H91K< 2%$#' 0$%=.,H5!<+!;+7)7(3$2$"8'(D0$D3$B..L9.S<)M72T>/N<'D4%@0(B2+F6,H6%<0/"":,!>."B0!E1>0+H6-O:9dJBmU+I:+K;D2'O=.WB3YB.X>0ZB/T>(K61WC;XE3S?.R>2ZEJq\2XD,D0$>.%I7*RA%R?%UA4]K0[E.[D3eM*^I7lX7cL/VB/SB,T>'TA!QB#TA'Q>'N<$J8(XD@x`7o\*aM'^HAu_=n[,ZI1WH"C21U?.U>*N,*<.->0,=/(=,&;*'=+&<*&=+)A/)=/(;,$:+%@/(A2-?1-B0)D1(G2)C/+D1%A.*?0*@.+@.(@.'B/(C3)E1)F3)H5)D1&?-'<+&9()<+,A/*D0$>*%A,(B0+E3*E5*D5*D7%B3&A1,G8*D6)C5)D4#?.(;-$9, :*"=-&B/&A/)>0(=.'=."<,(D4)E5&>/%9*%:,!;+ 7'.!0!4&8& >+>+ @, C.#D2%D3)G8%E4$C/'@0(C0)D1%B/)H4,M7)L8'J5)G3(H4)J8-Q@.R=)M8(N8+U>,ZD)YC/T?)P=*R@/VD,R>)O9*R=,N:)H6(K6'J4)F0'H3-M91S?8ZJ3XG0VF1ZI1XG/SC-Q=0VA1X@,UA,YD/^F+\F(YD(YG&YE,]J+XE(S>*T?0YD0ZJ.ZF-\G/^G-XD*TB*R=,T?-VD+UC0YG2\J-[H2]K3]K/YH+RB.WF+_J1YF-H8+B4(H9.TD/XD/VE,RD'K=(L<-R@3]G4^I+SA0YF5bL4bK3bL/aL'ZF'XG*WG*RE*UA+T@0YD4]H4\G0XC-WE0WE0TB0UD,Q?0WE-O@+M>-QA,P@'K;&J:*I:#F6$J:,SB,SA+O?)L>*N>(L<+RB-\H)]J*WB&S?)SA.YG4^H.YA/UB/S?.Q<'K:%M;#O<%N:"I;!H9"H4%K5$D1$B/%;+#7(%>/(E4(D0%D.(B/!<)4% 2&(:.(;*&A.'E3*E3(B1)D4'?2%>1)E6)J8(M8+Q<+R<,P<,O>&M;$I8)H8-I:-K;.O;.Q=/P=-L9)I6%A.$@-&@.(B00J7/V@.P>+J:"B1*K:$J4'C0'G4+I61K90J8&D0(C0'B0(C0+E3)C1.H62H5/I6/I5.A/(>+(A/%@.'>**@-,C0(C-&C-#=/ :+"8**@.,E1,G3*A.!7$5$ 9'4$/"%* 4(!9* 8(7'5%4$/#,*,/$ 0&-"- '>/3O:3N:(E1$A.$?,!:)"5)3%!;+(C3-J:-J;)G7(@1#6'/ #6($9*#?/#=-&=.(=.&9*0"!8&!9(8(#=,'A1%>.#7'";)(@.(;+#2$/"0"1"/!7'$<-4&$9*%9+#6'4%#:* :*#=- <,"=-*=/&9'$9(&?*(@.%>,$>/"7(2"6$4#5% 3*!6)4&4&0#*%'!#&&'& ),*-!/!(" #&- - ((&%$"% ,"- '!"&%'$"#(-('&&,+&'(" %%! !$%&(*6)*9,(<-/>1 ""0%-?7:OA4I:3G:->23B30L87S?1L94O;3K84J78L:/J83PeO9aK/\C7dJ;fM0YA,M;;WH*D5,G69WE=`JC`L3S>3R?,M:-Q)=',S;5WF/O>.J:-I84P?1O?/G8-E6+D6&C2A0D1 F6.S@AkT9hO&X>6gL4aG1XA.Q<.K9.L=%E7!=-.R@-UB(P>*U>-YD3[C,XA0\E6]H9_K@gU;]L7[H2WCChTHkX6UD)I4!C2D2 G7)R@'M;'L;+P<,Q;4]F/[E3cM/ZE&M<&O9"L5.]H.^O)\I(UD%Q>)RA*ZF7mUBm[4dN3cM>oX:gR(S@$F9'E55WB9aK4\I'H:-G7,G7,G60K72N8/H4,E2.F2+C0-C2)?,'>+&?,%>+$=+#<)&<,';+%<,%A/'@/*<-.A0*C0%A-&A,(@.$?,&8+&9*(<+'>+%?-&B0&A1(D3*H4*F2)@0);-(;+'<,(?/*C1&B/#@,(D1(E1'A/(B2(B1&?/'@-,E5.F8,E6'C2#?,&:)"9(!;*"<*%?-";)#<,&=.'<-$;+'@1&A1(>0$8+$<-9*6(/"!3%4&8'8(7&;* =*"?-#>.)E5*H7#E0#A2%D4%D2$D2&C0)D1&F3'E1)G2(F2*K9.QA+R=,R='N6,U<,XA'U?0UA+T?)SA+WC'O:'N6&K6,L9,K8.R;-Q8.M5-L6.N;2VB3YH2WG0UE/ZI0YH0WE/UA0VA3ZD+U@+WB+YB*XB)WB&Q@&TA(UA&O=$L:)U?+XB,WF(UC)WB+ZD)U?(Q>&K:*N>+R@+S=,WA.YC,XE-VE-WF+UC,WF-YH+^I/YG-K<%@3)J:/VD1_I/\J,WG*UE&R>-YB3`K3^K-YF.[G6dM6eM1`J/\H(TA&P?+VE&SA*RA&Q?*WA1_I.^G1`K-[E.YC0XC1XD,S>0XC/UD0VE/UE-SB-QA,O>.N@'M>%P@)VE*UC*Q@-RC+O?&L:,T@*XD#UB$M9 I6&P>(VC-\E*YA-VC)O;.Q=*O:'Q;#S<'Q<%L?%L=!G4'G2%B.'A.&;*&8)'>1(D4(D2%@/%>.$:*4%$:+'=/*>-%@-'F5,F6(B2*D5+G8'E5)I8,O>.S@-UB+T@/Q@+K;&I8'K6.K7-I8+H8*I6.M;.M:0M:(F3$B/'E1(C0%@..H53V?.L:'C49+&C4!C0&A.'F3*I6.K8.K9'H5*H5)E2*F3.I70I7.I71K;5P@.I8-E4+C2-J7$A-#?*(B/+D1)E2'G4#E2&D2*D2-E30J81L9(C/!<)#=,!7) 3%,%+4$!:*:' :':*9)2%*- ++1$0%"!2$)D22O;2O<$B/!=,#=,4$.$0" :*-L91QA/O?+H7&?02#!4%"6'!8)%=-"9*5(#8)"6&!5' 5' 5'!;)(D0'D0'=+#=*%<+%7)!0#2#!3#1!2!!<+7&6%!:,":,%;,%=-"?- >*";*:*9)':+$8&#:%*@+(>,$<)&=.%<*!6#1#--"2$&7*!3%"5( 3&(% (%)%)'**+. . ('&%&'+.-*, *++ ,!,-."/#+%#&&  !).'&&$+ &/$,.+'!+& """   !, ,8,"(9-1>1$& !.&)=42J;8P@3J?2G:7K;5L=4M<0J90J98O<;Q@7M;5L97P<3N:0P:6O=6T@6WB(H3%@+-G04O<$C/D3*S@0\F:gP=cP(P<#M7-WB5^H%L6)N82TA0M<1O=1S>7]F>^G8XD0R>9\G2WB1X@6UD-F8')(!, "-$0#6' @,'M:'M;%F7&J:/R?:WEGbMDcK8L:"=*+H5!<*"@.+Q=*N=1R@0O>,I9+J93RB2M:/I7-H5%C1:('L;0XF)N<=($S:jS>p^5dR'SA)P?(O;%O9'S==`N>fP7eN5dL4_I.TA!D6-J:.P;.U?*R?B4-F8-G:,F50K8.M5/N6,K3.J6*E1(D0&=*#:'#<("=):%9%#=)%=)!;(!?*%=*,=+-?.(@-%@,'A-&<*$=+'8,(9,,?.+B/+E3(C1'B3&D3'G2)H4+D3-?0*>1(?1)B2)D3%B1%D0(C3)E1'A/(A-(>+*?*+@--B0*A2)B1)D1&A.$;&"9%!<) :(";(!7'"=.%>.&;-%:+"8*";+&=,'>, ;(:'7$1! 2'4&7)8)8(#;,#=+%>/&=/)D4+I7%G3!E5$H8&K;#G6"B2&A0&E2(E1*E1-I5(H6.Q@.VA,S;,S:-U<+U=#N9*P;+T?&S@(U?$O7*P7-P<1O;.M:/R<.U;3U:0P=2TA4[F1YG/XF.VC,XF.XF1WE1XF2YE1XC)T@'T?+XB+YC(Q>%N=*PA*Q@-TB,TC,XE*YC*WG(VE(WA*XC*V@&O:,K>*K=,P?.U@#P6(T;,SA(Q?)RA*UE,XG(SD&XB+UD#F8+L>.QB,SA+[E.^L-]L._L._G-_D5bO4bO-[I.\I3cL0_H,]I+VC$K7%K7)T?&TA(QA$O>'U@2cL-aJ/bN)]F+[D0^H1^H,YD-YC-XE.ZG,YF-VD2XF1TB2UD,UC(WB)[E*YB-VA-UF+Q@)O;*R=,YE'WCF1F4 I6$Q>&XB&Y@*VC*P>-Q=.U>)W='Y>&S>#N?%M=$G5$B/&A.%?*&:(,?/+A5'B3 ;+!;+!7( 5 ''A/(C21E3+F4,L:)E5&A2+G9/O>+L;,O>+Q?,SB,WC-SC,M>&E6&G5)K50N6.L;,L;+M9,O;+M:*M8,I8.L;*G7*F5,F6,F62R<*G6&=0%=0$?0>+%A.%F3&G5-J7+K7$H4,J6(F3+G4*G30K85O>2L?6RD/J;0G70J8,M:?)=()C1)E2'G5"E4F1*K8-J6*D2/J83Q='F3'E3#>.5&/#(&,5#:&!?)!A*!>-"=-#9+/$.!*)/""3%&<+(G32O=(G39(!<,3$1!#3( 5)#=./O;3SA/P>(B3":+!5&$7(!6'6'&:+ 4$1""8)$;,!6'"3'#5)"7'";)(F0#E.,A/";)!7( 0"/!"6' 1 1!9'%?-5"6$8-7*4&<)<':#!9&6%4#$8)$9'%?)/D.&;)#;,)A2'=+ 3!/#*+"/!%4$1!"4&.!""('&,)('()*/ /!"0! +'(&)(-01#.#.# 2$0 3!%5&"1$ 3$!4#$3 *"!%!""-!. %,$))&,"!, '. )$###!#$"+$#%'!!7)-E5.H80I=;RF3K:$0$0$/F92M=6RB=[H@XG4J88L;5L91K74Q=:TC7RC0OB,K=$C1*F07S=(I4.SA.WE/[I+ZD0UD!G5#K8'Q;,R>$H5-W@5[F/P<-L8;_H;aG-O7#E.'J7C/.V?2ZA1UB&A0"4')++ ," 2&&A2*M8)Q>#N<-SC*SB%N92S=>]GCeNAQA(B/$?.#:,$=/*N>'I8+K:*I:-L;0Q@9\I6U<5S;0M82P=)K9/SC2UD/P@?/.WC1ZE4ZF/O;'H6+O>'G8)C5#9, !&M;'WA+U@6^J3_H1O?'I8)I93 #>+'G2!@/(K66]E3^E1ZD/XD0H5%@0>-"I8,TB/TB,]H7dP7aN1[F-\D([A9cU3\N1]G'V;O4/`M-VE)N>$F3.M9'E1 ?)/P=7_J4dK0bG2^H1YE(K=*H70R>-T>D1;--K:+G6(?/+>,,E1+F3&F1)I4+G3*B/%<%(?('=*'<)$;) 6&$7%&:(&=&%=&%?'#>&*<+,>,+?,'>'&@)'@*&7$&8&*=.+@1,B4,C6)A0&B/'C0)F7,F7*C4(B2(D1)E0(G0(H2&F1)C0'A/)C.%=+(?.'=.&C2*E5&A/'B/(B/%A-%<+ :)!8) 7("5%&8&"9'&>,%=* 8% 6$5##<'$<)!8)!6( 2$ 2"0 2"5%#=- =*#A,'?/)@1'@.)E1)I5%J4#F8&K<%N="I5!D1%D4+G3+H6(G5,K;,H8/K;.M=)M;+R'M=(K8,K7-N6,P;+O>2Q?3Q=0S;1W@3\F7_M/TA/U@,W?.ZG0`L-]I-YF1YG,VE'U?)XB+YC.YD(T>)S='U@)U?+VC/ZH.ZH.\K+XF+XE+XB-WB/WF-SB,PB,QA-UA-VA$J5%I5)M8)O:-S?+T@)TB)WC(PA-RB)M<+P@,RA+RA,YF/^K,_J.bL/dM1cL3hP1bL1aJ1_I1^H2`J1\K)P@$F7#F6&N>%Q?"P<'O>,VE.]L-`M2aJ.\J-XF5`N0]K,ZG,VD(VE,XG,UD(RA-VF0ZI1WG-WE,ZG'YF*XE.U@-RA'N<&P>(Q?.WE&L:I4!I9!G7#I:&P?)XB,XG+RA*TA*XE)[E&U?"M>$L,$=+,B3,C4#9+#7*6(#6(2#%:+'B1+K7'M4+O7-O:*H5(I8,M=+Q>/VA1WF+Q>.SB0TE,QA*H8,B3,C3-K9-R>4S>2Q@-L=0P@,N:)N5*R:+P9(F2(B2.I7,I6(K5&C2'@3(>2&@/$?+#?-#D1$H4*H6*G8,I:,G7,F6.G8+D20M:0N;/L?2Q@2O:5M72J7"B19%:)#=/$=0&?1&@1#E2+I6-G52J80J83N<-H4.H8&;..$))+2&7(7&"=+$>+@,!@,$?-#9("3%--4%&>.'<-'A1*H82N>!;+3$'9+ 2$3$;)$<-'@0.K;1O;0L7$<+7%"9'"8)!7(!7(%;,) +(5%)<+%9'%9+'@*%@*#?-$@/*F4,E3'?-"7(2#"5'!2%/$5&"=*6%1#5'0$-1"8%7&7':)1#.! 8*$=-'?.#=)">*(F2(D2!4& . 1#.!/ !4!$6##1$ /!$ '0"(/#0$(-1"/!--2 2$3" *++()**/! 3# 2%1$1%#4)"8*%:,#5$1 !4"1'$$!$&!2'#5% .'!*)$$'(*# #!  ,)=+1L81K:*:.%%,<)9M6,D3,I79[AR>;P=.F22Y>2XB6XD9[E-VF$L<(L= E5#F6(I:4^J1VD+O?,TB;bO;bL.M7,K6.I6%>+0Q<)U<)Q9/L7$:(..!/$4&'E4'M:!E5'L8'O:(Q;2WC.M:0#A.0P=8R=:TA2J8.@/';+&A0#@-,G4-J7+L83VA>`G6YD3S?1V@:dL)Q>)P@*O=/TC5O?)M90XC(K7#@/9*;*-R9/X<"M4-ZC1\E(L9!<)/!>+.N<-L<*L;'L%H7-UC:nY0jR&U=C0(O=A-/VABdP-$F8*L9(D6%?.'=,'=)'@,$A,&B.+D0-B/*A+'>('=**B.&>,8(#5$&:''=)'>(#>&$=&&9'':)(<)&=*'=))A*)<)(;+)=,(?0)B3)C5,C1*C1(D0(E4)F6+G7(D4)E4*F3(F2,I5*F4'C0%@.&A-(A/'@/%=/%?0*C4*B4(>-(>-(<,%=+%=-:*!9*"9)#8&$9'$9'$8'#7&!5$3"8%"9) 4& 4' 5&2$0!.!0!#;,$?,$@*'>.'>.'A/&C0%D2 D2%D6$G6'K:'K6'E5,G7-H8.K<,L;+K:+K:0K:+J:(J7)O:+R;+R=)O;*L:"G5!G7 D5'G6.I8+M8.S>,R>/Q>4S?2U@1XB4^I7_K0VC/UA+V>-[D.`I,\F-YC2YD-WA*XB/[F-XD/YD*R=+S?*YC1^H.ZH0]K1_L0`M.[I-ZF,YC,WB0XE2ZH0UF,SB/YD1WB&J6!E/'L:*O<'P>&N='P?(SA(TB-VD*R@,TB*SA+VC,XF,ZH.aM-`L0cM6gR3gR1cN1`L1^J.\G1_K2^L)P@#I8$I8#K:%R@%O9)P?/XH+YH+]J/^G,XF-TC1[I/\J+YG+TC+XG-XG,RB'N>+P@0VE(P@-VE*XE+]I(XB,S=)P>'O>'R@(SA+UC'P?#K6%J9$F7#F6%L;)WA*XG+VD+XE,[H*\G"Q;G6%K9B/!?-"<+%=*$>,(@.+B3.B3';-$7)5'"6'0 +A1+G4+I6+M4/P8/O9)G5*K;.Q@+S=.U@-S@'M<,P?)M=,M=,J9'D3+H8/O;/T@6U@0N<+I:.L=/N<0T=,P;-K9!<-%?/0K:-K7'I4'E4)C5(B4)C2&A.'D1%H4(M9)H5+I9+K:1L<,F6-G8*E2+H5-M:)F8-N=.M9-G2.E46(-1!1#3'%;-$9+!A.-K82O<0L9.M:.M:)H6(@23&(+.7(4&2#!7(7&:(!@-#A.'A.(>0':+#5&$7(":+&@0'@0$>.%D3(F58(9)#;+7(#;,%A-%=,&?/(E3+H5(C1 3&0"#7*6'6&$<+ :,'(&6%)=++@.)A1)C.+F/!9(5&&>-)@/)A/$9*$6($6(#3&2$ 9) =*5$!4'3'.#++ 5$2""8):&2#2$ 9+$?/%<*"6%":)&@/$<-.#.!#4& 1%!5%$9&&8$!1$($& 0%1%- - / .7'2$- *-4"0.)+(&(((-/ &- 2%5' 9)$:+1",+,%##"%."!1"+) '% %%$ "# "!"#1#$:+!5'(")"&0&,:*(<(2#$=.5P;2I7;P>

4K77Q=?[F>ZC2VA4TB8YC,TC-TD(O>0UE7\K5ZI4ZF,L<.P?'M;$N7/U?0N@/N?+G7,D1)I0$O1*O9%@. 4&0"(?3#8-":+#C2"I6B1/S>$J6%T>-VA,Q=%I5$G4-S>3Q=7UB4Q>/C2*@2&A0%E1/I8*G60Q@7\I=]J6\G$H3+Q;6`I7`J7YE7aI2[E)S?'P<*S>2XB;WC5YB9eL/XA+P9+P>1M@/Q<1Y>*S;)Q<%M7'J5%?-+E42Q?.RA,P?0Q@,O?)N="G7(K9)M8#G9#D6"G5&Q>'U>/[D F2:'B0&H8&I;D5I6U?(_G#P:%J7'K:#@.%C0'B/ 5%1 $>/-F4">++N6(N5@+,M:(L8$G3#C/:%'D3'@1&D1%B/%=+$8&&9&(=*'?+'@,(=*(;((='%;%'=)'A-#=+!;+(;*,?-+@.*A*'?(%?'$9 &&9(';)';()<+(>,%<*&@0'A1&A1,B0+C1+G4)G4(F4'G5(D6%C3&B0)D3*D4)C4'C0'B0'B.(B0'A0%=/&@2'?2%<.*>1*=/%7*$:(#<,$>. ;+8' 9'&8''9(&8'&8'$8& 6#!8(&;-$7+3'!7)5% 1#- 2$$8)%=)#>'$=)&>+%>,%A/#B2@.!=/#A1%B2'D4'B2,E7+G7+I9.N=+K9,J7+G3*F7+I9*M9'M8(M9&J7+L7&I7"F6%I9+J;,H8,M9.T@*R<+O;2T@1WB1YD4`K1\G2XD1WC.XB-]F2eL/aI1[D.S>.XA0\E1\D4^G2YC)P9-R;,[E3aK-\F/]G0^J,]I.[H0]I,[E,WB0YG4^L/YI)TA1ZE0WA&L8&I5)P>)P>&M=$K;&M=+TD+YF0^I,VA,WB+YC-[G2^N+[I,\J-^K0aN2bO0cO3cO2`M0]J-ZH/]J6bO,XE&P>(Q?#M;$N<'N;*N=/UD-ZH-^K*XD&O>'K;.TD-ZI(VE*VD-WE,SA-R@)M=(M=,P@'K=.TE*WD/bM(YB&O9'N:'Q<(V@$S>(XB(VA'S@(P=$G6"G6&Q>/]I(WF&S@'TA)YE)ZE$P:#G7&H8 <,:)"8(#:(%>,*C1-D3-B1,?/+=.%:+&;,(=.0H6.J7-K7/L61M7.L8*J7)K:+P?(P:*S>(P;(L8)M;&H8*I8)J9'J:-R=0VA/R?7S?/J9$A1.K;/N2L<+E5-G7,F4)F3%E2&?1(I8$G3'B/$8).!'*(,#5'!6'!?,'D2*J7(K7'K8&L7#C3"<-0#-2!7$9)5&!3%"5'5%9)"A.$A-'A0'@1)@0*?2'@0'C3#@0(C2%@0#B2"D3 >-$@0"?/ >-"@/%A-'A-*C2*F7,G7&@/0%"2(#7+0!4#!=* <.1!1 (<+-E31G5,G5+F0+F.%:)0#$6(";)$=+#9($7&$6')9+ 3#!;)<,8(!5( 5)!2%.!!3#%9(5$$;-7'1"/ 5&%;, 2$ 0"#5&$8)#7(#3$,6)#8)!5)#;+)?,%;& 1$+*+1$1$.!,-2 4%/!&(,0"/ - *)'&'&%*), 4&5&4$4%-)()(!!')'%% $!  #$""* *( #' )4)+, 1$*<08K=:L>3F82D3,C1:UA9VB:S<=YF2W=3VB5UD6U@0WC5\H+R>0YE6]J2ZE5VB6TC0P?'L;/V@7ZC1SB/P>">/)B.,H2&K1@.8(4&#>0+E97+!=,@/E3)N:-P;E1+WB&Q<#I5!D0(L8-R>/R>/S?1S@6P>/H70L9.O:2M<(E60QB8]M6XG.WA F16]F7aK7_I2S?2aH1_F-\F+VA,V@5\F7_H5bK1`I-WC.RA.RB0MA"C1)O8*O;$H6%J4$L61R=5P>1P=)M<'I8-O>'J:%I8+O>*O-6%/(A04"'@+&;*):*%5'(:(':'(=**=*%9&%8%%8#%9#&;('=+#;)#;+$9'&;),B/)?-%<&%=%#9$#9&"7(&9*%9'#7$#9'#9'&=+&A.'C0&B2*A/*A/)C0*E2'E2%F3'D4&B2%?1'A4)B4'A2)B0(B0%@,&@.&@/$=/%@1!>/#=/$>/";-#:,$:)%<+";+ :+9(9''9*&7'(8&':)'>*#>*$>/!:,$8,!5(!6( 8( 3$,. #4%!:#"8&#<)#=+$@.%A2!=-#=/$<.'>/(?0+A3+D6)E5'E5(H7,I5*G4,E3.F6.H8,K;-N=&I5%H4+J5(I7$H8)L<*J;.J:-P?-VA,WB-U@0WC/WE7_M1_I1]H2XC3XD1YG0`H._H0_G4]F3YC/ZC-WC3[G2[F5\G/T@,R=-ZD1^H0[F/[E,ZD-\F/\H.\E*XA-\E,YC0ZH+YF&S>+U?.XA.U?(P;.VD,TB'O>%L<'N>,UE0]K5aP2`K,ZD.]G4cK/_N+ZH,YH0]K.\I1aM-_K2bN1_L/\I-[H/`L2`M.\I*XE+XF%P>'Q?*P>+P=.VA.\F0aL-[H#H9 B3(M=1]K%S@+WE,WB*P>+P?.O>)K<+P@'J;+O?)RA0`L+XC'N8'L8*Q=)V@%S>%T?%T>&UB"N9&N8&M8)VB"UA#P?"L:"K9$R?*XC-VB(L=)G94($:-&9,%:-'A/,F40I7/G5/E3/C1)A2)@1-F41L9.K8*K6,H1-I4)J5*M9,P=)M<&N9%M8(O:(O;(N:&L7*I8-N=*S>+T?/U@.R<3R@+J6&C2.K;0K:3O<.I8-E6$;-,E51O;)L7%E0#D/-N:.O<0R=-N9)I7*N:'L7(G5,J:+P?0K;1L<1K;+E3'C0$B."9,$A2"@0 8)/#(#&%'#8("7(!;)9&$C0'I5'K7#I5"@1":+4% 4#5#:(9)7'#6(#5'"9*$A1&B.$?/7''B2)A4(@2+G7(I8%F5)C3&A0!?.#E4"D3!>. >.!A0@.'C0-G4/H81M?*F6&@0#7+$8+$6(2" :(%A,=-!9*':)(B0-G5/H6,H4(F.'B*#8("2&%6(9&#<*$<*"9'(>,,B/"8& ;(<+6(0$,!0# 4%#6&(=+ 9':) 3%/!. 1"%7(#.!- 0"&9*&9*&7).<.#8)"7*&=-'A-(=)1#,+.!.!1%* *.0"-&(', 1#/!/#+ .*)')*'(($4(4'3$3#4')$&((!"#&&%# &!!!"!%)!(!* *+)!0"5C7.;3)9,)9,-?1.C18R?9WC;XB6XC7ZE8YF=aK4YE2S;1V<7]E$D0&A2-H9%G6$C37( 9*%B3"A1!;.&A1#E3(O:+O<,N:(N8+Q=.R=/N;&D2/N:,I6*J8+R>2WC/'@2&A1'?,'>-(?+&=,$=-":,!<+"=,"<+"<-#=."=-$9'#:) 8)!;,":*!9'$6($3&%6%';*&?,#B,"@/#>.#7*"4& 5% 7$ 3!-+"0""3"!4"!6&$=,#>+$@-%@/%?.#<-'=.+@.+?1$:,%>1&@2%@1%B2,G4-E3-D00A3.C5.E8+F7&D2'D1)H7(K9'L<&K;*L;.M;.RA1]I.]G0YD0YE-WE2[J.\H+XC-U@1VC2YH0^G-\E/[F4[F5]G-\E0ZG1ZG0XD0WD/UA)O;1ZE3[G/WB,U?,XB/\E0^J/]G-[D/]F-[E.\G-YE+U@+U>,V?+V@(SA.TA0VC*Q?&N<(R@,XF/\L.[J-YF,YE/^G2bK/`M0_L2_L.[H+YD/]I-]J-\I0\K1^L,ZH.^K1_K-^J)\G+\G)UA*R?.YF.UA,VA,\F2dN1_K$J:?/)N<,WC%T=*T?+V@+T=/TA+O>,O?(L<'G6(H8&M;)WD(R@'L:*L8&K7'Q<$R=%T>)XB#R>#N7'N8*O;0[FP< G6?.!D3$M:'P<-T?,N>(D6 8*(<.(=.&<,&A/-G52M;7R?1L90J60I8.J7.K8.M:,O8&K5*G3*K6*O9*O<*P;)O:)O:(N:-S>+R<,T>*R;'M:0VA1VA.S>-R<0T>0R>-L9*J6/M<.K;0L/O>.K:0J;#=+7%8%"7*%<.2$''&$%&/%;,$>/1"1"">.$B2$D4"A0!<-8'8%4"12$3$!9+3$ 8($?-$A0"=-$>.7'&@2&A2%@3*I8'J9%D3*D5%>.8(@/!A0:*!=-$@0#@0*F4*B3,D6'C4:*%?.$;,';,$7(!5$$<+"?*:+#9+&=++D2*G4.I6+J5%D,#@(%<+#6*!3%6# 9(#>,(C00M9/K6$9(#>.8)5'0". 1$!6%':)%9%8%;(!2%. 1 4#"5'$1%"3$(:*)=,(<*';))<)1""8+)?/&=)%9%0#- 0!"4%4&,"' +!2$5&-*//#2$3#1!0".",. ,-!3%/!*. 4& 8)1",.!. %!%''"" #*'$&# #$!" #   !#* /""1" )')(3"6C2!," ) ))6)2E7 9'=YE4S?(L77]H3UB:]H6^I7]G5\B4\D7^K8[K4XC3WA6[D5[D4ZD1WA3YC?dN2R?)O9-T?0V?"?(.S89`H D1&C5(G8(J='I8#@1(D3&F4$D2,G5,D3'H3*R<,Q=-R;0WA1T@6WC1O<)F2+F3(B0+F61PA4UBm[>kZ2WG+J90P=.L?&I83YD1WF+Q<1X>4dJ6^G%H4!D3"F6#F5+RB/VE(O:)O:F3C1+TF/QC'F5/Q@1WA&K5"G4/SA&L9+S?1^I3cN/&@1(A/.B0.B/,;-(9+*=1*B4$>-)D0'F7&I:&L<&L<%K7*M9-QA0\H0`I1]H4^K(TC,VE)WB)VA)Q<-R?1XH2[H2]J1YG2XF1ZG/]I1^M/ZI(RA*QA+P@(M=.UB1XC,Q=*Q:,U>,XA/_G/]G0^G0^F,[E-[F.ZE.XB*S<+V>)W@%S@,Q;0UB/VB1ZF+WE+XE&SC(RC-UE.WE/]G.]H,_K1`M2_J+YC(WA1`I0_M.ZJ,YG,XG)XG(YG-\F*]G%ZD'[C'V@.WB,YF-XA,XA-^F-`I1^K,RA%H6*O:)U>(U=+T<*V?.V@/T@-Q@-RA+N>%B0,I6,O='R@+RC+K<,L:+N;'P;'T>%T=(W@$N<)N9.N8,M7/W@!M:#C3!>/$B2"F6!F4'J7'K6&D0#=),C--F0&B+*C22M:6R>4R=5U?-M8.J70N:0O<(K4+Q;+P:,M8,P:/U?-U?.V@,R<-O>0T@.S?+R<,W@+W@-XC.VA.O<0P;.P:2V@0S?,O;,L:-N;1O?1N>1S99X@3O;/L8/P;*O9/P7/R:0W>+S:.V=*R9,J8%F3#B/&A/)D4$G6#G5'F6*E51 1 5#2$"5(* "&+!)') 3#'@/<-0!/ :*!<-&A1$?/%<+"=*:&2)*/$7*5&;)>*$B-";,&?/";.'A4&C4'D5+L:&J9=,(C3'=.9)>-;+7' :*&>.&?/'A3 8*7)4&7&%@-$@,":&4 &:'$;'8'6'(;-,B1*D2(F31M9+J6#A) =&!:)$9-$8*8)#>+(D1-L7+M7*K53# ;,;-#:,"4&1/"%5%+:('7$$9'!9(1$ 0"3"9'8( 4&(:)*?-&;(!:&!:$":%$6'&9,+A1'=*"6""1$3%'8*(;, 3$,#% +#6* 5&!/ /7$5'2$ 7&5#1#2$1!0!0"3$ 4%.-"3&9+8*4% ,.!*$$%(!%# %*%%'("   ! ## ! %  ! &0$$8) 5#$!'"-'5!(# *$(@.;WC3!8XG5WD6TB7VF3VD8_H5^D1\B2ZH1WF3YE7YE7XD8XE3TA7WC0S>1XA1VA,R>(R<0S<&B+.S=-T@*O?*L:%G5#J5C2)H62O<1S>0P:,G1#;)1P=0WA,Q<,S=)Q:.S?/S?0S?7VC;( ;)8L=5Q@3SA5R?-I5'H2*I72P=3TA/VB/[C)S9/U@/T?.V@.YB,XB&K7,P;+L:)I7/O@2UD(N;(G4%K7*S>#J4.X=0^A;[M=aN,VA(Q>%R?(QB+QA)O>'T@ M6F/F75]M*PA'PA*VG$QA(O=/M<>0;,%UB/[I;eZ4\P*L>+B5*,7+,MA2XK/YH5bO5aL6bM>`O 5'/"!5' 9'&8'(8(&7+$7)!2'!2'/$."- /!$2!%2"%5%!0# /#!1%%0$'4)$5(!2%+!+"1!$5##4'!1##2&$6(':('>+&;(%<)'=-$>%(>+#9(%:+%?*&C+"B*%C,%@,'A.&A.&A1%@.&?,(>,%;)$<)!9'#9'$;)!9'":(%=+ 9)#7+$8,$8+"7+"8)#3(0# 4%7'">,"C.$>0#;."8)$7)$8)!6'$3'!0"!/!/"2 %3%3$"8'#8&"9'%<*"<-":,!9,":,4&3% 6(!;,$?-'D0'@.)?./B13>/.8+0;.->/&>-$C/'B4)H9%H8%H8%E6+J9+T?.ZF.[I.[J1YF2YB-QC)N?)N@"H7&O9/Y@0ZE4]I4\G6]G5]G3]F/]K)UD(P?(M=*M>(J;*P?1TD/P?-L;.S@2[F0YH2\I2_I0^H-]F*YA.ZH.XE1WD.TA+RA(Q?-VA1ZE/ZE1]G2]H)T?)Q?,RA+P>.SD.WF-XG.[J.]K,[H(TA,ZG/bN+_M)YE+S?)Q=%P>'UD,WG+UD)RA)Q?(Q?*UC'UB(WD)WE*TB0]J,_K,[J%T?,WB-VA,U@)Q@,WE,WE.WE,RB,N?(F9(C1,J7,P<+O>.RA,P>*L=(N<'S>(W?'WA(VD(RC&K:*N8*N80R@)M=*B4$>/#B/ B.!@0$B4(@1$>.(B1+E4+F0,E-1C//I8.M=/O?6S@.O8-J:2M:1M9,L7*O;+S@-SB.WD/WF0TD.RA*SA'P?,UA-U?,T<0X?1W?3ZD-V@,S>,M:,L8/U?1VB.PB,K<5S@4R?1N?1PA5UD-L<)N:)O9.U?-WA,V@,U>(O9*R8+P8,H5'D2#C2"?/'B3%>0&@-"<+"6(()/"4(2&*')."0!+*"4(%=1">1%8) 6'#;+&@0(A1$<-$@,&B/$>-&:,+'/ 5'4% 9(!<*#=+ A0!@/$B2+F5*F6,I9/K=(B56(#;.'A3&A2$=,7%7'7'9)<, 6(,.!.!%:-+A4#8(!3"0#7%!6(#3'"5(&*#>,>. ?1'A1*>+(9)&=-;*#@/8("6'#3%$4&,>/'<-)?1!:+ /#.!2%4% 4% 3$7)"9*4%"4%$5$'7&"7%*=,1D3':)&8'$6%$4#*<*'9'!2$+, 4$':,$8+!4&3#7% ;)6$#7%!2"3!4" 2 0"5#5%5' 2& 1#1#15#3!0/ 1"'$ %&  #" &&$%(%"#%  ""!#"##$&''+/ !6&-%##&"'! %$8+>TC"4!+/E73Q>.Q=3UB8WF9\C)M7/WB4ZI0VC1UA4^C4ZA+K54S@5YF4ZJ:aR8`L*T<)P8&L6)K9+M(Q:+Q<.Q?4R@/O<6WB4T@1 "9+.M<8WG5RC+H:$B2&E21SC8XG2RA6XD,R9)R73aD:bI,U=/ZF3ZE*I7-M<0J;0O>-UB1YD5TA.N<+K;)L9(O9;dK3aG7VH8ZJ=cQ,S=1XB/S<,F56&:*%@2%H9*UE3]J.ZD,[D-[E/[J*O:!J80ZH.SB9)*;+)N=7aN3cK.^G,W@3ZD,\D5]G;' 4" 6#"8%'9)'8'%6)#7*!2' 1%.".!!.!$2%!2 !1#"1$"1#&4'!/##/!&4'"3%"2%+( / !2"$6&%6&&7(%4$%5'#5$(;)(;))=+';+$<(#9'%8*#8*(@.'B.%D-&A.&>+&<,%<,(?0&C1&A/$?-$;*#<+$>-%=+'@-%=+'?,$<,!9($9*#7*"6*#6)%7+!6'!3&!3&!6'!8)#?,$C/%@1#=.$:+&;,$9*!8' 3% 2"/!2!!3$2$3$ 5$!3" 7$#:) :) 4'5'4'2%1# 7( <*"=,#?-&@/&=,-A1/>0/=0-:.,,TB,S@0VF-VE,XG-ZJ*ZH)VE'P>0\G3cL7eS3\J.R>,N;%K9%M<(R@(P?*P=%K8%O:)T?'SA(XE(WD(S@,YE.bM0_M+[G._H-[E,YE.XG/`L-]I.]J+VE$I9$G7&F3*M9*P;*P>,R@+Q?-N?,R?)U?(X@(ZC+[G*UE(P=-U>'L7.SA)M>-I:&D4!@-=*8* :,)>.)A2)C4-G4-G2/F01E0-G5(F7,G82M;0N7-N=2O>-K8-K9,O=,RA,R@/[H+XE/VD-TB*VC,PA0UB.T?+S=/VA/VA1XA,T?*P<)I6)J6.S=/WB.RC&H8+K8.O;,K<3PA7TE0P?,N:*N:+Q;+Q=,Q>,O;&I4'H4)J5,H5*H5'E2&C2&A0";+#;'5$/!(, 1$5'3$/!0#7%#:(!6&0!/ "5)%>0">0)=.(>/*D4*D5(B2%?/(C1(B3(B2%:,-+4%"8*$<-&A1$?/%A2$E4!@/'C3-G8-I9.K;2J;%=/1$#:,(A3(B4 <*:(:*5&3$2#(%-!*&8+#:,#5'+/6$7(#8* 6)#<.%B3(G7*K9'F6 =)6#4!7%!<)%A.,B-&@. 9+ :-#;,#9(%:)&>,$=+!:'!9&%<,(:+(;,,@0)>/+E4&@.$2%,1$2#. !2%!7'4%0! 4%!3%%5 '-@/1D2"5$%8'%7',=*+>-#7%1" 3&!3&!7($:-#7+0$1$ 4$#:(!7%#7% 3!"5$"6%2"3!#6&!9*5% 2%-"*. 0"*,0"1$*%"&&&"$&!!&%$&$!!%! "%&#&'),1#0#'  & $"'5+(6* %2%$C1-R?=^L;UF.F26%1RA0VE/TC-R?7[F-P<(E3)J82VC3YF7\I0SA%I6&L9*O;/T>-M8"B.=**J9)K:+M<)L6)K74XG3ZH1XC*J5.Q<8\I.Q?*M<6ZF3VA5XG2VB/Q>/L9$<.1$/H92M?'B4&D4!@-5XC4WD2TB+J9,K7/Q<3X@:eK:aKE2,UA1XD+K8.O;3R@6YE5_H3\G9XE.L<+J7+K81R>7YD0R=-O?7[H8_L5\F-P=+K63N>#A04% 8) >-"H6,TA-XC-YD1^I0[K2\K6*fU:aP(I7$=-5%*5#'E4*I9)O==gV7dP/bJ.`H-^F)V?)XA)Q:$C/ 9& 8'!;*&;,&9)!4& 5&"4' 2$/ -&1#%0#. -!0"$3%%3%$2$%1##2$!2$!1#-) /"2"#5$!3"):(%6#&3$'8'*9():*(9+%;)"6("4'!4'$9+#:(%?-%>-';,'9,%8*):/$>0'A2'@2&?/#=-!=+$>+'A-&>,%<-&=/'>0"8)"6( 4'!2%"4'$6'3&0"2"#9+(A0%A.(C3(C3%?/'=.":(6$5$!5$ 3!#4&!5&5'4%3# 3""9&$<+!;*!3'!4' 2( 5( 9*9' <*$?/"<,!7)*<--@1,=0,<1-?2*B3&B0&B-%G1&J6)N;(J:(J:+P='P:(Q?(P>(N<.SA+P@(M>%I9*L;,M;0Q>2XD2WC1X?0W>-S<,O:(P>)Q?)R@*Q?'N<+O>*N:3VB4WC4YC0V@0V@.TC0WE.UC/ZD/\F0^H0^I/ZH,VD0YH0ZH0\J1bL1dN2fR4eT,ZI%P@'P>-WE+UC.WG.YH.ZI.\L,[K)UD+Q?,T?2_G>jY1[H.T?,Q>(L;%J:$M:(Q=*R=)O:&Q:*T>%O?)XG)WDM9/]F1dL/^K/aM2fR2dP/_L2aM.aN(\H.`L)UC)P>'J9#J5,R=,S>.VD.UB-SA,R=/WC*XA(ZB-^G-^H.ZH)UA0YE/VB.UD(N?)K<'I7"@0 :(!9'(=,+A/+C3+D5.H8-F3,D.0D0*E1(E4(B2,E20M9,O?.N?-L9+I7-L<*K<%L:6cP-[H,VD/WE+WD/QA2UB.S?.S?.TB+QA-S=)Q;)M9)G5(H4-R<*Q='H9#?0)C1+H5-H:3M?1M>0M=-L;*K7*K7'F7,J;+I8(D4+F5*E3-I41N:*J5)E2'?-":(#7%1!- *,!5&"9, 5(!4%+@.,D/%@*"9)#8*$9*'=/'A1#?/+@/.F4.J8,H6'D4)E5,F7&?/)D3*A25#3!!7%!:)'C2-J:*F7&B3!A0!>.(C3*E5-I9,I9,E7!8*!8*";-(C5$?1!>.;+6%1"+)%'- 0#(?1%>/ 3'.!2!8'!>+%>-!7*!:+;+"A0$A1 <,3$0 0!4":'%B/0I5(?."6)"6)"9*!9(%?,%<*"6$!5# 5"&?++@-+C/(B/+F2&A-!<( .",/"/!/!$5'#6%/!5%!4%2"$7(%;)+A/%;)#6%)<++>-0B1)=,$<)9)!:*&>/"=-7*3'!2',!!0#$8(#6'$4&"5&%8("4%!6'#5&"6'5&5&.)'**''.!/",+**. )!%)'"$%&&'# "#$"!#$%""$(."/$/"&!%$( &:,6WH9TE/A6'0$*3M@0PA1RC/PA9UG'B5'B4(H7-P>0VB+N6?`N ?/6%2VB5]D6S?$A-+G41P=#D3.P?*L8.R>1]H0]H3YD)C0$A,6TC.J>#A52R?0R98`M5[H2T@*E5(?0 0%%9-$9.(@5$A13UB0U>;\I+J9%B2,J99XE(K5,S?6YH)M;)R@4]G/Q<0R<:^E9bI0ZC.VA5UC,P?0T?)M9+N:#B0-K:/UA5]G5_I:`L/N=+E6+F6)F7#>,$9(!9&!@,0TC,TD#K; 8-.!) 3!(C1%N8$M6!H2'N81\EL4?t\2_I*R=;_O9*'"3%!:(-L9:ZG1UC+SA)O?0WD*XA,[D/#@1&=.#8)"8'"8%!7(!6% 4! /+!+,-!0"%4$'5(!1#$4'!2$. ,, 0 2 3 !5!%6$%5#&2$#0"$0""1$%3&%4&$8)!4%"3& 1$&7)%:,$;)$<+&;,%7**<0)9.&>0%>0(B5(C2%@0%>.=) ;(%=,"7)"9+%>1&A1$=.$:*!6'!4%!3$ 4' 3$2$ 4%#9*&?-'C3*E5*E6'B/";*!9'7&!6&$6'#8)!9*3$!3#1 !8%&?. <,#7("6'"6&"8( 9*!;)"<+:+!;+"8+!5("7(%9,(=0)A2+F4)E1&E/ A+$H2'L9(L;)M<*O:'L8'M7&K9&K:+N?+QA&L;&K:.P?2SB2RA.P?/T@-T=(O5+M7(I5#H7+R@,VD'Q?'N<(N=.M:0R?2UA4ZD1WA+O9,O>-Q@/TC/WE1[G.[E0^H.\G,YF+XE2\J8bQ3aL6eR1dP2aO.ZI.WF,YF*WD)XD*VE,XG.[J5dT-`N1]L.UB/TA,XD2`N/]J+WB,VA(O=&K;&N<.WC.WB*T>,V?+T=*UE*ZI(YE(VC2_H,]E/\I0aN5jX4iW.aN4aO2cO/_L,ZG.XF.SA)L;)Q<'P;%O:/VE+SA-UD+U@-ZE)WB*[E,]G+[E,YF$P>(WA0[G/XF+SB)P=+N=%C3#=-)@./C0+D2/I7.H81K:1K7-F2+C0-I5)H4(B0*D11N9/RC,O=,L9,J8*G7'C4(P>.\I*\G+XE-VD+VD0RB3VC0T@/UA/TC+QA+O:$I4'J6(E2(G3*P90N<*C5%9,$9(,B0*C5/I;-G8-I9*G7)E6'D4,E70J<,F5'B2*D40K91O:1Q<0O;)E2$=+7%%8)1#0#!/#1"$<+'?5"8-"9+,C4,D3$?+%=,%=*+D1.I6)D1 >*,C/-G3-K8*I7)I9*J:2N>*D4'A1+C0&>,7%$;*&A/)F6+K:'E6(E6:*!=-)D4,G7-I9*G7!=/#=/9+:,;,:+:*7(4&)&&(0#&>0$?."?/=-!7* 2$5#!;($@-8'!2##7(!;+ ;+":+2$!, -/ .!:(&A/+C0"9'$8( 4%7(!<,!;,5&!2"-%9&(@,0F3&@-'C.(D0$>*!:&"0%#1$#1%"2#"3%&9*&9( 4#%8'"5'':+,C0-C1$;(':)-@/1D30C1&=+%=. ;+$?/$>.$>- 7)!5)0(*$0%!0"!2$#6'&9*';,(>.)>0+=.%:+ 7(3$,(%)'$(+*0# 1$+.!0 - $$#$#+-('$%%'%$%0#("%%# !###( * 1&"3)%! "5**A4/@6(#$&&;/0M>2OA0L<->50$"3_I4YE1J81O:8SB0K@)E74UA3V<.XF3XE-N:(D1%=.%9,+>4*>6%>1,G96TB*J5/L:#?.9) <,2Q?'I3(L:;[J<^N7]J5^H:\D9XD4ZC5bH2[A&I4;)'P>-XB+W@,WA2YE.QA8^I9dM4bH/T?.K9,7&#>. ;)"8&$9'$>* @/,O;6\G1YE&M2$8,!2%-4#%G2#U=,ZDD.,Q;+M8(J5Lr[0Q;@+@0"@1)A5 <+A.2YC2WA5VD-Q@*H9/N<)L7:$+U>3aJ+UA'N;)N=%G6'H9'H9#>-!:*%=*'=+#=+%?+$:$$6!!-))+!/ $3%$4$"3$#5&%5&!0!-+!3"4 32#4"#4"$0!!- *!/# /"%5$"6'#6' 2$.!1##5&&9'(<+$:+&<.';.&7+%:-$:-%?/$@-#>*%?,!@.9'!7(%:+&;-'A2*G9+H7)E2#<*$8)#5(2"2# 2#1" 4%$:+#?/'D4$D0&B/#=* 9&8)!6(!1$#4%#:'">*&9) 3# 3"$;)$=,"<,";+"8)#7'#6'!6'9*8& :)9) 9+8*!5(5% 9(%?0'D2.K9*J5*H4#D0%G3(M9.TA)O>+L9*L8&K6'K7%H8#F8'M<'N;(N;+P?1UE+N@*K=)N<(Q;'P8(L9)H8'M:)S?*VB+TB"J6(L:0M=(H6+O=0VB/S?)I5%C4+K;+O>/UC0ZG.XD.]F+ZC*YE-[H/\K9bR4^M6eQ.dO-`K2`K3^J-[H*ZG)ZF/\K-YH2^M2bO/bO0`M0XF,SB'R@(ZH+\H'XC*XB&O=#I9%M<.XF-[F.[G-XD0[F-[H*]J)\H$P=*S@,VB-VE-]K1gU3kY,`N1_M/]J/^J-[H/\E*U?,R>*R=,R>-S?/TB.XE-YG.^G1bN(YF*[H,ZH+XE%P@#O>)UC/\I1]F/V@(Q>*O=*I9+E50K74O93M:2N;2N=1M=/L8,H3)F2*K6-M8-H41L84S>.R?-P=-O9+L6&E3#A/*O>.[G&WC*WD.WE-XE1WG2XE2WB3ZE1WB+Q>'I3$G2&F3)E2)H4*O8/K8%=/%7*(<+*D2%A3-K;-L<-K;)F7$A2(E6*E6)E5*F6-I8)F3.K81S?0R>/Q=)H5(D2&?/*0)D5*D4#;*#=+'B0/J82N;,G4$B.*E/1L73R>/Q>*M=)K:+H:*E6)C4,C1(@."<)%@0)G6+K:,M<)F6)C3&A1"=-)C3,G72M>,M;#A3"<.7)7)6'6'3#0!,*)(,!"7)!:+:) ?-:&7)"8)&<* 9' 6&,. 2$9)!:+ 6(,'+0!5%%?,&B/"8'5#":)!9*#=-$=.3&- 1# 2");+';)'<,&?.!<+#>-#:) 3#!2%0# 0#%6(!4%&:*&>+!8&&9(&9+%7(*:-2I8/E3&<**@..D21C2'>-$:,$>.#>.!;,#<+$:( 4&"3'"2'0$"2%"0"$4&%9*$:,%;,)?0'?/.A3*?0$;,!3')))+(%()%,+**/-+()*$*,'$!%"(&!!+"1$('$!!'#"&!")-!5' 5)#   #!-!:TF0H9,B3%-$ -!'>/.J:.K7,I4/L7/J7'A-1K:7VD+M;8XF,J7,H5)E0/P:5ZD2P?-I7=^H3XB%H36PA<_J:[H6UA,L73V=+P60WA2WB,M6"?,'E1(D4)A3%;0%=1-D8,F7+C27'3%7)'B1'F2&I32T@2P>3SB3YD5^H3U>1L<+Q=-YA+Q8$A/%?0 I6$Q:)Z@-^C/^F1\G3\G1]E)W<,R98% )!7)#>. 6'6'<,;+?,.R?+P<.RB!F6&C2$<-.!*6&!I63bN.\H)R>(K8(F42K:(F3$@-%G4-TC)P?!E5:(%N82\C0T<9VC=XH8PB#<*6""B.+S'B2$=-%>*'>+$B/$@)'@&&;$"1 !+ (!+ -#2$&9(#9'%7&!3"!2 0. 0"6$7 3 20."/+, +,04%"4%"2"0 1"!3$%8&&<)#<*(>/#:,!5' 4& 5&9( :&#=(&?*!@0"=/$:+&<-(>0+D4)J;-M;+H4+E2(>.$9+"6&1" 2#"3%!3$"5&!=-&C2#C0#A.$@, 9&7)!4)#2%%6''<)#>'&:*"5%$7%"8&";* ;+;+!:+"6'!5'5&5& 8&9( ;*$=/&>1#8+!7%%>+.K7,J7/R<)N61P>-M<0RA1VD2YF)Q=(I6'H4'H2)L8&I9"F7&L;)P=)P;1XE-SC(M@(I=$J9$N:(R;)M;.M?)P=+U@(T?#N9%L7*K7-H:'F6'L:*P=.O>%D1#@1+I:'I9)N<-UC)SA)X@+[E)YF(WD+XG3]N3`O.`M+eM'aI+bH/bI,]H'YE([F+\J.\K1^L5eP/bM1`M1[J.WG%RB'TB(WD(XB)UA"I7%G8"K:,YH/\K,ZF,ZG4_M1bO,bM'[G%Q>+R@(O=.UC-ZJ2hW0fV)ZI+YF#S@)[G*\H*\F&U@(U>,R=-P<.S?.UC+VC-ZG,bJ+_L'YH+YI)UD'N> J;I;"M=+WD-WA'M7(N;,O>/P?0M<2R=5W>7VA2Q=2Q@1Q?.M:-K7-M8*N8,O73O:6Q=2S=+M9+P9,P8*M4&F/)G4(M:%P> P=-XF/VE,UC-VE1ZF-V@2ZB2YA)O8'G2!D/&G4.I6-L8+O8.K9&>0-B41I8%F3B2.O=-L<(G8)G9&F6+J:)G6,I:.M;1P<'F3-M90T@-R?0QA-M<-G8(C4);/ 7+(>24J<1H7-K7-L8&F2)H3+G4.H4'?,&@.)E30L83Q<3Q<+H2,F02O;7XC,O;(L9$H7%F7*H90J:+C1*C0'A.%C3+K;%G6&H7*F4+D3,G7*C3(B2/I90L<&D3%>0#8+.!.!/".!/ -+)**-"!4'4%8(#=*7$9)#<)"8&1+$)/ ;+;-7)-!,!0$5'7&!?, ?+"5$!8&;( =+">.7(')/#&:,)=/ 2!#9*":+ ;+!:+4%.!0# 1$ 1%$5'$8(#:*$=*&>+)?.+>/.?25E84K:*B0&=+-B10F4+@/"8)$?/%@0'A1$=+$;(%6" 2 3$$6)#7*"6)"2#!3$$9*$>.$=.$<-#=+,@//C3(>01%) ,,!. '((+ %&'(*."1 #0"+'%#*+'#"'#$(%#,+*)!#&&# "#$#%). 4&0#" +1K:3H7.?1#%#-!%7),E31K8/I55TB=XC6N7-E0'D2$C5+N<.M<5R>1N:8ZA>cI.I8!:&GaM0M8$C.?[I1WE'N71V><`E6[A/U0XA(K3"9,C09eO5XC)C0(@2(I9+T>.`C7kN/bD2aI2YF6dLApU5[B9Q= -%)=- 8+2$7*=/,F5*H40S?3YD/SCB3%D1!9(. 1&8*!H8:`P7_M#H6'K:%F5+J:E0'L7.VC3bN*ZF'Q>-I9*N:4\CKmVE^L.D7 8+'>.'C.&E1"K4(W@4`O8eRAn[Ep[:aJ0S;&B/&?-(=+)<*$;$%@*#=+$:+"5&&6&/+(,!5$#:(#;)!7% 5%1".!!1$$4##3#$2##0#".!", % +**("+"0%/" 3&3$!3$$5&'9'%;+#=/$?1"8("4# ,!*!2$%8*!8)$:+'>0&@/#?+%@-(A.0G4*I:/P>,N;,M:)G5%A1!8) 7(!8) 5&%2$4'%9)$<)">'!<'$9("4' 1#"3%%9(#;(#9+!8)"8*6%8&#:("6("6'6(6&!6(#7("7("7)%+W?.ZD1\G3\J4YI-N@+L?#G8"F5,M=)H8*E8&O>(TA%U>'Q<&I7$A2(A6'E8)N=)S>(O<,Q@&Q:&Q;&N9'L8%G7&E5+E6-F8(D6+K<+M;&K6"C2(C4(C5(J;&K;&K:,R=/YD/]E*WD*XE4]K2`N,bL*gN+dI,cJ+bK*ZG)YF*XF.ZI1^I3aJ3dL2aL5_L1YI.WE)TB'S@'TA'R@&N=%H9$E6%F7'RB+XG,WF/^J0iS/eQ3hS)YB$R<&P='SA(R@,ZG/aP,^L)WB'S=&L:%P='TC,YG+WF(P@,N=-O<,T?+T?(T@,ZF)bM*^J)YC0YG)P@%K=E5 F6$I8-N>/P>,M:.M:-P<.U?,S=/U@0VB/S?0S?2TC,P@,QB&N=*P:,P:.N:1R?0R?0SC,K<*K9+Q;(N8'J5,J5(K6"K4%S=)ZD,[D,UB0X@.YB-YB/WB0T@/J:&@/%C.)L60S>2Q=5O=/N:*H6.J7.H9)D4'C31QB,P?'P=&P=%L8+N:*O9.P=3Q>2N;1O;8X@2S>/Q?,N=+M<-M;)E1)?0'>./F76QA.J:/M<0K:)J9*L:3Q@.M<$F5.K3,G10Q;.T@1WD,L=+P:-Q>.QA,N=)I5$A+'E4.K;/K:-J9.L8!C/$?0&C4!A2)J:+I7-I4-H:+H7+G70L<+D47'"8+2%+*(*,,+*,#+"0$ 3'0#!5($:+6&9)":,0!)'#%/!<-"=.%:+ 9)"7)"5(2%2% 7)9)9%%:("9&!:,4&/#))4"/G40C2(9'7(";,$?.#8* 3$-0#2$!4%&8'*=+*>+*=+,E.-D.3D44F72J7.G3&A.'A0(D//K5(B*'A.%<*'?-)?.)=/%:+)8&'8&*<*"7%-@/'9*#3'"4&'<*)A/'=,%7*#;,-E3/H3*?,#3%!.#1/1 /,).*&&+!.!1"$2%!-!(#"$)()),!)! #&$(&)+ *  ""!(% !"$%"#'. 0#-"!)1C4=P>2E3$2%'5(2A38I;?SA6M=9UB9R@3J85H94E72A9+E76TE5XF8\H9^H7]G(B0'B/%A,4P<)I6.O@0UC=eO(J<0N<+E3.F5.H6+>.($))":(1P;EfN1P6-!!7((C1!@-;,#<.6&%F3:`H+T9&I4.L;,S<.\B/_G!L6(N='L>.M?/UC0YB9YE;P?'3$(=0 4(6*&A2$B2$>."A1(K:*I9'A1$@0>.:*7%:(?+#D0!B-$C2/K<+G8(I:$K6#F1G/$N5K22`EBmT:cM-U@3YC/R>+O>$G9,T?6\H1UC*M;?*,T=8lRAs\3fN;jRAiT0WB'C0'?-'=+(;)&=&&>)$<)#:+#8)(<+)<* 0+* -%6'(<(&;'%:%%;'&;()?*(:)#6$ 1". .,'((+('- 3%":*";*&>-%=)%;)%?-)F6#A1!9(.*+/ !4%#6(&;.&;-&>-&?,&@,)B/0F4-I72P@.O<+L:,L<(G5'@0%?/";,"6'"5'%5'!6$ :' ;(%9'4""6%"3&!3$!5%"7&$7)$6)$7(2#2"5$ 4%!6(6'6'"8)%:,$;,(@0)C45O@@]M+J9-E7/N?1VB/XC(O<)K;'R>+XD,ZE1^K2[I)O?$H8&J:)M<&J9&E8(D9%I:&L<&L:'M9 =.$=0'A5%D6%I9&M7'M9(L:&M:&K8#F4*K:'E4'D5)C3+F8(E5+K;*M:'L8(K6,G7+F8+J;'J:)I:*O:2YE4]H1]J/\I.ZH-[H*`J)bJ+aH-`I*^G-\I,YG*VF)UD+YD,ZC/^G2_K2YH0VF.UD+TB+TB*SA'P>'M='I:+J;'F7%L<$Q@)UC.aL/iT1iU2gQ.^H(W@$R='SA*XE)XF,]K*XF&R>%M8#J9J7%S?+WF/VF)M=%K9&M9*T?,WB)WB'VC)_G(ZC+XA,T?(L<"E6 D3$F6#G7+M<-N<+I9.N:-Q>/UA/U@+P<(M90VB0TB-P?+O>+Q?(O>(N8*P;0Q>1T@.Q@1UD)O;)N:+Q;+Q;&H5*H6(J5$L5(V@+[E-[E,UC-T?-UA+UA.U@*L9'D0'?/$@.+J74WB3TB2Q@0N;*H4+I60L<*E5-H8.M>+N>#J8+R@)O<1S?1UC/R@.L<2Q>5U?4U<0Q=.O;,N=,N<0O=-H7*C3+E5/L;4RB6VE3SB6SC.P>.P?3O?/L<-N>3Q>0M:1R>3ZE4[G0TA/P<,M;*K9'H7%E0%B.(D1+H7/O<.O:,L9%D0 7(%@0"A2.K<0L;1L8,K;'G6,K;/L<0J:%;-6&/!*'%)--*, * .$/#"3& 3&"8)!;+ =-;+ 9)/ )+)- 4%!A2&D3&@0%@1*D2(?/0"*,.!5!"9&5#8'3$2$#-!.!(>-0J7$<+8':+#@0$=.!;+#8*2$"2&$5(&7)*<+(;*)<*,A/,G0.E/1C32E60J6(C/(C/'A/%>-'B-&B+%=, 8((@.%;*$9)'<,&8'&:)+B2,F4*B4!8)%7*!5%";)'A,(?,+@/)@.-C2*A0#8(!3$$4&3",."- )(...- 1 !2!!0" /!+ ())++**/!4&*"!!%## &+!+ ""$''!,(2""# "!!#" $.!*$ &0B38L:4J5)<.1C53E6.B5)A38RC6VB4Q=3M83J76J:4G;/G83N>4SB5VD5XE)J7*E2%>,2L75O=)E3'E60TB/WC5_H/XB.P>-L;,O:;\E?`G?_H2T>+M:=YIBYJ;QB;UF7L>-#3&&<,*G5*K8"?-2 1$(=.-H5%B0*D4#:,4&#B/*O7,S;)N91UA2XD0^G(W@$K5"E2)J:(G:$H7?,%?.3$/ @-'F5!>/$@1*G7:(0!8'%F51L<'A1%A1$B2(C3%@.&@-;(5!*4%+J;1RB6YF1UA'J6C/'P:-YC$O8+T<2WC"G2#H20UA>dTCk[Go\8^N2VE+P?;(*T>6iQ,(?-)>*)<+$7'"8)!8)%>-)C/$;'$5%"1# -#1$$7%$8$(<(%='%@(*E-,C1$:(#6% 3% /!- +(*. +&, 5&$?-&C0(F2&B.%A.)F6%F5&D4!9*0- -./!"4&!2''9+';+(>,)?,.D13H5/H6-H7*F7(H7(H6&F2*D4#=- :*!7)"7(#6'#3'&4'#6&#:+!;(#5%7#!5$"4#"3%#5&"4'%2&&4(#4&!2%1". 3# 6%"9( 9'"<+(A0'A2+F52P=:ZHEfU3SC+H70SA0WC.U@%H8 ?2D3!G5%L:(R=+U@$N:%J6%J6(L;(M=#C4%@6%B5%E6#B2!>/ 7,%:0&>1'F5%H7#H5$I5(I5,M>(G8%D4'D5(C5*C5*E6)F7%D4(G8*L:(M9)J5.J8-G9.L=/M?1L=0O=4XD6_J2\J4bN/]J+UB)[G-`L*[F.\I)\G+VC0ZI-XG(TC*WB)W@1\H6_M3ZJ2WG0VE,R@)O=+Q?)O>&L:&H8*I:(G8%H9&P?'SB.aM-fQ.gR.fO-_G&XA(VA,YF'ZF'YE)WD(UB'P;$L7 J6H6&Q>,VE,QA*M="J8#L8&P;,U@)R?(Q?&W@(U>(S;*O<&H6!A1#C4!@1&F6)J9-K;+H6*K8*M9*O:*O;$I5%J6+SA0VD,P@*M<*N=)N=&K7)O;,P<-Q@1WE2WF+U@*T>,S=-Q=*J7*F8)L7(P:(V@,[E(U?'P=%J:,SC&N=-SA%I5#D/+@2'B2/O<5XE0TC'K;,K:(G7,I9/L<+F6/I9.L>(J:"F5(M<(L:-Q=.RB.RB/Q@1TA3W@2V=0P;-O:-P<-N>/O>.K;.K;0N=)J9/P?5ZH2VE6YH2VE.Q@2N>)F5+L;0TC0P?+O;/WB/ZD0V@/K:)D4&C4(H5)H5(F1,E3*F2*L7'K5*J4(E/":*'A1&F7.P@/Q>/O;(J9'I8*L;-K:-H8'>/8(/ )(%'*-- /"-!.##6(%9* 8))E5"D2"F2A0#<,"2$&2#5%6)6(&H7"B1 ?/"A/*J6)D2%;++$(3!!3!1 6'3#!5'#8'&=,.F4";)4$4$ ?,!@.>+:(!;)!:(%6)$5((9++<.*<+->-0E4,G1(A,.A22F8+F3+D1'B0%>,%>,+G1(D.&<,4%'<+'=+"8&%=)%8('=.-C5/H:&>/ 7)#8'%:)%>*'@-$=))@..B-)=,$8,$8+#7($6$0$("+ !) )!+ 1""4# 5$$9'+A/3". . ,- - 1$0 2 1 5#3"1"$&*% $-"'  (&(!#1#%5% # $"!#"! !%*($"+=,5J96M:/?//!&7*%8+)A4/J<7ZD9XD2N84L94K;6M>2H92J;4M>2N>1N>2PA7Q?(@-;R?4L:3#)G65XI7\J1XG+R=&K9,N=1WC=bN-O;=[G1Q=)K77RB$9*'>/,G7#<,$7)%@.(F6+H8&@2. -#4&.B4,F5+E5)B39)":+'D10T<-S:'N9(O:1WE0[G$Q:#H2!@+$@.(G95TD7SA1#*!A0&V>.[F1YG/RA0Q?1S=0C6/ 1N?.G9$<.'B3%A.&A/&=+$=+8%4".#6')L=1XF0T@,I5$H8%J9'O=)R?*R@+U@0P=$F1(L62ZC6bM.[J#L;@1(N>2YJ8aP6cM/^F 6$E2)G4#B/!C/%<)$?)"=(">*)?-%8'!2# 1"2"5$"@+%A.#;)%:(%7)"4%#2$#5'':*'?-&A-*F2+E2+C1#:(!3"0",,,. /!#/" +. 4&%@-'G3'J3%F.#A0(F5'F3&D1!:*1"!/! ,/. 1$"2&"5%$7&(;*+>-,C04I6/H5*D3*F7(G8(G5'E2)D4#>.#:+"9*$9*"8)$5&$3&"5&#:+"9+#6&5"!6#"4#%8'"6'#8(&5'(7($6' 2$2#3$!8%$:(%<*$<*#>+(E20N=1R>7]G?dPHjZ7XI/Q>/S?1WC&M8!C3 1'A4'A3#<.7*3( 2*#:-&B4&G7'H8#E1&E1"A2)G8%C4$>0*E7+F8/L;)H9*I:(G8)L9*M9+J6+E4,G8,L=1RB5RA4S@4WC5^I2\J1^K.ZG(Q?+YF'WC(SA*UC+ZG0XE/UD,UE-WF+YE/^G6`N8bQ5]M4ZJ5ZI+O>(L<(L<'M;'M;&J9&I8%F7$G7&M<'UC*^I&\H.eO-bJ/aI)[C)[D+\H%ZF%WC*XB(R=(P;(O:"P:!P9(R@)SA+S@.SC)M<%J7*N:-S>+P<,P='U>)V@)R>(N:#E1&E1%B3%D2)K:'I7&E1)F3)I6*J6&G3'J6%J6)Q<)SA/VD.SB%G6/Q@.P?*K;(L;*P>.TB3YG1WE)V@,U@+R<,N:)H8-J:-N:-R'M<+I9&G6.N=-J;*E52I9%F7)J9$D3(I8#G4*O:.RB1UE/SB3WF4ZC/U<3Q>2R?/Q=/R>/P?.K;.O=1SA+N<,P>6]K3ZG6YH2VE2TB/J; >.*N=-SD*M='J:(P;-XB+R;-E7(C3'E2-K8+J7'E2,F3+G3)G2%E0+J4(G/&B1<,#G7,RC+Q>%K4*K:%G6(J9.M<.H8,E5:)2"+''))-!2%0" 3&"6($8*#;,(D1&H5&J6+Q<#H7!;+$6'$4%:)@.%C48(!?/@.=(>,&G1&C/%;+#4&"0#!-".",+2#5&%:+ E0'F3!:+1",5'?+=*7%7%!<)9&$8)(;,+>/)=+,?.0C2/F5*E/)C.0C62I;*H4+G4*C1'>/'?-)B0:#&<, 5'"7&"8&2 '=*):,.A1-C3+>1&9,);-(>.&;)*?.%:(&:()@+&<&&;*&:-"6*#7($7%- +$/#%/##."%3%%:(!:'&>,%;)2 . /!. -+*/!4"!7%"8&3#+'',!"!!',! +"%&(&*!0$%!$$     %%('  '#'!# '&5'*<*(;)$)%#+!''9,3I:*H5/J65O<3L73M92M=6L:6M:2K86P>7SB;YH.*=/(A1-K:;]K6[J3XG6\I4ZD/T>5ZI?_P(D5(C5)G7'J6/L/"?,(B1.F6"5(*"-"$;)1H7/I9-G64#:',G5.K70Q<.S=#G2*N:/M>D1-U>'I3(B.(D/)E61N?)B4/ 0 'J6._G8hP0^H7_J5ZE2S=&>/%B2$C2 :*$=-%C3'B// 3!5#5#.$1#1VE0XC.P=*E1#G7)O?/VD5]K1ZG/U@2UA1U@,R<&O:*VB+ZG,XI0ZM2YJ5[L0XF6`K5_H3XC+J7)E16%-K;)B.'B/&B.(D/)D1&9*!.!",*)4$":)$:+&>,'=+$9&"3""4#$9''@.'B/(D1+F1*E0%<)!3#/../0. !/"$0$#0%2$ 9*"?,!>+#>*":,%?-%@-!<)6%1#/"0!011!!3%"5%!4$!4%$7&*B/,G23L8+F5(B3(E6+F5+G2*B3&>.':,%:*#7(';,#9'&9(&9+!:+":(&8&2 !4"%7&%8'$;($=*';*';)'<*$8)!6%#7)#9'"8&%;)#;)&A/+K82S@6\F'I6!@08* 5'3$4%8&">*#A. @,>, A1'E6&A2&?/(B4&@0!;,"8+3)!4,"9-%>2%C6$D5%C2*E2$E5(H8'I8)H6)H7'E3*I9+J;(H9(I:)L9-O;,I8,G6-K:.R@0VA4U@2WC4ZE5_J3^L0]J+WD+R>(SA(RC'M>&M=+WF0VC)N=)O?1[J0]H2`J=fU:eT5_P5`O5\K-R>'K;*M>(O>(O=&M;&M;G7$G7'M='VD'YE'WD'WA+[D0_G,^E-`I'^G([I(YC,XA,S<(P;(R=%R<%S=)V@-XF,XE4^K.TB*O;)P;.T@+R?*Q@'U?*XD)TB%N=%K8)K7&F6&I8'J9$H3$A/%?-,H5+I5 =+'K7(O:*U?)UD-VD,Q?,N=1P?1P=+J;,L=,O>-SA0UD4[F/XG/TC*M:+K8-J90L<-M80R=,P<-Q='K6$G5)O;3YF*P0Q>/R=/R=*N;)N<+I:)I:,L=+K9,E51G8(H9+I9%A1$A1%H5.T?0TE/UE2XH4\I2YE1WA0L=3Q@2UA3VA0R=,L:1Q>3VA.S?1XB4^I4^H1TC1VE6WF'D48'-TB*TC&J9(J9+R?,S@'M9-G8(D2(G3.P:-L9&D2&E3*E3*B/%<*)G3+M8"@/5&#H8%J:!D2$F1+G8$B1*I81O?,H8%@07(-((+,-1#!5&4$!7'$;,%>,'D1)L8'N8)P90WA(K6 ;(!8& 8&!A- H2"C38(5&9%;( <)!@,#?,%=*$8(';-$7)#1""- !/!#8*'B2,H7&N:?/1#+2 "=( <)8&6$7%5#2 8$(@,)A--E0-F0)B.,A2*E1)E13H:,E7'G5(D1*B2,A2+@1$>+;&%7'2" 2!.0 $9)+?-/C3,B2(>.(;-)<.'>,,@1-?2'8()<+)=+(@.'>-$;*&;,!3% 0"*+"0##3$%9('<-'<*(?-&@.%<*2 .!. . - -&%*.2 /,&%%%""$+1#*%"%,-"#!#"!#  # #''& ##1$$3%".&#" '"'   #&'##"!) 8H90D23$+?.0D24J71J8,H72H61G42H63UE#@3#,/G7'<-0#*1D60K8-H61L<:)6#%B/,N9(J51R<>]I/N:4Q>1G89(.P;'G2:'#@-/K95R@.I9#:*"<(>( I3*T?+TB4\J8_K1WA/P=-P>*M;%A0'C2&C2)E13N<:SA!:(5&5%2%7'+M;1S?'G4#>-&L9,T?+T?-WA)Q:-T>4\H9_J0V?*R:0\E6dO9fV/%/#&+ #' ((+-/"7")>)*?''<$#;#'A)&A*%B+'B.%?+#9&0,* 1"3!%2""0"- .!!+#-"2%8'9%$;(%:,&=,";'!:&!8'3& 1$ 2#2!20 3#4!#6&3$!5&$=*'D-+F2,G6'B4&A3(B1(B.&=.%:+(9+&7)"6&%:*;%%;(&;,!:*":'&8%$3%#3$%6%$8%":';#&@*%>(%?+":' 8&7%"9'"9'%;)$<+&C01Q>7ZG7_G>jPAoW:bP5YK6]L6^L+P<&I5>- :+ 9'#9("7(8(9(;,%A.!>. =.&@2'@/'?-#?0&@0"<,!:,"8-!7. 6*#;1%@6&B7'B4-E5&I8(L:$I7(J6+N9&I4*K9,L=*K;+K<+N;-Q<1J<0I;0O?+P>-W?2Z@0WB/XC1^G.YH+XE(R@)P;%L<)O@)L@,QB*UD1TC(M=(N>.YH.YF0_H/ZI,WH1_O4`P4]L/WB)M=&L<&N>*TB'Q?(Q>&O?+N>*N>(VE%WC*SB&Q>*VA0_F,^C-aJ'_H([I'WA*U>)Q:(Q;'S>)WA*XB+YC+YC/]I2`M/VE(Q>+WA.[F*XC)VD$R?(UC(VE)SD'P>*N;,O>+O>%K8$H4$B.%?,+F4'A/$@-,N;,VA+YB)WE-VE+O>-O=0N;.L7,H:,J;,P@-P?,P@1TA0UF*N>.O-R>)N9&K9/VA1WB0U?0T>/P<+K9+H:(H9(I:*J8*B34H:%E5$A2!<,#?/*J8/T?,R>-SB.XG3\K0WD*Q-Q=4WD2YD3\F*U?0SB-P?/O>)E6#D4)TB(TA(M;+L;,P?*O>)K9-J;'F4*K61S=,L7(E5#H7(B3*<. 3$.K8&M9$?/:*&E6"A2 >,%?+)C3&A0+F6*H8#?/6&3&-!)+./ /!#7("7(6'%;,%?.&B/(G5(L7(N9&M7-S='D2"=*;) =*B.C.;*1"/4"7% ;( <,!<,$<+(?-)B0(A/(>/+=.,?0*H7%I5!F2+J9!8)+1!<(C*!<*5""6%#7%/3!!;#"=&)C,2L5.I1'A+'>.*F2.I6-E7)D5&G5%C0&@/)>/&<,#=*:#3!--. "7(*C/,F3'C/$>,$<*&=.'<,*+!:(5#/$.!- ,'0#(1$&/"& +#1$/ )% #   #$&-,*  *-!(  !$'&#"  "%('*# /$!5%5!0**($(#!!      /903B3#9&( -&5&3F6%>..I:7O<6M95M78M@"5)$>.Nl\:]G2UA6[F9_I9bI(U8&G3#>+2I8,G1(I.,S5.YA(M6'G1)M6(M7-L70K;3K<6&!:'(B05Q>.M8 =)!=,2! ?*)K5&M6'L6(I6*F3#>,$=+,;-(A.6V@/N:)F3'G56P'P<,T?6_H1\E0XB1R>+J5#D/5 9%$>,"<*7&:)9*;*(F3.K87( :-'N8-V=2\C5_F5_CElR6`K4^H0X@/X?-U>,UA+[K,YI(P@B2B-<&&H4$J6(Q<2YG"B1)B3.F3.G3,F1*E.*C/+?,#5#!- +"*# (!-. 2"+>-&E4&D0%@-&?)&;)';)'9'#2"".) *( ,"."/! -(*") * #0$#4*:(%<-(>,%=*#>*%>+"5&!2$ 3%3"2 -!/!3 "4"!1 /&8&.C0-D3+G5)I6"F3$E1)G4)?-&:-).";*$;)$7&&;(%>*'B++G18U>:aK@fP>dNBgR@gQ:aK=dN0$=/'>/$<-#>-!>*#;-%=0&A3(E6)G8'F7&L>&K<"F8(M<,O@*N>)P8/T=-Q>*N>)N@'NA(J?,OA/S@/XA+XA*ZC(RA,O>2P>-P=*M;*L<)M<)M<,Q@+Q?2XF2WE0UE-SA(P=-WD.YD-WD0PF/TE3[I4^J4_J.YE.OA,O?.TD4[I+Q?*P?*WC*UC*VC+ZC+YC,YE+SD.WH.ZJ,VH/ZK+YH-WE*TB)SA#M8&P:+T=)V?+WA-XC.ZH/^K-^L(TD"P>0`J1`J0^H-YE+WF*VF,YH(TC*SB,RB(S>+R?+M=$C4(D4)D5(F3&D1&I5*Q+K8"E1.Q=/S<+Q8+S@2[F3YC+K6-J7%H7)N=-P?+Q;/S=+M;'G6&E6#E5$H7(I9'F4*G4%C0%A/4 $C3%J9)Q@-Q?4TC2VC.[F.YC,M8(J83UD/VA-S>*N:'K5)I6*M9-S>-S?.R>(J7(F6+M<-O?)G4*H5/S>0Q>+M8,R=.T?,O<2QB0M=*H61N<3R?1Q>'H4*F6,F5'B.;)/O?*L>'G4$B/&C0!=+">+">,!@1"?0$B/+G4%A/7)1#, +!.!0"4"8(&>/#9'#9&+B/-F3.K4*I7(H8#G4#H2+N5,J7 >+<)%C0%B/9'1%+-!/!4&";+ ?0">/'A0-I4/K40M52I73J81K92M9,H3(D0,@-&7)"1)(8.)?0"@($<) 8'!9+4%3#8%!<+"=*'C.,H1,D/,A.)B0-I5'E0&G3*H7"@1#;+&8*$:("<*">)$;(";$):& 1",!0$6$$?1*D2&@**B-*@/'<."1%>0(?0%=,$9(#9($7*#6'$9*#=.*C1*>,'=+&:, 4&1$/"&3$!2 "0*5')4''5&0# 0 2$)" $"&() * &$!'/"-"(  #$"""!#$!+ ++(&%% -&2'.",#.$/$* #%! " "&$!#&!$-8++5)!( $ *.=1"3'0F3AY==ZA;Y?;ZA?\D9WB4R>/K9.L8,H5'?/3N;1R@(J:*N>/VE8\KMiX*@1+9.)C37YA-N62M;*C4#D13SA1UA0XC,S?1O<.N=*F6!9*';./C4 5&)5&3'5%,L;'J9%M73TC+F84%#>,6T?0J<,L>1UB5XD4WC.UA5T?-K95R@(G3(H3-O6 E4*I:6QA"D2)K72R>5XD,WB+WC+P?%E6+J;#9*+4"<'A* E-<(<)"C00N;5%5$,I4)N4'R;2\F*O=)J<1WA7YG3TB.R;3aH8kW7cX)N@5ZJ0aM3gS7fS3YC+P>#N='VE)TC.R@,E1.G3(C.'C+*F2*C/$8%.!+"(%'+/#6%(:))C2'A.$?*%='#8&$6$!1!+ *)(*!-*)%&*) ,#4&&<-'A1&C3)D1*G2(I3*H5#<,$5(4$3%/(!,...!.!"4$+?-,G1+H4*J7'I4(E3+G4(D2%A2&B3'?0!5' 3"!2% 3$!5'!6'!4%!2%:(#<*!:' :&!<( <(*A0'B1$B0&D0(C0%>,)?-%<*)D1(D1-M86YB>gQCmUgPAhS=hN:dO,S?@.#B/$@,$=.&>/":, 8* 8*!8,<+=+ ?.:):+">.#>0#?0!<,"=-#@.#D/%?0%@2'F6&F6&H8(J:)L>$I9$I8*O>-R@+P=-O:2T@,M<(J9)M=)O?'O@)Q@5\I4]G/ZE-XD-O?/J;-F3,G5+I8+E7(K9(L;.SB0UC1WE.UB.RB,P@*O>-TB/VD,RA.QB-RB/VE0[G0YG-VE0UE,SC-WG5aN#O<&R@*XE*XE(VC,[D0^H0_I,WE1]K0]J.\J.[J*WE+WC+VB)R>%M:"I6*Q=+UA/VB0VD1WE.WC-YD*UD%WC*`J.dM0aM.\J-YG+YG+YG-[I%Q?(RA,VC.TC)O>(J:+K9,J6-M;)J6,N;1UA.S?-S?0U?3WA2U?2S?0P=*J7(I5*K7-Q;,Q;)M6/R;6SB/Q?.Q?.M:.M;.S@.P:(G4'I6/R?.Q=,P<,Q?3[F0T>.L8,J7(I7'K:*N;-P:3U@3Q?)F6&B2"A0"B1$E4(G3(E2+E1%>+;(*G4*J9*N<,R?2UC/UA-XB,S@)F5(J8.R@(M9)M9(K9)G6'F4)I7*K8,J8&C1#?.$D3&J9%J9&F3&F3,Q+#A/%C1!?,'B1:+6)8) 2%#4(2%6'(<*(A2)B2&?-(A/(C2-K79T>,H6&C3#C1(I3,M4'B/ =*'C0%A."=*4".", -!/"!6'$>.!@-&B1.H65P<3O:0N81K81L:/J7,F6+H6(D3'?.'<-$8(,@1)A/%?+$>*":)#:, 5(3%2&1# 8('A.,F3)B/,C3,G4+F3%D/*G3,H6#<-!6)0" 3# 9'#?+'@,&=)-?+%5&0&2&2!9*$@,.H13I4+A/%<-$?0(A2#8* 5'$9+(>0(>0(=/)?0'>0'=/'=.&>/&<-)@0%A0,F3+?.,?/*?0$6) 2%/!&3#$2"&3#)6%%2$!1#, /,' $*$$($%*!*!&!!"''+)"#+%#"''$"!"#$$")!)!+!,*%(),#3%0!1" 1%1$+  " #%%$$!)&/#$#%0",<-(;,9L;AV?8R?6T?8XD:ZF9VE2K=-H6(F3+J79S@1N<'L8.P>)O;,SA+N=-G91$#8*)E3BcKCcL9XC@aO;^I2R>4YD6_J:bN7WD5O@*D4+E55K<&8)$%<.(?/#9).I85T@#I4!G76WI5OB%=0(B35P@/N@-P@,Q>4UB7WE5YF2V@2UA2RA*K8#F2%K6(Q?4YF3VC*R=3[F6\G2VB)Q<-SA)J9 ?12TF8QC(B3"=-&B1)G2&C0 @-$D2#C1'E25 *)A/$B/@*?) @..I94VA7UD;,,K67`IO{i7eR*R?=fOFw^Bu[6fM7hO.]H/]I,_L/aM3`J+D0+D0*F/)H/-J6+G3&=* 1$.#( )*- 1 #5$&6&(<))>*(@*&?)&>,!:'#5&0", *)) ((%'$'#,#,#- $3&"8)'B3-L9/J80L9-O;+L9&B/#8* 5% 3$. )#)+, )) 0#':).K1-K4*K3'C/&A.+C1%G3(G6&C4$=/!7'#6% 2#"6'#8)!6'#4& 1$8%"8&%:)%;)$<)#>)&?.'B.$C.'F1(G/(D.*C1-F4.K8+K8+N:6[G;hQ?nW?lU9hQ>iRCmV:gM6`K-S=$D1$A-'@+'<-#8)5&3&!5(!6)8(9*>/:+9*:->/?/<,=, @.!E1(F6$D2%F5#F5#H7%K9&I8%G6'K8*O;,S>,S>-M=*H8(F5*H8'J7)M;%S@(UB2\J3[H/WE,RB-L;*B2,A1*D4-I9)C4'G6&H8/Q@1VE1UD,S@,O@0RD'I:+M>.RB.SA0TD.TB+R@.VD*QA,PB/SC*P@*UD.[H%T@'TA,ZG+XE(XE)YC-^H.^H2_J2`K6eO1`J/^I)ZD,ZD+WB'O='L;#G7+P@.UE,SA/WF-VA.WB/YB0WC%V@"ZC*cL/`N4_O0^K-[H+YE,ZG"Q>(TB-SC+RB+QA,Q>1U@3U>.P<+N:,O;5UC1R>1R?3T?3VA1WA0TA*L8)H5&J5'M8)N;+N9*I4.M6.O;0U?/S?,L9.N>,Q?+N6'H4(J8-N?/P@*N>/R@.UA-R<1P;-I6.N=+N=.O=3T?<[F4R@+G7&@0 ;+%@0&E2(F3*G4/I5 ;''C/,K6*L6-P;+U>.VA.WB0XC*M<'D4&J5*P;"F2"B/(G7*E5#>.$?/'C3)B2"9*#9*#@0$F4&H7$@-%B/&H4(L;)N9/V@/WA&J8)K;/N7-N:2T?.O>/O>-L=(N<&I8&H6$E3"D3$H7.O:-J7'D0,F4(D18%,I4)G4(F2+I8)B5%=1#>.'<.'9,6'#;+-C1/I8'B/)F3/L:&E2-M:,5"0#*"0$#4&%;,*D4$C/*H30K7/K82N;1P>/O9,J7(E4'E5(E7&B5(C3%@.(D-*F/&@,&=-">* :)6)!4*(')1#!8)&@.&@0+F6)E4*G2(D0-I4,C2!5&.!*+4$ ;(#<*%:(+:(#2#!2'!6'3!:+(A.*D0+A.(A-%?/)B/(B0!;*!;+%;-)),>-0C40C23K94Q>3VB7YI9VF2I<.H70O<:XG0M<A--T?2W@,R=2WEGfW2L>++%@..E3/E4-J8.K8(C0"8) 6& 3$0!!,)'(&) /"%9('B-+H1.J3'A.&=)'>+%A/*C2'=/&9*"3$"4#%9*#8)$9)#8)1"$3%#5&$6&(9(*<+(;)'=+&?+%@-'C/'F.)H0*G/,G44P=3S@-P<)O:2YC9eN8fOlU+O?-R@-P@.O?)I:*I90Q@0SC4[F.UB-VD+QA*M=)L=/N?,N>*N>,TB)Q?,SA+XE+YF,\H+\F/`J,_H1`J5eO9hR5fP0aK,^H-_I-[E/UC$H7!E5'J:'Q@(RA,XE/]H,ZD+YB1VB)T>,[F-_H5bQ5`P0_K,ZG+WE(VB%R?%R>)O@+SC-XG+UC.U@4YB1VC-Q<2UA5UB2Q>3P=5VA3WA/YB.VB'N:'H5(J:)I;(H<+H;&B3+E3.S=0WA.S>)I6.O=0WE+M6(H4+M<.O@0QB-QA,M<,R=-T>/P<.L90P>/Q@0Q@4UA9WC4QA.K;)C3&@0(D1(D1(F3)I3*F3!A+-O:,P:(N8)O90WA1\F-YD/UA+J:,J9,Q<+N9"B/#@.)E5'B2!<,%?/(?0,@1$7(#6'*A2)D4(C3(?-'>-(D1'J:-Q?/VA-R=#C0'G53R+G8(A4*F5,B4(=0'A3*E42L80K9,H5.L9'F3&G4,O;2H6-D2*B0)B0+G3-K5,E4'B/&A.)E1)B1#;(/#"3&):,%8*%=.+H7-H5.I5,H4'D1*J70R>4S>+I6(F5+G8'C5%A4&D3)I5*M4/P8-I6,D6%A-#?-$:-1''( */#4&$?/%@0&A2$A0$B/(D1(C/#8%,*%)0!7& 9'$9)#4"$5$"4(&;-%9'#<*&>,%;(#=)(A/)E2+A/%>,!:*#=.%>0-D6.F5#:(!4%':,&:,!8*:*":+$=,"=+#<*%:&!//!3% 4',-"/ '6%&5'!1#+')+-+(!1"8$0!$+&"*&%(**#,&('"! -!"0$%"$" "%(,!!-$/$.!*%$(+-!0!0!1"0-$$ #")" &(1&(/$""0<,)8%(-!*[H5N<*F1;YG6SC%B2(I89`L0U='L74XF=^O3O@2K;1Q>.O;0O8&B+!B*:eN#D/ A,/S?4]G;bN >.,H:3WC:bL9aJ6VD0H9&B0$?+%>*:& @*%L4(N9.R=5WA3S=/M82P;0WE@hU/U@=\G1O;'L93WC:XE-G4,G8"A2.QA(R:*M9'J7,Q@-V@-U?(F39''B2+D4!=.A16ZI3QB(B4$=-2#0!;('E2)E29'0G55H7*C6)F5+O9-T>1V@6YD9XC-F87)*B3/K81O>/RA7]L2YI+RB/VF:cR2hO9gO-)=.)D3+H4(C/%?*#:' 3!!4""2#.*((+1 &8'9'%>-,C1,C0+A.(=+(?+)<,'7)%4""4!$9'%;(&<)!7$"5#"3 #6''7)'8)):)';*$<*%=*$;)'A-*D0+F1)E0.N85V@8XE2VB,P<.R>5ZD;cL8eN6bK3^G2YD(L9"A1">.#9+#9(#9'!7%!7%4%3$!6' 5' 8(!;*:* :*8* 7)9+!=.!<,#>.#@.#C/&E3#B0*I8$D2"C1$F3&I8)L;+O<%H6%I4&J7*I;*H9&D41N>(G4&G3%M8.UC3[J3YI4YF/SA&J6+I8*I:)N>*P?)L8(D4'D4(H7)K;+O>)M<-SC.RA*K9.K9.P=.T=1XC+SA)P@)N>)L<)J:1L>.K<-O@-R@,Q@.UC*UC)WD0]J2aJ._I-]H1`J5fP8jT1dM0cM*_H,^K-YH-SB A2 @0 B2$J7.UA/ZH0^K,[F*YD1WG(O=(Q;/ZE2bN0bO._J0]I.XD+TA'Q=%M9)P<*SB.ZI0\K3]I4[E4ZF/U@4WC3VB1R?3R?8YD2ZD-\E,ZD(Q<&J6)L;,N@&H<&H;%E5'D1.VA.U@)P:(G4.R=3\G/Q9)K4&H5/Q@1SA*O<,M<)P<+R0Q=0R@.RA0TB5XC5XB3Q@2O?+I7'F2*F3(D1*H2&E0)E3'D3*L8)L8(L7+O94WD1\H.[E/T?0N=,M;3UB)I7%C0(D1(D3$C2#=,*B2.E5.D4+B2,E4/H90L<,F7*B/*C1*G3,M=.R?.R>)K5#@-(E3-N9+N:(N:(N9/O=/J8)C3'@2";-$=/"?-/M90T@.Q>,K80O<-M:)J75UB'I7&J9,O@,L<*F5+G5,C4*A3,H72Q>4R>+G3+H5+K8'G4'F6-K.S>(G60J;*G2(C2(@2!5) 2%/"-!2$!;*#@-$C2$A0"?0"?.$B-)D0)?, 2") $$)3$:*#:,3 2!'=/%>.#;((A/(>,5##;)'B0+H4*A1'=-%<,(A0)F4.N+D6,J8'N76ZB*N9&K:%G7-N<<[G/N;*J6(F2#=*2M:%E05#+G61Q>7]H+(D05UB(N6*L70R<4V>0T:1U=5X@-S@.U?5[E3R=*L8*SA7\H;]I8UA4S=/R?)Q=#M5&J5$G7)R@1\I*U?(>,3 ,H7/I:&A3'H9-S@0Q>-I6#>-#>-:((B3.H9(E2.Q?#>/1N<,P:.U?1YC:bM;]E)F5$=0(C3-G4'D/(B1,M<*M?)J>>1=..ZF8`J3[D1\E.TB1QB'=+*D/(H/*P4)Q80U=0R:0M8/H4%<('."",.!3##9')?,+A2/J72U=3Y?/V;+L1)B-#:%&6$%3!"-))(* * )!)",!/"#8&)A--I01M4.K6-E2,A3-I9.O:0O:-H1)B+&<)%8$!3# ."*+"0"!1 ':'*>0%:,(=--C03I6/H2,?-&9(%3$#3$$6%!5##9%'=)(>+$;(#6#&6$$;,(=.$:+&>,%?-"?,*>,%:)&=++D0.H4.K71S;5W?=_G9ZE3T?2R?7VA;_J9aK1]F+S<#I4"B2!<.$:-$9,%9+#9(!8&"8&!6'#8*$8)"7(#<("<+";)!9( 6' 4%7* 8*#:+&>/&A/&D2)E2&C/'C0#?,"?+$C/$H8'K;(L;&H7&F5'G3/QA(H8*F7(E5'F4&F4*K9.QA1VF-UE0WD1XA,O(N>'N?'L<-O?/O=.H:0O@0SD,SA)Q?'Q>'N<+TB0]J2aJ1`J/`I4eO6fP4eN)\F+^G+_I(ZJ*UE+O@!C2=,<+$C.0Q=2ZE2[I.XF,XG*WF%N=!I4-YB3hQ+gP,_G-\E,V@+Q<'L7%J4)Q;%P<.[J4bQ2]K1ZG2YE3YE5ZF0T@-R=3UB3V@2\E*\D(YC%Q;+P;)R=(P>&O>)P@&N9'O6-WC)T>(N8.O:0T>0YA0S:*K5%I5/R>4VB.T=-N=(Q;'R;.T>-Q<,P>+Q?0TC5[D1U?0P?2RA/Q=+K8*E4(C/+H4,J5+E6,F6/K;0P<&D1,J77VF)SB$Q2Q=+O92P@,H8-I6/K9+J6%F1+F3-H51I71J90L90M:3N>-M<)J9+H5,H6)I6(H9,N:.Q='G2#A,,G4,K:'J7#I5-R>6VC0M:,E5(C4+C6-G:(F51T>1XD)O:)L8/Q=1S?2WB3TB'J:%K;+Q@/P?,L7-I7,A2,D5/M<0S?-Q;0L9+K7,L9*J7-I9,G7/K:.J74O<.J6+L6*N8.L9)G4(H6,J7/M9+C2+?0.?1)9,'<,+F3:XE4O<)D1&A.&F0#F0!H1+I6,J7,I6%A,#?+'B/(F1%H6(O>%L<'H8.I9*F2(D2"<-6%6&0.!6&$A.$B/"B/"A0"?0<+ >*">)8$-$!"%3$9) 8* 4"$8%%<- :+$>++A/(=+%;('A.0J8-I7,D4)<.*=.+B0(I5)P;.K;'?0&8*'7(%7%2!///1.#. -1$0J;(C4*B4/C30B5$5*$4)"/'%#&$" )7#"7*1"01 /!)%')'+,(*%(.!5(0$.#( # !),((*%3 , +)*+,',!4%4%.*,*$"#$&"!!$"#"#&2"1D3!2"&"$% '" +#';(->1)9- ,#.$%@2$G76R==ZH/J;6OA5N=-O81U>4WD5YI5ZJ:`L:aI7RA-K;(G6+E5*A.)?,!<-1I;.L:4XC9[E#?(&B38TA:WA6S<3P>+K<)E5%B0'B0-J5-N9"G1,G8.M;4T@2W@/U?*O<*M9/U@4YB<'#J5,YF2^K8`J;_G6\C.XA(W?)X?*S?*RB0]MDtbJ5!2"3 'E4%B2%?1%A3,P=+M9%A.(E21Q=6YE0L;?ZJ-H69'2!,>,/C55O+I:1L;6T=2O:0C/$C0,O?:YL2RD+SB-QA-UB-YD-\G/VF/M?-C/)B.+D0/K7-K:/Q;.T:0U:0O7%?*!4#, +!0##7'(A-+J3-R:2Z?1W>3Q;-F3%8) 3"0!2! - )!)*/! 2 !/#.'2 ,8&*<*,D/1M61O8+Q80O:,E31L:/S?(S>0N9.K5)E.#?(#;("9*!5&0!0"!1!"3"&6%0F3-D0*?/*?/0H5/H4+A2&8(#0)4"%6&!6&"9*'>-)?-)<+$7&$7&)9*'>*'D-(A*+B1'?1">.%;-'9,+?/1L83T<6WC6XC:`J+#>*#=*:%%8'"9(8&9&"<'$<("<%$@,";,#5'"2&"4'6'"8("7("8(%>,,G3&E3(D3'@1&=.#<-'B2%G8%E6'F7*H7*I8*J9%J7(I8*G7)C4'A3%B3+I8,N=(N;(M'M=*N?-UE(N?'K:*L<-L<*J:,O=-R?+O>*O>-QA/RB/Q>2WC0YE-VA)Q@&L<+H<-N?.VB1^H3bL3cN4eR5eQ1ZI/YD+YD*[E&SC(M>(I:"F6<,":+#A2+Q@.VE/XF-ZF([E)UD&G7 E5'ZG/hR2`J*UC(SA*SB,R@(K:-K;*J9'Q<)]F+^M/^M5^J2_G1[E6\G+O?,P@.TD/ZD/\G-\F+YF'SA*SA&XB)V@*XA&U?$S<-VA(SB)M<2O=4O<.O=1VF5UA.O:,L7/S=2V@*P:1Q=.R>.T>1VB+L8.K8-R>2VB6WD4P@4O@9TB1U=-K4/H3+B//J6.J61M:1M;2Q<+H8#B1'E5'K8%K6,O:-O>.N=-M=/O>/O<2N;2N:0P<0O>,N:+K50L8.J5/L;0PA/J<*G7*J8.N:.N8-J6)E1/M81Q=*K8%E2,J7+H5(D1%C07VC3XC*R=)I8+L;+P?-R>-Q=/UA1XC.U?*N=/SC1UD0QA/VE%G6'K8-Q>,O?-J;(J7(J6,L8.N<0RC)M@*K<-K;/L<1L=-K8/N;3P@5T@5V=/L60L;3MA5Q=/O8+K51O;2M<+B3'A/.C1,@.&B..L72Q;.G6)B1'C0$@-!>, >+(G7/M;+H4%A.&D/'G2#F1*L8,M:+H8&C3)C5)B3&=. 5&0#/%+&2%!:,"@-C/D0A-9+0"2" 1#+'"!%07##6%/"5"$?+=)&B.+A/&@.!<-*E52N:.J4,F2*C.*B0*D2(B3)F6,G3(B/&<*(:))5)*4%"3%. 0"/ /!$1# 3"#:,*I9*M:1P;2N>*G96&1%."$!*(!"#*2$5'3&0". )(%*(**-*("*+#4&,,+%()%$&*+(%+. %'%/!"0 %/"!** /$=*9&.'.!. "2!!/'""!!%)#'%&%,1@3!0"%##!$ ! "'/#&7,1<1%%&6+(@3G\M.G89TC9VE6T@3Q>/R@0WF/WG:_M;^L3WA6WC5VC1N?/I;3J<-D5)@1/K;,K9BcN4O:#9$#E34Q?:VC3O=,N=3YJ?`O*J8&D0)D5-G8*B6/JB&?4-M<-UA*VC4^K4ZD-O;"A0>/(J;,PB5\G@dOAbM/Q<2VC6\L5eQ9hU7fRK{gGo]&F57*"6)3%6&%C4"=/'B4"=,$?,-L9,M=3WG@hQHmX3O?8)1#+C4>ZK/J:4P=)E3)H73UF:YC3T=2W@1WB3XB/Q=/J91K80P<4[J8eU:eW6bQ-\J1^M.TD1NA1K>,C/*D/'A-%B-(E4&H2)M3,P5,I2)A-"3%, +!/#"5&&=*+J30U=0Y?/V<.N7+D2$;*10 1 !- *$- .0!3"(7&,9(+8&0@-.B/3M51O81R:/S83S95R;3R;+N7&M4)M82V?.P8*J2(D1!<+"5)"6'#6(#5$$7%&7%/D05K8.C4+A2)B/(B.%8)$3$#0$2 "4$#7*"<-&>0)@.*A/*?-';)+>*'>,(C/-D21G6,F4%?0';-&7*&;,.I68YB<[F8[D:^F=cI;aG-$@-#=* :'9) 7(6% 7%"<*">*'B+'D0%<-#5'%4'$6'$9,!6)#7+$:-(C20N;&J6&F3(C0%A.&B/%F2%G7#D4%F3)G6(I7&J6&J6&H4(F4)E4(D4%B1%B2(H7$G3$G6)J:$C6%G3)M<*L>(J<)F8&C2%A."A0%G6)N<)O=,QA(P?(N=*L<-N<,L9(J7,Q=-T@)P>.UB/UC0UD2TC0VA/WC,U@,TC%M<'D6(J:)R>*X@0bJ0cL1eQ6eQ/]J0^I*[D%ZC%TB(P?%H9D4>0!:-%?1(J:-SA1XG1\H,]G%UB(N<"J8%WC)]J(SA&M;$L9+R?/UC(L;(J9*L:&O8(U>-YG,XG7aL0[D1YD6]H0UD,SB1YI4_I2`I-\F*ZD&T@+XD([F)XC'S?'T@(U@,S@.O?,M<3S@2TA/RB-RB3TB1R@/P>2SA/P>*L:-L90S?,R>*O;(H5-J73UA5WC5UA4RA9TD8TC3V?0P:/I5*C0/I74P<2O<3O<2M:*D4$>.%>/#E1(J6,N:+L;,L;-N=1Q@1P>2P;2P;8WD4TC.P<+I52M8)E1,H7/O?+I:)I8'I8-O;0Q<1Q<0K70N91O<(L8(K6,L:(C0&B/,H57VC7ZG0UA,K:-N=3UC0UA,S>0XC2]F+VA&P:.UD-TC'M>,RB&G6.N<(L8+K;+E7(J9,M;/O<4S@1UD*N>.N>,J:,I9+H8,K72R?6UA2P=3Q>.I75O?9TD3N=1N;0N96P.&@0'E3#>-$=+';*+=++;+"8)7'6'5&4%':,)>.*D8*K=)L90P=0J;#9,-.! /%' *!%1" *'$&)- 0$. &"$'(((**(%' !(++.!+( ,, (,!!0$. +*&!."-'+ 1# 3"$4&$2&!1%1",C04!+%+2#6"!4")%( &$" *&$ %/8,*4)  $%,+>.)<-3?1, :(%9,0!NhX?\L;YF6TA4S@.U@1ZH:`N9[H0U?3N=/J;5OA2L<3K:/H4*A22M=4SA/M<&A-)>++K82Q=.K51P97ZD4ZF-M=)I8,J73Q@0N?-I;2QF%B5-N=1YD0\F+R<%I7'H6-N=0RA*N>-RB0[F:aL3ZI&L<"G8<,+WF3\L(I:";."9*&>/+I8*J9$A3#B1?+=*.L:+L<,M@3ZEBeQ(E6+'?1+C4)C5%B1+J7-L9+H6-G8.J53Q=-O;,N9+M9/O=0L91K95U@EmYAk[AhX+A/'?-&?-'C0'C0+J3*M3.M4)C.';) /!!,#- &3#$6%&=**J2/S;.U=*P:.N:.J7'A.4!0!/$."+$/"0 2"!4!'8&/=,,=+-?-0H5/K40P8-Q91T90R:.P:+L6*I2"C)#J40W@1Y@/Q9(D1"<,"8+#8*$7&';)':&':%)=+.C10F5-C1,D2%=*(8*'5&&3"&8%&8)$:+'A0(B2(B0+D2,C1,@,,B+)C/&?0.E76O<4R:0H7-A/+>-%;(+E32S>:YD;\C?`G:_F9^D9]C6]G1W@/R=+I6#?,#;);+;+ ;+"=,#<,#>-7)!8(#5&%6(&;*#?,+G1-I6(@.'8*&7'*=,(>,%=,)B2+E6+H70R=-N;(G4(D2'B/%C/'F3(J9'H5"B/%F2#G1#H2$E0&F2(F3)G3)F5%B3*E5'D5%C0&D4&D4$A3#F4&H8'F8(F9)G9'E5%@/#@0#D3&I8%J9&K:%N:'N:-P-W@-YC-ZD/YD1VD/Q@.S@*T>-U@/XD*P@)G7)L9&N9)V@._G-aI1eQ4fR/_K._K*]H)_G*[E,XD#L:!F6A3"=1(C5$F5(N<2YG1]I)[E"WC*UC!L9!O>%SB"I9&I8%I8&L:.TB+P>&J9)M9*O7*N5(K8,R@.ZC0WB4[F5^H0XF-YF/[I3\G/\F0`J-^H*ZE.^H'[G&UA&P>&R?(O>(K:3L=/M=1VB/TA,Q@(I:-Q@.P?-O?4TC.O>(E63Q>5UB.Q=)L8*I62O<6WD7VD0R>2SC4SB4RA2U@2Q=/K8/H6/J92M=1M9*F3.I9,B3)>.+@2*I5-K8,K8,L;,N=.P?/O>+L:/L92P=2RA4TC1N>4Q=4P<,G3,K8+K9)I8&I8D0/TA1VB,M84Q=3P=,M:*M8(J9(I8%@.,H5,H5=[H<[H-N;-I:/N=5VB,Q=)R<0\E4^G)R;'O8,RA+P@*N?$G7&D4.L9+L9*I9*C5*I9,L;0P>2TC1TC*N>.O>/M<+G8-K8-L90Q>7V@.L;/L=-G92N;7V*$B/*D4#=-$>.&@-%A."B/+I9.K<,G8+G4*C2+C0/B/.A.-A/%:'!6(&;.*@2'@/%A.7$;*9)$7)0$ 0##0$*&) + , +(8*'7* 4% 2 (=*&@,)D04%4%+C4&A1)G4)G4)E1,G6*B3-B5,@1#9)%?-'@1$<,&<*#6%!2!$4# 6'8(7'6&3$"6'*B5)C9&H:%I8,L9%>2.!*).!, 3#"- &#%)&*)!"#&"!"'%"$ !!'(++ +(+ + - 0#/!*& - + ."+&%)/"/!!2$#3(!4$+>-0("*3!6$2!)"#!"%#$ #&0$.6,"$$  ):)1G26L59F8,#;%+)7RB7SC5SB3R?6T>-R>1XC7[I;]J.T=7PB7OA4K=/F73K75L6/F44P?>^N0P?,G75L=0M<4P@2P=4S?7YD0T>4TC.P="E1.Q=6WG6VG4VG+I9(K86]F/ZC*Q<%E5'G79ZI?cR/VA/YE5\G7]I2WB8]I5[F7]K,G9%@2=. J95_NAeU7SC&@0&A1&H7#G6$F5&K5'K61Q<.N<)I8-L>5YC2TB$A1$@15OA.I92M=0N=+M:,N:0J9,@2%>*.H60M:0N;1N>1N>0L90J68XC+/ -!*#,#1 '6$'7$!5!#5 +<',?,-A..G30M6/P9.S:0P=,K9&E4'C3(C1&A.#I34[C3W?-N6(C0'>.#;+ 7(#:(%:'';'+>)%8');*+@.'@.*B0"=+(6('3$'7%*<)':*(<-%:-(A2(C3+E3.E1+B/-E.+E3*C5.D69S@9ZB8Q?3K90G4,D2/K7/M;2N:7S?>^F>`D5Y@1U>,R<)K5&C0'B/#<*&<* ;+!<, :*!;+%?/ :* 8)'9*+9+*8'+>-,E35S;/M7'@.(;*(;(-F2.K31N83S>1S>-Q:.T=.M9-H6/H50I6-I6-L8/TA*M9'H5'H4#H2!H1$B/$A.!A/&F3(H8%E4'D4&B2'C/(C3'A2(C4#B2%C4&C4)F7(E5'D4%A1#?/%D3#D3$F6#H7#J3&I6(K73R?1Q>,O<.V?,U?'U?,ZD/YD,R@-RB3XE-VA-WA2ZF.TC,K:,N>'N='S>*WB,[E/_I0aL.^K._K,`L*_K-_H'XD N;E5"C5"C6(H9'N='Q?/XF.[G([E&WF'UD!N=G6F5 E5'H7'K:(N<,UC+R@+Q?(N9.Q9-K4*G5&J8&R;.U@2[F4^L3`M0]J-[H/ZH/\I.^K-aK)]G*^G+^J(TA%N<(Q?)P>*J93K>2Q@-S?+R=)L;)I:'K9-O>-O>0O>*K:,I90O<4TA-O<'K6/P=4TB6UB4WC2UA1SB/P?3P@5TA0P=1M:1K;/I90J:+F7*E5+E5+E5-F5/I6/M:2S@.N;/P?1SC*M<-L=&F3(I51Q>2R@0PA3P?6S@5R=1P;.O:)K9'I8&I8"G2,Q=/S?/Q>8VC0O<(J6(J9$F5%E4-H54O=6TB:YF8VC.M:'F3/M:5UB'K7&P8+XA3WA*N9&I5-N=,J<,L;(K;(E5.L9.O<)G7*C5*I8,M<2TC1SB2TC+N9.P?.M<+J70L9'E1-L85T=(E4,G;*D60L84S:0I;,F72J;3I7);).=(3B0)7%+<)'?-(B0*A/*;*$7&$:(%=+$?,'E2)C3#;,"9*!:+!<+$@0-J;-J;.J:1L9'@/+D1&>*(A-+E3#?/#A0'F5*D4,F4)B08&8'5' 8)5'%9.- ,-/!2#5% 6'$8+ 4'4%#6&&=+*D2#;* 1"%<-&@0%B/&D1'D1(G5,G4*B4):.$5($8)'?+&8,(:*&8&,%%*+/"+)+4'7-"B3&G7)F44')((-!/"2#/# /$'#&(!",,&!""!!"! !$*+ )+ +(+ - -. / &'),'  !%& ,'3%/##3%(;(-)#*2!5#1#%"! !#1%#1%&   %###!#'"3"/D/7M6.:+&'9',", *A3&A12M<8TA8Q?/P=1UE3TC3S?/Q<=WF;TD5L=0F64J6/F05K84P=8ZE3UD5SB4O>0M@7VI4UF6YI2TD)H7-O>-O=-P<-P;3UC0TC/RA!@/!D0#J50[D0W?6WG.QA:aOBjT9bL/XA2UA.O1P=8ZG8ZF'?1/H:)F7D4/XG+QA)J6*G3%E3"I6#L7%M8)P;1WB-R<,L9,L<*K<-L:/O=0O@1QA9WG3O>1L<4S?*L7&E1*D2-B3.F42L:4O<1M:3N>4N?7R?5P=6WA3[E3[H1TC&K6,$@-.K71O=(G7*E3'B/#;+ 3!,!, )+%4"&6$'8#%8##7"(;&(<)(<))C/+H1-N6,N7*K9*F7'?2'@0)D2)G3+N81X?4]C1V>+I5)B3#>+&>,#<)#8&$8&*;-&8'(=*)B.&@- :*&3%%4%%9&&:''7((7)'7*(8S>7R>1L;,I:.H8.I67T=<[B7ZB,R=&F2%B/%@.+B/%=+$<*#>+"<)!;('A0(B1!<,&:),@.+@.*B//I40L72P9.N7*F3,E2.I3,O6/R93X@4[E1XC,U>*R<,M82P;6R=0M83S>7[E6]L8[K(K8(G5%G3#D1'B0$@/"A1%E5(G8&E7'E4&D4)E2)C3%?1&B3=-">.&B0'C1'D1%D1!B3%E4&C3"@0#B1#D1!G2$I4/O<1Q?/P=,O<,P<-VB+YE*XC-TC.P@(L=.UD/WC-VA/WA/RA-M<,N=,QA)O?)QA*R@0[E.\F+YE-\H-^J*[G'YG"XDO>C2A2F7&O>)XF'XD*YF,\G%ZD'TE$PA(RB&K<%I8%J8&J9(M<*R@,UC(Q?*Q?'K9+M6-J6,I:*J<*P;.UB.XG2_L3aN0^L-ZF,XH,\K)ZI+]J)[H*[H,YG)RA%K:%M<%L:+K1RA.R>*K8%C3)D6(I7.O=/P>-O<,M;-O=/P<2T@,O:+O;1UA3XC2UA.R>.T?,P?,K:2L=3P>4O?3N>3K<.F7-C6'@0+E5-I9/M;1R>0R?3VB4XD0T@0SC6XG+M)I9+N;-P=/O?/N>-K<0O>1T>2U@1U@)N:*K7(J6D0&K7$G3+K8/R?+P;(K:&H7&F5*F7/K85S@3S@2T@6UC,K8&I5.O.P>,M:*J9*J9+G6.M;)M<0N>1O<6VC/N=,F8.M90RA3UF/TC2UD/Q@,R?.R>1O<0L9'B.,G3*H4(F4*G8)C50L86T>/G8,D6/G9/E6.@04F26G50@.,?,&?-+C0.A0+?-+>-)@.(@.)D2)E2$@-!;+'>/!7(3&%=0*I7-K9.K;+H7-G5*E4&B-'B0&B3#A1"D3%G3'F6*H4*D2#=+9*!;,"=,!<-":.0$0"27(8(;,"?/%?."9(5&!6&(@/&A/!7'#1$#9,+F4!?,#D."@-(E3)G4%=-,!"/%/"&:+':+-?..<* *#& ,!% ")2&$>1$A/"=+1#+(*!.!1#4%"8+';/0%),#*#&)+'#! !$"##!#"&*,!2$0"/!. -*()*,' %+*&!""#&$-'2#.#$1$(5#+)'+/- . *'! %3'+%! &%%#%%'(!* / %6&7M:+8* $2&!*# -#&8+4K<1I95N<-F7(G8:\M:XI3O?8VA>[H;XE:RC5M;:O<9M8:O=8TB8ZF6[E7YC9WC:\H9\K5[I7\M=`O,L:&H9-P=1U@/Q<-O;-M:'H4"?-#D32ZF6aK8aJ:_L9`M6_J2[G2ZE-T?2UA)K9.P?3UD=`L;_H1S@4RA-L:)N; G3#F3,O90O<'K7*T>+YD*V?-T@/VB0T>/S=3WC/TA.K7/M=.N>-L=.O>1P=2Q?5Q>-H5%@,+F30K:6R>?\HA_K?[G,&;)(E.&K1+R<(Q:)V<(Q9"H2#C2'C-$A+%?+#;'5# 3#&7('9'+A.)B.(A."<,&5'$5%"5#$8%$5&$2$&1&&6)'>0/I6(D-,F/'A3(D1%C++D-/L7/R@3V?/S;5U>8WA4O=/I;-E8-H62M77U>2S?)L;'D0'B/'?,.E2.E3+C1'B-#>*#>+*D2-G5%?.)A-,G4)I4+P70S<,O64P:.O81N:4P:7V?.V<.T@.VE.XF+UD&O>'L<,T=7ZE:[G3VA6]F;fOAk[Gn]/QB*J9%D4%D3&?1$>0 >0 B4#D6%C5#F5'F5)E4(A1&A1">1">."?,"=)&A-$A- @+B2!A2$A0$?.<( =,B.$E2(G7-M<*J:(I9(K:(O>,XE)UD+QA.O?$I91WH/XC,U@(O;(M9.N>,M>+LB,NA+O?-P@1XB.WB.YD-XG,XE)UC$WEUBQ?"I:B2I6$UC&\H VB)[H._J"XA"J>E90XJ+O@-N<+P<'L;)R@)SB&R?&O=(Q?)I:+K7)I5,M>-N@/R>-UD-YE3bN3aM/^H.[F,ZK)ZL%YH,\M'WF#P>*VE*Q@)O?%L=&N>-O@'M=.R@1P='C1$?/(C4+J6/P;.O:-P:,Q;/T>.R?,Q=)N9/UA5\H.WA2UA*P=$J7&I8&C41K;9SC9TC2L<0F80D7.A3*A32L-UA+T?2YE5ZF1XC5YH4WF/P?5SC0QA-R>,P<0P@3PB+K<+L9,P9-T>/V@(N9%E1#D0!D/B.?,'H7*Q<)P<%I8$F4)F6+E6-J7/M:-O2T@/N;(N90R>3S>(I4-R='S:*N>(L<+N="G3-Q<0T>/TC6VE5TB6XE,M<0K=5U?2UA0TD0TE5WH1QB+U?-R>0O<.J6,F2+D0'E2.K8-K8*F33O=5PA3K9/F8.E71H:.B1;P=8M98K8/D0+D2/E31D3.E3/G5,C1'B/*D3(C1#@. ;+(?03%4&)@2(I4+L:*J7&C2*F7*D6(A/*D3&?1"<. =-$C1#H4)I5*F2$>- :+#=-#:*#<.6*"8+!3%&6%7(7';*;,(A.&;)7(&<-'A/!<*3$%1% 7($?.;&@+ ?+(E5)I2&>-, +"+"5($;+-D1.B.!. "% ,%#*4+#)"("1%%<-"<) 7#"5&"5'%5(,7+,8*'6))=,&A/)D1#;*4"!3# 0#$/*%#""!!%)+) )( +"." 1"!4%2#"7(1"/ 1",*(')+)%*-+)(%$") )).$0%'1$&0 +)&))% (#/! 0 "   "$"!#!$(*)&$&6)2F8*!$"("5'"7&:N<>O=>SBHcP@cM5\C9]D<]D;`F6_F(S,R;)I8'E5.Q@<`NBhR:`K8`KAkVEwdRr,QD$G5#C-$F0#B/$A0#?/"A2&E6#E6)H7(J;%F7&D5(D4&@.(@-$>+#=+%?-'>,&;'%<*%>(%@)!<) ;* ;-!;+$>/)D4*E6'E4*G7*J9,P@/WF)RA(M?(L>'N=3\I,VE,S='H4&A.+P;*N>-PA.QC-SC/WC2X@-W?-YD,U@,TC%P?&U?&VB"O> K:#N=%S?#T=$WC#WE%YH*ZI'UC)H9D41]K-[J+VE)QA%R?)T@+U@&P9&L7+N:+O9+O9)M7.R?-R?0WB/XB&[C+aI5cL2]J.^L*\I*ZH*XF+YH'SBJ9!N?%Q@&S@%Q=$R?&RA$TB*TC+O?!>/%>0)B4.I;4P@5RB1S?0V@.V@/VA.S?.S?.U?/WA,V?+Q>(I;'D5%>-(@-2I:6QA;TF,A4/C6.B3*@./J90N?/SD'M=(M=-P=0]E.XE0WF2XG.TC-SA1T?.T?/T?0N<4SB-P?)G6)F71P@6VE2VD+M=!B3#@0'A1#;+#?+%D1(O?,O@*K:+G70K8*F4/J91M:0O<3S@/RB+O@.W>4[C2W?&M4/X>*T;&U>*N:.O:(M7.ZD-[A/V@:`J3YB5XD1R?4SB1XC/WB/XC2WF5XG/O?.N?*O?/Q?1N:6N;/K50K;:TD4L=(A/;VC5Q?4O?4K<2I94J;2J;9UD:R@8O=2L:1J70J82J81L:-H6,G70H90G9+C5'C0&@.&?,7% :)(C2*J3)H1*I3*I4*H4+I6&G1*F2$?/#;.$=1%?3#D2%C3)D5'@2";.":/&=.&A.!<(!8*(9+*7'$1'/#5'!<,&?-(?-$>*(B0&@0%;.!2&+ 2%0"6& :+$A/(G3,G6%<.!0$')-"!7%+B/,?,(8' )""*!6*6),B5->2':& .+)6)(7');)-B02H64I90B3(;.)C5$G5)G7&<.$9*&9* 4%%. % $%"", -+- !),!2$4$!7)!3'-#7(1#0"4$0-,)(%%*!."-0$, *!#'1"&(/#%3,&4''1$!+ %"##*. 2!  !#"$& ("))<,$6''!  "" * 0$%@53SC7T@;R?;O>0F98M=3G82J;2L=0J;=QDB]I>ZG9WB8YA<^E9]C8cF:aI1T@+K:A0,Q<3]K@fP8_F8^F-N9-F6&F31U@5ZE'O90XA-T?,T? N78cN3YD0VB3\G3aJ3eO,^G1^H5]F3^E-]K.ZF2WA3WA-Q;D0(H7+M1VA0SC7XI:fT@iX:]P/QE+L?-P@)A*.I2.J5-K7,P;0R=2R:/K3/F1'<($7#"4#!2% 1$/!-* * )(-#0 #6$#6#22 0 !/!#5#"5#'8%&8)#8'$9'%8%':'+A-*G/)K3(K5/L8%@0#=-!<-"A.&A,#>)9$2,- 0##5'#3&"2#/#6$0;*1A00E3+D5,@3(9,':)):)(9'%3&$1#%1$(7%)=+/H60M9/K7/I5/K9-H7/G65O;4P<1M9)E3&A0&@1*F52O<0N;2H=0J<5Q?,J4'E/$@+!?+)G4,J92P>7UA9XA4M<)D.2P8A_K5UB/P;9TA:ZF;bL=eO>bN+L7+F5-K6;ZB?cI@bL7YD(G7(H6+L8(H4(C2)B2+K:6YGGlWBhR9aL>fP@taQq2YL!G4"G1$G3%B/%C0(D3#E4'F6%E6(H7(H8&F7&F7*H6&C1(B/&A/#>.$>.(@.'>,"8&%;)$<'%=*#;*"9*8'";*$?.#A0(G5'I6-L;,P?.TD-TD)N>*M>-SA1YG-VD,S?(J6)F3-O=/SC,QA.UD/YG/ZF3YC+XA)WA*T@)S?&S>%T@'UC)UD%Q@&SA*WB"UAQ>$WE"UC(XF'WC&I9F52gT,cO(YG(TC)VD)VD(R?&N:$J7*P<.S=,P;+P:,R>0VA.U@,UB(YC,^F7bK2\G/^J+YH)[I+]K)ZH!M<F5!J<$PA'YE%WD&VB'SB$RA*TC)M=%E6"A2)G71SC2TC3TD-R=2XC1\D0VA,Q=.Q>*N<,P>+O>)N:'E7#>0"<*$?--F9/J90K;)?1/D5(?-0H50O<3RB3SC#D4*K;*M:.W@+R>.T@/TC)M;)N:2VA.VA.S?4UB6SC*L;#C2#F5+R@.XE1XF&K9"A1&B2'A1$;,#>+(F3(L9-P=+J8.L8/L8,K7.M:2R=3UA/T?1WC-TB1\D6^F4[C5ZC4[C.U>%Q=%M9(O;'S=-\E L6.ZC5`J1ZD3YE2XC3WC2YD2ZE/WD0VD3UE.O=1PA,O>0Q@2N:6Q=9U@:UF?ZI5P@1K9;VD:XE2Q>6S?6R?5P=4P<3P=3O<4O=2N;0M:0N;3Q>2P<.L8.K81N=/K9-I7*K5)H5'C0:(&A1+H8$C/&D0%D/%D/(F2,I6+K6'F1&A1">/$@2$B4#A/#?-'B0(B1(B3(C3(C3(G3>):+#<-#7&"1%)3$"=,'A.'A/+D4-G6!:+'<,$5'- .!,3$"9**C3)D1&A1'<-!/#"''4$$<*,A./A0)6'('1& ;-6TD>ZL3M>2E45E56E8/>0+<,1D33M<6RA4P@0G9*A4&C6$B2%>/'<.#5'#6(%9,)5(*"#(%0$$.$#.#$/"#/"!-!+! ,!/! 5& 6'0"+ / !6' 5'3"3"2!1 0!+)!*! + 3%*<.3!2$/"(#+ 0"% *"0$+8.,7((1!,0%!% #' .! /"0 " !$!"#" %"##%"3#&!%#! '"6+3PA-K87Q=1F55H;+B4!5&2J:4R@6RAAYH>ZI5S@1Q=4V@;_G*J8&G40S?+TB*P<4[C9cH2YB3P>*N9)N:"F3,P=.R?,O<0WB(S>/YD%L7&K7'O:-U?5^J-S>9\H;_J4]F2_L6_L4XB6T?-J6*G4'M8.T?/WB+XB.[E:hR+UC1ZE.R@*M<2UC7\D:YB2S=:XD6SB:\J6[J5UC,P=3WC7T@4N;8T@9XF5R>9R>5M67K93L>:WEAaM9\H-R=5XE:aJ:^I7YF=^K3VB4XC$7"*>))F.+M8*Q>1XB.P9-L3-I0)@)(:)#4$"0$."+ ,(**)!+(2"%:%(>) 7!2 0 ." 2$!3$!2$!2$ 4%4%#9'#8&&<(-E1,K3/P8)O7/P<,H9#=-9(";)#9(!3"/ .)(&)(')"0!,7'0B02H8,G7*A3'=.+A,*?+':)$4$%2%'3&'9&.E18S?4P<0O:3Q;.I9/I91K;9TC7QA2L<+B4)A3*C6.J96UA7VA4L@4O??]J5U=+K4'D-(G3.M:*L8-P<2V?3W?8TA4R;8[A9_I4XE0U?6VA;_J=fP=iR;cL0U?,E7-G48V?>`G9]F0U?&E2'E2(F3*F2&@.'A2&E5*K95[E>dN*&E0&I4%I3,L;.O>)M=,P@+N>-O@.SA4[I0YG0TC.P>/N:0P?.R@,SC/YH.[H-[H/XF+ZG-[H(U>)R=*XB"O>*VE+UG%Q?'Q?'S?&UD!O?!N(T@*O?%TB&bN.iU&ZH&RA&SB'SC#M=$K;&M<)Q?+R$N=)RB!H8$J:+QA/XG.SB/TC.SA2YC3ZE.S?)M;'G7(E8)H:)H<*K6'E5#=-"<*$@/(E7)F4*E5*A2)A/*C.1L6+P<0R@1M>)D5.L:(J6,O9,N9-O<0P=*K7*K6,P<,T?-VA.Q=/N<(I5&B2&H7&P>-XF&M:$G6$D3+G6,F4'@.(D1,I6,M8.O:2Q<0Q/ZE2YD4ZF/TA1VB6]H5]I/WE2ZH5ZI0SB0Q@2VE2S@/J74P=>_J<\K>ZG1R?/U>/T>)I5%B2)E5+J:&B/"@-#B-)H2*J2/Q9,L7)F2#@."?/#B3$G6'B/$?**B0+E3+G5*G4,F7(F3"A, =-;+ ;(.!(3##>-'D0(C1*D46' 5&(:,. ,/" 2$ 4& 7('A0'B/&@1*=/". "%%2"#=++C/2J6)<-!1", 2%6('C40L<+G73M:8PA7M>3I:7N?0I78SB;[K3PA1I;,D8&A4 7)&8+)8,-!.!#6)'8(#0$'$"/#%4(-;.*9+&5'!."!,!$/$ 2$"5& 3$1",."1$$:+#:)":(#:($:($:($8(%5( -!, %1&&@. 9'10!*&- 1$ .!''", $6)+<*.:',3%")# *$.##,"**'" " %%! !!"$$#""!#% $#!'5&(F5:QBFXI/?3-@3'*=.2M;6R>6P<6PA6QB%E3.N;1U?7]F;^H8ZD6VC0P,N<4UD9XI+K;#B34ZC/XC'N:&I5&G3'M8-S=5YF)I5/L81U?6cJ7fQ3\H5XC;YD7Q>3L<*T>2\G2\G/XC-T@3ZE3YE.X@.\B-WB4XC<_E5T> <(6%.N=9YH2QA8VC8^I3]F9\F:WA=XAFaO:R?9L92F22F38L9=VGB]LBbK=_G4X@?bLAbN6XC7[E7\F0X>2[@-=(,A)(E.$H1)O++G/2S:3V;0U=4YD.P<'A1!9&4" 2$ 0 #0 #/ ** (!(!'!((#,!%2$,=/0E6/H8+E2+F4-G1+D.';($6%%4&'5(,>,3F37M;8P=5O;2L8,F6+E52I:8O@1J:(D4)=0)=0/G95P@:YE9[C7R>6T>;]D9YE1P>*G7*I5.O<-Q@)O:-S>3W@2S>8]GiS:cM.W@.J8,I54P<6U@3WB.U?(N7'I4%E2(E5&C3(C3'C4+J9+Q;0V@4ZE9[G4ZI*N?-PA4XC4T?(E5(D4)J6+P9+P8(K6&F3+L9/O>.O>-P?)O:(O9+K8'F5&B3'D4+F6(F3*@1+A1,B3-A2,@/,@/+C0$>+$@,&E0+K6(I4,I8.N=-N=,N=+L=.O@1WC5[H2XF2WF2UD0RA/RB,R@,VC)XE)XD+XG.ZG*\H+\H&R@)S@+XC(TD)TD'RC'PA'Q@$O;H9$I:$F7!B1(L;4ZH2WG+WF+aN-bP)ZH)SB'WD&QA$MA'O?&R@&Q?,VA/[F/\G.\D-YB,U>*QB&L;+S?0]G1`J6dO3bQ0cQ+aN&XG&O?%I9!G6%UD*cP!ZGQ?%L<$K;%L<$O>%Q@(UD(SC*VE&P>'M;)O=,R@+Q?(K;%E5+G8&B6'B9*F;'I4)E6&?1&@/$A/(F8'E5)C3(B2)A/(D.0N4-R>+M;(G6)H7,K9+J7/O<3P=0O:0O:%D.(F3+K8*Q'P>$K:'G5)O=1VC2TA8YE/P=/R>9_M7^L0XF5]K8^J-S>.R@5ZH/Q>*E27VB<`L=^M7VE7SD;WD=ZH;XE-+E10N:3S>4VA,V@0VA,O;-N:0Q@,L;&B/%A.%D/)H3+L4.P8+L7"@,$B/9*&F6&I9)D0&@,,F2+F2-J6.N90G8.G5&A,":, 7("8&!2#1"#:+&@-&@.'B/)B2#9)"7('9(1 -/"3%7'"=-$A/&E1'A1,@0%2$'&*!6()@0-H50J7(@-';+(6* 0#0!5%/#<*-L<0O?.N;6VD@\M/K:2L?3O@3L>1G91C61&(:-)8+(4( -!/##7)+;+*8(&0$ +(5(+:+-?/%5'"1$ ."$3&%5(#8&"4$!3%,,1$"7)%=,"=*#>*#<)#9(%=+#8( 2% 1$!3%):-%=*3#3%2%."%2& 3&+:-%"$#."";+'=*+>++:)&2%("1""5' /$'&0 /#*"& % !!#)%"  !#  !&#-!#+ '#$# &8+-E6- $)1((+=-4J8.A/+C5*C5*D6'D38XF?bN:YG:ZH>_L5VB3SA7WF1SE7YI9aLEr\6`K7[E/R<.L:4PA,H93#"D2+P:,U>+R=+M9*J8(M;-U?3ZF-P<*J6(P91cJ;kV8gP8`J/R=#@.:)(U?5dN5`K4]G1VB/P<"E1,U;/]B0\E3[D6Z@/R("9&%8($6(#4$$3$%3##3!"4"$6%&;,%<+%@,)G0,N4/S91T=1U?0T@*H5#<*!5!"0#"4$!6$#7%"1# + *'&!' '$,!%1%%4((<.,D1*D2/J60J4.H3,B/(<*&:'*=,0E35K98M;8N;3I71F3(A.(?,1F25K:-C3%=,+=--A22I;7RB4SA1R>4Q<5T?8XD9[H3TC-L<,K:1SC/UC)N=(K7,M99WA>aF>eH3V@,J8-I5+I7.Q=5ZF7^J6\H.T@.M:-I6/J83O<1T>.T>(M4%F2&B2%@1'B2*F6,G7,K:+P;1WA5YD9YG4VB,N=5YG6^D5\D'K9+K:.Q;,T:*T:(O7+N:/T@/R@.P?/Q@/V@+R=+M8(G5(C3)D4(E2'E1)B/+D2-E7,E6)B3,E40J9)D3)D3(E3-J8+I8+I61O=0O?/M3ZJ4`N.ZI'VD,[I-\J&SC)ZF'TC'OC'P@*VC'YA.ZE-\F-^I0aI/\E/YB+RA)K;0UA1_J4hT7hU1dR._M,ZI'UD%P?"M;I6%TA)]KRBL;$J:A2%I9*UD*XG'WE$UC&S@!K:D3!F5(M<%J9%E6$C4(D7(D7(F:(H;(L8+H:(@2&>-+F4+J;.J;.H;'@2"=-%A-+K30R<&J7$J9,Q?-P=1P<.O?/O>1P<-I5(B/*B1)A2+L<1XC,N;+L9,O;.N>'F6&C3(F5%?/'B1+M8,O:.P;2Q?2Q>,L8-N8/Q:3T?0S=1VA5\F/RB1XD/VA1XB.WA+T>)N=&J8.P?/Q@,N=+N=,L=&D5(K:'P>"M:'K9+O>4VE6UD:[J(M8*Q<9_M2YG-VD0ZF2ZE+Q<1YD6_I/S?3P=7TA4XC6YI6XG:WG0U@1UA+G4+F3)H3)H3.O;.O<*K5'E2">+#A-'E4)G7(E4'C1*D2+G3,L7,L80H91H6/D1';-&8*'9((=+*@.)@.$:("<*#=+$<)(>,(:)"4#/ 0!/"1"8("=-"?.(G3+D6/B3-9,(2%"-. 4'$<+*D2(C/%>,(@0.@2'6(-1,?.*@.$B2(G5+K71O<2L;,D4(A20L>4QA,B4->0):,-?1'6)#0#!.!/" 6'*?,);+'7('7+);,*>-)8)$3&$5(&7*$6'#5%!8#!4# 1#) 3%2$"9+&?.#?+#?)$>*!8*#:(1#3%4& 6&$9'"5&0#3'2'0$"4' 6#!"-&5'!9+#:'%:&/ *-(7&0#)#.4%*%&''#! #$!!'#*!' %  !(!0%." - ()%2&# !, !3'1B6$3),!!4(!8*bN:^I8\J8YH8XI3UD2ZG>jV4]G1Q=1O:,G56) :+-M:,P9(N78aK(N;2\E3_J3]H0WB7aK4eK*YC.YC$E6)O8,U:)P;,S>7]F1X@5R?:*&M<1XD/J5-I80O>/O< :'!5#7N<9T@8L:8H75E81F4.G5.I8+E34P:<\D7ZC5[D5QB6UC?cQ1WA1VD.SC.J1)G.(D,'C,%@+)E.-G0*D-%?)":'$;&$9'#6% 2! 1!2#/ !/ 0%7")='*?(&=,(A-%?+ 8%'<)'9((6&+8('5$%3!#5"%9$'<,(@/&A.%E-'J0*O3.O7+N7+M:*H6)B/%9''6&$9'#>- <)2$#.#-, * )!+#*'1&&3'!4'&=+(B.(C0/G5+C0*C/2I6.E2/E2.I76P=6N;1I73H62H50H3)>*2E25H60C2'=+,?-1E54L<8RD7UE/Q>2MA/L?/Q@3VB2T>-M:-M=4VF2VG*L=)H8.J80L7;]B<`E.N8*D2.C0.K7+J7+N:0S?,N:*M9$F3(F3,F4+G4,L8(M7(G/'C0%<-(=/)?0)B3-F6-J9-R<1V@3U@7UB/R=#G40[B1`D/`D'S=-N=2WA0\A+Y<)R92VA3\G0UB-P?.P?2XC1Y@/Q<.L8,G4)D3'C0'E0(C,(C1*D6)F7(E6)F8-K:)E5)E5,G70K;/J:/L98UA9TC1P?.M<2RB1VA3XD0UA0UD,R@+P@+SC+VD(YC([D$SA)UE*\F&^G%ZE!P>+UE*UE&RB'PB&NB,TE,UD(Q=#I9'J9+K8*J:/WG3_Q/cQ-^L&TC'UD(ZH"XE'[F&UA"K=-VG/\H+\E2_J,\F,_H/bJ/\E-XA,SA0Q?3VB0bN3jX4iX0eS$UC(SA$M<L:P>"Q<"R?!QA!O?#M=%J:)I8)L<0ZI'VE#VD SA&Q?#J:#H8&J;$I9D4%D7'D6+G9+J:&H9%I:)M<+H:+B4)A0.J63SC2N@.I=)C5"=.'E1)K3.M9'K7&R>)VB+P<5S?.QC/P@/M<)E2#<+)>/'<+-I:5YE-P*Q?$F6,H8/H8'C3*G5)N91WA/V?1UA1S>1Q@2V?0Q=.N9+N:-Q<4ZH*N=-Q@-R?/VA0VA(N<D/"F2'G5*M9+N;*P<(O>&K9)N='R=!P:#Q;-QB3WG3UD3VEJ4*YC4ZI(O=+UD.ZE1ZE+S>0ZE5_J3VB7SA7S@/Q?/SB1UD5UE8VC:XE5TA6R>4P<3P<5P=3L9.E11C1/C2*C1#?,(I6/Q>1L=.K<)L;(P=*VB#S>%I9&G6)J9/R=3W@.U>,H0,H2!@+'F1*J7+N:,J7-K7.K8+F4*F3,I6#D3!@/">.(F3)G5,L8+H8/J7.F3-B3-A30C2-F4)A/"8&!7%$:)"8'#;%.D/,>-/'7*1$.!2$ 5%4$4$&?.)A30B41?13>.-;+0 2%!7'"<+$?+)D1)C1*B3!6&!3"%7&,@.&;(#9+$=,(B.1J6=QA./C12E5,?0 0"#1#%3%$5&%:*'B,(B/,D4$<,8(9')6)'4)(9,$6(#7'"7%&<'!4!$1$$4&$6) 7($<-'A/%A+'E-%?,&>.$:(3$2%2#8&4 $0#*-%-%.#3&7(".! )0$2$,/"#4$$5#(+,!,)% (6%+#&(*")! !!!$&&!%!'$!",0". *" +& ' "5,'<1!-$".'#2(#7**$=.6SEDfS:aL-J:8R@.F5+B4,G64V?/W;1Y@8cK)R=)R8.K6>.(S@1[E?[D%?/1M<7N?3D6*<+1H67S=9P=8I;6H:2H:/L:/J7-G43N94Q=-N:,P=9Q>>XC6W@/O7,K74Q@1G3-B/->,,<)(9,':*+A.)?+(=+(;)&;#$8#%6#%3#!.!/ 1 0"4#!4""7%'=,#<(%>)&='(>''<&)<&%9"(9$'7$#5$#7'$;,*>,*B0'E/(H0*G3/G6,G.+H0+H3,G5'A2"8+%7($:*$@,&@,$9("1$1 !0,!+$/""0$#3%&5'%3%&6();-)>.)>,+A0)B0.J5/J70L72K;3M=4K02C50H83O?2SB2SB0K-#>,%?-&B1)E5)G6)G6/L<,K92L8,M7,S:0]E/]F,XE+R@3[D1]A1]@.Y>2[D/_H.YD*Q;-T=3\E0\C0T@-Q;)L4'I1)H2,I5(C6+D5,E7-F8*E5+F6,F8)C5,E7*C5/J8.L8-M80R=/V>.U=+M9-K:0T?.TB-VD,VD-TA-S=+UA*XE)YE'XD$UB%UC,YE)WA*W@)XC'UB(UE+XC&SA*UE+VG*VF+WF'UE'PA*QB+RC.WH2^O+`O$XD#R> P<%YE$[J+^L'VD"N<-[G*\H,dM0_O*]I'[G-`I.ZD/U?3XD/WC+WE0bO5lZ.fU(]J"P@$M> G8F5!N: N?"N>"N?#M=%Q@%P?*Q;+YC,]G,YG#M;"Q>&YB'WB)UC*QA$H8B0(G8*J:+L9*K7&J4(M5'L9+I:%?1)C40L<4TC.O>.J;*D5-H8,H8,I8-M:%K8%P='R@%K54S=*R>-M=2L?+?3&:.(@2*D4+K;1UE-T?.S?3U@/Q<$G5&J:+O=*M7-M7+S@/WD,WB0XC0TC2PA8VC*I6+O9+O9,M<,N=+E7.N<+M:,P;+L:'C5$C0%D2%I5'L9*P;*Q<*R='L<$I9,RB&M=%P<+R=0ZE.YC,S>"H30YD0S>#G30UC2ZH-TD.SC2YH3XG1QA1N@2L>1N?/Q@5UD8VC7UC-K<-K<-QA%K<(J:%F7$F5%H7+P<,R>%B4'E6(D4)G5,M9.R;.Q=)K8,O;)L8*L8(L7">."9)#9*(B3*H9*K:,H8,G8.J90K8/K52L5/F6&>- 8&#:+$8+"3'*<*0B0,=/ 1$%8,!5)"4&/!. ),!#2&';.-D4/D21F5);)/!/"2$!:,&B1+G9*H5-C1%;*#:(%9()<+,@/+F32M:9UAPlXNkVGgOAcM>_K4R?,J71L93O91C0&4&*4(-:(/<+/>0*B/)B1)C48*";- 8(&8'*;-'6)+<.%:)'?,"7&!6'&9,':.'9,#4%!:*$B-D*!C/!A.#@+%8(0"-- 7)9)!-" *" -%/%3$9(:'4".". )), 0"/"%&"$")#+%$+4%*"% .!*  !"" !!#-"/#+!(#!%)! !!#*%/#&0$'5(3=23;/(%(=0&3'4%-P@=dS<]N]J7VC-J90K:6M?3J;3K<0K:-M9,S<3UC9bL1_E2^D5bK0_K5\D3]D4cI1`FApURf6\H/O<*E32K<'D5,N=CjQ5[E6[FBgS@eS3XH'G83UE/SB)K;(J7+I7)M8%L6(N9.S?2O?$=,"4'.E8-N:0O;1I75F7:R@6K91E35L91P<%I4/K;/K:/M;.K;2O?.M;7I6(C/#C./P;5XC2YC,E,,A**>%+;$*=,*>+)@**A+'>(%9'&;$'<&$7$%6#"2!#2!0! 0!/!2"!3# 5$6$8%";'%=(&?*#<%&9%'7%&6%#5$%9*'=.+>-)B/-J3(I1+H4,H5.G0)D-#?*%@.!:*5'#7''>+)B."<($9'$5&!3"1 "0! . !/!!1"%3%&4&*6)'7)-?1%:*$8*,A2*A0*B10H7-G4/D6/E6-D42H98N;5N7/H6)@0(<-*?0,B2/G43D61E6.H8,I93RA2Q@5O?3M=1K<3O;4P=-J6,M83S?.N;+K9.M=2RA-N;*K8(F4%?-$;*(:*(B2)D5'D5*E5%@0#<-"<*#;)+B0)B0(A0%@/(B2(B2&@/'A/%?-"<*#@,'C/&D0'D1(G3'E1)E2'G1*Q9,V?1]G/\H-VD.W@2]B2\@2ZB5\F0^G.[E0XB3]H5bK0^H0XD,S>-N8-N7&G5'K8*H9,I:-H:+H7)F5(G6(G5(E5*F7*F7+H7,J8+K8-O:-R;,Q=-O<.N=)N9+TA-YF*XE,WC-V@)U@*WB)WD%UB#Q>&RA+WE$P>'T>(U?'S@)TC)XB'SB,XG,ZJ)XG(WD(YF(XE.\I+XF(WE._K*^M'WD&R?)TB,YG#UE)_L(\J&UC+[G.`L/eQ-\J*[I([G,^H,YC/WB2YE,UA)VC.]K-aO)^M"Q>F6%J<#I:H6"OL;K;#O=-VF,VE0ZE/_I0aJ-ZH!L9-ZG(_G.bL1_M+TC&K;&J8(L:,O=1R>)J7$D0#D/'I8&D5%?1)C5.L;4XC1UD*N<1RA.N=,M=+N=)M8+O<%H7"D3)I50O:,P;-N93M>/G8'A2)F51N>-O>1VD*S>.U?2WB+RA)R@!J9+TA.VA/V@-TC,UB(U>2\C3YC1P=6R?,K80R>,M;$D6'E71K-WB2ZD*M:A-'M8#B/%H72WF2WE.RA-RB0TE.QA'F70P@.P>0R?,O?/SB5WF2UA7XC8WB9R@0J;9UD:WA3P:1K<4I7)@/)A2(E6+K:,O<,U=+R<+N9&J5"G4"K6(J:&G6%H7%I8,P?,O>)G8.J;/J;+H5/Q=1WB.R;/S<.S;)N7.P:%G3%@0%:+"7(*C4)H7(H7+I6*H7*J92N=.G4.E2.D4(>.$>+&?-$<+%:+/D10D2.A/&9)#8*$;-#6'+('-#5'&9,,@12H6.D1$8&!1!"3& 4%7&$@.(E2*G3'=/"7("8(":'-E35M;=WC=WC8UANqYFnU>jP:\E7VB/M:1K94M;/G2.A/);-+;,0B.6L78M<8S@2M<'B4+D7(@1'<.)>-*=/)<.(9+)=+(>+%;(&<*+?2&:-!2%#1%"<*'C.&G1$B/:)#=(!2# 0#)*$5'$9)".!*!-", 3% 8%0#'$#"'+)%#%+#."+(-!0"*#+ &!*'" " !"#+!&" "#( $% '"  #"$(,$' #,$"#"&"'FcT;^N?`N@[J9UB?\HCcQ9XE3R>4T?7U@9VA1M90N74W?8^D<[J5[F,V=0Y@4^H2`L5[E4\D7eM"R8Y‰n;lP9`L1R?-G5&?.$@06TD9aK4YD-Q?.Q@0SBB2<+3VEGjY/Q@"D0)G4&E3'H5-N<4QA%=.!4%,!*B4-L81O6SA5J7*H3.Q;4U@2V@3ZD'>%(>'':#,>&*=(,B,.F.*C+*A*'>((='+@**?),?-%6$#3!.! /!!/!"/"!2$!2$!4"!5$"7%#:'(A-"=($6%"4"$4#2$$7)$:*)=*(A-,G3,K5+I4,G4,H1&B- <'";*#=+";,%=)&?+%?*&<)#7$%8%#6%#4& 1#-0"!. &3%*8+1@20C4/A2*/-@2/F50I56M>4M=/J:-J:0N>5P@7RB7QA4P@6T@3P=.L9+L7,N8.R<.Q=+O?/RC,M=)G8&A2!8+#6(&:+(A/'B0%B/%?-%>,#9(%;+&=*)>,,B0)B0*C/*D4+E4)C1(C0'B/%A,%A.(D1(D1(D1)F3&F3(F2*J6/T>,V?0\F3`M*YB&S=)T;4\C2YD1XD+[C/]E0[F0\F7eQ3fQ/\K,R@,L8.K8)L:$M;'J:+J

,K:)J:(M9)O8(L7+J8+J;(H8)J;)I8,N<+O:-P<+N>*L;)Q?.YG-ZG,ZG,YF-YF-XC(T@$Q?$Q>%N=#J:*SD'Q@)SA+TA(Q>/VA+WD)XE+ZJ,[J+[I'XD'UB)XE/_L,]I)ZF([G,[K+WF/WD4ZH1YG,VF(_M-dQ%XD*]I)]I)^J,YH-ZI,ZH-ZH.\H/[F4`K/ZG,YF+YH(VF$SC G6A2!E7(L>%M="N;!O<#Q>&TA*XE/[F0\G3aN.aM-^J*VC#Q>2dO2kR.cM0]L$P>%N<)Q?/VA/VA,R=$F5#A0!>.#C2"@1#>0)F6*L84YC0UD+P>-R@+N=(L;'K:,T>.N=)D4(D2&C.+L70P;2P<5R?5R?-P;-S=/R@0TC/TC,UB,TA1YG,VD)SA!K8-WE.VB+S=*QA'Q=&S=2\B2YA3S<1M:1M:5TA0O?(E8,H<5Q?2P>+J7'G4&F5'G6-L9"A/!C0'J6)P;&N:&P8'L8+K:)G7&B3,H9)O=-UB'L:'C3$>."A0&B2.N>2TC/TC/RA3TD1OB.L?,K:1TB-T?'Q;,QA,Q@/TC2WB5ZE8]E7SB1M?7TC6WB/Q:1P@3M?,I:)I:'K:%J8+P<*U=)Q:,M9*J64 D0*L9&J6&J9&J9,P@/RB1N>/L<2O?+I81T?.T@.R;-Q;(I5(H5(H6=.#;-$9*'=.)F5)K:)L9(N8)L:)I8,I91I91D3+@1+C/)C0'D,'B-(C0.I51K6-B0!7$$;(%>+!3$1#4#5#(=*#7%#5'#9'1G4-G3(=+#7%%6& 8&!;(#>,&@.(+(<+&:-*?09R0%>+)A/,B0-?/.A./C0,C-+A/)?-#6(!0%"0$6%$?)$@,";+4%2 4%#6(2#!3$'7)#2$!. "/!*-2#('  $',(&, *dN3YC6^G4aN;bM5^H-WB5cHHx]6dJ3[D/R>0L94O=/I8,O:*J7&D1=-#D52RA6SD5N>,A1 6*&?0?]JGcO'?+5I69O:;Q<:S=05I:7K<3H8.B61C62C61C6,?2)@0.G3/E4-A42F96O>:XA8P<0D21E52E70F44L72M=5QA1O?/L<-J:/K;.O>1Q@2SB1TA1T@.S>2S@1V?3W@/T@-Q@-PB+L='B5%>/#8)#9)&;-&>,)C2'A/#=+&?-'=+'<-&=+%>,*C0+E0)C.,H5,H5.I6+G4)F1(E0%D0(E2*F2)E2$D1&I5(I9+O<.U?-YB-ZE,ZG'V?'T>'Q;,S>0WC.VD(W@/\E0[F-XC2`M1dP+XF*P?,L9,K8&J:"M;$J9%I7-N>,N<*O:)O:)R9+Q;,O=,M>,L='L;,N=(J:)K:,N>+Q>,S='Q?*WD*XE.\I.\I+YG*V@*VB$R?)R@&N=#H8(M>,SC)SB)P@)O<.Q=$Q?%SA(ZI,^M'YF%T@*P?.XF4aN0aM,[H,ZF1^N2^K4]K:aO4_M4^N'_K/eP+`L,^J+[H+[J)WC+XF/YJ%Q@-ZH0_I/^H0^I,YF)UD!K;#L=#G6A1#F8*O@(Q@&S@$P>'WC+]I0cL,\G1`J.aM-aM(ZF)VC,\H4lU-iP+aK*XF"N=&O=0WF.YD/WC-Q@%G6!B1;+#C2&G5%E5)I8-Q=0V@3SB,M5WD1WB.V>-R@,O@5ZH(N<(Q?1\J/UF)N>-R@2VE/RB&I8)P@*T@&R;*T;2X@-M6/K:1O<0P=/O>,K=.J>6UC7UA.N='G6(J9)K:)L8#C0#C0&I5'N9&P<$O:)P<)K7-L8,H8+E8+P>'L;%E4'?0 7(5%"=-+J9.O?0RA/Q@1SB3UG0RC0RA1TC&O9(S<,SC0XG6]L4\F8_I8_I3UC7VH;\K3S?-N8-N?.NA(K<(N>(P>'N;.T@/TA-N>3N?#<.3%(E7'L9)N:(L;+O>0RB/PA0Q=2Q>2P?-M<.O?(L:-P<*K9(G7'F7#?3 :/6) 5'$<,(I7*O<+P=(N9(M;!D3,I:1I9-B0.E50J6+H1-I2'E..I44P<1K78$#8&"9'7&!3%0"1 !7%8% 9&2$$9)*C/+D0*A.';*'9(#7%%;)(B08&"9(+@3*>0'<-!:+*F5"D1DfSGgT:VB*D1/J6/L4+G3/J7/F6-B2-@/-A.'<+#8*-G7A]GGeMA_J5O@)F6+I8*D4)B2(=.&?/(B/+@/1E12C15C2.C-.A,'=*&8)$5)"0%4#&?)$;'1#0# 1 2$$<-$>/'>/&<-):,+6)!. *. ,%$!!%').-*%0!6& 4'2%- +- - #7('8*#6&5#!2$( '"$ ""( *($%('& (() # ! "&(%/#", +).,+ $"&+!,!)+#':01N@2TC*J66R?4M;7R?8VD6YD7[E5YC6XD;^LBfS?aM7[G2TB3SB9^JAfPAaM3YE2]I9`K7^H4[E1XB,U<.W>7]H2XA4VB7UB2O;4N<*M:3UC/Q@)I8$D3!A0,G8,L;-P;-P;.N;*I5"G7#H7/TC2TB6WD3Q?,G9&B2?]J0M81K7@VCC\F?XBA[E;XA7YB5W?3YD5VA.K6;WC5Q>/K70S>0U?/S=7TA+L9&O:,?,'9'':'*<),C*-D-,E0/I2,F0-E//A,-D-+F/(D-&<&$7"#2!"0#2!&9')=+$<)%6%$6$&;(&;&(>)'>(,>/%8&%7&$8$(<')>')>()@-*B1+G4.M9-O7+J7)G4-I6)F2'F1)J4+J1)E-,@,(;(';%'=%%6'#6'$6'':*#4#&4#$2$(7),@25K=6O?1J:*B4)1,=/)>/*B2,J40K90E93J<8R@=\E;XB5N;2J83G5/E31H4.H72M>3SB0P>)I8$C2%E4(H8-L<.O;)L8-P<.O@4VC6ZD5YB1S@&G7"@0!:+#8()<,%>+%A-'A/%@.&C/#=+$=,)@.'>/&A0%A/%C.'E.*G0)I6)I6*J6+M7+L7*J6%J4)J5*H3)G2'K5(N8%J:'O<*R>*W@)YC#VA#R=%P;'N;)P=)R@*UB&T?*S@0WC)P;+T@0\H/UE*O<+L9(I6#G6'O=&K9%I8-O?-P<'L8&L7%P7*P:/Q@,N<.O?.R?,O:*M:.P?/R>.U@,U>)TD+XF*XE)WD,ZG/\L1_I-ZF)VC+VD)O>$I9&K;(O>&N?"M=&L<)M<(Q?)UD*YI'XF)WF&R<*M=+UC1`N0cP+]J.\J0^N3`N6cQ4bO1aO1bQ-aN/cO+[H-[I*SC.WF*XD2]K7^Q>0+XF*]F(\E-^I-[H*QA!E6%F9&K;'M>$L=$N?&SA'TA%P?'UC-bN/fR0gQ/fO,_M'[I'XF+YE/bO*gQ.kQ"U@*WE)QA(O?.VD+UD*RA*Q>&I8!C1!C1$H1)N:-P?,O>,O=-Q>2O-V@/YC/YD*T?,S@-N=+I8/K74Q<3T@1R@/R?.S@,Q<+S;+R?+O>6XGC4&M=-YG+PB,PA2TC0R@0RA+N=.VD4]J,XA*S;/U?'E1*H90P>.Q>1VA2UC0R@0U>1T?/P?*K<*N>'L;$H7$E4&E5%H7%K:#O=#R@*VC&O:2WB-R<)M:1SB#D3#?.(=.4%8(&A3.N=1TC'L;/SB3WC6\K4YH5ZH+P;%N8*U?1YE6^K5]H.WB8`M4[G/XG6\M6YH0R>+L8'G8)M?)PA)TB)TA)O>.PA-P>/M=0K<+C5)C6.I;+N=,O?*N=*M<,N=.P?/U?1WB1R>/N>,J;(G7)K;'G7&F6)E6#?1#>0"9, 7)$@/'L:(S>+U?*P>&J9#E6(G8+F5.G4-H50K8/M7+I3,G4)C1/M8-I6$<*0 1"0#/!/ ..1!3#3$":'*D0-F1.C0';():)':)(=-%<,3%%;-,C3.D4&:, 6(%?0%E67\L:[J-J8)D3-H60K7+E2'?/+B3,B31H83H6-C1%9.0H:@[HE^M:SC,B5":,'C/,F45$"6'"7'#:'&=),?+DS@?K:7E33C2)=**>,(<- 1$#:()<(2- '*,3%!=,#>.%=-#6( ,),"1##"')**+.!. . ,+2!4"0 ,+ )+3%$<,,@-(;)!6#!6# . +!)$!+*9,,<-!. &-"!+ $'&*,+)! " !"$*%0$*'(!2 +) *"( ! '+ , - "3)/F9?ZL4O@)@0.@02D82H92N>=]JAcO<_J?ZL>\M>`P;aO:`M7\K8_J;aN:^KCaP:]I1[E7`I,N;-K82P<(G3%C0(H4$E1!B.)E4'E1+J71U@.O9/O:%N9/XC+S=.U@+S>3ZE8[I;]I6UA5T?4P>A[ID`K@[HC]I;XD2O;-L7)L9,J70K9=WE2P=2R>3[D.U=+K8,F4+I9+Q@4H0/B+/B+,C*-C+*C+/H42L:2J60H32F00H1,H1,G1(A)#8!(7"&6!%7"$9#'@*(E.-D2(B-&B,)D,(D,#@'%9(%8&(;')=(+?'*@&*>)+A/'>-)D2+K7,M6%G5*J81N<.M8&H2&I1.O40K32F3+<(&;$(?%)9+%6(%8*+>-'7'*7'+:+%7)+@1.G71L;/H9(B3'=.+=/,>/'=,*C2-Q88VD7PC6MA^F=^G7T@/H53I7/D2-C/*E4*G7-L;,O>+L;%E5%>0&A0'A1%A/#A.)E3'I<*K:1S?7YB1P<&C2!?,%=+&:&&;'#@)$E,$A-'B/$A. <)!<*(?-)E5&C1(G5'I4&H0*J2&K7)M:&L6+P:+P:(O7%K6&H3+J5'H3$I4&N8%O>%O=%P<%S=#U> U>$Q;$N7)O=)O=)QA&SB&P?*Q?(L<(M8(M8/V@'J8%I5(O8(M7&J6*L;#I7(K;.Q>3UA+O;%K6'O9(O9,O>-O>0Q?1UA,P9/T>0Q>.R>/V@+W=+VF0YG-UD%R?)UC/\K-\H)ZE*WE0]J-TC"F6#G3#H8"L="M> I:$I9$J:'RA*XI*YG*WF+VB-RB+VF,_O+bP)_M+\K/^N2aN2dP1fS-eQ-dR2dO1aM+XE+TC'M=2UF.]G1[J.SG G:%R@$XA&]G0cN'TA"H8'H9-K>)RA.WH(TD%RB%UC%VA(Q@#RA)`M1kV+iS,fP0bQ-_M-]K.\I%\G!dL,gN$YD+WF+QA'N=)P>*RC,SC*O?&L:$H4%J5*R81YB/T@-Q@*L:+L;0L9.P<+U@,ZD([D([C)UA&P=)Q?,Q@0P<7S>/SA+N>'M;'K:'M7.S=-R?0SB1RA A3%K;)SC'OB-SD1TE0UA/SC0VE3\J7`L,WB+T>)M<$B2(G8.Q?+Q;+R<0V@/U?(P7,S>0SA*N>-QB#L:$H7'H7+K:)L;"I7#O= TC)ZF+YB-Y@.YB+U?1P@(E4&?/+=.%:,$=.!?0+K<6ZH,P>2XD7\H4_J8bM6]H/TA-RA0VD5\F7^H/U@.TB=cQ4[J/\J3\M5YI0T>,K8(G:'N>)TC(UB*WD,QB0QC-T?0S>3R>0N;,L9*M;'L;*N>(M<,M<)L8-P>,V?0VA/Q>3O@+H9'D6&H4$D0!A."@,$A-<(!:.4%=-G5&V?*W@&K:C5!E6$D4,I7/I6/L80N90N;/N9+E5#;-"@+&?, 4$- , -". -. . ."2%8($>+$?,-G0/D0,?,*:*+>.(<.%:-!4'&9,)B0,B0%8*#7*#;.#?3*L=-M>'F7&F6)L;&K:0G5$;+(?0+D4/I72K9/D3,A4.G:.E50G65E:)+A3=UD8Q>1 !6' 3$%8&,@+BU@XfSDM>?H;8E4.A.-A-$9)4$$8'$8$.&%%% /!5& :+!8*#6'&',)"*0" 2$/-1!, ,+.!0 "1!".**,!+$8+'B20F4(:%&:% 6# 4$'9+*&!", *?0'9*.")#$%&*3"2"$2$"(""#+ "* %%" !(*#"%(""$&%&#"!$& )&8+)>0-A3%6)0;/9=1,;0 2&1I<@^N:[H:YF=RD3O<6P@3K=2W?:aK2[D0YC3XD/Q>-I5:& @++M7,Q;#I1(E1,I6,L83T?4U@&G3-R9@fL7]G5[E*R<+U@6^G1X@&K2,L70M<0L>9WD?\I:XF@[I1L97Q>4UD,H82K<7QB6SB;^L))=)-@-+F-,D/*@-*D0.I4/N6.N7/O9/P;+J7(F1(E/,G./K7,I2'C+&=&+=-)A,+>+-?-)@.)A,-C,&?)$:'&;,';/(?0+E51F3+A/-C3,B4*A5*B60O:8VE9XH5TC8YC=]E<\N6SE4N?2I70C1.A1+?1(@0+F7.L;2P@/L<(D0&@+(A,'?)!9&!:*!@0%A10L<.O<'L6&E/ 9*!8)%6'$7''>.$=/'@1'C3%C0!?,%@-%@.&F2(H5*J7*J7*J6(I6(M7&M7'L6,J8,L:)N:)K9'I9*K;)G:)G9*I<)N<'O=$Q?!S?"R>"R?*N='O='M;*M<,O=,Q?(N9.T@)P;&O=&O>+N=*L5'J3'K5&N8&N9&N;!K9%N;1WE0T@2UA,N;,R<*O;.M<-N;/S=/V=1S>4SB3UE2UD2WD2YC1VE2VF0UB.S>-TA1[I2YD)T?+XB1^K-WE%M:$F1&I8(N@%N?"L9#M6&O>'R?1^J+XE.\I+[G)YF$YF*aN._O)XJ&WJ&WG+]L)\K,aP*cQ)fT+jO&`G)XA)S>(N:/UA/^H0YH1UI,QC&TA$[C)aK+\I'QA$H;+OA'O?)\I,\H)VB$O<(V@+[E,WI"O?(^I-iT'aM*^M.gS-cN+`I*^F#[G'aO%aN)]K/[I/VD,L=,I>'SA,UD-RB"H6$K9&Q?&W?/YC/T@/SB+P@*L>%I9*L:.T?+ZC)YE*XE*QA)M=-P?0P<4UA8XD1U?,O9.L;&G5*K:/UA3UA1R>3P@)F5&F5-WG-RA/TB1UD.S?.U?0WC3`M7aO/SB/O?-I:+G6-N:/R=+P<(O:*Q<*Q<$L5+T>*S=*R>0UD'H9(H9+M:(N9)O:#G5)K9 Q@0[H&P:+UE'SA-U@.TC)N>&G6&D1%@.%A-'F6'UC.\K1WE7\F3bJ7bO6cP3`I/XB/T?4UC6YD4UA.O<2UF:aQ0]L.WG+RA3VB.Q>'K:'J;+[G)YC'XA,YC*Q@-PC.QB-R?,T/R?2RB)K9)J:&G8'G9$E6,M>)W@/U?1P=.L9)I7"F5%@1&E5!?0";,9)9(%@*4" 8("A0&N<(WD%G8@/"E1,K:0L<1I;,O8-N9,K60K73J8!5$%6("3% 1$, , !/"!0#+!1$!2%"8*";-$>+)C1/H50I5-F2*B-.B/2E2+@.$;(":)#;+*=+(>+$=*">*!@*#D.%E,,D1'?0$E7,O>-L8,E3%?-)D3+D61K>/I:.E6,C4/F7,@1@VF@SE0J:;^M5WG'<.#3%2##6#&9'&<*2H68O<5J78E8/A2)A3)?0$6&%0%5'$.#& %%'&)-#6$ 9'8'0!( '!'* 1#0"2#1"-(&!*", ."0# 1*#,!+ -" 6)B2)H53L:.D2 5(5("4$!0 "- &"# + 1;.#. ,))&#% 3%!1")$0'$-&)+*")*!,' % %!  $#' '#$&&*$0% #-#+:.-C4*B1-M9)M81O=4PA7YG3UA(H/1WB1ZD7`I8ZF*K81VC8]G4ZD,M8)B0)A.)H50VE4WB7VA/I;+L9)C0/J:.O;8`G**A-.E1.I10N5+K2,I1&@,%=+$>(%>'*A*(A,'@--F/.D0-C0+D1.I41P83V>2U?1R=2P;)D.'C+.G/2L8/L7.J1*A+):,(A..B1,B1,G4(D0+D-+B/&<+!5'4'$:-.G73L;0I90I92J;/G8/G:/L86UB9YI5UB1Q=5S=3N@5P@3M;2J82I6/C1)?.%=-)D2,K91P>0M)&<* 8'6':*$>.'E5)K:&D2$9*1$"4&$6&%7')@1&@2'A1(D4$B/%C0%A.&A/$D1'G4)I6,L9)I6*J7'M:&N9(M8,M7,L8)O7'H8&H7&I8%I9(L;)L;'R=&P<%N:$N:"O;'VA*P>'R?(Q?-SA+O>%L;&S=)T?(S=(UB(SA+Q?.L8)H3&H4&K5(O:(Q;J7!J8-SA-R?-R>0T@,R?+P>+N=,O>0UA1XA3WB3WD3WF4XG5[H5[F3XG2WD/T@.T>.VA0YC3ZE+T?*U@-XF.XF)Q?-N9*N<*O@(O?%L:%N9(O=,UC.YG-ZG1aM-_J-\I'\H,`N.\L(TF$RB#S@+YG(XE,\J.cO-eQ,dO(ZE)S?#K7%L8-T@1`M2_N4^Q2_O,[H-`I&]I'XG(SD(SC*TC,VF-_K.\I)SA'R@*WC-]H+\M%VD*ZI'ZG&YF+\K-hS3iT.cM(]H"YE.gU,fT)^L/^K2ZI2WG/RD+WF/WF'L<A0*Q>(S@(XB.UC-O=,P?+P?*M<%I8(K8)N:+VA+WC*SB-P@"D3+J94S@6VC;]G6YC/O<.K;)I9+L;/S@1XC4\G1UD'G6(K:2\K,SA.SB0TC-Q?4ZE)R<5]M4ZH,N=,L;.K<+K:1R?1TA+O=$J7*Q=,T@+M82V@2VC+P<2TD.N=(E6+M:-R>,P<#H5,N="Q@+UAB-$L<)R@/VA-TA+Q=.Q?$F4%E3)G5-L<4`N0\J-TA7]H4dK5bO4bL0]F2YC2UB6SC5WB4T@1Q>5YH6`N3_O.VE.SC;]K+P<&L;.VF3_M&R?'S>-XD+Q?,P>-R?+R<1YA/W?0TA/O?*J8$E5$D5!A3&F7(J:#J5*Q<,N;1Q>.N<%G5'C4#B3!=/6&4$%B13L;-,5'$I7*UA(C5!=.$C1/Q=.P=*K:1M:,J5+I4.I6/F4"5$!2$0"'6'!/$#1�%!3$!1##5&$8)'A1(C3)G4,H51K93N:0I5-E1.C05J7*@.)?-,B/$9))<*(<*$:'";( 9&#<)8%5#'>-)I74VE0M=1K;*E5+F60K3O?2QB0VC?gR=bLD]M#?/(K:*P=%I6.O=5YE:ZF-M;.S@0XB*O8$G4-UA8^G1VA7[K/SD3P72N55Q95M52I/1G01H23M62L41N40N5.M3+J/)F-'=($6$%4"#6#%9&*D0,H4)D0,F2,I2-N5,P6)H2)D0$?,%>*&=(*B,(B.)C0.D0.D0,D1/G4.H32N70T3R<2M6/H01H34M;4O;1N6.D/):-$9),?/+>1/K8,F4)A-'=,'<+$6));.)>10G;1N>1K=1K=2L0K;.J:)H6'J4%L5$N5#K9!J7*R@-SA.S@0VA-UC,R@'N<*O=0VD.WE0XC1XD1ZE1ZE5^I3\G3\J1YE0WA.T>1WA0YD2XC0XC+T?*TB.WE.WF0TA-Q@-RB$K;%M;(Q'T?-XD-\F-]I-\I(SB"H9!F5)P>0XF3cP/aP2fU1eT.^K-\F+\L*[J*XH*VE+YG/_I0^K/[H)SA(R@-WF+YH&]L+`N&VD"M:J7*[H+eO-cO*^J)[I UB/dT+aP$XF+ZI5bQ3`O1^M,XG.XF%J;B1(O=)UB(UC.TB-N=)M9*P='J7"I7%G7#G4*R=+SA0SC1RA+H8-J:5S@5VC7[F5TA.L:-L=/N?/Q@0UA0]G5cM0[F+Q=1WD/ZH)O>/TB.SA1VE2XD,U?1WC0T@.N;1Q>/P4WC4XD*O=3YG.TB)H7.O=1T?+Q=%J8*N>%M>#I5>*'M=-TC-S>(R;+R=*Q<)L;#G7#G82RA1YG+UE(N;4YE8dM/[H0\G2\F4[G2UB6SC8XE5UB5WC6\J3]K1_L0VG,Q?:\J$I8'N<,WF+QB"H8%M8'N9*Q<+P<+R=-T<0X?,T<,Q>)L<)J7#A2;,!=0%C3;,'F4'I5)M8/SB.N=&D3'E6%E5#?1!9)/ 'A1"8+.#, 1#"B0"J3&@3'D5*M8.Q='J6A,/H4,F2(B01J9/G6$9'"3#!2%$5'%4&'4(!/##4&&8)';,(@0&B2%B2%C0'D1+G4-G3+D0*A-+E15N:'>+)?-+=,&7))<+':*&9*"4% 1#-+ #7)*D0.K55VD9VG.H;"<-'B3)F2(E2&B0%A/2M<1M<8SB;VFB\M:I;,":'(;*#4$$0!.:+&4%!/"!2$(;--C2#;,&:+)7,&5'#4% 4" 1$,)"/!#0 #0 ,*. "3"&6&//*( ))+.#!1&!2'.", -!#1""6%6%"<*':)%2"%3&$3&.""2#,/-E8&/4"&@/&B.!=* 8(3&/"*!, )%, 0#-!*%%(9/(5+#+!*)#$& +%$.(%%&#  $%"&" %!& &&""$#%%"!'#, &&*'9-/D9-B60D7ZF4M?3N?5P?6N?4N@4XH@gS=_K/M>!B2/UC-TCE3.RB9_K0TA)M9-YB4aJ7`H'I5-R?5WF9WF9UE1QB C.&M71WA1N;8TB?`MBfP8ZD3T?>_I=`L.Q>/N=,G7+J90UCBhS9ZF>)0R=,S=,TB<`O8XI6U:4T93R75Q84P55P77O66P84O55Q63M5/M3(H,'C+$9%%5$&3!#4"%:'&A--J61O:&M8+S;0Y?*O7'E/(B.'=+%:('<&(=',A/-C0)D-)C--H4/J72N85P90S;1U?.P<2Q:3O85O56N66P=5R=3Q8-G1&;,%5'-=.3F5/H6,E2*<+"9'';)(;,*=.)>2-D8-K>.L?-L)<+"7**2*%3''7'$8%&=)(D/'F1+F6(C4)D1&D1&E2(I6&F3(H5'G4(H5(H5*J7'L;$M:%N8+O9.P8)O8)M<,Q@*R=(R<)U>'T=%S>%O;$F2&G3)P:(R;(P>%R?*XE.VE.WE)VC'XD$S?%UA%XD'WC&P=+I;+I:+H6)I6&L4!K3$M8&O;)Q?*R@+Q?.TB1XF2WE-SA-SA+UC/YG.XE,XC0[G1]G0^I0^I.ZH/[G+U?,T>-V@0ZE-VA/XC,U@(SB+YE*YF.VA.UC+P?"J9%O=(T?-WE.XF,YF+ZG._K+^J0]K/aM2cP,XF)P@%O=O8#P;*T?,VA)T?)UA&QB(N?'K:%I9(O=3^L1`O,aN6lY+aN)WE/XE,YL+YK)[I(ZG+\G/_J4bO2^K*UC)SC(TC(UD'^K(aM+[H)N>%M;*YF.aM+\J)YH,ZH&TD+[I!P@M=,ZK4dR2fR0fQ,]K,WF+O?(M;+SB)XD,WF-RA*K;%K7&N8'M7#M7#F5&I8'N<-RA3UA1N?+H8,I92P@5WC6ZF1P=*H:)K<-P@/SB/T@-\F1aK-[F.U@4ZE/YD.WA,T@0UD-Q@,SA.VE0UA4XE1U@0T@1VB4ZF-SA0VD+N=#H60WE/WE-VA0YD+SA*R@1[I(TA)M;+O;0UA0UA,SB)PA%L<&H6&I5*N>*Q@,R=%L7'M9'N9(L;&I9 A2.K8.O>'L;)M;1VD2ZC,UA.V@/U?2S@0P>2QA4VD4XD4XG5[I0[H+WD+Q?1TC1RC#D5*P>+TB)K=@0%J6'K7-R>/VA*Q<-T>*P:'L7'K9%J9#F2 >.7*7+7);+(D3$D0*J:2TC&I7+H8'G8(H9)C5#8).6'2&/#-"0""@.#H2%J;-SB0VA/P=%@.!6(*B/*C1.H6.I6*B2#9*#6%$8&):+&8)(:+%7)&:))A.(C/(C0%A-$A.&B/#?,+E3'A-!:&&=*-H30K6'>++>-&8'"3%&;(*=-(9+. -", "1)*?1,F2,I54P>1M?&>25''@.*C1%>,1"(@4:SG7PC1J>3L?.G:,;-,<.$8&/F46L9,0J;2G7,,#?,$9(!- (($1%%4%,+;*#5)!3&):-$:*(@-'B.!;)1!- /$ 0"-#."+- 1$ 1$0# +/ -A1#0#(!+&"' *$ ,&$#( %#&!'&%&$#$"$"%#'"' " "'% )%(!#/'#2'"2'8H<-;,*<-CRD:I<5H96RBCSD?RC=VDD`M=YH:UFAdO@gM9\B;TC=UF2P<9PA9PB;XI7\L8^K(J5$D4)N:0YC-XC+RA-PA/UC5YE0U@,X>DsYNx_-N62YA2W@;YD:XC(J5*H5+O<7\I/O:)H47[E6VA&C2#B/,O<9^J.W@,L<+J:.O>1XBFkW5P>"=)&E1&K90VD6ZJ5VF;\A9Z?5U;2R85V9=Y?;U=9P95N44O21L2/M2)I.'D,(>)$6%(4"'7%%:'$>*(C/.K7,S>,U=0X?*P7)F2&?-$;*(=+(=*'<)(>,*A0*F/'E/*H40O:5R<8T=1T<2U>4UA4T:9V=9V;0L8+>-(<**>++>+-A/,A1+A4(J:,K=-K;/M<-H9'C2,D54P>5UB3P>-D5-?3.@0-A.0F2,G10L81K:/L7/K53O91L7,J4-L6+J3-I6(@/"7) 5%"8%"9'&<(&?($@+!8(&4(%5(&9)&=+&B*+G1)G1*F5)D4)E2(F4'G4&J6(H5)I6(H5'G4%E2*I6(K9&N9)Q<+R<.S>*R;*Q=,R?'O<(Q=&O<)S>'P@%M(SA*WD0XF/XF(VB%Q@%O?$P@#T@%VC+UC'L<(L;-K;(H5$H3$K5'O:&O:'P<+SB(Q?)R@1WC5[F4ZE0XB.WD.YH-WE,XD,\E._H.aL-`L,^L'XE%S?(T@(T?*VD'T>.WC+V@&SA(YE*]H,YG-WE.VD'R?'TA(WD-\H.]I+[G+\H+\H(ZF+VD,\I2eP)UC%O='SA&XC(WC'S?)R>*R>&P=%O?&L='K;)L;'N;.YE*^K,`N0aO(WD&P=-SB,XJ,ZJ$VD#VC'WD0\J2^O3_O.[J*WE+YE*YE*\H(bN)`M/WG1XD+\D-[I)VD)SD+SD)PA(O? J:I9)VF/`P-eR/lT,bO)WF*QB-UB+YG+^J.\J/WE+N=+S?-WA)Q<I5$H5'K;)O>-S?1S@.P>*J:1O?2SB7XH4WE-K<(J:'K<,RA/VD.VA0[F-[F+XC0WB5[F.YA)S>-U?-T@+Q?/UC2[J.XB/VA3YE0VB3ZE3\F.VD/UD)M=/SC1WF(RA)VD+TB(R@)R@*UC'SA+V@0ZD4\G4\G-UD&O@)M>-M;.P<-QB)SA1YC+P>&K8(J8+K:)F4#@/(A/)C2)F6*K:/Q?.O<,O;.P;.M81N<2N?2RC6[H6[J2YG2YG2XG,TA-S@(J:+I:"B3)K;'N:(I9)I7(I5(L81XE+SA-Q@)N;$F5"C1$E2 C/#F2"=/6(0$4&!;-#?.$?..J:)F6$C4,M=+K<,M>(D5#8),/ 5'4'."3%#@-'J5'R@-WD,S>-M9%>/%7)!;*+F31L90K:(A1$;-"9'&=+,C0,A2/C4-A2,D1,F2*E1'C/&@,%>*"9()A//F4#<($=)+D0,F2)A-%;)$:(%7&)<-(>,+C0(=,!5'1$&6)(8,#=.<-!<,'@0)E4&:-#7(&;)';'0",+?31E9*@4/E9.F9'?2BTEK[N;Q?>^ICcM.G2.E3*@/3I:5K<3J91I61J;.E5/B5.>0,<-#5"%/& -! 1 !1 . -*-2#2G5+<+#0!** ) * *". !0$".!$/""!"#3%(=.9):*"9*/ %!#4''9+'9+/>0 2#$4'$5(!4&%<+%=)"6%1#.#.",1/ ,- 1$0# 2%"1!#6%%7(*$#" %&+""/&& $, !2%((<-%4&!'! #( #)")%, !%  $' ' $!""% )!-#$2&)6+/7,9C8?I<:B63B44K<=L?>RC>WEA]KC^MAYJGjVBgO:YC8P?aL4M>!=('C0*J73SC9^K=dO=]B7Z?8Z>8X>;^A@_D7Q74N23L1.K1,K0%G,$B)'=(#6%&4"&8%(<)&A,#?+#@,*C1+H4+M5+M5%D0#?,!<,$?*&?,(?,'B.(D20M6.N8,O90Q<5V@8V?9YA9YC7YB5X@;Z@=[B7[A9^A;[A7U?.B25K98W?6\B,O8&C.+?,+?*-?+,A,+?/+C4,K:-N=.N=-M<,L;,G90I96Q?5TA0M;/E7/?40B30C25K84M91J9-G6*H1.J3/L40L5*H2+K4-O5/L6)A/#9'!5#%:'";)(=)*@(%@(9%5%%9*&<+(B-)E/+H1-J4*F6*E6+G4-J7(J7%J5)I6'G4)I6(H5'G4+K8.N9*Q;)S<-T?0VA,U@+T?)R<)O=*P>,QA,QA+PB(P@%N<&O<,S>-Q<-SA*UC'TA0XE.WE'TA&M>$I:"L; P)SA)TA+Q?.O>,M9'I6&K7&N9)P;+S>.VD&Q?&O=/T?3XB7[D5\E1YF/ZI0ZH.[G.]E+_F,bM)aL%[K"UD#T@$Q>#P=$Q@&T?'U@(W@'UC&YE%[G+ZG*WD-YF(UB*XE'YF'[G*]J([F*\H&ZE%TA+UB-\H-^J'UC&SA+[G*`L*\H)VC*SB%O>'Q>"M>(P@)M='K:#L5*W@%YH&WE'SBF4C1(N<+TF&UDP<R>#Q>.WG-WK3_Q2_O/_L._I-_H0YG%]J#_L1_M4^K-_H6^M,RA-RC/QE+M>*J;%J;(N@+VI-_M)bM*iO)bN&WD*UD+VC*YF(]J/_I3\I2XG1[I0]J+WC!L6$I5(M<&L<%L:,R<4YE.R>2TC8XG9\K1VE,K<'I:%J<-UE1[I/ZD4[I-XC)T?2YB9^I-W@,VC,T@)P;+Q@/UC.WG+WB,VA.WB/VA2[F-WB,VE0VF.RB4XH1VG'P?,VE+SA+Q?'L;(N<+Q@*ZD.]F1\F3[G-UD%N?-QA4UD4WC(O?&Q?/YC.RA*K;.K;-I6&@.#<(#:(%;,'@0)I8-L<0L82O;5R>3N:6Q?6QB5TG2ZH0YG/WE/WE1WB1VB-T?'H8&B4-G9%B2)I6*J7/N<*J80S@0WF(QB+N@,L="@2!?/=+>( A."<.5', ,2$%A1!;+*A2 9)$D5#I9,M=/QA:,4%-4%+G4$:*3$ 7'%C0'K5'O;-U?,R=+K;-H9&=2"?-,J75S@4P?-E6'>/'B0)C1-F4/I80H9.G6.I5/K6'D0(B.%=))>*(;)+?.&;*'?++D0)A.*A-&<($:'%;)&:((<+%@+)B.(@-&=,)0(;*#@1 ?38,#9+$@,&6*$5%%5#/+ -#,>./B21D31E42H88N=>UF>QA4O<4\E'P8+I20N91N9*F3/H7.G4*C..E6-D5,C5,@10@1,<)(1($/#"0""2 "1!%0#+/# 5',D2)=,'7"$1#!/!#2$$4#"0#0!%/".6)'.!(/#!,&7*0#&1# 7) 6('5( 4%%=-#=-%;-%9+%6%#4% 3&$6))<.':*%5$$2&"/%(*.. .!+'." 2%"0#"3&2%&"#'"%"* *('4(&$0##=,'@.(;+'#  (&'!+"(* . ,$! '*&#'$""$#) '2&,6+2>/.5/+5--6-#,"!1$'A20F93M=5UB=_KCbQHaS<\K=`I@^H?YGC`K>eK?bM9[H+Q=%Q<.WA4V?-O<6]F6aF/[A1XB2WF5ZJ6WD'H2(O65[B+N41T?4YE1VD5UB2O@&H7(@-*I5<_K7VB2P;%E1(=/+B5-E:(H9,Q?1[E&I5*N87_E.[B2S?/J8%D+'C-'B/4Q?>bN?jR<_E<`E:]C>aG>bK<]E&#<%%6!)8#);($?*"=*$;)"9'%=+(@/%@-#>+"=(">+$:)+;*+=+%=))F1-V@.V?1W@6WB:[C9[A2YA3X?9\C;ZB:[B<]D>]E<\D=_F@dI>eI>cF@\C<[B6YB3XB*J7!>+$:+'<,(:+);+*?-+C1-F;.K=/P@,O>1N>2K>3O?7UD:VB2N:-F6-F6/G5/G6.H92L=2L:+G4.F01I60L7-I6*H5(G6.L5)H3'@1%8*%4(*=,(=0'@-*D/(A-$:+#4($5''=-'C2)I7*K6.N51O;-K:*K;)L9(N7%L2(I5'G4(G4*H5)K8*O:-R?,S>.U=)T<*U>)R@+T?+S>*N:-Q=.S?-R?.WD.SB+PA-SA*U?+ZA/WC2YD,T?/V@/V@+S<)L:"G6"K8 L:$Q>(Q?)VC+SA+Q@*P;'O9)S<&T<'T<%R:-YB,U@*S>0T@1WC5ZH8YG4WF.VE/ZI2^N,\M([L+^M)_K%XE$WC!O%N@)T?%V@#YB&YB(W@+YF-[D*XD,ZG(VC-^I(YB)ZF)]E([D&ZG&XH%VG'WF+]K+^L)[I)WF.ZJ)\K*\K*[H'TA&P=(P>#O<'O=(J9%F5$F5(L<$O<%N<G4B0A0 D4&K>%M=H6L9J8'Q?'QA+ZH0bP-]K0`O*bO-_J'ZE*[I1`N0^M1^N)WK%RD&MA-RC)M?&K=%O>+VE.[J/^N([I-dO)[K&UE&QB'PA(O@'O?/YI3^N4_P2`O5gQ)]E%Q<(P@(L>!D5 A1/O>2\J4YG3XG5^H8`K2T@,M:'K9+R>-WE+XE,ZH.^G*YC*U@/ZE.YD.YE'QC'Q@(RA0VJ)OB+RA/Q?,VB(WE+XE-XB-ZA-V@-VB*XD-ZG.XD.U@.ZC0WD0TC)L;,R?/[D:bK6]I2\J0[I1XF0VC/WA7[F2UC&N>(TC/VF)L;(J80N>/H9%<*$6%(8+'9-'@1(D4,K73P=5O;7S?4R>6WB6WD2S@0VD-RA/WC6^I.XD3]F2VC$G6&G8/N?$B1(G20N90Q<*P<.XB*TB(P?(J:)I8(C3"<,7'7("=."<-6(. '-!"9*$:*,7)!=0;-D/0P=!:,4&3"'A-*G4:*8*#?0'F4)L6$M8&P;+S>0T@1Q@(C3'A5/P@2VB/U?.N:%B/%H1'H3.I9/J;.J8(E1,E6)@0&=*)@,)@-*C/,?2";,"<-(B4)A2':,%<+&?,*E/%?*#9&%8'#:('?-)D3-G7*C4$:-%:-,H9$?1*>/,?/'<*(;*&6&"/!+ 2& 7+*@2,A30G81G9-/@/*<*"2!-##*5#;&(<+!8)#=.$?/*A.,?*+=)'6$%3%&6((<-'>,$8*"4'#1$'$8*9)';,"3$&')$1# . $5'%2$& # #!  $!,!)) +!&!$#.##6&)!%( **&*"+$+( '!& %$%)'&'&*$)%/#%3',=0,>2+8,&2%')/$*>4)G83WG3TD0L>3')B3/M>,M=/Q@;^M-F7*J5'K60W=-S;(G2*B2#=+)J51V@:aK0WD>aF>_F?`GCeK@bJ9ZB7T=6R97T;3P7,M4+L3-K3*G.)C-'>*(=&)<&%:'!=(;'#:'#8'$9'"9'%=(";'!;'":("7&&7&(;()B.,K72W>8^E5]C8`G9dI4aF4[B0T<3T=7X?;^D>bHEeKAcI=`F>dHBiM?fK;cI9aH4[E-M8(@/%8'$8)'9+&9*(;*(@.+D3+F8-K<1SB1T@2P>4M>7SC=ZI,J9+D1+E21K8+G4%B.'D0.I4+H5)B3+>/,>/-C0)C2,G5/K4*F0(>-#6*#8&%@.(F6'J7*N8-N7-K8,J7*I7'I5*M6$J1'F3%D1*H5*J7(L8)O:,T@.VA.XA,W@(S>'R>*WA,T?)O;,R=-T?.VA,YB+VB+RC*TB.WD,XB1XC4[E.U?.U@-T?+R<'K:$I7#J8$L:&M<(N<*UC(Q?.TA-T?,T>+V@(V?%S<$R;&R=(T>&R>+Q>/VE2XG:[K5WF/VC1[I4_O1_O+\L+\L)[G&VE%TB#Q>!N;$M<&N>&S?%XB#XC%WB)WB+XB+YC+XD*WD)WD/]I(XB)YF+YD)YC'UC'UD*UF&XF&YG)_L']K#YF)\I'\F'ZE%UB$Q?"L;&N>&O>)N=%E5#A1$D4'I9"H9D4C3A1>.@1 D6F6F4K8"K9#L<%L;&SB+ZI-YH.\K-`O+\H'XD'VD+XG-XG,WF(QC$N?"N=+UF,VE*Q@/WE.[J5fU/bQ)ZH#T@'TC!K;$K<*O?'K<'K<-UF2ZL3^P-ZJ/_L*]G'XD,WD(J;7)<,0P@.[I:bO/VE5_I:cN-R>.M;+N:-R=.SB,SA.VD/]I+UB0WC.UA0WD.VB(OA-TB/UE1VI*NA*N=1Q>-UD.[I1YG2XD/V@,U@.XD0YG0YH0YF3]G0]E6]I1UD.RA2ZG7cL=eL:bL7^L5YI6YH5WF3XF6XH3WF-VE,XG,TD-P<*L83P?.I8&<.&:,"7*#<-'B2%D3,M<4UA3R@5UC6WE2R@/O<1O;*L<)P?.[H0^L,ZE6aN2VE"B2*I;3QB!>.(E1/M:,M:,Q>0VD(P>&M=%G7(F5)D4'A1 :+6&9) ;+4&*((0 3#,0#4&0"!?.+G86( 7((B15Q=&A12#9+(E6'H7#I4'N9(Q;,S>2VC2RB,H8*G:-M>+P?-P<*H6";*'I3*H5,G7-G8(C3#@/%?.!:('>+'?++D2/I8*A1&@0(C4(A4$:,"3' 9(+B/,B.'=' 5#!7%!7%#<)+C4(@1#7)#6()@24O@+F7-A3.?0'9)'9(!5%%:**B3,D6#;/)A2'B21O>@_NGfR0O;'C/.K7-0>.-:*#7&-C21D3'6&!3")>-.C2*;.$2%%3$%2%&4)(6)'8(&9%0B/4D15F5/?.'5%,*$')2 9&$;)2"$<,%;+)A./G20B/,=++;-*;-,@1%=+#6'#5&%4'"4&%:+#=+%7)#2%!+'&*)%7("1$!*$)!' $#%%$ & +!, ''$" $ + #!!"'(% +!$.$(")))'#( (!)!&#+!")!* * &1'$0&$2'$4)!0%'3'!-!'' ,!$4(,E43J:'3N?G^P0" '7(+A.?ZD>`I7]F3U=9ZJ3VC3XD7^H8_I1XF)L9+M82YB4ZD7VB/R@6XG.N>+K9+K:.K;-N2UD.N?0O@.G9+F7-K=,P?+P?4WF+J8(K64[E5\E1VA+J8)E4.N;4YB1YC.VB0XFAdJ>`GBaHDbJ<\E9V?0L53M55R92P70O7-M5.N6/J6.H4+C0'A,)>+&@,#@,"?+$;(':(%9'%9%%9&&;(%8'#5$!3"(=)/J62R>8]D;aH7cG9hK8hK4fI6[D2V=1T<4V>4Y?:`F?cF@dF>dH(C0&7&*5%'7*):,(;,&;,)C1+G4+G8-K:3WC7YE8XC8UA:XE>[H=YF3L;-F4.F40K8/J8/L=0M@+K=+M=*E5,H5/K8-H4)D0(E/1I70M:-I6/F7+D2*E4-K6.M71P90L5)B/(<.%?+(E2'H5%J6%I5%H4)F4*H5(E3+I6*M7(L4(G4'E2'G4+L8'L8'O:)T?,VB+VA+WA&Q<%O;&U?'T>%M9'P;+U@)V@&X?(X@(WA.XD,VD-XD1ZB2[D.W@-VA+T?+S@*N=#I7$J8&J9(K:'H7%K<&L;,S>,S=.U?.V?)V@%S=$S<&T>%S@%TA(SA+XE3[I7YH3VB2ZD3[I3^L3aP/_M,\J)WE&RC&RB&S@%N<&N<)O>'TA#UB!TA'UC+UA,WB*YC)WB)UB)WE,YE*XB&Q?*UC&P=$M;*TC.YH'UC(XF%WE&ZH#WD"XE'VA'U?$N;!G7"F7&J<(N>'L<#C4%C4&B3'E5#F8!D6 C5 B3=/>0 D4"H7 J8!K9!H7E5!E5%O?)UD%O=*TC-[I-ZI(UD'Q@+SC+RB%K;'J9%M;%R?"S?+XF(RA.WE1_N4hW-bR+[I$O=#K;!F6"E6+M>(K;+P@.TE2YL1YN)TE.]K,^J%^H)TB">/!;,">.-P=+\H5aN+R@3^I5_J.UA.N;/O<0Q>/O?+K:.P>-VD*Q?+O>.Q@1UD-P?,OA,Q?/SB3VH/QD*M=+O;0ZI4cQ8bQ5YH2VA)VB2\G/'C2-L;,M<-Q@,Q?(N<&L:&G6&E4,G7$>.#=-:*8(7(3$*('). ,/",+4&!7)/#'@0+H7)H5(=1(!8-'@2#C2%I8,O:/T@/T@2WC.P?)I8(H;,L>"F4$E49)#;,/K8(D2)B2'A1'A1%?0"<)!;('@,'@.*E4*D6'C/)E2)D3'=.1%-""<*,A/,<*&5$!3#6(#9&&?-&>,(>,&8('9*,E64P@5Q>3F5-<-*8+':(,D30N>8ZK,I+*B0+C1*G3/K73I60B0+>--B/4G5-C2!=*7Q>/C5)7'$5$*>-,@/(9(&4$(2%%0$)6+(8*+>,0E/0D20E30B2$4"+,%"%."5#!;&%>-'>+%8)%9($;)&@..A/':(*;-(;-+@0$<*#6"!5#$7('9+#9)!9(#0$$."", (*'';).>1#-#+ * &%$ ( '&' *%" $$"!$!""!#-#(#"(& "#%( ("*!#) (-"#0% +!)$%'$#%$ +* .".>1>LB)2(49/=C75?2H[K=XG=^LKiTG^OE\K?]G7ZB5UB7UC8ZG6ZI;`N=eO7^H6ZG2R>4T?6ZD4WA4R?3WA7[E2R@/O<,M<)G7/K8/K9,K8-K;.O>3UE7SC4QA.P?*N=(N<-SA&L70WA4]F=fP=`M/L==-2SA,Q<(O:.TA+P?@fL?bH=`F@aH=_G6U=+F1*G..K22O50N7/Q9,O70P;0M8/I5(D0&@,&@,'F0&D/&=*)?(+?+';'&:'%9$$5%#5$%7&'>+.I55UA6aK:iN7iK:lN>mQ0W=9_A:aD9_C5ZA1R;+M6+D1*B.,A0(;)&4$,8(&:(':*)<-)?0*D5.K;1M90O<5TB8[G;_I>aK@]K@^L*K<%H8+I70M:2N;/J5+E10I45N>2O<0N;/J6+F3)H6+L7,N7.Q91P<+H4(B.(G5'H5'J5%J6&J6$G5(J6(G4)H3*J5)K6(L6)I6&G4&E3&I5&K7'N9%P;)T?)SA)R@(S>%P;%S='T>$O:&Q<+XB'V@'YA(ZB+[C.\F/YE/XD.\C-YB,XA*U@,WB*UB*R@$L:%I8&H6'F5%E3!C6%H7(N9+R)P>(TB&UE&TD&QA.UC-XC*YC(U@'UB+TC(R?(T='Q?*Q?(M<%K;)SB&RA&Q@'Q@'RA%QA%UC"TA(Q='L8%F5$A2"@2'D7(K;&J:%I9$G7&G8*H9&I; C5B4A2<.A1!F5F4!K6"K6!F5!D4!@1C2$N=!G7%K;,VF(SA(SB'N>)O?$L;$N<)L8$K7!O9 P:(W@*V@*UC.]L3eT0bQ*XF'P>"E5!A0%D3,L;+N=0UC0WG2[L*UE'UE1`O3dP([I!K9#C2*F1.N:1[E.`L5`M&M;/XC1ZE/T@,O;.P<4UA/O>/K;/M<-TB)L;(H7*I8.P?-TA/SC.S@3WE8\L.SE)P<,XF0eQ2iW6eU2^L3\J/[G8bN;dO6_J8aL4aL0\E3\H0XF4^L5bN5cM9aH7^G9]G<[H5VD7XH:[M7YI4[K.[J1aO-WF5U@0Q=0O<-G9-F81J<0G8,D5,F6(C3)F6*J9,RB+RC0VD+O>)I7.K72J=1N@/TD'Q@4[I8]L4QD%B4'D5'D5!=/)D6,N=/Q@/Q?'I8&J9&K9*J9*H8-H8&@0!<,!<,#>-";+2#+&$&,+0#-/!1%3&4%&?0'F5'H7.<1"2&&9+":, =/%G70P=1T@1VB2VC.P?*J8)J<-O?$D4$A."=-'>0)@1'@0$>.%?/";,7)!9(":(%>*#;)'A2&A3)E1(E1*D4#8)"2&$3($=-,A./?-(7%(;,$;-&;*(?-*B0/F4*?.*>+)E53R@@^J8P<.>//>2*>-'B1#F5 B3 =/#:-*:,,A2(E2,H6-G51F3%@,&?*(?-.A0/B1.A0,=/,=. 3%4"#:('B.+D2)F3+G2/F2-?-0B2/F50H6,H61Q>4Q>.B0+:)&8'%8'&:)->-*8(+7*-9-.>0+>/-C0+D.,E2,B0,@/$5(!/!)$%"/!'8 ')A/*@.,?/'7&'7%#:*(7&$5%%6(%8)/E2'=*$8%#5#"7(&;-#8)"9(#4'-!"."$0$"."!,(3E4);)##,#.!!($#"&$) "'()&%!&!&! %*!#&#!!#"!  &!& "!% "(#"( ( +!!)$ !#*( &$'$''*!!,&,",2&1:06@6;C9GG=HG>DG>EOC[F=\J;]MCjWEkW1WA7\F6UA9WD:\I4VC8VA5XB5YC9[F5UB5VC.K;-J7)D2/J8'D1,N::_J7XG'G6*L;+O>0TC4\JOvaY‚l:eN=fP=_L+J:&?1$A/'G43VB4XE,M=?gM@hM>eK=dI9^F/R9(H0(E,*G.-J2,N4-R8,R9-S9*L5*H2(D0&>*$?+#A,#C+'B**A*,B++A*&;%&:'&:'$6%%7&':)(>++F21P;,T?8eL:kN;nP@pT?kR0T<1W?3[@4ZA3U=0O8)E2&A-.A0.A0->.'9(%7&*:)*@.-A/-B1/D5-F7/J:4N;3N>1P@3WD:aL?hQAdP<^L9WG/M=.J80M9/P?1P@/N?*J9*I7*J6-I50L80L91K9/J73N;:SD4SA1Q=0K7,I6+N:,K7)J6*N9*M;)J8*I7(I8(K8(K5*L7)K6)K7%J6&J5,L6(I4'J6(M:)N9#G3%F3&J5'K7&L7'R=*TA(Q@'N=$L8&M8&R='S>'Q<)U@*YC)XB*YC*ZB+[B-[B/ZC.WC,WB,WA+V@*V@+V@*U?(Q?'M;$I8&H7&G6$E4#?2$B1)L60S<1S>)J8#H7&L:$M;)SB#O>#P?$QA(ZF+WE0YC/U@.YB0WE2\G3_I3_K,VF'OA&M>&Q?'UB%R?&O>)N?'P?'TE*VI)PB,UC,ZC)VA)S?)RA%N<&O<(Q;)Q@)O>(M<#M<(WD([F'SB)RB)SB$P?$R@#R@%M9!E2 >.$B3$C3&G8'I9$J9#M;%N<$M;'M;#H8 D4 E5C3C3 E5"F5 G2&M8%K7 C3?0"@1F6 K:E5"F6&K;#L<)P@*O?%L<#N;$T@'S=#M8#M7!K7"M;(VC)YF0]L1]M1ZK+UD&N<%D2#A0(D3/O=3WE0XD0\H3`L+XH1_N4gS1fP(TDC2)M:*O:/XC1^I1aN4\J/RA/S?,P<,N:*N:2UB3XD5VF1RA,N<0UE'H7(D5,J;6ZJ3]K3YI3\F6_I4]L+VD+WA.dP3o[1n[6j[/\L-WF/WF3_L6fO6fO5aN3\I5^I4]J1\J4`M2`L/_G6\H1VA5YB6[D4YD7\I8]I7\I3^J1`M3cN1XG-O;1Q>/M;)F61M=2N@3Q>1N=-I9+I9'I8,O@1WF/WF-TA(M9(J53O:3PA3RC/P?*M=5ZH4YG3RE$C4(F5%C2$C1)H8/SA0S@+M9)K7(K7%K6,K:,G8,G7#=-:*:*#=*8&4%-(&$)0"4&5%!5& 4'4$!:+!?/@2 B61E8,A4(?.#=,?-$G70R>.Q=0TA0S@1P@-K;(H6*J7)I4,H4(C0!<,':,$9*"9)"<, 7)1%/!!6'&9($:('@/(B3'C0'@.&>+$7( 2$#3&%>,/G4/D1-A0)<.#7*)=,&>,,E3+E2+D1,D0+F73T@=]H>WC3G7-A3&=,'@/"=.9+"6*(:.+:,,?-)@.+E3*F1/K7.L4'C/+B0-C32I7.G4-C1+?/"3%2$#:(&A-*C0$B.'C/,C/,>-,@0,B3-H7+L91VA1P:1F3-<,%5(%;),B02C34C21B4.@1,@0*A/*C/.H5*@.+A.-A1(9+"1#+(+&4'$7%"9'&?.-?.'9(%5#(6%%1"$0$%1!#1#&6))<-/B0&9')8&"5$ 5&$<.4'"5'!5'3$"2%%1%%0#%/")7&1B0+&%, )(%"$& $#"- '1%$/"!+!!(!"!$&- "# !  #*#( $"&#)$-!&%#& +") %"$#-"&2$&/"")&*+.$+0%)1(34,23,*4*2?4;F=J>FZMI\MGWKJ_QHdN?\CJ`LIbQFcRAcS?dS?eP0V=9`H>^H9YF?bO8ZG7UA4VB5WE:ZH:ZG7XE1O<.O<0N<0J7">*0R/P=/R>3WF.QA;fK;fKhR8_I4XB2S=1S;1V=5[E4ZD/P;.J7/G51F4(D1)C0)@-+>-*;),=,+B0.E30F41G8/F7-F75L;4L>0M?/QA3[G7dMAgQ5YG/Q@/P?1Q?3R=2RB3RC/O?/L;)F2+H1+G1)E2.I5-I6/K75P?8TE5VD,N9.K7.L7(J7-K7#F2%I7'L;&J:(L<*K<-N<)J5+M5+M7-O:$M9*O9+M6(K4&L7(O=)R='L8)M9,M9,N:*N:(P;(Q=&M<#H8!G4"H4%O;(R>+T?-XD,YD*YB*UC*VB*X@,ZA/ZC-U@-YD)WA(V@&T=&U>'U=(S?'O=%I8'J9(L;#H6'@3(B3.L7.P83R>-I9$F5&J:$J:*QA&QA"M>#Q@$TB'UB/WB-VA+YA.TB0XC.YD2^I.WG+QD(P?&S@%UB&TB&Q@'K>'O>'QC(QF)OC*SB+ZC+U@)TA#M;!H6"J7%L7)Q<,P?&L>*UD)\I%_H)ZH'UD'SC&SB"SAR?!N<G7D2$H7%L:'N=+N=)P>#P=#S?!M;&Q?$J9 F5D3#I7$J9$J9"G5!H3%K7#J6?/!@1"A2!G7!L; F6C3B2!F9&J;'L;'O?%T@$YE%YB%R<&L:$I7C2+WF%XD-ZI1WI/RC1VF,SB,J6+H5/M:3T@5[F2[F4bK4cM1aM2eQ1gQ1fP(M>B2$N8*V?*[C-^G1`M5ZI1P?/O<(I6&E3'N:,S>:aK5[I1VD-P?1RC+I:.H:.M>4YJ2^M3]L4_J5dL.ZH+XF1aK.eQ8r_2m[2dV.XI1XI5[I2`L6nU4kR5cO9`M:dN8bO7cP5aP,[F+ZB2VF5XD8]D8]D2ZB1\D3ZC5]E1\G2cM3bN.TD.N=6SD-K;.L;1O<4R@0VB0U@,O>.P@)P@,TD2XG/VC.U@'L6*M62R;.UC3VE3SA,P<7_J+YB-M?'F5(J7$H3&I5)L9/U@1VA*J5*L6)L3%K3*J9*F5+E5%?/7(9)!:(6# 6&$8)2#((+ 7)";.#=.8(6("<+%B0#E4#E7?4-H:5QB0P<%H3"H4$M:0U@%J6*P2QA1L;%D0&E0+H1-H3*G3#@-'9-#7)"9' 7(1%0$+! 1#"5$'<*'?,%>/&A1&>/&<+"6% 2#%7&,C10J7.I5+E3-A32B60D4+B0,F4,H3.J6.I6*E5'I5;aHMiS/H8'?2%?-'=-#8)$5('8,.<1+?.'=+(?-&A-$F0.T>5X?.K7,E4.H8.I7,H4)E1$;+'9*&9*#:*$?+,E1#@,&C-(>*/B1,@1)?2,F7-O<.U?0Q91G/->/*>/-C2*B/3H54H5/C2+A/)@.'A//I6,F6+A.+@0-@1'8*#3& /#%.%#0$$5%"8&#<)%>/&5$/%7$)9&&- +-#+5%&3%)8*);-->-&7#,9'!4$2%4(2'!3'"9* 6'/"%3$&.!)2#*6%)8'!-#+%+( ) '!&!#('-".:.'3'-!'%""$)"&$&$"!  '$#,"#,"),#"+""* "",!+!*%(!5&!. )$+(,!)-"!& %!$$ $& +!,=1?QBDK?DEJJACKAKYLIXLCTJOfXNlXGaKRbOF^ND_PCeWChW@hP4[A;bH?aJ9ZF7[J9]J6UB*L;2TD<\J2R@BbO,K85[G;[H1M9+F23U=6_G9[F7VD2P=0P?8ZJ=bQ=]O6YI3YE-T@5VC4Q?7PB6TD1UB-UA-UD.VE1V=0X>.W<)L5)C0);+'6((9(&7'$:(#;'%>*&@)*?)):%&9$&;%%>'$?'(@((A(&C*%A+'>-'>,*G36\G:iM;nR=qT;iO5aG3Z?3Q96V=6\B=bI9]F0T>/O;1S<5V?,L9)E2-B35F8/C4,A2,C4.I8.K8+H5(C2)@1,C5.E62K;4R?3XC/(B0,F4-G80L>4Q?7VB2S>.P;0Q=/O>+H8)G7(H6/O<,O;-Q;-Q@-N;+I7/M:,K8-P9'N9*P<(O:%K8'L8,R=-S>.R>.Q:.Q;+Q:)R<(Q>'N:'J6$G5 B2#G8&M>%L<*P@-UD/WE-UC,RB-Q@-Q>.TB*Q?)Q@+V@*VC'UB'UA'S@(S<'Q>*SA'O=(Q:*Q<'M9#G6'J9,M(RA&P?$N=&N>$P>'U@*YB+ZB*X?&T=(T?/XC/XC,XC)VB$R?(VB+WE,VD)Q?*O='K=+Q@-SD(Q@&P>)UC'R@&M<"H6G5!K7"I4)L;*Q?'TB$XF%]J)bO)]J)VC)UB$Q@"RA$PB'O>%M:"K9#L;%N>)SB)WC)WA'U>$Q;#P:$O:$K6%E2(H7(O?$P@#O@$L8$H4'F5$@2 >0 A2 C3!I6#M;!I6C2!A0#C4*K<)O?-VE,XG*WG'TB'RA&O<#H6@./S?(UC-YH,XG+WF,UD,SB1L;2R@1UE2WF6_M6cR1dQ5eR3`M5cP7hS0eM%M:%J8(P>(TA0^K/]J/ZJ0[I/UD/P?'C4'@4'H9/TC:bQ5^H0YB/WA.QC*O>.S?0T@9^K3`M7`M8aJ8^H/XG0_N5lU)cN2lU1hQ,_I,\D2^H3aK4eP8mV4kT3gP6fO;eS5cN2eM/`I.ZF*R@1RD0UC4ZE4ZE3WD2UE0YF-UB1ZH0^K1^K0VD0UA5YF/SA1TC0SD2UE3ZE2YD4[F1XC.VA,UA/T?.S?-T?*P>)Q@)RB-U>0XE.[I.[H0YF.U@*Q?)L<.M>'F6'K6)P62T>7WC-Q;,L9.K8,H4*E7*H9)G8#D3=-8'2&!6($;,&=.2%,- !:+$C1"D0%C/#=,!;.)E6,K7$H3!M9&RB5ZJ3XG*P>*Q<%L7-S=,P6"E.%H43VB6VB,K6)E5%B1$B/*H5&D1&C0(@1$:+';-"3&,0!0 !4#%8')<.'<-(-'@.$?,">+ 9'%<*+G2+G3)C1'A2(A3(A3*C5.D6.G8-I9-K8-E3'=)#B/1[E*U@(J68Q>)H3&A.&=-%6)(;-0C4*=.(:+*=,'@.&G40WB0\C0Q<3L7,>,-D2,F4)>,$9*%;,&=+$>))F..E2*?,+>.*=,+C0+E1.@.0K81W@4[D6YA2P90I70H5+?.->-1F5/E4/A2,>0)@.0H64N<0J8.C11C2);*%6$&9'$7'*7(&3' 1% 2&$:+!8)1!3!$9():*(6%*4%%5'):,+-+>-&9&(7)#3$"5( 3& 4'"8*&=-"4&'1'%.#(5%'8 $/ .7'*3# -*'",!+%/"&3&-=.';')4$ (#"!! #!!&&!!$(%'#"% &%'%")") (&& +!%0$!) ##!'.)'!* #( #'  $%"(%1#2D58L>8F6AL@DLDDLCdHEjO=aJ:^I:\J6ZH.M:6VC8]E8\E9`H4ZD7_I8^F6U@#=/,E81L<9ZG>YF5R?6WC9^I=aMAfT>cNEfREfQ:\F:\F:_G7]G5ZH3XF5YG1VB;aK2WB2V?,N80J6,G2,G/-F.*G/2Q:2Y?.X>)S8%J2$>,'8*(9'(:)':)':("9%$;'$=&'='(;&';&'?(&@)!<&&<&(@))D,%A-&>+&9)%<+,L83[C`M6WF2QB4QA6RC:UD6RE2OA4SE0O@,I:(C4)C4&?/%<*+B0,E4.G9,I91O>4T@2U?1VA.S@0O?-M:-L90R?.R=.R<-R=-O:/N;2P;1Q:*K6&I5(L8(L8'L8*P;*R=-T<0X@.XB.WB+S=)O;'O=&L8(J7"E2A1"C4#K:%M<(Q>*S?.WB*T?-RA,P>*M=-P@,P>&K:*R=*TA'S@%R?)VA'S<&Q?%Q?*S@)S>(R>'P;'K:)L;+N=,O>/Q@0RA.Q=*N=&M;%P>&RA#O>#O;#P<(WA*XB'V?)U?'T@)T@,UB*TA*WB)XC#S@'VC(VC)WD*VE&Q@#M;(Q@)Q@*R@'Q=*S@#K:"E4A/E4"I5!D0%E4)N<'SB$VC&[H)_M'ZG$P=$Q<"Q=!Q@#P?'P?'P>&P?%Q>&Q>+WE/]I+YD#Q=#Q<"O;"N:$L;*L;*J;(P@#O@"O>#Q)N<#F6#E4,M;&O>)TC-ZI.ZI-YG.XF0S@.VC.XE1\I4aO4fT0aO6eS2bO3cO4fS2gQ&M;(O=(R@)TA.\H,ZG'UE-YG-UC)K:#A1'B4'I93XF7_M0YC0XC2YC/TC/WE2ZE6[F8_L2^K2`M4aK5aK3^N4dS2iS0cP/bM)\E)YC,ZD1_H8fR5iS9pZ4mV4kU2eO4^L/\H-]F.^F(R?#J7.QA/UA2XC0VA.S@1TD0TB,N=*P>-YG3`M3ZH3^G3\G/YC/ZG.YE1]I7bL5_J8aM/YD,U@)R=*O<-S?/VD.TB.VC)R>#F4*Q@.WG)UD*UC,T@,Q?-O>.K<*F6(I5(L50M>4TD-M=,N>-L<*H9)E6(F7*I:(H7#A1<,"6* 8)(B2*D4#:+/#5&/K;$G3$G4&E2(D1(B4,K;)O9%N9-ZF-YI0VC-T@+Q?-SA)O<(P;+Q8&K5)L85WC6UB6S>.K<'C3&B/,G4+E3(D1)?1'?0'@/!8+1$#3' 3#!4$%9+'<.(;.&;.'=-)@0$?-%@/$>-&?.)D/#=+%?-%?/!:+ 9+$<-)>/&?0)E5(D4&>,"8%">,(I6A..P;'D4(?0+?1/C33G5&<*,>--A/'A/'G5/UB-V@7WB2I7&#;*%A0$;)"7' 8)!9'!;*%@-(@-(?.-@2)?0+B1)D10G6.J9.R=2YD8[G4P=.F3*A.,?-/D25J8-F3/C4,A3.F55O=6R?/M9,B2-@0%6'+'8)(:+*7)&5'"3&2$!6&4$ 3!"6%(=+(:)):)+9(*=/0B31E5+>-+=-%8&)8+#3%$7'!6(&`L?[H9VC<\I=`LAcO>dO9_K=`LEkVFlV?fPCbO9YH0RB3UE<]J;ZG?hQ9`L3VB-K8,F3-G1,F/*D,)C,.I20W>.X?)S:+Q8+G3*A-)>-)>,'<*'=)%;("8%#:$&='(=''?)%?)%B*":'&:''=*'C/%C/&>+(8+'9*)A/*G45YC>dN=hP6cI4^D9]D9`F9eJ;fK;gK7dI4`D4aF8dH7aG-S<,J61L(D5,E3*A/&<*)>-)@.,E4-H;+J;/Q@.S?0WB/WB1TA/Q=1S?2V@.R=/S=/S=0R=1S;/Q9+N6&J0"C0'G4%H4'J6(M:)N9*R9+W>+]E'YC&Q>&J:&L:'K9%J6%F3"E2%H7%L8'N9$L7(O:*Q<*Q;+Q?,N>-L=.M>*J:&I7'N8'O<%N<$Q>&T@&T=%R?%S?(V@)WA(XA&U>,RA+Q?-R@-SB*Q?/UC/UC*P>&P>(Q@%R?#P>!O8(V?+XB*XB(VB'UA,UC*TB'TA&S@(VC(XD,VG*TE#N?)TE+XH&RB%Q>)UB)T@*S>*Q<'N9'H9$A1 <, C2#F4"B-%C4&K9'Q@"P@'WE'YG&WC$P<$Q;#S=!T>%RA*RA%P>&P>$R?%S@$R?,YG,YH'TC%RA%Q@#Q?$N@*OA)M>%O@!O>$P@&TA#M;!H6!D5"C4!D4 D3$L:(P>*Q?'N<)N<*TD)SC.YH-YH*XG)UE%G8'K;(L<"F4#G6*L<'M='Q@-ZI*YH,XH/[I/VA)VA-[H0]J1^L1bQ.\J.\K/_M/bN7jV0bN)O=)P>,UC-ZG,ZG*XC#SC*VE'P>%J9'H8,J;,O@4YH-UC*S@2[D2XD/VE/ZF1]F9cL5^H2aJ1`O8fQ7eQ1\M)WH+^J5bP,YE&S@'U?.\F4cM8gT5iU3kV.gS-fP&]I1YG,VC+WA)U?"K8'N;-P@+P?/VA0WB*N=1TD2Q@,I9)L;2^K5bO4`M7aK3_H-ZD-]E/_I3dN6dN2`J2_I0ZE(S>&Q;+QA-UC1XG.WC,UA'M88('I;)PA&PB&R@-XF0UD2SA2O?*F3(E1&E0.M-Q@/RA/P@,J<,K<-L>&F5#?0#?/$;/%?/*E5*E5&@18+'@1)H8%K7'M9+N:+K8/K+WA+[E.[I'N@&M6)P;,S>(N<$J9(M<,S<,S=0WD0TB3R?6Q>1N?&C3)E2.H6,F4*B0)@.(B3%C2!;,2%%2'"6("6(#6*';.'>0$;-(;,&;,"8*#<,"<-9) 8&8&#>+ :*8(7(3$#7)'?/*D5%?/#7(5#(>/#;, ;+/P<2X>.O>(E5,E7/F60F3-C0$;%2G5/F3+D5(F6-M>0P?/H8()- 5'(;*$5%1#!4& 4&*@0*C3+C4,C6(>2'@1.J:3M?*H9%H7%I8+K9-I6*C/+@.,B/-D12L70K6.B4.C4/H60J8/K9/L9+A2(=-!2$/!#4&';+*:('6'(8*#6'4$5"#6%%9('<*#8'!5&*?/(>1+B0,B0)?-(=,&:)&5('8**=.)?.(B0$?,#<-#>+.K6,F3)>0)8,*A05A2+/$!#-!$- &4&'5'$3% 1# /!,,("" !##  #!&-(')0!,$ "*"(%#%* !) !(# !)!'8, 0$*#-!,$-!%.!$*"&!$(,"(, '- 08,3=28?/0=/8I>`N5WG'L;,NB2WG4UC6TC:UI>ZPA`P<_LDaN7S@@aN>aMA^K9WD3R?8YF>aM@eP=cN>^N.M>1SC6XG=^LCcO?nV8dL2WB*J7*F3)E2'D-'D-'E-)D0'N4-U<+U>/U@1V@-N9-I6)E2%@+'A.'?*'?'&@)'B+%>('A*%A*$A*$=)&:''>*'C/)F2%@,(;*&:)+A/)E23PmU/I:)B4(B2*D3+C1-E3*D3)D42J<:TE5P@1O<3S@5UA4VF4UF4RF9VI6TG2RB7SF6UH3SH1QF-M>)E5/J80I7(@-(?-+D2/I7.J=.L=,L<-Q=/VA/WB0T@3VB2UA2V@1U?1U>1U?3WA/S<0R:*K3%E,'D2&E2*I6%E2'J6)K7,P9%P8&ZD(\F*VD(M=(L;%L8"J4!G1$I5(K9'M8(O9&M7%L6,R<'N8%L7)K<-L>)H9)I9*J7(L6&L9"J8#M;'Q>(T=%S='U?'V@(WB*ZC)[C)TB,VD,WE+UC,VD+UC+TA)R@&M;&Q<*U@'T?(V?+XA+YC+YC)VD*XE.\I,YG*WD)XE(VC'VC,QB+PA&L=)P@-VG+UE)VC)TB%O;-U@,T>%K6%D5&@1$?/#E3(I7'E2&G6*M<'O>%RA&SB&SB&P@"L8'Q=P9$S>&Q?'N>$K;%M=#O=$R>#Q='UC*WF+XG)VE&SB%RA'SF*QB(N?$R@%TB%S?'P>)O=&J9&G5&E6&E7!G4&M;*TB,VD*VD.XF'YE)XF,YH)VE,VG%O@*H:&I:%K:%L<)Q?+R@+S@'R?*ZG(YE'VB,VD-T>-XE/ZH0XF0XG*VE*SD%Q@-]K-_M2eQ+[H(L:.VD,YF.\I0_L+YF$O@$M='O=%J8+N=,L=/RC/VE+TA0WE1VE/SB/VF,YE0`J2_H.\F1bL4aQ7fP6dO)UE(SE/[I1[I+UC$M;#O=-]J1cP2fR0cO+aM%ZF$YE$WB/WE-VB*U?"O8$L9*Q@,S=/UC1YG,TB)O>1U@4RB,H8,P?.[H5fR7dR9cM7`K+XB0^G4dL0bJ2cM5cM/^H(WA(V@'V?,VE.YH1[I1[E,Q=#G2=/)K='L=&O?)UB)WD/VD4XF0R?,K8*G3&B0%J5/T>+S<.U?3ZD1U@1P@-L=-J;'D4"?/$A0%<0*D4+H8(F5*E6%?2#D3'I9&N8*Q<)P:)L91O<.T@+YC(XE'SA&L=+S=+R=*Q<&L:+Q?0UD-VB.WD-SB-P@.M<4R>+K;*F7*F4.J7,E3&?-)A/(D0"A/"=.$8))5)"6)!6)":,$;-$;-%=/*>/+?0&;,6'9)7' 8& 8&&;-9(8(9)#:*)=.,C4,H8#>."6''=*$8)1$!6(,I80U=+I8+F7.G9,C4-F3*C0)@+-E20H61K:/L<*I;*C3#7(*()".!/;,&5%"1%&4()8+.>/,E6(A3,B6%>1%?1-K;/I;&C4#D4$D3(G6*F4.G40I6.D1/F21I50J6/@20B40C2'>+-F40J8-C5&:+ 3$0##7'(<-)9($5&&6)&9*2"4"$8%)<+)>,0!:+(B2#:,&=-+D0(>+(>,&;+%6(&8)*?-*C0(D0)E0,F5-J6)I4$A-,A3/>3-D31>0$*!' +$-!(4&%4'$5'0"!/!!*, ,&!#"##$$$%!" (# &() '&$ * '"")$$%&&!,"!(##( )+;,#5%0$2"&1!#/'0")2%&-! &#(*.$+/#04(18,3:/=<3692?GAEMGORMXUP\XLZWIXXMOXKRYM_bVaeXafW[eUSaQThUSiVWeYSdWCZKE_P@ZH?ZFEdQHhW?`Q0QC-PC.PE&E70N<;XG5PD6SG9XI6YE?]J)G45UBMlYD^L7N<8Q?7Q?@\IB_NEaQ>`Q;_O6[I9^M<`O?aQ6eK6cH-R<,I7+D2)D1'E.$D-&D.)E1(H1,O9,Q<1]E3`G1^C2W@.P;+J4(E/'C,)D-*H1,J2(D-(D-$@)#>'%<((<(*@-,H4-L5*F.'?,(A.)B/*F3.L85WB9bL7dM2`J2]C6cI=nS=pX=oU=nU+F7+H7-J8/M>0N=-N:*M8+P;0TA.S?+Q4WA2W@4YA6UA2T?/S>*N8(I2&F0+J7,K7*H5)E2*G4,H5*J5'L8$R<*YF-YG)TC'M;$M:$O8#N7%N7&L8&N7'N8'O9%M7+R=$K8$I6(J:*H<(G9(I:'K8'M7&K8F4 I7&M:(Q:'P;&R=$R<&V>'ZB&ZB*[G.]J,[H*YE+YF'UA)RA&M:&N9(P;+T>-WA,WA-XB-WB,ZD+[E(]G.]H,]H)\G*[F(WB&S>*O>+P?*N=+Q@0VE0WF(TB$O=%N<-UC.UA'M9&F7&B2%C2&J9'M:)K7*L;+P>&N='TC(TD'TB&K"Q:&TB(UC,YG,[H&WC(XE'XF)UD*UD(WD&VB(S@*P>-R@,P?'J:%H7&H8$M;'R@(UC,[H-]J-^J*]J*\H)WF%Q@(QB$J='E9$G9&O>)WF,YH-YG-WE*XD+^I%XD%S?+UC-V@0\H0\J-SA/TC'O?)L>!K<+ZH+]K,ZI*VE)L<1ZG/[H-^J1`M*VD(NA&K;+P?-RA,P?.SA/UD.UD.UD2ZI/TC+N>)L>&Q@,]I-_J,_K3iV3hT0fN+^G*XG*WF-YF.]F$Q?%Q>%TA.bO+bP/bO(ZH&WD$R@N;%P?-VD-UB-V?#O8$O;&Q?*Q;/VB4[J-TC*Q=1VB0SB-P>,UB.`L/dP3eQ3cN1bM%U@+\E2dN.aJ/eN2fP.`J(XB)YC,[E.\H.\G.\I/YH*O;'E4)I:*L=(L>%M=&R=)W@0\I2\H;cM*N:%E2)F5&O9.VA+V@-U?/U@/S>,O@)I:-K<*E4)E5&C3+C7.I:+H8(I7'G7)F8,N>,P?-T@*Q<)N:(K7%H7%J9'P='P>)R@(Q?-S?*P<&L9-SA6\I-S@/UC,SC(O?*O?*N<2S?+K:)I8(G4)G4+H4(E2+E2(C1#?,!:+#9*';, 7*5''?08) :)$>.+A3-C4,?1';- 6(7'4$4%"9* 8) :* <*%>,&:+.F7%A0$@0*@3.B, 3#-#(<1.F7+G4.I5/G7,C4)>0)A1)C0+D0,E20K90K96RA3P?3O>0G64D6)4'% +%7'):++<.*;*-?./A/&@/)@2)@3*@3#=/+H6)B3">-#?/*G6.M;/N;.J8.H7*@0-B2/E5/E5/C4/C5*A/+C1-H55Q=.E5&<,%8(%9)*=,/D3$6&):,'9*0"1!$;((@-(>,&=/)C3#>0#:,'?/-C0"8$*=+!3$ 1"!3#$;()D0,K4-N60L8-H6'?/*@1'<,*;,5D3,7+$-#'4+$0%%.!!)$#2$#1#!, (- , '"$! #% &"& *!%"""$%$!) & "'%'(, .#!,#&"$0$$1$"0!-/#2!!+$-!*2'*2%'. %,%*!*/%03'06),3'/8,<=7=>8DHAJKDUULXWN[WK]WLXWKQUIQWK\]S]aUacUacT]aRZeSZiXZcWM[N>SCC]JC]JB\HD`OBaRGhZ1RD2VF7ZJ'B4+F41J94M@1L>-K:/P@7UE4PA1QA5RBaPCgUBiTBjTBgT=`P5_C1Y?-O8-F3.A1)A.'C,+H0)F0*E2+G0,J4+Q<1_H1dK+dF2\E.U?+N9)K2,J3-H2+L4+L5*J2)E.%@($>''>')=*$:&,I3+K2,J/'E.)F/*G0+I2)L5)N7.W@4bJ4cK/]E.\B3fKpR4SE5SE7WI3SF-NC2SH/PC0QC1Q>/P@,L?-N?+K:+L70S@6VG4RD/M@(G7(J6-K8.N90P<-O8-O:/O?+P<-S<,R<2V@3W@2V?4TB,M;*M9)L7(G43P;2R@/P<.L9*E2+D2-F4,H8+L;'L:+U@*XB)YB,SC)R?#P9"P9"O8%O8(N9*O;'L8*N=,P?(M<)L8&H8)I;(J=&K:%L7'M7$K8E3 G5#H5&L7$L7&P;%T=$T=%W@(\B'\G)]H*\H&VC'UC%R?'Q?%M:/T?,Q=.U?-W?.U@-T?*S>,YC+]G&_F/bK,aJ)]E([D)XA(T?&P>&P>'Q?)R@.WE*SB(P@$M=)N?+SB-UC+SA)K;)G7)I8+P>)P<(N9)M<(O=&N=)UD&RA'RA*K>%H9'M=%O= J8C4!B4"E5#G8$M:%P;%P;%S?&T@-[H+\H$TA#TA$V@*XB*YD)\E*[E*UA(N>*QA+TC(R?&P=)R@*VD'TA'UB+\H+`L(_K+`J'ZF'TC%Q@'L@"E:(H:$I:(UE)[I.`O(YG1]J/_K+^J%WC&TA.VE,YC,[F*XE*S@-RA'Q@)J=(N@,[K*\I*XF0XH3YG1[H*ZG+]H-\H&R@(J>*K=+O>/SB+Q>-SA,S@-TD.UE5\L-RB)K;'H=%O?+[I,_M-dQ7o\-jS&cI%`F&]I(ZH(ZE,^I(XE*WD+[I']J&_L-`N'VD%Q@#M<E5&L<*Q@/WD*U?'T<%R?&Q?.V@6^K4[K2YI1YE3[E1YF-SB+YF(]I'_J&\H&]J+aN,bO2iT0gQ,bK-dM7mV-bK)[E(ZD,[E-]E)YC+ZD0[H-O@-J;,P?+N>)N>(O<*S>,Y@.^I3bNDqZ+S<'J8-M='S@*WE%N>$L;,O?0O@,O@.N@/L=.I9+E6+I83K?0M=+J9*L;,N>/NA0SB.RB*O;+P<,P<%H5!G6 E4#F61XE/XB)T?+P?'L;)O>2YC3ZE-T=.SC/SD-UE)O?-S@/S@,K;'G6%E3&F3'G5*K8-J7+E3'>,&<+!9*&@0'>0&?/*D4'A.$>,$@.(@3*>2.A3+=0#7*2$/ !6'&<-!9*!;)'B0'A/&?-*C4&C3,I:6L?3G.1E30C63F=1F9.B2-D/2F42F6-C5>VG=WH3I:,E4+E3-J6/J70L9+O;*J7+C0&8)(- 7')A2+B3+C1(B-%>'%=+#9+#8*$;-+C41M90F8(?1(@//J70O<,O:*I8'B37'7L=5H9,?1*C4*D5&C0:(&F3,L8-F5+B0.@/.C14H70F4&6((:,(9-$4)#6(#7'!;(&A,&>+"9* :+7* 6*/E6(>*&;&)<) 1#!2$ 3" 9%&A,(H/,O5.K5'>.#4*)7-%5&#:$6@/",*!*;1%3( ("&"/!!/!' )+, '# &%+&&%'!-%#!#''+)'!!"!&* $' ."!/#-#'$!0(#.%$,"")*(&#+!*2'+4'$- )1!&,"(-#.5(07*&/#.8,6>5;B7FI>NQBQWHQXHVVJZWLVUJMOESWMYYOVXM__Q_^P^]OV\KNYGQYMM[KI^LRkYKfRLgRFbSDdSCcU1SD;^N<`N7OA/H5,D1,E5-G91O<3UD9XG9VF7WFB[LH\NDZH>XF=YI=YIA[LF^QAaNAbN@dNBfQ@`N>\M.K;+K:)F4'E2(?0*@-*@-*C0'B/)D2)F5*K6/U=7aG3gJ+bG4[B-S:,M5.N60P8-O7+N4+L4)I1)C0$A,#?+(=+(=,'9)';('?+)C.$A-%D/'F/'H/'L1'P4+Q<0\F4bK6_H4[B4[B9fNAnVCsY@sW?rW=nR1M=5P@1M>.K;0O>1P=/R@2XE*N=(F7(B4+E5-J9-N=,Q=.R>/U@-Q=.T@-T>/S?4SA6O@/N9.L;,H9,L;&J7-T>/YB1V@.N8+G3,I5*J5-O;*N;*P;*Q<)Q@+UC.XB&U?"Q;$N8)P;&O:(K<'L;&M9)P:-Q>,N=+L=(F7(J:&L<(N>)K<&L8%I5#F5 C2!F5!H6"M7O:$S>%R@%R@)ZH$[H$XE(WD'U>&S<#P9#M<$P?)VC)UB+YC)U@+S?-U@(S<'V>)^G%^I'\E'\G#XD+]I*VD,TD(N>'M>*O?*O?*N?,OA*L;(K9-O?,P@,TD)SD*M?$H9&J9)M<'N<$N<(M:(N9&O:*TB%S@$TA,SC(O?+RB(P>$L: H5 D3"H5#K7$L;#N=!L<(M=(Q?'S@%S@$O@&LA$O>'VB,_G,_G.\G(S@'Q>*VC.]G+\F)ZC,\E*ZC)XC(UD'WE+_J,dM,XG$TB%TC'N?)H:)D6,LB-TE*\J*^L*^J,\G-aN/eO-bJ+\E+XC1YH0\F0\F-VD+SA-QB4XG(VC*WG(UE,YI1]M7fS5aN3`N'XD/]J/WE&J9(I7,M<.O@2VE-P@+Q=.V>.T?/WE1^N+UI'I?(M?'TD'`L+gT3nZ1gU'fS'bN'_J)]J"VE$XG)[H*]I.aK'\F#YG%]L/_K#O>'RA'K<$E8+J<*OB+VF*XE0WC0WB,TB3bJ8dO7aK7^N3\J0\I4[E,ZF+]I*YH*VC&UB%XE-dP-fQ5lY1cP#RA"aL8q\'XE*XB,\F)ZD*ZB)[F,YH/WH2XF+TA1UG1UF-RA*O2ZD-T?-WA-UC)N<>/0L;5O?.P=1Q@.N=*K9(J9(N<+N>-L=&I8+SA/XE0WC0XF3\J/VB/P<.M:'J6*D9 @2"I90]K,XD.WB.S=)O:.U@0YE0XF-VE.VC0XF-UD-QA,M>.K=+L7.J5)F1'K4%K5/R=2P81M21L4$>,<,C/)G4*J6'G7&C3$=/%;."<.&>0)>1);.%9,5'-(9*)?0%?1#?1%B5(E3'B/*H4*J5*N82YBFePFdPKfUIaO:M?,>.AU=JeMJoYV~iX€k9^I3N>1J:/F7/F7/G8/J:*E5,G7-D6(:,./%9,'?0-I6+E1)?,)=*(9(%7&(;))=,+C15O=1G5.D2,F3*F6,J:*I:-H4(B2*D76QD2L>*F4'?4-D6+@14"*?//G8'E6-B3$8'.L73R=,H4.@30?5+7/*6/*=2$=.$@-%>,%9'2!1 2!4%/@2'6',:*+:)1 #7$#4"$5&5&&B.*D0'?()=)%8$(:((=+,B0,8+!,$2%$6)"."#!'* )),- -&%!!$(&'''&', $!%%%,!-!!+!$+$'!!#'&'!&/&(,&"" "%"#( !2#"-"#+!$) ","#0% (!)+4'/7+05+'+$#, *5)6A5.9-+2'17,8>3EK@LRDMRCQTIQQHYXKXWITUFLO@ML>MK>UTJUZOOPFHC:RI@cYTcbV\fVWhU]mZ[kZSfUMeRJbSEaT>[PDbVBaR9SF4N@2M>6QB6SC:XH;XH@[KA[KFaQQgWR_SH_MEZIDZHE]KC\NJfYGeQ;\F=_EDdKA`I>\H%C/)F2(D0(C/(>-(?,)?,+A.)C/)E40O<2WA1[B4`F5cI0^D3Y@1S;+L4.N80R;,O9(L5+M5*J2+G2(D0*E2/G1-B-)>(%9%":( <("=)&A+)E0)I2-P8,R:2^E3bH7`G0W>/X=4^G;hR?oW?rX?qX=pU;jT4^I0SB.J:)C3+C4,H5-H6-F4.G6.G72I9/M=3RB4R?/M:.K81O;4T@5SC.L?2PD5VI0TF2RA.K;0K;2N=5RB1P?/P@2TD2WF*N>&E7+E7+H7+J9-O>0UA0UA0T@1U?1XB0XA1X@4VC2O?,K9/M<.L<1P@+P>-T@2\E-R=+K6,I5/M80Q<1TA-P<)M9*P<'N<(O=+T@'U@%R>$L9'M:"I6$J8%J7&I4*L6,N:*N;&I9%F5$F7'M<'L;(G7%G8$F6@/A.D1"I3"L8 N:!O<$M;&O?)WE$UC%TB)VD'U@%T>$T=$Q@%R?'TA*WE)VD$Q?)UC+WD%Q>$R<&XE"WD%U?$U@'VC)XE+WE-VD+VE'Q@(O?&J:&H8*I:)L:+M<,M=+O>,R@,VD)OA(L<)M=&K8$J9'L<%J8%K8'M=#M;!M<%RA,XG-WF+VE+R@%N<(O=&K;#I7$J9$L9'M>!G9#I6'P;$O:%P>$N=$K=#M;&S?+ZF,\G&SB%M>(WD+\I.dO/eN/eM/eN0dN*]H(XF)YG+^J+`H+WF'UD(UC)N>&H;&J<*WG(ZJ(`M%]J%ZE&WB._K.`K,`I-^H-\G3_L2]H0ZH.YG,UC/XF3[K,YF/[K+XH/\L1]M4bO6hT6hU/cO.`K(SA"J8&J6)M<0SC0SD,P?,P=2YD0WA,SA0\J-YI,RD)VE'YG(^L+bR)^O(XI$]K&^K$XD(ZFO=$RB&XD*]F+[F([E(\J*^L+[G$P@&Q?+PA(K>(H:+L@,TD)VD0YD2\G/[H=oY2bL7fO7cQ3`M0]J1\H,^I)^M%UD%TB"S? TC+`O&]M*]O*XJ#M?&^I-_M&Q>&O=)VA&U?(WA&WB'WF/[J0\J/^J5]M1ZI.VD,UA+VA)WA/_K7lYAv^+YD4\G4ZE1ZC,S@(M;)K<1RA2QB/U@/T@/Q=-P;,P<+P=/UA2S@%J7/WB/YD5\F2[I6bO.XE.R@,N:+Q=(E6#E6'M=&R?*UC.VC8ZD5WB5XD4XD0UD.TA2ZH0YG-VC/TC(H9+H8-M8/I6)D1"C.)M:6XE-K64Q9/I3%<-6':*)H4+K8)I7"B1;-!<.#@1)D6-E7%9,&:-$8+ 4%(>/)C3'C3#B3'H:$E4&G5,K8(K7*P:6]H++=++A/5N<3I71H6,E3&@-(C/7R@1O:.J9.H:3K?*D5+F4)G8/K<(C1'B/&A-(C0)F3.D1#:&(B0(D4,F60I50E4/B2/B3-E3)C/$<+!:(#:)#9(0 #4#%:+,>/#3%.?-):)#4$&9&&5$!2#!7()B/$;('9'':(*<*,?0.D3-D6.B05D4)6'%6&!/# )#()&!*,!/!,'!"" !#,!&( )))'$$ (%$,&4',9.)6)"3$(%&%(0(-5+$*" &"&#-!&4'"."#+&/$%2'#3(&.#*3&.7*2;./8-'0&)2%3=05?218,:=1?@5AB8KK@Z[MSRFJI>TSJVQFUQFVSHXTJYUJ`[Oe^W]\SLLAd`Vqg_nf_ii]bj[\kY]kZ\iYWgXVhVMbQF^QHbTMhZFaSA^L8VC=\I@`M;[G=^I=`OCaQHaRPhYZl^_h\YbUQ^PI]LFaOC`QDcS+*B/,F3/H7.U92_D3dH5aF3[B0X?5\H5`K=lV>qY1RA3SB2O?-I5,G5/I73N>5PC4RE5UJ5VL3VL3SD0M>0J<1L=3P@5TC6WH8ZK1UE-N?)G8.H:+K;(L:(L.Q>1U?1Y@0X?3[B6[G2UB+L;-L<+I;+L>+P?)Q?-WA-S<,M8,M82S>3U@1T@-Q<(M9,P='J9%I7%L:$P=$O=#I7$G7"G6"H6#E2'D1+H4,O9*O:'M<#F5#F5'N;(K:$B1"C4$E6 @/?+C.$J4'N+P=)L8%H6*L;)K:%I9%K;"I9!L<#P@'WE+YH)VE)UB+SB*R?/RC*N?%K9'L<%J;"E7#J5&N9#M7$O:%O=!L;(O='Q?)UC*VF'PB(QE)\J-eQ+fQ.hS/jU.hP/iQ']J$VD,\J-_L+]G*WE*XE,UE+P@)Q@(WG']J'`M#\IYD$VC$R?*WD(XD.^H.aK0aL-]I/ZG0ZH1[I*WD-[H0bM,\J*ZH,\J3cQ3bP4dR/dO2hS.fQ-aM*YE$M;'J9)N=0TC0VD,R@2WE-UC0TC&M;/ZH/^K/\J,]J#TA!QA M?"K>$I>#WF([H&VB%Q?K8#M<"V@*ZD)YC*ZD,ZG-[H'UB$P@+UD.UE(K='I;(I:$M=&SA(V@.[I.cN8mZ3gR3dP0aM0aM.^K/\I)]K,bP%VH O?(XH%XF'[I!TC&VF'SC'N@(TB+TB%I9"F6(P>)T?&S>%XA&ZF0aM._L+aM3aO4aN/]J*VC&T@(VD-\I3gT8nW7fP4^I1ZE/V@.UA/UB3YI2YG3YH/YC4[F7[H/T@2WB/T?/VA0S@.S>0YB.ZC3ZD1\J1_M.\K)P>*Q>.XC,N=(K9$K9#J8#K9-TC7]E;`I4ZD/T@,P>,Q@.UC+SA)P>*N=&F6,I:6T@,D1#>-=-*K<.N>&D3,H3,D1!8+/#6&'E1(G4$D3"B1?0!@1%F7-K<)D67)'=0"8*'>/(A1*D4%A1$D4%H7$I7$H7'K:&J8-T>.WB'T?.[EEmX=`L/L:0H6BhRGnZ;bR7\L0P@'C2+D1.G33K74O<5P<-I5/K6.G5(A.';,#4((=-+C0,D13G52D3*>.)=-+?/2E61J96O@0H6,C1*@.'<)*A+.F/2P<6RA/I;+C6 7)&=+'D4&B1'C1*F2$?+#?,'?-#9(%<)">*&?//H83O;3M91K72L82L8%@,%9&#;'!=)!<(/ ,%9+,?0,?0.A0%8'#6%$6%"0 0 (=,%=+"5#!2$$5'&7()<-/G8-G76R>4G4%/#1!#4#+$'*#+!)&()%$& (!$ %'-"!)"*"*!($)** ,#.#0,8+2A3?N@#3&* 2&---%1'(2%)2&'0%"+$!,#&7')5)%."",!.!$3(-#)1%,4(2<.1;./8-+5*/8*4=.06'8<.DD6IF9RLDXRI}sXTJWSH[UJ`VNcZQaYOc[QcZQe[RdZTYTLQPEa]Qmf\lh^kj^ck^\gV`jZ_fY]fY\gWKXIMaRQfYMfXLdWCaPB`OFgUCdQEfSDgSKj[Ul_Th\Yna\na]j\acYU`TK^PHbPLfUB[LC\IGYHLXIFWH=VG4TF-I1+H/,F1)B.+C1,B/+C--H2-I5.K7(H2/U<3_H3^G4YC4T=4\B5ZA/S=-Q;(L8(M:*O9,O8-P8,K4)F/+G0.N40M3,D.)>)*>+'=+)?,)>+,@--D1,G3.I70W;0^B2cH8eJ4^E3^D6_K9eO4cM8hP8gP8gO6fN0XC.L92K9.H8*G7.K;4S>0O:2Q<4RA2O@2RA2RA-K:.I9.G5-G51I<5PC8VH3SI6XN6WO7UH0M?0J<0J<1N>6VE9ZK>_P5VG+L=-L=/M>)M;&H7)K:*L9)K8*M9.S<0X?.V=0[B6`J3\G+N=(I9)J<'J<'M;)Q?)R=,S?+Q=-Q=3WB6YF2XD+O<.S?-R?'K;$H7$I8!L9!K9$I7"D3"E4%I5&H4&D1*H4*M9%L6$L:%J8$H7$J8"C3$?/"@1%C4#@0?,!C.#H2"F6 H7"H8"F6%H8&N=(RA)SB+TD)VC(YE$XE%XD#WC P>#SA'UF$RB!SF&XF#UD"S?%Q@$P?&N;&N;$L:$M;+UC&SB&WD'RA&K;(H6%B2-K:*L;+K;*J7'K7(M8)Q<-RA,O?.S@,N:*L:,K:,L;&H8'K;#J:!J;&QB$UC,\J-ZI'UA-UD/VD/VG,RB*P?-TA+Q@)N?'O<&O9'O>&R@#Q>'TA'P>(Q@*UF(SD%QD*UG*_M-fR(eQ.kW,jT-kU-gS']I%WE+ZH,YG,ZG+YF,YF,WE-VE*VF(]J*`M-cP%\G#TA(UB(Q?$O=)XC._I-bJ+_I*ZG-XE2\J2\J'UB-_K']I*[I.^L2aP4eR1aO1bP)]K-dQ0fS.bP*WF!H8#G6+P?.TB.TB/XF2[I0\J/TC%K9-[F2cM/aK1_I&O?&I>%C:"@6$C9%VE+ZG'Q?%O9!I5&N<%T>%T>'R@*TB(RA(R@(TB+XG.YH+RB)OA'K=*K=(Q@#T@,ZE.^K0fT5iU1gS3hT2eQ,]I-[H-ZH)[I4fY&SF"OA"RB Q;%W@"Q=+XE-WD+S@-U@-S@%F7$F7%I9,S?*WA*]G,eM.dN,bN+cN1eQ2eQ3eQ0_O)VE)VE-^J6kW5jS8hR6`K/YD,S=-TA0YG3]K/[I.[H1\K4]K8`K4ZE3[E0XB0XB2WA3YC0YC,WB3YD1]L0_L3`O1ZJ0VC.ZD.U@'K;%H8"I7$K9-WD/$C4*E6#>-"?*&?,$:-2& 7(#?+$@,!=- >->/"B3(I8+N=(H7$B1'C3.H80G8/E6,A2(@1(C3&E4!F6"F6'K:*P>3[I1[J-WB0YEIp[EhT.K9=VDCjUGjX:YJ.I;(?1(?.&=*-E21L8/J62M96Q=0J9.H7+D2%<.$;+$9,/A1-B1(B..I54K88K91J;>XHC\L>YH5QA,K;,E30F5,?1&9&$:$+D+5S>7UA3M<)C3%:+,@2$<)%=+,D2)A.#9''<) 1*5(*C1+C/,E//K23P?0N=1M;3L;.D3.$6%&;*%?,";)#7%".1C4.C4,A33I7*A/$:(#4# .%5$(>,#:(&9( 0$%6)%7*)=00H91M<5Q>'8%"-+!3"2"!0!%5'$2$#+%%' *%%% ((/"+3%'.!&.#$-!#!",$-" /""0#'4$*8()6%)6(- *(-"2#$:+"7(4$ , '2"$/"!-#!3%&;*-9-!/!!0. /#)=1,4+*4(.9,-8+,9,+7+/:+/8(8=0IK=ML?JI<]WNYVLSQGXVL\WL^VIdYQcXPf[SeYRf[SeZReWRYSJLJ?faVlg\ki_nlbek]eo_dhXbdWef\VYMRXKZgYSfWWm_Sk]KdYFaUKeYLgZJgYLiZVj^Ye]Wc[O`WOeXShYXcYQ_TQbUTfVUbUS^QN_QP\OPYOKYN3U?3U@2VC,N?0L=1L>.I9.I9/J:.H71I@5OC7TG3SE5SG9WK;XM4PD2M?1L=1N>4TC9WH;YJ2RB+N<*N;,P=)K:'G6&D4'F2&E2&I5,Q<0V@-W?/\C3aL.[I.TA%J9(K:&J9'N;&N;&Q=,VA-WB/YD.WB3[G0YD,VA.VB-T?(L;%I8%J9$L;$M<"E5!B2!C3&E5'I9&I9&J:)M<$H4$K7%H6$H6!H4B0 <*"@1$A1%A1!?-!A. D/#B5@1 E6!E5C3!K;!M<%P@*TC'RB'UD(WF%WF$UD"R@#Q@&SB'SC(TG'VE#TA$UA$R>$R@'T>"M9!I7&N<&O>%P?'PA'L<%E5)F5&E2+I6%G6(I8(H7&G6#F5"H6(H9-N=1T@/S>-N:1Q@+K8)J8'J:$J9&O>)SB%SB)VE-YH+WD*TB-WD.UE-TC+UA+V@*UB)TA+VC-UD)RB%P@#S@#UA(R@&P>%PA%QB'UE+ZH,bQ-dS+fS+iU-jW-iT-eP'\I+[K,XI*WE+YF,WC(XE+[H/]J.]L,aO0bN.aM+]I*ZF)WD)TB+WD,ZE*[E+_H-`K+[G*UD0ZH4]J.ZH-_J)aJ)^M+`O3iU1hS1fT)^M&ZH.aO.aO+ZH$M<B2#C40RB.T?.XC0\J0]L1^N/TEB1*UD0dO.dM0[K(L>)E>'?7#@5&E7)XI)VD%P:$L7#J5(O;&R>%N<)N?*PA%K;*RA.ZH0\K.XG+UD*RC)QB)QA)XF*\H-^J,[H*]K2eS9lZ9kY/aL*WE)TB,WD.\J*WI!J< G9I9 N7!N7"N9(U@.YE-WD0XB.UA+N>"E7!D4(O:(U?(]F-gN/gO-cM+cP-aN0eS3fU0bP*XG*UD0_L2fS.fO5fO0]G,XD*S<-VC*VC+WF-\I0`M1\K1ZI5]L6^K3]I/[D0YC.S>.S?)Q=.UA8\J5]J0\K6`S0VG1VE1\F.VD(M;)L;$H5%M7*U>5ZH/UD*I9%@0"@."@.$>-7'$=*)B/%;.#6*"8&!;)$<*$;+$;,#;-'A2$E4(J9&J9*M<+K:2O?2M:.G4*A0)?0'B2'D5$F7%F8*N>)N>+UD0]J:bQDkZKr]AeR@`M8VC6ZF7VF1K<#:,)>.*>-*?-+B/+E2.J6/L8/I6,G7,F7,F7$@.$@/'B//C2'>,-I45Q<1K82J8-H8'A1%?/&?/5%!>-0H54H8,>0!2$%<'4O67R?3M<1L:-D4+B2)A2*=+*>/';-&9+!2#$5$$2(%;-'A/5I64G3&@+-G9.J93O=1I9&8* -!,1!3##8((<,':*0C4+A3/G7.G5-G58&&:+%8&+=*!7$!9&%8)&8,)/+@15N=9SB(<+'3$"-0 %:,&:,$8''=+&9+'2%&"'!,!+%/#", ", &1$,7))3#)3#%." , '!+#'4+$2& -"#0#/+&#0"*( *!$4((<.(?04%)*!1! /! /$ 2&$:().'9'1C2;L?*:2&0&'0&&4&(4&$3%$3'(5'8B5LSFKPDFK?MQDZ\QSVLHJAVWM_\O`[Kd\Re]Rg]Sg\Se\RcZPaVOPLDUTIhfWkh[ji\lh_dh\in`hi[eaWeaW^XQUVLV`UUeYRfZNf[Mc[Pe]Pe[JbVLdYOg[ObWVa[]c_Xf_PdWTj[Yj^Zg[`k^_gZ[bW^cY\dYYbXS_VEYM@\M@cR+I0,K2*E1,E5,I5.K5,I2,J2+L5)L6-G3,F2-G5.S=/\B/cD0bJ2_I/VA+N8.K7,I5+J5/O:+L8+M5&I1%I0$K6.P<-K7(C/&@-$>*+>+*?,'@**E-+L2,S81WB.ZC+[C1_G6bH:iN9hP:jR4dJ2`F3]B6^D:_J5\F.S=*K8.H62H5-L<0S>3W?2YA0TB*N?.H9+D7+F5*E5+F7.I90JA2OB1QB0RA1O@6RE5TJ4OD3NA1L=,J:4TD8SC4P>.M:(J7&L6(P9*H8*F6'B2'C/&F3%H5)N:,Q>*T=/ZE.]H,[I.U@(N;#G6&J9$L8$N8&S=)V@*WA*XB,YC0[F-ZC/[F0[F-VA%J9"F5&I9&M=%L<"E5$B3"B4)F6'J:&N?$L="F6"D0C/ C/!G2E0A-=)<+#@.$?/">."@0@/ >1@2 D6D4!F7I7!O>"P?%Q@%O>$N=+WE%UG"RAM=%RA'SA(TA&NA%P@%R?#S=%U?%S>#R&O?&J;$D5'B2)E5)H5'I4&G7$E4!A1"A2B3A2#?1(H5.P<2XB.Q=0Q>.M:-N:'L8&L;(P>+UC)TC+UC(SB-UC*UC+TB-TE+R?(S<&T='V?*YB*WD*UE(RD*WG%WEUA&R?%R@$O@)WG)XF-_J+_N)_N'`M+eR,gS)cP)^J(ZH/\K)TE+TC-ZF.XC([F(^J,`L1aN0`N/cM-aL+`L+_L,^J,]J1]K1aL.`I0dL6gR(YE(TC,UD.VD+WD,^F+bL+bO%]K*bM0iT2jX-dR2aP-]K)ZH#O>$J9?0)F71RA/VB1\F0_L/_N4cQ0VF#G7/[J3gU/gT/\K&K>'D<&@:?3%M;&TE"O<)R>'N9%L7)P;&M;&J;*LA$G<"G:-SD.XF/YI2\K0ZI+TE*TD.[J*`K,aM/_L-ZIL:0_O)N<@02XH8ZJ6\H2[K2WK.QD2VD4]G0ZI,RA-O>)L7G1)S:7^D5X@/Q;)I4<):' :,7)7('N<%N;/WE)SC'K:#@1"@-%C-#='!6&$<'*C.'>0%;-"8%#9''=++<.':,'9,'=0)G7(H8'J:+Q@/RB.P?.P:'G2+G4+D6)F6%F7'D7&C7)I;>/%O=)VE/YG2]K-XD6`J3ZF0V?,R=3RA)D3$;+'@.)B.+?-&>+)D13O<4P=.H7*E8(D5$B2(G3,M8"B-$:(7#-K5,L40K91J7*@1!5&"6'4$2#$<,0H51E7*:/+<04L:7S=-G4-G2.G4+E2.H7+D5(>,&<.#8+#8,!5'):+*:'%=*)D/3G6 1#)%?0+F3,I3(@,-<*(1$*+,, 1#5()<-/F80K:2N<4O='?-+A0+>+';(7#"<(,?0(>/(>/*?0/E3;SA0H6+6('!.!(;-'=/*@I>@I>EMDNTI\\N^ZK_[N`ZMd\O`YLaZN]ZM_TOLJ@Z[P`_QjhYhhZjf]bcY[`Q][Nb[Q^ULVMIVSNT[QVfYQeZOe]Yi_Ug[RdWUg[Xm^Yn`Tpd\mf^dbZa\R]TZgXZj^cm`cg[]_T]eZ[h`bg^Yc[J\SD^QGgWFjV2M41L42O52Q6,P8.Q8-L3,G1,F4,F40E3+C1+F4)H5,N91W@/SD/R?1Q;2N8.J20I3)K7.P:-O7,K3)I1-M6-N8.R:.R9+L3'E-%A**>)*=+)>/(A/+K41W;1Y@0ZB.Z@2^G7cL:fN2Y@.S>*N:(I4'E1)D1+C2.F31J8.M;0N>0N=3PB2RC0SD8UJ9SI4MD1K>0Q@1U?>VG8RB1L<+G7+G6*C4*D4,F7+E7+F6+H4.M5-R9+R;,S=,UA.YG+WE+S>(N9'K:(L;%K;!I8!N<&S@'TA)UD(UB'VC)ZF-[H5^N.TB%G6#D3%G4&H7#G6%I8!E4"F5+K6*N<(L>'H:%C2 B.#?.">.!>-@,>*:'5)$=/#?-!@-C/E0E3 H6!H6E3E3G5"P<$Q?#M>&J=&O=)WD&YC!P; L9&P>(TC%RA+Q=%M8)Q;'R=%T>#T>&O@$N=&P>'R@&P>$M>$I8$C3&C2%H3&K6#F1!D3 A0$@0"=-#@/"@0#@0&D3-P<3VB7XE6VA.O?,N>-N>+N=/TB2XE.XI*WE'UA+XD/WF+SD,P?,Q@&L:"K8&S@'WE,XE(UC)TD,ZH(XF$XA&UC'RA*WD)ZF,aI+\F)[G&ZE']G/eP.cP&WG)VA*WF*XK*WH'VB/[D(]J'^K&_K+eM/eN4eP-dJ(aH(dK+fQ3lX1jW7lW6lX3iU-dP-bN%XD+RB.UD+VC.\F-^L*aN)^J.^K/bP0m[/jZ+]N+bO([K*UI)NC(I<(E7.M;3SE3[J.\G3aM6cR:fY2\N/[L-^L1gR2dO.[H)I;&A6$B7C6&N?(L> I7%P;%P;(O<(N=%I9)M=)M?'K=)L>1SD-TD+\J+fR*`M'ZG/aO4iU0dS5fU3bR*VF#N>*WF2bP0`N$T@I7)Q=2V@1WC'L*Q@+UA,aI/fM.cM$YB(_H)aL'`K,eP,eO.bM+[G-XE(_J0gR'ZG%T>0\G.WB,T@-U@+S>&P>-ZG,[I%F4&G8*PB6cU8fT6`L2YD+UA#P>+R@4YH8\L5\J6ZH)M=+O=4YE6]H.XG+Q@/Q@%H4%F1,Q9/UA.S?'H5#?- ;( 8&:'3 ;(&C2)J9/TB.R>-M:&D1"B/*E3(;*3%%=+*C1%@1&=0!:("8*!<-'A1&<-+B1*E2.H6(G3$K6&S=-WA/Q>4O<1L95Q?3N;.J7,K8&H5&C3)A4 <1$I;&SB(UB*SA*N>0SC1RC(H9-M>+N;<_IEfQ:U@4"$;)$:,-C6/I;0L>*I65H:-G8+L9)I6&B0 6$$2$(<,-J6*J5/M9/H9(9*"4'"4'"6*"7)(A02D81E5.E22K46P95P:3G51E42F72H9&?/.I92I5.D3$>.%:,%:*';)+?-(>,/E4%:,) 0&&>-+E2#<+3#%7(!/!!*&/"2) 2)$;02I;6M<2K7/G4&>-&A.%@,$>*";'#;)'>,&;)'9),@12D57J87K64D8*:,.?-0C10G3/H3*F-2E11A0+;.-<0(3((2%-8+*4'",'5'2?1);.)5*+4'&0#$5$#:()<.1B42B51B45G9BUF6J72A2'5)*"4'"7*(?/,A3-" -"($. %4"!1"+0"'8+1B14E4+7&'0#& *!'*##3'"1" (%+!&,&"*"#,").#+0& )-6.+:/:C:>G=HRETVHa[K[XG\ZL\]QfcZf^VdXPUJEF<8A<5PKATOEVPEPNCWXLWUM`\Ug`VkbXb\UXWN[[V_c]^d^[c__fa[d^Ye]VbZalb_h_We`\fc]b`[]YTUN`bWegd`b\^_UZ]T^aYY_[\bWQaTG_QHaRPjZMkY2P71N53R97W=.T<-P8*K1,G1*F0(C0)C.+F0)D0&F2+K8/P=/P=/O:-N51P71O7/L4*P3.T71U9,O6+J6*H9+O60V:1V;/S8*J1&A-*>'':'(<+*A/(F1'J1.W>5^E8bI4^G6bK=iR5M:5P=5T=4V>1W?/T?*L9)F5%@1*B3.C6.D71I<1M=/L;-J:2P@4VG4XI7YO9ZP1QH.OA/TC1YC=YH=ZH2N>-H8)C3)A2'B2+E5.H9+H7)H3,N6+R9-S;,S=,T?-UC*SA*O>*N=&J9(M<#K9!K9#M;'O=&O=%P=&TA$VA&UA(VC,WE-R@)L;$E4%G7&H6&H7%H5(L8'K7)M8+Q@'L>'G9#@/?+#?0!=-:+>*?,>,!<.$?0"A."C0"G3"K6%K<"I9"H9E5E6!F7&N;#K:$G9%D6#D4)Q@%XA#Q>$M<&M;$M;!K;)O;%L8'M:'P<'U@"Q.!=-#@0!?/&A1$C2*N83YE4ZE3ZD1SB0SB0SB-RA0TC2XF4ZK/XG+YC,ZD-ZF,WC/QA.QA%K9"K9&S?'XC+YC+XE,YH-\J*ZG&XE(XF)WD+XE,^K/cO-]G(WE'XE'ZD-^K,\K"Q@$O;(TB,YJ(XG%VB,]F%]I$]H&^J+dM.dN4gP*aI'`I$]H&_K&\J+aO1iT4mW,dO.gQ0cO'YD'RC,WE-WF-ZH,[I'VE%XD*ZH-aP-jX&cS([L*ZJ(WF&QB(N@+M?-P@-P=/TF/[I1_K3bN/]N5cT=iZ8fT-eR2lW.eO.`K$L:&F7%H9"F7&K;"F8 F5)P<*R=*Q>$G7&N<*SC'SB)UE/ZJ(PB+YG/fS0lX+dQ(\I2fT7kW1fU3hX/cR*YH%Q?(SB*VE)UC"L9 G5*N=2U@,P?#H8"G7 F5A0%F4)M8)P9+U<1]E5bK8eS2^M1[I-XG0\I2aK3dO0cM+]H)[F)[H(ZH'YG-bN*`L(\I'ZF)[H-cO2gR%VB)XB0ZE.WB.S@+P='L:*Q?)TC&SA&J7B2'OA:hY*YG+U@.VA&R>"O<(O=2VF3ZJ*RA,Q@*O=)L;-S@'N9+Q>,Q>)K6>+%I4*N9/WB/VA#E1=*8&"9' 7'4"!9)#>.$C3+M=(L7(G4!=*=).H5"5#!3'*A/,D1'@3+A3":("6*!;,+G6-E5-H7.M9.L:*G5+J8,R?/UB1SA/O?4SC8WG4SC1QA-N=)K9)F7)B5$>1#C4)P?0Q?&E48)-I:'B3+E6,I:%C1:\H=[G0I60 %?,&?/(A3.J:.M='G43N>3O<,G4"=*!:($8((7')>+,G3.K62K91F8,?-):+$5)#4'(<..D51H:3K:9R>@YD5N:-F2.H0.F05M73K8$@+/L94N;0H8.B5#7()?/)A.'A.+F2&A-0$;+(:.';+1$0!"6'&8* 0!0 #4'"5'/*(&>10I;/I7/I7,F5%>/#=-&A0(C1"=,!<)&A.'>-*?.+<.*:,,@.0I4/E4/D30D3.F4,F3*G3(E/+A-+>/-@4+@31B6.=//>/)8))6(1=00<.&5()6*+9+,=-0C21G34L=3I:)=.(<-#9*$<+*>)"4#!1$!0"&7*,=1,C45'/$-!(+3 #8(*?11F8,C4)@0"2##-!%%*'("/#-#,$-##.'&"+!&"$.#&0''7)5?4),=,*@.)D1&D0(O65\C:bI8bK7aJ8dM-H7)B3+A2-B5.E7/G90J:0J:1K;2P@5XG4ZK9[S;^U5XM-QD.TC2YE9YD8YE6UD-I9*B5+A4*B30J;5P@1O<,M8*M6+R:0V@1WA2XB0WB.UA*N>+L=$H7*O=%N9L7$J8#G6'L:%L:&R@&S@'TA'SA&O=*O=&J8&I7&J:&I8%G6)I6-N:+K7(L:(O?(OA'H:$@2"B1'C4#A0#>.:&=* @- ?0$D3!E1!G1"J5#M8&J;$I9#J9 G7#G7"G7$I8$J8#E4$?0"@0(O=%WC"Q=$K8%I9$I7$J7(M=(M=&J:(M<'N>$M<C2!I8(R=%P;"M: K9 H8 A3#E4#G3#H3#C-#>/#>.<,!>.@/ C1(C4+K:(M<,T?-XC.ZD2VF2WF0WE/WE3ZH3XF4XH0VE.YD,ZD-[D,ZD.PB-PA+P>'O=(V?&X@-ZD,\E-\H,\K*YJ(WF%XE+[G,_J2eS2eQ)WC&QB$Q@*WF+XG*TD"I=%L:'O>'SB(YG'[F&^E$^I(`L+aN+^K']H1fQ%]J%ZH UB#VE%WG(XG*aM0hT+dO*_K,]I+YF'UE&UE*WG+VG)TD&PA#P@-[K,_N(`Q(_P$WH)UE*UE%P?.TD/WE-TC/WB-VG/\J0`K-`J(ZI4dU,RB&M;#F5"C6"F6(M9+P<,P>,P@,SA+VD$SB-_M/aP$UD3hU.jV*hT(aM)`M0gT6iW1gU.fU-dS-^K*VD)SB(R@*Q?(M<&H7*J9.O=&H8!E5!E5#I7E2&G5$I4$K4.YB2]H5cM2^M0[M2\M0]L3eO0fL/`L1aM-[H(UD(VD&SB,WH+XH+YI(ZJ*^M1fU3hT-_K%S@+VA-VA,T>)N=(J9(L<*N>%M=#O="I5>./VG/[K"P>*T?*S>#O<$P=%K9(M<)O?%M<(L<"E4%G6(K:!D2'J60Q>"B/<).R?#H6%P:'P:!D0<( 8' 6$!4#!5%"8)(@1'B2=- =-%A0:*9**B2(:+ 2%/D2.G3,E7)@3#;)$6*'@1.I92M=.K9*P;,R@,M<-M<3WF0WF/VD6[I6[I1UC-Q@*M<,N=-O>,J9)D4:,=-,M<6P>4O=+G4-H9+G63J;1G:0H9;VC2M:'<+.!#=,$@0'E4/N>/O>0P?+M82M:/E4&9(%8*&:+,@++C.,F22N,(;,)=0-B50G94P=8TB8Q=4N9$=(+E/'D,)E-.I4/I6/K:*H8.L90I71D4.A0-D2)B1,H3-G3'D,(A.(<, 0#"/!)+#4&(:)$6%"5$$6)/! /"/&/$-I6,H5)D3-H7+E6&@2&?1(A3%@1<,!A-,K6.G4*<,'5''6('<,(B0*B.*A.-D1-C1+D3'B1'@.#6('8+%8-*=1*=0,=0-?24D8=J>2=1'1&&1%&5(,@2-C1,B/.A.#;*1"/ 3$#8)$;-&>+,C/+B0';*9L;8K9-B3%:,%9-&9-!5'(=-,B/-D2'?-3%!7)"8).#(%+, *#)!*,!. #/$/$,$ )% )()%2%,4(5?3HRFUZN_\Nf]SZSIOI@\TKmdXncVkgYkdWleXri\ug^se\h`U`YNgaVjcYndZk`UXWM[YQ_[Va_[c`_c^`debXZVNOJVXRVTOTPLY]T[]Y_]Ya[[b[Xfa]c__d`^ea^gd`_]Y]\Y`b[UaXSfZVn_Um`IeX3W=1V=/P74Q9/P;+L6,N6/Q9/O9-M7.Q7,O5*L4*J2+J60O;2N8/N5/O5,O41U:-P7.N6-L3,M2)K0"E*%G-&I/,P5,R6.T8*K2'E/)C++A+)?,*B/(B/,H5-P80V>6^E8_I4^G8bJ/Q@3XF7XM7YM8ZO0PD-M=4TA3XB3WB4VE/N=,E8/E8/H95Q?9UB4S>+L7/O;/U<3YC1XB3[E4]G/YC.RB(J;$H7%I8%M8 J5#E4#E4%F5$H7#L:$P=$Q>'P?&N=#K9&K:&J8)N>'K:(J9)M8,J8*H6'H9$L;#I;%F8'F7"C4&F4$C3&A2!=*!>+ @,$F6%H5#I4#J4"K5"K6#F7"G7F6 F6"G7%I9$J8"J7!E4!A0 B1$K9'VB&P>$I7$E4!C2#G6'M=%I9"G7'I:&J:"G5"@3"A1(J6$F3$J5&M: D6#D6(J9$J8$I5&F1)E5&C3!B1$F5$H7"F5)H8,M=+Q>%N<%Q<)V@'K:2ZG1[I2]J1ZH4[I3VD/UC/XF,[E)XA+XB.UF.TE/UC-UC*W@)YA,ZE.^H*]I)\I)XG,ZI)]H+^J-bN/hS2fR&P?$J=*UD'UC)UD*P@!D5$I7&L;$O>'VC$[E%^G#`H,bO*YI'VE&WE.fP*]KP>O?!O@$SC%UD(\I)]I(]I,^J.\I0ZH)XH(WG)WF+WH+VF(PA(N?,XI(XH)WG)VH*WI'P@"L;)SA,XE.ZG.[H+XB)TE.ZI-\G0`L*[K2fR8gU/_N0jW2r^3p]4nU/aI0_K>jW-UD&I6&J;#G7'L80UA1XD0WG,WB+VD)WD,_K1dQ4gT7lZ/jV'dP(_L)`M+cP4gU.cR.dS,bQ-_L0`J.[I,VD.UC*N='H8(G9(K9)K;&G8!C4B1 E2"A3"D3%L:/XF4^M+WH.WF3\L0[K6dS4hR,eK-_J1`M,YF*UD(Q@&N>(QB(RD,XH'XH,`P0gU.cO+\H+UC"J5-S?'N9,O>*L;'I8'K:!J7#M;!H7#H6*P?#O=$O='M;#M7'S?$N=#G7(J:&L< D3%G8:+?.#A1:* @-*H4"@-)I6,P=%I8,V@+S>%J6%C0"=+5# 2$"6'(=.(?0":)6#6'"8*5%#>-.F6"3$&9+.E32M:1J=.H:&A.+?4-H8/M=2O?.O=+S=)WD,UB3WF3]J/[H(R@)Q?0WE+O>)M;"C1&E4%E4.O>.L:.K9-J:0M=.K7JkWJp\@fR>]L9TD;N?4I7-E3.%8(,9-'@1(D2.N;/R>6WE/O>'H52L:2G60B1/C2,C2*G1.L61P=.L9'A2)A12F3';)"7(-B5/G76O>8UA8S?,C1$9'#9()A0'B0)C1*D4+F71PA+K>$C1/H62H68L;/D2.F4*@.%:'#8%#7#1*#,*/!%9'-@/.@/,<*+ (0%:&)@0,H5.K8,H8+E7,F8(B40H:%=1";.#@1+J6+M5,D2&9(!/#)6*)=.-H6.B/*>*+>-,?.0D50D5&7)".!","-"#5'(8*.@2+>/)<-.A2#2$&0#(2'&6(&<+&=,'<)'9&'9("2",. #2%$3'#=,#?+">*#=,/H6+B2(:++=.(:.*?30E6'=.':(%8')*0 "3$"-"$& , !-!$-!)*!"* ,#+!/" 2&*"!+!$."!+!*! .$&1$+4(3=1>I>U[OdbTi^V_VM^ULlcZlbWqgYgfWmh[ph[pgZsfZsfYg\S]SIhbWjcXlcYkaWWVM[YS[YU_XYYSTYSURPNSSNSRN]YUa\Wh`[de[b`Zheaicbkccldagbaha`jbbhba`]Y^]YgfbXdZSgYTh[NcVNg[4Y?1UaK8]G3V?0R:4S<8XD5TB/J5+E2*D1-I6.K8.L;1K=/H:-G9/K;1QA3VD5WF3UF/QB/M@-I:1K;/TB0TB/RA(J9*G8-H80M?6UC9XC4T>.N8,L7/S=4ZD5]G3_H7eL3bJ/WD*P?%I8'K9%K9"I7#C2#B1%D3#E3&H7$I8%M;%N;'O=$L:$K9&L:&P<&N;)O;(K:)J9'F7%E5!G6"J9!D4#E5$H8%G6&E4&A1%?-#@-#C0'H6(L7#I4 J3 I3 G5#F3 E2 I5"K7#H5#F3"I7!H5"G1$D0 B0E3#M>%L:%G6!A0#D2$I5#J9$I8"D4&F6(E6 >.$=1$>0$B/"C/#F2%I5 C3 A1$G7#K:#J9&G8'H7%G6$H7%K:'M;(M;*L=-Q@*R@$L:&M:'N:#I7,UC/\I0^J.ZG1XF1VA/UB.WE(TC%Q=,XF*YF)WD+WD,VC(T@*XC+XF,]I(]F']H,\J,YI)_I,aM,fQ/kV/bNF6$H:*SC'TB'S?(N<&G8#H6#I7#N9(XC)aI&aI&bJ.`L-UF(NA%RB*`L-]L!O>"P>$P?%RB$TC+ZG,[G-]I-\H*VD-UC(TC(TC*WF,ZJ0\K*VD&M>-\K(\I*UE-WF)UD(RC,VG,ZG-\I/_K/_L*WA-VG.WF2]H3`K.\K.dO.]J+YG.dQ1l[.iX/gO.aL2dP9iX-^J)SA(O@%L:(P;+U@/[G0^K,[E-_I0dM1gR.eQ3jU4hV+cP*`M,^L)^L*dP/eT/aP3bR2`P.`M/dM0dP2bN3^K0XG*PA&K:'M8*M<+K<#C3"C3 B3"A2#F6+P?1XI.XI K<*TB0ZI0[J:gU7iU*aI-_I1aL-[F,VC)Q@(M=$Q?/[J0\J&SA3eR/dP([G*WE*R@#H4(K8&L8)M<$G4$I7"I4"L6"O8"H7%G6$G6'N<(O=%I8&N9)R?'L;"A1'E6#G7B4$C45'!<-%>/6&!@.)F6-J7-K9*K7(K6)P;-R>+N:%D1%C0!=*#9*'=. 7("7&2 -1# 3$ 3$#;,&>/%6(,@29P>6S@0M>,I:(G44K>&D5)J9.N=+N;.VA.YE0ZG1ZG-[G,WCC/E.1U@-N9*H4$?+%?+$B2/P=/R>/Q<4U@8XE6ZCJs\?nVBmX=cN>[G.J:*D5*C4.G6+C1/H61L70N83P<.K9-G7+B1(=+,D2(@0)B3,F64Q>9V@:V?0G2$7&!4$$:)'A.(;.#6)(?2*D5+K<*N>(C4+F54P=7Q>5K<,>0%6("5$!6##7%$6%#3%%4($5'&;,.E3-F3,C0,<+ .!"1%)=,(B.'C0,J6,J8(E5*G8"?0:(&?,(@09+-F8/L:)H0+<+&#6)*=0.B5+A2-B0/C00B13E45G60D3!0"%0#+3($5')<,+=,.@1-A1*A1+A1-?0,<,,8*)7(%7&"6##7##7"(6%)5$(2$%.!"-!$0%#8)3#3!6$2I94&!1#%6($3(-"%("4#0+*:(1@1"1##/!# & ) ' %(("( )& +/! )"' ) )#+"$-%*3'-4*+3(7C7U]NaaRg_U]TL^ULlcZlcWmdWgeYlh\ph\pf[qgZmcXk]Ve[ShaWidYke]i`YYXU^]Za]\b]\d__b\]idc[UV[YTc_]f`]ia]he_dc_eeahfegd`jeaiddhbch_ac\^]XX[YU^`[WbXTiXSfWWj\Xma1V<2W=0P84O9/L9.M9-Q:-Q8(M4+L4,Q60T:+Q6)M3)M3)M3-M4+M4(K1*N4,P80T=9U:0L2,I0)D/&A0&A2(B3'C0%C.)G0,H2-I2)F3'C/)D0)E.,I2-M55U=7YA6ZB8]H6^H5^G6[H2WD1U@+P:/T>0U?7XF4WB2X?3X>9`G8^H:_K7ZF4T=4T=4U@2R>/J:(B2&@0(B4&E7'G9.J:/I;.H:/J:0O?5VB3YD9`K3YG0SC/N?2M?3UD.RA(L;$G6#E4+H8/P@8WE6XA6U=/M5/K71T?5[F6`G5cJ6hM5iO6aL1XC(L;'K:)K<#G7#D3>-$A1'C3%E4$G6#J8"J8%M;(P>(P?&N;%S<&S<'P;+N>)H:(G9'E5$I5"K6#J5 E2 F5#F5$C3)C3'B/%C0'G4(H5'L7$K5 J2!H2C2B.A-E/ H3!G2$G3"E4D2%G2$A-#A/B/C3!E5%F4 >.%F2&L7!G5 E4!A0$A2'D4$A1%@2'C3"B/!C/ F0 F0"C1"B1"F5"K;$M=)L=&J9#I8%M;$M;)Q>+Q?(O>'N>'N=%J9'K:(H7'L<'R?+XE)YE*WD0XE1VA,S@)RB'PA%O?-UF!VA%XD(VC&R?'Q?-XF,ZI+\I)^H)`I,\I0\L-bL0gO.jU+gR$XF&L;!F8$N=#Q<&T>/WC0Q@'M;#I7 K7,[F+bK$`I%`F-^J1UG,OC-XG-aM-ZH'TB(RA&RA%TA#UA+UB.YF.[H+WD&O=+R@*S>*TC,YH,[J1aO4cN0`L%_J$]I,\H.WE/^K4_S4`R.^K.`M3fQ.`L,WC1VG5ZJ;bN4]I/XH-cM0_K/[I-]M*`P'\N*\H+ZG0bR0gT,aN,[H/YJ(SA(S?/[F1bM/cO)`H.fN.iQ*gO'aK,fQ2bP'XG+\J-]K+^L+fR.gU7hX:cT4^N2cO/hR2kT3iU6gT:fT7bQ*TD*S=-R>,L='C6"?1!@2$E3'L7-T>/XC$O<G5-WD-VE-WF5aO/`L'[G0dL2eM.^G*V@+S>+Q?(XE,YF N:-ZG1aM&WD$VB,ZF-SB'J6"F2 F2$I6#H4"G1'N8&Q9!P7"H5%G7)I7,Q>+N>&H6&N9'N:!E4"<-:*?0"@2$?2 8*)@2*?1$9*"A2'E5/J:3O;$C.!C, E1$I5'K7#C1#C1&C1'@2#=,7' 7$/+1"0"/ 3$%;+-?07N?=WF4Q=.M?*K<*K8-F8!A0#E4/O>2UB-U@-R>/U@0ZE*XA#I4">,%E01O;0L7/I50F31E2)F82SA*P:&M6%J5+L83YA=iP:kS;jR=cNC_L4V>7O61E1%6$+ 5%!:)%4&&6',B0%A-$G2%N61I9+G5,M70P<4J9)8*"4&"5 )#;+#;, 4(%7* 4'$=.*E3$@,'B.'A,#7)(9,,@/,F0*E1(F3$B2'E6-J:$A0 >+.H1*B/ 9)'@0"<*%A+$1!1!-B4";-#7*&8)'B/0G64I73H71I7-F4.?0.;.-;.+>/(?,)@,/A..C0)B.-H4/D1-@.+8+(5%(5%'6$&7$#9")9')8''4�"!-!(6*'2(!/"/0C34G7'&3%*7)(3)&1&!.!,/':(EZE?Q?&8( 1#%2 '/&+")#!%$%)&%(+!*"!* &"(&/%(0()1'-2)2:0>I1U?2XA.W<1Q9.Q7+R8.W;-U9*Q6/K5+K3,L5+J3-I31L4/L3,M4*L3.M6,P9.V@1X>2T=1L9.E5,C3,C3*A2(@/&A.(C/+H0)G.+H0+G/-F/,I2.J21P:1R=6W?1R:1T<2U@/Q>3M@5SD/P?+P<,P:0S:1\@4_C6`E5]E8]G:]G=dL5[F0T?3S@3P=3O;0H6'>.)=..B3+A3*C52G;3L>0K<0O;4R>6VA2YD5ZI5WI1TF2SF4UF4UF0PB,K='E7&D6)H:.O=3WB3WA0S;/P9/N92V@3YC3[E0\E6dM8hP4bK3\F+P<-M=,J<)F8&C1#@.%?1$B3!D1$J5$K5$K6'M9)O:'P;'R<'T?+V>+R;)M<$H7'M8(N6'M6'M7$L7!I6$L9'I9%E3+I4(F2(I2'J2)M8&K7'N9#J5E1A/@1?.?*A+A/C4C3B3 @1<- =.!>/<- ?0%F6!C2"E5'K9"H2#E0"B/'E2&G6%F4#D4$D5!B3 E4!G3!I4'C4!@/!C2#H6'L:,N=)M9&K7#H6(P>(RB%P?'P:(Q;(N9$K6$K9%N<&PB&RB#P=)VD)WD*VG*UD'Q@%O=$N;$O;(R>$N>)UD,ZD'U?'RB0WM)\L(`L)_K.]J.ZH*ZI.aM-bO1gT,_M'SC&K="N?"K<$O?)XF*\G'U?'O>#K<%O>0\K.]L(YI XE,aN._N-]K-]K*^L1_G*\D'XB+TC'O?(SD*RB-RC.QD+M@)K<+O?-S?.UB1YG/ZI7fV.UE,M>(K;B/F1(M9'M8%M8)R=)O:'M8"G7$I7%I8.S?+S=!J4'F6)F4%@.8&!6)%:.&?0$>.=,$F5'E5(@0(B5-G8*H5-J8:':)B.$E3(E8#>1&D5'H7'A18(4%"6( 2#0" 2%!1$ -!#4')@2-H94TA:T@4J42M6+M6'J7-G3&@/)F63QC/TB)Q<%F6/SC/UC*N='F3">+)A4(F6+I90H67M:.H5'C5)J9$E4;+!9*)?3,L<1TB1-=2*>2*A36P=2N8.K43I7-?-->-/I63Q<4P<4Q<.N:(L:-P>3T@4S>.I80F60?1(,!#3&!2'&:.(@1,F5)D0*E1.J8/K;/M2(;)(9+'8,%6+&8+':*(;+"5((=.$=-%@0%?-#:(4%%:+*B4(C5$A0(B3-I7/J7'G4(G4+G6%9*.""5'%=+)@-'/#&6)$8+2$"7'#<+'D43F79E5:F65J83J84E31C1*>,'<*-?.,>-1A0-@.+C/,D0':+)7+)4*%5(&9($9%%:$(<(*6'*9('9*&6('8*%5',2%&2%4&7M@#5*"0%1#0A14D41?.-9*'0$*+$", %6('5%&3#"- *''"*"-$!* #+"',.%"/$"- $.'6($6)/5+/:/7C7AL?V[Mb`Rf^QSOBc`Umh_lg_nf_ki]kh[mgZkdZi_Uf\RbVPg\ScZPaYOaYQ[SL]XUd_]fa`gabf`bd_ab]\SOM\XT`^Z`]Xda[_^Z__\X[YVVU_[Zg]]hddhdec_ddabVWU_`]gh`\c[Zi^[ja^ibX^X7WC4VA2V?1U;.N5+M4,Q82X?5ZA1T;.N6-K4-I2-I2-J20M61N6/P70P92Q91T;0Y>5]C5Y@1Q<+F3+D1+F3,F2,F1'B,(D-(D.(E-)G-,H0.I20L50L5.M83N:4P90N6/M6/K7.I5/K;3RB3UC/T>/T<.S:-Z>-Y=2[A7[D5WB<]H?gM9_G2VB3RA6TC6S@/I8)B1'?/.E5+D5)C50H:4L?1N>2O=3R>5T?1VB/SB-P@.OA1RB6WG4XE2VC0TA+O<&J7'J7+M<.R<-S=,Q:-O92R>3VA3XC/VA0YC2\F3^H0\I3ZH.RA/M?,L=-K<%F4%D1%B3&D4$E3#F3"E1"D1$F2'K7'O:$O9%S=*V>*S<'M<&K:&N8&M6'N7$L7#J6 I7"L:"L9"I6&K9'L8'K7%J6(K7&J6$J6"I4 F1B.?0>,<'>)>,@1C3!C3:,:+9+;,:+ ?/%E5%G6'I8%J6#G4"E2%D2(G4'H7%G6%G6%H7#G7"F6$K7$L7"B2!C2"E4$I8)N=*M<'L8$I8%J8$L:)R@*SC*S>*Q<(M9&K7*O>(P?'SE"N> M:&R?$O=$N=#K;"K9H6G5%O<&P)N>+O? F2"F2'I6%J7&J7+N<)J8)H6#D4&I8*O=,R=)M9#G3&E5(E3#>+ 7%3%"9,$>/#9+&>0,I9)H8)E5+F7%A3&C0#?+6% :+>* A0&C4 =/&C4-L:(B29) 9)%=.&=-"7(":,!8*(>1&>/+J:.Q@<[I0G53G30J6-M9,L:-H6%C3%J9.UC/WA%K7$F1*M:,Q>'I8'E5'A2)B3*H8.K<:TC6K<(A0'>2&B39(0! 4%&;/,E7*M<8dNNw`d‚lzŽx;S@)B/+F5&A1+I:-K<3O:/K80J82J;.D6(=//G:&@1.H82M:.J6,H4/H5+A./G52Q=>\H=VC3K8/I9%D4/M=4Q@-H5'C0-D3(7)$- %3'"4')8**+*F3+B0!5&"3%*;,&;,#:,6&-H9.I8+I60P;+O9,F7&:+*!4&'<,*>-'4'3%4'&8*%9((@-+B38I:AN?3F55J84H73A/1A0.?/':*&8+(9,2B22F4/F3*A-(:*(7**6*%6',>.)=*+>-1E21C2/A0.B31E61D6-?10A2,B10K;1L>0G7,@11C1CWD9I7+;+!.!%((%!- -!#3&!3#"3$ ."$1$+6+1=0$,#)3)&0&!(%, 2& 1$!- (2%)7+,<13@43D69L=BRAPYH\^Oa\OVQEXVKc^Uf_Uf\TfaTd^Qe_RmcYmdZpe[nd[k`VkbWldXjcZd^Wc][a][a]]`\]_Z]^YZ\VVTPO[XVa^[eb_c_^cb^\^ZW[Y]^\ifejddgdehfgfce`]_XUUa__ed_]b\^hb\ga\daSWT6WB8WB1R9,M4/L5.N62R=4V@5WA2V@/U<.N7/J3/J3-J3.Q82O:1R;1R:7U<5V=1X=4]B8_E5X@3P<-G5+F2,I0-J2+H/*F/(E.)E0*G/-I2,H1.K40L6+K31N62P82P75S:6S=3N;-J:.L:1T?0T>,S:0W>,[?.Y?0V>5W?6S?;XB=fK>eM3XD3TC6UD4SC2P=-J8+F6-G7-H9+E82K=5N@3P@2O?/L<5RB1U?*M:*L<*L<.Q?0S?5[I2XE2XF0VD+Q>&M;+M<)N:+Q;,R<+O9/O<1TB0RA,N<+N=-P?-Q@,SD/SE0RC,J<-M<+K:&J6$F6%D5%D5%E5!B.$@0$?/%C2#D3"H5!I7$Q<&T;$O7%K:%L;&O9&M7%O9#L7#L7 J8!K9I6!J8&L:&L:"F6#F6%H4#G3 E1 C/ D0!B.!>.!?.>)>)?-B1 A0A0;+!<,9*;, <-%B2&G6(J9&K8&L6!H4 D0$G3(H5%I5&I5&I9&K9%I9"I7"K8#L6#J8!H7#K9*P>(N<,R@(N<'N<&M;'O=)P>,R@-T?+Q=.S?)M:,R>.UA%RA"O>$O<$L:"I6 D4B1!D2 C1B1$G6$G7"G:%N>,ZG)^F#YD'[H(`L'`L'_H)ZE.[H,YG0\L.^K,\J(XF,XG.XG+QB(N=,UE/_M,`K(YE)YE)YE*YF.ZJ+VE$N=&RA'[I#\H'`L)]J.[J)]H)_N-_M1[L+SD'RE*Q@&L>&N?/WI-YJ/^J-aL/aN/`M/_M-^L3dT1fS(YG'XG+_M-dQ/jU3jX2jW.fR2fT0aN0\K0[J2_M4bO7dQ0]K,WF,YH.ZI.ZI.XG.WF4ZK/aN4dP._H/^I-[H,]J*bN,^I/^H1cM&^I$YF$YG'_K#[EJ8$WEBzi:tb.eR([I(XD&W@)]F'^H)eQ)gU2n\7r_5n[-hR-hS0jY,fT,cP)]J0aJ3cM0\I0]J2_N)YG&UC'S@(Q?.S?(M9!F0'H8.Q?-S>,T?&P>"M>+ZG-]I-^J+\E-[E%S=D/@0'F6(E7)J9%H4$G7'L<)SB-UD(N:%E2#C3"B1%E4+K:.J:,F7)F6(I8$H7'L7,K8-G4(G6(F6%?/8(7'&@0'A3(=0)>0,G8*J;(I:'F5$@0%?/ 8("9*%=. ?.?.#@0;+"@0'D3%=.";+!<+#?.'C3'B2%>0%>0&A1*I8-R>/UA3O?.D40E63M=3O?1N>-G:B2"L<)UB0YC>%$D0,L8)M8(J9)G8)C5+G5.N<0O<:TE5J;)@2(<-&=/2"/"'8).D51F7%F46bMVƒir’y‚—~8M8,B.(?-(C3*F7,I;,G4*E2/I71K:*E5+E5/P=+I62P@1L<1M<.K:/J7.H4.M83UB8UC/C2+?13%&?13L>/H9)?/='+C1&7'(4$%5*)9(.?/(>+'>/,D4.E6'=(&?,.J7.K8-H5-F3,K4&@/%;-+=0/@2*=+&.#$/:-%8'!8&(C0,@0"2$(6(0=/(7)#5''@23L>,G7+J6/S=-T)3D7@OA4F50I72K95G62?,1>..>0,=1):/*=10A/2G3+A.&<*'9*$4&*7'*;*0C2&>+,@04G73H90G80G80G8.@41C53M;:WC9TA,H6*C1*@/0E/2E0*=*!3"#1% -" ++"."!-!!."&4('7)(5**#."'0& )!& ")""+!#&."%9* 2#-+ (5*0@46E85F8:L;AQ@KUCQTBVRI\XNhcXhaVh_TcYMbZMneYtk]vlbuj`th^qh[pfZf^QnfYng]ha[f_^d^_b]^c^_b]_b]^]ZZVSRb]^fabhcdhcdged_`]Z[X]^[fbcibdfccebcecc_YZYUUa^]c`^^_]^b`Z_^X][X[Y5U=7W?6S;1O62O84Q:4R=6U@4TA2UA0\A5[C4S;/L5.N6-S:1Q<0R;1R:5S:4T;5[>6_D5]C3Y?/Q8,K3-H1+J0,K0,J1)G0(D/,H4*J5-H5.J6/K4.K4,L4.P83V=5X?5X?4V?3V@1Q>0P>0P<+P:.U<3[B.\B.X?1U=7VB7R>;XC;dJ@hQ;aL4XG4VE4VB4R?/M<-K;,I9/I:1J<5O?9UE4P@/N?1N?5OA4SA/N,L0O=-PA0SD-RB.SD)N>$J:(J9&J6)O9)O9)J6-M<0P?.N=-M<*J9*K:.O=+O@1RD1RC2RA/P@*N9#G7%G7"C5#D5$B3"?/#>.$>.#?/ >.@/C2 K8#M6$K5#I8%L<'P;&O:&O:#L8#L8!K9 I7"G6 E4%I8#D5!A2%E5#H5#F2 C0>+"A/>+ =-"?, =*=* B.C1A0?. >-<,?. A/$B.$D3%F7'L;(O;$L5 G3#I5!E1$H4%I5#H5'N9'M;'M;$J7"J5$N7%M<&N;%M;&N<)P>)R@-Q@,R@'Q?(Q@'N<+Q?+U?/T@0T@/U@3YF.WB(TC&Q?%L<"H5 D4A,#A0$B1$B2#A0%C2&D5$E6*N>-XG0`J(ZF'[G'^K%^I$\E-_I.[H-[J.^L0`N/_M*YG,YG-YH,VE+RC.WF*[J,aM,_K*]K-`N-^M/aN+XG(RA(SB#TC WD%]J*_L.^M,`N*cO.cR0\L)RC%QA+WE*UC)RC.[K2bP*^J._N0`N1^M0\K2^N3`P0_M)YG#TB&YG&[I&\K+bN.eR+bO-aO+[I/]K3`O0`M2cO1cN*ZH)TD)XG.[J/\K,XG2\K0[J3bP4eQ1bL/`K.\H1\K,`K1^H2]F/\G%UB%SA"PA(YH&TB=*%WEG‚r7vf ZJ$WE"S@"R>&YB'[E(]J#^L*jW9tb6n]+aL,`M+_M(ZI)YF(WC-\G0_I,[G3`M1^M'UD)QA*P?)L:+L;)I6)I6$K5)O;+N:(L<#I9$N>+YE-ZH+\H,YF+YD(S>$E2!@/'C4+H9,K;%H3&H8+P@)QA'M=)M:&E2$A1"@/&G5/L<0M=0K;*F6(G6%G6'G4,H60J8*K:*H8%@0!;,$@0)E4*D6(?1)A2+J;*K<$E5%E4 ;+#:+"7(&<-(@1?.#B2!A0"?/(F5(C3'>/'=.'@0$@/)G7*J9/D6+D5$A0)I62T?1T?-I8+B30G8-I93RA4O?&@2>/&M=#N;#E18!9$#A.*H5?.+H9)G7,J5,O:/P=5N?/D6'>0)=.+@1 2$$1#-=/+B35G9+J86bJZ…k‚£‰–}5N7H`L7SA,J7(I8(J:)F2&@/3J8,F4'B2-K;$I4/O;0L9*E6.H8.K:-L61M9(F1(I6+F3+?.':+*>00G93J<-D6)@/%C/)@-(:)&3%$2%%7)*;)-A.&<*&>,.D5*>/2*B-.I6/L<,J7+G4,F/)@-&7(*7,0@02B0)3(+4'.9,"2!!6%!:(+<-$2$20WA,E5*=.-@/&;('=+%6%1#5&"6)#4& 0!+@.IWJ/*?0.B3,@2*@1(?0'>0%<.,?12O>8V=7T=4U<4S;3Q92Q=2U@7ZF1aE6bG2[A-T9.T:2X=4Y@0W>0T<0O76W>5[B4YA3[@8^C1S8.L3/K4.M4.M5+H2*F1+F3.J6+K7,K70L81L81N70O7/S:6Z?8_C4[A3[B0W@0R@0P?0P>,Q;/UA2ZE3^G4YD4U@;VC8U@8XC;aJ@gR>fP6\G4YD3YB3Q?/O<-M<.J:/I:3L>4Q@8VF8WH4RC0M?5NB6RB4PB1NA0N?-M<+K9+H:+J<+J<(I;'J<#F8$C2"C0$H2'G5%E4)E6*H7,K;-N=-M<+L;+L;-O>/Q@4SB3R@2S?*N9*K:%H8(K=$E7"B3"@/#?/$>.#>."?/?.@/F4#K4#I4%I:(L<#K7$K9'N<&M;$K9$K9!G6 ?0?0&I8!D3 C0#D1C2@/>-!=- <,!>."@,"@-"A.!B/!G3!H2 C/A-?,?,C/"G3%E0#D2"F5(N=&P;!N5"J7"H7D1#G3"G3$K5'M8&L9(M; F4#I4&M7&M;(O='K:'M;'O>&P>,M>+P?(R@)UB)Q?)R=,UD.VD.VA1YD/XD/YC*T@(O>!G7D3C0C. D0#F4$H6#G5$H7%H7(J9,R?0[H.^K)[G)[G&[F%]G&]F*ZD,[F*]I+`O.bO.`N/_L/]J.[H,YH+WF.[J.bP*`N-_M,bR/eU-dT/cR-]M,XH.\H'WD#XD%\G'_J,bM/dR.fS(^L+[H$R@&WC+ZF)XE'VE1`O0bO%[F+]L)ZI,ZJ.[L3`Q2aQ+XG$RA$S@&VC&VE%UE&ZG+`L*`L-bM.aM0`L2bR2cQ0dP0dM,\H2`M+^M-_M._N.^L7fT2_M0]J2`K1bL5eO.^I-]I-]G2\F4\C-ZC"N;$K< K>%QB&P>;)"TB@{k3p^O>&SD$M=$M>&QA&UA(VD%WF(cQ7ub.fS-^J,]I+YG'TB'T@%R?)TB+UC-YD4`J4_L(Q@+N>+N=)J9)J8(L;*P?&T>+UA)O>$J7$K9&O>+YE/\I+YF*XD*VD-UC(J7"B2'D5,J;,O>$I5'L;*N>&J:(J:(K9&I5*E6#B2(H9-O?/Q@.M>'F5%A1"?/'B/,J7.L9*L;)G7"=.$?1%B1'G2(D3$@-(I60VB&J7(E3!>+!9)%8+!4&&<.&A1%@1$C2"B/$C/(E2(B2)?,*B/&@.$@,.K7-L8-D7*E5$D1+M83T=5S:,H5+D4-I:/QA.O>2O<'B1$B1+J;$A08&4!7#"<*&B0 ;,+H9&G7%D0'J6-P=/J:/D5%;-&=*-C3&8*-#6&(D00G5*G4.R>Y}i~žˆTnZ9TA?[G3O<)H5'I4(K7*F3#<*(>,"9'&@-*F3&E4/K:+E5)@1,E4.J7-M6-F1,B.%=+#:)&9+&=*2H86M>/H9)A2,F3+I7.G5,>,,9)&7(,?.0G3/F2)A/.E32G6 3#&7#-C2-F7+H:-I8-I5.F./C/,;-5D56J89P;5E55B4)6''4&'9*(9,$2$+8*-:,&8**A.5Q@/K:+H5*I6.Q>+P=,B5(;++@-,F21I7*?-/"1& 1$+"1$3G6HXJ"0"*;*.H51O<1L:4G7.?0,=-/A2-A0.E50C0.A.+=-):-(9*+=,0@.0C2+@1)>/.D2.C11?2)9+&7,#6)!4(#5(7RA1G7*:*&5$+;*-A//C0%8'"5'#5(%7)%7*(<,%:+%:+(<-';+#2$)&$ $    ( %),))* -"&5(/>0:C9@I=GPD^bTpn_jcVnf]ri_uj`tj\kbVYPCcZMsi]pgYqg]sj_ulbpgZneXnfXvmd]UO^USg_aiaejdggbdidfe`bVVU]WXf]_jaae]^d__c]^`\Zd_Zfa^faae^af_ae__^[YTRN[ZXddbgfeecdd_dcbcWYXV]W7V9<[?=ZB;XB7Y>7Y?5V>5U>8\F7^I7gK3cG,]@*W<-V;3X>5\A5_C4Z@3U>7YA4ZD5YA6\A;aE;^A6S:3M6.L7,L6.J6,H4/J6/J6+K7)I54P<2N:2N92O84S:9Y@:^C7\B1Y>.V?.P>,M<,L:+M;-T?0YD/WA-Q;.L78T@:WC6XC5\G:aM3P>7VD:YJ3RC.J>/I>2L?2M?2NA1M@+L;*J7/J8/K9-J8)G5(I7#F4%C/"A.#C0"B/#>/(A3+H7/L91P=*M9)M:(M9,O:.O:2S>8XD4WC*N:.N=*L=*M?&I;$F7(H8'D4'C3'C3$A1"A0A0 E4!G2%I4$E7C4C1C0"G6$K8%K:"G6D3 ?0?0D3E0E/!F1 E3#C3!>.%@0!>- =-#C/!B.%D2$G3!H3!J4#H4!D0 C0!D0 F2!I4%H3"F3#H8'O>'U?#S9"K9&M;$I5%J6(N8(P9)N9&K8%H8#F5&I4)N7)O<(M<'J:'N;(Q?$P>*I:(L<(Q?(VB+WA+U@(TB+UC0XE/XC-XC+WA*Q>'M< D4A1"D2!F/J5!M7#N;%Q>&P?&P@,S>*U@*YE(ZE%XF$YF)ZG#YC"YA(ZB'YD#YD'_N*`N.cQ/aO1`L+[G)\H.\K.^L-cQ"YG"VC1eX/fY*dV,dT+`O-^M2bO-]I*ZF)]I+aM+eP0eR+cP#\G*]I*\E#YB%YE%XE'WD0bP-aM"ZD&]L'[J(\K.bQ2gV-`P*VE'TB&TA+WD,XG)UG)ZF/aM,aM/dP1eR1dP/aQ3fT1fR2gP.aL3bO.eR.eR/dQ7kY5gU0aO/VC.ZF1bK3gP-`K-^K/`I2^F1\C*W?$Q>"I;!J?*UE-UC@.%UD/l]([J"O?&K=)I;%G8"F9 N<(N?(OA*_N1lX+bN+^J+]H'WC)WD'UB%R@%J;)O>/VB6]H4ZG-QA.Q>-O<)M<)N>*UD(VE%XD-\H,TB+Q?'N<'R>0\G0^H'S@'T@*TB.UC&K8%G6&F7-N?(L:!H5&N<*M=)I:&E6'J7(M9*G9(G9'J;(L<*O>)N>*K9">.'?0+D2*I6'K7*L;#B2=.&C4&E3$D0)E2&F3*S=/ZE&L7&A.9%!8'$7)#5'*A3+F6%@2=,<'@,&C/&@0,B0/F4)B0'A/)E3+H4(E6(J9'L8,R;.Q8/O6.J6,G5%B3$H7*N<1O;*F2(A0'>/0"2#3!5&9)!;++E5,L9%E3&D3)L;*L<.I9*@0":'&A-.G5&9*!0##8)&F1'A/*E2-L9>]J?]N3O>1I:*C2&@.*E2)F1)G1!>,%=,%:)#7&*A0+F2*E50H9/B3+?.,E3/K8-N6/E0+:',<+'<+(=-'B.5O<2K;)C2'C0)E0*I94L=0A0+9)'8&)=*-H5-J6,G4+D1&<((;)+=(/E4)B4,H;.K:3O<;S;:N;BSBCWH/I50O90F4.B/$4#$1$%1&)5*&4)"0$'3%&7)$;))D21Q<(H4&F2(F5(I8$F62G:*>.(>+(D01O;,E4(7,!0'() )7+1F7+;-&3%(5$+B0,K8-P;1H9/A32E51E4*A..E10C.-@..=0)8*&8),>,5D4/A3-A3/F75L9,B./8+,6*$3'/"*0$5QB)>1&4'#0!,?--C1(:,#5'/""3)$8+,A2.D5)A2(C3-E6(<-%7)'4$ ,*&!! !)!&!*- '&#,"$0%*9+6G5>L@CPDLTIci]qpcok]ul`ti]sf[pdXiaT[SFh_SnfZofYrh_tkari_oeZmcYog\ri`TKF]TShadg_bgbdhcegbda\^TRR_YZj``k__lb_h`_lcdkdaleaohdoggmdhodglddb^[YVQ``]ceccfbfddebfa_aY\ZRYS>]>=[?>^D7[C5VA3W@5ZA7^E6^D8_E5`D0\@,W<-U;3W>5W?3XB6[C5[C2\B1\B7_D7^D4\A9_A9]@6Y<1R80L8-K8.L:+I6,H5/K72N80K44Q85Q93Q90P81T:7Z@9^E3Y@/W>,T;+K6)F7-H;1O>1S?/R@1Q:1M:2L<6Q@;YE9\D6YG;aL:bK3]F0W?4ZB4TB-N;2P=3R>5S?1O<1N?7UE6VE1Q?.I:,F7.L90M>3PA0P@+L<(K7+I60O<.O<(H5,H5+F2&A1%@,&@.&A.'>0(@2+G7-N=-Q>%J6&I5'H5+K91R>8YE9[D3T?-M8/J:5UA2XD*P?$H9'J6&K:(J:&F3%E2"F1"H3&H1#H2"G3#F3<+ :+9*A/!L5!N7G2F1B1B0C1C1!G5E2E/ D/ C1#D2B0C. C/D0"F2#J5!I4#L7$J6%F6%B3%C3%E6$I5&E6%I8%L:*XB$T<$U<%Q?$N;%K:'M<)O=*P>(M<$J9'L8%L7(O;)O;)Q<(M=)M=)N>)RA#N8%H9%L:(R@*WD,[F)WA*YC+YD.YG-VG+QC+Q@(K=$G8!E5B2 E4!F5#I8%N<&S@&UA'WC+YF*[D*[C-\C&YA#WC&\J&\H&XC(V@*U@'U@+XH%]H+eP(cM)bM*`K(WD)^I,`M/aO0`N)YF#Q'P<"N=*WF2\KC3(RA-ZI(M@$I:&K:%F7#C6$B8&G8%L;"Q?,_M.cQ-aO)]I-\H/[H)YF(WD(Q?)O;*O;.WB0YD0XB-R=.UC+P?-RA+TB+ZG']I(]L*^K+ZF-VD.WD6^H1[J+SC%K;'L<+P@)PA'K;"F5+O>.RA)I9(J;+I<+J=&J:)L;,N=*M<-S?*M;*J;*J;,NA/SF(I9'C4+F4+E3)J6*O;+J5#A-'B1)D4$C1%H4"F6'O:+T;,S;.L9 7(!6'$7'$;'$<+*I4)L6&E/9&!8')>.)B/!A++D7.I:,H5(D1(D2*D4%G5/OA/O?*H3)G0/I7(F4)E2$?,'D01S=(M5)E1*D0(?,&:(&8)"4&6*"9.!=/$B4"D4 B3'A1'K8%L7)G4-D0$9'$>.+G7(C3)>+,B0#=+6'-C42H4(>*"8'#=-1"%:+)>/-A2+=.%9)*<*)<)%=* ;)'C/*E5*G70I:/D70C43G52H4/G41G5.B10C5-A3&.!9'"5%%6(%6((=/-G94F7&=.)E5'F5*D5$;,3J38G72E3-D23N;-G6+C1+9,*6')6%%5"!3!/B39TB+@.+;*,9(/B/,@-->-$4%0!3$'<,*?.4N9.K:*G72J;,@0'@+$9(#2%!*! !#!&!)$, "+$)!)%. *2%3=0>J>?PCGQFY]Tjh^rmcwobwmculari[pgZh_SSH@f^Uif[lg\laWk_Ve\Sd^Ue^Q`XHZSF[UO`ZZf_df^akceibcfa`a\\TSQf_bodgsggqefpbdpbekddkggpjjnjikhhhgcgdb_[[XTT`]^facd`bd_aa\]`\ZYUUVSPAcEBaE?`F8[C3S?2S<6X@;aH3T;1M9.K7-L9,L8,J6.K61P=.N7/N62Q9.P8/Q<3T;6X>9\B3X@/V=-U<+N6*H7/L<0N<0T=2UB.Q:/O;3Q?5TB8YE2P=3Q=3QA6UE2RA.K;*E5+C4-I6,J7/K;.N=.O=*M9+I6-K80P=+K8*G4(E1'B2%@-"<*$>,&>0'@2(E4'H7*L9&G4"D0&D0'G60O;8YD;\E5U@*I5.J7;[D6\F+Q?&K:*N9/SA/S@'G4%E2#G2#I3&J2%H1&K4"C/ <*8'8)=+ G2G0D/D/A1@/A0?."C3$C2!E0!D0%D3$D4#D3"E2C/!E1 E1 D0B/#G3%H5(G7)D6'A3$C3%I5'H9&K:&O>(V?%T=(W?#S>%UA'T@'S?&R?&T@%P>%P='Q?(T>,WB+U@(R>*Q@)N>*O?*R@'R<'K<%L;(Q?+VD,XD.ZE+[B+[D+XE+UF&O?%N=$I;"G8#H8!E5#F6!E4!I6#O;&TA%VC'WD*ZG)[F+[E+[B'YA$XC'\J)[H)XC+VA*R=)UA-XG,cN)bM*dO,dO)_J(YE,`I2cO.]K.\K)VD"O=([J/aQ(ZK'[J*aO*eO+fR)cP*bO,dO.eP1gR/fU-bQ&YG([I#YF%\I&ZI&]J,dQ.fS)aL'^I)]L+aP-fU-eT0fU)ZJ)UD(WE.`O2fV5kY0hX0gV5mZ5p\4o[6mZ5iV1eT2gU-eQ-`O)YH"PA(]J+aN,bM-aM,]G+YE*RC+XD-]E0bL.aL/`N._M0^M*WD-UC+SB'O=#L;(TC,WF&L<*RA'SB"L=#J:"H6$H8#C5%A7(H8'L;)UC4fS._L'XF$XD*YE.[I'XD)YE,TB+S=,U?.WB,VA+R=+Q;0XF0XF/VD-WE+YF)[G+]K+[H+YF1[I2]J2_I0YH&L;"F6%I9)N='M<)N=*O=.R>2U@*K:,L;,H;)I;)L>*N=.RA.Q@-SA+N='I9'I9+N>+P@.K:+I9*J7,M:)K8.R>+M8%E4(G6(G6"E2$H3(L. A/)K7-P;'J5(G3&B0'A1+C2-@1);-%:*$;+"<+#>-;) =+&?/(G8(K9(D3+@0%9)(?2-J:(F6/H5-B02!:*.D4/E23!)?/+B3-A3(<.&;-$8*#8*'<.)<*$;(#?,&C0)H4.L;/J8-G70E83I94L;2L95O73L75I87L;+A1)A21I;5N=+E0&@+'@/&?1)B02J7/F2(=+'<*-A/2M64M:0I6.F6/F33K83M82L71L79V@.J5'E/)A.(A-#5&)%4',B47O?)=0*;/,=1.@2+?1(:()9*'5(++A30I;*?.(@.(B2%=-#7*&+B39UE2L<%9*"5' 7' ?1+H8.F5.@/,9**2%,;,*<--B14M:6S?9WB/D71E61C20@/0?/1>/.=-)9*,=.'8+,=/1C64D3.A00E31G5+A/+@/*9.(8*+;*+>+.B/:P=7L:.C13G64F44E3+;)(4$$1". !3%'<+)A.3K;5QA/L=/G8&9+'?.%@1+B2(5'*1&&)&)')"% $#!*&$,-<)=J7JXEL[JGUHNYL``Wolbxnevnbuiarg]lcWi`SaXLXNBcYQicYjbXpdZi\S[QHicZunaqk\qh]d]Wf__jcihbfldgicehdd_]]WVRhbendfrfdpeaoccncbgb_gcbkedneeg``d]Y^UT[RR_VUbYYcYZ`XY`YZ_ZZ[WVROOXWVBgKCeJAaH9YA6R?2N91Q98[C>eL;fK;`F5Z@.T:,S:.U<.R:1R=7XA8]E>jQ7gK5bF9^D9]C9\B3U=5U=7X?4S>3S=0Q9/Q9-N7.M80N<0M9.K5.L5*J60P=6V=3T;2U;3V>0T<.R:1V<0P<2P=2R:3T>4VB1U@0T?5YC2XB4YD8_I;bJ8^G5[E2TA/N=0K;3R?5S@2P=4R?4P=4P=5SC5VD2RA,H9&@0+C3.I50L9-K7-M:.P<*M7.J9.J9/O>.N<(G6'D4)D4&A.&@.'A/(B3(A3(E5'D4'E2$B/%A.%A.+F61M;7S?;WC6S?-I67R=>^F:_G,Q>)M;+R:3VC1T@+M:'J6&J5&J4&M4'M4&H3$B."<)"9& ;+<)>+!B.>+<)=-<+ =-8(#>.%?/$E0&F4(G7#B3#D3 B/B.B. @->+;(&B/$D1%E3'@2%B3'E4'J5%J8%L:&Q<)WA(U@%S<$V@&V@#S='V@'V@'XA)VE&TA%S@+YE,[E.\F,XE)TB)Q?%N<)Q?*TB(RA(Q@+UB+VD,VB-WB,]A-\C*XE+XF%Q@"M<#J:"I9#H8%J9$H7%J8#M6%R;(VC#T@$WF'WG*WF,YF(ZB,^F)^I(\J(ZG*YE+YC.[F2_K2bN/dP)aL+cN-eP(^J)\I1cL1aM.ZI-XH'SB#P?#UC-\K*YI$VF(_K)aL*eQ)dP*eP*cN-fQ/gR1hU/eR,^L%UC'WE'VE(YF(`L*fO*fO-aK'WB)\K.fU+kX*hW.fT-`P)VE,\J.dQ/iW2nZ0lX4k\8rb8tb6r`6q^6n[6o^1hW+cP*\J$O@G7)YE)\F*]I+\H*YG(UD,VE+XF,ZG+\H+ZI,YI*XG*WF)UD'TA(UB&R?&L=&PA(SD*PA%N@"N>#P>!N;"K9$G8$D5#A4(G7'L;-XE8gT-\H)WD"T@+XE,XE)WD,YF,TB'Q?-ZG-ZG-XA'P;(P;,XC0ZF/[E/ZE*XC+ZD+XH+XF0[I4^L2`K/^H+VD&L:#G6&J9(L;+Q?,TB.U?/S=4WA4T@/P>-J:)H7*K<+O>0UD.TB,QA(L<)M<*M<+Q=)P;/J:'F6(N:,S>,R>1T@'L8*N;-O>(I8#H3&M7/SC.Q?-N9,I6,E4)0"6('8+,@3-M=&L8+I6)?+0(<--C3)>+&;)*A1(@0';/%:-(0(?2)?,8$"?,'H5-M:)H8*E1*D44N?1K;0J95P=-G00I50I52K72K91K92G82F6*?,$:'$:*'A0+C0/J6.H6&@.'B00J:7P=2K72J8+C1*C1/G5-I5.I5-H4.H5&A-%@-";,$8*,!'%/$)-*@-%9)"3&"0$$";*<[H3TC 8) .!$."":,)?0(<+/A0+9*,8*-@.0D21H6=UA3K8*A-';*/B13E4(7&'2%*3')6++;-,-.@/1D32D61C49J<.@.,>-/A1.?3,>0/B1+?-0H45O97I8/D3/G51F4-=-)5$+4$(1$&2&&7)*=..G32I:3N>1K=(>2"6($<.%A1*A2+;-0:*29+19)-6$+3#%)%2$.>09M7WA;`H>nS:kP4bF7\B6Z@8ZB5W?3U=8ZB7ZE:]F4Y?0U:-M7-K60J8-G4.H1,G0-H43O;5V=2U;/R83V>2U=,P83Y?3U?6UA4U=4U>/Q?1SB3VA6\C6]D3XD8\J=`H4ZC2UA2UA0M>.I9-K93Q=4R?8TA3P=2N;3P@7TC4QB,I8)B2-D5,F40K80M81P;-O.J:/K;.N=)H8(D5(C3)C3(C1&B/'C0(B3'B4'F5(E5(D1'B0&B/#?,(B4.J83N;3O;1M:0L9:VB?^F7ZA-O<(M9/V=1U@2XB1WA0V@,Q<*M9,R<&K5)H3(D/%?,'@.$@-=*;'7'7$6$8(6&9)7' 8(&=/%B.*H:.N>&F6 C2 B/C/C/ A- >+ ;)%@-$D0'E3&D3#B2#E3'J6&N;%N;&R>&T>%S=(T?&S=)V@'U>)WA*XB,YC(XG'XF&WD'YE,]J._I*[G(VA(T>&R<,WC-XE'RB)RA)SA,SA,TA(Q<(X@,[D'VB*WD)VC$Q=$K;$K;'M;'M;%K9&L:'Q:(T=)VC%UA(WF&UE(UD.]J.`I,`H-aK'ZI(\K+^L/cM-aK-dL3jU.aM(]I+bM+cN+bN)^J-^H0`K/[J+WF(UC&SB(UD)VF+XH(WF$XE%\D)dO,dO+dO)bM)aM-eR0gT0fT)[I%TB)UD)TC+XE-^J%^F*aK1dM-[C.aQ0hW-kX)gT+dR/cS-\I/aO.fR-jV0nY'fQ0jX9tb9sb2n]5p^3nZ.kW1jW*`O$SD J:$I8&V>+\E+\E*[G+YG,XG-[H.[H+[G-]I,XH)TE)RC+TC(SB%Q@%R?$Q>'N>%Q@'UD(RA'Q@#SA#T>#R="M;#J8$H8$D5'G6'N<.YG/^K+XE'Q?(UB*RA*Q?)UB,XF+R@$O>'TA-ZG*VC$N8'O:+WB+YC.\F+YC+YC+WB+WG+UD+VC/ZH,[F)ZC)TB%O=%L:)O=*P>)R@)SA+T>.T>4XB/U?*N=-O:*K7+N:.R>,Q<'M:$I8(O<(N<*Q<-S>)P:1N=*L<+T>(S>+R=,O;(M9)M<-O>$I8&L7,U>.Q?-L;2N;0J82I:'>/)?.(>/)B3,G7,G7'C2"<,%@0'D3&C3+C45J:4L<*F3+L8,N6*I4*D1#@-$?1&?/0G3/C.);*&?//N=-SA)O>'K:+H8*I:)H9%G7*I8,H7(@0+=/*:-&9+$6)$6))9.":)%@/)F6$;-/"$9,+C4-P?*Q<,K6(>**<'(<-)?.$=)#<("9)$;,%9,&:-(;.%<.+B4&=/ 9&9%"?,)G4'G3$@0#=*&@//I8,G74N=.H6(>+-F21K7.H7-G5.H53G70C2(9)"5$!8&$>.+D0*D/,F3)E3(D5*G65M:0I50I5)B.+C11I71K9.G5(@.#:(#;))A.$:+#7'$.!*/$'1&$9+%@0'?0(=.0C3/B3-@1+<+(:**;-0F7-F8+G8%:,+?0. !, *!, "9)&E2+K:-D5)6*'1%(2$(4%"1 ->-0C3*=.1A/2C1;N:0,?.1E3-C0.@20A36E7.?20B12D4-A3$9+)>0(?,)C0.J52E5.D20J8/F5.@0+8*)4'(5&+:-'9*4H6/H4-D64N?4M@+>2,?1*C3-D5"5' 0):)1D1,C04E0:H7>K>->/*>//F54L?0G80F65G76Q;4Q91N73W>9aG6gL4dJ3_F0V>2Q<7Q=3U?7YC>eL@oU6Y?6Y?1V<3W?4W?0T<0W=1U?2R>/R9/O:-M>3O@3R?5Y@3X?1T?2RB3UA4XC3YD2TD.M<+I:/M;1N;7S@5Q>2N;3N<2M:6R?4Q=-K7.J7-G4+A4.F51L91P<3TA0RB0N=0O?-M<)G7&B1(@1%?/&A.*F3*F3'D5%A3#E4#C3'C0&B/$?-#@-&B4)F5.J80M:-J7,H75Q<9W?:[C0R?,O=/U>,T=3[C5^G1YB/U@-S>0WD(M:(E5*G5(E3&B0!E. @,:+7&7&6$5&5& 6'4% 8)%>.%B2)H8,M?%H8!D3#G3!F2 D0 A."@-!<)#<*'F1)J7%G6"F4$H5'N8(Q<(T>%S=%S=%Q<'R=)R>'R>(VA,ZE)VB(T@(VE'UC'UD*YE.^J-\I*YE)XB'U?'V?*ZC+ZE(SB*SA+SA+SA(R?%R<(T@)TC#P=(SA)VB(V?)N=)O='N<%M;$M9$N8(O<(P=(UB)VC+YG'TB+WF-\H-aI-bJ([H*[L+^M.bO/fO+cL,fN/iP*]I)\H/cO)^J*bM*bM,_L0_M.ZI*VE#S@!V?&UB(UC)UE+UD'UC+[E,bN+aM,bN+`M-dQ.eR,bN,bO(\K(XF)VG*TE,ZG-_K'\F+bL0fO/dN.gU/hV1jY,eS*aP0gU0^L0dR.gT+jU,jS'bM/eS=sa9o_/gV0iU1kV.gP,dO&ZH%UC#N<$L8(XA-]F*[E'XB(XC,ZE1`I0_I-]J-^J,XH(RB*K>'K=!I8H7I8 L:)Q@%TB!R@&TB'UC%VC%V?$T>#Q=)Q?&L:"H4$H6*R?/\H2`L-XD)S@)Q?(M;(M;+SA,TC!F4'L=,TD*TC&T@"N9(R=,U@)V@+\E*ZD,[E.XB-YH+TC(R@*TB(VA*YB'UA'T@(R>*S@(R?-XD+WE+TB-S>-T?+TA'RA0U?,Q<1R=,N:'K7$J5&L9*R>)S>*U?,U>*Q:)O>+P?*R=&N9*Q<*P;*N>)M<)K:'J8-S>-V>&H6.J:5N>2I:,H8$B2-D7+E7,H9,K:*I6*H4(G7+I7,I5'E1)D2-F7.F8&E4)M8,O:'D1)@0"<+$=0,D42K80H2-C10K7.L8*L8(J7)K9'H7)E5$B1%G5*L:-K9,G4-A2+?1(<.*<-&8*(:,'=.'B3,I7$=,!7&#;*#D0-R<+P;,G3*>-)<));,)=-%>*8$!:)"9*(;+)?/(>.+C2(A0$>-$9&"9%&?-'B/$?-#<,%>+&@/'A0,E79PA(>."6%/C38O>)D2$>-$=,+C0.D2'9(#5#4"#<)*>.(?.,C3,F4*D3*E32K93N:/I3,E1/F34K<5I8';*#8'&9)&;+%;*$7' 4$$6&+8)+;+(>-&=.(=--A.0C12D5%9+*A/,C2,C3%?/%>/-F7+<0(5**%/#".! 0$*<.%?0+E6-B31C4+<.*6&/=,4E3;M;.B1)>13A04D38J80B1'5&'1#&6&+=-%9'+>-+:,*6)*9+.>0-?1+>.*A/)A0(9-/=11?3*;-.B0,C0,B/*@/(=.(=.+E3.J70I71J81F7*@2*>0/C5/D43G91D7,@17N;1E1+B11J:6M?5G9+@1-G63I:0C5/B30D47M;4N:iN?jH;eF9`F;bI8aF;dI9eM4`E1\=0U71P81K6.M5.M41O64Q85T;3T<4Z@3Y@1X>3ZA1X>1U=.V=/T?.O:.Q9)J6'G:4M?5R>4W=6X?/M9/K=0Q>4WC2WC2VE-P?(K:.K81N;5R?5Q>6Q>5O>4L:5O<6Q>/M:.K8.I70E7+D41M:7UB8YI3TF4VD/P?-N=,I9&@0&<-$>.&A.,H5.I7(E6#A2 D2$E4$C0%A/#@-"@-#@1'D4(F4+I6*H5*G6-J65R<9XB3SC,O>-S=,T;/Y@/[D,X@-WA3[E1UE-N@*J92P@2RB&G6F/ D/>-9*6'9'!5&4%3$5$#?.(D5(H9)L=$J9#I7&K8"G3"F2#C0"A.#?,#>+$D0)K8'K:#I7#K5&N7'S>'V?%T>%R=#O:(P=*TB&SA%UA&WD#S@%S?(VF&RA&SB#Q?(WC*XE)WC'U>'U>+ZC*[D&XE'Q@*Q@)P=)Q?(R>#P<'PA'P@"K<$M<(R>'S<+O?(O<,S@"J8!L7 L5&K:$J8%P>(UB,YF(UB+XE-]G,`H.dO.`P+\O0^N4dQ1eO-dL+cK+bL-_J*ZF.aM(^J(`K)aL*^L,[J-YI*WF#U? V="S?#P?*TC-WF*TB.ZE-cM,aM-aM+`N1fT/eR,aN*_L#[H&XG*XI.ZJ+_N+_M'\I&`J)eP)jR(gT0hV.bR*\L-aQ,dS3cQ0dR+dQ'bL&`K'_H#VC8kX7jZ$XF,dN-eN*aI'\G$YE#UB&T@(T>-[E+[E'YC%XA(YD+[E2bJ.aH,^G0^K,ZG%O>)H:"C6C4E4 I8&Q@+UA"S= U?$XA(YD$XB$W=#S;$Q>$P=&Q>%M:'O:(S=,[E1`J+ZD%Q;&K: A0*K:.RA"G5@.$E7(K<&P?)TB%S='S>,R=(U@,\F*]F+ZD+YC*VE,XF*TB(R@*UA)XB%V@)XB'U?(V?)WA-\F+WF+TB+Q@(P=%R@&UC-X@-T<1R=0Q=+L9*O:,S=/ZC0\E/ZC+V?.V>%S@(Q?(N9*M9*Q='Q=+O>*M=%H7*L:3XD2ZB%D31N=6M@,D6*H7/RA3OD-M@+O@(N;(O:,R;*P>+N9,I4+F1)G2)H60K=*J:*O;'I5$?.$7)9'8+.G80J7.J4-G5)G1)E1)E1/L9,M:(K7.E6)F4&H4&I4'I3,I50H72J82I61F51E0.C/+C3(C21P=4O<(A-'D/)O7.U=.N9-F3);*&;,(:+,@0-F2,F3&A0#;,)<+-D1)A0*C1&@.$?,);)(<)$:($:)"7%'<,'@,$?+(C20F92E81C4'6+.@3,B5%<.$;-(>/-H5.F4):+"4%!6#%=,**8+!1#$5'&9*%:+(<-):)$9'6$"5$';)*C10C51D41C0/B/)<,1"+H4/L:*E6'A1+D5-B4-:0)3)$-!*3(%6&&:)&6))=0)>/)<.1F5,H50J81L85M8=R@&:*->1/?.0C20F4.C4);,,8,+8, 2#1+C/0E41B40@0.?/+?/+@1,B3.D43B62@5'5)#5')?-(B0-D0/E2'=--A30I:-I6*H5,H5)?/2"3$'@2*G7/I<+E6-C42H5+@**@-+C32G92E70E5.J6,K:.I9*@1%6(0"0 *%!+ +4(,:+*=*-=0-@25I56J4HUAQXFW]K\]NccXgeZbaVSTF`[Lqj^ulcyndvkawl`~rk{siwpdsi`aXNfbZrg^pi^rmclf`cZXeZ[jc^ka`i^`h^^_[T_]R\bXdc`gbbjc_ka`g\_a\YUSPecbidejdfjeglffhb`a]Zb]Zc`Zc`[h^^j``i`]e\Yh_[f`[8cJ4\F8XC:TA:SB5P>2P<3Q=0S=4XB3\A6_D5]B5\A5X@6YA2V>2V@8ZE=aI1O;0R=4P>4U>4X?4V=1N;1I;.O@4WD4ZG/VA-P>,M=/O=2R?2R?6UB5QB5OA/P?0M>1M;4P=/M:*J6+B4(B00O8<_H6[F6[K9VG6TF.N>,J9&B1'@.%?0'A2(E3,J6)G5'C3$B2$B3#C4"C4!C0!B.$@0'D1%C0&F0'F1(G2&H5-L90Q=1WC-WA)N:+P<%N9+Q=/R>0UA0[G/UF-M?2QA3YG/\E#P:#F2@,;)<+:* ;+ :,6'#7&!7%!<-#?0+K>*L<)M<(N<(Q<'Q:%I9 D4!E1#F2$C0%A1$D4'L;(P>'L:)P;&P;%R:(Q>.SC*N>&M<(P>)S=#T=&U?'V@'S=#R<&Q@'O?'P?'O?%Q@#SA$TB"SA#S?%R?)VB+T?)L=)K>)M>)N@$N=#Q;+Q>+Q@@2$F9%J;)N=,N='P>+UB'N<$G7%F5'G6#G7#M<*WG+XG(SB,[F*[F-`N/fS-dT+`R,cO.aO-_M-_L+]K.aO,aO,_M1cQ.`L+_K)`K-]K+XF-[H/]H,ZC(W@$VC$O?-SF0TJ.YL/^O/aP+^L(^L,cR/jX.iW)_N,`N)\K'\J&\I+cN/cP-`N%[I*bP-gU+gV(dR*aO(\H)ZF*[H.aO3gP1fP0dQ&YG&TB'R?&QA.\N3cS"YB'`H,aL-ZH'VC#UB%YB&WA)YA)VA,WF'S@)UD,ZI,]K/\H0^I/^H-[H*XG#PA$G6"E4#I5#K8&Q@'TC*R@&R@'WC'ZG'ZF"UB%T@(WA'U?*TB(P@(O@)TB'WD'YE+ZG*TB%K9&A0%?/+E5,G8(F7#D5B3'K<(M?*RC+XG$V@!P=+ZD,\D-\E,[E(UB.ZE._H+ZD,WA.WB)WA%WB*YC+TB,RA,VD-YG)TF'RC&P@$N?(O?(P@-RA*N;0T>)P:'Q;&TA,U@,[E/^J4ZH/TA'T?(VA)Q@/N>.M=-SC$Q@(N<)M;+L8,P;1YD3_G/I9.O>,O=,L;(L;(Q?/QB/RB%O=&O=&Q@&P>)M<(K:)G6,D4+D5,L<-R>-Q@/O>$@05'"4'1$4&,C5,B5.D6-B4-F5,F3*J5*Q:)O:-M;*H8)D4+D4'A2*D4-H9-I9/I9.I4,I10N61O:3N:#L5,X@3U@-I5)G3*O;1Q>2L:,E1*B/*D0+?3+C6,G9(D3+B0&9'+=0)@2&@1(E5,D7*?2'@/+@/*9($1$$4%#5%%:+&>,,C1-D3,@2/A50>1+=.$8'%;))C.,J30N9/G5+=+%7)%9+"=.-B2-D41G77K<7L=.I9.I6-H6&C0,G52L:3M:$1!%7&'<*+@1%;-+>1(>-$<+08'/E4,@2%>/,A3.A2->1$6)!3(&G4-L:+J6+I50L:.J9/D2':*&9'.>./@.(9(0:./A2+@02C1:M;,J55O=,E44L,%?-,H5+J5-I4,C0':)'8((8*#5)+=/1D51E4/D0.B02C67L<7N;EYFR^N^cTXZOaaVjf[mg[gbT[VH]\Srmcwndyoerk^sn`ujbrh\qgYj`QcYNjaYk`XlbWg_R_VO^WTe`alcdkccjb_hc`_\XWUT`^Xb][a][c]]bZ[d[\`VU_YUb^]`][gbblfhujif^Zb\We_Zjd`mcbocfpbdpffifekggldf?dL7Y@9W?9V=:UB7R>3P:2R<3U=8\B4]A3\A5]C5]C6\C4Y@2U@,L:1M<2O=5S?8XA<\B?bG8_B4^B/W>2ZB6\D6[D4U=3S;2S:/P7/M9/L81P92R:1P;1Q<1V;3Y?4Z@5[B2YA0WA0V=0R;2R<7TA7YD7[D8YE8[D8]D8[E2N?1H<-O?3WD4[F.T?)N;+M=-K;0O<2R?3R@/N>2N?/M<0L:1M:0L92N;+K6'D4$D0.R;4]C1ZD0YG2WG3XH0TD'J9*H8+F8)D5)E4+G4(C1*E4(A3$?/'D5%E5"B3$D2%D1%B2&D3#C0%E2&I4%H2#G4%F4&H5%O<$P=&N;$H4!G2#I5(K7(N9-XC,VC(N;.UB2_I-\G$Q:#B0<*:+;+"=. :,9*7'8&!;);*&F7*N>.RC+Q@+S@0YD*U@"G6B2!C0#D1'F3(G6'H9*P>,UB-Q?-SA)T?&O9'N:+O?,QA)P?)Q?%Q=$T?'VA)UA'S?%U@$R?#N<(P>&N<'R@)VC&UD#Q?"S?%Q?"L9#L6*G7)I:*M>*QB'P>'P?-T>*M=#F7!C5#G7$I9)Q?$R?'VC)TB!H6!G5#C3!F5#N;(VD,YG)VD*WD*ZF/bO1iU+cP+cP.dQ/bP/_M.\J.]K3eR/eR.cP3eS.aM+^J)^J/_M+\I*]I/`I,_G,]E&XD%RA.UH/WI.ZK,\K/`P,_N-eR.fR0kV.jU,fS-fS+aO-aO(^J)`K-bM+`K+`M*`M,cP*aN']L%WF(WC&S@(VD0aN4eQ1_K*TC'M=$J:'N="O>*WI+\L'[F'ZB)YE*VD(VC"Q>$Q=(U?'R=&O:&O>(Q?&S@-[J)[I%YC*]F)\F%VC)XG$QE+N>%K:&L8(R='RA&RA'P>)TC)[F([G+^H(ZE&WA*ZD*YB+YC*UD+UE,YF(WC)WD%Q?%K9&H7)C3!;+%?/-G:)G8%E6%H9(J=*L@+QA,VF*WD'TA*YD,YB*W@)T?(O=.XD0^J,[F2ZF0WD*VB'WD&S@'O=)N=,UD,WF(SD&RB$P?)TB%Q?$O>)SB+R@-S>$K6#L7(R@-WA-[F.ZH.UC,R?,XB,YC+SA*P>,P?-TC(Q@+R@+O=+N:/R>2XD*T>1N>-SA(O=+N=,J9(H7.K9-L:&K8*O<*P='N:%K9'L;,K:/F7/H82O?/T?.R>.M=$>.2#- /! 3%)?0(?0,C4*@2/I7-G5)H4)O9-P<(C0%@0'A0"9*#9*%=.(C2)B4)B2,D1*D/+F3-I5.H7#E3+R?4TC+F4'D3*H9/K;0J:/H6.F2*E2+B4-F6/I:+B2(:+&6'*0(<01B3/B3&;*-D21K75P;1N<.E5*=,*<,&;+*D32M;-J70L92M:2N;*K7*F3+F4!<).H62M9)A0,A/2E41C5);,';,$9+'8&$7&"9%-E3-G67*"6'*=/.>0'8+#4'*=0&?17) 7)'A2/J8,H5-H7.G63J85K91G50F4-E53N?7R??RA2D3-D20H8+C4&<-*=.$6''7'&@-4O;,C/.+=/->1'4'+2&(1#+:,)?01G75I9,B1+D1=TB;QA4G:0H6/@1*7'*6&(9)*=--@3.B5-E6/I75Q>-I6.H8/D5.=/(4&'4&/?11C50E5,B0+A--A,-@*'7&/@/.=.'6*$5'+!9'0F51D4);+@SD?QD=QDBWIBYJ^F6S97T97V9;XB8V?5S:2Q84T;<]D7`F7`E7aE:cH:cH6^D2T>-J6+F4+C1.F36N98V;:Z?8^B3Y@.U=,Q=2Q?4R>2O;1P:.Q8-Q71K:-G5.J60P71R:2S;3V<6Y?3X>3W?1U=.U<0T<2R<4R>4UB6[F3\C5\C8_F6]F8[H0M@+D<*L80T@4[E0WA-Q<+N:.H8+H6/O<0S?1S@1O@/K80L91M:1M92O;.N8'H6&J5/S;.V=.U@.WB.VD-UC.SC.N?+H9.H9.I8,H4'C/'A/&>-'>0&?1'A3'C6%D3$A2(D1%B2'E5%E4"E3$F5#F4%E4#@0 B1 I7"K9"G6%H3$H4 F2(H5'K7,U?.U?)P:+U?/]G,YC&J6(A2%?/"<,";-#<.8*5&6&5'!:*#A0'H8+QA/VF/YG/YG3`L,YC#G9B2B.&E2&H4(K:+N>0WD.WD0TC2YG.YG*R=)O=*O?.SB+R@'P<#O=$R?%R@&O=&N<%SA$U?$Q<%N:'P:+UA*WB'SD"O=&TA#P=$L8#H3+F4(J7)SB(UD)TC)P@(N;'J9%E6%D5$F6$H9&P>&UB$UA'Q?'O=#K9$G7$J9%P=+XE-ZH)VC+WF,\I.bN/gR+cL.fO,bQ-`O-]M/[L.ZK4aQ/eS1fT1bQ/bN*\H%XD*YG(XF%XE+`K+aJ*aI)^G(VD-YH0\K1`N0cO-aR1eT/fS/fS0iS+eM+kV/jW1iV0eP/bN*]I']F-cL,bK*]I+\H,\I*WH$P@%P>$N<$P>.\J.aO,WG*M>(G:"D5%K;'UA+[J)ZH'VA'T>'Q?+UB)U?%O=&N<-S@)M<)O=+Q?)Q?)SB-[I&XD#W?'YA$W@%S@(TE&PE+P@)N>'P;'P;#M:&P>K;,WH/]I&XC,]F)[C%V@([C*[C+ZC(VB+XE,ZG*WE$M,RC)UD&VC(VA)T>+S='L:*O=1XG5aO2]J2YG.SA*TB(VC$P>(O?.TD-TE*SC$Q>&S@%S@)WD(WA&T?$UD(SA)P=$I6E0+R=-VA2]I,WE,SA-UA,WB-SA+R@+UB*UB*SB-RB+S@*Q?)M<2XC.T@*S=.Q@+TB(TA)L:*D4)>.$C/)G5+M9+Q=,Q>&K5)P>+P>2R@1I:1H9/L;.P=/Q=/M;'@1#6' /!(8**<-/C5*B3+E5+D4-G7,F3+I50U>3T>%=,*C4)B2#8*!6'%;,'?0&<.#8+#;+(?0)D3*F5-E6<,*K:1QA(D5.H8,E:4L?3L>3N=-G6,F4.F4.F7/G7+?2$4'*5).C4/E6*B3)@1)@1*A2-C0)>,)<++@1+D5/J;%A1&A0,H5"<*&;++=/6I:/D30F31J74M95P;6QB3K<.@0*=,(?,/J63Q>5VB2Q>+G4)G4*M90N;*G4*D21J8-E3*A/)D2)<-'3''2&,0"%6%'7')=*&=*#<* 6(&7'3C3--4?02=12E62I:/F81L<4M>+D4"8)$3(,:.-C02E30@/,:),:-+=.1>3.?32G83N;4P;.J6/F86J:7F6/9).:*2B10C41D3+>-&8&*=*5I5,@/6H83B52=1'.&!*"&6((7)#0#!0#*=/#6).G73M>-J65N=:R@:S?:TH=YIB^JNfRap[fl[ho[U^MQ[J]cTedU]TIiaWoeZqeYdZM`ZMa`Rvh^|nbƒsf†xm†xpvn~tnzohynfi`W`YSfa^lacfZZ`TRg\ZaZW`YYpddnbbsfgughughxiiqggpeetjjvkksiirggmde\VV`\Ymjfkffjcejcbmc_l_[f_Zf_[j^^:S<:R99U:8Y=8X@-P;-P:/I92L<5P=6S>2T<,S;/I8*E3-J6/O92U;2X<4W=4W<5X@6ZB5YA.T;/V=1T?2R?3S@3ZB5_G7`E5^C4ZD2TC/L@+C;%E4'J6.S>/S>.P=,K:.G9*F4.N;-P<2TB/Q@2M;-I52O0WB/UC-P?,M;+H8/I93M/(C1(E5*H7&E4$C3#E4!B1&A1!<,!=-#D3$E4(C4'D0"E1#F2&E2(H5'J7)L6*K6*P9/XD,R>+H5+G7,H8'B2$>/#<.7) 4% 3$!7(%=.*H7)J9&P@.XF-ZG-[G1^L%R=!F7@0#B/&G4(K6+P>1XE1ZH/VD.QA3YG0]J0XE.WD.UE-TD)Q?&O:$N<#P<&O< D2D2"M;$T>'S>*S>*S?,VA,ZD'TC$R@$R?(UB(O<"H3%F4&O;%UA&YE'UD&QB&M;%H7)E4'D4$G7%J:&O=)VC+WE)P>+P?*S@+O@,RA+TB,YE/^G*YB+ZH,^J.bN-cK,bJ-aI,`M*]K-]K-[I-[I5cQ/fS-dQ/dR-_K)XD&R?$P@&TB#TA+_K,cL-gO,aN,^K/]K/^M/aM/dO4hW1eT,`N/gR/gQ,dL+hU*fR,eP0eQ/bN/aM'^F,bL*`J'ZF&UB)UC(PA&L=%M;$K9%N=/YH!TB$RA'M?'J<E6%N=)WD'SC"O>%R=$L8$J:,U@,U@+S<*O>/SB&J:)Q>/UC,TB*V@(W@&WA'WA-[F'U?&P?)PB+QE*QB#K:%N:%N9#N:&P>&TC-ZJ-[H#P=,]F(ZB$T?+\F-]E)YA'UA*XE&TA'Q?"C69-$;-,A2+B3&=.'A1*F7'G8&K;'M@'K>#G9-RB,RB(O?)XF'T@+S>+P<,N<.O@1YG2_L/ZH'M;,R@*SA*TB)Q?*Q@2WG/UE)O@(R@$Q>*WD-\F*YC'XB%VD"O=*O?'K:$I6+S=1\G1YF*Q?&Q?-YE+U@"G6-TB,WE&T>*V@-V@-VD-UC0VD4XG+P>-TB0SB.WE*SB)I8(@1(>-$H3&N8(P>.VD.WB/W@/RA+P>-L<-H71J:0M<2Q<*I6.L9+F4&<-(:,.@.0C2-E3*E3+E3-G5-G7&A/#C.-K<1N?1L<-H5-G5,C3-C3/@4#0%(2(.C40D6-B3,A2(>0)B3,D2*@.$;()?1.H85%!8))A0,E1(>+-@.2B45J85L:8P>5M;5M;9R>9TC2K9+?.,?.*B.0I5,H5:WD7T@.F4+D1*J60P=.K8,F4'=+&<*&<+&B/"4&(1%#-!-$;($<*'>-(<)"3##3#&4&1?-5D5,=0->1,?1#7(&2($1'$6)0F71L;-I60I;2H92D3/@/';'5 .D2&=+&A.'E2%C0+G5+@2)>.(9,+;*+:*(5%"0#(8)(7&/<,4>2'2$0E54H63G5/I:/M<1M<+,?-,?.-@/.?13D62?31B56K<9Q?6P=-H30G86H;8F61<-2?/1B/0B31B1,<+'7&/@01G42N>5M=0B5-;0/;1-90-9-/:/1=0/<.+=.7L<7Q@7QA4P>9UB6N<:N7U=7T<6R97S;7W?<]F9_E:aG=eK;eJ@dG:Z@6R9/I1,F.0K12N62O:1P<2Q>.N8/N61I61J65O<7S?3S?.S1R>3RB3O<.L7.P;3U@5WA2T-%:-(@2-G:.J=+H;'D4*F6-L;,J:)F7(C5%A3&@3#>/%?/%B3"B2$A1%:,'@."A/ D0$B0%C0!B/!B0&C2,I80U@,R>/R>3WC2UA,M9&C2#?-7&$7& 5&#<.)E7,M=.R>+WE-[H/[I2^K/[H#N< F6!D3(H5*J7*O:*P>2\G/ZG+R@*N<2WE0[K.ZH/[I1\K)TC$M:$K5!I9!J9$I8 >/>-F5"P=(S@)Q?)Q?)UB*XE'VD%TA"Q>%R@(S?$L6!F6&O<'S=%S=$Q>&Q@"J8$H5)I6(H5'K:&N?'Q?,YG-[H,SB+R?,UC,UD+TC,VD,ZD.\F+\D+]H-bL+aI)]E+\D.]F*]J-^K,]J0`N,^L.bO,cQ+cO,`N-_K)VC'Q>&K=%M>%P?,^J,aL-fN-aN,_N1aP2cQ4gT4iS3kX)`L'[H+_K/cN,`K,bN+aM)^I0dP0fP(`I'[E)^I+aN'YF%SA*TC*M?%J;$J8#I7"H7%K;J8 L;%N>(N>$L:$N;(U@)SD#O>(P=!G3"D5*T&Q='R='P:(P<#TA(WD*WD(VC*XD(XC'TB(VC(W@'V?&T@(UC"M:(K=!;13)"5));-+A2)@2&@0)D6%E6&J:$L='P?)P>-VC-WD,XF(WE(SB-S?-Q=.QA3WG/YG1^L-ZH"J8/TD+UD)R<)P;/VC1XE.SA*P@+RB%M=)TA,XE+ZE*[E&TA(SB+PA#I8"J9&Q<-XC-S@!G5$Q='UA'P;#I7,SA+U@(T?)U@*WA,XC0[I1ZH.SA-PA,O@,N=+P?)L;'C3%>/)H6*P:*Q>+TD.YH-XD-V@-M:)L8*K8/K82K9.L9/K6-J5.L9-J6(C0)B1-D1-E2*D1*E2,H5/K8+@3'A/*M8:cI>bK$?*+F7*C3&<-%:+%=-$>.,?/(>/'A2/J<1L=0M<,E5';,+B1.K:(E4:P?3L=2O?.P@2TD2O?1K<.F5,B4,A2':,,&6),C3,@0);,%8(&<,%?/(C0+E3!;)/E7&<,3$ 5&)A0-G3.I51J61G5/H61J89P>3K87N<9P?7Q>/H5+A/)@--C1-E20L8.F2+D1,K60S@5R?,D2'9((:)&;)'=,%7)%0&%0$)9**@+'?.+@/#5#"1 %3#01/A4*?0(;)(:-&7*(+3E3$6%(=+%B08)"3$%9,-B41E6)=,*?-!5"('5'0>-0>-0;."-"+B1/C3-D2.J77UA:VB6R<+H20I83I9/A1,;*+=-*>.+C10G58N=?SC;L<7J:8N?;VF3L;0K:2H;9L>7F95C42B22D20C25D3.9*)6%):*.C34O?5K>2D71A47H:9K>=M@?N?@N?@L>?O@CUDAVD;S@B[IBZH@RA@P?FSDFVFJYGZdRbaSd[Pf`Uoh\qf[ncWsg[ym`wn`xl^zm_rdY\TGvpc~tgƒvjƒwkˆ{r‚xnwm~vk}tk~sk_TOi_\ngdkbcnddobak_]\SPe\\ofhmdflddjbbmgghcafaa^XXZTSaYY^WU]XUaWWWON_ZWb_[d_]f__fa`k`^]PLcZUhc`lff3J4:WB=[F6XB3R=1P;2O87R;7R;8R;8V?9X@7ZA8^C7`E7`C8\B4U>1M9*D1(C0*F1-H5.K8,J7+I6/K5.J11I41J64M95R=0O;0T>1R;0P<-P0T<0U<.T;(M50W>3[B7`E7`E0`H1]G1VB0R<.P:3V=8bE6^D2U?-J7)D4'A1'?2&@2&B2*E6,F80I<-G9+H9-L9.M:/N:0O<4P=1Q<0T>0V?0V=3W>6ZA/R;.P;,R<5bI2eK:cP*P=1V@0T=2W=/V;0U?2U>4U<-H5+C3(=/%?13NB1OB0NA-K<0L<0P@.M>/J<-F8,C6+A6"B3&F7#E5A2<-$8+#<*=+?+#@-$@-?,>/#@2$B2*O=,XA+WA1\D4\F)O9(I5%A.">+$<*#=-$B4(M<.UC+WC2[J2\J/YG3\K2[I'Q?"J9$G7*L8*L8*O9,SA,XB,YD+R@,N=-SC*VF)YE+\I.]K'SB%O;&O8"H7$I9 A2 9,9+?0H7$L;%K;#J:#O=(UC"Q@ P=N; M:$O<#K7F6&K:&K7%K5#K6&N(RA(O<%K6'P;)RB(O?(P= F2'I;,U=1[C/XB.WE.YI*XH(XE'VB/]G+XC-[D.]E&VE#UA%WC&YC&ZF)\H+VF#P@&Q>&Q<"K6'P'SA&RB H6%D7 7,0&"3'':+)?0)?0%?/&A3*K;'L>(RA)TB*U@-YC*XC*WE(XF,UD+Q=+P<0UE4YJ2\K/]M0\L#M;,TC(SB,S=*Q;-T>0WB/WB0WC/SC+QA(P?'R?*WD&WC(UB)RB'K=!D7"L;K5#P;'L9#H7L9!P<%M8$M<*Q>(O:)R=+YA(ZB.[F-YG0ZH0WG*M>)I;+K:*K:'C2&@0&D3)P=,Q<(M='N>5\M-SB-U>-J7'I5+M9/L90M:/N;0L71L91P;)I6&E2&D1*D0+G3(F2*I4-K7-H4+A3-F5%I3;gN7^F$A,+H7(C3$>.#<-%?/%?/1F3.F5-H:+J;)H6*H4-G4/C0/F2(G3.L75L9-I5-O<-UC1UD1O@2J=/F8+A2&;,%8) 3$':,$<)&;)!3"'9('=+ ;'!?,'C0*E3.D4#3&. 5%*E3+K61P;-M8-L7,G5#=+6$0I6:Q>=SA6Q:/I3-C0.D1*@/-B11Q;4VB.M81K76Q=5U@-R>2O=/G4&8'%6&+>./A1.>1+8.)7,)9*);'*:*-<,(7%"2"%8(0D60C/';*'<.'?1.C5,A.(A/&@.-F45N=.H6+E4+H41I7*<*-=,-@.,D2*@,"4"%6%+A/(8*+/" 4'.D61H94K91K7:T@GYM8I;2D63F6/@2#4&+=06H97K:5P=4P;0I4/G0-H23K82K71F3,?+1A3/C4.G65P>=YF=WCAUBQ?>RA7M;7K9AR@JTFFRAGVCDR@\cShh[]TKa]Tukbxh_zkawnapl_vm^ym_wi[[MA\REwncvitg„xn…yo‚yo~uk}vg|sivjcdXUnb`jbad^_i__ka_h_\[SOc\\i[]cVXbUVg^^kbac[Z^XYaXYh\\mabod`oeaeZZ^URhb^jd_jd_lccidcf[Z_QOf_[ifdife/E34M<;YF:]H8U@7R:4N65O54R97U<4V>6XA6XB6YA7^B9`C3[@2R<1G5.A0,@..E2/K4.G4+?1-A/0F01I/2P75Q85P86Q86R:6S=7R?6VB6[C2XA1S>2R=5R<1Q91U>4\A5`E2_D3_C4`F/ZD-VA-P=4S@.YD1ZE2VB+I9/G83F7%=0'>0*A1-G7.J:1N?1K=0J:+F5)F2'D/)J35T<6YA6\C3YD2T?3O=1XA7YE3Q>5UB8eO3kR2YD-L:1P?1V@1YA.TA/UE2YA/S8/J7,D5+A2-B;3LE7RJ5PD4N?8QA1N=7TE2NA0KA3JA0F;-G;&H:E6F4#B1%<+!=+$>.#:+!;+!A-B, ?/#@1"?0#D2%K5%M6$Q;+WB)P<%B0$A.!B/$B/&D1*I8)K<.UE.XI1ZK2\M1^L2aJ7bK/ZC(M;$J8$I8&J9'J9)L;(R=,W@+U=+R=+P?,RC+O>,SA-YE(S>%P;$O;#K<"J9"G7?- =-#>. B/#B0$A1?0#H8$M>#M< F6$E5%F5$G6#J5"H6$H6&I4#I3#H5%M;'Q@%N<,T?+S>.WE-XG-YH1]M/_M,\J*XG+WG*ZF.]I,[E.]G.`K-`M-_K+^I+\H.]I+YE*XE&aI-dO+aN/dP(^J-dP+^J-^J/]K.ZJ0\K+[J/\I.XH/XJ3_Q2bP.`M(]I.]L1`N2fT-aL0bK.fQ+[G,VD(WC'YE&VB-VD/WG/XH.ZK._N%[G'SB%UC,[J)[G'VC%SA'L:(N;&N7!H2A/ ?.#@2"E5&L<&Q@'O?&K;#Q;'UA%O<&K<#E7%M=(S@-WE.VD.XF+XE'TB$P=+WD,XF*XB,ZD/]G*TB(TA(VD)ZG(ZH)^L+YH'RA*QA'L<"G7&M<%XB)YC&S@'TA$P?!P?&L;#I9$K;$N>&QA%P?(M>'C6$<.#<.$<-&;-%@0'B4#=/$A3*M:-S?&UB'UB,VD1XG1ZH+WE)XB)U?+P.W=.Y>.[D/]J+UH(SB&M='L>4YK.WC*XE*VCE6!D6!E4C1 N7*S+H7!E4/VC8ZI,L<,O=0M:+H5/L9,H5.J7*J6.L=0M:2L9-F8)C5(D1'C5+H9/I;+F7.I8,G7,B6*I:*O;6\F4VA-I70H3)B/*E2(E3)J6)P81P?0P?(J8(G7(C4%?/*F3-H6.G7-G7,H9*G7,H30L86TA3T@/O=+J:*G7)@0'8+#7*!:-$>1+=0&9)%:$+?+&:*!4'!6'$A/-I6*@-$4"!. 1.H5+K4)J5,L:/L=-L7/I7%:+3H9:TA:XA9U<6M84H51C2,B/1L84N:0N6/Q9/V>0VC*O?*F50J9/F7&9-$5*):0/D22E6/?3/;/,9**7%.5))6'&7%&6#*9((:+#1% 0"#:)(E0*G1-E.,A.)D3/K;3L=.@3*>1,B0'=-&;,+?00@3*6+/9,)6*&7'.A0-<,",&9&0D45M>6QA1Q=/U<@YH5L=5K;8J=8H;2@41J30H40C3/B53E82F71F6.E50J;2I:3J:7J:4F<1D80H::R??SB5F6=U<7R::UB8N?7H91@0,<40C7/H97Q?7Q>:N;5I:5B54?23D63H97K<9QC:L?4E87K=>RACUADWILZKP[IP[ILWGN\LMUICPA@Q@>N@AN@GPEIPAIVGBUEO_QadYNH?g\Symd|qgzmd{nbwi]{ja{ldvj`ZQGb\Nxrd{se€vk}sj~uj}sizsewkcm`X_SMaUQcXW`VWlY[l\[m`^aUSULMh`akafrgipffpggmffb\\d^]pffrdesefpffhcbaZY`[Vja]meamcbl`bj`bbXX]SSh``g_bh^e3H65O<:XC8[C;YD8V>9U<4P63P76T;6U=7V>7Y@7Z@7]@7_@4[E2S=3K92G5/F31K40M8/I6(?/(<-+?+3K35Q:5R:5Q96T<7V>5W=6R>4U>3W?-T;3U>7UB3U=0U<3YA5^C5_D0\A3^D4aJ/^G.XC+P;-O:1VC0S@.O;0K:3K<1G8+F4'?-+D.0L60M:0P=.K<,H8*E5&>.&@.(D28YA:]F5\F7\E1R>/L83YC:_J3XD-WB6fO4gP/U?,K9-L:.T>0X@0TC-TC4ZC/T:*F2(A1.D4.E;2JA3NE4QF9UG/ A/!E0"H2 H4 I4$J6$B/'D1#E1%F2+L:/O>+M>-RC,TE-RD.UE5]K7aN9cM4]F.QA,N=)K:'H7(F5'F5)P;0XB1[D0YD-VE)RA.R@,TB+TC)V@*VA)S>$Q@"L;#H8$G7?.!=-?* >+<*<,A1"H7C3?0!@0"@/#B2#F5!D3"D2$F2%G3$I6&M:&O>'O=)R=-XD/[I0^L0^L1_N-]K/^L/\K.ZI.]L/^J-\F1`J,_I+_I-\I-^J*[G-^J+[G.]J+eP,eO/bO-aM)]I-aM*cN&]H*^L+]K*]K,_M1_N/\K-ZL2aS/cQ)_M*`L-]L/_M/aO,^I-ZE.bN1]J)R@)UB(XD&TA(U?-YF.YH-YJ+[I%YD#Q@&SC(XF(WD*VC)SA'N<)Q='Q:"I3 C1"C2&D4$G7'M<(Q?&L;(L;&Q;&Q;H3%H8'I9&K;%Q>)R@/VD/VE*SA%P="L:&O=+WE*XB,ZD(V@#R<&T?)WD'VD#RA*XG+VE'O?*O?$I9!F6%K;(VA*WD*UC+TB(TA&RA)O>#J9%L;'P>)R@&P?(RA'J:'F6-I9(D4";,$C2(F7"@1$D5*N- I5$J7#H6$H8%K:#O=)R<'T>)YC(XB)V@%O:&O='Q>)TB,TB.SB-O=*H8*E6*E5*D5-I:)F6)B20O>2VE-O>(K:)Q?0M:.I7+F4'C0-J7,L9/N>/M93O;*C5*C6(E4,E71K=*F8'D3,K:(G7,G9(I9*Q=/WB/R@,K:0K86R>4P@/O>1S?1U@5UD.N=+I9.I9'@0'=.*F32L;.H8,F6(B3'D5.I61L9/L:3R?4QA-H9)E5-B3'7*(;.,C5/E90E6+?.,B,,A+(;) 2$"9)*E2,H4,B.'6%/ /!%?.#A/!E/,Q=/RB,J6*F3/E40H57R?>]E>ZC:R<6I92E4-D14O;6P;2P91R<0T?4XE.P?*H00M7/J6*@.(<-.A3*B30G8/D7,=1*:,,=,08*)7();))7%&*-!.!&:*#>+(@,-@++>,-E41M=+A2#7((*0E3,>.,>-1D42H:2L:0N;7WA1P<1O:2P<>XD7PB9SE;XF=YF2J91D72L62M9:VE;TD:P?7I85G;6K=4M;:UB@ZFCYGBTE8D6=F99G98K<;N?9M@9H=5D::M??SCKZIWcQ\dR^fR_fQ[fP[gST]JKXDGVACR?AL;JRCNZIK[JI\KQ]OZ^PSM@g_Uwqdxnewncsj`wnb|pgvj`j^UaWNh^TneZrh[neYkaWoe[tl`rj]re\hZR`UPgYYk^`i\_o`coaak^]]QNUKKnefqeiqfithhshhlccc[]gbamcdobcl_`i__d_^\YTa\Yd_[g^]lacladh_bbZ\e^]mbclack`c9N;3S;1R90T:,S93X?5W@4\C6]D3[B3]A2[@/Y=1ZC2\F-ZE1\G/YB+S;+J5)F3-I65O=9SC2L=/I5*E2*D0/J64P>0P>.M6S?/N:3XC4[G*XB-[E-ZC0T>*F5.L;.S=0X@-SA/WE2[B+R8)G5&>1,@1*B4-F9,G;0M@8WJ7WI1OD0PE7XM4UJ4VG5WG1TE5WH0P@)I9'J7#F2"E0"A.#?,$@-"@*"A* @."A1"A0"B0 A- C-C/ F1$H4'D1&C0%G3#F4)K9/Q@0QB0UD0VF/RC3XG4[K7^N:bN9_I2XG0TC.O?-N=,L;,L<*N:4ZD5_H5`K0[I+VE/TC.VC*TB*XD&T>(S=&TA&R?"J8&K: C2 @. ?+!@+=*"B/!B1$F5$C4 >/#?/#>.%D3$E3!@1$A1&D2'G4&J9(M=)O@+RA+UA+YC(ZE.bN/_N1cQ0aO1`O2^M1\K/\L0]K0^H.^H1dM-bK-[H.^J,]I-^J+]I*]I+cP,bP.aM,^J)ZF.^K+cO'_J'\I)\J-_M,]K0^N1_Q2aT1dV*`Q(_N']I)XG-[I-\J'XC,WB/^K0ZH-TB,VD*VC*UB+[C-]E.[H)WD1_N(WE#O>$Q@&TC+XE,UC-UC+Q?)M<%H7"D3$D3&G5$D4%G6*O=)O=)M<&I7'K6$K5!F1%E2)I8%L:%N<(O<.TB+O>$J7%L:!K9)R@(TB)WA)WA#R=$T<%T="O<$O>#L=)QB)P@$I9)N>'K;%I9'K<&P>,UC,TB.TB+R@,SA)R@+SA-UC+SA(P>(P>'V@)R=)N9/RA(H7";.#@/%@2#?0%C5.S?-T>(P>G5.XF,VD+XE*YF-XE"K9(N<2[I1\I2`J0bJ/_I3dN._K(VD+XH,XG-ZG)WA,ZD,XF,XF+WI,XG-[G1]N0_N,aK,YH*P@6(4&5':*A1 A2C3#H8'P?(TB)Q=(T?(WA&T>(R<&K7'L;#J8$L:,TB)L:*H7-H8/J9/J:0K;*F6+G70M=;\L0TC'F6#B1$H60K8+E3(B0-H52O<1P=2RA1O;.L8+G9-I;/L<.F90K=*F6)J9+L<*L8.K<(K:*P>,TB*O=,M=2P=6TE2SC0RA4VE/S?0P=*K8.L9+F4'<+,<,)D20K9.F7'?/#=/,G80K83O<)H45SC2O>,F6(F69N@'8*'>//J91K<,F5*C0/F0.D/);*':)(@.2M:.H6,@.#3".-"0"#>-"C25VD)H9,I6+G3,E33L:9VA<]H>[D8R@7U@4U>4S@5SB1N>.K33O91M9-F40F7/A3(<0-B5.D8+?2/?2.>/2;+/=+*;)&0## -!#/#&5'%:)*=,0>,&5$(?.,F6)?0&:,0D6/H4+C/+B/-@/0A0$4#-6*&6'!4%+@0)@-3F55G53F43G51G51J83M9,J90M:5Q=9UA6Q;5P:5K;6J<4E86G:4G74I76K96M;7O=8N<7J9:L:;VG=[I=ZG6Q@2J<7I>5O?6P@9UE5SC>WD=TAGZIB[G=XC:WA=WDAVDERFBH=KPEBMBBRF@QD7H>7F;8G;@REIZLZfXdgVegVfgUghVeiWgm\U_MO\IJZEHXD?L;LWIQ`MP]KS_NX]MPM@`WJldUmdVofYh^T]RHbVNbXMi\QnaUocYqd\pc\wk^vlbod\mcYulaun`{nbrf^cVSk^_m^co`eqdftghnb`WKI\POsggodgpceoccoccdZZ_WWh``bZZgZZi]]bYY_XX^\Web^idaoffncfocfiadc\^f^_pfeqfgrff=Q=?W@;W@:YA7U@8V=7T<5T94Q86S::U;;X@:X?6W>5Z?8]@5YE5XB6W>7V?5R:0N6*I3+I5,I5,F4.F33H50L8-H5,K41T<4[B0Z?4V<1T;.R:/R;2V=2W=3[B3[B5\C2X>1W>1W=/U>.U@.V@1XC2\D1[B7T@3P;0L97S@6Q>2O;/I7+E5.H9.H91O@2QC1Q@3O?6N>1E8.C5:N@7YD6ZE4WE0O>4P<4P92K80L90S?*P;&L7/S=/S>-I8-K:1U@5]E4XG,V@1\A3[B)J9%@2(@1(?1)A3*D6.K;-M>-OA.K@$D9.OC.QB-P?,O;-RB2UD5UD0Q@'K8"I4#F0#E1"?0%A.$@-#B+ @-"B0#C2"B1!@,=)"?,"B/!D0$A/'D1'H5'I8$F5-O>7YH7[K6[K2VF2YJ:aR;fT(M<*P>+N:1V@5^G6bM0]L*UD1VF3[K0\J0]J)VC*XB)UB%O=$M;(M<%H7 B1#@,$B.#C0A.!D0$E2!>.">-"=-%A1%B3%B3$A2!?/&D1(G5*M<(M<'N?,SB-WB)XB+]H,aN1dP2eQ0cO5gR/]J4^L1]L/\J-[E.^H0bL.cM0aL+]H._K*^J*]I)^I+`O.`N0]M-ZG,YF.ZG.aM.`L)[I)XF*WF+WE*UG/\K-]M/aP*]M&ZI!UA'UC.ZI,YH(WB*U?,[H2YG.UC,VD*VD+R@'VA.YD0ZE+TC1\I*VE%O?%O?(SC)UB(Q@0VD1VD1RA!>.$?/(E5)I8%J9'M;(N<&L:)L;'I8&I4$K6#H3%E2'J6%O8#M<$K9-Q@'K:#G6'M;#P=&S@%R@*WA)V@$Q;#O;&Q<(R?#I9$I:+OA+N='L:)O=)P=*P>'M;'M;%N;.SA*P>+P?,P>*R@+R@+SA)Q?&M;*P?%U>*S?.U@,R@%G7"<.$>.#<.'@2)D5-L9.R=*L;&H72WE/VD2YG2ZH*N?(L<.UD1[I.\H2aK0cK0`J-^H-[H-[H,YH.[J.\J*YF+XE*UC+UD(TE+XD+XE0]M.^M(]F'VD,RB%?05'3$6'8, ?1!E5&K<$K;"H8"I4)S?$Q;$O:%K7)M7'I9"G5#K9+Q?)K:+H8-H8/J:-J:,J:.L<0M=0VD/VD,N>&@1%<-(@1.H6!<)'@/0J83P=2R?2N>2R>/O<,K=0NA0Q@3M?1M=.M=*K9(M8'L8-K9(J9*P>*O>0RB+L;/K;2RA,Q=-R?1TC-O>,L95TA5R?+D2';)->,)C1-E41H95&7(*C54K<5P@.O>5UD1O?+E5*M;4Q>+E3*I5.O;)G4$>,*E1,F3+A.1E3-A/*C/3O;/H6-A/)7)!3#(/#"0#$7*-G7-I7+E3*F3)E3.K67TA7R>5P<0M9/K76Q?3N<0L91M:+E2/K8.J90I:4H:+;/,"*;/4H;2C5-<0*3'/8%.<+&5'&#%!."$-"#/#$5'(9),8():)*B0*E5.F73G84H;,A3,>1.?2.=UC9R?=UC?UC5G6:L:8P>6O<7OA:TE:WFYB@[EDZGGZIHSGRXKQVJMYJGWI?OAPB>RBO`P_i\pmaok_khZedWeeXef\R[NQ^OM^LFYH@QDDUHP[LV_O[]M_ZKk_Qq_RhXKm^PteYcUI`RIsd[si_uj_ui]ui_wg`zje{ofymbrf^i`Vtm_tn`{pboe[XNJoden_co`dk^bj_`h`]ZNMdXVnaak`bl`bk^`k``jb`kd`lddmccmccnddndde]]_ZVfa]jedriiqfhpdgkcdd[\habmbdpgenfb4I37P<1L:5M94N74Q89W=9V=9T<YD8V@5V>5W>7V?6W@4W=2V;/M6.K5*G/)G/,K31O93N:2M8.J7,H4*I5-O70V=.X=/T:/S;.R=/S>1U>2X?3Y@5[B4YA4Y?5Y?3V<3T<3S=/Q=/Q=/U@.U?7\F9]G4VA2Q>2N;/K80M80K90H<-H;.L>/O@2SA1O>5O@3L;7O=9R@:]H8ZH5TC1N>2N;2O71J6+C0)C0%A/#C/,L6+O:.L:*F5*L82V@7XF0ZC5_E1\C)M;&B4(?0(>1'>0(A0*D3*F7(H9(E6#B4%F7(H8&D3,I5*L:,P>2VC1UC)M:"G5$E3"B2&E5#B2&D1#A.!C-&F3'F4!A/!=):%#:)<)?,$B/$@-"C/&F6'H7*J90RB7]K8`P9aO8bR:dV@l]?mZ5dM4cQ:fT+R@&K9)O='O=-N:3ZD5`I1_J.ZG,TD-RB2ZJ4_O.\H-[H,XF-WB(Q<)O9)M<)J9$E4'D2#D1$G5"G4%F4'E3#>/;* <,$A1%B3%D4%B3$A2'D4)J9(L;'L<%M>,SC-WC+ZD)YC+_I0aM-_K1dP4gS1aN3aN5bN3^J2^H2aK3dP2fT2dO.aM/bN,_K([G*\H(\K.]M2^M/YH,UC-WD0`M1bN,^K-ZI)TC&N>)OA,UE-XG*WE(TC&O@"N<'O?.XH+ZH%XB)V@,ZG.VD0XF/ZH-YG)O>'O?'M=+Q?1YC)R@&Q@)M>)O?*QA*TB&O>/UC.WE1TD$C4">1'H8*N<'Q='P<$L9)O;*O=#H5#G5&M9#J6#G4%K8(UA&N<%L:)N<)O>%M:,UC&VB&TA$Q?,WB+T?%N9#G6#H7'L:&L:'M=+Q@,N=)N='O=*RA+SB)R@&J;(N<)Q?'N<&K9,O;-RA-RA-SB(O>$K:(O>)P@-RA*O>&L;#F4%@1+F6(A3(B4,F8,M:/U@-Q@,SA2\J0[H1\I0ZG,O@*O>-UE-YG,\G0aK0^J*WC)VC-[H.^I.aK/`N+^I([G+ZG,WE*RA%P@*T@,VB-VF)VD+\E*UE*RA+N<$C3=-;- :- @1"E6%K:!F6"F6'J7&M9#L7#M8#I4&I5'I8!G5%M;-R@,N=.M<2M<+I7-P=)L:-P=2TB+M<*M<,J:#9*&9)*@1+C0(@.+C0/I71N;.N<3OA4SB2T@-P@3UD4UA-M<.O>/P@*N9)M9*O:-I:*G6'G7,K;,K:)H4/I8+I5-P<,R=,P;+M<3R?5TA2Q>-H5*@/-B1+E2/H83H9+@1%9++C5-B51K=2TB7\K1SB+J63UB5Q?-G5,L7/Q<&E0'A0.H8,C2(@/.E4,B2,G//L7.F4,>0-<.*<++5''6'$9+-E6-G60I6-E6*D11K8/O<5SB7SD3P@8U@3N:.G5(A00F71H9,G5'D0)@1/H93M<4L;2E4%4##-",<00H73I9-<-+3'39'+5&'2% '%&$/%&.#$.#%2&,=//UGS`Q^dUgbWpdXyj_~ma~ma~mancsbWhYKvg[ue`zldylasg[xkc{kgyi`viaoc\kbXoi[so_rk[aZOXRM`YXdZ[eXWeZ]eZ\d[X^VSg_[pfcngfkbbpdgmedoihnjdqghpffnddj``oeecYX`XTmd`nccnebmd`ld`f[Y^SSdY[c[\aYZc]\7M68O97P=/J91C/0F/1L36T:8V=8U=8U=;WA>ZG0W=/S<0T?0S?1T@.S=/U=4V>6X@8ZB7[@7Z@8ZA;X=;W@6S@1P>0R?0U@2_G8bK3XB+M8-J80K82O74P;1K:.H9,J9)K8/N?/M=3O=5P=5Q<6T<7\G8YG5RC3M?4O;0M5-I6(B/'?-'A/!A-#G1#J4%E3%B2#D.'I41N=/YB1^C2]F'L<">0#;+$;.'=/*@.,C1*F4)F7&D2&C2&C3(E5$?,(A-.M:/R?*R=$N9%K8%G6'E6!?0 ?1#C4$D4$D1$E.(J5#E1"B/"=*";'%8(8%;("?,#?-"A.&C4-K<.N=3WD2YH8bP=kX;fV;k\?pb- <,#@0$C4%D5&E6'C5'D4'G6)J:'L<$L<)RC,SC.WE,XC)XB+]G.^J*[G.bM2eQ/aL1aN9fO8dN8cM:hR4dS4gX3gU.cN/bO.`L'YE)ZF)ZK'VG,WF-SC(O=*Q=*\I-bM(\J(YG!N=$N=&K;)N=&P;&M9(M<'I:$J9(L=/VF)YG#YC)[E,ZG/XF5^M3`M/[H'M;$F;$E7+N>1VD*R@'Q?*K<-O@)P@*TC*TA#M;'YD-ZG&K<'K<(Q?'SA*WA'T?#M8&N9'N8'O:(L<'N? I7'L:&N<"S?%M;*O=*P>*P>(Q?)TB$XD"S?$R?)T>(P;#H5$B4&E7(L<(N=*TA(R=+N>$I8%O=&S?*VC*TB-QA%K;*R@*R?$J5*N8/PB,P@+P@(P@(P@)QA,M?-L>(I:$I9)K:.I9*J:*I:&F7*K<-TA*T?)VC+[H,]I-aL-^J(WC*K>*N@*QB'UB+]G*\F)SC&P?)TA/\F,\F.bJ+_H'[F&YE*ZG+WD)S>(O?,T@)P;$K:(Q@,WA,VG,WE)TB'O='K;%D6"=/?0 E4"H6"G5%F3(I5(M9%M7%M8#I5!G3'J9)N=+SB/VD,P>,L<+I6'G4-Q=)O;+S=(K7+C4/I9-E6$9*+C3)E6*B0,D2)A/)C1,J7-M:2MA/O?0SA5YI5XE5YA.Q@.P?,O<)L8-P-K8*E2(A.+D0.H61J:2G8.A2,?1,@3-A4+F8(K;2ZG4ZI7XE:WC:RA-F25Q=7R>*E/1H9*B4";-#<.(@3*C3.K2,H2+B2/A31A30C2-@+'<)(B1)D5.I9.I70F7-D26Q;5M8-@)$4$/$&;+)E3(C/ 4"+7)46&&. )' '", ","#) ",!"1%-?21B52L;-L:'G6+E51C76H<7H:6C58B39A2;C32<,4E86G:3C77I;3E74F73I<1I82H55I73E3-?.-;)0?+0@./A/.@/4F51L73N:4M;4O<8UA6V?8VB@]I?\H:UA9Q==P=>QACWFCXE?VB;TB=UEAZHG`LG_ILbL]jY^hXP[OGXGG\IFZGI\JP`PU`N[bQ[bQYfTJ]KK_LH[KBUCCYEB]G>S@HTFPXGQXG\eR`eT\`Q\^RecTceR^dQM[GEWFE[JR`T^eZhf[tla|qfzqdof}oc€reeYKj^Qwm^yhd|lf{lawk_xkbxkdxiauf_maZkbWnh[nkYeaPXUJ\YSb_[ha^nd_n`dj^`g^[]URjdaphelgdohhnefnfghdbif`pggqgglcbkaaf\\[QPaURi]Zk_]k`\g_Xg`WbVSbWUk`bh`akffjfe4I76N78P94O60M51L45O79T;AZ@;V>9U=A\G3[C3]D6[B,T:-T;/U?2T@2Q?3M<3Q=7ZB4[A6\B;aH?aGA`G<\D:YD4WB3XC.]F3]F2V@*H40L8/L91M:3N;3J<1I;/H91L:0O?1RA3P@2Q>4U>2X>6ZD;^I6XE5S@5O:7P88L:0H4(C/)=*'<)'?-&@.&@/$@0%B2'F2-P91ZA5^F1[C&J7$>.&;,#:,$<+%=+*F1+G4'G4(D5%B3$A2$A2$A0'C0/P+!?,'@0*I45XA:aI8_K;aQ@kZ>m]=qbBvh=k]2\M-_M2]K+K:(B3'E3)N8)Q:2]E8bN5aL/YE*P>$K9(O?1ZK2\N4aQ>kZ0]L*P@)I:$I9"F4&E5*B2#?0"C5"E5%G4%D0$A3#A2$D5"C4!C4#F7)K8*I5*H4-O:+Q=*SB)VB*SC/TE/WF-[F-_G/_G-[F1^M6bQ7dR3aN7hR6iS4jS6kT5gS:hU1fV0eS-bL,bJ-bN']L.YH&M=.RA)K<'J:)N=,WD/`M*[I'TC'SA"P<*N=+M;(G3+J5'L6$K7%L<&R@.ZF1[D/YF+[G-YH-ZI1\M3^O/[K$O%P>%P>%M:$I7*N=%N;$O=&O:'O=)O?&O>"Q="V>#UB#SA"P=&P?'P:%K6%D4$G6)N?'PA(UB%Q?&M;$K9(P>(P>(R@+VD/QB)M<,TB*R@#I6)K8/P?,R@/UC+O='L:&P>'M:(J7+J9*I8(J<*N>,Q<+M<*H;,I<(K9,Q<'X@,ZE+WF+UF)UF*WF)SB-RB,O@)QA(UC%RA)N=&Q?'XB.^G(WD,_L&ZF'XE'UB)TB*TB+UC)VA1SC+I:&I:'RA*XE&WE*\I+\H$Q?(P>&J7&A5%A4&E7'H9#F7 C3&J9%M<%P>$L;#E4*C3*I81R?2WB2VC,J:+E6!<)/N;1VA+R=)G5.F3-F80E6-@1+A/.H6*I5*E2,E3+D/+E2,I5.O83L?0M>1Q@2S?3XD4ZE3UA0S?.M:0P=-O>3TC7P;1G7)>0&=11J:*F3)E11L;*E78+"D21WA5T?.Q;'I6(G4,E4.A31J:5J=3G:/A5*?1)>/+A0/A2(C4*VF*ZD7ZE>ZJ9UA1O;6UA3S@-O=3K;+A2*>/+@1*B2)E45J81I5)D0)C0)@0,A4-?2/D6+D5)F5+F30I6.E7-H45S>8WC1O=-H91O>/K;+K:)M<)H7.E6,G4-E2.B0/C1,D1+D2)C4.J;3O?8M<(9(!1"7"'<,%:,&7-"/#.8)/6'%, "&$"'!'!)$,!#,#%3+&22F85F58I7;I7=K85D24D39I82D31G48M:5H94D6.@40F55M:2K46K62E13E81D26F16G25E69J=:N=5M:TBFWFK]LF[JC[IAXEH`HMcMPcQWgWcn^ak[J[HAVCA[IE]LN]KZbPcbV[cSUaQMXHNVEQ[IMXFHZGE^LB\KL]NQYLPQFY^S^dXcfZbfUXbQ\aQdeVedUY\LP`ND^KNbKYeSfiYtne|qg}oe~sc~rfzndpdZm`Uxm_vj^wlasj`tj`vkawi_qh[lcVf]PjbTohYf_N]VH^\Qef]eb]gc^if_nbdm__d[XWTOc`[h`]d`\f``gbaf_^aZXga\l``j^^hZ]g[Zj`\ga]j``kabkaaogcqiclf\`YYc][mfbogemgemje,B03K43O88U=9T??[E;X@9W?;ZAA_F@aH>_G;]G=_I:]D7[A:Z@2T:2T<1S<1Q<1O:0P84Q83O64Q75V<8^B8WC.M8)I4*M72Y@8`G7\B/U=.U;.S>,M9)I70I61N96W?:]D;^E?bKCfM@cJ?_G>^F9ZD:\F3ZB5XA-L70L92N;6R?2P=1L<4M?4N?/J:1N<0RC1QB1N?2N=4T?7Y@;[FA`L=\I=[G9T@:T;8VA1R=)I4&?/ 8(9($>,$>-#>.(D3)H40Q;4X@1W@'M8!D0">-#:+#=/$?-'?.'B.)F4(G4'E3(E6&C3$C3#C/)I4.P<-Q=+M9+M9,L92Q>,P:(K8$E6$E5$E4%F5#F2"G3&E2'B/'B0$C0'>-'>,%>,%@-"?,!@-%?/&D02W>;dKAiU9aQ8bUAqbCuhExkjX8cT*QA'I:#H8$G7%E5%B1#B2#E6$H8#D2$B1'A3&C4$B3"C4%H8)L<(L:+M:-K:.P>-TA+VB+ZF+XE.WF/XF1]I,]E.^G0_J0`N3dR8iV6hT4fS5iV8lY5lW5jT6hR0eV2fT0cL.bK/dN']K'UC"M<%K;'K;&G8&I9&P>*YG)YG(TC*VD&UB/RC+K:'F4+K6)M:(N<%P?)VD0\F1YD0XD+WE+ZF/\L.YJ.YJ)SC!I9!@4"D5'K:)O>$I7$I9%K:%N<'R@*VB-VB+R<'RA.ZH-[E.]G)YB(VB%S>$Q:%N8(N9'M<&N?&O=(N='K:(L;$J8 I7(O<*N=+P?&N<$P$Q?%Q>&P>%M:%M8'I8%I8%L=)SC+VD&P>&L:&M;)Q?*R@,UC,UC+QA&P>+XE$Q?"L8$L7-SB.UD/WE)M<%I7'P>(M8/O=0L=)I9,P?*P@,P?*M?)G=(G<'J<,P?*W@+VC+SB%P>L;'TD)XF+RC*O>%N>#O="M=&M=$Q?/^I.YFI7'UD+\G)XE$Q>%O=)SA.YG-[G0VE.PA'Q@)ZH'[E,]L,^J(YE(UC*T@)P;'I8(H8&I9+N<"G6%I9,TB*R@'P>F4"G5 C1,H:0Q@.S?/S?-K9-H7)J60P=1S@(H4)F30J72M;1J9.D50H9/L:)I7,H6(C2)C2+E2,H4/M8/H7.H63N>+H7$B06TB4RA2P?0P>3UC5WE4VD9T?4K:+@44()B3&@-*A2-E4%>-%@1.M<$G5.R=2R>-K9.I6/F6.D53M<7L=2F8);-$8)'<,2I7.?0'>1(Q@(R>1Q=6UD8WD5U@9ZF4UA4UD6N?1G81F81E71J:1K;4M92L8.G3)@-)=-'7*%7'.D4)D4&B2)C3/F6-D3*D27S?5Q=+E3,C5/K;0J:'D4&F6,I8-B3,B/3I70H6+B1*@.,@/+B1-G6/G87G8(4%%2#'8$&8( 2%%6*)5)/9)17('-!#(#'$)!&$++1'*2')3(*:.-@2,?0+8,(2&*3(0>0.A0+?,0B/5C17D49H79I8:G72E35I6;P=7H92@31A51E42F44G59K9;J;8K<9I9:K6AN:BO?FSG?UE=TD:SA3M:6M:>WD?ZE/S;4V>1R<,K6-K31N74R:5W;7]B7`B6U@0N9'D/*J5*M71V?6[B6[C0X?-S=,M:/M:/L61O84W?5YA9]H;_J=bL>cL>`H?_G<^D:^D>^F9[C4V@6WB8XE5S@4QA3M>1K=4M@4R@6WC0TE2RC2O@4N>4O<9V?=XDC`L@^JA`K>]E;[B6YD2WD'I7#>.!8(8(7%";*&@0%A0(D2-I66S>2R=&I5"E1"@/"<- >/"A/&B/'C/,H5(F3,G4(D3%E4#C0!F1%K3+N:,O;,O;0S?2UA0S?.W@(M9#G3!@0$C2&C3%D3"D2"B0#>-%A1!B2%B.%B/%C/$B/!?,!@,$?/'F1.S:9bLBmY=fU6aT=j^?ncCrf9dV/VG(SB*P?'I8&F5'K8$L7(Q<1]H4bL1`J4bL/[E&P>&P?'Q@+UD/WG:`P7`S)L?(I;%J:%G8'E6$F3#G5$I9#F8$D5&D5&A2'C5&D5"D5%I9+N@.RA,P?+P>-SA+VB.\F*\H+[G-YF/XG1]I/]G/aM3fR1cP0eQ3hT4iU2cT/cR3gU5jV6kV4iS0bR2dP2bL/_I.aL*^J(XF#Q@$L<)L<'G8%E6%L:)UC(UD(SB+TC(UB,PB'I:'I8*M<+Q@*RB*ZH-^L1^L4ZH/TB+TA*ZC/]I&RA(PA'L=!D6#?0"C4'J;%K9F6"G8#M8(Q<%N<)Q?*R@/WD+UD-ZI/^H)XB#S<"O<&O<&N<*P:(M<'K<&M>+P?,P?,L;+L<&J8"I7(K:)L<)O=&M;"L7 N8#M;%O=&P>%O=$N<%N<$K9'M<)PA-VG/YG&P>&L:&M;*R@+SA)Q?(P>'N@&Q?&R?!N;"N;#O:-TC-XE,VC&J8(J9)O>0N>-K;,I9+L;,P?'O>*N=)M>(J<'J=+N@(N>,U?*S?(O?&O?K:&WD'YH'SB'N>'Q@$P?%L<#L<&TA0]J%M;@/&K;*VD*TB$L:&N<+TC,YD/`L5`N0[J,]J)aM%\E+XH)WE)WD*WD+UA+R<(Q;+R=,R=)O=(K;,P>'TA'O=%J8!F4"I7"L97TH1RC1T@2U?1R=3Q>(O:+M9/K8-I7.J7,J72N;5P>2M:0M=/O>*K:,K<)G82L<1L;,F6+E4/H50F4,D2%;,!;++C44P?3P@0P?9ZI7[H4UB9VC9SD.E83'$:+&>..@4.A2+A.-E3%@19-(M90P=0L83I:5N>1K;3M:1G6'<-#7(5%/E23I7&8*&=/,M=$F6,H4-L<2S@4WB7ZD1Q>1N>5M;,D2/G52J85N<5O=6P=1M9-G3*?,*;+&3&&>*/H6.I7-G8)D4*A4*D0-G61J8+C1(<-0D54L<1H9+E5.H85O?/A3!/+?.-H6+F4+B02D3.C0+B0.B1.:-)2&(0$)4#&3$'6(&6(-8*1<+6:+-1$!%$(!$#(&0#-6*/:-+8*0>0.=/0M;Q@>P?CWDGXFGYFG\I=XDKaNVdRR]OMXKZ`Ubf[acWWdTRbTK^PQ_R`eZpobmj_Y\NX_Pej[jo_aiX_iYWaP[dSckWdhU]aNWcR`iYnn`vm`vq`kkYffSdeT^eUZeUWfXTeUYcQ_eVhgZpj_zqdvna~nc{kbsaZgVOtb[xg`zj`uf\fZPYMCwj^‚tgƒng~kb€of€qg|neyncwj]e\Sa[WcYWdWT_TPXQNg[XSHDcZWocbsacsfdpbdocccWW[RPrhdqheqhgsggpfflcbea]nbdmbdmccmd`mdalb^f`[ia]i^[g[[i]_h]`,B/.G31N74T<;UB?[G?]G=`G:`G7]E8[B=]E:XB8WB7X@6\B4[A6\D4X@9[C6X@1S=-K30M65U<4W>5\@2Z?3U>/O8*F2)F2*J5-M81T:2X@5_D1WB.Q=2O=2T=3V>0W>0X?1WB3XE7^G;`I>`H<`E=`E<_D>aI>cK8aK:aK3YD2UD/I9-G80J<7QC7WE8]G5ZH6XH9WH8TC9UA9UAaH;_G<^F:\G2UB-I;)>0&8+"8&";)"<+#<."<-$?0'C1)D02P<*M8!C3"A1"@1>/ ?-$A.%A-+G4*F3+G4(D3'D5#C0$F2$I2%H5(K7(L8*N:2UA/R>+O;$D1%@.$>+"<+&?/"?/$E4%C3$>.#>."B1"?0"?.$B/ >+!@+ @*'A3(I60WA0\E@lXAm^5]Q4]R:dY;fZ5^P,RB)O@(L<$I7#H7(N;&N9'P:1ZE7dN4bL4bL3_I,VD%O=&Q?.TE-TE0WH9`T,NA,J<(L<'K9*K9$K6#H8"G7!C6%D6+J;+I:*I:(J;'K;)N>+RB0UE1VG0WF/XF.[G.^H)]I0bL1aK0_I1^K2_M/bN1cP/bN.aL0bM,^J-]N*ZJ+\J4fR2hR2gQ/^L2_M1^I0^H.\G)YE*ZF)VC(Q?(N<'F6'B2&K9(Q@&RA*SB-TC(TA'J>&J:+O?+Q?(QA-WF,`N/dR/^M2WG3VE/VD*W@+UB&M=&I<&H:#C5"@/#C4$H8!F7!H7%L<(N:(L8'K9)L<.R@2YF/ZI0]K)XB#R<#O9#M;(L<)M<*O>+O>(M<*N?+Q?/RA.N=-M<(K:#I7%E7'J9'M;$N8#N9"L7$R?&S@'TA%S@'TB(UC)P>(O>*QB0XH-XE(UB&N>%K;+O?+P@'K<%I:(L<(L;$I7%J9&N;'Q;*VD*XE+UC(M;-N=-Q?0K;,H8/L-VB,TB*QA%O>#P>#T@&XF%RA&M=(RA-TC$I8!G9#N=&S@ E4?0"D6'M='L<#J7#K9(T@.\F3cP4`P.[J(\J$ZD"U>#K;"M;*VC-WE+TA+Q=)U=,V@+T?.U?+P?*O>$O=%K9&H7%G6$I8 J8)F9.M>5WD2U@4U@2T@+S>(I6-I63L:0L9*J7-H5,I6/O?2UD/TC-R@.L=-L=1N?2L<)C2*A11I65I8-?."5&"5'%:-*B4-H:6UE;[J6SB1N;4UD6QB,E6&=.#8)'>//C60C45H6%<*6)!6.&F61N>6QA7QA/I9-H72L9(?.!6' 2#&=+0F3%:+)=/2I;-F9)C4*C3'G5.R>7[E3U@/L9-I80F4-D2/G5/G52K94L:4N=3N:-F2,B/%5%,8*.I51L80L91M:(B2)@00J7-G5+A/&8*&8)/@24M>4I:0E6/I91I9(9+&3#*=,*D2-I6.G54H72F3/F4-@/+6(-4(*3'*4$'3#&5&(6(-9)5=,7;,16)-1%)-!).28'.=-2A00B0/A02D31C13>2.<-1>.4D25I64H5;K6;E48A59B60>/7J8=N;9M::N;:O<9I;8B69G9>KK<@QABSBDQAEXEJ\II\ID[HJaMRdR]hVZbTPWJW]S`dW\bTSgTQeSObPO`OahWdfUlh\\^P]bSik\fhXdl[ci[]dT\`PjmYssafeSUcRZiXgm^tre{wivwetp`lk[fkZel]\hWT`QY_NbeTheZh`Ug_Rph[pgpg‚qg…tl‚oiƒsl‚nfƒsjg[Qxl`€sh…vj†rj†tl…tkpg|nezoexi]cYQaYVk__m_^la]o_^iWURDAe_\kecodfodbnddkba]UUaZVke`lc`k`_j]^h\\f^\e_[aUXg\]kaaja^lc`mdaie`learffthhuikpfh-C0-G3/J71P<9T>A]GBbIAcJ;_F8^D;\C=\D;XD6U@0W>4\B5^F:aH7\D7Y@5W@0S;-M2-M33R99]C1T<-Q9,Q8/P8.M8*I4-L71R=2S:1W?2\C0WB+M:0L90O;1T>2Y?.T>,Q;3UC:`F:_F>aG;^D;`F9`E.)=-'?*#<+%?-$=/ 9+!9+!;+*F21O<,O<#G7!C3 ?0 >.#>-"<*#>*&A/(E2'B1&A1&A2&B3$B/#B.&E2'H5(K7*K8,O;-P<$G3#@,%>*)?,&<,";+#?/%D3&B2%;,%<-!;,!;,:*:(=)!?* >)'A2*J80WA3^H;hU>k\?`S1TH/UG4ZL1WG+R?)M>'M<#J8$L:'M:&N9)M;,S>3]H2_I9eO;fO1XF(O<*R>,UB,UC*RC,SE*K='G6*M;(M:(K6%H8$F6!C5A3#D5*J:0RC+P@+QA'N>+QB/UE1XI3[K1\K.\I-\H/_H-aM/dL4fO4dN3aN5cQ0aP/aN.^H+ZD*WC+VD-YH+VE$P>-YG2aM1cL/]J1]J0YG.YD-[E(X@&Q?(R@)Q?+N='E5&A1&G6)O?(RA*O?*P?&P>'J=&J;+SA+SA(TA+YH,bP,aO,ZJ3XI1TD.VA*P;(L:%H8(H9'F6&D5"F3%J9(N>(PA(O?+RB(O>(L<)J9*L:+P=1YC5\L.WF"O:"O9%N8%L9,N>*M<'M8'M8'N<*Q@.UC0SB2RA1R@(L;"G6#D5*M<+T>)Q=#N9%Q>'XA*ZF(XD(UC)WD)UE*R@*P?*OA-TE*WE&UB%N=%K;(M<$I9C3&J:*O?(J:'G6%G6*Q=(S=+VD+YF,VD*O=0RA.RA0L>+H8,L:+K:&I7(M8*O:.VA.ZE+XB)V@*VB/[H)TB+SC)SB!N<'U@%SBH6#I9)RA(N>%D5"C5#I9#I8 B2#B4!C5*L='I:'K:(N<+V@+YC0^L0[K*WF#RA'VA#N6#G7%I9+R@1XF+Q>-Q=+S?*R?(O<,R?)P<&L9$I7%H6&F5%D3%C2!@/%B3.N>7WD5UB0TA-O=+L8(G4.K86SA0N<)J7(B4"C3*P>/XC+U>+T>*I9-K<1Q@-K;&B0.H62M/D5#8*(:,*?/+A0,D51J;0G;+A5)>0+B3+H8.P=>cM/N9*E2+A1,@.,C0.H6/I7/H61I71G80I6.G3,C0&;(4G82O;3O<4P=+D3+E20H61L8.G3)=.&9*&9)0F30I72G56K9/G5-E2+>,->-,@//H61L:3N;3P=/H73L;2E64@33>/.;,-9)*7&)9(*8'0:)9@/7=-C6@F8EL;DL8;I9=O<=P=:N:>P=?O>=G8O<@Q>UB:J=.M94R?>bGAdK?bH<`F:`F:cH;bI7`E2[E0T@)C3);,)=0-B4+B4.I82Q<3XB2[B5\D5ZD4WB2V>6Z@8\G=dL@iPDnRAiO;cK>_F1V?)G6(A1+E2,H1'A0$>-$=/#<.!:, :+'D12S?4XF(M<<- @1$?0"<+!:' :&!=*'B/%@/"=.!:-'@2#=,#>+"@.&D1(F3%E3*J7)K7&I5*H3+E0+D/&A/#?/#>.$@0&A1)<-&9*!8)"6)5&7%9&;&!>'"=.(H6.U?2`J5cQ1`P4PC,J<$F8)M=*O=(O9'L<&M=%M;&N<$K8%J5'H8(M:/XB3\G:dM>hR9]L+P=(Q<)Q=(RA&P@(N?(J:&F5'K6(P9)L4'H:#D5"@3 >1%F6&I7+TD,VE,UD/VF.VE/WF1YJ4^P3_N1_L,]H.`I0cN/cK5iP5gP8iV6cR1bQ*ZG(WA&Q<'M:(L:-WA)Q;&M8(P;.[F1_K/\I.YG/WE0XE+WB(T>&N<%M;#I8(K:'D4(B2-K<(M<(O?*O?)P>'P>(K=&M<'Q?+WD(UB*YE*^L#YG%SC1XI2VE,U>-L;'E5(D5+G8'D3&E2$K6%M:(PA%N?'N?(O?#P>'N>'L;)N9(R<*YA3YG+RA%M8#L6'L7(K9)K:(L8"I3%M7%N8(R?-TB/SB2UD2UD(L;"I6"C5)N=&P;%Q;"N:'R@)]G+_H%XC'WC'SB(UD1WE*P?'L=)QB*WE&WC&N>&L<'K;#H8C3#G8+QA-P@'J8'J9(R>'V@*TB,ZG0^K/UC2TD-SB1O?0N?/P?(H7'G4*K8,Q@-TC+WE&RA#P>)UE*YE%R@'SB(SB"O=#R= K:C3D4$J:$H8#A2&B5"C4B3'H9"E6#G9,K>+J;(J:*O=*U@'W?'UC'QA#L="N=(Q>&H3$D5&H8*N=1VE.S@-P<)O?%K:%L9(N;'O:&K7$C3%E4%E4%B2";,%=-(E44Q?5UB2S@&G6 B2*E2,J7/O
.O;&F4%@3%F80XF)V@'T<&P8,H7.L;/O?-M:,I62M:0N?0I:-B3(<+&:)$=*&?2'D6*H9+K:/H73G54Q>9TA2M9+F1+F00L75S<3N=/C9!2)%5+(:,%;-)F74YI3VE5P@8K:0H9+A3)<0+>2)=//D56O?2L>.G:*>1"4($<-+F7/N;BcN)G2(@-):,,A//G5-G42L92K91J64I90G5,G3+E1-F33L9-M+/>+3=,8<,9A0=D5=D4AG8?G5;D/:C3F38B.7E/8E28C29B4>@/@>0A@5CF<@N@@WCAXB;U>=WC=VC=PB9I>@SFBTD?R?lP7eI6^C4\C-[A+P@-L=1K;2M:0O80V<-S:-P70S86W<2V;+N7*M8+K7-K6,J7+H52Q=7]E9_J6[E,N;*G4/J70O63V<6\B6]C6Y?:X@:bG?iM:eIkR9^M8UD1I75J77O=/L;)F6%@2$>0$?.9(:('A1*I87]G/U@@-#?0@/ =,#9*"5'"7)&?1%?*"=*#?/#@1$@.!>* A*"C.#B-&D/+G4+G4-I1/M:+M7*J1'D- >*#=+'?-'@-&>+#;)$9) 7(!8)7'6'7&!9)(;-*E2,Q9/[C4`M.XI1H<&B6%F8)M@+M?)K<&M=&N:$N9(O9%J6&F3'H6)M90VA2[F7dM=kU:cJ/T@*N<,QB)Q@'R?(M?(J=&D7'H8)N:'P7%J6&D4$*WC,YF/[K5\N4VL4^S6_T6^O3_N-`J+bK-bO.cO4iU7p[7nY2jU5dO/\I)SB'N>%K;'L=-UC'K;%I6,P'L7#F5&H7)G8)M8&J7#H5$J8&N=)SB*P>-UC0WE1XF,P?%I8&G6%J8(M<)L;'L;(Q?+^G*]H%WE'VE"RC(UG(WF'TC%Q@$Q>(VA&T@(RB(P@'O>&K<"E3,M<0VE2YF*S<%N8+UB&P>'P@(VE1_L*SA,P@-P@*R>2TB/L9+H4)G8*L=+R<(V?(W@'N;'L:,Q?%O>%Q@&RA'RA*P@&J;E4"A2*E5(L;$H6$?/&@1#<.!(K=$K=%N<+UC.WE-QD(KA+O?'H9%H9'L<+K<+D6';)"=+)C5*<0#9(%B/(M6.O;0M=.I:#>0"=.&D1/L:-J:+H8+G8(C5=.'K;+SC%N>'M<&J9-H5-K65U@-O9*I7-L;0L<.E5,A.%=)(>++<,&7-%;.(@02F83I:/J;2QB6RB0J:0J:+H62Q@2UA3Q?0I;-(?.&<)'=+#?,1UB7[G5Q>5I7,=/,@1)@1*A2.E61I:3N>/I9)?0!4%4$+@1(G45VC5WD*F3+B0+=+/G1-H40K;6J<3G94K<6N;2H50H7,H5+G80I:.J7/J8-F4,F40G5-D20K81L9-J60K9,I6'C0+G3-E11C1+=,0C3/E72K92J82E43F41H23M5-D4';-/D58L=>QC3E77C52>/4?/4=-9>-:;+<=-=?.=>0??1=>0;;.>A0BA1?C2CP?AO=AE4>?0>@0=>/??0?>1><2@@2DA3ED5IPADUD=WFAUC@UCDWDL[IFVC>P@?UC@RACTBHWEK\IN_MVePYgTQ[KSYJQ[HCV@J\GSaKYcOR\HHXFDXIZaQ`gWYbQN\GL^GG[CQ_KWbNTdOJ`JZjUpq^tgY]\MR[NR^Q[gYZhWWj\]l_jrg|sttekj[geZmf[iaUngZ_bQYaP]`TccTdcViiZjhXri\oi\mh[ji[dhXSVGgbTxqc€vi~qezqcol]hm\hk\sndvldsh`rl`stduhthsgƒvg‚sfrdoguf\re[yoe|siyqg~tgyscwq_thZqcXmcWgXTcWTf]]icalc`j_\k[ZbSTfVYj\_pbdscfrehpacuedpecnfcjedk`cqdfrdfl_acVZkafldinfjngimggmeekdckeckddmccoddpdama^:UB4O:-J23L58R:A^EFeLCgMBiO@iN@jO>lP8dI3[@6\D6_G-T?$D1'A22K83Q:4X>1X?/S:1R81Q8/N6,M7(J5*J5)E0+G4.J72Q>6XC6\F6ZD0R=3P<5O=7X?fL4XC6aJ;kS=oX>lV;fO9]L5TB4O:7R<9UA1R>/J<&@2&@0%@/":+ 9&";,#A/-R<5ZD-M<&A1>-"=-$9*"5(&?.&?)#=*$>/%?1#?-"=)?(#B-&D/$@,%A/'C/+G10N;+K9-L5*F0"?-!=*#>,$?,(A/&>,#<)"8*#:+"8)!7) 7(#:,(>.)E1)N7.WA5\J-RC.F9'C5(G9(L=,N>-L=*O?(P<%N9'N8&J6(H5*H8(J6/T@6^I7bJ=iR6aI,S>)N<(L<)O>)Q?&H9'H9&F7%H7&N8(Q9(O;%E6'A3$>0(D5)K:(M=(S@-\H2_N4\O7\Q8dX=h\5`Q2_N-aL.fP2dP3dP4hT:nZ5jV3gS2^L-XF+TB&N<(O>-RA*P?#H7&J6+O;,VA,[D/\F+VA)Q<)Q>.VD*RA+Q>-P=-N=*J9+L;+M;*O:&M:(N<)N=&I6%E1,O?-RA1WE0YI+VD+WF*ZH)QA-O@4RC-O?)O:+N=(G4(C0,H5.J8.M<'M:#H6#F6&G7,L;+L9$J5(H7&F6+N=&L9'L8-R?+P<&K8%E4'G5'G6*M9&K7%I8%J9,Q@)M=(M;.T@0UD1TC.M>,I:*G7$E4"G5)K:#G7(R?,ZG(WD'UD)UD#P?'SB&UC(UC(TA(R@(SB'TB*SB*UC,XF*UD#L;+RA,XF.\H)WB&S=(T?$P>(L>'RA+YF)P>)K;*K=*Q?/S>.M:*G4+J:+M>(O<&S?'U@&L;(L<)O>$I8#K:'O=(Q@)P?$J9!E6#C4+L=,RB'I8%=.";.6(7* <.#D4&J8'K8+Q>-WC'R?'R>&O=(K<&J;&K;#H7+P?,SB-UD+VE-WE*TC+PA#E8*M<)I8)L<0VD+M< ;,5##@/)F7+B4(B1(G5(H4+I6,F8'A4!;-"=..O<0O>)F6)E4,F7";-7'*L<'L<$J9%I9(I8)C1.K73T>+K6/K:-H8+@3*<,+<**?,+>,+9)#3)"6))?01E57M<2M>4RB2M>-G80J;-H93RB3WC4TB/I:%<-)?.)?-$8'%?,/P=3VB5Q?1H6/B4.C4-E60J:0J:.H85J;1E7);.6) 8,*D6/L94R?0O=/L9/G51E4-H3-I53M=7K<3G72H72J7/E36O<-M:-L--@.-A00G75J98L<5G90A06H68M92B4.=/6D69F9/4;,5;,9=,79)A@0@=->;,?;.>;->;-<@0>@0?H7BQ=0EA3GB5E=.C;+C<,NQ?JVCF[FGWH@WDC]IMcOM]MJ[KEZHG[IG[HO^LVbNZcO[eQVbQNYHX\M]_ONWCNYIX`NdhT[_KOXFTaQaeUhiZhkZ^bOQXGV`L^hT]hT\mWK`J[iTnp]ul[\YIZ\M^dV\dU[hV^iW]eVbhY„wmm_fgVni_skauk_tm_jiYZ_MZ]Pol^tm`mj\hiXom]rnami[deV^eVV[LeeWwsd}uguf}tcur`oq^mk_uncyneuk`vnctscrl`sn`~ui|tfzqb{qb}jcxe]q_Vp`VpaXqdZj_Vc\PkcXnaWrb[lbZaTPdXWkcdmeemcbnb_l`_[PQ^UVj`aoffrhftegpbbob`pdbnfdkefl`bpddodceZXaWXh`anbcnbbocbpfbk_[h^Ylfdpihohhtiirgdmb^4L:.F4-F20F28SgLAiO>jO9dI7_E:^E9`F8^H+M8'A0-G42P<:YB4\A/U;,L4/M81M93P?0R7VA:WCgM>fK@eKDcN>`K_D8W?/L5-I60Q>0R=.I50L5.M4,I6/K84M;2L:2N;1P+">++F1*I9%B3'A.'@-">/!A0"@/#A/&A.'?-$;)$;*%;)&<*%;*#<*$=,(B2-K7+O9.R<2VC)J:-F7*G7)I9*L(L9(M9.VA,YD+ZD1XF0XB*O<)Q;.WD.WE1WB0U@0UA,P?,P>+O?,S>+Q=*Q?*M<+K8*F3-O?0SB.TB1VF+SC1XI,[G+TB.P?3R@/Q>-P;,P@)K6/M9/O95XB/TA)M=!D4#E4-M<.M:+J7(I8*G8'E6*M>&M;(L;-T>-Q>*K:$D3'H7(H7*M9(M9%J5*M:,N=(H7*K7+M9+O;/O=.J<1I;/J:#B2#E4%G6&J9*UB(TD%Q@$P?&S@&P>'RA#Q<%R>)Q?"I9$K;)RB.YG-XF-[I-\J(VE$O@)ZH/^K&U?%S=$N<%L;$I8'O>*TB)O>,K;(G8%K9)M:+K8*I6-M;,P@(L<&P?(SA)N>'I9(M='J8#E4%J9(N='P>&M<)G;'I<,SD/WH%E7%;.#<-3&7)(B4'E5'E6$I4+P=)P?&O=)S@(TA)I=%G8#D5"F6*Q>.VB)SB*TC%O>-TD&K;%F8.N;+K8/R>.T@$H4;(;(&E3'I8+J9,K8%F2)C3'@0)?3&>2$=1)F76VC3TA&D4'B2(B3!9+">.-M<'H7#F4(I9&C4)D3,K7-L7-I5.F6(>/%9,)9,->..D1,@.-;,%4*&:.-D65I75K9/I9.L=0L=3J0F7.B3(>,(9)*B0-J8/O<5Q>2L:5I:3K<0K;.J:+K:/K;5K;0E7,@3&=1)A4&>3.G51K91N:4P=3N;2K9/I60M;4O?5I:0B0+@--E3.E33O<0R?/Q>+G4,B00F41G5-B0(;)+@./I74N<0H5*@.,?.1E44G64G6/A0/B10D34I89I66C44@35?3.9@1:A2;@49?2<<.;;-57):;-;;->=/E@1B=.A<-B=.B@1BH7?H7:@0BD4EB3EA2B<,C;-C:,D:,SI7g]LskZfeSW_KN\HMVHG\JGcPLfSVgWR`SI^KI`MG[HTbPglYigU\bRP_MN]MZdTdeVZ[JT[Mgj[mn]jjY^bO_hUfiYnp`pn^a^OZZJ\^N^eSYdSVfSPbO]gUegVfdRgaQnfXhfXbiWdmZkkW]^Mij\tufml_po`wlbvkaxl`zocql]edSadVsl_znarj]hiXim]nk]lj\eiZ_iYZdTfiZvugzsf~sf~sfxrbuqcunczpezlctg^ri]rk]lh]kf[gcUmgZwnayo`yiaxi`yjawf]}lc~nepcZc\QkcWsg[tg^nc\bVUdYYlabncenccoacj^\XNL\URh`_ia]e]Yj\[dXUdXTh^\kbcjbcmccodcoda`TQcZWkdbrgfuhfvhftgdj_[g]Ymheojhqjksiipgcla[(>/,B/,B/5L89T@BaJFjRDkR?hL=eKAgM?jObH>eK;aI6WB1M:0L94U>8[C6^C4YA1S;3R>3Q>6VB5UB0O<2O<.J63O;3S>6YC9\F5WA3T?7YB=_G9bHBkP?jOAlQDoTClQCdP<]H9\E7]E9aF9bG;^F8_D9bF9`F:cI0T=1J9,F3)E2-G7/D5*=.&=.(A1*E2*H30N<-K;%>/!9)&9*&9(%;)'@-&B-&A0(A2$<1 6( 3"5#";)+D2&@/">+">+&B0&D5#?0&>,(A.'@2 @."@0"?-#?,#?,!<(&>-&=+'=+%<+(A/'C1(G3,K8,O;,O:0R?3SC1O.O@1SD-QA(M:&M8%L6$H4&I6+I8,K8,N:.R>1XA6^H5aK1[G+S=)M<"C2%B3'D5&G7%K6*S>*V?%T<&O?+P>-N=+K:-O>0SC3]L8dR7eR6dQ0\K.\K1cS5fV7iY6hV4hV0dR1_L/]J1_L2_L3`M1_L5]N2\K/ZI/ZH/[G/[F*R=(P;+R=-WB+YD+[E3ZH1WD,R<,S=-VC-ZF5[F2YC3[F1XC1WE/UC,S>-S@-SA-P?,M;-L8/P@/TC.RA.TD+P@-TD*VD.VC.R=5TA1Q>/N<-P@*K;0Q=5WC2YC/WB+O?(M<)K:*M;+L9*J7+K9/K;/N?+O?)P?*M;*P>.Q@*K:+G7'F4)I6,O;,O;&L8+M:,J7)E2*G4)H5'I5'I8-I95N?.I8&F5%J8*L;*Q?+VD'P@%O>'Q@(R@'R=%Q< O9%P<&N<%I9%J:-QB-TC,YF,]K*\J$UC"O?(SB*TB'P<$J6&L:'K;'I:%O>*YC+R=)L<&G8&J:'M:-P<0T?.R?(L;&J;%M<*RA+N>*J;+M>-N<(H7%F6%I8,O?'N=-H=,OB+VG.UF$C4%?1&B2!>-#@0,J9,I9'A2#G4'L:'M;'O>*UE)UD(H;$B5!A2%G6)N;-U?)P@(N?(O?,SC)L;+L;2Q?*G5(J7(M9#D1%<+=*$A.'H5)M9'I6:&&=/(@1+A4)?3*C5.J;1Q>.K:8(*F5+E6)@2+F3+H4#A0(G6)G7$A2+G5.J7,H4-F5-D3$6("6*(:,-C1)E2+F4/A3'8-,C52K92H64K90L:.M>4PA1H:,C5)C5.K<2TC;YI:TC.F40G8*@1)@--F4-I6.L91O<2O<5M>2L<0L

/M=/L;2M=(C3,D60C6->2*9.-B2/F53L:4P=+G42O;0J83P>4O?0D5/A0-C01G52I75Q?1VB1S?'B00C15H73E5-@/+>-0D31K95N<1H6-C12D36H7:L;6H73E46G68H77D4:B18?08?29>3>B5<@2?0=>0@?2?>2=;0A<.?:-;:+;:,<:,D@2ID4D?.C=.D>/HA3C=/I@/DB/HH6FG5GE3GE2F>/LB4XOAbXJpfX{pcwsaur_ghU^cPZeQZfRY\MUfSKeQTlZ]m^U_SK]NObQN_N[fTmo^sn_ZhUJ]KL`OXeUZcSOWGUbR^gXhn^in^`gVenZ_gUhk[hfWfcT`^O]]O\`OYeSUeSUbP`gVll\mm[{q`{odnk[diWkp^sm[e`Pom^lk]poaurbzncynavk_xpbvo`rk]`^R{pd}nbxoblm\fjYll^poako`cn^^iYeiZlj`skctg^zkdpf[jbXqf\reYn`Tvh\sf]sh_ukaof\aWNph[~pd~nbukavlbzqg}sh|qg|oerfYkcTqjZwl]wk^ldY_WTbYVdZ[dY[i[]hZ\fXU]PN`URbXTfZWg[YfZWdZV[RNe]Ylecnfgoeeogdmb^`YQf^Zlgcpgitikqfgpfff`_gbbnjfnifpiingdneag_X(:*,?-,D11L76R>:ZF7]FeKAdL,$@,#@0#>.$<)%<)&?/ <-9) ;+:'">*$@,%A/'B/)A/'A/(F2%F2)K6*M9,O;-N<3TC1RA2U@2WB-Q=)N;.TB/TD.N?&J8&J7#I3#G3%H4(H7(J6*L8+Q<3ZD8`I3]I3]G0YC/T@"C2%A5&F8&I9%M9+VA*XD)UA(N>.RB0TB/S@.TD0WF3aO:hV:iT9gS4bO4aP5cR5eS8jW6gX3hW2gT3cP0aM.^J/]J/]J0^K5_N5_N1^K/]J0^K.^K-VA(R=+VA-YD,YG/\I1XI2ZG1YD0YA.YB-YG0YC1ZE2\G4_J0XB1XB2ZE/XD.VD/UC0TB.R>-Q@/TC2XF/TD(N>(O?(QA-RA.Q=3S?2O=,J8(J=+K/S>2ZF0ZG,SC,Q?)O;-Q=)L;+K;+O:1RA1TC/VE(P='I4%J9-O>-J:,G5)H5,L9*J7+P<)P;(N9*M7+H3)C2%D2"H3%K6'K6.N:/M:(M8)P;+P;-T@)VA%L; J9&P>+UC(T?$R;"M<"J9#H6"F5&I9,N?)N=(SA)YG&WE%P>"J9%H8&I9$H7"F5$J9(N=*O?)XD*[E-ZE-UB*Q@)N>+O?.T@0VA.T?)N='J:(P>*R@*L:,K:-O=/M<,H7'E3*I7,O<'L:-M?+RB,UE+M=#@0(H8)K:$H4'K7*M9(H9(E7#G4'K9%J9%L<*UD&SD'I9"C2$B3%D3,N<,Q>-O>)L<&J;,P?)M;.N:,L;*E5%C3"A0 ;+%6(:("<)'F0&L6#E1"<*%@/)C3-D7,F8/I90M*+H8)F6%C3(A1*C1,E31J7-@3&8*#5)):,+@0'E1-H6,@0*=1*C40L9+E21L92O=0P>5Q@/H7,C2+D3.J84PA9TB5O=0I7,F4*D5+G4-J7/L91O<.K8-L96R@1O;.L90M:/L8.H5/K<'A0.I81G6/B1)9)0D32H6=UC-G5+F3/M:2L85Q>0L;3G8/B23H83J;4K<5R@5WC-K8-C13F56I81E4+B/-C1/F44J86M;6L:3H74G68M;EVF=P?8K:@N>AI9=@/=?0=>1>?3>?1@@0A?/??.??/@?0@?1@<2@=1D=/A=.?<.@=/A0H:-K:*KE4QO>YTBb[K^]JlfXlgXeaRfcRcbPdcPefU`dR`gU]fSbjWho]om\ajWTgQ]lXal\X_TFYKVdW\dWfj\ppcom`WeSN_ORbTXbTPYIN[IReQWeU\gX[cURZJMWEV]OfgYni\oj[lj[fgWchXXgUQcQXbQml\qp`spb|nbyncffXbiXpq_sk]gaTkgZrocwpc|sezqaxqbvpbvpcxqeph]g`U}reyl`sl_ll\gfVdeW`bSbgXak\`iYffYb`Vd\TjZS^OFWLCnf[ti_xk^zl_vh\xkbznf{kcth^mdYtja{ob{l`vlbzpf{qg{qgyoevmbvi\phXsl\vk\rh\kdXZUOZSO\RS`STgYZn]^cUS\PLh^Zka^i]^m`bma_g\Y\UQhb^phdqgeohhqfei`\_UPfa[jeahcaf^]i__kcbfbaggfqmhmifmhengdme_f^V(9)/D1-F1)F/,I60R=+R<+V<5_C:aF@aI8bI6gK7gK7dI0]A-N:*I6.P<9_H:eJ4cD7_C8`G8_F8`G6aF2^B.T?*M9+K82R=5XB7ZD5[E4[D3YA1W>.X>5aG8eJ=jOAnSAnRAoT@pT?kQ:bI8[C5U@7VB:XE0+>/&:,1$$:.,G71N:,K5,K4,F5,N91[D5cJ5]G0R<0G44O:6VB7VC/L:+E5,A2,@0.B/.F2-I8*J9%?19)!;)%?-%@,$?*#C.#B1 -'<)'>)&@0#;-!9*9):&#@+%D/(F4+F4,F4,F5+J7&K7&L5(L8,P;.Q?/TB3XE3ZC1XB+Q<*P;-TB.UC.N?%I6$I5"H2!E0!D/$F4(K6(L9-R>1XA4ZD5[G6_I5`H5[G,L=,H;'J;(L='P>,WE,WE-UF0SD0TD4ZE4[G2ZI4]N3dR:lYApZ;jU7eS5bQ4`M9fT5eS8jZ5hY/cT0cO*\I*[G-^J+YF1_L5cM2_K.\I,[I+\J._O1]F-YC*XB+YD-YG-ZG.ZJ0[H4^F2]D0[E,YF,TC+XD-[E/[D.U?0V?4[G.WE-VD+UC-UB-U?-SB0VD0XG)PA$K;'M='N?+O?/S?1Q>.K9)D4&E:#A3-L=1UC1YH/\I.WF*S?,S>,S>+O?)M?+Q;/T@/TB+TA'O:#E1#H8,N=0L<.K8.K8.M;,L;*N:+Q=%N7)O8(J5,E7'G7$K7"N9%O7,R;/S?,U@*S>,S>-T?*WA#L;"L:'Q?*VD)VC%S@"N=F6@0$G6&I6"E2!E6$L<"P?%R@#L: D2"A2 C3!F4G5 J8%P@*TC(ZD(]F*ZD,YE,WF0TD.TC4ZF0WB0WB*Q<*M<*Q@-T@+N:,L7+L8,M9/L9*E2+H5,L9+O9.QB'Q@*Q@-L;)H8'M:*P>"L6#L6*P;*K<-J=%J7'L:!F5#I9&QB"P@'L;*L;*F6%A1/N>.RA5P?+I9'F9)K;)K9*J5)H9)C4%?0!;-2% + 4$$;(&B+&J3%F1&;,%C/,G61K;2L=3N=0L9,E30I85O?1L;*F7'C5.L7#?+&C/'E5%C4%C5)>/(>.,C1,C1(<.&8+&3(+7*':,*A0*A2,=.'=1'B2,J70L83O;0P=4T@:VC:SA6L:0I7/J71K=0J8-F3*E1'C2)E6'H5,L9,K81N<(G4*I7.N;-M:*I6.J7+D3/G41C6*?1/J7-H5/I4.E03I72H67O=/H6.J6/K83M73O;4O?7K=6I<3K;6L>3K;3P>3S@+F24G37J9=SA2H6#<)%=+.F37L:5J94I76N<@.@@/BC2A?1C?3B>2D>/B>/A=/B?0IA5ND8iTFhQBO:*S=1XB6kUIr_Prm[mn[fcRcbP_eRdeV]`QT[JLVBP\HYgRfiY[_PY`Pgl]uwhvwh}xfpu`cmWdmY^eUU^OO_SZbWbaVki_hf\]bUWcRVbSX`S]`TY_QTcRVhRZiW]fXY_SSYJW\Mfh]qnb{rfqiZtp_lkZdkYWiVJ^L`fUsn`yseyqe‚rixndel^eo^rp`sj_c^Tmj`wrgxobzm`wq]ur`on]lj^^YPRJB_UKh\Of\PfbT`^O`\L\_Q\_Pdh[fo`hl^mk]kk\qj\qdW`TEaXGsn^ymbymaxl_uj^xlcxkezh`rf]me[rlaxqexna}nenf}of{neymcwlbwh_ti_rj_uh^pd\f]UebYlgaofcpddn_am]]bYUYRMfb\icajcdlagj^^bYWZTOc`Yf^Yi`]bYZe\\f^Zi`\kfagc^hb\lc\ka\lb^da\jjdolgokgmhepifle_g_Y,E30L54N8,D3,B0-F4.K7+K6,O95X@6ZB5^E1\D3^G2\F+R=&C-$@+%>,*F2.O92W>5Y?5ZA7_F5_E5bG1]C,Q>-I6/F46Q=7YE5XF7UE5R@9WD6WB2VB3ZE9WG6YF;cM:fP9gQ4`N9aL7^I6\G:[G=ZF>ZE<[F=bI:cJ;cJ:]G6S@8P@8S?9XC9_G;cL9bL6YG4QA.F7-@3*,,@2)B3#>/#=-%?,&@+$?)%?.&@2)?1#<,"<,$=+'A/'H5(N7&K5+L7-L7.L7-K6)G5*I5.N9/Q<1Y@4^E2_H3\F-R<,M76U@5VA-O>*J9+I9(E5!B1!D3'G6*J:(K<+P@+SB+VC4\C5aH:eP:eQ-VD-SB.RA.SA-TA5ZI3YI3UF0UF2YH1[I4^L3`N7cS7iV5jV8oZ+I6)H4(@4#?1+K;.VF.[H0`L0XF-SA*P>-Q@*M.N;-R=*O;+L8,K8)N9&G8)M=&N9$L8%N=+RC-SB.SB.O@.RB,SA)VD%P;$M9)P?,SC-VF&SC(Q?D2A/(G7$C2=,#?1"C6&I:%I9%E6&C3(F7#G7&M9&L7%M;&RA&UC+[I,[E+]E/`J-`I+[E-[F2\F0WC/VB,QA+M9,P<,S>,Q@-N=.K;-J;/G:-E51J:1P=/R>/SD-Q@,S?(Q<'N=(P@-N=&H7(J:+N=/SB/SB&J<(J;&E6%G7(M=$M>(N=+Q<)N9&D62OA2Q?0M>,L;+K9)I8'C3+D5)D4+E4)B/,?..- /##8)&A.-H6-I8%>/'E5,L;0O?3O?3L=2H93E47M;5Q>3N>)D4,E6(I5!>+'D1%F3&E5%A1*=.(;)/C0.B.*=,%:+"5&&6(*9+.>1->0*;-.B0.E22K76Q=5R>2P;5P@7XF4VB0M:3N=0N>.K:,B32B4/A3,A3.C5.G;+F5(F1-J5(C2,D7+G7.J:3M=/J7(?-.C2.A11G61K9/K72P;2Q83K95H76L:+G4,H5/H62E85K=6P>3M;3I;0B51H76M?3K>1J=.G80H74N?;OA5D7(;,)<-6G96F37F49I8BTBF\HE_IM`MEXFETDV^NNMAHB7G?2GB3CA0AA0CA2D@2CB0B@0D?1GA2H@3I?3I2P=/paP™‰z—„w…shˆxmŒqxgzo_dcTW_OV`P]bRfeTijXdhWT^MHYGP_NciYfh\^`TYZObaUd`Voj_vrfff[giZddV]`RYbRff[_cVbgWjjZhh[UYK^fVehWpl^hfWaeWak^[lXan[]hV[bSPWK`f[ooevsiwqdtl`unbroaik]^gXSbQbj]urg|qi|rf€sgxtffp_gp_oo_haUb[Pe]Rg]Tj`Wj`WdZRb_ShdXmeZmcYi_Vog\shZvfYzi\mcUf`Sok\ghW_jWco\ajYdg[mh[vi\xiY_VFg`Qul`wn`|pd}nd}newlcrhaqjamd[mdZtl_xnaxo`ypfxn`yl_xh\ve^sc]r`Ypd[og\oe[gZT`VP`^\mfioegocama`k]b_WVYSQa\Yb\]d[]h[`eOOjXWdWUf[Zi`]g^[pcama_k^\ia^mgdlhdrfcrfdpfdh`_ga^jeanggpihqifpebi\\i\\3N;7U?=ZA2M9-C1.G51N:+K5)J43S<5YA4[B1YB2[D1WA+O9%A-#<*8' 9'">*&D.+L32V>3[A1Z@2ZA(R8'J3)D/0H04R:6ZB5ZB4VD2TA8YC5XA2XA2XB6TB7ZE;bL9dM8bL3\H3[C3Z@6]C:^D=_E@aG<]F?dL[J>^I;_I;dK:eM6cM8_J5XD0K;-D5-?1&8* 2&':+(>00I71K87S?6V>8[C6[C5ZC3V>3R>:WC:^H;_G7U?4O<4Q?/L:*B0)A/'C0*E2+A/,A2(A.'@.'A/%A,)B/'B3(A2$;,!9*#;,"=,)@-'>,)>-,B3+D4">-#@/#@,%D-$B-#B1$A2)A1$@/%@.(A.)D1'K5(K6(L7*J7*J7-K9+J8+I5*J4.N9,Q:4\C5_F0^G3]F+R<,O:3U@2T?/T?*M9*J7*H4%E2%F2*L7+L:'K;(N=(O=*U>7bJ8cL9dO9cO6]L5\I3ZC0WA/XB2\F5]I3ZG5YJ3ZI2YG4_M7cQ;gX7iQ8mU;s[:rZ4hT2bO5fS4gT1eQ1dQ9fX4aU3]M*TD&P>.YD3_H3`H0`J/`J1`J0YD+TC*YE,[D1_I/]G.\F,ZE-ZE0^G/[D/YD2[G3\G/WB*XA+YC,ZD+WA,T@-R@)SD+VD%P>#P<)TA)UC-WC-WC(O:&J:#G5%G6'E4*H82P?3TA2T?-O:*B3&B3(I8-VB+YE._H.TC+P?-Q@-Q@,R@/TB,P@+Q@,UC*VB&Q<%Q9+P?/SA0SB/QB0QB2TD1P>,S=)N:,N:,L8'M8.L>/RA-S>/U@.TC3WG0SC-O?.N@,P?+S@(UB!O="N=&R?'S@)WE*YF(Q>@.>-'B3:*:+=-!C3&K;(N<(L9-L:,QA(Q?)T?)P<)SA*WE+WF-ZH*WC-[F0_L/`N0_M3_M3\G4ZD4WC0TA.N;1UA,S?,R@.O>/L<-J;0J;1J:0L<5SC2WB3VF.QA.S?*P<&K;(M<'K:)L:)M<,P?1VE/TB)N?*N>)I7'H5)M='N?(M<+R<2UA/N@/K>0M;0O?.O=-L<)E5(@0)@0(B4+C4-C2);,/" /#"3'#8*%>-,G4,F5)B2-I90O>0L,$;+%=.&?.,D42I81H8/H8,H62N94N:5O;2M93O:3N90K:5UE0S@1N=6QA/N<,L80E42A20B3.B4-@2,?2'<-,E23J8+B20B52G85M=9RB4K9/D21D2/E62K<6R@3S?5V@5U?4N=5K;2H7.G6.H71G64F83F75J:4I82D42C53I7;RA2J;1J:5P?4P=7N?9L=5E7-@1/D54F75F3bH9]F>eKcR>dO=eO9dM7dN6eO7aL7^I5S@-G5+@1';,&:,*A2-F51M:5T>6VB1X?6ZB9ZB7[A4Z@1Z?9]G7]G7[D6UA9WB6XD2T?,I5)B.)F2+F21F3*D4,E3+F4)C0&A-&@-(B2&@0$>.%?/&B/&B/)A/'?.)@1*B3)D4#?0!>.#A,&E/"C/ A.#B2)F2&E1&E1(C/(F1&K5*K9*K9(J8)K:*N:&K7*I4-L7/O:0S=6^G5`I2_H7bK1XB0V@/T=.S<,R>*N:*J7)I6)I6-L9,P:,Q<)M<(N<(O:,U>4aJ7cL8dO>gR:aN6\J7\I4[G/ZD3`K7dO5aM8`N4\J4]K2\K9dRAm]9jT9mW)R<&M=)P@'N<(P>*R@-TC.YD,VA'O9'K:"E4!C2&?2*E66S@7XC4YB-S=.H6)G5*N9,VA,[C'ZB/QA+O=.RA-SA+Q?.VC0SB+Q?-XF)XA'U@(V?,SC)P>.TB.RA2TC3UD1UA,S>*Q<(L8(L8)Q<1RB-R@,R?.WE0WE0UE6TF/N@/N>/SB.UD(T@ J:I9$N="P=$R<'VA"K9C1&E4&A1!;+%>.#E5&J7*P<*S>,R=1VA/XG(VC(WB.XD/XF,XG.[J/[I*R@-XG/[L-[L.YI4]L5ZG7\E5XC5U@.R=1TB-SA.RA/P?.O>0K<4P@5QA5RB7XG2WE4UF0R@-P<.Q=(K8'G8)M<*N=+Q?+Q?1WE0WE.RA/R>+K8+K8*N<+P@'K:,Q=3XC/OA*H:.K9.O>1Q@0M='B2'=.,>0'=0'<.+>/&9*$3'&5)&8*(<.+A0+B0'>/'>0*E5,G7+G7,E5-C44G8.F40K95S@1R>,I7-G5&@.%;)%9*&>.&<,%7)*.#9*%@0*F71Q=8VB2S>1S>.S>/U?4TA1P=+G4.F4.D11F5.G54QA3SB5QA0L:)I6/L71E35B20A0.A0';+*;.,@1/E31G52F74F94H94K<7QA5Q?4N<5M;1J;3N>9YF3SA1R>2Q<5QB6N>6K<3J;0G85H82G84H78L89L97I86H9;P==S@0F36P<8UA;[E5L:6F54E45I88M<9I89M9@R?AQ@IVFIWER`LZdRT_NMVGZ\MTNAOC7GB4FC3HE4LH6MG8IA3G<*PD2UF5hXI~l]ˆvg…we‚zh}yf{vhom^jo]`jYlp`utfrqcrsdkp__jVXcRU_N[cThl[oo^ij]deWZ_PWaQcjYihXnh\sm`wna}pd‚pfƒncqcZd^Spmbvqexsepqcql_nn]pq^pm[kiX\\Nno`vtf}uhxqdfeW]aRbjWejXgiYij\YYO\]Tkh[ysdxoaqhZjcWd]Te_SYZKV\MafWmj\vj_yd^_VMZ`S]jZbiVpkY„ui€qe}nayi]vf[o_T]VIon_sq`}sc|m`yl`ul^xk^{n_xm_e_RcaTii[jhYrn^ol]ihYddWjh^ph]si^OG=b]Qog]ti]sf[nbXm`WkaXmbZp_Vl\SsbXwg[wi]ui[laXnaUpenc~nf}me|mcwnaxoaxmavh]WLC[SPg\[i]\lb[j`[g\_ZQN`WSlb_qedsggsdfqefofgrijphhpghregrfdpdaaWScZUhaZjd^mdejbch]_eZ]j_anccmeelb`mcaneaqedqef8]H9[B2T:5R;-K8.K8/N:/Q;/N:4Q:3S>3V@.T>-R7\B6^C0V=,P:,H6+F21M7/R;1WB8[G5\F6^F9`F6]C7ZA4U>5ZB;aH?hM:bI1VA0S?1T@4VB6[G9_J:aKfS=gR8dN6bK6cM4`M2ZI/TC+K:)D4'A1'@0%?/*E53O=4U?5XC1W>1Y@5YA:ZC8[A6_D4_D8]G4ZD4VA9VA=\G8]F3XB0N91M91M9.I51G3.K;.K7+H4*D2'B.$@++A2(A1%@0%B.)F4*H4*D4&?/)@1*D5)D2"B.%?/'B0)D0)F1'C0%C/%G0'K6*L7-K6+L6(N9-M=,M<+M<)M;(N9)O:+M7-L70Q+N:)O;)M9+K8)I7+M:,P<+Q;-R=*O='L:'N8*Q;+V?/[E7`K*S>)S?%R<(V@+XA)U?'O>(N>,P@*N=,SB+U@+VA)S>,S>,P?%H7!C0&>1+E53R>7XC1VA-Q=.N9.P;+R;-XA'U?'X@(K:)L;/SB/UC-SA/XF/TB.VB.ZE*WA&T>&R=(Q?(O=+Q?,O>/Q?/Q@+Q=-XB+T?'M8)O;*S>-V@+VB,[I1aM2_J.XB5UE0Q@.Q@0TC.WA%O<"D6!E6(L<'N<(R=%Q;'O<%I7,L;(D4#?.*G7.VA-U@0XC3\G2]F5]F0\K,[G,\F.YD-XF-ZH.[K-VF+RB.VE/ZL,ZM/ZL3[J4YE:^H9[C2U=1UD-RA-Q@,P?.R?4T@3SB6VE4SC4VE6ZI3WF6WF.Q?.N;-M:)G6*H7(K:+O>,Q@-SA2XF0VD2VB1S>.O:-N91R@*J;$H6-R>0WA&J;&F7.L:/O>/O>+I8(B2+@0,>/(-+>-(;-):--?1*=.)<,*<-"6'#7)";-&>1.G9+D6*?2*=1&@.)G33S@1N;1L9*B0%:)(8*'8*)>/,@3+=0-C30E7-B5(?2+F7/N=1R>3XB0V@0XA/XA/WA,N:+I6.H6#:'+=,3E40G54R@6UF6SD-I7*J88U@*@-,9)&8&*=,.A2-@2,B3+F40J9-F71I:/G7)E4.P?3UB2T@4S>2K<2N>6SA2Q=-J72M:9VFR?>R?;R>:VB=ZF?UD4E4:L;>Q?>RA1WA0U?4W>5S;+E0(B.&C1/J9(C0*F12R=5Y@7_C:bF7]D0T>/O;4T>3T=/W?1YB5VB1TA0T=1X>5ZA7[B5W?5^D=gK?iM9cH4YA0T@3SA6XE;`K;aL:bK8bJ:cJ8aH5\B4YD9[K>`Q8bO6aL8cL8`L8_M6\L,PA$G8'E6*D5)D5(D4)E5,J7-N;5YC4ZA/V=3W?8ZB5X@7ZD4\D6^H4ZD-R=/Q>5Q>8\E5cH1VA6T@9VB4U@.L84M9,N=*K7)F3*D2)E0)E/)B3*E4(E1&E2(E2*E1)D5(B1'B1+F4(F3#D0&A1'B0*F4-J7+H4(G2%K5(N8)N9,L9+L:(O;-O?,O>+P<*P:(P:'O8)O6-R91R=3T?/T>/U?2XD;cN6^I3ZE.R>)L8%G8*L<+K;*K;)L<*P?,S=-SA,P@)M='K9-R=*S>.VA6^I9bM9dO9fQ8cT7cT4cR3dS3dQ6cR8hQ6eP3bP5cS(R=+S=*N=(K:%F6'A4-I87U@5W@.R=.R?3WA1WA0WA,U@*U@'R?%J8*P>3WF4XG+P>-Q@-R>1XC0YD'P;&L8&M8(L;(K:*L<)M8+N:(L7'M92^I3]H*R='N9)T@+V@-[D*^I.aL-\F/YD3WF.SA,Q@1XC1XD'O:%D6%F7)O?'O=*T?)R=)S=*Q<)M9(K8'K72VA1]K0\H-YE/ZE6_J5_I1[J.^J.]H,YD*UC)XF-[K-WG/TC-UD0]K+[K,WH2ZI5[G6[E6XC.Q;.TC.SA+P>)N;.R>7\G7WD5WE1SC4WF5ZI2WG7]K.R?0S>1R=/L91L<.Q@/Q@+O>0TC3XF1VE5WC3T@/O/&6'$5$%7%#3& 3'#;-*C5.H:'@2(>0+@2(B0*G4.M9,J5/I6(>**;,)8*+=.-C6/I:/E70J73L<4L=1K<4P@0O<3Q@6UC7ZH5WE/P?(I7*E3,F4.F4!5$%7&3D35K77RA6TE3M>-I70R<9UC(<+#/ "2",>13D6.C3-D5.H9/J:.I9.J9(C3%D34YH3YD5WD0N;0H91J;4M>-E6/F7:OA8VB@VC9R@6UB4TB1Q<1S<2O;/K6.K8/P<2WA-T>1W>6W?4O8,I4*J64S@/P:*J21R=5[BeI:eI6_D4V<.L9&F2%H11U<6YB:XC3_C9gJ:[C7\E4XE1VC5YH3YC,P4[C1bF3ZA7V?=]F4W?5U>9U>.S@*M9)E2*D2*E0,G3-G6+H6*H5'E2(E2*E2'B3'B2&@0&C/%D2"D0%E4'F6'I5)J7)M6(L6'M8(Q;)Q<,M<*L;,RA+Q?,R=-S>)P:'N5*Q7+S:-T:/R;1S=1Q=1R?0VA7]I1SB/VA/WB4ZE7aL7dN6eO7gS2cP2dQ1dO4dN5cL4gO3fQ2cQ5fV7hX5gU5kY4lX.hQ,bM-\I.XG-[H2aM/cL0dL*\E'XD*WE*XF*VE(SA(Q?-UC1YF-]I)[E-[F.]F-_F/^H1`J-\F+VA)S>*T>+QA(RA-\I-\I(V?!H4%E7%H9&L=)Q@+TB*R@&P>,RB-QC/TB-T@%Q<%O;)T?+R=*N>,O=(I9)E8/L;6VB3U=.P<2TC5^G1[E/XC/XE/VD&N<&M;*Q?/TD3XG2UD)K;-R&N=(UC)UB*VC+WB)S>'O:*Q=-VA4_I0bN+[G*WD0YG5_I5]I2[J/\I+ZE/YE+WD+ZH*YJ-XH/WE0YG,ZH([G/\L5_N4\H1WA0S>*N:.SB.TB*N=)N:0UA8]I7ZF3XC2VE3YF4YI5ZJ7^L.S>-Q;2S=6S@;WF5VD.P?0SB3VE1UD2WF7VC1R>.N:4TC4QC.H=)I90UA+S>'M=+M>1Q?-L8 ?->*(G41M:/I71J8/H4+E.*D.*E0)C0':+!2"&5$)6&'8)(9.-E80I;-G8*D6,F81H:.H65P>2O;1L83K5.B-.?0-;.+4N>8UB0O:/I8;XH5SC3P@2N=!<,-D46J;2F6&9*%6(1B35J71L:1N?4NA0L;9ZE9UE$5'"-%3',>1.?2-@21F84K=2L<2M=2I:,E5'E43TD8[F5R?0I75I:8L>9O@+@15G9?P@:WA@U@fIDiPCiO=fO;eKBhNBkQ=lR6cJ1P9/B2+E4,J80M:1S=1Z@4`D)O:+Q;+O:-O?0Q@0T@.Q;*M6+O8+R9-Q:0O<1O<1T>1W>5U<8^D=hO7`J2VB0N;*L;.Q@+O>+P?/TB2VE,WC+U@.VD.UC.SC1VE/XC2WC4[F1\G0^H6bM7aK1`J0dM/cL3aK:bM:aM4bP1gT5hV6fV0dS/_M4fR/cO)\I*ZE,XC-ZG1`M*\I*XF)VB)Q;%Q<*T@)WB#Q;$Q:+VB+RC.SC/UD1YD/\E*\D,ZD/]G0\E,WB'Q='N>&N=.SB/XD+XB(N=&C5)B4%J9$N9,WA,T>)S>(P9,S?,SC-RC+RA)Q?#R;)R<.S<+M9,M=)L<-K.Q;-Q<,S=0WA5YH4YG2XF5ZH0SB-L;%K;,O>0Q>4UA4SC-M>,PA+M>(F6'B2$A,'C/(C3'C3(E50M=6SC-J:(M83[H1XG(K<'J:)O>,R>-YC+ZC/YD0WB3[G3SD.O@+Q<-VB/XE+UD)V@(U@*XB+YC,ZD+YC)WD+QA,PA,UD-ZF4bL7aK2WD2VE4YH5\K5^M3\I,XF.ZI+XH-YI1[L,[J2[J0WE*VD*ZD.\F/\J5]M2VF2SB/Q=*N8-S?1UA,O;.R>6]G7`I;ZI8[K2ZI.WG4\J8_L3YG/Q@5TA8TA8WC7ZD4VF*K0G9/J5;UC2K=5M?-F88(-F81L<2H6,=,(7).B45K:6L:3K90J8.J77VB4QB6RB4K<5P=7P?9O@3I79M;1V?6YF8YC6WA4Q:-J3-H44P=3VB6ZE-Q<*L7+J6+G40L76ZC8^F7\E7[F7YF:\I?dN=dM:bI9cJ9aH8`E8_G8^H7]G9`I6^J8`K9^M:`M8^I5YE3VD0RB+P;3VD2SE*L='F8'D4(B4'B2)E4/N:5U@9[B;_I;aK-R<-Q9,P8+S9.Q:-N:0P<1R;4W?6X?7^E;gP9eN2WC1Q>+N=.RA/SB.UC.VD0XF-YC,WB-YC,UB,VB/XD,XC2XD2YD4_J2^I5[G4ZG2^I3dN/bM3bM7cN8]M6dR2eS9jV8jV2eR2cQ1bQ/bM,]I-ZH-ZE-]J/]J(UD*RA*R>$K6#L7&P;'Q<(P;%M8*P,Q='O:*J6-O=.O@-P@0TC*O>(RA)Q=*O:-P<*P<*O>.N?+M:)M8+Q/N<0N;/O>.M>*N=)J:$A1&A0$?.'B1&D4'D4)H7/N=4SB1RA1O=1VC/SD)J:+L;*P=,S>)V@*WA.VA0TB*N<,M?.QA+Q=+S>.XD-WF-WB/YD'T?)U@(W@+YB)YE-VE/VE/[I.^H0`I3\G2ZF7]K2ZG0YH0[K4\F,WA.[F+XD.[G.ZF-WG2WF+P?&O=-YE.YC.WF3ZI5WG5UC4S@4U>2P@0QA-Q?5[F9`I6]F7[J7_M/[J(VE/\J4_L2WE.O>2P=9UB8WC5XD3SC-M>1RD0PA.O=2S@7SE1RA3ZE3ZF3XG3VG4]K9_M5UD,M<,M<*K:(C4 1$%5&%B0+K7-I4+E7/I6/E2/E3,E6$?1)>3,A10D21G2/F6.G8.H4(?.'>.(C1+C3.A2.I71R>/P=6Q>3M80L74H63F57N<8TA4T@3WD7\G4UB4Q=2K9/E4+@23J8.D5(=0+A3-D4)?/1H82K:0E41B1(7*5F96K;9L;4J93I8,F50L:1J<0?23>11?2/E7/G93G75G93D67K;:PB8P@6M?8L=3L<9TD8SD4J;:P>9QA7PA8QA;P?CUAHZFBWF>SACSBERBGXDT_KdfV]^NNXGGTEGSC?QDLUIU^OWgTPbLUdO^kYdjZejZVaPYdSejZcaQ^aQR]KR^M\hVahXdeRheRdbRkjZtn_whZrfZiaRniWhgUgeUliZ|p`}q`xp`to`lnachZ]l[\o[_m[sue{whssdwuf…|m…yksm_bcTsuf|vk{ui}yltrejm^lqa}pgpf]aZRldZwmauh[qh_ldZkcYmcZzmc}md€oi‚sk…yo…zo~uhpjZpj]}yj†p„{m}si~wn‚}r{uk{wk}wlmdZvj`wuf‚xlvg€zlrqexvl€xm„|pzoblbW{rgxpdrqano_im\fo]^kY]mZdcU]YMje[f`Uc[RXNFYSJmdZwkapd‚re}n`rk]~seoc}m_o^To_Wxlawk^xl_znc|pd{pdyoewmdxpfidYog\sj`un_rpbuqdwm`wg^zjavd^bTOhaYqnaqndtlgxoepj_ndZsdXtcWaTGdXNpdVufYvj\naY\QLaWNsi^}rixnelf`ifaogfia_obape`ka]cZVha^kb`ka^i^\k_]i]ZgY[j^^lbbpedrfdqebkabicbmhglggmghsijrijsijthjuikujixljqjgpgflba[RQrmjrmj1G47WB7VA6Q=4R:4Y?8[A9\C4V>7[F6XE7XG7[FcR@dP8[G5UB4S?4QA.W?6\G5[I*O?(J;&E6)C5)C5)D40L94T@8YD8`K=gQ)H5(D2*B2)B0+E30L80N81Q92T;.N7-I5.J60L61L5-N7,O:+O9,Q>+P;+P=)T>+XA)WA*WC,UC,R?/U?/T?.T>/S;,P8-P8+R9-S-Q@/TC.UC.WE/]I/]J-ZF-XC.YD,XA/\E-ZA/\F3]H1ZE1\H2\F2UA1SB2ZH2_L0bN2dP6fS9cS7gV2fR:iV>nZ:nZ4hV0cQ2dR0`L.\I2^K.cO/^J)Q?(K;)L;%L9"J5&M9(M9'K7(K7-P<4XD1[F,\G*ZG*UA,RA+UH,WG-YG,YF*UC(RA)Q='M8!F2!J6%K7+L9+L8*Q>(O>+O='J5#H4+G5-I9.N>/PA-SB,S?*RB)P?+R=,S=-S>.VA-O?)L;)N9,Q=-U?'M8+P@*N=*P?+Q?*N=)N=.N?1O@1O<.J7)I70P@*N9)I7&D1(B3%?/$@0*G7+H8/O>0Q@3UD/RA4PA3WG0UC'K:(M9(R;(Q;%R;,V@+O=)H9&I9'K=1VE.UA+R=,VB*UC-TA-UB)Q?)SA)SA/YG,^G/[F0[F1aK-_H/_H2\G2[G7^M1[I1ZI1\K2YD+T?+VA(V@.[E,WB1UF1RC)J8+R@/XE/WB0WC2VD5WF2Q@3R>8U?9RF4RB3YH6_J7^H7ZC4[H3\J-XG+WE.XG/YG1RA/N=5O?;ZF6UB2UA3SB1O?1N?3PA/N<2Q>1RA/TC1ZG0\J1\I0[I3_M6\K1SB.K;,K:*K:'@2%:+-A2+H5&E1%@,.I91J:1F72G8.F9,F7*C6+D50J82J8,D3(?0,@0*<-':+(=/):UB9ZF3XD3T@.K81K70E3+>.+=0.A3#5' 2$)<-.A0,A--D2.F33H54D44A43D88J:7G:8J<4F8*A2-G7/G90@31<12E84M?5OA4M=4H96F8:L>:RA9WD=UC7K:6K::TC9TA>TBBRA:N@5OA7QCCUEQ\LT\MGZHCZJJZIRZHX^K]dQacS^_OT[JOYJGXGDWHN^OXcRVbPXcQfnZjn^kl\giYcdTddTfeVkfTdeS]dPYbP^gSbiUqj[vn^yoaypbqd†qek`n`RleVomZrl[zn^„ocƒueyr`sratscedYcn]gsbmsbutdyugrobwwg„|m†zlun_eaRvqb|sdvqbprchj[ll^pj_wd]qb[oaYxlbzm`}n_ykak]Qui]ƒuj‡xmŠym‹}u‹|rŠ~r‹~r~vhxoapi\}wi†p†{n€wj{vkxznzym{wmzsig^Tvlbxtgvj}sfzviuteyuj~uhuk^pdZj^Sri`of]jj\ghYdhYjqansdin_una}sh}si|pf€of{hajcZvlb~od…tg„uf„ve}rdre~oa|k^l[PpdX}nbxk`vj_ujbzogwmdukbsi`ri`XOFti`ymcynbsn`qm_uj`xi`re[m\U[MIf\Ud^Ud]Sme`h]Se\Rtj`{k^od€reqh‚sfqd„ugtg]j\Uzobse€rf}rhlb]e\Ylcembcla_la^dZUbYTd]ZcZWgZWfYWk\Yn`]i^`k__kaaoccocaocaka^f_]mhglgfrjkrhiqkhskirijtkmtijsihsnjnjec]YaWTh_\i`]+;.2N=5ZF8]H7`F8_F7_F4ZD.S@,O>0V@7^F9_F3YA.S<-Q:*O?+O>)J9%A2!8))<-*D45YD;eMmR@tXEtZ?rW=nT?kS9cI6_D6W?:]F<_I7S?3O83T;>bE=aD9_D:`G;bL7]G>bL?cL;bI8aG8cJ;hM?fN=eL:cJ:dM:eN:eN@ePAeQ:]I0S?5VC9\H9`H;eO4]K.SC+N>&H8+K;-J:,G7/L80P>3XB9bM.T@.T@*U?+XA*XB*XB-UC.WC-T?.T>.T>-R=.R;-P9,S:+P9-Q=0O=1R;7W?6[E4\F1ZE/ZE/WB/U@/TB/VC1YF/[H0^J/]J/YF,VA.WB,XA2`H._F1`J4^J/[E2`J/ZE0R?3SB0UD/[H-`L.cO1fS8fX7hW5hT:hR>n['K;'RD+WF-YG,YF)VC%R@%O;"G3B.!G3&L8)M:-S<+R?&L;#D3&C2%E0(D2(F6*K<+QA)Q@+V@-RB.TB+T?,R<)P;+P<-O>+N='K:-P@*N;(M8.N=,L;,K:,L;/O>/P?1OA,K;0L9'E2-L:1Q?0T>*M7&E2+G4*F7+H8+L;/P?0RA/SB1VE/UC/VF5_M/ZE*U?)U?%U?'R;&T=,U@,N=-K=(J;)PA3YI1XC*Q<.UA+TC+O>+P>(M;)Q?)Q@/ZG.\J/XE0ZE/_H.^F3`I/YD3[G5_M5_M4^M2[J.QB)M>(O?*TD,VD(RB.RB1QA,M<.SA.XE3ZE7^H2XF2VE1TC5TB7VB:UF5VG7]L6aL6]H6VB4WE2UE0TD,QB2VE1UD2O?/L<9WG9XH2TA3XD4TC1P@3OA2O@7R@6R>0UC3XF2ZH-ZG/\I*XE1]K3[I1TC0M=-L;)I8*B5+C40J:+G4'C0)D/+D34K<1H:/G80G90H:(D5*F7+F6+F3,D4)@1)/*<-.;,3F74K<3J;.B0->.,@./G57O=>VD;XE7WD+M9.I7-E4/D1*<+&7()9,)6+#1%&7));+.A/-A.*=-,A/3F36C12@0/A33I::M>=M?4F7,B32M=4M?4D86E9;PB7PB6PB2P@5O?6L==R@>YF<]I:R@7J9=P>9Q?>WEDZHHQB>M=:PA;PAIWHX`Q[`QQ`OK_PTbRbgVghUcfS_cS]^N^`Q[bSLZIN]PRaQYdT[_NacReiVkhZggWmj[qj[tk]ul^liWljYhhUcaPlgVzp`|reƒug„wivh€tf…se~k]n`Stl^tm_}rb€ra†rftextbwxevvhol^gobstexufzwhytfle[{tf€reygZsbVpaU}l_~m`ym_ifXjfYsj`|md€ohqi‚qjri…vjˆxi„thteZ€rf‹}q}q|p‹~p‹~qŒ€t‡}qvh|tfkbW‚ynˆrˆ}o€ykuvgwym{zozujoh]cYNui_um_uj]th_ni\mk]vpcxoarfZvj^xlbulaskafiZfiYml^yug~uh~qdqeshƒwm€qh‚og}hbf^Uzof}qesf†xhud~tgpc€ndyg\gWKpdXylaxmcth^ujbzohyohwicsha\QI^TKrh]m_Un\Tf]TZUJj`Vk`Vse\yf^{gdsd_pcZukavjdf[Qi`Vvmqeƒqf€qe„wj…vjƒsf‚sgth]pdZzoard~pdxlceXTcXW[PSbVWfZZi][d[W]WQkbbqffqcetcdtfgpcdkefjdclddngfogcndah_\i`^jecjddpffmddkfbledjbcibbf^_lacd^Za[U_YR]UNla_h\\)5*,B50O>:\G8_G8_G3WB.S>-Q<,O:,P;1U>5]D3ZA-S<(L6'F4+J8'F3%@/"9(+?/-G40S>0Y@4\B4^E9gOhMAiO>kP=dM@iSgM=gM?iP?eO=dL>eL;bI;dJ;hM@mR@kR=iO=gNgP@fP@fQ>cP4[H6^H:bL:bJ8aK1ZG.TB.R?/P>0TA/P?0N<.M9/Q=0V@7]H:dN:gP:fN2WB/N;/H9.H70M:2V>3\D1_H6cM9eM7dI7bI*O;.Q=.Q=-T;/U>/T@.Q=4T>:W?5XF4ZE1YC3[F2WC1VB.V@0YC/ZE/[E.ZD,ZD/YD0VB2XC6^J6cN2bL1`J4aK1_J3cN2_J5[F8WG2WF+VD+[H/cP3jV3iY4kX4iR2P=,Q=5ZF;iT8fP+ZE&S@'P>(N=%Q?)VC-ZF*XB*WE$SA#L8%G5#A2%H8'M:-S>-V=)S?!F6:,#<,#>*%@1&C3(H9*M=)P='P9,O?-S?*T>+P<&H4)G7.O=+L<.N?*J:*K8*K70O>2N=2M=-J:3SB3TC/MA*I:.M:(H5)L8.Q>,P:*J5+I6/K8/M;1O>2RA5WF3VE1VE2ZG-WE2[H3bK/^H+W@+VB(WC+T@'T@+SA,O>*M=,SB*VG/YG0VB+O<+S?,UC-N=,N=)N<)O<+SA1ZH,TD.SB0WC/[E/[F3ZG2XC4[G0YG2\J5]L1WG-M?(J<&L='O>*TC,UC0VF1RB/RA.VE2^K5aL8`M3\J2ZK1WG0TD1TC4XG5ZI6]K6\K4XH3WF5VE2RB3QB2RB7VF7WE9VG6TE7YH6ZH4YG5[H3UA0Q@0O>7SC8UB3O;1VB2YF0VF+SB)SA*U?.\I3[I.Q@0M=/L<)H8.E7/I9.I9*C1*A.*A..G41I7.E52I:6N>/F6'@3*C5,G8-H91J:+B3*?0*<.(:+,B1'<+2B05E83I:2J:1D52D3.C23N<;VDRB5K:.F68UD:SB=O?=M=:N>5N=3L;7OB6O@:QC@XEAZH@ZF,.B1+G3.P9-T;-R9/T?5^H:bL1aF.]D8`EiN=nR?nSAnT@jQ@iQAhR?gNCkVAjW9bP7dM2aI7^H9_L4[H1WD3WB9\F3[E2YB5XC2T?2WA2YD=`I>gO:hP5^J.S?,J80E91J91N:2V>4]E/]F1[F6bL5`G3\C/K8.O>1Q>0O>3XB1YC/[B1YF0YG1\G0[F2[D3ZD1ZG0WE)O=*N<0Q@/R@.T=-U>.T?0T>8V@?[D;]I3WB0UA/U@2WC4WD/WB2\F3]H2\G-XC(S>*Q=,R=4WE5[I9cR.^L/]G3aL0`K1fO2aL8`K<\N2WF*UD,[I1dS4kX6o^5pZ6lV=oY=o_:qb3lZ5jZ0bR4aO0^L/\K.XF+YE)YC'T>(O>/QB1TA5TA5S?2TA0WC7aM8kV9gS.YG,TB(R>$O;$N9$R<)W@#R<&U@%S@&N;*J:)E8(H:'M<,S>+V=&Q<"E5">.#:)$?*"=.(C3'B4'F7*K9)L6)K8*P;&O8'L8%B3+C6,L:0O?,J<(G8(H6-L8-N=/P?3RB0P?/P?-SA/OA+I<*J9)I6&K6*P<*M8+J7+I71N;3R=5V@2TC4WF2WF2XF/WE,VE4]G/]F-ZC0XA)Q=(SA-TD)TC*TB/SA1VE*XD)VF/YG3XD+P<1WD.YG2P?/P>-O>,Q?.UC1ZH1TF1SC2VB1XD1XF2UF4XD0VC-TB0YG3YH1VF2RA-P>+R<+T>*VA/YC-UE1UE3XG2\J5dP5dO2N?+K:0E7.H9-H8-D2.B0*?,1H33L85L=:QB6M<,C0*@2-F8+F80J<0K:,D5.E7/C31G5*C1(A-2E35H;.J:.J;1I:/H7/J73Q>7Q?0H62G5.D20F45I81C2,:(/;+1<-,8,-8.1?25G5=O?7J9.B53B6/A29J97C.-<'2F24T@9UAAWE6N<5R?6XE;UC@TB@P?;N=7L:7J9?PC;M@?SD@UDBUCEXDBWFEUDDTCCUDKaOUhW^gQagS[aPY_NZaP^fVZgRXgSZgW^eVadTdhY]`O]eTfk[icVebTYbSjfXbeWml^ypatj\ggXul^ro`ztf‰wlˆtiƒth|pcqi\lgZgdVom_rrc~rf„vi‚wivrbtsaxvcnj[d\Oymare}p^|r^soapi\skZrgWrgXqfYrmcƒti†sevgxqdkZT~vm†wp‰wq‡xo‡wnŒxnsguh]ypcrf[zma†vk€yj€xjƒxn…xn…wl‚ui…viqdW{pd†~q„{n…|n„yp‰u€wntmcnh`d_Ve\XngakbXj`Vif[bi\sn`wnb~pdƒsgƒui}od{na~mdxiacYOqi[}rasg…xiƒvh‚wgzravq^}qfbYOrnb|vlvlvl„sg€ti{tiyrgwnetg`le]vme}si€wlyoeqh^pk`md[n^XcOJm[SgZNg^TlbXoe[iaTlbV}sf~jcng~rh€wjƒzl|rd†nheWOc]Trj_wlczpd~rd~of|ngtiypbsk\YPFmh]wm~qe„uh€tiwi€shsfznbndWogYpg^of]ld[g^Xd\Xkaamc_pdcpcdl`a_UV\WWh``laal^_pccg__da`b\]g]^i[[m^_l^\k^\f\Xkd`lebib_pfgsghiaae[\lacodftiipdcnaaf\ZXRLngcpdfo`g*;*-B01M97WB6\H.O:)E0,E3(D2!?0&A**D-2M93M:-I5&D0&?/)A.(A0*D2(D/*F2,E0+K6,N:1M66U=3[A9`G4YD7\F4[E6\H8`J:`HeO;aK6ZD1P9/J4.J12M9,K9+K<1R>4V?1T?:^H8aJ4]F8bL5_H1UB)L9(I5)G4)D2-E3/F6.I8-K6,M8.L;0M=+K:)H7.K;4QA3O?1M=/QC2RC5SA4UB3YE2[F.YG0YG2ZE5YE4ZD4ZD1ZE0WB.S?,P:,S=.U?3U?1U=0V=.U;9]C;[C3YC1VB1VB0TC/UD1VE4YI6[J3YG,U@-VA)Q;,L8-N=2VD9^N9^L9]K1WG.XG-ZI4cP5cQ4dN8eP2_J,WB0_J6lV:s]>xa=r[8nUxa>q^4iV3dR1_M/[J2^M-YH/VF-TD-VE+SA(P>,TA,UD.UC0VF3XH2[J0ZJ8gV1]M,VE&Q@&P?!N<"L8)Q<'L8(M9&O:&Q:*N:*M:)K8*L;-O=.O?'N<+N='D4&B.#=+ ;)&>0'@2%@1&D4+L;*L;+J:*L9(M9%H4&B3'?3/K<-L=*J9$D4,I6/J8(O:-R>0T@0P?0N>5QB1PA,K<(H7(H8)I5+K7-O5,N8*O9,RA.UB-VA/PB4UE5WF1UD.S@.XB+XF)WD%R?'P?#M;"K;*R@+TB*VC*WD-WE+TB1VG-XG,WF-RB/TD-UF2Q@3RA4VE2WF3[G4[G1TC0SB2WC3WF4WG1RD3TD.P@,M?,P@)P>-WA.WE.WE.WE/WD/XF,UD.RA2WE6^I3_M6eR5fU;jX>kZ:eS5[I3YG3YG1YG4\I9aO:bO8aN8bO6YK8\L0TD8\KBgV?gR?_L:[I6WH7YI6ZI8]I3ZE4ZE5[F5[J7VE7L>1M80L;0O=,Q;-T@3WI1]L0ZG0XC/T?/P<.K;,G7/J8-H5-D20B27E75L:8PA8RB4K=/B5-<0.D14K:4K=,E7*C5/H:+J9+H6)B0.D3-E3.G67L:2I7.L83Q>0O<-K8/J;2I:0@/1<-/B0,I46I8-@/*7'2?0/>.1B19F43K77T=AT?=L:9K90F6;K;?J9:D36C2:K::O>>QBBVH;UF>ZIBZH?YGAYD@UABS@>N?P@?P?ETBDR@?P>FXGIXGRZJLVBL[GL^KVcS]iPdkW_eUYbS_dTfgTYaLbhTikZaaRgfXli^bdWffWol[un\qk[mm_gg[ke[zof}qfkcWmg\tn[yo]€ufƒwiƒsg‡ti~rfvm`geWbaSmk\tmawq`|tfxqcpm_to_shXj^TobWoc…qf‚nb‚m_qe\kcVwm_~pb‚qd|pdqdˆwl‰vn‡ri}jco]U…xj‡zm…wmŠypŒ|p‹ym…uh‚re„ugm`Rxm_zkxm€wi€wlwntlteodm[Pyi]yj^|nbvl`kdV`[NeZPpaWm]SncXxn`zqdzqeuoapi_ke[ƒyl†ymˆxm‹|pvjwpbtndyodrj[e_Qpi\|pe€uk€vh€xj~uk{qh~tfsjl`Vwlcug~thrf}rhzrivmevibtg^cZOi`Qrg\f[SaUN`TLbWN\TGXNAdVK|oa~pbrcylbykbzkbocVxpb|wg~rf{oezndsjzog}sjsldYQe]Tplctneyqj|pe{re~tjqh€pfnbZWPBrl_|vi‚yovmxoewhcuiare\h_TkbTiaSi`Wh]Tj`UcWO]VP_[Xf_Zd[WbYUaXTZRO`XUj`]j`^i\Zm`^m^\fVUf]Yj`]k^`m^_p`bj\Zh][jb_lhdokipkgoieka]e\Zh`amdgnadoaclb\f]Xd]Xnfdrghrff+9*+<--C23L91O>-G4'>+%:(&<+$;-&<&(?+0H45O;2M8*E3+B0&?-%@.,H4/L7*H3-G4/O;2V@7U?4U<2X?3YA2WA6]G:`J7^I8^I5]B5\B5\C4ZB3V>;]C?eM?fM=dM0P<8ZBDgMCjQBkQDqTEpUGqVKt[GsZEs\Ds[AqZ9jR3aM6[J6XH6ZI;`M;aL:aK9_L:bP8aO1[F2ZE1W@4YA3V=3TB6YD5XC4U?3P<2N72P90M:(F6$@1'B2.G5/L87WA8]G8_I7_I0XA*M8(H4)F3(D1*C3.F5-J:.M;.P;-P;.P=-L;3M=-I9,I94QA2Q@0P@/PB1RB5TA7WD3XD/XC0ZD/XB4ZE2VB3WB3YD3YD1VA.S?/V@/U?/XA1T@2VA.U=3V@8[D:ZB8YH4WE1VB1UC2XE2ZG3ZF2XE1VD-Q@-Q=)M:,K6,M;3WF9^N5]J3ZH3XH-TD,VD/\I8fS8gP8eS2^K.ZH4bO6jV9r];s^7kV,VD-XF+VC+SA/TB0WF-WF*TC-RA-RA0WF6YE7YE4WE/UC0XF0XG0WE.VD1YD2WF3UD6SF0P@-L=.K>$C5(I80TB2WF2\J1^K3`M1]J,UB,TB4\H6aL0]J2fR4lZ1H9.D6(:-->00L79TA5O@+D6-E:5M@0J:*@1%9)'9+*?00G95H:2H95M>5O@2L<.F6-@2,A2/?1.:,0?0/D51F4)<+0B15H66J8P>;S>:S<;L7:K9;O?>SDAQ@BL;EN=>L:?P>=N=@N?DUHAXJI`PDWEB\J@WF@TAEXEBSD>OBBQAFTCLWEKVDBQ@HZJOZIY_M[_LT^KV`OafXhmVhiV]^P_bWlm_liYihWqn_rn`pj]pk`qk`ke[jeXvm`}oaynapj]a`Usmc}rhqipf\jcXsp^{razoaypb}sgrf~qevmakeWe^QpfZwj]yo_qgYpfYoj\yrd‚vdqd…uhŠxl†sg‡sf„pcve]sg]vg„sg†uh‚th†ymˆzq†ulˆvn}kcuf^ylƒzn„zp†|q‡|o…zk‡xm‡xk‚qeiWLvi]}pcpg|obxmcqh_vkc{o`tcVyi\~naqc„vhsdkdXd_S€ukocnbxk_yna}sg|rexpcpg^nh]ƒxo…yo…um„ulwmvodsncypcrk\icUlfZ}rh~ulwj}wgzqgvjavk]uh^gZPnaVvi]vi]vi\rh^e^Rh`VmbYocYh_SoiZmeYvkbzlcjZP[J@f^Rsh[}ocsgsd}qcpe€rh}ndl_R{qe~ui}qf{pf}qgzqgyog|sj}nh_SKkbYumdzrixpf{odvlcxnd~neziai]Rc[Nri\xnaukaodZ]QGi]Twkbyndsish|ndxlczmevj`eZS]VP\YUeYUhZViZYhYWdWVi_\mdaneapfcqfdmb_i\Zj^[j]\l^_o`aq`aj[[f[Ylc`keblebicag^\aZX`ZZf`aiabmeemcalc^`[Vga^qkhqiivkk'1%*7)+:+/?1*=/(:)&6$)7%'7''7*&:')=**@-1H60H6.F4-G5*E3(D0.L72S=-M9+J50R<4XB8WC5V@3YC6X@5XB5YC>aL<_K5[F8\D6]F5\F5[E5XA<\D@bJ=`H?dM@eO=`L4UC2P@3Q>6X@=bHEnSEpU@pSDrWHtZJv]Iv]Kw`Cx`@t],R>/U?4XB6XA5R@2P=0N:1M96R>:UA4VA-K:%?1%=/*>00B30F43M:3T@:]H7]G,S>(H1*F2'C0)C3,E6.E8,L;,K:/N>1Q@/N=.K;2J<4L>6QC6TE3UF/SC2SD3TC2R?6XC2XD.WB0YB0WA1T@4WD4WF.RA4WC3VB0UA0V@-V?,V?/T@.S?,S>6YE6XD9XE8XG6WG2UB1VB5\F2[F4ZD3WC.Q=.N=/O?.M=-M9.O=3WF6[K5]K5^L7ZJ0VE.VD4_L7dQ6dP5cP4aN3`M7fS6jU:o[:m[6fT?n]:p]8m[6fU/\L-XH.VF/WE.XE+VB-PA,QA'K;%K8'M;+R?1XE,R@*O?6`J9aM6bL8`O8_M6\J.RA$I7$H7%F5(I8%G6'K:*M<$I8'N9.U@0UA+O>(L;#G6$F5%E4(D5+I5,G4-I6$L:$L7%L7(M9)O8,P:+O9)M6'J6'F5(B3+B6-I9*K:)L;+N=)M<)L;+R<2XD1UD.RA/Q@/QA2P;0P<1Q>(J9%H7+N>5ZD2VD2QB)H:%D5'F7*K<8VF6TC-M<*O<*R=)P?(O=&O=&M;%N9)Q=+T@,WE,SD+P?-R@0S@1UE,UC.VD,P?.RA0VE5[E6\G.U@*Q?.VE0YH-[H,ZH0ZE3XF5UE6QD-L>-I<2L?.H:+H9/P?4XF6`N1bN-_K.[H0UD/WD6[H6ZF0ZE3dR2mY8hU6cQ7_M5\J5ZF6[F6`K9dO4_J9bM9]I9]H=XG=]J8\H8`L8aL7`K;`P7\L9^N8YJ-N?2QB5XG6VE4RC/M>1J<2C61G8/F9+G60P;2U?-QA6OB7PB9SA7S@4O>5PA4M:2M97S=6S<7Q=9P=7L>5J;2H9,A2/A32D84S:<[D3N=/H:/G5H9/B3*;./;.0A30C61@3,7,1=20F4/E33J87N<XF>VB=S@>P;:K8:O<@WHH[KGVFLUDS[JKVDCP@BRBDPCFUHJ]PI^OJZIE[L@VCG[HK]KDWFCTFITDQZJV]LSYHIUDN]MV_MbcQigUcdTccVnmbro^oi[\TJomarnbphZuj^yobzndukavmctiambZh_Uwla€oc|obphZkgZzre€sgshnbVg_Qrj\ui[qdVkbVqi\rh\{n`xm_uk\wk]‚qe…sfqapcqfYrj]|se…uhŠvhŠxjŠyl‰xk…tg…qf~leykaugˆxj‰ylƒxk„yo‡zp‡vn…ulqgrcZ~uj‚wm‚ymui}tgzrbvi_scZwd\q^U€nendme€pbm`Vtg_qj‚xhŠyl†xj‡{m‰xl†vh„sf`YOkeZ„{m‡xj…uf}o`}ncƒui€th€uhneYgaU‚xovl„vlƒwmwmwsgpnctnaleVb]PkfZqi`md[mgYieUh]Uqf\wk^wh_xi_{m`}ocrf{n`odVldYqg]uf]xh_shZofXvl_yl`zl`oaVo`Tynd|oe}od€rf€th{qc€rf~pcyl^oaU{pf}sj~rh{rh~uj€wnzqgri`fTN\LEfZRqg]pg\iaTk^Th^Tvmc|lc{k_yma}qe|pdqe{mdte\i[S{pc~sg~og€qh‚ohoh{lezkcpf\d[S]XRc`\l_[na]pb`i\ZcXUf]Zmaaoabmbaqfeg\[^SSgYVhXVhXYl\]k]^fXYg\Zja^kb_jc`ja^e\Y]WXb\]idclgfqjgpifhb^_YWifanjisnmslk&0$'4&&4&,9*(7*'5&'5#'3"%2"(6&':'&9&&:')?-+B0+D3/K8/L8*I4+L87XB1U='J4-N94T?1U?0T>0R>2S;2S>1R=2R>2S@3UA5WE8]L;cQ5\I3VA>[G=`HgL>kP=kR=lREtZHx]Es[LybFzdBv`=lX6_N3VG6UG1UC4YH5[I5[I1XF,TB*P>&I8&K7.P<6XC6XB7SA3O<1K9.I55P<=YE6[G4RA(D4)=0,>0/?12G52K83Q=9[F:_G.T;,I3&C/*D1+F5,F7,E70J:0J:0K:3K<3M=3M=6O?6QA8TD8XG4UD5WF5UD1P>3T?5ZD1WB0WC/V@1U@.Q=4TA3UD.RA1R>5VC3XD1WA0WA.U?.S?.T@1T@6ZE6YE4XD7WF6XE4VB/T@2XB3YC4XC2UA0P>1Q@0O?2O@-S>5YG8^L7\L5^K5^L5^H0YD0YC4_M6aO6cP5cP6dQ3aN5dP5hS8kW6gV2_N5bQ8kY:m[8iU/\K+VE*R@)R@)Q>(Q<,M>-L=%F7%I8&J9-Q@,P?*P=0WA3\G8bJ9cKdR;_N/SB)J9'G6*G7)K:'K:+O>)L;(I9'M92XC1VB(L;&G6&G6(G6)I8*J9+L8-L:.M9#P<#P:&N9'L7*L7,L7,P8+O9+L8)E6(C3-E5.M=+L;,O>+Q?,O>'J9+N>2VF.RA+N=/Q>/S>4T?2T>2Q?,O;.O>1UC5]F6ZG2P@.I:%C4)H9+L=4RB0K;.K;+N<*P<*M<,P>*R@)T>*S>-T?,XC1ZH-TC-QB0TC0UA-Q@,SA.TB/RA0RB0VD5\G2XD.U@1WE5[I4YI)WD(UB)T@-SA0P@6QD1NA0L>2L>/K<.M>2SD8\K2]K0aN*[G,WD-Q@3UD7ZF7XD2VC7dQ3gU7eQ9dS:`O8]I7\H8^I7cM7bM3^I:cN=bM<\H@ZH?^K>eO7aK4\G7]I9\L9]L<^M7XG1PA5TE5WF6RB5P@3P@2L<5H93K<2J<0J92O:1O90M=7N@8P<2F9.B52E50C4-@13F66T<7Q>2I:1G:5K=6N@1C4*8+'1&-6,.=00C4/B38I;42G63J88P>=WEA[I?YG=UC?R?BP?>O=?SBK`QP^PS]M_dTlq`Q[JFSBBTCHWGJ[MNbRNaQO_NHYKGYIK_LK]KL\JO\OP\L^cSfgW]^NUYJS\MZaPlhXqjYlgUifWtpdzrdwk_h[Qtl`sncph[|nb~pd|pe~rgymczmcpe[i`Vtj_}mdymavna|uhypc{nbxh\qdXmaUteW~k^}j_~nbl`TseYtftf…xj†uiŠxkŒwk…vf„tgobUsj`~tg†ui‰vj‰wl†wk„vi…uhˆwkzlcsi^~tgƒwj…xl}uhtksjne~mdq`WiZQsd[€pe|l`yj\mbTofYsf\qg†tkˆumˆvm‰vmŠvn…uifXNyleƒun‚xh†ykˆ|n‡|n†yk†vj†sfXOHrkaƒ{m‡zl†xi}tg~th‚wl‚th†znh_Rh`S€vl€ujƒuktivodnk`kj[nfXi`QmeXoi]ukbwmcoeYc^Mukb}qh~sf}oc}ocƒuiƒuite|pbxg[qeZzlb|h`|h_vgYwh\wg[~na{nbd\OjfXtj}ofpg‚thsg|re‚sg~qdtgYmcUth^yjcxj`th^of\e]Pf]PlbV{h`{kbwk`{ndzocrfZ`RJndZypfpdoc{oc}rf‚wk€sfqhxjan`V}reuh€rirh€ng‚oh}leymdsj`ZSK`\Ue`^lfakb^ja^d[X^XUb^[o]_n]^eUWZLMeXXj^^pb_qb`ufcvifoabk]]lb`ofcrhepgdofch`\ZUVd^_lgfohdpigmfcg`^_\Xgcbhdcjfejcc$1""2#"3#%7%'5)&7''7&'7$%5$&6&';(&9('=+)@.*B0(A0-K76VA2S?(L43Y@3ZA.R*N:/L:-L50L80O:2Q=4SA6UC8ZH8^L7`N2[F1V?;ZB;_G9_G8bJ:fO:eO:aO<_L;]I;]F;`F:bI;eK6XB9SC3M;2L:4O=5Q>;[E:_J0P;-G6+A0/D42F7/F51K81O;8YD9\D2U=/K8)F2)E2+H5/K:/L:3L<4K<4I=5J>4M>5P@4Q@7UD7TC8VE8VD7UC5TB2S?2WA2WA/T?.RA/T>/Q=-M:0P=1R>,R;2Q?5WC2WC1WA/U?-S<-U>/U@4XC6YF6YE4YE5ZE7[F4WC1U?/U@0T?4SB6UC2RA2SB0S@3VC0[E4]J7]K2WG1XF1ZH2`J/\F/ZE4]G3]K6aO9iR8iQ5eM2eM3dM9iR9gS3]L1]L6hU6kV>nW3gQ,]G+VC+SA,RA&M<(G8(F7$C4"E3'K:+O>,O>*O;-V@7aJ;dK8`H7^J;aM-N=*H7(G6)F6)I8)L<,Q;,Q<,P<&Q@)P?%J7%F4'E3+G4,N9.M:,K9-J:,K6.L70O<.O>*N=,N=*L;,K=1P?2Q@*K:+L:/Q>/R>1WA4XD3WB/Q>,O:3VA7\D6XB.K9,F8(E5+L9.N@0L<2J;,G7)J8)O:-O>.RB/ZE+WC.YB-W@+XA1ZG1WG.TD-TB-V?0TA+R?.UA2TB1R@2WD4YH1WF.SB2WD6XF2VC&M<)P?,T?+P?.P?1NA1M?5RA3R@4TA2VC4[I4]K3`M1^K+UB-RA3TC8XE6WC6[E7_J9cO1[K0_K3^K5]H6[H8\G7\G8bK7bK5aJ=fO;`J?]H@ZHA`N?fS8cO4YH7WG8VG7VD=\H=\I7VD9WG3TC3N=3N=4R>7T@8R?6O>4N@4N=:S@6P=4J=ZF>VC?YD>ZC=WA?UA9M;1E72D75F82C51D54I97P<7K97H99I;;N>7M;4G6/?10:/3>34B41B15I62XA,P;-J5.I6+M9+M:.H84Q;4P<5R>4S>;YF=\H:]E4\D5`G2^D5\@>_A<_G8_E7^H:aK7]I6ZH5[E9^G=aI>dL:bI:`I;eO=iR=nW@s[)M<(I;%F5$D4'H30Q=4U@7RC2M<7R?:UB8WC9ZE8]G5S?3N:.F3-E43L:4L=2M;2Q<1S=5V@2T:1L;.I8-K8/N;-M:.M:1L<4N>3K>3L?3PA1RA4YC7ZD9YD:WC;WC;UA2R?2T@4YC3XC1VA+O>*K:*K9)G5,J8-P:/S3WC4[F4ZD3XB2T?1[B5]C7[E8\F4YE3XD4[C6]E3WA2V@4TA1Q>5RB5SC3SC3VB2WC0XB0`I2_K5\J1WF/TC.VC-`H,]F*XB0[E3\I6aN9jS5gO5gN5fN3cK8iQ;gR8`O7aP6fQ:mV>oV0hO.aJ+YC.UC.SC(M>,G8)F7'F7&G6-N>+N<)K:+P<.XA5_H8bH6]D0WC-M:-J:/K,T='M='J;#D5#B1'C3)C2-K7.L:-I9.M9.O:/R9,N:.R=+N<)K:+I:/L=2M>1M=/M<.N:1R?4WC1VE0VC1VB/R=,L72S;4Y@0O9.I60J:.L:+N:+L=+G70H9-G8*J9*Q;0PB3WF.ZE)XB$S<+Y@(V?/XE1WH0WH,WD*XA2WC/VA0VA2S?5TA4WE5YJ1WF3WF4WC3VA2T?(J9*M<0VB0UD-O?,L>0N?1Q@5WC5[E5^I0]G/\J1^K4\I1VC1SA8WG9]H6]G2`H1_H4aL4[H.[I0[H1YC2WC5XC3WA4ZD7`I:fOYH8TA?[FBbK8WC8VE3Q>4M;1L95R>7XB6S=5S?5P@:SC>VB>RB=NDLYHM]IL^GH\EKbJG]FC[IBZGB]E@YC@TB;M=4G:6F:6H:4E7.A25K:=O=;I9?JQ?;Q<5O92G73B56C73C32E1:M9@O=>J8>I85C10>+3@33E62D35B3@L;BQ?BUDDXFBXFEXGHYHK[JR^NS\LN\KI`NK^O[cWjh]mi\jfWebSaeTZdU[cNinZagT_iUgnZlnZU^SS^OVdR\iW[fTbjZ]hXgm]sn_phYd]Oa_RdfZpj^ul^mjWfhVora{rf}natfYgaRlj[nk\vn`qj[ldVkbUreWvfYyeYwfY|ma€mam_ugWk_Svi]€pd„sh„rg„rf‡xmyn‰uk€thfaTspa…yk„yi†yj…xh…xi†yi…ufqdwjatkaypfof}lhuhaqg_vlbzm`zi\xe_yjb~ncˆrg„mdxc[tc\…rk‰vnyq†uj†tj‡{mˆwi„td~narg]}un†}nˆ}o‡{m‡{mˆ{m‡{nŠzq‰}oe[Qxlfƒtm‚ugpg}rizrh{titi`cUKWLFicYoi\ldXjd[ca\jk^wqg~tg|nb~sf€wi†xj‡wjŠymzm_h`Rnk\urcwi†xj|odzpg|nhmfwh[`UGwlc~sj}tg|pdxl`}se€tg~sf{qaZTIlh^ke]qf_of\f`Veb[pkboeYcWKdXMj`Wph^oe\tf\paWl\PseZyf`yi_vk^yo_€rd~kc|h_ue[f]Pzpcvg‚qdƒtd„vf‚vh|sfukash`i[Sujb{pg~nb~oc|qc{uhztgxqdkbXSK@f]SnbXuh^m`WkaWj`VneZld[mi_bdWccYmibrifjfaic^g[Y[OMgZXtgemghqjjpijqjkrlmsmmqihrkgukhvkgpccj]^icald`nc`pcaqdcj`^d^Zlebqfbshesggtkmtjjoggnihqkjrkkrhh"-(6)(;,$:,(9+)9+&6((8(*9'-=).E23N:/L9,J63M:2I:2L:6UA5XA-T<,P;1U@.S;+L4,J2,H3+K5.O93W>7WAaK8^G7_F9aF=eI=dG?`K9`J4[E7\F9^H2]F7ZA4ZB8`G8cJ9eJ:dI2RA5SA7V@=`F<_E=aH8^E7VB5O<6N<5O<3P<2N:1L90N;3O?5RA5P@2O?/L;3O;4P<5P?3M>3PA6QB4O>4O@4SA3UA6VB7WD9WD:XE-V@+VC*VB,ZD-[E4bL8fO9hP2eL0cM5bL8cO:gT0WA0WB3XD0YF;iS;jS2\E,R>+Q?,N?-SB,U@+SA+L<,H<*N?1P@0K;/K:-L8-R<,P;,N<)M<*O?,R@'O<&J5'F5'@2$>0#:+$=-*E60L<.N=/Q@/SA.SB1Q>2R?0P>-M<+M=,M>1QB-M>'K:-P?0TC0TC-SC/U@0Q=-J<.J;3Q?/RA0K=/I;/N<+P:+O>-M;,H80J:-J6'J6&Q<,R@.UC-UC'P>"J8)Q?&T=/XD4XH4WG2[G,YC3WE0VE0VD0Q@5VE6[J4YI3YI2YI*R@/Q@0O;/L<.Q?0XG0]I-UC+N=+L?.P@4VB5]D5^H0]J0^G4^I6^F3ZA7[E;_I>_L9]I:aL5_I5aJ4`I0YD.WC1VE5VE7WE7VC6ZD:aK:eN:eN=aKC`LG\HGbOAcR@eUAeU?_N@]M6SBYG:VCTDAUGSE>TDCWFFXFKYJS_LWgRUgTNcMOdOH_IL]KFXGG[JDYH@UF:O@7I:8N=6L;3D31>28H<@PA@Q??R=@R?ATBBSC=QA:L;:L::J:5G67J9>O>AQ@DO?FK:GJ:?H7LZGR^MV_RbeY\YMW]LMaJVcPjgXtl\l`SfZNkgZlm\gjVsn_wteeeVhk\nqanoaY_PYbR_iX]fRejWoq\ei]ll^uobxj`g[R\XPdfXnk[rm]lhYkgZri`yi^yi]raUoaUqeYrj]wg^sf]^RGmaUui\zk]{ma}lbneqh‚qe|n^pcVsi[ƒvjˆuiˆri‡tk…xjŠ{m€sevqc[[Mnocujtiui{tg}se‚re}lcwh\rdXyl_}nc~me€mewg^se[~oe‚of…nfpg…tkˆvlˆuj‡sgi^se]†xmŒ|oŠ{nŠylŠxm†xl‰xl‰wioexh`€vo‡zo†|p…{n‚zpƒyo‚xn…yosjgYRvi`zncuk]vh[qfYuj_tcZwcWyh\pe‚ui~tg‚sh~pelcWpmc€{o‚vn†xkƒuiƒwk†ykŠxn‰vp}mgqh]qn_wre‚xjtf{sdyqf}rj|mgrg`_UNypg}tk}qgsizukvqg|qhxg`cQJSJA^TLdZQbVNZOFMD:]\QidZvnbyk_{l^€pa|oczm]}n\rcTsdY}nh‚qi~of~pd}pd~oc}ma{n`k^Pi\Ntf‚ug€tf€uhuh~vj}rivlcod\c[Ptka{nd|hayg_vl`qiZqaXQ=9K95]OGhWNm_Rq`UscVj_Vvkaph}ukvpfebYhe^ohdrfbkcbnb`g\XcXTi``mggmednfepgemdbiaba]^j\]m^`obama_l`^sgcshisggyklxhkvginadndfrhjohhtijuijxljrhjtijriiriesjepgc$1"(7()<.)?0*>,)<+'9*(;),>+/A,0I4:VA;\F1T?0M:/M94Q=,K7*M5'I2+K6.M:,P9,N5/L5-K3.O60S=4Y@?`I@_I@_I:^GdL>gP8dM9fO:gP6cL3_H/UA,N>+K<0N>2R?1S?3VA;^J9\G7[F4XC0S>.J<*E6+F6-H8+J9/O=3TE8ZG6ZD7\E6S@5U?6VA9XDmVjT;hR4[F.R>.TB0TB1WC-VB+S>.P?1N@-P@0Q@3O>2O<.P;+Q;.V?-R?+P>,P@+O=(L:%H4#B0&?1'@2%;-#=-'B2-H8+I94UD2UD.TC.R=0U@1UA.Q>0O=/O=+M>-M>0Q@/Q@2RA2R@-P@1T?.M:0L>0N>1R>0SA1M?1J<,N;-T=0UE1Q@.J:0I:+I5(K8*S>*R@+SA,TA&L:%J8*O>+V@.YF1[J2[J1\H.YD5WG2YF0UD0Q@6UE4WF7\L3[J3^L1XF1SB4R>0L<.RA4\J0^J/YG-SB(K>,P@6ZF5[F3\F1\I4]J2\G5\C6\C9_GeNEgRGcOKbOI\FMdRKhWKj[JgWHaRF[L@WH>TE;SB;TB=VD=YEAYDEYEHZFHXHHWHHXKCVG?UCDZGL^LTbQXfT\kZViVSfSObON^LU^MU`PP^NL\KEVE=M>@I?M=6C6;K?DTBGWEGYDFZFHZHEWHDWE@Q@>N=9L;8J98N;=O>BSBKUESWFTVFKSBCN>CN>>L:?P=H[IK_IIYGIVCP[FU^KW^M\aTefXmi[ccUR_N_gWxqd~uhvj^meYnl^po_up^{xiqqaceTml_qqcll^chYbhYdkYeiYpr^pr^gl]ik\sn`wj]fXNe]TgdVnfYqhYjeUd_Soe[yj^zj^wg[{l`xl`vm`}kcse\_SGrfZyl_oc~nb€pepg„sj…uio`pbVpeZ~ti„si„riƒtl~vh€uh|qdmhZ^^Okj\|qgphzl`ofYuj^€od~mcnc€rd„vh„sh‚of‚oeyk]sg[ƒvi„th‰ui†tkˆwn‰xmˆvkŠwm|j^l_W‡}rŠ~pŠ~qŠzn‡xl„ymˆzm‡vjƒrfwg_ylfshwjyqdrkaulbzpf}pgxjavh`xkb{od|pdqblbVsi^ƒri…ri‚re†ui…xl…ym†xl…wklcVvod…yo‹yq‹yoŠym†wj…|kŠ}pˆxp~pgmeWro_wsg€wj}ugqn_mi^oe]qd]`SMXMEnb[vjaqdZlaXf_UidYpe[xg]teZwi^xi^ue[wg^obYYNFj\Svh_‚sg€rgsetfrf|o`|o^qdTk`U{ogsi}qgyof|qf}re{maxmcndYlaW€ukuj‚wlvk}th~sixmcqg\h]QYPEph]se\xd\n^UaUL`\LpbWzg`{ic}me}nb|oc‚rewg\f^Swm€vl|sgrk`d`Wgc\mdaoa`k``k`^h]Yf[Wi_^oeemefja]h_\bYVaYZjceviisffsgexkiwljyokwmnvkkxjkxhjsegj^`nefnhhmginghpggpfclbaofdofdmdbnecpfe,9)*:)*>-+@/+E-,F/)A-+A.-D/1I15U<9\C8\D0U<)L51R:1L9(E1$B-&B.+G3,H4)I4*G3-J3/M63U=4ZA8`F?dLBfNCfL@gM>hM:aG8aF8aH6VC8]H5\F1U@0T?8ZD;\I.J;/J:0K;+J7.N;5WG3XE6^I:cL>fQ_K5UA8TA1M92N=4QA8RB5O>5O=4N<4P=5R?5TC6RB3N?1M:3N;5P=6S=9X@;ZD6WB6YD7[D9ZJ:]H9]H5WC3R?1N=2T=5T=1O<,L9,P:0W@1YF5]J4\I3[I8^L2YF2TD2TC1SB3VB0S@1T@2Q<6XC8YD5YC5XC/T@2R?8XE6YE6YE4ZF2YD4\D2U>0P=4TA4UE-RB-S?+T=.XC0[D1^G1_H3aK6aK8^H7ZE7aJ8oV>oVBqW>lU>mW:lW4iU0ZE.\F-XG0VD1YG0^K0]H.S@,K;(L:)J:,I8/N?(G8+K:-N<)I80N=:_M;eP6cL1WB.R>/UC2WB2YC1YC*Q;1S@5UD/TA3TA/O<.P;-Q;-S>+W@*S@+Q?+O?+L;+J9%G3%C4)B4'@2*@2$>,+C2,G7/L<5TC1TC.RA/U@3XE1UA1Q>0O<.M9(G8+L;.L;/M<0L9/K80N>3Q=1P;0M>/O>2U?/TA/J>+H9,P<-U?0UC4SB+G7-G7.K7)K8*P;*Q?*O=-P?(I8'H7/O>.T@-WE+YF-_K.ZH.WB2SC/TB.RA.N=1O?3UD5[J6\K3]L5]J8\J5UD3TC3XG3\J4_M5aO/XF*N?(N=1WC6]G5]H3\J5[I1WB3XB4Y?9^H:`K:\K9]K^KBfQOt]LiTPeRQaON^IVhWThZShXK]MMZJO^PK\KBVEAVE?WE?XFD\HMbMTfQTbMT`NV`RXbRJYGFYGMaLSdP_lXdo^bo^WfUUcSWaRZbS^cR^dUWbQM[KDTCAP@MTEKYHDVEGVE>L<@QCO_IO_IO_JN^LJ\LHYMKZIDQAHWFfMCkRDlSClSDpUCnTAfL7^D9_F;^G;ZE7S@5R:6V@:ZE>XE9TA5T@7\H6[F4XA/P84T@8XE6^G9`J9_I9cL8bK7bK5`I2YC3VE6VE6XD5YE9]DcIfU>iT=gT3Q<6VD6VE3R?2P=4Q>7S?8U>7U>8WB5WB6[E5[E6[I:\G;\F:YD4S?3Q@4W?6WA3R=1P<0S/P<5UB3TC0QA/R?-S?/VA1\D0]F.]E1_H7bKCiS7ZE:dN;sZArVBrX?oW;jU8jW1dP2[F/ZE.ZD0UC1ZG1^K.]F/WB-Q<,N=-O=2N>/PA+K<+J;,L<1R@6VC:^L8bN2_H1XB/T@,R>0X?3ZE1XB/T@3VB7WD4WC1T@.Q=/T>-T>0V@(S<(Q>,R@-QA,M<-M<*L:(G6*C5)B4-C4*C2-G51K92M=0N>-M=.O?2VC5XD/Q>,L90N;,I4)F6*G7-I9+G4/J8.H50M=2P<0P:2OA3TB1WA1TA1O?0M>+Q;0WA0SB2P@+G7+F6-I6,M9)N9'L;)K:,I9,G7,G8,J9/N>(N=%T>+[E.YG+Q@/N=*M<,N=/K;2M=5UD3VB2YD2]H3^L7^L7]K;aO9_L2YG4ZH7^K,S@)N>)P?.WB5]H4]H4\J8]K3WD3WA5VA7\E<_JA_L>_K=`L:_J8[H9\I<\F;YD;XG;XG?\HEbMEcPMlYZwcRlYUhTVdOQ]J`kZcn^]fX[^PabR_hVWcQGXFHZHFZIGZIO`PZhValZahXchZdi^ehUXaMS_K\jVclXrvapuehn_]eUYbRceVkhZdfU]bRR\KKXHFWFEWFU`OPaPI]LJ[JM]KK_KVdNVbMVaOUaOJYHI\JMYILWGHYH@RA@Q@@SBKXHQ_NY`QbcR^_OV]LOYIQ[KXeSUbQN\JJZELWGXdP]fR\fRXaQ]fXon]zxfpn\fbStpc{rj}tjzpesm`qoaztg†ymsrbjk[jk[nn`srdqn`nh[lhZjgYjfYkeVogXhfXll]ql_wj^|k^wk\tj`ncnawk]ogYpg\xk^|oc{oc{nbzl`|nbocxj]o`UrdXxi^{k`€nc}ndylbzlc{m`ziZkWQi[Sqg]zmcwlaf_Tsh]€pd…qfƒre…uhŒyj…uk…shtfg]Qwmaˆym†uh‡vi‡xk‡xk‡wj…tg„rgoaVri\~uh„xl‡xl‚ul„vm…wl‡ym‚tiwh\lbWwl^€vh}qcylaqe[xk`~qeƒsj‡vm‡ulƒtj‰uj‚rgpdqbYnf„ri…tl†ul†viƒui„vj„vj€qekbVyph€rk†xm…ymˆzn‡|o„ym†vjwh\YOBtnaxl„yo‚wmvlwqfrhashbsgbi^WmcYvka}oc{mckbYc^UkcZyg`yja|md~of}nd}md}mdl`XVNDoh]zoc~qc{pb{o_|oaymawndicY_\Somauoexoeyoezmbxpc|l`}ocyl^^SGj`Tqi^sf[oe\lbYlbYlcWl`Rq`Xn\TraXtbYkYQtcYpf_rh`{oe}pd€qc€rd|qcypbxmc|kbl\UbUNmk\yoa}ld~pf|qh~rexmdwh_l`Vrk`{wj~vi~rh\RI[RNia_sgiufjtfhm__eZVe[Wk_\m`_oecqeaj_[`UQg]]ldenddoffngflebia_lhcrfgrhhrhhriirihshgugetfhuhlwikvigh[Vhb[oieskgoefocerdh-C/,F0,G0.J2/L82O;3Q>7WA8ZA9\?6]C:^E0P:(F.%>)&>)'@)(?,'<+'<*(@-(C,&B0+F22L81P96[B@iNCoTFrWErXDqYEr[Fr]ClR;cJ8^G8\F9YD8T@8YA6[B8ZD;YD8TA6WD5\G7]E;^D6Y?4W@6ZF6aI8bK:aK;dM6aJ6cL3aJ0[G6]K:_L6]F:aJ9bK;cK=eK=eL9_K5ZJ1TC0Q@5TA5S@2Q>8YE;_H:bK8eL:iRhV@iW:fP7dJ9_J7ZD:VB7S?5R?5UB7QA8SC6QB7UE5UA3T>6VC6WC4WC4WC:]G:ZE:XB9YD8YE4UA3VB3WD3YD6ZD;[B>_F9[E8[F6\C7ZE7UB4Q?2P;2Q:-U@/WA/T@+P<,Q=/Q=,P<3YE6^H3[F1VB2WB1RA4UC3TA5WC8ZF8ZE9WD4VB8\H5ZF4WC5WC5UA0Q=/O<5VC4VD0SA2R?0U?0V@3^G2_H0aF9dM7eNBlV7^F1V@5T@0R@.P>0O?/O>4XD8]H8]K6aL5bK3[E.T@(Q>.V>-T>-R?-Q>5WD4VB2U@2UB.R@-S@0WC/VB,S=+Q>-R@.RB+P>.RA.P?,K;,F8-F80G6,F30K83N;.J9/K;.H:.H;2O@5QB.J;-I9.J9/K9-G7*E3)E1+H5-K8.M9/P>3U?2U>5VF4WD/V?2UA3QB0P?+R<.W>/SA0M=)E5,G71M:.N;-N:)H8&B2*D4+C4*D4+H8-G8'H5"H4*S>.VB)O>.J:)J9*I80J:6P@3P@1P=/R>.WB3aK8eR4`N8dN:bM3XC2UB2UA*L8+O<,S@0XE3^J4^L5]K5ZJ5YF3T?7WB=\H<[HE_IE`JFcMDaNA^J@[G@]HD^KB]JD]KI`NPgSTiYZp^\p]ao]bmX^eQT^Mjp`pseihZpi[zo`sq\mn[[bNYcNZaOagUdfUmo\xvcwsawsbxtews_klZdhXhl\sr`{sazqcmhYeeUqn_wqb}qdto]hfV[^NS^LQ\KVbRXfSUgUSeU\hWckY^iT^hS`gS`fU\cRN\IM^JS_OVbRL\KGWFK[JLZISZJU]N`bThfWcdU\cR[`QW^O`iX]fUT^MT^JX`P`gUagTagT^fV]gXkm]nq_oo]uoayrfwqh|ukuh€teto^wrc|ugso`nm^jk[mm_ooaml^uk^wnbqj]pi\rh[ndWlaUpl_tlcxmb|nbyn`wlc†sj†qe~obogZibUtl_um`sk^tk^yl`yk_{i]vg[m_Sl]Qve]|ia{i^tdZj^Tth^|m`yiY{c]{ia~ndnc|nccYLtk]ƒsgˆui‡vi‡vj‰vj‡vj‡uj~pdi`Tulc‚uk†uh…wl„xmƒvlƒui‡vh‚qiqc[mcYwmd|ph}newoexnd}sfui„uirf€qe…vj†wi…vi‡xmhXOƒth‡xmˆxp‰xp‹{qˆylˆuj†ui‚sgue]‚qhˆvn‰vo‰yn‚ui‚vh‚xlwkrgph^wpf~rj‚tkui„vk|re}rf€ocudYg[Oqk]zrd~sh}sitlalh\pgayphtmtj‚uj„uj†thˆxmd[PYULpi]~mbxm`ug€qe}nb{mcxlbh^RXQEvnb{nbym`wn`ypdzqfumapj_b^Sa^Tkg\jeZkcYqg]lbXjaWug[qcXm^Sm^Sf[NkbWsbWp`XbSLl^V{maqandne€mcmcƒpgpfl`Xui`~rh~pc€rfqd€qg{qezoezjbfVN`TJpma{qf€qh|qf{qhymdtk`rcZdXNqj^wqcnfYh\TOD=`YUmgfohhpcfpbdj^_^UR^WRd[Wk_\h[YeZUfZWcWTk_^k``kedrkktolnifkgdqnhxmmullslkuokunkskhuiexjkuimshjpfcaXQb]Xg`]ja^h^^l``j]_(C,,H2.K3/M4-K;/P>/N;0T=;_D7]@/V=*N5*I0&?,';();)&;&&9'%7&';*(A.*G1,H4/J76Q=<[C=cIAkQHuYFtZEs\Et^HvcFsaEt]fL;eR;gO>iO>iO:bM:_O7ZJ2SA4R?/M;3R>8YD>aHfU6PA8SD8UF8WF5YD6ZB9XD9ZG6\G6]G;aK9_H9YG9YE6VC2UB2TC1TC.V=/S:5V<@aHAeL+N>)N>)O='O<,N=.M=0I<.F81H7,G3-K6.K9+F5-G8-F7/F:2J>3K?-F8+E7-G8/K;*D5)D3,H5*I6,N:+O9,Q?/V>0T>/S?0TB2ZB4VB4SC2SA0WA/W@0R@+H8)E4)E52O;4Q?-M:)E6)B2.C3.E6+E5+H8.F8&B0%D0(L62WC'L=2M=(G7,I92K;7N?3P?3O:-N9/WB=lV;lV5fR;hR5S?2O<,J7-P<-R@2ZH/[H3`N3`M6\L7ZH4UB;ZE@^IeN?mUCsYCrXBrXEv\Dt[Fv]DtXAmS=gN8bI>fP;dM<`H>`H<]E:[C4YA6]EiS?iS;gR:hR>lVDnY?fR?cO=cN8\J2RC1N?1P@7WF6]G9`I1YB9`L?fU3P>1N;1N>1RA1WC2^E2_E1Z@1W@0X@0T>4P?6QA8TA:YC6VF6RC6UB:YF8YD3XB3RB0QB0TC4VE4UA5TB2WC.XD-XA-S=0U=2X?;aL6cN8gR5aM5^I>gQBpY>mV8hT6gS9jUlT;dP4YH2TD2R>,O;)K8-J;.L:1RA/QC1N?0M>1N>-O>1VC2ZE1TD,O<*M9*L9'H8(J;,L>,J;-I90J:/E6.C4,J7.M8,K6*H4*G5-G84L>8O@5L>2L<-J9)I9-H6,G51M:2P>.N;.N;+O>.RA-Q?/K;1N>3VC3R>0S?2WC2SB2QB0OA,E5)A2-D54O?5S@2Q=*E5+E6)B4)C5*E8,H:,E7*A0+F0'I3-R?,N?/O=)K7/L83L:5P=0T@4N=-K;2\J=u`6mY7hT6kT=gS2RB4M>2L90O;-PA-QA0WG-VE7bQ4aO7_K<_J;ZE;\G>_ICaKIePQiRWlRVgPUbMT_MUeTTcPV_JdhTqp]{vdxe€xf}wd}sa}saqhUkhT‹~m—ƒs“€p—…s›‡s—†o–‡p–‡p™Šs—‡q™ŠtŠwŸŒw¡x¡x¢z‹w”€o…yh†zlxkŽxj‹zj‰xk„si|neviŠ|nˆzi†vk}oa}ra{tbytdxsfdn_do^fn_ure|tguoaqn`pi\oj[om]bgV^iUam[cnZcjV_dQ_cSdfYgeWmi[uobupaxsdto`sodlj_mkatrfuqbqlZqr_ur`tn_sl]ql]okZimXjn[jm]op`mj]uod~xm„xn‰xm‹zn†ylwhpp`oqaggWll^urd{sf‚xk„wk}thwrc|tfnbqg\qf[xncvmbqj_mj]um_xo`|nbzl`oaUpcWugZvj\rhZncVp`Umb„pd‚ma}l^na‚pf…ph…pitaYveZsgƒrg…rg„piƒqi€ofpd‚wjc]Pb`Rzuhzqe|sfri|qf|tg}pb{m`qh\sh^~nd}pbqd{kbve\ob€pbzk_|mb~nc}nc‚shzj^l`Yke\{q…|p‰}oŠ}lŒ|q~rŽ~qp†yl{qgzl‡}q„{n‚ylxh€{i‡{j…xj{qdvkboinl{re{reqh\ul^se€se}qe}od|ndtjrh~rhvfZ‚sgŠzn‰ymˆzoƒwk„um…yl…{lwjlcZsjcwi„xk†wl„ul„vmƒyp‡tjynb^]O\[Mtm`uf[zl`tk_woaxlbukanh]cZLldWqh[h_Ri]RpdYgaYkbZsg_wi_wi_zl`{pc|mb~lcucZmaXypd|qd}reuhƒtk€ri…ul†rh‚ngsc[€ng„sjƒrf{qfzmc}nd‚ri€rivmcp`Vwm_zsfyqczneukdykdui_rhZk]Mh[LugZrg_zmawf]jXQuh^vk]yqc|sd}rdyo]zp`wkZodZRIAUPKc_Zka^md_k]^dZY]WWkfesjjuiiwkkukkrjktjluhkwglriioeepee_TUe^]kddqdfkb`c_Zge_hgallfojgmedtfgwikpecka^tiewli{nmvhjvjmjac*<+*?.'?+&A,$A.%?-"8&$:'&>*+F0-C0)>*,@.'=+(@-(@/+B0)?-'>,&<)&=+/F46V@9_G;cMpY7kS6gP7hQlV>mW?mW?iT>hS;fQ=kUDp[EoZEmXFqZ>eR6YJ0QA/O@5WD7ZE6XB7XD:\HAeT=bU=cT>eU;dS5UC4S>2P=3O>7YF:aM7dM8`H:_J;]H4TB3TB2WC/YA2]D3[C3YC5XC2Q>2N<4N=6T@7XC6UC4RA5S@5UB5XF3XF1SC0TD1VC3WE0S?2Q>3XB0YC-V?-Q<,L8-O<2ZD3`J6dQ6`M3ZE:cL>iR?kUeMCs\@oW6`N2YF0UC2S@-P<'J6+I9*J9,N<2SC1P@0M=.L<+K;1VA2ZD.N?&H6(H5'F5%D4)E7)H9,K<,I9-H8*E4+F5-P<.Q=-L7-H4*D20F96M?>UG;RD5O?-I9&F5,F60K;2M>2O?-N<.N=+L;+O>.P?.J:,I9+N/OA2Q?/N;0L93K:4O=1T@7SE1QB8aQ>r_8mZ;hW;fU;`Q2OA0I90L91O;/P@0QA.SB(N=3]L5`N6^K;[J=YF?\HE_LI`NVePbmXip[loZkmZkmYqp^pnZvq]ƒye‹~loƒqo€n‹o‰}lriVjePž~¥’¡{¡|£Žy£z£z£‘{¢y¤‘{¦“}¥‘€¦’€§”€¥’}§“¢Ž|•„r‡{jŠ~pŽ|p{n~n}p‰xn€pg~qhˆzo‰{n…xm…xkˆ}nyj€xk~uiio`em^jk]ysf~rftk^sl_vna{sdtqbmo_owclrbmq_nq\ijWhhYmm_soarm`una|uf€xjvg|tjvndrkayrhzufvp_ss_rm]voa{pc{scvp^sq`po^nm^qo`mhZvpb|vlwm„ymˆ|pˆ|p~vhqs`mo_giYkk]vug|vkƒzq„zo~uhwqc~tf€pavbWsaUvfZpg[heWefXneZuj^{m`~ma~m_|k]|m`|n`xk_qdXrdX„si‡shƒrf€pc€qd„ti‡ul…ultd\paVsg„sg„rg€pf~qfxk`yj^ymbaZOi`Stk]ti\vh]sg^pf\vm`pe~oc|pe|of€nf‚rerf|mdre[znb}qcnc‚od‚peƒpe†rg‚odqe\mg^{vm†|rˆ{oˆ}oŠ}s‹}qŽ~q}p„vixjb{ob‚tkqiyncvm`sn^zj]wk]zn`}pdnf€nhrgznancW}rf‚vg„wisiƒsk‚tk‚sj…umƒsirfZ‚vj‰|p‰|p‡{oykƒtkth„xl~vilbYwnexjƒ{m„zmwmyqfxqhshmaUVOBd]PofYqdXsg[leXohZxkbylbvndzna}pd{nb|oc|nbqgZibZvmczoe{mb|nbtf|qe|nc|lcvg^meX{vizrd{sf|tg|sitj|rh„sgzkbqe]xmd~qhsgzoewmcwncwncvj`oaWm\Svk`tl_rg[qbZndZwi`ui_ugZsfZ~pb~ndzog}qezlbdUN{neyqa}th{re|qc{oczobtg[of[SKC]XSgb_ldape`qdfcZZa[Zmggpffreeodcnddlddodgqcgo_ch\]m^`qacfYWk`\ndaqdflcbmhdmmgijdjlepjhtjiyllvjioedldbojhtmjsjjphhnhhb^^*:))<+(>*(>+%=+%8'$6%&7%':)&8((:'*:).>-.A0)@1)A3-B/*A/&B/)B1,B04G65XC,R=0TB6[I9cK=gQ>kT?jU:hS:gS=fP:dO?iTBpZDr\Gt^Gw`Dn[9_O4WG2VE5YH;[H9YF:\G>`OBfV?eUAeU=bQ:`N8_M8S@/O:.N92Q<5U?2Q<1P?6WH6[J2[G5\F5\E3WD7ZF4VC4WC0S?3WA2T<1S;2T>2S>4TA2WA0X?/WA2VA0S@6R>1M:1K95Q>7VC7ZF:XD6UA5S@5TB4VE.SB0T@1VB0WB3ZE4WD3UB5XB0WA-S?-N:/L:/P>9_J6cM1`L7_L8]I9_I>dN=cN9_M8aO6cN:iS7hR-^H,ZD2[F6]I(Q<,M:,O:-U@+VA(N:-J7-I8-N<2VG2YF9^KBdOArZAoY8eR7`O7^K/U@-Q>,O:*L9+L<.O>3WE2SB/O>,L;-P<.R>-S?)J6'F3(G3+F6'C2(B4+K:+K:,K:)J9+L8-N;-S@-Q>,K7(C1&<+/B36M@?WH7PB0K;.J:,J:,F80M>3PA1N?0O@-L=-N<-O>+M;+F6*G6%F6.N:2VB,O=*H77RB7TE2M:.J7.J:/O>/RA0UC,O>+J9*D4(A3+E7.H:,G:,E7'D4%G6,O?1PA1K:0L92N;1J9/K8.R=1RD,M>3YJ;jY4dR5`N8YL9WJ3N@0I;.K9,J73N>4RA.O>*N=2WF5]K3YG=\LC[KF\LOaPWbQrp\‚{g‰€n‹}l~m~m“ƒo–…p™†qž‰w¡‰x¢‰yœ‰wŠx™ˆw–‰v€nvkXzr\­œŠ¬–„©–ƒ§–€ª”~¦”§•©–§”¨”€¨•€©•„©•ƒ©•ƒ¦“€¥‘£Ž~˜†u…xi†{lŠ~q}pŽ~q‘~rŒyp„sj~ngsk„wo‚wmsi‚vk‚wl‚vluksrckl^tqc‚wkƒsg|nbunavj~whytezxjy{iywivtdzuepj[oj[upazsfvnayqdufƒtg‚rf‚rizmcvkb|sfzrdvm^vpaohYzoc‰{o‡{l†xg~uhwn`wpb}vguo_tn^yuh€yl€zm{n{n€zmxwdxweqo^ni\xrgyrh}tk}qhwmbtl_}qbp`j]zgYyh[xl^lhZcbSod[xja€od„pe‡qe…pdpcobyk_rdXrcZ€qh…ui‚sg}qctf‚tiƒtlvlrg\g\Pqd€nc{i^rhZmeWndWvg[vh]ndZteYug[xg[yk_rh]ndZzqd†uj„th†ymƒui†ti†ul…ulpgndYpf\|si†sg„rg‚qe†uj…ti„rfylcke[rlcxn†zp…yoƒzm…xl†wk‰wl…sh|l_ocmd~leykboeZrl^ƒsg…uhƒwi„wi…wj„ul…sj}nek_S}qe…yn„xj…tkƒtk‚sjƒsj„thqekeX‚znˆ~rŠtˆryl…xo€thƒwk}rfrg]tka~uf~sfymai_RXQEkdZxm`obVwi\zl`yl`wnavk_ngZsl_~rhƒtjsi„sg„thƒsgqerftgZlcY|qf|pd|nb~rc|qc}qfylbyibqf\h`Uvtd}th}uh}tgzofzod~qh~obtf[sf^xldvk`zk_rcZmcYpj`ulaxi`|h`~lcznd|qe~pcuf\oe[yla{nbyk_xj_ne}mcxmezpdtj``UM}sh{tezqdxocvj`th^th_qaYd\SOI@_[Vc_[g\YgYV`STXNNXTS`[ZcYYaSTeYVfZXh\\occsfhrdhsdgugiqdei][md_mg`pefmgejgbkmffhblkgqhhrgfuhfrgeg`^b_]jddleelddlddhd`ec_-=,,>-.A.*>+(:*):)(7&'7&)9((8'+7(,9)+;*.@3-E6,H80E3*D2)E2+H51J82H63XC;fP;kU;hS?iV>kX=gU8]K4UE/L<3P@;XG<`K;[F9UA9VA<\G>bL?cM?cM?cM;^H6YC=_I@gMBfM=aIAeOAhR;dN8\H6YE4VC/Q=1VC;_MCjS@iQ@iR>fQ;eP6bO9`K9`K?hSEp[Ft_Et^Ew_Ap[;fU7^N7_N:bO;cQ9`N9`O?fT@kY>kX>bR?cR;^M6\J;aO=dO5[J4TB7T@9ZE:ZF>YI;]K6VE8UE:VB6Q>1WA3ZD7]G4\F4XB.U?/T@0M:0L=4TC9`J9dO5aO9aN7ZF9\G=cM;_I4VE5XG3ZF:dO5eO(VA-YD/YD1WB)L9*G4+Q<+VA'P<$G4'D1+F6,L;-RA4\J:_L@dO?lV=lX:gT=gU1\F,V?0U?+Q=,Q=,R>/SB4WG2VE/Q@,M:.Q=.Q>'M6)F5(F2+H9,G7*E5-G7/K;-M<(J9)M8(M:,Q<+P@(K:*I6(A/&;*0B44J<5M?1K=0K;/J:0K;,I9/L=0N>-M=0O@.N>-N<,N=+K:,F7)E4%F5,J:7YI(M<,L:7T@6TA3R>2P=2P;0P@-Q@/UC+O>+K:)D4)D3,E7/L=/K>-G:'G6*N=.Q@.K;0G7-H51M:0J8,J7,P<*O?,L=1SD0WF-TD1UD5OD6QC5PB2M=/K;-K85O@7SC1Q@-N=0SB5XG3UD@[KJ_OQbS\eVopbŒ}l—‡vž‹z¡‹{¢Œ{¢|¤y¥‘{§’€©’€©’€¨‘¥}¤} {™‰x”†tqfSƒua¶¡®—†ª—„§—€¬–€ª–©–¨•€ª—‚¨•€ª—‚©•„¨”‚§“§“€¦’¡|•ƒsˆxiƒvj€wj„zm‰zmŽ{pŽ|p…rj|kboh€qj}sizoe{oe€tk†xo‡xotqcon`|wiˆzn†uj~ncxnb~vi€wi‚yk‚{m|j€{l{sdsfxm_pdVxn_wl^sj\ul^zl`€nc†qf‡qj…qh„sgƒui}sfzrf{reth]ul‹|pŒ|p‹{kˆzm„whƒwj„ykvhzrdxrexk~{mzwizvh~xlƒwgƒxi€qdvg\~pepfvnfvjavj`{qd€tg‰xk‡ylƒsf‚rerdym_ncUndZzkaƒpi…rg„qg„rf}oc}nb{k_xg^te\}ne†vjre}rd{rd{odui_ukape[pbVwg[yj^yh]lcUe^QkdWxj^{l`{na|j_{i^zi]}nbti`jbXui…ujˆxl†xl„wkˆvk‡vmƒsj‚sjf[Qi_T~vkrerf~tg|sfynb{nbxi\mdYqja}ph‚qjxjari\wj_‡wk†ti‰wl‡ujˆvkˆum†slmfk`Vvna‡wl‰ym‡wj‡zl„xk‚vj†tlue\i]S}qe„xlƒuiƒtk‚ulvl€uhƒth‚pejbV€wj…{nƒzm‚yl~vi{oewkazne|pfui^wk^qdreqek]Qf[Nzqdzqd~qeƒrg„sg‚ui~sgzmad^QngZwm„ul€ri„th€qf‚rfqe|ococWpgZ|tg~rezoczpcwo`zndvk`pc[eZPiaTum_yl`xk_qbVn^Uzi`~mdk`xe\}lb}mend|l_s^WpbYzpfzoe€nf†phƒrj~thwiƒtf{k_rg]{nbzodznf}me~of{mczme{pdf\QlaYvk{sdyperh^maWnaYre^l]WWOFUMH]WT]YVbWUhZXk`a_VV`ZYfa`labl^^l`]g\YfZWk``thisghuhjrhiibaea\hd^jh^kbae^\ea\XWQ^]Ygfbndfj_^od`lc_b][c``nddoddrgethfqjfojg,=,+=,+?,*>+&8();**;*(8)*9+(7*+9(+:)*9++?00I94O?1L9,G5*F3.K85S@5VB6[D9eM8gO;eP:bL:cM9`N7[G3P?3N<8SA=ZI9_J6VB5P=4N::WCBaM>`JcKeN>gQ6bK:_L8^I@gQGoYGs]Ft_Gw_Bp[?iX8bQ6aO7dQ8eS8dS;dU>hX?lY;jT=aP?cR?dR7]K:`N;aO6[J7VE8WB9ZE9^H>]J;_L5WC5S?6P=4O:9S=0Q=0T>3XA2XC0R>/O>,M=,P>.R=,P81Q;3P<0P?/N4Q?3M61O73U?4[C7^I7^I5YG0WC0S@0N:1N=6YF4[E2]G5_M8]K:ZG9ZD?eO>_J0M<5RA5VD9\H4`N.VD0VB+VA.U@0O;(E2,R>+T?*M9'G3#E1*I4,L9,O;8]J5]G;cL9fQ;gT>jW;eS2]G,W@/U?,S<-U@-U@/U@2VC1XD0VA.R>0S?,Q:%J4(H1,H5.K;-J:+I9-M9-K;+K9*K8*M9*O:.S>,L='F6+H7*D2+B20E60G9,F7.H:.J:0K;/J:*I9/O>-M<-M<0P?0P?5TC-O>(H7,E5+F6'G60L=1SD+P?,O;0R?/R>0S<4SA6TA2RA,N=.QA+O=,K8)E4,G6-I95UE1OA*H:&H7(N<+O;,H51D5.H82M=1K;,I9*N<)O;-O<0O=.N<.O=2P>2L=7SC7UD4SB/L-)=+)=*%;('9()<++=,(:,)9+)8+'9((:*)9,*>/0H::TG7UC3N;.H62P<9]I5^H7\D6`F5cI:cL6[E5ZC-XC0WB1Q>5TA8YF>aM;cN7YE2L;4M98S@@_I>fM9aI9cI=gM:aH8]D4]E:aHBeKEiOEmQGrVDkPFnSDkR?fP2YE6]KfM=fM@fQ7R=;WA9V?1P:4T=2T<5Q=6VC1VB/T?1R=2P8/M9.N91T<1V?+N:-K;,N?.RA,P=-Q;2Q<6Q>1PA.L=/M:2P;2N:/M8.F7*C2+F4/M9,I8(E71M=6QA4L92J84M:4L84I21J31Q95ZA8_I4^G5YJ0UD1TC4S@3R@4YD1WA-WB0ZG6YH6TA1Q=?dN>_K6P@4N>5Q@5VC0YG/TB-Q>)U?,V@/M8)I6'N9(M9+I6*H5&L8+O9.M:3P>:XF6^F9fM,U>)Q<-T?.T?.V@1VB1UA1T?,P;#G2*F0/J60L<-N<,N<-Q<+K:+K9&F3'H5(L7-O:-H;*D5.J:0J8,F5,F61I:.H9.J;0M=0J:/I:-N;1R?3R@/N<0P=2R?2O?*K:*H8,F7.I9*J82OA/QB*P>-Q>+P<'Q;,P:/Q=5S?3P@-K<,K;+N'F6)L;)P;+O:.J54G72J;5P@0K;,J9+N=-T?2R?3M;2M;4O<9R@6Q?7U@9ZE8YD3Q@4PB2UB1T?6VC7VC:XE@\IA[IUhVao]co]oq`†~l™‹w¦•ƒ¨–…ª–…¨—†©™„«—†«—†«–‡«–…ª—„©–€¨–¦•¢’}ŸŽ|˜ˆwzkZ›†u¶œ¯˜‰©•†§”ƒ­•«•ƒ«•ƒ¬–„«”ƒ«•ƒ©”‚©•‚¨”€¦•~¦”~¥‘~¢|—s‡ocpe{tgypcƒpc‡zqŠzpŽznŽ{m‹xkˆxkˆ{mqg{lc{oe‚vl„ylqpbrrdzvhuhƒuj€uh~re{nbug„xj‚uh|p`soaul`~pgƒogƒpd…pbma‚pcƒsf}ma‚ncxn‘xq‘yp‘}pŒ{n~sh{tk†sl}ke|og„yo…{m‡zk‡}j…yi†uhˆyk†xn~rgƒsf€uh{tgpi\j`Vƒvm~t~t~sŽ|op‰|l‚vjƒsg€pesj€vn‡zr|s‹wo…sjqgtkamg[i_RpgYvi_zpgvkdmd\mfYsg]sd[uaZs`Xwe^|kavgZk_QaVHi[Qzkb€nf~ldnd‚mc}l`{m_tb\cXOsj]€se€qa~o]zl_{k_~ma{nbxmdg]Svmc~pg€rg{qd{pc}n`}md}mayj[wgWyi]}lbƒod€ocfZNqi[{pc‚sg‡peƒtgui…uh‰wi‰xhthYqc‹xpŽ{s~q€s‹€p‹~oŠ{o‚rftg[ymb„xlƒwj„uj~rhwmetlexldlbYcZPmcX|ndwi]wkdri`tmc}vh‚uipcƒqh…si„si€rgrh][RI~ugƒxoum‡vo†vj‡vj†zl‡zlƒvhoeWoiZxsd|oc|rfzre{re|pdqe}j_bXLoi[wnexmcwndsoatn`vpcvnari]ofYng\qi_ulbqj`e_Vb_Vsh^uhaujazlc|na}o_|qd{ref[OodY~qg}pe{k^~qdti|qf{oc{oaj_Vsg]~rh|rh{tixui}sixqfypawi[k]OkbTld[og^qg`h^UkbVohXs_YjZOpdYrg^vkavj\rg_eZSk_Wth]wk`tg[i\TcZTgb^jccpffka^g^^YSSb]\f]]obbl]]ka[n`\n`\tecpecpefufdpcad\Xlfamgblfapdaneakfafa\ngcqihoijrihshdkc_c][iddig_hd^hc^ga_a\\b__*?-'@.%;+*9,&8')<+)<-+>.+>/(:,*<*/<+1<,,<+5M=<^L9eP0UE/M;2T<=cJ?iR8^H6[E9[G9YF8ZG5WC.S?4TA5SA6\F:bM>eP:dM8ZC9T=9S<:VBiReM:`I:_K3XI7]N=cS?iX@m[Bo]Cp]?jX?dR9[J7YH6YG9]H:`K:R?4P;3Q88R@8UB6WB7XC;YCWF>UD8O>4Q=4U>5W?7Y@6X?2U>3T@/M?/K8/L91N;2Q@/M<0M>2Q>2SA2RB1P?1R>3S;1Q?2K;0J:4M=2L:5K94I6/D2-A0-C1-C1,B0/D54K<4M=0H93K:4K90G90K90O;1V@7^H2ZE3[I3VE0Q>3S@0UA0YC-Q:)M73VC2T@4T@9XD6QA0RC3QA.K;.K;1P=*L9+K:/M*P:+P:/S=4YC5`I6fOkR8bJ7]H1TA-M<3P>.N9+O8*Q:-N;+N7/U=/YA2YA/P8,G0)F3-J;/L=-M=,L:.Q<,L7,J7,J6%B3)F7+H9.K6.K70L9.J70J:1J99O:1L9.K:/L<0J95M4V>5S>4P<3L=-H8-H8-I9.L.N<.M=.K=3QB+K<)L=,N:,N<-O>/O>0J;1I;0PA5N=5N<2O<0UB2XH&D:)G;,N>+O>.O>0N<2G96O<8S?1M:.N;.O@.U@4TA8TA5TA4UA;YD[IB\JB^JI`O]jYktcirattbŒnŸŽz¨—„¨–…¨–…©—„ª™„¬—…©—„ªš†ª™‡­—‡«•…¬–¨•€¤‘{žzŸŒz”~n¢y°˜†®—…©–ƒª—€¬•|§”©•ƒ©–„¨•ƒ¦“¦’€£”| zž|Ÿ~Œ|›ˆ{™‚wzm’~p‹zm„tj|of‰rl‘{s‘|u}sŽ{qŠzn‡|nƒyj{ocxl`~vh{vjqsdvwiwsfzrdtg‡xiƒng‚nf†uj‰wl‡vkqe{md{ndƒul‡wkŒynŽukuhŽxhŠyi„sfqi†vo{p{oŒ|q…zn{sf|ug„qkzh`yi_}of‚sg‚th}lbrfˆzn}qŽ}q‹xo‰zl‹{q‡yppgxlaƒwi’~u’u‘€tŒ|s~tŽ‚r†yn‚zlyrc}qd‚vi‚yoŠzs„tm|ngwkaqe\kaTh_RkaVocZsf\o`XcUNhZRwg_wfZyeZ|i]ƒmf€kak`tcWcSGwi]|pcpd‚qf€qf|ma}la~mbxiaf[QsgZ~qf€pf}lctj^wl`{nbyl`peXmdUsg^~pe}k_}maoaYnd\~pa…tg†tg€pcpd„od„peoci_Pvl]ƒsi†slŠvm‡sl‰vnˆwk‰zk‡vkxnaƒvjŠ{n}qŒ|sŠ{r‹zs‹zr‰vn…tkqaWtgZue\yjaykbuh`oe]pf_naYn_Uym_…uh…uh…sj€mdl`Vvpeƒxn‡xoƒvmtg‚wi‡zk…teveYYPB|ri…yp†tn†tm‡vk†yj…~l†|m‡|pk`Vle[poa{pbwpcsmcnh_ph\oeUf]N`XIk`TqeXsg\obYccXheYwoeznd|nbqe€od„sf‚pg~nel`VncYwng}pf|obypazpaqc{qcxpajcTtn^|tf}sf{ldog|ncre|ncxjanbZrj`tk`tg^rg^jc[e`TiaVh[RgXLjZNo`Uqi[uk`uh]eWLjaTum`|ne}meni…xq‚ul|shud_YOKf^Yshazlfuibl\V`RNdWWj]]i[Zj[[gZXaVTnbdsdfwfhzfgtggvihwjkwjkujitlitielc`_YVhdapgfrggqcdmcad\Z]YUhb`kddhecgaaj^^l`^pgbpjcnidja^lc_f`[_\Xed`-C1(?.*=/-<.,=+.?/-?.-@/.B2-B2)B.-B/->--B02P>;aN=kT`M9[F4U>7V>:VA@\H=XG7WD3XD8`J6^G6XB3Q:4RA9WD=`K?fOAkQFrXNy_N|bIw]DpY=cP4TG4WD;`JChRDmTBlTCnWEnWAlT>fP?bL9\F6^GlX@n[Bq^Bm[aMAeP>cMAdO>]I:VB4R?4P=6P>:TB:V@:W?7TA7UB6WB7WB<[E?]G<[G=XE0P<2RA5UD5UD5UA5VA2R@1K<3M>1M=2N?0I73J84K9.E3+B0*C1,E3)C0-I5,J62Q>5TA2Q>5P@1N<0P;/S=3YE5[H1YG3XG1S@/Q>1UA/VB(K8(J8/O@0P>7VB-PA.R@0T>5VA4S=2O;/I9/J:/K;/M=.N=-O>-M=.M=2O?/L<,M=.Q@1P=/N:/N;1P>3N<4M=4Q?3L;5O=0S?4VF0QA(B7+H:.N>-P=4XF2TC4L>5M>5Q=2P;,K72R@0TB8WEYH:WD=[HH^LN_OOdQQaP_iXkp_hm\wtaq¢|©•‚©•„«—†ª–‚ª—‚ª–„©—„§—…§•„¨–…«•…§”¥“‚£“¤”£‘Ÿ{¤”€§•ƒ ‘’š‘}¡’~¡‘Ÿ~žŽ}Ÿ~œŒ|ž|˜†t’‚p“…t—ˆw—…x–ƒv–€u”s“trˆwn€ofph‹zrvŽ€v‹|s‡ypƒwkuizkarf[tj`yofusgxtfvna~rfˆykŒzmwo‹vnŽ{p|qŽ{p…uhyjc}qhƒxm…umŒzoŒxn‰xl{oŠymƒuhxiapj‡xm‡ymƒxk|sfsm`tn`me{h`|jb€neƒrfodyj]pd†ymŠ}qŽsŽ~q}p|r‹|s†wo{mc~qd‹~qŽ‚sŽƒuˆ|uŠv…}oƒvk}vgwn`{oa~qd~tj†um{jauf[xi^sfYqdXsaUucZvd\xf]yf_iUNcXOzkczi^zh^~ma~lc‚od}k_tdXhYLyk_}oc~nfpgylbxja}lc}jbwf^k\RmaUwj^zi_zg`mdWndXzmawh\vg\{l`„qh…qf‡shƒnfwf_sd_€th†vj„sfqepf…rh„pi~ock`Rul^€si‡vn†vlˆvq‹yr‹zmˆxj‚ogug[~pdˆwkŒzp‡vmƒtjsj…ulƒri~mdvh[zl`}ndpe~rhncYkaXzpf…qj‡tj‰xl|o‹zn‰wmpgiaV}xm‚wm„ulƒul†uh‚vi€wh~tetn`SRE|wi„zp€vlum~xl|ylzkvj~qifZPmdVoi[yn`ri^g^Ud\SmcXmcTm_SreYrfZocWui_ncYc_Rrk_|se‚rf†ui‡vj„tj„sk€pg~oeod[ph]skcymeyodun`xpc{pd{mcvmabXNukbwmdyjczmezoerfZui^rfZmaWiYQncYshZrbVm_Ue]Spi^ynd{lbxj^yj_vi^xobxn`zl``RFwm`xpb€riogpitlul{pfi\WTMGhc\skdwogoj`g_Sc[Ri`Yla]m`\oa\eYWaUTtghvikwjjzkiwmlukiujhrieofbnfbpebj_\g^[ka_naak^_i[\f\Zb[Wb_Zhdaiednhhpiirjgpieqjfqlfqigpgcqhef_Z^ZUec\-H5*A/,=.0?1/>/2A0.@/0C23K92N:,I5,E2-@0/G53R?;bMeT:^I5V@7_D4R>;VC7P>1M:0M;4U@7U@1L80H30M<5TA5ZD9_H4_E:iOLsZJw]Dv]aNBhRClSBlSGnYClU@gQAeO;]I7^H=eU@fT?fS?eSfT6[G7YD=^IAaNCdP@`MAbM?^IXF1N;/M:1O<5Q>2SC5VE8WG4TA4UB3V@4SA3P=1N>1RA1R@.J:0J81K91K9.G5.I5*E1)C0-I4.O:1T>0U@/R>4R?5SA0Q,L=(E7,I:0N?7UB;^H:aJ6[F1R?0M;,F6,F60N@.L>(G8(F8,K;0O>*J6.M:1O<6UB2S@)N9+M;-N<3P?6RB7VE3VD4`MBr\?mU3_I3XE-N=,F6,E4)E1*N90UA.R=+K:*M;-TA/UC,O=,I9+F6*E5.I9+H8+J6*I6(K;+M;'I8(G6)H5(F3*J70N;-K8.K90L:2M:7R=5N<0F6.G72O>/R=+K=(L9+M7/P;2R>/N91J;1L<5QA2Q@.Q@-Q?-L=0N?1N>/L<2SB2UD6R>3P<1M92N;4O=6O>6O=4O=4U@4YH6XH.G9-E82M>1O>.Q=5[H6\J6OB4N?6R?3S>4S>/O;3SB;WF=XDXF;YG:YF=`K=`JA`N?\JC\KB^KH`MVdS\eT_gU]eTdjZlm]pm^}uf‚t¦}ª”‚©’‚©“‚ª”‚¨”€¦”ƒ¥”ƒ¢’£“‚£“ƒ¢’‚ ›~™Œ{›{™Šw™ˆu˜‡v—†uƒs‡€q‹…u•Š{—‡z•…w—†y–†x—‡y•„w’rŒxmzn•‚u“€s“€s’u’€u’€u“uŽzo„phpd‚rj†xn…um€tluibync~qh~mdyib{me}qi€vl€vm{ob„th|rŽ{n’zs’{t‘}r’~s‘}r‹xm~oiyld‚sm‡xo‰xoˆwn…ul†vl„tjogxe]}jc…viƒth~qdf[Ouk_|se„skpfƒpf…qg†rgƒodmbqc†zpˆ|q‡{n‰}q~r}q‹{oŠzn{l`vh\†zk‰}l‡|nƒvn€umwk‚uizpcvnasgƒui‚vj‰yl|j]sbVyj]yi\yi\~h]ja}h`|ia{iap]Vl`Xyjbyl_zj^zk_|mdmbwg[tcWiYMsbXteWuf_rg^laYn`XkZStaZuc[scYwh\zl_}j`{g`hbUndX~pc~nbnc…sh…rg†sh‰ujƒogq`Yrb_€uiƒsgpg}qgriƒri„sjqg_VKoeZ|ph‚rk€uipj‚qj„ujƒqgzg_xi^ƒsgˆukˆvl‡tmyh_vk‰{qŒzs‡wk‚sg…wlˆ{m†ymujl_Ti`VukŠxoŒyq‹zoŒ|oŠ|p‡ymzndd^R{uj„xn‡ul„ulƒtj~th|teyoac\NVVHpiZ{sf}siwpfll`gl`woeyoeziavg[wk]yo]}pbuj_dZPi`Vsh^rgYsdYtfZsgZsg]vj`pdZfbTyre~rf€rfth‚uk€uk~qgymcuh_j_RogZrkcujbtjaqkarlbocZte[l`UcWNodZse^wg`ui`nbWmaWqeYrg[pcXve[sfZzl_zk]vi\jbWxnd|pfxmcxm_{pd|reypfxmcvg]^OExmb{rh‚sg~qh}ph~qi~qgwl`k^X\UMkd\tkbpi`gd[WUJgaYlfalb^shdqa__SReXYpegsgithgtifnddkb]jc_gb]e`[ha]m`^pb`ob`qdatgerdcsfgpdb`[Ugc^mjfoljsiiskjokfnjemiclganccnb`f\YbYT^YQc^W/P=.F40B13F45G96I83G63J8:WC<]G4Q@0I70E28M:5S>BgQ>mW>eU<`K7[C6\B:cL8fO:dN`L6YE4WC5XD8UB:VD4UB6[G:ZG=[G;[F5VB3R?1L:2K9.I70L93N:4O;3M94M82R@3R?4VA3V@2\B0]E=eJBnT?pX;hS6ZI7TC7QC4TC:]K=bO=fPClTFmSDmUAkTBiS?bN:aM>hWAfW?dT>cRfQ9^J7ZD=]F?_MCbOA_LA`KCbMA`J>_J>^JA^KB^K@^H@`H;\G>\H:XC9WB;YD:ZF<_F?_I<\G:ZF;]F:^F7]G9\E4R?5S@6UB3S@7S@4R>0O=/P<2Q>6UB3VE5VE4SA2R?1R?0UA5WC6R@1O<2SB3VE1P@/K70L9.K7.J6-I5*G3*B,.H34R=4T@1Q>/N;1Q>6VD2Q?3R?3RC6SF0UD/SB1T@0T@4WC3VD-K=*E8,E81K=4P?7WB8[H2UA/O<-K8)D4.G7.L=.M=+I:+J:.N<1P?+K8/O<1O=3S@3TA+N:*O>.Q@0RA4UC4UC6YH6YG@gS6Q=1G81K;4Q@+N:(F8&D2)F3+J52P=,I92M=8TC6SC3SB2TC.RA,K1N>3P?5VB7\H:WB:VB6R>4O<6R>6R?:UB6TB8WB8WB8VB8UF@YIA\IA_JVD>YE?\GB^LCaMGdOJfRNcQLdQSdSdkZmj[qn_ml\nn^qqavo`€tf‘ƒu¡}¤‘¥’ƒ¥‘‚¥’£~žŽ}Ÿ~™‰y™‰z–‡w’…wŽvŠr‹€q€p€n‘€m”p•~o}nwi‚ykŽu•v“t™„z—ƒx”€u”€t‘|u‰tlˆsi’}s•v“t’v‘v‘~w“~vzo…odyg\}j`‚of†slmfn\Trg…vm„tk€pi‚tl€um†yo‡wn‚qh„shŒzo|q{szs’s‘}r”~s’}q‚qkwf_‚qh‡ul…tk|mc€mekeƒnf…nf‚j`ˆoe‡sh‡shl`m\P~ma‡xkƒsg†ui†siŠvk‹wl†rg€pc~nd‚vl…yoƒvl‡|nŒ{p‰ymˆxl†vkwh[vfZ„sf…vezj^q^V{ib‰xm†xl}sgƒvkˆymŒzoŠ}p}pqdxgZ}l_naoc‚pe‚qg|kc~ndzjbhXQrf^wkbzl`ui\wi\wjaufYtdYueYk[OueYxgZsf^naYgZReXPq`Yyg_|h`}l`~pc|oa€qdziagcUng[|pcqe„rg†th‚uj„wkƒvi~pfn`Ytgati€pc}nd~sh~siƒsj}pcuh^`SJqe]wjbxkcwoape[ymd…wkƒsg…sk†sj{pŽ~rŽsŒzrwd\~si‰{rŒ|p‰ymˆym†yk„yk†znƒwki\Qk`Vukˆ}r‡{qŠ~uˆr‡r€ykmaV]TJwnd„ul„sj|ofri`pg\tj]kZMn]Qxj^qfƒujsfqf\hcY[YOunctjqhƒsg‚tf~tcre|ocaVLqf\ogYsj]vkbymcvkawkati_pg\edTwrb{rd|pdyrduncvlcukawj`ocWg]QneYqg]mbZh_X^WP]UOqc[xi\xk]ti[yn`{n`zk]xmbl`Vpe[vj_uj^xm`si_um_xoayn`pfYoi^|qg}pg{oe}qexpcyrd{qg|pgvj`pdZuj`{pf}mbykbvlcvkbvlawh]eTMn^Vrd]sc\e[RWUK][S`\X`XXi^_l^`h[\cVTcXXlachabsihrgeh``aZWngake^ujftkhpdcrfdshfuhgshftifsjgkb__XSg`[hd_gc_kacfa_``XdcZec\gc^mbcg_]jb_ld_me^pga4\H2N;1H75Q?3L<9O?7N<9T?@aIDjQ<^K6S?2J6@XDBbKChQcM;\I:]I6YE8[G:UC8VD=aM=dO?eQ=eN;`K9XF6QA4N=2M;/K9/K82N:6R>5S?5U?5VD3Q>.K7,N8/T;0Z@;cHjSCjQAmSAnWEmVDiU@hU@jZ@eWBeY@dW[F=YI@[JA\IC_KCaKBcJ?bJ@aMB`MC`M?^J=_G=\F>ZE;VB7R>8S@9WD;]E<^G<^I=aL;`K;`J9`J6XE1N>1L<2Q>3T?6S@3R?2UA0V?3WA4V@1UE2TB2Q=/N:-P<.T@3XC5UA2O<*L;-M=0L2M>0PA2P@4P=/L9.I:3L>/N=1P@2S@3TA5XD4XD4P@.I9,E62K=3O=3S?4RA1O>.M=+L;-K:-I9-J;,J:*K8,N;/N;1O;.P;0P>/P?2RA1Q?.O;,N:/O<,M:/Q=7YE5VB:VF7XE6]G5]E8\F5R>/K;2J;/I:-L<,N<-M8,G8+G8.N>/QA0QA)J:*F7*E5/K8/I7.H5-E6-J60K:-I7.K;-K;*H9-I94N?3M;2N;2K:1K86U=5Q>0N=3O@5Q@,I6$=/";*#>,)D20K:-J:1N>6UD6VE2RA0Q@.O>,K<0N>2O@7VB7XE6\F9[G:ZF9UB7P@4O>8SC=[H?YJ@^N:[J=[I@WC>VD@YG?ZF<]H:`J?gS>]M8WF9WD<\G;XE>ZIXF=XEFbNHlSHpW@iT7ZE4Q_L>`M<_K8XF:WD8WD:_K=hS?iT7iO:bM;XH=VG8SA7UA6TA1N;2N:3R=5XC4[D4XF.N;.J6+I43V=:aHcS9cQ6cO@gMhX7dS=cP8^K9^N9`P8_O8^O?aLAcO?cM:]K;ZG@\J?[LC]LA[IE_LB_I?^G.L=/L=2M@0M>1L<0J70F61G91J:7RB7TA3S@8YE8ZF7VA3M<5J;7O>7QC3TA5O?2N>.M<+N=,M=-M<,K8/N:/P=*M7.M82Q;-N9.M6R>5R?0S>9dL=jP;cK/S<2O<3M?/I;,K<,N;/M8.H8,G7.L<-M<0P?+L:,F8.H90J92L93K:/E70H50J7,G5.I9,J;+H:.I83M=3M;1J80I60I65R<2Q=-N=/O?3M<1I6+?1%;*%<*)B1-G8/I:0R@2RA2P@-M;-K;/M=-L=2P@6SC;ZF7ZD7[E5[G7YG7UD8SC:UF@\M?^N>YJAYM>]KA^JE_HC]JD_KB^H?_I;`K\I?[ID]NC^PE`OEbLEiRDdOE^NReSTfTUgVQcRViU\oX[lZUgTZgUqqa€wfƒyhƒxgxvevsd}rd}ob|sf†zmˆ|n…yoƒvlrf{pb€rbƒsf„tgˆxk„zl|ug|rezrd„wk‹}p{n‘}o{r”}r|n‡{kve…tg‡zmsŽsŽ€t‹}qŠ{oyn†qfƒk_†leŒvn‹wo‡tlnf€mgŠwp”v‘~qŽ|qŽ|q{o~q‰zkƒsdˆxkˆ{m‡zn„{n}wj~{o…un†xo€tk{of}rf‚wj‰yn„rj}k`†uj‹wmŽzoŠwlŒwlŽxm‹vjƒsezl]~o^‰ykŒ{pzr‹xnŠyl‰ym…ti‚qevcX{i^„rg†uh„tg‚sfƒuiƒuirgobxi]xhamf‚pfƒqb{kapfˆxjŠyl‹xoŠxp‹zp}pŽ|qŠvo„qhˆxg‰zm„yl„vl|r‘}q‹{n‰}n‡yk|m`zj^‚qh~kbxh\wd[zg`{g_zd]wb\wf_|kc€pd€pdzj^dXL}rfsgre‚qf„qf€lakazg\qaUreX}ob|ocqere€uhwi~rftg[a^QjdWtl_|od~rf|qevnfwmetk_tg[udYxeZ|o_~m^}l_thZsi\…ui…vh…ti…tj„ti†vk†ylƒubqbTreŒ}nŒ~pŒ}s‘€t~r‹s‰}r‹~usd[|tg…{o‰znˆ{m‡xj„xiulsiwjaqcZsd\vga{rd}rgwkceYOqeX{o`Šwlˆxl‰zn}rŽ|q…vjne]xrh~wj‰q†~p{oƒyqŠ|s‹{o„uhsgZwndwkuj€ri€qh}re|uguixnah_Rg_Roi\lg\ig]dbXe_WibWkbWpdXym^€p`‚obmbuh]f]Sme\ujbxjazk_xh\wj\zm^wi^i^Ve\Vskd|le~nkzmiukcul`sjZujYoeYi_Vpe\qg]ndYneWmcZof]oeZsaYaNGYJCcZPbYNg^Ti]PlaTjbTre[xlbvlbyoeuk`zmcyh[paWula}ukti€sd}pdynazlbykbok`ai^li_ke^oc`pecpdbe[XYVMhb^hccofhnbfk\a`SXbWWqeapeaoa`padb`^a^]e`]jebkhdnngolgqjerg`vicreareanegdc^ZaVdj]olcsjetlhrmhjgbgd_ga^kb_?fQ:_L6WF;YI>bM8YE>`L>aM@eQ?hP;hM;fLAfP>^L1VG0S@3T?7[F>dP;fOBgNAgN@fN9_J6VD7WD;WB6R>3O95R>5UC3TD7TD2O?1M:(H33V@:bH;fN;aK6VF0M=1M:3N;3N>+M<3XH9dS9dS6`O:bN=cPBgUHl\Ip^Dn]LpdImdFleFldDk_?eV?aR;]N=aQ>bQ@fT]I?^K@^IA\IC]GA]FEbNA\L=ZJ=]I>`H>ZCWC9Q>;R@BXF>WG;XE;]H=aK<_M6YH8VC8XC8XD7WB7UB7UC3T@4WA4XB4XB5XB4XB2Q>1U@-P:.L91Q?1UF,O>+O>(G7,G7,E6/D52H50I81L<5RA1Q?0P<.P;/O:4Q<4O=1J;2L>/H7,J92P=1K9/G54N:3J98Q@7TC6SC;YH;XG7XC7WB5W?7UA6Q>4L<,O>0Q?1QA/N;0N;.K8)L:/N>2N>.I81K;0M<*N:.O=.L<0L<-K9,O;3Q>,I7-H7/J:0M94T>7R?3S@;`LAiU<`L1R@5O<4OA5OA1P=/O;/P:0I7.J6-I9,L;.L<-J9.I9,K9,N;2M:4K;/I:4K;1K<0L=1N=1L9/I3-C45K:3N;/L9-J81H9/O<5S@1N;0K80J80I7)A/$:)&:,*>1.F5.J7.J;3N;2M8+G7/N>.P<0N?8TE9XE8]I8ZG=YH9[H6]G5VE?VFE]O>]NG_JAZHC_OA^MF`MIbKK`ME^JE_LA_MA^N@^OCaRBbR?`O<]IDaLLhSNfUIbPGbPJhUJfSOkX[jZaj[el[biXel[ns_lq^ejWgkXtr`wj„xmun}ti|te|tcwm]zn`†sk†sk…qi}jbqbYqf\oc‰vk‹yoŒ|p‹|p†wm†sk„rfˆwjŽ}p~r|t|u}vŠ|qŠ|npf|ja†rk‹yr‹xpˆwo€qh~riˆvj‹vkŒti’vp”zs’{rzoˆth„ogŒwo“}r”€s“‚w“‚v~s~sŒzoˆvjƒtl}uk}vi€wjumtlpirksg{m`pe…vlyl†qfwdYˆvk}r”p”}q–~q‘{lznŒxnƒmh€oc‰|o}p‘{pŽxlˆylƒwkƒthqep^Swg[‚rf„sesfxm_{qc‚sf„sf„qi€ldƒng„ph‡qjƒpinc„shŠ|q‹}q}q‘}rxn”u•„wrƒsh‚qj‹{oƒzi‚yi‡~nŠ|oŠvlŠzp†tj}i^€mbmc~le{f^wdY{k^€pd‚pcƒocmdƒqf†ti„sf}l_qaS~md€ne‚ogƒph…rg€mbmbzh]rbVrbVxj_qeqe{pcyratm^meVdZQcVOl_Xre^ugawjdtf_b^Unf]zjb‚odna‚pbƒof„pg€neuh]xl`ui‡vj‰ugˆugugƒxl„vl†smp`X{oe†{q‰s‹u‹}q‰}sˆ|sˆ{s‰yntcV{k_€siul„tm{mcqi[wlcth…ui‚qd„sf„sg†vf…wjvh\uj]ˆzmŠ}n}t~t‘t}rŽ}p†vin_X{rgykŒq~p‡}oŠ~rŠ|pˆ|p€uildWsna{sd~sfzpbqm_ol_ulbxj^sfYmbTwk]ndXi^Vb\Sa^Rrqdzue€xh‚td…yl‡{o€ug|qbseZjYRof[yjazhatg_qf[ufXwg]uh^j`WjaXwmdyqh}vlxvfto`wmcvj\qjXh_Tf]SmcWobWseXrbVk_UscZraXjXOo_VsbYlaWth^th^mbXnbYxlbyoe}qf~pe|nd{pewncuh_l^S}oc…ui…wk|pe}qeohlg{mfoi`jk^ld_nd`ma^nb`mc`dZYVNPdZXoa_k^[h[Zh\^qcduhisghuiivkiqfe`^]c`^lhgmheogdujgnjjmgeogdnc_ne_mf^jc_db\a`Vlg_oe`mgbpecib_][Xaa]eb^g`]eQ@fQ?fOAhQIq\BlVAjQ:_I6VA3P<4S@2TA.Q?,N<0O>6T@8VD8XD8]I=eO=jP=iP?hR9_K4VI1Q@1P=9WGdO@gQElV=`K4T@3O<9S?:TA:VA9VD3QA1N?3O@5Q?5T@6XA8^E=gKAfM9ZE5R>4P<4P;6SB5UD0UF6]L7\L7[K:`MeTChXHl]Hj[DjZDl]AiZ^K@_LA]JB[HEaMGcPA_K=\IBcN?aLC_I@[F[F<\H=aK<`J6XF2R>6WB:[G;\G8XE8XG7XD8XC7YC6ZD5YC7[E6YG1WB-S<2O=1P=.PA/P?-L<'D4*D5,E6-F70J7/I96UD9XG5UB5U>0O=2N:5O;6O=5M?3J=/H9/L=3R@4O<2M95R<7S;9V?8XA8YB=_H:ZE7WC<^H:_G6WB7UA/J9,K;2P?4QA2O0P=/L:.H8+F5.I64P<5P=3S@3XD=cN5WC/M:2Q=4PC4RB3R@2S>.M:3N?1M>.L0M90I7+F61I95O<1P<0M<1K;2N;4P=/K8.G5.F41H6,D2)A0)?1*B3,F5.J6.H:0L92M8/K;0L<4UB8UE;WD=[G;^H@`JC]K?]J=_K?\HBZIG^M@^LF^KF_LF`MLeSOdQPaONbOKbOFaNC`MC`QB_PLbRNdTOfTJ`MRfR]nYXjYOdSPgURkXUlZZp^bp_hn`npajn]orbxvgrsdil[kn[rsaxvgysgvnezqf|rdsf€pcƒre†slˆumƒqixe]j[Rpd[pdŒzoŽ|q{pŽ}qŒr‰vn‚pe„tgŽ}p~sŒzqŒzs‹zq‰{o„sg~ma~jbˆujŠulŠwm‹xnnd~oe‹zo‘|q•€t–w™‚z–w•€t‹xm…sjˆvm’~s•u‘‚v€t}r}r|p‰uj~ohwndyqd~rf~pgwlc€mf‡umˆwk†uj‰ym{r”~p‹vk{j^ˆvkŽ~q‘€r’s’~r‘}p}p|rˆrl}kcphˆvoŒsm†qj‚qi{nboc|k`yg\€mbƒqf…qdqdzm`{oaƒugŠyk‹xk‡vkˆvj‰wj‡tiˆwj‡sh…tiŠ|pŒ~r~r‘}r|r’u‘~tŠwmzha{ib…ui„xj{sc|rb„ui‰vn‡vn‡vl„pe‰ujˆtkng€mf{ha~nc€qfpe…rg„th†uj‡uj‡tkndvdYvi^zmdzlb~pf€ph{kazi]vdYr`UraVucXveYxj]thZlbRj_SlbXm_XuaZ~jc~kcngngubZbZQvlb€og‚od‚pe…ugˆsk†skmeyl_{oc€ui‡tiˆvi„vi€xjyn†vm‡tmq`Xvi_‚wm„ynƒwkƒvi~rgtk‚um‚qi€ofƒqguk€sk‡wpse[mdV~tjˆ{pˆxkŒ|o‹zmŠynˆzl‰{ouj^€uh†|oŠ~oŒ}s}t~rŠ{oŒ|pˆzlsf]zqgƒ{nŒ~qŠ|p„xmƒxlƒvj‚uhwk^si[sk^pfY|nbsh\ibThdYulbog€pesesg|ocvi`mdYd\P{tgxi„wkŠzm~q†wjrerdsdZaPIne[te]sd]qh_sj^rfYpd\ldYd`Uf`Wmh_pj`oi_kj[jfYmcZpeZpiXmdZoe\odZpdZreZnaVqe[vh_zi`yi_{jbxh`ymcymcvj`j_Tsg]ymc{ob~qc~qc{n_xp_vp_rj[h_S„yotk€wmxo{sezpf}lfo`[]VN\[Q`XTdYWj]]k_^g\]`UUf_`tiitgetgeymmylnzooznnymlxliuigqfb\ZYb_^gcbjeanfcogdea_f`\kb^la\ld]kd[kd_fd]jj`rldtkenhcpfdg`^a^Ydb^jgboid:]J;`L;`L>bN?gR>eP:^J7ZF5YE6ZF;`H7XD4Q=/J5-G5,G6-I<1M?6QA;VE4Q>2Q<5XD;bL:eN;gP;gQ1ZF0M@.M71N8:XF<`M:aJ8_I@fQEoXHoX=eL4W@3L;5M:;T@?XD=YF8SA/Li[CncDnc=h[=dU=cP;fP8bM>fSFm]OtgNtgEm^Dn_@k\?gX>cQ?aM>^M=]LAaQA`MB_LA\JFbNHfREeRCcPAdOCgPEcOEaMB]IA[G>WC@YE@]I=\G<]F;_H4T<2M;3M96O;6L:3K;5K=2J<1N>1S?3Q<4R;5V=7V<7W?7YA7[D7YE6VB8XE:\H6[E3WA6TB3N>/K:/J:0J:0J9/F7.F7/E3-H5.N;/M:2H71C1,D3-F5.H85P@3R@.O;1O<1M;,D4*A2*C/6O;7Q?0O<1T@4VD1Q=2N;4WA0QA/Q@6YE1U?.O=1M>-K<,L<2P=1M:/I3-H8-J9/N:/I74L;2L=3J@1M=6WA7ZA2Q>/H;1M<1J91K72R>3Q>4N>6P=6N<1J7/E3,B0.E3+F3-H5,G7+F6-I6/K74L>1K91L71K=7RCYG?WEF_IIfPGcOIaOGcOD`LA]IC]ID_KD_KE_JH`MLaPReSYfU]gVVgTReRJcOJeSHcPEbOTcRVeS[hVWdRbmYeo[dm^al\\k[aqa_o_^n^eo^ppbtpcrnawrc}tf{sgxqcvrcywe{xiusdundype€rf‰xkŒwjvjŒyqˆum‡tl€nep`Wtf]…tkŒyq{pŽ|qtŽs‹wl‚nc€la…qfŠvk‹wm…tm€pf…tk…ui†shˆrh‰vixlznxl…sg‚sfŠ{n’€u“€u•‚z•‚z“€w”ut‡vl€pgŠym}p‹}q‰znˆxl‹xmŽynŒvk„sl}sh|tgui~qfynf†slŽyq{s‘~r“t‘~s”~rŽym†qiˆumŽ~q€sr}pŽ}oŽ|p{q…ohye\|jaog…ne~i`yg^vi\pdƒpeˆrgŠti‰shŠth…rg€pd€pd‡xkŒzpzm‹yl‰xkˆxk…tg‡vj‹wloc„vj‰{o‹yn‰ui„rk‹wo†ujƒqg|iboh‡vl†xlugznb€pe‡um†tm‰vo‡ukŠvk‹vmˆsk‚ohxg`yib~ofqh‚ogƒsgƒsg„sjmd|hbr`XrdXwi]vg^xj`te\qbZueYvfZucXyf\}i^ka~o_tfWhZMk_Swg_|le„pf†qg„oe‰uk…qg}i^dYOxkbphƒsfƒthsf…rk‚ph€of}nbvh]sf‡ti…vj{tgurc{sgƒqh„ni{ia}ne€ri‚shqezm_wk_‚vl‚tm„sl†tn†umvmƒwm†wnue]vlb…zq‹~s‹{n‹|oŠznŠ|rˆzm„zmtj_{rh„{n…|n‰|s‰}s†yo†zm‰|p…uise^xne‚yn‚vk~ogtjayoe€si~of€pf‚sjri‚thƒrf{nacZPvqf|tjƒrk‚rj‚sjƒviƒthodrhZnfXvj€wjƒvmƒtjtkzna„xj€tfh]QdYOlcVre[qe]mg]le[mcWmdXf]Sg_UjbYld\mf\k`Xg_SneZxhbxhavk]vibwkcrf^re]oe[ne[ukaxlb{lcyja{kbrf\vk`xlbth^naXuh^xlb{mc|nb~pczn`wm]zq`mcVgZOg\R_SK[RKZRM`]MmeXre[l_X`VQ_[Vlbbshhoccrffh^]_UUoeexnnxllxllwllsiiofcmcboccl`^oc`la\ZXV`]\ea`kebqkgjd`c`Zd`[nhcpibsjcphald`ca[igarkfqgcpjdsgie__`[Yie`hc_d\V:[F;^H?cNAfP=bM=`M6VC3P=4Q>6R?7T>6Q=4L80H50H6-G5.F:6PB8RC7RB2N;1M9/Q>4XC6]G6^H3_I.WB-J7+I00M25U<;_HAiN@hTBlWFpYEoXDkR;bJ:WD6Q=5P;@[G@[H6TA/I:,H8-K80N;2Q<3Q<3UB5TB5PA5OB5PA8TE6VE3RA/QB6TE1O?7RD7YH>bP?bQ=cQ@fTAgViZ=fV9_O:^K9_J=cN?fTCo]KwiJvjHpaDn_Cn_En^FjXEdO<\J<^J@dOCfRCbPBaN@^KDdPFgRChQFkVEjVHjVEgREdOC`KB^JB]J>aI>^J@aL=aK:_I8`H<\I;]G<]H<]I7XD7WF8XE9XE:WD8VC5WC:_K:bP4]I2WB0O:4Q>.O>3M:1K9/I7-G5.H6,E40L80N<4TC4T@3S?6V@2N=0L92L97O=6P>5PB5P?0T@2VB3S>2R:2T=8U@1Q=4WD7XG4TE3RC6RC8VE5WB3T?9WD8SC6M>1G9/F7.E60F72G84G5.G5.K81M:3I72C2-E3/H71L<4P@4RA3P=2N;/J8+C4,@1/D14L86Q?5R?5WC>aM.N<5Q=,F1)C41N<4O<-E35L;3O>3I>.K:7ZC:_G3R@2OA6SB/I6-H43Q<3S?8SB:Q?9O=8N<0F4-B01E4+G52N;4P=4P=1M:4P=8PB2N;3P;1L==ZJA`L@[HE[HNeOKfPIbPMcREaME`LC]JC`IKfOKfOUfUScRVcQ]gVfl\fj[_jXXfTPcPNgSLeSLdRTbPZfT_hWcjYlq^mr_ppbnqbio`hqbdn^bl\kk`unbyobuk^{qdƒtf†sl…si…wjƒxk‚xk}ugxoa{pc…vkzpŽxlxlyrŒzrŒ|s„sjwf]ucZogˆunˆuk‰wl‡wk‚uf…qfƒoc„pe‹wlynŒxl†sk€me€of‰xoŽ{p‘|q|o{o‘{o‘{oŠxl†uhˆvkŽr’‚vv“‚xŒ{qŽ{o‹ynƒri~nd‡vjzm…vj}nb†thŽ|q|q”tŠzqƒxmyl‰|p…vlzoe‰vo‘~v–w”~v’€u~s‘}p|q‡rj„qi†vkŠ}p‹{n‡wk„ti‰wl‹yn…rf…pc…tg†uh†sf…qd{i]yl`…si‹wl‰uj‰tj‰uj‰vk‡ujƒpeoc„th‰wlŽwn‡sl…tj„rj„tj„ri‚pezj^qe„uh‚rf~laygaŠxoŠvk‡si„qi…sj‡vjˆym‚ug}oc~ncƒqjˆvn†um‡xl‡vkˆwkˆsk‚piyiasc\~of~ne€me}oc{m`~mc}kcyf_r]WubX|i_|j^}jbkYPq_V{k`pcmb~mb€mc€mbpb{k_m_SrcZ{ld‚qi‚shrf€qeƒtgrf{l_eVMxi`ƒri€pg€rfre~ne~mdnewg[xh\|mbobzk`qk]ola{sh†sk…pj‚phƒriri€odpe~pbznb…yl…xo†tn…rm†vm‚xn†zp…tjwh^zoe„xnˆ{p‹|p†vjˆzpˆzpˆzm€rfoeYtj_~tg€tf€sjxmbtja€vk„wk„th|mf~tjwm„wmsjne\}si€vl„ulˆwn‡vmƒulƒvi„thpgh^Ttlb‚xn…tm~qi~sksishqfnhXjeW}xj}wlzsj{rjxqfyrewoawo`b[MhdYncVl`VmcZgbYieYogZsg[ui\ui_pe[uj`ujbvd\i\Qwj`~ie|hcwh^vibyjcwg`sg^ukapk`vmb|qgzkbxi`uh^th^ui_xkare[l_Vre[re\vd^qa[o`WocZnbVi]Qo^S{i^vf]o\VhZSi\Xpi]vn_ul_tiae[Ve[[ncdoeeobcocccXW^UTj^^f\\h__h__e[[cYYe\Yj`_lbbqddrgela]ZXUhcbmefxnktlikeb_\Wfa\lhcrlgqjcnf_ha]b`Zfd^jc_mc`e`Zb[Z^VUd_\hb_ha\mda8VA9VB=[E;\E<]E9WB5P=1J62K64M68L75I66J70F4-D20H73L<6P@8TC3Q>0M:-I5,J9-M:/P<*M8)M9)L;+G4-J1*G-2Q97ZDAiQFq[Eq[?mVdR=bPBeT@hW@hV:cR:cQ:aO8]M:`K:aM;cQ@hXBk\Bj\EkZAk\Cp`FpaFjYBbP@aK>aJ@eN@dP@dOBcOBbOEfRDhREjUHnYIo[Io[KoZEjTCfPCeOAaK?cN?aK?_L?_M:_I8^H8\G8]F9]G=aK4WC3UD7YE9WD7TA6S@4UB6[G;aQ9bN5ZF3S>3R>0SA4N;0J8-H6/H62I71H65O93O:3R?3R?0P<5S@/N=/M:5R>7VA7VD6VE5VA3ZD1WA1S=2P<4U?4N@.K=3PB4RC.K=4NA5PB4P@0O<2S>9UB6Q@6M>/F7/F70G90F92G91G52K73N:3M86M94K70J8/J90L<6SC6SB3O<3L:1G60D51C50D25M95N<7TA<\I8\H7\HBeQ8_I1VC5XE3T?,J6-G:0M=0O?/O>1N<2L;+E1-F73N=2L:,C15L<4P@0I:2O=;_K8]J0SA5SC2O=0H6.G2/L73R>7S@7N<:P>7M;2H63H61H5/J:8S@9YD6Q>7Q?7P@9RC3P<3R=4UEBaRCcOEaMH_KThUQjWJcQK`RIbOL`NNbPKcOSiT_mYgl]ekZejYfhYkl]mm_dgW^eTXeSSfTRfSOcPYcS]cSbdUhhYom_pm^tm`pm_lm_jn_hm^fk]tla~of~mczk_zl`ƒrgˆsm‹wpŽzo‹yl‰yj…xjsfpd„tjˆvmŒzm|o‹xqŠxoqh}neucZubZ|jc‚og€lembueX{m`‹uiymŽwoyq’{p‘{oŒum‚meme‡vm|s}ozq{r{q{qŒwn‚pgnc…thŠznˆypƒri‚qgxlzoˆvm…tk|q‘}pŒzoƒrg…shŽ|q’v“ƒwŽ~u†|pŠ‚trŠzpsisg}t{t‘}uŒ{r†{m‹{o‰wnˆsk„pi‡ulŠznˆwj…rg~jbˆumŒzoŒ{n’ynzo‹znxm‹vjma|la†uiŠwm‡ui‡vj†vk‡xl„th€pczj^}k`od‡piƒohzjcxjb}ldmgpd~nbpd‚qf„sgnbsd\†vjŠvjŠvhˆui„tgŠymŠym†vh~o`yj_qg„smƒul‚uj‚ui„tgpe|har`XrbXzj_~lbyg[qeXqcWyl_}lb}lbmbƒoc‚od€nb}kcn\Svb\€oene|ld~neofphqcxg^iZRpd[}oe€sg}qe{odzodymbxlaqf[l]Syja|mc|mdzkcyj_|md}neneococpdtf}mcvi`qi_}si…tkƒpj‡um„ulri€pfƒrg{lbxk`…xm†zoˆwpˆuoƒtl‚xnƒxl„sgxf^vh`‚vl†ym€rf}oc{md}ri„rf}lbyja~oeƒti‚rfmgn`Xxnc‚xn…wl‡vl…tk„yl†{m‡xl„tkpe]xn‚wmƒvl‚ukri‚wnth‚sjylbh^TvlcrkypdvnevqgtmewndymbhaTjcWtnbumcqj`lg]fbXkfYrj\wm_rj\oh[xh\wh]rh_faXgdYpf]wm`xk_yk_te\wkawkawg]h]Pvj`}kfyhbwk`wlcymdwi`ug]qg\pk^tjari_vk`rf\l`Vne[td[p`Wn_Vn^UrcZuf]saWiXOl]U|og}ng„slqfƒrh„riƒrjxh`j]Tymd{pd}qcwj_aUPg[]kaaj_`k_^j]]dYWe]Xl`]nbbh`aldfg`_]TPqihpgiqeirgjpcci]Yc^]neesghtifrhejb`[WS^[Wfd_ie`nfbk`^c]Xc`\jgeogesjfuniuojunjqkgtlhrjhpfe>XD@YE=YA7T>5S94P82I53H46K56L43R=/N;-L9-J6/J:.J80L8*H3*G6)G7(B5-H5+F11M=2VE9aNCoWDqXAoW;iR;eP>fQ;`P6YF2T>0S=5XC3XB6Q>2O<-L93Q>2O<8T@5Y?7ZA6W?4V?4W?6]D9[I4UD2QB/M?0N?/PA2SB;^N?eS?eR=bPAdREjUCiT=dO:bP9`O?cT7fR4`M:`P;_O=]O?^PAfU=gV?k[@l\DhYEdUAcJ=`G1N>/L2M>4Q>4P=5P>4N;1H92I:1H90I:2I;1H;5O;4M95L99Q>8R>4P<4P=1N<.N=0O?2N<3N;6L:3F74F73F75I75N:5O=9VB8YF7\H8^J9aL3ZE4WE3VB2S<+I6,D8/L90M:-M<2N>2N=.I8/F75P?.I71F46O=1N?5Q=7TC4VG5XI.Q>2R?1M:/E20F23O97T@7Q?7N;8N<9N=8O=3L95L96Q@5P@6TA5XB9\KBcSCcOE`NOdSVjXUm[LdVNcVScU[eU_hYWhT`kZoq`tocuqcsp_nl[lj\ji\iiYeiX`iXZiWTeSQdQcfWddUgaTldWri^sj`ri\pj\nl^lm^lo`km_~of„og…ngzj^{k`„rg‚sn‡voŒznˆwk†xh…xiˆxi‚qd~md€oe„vi†vj…riof~ofof~lcjbog†sl‚ph~mb{k^qdŽym“}q•}u–v”~r‘{o”yp‰rk€leƒqj‰xnˆxkˆwnˆumŠumˆsk†rj~leƒmbˆuj‰ym‡wn~md‰vm•~s’~r‘|t’}u”€t•s‘~rynˆvj{p‘u€tŽ}t‹€s‹‚ttŠzn~qfypc€ri‡unˆvnti{sd‡{o‰zp‹xpŠumyp|q‘|oŒwl…pg‰umŽ}qŽ~o–{tzsŒzsŽxqŒvoƒogxh\oc‡uj…ui„vjui}rhzodxi`yh_zg^od‡qenbxj\vj^{naƒrgƒsg„rg…rh„qg‚pezk^naX„uhŒxiŠvg‡vfƒtf…tg†vf„tdo`wi\yk_{nh{ofvl_xn`|oa|k`|g^xeZzj]oc€na}j^ocXi]P~ocpc‚rd‚ra€rd€sfpd{ndpc[sf^of~nf{kcynd{ndzne€ogtd]eWOl_WrfZ{o`vj`ti_pdZuj`uj_sf\wi]~pd|lcqh}mdwf^zkbqg‚qh„tg†ui†tiviƒti~ldsh_{ogrf‚pjƒtl€tj€tjƒsi„si|mfvja…zn„wk†vl‚pi~oh|rhujpe{i`xjc€tj‚ui}oczk`se]slŠsi‡sh…rjŠwp‹xn‰vk†tlqb[wmc„yo‰ypŠvn‰wkˆyk†ykŠym…vkuia|ti€vmtj~sj{qg|sizqgzofrg\dZPrg_vg_niYheY`^Vliapjaqg^wj`|ndzmcymcyndog\hdYtma}oaob}m`yl`|k^~mcujac_Vc_Tsi_vpbvnaul_vk_wmdsj`neYd_Pni\mc[mb[mj\ulbsh^wh\qcWlbVneWqk`si_sg]nbXpe[ypf{kbykbwi`xh_{lc{lbyhZhYKwl^ui€sjpi}si‚ukƒvk‚tiwk_ndWpi~qe~qati\eXSl_`mccrherfdla]e[Wi`\pcaqfekbdjdee^[]TQmffneglafh]aobdcVTf]]nbbqbcpb`rfdh`]^XWfbalhgmigqhhrfeia]gd`qmkwpp}sowplsqitoitlgpgeoefnce=cI=cK>`L9YF7O>3J91K70H45M66M66K47K56L51J7.I6-K80L93O<4O<0K8/K81M:,K60L7/I6.H9/I9*F7(F6+F60H82L<4Q?;]H@gLGnSFqVYF8_H4YD1UC0RA/QA1S@0T@6YE;_K=bMlZ=cS9_N8^L9]L5ZH>bN>dP=iS:hT=iUAgUCdS?bO=aK>bL?gNCmU2VE4VE4TC1N>.J:2M<3XI9]O8^O5[J1VC0T@2R?0M9.J7+J74R>8Q?8UD;WE4O?1L3K86M78S;1O<0J;6N@3M;.H68N<7M:7M:9O<6L;8Q?;UC;WD>ZG:ZF2VD5VE5QB1L;/H8/I:3M=2N=.N;0P=/O?.I<.F9/E7-B4/G54L>5O@3R=7TC5SC1P>.M;6U?/L;/F64H85N<6SA4S@=L?9M=:T@;UA9O<9L;4U?=\FAZGDUD?OB9N>9S?=YE=\G@_LA]NGbTKdLRgSWmZWm^Xj[cl^`gValZ_n[]jZdm^swh~sg|sezrasq]jlYdjXjgWniZkjZagV]fU_cSoiZofXrg[peYylbwi_tf_od[qk^ql_yne|lfƒoh†ri…phk_~i^ƒmb‡wn‰xoˆum‡um†uk„uk…sh€nc}k_„oh‡skˆsk„rg|i`ld…riƒre‡wj‹wlŽynŽyn†tg‚pc‚qcˆvn{t~s~r|p{nyn‹vjmb{f^€me€md„ldƒmdˆsjŠulvmŽum‹wlŽyn“~sŒyn…thŠ{n—ƒx–‚x“‚v”‚x•‚z’w”wŽzr†skŠxp~uŒ{r‡{mˆ|s†zoˆxo‡ui}iZwh_pfˆvj‰xl…tjphˆwp|v{s“|t”s”t”}q‘}p†ui‚qhˆyp‹|u|r}q}qˆxm…sinc~g`{iaƒth‡tiƒqe{n`„rf„rhogneƒse…ufˆtiˆqe}j^ufU{o_ƒue…rj‡vi…uh‡vi„pgicwh^|mb‚rf…tiƒsfnaoc‚qdna{k_ug[th]xj^yj^xi]wfZ}k`kajble|ncpe„rf„m`sbZkZPnbƒqf…sf…rfƒqg‚qephyndmbZj`Wwi]wi]th[th[sg[sh\wi[udXs`TzcX|h]~la~obo`TqdZ~nenf~kd~nbnd‚od‚pgnfpdZri^{qg€qi‡vn‡un‚rk‚vj„wk{pbuk_{re|sf~tf|th{tkwqiwoh{qjthbzke„qk„qj‚qfyk^mdWzqdsg€tfug€uf„wh„thƒqf{k_vi]‚xn†vhˆxj‡xk‹|oŠzn‹znˆwnpbY{oe†|r‰~t‰|rƒxq…zo†zk‡zk‚vim`Xtlb|sgxoaqh[neYkdYsk^rfYwf]ze]~ib€jeyj[bZNdbWumd~qgqfqd}m_obrf|phke\tj^zoc€pepe}ocynbxnayobrh^e\SfbYmlbspcol^ok]qlatj`l`W^PL[NF`QHkZPr`Vp]Qh\Rrh^wlbvi]yk_zn`}nfykbvg^ocYvkaxqf}rd{rdzpfxmfylc|mdpeZg]R{rfui€tg€shuk~sitnsloe\rh^zle~mbuiZg_V]XSga\ofctjfrfboc`cXUe][nbdk__k__m``fZXi][qfdsgeqebqedkc`WPLi^`pefvhfzgezhcj_X_[Wqjgtlhsijshhndfb^]lfemhgqjiqjgmecea]]XWc[\g^`j_`lba@aJ?cK>^J:VC5M:2L81J62K73M84M85M47M77N87P=2N;1O<4M;5N<5O=1L:1L:/K82M92L81I61G80J9-F8*F7,G72J;3K;3O<5VB8_F?gMBlR@jQ@hS=dO:^I9ZE:XF6RA3P@4RB4Q@5SA9UC:VE6TB3UA2UB1UA7ZE:[G:WDC]K;`J9]H1SB3TB4UC2R?0R@5XC<_K;aM>gPfUgU6`M9`N8`N:bM=cO=hS@jU?hS>fQAhW?fT.I9.G72QA6UD4SB2O?0L;UD;VFA[K;VF5P@5O?1K;0K91O>5XD4YE5XD8YD3N=4P>/H6-C5-F6,G70J;1H98K<6L=4H63H5:Q<8S>7R>5O@6Q@3Q?5Q>/I90G81K92K9:Q?;Q>9N<7P<5O<9R@=XF>ZG9WE4Q@1TC3TC2P@3N>3N?5P@7RB3P=1P=1Q>2Q@-G9+C6.C50D63I76O?7QB7T?7TA2N=/K;,I54S>4T@3J86K99PB;UE8PA:J;8K;:S?:UA:S?=S@B\FC]HDWEJUFJVI?PB-G90H:2I:3K<4O>5RA9]F>dNAkRAkR@hQ=cM4TC8UE8UC>ZG=`K9]H5UD3SB5UC4TA5UD;]K?aM@eQ?gQgUiW=fS=eO=cM@bNAaM3_M2[H1VE4WF8^M>fU-M<1RA8ZI;^K:]I5UA.N8,F70D5/D62M=7TD8SC9UD>ZJ>YI;VF6RB6QA6OA5TD6ZI6[F:YD9V@=W?:T?4R?;ZI>^N>\O;cO9^M4TE5RB4R>1Q<0K=3K<6L=5P@2P?/I92G51G80F72I;2H;6G;9L<5H75H76L97O=7Q>3N>6Q@7S@6Q?2K:/D5.H67N<7RB7TD;WD6TA3Q>1Q>0P>/N=3J<1H:1H75L:8Q?7R@9VB9TB2N;0L:/I77Q>5ZA6Q<8N<;SA;RD8J>WA>WCBZGI^HI]JFXENYGQ]NEZHB]GGdLEcJEcJE_JKcQUiT^nZdqaeqaoseytgoqbfm`ZfYcnalthkncog]rh^sk^{oczpdymd€pcrdwn_ijYdfVhhYnb‚od‚odƒpe„pfmcyjasg]tj_zodrh‚qi€qhof‚phƒqi€mdmbƒqj„qj‡rk‰sm~ld}ld‹wlŽzoŽxmvnxp‹um‹xm„qhnf†sk‹znŒzm‰xqŠyqˆwoˆwnrf{k_xj\~napepe|kc‚qh‰vk‹wl‹ujŽwoŽtmŽtm‰uj„qg…uit“v˜„y”ƒx•‚w—‚w–‚w|q‹yn€t~r’‚vŽ~r…wo‚tkŒyq{t„ogˆwnˆvm…ujŠznƒvh†wn€x~u’}uŽ|t‘~ur~qŒzp‚ri‚ukŽ€wwvv}tŽ{tŒyq€meyh]ƒqf„rh…ogƒnf|h_‰vn‹vnxpynŒ{p{pzoŒuj‚nc„tg‡wj†tjˆvk‡um†ul…vmˆtl„ngxh^{i_ƒod}pd€th}qe{la€ne€kc|j_|j_~j_mbk`yf[sdWpd…pfƒodla}i_le}kd|jcvf_zjb}qf~mb~oc}oc€rf€qe~mawf^m[Tug^{lcznduj_sa[tc\ud[ud[ucXvdYxf^yh^xg^rcUk]Rqe„tg†vi†uhˆti‹wlŒvk†rgxg\wi]|pd|pe}pf}qd{na}nbri}phob[mdXtj`zndymcuibpf]~nd€pd~oc|l`~oc€pd|pbuk_lcZof\pi†umˆxlŠyn‡wn‹yr…rlzgbdZP}rh„ul‚ti‚vl‚wm‚ujsg€sgrf\wka€wl‡wmƒvl€ukulsiqgneyi_€qh‡ypˆxo„skg`S}sk€rm‚qm‚sjƒvirjri€rfrg[ndZ|tk€sfuftfqepe}pd‚qce]OkhZxqfzrgwqfwphwndqe}oaui[laSoh[tl_vk_rh\jbUmeXsg^uf]wh^se\ndZmdZvj]mcVlcVvlbxmcxlbzga€oe~qd}pbym_pcWuka}rhwka|mcxj`|lc|lcxj`vh_l]Twlb{rh|qdsk`yofyoeuj_dVI\PGj_UqhZul_tg[teYo_V~ne€me†sj‹xp†ul€sj†th{k_eXSaURrecshdoc^oe^j_[_UTk`ctfhsggsiiukjukgukhvmjzomwkinb`h][^USpiiljimhgsiimedc[]nddujjwikzljxljwmjtmiunjwmltkivllpeflkfkjhlhgjefjedg__BbI>]E9U?:Q?7M97N:7M:4M98Q=5N;1L70L57Q<6Q=5R>8WB4VC3WD3YE3YE2XE0T@6P<4N:5L:7N?5M=5M?3L>/H:3L>5P@6QA9VF8[GhT@lWAjTiS9gP9iS?iTEjU@eQbP:cQ=eRAjTDkW?hS3\G0P=1I76K96N;9R?9O<7P>5Q>6TA6UE4QA.K;/J83N>1O?3P@/P>.N=4VE:^K@fR;aM=^K4TA2M=1G75J;8TD:[J;YI9WGQ<7O:6R?8UF=]N=_P;bN9^J8YG9VF7VA3R=4N?5I;5J<7QA4Q?2N:8I86I99N>5I<5K=5J=9P>:O=8K:6I84L:5L:3O>6S?6R>6Q>4K92G72K85M96L96L:9P>5M=7R>6P<9Q>9YB:S>@S@>RA?QC@L@DM@HSBHXCFXCI\HL^KM`LJ^KEWEM[IPbPHaOJbMIcKHdKKeMNePUjWYoY`q`erbgscptexrcpm_jk^bi\hpclnclkamh[pg]vlb~qg‚ri„qh†ti…sh€rgok^gfXnh[}manc~nb~mbqd€pd}nateZue]|lcqfpc{nb}ncphƒsj†ul„rj‡tl‰umŒwoˆsk‚meng‹wkyn{pŽzrŒxoŠunˆvk„qgldƒphˆwjˆvj†qk†pi†rj‡sj…pg„pe…rd†sgˆshƒpeze]†qiŽzo|qŽzo•}vyq•|u{p‰xm†vjŽ~r“v”w’€u‘~t’~s”t|q‰wlˆxlŒ|pŒ|qˆxlof{md‹xp|tŽyqŽyq‹yqŒ|rŒ{oŠzm„ulŽ~w•‚z•ƒ{”~v•x’tr}r…ul~rh‹}t~u‹zq†vm…vm‰vo‰vn†skˆthŠvj‰uh‡sk‚nf~lcŒyqŽ{r‘}u|qŒ|p}r’{puk„pfre†ui‹xjˆuj„si€qh€rhmfkdwe^{j`…pc~rd}qeui]wkb…sjƒqh„rgƒqfƒod„pe‚nc~k_th_oe„qf‡qf„nc…pemgnh}kdwf^ug]{kbmb~laxi]wh\zk`|maze]vaY{h`|ia~kdxf_qaZsc\zi`zi`zh]}i_{h`{ja|kbwf]pbV~pd‡wj‡wj‡wj‡vkŠynˆvk†rgzi^qcWzncznb{obznbxl`ynb{oewk`re[rgZzma}qf|oeti^ph^odƒsg„th„th„th„th€rf}qfkbY{og‡zpŠzq‡zmŠ|pŠ|r†wp…qmzgbaYNyoe~tj|rh{rhyqgxnaxl`zmdqf[th^|oe‚qh{ndmdZwocvl…wmŠyp‰zpŠ|rŒ|s}s‡ukZTFum…vq…uq‡xp„vjƒum‚sjƒujvk_tk`{sjse‚ugtg~rf}rf~re|kbh\SlbYukbqi`kf_ig^ng]th\zk^yj\yl^zlaxi^|nbrdYdZNri\xkb}ndpg~ne}pgynd~qdreYpgZvkazmc|ne€ng€pepe€sfvj^g\Rrncxpfyoewodtkatkawlbwg^q`WbRJse[rh]pcXof[nh]icXpe[zk^xkbylc}sg~rfxk_o_Sne[wm‡yp‹|s‰|s„xm„wn†uhƒti]QMg\]wjhrfcshcnf_`YUbZXldcqdfqeeqggrgfib^ic`sjgujhuigrecrgeulivkkuonrkkwjjsdfi_arjktllxoo{sotnkqniqmlpllojkpijngikdgff_iidhdcd`^b]\c\YHgN?_F8XC8[F<]M9]L4[I2YG1UD3R@1P<4R=5Q>5P@2O>2N?3M@3N@3N@5QB8VF9XG;\J9^N;fUAo]Cn\?hT:aL5[E1TA4UC7YH3UD2TA3RA5T@;[F;]F3ZB4W@3TA8VF7XG9]H8]G:`K8^L:^M=`O:_J5XC9VF7XG9\KkWkS=iR=jUfR=hV:iV?kZ=kW=jU:eP;`L9\J6[H4YF4WD<_K>bN8^I:\H:\I;^K>aM=aM2WC0N;3K97O=7S>9U@0Q=0Q=1S?0T?7]K>fS>fTBhV@fT;_N5XE2O=5O=8WF<_M=`N;]L=_N;^M>cQ@dS=bQ@bP:O;7O<9TA7UD;\L<^M:^L8[F8WD:XD8WC6U@4M>6K<3H88Q?8TA6P<;M<:M<9O=8O>6O=;UC8T@:S@7N>3F82G75L:5P>6R?5Q=6P<3I73G63K86K83I58N<7P>8R@9QA9QA4L=/G80H:5L>6QB4O?4M=3L<8QA6P@6WC7UB5RB7UA7YE6\D=VD9TA:VD;XE:WB?\E=YF>YF@]FA[D>UB=TA=S>AS?EVDFYGDXEHVEQVGUZKT[HT]JXcNXcQTbPO_LO]KR_MRfRHdNL`MJ`KMcMRfPZlW_n\`p^ep_dn_hqbno`woaznatn`ml^ppcspcsmapk[pj]vlb|pg…tj†riƒsg‡ujthrk]jeWneX|jb|jcyi^yj^yk`zl_}l`yh\xg^md‚qe€oc}nb|l_~nc‡tlŠwoŠwoŽzqzp‘zqŽwn‰tk„qhˆti‹ynzoŒyqˆvm†tl‰uj„pf‚ldƒnfˆthˆuhld€mc†sjxmxmxlŒvmŒvmŒvk†qf|g^ƒpf{o|q~r’~v‘}u‘}u”~xŽzs…sl‡umŽzs{tŒ{o‡uj‡tj“|q’tŽzozp}r‹zoŠym‚qh~oeŒ{r|t”~vzr‘v€w|r|s…slˆvo‘€w“€w”}u“}t}qŒ|o‰xnˆum„vi|s}tŒzqqhohŠvoŠwoxp|r{oŒymyr†tk€ofˆxo{rŽzr|pŠynŒ{pxmŠum„qi|nbod†sf…re}lavg]zl_~jclfle„shŠvi†wiƒtgrd[xja„uk‡wk†ui„sfƒsg„rg…rhƒpgwh`yia€me‚nfƒpdnd€mgng}jbvd[vdY{k]~j_zg\saVsbW|lcxjanancƒof€lcld{g_qaXsd[zja|lc}lcziazic{icxh`uf]reY}pd†vhƒtg|rdsguhuiqexh\teY{ob{m`pcwi`obZznexl`zl_}m`~ocrf‚sgofoeZqg^€sg…wk„ui„ui†ui„th„sh}qef]Sxqf„{p…zm…{o„zn‚xn|ogve_lXQlcVvm_uj^wk`nf[oh^yma{ndznd|pf„tlƒrkˆtlpfi`T~zl†|n‡zm‰znŠ}qˆ|pŠ}pŒ}p‚peh]S†zpˆyo…vn‚wm€vl}sk}ri|qhrf\nd[ukcymaynczqfvmaxmaxk_yh_rf\qeYsf\od[id\c_Wnf\{mbob€ocobnfne}ofre\j^Twlbxmf{oe|lcofpg{oc€thpfYneXsh^ykb~ne{icwhaxk`maWgZRaTMmcYpd[tg]naZ^VMd_Vqe[n_Vo^UraXwh_vh_ui^kbYicZsnbyodpb}nf|pfymb{nb~nbk\Psmb‚{o†}oˆ|o†{pwm€vlƒug{jb_RPj_`ob`pabqgdkeadaZeb\jfbm`bpcckaae[[`YVkebunkvliwliyljzmlxmk~pqxomsmkymmn`_h_]nigohfmech`^kfdfc`ecbecchcdhccidcmhhmlfqnjqmlnggohflda8ZA:YA9U?9O<8J;7L;:P=9R=8S<6R:2L86O;2N98UA8[E:aI:\K7[J3VE1SB3P@5O?-P:4VA6VB5TD0Q@.P?0L?0N?3QB4SC9XH9ZI<[J9_O=i[DufFte@l]:aO5ZH4VE6XG9\L8\K7UB9VB;XD>_G;_E6]D5\C8ZD9YG:\K;`K@jPBhS>eS>cRAgU?cO:`H=YK8XG6ZI;aOlZ@nXjS?jS?jSDmY?iT=jT=kU3O=3L95M;3R>7WC;[F7]D3ZB4^G9cM;bL5\F6YE4WC/Q>.Q=2UB6YE5^M8dRdPeS>dO6aK2`K5^I5TB:P?:P>=VD>ZG:YF:\I>^M=^L;YF8UA8TA9WB9XC7TD:QA9O==P?;N==Q?9S>9V@9W?6V@9VB6N@1E87I;;P>6R@7S?5Q=4N;4I73F56L85K85K7/E6,C32H93H95O?7P@6K=:O@5K=6M=7XC6TC4QB8VE7YD6]C5R=7V>4U=3O88N;9N:9S@7YF6`L1\F2XE1RA3O@3O>9U@4U<:ZD7[F2TC1Q@0NkY:iV7`O5[K5ZJ;_K;aJ;aKiS@oY@q[>nX?lY>hV:gT=jW?l[An]=nZ@mZ3O<5P:3M;4N?4O@6T@3T>2T?5TA:XE@^L<`L5[H6YE4ZF3XD1W@4XB8ZD7bL;dPhW?gW?cR9]L6YH?bQ=bQ;bQ9\H9\H9^J?dO?fQ=eO9[L:^M:]J9YF:WC9TB=U@B]HC_K>\I>ZIB\L>[K=[J8UA8U>8S@:UA<\F8VA:WD=YF>ZG;WE6N;4M88Q=:S?9UA6U@3R?6R@8M>6J:5M;;WC:WA4P;6M<6H:0B50@44F86J;6O<:SA:S@:SA8Q>6N<=YFZG>]J@`L?_J@]GA^FE^JG_KLcKK_JI[JIZKU^KT]IaiU\fRVcNVeQcgYqm_skYohXjiZahY]cR]`PaaRdgTbiVakXWbTXdR^jUemVnm\vobsqcsobwobzqdtm`vnarbƒtc„tcƒpc€na€pc}rdvm_kaVujb|od{l_zhawj`ri`phZtg[xh]€j^„mbl_~k^weXxgZ}k`od„rg…shƒpiƒpg„qe€ne~og‚rkˆxoŠyn…vm„ti†uj‰wl‰tkmf~nf…rkŠuj„mekdˆsmˆwmˆxk|o|n’~r|q†tm‚qh†tl|t~u~uŒ{r‹zpŠzn‰yl‚sexj^ƒpiŠwpˆun„pj€ng…tmzryqvpyq–v“}r’}r‹vmˆum’v•„x’‚t’v}t~qŽ~qˆyn€tjƒwm‰zq{r‰wo‡vm‹zqŒyq‹yq‡tl†sk|u}uyn†sg†wkŽt‘s•€t™x˜„y˜ƒz•wŒyrsk†yqŠ{uŽ}tŒ{rŠ{n‡ym†woƒtkzkb|naqeqeriof€of‚qh†rkƒpi‚qe‚qe„rg…shod{h]}ld„rjˆtlŠumˆtl†si‡wh…tg}maxh\}lc‚oh{lcwi`xjavg^yg_}jawgX|i`ng†rg€la}ga€ng„si…tg„qd„oe„mf‡ng†pf}j_wg[wh`yke|je{kcvh\yj^zh_yf^qaTn^RugZwi]sfZmbWla\pb[tc[xe\vdX{k]|l\yj\vh\seZwm`€wiƒtf„sf†tg„re‚rere}laqeXxpb}qe~pe|sf{qb|pc€pg|ofqfYogY{te{tf{sfsobumcofqjzjbwi`zl`{nard}qiqk`|tjƒul‰um…tl‰ym‹yoŒxmŠymzk_ui]~sk€skri‚uk„vj†xm‚vm~pi]OGvja}sj€wouk|tf|se‡zl„tgmeuibri…ui{ncqhZicWvla}of~ld„oi‚qjqj‚ng|kdbUNxldrf‚ug„th‚rh€ti€tishzpcf^Vxqfxi~sd}shxsjzrgwsgqmbb]Ua[Rme]si`qjbjf^ie\qg_mbUtb[n^Vvi`{na€qd~mal^Sui^zqbzoarb‚rb}pc|pevmbldYh^Tri]ypa{lbykbxmewneznhvkci^Wod]ymd}lc~k`tn`xoayn`yl^n_UfYQtja{pf|leueanb\oeYygYvgZaVLh^Wpggnghnhgwmmg`]_\XlhcqhdphdoeclddaYY`YYe`[g^am_`ob^h^ZaYVi`_oabreavjfwhkuhkvihvmmxlkyljujhiea\^Yjigtoluniwlhrigsllmifidbhdcidcd`_ZTU7R?5P<3O;3P96L96N:9S>6Q=5R:4R:9P:8O<6P;5R>6WC5ZF1YB0TB3SB3QA5RA5UA7XA:]G:^J6YG2S@0Psc:{u?„ƒ7|}8le2^Q6YG>[FhS@gQBjQ@kUBpZAo[=jW>gU@jX?iX?kWAmY@nY:jW?mY9VB3O<0I82J94K:1K95P>4P>3O=0L;2P?3UC4YE5[G2UC6ZD3YC3XD2WD4UC7UC6[I9^K?bQ@eS?dQ=aN:]M;[J:[J<^M<_N8]L8XD:\H9]I:_K[L=]J;[F9VB8VA;XD:[F;\F>\I=[H=ZG:VE6O<2I68N;7P=7Q>5P=3N<4L<4I:4I:8R?YDZG>ZG>ZGA\IB^K=YG@[HD`MC`LD`KGaKKbMMaNN`KRbMSdOM^MN^MVbP\cRrsdjiZdhX^fUhiZup`vm[tl]mi[efYgdXgcUmeWnhZpl\oo]hk_agYbgTkmZuoa}qf|re}pdrf€rf|pcxm`zn`~rb‚re}m`|l_{ma{n_uk]oeYth\yl`{k_{h`vf]rf\xl_{l`l`ƒne‡qh…pflczg^yf]yg\od‚peƒqg„qiof„pdmd~nenf‚ri„si~md|k`ƒsf„re…pfˆrj„rh‰uj‹xk†pf‚ne…skŽyp‘|q“~r•s•t“~tŒ{r…tkqg‰xo‹zqŒ|r‹zq‰xn‡vl‡uj„sh}k^…qhwm‰tj…riƒqg„ujzs’}u‘{u’}u–x–ƒv—wzsŠwo|u’‚v‘u“~v}t|oˆyl„uk~ofƒsjˆvnˆvm‡tlqh‹yqŽ{r’u{sŽzr’}w’~vzqŠxn†wlŽt•‚x—‚x–‚z–„|•ƒ{”wŒyq~qhƒsk‡vnˆwo‡vn~ph|ph„ulƒsj~ne€qf„uiƒuh…tl€pgne‚qh„ri…rjƒth‚sh‚rf…thpe}lavlb~rh‚uk€qiri~qg„sf„sf|l`xh\xg^{jbyg_raXrcZte\xh_}la€oa…ri…rj…rfƒoc€jd{jb…vk†ui…tiƒoemfƒogƒnelawfZuc\xha{hbwe]qaVtdXvcYwb[q`Tp_TwfZyh]scWm\QhZSwga}lcmd}l`|ma€oanc|lapaXyma€uise†uh„sf‚resetezl`mcWpk^xpcxobvoasm_rj_wmdrh^ndXrj]yna{odul_lhZwnd„sj‡unƒri„sjƒsg‚reƒsfqipe[„yo‹zqzs{sŠ{oŒ|qŒ{o‰xmseYsgZ~sksi~rhri‚sj‚thqfueZj[Puf[xk`yncxmcqgZzoasfqeƒog…wn†vm…uirfqi^ni_xqf{pg€rhƒrk‚tl€sknfvf^dVN{ogtiug„uirg~rhsi€rgvh\h^Utm`yoazl^th_hb[qh]mdZibXi`XmbYtg_vf\f\RUMDld[{nd‚pe}lb€of€qhsi‚sipeg\Srh^ypdypb~rd|o`zmawlasi_j`WofZsk]rk`qh]sj`pk`nh_qg^ne\g`Vkc[rh_ug^teYmcYnbWwh[yk^vf\yi`‚vm‚wlphyketha|tg„sfsgj^Vh]YofgmcepggncbaYWZVRhd`ofbld`kb`iaajaaldbogcpghxiiuiei`\^XWodgriiukhuljukmsjmvnmunpvklxkmtjhjfddeaggfifeldcka_g_^d^_g`\d_Za\Yda_kgejgd4Q?8VB4R>1N:4M95O:8Q=;T@:S>7P=:N96O<2R=1S>7VC7TB2V@3UC4TC5UE7WE9ZE9\H7[G:_K;bM8ZD2S>3O<4P<5O=5R>3S@2XD3ZJ8dS9pf6yx7€„9ƒ†9tm/_R6[E=[B:XB7ZJ;bR>cS8\K6XG:XH;YH:_I;^H<`J>`M:aL>fQBfRCgVBk]ExkP†|>rj5^S6^PdS=bQAgSAhS>eQiR@gPAiRBnWAqZAlZ.G8.C60E81I93M85O:4N=1J=5K=2O@4YH1XH-RB+K=1S;2WA5XD5XD5SC3PA7SE6RB:TD;XF:WE5U@5UB;XH=ZJ=\K?_N8ZJ9XD;^I<_K=aP>cS:_O;[J7XG9\H;^J<\I;YF9UA?ZH6N<9M<7K:8N<9Q?8P=7N<4K;7L=8S@;XDA[D?XDAYG>VC@XD;T>AU@=S=?WC>VD8N=6L=4M;3J;2F9.F75N=:UB=WE?YG@ZHA[IAZI?YG?[HA\JD^LIbPI_MI]LH]JH]JJ`LJ`LNbOSfTYePZeQbjV`gVV`NVaQYfTgk[xrc|sewo`mk[nhWyo^{m_{m_pi[ki]sj`ylb{ja~ma~oc}pduoenj_mi\qk\zoc€pg„qi‚pgƒrh„si}mdtg]sk]}pc€oe~mdyh_wi^{o`zn`wl^wk_}nama€ldyg_ud\zk^od„peƒpi…rjƒphƒohnfxe^xf[}k`€ncodld}kc}k`~laldne‚og€mf}k`{h]na†reˆrg‹uj‹vkŠwkŒylˆuhƒqg…slŽwo’}q’~q‘r~qŽ{sŒzq„rj}kb„qi‰vnŠwoˆwnpg€pfŠwnŒwlŒvjxnxnwl‹vk…si„tiŽxp“w’~w‘~v”x“‚u“~v‘|uŠto†tlŽzs|pŽxq„qg…uh…uh†vk…tjŠvnŠum‹unŠwprh†xo’~s˜ƒx”w”~w”}x’|v|tŠyq…vm‰yqv’€x~wŠ}t‰{rŒxp‰wk}obƒph‡tl‡tm†tmyjdylf…sj‰woˆvnˆvn‰vlŠxlˆvn„sjne€of…tk†ulƒui‚th€qeqe‚rf}matk^ynb|pd{mbuk^sj]€pdpdmbld|lc}nd~jbwe\o`Wwh_yka€oeƒsf…tk…ri…th…rfvaZte[rj„th‚rf~md}jb|kb}lc{i^ubZuc[|g`|h_vaZm^QweZ~k`}i]{g^yf^|iajai`zbZo^Wzgame‚qh~nb}ocqeƒrj|jcn]Wte^qg€sf„vj}nb}oc~pdxnavi\kbUleXti]wk_kdVf^Tne\tg_yjd~qhsi‚rfqfzobtl^xpc†vj‡vm†ul†vk‡wk‡wk†viogui_ƒxnˆ{rŒ}t‹~uˆ|pˆym†wkrfi\OrfY{oe~rh}qgvj`wkb~qgnc€nc€nc„rg†ujƒthphwi^‚th‡xlˆvl‡tl„wk‡ymˆym†znmf\nh`xsh~tj~ti~rk~skyriqfzkah\Rvka}pf€qg}qeymaxlbti_tdZtbWlaTum_xl]xi\oaYd\Upf[tkayncync|mdnd{l]i_QXPFvlc€riƒrgƒqf‚pg~og~rh|ogxi`h\Ttiavlbwmbvlbtk]vi^ui^ndZf\RlcWmeWlg\lbYj`VgaWkdXkaVmdWrg_siaynezlbzk_gZStc[€og…sh„uh…tk†xn‡yluiwldzof{uf‚ti}qid[Ve[Zj_`l^`rfdob`cZW\XUolhsjgqjjvnnsjjwmmxmmwkkqjirgdrgc`YTga`rhjtiloihqjipgjldhlgfpjkqgirfhndffbaffeihhjffmefmeef`_b`^oebqidnidnjepokdd`4R?6SC1R?-O94L96P;8Q=;Q;5R=0T=4XB8WD7TB5UA6VE6VE5UD8WF9ZE7ZG5YE7]G8\F9[F6V@5N=6Q?8V@7W?2UA2WC1XH2]N=qj8xx0uv.pp6f^0ZK5XB8Y@5[E2[J8^N7]K8\K7YH;ZH>\I9_I9^H;_I<_K?cO=cOBeRBeTDn`EwlN„{I|ufUBgTAgS=dO=dP>eP@iT>jS>hR>eO@gSAmXApZCm[=eS;aO?gQ?iTAlWBnWCpY>mW8hQ9fS;fS?gUCkUBhR@dL>^I:YD8RA6H96G:8K>4L=3G8/G:4K;4N95N:5N>3L@5K=5PA4WG0VF-PA.K<.O:3U@2UA2SC2P@3M?4K=4J;3I:8O<9RA7S?5S@?[IE_OC^N>[L5WG:ZF<\H=`L>`O>bR=bS>_N:[J:\I:\H9YF7UB9XD;P@8QB9SA:UB=WA@YE=WD?YGA\H?[D@XB;S??XC=UC9N?:M>8L=:M>6I::M>=TA=XCB]HC]IFaMGbNIdOC^JF`LIaNOeQSfSUfSSbPO_MQ_NXfTYfTYgU\iWeiWklYpn_mk[`bR_eTdiYpo_zqc€qdƒtf{ob|q`~pb‚qdqezobrk^xlc€ph†phˆqi‰ti…thynfyogsj]pdXzk_€pfqg~ofxlcwkauj`vi_ulb}pg‚qhqg~ndwi^|l_}pb|oa{n`€ocnfld€ldyf^|j_mb‡sgƒqh‚qhog„qi€me{havdX~lambod{h`yf^€ncodoc‚nf‚ogngmc~j_€ka‚nc‡rgŠti‹uj‹vj‹xk‡vj†sj„pi„rj‹yoŽ}qŒ}q†xm…vl‡tl†sk„qi‡tl‰vnŠvoˆylpi}ng†tmŽzq”}q‘~q’r“}qznŠxk„se‡rj”~v’x‘~v~s}p{p{t‰smŠtoŒzrŽ{sxpmc„sfˆylŠxoŽzrzr{szrŒzq‚riƒvl’v’€u“€x‘w}v|u|s‹{rri‚sj‡vnŠyp…vn{phsj‹zqŠxm…vkˆumŠwo‹xp‡unzjcwjc„rg{qŒyr‹xp‹xp‹xp‰xo…tk~md~mdƒqi‡ul‚thqe}oc|nboc|l`yj_pdoc{j^vg[vh\}nb‚qe‚og‚og‚qh€ti‚me{h`ud[uf]|kbpf…uh„sk„qi„tg‚qdo\Tug[}ne~me|kczi`wg[xj^|kb{h`{h`lal`€kcyf]n[U~ob†sg‚pbld}ja€menf‚ld}e]taYzh`€ofne~md~mdnenfzhaq^Wp_Wwh_oc€qexj^xj^vj^vi]yh]zmaqeƒqe|j^reYmaZvka{ka€oeƒqi„rk…tiƒsh|pcjdWvnaƒvk‡vl…tl…ui…vj…ui…ui}ofrj_yrgƒyo€vl~vm}pc€th}qevj^seX|ma~qg€uj~rhwkaxlb„vm…vh‡wj‡xkˆykŠylŠyl‚qgyi`„xn‰zr‰yp‡vm…znˆ{o‰{oƒxlkcYkg^{si~si|rhvkctkbulbuj_j]Qj\Pvg\|md|ldwk_pdY{oe}pf€qgod|pe{re~pe~mapbZh`Wwmbxlb|md~of~pg}pe{p`mfX[XMpl`{tjuh€qf}pg}rhzogymese^eZRsh_nc[pf[mbXj`Wth\ui^pcYk`VoeZqhZqe]te\hXPkbUtj]zk^yj^yj_~ng€oh‚ph~i_dVQwib€of‚qiph€qi†vm…xksgrh`wnd|teshwkf^TQf^^nbbqcdrfdrdbdYWc_\lifsjgummqiioeerggocbpeeohhmc`j`\^[Vfbandgrdiuiisihj^bj_bofflfhqgirhinefd__gdchhimhinghldee`_da_lgaid^hb^ea[YXTRVQ4P@6TD3S?1Q;6P98S;8T?8T?9WB9WC9XA5T@2T?3WB6XE7WC8XC8YG8YI<[K=[I>[G:\H:\G8[D5XB7TB5P?4O?7Q?9X@8[C3WC0TC2WF6]N>mdCwu9oi0bV3YJ4XH3VC4UB2VD3ZG6[H5ZH8\G:]H>_K@`L:_I9\G9YF=]J=`M<^N;`L=aOBjZ?n_ArfBnd?cY<`S?dS@eS?fT@hWBgVAgV?dS>eS=fR>fSlZCl\;bR:bP9cN;fQ>lUApYCq[?nX;iS:fOAjTClYFoYFnUAiO>bK=`K8U@6J84E75I:1H92H82M<4N?2M=/H93M=4N=2K<4N@4SC2QB1N?.L<0N<.M<0P>/O>0K_N;]M9[H7ZF8VC;VC:VE:TC9SA:SA:T@;WB8S?7T?:YD<]H9^I7\I7U@;O=;O==SABV@;Q>:O@:QB=UD;TBRC?QCBVGD]IC`HIaNLdPPgTRjVOgSLcPNeQSgUZkX_lZdl[el[]iU`kXfm\gn]fm^dl\nn[so^zpcwl_kdUmkZvnbxqdzqe|pc…ui‰vk†ui†th‰uj‡wk}sdslZrla~si„riŠwk‰vl‡uh€riqhxkavg[xk_{oa|mdxkauj`tj`{nd|nd~pf€qh…tj„th€pc{m`|j`}ncpd~ob€ne„nh€meme{g_yfZ{i^ma€pf}mc}mb‚rhnd}ja~lambod~layf^wd\ne‚pe…qf‡rg…qi„pi„qh‚of}ib€kd…qh‰ul‰sjˆtj†th…sh†sjƒmg„rj‰wnŒ|pzp‡ulƒrjˆtl†tl‡tlŒyqzr‹xpŠznqiylfrj}t“€sŽsŽ}r}r’~sŒxnwcX„leyqxr‹xo…ri‰xk|p‘}rŽxrzr‘|u‘}txq„pgƒsfˆxkŒxo’|t~rŽ|pŽ{pŽ}q„uh|ocˆwpŽ}u|s‡wn‡wlˆxnŠyoˆwmzi^…tjŠxnˆvl…skxkatj{r{s{sŒ{pŒzq‹xoˆvlƒsiyla„uiŽ€s‰{p‰yp‡wn†wmŠwo†sk}lczi_~neqh€qezk_|l`~manb~mboc‚pe€mbzi^xh\uh\{ld€ne„og„qi‚ri~qg‚ng}kbtcZvd\}kcnfod}kd}lbob{j[vbZyi\{i_~md€nezi_xg\~nb€oenf€ldƒoc‚oamazi^ud[}obƒsgqb€kb~ld}oeoemd~iat`Wwf\|kbzi`zf_zd^|kbyg_yg`we]wg]~m`ncnbtfYvh\xj^yj^€pd€rf„tgˆsh„pe{k_oe[ymb}pcqdrhƒum€sjqizqdgdWsob~ugtg€sg‚uirf}pd}pdzlculb|titk€riti_vfZqfrf}qdƒsgƒqfsfƒsj‚vlui_zne„xo‡zo‰}q‰}q‡{o‡ym‹yn~ocre\†zrƒwoul‚ui|tkuk‚uiznbldXlf\vi_{mdth^nbZl`Xvjbwmd}nczm`rf‚ug~pfzk^ug\~rhuk‚tjƒsg€umzqh}pf|laobVlgZvlbxlbyndzpc{sfyqdyocme[\[Pa`Vpk`wnaulbtkbri`skbqf_obYrg]ug^uh^obXdYOf]Swl`ykaxi`vi_wlavn`wg`xd^l\Rti]vn_ym]xl^xl`}pfqi€qh{j`eYSzph{og{nf~rktn‚sk€thujbk`Zthaxnayjal`[`XVf`_lc`nb^ma^l_]`WT_ZWd^]k__obdncdf[Z^VTeYZm`cjcdkbahb]`^Ygecqgirgjwmlphff^_h_aoheoiimghoggg`__\Yca^daae__kbdi``b^Zfe_gd^hb^ldaha`a^\^`\3N>3P?6U@3T<8R;8U=:VA7VA7WD9\H9^G5YD4U@5VA5XE3YE<^I=_L>`OBaPC`OF`L>_J>`H=^F8WB4O>5M?7O@7Q?8W@3W@3XC/TB1SD0TE4\Q6aZ9aWfQgN;cJ5M>4N?4N>/L<,I9*H8+I8.J;/I8-E2,A0+=,3G86N?7RD:[F8VD6RB9UE?]N>_P6Q>;SC6VB5R>1L85L88N;;R?=Q=9O=8O?:QC?WF8T=8WA8ZD9\F:`J9aK9`I7[F8WF:XH>YJ7\K=bP?cR@cR@aP@aQ=_K<`K8_G6\C5W?3S=3SC5Q>6S;7U<3U?/S?5SC3RA8YG;^M:`N7\K7WH7YH6ZG2WD3WC5YG7\G8]F9[E>_J@eM@iOB`M?\H?\H?^Im[@m\Dk]AgXAgUAgU@gV>hX7gT;gU;hT;mY=o[@n[Bo^Gr`JtbDn\?lW;iS:lV;jSAkWAhR=dN;dN2S=3N>/J;,I:1J=3K>3I2I;;SDD[K:VF6RA8R@:VC:YF5WC7WG:ZH7WC7VA9RA8N?5K>8N>9O<WEcN>gMaN>aM<_J;_H8_F=aH<^G7UA4RB5R?6Q;8U=4T>4VC7ZE8ZF7ZF9\H;_L7ZI4UE4WD6XE5[F6\G8_K8aK9`J;`JdKbM>aK;^K:]L=]I>bNlX>hZ@iY?fT;SA;TA=XE;XD:ZI;[I<]I:YE:UC7O@4K<3I98M::O<>S@;TB7R>4P<4O<6RA6P@2N?8P>9P?6I<6H;:J=?OA:O=9M<9K:9K:7L;7M;7P=9S?8R>=[D8X?3T@5YC;`J`J:[G=`K?dOhW>hV=gU=fTiU=lU@lW?jU?hSBkTCiSBiS@dN7ZG5UE;]M5OB1J<2I;.I8,F6/F71H93I:3H91G5+A2*D4+E5.I6.G30A11C24F46I:4I;2I;.A4,>10B52E66G98I:8N:\I>YG7P;7Q=5N<3K=5K<8M?:O?8O<;N?9L=;M?@QC;R@=Q??RA>RA;S@SC?R??R@@S@BUBM\KMZJIVJETEBR@BVCEZGBXFM`KPcOUgU`o]dsbcrajobkpcoocll`mnbnobpp`wrcxretobvobƒvjŠym{o”|p•r{o‰{o€rg€pc„uhŠxmŽ|qŽzoxqŒwo‰tm†rg€mb„qe…th‚sgqeyl`rh[vm_}pfqd‚rd‰rk†rk‚qdxl`xh`yi_€oc‚sd€ri„sf‚pend|kcvh_xlc{nf{lexiazi`{ja}lc~la~la}k`|j_wd]t`Z{h`…qi†sk…qj†si…sh†tk†sk‚of{i`xi_xkb}m`qe|l`{k_ƒnc„ldƒmb‡rf‡sh†ti„th|ncqeˆvnŠuouovnwkŽxmxmˆti‚pf…sk†tm„th†vk…sk‰xo‰vn†qi„qe…sh…sh†tjof}lc‡qi„qf…qe‰shymxl‹{r„sj~md…rj}s‘~s|rŒ{p{p{pˆvk~mb„qe‹wlˆti„rjof‡tlŠwoŠxlŠylzm‘}p’{syq‹ulˆwk{pt~u}v}rŽ}sŽ{v‰wo„uhuk}t‰ypŠxp„sl‚rkˆqj…qh‚mf…sj‰vnŒzo†skod€se†zl‹zpxp‡viˆwk†uj€qiylcylc‚qe„rh‚phtkƒskƒun€rj|ndzk^|l_€nb€mbti\kdXpj\xja|jbzi`}lcleƒnf}iave\wg^ƒqf…rj†sk‡slˆtl„qjƒqgma|j_‚pe‚pe€odke{ibzhavg_wf]wf]|i`lak`zf[r^Wwd^|l`}mbofpgpg‚qh‚pewe[tbVmb~lamb}kcld~kc}l`{h^xg\{n`‚sgqe€rf~pf|oepd~pduh\wl`zma{lazldi_Wnd\ngoeoc|ri„vj†vf„ue|qee]T|rh†xo†vmˆvm…ulƒukƒwiuhzncymc~rg~rf|rhyoe{pg~rhzkazg_yhazkbzmcznaqh[kdV|oe{oe}qgsiƒtk†woˆznƒwlodZ~tk†xmˆxk‰xoƒyoƒyo…xo…ulobXwmdvntlvlxlzug|siuk{maud[yia~ohzoesi^rh]yoe‚ulpfri€viwf‰yjsfsh^lf]xpdrf~pc|od}qf~scrduk\lfYqm_xob~ph}ph{pfzoczmazlaj\Vi_Vvnesnetodrl`id\mi_mh]ibWiaSh`Rrd[mcYld[f`WhcYkh]kf]rkbwkcvkcukbvoesd_sf]zncznd~qgzma{lb‚ri„thug[oeWwp`|riwltj|uj{ukznd|mdg[UaXTcZ[i]]j^[hZZ[TT_[Zmddqeerggrjjtiiukksllullvkkzhkpcdg][ogcqjdtmfqkjlgfba\db^lfbocbpe_shduignddoiiokitnjvjishhgackggrnkvoltnkpkheb_fbbljh:UA9T@8S?7S?:YA9YA6WB7XC:^H=bK9_F:bG]H>]H:]H9`GYFaI<\H>^M@_JAcOAeQ>cN<_N=aO>eSCiVEnYBqZ@rZ?mV=jY;hW@jYCkY?iW>iT;hUAiW?hVfS?gU>gS@jUBkVAkV?kVBmVGqZDnVAdS<]M8XI?_P;]L9\K4ZI2WD7ZF@dNFkU:]H4VE4VE0RA0O>0L<0K:2I;.E6/F70G84J;5J:5H6.E4,C4/I91I61G32D12C05H96H94H91F70A40A4/@23D65F89J;9N8:O9[I>YF;N?9N=7M;>P>=Q>5J87K<;L?P?@SBCVGDWHBZGBXFBUDBUDE\IBXFA[KA\IC_KD^JAZGBVFEVBDUCEUCM\JXcRZcRV]QNWHDRACVCI]KG\JL^JScNYdR`iYin`prconbmlamnbjl`kk_nnbwqc€tg…wkuh~sh†um{o‘}q“~s’~s~r‹~p‰xl‚qfƒpf‡uk‰wkˆwl…tkqhƒri„tjƒthpd„th„thqeyj^ug[|m`‡rjŠwk‹uh‰rlˆsk†sf€qevf^we]zj]}qa|oc}na}k`~lb}jbxh`yha{nf}nfxg`xg^xh_{kalbodna~la}jb{h`}j`oe€meƒpgƒph…rk„sj„phƒph}jb|jb~md‚qeqezja{j_ƒncŠqgŠui‰ti‰wl‰xmˆxl€pd€ph‰wn|sŽwo‘zoŽxlyn‹xk†sfyh[of„qj…qi‚pgpg‡vmˆwm‹vk†rf‰uj‰uj…si‚ng€nfŠtlwlŽwiyj‘yl‘zoŒ|pˆwmyh`ƒph‡tlŠwo„thncƒqf†tjˆvk‡uj‹wlynŽyq†sk„qiˆum‰yoŒyo}p’r’~t’}u’{uŽyo‰tiŠymŽt‹{t‹|r~q‹{qˆup„qjqe‡tmypŒyn‹wl†rk‡snwqŒvpŒwoxpŽ|rŽ|qˆxoqg~qbŠyl|r‹xq‹zm†ujƒsgqh|leyja~maqf~of|ndwkb}phsi€rg€pc„tg„rf„pf|qdnhZfbTsg]{kbnepg‚og‚me€kczf^ve\od…si†sk„qile‚oh‚pf€nbweZ|i^nc~lbzc_r]Vyg`og~ndnf‚og„of†od€j`{f^}icne€ofpg„sjƒshqd‚petbWp^S~la~lb}k_|iczi`yi`xi\{k_yh[|k_€qe}oc{ldvka~pg‚qeqe}oc€rfsgƒsf~ogrh_vld‚tj…sg„tg‚ul…uj†wg„wg~rfg\T{qg…xo…vmƒtkpgsi~rezncsf\sg\yma~qdvkapf\si_ukqh…rj‚ngƒogƒqi‚rfqbWtg[}qh~qgsi‚uk‡xo†yo†~q}uiulb{rhvkvjƒul~vl{sisi|mdobXthawldzpfypeoi^ki]}sivisgqe‚qjrk~tixndqi_}si…xn‰zpˆzq…{m‡~m‹|k‡zkwndmj^|th~sfpd|pezog{ud{tbrj[ffWom_xqdypfumcni^qlbslbph\laYmc[oh_qj`jdYd^Tjb[vmexnd{pezm`|n`€oc|meqf^i_Wslbrj]qiavlcwjbyldvjbqh_laYsh`vkcska{rfwodwmgvjdh[Ug\Tpg]ypezpg|oevlbieYmg\vk`sc]k_Xk`]f_\i^^m_`h\\YSSfcasllvjjujjsijojinkhqhgshgqeen^al_`i`]j`\skerkdrlinlh___ca`pkkvml{qjypk{rnyqnzrsyqr{qmzmmshhicbnjgslgrlgohdhb`a^Za^[ged8S?:UA;XC9VA:W@:YA6S>2R=7WB8XD8YC8[D9`I;bH;aH=aI=]K;[H8ZF:]G;aH9aG;bM;cK9cI8aG8^F7\G=[H<[H=]G;]H:]G:^G:\K9\K4WC3UB3V@2T>4UD8[F=`J:`I5[F7_I;bLdNcK?cL?aMAaN@eOAgQBgR=dOP@=Q@;Q?P?=P>>S?@TBCWFDXKCZI@WEDYGEYHE[JC\ICZLD]LC^JA[GCZGDXFEVEFVEHWFT_M[dTfkZcgZZaRNZGIYFL^KO`NP`MVbO[cRhhWro^zrbzodoi]pnanobij]nm`vi‡xl‹{o‰xo„ul‡tlŠyoŒzq’~t}rŒ|oŠ|o†ti†sjng„sk…wj…wiƒukph€pg…ul…um…ukŠtjˆtj†ui€oc}m`l`‰slŠwlˆwj‰vnˆuk‡tf€pdyf`tb[wj]zo_|pdvi]zi_€mdmemc€ncoh€nf{i_wf\zj_pcld€ncna~m_~la~kb~lazh]{h_~kcnf‚of|hame†phˆrj„og‚og…sh„ri}lb{ja‚pd‹vixmŠwl‰xl‰znŠxm†th|mdƒph‰tm‹wm‰wk†sgˆtlŠwk†tel]‡rh‹snˆsj€me}md„shŒxmŽwmŽxlŽymzo‹vo†rj‚nh…qj‹wn‘{lwiŒvkŠtk‡vjˆvj{i`me„qi†qi}kcxf^nfŒxpŠwo‰voxo‘|u’}uzrˆum…si‰yp|r~s‘~r|r}sŽ|vŠwo„pf‡uj‹yq‰xq…{p€tgsi†toˆuo‰ylŒwp‘{q’}p{o‰vm‹wqŽ{u{uzr{s€t~q‰{rrh|pbƒvhˆxm†vm„uj‚rg€oe€nfncmc€ocƒsiofxmcsi`zpgƒsiƒuh‡wi‡wi†ui…tirfngZ`\Nqg^~oeƒri~of€ofldme{g`tbZ€l`ƒoc‚og~jcyf_mf…qf†rg„pe†rg‡shƒpd€jct`Y|kcpg„rh†skƒqi…si†sh†rg}ka|ib‚qh‚qg‚qh‚rh~pd|nb~k`raUp^S{i^|j_yg\vb\sbYzkb}nd„sgod„rf„sgƒrh}mcwi_~pg„sk‚qhƒrgƒsgqe‚sfƒrjwlcwnfvl„ui„wh€qiti~td|rauk_od\xobsfrezlauh^wka}pd€qg€pg…ulƒtg…thƒsfseZxi`uk„tj„sgƒpf…rh‡ukƒqivf]xh`~rh€si€uk‚wm‚xn€ul‚zkxodnbYui`|pe|pbzlend[jaYug]ud[zkb|md~od}qevl]b\Qtpe†zr‡yn†wl†wk†xn„xo…yn|qhsla}uk…{q‰|s‡|q‚zl†|nŠ{n‚wkqnbrmc{tf}sgzpd{rixqgvodtl_ngYifWrl_wlbtj_ne\faZebZlg]ph^ujbrh_vlcvlcpe]e[Rsja{qh}pfqeqdpcrd{odnc]lc[tkbui]tj`vncwpdsk`qh^qe[lbYof\shbukcujbodZh^[YPKcZRqh^wma|pe|pf|nfukc[UMnh]~tg{kdk`Yi_[g`^i_^i[]dZYZVVb`_kdcnccmaah_[eb_dc_mebxkhulixjkvkkulkwpoxqnzpnxsopmj\][eeeronvpoxomsliqkirmjvnovknvllwiithhoheoicskdtjfohcjea_YWca]ggb5P<7T>[B=ZC9V>7S?4P<6Q>7S?9S?;YD9\G9`I>`J?_J=]L:ZJ:ZH9]G<`IhQ?jS@iPBiQ?lU;hM>iN?gOhS8eO:eQsX@s]@nZ>mWlV>pWCs\AqX>hU9_N7WE1N<-H9-H92F:6L<7Q>:[C?eN:cL7XI6VE4PA5M;7J7:G83G63H66K98M:6L93N76I72I63H96L96K99N8?M=;L<6H:8K<8K9;M98I:5F85F86I:7J8WIA]J9WE7WF7TE8VDYE?WC@RACUB@TABUCAXGH\NE^KDZHG^LF[IH^LE]KH\NG]LD]IC[GDYFH[JKZMJXJLYJXaQ`fUmp\mn_ciWT`KO_IVePYgTWeS\fUchXolZzsaƒve‡qf}maum`spcqoauqbƒwl|q|qŠyp‰yp„qi†skxpŽyoyoˆuiˆui‰wmˆun‡un…vm†xk‰|mˆwlpdƒqh‡tlŒvnxpumŒvm‹wlˆvkƒrdƒoc‚oh„shrfpg‚pf‚na‚od}kd{jd|nb}sb{pblbYykbnh…qfˆrg‡rg„og„pelbyg\yi\yk]kdlc|k^{j^|k]}k`}k`{i^{j]€me‚og~kd}h`kc‰pi‹rlvnˆskˆti†sl€nf}lc‚qe‡whŠwm‰wk‰ym‡wjˆujˆsi}kc‚qg‡uk‰xl…uisg…tkˆwk‡vfˆufŒvlŽuo‹un„ogme‚qfŒwl“zp{o‘{oynŒwo‹tmkd~lf†tkŠwj‡sdƒpdkd‚peŽ{pˆti†qiŒvn‹umnf{h`ƒnfŠumzr’{r{t“~v”~v}uŒyo‚qeƒtk‹zpŒzo‰yn…wl‚wm‡voŠwp‡shˆtj‹xqŠxrƒwm{qcƒvkˆxrŽ{u}sx‘€u~p“‚s†vjƒtlztŽ}uŽ{s{rŽ~rˆ|n†{q{oexl^tfuj€sj{mexia|kcƒqf„pe„pc€pe‚rh|ofzncukb{si…uj†vi†wg‡yj†vj„th†ujti]jcVtja~oeofymczja}kb{h`zg_xg^€l`mb€me{h`zg`ƒql‰tj‰vj‰ti‰vjˆti…qg…og{g_€nd‚sg…th‡ui…tl…si„qf…pe{i_xf^~ld{ja|kcvi[wi^vi]veZucXtcX|j`}k`{i^tbWsdZ~ofƒtk…uk†sk‰ujˆul„qi~mdwf_xib‚sjƒqirfƒsg‚rf…ug…sjvlarlayoerf|qavkavm`un^tn]oh[vmd{rb~rd}pbyk_qfZ{re„ui‡umŠyp‹yo‰xkˆxiˆwjraXuf]riƒtjqe‚tf€se€sg~pgrd]qd\qh{oexndulbrkatnc}pd}mczh_|jaƒqh„sh}mgf\Sxme‚siƒpg…tk†ti‡vi„ug{pae]Rytk‰zrˆxp‰xm†zkƒylwk‰xqrini]|vk…|r‡|rƒ{mxm‚yo„umvjhiYok^yreyqcvnbqkaqlcxmf{nezncwqbzoc{kazlaof\iaZle^pi_ukari`vlcynfwkcuh`cVNrl_vnayoc{sdzpa|pc|sdwpf_[SZSOog_si]tg^pi^if[ni^rh^te]th\th_xic{kezhcp^Wg]Uoe]~rg‚uhˆxj‰xi†vm…tn{oh_YQtnbthxici^Wja]hb]mban`be]]a]\ca`kccqeeocdmb___[fgb|tq|nlypn|sqyopunosnmslnsklmgcea_^^^abcfeefbajbcibbeb]kgftlnxlpulmzmozmnxqmxrk{pgvmhslgle`a\Yed`fea5O<4O;;U@>ZC:W?8T?7S?3S>4Q?8VC8YC:[F9^H<`J;cI=cI>_L>^K?_LAaNDdQEfR@iQ>jP>iP>eL:`F>`E=_G7^F9aI>aJ:`H4]DmS>lW=mZ=mW>nX>lVdPAfREnWFqZFpY@nW?mW@nYDm\AfV:bO6^H=O:=Q=:L;:M:=N=>Q@?SB=UF=WF;VD5RA:TE=SG>XK?XK;L=7O@7TD:P@;SA;TA@YFAXG?UFDUGCUFCUFAUFG[LG[LM[KK\KL_LM`KPaLM^FN^LL`MH^LJ[JN]IO_JM_NQaPUbPYcQ`hThlYpk\jiYgiYehXeiYik\jl\nl]vo`ug†uiˆvk‰vk‡vj€qe~rfzqd|th…xi‹|nŠzm‰wjŠuh‰qf…ogyo{oŽ{lŠwj‰ujˆunwo’yq“yr”|r“|q’xqwp…rh†vj‰yn‹zn‰yq‡vm‡um†sk†qhƒmb€leƒph‚ng}lc|kb€of„oh†ph„mfˆtl†tj‚qewi]wi\pc…sh†sh…qf‚qi~maoazi\xfZzf^|k_~kb|ibxe]zi]oa€ndnf€me„og‡si…pe~iajbƒod‡shznŠvk‡uj…ui„tg~pd~pdrgƒuisg€rf€qiˆtlˆrk†sk‰vj‹zmzmvkŠng…qiwoxpxpŽxpŒypˆvn‡vm€ncmb†tiŽzoŒzo‹yp†rl‰smslŠle„ndŒwlŽxm‹uj…pe„nc‡uf|pŽyqŽxpxpyoŒtlˆrg„sg…tiŒyqwsŽ|t}tŒ{sŠypˆwome{l`ƒqfŒxm†sh€oc‚sfŒyqŽ{oŒvkxlŽ{pŽ{r‹zlƒsf…uhŒ{r“~x•y’x‘~v’v}r‡uiƒsfˆym‹|pˆzmsgsgƒui€whtitj†vm†wl„tfƒrgzj^~nbƒsg†shˆsi‡ug‡sg„ph‚oiyldypf„ul‡ul†tmvl|tj}rg€oc{h_ve]{ib}kc}mavg_wg`{ib~kd}ic€ic„oc†od…pejb~kc†sk‹vnˆun‡tm…rkƒqj‚pi‚oizg_xg^~mdpi|ke}mbuk^vi]|j^€j^{g\€k`~j_yg\p^SufZxj^zi`|ja~kd€mfnd~obwhYqaV‚pi…sl†ul„sj‚viƒrg‚pe}m`rdWxobƒtg‚qf|newnd|pe‚rf{lcui_wla}qg}of}ndui]qi]woc}odrf€sh€rcƒscqduk^qf]€ok…vm‡xo‹|sˆzq‰yp…wl‡wkocVrh[}qg~oh}lewnazn`|m`{j]yg]|ibxmeykawk^idUleZ{phƒwp‚ul‚ui‡xk†wk†sjngpe\{uj‚ym‚sfk_ƒse…th‡vj~phlaXysi…|p†yo„xnƒzpƒzo„wjvi{sgqj`xrj}vl~uk{rhsodlk]{sfwpbpk\wsd{sd|qc{mari\wobuf„vi€tf|rd{oanawiaoe\je\ojaqkbulbskcvlcwh`wh`nc[d_Tsk^xoa|pbynarl`jg^nkaebUfaSibSqf\vh`td]lbYd\Rng\xnc‚sjsg~tizpezof}of|jcibV~ti}sj…ynƒwl„vl†uiƒxkwpgc_Zwsk}yknb^e[Wnecnghnfgpehc\[]UVpegrfhtghuggmgac\Xnggvlmshisigqgce`\e`_i_ak^`jbcocesghshhukivkgznkxoolfefcbomnvqrvnn}oq{ppuqltqiqohomgoifhda[ZU[\W`a^aaa0J84N;4P<7S>3Q96S<6Q=7VA;YD>\H<\D<]I=`J:`J=fL=gL@bK?`J?dMBgPCkSCkS?mUCpW?mS>iP?gLAgL<`K9`J9`K@cN=bL:bL;]J:\J<^K=]M;\M;^M>^I;]H9_I8^HgQ?kT=kTBlXDkVAlTAlSApUCrY@rZDu`Ar\Bq[=mV;eP8bMjU?mVBmWCnXBjUAjU@jTCpZFqZDq[?nX=kX@jXAfV=eSgR=iT9bO>_OO@9J95F57G59L98M77P9:O>;R@6P>9SA8R?:R@;S@=R?@Q?AR@;M;;P>>TB?Q@?Q@=O>CUDBYG>UB>XC;U?7Q<;Q@=QASAAUDBWGAUFFUDFTCETCHVELZIM[KO_NO`ONaNQdRZkU\jTVeSPcQNaPR_OU`MUcNYbQ^gU\cRbgWfiVlm[sl`pk_nmanm`ml_nnann^qn_zqcƒuh†uj‹ynŠyo‰xnƒtj~oeznc~rf~sf‚xj€ug„vhˆwj‰ui‰ulŒxmŽ|o}p‹wm‰ul…skŒwo‘|s–~v“s‘}q”}uxpˆvlƒrg†tiŠwlˆvnpg…ri†tl…qe†qf…og†qi†skme}jbog‡tjˆtm‹tlwo‹wo‡tk}ncxi^{j_€ndƒoe„pg{kawgZxg[{i]|h]i`|i^}j`|g_zf^|j]‚pc„qg„rh„qh‰tlŠvlˆtimf€kd{h^„pfŠvl‡ti…thƒrgƒqfƒrfpd„sh„vh|ob|na‚sgŠxoypxp|p|pŽ{oyn‹rj†rjŠumŒvowoŒwpŒwp‡um†slnd{j^‚ncŠvk‡vh„sh€me‰unxotjŒvkynzoŽxmŒvkˆrg†tg}pŽzr{s{rznxr‹vnƒpe~nb…rhŠtmˆum†rk‰vn|tyqƒphŒvk“|r”{qynˆti…rg‹yp}pŽ|nŽ{oŒyo{s{q‡ul…ujŠwp|u”}v’vŽ{qŽyqŒwo†qg†rhŒ{qŒ{p…ukzmb}qf„xm|pŠyo‹woŽzrŒxo‰vj…th|l`zl`‚sg‰vk‡ui…tgƒrh„qhƒqkwi`sg[ypf~qh}qhxqfsncxod€qd|la}lcnf~md}ncwk^tfZ|maocnbnc‚oe…pg‡qi‚nf~kd€nhŠvm…sj„qi€mezia|jczf_p\Uwc[{iazh`wd]tdZlbVth]~lbƒmcƒne‚ncƒod}k`tbWscWufZ|ia~lcle~md€nd€obxh[scV{k`pe€pdqczma~nb‚nc}j`wg[}oc€pd~ncvg_ne[ync…sg€pgpgritj‚riqhxi`re[xlc‚pgƒqh€ri}qdqe~pbwmaneZ}mg„ul„ul…vm‚sjƒtkƒtkƒsfwi]{nbri}ldyg`oe[xk_€qd€pcpepe~lbla~mah^Pqh]ƒvn‡zr†zp„wkˆzm‰ylƒrixmekcX{rixk~ugzpa„ykwjƒxk|qhnf[wqg‚yn„um~phxmenf\{lb€rbte|qe}rfuhtgzkbti_{qerfrg~sfserf}nduk_d_Ujj_znapd|pevpdtnbwlarjake[hd[oi`ri`th`shbmc\ne\qg^lbXlbWri\wk_zm_qfYe]Qd]Tqi`vmasf€rgod}ld{kcqf[e[Qrh^}rhƒsjth|pfxnd{pf~phud]tj`~tj{qgti~rfrf€sh{reqka`[Wsmfrm`f^Td]Ske_jc_lb`j_^cYXeY[qcetfhvgitdcrgcpebthisegtghvhiohd_\Zhdetkm}nrxopulmvlmxoovllvkjwlkqiihcb_]\jhhjghnfgmbfmeejeakhdda\_[Xc_[`\X^_Ybd^dfbhgg/G84Q=6S?5T?3Q94U<7W?<[F;\F=^I@bJ=`K;_I:aK>hM>iNBeK?dJBiOFoTDoUDqVBqZAqY@oUCpVBmT@iP@fPiRgRBiT?iR@mVCs[Ew\Fy^Cu]Bq[@nX?nW9fQ;gP@lUClSBkU@iV>fU>gSBkV@mUDpYEpZBoZDq_Cp\EpZDr[[I7YE7XD6TA9ZG:aL8UB2J81G5/H61G54E45H95J<7O=9R@;VD;WD?VB@VC@VDCVE>P?8J9;L<>Q=>S@:S?@VD9R@7S@:WD;YG=YG@YC@V@DUBAR@;M;?RAASBBTC@RABUD?UB8L96J78J:>M=9SC@XGAWEDVE@RAASB;M<9I8=I7?L;BRB:P=:K>9J=>O?BTCEUHETGFUFGVEJUEJVFPYIS_OQaPPcRQbQXiVbo]cm[_kYVeSYfT_gVagV`iWkk[om]rn_nj[ljZoo_vpeuoduodtoduqfupdtoaxqc}pd†vj‡wkˆyk†tl…tkƒsjne}lc‚rise‚tf€seƒug„tgŠxj‘zo“}q“}r’|q’{tŒum…tlŠxozs’~s~sŽ}qŽzs‰vnˆvkƒqg†rg‹wlˆun…ri€me‰ujŠvk†rg‰qj‹umvnŠtlƒofld†ui‰vlvnyqvn‡ph€newd\yf^‚meƒnfkcwf^scXwh[mb}j`€ia€la€lbja|g_~k^‚ob†vh‡tkˆsk‰sm‹unˆtiohzi`tdX|k`‚rfococƒrg‡uj‹wl‡tiŠuk„tgqd~rc†uiŠylzn“zs{q}rŒzoyoŠtmƒsgƒpe„oeˆti‡tipe‚ogƒphnc‚nc‡shŠvj†wi„tg‚qfˆvkxn{o’|q‘{p‘{pzoŽxmˆsh†tg‰wkzrzr‹xoˆvkŠsm‹vnƒph}l`‡tiyn‰vn…rjˆum|t‘~v’~v•s–€u–€u’t‹wl†sh‹{n~r}nŒyozrŒzuŒvp‡um‚ogˆujŽzp‘{pymŠuj{pzrwqys“~v’x~u‚sj}pfƒvlŽzoŽzozp}r‹zoŠxl…vj|obzl`}oc‡xl…th}pd~od~menewf\tgZxne~qg}qesm`ni]yqgqe€qepgpgneofui]qeX{l`peoc€oene‚pg…rk~kdwe^{kd‚ndodldtaYve\zi`~hbjb‚nckakc|f`r_Wl`Vxka†rj„og„qi…pe†sh€nbyg\qaTteY|i_zh`{jamd~nb}l_xh\scWwg[{k^|m_vgWseZ€oc‚nc„pe€mbpe€obƒqgzjbne[|pe‡uj†tl…ul}rhvl‚tkƒrixjarg\|ne…tk~pgyqfypf|od}pbvm_rj]}pf‚qhpgpgzkb}ne€sj„thqf†vi‰xp†ul~meqc\~ogqe„tgƒugqdod‚nc‚pdpd[qg^…xo…yo„wn‚sh…xkƒsiofoe[obXxi_paUpfZrl]mgZxobtg~rh}sitjxn…vn~phpe^sj`rh†uf‡vjƒth„ti‡xk‚qdxi]tg[~pe‚pe€od~rf|qh~oh}lepe\e_Ukh_ylaykatjaoncgg]he[fcYecYgf\jeZnd[sh_n`\f\Vke\rnbqj]vk]xnc}ococyk_j_TjcYukaxmcyma}ob~ne~le{ndvka]UJulcypg}qi|qf{oezod{oexi`paXm`Xui`wkaogZwn`vl_uh_xnark`mb]vkdndY]ZPc\Ufb[h_[l`^j][d\Ykcdrhjwlmznowliznoxmnyoprvqr{mmhc`YXWfcclchj\_oefkedkfef`_ibcmefkbcf`]b^\b`_gedmjjpjknhigbbd`_lhfmjipljmjca`Wbd]fhbhicmjg2L:2N;5T?9WB7YA9[C;^F<_G>bJ>bJ>cKlV>lSCpVAnSEmW=hQ;cM=aK;aL=iS?qV?nS=hPAgQ=cMhQ>jT@jU@iU?iR@mVDu]Ew_Dx_CuZ@nX>lV=kU;jRfT@fR@gR?kTDpYBpZCp[Cq_Ap[BpYCq]?l[4O=4UB4O=3I76J82J80F53E41C53F74I89Q?=WE=XE@XB?W@BXECYFBXFAXFFXG@SB?Q@BUDBXE>YE?UB?N=BN=EQ=GS?BQ@>N==K>AM?BN?HSDLVILUIJZILYHLWGQ[KXcSV`PUaQYeU[gW`jZkq`prbim]ciYgk[on_spanoatn_xpaug~setn_pqa}uk{sixoevmczqgypf{qczm`}nb‚pe‡ulƒrjne€of‚qhnfnfƒph…sg‡tjƒrfƒpeŠujvl~q}q‘~s’}u|szq‡vn‡ul‹wlŠxmŠym‡xj‰xo‹yp‡ujŠtiŠvkŒxm‹xqƒph‚nd‹wlŽzo‰viŠqjumvnvn‡qildod„rh‡rgŽtm†phƒlenf~jb~ia‚me…oh„og~kbxf]zi`€ofneƒkd„pe‚nd‚mfld}j]m_ma‡sg‡ri…oi„phƒphne~mdxg\}la}ma{k_{k^‚qf‰wmŽzoŒxm‹wl‹{m†vi†viƒsf…tgŒzl‘wozrzrˆum‡tm„qi}namc‚nc„pfˆtipe‚me†qiˆsi‰uj‹wmyn‹zl‡vi„rg„rg‡vjŒ{o‘|q’|qzoŽxnŽym„od|j`„rhŠwoŠwn…thƒseˆvmŠvnŠum‰slyp|q‹xp‡tl†tl‘~v—„{“€x–„y•„y”ƒx’‚wŒ{pƒsfog…si‹vk‰uj†sl‡uowq‰tm‡umŠym‘|p”}qxlŠwiŒzo~v’~w–€{—‚z•‚z’x‹{r‚ukriŠym‹{oŠzoŠ|p‡ym„xl‚th}mbxg\}na€rf}ocvl_qeZ{kb}lc}lb{k^}lfng€odvk]tj^|mdrfsg€sfpgpg€ng|ldraZvf_~ke~lezhavh_yja~ld}kbzi_~ne„qf„rg~lap]Vp_Vne†qk…phƒpd‚ndldibsbYqcY}qgƒqhˆrj…rj„rg†ti‚pexeZq_TudXxdYxf\se\vg^|l_~k^}j`~la~m`€ob~n^|k\ufZ~mbƒqf„oeƒodpd~ocnd€neobXsh‰xmƒph€rh~ti~ul~sj€rhqh^me[xodukapj_hk^qkb{peqe|qd}rfƒui…tk†vm~ofpaX}of„xo|p€tŒ{r‰xoŠzq…sjvfa€ohƒrhƒsg€te|pd|n`qdyi`bYNjbXxpd~rfpfvh_rdZwi_tcZqaW{h`‡qgˆti‚tgtk^ogZ„yl†wn‡vm‰xo‡wn†|oˆxppiob[zqg†xm‰yn†vm‚unƒwn…yo€sguj^rj]{qdoczmatnbrofsmcsh_p_YpaZth_tf[uf]oe[ed[bdZfdZki_rmevqfvoezqg{qdpc_cYTrldupdvob{pbzpf|of}lczkblaWpg[sm`vodxnexnd{qgwm`tmcb]R]YNki_trhsoevkawkawka{mavh\ugZ|kd}rgl`VlcUwnaxpc„sjrf~qf~nj}kerbX]XTga_riftfgsegn`aa\Zkgdrllslntnlrlhpiismmpikoijqiiocdf`]^]]a]^g_`n`bmdcda`d`_nihojhmhglggkdac]Zlhftomokjsnlnhhfabhcdlhgmffkdbb_W\ZTZ\W_c]``ZURM5Q=7S>8W@?^E;_J=cJ>eL=dL>gL=fK=hO:cL9bK=cM;dJ=eK>eK>fL?hN@kP@kQBnTApZ?nW=jS>iR?mTBrWBnZ?lV>hR?bN?eQ@nX>rXAqVhR>iP>iRCnWGt]Gs^?jUAjPCnUEt]Ev_?qZ@pW>hT;fQgP@iSBlVAnX>mW@oY@nX?pWAo[Bm]?j\gM:TD5R?4L:8O=4M;0H61D32C55G96K:XFAZE>XC@YEAYGBYJCZLFZIBTCBUDBVE@XF;VDBWD=TAI8M=@M=EQAAL=?PB=PBCUHGYIEUDCQ@ET@DTDHWCMZDN[EGTABQ@GPAGRBKTCLWDQXIUZMT]LX_NY]LZ]M_fU]fT]eVdk\hn^opbvre{tgwqbpm^sn\xpazrewsfyudweˆyk‡xk{sdsrcyrf{rg{pe{nc|oe{pepdod~k`‚pg†tk„tjmdka‚oe†tj‡uk‡tkvk‹ujˆui…rg„pe‰ujzoŽzrŽyrŽzr{rzm‰vmŠvjŒxmŒxm‰yl‡vi‡umŠwpŒxmyn‘}r‘~s‘}tym…qf†rgŠwj‰vhŠslŒum‰sk‰sk†qilcmaˆqfŠqf‰oi‚kd€jd„ne…of†qhˆriˆqhˆqh‡od~ibyg`zjcme€mbƒncƒndƒme‚md€l_k^o`„qe„of€ke}jcƒphƒnfme~k`€la€mbk`}la~ma†uj‹zoŒ{oŠym{r‰wm‡wk„th‚peˆviŒvkŠun…qkngƒpi‡ti†sh…qf†qf‡rh‡shƒpe†ng‰rk‹wm‹wlŽzoŒzozmxmŠsk†pi„pg‡vjxn‰vk‡rh‰ujˆtj‡sh„qf‰vm‹wo‹wo‡uh†tg‹|m|pxpyr{t|uŽ~tŒ{r‰wn‹zq~uv“„w‘‚vŽ€tŒ}q†ui~ka€lf†qjŠsj‰ti…qgˆum’|t‘}uŽ|t|s”t”|q”|q‰vkˆyl‘‚y–ƒ|•‚{—…}”y’y~umezh_…tl†wlth~sf{rg}tk„th€od~l`‚rf‚rf|ocrh]pf\wianeqf~pb}kenfmbzo^tj]yl_}pg}qd~pe|ma}ld€mf}jdxe^}jdlfzgbs`ZoaW|laof‚odqd„sgˆui„sgmbp^Sve\ƒri‡ul„rh‚qf€nc€lc|h_wd\qbZwlb€mfƒoh~meod‚pelazh]tbWzh]}h]{j_te\vg\~nbn_ƒpg…sg…th…tg‚qe}jawg[}mape‚qf‚rgqf€qe‚mdwe\l]S{oc„tiofzoeqlaqlaslb|qhrk]qj\uk]ofXgfW\gUpnb€ui‡vi„vj„vkˆxn‰woˆwnqhk\S|pf…zpŒ~tŠzrˆwnˆxo‡worhua]uc\le}mawj^pg[wl`|kbqaYi_Utk^yl_~pc|ncl]Tyja„tk…wm‹ymŒzn‘|rŽ|pŠzo}nbri^…xoŒ|r‰xp‹yqŠ{pˆ}p‹{o„ulqf[~th‰yl„vmvm}sk~uk{rfwnbqh[sj^si\zl`zneqlaji_oi`wlc{jb}md|nc|obyk`ti_fbXjf\oh_sjayofypfypdyrdysdmd^g^Vvnewpfvodwqexoeyne|nfvh`h]RleWnj\ql_qlatmbqi]ngZleXc]QgcXc_Ub_Vkh`ukayodsgsgsg€vhƒui‚riqeZqg^}tk{ti~ogsf}pe}ohwkdj_U_[Wjcbmbbqdcnbch]^]YUga_kediccjecjeaf^^fa`lfhligrkhpgcbZWca]mjkrijvihqiec_^b^]mieojeokgoief^Zg_\slhskimfeiccogdib`leeojhohgqgdgc[^^X_c_fiehgcmgcfO=gM>hO>iN>jPkS>mS>mV@mWAjTCgT@gR@nXAsZAoXlS=kTDqZL{cKxcApYDkOBmS@oWmW?lUhQ>hP>eQAiW;hS>lVAoXCpYAqX?n[Bn^Cm`>jZ8eQ9cM9\K6YJ:`QAjR=fJ;gO^J:UC;VC8TA3M;4G64E88J;>TBBYH?YF@ZF>UC=UC?VGDYKFZLE[JCWF@SB@VD>VD8SA?SA=R?>TA>UAATB@SACWFGWGJUDIQ@EP=DPHRBHRAISCCM>@K;=L7@L:AL=>LgL@gQCjRAmQHpUFlTFkV9cL7`J8aK7`F=eL=fLlR?mT;jS=hP@kPAiP?fR>bQBfQ@iUBkUiQ?dQ;bM6]H7^I9`JAgQDn[AnZApXDr[CrXCpVBpSDnTBlU?iR=iP;jO?gV=fR=fQ?kTEsZEv[Cx_Dw_Fu_DoZ@jU;gSdP=cN@lW>qZDr^Cq_Cq^Dq_An[>kX6bQ6^L=aN;_I=cJ>gL@hORBB]JGcM?ZEA^I;_J9XE6P=8OA=SC@TACWDFYEGXFEYD@YD?XDBXECYG?ZHFZHDWFBUDBTCAT@@T=>S<>S=@TA@RAAPAFQDCTCLUERXFOYHLXFLWBJVEFR@GQEJVEET@AS=>UB=R?BUBCUBDWDJ\IDVFEVFL\JO_MR`MP_JUaO\fRcjSbgQZbMV_MT`KYaN\aN\eTafUddSkeQneVndWuj`vnctoavm]yq`|vc€yh„zm…wk‡ui…tgƒrf€se}qc}sexreyth{ui}qgsf{ve|ug„vh‡ujˆuj‚rh}ne€qe‡wk‹ynym|p‘|pyo‡tjocrf…ui‰wlƒsl‚rhƒtgƒrenekd„rk…tj„sj‡uj…sh‹znys‘}s’r‘q’~tyr‡xm†vk‹xpŠxp{s‹yrˆumˆuk‡uj‰tiˆpevjŽvj‹rj‡le…idŠmfpiŽtmuoŠsl‰rj‡qind‚pf„rg…qg†rg‡oi…ng…oe‚nfzhayg`~ld€nchb~ia…nd‡qdŒsh‹ti‡sjˆumŠwoqe|l`~naƒlelbƒnbmboa}m`{h`ueZxj^qf„rf†sepe€mbƒpe†rgˆshˆrg‡rj‰sl†rhƒnd…qf‰uj‡ukŠvqˆtnˆuj‡uh‰rkme‚me…qg…sh„sg„sf…th‡siŒsk‹qj‰tjˆxkŒwpŠum…rj…tk‰yq‹{rzt{uŒ{r}tŽ}ryo†vkŠxpzrˆtm‰vo…tm‰xoŠxp†sk†skŒxpyqyq‡sl…tkŽ{t‘{t“ys}p’~u“€u’}vŒwoŠum‰xq’yyy~x~vŽ|r‰wmƒrjƒri…vlˆxo„ri}of‡vlŠsk‰oh‡ph‰ui‰uj‚pe~me{ne€vl„tmˆtm‡ujƒwi‚th‚qhskcmf]tkcwodzpfymctibznc€obm`{jawhb}qe„rgmbzl`|qd‚ti‰voˆun‰um‰vj†uh€obxi\yl_„tiƒsgƒqhƒph„peng~kdn[Ur_Xwh`}lavc_r`Zzg^€k`„kbƒnbl_„pe„pflcwd\|kbƒog…qiˆrj‰rk…qiƒsgnd{jawe]od‚re†rjƒng‚ne‚mf€meye]scVyi^{ia}jdzj_vfXykb‚pfˆuh…sg‡tk‡ulƒuhrfpgZifWro`zoc|nb|layj_xj^ul_gbTmk`yk…xh„ug‚tj|qj€qjrirfYqbVxh`yhasbXcUMtkcvmwk…wi‹uo‹wpŒyqˆtlufZh`S‡ulƒqi…rjƒsjƒsi‚qhƒsi€rimcY€uk‡zpŠzrˆ{o‡{s…xq‡vp‚ohzf_ug]…yo‡xo†rlngxjbznb~odqe‚qe‚rg‚thƒuiugtl]woa~tg‚th‚vk‚tk†wo‡wpƒujxoaicV|qe}rf}tg~thpd~oc{rdun^gaRrl_uncticrhapg^ri`sk_rk^lcVmcXmd[oh^haWjdYxj`tg\ui^vj^ynayoaxk_l`TocVsh[seXn`RmbZph_rj^wmcrh^mf^|pk€vo~rlzqiysjwtj|tkqg^h]Uujbujbwkcsh_rj_nl^kfYmg^lcZka[qebuhfvhgpffh^`i`^ofbpgdredrefk]_iX]ucgygitefnb`h][c\Zjbbneerhhpeenbb^\\khgrlhvihujhmfdh`btjixpl}tpvplsplsolpiiphhrjhokeih^[\V[]Wdf`bb^YZVXXWAcNHkQGmTJrWCoU?lS?mUAoWCoUBlR6dM6cM6dL7dJ9dK?jQ@gO?eOChRDgQ@bN>\I:_G:`HgM:dJ:cI;dL=cOlTlUEu\Fy]Cz^Ez_Gw^CrYCpYAoX?nW?hR=bN=bN>hS@mZDs]Er`Er`EtbCqa>m]=iY=dT>bR?aO=bL`I?eOBkUBiT<^J=UG=UD?TACVBGXEL[IKZGEYFG[HHZGHXGGZIG[GFYFFWFFWFFWDHXEFXDDWDBUBDVDDTBHVEIVENSCUWGX]MW_LU[GRZJLTEHPANVGMYGIXCFYHFVFKYIKXHHUEO\KJ]KK[IQaNXfS[hT[gR^gVekWloZikWeiV_dT\gScgUegUfiYfhXkhYuiXyl]wh\qgsg~rf}qd{qcvf‚yi†ymˆwm„ujƒsiƒsi€qg{mb~qg|rf{sg~qhog„ui„{j‡{mŒ}pŽ{p|qŠxn…tj‚ti…ukŠxnŠxnypzpŽyn‹xm‚rf}ma†qgˆth…sk‚pf€pcƒrf†si†rjŠvnŒwoˆtm†uj…shŠymzt}s’‚t“ƒu“€vztˆvl‚qe‡rj‰tlˆum…sj†qh…siŒzo’~sxl‘xl‘ymvn…le„ke„ldtl‹voŽwqŒvo‰tlˆsk…ohlcmbƒod…qfkd‚kd‡ne†qilfkdƒoh„peƒng~i_l`‰sh‹wlŒwpˆum‰vn‰un„sh|l`xi]}ha}ia}h_}i_zg]~k_~hazg^{j^‚pd„qf†sg~manc„rh†sh†siŠvk‡rk‡rj‡sh‚oc„pf…qg‡vjˆto…sl„rg…re„oiƒmdmc…qf„rg…ri‚og‚qe‰ukslvoŒwn‹znxpzrˆumƒqh†ul‹{qŽztŒyq‹zqŽ{sŽ{rŒwl†shŠvoŽwo‡skohzha€nf‹xp‹xpzr‘{s“~v‘{s‹xoƒsjŒzr{s’zr‘~r”t‘~r’}uŽyqˆrj„rhŽ{t{uˆun‚pgŠypŒxpŠwo‰vn{qŽ}q‹ymog{lc…tkŒumunŒwo‹xm‹xmˆvjpg|ne~siƒtm‡tm…tiuh}sf}ndsg`th_yldzmc{mczjaoe^}pf„tg…tgƒpf}levkˆul‚nf{kb|pf„tl‡uoˆun‡um‡ul…sh„tgyj^yj_~nc~ncme|ha{j_{iayf_vd[tbZ{j`}k_xe`t`\|ja…qd‰pi†rfoe„qg„rinfuc[vi_qg‚si…tk‚ujpg€oc}jayf^ubZ~kb€nb‚ldze\v`Xyg_md}kcmanc€og€og|mbteY|nf…uk…uh‡wj‰wmˆwoˆxkƒthqeYmgZwna}ob{oc}ocxj]wi]peYlcVoi^zrd‚te~nbti^rjaqiqiƒuith‡vn„sk‚ofo]Uylc‡zpŠ|rŽ~q|u‹{r|s‹wo‚pgti_tksjtk‚ulri}pgƒtkpgj]Sxj`‚sj„ri‚slzmeyld„tm€md}j`€rf…yn‡yn†tjldo`Xzpc‚ti‡xkŠxmˆvk†vj…vnsiuk_xoctjskuk€uk„wn†xo~shsk\hf\xqgypgxpfypfzlcxlavk_nfXkbTndZncZmc\jaYpg^sj_sk_ri\yj\{m`wjbpd\kaXsj`ymcxmbxl_zpc|qdypcznbk_SmeWsh^reZscZpe]oh]smbvkanbYle]znh|pixmfvncpi`mh_xlcti`ti`ylcxjayjbyj`uj`ogZvmbvlbl]Vkb]nd_pcaocai__c\\h^]ib^pdbpdbsggsfgtjmvjlvimuiiukhlebgbakgfnjhoiijedd^]b``khgslivigtigleei`asjizqmulhmgdmjfjgdlgfqjiqjgplfig^UWPac\klhghdfgb]_[FlVCiRIqXJtZBqS=kQ?jVAlXAmUCnRdP9\J:\F9_I=dK=eJ>dJeOChR?mVApXCs\Dv^Bt\Dv_EuZ>mT;gP;fQ@kV?mW=kUoWAu\CzaEy`Bt\?oX>mW@nY>nV>gQ?dP@bO=bPBiWCp[Cq\Aq_CtcCtgDvjCob@i[>aS?`P;^L6\H8ZE8\H=]J?^K;ZG@bO:aK7]G=dNEqZFr[BiS>XHeKdN@gO@gM@kUAmVAmVCqYEs[Hv`Gw_CpY@lT>hPBlVBlWiUoW?s[Ev`HxdDua=mZ=jY=hW;hRaKEpYGr[DlV@^KC]JBYBFVBPZGW^MUaPTeSRfSWfTWdRSaOVcNR^KNYIOZIQ\LO[IMVFNZIL\JJZEL[EL[DKXFSWG__M_cP]cP]aNWaOXaOU\JX`K\dQ_gSdhWedUgdTgdUa_O_bQXgPYeP`hTfkXfhUkjXsk]rj\qhZri[un_wparm^un_vo`ro`ol^sk^unaum`}pdqe„tjrirk~qh}oc}oc„si€pg}qh|pf€qhph…tl‰yn‹zm‡xk‰vn‰rj‹ukŒ|n“€v“t|qzo{oŒzp†tl‚ph„sj…rjog†sl‹yn‡tiŠvkynzpŽym‰vo…ri†sf‡thŽyp‹vo’zo‘zpzsŒxp„pi‚ph†tkˆwk‹{o‡wk‡vjŠvn}pxmŽxmŒvkŒvnŒwo‰vj„rgŒ{p}r|qzoŒzmŽyoxp„oi{h_}mdqgƒsj€me…phˆrkˆoi†pj…pgˆti‡shmb‚me…ph‰rjˆqiˆqiŒumŒumŠvk…rg}l^od…sk…sl…rj‚of{hama€ma~j_|ja}jb{h`ze]{d^hb„ogˆsk†qh…ph‡sg‚oeƒrf~nb|l`od…shoc€jcƒnf†rg‡sh…qf‰vk†uj†sm„rkpd~na‚pi‡tg‰ui‰uj†ti‡tl†skpd…qhŠumŒxp‹wnˆvj†sk‡tl„qi‚og…phŠtlŒxpˆum‚rhŠwo|t’{s”}u‘zr•{t•sŒyn‚pdmfŒyq}u‘~v|t|uu|rƒqh‚ph‰vnŠumƒogwbZ‚me‹vnxp‰ukŒ{o’}r‘zq‹ul…pe‹zn|u|t}u{qŽyoyo†sk€qh€of‰sk‹um†skˆwn†tl‡tl…rj€pgqh‰ujukˆqjziazjb…rk…tkŠypŠwo†sk„qiogxk`zmaƒsg„rgƒqeld~qi‚ng€kdxf^{jcng‚oh}kdzjb|ld€pg‚og‚pfod„qg†ti„shyi]wi]mdneld~mam_€la|ibve[yg[ƒqc‰skƒoh€nfƒph‚qhxg^o_V|iakc€ld}jbscZue\„qf‡si†qi‡sk†qh…rgˆqi‚kcwc[}md}ofqh€og€ne‚od„qg}lcnaWth\}pd€qf{nbzmayob}pdodocsgƒth†sh~qeth\yma‚sg‚sgƒsg…vj†wk…uiqetk`wqgˆzq‰{p‹}q‹r‹}sŠ{rŠ|syk`vl_…}pƒyp‡|r„zn}uhvkˆxo€mg}kd†vm…tl‡um…sjwd\€ne‡xoˆypŠyp‹{qŒ{r‹zp‰wpqaZxkdˆyp…vjˆxiˆ|n†|n‰|qŒzn‚qfxlbzqe~sg„vk†vk„uj„ui|revj\rcUvgYyk^tk^mf[qg[wn`xl`ynbul_xof~ph{kdvjayldph€qhsh~rf{oczld|jdjb[ng^ynfyoeznczl`wk]vj]si_lcZmf]tne{kbte\qe[rg]nfXiaTi[QaVKpf\pf\qaZm]Vsd[i`Wnj^vka{obxob{pg{oe}qgzmamcVph[|of}rg€qh‚tj€qh€pgxkeoe]ldZ}wnoh`jb]ngerhfpgdpgcc[Y\XVjbaqgdthfrfeoffh`akccoadl]^j\]n`avhiwijuiivjjvkkrhh]TTlghuqpxqnymkzpntpovoquomxokukhrifid`kfenihhc`hdaec_dc_]a\cgbdea]^Z[[WWVRCpYAnW@lUBlUFmS>dL>`J>_JBeM@fLCkRBiQ?fM=cMeK=cOeK@gN?eN>bL>bL?eO@gO@hOBkR?pYAoXCoXCnWFrYEsZGv]GuZFoUClQBjTCkV>kU>iS@kT=kU>nW@q[Cq[Fu`Du_Bq]>kX=gU>eR;`M9]H;ZH<]I?bMBmXEq_EsaCq`BsbFxhN{oPxlHl^IhYDeT=_N@aQCaOFhSEmVEmXIlXEkWCeRDfQGoXDrZFqYIiUGcMKaKQ`LXaNceU_dVWdTYgV]gUagV_gUZdQV_MV_OYcSXcQVaNU^MR]JT_LS_JS\HT\GS[HZ[IhdRiiVfhSefRbfTeiThhRkiRpjVsoZyq_zo]q`€sayr_nlY]fR]dQefUjhWpk[tj^xm_wj^ui^uj^wm`ypavpayoayqcsm`pm_sk^og]qi\{pd~re}qfzodzph{oe}pc€re€rfqg|pe{odshƒuk‡ynŠ{pŽoŠ{oŒzqŒvoˆtk†xlŽyp{p‰vk‡tiŠylŠylŠvm‰ul‰ul‡tj†siˆtkˆvkŠwlzo“~s’~s}q{rŠxn…uh‡ui‰ul‹wo‹wlŠvkˆtjˆum…rj„riˆui‰vl‹zn†uj†siŠvkq’~q’|qyo{o{r‹xj…sg‡vkˆxl‹xnŠul†uh‰ulŽvnˆoikb€me„rj„ph‚nf…ng‹sm‹snŒtm‰tl‰ujˆti‡thƒphoh†qiˆshŠsh‡qi…qj‡slƒqgpdoc†sh†rkƒph€me~ib€l`mbk`€nbmclcka~jb~ib}le‚pi€ldld‚md„ofncoe|j`„qg…qg„pf€kc€kc…qfˆtiŠukŠvkˆuk‰to†rl‚pf€pc‚piˆsjˆtj‰tj…si…ri…sj€nc~lb…sk‡um†tk„sg„ri†tkŠvn‹vnwozr‘|qxp…rj‡vm}u”€z‘w’~v“s”~s‘{p‡shld‡rj‹xp†sk„phƒqh‹yp‰wo‡tlˆtlyqŒvn†sl|jc‚ohzrzszr}p’~u”|uyrˆtj„th‹ynŽ{rzq‹yq‡tmˆtm…sk~qgqhˆtl‰um…tk€qj„slŒyrˆumˆvm†vkŒzn‘yp‹um|mdzmcƒriˆwl‡wk‡vjƒsj€of|kbxk^seY{k_€odlbzg[wj_ne€jb~kc‚ph†rj„og€me{kbzka‡tlŒvn†rjˆsl…sh„rg…thoc{j_~lcle~ld~lc{j_~j`|ibtdYueWn_ƒmgld|ha}i`mc~lb€pc€mc„of…oe€i`xd[}j`‡ui‰vm‡tl†sk…ri…sh‡rk‚nfyf^xg^{kbzkbwia|lbƒod‚nc|j`vf^vj]‚sh„rj}mese[ypbviŠzoŒzoŠ{o‰zoŽyn~pdwj^{oc…xl†xl‰wl…vjˆwk„uishukawnd‡zp…xm†yk€ug‚wl~ti~rhym`}rewk~si|qiyndpi_wmŠ|szrŒ}sŽ}t~u{sŠwozia†ul‹~qŽ~rŽ~r~rŠ}q‰~rŠzouf\ng‡xo‡wl†xjƒvjxluj…uj{kbi]Tsh_€qhzkbwg^ykbwlcyocyk^€o`„sd„wiwnbjaX}tiƒxj‚whugsgsi‚qhnfti_|pfsj„ujtg~uh{reyndvkbk`Yoe]ujbsh^ui^ti]qh\kaWmcZmaYodYreZxe_vd\te\qdYlbWsj_xh_{nd|od{nc}mbyh]rbZkaXsmbukaym`xn_|qhri€qhzkbpdYvk_{ogzne|qh|ofzldxkbshag]Vkd[tmffa\c_[nfcocam_^ma_d[Y`ZVia`ka^nb_nbabZZc]_rhhymm~pqrr|ppyonznn}pp|opxkkpddgZZnhilhglebqdbmdafbakeflgeqhdsjfrjgoheqjlqlksnkqmjjgg__^cgdimhnojopkjjca`Y?mV>lUdI>bI=dL>dN=iO>kQ>jPAjTAkT=eNDlR@lQ@lT>iT>cP=_M;aLfM?gOdO>hN>iPCpWhQ?iR@iRAkV?lV@pY@mRApTArWCrX@mU@jSAfU=_O;\I=^H<^G7ZC;eQDo]Ao\Dr`GvcGxdIwjMwiLpaJiZIjYFgUEhXGfTGiTEpYHr\Qr^Js^InZHmWGs\Fv]Gv\MpZOkURhRYgRahVihZli[`eV\dSfiYiiWhhU_cSX]OX^O\dT\fTYeO[cPYcN[eQZbO^aN_aO__Mg^MshWum[rmZun[uq]wq\|q[„u^ˆv`Œyf|k|k“{k’~mŠlytaekWdeTigXqj[yma|nc€qd~pexj`ui`xlazoazrdzoaynaqk]mh[qg\rg^xl`}obƒsf}odyndwmeync~seƒvhwh~sgtf€tg€ug‚wi…yl‰}nŠzj†wj‡vn‰vnˆulvi‰ul‹xm†tiƒsg†vhŠzmŽyn‘{pynzn‘{pŽzo†tiŠvl‹wl|q~s‹~r‹{s‰yo…uh„tg…tjˆun…ui…thƒsgƒoiˆumˆtm‹wl{pzqŒypˆui‰ti‹{mŽ|o‘}p{pzo‹ynŒym†vi‚re†vk‰wm†sj„vi‡tk‹rkˆoi‰skˆtmŠvk‹un‡ph‡oiŠrkŒtntoŒtn‡shˆti†ui„rg}mf‚og†sh‰sh†qiƒnhƒqj…rj…qg…reˆsg‹vk‡tl‚ogle‚nc„pe‚mbl`m`mamb~lcyh_ujb}lemeldjb€kc‚oh…pj‚lf‡pj‡piˆpjƒnf€jc„peˆti‰ujŠvkŒvk‡ql‰slƒpg€ma~kd„og†qj„oe|j`‚pe„sf„rgƒpg†sl‰vnˆuk„rg‚qh„riŒwozs“zs”zt•}rznˆum†ul‹yq‘x€v‹zpŒyn’|qxmŠth~ib†qi†sknf{h`ne‹woŽzrŽyq‘zr’{szr‰vo†sl„pj|t|t|uŽs‘~v‘zsxrƒph}oc‡uhˆwj†vi‚qh{kd‚qkŒyq†wn…wnŠwoŽyr…ul€rkƒskŠvoŒyqŒxqŒ{q‹|o‹yo‡un|riqi_zpcsf€rfqdzjayjawj`xj\vh[~nb~nblazgZuh]ƒpf…qg†th„sh„peˆrg„qf~pd~oc‰vlxm‡sk…pi…sh…sh‚qe{k^{g\xe_|ib{hbzgatc\}j_jc}la~o_ƒre‚ng†ogj`|h]nb‚pd‚qerd‚se‚qd„pc|k]|l_ƒth†uk…sk†ul…tjƒsg€pf}kcue]zi`zi`yi`pf^xi^…qe…rfƒpf‚piƒtgˆxn‰wnƒqitf\~tfƒ{n‹|oŒ{o‰{oŠzo…rg€ocxi]|oc‚ui†vj…uiƒsf‚qf€reqhti_wmc€tiui~tfxn`tk^|ti‚ri…ui‰ylˆyn†vn…vppitkcwn‹u’uŽ€t~u}t‰|r‡ypuj`ƒxn‹}r~r~r‹}q‡}p…p‡wjyj]{lc€qh~pe~oc}qf|rh€uk„qj€og{oh…vmƒtk{lcvh_tjul€vmri†sjˆul†wnrh_lcXƒyn„xj„wh„whrf~rgrg}qdkcWysg{thrf}qc{sbwp`qj\ri^j\Vob[re]ndZndYofYkbYpe]{kczib~j`naƒohƒngofrcYnbXxnd}le|ld|nb€qdrbp_tcYjaWrkbsj_ym_{o`{pg~ph|levg^re[wkari`tjbvkdymeyleviawidylfzpisicha\c^[nc`pdcqdbocah][lc`nffqgeuhfqfde]]hbcskkxnntkktklniimghqlknggmffulkqhhqgfoijrnmvonuifkb_fbaojkvpnzqmypm{qnumlqlltomtomqnjbaaVWX`echkgcd`_`\``Z`_Y=hN?jQ?hR>bOBaN@_L>_G?aK@dM@aN?fSCkUClUBmYCnYBnTBgPCjUBmX?jU?fQBgR>ePeS>aP:cQ?hTBiS>fMBkRFoS;fOfM>fM>gL?hM?fKAhNBiSBhS=dOAiUBsb@yggNBnTDoU>kQcQ=dN=bL8^H?fQ?jTHraLygLyhLxgLrbHl[FhVIjYHjYGjUFfSFgTIjVJoWNuZMwaNu`Kr^JvaMzdRxdQt`Xp]ZmXZmYcj[oh[liYgeWabTadUdfVbcS^dL^`N``SheZedVccTafUdhVikXkjWjgSnjVkiUodQp^‡xf…xd†wdŒ|egh“j˜‚m™„nš„tš‡sˆq›‡n‘‚lxdmk]jfWpj[vn]{p_qbrbpbob}m`wj^tk^{maxk_wkaqf\qg]tk`}o`n`„re…tgrfyqc|re{pd~rfsg„th„ti„vgvfsgrg„riˆsm†rg†ri‡rjŠum‹vp‹uoŽwjŽwkŒxk„qd‡uj}q}r}r|q|q}rzouo…pi‹unŠxmŒ|pˆ{l‡xmˆymŠymxpŒunwqwlŠti‡rg‰ujŠzmŒ|o‹xn{r“~vzr‹wm‡sh„rg‰vkŒwl‰vo‰vnˆxnxmwlŒwi‹vh‹vj‹ti‰ti‡sh‡uiˆum‹vnwoŒxqŠxn‡th‡sg…qe‰sf‰tl‰tl†qi„ogˆrkˆrk‰pi‹rktlŽtm‰pi‰ph…pjˆrk‰tlŠvm‡ul‰ym‰uo…rk‚phnf‚phƒph€leme{jb~obncmb{ibƒog…og‡oej_€j_Šri‰rg‰rgˆuh‡wj‰wjˆtimbmb…qfˆti‰uj„siƒqh‚ohog{h`€mc…od‰shƒnc}k_‚rd…vf‡shŠwk‰wlŠxm‰wo…tlod‡rlzuztŽzsszo‹yn‰wl…sh†sh‰vm‹wp‰tn‡qjŠulyn‹wlvnŽxp‹vn…og~jc‚nhˆxmŽ|p‘}rŽzr}uŽ|t{tŠxpƒtjˆwnŠ{r‹{rŒxqzrŽzpŽxn‡qeŠuk‹ulŠvmˆtl‚pgwg]„tjŒyq|t}tŽ}tŒyqyq…wjuh‡xlŠzn‹zpŒyqˆxq†um…tk€of{kapdqe~peykcoa[{jc€ne€kc€mb„pe‚ncƒpc}j^{jdoi…sk†ul„tiƒrfƒph‚qh€of~me‚riƒtkrgofofpg„pe€k]~k`~la~kc€me{iauaZ~leƒph‚od‡sh„tfƒtf…pgnd|h\}la€menhqi€pe€ob}l_|g]hb†ob„qdqh„vn…ul‚pfƒpd‚nb€ncoe‚og~md}ib}jb‡sk‰tl‹vmŠvk†xi†uiŒwo„qhzm`~vfˆyo‰zq‰zs†wn„ul‚riph|kameƒqe„qgƒod|l`{l`~pd~sf€sgxk†xjˆzk†vj~nezle„xpˆwmŠymŒzpŒzo‹{o‰zotjzpf„zp‰~t€vvvŒ|sˆyp‚thxj^}rf‰vpŒzqŠ|p…wk€rf}ne~mf{mdqe„pe„ohxja}rk…xl‰ylŒzr‹zo~oŠ}o|qohynfƒxm†wi‚ul€riƒtm€sl~rkpe]jdWxk~vi}uh|tg}sevtiunewjbsf_wkbyogypcum_qj\h`RlbTui\wkaxlbth^vi`ug^se\n_Ywib~rh}pf}pd~qfqc|obwlah_UlbZwnfykd{ngypfynd}pdxi\icZf]TkaYk`Xnc[qh_ynaxm`yl`{m`{lczlbugarh`|qg‡xlˆtkqh‚sfsf€vjvmeb]Zkddnccpegndejb`ea\gbblegmdfsggsefpcbqecvceriitlhrdbi_]hkfwoo{oo~rr~ps{oqympyppzop{nqtgiia_mfajjiqkmuklsijnhgjeeid`ie`hc`ebb\^^X]]`c]hhcfdcb__aa_Y[U=fL>gN?eOBeQ?aM@_I?]FDbJ@bMAfQ>fTAkSBlTDnYDoZDpUFq[CpYEs]Ft^EnXFnVDjVBkV@lV?iTeP?gQ@gPCkSCkS@fQ?fN?gN?gNAiO>gL>fK?gMAgQdL:bL6^F7bF=hNApWBsZ?kT=hQ=hQ_N?bQCiUClU@fM@dO=bMAhSGn]QzhS}lJueDl[DfWDaRHdSNiYJhTFcRHdSGeQLmVOrZNr^Op]Np]NuaSwcYxd[uc`ubbs_`q\fo^mk]jgYedUddVdbUgcTheShfQjeTlcUqgZpiYqkZwn^yp_|sa}sb|p^{n\qkXwjX~k”†q“…p–„n—‡qœ‰s›ˆr‹u¡Œv¢wŸŠyœŠwŸŒu¡Šs•…pˆ}kwtesn`rk\ti\ym`oc€qdob~m`|l`xj`wj`}lb|lazk_uh[rh[wn_~rdqd†tg‰xl†xl€th~pe€rf‚sgƒrg‡uj‡tiƒrg„vi…vjƒrg†qh‹tjˆui…qe†rg‰tkxnypzn‘}pŽ{nˆvk†uj‰ym}qŽ}r|p‹yn‹xmŠwlŒwnˆtjŠum‹woŒzpŠxn…vj†vj‹yn‘}p‘{p‘xo’zpxo‹vmˆsj‡uk‰xnŠxm‹yo‰vo‡tm„rh…rgƒpeˆshŠujˆsk…rj‡umŽzn{p{m{mzoynŒvkŠvk†sh‹xoŽyqvn‹woŠum‰ti‡rgƒmb†peŒuk‹ulƒoe„pf‡sj‰vlŒvnŒvnxpŽxpwo‡qi„ri†rhˆsjˆuiˆwk…vi†slˆum…rj‚pg‚ph„qj…qimdxg`ocƒqfƒpd‚rg†ri‰rjˆohƒlbkb‰pe‹tj‹ujŠwkŠwk‡wj†rgmbk`‚ncƒncƒodpdmengƒpi‚og„pfŒui‹vk„ogoeoe†viŠukŠwl‰wl‰vmˆum†tkpe|jb‰smŒvpˆsm†riƒpgˆul…si†tkˆvlŠxnŽwr‹vnˆsk‹vn{s‘}r“|s’}uzsyq…qj„qi†ukzqzsxpyr‹yrzr‰vnƒqi…sk‰wo‹xpŠvn‰tlŽzo{p’|qzoŒyn‹xmŠxm†ti}l`…vi{tvŽ~uŒ|sŒ|sŒyq‡vj‚pe…th‰xlŠwnˆvn‚qk‚qi„rj‡sl†sjŠwl‡tj…tj~mfq`Y{ib‚ogƒoh‚oh…ri„ri„rh~kazic~le‚pj‚qhqfma‚ogog|jb{i`‚ph„sj‚ph~ldyha€nfof‚odod€menf€me{h`yf_oe‚phƒpf‡sh‡uh„tf…pgmbs_Tzh]|ia~jdziayi^|j_}j_€lbjc„pdƒrfrhƒxn}pg‚tg‡sh†si†sj†rk‚pg‚ph~pg{mc…vm…ulˆxlˆwlƒvh†tiˆtjpfzk_~se†vmˆxo„tk~ne}mdripgph‡ul‡ujˆvk†ti|obzma‡ymˆzn†ymŠ}q‹~q‰{n‡xlph}pg„yqŒ|q|pŒ|pˆymˆ|oƒylrizndvl„yo‡xo‹zqŒ{r…ulri|nb}od€uiŠyo}rŒ|p‰ym‡wmyi`ƒrj†xn‡xl‡shƒpg|kd€tm‰|q‹|oŒ|ssŒ€o‰~rŠ|ryldxof€wkƒthxjbvlaslbpkbqh_mb[pg[vmari^uj^xncvmagdYph^ymdymdznezqh{pdwn`sk]jbVsj^wlbxlbymcwkath^xh`wg^naZxle|pizpe{pe}qeqd{matf\g\Ri^Vpe^vf`l`Ypd[tg]tfZvgZpg^si_ncZncYnd[wndsg€sg}qerf~nf~ofxjdtka€vmˆzm†vn‚wm‚ujuj~tjoh`e_]e_`k`]l`ckabkeafc^gdaoghtjlxmmwllvlltmkqs{qqulltfie[\nllsllwlmvjjwklqehofgneeqggoefmdeicaig`ihgojiqhhpfega`iedonhmlhnlhhhg[`]^dcnplnnjpmmkih\[XNQK;bH@gMAfOCgQ?dNAaJ?ZCC^GAcK@fP@gT?gP>hNBjVDnXGuZGu^IxaGwbFv`Eq[DlVDjUEmWDnWAkT>dN>bM:aI=eL?fP=fO@fQBiTAgQ>eN>fM@hO>gM=fKoWAnWChR@`K=aL:^E8\D:^F?hOAoXCr]@mW;iS:eP:cM9_K:^J7[K>_NBdSElWFpXCkPGkUEkTDjUFoZNwfR|jGrdEl\EfWA\LAVGJ]NF`PJcSKbSHbPKgTPnXOmZOkXPlYNo\Sq_Yradvcgucivcfrahq`gl[hhZbaSfcUlgXriXvlY|p]|o\~n]‚q_…ub†ybŒyiŒyiŽ{j{jŽ|k‰wf|r_„r`™„qŸw›Œsœ‹q›ŠuŠuŠuž‹v¢x¢x {ŒxžŒvž‡s˜ƒqŒ|kzufwoatl_pdZyi_}lc|md|kb{i`zi`}lc~ld€jcƒnepc}naym]yo]}qdƒug„rgˆvk†vj‚uhƒrf‚pe~ma‡rh‡th„peƒpe‡ujŠwl‹wl‹ujymwk‰tg‰sg‹wkzo‘{p}p‘~q~rŠxnŠymre‡wk‰ym‡vk…uiƒsg†vj‰xkŒxmŒxmzs‘|tzt†vj†tizn‘}p“}n‘{nŽyq‹vn‹vn†qi„phˆsk†uiƒqh€meldƒrh†ui‰ujŠtiwlŠtl„qh‡ulxo‘~q‘~q‘~q‘~r‘}sŽxlˆui…sh‰wlŒwn‹tlŠsk‡ph‰rjˆrg…od†pdŠtiŠti‡sh‚oeƒpf‰zlŒyqŒyp‹xpŒyqŒxp‡tlˆti„pd…od‡qeƒqe€qb„ohŠumˆsk‡rjˆrlˆrl†rjle{ja€pd„rg‰uj…uiŠvkŠvk‹sl…mf‚kd…nd†qfŠsh…qf…qf‚ncƒodmb€la„pe„pe„pe~lb~lc€ng„rj†rjˆsizm‹wmwq…rk‚ohƒqjŒwlŠvk‰uj†ti„qi‚qh}md|jb†qjˆrlˆrj‚ldzh_ˆvm‰vn‰vnŠwoŠwoŽyq‹vn‰tl†qixp“~v”~s“~s‘|s{sˆtl€meog‰um‹vnŠto†qk…rkŠwo‹xpxpŽyqyqŽxpŽyqŠumŠvl{p‘}r|q~r|o|pŠyl…thƒrfŠxpŒ{r‡zpƒvl†vmŠxoŒwl†pf‰ujxpŠwoˆvn~mf‚qi‰vnŠwoypŽxlŽxmŠun„qjxf_~lfrjƒpjogpiriƒqh|kbzhazga~md‚og|jazh\mf‚og‚nfƒog‡rj‰tl‡rj€lfxe_|keƒqiƒrh„sj€of‚og‚og|iaye^zkbpfpd‚pd‚oa‚pbk`~j_yeZ~la~lbldxg^xg^mb…sh„ph„oh‹ujˆui‚rfpg{k_€oc†sl†sk…rj„sjpgƒrj}nexi`~ofpc€pd€oczm`{l`‚pe‚peqe€sf†tmˆum„qi~kcld†sk†wkŠzn‹{o}qŽ~r†wkzncxma‰|p‹|o|qŒzn‡{p…yo‚vl{nevj^vjˆxlˆxl‡wkth~uhztfpg|ne‚sj…wmˆwn‹zq‰xo„tk}of‚sg‡zn‡{oqŽp~n}qˆwmvc[†tk†yn†xl‡ti‡tjxh_ƒum‰{pŠ|p}tˆ}q„|l…{oƒtkyjawlbymd|l`~mbuk`mi^d_Urj_~ngynd}pgwkb}pgriykble[xoe}qgrh~qgzpf~qezodsj`ne\si`vjcwjavj`th^vj`xi`uf]mbZujbxmeujawnczpc}lc}lcrd[td[vg^th^p^WeWOvj_xlbyi^xj]xmc{neyjal`Vi_Uypf‚vjth}tgrgrf}pdxibukbwlƒululzrizqg|riyphldaf`^legqfatggtkimhakj`mjesijwmmullskknhgnjikaakccj`ai]`g_bd_aib`qgfoddj``e\]jeeskirkhqkglgdgfahkdnklqmlrkjoggg`_jgemjimjhmjiigc``]beafgchgddc_b`\UUQLOJeL;eL9bL;`L>bO@fPAhPAgN>fM>gM>fK9dI=hN?iQ@kV=iSmU9iQ9gP^I;[C=^F?fMCnXBp\?mW@nW:hR:eP_L?]KDcSGnXFoWGnTHoVFmXGpYDoZFs`Ft`Bk[DjZEgV?ZJ?TBDUDDZKI^OOdRKaOMfTPiXQmYOhTQkWMkVOkWYo\hsakvdfq`kp_mrblrahgYdbThbUrhY|m\‡vcŠzgŽ|j‘{i‘zh“~i•‚j™„q˜ƒq–ƒp•…q€l~kra‰ucŸ‡s¢yŸv Œuš‰tž‹u xŸŒw¢x¡Œw Œz›Œz›Šwžˆwœ…uŽ|l|teyobxmaxh_wg^|lb~mdzkbwi`{ja{ka€of†ph†pgƒreqd~o`ym[{n`€reqe‚re‚qg‚qhod…qf…qf…rf‡sh†rgƒod‰shyn‘{p“}r“}q“~s‘{pymwkwkwk|oŽzoŠwlŠxl‰um‡tm†vjˆxlˆxl„ui‚rf„thŒzm|q{p’~v’}v’{uŽ|qŠxmŒylyl{lwj‡sj‰tl‰tlˆsk…phˆsk‡sg†qh}jb~kc„ti‰ym{q‘{pŽxlxqŠum‡ulxo|q}p’r‘}rŒwnŽxlŠxj‡uiˆvlyn‹vj‹tl‰rjŠskŒum‰rk‡pi‡sh‰vk‹wk…sh„rg‡uj‹xpŒyqŠwoŠwoŠwn‡tl‡sh„od†pe‡rf…sf€obƒne‡rj‹vnŠtoŒvowrŠum‡sknf€nc„qfˆsiˆuhˆsiˆtiˆskŠsk…lfƒnb‡qf†rg†rglc|g`‚ncƒod…qf‡sh‰ujˆsh€nczh_|kcƒqk„pivlyoŒwnŽyq‡qlkd€mf„pe†rg„pe€la‚ohƒphng‚qhˆskŠtl‰skkeofˆumŠwoŒypzr{szrŽyrŠum…phŒwnŽyrynzoˆtiˆsk‡sknf…rj{s’{sxp‡sl„qkŽ{s|u‘|t”w–w–w‘}uŒvoŒxm|q~s}s~q{oŽ}p{oˆvj…th‰xo‰ypuk€sj‡wnŒ{szoynzs’}t{t‰xo~ng…tl‰xoˆumŒxo‹wlxp‹vn‰tlnf}le}oh‚ng|kdykd{oeqh‚pg|lcƒri„sj…rj€ne{i]ngƒph„qi„qi‡tlˆtl‰sjnfwd_yjc€ng€pg~md€ofof~kcxe]wd\zj^}ma}na}j`}j_€na…pfmbƒncƒrg‚peƒqf~nbzh_}jb„qi…rj…sh‹skŠti‡rg‚nc}h]maƒoh‚og€me~mdnd~mcyg_yf^}k`‚nd…pemawg^{l`„thˆxl„th„uk‡ul‰wn†sk}jb~kc‰voŒ|p}qŽ~rs}q†vjwm`wk`†xlŒ{p‰wlŠvl‚ul{oe}qh}peqd„vjˆwl‰ym‡wk‚ti}ugwob€uk†vm‡vm|s‹zqŠyp‹zqˆxo‚sj…wk‰|pˆ|pŒq}p}nŽ~q‰vmne…tk†ym‡zl†tg„pewf]qj…xk†yjƒtkwlvn`~sh†sk„rg‡wk‰xpyrxm‡vkwl_i_R€qg†qisj‚vltj‚sjrixi_odZ|rh~rh|pf}qg~rh|qgxndri^lcZrh_qf^th_th^vi_uh_wg^uh^si^vlcrf`laYvmb|qe‚qi€pg‚qipg{lcxi`l`XodYznd|pfui`ui^ynd|oe|mcj_UlcY{ri|pd{pdwmazqd|pd{k_gUOpe\ri^ymcth_ng_vmbypexogib^hb`nigtgbqddoebd_XdaWjfaoeeqeencce\\fa`fbbidcpfgocef`ae`bnjktlktmjujie^^aZZmihrjjqjgpkhge_\^Xdhbmhfkgemfehaagbakffngfmddngflebd`]mjgnommjjjifb`]PTNOSNBhNCkQCkQAhN@fP>eK@fLChNBgNCgPBiSCkRAiOEmXDnVDoTCrYGv_GybCs]AnXCoXFrXEqWEpVFqWClS@iP@hN>fMfL;fK;gLsZAqXDoV?kQ=hP7fN8gNAhQAfOAgPA`M=\H<]G=bK?gQ@mWBmW=jS>lV
fPBePBaJB]I@\IAfQFlVIlVGlSFkSElUEmXDnY>hV>bRDhWIkYEdOC\FE[EDZIG\INbNMcNPgUNhVXlXXiWViVUkXTiU^l[kuaitcipapn`ro`nr_ol[kfWmeVsgXƒqa’{j”‚p™„qœ…p›„p‡rš†p™ˆq™‡q™‡s—†r”…rŽlu_Œwe ‡v¢ŽyœŒxŸŒyœ‹wžŠwŠvžŠwŸŠv¡‹xŠxš‹x™Šwš‡x˜…w‰ykzpczob|ob~pcnb€pc‚pf‚qg|nbzm_{m`qdƒofndnc‚qdma}l_{j_|l`~nb}mc}ne~ne„pe†rgŠvkŠujŠujˆshˆth‰tiwl‘{p“}t|s“}s“}syo‹ui‰shŒvkzoŒwl‰shˆsjŒvnŽxqŽ{p}r{pŠyn‡vk…uiŽvm“{r“}u”w’}s}s‘|q‹vk†rh‹th‹uiŠtj„riˆul‰tk‹vmxnxoŽwlŠtk„nf‚me…riŠym|q{pzoyqŒzr‡ul‡tlyp}qŽ|oyp„rh‹ujŒzl‹zmŠxl{pŽxm‹vk‰tlˆtl‡skˆtmƒpjƒrh…si†tk†sjneƒpgˆtl‰um‡sk…qi„ph„qh‡riˆqg‰qhˆshˆtipd€la‡riŠum‹uoŒvpwrvo‹vn…qj€nc‚nc„odˆrh„oeƒog‡sk‰tjˆqh†qf…rf†qi‡rk~ia|f_k`…qg†rg‰uj‹wl†rg‚mbucZtd]zhakc‰si†rh†qiŠtn…oiƒnf†qhŠshˆsh†rgmb‚mf†qiƒrk…skŠvmxo‰tmƒohleƒphŠwo‹xqzr‹xqynŠum‰tlƒnfŠum‹vpymˆsh‚nc‰vj‹woŒyqŽ|p“~r’|q’|sŽxn‰vlŒxp‘|t’}u–‚y“~w“w’}u‹vo…si‰wlŒzoŒ{p†vj…thŠxmŽ|pŽ|qŒyl{sŠzqˆwn…ul‡wn{s|s{s‘}u“~v‘{t‹wp†un†tl„tk„sjƒsi‚rg„rj…sk…ri€mfofƒrlƒoh~leui]{nd…uj‰vj†vk…si†tjˆul‚of~j`ib…qi…rj„sjƒtjƒsk„rfnftcZwf_€nf}kbxjcuf^xg]}lc}jbmbƒoe‚od‚qe~nb|k`oe„pd…qf…ph…sg…sg†ug‚pezh^yf^‚og„rh‚qe…pi„of‚nbƒnb}h]j`‚pf}lbzj]wgY|l`|n`~mc€nbnc‡thˆuh†qeyia|nc„ui†vjƒrh‡tm…ulˆyo„tk{kb{kb„uk‰ykŠzm‰yl‡xlƒui}obxkb|mdƒskˆwnˆumˆum„tj{mbymb„ulˆxmŒzo‹zq‹zqˆvn…tl~qhyndƒxn…yoˆyp‹{r‹|s‰{qŒ{r‰ypph…wk‹~r‡{o‰zpˆxm‡vkˆwj‡si‚me‡uk‡ymˆ}p‰wjma|k`~of†wj†vhƒsksksi[}sjŠzpŽ|q}r‹{p{s|oŠyl{k^wfZ…viƒtj‚ul€ultk~ri€ritg^xj`|od{nc|pe{ncxlasjari`mdYkbXui]pbWpe[th^xlb{nd}me{mczpcynesg`na[yne}rg‚qk€piph{lc{maugZoe[tj_yndzpfrj`qj`wocvmbsk^k`Upg[umaxkbpf]mfYphZwl`yi[ue]|og{re|nfykcoe^rg}qhxmfi_]hb_mhdofaodcofdf_Xe^Wkc_ndcqeembbh^^ibcohiqkluikndda_^ccaifepifohelebb\[a]\hfelghnihlhefb^dc_jkhqjgqkiqlitoltpmrplupluolwpllffidcnkkpmoollffb[[ULOHJPKFnTFpSDnRBkP?dM>fL:gK=hMCiPEfQCiSCkRClQEmVCnUBmRDnWJxbFvaEu_Et]BnWBqW@oTBoUDqXEqWBnTBjS>hQaKA]I@aLAeNAhO@gN?gM;fK:gL:fM?kTApYCpZBqWInXAsY8sW;sX@nT@iP@gO;iN=lRFpVHoVEnVFgW@bP=`K;_FaJB`GE`HD_KBdQGkWGiTHgOFeMDdOFgSFkVAeSBcRHkWLpYJkTJhOIeKG^LDZEH]FNcMPgSNgU^iXfl\dm\_k[^iXfk[eo[frbgm]pj^ri[nn[rlYpiWqfXvgZ†qc˜q˜‡s™‡rœˆsˆsˆuœˆuž‰sžŠt›ˆs›ˆs—„r“ƒpŠ}g{g ‰w¢}›‰yœˆyš‰v›‡uœˆvœˆw‡v›†tšˆu–‡t’…s”ƒtŽ~p†wi{ocxk^qc‚teƒtd…ug‡rh…sgtf|qbzn_|n_}la}ma|ka|kb}jb€mela€ncqe~ne}oe|of…rf‰tjŠwmŒzo‰wlˆvkˆwh†qcˆrgŒvkyrŒxrŽvoysŽwpxpwmŽxm’|qŽxmŠti‹rjŽum“{r“}r’~s|q}r{o‰wlqlun”|tŽzo‹xm‰xkŒxmŒymŒvkŒumŽwo‰rk…th†uj‹wlyn“}q”{q—{q’xpŒun†oh…pg‡ujŒzozo‰ui‹wpŠwoˆxo†sk‹xo‹ynŽ|q‰wm…siŠugŽ{oŽ}p‹{n’~s‘zp‹yn‰un†skphme€ngpgof‚ph‚og…og…ng‡qi‡rj†pi‚me‚ld†qi‰qjŠtlŒslŠskŠsk‚pfƒod…qf‡sk‹to‹uoˆrlŒum‡rknfmamc‰sh‡nh‚le‚ng†tiŠujŒviŠwk‰uiˆsl‡rj„mf~f_~ja‚ne„oe…qg†rgƒockap^VrbZxg`‚nfˆrg~kcld‡qjˆtlŒxm‹xk‹ujŒvk‡sg€lb€kd…og‚oi†rkŒxmxoˆumƒpkmele„qk‡tm„rk„rkˆtiyn‰umŒwoŒwqys‘zo‹vj…rg‹wm}t‘w”ƒu•€t“~r•€s‘|qŠwl‰tl{rŒyq{rŠzp‹zrwp‰un†ti‰xmŒ|pŠznƒri{kb‹yp|u’w’|t“w~v{rˆwn‡tl‹vn|s~u~u|tys‰sn†tl€oh~ogtk}rg{pc~qi†wmˆwl‡uj†vn‡xqŠulƒqfzl^{naˆwkzmˆxlˆvj‰xlŠwl†qhle~ia‚nfƒqipgymczpeƒrdobxh_€nfofmbvharc\wh`md‚peƒqfŠsh†rf‚rfrf~nbnc„qd„oe„ogƒqgƒre†ve~maq^Txe^le~kb}k_zia{kaob‚reobƒtf…shre|l_tdWzm]rbqe€rf‚thˆxkˆzm†viwg`wi_se‚reqfnhofpg{lcug^xja~pf‚sdqc„tg~qc}ocyl`ƒsh‰xpŠzqŒ{rŒzr‹xp‡vj|ma|mb‰ypyq{s{sŒzrzr‰wnph}ne€xmƒxm‚sj…vm‚ukuk†uk‚riof…wj†yl„xl…tm‚qi~nbŠxmŒymŒxo‘~tŒ~r‚s{o‹xl{j^‚sj„ui…tgˆum‚qixj]{yo‰tŠ~pˆ~qˆ~s‰|t‚zlˆzmxhZ|k^thzre}rkwldwldtg`xlcuh_yj`|nb{l`znbyk_tf[mf]oh_mf\qi\vi\seWqeYxkb{od~rhpf}oe}qd|ofxicsf^|of{oe|oh{ngxlbykbzl_vi[nf\pg]rh^lcYjdYjg\qm_tl_vm`vn`ypdwob{oeqg]lfZzrf~sfqb€ph€vkƒwk†um~ngwic€qdofxjdg]Zhd]nkdqjfqggnece[Vi_Yma`oebnbal``l^_ladofhlgiqdfl`a__[^c\fe`mhcmfckdac^Zd``kkismouppqkijebkgernowpmtnkqliokgnkgkgcgicmmgigbfccfgfdeegefb_^d`\TTNDGAJPJEoSDpUApU?oWBiSAiO=eL@eKDiOHlQHnRDmRBlQDkQDlREpVErWJt[Ku]Kv_OydGu_Jr[DkUCkSGoVJsYDoTFmWClS@hO=eLfM>fMBoUDsXEpWGnXCpY>pY=rVgMAhT>iS@lUHt^Gq[Hq]Im^DhXBeQ>cM?ePBiS@jQFnWDlVBgS@eP>dOD`JEbJB^JEaMGfQEePHbOEaNEbNBbMGiTChQAiWFnXKqZJoTHkRIhRJbLFZDEYEL_JYgSehVpjXro]po]jmZeiWfiVhk[knZkjYnhWpgZrdZxfXweXxeX{gZŠve—ƒrš‡rš‡rž‰tœ‡rž†rŸˆsœ‡t‡u›‡u›‡u˜†s–…r’ƒm”ƒl™ˆrœ‹xš‰w™‡v›†t™…rœ†q–„o“‚p€p}m~mŒ{j|lŠxh…sd‚oc€lala‚pd…th…uiƒui„ui„th€od}la|j`{k^|l_{k^{l^~k_„pe…tj‰xlŠvlŠwl„qj€nh„te‡vhŒylŒxkŠwl†ujˆqj†pf„ob‹uiymypŽtkŽtkyn’|q‘|q‘~s—~t”}vŽyrˆskŠxl‹{lŽ}p~rŽ|q‹yoŒxqˆvl†peˆsfynzoŠti‹tkxpyr‘{p“}q‘{o‘{oŠwlˆvkyn{p‘~s“t‘}q{ovl‹sh‚ma‡shŒvoŒwo‰tmŠtlŒvnyqzn‹yn|oŒ{nzl‹vh‹xlzmŽ{n|o~pŽ{oŒwn‹vn†qik_€mc‚oe€of~kc~jbƒme‡qi‹skˆrj‹tl†rg„penbqd‡th‰ui‰um…phˆsk‡pj‚pf…od‹ui‹uk‰rl„pj‡pf‡qf†od‡pe‰sh‹uj…qild‚me…piŠumŠvoŒum‹tmˆsk‡rj…qizf^yfa{hc|jc|jd}kb~me€k_€k_„nc„nc‰th‹ti…pd‚l`‹uiym’|q’{qvoŽwoˆsknc}lanaƒme„oh…rkƒpi€mhmh€la…oeŒwmŠumŠtl„ng…nfxo‘{o’|q‘zq“|t’}vŽyr‰smˆslzt“}w“y‘ws|ozoŠulŠqm‰tnuqˆum‚ogˆtmxmŽzoŠzn~r}ryo…vinbˆvk‘t–v•v”w“~vzrŠym…vjvj‰zm‰|p„wo†vo‰vnŽwo†vk‡vk…sh…uiuh{qd~riˆxoŽyqŒwpŒyq‹zqym‡ukzib|kd†um‰wm†wk‚uithtk„rikd~jd…oh‡qflawgZ}mc‚ra‚qcƒpd„qfƒod‚ncwg^ud[~lb€of‚ng„qi„sj„rj‚pfmb{g\}g]~idzha~lb|k_|h_}h`|jbzg_€me„qfodmbtdV}m`„thƒshpg…sk…sk‚rg|oavj\ui]}pf‚qe‚qe„th„uluk~pgtb\td\{lc{maykbzjcyh_raXwe]{k_ƒsf„shƒpk…rj‰vj‡vipb{nb‹ymŒzmŒzoŒzo{pŽyq‹xm‚og}mgƒtm†zq‡xn†wn‚xmwmuh€nc‚mb€qj}lfƒqirj}ohynetf„sg‡tkŒxpŒxoŠwlŒwm…rg{ma†ym~q|qŽr~sŽ|s|szq~l`ƒtf‚sh‚rk€qkqi|k_}vi‡|p‡zo…|oƒxk†tjƒskrh{oaqc|ob|nbth\tfZsh^tkazmemf~mc}qd|rbzrbyobsf\nd\rh]tj]tk]tj\rfYmeZtl^{pb~re|qf{qiyofwmcnfZpf[wmcxmd|nanh^ge\lc]vkaym_tj`wn`wm`sj]i`Wle\}of{pexobxob|se|qc|q^ri[ri`}qirj|ug~uj€wm€ul‚tmzjfvd`|pfphqe]haYie`mb`rgcqf`mb]]YTha`pdeo`apbeqcgqgjshgsgeujhsjglf`ea\iecpiknihthimbc`ZZhdbldcnikndfmbcib_jfbojeregoffhdcgd`hgdkidrjhpkhihefidhlgimijmgolgec_RRNFH@PPEEnSCoTDqWBmVCiP@fM>cK?dKDjPGmTIpTDoTAlQDkQFnUDpVJtYHrXLv]Kw`N|eO~iNxaDoXAmSDoVGsYFrWCmVDnWCnUBlS@jP@jPCgQCiPAiPAhPAkP@kP>gNAgN@iPBoUCrXDnUDmWAnWAnX=lR>lR@mTEmXCnWErYHt[Gr\Ir^OsdJo_FlWAhR?hQAlUBmTBmUBkTFnXCiTChTGiQGhOB`KA]IC^JB\HC\HA\HC_K?`KChRFmVEiXHnXOqXPnVRmVSlUOdQJZHL\JQ`NaiXmk\vm_yrcwrcspall\ihXjhXliXmgVogVqeYqcWueXwfX{h[€m`yi˜ƒq›‡rš†q›ˆr›‡rœ‰tš‡qš‡t™‡tš‡u—‡t•…r”„q”ƒo•ƒq”‚p”ƒq”‚q“p“~n”n”}l’|l{lŠxj„rfƒpf„pgƒqfƒoe„pg…qf‚nc~k`}k`ƒqf…th‚sg‚sgoc€pd€nc€ncna€naob}la‚od‡rgˆvo{pyoŒymˆuk„sk„rd…qeŒuhŠsh‰uj†rg‰qhŠsgŠsgwkxp‘zswmŒvkzo”~s•€u—ƒxšƒx—v“~v‘}t‡vk…tg‡vj‰xmˆvk…tjŒxq‹xowlxl{o{pŒwlŒxlŽxqzs‘|q’}r”t“~s}r‰wlŠvk‰vk|q’}rynŒwlvlvlˆtiŠvkŒwp‹vm‹vn‹skvn‘{r~r}q|o}q{pyn‰ui‹vi‹xkŒzm‹ylŠwjˆvn‰um†rj„pdƒod†rg„pikcjb‚me‡rjŠtl‰tlŠumˆti‡sh€la€ma„pe‡sh…ph‚me„og…pi†qh†qeŠsh‹tj‰rk†pi…oe…od†qf‰tixmŠuj‡rj„og‚meƒnf†qi‰tlŠsk‡qi†qi‡rjƒog|ia~ickd€ld€kdjcka†qh‡rh‰tjŒwmwn‹vl‡qg†pgˆsiŽxoŽyoŒwn‰ul†si‡sgƒpd~k_~m^‡phŠtl„nh{g`xe^~ke‡riˆuiŒwmxp‹vn†ri‚pg„rhŒxm{p|r‘}v}t|s…tk…sk‡vmŒ{sŒyq†si†uj‹ynŽ{rwpxqxqwpŒxq…skˆtm’|p‘~sŒ{p{u‘|u“zt‰uk‚odƒqfŽ|q‘}rzo{s|tzr‹xm‰xm‰zn‹znˆyn…tmqk‰wpyq|qŠwlˆtiŠwl„th‚sg~siˆypyqyrŠyqˆzp‰znƒvkwkbui`€riƒskrfznb}qfqh„qi‚nf‚oh‰tlˆshƒodxf^|kb„re„rgƒpgƒphƒrh|l`zjayg_}mdogƒphng}lc|kb{ia}i]zeZi^kdkc‚pdvcXvd\le‚of„qi‡tl†tjƒrfodyh^{j`qf~me~mdpg€ngod{k_ufXscXyh_}j^€mbpd}mdte\obXu^Y}i`„pd„pe…sh…rhnfyh_xf^‚rf…ui†uj‡tn‡tlˆvk‡vi‚te~ocˆzm‹|qŠzpŠ{p‡xp†wnˆtkmfyib{ng€tk‚sjqhzoexoe€viƒshŠvkˆtk‹xn‹wmŽypŠxnyi^‰zmŒ|oŒyqŒzo‹znŠ{mŽ{qƒrguh\…ymŠ|p‘€uŽ‚tŽu‹{rŒyqƒrh€ob„tg‚rh€pi‚rk€pfzj]yre‚vi…xlwjsime~og‚ujƒwiƒwitgrgtirftj`wne}tjƒrjof}qe~reypbzoapcWmc[qi]uk^ti[rfZobVqfY{ob{ob|ocwkbrjbwldwmcqg[sj]ukatjavk]hdXa_Vtme{pfzpc~oe}oc|odrk^a]Snlcri}qgxoczpe{rf{pd~obrh[sk]{nc{odwnczrdypc{pf|pgyic}le~qgphmb[d^Xokgthfrhctgbka[e`[jdcsfhuggvikuijtikujishevihrgdg`\gb^kddpikmhgqeef]]b[[iedqhgohkshishhsjjrnjxqmymmtjjmgfifbqmispluoknjfee`ae`fjegkfklfigceb^LLHHJCUTKBkQDmSElSElSFgO?aI<_G?dLEmSIrWKrXGsXEqVFmTFmUCoVItYGpVGpXGsZGu^Ev^Ix`Es\BpYDrZFu\EtZDoXAmV@lUApUBqW@nTCkS@hN=dK>dLBiPBjQ?iP?eLAjQCoV?nTBmT?lU>iR>hQBkR>mS?pUCoYCpYEtZGu\Hs\Jr^KqbJp]GnXGqXAnU?mVCpZAnWCnWHr[HoYHnXGnUGlSBcNC]IBZFDXFDXEF\ID_KCcNFkUGnXFjWJnXRr\UqZZoY[lWZhW[fU[eS\fUeiYsn_{qc|rd}tezqbrk]ngYkbTpfVshWsfVvgZufZtdWwfZ{i]„pb{k˜‚pœ†t˜„r˜„r–…r”„p“„p“ƒr‘pn€o}l}l}oŽ|mzk‹yiŠwhˆufŠviykŽwgvf‹uj†sg€od|l`}ma~ncocncnc€nc€nc~lapeƒpf€pd~nb}maococqeˆqd„ocƒre‚ofmbma‡tmxozmŠwj‰vj„th‡rg…qf‹sh‹si‰rg†peŠrgvj‘xm‘{p“{u‘zs‘zqzoŽxmŽzo’}s–ƒx—u•t‘}r{t‹wo„qiƒtg†vjƒrf‡shŽxnzo{o‘~r|q”€u{pynyo|q{p|q‘}r{pŽ{p‹wm…qfˆtiyn’{pŠxkŠvjŽvjxlŽzm|pzrzr{sxpŽwown‘{oŽ{nŠxlŠxmyoxowm‹ti‰ujŒxm‰xm…th…ul‡tl‡tlŠvjŠtiŠtiŠsk‡qi‚meld…ph†qj†ti…sh†rg‚nc~i^~i]ƒoe„peƒoemc‚md†qiˆqi‰qh‹qgtjŒtk‰qj„pf…qf†rgynŠvl‡th†qiƒnf‚mejbƒnf†qi‡ph…og€kc…phƒog€me„ng„ogƒnf‡ri„peƒoc‰tm‹um‹vn‹vnwpŒwo‡tl„ph‚og‡tl‡tl‡sk€ocoa…tgˆuh†sf‰tgvo’{sŠtl~hbzh`…rk‹wlxnŽyrzrxp‰tlof{lb€pd„th‡vl…tl‹xmŒynˆuj‡tiŒyn{p‰wl‚peƒtg‹wpŽzs“|v”v“~s’~uzr‡rl„rk{o~sŒ{rzswtsr‰ti‚mcpd‰wlŒ{o‡wk‚qiŒyq{s|qŽ|q‹|p{o‹yo‰wo…ul…tk{rzoŒzo‰xlˆxl…ui‚sg~rh€si†ulˆvmƒsj€tivisg}qe~ofrh‚qh~qdzla{mdƒriƒri†skˆul†ti†ti…shyf^yf`„rh‚pi~me€ng}kczi`{i^zh]}k_od~la~laq_Xvf\}ib}ja€l`la„pe‡rgmep`Wvd^€pi†sk…rkˆum‡tl„rhocxf_saZwe^vd]vc\xe^ud\taZr`VvdYyfZ~k^€ka‚od‚peohue\n]Tƒle…oe‰rgˆuh‰uiˆui‚qizj`xg^qe…ui‡wk‡tl†rkˆuk‡ujod|l^ƒtkƒtjƒsj‚ph}ng|mf„sjƒqiogƒtl…vm…wk…sk{oexof„{mˆ{o‹zo{n‘~r“t|rŒznobˆxl‹{oŠznŠzn…ylƒzkŠym{l`tg[€th…ylŒ|pŒ|o†xn€qh|md‚sh†vh…ulƒsjƒumsithwj[~tf†xj†xkul~rh{ha}of„yn‚vjƒxj‚wj„wi„xl|qdndXroazti}qg|kdykbrh[pfYi^PgZMj_UnaVsg[vk^vi^tf\xi\{l_}maxi`qe^siaynexnewmcyoezpeulbuk_faVhf[zqhyoewob~qg}qdzmask^]XOpnd€qjznevkbvlbsj`vi`zhaui^xm_}o_{lash`wobvj‚vj„tl‡wnˆwo…yo~qjbWRf`]tmmuiiujfrebh]Yc_Zicbrfgsgfsgemdanebujhvjhxijthhqjgulmwnn{oounnvjj`VVicbspoyooxqr{ooxnntnmunnxmkvhitihhaakfcnjgpkhqiiifca`\`d_dhcdhcfgahc__\XTTPQSKZYNBiSAhRDiREhPEcJDcJ@aICgOFmTHpXLtYGsXGqXEmTCkRCmTGrWIqWElSAlSBoUAoUEt]DqZAoXCpYGs]Ku_Gr]CpYAoXAoXAqW@pVDjR=bJ:\E<]H@cMBgQ>gN?fMBjQBnU=kQBmS?kT=gP>dN@iP>lR>qVCpYCqYFu[Jy^Kw^Jq[Ho^FmXIpZHsYFs[Cs[Cs[CqZDpYHs[GmWHnXHoVGmTDfQC`JBYFDWDGXFH]JOdQKeQJiUOpZMnZOo\Vs_]taew`kwaksbln_ij[hiZkj[ql]ym`zn`~na}m`wk]shZtfZueXteUxiYyi[|k^{j^{j^|j_ƒpczj•p—ƒr–ƒr“p‘po‰{i‰yj‡wg†vfƒsd†vgƒscˆth‰viˆuhˆug„qa„qb…qf‰uh‹uj‹ujŠuj†riqc}m_{k]}m`}n`}m`mb~la€ncod„rgƒqf€pd}ma|l`~nb€pd€odƒmc…pe‚pe‚qd}l_|j^†qj‹vl‹tiˆuh„se‚se†rhŠvkwlvltj‰rh‹seŒujŽym‘zr|t{t}rŽzo‰uj‡tiyn‘}r‘|p|p‘|r{pŽyqŠvn†ujˆwl†si‰tiŽxm•}r’}v’}t•€u“u‘}rŽzo‰uj‡siŠvk‹wlŒxmˆtjŒxm‹wlˆti‰shwlyn‹wl‹vkwm’zp“~s’~s’}v’|t{s‘zrŒumŠskŒvkŒwj‰uj†qg‰rkyq’ynukŠvkŒxmˆwl‡wj„sjˆum‹xpŒxmwlŠti‹tlŠsk‡ph~iajaƒmf„pe€nc€mb‚ncƒmbƒmcƒod„peƒod‚ncƒod…qf‡qk‹tkŒtjŽuk‹uk‰tl‡sg„pe‚od†rgˆti†rgƒnfƒnfƒnfƒnf…ph‡rjˆqi„nf‚me…pg‡sj†skˆsh‰shŠskŠsk‰rkˆqj„qiˆumˆum‡tl„rj„qiŠwoƒpiƒph†sk†rk…qj€pc€qdŠxmŒzoŽzp‘}s–w–wŽxp…ph~kd†slwpxqzrŒwo‹wm…rf{lb{mb€re…uiƒrhogvkynxn‘zp’|q“|r{n‡ujƒqh‹xo‘}u–w’t’t•€w{s‰sm†oi‚rfˆvkˆum‡slŠsoŒsqˆuj‡sh‰wlŽ|q|p†vjƒriŠxo}u‘}r}rŽ~r‘|u{tŒyp„qi‚qi†voŠzoƒvk€wk{re€uisfqh‚tk„tjƒtkofwka†vj†vj†uj†ui‡uk†rjri€of|jbpgƒrg‡xk‹xq†ti…uimbtaZxd^ldld|icxf_sbZxi`€mb‚peod‚pe‚pemara[vd]}lc~jc„ogƒoe‡rg…rgmetcZsc\phƒpe‚pf…qj‚og}kbyf^uc\vd]zia~kd}kd{g`uc\o\TtaYƒodƒpc‡sd„rh†sh‡ui…sk}kb{iaƒog†si†uh…uh„thqe‚og|iaxe]oc„rg„rf„qi‚og~kc„rg€nc€ob…sj†qi†ph„nh}jcwh`ˆuoˆwo‰xoŠ|nˆzn‰{n…wn}rh{qg‚ylŠ}q}qŠ|nŠ|oŠ|p‹|p…vj{k\†vjˆxkˆwl…xlth{sf€qe€rf|oc‚vj‡ym‹|pŠ{m…xmvka}qg„xmŠ{m‰vnˆwo†yo„xnvivj\ƒxj‡wj†vjsg|oeyg_|sf€thui€sg‚tg€seyl`pcWldWlk]lh[qgZuf]nbXqf]tj^sfZvj[mcZjaVvk^xl`xmczjc|m`~nb}mcwg`qe]tjbzpfxndwmcyoewmculbuh]e^TkcZxmdvlark^ok_tn`vnasi\qe\xkd{mcth^ndYqg^siavia}ke}pgvi†xj~pfwlexl‚yl„xlƒwm‡xo‰xo…wpzmhaXVgbalfeqddsgdob^h^Yic`mhhwjmxmlshfh_]pgdxmk|pn|mnynnwooxsruv}opsnmthhcZZjccnjiukkslipffkcciedmgftghtfgrggqlksokspltqmtqomih^_[ghdjninpjlmgkfba^ZXVRZ[T[YOCiSAfQAeOBdMB`FCbIEgNFjRFnUIqWKqXEnUBlSCiQBfP@gQBlSBjP?gN?fMAiP@jP@mVAmV@jS>gQEkWJp\Hq\Eo[AoXBpY?oW>nUAhO;^F;ZE:[E;]H@ePClSDjQDlSBnU>mSBmSBjT>fP=fP=hN>mS@pVCqZBrXBrWHw\Ht[GnXEjWAhRCjRHqWJw_Dt\Es]CpZDnWFlWGmWLnXOpXPrZLmXIhSIbOL`MP_MRaOVeSWhUXjW]o\]r^^sbcwfixepyevyevrevoctm_mj]jhZleXqg[vh\zi^|i^ueYqcXufZyi]~n_m^m_ƒoamcma}k`€nbˆvgŒ|k|nŠylˆwj‡wi„sf€ob~na}l_yi\|j]~l_pc…rc‰vhŠwi‡uh‡tg‚pdpdƒse‡uf‡ui‡thƒphpb€obn`}m_~m_|k_}l`€nc„qg‡uj‰ti‰uj†ti„rg€pd{k_{l`|l`~lanc€qe€rdnana‡rg‹ti‰sf‰sg‚pc‚qf‡um‹yqyp’zp‘{pyo‰uh‡rg‡sl‹wn‹yo‡wlˆvk‡uj‰uj†rg‡tixn‰ul‰tjzn‘}qzpŒwpŒxpŽzs|qŒwmxmŽyn|t|t}uŽzrzo‹ynŒwl‰ti‹vkŒwl‹um‰skŠumŽxpxpxq”{t“{t‘}s{q‘xo’xp‘|r|rzrxpŽypŒum‹tlˆrjumwnŠul‡sh‡qhzqzoŽyn{p|q‹xl‰vk†sl‡skŠunŒxl‰ujˆsh‡qi‰sk‡ph‚kc„kc†nfƒod€lamb„pe„oh…pi‡sg‡sh…qf…rf…rf†re„rj‰slˆtiˆsh†qfƒph„qfnc‚od…rg‡ti‚ocld‚me„og‡rj‰tl‡skŠth…qe„pe…qe…rg‡ujˆsj‡rjŠumŠum‹uo†pk„qj†tl†tl‚og€mf„rj‡ul†sj†tj†tj‡tk…sj‚qe€odˆulŒypŽ|u‘~w•u~s‹xp†tknf€og‡sj‡rj‡rj†rh‰uiˆuj†um…tj…sh…rg†rh…nfŠsl‘yr”|u“{t”}u”|u’t‹woƒqi†sk}t•u}r‹xoŽ{qŽypŠvlndˆvj‹xmŒyo‰sm‰tnŒxqŽ{q}rŽ|q}r}rzoˆum‰umxpŽ{pŽ}r‹}p‹yq‹wmŠuj‚pemeƒrl†ul€ukyqgxoeƒwn‰xq‡vj‰xlŠzn‡xk€rfzl`„sg‰wkŠxk‹xk†uk†ul‚sj€nezg_€mc‚peƒshƒpi~ne~oc{l`zg^le„me‚me~jdwe^sbX~ob…qf‡rg†rgƒqf…sh‚qdwf`td]mf‚of‚og…piqeog|jcuc\td[}mb~laodƒpfldxe]xe]|jc€og‡slŠxn‰uk‚lb{hao\Uub[‚pf…ug‡wf†uiˆvj‡wk‡vmnexg^mf~lc~nb€pd~pdxh]€mezf^zg_€ocƒqfoeƒqdlc|ja…rj‰ukŠwi‰wl‹vl‰siˆsj|kcxiaƒtnˆwpˆxlŠym…vj‡ym„ypwndwmc~uhˆznŒ|pˆ|m€uh}ritj|oc|o^†vj‡xjˆyjˆxkriwkc‚shˆzn‹{oŠ{o}rŒ{p‰zm…xmsi`}si„yoˆ|mŠwn†wlƒwlƒxn|rgwk`‚tj…siƒqg|ob|nb|k^yl`vi^}mdrg„sgrc€qezk_ri]liZnk\um^xk^ymbxnezmd|of{kakcYoe[ypcxodxmd{ngznd|nf{mfse]pd[rj_ul_tj`tiash`si_ri\m^Vj_UmbXse[uh_nf]fdXpk^wobrg~ph€riƒuhxk`mcXtj`zpe{ofƒrh~tixm…wnykdxneyp‚yp„{qƒwo‚ulqh}phpc^cZZgbdoijtgguigna^g\Ymheuoowjnvllpgdha_rifvklykmvhipghlgimghohfuhfrmlvjjukloihronyoovokpieb^]kkjtop{mp{qqvnnuqpsqmqplsqmnhhfbbYZVbd``b[bd^a`Z`\WVROUSOWVO[YOCfRAfRAeP?bJ@_EAaHFiNGkSChO@fPEiQ@gN@gN@aJAbLBgPBjQAiPCiODiOAfL@fL?hPBiR@fO9_K<`L?aN>fQBlWDoZAoW?nV?nW>hN>eMCgR@eO?gS@jUFpXJqWGpWFsXCrWFqWHnYDjTmT?nTCrZCsY@rVCsWEoVBiS@fR;aL=eLCkQIt\Fu^Gs^EoZCjTElVLoWOqXWt]Vv^Tt_Ss]RnZTkYZgU_lZ^iWblZhp`ltcmvdkuepyisxhzwe|uazpdyl`vj_oh[kgZgaToeYug[zh^|i^zi]xi]wh^{k^}m]„pa†rb‡pc‚nc‚mc}ia{i^}n`r`tg{mayj]}la|j_}j_{i^}k`{h\{g\~i^…oc…sa‡ud…sd†re…qeƒoe{oa~o`€qbƒsd‚qenckd‚og‚ngƒph‚ph‚oh|mancod„rg‡tiŠuj†uiƒqf€oc{k_zk_{l`}nb}oc}pd~pb‚qdƒtfŒvjzl{k‹ui…sg‚qg„sk‡ulŒwowlŽwmŠujˆtiƒofndƒri‚sf~qcƒqf…ti‡ujŠvkŠwk‘{q‹upŠvm|o}p‘}q|p“{s“|t|qŽzoˆuiˆuiysŒyrŒyq‡tl…sgŠwlymynyn’|qyq‹tk‹voyq‘zr”}u”{t•|t‘|u’{u‘wqsmyr‘ztxo‰tl‡skŒtlŒumxp”xrxqzr‹xl‰tixlŽzqxpzrŽyqŒxp‰tlŠumˆrk‰tl‰uj†ui…sh„qi‡rjŠskŠskŠng‹og‰tg‡qf„peƒoc„qj†sk‰sj‡sh„pf…se…reƒpcog…qj…qf‚odnc‚qg…sg„rgpf‡uj‰vk‚pekcld†qi‡rjˆsk‰tlŠthŠtj…qfmcnc‚pe†pi…pi…oi‰sm‹upŠuo„sk†un…sl‚ping‚phˆuk‹xlŒxmŠvkŠwl‹vk†qimeng‡unŠxrŠxr‡uk„rg„sjri~nd}pf‡rkˆsk„og„pe‡shŠwkŠwo‹xoŽxmŒwltlˆnh…sk‹yr{t|uŽ|u‹xqŽ{s‰un}ld„qjŒyn{n‹xpnfˆtm|qŽ{oxlŽzo{p‘}rŒxm‡vjŠzn|p~s{p|q}qŽzp‰tl…ph‰tl‰xlŠzn}pdƒqiˆtkˆth…qf…qjˆuoxo…ul|qg|qg‰ypŽyqŽ{o‹yn‹{o‹|oƒtg{la}ocse…tfƒui€th|siph}kb€lc…qfƒqg…vj‚oiyh`pesf„sg‡rj‡ph‡qi„mg|j`yh\~obˆrh†rg†rfƒqf…rg€oduf^n]V{jc~ldld‚nf|lc|kcvd^yg`~mbpdƒrf…sh…shng}jb|ha€pf…tk…si‹xmˆth†pe‚nfwd^ua[‚pf‚seƒwe‚sg€rf~pc|me{kbzi`€le‚mfƒnf‚qf{g_ub[ogng€meodƒqfƒrg„qd|ja{ja‡tlŠumym†xj…vh‰wl…uj|pctkaslˆxoˆxl†uh‚sf~reyqgtk`yoeƒvj…wjˆxlŠ|m…wl|og~mg„shˆwh‹|n‹zkŠykˆxkqjsc]„vj}qŽ|qŒ{oŒzoŒzo‰xlvkf]Rzri€ujƒwh†tisfrfwmdrh_{qh„sl†rk…rk€re€serctgYsdXlc…sl‰vk‡uf†tjpdvj_ljZnk\woa{qa{qdynfyldxjc|jcme[ng[vpcwnewnexngulcshavhaqc]pfZoeXqf[j`Vg\Tvkcwmcyob}ldzkaof‚ofzjbmf[tj`}tfviuh}tk{tj~sethZkaU{rdypeync}p_ypdzpiykenaZiaUslcyriypgsjawldxneuf_m`[e]^hefmghsggrfdm`_cXVlfdpijsfiujlqiiqkgskkuhkxjnvjkjcdeabqmnvpntpzss~rrzqqxrpwtryqpxqmkea]]Ycgekjjuhjpggmffebaiieikgefbf_a`]][\W`a]ac]_c[ed^[VSNIFSRNYXQYUL>bM=dO=dM?dL?bJ=`HBfNFhPEdM@]F@aHCdKDfK=aG@eKBhOBhPDlSBkRChNDdK@cJhQ=hQ>lS?oUApUCsXGu[GqZFlXBeRBaO>dO@ePHeQMnZHu[Lq]Mp\HnZJq[Pt_Vr^Xs__v_cvacxacu_eq[go_ip\mp\nr]suavxguxitvguxhuwgxtexq`€qc~pbyl^qgYpfXmcUpgZsj\yn`~oc‚oe„kdkazf[{j]na€pcpb€mc~la}k`zi\zi\€oa}oc|k`|h]i^€k`‚la…lcƒk`i[j\|i]|h]€m_qdzobwmcvjb{kdnc~mbmb€nb~m_{l_na‚qdqe‚qf€sh}qgpg|md~nepgpgƒpi~qd€qeqeod€nc…pe„sg€od€oc„qg…sh‰xmyoymŽznŽ{n‡vjƒph‚pd„sf…tg†uh‡uh†th„rj‚of‚obƒoc„ndha€me…ohŠtlŽvoyq‘|t}rzoˆvk†tiŽ|sŽ{s|qzoŒymxqvnŠskŒumŠvo…tkƒri‡rkŽvm}q”€s•€t’{t”}v’yt‹vnwoŽwo“{s”zs’yr{uys‘ys’xr”xs–ys“}qŽwlvk‹xmŒwp|t’|v“}v’}u’}uŠvk‰uj‰viymŽzoŠvkŠsk‰qj‰xlˆujˆsgunŠsl†qi…oi…piŒxovmvoŒto‹uk‰ujƒqenf„nf‡oiƒpc…se…oc‡qfˆrg…od‚nf…sh…sg€pd~ld~keˆriˆtiŠwkzpŽuo‹qk†me„le…me„ogme‚og„og„pe†sfƒpc€l`‚me†nf†qh€me„qiŽxpwp‹up‹upŠupŒwq‡qk…pi†ujˆxl‰zm…viˆwk†vjƒpi}jbldˆun‡tm…qlnglf…rj…rf…reŠtg‰sj‰skˆskƒqf…ui‰ymxryqwl‘ymŠti„pe„rf‰wj‹xmxp†rkƒpi…tm†tmˆumŠvnzr‘|tŽxmƒpd‚qgŽ}tŽ{uzt|s|u’}uzs†ul„ulˆxr‡xp†xlƒthƒsk…tm‹smˆoj‹tl‘zsxm‡qfƒnfŠumŒwpŠun‰vnŒyqzlzn†th…thŠyo‹zq‰zn‡xl‰wkŠwl†rg~k`|na‚qf…tjƒrh|mc~rdˆui†uh†uh‰xkŒyk‹xlˆuk€mbnc†rhˆuj‰vkˆwk…th‚pg}kcyfZ{i\}na~na€ng€mf|kdtf_k`Zzc\…lama}lb…mg‚ld€lczi^od†riˆsm‰rjŠsl‡rj…rj}kbxh_‚og…rhˆrf‡qeƒpfkd{k_wg]we^~leƒrgƒsf‚ob|k^qbY}neƒsf†ufƒsg„tg„rg„rg€lc~ha„pe…pfƒph‡rf…qf…reƒnf}kbvg[rf†vk‡vk„uh€sfzpd{pdylcpg„slˆulˆvk‡wjƒujynfyme†{p†xm}qŒyr‹xq‹{nŠyo~ofmd„ri‰wj†yo†yo…ynƒtj|mel]Tƒui‡wk‹wmŽzoŒxn…th|nfm`Xsf^si‚vl„xkˆwi…ujqisf^€ti„wiˆwkˆwlˆxl‰ym‰ym…thwk\ti[ƒvi‡uj‡vktipg}ndwl`neVqj[vnaxocxofulbvkexkfwfcnbYsg^sj`wmdti_dYOsg]~lbka{k`wg_zhb{k]reYqhZwoe|rh}qh~qd}rg}qg€qhxkbjaYvod}qh~rh|sh}tj€si€octbZraY{ib{kdzibtgWqeWpdXwjaxkbzkczoe{phwndj`Yzlfpk‡rktf`e^[maaqebpf_thdh]Zi^]ukhxll}poxpoyqqyqqxmmynpynpvmngaahdbpmiqmmtnoulknkjkhftmnwnovoqukjaZ[a][lddujjtkkmeec_^dfdimjkjipmkide^\[aa``f`ad`cd`e`]]\VZZR[WP]VM]SI=aL`G>aIAcKCfNBdLA`H@[EA`GBbIBbI@bICdKEhNCgO@hOBkQBeLBbI<_EaI>]E?[DCaHDdKDeLFfMB]DB[CD_IEhOCgOCeKDdKAfK?cK@eL@eK?bH?^HA]IFcMIiQKnXNu_P{dP|eO}jM{eEtZHu[Mv^NybPzcMw`Kw`Kw`NzcLzcN{aJwaCs]Es]DoYDrX@pWFu\Hx`JybIv_Lv^Os`Rq^Vs_VwbW|fT{bXuaVs^Wv^Yyacyblwbtvcttbps`ruevvg~wh|sezpczmayk_yl`vk]wodxrfxreyrfzqdxoaqe‚sgƒsg‚qe‚oe€oczj^wgZvhZvi[zk^yi]xg^zi_zi]{i^€lam`oa}l_{j]{h^}k`mbod€laƒmb}i^wdYrbVxh\xh\tdYvcYvcXzf[}g[~k^|l^|l_wgZueYwgZ}m`„rd„pe‚mb~lb‚ob~k^€l`€nc€nb~kcld€me†qiˆsl‡skŠsk„sh„rf†rgŠti†tiˆvkˆvkƒqfoe†ti…sh‚pd„sjph}jcle„ng…qhŠtm‰tl‹vo‰ul‡qi€kcƒmf‚md…re‡tgƒne€ldpf}i`h_‹rj‹sk‰sj‚oh‚nf‰tl{p’|p“}o–u”~s’{p‰umŠum‹vn‰vnˆvm„sj†sk†rj…ph†ofŒunŽwq|u{s‡woŒwoŒwo‘|t}u{s{svo’yr“|t”w•y‘w{szs’~tŒyn‹wk”~r|qŽzoŠvk‹wlŽzo}r•{t”|u“{t{tˆvn‡rlwnvmŽymŽxpwoŒtl…qfƒod†qg‰ujŠvk†rg†qj‰tlˆskŠumŠul‰uj‰uj‰vjˆrg‡ph…nf‰skŒsiŒtjŠti‰sh†qfl`ƒha…nd‰vi†sg…pe‡pg‡rj‡qi‡ph†ph‹pi‰ph…oiƒoeƒod†rg…qg…oi„qi„qi…ph„og‚og…rj‡qi‚ndƒod‹wlŠwkŠwi†qj‰tl‹vnˆtl…ph‡rjxpŽyqŽyq{sŽyqxp‡tm€nf€of€sf…vj‚vhƒmf„og…rj†thƒqf…sh‰qk…ph‚odmc‰voŒyrŽ{s{s‘|tŒwo‰um„qj…rkˆtm‹xq‹xp†sk†sk†sk…rj‚ogˆumŠwo‰xonf‚phŒxpŽyq‘zr‘{r{u‘~wŽ{t‡tm„qiŒxr‹{qŒzo‹xpŽyqŒvp†pj|jb€nf…tk†ulqh}nd‡tm‹yq}uŒyq‹wozr‹xq€pirk‰zs“y”y’w’}v’~xzu…skpg†rkˆun‰vnˆumˆskƒnf€menf‚pg†sk†sk‡tl„qh‚oh|jcyga‚qh‚qiŠvkŠvm‰voˆun„qi~kc{hbldƒng‚nckb{jaoemcla†rfˆsj‰tm…uiƒrfna~m`‚qe‚qd…rkˆvm†uh†uhƒpg|jb‚leˆsk‰uj‡sh…qi„of‚pe‚oe{i^odƒri…tl‡sl‚ph}jd{h`€nd€nc…tk†sk†slƒqiƒtj}pewkbƒtl…vmˆwk‡wjˆxl‡wkshqh[xl`‚sg‰uj‡xl…vj€tjzndwnculb~qgsisi~rhtj€vk‚sfpf…wn†wn‰wm‰xkŠvk‹xnŠymrf‚th‡znŠyl‹{n‹|n‰zl‰yl‰xk}pd€seƒui„ul€qh€qiƒsfƒsjogwg`€qg„tiƒsg€qepdƒth…uiƒsg…shth‚ukƒrizndsja~mb€nfohƒrj„rh†uh|pfncYslavpcxre~ui~uh}ug}sfzqcmdWri\zqgymcymcti`uka|lbxjape[qf]vmdtkbrh`meapkdwoeyl`}na~tc€ug„vh}pfldZwphtm|si}tjwmui€thyockdZxof|pf|pfzpdzqcofwi`peXzrd~tf€vgxh]hbZgd`jcdsgipffodebYYi``phhqiivkkqhdg][mccvhjvilsfikab`ZYa\[idcngfh``i`ba]]edde_`hbafcbcb\[^Zmpkuqm|tq}wtyutqonomlommpmmlghad``cacifikihibdd[]ZUKHCTQL\WR^WPaWPAiPaIZBD\CC\FCcKAdMCcJBdJ@eK@cJ?fK>eJ=cH=\E?YD?ZHD`MEfQFjWJs_LwcMyfO{gNzdLy_M{aO|dN{dP}fQ}fOzcNxbMv_Nv`Kt^HuaFt_Cr[BpYDpZEs\Eu]IxaJw`NxaXuccxfeyfc|i_}ia}fbyg^wc]yf[{dc{fm{frxdtweqsdnsbrrbxqczpbznbzjavg^ylayoa~tk|tjythzsf|sf|qexnazob}oc€qe‚pd}k`{h_zi]wgWwgWzi[{g[xf^zg_{i`{i^mb€oe€oanb|k^xf[zh]{i^zi]yh\|h]~i^}i^zg]{i\~jazf_uc[wd[veY|h]}k^}k`{k_|l`wh\qaTxh[oak`j_i^naƒpc‚nc„od†qf…og~ld‚og…rj‡sk‡rjŠum†uj‰uj‰qg…nc„pe†vi„rgodma‚peƒqeƒpf„tg‚pgng}jcne…tg†ukˆwm‰wn„si„si~mb~g_|g^‚ob‚oc~i`|ib€maƒnb„oc‰tiŠvk‰uj„rhƒof‹wk‘zp•t–~r–}s–t•~s‹vo†rj„qi‡sk†skld„nf‡rjˆqi‰ohŽunŒwoyrŠxo†wnŽwoŽyq”w‘|tŽ{rŒzryo‰tk‹vlŽzp‘}tŒxoˆsjŽyp‘}r“}r“|s•~t”t‘~rŠvjŠvk{p’~s˜v•v•vzs‹wp‡tl‹shŒukŒwl‡sl‰skvoŒuiŒtl‰qjŒvoŒvnˆti„qjˆsk‹um‹uk‰ujˆvk‰uj‰vj‡ph„meƒldˆqjŠsk‰qk†oh†oh…ph…qe‡lgŠqk‹vn‰tk„of‡pi‹rjŒsl‹skŽtmumŠrj†pjƒmfƒoeƒod„oh„nh‚nf…ogˆphˆph…of†qiƒnf‚lelc…qgŠvk‹wlwpyryrŽxq‰sl‰slŠxoŒzqŠxo‰xl†ui‡vj†sk‚og„rjˆvlˆwl„ui‚ognf†skˆvkˆvk‡ujŒto‰ul‚oenf…rkŠvqŒyqxq‹un‹un‡slƒpi„nh‰rlŠvo‡tlnf†skŠwqyqwoyq{rˆzm†rjƒogˆvnv}t‘|tŽ{tŽ{t‹ws‰tp€mg„qj‚ri„sk€ofƒpiŠum‹vn†rjŠunŒyqŠxo…sk€nfƒqi|u‘~u‘~uzq{pŽ{t…tnsl…xpŽ}v‘~w‘€v{r‰vo‚qipg~pf†tk‡tlŠwo‰vnˆrk„oh€nf„sj†ulˆwn‡wn‰xnˆvi„ri~mezh`pf‚sf‰ukˆum…slph‚qh}la~fame‚qh†pi€lbwj\|ld†ukŒxmzoŽyoxp‹yp‰wnneoe†vl…vk‰tmŠxnˆxk†vi†tkkc{ia„rh„rh„rgƒpgnf{ha€me}j_nd„sh…vm†siƒpg~kb{h`†um‡wlˆyk‰xl‡tl‰vo‚tlyoftjb|qh„um†vj„tgƒtd‚qhxjaqeYwk_€od…qe†ugƒsg~pfxkcylcsjƒsh„sk‚sl‚tl‚wmƒznse}oe†{qˆzpˆyoŠylŠ{o‹{pŠ{o€qe€rg†xl‡vj‡wk†ylui€tgpcpdpdpd~ocxh^xi_ƒuh„vi€uh‚th„uh‡vj‡xmre}pcƒui…xl†xm„uhtgth…tjzmatka|rf}qh€pkpj€pg€qcmaXg\Rukaxnezof{ogsj_wma{ncth]rg\ulavmbvi`oc[ibYtma}re}nd}oe~qh{pgzofvmcf^Vtpfwnd{mc~pc~ug„ukˆwm|mdsk`vqf}uk}si~si{rezmbvj^l`Stia|mfpiyiapf\xqe„si†wlˆ{pƒyn…zo†{opih`Zjfdmfgsfgrgej]_aVXjabneepeeoccmcdh^_rffrffthirfgg_]c\]hbckdepfgthhhabjggpoowrrwrpokjeb__b_kkipkitkjoigggefdcigeggcfc`b`\Y`Y_fbageehfef_caWUVONJEVSN]VQ_WS_UR@gO>hL;dK9eK;aI;cJ=dK^G>^E<`F9_E<]D;W>BX@B\E?]FAbJDcJBcI=bI>bG=dHY@@WF@[I?^M;_O>dSCl[JqaNxdO{dO~dM}bL|bMzdShQ}fS}fSycNu_Qu_PycKwdFuaFu]Cs[EqZEr[Cr[Iv`Iu^Ku]_wejwgmygfzhb{hj}hizjeyh]xfWzd\xdfyelwcnuclsbiq_ppaxob}qc}mdkd}kdzka{oaxnezshyrhxreyre{rdxoeulbymb}ndmd|ja~jb~l`~n_}j[k[h\~jb}h_zg^~ma}m`|l_~m`|k^zi\zh^xf[zh]tfYucXvcX}g\k`€j_ƒmaƒnd~jc€kdvdZudWwcZzh`zf^wh]zlath[seWwgZ~k^€i_€j_j_‚oc…se‰thŠujŠthˆrj„sj~menfng‚ngƒphƒsg…qg‹si‰qgƒodƒsg‚qfodmbmaƒqf†tiˆuh„qe‚of€of}m`qcƒtgƒsfƒsfobob}l`€jb€i`‚na€m`{i_zg_j^…od‰tiwlŒxmŠzo‹ym„rfƒod‹uj“yp’xq’yowm‘{p‹vn…sk…rjŒwnˆrjƒmd…kcŠphŒtl”wn’wnŽwmŽzpŠxn…uj‰sk‰umŽyqŽzs‰umˆtmŒxl‹wl‹xlyn|p‰tj†uhzo‘}s–v–w–w–ƒv“€s|p‰uj‹wkŽyq‘}q‘}rŽzp‹wmxqvn‹sh‹vkˆuk†rj‡skŠtmum‘voupvqwpŽxo…qj†qiŠrjŠuiŠvkƒqf…qd†ri‰sj…nf…nfŠql‹tn†oj€keƒmh†rl‡tjŽqoŽup‹vnŒwo„pi‡oiŠohrkŽtmŒrk‡qi‡ph†qk…nh…pf…rf„ngƒlf‚ld†nfŠngrk‹rk‡qiƒnh„nhld‡qi‡rjŠulyrŠvp‹wpŠwp‰vo„pj†wm‡xo„tlsgrf„vhˆtmˆumŠwo‹xp‰wk‰wk‚ph„qi†skˆvkˆwl‹vkŠun†tk}ofuka|ngƒtnˆvoˆsm…oi‰rmˆtm„rj‰rlŒvpŠwp‰vnƒqhƒqh|uzt{s{t’v‹|qŒum}ja„sjˆyoŠzq…tk„sjˆvp‹xt†soƒpjƒqi‚rkƒsl‚qhme‹xmŒxnŽyq|szsŽzr‰wn„qi„sjŒ{q‘~tŽ|pŠxk‰vj‹wp…ul~rh‚wm‹{rzr}qŠyp„sjne~qfuhŠxoŠxpzr‹wqŠtn„oi}lc…sj†um‡vm‡vm‰yo†vi‚re|kbxg^yk^}n`ƒpeƒqi~nf{meodpdˆohƒoh„tkˆqj„oeuh\xlbŠzp’~s”~s’|s{s|tŒyq…rj}ld~nfriˆtk†tjƒug~qcmckdnh…ti†vi…uhƒsi€nfxfa€lfƒoe„qd…uh…wk†th‡uh‚pepc‰xn‰xoˆ|hŠzj‰xl…sktlwneph`wldyjb€ocqb€qb}mbwjaymb}qe…sg‰sg†uf„tgƒsjviazkc„tlˆwk‡um…skƒtm‚vlƒwk}obylaƒwm…xoˆxm‡vi‡|p‡znƒvj|nb~oc}ocƒtg{nbtj]ypcuhth†uh„sfƒsgpdxg]{ka†xk‡zm„zi†yj‡wjŠyl‡xm~od{laƒvjƒuishte~ug}sepdvi[sj^trcrmcog`of^wnbvl^rf[th^zof{lf{jexfblcZwlbznd|pf}pfypfxlb|nerh_lg^urevh‚re‚rf‚sgshriuj`kcZoh_tkavj`xl_yqd|nd~ldqbXph^sncxrh~ofug\vh\zna{qc{qc€ri„qj…rkzibsg_|ul‹ymŠ{n†{qƒyo‰}u‹v~mge\XhcclddqddpebeWZhZ\qfhtiivjjxklxmoxknzloxllvjgwigia^d]^jdeohiqhiqfce]_`^^gggjechcchdcjedgfekihohgshhoee^^]edcnliomgnlemkcZb[bifglkjnikmehg\NOHPNI]XT^XS`XT`WSDaO=aK>eO=iT?jP@gNBfNDfNCcKEdL?cI;]C=[B>ZA?WAAWDAZBA[C?]DHhOAhK]E<[HA]JF`NFcOGgSKp]Ms`NwaNybQ|eRjRkS|eQ}fR~fU|fVwaZt`^vbTxcLxeNxfLv`Mw`Kv`Gu\FuZJy^Kx`Ozd_ygcyhlzjr|kt}lr|ho|khzgazf[wcYua\uaiscgsdiufjqbuoe€pgth‚sgƒsfqe|mayl_tjawmayqbzrdysewseytewo`xl_}pa€nal`oapb…qd„nbocƒpblbl^}jYxgVyh^|kczh^{j]{gY|i\{e[h`|g`{h\{hYzhYla‚leƒodmbƒod€la{g[xdXr`YueYxiYvfWyh\~kd}h_„mbˆpeŠsf…ocmd†od†qfˆtiˆti…rg†ti†ph„qf€nb€oc‚re€of€oc…rgŽvjwjŽvgŽxk‹uj‡ri„ognf„rh…ui…tj‚qi‚rhnf|ia{g`‚pe„qf…qf€mb}ma}na…pe†rf…qg‡rh„oh€mfl`‚od…shˆuj‡vn†tn‰tmˆrkle‡ohŒumsl‹vjˆtiŠvkyrŠwo‹ypwqwqŠrl†oi‹rmto“q{mŒylynŽyp‡rk„me‰shznŒvj‰sjŠtlyrŒxqŽxr”|t–zu•ys‹wo‰vpzu”€{‘}v“w“~u{s”|tŽwpŒumxp{qŒxm‹wlŒxmŽ{o’~sxnyqŽvoŽvp‰tmƒtgŠvnŽyqŽyqŽxpŽxpvnˆsk…ph„oh†sh…sh‚qenf‚oh†plˆrlŠrl‹vktm‰qi„me‚kcŠskŽvnxrypŽzmŠvjŒrl‰li…nhˆrj‹tl‡phˆmg‹qkŽtlŒrkŒsl‹rlŠqk†mg‰ngˆph‰skvm‹woŠum‰rj‡oiˆojlg†oj†qmŠsl‡qi†sk‹woŒvnŽxpŽxp{q‰vj…rgƒof‰uoŠwoŒ{rŽ}t}q|qxn…pi‚lfƒnfˆsk†th„qf‚ph„qi‚me€nf„qh†vm‡si…qi€og…tl‰umŒwmŠyn‹yo‹xn‹vo…ph‡qkˆqk‰unztˆup‚nj‡so…oihc…qi‹woŒyn‹wl„qi‰vl}oŒyp‹wp‹toŠsq†tmrg€sg‡xn{w}w|w}w|w‰ysƒrm…rj‹wmŽymvjŒtkŠsknfof‡xo‰ypŽ{s{s‘{p‰uj„phpgskƒzq{o{oxm‹vl‰ul†rj‚qd€ob…th„rg†sl…ql{la|l`od|j_jc€id€od‚od€la€lbƒrf„ui‹un‹tl‰un‡thnc}l`{leˆwp’~w”w~sŽ}qŠzr‡vm~mdzj^€nb…shŠsf‡qfnd}kc~mc‰xlŠwp‰vp‹xo‹xp‡uj„rgzi`od„thƒrgƒsf„tf†vj…vm~pf{ne…vl‡xl‹vnŠvm„th€rfyl_|pc~pe~pfƒqi‡wk‡ti‹wi~ocxnc|ph…rm…rk„tl„ui„uh…vjxjaqf_tn…uj€skumul~ph‚qiylbog…vj‡viƒtg}qc~tf„ug‰vh†qd†sg„sf…uhvh]od[zpg~pg‚pg…wjug‚tgskuf_}mf…wm‚vl„wlƒwkvixiuixn_mcTyoc|sixmdum_wnbxobwlbyh`|iapdZbWNbXQmd[ƒxmsf}qe}pe~ne€oh~piykdqj[|sh~rh~phri|pf|pczk`ue^sf_{qhysi~qhzqgvnd{masdXocWqdWrf[ti_oe[ni\to`„qk‚qg‚tgtf†xmˆwpƒohscZ}sf~vfwj€ui„vi†wk‰wmngxke~vo‡|n‡zo†yq‡{s€vm{rgme[j`\ofeqgiqihqjfi[_d[\vqpzss{tptq}uuullrihqggqhimeeh__jbbpfftjjthgrdec_`hcdnihnjhqlhtokupmvqoxrqvnoxlmm`bd\^oghqjljdegc`Z[RU]V_f`\d^af`_`XZXNLKARQH\ZRa_Wa^U`\U=\G=`JAhR@lS?mS>iO@gNAdLCcKGfNAcK>_EBaHHfMEaK@[F@[EAZE?ZCCaIBdLBgMChP>fM?gN?fM?bJ?]FA_LC_LE_NIeRGfSOr^PwbOwaNw^Ky_Q}fR€jThR~gV~gV{e\xd[r_^u_ZxdY{fXzfTxcPy`RzdMx_Jx^Jy^Mw`S|eZ{g_zgdzhk~km}kkzhhzhdzg_xe\xd^yeayfhxefwegxgjtdroa|nc|pd~pdrf€pd}ocwk^ui`tj_xpaysduseuugxrcwpb{pb~pb‚pd„qd}m`~na€obƒqdpc~na€mbl^jZ~iZ{h]zf_zg[zh\}k^‚ob€mdmeƒmfmb~k[|iZ}j^kdne~ka€kb€ka€ja|g]{f_yf[{iZweV}i_kd‚ofˆtiŠthvj‹uj†qi†peƒncƒod„pe‚od€nc„qe…qeƒqbpb„reodoc„rg‹wk“|pynzpznŠvmˆsk„ogƒpg…sg„qinezg_mejbkd„qf„qf„pe‚nc€nc€pe‡qfŠuj‰ujŠvk‡sl…rj~ia{g\~laƒpeƒoh€ng†qhˆtj„pfˆqhŠtjŒul‰sh‡siˆtiŒwo{sŽ|tŽzs‘zsvoŠslrkum‘{myl‹vk‹vkŒwnŒwo‰rk‡qhwl‘zoŠtkunzq’|t”}u”}u”|u–~v‘}u‹vo†ql‹xp{r|pŒvoŒwozqxpyqyqŽznxmŠvkŒxm|q“t~rzrŒwpŽxrŠwn„shƒsj†um‰xoˆvn†sk‰tmŒtl‰rjˆrj‰ti‡si„qfleke†pj‰smxozoxqŽvn‰rj…nf„nfŠvnŽvp‰tjˆuhŠvk‹sk‹ol‡ngŽvo‹tm‰rj‡ohŠrkvmwmvnumŒtm‹rlˆph…nf‰rj‹umŠum‡sk†nh†ng…ngkd‚mf‡rk‰rj†qi„qi‡tlŽyqyq‘}t{t‹xo‡ul†sk„si‰wo‰xo‰ypŠymŠxmŠvk„rk~ldog…qi„ogƒpd~kc…rj‡rj‡sk†tk†vnˆui‡skƒpi…rk‹wo{pzoŒynŒwmŠumˆsk†og„me„pi†rkoi€mg‡unŠtl‹woŒwozrzr‹vn‚og†tirŽ|q{t‘ysŒvr‰wp€sh|pdrh‹ysyrzs‹yr‰wo…tl‚qj‡tl{qym‘znŽxnŠumog}lbŠzqŽ|s}t‘|tyq‹wo‰vn‚pg€qh€uj‰wkˆvj†uj€pdof‚ri‚ofƒqgˆvkˆvkˆvn†smnf|kamcoc‚me‚lf‚pf…rh…pg€mcpf…ujˆunˆtl†sk„sgpd{k_td^„ri|s’}uŠwn…th~nf}lc}lc‚rf†si†sh‹th‰uiƒog}mc…ukŒ}pzt{rŒyq{s‰vn„sg}ia€lc€oc…qg…rg„rf€peqd}pe}of…ul‡un‰wn‰wn…uiodrdX…vh…vk…vm…umˆwoŠvkŠwj‚ugyob}rh…sl…skrgqj„tjqevg[wjarkrg}pfynfzog}of~mc}mc‚rg‡vk…uipfuh]~vh‡ymŠwl‰vj‡uiƒsg…ugwi^mcYvkc|ndld€pe‚qg„ti~mdtbZzh`ƒri‚pipdyl`{oc‚vj…rj}lb|l`ƒsfrf{lcxj\~oc~qd€qdpemcylbzneqg_rh_}rg~qe~vhrhrh|ng{nfpd^nhZyrfxoexofvndwpexm_xj_n_Vwg_ymcyoczndog]skaym`~pdxmbna}ma}neykdsg_€vkˆwn†wl†ymˆ}qˆ{p‡xpƒujxk_tg€zjƒ{n€xl„wl†wk„qhrbWtf\~rh€siqhzibug^|oeui]maYm_[uggtegredrech]]i^amdeogfqifqgdja_pfdthhnbbtiirijohhrkktkk{qqwkkrff^ZXjfdpkioiirkinhgkhdnifmhgmfdkaah``jcbjcch`aa\\b`\^_YYaZbidcjfeiejicc`ZSTLUUM][S\XP^YQaZR<[F?bLCjQCnU=pU?mS?hN@cKDfMDeNBdKAcJFiOLoVLmTEbNAZHYCDcKCgNCiPAiP?eL@cKB_GC_LC_KE`LGaNKiUPq\Pw_Px`Nx^Q|aP}cU‚hT‚kThW~h]|g`vcbwdav_bxdbxef{g]zcT{aU|fS|cQ{bP{aMw^RxbX}h^j`jfmh€md|hb}ia|i\ze_zfb|gfzhfzdd{edzhiwepscum^um`zpc}oc}oc{nbwk_vg_vk`zreywgw{jsyhxvfysdvm_zn`}oa€ob~qc}oa}l_~n`na{l]~la‚nbƒn`‚l^…la…mcƒmb~i^€l`maƒrgpg‚nf€lb}j]l_{h\j_}kc}kc}h`jbƒkc…le‚nc‚oc„qcnaƒoe€kc~oeƒrf‡tgˆqf‡rf‡rk„nb}h^}i^}i^|i^mbnb„re‡teŠugŠth‹tiƒshpdˆulŽyp‹un‹voˆwk‡uj†sj„pgˆshŠthˆtiƒodncmbƒod…pfˆti‹wl†rgˆti…qf€nc‡qf…pe†rg‰tjƒog~kcƒne|h^k`‚pe€md}jc…qeˆtiŠuk‰ujŠvk‹wmŒxmŠvl‰uj‰tl‹vnŽyqŒyq‹woŽwo‘wpumŽrk“ynvkŠqg‡ph‰sk‹vnŽvqvoyq“}r’zsup‘wo“yr–|u”}u’|p{pyqŒum‹ulwlynŽyl‰tk‰ulŽwo‘zr’{s’{s”|q“{qŽyn‹wm‰wo‰xo‹}q‰xpŠxpŒxqŠwo†ti…sh‰wl‹xmŠxm†uj†shŽvnŽtmŒtlŽxlŒvkˆth†qi€kdƒmg†pjxnŠvkŒunŽwnŠsk„me‚me„qi‹rm†rh†rfŠukŠrkŒrmŽsovoŽwo‹uk†qi†piŒsj‘wmŒujŽwlŒvk‹uj‰rj„meŠskŒum‹um‰sk…mfƒmd‚mf…qf†rgˆuiŠtm…ph€ld…qiŽxqyr{o‹yp‰vnˆwn…tj‚sf„sj…tkme€rf‚rg†ui€of€ofƒph„qi†qiƒnf~ld†rjŠulŠum‡tl‡vmˆumˆtlƒph„qi‡tlˆunˆti„oe…ph‹tl‰rj‡phˆrjˆum‰vn„rjng†sk{q{p|s{sztŒuo…rj„qgˆxl{pyqwn†pk|kcylaznbsj‰woyo|q{p‹yo„rg†ti‹yq‘|sŽxl‘|pzp‰umƒripg†ul|s‹xpŠvn‰vp…sl…rjnfocqd„sh„qf‚qe{ia|kb…uk†sl‰vo‹yn{p‹yoˆul‚pj~me~la€nc„qf„od‚og‚og‚og€me}jb€of…qi‡rj…qiocmc{i]}ld‡tlŽyqŽyq‰tm„sjxi`xg^„sj„tg†ti‡ujŽwkŠui…qi€ofƒsh‹yn‡tm‰vnˆum‡slnfldƒlc…nf†ogˆsgˆsg…peob}nbsgƒtl‡wo‡un‰zqŠyp‡vm„rgyf[…shˆvnˆwp„xpŒ{t†tk‡shreyoa|pe‚rfrfwl`xg`„sk‚pf}k`ƒrhqi…tg}oetiazpf~pe‚pd‚re„sg‰vl„th|nerh^‚vi‡xlˆxl…tiqe}ocƒrexi_qe[viazja{jayg`zi_~mdzj^{j^~obnc~k`~masdXƒvj‡|oŠwpˆun†ui‹ym†viqe|j]„tfƒug~tfug~qd|pfvj`rf\sg]~rf}rfyqdxncsg^l_Vpf^qg^phZulawnbpf^leZql`|qd}oazkb}nd~pe~rd}ofog]vpe|re€rfvi…vg‚rfqhpiuh^‚wl†vn„wm„{n„{nwm€sipaSvgZse|qdylbxkc}qf‚vjƒsg~la…uh‚uhƒslyibrcZ†wn†vj€odvham^\p`aqbcn``i\Yf[]j_`lccnddnebkb`i_\pdbtggxjkwiltjlokimhgleepffqggi__d_Zhdajcaqjgphhh^_ca]nlhrmjqmiwrotolqmixrn|trvqnnlg[]XZa^cjgdggghfca^YVQDHCWVO_[Sa[Rd[QcZO?aK@eLClSDpVArXAoU@iPAhOBfNEgOFgRCfLDgMIlRGiP@bI>VE;SA:O;8L9=TAF^KCfMEjREmTCjQAcKCaIC`HGcLHeMJgNMkSQpXNtZOv\Ov]Qy`V€fX„jUƒlU~gXzd]vbavbdtbhxfj{fn}hm~ig~h\}gXfV~eT}fT}fS{bQy_X~e]ƒkd…pb„nfƒofmdma€ka€k`{hezggyfcwabyca{fexeirbno_om_tnawob{oc}nbzma{m`}pd}thzwjy}mu~m{{mwvhytgxobxl`yk_|nbzk_}k`mb}la{l`~i^€ma…sfˆrf‡qdˆoe†pd„odk`}jbpgpgld}i`}i^~k^~i\j^}lcne~iajbˆph‹rj‹uj‰tg‰sgˆrf…ne‚ld|i`}k`€m`ƒnb‚ocld†pe„peƒnclb{h]zh]mc„rf‰whŠugŠuj‹uj†shƒpg‚og…skˆtn‰tm…tgƒrf…ri‰tlŒwkŒvj‹wlŠvk„pe‚nc„pe†rhˆuj‡uj…sh„sg‡shƒodk_„od…qf‚nc~jb€me…oiƒne„pe„oe…pfƒmf†rf‡sh‹wlynyn{p‘}r{p‰uj‡ph‰rjŒvn‰tl„og‰rjxp“wq–zs”yo•zqsl‰rjŠtl‹wo‘xs’zs’|q“}r”}s“{rsmun”zs’{pxm‰ujvnypynyl’|pym‹vnˆskvn“|t”|u“|s•|q”|rŽzo‡rg†tlˆvo‰ym‰xo…sl‡unŠwoŒxmŒvlyozoynŒuk‹ujŽtmŽtmŽwoŽxmŒvkŠvj‡rj€kc}gaƒmf†qh…rdƒogˆrjŠrj‡phƒogƒrjˆrm„og‚pfˆtj‹ununtp‘wqxqŒvk‰sl…ph‰pfŠsiwl‰sh†rg‰vkŒumŒumvnyqyqŠskƒog‚mf…qf„qeˆtgŽwlŠum‰tlld€kc…phŠum‡uj†sj„qk…slƒsh‚rf‡tl‰wn„sj€pdqesg…tj†ul„ri…sjˆul†qiƒog…ph‡rjˆtk†tl„sjˆtlˆum†sk…qiˆvmŠwoŠum†qj‚meƒnfˆrhŠtivnyrŠwm‡xk„rf„rgŽzo‘}r‘}uzrys‹up„riƒph„sjŒxqypŽxl†rj€mdwj^rgˆxozr’~r”€u“t‘~sˆvkˆvkŽ{s‘|s“}q‘|pŒyp‰vnˆwn‚qh…rj‡tlˆum‹xo†toƒpj€me…ph†ui‡viŽwo‰rk…ogƒnf€kd†sjŒxrŒyq{p‹yoŒzo‹xn‡uo~kd|j`mb€nd€nc€mf~kcmd€nf‚og„ph‹rjslunŠti„nc‚la‚ph‰umŠvmŠumˆtl‡vm|md|ja‚ph‡vj„qg„shŠthˆth‚og{ka€ndƒrf‡tl†sk†sknfyf_og‰rj‰skŒum‹tmŒun‰skpf~nb€rf‡xo‰xoŠwp‰zq‡wn…tk€mezg\†rgƒphqj~qi~qi‚ri†rg…viugƒxj…uiƒrhqd[€oi…um…ti„rg…ui‚ui†rk~mdre[znd‚tf„sf„sf‡thŠxm„shxi_uh^pd‚rgƒsg}nbwi]yla|l_}nc{lc|le~nezi`uc\~ld‚ph‚qe€ocqdndod~laueYƒti‚tiˆwpŠ{ru‡zk€uhyma{larg|tgwpbsl^tm_wlcsg]ocWxl_|pd{nbqh[h_Sqe[ymczpfzqf€tf€qg|mdqb[j_T~tjsf‚uiƒuk„tl€re„ug}pfqh^xpg|reƒui€viƒxi€uh}rhj`XkbWvl{ocpe[rg]{qg}qgyk^}k]‚qb„sg…rk~le}kd~si„vmˆxlŒ|pŠ{nŠzlˆuozharf\ƒwm†wkƒrgqgclb_qgdndbmb`j^\cYYjaak^^i^^h_^g^\j`^qecqcdsfgqdembdfednjiskkukjwlmxonvrnvrmxqnunlwopj``feaojgrkhunlsnkkhdmjelgbke`ga^cb_\_[^dbehggggjggidbPKHGKD\\Uc_Ug^Vd[Od[NDiQFmTAoUEsYBpVBmSBiPAgOAeMAgNCgQCeMEhNGhOCbI=[D;TA>S@>R?S?G_HEfNEkRHoVDjQDdLFcLGcMKgPOkTPlUPmVVpZOtYMs[Ms[Lt\Q{bZ…iWƒlX~g]xebwdcvccvcjtcl{jm~jnjg|j`}iZhXhXjW€iV~fV~e^fd†nj‹sh‰qh„qj„ph…qf…pj‡rj„pk}jhuciubevebzg_xectcepajp`qrdxqd|qeqfƒrf‚rfpf|qh{viz|mw€nw|nwyjutfwsfxpcvl`{l`|k`}k`~k`odoe„odƒodƒqd‡viŠwi‰tg†qemd|ibzg`xh_{kcyf^we]zg\|h\‚l`…oaƒpe„rf…qeƒoc„pc…qe‡tf…sf„qe…qf„og}i`|f^|g\i]i]|i]}jb„nc„od…qf…qfnc~lajc€kanbƒpd†rhƒngƒnd…ph‚ogodˆsjŠtj‡ufoc‡sh‰uj{op‘|qzo‹xm„rgocncocƒsf€qeocƒqf„pe‚la‚mbƒodƒoe}ib}ja„qjˆslˆtiŠvkŒwl‹tl‡siƒoe†qh…si†tj‰wm‹wlxnŽwl‰rj‹skwoul†oe†ogwm”}t—w•|v–}v’|tŒvo‡qk‰snun‘zrznŽxjyl{o’vp“yr“zp”{qvkŠsgŒvk‘{p“}p“|q”}t’ysyqˆsk‰rjŒumyrxo‹xkŒxk‹wk‹un‰unŠvnŒxnŒyq‡un…rkˆtl{p•{q”{q”|q”|qyo‰thŒum‹um‹unŒvk†rh…rg‡rfld~haƒne„pfƒreƒph…ofŠoi‰sk†rk…tkŠtnˆslƒphnfŠtkwnro‹ql‰rkŠtiŽwlˆohŠpjŒtm‹tk…qh„pf†uiŠumxpŽwoyq’{swp†rg„of‡ri…oe‰rhˆsi‡sl‡sjƒmekc„og‚of†rf~kbjc…sl†sj†vi‰um‹woŒwp‚qe{oc|pdƒpe…rj†tk‚qhƒsj€oh‚nfld†of…og…qi€ofng‹voxn‹wlyqŠxq‹zq†tk€me„pf‡ujŠwlŽwpŽzs‰vnƒri€mbnaŠumŽzrŽyqxp‹vo…ph„riˆtlŠyqŽ{s{rznymˆti}nbƒsjŒyqzr‘|s•€v’u‘~u‰vm„siˆtmŽypŽym{n‹yo„sj…ulŠxo‰xpŽ{s}uŽ|sˆwpohƒnfŒwoŒymŠxlŒtnˆqk‰skˆskƒoh†rg‰vp‰vmˆvkˆvk‡tj‚of€mf}jb~la‚pe‚of‚oh€mf~ldnf…tlˆsl‹smŽwovnwp‰ujƒncƒod„pe‡rjŠsk†qi‡sk„qj|ndzj`€of„thƒqfˆvkŠthƒqe|ia€of…si‡ti‡vjˆum‡tlƒph}jbƒphŒwoyqŠvn‰umˆtmˆsm‚oh~lc€pgƒsi„si‚pfng€nfƒph€meld‰tkˆukqi{pgyof†xm‰wjŒwnˆwlŠ{o‰vk†skn^W~nhƒsk…thƒth€sg€sjmeraXk[Rxi_~na…rd€od€mc‹vkƒrgƒrhƒsiˆvj†th„sg{l_reX}pc‚re„ti‚pg‚pi~mdyh_xe^me…qjƒpfƒqeƒperfqf|l`p`U}kcofqh€ti}se{pdwmawlc{kc|ofzqfrj_mfYrj]yme|oc}ob‚uf€sg~tfsi^pcYyla}pe|pe|rgtf€qfqhyhbn`V€ujrg}pe~sj~sj}rf€te{lcri^vlbyl`pdwj^xmayoewkcth^znb{ob|ocylaui`‚ul†xmˆwk‹}mŠzl‹xn‹wo†tk~oevk…zp„yn‡zo‰|pˆ{pˆsmyh`ti]ƒ{m~riykbf_\f`]ha_ha^jc`d\XdZ[nccpccnaanbboeeullujlxmmymnuljia^_camlkunnyoovllwopvrntqltoltplmgb_ZVd`ahbbofdkb`f`\^ZWdbbqkjwomqlhed`_cafmiknmnkjpkjidaNIESWM`^Vg_WbYO`VM`WMElSEoVAoT?pTBlSCkQ@gNChOCjQAgNCfQCfOIjQKjQHfLC_GDZFBWDCWBAV@=U?A[DBdLGmTJpWEkRFeNJfPQlSMkSQnUTpWVoXWqXOtZQu^Ot`PvaQyaXfY‚kZ|f^wcfyfg{gewdipbcsafzgg{hh}jb}mY‚gWiT~iW‚lYƒkXgfƒjh†nkˆoj‡pi‚ok‚nemi…pj†ri€lj{hitbkpagtcave`yhbwgasefraoufyugsg„rg‡si‚sfrg{oewqfvvgtygqykrxirtguvgxsevpc}nboc~k_ƒnc‚nc‚pc…pdƒpepdqdƒsdƒrbpc~kb|ia|jc{ibyh^|jbyf^ze\~j^‚na‡qb†sd‡te†sd„qcn_k]ƒpa„qck`kc€jbjb‚jb‚g]„l`ƒl`|j_{h`‚ma…od†rg…rg€mbnc~ga{g`|janf€of|jc€h`jc€lb†rf‹wjxlŽyk‰ti…qe†ti‹zmŒ}mŽ{q{pˆuk†ui~na|maobrf{nb|pd€odƒpe†pe†qf…qf…qf‚nf€me‚ohˆslˆsi‰siŒvkŠti…pi€kd‚meng…qingˆuixmzn‘yr“yr”ys”zpŽukŠshwl’~s–v”y’|vztvq…oi…oi‹tlyowkˆrdŒwg|n”zt–{u˜~u–|r”|pxjŒwl|o|o{qztŽwtxo‰tm…ogŒumŽwovm†sf†sf‰ui‹xpzsŽxqxozr‰vo‡tm‡sk‹vl‘}r‘|rŽzo}qŠxm†ui†pi‰tl‰tl…tioc€ndˆqgˆpi„ogˆsj‡ui†uhogƒnf‰piŠrkˆul‡wnŠvo‡tm€mf€ld†qg‰sh†ollf†oh‹tiŽvkunup‘xrwqŠvm…qi†tiŠumxpxp’{rypvo†sh‚nc‚me…nf‡pi„mf…qjˆsk‰rj‰qj…ph„qiˆsf‚mbic†pk†sj‰xkŽyqzrŽyq‡ti~ocui\~j_€nc‚of|lc{ke}ng‚ne…ogŠsl‰qj†rjpg€ng‹wozp{p|tŒzs‹{t‰xoƒqiob…rh†tj‹sm‡rl€mf~md„ph„ri‹uoys{sŽypxmmcƒqfŠvoŽ|u|u}s“~q–}qxl„sh…qjŽyp“zs{tŽzs‹wp‰vn‡vmƒri‰umŽyp|o}pŠyo„rj…wn~v“~v•€x’€xŽ}t‹xq‡tm†qiŠum‹wp†uj†sl…sk‡tn„sj|kdqf„qj…si†th…shƒqg{h`of‚peƒqg†ti„qi…qk‚ohngme†tm‰uoŒto‰xoŠxoˆvn„uhvh]xi]‚nc†qfˆqi‡piƒnh|jcqh‚qh‰xo†vjˆvkŒzpzl‚qdkdƒri‡tkˆuj‡ujˆvkˆul…rjxe^|jbˆxmˆwo„sj‚pi‚piohmg|ib~me†vj‚qd~m`s_X„pj†sl†sk†skŠwoŽzo‡xowmdypc†wlŒykvoˆum‰wl‹vl…php]Wtd\of~pd}odulasjbjbwe]uf]}oc‚rd†ud~mdmeyoŽznŠym‹zm‘}p}pŠylzj^zk]qc‚reƒshqh€ng~mdzj`yg[mc‚og~kclczi_xm_{obtfZraVwg_}kc‚rf{k_wgZ|nb~og€piƒpk€pirjxldti^xmc{pg€sh‚se…vire}sfxlbqdYzj^€qe{ocxnaxrcypdrh]k^Vrh]|qg~ngzlevkcsjaxod|rf~lcznd{pgnc‚qfyj^{kdqjƒqj†tl…sgƒsdtg|mbwjb†voŠyn‹zm„|kˆ|oˆzo‡wn|qfznavm€wm€vluk|qjsk€ldwg]yqdwpdtlclaZe]Zneaogcujguigma_i__vkk{lnrs|qqyoownp{qtynozpmskgf`[`fdkkitmmvmlriinhhtqournsnkpmhif`_\Vlfgsjktgisggkccfc`kiltnosjjpjhbb^[a^_gaac`hcdfa_c^[[XP\]Qc_Ud[QaUMaVM`WNGnXGoZBhRBhODfRCiQBjQAjOBhPLlWDlPBiOEmSKmVIiQCbIE[FE\ECYCCWACU@HWCG^HKjRNpXMnTIjQLpULrXUsYYpX`qZ]pX]r[Ww]Zx`Xx`]|f[ze]|gZg[|e`zfbzffxgkwghscar`dyfb|hc€mclXƒiYiVhU}hWkZnf†ooˆtrƒqs€nmyhlzgrzjt~nq~nmyimsenpasrfovegyge~jdl^yicyfcyelvextg~qe|pd}rh€rhzndsodrrcvvftwlotliwmk~po{nvtkxoe€of…nf€ld~kc}ha}kc€ocncmbpc‚remb{k_zj^}k`ƒpc„ne…kf‚ic~ia}h_}k_€qd…qf…pf‚pe~lb~mb}lald}ka}l_}k_|j`kckdlc‚naobn`|j_}k`nb}ocrfoczi^~j_~iajbƒmemd~lak`~j_‚nb†qj‰tlwq‹yp‰wo…rjng…qiˆul‰ym…vj‚uisgƒrg€nc}kdof}nc|m`€od„rfˆpi‰qjˆsk‡rk‡rjƒnf€mgmgmf‚oh€ofph‡shˆti…nc…od‡pe‰pfˆqiŒumxq{s’}u“}u”}w’|tynˆujŽxq{t’zrvnŒumŽyqŒwo‡skŒvjzoyo„lgŠsk’{r•u–v˜ƒw—v˜~u”zq‹ul‹rj‘uo”yr’yrwoym‘xnvlvo’zrŽyqvkˆrhŠskŽwo•~t“}p‘zrxqvn‹sk‡qiˆunŽwpxrŠtnˆumŠwoŠwnŠthŠuk‰smˆrl„qg‚qd…rhŠum‹skyqŒxoˆwk…ojƒlf‚lf„mg‡qk†qk…oi†ph‡qg…od„ph†tl‰rjˆqiˆsk‰tlŒwpyqŽytztzt‘yrŒvn‡qi†rj‹unŒvpˆsm…pj‡plŒvlˆrg‡qe‰sg‡qf‡qgˆtiŠujŠwk‰tl‹un‹un‰tl„oh€mfog…qk„rm‡un‰wpˆvo…tk|lczia}k`ƒpi€ngzha}kbƒqg‡pjŒumŠukˆtj‹vnˆrk‚oh‡tmˆwo‹ypŽ{pŽymˆ|qulzmcoh‡smŠrlŠql‰rk‚nf~kcng„rlŽxq‘}t’}u|tŒyq†skqhˆxn}t’|s’|t“|uyrŒwp‡pj†pi‹tnyr{qzn„uh†ulŒyq‰vo”€s’t“t’~tzrˆslˆxo}u‘w’w~v‹|r‡zmˆylne‚pg†sh‡sg„qi„qi}kd~le„pi‰shŒvkŒunˆsk‡rk‚oh{ha„uk„ul…qk‰to‡tn„tk‚oh€me~kane‡tl‡voˆrj„qinf€nc}l`pe‰rgŠrl‰sm‡tm„rj€peˆuhŠvlŒxpŒwp‹yp{o‹yp„qi}lcqeƒthƒui…rj„tk‚ri|h`{f]|kb‚qd}latfZrh^|mc…nf‚lbƒpe†ti‡vj…ui€merbY…uj‡wj†vkŠwpŽ{tyo‰znxl`zma‚sgˆti…sl€pg}meƒuhmb{h]€ng†si…sg‚peve^{md„reocƒsg†vj‡uiŠyl€oc‚qczlŒzkŒ|nŒ|p{rŽ~oˆyk{i`xe\n`ld|jb|ke{le~kc~jb{ib‚nf‚mejb|g^xc[|n`€pcnb}ma‚qgƒsiphve\yja~og€qh€rhƒqi‚rj€qhyncsj_xob}qfukul€tk~phpdri_ohZwm_vm_ti^ui`ofZoe\ug_sc\|kcƒthoi}phvia{ohtm„tm€qj‚tkuk†ym‚viqgX|qg~shsj„tg„sh„sg€ph|lcrcZ†wnˆyp„ul‚vk„uh‡vi„sf{k^oe|pf~qgrbYm_V{qfƒ{pŒxp‡ymth}me{hen]`hd]rjhuhjwilqfeg_[i^_shjwjhyljwkjrffrhhsjjxpnwqnqjhjdalhhslkwkmzmpnfeiednjhnieslgtmhkc`h``nhiqhhughsffc[[`[Xjddlfenjggd`cc\ef^igfokjoiflga_]TYWM]\P^[PaZP[VKZYM\aTFjTHlWDhR@dLBcMBhOAkO@lPBjPFjSHlQHlQIkUKkUIfPFaIGYEHZGEXCEWBIXBMZDK_JPlTTr[UsYRpWTv\V{a[x_]s[`pYdu^ex`azcaxafzef|ec{h`{gY€f\zcazf`yeatbdp_fscevcf{geie€ldm^‚k^kX{fVzeY|h[}ka…pk‡sq„qpyhmrbmqarrdtugvykvwiwsewpcuqesvfp|jm}kj}ki{kgzeezhhygpvewpdzreyqe{qfyncwodvsfyuil|rj}zfƒf…p‚zvwnwpg~oeƒmejc{ha|e`zi_~ma‚nc‚oc…re†sg„qf€mb|l_pdƒqf„peƒmf‚kdld|g_ye[zh\€lak`€lamb‚mb€maƒnh€lcnboc~jakdka‚mc‚obma~k`|ib{i]|k_~nbpd|k_weZ}h]€kbƒnfƒog„qhƒrfƒod€lalc‚meˆsk‰tlˆtl‡sk…qi‚ng‚nf„oh†tinc€ocpeƒoe‡rf‚qh‚ph€qepe~la‚nc‡phˆri…ph…ph„ognfme€ldme€ld€lblb„peˆti‰tjŠti‰siŒujˆrkˆtl‰tlŽyq’~v’|t’zt‘zryoŽwm‹tlŽvpyqvn‰rj‹unŽyq{s“}q”}uxqŒumŠskym{q•€u—v•s“zp“yoxpŽun”yr˜|u”{txpŒxm‘zp–|r—~r–€u”u’€sŠwn…qj‰vnzq|nŠvn‹vmum‹umŠsk‰umŒwpŠtmˆsj‡tkˆvlŠynxmzp‹voŠun†si‚peƒrg‡si‹unyqŠtk†shƒmflele†qj‰tm†qjlf‡qi‰shŒvlˆtl†tmŽxpŒwoŠum‰tl‹vnyqwrŽwrztwoŒulˆqh‡qiŠtlŠuo‡qk€lf‡rlypŽwnŠtjvmŒulŠtj‹wlŠvkŒxmŒwo‹wn‡rj‡rj…rjle|ibngƒpkogoh…sl†ul…tkpg„rg‡um„sk€nf~ld‚peˆsm‹wo‹xnˆuk†rj…qj‚ohogˆwm‡tmyq‹vk‡vn‚ri€pg‡unŒwpŒuoŒvoŒwo…qhoeqh‡vn{s‘|tzr|tŠwo‚ognf…qi‹wozrwoŽxpŠvn…rkŠum‹vo{s“}u’~s‘~sˆxl‡vm{s}u•€v’}t’}t‘|t‘{tˆsl†vm‹ypŽ{s|t‹ypƒsi‚vi„uiƒri†skŠwm‹xk‡uk‡tm}kdohˆumŒxozowl‰ukˆul„qjneƒsg‡tk‡sl‡rj†sl‚qhmg}jb}ka€nd‚og„pi†rjƒog~kc€nb‡vkŠ{nŒynŠvo‹wpŠwpˆvn†vj‹xm{rŒyqŠyp‹yo‰xlŠwoƒqh~kdnb„sg…shkd~nfƒri‚nfkbog}m`veYteXpe[|lcˆoh‡sg†shˆxl†wk‡uj‚pdvd]pd†ui†vj†sk†tl‘|s‡vkqeth‚rgˆth…rkyg^|ka‡ujˆtj…pe†tm‰wmˆvk‚pexi_rk„tg„ti…ulˆxo…ui†ui„thpd‰vh‰vi„si„rk„tj†vhqczi`}janap`|k^xg]‚qf…tg†uf„tj…sk‡sk…qj}ibvd\qd‚rf„thocƒrh„sjqhrd[wi_|mdzlcofqhqf€qgwj^ocVth[}mb~nexkcug_{nd}pdynczpc|rd|re}odvh_qgZzocultj‚ujuh„umƒumvkc|qiƒum„umvm‚vm‚vm„ymvi]nbTxlc{oe}neƒth†uiqepe|mcyk`‚sj†wnpgwlbuh†wj†wk…wj„vl†yo‡yppgte]†zq†}sŒ|s†zn‚xk‚rjwfbgYZjc`pggtfjrehqeeaYTk`brfgthgukirihleepfgullulmpljmiec_[jgfmgfpegshipjikgfpjjnggpgcnfcjcbmhipkjqjjukipfdga^ljeqomrolroknkfhearnhtpnokipieke`[VMWTK_XMbYOaVL^UK\YN]^RFiSEiSCiRDiQEgODkPBkO@mO?jN@hOEjPHlUGjUKjUJePKbKN_ML_LL`JK]HO_HR]GUePTjTYr[^t^^v_]ybY|b\x_aw_fu^ht`kxbdwahubnvekudgwd`ye]~e`{dd{ec|hbwdcr`frcizhi~hi€kg€lh€nc€m_}j[zeWxd\}h^kZod„sn€qowjonbpm_vpcytg}viwj}tfrfzrdvqbqtdqveovfntclxdg}fd|hgwdqudusdsthxxjwtfvpcvskuxpgjŠŒ`Œ’d’šs’‘r~wtrgzne~kcle~jde`xh_}l`nc†qfŠuhvjŠtk†rj‚rf}oc}nb€oc€od~ka|j_|h^{e^|g_zg[|i^i^‚la†ndˆoe†rg…qf…qf„oe‚nc}j^€j_‚la€l`k`{f_~ha|i^~mb~nb€pdlayg\~h]md‚nfƒph…ri…sh‡sh„ofjajb„ogƒng…pf„pe…qf‡sg…qf…qf…rgƒncmb‚nc„oe‰rg‡rk‚og‚pe‚oe€k`k`€kc„ogƒnf€kc€meƒph„og„og…qg„pd‚ncnaƒqf‡ti‰ujˆti‡sh‹uiˆsk‡rj…phŒwo“|tŽwoŒtnŽwo‘{o‘zpŽwoxr”}t‘zrŒumvm‘zr“|t“|s’zs‘yszq‹uj‰sgwl“|r“|t‘zqyo”}r–w”}u’{s—€x–v’{sŽxl‘{p•~t–€t•r“p“sxo…phˆskŒwn‰wi…rj‡sk‰tlxpwoxpŒxo‹wlŠvkˆti‡vh‰xk‘zpyq‹vn‰tl…rj€mc€pc…ri‡sk‹sm†og‡qf†rj†qi…phˆtkŠumŠul†qj‡qiŠtiwmŠvnŠxqvpypŒwo‡rj‰rj‹ukŠtnˆrmŠtnxpŽymwlslwoŒxo†pj~le‡unxpypŽwoxpvnŒtmˆti…qf†rgˆsk…ph‚me‚og…rjƒph€mg‚piƒqjqjng€oi„ulˆvmˆum‡ujˆvn†tl‚qime~k`ƒrj‰wnˆum†sk„qildnfƒphŠwozrzr‹vn‰wo„tkƒri‰vnxqvqŠwo‹xo‰yl„tg€pf‚tkŒxo‹voŠtl†tk…rjƒph‰rjvnŽxp‘|tzr‹xpˆtm…riŽ|q|q’~s“u•u“u}q†ulˆwn‘v’~x’~w‹yrŒyq‰un‡sl†sk‰woŠwoŠwoˆunƒphƒtg…tj‰xo‹wo‹yoŠwl‰wl‡umoh~ngƒsk‡wnŽym‹vk‰uj†uj„sh€pd„re…qf‡si‰tm†sl‚og{ha~jcpd€nc…rj‡tm†sk„rjnfpd‰wl‹znˆwn‡vmˆwoˆwo†ul…tj…si‰wo‡un„rkofƒuiƒph…sjƒpi‰vjŒwlŠth€le|lc†vm†sk„ph|lcyi`{i`wf]sf\}md‡qi†qi…qi€pe€pdƒsg€od„pe…shˆwk‡ulne‚qi“~t‹xnˆxlˆxl‰vkˆti„phxd\og‡ui‡ujŠuj‡woŠxp‰vl‚pezj]sg‚rfqhrk|og~ne~mb€pdnc…rf‚me|hayf`|mbsdoaneogrercxj]sfY‰zo…xj…wh…wk‡xm‰wl‰wlncyi]€pd€pdobofof€pg|mete\td\{lc~mdodzlaxk^{k`yi\teXzj]€mc}ldwg`sg^~tj~thƒvj‚th„vj‚thpgwh_yl^€tgƒwlƒwk„ylƒyk†vnpipc[}qi€qjphyogvkb|pfvh\paUyj[zoe{odzlcqe…wk…ui…xj„wi†xk‹|t†vn~ohti_‚wl†znˆ|o†zo‚yn…tl„um~pdqf†xmˆzn‡xo‚zm}uhxi`m^Z`UVmeeshjshlwhmrfgj]\shjtjkvljslgkgcdb^ncfsihoggkdcb`[a`\mihnggogeqjgmffnjhwpqvklulkoffibbmhhsmjqigohenidkhcnoijmglmgljekhcfc^heaheaea^c^Y_WQUNFWQIfZPdYOcYO`YN_[Q\\PKoVEmTBjQBjQEjQAgM@iM?hLAjNDkRFnUFmUFlVKkWNkUOhQQdQPeRPiSRhRTeN\gQ^gT]jUbp]fr^et`f|eb}eazbdwbhxckvbitbcraeq`nudmvdjwefzg^zcdydg{fg~gg}fgwbiuchwdhzefzdh{gk}jf~oc~j_}hZ|cY}iZkYod„uk€rq{nrsfsnaqpawrezrf}sf~rf}qe}rcvn_sm^spastcppakt`j{gf}fi|jpziszis}os~lv}kuvhqvnn~zg…‰h”a“žd™¥pšŸpŠƒwym|rh€ofog€me„md~lc|j_mbƒod‡qdŠqfˆrj‡sk‚rgqe|mb|oa}ma}ma{i^yg\|h]~iambmb‚lala…ncˆoe†rg†rg‚ndƒoe€la~j_}h[‚laƒkd}h`ze^{f`€mcnc‚rf‚rf‚od„nc~i]}j`~lcqh‚qgƒqf‡qj†qiƒnf‚meƒoe„qeƒod„pe„pe‡sh‡sh‡sh‹tiˆuj†sh‚nb…ncˆoeˆrj‚nf~laƒod‚mb‚k_~ibƒne€kc~kcld‚og†qhˆskˆtj†rg…qf‚ob~la€ncƒqfƒqfƒpe‚nc…phˆskˆskŽwo‘{sŽwo‹smŽvnzp”}s•}v•}w˜‚y—€x’{sxpumvnxp‘zrŽvpyp‘{pŒvjyn•~t–~x‘ysyp’|q—x˜yš„{šƒ{˜y“|t‘zrypxnŽylŽxmxk’{o‘wo‘vo‘vovnwk‡sl†sk†skŽyqwo‘zrzqŽ{p‹wl‡sh‡tg‰vi‘yqwo‡sh‡sh…qioe„rf†th‰ul…pj…phˆqiˆtl‹woŠvnŠumŒwoŒxoˆrl…og‡qf‹ujˆtl…slŠuoŠunˆskŠskˆrhvmŠqlˆqk‰tlxp|p|p‘yp“{szs‰tl‚oh„skxpŒwpŠum‡rj‡rj‡rj‡sh„pe†rgˆsk†qiƒme‚pgˆum‡tl…tk†sl†un€rkrjskƒtkŠxoŠum‡ujˆvnƒrj€ng}kcƒqe„sj‡vm‡tl‡sk†rj„og€meˆumŽyqzrzrŒyqŒyr†tl…tk†sk‹umŒumˆtlˆvl†viƒsf€pe†ulŒwoxpxpŠwo„qiŠwo‘zr’|t‘|t’}u|uŽ{s‡vmŠwp‘~t’€u“€t”‚t“t‘~sŒ|oƒri…tkzr|uŽ{tzs†sl‚ohˆunŠwoŠwo‹xpŒxp‹xpˆtlqe†ukˆwpŠwpŒzp‰wlˆvk†tj}kd{ibohƒvmŠtjˆtj‡uj€nc€pd…sh‰thŒwlŒxmŠxm‰wmƒph{hameƒqfƒqf†tlŠwoˆvm†skngyg\ƒqf„rg‚qiqe‚re†wj…ujƒskˆvkˆvm…sl~ldxh_„ui‹xpzr|tzpxmŠuinfzjb„sj„piƒogzjayja|ja{iayja~ofˆrj‡rj„rjudY}pd†ui‰ylŒxmŠvkŠvnŠwoƒqh…tkynŒynŠxmŠxmŒyn‰ujˆqi€me€me…thˆuj†sh‚riƒriˆun‚pe}l`tfƒrg€pgxkcqd\}mdƒrgqeƒqh„ohƒmgjcwe]}oc€rc€pb„qj„tl}rexpbpf[oe\zpf~th~vi‡yn‡xl‡vk†ti{j_vgZ}k`|l`€ofzi`{lc~of}mf|ld}nepg‚rg~nbrfZzl`}nazj]~m`oblbldyhayld|qh~thƒugsh„vj€pi€rise\}oc€sg€ug~se}re}qf~mdtg]wka~rh}pf}lcph_yof~si‚uh„ui†xi…xn‚vl|pg{l`…xlˆznˆ{lŠ}oŠ|pˆzn†vnzlcyod…zpƒwm„yp…zq~vl„tk€ogqcX|mbƒrf~n`xjawpb{re|ldm_[_VXpegqfirgjtikobbj^^f[^pffxnjokfhd_ggavmlvkltkhpgd^ZWca\smkuojsjeme`f`\pjhtkjsigrecmc_f^\ga`ib]hb]ic^kg`kjagi`biaghbgd_hd_fb]c_Y_[XZTP^TQ^TM]TLZSJi`Vof\g^Td_T`]Q[[OIjSMpWDjR>eM@eN?fMAhMBhM@cKCfNFnUKrZNr[RqZVpWWnUXmVXpXZr[]p[^hVegVhiWhlZin[lo_jo_iucg|dfzcdwbfvbgsbgqa]o^^o_brahyfhyghxfexeevahxcj}hk~ho}fnwfmwchu`ds]gt`mygmxihygf~g_}g_€l[~nY|m`ojrooq{jmsbpoatnaznb~qeqf{pc{o_wl]sl^tm_wtbwvdswco|hl}in~io|kplu~qq€mu‚mw}nn{tlŠˆf—a‘a“–jš¥r•rŠ…zzr|slƒrk„tjƒsg…rf‚nf}l`{i^zi]l_l`„ng„qhphqe€sepc~mb|la}k`{k^{i^|j]€la‚od…qf„qfmb‚mb„od…ofkc€jbkc‚ma„kb…me…mg„lfkc{f]}k`pdrf‚pe…oe…mcƒmb|i_|lc}ne€oe‚nc‚mf„ogˆsk‡rh‡sh…qf…rgƒpe‚od†rg„qfˆuj‡shˆtiˆvk„pf‚mb‡pe‡qj‚ogmbmb‚nc„ocƒnfƒnf‚og‚nf€neog…qi†rk…ph…qind‚oepd}ma~ma€nc|k`~k`ldˆskxp’zr“{t“yr’wqtn’xo”{q—}v—}w•~v—€x•}u”zsvo‘vo‘{p’{rŽvo’{t”}t–€t˜t™€x™€|•|x‘{q‘|p–s•u–‚w“tŽznym”yswoŽzpŒxnvlŒsk‘vk”yq•xq”xq•yq•{ovo‡tlˆtm†ulŠvnŽyqŠwoˆunŠwm‰uk…qg‰ujxqŒwm‰ujˆti‡tj‡tl‹uhŒvk‰vnˆun‡rl‰sk†tk‰vm‰wm†sjˆvlŠxo‹tn‚ld†oe‹uk‡skƒqiƒpj‡slŠum‹tkŒvkwl‰sj‹tk‰siŠukxoŽzp|p{pŽyq‰tl„ph‚og‰ukŒwnˆtj„of‚nd‡si‰vjˆti…qe‡qj†qi…ph‚pd†ujŠyp‰xo…tk‡wo€sl~tk~skƒwl‰vnŠsk‰vl‰wn…sl€ngof†tiˆxlŠwo‰tn‹uo‰sk†qf„rgŒwo{s‘|tŒzrŠxq‰vo„sl„tl…ul‡tk‹vnˆvn„qi„rh†sj†ulŒzr{s{s“~vŽ|tˆumˆvm|t’}v~u~v}t}sŠxr~w”y{qŽ}qŒzn‹vlˆuj‡wk„sjˆvn|t}u‘~vzrˆul‚pfŠxn‘{sŽzr{r{rŽzr‹unpeng‚pi…rk…sk…ti€rdmc~jckeƒqjƒrkŠun‹uo‡tk„rh€peˆ{mŽwqŽzqŠzn‰yo‡wn†rm|ldxh_€qfƒth…ul…tm†vl†ulnf~la…rg†sh€ld|i^nc…th†ui†vlŠwo‰un†sl~ldyf^†tlŒyq|tŒxqŠymŠymˆujme~ne‚ri„phkbsbYwjb‚ngngqgri…qi…pj‚ph|me‡ym‡yl}pŽ|o‹wn‰vnŠunƒog„qh‰xl‰xmˆwk†ui…th„shˆqi€meof†vjˆwk‚qf|nb‚riˆun…thƒrd„vf†ti‚rgzjaue[†vj…sg‚siƒrj„rk„ng„pevcW{obrbpc…rk~ogri]j`SaUJfYOhZQrf[xobrŒ{o†ti„qfncncƒqh„qh…tkxjazkc€sk€slpirj†ulƒsf}k_vi_znc|mc~oc€pd€qe„odmdue^sg^|pf~qe€rdre€qh~qgxkavj^zofsh‚vi{ob|nb~pine‚ririuk‚ri~mdwjb~rj„wnƒwl‡{n‡{l‡{r…yo}qgxl`…ym‡{pˆ{mˆ|n†yl‡ymshug]uj]€sj{leqc[qf\yre‚ph~ld|nbˆwkˆwi„sevj_~vi‡{o‡wnugbg]^nbergislltkilb`ocbrijvnnwnkuohmialhaumjvlivjenb]cZUb[Uja[lc[ibWh_Ve\TjaZh^XcXR[OGdXQf[Vf[VbXSg^WibZki`hf\ddZde`hf`je`mf`kf]hg]mifsniphape^`TN\QIjaWtlae^TaZP`ZP[UKJdLMiOOoVJkUCiTBhPIkSHhPIgQJgRMpWPrYUs[WpX\oXcrX]pXat\cv`gs_kk]mfXlgUmlZnlZpm^nn^oufixbgxbevadracp^dn^]p_Zr`[uc_xdh{hm|hjyfkwcjwbl{el}fo{eqxgqyemxcgs]jr_pvfwxjrxfp~hkjfpesbrc~oeni~ll}kkygpobun`zk_€ncoc~oc~o^xl]wm_wobxteyyf{}iu|hr|hs~hmzgj}juyls~ku~ix|nn~wm‘‘j «gœša’m“œu•{ˆ„{x~so„rlriseƒrdƒnd~nbxi]wh\zj\{j]~jdme|md|napcqd‚og‚ph‚peoa{l^zj[{h]j_€nc‚od~mb~lal_‚lbib~g_jaƒnb‡meˆpj‡ni‡pi†pgl_|j_~ma}na€mbl`‚j_€k`lc|lczldndkajbƒnf…piˆuiˆtiˆshƒqf‚pemc€od‚pepe„peƒqf„rg„rg†rg†qe‡slƒqiocnbnc‡rgˆsk…qi„qh‚pg€of}mc€mgoh€ogme~ld~me€pd~nb~obmb~l`}l`ng‡tlŒwp”|t•}v”zs’xrunŽuk’xo—|v–{u”|t“}u–|u—}v•{t•zq–€u•tyq”{u–w—€wž„yƒ|™|˜{’|u‹xj‘yo{o‘~rŒyn‹vkwl’xq’yrztys‘xrrnŒvjxo’{s”{s”|s•~q‘yrŠunqg‡vmˆvn‡tl†sk…rkˆun‹unŠumŒvn‘yszq‰vi‰vi†ri‰unwjŽxlŠwo‡un†tm…rk„rh„sg†tiƒqf„rg†tj‹vpˆrjŠtiŽxm‰um„rkƒpj†rm‰tmvnŽwlvkŒvjŒvjŠth…ohˆrkˆumwmˆthˆsj‰tl‡rj‡rkˆth‰ujˆth„pe‚odˆtj‹wlŠvk‡sh†qi†qi…ph€ocƒtg…tkƒrisjri~rj{qi{ri„xnŠxoumŒyn‰wo†tmƒqiƒph‰vl‹yo‹wowquoŽvnˆqgƒpeˆti‹tlŠwoŠwp…tmoh…tl„sl†wnˆwoŠxnˆuoˆtmƒng‹woxq{u’|u“~u“~v|t‡tl‡skŒ|s{rŒ{rŒzr‡vn…tk…rmŽ{wŽ|u‹xpŠwn‹ynŠvk‰ujre†ulŠxoŽ{s’w~vŽ{rˆvk†th‰xl’{tŒxp‹zq‡vm‡sl†ph‚ofle…rkƒqj„rj„thqc|k`‚lfˆpk‰smŠwpxrŒxq‹xq†ulqhˆymytztˆxo„tl€pjƒplzle|oe~rfth|pf|nfqh‡vm„qi†ti‰vkˆti†og€k^na…sf…uh‡umŠumˆrlˆrl~ictaZ|h`ˆvnŠwo„ri‚sf†wk…vi„pi‚sjƒsj„pi€ldwf]xjc„qi…rk„sj‚ri‡sk…rk„ri}of…xk‰{mŠzmŠyl‡uk…sl‡qk„nf†qf†xkŠzm†vk€pdoc„uiƒphofpi…wj†wk‚reznb‚rg‡tl†th…tfƒuc‰wjˆvjvfZvfZˆvk†thqh‚qimg†ri|i\weUxm_~q_n`mepc[i`SsdUwfVzgY€l_n_~o^“ƒw}q‰uk‹vjˆtj‰uj‡ul‡tl†tkzkb~phtl‚uosjpg†ul‚qezj^uf_|ne}pf{oeui^ym`…rg€nfzib}mf€qhsgrc{m`sh‚umth|se~umukti{nc€phƒrjƒqi‚rjti€sjƒri€of{ldtkƒwmƒwj‚wj„yk‚vk€siwkawl_ƒvjƒwkƒui~pd„vk†xjƒuh€rd…wlˆxpƒtmohyneƒym‹yq‹zo‹}q~p‰xj‡sdymb…{nˆ{o‡tmo`\f^_sfitkkrkhngcneathdphkpggmc`ne]h`Yg`Ygc[ka[j\VhYRbWO^UMaUOcZOc[NaZKg\Sg[Ug_Uqf\yk_qcXoaWk_Vi]Wh^Vg_Xkg^he[gf[nlhrnimd`ne]kf]ji_ljbni`pf_maZcVQ`TNeZPaVLaWMaVL[ODZNDIeNLhQOlVOlXLqXHoVHmUGlTMnUNnVMsYQt[TrYXqW`qYft\br]es^hr]psdqp`ql]qkYokXom[on\ln^qrahtckudjs`mo]io^bn^`r_\v`\ycbzdgxgiyirxgowfowfjraiq`lratvfuzft|ftycrtavvexyew{gwku}jnlf‚nd…ra‚mckf‚nfnbzjkqcuoa‚pc„qd…qh‰ul…ui€qc|oczoexpc€xgzh|{jw|kr|klzjdvfptfste{wi}yoxz~”“€¬³sš o‘{މˆ‚„‚ƒ||yqzsiypc|od~odna}k_{i^|i^{i^}m_ma„oemflemeoeƒob„qe‚odmb~mb{layg\zh]€la€la€lak`‚j`€k`€lakald…ldƒqf„pe‚nd‡qf†pe…oc~jbyh_{ia}lc{g_h`}l_€na‚oc€ma„pf„og…mc…mb‚nc†rgƒrgpeƒob…ob‚ob„odƒnd€me€mfldƒnf…phŠrk‹umŠwkŒwm…qi‚qhndqcƒre„sf‚rd€obob~maodƒqgqenc}laoc‚ohƒpiƒog‡rjˆrj…nh‚qe„rgˆvj‹woŒwoŒvnŽupŽwpwmzo’|q“}r“xr”zs“yr˜wz€y›…y™„x“€u‘}r‘{r•{t–u—v•€u•r•~s’{pŽwo’zt“zsvmtj“xl’xq’|s‘~v‘v|t‹vn‹qkvn’|p‘{o’{pzmŒxq‡tl‡tlŠtoŒvpwq‡tj†si‡ujŠxmŒzoŽ|r{oŽzo{p‰vk„sh…uiŠwm‰wl…rjˆum‡tm‡tl†sk‰tlˆrj‡ph…phƒphŒwo‹vn’wp“zsyq‹vn‰tlˆqiŒtmŽvoŽtmŒrk‰shwmŽtjrhŽtjwl†um„rjƒnf„og‹uiŒuj‰tlŠum‰tl„mgic…ni…sk‡sk†qiˆqi‡pg…lelaƒqf†ui„th‚rfƒsg‚umohƒpi‹uoysŽxr“xr’ztŠwpoh€oe„tg‰snŠtn‰sm†pj†pk‡qjngˆsk‹smŒuoŒvp‰wnƒpkˆtnŒwo‘{s|pzl‹yoˆyl„uk…umŠxqŒzs{s}uŒyr†tn‚pipiŠwoŒ{r|s‡yl„wksg‚rk‘~wŽys‘ysxr‘zs‘zs‡umrj„ul{s’zr~s}t‰yq‡wp…vm‡ujŠxp‹xlŠxkˆuh‚pd‚pg†umŠunuoŒvn‡ulƒtk…sk€mend…uj‡vnˆyq…vp‹wqŽ{s„vk|reƒwjŠwlˆvm~mf}ph„tm…sl†sk‡vm†ulˆvooh}mf‚sjˆulwmxlˆwj†xi‡shla|j`ocrfre‚ri€qgof}ib€ia‡phŽwoŠun‚qhƒriˆumŠunˆuo†unƒsm…slƒpj~jc~jcngƒqh‚og€ncƒqf‚sfsgri„sj‰xlznˆwj†sj‡tl†tm†skˆtl‰vo‰vm‹zl~land‰uo…si†ui„ui…wk‡um‚og{gb‚oi‡tl…rj„rh‚pd‡tk„sfyh[|j]†th„sj‡qf~lapg€rire‚obpd„rfˆugqfodZld]p`…qa‰ra‰q`‡q`weT˜Š~t…sk‡tlˆwo…vn†ti„sipg|kb~nd€pd~mgm]V|icne}lc}k`€odƒrf„sfnftj_}tj…vm†rjƒphƒvl‚vlƒrj€ngzne…zp„uk„wlxk€wj€tlƒqjngƒrg…ui‚tgre~re~rf€si}newldtl€tj|rhypczre…vh‡xj„vi…wk†vj…tire}pd‡~qˆ~sŠuŠ~vŒp‡|r…{q|uk}uj…~oˆ}p‡|o„xlvj|re{pdsi\xk~ukuiak_Xk_Yoe^shbmc]mb[f[Ti_Xh]Xj_YmaZgZSi]Uk^Vi\Wi[UeWQhXQjYSkZQi[Ph\Pf\QkbYmf]ic\gg\{xm€yoqi[ndWrcXkdZhbWjaWnf[ldZkbXme]le\jc[kf[kg[mh]qh[qg\mg\le[g]UcYPh\PmbVi]TgZStg_sg]QnWQpXNnVNnVMoWLoWJmVKoWOpXRpYRqYTsZVqY`r\erZlt\rr`pp^pp]qpatsctscro^ol\oo^no`ln^fjZen^er`gt`jr_mscischsbbxc_zd`wbcvdgxgjxfhvdiuchp_ko_mo_yse}xh}yg{xfytexrcvvduzgu|iu}in{jk‚odƒob‚n^~ia€la}l_zllwksqerf‡wkŠyo‹yo‰yn…vj€tg}phvmc{te}vf}yi{|mv~lr|mjvepscttd}wi€wm~}wŠˆ™˜}’t}x~y~{u{u€{t|vm{shzna}nanc€nbmbmczh^}l`naobne€nfogne{kb{k^mb€ncmc~kd{ia{i^yg\|j_€mb~j_}i^j_€k`~mb}la€jb~h`~j_lb€la‚mb…od‡qfmf}ia~jbleiaƒkbj^na…qf„qf‚pfƒpg‚mb€lak`k`nck`m`‚nbƒod†rgƒodƒob‚ogmekc‚nf†qi‰tk‰vj†sjƒph‚pg€ndobƒpf…sj‚pglcoe€md‚mf„ph„pime€ldme€meog‡qi†qi†ph…ph„qfƒpeˆtixpwo‰skuqwp“|r–€u—v•u–}v”}u”~v•~v›‚z€y™v™„y•v‘}rwoxq”~t“}qyn‘{p”~r”~r•~u—v”zs“yr‘wnvmun’}u‘|tŽ{sŒxpŠtlŒqkŒrk’{r’{ryo‹wkˆumˆumŽyq‘{vys“{u‹xp†sl‡tlˆumŒyqzsŒxn‹wmŒwn‰uk…qhˆsjŠwl‰um…qi†rj‰um‹vp‰wnŒwoŒumŠtlƒnfƒqi‰tlŒvn“{s”|tzr‹vn‰ul‡ohvnyqun‰nh‰tixn”youl‘wm‘yo‹wp†sjƒnf†pg‹vkŒti‡qi‡rj…ph‚mg}ga€je‡qh†qi†qi†qi‡qild€mc„rh‰ul‰ul‡tj†sj…tm‚qinf‰slŒxqŠxp‰umˆtn…rk‚pineƒpe‡qjˆsl‡qj„oh„ohˆrk†skŠunŒuoŽwqxqŠwo„ql…rmyqŽzrŽ|p‹{m‹yn…ulpgpg…tkŠwpzs‹xp†tlƒqi€ph†woŽzr}u}u}rˆym€tg‚pi‰wpzsxq‘zsys‰yp…vm~rhtjˆwnˆum‰wl‰wo‡un‡unŠwoŒznŽ{s‹yn‹xmˆwl‚rf„tkˆwpyrŽyrŒyqˆwn‚uksi}qezob}re~thuk|pjƒrlˆwnƒukuh…wi‹xk‡vjxg`rj‡vn‰yn‹wpŠwo‰wnˆvo†sl€lfƒsiŠwlyo‹uj…rh„si…qf€la~lanc„thrfxja{kb…tk„qi‡sk‰vnŽyq‹xp…skƒqhˆsl‹vm‡um‡um…tl…sk„qj„og€jbƒmemf€ldzg_{h`ƒrfˆukŠwoŒwo‘zp“zn…tg„qhˆumˆun‰vn‹xpŠwp‹xo‹yn~laoeˆvm‡ti…tiƒth‚th„tk~mdzf_~kdƒpi€ne~kb€md‡tl‡ui†uhˆvi‰xl‹xqŒvk€md€qh…vmˆxl‰wj„vj‡viŒyl‡vkk^Voh`„tg…rb‰rbŠsc„oazh[’„wŒ|o…tg…th‚rf|mb~nbpfnfnfƒof„qemgraZ€oe†ul…um…vj‰wl‰wlŠwl€ph{nd€vk„vk‰xn†vk„wlƒyn…vlpi~sjƒyoŠzrˆyo€vi~rfrimf}jc‚qgrfpfzl`}pe‚ti†wl…tjƒul‡wn‡wnpgwka‚wl‰ymŠ~pˆ{oˆzo†xl‡ujzl`xk`ˆ~rŠ€vˆ}s‹€uŠ}p‡}rxoxpfzrfyk}thzqcvj^th\reYoaUlcVi_Si^Tk^Uk^Uj\Ti]UdXPg[Si^Ui]Uk^Wi\Uk_Xk^Vm^Wm`Vl_Vk]Tn`Wsc[ue]qcZqd[tgZpdXlbWne\nf^gaYfcYgcYf_UmaYmbWqdYme[ne[ndZmdZlbXlbYof]pf^od]nf\nf[mf\si\qg\nd[pf\qe]j^Uk^SnaVl^Wrc\‚ulƒulOoWSs[Ut[SqXRpYPoWMoWLnVPrZVs\UoYVoYXoWbr\lt_st^yraxp_vn]sl^pk\sn^pl]pk]ok]om^ll_gi]fn^fudexckubptdrteptdhwcd{ebxcaubbvfg|heyfgxekvdrsczuf€rf†yl‚wjvi}sg}tgwvfrvcuzfuxhpygn~li…pdƒj^~iX|f[|lbqqxuxn}ujuh„vj‰ym…umƒujƒuiqkyofysf~vg~wh€|m€o}ouyistdtue{whuhƒzq€|v}w~{rytkxqh}sjsj}tj|qh|pd|nbmb‚oeƒreodnf~kb|j_~l`|l`oc}lc|kb|lbwi]vi]{l`od€ncmb€k`}k`zi^{k_~lal`~j_|j_{i^{j^}la{i`{h`~j_lamb€laka‚k`mc€la€laƒmbƒlb…lbj_la‚ncod€oc}la~j_}i^~j_~j_k`k`}jb~kc‚ncˆti†sf‡tfƒqi‚pgnf|iameƒoe…tg‚of€menfmdoanfƒphnf€me~kc€me‚lf‚lf„nh„nh‚lfic|iald„qiƒphme„og„pe…rgŠtivoxpŽum‹pm’xr”~s–€v–‚w“€u—€x’}u{sŽyq‘{s–|u“zp”}r”t’}v‘{s‘zr•~v‘zswlynzo–€t•s–~t–|s•{t“ysŽsmunwoxpŒxpŠtlŒvmŽtnvp“{t”}u‘yq‰tk‰um‹vn{s”x’}uzrŒvp‹vo†pk‡rk‹voŒxoŠum‰tlwowoumŽtmwoŒwoŠum‰tlˆsk‹vn‹vn‹vn‹vnˆsk‡rjkc†ogŒumxp‰rj‰qj‹tl‹vm‹tlŽwo’{s“xqŒsl‡rgwm“zp—{q’yo’zowq‡qk€kc…nfˆqiˆqi†qi„og…ph|g_kb„ogŠskŒum‰tl†sk‰vnpg‚nf‡rjŠumŠum‹unvnˆumƒnfld„og„rj„ul‚rjri}mfƒpi‚ng‡qfˆsl‰tl†rjƒog‚og„ph‡tlŒwpwqysyrŠxpƒrlpi„qi‰vmŠym‰ym†ukof}neƒtk†vm‹zqzr{s‰xo‚sjsi‡{q{t“~v|t}tŒ|q…uirf†ujyoynxnŠxm‚qi‚uk‚vkƒwm‡vn‰vnŽypyrˆvn‰woŽzrzr}uŽ{qŠxmˆxl„ujsi…un‹zrˆvo‡vmƒtj}si€th~retf}te|tg{qetld~ng…tk‚sj„wkŠyl†uh†uh|lb€pfˆxl‹{nzs‰vnŠumŠum‰rj‚ld„th‰vk‹wk‰tl‚md}ld…pe‚ncmb‚pe‡vj…uh€of{j`…tk‡vm‡vm†ulŠwoŒyq‡tl€nf„qiˆrj…rj~ld~md†ul†rj†qi‰qg‰qg‡phldzf_|ibŠvkŒzp}t‘}u‘|s“}rˆvi„qhˆum‹xq‰vn‡tl†rl†sl„qi}k`‚qd„sf…peod~nb€rgƒtkri‚rf„ri‡tlˆunle{h`Œxozo‹ynŽ|qzoŠxnŠvklbƒri†xnŠzm‰yl†ykˆxkŠvj„rgpbXtj`ƒsfƒqd‚n`„oc€lbof‰znˆwl…rh„ri}lbuf]„th…si‡ul‹vn‹ul‹vj‚ohwe\pg‹ypˆzp†woŒ{oŠznˆxk|kcyka‚wn‚wk†wkƒth€vi…{oƒui~pi|riwm‰yp…ujui]~pd„tjnf‚ri…ul‚ukƒri|lc‚rj…vm‰yoŠznˆzo‹|q‹zqrizld‰}uŠ}o‰}qˆq…|n…yn‚sjwi\tg\‚wm}si|si~ri„uirg\neYldVldWmeXmdWlbVk_Sl`Tn_Sk[Oi_Uh^Uj^SqcWqcXrcXn_WrbZo`WoaVo`Vm_So_Vo`Wo`XpaXp`WraWrbUvg[vh\th^th]oe[rfYpdWkaWjaWj`Vg_VkdZhaXk`Xi]Um^Vn_WmbXndZlbXnbXmaWmaWqd[rg]rf]qe[mcYkaWrdWrdYpbYrd[ue]qbZrbWsdWo^Vo^VtcZud[RqYUrYWqZUoWXpYSnWPpXNpXRqYXs\ZoYZoY\q[`r[jt^rt`sr`wsayp^wk]ui[odVmfWrj]qi\rk^ml^kl_iqbhweiydlubstdutfvugnwfi|gcxbdwc`vcc~ig~jk~lr}kzxi|sdrf€sg~sg€th}tgyqdtsaqs`sscvvfuuetyjsol‚pe‚n]€k_~mfƒurƒzv|t}yn{sfypb€qfoh…ti…vi„um|qi|uh€wi‚yk…}o‡€q…€qzkwtestdute~tfth€wktl}qi}qi}og€qj‚sl‚tjƒtjnf~nb|k`€obƒqf‚ofnfld|j`zi^xjazk_{i]}k`|l`yj_wi^{l`€pd„qf‡qg†pf‚od}lazj^{k_|i^}h]~la|k_vh\xj^|ia}jb‚ma…od„pemb~j_~j_~j`la‚k`‚laƒmbl`la~j_mb€nc~la|j_|h]|h]}i^k`‚nc‚nc}jb~kb~leƒod†sgˆvh‚ohƒph€ld€me‚ld„pfƒpd€md~jcmeƒoe…seƒph„phƒog€me€me|ja~hbke„ng…oi„nhƒmg~kcnfƒph‚og‚ogme…qfˆtixmyqyqŽumŒqmsmyo’|q’}r{pzs{sŒyq‰vnyq’yqvo‘xq‘|t“~v”w–w—x–w‘zrynynyn“zn’{p‘{p’{s‘zsŽwq‘xpŽyqŽyqŒwoŠsksl‘wp—}v–w–€w”|vysvn‹tlyqzr‹vn‰tk‹uo‹uo‡pj‰sm‹wn‹wn‰tl‡sk‹tmŒumxq’zrzr{sxpŠum‡rk‰ulŠumŠum†qi†qiˆsk„og…nfŠskvnˆrj„nf‰rj‹wo’zr’{s“{s–{uvn‰ti‹vkxm’yo’xowkŠto„lf„lf…nf‰rj‰rj„ogˆsk„oglcƒnf‡sjwpwowo‹xp‹zq†vm„rj…qiˆskŠumumvn‹vnƒnfldme‡um„tltgsk€ohƒqj…qj‰rj‡rjŠum‰vn…rjogne‡vm‡tm‹vpŒvp‰vo…tk|lfnf†skŠwo|qŠ{n‡vm€pg~qhƒwm‰yp‹{qzr}uŠyp…vm}pf‚tl‹wlzpyrŠxo†ul†ul…ui‹{o‘}r‘}r|qŠxm…qjŠxoŠypŠwoŠwnzrzs|tŠypˆwnŒxp{s|s‹|s‡wn…wnri~oeƒsl‡wp†vorirh‚vl‡wl†vi‡vi…vhƒth€pfulc{le…qj„sj†vj‹xm‡wj†ui‚og‚of‡viˆwj‡tlˆsk‡rj‹vm‹ulˆri†tjˆvlŽyq‰ulme}jb…qf…qf‚od…sh…sg…sgnfzh_pgƒriƒsipg„tk‰wn‰vn…og†qiˆrk‚qe~na|l_‡vj‹xmxlŒvkŒvkŠsk…phjd‚nf‡wlˆxmŠzs‹{s‡wlˆvk„sfof…rj†sl‡tlƒog}ke„rk‚qh‚qh†wi†uhˆti„qf~nbƒui…vn‰zqˆwk‰zm‡tlŠxp‚mgzd^~rŒ|p‹{o‹{oŒ|p‡wk„pevcZog†ul…uh„sfƒvh‡vj‡uj‚pezk_|nbpbob|k_„pi‡ulˆwn‰yr‰vo‡tm‡tmng{ld‡wl‰xn‹xpˆvnŠwn‹xm…thsbV…uhŠxo‡yp„um…wk†wkƒsgzi`~oe†xp†}oˆym~pdthƒyl…virj€ul‚ynŠzq„tiznaƒvjˆznŒ{qŠyqˆzq‡{sˆwpqjƒvm…xo‹{qŠ{nƒyl‡|o„xn}rh€vnƒ|rŒ€s‚wkzqewmduk`tg]n^UpaXlaWmcYk_TnbVh\Ph\Pj]Ri`SiaTd\Oi`RjaTocWrdXqbVpaUl`VmaWrcZse[yi^xg]te]tf[seYrdXobTqcVr`Wp_VpaWlaWqaXsbXraUseWseYqeYnbXod[ocWocWl`Si]SfZPg\ReZRdYPgYQhZRgYQiXRi^SnaWl_Vk^To`WpaXrbYqbXqbXqbYpdZocYug[tf[q`XtcZuf^rb[scXtdXrbVueYve\ve\Xt[XpYZpW_sYbu`Ys\Us\Qt[Wv^[w__r]]t]Zs]\r]ar[gs]np]sq_tl[rgYoeVofXggVom\pk\ml]npajp`judjvdktaln]ol]pn`tobpvgj{fhzegyeg{hggijn‚lt€kxwd{r`ypavl`}pd~qezpdvn_sl]nl]qm^yrc|sgzvg{ynt~mk€md‚ne€nj‚qtwz|r{wk}tgzrc€pb€ngˆvjŒzk‹yo†xoxk„{n„|n…|n†|n…|mxi~vjsreptdwse}setf€qi~nfog€piƒsk‡woŠynˆvmƒqi}ldyi`}nc€ncƒph€mf~kc{i`zh]ug^yh^}k^m`€oc}na|lc}mdoeod†rg†rf…sh}nbwk_xj^|j^i^~k`|j_zj^|k`{iakc…nc‡qf†qf„pe‚nc|h]wfZ|i^la‚l`j_la€mcmc€mb€la‚nak^j_~i]€la„peƒpe‚od„ne‚ld{h`|jbncƒsi‚nfld…og…og…mfˆqh…pd„ne€kc‚me‚of…tg…qg…qgƒne„of‚nd€ka€lcme‚nf‚nf‚nf‚nfnfnfƒph„rjƒri€pgƒpe†si‰vj‹vnŒvn‹um‰qm‡qjŠtiŽxmŒujŒtjvnŽxp‹woŒwoxp“zr‘toŽuozr’|u“~w“€t–~w“}t‘zr‘yrxlŽxmvmxoxpxp{q’|s’{s’|t’}uzrŒslŽsk’yn–}t”}t”~t”|txqŒtmˆqiŒumwjˆshƒodˆrlŒvpŠtmŠulyn{oŠvlˆtj‰tkyozqŽypvpŽxqyqwoˆrjŠuj‹tm‡rjƒog…rjŠum‹tl‹sk‹vn‹woˆtk‚md†nf‹wk‘{o’|q‘{o‘xmŽuk…rg‰ti‘xn“zpxnwm‹rm‡oi†nh‰qkvoŒtlŠumŠum‡rk„pd„peˆthwowo‹woŠwo‰xo‰wnƒsj„qj„qjˆtlŒvowpndlb†pfˆsj‰vlˆvm‰vk‡uk‚piƒrk†rl…qjˆtjˆtj‡tj‚qg€pfrg‰wnŠxpyryr‰woƒripi†tl‹xpŽzr}u}qˆwp€ri{od~rhƒvl‹{o‹{r‰yp†wo‚sj€og‚rjˆuj‰vk‰wm…tk‚sj…xn‹{o€t’t‘~s~sŒ|oŠwoˆvm‰wnxqyq‘|t|v{sˆym‡xl‡um‰vo‰zo‚ulskƒvm…um„thŠxqˆwo…unrh|ne„ulŒwoŒxnŒynŠxlˆvk„qiuha~lcˆrj‡ul†tk…qeqg„rj…qj‹vnŠxnˆvjˆtlˆsk‡rjŠwl‰vkˆvjˆumŠwo‹yp‹xq€me}jcƒod…qf‚mcƒnc‚nc…qf…oglc„og†sk…tknezlb‹ypŽyqŽxpŒwnŠvnˆvjƒqenbˆvjznŽxl‰vo‰umˆtl†phme‚mf…sh„slqj~nf‚qj…ujŠxk†tk‡tl‡tmˆtl‚ng|ma‰xnˆvoˆwo‡wl‡wj‰vl…ti}nb€rf‰yp{sŠzmˆxlˆvkˆul€kc{g`Šyl‰yl†tkƒsjˆxlƒse~la|j`…sj…sk†vi|l_ƒvg‡ylŠxm‡uj‡uiˆxi„tg‚rg|kb…vlŠ{o‰{oˆxqˆvo‡tn‡tkpg{mc†sh…tj†ul‚ri„vk…wkƒuhsf}q‰ym„uk|lcui‡zn‡wk…tk…ul‡wo‡|qˆxn‚rhujƒuk†tk„smvm†|rŠzq„uj€wj…}pŒ‚uŠ}q‰|q‡yp†yrˆxryld}ph‚wm‚vkrf{qgvlbuk`laWpf\oh^seXnbVk_Ui^TmaVl]Up]Un]Ul^TmaUm_Sm^RncYreZsfYti\sj^ng]obVpbVsf[ug[qcWscWraYsbZsc[ud]td]ue^rc[te\seYseYqdVpcUsbUoaTlaUk`Sl_Vp_VnaUm`Uo_Um_Ti\Qi\Qk_Sh\PeYMgZNj[Pl]QgYNdVLhXQk[SjZSm\VnaXo`Wn_VrbYqaXraXsbVrcVpbVqbYtf\qf\ug[vf\ve\ve\ve]qbZtdYteYseWvh[xh^ud][t\^s[asZfu]eu_cycZxaXybYw`\w``r`Zr\Ws\Ws\\t\`s\nn\qm[sl[rk\nk\hiYenZin[ko\jp\graetbhudjucmq_pkZohZlj[tnbqvfn}im}ho~hj|ij~hjjl~ip{gvvcxp_vm^uk]|l`|m`|n`zn^uk]ql]uo`znb€rf~sgtkwwkn}jh€mgkm€nt|qxylzuf}uguf‰zlŽ{u“~p—q”tŽu‡~p†~r‚zm‚yk‚wjƒwhƒxh}sgxwltxlxxj}xi€yi†vk„tiƒsgƒsf„thŠxmŠxmˆun„qk€nhzjcxjapeƒohnfnf}jc|j`wja~mbma…oa‚pc‚rfpg~lc|k`€mb€oc„seƒqfqdyl`yl`~la‚lalancod€od€le€kc…od‡qf‡qe‚nc‚oc}k`wg[zi^€lamb{h]|j_}lcqfƒqfƒod†pd‰pe…mb‚j`}i^€ka~ma}ma„mb‚mame~me€ohpi…nfƒld†nfŠrj‹rjŠqjˆqeˆri„ng€kd~lb‚re‚pc‚ob„qd…re…reƒqc‚pfƒsgpeƒrgqe‚qeƒogƒph†rjƒsj†tl€nf~nb€nd„rg…rj‡rj†qiˆsoˆslvlxnukŽsk‰skwoxp’{s‘xp•xq”xsuo‹uoŒwoyq{pwq‹tm‘zr”}u’{r‘|p“yt’zsxpŽyn|q‘r•~v•}u’}u•|tun‹ohuj“{o’|pŽxmxoxpumslŽwovlˆsh„pe‡rlŠtm‹voŒxm|nŽznŠvkˆth…shˆvk‹yn‰ylŒtoŒtmxpxpŽxlwlŒun‰skng‡skŠumŠumvnxpŠumˆtlia€haˆshŽxm‘{pynŽukŒsi„rg‹vjyn“zpynzpvpŒrl‰qk‹smyryqxp‹umˆsk‡tiƒod…pe‡tmˆumˆumˆum†tl…tk„tmƒrk‡tnˆunŒwqŠtmoe€nbŠuiŽxmŒxmŠwkukŒul†qjpi„qj…rl‡sg‰vl†si‚sf…vi‰{o~u~v|uŒys‹yq…tk„sjŠvnwowo{sxpƒrkzmewka}pfre†vi„vn€skpi‚rk‡un‹yq{qsrˆyp…wm„xo~t~u‘~u‘~u~uŽ~t‡zpqi~og†wn†woˆwnˆuo‰yp‰|p‡xlˆxo‹xqƒym~sj|ri…voˆwoŒyoŒyrŠwp‡uosi~of„sjˆum‰umˆxl†uj†ul…slzkb‡qivo‹vo‡sl†ph€oh…tlwqŽwqyoŠxlxpŠul…rjƒqg…ui†ui…qj†slˆun…rj€ndk`„peƒodmb}i^‚nbˆthŽvnwpŒvnŠvnˆvn‚qh|me‰wnzr“{sŽxpŠumŠxjƒre|k^„sf‹xk‹vi€oh‚qj…skˆumŠvkwmŽxm‹vpˆuo~kdˆsl{p|p‹xo‡tl‰voˆumle|m`‡wlˆvn†um†uk„ti…ti€pdzk`}ncƒrj…rj}ocre‡uj‡uj„pfˆrh‰zlŠzn…tk€pf‡wi„th…thˆul‰vmŠwnŠ{nrcU‚ufˆznŒzo‹yoŒ{o‹{l‡wkƒrhwh_‡xo‡{m…yh‚tg…uh…ti…tf€qc}naƒqf„shpg}ofvjƒxmŠ}n€rŒ}qŒ|o‡vllcvj‰|pŠ{n‡vm‡vm‡vmˆ|r‡vnƒqi…vl…vl‡tl†tn‚vmuk†vmyj`ypb{wi~wi{revk_wkbxjgpa[ob\rh`qi^ofZrfYpcZq`Yq`Wm]Sj^Rk_To`ToaVlaVl_VpaYve^r]Vo\SraYudXp_Tq`Trd\vh]xk\zoavk`qi`ug[seYvh]vh]tf[rcWuaYwc[ub\sa\rb_qb_rb[sc[sd[ug[reXobTr`Um_Qh_Ph`Rj_Qm\Si]Tj^UgZQhYPiZMhXLg[OdXMfZMl^Rm]Ql\Pm]Pm]Qo_SqbZp`Wn]WrbYp`Wp_Wq`XtbZq_VpbUuf[ugZug^ui_rf\rfZtf\wf]ve]rd[pd[te[tgZtgYsfYug\td]cs\_q[dq\nt^hwcjxcixahzc^w_Yua[r^Yt\VuZYv]Zu]\r_op_vobwnbtqaot`lr]eo[eo[gn[io\ko\jo\lo`ln_on`qk`qh]tiawp_xucwyfs{hn~lj~kh~hlyeqrbsrbsoask^uh\xg\{g]~m`nb|oayodvnatm^sl_wncxofynhxshlyjerh„vo‚rv…xy~q€zl‡ylˆyl‰{o~p“s’‚u‚vuˆ|s…|nƒxktfue…ue†vfug}ufzm}€qrzo‡yn…wk„vj‚th€qh‚qi†ti…rg‚pene{kb|ld€nb‚qeƒqfƒrgƒrf€nbƒnc€kb€le~lbme~ngng}le{kdyja~kblbpc~naobmaƒnb…nb„pc†pc…pb„oboc}kb|l_„of„jc‚ha€ld€oh}l_ƒpc…pd‡qf€la|j_ocƒsfƒreƒpc‡qg‡piƒmg€lbl`|l^|ja}ic„ld„nf€meƒoh…phŠpiˆqi„nf„og„qi‚qiƒqhqf‚qeqenf|kbmf€qdod€pfpf…sh†viŒvl†sh†ti„tg‚re€obƒph‚qh€pg‚pg†ph‡nf…od„od‰sh‰rg‡qf‡qf‹qkŽuo’xr”zt“ysŽuosl‡rj‰tlxpŽxpunŠqjŒtmˆskŠumxo”ztŽyn‰rjŽvp’zt”}u–€u’~v”~v•{t“xq‘wp‘yq{szrxpŽwovoun‹ujyn‘{owlŽxmynzn‘}pŒzlŽ{n{n„sg…ph‡rj‰tl‹vnŠum‰tlŠslŠvlŠvj‰xkŒ{nŠxnˆtiˆtiynŽzoynŽynxpŒwo†tk…tk„sj„rjˆtmŠtlŠti‹th€jajcŠtgŽxm‘yovm’xmŽthˆrj‹tlwpyq’{s’|t‘wp‘wp‹qiŠpiwm‘xnvmtmˆqiŠrk†pj†qi‡si‰sk‡sl†sl†sk…ti…tk†tkˆsk‹umˆsk‰tlnfle…phvntlŒslŒwl†rg‡rj‡rjŠtnŒvpxqŽwpŒtnˆskˆtm|q“}w{t‘~vŒ{r‡yo‚viqi‚qh‚qi†tl‡xk…ui~pd{pd~reˆujŠuk‰wlŠxoƒtk~tjƒwm|s‘|ts“v‚vŒ}t…zp‚xm‡wp‘{uxrŒzsŒzsŽxr†wlƒsf„th‰xl‡vjƒsf‡wnŠypŠxpŽzrxqyqŽ{t‡sl„rj‡voˆxqˆyqŠyo†vmƒul‚qhƒog„og†oiˆtl…ui‚th…ul†tl‡rmŠxpŒ|pŒ|nŠxl‡sgƒph‡tlŒyqzrˆumŠwpŒwlˆsk„og„oh„mg‚ng~ke}le†sk†sl…pi‚le€me€mfld}h`€mf†tlŠumzr{sxpŒvn…qi~k_‡si‹tnˆrl‡si†sg‡tg…qe…qf‰ti‹vmŒwoƒmf~jbŠumŒzn{q}r‘|t{o‹wj†sfˆth{s|rˆwn†sk‡tl†qi‚me}l`„qh…ql„pk~lf€ph†peƒpenc‡tiŠvk‹vj‚pdƒpg|sŒ{sŠyqˆ{o{sŽ{s‡tl|ia†vl†vm‰tmŠwmŠzmŒ|o‹xlp\S€rh‡vm‡uj†ti†wj„ym†xl„thƒsg†vjˆwk…th€neƒph‡tlˆvmˆtl‡tkˆwf‡vj~ogzog„zn…|m‹}oˆ{nˆ{q‡yp†wk€re}vi…xlˆwn‡vmƒtm€un‚tlqk{mf{nhznfypczlcti^ui_th^pdZqe[rf]ncZpdZn]Wo^Xsb\r_Vuc\xfcxebq`Zrb\na[oc\pb[m^Tl^RmaSlbTm_Up`Wp^VtbXvhZq_SqaTseWreWrbUtcVxfZyh\yh]vf[vh\vj]xhayg`uc\tc[s`Yua[tb[r_Yo]Xl]Wj^Wi]Un]Vq_Wq`Wq`Wn]Rp`Tr^Wo]UiYQhZQiZRm]Qm_Sj[PhYOl\SiZRhXOlWQjZSj^Wi_Vl_Vq`Wl_VobYobYpeZqe[qcYpc[qg[sj]qgYreXsdWug[vi]si]vkavh_ve]sg]tg[xh\yi]ug_re^ue\xh_te\ue\rcZsdZ^t[XpY`s_hv`guajzeg{cax`Zt]Vq][q]Wt[Wv]Zy`\y`\t^fq[pq`rqbmsalvaku_gr_ep\gp\io\kn[hkXli[pk^sk^ri_vkawj_xo`wrbutepwfl|ii}jefixbns^mn^rnaxocyj^xh\{j_na€pc~rc{pdynaum^tk^ri]ulbukcqpgkxb‰…eŽŠl‰‚x‡~~ƒx…}s‹zoŒznŒ{p‹{lŒ{o~rŒ}q‹zrˆyo„wl„wjƒvh…thˆwi|m†yk‚vi}ug~|n}pxmˆwnˆwk…uh„tg€oc€oe‚oe„qf†pene~kcof‚pd†ti†ti†ti…riƒqh€nc~l`}ja}jb~kc€melele}lb}jb~jc‚nc‚od€oc€od‚peƒodƒmbƒpd„rdƒn`ƒqbnb~ld|k_ƒnd†le‚iaib~ld„rf‡thŠti‡qh…qg€ldmboc„qd„oc„md†ke„mf…pfƒoc€k`lb~jc„me†ph…qi„phˆrjˆrj‰rj†phƒnfmene€of~ob}ma}lb~ld~ld‚og„sgƒrf‚pg‚rh„sg‡vi‰tm‡tj„tiƒsgƒqeobldofoe~kcƒld…mf†qeˆrg‰thŠuj‹uj‡rg‰slŒvozsyrxqŒvntm…og…qi‰tlŒwoŠqjŠqh‹uk‹vmŠulzp“zr{pŽwoŽvo’zs•~v”}r”w’|t”zr‘wpŽtmŒumzr‘yqŽwoŽvnzryqyo’{r”~tŽwnŒvmŒvmxo‘{rzqŽypŒxo‰vmƒnf„ogŠumŒwoŠum…qi‹rlyoŽzo{o|s‰wo‡uj†uj‰wl‰wl‹ynŒzowpŠum„sj~mdmd†rjˆrlŠtltj‰qg‚kcƒmgŠuizq’{t’yq‘yq‘zn‹tmˆqiˆqiŽvnxpyquouo‹qj‹rjwm“{pxrvn‰skˆqj‡ql‡qk‡ri‰tlŠtm†sl…rjƒqfƒqiˆsk‰sk‹sk‡rj‡rj‚og„pg‡skŠrjŒslvoŠvj†qiˆsk‹voxpŽys’ztxrŠvo‰tm‡tlŠxp{uzrzr†ulƒsi‚rfogof‚ph†uj‹zo‡vk€oe|qfƒvkŒzpŽyp|rŒ{rˆzqvlƒvm|t‘|uŽsŽrŒ~q‹|s„wmtk†um‰un…rjri‚tk{sŠzpˆxnŠyoŠzo‰yo„ti„ul„ulŠypzrŽzsŽzrŒyq‰vn‡sl‡umˆvm‰vm…tkpg€qh‚tk…tl„ri„pi†sk†vk„sh„qiŠvoŽvrŒxqŒ{p}pzn‹vkƒog†skˆvm†sk‚qh€ofˆslˆtl„ph…pi…qj…qj€nf}jb†rjˆsk‰ukˆri‡tl‡sl‡qj|f_~jbphˆskŠum‰tl…ph‡rj„ngƒod‡ri…pi†pi„pf‚od‰xiŠykŒymŒyqŽzswr‰tl„ogŒwo|s~r~r‘|t|qŒyl…sfˆtiŽyq‡um„qi‡sk‡sk†qi„og„rg‰umŠsm‡rm{ib„skŠwl‰wl‰xl‰ym‹xmxn…tf†thŽ|sŒzs{sŠzr‹{rŒzqˆumtaY†tk‡vn‰un…si€pd†uh~laze[„rjˆtlˆri„qe‚rf‡|n‰znŠzn‹zoŠzn‹yn‡ujne†ul‰xo‰wnŠypˆxn‰uhˆwmyibvha„zpƒwk‚xjvlvmtk…ul}k`{oa{nb{nc{mdvg`tf^wf^tc\p_Zrb\paYpbYn`WobXoaXse\pcZrd[obYnaXo_Wm]UqbZtc[veYxg^zgbxe`sd\se[sf[re[obXnaVj^Rl_SmcUm_Tn^Up_VrcXsgYs`WraWse[uf\udZxf]veZxe[vfZscWqcXxj]tc]p^Wo]Vm[To\Uo]Uu_Yt^XnZSkXQlZSm[TlZSm\Tn]TkZQn]SoaSr[Vo]Vn_Vn^Un^Up`Uq`Tl\Om]Pl[Pm]RjZPt^Xo]Vn_XnaXo`Vp^Vm]To_VqbYsbYve]ue\ra[qeYtg\uiZtf[veZvfZsfYsg\sh^tg]tg]sg^tf\ufZwg[uf]vi`vi_vf]rcZve\tcZud[^u\ZvaXt`_v`fraewbaybZw^Xt]Wr]\t][waXx_Xx_Yv_[t]^s[ft^is_hvbgwahw`gq^eoZfo^kp_np`mm]rh[ti]vj^yl`zmaxj^xmatl]rp`pudkyggzec}cn}frxeuyhyvj~tk|oazl`yk_{k^}m`}o`zmaxl`xk_vk_si]vlcxodrtmn‡‰iš¢i›¤j‘•yЇ|‚}zrŠypŠxl‰wl„vi…xj…ui‡wk†uk…rk„tj†tk‡tmŠxl|q{pŠznˆuk‚thzsf~uh‚tgˆsl‡th‡se†sd„qbƒpcƒqf†rg‰sh‡qf…qg†ti„tdƒrd‚peƒqf…riƒohoc~mazj^{g`~jb„me€kd€me~kc~kckc‚meƒnfldld‚of€meldoc‚qf€obnd€oc{la~k`md†og‡me‚le‚lfnd‡siˆri‡ph„ohmf‚mel`…ocƒla„ka…ld…kd‰ohŠpf†qfˆqi†og‡og‡rj…ph„og‡rj‡ph†og„ofleƒog~kcme|na{j_zjakcƒnf…qhˆuiˆuj†sk‚pg€pd€pd…rkƒrjpg‚qh…qh†qe~le‚ofof~kc€kc„og„qi‡tkŠwoŠxm‰xm‡ui…phˆsjŠum‹vnˆsk‡rj‹tlŠskˆrjŠskŒvmŠtl‹rg‹vjŒxmzo‘{p”zp‘{p‘zsvoun‘zrzoyrxpxo’{s‘yqŽxo”zszrwoŠumzrŽ{s”|t•~v“|uvn‡pi†og‹tlŽxpxp‹vn‰um‹xpŽyqŒxpŽyq{sxp‰tl‰tlŽyp‘}r{szuŽxsŠwo‡tl…rj…rjˆul†tk‰um‡um‚og€meƒogŠtkŠsl‹umwmŒtj…nf†oi‰tlŽxqytxs‘{tyqŽvn†og‡phŒumŽwoyqŽtnsm‘wp‘wp“yr–|u‘{ryq‹tl‡ph‡oiŠrkˆsi‡skˆrk‡rk‚oh€nb…piŠsk‹rk‹qj‹skˆqi„ogˆskwoŽwoyqxpxpŒwo‰tl‹voŽyq{s|u‹xp‡vm†ulpg‚si‡unˆunˆvn‰tlƒoeŠwkŒwqŠvnyo|q}r‹xpƒsj}pfƒtkŒzrŽ{s‰zqŒ{r‡xotj€tj‡wnŠwo‰ypƒtk†xo‰xoˆxo‡ul†vl‰tl…sj~qg~tiˆyoŒyqŒyqŒyq‹yqŠwo…rj‚sg‚ui‹{p‰zn‹ynˆvkŠxn‹ynŠxnyoŽynxmˆum€pgog€tjtj€qhƒqi…tkˆwl„rg„nfuoŽvpŒvn†rj‹wlynŠwkwpyqŠwoˆumpg€of‡ulˆwn‡vm‡vm‡un‡uo„phmeƒoeŠukwlŠuj†slˆslƒng~hb~icng…rj„qi~kcƒph†sk‡tl†rgŠum‰tlxp‡sk„pdŒ|m‘r’u|tŒxrŠwrŠtmle‹vn|tzp‰ymŽyn‘{pŒwkŠtiŽxmwm…rgƒnfƒnfŒwoŒumvo‹xpŽzrwpŠumkcˆwoŒym‰xm‡xl†xlˆxl‹zn…ud†ug‹xp‹xqˆun„piƒtk†tk„qi|jb‡tl‡vmˆumyh`pd†vj‡uk‡ti‰uo‰um‡skƒsf€tf…|m‰|pŒ|oŠzn‹{oŒzoˆwl{lcƒtkŠzq‚sj€qh€pg€ma~lbo^Wm^Xvg_sf[og\ulctiazldzh`saWudWseYpfYpf\paYq^Wu`Vu`Ws`Xs_Zwd]ub[te\wg^td[wh_yiaxi`p`Zn^WqbZsd[pbVseYyh[zj^yg^xf^xh]ueXxh[vfYseXm`Tj^Sk_UlaVi\Rk\TqaUqdXndUxg^ve\raXtd[we]wd\xdYtaVo]Rm]Qo`ToaUn^WmZTkYRn\Uq^Wq_Xu_Xwb[xd]xe^o\Un[Tn[Tp^Vl[Rl[Rp`Un^Qs]Wq_VqbYpaXo_Vn^Sp`Sn^Qn^Ro_TrbVwf\u_Zp^Wn]Tp`Wm\TmZNn[Tp]Uo\Tq`Wp_VraXraYudZvfZteXtcXubWueYue[sd[rf\ui_sg]tg_yh_ueXudYufZsgZth_re[te\sbYvd[yf^^t`[{kWxjUra^r`]tb\xaWt^Vr[Vr[\w`\ybXyaUw_Ut\Zw^]{_czadv`ewbfvbju`nq_lq^qverxgxxiroawj^vi\wi]uh[ug[xj^ug[rg[pj[pp`nvelzei{co|es|gv~n{|ozsi{ocxm`vk_xl]zk^}m`zn_yl^xh\{k_ui]yob{rewxpt‰‹{¤°y§±r˜œxŒŠu{zwp€tl…wl€sg~serfrf„sg†ti†uj†sl‡tk†sk†qiˆtiyn‡uj‡th†sh|pdyl`€oc…ph…rfˆug‡uf‡te†re„rg‡sh‡rgŠtiˆti†ui…tf‚qbodod‚ognf€oc|k_zj^}maƒog‡qiod‚pe€ncld}jb}kbldld‚me€me€neneqd‚qfƒpfoc‚qf~nb~nb€md„ph„og‚kd‚ke€mc€lb„me…ogle‚oi‡pg†pe…oc‡qe†oc…ld‡ncˆngˆoh‰ohˆqiˆrf…qi„og…nf‡ph…ph„og‚kc€jb‚meldƒnfƒnf€of~md}jb}jb‚nd„pe„qd„pe„qiƒqh€pc€pd„rlƒrj~of€oeƒpf…qfƒriƒph‚og…ph‚meld‚oh„qi‰vnŠwoŠxl†thog„ph„qi…rj„qi‚ogˆrj‹tl‹tlxp‘zr‘zrtjŒwkŠuj‹wlŽxmvlwl‘zrxqŽvpyq“}qŽvoŒvmyqzr“}u“|u•w–~vŽyq‹vn‰umŠxpxpvn‰rj‡piŠskŒumwqyszs…nh‰unŽ|u“}u–w—x–w•~vyq‡skŠulyn‘zrŽvqto…rj‚ogƒog…rj†sk‡tl‰skˆsknf€me‡rjvn‹smwoŽynŽxmˆqj„kfˆsk‹uoŒvqwrŒvp‰tmvnˆqiŒumŽwoyq‘zrvpuo“yt–|u—}v–|u“{u“|uvn†og†og‰rjˆrg‹sk†oi„ohƒnfƒpeˆrjwo’yqunŒvn…qiˆskxpyqxp’{sxpxq‹vn‰tlŠum‹vnŽyqŠxo…ul‚ri†tk…tm„tm†sl‡tmŒwoˆtlˆrhyo•|w•}v”u•‚t’tŽ{r‡tl~qh~siŠxo„tk€tk‡xo†wn„tk‡wnŠxo‰wn…wnrjˆwnŠxpŽzs‹xp‹zqŒwp‰vm~rh|rgƒtk†sk†sk…rjƒph„qi‰un†ui‡wk‰ymˆxl‡vk†ti‰wm{pŽ|r‘}s’}szoŠvp‚pg~of}qg€qh~nezjcpg‡uj‰tjŒumŽvpwnŒum‰rjŒvnŽzoŒ{o{syr‹xpŠwoƒri€of…slˆvnˆwn„sj„sj…tk‡phƒkd~k`†rg‡sh„qd€mf‡sl‰qk‡niˆtnˆun†sk…rj|ia‚og‰vn†sk‰umŠumynyo„oh€jb„tf…tfƒqf„qj‡tm‡sm…qg‚ndŠumŠwo‰vn†slyn|qŽzp{p{p{pŒuk‰siŠumzrxq‘|u|tŽ{syq‰ulkbƒpi‰ui…ti€qerfƒth…ui†vfˆwjŒyp‹xq‚oh}jd†vm‰wn‡tl‰vnŒzrŠyp†tk‚pg„sk†vj‡vk‡vj…um…tl„tkynaxoaƒ}m‰{p‹zn‹{p…uiƒqf€ocue\|md|mdte\td[ue\vbWuaYo]Vk\Tq`Xr_ZoeZoc\kaXoaYtdYwcWvdVueXqgZrgZtc[u`YxdXuaWt^Xuc[wd]yf_yi`vg_yjaxi`wh_uf]uc\uc\wf]sdZtfYtfYvgZwh[yi]wg[vgZscVsdUraUn_Sk^Rj^Ti]Sl]Tk[Rq`UscWtfYrfZuf]td[q`WubZubZubZvbWubWsaVscWo`Tn`Sl]Tl[Rn]Uq`WuaYr_Wo_Xuf[{l_xh\l\QlZSp]Vp]Un\So^Um^Tm_Sr_TraUoaTo`Wp`WsaXqaTn^Qp_Sp`TraWraXs`Yq^Un]To\Sm\Pp\Qr]Uq^Vp]Un\Tn^Uq`Wn^Xwg\zj^‚pc{h^ucXud[ud[vf]vf]ug\sh[zjayi`vd\vfYwh\sfXrf\te\sd[ud[xh_|lc]yjX€wS€yPznWvfYubYu^[u_Zu^Wu]]x`]{bZzdPu^Su\Yy_Y|_b}dexdfweltdtsdup_ts`xxg{|n~|owsfvl_tj]sh[ui[tgYsfXvf\ue\sg[tn_trasvcqucrverxfp{kt{jttezoctl^tk^uj\zl_{j^zm]}n`la~la{nazobxpd}wm{€|y’™{‘“{‹{ƒxun}qi€sisi€rfqe…ui†wk†vj†uj†sl…rk„qh€oc€od„rf†tjŠtj†sh~nb~pc…se‡rjŠvj‹xl‹xlŠwk‰umƒsg…rg‡th‰uhˆuh†vh…tgoc€nc‚pene„qh…qe‚pc~pdpdod†qg€qe€oc€nc~ma|mcylcma‚od€ma‚nc€od~nb‚qf‚pg†qj‡qi†th‚pc|oc|ka|kb~lc€le€kd~la~k_€j_‚lbmcld„mf†pgˆsgŠviˆsh†rf‡ndˆpg„ke…mf„neƒocƒng†og‡ph†og„nfƒogia}g_„nf„nf„nf…ogƒogƒnfkc{h^~l`€od‚pcnc€me„ph†sh„re„rj†ukpf|nb€pd‚qe†tl…qi…ph…og‚nf}kclfƒpi…rk‡tlˆvk…ti†qg…pg‡siˆsj„pf‚ne‡rjŠumŽvnwoyqŒxpul‰si…pf‡siŠtjˆnf‹ujyr‘ys“zu”}u–€t’wqŒwo‹woyq{s‘|t‘~u’}uzrŠumˆrjˆtlŽwn‹tk†of‡pgwm‘{q’{s”~v”€wŒwoŠumŒzq–w—€x—€y“|t’{tŒum†pj†qhwl‘{o’{rwpŠsk†og‡qh‹tl‹umŠtlŽunwoˆskƒph„ogˆrjŠsm‰slˆvk…rhˆsk‡piulvoupwr‹unŠukyq‘zr‘zr’{s“|t“|t“xtuo“ys”zt•{u”{sysxr‰qkƒldˆqi‰pjŠtivn‰qk…oi†qiˆsiŠunwowpwnxp‰vn‰rjvnŽwoyqŽwoŽwo‹uo‰tlˆsl‹vnxp{pŠxpŠwoˆvm†tlˆvo†tmŠvpxq‘{s’zrvm{p“zv”~u“€s‹zm‹zp‹xq†slrjuk†umƒtl{qhƒtk„ul…vm…vm‹zq‹zq…tnoi…sl‡vmŽ{syrˆwo†qjˆum„sksk†um…sj…sj„rhoe†sj‹xo‹xmŒyoŒznŠwl‰vk‡uiˆumŒyq|uŽ}tŠyp‹xo‰vn‚qhrhƒsj„qh‚nf|kdƒphŒwlzoyqys‘|ryp‹tmŒwpŽ|r‹|oŒzr‹zqŒyq‹xp†rjmeƒnh†qk…qj‚me‚nf†rkŠtm†pi‡rk‰umŠwm†tkme‰slwpwpwp‡umŒxpŠwome‚og‰vn‡tl…oh‡si‹wl‡sh€lb~h`|i]€ma€mb|h_‡tj‰vmŒwmŽzoŽyoˆun‰vn…sjŽ{o}qŽzrŽzrŽ{oŽ|oŒwk‡shƒogŠvnŠvo‡uo‚tl…tk†vj…sg‚qd„rjˆshnc|l`‚sg‡ymŠzn‹{m{oŒyqŽys‡qj‚mgŒyq{sŽzrŒ{rŒ|s‡yqŠym‚qh~ofƒtk„sf€ob}lb|lbwh\qdXymb~rh~pd‚rf‚rfyi]weZucXtcZwf]sbXq`WraXsbYxbWubXvdZsbXtbZwc[rcYpbZpbZvf^yh\{hZzkZxh[xg[we[we\xf^weZudZtaZtb[ue[wg\wg^vf]vf]wg]ve\td[vdZtcYve[wf\te[teZte[seZueYvfYtdWrbUq`Vm^Sl]Rm]Sp_Vn^Tq]Xp\Us`VucVudVrcVpeZtdZr_Vr`WtbXr`WxdYxdYvdYsaVp`Tp`Tl\To^Uo^UsbYr_Wr`Wo`YrdYpcTrbTlZQnYSp\Un[So^UqaXrdYteYvcWo^Rl^RpbVp`WsbYs`Wr_Uq]Ur^Wq^Vo\Up_VraWp^Vr`Tq_Tp]Rs^Vn[So]Up^Uo_VmaVoaYp`V‰wl˜ˆ{vfZqdWrdZqcZud\tcYvfZufZtgYxh[wd\zh^xi\thZud\vf]wg^wi`}neykbVzqT†U‹‰O†~T|lWwe]ta_v_[t_Ww`^y`\{bVxcRv_Ru\Wy_X}``}dbvcdpajl_sk`xm]wp`xufywi{ylztisl_ph[ngXpgXqfWshXyh^xg]ueZym_vo`vr_wqcvsdqtcnzhpyfqudypcvnatl_vl^xl^}m`}p`n_ƒodƒodpdzpbzpf|pc}vkszrnxurzvw€}ƒ„‚yqƒrj…tlƒtkƒth‚rfqe€pdqf‚sgƒpfƒqf€pdoc}m`qb„ri‰tjŒwl‡wkƒtg‡uh†si‰vk‹wlŠwl‹un‰sn„vk‚sg„sf†uh†uh†vf†si„rg…sh…sh„rg‡ug‰sg…re€re~pd~na‚nc€rdsf‚qeoczlaxmc}m`ob„pd„qdƒqeqdqeƒng†niˆph‰sh„rd}qevj_tf^wh_{ia}jc|k^€m`‚m`„ocmb}ka„nhƒne…re†tg…tg„pe‡pe†pf„lfke€lb‚nb€me…og‰qiŠpi…ofƒphƒnf‚ldjbƒld„meƒldˆpi…mekc|k_|l`~oc‚qeod€of…phˆsh‹vi‰uj‡vjƒth}pb{n`€qcƒrj„ph„ogƒngme~md‚nh‡qkˆslŠum‹xlŠvk‰sh‡qf‡qfˆrg‡qf…od…piˆrj‹rkŠqi‡rj‰tlum‹tl‰sl‡qjˆrjŠpi‰siyr–~x—y–w–v–|uŽxqˆum†skyqxpˆum‡tlŒxpxpŒvnwnzowk‰sh‹ujzo•~s•~v–y•€xzq‰um‡tlyq”}u”}u“|tyqŒumˆrl‹ulym“}q”|o’{pwn‡ph‰rj‰rkwpxp‘vnŠrk‰tl†sk€me…rj‹voŠwo†uk‚rh…sk‰sl“wo’wp’xr“ysyqŽxmyqyq’{szr‘zrypsp‹pkuo•zt—}v”zsztŠtn‰ql„nf‘yrŒriŽxnxqŽvp‹tmˆskˆti‡rj‹vnvnŠum‡tm†ulˆrj‹tlvnŽwoŒvnxp‰sm‰sm‹unypynŒxm{qŽzs†sk‡smˆuo‰xqŽvp‘zs‘zqxpypxm’zv’{tˆwj…tf‰ynˆxp‰uo†vo†wqˆwq†wp|sjqg‚sk‰zq‰xo‹{qˆwn‡uo…rk‚pi‡vlˆwn‹zq†vo€ke‡rlŠyr‰vo‹voxm‹xm‰uj‡tiŠuk|q‘{qŽxnŒxm‰ujŠvk‡sg‡tmyrŠxq‰wo‚rk†un‹xoˆumˆumˆtm‰tlŠqjƒqjŠumzp’{q‘{t‘~v}qŒwmŠtnxrˆxn„wj†wn‚rh†tlŒyp‹um‰rj…oj…oiˆrl†qiƒmf‡riˆsn„pj‰vo‰wp‹zq‡ul‚ogˆqjyqumŠtlŠwo‹xpŠwo…rj†sk‹xp†tl„nhƒnd‹xk†sg‚mcjdƒog„og‚nbk`‰ujŒxn{p|qŽ{o‹woˆtl„pj†wiŠzm‰xnˆvmƒtg„tg†sf‚pd„ri‡tlˆvomhsg_‚tk‡wj‰ylˆyl…vkŠti†qfpd†vj~qŽ}rŽ}r}tŽ{sŽyqˆsk…pd‘|t”}uŠvm†sjqgul‚pdwh]xg`wh^wh[vfWucVvdVwdXwd\{h`{g`xi]yh\vgZudXtbXr`UsbZwd\tbYvb[vcZwe\|gZxgYxgZyg[xf[vaYubZtbZud[ufZxhZ|kZvjZyhZ{fZ|g[vcYte\wg^uf]rb[o`WsfZshZud[ud[scYxg^xg^ve\ucVr`UrbVr`Xsc[tf]uf]rcYscWueXveXveXsc[sc\rcZr`Wp^Vs`Xu^Yt^WvaUuaTq_RrbVpfXvh[scVwdWxfYtcVzfZ}h]vdYsaWp_Tn^Sk\Sl[Rp_VsbYq^Vq_Vr_WtbVucUvbSs]Ru\Ut]Xq\Vp_WqaXte[qcWtaUm\Pl]Qn`TqbWud[wd\p]Vo\UlYSn[UnZUk[Rp_WrbWvcYp]Sp^Sr_Vp]Un\Rl]Um`WpcYnd[pcXsdWyg[rcWn_Tne\pcYsbZr`TtbXyh]viXvfXxfZ{haxh]tfXye^wd\|kb{lcwlbti_UwY‰„\ŽZ‹ŒUƒx]}kct`fn^do`^raawa]vaYtaTq_Tr^Ww_S{b^{ceubil\lfXogZogZsk^tk^tl`tl_tl_rf^th[sfYrdXvh]skZwi\yi\yj\thZrj\sn_wnburdouflueopaqk_yl`|m`~pb‚pc~mb|l`{ma|la|lc}ldzlcxldxlbylcynd|qhzqgzrh}tiuk~uh€th†ti‡ui…sj…ui‚rf~na|k^oapfogƒsg€pdpc†th‹zlŒxl‘zn‘ymŒxkˆsgƒugtg‚sgƒti…rj†riƒueƒseƒsg‡ti‹ujxmynŒwl…rg„thƒrg„rg‰qi‚nfpg{ofymd{nd|qb}r`~sc}qc{pazn`nb‚oeƒod‚od…pf…qf‚qh~mcmc‚nf…piƒmh}mbyi]yi]{k_€k`†nd}j_}ka}ma€nf~ld‚lf‚lf‚mf„md„me‡qg†pe†oh‡ph…nf„me„me„mf„og„oh…oj†qh…rf‡tf…rkld|h]‚k`„ka…nbod‚pdpdmbmb‚pe†qh…qe„qd…qe…reˆtk‹skŠtlƒph|mcuj_xndƒod„pd‰sh…rgpe€pc‚sh…siˆukŒvkyn‹xnŒvi†pd€k^…od†pf…nfƒnf†qi…ph†qi…phˆrk‡ui‰wkynŽxluj‹rh‰thzp‘zr”|v”|wŽupŒvn‹woˆsk‡rjŒwoŠunŠtiˆrgxlwo–{u–|u•~v”}v’{tunŽwp”}t‘r}szs‰vq…ql‡smyt“|v”|v”|v’{vŒvpŠxnŒxm“}r“}r”€u~s{m‹wkŠqgŠui‹ul‰um†th„rfƒqh„qj†sl‰vo’zu‘ysuo‰qkŠrmŽvp’xr’xsŽuqvrwqvoŽtmvo“xq‘wo‘wp’xqsm‰qkwq’{u•}w–}v“{uxq‹tlsn•{r“{owpypŒwpŠtnˆrm…oiˆrl‰tlŠvkŠvk‰sk‰qlŒrjŽtmunvo’xqvo‹uoˆrlŠumŽyqŽzoynzszqwo‰qkŽtn‘wqŽyqxpxp‘zr“yr“zs•yt•ztun†qi†uk‡ym‰xm‰xnŒ{r{r‡woph‚oe„thˆwmˆwn‰un„nh‡pjˆtnˆunŒysyrztxrƒmg…qixpzrŽyq‰zlŒyoxr†lh‡pjŽyqŒxrˆtm†qjŠum‹wl‰vjŽvqŽxqŽysŒvq„pi‰vpŒ}r‹|o‹yn‹yn‹vkŠvk†vi„tg‰xmŽznypŠrj†qjŠunŒvn‹wmŠxm‹zn{m‡wisgˆ{q‹zn‹xlwoŽwpzq‰umogƒph†wm…ul†vlˆum‰umˆrk€ma„od‰sgƒpd|k_…vhzsxp{sŽxpzrŒyqƒtg‚pg‰voˆum‡sl‹uoŽulŽxlŠumngˆunˆwpŒwowovn‰rk‹rjˆph†uk‹uo‹sn„ng‚qf„vh‰uk†rk‡tm‰wp†ul„sh|lc†ul‹xnxnznŒwkŠum†qj|g_…pizrŒxo‹|oŠzoˆvn„rk}kcofr‰tj‚jd{d_}ib|ib|h\ydZwbZtaXucWwfVycX|f[xf[zh]|g[}g\zg`{h`zf^yc\yd\waZzeZ}g\i\}i\zh[zkZ|iY|iY|iXzkZyj[thY{g\zf[xeZucXveYyh^yg]vd[vc\vbZsaXs`XpbXscXudXraUyi^uf]rd\vf[veWzgZzh\veYufZvfZueYsbVueXwg[wf[veYwi]wh_xf]vc[wc[wcZvc[p^Vp_VtcZsaXq_VraWqaWvbYwaXvhZzi]weZxf\ve[sd[we]uc[r\Vr]Vp]Wp]Vl]Tm]Tp]Up\Vr[VqZTraVtfZsg[nbWp`Wq]Uq`UtaVuaVwaZs^Yr_Yt]Uo[Sm[PqaVtcWyh[tfYp_Tn\QpZQo]Rl[Qn^Uo`SucWvfWsdVrdWygWxdZo]Vp`YnbXofXsf\ue]xg_xd^r_Xub\s`Yp_YpbZqaZuaZzc]wh^ug]ud[wg]wf]xg^yi]|natgqdyi_~kda†~\‹†b––\••a‚_€pdtabl\]l\\r]`s_^s^Zs`Vs^Ss[Wy`Vyb]vadq`jm]hfXkfXmeXofYqh[qh[qh[pgZsh\wkZxkZvi[vk[sjXsiZuj\uk]pfXnfWok[rpcsseqteptemm_nl^zl`|m`obpcpc{l`vi]ugZxg^}lc|mcwi`uh^wja{mdzof|qg}rhsj|rf{oc|odqe„re„qi…thpenc}m`na‚pdƒqe„rg„rgƒrf„tg„wi†wjˆxkŠyl‰xk„tf~qe{mazl`{ma€mf€lc€qb‚se†vj‰wl{p•~q•|r|p‰wl…thƒrg„qf‰qj†qi‚qh~ne|md}ndpb„se…ti†uhƒrf€odyj^zj^}l`~mb„od…qfoglc~l`neƒmfƒlgoe~nb~oboc€mbƒncnc}k`|k`meld‚ne‚mfme„ne†of…od…od†nh‰qj‡piˆqjˆqjŠrk„pgld€jd„of„pf…se‚mf‚mf|h^€k`mb„oc‚odƒpe‚od€mb‚od‚pd„pg…qf„peƒodƒod†qi‡qh„og‚nf|kbyj`}nenc…qf‰shˆui…sh‚rf‚sfƒrfˆti‹vkŒvl‹wl‰thƒnb‚la…odˆrfˆqf„oh†qi†qi†qiƒnf†qi‰thŒwlŒxmŒxm‹uj‡rg†pe‡qgŒum’zt’zt‰pl‡rk‰ulŒwo‹vnxpŠvnŠuiŒvkŒulxp–{t–|u•~v“|svn‰rjŠskyq’}s’|s’{uxs‹tmŒunŽyq”}v—x—x—€y‘{tyq‹vmŽwn’|r“~t|s‹vk‰ti‰shˆsgŒvn‰ulˆvj„qf„pi…pjˆtn|t–~w–x’zsxq‹sl‰rktn‘vptpvq‡pj‡rj‹skŽtm‘wp”zt”zs‘wpsmŠrlŠtn“}w—y—~w•}w•}vxpvo‘xoŽvkŽxpxo‹tnˆrl‰rl‰rl‹un‹um‹uk‹uj‰rkˆpj‰tlxoŽxpŽxp‘|syqŒvpˆsk†qiŠum‹vnˆuizrŽxpŽwoŽvpwq‘yszr‹xpŒwo’|t‘{s’|t’zu”}uwo‰tl„tiƒvjŠwlypˆvn„sj†sl‚ph‚ofˆvm‡vn†um†qkƒmg„pi‰wozsŽ|u{s{t‰xqoh‚phˆwnŒ{rŠyo„tgŠwlvnˆpj‹umxowrˆql†qi‡sj‰vkŒzoŽyoŽzrŒwo‹uo…sk‰un‹yqŒzr‰vo„qi…qg„qg…viˆvk|r’~r‘{rŠsk†skyq{sŽzozp‘{pznŠynohŠzr‹ypŠvlyqyqŒwoˆskld€me€pg‚sk|ka~kd„ph‚nfmd„of†pfƒoezg^‡vl}u}u’~v’zrzr‘}vˆwkƒqgŠwoŠxo‹vo‹uovmwo‹vn…rj…rj„rkˆtlƒog…phwoŽxp‹vn‰xoyqxq‰slof„xj‹ynŠxo‡tl‡tl‰wn†thyj`€qfˆwl‹znˆtj…qh†sl†rk}jc}jb€mf|ja}k^}i`|g^}f`{d]h^{j]|h]|e]|b[}f^{f]{dYxaXzc[ycZydY{iY€j`~j_|j_|j_~j_j_|ja}ka{j`|i_|i_~i`|h^h^€k`€j^}j^}l`~l\m^xeW{iZtdVvgZwdYvbVsaVn\Rr_TrbVo\Tr_WtaXtbXucWveXsaZwdZvdXvdXwf\ue]wf^{h_yfYxeXzg[vbXwe[xf[vdZweZyg\xf[vdYxg\{l`xh_xf]wd\waYs_Ws_Wq]Ut`Yvd\tbWraUrbVueXwdXvaVrdWscXvdYucXtaZxe^tcXp]So\Rr^Tn\Rm]Rl\Rm\Rq^Wp]UnXQnYSr`Vwg\ufZpaXq^VtaYr^Tt_Ss`Ur^Tq[Up[UrYRnXPp\Rt`UvbWvbWn_SlZOlYOn[Pp^SraVqcZrcWudXtcWscXrcYvfWo^Tp^Wn^Wn`VobTobWscYueZtbWtbZraYs`YqaXpbZqaXub[xa[qbYrcZqbYve\wg]yg_zj]|nbqc{m`~mb|jcc{tj‹‡p™˜p››o…f}odp_cj[bm\bt^gsbaq`]t^Vt[Vu\Xz^^wb`tado]hl\jk[hgZoeXrfZqeYsg[sg[rfZsh[rhVtiWvj\vk]ujXqj[piZohYmgXmgXqm^rsewugxsfzsfspbsoayj^zj]{j]{k^zk^wj^qfZwh]wg[{ja|lb{jaxg^zi`|md|ne{lc}of‚rf~oc|oc{qb}ob€qcnf„sgƒpe„rfpb‚qd‡re‡rf‰uj†ti„riƒsi€sgsg„th…vi‡wk„th~nbwi]xj^zl`ncod„tf‚rf„tgˆumŽyn•|r•t’}rŒynˆvk‡uj…ti‹qj‡qi…rjƒripgneƒqf…sh„sf‡skog€mfyl`vi]zj^~la€mb…pd‚ph€md}k`od‚ng‚oh‡sh‚odoc~nb~ma€nc‚nb€mbld~kcld„ng…phƒnfˆqj‡qf‡qg„nc…mgˆpj‰qkˆpj‰qk‡pi†rhmc‚leƒnf†qh†rg…oeƒnci^}j_mb‚pe…pfƒod…qfmbmbƒod„oh…qg…qe€laj`€kc‚meƒog…ph‚nf}kc~ld„qi…qh‰tl‹wnˆtm…rina‚pc‰sgŠtlsmŒsm†sj‚og€mbˆrgŽvj‰sgˆrkˆsjˆskˆsk†qi…qiˆoe‰rgŒvk‰vk„rg„qf‰rgŠtj‹tl‘zsxr‰ql‡phˆrjŒum“|t’|tyrynŠvlˆph‰rjŽxp–{t’|t’{sŽwo‹tlŒvn”}u”}v”|w–~x•}w‘{qŽxmŒwo”~v˜y˜y”~v{syp‰tkŽwo‘zr’|tzs‹wlˆti‹ujŒumŽxpzqym‰uk†pj†pjŠtn‘|t•~v“|t’{sŒvnˆphˆqj‘uk‘vpvp‹tn†rk„qitlvn’xq–|u”zs“yruq‹sm‰rlŒuo“{u–|v’ztŽvpŒvmuoum’yn“yr‘wpuoŒrluouoŒsm‹tlŽxm‹uj‹tlˆqkˆsjŠum‹woŒwoˆskŠumŠum‰tl‰tlyrŠumˆskŒwo{szrxr‘yr“{uŽ}t‹yqŠwoŽ{s{s|t|uyrˆtl„qi„rh„sgŠuj‰sj…qiƒnf„pi‡un‡tm‰wp‡unˆvoˆtm…nh}jc‡tm‰yrŠzs‰vo‡sm‡umpgƒriˆwnŠzn†vj‚qdŠvlŒwlwlŽyo{owqŒun‡qi„piŠxm~qŽzoŒxmŠumˆum…sl‡tmŒwrwrŒvp~ld„qiŒzo~r~s“ƒv•€x{s‹umˆvmŒzrŽ{t{pzozo{s‰vnog†tn‰umŠum‰tl‹wo‡tmlc}jb„qh„tk‚sj|kb{iame~kcldƒogˆsk‰skƒog„qi}t’€y“~x‘zrxn{p‡uj€ne„qi‡qjƒng~gc‹umŽyqŒwo‹woŠwo‡tnˆumƒph‡tlŽzr|uzr‹zq‹yp‹xp†ti~oc‚ugˆxk‡ukme‚lelbzg\rdWtgZyi]xh\yh_{h`|l_€pdzj^zj_wg\wfZ|i\wdZvaY|g`~h^j_|k^}k_~i]h\i]ƒk_}dY~e[€g_€i`~h\€k^‚la€mb~lamb~k`€k`}m`}m`nb~l_|l_yh[|e_‚ldƒlch_|g\xe[zgYyeYvbWp\PscXscYtaXuaYq_Up^Sr`UtbWq^WtaXtbWudWwgWygXzcX|f[xbWtaVucXueYs]WwcYyeZxeWyeYyfYyf[zg\zeZyeZyeZyeZweZ{i^~lazg`yf^wd\zcZwaXwbZwbZwc[wc[wcXraVscWtdXvcYvbWrdXseYucXwcXwbXvcYtdXsaVs_Tr^So\Rn^Rl\PjZNp^So\VoZRp[TpaTsdXsaVr_XuaYs^Vp[SmYPm[Po]Rp\UnXRr]Ss^SubWs`Uq`Up_Sl^Rl\PkYNo^Rq`UqaUraYp`UqbUp_Vn\Vo\Wo_QjZPm\To^Vo_UrbUpeWsdWscUsaVtdXqcVuc[rcYscZuf]td[wd\ve]uf]wh_yja|jbzh^{k_|mazl`yk_yg^{f^]kaWf_]midsqjwoireln`ll_jk]ho[jo`jr_bs^]v]Zw]]zacudeqahm^lk]ki[hhXrfZrfZqeYui]th\ui]th]shYrgYsf]uh^sh[rj[sm^rm^pl]mk[mk[sn`wob|qd|ocxmawobwi]wgZyi\yh[vgZvg[wj\wi]xj^}ma€me‚og~md~md|kbvg^zka|me€nc~nb{mazm_|oa~oa„qh†ti‡uj…shƒre‚qdob…seƒrf‚pf‚pg‚qgpd€nd…sh‡tiˆtj‹vkƒsh~ocyk_~oc€od„rf„te…uhƒsiƒphˆsiyn“~s‘{pxmŠvkˆwlˆxmvo‹vn‰vn‡vm‰xopg{ma}oc~og~pg€qg{ldxl`yk_ocodƒpe†rfƒogne€nc~lamcneƒodod~na~nb~mama‚me‚me‚meƒmf‚md„pd…ph…phˆshˆrgˆrg‡qe…ng†nh†oh‡pjƒlf†nh„qfƒneƒng…ph…pgˆtiŠrh…nck`k_~k`~lak`mbƒod‚ncmc~j^€lc…pgƒmfjb~ib€lc…ph…ph…ph†qi…ph‚me‚og‚nfƒnfƒnf…qh„qi†rf‚oc†rh‹umŒtnup†tm…ri…phˆrhvjŒtiˆrj„og…phƒnf…ph„qiŠpf‹rhŒvkˆtj„rg„sgˆrgŒvmxp‘zr“|txpŠsk…nf‹tlwo‘zrxp‹vo‰tl…qi‰rj‘zq”~s–w’{sxp‘zq’{s—€x™x™y‚|›z˜€uxl‡rkzr—x•~v“}uxpxp‘zr’xq•|t”~u‘|tŽyqŠunˆtmŒwo’{s‘zrŒyn‰uk†qjƒmg†pizr”}u“|t“|tvnŠskŠsk‘vl‘wnwruoˆrl†rjŒskun”zs—}v–|u“yrvnvnˆsk‹vn•~v“yrŽvqŽvoŽwovo‘xo”{p–{u•{s’xrŒrlsmŽtnŽtnuoŽxmŒvlŽwoˆsm‰tkŒwoŽyqˆsk†qiŒwoŽzqzr{s’}u{sxpŒwoŽyq{rŽxrztzt|sŠyp‰vn‹xpzrzrŠxr…sk‚qh‡tl‰uk‹wlvkŒul‡rj‚meƒngŠtn‰voˆun‡um‡unˆumkd|ia†sk‡ul†ulƒqh„qi‰xoˆwnˆum‰xk‰ym†uiƒpf†rgŒvkxmŽzoŽ|pwpvm†phƒphˆvn‡wl…qfˆti‰un|s‘~v|u’{u”{uŒuo…rk‹wov”€z•‚{›†~–y“~vyq‡um‡um‹xp‹wlwlzoyrŠtn†qlˆtnŽxqŠum†sk‹xp‹xpŠxoˆum†skŠxoŒzq€me~jbkc~kcldƒog†qi‡rj‚nfnf‰xo‡um‡qkŠrmxo}oŽzoŒxn‰tl‡riƒmf}hbŠxo”y”w“~vyrzqŒyq‡tl‰vnŠwoŒyq‰xo‡sl…rh‚od|j_scWxj^}m`|i]zc[}d\}g[xeYqcUseXscWtdYve\xg^{j^}la{k_|k_zk^zj_{k^scYsd[xi_}l`‚ob~m`~m_m`„nb…ma†la†na‡ob…ldƒmd€j_l`ka~k`}la€ncla€la~nana|k_|k]|j]~j]{h`€iaja~g_}h]{g\xf[{g\|fZxc[s_Wve\ye]xe]vdYzh]mbwfYyf_xe\weZudWygXveVe\{bXwaVwcXvcXtbWu`UwcXye[yeZzg[|i\{g]|g\|h]{g\{h]}i^vdY{i^}k`{h`|i`xf^{g^{f^{f^yd[w`X|e\ubVtbWvfZwgZwg[vcXvfZveZvbWxdYvcXs`VscUp_Sq_Ro\Pn]Po^QiYLjYMhVJkYNq^Up]Un^Rq`Up_Tr_WtaYo\Tr[Sn[Rn\Qq_To[TpYRkZPp_TsdXscWm^Rj[Pm_Sp`Tm[PkYNp`ToaUraXraXq`Wq`Wn\Vq^Zp`TsbXp_VraXtbWwe[xi\vfYq_SraTrcWreYwe]vf]uf^uf]xh_yh_vc\ziaxja{lczi^|h]xh\{k_yi`xg^xf]}h`_h[ci[di\knbmlbqm`qm_qkaqk`mjZggYdiWamYas]cv`avaitejobmk]nj]pk]ok\sh[qeYpcWpdXsfZth\sdYthYpfXpe[se\tfZuhZsj[sn_urcppapp`ul_sj]uk^vm`xnbvl_rgZugZxh[xgZyi\~mb€ob}l_zl`yj^{k^lc|m`|m`vi\vi\tg[vj]|k_}m`|o`{m`~narcƒrhˆwk‰xlˆwk…tg‚re|na}nb}nb€oc~ma}l_ƒmbƒpd‡tiŠwlzo‘yn‰vo„tlqe|nb{ma€ncƒqd…sgƒri‚og‚ogvl|q’|r’|qŽzoˆwl‡xlvo‹vo‹zp‡wo‡xo‚ri|ocyl`{oa~qf|of|of}nb}nb€od„rg†qf‡th…oi…pfnc~m`|j^nb€nc~ma~nb}ma€nc‚nbog…og‡ph‰rh„peod†qg„qe†pe‰sh‡qdˆrfƒoe‚nd‚nd…qg„pf„ofƒpc‚mcƒnf„nh†qiˆtjˆrg‡qfƒnck`~h`}iakckd„nf†phƒme€jcƒodƒngƒmgkejbƒod…oh‚og„qi‚qh‚og}ldzh_kc…phˆqiˆsk…qi„qg„rh†ul‹vnwp’yrŠvm‡sj…phƒnfˆrhŠtk…ph†qi…phld…phˆslujwlwlŠvk†si„sh†rhŠvmxo‘}s’~uŽzqŒum†og†ogŒumŽwoxpŠvnˆskŠtm‹wm”~s—v•t–€t•t”~r‘{p”~s—w˜‚x–x•v“}r‘{oŠul“~t—€w•u’|sŒwnvo“{t—}v—}v—€x•~w‘{v‰un„rj‹vn‘yr“zoynŠtm‰rlˆrkŠtl“}r•~u•u“}syp‹tk‹tkuhŽwmyruo‹rlŒtlŒrkvo“yr”zs”zs“yr“zr‘zrŽxpyq’{s•{twrŽwpxp‘vo‘xp“zo’ys“{s‘xr‹sm‹qltm’upunulynŽyqŒvpwoŽyqŒvnŠtlˆskŽxq|q’}u“}v‘|t{sŠto†nfŠvnxp‹uoŠvoˆun†ul‰vnˆumŠvn{s{sŒyr‡skog‰um‹vmŽxl‹wlŒxn‹vnƒognfˆun‡tm…skpf…uj‰ukˆth‡qj‰tlˆvn‰xo‡qi…ogzs{rzoŽyoŠujŒxl‡qkˆqiŠti‹uj‹xn…tjˆrj‡rj…ph…qiŠwnˆvnˆun†sk‰vn’€v€u“ƒw˜x–v‘}szryq”x”€y–€z–y’}u‘|tŽ{pŠwoŒxp‹woˆti‡rh{o‘yrŒupvoŽwqŽxpxl‡um‡vm|tŒyqŒyqŠxpŒwozq†phkcƒme„nfoh„piŠunŽwp‰tm‹voŠvnzt’zv‡qk‰wmŒ}m’}qzpŒwpŠumˆslƒoi…rk“€x‘~v{s‘zrwkˆtm€ld|h`}jbzh_|kb~g_{e\xeXveXs`Ss_UxgY{dY{aX}cZ~g\ygYvcZvd[tcXxg\yh^zh^{i]mb„rgmb|j_mb|j_wg\vh^zmb€obl_‚odlbpco`‚ob„nc‡pa„nc„md€jb~h_j_{g\yf[yi]}ma}j_}i^~k_}l`nbl`{g[}i\zg^{h^€j_‚l`‚k`~j^~k`{g\zeZybYu`XvbZxe^yf^|ia}k`}j]zgY|f_ze]|g^{f\|h\|g[}eY{d[zd]xc\|g]{f[ycXwdZxe]udYxh[{i[zh^zh]{i^|j_yg\zg]{j^|h^k_ib|h`zh`yh\weZwdYzf[wcXuaVydWygYyi\wgZ|k^vfYwb[vbZwbXwcYucXqbVp`To]Sr^So[Pm[Qm]Ql[Ml[Nm\Om\Pn\Pm\Pm_SscWr`Uq^Wq_Vm[RqYSmYRqaVqaVr^VpXSn^Rn\Qr`To]RjZRk]Tm^RiZMjWLl]Pm_Sl_Sr_Xp`XsfYrcYqaWp]Vq`Wr`Xr`Wq^StbWveYvgYudXr`TtdXvf[qeZve[wf\vg]ug\ug]uf]ub[we_vj`xka|k_{h\{i^{k`zhazha{g`~iago[hp\fnYhmXoi]lgYmgYng]kd[hbUfdVceT`iVamYdq_drchoajk`mj\rk]ul^qk\ri[qg[jaUkaUmdWoeYugWtiVphVofYrfYuhXyi\rhYoiZom]qrapo`uj]qk^nm^po`tqctm`og[sh[zk]m`ncnc„pc‚pc|l_wh\xi^wg[xi]yk_wi]tg[wk^xk`}l`qc~pc}paqbƒqc€pe‚re„uh†vj‚repcyodwlb}oc~ocna}l_~kc‚ogƒsi†vlŠvnŽwnŽzr†ul~pd}oc}obpb…re‡uk…sk…rk†rj‹uk|q|p’}ryn‡vksgˆqi‡rk…vm†xn†ypujoc~nancƒqe‚pe€nc„rgƒpe‚ncƒod…peƒod‚lg‚ne‚pcn`|l^}ma}ma|maoc~nb‚ndˆpeƒoh„og‡phˆsgˆsh€ncƒncmb‡rg‡qeˆrfˆrfƒpembƒpd„oe†sgˆti„rd†rf„ng„oi‚le„pe†sf…qembk`~g`€h`„ld‡ogˆqi‰rj‰qi…ngƒodkdkeke€jdƒodƒnf‚ogog‚qhrizkbnene…phŒumŠum‰tl…rkƒqj„sjˆvn‹vnvoˆshˆui…ph„ph„rk‡sl‡sjˆskˆsk…ph„og‰tlymyoŽypxmŒym†sh…ph†rh‹wlŒxm{o‹vl‹sl†ogˆqiŒvn‘{s’{tŽ{t‹woŒxpzo“~s—v™ƒx–€u“}r’|q‘{p‘{p˜u–€w–wys“|s’|q}r”t•t—€u•tŒynxr‘xr”zt–{v“zu”|vzt‡um‚pi‹vm’yr”zp’zqyqŒtnunxo’|r—v—v”~s‘|pŠuiˆrgˆsfˆti‹ul‹smŒrlŽsmtm‘vo“xr•zs”zs‘wp•zs”}t’}t”~w’|t•{t’ztŽwp‹vmŽtmvmulŽwnyqxrupŽvpŽvp“vptmulwmyrzs’yr“yr‘wpunŽtmtlxn|q{sxp‡qk‡rl†og‡rj‹vn‰un†tm†tl‰vnˆumŠvnŒvnzr|t‘zsŠtm„pi…qj‰sj‹si‡shˆsjˆtlƒph‚phƒqj†tj„tgƒsg„tg‹xl‹xkwoŽxpŽyq{rŒvovn’wo™v™t–|r‘xmvjˆroˆrkŒvlynŒxo‡unnf‡tl‰tl‹vnŒwozr‰wp‡tl‰vo‹{nŽ~q’ƒt”€r”t“€t‘|tyr•€z•~yzt‹uo’~u“w’€u‘}u{szrŒxm„thŠwk’zr‘yrxqwqxoŒwk…sl‡wmŠyqŠwo‡ul†rjŽumwpŒtlŽwoypxpŒ{t‰wpzs–~x“|v”~xšy—~y–}xŽys‰wmo‘|qxoŽwo‰tl‚kezf`yf`€ngldkc€i^€h]€iaxbZxd\|h`zh_xd]|c\{f[{fYxeWvcVwcX|fZg]€cZ„j`€i^|k^zf^|h`zh^|j]~la}m_~j_‚nc€la~j_€la€lai^yg[xf]zi]€l_}eW{d_yg^zk^wj[xg\|i^}g[~i]ia{f_yf\yf[xeYxf[wg[{j_{i^|h^}i^k`„ncj`h_€h^{i^~l`‚ma…ocƒm`€j\}k_zfZ|f[{eYyd[|g_xg`zhald|j^{h[zfX}g`~h`~ia}h`|g_{g^~h[|h_|h`}jb€ja~gZ|fZxd[td[te\|l`~n^}ma|l`{l_zj^zk_}lazi^zg\{eZ~g_zf^ud[ueXtdXr`UudXvcWyeZ{gZwdWteXueXveYudVzc[v_Xv`Vs_SsbVqcUsbWq_Ur_Tq]Rm[PkYNl\Mo_Ol[Nl[Nm\Ol[Oj`Sm`Tp`To\Un]Tm^Tt\Vp\UscWsbWvaZw^Wu`Tw`Ut[Qr[PnYPoZSl]Qk[Op_TqaUl_Sl`Sr_XrcZxj_vi[rcWs`Wxc\wd\veZvdYtcYveZvfZtcXsaVud[ue]sg]tcWufZwg[ug[xj^wj_{hbyhawkavj`zk^|j]}l`|j`zia{id|ha€kcht_jr^lo]hhYicThaSlcVnbVkbWjaXkbUgeVdjZcn^fqahsbmp`jm\ikYnnZomZqlWriZmeWicSicToeXseYveZxj]rfXpeWvg[wgZsf[tg\rgZqg\pf\pi^qjYnn\qsasq`{udzscym_sg[ti_xmb~pe€pc€obna€obyh[xgZxfYzi\{j]{j]}l]}l]}l^ylb}mcpfnepe|nc{lc~kcodƒqfƒre~qc|nb}m`ob„qeƒqg‚piƒne„rgqd‚re…sg‰tiˆuj‚qf}oc}nbpd…rhŠuiykŒymŒwo‡ul†slŠxqŠypŒzn‹zn†ujƒqjndpdˆvjŠyl‹{nˆxk…uj‚rf‚rf„sj„ph†piƒqf‚pemb}l_~naob‚pe€qe€qe~ocyl`|nb‚pe€mb‚nc‚peodqd€ohƒoiˆqi‡rgƒqe€pcod‚pe‡rgŠqg‹vkŠvk‡sh…qf…qf„pe‡qfˆrgˆrg…pi‚ph~md~ma„rcƒsf‚rd€maƒla~i_jc„qf‡uj‡ti†ti†rk…phƒncl`lb~la~la‚qf…ng…ph…rhƒrg„sj~mfpgƒphŠskunwo‰vn‚tm~ph|ng…tmˆtm‰rk‹sl‡qi†qi…ph‹umŽvnŒuotovqŒumŠrj‹tlˆsk‹tnvqtoŒsm‰si…rg‡tiŠvkwp‘wpŽtn‡tlˆrjŒrk’xq•{s–t“~v”|t‘xqxn‘{p“s–}v”|u‘{qzo’~s’s“u˜€v˜~t’yo’zp’|q–}s–€u˜‚w”€u•v|q‹vnŽvn‘wp’xq‘{s{twr‰rnˆrlzu•~w“|t”yt•{u“xrŠsl‹vpzs’r’t’|qŽwotmŒqlŽskŽrluorm‹rk‹tlŽxpxp‘{s“}uzryq’{s“|t“|t•|t’wqvnvp’xrvpup“ys’xr‘so’vp“{u’|s“zs”ys•zpxmxlymxm“yoxqypwoŽtmtmŽtmvp’xr’zrŽwo†pg…qe…rgˆsi‹ql‰pj…njŒur‰vn…rjŒvpŒvpvoyqynŠvk‰vj‹vjuj’vl‹uh†sf‰vm†sk‰snŠsn‡tlˆum…rj†pjŒvoŽxrxrwr‰voys—}t¡‚x¡†{¤†|§‡~Ÿƒy—v}u‘yoyoxpŽyqyr‡voˆsk‹um‹vnŠumŒwo‹wo‹um‰tlŠumyn|q‘~r}p”€v•y—‚z”v™†y—„|“‚y‰yo}u–xš‚z“|w’~t’~rŒzo†sjogŠunˆvo‡sm†smŽwqŽtnˆujŠumwrŒvqŠsn…qi‰xq|u‘}v“w–€x˜‚y‘}v‰wot˜†{™ˆzš„v“v”w|tƒph€mfƒqh…pe€mc~ia{f]zfZwdXxe[ye]{d^{f^xfZxgYyf_{hayg`|l_yj]zl^xh]}la~l`{h\}h\~g[}k]k_€lak`m_‚o`€hbzc]~h`yf_|j_~lanal_}i^zf[zfZyd\{d\u^Wt`UxdYweXvdW|eYg\}g\|f]yd\}h_€h^€h^{g\zf[}g\~fZf_k_{gY{j\ka~hb€kc‚nck`la‚obl^€lbƒnc…mcƒka€l`~k`j^}fZzf[yeZzf[}h`|ib}kcld{h`yh^yg\zi`|ia~kc{h`{f^yd\{ha|ib|ia}h`{h\ydZvgY{i]|g\j^zg]zi_xg_yh^|k^zh[zi\|i\|i\ye[zd_wa[wa\waZuaZwb[vaYvaYzbZyd[wdYsaWs`VtaXvaYw_Ys`TvbWucXub[s`XsbYtbWraUpaTl\Np]SpYQmZLq]Po\Om[Pp^UlYRk\Pn^Rm[Po[Tq]Ut^Vr^Ro^RpbVqcWvcYy`YwdWtbUt^Ru`Tv^Ru]Qq_Oo]MqaSn`Tq`Up_VtdYwg_rd\uhawf_xe^|l_zi]ze]{f^wd]wd_ud\vd^wh\sfZrj]ri_{k^{l^zj^yl_xi_{lc{kdyibyjazkb}mczj_|l_}m`oboe€ndmbfkYhl[jhXgbUhcTjbTk`SpcWocWocWodXgbUfhZgo`grbfqajm^hn^fo\ip[nmXqkVtjZofXpgYpeXpcWtfZweZwh[thZsgYqdWrcWodXqcWqbVpeZoe[nf[ofXmkZpr`usa~tczra}pczncuj`vi`xk`pcƒoboa€na|j]|i\l_}ka~nananbo`|l]wi]{l`}l`€nb}ma|l_{m`~maodƒqf†ui‚ug€rf€qd€pc„reofƒqiqh}oe{oa{pbre…uj…rh‚qe€pd€pdpe…tiŒvmxnynŽyoˆul„qgƒqi‡tk‹wkŒxmˆuk…rkƒqf„shˆvk‰yl}p|oŠxm…uhqf€ofmeƒnfƒrf…sh€ncna€ob‚qc„rg„sh†ti‚rfoc~ocnb~mb‚ncƒod€od€od}mf‚ogˆqjˆrg„qf‚reƒpf†shŠsh‹ujŒvkŠvk‹vkˆti…qfƒod‚nc‡rg‰qg‡ri…ph€md‚ocƒpd…tg„re„od†pe‚lb€kbƒnc‡rgˆshˆsh‡qi†ph„nb‚la‚mb†qe‚nf‚og‡oj†qi…sh‡uj†ul„rk€ofƒog…ph‰sl‰um†rjƒqinf~meogˆrkŒsm‰sjˆri†pi†qiŒvnyquoŽvpwqŒum‰rj‡ph†qiŠsmtouoŒslˆrh†sh‹wlŽzpyq“zs“zs‹xm‡sg‹rivo“{s”{uzrŽxovp‘xn’|q“t”}u“|tzp‘|q•~s–€u–€x™€y›x–ys“xq’xq’xo•}t–~u–v•uŽyo‹tmvn’xq‘yq“|t}uysˆslŒvp‘|t“v“|u“|w”{uwq…mg‰slŠwpxoxnvnŠskvmŽvmvo‘wp’wquoŽtnŽslxpxpyqzqyqŽwoŽwo‘zr”}u•{t‘wpun“ys”zt•zt“ys•zu“zt‘tovpxr‘zr“{s”{t“xownŒulvm‘yp“ypyqxpŒumunvoun‘ysxq’|s‹tl‡ri…rf‰smŠtmŒsm‹qk†ojŠuo‰sjˆqjŒuowqŽuoumzp{rŽzqxn’xo•xp‹sj‡rh†rj†tl„qjŠtnŠwo‡tlƒphkeŠto‹uowp‰uo‰wo—€z¢‡¬Žƒ­’†«Ž„­Žƒ¥‰Ÿ‡}˜„y•~u’zsŽyqzr|t‰wn‡rj‰skŒvnŠtl‰sk‹um‹vnŒwoŽyq|q’~s‘}r}q—ƒy›†~›†~›†|š†{™…}–ƒ{|tŒyq“}u—}vyrŽzqŽyoˆwm„qj„ql‡tmˆum‚qi…rjxqŽwpŒynxp‘{uyt‹uo„ph‡vk€t”y“€x”w“}vŠvnng‹zoŠ¡Žzm†pfƒmeƒme}h`{h_zg_|h]yd[xc[xc[xeYyfYzh\{g\ka~h^k^~l]}kb~ka}ka€qd}mazl^|jbocnema€l`k_l_‚mc‚ncmb‚oa„qbkclckb~i`€lalb|i\xfXwcXuaVp]Qt`WwcWubVvcXvcXudXvdW}g\|g\i^}g_zf^|g_j^€k`}h]|h\g]g]g`‚mal\€pb‚md‚kejb€la|h]€l`nam`mb…pe†peƒmbƒnc~k`‚k_}h\zf[|h]|i]€kc|iazg_zg_yf^xfZyg\ze^|g_zd\xc[yd\ze]yf]zh^|g`{f^ze\zf[zi]|j^ydY|g\xe\taYwe]}ka{i]}l_}j]|h]|i\{f]zd]yd]xc[wcYwd\taYtaYu`Xwc[t`Xr_Sr`Vr`Ur_Vt^Vu^Ws_SxcXuaVwbZubYwb[ucWsbVqaTsbUn[RoYPmZMq^Ps_Sm[QmYRn[Sk\Oo_Sp^Rr^Wt^Vp\Sq\Qq_SscWpcWyf]yd[xeXvcVwcVycWxbVxbVwcUtcVtdWtdWtdXwg\xfZyi_{kc|kd|kc}jc}l`}j_}h`ye]xf_xf`wg`wf^zi^tfYth[xla}m`|l_{k_xk_yk`xi^{mb{lazlb}nb€qd€oc|n`oc~oc~na}ma€oddeUgdUjaTj`ThaRkaSncUtfYvfYvgYug[ndWgeWbiZen^cm\ik_dm_ao\dq\mp[smYtjYuhZviZueYueYtdXtbXucWsfXuhZqdXocWsfXqcVpbVqdXoeYne\si\pk^mn^qm[tjYtjXynazncwkatf]xi^}m`…pe„pe…pd„oc~k_k`|kb}lc~ld~na}k`zi^wh\yi]}k`~k`mb€laob€qdqeƒrg…tk…tk„vm‚tgqd€oc€qepf€qh~odzn`{oapc‚th‡vk†ti†vj…uiodoc†oiŠun‰vnˆvk†uh‚qe‚og…qf‹ujwmŠvk†sk…sh…ti†vj‰ymŒ{oŠym‹xm†tj‚qine‚nf…ph‡uj‡ujƒqfƒrd„sf…uh‰ujˆujˆvk‡uj‚qe~nb|nb€ocpe…pe„qfpeog€nf†qi‰uj‡tj‡uj†sh…qf„pe‰shŠtiŒvk‹ujŠti†rgƒod‚ncƒpe‹qg‰qhˆqiƒnf…qf†sf„rg‡sh‡qf†oemb~k`„nc†pe‰shˆrg‹tl†og†pe…ocˆrfŒum‰rj†nhƒnf…ph†qiƒphƒph€nf€meme‚me†qi‡qi…ph…qi€nfnfnfŠtlun‹um‰tl‡tl†sk†qi‹tluououoŒum‰rj†og†pj‹uovovowoŠti‡thxoŽwp‘zr’{s“zs‹xkŠtitj‘wp”zt‘zt‹vnvnun‘yn–€u“t•x”~v’|q’zp“zp”{p“{u”|u“ys”wr’up’to”zs•{t–|u–|u–}vvoŽwo‘zr“|t”}u“~v“v•synŠvkŒwozs‘{u|uztŒtn‡oi†nh‰smŽtnŽtm‹tl‹ujŠvkzmwp‘yrwq’xrunŽrkŽtmŽtmŒrkvo‘wpvoyq’zs•~v–|u“yr’xq’zt’zt“{u”|u•|vxr‘wq‹pj‹tnŽwo‘zryquoŒskŒwozr”{t•{t“}uyqvnŽtmŽtmvoyr‘zs’{sxp‹vmƒod†pk‰smŒrlˆng†ph‰tmŽwoxq“ys“ys‘wpŽun‹um{s‘}u‘zr’yr“yrupˆqkogƒph…sh†ti…rj…rj‡tlŠumxpŒwoŒwo‹vp’|vœ‡©†¯”‰¯”…¯’†¯†ª„¥Œ€œ†|•|wysŒwoŒwnŽ{q}pun‘zr”}u‘zr‹tl‹tlzr{s“~v“t”€v’~szp“v™ƒ}š„}—‚z”€u“€y’v‹xpxp{s’{sŒvp‰tk‹vnŒwqŒur‹ur‡umŠxo…tk‡vmŽ|szrzr|t”wŽyq‰tm€kc„sgŒ}p‰xm†tl‡rl…oi~ia~ka„rg’€tˆtgi]€g^ƒka‚i`i_~g_|e]|h]{f]yd\yd\zfZygY€m_ƒnb‚la‚l`‚m`n_ma}k`}k`~la}k`zh]{kc}kc|jb}jb|i`{g\mbƒpdldl`„qe†re~lc~jb{f^|h]€j_}g\|fZxbVwbVxcXwaVydZzg[xgZxg[zh]ye]yf^€j_i^i^h`h`€jb~i`kc}jblcƒjc‡kd„mb„oc‚obƒpdƒnd~ga}h`|h]{g\}i^l_€l_€mb„od„ncƒnc~j_}k`~k^|i\{h\~i^yg\|ia{h`zg`yf^vdZweZyg\€h`~f^xaYxaYvaY{e]|k_{i]|h]|f_}h`|f_{i^{g\xdXze\{f^ubZwd\zh_|k^{h[|h]|h_}i\ye[yeZzf[ydYwcXudZsbYtaYraXtaYq^Wt`UubWweZsaVvcYvaV{`Zzd[zc[{d\|g_yd\vbWsbVrbUqaTq]Tr\StaTq^Qr^So]SmZRp\Uo_Sq`Up_Ss`XuaYs_WycWvcXueYve\yh_xe]xdX{g\}i^~j_~j_}i^|i^{j_xh\yi]xh[xgZygZzh\}kb{ja{i_~k`mbka~h`xf^yg`ue^xhayha|j_zi]wg[ld{k^{k_yi^wi]xj]yk]yma}oc}m`~naqdpc{nd~qe|nb|nb~oc€pcfcUkeWoeXtcYndVrfXpeWreWvfYwfYvfZqeYleXhi[dhYek\ll`ipaeq`fp\koZplXtl\vk]yi\xi[seXpdXwgZtdXudWpcUsfYpdXugYwfYvfZtfZqfZri[sk^pm^nm]ohYrhWrhWshZwi^xh_yh_{j_|m_ƒqfƒpe‡qf‡qfƒpf€nbzkczka{ja|ka{k_{i^yi]zj^{i^mb‚odƒpe‚re€pc€pd~nbpf‚qgƒri‚rfrdrdreri…ri„qhƒre‚qd€oc„rgƒsg…ti†ti‡ujƒrf{m_mf„qi‡tl†ti„sfƒse…sf‡sh‹vkŒvkŽzo~qxm†uisg‚thˆwmxp‹un†rj‚og‚og†ri‹wkˆvk‰wlˆvk…tg…tg…uhˆtiŠvl‰uj…sh‚pe€od~ocƒrg…sh‡sh†sh„qe€ofofƒog‡rj‡sh‡ujˆti…qf‚nc…qf‰sh‹ujŠtiŠti‡peƒod‚nc„qf‰sg‰thŠsk‹tl…pf‡sh†rf‡rgˆrg‡qf„ncnc†ncŒsitjtjunŒrjˆrg†pe‡qfŠsiŠskˆqhmd‚me‚mf„ognfnfld€jbognf…rj†qi‡ph…phnf‚ogˆrjŒumŠtlŠum‡tl„qi…ph‰skŠrluowrŽwo‰rjˆqi‡qlvo“yr”zqxnŒvk†rk‰tlŒvnŽwp’{qzoŒwmwn’yp”zs•v’|vŽyqŒumtm‘yo•t“t“~v•}v‘{pwmŽtj’xm‘xr“ys”zs’xr’vp’vpxo’{t”}u•~v—}v“ztvnxp‘zr|t’}u’}t’{qynŒujŒwpzs‘{u|u{uŽvpŠsmŠun†qkŒrlŒrl‹tlŠtiŠuk‹xk‹unŒvoŽvp‘xrŽtnrkŠskvnŒvnvnŽwo‘zr‘zr”}u—€x˜~w—}v“yr’zu’zt‘ys’ztxrŒtnŒtn‹tnŽvp’{s‘{s{swoŒvnŒvnzq’|t•{t“}u’zsyqŒrk‹qjunŽxsxpŠumxpˆsj†rg†pkŠtm‹ql‹qj‰thyn’wq•{t”zt”zuxqŽvn‡skŠumŽwo‹tlŒumŒvmto…ni„piˆumˆuiˆth„qi…sjzszqzrŽyqyn{s—‚zš…}£‹‚¨…ª‘‚ª„©Žƒ¦Œ †~œ…{“{vzuzrŽyq•‚u‘r–}v•~v•~v”}uvnŒum{s“~v’}u‘}q•v’}rŠwmxpzt’|uzrˆtizrŽ{sŒxpzr|tŒxpwr‡rk‰tlysŽxrŒuqzr{sˆvnƒri‰vn‹vo‹vnxpˆsk‚me~ibxc[‚qe‚rdodƒnf}f`~ga€i_~j_mb„peƒl`i]‚j^ƒk_€g^f\~h`~g_~k_~i`jb}h`|h]~j]{k^k]l]m^ƒoc~m`~m`na~la|j_weZweYvb[ub[ye^zd\{f]{g\€i^ja€iah`‚k`l^yf]|f^xdYycX}g\}eYycW|fZ|f[{eY~h]|g^{j]~m`~la|j_~kb|ha€j_€k`i^€ia€iajbldkc|ia€kcƒme„kdƒma„pdnanaƒnd„ld€kb€la€lamb„qd„pc€ncƒod„od€k`k`}k`~k]~k^~j_yh]{i]}jb}ia{h`{i^xf[yg\zh[€g`~f]zc[{e\zf]~i`~k^{h[}i^j`}iayf^{f[yeZubZubZxb[yd\{e]}h^k`{g\{g]{f_|h^yeZ{g\zf[t`Ut`UsaXtaYtcYp_Vud[tcZwaVweZudYwfZyf[xeYy_X|e]ia|e]vaYvaYxcXubVrbUueXr_Vs^Wt`Uu`VvbWr`VtaYtaYueXzh^weYzg_|ia{h`}g`}ha|iavf]yh_|jb|i]yg\{i^{i^|k_|j_}ibyh_yi]zj^yh[xgZ{h[yh\{j`zi`yg]}i_}kazf^{f^{g_we]ue]td]wg_yg\wcX{g\{h`yi]{j_{k^vh\zl`}oc|qc~oanamanc€qe}pf{mdqf~pdpd}majkYkgWodVsdXtfXsgYpfXoeUrfUrgVueYqdXmdWjfXihZll^nn_kn^jn^hm]kn]lm[qn]tl]xj\vhZqfZlfYrfZtfYxh[wfZwh[vg[ucWveXwfYufYug[rh[up_sscpo`ogYqfXpg[ti[yj_zi`|jb~mc|oa}ma€nb„od„pd‚pdocvkavh_wh^{k^|k`}l`}k^}l_}oa€qd€rd€pcpd~nbzl`xj^}m`pd„ohne€pc~rd€qd‚reƒrj‡tkˆuh„reococ€pdƒrf„rg‡uj†ui€pcqh…sk‡ukˆvkˆwj‰xkˆxk‡ui‡ri‰uk‹ymŠzmŠvl†ui€pg‚sj‡um‰tmvnŠtl„qi„qg‡ui‹wl‰xmˆvkˆvk‡vh…tgqc†peŠti‡rg‡sh„qf‚odƒqf„sh‹wlyn‰xm…ti„rh‚ogme…ph‡rkˆtk‰ti‡sh„qf…pe‡sh‹rhŒsi‰rg‰sh†rgƒpepe†tgˆrg‰ri‡rj„phƒrf…oe‰rhsj‰rh…qd~n`‡qf‹vkŽxm‹vkŒvnŠtl†rjƒpf„oe†qf‡qf…oc‚nbld„nh…oi†qi‡sh†ohƒme‚ogƒqh…rj†rj‰ri…ofne~lb‚of‡sj†rj†rj†sk„qi„pi‰tlŽvpxr“{u‘zrxp‰rj†qk‹ulwn“zoŒuj‰rjŒumvnŽwo‘zq“~r’{pŒunvo”zt˜v–x’u“}uxoŠqjtj“}r’~s•|u”zs’xovlŽuk‘yn”yr”{t{szsxqxqŽysŽzs“|t’{u“|u‘zrŽtmŒslŽyq{s{s’{s•zu‘yrvoŒwp|sŽ{t‘|v‘|uwqxr‡smƒqjˆphŠsj‹tlŒumvlŽvmŽxpunŽvpŽvqvoŒvm‹tmŒvnŽwovn‹umyr’{s“|t“|t“yr“zr”zsxr’zt“zu“{u“{uŒtnˆqjŒun’xr‘{r’{s|txqŒvoŠunxqzt“ztŽxpyqŽwoŒrkŒrkwn{tŒxq‰tlˆskˆtjˆrgˆsl‹tmvnslˆsiˆuj’yr‘xruoŒuoŽwpŒvn‡rk‰sl‹sl‰rk‡pj„rjŒvo‹wpˆumŠwnŽypvm†rj…rj‰vo|p|qˆti‰vjyo{s“~uš„xžˆ}œ…yšƒx ˆ‡~›†}™‚{–{•y’}u‘|t”€u•v“}u”~v•w’|tŒvnˆrjxozrzsyn‘}r|qŽxqzszt‘{uŒwp‡rk‰vnŒxpŽxp’|t|t‹yqŽxsˆsk‰ulwn‹tkŠskŠrj…nelc|i_kbkbkejbzf\}j^|h\{f^‚laƒla†oema€j`i_€i_~i^la‚lai_ƒh^„l_j]‚k`€j`jb€jbk`€kbjbja{g[zh[{i]{j]~k]€ma~lalc|i^weZyg\xfYyfYxeXzcZ{e[~g^zeZ}g\|fZ}g\g`h`g`|g[~h\|g]zfZzcX{eZ€j^|h\}fZi]}g\k`~h]}e]|i]maƒnc}h]~h]j^~i_}i^|f[h`€ia‚jc€i`€jb~kckd~jbkala‚ob~la€k`ƒmc…md…pg„peƒod„pe‚obƒpcld‚nfle~ia|hazg^~j^l_{j^~la}l`}kblbzi]|j_{i^|k]|k^{g\yfZzf[{g\}i^~j_{h\{g\k`~ka|j^xf[wbXs`Wr_WtaYvaZt]Xu^U{e[zf[wcXxb[yf^xb\ze]{g\uaVt_Ur]Tr`TubWvcXweZyg\veYycXxcXxfZyh[xh[xeWyc]{d^yc^yd\vbZxc\{eZxfZwfYvfYwd[vbZyd]{f_{f^zh`|i`{h`}j_~la}k_{g`{h`}jb|ib}jc~kc}ia{hayg\yh]zh\zg\yh\{k_{k^yg_yh_|kayi]yh\~j]wfZvf\xh`xg`ve]zf_{jayi`|ia}h`|h`uc[sb\ue]vdYyg]wfZwe\wg\|l`|l`{ma}pb~qc{pc€pd€nbkb~lb}nd|na}m`~od~md~le{hamp\nmYoeVpcUueXsgYpfXngVmfUofUrdWqdXrfZogZkhZnk]mmZqm]ok\nk\jl]loaln\qk]uk[thZpgZkgYnfYvj\zk]}l^{i]zj^xgZveXudVtdXtg[rg[rq]tubsrbrj^pf[nf]thZyj_{h`~kc|ka{n`xl`wf]{g^kc|kawj`ui]vi]wi^nc~m`pcna}l`zl^xm_yn`zn`€nd}kbyk_|ma}l_‚pd‡qj†ri„tgƒsf‚qd‚od~qh€rgƒsfqdqdxla~ocƒrg†rg‰uj‡vjƒth…tk†ul‡xlŠxmŒzozn‰yl‡wj„qi†sk‡vi‡xj‹xlˆwkrhri‡umŠtowq‹umˆum‡ui…sh…qfˆvl‡uk†ti‡vh…tg€ob‡pe‰siŠtiˆujˆti‡sgƒqfˆti‰ujˆwl‰xm„ui„rgod‚ogƒph…oh…pjwlŠvk…sh„rg‰tiŒsiŒsi‹si‹ti…rfod€nd„te„sfˆsl„ogogqe†og‹rjŽujŒtj‰uh„re…odˆrfŠtiŠtj‰qj†og‚ohƒog‚ngƒod„rd…oa‚od„og„nhŠtmŠulŒwltmˆrjƒpg€ne‚ng†rj‡qf‚odod€pd‚rf„sh‡qj†rj†ul†tk†rj‹vnŽupxq“zuyqvn‰rj†qk‰tjxl’znŽwkŠsltnyq•}u”~s—v—x“{u’xs“ys•}r“~r‘r’|uxpŒslvl”~s”t˜|v˜|u•|s‘wnxm’{r”yo”|q‘~t~sŒ{p‡uj†sl‹yrŽ{tŽ{t‘{uŽxr•yrŽvnxp|t’{s“|t•{v’ytwqwr{sŒyqxrxrŒvpŠtnƒrkpi…qf‰uiŽxmxq’xq‘wqvntm‹smŒun‹unŠum‰vnŠwo‰vnˆtl‰vnŽzr’{s‘zr’{s“yr‘wp•{t’|v’|v’|v‘|u’}uwq‡qk‹sm‘wq‘{rzrŒyrxrupˆrl‹up’{uxrvnxpyq“yr‘wp”zs‘|vzr‰vn‡rj‰tkŒvk‰tm‡qiŽumtmˆriˆsj‹tl‹unŠsn‡qk‹xpzr‹xqŽvpuo‹sn‡rl„rk‰vn‰xo‹ypŒwoxpŽsl†skƒph†skŒxl‰ujƒpc‰xj|pzrzr”€u”€t“|s‘{s—‚z˜ƒ}š„~˜‚|—{—‚z’}u{sŽyq{qzr‹vnŒxo‘}uŽzrŽyqzs|s‘|tyo‘|r“u“v“}v”~x“|xzsŠumƒqhˆtlyqxp‹wo…tk†pl€jdmb…oci^€h]g]{cYzg\}i^}h]~h]ze^ze]|i\l_l_}g_†nc†mc‰pf†mc‡nd…lb„ka‚k`ƒmb€j_‚h^g]‚m_l^‚l_k`~i`|g`~j^{f]}g`|g_{h[weWtdZscVveXzi\yh^xg`vd[xe\xf[}i\{iY|hWh^h^‚h^i]i]€h\i^~h`€hbh`~g^€k^g^‚i_~g]k_l_~k^~i]~i\~h]‚la€j_}g_€i`‚kb‚laf\i]k^~i^}j^|g\€iaƒkc…kd„ib‚kb~jb|kbzh`|ja„pd€nb~la€la‚k`†nc…ph„pe‚ncmb€m`€m`mf€ldme‚le}ia|j`‚nb€na~la~manb}lc~l`zi]yg\{j\zi\zi[wg[wfZxf[yg\wdYwdXyc[}i_|h^xh[xgZwfXw`Vp]Un]Ur`Xs_Yu\Wv_WxbVwbVuaVu_Xs`Zv`\xc]xdZwcXvaXu_YydYzcX{g\zg\xeZtcX}g\{f[{j]|k^zi[yiY}gc{e_ye_yf]xd]xf^{f[xeZwfXwg[zi^{h`}h`jb~i`}ja~kb|ib~manb~lbzg_yf^yf^zia{ible~kcjb~k`yg^xe]yg^{ja{kaxj`xh\xh\zja{jakc~ibyh\tc\ug^sd^sb\ve^xkazja}kb}h`}h`xc[p`Ywf_veZxh\zk^xi`zh_{k`{k_zl`~qc~pbznb~mckb€ib}ic{kc}n`|l_{k_~kc~ke}hespbpi[lbTnaSrbUrbUtdWqaUqbTseWuf\wh^wfZth[rm_nn^llZmj[lj\lj\jk[hlYomZsk]xh^yg_yi`ug\xh[veZyf\wf[zi`yi`xh]veZsaVsbUveXvgXrh[um_vobwobuj`vh_vg[xh\vfYxg_wi`uj`xh[yh\|gZl_~j^{j^}h^yf_{hb{kd~nc~m`{mczlcvl_rj]xk^{n`{n_}nana}l`pdƒuiƒugƒugƒuisgpe~ne}neod†tg…sfoc~ne}qc„ug‹xjŒwjxoŒwp‡vo„sk†ti‰ujwmxnŒxm…shƒsg†sgŠvkvkŽ{nŽ|q‹xr„sn†um‰wlŠwl‰ukŠum†tl‚ri€rg‚smˆvo‹ul‹si‰th‚qc…shŠviŒuivj‹vm‰sn‡ulƒrh„rf†ti…uh„vh‡pkƒlg‚lf‡qi‡uhˆwkŒujŒvk‹uj‡sh‰uj‡tiŒrkŒrk‰rj†qhƒod‚pe†phŠuj‹ti‰ui„re‚re„oiˆsl‡rj‰sk†ri…ph‚nfnf‡ph‹rhŠpfˆlbƒmb…od‰sgˆrgŠtiŠti†ogƒogƒri…sj†ul‰wn†ti„pg‚lg€id…of‰tgŠpf‰qf†qi†qi„qj‡tm‰ukˆslwqŠtnˆslˆti‡skxpŽyqxouk‘tjsm‘vpxpynŽxnŠwkŠumzr’}u•€x•x•€x—{ttm’vo•ys•zs˜}v•{t‘wpun‘wp—}v˜~wœx™~w™}w‘ztŽvqŒvqŽwoxqwp’{uypŒwjˆqiwn’zs’}u’}u’}uzrŒwoxpŽyq‘|t‘|t{rzqzrxpyr‘zu{s‹wnŠvmŠum‰tl…qi„ogˆsk‹wo‘zryqxpŽznylŒtiŒshŠtjŠvkŽwpŽwoŒumxp‘zr‘zr’zt“{u“{uxrŽxo‘{r‘|v–}w—}w•zw”zwŽws†skŠulvo‘wq‘vrvq“xp•yr‘wp“yr–|u‘zrxpyq’{s‘{s‘zr•~vys”~v‰uk…pf‡rjˆrl…qlƒoi„ph‰sk‹rltouoŒvp†tm…slŒyr‘|t’{uxqtoxoxp‹tl‡tj†rk‡sm†pl‹toŒto‹wpŠwo‹xpzt‰wmƒqg†uh|o|q’~s“t”v•~uwpyt•y•‚{’€x‘|r’}t‘{tŒwoŒwpwq|r‰tmŒvp•}w–~w”~s—~s”~u}uŒyszt“}y•~x“~v’}uyoŽzo‡rh|id~kdmdjbg`fa‚hb~e^}d[€g]€hZiZ{dZj]€j\„oaƒl`l`‚ibkcldlala…mb†peˆpfŠqgŠqg…mcƒmb‚j_€k`€la|i_xg\xh]~k^~k^|i^|h]|i]ze]wg\xg\xdXxdXybXzaWz`UydYwfYvg[yf]|d^}d`~f`€iaƒlc‚l`k_~hajbi^k`ƒj_‚j]f_‚hag`h`€iajaƒo`ƒma€j^‚l`„mc„nb‚g^ƒi_ƒmbla}k`{j_€l_‚k_ƒj`„kdkdkc€iakc}jd~jbme„mdƒob‚l`‚j`h]}h\}jb‚mbƒmb‚j_i_„j`„nc‚ndmcmbmbk`nc„mfkd€oc€od~k`l_€kcibjbjb€kc~ia{f^ze]{h^yg\zg]wg[vcYvdYxdYxcXxbWxbW{d\}e^yd]zd]ye[yfYzb[u^Vv`Xs^Vu_WtaXw^Ww`Xw`XvaYvaXyd]zb\f`|f`{e`yc]|f`yf^}ia€j_k`{i^zh]|j_|j^~m`|k^~m_~o_€jc}ga|iaxf^yi]xh\yeZzg\xf\yh\zj^}m_€hc{f`yh]}n`~na|j_€kd€kc{f_}h_{j]yk]wg[zi`{kayh^zk^{k\~k^|i_xhaxiaxlawk]xgZye\~ibjb|laxi\ye]xeYwfYxh[xh^ue]wi]|j`{h`ze]xb\r^Xxg[teYrdWuf]vi\ti]vh\wj\wi[|o`|ma|lene}lczi`zh`|ja{ja~g_|g]{i\|l_}mbzjbpj]mdWm`To`Up`SqaTscVueXueXveYsfXwh[vfZsgYvo`trbsn\qk\rk]oj]kl\kn[ml[tn_xj`zi`|lawh]uhZwg[vdYtcWucXwe\we\vd[wcZwfZyi]yk^wk]si\rj]sj]sk]tl]ti\reYsdXte[ug^sh_sfYvfZyfZ}k_~l`|k_}iayg_vg_xh`yi_yj]zjbxkbuk^tj]vi]{m`qdqdpd€ndnd|mcoaqd‚rf‚rf€pd~mc~oe€oc„sf‡vi†uj‚ri€rhƒthˆwk‹xmŒxoˆun‡unƒrjƒqf‡sh‰tivpŒxmˆwl†uiˆujŽyn‘{p’q|sŠxq‡tnƒrj…sh‡vi‹wl‰tl…sl‚qisi…vm‹wpxpxpŒwm‡tk…th„rf‰sgŒuitlŒsm‡sk„pg„pe…qf…ti„tg‡nj„mgƒmf…ph‡ti„sh‰rgŠtiŠti‡shˆti‡shŒrkŒtkŠsj†sg„peod†qjˆrk‹tkŒulˆukƒrfld‚me…ph„og„og…ph†pg†phˆqiŽukŽtkŒrhˆqgˆrg†peˆrgˆrg‰sh…ph‚ogpgƒri…rj‹vn…sg„phƒmgkf†ogŠtiˆti‰skˆtl‡sj„qi…qk‡si‡rj‡qkˆrlˆslˆuj‰sj‹woxqyquotkun‘xp‘yr‘{p’|rxmŒumŽwoyq’{s”}u“|t‘xqxpvo–~u—w˜€x—w–~v“zs’yq•|t—w™w˜~u”{s‘zsˆslˆslynzp‘yr”}u“}synŒumŽwoyq‘|u“~v“~v‘|tŠumˆsk‹vnŒwoŒwoŠvk|szsŽyqzs’|v{sŒwo‰tl‰tlˆskˆsk…ph‡rjŒwowoxp‹tkŒxm‹vlulŒulwoŒxq‘zrxpŽwoxpyq’{s”{u”{u“zt“ztvoxqŽyr•|w”{u‘wqvsŒup‹vovq’xr”zt‘xqyr—zs•zs”{t—}v—}v”}u‘zrŒumŒunxpyq’{sxryq‹ujˆrgŒumŒtn‹tn…pi„phˆrk‹smŽup‘wq‘ysyrˆtn‹wowovq‹tnŠsmwoŽxp‰tlˆujŠunŠsm‰rmŽvp‘zr’}v‘|uŽ{s‘|tŒxo‡tiŠuj‘|q{r“~u{t{t’zs‰tmxq“~v‘|u‹xqyn{r{s{syrys{qŠvo‹tn“}v–x•€u˜u•€v‘}u‰wp‰sm‹up{tŠvo€ldmg€lckbvc\wd\zg[zg[|d\~g`g_h_}d[~e[g\i^i`€j_ƒma…oc…ndƒmd†mg‚le€kcjc€ja†neŠti‘zpsjˆneƒla€j_~h]~h]~i^{g\{g\|g]zgZ|j\yfZ{g\yeYxc[xeZxeZyeZzcXybW}e[dZ€i^|k^|j^|h_€ga~g`‚jdjc€iaƒmb‚l`jcjb‚ka‚k`ƒi`‚j^‚hb‚ha…jc‚kcƒmeƒlc‚oaƒob„oc„nc…peƒmb„i_‡mcƒka€j_€k`„od„nb„la‚i_ƒhb€jb~ib‚kc‚ldkckd‚le€ja„l`„m`„ka}e[{fZ{g_}h_€kah`‚h`€g^ka~iaia‚mb€kala‚nb‚ld€lendmb}j`}h\jc~iajc€kcjb{f^yd[}f^}h^|h]xeZuaWr`Us`UuaVuaVt_TxbW{eZ|f\zf]ze[|i]yhY|d\waYvaZyc\waYxd]ybZ{d\~f_ze]{f^}h`€ibƒkd€jc€jc~ib|ga~kc~jb€k`j_|i^{i^~kb|jamb|k^{i]~ma}i`}i_~kcye]zf^zg]ze^zg^zg^yg\xh\{k^}ha|h`|l`~nb~mb}ja|la}jbicjbzg]yh[veZyh_zi`yh_xi\{m`{h_yg]xj\yl^|mayi_zg^zg^kdkczh`wg]zf^xfZueXxh\ug\yhash\zk`~ld}h`|f^wa[wf\xg[vh\ug[tfZtg[zj`zi]yi]zi]}kb|ibyh_xf^xg^xg^zh`yh_}h`{h^zi\|k^yh^zh`qfZobVn_Sp`TqaTueXueXvfYxh[wgZvfYtdWteVtfVum[un]vm\qgYtj^uoatsdrubrrbuoaul_vg\xh\tfYuhZtfXraUu`UuaVxf[yf^zf^{f^{h`vf]ug^xi_sg]ph[sm`rn_pl\qj]ofZreYseYvi]uh\xj^wi]zj^xh\xi]yl_{i`zjavg_ug[sg[uj\xj_yk_xj^vh\vh\vh\{janene€me~ld{ja{i^}k`od€ncpe€nbpgqe…uh†ui‡wk‡vmƒulqhƒrgƒsgˆun‡tm„skƒrh„rg‡rgŒukŽwo|q{p‹ynˆvkŠvkŒwl}pŒyoˆvo†tmoe…rgˆxi‡uiŠumˆrl†tl„sj‡wn‹woyqwqvoŠuo„tkƒreƒob‹tiŽtjŽtm‹sk†og…nf„pe†rg†ti†nhƒneƒnf‚meƒpd€odŠsh‰shˆrg‡shˆti†shŽukŽymwlŒwl‡tgƒpd…nh†oiŠpj‰qj‰sj…phƒndmc‡rj†qi„og„ph‰pislun‘|p“|qŽxmŠti‡qf„nc†peˆrg‡qfƒohnepg…rjŠulŠtj‰vkˆrj…mg„mf‡piŒuj‰umˆrk‡skˆpiˆriˆpiŠsk‹tlˆqiˆqj‹tlŒumzoŽyozrzrwpŽqk‹slxp‘zr‘{pynŒvkvmtk‘xn–}s•|r“|qzrzr{s‘|s•w•€x•€x•€xzrŒwoŒwo{r•}q•}s‘{qŽxnŠumˆtk“}p•s•~v—€x˜€y–€uxpŠskvnŽyq‹wnŒwoŽyq‹vn‰tl‰tlŠum‡rkŠvjŽyp{s‘|t’}v’|v’}uyq‰um†qi‰umŠul‰tmˆrjŒtlxpumŽtmŒvnŒtnŽvpuo‘zt“{u“|t’{sŽwoxpxpxp’xruoŒrl‘wq‘wo‘xq{s–w–}w“ysunŒvqŽxs’{t•{u•{t”{u‘|r’xq’xq–|u’{sŽwown‘zsŽwnyq“|t•}u’{svovovovowpwpwqŠtl…ph…qi‰tmŒtosnwqwqŠunŠtlxp‰sm‡qk†pj‹vn‹vnŒwoypyrŽvq‹rnŒtnyq’|wzszr’}u‘|rˆuiwp”|t’{s‘|u‹xqŽ{txsŒwpzq‘}tzrŠvnŒxl{q‘|t‘|tŽyryrŠxnŠwn†sl‡smˆsjˆuj’yoxnˆskibic‚lfƒpile~kd}jc}jb{hayg]zh]}j^~k^‚la‚nb„k`„kah^h^‚i_„la„jd„jb€j^ƒma‚lb‚jd‚jdƒlegb~h`}f^„mezo™w‰oe„kaj_i^}g\|f[g\€g]~e[€f\|g[~i\~i]~h^{eZzc[xdYzeZi^}g\€f\ƒj`†kaƒka‚ma‚mb€i_„hbk`‚la€j`ka‚kcƒldk`‚ka‚laƒmb„jaƒla…jd…kd„jc‚kc„meƒkc„pe‚nc…qfod€nc‚odˆoe†mcƒj`…lbƒj`‡mc…obƒmbƒmb€i_‚kcjb„kb‚la~k_k`€j_h_g[€h\h^€g]~i]zd]{g_iag`€f_‚ib€iagaƒlcƒld„nbƒma‚l`mb„peod€nc~j_~j_€kc~jajajb|h`wbZzaZ~g_|f[zdXwcXt`UuaVs_Tt`UuaVt`UvaV{h[{g[|i\}j]{j]zk[|g]|h]{g\zf[~j`}i^~i_€la~j_|h]~i_}i_ld€kc€kc€kc~kcldld~kcmbmb|j_|j_{ha|ia{h`md~ma|j_obob|j_|ha{f^zd^ye`xe_zg_xe\zi\zi\~i_~k`}k_oc|l`{ia|na~mcld~ha{f\{g[{g\|h_zg_yh_wi\xk]xe`xh]xlZzk[|j`ze_xe]wd\{gazga{i`wf]yi]vfZwf[wi^wh_{lcypbrg‚og‚ldg`zb]xh^wg[whZthZwi\uh[we]wf]xh^zia{ibxe`wf]wf]ud[wf]yh_yg_zi`yi_yh[yh[zf^{f^ueYsbVtcWsaVsaVtbXwdZxf[xf[xf[wgZudWsbSvgWugWujYviYviZvk^ul_tpayxfwvgvoaogZpdXseXwhXvhZwfYxfXvaWwdYyg\yf^zg_|g_zg_xg^te\ve[tf]tk^toaurcqo`tmatk^tg[vfZveYzj^zi`yjaxi`vg^te\wh_wh_xj_wi\tg[tfZvj^yj_{mazl`zl`wi^ug\wf]zh`|h`ld}kb{jazh]}k`odpeƒqf‚peneqesf€se„th…tj€pjqi~pd€rg‡vl†tm‡vm…riƒqf…qf‡riŽvozozoŒxm‹wl†sh„shŠuk‰tmŠtl…rj„qh†vjˆxk‹znŽzqŽxrŠvo‰vn…sh‡tjŒwnŒvp‹uo‡sm‚qhoc‚re…sf‰rgŽrjtlŠsk†qi„og†qi†qi†of…ofƒnf‚nc‚od‚pe‰rgŠujŒuj‰uj‰tjŠvjŽwpŽwnwlwl‰ui…pdƒng‡mgŠpj‹piŒtkŠsk„pe†rg‰ujŠumŠumŠtlŒqjrkŒrk’}qzpŒxmŒuk†pf„ncˆrgˆqgˆrh…pj‚og†rj†sk‰tjuj‹tjˆqi‡piƒkd„me…od…pi…ph…nf‡ph‹qjŒrkŒumŽwm‹uj‰shŠtjvozo{pŽzoŽyqwoŒrk‹ulŽwo‘zrŽxm‘{pvltjŽukxn”{q”{q“{qzrŽzq‹wnŽyp{s’}t”w“~vŽyqŠumxozr‘|p“~rzozpŒwoŠvm‘zm”~s—€x–w”}u”}uxpŠskvnxpŠtm‹vnxpŒwoŒwoŒwo‰tlŠum‰ujzq{s|szszu“|s’{rŒumŒumyp‘zrvnŽwovn’zrvovowqŽvpŒtnuo‘ys“{u’{sŽwoyqŽwovnŽwovptn‹qkŽun•{t•|u’}u–w™€x–|vŽvqwqzt“ys”yr‘wpypyn‘wp“yr•{tzrvnvn“|t”}v˜y˜y–w’{svovo“yr•{t•{t’yq‘yqxn†qfˆumŒvo‹sorkvpuo‹voŽypyqwr‰sm†pj‹vnŽyqzryqwqwstpŒtmŠtkxrŒvoŠumŽzq‘}t}q”zr—}u“{sxsŠwo‰voxrzs‘|tzqŽznŒxmŠwk‹wmzsyq‰sl†pi…qf‚mdia}h`kama†mcƒkb}h`|g_iaƒldmf€mfog~kd€mf}kd~ka€oc…rcƒpaˆqf‡qf‡oc†mch^„ka†mc…laƒid‚h_f\}g[}g]}f_~f`ga~g_~g_h_„meŠti‹si†lbƒj`i_i^i^€k`‚i_‚i_‚f\…j`€j]€i]k`}h]}g\{d\€j_k`„ka„ka…lbƒj`‚i_„ja‚l`„jah_„ic„mcƒmb‚la‚laj]ƒlcmbƒmbƒmbƒmbƒja…laˆng‰ohˆng…nf…nf‡ogƒod…qfƒod€mc€nc‚odˆpf†mc„kaƒi_…j`…j`‚ka„ncƒmb‚la‚kc‚hah^‚j`k`€j_}e[~d[}eY}eY}g\i^}h\~h`}ia~i`€iaƒjb‚lcjbjbƒkc„ncƒmbl`~i]~k`‚ncmbj`lbod‚kdƒkcjbh`|e]{d\€f_h`{e[{eZuaVuaVt`UubWvbWxdYxcYyeZ}j]~k\}j[}m^}k_~l_~la|j_{i^€la}i^k`‚ncmb}j_~j_k`€laleƒnf€lc~kcld}jb~kc€le|j`}k`{i^{i^|ia|ia~jb}kb}k_}k`~na}m`{i^{i^|f^ze]yf`zg`yf^yg^zh^yh[yg]}k`|j^~kc~lc~ma}ob}kajc}h`~i`|h]|i\xg[xe\yg_|kayi^xe_zj_yiYwiX|h^}e`{g_xe]xd_xd_xe^xe]yh[wf[wh[xf]zja~oeyma{la|iajb}f_{e_xf]xh]wgYvgWviZuh[ud[wf^xf_zgaxf_xf_wf]zi`xg^wf]yh_yh_|kbzi_zi\zi\ye[yd\xeYyg[zg[yi\vcYucXtbWucWvdZucXtbVtbVveYyh[yj[zi[yl\xk]wi]uj]tl]uo^woatk^si\pdXpcTwiYziY}i\~i]}k]wfYvfZtfYvfYyg\zg]xf]vd[vgZuh[um`upcuuetsczpcxk_wh\vfYwgZtfWyf^xg^uf^uf]td\xg_xi`}ka}l`{j^xj\vj]wi\xi]|k_}k`zjavg^yg_xf]}h_€ma~ma~na~mb}mboc‚rf‚qd„tg‚qg~oc{ob{oapdpf~mgpf}qe}reƒvi†vk†sk…th†sh…qfle„ohŠvm‹xl‹wl‡sh„peqe‡rjˆskŽxp{qzo‰xl‰yo†tk‹voypŽxmxm†sg„re‡ti‹wnŠvm‰tk„rjpf‚reƒre‰thŒukŽtj‹um‡sk…qiƒng„nhˆrh†qf„peƒod„qfƒrgŠshwlŽwl‹wlŠvkˆtj‰qj‰qj‹tlŒumŒvl‰qh‡pi‰qjrjtk‘vmxnŽzm‹yl‹wl‹wlŒwoŠtm‹qk‰oh‹pjynwlwlŠrk†ng‡piŠsk‰rk‰rjŠrmˆrlƒog„qiˆthŠthŒqk‹qjˆph„meƒldƒld‚lf…og„me†ngŠohsiŽwowlŽxmŒvkŠth‹ul‘wlynŽzoŽxpunŒrl‰sk‹tlŽwo‘{o“zpulŒwlŒvkŽxmynzoxm{pzoŒwl‹vj{p“~s•w•w’|tzrzrŽxpzq{rypxpyrˆslŒumyrxsvrxq’{syqyqyqŽzrŠum‹vn‹vnŒwozr‹vn‹vnŒwo‹wl‹vm‹vnxpŒwpzs’{q‘|p‘|p‘{p”~s”~rxp‘zr”|t”zs”zs‘wpvpŽwq‰tm‰tlŽxp‘ypŽwo‹tlŽwoxpŽwoypŽwrŽwpŠtnŒuo‘|s•w”v”}v—~w‘xp‰qkŠtnyoxpvotmŽxpŽzq’xr”|t”}u“|tyqzr–w˜y™‚z™‚z—€x•~w“yovo“ys–|v“xrtj{q{pŒynzoyrvrŽtnŒtnŒwqyrŽyqzr{tŠvo‡rlŠvnŒxp‹xpŒtm‰qlŒupŽwpxq‹xmxrxqyqŽyp“}t•€u–u–€v”~t•vvo‰rl‰voxqŽxq‹xl„pe…ocmblcƒmejb|f_|g`‚k_€h^|d\ze]}g]}i[‚g`g^~h_|h^ƒmd‡qhƒoeƒofmfmf‚ng€leƒpgƒrf…sf„qd…oc‚lb„jah_€g]€g]h^~f\bZ|aX~fZg[}g\}g]~g^~f]€e]g]~g\€j^k`ƒkaƒj`‚i_€i^‚lai^ƒmbƒlb‚j`„ka„j`„l`ƒl_…lb…ka‚i_g`‚h^„j`†lb†lb…ka‚i_‚mbla„ma„ka‚i`…ke…neƒmb„nc„mb‚laƒnaƒpd‡pf†oe…nd…kd‰ohˆng…kd„jc…nf„me…nf†nf…le‚lc€la€nc‚peˆqe‚k`ƒlaƒka„lb†nd…odƒmbla€k`‚ka‚i^ƒh^‚i_i^~h]~e[€dZ~fZ|g[|g\{h]|h]~h`{j^~l`k`‚la„nb}j^€k_ƒncla„nei`j`|j^}k`~i^|f\|ha}kc€iajb}f^{d\|e]h`jb€jb|h]|h]yf\zg\}f[|g\xdYyeZ~j_|j_n`n`o_o_ob~mc~mambod}k`lambod}k`}k`mbk`€lamc‚nd~lb~lb}ka{j_kc~kcoc~mb}k`|i^}ja|i`|j_}l`|j^|k_€na|i^{i^{i^yg[|i^xh\yh]|i`yh\{i^|h_yg\}iaia|i`}l`~oanb|i_{f^zd_{h`xg\xgZxg[xe]|ia|h_yf[yf\yh^wgZwg[zg]{e\yf]xf]wf^yh_ye]{e[xgZvdXwd]we\zh_|j^ufZvf\{g_|g_xe^yf_vc\weZvhXxjWxhXvgZvdYzg_{hayf`xe]wd]wg^zi`|lbyh_yi_xg^yf^wf\yh[}l_yf]wc[k]~j[yfWygXweYtcXr`UsaVtbWtbWr_WsaWucWxf[|j^|j]vjYyj]xh\ug[shZohWsfXufZreYqeWqcUthT|iZk[~i\{i\wh[tgZqgWseWwfY}i^zf[ye[ugZuj\wpcurdwshwrgvi]wf[weYwfYvfXufVxd]wd]sb\td]vd]xf_zh`|j`€l_m^|l^wi]uhZugZxf[yg\wg_wi_zj^|i^€la„qd„qe‚rdpf|mczl_{ma~pb€qc€of}na{oaym_oc€ofog~pfzpb|td€tf‚tf…sh…sh‡sh„pe„ng†piˆvlxmwlŠti…rg„sh†rl‰slyo“~r|q‹{n…un…skŠupŽwoŽxmxj‰ui‡sf†thŠylŒymŒxmŠtn†si„sgqdƒre‰shŒuk‹umƒqioh‚oh…piŒuk‹vk‡sh†rg…rgƒrgŠti‰shŒujˆtiˆti…qg†pj‡nj‰qlŠsmŠrl‹tlŠsjwmtj“vm“ym“zn’~pxm‰ujŠvkŠum‰smŠskˆphŠskujŽvktjŠtlˆqiˆri‰qjŠskŠsl‹qlŠrl†qine…rfˆsg‹rkŒskŠpi†pg…nf„of‡lg†lg„me…nfˆrgˆrg‹umŒuj‹vj‹ujŠti‹ukvkymzoŽxpuouo‹umŠtlvnyn’xnwm‹vkˆsh†rg{p{pŽzp‘{p‘{pvkŒvl‘{p•~t˜x˜x•~v”}uxqŒum‹vn‹vn‹uoŠunŽxrwqŽvrwsvsŽuqŒtnxq‘zr’{s“}t‘}tzrŒwoŠumˆtl‹vnŠum‰tlŒvoŽzoŒwn‹unŠvnŒvoŠuozo“|q”~s”~s–€u”~s“{t“|t”zs”zs“yr’vovowpxp‰ulxmvmŒvnŒumvnyp‘yq‘zr’{uzuŒvpŒvoŒxp‘|t’~sxovovoŽwoŽwq‘{p”zp“zpwpwp{u•}u‘{s“|t•v{sŽxp’{s–w–w“|t•~u˜y—w”}u—x—~x’{sŒvlŠwlŽ{p}r’~u•|u”xuwq‰rmˆunŠwp‹xpˆskˆvp‹wp‡sl‰umŠwo‰vmŠsm‡rlŽxsŽ|uŽzsŽ|q“{u’zsyqŽwoŽwn“|r–€s’|p’|qxn†odlb„oiog…ph‚nb~g\€i]|h]}i_~ha|g_|g_~ga‚i^g]}d]€f_€j_j\ƒha‚kb€j_„odƒmb†ndƒncmbmbkcld‚mfƒph‚oe€ma}i]~h^|f^€f_~c]}d[~f[gZ{eV}aX|bVeW€i[~h\}g\}g\}f[ƒj^ƒj]}fZ~h[~h]h]€g]ƒi`ƒla‚mbi_ƒmbma‚la„mcƒmb‡maŠpdŠpeˆmcˆnd„ja†k`†ka‡ka†kaƒh^…j`‚nck`‚ma…lb‡ne…ke„me„meƒmc‚l`‚m`…oa…re‡qe‚mbƒlb…kc…kdƒib…kd‡mg‚ldˆqhŠsk†ic„ibƒia‚la‚nc‚od…mc€k_‚la„mc‚oc„pd…nfƒock`€laƒla†lb„h^ƒi_€h]f\€f\€e\}h\{j\}lazi]zh]}h_|m]~l]€k\‚m^{hYygX~l]‚ob~j^|g_|f_ic|l_~k_~h^}g]ye^{iakcg`}f^}f^€iaƒldjc|f_}j_mb~la}kaja‚ka|g\~j_}k`~ja‚nb‚pc€pa~na€mc|kc}m`}mambmb€ncmb€nc~la}k`€k`~j_€la€la€mb|j_}k`|k_}ma€lc~ld|nb|ma~mala|k`{j^|k^na{k]zjZ|f^|h^xeZzi]zi\zj\{k\|m^}l_|k`|i_}h`we]|f`}g`~ia{j]ylZ}j]|i\}h`|f_yg`vg]wk[xj]yg^ze]zc\|f\zg[{g^ve]uc[yf]zhZxgZwf\yi`zi`xe\|gZxeWzg\{g^|f`}i_}h]xg[yf\xc\|g_we]wf_xe^xf[yiYzm[whWxh[xgZ|i`{ha{haxf^xf\ve[zi`zi`{i`}lczi`yg^|i`~l_{i]zg]xe]ˆwi†qej_zdXycVu_Sr^SsaVraUwgYveXveXweZufYueXwg]tg\veZueXrfVqgUugVweYzgZzgZygZxgXudUyh[xh[zh[zi\uhZrgYtfYvfZwg[{i^{j_zh]zk]tkYwqbtpbwpfxme{k`vf[ucZucZydYygZxe]wg]wh_yh_xe]zd\ye]zh]{j]|m`{k^vh\vi[vg[yh_{h`|k_}k^{ha}jaob‚oe‚ohngƒlb}k_yjaxi`~lc„ognepfoc~la€ob€oc~pc|oczqd~rdpbpc…qf‡rgŠti†rg„tg„thŠwj‹xkzmŒxmŠuj‹wlˆthˆtiŽzoŽzo{pŒxm†tl†sk‰tlyq‘{s•{s’{sŒxp‰vn‰umŠvoŠtlˆumˆtl‡rj†qh‡oh‡piti‹wk‡ui„pi‡skˆskˆslvj‹uj‹sm‡rjƒqe†oe‡qf‰shŠti‡qf‡qe†pf‰rhŒvkvl‘wn“xp’vq‘touk’wm“xn“xn“xjviŒtiŽsm‹tm‰smslŒrkŒqjŒrkslsmŽtmtj‰rfˆrg†rgˆsk‰rj‹ulŒumˆrj‰rjŠrjŠtnŠsmŒtnŠsmŠrlˆoi‡mg‡ngˆmf…nf‡pg‡rf‹pirkslŽsmunvmxm’yo’zo’xq’xruouo‰si‹uiŽxlymŽxmŒvjth‹shŒxm{o’{n‘}s‘|tŽyr‹wpŒyr|v‘{u‘|u•~v’{syoŠth‰ujŒuk‰rj‹smŒwrytŽ|tŽ{t{sŽwown‹xmxrysŒxr‹xq‘{rxoŒvpxnznŽxm‹xm‹wpwoyozoŽxmŒwqŒvpŒvpxr”zt•{tzo|r”~s“|t•{t•{v’yr’vpŒxnŽxowowoŽxqŽxrxoŒun‹sn‹soˆslynŽtoxnŽznŒym{o–}v|uyqŒwoŽxl“}r•~t’}u”|u–zt”wr‹tnŽ|uv‹zrzr{u“zt”ys‘|r“€t”}uyq’zt›ƒ}ƒ}™‚}•z“}w•|v’vq‹slyq‘yr‘ysxr‘xrvq‰qjŒumxpxo‡tg‹vnypŽvnvpwqŒwp‹xlŒwnŽyq{s‘|s‘}qys‹up†pi‚membˆuj‰tl‡th„tg}l^}h\i`€kbjb~j^}i^~j`€kalaj`‚h^‚g]‚i^„lb„ha„hb€g]~e[‚i^€h\ƒj`‚h^g]…lb„j`ƒj`„l_€h]}f\}g[~g`jbh^€g^}e]~d]d^e_e\f\€g]€g]~d[e\{dY|eZ~i^jb€ia€ib~g_i]k`i^|g[}g[f_‚ha‚hb„jc„jb„l`†nb…laƒhbƒld…mg…lh…ne‰oi‰nd‰nd†nc„pcˆn`ƒk]j]i_€i`„ldƒl`„l`‡nd‡mdŒpiˆke„pe‡pe†lbƒg^ƒj`†pe†oe†od†lb„l`…j^ƒj]kc…nbˆnc…j`‡pd…pd…laƒj`„ncƒma‡pd†sf‡ocƒiaƒle†niƒld„pe‚peodmb‚ncƒod…od‚m`k_h`~g_h`j_i^‚k`€j_|f[~h]i^{i^}m^€n^l]~h[i^ƒld„lfha|f`{ianf…mbƒkaj_€j_j^‚mb€ma{i]€kcmd‚leib|i^{g]~kd~mdkc€jdidƒkd‚kc€iaibiclcmb‚mc†pe„od€j_€j_~la~nb€qe€mb„lb€k`k`€k`}l_|k_~m_~ldnd‚na~n_}m`yk^{oapcmc}k`kdmc~l`}m`|l_~nama€k^|h]yf\yf_~kc{h^zg\}jc~la~la{g\}h^|d_xc[ze]}h`|h]~j_|h]}g\j_}i^yf[zg]xeZvfYxg[wd\weYydY{hZwd\xe]rcZsd[xf]wc\teXvfZ{i^xg[vfZvg[wgZwgZyj`{ja~ka|h]{f_yg^yi`ui_ug^uf]we^xh^yi]yh\{k^|l^}i^{j^wk_xl`yi^zg\xh[zj_zg_|ialb|j]zj]zm_}pb{m_yi\zhZƒob„re€k_~h]„k\ƒj\}e[ycXwdYzgYxgZveXveXucYrcVp`ToaUucXvdXseXreVveXvfXvfXxgZwfYudXvdXvgZwgZxgZxgZwgZvfXueXwg[yi]|k_|ja|hayj^ui]sk]qiZti]vh^zj\udXvcZubZvd[wf\wd\we]ud\ve\ze]{g_ud[wfZveY{k]zj]zi]xi\zk_zi`yi_~la}l^}kc{j^|j_|j_~kc€ld€k`zi]xk]zl`mcƒoeng†sj„tg€pd|na~ob|nc|ob|pd|pd}oa€pc„pe…rg‡sh†rg…ti„thˆsjˆsjŠul‹wkŒxm‹xl‰vkˆti‹wlznŽzoŒymŠxoŠwnŒxozq“|s–~u’|t{s‰vn†sk†rjŠtlŠvn‰tm‰tl†qi‰rjŠslvlynŠwl‡um‡rj‡sj‹slŒwlŒujŒupˆrjƒqe…od‡rgˆrgˆrgˆrg†pe†rgˆshwmwlwmxn‘wqskŒrivl‘wpun’xm‘vk‹qg‹rjŒvlŠtlunslŽtmŠpi‰oh‰ohsltjŒth‰sgˆpg‹qi‰rjŒumŽwovnŒumŒumˆsl‹tm‹tmŒunŠrlˆng…keˆngŠpiˆqiŠsj†pe‹piŽslslunwovnvn’xo‘wp’xqŽululŠrl‡qgŠtiŽxlyn‘zoym’wmŽvnwoŽ|q“}r“~t‘}s{sŠwoŠwp‹xpyt‘|u’{syrwm‹uj‰ujŒulŠsk‰qlŠuoŒxsŽ{tŒyqŽxpŽwo‹vlˆuivqŽwp‹uoypzr’zr‘ys‘{r“|ryn‹vmˆun‹umŽxpyowmŒvn‹unŒwoŒwo“zr’yqwp{t”}u•~v”|u•{t•{u“zszpyo‘xpwpxq‹uoxovoŠslwqvpxosmŒwn‘}r’s”s—|u”u’|sŽyqŽxn’~s”€t’}u–}u™}v•zuvpŽ{uzrŠvoxp’|v˜y—~x’~u”w•x“|t–|uš€zšƒ{š„}•€y—€y–~wŒqkŠskyqwpŽvpŒtnwq’xrŽvoŽwoyrzp‰uj†vm‹wpyrŽxp|r{qŽyp‡rjˆrk†qj‡rj†qh‚ng€ld|h`zf^}ia‚nfƒnf‚odnb|k_j_ƒlcƒldjb€i_k`ƒla‚lambƒla†ka†ka…k`…lb‡kb…ia€g]f\}d\h_€g]~e[f\€g]f\h^€f]~d[~d[}e[g^€g^f[}dZ}dY~d\f]~d]‚i_h^h^h^f\ƒi_~i^j`‚k`ƒlc„me€ia~g_j^‚lb€k_i]i]i^ƒja„jbƒib…lc…mb†nb‚j`h^‚kc„lf…mg‡ng†lf†lb„kaƒlalaˆpa„l^‚j^h^ja‚kd‚kb†mdˆoeˆoeˆoe‰neƒoc…nc‚j`ƒi_…lb†nd‡mc‡mc„kbƒk^ƒi^„l_‚kcj_€g]‚i_j^‚l`„ka…lb„nc…oc†pdƒpc„m^…ma‡og‡oh‚kcƒme„nclaj_la‚mb†oel_€j^h_~g_ja€j_€j_~h]k`‚lak`k`€manak]l^€m`‚oc„obƒock_l`ncoc„mb„jak`€j_ƒmbla~mb‚oc„ogleƒleibzg\|i^~lc~kb~jb~ibjc‚kck_k_jbƒke€mamb€lala~l`}k`€k`~k`~ma|la~j_€h^€jbka~j`}j_}k`~l`}ldmdma~l_}l_{j^|na~nc€nc|j`}jc|lb~l_|k^}m_|l_na}g[{h[|i^|j`mc~j`{i\{ia{i_yi]yg\{g^zf_{f^{f^|g_{g\}i^|h]yeZzh\zg\yh]yh]zi]wh[yh^xe]we[zg[ziZvdZucZtd[vf]we\vc\ufYzg\{i^yg\xf[wg[xg[vf[xf^|jc{h`|g`ye]we\vf^ti^tg]te\ve\wf]vfYwg[{l^~oaja|laqgqgmc~i_zh_xf_yf^zh^wfYyi[}k`zj_}mc{la{i_yd[ucUvbUzfZ~i]‡o`’xj“ym‰qgƒj`|eZwcWvcVudWtcVp^To_SscWyf[yeZxh^vd[ye[veVwgVtcUvdYucYtaYufXweZzh]|h\}j]{h[wh[xgZvfZve\xg^yf_yg`uf[ui[tgYufXvdZ|iZ{gZwc[ub[uc\ud[xf[xf\ucYtbXvdZxdYue\vfZwg[{j]|l^~k_}l_{k_yh_yh_zi^}l_{k_yj]{i]{h`}g_}ha‚o`~n`{n`zm_~obod…qi†skƒri‚rf|odznb|md}neqe}odocqdƒsg…th‰ujˆtiˆujƒsh…ni„nh…oh‰umŠvk‹xkŠuk‰uj‹wlŽ{o{p{q~q‹ylŠwjˆviŒwkzn‘{pzoˆuk†ti‡rh‹ujynzowl‹uk‰rh‹ukŽukxm‹wlŠum‡rjˆqi‰qivkvlvpŒvnƒre‰shŠti‰shŠti‰shŠti…rg„pe‡shŠti‹uj‹ujŒuk‹tjŠsiŽwmxqŽup“wp’wpŽuk‹rh‰thŒvjŽtmslsl‹qj‡mfŠoiŠpiŒsjŒsitjskŽqj‹rk‹tlvnvn‹tlŠsk‰skˆqiŠtkunsl‹pi‹qlˆnhŠpi‹tlxoxltm‹qj‹pirlŽvnŒvnŽtnunŽsmwmtjujˆqi‰qi‰thzn“}r“}r•t–zt‘xrŒvpŒypzo‘~r‘}rŽyo‰wl‹xpŽ{s‘{u’|u“}t’{txoŒvk‹wlŽwmvnŠsl‰uo‹xqzsŠtmŠskunwnŠwkvpvpŽwpxpŽwp‘zqxs“zt”{q‘yovoƒpiˆrnŒwpŽxn‹ujukŽumŽzo{p“zr•{txrxr”}u–w•~v”|u”zt”zsyoŽvmunvoŒsmŠrmŒumxp‘wq“ys”zs‘wpvpŒvoŽyq’}r”t—u–|v•{twoŽwo{r‘}q“}s–}w˜~w–}v’{u‘}w”~t“{t‘zr”}v˜€z•~x—‚z“w”w•~v‘wp”xr”~u“|t‘zr’{s”{t“yrŽwo•~v’ztxqvpwq‘wq‘wq”zs’{syp‹vk†to„qj‡pi‡qf‡rf€m`jb~haididle€kc~mb~la|iald€mfng„of†rhƒodƒod‡pf‡ph†og„mel`€j_€j_k`~j_ƒka‡laƒg`‚g_€g_‚g\€f[{bX|cZ}c]}c]€g\f\f\~e[e[g]ƒf`e^‚h^ƒh^ƒk`€g\~fZ}eYg[‚i_€g]€g^‚i_h^€g]h^„ka…lbl`j_l`…odƒmd|f^e^g\‚i_€h^i]i]‚k\…n`…ma„ka…lb„k`ƒi_ƒj`‚i^‚kdƒle‚ld†ld†mc„kaƒj`j_‚lb„l`…na‚j_h^„kah`…mgˆqh‡phˆoe…lc†na‡qf‡qf‡nd†mcˆoe„la†j`„i^„ka„l_j^~h[€iaƒk`ƒj`ƒj_€i]k_„ka†mc…nd„na†odnbƒl]„l_‚lajb€haha…ja‚i_‚j`‚j`‚laƒmbƒma€j_jbƒld‚kbk`‚lak`„ncƒmbƒmbƒmb„nc„nc~k^~k^€nb€nc„pe…qeƒoc…reƒpcna†mc…lb‚ka‚la…pdmbod‚penc‚lbƒmdkb€k_}j_~laldjb~h`k`k`‚l`ƒmaƒmbƒmbƒmb‚nc~k`|l`~oc~oc€la}j_~nb‚pela„nckejc€kclc}j`}k`|kbncmamb}j^}i_|ma|k`}j_|i^{i_yi]|j_{i^|j_{i^~j_zg[{hZ{j]yi\{j^{j^ziZ{i`zj^xh\xh\yi]zh`|g_{f^yd\zf[|h^{g\zg_zg_zg_zj^wg[wg[zk^xf\yf^xe]zh\zi\xe]wd\ubZubZvc[ye^{i^{i^|f[~h]zg\yg\weZuc[tb[{hcwd^yf_yd\uc[uf]sg]ug]vg^xg^ud[ve\vfYyi]zj^{h`|ja~nf€qh|ja|h`{gazg`zh`zj^whZylZ|i`yg_{ja}ibzg_xe]vbWvdZudXxgZ‚j\whž†zŸ‡zŽukj_yfXxeWxdXveXveXsaVqaTxcWzeZzg_wf]zc\tdUscTq`Sr`VuaZt`XsaXwe[xf\|j_~l_j]{j]xh\vg[tdXtd[uf\yg`wg\vfYxgZwfYzgZ|iZ{h[yf]vc[tbZraXvdYwdYxdYxdYwdZveZue\vfZwgZ{j]|k^~j_|k^{j^wh^vg]{k_}l_{k_{k_{iazg_~jb€lco`oa€pb|oa|m`}na€me…rj„ripg{na|pd}nepg€ofqe€qe€pd€rfsf…sh‰ujˆuj‡tkˆrl‡qk‰tlŒwn‹wlŽ{nynŒxm‹wlŽzoŽzo{q{nŒylˆvhˆuh‡uhŽyl‘{pxn‹wl‡sh‹vkyn‘zo‘{pzoŒvk‹ujŠtiŒriukŽznŒwo‰skˆqi‹tmxn”{p’xrxq‹wkŠtiŠtiˆrg‡qf‰sh‰sh‡pf‡pf‡pfˆrgŠti‹ujvlŒvkŒukynxqws•{t’xqvo‹rg‡pdŠthsltlŽtmŽtmŠpiŠpi‹qlsktjtjulqm‹rjŠpiŽslunslŒrkŠskŠrj‹tlunvoŽtm‹qlŠpjslvnŽxnymŒumˆqi‰rj‹tlwo‘wpuoŽtmunŒsiŒsiŒthŠslŠskvnxpyo’|q“{t–ytŽtn‰uoˆvnzr|o|q|qŠxnŒyqŽ{s•y“}v•~v•~v‘zqŒvkŠvkŽwmŽwovn‰um‹yqŽwqŠtmŠrjvnŽxoŒyn“ys•{s•zsypŒxlŒymxrwpun‹rk‰slˆrl‡qlŒwpwmŠtiŒtjwp{ozo•{t•ztwpxqys“|v•~v‘{s‘yq’xqzoŽvm‘wp‘wpunuoŒtnxp’|t”{t“yr•{u’xrŠsmŠtmŽyqzqwm“zp™v”|t‘zr’|t“~w“}q•}s˜~v˜w—y•€x—~u˜u˜~v–w•~u•~w|t‹woŽyq“{s‘wp”{r‘}u‘{sxp‘wp•{t˜}v–w•~v“{t’zuwquoŽtnun“yrŽwo‹tkˆrg‚jd„jdƒha‚f\‚h\€g[h`ib€gbgc†oh†ph‚oeƒqgofƒphƒpi†slˆsk‡rj…ng…nf…ng‡pg…meƒld€j_~g\}g\€j_{h]~f[‚e_€d\e^~d_g[€eZ€f\}dZe^€e_ƒj`€g]h^h^f\‚i_‚f_‚f_‚h^…j`‚j_€h\i]‚j^‚j^ƒj`h^ƒj`„ka‚h_h^ƒja†mc„kaƒj^€h\ƒj`…lb„jaf\€f_f\‚i_ƒk`‚j^‚j^i]ƒk_„l`„l`„kaƒib€j_‚lak`„ka…kc‡mf†mb„kalaƒmb‚la‚la„l`…lc„ka„ka„laƒibƒkeˆqj†og…ld…lb…kb†pe‡qfˆrg…od‡mcƒi_ƒh^„h^„kai]j^€j]ƒhbi^k`k`j^…ma…ma…l`l_†pe„ncƒoc…n_ƒl_€j]i^€iaƒne‡kc†ka…lb†mc…od„mcƒmbƒmc‚kc…nfƒnb…oc…od‚la„ncƒmb„nc…od…od…ocna€m`€nb‚od„og„nf…ph…qf„peƒnc‡nd†lc„ncƒmb„mbla‚qf„qf‚laƒlaƒnc‚oc‚la€la|j^odldjck`€j_€k]ƒn_ƒmaƒmb‚mb€lancoc~nb~oclaod€ncodmc…pe~le}ib€kcjb}h^{h]zh_}jbkd|j_{g\~h\}la|j_|h]~j_|j_{k_~la|j_|h]k_}i^{g[|j\{k^zj]{k^|l_zhZzi]xh\xh\xh\wg\xh\{f^yd\ze]zf[|h]{g\{hayg^wd\yh_zj]teXvdZwe]vf]xh^yi]zk]yf^yf]xe]ubYs`Wwd\xg[vcX{f[|f[yf[weZvdYr`Xtb[ub]wd^wd]ze]uc[uf]qf\se\vg^we\ve\wf]zi`zi^xh]yg_wf]zi`yh_zi`|ia{gb{ia{ja|l`{n_{o_}i`zg`xe]yf^xe]yf^veZweZucXscVwcZ~j_yj–‚s“~q†qe€m^m^}j\|i\yh[wfYueWwdWvcWvfYueYwbXqaUp`TqaUrbVueZvf\xc]we\td[ufZxg[{i\yh^zi^wh^seYtgZwj]{g_|h^{i]zi\yi\xh]xhZyh\yf]xe]wd\tcYxdYzeZzeZzeZxeZvfZyg^wfZudXwfYwgZyh\}i\yh\xi_vh^yj^|k_~l_ƒogld~kd}kc}lb~ma~nbob|m`|mczla}le€ohqhri€rh}oe{ofqhpg‚ogqd€pdyoc}nbpeˆtiŠuj‡tjˆsk‡rjŒwnynŽzp|pŒ{p‹yn‰wl‡ujˆvkŠxmŠulˆtk‡riˆsj‹vmzp“zp{pŽzoŒxm‹vktjvl’zpxm‹ujŠtiŠtiŽsjxn‘{p{sxpŒvmvo’yn”{p“zt‘xqŒym‹uj‡qf‡pe‰shŠti‹uiŒpj‹pi‹oh‰qjŒtlumuovnŽuktjsk‘wp•{u–|u”{qvltjŒtiŽtmŽtmŽtmŽtmŽumŒrk‹qkŠpisjŒuktnŽsm‹qj‰ohŒrkuntlŽtmŒulŽulsjŽul‘wo“xpŽuoslŽsm‹umŽwnŽxlvo‹umŠsk‹tlvovownvmunslskskvnuo‹sm‹smwmwlxo‘voŒrm‰vo‰xpŽ{r‘|s‘}t‘|tŒyqŠwpzrzt’|u•~v–~w‘zqŽxm‹vmŒulŒulŽxo|rŽ{rwqŽvoŽtmŽvnwnzo’zr•yr’wqwmxmŒyo“yu‘wqunŒslŒtmŠtowpŽxq‘{pŽxm‰sl‹unŽyqyqwo‘wpyrzrzt“}w”}w“|txpyq’{p–|t—{t–zt’xqŽvpˆun‹wpzqypŽvo‘xr‘wpŠtnŒvqŽxrxpwm‘yo–~t™w–~v–}v—~w–}s•|r‘{o•~v•w‘|t–|ršw™€v—}vš~w—|t’zuŠtlŽwo“|t‘|t’}r|s“}t’ypŽtlxo’|r“|t’{sŽwp‹sm‡oi„mf‡je‰nh‰oi‡mf„kb€k`‚f^ƒg^…g_‚f]g]i^ka„me…ngˆpi‹sk‰ri†rj…qi‚nfjb‚nf†qj„rg…ng‚ic„jdg`~i]e_€f_~dZ~e[€g]g\}h]|dY{`X~b\ea€ga„g_ƒg_€g]h^‚h`‚h`‚i^ƒj`h^h_‚i_ƒka„iaƒh`ƒj`ƒka‚i`h_i^‚j_ƒj`„kb‚iaƒib‚hag`g`‚haƒib‚h`h]g[€h\h^h^}dZ~d]f[i^€h^€h\i]‚h`ƒj`ƒj_ƒk`€f^‚ha€j_‚kak`ƒj`…lb„lb‡lb„lb†od‚lbjc‚jb‚lbƒmcƒk`ƒj`…lb…kaƒmfˆqi„meƒmd„lf…kd†nd…od†pe…ncƒka…j`„j`†ka…kbƒj^…l`…l_g`ƒla„ncƒmb†oc‡pd†nb‡oc„nb†pe†od…rgˆme†mb‚m`†pc†pd„pf‰pi†nf…me‡ngˆnh„meƒod„ofld‚me„pd‚pcˆrg…od…od„nc‚la†pe„og…qf‚ob‚ob‚od…pgng„ng†qg„pg‚oal`…la†mc„ncƒmbƒlancƒrf‚od„mb†mb„pc€obƒma‚m`‚nc‚nc‚mb„nd‚lb€j^k`ƒnb‚l`„mdmblb‚ncla{i^mbmbodnc‚mb„pema~kc|j`|h_k`~j^|i]~h`~ia{h`{ha{g^}i]{h`{f_}i_}i^{k_{k_}j_}k_€j_l`~i^zf[xgZ{j_{k`wh]zh]zj]zh[xfZxe\yg]zi]yi\wd]xe]wd\zh]zi^yh]yc^{g`wb[yf^xg[veYxe]xf^vd]yg_{kazk^zi]xfZ{g\xdYvcXwfZvfZxf[yf[weZwdZtdXxdYvcZvd\uc\we]xe^yd\we]qbYpe[re[rcZwf]yh_wg^yh_xg_ve\vf[vf[yi^xg]{j`xh]xfaxh^wh\yi\{l_{m_zh^ye[|f]{f]xf\zi^wdZxg\ufYrbUo^Vp_VxiYp_†vf†vf‹vf‡sd€m^~k^{i\xgZwh[wdWveXtfXufYucVudZueZtdWvfZvfZvg[|f`we]paXpdXqdWwgZzh`yh`wg^wh\thZuj[|h_}h]zi\yh[wh\se[ueYue[wd\ubZxdYxeXyf[|g\~h^~h^zf[veZxc[veYudWscVtdWufZ}i\{i^wh_vi_zk^obƒnaƒld€ld€nf}mczl`|l`}m`}lb}lbzlczlczjc~ngpg~pgri‚rizlf}ld€mdmf‚pf}nazoc~qe‚qe‡tjŠvk‹wlŽ{nzmŒzmxl‹wkxmˆvkˆwl†ti‡uj†ti‰xm‹vo‹wnŠum‹vnŒvnŒwp“{o‘zpynxmŠtiˆoetjwmwmŒvk‹uiŠuj’wn“|q“}r“}v“}t’xrvnŽtj’wn‘wqwpŠvjŠti†qe†qf‰shŒvkym”vo’unŽrkrl‹qjŒrk‘tormŽsjŽsirh‘wn•{r—~t•|r”{q‘xnvlvoununŽtmslŠpiˆnh‰nhŠsi‹uj‰tmŠtnŠqi‰oiŒskŽtmun‘vp‘{p‘wntjŽuk•yn“xn‘wqsmsl‹umŽwnxlxpŒwo‰rjŒumvoŽtmvlvlvlŒrkŽsmuoxpŽwpupŒtn‰ti‹vjwlumŠrkŠwo‰yn‹znŽyr{sztŠwp‰wp‰vp‹uozs“|t“~vzq‘|pyrŽwnymŽxm{q{pwquo‘woun‹ul{o•{t‘un‘uk“yozp|q”zu—{v•xrŽtm‹rl‹tnvoxmŽymŽxn‹woŠtnwqŽwq‘xq’xq‘|q“~u“}w“}w“}x•~v‘zszo‘{p•{r–ys•yr”yrxrŠwqŠxpŽ}rŽzo‹tnŽup”yrŽwq‘zv{uzt‘wnyo’}r–}s˜}w”yr”vq•}q“|q’|q•t•~vyq“{q—~t™€v›v›x˜}v•zuvpxpŽyq‘}qŒyn‹xmŽyntjŠqg‡pe†peˆpi†og„ke‚jdhb~f`ƒf`†ic…ld„ibg_€h^„ka‡lbƒi_€g]€k`mbƒob‡pg‡ph‡pi‡qg‰rgˆqj…oi€jbjbmbƒocnd}g`e_€f`|d]ybX~d^e_€g]€h]€h]g\~i^~g\€d]a]€e`ƒhc„ha„haf\€g^~f[€h\h^h^‚i_€g]‚i_…ka„l`€i]j`ƒnb€jc€jbƒka„jb†ld†le…kdƒicƒia‚g`ƒibƒjb€f_|d[~fY~fZfZ~f[|cY{bXc\f\‚g]f\h\„i^…ke„jdi`€g]‚h`ƒhbƒmbƒmb‚lah]…ma‡nc‡m`…mb‚mb‚nckcƒibjbƒmeƒib„jc„j`…j_ƒncƒnejb‚jd„lf„ke†md†pe„qe†qe†mc…ka…od‡oe„ka…m`‰nc†m_ˆne†nd„od„pe‰rfˆma‡oc‡oc„nb‡qf‰sh†rfŠpjŠqhwhŠuf…pa…re†qi„og†og‡phˆngŠpj…qf„og‚nfƒngƒoc‚pb„mb…nd‚la„mb„nc„mbmf…si‡tgƒpc…ne‚ld‚pd€pcƒpb…rcƒo_„p^†lb†mcƒla„nc„nclb‚qfƒpe„mb†oc„oc€pb‚k_€m_ƒpclbƒod…la„me‚lbƒmb‡pe„mdƒkd€kak_k`k`k`la€mb€ncma‚nc~k`k`ƒqf~k`|j_€m`|i\}h\‚i_hb{ha{h`{i`~k^|g`}h`€j`{g\zi]wgZ|ka|h`h`h_{g^xcZweZzi^xh`yia{i_wfZ{gX{h\ze]yg_{j^zj[zg_xf^wd\{i]{i^xg\{d_}f`yd]yd]weYxe[xe]uc[vd]ve^wi_wj\yh\{h^{eZ~g]xeZwfZtgZwg[yf\wfZwg[teYyfYxfZtcZtd\vf\ueXuaYwe\rcZrf\qcZpbYzh_zi`xg^xg^zh`zh`xi\ueYueYwg[xh\xh\vh`wi_xk]yi\yh^yg]}l^{fZ|gZ{g[zi\xj]tfWufWvdXvbWq_SraTveXzi]}ka‚pi‡seˆvg}n^zj]|j]€m`zjYvfVvfVveXwfYwfY{i[zi\xh\xh\udZvbZxfYveXweYveYyi]yi_~h`{ja{i_{h]zi\ui[yd^zf\zgZ{h[ygZvbZxfZxf[yg\~i]{h]}i_xgZyi\zi\|i\{g[|eY{cYxdWveVtfUwhXxhZzh^|j_}k`{k_|l`{k_zl^}l`}k`mb}l_zm^zkb{lc€ng~le~le~jdymbzlb~ofofpf‚qg~ne{md|kbrdpe…rgƒqeƒrf€sg…wiˆwjŠxixnŠum‰tlƒpi‡tm‰wmŠwjŠvj‰ti‰ti‹wkzn‘xrxrŽxrzr‰vn‡tjŠvl‹wlŒxmŒxm‡sh†rgtj“zp”{q–}s–{u“zrŽwlŽxlzn”{r’xrvrtnŠqk‹tlŽwlŒvjthŠti‹rhˆoe‹sixmŒ{pyq’wptmsh‰pfŠtiumtjtjtjŽukvl’{s“|t“|t•~u”}uyqtm‘un’vo‘unum‡phˆqi‰qislŽsl‘vo‘vnsopkŽpktmtn“wmxnwlvlvpun“yr‘yqvnŽtmŽtmun“xqxqxovn‹tlŠskwounuoŒrksltivlzr’yr”yr’xqvnŒvnŽtnŽvnwoŒum‰unŒxp‘xr‘ysxrŽvq‹uo‹uoŒwozr’{s”{t•{t–}v’|qzrŒwoˆvn‹yrŠxqŒuouoys‘ytyr‘zs•yr”xq‘wq’xq”zs–|u‘zr’vo“wp‘umŽsl‹umyoŽwpxpŽvoxr‘xs’{r’{r“|t‘{s’zs“|t“{u–v•~v—v”~r‘{o‘yr”}uzqvo“{u•~x|t’}u”|u“{ttnun‘xr’xr—}w“|u’zszqŽti‘vn–}wysun’vpšu™~t—~t•~w•w‘|tys”}v—wšƒxš€y—}w”|tŽul‹rg‹sh‹ui‡tf‡re…se‚odlaƒme„jcla‚meld~kc~ib€ic…pd‡nf…keƒic†ja†ka…ncƒnb„kc‚haƒjd‡lfƒlh„lfƒle…k`†la†l`†kf…kegb~g_‚kc€ia€i_}f_e^e_}c]}`[„h_…j_ˆlb†jc„ha†jb†mbŠodƒj`h_haƒle†icƒg`‚f`ƒh]f\e\ƒh^h^h^~g_~g`€ia‚g`‚h`‚l`€j]i_ld‚kdjd„ke„ke„ic…hc‚j^j^}h\~j_}i]zf]~f[~e\€f_~e]}eZ~fY‚f\‚g]h^i]‚h\ˆmbˆqg‡mc…i_ƒg]†ka„oc…lb„ka„ka„jd…kc†ke†nc…od†pe…od‡mc‡mc‡ndƒj`„i^…j`†ka†ka‰je†kd†kd„nf„og‚nf‚mg‡qj‹skŠoi†nd†oeˆskˆth…pd‹qg‡obŠpd‰paˆpc‰qe†pf†oe…of†nb‡pe…od‡perhŽqiˆqfˆrg‰sh…qf…qf„qf‡qj…ph†og‡qf‰qgˆod†oh…nf…od…oc„nbi]l`ƒod„peƒpe…piƒnf‚pe†sh‡qf…od€mb€nb…pfmb‚oc„pd‚ob‚ob…mfƒle„nd…od„naƒo`‚qfnc‚od„peƒpenb}nb‚qe‚pfmbƒnc‡qf„ogƒnfƒnfl`mb€kb€jd€jc~j`€m`l_mble‚ng‚pf€nclaƒk`€mc}k`mb€l`k`|h]{i^|i_{h`zg_{i]zj\xf[zi]}j_|h]}g\~i^{h]}k`|j^zgZ{gZ|i\{h[{k^zj^th]wi`yg`|j[}i_yf_xe^zh^p`~j`xeZyg\xf[yg\xf[yd[xe[wf[ueYvc[vc\ud[ta[ta]vc\xh]whYuhWwhZ{h\xc\{e^ze_yf^xd]zg_zg`yf]yh\yg^xd\{f^wc[vbZyh`weZzh^zg_wf]tcZtb[wg`vh_ug[wj\xk_wh_yg_ve[vfYyi\{k^xh\zi]{l_~la{i^}j^|h]‚kbjb|i^wf[{j]zi\sbVwfYzg[{f\xg[veYveXxgZxd[zg_~i[l]oa~l_na‡rf…ueo_yiZyi\xhZxgZ|iYxiYxiXxiYueVtbTubUvfXzh^xg[xh\yh_|f_zh`{i^|h]zh\ug[we]xf\xg[yh[zh]yf]xf[xf[{i^|i^~i^}j_zj]xh\xf[ydYydYzeZz`\zd]{h_vfZxg\yf^{h^{i_lc~kayi_yh^wj[{k]€od}ma|l`{m`zmczmc}od}odoezkbwk_xj^xl^ococ€nbnf~ne€pfƒsh†ui†ti‰sk…sj„sh‚sg†ui‡vi‰vkˆti…qf…rg…th…shŠwjynxoŒxn‰ujŠwjvnŒwpŽzpxoˆtj…shˆrgŠtiŽxmwlŒvkŠtivl•|r˜~t•|s•{t’wp‹vkˆrfˆsfwmvpuoŒrl‹rkŠslŒvlŽvn‘wnxmŠshŠqg‹rhˆshŠwlwountnŽsi‰pf‹ujwlvkŽvlŽwlvkukwoŽwo“|t“}t’|tyqŽuovo’vp’vptnŠqj‡phˆqi‡qi‹sktmunrlqkŽsjsk’vm–zp‘xnwm“zp“yr“yr“yr•~v‘zrwpŽtmŽtmunxpŒvn‹ulvn‹tlŠtk‘wqvovountmwm‘{t”|t”{t’xqwoŠvntmwoxpŽwoŠtl‹umvpwpwpyrxqŒwpŠxpŠwoyqŽ{s}uŽzr|q‘|uyqŠwoyr‘|uvpvp’ys“{s”{t•}v—zs˜{t“xq‘wp‘wp”zsŽxpwp’wp‘vo’yqŽxpyqyqŒumunxr’ztxpxq‘zr’{sxpyp“{uyqyq“|u–€v”~s”}u”}vxqwp‘yt—~y–y–y”}u“|tvo“xqŽto“ys—|vys‘zr’|t”yn‘vm”{v’ysuo“wp˜~t›‚x•~s”~v“~v’}tŽwqunwm‘yovpŽtn‰qi‡me‚j_…lbƒmb‚nbƒpd€nclclc‚me‡ogmbƒpe‚qg€ne€kdƒof…ncˆne‡mf‡le‰mc‡nc…odkbƒibg`‚haƒgb€g`€haga€g^g_h^…kd„id„kbi`‚kal`€g]‚ha„ib…jbƒe`‚d_…i`†kaŠoe‰mfˆle‡leˆmb‰mdƒj`‚i_…jd„ld†jcƒg`„ha„i`‚h]‚g]‚i_h^€g\g_ia‚kcf_f]‚k_j^kbldƒjdha„jd‚hb‚f`€d^h]}fZ}f[g]~f[}e^€h]h`ƒjbg`‚i^€i]…j`…kaƒkaj^i]ˆmaˆpf‰neƒh^…j`†lb†odˆne†mb„kb„jc„jc‡mfˆpe…od…od…odˆoeˆmc†nd„lbƒlb…ka‡mcˆndŠng‰mfˆmgˆpi…og†phˆrk‰sksl‹rk‹qgˆrgˆph‰rg‰rg‰rgˆqeŠrgŠtf‹tg‹sg†oe…mf…md‰qdˆqd‡qfˆrgŒqjŽpkˆoe…mc…nd‡pfƒnc„od‡qi…og„nd„nb‡oeˆne‚kdƒmc„ncƒmb‚la‚l_~jamb‚nc…qf‡rg‡ri…sh„qf…pe„od€la€nc†od‚ma†oe…od†oe†peƒld…nf…nd‡qf…oc„pb€nc€nc‚od„peƒpe~maoc„qg‚oe‚ncmb€k`€kd€kbld€la€la€la€jcia€lbl_€l`lbldmeoemb„odƒla~la}k`}k`~j_k`~j^{h]|i_{g_{h_~k_|i\zh^}h_}h_|h^{f]|f\{h]|j_|j_}i\{h[zgZ}f[zgZveZwg\wf^xh^}i]}g^{g`xe^yf^€obzi]wf[yg\ucXxeZyg\{f^vcXwg[vfZvd\ub[xe]ub[wc^we^xf\yiZvh[vdYwcXyd[xdZzd\xe]vc\yf^zg_yg[yh[udZxc\ze^|g_yd]wf^xf[zh\xe]xg^ud[we^vg_vh]xk]wk]yl_yk_yg_wg\wgZyi\yi]zj^zi^|k`}k`~ma{j_yh]k_}k_yh\xh\}m`|j^ubXweY{h_zf_wh^yj]xgZygZyeZxbY{eW{fXwaU|g[k_ˆrf{kŒyk†sfƒob|i\xdYyeYweXxgYvfWudUvdTyfZxhZzh]zh]zj]wg]wdYxg\xh]{eZyf[seYwd\yf^{i^}k`|j_|j_zj^xf[yg\xf[}j_{h]uc[wd\wd\ye]{f^yd[|d_ze`zg`zi`{iavd]xc[yd\|ia}jb}jb{j`wk[|m^~nane}md|nbwlbui]wk_{pb}pbzm^vi]yk^~nb€pd‚qf…sh…tk…uk‚rfƒth„sg†th‡qi…qi„qiƒrisi…vl‰ui‰vi…re…re„rf…th‹xk‹wl‹vn‹vnˆti…sf‰tj‹wl‹wlŽzo‰uj‡sh‰qgŽukvlxnwmtj‹ujwlypzoyqŽwo‹uj‰sg‡qetjumsmumuk‰si‹tmŒtlŽtnˆsiŒtjŒsiŠqg‰shŠvkŽvn‘wp”xqukulwlwlŽxmynŒwlŠti‰sg‹qkslvo‘wp‘wpŽvnxrxq–yt”ws’uptn‰tl†ph†nf‰skŠsksltjtjŽukwm’xn”{q˜}s‘wm’yo’xq•{t”zs‘{szqvoskvo’vovounslŽtmunwo’xq”zs’yr‘wp‹tl‹tlŽyqzr’yq‘wpŽvnŒvn“xqwpyqyqxpvnunvo‘wp‘zrxpŒumzrzryqŽ{s~v}tŽ{s‘}u‘|t“|t•~w–}v—{u’vo—|rš~u›€w›€v{›~w”zs’wp’xq”{tyqŒwo‘wp‘wp{rzryqyqŽwovnŽvoŒuoŒum‹umyp‘zryqŽwo’{swpxp‘zr•~v•~u•}x•}w’zuwqvr‘ws’}v”~vxp’{s–{t•{t”zt—}w–|v‘zsyq‘zr—{u–zr“{s’zs“xq‘uoŽwlynŒvjŠunŒvo‡skˆnhƒja†nd‰pfˆof†kf‚ld‡le„jc‚j_k`ƒod„qh„riƒqi†qi‡qkˆqj„rf„rfqemb~kb…of‰qf‡oc‡nd…lb„la€g[~g_~g_~e^|b[€g`e_„i`ƒh_h^g`i`€ha„jb…lb„ka‚i_j^„la‚f_‡kdˆle‹mg…ha†ic‡laˆmcŒqgŠng‡kd…ibˆoe†mcƒj`‚i_†mc…lcƒg`e^„ha„haƒh_…j`h^€g]f\f`‚iaha€f_€f^‚j^g[‚ia‚ibh^h^g]‚g]dZe[}fZ~fZg\f\f[ƒg_‚hag`‚haƒj`‚h_ƒk_…lb†odƒnc€k^ƒl`†na‡nd†mb†mc…lb†mc‡nd‰pfˆof‡mf†le‡mfˆng†mc†of…ne†ogŠqhŠpf„pe„od†pe‡qf‡peˆoe‹qgŠqg‹riŒsiˆofŠrgˆrlŠritjuk‹rh‰pfqkŽtj‰pf‰shˆtg†re…qd‰th‰ti‰pf†lfŠog‡pb‰rdˆpeˆoe‰oi‰nh‹og‰nd‰ndˆndƒka†mc…meƒmd‚ma†pe„mb„k_‚mb‚laƒmb…oc†pd„nb‚mf„og†rg‡sh†rg…qf„rg†qfˆrg…odƒncpe†od„odƒmb„nc‡pf†of…ng‡pgƒmbƒmb„nb…pd‚pe‚nc„od†pe…qfmb†peƒod€lak`|j_|j^ib}h`ld€lamb€la‚nd‚ocnana‚mejb}h`~ibmcmb€l`mb|j_mb|k_k`‚nc~j`|h]~j`|g_€kbl_|j\|g`}h`ze^}h`{f^{f^~la|j_|k`}j\€l_|i\|fW|gZ{h\xeZucYubZzg\xe^zhayf_zg_|j^wg\wg[wfZyeZxcX}g[}h`zg]wfZueYwe[yf_ze]{f_yc]|f_{g^zgZve[wf]{g\zf[yeYyhZzg_{h_xe]xf[vfXwfVtdYzf\|h]{g\{h]wg[weZucXxf[wf^xg]xg^wg[vfZxi\{k^yj]}m`~nd}lbzj^xh[xh[{k^{i^}k`|k`{l_xi]xj^|j]yh[vg[xi^{jayg^|h]zh]yi]wg]rdZwh\veXucWwdXydYxcWzeY}fZ{dY}g\~h]†sf‰vi‹xkˆui€lb|h]xb]ye\}g_|g]}h^{g\xeXwfYyg[wf[xh\xg^yg\vgZyh]|f[{g\wg\vc[we]zg_{i^}k`{j]zj^xi\xf[xf[xf[yg\yf^yf]|iaxe]|g_|h_~f`{g^xf[yi[yg[xeZxc[ze]~ialdnf}ja|n`zm`{md{mdyj`yk^uk^ui]ui^wk]|o`|p`}l`~nb‚rfƒsg‡ti‰wl‡uj†ti…sh‚oeqcƒtf„og…phƒog€pg‚ri„wm‰xlŠxk‹wk‰vi…rf†sf†rg‡ri‰tl‡sk‡sj‡sh‰vk‹wlŽzo{pŽzpŠvlukŒtiŒtjtjxmukŠtiŠti‹ujŒvkyq‘zrxpŠtiwkŽukskunŽvkŽwlŠtiˆqi‰qjŒsmŠtjŠuiŒsi‹rh‹si‹wlŽvo’xq“xq“xnwmvkŠtiŠtiŠtiŒwlˆrg‰shŠoiŒrkŒrl‘wpunvoŽwq’ys’vq”wr‘to‘uoˆsjŠrj‰qj‡ohŽtmslŽuktjwl”{q”{q–~t–zp“xn’wmvo’xq“xr’|syq‘wpvoun‘un’xq”zs‘wpvovo‘wp’xqvpunŒvn‰rk‰qj‰voxrvpuo‘vqŽuoŽwoŽvn•zs‘wp‘wpvounvo‘wpŽwnxqyq”zs“yr“{s“|t”~v’}v|t|t’{s—u™uŸƒyœz™~t›v¡‡z¡‡|žƒzŸƒ}¡…~š€y–|u”ys“{szrzr‘wpwpyqxpvp”ys‘vo“yr’wp‘wp‘wpun‘vo–|u–|u–|u“|t•~vŽwoŽvqwq’yt’{r‘zsŽvpyrŽvqxs–w”}uzr‘yq”|u˜~w˜~x˜~x˜~x“{u’zr‘zr—{t•zsvnŽwoŠpi‡jd†od‡qf†pe†ng‚ld‚me…jc‚i`…lb‡nd†ld‡mf„me†kd…kd„jc‚mbˆsg„qj‰smŠsl‰rjŠskˆqiƒpd‚pelb}j_|f^„jd‚i^ƒi`g_‚hb~e\~fZ}f_~h_~e]e^€f_ƒh`…i_ƒi^†k`€f_‚hb‚je‚ha†mcƒj`h^…l`‡maˆlf‡kd„ia‰mcˆlbˆkb‰nd‹pfŠoeŠmh‡kd†jc‡ne…kb„ka†mc„ka„kaf[‚f^…ib„haƒg`ƒf`h^~e[}dZ€e_‚g`‚e^€f_e]~fZ~fZ‚h`gaƒg]ƒg^€e[€e[dZf\g[g[ƒi^…j`ƒg]ƒf_ƒha‚haƒj`‚i_‚i_ƒj`ˆpc…nb„nbƒnc…mc†lc†mc…lb‰of‰pfŠpgŠqf‹pjŠpi‰ohˆnhˆog‹rhŠqg‡qg‹snŒto‹qhŠpg†qf„od†peˆrg‰rg‹qg‡qfŒtjŒtiŠqg‰qf‹qg‡sg‹tirhrhŒqgŠrgqish‹rhŠti‡tg„sf‰ujŠti‡qf‰of‰pi‰mfˆqc‰rdˆoe‡ndˆng†og‹pgˆndˆndˆmc„i_…i_‡nd‰peˆoeˆoe†oc…oc†peƒmb…odˆrf†pd…ob†ri„pd…qf„pe…qg…qf…qf‡rg‡qfƒmb‚mbƒod‚la„nc‚laƒldƒkc„le…pc„nc„nc„nc‚ma„ma€ncƒod†pe…pemb~k`†od…odlak`la~la€kc€ldldmb€la‚nclb‚oc‚obna€l`jb}h`jbmb€la€lbmb~la€ncmb€la}i^|h]|h]|h_}h`}h`}i]~l^|h_}h_}h`}h`lcjb~la|j_yg\|i\|i\}j]~iZ{fY~h[|h]{h^xe]yf^zg_|ib{ha{h`{g`vgZyi]veZwbXydY|g[{e_zg]veZxh\yh^{h`|h]yd\{f]{f^{g]zh\vd]zh_ze]yfZygZxfYxh^zi`ve\ueXueXvgWyi\zg\ydZxdYwdYwg[wfYucXxe[yi]xg^wf]vfYudXvfYyi\}m_pa†uj€pd€pc|l`wg[zj]zh]zh]yi]yi]yl`vh\xgZxh[zj^yi]yg_ze]{j^{k]vi[rgZuc[tbXudWveXvdXwdYygZyfY}g[€i^xeZzg\yfY|i\l`mb„pe€l`|ja€jb‚kc‚kc‚lezh_|h\wfYvdYveYwg[tdZucWsdXxg\~g]~haziaxh\ue[wf\ve\yi\zj]zj^xg[wg[wf[zh]{i^zi^~lama|j_xf[wfZ|g_yf[wgZxhYyhZzgZzeY|i]€m`€ma~ma{j^zj`ug^ui`vj`uh\yi[ui]tg[wi]|oa€qdsepcpcpcob‚qd…ug‡ti…rg„sgƒre€pc€pbpd„sg†thƒqg„sj„tl‰wlŠxm‹xmˆti…qfƒodod‚ofƒqi…rj†sj‡uj‡vkŒxnŽypyoyr‘zsŒvk†qeˆrgŠtiŒvkŒvkŠtiŠtiŒvkŽxm’{s“|t‘zrynŒvjui‹qhŽtmvlvkŠtj‰rkˆog‹qk‡tiŠujŽukŒsi‹tjŽxlumvo‘un’wm“yoŽxmuk‹tiŠshŠshŠshŠrhˆnhˆohŒrkŽtmŽtmunwq‘wp‘uo”wq“ysxqŠrj‹rkŽslun‘vn“vowltk‹qiwn’wq‘wp’ul’ul‘vlvo’wp‘zr’{syq‘wp“yr‘xq“wp“yr’xqvo‘wpŒrkŠpj‘xnunŠsk‹tl‰tl‡sl‡umŒuovpvp‘xrvpvnwp“yrvounvo“wo”zq’yp”zq“zq’{q‘zryq‘xq‘{s”|t‘zryqyp“|q•|r‚x¡‡{ |Ÿ‚x¤ˆz¤ˆz¤‡z£†|¥‰‚¨Œ…¢ˆ›€z’xqvoŽxp‘yq‘voun‘yqwn‘wq‘wq“ys–|u—}v•zt“yrvo‘wp“yr“zs”zs”}u’zs’ztwpwr“{vŽyqŒwn‹wn|t‘{t‘}v•~v•~w“|t“|t”}u•w˜~x—}w•{u’zsum‹ulŒokŠnh†oe‚l`†kc„gaƒj`„ka…lb…ke‚ha†le‡le‡kb‰pdˆpdˆof‡le…mg‰nh†le…le„me…ofˆrkŠtl‹qhŠph‡md„ma€jakbib{d]}c]€c^€d[d]e_e_g_€h_g`~g`g`‚haƒib…j`„j`…j`„i`…ib‡le‡ke„jd†lfƒh_ƒh_‡kbˆmc…ke†kc…kaˆoeŠoeˆlaˆndŠoeŒqfˆlf…jb‰le‡nf†ke…lb‡md‡kb†laƒi_…k`…jaƒg`€d]€d]€g]f\‚g]ƒf`ƒga„g`g`€f^~f[€g[„h`‚f_‚e[ƒf]€e[dZ€dZ€g]‚i\‚i]‚i_„j`ƒi_‚g_ƒic€g^€h]‚j^„kaˆneŠpd‡nb‡pd…mc‡mcˆmbˆmc‡mc‡pe‰qgriŽsh‰ohŒrk‹qjŠpgˆpe‰pf‰qe…ne‘xtŒso‰ph‹qf‡od†ndŠshŒrh‹qgŒrhŒriŒsi‰pf‰oe‹qg‰pf‹uhŠrgŒrgsiŒqg‹rgŽqk‹rh‰pf‡qfŠth‰viŠqj‡ng‰qiŠqj‰piˆph†mb‰peŠoeˆnd‡pe…qeˆpf‡od‡nd‰nd‰nd‰ndˆoeŠpg‡odˆpd‡pe†pdˆrg†pd…oc‡qe…pc†qbƒqc…qe‚nc„ofƒng‚le…qe‡qfˆoe…lb‚mb€mb†ma„ka…lcƒib„jd†keˆqh„nc‚la‚lak`‚lanb„odƒmb„nc‚mb€laƒmbla‚la‚nc€lala~ld~kc}jc|k_}ka~maldla~k^n`~k_k_€kciak`‚la~k`ocnc€nb|j_|h]|h]~j_}h]~i_iaia~i]€k_€j^~j^~j^|h\€m`|k_mb{i^zh]~k^xeXyfY|gX}hX~g[|j]xg\yj]yg]xf\yf]yf]}h_jazj^yh]xf[xf[zg\xeYzc^yd]xh]zj^}l`zg_zh\|j^{i^xf[xf[xf[yf_|h_yeZ|g]zg[wgZwg[{j`meve]tcYueZyi]zg\wcXr]SwdYueZxgZxhZweZwg[xh\xg]ucWucXxe\yg]~m`|k]{k`}mb{iaxh]yi\xi[xi]wh\xi]wh\xj]xi]|i\zh\zi^}j_zg[{dXtbVtgVpfUnhXvbZwe[wfZ{j]yh[vfZvfYygZ{g[{f[yf[saXucVvcUzdZ|h]‚nc„pf‚rb…pb„nb€i^lb{h^|h[yhZxeZyf[yi]yh^xh\ugZyg\}g]{e^zi`xh[wf\tc[ud[yi]yj\yj^{j^xg\{j_{i^zh]}j]{k^}k_}k^xfZweXxd\vc[ueYxh\}i_~iaj\|iZ{i[{iZ{jZyiYve]te^qd\th^wk]{l]zm_zl_xh\}lcnd‚pg€pbpcnapcnapcƒod„peƒqd€ob‚qd‚tdƒue†uiˆuh†sh„sh€qe„qi‡tk‡ulˆsjƒneƒmeƒqf„qiˆun‡tmˆumˆvl†tj„qi‡sjŒupŒunuo‰uj‡sh„qf‰uiŒxn‹vlŠwk‰uiŠujŠvkyrŽyqyqŽxo‹vjuitjunŽumŒtlŠtl‹vm‹skŽtjˆvk‹vkujtjŽukŒvk‹umŒslŽrltivlŽxmvlwmŒsi‹rh‰pfŠqgqj‹phqjŽrksl‘vo‘un’vo’vp•xr“|t‘{s”xp‘un’vo“vo“vo’tn’xnuo‰oh‹qksmrmŽqhri‘vk‘un’xq’{s’{syqvounun’vo“xq’vo“wp“wpqjqjxmvlŒtlŒvoŠuoˆun‡sl‹tn’xruovp’xrzq‘xq’wq•zs“vp”xq”yo–zp”{q•|q’xoŽwm‡tl†tl†umyqxp‹umŽun‘xo“yp’yošu ‡{¢‚}¤…{£†v¥ˆy¥ˆ{¤…|£‡©Œ…£‰‚•|uunŽslvn—{t”xq–yr•zs‘zr•ys“xr”zt•|t–|v”{r“xrvotm”zs—|u“yr“|t‘zs’zt’{uws•|x‘}qzmzn‘}s‘}r|s•~t”}uŽwoŠtkˆqi‹skŒsl‹qk‰oj†nhˆpi‚kcˆjf‡kf„lb‚la…kb…hb†la‡mcŠpf‰mf†jcˆld‰mf‰ncŠpd‰qe‡nd‡mf†mg‡mh†mf†lejb‚me†ng‡md‹neŠmd†k`‚i]‚ga‚ic€hb}b^a]`\}aZ‚d_e`gb„jd€ia€f`‚jdƒib€g`…lb‡la…kd‚ha…ib‡kdˆkcˆlc‡lf†lf…hc‡kdˆkd‰le„ld‚lb†mbˆoe†maŠpc‰ndŠoe‰oeˆleˆkd‡le…le…le…lc…lb„j_‚h\„i_ƒh^‚g\c\€d]€c]e\}dZ€e[e_†ib…g`g`€g^€h\‚h\‚g^ƒf_ƒf_…ha†ibf^…jbƒia…k_†ma…lb‡oe…ndƒkc…ke…lcƒj_„k`ˆpeˆngŒpe‹qe‰qd‰ofŠoeŠmdŠoe‰oe†peˆrgsiŽsiŒrk‹qj‹qjŒsiŠqg‡of‰pe„nfŒsnŠpl‰oi‹qeŠpgŒsitjŽsiŒqgrhrhŠpf‡neŠqg‰sh‡pfˆsfŒsg‹reŒpgŒqf‹qi‹piŠpfŠqg‡qf‡qe‡reŠogŠpi‹pj‰sl‡ph†og‰oh‹pj‰oeŒrhˆqe…rc‡pf…odˆoeˆoeŒrhŒqgˆmcŒpf‰qe‰qeˆqeˆrf…od‡qe†pd…ob„o_„o`‚p`ƒoamb‚mf„mgƒmh‚nc…pe…ka„lb…odka‚j_„ka†kd„icƒhbƒhc…odƒmb‚laƒnb‚laƒmb€la‚mb„lb†ncla~k_ƒmak`€j`k`i_m`~jb|ia|iazh]}k`|j_€jd€kb}j]€m^l]}j[‚mekc‚la‚lala~mb}lamb{i^~j_}i^}i^~h]~g^~f^}e]€j^€i^m^m_€m_{iZ{k\{k\xg\{j_{i_‚ob{i[|g\{jY|hXk_€m`yh]zk_|l_vdYyg[{j]€k`‚nclayf[weZzh^xf[xf[yc]xc\vfZvfZyh\{g]|l`}na{k_xg[ueYve[weZyg\}i^{g\yg]yh\wgZwg\xg_wd^saZraYvfZyf[yeZxdYxeZxi]yhZ{j]vdXxh\yi]yi]ye[xc\yd]zf_yf[xfZwgZzh^we\wf\xh[whXsg[yl`xj^yh]|l`nbkc}g_~j_}i^}fZ€g[qeWreXqdWreWtdXwh[wj\xi]xi]zg`xiYvfWucXveZyc\yc\zcX{gZyi[|k`mb€la€odpbl]|iZ~i[~h\dZzaV|eY|g[{g]xc]zf\{g\xgZxgZxe[ve]zj^vfZzi]yg\zh]xf[j_laj_‚lak`xf[{f[|h^zf^yf^wd]raZuf\ve\wd\yf^ze]iayk^wi]rbYtdXvfXufVufYvh[sg]yjandƒod‚rf|la{nawh_yja|ldpc~naob~naobpc†qfƒpe‚peqerf€qe}rd„vh…tg†sfƒre‚qd‚md…ogˆskˆsj‡ri„pgƒqi…skˆum‰vnˆtlŠtl‚pi‚ngƒnfˆqiŽtltj‹ujŠsjŠrkŠrkŽuouosl‰slˆskˆtl‹snunvmtjŒsitjvl‘yn•xr’xqun‘uoŽtmupwlukŽsiŒqgvk‹vkˆvkŠvkŒtiŒtjŽukŽuksjvltk‹rhˆoe‰pgŒrltnŒsm‹smŽsm‘tn‘vmyn‘{q“~s”}r—~r”zuvosl‹rkvntmunŽtmsl‹qjŠpiŽtmŽtjtjŒrlŽtovp”yu“ys’xq’xqŒumŠtlyo”zs’xq”zs‘wpvoslunŽxpvnxpŽwoŽvnŠskvmynvovq‘wr“xq•{t–}u—}v—~s“zp“zp‘yo’|syqtmsmslul‘xm‘yoŽunŒrmŠslwl“~r’|q•s˜‚vš€vœ€vžv ‚xŸxœu‚| †ƒ|”zsunŒsl‘vq“ys•{t”zs•}r˜}syqŽxp“zr˜~wš~w—{t–|u•{t–x•~v–€x“~u•{u“xr‘xs•{t—|uš|v•tzoŽxmwpŽwoŒum‹sn†og‰oh…kdƒi`ˆlb‡lb‡lb†k`ˆmdˆleŠng†jb‰le‰ldŠndŒrh†oc‰pfŒqf‹qeŒqfˆme†lf„lf‡mgˆnh†nc†m`ƒi]„i`‡jd…hd‡jf‡kfˆke…lb…lbˆndˆlf†ib‡id‡kc…jc„gaf^‚f`ƒg`‚f_„haƒibƒib‰leˆjc†ic‡kc†jc‡ma„ka‡nd†lg‡ng…kd‡nb…mb‡obˆle…jcƒib†mf…mg…lgƒldƒldkcƒldƒld†nfˆlbŠlc‰ja‡k`ˆmb‰oc‰jdˆic…j`„i_h^j_ƒh^f]e^€d]e_~a\~f]g\ƒf]‡jaˆlbƒi^†jc…ia„h^ƒi^†m`‡maˆnbŠndŠmd‹ne‰lfŠme‹qfrfrf‹pf‰ndŠoe‹qf‡od†kc…pg‰qk‰qkŒqhŽsiqh‹pfŒqgŠpf‰piŠrhŠqeŠrfŒphqj‹rk‰skŒrl‹rgŠpfŒpfŠqgŠqftlŒpg‹pgqhŽtitj‹si‹si‡qfˆrg‰pf‰qfŠrf‹sgŒtf‡na‰rgŠqgˆpfŠoe‰neŠpe‰qjˆrhˆsh‡qf‡pf‡rfŠpiˆngŒri‹qg‹pf‰oe‡og…pdˆshˆti†sf†tg‰seˆqd‡ocˆpd‰pfˆoe†od†peˆrgˆrg‰sh†pe‡pe‡qe„ma‡qe„nbƒma…mb…ma…l`…l`†nc…m`†ohˆpgi_„l_„n_l^~l_~l_la‚ma„oc…of‡na‡nb‚kc…nf€lblajc|h_€obobƒndf_ld€ka€k^„j`ƒm_h\}i^ka€jb~ia~k_l]zj]}j_k`k_~l^|l\‚l`~g^€iaƒma„na€jb€l`€la|h]|h]~j_€la}j^zf\|g_}gb|f_yd`ziazh`~kc€kb~i^~h]{e`{g_~kc~lczg^}i_|h\}j]}j_~mb~k`|j_{k_yj^xh[}l_}k^€m`yh]wf[|l_{j]|j]~i[zh\xgZvdXve\zh`yha}l_}k^yf[ydYzcX{cXxa[{f]zgZ{hZ|i]{f]wf[xfZyf[wbXwbWzcYwe]vbZxc[xc[xd\xg^xeZxe^wd]ucWue[we]uc\veZwhXxhZudZwe]ug`te^sd[{jaxf^wd[ug[xj^yk_wi]|nbqe€od€od}jc}j^{gY~iYseXufYvg[ue[rbXreXoeWqcWvf[yf^wgZveYveYweZye^{g^{gZzh[|k_yi]wfZveZzf\zgZ{h[{hZ€i^ƒmcƒk`j_~i]|i\zg^yf^zg\zh\zh[xfYxd[ye^{j_}j`{j_{g\|h]yeZyh]}j_‚lak`}g\|h]{g\}i^yg_|i`zh_tb[td[sc[ve\vd[vbZwd\ueYueZwg^scXwg[xhY|l_{k^zkb{ja}lb~l`}ma~nb}nb{nayk^yma~n`€pc€pc~na€pc€pc„peodƒqf‚rerfrfsd‚sf…tg…sf„sfpc„pe„qfˆujŠwl‡ti†rg‚phƒph„qi‰vo‡rj‡rjƒpi‚nd…pgŠtiwm‘xnŽvoŒum‹ulˆqi‰rk‰rk‹qi†qhˆskˆtlŠtmunŒwm‹ujŒvkŠtiwm‘xn‘wp’xq‘wpŒrkŽtmvoŽxnwnumsjulŽwnŠwlwlukvlŒtjˆrg‹ojŒrkunŽtmŠoi‰ogŽtntnŒtmvo’vo“vp‘vnwnyozp•}t”yq“yr’xqŽtmŒqkvovovounŒrkŒrkŠqh‰ogtiŒrj‹qjŒrkuo“wt’yt‘ysxqwoŽwl“{p“xr”zr”zs•{t’xqvo‰skwnŽwpvnŽxpwoxqyrŽym“xr“yr”yu”zs•{t—}v™x—~u•|q•{q”{s”}u’{tvoŽtnŽtmvm“zp’younrn‰qjvo‘zqyp‘{q”~s–~u—~v›w™}u™}u˜}t—~uš€x—~u“zqwnŽtlunvo’xq“xr’xq”zs“zs”zs—}vš€y—~w–~v—}v—}v™y˜‚z™y”~v–|vvp‘xs“yq“xq’vowl‰rh‹si‰pi‡le„icƒjd„ib‚g`„ha†k`ˆlcŠoeŠoe‡lcŠoeŒpiŒqjŠphŽslpjŒoeŒrhˆoe‰pf‰oeŠpdˆnc‰of‡mgƒke…le‡lf„ka…k_…k_†ja…ib‡jd…hc‡ke†jb‡ka‡lb‡lc‡kdˆleˆleˆme‡ld‡kd†jc†jc‡kdˆkdˆleˆng†kd‰mf‰mfˆkd„ha‡le‰neˆmc‡nd‰ni…kd„jc†ld‡ne†ncŠnfˆle…le‡mf‰oi…lg‡le‚f`ƒha…jc…jc‡le†md„i_…i`…h_‡l`‡ma…ha„g`…ja„i`ƒi_‚h^„i_€f[€d]‚f_ƒh`„haƒk`…k`ˆkb‹neŠmfŒpiŠnfˆmdˆmc‰nd‹qeŠpcŽqgqh‹pf‹qgŒqkŠphshŒtgsirhŽrhrjŒsi‹rhˆng‡ngŒtlŠtlqhŽsirhrhŽsirh‰ph‹qhŒthŠrfŽriŒqjŒsl‹tlŒrlŒtisisiŒtj‹sirgŒqg‰oerhŽsiŒsi‹rhŽukˆrg‡qfˆnfˆnfˆoeŠrfŠrgŠqg‡qf‡rf‡oeˆqgŠqg‰oe†qe‡qfˆrg‡qf†pf‰siŠpi‰ohŠqh‡oeŠne‹pf†me…mb†ndŠti…qdˆsf‰ti‡sg…od†qf„ne„oeˆnd‡ndˆndŠqgŠqgŠpg†qe…od†pe…od†pe†peŠrf†nb…ma…ma†nbˆocƒleƒkc‚i_ˆod„m`k]~j]l^k`ƒmb‡qf…pf†m`„k`ka„mf€lak`{f^{g^nama€kaiaƒja‚ka€k_}h]j^€i]~i^}h_}h`~ia~k_}j[|k^j_€mal`m`€n_~g\|e]€kb~l_~l_}ia€lak`}i^~j_k`l`|g^}h_|g_}i`}gayd]yg_{i`ld~ia}h\|eZ{e_ze^|hazg]|i^k`~j_~j_}k`€nb€nc€mc}nbyi]|j_}ja{i_|i`zh]{h^yi]yh[zh[~h\zh[yh\yh\yf^yh_xf^yg]zi]ye[{h]|f\zfZwb[zf\yf[}k^~jb|hawh[wdZyf[yeZzdYvaVubZubZzf]ye]we]wf]{g[xf^wd\xg[xhZzh_yh`vf[wgYvgYve[xf_wf_xg`wh_xi`ue[xh^wj]ug[vh\wi]xj^{mapa€re…sjoe|h^|i\weZvdZxe]uc[td[reYncUpcUtbYwb[ugZufXvfZvfZxf]yg^zh\yi\vhZseYufZudXxc[ye\yfY|i\}i_†ng…qh„qeƒpc|k^{i^ubZweZweYzfYyfYyd[~h`{k^}l_}k^}j]ygZ{fYufZwf[k`€k_}g\}g\}i^j`}i]ld~jb{h`vf]pbYraYsbYvd\ye^whZzi_{h`yg^{i]}l^yj^{k]|kb|kb{j`|i^|m`oc~nb}n`yl\yn]|mb€qe€oc‚pe€odocmb€ncodqe~nb€pdqe‚sf‡uj…sg‡uj…sh„thƒsg‚rf…ti„thƒsg‚pe‚pe‚pe‰uj‡sh†qgˆui…qf…peŠthwkwlŠsmŒtmŠtkˆqiˆrg‡rg‹rhˆsh‡rjŠumŒwo‘wpzoynŠwl…pe†rgˆtivn‘xqvosltmxowq‘xrŽun‘wpŒslˆskxlŽwlŽuktj‰ti…rf‰qk‡oivpŽuo‹slŒtoŽvnum‰skŽtmtm’vo‘vp“yr‹vnwowp’xq“yr’xqunŽtmŽtmŒrkŽsosnŠpiŠpiŒthuhŒskunŽtmŒrlŒslxrws”{v’{s’xqwlxl”zt”zs“yrun‘wpvo‘wp’xqwpvo“yr“yrwqxqyq’xq“yr’xs“ys“ys•{t˜~x—}v–|u–|u—~v–w–w’yr’xq‘wpwn‘xnvmuorn†oh‹tmŽvpxpyq•~u”~vš‚z˜€y—|v˜}v“ys“{p”{q”zo’xowmŽuj‘wn‘xn’yqvovpuo•yr˜|u›zš€y™‚z—x•zt“zr”zs“zr’xrvmsmŠpj†ogˆng‹pi‹nf„lb„kb…la‡kd‡jc…ib…ib„ha„ha‰odˆkbpgtjŠoe‰nd‹pfŒpi‹ohˆqk‡nfŒpiŠngrh‹qgˆpfˆndˆmc‹ne‰mf†leƒib…jdƒj`†kaƒh^…k^†jc†jc‡lbˆlcˆncˆnb‹neŠne†jcŠngˆmf‰nh‰mfˆle‰mf‹oh‰mfŒpi‹ngŒpi‰ngˆngŠng‰leˆle†jc…ha‰mfŠne‰nd‡nd‡md…kd†le…kd…kd‹pf‰nc‰mf‰phˆngˆng‰mf…ib…ib†jcƒg`…jc†rj†og„ka‰nd‡lbˆnb‡kd‡ke‡lb…j`‰nd‡lb†ka„i_†kb‡ke‡ld‡kc‡od‰ocpfŽqjŒpiŒqk‹peŒqg‹pfŒqg‹pf‹qfpgqh‹pf‰qg‰rhŠtjŽvjŒsiŽsisiŽqjŽrksiŒsi‹rhŠpgtk‹rkŽshrhŽsirhŽsitj‰oi‹qhtjŽvjŽuk‹qjŽumŽtmsmŒsi‹rhŒsiŒsiŠqgˆpfŒqhŒqgŽsiŽsiŒtjŒsi‹rh†qfˆsgŠoi†le‡mf‹qi‰qf‹rhˆshˆrg‡qf‡qf‡qf‰shˆpdˆpdˆpeŠpi‰piˆni‰ohˆnhŒsi‰pfŠoe‰ncˆme‡mcˆoe‹sh‰rf‡qd…og†ph‡sj…qh‚meldˆnd‰pf‰pfˆoe‡oeˆoe‡ph†og‡pg‡qh‡pg…of†lb‡nd†mc…lb‡nd†mb„meƒkc†lc„ka€h]€j^}k^}j\~j_€mbƒncƒlb…la…lak_€j`€k_}i^‚jbja|j^}k_ka€ia„k`ƒj`h^{eY}i^{g\|h\~j`}h`i`k_}j[}j^{h]}ja~ka~k_~k^~h\}g`|h`~l`~nb|jb€lbk`~j_}i^}i^}i^~ia}iajbib|g^|h]zh`|ia{ia}i^}i^ze[|h\zg\}k`}k_~k_|j\|g_~i_mb~lamb}k`|k`zi]|i`~kczg`zg`zh^{h]wg\yg\xgY|fZ{i\}i_yg\yg]{h`zh_vg^xh]wg[xh\vdYyg\wg[yi]yh^zi`{ibzgaucXvdYveZzeZzf[zeZwe]yf^xe]{g_yf^xg]{hZvcZxf[xhZyj\yi^xf_vf[zj]yi\wg[ve\xe]xf^xg^vh_qeYvj]zjaxh^yh^zj`xg^zk`{p`sd€qh|kbxf^xe[ucXucXtbYuc[sbZqcYncUrdWveYxf]vh[uh[rdXueYueYvfZyi]vg[seZreWtfXweY|g_{g]|i\|i\|h_~jalc‚mcnbna{j]|i`yeZzg[k_}j]~i`|f_yh]xf[yg\|h]yeZwcYufZwf[{g\ƒlbk_~h^|i\|h]~j`~j`{ia{h`zi`wf]saXve\xf^|i`}k_}ja}ia|iazg_yf\yh[{j^{h_}jb|ka|m`}nb€oc€ob‚rdqaxm]xl`~ocmbod€oc~ob€nc~lamb}maococ€pd‚rf…ui…ui‡uj‡uj„tgpd‚qeƒsgƒsg‚rfoeodƒod‰uj‰uj‰ti‡sh†rf†pe†pdŠth‹vj‹sl‰rj‹tl‹ujvlŒvjŒsiˆsh‰ui‰ul‹umŽtnynynxmˆth†qfˆuj‰tlvo‘vounŽunxpŠtnŽvpwqslŠsk†qi‰shŒukvmŽuk‹uk†rh‡oi‰rkvpŽwpŽvpŽvoŽwoŒsl‡mfŒrkun‘wp‘wpzqŽyq‹vnwowo“yr‘wpunŽtmŽtmŒrkŒqmrmŽtmtlŽvk‘xm‘un’wounŽtmuotn‘yu’zs‘zr‘wp’yovk‘wp“yq‘wpslŒrk’xq•{v–|v”zt”zt’xrup‘vpvptmŒvmyrxr’xr”zt•{u–|u˜~w–|u–|u–}v–w•~v•|u”zr’xq”zr‘xnŽukuoŒqmŽtn‘wq‘wqvo’xq–|t“~v•€x—‚z–€x•~v“zs‘xm“zp•|r•|r‘xn’yo“zq’yowp’xq‘wq‘wq”xq—|u—}v•{tyqvnŒqk‰ohŒrk‹qjŠqhˆod‡mg†kd…nfƒia…la‰lcˆnd…kaˆmbˆkdˆkdˆkd†ibˆkd‰mc‰ndŠpfthrh‹pf‹pf‹pf‹ohŠoh„mg…lf‡ke‰mf‹oi‹qhˆrg†mcˆleŠmgŠng‡kdg`„jc‡lcƒh^„h^…j`‡kd‡lc‰nd‰ocŠpeŒqe‹nhŒohŠngŠng‡md‰pe‰mfŠngŒpiŠng‹ohŒpipiŒpiˆmf‡mf‡kdˆkeˆnc†kb‡kdŠngˆleŠmgˆoe‡md†le‡mf‡mf‡me‹pf‹ofŠodŒpiŠng‹nh‰le‡jcˆkdˆkc†jbŒoh…rjŒvm‰ohŠoeŽsishŒpiŒpiŒqgrh‹pf‹pf‹qe‰ndŒqgŒqg‹oh‹ogŒsgŒrgriŒofŒqiŒrjŒofpgŽqhŽqhririŽqhŽritj‹rhŠtiŠujŒsi‹rhsitmskrksiŒsiŒsiŒsisititjŽsitjrhŽsirh‰oi‹qiŒsiŒuhŒtiŒsi‹qkŠphŠoi‹rhŠrhuk‰shŠqgŒsiŒsi‹pfŽsiŽsi‹rhŠqgŠqg‰sh‰shŒrk‰oh‹qi‹qiti‹qg…od†peˆrg‡qfˆrgˆrgŠse‰qe‡nd‰oh‰oh‡mg†leŠpi‹rh‡nd‡lbˆmcŠng‰oe‰pfˆpe…nb‡pd†mf‡mf‰ogˆngƒib‡mf‡ndŠqgŠqg‰pfˆoeˆoe‡ph…of†of†of‡pgƒmd…lb‡nd…lb…lbƒj`„k`ƒle‡ng…lcƒi`i_i^~h\m`~j_k`ma€lch^j`k`ƒma‚la€j_haja{j]|k]}i`}g_€g]j_|f[|h]{g\}k`~j_}h_}ha~ja}j^l]i]xfZzg_|i`}k`€h^k`ib~jc}k`}l_|jbj`~k_~j_{g\~j_}i^|g`jb~ia~j_k`l_}ja{h`|h^~i^|i^}j]~j^{h\{ia{h`}j_~j^|g_jb~kd|k^|j_{i^zh]{i`}jbzg`yf_yf_zg_zg^zj^yg\xfZ{eY{g\yfZ}h^zh]zg_yg^wg^ue\wf]vfZwg[vfZwg[xh\xg]zi`yg`vd]yg\zh]zh]yg\yg\{g\zg_xh_yh_xg^xg^we[zgYtbYwdZxgZugWwf\tb\ve\yh^yi]vfZvfZyf^wc\we\uh[th\si\xh_zi_xh_xg^wf]zj`vl[vk]xi`vf_wd]yf_sfXrdWqbVtdYtb[udZteZqeWreXvf\ti]sf[reYqcWrcWqbVscWrcWtfZseWueXxfYwf[xg[xh[zj\wi\wg]~g`ycZ|g[~i]j_‚mb„la‚k`‚k_~l_}j`{g`xi^uf[we[wf\we[ye[scZvc\ze^|h`~jb|i`~g\i]{g[{g[yf[|i_zf^ye]xd\ye]|h`zf]j^€kald|f`zf_xf\xgZ}k^~ia€ldnc}ma~pdpdƒod‚pdre|odtl_wj]}k_€la~k`}na|jb{ia€nf|jbmeoh‚oc€oc‚re‚sg…th…sh„reƒpdƒpc„qd…re†tg…rg‡sh†rg‡sg‡qf‡qeˆpi†pf…oeˆrg‹uj‹tiŒul‹ukŒvj‹ujŒvkwmŽuk‰ui†rh…qfˆsjŒslvlwl‹si‡qf„pe‹vkˆtmvn’vo’voŒum‡sk„nh‰slŒtlŒtkˆthˆui…qjŠtltm‘wpvovnŠsk‡ph‡ph‰qi‹tlŠskˆsj‹sjŠogqiŽtk‘wovpŽxqŒwpŠun‰slun‘wp‘wpŽtmununvosmvp’xq’xp“yq“zq–ys”xpvnvo‹tlŒunŽyqŽxpŽwo‘wp’wotm‘wp“yr‘wpŽtm‹qj‘wp“zt”{u’ys‘wq’ysuo‘vrvoslŒvkyqxq“xs”zu•{u•{u•{t”zs‘wq•}u”}u”}u–~v–}r•{u•{s“zpwmuouq’xr”zt“zq”zr‘xn“zp‘{q’}t“u{r“{r•zq–}t˜v™€w˜~v”{r“zq—zs–zs–zs“wp“wprk‹sktmun‹qj‡ng„me…jeƒjc„jc†kc†j`ˆlb†mf‡le‡ohŠpf‰oeŽpgsiŠneŒqgŠpiŠoh‡mf‡kc‡lbŠoeˆnd‡na†pdŒpfŠoe‹pf‹pgŠng‰nf†mh†mf‰lh‰ng‰piˆpi‡rg‡of‰lg‹mh‹nh†jc„j_„j`ˆmc†ka†j`‡i`‰mf‹of‹qeŒrfrhŽrjqkŒpiŠngŠofŠoeŠoe‹ohŠngŒpi‹oh‹ohŠngŽqi‹ohˆng†kd…ibˆkd‡nd‡lb‰mdŠngŠng‰ldˆkeŠmg‹ngŠneˆmcˆmb†mb‰nc‹pfŠoe‹ngpi‰mfŠngŠng‡leˆlfˆmfˆqjskŒqjslujŒsiqjŒoitkŽsitiriŽtgtgrhŽsirhŒqhŽrkŒpgŽqipgujŠshŽrgŒpesjriphŽqirk‘un‘vl‹rhsiuiŽsiŒpfŽrkŽrktmŽrlŒsiŒsitjŽshŽththtjŽsi‹pfrhshriŒok‹ni‹qhŠrfŠqf‹shŠpiŒrk‹pj‹rh‰rgˆrgŠtiŠuj‹rhŠrhˆpfsiukŒti‰pf‰pfˆshŠtitkŠqiˆoeŠrgŒsh‡odˆmd‡neˆqfŠth‡rgˆrg‰qf‰pf‰qg†nd†me†mcˆng‡mf‡nd‡nd‡la‰nd‰piˆqf‰qf…od„oc…pd‡nf…lc‡od‰odŠqfˆpe‡qeˆrg‡qfˆrg†pe†pe„nc„nc…od…od„ncƒmb„ka‡nd‡nd…la„la†mbƒle‚jbgag`f_i`i^€j^€j_k`k`€lc~g`ja‚l`ƒma‚k`€j_ƒjci`{j]|k_|h_}i_}h\~i]{g\|h]|h^j`}j^ja€kcldk_~l]i]yg[{ja{ja~kcj^lb~ibickaka€hb‚mc‚nc~j_}i_k`~i_{hb{ha}ja{j^|k]zj\}i_|h]|h]~j_m_}k_€m]|i_zga}ic|iak`~haicldzh]{h^yi\zf^|ha|j`{h_wf[xh]zg_{h`{j`|i^zh]|f[zf[yeZ}i^|h]xg[zg\xf_xf^we]veZvdYxh\zh[yfZxd[xe[zg[xeYweYyg\xf[{i^yg\vdYub[ve\te\wh_yh^xe]zgZvc[xe^xgZvfYve\vd]vf\zi_yi]wgZwgZwe]ud[vfZseZsgZqfYxg^xg^wf]udZve\vf\vj\ug[vf]xf_yg_xe^qeVsfXpcVufYwc\yg]ug[rgYqdXsfZocWnbVobVpbVn`TqcWueYueYvfZwfYvdXwdWudXufWtgWtgWthXqeXyb[ycY{eY~h[k_…pd‰nd‡nb‚ma~k_{j`xg^td\tc]vf_zha|jc}kdzg_ye]yd\yd]zg_wf^}g[|fZ{g[|h]}i^|h\}g_~g_{f]~ia|g_zf]~h\€i`ib~hb{f_xf]}k^l_ƒleƒng‚pf}ocpdncƒnc‚nf‚qi{mewncyj`kb‚memeoe|lc}lb~md|h`€melc„pgof€qg€qh„ri‚og‰vi†tg„qd„qd„qe‡tg‡sh†rg…qf…qf‡qfˆqf‡pi…mf‡ohˆrjŒvlŒxmŽxlwkŒvk‰sh‰rjŠskŒshŠti‡sh†rg‰sjŒqk“vlvltk‹ti‡qf…pe…rjvnsl’vovo„qiƒnfˆrjŠtjwkŠvi‡ug„sj…qium‘wpvotm‰ui…pf…pe†qf…qf…pe…re‰rgŒqgrh‹rg‹siŒtnŠtmˆrlˆrm‹sntn‘wpvounŽtmun“xq–|u–{t•{t•{t‘wp‘wq–ys“vquo‘wpwo‹vnŒynznŽwovo“wrtovo‘vp‘wpvoslsl”wr”wr’up’up”wr“vp“yt’xrvoŽxnŽxoŽwouq’xs“ys•{u—}w’xq”ys–}w”}u•~u–t˜u›zšx•}s•{s’xq’ws”zr”{q’yn’yo“{p“{n“{q‘|q{p‘|qxm’wm–|vš€y›z›z–{uvp–yt“vq’votmrhŠof‡og‡ph‹qj‡mf…ib‡kdƒhd†lf†leŠmf‰nd‹od‰oh‰oh†pe‹rhŽtjŽririŽqhŒqhŠph‡ph„nfˆnc‡mc…lc†nb†qe‡pd‰oe‹pfŒqgrh‹ohˆleˆnh‰niŒpj‰pjˆri‡qj‡rfˆqh‰mhnkŒoi‡kd‡lb‰md‰nd‰mc‰lc‹mfŒphŒqgŽshukŽrlŽqlŒrkŠpiŒpjŠodpg‹ne‰mfŠng‹ohŒpiŠmg‹qjpjŠng†le†le‡jd‰le‰oe†mcˆmc‹ohŠmfˆkeˆkf‹niŠmg‰nd‡lb‰nb†ob‰mcŒqgŒofphŒohŽrk‹ng‹phŠng‹ohŽrjŒrlpj‹ngtmukŒtjŽpjrktjukukŠtiŽtivisgŒqgrhŠpepkql‘smriwiŠsfŽsgqfriri‘slŽqjsl’uotkriritiriŽqiqjrl‹rl‰qk‹qj‹siŽsiŽthŽshŽsgukŽsiŒrhtjriŒqg‹nj‰mf‹qhŠrf‰rf‰sg‹og‹qjtmŒsiŠsiˆqg‡rfˆrg‡qf‹qg‹rg‹shtjŠpg‰pfŠqgˆrgˆsh‹rh‰qfˆodˆpd‰qd‡ob‰nd‰ncŠoe‡nd†mc†peŠoh‰ne‰nd‰ndˆmcŠodŠpi‡mf‡neˆne‹oeŠpfˆph‡qf„pd‚nbƒqd…re…qe„pd…re†re…rd„rc„pe†rg„pe…pe„peƒodƒl`ƒmaƒmak_€j^ƒmb„kc„jc†le‡ng…kd†kd~h_~e^f_g`ib‚lc‚l`€j]‚k`~j_~j^kc€gaka‚la‚l`k_€k_†lekb~l`}k_~j`~i`zh]|k]~j_}i]h_g_~j_€lb€lc€kbmal\~g[~l_}lc|jbkdh_~lb}hc~ha€i_f\„hd‚nd‚mbma‚mb~j_€la|ic|ib}k`zi\{k[zjY|i]}i^€lal_}l_zi\j^}j`|hc|gczf_~i_}ga~hb|ia~kb}la}k_~ha|h`|j`ob{l\xiY|j`{h`{i`|j_}j_~h]}f^~i]}i^{g\zg\we[zfa{hayf^xe\weYyh[zh[}i]zfZwcXygYyfTweZvdYxg\zh]udYueXwd\wh_ug^sd[ue\uc[taVvc\s_XvdXueZwe^we^xg_wf^vfZtdVtdVve[veZtfYrdXsfYqcVvf\wf\ud[ve\ve\ve]vh\vg^xf^xe^ye^zf^uiZtgYrdWqcYtdXraVscWveXucWudWrcWqaUudXudXwg[xh\vfXteXrdXrdYqeYqdXmdUmaSueXvdXwfYwgZvd[tbZxe\{f]jbƒkd~kc~kaob~mazg^zf_}i]yg[xd[{h_}ja~la|iayg_zf[{eZ|d]e_~h]k_h]k_ƒmal_kczh^zi\yi\{h_we\{e_{h^}i^~j`{ib{ha~k_l_€l`‚ncndkd{lcyjb|jc€obocmama€mbƒpd…og‡oh„nhƒoh~kd|ib~jdleƒph„sepbpf‚sj†tj‰ukxlwj‡shld€mfng„qi„of…re‡pe†pf‰rj‹tlˆrj‰tl†sk…tl‡tlŒun‹voˆtm‡sk‡si‰rhŽrhŽtjŽuj‰sh‰ujŠxm‹wl‹wl‹vkŠvk‡ti…qf‡tgŒulŽtmŒvmŠwm†th‡rkˆsmˆsmŠvm‹vm‡sh„pk…pk‹snvp‘tn‘umtmŒrk‰oi‰nh‰piŠoh…ogˆpiŒpi‹oi‰pi†qi‹ujŒwl‹sj‹rktm”wr“yr”yr“wp“voumwoyqyq’yp•|r”{q—|r”|r“zq’zo’xqwp’yqŽwpzqŒxm‘vl‘umupxovntmun‘vo”vo‘yn“zq‘wq‘wq‘xp’yo“yr“xrup“xt’xqŽtm’xr’xr”zt–|v—}w˜}x”|v—y•}w–w˜}w™x™y™y•zu–|w•{u•{u˜~u–{u“yr“yr”{q•~p–|u•{u”ys’wqŽtnŠqgwl“zo”{q“{qunŒrl‘ukukŒsh‹si‰pf†ncŠoeŠodŒqg‰nc‡lb‹pfŽoe‰qeˆreŒqepeŒrgŠpkŠpj‰ohŠpiŒrkŠqgriohok‹oj‡mh‰oh‹peŠoeŠoeŠnfpj‹ojŠpiŠqjŒsl‹qjŒohŠleŠminlŽolŒmjokŠpkŒqjŠoh‹ni‹oj‰lh‰oi‡je‰lgŒoi‹nhŠoiˆoirf‹qfŒqitntlrh‰pg‹ph‰mfŠngŠofŠoe‰mg‰mfŠmg‰lb‹ne‹mdŠpe‰ne‹niŠlgŠnf‹pe‰pfŒqgsipgŒofŠmd‹mcŒnjŽoj‰ne‰qd†nd‹nfŒqirgŒqhpjŒpiŽrksgŒqf‹qerirmqiŽrkŽslŽrkslqkujti’vk‘ujukŠtkwmwmvlŒqg‹ohŒoiŽsjŽsjtjtjŽsiŒqgpgŒofrhŽsiujŽtj‘vlujtjuisgŽtgqjŒqhŠrfŒthŠsj‡oiqhŒqgŽsirhŽsiŒqg‹tmskriŽshŒthsh‹niŒokŽrkrhtjŽsgrhŽshtj‹pfŠpfŒpfˆngˆng‰oh‹qjsm‹qjŠrk†pd†qdŠthˆrf‰rj‹pkˆoi‡qg‡qfshqdŠmf‹ng‹nh‡mf†ng…nf‰ohˆoe…lbˆoeŠrfˆpdŠqg‡pe‡rg‰tg‹sgŠrfˆpb†oc„me‡ph…ph„pf†pi„phƒqf…sh†qf‡od‡qg†od„nc†od‡pe…od†peƒmb‚la‚lbk`ƒmb€kc‚meƒnfƒpd…pe„pek^~i]jajb~j_l_~j`k`k`mb€la€l`‚kb€ia€iah_…nfƒmd…kfjc|ic{h_mak]zi^|k`k`‚mc‚j`„la€oa€ob}l_}l_}l_|k^‚mc€la€mb~l`|j_}j_yj]|k`|ia~ia~j`j]~mb~mb~ma~kdzg_|ib~i_}k_{i^}l_na{l^yi`|k_€m`~k^|i]j`}jb€jbh`~g`ye]zh`h`~h_zh[{k^|m`|mb~lc}iakb}h^{h\{k^}ga|f`~ia}i^}j^|i\|h]|h]yg\xf\zh]xh\yg[{h_zg`xe^we\weYxg]xg]wf\uc[udZwf\vhZxgZzf[{g\weYtaXweZyf[wf[weZuaZwd\rbVrcYrcYrbZub[xd]wd\wg]vfYwhZsfYqcWsd[td[uc[uc[ue\uf]zi\wfZweZweZwd[ye^xg_yf_zj^yh^xh`wf`wj]xj]ug[te\ocWm_So`TqcVteWudWtdXteXwg[vfZxh\yi]tgZseXqbYpaXteXrdXncUqcVvfYxgYyh\yg\wg^tcZvc[yd\|g_h`{g`xe\zh\|k_~kblc}k_}k_zg_yg^xg]{k_|ib|i_|h]~h]€j_‚g`ƒmd…ne„nd‚kb‚kb€ka{g_{i_zj]{h\|g^~h`|e_€lb€l`l`}l_{i_|i_zh_}i`ja~iai`zg_{g_}ia}la€ncodmc}ja~lamd„pgneƒnd€kbmc‚mc‚nd„pf‡ug†uh„ri„ri†rhŠujŒui‰vi…qe‚meƒnfng†ph…qg„qd…ocˆqhŠsk‹tl‰skˆsk„qi„qiƒriŠsl‹vn‡tl…riˆth‰shŒtjŽwlwmŽxm‹vkˆsh‰uiŒwlxm‹wk‹wkˆthˆuivmŽunŽwp‹wnˆwk…rl‚qiƒphƒqi‡rk†rg…qj†rkŒtnŒtnŽtoun‘wpslŠpi‹piˆngŠpiˆqi‡nf‰oh‰piumumwlŽwlulŒrkŽsl’wo“yr“xq’vo”xqŽunŒxp‘zryp‘wq“zp’zp—|r–}s—}s”{q’xq‘wpun‘upŠvnŠul‘um‘tnuoyqxp’xqunvo“xq”{q“zq‘wq‘wp‘wn‘xm‘wp’xr‘vq“xt”zt“yr“ys“ys”zt•{u—}w—}w•~x–~x•}w˜~w–|u–|u™y˜~x˜~w–|u–|u—}v—}v—}v–|v“yr’yq’xn’xrvpŽtmsl‰oi†mbˆndŽtjŒrhŽsjŠoi‹piriqgŽrhŽtjŒrh‹qg‹pf‹pf‹pf‹pfŠoeŒqg‘rgŒsg‹thsgshsg‹pkŠoiˆmfˆmfŠohŒqgqhŽpiqlŽqm‹ojŠpjqi‹pgŒqjqjririqj‹piŒqjqjqjŠmfŠnhŒoiŽpjŒoiŒqk‰qj‹qjŠpi‹pi‹niŠmhˆkf‰mgŠmgoi‹nh‰nhŠqj‹qhŠng‹ngŽrkŽrhreŽri‹ogŠngˆle‰ne‰ncˆleˆleŠmf‰ldŒoeŒofŒqg‹ogŒpj‹oiŽriŽtjŽsiŽsiukŽripgŒof‹pdqlojŠpfŽrgŽrhqjrjtlŽsjŽrjŽriŽrkrhshvkuksmqjslsl‘unslŽrksmvk’wl‘vkwltnŽuksjrhŒqg‹ohŒpitirhuk‘vltj‹qfqiririqiŽrjŽsjtktjtjshŽtgŽthŽqkŒqhtjvlŒsjŒsmqfŠoerhuksi‹qgˆsjŽqiqhŽsiŽtiŽrgŒpjsmŽrkriŽsjsgŽriŽriŒpfqg‹ofŒqg‹pi‰ng‹piŠohŽslŒpjŒqjˆnc‰pd‹qeŒqgrk‹ni‰nh‰piˆpg‹rgŠoeŒoh‹ogqj‡ngˆng†og‰oh‰pe‡nd‹rh‰qeˆpdŠqh‡pe†pe‰sg‹th‡oc‡ob…oc†og…nf„of„od‚mfƒnfƒqgƒpe…qeˆpe†pe†pe…od†pe…od…od†pe„nc„ocƒmbƒmb‚laleldƒnfmb‚ncmb„mbk_€ia‚kc€la~k^k`€lak`€la€la}j_j_j^i^k`„nb‚la„kb‚ld~kc~jb~k`}j^€kdkc‚me€jb‚ld‚ld‚od€nbnbl`~l`~l`€mb€la€lb~i^~k`~k`}k^{h^}ia~kb|h_{i\ka~k`~k`kb|h`}ia~j`}i^~la~la~m`}m`zh`|h`}i^~k_{h_{ia€jajaj`~h_{g^zi_|ha|h^{i]{i]zi^zh`we^zf^|f_ze]{g]yh^|f`~ib}ia~j_{g\|i\{g]xe[weZzh]xg\vf[zh]yf\{h`zg_vcYtbWueYtdWueYufYwh[vfZui[vfYwdYxdYucWs`WudZwf\we\uc[uc[tbZuc[tc[sc[ud]wd^va\ubZwf[ueXxh[xg[tfZse[teZxg]wf\vg\wi^yg[xgZweZtbWvcYvdZyd^xe]yh^{j^{jbxg`vg\tfZvg^vf_qf[ocYmaTpcWvg[tgYvfZveZueYudYvfZvfZseYrdYsbYrcWueXwgXuhZugYweYvdYyg\xg[ve\vc[ubZxe]{f^{f^|j`xf\xf[xf[{i^yg]€ob|k^}kbyg_xh]zj]}i_k_€m`j_k_ƒlajb‚kc‚kc€iaja|f^ye]zh_}k^€n`„md‚kc‚idj`|i^~l^~j[|j[{hbxf_yg`~ia}h_i^}g_~h`h`}j^~ka€mb}lc}ld|k`}mana€oaƒnc„ncƒnc…od…odˆrg…qf†rh„og„og…oeˆrg‡ug†rh‚nc‚nd„og†qi‡rjˆsj†sf…reƒnd†ng†og…og‡rj…qiƒqi…rj‰tlxo‰umˆtj‡sh‡rg‡shˆujŒvkŒvkŽvltjŽtnvnvn’xq“yrwp‹xmŒwlwlwm‹wl†shrj‚pg€ofnf†rj‡rj‰sh‰rkŠskŠtn‹uoŒupwo‹tl†og‡og†ogˆqiŠskˆphŒqk‹qjtlŒvnxm“yp‘wpun‹qjslxptmtm’vowoŽwowqzq‘wp’xp‘yn•zp–}s—~t•|q”zs‘wpvo“vq‹rlŠrl‘sn‘vpwr’yr“yr•{tŽtmŽtmvo‘xn‘wp‘wp’xq”zswm‘wq‘wpvo‘wp•{t–|u–|v•{u•{u•{u˜~x˜~x—y•~x–|v˜}v–|u”{u™x™x–|t“xr•{t–|u–|u”ztupŽsnslŒrlŒpjŒqjŠnh‰pi‰oh†le‹oe‰ndŠoe‹pfŒoiŠoh’sjri‘ulriŽsiŒqgŒqgŒqgŠoe‰nd‰nd‹qgŒneŠpf‰peŒofŽpfrhŒoioiŒohŒoh‹ngrkslrksltmtmqjŒoj‹oiŒpirh‹pfŽtiqkŒph‹nhŽrkŽrkririŒpfpgrhŒrhˆshŠtjŠqjˆngŠng‰kg‹mh‹oh‹oh‹ngŠmfŠmfˆohŠpj‰ngŠnhŒofqgqdŒogphŠng‹oh‰meŠoeqkŒpirlŒoh‹nfpg‹pgqjˆmfqktmŽsjtjukukŽsitjof‹shŽrmŽqkŽqhthriqjŽrksltmtktjslqjtj‘vl‘vltitmtlsltm‘unslun”xo”zn“ym”zo‘xn‘wmŽsiŽsitjpjŒohrhsjtjukukŒqg‹qkslqjŽrlŽqjrk‘untmtj‘vlrhtiqjŽriŽsitktjvmriogŠpfŽsiŒsi‹rh‰shqgqhrhŒtjpgŒqhtjqjqjpiqjriŽqhpgpgpgŽqhrhŒqgŒqgritjŒpg‹pgŒqgŒqg‹pfrhŒqhŽpk‹ni‰oh‰oh‰qh†pepiqjŒpi‰oh‰oh‰oh‹qjŠqg‡ndŠqfˆpcŠrfŠqgˆqf…od‡qeˆqeˆoc‡oc…mbja…nf‡qg…od…peƒoe…qf„pe†oe‡nd†mc†od†pe„nc†pe…od…od‚la…od„nc…odƒmb‚mfld‚memblbmbƒmbk`k`ƒmc€m`€n`ƒnck`k`k`€j_€k`k`‚lai^ƒmbk_k`‡oc‚lc€ia~hb€kck_€kcjbjb|g_md‚me‚ncmb€k`€la€la€k`|l_~k`}i^k`‚l`j_€i]~h_}h`me|kb{l_€l_k`k`~j_ja‚mejb}h`~j_}k`nb~l`|g`}g`~ia}h`|ibzibl`l_k^zj]|k^zj]xh\|l`{j^|j_{g_}h`wd]vc\xd]wd\vc[xe]{f^{f^~haxeXydZ{g\yh[wfXyhZyi\vfYufXvcXuc[wd\ubZvc[saUrbUpaUrbVueYvdXsaVtdWtdVs_TuaVr`Up_UsbYve\tc[uc\we^ta\we^tb[saZsaZtb[wc]xe]xe]udWufXwgZueYsfXueXudXveXvfYuhZvdYudYvdYweZvdYxf[zd^xdZzh]yg\yg\xe^ufYugZtf[wh_rg]rg]pdZpdXuh\tfZtgYtgYsfXpcUqeWreWseYueZtd[xe[xg[{iZwi[yg\vdYye[yf]wg^xe]wd\wd\ubZxc[{f^zh]zg]xf\zg]xf\vdZxgZ|k_}ia|kb|ka|l`o`‚nb€la‚mcƒma€j_€ha~f`gagagb~fazf^{g^l_ƒoc†of„me„me‚kd€i_{h[}j]|j[yf_{ha|iblckaj_‚ha‚ib~g_|h]}i^|j^~kc~kb~nboc€pcqd…pd…oc‡qe…oc‚ma…oc„pf…ph„lfƒke†pf‹ujˆtjˆti†rgƒodƒnf…ph‡ph‡qh…re…re„pf‚me†nf‡qi†qi…oh†qi‰skˆtlŠumŠvkŠvkˆti…re‚qf‡ti‰ujŽxmvkŽvkŽun“yr”zs”zs•{t’yrŽyoˆuj‡tjŠwlˆshˆrg„sg‚rf€oc…rj†rj†qiˆrg‡qg…ph†qi‰sm‰sm‹tlŠsk‡ph…nf…nf‡qhŒrl‹sk‰sjˆrj‰pislvounslslvmwlxpŽunsl“xq‘vowo‘ysxs‘wp’xq‘wp”yo•}s˜u”{q“xr‘wp‘vo”wp’vqvp‘to‘vpŽypvo’yr”zs‘wp‘wpunvoun’yo’yo“yr”zs’wp‘wp‘wp‘vo”zr–|u–|v•{u–|v—}wš€z™y—y–}w–|v”zs˜}vš}v™x—}v”zttmŒqk‘wo‘worl†lh‰niŠpjˆng…i_†ka‡mbˆle‡nf‡nhsiŒqg‹pfŽsiqjŒqjqhsj‘tksjŒqgŒqgŒqgŒpgŠofˆmcŠoeŒqgpg‰pf‰oepgrisipgpgŽqhŽqjŽqjslslrkŽrkslslsl‹nipjqj‹pfrhŒrgpkojphqj‹qhŒtjŠrhŒrhŽsiŽsisiŒsi‹rh‹rgˆnfŠng‰nfŒniŠohŠmfŠmf‹mfŠoh‹ohŠoiŠohriŽrh’ti‘rgpgqiŒnhŽrkŒqhŽsitjŽsjŽqjpiŽqjŽqjpiqjsjsj‘tmsmritj‘vlŽrhtjtjŒuhqlqkrjsg‘sjŽsiŽqlpl‘to’vmvjtjŽshslukuk‘vlŽrlsl‘un”xq’vo’vo’up“wo“{o‘ym“zm“xnukŽsiŽsi‘tkŒohpirhqgŽtjuktjŒqgrlslŽrktm‘tmslsltmtm’wmŽsitjqjslŽrktjŽshŽtgripgŒqgrh‹rh‹rh†qfŽqgŽogŒqh‡pe‹qgriŽriqiqjŒpiqjtjsjririririujrhŒqgŒqgrhŒqgŒqgrhrhŒqgŒqgrh‹phŠoh‹ohŠpiˆof‰shpj‹ohŠngŠng‰oh‰ohŠph‡nd‡ndˆoeˆpd‰qe‡nd†nd†pe†qd‡pd†nb…pe…md†kdˆng‰pe†nb…od…peƒod„pe‡oe…lb†mc‡mcƒmb‡pf†qg…qf„nc…od„nc„nc…od…od€kdjb‚meƒoc€lambƒleƒmd‚lak^ob‚obƒmc€j`ƒmb‚l`kaƒmbƒmb‚la‚mb‚ma„ocƒmb‚l`€i`€iaic€jbmbiajbjb}h_€kcjb€la€la€lak`~j_k_€lej`€la‚la‚l`ƒk_‚j^ƒjbƒld~iayh^{k^~k^l_~j_{h]~j_l`€kc}h`}h`~j_{i^yh]{g^}ha}ga}gaxf^xh^~k_{i]|l^zi\yh\yh[wh\zj^yf^yf^|g_{f^wd]xd^vc[wd\wd[xe\ze]|g_|g^{f^yeZzf[yg\yg\xe[xh\ueYwg[s`Xvc[weZvdYvc[vb[scWrbVueYwdYp^SucXvfYtcVvbWvbWsbWsbYxg^ve\vd]vd]ve]uc]we^vd]ub[vc\vd]tb\wd\wd[veXveYtdWscWreXveXucVudWwfZvhZweZweZweZweZxfZvdYwbZxdZweYxf[yf]yf^qdUugXxl^xi_wkawkase\re[rdWobVreWseXrdWqcUreWtgYzg[zg[yf^yf^vdXucWwgZzh]yeYwbZwd\xe_{h`zg_xe]wd\wd\wd\weYxe\yf^wd]ubYtcW{fY~i]€lc‚nf‚neoeƒnb€mbjc‚le}i_j^~g_~g_h`€ia€iah`iai_mal_€lc€ld„mbƒkc€ib~g_~i^~k^i_€kb€ka|i`}ha|i`~jbia}h`}i^}i^}i^maoc„qeobococ„odƒod„oemc€mbƒpeog‚ng„lfƒke†pfˆtiˆvkŠwlŠvk…qfƒod…odƒle†of…pd†sgƒne„nf…pg†og…og†ph…og„nf‚pf†sgŠtiŠuiˆuh…tg„qf†shŠvkxmxmzowoŠumwoyqzryqŒvo‡si‡th‰vjˆsjrkŠti‡rg…pe…qf†ri†rj…qh„ohƒne„oh‡rj†rhŠrkŠsjˆqi‡ph†nf†og‹qj‰qi‰rjˆqiŠrjslununslŒsjwlynxpxp’vo’votmunwrŽwquo”zs’yq•xr•|r•|r“zp’xq’xq‘wp—zp‘xowp‘tntk‹ujsl’xp“yr“yr“{szr”zs’yp’yo“zp’yp‘xq’vo’wn“xm•zo–{r™}v˜~x—}w”zt—}wœ‚|ž„~›{—}w”zt“xp”xq’vp’wn‘ulriŠnf‡kcŠne‹pf‰meˆle†idŠmg‹ohˆkaŠmd‹ofŠpf‡nfŠpiŽsitksi‘ulslŒpiŽrh“wn“xnŒqh‰pfŠpfŽqkqj‹ohŒpi‹ohqlpfŒrhŒrgneŽqhŽukŽrhripgogŽqiŽqjŽqlqjrhŽshŽsiŽrjriŽsjŒpi‰ngriŒqipk‹niŒpi‰ohˆsh‡ui‰vk‰sjŒriqiqiqiŒpfŠneqg‹piŠohŠoh‰pg‹ofŠldŽng‹nfŒogŒoi‹ogŽqh‘uj“tkphqhpisl‘tmskŽuktjŽsiŽqipiŽqj‹nhŽqkŽqiphrj‘tlŽqkŽqhŽqhŽriŽsiukukrgpkojŽsjui‘tktjpk‘to‘tn“wnwhŽtftiŽrkpk‘tntkqjtm’vo‘un‘unum’tpvmwkxlwk‘vjŽsitjsjriŽqjqkŒpf‹pfŽritjrhŒqgŽrjqiŽsj‘vmskŒphpjqjŽrkslŒqgŽsislsmtmŽskqgŽsesiŒrhŽsiŒqgŒqg‹ofˆpdqgri‹qg‰qhripkqjŽrkqiŒqhrgŽujsiŽtjŽtjukŽtjsi‹rhŽtjsi‹qg‹qhthshqkŒpi‹qg‹reŠrh‹sh‹qfŠpd‰peŠrg‹oipiŒpiqj‹ng‰ng†le‡ndˆoeŠqg‹rgˆpd‡nd‡oe†peŠsgˆqe‡oc‚mb†meˆngˆng‰pd‡nb„nc…pe„oe…pe†ng‰mf†le…kd„me…nf„ogƒnf‡qf‡qfƒmb…od…od„nbldjb‚me‚ncmb‚nb„mf‚lb‚l`‚l`l_‚obiajbƒleƒkdibƒlcnaoal_nal_m_j`€g_ƒice]}i^‚ocm`~l`~k^~j^€k_j^~i^€k`€k`€k`€j_€k`‚ldjc€j_i^‚l`l_‚i]h_h`~jb|h_|j]~i]}i\}i\~i^j_}h\g`|f]{f^|g_yf[xf[xg[{g_}h`|f_yf]zi]|h^|h_yi^zj_yh^yg]yh\yg^yf^xe_wd]yd^{f\zf\yg]veYzg[yfY{f]{f_wbZwcZyd\ze\we\vf[ueZvf[tcYsfZwc\tbXvdYucXwe[vc\ueXscVudVtdVtaSvbUwfYvdWxdYwcXudXsd[we[raWuc[vd\taZuc[ud\we^taZxe[uf[seZwbZvdZudWsbUvdXwg[wf[saWubXzf\yh^ve[vcZwdZyg\xf[weXxgYyd]ucYveXxgZyi]vf]ugWvhXxk[xi]xkbvg_sdZqaYn_TqaUqdUreWrfWrfWrfWseXzgXwdYzf[vc\vcYqaUueWzg[|h\ze]vd\vc\yd\yf^wd\zg_yf^vc[xfYvcYs`XvbZvdZvfX}fZ€k^€ja‚ldlb‚nb„nc‚kdkdlf}ha|h^~g_h`jb€iahaia‚ga‚h`€i]~k^lc~kb‡oc…mdƒke‚jdibk`‚k_ƒnak`|j^{j`{ia{ka}jb~kc€lak`ƒmb„na„oaƒpcƒpc‚od~lamcod€ncmb€ncƒqeƒri„pj‡pj‡oiƒne‚pd„qi…sh‡sh†rg‡qfƒnc„me‡pgˆrfˆtg†qh„qiƒnf„nf‡ph†og‡ph…og€ma…qeˆshŠuiŠwj‰xkˆthˆti†rf‰ujŠvkŒxl‰tl†qi‰tlŒwoŽyqŒwoŒtm†ri†vh‰wkŒukŽulvjŠrf‡oeˆrg…rhƒph„qj‚ngld‚od…qg‡pg‡rjˆtkˆtk„ogƒmfƒme‹oi‡ngƒnf…oiŠqjŽsl’uounŒrkŒriˆthŒvk‹unŒslŽrk‘upunŽtmwqŒtnŽtn”yt’xr•yr—~t“{q”{q’xrunvn”ylŽwk‘xp•xp”xn’ym‘vn‘vo“yr”yrzq‘{s”yt”{r”|p“zo”zq”zs•xq’vo”zn—}q™~v›y‚|—}w“ys”zt”zt–|w“ysunsm‹oh‹ohˆmf‰nd‰nd‡laˆmcˆmcˆmbŠpb‰odˆleŠngŠngŠogndpepgŽsi‰pg‰oish‘sjrhpg‹ngŠmfŒqg”xnsi‡od‰pf‰qgŽrkslqjslŽrkŽrkrjuntm’rlslumŽth‹qd‹pfŒqgŒph‹ohŽqlsksguisiqjŠpeŽsi‹qfŠngŠnhŠlh‹mi‹mhrk‹rjŒyn‚t‘y‰um‰qjŽpjphnhqhpgŽriŒsiŠrjŠsksiŽriqh‘rhŽofŽqh‘qk‘ri‘shtj‘tl‘rm’rh‘qjrk’untkŒsiŽsirhŒofŒohpiŽpjŽpkrjshŽqgŽqhŽqkŽqiqhriŽsiŽsiŒsirgŽpkŽqlshvjŒujuksmsnsm“xnwgŽueuhumŽrltnŽrlŒphslsltntmŽrk‘rntlvjvjwktiujŽrhsjsj‘qmŽoi‹ofrhrhŒqgŽsirhŽqhŽphsiukŽuk‹rhŽqlŒoiqjqjrirhun‘tn“vpslqfŽsdŠti‹sh‹qg‹pfŽpgŽqg‹rgŽqf‹mdŠpfˆpgŒpiokqkŽrlrhŽthŽth‰pgŒsj‹rhŒtiwm‹rhtj‹shtjŒsiŽtj‹qg‹uiˆrf‰rj‰rj‰sg‡qeˆtfŠsg‰pd‰mb‹qeŒsgŠph‰piŒoiqj‹oh‡kdˆnf‰pf‡ndˆpeŠreˆpd†mb‡pe†pe†qeˆpe‹tf‡qg‰piˆmgŠoh‰od‰ob†nb‡qe…qf†pe…leˆmfˆleˆmf…nf„meƒnfme…od„odƒmb†peƒmb„nc‚leldƒnfncnc‚nd‚id‚kb„nc‚m^€m`naƒld‚lcƒld€iaƒld„md€m`m`nana}j]l_jc„jc„gb€g_j^}j[€pcoa€m`naƒl`‚k_k_k_‚l`€j^€j^k_‚jbhai^i^n`~k[i]i_iah`~i_|i\~i[k^~h[€j^i^~h\}e`}f^{e]{g^|g]xeZwi\wfZze]{f^zfZ|i]|f_vd[yg_xi`wf^yg^xgZvcYwd]wc_wc]wd]ydZwdYwg[vfYygZxeWyeZzf[yd\ze]xd[ze]uc[vd\xf_tb[td]rb[xe]tbYtcVveXsaXxd]vfYvfYudWweXxdWydWzh[ygZyeYxdYwfZse[ucWsaVtbWucYvc[zg_td[tbXvdYucXugYrfYyc[wbYvdWweYxfZzj^xg^yh_yd]}hayg_yh_xe]wd[xf[yg\xgZzi\xf]ueYxh\xi\wi]wg^}k^zi\we[vd[xdXubZr`Zs^Yr_VrdUth]ug[yh\vfYscWscVo`TrbWp_Vo^Uo\Tr`TveX{j]}k`~j^{f]xc[uaYvc[ubZzg_zg^wd]z`X}c\yc\~h`|ha{ia}f^ye]xf^{h`g_ƒf_‚i^„k`ƒmb…meƒle€jdjb}h`}gah`i`‚j^h^ƒi_j_}i^~k`€nc†oe†pe†pe„nd€j_€j_€j_€j_k`k`j_la€lf‚nf„ngmb‚mbƒmb‚l`‚la…od‚odlc€mdƒnb„oc†md‚mb€ldogƒrjƒri‚ph„qi‚nf…ph€ocƒoeƒod‡rj‰um†tl‡uh†rg‡rg‡nf†ng…mf~nb~nbƒqe†rg‰ti‰sh„ng„pi†uj‹yo‹{oŠ{o†sl„qiƒph…rk‡tl†rk‹ql‡oiŠrl‹upwqŒwnwkˆtk†qh‡qj‰qhrgŽsjˆqf…of„qj†qj†pj‡rgˆsg‡pg…nf„ke†ng‡phŠth‹ui‰rg„nc…mf„nb‡qf‡qfˆrf‰shˆshŠqlŠrl‰rk‰oh‹qjŽrlsiŽrhŽsitjvl‘xnyqŽwovo’xq“zr—{u–{p”yo•yo”yo“xm’wmvkumxp“zt–|r—{p”xo‘vm’voun’xr“xsyqyr’{s”}v’{s”}v’{q’{p‘yo—{q—{r˜|r”{vwqsl‹rj‹qhsi‹ri‰of†md…j^…j_‡ia‡nbˆld†id‰leŠmcŠpaŽqfŽrhˆpeŠpi‹mhŒmg‰leˆka‹ncŒseŠodŠngŠngŒpi‹ohŠngŠng‰mfqjtl‹qe‡kbŒpjqkŒpgrhujslslrmsl‘un’vosltltn‹siŠqh‡oe‹pfpjŒohŽskŽrkŽrj‹piŒpiŒpi‹oh‹oi‹oiŠng‰me‰mfˆng‹ogthŒvj}s˜†•ˆ~{s‰pkŽqlŽpj‹piŽqjŽqjuitisj‘tmshtjsjrkqlŽpkŽqjsmsl‘tmsl‘tm‘tkslqlrm‘tnskui‹rf‹qgqhrisiŽqirk‘tnqlpjŽqhtjsitjŒsiŽrhŽogŽrgŽrhphŒofŽsksltjŽriŽsjŽrk‘untlpl‘qlŽqjskŽrhŽsgojtluiujŽsjpkrkrjsjtjtitiŽrkŽslsjtkŽpfriŒpgriŽrkŽrkŽrj‘vlŽthŽthŽsiŽsitjrhrjŒohririŽrhŒrfslskujŽthrhŽqgrkŽrkŒohŒpkqj‡ph‰pfŠng‹mgŒniŒoh‰pfŠrjsjsiŽrgsjŒqhŠsgthŽrirkŽqjrltmŽrkslŽqjŽqkqj‰uhŠrhŠqgŒrg‰ofˆqhŠpdŠoeŠme‰ndˆre†tfqh‹pe‰pd‰qgŒqfŠnd‰peˆpdˆoeˆoeˆnf‡mg…nf…pg†rg‰rgsgrg†rg†sg„nc…od‡pfˆoe„nb†pd†of†og†pf†pd‡nd‡nd‡pe…odƒmb‚nc‡mc„k`„l_‡nbƒja…kekc„na„nb„ncƒm`„napa‚oc‚me‚kdk`ƒmb†le„ib„i_‚i_‚l^€m^m^}l`peod€k`„m^†mcƒk`„kaj_haja}lamb‚nclb€j_€k`}l^kb€jag_i_‚l_~k`k_k`}i^k`}j]g]~j^~k_xg_xf]{h_g\{f[{eZ{h\|h]|h]zf\{f^}e\}g^weYueWtaZve]we]xf[xfZzh[we]yf_zh]zg\xf[xf[yi]we[xe]zg`xc^xb]vdZxfZvdYtaVwbZycZyeZyeZyeZyfYxeXxeYtdWtdXve\saZta\u`]xg\vdYvdXtbVxcXvbXteXsfWtgWufVudYve[zj]vdYubZubZxg[tgYzf[vdYtdXueYxg[xeYzeYwcVtbWucXsdXtdZt`XucYweZxgZzj\zj\yf]we\ye]yg\yg\wfZvf]vgZwg[xh[ygZvfWyh`ve_we]yf_xc]vaZyl]wj\vh[seXtaUo`Vra[wd^tbYpdVobXpcWobUmaTl]TiYRgZPfWNgVOhWPjZQl[Qo_UrcXvf\yhauc\vd\vb\r_WtaZvc[xe\ye^ye[ye[xg]zi_{la|la|g`{f_wf]xd]h`ƒg_€h]€j^k`„mfƒnf‚lf‚md‚neic}f^h_k_…kb†mc„nc‚ncmbod…mfƒmd„ncƒmb€j_i^‚la‚la‚la‚la‚ka‚lald‚me„ogƒnd‚l`‚laƒmak_ƒmcmb‚ne„og„od†pe‡pe…peƒngle~lcnf‚og‚ogˆsk†phƒrg…rg†rg‡rj†rj†sk†ti‡th‡qg†mf…nfƒmd}l`mb…rgŠujwlŒukˆsk†rj„rg†tiˆvkŠym‡tm„riƒph‚pg…rj†tlŠrkŠrl‹slˆslŠtmŒwp‹ui‡ri„ogƒnf‡ofˆpd‹oe‰qfƒnf†rj†qi†qj‡qfˆqiˆqi„ne„me‡oi‡pi‰sjŠti‰ti…of‡pi†peˆrgˆrg†pe…od‡pf‰qlŠrlŠqk‹pi‹qjŒrksiŽsiŒqgtjxnvlvoŽwo‘wp”zs”zs–zt”xo’wn“xp“xo”xo”xp”yp“xpwq‘xr•{t”yp‘to‘uo‘uo‘up‘wq‘wrwq’zt•}w’zt“{v–x”~s’yoŽukŽsisiri‹ph‰og‡ng†le…kd„kb‡nd…lbˆmc†ka†ka†i`Špd‰me‡jdŒohpfrdŽrgŽrh‹qg‹ohŒoh‹mhŠlf‡jbŠmdŒqf‰mf‹oi‹og‹ohqj‹ohŠng‰mfŠngrh‰nd‹pfŒpjŽqk‹pgrhŽsjtntmumŽrksltmtmslqjsiŒrhŒqgŒqg‹ohŒqjŽrkpj‹ohŒpiŒoi‹oh‹oh‹ohŒpi‹oh‹ohŒpiŒohrjŽtiwk~s“†|“„{‹vosnrnsmsl‘tm‘tl‘tj’ul’un‘tmsi’ulsj’un‘tnqlsk’umsksk‘tlsk‘tk’un’tn‘sm‘tm‘tkultjtkritk’ulrh‘tmrlŽqkpiŽqirktlum‹qhqhŽphpfririsjqjŽrltiŒqhtismslŽslqiqhsjtkŽshujsmtlŽsiŽrhŽripjrjrjsisjtithtmŽrkriŽqhŒofriŽsiriqjŽrktlukukukŽsitjtjukslsl‘tk‘tk‘tkŽrhŒrlumuiuitjŽqhslqjpiŽrksl‡qi‰pf‹ohŒoism‹oh‹qgˆqirhŽrhŽrgŽrh‹pg‰sg‹tgŽsirlqjŒqkslŽrkqjqkŽpjŒpi‡sgŠrhŒri‹pfŠphŠpj‹pf‰mf‰me‰meˆqfˆtfŠpf‰oeˆpfŠrhŠqg‹of‰re‰qf‹rh‰pf‰ogˆof‡neˆpf‡qe‡qf‰pdŒsf†qf„nc…nc…od‡qf‰pf„ob†pe„md…nf…ne…od†mc†mc…od„nc„ncƒod…kb…lb…ma†mb†lc…kd„me†pe„nc„nc…oc‚l`‚obnaldkc‚kc…ocƒmeƒic„jaƒj`„lal_€n`ma€nbpd‚la„na„lbƒlak`~i_kcjb|k_k_k_€la€ka€j`}k_i`}f^‚haka‚l`}g^~i^}h]~h]~i]}h[~e[~i^}k`yg]we]xf]}g\}g[|eYygY}i\|i\{f\{e\zc[zc[xfYvfYubZye]zf^{h^ze[wcWxe^zf_yg\yg\xfZyf^wg[wf[yg]we[vbYu`YweYveXucXxdZxb[waZxc[xcYycZxcXyeZxeYvfYteXve[ueYve\ue[wfZweZwd\taZs`Yu`YufYueXvgXueVvdYwe[|g[{eYzcZxcZyfZveXxdZvdZueZyh^zg^xeZzgZwdWvdYtbWwgZrcYwc[vd\ubZwfZxh[xh[vf[wf]yg^xi\yi]yh\ugZxg[wgZwgZxg[wfYxg^wd]yf_xd\u_Xv_XsgYuhZwi[wgZyjZsgZpeZo^Vn_Ug_QeYMd[N_WIaWMbSLbRNaSL`RKaRLeUOeUMgVOgXPhYSgYSiZTj[UeVPkXUo\Xt`ZsaYucZwfZwd[vgZueYwgY{k_zi`{h]{i_zh]{h^j_ƒj`ƒma‚lak`~i^~ialdƒnf„pg‚lf~ia}i_m`„ka„od…pd„nc‚nc‚ncƒkc‚kc…nfƒnb‚l`‚l`„nc„nc„ncƒmb‚lak`€kc€jb‚meƒldƒlb‚ma…nc…pe„pe…ph†qi†qi‚ncƒnc…od…od‚ndnckc}kbnfƒnfˆsk‰tl…sh†rf†pe…og…qh…qj„rf†rhˆqiŠskŠsl…qj‡sh†rg‡qf‰shvkuj‰tl†piƒod‚peƒqf‡uj†qi‡qj…ph…ph‰tlˆtkˆslˆsk…ph„og…ohˆrk‰sh‡qh…ph‚me‡pg‰qeˆoe‰rg†qf‡qfƒneƒnf‡ph‡ph†og†og‡ph‰rjŠpjŒrltlŒrk‰pi‡mg„odˆqfˆrg‡qf‡qf‡rf‹rkunvo‘wpunslqjŽrksl‹qjvn‘wovnwnwp“zr–|u—|u—{t’vo“wp“wp•xq”xp’up’wqvpvp“ysvp‘sosn’up’up“xr“yu–|v”{u”ztvp‘wqvptl‹rhŠoe‡lb‡kb‡ja„k^‡mb‡lbƒib…ld†lfˆmc‰nd‰ndˆmcˆmc‰md‹qeŠnf†jc‰mfŒpfpepgŠofŠpeŒpjqj‹ng‹mh‹mgŠme‹ohŒoi‹niqjŽrktmqj‹oh‹oh‰pfŒqg‹pfŒpi‹ohŒojŠofŒpgqjŽrkŽrkŽrkŽrkqjslŽrkqjŒpiqgpg‹pfrirkŠpiŒqg‹pf‹pf‹pfŒqgrgslŒpiqjŒpiqjqjrk‘skti‘xlyq‘~vŽ{sŒwoun‘un‘un‘un’ul’ul‘tk’ulsjsjsj‘tk’ul’up’unrlŽqh‘tk‘tk’ulsjŽqh“vm”wp“uo’to’un’tlŽrk’vnui’ul’ul’ul’tl‘unqlpjŽqjŽqh’rm‘slslŽrkqjqjŽqh‘ulritktktjtkrhŽsiqjŽrkŽrkrhqhultjriŽtl‘unŽrlrhrhŽqkqkriŽqhqiŽqhrisismslsjripgritjŽrjŽrkŽqkriukŽrlŽsjŽsitjŽsiŽsiuk‘vlsj‘tksk’ulŽsltktjŽthvjŒrfslŒpiŒohqjrkŠskŒsiskrkŽqjŒqh‹qg†ogŒrhshŽrgqh‹qh‹ti‹sgŽuitmŒrj‰qkriŽsirhŽsiŒpgŠoeˆrg‹siŒqgŽrkŽslŒrkŒpi‹oh‰mfˆng‰qf…peŒrh‰rh‡qfŠti‹siŠqg‰pfˆoe‰pf†mc‡mc…lbŠoeˆnd‡mc…od†od‡qfƒncƒmb…odˆoe‰pf†mc†pd†pekbƒld„nd„nc…lbƒj`„nc„nc„nc‚nc…lb†mc‡nd‡nd†lb„jc‡ph„nc…od„nc…ocƒmanalb€la€kd‚kcƒlc€ld€jai^…lb„l`i^€n`~j^ld€lcl_k_k`la~j_{g]}ib{i`€l`~k^~j_~j_~ia|g^yh\{f\|e]g`h_€j^g`}f^}g\i^i\}g\}g[}h\zh]yg[we]wbZzgZ{h[zgZzgZzhZ}j]xdYyd[xc[{f]wdYveX{f\zg\yd\|e]ybZwaXxc]zh^yh\weZwd[wd\weZweZweZzgZyfYs_SxgYveXucXr_Ws`Xs`Ys`Yxe^xd\vc[xe[tbXwe]vdYucXvdYxgZwfYwh[ud[tb[vc\ua\t`ZveXveXwfXucXvdYxf\xdXyeYvbYxd\wd[ucXxc[wd\wf]yh_yf^yd[zg[xfXtbWvdYwg[ve\vc\zf`we]yh_xh]yi\vg^uf\td\vg[xi]wi]yl]zi]wgYzj^}k_zg^zg_xe]ze]yd]zd\{c[xgZzh[{j]~k^{l`wl^mcYhYPaTK]TKaUK_TK_UK`UM`PLcPNbRMbQLdTMcTMcUOeXQdVPgXSeWQeWQaUOfYShWUjYWk[Vl\Vn^Vm^Ur^Vr_VucVweXyd[{e^}j_|j_|j_}k`~j`€l`k`€lamaj`{f^}g_}h`„ofƒmg€kb‚md~k^‚la€j_k`ƒmbmcmbƒld‚kc†pe†pe‡qf„nb…odƒmbƒmb‚la‚la‚la~k_~j`„me†og†og‡ng„pd†rg‡rj†riŒvn‰qj‚ncmbƒodƒod„od…ncƒme„og„og‚ne„ofˆsk‡ui…qf…pe‡ph…phƒph„qiˆskwoyqŒxn‰xlŠvkˆsh‡qfˆrg‰ti‹vk†qi„ogƒodƒod†qg‡sh†qi†qi…ph…ph†qi‡rk†rf†sg„pg„og„ohƒoh‹rg‰ri‡qi…ph†qg…pc‰pf‰pf‹rh‰sh‡pf„pd‡phŠskŠsk‰rjˆqi‡phˆngŠpj‹qk‹qkˆohŠpi…od‡qfˆrg‰sh‰shŠti’uoum“xq“yr’xqvoslqjslŒrk‘wp‘zrŽwoŽwo”yr•{t–|u™}v—{t”xq“wp”xq”wq“wp‘to’up‘to‘vp‘xrys‘wqto”wr’up“vq“vq–|v’xr‹qk‰oiˆnhˆnhŠne†ka„j`„i_„h_‡ia…k_‡ma†ka‡la‰leˆmfŒoeŒof‹ne‰nd‰ndŠoeŠld‰ld†jc…iaˆmd‰nd‹pfŠoeŒohŒphŽrkŒpiŒniŒoioiqjqkpl‹ohŒpiŽrkslqjŠngŠrgŠqg‹ohŒphŠmfŠleŠng‹ohŠngŽrkŒqhrgqjqislqiŒpiqjofŒofŽqhŽsi‹ohŠohpgŽqhriŽohriŽqgslŒpiŽrkqjsltm‘tm’rk‘uj’vk“yp’{sxqun’vo’vntm‘un‘tk‘tl’ul“vn’ul‘tk’ul’ul‘tm‘tmslŽqjriri’uksjŽqhŽqhri”wprl‘tn’un’ul‘uo“vo‘tn’ul“vm“vm‘tlrkqlqlŽqkriqk“smqjpiqjŽrk‘tksjsjŽqhuktj‹pfŽsi‘vlŽrkŽrkslsjrisjrhsjtmtiŽrkqjŽrkŽrkujrhŽtirhŽsiŽsitjrlsl‘tk’ulsisjŽsiskŽrkslsktjŽrkqjtmuktjŽsiuk‘vl’ul“vmsj”tlukrhŽsitjŽshsgqj‹phŒohŽrkrlŠsjŒthtjsmrkŒqgŒsgˆqisishŽrg‹pfŒqhŠrgŽuitjtmŽsl‹rlŽrjŽsiŽsi‹qg‹pf‡mc‰rgˆqfqjqjŽqjŒrkqj‰ogˆpeŠqg‡ndˆoeŠqg‰rg‡qf‡rg‡peŠqg…od„nc‡qf„nc„nc†odˆncˆmc…lb„ka…od‚nc„nc…od„ncˆoe‡nd…lb…pc„nbjb„me…ne…od„ja„ka„mb…od„ncƒpd„kaˆod„jc…lb„ka†mb‡phƒmb„nc‚la„nb‚l`‚lala€lak`€kc‚le€nbl`i_…lb‚k`~h\}j]€j_h`h_~i^l_€j_~i^}i^|h]{g_zf^}j^}j]}i^|h]~j`zf]yh[}g]|e]~d]|f]€j^}g_~g_}g\~h]i^|gW|fZ{i[zh\vdYxeX{g\xeX}j]{h\yfYyfYyfYxeXzf[xd\xe]vdZucXxdZ|h]zf]zc[zc[ybZye]yg]xf[vdYucYwd]yg\ucXygZzfZwdWvbUxgZwfYvdYubZvc[ub[taZwd]wd\xe]vcZyfZtaYs`XucXucWudWueVvf\xf]we]vc\wd]s`[saTtcWvdYucXwdZyg[ufWscVscZrcZrdYrcWwc[vc\we]wf]xe]wbYwfZwgYvdYweZwfZve\yf_vd\wf]wf]vg^xi`wh_vf]vf^xi]xj^yk_yk\{k^xh[{l_|i_{h_{h`zg_we]|g_|h`{f^{g[}j]{h\}h\te[maVf]SeUM_PJ^RLbQLaSM_SM^RKbQLcONeQMfUNeUMdSLgVPiZTjXUiVThVRiZUhXRhYRgUSfUQhWTiXShWRhXQhVRiVOlYOr^Szc\|ea|ja~la}k`}k_{i^yg\zh]|j_k`k`}j^i]}ha|g_}ga}jb~kb}m`j`k`ƒmb„nc…od†pe‡qe†pe‡qf‡qgˆqh…oe‡pf‚lak`ƒmbk`‚l`‚mb„mb‡qgˆqiŒqj‹rk…of„og…oh‡qiŒtmŠrl†phƒmfnd…pe„pe‡od„ncƒmbƒoeƒoc„pe„rg†rg†qf…od‡ph‡qiˆsk‡tlˆsk‹umŒxn‹yn†ujˆti…qf‡rh†rg‡sh‰uj†sk‡qi…qfƒod„nc‡qf…pi†qi…ph„og…ph†qh„sg„rgpe„og‡qj…oiŠqfŠriˆsk‰sk†rh†pc†pfŠshsi‹qg‰rg‡qeˆpj‰rj‹tl‹tlŠsj†pe†mc†me‹qkŠpjŠqi‹rg‡qfˆrgŠti‹uj‹uj‹tisitj“xm•yr“yr“yruoŽtmŽtmunyq’{s‘yqyq‘wp‘wp“yr”yr”xp“xp”xp•zq—|s—{r”wr’vo’vn“wo‘xpwq‘wpŽtnrkŒqhŠnfri‹riŠqh†meƒia„kbƒia‡ka†ja…i`ŠndŠnd‰mc†oc‡mcˆnd‡kbŠmc‹ndŒne‹mdˆlcŠmd‡lb‡mbˆlc‡ja‡kd†jc‡keŒni‰ofŒoiqjrkŽqlŒqiŒnhŒogqhŒqf‹oh‹piŠng‹ohŒpiqjŒoi‹phŠrf‰ph‰nf‰lfŠmfŠldˆmfŠmfŠngˆmdŠoeŠoeŒqgŒqgrhŽsh‹pfŒqgŒpgŽqhŽqhŽqhqjŒpiŽqh‘tk‘tkŽqhriritmqjŽrkslsl‘un“vo’vn’wl’xl“xp“xq’vo“vn’xl‘vk’wntmvkum‘un“wpumuj‘tktmslslslskrjsk‘tlskrjrjsksm’to”vq•xq”wn’uq”wr’vo”wn’ul’vk‘tkskojŽpkrk‘sk’vnrjohqjrjphŽqkŽqkriŽqhrh‹peŒqgŽsirhŽqkŽrkŽrk“sk’qj‘tjŽpgsisiukŽriqksmŽsjtkvjŽtiŽsirhriri’tn’vo‘tk“vmukuk‘vlul‘unŒpiŽsjŽsirmpkslultjŽthujtk‘vl“vn’sm”sosjqitnsjshŠsfŒpf‹qfŽqhrh‹qf‰shŒsgtjsjrjŒrgŒth†phŒrgshqfqhŒphrgŽsgri‘slsk‹qkphrhŽsiˆpfˆpf‹qh‡qgŠng‹ogŠmfŒoiok‹og‰od†obˆrdˆpc‰oc‹pfŠpf†nd†odˆoeŠpe„ldƒmc†od†pe…oc…oc†oc‡nb…j`†lb„mb‚mc…od‡oeˆndƒj`‡ncˆndˆrf…oc„me‚kc†of…pd†mc…lbƒmb„ncƒmb‚ocƒj`„jcƒib„jc…mb†ma‚lb‚laƒmbƒmb‚l`k_‚lbk`€k^k`~j`~hakai^~i^j_j_~j_k`€i`„ic€g`}g^|j]€i_h]j_€kaha|g_~h^|h^|h^|h]|i]xg[xfZ|f]|f^~d^}g]~h\zf_zf_{h]zi[zhZvfU{eZxfYwfYxg[xe[{f[yg\zh\xg\|g\zf[yeZ|fZzh\yg_yg^ucZweZwd]xe^xd\wdZxcYxdXwd\xfZyg\ucXwd]we]{h\xfYyfY{f\zcZu`Vxe[wd[veZvgZwg]vf\wd\wd[we[vdYvdYtcVs`Yxe]tbXr`WtbXtcXvf^wf^ve\vf[udZucYudWucWubYxe]ve]vf[tdUtfWvh[qe\qdZrdZvcYyf]vf[xg\xf\wcYweXyh[vdYzh]weZyf^vf[vf[ueZrcYvh\xj]xf]xg^xg^zj^xh\zi^xk]yi]zi]zj^zh]xgZyh^zh^wf\xg]zh^wf\yh[wg[xg]scYn^UcWM_SJbRL`PK]RNbNMbQN\PJ^OJ`NJeNMkXRp]Vq`VrbVtc\ud_ydauc]ua\tb[r`Yo^Wj[VgWTfVTeVSeVTdURbURdXOfXOeULlYSp[YweZzh]{i^{i^zh]zk^{h_|j_|j_k`lak`ka{f^|f_zg_{h_zj]}h]‚la‡qfwlŠtiˆrgˆse‡re†pe…ng„mfƒlf„od„od…oc‡qf†pe…od†pe…od‡qfˆngŠpi‡mhƒogƒnf…piŠrjŒuo‹sn‹skƒoh‚pe‚oe…od†nbƒnck`‡peƒpe…qf„qg‡sh‡sgˆpeˆng…ph‡qi„qj‡rj†rj†rgƒrg‚sfƒqf‚pe‚pe„qf…sh‡ti‡sk‰sl…rg‡pe‚la…od…pg…ph„og„og…ph†qhƒrf…sg„rg‡qi…ohƒmg‰od‰qi…ph‡rj…pg‡rf†qg‹tiŽsiŽuhŒthˆrf†oh‡oi‹tlŠtk‹vkˆqgŠpdŠpeŽrkqjujvi‰tiˆrgˆrg‰thŒvk‹tktisj’wm–zs•|u’xq“yr‘wpunxpŽxoŒwnvnyquo’xpvo“wq”xn’wm–{q—|r˜}r—|q•yt’vnŽrgŽth‰riƒphŠpi†md‡ne†ka…k_ˆmaˆmd‰nd‡lb‡lb‡lbˆndˆjaˆkbŒnf‹neŒpgˆod…mf†nf‡laˆla‹mbŠk^‰jb‰i`†i`‡ja‡kaˆnd‹mdŠmdˆjbˆleˆleˆmg‰oh‹nhŽoiqkŽqhŠqgpiŒofŽrg‹qe‹qfŠneŠngŠngŠohŒpi‰mfˆme‡od†me†jd‡jfŒoh‹mdˆke‰mg‰mf‹pfŠoeŠoeŠoeŒqgŒqgŒqgrgŽsirhtjŽqhŽqh‘qkpjŽqh’ulŽsjririsjulqjqjŽrksltm‘un’wn‘wkwl’wo’vo“vo”wo‘wk‘wk‘vntluitl‘un’votlŽsgsmrkrk‘tmririŽqjskslrkŽrktmsksl’to“up”xp’un’up”wr”xq“vosjtiŽqirloiŽpksl“vmtjphŽpf•sj‘ripgŽqjŽqjriŽrhŒrg‹pe‹pfŒqgrhŽrkŽrkŽsk’pk”ql’pkqh’tj‘tfujulqkŽqlqi‘wk‘wkŽuhrhtjqiqj‘qk“to’um‘tkuktjultksmtmsjsjŽqlŽrlŽrlskŽsiui‹sguj‘uk‘tkŽojpitjskŽrktnŒthŒtfrhŽsiŒofŒqgŒqg‰rgŒthrg‘tjqgŽsh‹sgŠrjŒrhqfrfŽriŽsjŽpfqf‘qhqkŽrk‹nhŒqhrhŠoe‡nd‰pf‡pe‡ohˆmfŠmgˆle‹mh‹nh‹pe‰oc…qa‡ra‹rc‰m`Šmd‰nc‡nc‰pf‹pfŠod„lf„md„nc…od„ob‡qeˆrf‰rfˆnc‰nd„kb‚jd†pdˆnd†mcƒj`‡lb‡lb†pc…ocƒld‚kcƒlcƒnb†lbˆnd‡rf…ncƒmamb…kbƒic„kd…jc…lb…m_‚lcƒmb‚la„nc„ma€j^i`€j_€j^m_ja~ibkai^i^}h]|h]{i_€k_ƒjb„ic€f`}h^~j_€g]h^~e[€j`g_}g_}f`f`}i^|i\yi[xgXxfY|f]}f^€e^~h_|f[zf_ye^xg\yh[xgZufVvcTxfYxgZxgYyf[}h]yh^yf]zg_{f^ze\xe[j\{i]xg^yg_xg^vdZwe^uc\vc[xfZudXyeXveZyg\xf[vdYub[wc]ygZyfYzfY|f_|e^zc]xc]vc[ve[wg[ufXvgZxe[vdXxf[wfYweYudWxc[ze]xc[u`Xv`Yu`Ztb[vf^ve\tdWueXvfWwfYudYsaYsc[sc[tfYyfVwfXvg[tdYsaYvbZzeZvdZvfZwg[udYwcYxgZzi\yh\xf[yg[vb[vfXscVtcVuhZvh\ufZxf^zg_zg_zh\zi^wfYvf^xg[vfZxh[yh[xhZxh\wg[xj^ug[xj^tfZtcYvf\vdYsaTm\PdVK^TK^RN]PO^ON]NK_OI^NGcRKjWPr]X{f\of‚qhˆwo‰woˆtmŠvj‰uk‡wl†ulƒrjmfzhdwd`p^YjWRgWPgWPcWSfWPhVNhVNjYRhWSk]UtcY}i^k`~ja~kdldle|j_~j_k_~k^}k\|i]xf[|j^|j_{h_k^l_†sfŠvk‹wl‡ti‰rg‰pgˆoe…la…ma…lc…ke„ke†phˆrg…se…re‡qf…od…od…od‡qfˆrf…qf„og†qi†pjˆun‡tl‰vk‡si‚leƒke…mf†pfƒod…nc„me‡ogŠpiŠpj‰rj‰rjŠsk…of„og„phˆti…pf…ph‚nc„rd†tcpf‚og‚ogƒph‚ogpg‰rjˆqi‡ph†ogƒle„md‡odˆpe†peˆrg…ph…ph„of†qi†qiˆqi…nf†nf†peˆrf‹siŽukŽuktjŒun‹vjŒuixlŽujŒph‰ohŠpismŽsmtnsm‹ri‰qgˆrgŠqgtjŽrh‹qj‹qj‹ojŠpjŽto‘vptluo’vp“vqwo{pŽvqwquoŽtnvpvqunŽunŽwoyq’yr–zsvp‘wpvlwmvixjŽqiŒof‰mb…ja‡jd‚gbƒk_„k`†nb„l`†nb†nbŠodŠog‰nf‹oi‹pg‹pf‡lbŠpdŒrd‹qd‹qd‡lb„ma…mbˆmc‰lc‰i`Œia†i`†ic†ibˆkd‡j`Šnb‰oe‹pf‰ndŠlc‰lc‹neŠpfŒof‘pgofqg‹qgŽodncŒpeŒoeŠpd‡oc‰qeŠod‹neŒof‰og…meˆnd‡lb†i`‡kbŠmd‰mcŠle‹nfŠmdŠldŒofŒofŒqhojŽqlŒojŽrlŽsipkojpj‘ri‘rh‘sg’sj’sj‘riphph’sjtisiŽqhrirjsl‘snrmsn’uo’so“vp‘vl’xm’wm‘vluk‘vl’rm“sn“tn”tm‘sj’riŽqjslrkslsj‘tjro‘rn’unrk“uo’sornsp“vr‘to”up—uo•uo–xr”wp’vlukŽsirirhujŽritk’sjŽpgpg‘qh“tk‘ripgpirkrkslqlŽoj‰ngŽrlqk‘slrlrk‘qlsmqjtiŒrgsgŽsitjŽsiŒpguk‘vl’ulŽsitjtjshŽqhsksjsj’ulŽrgtitn‘umŽtitjulsmslŽuiŽrgqfŒshtkŒujŽulŒsisiujŽriŽtjtjuk‘tk‘ukrjqjqj‹ohqkŽqkrlsl’rl’smpjpiph‹qg‹rg‰rfŠtg‹shrhsg‹qfŒsiŠrhŠsk‹skrkshŒpe‰mbˆqe†phŠpe‰mc…lb‡nc‰qf‰pg‰pf‡ndˆndˆod‰ocŠqdŠmfŠmfŠnhŠng‰ng†mf‹ng‰mf…nf†nf‰nf‹ohˆoe‡nd†o`ˆpcˆpd‰pe„k`†mc‡nd„ka„lb†mcˆoe…jd‡mg…ke…jd…lb„meƒle†ng‚nf„ogle…nc„ocnak_„lb„ic‚ld‚ocla~j_€n`‚mai]€i]‚l`€j`ib|fbjb€k^€j^~h]g`~fa}f\i^€j_i^€j_~h]~h\€k_}gZ€j^~h\{eZ|f[|f[i^i^{f[}g\~g[|fZ}f]{e]{e[}g\|f[|hZzfXzgXwdYtbXyfZ{hZyeZzf[{g\{f^{gayf_zh]ydXyd[}f^~f`{f`wg[wg[ze_zc]xd\wd[xe]xe]vd[we]xa\zd]}f^xe]yg]rcWud[vd[ve]we\taYxd[wdXveZweZygZyh[xfYwfYwfZvdXvc[wd]vc\wd]tbYtaYtaYsbWtbXvbZxe]ud[tcZtcZxe[ueXtbUxbUzcXyfZud[xeYweYwfYwfYudWrcVyg[wfYveXveXudWscUzgZzfZweZvdXt`Yve\yh\wf[wg\ueXuhZvhZyc]wd]wf]vf]xh^yf]ye^zg]yi\xhZzi_ze_yh]zj^zj]xg^{iaxf]raXtcZwe\tcYn\ReULaUM^RL^PL^OM_PM\LG`PIiWPvb\‚ohŠxm‹yp‹zqŠzpŠxp‹yrzqŽ|r}u~uŽ}s}t{tˆvo‚pj}kcn_Wk[SdVRiYTkYSiVPjZUl\Xl[So]TwcX~i_jb‚lf€md€lc€j`~i^~h_ƒlbm_l_~j_|k`€nb~ld€kcld„of„pe…qf†rf†qf†qf…pe‚nc„od„pe…md„nd†pe„od„qe„qe…pe…pe…pe…pe‡rg‡rg‡rg†qg…qgƒoeƒph„qj‡sf„pglejc†ng‰qj‡shŠti‰ri‡ohˆng‰nh‡phˆqi†og…nf‚nfƒofˆtgˆui†qh„ogƒpdƒpc‚peƒpeƒpeƒpd‚odƒqe†of‡qg‡phˆqi„le…nf†od†od‡qf‡qg‡oh‡ng„nf…nf‡qi‰piˆogŠpiŒqg‹rhtjwmŽxmxlŽwoŽxmŽujwlwlŽskŠpjŒrkunuoŽtnŽtnsjŠrg‡qeŠqgsisi‹qiŠpiŠqisluovp”zqvn‘toŽsmŒslŠvk‹slŠslunvp‘wq’wq“wpunvotmwo‘unŽsltmŠpf‡mb„k_ˆobˆkb†j_†j_ƒi]„h_…hb†iaˆld‰me‹nf‹ogŒpgŽtgthvjujŒrf‹qc‰me‡kb‰mcŠodˆmc†ic…k`†lb‰mdŒof‹md‹lc‰lc‰leŠmfŠmfŒoeqfŒrg‹peŒqgpgŠmdŠnd‰pgŒogŽngogqhŒqiphoh‹nfˆkcˆldˆld‰ld‹nfŽof‹ne‡lb‡ld‡ndˆmcˆkb‰kbŠmdŠnd‹ndŒof‰lcŒofphŽqiŽrhŽsiŽqkqjsjŒqgoh‘rj‘rhphŽofrhqh‘ri‘ri’sj“tj“tktisiriŽqhŽqjrkŽqiskri’umtk’umtl’wn‘vm’wo“wo‘vm•tp–vp–vp‘qk’rl’sjŽrjsk‘tksl’ul‘tmrk‘tmsl’um‘tmrnsoqmrmŽql“tn•sm“tn”wp•xq’ul‘vltj‘sj’vlukuk‘uk’tk”uk‘qhqhqgpgŽofŽqislrk‘tmrmŽplŽrjqjtmtmslŽqj‘qlŽrkrltjŽshuisjriŽqhpgri‘sksjsisisirhrirkŽqhsjsjshshtmskŽsirhtltnslshŽshshshŽtnŽskŽtltkŽrjskskuktjtjsjsj’ulŽrkŽrkŒpiqjŽrkumslŽumtl‹rj‰pi‹piŽrkŠqh‰sh‰sh‹rhŒpiqgrh‹qgŒqhŽsmtmtkujŒqeŒqeŠphŠqj‹pf‰md…lb…lb‰pfŠqg‹riˆod‡nd…lb‰ob‹qd‰ng‰ng‹ohˆpg…le†mfŠng‰ng†nf†mgŠoiŠng„mb…mb†pc†ob‡pd„mb…kbƒj`„kaƒj`…lb…lb†mc†le‡mg†lf…kd†mc‚kd„me…nfƒmeme‚me…oc‚mam]€k_ƒkaƒi`h`ƒma‚la€k_ƒla‚m`h`€j^€j_k`|h`|ga}f]€j`~h\~h]€j`|f]{dZ}g\i^~h]i^~h]zcZ}g]~g^~h^|e\{e[|e\}f]~g^~g^}f]~h]}g[}g\}f^{d]i^~h]~gZ}gY|gX{fZxcYzd]zgZ|i\zf[{g\}i^{f^xe^xf]zh]yfZyfZ{g]{d^{g`xe[xf\xd]wa[wc[zf^xd\xd\xd]wc[ye^{g_{g_xf^{i]wcYueXueYueXvdYweZweZwd[yg[{h]|h]|h[{gZwfYweYvdYubZvc\ub[taWubZxe]vc[vb[yg]xc\we]uc[xg^tdZxf]wg[weYycWzdZxeZtdXve[ve[yg^wg\te[tdZwd[tbYtbYr_WtbXtbXvaVvdYweZtbXvc\ud\yf\xf[veYveZyh[wi[xd\xg\vg]uh[xi]yk^xd^yf]zj]zj]zh^|gayh^yi]wg[zi_yh_{karbYtd[tc[tcZn[TgVOdTMbSL^PJ`QL_PN^MIaOIp`Vqe‡vm‰xlŠyoˆzq‹zq‹yqztŽ|u|tŒ}t~s“u“€t}vŽ|uŠyqŠypƒsjziao_[lYViVSkXUgWTfXUn[Un[Ss^VxdY{d\hama€j_i^€j_‚hb†me„oc‚pb‚ncmbzi]}jakfkfkd€kb€la‚obƒodƒod‚ndmbncƒod…od…od…od„nc„ne„me„pe„peƒod„pe„pe„pe‰sh‰rg„peƒod‚nc„pe„qd„peƒocle„nf†nf‚od‹ti‡qg„nc‡meˆng…nf…nf‡ph…nfme…pg…re†sg…qf‡rj‚me€kb„pe„pe†rg…qfƒodƒod‡qf‰sh‡ohˆqi†nh…ngƒne…qe‡qf‰sh‰pgˆoe†og…ofŠqj‹qjŽtmŽtntjŽsivlxm‘{p{p–|u˜~u—~t’yo‘xouotjuoŽtmunŽtnŽtnslŒrj‡qhŠskŽsl‘uovkŽuksl‹qjŽtmŽtnwmunsl‹qkŠpi‰sh‰rj‹qjŽtmvo“wp“wo“wptmˆoh‡nf‰ngŠng‹oh‡kc‡la†k`„j^ƒi]…i^†k`…l`ˆnb‰oc‡maŠmgˆkd‡kdŒoh‹ohŒohsfsgvjŽth‹qeŠqeˆkeˆjd‡ja‰lc‡jd…hcˆkb‰lcŠmd‹neŒof‹oeŒof‹nfŠmfŒog‹ndŒpe‹ohŒphŒpiŒogŠmf‹nfŒoj‹ni‹lgŒmhŠmgŠniŠmf‹ng‰le‰leˆkd‰kdŒnh‹ke‹kd‹lc‰mdˆla‡ndˆlcŠlcŒmdŒneŒof‹qd‹odŒpfŽqkrlrlrhqgqi’sjqgqf‘ri“tj‘ri‘riphoipgsjri’tkqhrisjririŽpjrkrkriŽqhririsj“vm’vosltm”wp”wq’un’rl“sm’rlpj“sm‘pjri‘tk‘tk‘tkrlsmuhtitisk’uormsltm’untm‘sl’rlsl”wp‘tm•xn’ul‘ul‘tk‘tk’ulsjsj’ul‘slqjoirkph‹ngsj’ul‘tmslsmŽqjŽrkŒpislslskrlojuktjtjŽshui‘tkŽqhpgŽqhŽqhsjsjŽrhuktjqhrirk‘tkrisi’vkshunrktjŽsitkŽsitjŽrhriŽqhpg‹rhrkslsl‘tm‘umqltjukŽsitjsi‘tkslqjqj‹oiŒpiŒpi‹qjŒslŠpiŒrkŠqjˆohqk‹qjŠsiˆrgrlŠnhriŽph‹pfŒqgtkŽsjŠsgŽujsgŒqgŠng‹ohŠoeˆmc†mc‡mcˆofŠqgŠpiˆng‡nc‡ndˆmbˆmb†le„ld…nf„meƒnf‡qi‹rh‰pf‡md†mcˆoe‡mc„ncˆrf‡qe…oc„ndƒld…ka„ka„ka„ka†mcƒk`„jc†le„jdƒic†leƒiaƒja…mc„ndƒmb€lak`ƒl`ƒmak_~i\j_i]‚hah^ƒj`‚j_ƒk_‚j^€ia€ia~h]~h]~h]}h]|e]}f^}g\i^~g[|fZ|f[}g\|f[}g\h^{eZ}f^€ia}f_{d\ybZ|e]}f^h`~g_~g_~g_|e\|f[i]ha~h]~h]}hZhY}gW~gZzdYyb[}e_}i\zgZxdY{g\|h]ze]yi^zf[{h[|i[{g[{g\zc^xeZweZzh]ze\yc]wbXyeZxdYzf[{g]}i^zhayg^we]yg\}i^{f[xf[xf[xf[xf[we[xfZxg^yf^{g\}g\}eZ|dXyf[xf[vdYvc[ubZtaZvdYxf[yf^wc[wd\wd\{e]wd\ucYwf]vf\zf_ugYtaWxdYxdXweZueYsbYvd\sc\ud]te]rcZwd\taYubZs`Xvc[ubZtbVvdYucXvfZueYteY|f_yd\vdYweZxf[xgZxh]wh\vh\wj\uk]vj\xe^zi_|j_}k`|j`}ga|k^zh]zh]yh\{h_zg_xi`ug^ud\raXmYRlYRhVOhVOeUN_RJ^OL_MI^KDo]Tqe…xl‰ymˆxnŠzrˆzqŽ|tztŽ|tŽw~uu’u“u~v}vŽ}tŽ}t‹}tˆxp|mio^[jWTkYVjZVhXVmYTq^Wo\Tt_W{e]h`nbƒmbj`k`ƒic†le„oc…nb„od€l`laldke„nhldlcnb‚obƒod‚ncmambƒod„pe†pe„nc„nc„ncƒmc‡ph…qf†qf„pe„peƒodƒod‡qf‡qf‡pfnb‚nc‚od‡pe†qf†rg„pdmcldƒnc†pe‡qf†pe‡ndˆodˆqi‰rjˆqi‰rjƒnf‚ne‚nc…qf†rg„pe‚meƒngƒpd…rf„qe…qf†rf„pe‡qf‰sh‰rjˆqi‡oi…ng„oe†rg‰shŒujŒsi‹rgˆqiˆqiˆqiŽtm”zs—}w–{q”xo”yo‘wm”zq–t›zŸ†ƒ}“yrununŽuj‹rhskŽtmumuoslrk‹ulŒumŒrksmwmvlŠrgŽsmvoŽtnvlŽunŒrlsm‹qj‹qh‰nh‹qj‹qjpiŒpipjŒpiŠng‡kd‡jc„ha„ib…j_†ka„i_‡lb„j_†l`‡maŠpd‹qeŠpd‹peŒpemfŒlf‰ic‹ke‹keŠleˆkfŠnhtm‹nh‡kd‡jeˆje‹mgŠmf‹ng‰lfŒniŠme‰lcŠmdŠmdŠpfŒqgqfŠmd‹ngŒohŠmepgŒpiŒphŠngpiŠmf‹ng‹ni‹mhˆjeˆjeˆjeˆje‰kf‰kf‰kfˆjeˆje‰jeŽkgmhˆkdŠngŠmdŠmeŒqfŒpg‹lcŒmdŒmd‹oere‘rhpg‘qk’rm“sm‘ri’tj‘sh‘shqgŽof‘ri”ul’sj‘ri‘rjŽnhŽqhŽqh‘tk‘tkŽqhŽqhŽqjrkslŽqjrkrkti‘ujŽrgshui‘tj‘tnsl‘tm”wp“vosl’rl‘qk‘qkpj‘qkoiŽqjŽqishqhŽqkrnsfsgsjsjrksl‘umtluntm‘sl“smsl’un’uo“vm’vm“vm“vm’ul’ul‘tk‘tk’ul‘tmslrkŽqjŽqjrlri’um‘tk’unrkslrlrkskslsksl’siŽriŽsiŒsivjvjrjŽqhŽqhri‘tkriqh‘tkukŽriŽqh’sjslririŽqhshsgtmtmslŽrktiujukŽrhririŽrhŽsiŽrkŽrk’unslslpj‘tktkujtktjtjŽrkskslŒpiqjqjtmtmŽqjrlqjpiŒojŒrkˆrg‹ujŠpi‹oiŠofrhŒpg‹pfqi‹ne‹sfuiŒsiˆoeˆng‹ohŠoe‰ndˆnd‡ndˆoe‡nd‰oh‰oh‡lg†mc…j`ˆnd…mfƒld…nf‚me„og„qiŒrhŠqg…lb…lb‡ndˆnd‚laˆrf„nb„nbƒlc„ng†mc„ka„kaƒj`„ka‚i^…kd„kb…mbƒk`…kb‚hbƒj`„j`‚la‚lak`k`l_m`€i^ƒj^„l`€i\hag\€g]€g]‚j^h\}g`‚kc}f_|f[~h\zdX|e]}g]i^}g\}g\~iZ~h^i^|f[}g\|f[~h]~g_~g_~g_|e^{d\{d\~h_i`}f^~g_}f^|f\i]~h]i^~h]}gZ|gX~gX|dX{bXzc[~g^|f]{h\yfXxdYzf[{g\xc[{g\zg[|i\l_{i]zh]zg_zf\}i^|h]{f\xf^{f[xeZ{g\}i_{g\{g\zg_zh_wg[tdYzg\h\|h^yf[xf[weYweZ{h]xg^wf]yd^{g\xcX{dYzg\xf[xe]xe]s`Xwd\xh\wg[xh[xg^xg^vf]{e]yf^vd\ve\vf\wd\ve\yf]xe[we[vdYueYsaXsaZrb\ve_sc\sd[we^sbZsaZsaZtb[uc[vdYwe[weZufYvfZvfZze]ye\vc[zh]{i^xg[ug[vh\wi]xk]wj]xm_yh_yh^|j_{i]}i`yf^{i]zi\xfZ{i^zh]zh]sg]th^ucZu`WlZPo[TmYRkXQhWPbSM_QLbPKcOGjWOxh]si‡xlˆ{pˆzqŠ{rŒzr‘{u‘€u‘‚w‘‚y‘x’ƒx’€w‘x‘~x}w}vŒ}uŠ{s€unse_kYViURiXSjZRn[Xn\Wl\Tm\Sxd]ibmdƒof„od„odƒndƒlc‚l`…oc…ncma‚nc„nf†ri…pg…pg…qf‚nc€maƒle„ngƒme‚le„ng…oh‡sj†rh‡rf…od‚la…ocˆpe‡oe†ndˆpe…mc†ncˆpiˆpi‰siŠsj†qgƒod†pe…oc†qd„qdlc‚ldƒoc†od‡qf‰sgŠqf‰qe‡ph†ogˆqi‡qi„ph…ph„oh…ph†rg†rg‡rj…og…qeƒob…qd†reˆtgˆsg†oh‡oiŠslŠtkŠsj‰sh‹rk‹sl‰siwlvlŒuj‰um‡tl‡qjyq—yš„|ž‚x˜~t–|r”yo–zpš~u›wŸ„~š€z•{uŒtmwlŽukŒsitjun‘wpwo”vounŽsm‰rj‰phtnvkwmwmujununvmŽvnŒtnŒtnŠoh†ja„kc†ldˆld…ia„i`‡kbƒib„haƒf_ƒf_„ha„jd…k`„j`†ka†lb‡mc…kb‹peŠnf‰neŒpgŽqgŒpc‹ngˆkcˆkcˆkcˆkc‰le‡je‰lgŠmf‰lf‡ke‰lh‹mhpjŒphqiŒoiŒoi‹nfŠmd‹nepgqgŒpgqfrhŽqjŒohŒohŒofŒpi‹oh‹oh‹ngŠmfŠmfŠlfŠmg‡jd‰keˆjdˆjeŠkdŠkeˆkc†jb‹ngˆldŒmg‹ngŠmfˆmfpjŽpj‹pfŒneŒneŒmdŽofqhqfqg‘rjqhpi’rk’smrjrhsiriqk‘qj‘rkqg‘ri‘riqfsksjrisjrirhŽplpjslŽqjrkri’ulsjrjqisk’tlrkŽqisk’um’umskqg‘qkpj‘qk’rl’rmqlpiŽqgŽrgsksnthsk‘tlrksk‘ul‘titjuk‘vl’vo‘smsl’vo”wp“vm“vm”vn’wm’wm’tkrjtk‘vl‘tmsl‘tmslslsl’uk’ul‘tksi’tmslsisjqhujuktjqhŽshŽth‹sgŽshŽuh‘riqhqh‘ri‘ri‘ririsjqhŒpfŽqh’sjŽqkrisiŽqgŽrg‘ujŽrlrlrmtl‘wl‘wj“ymtj’rloisiŽthtntmrlsmŽqkŽrlsjsjriŽsi‘vltjtmŽrkŽrkŽrkŒpiqjŽqjŽslŽrkŽqjŽrk‹piqj‹qh‰sgˆqf‡nd‹oh‰phŒpj‹qhŒrhrhŒpfŒqf‹qi‰rj„og‡pd†pbŠod‡lb†mc‡ndˆoeˆpe†lf‡mf‡meˆmf‡la‰nd…me…leƒldƒldƒme†ph†od†lbˆmb‡lbˆnd…mc„lb†nc†oc„lb„ke„ke…lc„ka…mbh^‚i_‚j_„jc‚j_‚i_‚j_‚i_f_‚j_„ka…kaj_i^l`}i`ia‚ha„ja‚ka~i\}f^€j_€j_}g\i]~h\}h_}i`}f^}f^~i]~g[~h[i\~h]~h]i]~i[i^~h]i^‚la€j_i^h_i`~h_~h_}f]|f]j^€j_~h]|f[}g\}g[i^}g\}g\~h\|gY}iY}fZ{dZ{c\}g_|f]zeZvcVwdVyf[yeZyeZyd\zf\zg[zg[|i^zg_yf^zf^{h^~j]l_yg\zg_{h]~k_}j_}i^zh]|h]~h_zh\wg[xh\ygY~h\~j]}i]yfYxeXwfYxgZxf^wf]we]xf^yg\xf[xe\xe]yf^yf^xe]xf\xh[vfZvfZud\we]ud]{f^wd\tcZud[ud[wd\wf]ve\we]we\udXueZtdXuc\xd_vc^td\uf[xg^ve\tcZve\tcZve\yf^wf^vg[yi]vf[vi\ye^wd\yf^|jaxh\wh\ue]zi^we[{j^wi\wk_wi_zia|i_|g]{f_yf\yi\zi\yi\yg\zh]wf[mbXnbWr`UwaTsaVr^Ur\Tp[UiXQdUOcTNdRJdPHdPHfVNsf^qe„xm†zpŒ|sŒzs“~x~r’‚v’„x’†|‘„{‘z’{“€||x}wŒ{u‰zs}ukpc\fURfSPhUOlZRkXVk[Vk]Ul\Suc[‚memele€nb€mb€l`naƒla…oc†qg‡qf„pf…qh„pd„qd…re„pd‚ncnc†meŠqj‰piˆohŠqh‰qjŠtn‰tl‡ph†qe…mb„m^…lc…lb‡ndŠqg‰oeˆpe‰oi‰oiˆpj‰qjˆrj…qg…od…oc…ob…re€lb€le„og†pe‡qf‰rf‰qe‡nbƒle…me‡phˆqi‡ri†riˆql‰tn‰vk†sg‰uj†qh†pd„nb†pd‡qeˆrfˆsg…miˆojŠskŒumwkxkslŒrk„odˆrg‰vj‰vj‰vnˆul…rjŒxp“~v—‚z›…z—€v’xl’wm–yo˜zq˜}s–|v’yswqŽwqwn”{q’yovlŒtkŽtm‘wp•yr“xqvo‰skŠrjŒsk‘xl”|q‘xnwmultm‹rhŠrkˆpi†mh†kd„h_g]h^‚g]‚g]‚f]„g]ƒg`„haƒf_‡jc‡kd‡le†mc†nd…lbˆnd‡nd‡nd‡md‰mgˆkfŒoh‹ne‹nc‰mb‰mbŠncŠmbŠncqg‰mf‹qfŒreŠqeŒqh‹oh‹oiŽsjŽsisitkŒpi‰ndrhqhŒof‹neqhrfŽrhpipiŒoipgŠng‹oh‹oh‹ngŒoh‹ng‹ngŠleˆke‰mf‹ngŒphojnhŠmf‰le‹ogˆmfŽofŒph‰oh‰pj‹ojŽqlrhnfŽofmdofpgoiogpg’ri‘riphrmqlŽri’ulŽpkŽpk‘ql‘ql‘qk’sj’ti‘shsjsjŽsisitjsjqlpkqlrkrlrisjŽqhriŽqhŽqhqhsjŽqh‘tjsj‘tkŽqh‘ri’tj‘qj‘qk’rm’qlŽpmrktjtg‘ukqjrismrmŽqkŽqisi’ui‘vkvj’wm’wm’unum“wo•xq‘tj”vm•vm“wn“wm‘sjrhtitjŽrk’vnsl‘untmtl‘tjtj‘uksj’um’uo‘tkŽqh‘tkŽtiuksjshuiŽthuhŽthsg‘riqh’sj‘ri‘qi‘ri‘riŽogpgŒoe‘sjqh‘tnsiŽpgrhŽrfshŽqjqlrmsl’xm’yk’xl’vk’rk“tntiujŽuounŽtmsmsnrlrjŽqhŒpgtjtjsiŽrkŒpiqjqj‹phslŠrj‹tl‰qj†og…nf„leŒqgŠrg‡qd†pd‡nd†lb‡ph†oh‰pf‹rhŒrh‹qeoh‰mg†ogƒog…rd‡rbˆmc…j`…ka†mc†mc…mb†lf†leˆmg‡mfŠne‡la„jc†le…keƒke†ng„me‚l`…ka‡lbˆmcˆmc„oc†la…la„l`†mc…jd†kf…mcƒj_h^„kag]‚i^…kd‚i^ƒk_„l`i]~f^ƒh^‚j`ƒj`i_k`‚l`}hb~f`‚hc„jdg^~g[|g_~j_|h^|h]}i\|h\}i]|h^~f^g_h^g[~iYi\|f[g_€j^€j^i^€j_~h]i^i_~h^~h\}g[i]k_~h]{eZ~h[~iZ|gX}hYj[l]i^~g]~h]}g[}hX|hW{e\ze]zd^ze]yg[xgZzeZzfZ{g\{g]yeZ{g]|e^|g^{g\|j_|ib{gayh_{h]~h\i]zh]zh`zh]|k`|j_{i^zh]|j_‚k`{h\zi]zm_yi\|i\~h\|h[xeX{h[veWveXwf^xg^ve\ve]uf\rdWwd\tcZxd\yg_yg\yg\xh[vfYueXvd]sb[xf_ze]vc[r`VsbYtcZvc\xe^wf^xg^xg]xi\xf[yeYvbZxd_wc^vc[yi\zi`ve\ud[wf]xg^yi`zg_wg^xh\yi]vh\xj]yh`uc[wf]zjawh^wi]zg`yf_xd\ye\yi_yk_vj^|la|h`{f^yd[yg\zhY{i\ygYxeYxdY{g\n_Wp`Yvf[xh\wfXyh[saVo\TlYQkXQhVOgUNgUOdQMhUSlWWp`U|kdqj„vp„xq†|sŠ~q‹€uŒxŒ‚y„}Ž…|Žx€xŽvŽv…zq~tjplag^TdUMfTOgVShZUl[Xn^Xo]Uq_V{g^le…menf€me€neld€me†pdˆqeŠrfˆrf‡oc‡oc‚o`ƒpc‡ri‡qj„pf„pe…piˆtj‰ujŠvk…tgƒre†ng‡phˆqi‰sh„oc…oa‰md‰mdŒqk‰rj‰tk†rg„oe„pe†rh…qf†rg…qf‡qe†qe…qg‡sj‡sj‚pdƒmfld‚ngƒpe†qgˆnd€jb…nfŠpiŒqkuotnˆvm‰um…ph†qi‡qiˆqhˆpb‰qe‹rf‹sgŽtkŒsitk‰tk…rk‡slŠul‹uismŽslˆmg…nfˆrjŠulˆwlˆwkˆvjŠvkxo‘xr{q‘}rŒwntmwq“ys•xt–yt”wr‘un‘un’xnŽxn”zp“wm’vmukŒwk“ys”zs’xqunŽtmwnxlŽxlŽxmwpsmŒnhˆmc‡laˆnc…j`…j_f\‚e^„g^„g^†h_‰jaˆh_…j`…kaƒk`…la‰ndˆlbŠnd‰lb‰le‹nd‡na…n`ˆlb‰ncˆnd‰mfˆleˆmg‹ke‰kdŠmeŠnf‡meˆmg‹og‹pgshrh‹qergŠqjŒqjslqjŒoiŽqjˆlgqi‹od‹peŽohŽnhpiŽrjŒqjŒqjqjoh‹ngŒohslqjŠngŽpjˆncŠne‹pfŠngŠngŽrkŽrirfŒrhpkŠmhŒpfŒpiŒpipjŽrkŽrkŒpi‹neŽriŒpgŒofŽpgŽqhŽqjŒphpiŽqjŽqjpioi‘qk’pkŽrkslqjŽrj‘tk‘tksj’ri‘ri’sjri’sjqh‘qk’rl“ql’qj“rl‘rj“tkriqh‘rh’qk‘qk‘ql‘pk’rlsltmŽununtn’qh’ql“sn’rm’smrk”ql”snrn‘tn’rj“si–ri”ukthŽshtlrmtl‘tl“vm’un“up’to•vr–ur’tn’un“vm’vl’vp“wp‘unrksl’vp’to’to‘sn‘sn’to‘snumsl‘tm’ul•ul‘riqh’sj“vm‘tkuk‘vkrhujtishrhrjŽqhtkriripgripiŽrkqjŽrkpj‘ojshŽsirhrhŽsiŽsiŽujŽsjŽrk‘sl“uo’tn’tj“uksjukŽtmŽtmvmvmŽsjtktk‘tkslŒpi‹pfsiŒsiˆqfˆqj‰menjŽni‹oiŠqkˆpjˆqjˆrgˆoe†mb‡lepg‹og‰mf†ke„mc‡qf‡mc†lc‡mg‹qkŠohŒpkŠpcˆmd‡mg‡mg†pe†qb†n`„m`†mc…lb…kd…kd…lc‰pfˆoe†le†mfƒibmb…ncˆmc‡lb…j`…ka‚kc‚ld„ld†le†le†le…k`„jb„jcƒicƒmd…oc†keƒibƒib‚kch`€ia‚hb‚h`‚j^‚j^†ia†jdj^}g^h`h`}h_}j^ƒg`‚f_ƒg`„haƒha‚f`|g^j_j_~h]g`f_fa{g[weX}g\e^‚g\h^}g]yf^|iajbh_}i^~j_l`k_}g[}g[€j_|i^|i^k`€f`~c^j^i]}f\~h\i^i]{i\zfY}fY}eY}i\~m_|eZ|f[{f[zf[weZzg]}m_j^ƒl`~eYg[|h[{j^zh]|j_}g`ha~e`€g^g\i^i_h`}ga|j`|h]k`}h\€i]€j^k`|gaye_~kd}j`zi]yi]zg\|f\{dY{eZxeYvgWueWwg[wg[wg[{jayf_|e^|e]|f[zf[xg[wd]vc\ud\wf]xd^y`\ze\zg_s`Yud]ug^vh\xf^wf]{jaxg^ve]xg^xe]vc[vcZud]tb[vd]wc]vc]wf]ue[yi\zi]weYvdZyf^xe]xf^xe]xd\ye]zf^xg^xg`xhavi`vi_yjayh_ye^zg`wj`yh`{g^|g_yi`xk`~k^i]~f^~f_ye]{j^paZqaYsbXscXtcVweZucXq`Tp^Tp^To_Tl[QiWOgUNgTNgTNgUMiXPkYTn^Xte_zogƒul‚vm‚vm„xp…zsˆ|u‡}uŠ}u‡xq‡yq}qinc[g]TbVOgTOiURiWSkZWn\Xq^Xp]VxeY|g^iaƒme‚nf€me‚qh…rjnf€nb‚pe€pdodnbnb‚oc‚oe†rjˆtl‡sj„qf…og†ph†rg‡rh‡ujƒrf†ng…of†og‰siˆrfˆrfŽtj‹qirk‰sk‹tk‰sh…qf†rg‡sh‡rhˆtiˆtiˆrf‰rg„ng‡qj†pi„pg‚ld€lc€nf…pfˆshˆoeƒnf…og‡ph‹rkŒslŽun‡sk‡rj‚meƒne‡og…neŠqf‰qeŒthŒsiŒsi‹rhul‰tlˆrl†qhˆri‹uhslskŠpi‡ph‡qi†qi‡skˆuk‡sh‡sjŠrlŠpl‡tj‹tl‹tlŒumxqvp’yr‘wqunŽtmuowmyn”zp“xn’wm’xn‘zo’|u‘{s“~u{s‹um‰sk‹rg‰pgˆoh‹qk‹niŠje…i`„i_…j`‡lb…j`„j`†i_†i`‡ja‰nd‰nd‡ja‡ja…ka…kb‡nd‹qgŠmd‰neˆlc‰lf‡jb‰nd‡oa‡lc‡lbŠof‹ohˆleŠngŽnh‹mfŒoh‹oh‹piˆoh‹nhpjŒph‹phŒpgrgŒpjŒpiŒpiŒpiŒohŒoh‹ngŠnfshqfŽpiŽnhqjsmtmŽqkrk’qkŒpiŽqjslrkpipiŒof‹of‹neŒoiŽqjrk’uktisjplŽplsjŒpipipipiŽrk‹nhqh‘sjqhŽpg‘sj‘sjpiŽqjrkpiphrkqk‘rl‘rlpjŽpiqksi‘tk‘tk‘sj’si’siqh‘ri“tk‘ri’rl’rl“qj‘qj’rl‘qi‘riskqhpi’rl‘qkŽnh’rm’slslrkuntm‘un‘sk‘sm‘rmsmtmsj’rk‘slsn‘sn‘tm’rj”tk’tkui’xm’vn“to“vo‘tm”wp‘tm‘tm“vo”so”so‘tmrksjtj“un’un’tm’un‘tm’un’um“vn“vmsmrmqlslsl‘tm‘sj“ul’sj‘sk’um‘tl‘tl‘vnultmŽtj‘vk’ukph‘qkskrk’unslŽqjŽqjoislskqjŽpipjŽriqhrjŽrjŽrisktkslŽrlrlqlql‘qiqiŽqiŽqkrkŽtn’xmujtjŒqgririŒqkŒqjŒqg‹pg‹qgˆnd†mg‰ng‹leŠlgŠmhˆnhˆpjˆqhˆpf†mc‡nd†me‹md‰me‡kd†le…lc„nc†mc‰nfˆng‡mfˆnhˆoiŠqd‡me‡mg†mg‡pf…pb‡ob†nb„la„ka…ke„jc†mcˆoe‡md†le…kcƒibƒmb„mb‡lc†lb†lb…lb„kd…kd„jc…jc‡le†jc…k`ƒj`‡mfƒib…od…oc„jcƒib„jc€jajb‚kc„icg_€h]„k`„h`ƒgai^h_€iajbh_~k_„jcga€f_ƒia‚h`g^lb€j_k`€j`g_ga~eb|g^zgZ}e^~d^e\~f\{f[}i]{h\}j]~j]~j_~j_j^jai_h_}g\}i^}i^{g\f_fa~g_i_}g^}g]}g]~g^zf[{g[g]}eZk_|h]}f[{g\{g\yf[zf[zh]~kb~ja€ja€h_h_~i_|i\|j]~j_}h`yf^|hb~g`}g_~i^~j_}i`}gayi_zi]|i^j_k^j^{f^~i`kd{ha|i`yh[wf[{g^}g^ze[zf\ye[yf\zf]ye\yf[{g\{h]xf]zh^~h`|f_yf]yg]ub[we\wf\yh_xc]zc^{f]|g_zg_xf_wf]ufZve\td[ve\wf]ud[wf]vb[vd\xe]uc\tb[tb[wd\xe^yh_yh_yg\yg\yg\xg[yf^xf]wd\wd]{f]zf^xe]zi`wg_vf`uj`wh_te\xg^yf^xf]wj]zj^~j_~i^}l`}pc}k]~k^j`{g]{i]zj^qaZsc\r`Xp_Vq^VtaWtbWr_UsaVubWtdWrbUo^Sn\QkYOmYSmYQlZShUPgUPgWQiYRn^Wp`Ytd]oaYtg_{mgzqiwmdth`h[SfYQeYQeVNhVQmYUnXTmXWo\Zq^XubZye[|h]„nd…nf„me€ld‚og€ofƒohƒoh~mc}lc~mdoeme€ofngng„qi†sk„rhƒre…nf„meƒnf…qf†rg‡thˆrg†og‡ph‰rj‡phˆriŒujŠsj‰rjŠsk‹sjŒti…qf‡sh‡shˆti‰uk‹wl‹uj‡pi†mgkeƒmfƒng†og„ngƒog‡riˆsi‹ti‡qi„og‚me‚me†qi‰tl‡rj‡qi‚of…nf‡ph†qgŠrg‰re‰of‰pfˆoe‹rhŠskŒumˆqiˆrj‰rgŒsh‘unŽslŽtmŠtlƒmfƒpg†nh‰rk†og‡ph†ojˆrlvnvnŒumŽtmslŠpiŒrk‹qk‹qjslŽtmun’xn•{q“zp”{q’yowmvnŒvnvnŠrkˆpi‰qi„jc‚ha€g`†id‡jd†hc‡kb†ka‡lbˆmcŠoe‰oeˆkb‰lcŠne‹pfˆng…kdˆkb‰mc‡nd‡nd‰md‰lcˆocˆldŠmfŠmf‰lcŒod‰lcŠmdŽqjŽqjpiŽqjpiŠngŠmfŒpiŠohŠngŠmhˆlfŠlhŠngqj‹og‹pg‹ohŒok‹mg‹ngŒogpiphtiqgpi’slŽsltm‘un’vn“rl“rl‘slŽqj’un‘tmŽqjŽqjqgpgqhŽoi‘qk‘qkriŽrgriqlqmsiojoioiŽoioipj‘riqhqh‘ri‘riqhpiŽqjpiŒoh‹ngŽqjsl‘tmsloipjoitm’un‘tmsl’rl’rkqhqh‘ri’sj‘qk‘qk’rl‘qkoiŽqjŽphŽqg‘qlpjoj‘qkŽnhpj‘tl‘tmslsl‘tmsm“vm‘unsmsn“wp“xn’vkukuntmsm‘tntk‘ul’ul’um”ul•uo”vr’to’tosl‘tltj“rn“rlsl‘sl‘tktjsl‘tm‘tm‘tmsl’unsi’vksjrj‘sm’tn‘tm‘tm“vo“vm‘tkri“vo’unrk’unsm‘unŽsnŽsl‘vl‘sk‘qk“qm’to“up’to‘snql‘sn’rl”tnpj‘tmqjqjŽrlslqjslŽrk‘unsmrlŒpkpkpkqlŽqiŒohpi‹oh‹ph‘unukŠoe‹peŒofŒof‹nd†ng‰oh‡odŒqg‹oe‹oe‰ofˆkfŒohŒoh‹ni‡lfˆnh†ld†naˆpd‡od†mc‡lbŠnfŠng‡ng‡me†ncˆkbŠme‹pi‡mf‡oh…oh†mb…ld†lf†lf‰pgˆpd†nbˆpd„l_ƒj`„lc‚jd…ka‰pg‰oh†le…kdƒhbƒmbƒj`†ka†ka†lc…lbƒib„ib†jc„haˆle‡jc‚g_ƒib…kd…mblaƒma…kd„jc‚g`€ia€haia~d[h^€f]‚i_„i_ƒh^€g]‚i_ƒj`j_k`‚la‚jd~f_g_„mb„nb€j^€j_k_k_€j^~h^ic~gb|g^~j_€ib€gah]~g]~j]|i\}j^zgZ{h[}i^{h\{e\}f^~f`}f_{eZ{f[}j^}h^}f^}c]~g_~g_}f^}f^{d\{d\ze]|f^}d\~e]|f^{f^~j_}i^{g\|h]|h]|h]{h_|i`{g_~h`|h_zg_|hXk\~k^{ia|ib}je}ga|g`{h^}k`{j_zj^yh_yh_}k`{i^{i]{gZ|g`|g_zg_zh]yf\wfYyg_zg_zg_|g_yd]xcZze_zf_zf^ye\yfZ{g]{k^zi^}k`{g`xe^tb[wd]xf^ufZveZxd]vb[{f\{f^|g`{e_wd\vdYxe]vd[wd\yf^wd\taYvc[vc[xe]xf_uc\r`XvcZwg[xh]wg[xf^wbZxf[zg]zh]{g`yf^wc[yh\zh^wd\xg^zi`xh`vg^vg^wg^xg^wg^{h`wi\xgZ|j^{i]{j^xl]xiX{l\zi\xi\xh[zj^sd[sdZsbYraYs`Xzg^weZzh]vdYtbWtdWscVraTtcVtbTvbVr`Uq^WoZVmZTm[TkYRn[Tm[Tm[SjZShXQo`Yk^Vg[Sh[Sh[TjYRiYRlYRmZSr\Vq[Vu_Zxd_{e_|f_}i^„od…qf…og‡ph‚nfld~ldld€me‚md€kb„pg†qiˆsk†qi„qjnfmc‚pd‚peƒqf…nfƒld…nf†qi‰tlˆsmxp‰rjˆqi‡ph…nf†oi‰sg‡qgˆqiŠsk‹ulzowlwlŒuj‰shŠtiŠtiŠpiˆpi…mg„lf†qi‰uiŠqgŠsi…ph„og‡qi‰qj‡pi„og‚meƒnf†rjŠumŠum‹vnŠskˆqi…nf‡neˆodŠrgŠqgŠqg‡nf‰pivpŒvn‹umŒsisiŠqgqjŽsl‹pj…nf„nf„og‡lf‰oi‰qiˆqi‡ojŠpmŠrk‹tl‹tlŽtmsl‹piŠqgŠqg‹rhŒrkŒrk‘vo‘xm’yo“zp‘xnvltjŠng‡jcˆleˆkd†jcˆke‰og„haƒg`…ib‡ieˆke‰ld‰lcŠmdŠmdŒofˆkbˆla‹neŠoe‹pfˆng†le‰kaŠneŠoe‡lb‰mdŠldŠpd‡kb‡kd‡jcŒnfofŒohpiŒohpiŽqhŒoepi‰le‹oh‹oh‹oh‹oh‰lgŠmhŠlgŠmfŒmfŒmg‹oeŒpi‹mg‹mgpi‘rjŽnh‘qj‘sh’sgrk‘tmŽtmsl‘tm”tn“sl•sm‘tmsl’un‘tm‘tmsl‘ri‘riogqk‘rk‘qksithsj‘sorl“uk‘qk’sl‘qk“smoioi’sj’sj’sjqh‘ri’sjrkŽqjŽqjpiŒohŽqjŒpisl‘tm’rloj”rm’vopirk‘sl’rloiqhŽofqh’sj’rl’rl’siph’rlslŽqjrk‘qk“smpj‘qkoipjsk’um‘tmrk’un’un‘tk‘un’uosn‘un”xo•xo“zowmtkuo‘sm‘vl’wm‘tm”ul“tk’si“vo”vq‘tn‘snskti‘qk“sl”vo’ul’tluk‘tmsl’tn’un‘smsk‘tjsh’vk“vm’ul’un’un’un’unsjsk’ul’uo‘tmsl‘tmsl’unŽtmrkvksj’ql”uo“uo‘sn”vq‘smrlql”tn’sm’qkrkpiŒpiŒpiqjqjŒqjŒpiŠogŽokrlqmŽqlŽqlpjŒohpjŽrkŽskŒpiŒpi‹pfŒqg‹neŒofpgŽof‰pi‰ohŠqg‹pfŠndŠneˆnd‰od‰meˆle‰mf‡lfŠmfŠnf†nbˆpd‰qe†mc‹pf‹ogqj‹ohˆnf†mc‡ka‡kc†jc…kd„mf€jd‡nd…ke…kd†le‡me„kaŠnd‡nbƒl_ƒk_‚lb„mg…kd†le†le‡mf‚i`„ka‚i_…ka…j`…j`ƒja‚laƒhb…jcƒg`„ha„haˆkd†kd„jc…lbƒk`‚ma„nc…jc‚ha‚haƒld„mdh`‚i_„ka†lb„ka…j`‡lb„kaƒj`„kak`k`„nc€hbgak`€i_€j^~i[i^i]i]i]jaha~hc~i`€j_€ia€hb~i_~j`€lb~h\€j^{gYzhY|g]ze\{d]~g_~f`{d]f]|eZyfY{h[~h_~f^}f^}f^~g_}f^|e]{d\|h_}g^‚ha~e]~h`}h`~j_|h]{g\|h]|h]|h]zi\{i\|i[|h[~l_{k]m\k\}j]|j_|ia|jc|hczg`|j_|j^|l`yi]yh_~mc|ha|j_zh]zi^|g_zf\zh\yg\xf[vdYyf_yg_{i`{h`ye]xd\xg`yhazjaxi_zm_zk^~l_zi^yi^yi`{iazf_ud]yg^zh]weZtdXyg_{g]yd\ze^ze_vc\ucWzf_vd[xe]wd\vc[t`Yvc[ubZxe]xf_vd]vd\xh]wg[vfZyi]yf[ye\yi\xh\yi^yi]xg_zi_{i\yg\zg_yg`yi_xh[vg^vg^{ja{jayh_{jayi]{k^|k^|l_wgZxg[yj[xiY{l\zj]zj]yi]oaTqcVrbVtcZvdYweZweZxf[yf]wdZscVraTtcVzgZ{g[}h\yhYucXsaYs`Xs`Wp]Tp]Vp\Uq_Wq_Tp_Up`Vn]RqaWl^Tn_Un_Tm[QnZSq\Uwb[ze^jd…ogƒpi‚ofnc}j_ka€me…og€me}jb}lcldng†peˆrh†pe†pe…pe†qe„qf„qe‚pboaƒpd„qfˆpfˆph‰rj‡ph‡qk‰smˆrl‡ql†qj…ph„og„pg‰qg‰riŠsk†qiŠtjŒwlŽxm‹uj‰th‡qfˆrgˆrg‹qi‹qjˆqj‰rkŠsh‡qf‹rh‰rg‡rh†qi†og†ogŠqj‰qi‡nf…ofŠtl‰sk‹vkwlwl†pe†lb‡ndŠqgŒsitjŒskŒqk‹rkŠun‰skŒsjŒrishŠpiŒphrksl†ogƒme…qi‡ogˆof‹rh‹phˆmgˆlh†nhtmtmŒrkskŒrh‰rg‰shŠtj‰tiˆqi‡qi‹pe‰oeŠrh‡pe‡lb‡la‰kd†g`†ga‡haˆib…g`…j_„h_ˆjb‰kdŒog‰ofŒofŒofŠmdŠmd‹ne‰lcŠncŒpepg‹oh‹nh‹lgŽng‹ne‹pf‰ndŠneneod‰kd†jcˆjfŠlfngŒohŽpipiŒogpgŒof‹oh‰mf‹ohŒphqjŠngˆlfˆlfˆkcogognepfohokqm’ql’si‘pkphrg“uk’sk’un’vn’un•tn•uo•vo”uo‘tm“vo”wp’un’tm“vo‘tk’tlsjslskŽrk’rirg“tj“sn“rm”uk’ql’rl’qk“rl“sm“rm“ul“ulriri‘sj“tk‘tn‘tmrkŽqjŽqjslqj‘rl’tm‘rlpj‘sl‘tmrksl“un‘qkpj’tj’sj‘ri“tk’rl’rl‘risjrjrkrkrk’rm’rl’rl‘qkpj’tj’vmsi’sj“tk”vm”wn“ul’sm•vq‘totm’vm—zr–zq‘xl‘xmuk‘tm’xn”xp”tn“sm‘sith’uk’um“uqrmsl‘ulqh‘rh“vl‘sk‘tkuk’ql’rl‘pj’rl“sm•tn’tm‘skrksj‘tk‘tj“rl”tn‘tm‘tk‘tk‘uktltl’umsk’um’umslŽri‘tj’vl’vmtm’un’un’vo‘tmrkŽqjskŽqj‘rloiŒph‹ohqiŒphŒqhqiŒph‹pgŽqkslpiqiŠofŠpdŠneŠofŒqfŠpeŒqfrgpgogŒofpgne‹md‹qjŒqjŠneŽsi‰oe‰oe‰ndˆmc‰od‡ke‰mf‰mfŠngŠodŠpdŽtgˆpd‡nc‰oeŒpgqj‹oh‰md‰oe†mb…kb…kd…kd„jd…lf„me„me„jc‡mfˆmf†kd†la†l_ƒl\ƒl_jbidƒic…kd‚ha„ja„kaƒj`…jdƒha„ha†jciah`€g`h`‚haƒhaƒib…ia„gc„kdƒja‚k^ƒma‚ma„ka‚j_†lbƒncƒlai^„l_ˆod…lb„kaˆnc‡na…ha‚h`ƒk`ƒj`‚iaƒldƒh`ƒia‚h_‚i_‚j_‚j^h]€i]}hZ~h\~i]~h_}hcj_€j\la}h_}k^}ib~iai_€i]}gZ|hZ}i`|g`i_h^€j`i_‚h`g\{h[}j]}i]h_~h^h_€i`i`~g^g^|h]}h]g\g]}i]k_{i^}i^{g\~j_}i^}h]zeX~h[‚j]j\€l_}k^}k]~l_€l_la}k_~k`~hb}iala~lb}jaxf_|g`|h`}iazf^yf[zg\{f^|g^zi\yh[{j^|k_{h_yh^{j`{k`ye\xd[yi^xi^xi^|m`|ma{l_ja{h^xf]yg_zh^{f]xg_zh`xf[yh[wh\wi_zi^vd\xe^yf^wc\{h^vc\xe]yf^xe]xe]we]xe]yf^zg_xf_xf_we_yi_xi^vi]{k^|j^|g[xh[xhZzj^xh\xh[xg]xiYyi\zg`yg`xg\yi\xg_{ja}lb{jayh_zh`yj]xh\yi]xh\|l`wg[yh\xh\wk\yh\yg\{f_ocTtfWwfYxg\xgZtcVtbWubYxe\wd^teWveXueXzgZ}h\}h\{jZxhZvdYxeZuaVxeXxc[xe[vdZucXueXvfYydYtbWtcWrcWueYveYwcXyf[we[{i_nd„rg„rj„rgqd|k_|ka|jbia~jb~kcneof„qi„tg„sf‚pdocnapc†se…rb…qa…qa„pd„og‰pf‰pi‰rj‰qk…nh…oiƒmi†pk…oj„og…qg…rf‹qhŠsj‰sj‡rj„pg‚qf‰sg‰sh‰th‡qfˆrg‰sh‹rhŽtlun‰sh‰sg†qdŒqgŽtjwk‰tl‹tk‰qkqjŽrlsltm‰rj…mfˆsgŽxmŒvkŒsjŠqgŒrhŽukvlukŒrlrlˆogƒpiˆqjsiŽshŽriŠpiŒpirkrk‰rj†ph…ph‰shˆsgŒthŽtiph‹mgˆpjŽtn‘wqunukŒrh‡pc„nb„oc„nbƒlb‚kc†j`ƒi_‚k`€i^g]ƒh^…jcƒhbƒia…kd†kd…ic‡ma‡la‡i^‰k`‹pdŠqfŒoeŠmd‰lc‰lcŠmdŠndŠpeqfpgoimgmhpirh‹pfŒpfŽqhŒneŽnc‰iaˆjdˆkf‰lfŠmfŠnh‹ngŠmfŠmd‹ne‹neŠngŠng‹ogŒpiŒpiŒohŠogŒpf‹of‘shqf‘qgŽqgrlqm”sp“tm“ti–sn”rj’ti“uj“um“vo”vo“rl•sm—uo”uo“wp“vo‘tm“vo”wp’un“vp‘vl‘vlukŽrkslun’si’ti’sipk’rl“tkŽqj‘tm’um“vn‘tm‘tn’ul“vmsj‘tktktk‘tm‘umrkslsl’tm‘qkoipjrkpislslŽqjrksl‘qkpj“tk“tk”ul“tk‘qlpjriririrkslŽqlpkpl‘qk‘qk‘ri”ulwmsj“tk“sj”ul“vm–ul–to”to“sn‘rk“vm–vq‘tluiuiui’tk‘vm•vp”to•un‘tjvj’vi“wn’spŽol‘smsk”tl’sj’tkrisjtk“sm’rl”tn“sm•to•uo‘tpql‘tmsjŽrhsf‘rk“rkslsj’vl‘vmvkuk‘tk’ulri’sj’sjqhtivj‘vkuksj‘tk’tkriŽqisj‹piŒpiŒmgŒmf‹lf‹mgŒqf‹pfˆncŒrgŠoergŽqhŒofŒof‹re‰ncˆocˆmdŠpe‹qe‹rerdŒqdqgŒnf‹neŒneŠkb‹lbpiqj‹pfˆoe‡nd†neˆmc‰ndˆmc‰md‰ng‰mfŠmf‰mb‰oc‹rd‡pb„l`…mb‰pgŠng‰mf‰meŠod‡ne‡ne‡lf…ld†jd†jd‡pi‚lc…kd†le‡le„ga‡kb†l_‚j[‚k\€jake…keƒibg`€g]‚h_i_ƒib…haƒg`ƒg`haia‚kc‚kc€ia‚ha„jb…kc†ie„kd‚i^…ma‚l`‚laƒk`ƒj`„kaƒmb‚l`la‡ob†mc…lbƒj`„j_†l_†kb†kbi^‚i]ƒi`€jbƒi^†l`‚i]‚f\‚h]„j`‚j^i\iZ€j^~i]~ia}ib~j]~i[}h\{h]}k]zh`~ic~h`h_~h\~k^~ha~ib~h^i]‚l^k[‚g_g]k]k^|i]j^~h]k^i\~h\}g[h\|j]|h\‚j^g\|h[~k^}j_yh]}i^~j_‚k`h]}e^€g_|c[~e\{e]|i`~nb|j_~l_}j]~i\€k^~j_~k_}i^‚nd|jc|gb~gag`{f^ze]ze\zg\|g`|h]m`{k[}l_{i^yg\yi^vh[xh[zh\yeZxhYwfXyh[xf[zh\{i`|d^|f`zg_zg]}i\yeXwe^yg_xf[yi\yi]ui]wg[ve]vd]saZud\tdXye]ze^ye]{f^yd\yd\xe]wd\yf]|jcxf_yf`xh_wh_xj^zj^{i\k\xh[yh[zj]zj^xh\ueXxiYyj]xg_yf_yg^{i]zi_yg^{k`xh]wf]xh_xh_xf]yi_zi`yh_xg^zg_|l_zk^yi\xe[|d_qdXqbXqcWsfYue]sdZvfYufWwgYyh]{h\{h[zfYzgZ{hZ|i\}hY{fW|fY|gZ|h\~j_lak`~j_{g\{g\{g\{fWyfZyd\xd]yg\{k[}na}m`~l_€l_|k^}m`ƒnb†odƒnc€mbl`€ocƒncƒnd‚og~me|leykd€pf‚qf…rf„ob…nc…pg‹sgˆti†vi…th‡rg‰pe‚nc‡pg‡ph„lf…nh…oi…pi‰tkˆth„qd„ofƒng‰oiŠpk‹pjŠqi‰ph…mfŒql‹qjŠpiŠrg…qf…tiqk‹slŒum‹tl‰qiqiŒrgwl‘xn‘{qŠwoˆtk‰pfŒsiŽukvkŒrhŠqf‹rhŽunŽwq‘ysŽyo‰vi‹qh‰niŠpkŒrlŒrk‹rh‹tf‹shŒrkŽtnŽtmŒsjŽpjŒpi‰rjŠskŠsk‰rjsiŠshŒumŽvn‘uo’toŽtlwmwl‹rhŠrhˆngƒld€g`€d]e^„f_…f_ƒh^ƒh^ƒh^‚g]f\…j`ˆmb‰neˆkf‰lg‡kc…j`†l`†j`…f^‡h_ˆkeŒoi‹qf‡mc‰ncŠngŒpi‹mh‰ohpiojoimgŒnhqjqk‹oi‰mf‹oh‰mfŠmbŠldŠmf‰le‹mfŒpemcnemdŒmdneŽne‹pjŠnf‹qfqfshpfŽohoj’rl’sm‘qk‘qk“rm”sm’rl•uo”tn“sn’sm“tl“tk•wl‘ri”tk•uj•sk“sn–vq“uo”wq”ul”to•up”to•to”ul’uo“vo“uoslrksl’sj’sj•vm’sk’skqhph•to•up•tp”to“sjsl’uo‘tl”tk–wm”uk”to’qm’sj‘ri‘th‘sfphŽrkrkrk‘tmsl‘rl’rl“rl’rk‘ri’sj’ul“um“sn”tn’tltjuktj’si‘rlqjuntmtm”un’rl“tk‘sk’tq‘tn’vlth“tk•uq“vm“um’vo’un‘tk“wl•wk“tksk‘tm‘umŽuh”tn“sm”tn•uo”tm“sl•wj“vm‘tm’tn‘un‘wl‘uj’vlsjrk‘tk‘tjrm’tp‘um‘tm‘tk“vm“sm’rnŽolŽplŽqjrhsfrgsj‘tkvisfrksl’unsmsmrk‘qlpj‘qk’tl’ukŽsiŽririqgqgpgqg‹nhŒph‹qfŒqe‰ncŠoe‹nh‹ohŒmgmgŒpi‹pgpgŽqhŠngŠog‹pfŠoc‡pe†nd‰oe‹neog‘pgŒocŒqe‰pe‡mcŠnfnhnjŒoi‹ohŠng‡me†lbˆpjˆog‡phˆph‡ph†mf…nfˆpe‰pf‰qe‰nc‡laˆkf‰lgˆpj†nf‰nfŠof†pc‡od…kd„jd†jbˆlcƒk_†ld…ke…ke…ja…k`…m`i]‚j^‚j^„l`„l`‚hbƒic‚ha‚i_ƒj_‚k^†j`…j`…j`ƒh^ƒh^…j_„ib‡mf†le„nf‡ri‚lc„kah^‚i_i_„j`j_€k`k_„lb‡mc…lb†mc†mdƒic„ic‚kc‚kcƒlcƒkdia|f[k`k_~i]‡jb…ibgag`ƒic€h`i]ƒk_€i_€j_k`~j`‚ice_€g]ƒj`h_‚jc„jdhcga}f`j`m`ƒicƒja€j_€j_~i]|i\…m_€l_}i^k`|g^d^}h\i_€i`haga‚ic}i^€h^f\f\g]}i_m_|h\|i`|h`zh[~h[}i^}i^~ia{f^|f`|g`}ibia€iah`ia|i`|j_~k`~j_k`j_h^}g`~gaga{f`xf_zjb{k_{k_{k_zk_{k_yi]zf^zd^xd]yf^weYweZxeXzfZudWucXxf[}k_}h^ze]ye^|ibxe^yh]|e]|f^wd]yf]yf_xc[ub[ye[zeYxcWxfZyh]|e^{e]}h`zg_xe]yf_xf[xe^{ib|idyhawhayg`yh_yi]{i^zi[zjZvi\vh\xh\xh\zh]zh]|j]ye\xe^ye_we^yh_wj]wi\xhYwgYzh]yf^zg_{g_{h`{i^{i^yi]zj^zi]yh[|h]{f\{c]seYoaUpaUqcWsd[seZueXvgXwgZxh]{j[zhYzh[xfYvcWxeY~i[|hZygY}k^~k_|j_}k`~la{i^{j_yg\xf\|i[}h^~ic}jc|j`{j]|l_}m`€m`}k^|l_}m`€mb‚od‚ododnb€ndma€ma€nb€nd}mb|mb|kbod„qd„pc„od„ph‡qg‡sjƒrh‚rg…qg†ofƒmg…ogˆph‡ph…oh†qk„ng†rh‡sh…qfƒoeƒmfƒlg„ng‰tl‡qi‡qi†pgˆqiŠqi‰ohˆof…qe‡sh‰ngŠqjŒumŠtkŠrj‹qjŒskvmxnxq‹un‰sl‹ri‹qiŽtlvmŽulumwn‘xq‘yrzqzrzlŒriˆog‹qjunŽtmvmvkunvoŽtnunŽtmŽqj‹pi‰qj‹tlŒum‹tltjujvnwo‘vp’uoŽsiŠpfˆndƒi_„j`ƒi_€f\~eZƒh^f\ƒf]…i`†ka…j`†ka…j`ƒh^ƒh^‡lb‡kc‡jc†jd…ia…j`ƒj^„j_e\ƒh^…jb‡ld†lb‡mc‡lc†kdˆmfŠohŠngpiqjoi‹mf‹ngŠohŒpi‹ohˆle‰mf‹pi‹neŒog‹ng‰leŠmeŽrgŽohŽogŽogŽofpfqgrlrjshrgriqjsltm‘un‘tm‘tm‘tm“sm”tn“sm“sm”tn”tm“so“tl’sj“uj“tl’sjti“tm–vo“sn”uo”vo–vn”to”to•up”to–wn•xq“vo’unslrjsm“tj”ul’sj“ul“tk‘ri‘ri“sm•up’rmpj“tjsl‘tmsk“tk“ul’tj’rk‘qjqh‘rhqfpfpislqj‘tmrkrk‘ql”to’rm’sj’sj“uk‘tk”un—wq”tn“um‘tk’xmtjri‘slslŽrktl“tn•uo’rlrlrjrn‘un‘ujti”um”to’ul’um‘tm“vn‘uj’wl”uk’tkŽqjsmslsj“sm“sn–vp“smqk’sm“uj’vlsl“vo“vm’xm’wi’ulskŽqj’um’ul’to‘tmrkslrk‘tk’tlslsmrjŽsiŽthŽrfŽqiŽqiŽskŽtjvjrkŽqjŽqjrksl‘tm‘pjoiŽohŒpgriŽqhŠqg‰rgŠrh‡qfˆqg‰qgŒoj‹oi‰neŠnf‹pg‹oh‰mfŠngmgpiqjŒqhŽrhri‹og‹ohŠof‰oc‰neˆnd‰nd‹neŒne‹lc‰ncŠod‰ndŠpfŒogŒogŠlgŠngŠog‰mf‡mcˆpfŠngŠohˆmfŠoh‰ngˆmfŠpe‰oeŠqg‰pe‰od†mb‰lf‡ke†nf‡ngˆmf‰lf†nc†mb†le…jc‡jb‰nc†md†md†le„jc†kb‡kb„l`…m`ƒk_„l`†nb…maƒic‚ha‚haƒj`ƒk`…na†kb†kb‡la…j`…j`…i`„la„k`‡ndƒma…nc„nb„ka‚j_h^‚i_ƒj`j_€l`‚kaƒka„ka„ja€j_„jc‚ha„jcjbjbjb‚jc€ha€j_‚la…od„nb†ib‚h`ƒib„jc…kdjcƒk`„ka‚l`jaƒkd€kcƒje€ibka‚lakbƒkd„lejd€icic‚ndna„kb…mcƒmbh]j]j]…m`~j]~k_~j_|f^g`i^k_€j_i`~h^€j`~i^h]~e[~e[~g\}h]i]}i]yg^zg^{g[~h\}i_€kb~ia~ia|h^}h_~kckc€ia€jbkc~jc~la}k`k`}i^}j_€k`~i`j`‚ka|h^yh]yj`|l`{k_zj^zj^zh]xg\ze\ye[wd\yf^yf^zg]{h[zgZzg\yg\|j_|i`}h^|g_zd^xe^xe]xf[~f_{g`{g`yg_xe]ye]we^ye\xeZ{h[|i^zi]we\zg]yh^yf]yf]{h_zh]zh_yg`zgawe^ue]ve\wf]xh\yg\xg[yhZxh]wg[vfYyi]zk^wg[{h]yf]zg`yg_yg`yh_yh[ygZxhYzi\{i]{h`xh_yiayi`wj^yl`znayi`wg\yi\zi\{h]}g^rdXseXrdYtfZvh\vi\wgZwgZvfYvfYxhWwhWueXueXtcYwe]{j\}l_}l_{k^zj]yi]zh]|j_{j^}k`yg\zh^|j^lele~kd~kc|j_zi]|j_}k`|i^|k_}maod‚peƒsgƒsgqe€pd}l_|k^}l`}m`}la}la~ia‚nc‚ob„qe‚peld„ogƒogog‚qh‚phƒog„nh‡qjˆqiˆqiˆsh…qf‚meƒnf†rg…qf„ogƒnf…ph„og‡rj‡sj‰ujˆti…ph‡qiˆngˆng‡pf†qe‰rjŠskŒumvn‹tl‹tl‡pjˆqk‹smŽvpŽsn‹qksmŽtnŽtnuo’xr’xrunumŒvmŒumŽxmŒwl‹qh‹qiŽtm‘wp‘wowmunŽtn‹pksn‹smŒumtmun‹tlvnvnsltj‹qgˆoeˆoe‹phŽrjˆnc†kae]}aZ‚g\…k`…i^„h]ƒi]…k_„l`…ma‡lb†ka‡lb‡lb†ja…j`…j`…j`„ha…ib‚g]ƒg]h\eZ€e[€e[‚h^‚la†mb„kb„jc…kd‡mf‰oiŠngŠngngmgng‡kd‰leŠmfˆkd‰leŠnf‹ngŒofŒofpgŒog‹neri‘qloj‘ri‘risfrd”rj“ri’rg’sj‘rm’toul’wm’vm‘vluk’vm”tl•vl“sm“sm“sm’rl”to“tl“tk•wl’sj’sjuj’un”tn“sm•sl—vm–wn”tm“sn“sn’sk–vm—zs’unrkslrkrk“sj”ul’sj‘ri’sj‘ri‘qk’rl“sn“sm’rl’qksjriŽri’sj’sj’sj‘ri‘ripgoimg‘qjqjrlsk‘tmŽqjŒqj“qm”to‘ql‘risg’ti‘tk“tm”tn’ql‘rksi“vmsjsl‘tm‘tm‘tm”uk•ul–vp’um‘untm’to‘tn“vm‘uj‘sk‘tm‘tk‘tm’un‘tm‘uk‘ujrirkrmrmrmrl“sl“sj“umsjrjsj’rl”un”to‘tktjti‘ujtjrkrkŽqiŽqhŽqjrkrkslŒohŽqjrhriphriŽrg‹peŽriqjŒpjpkskrhŽqjrkŽqjŽqjphpiŽqhpgŠmdŒofpgof‡oeˆod‰qfˆoeˆoe‰pf‹oiŒojŠmh‹niŒoj‹niŠng‹ohoioiqiŠng‹pfŒqiŠohˆle‹nf‹neˆmc‹pf‹pf‹pfˆmc‰nd‰lb‡mbˆmcŠpeŠoe‰lc‰leˆkd†jc‰ndˆndˆoe‰lf‡kd‹oh‹oh‰mf‰mfŠoe‰nd‰pf‰pf†odƒmb…lb…lb‡mfˆng‡mg†ke…la…lb†mc†ke†leˆng…lb„jc…kd‡lfˆle‡lb†mc„kaƒj`…lbˆoe†mc…kdƒib…jd…laƒi`ƒj`‡lb…j`…j`„i_…j`‚h\‚i_‚i_„kaƒnb…nd‚maƒib‚h`€f^‚haƒjbga‚la€i^‚h_…lb„lb€j_‚i_ƒj`‚i_k`i_i_k`‚lb‚laƒmb„nc‚ma…jdƒibƒib„neƒld‚ld„ka„kaƒldƒld„mekeke‚nekd€k`€la€la‚le€jc}galdƒne‚ob†od†pek`€j_€j_i^‚j^k^~k_}i^|g^€g^€j^€j^i^~h\~h^}g\~h]~h]~h]j_~h]~h]i^}i^{i^zh]}i^}h\~ib~ia}h`~j_}i]~j]ld~kbjb‚kc|h`|ia~la|j_zg\~i^~j_~j_€laj_€j_|h^zh]xj^}l`{k_zh]{i_zg\zh^~j]{g[zh]{ha{ha{h`zg[{g\zh]{i_{h`xe^|e[|e^|f`zd^}g_yeZ~e`|hbxf_xf_xe^yf_zhazh_yf[{i^yh\xf\wh[wj\yj\zj]zi\xgZxh\vf[xf_we^vd\wf\vd\wf\xh[xf[wfYyh[{g\xf[wfZyj^wi]wi]{j_yg_yh_xg_zh`yg]|g[zfY{h[yh[{i^{i^wf]wf]yi]yk_xj]xj]uf]vh]zj]yi\{j\zh\rdXtfZseYtfZsfWtgZwg[xh\wg[ueXufUvgWwgZxi[xh^ve\weZxf[zi]xi]zj]yi\xf[{j^nd€nc€nc~mamb|ia}kc~ld~kc{i_|g\|i^}k`}oa€pd~nb}ma}maoc€odnd€ncod}kanaƒpcƒoc„rdld}i^}l`~m`}k`nfkcnf‚pg„rj„sjƒqhƒmg†ph‡ohˆrg†qg…re‚nc‚me†qi…oh…ph‡rg…phƒnf‚me†rg†rh‡th„pd†qgˆohŠpi‹sk‰rj‹tlŠskŠsk‹ul‹umŠskˆrl‡rlŒtnwp‘vpvp‘wquouoŽtn‘wq’xrvptmŽtmvk’yo‘wnwkŽujŽtlŽumvl’zn’uotnŠqlŒrmvoŽwn’uo‘voŒum‹tl‰qi‹pj‰pfˆoe‡lb„i_†ka…j_ƒi]„h`‚e_e_†jb…k_ˆkaˆka‡la…k_…mb‡oc‡lb†kaˆmc‡lbˆmc‡ka†kaƒh^„i_‚h]e[e[}f[e[eXgZ‚i]k_„ibƒib†kd„jc†mc†maˆleŒmfŒlfŒlf‰mfŠngŠmf‹ngŠnf‹nfŒohŒohpgriŽqhpgpgqh‘ql‘qkqh’sj‘tg’uh“ri“ri“ri”tl“tn’so’vn’wmŽsitj‘vl’vl•ul’tk”ul”tn’rl‘qkql‘tl‘tkti‘tlsj‘ujqj“sm’rl–vl—xl–wn•un’rm’rl”um—xn•xq’umsl‘tmsksl‘rh‘ri’sjqh‘riqh‘qkphpf’sj‘qiŽnipg‘qi‘risjphŽriqgpg‘ripjojpk‘qkpj‘pj’rmpj’qk’rmpk‘qkqh‘rh‘sh‘tk“tm‘qkpj‘sk’ul’unsl‘tm’un’ul“ul—tk•tl—xm‘tnqjŽrk’totl‘tl“vmsi‘sl‘tk’umrkslrhŽrgŽqjrk‘tm‘unql“vp‘ri’tk‘tk‘tksisi‘ql’sl‘ririrhshsgqgrkpiŒohpgŒohŽqjrlrkŽqiŒohpgŒofŽrgŽrgŒpeqfŠofŒpj‹ni‹ni‹oi‹pfŒnhŒohpi‹ngŒohpiŒrg‰ndŠmdpgŒofŒofŠmd‹meŽqg‹ofŠndpgqjŒojŠmhŠmhŒojŠmh‰mfŒphoioiŠng‹ohŠpfŠnf‰lg‹mgŠne‹neŠmdŠoeŒqg‹pfˆnd‰pfŠoeˆmc‰lcŠmd‰nd‰od‰ke‡jcˆmc‰ndˆnd‡od‰mfŠng‰mfŒpi‰mf‰mf‰ndˆmcˆoe†mc‡ne„me…la‡nd‡nd†kd…kd„jcˆnd†mc†mc†mc†ke…kdˆnh‡mf‡nd†mc‰leˆle‡nd†mc‡ndƒj`†mc…mb…kd‡le„jc„ibh^ƒj_†jd‡lc†ka…j`„j^ƒi]ƒj`‚j_„kaƒmb…odƒnbƒhbg`g`ƒib„jc…jc€k`ƒkaƒj`ƒj`„lb€j`k`‚la€j_ƒj`h^„ka…lb†mc‡nd…ka…lb‡nd‚hb†me…jd…nf…nf†og‡nd†mc…ncƒldƒkcldld‚ld€kcjb‚ncƒnd€la~ia}h`ia~i`naƒla„nbk`€j_€j_€k`ƒk_~j^~j_}i^j_ƒj`j_€j_~h\}g[~h\€j^~i^€j_k`~j_i^i^k`~j_}k`lbmb€j_zf]|g_~j_}i^}j]~j\|jc|h`|g_€kc}ia{g`~nb|j_xg\}k`k`}i^~k^~i]€i]l_wgZxk]zi^zi^{i^zh]{h]j_|j\|i\{i^zh]xe]wd\zf[~j_zh]xe]vc[yf^zeYyd\|f_~hb{g_wf[|e`|hawe^we^xf^yf`zhayg`{k_yg\yf\yf]wj\xj\wh[wfYyhZwfYwgZve[uc\uc\ud\wf]wh[xh\zj^wdZxf[yh[|f[yfZxf[vfZyk_yk_|jbyi^zj]yi]vfZwf[{fZyfY{g\zi]|j_zh]yeZzf[yeZyg[yi[ygZugZwj]{k^yj]|k^zh]tfZug[ug[ugZtfWsfWufYxg\vfZueXvfWvfXwgYxgZxh[wgZwcYvcZvdYwfZyi\{k^{l_~nb|l`~nb~nb€pd{l`}lb|la}kalc~lb‚la}j_}m`}maoc}namb|j_~lambodƒpe…rh„qg…pg„peƒncob€ld}j_|k_zi\€la„nfƒmcƒneƒofƒof‚pg‚qg‚mdƒnd…od…od†qe„of†rg„pf…pi…oh…qg‡sh‡qi…of‚nc…pe†qf‰ti‰rg‰pf‹riŠpiˆrjˆtk‰tl‰tkŠqj‹sk‰tl‰um‹unŒunŽwoyo‘xp“{r‘wq‘wqŽtmsmsm‘wpŽvpŽunŽuk‘xn’xn“yp‘ymvk‹riŒrjŒshŽvjsmŽqkŒrltmvmŽym“wqŒtlŠrj„meh`…hbƒj`ƒj`„g^„g]…j_„j^†k^„h`…hc‰kfŠme‰nbŠne‹oeˆmb†ka†lbˆnd†ka‡lb†ka…j`†ka…j`„kc‚i_i]€h\}dZe]~dZdYdX€fZ‚h[„k^„g`„h`„g`‡kbˆlb‡kbˆkd‰kd‰icngŠmf‰mfŒofŽqgŒoepfŽqhŽqgŽqk‘tlŽrhqgphŽrk‘rj“tm’sj’tj”uk•wm’rm‘rk“ul“tl’sn’so’um’ulsj‘tk‘tktk“uj“uj“tk”ul“sm“smql‘tm’ul‘ui‘tktk‘sj“ul”to’rk“uk“wj•wl•vn•uo’rl–wn–xm’ul‘tj‘tkriŽqgŽqgqh‘riqh‘ri‘riqhpjpfŽofqgpg‘qjpgŽof‘rirjŽqkŽqj’rkphoipjojokoipjpj‘ql’rl‘qk’rj‘qi‘pkpj‘rj’rksj’tl‘qk‘qk“um’ul•snrksl’ul”vm•ul—tj•tk”vmrkqk‘rm•tn”un’un‘tk‘uktjri‘tl‘tm’un‘uk‘uisl’vl’uktj‘rk’rl’rk’tkritjŽsisi’qkphqgndphqjŽrgphoiqlpipi‹neŒohpirkŒohŽojqj‹ofŒpf‹od‹oeoe‹neŒphŒmhnhŒogof‹ngphpi‹ngŠmfŒofˆpcˆnbŠpdŒrgpgŒof‹mdqhofofŽpgŒneŠpeqjŠnhŒojŒoiŠnfŠnh‹ohoioi‹oh‹nhˆoe‰mh‰lgŒnh‹mgŒmeŠpfŠpfŒrhŒrhŠpfŠpeŠog‰md‰lcŠnd‹od‰pd‹meˆlbŠpeŠoeŠqdˆqd‰mfˆmfˆle‰ngˆmf‰mg‰oe‰oeˆng‰oh‰mg‡lfˆnf‰odŠoeˆmbˆmd†neŠnf‹pfˆpd‡od†md‡ohˆmgˆof‡nd‡md‡lc‡jd…mb…la†mb‚i^…lb…mb‰md‡kd†ib…ib†ic†jb‡kd†jc…ja‡mb„j_†k_…nb†nb†nb„obƒma„naƒhbh`g`‚ha†le…kd‚jb„icƒib„jc‚kd~ib‚l`‚lala„ka„ka…lb…la‡nd‡nd‚i_†lf†le†le…meƒld„me‡ph‚ne„l_„m`ƒmb„nb…oc‚ndƒla‚lc‚kcjb…odƒn`‚ma~j_g_€h`j_„la~i]l`k`ƒmb…lc‚h`ƒkaj_~j_~j_€k`i_}h^ka{g]|h]~k_|i]k`j_~l`~k`~i^€j^ha~j^|k^}l^ma€ia|i]}i]{g\|h]{g\{h[zh_zg_kb€kc}jb|jb{l_zk^|j_}k`}k`|i^|h]}h]€i^}j_xg[wi]zi`xf^zg_}h`}h`~f_zgZ{g\{i^xf[weYyh\{f\zfZzf^xf]we\wd\zg\|hazhavd]ucZvfZzf]we[ueZwh]xh]xf]we_vf^wg^wgZyf\{e]we\yg]wf\yf\yf]we[wh[vfZve\wf]xe]yg\zj^wg[vfZucXvdYxf\zeZzf[xf[xf[wg[zk^xh`xj_vh[wfYueYufZzhZyh[yi\}jayh\xg[{f\|g\{g[~j^zh[ygZyj\zk\{k[wgXyf[zd]qdVsfZseYrdXreUpcTscWue[ve[yi\yg[xgYueXveXudWveWwc[wb[zf[{i^}k_pc~nc}mazj^yi]yi\|m`wi^zj^|l_~oa€nboc‡ngld|kbyja}mc}lc~lancma„od†qfˆshŠrlŠsn‡rk‚memcmb{i`{j^{k^~m`‚laˆnf†nd…ncƒmb€lancnc‚na‚na†pe‡pe†phˆrkˆuiˆtj…nhƒmgƒoe…reˆohˆogŠqf‰qg‹sgŒthvmŒsi‹rh‡nh„og…sk‡tlŠtlŒrkŒslŠulˆtlwoŒun‹tkvk‹uiŒwk‘vovoŽtmslun‘wpxrwq‘wnŽti‘vm‘unvkŒshsiŒshŒtiŽvj‘ultlrkŠph…qf†qdŠph‡ng€jbg_}b[€d]ia‚i^…h_‡i^…j_„i]†j^†i`ˆkeˆidˆkbˆma‡kc‡kd‡kdˆle…ia†jc…j`…j`„i_‚g]…j`‡kaƒib‚j^j\~gY~eZ}c\f\€dZdY…g\‚hZ„j\…fa‡g`ˆib‰jaŠkbŠk`ˆkdŒlfŒkfmg‹ohŠoipfpgogsjrisj‘tm‘slshqfŒogrlrh’sj“tk“tk”ul”tl‘tpsnsmtj‘sl“sm”ul’sj‘ri’sj’sjqh‘th’ti’sj•vm’rl’rm’to“vn’ulujsitk—wm—vm”to“tj’vk’xj•wl”ul“sl’rl”ul“uj‘tkqhŽqhpgpgŽqh“tk‘ri‘ri‘ri‘ripgpjŽpfqeŽpeqfohoeŽofnetkŽqkŽqj’qkoioioj’ql‘qlŽnini’rl‘qk’rl’rk’tjrhpg’rm‘qlpltj’tl’rl‘qk’tl’ul•snrksltj‘sj•ul—uj‘rh’tk‘un’sn”sn“sm’qk‘tmrktjuk‘tk‘tm’un’un‘ujtitk’vkuish’rkoj‘riqhsjŽsiŽtj‹si’qj‘pgrgqgŽnholŽqgphrlrmpj‹og‹neŒofohŽqjŒmhojŒoiŠof‹odŠncŒneŒle‹oeoeŒlemfofmdŒng‹ngpiŒoh‹ng‰mf‡o`‰pdŠpd‹qeŒnf‹ne‹pfŒqgŒqgŒqg‹pf‰ndŠpd‹peŠng‰lgŠng‹of‹pi‹nhŽnhŽnhŠng‰mfŠqhˆngˆkfŠmgŒnhofˆqg‹qg‡nd‰peŠoe‰nd‰nh‰md‹mcofŠocŠrfŠnd‹ne‹qg‰oc‰pd‰qe…ng†of…nf…nfˆph‡ogˆrg‡pe‰pg‰ohŠmgŠniˆpi†kdŠoe‰nd‰pd‡peŠog‹qeŠrf‰pd†ne„mf…le†ld‡ob‡ocˆld†ic…kd†le…kd„jc…ld„jc‡lb…j`‡kc‡kd†jc‡kd†ic‡kd†ja…j_†l^†l^…m`‡od†ma…oc„ncƒna„jc‚ha€g_„jc…kd…kd…kd„jc†jc‡mfƒmeld…od„ncla‡mc‡ndˆoeˆpcˆoe…lb„j`„jc†le…kd†pg„meƒldƒnfmc†o`†o`‚m_‚l`…pc„pc„ma…lcƒib…kd…laƒk^€j^€h]f_ƒib…ka„k_€m`l_~h]j_‚j`haƒj`k`‚mb}i_~i^h]~ha~hb|g_~i`j`~j_€j_‚mala}k`~i^~i^~h_{g[|k]~l`~k^i_€m_~k_xeX~j_zf\{g_{j`}jb~jblc}kb|kboc~nb|l_|j_~lazi^zg\}h]j_€lazi]xj^xg^yg^zg_}hajc~g`{f^}h^zh]yhZ{j]wgWzf[yd[zg_ye^yf^xe]wf\we]xf_we^uf]ug[xdZveYtdXvi[wh\yh]vd^ue]te]yk^|g`}f^xbZyc\zd\wd]xe^vd[vh[vgZve\wg^xd]xf\vgZueYvfZwfZvdYvdYzf[wcYzg]yg\weZxg[vg_wh^thYueXvgZwg[viYvi[xh^{i`yf[udWyf[zi]}m`yi\yk]yj[zkZ{kZzjZygY|f^|d_q`WraXucYreWtaYucYxgZvdWudVvdZxh\xg[zf\{f[|eZ~f\€j_k`{i^|j_yj^yj^€j_{i]xh[wg[xf\|ha}ic}jb}k`}k`~lb‚ng†nf…neƒnb€la}jald€mengngof€oe€od‚qhƒriƒpf€ob}k`mb€kc€kblb‚naƒlaƒna€lbƒncnc‚ncƒod„od„qd†sg†rg…ph„nh„ohˆqi†rkƒqhƒph‰phŽqjrmŒum‰tm‡ti‡ti‡rf‹uj‹uj‹uj‰shˆrg‹vkŽvkŽymŽxoŒum‰sn‰sm‹rotnsiuisltovnuovounslsl‘vnunvn‰skŠtlˆul‘vqŽvpyqŒumˆtj‰ti‰qeˆpd†nc…maƒj_€h\ia}g]}fY‚h]ƒg_„g`ˆmbˆmc†ja‡ja‡i`ˆi`‰g^‡h_ƒj_‚kb†jd‡ib†la‡la†ka‡lb†ka…j`…j`„j`„i_„i_‚g]ƒh^ƒh^„h_„i^ƒh_„i_„i_„f]…f]…f^…f]…h^„j`†hb…hb†ka‰ndŠmcŒohofofpgŽqhŒqgŽshslshsfŽtgvj‘uo‘tj’ul‘si“sl’qk”sl“tj’ul‘tm‘un‘tk•vk“uj’tj‘ri”sn’rm’rm’uptlŽqj’uk‘tkri‘tm‘um“tk”ul•vm—wn”tn—wq–up•uo•uo”tn”tn”um•vm“tk“tj”vk“wl‘uk‘ql‘qj‘ri”ujsjŽqhŽqhpgŽog”tkŽqkoioj’rl’ql‘qkpkŽnhoipgqh‘riohmg‘qk’rl‘pkŽnhoj‘phofod‘qgriqh‘ri‘ri‘ri“tk“tk“rj‘oj‘ni’qh”sj“sj’rl‘tm’un’untm‘un’vo’un•uo–tn•up•uo“vo”rm—tn•sm—vp“vo‘tmslsj’ul’ul’vkŽuiuj“vn’um”tk’ti‘sj“sj“tk‘ri’sipislsitjuhviuj‘nk‘ojqh‹peŠneŒphŽoioipjohoinhŠoe‹peŠqcŠncŒoeŒogŽne‹md‰nd‹pfŠoeofŽqjŠng‰mfŒohŒohoh‹ohŠmc‹nepgŽpeŽpdŠneof‹neŒofŒrgŠpe‹oioiŒoh‹neŒmdndŽqjpi‹ng‹ph‹ohŠof‰odŒphŒoh‹ngŠleŠla†lhŒojŒlfpgrg‰rfŒrhŠpfŠoe‹ne‰lfŠlfpf‰lc‹ne‰nd‹pg‹pf‡ndŠod‹ne‰kc‰nd‡nd‰mh‡mgˆngŠqg‹peoeˆnfˆne‡pe‹pe‰neŠmf‰nc‰nd‰nd‰oc‰od‹pd‡pf‡pe‡pf†pe„ncƒmb„ndƒnc‡nd‰mc†j`ˆlc†kd†mc‚i_‚i_‚j^ƒk`‡lb„lb†mc„lak`‚l`†ka†ka…j_ƒibƒib„idldldƒlcƒld†kc„ic‚iaha„jc…kd…kd‡me…nf…pdƒma…od‚le‚lf…re„qe…od†pf…ogˆng‡qh‡phƒld„meˆqi…nf†og…nf…nf„meƒld€kapbƒoc…lcƒj`†ld„me‚kd„meƒldƒld„me‚lcjah`‚kcldƒme€lb~naoc€k`€j`€kd€kdi^„j`‚k^‚l`ƒla€l^~ib}i_~k^~k_l^k`l_€m`~m`}k`zi^{k^{jbzg_|i`~kbkdjam_~k\~l]k`}i_~ia€nb~l`~l`~l`{j]}k^}k`lc}jb{h`~lb{i]{j_}j_}i^|h]|j_{k_zk_~j_~f\}eY~i]{i]vdYyg]zg_zg^yh\wgX|dZ}g\zi]zj]wg\yg`}fZ{fZ{f\ze]zg_xf]|d^|f[{eZyd]ye\ygZzf^xd\yg^zh`yh_yg_xgZxfYyh\|j]xf\wd]tg^xg_xf[xf[yh[xi\yd]ye]{f_zf[wcXxcXxf[veYwhZwgYyj\ug]zh_yh_xg^yg\xf[zi]zibzga{hbzfayf_zf^xh_wg^wi]zl`zi^zg\zk]|l^}j]{g\{j`{j`q`WsbYtcXreWvb[ubYvfXudWucWtbWze[xf[zf[|h]}h]j_~j_~lamb}k`yh\veYze\{g]zh\yi\zh^~i`|jc}jb~la|l^wfZ|j`…ogŠukŠwlƒpend~md€mf€mdnf€of~nb|l`~nb|m`}k`}j`}k`mbnboc‚nc‚mb€j^‚k`‚ncƒod‚nc„pe…qfƒod‚pb‡rg‡rg„og„ng‚lg‡pg„qi„rj…rjŠrkrksktl‹umŠtlŠtj‹sj‰shŒvjŒvjŒvkwlŽymvlŽwoŽwoŽwo‹tl…pjŒrp‹rlŽtjujulŽtmŒumunslŽtmŒrkŽrkqjtmvoŒslvnŒvm‘wq‘wpwo‹rkˆpe…ka„ja„j`ƒh_‚h^g]g]g_€g^i]„i^…ia‰ke‡lbˆmc‰lcˆkb…h_‡i`‰g^ƒf\h^i_ƒha†ib…j`‡lb‡lb‡lb‡lb†ka…i`†ja…i`ƒg^„h^„h^ƒh^ƒi_„i_†ka‡mb†ka‰mcˆkbˆi`‰ka‡jaˆmcŠkf‰me‰md‹peqgŽphpgqhripgsjŽrisk‘tk‘ujsh’uk’tmsjqh’tjpj’qk‘pj‘sirjtlslsk’ti“uj’tj’sjpjpk’qm‘slrk‘qk“tl’sj‘rirksl“tl“tk”ul–ul–vp–vo”tm“sm“sm“sm”tm“tm”tk”ul“tk“tj’vk‘tk’sl‘qk’sj‘rgriŽqhŽqh‘rhpg’sj’ql‘pjojpkŽpjqj‘qk‘qkpjphŽofŽof‘qkpj’rlpjoini‹ngnfpf’rg‘phŽqj’ri‘si’sjqh’sj”uk’rm‘qkŽnh‘ri’sk“uk’rl’un”wp’unsl‘un’vo’un“tn’rl•tn–wp’un’ql—up”rl”torl‘tmŽqkrj‘tksj‘tjŽshŽrjrlrlqi’sj’sj‘ri‘ri’sj’sjqhŒogŽqhripgshŽrhnjpjpg‹oeŒofŠognhŽnhmgŽnhŽnh‹lfŠmfŠof‹oe‹ndŒogŠngŽneofŒpfŠpeŠndŠndŒoiŠmf‹ngrkŒoh‹ngŠngŠmdpgpgŽpeodŒogŒogŒogŒogŠnfŠof‹oiŽpj‹nf‹ngmenfpiŽqjqj‹oh‹ohŠmeŒrg‰me‹ngˆke‹meŠmcŠnhŠngŒmgpiqi‹qhŒpfŒpf‰nd‰oe‹ngŒpiŒofŠmd‹neŒqgŠoe‰nd†nc‹pfŠmd‡ka‹pe‡oe‰oi…le†ogˆpfŠpf‹pdˆng†mdˆoc‰oc‰me‰ngŠnfŠodŠoe‰ndŠpc‹pd‡mcŠpfŠoe‡lb†lb‡mc„mb…lb‡nd„j`†lb‡mc‡mg…keƒi`…kcƒja†mb†kb„ka…lb…mc‚mbk`‡kb…jaƒh`„jc„kbƒi`kckc€jb…ld…jc„jcjbjb„meƒld„me„ne‚lc„od„nc†pe…lfƒkdƒod…oe†of…ng„me‰oh‡ph…nf„me…nf†og†ogˆog…le…me†mf„le…me‚oc„od†ncƒja‚jc‚ld†og„mekc„me…nfjcl`l`k`€k`l`l`ndlclaƒmb‚mckbh^ƒj`j_k_ƒnb‚k_}h_}h^~k^€l`‚ncmdl_l_~j]~i^|g\k`kd}ia}jb~kc~ib€ldl]~k]namb€lc~ia~kalblckb}i`~jamb~kb~kc|ia}ka|j_}na~k`{f[{g\|i^xh\{j_yf[|e[€f]}h\xf[yf[yf]yf^zg_veYweYzdY{f\zi\zg]{h^ze^ydYzf[yeZzh_zi`zi`{e_}g]yf[xd\zf_zi\wd\ubZxe]xf^vd[ve\xcZyeZ}i\{h[zg[zf\uh]xh^yg\zh]xf]wg\|g_ze^zf]yf[wdZwdYweZwfZxgZwgZxg[wh[zh_zh^wf\yh\yg]zh^{ibxe`xfa{h`{h`yg\ve\wf^vg\xi]|l`}j_}l_{k^|i\{h[|k^zj\saYtcZudZocUt`XsaVveXveXveXucZ{eZ{eZ|h]|h]|j_xf[{h]zh]{i^|h]zf[zf[€halbl_}l_|k^zh[zh_|j_}l_|l_yh[|j_„phŒyo‹zn†vjƒsi~of}kb}jb|ib|ma{k_{l`}m`zj]~l`obmb}j_{l^~m`}k_k`‚kc†mf„od†rg†rg†rg…qfƒod‚ncƒpe„pe„og‚me‚nf‡ph‡sl„ri…rjˆqi‰oh‹rg‹rhtjŒumŽtmsmŒvmŒumxozqvnŽwoŽtlskŽtmŒumŠsk‹tl‹tpŒsmtkukskŒrm‰rj‹tlŒumŽtmslŽsl‘uk“wp”xq”xqtlŒsmŒrkŠqi‰mgˆmb†i`bYf\‚g]g]ƒh^„i`…j`ha‚ia…l`‡ma‡kc‰leˆkb‡ja‡ja†i`…h_„g^‡h_„g^h^ƒj`ƒhbˆjd†k`ˆnb‡ma‡ma‡ma‡naˆjb‡jaˆkbˆkbˆkb‡jaˆkb‡ja…h_‰lc‡ja‰lc‹pfŠne‹nene‹mdŽpfŽniph‹pesgŒpfqhqhqhririsjrj‘tkrjsirisj‘tk’ulri‘ri‘qk‘qk‘qkrhsksl‘unsk’sj’sj“tk“tkpkojpk•sm“qk“rl•tn’sk‘rh‘tmrk’tk”ul”tk•tk•up”tn“sm’rl“sm“sm“sm“sm”tn”ul’sj“tk‘uj‘tk’rl‘qk‘ri”ujrkskŽqi‘qk’qj“rl•qinfqhqisjrhpkpjpjoiŽogrhpj‘qkpj‘qkpk‘qkŽqhog‘qf’qh‘pirm”sm’rl‘qk“sm”tn“sm’un‘tm‘tm‘tk’ulsj“sm“tm•uo‘tmsl‘tm’unrk’rl’rl’sm’un‘ul’tl“sk’rj“ultksjrjrisjririŽpipjŽpkŽpkŽqkŽqj‘qkpi’rj“tk’sjqhqhqh‘riqhpg‘rhqkoi‹neŽofnfŒmgoimgŒlfmgŽnhŽnh‹mhpiŒofpgŒohŒnhŽofŽph‰lcŒpgpgŠmdŒoh‹ogŽqjŽqjpi‹mf‰mfŠmd‹ne‹nergŒncŒpiŒohŠmfŠmf‰mf‹oh‹niojˆje‹mhlfŽnhŽqjŒohŽqjŠohŠmg‹phŒqf‰nf‹ohŠmf‡kb‰nb‰oe‹ofpgpjŒphŠoiŒnfpgŠmd‹pgŠoh‹pipg‹of‹ne‹pfŠoeŠoeŠoh‹oh‡kd‰me‰mf‰mf‡mf†mf‡ph‡qf‡oeŠoe‡mg‡ldˆnaŠpdˆldˆle‹ohŠng‰ncŠoeŠoeŠpdŠoe‰nd‰ndˆmcˆmcŠoe†ka‡lb…lb„ka‡od…odˆmh„kd„jd‚ia†kdƒkc‰nd…mc†mc…lb„ncƒmb†jc…jc…kdˆng…mb‚k`…ld„jc‚ib†ke„kd„me‚ldƒmeƒnf‚ld…ogƒnf€md€mbƒod„nb†mf†jeƒleƒldƒld†le‡mf‰ohˆqi‰rj†og…nf…nf…nf‰ng†le„jc†le…kc‡mfƒoc„od†nd„kaƒlb‚mb‡od„kaƒj`„kb…lc…la„lbƒkaƒmb…odla€mb}md~ld€laƒmbƒk`‚j^j_ƒmb€j_‚la‚l`‚k_}i^}i^k`k`‚me‚mf€m`k^k_‚i_‚ja„j`€ka€lalb~la~nb|l`€l_~k^}i^k`~j_}i`|g_|g_‚me€kc€kc~ialakb~ia~kc{i_{i^zj^|i^|h]{g\{h]yh\zj^zg\{dYh]zeZyeZyf^zg_xe]{i^weZwfXxe[yg\yh[wf[|g]}f_}i`zg\xf[xh\xh^xg^zc^veYweZyf^zi`xi\zf_wd\wd\wc\vd\ubZwa[xdZyeZxfXwdXwcYtfXugZueYzg]wd\xe]yh_yh^tcWvfZyi\wg[xe]yg[yh[zi\wfYxf[wfYxfZweZvgZwf\xg^xf_yf`we^{h_{i^zi[xf]ziawi]zl`€oc~la|j_zi\yh[zjZ{k\{kZsaYsbYsbXpdVtaXsbUudWzi\zh]xf^zdYzdYyeZ{h]xf[zh]xh\yf\{i^k`‚l`€j^€ia~h^~h\l\}k]{j^{j]{j]}k`€nd€ncpc€ofqe‚re‚rfpe{lc{ja{ja{l_~kamb~m`{k^zj]zi\{h^|j_|i^{j^|k_}k`‚ldjaƒle€lambmb„peƒodƒodƒma…pd†og…nf‡ph‰qj…qh„of…ph‡ri‡qi‹tkˆrf‰shŒtjuntmŒtnvnŠskŠsk‹tlvmŒumŽtmslunŒumŒumŽxoŠup‰smŠtl‹tl‹slŒqjˆqi‹tlŒvnŽtmŽtmŽtmujtk‘un’woŒsl†mg‡mf„ha‚g]ƒh^‚e\„i]‚g]„i_†ka…j`ˆmcˆmb‡ke†jb†l`„j_…ia„g`„g^„g^„g^†i`„h^„g^†ja‡kb‡lb†ka‡kd‰ng‰od‰mdŠoe‡lb†ka†kaŠmdŠmd‹neŠlcŒofŠmd‰lcŠmd‰lc‹neŠmd‹neŒqgŒqgpgphqhpgpjŽohŒrfsgqgpgŽqhŽpg‘ri‘qh‘ri’sjrisjŽqjŽqjri‘tk’riqhrirkŽqjslqhŽqiŽqlrmsk’tk–wn”ul“sm‘rkoi‘qk•si’ph“rl—tn’sm“smtmsl’sj’sj‘ri“rh“sm‘qk•uo’rl’rl’rl’rl“sm“sm“sm“tk‘rish’ul’rlpj’sj•vksltm‘tm’rl’qk’qk“phne‘riqhŽriripgphoipjpjpjpi’rl’rlpjoiojŒoinf‘qf“sh“rksk’un‘tm‘tm‘um‘tm’un‘tm‘tmsl‘tk‘tk‘tk”tn“sm”tn’unslsl‘tm’sm‘qk’rkrktm‘ul“ul”ulqh’tkriri’ulsjŽqhphrisloiqlŽploipioi‘qk“sk”ulqirgqh‘ri‘riqhngoksiŽphpiŽnhŽoioioiŽnhŽnhŽnhmgpiojpipgriŒohŒoiŽogŒmdpgŒofŽri‹qgŒohpipiŽqjpi‹ngŠngpf‰mdpg“ujqeŒoiŒohpiŒohŠngŒpiŠng‹ngpiŽqjŽmgŽnhŒohŒohpi‹oh‹ohŒphŠqfŠofŠng‰mf‰ldŠncŠqe‹pfpg‹ng‹nhŒpjŒne‹neŠmdŠof‹piŠohŒof‹nepgŠpfŠoerhŠng‰mfŠohˆmf‡kdˆleˆle‡le‡ng†ogˆoe‰od‹ohˆmdˆnb‡ma‡md†le‡kcˆldŠnh‰ndŠoe‡lb‰ndŠoeŠoe‡lbˆmc‰ndŠmd†la‡lb…lb„odƒmb…kf‡mg‡mgˆmg†leˆnhŠoe†mc‡nd…lb„nc…od‡mf„jd‡mg‡ng†qe…obŠnf‰le‡me†mf†ph…me‚meƒnf‚ld‚me‚me‚md‚ngoc‚nc…od†lf‡kf†nf„le„me‡mf‡mg‰oh…og†og‡ph‡ph‡og†ogˆngˆng„kc…ld†le…me„od…mb„ka„lb„ncmb„ncƒncƒmb‚la‚laƒmb…la…lbk`ƒmbƒmb‚l`~leogka‚k`†laƒi^i`i`€k_ƒmbk_j_na}i^~ia€kc€kdibk_€j_‚la„l_h\‚i\j_}i^|j_~la}la~mb€m`~j`k`k`€la}h_~iajbld€kcjb|g`€j^{f]}h`~ia{i`zh\yi^{h]}i^{g\{g\{k_{h^zg\xdY{eZzeZwdXzg_yf^vdYxf[yg\yf\xf[yg\ygZzh^ze[e_{h`zg^zi\zj^wg\zi`yb]wdZucXyf_yg_yi\xd]wd\xd\zg_xd\yd\yc]xc\zf[zg[zg[wbXwgZueYueYvfZvd\ye^zk^xh\xh\vfZyh[yi\wd\xe[xgZyh[xgZygZyh[yg\udXwgZzk^yj]zg_zg`yf^yh_xi\xiZzh_|iaug[yj^|l`|j_{i^zi]{j]{j]}m]zjZp_Vn]To^TrdVtaWudXwfY{j]|i`yf_{fZydYwcXyeZxeZyf[zf\|i^~j_€lai^‚la~j^~h\i[~j[lamaƒreodnd‚nhƒpfodne~lb|k`nb€nd~lc{j_|l`|l`mbna~m`zk^vgZxf\}jb|jb}gb}i`}j`|ia}kcldne€l`}i^mbmbƒndƒod„md…nf…nfˆqiˆqj‹tk†sg…qe…pe‡sgˆshŠuj‡ukˆtj‹tl‹tl‹ukŒvmŠsk‰rj‰rjvnŒumŠskrmslslŽtmvoŽxmŠsnŠun‹wo‹wn‰tkŒtm‰tl‹tlŠtlŠtkŠskŠpiˆqf…od‡meˆngŠoj„idƒi`ƒh^ƒg]„j`„k^„k_„k_„k_†ma†maˆocˆob†jc„h`ƒh]ƒh]„g_ƒf`‚e\ƒg^ƒf]„g^…j`‡lb‰mdˆmcŠne‰md‰lf‰mgˆmd‰ne‰ne‡lcˆldˆld‹oeŠndŠne‹ofŒpgŒpgŒofŒof‹neŠmdŒofŠnenhpiŒpi‹ohŽqkpjoiŽqgŽrgtgrgqgriqhqhpg‘qh’ri‘ri‘qjpj‘pkqi’ri‘ririsjrkrktm’tkrlql‘tnsm‘rj‘qj”sn“sm‘qk‘pk‘rk“ri“ri’rj’tn’tmtmrksmqhqh‘ri”sj’rm“sl“sm”tn“sm’rk‘ql’rm’rl‘qk‘qkqitisj‘rk’rl”ul“titmslsl’rl“qk’oj“tjpgqh‘riŽpgriqh‘riqi‘qk‘qk’rl’rl“sm’rlpjoipjŽpkoi’qi”ti“sirh‘tm’un“vo‘tm’untl‘un’vn‘unsj‘tk‘tk•rm’rk’rl‘qkoirk’tk“tk‘riqgŽqgtjŽsisjqhqhpgŽsiti‘tk’ulrirlrl‘rhoiŽpjŽpjrkŽsh’ql‘qk‘qk“tkrg‘sh‘ri‘ripjoiŽnioj‘rhohŽmgŒpipiqioiŽnhŽohŽnhoioioiŽog‘rhrhŒofpiŒohnhmhojŒpi‹pjŽqjŽqjŽqjpiŽqjpiŠngpgŒpgŽqg‘shqfphphŽqiqh‹og‹og‹qfŒoeŽqhŒogpini‹ohŒohpiŒpi‹oh‹ogˆpeˆnfŠng‹oh‹og‹pdŠne‹qf‹og‹ohŠng‰mfŠne‹ne‹pf‹pfŒoi‹oh‹neŠne‹ne‰oe‰md‹pfŒoh‹ngˆng‡mfŠng‰mfŠldˆkeˆle‰mfˆlfˆldˆmfˆmd‰nc‡nb‡nfˆng‰lfˆle‰mfŠngŠoe‰nd‰oeŠpfŠpf‰nd‡mc‰oe‹pf‰nd…lb‡nd†ndƒmaˆmgˆnh‡me‰pg‰pg‡nd‹pfˆpe‡nd†mc„oc…ocˆoc‡ne†lf†nh‡pg‡pdoh‹ohŒohˆoh†ph„nf„me‚kc„me…nf…nfƒmeƒmd‚mb…od†pe‡oh…lf„ne…lc‡nc†nb‡odˆoc†og†og†ogƒld†og‡ph„pd„od€l`‚nbƒncƒnc„leƒkdƒj`„ka‚mb{i]‚la‚mb‚mbla‚mb‚mb„l`„l`†na€j]€j^k_ja~kbk`‚mb…ld‚g^|iajb€kb‚ncƒmbƒmbmdldicic~h`jai^~h]k`€i]g\h\k`k`mb}k`€la€mbjaka~j_}i^~j_}i^€ja€jaj`}g^}g^{f]€i^g^~h`}h`{i_zh]yi]zg\{g\{g]{h]xg\yg\yf[{f[|h]zeZ{fYye_xe[wfZwfYyg\yg]{h]yg\xgZyg\zf\~f_ze`zh^|i]~l^}j^xe\yb]{g\xdYye]|h`wfYvb[taYxc[ze]yc[zd\vd]xf]wg[yh]we]tcZue[ue[ug\vg[yh^zf]yf[{h]{h]ygYygYxfZyf_vcZxg[ygWyeWxfZyi^wh]xh\xgZziZzhZ|l^|j_zh^yh^zj]zj\~i`zh`zk`xj^yj^}mak`zi^{k_zi^}k`~j_o]Ur`WraWqdVucXweYveXweYubYtaZxdZvbXvbWyeZ{g\{f\|h]}i]zf[zf[yeZ}h]{h[€j[~gX„n_†qe‚oe†vh‚of€mfke~kc~kb}jbzg^zh\~l`€md~kc}ma{j_zj^{j]|l^|k^zk_yh^{ia|ib}id~hbke~hbzg^}kb~nbqe€la€ka€maƒodƒod„pe†pg‡ph†og…nf…odˆsgˆsi‡rgŠtiŠti‰ujˆuj…ul„qj…phˆshˆti‡th‰rjˆqjŠskŒumvnvnŽqlrm‹qj‹qjtj‹uj‹uo‰tnˆvnˆum‰rl‹sh„ohƒogƒld€ia‚lcƒiai]h]€h`g_€hbhbƒh`…j`†mc…maƒna€k_„m^„m^ƒm^j\‚j\j\ƒf_‚d]dZ„h]„g_e_‡i`…g^†i`‰lcˆmc‰od‰od‹pf‹ofŒpfŠmg‰mfŠmgˆlf‡ke‰lgˆkfŠmgŠne‰ndŠpeŒqgŒqgŽsi‹nepgpgŒofriŒpgnhpi‰mfŒpiqipinhrgrhŽsdqd’shŽqhqhneog’qh’ri‘ripi‘qk’rm‘qj‘ri‘ri‘sjŽqhqjŽslsl“tkrlŽqlrmrl‘ri‘pk‘rk‘ql’rl‘riof‘pgqhrhslslsm‘tmqjndqhrh”si’smpk”tn“sm“tn“sm’rmpk‘qk’rl”tn‘qk‘uj‘sj’rl‘qk’tk•vkŽrlŽrjtm”sm•sm“ojriqh‘riqhpg‘ri‘ri’sj‘ripj‘qk’rm’rl“sm‘qjpj’qlojŒmj‘pk”rj–vk•vi‘vi’um’un“vo’un“vnrk’rl”uo’rl’sk’sk“tk•sm“pkpjpj‘qksl”tlqi’riqhŽrhtjŽsiripgphqgrhshŽqhqhphŽrkpi‘rgpgpiŽqjŽrhujpkpk‘qk‘ri‘rhpfri‘sjslrkŽpjpk‘qg‘pgmgŒojŒoiŒpfmgpjoiŽnhohŽnhofrhqf‘rhŒpfŽqhpiohoiŽnh‹ohŠpipipiŒohŒohpiŒohqjŽpgŽqhŒofpfŽpfŒpgŒofpgqh‹pfŒqhŠpbŽrgqfŽqgpgne‹nhŒngŒoh‹ohŠngŠng‹qf‰pg‹ohŠng‹ogŠpeˆkcŽqjŠnhˆlf‰meŠmd‹rh‹pfŒqgqg‹ngmgŠmd‰lcŠmcŠoe‹pf‹pf‹nhŠng†le‰ngŒpiŠmgŒmcˆja‡kd‰mf‰mf‹ng‹ngŠog‰oc‡od‡ne…leŠlg‹ohˆleŠng‰me‡mb‡pf‰sh‡qf‡pe†pe‡oe‰pf‡ndˆoeˆoeˆnd‡ncˆngˆoeˆndˆpe‰qe‡pd‹pfˆneˆod‡oe†pe†pdˆpd‡me„mf†mi‡ohˆrgmhŽpiŒoh‰oh†phƒof†leƒjc†mfˆng†mf…kd„md†pd„nc‡qf„ngƒnh…od†mb†nb†nb‰oa…l`†of…meƒleƒld„me…nf…pe‚nd€mambƒodƒod†nf†keƒj`„kama{j]~k`~la€nc€mb~mb‚od…k_„la…maƒk^k_€j^‚j^la€la€mc„kdga}jb€kd~ib€k`‚la‚k`le€jd~hbjd}i_€m`‚i_€h^j`}j]|h\|k\~la|j_|j_mb~i^€la€kcja}h`‚md}i^zf\}g\~h\i]}g[~h\~h\€g]h^g_kb{i`yg\zi^zg\{g\}i^yf[xh\{h]wdY|h]zf[~h^xcWyd^yg]wgZygZyh[we]}g\xe[xgZyh]xe\{e_|fa|g_{h[|iY{g[{f]|b^|f[{eYwc[ze]zgZvc[vc[|f_wbZ|f^{c\vd\vgZwg\yi]wf^ta\we\ue\sdXwh\yh\|i\yeZ{f\}j]|i\zgZxfXwd^wdZzi\yfVxfX~h\wiawh`zj^}k_~kZ{hW{k[{k\yg\{k_zj^zj^|g_|jbzk_}oc{l`ocnc{j^|ka{ja}kd€keqdWpcVqbVraVqbYraZtcZub[taYwbXzgZxfXxfX}g[zd[|d]ze^ze]yeZxdY|eZg]i]€j^‚la„nb…oc†pd…oc„obkbƒmc€i^k_na€lb}jc}jb~nc~na}mazj^zj^xf\}k`lb~k`~j`~iajb|ia}jc€k`l_}h\~k_‚pe€pgqeod„nc…mc…odƒnc‰od‰oe†pe†pe„ohˆsk‰qlŠrl‰sh‰sh‰ri‰qjŠuj‡rg‰shˆrg‰sh‹vjˆujˆuj‰tlˆskŠskvnvpŒtnŒtn‹smŠsmuoŒumŒunŠtk‡qg…ocƒmb‚leƒld~g_e^€f_~d]…f]„h^€h]i]‚la…kbƒj`†kaˆkaˆkc…j`ƒj_…h^ƒh]‚i^f\e[€d\€d]~b[~dX‚h\„h`ƒg`†i_‰mcŠobŠncŒngŽpjŽoiqj‹pjˆqj‡ohˆqh†obˆpcŠmeŠmf‹nh‡mf‹nfŠoepgpgŽphri’ql‘ri‘rhqf‘rh‘qloiqhqgpgqfŽpfrl‘tlsh‘shserdsh‹pfŒofpgpg‘risjŽqhqg‘qiqh‘ri‘qkpjpjoiqj’rk“sm’qlpjrjrjsj‘qkojpgqgqh‘riŒofrjrksl‘sksjŽrjqjohoi’pj”rk•sj”sj”sj”si•rm“rlsk’ri“pj•rl–tn’tm”tk“ri“ri•tk”sj”tk’tmslslslrkpj‘riqjpkpjqgrg‘tmtm’rl’rl‘ql”rl“so‘soql‘tl“tk“shŒpirkri‘sj”uk•vm’ul’ul’un‘tmrmrm‘qk“rl•rl’ok‘sntn“sl’tj‘ri’sj‘si‘qhpkŒnhrkrhŒrguh’sjrjoiŒoj‹pgsipkojpkojoinh‰mgŒpiŒofqhojpkŽqjŽrhriri‘qlpkrj‘tkslslslskŽrhŽqfŒoe‹neŒofpgŒohŽqhŽqh‹neqgqfphpjohoioioiniŒnjpipipgpfrlŒohpioiŽqjŽqjŽplŒoiŽqiŒofpjojojŽni‹neŒrhŠpj‰pkŽpjrjpgŽrgŒqd‹pdŠofŒpi‹ohŒqg‹perhpd‰od‰od‹pf‰mc‹mf‹ph‹ohŠng‹mfŒoh‹ohŽofŠoeˆqeˆreŠocpe‰md‹pfŒqg‰pfŠqg‰pf‰peˆqg…ncˆoeŒnhlfŠmg‰ldŠmdŠnd‹pg‹oh‰mfŠng‹oh‹oh‰mg‹og‹lhˆkeˆjf‰nf‡le‰oh‡rfŠshŠqgŒrh‰lcŠmdˆmh†le†le‡rfˆrg‰shˆqi†oh„nd‰ofŠqfˆpe‰oiˆnh‹pj‰pf‰oeˆpd‰neŠoeŠnd‰nd‹qeŠpd‰obŠneŠng‰mf†ld‡od‡mf†lfˆoe‡nd†nc…lbˆpb‡oa‡ob„nd…lf†mi…od‚maƒnc‡nd†nc…la„nb…oc‚l`ƒmb…ne†nfˆmbˆpd‰qeoaƒna…nb‚l`‚maƒmaƒma…nb„nc‚l`ƒma„od…odƒmdƒkdƒlcƒld‚la‚la‚la‚l`ƒmb‚laƒmb‚l`‚mal`‚l`la~lcmeme~jb}i]j`‚j`…lbl`~k_i[~i\~l^~k^~i^‚j_€k`j_~j_~j_la|k_€jb}h`€kcjb~hb}ga‚kc~i^}k\}j[{j[|j]}j]}j]}k]€l`k^}k]h_}g`ze]ze]zf^{h`}h_{h\|h]{g\zgZygYh`{f^xf[xf[zf[}g\}gZ|eZyeZ{g]zh`{i`}jbzi]{i\zgZ}i]{f^}i_{h\zf[{g[|i\|j\zg_yg[yg\|h\{h[|g[wf^zg_zf_{g^yg\yiZwgZxgZxgZyh[zf\{g\tdYxg\yg\we[ubZyg^ud[xf\xf[vdYye[{g^zf`|i`}j_}m]yjZ{i\{l]|k_zh]{i^yj^yl^}kc~kb~k`~m`€obnblc|ia}jb|i`€kcƒmdqcWseYrbVr`Tr_Wr`WraWscXvdXudYxgZwgZzh[zi\wdZu^Xzc[zd\ye\yfZ|i]la|j\|j]~l_~l_{i\|k^j_kcjc€ic~h_k`ma‚nd€kd~jb~ja|k_{k^|k_yi]{i^|j_|j_{k^~la~k`|g^|g^€j`€ma‚maƒl`„ma„od„nf‚pdƒpe†pe„mb‚mbƒnc‰pe‹rh‰shˆrh†qj‰tl‰pkŠrk‰ti‡rgˆri‡qiˆrhˆri‹tk‰si‰ri‰si‹tlŠtmŠtlŠrj‹tlŽwmyrununvovo‹tmŠohŠoh‡lc‚g^d[€f[~e_}e]~d]f`ƒgaƒg`‡i_‡ja„kaƒla„lb‡nc„ka†ka…h_„g^‚g]g]eZ~fZ~e[€e[cYaZ€d]f]‚h\g[‚f^ƒg`…h`‡ja‰lbpfŒohŒojoiqiŠpi‰qiŠqjˆoh‹qfŠpeŠmd‹ld‹neŒohŒpg‹neqhŽpgpg’qhpi‘rirg‘si‘ripjohpg’sjqhŽqf‘sgrj‘tkrj’ti’ti‘shrhqhqhqhpgpgŽqhŽqhpg‘riqhqhqh‘ri‘ri‘ri‘rirhqipiŽofŽqhqhripjoipgpgpgpgŽrhŽqipirkrjŽqh‘ri‘ri‘ri‘rh“qh”si’uj’tj‘sj“tm’sm‘qlrl’qk•sm•sk•ulsi“qi“rk”sj”sj’rh”tj‘slsl‘tm’unrkŽqjqh’rk“smpj’si’ti‘un“wo”tn“sm’rl•tm“tn‘tn“vo‘tm”tn“rjqkrlrj‘tk“vk”xltkslsl‘tm‘slrm’sk“rj’qi“qj’smsm’sj’sjqhpgqiqgŽploiŽqjŽrhŒrgŽuiriqiŽojpjrkriploj‘qloioiŽnh‹nhphŒofpgŽngmgŒpiŽqgsjriqk‘pkrjslsl‘tm‘tmŽqishqf‹oepgpgphohŽqhŽqhŒofqfpfŒpfŒqgpfofoeŒneŒoh‹ng‹ngŒohŒohŒohŽqjŽqjpiŽqjŽqjrkqloipg‹nf‹nhŒoinhpiph‹ofŒpipkqiŒohpgqfŒpd‹ocŒpg‹ofŒpiŠng‹pg‹ogoeŠpd‹pfŠpf‹oeŠlfŒph‹nh‹nhŒoi‹ngˆke‹naŠpdˆpd‡od‰pd‹neŒqgŒqg‹pf‰pfŠqg‰pfrhŠof‰pf‡oe‹ohŒmg‹ogŠmeŠmdŠpfŒqhŠngŠngŠng‰mf‹ph‹ohŒpiŠlg‰lg‰kg‹ph†le‰ohˆsh‰pfŠqgŒqg‰md‹odˆng†le‡mfˆrg†qf‡qf‡pg‡pf†peˆneˆnfˆnf‰oiˆngˆngŠqgŠqg‡pc‹ng‹qfŒqgŠoe‹qeˆnb‡nbˆme†le„le†neˆpdˆmg†lf†mc‡nd†mc…lb†nb†nb†na„ncƒlc‡nh…oe„nc…od†mc†mc†mc†pd„nb€j_k`‚lbƒlcˆnf†ne†pflbƒkb…kc„oclaƒmb†pe„nbƒnbƒl`ƒla…nc„mcj`i`‚kbƒmc‚ka‚ka‚kbƒlc‚lak`k`i^€j_ƒmb…ma‚lb~jajd}ia}h^}i^~j_‚i_ƒj`€l`}i^~i\~j]l_~j^l`k`i^j_}i^~j_~k`yg\jakb~iaib~hb~hc€ibj`}i^|i]|i]{j_k_l_}j]l_~k^}j\h`ia|g_{f^yd\zg_{f^|h]|h]~j^}k]}j]i_{g\yg[yg[ygY{fXzeY{f[|g\|h]{g`{h`{g^}h]~k^|i\}i]|h`|h^zg[yeZzf[}j]|i[yf^}k`|i^|h]}j]yfYyh]zg^{f_zf\yg[yjZ{g]ye\yg]zg^{h^zg\xgYyh[{i]zh\weYxf]we]zg^{i^yg[{f]}g_yg^{i^zj]|l]|k]nb|m^{k^}k`~la{l`{oamc€mc~lalclclc}l`~la~la€la€la€lak]QoaUq`Tq_Ts`XvcZvfZyi]ugZseWsdXtdVscVwfYubXta[{dY~h_}jb{j`|i^yf\yg\xf[yg\yg[weZyg[{g_ld~jd~kd}jc|i`k`k`€la€lb~j_}k`ldmd~kc|ia{h`{h`{l_~na~nak_~h]k`l`„pc‹rfŠqe‡mc†kd„mc„nc†pe‡qf†peˆrgŠqgŒsiŠshˆrg†qf‚odˆnhŠpj‡ph‡rj„qi…rjˆqiŠrk‹tl‹tl‰rjˆqiqj‹qj‹qj‰rjŒvkŽzoxpvnŠtlŒumŠsk‚lc„ha…ic‚g^~bX~cY~cY‚g]ƒh^‚g^ˆmcˆlc…kaˆjbˆlb‡lbƒj`„laƒj`‚g]f\‚f\€e[€e[€f\~g[€h[€h]e[‚e[„d]d]„g`‚f[‚f[e]ƒg`…gbˆkdˆkbŒofŒohŒnioiŽqjŠohˆngˆngŠng‹ogŒohŒmdŽofŽoergogqhpgqh‘qh“ripjqhqf‘rh‘ripjoiŽof‘riqhqfrgŽqh‘tksj‘qk‘qj‘qk”rj’riof‘qh’qhpgŽpgsjqh“tkpgpgpg‘ripg‘riqhqhrgŽnfpgpgŽqhrkpjojŽofqhpgpgpgpi’rl’sm‘qjqh‘sh”uk‘sh‘sh‘rg‘sh‘tf‘si“tj“sm’rmpkŽpk’pl–tn–uk‘qgsi“pl“pl“qk”si”ti•uj“tk‘sj‘ri’sk‘rjqiqh•vn‘qk“sm“uk“ui”wp“vo”tn’rl‘qk“rl’sj’vn‘tm‘tm‘qk“qk”qm‘pjpjriti‘uiulqjrkrk’rl’qkŽqg’sh“ri“rirjŽrkqhqhŽofŽofphqgrkŽqjpiŽqhriŽqhŽqhŽpgŽnh‘oi’ri“rh“so‘qlpkoiojŽofŽqkŽqjpgŽofphnhqiriŽriogrlojpirkrk‘tmririŽrgpgpgpgpipipirhŽqhŽqhqfqf‹pfŒqg‹pf‹pf‹oeŠoeŒpe‹meŽqjpiojokrkŒohpiŽqjrkrkŽokŽqipgŒofphŒniŒojŒqhpgŒoeŽogŽniŒohŒohŽqhpgŒpe‹ocŒqgŒqgrhŒpipj‹pgpfŠpdŠoeŠoe‰mcohŠne‹pf‰neŠmd‹nfŒoeobŠpc‡ocˆofˆng‰keŠpeqhŠoe‰pf‰pf‰pfpgŠoe‰ndŠof‹oh‹ohpiŠmeŠoe‰nd‰md„jc‰mfˆle‰mfŠngŠng‹oh‰mfŒpiŒpiˆngŠpi‹qj‹qgŠqgˆoeˆmcˆmcŒqg†mg‡le†leˆrg„nb‡qf†qe…pd‚mb‡nd‰ohˆng‰oh‰oh‡mf‰pf‹rh‰pf‡mfˆoeŠqg†lb‡oc†ma†nb…me…mf†ogƒmd‚ob‡ngˆnh‡ne‡nd†mc…lb†lf†ld‡nd…od…ne„mf…od…od„oc‡nd‡nd‡nd…od„ncƒmbƒmb‚laƒma„leƒld‚ld„me„ibƒhaƒlc‚kcƒlc†og„ld†mdˆoe…lb…lb„kaƒj`„kaƒmal`‚lak`€ibha‚la‚lak`€j_k`€j_†lb‚kbh`h`~h^€j^€la€k`‚i_ƒj`la}j^k`~j_}k`~k`~j_€j_~h]€k`~j_k`|i^}k`|h]~j_~ia~ia~ia€kc€gbi`|h]~j_{h_yh_~j^~j_{g\}i^{g\zg\}f^~h`~jb{f^|h`zg_|g_zg[|h]}j^}k]~l_~h\}j]ygZxgZ|iZ|gW|i^yg\zh]yg\|g]|h]|h]{g\}i^|h]zh]|k_ib|g_|h]|h]|h]{h\yg_{i]~j_~j_}j\{h[xg\zh]{h]}i^yhZykZ}gaze^{h`{h`yg_yi^xhYwhXxh[xi[zi]xh[{h`{i^zi\|k^}k`}ia}l_~m`|k_~l_}k`mc~n_na€nc~nb{mazm_~la€ncldmdmd~kd~nb~ma~m`~k^€mapci[Oi[Op_Tq_Tp]Uvd[scXseYtfZobVobWscWrbUtdWwg\xf]zfY{g]xf^zh`zj_xgZvfZwg[{k_zj^xh\zj^{h`{ha|ib~kd|i`}ja}j_}j_‚nc‚nc…ncƒmald~jb}jb~jb|ia{h`|l`ncpcna‚l`ƒl`laˆqe’xl•ynriŒpiŠqg‰sh‰shˆrgˆrgˆrgŠqgˆpf‡qf‡qf†pe…oc‰nh‹skŠtk‡rj„qh„sh†ph‰sj‹tl‹tl‰riŠskŽsl‹qjŒrlŒvk‹uj‰ujŠqjˆng†le…jd‡lfƒhbe^„gaf\€e[‚g]ƒh^†ka†ka‡lbŠpf‹pfˆmc‰nd„g^„h_ƒg^ƒh^~e[dZ~cY}bX}bX€e[f\€j^j]„i_†h`…i_†f`…ha…h`ƒf\‚f\‡jb‡jc…gb†icˆkbŠmd‹ng‹mh‹ohpiŠqj‰oh‰ng‰mfŠlgŒohoipfodqfpgpgŽofpg’ri’qhoiqhŽpfŽpfqhpjŽngpgqhpgŽpergqfriri‘qk‘ql‘ql“qh’qh’qhne“ri’qhpgqh‘riŽqhŒofŒpgpgoepgŽofpg‘riŒqeqfpgqh‘rh‘pjpiŽqjpgŽqhŽphŽri‘riqiqkqkqi‘ri’ti•vl•vl’ti’tirgrg‘sh’tj’rl‘rlpkŽpk’pl”ql”si‘pgŽsh•ro“pl“qk”sj”si•uj“ul‘ri’sj‘ri’tk‘ri“tk–vo”tn‘qk•vl‘sh’un‘tm’sm’rl‘qk”rm“tk‘ulsjrk‘qk”sl‘nk‘oipj‘siŽrgshslŽrkrkrkpj‘rksi‘ti“si‘qhof‹ohqhphŽofneri”ukŽqkpislrkogŽqhqhnfqh“ri‘ph“ri‘qlpjpjohŽoeneŽnh‘qhrgŽrgpf‹ngŒohŒofpgsjrlojoj’qk‘qk’sj‘ri‘riŽqhririŽqkpiŽqj‹ngŽqhsjpgqfqf‹pfŠoeŠoe‹pf‹pf‹pfŒpe‹ndphpinkokqkslŽqjŽqjŽqkrkŽqjphogpgŒogpiŒpiripgqhphoipislŒogpgŒofŒogrhŽsiŒoi‹ph‰mf‹phnd‹qe‰ndˆmcŠndŒngŠneŠoeŠoe‹nepgŒoe‹pcŠpb‹pf‡neˆlfŠnhŠofŠoeŠoe‰pfŠqg‰pfŠoeŠoeŒpg‹ofŽqk‰ohŒoh‰ne‹pf‰oe‡ne‡nf‹oh‹ohŠngŠng‹ohŠng‹ohqiˆng†leˆog‰rkˆoe†md‹pf‰ndŠofŒqhˆng†leŠpi‡qfˆrg‡qg‹rfŠqfŠpf†peˆqiˆqi‰ph‡mf‡mfˆngˆoe‰pfˆng‰qf‰pf‰pfˆpc‡oc‡oc…md„me„me‚mc„qcŒqkˆng†mcˆoe†mc‡nd‡mg‡mg‡nd†pe†of„mf‡nd…kb…lb…od‡qf„nc…pd…od„ncƒmb„nc„nb‚nf‚ld…kd…kcƒic„kdldƒme„meƒkc‡le†le†mb†lb…lb„kaƒj`„kaƒma‚la‚la€j^€iahaƒma‚la€j_i^€j_‚mb†mcƒja‚g`jbi`|i^€la€k_ƒj`…lbj_laƒmb~j^~k`}k`l`k`€j_la|h]~j_{h]zi^~j_}i^|h\~ia~ia~iajai`~j_k`}i`}jc}h^~j_|h]{g\~j_{h\jb€jb|g_~ia|h`yg_g_~h]€j_~h]€i]}fZ}h\}j]zh[ygZ}iZ}j[|i^zh^|i_zh]zi^|h]|h]}h^}i^zi^yf[|j_~h`}h`jb~j_}i^{g\|g_~j_}i^|h]|k]yh[wg[yg\{g]|i^zj[|m[jd}ga{h`{h`zi^zj^yiY{k[{j]|k^}l_|k^~kb~l`}l_|k^}l_lc~m^~n_{j]}k`}ka}ja€oana~nb}nbzj^|l`nambmald~kb~ld|na€ocƒpcl_€na€pccYMf[Ok^Qo^To]Vn]Vn^Vl\Um]Tn_SraXp`SrbUtcVxfZxe\xgYtdYsb[sbZxg\vfYweZyf[{h]{i^}j_}j_{j^{h`zh`~kcld~ma}kc€lcnb€ma‚md‚lekckc~ia€kc~kcld€oe€mcmemaƒnc†qe†rgxl—}q›€u›u•yr•yo‘wmŒvkŒvkŠujŠqg†ph†oh‡qfˆrgˆrhˆrg‡qi†oh„nh†oi„qh…rf†ohˆpiˆqj‰rk‰qk‰rk‰ql†ph†ph‡qf…od‚l`„ja~e\}d[|bZ|cZ~e\e^ƒha„i`„i_…ka‡mcŠoeŠpf‰oe‰pf‡oeƒlaƒi^e\ƒe\€aY€dZ~dYd[€eZf\~d[f\ƒg^€i]ƒj^†j`‡jaˆlb„h`„ha„g_‚f[†j_ŠmeˆkdˆjeˆkcˆkbŠmcŠmdŠmeoiŽrk‹oh‹ohŒphohŒohŒpiŒrhpgŒpfqgpgpgofŽpgpgpgŽohqhqfqfpgpjoi‘riqhqgqf‘shŽsgrhŽrh’rj‘qjqj“ph’qh“qh’ri‘qh’sjqhpgpgŒofŒofpgqfodŽpeqfŽpeŽpercŒqcŽrgpgphojqipiphripgpgpgphoipjŽog‘sj’qg•tk“tk”ul’sjrirjrksjsiŽqjŽqiŽpk‘oj‘oi“qjphrh”pk’pk“qk“qk“rj“rj‘ri’sj‘ri“tk”ul”um”ul”um”tn’rl’sirgrktm’rlpjqj’pjqisk‘tkrh‘rh”ti‘pioh‘ri’ri‘piohojpirkŽqjqisiŽrhph’qjognioipgpg‘ripgpg‘riŽqi‘tmrkpjŽnhohogŽpgrgshofqipjoioipgpgpgŽogŽof‘shŽrgriŠnfŽmgpgŽqhsjrlŽql‘qk‘ql’rl‘ri‘rirgripgrkŽqiŽqjpj‹oh‹pfŒqg‰od‹qeŠpdŒodŒpergŽthrfŠqeŽqgŒofpiŒohojojŽqhŽqgŽqhŽqhpfsiŽqkŽphŒpeŒpeŽqhŒohŒpiŒnfŽqfŽpephoiŒohqjŒpiŠngŠng‹pi‹nhŒpjŠnhŠpeŒqf‰odŽpeŠpdŠoe‹pf‰mc‹leŒpf‹pf‹pfŠmdŒofŒof‹oeŠmdŠpe‰lf‡mf‡ngŒqgŒqgŒqg‹rhŠqg‰pf‰qg‹pfriŽqh‹ohŒpiŠng‹ogŒqgŠqgˆnfŠpiŒoh‹oh‹ohŠng‡kd‰mfŠqf‰qfˆoe‰ohˆrjˆqiˆmfŠmfŠng‰mgŒpi‹pi‡mf‰ohŠpiˆrg‡qf‡peŠph‰pgˆoe…od…ne†pf‡ld‡mg‰ohˆng‰oiˆnf‰oh‰pfˆoe‡nd‡oc‡ocˆoc†kc†ke…me…ld‡pd‰oh…kd‰pfˆpfˆoeŠqg‰oiˆngˆneƒnc…mf…ng†md„ka†lcƒmb†pe‡qf†of„ndƒmb„ncƒmaƒm`ƒmd„lb…jb…ldƒkb„ne‚nc‚nc‚la€j_‚i_…ka…lc„lb„lb„mb‚k_ƒl`jaja€j`€j`ka„md‚laƒmbj`€j_€j_‚la€jaiahbƒldka|l_k`€la‚i_‚i_j_k`jc|ha~kb~la|i^}i^‚k`j_|g]}i^|h]}k`~k_|i]}i^|h]|g_~iai]k_l`~j_|i`{h`~j^|i]|h]}i^~j^€maƒldkc~ia}h`~jb}kc€iaj^~h]k`i]€j^i`~j_|j^}k_}k]j\|g_yf^mb|k_{j_|j_j]}h]|g^{h`{i^yi\~ha~ia~ia~ja~j_}i]~ial`~j_~k`|l^{j\zi_xf]}ha~j_}k^}n]€le~ib{h_{i]}k_l_~m^}k^{i]{i]}j_~ja}i]~j^|k\|k\~l`}l`~n^na|j_}ja~l`|k`€n^}l_|ma{mazk_|l_}l^na~ma€nb€oc}l`sgƒsgƒpdnb~ma{l`aYLaYLeYMgYMi[UiZUl\VjZSm[To]Vp^UraUsaUraTs`TuaWtfVqdXqa[sc\vd[zg[yg^vd\xe]yf]yf^zg^}j]}j^~i`€kc‚oc„qdof~mcnama~ja€ldƒme‚lc‚ld€kc€menf‚lf‚lfkd€kc€ndƒqfŽxm‘zn•|p™~s˜~t—|uš~t•zpxmxmwlŠshŠskˆpi‡qfŠsh‰sh‰sg…rj‚ogke„nh…pf„pd…ng†nh„lgˆpjˆpj„lg‚ng~jc~jb~i^|f[|fZ~e[{bW}dZ~e[€g^ƒi_ha‚kcƒmbƒmb‚la‚mbˆndˆoe†mcƒnbk`{g\e[dZbYƒd[€e[e[ƒf]ƒh^€g]€g]ƒh^„h_ƒk_†k_‡jaˆlb‡lb‚ib…ha…h`…i^‰lb‹nfˆkdˆke‰le‹ndŠobŒoe‹oe‹ngpiŒohpi‹ohŠkfŠnd‹pg‰qfŒrhqgofŒqgrhpgŽqhofŽqhŽnhpgrgpfpf‘qj‘qj‘rhqhpgqf’si‘tiŽrgsh’tirgrg‘qh’qh“tk“tk‘sjriri‘qhpgqhpg‹pgodŽqfŽpeŽpeodŽpeŽreqdrgogŽogniŽqjpiŽrisjqhpg‘qh‘ph‘oinhoh’rh“qk•sl‘pj’rl‘rlslrmrkrkrishŽrgpgpg’pi“ql‘pioi’pj“pj“qk“qk”ql’oj”sj–ul•tk•tk–ul–vl“tk”tm’rl‘qj‘shpfrmtlpkpjqknhŽnipisjrire‘qdŽpeqfqg‘pi’pj‘mimiojŽnhslrhŒshslpjoi‘ojniojpgqhqhqhqgŽofŒpgrjoipjŽnhnhŽnhrhreŽsgŽthqjpjojpgpgphpgqhŽoeqfqfŒpfŒofoipgŽqhŽqhŽpkŽqkqmpk‘qlqh‘sipfrirjŽqjŽqjŒoiŽokrjŠodŠoeŠofrfŒrfpeŒpeqgŽsgŒrfŒqf‹neqirkpipiŽpkŽqhŽqgriŽqhpgpgohŒofŒpeqfŒoephŒmfpfqgqfŽofŽoi‹ohŒpi‹piˆlf‰mf‹phŒok‹niŒoi‹pgŒre‹qdŽqeŠodŠoe‹pf‰mcŒngŒpfŠoe‹pfpfŒofŒofŒoh‹ng‹ngŒrhˆqgˆrgŽrirhrhŠqgŠqg‹rhˆsi‰qgŒpfofoipiŒpiŒph‹qg‹rh‹riŒrl‹oh‹ohŠohˆleˆldŒpiŠqf‰pfˆoe‡ph‰rjˆqh‹piŠngŠngŠngŠpiˆnhˆng‰phŠpjˆrg‡qf…oeˆmgˆmgˆne†pe‡qe‡qeŠpf‰oeŠpi‰oh‰oh‰ngŠpi…la‡nd…lb‡obˆodŠqe‡lc‰mf‰ng‡me‰pd…le‰nhŒsiŠqg‰of‰oe‡mg‰pg†lb…nf„le…mh†mc…lb…lb„oc„ncƒmb„nf‚lb„nb…oc‚la„nbk`†ma‡ma„mal_‚pc€ob‚obl_€j^ƒk_…k`‚kc‚lb‚la‚lak_€j_€iajbk_€j_i^l`l`l`€l_i^k`‚k`~kbic€ic‚lcla{k^j_~i^h^‚k`€k`~j_}ha{g_}jc|k`la}i^€j^}h]|h]~j_|i^|j_~k^€ma~i_~j_ka|g_€i^l_l]}j[}k_{i`~ia}h`~i`}i`ja}h`€iaia}h`jb~jb|ia‚lc‚mak`j_€j^j_‚ld€kc~la{i^|h]}g\ja~jb}k`oc~ob{n`ma€k`ja~kc}l_|l_hb}h`€jbjbj`~j^€iak`~j_|j_zi\yh[{jb{ha‚lf~i`|k_}m_}lb|j`{i^{j^~k]~k]j_~i]i^i_iaia~j_~j^}l]}l]|l_}ma}m_ma~kclc€oc~n_€m^|k_|na~od~oc|k^|k_~m_naqb‚rb€q_}pfpgƒofmd~lczkb[ZN[XM^ZKaZKfYPh\Rk_Uj_Ti]Rj^Qk^Qn`Sq`Un^Uq`XpbZxe\xf]wf]ve\ze]{e]{b]}g^}g[{fZ}g[h`€kb€kcldldmcmalfnf~ib‚ke€ibƒmemf‚og€ncldld€lflemfke€mf‚ogƒqgŠwizqysys‘{u‘{s“}r‘{rwpŽvpzqzm‹vnˆsk„og‡rj…ph‡rj‡pj‚lfƒmg‚ognf€nf…mejb‚ldƒj`‚i_ƒi`e_}d\~f\}eZ~fYhZ~e]e_€g^‚i_…lb…na†mc†lb†lb„ka„ka„ka…lb…lb„ka‚h_f\e[}fY€cZƒc]„e^„h^‚j^„i_ƒh^…ib„haƒfa…gb„ka‡lb‡ja‡lbˆnd†pd†lf‡kd‰nf‹oh‹ngŒoh‡ncŠoeŠoe‹pf‹ofŒofŠlgŒmhnhngŒnd‹oeŒmgnhŠoeŠoeŽqfqf‹qjŒph‹pfŒofŒoeqeojoioioi‘pk’rltmrlrk‘pk‘qk’pj‘qk‘rhrgqfqg‘pjpjŽpiŽqk“rl“sm‘qlqhriŽqhsj‘qhŽof’qhof”ri‘pg’qhpgoiŽngoioi”qk’pjŽpgŽrj‘qk“rmpi‘qf’qhqh‘riqhŽqkŽpk‘rhqh‘siqh“tk‘qh‘smqjŒohqhsjriojpjoipjoiŽnhpg‘ri‘ri‘ri‘ri‘rj’sj“tk“tk“tk•up“sn”sj”tkŽpfqgqhŒpg’qk‘qkqhpgqhqgŽnhpjqhpgpgnemipjqfrfŽqgŽpg‘rkqhqg“tkriripiŽqjŽqhpgŽqh‹peofpgqhoioiŽnhŽnipkpkpkojŒoiŽnfqgpgrkrkŒohŒofqgpgqhŽqhpgpgŒofpgpgŒqgŒqgrkŽqhŽqhŽqhqgshŒqjŽrjoipjqjŽqjrhrirkpi‹njŒpj‘rkojoj‹nhŒoiŒqg‹piŽqj‘qkoi‘pjŽqjlhŽpjpiŒohqk‘pkqkrkŽqjrk‹neŒpgpf‘siŠofŒqh‹pjŽrkqg‹nfŠmfoi‹miŒni‹ohŒpiŒohŒohŽpiŽpingqhŠrgŠrh‹pf‹neŒojŒpj‹ohŒqgŒqgŠpepg‹pg‰oi‹qjqiŒogŠnj‰oiŠpgtjŒpgqkŒojpjŒpiŒqgŒoiŒoiŠniŠoi‹qk‹qk‹ohŒpiŒofsi‰rgŠtiŠrgŠrg‹oh‰ohˆph‰pj‰oi‰mh‹ng‡le‰nhˆrjŠrj‰ohŠqgŠqgˆoe‰pf‰pfˆoe‰oh‰oh‹qk‰oiˆnh‡mf†pe‡qf‡qf†og‡oh…ng‡ohˆqiŠpiŠpiˆogŠqi…ph…of‡pc‡oc„oe…og‡qe‡qe†pdˆqf…oc…oc…pi†qi‡ph†pd†pd‡qdˆoe‡ne†leˆnh…ke„id‚kc„kd†ke…kd‚ibƒmd„jc‚jcjb„me‚mdldƒkd‚ke‚jf€gbkdƒpe„kc„ka„j`ka‚mbƒlamb€la€k`‚lai^‚lb€laƒlbjbjcƒhb…ke„ka†keƒga€ia€i^~i[}l_makcic€ic|ha}h`}h`~jbk`‚mb„ka‚ma‚lala‚laj_~h]h`|h[l_€m`m`}jbidid€id|ia~l`}l`la~k^l_m`~kb|ib~j`}h`~hbic~iaj^…jdƒhaia€lc}ma}l`}l_o`~m^}l\~k]‚ob~lf~ld~lbƒoa‚l^‚m\€m`m`}k`nbmdnd}kb~ld~kckcld€ia}kd~kd~kd}jb{h`}k`}j^k`{i^|ia{iaxf`|hb~jcld}k`la~j`}ia{ia}lc|lb{j`{g_{j_yi]zj_}k`~la~k`|j_{i_}kc~ld|la|ma€lcma€la‚nc‚oc‚pb‚lakb|kc{meznc|qb}oa}m`}l_nbod~nb€nc}l`~ma~k_ƒl`ƒj_\ZNb]Qa\Nc[MeXRdXPg\Ri]Sg\Og\Oi\Om^Rn]Qo^TqaVrdYwe\xg^wf]xg^xe]xd[xd]ye]zh]{i]zh]}ia}h_~ib~iald€kdja~lb€lc‚me„nike‚je}ibld~lb|k`~kdlenfoh‚oi€mf‚ogƒqfƒpc†rh‡pj‰smŒvn‹vo{pzqwpwoŽwn’zowqŠum‡rj†qiˆsk‰ujto‡rl‡pk‚mekcxf^}f^{d\|e]}dZ|cY|cY|c[}dZf[g[hX€i[ƒhaƒhbƒja„ka…lb…ma‡lb…j`„i_ƒh^ƒh^ƒh^…j`…j`†ka…j`ƒi^ƒh^i]ƒf]‚e^‚e^ˆkb…l`…ia…jbƒg`ƒg`…i`„h`†j`ŠndŠlc‰lcŠoeŠqg‹pi‹oh‹ohŒpi‹ng‹ngŒqfŒpfŠneŒof‹neŽpg‹nhmgŽmglfŒndŒofŽpeŽpfŒpfŒqgrhqgŒpjŒpiŒpfŽqhpfpfŽngpiohpiqj’rkrk‘rlqjŽpinhqj’rl‘rkqgrhohŽnhpiŽpirk’qk’rl’rlsisjsj’tk“sjpgŽofŽofpgrhŽpgŽofoiojpj‘pk“pk’qk‘tjslojpjph‘sh’qgqhqh‘rktlslqh’sj“tk‘ri’tk’sj“sm’rlni‘ri’sj‘ri‘qk‘qjpjoiŽnh‘qkqhqh’sj‘ri‘ri‘ri“tk“tk”ul‘ri•uo”to’rh“sj‘ri‘riripf‘qkpjph‘riqh‘qhŽpipjqhŽofnene‘niohqgŽrgqhqi‘riqh’sj‘sjqhqgpjŽqkŽqhŒnfogpfpgneŽnfmgmgmgnhŽnhoiŽpjŒnh‹nhŒmdneqgŽqjqj‹ohŽqg‹ne‹nepgqhŒofohpiphŽpipiŽriqlqkqiŽphqiŽpgqjŒpioi‘qkpjslrislsmrkŒpiŒojriŽqkŒniŽpkŒqj‹pf‹piqiŽohpjpjŒohmiŽpiphphqk‘pkŒohpiŒohŒoh‹ng‰meŽmdŒneŠoeŽriŒoiŒqiŒpeŒofŒog‹ohŒoi‹mh‹ohpirkpi‹ohŒpinfŒphŒpg‹ph‹ogŒog‹ogŒqhŒpiŒpiŒph‹pg‹ne‹pgslŠpi‹pgŒpgŠoiŠpi‹rhsi‹pgŒpgpkqjŒqg‹pfŒpirmrmqkŠpk‰ph‹ph‹ohofqgŽsi‹qg‹qg‹qf‹ohˆngˆqi‡oiŠpjpk‹og‰oh‰ohˆqiŠqi‰ng‰pfˆoeˆoeŠqhŠqgˆof‹pjŠpj‰ojˆngˆng‡nf‰ne‰oeŠog‰mf‰ngˆmf‰mgŠoh‡mf‡nf…ogˆqiƒnf†oe‡oc†oc†of‚mf†of…of†of†pg†of…oeƒne…ne‡qf„nc„nc…ma†ld…ke‡meˆof…ldƒjaƒld†mf„jc…kdƒkc„meƒldjb€ia‚ld‚kc‚kcƒhbƒic‚icƒjc‚kbƒnc…lbƒj`ƒi`‚ldjc‚jd€lala€j_‚lak`‚lak_ƒla‚la‚kc„ja„lc„la„jb„jcjbk_€j^€n_€maƒlbƒicibi`ja~i_}k_€l`k_„l`‚j`ƒlaƒkaƒlai_‚k`€ia€k_nana€mb}jb~hc€jd‚le|ja~lamb€kbk`ƒpbobmbmd€k`kbjc€kd€kb€maƒlb„lc…odnb€mbma€mboan^€m^m_‚mb|kcofnbƒpdƒob†pcnb…pd}j_}k`~l`~nakc~jajbjbjb€kc~kd~kdkb€mc~j_j_~l^k_}k_|j_{h_{i`}ic}kc€nd~lajaib~ia|ha|jb|jb~kc|ha{j^|l`}mala}k`~lamb}ja|kc{iazi_{m`}jb}l`{j^~mb~m`ob‚mcmemfzkb{l_qc~ma}l_~l_ncnb~na€mb~la€ncmb‚mb~e[^XMe[Rh_Uf^RdZSdZRd[Qf^Rc[Nc[Mj^Po^Sq_TsaVtcWueYud[ud[ucZtcZubZwc\xe]{h`{h`|h`}jazg_}i]~j_}h`jb~ia€jbnb‚nc‚neme‚lg€je~ibke€mbnb€ka‚nf„og„oh‡qk…oi„pf‚nc‚ob‚nb„og…ph‰tl‹wmˆwlˆujŠvlŽwlŽukvlŽuoŽvpŽwpŒumwl‹vj‰tlˆsk†qi‚me|g_wd\zc[xaYyb[e[}dZ~e[fZg[€h\ƒl]‚hZ„j\€g]‚i_h^ƒj`ƒj`‚j`…h_‚e\ƒf]„g^„g^„g^„g^†j`ˆlc‰mc‡kbˆkb‡mag]ƒf_…ha†ka†k`†ic„ia„hb†ka‡mb†l`‰lc‹md‘qhpgpgrhqjqjqjpi‹ngŠng‹ne‰lcŠmd‹lc‹mdŒmdpiŒogpg‹meŒofŒogrg‘sh‘ri’sj’rl‘qkŽqjŽqjŽqjpgŽqhŒofŽpeŽpeqg’ti’ti’ti”rlpjpjŒohrkŽrkojpj‘qkpjoiŽnipipisl“sm‘qk’qlqh”ul’sj•vm”vmpgqhqhpg‘riŽofpgpgqhqh‘ri’ph’qh‘sh‘qjpj‘qk“sl‘sh“shqgpiojrkŽqiqh“tkqh‘ri’sj’sj•sn’qk’qk“ql’qi’qh‘qk‘qk‘qkpjpj‘qk‘ri‘ri‘ri‘ri’sj’sj’sj“tk“tk‘ri“sm“sm‘qj’rk‘qkpj‘qkoiŽnh‘pk’sj“tkpgŽofŒpiŽqk‘ri‘pgof‘ofnhoepgripg’qhphpgqhognhŽnhpgneŒofŠmdŒofŠmdqhmeoi‹keoimgnhŽnhpiŒoh‹ngŠmfŽofpgofŒpiŒohŽqjŒofŒofpgŽqhŽphŽqh’pj’piŽnhpjpjpj‘qlpjojpjpjŽpiojql‘qlpk‘rlŽqlrkŽqjŽqjŽqjqjqjŽqjŽqjpirmrlŽqjŒpiŽrjoioipjŒpipiŽqiŒofŒofphpjpgŽqhpiŒohŒngŠmf‹lbŒnf‹pfŠofŒqhŒof‹odŠncŒofŒofŒogpjmgŽoipiŒoh‹phŠngŒohpi‹ohŒpi‹oh‹oiŒrgŒqgŒqhŠng‹oi‡je‰ndqiŠohŒpiqjŒpfŠqgŠqg‹rhrhŽtjrgqkriŒqgŒqg‹oirmŽql‹ql‰qj‰rjŠoiŒqgpiŽqjpiŽqjpipiŽrkŠoiˆqi‰pkŠpjŒojŠngˆlf†og‡ph‰oh‰mf†mb†mc‰pfˆoe‰pfˆnfˆni‰ni‰oh‡meˆoeˆpd‹pf‰neŠng‰mfˆleŠngŠngqj‡mf†kd†ph…nfjb„oeˆpd‰qe…oeƒme†le‡mfˆng†mf…kd†me„pc„mbƒmbˆoe‡me…kd†le†ld†mc…mb†nb…mb‚ld„kd„jc‡mfƒjc‚kcjbiajb„jc‚ha„ib„i_„i`ƒj`…kb…mbƒk_‚j^€g]„jcƒkeƒkfie€lbmb„oc‚mb€j_‚lal_„mbƒmaƒma„kaƒj`…ka†ld‡le‚lc~i]k`m]ƒn`ƒj`…lb…lbj^€la€lana€m`l`„l`†mc‡nd„kaƒj`„ka…lb‚la‚mbl`€l`nc~lb€jc€kcld~kc~lamb‚memcod‚qd‚pd‚oa‚nc‚ndldƒnf€lbmb„pe‚nbƒobna„oa…oamb€n`ƒn`€k]€j^…nb€mcƒqf€nc„odmb‚mb~kc~jb{i^}k`~m`oaƒjdƒjc‚kc~iakc}jb}k`~ka€lak`‚j`€i^~l_~l_|k^{i]}k^}l`}jc|ia~la}k`j`jc€j_~j`~kambmbl`|l`zj^yi]mb}l`|k^~la|j_yh_{jb|k_yk_~kc}k`€nbod~m`}l_}l`}la~nc|la}m`~l`obpc€n`‚nd‚oe€pd}k`}j`~nbmal`k`]RH^TJbXNd[Rf\Ue[Sf^Tf]Sg^Sh`Tk_SpaUr`Ur`UsbVtdXpaYrbYtcZxg^xh_xg^xg^xg^yg_xh_|kb{ia|h]j`~k_€kc‚neld‚nb€na‚me‚me‚le€jekeƒmg„pe„peƒpd‚ncld„ng‚lf†pj…pg‚ocƒpc†rf‡rjˆsl‡siˆth‡uj‡ti‰ujŠtitjvm’ytwqyqŽwo‰th‰sfˆtkƒme~ia}f^zc[|e]{d\{d\{d\€g]g]g]i]h]‚j^ƒk_„j]‚gZh_‚i_h^‚i_ƒj`‚i`ƒg]„h_…i_‡ka„g^†i`ˆlc‰lcŠmdŠmdŠndŒofŠnc†ka†jb…ib‡lb‡k`‡kd‡kd‡lc‡la‰oc‰ocogŒofneqhqhrhqjŽrkrkrlŒohmg‹neŽqhŠmd‹lcŒneŽofŒoeŒofŽqhŒofŒofri‘th“uj’ri’rj‘qk‘qjŽqjŒohŽqjpiŽqhŽqhqfŽpeqg‘sh’sirg“qkqk’rlŽqjŽpiqjrkrlŽpkŽplŽqkpioi‘qk’rlslŽrjqj“sj“tk“tk“tk“sjqh’sjqh‘sj’sj’tk‘sjqh’sj‘ri‘ri’qh“ri‘sh‘rkpj“sm‘rk“uj”tgqg‘qk‘qkŽriŽqhqh‘ri’sj’sj‘riri”sjogoi“qk“qk“qk‘qkpj’rl‘qlpj‘ql’si‘ri‘riqhqh‘ri’sj’sj’sj‘ri’rl“sm’rl’rl“slpjoiŽoioi‘pk’sj‘ripgŽof‹nhpk‘rjqhof’qhqhpg“rinhne‘pgrgŽof‘riogŽmhŒlfnemdŽof‹ne‹nfŒofŽmhmgŒlfŽnhphqgnhŽnhŽqjŒpi‹ohŒlgŠne‹of‹neoiŽnhŽmgpgŒofpgŽqhpgŒpg’pj‘oipjpjpjŽoiqlŽniŽniŽohŽnhŽpiŽrk‘rl’rl’rltlŽrkŽqjrkrkŽqjŒpiŒpipiŽqiogpgphpiŒpipjŽnhoipi‹ohpipgŽrgŒpepgŒogŒofriripi‹ohŒohohqirh‹pfqgŒog‰ncpfripgŒofŒoeŽnhŒngqjŽqjŠohŒqjpiŒohŒoh‹ohŒpi‡nfrgŽsi‹pf‹oi‰lf‰mgŒqgŒqi‹ohqkŒqhŒqg‹sgŠqgŠqgtjtjtjrhrgŒqgŒqgqkŽqlŒpj‰pi‹tl‡qh‰qfŠpfŒpisl‘tmpiqipiqjŒrkˆqi‡oiŠqjpkˆmf†lf†og‡oh‰ng‰le‡ne‡ndˆoeˆoeˆoeˆnf‰niˆnh‡lfˆngŠrgŠrf‹ohŒpi‹og‰mf‹og‰ncŒoi‹oh‹ng‡mfˆng…le†kdˆnf…oc…nc‡le‡mf‰oh…kd†le†le„jc†ke„ocƒmbƒmb†mc‡ne…kd…kd‡md…lb‡nc„l`†ma…nf„kcƒib…kd„kdjb€jb‚kb‚kc„jb„ib…ia†jc‡lbƒj`„l`„l`„ma„l`„l`„ib…nf‚jdic€lb€la€k_k`k`„nc€la„ncƒmaƒma…ma…m`„nb…odƒme‡mf„jb„j`l_ƒma‚la‚laƒja‡nb„odƒnd‚pe‚ob‚ma…maˆoe†mc†mc…lb…lbƒj`ƒmb‚mbmblb‚odnbjb„og…ph|j^lbmbƒld‚nfod€od‚pc†oc‚obƒodmdƒnfk`l_‚ncnbna„nb„na„o`€la€maƒn`‚m^ƒmb…mc~m`€nbmbk`nbjbyg^|i`|j`~ma€ob€pa‰lfˆle‚jbldnf~kdmbk`mb‚la„ndk`m`~m`~l_~m`{i\}l^lc|j`|k_~lajaldma~ka~la~mb~k`€ma}kc|k`{m_}j_~m`}l_|j_|j_zj]}l`}l`zl`lc}k`{i]|k`|k^}l_yj`~ob~mb}l_}l_}m_~ocncncƒpc€qcpb‚odnbocpe„qfƒod_PGaQHdVOcWPbXOcZQh^Vj`XkaXh^VmdZocZqaYqaWqaVqbXocYtcZve\wd\zi`wg^{i]|iaxe^ye_{hayg^}j]€la~j_jbkdlf„nbmbmb€lcƒng€me‚lf‚mfnc„qd„qcƒpd„pe‚me…pi‡ri‡rh„qe†sd…rf„pf…pi…qg‡sh‰sh‰uixjzlynwnŒtoŒsn‹slˆqh…oc„nbƒodla|f[|e^|d\}e]‚kc‚kb€ia€g]€h^„i_}h\h]f\‚f\e\€cZe[f\‚i_‚i`„jcƒib‡lb‡lbŠoeŠoe‡lb‡lbˆmc‹oe‹pfŒqgŠoe‰nd‹odˆkbˆme‡leŠmd‰ncŠodŠpdˆmc‡lb‡lbˆnc‹oe‹oe‹mdŒogŒqgŠqgpjpiŽqjŽqjnhŒlg‹oepg‹oepg‹neŒneŽqfŒperg‹pfŒpgqhsh”tj“ri“ri“siri’pl‘qkoiŽpirjŽqipipipipi‘rjpipjqkqj‘rlrk‘slrislsmrlŽqipfoipjpjrksl‘sl”tj•tk•ul“tkqi‘risjsjsjsjŽrisj“tk’sjqh‘ri•sj”sj”uj’rkpj’rlrjti”tgri‘ql’snrkti“tk‘riqh‘ri’sj‘ri‘riqhphpjoi‘pj‘qkqj‘qkoipj‘qkqh‘riqhŽofpg’sj“ri“ri•tk“ri“pk’qk‘smsl”tnpjnhlfpj’rl’sjqhqhqh‘pjnh‘qh’sjofŽphŽrfpfpjŽlflfofodŽpeŽofŽniŒlfŒlgmdmdŒmdŽof‹nh‹ngŒlf‹kemgŽogŽoeŽpf’ngŽngri‹pg‹nfoh‹mdŒneŒofoiŽohŽmgpjpiŽqj‘tmslpiohŽogŽohŽohqiŽrjŒoipjqiŒqhŽriŽriŽqirjpi’rkrjŒqiŽokrkpipi‹oh‹pf‰mfŠpeqgŽqgqhŽohpiŒngoipiŒohŠpirhŒqfpdŒocrgŒqgqfripgpipjŽpkoh‹ohŽsj‹pgŒqgŽpg‰mepgrjŽqiŠmeŒogŠogŠngŒohpiŒoh‹oh‹nhŠmg‹nhpjŒqj‰piŒphŠnfŠngŠng‹pgŒqhŠqg‹pgŠmfŒohsk‹rhŒthŠqh‰oirlqjŒqgrhuhŽuhqh‹nhŒnj‹qjŒsk‰sl†qfŠrhŒsiŠrjsltmpirkŽslqjŒrk‰rjˆpjŠpjpkŠoh‡ng†ogŠoh‰ng‹ng‰ngˆng‰pi‡mfˆnh‰ohŒniˆkeˆld‹peŒpf‰nbŠohˆmf‰mgŠofˆmcˆmcŠnhˆmfŠngˆkeˆkd‡kd‡kd…kc„ma„nb†ld‰mf†me†ldˆngˆof…ld…lc…oe…lc†mb„kb„k`…k_†me†le‡me†ld„kb„kbƒme„kc„jcƒib„ldjb…la„la…lbƒj`„k`‡od‰mg‡meƒl`‚k_k_€ka„k`…ma„k`‚maƒmbƒmc€lambk`k`ƒmb„ncmc†oeƒmc‚k`…la†mb…od…oc„me†le†me†mcƒma‚mbldƒld„nd„maƒmgƒmgne„oeƒmd†mcƒncƒnc„pelambƒod„nb‚malcƒnf‚ocoa‚nb‚oc„pd~mbod~mbƒma‚pdof€pe„oe„ma‚nb€makamb€la€m`ƒmckambnaƒmb‚nb‚nenbob€m`€k_ka~k`mbk`€la€k`}j_~m`~la}k_€ncmaƒob„lejckc€ldmdldla€lamc}i`}jclc|j`}jb|j_~l`}i^l^}k`|j^|k^~l`j`€kdmb~mayj^zl_{k_~ka{ja|kb}ma}j_|k^n`yf\zi]|k_ob{j^{mbndpc|l`~nb~na}m_zkb€ob€ob€paoa|ma}ococ~nb~napb}pcmc~mbqe€pd‚pe€mbfUMm\Trc\j\XcYO`VLbWOg\Tj^Xpc]ne^nb\ob[rb[pbYqcZqe[te[wf]xf]xf]te\zg]yg^{hbzfa{hb{i`}j^k_~j_{g_~hb€jdƒme„me€la‚ncpeoe„mgƒmfƒpd‚naƒpd†sf†rh†pi‡rjˆskˆuiˆuh‡te…qeƒpd…ph†rf‰uivj‹ujŒwhxj‰ti†shˆoj…mh~g_h`~i]€i]|i\}h]~h]~g_e^g`€iaƒld€ha‚i_i_~dYh`}f^~d]d\}`Z}`Xf[‚i^„kb…lb„jc…kd…la…laˆoeˆoe‡nd‡ncˆoeˆoeŠqg‰pfˆoe‰pf‹md‰lcˆng‡lf‰neŒndŠqcŠpd†l`†ka‡lc‡lc†mc†ka‡j`ˆmb‰oe‰pfpipiŽqjoiŽmgŒmg‹qhŒrgrgrhpgŒofrfth‹sg‹rhpgpiqk’rl”ph’og“tirh“pk‘ok‘qkpjŽrkpiojpjoi’rl“smnirj‘smŽqi’rlpj“rlsisiŽqjslŽqgŒpfoipjojŽqj‘tmrk”rj“rj•tkqh‘ripgŽrisjŽririqhsj“tkqhqhog”sj“ri’rg‘qj‘pk’rlslti“th’sk’rl’rmsj’wl”ul‘siqhqhpg‘qhpgri‹oepipiŽpkŽnhpjojpjŽnhojŽpfqhogpgph‘ri”sj”sj”sj”sj‘oi’qk‘rl‘tmpkpjŽmg’pjpj“smripgqhŽpf’nhlf‘ognf‹neŠoeŒsf‹pemhŒlgŒmgŒogocŽpdpfŽnh‹kf‹lfmcneŽmdŒmd‰mfˆleŒlgŒlfmgŽofofmdmdpg‹pf‹qfŒneŽme‹neŠmdŒofŽnimgŒmgŒog‹ohphqiŽqjŒohŽpgpgofŽqhrhŽsgqjŽsirhrhŒrgqfsh‘rhqfrgŽsh‹sgŽpkŽpkŒohŽqj‹pg‹pe‰mgŠodŒqeqfŽpfŽnhohŒlgŒlfmg‹ohŠpg‹qgŒqepcŽqdrfŽsjŽqeŽqgriqkŽpknipipjŒqgŒqgrhqh‹oiŒniŒohpiŒohŠmf‹ohŒpioipiŒnhmhˆlg‰lgŒlgŒnj‹okŠoiŒoj‹nh‹oh‹pf‹pfŒqfŒsh‹og‹nhpiŽrjŒsi‹shˆne‹pjŽqmˆkfŠnhsgŒrfŽthŽsipkŒoj‹qjŠqj†qgˆsh‰rgŠpf‰tlŒskŽrk‘tmŽrkŠpi‹ohŠpi‡og‰pkŠpk‹njˆng‡ng‡phŠoh‰ngˆle‰ng‡mfˆng‰oh‰ng‰oh‹pf‰ndŠoeŒqgŠmfŠnf†mg†og…mf†pe…od†pf…nf†ngˆleˆle‡ib‰jd†jc‡meƒm`…od‡me†kdˆnb‰ocŠpdˆnb†l`ˆnb‚jc‡mf‡mf‡nc†l`‡l`†mc†lc‡mf„ke…ke„iclc…mf…kdƒib„ldƒkc†ja†ka…la…lb„lb„nc„lg…nf‚mc€j^ka€lb†mb„l`„l`…oc…oa…naƒodƒpdƒnc…oe…oc†pe‡pi…mf…nf…nfˆnf‰pf‰tf…od„mdˆng†le†mc„ng€lelemgƒmeƒlb„mh‚lfmg„oh‚md…ldla„qfnb‚ncmb„pe„nbmaƒnf‚nf‚pd‚qc‚od€lambncod€ncƒn`ƒre~of‚ph‚nd„kam`‚ocmbla€l`~l_‚kcjbkbld‚nc‚nc€nf€ob€oaobƒoc€lb€kcmc€l`}k^€ob~maob}m`}k`mc‚le€kc€kbkb~jcld~kc|iaƒmb†og|ia|ibyg`{jc{ib{ja~kc}j^~j^}j^|j_}l_~na~l_j`jcnc{k_xj^zl`~ob|m_{jb|kb{k_|j_}m^~m^{g_}l_|m^~n`~n`|md|kboc€pd~nb|l_{k_zi_ob€o`‚rb€rb~re~re}od|nb}pa~qc~sdƒpeqe€pdoc~mamacVPodXvk^tg^fWOeXNdXNf\Ri]Vl_[pbYnb[rfapgbrk`mgYrbWsd\ug_se^uh]uh[ziY‚najajd}id{hc~h_|i`zk_xj^{jb~ke„oe„pe„pe„pe„pe…pfƒre„ri„nhƒnh‡ph‰skˆunˆvn‡rj‰rjŠsitjuh‰sgŠtjŠvk‡tm†sk‡rj†rj†qe„nc€j^~h[~h\i`‚hbfaƒh`‚i]g_‚jbg`h`i_~i]€h`„k`‚h]g[€e]{e]e^}b\}e^€b]‚g^ƒh]‚i_…lb†mc…lb„jd‡mf†lfˆngˆngˆng‡mgŠngŠoe‹pfŽrhŒpiŒpiŒoi‰oe†mcŠoeˆlbneŒmdˆm_Šnc‡k`‡k_…j]‡m]…k]…k`†jb†ib‰lbŠobŒqgŒqhŽqjŒphŒnhŽnhofŽqhŽsiŽsiŽriri‘riogŽpgŽpgŽqh‘tj‘pj•sm“qk”rl“qk’qkpk‘qk‘qk“smqiqhŽqjslqjrk’pj“qjpfshshsitisiukŽsiŽqhsjri‘rjpj‘qkpj’rl“sm’rl’sm‘qm’rmoipjriqh‘ri’ri“sj“tk‘ri‘sgqfrh’ti’sjphŽqhri”sj”sj“sj“tksjrh•sj”rl’sm‘uo’qk‘qk‘rkpjpkpj‘pjoimgpkmhŽniphpgqhpgŽpg“rhokohpgpgqfqf‘rl‘ri‘ri‘ri‘sh’tj“sipf’qh’pj‘oioipi’sk‘oe“qfoh‹oilfpfŽqcpcpfŽnhofŽofŽpfŒlfmglhqg‹neqjŠmf‹mh‹ming‹mgŽnhmglfŒke‹kfŠlh‹ohŒohŽneneofqhŽqjpiojmhieŽlf‹ohŒofof’pgŽniphpfŽpfqfqh‰pe‹pfŽsipgriqiŽpfphŽog‘qlojoh‘shripgŽqhpiŒpiŒqj‰mfpiŽqjninioeŒnf‰pf‰ogŒnhmhŒneŒmeŽnh‹ngpfŽrgqhsjŒqg‹pfqh‘ri“og‘ojqmŒokpjŒpgoiohŒoh‹ngpkpkojŒniŒnioj‹niŠmiŠngŽrjrhŒqg‹pfŠpdŠmf‹ng‹ngŒohŒogpi‹njŒoj‰lgŠng‹og‹pf‹oh‹oh‹ohŠohŠpi‹qjŠmh‹niqlŽqkŒph‹ngŒpiŒpiqjqjqjŽrkŽrkŒpiŒpjŠoh‹ohŒpiŠsk‰sjslqjŽqjohŒpiŠmf‹ng‹og‹ngŽrkŽqjˆmf‡ph‡ph†mfŠngŒojŠmh‡mgˆnh‡qh…nf‡mf†mf‡mfˆoe‰pf‰qgˆnhˆng‰pfˆoeˆmg‡mg‡mf‡lf„kd‡kd‡kd‡kc‰kf‡md‡md‡nbŠne†j`‡nbˆpe‚j^ƒk_ƒk_…la‚ld…nf…nf„ncƒlb…od†ld‰ng‰mf‰mfƒkclc†la…mb†mb‡nd†laˆnbˆpc†ob„jc‡mf…la‡nb…kbˆne‡nd†lb†mcˆndmaƒmc…odƒodncmbƒmd…me„nbˆsf‡qg„nf†nc‡ne†mc‡nd‡nd†mc…oc†pc‡qe„ob…oeƒleƒmala‚laƒld‚meƒmf„me‚ldƒodƒobˆpcˆo`…nb„md„leƒkeleƒoeƒmaƒmaƒmbƒmb‚mb†of‡oe†mcƒlamb‚mfme…od„od…nf„nf†mg„lfmb‚nc~j_‚oc€k`i^€j^‚ib„ic…id…leƒmbkc~ob~nb|l`€oa„ocpc€md|iakdne€obp_€m^‚oa€m`€l`ja€pboc€pc~la~la~m`€kc~ia~ia~h`|h`|h`|jayi`zka}lc}h`€h`{kala~j\j[}i\~k_|f[|h]yi]|l`|k`{i]|j_}k`|j_}k`|i_zh]{l_{k_|k`|kazi`~mc}k_}l^|j_}j_}k`mbƒqfodƒqe‚rfƒrf~o`|o_~qb~pc}ocqd~qc€ndof~mdnenenebWRe[Pf[Oi\Ug[Ue[Sh^Uk`Wk_Xma[odZmc[mc_ofaqjaulatg^tf^rg`sh`sh^wi_zk^~mb€kd~jd|jczib}h`|i_}m`|mbme€mgƒndƒodƒod†rfƒod†rg…ug†tjˆrl†pj†pi„og„pi„oh†qi…ogˆsiˆqfŽwlwmynŒwmˆrj…ngkch`~g]|dY{bY|bW|f\i_ib€g`€h_‚h^}i^‚ma‚lb‚jbha„kdh`€e\€eZ€f[€f\{d]{bY~e^ƒgb„ha†jb‰oc…mc…lb‡nd†md†lf‡mfˆngˆng‰ohŠpi‰ohˆngŒpf‹pf‹pfŒphŒpi‹nh‡od‡mc‰ndŠmdŠmdmeˆmc‰lc‰ld†i_„i^…j[„j^…k`†i`ˆkb‰lb‹od‹pf‹qfpi‹ngŽqjnioeŒneŒqgrhŽrisjpgpgpgsjrjsi‘pk‘ql“sm“rm“smpj‘ql‘qk‘qkpj‘ri’tj‘rlrkpiŽpipi’ojqg’sirhrgsiuj’vmtjsjsj’tk‘rioj‘qkoj‘qk‘qk’qkrn‘tnŽrjŽqjslŒof‘riqh’sj“tk“tk’sj”vl‘shqg’rk“tl’sksj‘sj”tk“ri’rj’riripg‘ph“qk‘rlsl‘rh’sjqhrhpg‘riqhphŽohŽogojniŒog‹neneŽogŽof“riphŽogŽof‘ri‘shrfŽnhqg‘ri‘riqf‘sh‘riqhqhŽohŽnipjŒpiph‘oe‘oeph‹oiogqgododŽne‹jcŽofpgohŽnhŽnhohpfofogŽoiŽoi‹lg‹mfŽnhpjnhnhmgmiŒmgpiohnhldofŽnhŒngŽpimgjgmfŽmgnhngpf’qhŽngŽnfrgŽpeqiphŠndŒpfqgqgriqhqhogpgpjpjpjof‘phqhqipjŽoiŠohqjpipipj‘qkŽof‹oe‰pg‰nhŒohmhmfŒlfŒlfŒoipgŽqgqhŽrhŒqgŒqgsiqh“pi‘pkniŽpkqkqhpj‹ogqipiqjqlŽpkojŒniŽpkŒojŒojŒpiŒpirhŽsiŒrg‹qf‹ngŒohŒohpiŽqjpi‰mg‹nhˆle‰mfˆlfŠmg‹oh‹ohŒpiŠpi‰ohˆng‹miŠmhpkŒpiŒpipj‹phqjqjqjqjŽrkŒpiŒpiqjqjŒpi‹piŒsltlŠqjŽrjŒohŒohŒpipi‹ohŒoh‹ohŒpiŒoh‰ng‰nh‡ng‹qjŽsk‹niŠmhˆnhŠqi‡ph†ogˆng†le‡mf‰pe‰pfˆoeˆmgˆmg‹qgŠpfˆmf‡lf‡mf‡mf…kd‡kd‰le‡kdˆje‰meˆoe‡ocˆmcˆlcˆme„kb„jb†md„jb†md…og„me…nf…od†pe„od‡ndˆnd‰nd‰nd…mck`†nb†mc†md‡me‡lbˆmb‡ndˆng†le„jd„kb‰peˆoe‡od‡oe‰pf‰pfˆoe‚ma„nc‡qf…qf„pe€la„leˆpg‡pd‡pe‡of…le‡nd…lbˆoe†mc‡nd‡nd†qe„nb†pd…od„mdƒld…od†peƒmc…nfƒnfƒnf†oe„od…qg‡rf†odˆob…oc„nd†pg…mg„og„pf„nbƒma„nc…odƒma‚lc†nc„nc„oclbld~ldƒmcƒne…ogƒme‚mcƒmc‚oc‚nc‚nc„pembk`€k`ƒlc„jc‚haia€la~kc}l`|m`|k_€namaƒqdmb~kc~lc}k_~maƒoa‚obmaj`}h`~i`~nbpcoa€ncmb}k_ia}h`~ia|g_|f^jb|ia{ia~mc}lc~kc~ia{ialbzh\€j\k_|j_la|i^~mb|l_|k_|j_}k`€ncmb~la~la}k`yj^zk_yi]{ja|ja{jb~pc}na~oa€pbpb€pa‚pf„rg„thƒsf„sf€qeq`qc€qepdpdqd„rg„qfncmbod~ma\SN[TK^ULbVSkc_lc_of`pe_oe^rf`slapjalfaneamd^pd^oc]pe]sibujcwkcylbymcykcyjd{ldxiaxi_{ib}ia|j_}la{iale€kc‚ne†qh…qh…qh‡ri…tg†tj‡um‡sm†qj„pgˆpj‰rk‹umˆrkˆsj†rg‰shŠti‹ujŒvk…od‚ncf\{bY~e[e[€e[€f\~g\€iajb€ia€hak`}k^j^~i]‚g`‚f`ƒd`~e]e_€e\ƒh^…ka€j_h^‚h`ˆkeˆleˆme‹qe‰oe‰ndŠpfŠoe‰mfˆle‰mf‹ohŠpi‹qjŠpiˆng‹pf‹pf‰nd‰ncŒqgŠofŠoe‰nd‰nd‹meŠmdŠndˆkb†ibˆje‡jb…i_„h]†l`…j_ˆkbˆlcpfshŒpgpgpgpiŒoh‹ngŽneŽog‹pfŠoeŒpg‘ri‘riqh‘ri‘tk‘tkriŽqiriqi‘sk‘tk‘tk‘qk’rl’rl’sk‘qiqh’rmqjpipiŽpioi”qk’qj’rlpj“tm“rmsj‘tksj‘ul‘sj“tj‘qk’rl‘qk‘qk‘qkqktnsltmŽrkrkqjqhpg“tk’sj’tk”ul”tn“smpj‘ql“sn’qlsi‘ri‘ripg’sjqhqgphoi‘qj’qlojqgqhqh‘ri‘ri“tkrfrg‘rhqh“tkoiŒof‹neqhpgqh‘pg‘ripgpgpgqhndŽnhpfpgpgqfqfqfŽoeneŽofŽohŽmhŒofŽpgne‘phŽpgŠmdŠoe‰md‰lcŽoeneŽmdnepipjŽnhŽnhmhŽofŽofŒmdnimgŒlfoipjnhnhnh‘mgmhoh‹ngpiŽmhŽmgnhŒlfŒoh‹mgŒlg’piŽniŽnhŽnhŽnhŽogŽoeofŽpeqfŽpeohojŽnhŽnhmgpipjŽnhqhpgŽofpjpj‘qk‘pg‘pg“ripgqhqhŽrkpirjpi‘qkpjŽqhŒpgŠpiŠpipi‹nhŽnhniŽmjŒmjoipiqhqhrhŽsiŽriŽpg’pjnhŒnipjrkrkŽplokrkŽqjŒohŽqjojŽokŽpkŽpkŒojokqjŽrkslŒqfŒqg‹pfrkqjŒohŽqjohŒohriŒph‹ohŒojˆkf‹nipi‹oh‹oh‰oh‰ohˆngsl‰oi‰ohŠpiŠpj‡ofŒpi‹oh‹ohŒpisl‹ohŽrkŒpiŒpiqjŒpiqj‰oi‹qjrkŒoiqjpiŒpiqjŒpiŒoh‹ng‹oh‹ngŠmf‰mf‡mfŠpiskŒmhŠmhŠng‰ohˆoh„nc‡mf‰oh…kd†nc‡nd†mc‰le‰mfŠnf‰nfˆle‰le‡ng„jc…kd†leˆng‡mf‡jeˆmd‰nd‡naˆmcˆmcˆng†le„jc‰oh‡mfˆngˆng…kdˆng‡od…mbˆoeˆpdŠqe‰ocŠpd„maƒmb†nb‡mc‡mfˆnfŠnd‰odˆog‡mg†lf†lf‡mgˆng†mcˆoe‡nd‡nd†mc‡nd‡nd†od†pe†pe„odmbˆmg‡me‡oc‡oc‡me†le†mc…lb‡nd‰pf‡nd‰oe‡qh„nb„oc…oc‡qg…ng†qe…oeƒld†ogƒogƒnf†pd…oc‡qe‡rf†od…lbƒnb„md…nf†og‚neƒod„nb‚l`„ncƒmbƒmajb€ma‚nc‚oe~mbme~md‚ke‚mdƒmf€lanbnak`|i]k`ƒodmb}k`mb…of„me€haj`{g[lc~k`~la~mam`~j^}k_lb|j`}ka~kana€mbmblc}jb~kcleocna~m`€ncod~lake|i`~kc|i`~kc~kc€ldld~kc~kc}jb}iazha}i`}h`~j^~j_}la~j_}la~laoc€nc}k`mb€ncmb€ncma}la}nbzma{k_|kb}jb}kbrf|nc}pb~o_saqa‚pd€pdƒsgqe€se~qdrb€odqdpgqdƒsgqdpcpc‚qdpcnaRMGTNFTMEWNMYUQd^\f`]kb`ne`nf`tnesogqlfpkeoeak_[h]Zd[Ug`Xnf_vkd{mgznhyohvleri`rj_tk^zkd|kc}m`|j_}ja}kc‚meƒof†qi†qi†rj†rh„sg„rh†sl‡tm‡tl‡ul‹snunŠtlŒxp‹vmˆtiƒmb~h^k`„oc„mb†mcƒj`‚i_f\‚i_„i_‚h^f`ia‚lak`iai`}i^~h^€g]€f_ƒf_„gaf_g_ƒg`…ia‡mc„nc‡m`…j`ˆldˆle‡ld†oc‰ndŠoe‹pfŠoeŠng‰ng‰mf‹ohŒrk‰oh‰oh‡ph‹pfˆmc‡lbŠod‰nc‰ndˆmcŠoe‡lbŠoe‰lc‡ja„g`ƒe_…gc‡id‡jb‡j`ˆmcŠpeqfŒpe‹oerjqfŽqhŽqhŒof‹ng‹ngŽofpgŠpfŒqgofpgqh‘ri“tksjriripgrirjsjrisj‘qkŽoh‘qi’sjpgqg’qkqkŽqjŽqjŽpipj’pj‘oiojpjqk‘qk’sjqh“tk“tk‘sjripj‘rk’rlpj’rl’rltktjtjqjŽqjŽrkqh‘riqh‘riqh’sipk‘qk‘qkpk’rmpjoh‘ri‘riŽof‘riŽofŽmhoioiŽnhphqh‘riŽofpf‘ri‘riqhŽshtiriŽqhsjpipgpgqhpgqh‘pgŽofŽofŽofqhŽofnemgŽofpgŽoeŽpeŽpeqfŽpenepgŒneŒmdŒofŽpgpgŽofŒofŒofˆmc‰nd‹ngmgofŽmdmhohŽnhŽnhnfneŽofŽofpgneŽogŽnhŽnhmgmgmgmgmgmgojŒngŒohŒmgŽmg‘oiŒlfŒohŒohoimhpgogmgŽnhpjmhŽofŽpeŽpeŽoeŽngmhŽnhmgnhmgŽnhoiŽoeogpgoipjqk’qh‘ph“sj’ripg‘riqkŒogŽqjpiqjoiŒohqjŒpiqjŽqiŽqhoiŽmiŽmjŽolnkojŽnfŒpgrhŽsirhphplpjpjpjŽqjŽpkŽplŽpkrmsl’umskŽqjŽqipiŽqjŽrkŽrkŽrlŽrkŒpiŒpirhŒqgqkŽrkŒpiqjŒpiŒpiŒqg‹ogqj‹ni‰lgplŒpiqj‹oh‰oh‰ohˆng‡mfˆnfŠpiŒrj‰peˆod‹oh‹ohŒpiŒpislŒpi‹ohŠngŒpiqjqjŽrkslŽrk‹oh‹ohŒpipiŽrkŒpipiŠmf‹oh‹oh‹ngŠmfŒoh‹ohŠohŠpiŠmh‹ng‹oh‰og‰odˆqfˆngˆng‡mg†mc†mdˆqe†jd‹ogŠmg‰mfŠng‰me‰oh‰oh†le‡mf†mf‡nf…icŒphŠoeŠpdŠoeŠoeˆngˆng‰oh‡mf‡mfˆnh…kd‡mf‰ohˆoe‡ndˆoe‰qeŠpeŠpdŠpe…nb†pd†mc‡me‡mfˆngŠnf‰nd…kd†le†lf‡mgˆngƒjb†nc‡nd…lb…lb†mc†mc†mc‡md†oe†pe…od†peˆmg†me†nb…maˆof‡lf†pe‡qf‡qf‡rg…pe‡qf†oh†pgˆqg…pe†pg…nf†og‡ph„me‡phƒoembƒqcƒoc…oc†mb†nc†mc†pd†pf†og…nf„pd‚obƒma„nb…od…od‚l`ƒlc€lalamblanf€le€lb€kc€lak`l_naƒodk`mbmbmb|j_ob€lajbkbk`€nb€jbma~lamb~l_}j]}ka~m_~m_€na~m_~la}k`ma€md}jb}jblc€obma~m`€nc~la~ma~jc}jbld}jb}jb}jb}jb{h`}ja~lc}kc{jazi`~jb}h`kbmb|l`~lala~lak`~la|j_€ncmb~lamb~la|j_|ma|ma{k^~ldkc~ld~of|na|oa~n_€rara€of€oe€pdqererdqb€qd‚qh‚qhqg€pd€sf„tgreqdna~m`IG>KK>NKBPHHRNJUPN[UU_ZZgb`je`oiepjfokfokfmfai`\d]X_YRa\ShbXqg_vjewkeyphojckf^hdYjfYsiaxmd|nc~nbnc€oenf‚og„rj„qi„rj…sj…th†sj‰voˆvoŠxpˆxnˆsm‡rk…ph†ohˆri…nc„hb€e_€f]„ncƒmc„nc‚ob…od†ndƒka„jd†kd…hbƒh_‚h^f]g^f_g`ha€f`…h`†jb„i`hc…jd…gc…ic†kc„nb‰oa‡mb‰meˆng‰pf‡nd‹oe‹pf‹pf‹pfŠnhŒpipiŒpiŒoh‰ohˆphˆqi‹pe‰ndŠodˆnb†laˆob‰md‰od†ka‡lb‡lb„h_„g^ƒf^…hbˆldŠmdŠncŠoe‹qfŽrgŽrgŽqgrisgshpgpgŒqgŒqhŒofŒpgrhŒqgog’qhri‘qiqhrisjpgrisj‘tk‘tkriqg’rkrh‘riqh‘thqe”pkqjqkrlpiqjoiojqjqkŽqjŽrl’ri”tk’rj“tk’tkri’rl“sm’rl‘qk‘qk’rmtjsjsjrirjsl‘riqhpgŽofpgpgohpinioiniŽoi’oh’riŒofpgriŽofmgpjŽqkŠmeneofrfqfqfrgrg‘shsjskrjskrlojŽphpg’sjpg‘ri’qiqfqfpgqhŽogŽngoiŽofneŽofodŒncqfŒpeŠodŒoe‹neŒofŒoe‹ngpiŽqjŒogŒoe‹of‹ogŠlf‹nh‹me‹mdŽnhŽnhoiqipgqhofofŽpgŽogofŽpg‰ndŠne‹mdofofof‘pg‘pjŽpi‹ngnhŽoi“oloioiŽqjoineŒpgŽpgŽngŽnh‹mg‹phohpgŽpepeneŽnfŽngohŽoiŒoh‹ohpipgpgqhŽnhoioini’qkqhriphrhŽqkŒohpipipiŒpingŒngŽpiŽphriŽpgŽngpjokŽomojojŽoiqjŽrkrlrlpjrm‘rm‘rj“rk‘rmqlroŒpkqlrlskqgŽqjrkslrksmslsnrmpi‹ohŒqiŒqhŽrkŒpiŽrkqjŒoiŒpiqkŒoiŒpi‹og‹niqkŽrkqjŒpiˆngŠohˆng‹ogŠnfŒoi‹peŠoeŠod‹oh‹oh‹ohŒpiŽrkŒpiqj‹ohqjŒpiqjŽrlŽrkrkŽqjŽqjqj‹ngŒpiŒph‹ngŠmf‹ng‹oh‹ohŒohŽoi‹og‹ohŒqjŽpiŒoh‹oiŠoeˆpfˆoe‰oiŠpiˆngˆoe‡nd‰ofˆnd‡lfˆlgŠoiŒqjŠpf‹qk‰ohˆoh‡qi…nf…nf‰oiŒqhŒofŒqf‰ndŠqg‰ogˆnf‡nf‰og‡ne‡ne…le…kd†mf†mc‡nd‡ndˆoe‡mcŠoeŠoe‡pe‡rfˆne‡nfˆng†lfŠnfŠoe†ncˆngˆmg‰oi…ld‡nc†mc†mc‡nd…lb†mc†mb†le‡mfˆng‡og…ng†og†me…ne†oc†oc‡of‡ogŠti‰shˆrg†od…od‡pf„oi‡rj†sh„pe„pe‚me‡ph‡ph…nf‡qgƒpe„od…qh†qe‡nd‡oc†oc‡qd‡qg‡qf†og„ndƒpd…rc„nb…pc…od‚lbi^ƒld‚ncƒod€lamcƒngƒnf~l_m`lb|i^|j^na€lalb~la€nc}maoc€ob€nb€kb~i`‚ocqc†mf„odk`}k`€nal_mbnan_n_l`mb€nc~lambodpcma€oamana€nc}k`}k`~kc}jb}jb}jbld~jc}mc|kb~jb‚meme|jb|j_}jajb}i`}l_{m^|mambk`mb}j_|j_nd}l`|j_}k`|k_}k`nb}k`|l`~md{ka}mdnf€mdnb€pcqere‚rhog~oe€rf‚thrftere~qgtj~qh€th}re}sg~rf€qe€pdpdBC8HH;JH?LGCQMHVQOZUV`[\`^^`^]d]\f_]hc`lhcjfaic^c_Zb`Va_Td`Ume\qf^shaof_fc[b`X`aVbbVmg`ulb}qfqe}oc€pgƒqi…rjƒoh…rj…rj†tk‰vk‡uk‰vo…sm†ul‡wmƒpi€mfkch`}f\€g]…hb‡le†nc‚la…od„qdƒpc„pd‡qf…od‚kc€ha…hbƒe^eZeZ€d\~d^ƒfa…hd…ibƒj`†ma‚j^„lf…ie…hd„gb†lc„maˆm`‡ma‡lb†me‰pe‰pfŒqg‹pf‹ofŒpg‹nhŒpioh‹ohŠngˆngˆqiˆqi‹qg‰nd‡ma‡ma‡m`‡n`‰lc‹ne‰mc‡mcˆmcƒi_†i`ˆkb‡jbˆkb‹oeqdŒqiŒrgŽsfŽrfpf‰meqfrgŠncŒpgŒqg‹pfŽqhŒpgrhŽshqhpfpgqg‘rhriogqi‘sjrh‘riqh‘sj‘sj‘ri‘riqh‘sh‘shrg‘pj‘pjŽqjŒpirkpiŽqhsjpgritjŽri’ri“rirh“sj’tksi‘pk’rl’qlpj’rl’rl‘si‘shqh’sj‘rj‘qlpgŽofneŽofŒmdnenepfnemgŽnh‹lf‘meŽnepgqhŒoenemhŽqjŒpi‰mcŠldneqfŽpe‘sg‘shqf‘sh‘tmŽrjŽqiojpjqlŽqhpgŽpgpgqh‘pgqfqfpgnemfmgoiŽofneoeŽpdŽpeqdŒpeŠodqf‹neŠne‹oeŒog‹oh‹ohŒogŒpdŒpf‹nf‹mhŠlgŠof‰nemgŒlflfofofofpgŒofpgogpfŒpeŠndŠpf‰mdŒof‹ne‹ne“pgofoiŒnh‹nhŽni‘ojmgŒohŒohoepgqhŽpgnd‹kengŒojojŽogqfŽoerhoe‹mhpirlqjŒpiˆngneŽofŽpfoiŽnhmgoioi‹neŒpgŒpe‹pe‹ng‹ngpi‹ngŒoh‹ngŒlgŽmgnh‘pgpgŽofŽpeŽngpkŽokŽpkslpjpiqjslŽqjŽpjok’sm’ri“ri’rmokŽqmrmŽqlslqhpgŽqjŽqjŽqkŽqjqjŽrkŒojpk‹ohŒpiŒpiŠngŒpiŽrkslŒpiŽrkŽrjŠmiŒoiŒoiŒpiŠnftjŽrk‹ohŠng‰ngˆohˆoh‹ohŒoi‹nf‹ne‹neŽqgŒpi‹phŒoh‹ohŒpiŒpiŒpiŽrkŒpirjŽrkŒoislslŽqjŽqjŒoh‰mf‹ohpjŠmfŠleŠmfŠng‹ngohmg‹lfŠngŒqjŒnhŠng‹of‹pfŠpfˆoeŠpjˆng‰oh‹rhˆoeˆoe‡peˆngˆnhŠpjŠpi‹rhŠpj†lf‡og‡ph†ph„phŒpjŠofŠmdŒqfŒqh‰pg‰pe‡pd†nbˆpd…ma†mb‡kd‰nf‰mf‰od‡mbŠodˆngˆme‡kd‰mf‡og„neˆne…ke…ke‡mgŠmgˆlc…naˆod‡mfˆng‡nd…ma†lcŠqgŠqg‡ndˆoe…lb†jd‡mg‰oh‰pi†og†og‡ph†of…oc…oc„mdˆpi†pd‡qf…od‡qf„nc„nc‡ok†pj‡sh…qfƒodƒofˆpi†of„me‡qf„pe…qf‚oh‡qh‡ndˆpd‰sc‡qb„nc…pd„me„oc„qe‚pa†oc†pdƒmaƒla„nc„md„od‚la€j_‚lbƒld€ia}m^€ob~m_}k`mcmdƒmc€lamb~la|m`|maqd~ma}i^mbpdqd‡ne‚mb~j_mb€nanala€m_‚n^‚o_n_€la}l_~m`pcpcnana~m`}l_~m`odmb}k`}jb~kc}jb}jbmd~kc~pf~me€ld„nfƒnfianb~mamb~ma~ob~p`~ocpdk`‚malambnc€nc{i^mb}j`~lanc€mb~l`{kbylb|pf„nfƒmfne€oe€qg~pg‚qhof~ofqe~rf~rfuf~sg€tj}ph}rh~sf{shwncxnc{pe}pf‚si?GHG=NH?OKGXSQ\WWb[\d`]a[X^\U_]Wa^Yda_db^da^d_[da[fd\fd[me`qfbpe`og_gcXccWbbWccZkiatofzph~qhph„sjpgƒqhƒpi„qj…qkˆrmƒum‚tl„tm„rk‚oh‚oh€jb€jc€ka}i^~k_‚nb‡rk‰skˆsk†og†ng…ne…le‡le†leˆmg…kd„ic„h^‚g]‚g]ƒh^ƒh^„i^„ibˆleƒib…kdƒjb„ld…ib†jc‡jd†jc†ic†jb…ja‡jcˆmc‹peŒqf‹reŠoeŠqg‰pfŠqgˆqfˆpf‹ng‹ohŠngˆng…og…phˆqe‡od‡ndˆmc‡kc‰ldˆmh‹okŠni‹niŠneˆla‹n`ocodŽpeneŽogpgqh‹qfŒqgŒqgqg’pg‘qhofŒofqhrhŽqkŽqjŽqjŽqj‹oipipkoirlpgpgŽsiŒrkŒpjojoj‘si”ti’rkpj‘qkskrkŽqjŒohrkslŽqjŽqjph‘sf‘rh‘qkrmqlrk’rlslslslsk’qlrgriqh‘riririqhŽqhŽri‘riqhpfŽmhmhŒlfŒlgŒlg‹kfŒkf‰kd‹ni‹oeofnfŒlgŒlgŽofmelgmgphŽofnemeŒmdnepe’th‘riqhpg‘qj“qmql‹niŒniŽpjnjoiŽngofŽofŽsgsgŽqh‹ofoemgŒkflhŽnhŒlfmgŒlfŒmfŽngqfŽoeŒofŒofpi‹ohmhmgnhpfmdofŒoh‹ngŒohŽneofŽne‹odogojŒoiŠngŒqgof‹pfŒqgŒrhŒpgŽofŽogŒnfŽofnfphpgŽpioilfmcŽneŠneŒogogŽoflglgmhqh‹og‹nhŽnhŽmhlhpipjpjpjoiŽnhofŽnfniojŒnjŒpiŽoioiŽmhŒlfŽnhŽoiŒpfŒpgoemhqiqisgŽpfpgofŽph‹oh‡lfŒoi‹pfofofnfŒnfŽrhrjqjrnŒplŒokŽrlrhtjriqj‘tksj‘tmŽqkŽqjsltlrhsi’sj‘qhofŽqkri‘ripf‘tishŒqgqhpg‹oh‰phˆohŠpi‹qjŽqjoiŒrj‹qjqh‹pgŒph‹ohŒpiŒpjŽrjŒqgŒnf‹lfŒojpjrirgŠoesiŠqh‰qf‰pj‰pj‰ohŠpi‹rgrh‹rhŽrhŽoiŽoiŒoh‹qjpiŒqjˆohˆph‰oh‹piŽpf‹ofŠod‡ndŠnd‹pfˆngˆmfŠngŠngŒpiŽqjŠngqj‹oh‹rksl‰oh‹qj‰ohˆng‰oh‹piŠng‹ng‹ohpiŒpiŒpiŠngŠodŠnd‰oe†le†nf†og‰oi‹nh‹nfŠmd‰lf‰mi‡qgˆndˆlbŠmd†ma„nc‡mg‡le‰nd‰nd‰nfˆof‹rgˆoe‡odˆoeˆngˆmf…lb‡nd†mb‡mf„jc†le†mc…ofƒmgmf„nf„od†pd‡qe‰sh…pe†pd…me‰oe‰oe†pe†pe…qe„oh†pd…pe„nc…od„pe„pdŠoi‰ng‹oiˆoe‡oe…qfƒrepd…ph…me‡pe‰pe‹qk„ofƒnf…qi„ogƒnf…ld†ne…oc…ocˆrg…re‚pcocpd~ocnd„md‚mb‚md€kc€kc€lb‚nc„mak_‚k`€lajb~jal^…pc„nckckdƒlgƒmfld€me|ib}ib€kcnbl`€k`‚leƒnh€mfƒnbƒnbƒma„nb„nbƒna„ha€l_€pc~ob‚nb€ka}m`}m`~nb€pd€od~ldk\k`}k`ne~mb|k^ldƒpf€k`…pd‚pc‚re€pbnd„sj‚oh~lbocƒodla€la‚mfƒof„pg‡pdƒod~kc}lc~nbob‚pc€pbod~oc~nbzkb~ma|kb{ia{kbvjawnezmcrk`pk`mk_pk`ypf}ob~odƒvl‚wmulviyqgzqhyoeypftkaqh_lf_mf_kd[nd[ri]pfZ:B8>B:ECMJFVQNXRQ^VVd[XbZU`]U_[U[WSVRN[WR[VP[VS_[Ufd\ig_kf`kc`mc^og_mh^kg]ecXdaXmj_tmczog|mfyjb|ld}mdofohƒpi‚piƒqkofnfng€nf€le~jb€ld‚nfƒogmeƒof…riŠumŠumˆsk‰rj‡ph„me†lc„kb‚ha‚ha…ke…le„j`„j`…ka†lb†kb†lb†kdˆle†kd„jc…ib…jc…jc†kd‡kd‡le‡le…jd†k`†la…k`‰ndŠoeŠodŒpgŠoe‡nd‰pfˆpf‰qfŒqjˆmf†kdˆng…le†me‰oe‰oe‰nd‰ne†ke‰mfˆngŒoipk‹nh‹nfŒoe‹pcŠod‰oc‹pfŒpf‹pfŽofrhrhŒqgŒpgpgpgqgofpgrhrhphrjŽqiŽqiŽqiph‘pjpjŽpiqiŽqhŽsiqgpiŽqkpiqjrh’rlpj‘qkŽqjrjpiŽqjŽqjrkslrkŽqjrfpfoirl‘smtm”tmslqjŽrkrk’rlsjŽpgqh’sjofŒof‹nfŒog‹nfohngŒmeŒlf‹keŒleŠjdŽnh‰ic‹keŠle‹oiŠne‹mdndŽnhŽngneŽofŽohŽnioiniŽnioiŒlgmfqf‘shqhneqgpj’pkniojŒoiŒnhŽlhŽpiŽngŽofnfŽqhŒrfŒofŒoeneŒncndogŽofŒmdneŒmdŒmdndŽohmf‹neŒofŒnf‹phŽnhmgŽnhŒmeŒndŽofŒngŒngnhŽphofŒne‹odŒngohoiŒpi‹phŽofŒpgŒqg‹pfŒpgŽpfŽnhŽnhoioimhlg‹ngmgnhlcne‹neŒpg‹oe‹nf‹lfŠlepiŒneŒmfqjŒnhŽoiŒmhqirkqjŒpiŠnfŒohpgngŽniŒni‹niŠohnhŽnhpjmgŽnhpkqg‹ofŽpfoiqj‹ohŽriŽqiogoiŒoiŒpiŠmhŠnhpgpgŽpfŽnhŒogpgpgnfninj‹njrmsjtjŽriŽqkrh‘tl’umrk‘smŽqksi‘tk‘tkqgŽqgqgqjslpgŒnfqgrg‹qgŒrhŒpfŒoh‹oh‰ph‰oh‰ngpipiŠohŠpi‹pfŒqg‹pgŒpiŠngqjŽskŒohŽoipjŒohqjŒrg‹qgŽsirhqgŒpfŠqi‹qjŠpiŠpiŒqiŒpi‹qhpjŒohrkrlŒriŽqj‹piŠpiˆohŠpi‹ohoe‹pf‹pf‰pf‹pe‹peŠohŠng‹oh‹ngŒohŒoh‹oh‹ohpj‹qjŠpiŠoiŒoh‹ohŒoh‹oh‹ohˆngŽrk‹ohŒpiŒpi‹ohˆle‰nd‰mc†mb‡lf‡mfˆohˆohˆnfŒpgŠof‰ohˆoh‡peˆndˆmcŠoeˆnd‡pd‡ng‰ne‰nd‹qeŠpfˆqf‰peˆoe‡ndˆoeˆnh‰oi‰pfˆoeˆodŠpi…kd†le‡mc†mf†oi…nh„nf†nd‡qe‡qeˆrg†oe†qe†og…nb‡oeƒmb‡qf‡rg†qe†pe†pe„nc…peƒod…qfˆoh‰ohŒqi‰pf‡pe„pe‚reƒpeƒneƒlc†pe‰re†le†ph„ogƒph„ogƒnf…nd†od…od„mbƒobƒpc‚ma€nb€pdƒqfƒnf‚jcƒod‚le~hb€ic~iaka‚kaka‚k`€lble‚mf„nb…od†od‚oc‚md€ka€lclbkb}i`ja€lc~n`}k^j_‚lc‚nf}jbnb~na~ma‚qdpdmah`|i]|l`yk_|ma}ja}m`}la|k`pdne}kb~ka{k`{kb|oe|oa}n_‚ohnfme‚oepf€pf„rf„qgƒoh„ph‚pf„pf}nb~mb~lb‚qhƒqi„pi„qe‚pf€rh~rh€th}qb€sh~qg}qe|ne|ogqh€skwiaqf\mc[gaXfcZgbYb_V``VcdYgdZkf\haXe^Uke[icYjeYmh]jaXi`Wf^UbZQ`ZQ^XOYTL[VNZSJZSJ[RIYPF8@6;?7??9IE@LJCSOJXQN\SP^SN_SN\VM]UMaXT]SO[SLXRJWPLVQL]YRa^Wd`[e`\g`[le^of_qj`le]jc[keZoe[pd[td]ud^wgaxh`yjc{jc{kc}kd}kd~kbld~kc€kcldjbnf‚pg…sk„rj†rl…rm‰sl‰tl†qiŠrj‡phƒld†mbi^‚ha„jc‡mgˆng…nd„nc„nc…od…oc„ncƒld…le…kd…kd…ib†jcƒld„me…nf†og†ogƒlc…k`‡ma…j_ˆmc‰mfˆle‰nd‡lbˆmc†mcˆoeˆoe†og…le†le‡mf‡kd†kdŒofŠneŠoeˆoe‰pf‡oeŒqfpipiojŽqjphŒqgŠoe‹peŒqgqg‹qgqhrhŒqgrhsinepgŽpgpgŽqhrhŒqgpgqhŽqhŽqhpgsj’qloipislskŽsitiriŽqjpisksm’rlpj‘qkrkrlŽqjrkŽqjsl‘tmrkpirfrhofŽqk‘tmsl‘qkslslŽrkqjoiriofnepgŽpgŒof‹ngŠmfŠmfŒkeŒkfŒlf‹ke‰ic‹kemgŒlf‹ke‹keŒle‹keŒmdŒmdŠlbŽniŽngpgqhpiŽnhŽnhŽnhoioimgmfoepe‹lcŽofŒneŒohpg‹nfŒofŽqhŽphŒofpi‰kdŒkepg‹md‰mcneŽofodŒncŒoaŒoaŽpfŽpeododŽpeŽoemgoiŠne‹ne‰mc‹qemhoimgŽnhŽnfnemgmgoi‹ohŒogŒqfpgpfŽnhŽohpi‹ohpg‹pf‹pf‹pfqgŒndŒlgnhmhŽniŒlgmhŠngŒlfŒlfŒmdneŠmdŠpe‹oeŠngŠngŒohŒnhpfohŽnhŠmfŠmgŠlh‹ohŒpiŒpi‹ohŒpiŒpipgnfmhojŽplpipjoipjoimgnhŒpfŠneŽofojqjqjŠpjŒojojŒni‹niŠpj‹niŒphŽqhriohmgŽqjŽqiofpglgmknkpjsjriŽqiŽqjrk‘tmrk‘tm‘snqlrk‘tl‘tm‘tmslŽrkrkqjpi‹ne‹pf‹qgˆrgŒrhŒofpipiŒpi‰oh‰leŽqjŽqjpi‰ohŒqgri‹ohŒpiqjŽrkŽqlpkŽqk‹ohrhŒqgŠrh‹rhrhŽqhŽpgofŠqe‹rislŒqjŒojpkŒoiŒpipiqiŽsiŒqgŽpjqjŠoh‰ohŠpi‰ngŽoi‹oh‹ogŠpi‹ogŒpiŒoh‹ng‹ngŒohpi‹ngŠoe‹pgŒqgŒsi‹rhŠqgojŽnhŒoh‰mfŠoh‡ngpi‰mfŠngŒpiŒpi‰mf†mb‡nc‡ndˆng‰oh‡kfƒncˆofŠpg‰oe‰qg…qf‡ndˆoe‰oeŠqgˆof‡mfˆqi‹qhŠqe‹qe‰qe‡qfŠpg‰pf‰pf‰pf‰pfŠqg‰pf‰of‹qgŠoi‡le†lf‰mfˆmfˆqi†ng†ng†ld‡re‡qe‡qf…od‡qf†og‡pg†og…od‡qf‡qfˆoe†pe†pe†pe†pe…qf…qf‡ph†ne†mc‡nd†qe„qd„qd…qeƒne†og„nc‡qe†md„pe„pfpeƒnfld†pe…od…ne„of‚ncobƒlaƒmb…qf„pe…nd‚j_€kd‚me€jdkejb~ib€mak`laƒod‚nc‚nc…nf†oeƒod„pe„odlanana€m`‚ob€nanana~l_l_k`k`~jc€ocnbmb€od€nc~mbia{h^zk^ymazlaxi`|na~nbmaldmf}jb~kd~mf~ngpg}nb|m]og€ng€ngng}ofyld}ocqhphƒpi‚tj„yl„yo…zpˆ|r†uo†umˆunƒwjwk{qgumcul`ul_ni_oh^nf]qh_oe]l`Zf\Sd[R\WNZXPYYPSWNWWPVYSTYRZ[UZZTXTOTQLURLURJQNDQLCUOFVLCTJARKBOJANI@QJAMF=MF=NG>LE?8HE@QLCYSMYQL[PL]PK[NG]RIaUNg\Uj^WfZRcXNdXUcYS`WP^WP\XQ[XS^YQ_YRd^Wh`Ykd\mf]keZjbWj^Vm]Vk\Vk^Wsc\rb[xhazibyg`xg`xe^}iakc‚meƒnf„ng„rj†sk†sl…rk„qjƒpj†pi‡rj„og‡ph†og…nfˆoe†mc‡nf‡mgˆnh‡mg…od…nd…nc…od…nd„nb†og„ld†le†le‡kd‡kd…meƒld…me…nf†og†ofŠncˆnb‡lbˆmcˆle†jc…j`†ja†ka‡lb‡nd‡nd…nf„meˆng‰mfŠogŠnfŒogqhŒqg‹rhŠqg‰qgrfŽqipipiŒphpgŒrhŠoe‰ndŠoerhŒqgpgrhrhrhŽrhŽog‹oeŽripgŽqhŒqgrhpgqhŽqhri‘ulŽtj’sj’rkŽpjpirktlsjsj‘tjŽqjrlok“rl’rlpjrkrkslrkŽqj‘tm‘tm‘tmsl‘ri‘ripgrirj‘smsl‘qk’rl‘pjnhpiŽqhŽpgneneŽpgŒpfŒlfŒlfŒlf‹ogŒoh‰nfŒlfmgŠkeŒlfmg‰icmg‹keŒlfŽofŽnfneŽnhnepfrgŽofŽnhmgŽnhŒlfmgpjŽogpe‘rfŒmdŒmd‹ne‹ngpg‹ne‹ne‹nepg‹neŠng‹lemgmgŒmgŠmfneŽofŽpeqeŒpbpbŒncŽpfododŽoeodmgoiŒof‹neŒoe‹qe‹ne‹ofŒohŒohŒoh‹nhoeŽog‘qkŽqjŽqjqjogneofŽnhŽoiŠnhnfqgŒqgŒqgqhoe‹kemhmhŽniŽnimhmg‰mf‹ng‰mdŠne‹md‰mg‰mfŠmfŠngŠme‹mdmeoglf‹ng‰lf‰ni‰ohˆng‰oh‰ohŠpiŒqjqhohmhŽplŒniŽqj‘qkŽohŽnhŽnhŽnhŽoj‹pe‹ofpgoiŒpiŒpiokŠlgŽpkŒniojpkŒohogpgriqjojŽqjphqhph’okojnkŽql‘tkpgphŽqjŽqjrksl‘snŽpkrm‘tm‘tmsltmslqjslŽqjŽqjŒohqjŒqk‹rh‹qgpgoiŽqj‹ng‹ohŒpipiŽqjpiŒpiqkŽrkqjŒpirirhpjŒoj‹piŒpi‹pfrh‹rh‹rhrhpg‘ririŽsftiŽrkŽrkrmpmŽqkŽqjŽrkŽsirhpgpipiŠmfqj‹piŠohŽoiŒpiŒpiŠpiŒph‹ohpiŒoh‹ng‹ngŒpiŒoiŒrgrhrh‹rh‹si‹qgnhmgŠmf‰mfˆmf‰pi‹og‰nfŠngŒpiŠng‰mf‹qg‹qg‰pf‰oh‰ohˆmfˆod†od‡qg…odˆpf‰oe‰pfˆoeŠqgŠpjŠpiˆngŠtlŠqiŒrf‰pdˆqf‰shvlŽuk‹rh‹rh‰qgŒsi‡rg‰shŠti‡ph…of‰rjŒpiŠoh‡oh‡ph‡oh‰nh‡qe‡qe‡qf„nb…od‡pgˆqi‡pi‡qf‡qf…od‡oc†pe‡qf†pe‡qf‡sh…qf†pe‡peˆoeˆoe„pcƒre…re„peƒnf‚me…od‡qeˆpd†qe„oeoe„ngld…oc„neƒnfƒnflc€na…lc„lbˆrg‡qf…od„lc‚odle€jd‚lf‚le‚nc€lb€lb‚ncƒod€la„qf‡ogƒof„pe‡sh‚pembqd‚pc†pd…oc‚pcna~m`€lb‚nd€la‚oe~male„ogƒnf‚me‚me€kch`{e^zh`wg_xiaxj`vlbzmd~of€of~of~pf}ld~lf}mf|menc€ob~ng|og|ph|sjvneukdvoc}tj€sj~rjyoexrexpf{riwmeyldtf_ue_lfYd]R_ZQhcYlg[f_R^ZP\WNUPGVOGSJDUKDRLCOI@JH>LLDNPGLPFNRMPSMQRLUUOUSMRNHOIFNIBLG>KC:OD=MA;OB:OEC7GH@TKCWOFXMG[OI_RJ^QH`QHfWNl[Um]Tm_TobUrc]tf_uiakdY_[QSRIPMERNJXSO\XRc_Vkh_kh]gbXf]Ti]Ui]Si\Tl[Uk[SsaZtaZr`WsaYwe[|i_„pg†ri†ri†rh…pi„phƒngƒnfmdne…ph…ph„og‡ph‡ph‡ph‰oiŠpjŠpj‰oh‰ofˆof‰ndŠoeŠpfŠoe‰neˆmcˆmf‡le†le†leˆmfˆmf‰mf‡le…ibˆmf†kd‡leŠpeŠpe‡lb‰nd‰ncˆmbˆjd‡jd‰mf‰mf‰mf‡lf†nc†nc‰pfŠqgŒqg‹qf‹pj‹pjŒpgŒqgŠpgŠqfŒofŒqi‹piŠoh‹rfŠsgŠmf‹oi‹og‰nd‹pfŒqgŽofqhrhrh‹oepgrhrhrhŒqgŽsirh‘pi‘qj‘tlrkŽrjrj‘ri“tjskpiŽqjslrlŽrirjriqjql‘qkoioiŽqjrkŽqjrkrlrkŽqjsl‘tmpjphqgqgphslqj‘qk‘pinhŽnhpiŒofŽpgŽofmdof‹ne‹kdngŒme‹ngŠme‹ofŽnhŽnhŒlfŒlfoimg‹lfŒkekeŽmcmd‹mdŒlenepfŽpeoemfndndŒmcŠlandoeododndneŒof‹ng‰od‹oeŒne‹md‹oe‹pfŠoe‹ngŽnhmg‹kfŒmhohqhmeŽpeŠmc‹ogŽnfŽofneŒmdneŒmdŽngpiŒofŒofŒogŠofŒofofogŽqjŒohpiŽpgŽpgphohŽpiohŽnhpfnf‘pgniŠmgŽogŒpf‹pf‹pf‹pfŒndŒlfmgmgoiŒlflgŒmfŠmfŠmgˆmc‹ne‹mdŠmf‡kcˆle‹ldŠlc‹mdofŽogŒkf‰me‰keŠlhŒpiŒpiŠng‹ohŒpiŽrkqhŽphŽojnipk’smŽnh‘qkoiŽnhnhqkqf‹of‘sjpjŽrkqjokŽnjojojŽni‹nhŽqjŽqgŽqhriŽqkŽpkpjqjŽqhrirkpk‹njŽqkŽriqhrjsl‘tm‘tmrmrm‘snqlsmŽtlrjslpiŒohqgqjŽpiŽpiŽpkŽqlriŽqhŽoepjŽrk‹pi‹ohŒpioioiqjqjŽrkŽrlŒpirirhrgŒpiŠohˆoh‡ogŠohqksisirirjŽqh‘rjripgrjŽrkqmŒqlŽokpjrkrhŽrhŽqfŒpjŒohpjŽrjŠng‹piŒng‹ng‰mf‹qjqj‹ohŠmfŠngˆmfŠpiŠpiŠqjrhŒqgrhŒsi‹qhŠqgpiŒph‰mfŒohˆmfˆngˆpe‰pf‰qfˆoeˆoe‰pf‰qg‰pfˆoe‰oh‹ngŠngŒpfŒqi‹rlˆpj‰og‹ofŠrfŠrh‰tjŠtlŠqk‹qkŠsn‹rl‹qjŠqiˆof‰slŽtmŒrl‹rhŠqg‰pf‹rg‡qf‰shˆrf…nf…nf‡phŠoi‰oh†pe‡rg‡phˆoh‡pe‡qe†pe‡qg†pd‡phˆoiˆph‡oh†pe…qd†qe†pe†pe†pe†pe„qf…qf†pf†pe‡pe†qe„pcƒre…qeƒodƒnf„ogƒod†rfŠre…qd†rflb„ng‚nem`‚mckeke|ia€nc†mf†nf‡qgˆrg„od…pd…rf†rgƒne„ofƒod„pe‚oh€mepf…qf‚nc…qe†rf‡sgˆti…ti…ri†si‡vl†riˆrh†pg‚of}la}mdmf€mf~kd€of}md}ld|kc|kdzja{kc{jbxg[ub[qbZobZkbYkeXlh_rkaxmcxlcxndtn`rg_qg`qhariarf]uh]ujarjajf\he[b`Wa]U_]R`ZOeYReYQaUL\TJ]TKXOFYOGZNHWKETHCRNAQOEPOEZYOWUKIE7OI?TMCTLCLDJJ?KJ@LKAJFMG>OF>NDNH?RIOK@OLANF1G>3G<7H=:J?3C:-D=/ND8XHUK3=B9BD9MMCRM@VLA[ME]KEbMEeSKj[PpbVzi^…oc‚rh„sg‡tj‚sgwmegcYSTJMMCKMFOUKR\RS`SP`RP]PU_PabThbTm`Tp_WucZ}kayg\raSuaTzi\pdƒpdƒng‚ke€jdƒjd‚iaƒk`„l`‡ndŠpg‰qf‰pfŠqgŠqgŒsi‹rhŠpi‹qj‰qhŽrhŒpgqgŽqlŽrkŒpiŒpjŽrjŒqgŠqg‰rg‡qf‡phˆng‰mf…la‡lc‰mf‰ld‰lbŠncŠmc‰lcŠmd‹pf‹peŒsfpgŒogŽqjŽqjŽpjŒojŠqgŒpfŽpinhpk‹ojŠpdŠodŒoh‹ndofpcŽqjŒohŽqjri‹rgŒrhŒpiŠngofpgŒpgqiŒojojŠmfpgqercŽrhqiqhsjŒqgrhrhririsj‘smrj’si’sj”tn“sm“rn‘rntmslrlrk“rm’rlpj‘qk‘qk‘qk‘qk‘qkrkpiŽqjojŽnhoiŒpgpgŒof‹of‹ofŒof‹nd‹nepgofŽqhpgŽofŽofŽof‘pgneŽmdŽmd‹lcŽofmgŠmgŒohŠmeŒofŠmdŠmfˆle‰le‰nc‡j`‰kb‰kbŠje‹kendme‹kbŒmeŒkfŠmfŒkeŒleŒlfŒlfmg‹lfŠlc‹lbŠla‰mb‹nfŠmhŽldne‹lanh‰le‹nh‹ng‹ngŒohŒohŒohŒoh‘pg‘pgnepfninhŽpimhmd‘nepfŒodŽodŒlenipkoipiŽmgŽnhŽpj‹ngoiŽmgŒneŒofŠneneoeŒld‹mgŒohŒpiohŒpg‹qgŽnhŽpjpkŒpiqgŠmb‰ndŠneŠmf‰ke‹ke‹keŒlfŒlfŠkeŠkeŒlgŒmgŠmh‹nf‹oeŠocŽng‹lhŠmg‡kfŒniŠmhŽojojŒoh‹ng‹ngrkpipiŽqhŽpkŒmjnkpjŽqiplpkŒpkŠohŽrkoiŽqhŽqiŽqjpiŽphŽqhqmpkqlŽpjrkrkŒqjqjqjslrkŽqjqjŽrkslŽqkslslŽqhŽpj’sm‘qlqlŒqlrnsmriŽqhskrl‘rlrktmtmrkpjŽrkpirkslpiŽqipkŒni‹niqlqlŒniŒpiqkqjŒpiŒpiŒqi‹ocŒpdŽrgŽrgqipgŠng‹ohŒohŒpiŒpiŽrkŒpiqkoioiŽmhpiŒqgŒqgrhŒqgrgriŽqmŒojŒpirhŽthrfŽof‘riŽqiqjŽrl‰pinkŒpkŠqkˆrjŠpeŒpfŒse‹shŠpiŠoi‡pgˆrgŠpjˆogˆpeŒpfŽshŒsgŒoiŽqjŒqj‹qj‹qjˆohŠmh‹ogŠpd‹peˆogŒqk‰qlˆpjˆpjˆpj‹sm‰pkŠqgˆsh‡ti‡qi‹piŠng†mi‰pj‹pislŒukŠti‰rj‰qk‡qj†oh‡oh‹oi‰qfˆpg‡qi…qf„qd‡reŠoe‰oeŒqg†pe‡qf…rfˆocŠrfŠqe‰od†ld†lgˆrf‰si‡pi‰qkˆqhˆsg‹rh‹rhŠti‰sh‰si†qf†rg†rgˆti‡sh‡qf†peˆoi†pfˆrg‡sh‰ui‰wiŠsj†qg†rf…qe‡pgˆmg†qi„pf‚me…ph…ph„ogƒpe‚ne€nfne†og†ng‡oj‡pj‡rj†rh…qfƒre†wj…vi„tg†uhƒuhvh„wh…wh…th…uj…sk…unˆxmˆxm‰xoˆwn‹ysŠyr†yoƒtpsm€siwj`se_le]eaW]^S^`TfaZf^Xb\Ta]T[ZP\ZR[VOVOHZSLUPISQIRQIVUKYWMXUNVSJWVJYUKXSJXQJPNDNKAPHCRGCQE>SG?LJ@LJ@LKALJAKH?MF=SC:O?7PB8N@7M>8K=9M=5G@6F@7H?6J>7H?6H@2G?1JB6G@5OG=KE:K97P<;NA;JC9NE7OD7QE8L=4J;3SDMFIF=LI@NKBOHAMEBJG7K@8MA7D?6EB8EB7GC9JB9NC;O@7M>5J;2J;2I;5J<6K:1I=4F<2O>7P@8K=4M=3M>3N?6M>5J=2OC8QGWLAWOAZMB]ND\MBfWLo_UqcXb\NXWJmj`‡‚x‹ˆz†‡x}ykrm_ieV][MaaSdgX^gWaiX]bSSVHUXHPSDONDNNCMOANRCNSEMSE3@05A17@45?39>3:A3;B3?D5CE7JI>QKB_SKjYQt^Wyf^zi`|ka|j_zf[ucXp`Xl^W\VLPNDHMCMWKL[LK\KMXKOXKYZLfcUodWzk^|ha}jbƒph…qema€la|k`{i^~j_jbƒjc†le‡mf‰pfˆoe‰pe‡ndˆpfpg‹pfŒqg‹rhŠrh‡shŒuh‹sgsg‘vkritjŽrkslsmrhrhrh‹qjŠqkˆrgˆqgˆob‹qbrhqhŽrkqjŒqfqfŒpe‹neŒohŒpi‹pfsgpgŒofŒofŽqk‹ngŒohŒqgŽsipgŽqhŽqi‹ohŒofŽqiŽqjpiqgsh‘qirhqfŽqfŽrfreqjŽqkphqhŒpgŒqgtjŽqhŽqhri‘qhqisiŽqhpgŽqhŒpgqitiqfqfŽqhriri’sj’sj“tk‘qk‘qk‘qktkrjririŽqhpgoiŽnhŽnhŽnhoiniŒohŒoh‰meŠjdmgŽnhŽofneneŒmdŽof‹lc‹lcŽofŽofqhqhne‹neŒneneŽofŒlc‹jamdŒmeŒlf‹le‹ngŠmfŒnd‹mcŽmdŽmdŒkd‹idjd‹jd‹kb‡kbˆlbˆnbŒmd‹lc‹lc‰lf‡jc‰le‹ke‹keŒlfŒlfŒlfŠkeodŒnc‹laŠmdŠme‰lfŽmcŠkdŒlfmg‰mf‹ngŠmf‹ngŒoh‹ngˆleŒpipgqhofŽofmgŒlfneneŽofŽnemdneŽncŒmfŽniniŠmgŠmfmgoi‹mf‹ngmgŽmgof‹ne‹neŽneŒmdŒmdneofŽnhmg‹lfŽngoeŒog‹ohŒoi‹ogŒmd‹odŠnc‹ndˆle‰kf‰jfŒpi‹oh‰mfŠngŠng‹oh‹oh‹mg‰lbŠmdoioi‹oh‹ngŒoh‹ngpiŒph‹mhŽpkŽpkŽpkŽpkŽpkslrkŽpkŽpkŽqjŽqjŽpkŽpkŒnjŒohrkŽqjŽqhohŽqjrkŽqiŽqhŽqjslrkskrkŽqj’unslsl‘tmslrkrkŽqjŽqjŽqjrjŽqjrkslslpirlrmqlrlrkrkslqj’rlŽrkŽrkslslŽnhrkŒohŒohŽqjŽqjŽqjŽqhri‹nfrjskŽqhqjŽqj‹ohŽqjŽqjpiphŒohpipiŽpkojqjpi‹ohŒpiŒpiqj‹qj‹piŒpislqjqjtlŽrkŽrkŒphrjŽrlriŽqhriŽqjrlqlrkŽqjŒpiŽrkŒrhŠqgpkŽrjŒrkŠpi‹pfŒqgpiojŽokrmpkŽqlŠqi‹qjsltjrhrhpiŽqjqjŒoirjŽqj‹qj‰oi‰rg‰shˆrj†pi‹ohŒpiŠoh‹piŠpi‰ohŒrh‹rhŠqgˆngŒqjŒpi‹qhrhsjtiuiuitjŒsjŠqg‰qgŠpf‹pfŒthxl‰um‡tmŠvoŠumukukˆrgˆrgˆti‰ujŠui‡rh‡ug‡qdŠqe‹qe‰qh‰rj‹sl‰qjˆqi‰shŠskŠtk‹tl‹sk‹oi‹qjŒsk‹skˆqhˆqi†ri„pg„ph…rj†sk‡ujˆvlˆvkŠtn‡tjƒreƒsc†qb„o`‚nfld}jb}iazg_yf^shZneWkeYri`sibwlgvkbxmcxmcxncwndqh_icZd]Tf_Vkc[hcZicZg\RdWNgVOfVO_PI]RL^PH]QI]QGZMC[OCXK@XLDVHEPFAPG>MF=LD@RIENIDNIBLG?NENF=MB=LC9RG@OC;QE=NB8O@7JD:HA7KB:LB7L=6M>6PB8J@8LB:I?7MB:QB;TDN=:P;?S?BVDDVDBRBDTDERFBPB=M<@Q??RBSF=SE>SG=QE;L@4QE9ND;NB=NB=ND;KA8MAJ@7J@9KA9L@6M?6O@7M>5L;4QB:N?7NA9MA7N@6N?6P?6RB7PA5PC8SCTDATB@VD?VD?VE?YGA[HF`JGaIB[GAYEBXGBXF@UD@WD>XB>ZC.3>-3=06C34E3;K9AL=GNAIOBKOATSE_YJh[Nk\NoXPmZOm\Qm^RhZRi[Sd[TYWMPWHLZFN^KL^KUYM]\QjcVsg[{k_mb‚od‚nf‚me€jb‚jdƒke„ldƒme‡og‡ph‡qi‡rhŠrfŠrg‹qiŠpiŠqi‹rhŒrgsiŽsisiqhŽqhŽsishslrksm‹qkpirgrhujsgtirhŒsh‹rgŠrftgŽsfŽqhŽqi‘tmskŽshŽtgphqirkŒoiŒqi‹pfqfqfpg‹neŒofphpgrhqgŽshqgrf‘qkoiŽokŽqkŽqiŒqfŽqiŽrjŽrhqfrirhqjpj’sj‘rjŽriŽsisksjrirh‘qipirhqg‹ofpgofoeŒpcŽrfŽqgŒpeŽrgŒofpgnepgqhqiqh‘qhqhriqhŒpf‹ofŽnhŒmfmgŽnhŒlfmgŒpf‹mdŠmdŒmcneŽoeŽqhŒneof‹mdŒneqhŒmeŒneŽofŽofŒnene‹ne‰lc‰mdŒnene‹lckeŠke‹keŠkc‰md‹ne‰ocˆlaˆl`‹lbŒkbŒkbŒkclelcnf‹leŠkdŠkbˆkb‡ja‰le‹ng‰mf‰kdˆkdˆkdŠmfŠleŠmf‰nbŠndŠmeŽmhngqhŽmf‹ke‰kdnfŠmdŠmd‹keŒlfŽnhŒlfŽnhmgŽofqhpgŽogŽnh‹kfŒndŒme‹ofŠneŒnh‹mfndŒmeŽniŒmhŠmg‰lfndneŽpg‹md‹mcoeŒmdneof‹neŒof‹neŽodoeofnhŠmf‹mhoh‹nf‹oipiŠnd‹lcŒme‹me‹ngŠmf‹nfŠnfŒofŒof‹ne‹ofŒofŒne‹ofŠmeŒnhŠlfŒleŽneŠmeŒogŒogŒogŒphqiŽqirirjsjŽqhphqlojphphqkrmqlpk‘okoi‘rltmŽqgrjrkrk‘skŽqh‘riqh’sjqk‘qk’sm”rl‘pkpj‘slslrk”sn“sn’rn“sn’rm‘ql’toŽpkŽqlslrk“rm‘tmrlŽpkŽpkŽqiŽrhoipiqjŽrkrkpjpiŽqjŽqjŽqjŽqjŽqjŒofpgŽqhpgŒofpgpirkpipiŽqiŽpjqhriŒpiqi‹nh‹niŽrjqiŒpiqjqjqjsl‹piŽpipj‘smsl‘unslqjŽrlqjqjpgqgph’qk“rmqkplrlrkŒrhsithŽukŽtjŽrhqh‹rh‹rhŽrktlŽskulŽsmŽtosmŒrl‹qk’unrjriŽsmunŒsl‰rjŠqjŠskŽtjŽtksmŒtm‹siŠrhsktkumulwmŒvmŠujuk‘xnwpzq{s‘|p”}s’xo‘vn’zqwnˆtlˆslwotmŒtmwp‘zr’}v’~y•|•‚{Žyqˆslˆsl‡rk†qi‡qj‰tm‰ti‡rk…sl€oi€mf„oh…qjŒyo|r‘tŽ{q‹wo‹vn‹vn{s‹zq€pg~ne|jb{iaxjaui`oh]nf[rd]wiayjbxi`wf]udYtaZsbYrcWm^PlZPfRIhWNdTKdSJbQH_NE_NFXNBXODXPFUMDVKCUICXHBVE?UE?TG?TG?UH@PF?OF>NF>PG?OD[CC[EA[F=YEA^G?]F?]GZGB]KLcNJcNC]I?ZDA[F@XC;WB;W@?]D<]C8X?9ZB8E49G44@/5?/3@13C34G46H5WF=RA8VENB:MA9MA9O?8P?9Q=9S?:S@9R@9QA7SB8OA9MA9ND;MB9M>6Q@9OA8QC:L;2M<3M?6L@6PB6OA5QC9SD;PA9RD=UG;VF>WE=[H?]J>`IA_QB\LA\LD\OG]SI\SG^SG^SGaTKeWMaULaVNbVLcVKfYMfYMcYL_XId]NibS_WL[TJfbT~{jjgX[WI[WLZXMWWHXYIVVJSWJNTGKVILXKKWIK_JJ\JEXGFYHK^MMaML]PK\OM\OO]LO^MG\IGZGEWFHYGIXJJXKJXLFXIHZII\HI\FGWDIYGL]IDZF;VB;XD?[H_D;^D?^I?[I=UFAYG?ZF;WC;X@:W?9T<9TB;UB;XA8V>7W@8YD4C55F55E31B/1C02E35E48G7;G:VQB]RGaQHcRIdRJaQH_SIZQGQLDJLCFOCERCKUESZIZ]Md`QqeWyh]|k_}makdƒnf†qi‰qi‡ph†og‹qj‡phˆpj†qi‡riˆthŒsguiuiŽshŒshŽvjuitlslŽrkŽslŽshŠrirktmŽrjŒqiˆpiqjŽqkŽqiŽqhsjsjŽthŽthsgŽthuivirjŽrkslŽrkrkŒrkririrhpgŒofphsgŽthŽuhŽrgŽrgshŒqjŽrksktjŽsiŒti‘rgshqgŽqhŒrgqirkskqhriŽqiŽrkslŽrkrlŽqjŽqjŽqj‘rl‘rhpgpgŽqepergpfŒneŒneŽpeŽqeofpgqhpgŒpf‹oeŒlfmgne‹nepfŒpeŒofŒofpgŽrgqfŽrgpgpfŽofŽofoeŽofŒpe‹peodŽpeŽodndŒmgoiojqjŒohŒohmfŒndpgpgnemgŒlfmgmgneŒnc‰k`ˆlaˆkcŠmfŠmg‹ng‰mbŠkb‰ja‹lc‹lcŒlg‹lfŒkakcŒmdne‹lc‰lcŠmbmdŠjd‹keŒlcŒmaŠmc‰ld‹ngŠlgŠmfŠmfnemdŽoe‹lcŒneŠmflf‹mf‰mfŠmgnhŽlhlflflfkeŒlfmgŽofpgŽoemhŒmfŒlgŠo`‹oboflf‰kd‰le‹mdŒlcmdmgŒkeŠmfŒmdŒlgmgmgŒleŽpeqkpipipipipiŽpipi‹pi‹piŽqjpiŽnhŽnhŽoj‹mhŽqk‹ngŒpfpg‹ne‹neŒnf‹nfŽqhŒofŠmd‹nhpiŒnine‹lcmdoioinhpgriŽqjpiŽpj‹mi‘olŽojslriuitgslŽqjslrkpirl‘qj’rm‘ql‘ql”tl“ujŽsiŽrh‘ri“ql”tn’rltiri‘ukslsm“up‘tm‘slrkrkrlsl‘snš{w›}x“rn”to“rnrkrkŒrk‹qjŒrjrkrkŽqjpirkŽqjŽrksnrkpiŽqjŽsisjŽpkoiŽqjrkŽqiŽqhrkŒohpiojojŽolpkrmŽrkŽrkrhrhsjtiŠsh‹titjshpgŽqhogrhritjrkrkslrkrksl’tk‘umunŒumŒtkŽukŽrkrkslrk‘un’vpŽununslqjŽqjsl‘un’vpunŽslŽrkqj‹sh‹rhŒsitjukvm‘unsltmtm’voŽsksnrmŠrlŠtn‹snŒtmsl‘vk’ym‘vmun‘vqzp‹xnŠymŠxmŠwlwoŽunŠvmŒyn’xn‘yozqws‘{u|t{sŽwq‹rnŠul‹xpŽ|t~u‹{rŠ{rŒzqzrŠwo„pi‚pg‚og}kd|lcyk_yj^wg_zg`vmcxneugalaZodand`pd]l_Yl^Xl\VjYShVPjVKeSIhVM]OH[OHVJEXJFYGBXE?VE@UG?TH@ZJ@WF=ZE>XD=VD5Q>6S?7O;4O<4J=5I<3L<6M=6L:2L;0N=4Q?6M=4O?6PA8RB:Q?7O?3N@2PC4UD:[E@XC=XD=ZIA[J@^JA`LAbQEeTGeUGgXKbWJ_WJeXOdVMdSKl\SobYj_UcWO`VMb[Oc[Nf^Ph^NgXNdXNcZP^WM^XM`ZNZZKZ[LWYJSWKRYKRYLY\MRXIQZKT]LV_OV[LPRHRSHVWKY\PU\PU^QU^RLXJHXFEWEG[IG[LG\LAYI>VHA[IJ^LL\KLZMK_OD\IC]ID]IDVEDWFATEATEBUFDXFDWBEXFH\IG\FEZGBXEBWGH[J@[I9WC@ZH?XH@[JDbJGfLGeKDaG@]DD`G?]D?]D?^C@^EAbF>_B=S?8R=6R>2Q=3S=5S>8V@RPC[QI_QG]PG\NEXLCWMCUMBLHAILBGPCGSCLUDTZHbaQlfWsfX|h^mb‚pd…oh…ph†phˆqiˆqiŠskŠqjŠrjŠqk‰qi‰qiˆqe‹qiqitlumtksjvjskŽrksmskŽth‹qgŒqgŽrhŒpgŽsiŒqgqjŒpiqgqgsjsiŽtiŽtiŽshujtjujŽqhŽrhŽsiŽsisiŒsiŽrhŽriŽrhŽriŒpgŒpgsktkqiph‘tl‘tmtmslpkrhtiŽsishŽrgŽqhŽrishrjslrjŽqhŽqh‘tlrlqiqiphŽqjrjrjqiriripgqfqfŒrfpgŒogŽphŽoeqfpgpgph‹ogŽpi‹ngmgŽniŽnfpgpgŒoeŒohŒnepgpgŽrgqfpgpgpgneneŽofŠnfohŒmeŽohogogmhŽnhoiŠnfŒoh‹ngŽoeŒmdneŽofneneŒmhnhnh‹md‰laˆk`‡k`‰kd‹mg‹ng‹meŠnc‹lc‹lc‹lcŠkbŠidŒlfŒjc‹kd‹lcŒmc‹mc‰lcŠnc‰jbŠjd‹keŠjbŠj`‰laˆkcŠmfˆjdŠmf‰leŒkcmfŒme‰jbŠlcŠncmgŠke‰le‹nfoh‹ke‹jdŒkeŽmgŠlfŒmgŽoimdneŽogŒlfŠke‹jdŠpbŒodlfŠjdˆjcŠmf‹meŒlelfke‹jeŒniŒmdŒmdŒlfŽnhmgmfqjpiŽqjpiŽqjqjojŽqjpiŒphpimgŽnhŽnhpkŒniŒohŠoh‹nd‹neŒofŒofofŒofŠmdŒofŒogpiŒohŒohŽofneŽofoj‘qk‘pjripiŽqjŒoh‘tmqk‘smrkslskskŽtkslslslrk‘tm‘tm’rk“sm‘ql“sl”tm’ujtkri‘qj’rl“rm‘rlrksk‘tm“uoskŽqi‘tmslrkrlrj‘tm’tn–xrsl’rl’rl‘qlslqj‹pi‹qjrkrkpjpjqjpjŽoipjŽpkŽpkrl‘smqkqjŽpkpjŽqjŽqjŽqiriqlŽqkpjqkpjqkŽslŽrktmŽrkŽrkŽrltlŽsj‹qiŠsiŒriskriŽqhŽrjsm‘sm’upskrk‘tmsl‘sl‘tm“tl“wptoŽtntmŒsj‘untmsltm‘untmvnŒvn‹skumslŽslvoslslŒrkŽtmslriŽskrjulŽtkvmsmŽrk‘un‘un‘untmrmsnŒsmŒtnŽvpŒtntm’wn‘xnwmtn‘wrŽvoŽxpyrŠvoŠtmŒtlˆqm…sm†smwpŽvpŠurvpŠvp‡vm†tk‚oh}fa~jc€me}kc~nfpgxjap^Wvc\wd]saZq^Wn\Un[Um[ThYOfXMeTLjVPaUKcTMbTL_QJ]RIXMH\LF^MFZIB\IC\HB^IBUD:ZI?WG>UGASH@OC=N?9O>8Q?9RA9O?8PB:QC8O@5SA8RA7P?7N>7Q>6R>6Q<5R?4TB6N<1M=2M<2Q<3R=3R?6P=4Q@8P>7SA:R@8UA9SA6ZE>_JC_KCbMFcPHbOFaNGaQGgYKeUJfTLfRMiVOiYQjZThXOiYPp^Uh_Sk`Ug^Sc[O`\NbaRa\R^[O_ZO]ZO[[OTVJXVMWXMZ^RX\NXZKYYJYXMUUIPVJSZNW^RRZMM\KP^MFTDETFGUGMZON]KL\JSdRRbPTaPT_NU\RV\Q[_W[bVZbVU`SS[QPZNNZLHWFL]LJ\LI[MF[LC[JH`NG^LJ]LI[KCZGB\H]IE`MC^KFcODbJC`IC`HC_G=ZB>[C=[F>[F;[D=]F=]G:XC5R=2O;4T>4VA7WB:YD7W?7V>5V<7X?9YC9ZE:G79F87C58B69E4;H7:J9;K:9J:;L;?OBCN?EO>JRAORDWQH\RHYOEZQFWQFSNCPMALKAJOCIQEKUDQWF[^MgaRri[{k^j_„nc†pe†og†ogˆqi‡oh‰rjˆqi‹tl‹skŠpjqjŽrjŒrf‹qkŒrkqjtntmŽsjŽshskslqjskŽth‹pfŠofofŽpgŒqg‹pfŒoiŒpjŽsiŒqgŽsiŽsirhrhŽsirhrhrhpgŽsirhrhŒrh‹rhŒqgrhŒqgŽsiŒqgtjqjqjqjqjrkrkslqjpj‘qkrjumtitiŽqgriŽqhŽqjŽrkŒphpgsjskŽqjshsgqftishshqjŽrhŽsirhrfrf‹qeŽqhpiŒohŽofodŽofpgpj‹ojnjokŽngphŽofŒofpgŒofŠmgŒph‹neŒofŒofŒodpgŽofŽofŒmdnendŽnhŽnhŽnhŽnhmgmgoiŽnhŽmgŒoh‹ngŠngŽofnemfŽnhŽofnepiŒoh‹ne‰lc‰lc‰mb‰mbˆkd‰leˆkd‡kd‰nc‹lcŠkb‹kcŒndŒlfŠjd‹kf‹ke‹lc‡jaˆm`‰n`ˆkbˆjbŠmfŒlf‹kd‹kbˆla‡jbˆkdˆkf‡kdˆkd‹kfmg‰ic‹lc‰la‰obŒleŠke‹ng‰leŒngnh‰leŠmfŠmfŠmf‹ngŠngŽoe‹ld‹ke‹leŠidŒkeŠnc‰lb‰le‰leˆjc‰lfŠmf‡hb‹jdŠid‹lgŠlg‹ob‹ndŒohŠmhŒniojŒohŽqjrkŒohŽqjŽqj’pjpjpiŽoi‘qkmgmgmgŒniŒnioiŒpiphŽqjŒohpiŽqjŽqjŽqgphŒohpipiŽqjŽqhpgŒofŒohrkrkslrkŽqjrkslrk’umrjsj‘tmsl‘sn’unrl’un’unsl‘tm‘qk’rl’ql‘ql’sk‘risj‘rj’rl”tnrkŽqjokrk‘tm‘ukqhŽrgrkŽqjŽqjŽqjsk‘tmsltlskpj‘qk’qkŽqjrk‹qjŒrkŽqjŽqjpjŽnhoipjoipjqmnjrmqlŒpjŽrkŽpkŽqkŽqjslŽqiŽqgŽplqlslŽqjŽqhriŽsiŽsitm‘unŽqlŒokrmrmsnŒrl‹qkŠpk‘tkqkrm’to‘ro‘so‘tmsl‘slŽrltmtm“uo”wrtpŽsoŽtoŽrkŽtmtmunŽtmtmŽtmŽtmunŽuntmslun‹um‹tlŒumŒumvnumtmslslsm‘untm‘untmtm‘unslsl‘souo‘wqŽwqwqŽxrvnyqxoŠulˆsk‰sl‰toˆto†sn‚qj~lf~kexkdoh_qi_xjayf`vd_vc^vc\rcZqaXn[TlXSgTOeSNgXQgWQbTO_QKaPJaPK]MGaQK_OI\KE_JE_LD]LC\KCZHA[GB[HCZIAZIAXH@VG>VF?YD>XC=XBYC=XB8T@8UE8TD7TB7YHZG?YE=]I=]G<^I>]MChWKm\PdQG`NDbRFaPHcQIaOHcRKhXMj[No_WhXNhVLgVLgYNdWK_VMbZM^WI\TH[SK[SKYTK]XO[WN[WN[XN]WOXYOYZPX\QW]MQYIQZISXLPUINVIMWJLWJIWILVJMWLLXKOZMMYKNZJKYJIYHG[JL`NM_NM`OIbMIbMG_LBXGDXKJ]QMaSMaSNaSScVUbUS_RS[SR[RUZQQWNPWMKTILTLPXOMWKO[MLYJHXGIXKGZKI^LF^MC\IG]JG]KE_J?\E@_JA]L>YID^HC[E@VCAWE@YF>VD;UA1L71N77T>9XE<[H>^H=aMBeOIfQDaJ?_GEbK?]F<[F;YD>ZD9U?4V>4W?8WA<[F;YE8VD0U?3YC6[F3YC6YC8ZD8YA3Y@5[B:aHAcMC`L@N=XC>XEZE=YE=WD<^IA_JB`LC^JBdOFeOGdUHfUHeSHeSHbTHbUKbVMdVLdULcTIcRGfUIi_Vpe\maVh[Of]Pd[Ne\QbYObXOcYPd]QkeWcaSYWIXTGWUEUUEPTCPUHQWHPWGIQBHQALTFDQBP\NU_ROYKMZLNZLKYMKXKM\NK[KGWEGYDMVJJTHKWJK[KIZIGYGGVHJYJL[NIZLK]MM_NJ]LK_MKbPJbPLaOL_NE_IG`KG_KLaPPbSK^OK^TN`VO]UO[RPYROWPPWPQWPSVMPSIJOEHNCKTIKTJLVJHTHJWHL\KN^MM^MK`NCYGJbNE_JE[HGaJHdMIeOE`LC^MD_JD_HC]FA[D=YF8WDA\G>\DEbKAbJAaMAaN?_L@eO?dNC`L>\D;_GA_G>\H<]I=]I?^I;YA6W<8Y?:]B=aG:^F6ZB4_F7`F8`G6]D6]D1X?6[A8`G7aI8bI>cJEeMDUEAQC>L>=J=?K;@L;=M;?O=>P=?S?BUAHVDKXGKYGSZI]YJh^Re^Q`^OVVHPOAKL=FN@LTDPWHTXI[[Kc_PncUvj\}m`€mb„od‡pe‰mg‡ngŒqjŠrj‰rjˆqiŠrj‹rkŠqk‰qi‹ri‰sgŠsjŒskskŽrjskqiŽthŽsjŽrktmqi‹qe‹rfthuiŽsgŽthŒsgrkrkri‹qgsisiŒqfshsh‹pe‹pe‹peŒpe‹qeŽthsgŒsgŒthqhŽsiŽriqhŽriqgŒohŽqjŽrkqjŽrjskŒqjqjrk‘snqmrlŽthŒsgŽqhŽriŽri’tmŒrjqiŽsi‘tkŽogŽpiskqiphohrjphŒpiŽqhŽqhŽqgŒqfŒpeŒqgŽqjŒnh‹mgmfneneŽofŽnf‹ogohŒohneneŒmdŒof‹nhŠmf‹nh‹ngŠnfpirhŽqhogpgŽofŽofpgpg‘pipiohŽoh‹nfŠmepipipimgmgŒleŒmb‹ldŒlgŽnimfŽqeŽmemdpgŽmdmclc‹mbŒleŠjeŠjd‹ldŒodŒmd‹lcŠkb‹lcŠkd‹ke‹ldŠmeˆkbˆkbˆkaˆmb‡lcˆkeˆje‰kf‰keŠkb‰k`‰ibŠjdŠkfŠjdŠjd‡jb‹of‰lcŠmd‹mcŒmc‰me‹lf‹keŠje‹mf‹ng‡leŠmfŒohŠmfŒmgŠleŽngmg‹keŠjcŒmd‹lc‰jcˆle‰lgŠmh‰me‹meŠpeŠndŽoeŒmf‹neŠnfpfŽqhŒphoiŽqjrjŽqjpiŽqjpioiŒohŽnhŽqjŽqj‹ngoiŽnhŽnhojŽpkojŽpjŒpipiŽqjrkŽqjpipirjŽqjŽqjrj‘tksjsjqirirkrj‘tmrmslslsltm‘tk‘vluj‘tl‘tm‘tm’sntl‘tm‘tmslrkrk‘qk’sj’sjqh‘rl’rm’sl‘qk’rl‘rj‘sjukrjŽrjrk‘tmskŽqirkqjrkrkslrk‘ql‘ql‘qkqlqkŽqkoiŽrjslslrk‘qkqiqjŽqjtmŽrkŽrkqlrlsjsktk‘ukŽqlsmtm‘unul‘wl“vo’vm“vn“vm‘tlskslumsl‘unsmtm’vpsm“to‘tn’uo‘wqwpŒrluntl’ul“um’un’un“wp’xq‘xqŽvo’vnunvqvptn’vn‹qjŒrkslvovosl’wp•yrvnunŽtmtl†rjˆtlˆsk†qiˆskˆtlŠsn…oj‰rmysxt“|v’}v”€wŽyq{tŠvn„oflf€ke€idye_wf_rb[r`Yo\UnZUiUOhYQhXNgZVh\VeYR_UL[TJ_ZNTTDSWEUZGZTE[LAZHAYE@ZHAVG>XH?WD=WC>WE=ZH@XH@WG?YH@WG?YF@XF?UD4UB:WA9XD:YJ;\L?[J@]JDeOFaMDaNEdSIaPFfVLfTJcPGcRHgUKl[Qp^Uk[NfXLlaTlbWk_UfZQg^Qg]Qh]Re^Ra[P[WM^YN_ZO^YN\XJ^YL]YL][Q`]T_\Q[YNWYLTVHV[MX]QU[OU[NV^OT]KN[LJUEKTCHS@IWBHZDJ\JHYGIYGGZEF\GG`JKbNK_MH[IBUCDVGCXGG[JF[IH_LI_ME[EL_JK]LG[JG\JJ_LMaLJ^II]JJ]KFYGDYFD[HD\IJ`NKaOD\JG^LJ^LEWFDZGF\IG]JL_NL_MJ\KF[NO`TM[PJWLMXMJUKLVKJRGHPFDLADOBBOAFUFLZML[NKZMJZMO`PPaPN`PQdSNcPNcPG^KH[II_KH_IE]GC]HD^JA^HGdLFbJDbH@aI=bKBaJBbJEeLCcJ=]F]K=`M>^K>ZF7WA:`GGcJA`J=_K;_K=_H>]CCQ@BR?DTBCT>CT?AT?HWCIYDM^JU]Ib_MmbVhbUa_QRSDJL>OOAIRCNWHSZKZ]McaRidVwl^}pb‚se‚qf‡rg‡rg‹og‹phŒrk‹qj‰sk‡qi‹qjŠrj‰rk‡qi†qh„qd‡rfŠtg‹sgŒrfshŽrgsgsksmŽrkqisg‹ththŽthŽthŽtiŠsgslŒrl‹ri‰qg‹rhŠrhrgsgsg‹rfŒrf‹qfshŒpeŽuhŒrfŒrf‹sfŽqhririŽqhŽpgŽqhŽqjqkŒohqirlrlŒrkŽrk‹ohŽqlŒqksnŽthŽthŽqhriqhrkslŽskŽsiriphpkŽrkqkŒohŒpioiŽqjpiqhphneqfrgriŽqjŠmg‹lgŽnineqhŽpfŽofŠmd‹nd‹odŽodndpgpgoiŠmf‹nhŒnhpipiŒogripgpgpgpgqhqh‘qg‘rgrgqf‹peŠnc‹ohŒogŠog‹keŽnhnhreŒldmhmhŒmeocneneofofneŽkdŠla‹kcŒlfŠjd‹kdndŒmdŠlcŠkbŠkb‹je‰jd‰la‰lc‰lcˆkb‡mb†ka†kaˆke‰kfŠlgˆke‹lcˆk`‹kdŠjdŠjeŠjc‰icˆmcŠodŠmd‰lc‰kc‹ke‰mfŠlelfŽlfŠleˆleŠmf‰le‡kcmgŽnhke‹lfŠkd‰icŠkbŠkbŠkbŠjd‡ke‡mg†kf‰kfogrfrfpfŽpe‰mdŠoe‹ogŒpipjŠohŒqh‹peŽqjpipiŽqjqjpipiqjŠoh‹piqjŽqjqjqkrlrm‘smŒpjrkslrk‘tmŽqjŽqjrntmrlsjritjukukuksmqkŽrkqlrmsl‘tm‘tj‘sjŽsktm‘umrlrj’risl‘tm‘tlsmrkŽqj‘qk‘rishphpk‘pkqlpj“qk’sjtjuktjrhrjrksmojskpiqjslslrk‘qlpkojrlŽqkŽpjpjrkŽrkslŽrjpjqjqjŽrkŽtmtlsl‘tksjsj’vk“ym‘wk”wr‘uo’vo’vo‘um“xn•wm’uk‘tk“votm‘tm‘tosnsm‘un“xn’vm’vo”vo”uo•vo’un‘woxrŽtnŽtm‘wl“wk”yl—yr”wp”xq’xqwovo’wl‘vounvovmtjŽtm‹qjŒslvnumŒsl‹um‰tl…qiƒogme€of…phmdƒne„ph„pg…qhlg|id~je‚ni~jd}ie}kcyf_ubZtbZm[SmZRm[TiWPgTMcQJ_NH\PH`NG_MG^MG[IDZJB\MC^MHaOJ`NG_PGVMBWNCVNCQPCUPBXIAZC>]B>XB>VB_OF[I@XF_LC_KChNEhQFfSFdSFhWJkZOkXLgUHk\LgZKhVNlYTn\Rn\QjZNk^Qk^Ri]Ph[ReZOdZMbYKe\OaXK`YK]ZK]^OZ^OWZOVXL\]P]^R]]QTVLQVKRYO\^RY\P[^RZ`PY_PV]OSYQUZQMRHNTIMUIP[LN\LM[ML[MK[MG[HFYGFYHEVDGVDFUAGZDIaJLbLI_IF\FF\ED^FDbHC[CCXCDXB@S@AWDDZGD\FGbKGcLKeNJaJK^IHaOGbND`KC_IIdKLbJD^HAXFAXDB[H@]IA`KKdRC]K@YG>XFG^LK^MCXHDZHF\IH^JI_IF^IE`LH`MH\JGYHGZHI\JJYMESGDSDCSE@TE?UDG[GJ]LH[LK]OG\LF\KI\KI[JI\JH[JK_MK`LL]LJ[IK]IH]FI`HG^IDbNIfPHeLGfKDfL>eL?aI>`G@aHCaI=ZD=XE=YJ=\L>]K=XE<[G8^GB_E>]G8\H<`L=`H@aG?YG8TC2T@6[F5_H3_H6bH4]E9`G8`G9bI;eL:iMQ@@O?EP=GT@GWCCVDEUBFTCLWGMVFT[LX_N\`MSXFOTEOVGMTBTZHV[LSZIY]M\]KlfTtjYoeƒng†qi„oh‡rgˆsh‹rfŠsf‹rgŠqftjŒsiŽsiŽtj‹rhŠrhˆpe‡qf‰pf‰pf‰pfŒqgsirhviuhŽshrh‹pfsjujujtjukŽrkqjŒqeŽshŒqgŒqgqkqjrhsjqfshrgŽpdrhsiŽsiŒqgqhŽqhrirjslrkrkŽokŽqlritjŽthtjŽsiqjŒphslslqjŽrkŒsiŒsjtjtj‘tksjrhtjripgŽpgŽofqjŒpf‹odŒpfŒpf‹ohŽrhqf‹od‹nepgpgŠofrh‘pg’ohŽmg‰leŒlfŒlf‹mh‹ne‹me‹of‡lc‹nfŒodpgrjŽrlphŒofŒofpgŒrgŒqh‘oi“qjqfqfohphpgŽqhŽqhŽqhŒofpgmgoiŽmgŒlfŽnhŽnhŽoh‹kemgmgŽmhohŒlf‹leŒodŒmemgŒlfŒlfŒlgŠic‡jc‰leˆldpbŒocŠla‹ldŒlf‹le‰naˆoaˆlb‰leŠlf‹jf‰jbŒnd‹ld‹keŠjd‹lfŽlfŠle‰mf‰mfˆjc‹ic‰kbŠkb‰ja‰ja‹lc‹lc‹lcŒmeŠkeŒlgŒlgŒlg‰leŠlfŠmfŠlfŠmfŠlelfŠicˆhb‰idŠmf‰lf‰lfŠnfŠmgŠoeŠodŒrg‹ngŒogŽqk‹nepfŒpfŒoipgŽqhŒofphoiŒpjojŽplpkojni“qj“ri’rlqjqlqlrn‘sn“upslrkŽqhŽqj‘tmrk‘tmrkpi‘ro‘tnri‘ri“sl’rltj‘ul’vluktjŽsi‘qlqj“rl’rl’uoun‘sorm‘tnŒrgtjŒpgpkrjŽrg‘tjphql‘qkpjpjrkslrkslsjvjui‘vmrl‘pj’qk‘qk‘qlqlrm‘qlpj‘ri“tk‘qk‘ql‘qkrkriskskujŽsiŽqhriqi‘pk‘qk‘qlqlrmrm‘rnrmtl‘tn’un“wp’xm’vlwo”yr–xq”vo“tn’vo“vq’uo‘to‘upŽtououounulukuowp‘yp’xn‘wm’vo“wp“vq‘xoxqwo“yr“yq”zq“zs‘yq’ysvp‘vquq‘up”vq’up‡rl‡tlƒnf‚mg„rj„sl„rl…rl„oi~jh{jgykepe^pd]ujbrg_ne\mf]jbYkaYkaXk_YiXSo\UkWRhSQhSSfPJcMIcKKcLJ`JD`KA\IBXC?UA[C9TAYD9\F;]D=YC:ZC:`G?bMEbOGaPG_TJ_VM_UM`QJnaYnf^tjbvgaxg_td[m[Sn^VraUubXzg\scXm`TjaTe]TiaXhcWfaUd_Sa_R^^TZ[QZ\Q\bVV^QX`RUWLVYOY_RV\OX[PYWNW`PT]NV_OT]NV`OS]MXaT\dVZcVV_QUcUTdVWbUWaSWbQWbPT_OOZJOYLLWHKYGMZIO]IO^HO]JKYGM[JN[JL[HIXCD[CD\GB[IBZHE]KH^LI\IH^JB]F?]F>\D@_E?[EB\EBYDH]FF[EDZDEZHBZGC[HDaICaHEeIJdQKgQDaIDbH@]H[E=ZCC^H@\E?ZHC^JH_LKaOGaKFbKCcPDcODaMD_LHfNGcLKbJF_HD`JC^IB\HDZGF^HC[DG[HG[HG[HEYFDWCFWEBUF@TFE[LKdTLaLJ_HG]HI`JH`JG`IHcLIfNHfNJfOEcL:_FC\J>[E?bFCdHGdJKaKCZEC^H?[E<\G:]G5YE;\C=\F:ZG;\H:]F8]C6WC3VA4XB8_G8`G3]D2^G7aF:cF?dI@gL?gNBhODlSElSGhPLlUHkTAVD@UD@SB?SB>SB?R>BRT?>S?=T@:WB;XDYG@YFBYFDXE@WB?[D>[DA]EA_EC`IGbJJaKPeOJ`JE\FCZFC[GB]IFbKIgNIhNLhSKgRB`HC`IA`J=]H@\HC_HEbIDaH<[C;ZD;\D?`HA_G?^F@^GA^GEaNGcOHaMD[HE_HEbKCbNCbMBaLB_JHeNGdMIfNNjRJgPIeND^KG_KGbKFaJD]JCZG@XD=TA>WAAXD=UE8SB=XEGbPGcLOjSOfPTgROaLP`KIaKGbKGbK@YB@[D<^GB]K@^GAbIEeKPlTXp]PjSC_H=YC<[F9[F8]G;\C:[C7YB8YC7ZB:_E7]G:`I;aK=eK?fN9bI:fK>fL?fKAgLBfOCiSEiSDkVGlVEbNE`MFeQ?Q@@Q@=RA;UCCS>AS?BTCCVBCVDFVEEUDHYFM[FS^GT`KYdS\fYcm_gpbkrcgm^km_tqcwobzl`€la…pf„ph‰rj‰rj‡ph‰pf‰pgŠpi‡mf‡mf‡mf‹peŒqgrh‹rh‰qgŒsi‹rh‹rh‹rhŽsiŒqgrhsgŽtgŽsiukshŒoirhrhrhtjŽsiŽsiŽsiŒqgŒqgtjŽsiŒqgshukŽsiriŽrgqfŽqhŒpg‹pfŽsiŽrhripgŽqhriŽqjŽqjŽqj‘qkphrgrg‘riqjŽtfŽsfqgŒofphŒoishrhrhrhrhŒpfpgŒofŽqhŽqhŽqhpgqjŒpfodŽpeŒof‹ohoj‹nhŽqhpgŒpererhŒofŒofŒmepkŽnhnhlg‰mfŒofŒnfŠoeŽofŽnfqfpgphŒlg’qjofneŽofŒnepgniŽngqfŒncŒnfŒohŽqhpg‹neŒofpgŒpfŒlfŒlfŽnhmgŒke‹ke‹ke‡gaˆiclfmg‹keŠkb‹lc‹lc‹ke‹ke‹kfˆldˆkdˆld‹leŠicŒlf‹keŠjdŠjdmhŠjeŠje‰le‰leŠmdŠmdŠmd‰ma‰lc‰lc‰le‰leˆkd‰leˆkd‡jcˆkd‰leˆkc‡jcˆkd‰ldˆkdŠmeŠleˆkdŠjeŠjdˆhb‹jd‹lc‰iaˆi`Škb‹lcŠkc‹lcŠka†jcˆleˆkdŠme‹je‰ib‹kfŒlgŠje‹keŒlfŒlfŠneofphpjŽpkojŽplŽqjpgŽqjŒoiŽol‘oj‘qlpkql‘rnsn“to”tn”sm’rl‘sjsj‘rj’sj‘ql‘qk“pl‘okqkpislumŽqjslsl‘tmsl’rl‘qk“rlrkrkslrkslslŽqjŽoioi‘qkpjpiqn‘snŒofpgŽqiŒohpirkŽqhŽqhslrkoipjpjrktmrkrmrm’to‘snrm‘sn‘tmrkrmqlrmrm‘tn’un’ul‘sksl‘sn‘rormrmrmslslsj’uk’unsl’um“tosl‘un‘tm“wp”xp“wp’up”wr•xrvo’xq‘wp”xp—{t–zs—yr–yr”xq–zs•yr•xq”xqvo’wpuoŽunununwpŽvp”zr”{syqyqŒwo‰tkvnwovo‰qi…og…meƒmflf~hbzf`zhbwg_te]uc]r`Zj`Wh_UkaWmbZiaXh`Xg`Wf^UdYQ`XQ^WPQNGVSIXVMRNEVMDTKCSLCTLCTKCRIATAXFWC>YCB_H@]F?_GA`GHeNKgPRlUQjTHbKGbKC_HE`KHcOFcNEcJEcJHdPDaJ@]FA`H@`H@_JD`LIeN[x_IfM@^G:ZF:\D?aI?aIA`HDdL@`HB^JFaME`LB^GC^GEaJEaMA`L?^HA`KGdOEaMCcKEdNDcNGbNC^JF_LFbKDaI?[GA]H>YEZFB^GGdMMiQH`JG\FGYEFXBDYCB[EF]GI^HE\FEcLB]L?[G<]DA`HGbLNiUOjSD`J8X@9[C6XA8\E7Z@9[B9\B:\C9]C:`F8aJ>hQgNAhODmQBjO>dICdLDeQFgUFhS@gQCePE`L@YE>ZF;L;AP??SB;UC@XF?WBAV@?R=?R>@RAATAFWGJZIJXGQ^KTbL_eNbgUciZgl`mpdvwkxyjywi}vi~uh~pd~ob‚ncƒod‡qf†og‡phˆngˆoe‡neˆnf‰oh‡mfˆnhŠofŒqgrhŽsi‹rhŠrhŒsi‹rh‹rhŽsitjŽsiuisg‹pfŽsitiqjŽsirhrhrhŽsj‹pf‹pfŒqgŒqgrhrhŽsislqirhrhrhŽthŽqhŽrirhŒqgrhriŽrgpgpgŽqhŽqjpipjpgrg‘shŽohqkqeqfqfpgŒofŒofŒqg‹pfŒqgŒqg‹pfrhŽqhŽqh‹nepgŒofŒpfqiofŽpeqfpg‹ohŽokŒnhŒoh‹ne‹odqfog‹neŠmdŠmdŒngmgŽnhŒlfŒohŒofpg‰oepgŽofŽpene‹mdŒlg‘ogneneneŒmd‹lc‹ngŠmfŒpeŠoemfŽmg‹neŒof‹neŠmdŒofŠmd‰le‹oh‰leŠmfŠnfŠng‰icŒlfŒlf‹keŠjdŠicˆkbŠmdŠmfŠnf‰leˆleŠmfˆkd‰leŠjdŒlf‹keŠjd‹ke‹ke‹kfŠjeŠjeˆje‡jc‡kdˆkb‰mb‡k`‰lf‰le‡jcˆkd‡jaˆja‡hcˆie‡je‰kfˆjeˆjeˆkdŠmfŠmfŒoh‰leŠmf‡jd‰leˆle‡ja‰ld‡kaŠja‰jbŠkaŠkbŠkbŠkb‰mf†jc‰leˆkdŠjdŠjdŠlfŠje‹keŽngmgmgŒofŽqhŒohpjŒniŽpkrkŽqjslpiqnŽpn”rm“sm‘qk‘tm‘tmtm‘snrlrlslri’sj‘rhqh’si‘ql‘oi“plpj’rl‘qk‘pk’rl”sm‘qj“sl“smslslrkrkrkŽqjslŽqjrkrkrkpj‘qkŽpiŽqjŽpkŽpjŽqhriohŽqkŽqhŽqjŽqjŽqjslrirlrkŽqj’qk•tn’qkql‘rm’up’to‘snrmslrk‘sn‘sn‘sn’to‘snslsk“vm“vo’tp“tp“uo‘uo‘uo‘un“wp“vm‘tn“vo’un’to‘to”wo“vo“wp”xp’vo“wp“uq‘vpuo’xqxoyr—yu”wr“yt”ys”xs”ws•zs“yr’yr“zrxpŽwoŠup…rk…sk…sk…qk‡rmŠrluoˆrl‡sknf€mfƒognf~mdxg_wf]tcZtc\o^Wm[Tl\UdZQ`YPbWO`QJbRK\SJ\TJ^TJ^RJZRIZSJWPGYQHVKCWICSG@UJDVLDUKBWKCYG>UFRD:SB9W?:WA;WB;WA:T=6W?9ZE;[D>]GA^EAcJFeLHgOEjQGePFjUJkWLhUKjVOlZRkYRhWPk\Vtf`volunkrkhtmivmhyrkymivjetm€xpombhi\^`TVYLUZMTZMLRFQYKU^QT_RW^Ric\vnj|wr}xqsqhde[Y\RY\QY`SZ`QZbSVcSWgVUgWQdSNaNObOOcPNeNPeOSjSQiR\s]VkVYmXZmZRcPZeU\gV\fU]dV[`TW[QP\LQaQQbQObOPfRQhULhTOiUNeQLbPLbPJ`ME`PE^KC_HB]FA]GD_LFcNHcOLdNMeOHbKEaKC`GD^HD]ICZH>XE@]HC_G>ZE[E@]F>\E?\E>\G@_JAaI@aIA]IEbKKgOFeLCbJ?`KBdMCeMCdLGgODdL@`HB^JB^JB_HD`IFbKJdMFbMC`K>_JAbMDbMDaL@bN@`K>]HA]IA\G@[HA]F@\E;ZF<[E:UA>YEAZC?XC?XD>VC@ZC@ZB@WADZD=W@A\E;W@AV@C[EF^HF[ED\FB_HA`LA]JB_H?\E8W>=\HDeL>_G=^F8ZB7\C7[B5Z@6[A7\C:_F9]C<^EbJCcOJhSJfSFhSDiSFgRIdQG`MGbN@Q@>M=@RA>SAAVDFZECWACVABUADVEFXGIXGMXHR\LYaN`gQkfTlgXmj\rlawpe~sh€yi‚wi‚thƒrfod~mb‚na…nc†pe‡phˆmg‡mgˆodˆoeˆoe‰ogŠpgˆohŽqgqhŽsirhŒrh‹qgŠqg‰pfŠqgrhrhriŒrf‹qdŠoeŠoetiŽrjŒpiqjrhrhŽsiŽthqjŒpjrisjqhujpiqjrjrhsi‹rhriqgrhŒqgŽrhŽqhŒrfŒrfŒrgshŽtiriŒqhŽriŽsgŒpgŒpgŒpjŽpiphŒogpgpf‹oeŒof‹pf‹pf‹pfŠpfŠqgqhqhŒof‹neŠoe‰od‹ngŒoepfrgofŒogŒnhŒoipi‹nfŒngŒog‹neŠoeˆnd‹pfŠkfŒlfŽnhmgŒoi‹neŒofrhŽqhqgŠpd‰of‰lcŠlfofneŠlcŠlc‰lc‰mcŠng‹nfŠnc‰lbŒnfmh‰mcŠmdŠmd‰mcŒofŒofŠmfpiŠmf‹ng‰le‰mfŒkeŒlfŠjdŒlfŠjdŠkc‡la‰ld‰ldˆke‰le‡jb‡leˆleŠmfŠjdŠickeŠkdŠjcŠkcˆiaŠjcŠkcˆjc…ha‡j`‰lcˆnc‡mb‡jc†jb‡jcˆjb‡ja‡ka‡je‡jd‡hcŠkfŠlg‡jeˆkd‰le‰leŠleŠmf‰leˆkcˆkcˆka‰lc‡j`‡jbˆlcˆkb‰lc‰lc‰lcˆkb‰mfˆkd‰le‰mfˆleˆle‰md‰neŒogof‹ncpfŒoiŽpjqkŽpjpjŽqkrlrkrkŽqjŽolpn’tn‘sl‘rl‘rl’tmrl‘tmŽqjŽqj‘tmrkoiŽrjsirj‘siqi‘ph‘qk‘qkpjpj‘qk‘qjqg“tm’rmŽpkŽqkŽqj‘qioh‘qjphohŽphŽqkŽpi‘qk‘qk‘pkqjploiqhqhpj‘qlŽqiŽqiŽqjsl‘tlri‘tm’unrk‘qk“sm‘qk’rj’rl’rm’rm“sl“ulŽrkslrmrm’to’to’tosl“um’ul’un”uq–ys”wq“wp”xqwnwo“vo“voum‘tp‘uo‘up’uo’vp“wqtnvovptpvpwqyryq“}t–{v’{uyryswpvpvoŒun‹vo‹woˆum†rj}oiymdwmcukauiavhb{hb{gaxe^wd]r_Xo[Sp_Vm[SjZQfWNcXN`UJ_QJ_OG`MF_MFYMCVLAWJCXF?WF>VIASH>UH>WG?RDXC>WE>VF>UE=R@8S?6VC;VD;TD;XG>XF>]JB^KF]LD\NDcUIdTKgVNeRKdQJhVNfVMbSJeVNgXOcSKbTKcWMaUKbYNe[Rh_Uc]Re_UhbZnfcijahg`jhbqmgwrmzupxqhvogzrlolbeg[agWWbQP\KNZIKUEKUDOUFMUHJRF_`Wwni€tqyqnnocbf[X_RV`QZbT[cUZdTWbRVdSVfUSbQQ_OUcRWeUTeRSdQTfRWiV\m[crbYhXZhW[iX[gWVaSWaPZaQX`PU]OP[OI[JEXHF[HJ`MLeNKeMJgOIfNGaLF]JHaOF`NIeRHcPFbLDaJEbKJeQFfNIfNHbKC^GZC<[C]G<[F;[E<\F<_F=[F?\D?]EB`G?`HAcMIkRFhPKiREdLB`IA^GA]GB`HDbKCbKHeLNiPJeNEdLCdO@bMBaLDaL?^K@]IB]JB]IA\H=YF>XA=YB8WA:[E:XCB]IJbM>VC=WD>XE;YB;Z@AZD@\E>ZC=ZC@^F;ZC?WA>YB?[D?WAB]FAcK?_IA`J?[E?[E@`G?cJAcL<_G=`H8]C8]C=bH:_H8^E;`FN>?N=AR>DWBDWBFYEFXGIYHLZIR[LX]ObcRijVvhZug[vj_{kb~nc€nc‚rb‚qa†pb‡pd…qd‚odƒla„nc†peˆnh‡mg‰oi‹rf‹tgŠrf‹qg‹rhŠqgrhriqhŽriqgrg‰qg‰pfˆpfrhŒqgrhŒrfsg‹pf‹pfqhŒpiŒpiqkŽsirhshtgŽrlŒpitjŽsithŽthphŽrkŽrlŒrhŠrhŠrgsjŒpfrhtjqgŒofŒrfŽthŽthŒpgŽsi‹pfŽsiti‹qerhŒqhŒojŒnjnjpipipf‹ndŒofŒogŠoeqgˆpfŠpfŽphpgŠmd‹ne‰oe‰nd‹ngpgpepeŠldŠngŒphŒoh‰mfŒohŒoh‹nhŠmdŠoe‰oeŠpgŠmgŽnhŽnhŒlf‹nh‹neŒofŒpgŒofŠoe‰qf†od‰nf‰kfˆkc‰kb‰lc‰lc‡lc‡la‡kd‹ogŠnbŠncŠkdmf‹ne‰lb‡ka‹nfŠmdŒof‹ngŠmf‹mf‰keŒngŠmflfmgŒlf‹ke‹kfŠjc‰lb‰ld‡jd‰ke‡jcˆkb†jcˆleˆld‰icŠicŠicŠka‰jaˆi`ˆi_†h_ˆj`Škb‡i`‡ja‡ja‡mcˆlb‡jd‡kc†jc‡la†kaˆmc†keˆkf‰idŠjfŒni‡kfˆleˆleˆle‡kdˆleˆle‡k`ˆlaŠmd‹ne‡ib†ibˆla‡lb†ka‡ka‰nd‰mbŒmgŠmf‰leŠng‰ng‡leˆodŠofŠoeqfŒpeqeŽplplqlrkŽqjrkslslpiqlpmonrk‘tmsl’rl’rl“rmŽrhŽtjslsl‘rmpkŽqjŒpisjrithtj‘pk’rl‘qk‘qkŽnhoirh‘qjojŽpkŽpjŽqjphrhqhqipgqiŽrkŽrkŽoi’qk‘qkoioioj’rj“sl‘qkojŽqhŽqiŽpkrmtk‘ti‘tm‘tmslrk“tnrk“uk’skpk“sm‘rjrhtnŽrktn‘sm‘sn‘snsn‘un’vl’vn‘vn•xs–zs’vo’vm’wnwl‘xm“vo“vosm“vquosm‘to‘torm‘upvpŽuoŒqm‰qlŠrlŒtoŒxqŽzrŒtn‹vp„rk€ng}jc~ic~le}jcle}jcve^tc[mc\kc[gdZfaXd]UcYRfWQeTOdQJeRKcPH`MEePH_KC^LD]LC[KBXI@WF@ZE?]E?[CZB>[G=]H=ZFB[G@[G?YG=ZH9XE3WA1V<5X@8[C;]E?\D]E>YC?]D?bHdLbNGUHGWECRA@N:=O8?Q;DT?FVDFVDGVFIWCOVD[[Kd_QjdXmg\viYxi\yh_mdnb‚m_„nb„nb„nc†pf…od‡pg†rgˆpg‰ohŒpiŒrjŠskŠujŒsiŽrhri‹rhˆthŒueŒufŠrfŠrfŠqgŠph‹rf‰qerhŽsioiŽpjqiŽrj‹qg‰qfŒuh‹tgŒqg‹pfŒpgŽqhpgpgŽsiŒrh‹siŽsiŽpgqhqfshŽrhrhqh‹qjŽsirhrhsjŽrk‹ogŽthrgŽsi‹pfpkŒpjrhŒqgrh‹pgŒqg‹pf‹ngŠmfpipiŒoh‹nhŒqg‹qf‰oeŠqgŠpfŠqgŠpdŒrfŠqd‹pf‹pfŠoenhpgneŒoeodŒodŒkfŒlfŽmgoimg‹mf‡oeˆnd‹nenfoi‹ohŽnhŽnhneŒmdŽpfodŠlaŒmfŽni‹mh‰le‰le‰lbˆjbˆkb‰lc‰lcˆkbˆlf‰mdˆmcˆkbˆmaŠndˆmcˆnc‰oaŠpb‰odŠoe‹mgŒkfkglhŽlgŒofŒlgŒlh‹ke‹leŽpfŒmdlc‹mdŠod†lcˆmbˆkb‡jcˆldˆkd‡kd…ibŠme†l^‡l_‡ja‡ja†jc†ic†ic†je‡jd†ibŠlc‰kbˆleˆle‡la‰ne‡la‡la‰kf‰ke‰le‰leŠme‡jb‡kd‡kd‰leˆkbŠmdŠlcˆkd‰mf‰mf‰leŠnf‡kcŠje‰le‡keˆleŠmfnhneŽofneŽnhŒlfmhŽogŽofpgŽofpgpgŽqiphrkŽqjslrk‘snŽqkrmrkŽrkrlŽrkrk’rl‘qk‘smqjsmrkŽrk’qk‘qkpjqhŽqirkrkŽqisi“snpj‘qkŽnhoipj’rhqgpjŽnhŽpkŽpkpjpk‘qk‘qlplqk‹pi‹piqjŽqjŽpkŽpjŽqjŽqjŽqknjŽolpmrkrkrkslsm‘tm‘untm‘vmvlwl‘xl“tm‘rl’sl‘qk’rl”sn‘rl”vq‘tp’uq’vp’vnsn‘upŽvpŽuo’vq”vq’to’tptntn“wp’wnvkŽulŽumŽtn‹pm‹pmŽtnŽtm‰pk‡oiƒoh€ogzif{jf{jg}khmk€ml{lgykeug_qb[pcYocYpaZo_Xl\UgWQfYScYRdYNaVK`TL\OHZNH[NJ\KEZF@[E?YF?[GB^DAZE?YC=YDZD>[GB[HA^KC`MEfMEhRIbMFhVMhWJeVFlZPn[RkXOp[ThXNbVJaYP^[NYXIQTERUHRSHPSHPWIP\LMWGMVHRUJSVJSVJRVJSUIWZO]bUY^R[bU]fYZcV[cUZ`SWaV]hY`kZak_\fY[fV\hX`iXaeVii^llahh\daY`^V\^TZ`T[bVU_PQaOTbQWcQ]eWhiamieqoktpmvqmoidhe_ee^ZdXUdVRcUPbPVfQYdOQbK[hSWhTQgTRgU[iZam\fp`ep`ak]`k^[eYZj[WgZReXQdVPcSJ]JFcLGdJHcHG`FG^GH\JFaIHbJHbKHbJFaJEbKHdMF^HF_HCaIEbKD^HFbNJgRDePDfPFfMHgLCiMAbH=ZAC_HDbLAaL;^I?bJ@bI?bGCdLDcM;_G;_GFkRGkSGfOIfOFdLCfNEgNIfOJfPHgQFeJCeJAeKBbIFcIC`F@_F=]D=]E?`H[D>[D>ZDD`JFbKDcOCaMC^HA]FCaHEcJC_FFbIEaJGbKG`LF^KFaLA[HBYI?WG?VE7O<3M;5N<7O=:S?>YF?[E?YB@ZCC^GC]F?YBB\DB]I@[IB^J;XD2R=5U>6VB:ZE8WB8WB_J=`I^C>]DCdKAeJhN@hPAeNCcLAbOEeRDePAbMAbMEgPHgNHhOFhPEhPEjQDiSCjPHjQIhPKmVKiUIdOFfMCcMEbNGcOFcKFeJKWIHSEFSBAP;@R;@QBR@@P>AQ@ETALSBXXHjbUrgZui^~l_€ma{i]~j_l`‚l`„nbk_€j_ƒmb„nc†og†rgˆpf‹qgŒrg‹rf‹th‹vkŒtjŽrhŒqgŠrg‡shŠre‹sg‹rg‹rh‹qiˆog‡od‹pfŒqgŽsiŒqfŒpeŒrgŒrgqh‹rhŒsiŒtiŽsi‹qg‹qfpgpgŽqhsjŽrh‹rhrhqhpgshŽrgŽqhrhŒqhŽrjrhrhrhŒqgŽqkqjtiŽsirhrh‹oi‹ohŠohŒpiŒoiŠohŒpi‹nhŠnfŠnf‰me‹ofŠofŠogŒqfŠoe‹oe‰qg‰pfˆoe‹peŠof‹pg‹pg‹oh‹niŠmgŠnhŠnf‹ng‰me‡lbmgmgŒlgŒkfmgnh‹oeŒpfŒofŽpg‹nhŒpingŽogŽnfneŒle‹kcŒmd‹kcŠjeˆkfŠlf‡jd‰lc‰lcˆlbˆkbŠmdŠmdŠldŠmd‰lcˆmc‡maŠpd‰nd‡la‰ob‰obŠodŠoe‹mcoeŽmdneŽpd‹pbŽnf‹kcŒlfŒlfŽng‹kdmd‰kb‡kbˆlbˆja‹kbˆibˆjcˆic‡hb‡hbˆib†i`‡ka†i`ˆkb‡lc†kbˆle‡kcˆkd†jb‰mf‰mfŠngˆle†jcˆle‡kdˆle‹mh‹mhŠlfŠmfŠmfˆjc‡kdˆle‰lfŠmd‰md‹neˆlfŠng‰mfŠmf‰le‰mf‹keˆld‰mf‰mf‰leŒlfpgpgŽngpiŽoioioiŽnhoipjoiojŒofogrkslŽqjsmqlpkrjqiqiofpi‘qk’rl’sm‘umŽrkqkqjŽpirkqkqkqgŽqiŽqjŽqjŽqiŽqhpkoipjoipjoioeŽnhniqjrkqlpjpj‘pjpkojokpiŽqjslŽqjŽqjpjŽqjrkrmrmqmŽplqksl‘smslslrk‘sm‘tn’vo“voul’wo‘vo‘vo‘vnun‘un‘un‘um‘uotpŽtpuqtn’tououoŒsl‘up’toŒrmtnŽunŒtlvowpŠvkˆtk…qh‚lf€jeidlfngyhasf^pf]le\l`Zk^Ym`\p_]ra^n]Zg[Tg]UdXP_TL_SL_TM_TK^QJ\LE]LEZKFYMFYKAVH?VH@SE=TD?TE?TB;YD=WC;VE;XG@ZD?XC=XCZG>_J@^I?`JC`JCcOHcNHcPDcQFeSIgVMdWIh\Lse[j\T`SLaVKbZMbZKe_Qb[OaYOa[P[YLXXIUZLT]MP]KKYGKYGLXILXKHWGFXFJZILYIT]PXaS]eXbh]kpdmpflpessipsgjnbjnblnchi^bh^_fXYaRX`TYbV\hV\gX[eU[aR`eX`eY\bUY_SY_S^gY[gXXeVTbSQbQWfT_j[gnbnphsqmqqkpohkkc`cYY`SXcUR`PO`QPdSNbQRdSZiWr€misaXgVSfTWk[\l]_kY`m\]jZXgVYjWXjWQiVPiXNiXHcQD_KF_JFbKDaHD_FC\DE[DF\IEaLIfPKgQGdMD`IC`GE_JF]HF^JFcLGgOFcJJfQIgQEePBeNAdL@cIAfMBdKA^GFbKFdLCeL?cJAcJAdJAbIEdNEcP?`HAdLGjRLmUKhQHdMGdKGgPIgPHcLI`MEcNGeKAaH@aI@`HB`GA^D=[B:YA;[C?^F=[D>YE=]E=_E<`G;^E7YA[E=XE8RA;TC9SB5N;3P=:VC=VCAZF@[F>XE@V@BZDB[D@\E;XA8U>ZG;WD9VB3S<5U=2U?5XA:\E7XB;[DAaKCdLBcLCcNBcNCeN?aI>^E9[A;\D@bIAdJ@dIAhO@hO?hP;bI@dLCaIBbLBcLCcMCeLAbIEfNHhPFfNCcMBbLCePCfQBfPIgRFeOEgRFfRHeOEeMCbLCcNGcOHfNGfLHPCDN@BO>DS@CS=BP=BP>AO=AO>BO?BR@MUEZYKmdWzk]~l_m`„nc‚mbƒmb‚m`k_k_‚m`‚laƒmb†pd†og†qf‡peŠqeŒrf‹rfuiŠtiŠsiŒqgsiˆqf‡qf‰pf‹rhŠqiŠpi‹pi‡mgŒph‹ogŒqgrhsgŒrfŽrgŽuhrhrhŒrkŒsk‹rhtjrhrhŽpgogpgqgŽsirhrhŽqhŽqhpgŒqgŠofrh‹qfŒqgrhrhrhŒpiŽrkŽsi‹pfŒqg‰nd‹pfŠod‹ohŠng‰mfŠng‹oh‹ohˆpd‡nc‰pd‰qe‰qeˆpd‹neŠpeŠoe‹pfˆoe‡nd‰leŠme‹mhŠlgŠlgŠlg‰lgˆkfŠmh‹oh‹ohŠnfŒofŒnf‹ne‹me‹ne‹nfŒmdŽof‹ne‹ne‹ohŠogŒpf‹nd‹neŠmdŠmgˆkdŒld‹ke‹kfˆjeŠmfˆkbŠmdŠmd‰lcŠmdˆkbŠmdlcmd‰lcˆkb†mb‡nd‰ndˆmc‰ndˆmc‰odŠoeŠmcŠmcmdŒmbpeŠn`odŠlbŠkb‹kf‹ke‹je‡ka‰kbŠkbŠkbŠi`Œja‰icˆgaˆhbˆhbˆhb‡ga‡jc†ib‡jcˆlb‡mbˆmcŠlcŠlcˆkd‰le‡je‰lg‰mf‰meˆkfˆkf‰lgŠmiŒniŒniŠlf‰leŠlfŠmfŠmf‹ng‹ng‹nepgŒof‹ohˆleˆkeŠmfŒohŠmfŒlfŒohŒpiŒohŒphqkpfqiŽnhpjoioiŽniŽnipkpkpkpkŽqjpiŽqjŽqjqlŽpkpjqi‘ripgŽpeqgŽoipjqjpislŒslpjpjpjrkrjŽqkŽpgŽqipiŽqjrjŒofojoiŽnhpjoioiŽnhoiqjŽqjrkŽqjqiŽqjŽpiŽpjplojojojŽoiqjoipjrkŽqjŽqjŽpkrmŽokrkrkrkrkrkrkpm‘sn’to‘to‘un’vowq’xr‘xrwpuoun’vk’woŽsn‹soroqmrmrmtnŽtnŽtn‹qk†rk†pi‡rj‡rj†riˆsk„qiofziauc\saZp]XnaXobZh\TdZQ`[RZYO^VM_VPdXRcTN`OMcPM_NF_PG[MD[KDXHBXGAWG>XG?WF?YD>YD>WC=VC;WC;WC;UA:WC_F>ZF9[K>^PC_LBeNFcNFeQIcPHaODdRFeUJcRGjYNufZhYNbSGaTGaTH`VI^UI\WI[XHZ[MTTJRRGTWLTWIVZKXbPV]NT[NT]OQ]LHYGOaNSgSPePPePQdRSdSUgUPbPM`MPcPWdS]gWcj^jpdloeqskutnvtmqofjh`qogutlurjoldfh]_bTZ_P^fY\fY_hW]iWYdS[fV^gW\gY[eYWbRXcR\jX[jXYjXXgU]hZcl_nthoqhomfpmieg]^cYU]QHUFJ]KPdPSgTQeRMcPKaOMbPZl]Œ|isc_k[ViYYm^Zk\ZiXYjWWjUUjTTlTSkSLiRNlVFeOEdOC`JC`HEbIA]D@ZBB\DE]HF^JFaPIeRHdPDaJB_GC`HIaOK^LH^LB`IDdLHfMLhOFdNFgRDgR@gP?fNFiSGhRD`JCaIIiOGhM>aF?_G@`F@`HB_KEaMGdOEdMHhPKkSNjTLfOLgPMjSIfNI_LI_LC^JEcJCaHC^JC_J@]E?]C;W@;ZB>^F;\D=]E@]GCaG@aFAeJ@dJ=`G>_GEbKB^GEaJFbKC`IEaJCaMHcOIfOIdLHfLHeLG^JDZG@UB8P>;S@9RA7T?4P<3O;9SA9T@ZC=ZC6V==XE>ZF;WD8TA6S=7T<7YA<\E;ZC:W@>ZEDaMC`I@_I?`KBbNBcM<^G>aF<]G;_I@cMAdMDhMAgOBiP@gNAdKCcKEaJ@aHBbJBbIDdKGhNIiODfNDdNCbMA`KDcODcPDdSIfSFeRCgQDiREgOCfMDcKEdOJjRKgPJhPCIALESABP>AO=ERAERBGSCFQALSCWXIg_QwgZk^„ka‡nc†oc„nb…oc…od‡nb†nb‡nc†lb‰pf‰oh‡qf‡oesgsgŒreŠsd‰sh‹qgŠqgŠqg‹qg‰rgŠqg‹shŠphŒrk‹qjˆngŒpiŒqirhrhŒre‹rfqfŽrgŽsiŒqgqi‰oh‹rh‹rhrhrhrhŽqhŒofqgrhrhŽrhqiŒrg‹pfŒqgŒqgsiŽphŒqg‹ofŒqgŒpg‹oh‹oh‹pf‹pf‹pf‹pfŒqg‹pfŠng‹ohˆle‰mf‹og‰ne‡od‡oc‰qeˆod†nb‰pd‹neŒof‹oe‰ndŠoe‡nd‹ngŠlf‹mh‰kfŠlhŠkhŠmg‰lg‹ni‹oh‹oh‹phŒofpgŒofpgpg‹neŒkbŒmd‹neŒnfŠng‰le‹ncŠnd‹neˆkbŒnhˆkeŠka‰icŠjd‰kfˆkd‡jaˆkbˆkb‰lcˆkb‰lc‰lcŒkbŒlc‰jaˆkb†kaˆndŠmdŠmdŠmdˆkbŠmd‹me‰lfŠkfŒlf‹leŠlf‰mf‹maŠlaŠkb‹lc‹ke‰icˆkb‹md‹lcŽmcŠja‹j`‰ic‰icˆhbˆhb‰ibˆfa†ib…ha‡jc…hbˆld‡lcˆja‰kb‰le‰lfˆkf‡jdˆle‰mfˆkfˆkfŠmhŠmiŒmjŒniŠlgŒnhŠmfŠmf‹ngŠmfŒoh‹neŒofpfŒqk‰mfŠngpiŒoh‹ngmgŽqjŠohqjpipjpjoipjoiphphŽnipkpkojŽnh’rnqiŒohŒohŽpkojojpiqh‘sjqhqfod‘qkoioiŽoiŒqj‹rkoiŽnhojslŽqjrkrirjŒohpiphqgpjŽnhoiŽnhoiŽnhpjoiqirlŽqkqjqipgpiŒohrjŽpkŽniŽniŽniŽoiŒohŒohŽqjŽqjŽqjŽqjŽpkrmsmslrk’untmtlqmrmsn‘toun‘un’up’up”wr’up’upsn‘uj‘tmrn‹plŒplŒplŒrl‹rlŽsnŠqjˆqkkf~mdzh`}jbyf^{e_wa[wd\q^VlZRgUNeVOcSLcTLaRI`PG^QG\RHYQGYPG[RIXLD[LF[ICYGB]F>\H@XE>VC=XB>[B>[D=[D^D?^B<^D=]E>aIA_IA_JC`KDfPHhNFeQDfVHn`RfVHfSKfTKbRI_RF\OC]RFZTE]XI^ZKa]NXVFXUETPEQODOOEMNDLQCLTCHSDGSFLYLN[NN]MRaPPcPN^MO^OOaRNbPMdQVhUYmXXlVYjV[jX\gY\gY\fWWbQ^gV`fWfi^nnbnnbrqhqogtpkrnhjh`ji`urjpogqpgji`df[`eU_fU[cW]eXVcP[eTYdRWdSXfUXhVTdSXdQZfS[fT\hV`lZeq^ipcnpfwskuqioldgd\]eWWaRJ[IF[HJbKJfONcMJaLF\JF]JI_OVi[erdena`l]XkYOfTPdRThSThRTiSTlTQmSNiOQlRKgOHeMFaME`HIbJG`ID^GB\ED_LC_JD_KCaOEbOC^KB_HFbJHeMLcRNaOJ`MDaLCdKHfMIdMCaKEdQAcOCfQDhODdPBaLAbJDaHFfKEfK@aFDeKIfOHdQGcOIeRJfOEaJBbJGdMIfOIcLIcLFcLFaMJ_LI^LD]KB_GA]I@[HA]IA]GC`G?[D>[D>^F9[C>^F?_GA]D?]DDcKCdK@`HCaJIcLGbKEaJB]F@]F@]FB_KD`MGaJF`IE`HA`EEYHBXE=VA7O=6O<8R@8T@7S?8T?9T?=XD?YFB`HC^IAZFAWE?UBAWEBXB?W@7Q:9U?>]E9ZA>ZF=ZE:UB6S>7T>:X??]DD`G@YB=T>?XCC^JEaJA^H?`K?cM@cL;]EA`I>aJBfPEiSDcMDdLAdLCfNFhPDfNGfNIfOEfLFfMBaHDdJEfKAbG?bI?aIAbMEdOEeOGfQDcSIdTHfSEjTGnUIlTGhSGiQHiPHhPIiSLiU=D9@H<@I;BL;EP?CN=GQAHSCKVFKVFPVEQWFUYH_[NobUzf]€l`ƒnc…pd†od‡pe‡odˆpd‰qeˆoeˆoe‰qf‰oh‡oh‹ohqiŽqg‹qdŒreŠqgŒsi‹rhŠqg‹rhŒrh‹rhtjŠqgŒsh‹rgŠrgŽqgŒqgrhrhrgŠrfpeŽrhpgrh‹qfrgŒsiŒsiŒsiŽsiŒqg‹pgqhqhrh‰qgqg‹of‹pg‹pfrhqhŽrgqfŠof‹pf‹pf‹of‰mfˆle‰mfŠnhŠof‹pfŒpgŠpe‰od‰nc‰oc‰ocˆmb‡laˆldˆld‰me‰me‰me‰nf‹ne‹ne‹neŠoe‹pfŠoe‹ng‹ogŒnh‰lf‹lhŠlgˆkf‹nh‹ogŒog‹of‹pfpgŒofŒofŒof‹neŠmdŒlcŒmd‰lcŠmd‰jdŠjd‰ld‰ldˆkb‰lcˆjbˆld‹kfŠjdˆhcˆje‰kc‰mbˆkbˆkbˆkb‡jaˆkb‰ldnb‹mbŒmd‰kb‰jb‹meŠmdŠme‰le‰ld†iaŠmc‡ifˆkf‰jcŠjcˆkc‡jdŠkaˆi`ŠjbŠkbŠkaˆi_‡jaŠlc‰jaŠja‡jaŠlb‰jd‰jdˆjcˆjc†haˆjc†ia†ib†ibˆld†id‰lg‰lf‰mfŠmf‹ng‰mfˆleŠngŠng‰mfŠngŒpiŒoiŒmjŠkiojŒni‹mhpj‹mfpipiŽqhrhrhŒpi‹ogqjŽpipiŒphŽohrksl‹ohŒohpjpjpjmgpineŽofmhoimgŽnhŽnioiŒohŒohojŽqkŒnjnjŒpjŒpi‹ogqiŒpg‹oeŒohoioinhŒpiqj‘oinhoipiŒohŽrkŽqhŽqioipiŒogŒpfpjpjpjpjpjpjŒojpiŽqjŽrkqjŽsiogŽqhrhŽqjŽqjŽqjŽmkŽpkŽplqjphqgrkŒqiŽrlslqjqjqjqjŽrk’voslqjrlŒqkŽrl‹qj‰qhŠrj‡pjˆpj‡pi…oi‡pj…lf‡og†nh„oj„oj„oj€idjd€ic~ga}gavc\raZn^Ul[RkXPkWPjTNfPJgPJcLF`LF^LD_MFYHB[JA[IAZH?\G?[JAXH?UG>UE>WE?ZHAYE?[FA\C?[F@YG@ZG@\FA]D?bIAaJCcMEfPHeMGhOJfPHdPHdSJfYOcWN]RH\RK]QF[PCa]LkjX`ZKXRIVSGRRDPRDOTELTCNVGOXHLWGGSAHUCHUCHTFIUHESFETFCUDEVDBVCDWFF[JMaPOcQSgU_q^RcRScRWhWVjXSiUZjX]mZ^mZ`l\fm`fi_ej_dh\dhZfj\gi]lkaombrpenmajj_lkbjkacj^ek^dj]eh\ek_ci]_g[^gW\gVVaSS_PVcPZdSTaOSaOTdSTdSTbQXfRVcOWbQ[fT_iXfp_gnbhlamlbpnedf[Y_RRbNL_KG_KJaMIdNJcNH_KH_LJ_LI_LNeRVlX_m_cn_\hWMcPIdOKcOQiRPiRPiPPgQPiRMfOPgNLeNIdOFaMGdNJfNIcKIcMGbNGbNKfREcLB_JDaLC`JD_HGaJJcLKdRJ`ME]ID`KBbKB^ID\IB]J?]I?_LBbMAaH@aLDdOCcK@`HGfLMlRFeKGdLJgQIdPGbNGbMIeNB`ICcKFfNFcLB^GE_JA^KD_LI_LG]LE_MFbLC]IB[IE^LD^KDcLC\IA]F=]E<^F<^F?_FF`HHcLGcNEaLE`KH`MJaKKdMLfOHdNHdMGdLFbNA\IF`JD_HC]E?\BAYF=VA8R<6S=9VA9VA?[H@[H=YB>YA>YC?YE@\EB]EAYB;R<;R?;T@;T=6Q:3O88T=:X@8W?<]D9YD6S>5R=6T;:W?:[@?\C;S=@ZDC_KKdMLhRDcOCgQEhQAaIDbIBbKEgRGiSJhQGbKCaJFdLHgOEcLCdLAbJ@aI?`G=^F>`F?`G;]C=`E<^E=aH@cJAeMCgPCgSIgTIhTJoXIoWKnTNnZLmWIkSNmVKiUIgVBI>CK@CM>CN=CN>DO?HTDJUDOZJR]M`cQ\aN[^N`_RkaVue[{ja‚pdƒpa‡qd‡pe‰ogˆpdŠreŠqgˆoeŠqf‹qk‰qk‹pi‹nhŒofqg‰pd‰pfŠqf‹rh‹rh‹rhŠqgŒthŠrf‰rf‹sgŠrf‰rfrgshŽsitjŒskŒrjpipiŒofŽqh‹qeŒrg‰pf‹qgŠqgsiqh‹ogqhof‹pg‰ofŠqfŒqg‹oiŒqh‹pfŒof‹oc‰nc‹ofŒqgŒqg‹pf‰mfŠngŠng‰mfŠof‰ndŠoeˆob‰oc‰oc‰ocˆnb‰oc‡l`ˆke‰le‰le‡jc‰leŠmf‹ne‹ne‰lc‹ofŠpfŠnd‹neŒofŠngŒogoh‹nhohpgŽofneod‹nc‹pg‹pf‰ndŠoeŠoeˆmcŒmdŠmd‰ndˆjbŽlfŽkeˆle‡kd†kaˆmc‡laˆmbŠjdŠjdˆhcˆjeˆlcˆla‰lcˆkbˆkc‡jbˆkb‰lc‰mbŠnbŒnd‹kbŠjbŒmeŠnd‰ld‰lf‰ke‡jbˆkb‡kd‡kb‰k^‰l_…k_…j_‡gaˆha‡i`‡i^ˆk`ˆk^‡jaˆj`‰i`‹lc†ja„lb‰le‰keˆkd‡jcˆkdˆkd‡k`†i`‡jcˆje…hdˆkg‰lgˆlgˆle‹ngof‹ld‰mgŠng‰ndŠoe‹qfŒqfŒmj‹liŒmjojoj‰lgŽnhoipiŽrhshsiqjŒpiqjpjpipipjqjŽqjqj‹ogmgojŽnhoiŽofŽofŽofpgpgneŽofŒmdŽofoh‹ng‹mhŠmgoknk‹oj‹nj‹oi‹oi‹phŒpiŠngpiojoiohŒohnhnhoiŠmfpiŽrkŽqhrjŽqjŽqjŒogŽqg’rloioioj‘qk‘qkpkpl‘tmslŽsiŽrirhŽsirhŒqgqjŠngŽplqmrmŽrjŒrhŒrhŒpiŒpiqjqjŠogŒph‹ohqirkpjŠoh‰mfˆph‰oi†od„nd„od‚na|jc|jcxf_wg`wg`wg_ue]se_sf`xlfvi`j\SmYRjVOlVPhTNfUO^RJ\MC_NE]JB]JC`IC]F@`F@]E>[D>ZE?[F@YF>VI?XG>ZH?\G?`JC\HA[G@aME`KCbLFcNHbMFcMHbPK]OH^OHaQGaMFbNCcQGiYQfWNaQIbPI]OF[PFYRH[XMRSENSEOTIQTGRUFS[JOZHPVEMXKJWGJYHDXFD\IC[GFYIDXFEZIH]IF\IC[GD]HE]HC[HE\JD_HC^ED^GD]HJbPNfUPhTTmX^mX[hWYeTWeTTeTTiTYiXYiXXfUak\hmallclndhh^klaik`ei^dh^hk^eh\dh\bi\]eX_h[ZfX\gY\eW[dXZdWVdVVdWXgUVeSQ^OO]LTcNU`MUcPUeSTdQP_OO]LM`LO_NScQYgVYfU[gVXgW[eX_fZag\YcUTbQOeMJcLGbKFbNMeQNaPI_LMaNRfRReSVjWXmZ[k]WdSS`PH`IFcKIgNOlSPlSOiQMcMPePTgTPiOMgOHeQIiTGiSGiRLcLMePJcQFaOGcPCcKC`HEcJHdKE`GJbKIaKFaNKaNE]JC^KD_LD\IC[J>YI>ZH?[IA]H@]E>^GIiQEfMDcKIhOLjQFdKIfPF`NHcOIeMGdJFdLEcKCdLFhOBbJB`HF`NEbNEaMG_MH_MD_MD`KC\JH`NI`OD_LA_ID^JC^KCbJBcL>aGBbILfPJcOHaMMdRPeSPcRPfQMdNMfOMjSNjSLiRFbNE_KD_IE]FC]E9Y@7WA=WFA[HB]EA[DB\DD\FD^FC[D=T>;S=8YB9UB7S>7T<:W>5[>8Z?<[AA^FEcNDdQH`JB]H>^ICfPAdMBaJC`G?^E<_GDdMKgOIbJHbLGbKB^G;YB=^F9]E<^F<^F9[C<^E:^C:]D=`D=aFHRFEOBCN@DN>FQ@KVBS[HZ_MacSheWffWdeUfeSlfStiX}m`odƒod„pfˆrg‰pfˆpd‰qeŠrf‰pf‰pf‰peˆrg‹pgŒqgŒqg‹qgŠshŠqgŠqg‹sg‹tgŠreŠseŒrdŒrfthrgŒpgŒqfsgtfŽsirirgsfriqjŒohŽqkŽqjŒpi‹pi‡ohˆoiŒoiŽokmiŽqipiŒnhŒoiŽqhrfrh‹pfŒqgŒqg‹pf‰ndˆpcŠqeŒof‹neŒoe‹qf‰je‰kf‹mgŠmf‰ld‰ld‰lc‰lc‹ne‹mdŠjbŒlcˆkd‰leˆkd‡jc‰le‹ngŒmdŒkfmgmhŒmdŒncŒmdneŒmdqfoeod‹pfŠneŒmdŽpg‹md‹ne‰ndŠoeˆmc‰nd‰nd‡lb…mfˆod‰nd‰lcŠla‰k`ˆkdˆka‡k`ˆla‡kaˆjcˆmcˆkb‡jb‡jc‰ic‰ic‡jcˆjd†hc†hbˆld‡ja‰jaˆlcˆmc†jcˆkd‹kdŠmc‰mbŠmd‡kb…ib…ib‡kd†h`†jaˆi`ˆj_‰la†j_‡kb…ib…ib†j`‡l_‡jc‡jb†jaˆkb‰lbˆla‡ma†ka‡lbˆlc‰mgˆmfˆi`‰ja‡jc‰le‰je‰lgŠme‰leŠmf‹ngŽqh‹ofngŒlf‹ngŒohŽqjŽrk‹nj‹ojpjŽpkŒoipiŽnfphoi‘qk‘qkqlogqhqhqh‘rhpgpgŒohpkoiŽnfŽpeŽmhŽmgŒohŒohŒohpiŒohnhoiŽmhlf‘ojneŒlfŒoh‹mhŽninioiŒphŒqf‹peŒnfŽmgŠmfpiŒofpgŒofŒofojoj‘qkpiŽqjŽrkŽpkqmojpipipi’sjripg’sj’rl‘qlsjŽtjslslŽuntmŽrksmŽqjŽrlŒqjŠrj‹plŒpjŽqlqjpiŽrh‰nd‰ndŠng†mf†mg„lfˆlgˆlh…kg„kf‚je~jc~lb~nbxi^wg\tdYsdYqc[n`Yk`Xi`Wj`Xf^UdYTdXSfXRzjefUP^LF_KE`HB`HB_IA]IA[J@\JC[G@[E?\D>^E>^D>\D>_E?aHAbJDaKF`MFdMGfOHePHhSKgTHfSHjUJjVIgSJiVOjZUdYTaWL`ZM[WLWVJWQGXOFVPBYPD]TGTODRSHKRGNWFIQCJVHKZHK[FJ[CFXGHZKE[LE[ICYDK^GJcILdLF^GE]GE]FE]FC^HFaMGbNGaMH`OIaPOcQLbPIcQJdQKePLeMJdMLfOOiSRkWRlXUlZ`j^]fZYcVWbUVfWXjXWjWXfUXcU\dY\eY`j^fk_io`gl]agX]eYV_U[eR]gU^fXWaTVcTSeSWdTVaQYbQ^hWYfVRbQLdQRfUSdSJ_KMaNN_LRdLQaMPbQI\LG[IL`MMbLM`KUhSSgQOgPLhQMgRPhSUhVUhVUgTOcMLiNIgMA^GIcONfQPfQNaPObRQdUQdTTfTShRK`MG]JE]JF`IIeKLhLSmPRlSQkSMfSShSUiSRfQNgPMhOMjSOhVPgXPcQL`MMcQG_MIbPHaQM`OMbLMdIGaFDaGCbIHbNJdNHcKD^FE`GD_G@ZG?ZG=[E@_GA_EB_E@bJIhPJfOFaJFbKFbKJhNJfLHeLJeNKdQI`NEeRDeP@cMCdODaJHeNJiQGeOGaNF^LG`PG_PD[JF^LH`NK`NM_OL^MPaSQbUQdSLbPLfRKhTTdWXdX^fVafW_fX[eXXeUTbRSePPePLfSGdRI`NF\KH]JE]IAZF;VA=TE?WF?WF=VC>YD@\EA^H@[FCZFCXE=U?AZCB^GAYBU=;T>9S@8UA9S@8P<=T>7T:4T;:X=:Y?9YA;[F>[H@[I>^F>`H>bJ?bJCaJF`IAZIA]GB^F@_D>]C?^D?ZD;ZB>^FFaKGcLFeMCbJC_H@[D?YB=[D>`H;_H=\G=[F<\G8_F6aF:aG=bH>eL;eL;cL?dOHhTFhTDiT@fPBgP@dNEeR>bLAeOBfPAbJA]HAKDM@FPALTCX]IcdRgeTlhZkhYnjZpjZvk\yj[~lb‚pe…qf†qfˆrg‰pf‰reˆpd‰qeˆoe‹rh‹qgˆrg‹pgŒqgŒqgŒrh‰sh‹rg‹rgŒuh‹shŠrgŠrg‹qeŒqfŒrfŒqg‹pfŒpfrhriŽrk‹ohŒqfŒrfŒphri‹phqiŒph‹neŠngŠngŠphŠphŒpgŽohrfŒoeqfŠncrcsd‹pe‹pf‹pf‹pf‰ndˆmc…ma†mbˆkc‰ldŠmdˆnbŠnd†jaŠmc‰lbŠna‹oc‰mdŠmdŠmd‹neŒlcneŠmgŠmgŠmfŠmgŠmf‹ngoeŒmgŒmf‹meŠlb‹pbmfŒldŽngŒmdndŒndŠoeŠoe‹lcmdŒneŒof‰ndˆmcˆmcˆnc‡lb‡lb‡ldˆnc‡mb‡kbŠpd‰mb‰ke‰ldˆlb‰lb‡jd‰ke†l`†j_‡j`ˆja‰ja‰jb†jc‡ic‡idˆje‰lcˆlb‰ja‡kbˆmb‡kd†kcŠjd‡kcˆkc‰lc‡ka†ka„h_‡jc…h`†i_‡i`†g^ˆj`‡ka†jc…ib…ib„j^†l`‡jc‡jc‡ja‰lcˆlbˆka‡kc†kb‡kd‰mf‡keˆlfŒlcŠjcŠmf‰le‰le‹oiˆkbŠmeŠme‹ohrlŒoioiŽnhoipipiŒpiŠojŒojŽqlojpiŒpipg‘qj‘qk’qk‘pk‘qlqiphŽogngŽohŽogŒngŽnhŽni‘pj‘ohpeŽmhŽnhŒohohŒpiqjŒohŒmgŒlfmgŽnh’pkmd‹lf‹ngŠmf‹kfŽmiŒoh‹pgŒqg‰ndŒmfŽnh‹mfŒngnhŒneŒnfofnipipjŽqjsl‘smql‘snqlrkqjqksjsj‘uk‘uo‘tm‘un’ulsl’un’vo‘tmsnrltmslskrj‰rhŒoiŠni‰oh‰ng‡lfˆmg„ic‚hbjb}ha|ic|id|ha{f`yc^{fava[q]Vn`WocYk`Vj_Uf[Re[QdYQaVM`UM^TL`VM\RJZNHXLF]OI`OHZIBYG?YE?ZD>[D>ZD?ZG?XG>\G@^JB^JB\H@`KCaNDcPFjVLgTJfTJdVKbVKeVNfWNh[QeYNdXLcWKdXMbWL`VL`XO]\PZZOXZKW]MPZINWJMSEKPCKRCJRCKUDHTDHWFIWFJYGIXGGYHK`NMbMLaLJ^LLaNJbOIaNMcMOfMNgMKeMIcKHbLG`IHbJFcMIcPIdQLdPMdRVn\_r_PgULeSNgVNhSMhPRhTQiUQiVRjWSkXSiWVjZWiYUhVViVUiWRiUSiTReTQaSQ^QTbUXgW[gY]iZ^hXZdUWaTU`TVfQWeRVdSScSReSMdPOcQRcQXeUZdUVdSOaNOcRUeUSbPMaNLbPMaLJ_IK`MJaMH^KH`KMfOMdMLbKRfQOgQKdOMgRMlTQmWQjWSkXPiTLfNLgNGdKGbOLfSNeSPdQMbQLaPLbQKcOIcMGaHH_HG^HH^KNcOOgORiPUhPThQRgRQeSTgTUgTRePOfOLdNLdMKcPK_PH^KJaMLdQG`NGcPJfSMdUKbOHaJIcKC`IDaLC_GEbKB^GD`IB^GA]ED\GD]HB^GC_HA^FD_HHeOIfPJdNH`KLcNPhRRkSPgPMcMNcONaNM`NKcRLfRJcOKcPOcPTfQZiVUdRSbPT`PXdVXdWQeSOcQM_NO`OVcSZeU`jYajY]fV[fV\jYWhVXeW^hZfj\gi[gi^dh_efZdgXchX\eUXgVPcUUeTO`NN_LI[GH\EE\FBZFC\J@[F=YC[A:V<;U=6R<6Q>3R?4O;6N::T=;W?:ZA:YB9ZC=_H?`K?_JB_KAbJ?aI=aICdLEcLGaKA]L\D=^D:V?7YA<\D@\E?[D>^F@_G>ZCA[D@\E;[C9]E<]E:[D:ZC7[C6_D4aE:dI>cJ?eLeM?`KD`MAaNCeP?dNAdO=aJ?`I=`HAeLBfNDeMA`HFRAGRBHRBGQAGOCNVHPWF\^JhdSmgVofXogXtk]{pb€obƒnbƒpe…qf„pe‡qfˆrg†peŠrfŠrf‹sgŠqgˆoeŠqg‰shŒqgrhŒqg‹qg‰sh‹sg‰re‰qf‹rhŠphŠpi‰pdŠrfŠqfŠpfŒrh‰qgŠmi‹niŠmhŒpiŒqg‹qeˆpdŒqfŠpdŽthpfqg‹mfŠnf‰pf‹sg‰pe‰oc‹odŒoe‹ofŒofŒqdqdŠoeŒqg‹pf‹pf‰nd‡lb†oc†laˆldˆkdŠmd†l`‰lbˆkaŠmdŠncŠnb‹od‰nd‰nd‰lc‹neŠnd‹lb‰lc‰lc‹neŠmeŒofŒogŠqe‹qe‰ocˆnb‰ocŠpdŠkfŠlfŒngŠmf‹nf‹neŠoeŒpf‹ldŒmdŒneŠmdŠoeˆmc‰lc‡kaˆlcˆlbˆkd‰lc‰lc‡laŠoc…la‰kfˆke‰ld‰ldˆke‰kfˆma†j_†j_‰la‰k`ˆj_…h_…ha…hcˆje‡jb†i`‰ja‡kb†ka†jc…ib‡ga†ic‡jb†ib‡ja†ka†l`†ib†ib…ha†i`†i`†i`†jc†jc„ha†jc‡lb‡lbˆkd‡jc‡jcŠmc‡jaˆkbˆle‡kdˆkeˆkf‡jeˆkf‰id‹ke‹ngŠmfŠmfŠng‹odŠndŒofŒohŽpkŽpkŽnhoipirkŒoh‹oh‰pj‹qkŒojŒpiŒpiŒpiofŽqipirkoiqloioiŽnhŒlfŽnhmgmgŽoinh‘oipgneŒmgŒoh‹ngŒoh‹ng‰le‹ng‹ng‹ngoioiŽnhngŠmf‹ohŠngŠmfŽnhŒniŒohŒqgrhŒohŽnioiŽngoiohŽofŽofpirkrkŽpjqm‘snrm’tormslslslŽti‘wl’vo‘un’vo‘uo“vo’tn’un‘un‘tmŒpiŒqlqkrl‹qgˆpd†oc‡ndˆnf‡mfƒkega~d`{d]xb[vb]tc]qb]pc\nbXl]Vk[UkVRfSLeRJdVMbTM`RJ^SK]SK]TJ]OIYJCZJC\KD[KDWIBWG@WF?XF?[GA\H?\F>]HB`JD`JE^LC_MEbRIeTIbRGaRFbVIaVJ`UIcWIf\N_WI]XIZVGWWH\[M\[N\[MYZLVXIXYKWXLSVHQVHS\KQ^ML]LL_JNbLMdPIaNCZFG[JH[IF\IC_KDbJIaJMbKG^HF`JIcOOiXNiVNgUQhTQjWRlVQkURlURjRMjPOiRLePMfRMfQLgPJgPHcOHcOLeQThWcveZn\OfTOeSLeQOhSOiQRhUShVTgVReTRgUNcROiURkWTjVSjUQiSOiRMiPOfRReTObRQdTQfTQeSSfSTfRRcRP`ORaSXhSXhTRaPObPNcQMcPMcPN`NQ]LWbRVcQRaOUdTXdRUaONcPLfOGbKB\HD^JFaMHdMKgOMjQJcKJdLKdMJdMHcONiUPpXMjUMgUSm[MhTGdMIcKKeOKgSPhVOfTM`OJ`MH_MG`MGbNEcKBaFE_GG`IJeNRgURgTUiUUhTTgSQdSSfVSiWSgUQfPOeOKcLJbNH^LK^LG_LMdQJcOIdQKeTJfSIcRG_MG`JKfOIdNGbNGbIGaIF_IEaJGaMF_KJ`JF^HA]EC_LD_KIdPMfRNdQReRTeSVhVViVXhTVeRVcQYfUYgUYeSXfVZgWYfU\fUagVdhWiiYhhXdeW`cUaeXdh\^kZYeU[gV[eVbgXceVjhYliYml^ml]gf[ceYahXfjZii[mi^nh`ogbvmdrj_hcWcbVci\bl`cq_]iWWbOUePN`KJ_HF_GC_GA]F?\E?\E?\E=YFYD=ZB?^C:[@;[?:X?7S=7U@4R>8T@9UA>[DA_G>\I=\IAaNCdOA`L@aIA_G<^E;^EAcJEcLA]G?[J`HFcMA]F=YB;YB8ZB5ZB;\CA_F<[D:^D:cH9hI@kP?gL>eL?gNBhQFdOD`MCaM?`J>_J=_G>^F?`F@dJBgM@eKDfNEfNLWGLWGMUEMUDPUIY]N[]MedRqiXujYuj\ti[xk^qd„pe†pe…pe„od‡qf‡qfˆrg†pe‰qeŠrfŠrfˆoe‹rh‰pfˆrg‹qgrhrhŒqgŠtiŠrfŠrf‰pfŠqg‰oi‰oh‰qf‰qfŠqgŠqgŠphŠpi‹mkŠmh‹ni‹ohŒqfŠoeŠrf‰qeŠqe‹qeŠqdŒqeofˆlb‡ndˆpdˆqc‰pbŠngŒmhŠlgŒni‹nfŠmd‹pf‹pfŠoe‹pf‰nd‰nd‡oe…jb‡jdˆkd‹nfŠne‡jdˆkfˆlfˆmeŠmg‰neŠoe‡lbˆmcˆkaŠmd‰lc‰lcŠmd‰lc‰lc‰lcŠmd‹qe‰oc‰oc‰oc‰oc‹qf‹mgˆkeŠmf‹ngŠme‹ne‰ndŠneŒmdŒmdŒne‰lc‡lbˆmc‰lc‡jaŠlcŠkbŠjdŠlc‰lcˆmc…l`†ob‰ld‰lfŠlg‰kfˆkdˆkd†lb†ia†i`†h_Šla‰k`‡ja…h`ˆjc‡jcˆkc†i`‰ja†ja…j`‡kd„ha‰ic‡id†ib‡jc‡jc‡lb‡la†ib‡jc‡kc‡jdˆke…ic†id†jc†jc‡lb†ka‡lb‰leˆkd‰le‰le‰lc‡ja‡kd‡kdŠmh‰lgˆkfˆkgŠjd‹keŠmf‹ngŠmf‹og‹odŒpe‹neŒphŽokojŽnhoiŒohpipiŒpiŠpjŠniŒpi‹ohqjoh‹ne‹ogŽqjŽpioiŽpkŽngŽnhoiŒlfmgmgmhoimgneofneŒngŒohŠmfŠmf‹ngŠmf‹mg‰le‰mfmgŒmgŽmh‹ngŒoi‰mfŠoe‹oeŒpgŽniŽqjriŒqhŒpiŽpkpkojpjpj’qlqirkskslrmrmrmrm‘rmsnslslŽtm“vm‘tn“vo’un“up”vq’vo“xqsltmtm‹qj‡oi…ng…lb…nd€l`~l^j_}g^iazb\v_Yq[VoYUjVQiVQfVPbUMbVN_VL`ULbSLcQIaMEaKC]IB]IB_MF_NGZLDZME\KB[G?^JA`IA]JB[I@]IA`LC`KCbODbPEcOBcQHcSJcUK`TI_TGbXJ]YI\XIXWG\[LWZITXGXYGWZGSYFQYDP[FR\HO[JO\KR_NO]KO_LO_LL\JO]MN^LNbNKcLMiPMiRLiROnVMjVJgRIeQLdPJeREeMJhPOiQRhPJeOKgPMkVMmWPmZPkYSmYUpXTnWTmVQkUOkTNkRRjSQgTPeRRiUQmVOlUKeRKdPNfRSgUXjYQhVPfSNdQNcPPgTPjVSiWTiXWkXQdQLbNJaMMfPPhRUiSQfPPgONgOKhPOjSOhTNfQLgQKhPHdLLcPMdQMaPK`NOdR]jXVgQNbLMaKOdNOfPRfPM]KPZJV^NXcRZgRUbPXaQTaOQgQJgPHdMB]JEbLGdMJhPKiPGfMLeMIcKFbKIeOKeQNiTPkUMeSQgUOeSKbPLfONeRNgRNgSMfQNfSObQLcNJaNIcOIdPGeLDbIFcJHeMNhQNgSPgTRhVSfUTgVRdTShUTjVRiWRiSRkUNgTOiTNeRPfSQePSfRRgTRgTOfTMeSPfRRgQThQTiQPfNJcMPbLOcNQfPPeSOePNcQPfPKbLHbNHcONfUQiXWgW[hX^iY`hX^gXZeU^eVcfXdhXfkZgjYehWcdVcdVihZgdVieVmfWphYnh[edVccUbaTddVghZhj\hj\ii[fdVjfYri[xoaxobum`ph]lbXeeVheXoh[sk`vldthcoe[lcZg`Xa`V\bV^h[[kY\jX\jY_nYYkVWiUQeNI`HB]D?\CA\E@[C?YE>YGZE?]E=[A<\A;]B;[C=]F=]H<[E>ZF@[GB^GB^GB]GB_GC_L?^K@aLBcN?aH>[D=ZC9X@?^G@bJ=]E=]F?\K?]K=\G<\D<^F;\G8XA6[B9]E=^F;[C@dLFdMDbK=[D;[C:]E9^FCaHBcJBdLAeK=fK=hJBlQDjQ@fMAiPAfOEbNE`LA_JB`L=`G<]EBbJDeKDfLAfL@dKDhPGgOP\LQ\MQXJQWGWXJ^^NbbPqlZwm_zla|pe|ma}laƒqd…ocˆpd…od…od„nc†peˆrg‡qf‰pdˆpe‰qeŠpg‰pfˆoe‡qf‰oeŠoeŒpgŒqg‰sg‹qi‰ogŠphˆoe‰og‰ogˆoe‰pf‰pfŠph‰nh†mf‹mi‰mgŒpiqgŠof‹oh‰qfŠqfˆpe‰od‰od‹qfŒnfŠne‡nd‡oc‰peˆndˆlf‰lgˆkgˆkg‰mfŠng‰nd‰ndˆmc‰nc‰ndˆmc…mc…jb†hb‰lf‰leŠofˆlfŠnhŠmh‰le‰meˆld‰oeˆmcˆmcˆmc‰kb‹ne‰lcŠmd‰lcˆkb‰lcˆkbŠneˆma‰ncˆma‡kbŠmf‰ldˆjbŠmeŠmcˆkb‰lbŠnhˆle‰jdŠjdŒmgˆke‰nd‰nd‰lcŠlcŒlc‰jaˆldˆja‰lc†la†l`†l`ˆkaˆkdŠlfˆke‡jcˆlb…ic†ic‡ja‡ia‡h_ˆi`†k_†i_†ib†ib…h`„h_…f]ƒh^„i_…hb…haˆhb‡jd‰le‡jc†jb‡jd†jd†i`ˆkdˆke‡kd‡je…je†id†jd†kc†ka‡lc‡je‰kf‡jd‰leˆkd‰leˆkc‰me‹pgŠng‰mf‰lfŠngŒlgŒlfpiŒohŒngŠpeŒoeŒogŒogoiŽpjpjŽnhoipiŒohŒohŠngŒoiŠnhohohŒnfnd‹nf‹nfohŒohŒnh‹mhmgmhmhmhmglg‹mhŠmfofŠmd‰lbmg‹ngŠmf‰le‹ngmg‹leŠnf‹ngŒohŠogŒohŠkeŒph‹oh‰pfˆofŠpe‹peŽniŽoiqjŒoiŒojŽplpkpk‘rmqjrk‘smukum’vosnrmqn‘sn’tosnrktmtm‰qiŠpiŒrk‹qlrmtoŽsnŠrk‹rk‰qj…phj_|j`zf]{h]xfZteXrcUp^Wn[TjVNkVNkSLfOIaMG`LF_LE]KC_MF^MFYNC\NE\KDaNG\H@^F`H?_FB`FFbLC_HB^GD`IB^GB]H@\FA^HDcMDeLA^F?]DZD>^F;[C;^F?bJC`N?_J?`H<_F>bI=aH=_G8_F9aH<^F?`I`H?aIDeNFgNGeMFfOBfN@cKFiQGiQR`RU]QZ_RZ]Pb_OgeSlhWtl^xmb}ne}pg~mdmb‚maƒn`ˆqcˆoe†mc‡pe‡qfˆrg…odˆpd‡pcˆpdˆoeˆoe‰ofˆrg‰oeŠoe‹pf‹pg†pe‰nhŠpi‡nhˆoe‰pfŠrf‡oe‰pf…lbˆogˆofˆof‰mf‹pg‹qe‹qe‰neŠmg‰ogˆodˆoeŠpfŠoe‹pf‹pdŠod‡nd‡mf‰mfˆkd‡lc‰mdˆleˆmd‰mcˆnaŠoe‰nd‰nd‰nd‡lb†ka‡mc†ke‡idˆkf‹ng‰ndŠofŠoe‡mbˆnbˆnaˆna‡ndˆmc‡lb‡lbˆkb‰lc‰lcŠmd‰lcŠmdŠmdŠmdŠme‰lc‰mb‰lc‰keŠjg‡kcˆmc†kaˆnb‡ma‡m`‰mfˆle‰hcŠjdŠkdˆkcˆncˆmb‰lc‹lcŒlckbˆmeˆmc‡lbˆmcˆma‡k`ˆma‰mc‡jb‡jc‡j`‡ka…hd†gc†hc†icˆhbˆha†k_‡j`†ib‡jc…h`‡i`†g_…i_…j`…ib†jc‡ib†i`ˆkc‡jc‡id†id…hc†ia‡jcˆleˆkf†je†lf†ie‡jdˆmcˆmc‡lc‡je‡idŠkg‰le‰leŠmf‹ngŠpeŒqgŠpf‹pfŠngŠngmhŽnipipj‹ne‰md‹nhŒoh‹ngpipgŒofŽnhnhŽqjpiŒpi‹ngohmgmgŽnhlcŒkbŒpfŠnfŠng‹ohŒoi‹ninimiŽnimhŒkfŠkf‰lgˆlg‰ne‰lb‰ld‹mgŠohˆleŠmfŒohmg‹lfŒoh‹pi‹ngpipiŽpiŒohŠpg‰qfŠqgthŽshokpjqjrkqkplŽpkql‘to‘smsltmukvl’vosnpmqnqlrlŽpk‰ph†ng…og~kc}kb}jc}jc~kd~kd„mg€ic~ibzd[ubWsaVl^Ql]Pl\OiYMhYMdXKcUNaQJ^MF_JBbKBaJ?]JB[H@YG>]I@_K@_LA\LAbPGcPIhRKeMEhOFdOEgTIhUJdSHcUI`UHcWLcVKdVLdVL`WL[WK^XJ]XJWXHW[JU\JWaLS_LTcORgPPhPJcKIbJHaJKdLMhOPkRMhPNiROhTOjVMiUNiWKeRQjUQnUNkSMjSNkTPmYPnYRrYQnUUpXTnVToWRnWWmZUkXXn[TkYTm[Tm[NmVRoYVmZQiUQlYMlXTkYRjWQjSPjSPgTTiWKjVQlYOiSPjSRmYNiXOiQWkXSeRRdSSgTJcONeOOdQI_LD]IG_ME^LL`PPcRPcNLaKNePNgTHdNJcMMcLJ`HJdLHfKG`KIaMHaKFaJEbKFgNHfLFdKDaIDbIEcIGgLKgNMhPMfRLgSKhRKjRNgSGdLAbGEhMGjPCfKFaHG]IG[II\LLcNIcKK]JKYFK]GHcKBcKCdKEaJFbIJeLKeLQiSVlZSiVNeROiSOiSNgNNfLMhSOhUQhYMdUOgSMhTPdRNdMMgNOiPTlTVkUWmTUjTYlZSgYWh[WgY_hYaiY^iV`kX`m[al\bj_cj\hmYhlXhnZryfmwc`kXdo^dn^hq_kp\_jV]hT[fRVcRZgV^lZkj[kk[lk^gi[^eV[eTecUedVegWgkZgkYbiUbiY`eVdkZjo^mn^nm]gg\kg\lg\nh]ng]oi^qh_tkbsj`ri[ri[qfXn_Vi\Rd[Nh_RodWpeXnbUlcVibUkeXpi\ndWvcZyg^wkaxndvlbwmctmblf[nk]rk^xpbyn`xkcpd\lcVmdWrh]si`peWmcXkd[hg]`fWZgU\h[ai\hm_fhYcdVaaR_eVXaRSbQSfQQdMSbMLbID\EA\GB]IF_LF]IC`IFcMBbM?aHAaGEbHGcKEaJE`IFbKD_J@[GB^EA^ECaH@^EB^FC_FB^G?\E;YB;[C>aI>bJ>_K?`J>aHAgK>dIBgMAfM>fM>fMBeN?cK9bI>bJ=`H;^FAcKBcKEfMCfNAeP?cM=bK>bJAfLAfLEfM?cK:bI;aICcNIdQEeOBeMCeNDgOEgNGcQCbNDgRDhRBfNFiQXaRZaQddVifXrhVwk\yj`|meodqaƒpdndld~la‚naˆra…pg‡qf‡qf‰qeˆpdˆpc‰ndŠneŠpdŠpdŠpdŠpc†rf‰si‡ph‰ohŠqh‹qf‰pfŠpf‹pfŒpf‹neqh‹pf‰od†naˆpdˆpb‹qcŠoeŠoe‹pfŒohˆle‰mg‰ofŠseˆqc‡ne‡mf‡oc‡pf‡odˆpf‡lb‰lc‰md†lf‰nh†mdˆmcˆmb‰oc„mcˆndŠoeˆkb‡ka†mc†nb†ka‹ni‰kfŠlf‹ngŠod‰ndŠne†kbˆmbˆmc‰leŠleŠncŠnbˆkd‰le‰lc‰nd‡mc‰oe‰ndŠmd‰oaˆobˆnb‡ma†kb†lb†i_ˆlb†ka‰nd†lb…mb‰na‡ja‰lc‡ka†i_‰m`‡ld‡kd‡jbˆkb‰jaŠlaˆkb‰kb‰lcˆkb‡jaˆkbˆkc‡jb‡j`†j_†h`‡jc‡iaˆjb‡h_ˆh_†i_†i`‡i`…h_†i_‡ka†ka‡ka‡l`†ia‡ibˆhc†ia‰ncˆiaˆja‡j`‰le‡jc…ia‡idˆjeˆkeˆkd‰le‰leŠje‰kfˆkf‰mgˆkdŠle‰le‹ngŒohŒohpiŒohŒofŒofŒofpgŒof‹ndoingojŽoeŽofnepfneneŒmdne‹neŠmfŒoh‹ofŽofofŽpgŒph‹ngŒohŒoh‹ng‹mf‹ohŒng‹lfŒmfŒngŠngŠohˆleŠng‰jaŠlcŠnd‰kbˆlc‰nd‰nd‰mcndŒlf‹jdŒlfŽnhmgŽnhpiŽqg‹qdŒre‹rgŒqjŽqjŽqjslŽrkqj‹pi”ok”qm’ql’ql‘qlpkpiŽsltmtmsl‘slslsnqlpm‹oiŠoh‹qhˆpg„ogld|kdwg`qg\pdZrd[q_Vs`Xu`WsaUo\Vn[TjXNhWJfUI`QFaQHaQEaOD_NBaOB[KD]IC^IC]GA\G@[G@\H=cPDdQDfSGhULiVOo\UsaXo^ThWOhVKjWKgXLgYMcYM`XL^XO`[OY^LY\I]]L[^MT^KP_KO`KOaKNbLMdMQfQUjUOlSOmTQqXPpWKlTLnUQnWYu^^zcUqZVqZXqZRnWRnVRnVPkSOkUOjWQlVQjSQlUPpWPsYVs[KlTIiQPnWSoXSmXSlXSiVSjWYn[VmZSmYVoZNkRUmWQeTSfWRfXQgWThSUhUViVOcRKeSKfVIgWKgTJdNLfOKgNIgLQgNTiSQfPKaNJePC_KF_KJdOF_KE^IG`LHbLK`JKbLKaKM`MLaNHbNKaRJ_MI]HH`HHcJA^GE^JD\GH`HFaIGeLGkPFfNDcJB_ED]FD_GGcMN_NMbPNfRJfROhTMeQRfUMdQGaMLiSGgODbKF[EH]GJ_IMbLH_HKbLJ`NF[HF^KG`LHbOGbONeOLcMOfPPhQRhQWmVVhSUdR[gX[fXXdUXfT[g[\i]XgYTdSTgVWjXSgQWgRXgT\iV`iYbjY_iY`gXbhZdl\hm^ll_nk`ml`ii\mobppcjk^me_kg]li^mk\po`rqdojbpkbpm`pn`ik^dh\^fW\dT`fWdiVfjXhkZmcYiaVkf[jh]hh\ff[jdWkdWldWngZmfYlfYidYibUrh[vh\ufYveWod[pe\pg]rh^xlb{kbse^uf^vi_vlbwj`xc[o_ShZMdYMe[QndZrd[tf]lbXf_Vmg\sj\{n`napezndujbwlawjavl_ti\th^sg]sf[wkatj`od[neYri\tj]pgZqfYldXjg\hf[ieZkcUgcYeaWfd[gf\ccYbdU^_U^]TY_RVdVVeTadUZdTSaQN^OM^MMaLL^GJ`HF]HE^JFaNGcNFbJCcJCcJGgNFeLBaH@`HA^H?^F?`EAcGAaG@`GA^G@]F?_G=`E>bHdM>dJAbJ?`HEeLCbMFbNHbPEfQFfQFgRDfNBdLDgOHdMEdNGfRBbOHfQHhPIhTGiREiQAhOBeMGiOBdPBfQBjP@dK@cJGgO[bOegVmjYqjZzlZnakd€ldƒne…pbpdpc~od}na€obƒqbˆpeˆqf‰qf‰peŠpeŠpd‰nd‰nd‰ncŠpc‰ocˆmb‡pe‰qhŠpi‰ngŠogŒqe‡oe‰pfŠqgŒrh‰pfˆoe‹qe‰pdˆpd‡ocˆoc‰nbŠoeŠoeŠoe‰neˆleˆle‡nc‰pcˆpb‰nf‰nf‡nb†oeˆndŠpfˆmcˆlc‰lc†md‡me…mc†kaˆld‡kc†mdˆmdˆkbˆjaˆlb‰mb‰oc†jbŠnhˆkeˆkdŠmf‡lb‰nd‰nd‰ndˆmc‰ndŠmg‰ld‹nd‰lb‡jcˆle‡ja‰nd‡nd‰oe‰nd‰md‡k`‡laˆla‡ka†jb†jb‡ia†ja†ka‡lb†lb„ka‡k_†i_‡ja†i`‡ka‡k_ˆld‡kdˆkb‡ja‰jbŠka‰ldˆkb‡ja†i`‡ja†i`‡jc†ia…i^†j_„f_‡ic…k`…i_†g^‡h_…i`†k`†ia…h`…h`ˆkc…ia†kc†ka†ia‰ic‰jdˆkc‡mb‡i`‡ja†i`‡jc…ib†kcˆje†hb‡jc‰leˆkd‡lcŒlgˆlf‡ld‹pg‰me‹mdŠmf‹ohqjpiqjŒohŒogŒogŒogphŒogŒogŒohŒohŒph‹neŠmdŠmdŽmdne‹lc‹lc‹mdŠmdŠmg‹ngŠmdŒofneneŒoh‹ng‹ng‹ng‹ngŠmfŠmfŒlf‹kelfŒlf‹ng‹ng‰kdŒkemd‹md‰lc‹mdˆlc‡mcˆndŠne‹mdŒke‹keŒlfmgŽmgoiqiŽrhŒpeŒqfŽrhqhrkslŒohrlqjrjql‘rmŽrlqlsnŽsmrlŽsm‹sm‰sk‰pjˆoh…og‚lf‚kf‚kf‚leia~i^~h`{e]ubZq_Vn[Th]Sh\RcWMdULeULdTJdTHbPJaOG`ODbQC`MB]OC_QE^NBYJ>]M@_MD_LEaKEdMGhQJlWOtaZtdYi[Pj]Ok^RnbWmbYod[nd[g^Sc\Pb[N_ZM]\K]^L\^N[`QX_OW`PSdOQaLSbNTdOOfPOjSOhQMgQOkUPnVTpYZt]Wt\Xu]Yv_Wt]Vs]Vt]Yu_]yd]ycWr]Zt^Xr\VpYVpYTnVOiQQjURkYMjUPhSOjTMlVOnXQlWJhQHfONkTSoWNjSLhQPhSRlVVq\UoZRnYNjTPhQRfRTdSSdSTdRTdQOcQRfSSiVRjVKgTKjVKjVKgUIeNNiRJgNLiOLfOQjSQiRMePKeQEaMJfOJgPIeNHdMKeNGaJG`HHdLMfOL`JJ_JD^HI^LE[HCXCE[ED_IB_IF]JE\IHaKJfNIgPGhQKdQJcNJaIE^EE]FFaIH[IH]IKaONfPTiSRfPRfSMeQGcOFbNBbMB`KD^IF_JIbNLdOMdPJaMF\IF\IJaNLdPPgSPfRPhRTjTYlU\hUahUdiX\gU]fU`gZdi\dj\biYbg[di]cgZ`eV`gVdiYgj[egWdfWfgZgh[hgZhgZlg[nj]qqdsqdxpd{qfvlbula{sizshslbnf^kc[pi]rn`rm`okasjcof_oh^kfYge[gg]dbXdaWgcZicXicXkdZmaVmbWndZpg\ph^pi_ogYjbUlcVnfYrj]ogZof\ndWqeYpbUueXyi[wj`vj`qg]pe[yncykbui`wg^te\pe[qdZr^Vl_Rk_Se[Pe\Rh^TkaWqbVpdZpf\ri_zpb}obob}ndxlbwkcxmbzndxlawk_ui_rg[ui_xlaykaykawi`tfYtf[qdXnbVoh\nh]ieZgbVg_Qg`Wha[eaYd`X`_T``S^]T^^R\`TZeXZdV]^P^bSY_SV`SVbRUcPSaLL_HJ^HG^JIbNHcMGbJFdLEcLDdKBbJEeLGhOBcK@bH?`FAaGBcI<]EC_H@_GCbK>aG=`FbLCgMCdLFfNHhPCaMEbMGePCePFiSIjUGiQGhPIjRIfMKiRJkUIkTHiRJjQKjUKjUGiPGiQGhPGfNEhSCgQBhO@dM?`KCbN`aOojYvl\yl\~n^}m`}k_me…od‡pdƒqd‚pepeod‚oc…qdŒsdŒrg‰ocŠoeŠpe‹ohŠoeŠoeŠoeŠoeŠpd‰oc‹qe‰nf‰mf‰mf‰meŠqe‡pf‡qfˆqf‡pe‰pfŠqg‹qd‰pc‡oc‰pgˆoc‰mfˆmb‰ndŠoeˆmc‰ndˆmcˆmcˆna‰oaŠng‡kcˆnbˆmcˆmc‰nd‰ndˆnd„ka‡maˆmb‰nd†kb†ic‡ld‡kd‰mf‰ka‹lcˆk`‰mbˆmcˆmcˆleˆleŠmf‰lcˆmc‡ka†kaˆmcˆmc‡lb‰lcˆkc‰lc‰lc‡ja‡jaˆkbˆmc†mc…kaˆmc‰lc‰le‡jc‡jcˆkd‡jc‡jd†i`‡kb„i_†ka†lb„ka…i^‡j`…ha‡jb†j_‡k`‡ja‡ja†i`‰lc‰lcˆkbˆkbˆkbˆkb‡ja…h_†i`‡jc†ia…i^„h]„g_„ha„ib„ha…ha‡jc…ia…kd†ia†ib…ha†ib„ha…ib†kaˆkbˆi`‰kaˆkb†k`ˆkb†i`†i`†ibˆkdˆkd‡jc‡jc‡jcˆkdˆkbŠnd‹ldŠne‰md‰pcŠodoeŠngŠngŠng‹oh‹ohŠngŒohŒohŒohŠmfŠmfŒoh‹ng‹ohŠmf‰ndˆlc†kaŒlf‰jcŒlfˆle‰le‰leŠngŠngŠmd‰lc‰lcŠkb‰le‰leŠmf‹ng‹ng‹ng‰leŒlfkeŒjdŠjeŠmfmgŒkdkelcŒneˆmcŠmdŠmd‹neŠmd‹neŠmdŠmfŒnhŒohpiŒohŒohrhtjpgŒofripgrlslslŽrkskŽrkŒrlŒqkŒrl‹qkŒrl‹rmpk‹rl‡oi‚nhle{ibxh_ud]xf_ud^sbZn^Un\SmZRmXPkVNkVNhSKeSK`MF^LD^MF]LD\KD]MA`LF`KD`KB_I=cOCdSDfUIcSEgWKhWLgVLiVOiWNkXPp^Vxi_zmanf[f`Sa^PcaSccW``V`cTZ_PU]MZaRV`OU`OXfOWdNUeQTfQPdOQeSNiQNiRSmVSoXPoWMpXQoWRsZQpXQpXVrZ]xaZt]Xr[Zt_^wbYs_Yq_ZuaYt`Wr^Yr]Yr^Wp\TkUTlURjSTlTVlXRhVNkVKeQMhTJgSIgRLeQFbKHdNKgPLhPKhOKiOMiRPlUQnWRqYOnVLiROhTNeSQeTRcRSdQSeOQeTShWTmYRmYMmULnWNkTMiSLiRLiRJhPIiPHhPNkTPlUKeNIePIcPHgOKiPKiQIfMFbIGaJFcJGfMFcJH^FI^GC_GI^ICZDAXAC[GAZGE_MG]MDZHE^JHbMHdQD_LNaROcPLcMG_HC_F?[CC[HE^JHbLOfPShRShQQgQNfQKeQIdRGcOF_NC`LIdPKfRMfRShUPdQObQSfTYjY\l[^n\[jY\jValWdkXggYjfZkdYcfWddWhg\nk`lk_jj^ji^kj\li[mj[qk\xrbxodti_pg]md[lcZoi_vldyldxldxnfzqh~ph‚rhne}mdƒri}ofth^pf]ri^sj]sk_sjaqf`sfaoc\gZRmbZog^lh^mb\j_Xi^Vf[Si^Vpd]ti_{oe‡{pqeZqbYsd[rf\pe[lbXmcYqf\qf[sf\uh\xk_ug[tfXreWve]pcZocYpg]vjavj`xi`we\q`WpaXn^Wr^Wo`Uk\QdVMfWNl^Uuf]ob{mawkavi_yj^~naˆwj‚rh~ofzmfxlbvi_xkcwjaxl`|nc}pd|obzkczkbvg^uf\seXpaUmaUodZjaXh_Vg^Tj_Tlc\kd]h`[b\Uc^Va]Ra`UbaV_aU\aUY\P__Sa_S`^SbcW^bR]cSY`OXcQTbORbQOcLLbLIaKGcOGaMFcNGdOIgRIhSEiODiODeL@aG@\F?^F=]E?^F@`H>aG>aG>bH=bH=bI;_G>aJ@bHBeIDgMBeKAbMBcNAbLDdKAcLAbJ@aGBaL>^IAaL@fPDiSGiTHjQKkSLiRLjQNmTMpVKnTLmTLlSLkVHhSHgRKiRLiRHfOEePDfPAeMBeQA`NB_OfbUsj]|oc{i_wm\zm_|l`{k^odƒod‰pfˆoc…ma‡oc†oc‡ne‹qdŒrf‹qd‹pg‹qf‹og‹ohŒph‹pfŠoe‰ncŠpd‰oc‰me‰mfˆleˆld‰ocˆoeŠpf…nc…od…od†peŠpbˆod‡oc‰pfˆne‹oh‰nd‰nd‰ndˆmb‡lbŠoeˆmc‰oaˆnaˆld‡ld‡maˆmc‰nd‰nd‡mc†mc…lbˆmaˆmc‰nd‡lbˆle‡kdˆle†jb‹lc‹lc‰laˆl`‰le‰lc†kaˆmcŠoeˆmc‡lb‡lb‡lb‡lbˆmb‡lbˆmc‡lcˆmcˆmcˆmc†ka‡jaˆmc„ka…kaˆmbˆkb†ibˆkd‡jc‡jcˆkd†ib†i`†j`†ka…j`…kaƒj`…j_„g^„g`†ib‡jaˆla‡ja‰kb…h_‡ja†i`‰kcˆkb†ia†ja‡ja…h_‡ja‡jd…h`…i^„h\…h`…haƒha„ha…ha…ha†jc…kd‡jc‡jc†ib‡ib„ha…ib‡laˆlbŠkb‹mcˆkc‡lbˆkb†j`†i`‡jc‰leˆld‡jcˆkd‹nfˆkbŠmdŠmdŽofŠndŠpd‰oc‹pdŒoc‹ohŠng‰mfŠngŒpiŠoh‹ngŒohŒoh‹ng‹ng‰leˆle‰mf‰mf‰nd‰md‰mc‹ke‹keŠjdˆkdŠmf‰leŠng‰lf‰nd‰lc‰lc‰lcŠmfŠmf‰leŠmfŠmfŠmfŠmf‹mgkeŒjd‰ld‰mfŽlfŽlfŒjdŽmd‹md‰nd‹ne‰lcŠmdŠmdŠmdŠmdŠng‹oh‹ohŒpiŒqiqjŽsiŽsiqjrjŽtjrh‹rl‹qk‹sl†ojˆqj…mh‡og„kd…ld‡mf†mf„jcƒjd€hbze_ub[p_Xm^Wk_Sg[QgZRdVObUL_RFbOGaNF^KCdOGbMEaLDfLEbIA`IA`JB`LD`NEaPCeNIlRKpVNu_RwaWxiZqaSm_QseYmbUh\Rg_Ti^Uf]QhbUnl^efW[`TX`QZdRWcPVbQUaSTbPRaQSeSTgTQgSRiTViRVjSWkVUjSRiSUnWRoWToXVqZUqZTrZSqZUp\Up\RmYVp]Vo[Yn[UpXTmVXq\^wcZs_Yo]UmYSlXTmYUnYSkXQkWTkUSjTRlSTlTTkVQgUHgQKeQJeQGdOGePHaMEbKEaJEaJHeLHeLHeLLhQOmVMoWNpXMmUMjSNkWKhUJeRHdONgPTmSTkYRkWQlXOlUOoWMlRMjTKhQGhPIjRFhPDfNGgSJhRKgPFbKFbKJfOIgNKiPKgODaHD`GGaHFcMEdLFaKH^HJaJGbLI`HG]GC\HE^JG_MI`NI]NDZGE[HKaNH]MG\MM]QObQNcPIcLFaKGbKE^KHaNMdQQhSVmWUkUXiUTfSPeSUiWSgVQeWOfTRhWSgVYjY[jZZhW_l\cn^cn_ipbnsdkn_liZoi[ogZne[jaXf`Whc[lf\rj_qj_pi^oh]hgYmj\oi]qh\ri\tj]{lcuf_od]mc[of^qjcwme{mf{mexneyrisk€sj~ofoezjaqe[mcYri\ri\ri\qh[oe\oc]pcZo`Xl\UmaYk`WlcYocXm`Vh^Sg^QneXqh\sj`„{psj_j^TnaWte\xg_se\m`VpcZwh_xg^yh^zj^|k_tfYnaSmaRraXtcZsf]si_ocYqd[paXvbZxc[tc\o^Wn[TmZRr_WwbZye]{h]yg\|k^€ob}lb}lbzj^}l_~ob€oe€pfyhbsf\qh]zlfymc|nc|oazlazi`yibxhatf\vg^p`Yl^SlaVj`Vj_Wk`XmbXi^Sg^UdYRf]Vh_XibYd^Tc^S``T``T`_Sa`T__Sb_Tb^Sb^Q]]O\[M]]PZ_PZ_QXbQUcQReQNdOMaONcRLcQIcQGbPGdPFiOIiPGdMA^G?\EA`H@_G@`HAaIBbI?bH?bH=bH=aICdMAcK@cJDgLDfNDeLCbM@_I?_G?_F=`H?`HCaIB^JAbMAdNAgQDiSFgRDfNIiQLjSLjQNoVKnTImSImSKlSLjWKiUNjVNjVLgQJfOCdODgOCgOEhPAaLD_NofZvl`€pe~ka~m`|l^}m`}l`ncqe‹oeŠndŒpc‹odˆmdˆog‹qfŒrgŠrg‹rg‰rg‹shŒpiŠngŠnfŠoeŠoeŠne‰ocˆmeˆmf‡mf…md„ma‡md‡ndˆnd‡nd†nc…mc‰md‡mc…lc†mc‡mcˆmc‡mb‰nd‰ncˆob‰oc‰obˆndˆobˆob†kc„iaˆoc„lb†lb…kaˆmcŠnd†ja‰ldŠle‹ne‰ndˆmd‰md…mb‰od‡kbˆkbˆkcˆkcŠmf‰kdˆmb‡ma‰ncˆmcˆmcˆmc‡lb‡lb‡lb†kaˆmb‡kc‡kd‡kd†jb†l`ˆkb…k`ƒj`„ka†kaˆkbˆnd‡kc†ja‡k`ˆmb†j`†i`…i`…j`†ja„j`‚i_…k_„ia…ib…ib†jb†la‰j`‰ja†i`ˆjb†ib†jc†jc†jd†jc†jc„hb„ha…ha…h`…i^…i_†h`†ib…ib…ha†haˆjc‡kd†jc‡jb†ia…h`†ia…ja…ja†jdˆkcŠka‡i_‡jbˆke‰nc…j`ˆlbŠmfˆldˆjcˆkdˆkd‹ne‰lc‰lcŠncmf‹pfŠoeŠpe‹peŒncŠlf‹mfŒmgŠleŠle‹mfŠmgŠlf‹nhŠmg‰keˆke‰le‰le‰leŠmc‰lc‡jaŠjdˆkcˆldˆkdˆkd‰mf†kd‡kd‡lbˆmcŠmd‡ja‡ke‡kdˆle‰mf‰mf‰mfˆmfŠmfŠleŠle‰le‡kdŠmf‹mfŒkemd‹mdŠld‹pf‹oeŒneŽpgŠndŠoeŒoi‹ohŒpipiŒpiqjŽsiqiŠqj‡oi†pg„qe}jdle~le}me{kdzjbxg^ud[ubYwc[vbZuaXt]VpZSnXQgTMeTL_SJcSGbRI_NF^MF^ND\NA]ICZF>^IAaLDbNF`MAgNFgOFgQHfRHkXNlZPn`Tl[Tp[Txf\viZsh\pjZhbTdaRdcT`aQ]^N[cTZbRYaQXbQUaON]KObQOdPSfQRiQTjUTjTSjVSiVUlXUnYTnWSoWYnWWmWXoYYq\Xr]Yr_VoXVoXVpYWqZVqZQmUTjWQjVOhTQjVTmXTkXRlUToVYs\[u]WlYWnYShTRiTTmXSlWOhSMiTPjSPjSOiQSmUQkUNgTLjRKeNHcKGfMFfMGcKC`IC_HDbIIdLIfLJfLKeNIhOJlTJmTMnVPlTMkUKiSGhRHhRMmUNmTSmWTnYQnWSpYRmWMgQKeSGeQCdMDhPEkPDiNJiSGcPIdOIcKJeOKfPMeOLdNLdMGaJE_HFaJHaOD_LE_KH^IK`LFbKH`IG_IF_LF_MMdQPgSObPL_MKaLRdRR_PR]PXcVYfWWhUXjVYkYYiXScTXfV_m[an\^m\\lYak\bn]an^`n^ao^\iX[eW_hZdl]fl^mpbloanmbqodrndqlbupdqk`th\tdZq`YpaYi`XhbXmc^rf_xkawjatg_rg^rj_oh]oe\nd[ocZqd[o`Xse]uiaoe\of^qkdtndymd{mdzofyofxlcuj`vh^yg_yh_uh^pg]oe[mdXofYmdWocZqc\ncWqbWn_Vm]Vi^Ui_TqbWq`UrcXpcUsh[si[uk_}qdvj]sdXufZtcWvc\uc]ue^xib}kd{g`{i`wdYyh\ueYpaSqcUp`XqcZqd[obXsd[xg_teXh_}f^r_Xo]Wp\VraYyf^kclb|i^ucXwgXzk]~nb€pczj^ueXvfYzi_yh_we_wi`tj`ug`sg]uiZwgZsbXta[qa[m_Wn_XnaWk^TgZPi_Uh^Uj_WlaYi^Uf[QbYPf]Snb[nd[mcYf^Qa[M_^Ra`UhbWhaW`^T_]S_\O`]O_[N`]Q`\R^\S^]S_aTZbRSbQSdUVdSScRPaPJ^MG^ME^LGcMLfRG_MF^IFdKFgLBcKCbJCcKFfMGfM@bH@dMCeLFeQCcLCeMCgLDcLDaKFcKB^G>]E<]D<_H@aIC`IEbNBdN@fPEgRFhSEfQEgOFgOGiPMjUJkSGkQGmSJmVKlVJkXJiVHeQKfRIdQHdNDdODfNCgMBdKBbJD`Kum\zq`}p`~o_…nb†oc„oc„ocnb„pg†od‹qd‹qcŠrf‡pg…pi‰oh‹rh‹rhˆsg‰sg‡re‰nf‹ohŠng‰ndŠpeŠodˆpdˆnfˆng†og†pg„pc‰mcˆkb‡lb‡la†lb†nc‰mf†kd…la†mcˆncˆnc‡lbŠne‡ma‰ocˆnaˆn`‡nd‡oa…n`†md„kc‡nbƒmb„kaƒja‰nd‰lc‡jaŠleˆkdˆjb‡lb‰nc…k_„n`ˆpb‡ma‡ja‰lg†ke‰kfˆkc‰lb…k^‡ma†nc‡lb‡lb‡lb‡lbˆlc†ka‡la†kc‡kd†jc†kc…l_†i`„i_ƒj`‚i_†k`‡jaˆnc†ka†l`‡ma‡l`†k_†i`†j`†k`‡mb„j`i_†kaƒh^„ha„ha…ia…i`‡i^‡h^…g^…h_…ib…ib…ib„ha‡kd…hb…ha…ib…ha‡jb†j_‡k`†ia…ha‡kdˆic‰hc‰ic…g`†ib†i`†i`‡ja‡j`‡lb†ka‡kd‡jb‹mc‰k`ˆldŠngŒqgˆmcˆkb‰le‰kdŒlfŠmf‹nfˆlb‰lc‹ne‹odmhŠnfŠngˆmbŠne‹lclflflfŒjeŒjeŒkeŠmgŠlg‰ke‰kf‰kfˆje‹ke‰jdŠjd‰ja‰jbŠlc‹ke‡jc†jc…ha†jb†jcƒib…ic‡lbˆmc‰lc‰lc‰mf‡kdŠng‹ng‰ngˆleˆmf‰mf‡kdŠngˆlf†kd‡mfŠohŒoi‹mcŠlcˆkb‰oeŒpf‹mdŽog‹of‰odˆng‹pi†lf‡lf‰oh‡mf‰ndˆof‚jdjc}ka{k_tg`rf^rf^qf^pe]lbZh^Ue\Qe[Qg\RcWM`SIcPHdOGcMEaLD\KB[KB]L@]KA]KD\IB_MDaPDdMGhRMhRJgTLm[Ps`UtcUscUp`RrbUpcUqdWidVf^UmbYiaUgeUcfV^cU\dSWbQWcQWhSUfQReTQdSRfTQeRRhUQiTOlXOmUUqXUrXXsZWrYUo\Up\Xu]WrZTnWWqYYs\UoYVr\Ws^Uq]Tp]UnWRlURlUSlUTnWRlUOhUMhTKfRLkVTp\TpZPnTUrYWqYQkUUmWTmVQiRUlUVmWRlUOhQMhQLhQJfNKhOPlSPjUNiVNiRMfNJeLKkREhNIhNA]IEaJDaHHbJMfLF`DGaIJgNHjPIkQNlSMjQOkRLiRHgRHjUOpWOmTPmUQnUSpYTnXQgTNaNKcRHdP@aLFlSElQGmPMhTE_KD]IJdLKfOKiPReQK_KLaNH_LC]IC^JI_OD\KG^LI\KG]IE`KMdNMdOHaOMgTOfQTiRUiVThTXlV[jU]eU`dWdfYgl]em]gq`gm_di]cg[gh\kk_kn_kp`fn]locjnbfm]go^gm]fkZih]nmarodqnbrmbsmbvncvlbukazoeuj`pe[oc[pb[p^Wwe^vf_sg^vieug`zkb~ofzkctf_tf]qbZpaYqaZtb[uc\wg^xi`uf]nbYoc\ukcsmbtf]yh_wi`yjawf\sd[raX}h`{h_wh_odZmdZqg]sj]rh\rg]rf^peUobVpbYyiamaUncW|d]v_Yu_Wwe\wf]yi]|k_~kala}i^|h]{eY{d^zg_ud^wf_zg`{d_~jb|i^yg\zh]yhZveYjZQpcYwkasiƒrj‡um•„wŠti}e\wb\tc\r^YkaXpbXve]yg[yi]~oc„xfyk\zj^zj^wh\vj[xh[}ka~kc€mf{nesi_ti_qeXrfVq`Tp^UmZUh]Uf\Tj^Vj_Wg]Sf[Rf^Tg^Ui`Xnc\e[Rf\Qe\Oe[Qe[Qh^Ti_RcZL`WK]\M`]Rj_Ug\T_\SX[OZZN^\N`ZNf`Vd^VaXTd_XecY^cWXcUTeXXbRWcQRaON`NMbOI`MJbPOdROcRNePLiNIkNDfMDdMDdLFeLGgNDfLBeMDdNCbMCbMAdK_G?\EA_J>aK:bLCdNDdODdPEfNCeLCfNJhTEfOBfNCgOCeODdPChTFgTFbOGcOHdPGeQGgQEgNCfKAcIBcHB`G{m`~nb~naoc‡pdˆpd‡pbŠrf†ld‡ngˆoeˆoe‹pfŠqg†qf‡rgˆoeˆpe‹te‹te‹rgˆoe‰ohˆogˆnfŠohŒpiŒpi‰peˆnf‰oh‰oh‰of†mc†le†le…kd…kd…keˆng†le‡nf…kd†le‡mf†ld…mb†nb…maˆna‡ma‡laˆoe‡nc‡nd‡nd…lb†mcˆna…l`†nbŠmdˆja‰kbˆkd‡ma‡ma†l`‡la‡lc‰oc‰oc‰nd†la‡mc†ldˆmd†ka†ka…j`…j`‡lbˆl`‡j`‡jc‰ke†id‡jdˆkb‡ja‰lc‡ja‡ka†jaˆja†ka‡kaƒja‡jd…ic†ka†i`‡ja‰kbˆja†h_‡kb†jc†jd†jc…k_…j]„ka…ib„gb†hc„g_†j_‚h^ƒg^†g^…g\…j_…j_…j`…j`…j`ƒj`„k`ƒk`‚i_„i_‡lb‡ib†jbˆjf…ib†jc†ib†ib‰icˆia…k_‡ka‡ibˆkd‰meŠodke‹jd‹leŠkeŠmf‹ng‹pf‹pf‡ka‰lfŠle‹keŒlflg‹keŠmfŠmfŠmfŠniŠmi‰mfˆmcˆncˆobˆlb‰keŠljˆigˆjgŠleˆlb‰ncŒmd‹kc‰me‰mfŒlc‹lc‹lcŠlbŠkbŠkbˆkdˆka†i`†j`†l`ˆmbˆkaŠlc†i`‰nbˆnb‡nbŠngˆleŠng‡mfˆng‡mfŠle‰le‹neŒofŒneŠmd‹of‰mdŠod‹ngŠmfŠmg‰qg‡peŠpf†lb‡mbˆlc…lg†keˆlc†mbƒlb€ja€g`}e]yc[uc[naXmcYi_Wh`Xd_Uf`Se_Oc[K_YLZWL[XM^UK^QH_MD_LD^KC]JB]JB_KCaNFcNFfPIjUKlYNkXMn\OmZPlYQiWPn]UrdXqeWnbVk`ThbTebRfcQjgUagW^fVYcSXdOXeQUdOMfPMfOSlUSlVTmWQiSRlSRkTTnZUq]SpXSsZTt^Ut_RrZUt\Yw_Uv\Wr^Xs^\s_XlYVkXWm[YnXUnUUrXUrYTqXVq]QnZOlXQlYRoWVpYWpXNmTIgRLhTKgSQnXOmVQjTUoWToUQmRPmTOmUNjVQmYVo\Vp[UpYPlUMkTHeMJgMOlQMkSNkSNfPKeNJjRIlRLjQKgNJhOKgNC`GGcKHcLGaJFeNFiPDhQKmUOkSQgPMlQIlPEiPHjRPiTTgTM_NOcPUmUTlUSjSObNNfRHdNCdLGkSGmSFlRKiQC`HGcKOhQOiRQkUUdURbRNbOI`LFaHFdKK^MI_LGbNGbNMcSUeX\fV\hVXhS[kU[hS]gU]n_bp`iq`fk[fhXffZge[deZai]dj_ef\kh_kj^nk`pk`vmcrncrnctmdmg]li_oj`uk`yl`yldxkbuiatg`wicvhbyjbuf]vg^rdXseYteYye_xf_we^yha{j`{i`zha{jaqe~pdxkaqe\j_UkaVn_VsdZug]wk`uh^rd\p`Zrb\xh`xj`vi]tf\ud[ve\yh^yh[oeWpeYse^wf_wf^wf]{h]ykawkbvg^ud\n`XnbUsdV|j_|k_we]ue\udXp^Txe^|ib|h^zg\ve]we]zg`€kc„og„pf„qfzi]ucXzh]zj^{k`ƒm`|h]uc[we^xh_zh^yi]vd]zgcih|iclc‚pd~kb{g_wf]vf\rdWp`ZrbZrcZxj^ƒui‡wj~mbueYvfZzk_|oc{nb~jbzh_uf]sg]sh^sh^of\od[o_Wn]Vn[Vr_Zuf_xi`vf]oaXn_Un_Sk\SeXPh\Vj]WfZTh[TbZPaYPdXPf[Sg^Rd[O`ZK^WL[XN`\Uc^YaZT]ZR\YO^XP_[QebVccWfeZcaX^_V\aWU`TN^PT`STdTTdRUaOP]LJ]LI^JN_NS_PXbQX`O]gRQbPPaLPbMMeNIfPBePFeTFbPGcPDaL@aIAcJBaMDbLEbKAaF?_D?aE:]E;[G;XE=[H=]G;`G?]I<^K<_J@fJBeHBaHAaM@aLBcNBcN>bL>dMFePHhPBbKEcKCaHEbIG`OD]KK`OD^IA]H@_H|l_na‚qd€oa„nb†pd„nc‡qe†pe„mfˆnd‡nd‰ndˆndˆqf„peŠpf‰peˆobŠrdŠqf‰oe‡nd‡mc…lb‰peŠodŠoe†nc‡meˆngŠpi†ld†mc†le…kd…kd†le…ke„jd†nc…lb…mb†mc†mc…lb†nbƒk_†maˆnb‡lb‡la„ka…lb†mc†mc†mc…mc‰mb‡ma…lbˆmd‡kc‰jd‰mfˆmb‡maˆnb…j`…jaˆma‰oc‰ndˆmc‡ncƒjcˆmb†kb‡lb†ka…j`„i_‡m`‡ma†jc†id‡jd‰mf‹ne‡kb‡ja‡ja…h_‡i`‰ja†kaˆmc„ka‡kd†jc†h_†i`†i`‡i`‰ja†h_†j`„i_…ib„ha…j`…j_„h`ƒg`‚f`ƒf_…h`„h]‚g]ƒh]‡h`†f_„g_…ia†i`…h_†ja†j`…ka…ka†j`‡la‡lc‡jcˆkdˆld‡kd…ib†ibˆkd‰leˆjb†j`‡j`‰icŠjd‰ld‰mdŒmg‹mf‹lfŠnfŠng‰mfŠoeˆmc‰mcŠmfŠmfŠleŒlf‹ke‹ke‹og‹ng‹ngˆlf†jd‡kdˆmdˆmd‡la†ibˆjeŠkiŠkhŠlf‰kd‰od‰ndŠlc‡i`ˆkdˆleŠjbŒleŒleŠjc‹kdŠjc‰ke‰ke‡jb‡jbˆmc…j`‹kb‹mc‹ld‰ldˆkd‡jcŠmfŠmfˆle‰mf‰ngŠoh‹ohˆleŠmg‹oeŒofŒqg‹pfŠoe‹pfˆlfŠnf‹ohˆmdˆldˆldƒi`ƒi`„ia}ga}f_|f_zf\wb[ub\taYp]Un[SkZQgYPe[Qf^V^WN^YN_WK^UI[QE\QG]TI[SIZPF]OEbOG`MEbOGgTLgSLjWPn[Sl[So_Vsd[qdZmaUk_Ri_Rf]RcZPc]QgaTebR^^Q]`RYcQYdSYgR[gRWgSVgSTfRSfSPfRQgSOlUUqZSpYSpYRnWSoXSpWTqYUr\Xu_Xw_Xx_ZvaUpZVr[Xt]Wu^Wv]Wt]Wr[Xn\WlYVlYXn[Yq[SlUTqZSpXUp[Tp]Rr]Qp\OmWPlUToYVqZOnVGhQHdPJfRRoYQoXQkTRlTSkRSmTQlUPlUPmYRnYVp]Ws\Vs\PnWQmWIfNNhONgNRlUKfOJdMIeOLlTNpVPoUPmTMlSKjQEfLFeNDdLHgOJiQJkSGjRKmUPmUSlUPmSNlRIhPMiRViVQ_MM\NO`OSgUVkYTgWTfXMgRLiRIhQIiPLkRNnUOhRPgRTiUXlVZoZUkV\hWZfVWfUPdQNcOOhROaQTfTYiWZhV]jZbm_ji\hj[eiXfiXdfWij]iockpcnoaji[heYlh^oi`li_fj_fi^mj`qkbsmbslavmcvmcsk`rj_qg_nf]qi_umbxlc|mb{jcxiawh`ujavhbwjd‡un{kcq`XqaZuf\xk_ƒmg}kdxg`vf_xg^zi`zhaxg^sdZoaWoaXpbZoaWqbXvd[rbXscZqcZrcXqaYsc\te^sd\tf[wi\yj_zi`ve\sdYtfYndVpcXte\yha|kb}kd|j^tf[laVo`WtbZpc[wi\tdXo\Qr^Ut`Xo]UrcVrbYtb[vc\zi`~la|jazh`|ka€odqd|k`{i^vdYweZyi]zj^zi^~h[s_VmZRud[zi`{j`na|j`yfavd_zhb€pf‚pd}kbtbZraYudZzi^~nbod{kbsd[wh^qdZn]QqbUxh[xj^zl_yk^wd\tcZrbYp`Wn`WobXl_Vg[Rj_Um`Xue\}lbyhbuf^iZQhYPl^SqcWpcVncYdZSaYQjaXpg^h_Uf[SfYQdVNdYNcXLdZL_VJ_WM^WQ`XS_XQ]ZO]YO]XO][PeeZdf[cbT[[OXYOX^SS_RK[KOZNSaRUbRT]MR[KLZJLZJMXJQYMS[NV_OVaOP[LR]MS]LP^KM_MJaPEeQDbOAaL@cL?bJAgM=bK=aH@bJ>^F;]C;^C5[B7[E8XD<]G=^G:_D<[F:YG;]H=`E?aDDcIBcL@bKAbL@bK=bKZDA\GA[GB_J?^Ipcƒre‚pb„oc†pe†peˆreˆqe‡pe…od‡peˆndˆmc‰nd‰pf‡pf‰ndŠoe‰nd‰ncŠoeŠnd†mc†lb…lb‰oeŠodˆmc†nb†mdˆnf‡mf†lc‡oc†mc…lc…lb…lb…lb‚i_†ka…ka†ka†lbˆmc†ka‚k^…l`„i^‡mb†ka†kaƒj`…lb†mc„ka„kaƒj`ˆkd†jc…ib†jc‡jcˆjc†ka‡lbˆmc†ka†kaˆmcˆlaˆla†la‡ka†ka…jc†k`…j`†ka‡lb„i_‡lb…lb‡mb„jc…kd…kd†ke†mb†lb„i_†h_ˆi`‰j_‰ja‡ka‡lb„ka‡jd…ic†i`ˆkb„g^…h_†i`…h_„j^„j_ƒh^e_‚f_ƒg`‚f_ƒg`„h`ƒg`„h_„g^…j`„g`†f`‡ga„ga…icˆi`†h_†i`‡ja†ja…j`…j_†kb†jc‡kd‡jc‡ic†jc†jc†jc‰le‰leŠme‰mb‰lbŽlfkeŠkdŠmc‰mfŠngˆleˆleŠngŠng‹neŠneŠmdŠmfŠmf‰mflf‹ke‹jeŠnfˆle‰le‰lcŠmc‡kdŠmf‡jcˆkc†hcˆhe‰igŠlgˆkd†i_ˆlc‰lcˆka‡jcˆkd‡kdlgŠjeŠje‰id‹kf‰hc‰kf‰kf‡idˆkd‡kd†kc‹lc‹ld‹ke‹lgˆif‡heŠmf‹ng‹ngŠngŠng‹oh‰lg‰me‹oh‹ogŠpe‹pf‡ndˆmc‰odŠng‡mfƒkbichb}f_{e_yd]vb[sc\o_Vn]Tm^UiYRgXTi[RbSI`PGcRH]QH^RH_SK]RKUJB\PH]NE[IB]NEdXNeYO_SIeWNhWNiYPkZQp_Wn`Vn`VoaWj_Wof^mh^je[caUa_T\_PZ^OX^OX_OX`OYdQTdTUfTPgSSkTUmVQjRTlTVmVToWQkUOjVNjWRmVSoXRnWWqZXoY^s]VrZVr[Zw`[v_Xt]Xu\YpZYpYZt\Yu^Xt]Vr[UrYTnWVpYWmZYp^]ta[q\SmVSpWTr]PnZQn[Rs^MoYKkSMmUQqYQnWMmUKjTIfRLhTOkUOnWMgPOhQSjTUlVUoXSoXRmYNkWPmVUq[PoWLmTKkSLiRIeNJeNLgPIcLIeNJfOMmUNjSNlTOiRLmTHkQGiQEiQEjQEgRLgSIgRIfRKjURmYSmXTkURmVNjROgTQcQT`NQ`PRcRXkZXkZWj\Wk^SnWSoWOiRUmVYoY[pZ^l\_l\_jY`j[]hXYfV^dUbiZcl\`jZ\hW]jY\m\an\gl\lk[jhZhg[oh]ni]mi]oj_oh_skbqlboh_nf]qh^siavkctiaph`mj`pjaslcxmdxmeymezmeug_sd]te]xha}ngykcvi_xh_zh_zha}kd|lexibrf^wib†slyg`uc\ue^vh`xlc~jc|ibvf_wg`wg^wf]vd]sbZq`WscYpaXn_XraXxe^q_Wo]TsaXsd[sbYyh_te\qbYqbYrdZ{ia„ri~mdyi]sfZobTthXtgZzi`nezh`vdZtaUqcXodZwf]tc[o`Yn]Up_VjULt_Vt`Xp^VpdYpbYo`Wo`WtcZ}lb|hazi_|l`tfZqcWseVvcYxeZtcXm]Qn^RscWyfZ{h^xd]yh_zh_xh^}k^{h_{ia}kcxj`}rd€odvfZqaUxh]zj^|l`€ob~nbzj^te\tf^viaˆwnpgrbYrcZrbYrf\xi`zjavf\q^Vo^Up_Vq_Vn`UneYwoa{pctdWtd[rc[te\qbYo`Vl]Qp`Sm_Ri]Si`Vwmd{qepd[j[TkYQfTMfWLhZNl]OfXNbVNaVPbYPbYPb[Oc\Q`[R\[QbbX_bY^\R^]R]\R\^UZcWS_SS[QS]QV^OYZLUUHRWKSYNTYNUXOY]SX_SU^PU\QU\PY^PU\MPYLP\OLcOG_KD^HA^G@bJ>dJ:bH;`H?aI?aI;]E6YA6]G7^G7\F<^F<]E@`G>`I<\J:[G@aGBbHEbJAaI>`H?aH>`H?aI>_F<_J@cNBcN?aLAbMBcMCcJ@_G>^FA`I@_JA`K~k^‚ob†oc…oc…odˆqf‡qeˆrf†pe‡pe†peˆmc‡lb‰nd‡mc‡nd‰nd‰nd‰nd‰nd‹pgˆmcˆoe†mc†mc†mc‰ncˆmc†na†mb‰og†leˆod‡oc‡nd†mcƒj`„ka„ka„ka‡mb‡lb†ka…j`†k`†kaˆmaˆmb‡lb†ka„ja…kd‚i_ƒja†mc†mc†mb†mb‡jc‡kc†jcƒh`…ia…ha…j`…j`‡lb†kbˆmc‡lbˆlaˆla†i`…j`†k`…ib†ka‡lb…j`…j`…j`…j`„ka…lb„ka„k`„ic„jc„jc…ja†j`†i`ˆj_Šk`‰ja…i`‡ka„ja…ha„ha‡ja…h_„g^†i`…i_„i_ƒi]ƒh^‚g]‚g]„h`‚e`„fa„g`„ha‚g\‚g^„i_„ha„ha‡ga‡ga„ha„ha‡i`‰ja…h_‡ja†ia‡mbˆjd‰mf†jc‡kd†jb†ka‡kdˆleˆleˆleˆleˆle‹nd‹mcmf‹lfŠld‹neˆleˆleˆle‡kd‰mfŠng‰lb‰lcŠmd‰le‹mg‹ng‡kdˆkdˆldŠjdŒlf‹keˆlcˆkcˆkdŠmfˆkd‡kc‰kf‡jdˆje‰kfˆkb†i`ˆkeˆke‰leˆleˆkdˆkd†id‡id‡je‡id‡je‡id‡id†hcˆje‡jc‡kdˆle‹mdŽngmh‹mhŠkjŠkjŠngpiŒpiˆmfŠng‹oh‰kg‰kgŒoi‹oh‹nhŠofˆoe‡mcˆmc†jc‚kc}h`ve^tc\qaYn_Wi\Tl^Vi_Tg[QgYPbUK`SLZOI\RHZOE`QH_PG^NEbTKcRI`PF`PIcPIcOHhPLfVMpcYkbWf]Sd\Ri`Vh^Th_Ti`Ue_Sg`Ve_TccYdfZfj]bg[bhZ]dTZfUWdRVcQTeQUgRViSViXWmYTo[SoXTqXTnV[rZZrZXnXVlWUmYQjVUjTVlVWnXZq[[nXdu`ZqZZqZZrZYrZ[r\^t^YoXTnWVr[Xt]Yu]UoWUoXVpYYr^Xq]]r`ave^s]VmXTo[Uq]NmXPlXLnVGiQFhPNmUMlVKjULlTLlUJfRIeQIePIfOIbLE[HOcPUiWVm[Xq[RmXQmUPlVPmVPnUKjQGhQGiQIkSFgNGeNHfOKgPKhQLhRIfOLhQNjSJkRJkTMoWNoXOnZKjUPiUOiUNhSQhVWmYXjXWjWWlYWkXYmZ[kX]hXZjV^mZ`o\]n[]o]Zk\YmZ[jY^lZcm\gp_dm\il`jl`ih\ij^fh\_cWfeWhhZjj]ij^hi]hi]dl]hj\kgXnfWmdYkaYqh_ulbsjaukcsjaqh_vf_uf_tf`vhbykcxjbvf_qf^siaulcxldzjcwf_xha|kdvf_{hazha~je~kdzh`we^ve\yg_zha|ibyibtd]sd]vh`|ib|jb}kdxf_wg`wf_|ib}jczjc{ldvh_tcYta[uc\ve\xg^ta[lZTtaYye]zc[ubZsaYpaXtbYud\tcZrcZuf]sd[yf^xf]tdYvfZrdXtfZtdWxh[ne€mewe[xg[yeYug\sf\xf^s`Yo^Wxhale˜…~†pjq^Wp^VoaYpd[rcZqbYtd]tc\ubZsaYxh]reYsdYteYucXtcXqaUrbVrcWuh[mfldmb|k_yi^|kc€oc‚peofylauh\sh[zla|ma€pd}layi]zj^‚re‚sf~nbxi`xhate^wf]se\o`Wse\pdZsg]th^wg^wd\p^Up`Vrc[vfYtfZxm`wobk`Sn]Qp`Xrc[vg^sd[m_Tk]QwdVweYwf]uf]rdZhYMm]Ur`Yq^Wp]Vm]Rl]QjZMeVKcTMbULdXPcYQh]SdZPc\S`^T`_V]\TZVR\XS^ZUZWRZ[VY\W[]VZ_U]_S^YNYSIWUJYYOYXOZWR]\V[_VV]SWaWYbWV\QRZMSZMV[PR]LNYGKZHI\FF^HC_ICeMCbKA_H@^G>\C>\F6[E5\D:_F;]D;\C>\D>`I?]M?\IDbIDbHC_J>^F?`H<`H@dL@aICaJ@dJBgMBfKCfLBeKEdLCcJEeLCbJBbKBaLA`K€j^ƒl`†nb‰pd‰ohˆoeˆpd‡ocˆpd‡nb…oe†lb†lbˆkbˆmc‰oe‰odŠogˆmfˆmfˆne‡nc…na…ma†ma†na†l`‡ma†oa†mc†mc‡nd‡ncˆpc†mc…lb„ka…lb„ka„ka‡ma†l`‡ma…k_…k_†l`†m`†k`†ka†ke…kd…jc†lc„ka„ka„ka„kb†lb‡ib†ib…ia‚j_†k_…j_„k^„i^‡kd‡kd…j_‡ma†i^‡k_†i`…h_…j_†jb…j`…j`…j`†ka…j`…j_†ic„i`…j`‡lb…ja„ha†ib„ha…h`…i`‡k`†j^ˆi`†j`†ka„kb…hbƒha…h_†i`…j`„i_ƒi_‚h_…iaƒh_ƒi^„j_ƒh^„h`c^…ga‚f]‚g^ƒh^…ib…ic„ha‡h`…g]„i]…k_‡ib„ha†icˆkd†jc„icˆkd‰leˆkdˆmd†ka…k`‰keˆleˆle‰le†le†mdˆodˆncˆjc‹mfˆneˆncˆle‰le‰mfˆjc‹lf‹lf‰kb‡ja‡ja‰le‡kd†jcˆkd‡jc„ha‰icŠjd‰icˆje‰leˆkd‰ld‰ldˆkaˆkcˆkbˆkdˆkd‡jc†jb‰jd†id…ib…ibˆle‰kbŠlf‡icˆkd‡jd‡jdŠlfŠmg‰le‰ld‰meˆmd‰ndŠmg‹ohŒpipj‰mg‰nhŠpi‰ngŠohˆoh‡og‡ng‰mhŠoi‰ni‹ph‰ng‰mh†od…ja‚g]~c\vaYq^Vj\UgZSeYRaTM`TLdWP_TJ_RG\PB\PCWMBVLBUJ@\NEaQIfULhYPj[Ri[QeXNeYOcXOcVLgXOj`Vpf\eaW`^S\]RZ_R^_PZ^O\`QX_O^eU^fV]gX`k]`lZ_jX_jY^kY[jYZkXYmVXlVVlVUlVZo]Xo]Xs]Yu^Yu\XsZ]s]]s\XnWXoXWmVVmVXiTYmXVoXYq[[r[`u^WlXYoXWnWSlTWqYVoZRoVPnWSqZWu]Yt^^sa_uc_vcWr^Xr\Zr]\r]VkSTjSTmXSo[MiSMjRGgOEeMIiQIhRHgRKjUIiQGgQHePFbNFbMFdLG`MH]JOaQRdSViWUjWTkTQiSQlVRpVPmTMjRMhRMkTJhUFeRHhQKiROjSLhQIfNLgUMjVNlWLkSNlUUrYYq_Vn[UmZWlXXlYZkY^lZ^iW[eTaiYbkZcn^cm]ck\fn^jrcntdnr`jm\gk[dhXhj[ii[kg\ji[ki]ji_qj`kdZne[ph]lg]lh]ng^mf\ng]pi^oh]oi]oj`lg[icWndYre]sc_wjcxierb]sb\xjayma}lb{kcwga{ke{jbzi`vf_sd]sg_wkcxhavg_we^xhayib|ke}kc~jc{e`yd_{ib}ibzhawg_vgasd]ue^xg`zib}jc~nc€pf}kc}jc}kdzf`{hayhavh`vjaxjatf\va]wd^we^xf^p]Vp]W{h`€me~jbyf_te[oaWua\ub[we]we^ue^qb\n]WrbZxi]{k^qdvh[vfWzi]lcldmb~lb|f[scYqbYud[o\Uzjcwhbxhbzf`r`Xp^Wp`Yqa[td]uf]vf^wf_sa[vc]zh`{iatbZsaXsaWqbVtdXvfZzk_tfZrdWvd]zja€nc€oc|l`zlaxg_zjayi`wi\tf[tg\vh_ug]vi[ugZudZyi_znbxj_uf]td[rcYl\Ql]To`WqbYodZj^TnbXncYuf]ve\o_Vl`VlcXofWuh[ufZwg]paXk]Uj[Tj[SjZRiZQl]Swh\|l^{k`xj`r`XhVNlZPo`Wvc]ub[sb[paVk_Si]OiZPgXPiXRgYPf[QeVNdWNd\Sb\SdaV_ZPZSO]SO]TNaYTb\W_[W[XRZYO^ZP`UL`VMYRJZXNXTKWRLTPJVUOYZQV\UX]SV[OW\NUXKVXLWYJPUEPVFOZIK[INaONcQJ_MI]JG\G@XB@ZC<[F9[B8]C:\B=[B=[C9YA>ZJ@\IC_JC`G?^IB^GAcJAeMAfMEdLGcLAcJAbKAbKAbKEcNB`LA`JAaJ=_HA`LEaL@[H„nb‡oc‰oc‰obŠoh‰neŠpdŠpbˆoc‡oa‡of‡mcŠmd‹neŠoe‰ndˆpdˆof‡mg‰oi†md†nb‡oc‡oc…ma…ma†l`‡na„m_‡nc†mc†mc†mb†pa„kb…lbƒj`„ka„ka„ka…k_„j^‡ma†l_…k_„j^‡la‡mb†ja‚ha„jd„jc„kbƒj`„kai^ƒka†lb‡i`ˆja„i^ƒk`„k_„k]ƒj]„j_…jb†jc‡mb…l`†i^ˆk_‡ja†i`†j`…ib…j`„i_†ka‡lb…j`„i_…ga…h_…h_†j_…h`„fa†hc…ha„g^…h_…j^†l^‰kb‡kb…j`„ka…ha„gb„g^†i`‚g]…i_‚h^h_…gb„i`„i^„j^…j_f^‚c^ƒf`„g^„i^ƒh^ƒha…hc…hb†h_‡i_†k]†l\†jb„ha†jcƒib…kd„jdˆjeˆjdˆkcˆmc†kaˆncŠmfˆleˆkeˆng‡mg†me†pdˆocŠng‰mf†kc„mb‡jcˆkd‰jcˆhbŠic‹icŠkaˆjaˆka‡jd†kd†ib‡jc†ib…haˆhbŠjd‹ke‡idˆjeˆkdŠmdˆlb‡l`‡ja†j`‰lc†ib‡ic‡idˆhc‡jd†idˆle‡kdŠja‡jcˆkd‰leŠmfˆkc‰ld‹ngŠmd‹neŠndŠqd‹oe‰mfŒpiŠqjŠpi‰oiŠpg‹qjŠpi‰rj‰skˆqi…og‰nh‹qkˆmi…keƒiaf^{e[x_UuZQpUNjTLbRHaRIaRI`PHaOG_MDbOH]PGZLB]M@_SC_SEYQCbTKeVLkZQn]TrbYobXe[Q^XM^[N`^P[XJ\ZKa[OdaV__T\aTV`SU`RYeQYeRVdPVeQZkVXiTXjX^n\[kY[iW_mY]kV^l\_p\ZnWYnVWmVXoWUn[Uq[Vs[Xu]Xu\WsYXr[Ys]TnWWpXVpXToUZmXYqZSpZTt\Vs\ToXQjVOlTNlROoTQqXPoZQqYPsXRu]Sv^Xt`e|ih{l`wfVq\Vr[WpXTkSTgMThPVnWPkTLjRKhOHgNHeNKhQFePHgRIhSHgOHgQJfRIeQFcNGdMJcNK_MN`RPaSSfSSgTThRUkUOiROkSOkRQkRWjSVlXUmZOiWPkUSnXSlVSkURmWTo\Tp\Po\SoWUmW]s`_q^]o\\kZ[m[_m[bn\el\dgWfhYoi\rm_qn_iiZhhZrrevohyphymcvj_tg]sf]tj`si_pd\rf^lc]pharg\rg[teZui^qgZsk_qe^sg`sg`ui_rg\rg\se^nc[icZng^tgbxhc{gdzfd{ca|e`}ka}m_}lazjbykc{ke~mf~mczibvf_re]vh`xha{le|jc}lezjcwha|ib~hb}ea{faid}jcve^xhavgbue`td]}jczg_zg_wj]xj^yi^ƒohƒof€jcyg`uc]pbZvjb{ndvf^ve_xf`xg_{hazg`~je‹yqˆumyf^zi`vh^rg]}gcwc_uc\tb\td`pb^ud_yia|l`ob|k^{j^~l^€ma€mb…qi€nctdWxbWrbXrcZwe]xf^zjbm`\j[VhZTq^YqbZud]sc\tc\vf]|kbzhazfaxfayf`wc^xd^yc]zd^yi]wfZvfZteZn_SpaVqc]xg`mc}k^wfZo`Wn_Xtd^ug]wh_tg[vfZmcYqdYuhYreXudZqaXl`Xl`Vm_VqaTq_Tn^Qj[QiYQg[Qj^TmaWqe[pf\re\raXn_Vh_UkfZro^|rbweYuaYm\VdXSgXPiZRj\Sj[Rn`UrdXphZkaVi_Vnb[zne€qh|lcp^XlZTm\UgZOf\Pg_Qi^SgXOlYRjZQj[QjWRhYRbXObYPcZP`WM_VNbWOdZOe\Q[SK^YPd[W_YT`XOdVNbUN^UNYUKZUMYSN[UPZWQ_]U]]VVVMUUJ\[M__Pa`RXZKQTEOUGQZMP]ORcUXeVU`QQ]KN^JQdNMdKGbNA_G?`D@`FA`F@]E<]F>ZJA[HFbKD`H@]IB_G@bH>cI>bHCaHC^F@]KA_M>]KA]LB]OB[M@[JA^KA^LCbM@[G?YC‡oc‡oc‹qe‰pcŠmdˆod…od†od‡nbŠncŠpf‡od†qf„pe‡oeˆnc…pa„na…od„kb‡nc†oc‚k]„m^‡m_†l^‡k`‡ja†jaˆlb‡k`ˆmc„j`…lbˆna†la‡jc„jc…kcƒj`„ja„l^ƒk^†leƒib‚j^l`ƒlc†lf„ic…h`Šnc‡m`‡jb„hbˆke„hbˆlb…j]…k]†l_…k]†k_…h]‚e^„g`ƒf_ƒf_…g`†ia†i`†i`‡i`†i`†i`…h_…j`…j`…j`„i_…i`ƒi_†i`„g^„h]‚h^…ic„gc„ha…ibƒga„hb…ha…ib…h_„g^…j`‚i_€i^€k_ƒg`ƒha„hb‚g\„h_ƒh^„haƒg`…ibƒiaƒibƒib‚hb‚fa„ia…j`„i^†j_†jd†ic…ia‚g]†ka†l`†jb‡lc†ka‡ka†hc†ie†gd‰ke‰lbˆl`Šnc‰lc‰lf‰meŠpdŠpd‰neŠmg‡me‡ke‰nc‰nd…k`…ma…kd†kc†jc†ib†jc†jcˆlbˆkb†i`ˆkbˆjaˆja†kdƒha†jc†jcˆkd‰mf‰leˆkd‡jc‰lc‡jb‡jaŠhc‹lf‡ld†kd†jcˆkd‡jaˆkb‡jb‡j`ˆkb‰lcˆmc‰meˆle‹ng‰lfŠlgŒohŒohŒohpipiŽpiŒoh‹ngqjŒsk‰tkˆrk‰pf‡rf…qi„qi„ni„mf‚iag`|e]xaZr\WmYSmUNiQKhOJeMGcLFbKEaMG`LF`LB\I>]MC]NE^PDdTHeUJeUIdXL_VI`XNf\Ti]Vi]Ug`Vb]OY\JY]LW^MU\KTYJY]NX`O\dT_iX\hWYfTYhTUjWUlUSkSWlU[kU[hU\mW^o[XgWWiXWhXViVZn[]p]\lY[mZYlYUkXOhTWoY_u\[qXZpXWmWYpX[tZVoWRoVRpWRoXXpZUqYSsXTuZOsXOpWInTNoVPmSRoWTpXUp[Nt]Tu^Yw`Zv_ZvcYxg^wiWq_Vq[WtZTmVSjTOjORiPSjTPiVJhPGhNEfOHiQHiQEeMLkSJhQEjQGkPGjQLlSLhQKeOIfMMfQPdQUfXUeXTfUVjX[lZ[iWZeT`jZbk`bk\`k[ao__n]`m]dp`am_al^bn^bsa^r_Wn\\o[`p`cobdlbhlafi_ck]im`pnbni^lg\pk`sj\uk`xmdtkavkcwlczjdzjd{kdzjcxgazjavibwf_xf_p]Vve_sg_td^td^vf_uf^rc[vi_vj`ui_ui_sg^pg^oi^si_pf]ti_wh^{kc}lc|me}mf€oh}mf|kdyjb~idkf}kdne|lbxi]yfa{gb{ga~kd|ib}lc~kd|idzga{hc{jb~nc~mfmf|jcwg`ue^zjb|ib{ibyg`vd^vf`vf`yibvf_xg`{h`|h`}h_zh`{jbxhawg`se^pb\wc`yebzgbnfne‚of†oj€idxe^zgaxf_xg`ze^v`Zvc\wd]{ia|ib|gbye_udY|k`neƒngƒmg€jb~h]{h]xhZxhZug\sd\r_YlYTp^Vs`XrbYsaZs`Xp]Vq^Yua\vdZzg]~l_€le‚of}jc|iavc[xe]|ka€og|kbxk_rg[rg^sg^ug_ub[p^[h^Wg^TmaUn_UpbYqaXp`Xm]Wo_YqaYn_Wl`Tl`Uk`Vn_Wm\VjXTj_VoaXn_Vl[RhYOeXLcYJg[Nm^Rrc[xg^xg]seXm^Tm^UpaXrdZwj\|n^nbUh^Sg\Tj]Vj\WgZSf]Pe]Qf^Um_Yn^Si\Nh\PdXLi]Sj]TfYQbVNcXPe[Rj^Vn`Xn]Ul_VhYQiYRm[Um\UlXRjWNgULbSJcWMf]Sc[QaXP^VM]YM\XJc^Tf`Yld[jaYeXPaTL`TL]RJ\SJ\RM[UP[UPcYTd\S_]RXUJYUJ^YOYVKXWKYYHPWIOWLQWNRYNR\LOYLSVJQRHT[Qbn`V`SMeOLaLJ]GL^HH`HE`H@_G\L>]HA]HGbKF^HBYFCXHˆpd‡ocŠoc‰obˆmc‡mc…mc„ma‡nbˆmaˆnd‡oe†pe†od†mcˆnc…qa…pc…mb„jb„kb‡mb†nb…k_‡lb†l`†la†i`…h_ˆlb†lb‡lb…ka„la‡m`…k`†jc„kd…kc…lb†kb…k_…k^„hb‚f_†k`‚k_kaƒic‚haƒh_†ka…k`„jb…hb…hb‡ic„ha‡i`†j_…k`ƒi^„i^„g]„g^…h_„g^‚f\…h^„g^‡jaˆkb†i`‡ja…h_†i`ƒh^„i_„i_…j`„i_…j_†hb„g_…h^ƒh]ƒh^…hbƒg_„ha„ha„ha…ib„haƒf]„g^„i_h^i_j_ƒg`ƒh`ƒg`ƒh^f]‚g]ƒg`ƒh`„ha‚ha‚ha‚ha‚hcƒhb„ha…j`„i_†j_…h`†jbƒg`†ib…i`…i`†ic‡kb…j`‡lb†jd†idˆieˆke‡jb‰mbˆla‡ka†ic‡kb‰mcŠneˆldˆlf…jc‡keˆjb‡i`…i`„j_…kd†kd†ib†hb‡jc…ib†kb†ia‡ja†ia‰ibŠjb…ib„g`‡jc‰leˆjc‰jdˆkeˆkdˆle‡ja‡ja‡ja‰ic‰ld‡kc†kd‡kd‰mfˆkc‡kc†jb†jbˆkc‰ld‰lb‰ld‰le‹ngŠlf‹mhŒoh‹ngŠngŒpi‹pi‹qjŠoiŠpj‰pi‰rkˆqj‡piˆnd‚jc~h`ze]yd\x`Yr\RoXPjUMfQIcNH`LF`LDaMF_JD_ME]KC`OFaNHbOGeRHfVJdVJ`VL`WIbWJ^TG[TH[WI[YMY]Q`bV_`VY\QX\OW^NQ_JR`LP_NP_MTaPVbQZbQ]fU^hY`k\^kZ]lYZlZXlWVkUXmV[mY\jX\lW[kXXiWXhWVgVUhUXkXWjWWhVWjWSfSRhUPiUUnWYoXZpXWmUSjTUnVYs[UpXRlTPjTOiTWoVWpWTrWQrXOrXPqZMpXMnTNkQQnUNkTOjVOpYQpXXt\Ur[RoZMn[PlZQmYRpXQoVQmTPlTTmRTlSUkTPgQOkSMjQMiRMiRJhQIjQJmVLoWLpVImUNpXSqYSmXRiVWkVXkWYgXZhZ]i\WdU\gY^gVagWhi[urgqndhi\koblqckqcmpcnrdlpejlafj_gl_hqbepakralpalkali^mh_pjami_qkawndvi`ug]uh]vh^ylb|oe~ofyjcxjbub^yfa|jc~le~le~mcwhave]~le„rk€ohqjve`paZqaZyhaƒsloiug_xf`zibwibvkbqh`qf^rg_xkc}mf~mfmg}mf|le{ke{lezjdxhaih€lh~jemgziayg`~kfmimfyhazhaxia~lfzhb|iemgzi`vf[{kd}mf{le|icyg`xf_{hayf_vd]vd]ve^yhaug_wg`uc\vc[vb[|g_}kczh`we^wd]vf_yha|ga|ib€og€ogmelc€kele€ngyg_xhazjbzg`xc]xe^}jc~ic~ic{e`we]veZzj^zg^|g_|iau`Yw`UxeYxfYxhZwg[vd[uc[ubZ{g_€nb~lcyh^q^Vvb[wc\}ga€mbƒpeƒpf~jbƒnf€ld€ld}kc{h`~kbyi`wf]rbVqbWrd\re]paZn`Wj[Vf[Sj`VqcXraWraXn_Vo_WqaZp`Zsc[qbYj]TeWOgWOhXQiYRfXQf[Sh\SeWNfULiYNiZNhWNl]Ro_TsbWudZraVqcVrbXrbYue\wg]tfYn^RgZMi]PjaVth`wkbraZdYM`WIlbZ{phxh]nbVj^ScWMcVNeXQeVQaVM]QJ_TLcWOo_Xq_Wk\Uh[Sj^Vl`Wk^Vk]ViWMeTJcULcXNcZO`[O_UL_XMg_Sa[Nf]Sg_UiaXkaYaVNaTLcWOcXQ]SJ[RJXPJZSM_VN`WN[WM]YO_YNYTJVSHRQH]VIWXLQSISRJVVJSXHRWJWUIWRGTWKRXKT[MR`MT_NQ[HR\ILYEJ[E>YCA[GD^LKcRKeOHbHB`GCbI?`J?`KB`MDbODeJAbJAbL=^J>]I?]I<^I@_IA^FC^I?ZGB\K‡nd‡nd†mc…lb†mc…lb…lb„m`ƒk_„l`‡nd…la†mc†mc†mc…mc…q`‡ob‡nc‡mgˆleˆld…l_‰nc‡kb…ib„ha‡lb…h_…i`†ka†ka…ka‚j_ˆm`†k`†jb„jc„jb„ka†jb…j]ƒh\†ib„gaƒh]ƒj`‚i_h^„i_„i_…i`‚k^ƒj`…j`‡jd„g`„g`…ha„haƒga„i_„h^e\…g^…h_„g^ƒf]…h_ƒf]…h_‡ja‡ja‡ja‡ja…h_ƒh^„i_‚g]„i_„i_„i^†gb„ga…h_…k_„i^„i_„i_…i`„i_ƒh_ƒh^ƒh^ƒf]ƒf]ƒh^„i_„i_h^„ha‚f_‚f_„i^ƒh^‚g]ƒg`„ha‚f_ƒib‚hag`‚ha„ibƒg`ƒh]†ja‡ja†i_…h_…h_…ha†ic…gb‡kc‡jc†ia‡jc‰ke‰kfŠmfŠmfˆka‰lc‡jaˆkb‡jc…ha‡j`‡iaˆkd‡jd†ka‡i`†g^‡h_†h_…j_…kd†ic„ia‡haƒh`‡ib…ib‡jc‡ic…ha‡ga‡ga†ib†ha…ha‡jcˆkd‡hbˆkdˆjc†jc‡jaˆkbˆkbˆkd‡kd†jdˆle‡kdˆleˆle†jc†kdˆle‰mfŠng‰lbŠme‹ngpjŠnh‹ni‰ng†le‡mfŠpi†og„nf„ohkeicga~e_|b\y`Xu[TnVOjTKjSKbKCcLDbLCaKC`KC`KC`HBbPHcOHhYMiZN`RFaRFhXNgXMeYMc[N_ZM\YL[YHWXETVFRWFRYJQZKN_NTcTWdVUbSRbQSfRRePQfPRhRQeRRfSUeS\dS^fV]fY_i\al]^k[ZkYXkWWlVYnXZkX[kY]kX]kZ[hY[j\VgUUeSXiVVhUUiUViVRgTShVOkSSkUVkUUjSRhRTkUQkTUoXUoXRkWMeQNeQUkRRkQPnTOnSLlUMlXPnWNlTOlSMjQLgRKfSMhQNhPSlTNkRKiRIkSMlUQoXSpWQnUQoUOmTRmSRlSPiROhPPkSPmTNjSNjSMhQRoWUrZTpYTrZSqYUr^Yt_[o\^o]gqagn^ek]fl_fl_\eWek^eh[mm^uobxofticpk`vqfzrhyrhzpfwncsofpiarjctkctmetndsocsncrj`ujbwkcwjbuicwjctd^wf\zi_nb~md~md~mf}kd{ib}kd|id}je|jd{ibyhazi`|jc|jcohoh|lf{kdsd\uf]td]|me~nh|lfwg`zha}kd{jcvhaviaykc|lezkczjc}mf|le{kdzjc|kdmfmf€og€ji{fd~ie}jflgmf}jf}kfve^xhase]zmcog{hbzgb{hbzh`}kb|ng}ng}ke€of}ia{f^{ha|ib{jbvd]wf^te[r_YraYucZvc[yf^{g_yd\yd\yd\yd^{g_|g`~j_}ka€pd‚qinf€kc~kd€ng}keyg`wg`xibzga|icyf_zg`{e_ze^{f^{h`wg^{j^xe]{f^zg`mdƒod}i]vdWudW~i_†sgˆti‡sh€lbzf[{i^zg[~j_}i]‚mb†oe„peƒoe‚mf|g_jbjbjb{f^yf^vc[vc[ud\vcWr`Yrc\qd\m`WmaWpaZnd\ocYp`Wr_Tn]To_XpaYrb[m]Vm]Vk\TmZUlZTk[SfUNcVLcWMaWOcWNgXOiXOjWNjZLp]Vr_XkWOjZPsdXtfZudXwg[scWqaUtdXraUhZNh[OfZOgZNpeYwj^p^Wi\Pj]Qj_Xj]VhZOg[Qk_VgZQfXQjZTeUO`QJ]QH`SKdWOjYRkYSm\Sm\SgXOhYRi^Vf[ShWPdTM\OG[PH^VM^WNbYOof[oeXh\PcXMdXNe\ScXP[QIZOG\RI_TL]RJZPHXOF\QI`VNZOGYQJ^VN]SMYSJYUKYWMcXOURIQNFUPGXUHUXHXWG]UI]TJWRGSRFVWGU[KTXIUVHQVEHQ?GSAAWAEZEH\IJ_KK`JNbIHdKFcKDcKJjUGhT>`NBaJ?`I>bK<`I<^H=^I<`J=_J?^I?]I;XF?]J„ka‡nd…lb†mc„ka…lb„ka„l_…ma‡oc‰pf‰oe†kaˆmc…lb†lb…n`…m_‡ndˆle‰mf†jb„j_†k`†jc…hc†ja…l`‡jaƒg^…k`…j`†kai^‡m_…k`†jb‚ibƒia‡nd‡kc…i]„h\…ga„f`ƒh]„j`h^„i_‚g]ƒi^…i_ƒi_ƒj`…j`„i^†ha…h`„faƒf`ƒg`ƒg`ƒh^…g^‚g]ƒh^„i_ƒh^„i_„j_…j`…j`„i_„i_„i_…j`„i_„i_ƒh^f\†ka„i^…gb„f`…h_ƒi]„i^ƒh^ƒh^„i_ƒh^ƒh^f\‚g]„g^„g^…h_„i_…j`‚f\‚f_„ha„hbƒh^„h_‚g]f_„ha„ha‚ibƒib„jcg`‚g`ƒg`†jc†ka‡ja‡j_…h_…h_…ha‡jd‡id…h^‡jb‡jdˆkd‹ng‹ngŠme‡jcˆkdˆkb†i`‡k`‡ja†ib‡ib†ib‡jc†i_…ja‡i`†g^ˆi`†h_‡lb„ic„h`‡gb†f`†ga„h`…ib…ha…ha…haˆhbˆhb†ib…ha†ibˆkd‹ngŒoh‹oh‰mf†jc†kaˆmcˆmc‰mf†jc‡kd‡kd†kd†mfŠng‰mfŠmfˆleˆleˆleˆkbˆldˆmf‡me„kdƒic}hb€jcic‚jd|gayg`wf_r`Yn\ToYSmUOnUOhNGgLEcMDcLDbME`LDdJCfLEhNGhOEhQFqZOq`Tl\Pm`SdYKcYKaXIa[L_\L^\O[]OVZKUZKS]IQ\HP^IN]KPaNO`MQgSWjWYkYUhVThTUiSViSUhSShRXjUVfTTaO\dT]eW^f[`k^_j]\iZYiXVhVViUViUVgU\iY_jY\fV]i[[gYXeUVeSWgUUgTYlYUiVTiVRiVNiQOhQQhRShRSjTQhRPjSQjSSmVShUKaNNeQSiPPiPLiOJiNHdNLfTMgRMiQJhOKiPKgRIeRLeMLdNPjSJfNLjRJlROrXTqZVpYRkSVpYWrXQmUPmTMkQMiQRkUQjTPkXTlYWkY^n\htblvebsa^r_\r^]p^]l\hpapodnlamlanmamlbij`jj`ll`nlauncymfxicwld}pi†worj~ng{kdxmeymh‚qoyifwhctg_tjbwndznfzohymdwicvgcvhbuiaviazmb|la|jd|jd|jb|jczha~ld~je|hcyg`zha|ib}kb}lcme~ng{leyicwgaxiavg^wg`xhazjdzjd{jc|jc}jcwe^xg`uha|kdzjcyibwg`ue^zjc|le}mf|kd€ngnglejh}hf~je€mh€lg~kf{hcwe`vf_yibyjc|nf|jazg`yf`}id†rlzrƒum{jdzj`~kc€ld†riohyg`xd^taXzg_xe]raXye^yf^wd\{ibyd^yd\{f^}h`~h`}h`‚jbm_€n`€nb€nc~jb~h`yf^{i_ne€pg{jazi`vf\q_V|i`ld‚mdjb}j_zh^|jbzjazg`k`€nc…rg†rg}i^weY{j]†rg†rg„pek_u`VuaV~laˆuj‹wlmb~i^}g[}ia~ia}h`{f^yd[zfZze]ye]xc[vc[vc[s`Xp\TsaYtc\pc[qe\qdXqaXre[tf\zd\wbYq`Un^Xm]Vm]Vl\Uk[TjZSiUQjWRjWQbSJbSJbUJdXQiZRm\SmZRkXOl\Op]Wq^Wq`Wp`VqcWl^Rp_TqaUrbVo_So^Rj[Oi[Rk\Sk]Qj[PhYMj\PiWPi[Og\O^PI_RKeXLcXPnaYsf^]OHRB<]MGbQJeUNeXPiYRp_Xxe]yaWoXPjWOiXPi[TdWObSL`SK`UM_ULaZQ]VM`WL]TJ`QIcTKaSJcWLcXPaVM\QIZQHZOG\QIbVNcWNbUK]QF_RIbVN^TM^TM^SL\SJWSI\YO_XOZVNVTLXSJTRGNSEYUG`UJ^QGZSIWSGYWHTXLXXMWVHSVHIQCISDFUCHWEFUCL[IM\FVcNQeOQfOI`KG`LEaNDbO\I>\I?]J=\I…lb…la…lb„ma„nc„mb…lb‡oc„ma„ob…lbˆodˆlc†ja†lb„ka…la„lb†jc‡kd‡lc†j`…j\ƒh]ƒg`…ib„i_ƒl_‡ja„i_ƒh^…j`„ja‚j_†l_…k`„haƒib‚i`„ka…h`…j]„j]ƒg`…ib„i^„i_„i^ƒj\„j]ƒi^„i_…i`„i^„i^…k^‚h`g_ƒe`‚f_‚g_‚g]ƒh]„h]ƒi]…k_„j^ƒi]„j^„j]…j`†ka…j`…j`„i_„i_„i_„i_ƒh^ƒh^„i_ƒh^„ga„g_„g^‚h]‚g]‚g`ƒh^ƒh^‚g]‚g]‚g]ƒh^„g^„g^†i`…h_„g^ƒf]‚f_„ha„ha„i^ƒh^‚h]ƒf`ƒg`„ha‚h`…kdhaƒia„hb…hb„ha„ha‡jb‡kcˆld†jc†jc‡kb‡kb‡kaˆkc‰kf‡id‰ke‰le‰lbˆkc‡jb‡jc†ia‡k`…i_„h_ƒf`„ga…h`„h^„k`…i`…g^…g_…haƒha†jc…ib†f`‡ga†g`…g`…ia…h`…h`‡jb‰ib‡ha†ib†ib‰mf‰ngŒqirlŒoh‹oh‡keˆnc‡lbˆmc‡le‡kdˆleˆle‡ng…nf…jd†kd‡le†ke†kd…jc„j`ƒja‚kd€jbzf^wc\qc[sb[t`Yt^XmZTfVOfXNeVKaPF_MCaMC^H?\GAaKCbKCbMEbOFeTHiSKjVMlZOl]Qi]PreXmfYgcTfcSbcQ\_L[_KY`KU]KT_ON\LN]LQ`ON`LNbMOfOOgPQiPSiQPkSVlXVjWVjVUjTVnT[oXUiRViTZlW[jUXdQ[dSZbT^f[`j^]h]\h]TdTUgUSgSUfRZgV^iY\fVZdWZdWZcVXeTYgU\iW\lZVjWUjWSjWRiUNiQMiRQgTTjXTjWQkUQhPQgPQhQNfOJcMKcNOgOLfMJfLGcIFaIH_ILbNLfOKhQLhRMiUKgUNhSPjVNhVNjVLiROnUTv\Yr\YoZ[kX_oZ]oY[mZ[oZXmWYkX[kY[gX^k[bl^el]lnarqeqobmn`kqbep`cn]gm_nncsmeundxpfvoevpgrleslcrlcpj`ulczmg{jf|lh‚plƒpklh|jfzje{md}lg~jiwbaqa]se]vic{ngzndxjbvgate_vgawjdtiaujbujatg^{gbyga{hc|jc}kdzhaye`|hcle€me€mf|ib{g_|ja|kd|ogwicwgbtd^sc]xhayib{kdyicyjexhczgbub]xgaugazfa{gbzfauf`uf`xke|le}mg€ohng‚ngƒngƒpj€lf~ke{iczhb~ke~kfye`{ib|kdxg`xi`{h_zh`lf~keƒoj‚og}kd{hazg_oe†th…rgzgbwe^uaZxe]|i_yfZwc\|h`xe]yf_|ibzh`~jc~ia|f^}g`k`„nc‚nb~k`}ka{h_ze^€jb|h`kc„piƒng{g`{g_}hakc€ld‚pg„ph‚of~k]~m`pgƒqhoe€la}la}j`€lak`€manc€jc}h`|g\yf[vb[yf^~mcwe[}ja|i^yf[yfZzd\|f^}g_{e[|g\{f[zd]wbZwbZwbZtbZo\To\TsaZqaZqc[qbXueYxfZyg]}iah`u`Wm]RiYSiYQk\Sl]Tj[SdTNcRKgUNfTMfTMgWNgXNeUNiXPn\Tn\TgXMiZNm]Ul]Um`Wm]Ul\Ul]Uud\vg]qbVj\OdUJaPHdXOk^Us`YkZRgVNgWO`SKi_Ruh[k^VgYReYMbWN`ULfZQsc[p`XeTLgUMjYPgXOgXNq`Wwd\t_SmYNiXNaRI]PI]QIaVNbWOdZQaYO]WM]VMd[Qk^Vm]VdTN`SL]UKeXNbWM_VL_VL]TJ_VKfYQfZOcTH`QFaTJ]PH\PJaTMaVN`WN\WKVTHZSIVTJVSIWQHTQIPTI]YMbVLcVM_WM]YO[XLXVLZWMZVMZYNQUHLVGMVHNWHPYHV_OYaQYaOZfTVcPR^MO^LM_JJ^KE]NB]L@^M>]L\N@^ID`LE`NAZK=YGXD>XC=WC‡nd†mc‡lb†ka„ka„j`„ka…lb„jc„jc‡lb…ja…j`ƒj`„ka‚i_‚hbh`‚i_„kaƒk_„k`k_ƒk_i]…k_…l_ƒi]†l`„h^„g^…i_ƒf_ƒg`„i_ƒh^…j`„i_„i_‚g]‚f_ƒh_‚h\‚h[‚h\‚h\ƒf^‚f_‚hbƒib„i`…i^…k]„j]„h^„g^†g^‡i`ƒg^ƒg]ƒf]ƒf]…h_…h_„i_„i_„i_ƒi]‚h\ƒi]‚g]g]‚f]‚g^ƒg`‚f_ƒf]g]€e[‚g]€g]h^€f_‚ha„ic„me…mf…nf„ni‚mfƒmf„ng…mejc„i^ƒh_ƒg`ƒg`ƒg`„ha„i_ƒg_…hc„gb…ia„j_†i`†i`…j`‡lb†ka…j`‡ja„g^†i`ˆkb…h_„g^…ha…haƒf^ƒh^ƒh^„j^‚g]‚g^…e_‡gaƒh_‚g]„f]„g^ƒf]„g_…ha„g_„h^ƒf\ƒf]„g`ƒf_ƒf_ƒg`ƒg`ƒg`ƒh^†ka„i^ƒha†jc„i_„i_…j`…j`†i`†j`…j`†ka…jc‚ha…i_ƒi_…j`‰nd‡kaƒh^…kb„mb|h_}jb}kayha~f^|d\t^VmYPfUK`PG^SK_SKYLE\MD\JAYG@^K?^I@^IA_JD`LBbODbRFfVJgVKjYPm]Tn]Vte\pdZmcYleXlgYmgZjk[gjY`gVWaPS_MVdOTeSUfRVeQVhSTiRTiRRjVQkSTkSTkSWmWWkXSnWQmVPlTQlXNhTPkVUnUQmTOlSOkTQlVOjVOjUOjSNhOOjQPjOUnSPjRNjQLiPKdLMdMOeMRgPSfPRcORdPNcOLbOKdPKdPKdOMgPRhRUhSZiTYhTZfT\gW]gX\eX]kZWiVRhRRjRUnUPkQMhQPiRQiSVkUXmWUiTWjUTgQSgQShRQfPRgQRkSSjRRgPVhUYlZWkY]m\esbhudkrflpcmobjqfjodmodqpfrpgppftrhurivphxnhzngykfykhxmgvlesjbugbwfe{he|jg{jfwiewjdujd{le}le~kd}mfyofxpgvjd~nhqk„tnƒtnzoi{lkzihzhg|kh|lhxkezic|lf|lf|lf}mg~mgzlfwicxhbyibyib{kd}ne}md~leƒphlh‚lg„nini}mg|lfygdwd`xgezidzlf~mgzibxf_ic~hb~kd}jcwfaud^vf`zjd}je}je{gbxd_{ia}ib~kdmf}kdzhakdƒoi€mf}je}jexfb~i^‚mbƒjcjb€jb{h`|je}jewg`wg`wkcvkcugave^taZwc]{h`|kbƒpi€meng}jc{ha~jd‡tl†qijb{f^xf]xg^xf^|h`„nfla|i_vdYuc\~kdub[r_Xq^Vwd\{g\wcX{f]xe]wd]ub[p_VtaYt_WuaYr_Wr`WqaXp`Wr`XtaYtcZte\zh]o\Sn[So\UkWQnZVp_Xp`YrbZo`Wqd\m`Xma\na[rd\qb[oaWm^Sg]Sj]Sk^Tj[Rn_Vp`Vxe]zh^zg\{i^}k`r`Uu^YxcZwcXxcYvaYwa[{f^yd\yd\yd\zf[xcXwbZt`Xs`XubZtc[p_Up`SqaUxh\raXn]So]Ul\Uo]Vq_Xp]Vo`Wm^UjYSn[TnZTjXOfWMeYOk[RjYQhVNeTKfWNgXOlaTk_ScWKcVKh\ObZKbXLcWM_OIcQJjXPjYMeWIcUJcUKcSL`RHaRIeTM`QJ]NE_OHcSL_PLcUNdTMaQJ]PH\RJ]WMaWL`VLaVN^RK^RL`SK_SJ[OE[NF\PF`QF`RE\PF]QG\RH_TLdXPbSM_VJ]TGYOE[PG^SK]SL`QI\PI^SMcZSkbZkbWg[U]QL]RN[KI`RKbUMbRK]QI\SJ_UL[PF\PFXQHZUI\UH\TG_TJaTL]SJ[RIXNGWQGXRGYREXSH]VK\SI_SLdXPk^Ve\RaWNaUMbWMbXMb\L^VJ[TG[UJ[ZO\ZP[[PX]TV^RS\MT\MTZLVYM\YMZWMRPDSTHSXJT\MS]KR_MM]KH\IG\IG[H‡ob†na‡maˆna„l`„l`„ka…kd†ld„kb„i^„j^„j^…k_ƒk_‚j^„k`ƒi_‚i_„ka„lai]h^‚j`h^‚i_…i`‚g^‚h\ƒi]ƒi_‚h^ƒh^ƒh^ƒh^ƒh^„i_„i_ƒh^ƒh^‚f_ƒh^ƒi]ƒi[‚h\ƒh]e]„h`gaƒib„h_ƒg\i[ƒh]ƒh^…g^ˆi`‡i^„g^ƒf]ƒe\…h_„g^…h_…j`…i`„i_„j^ƒi]‚h\g[ƒh^f\‚g^‚f_f_ƒf^ƒf]‚g]‚g]„h_‚h_€f_„ib‚kcƒld†ogˆqh„oj„pi„qj„ng‚ldjb„ga‚f_‚f_„haƒh_ƒh^‡ia†ib„fa…hb…ha…h_…ja†ka…j`†ka…h_†h`†ja…h_…h_„h^ƒf]„g^„g`…ha„f^ƒh^ƒh^…j`ƒh^„f^‚f_„g`„f^ƒh^‚d[d[ƒf]„g]„ga…haƒg]„g^ƒf]„g^„g`ƒe`„ha…ia„hb„i_‚g]ƒh^ƒg`ƒga„i_ƒh^ƒh^„i_†j_ˆlc†ka…ib„ibƒib…h_ƒf]‚g]„j`i_~g\j`|f_xd]ve\rc\n`Yt]UnYQgTLeTKaPH\KB\MC\KB\IAYE=]IA^IA_K@_LAcODcPDfSHjXLfZLg]Oi`RkaUmdYmeZjg\ii]efZcfZafZahZej\ck\]gVYdTUdPSfPThUTgTViTViTSjSSlUQlXQnVOjRSmVVmWVmZSoXRnWQmVRmYPlWSnZSnUQoVOmUNmUMjTMiTQlWKgPKhPLgNPkQMjLOlRKhNKhNJgMLfLPfMQjRVmUWlVSiSNgPKfNMfRLfRJeRLeNOeOTgRYiT]kX^jX^iY_iZ_gY_n]^m[\kVYjV[nWVjSUiVUhVViVUhUYiW]mX_m\^kY\lZ\kYXgVWgU[mV^nY`m[bm\an_amagnansgstiwvlsqgtqgonfpmepjcvmfzpiynhzpj|qj}pl|nk~nk|khyjhzliwkgyig{jhygg|if}ki|khziewibzlf€mf€nhmf{lezmfxmeznh~oi‚rl†vpqkzni{lk€pnmllhwhduhbzjd~nh}mg~mg}mgzjdxkevhbwjdzjcxhaxha}kc{ja}kdnglgkf€lg~kf{hcxic{hf{hewhaxhbxke~mg€oi‚phƒke€jc|hcje{id}lgyib{jc|jbog|ha~ld‚ke~hb}jc{ha{hazibƒmf‚lfme|gc{hc{gc‚mb†nd†mc…ldlc|ia~hd}hb~kd~lezh`xf]ve_we`}ib|ia~ldlc~kd|ib~jd|ib|ib€mf‚og‚nfldxc[uc[ve\u_\xc_{d_zd_xb\vc]ub\wc]p]Vp]Vr_Wxf^|h^{g]zh_vc[ub[saZraXq^Vs_Wq]Uq_Wn^Um`Vp_WraXuaYo_UraXr_Up]Vo\TmZTlYQn\To^Wp`XnaZnaYre]rf]g\Vi_XlaZkaXmaWocWk_VfZPj^Tp`Xue\ve\yg\wdZucXvdYweZr_Uq_Xn\Tq_UraVtbZzha{d^yd\yd\yeZyeZvbWw`Xv`Xx`XwaYq]UlXOiYMl[NrbVp`Sm\So^Ui[So]Vud[vc[sbXl[RlZPmXPlWOjUNiYPi\RiXOgWLfVJdTH_QFhXPqe\vj_l`TdXLfZLeYKdXLbWMaQJiWOjVNn\RgZLgXNgXOeUNbSJ_QHdQJcRJ`QH_PG`QJ]OJbRKfVObRK\PH`UM_WMcXPbWO^TL]QI_TM]QJ\SG^SIYMC[LB]OB^QC^RH\QGZOGYNFZOG[NF^UI_VK^TJ[PH^RK[NH^NGXMEYQJ]VNb\S`YP\QJ[OJ]QM[NG`SL_SI]PHYMEXNDXOE[RH_UK[TJZRHZQEZQEZQG`WMc[Q_VNYOHYOF\TI^XK^XK_UK[RH^TJ_UMdYQj`Vg^UeWOcVO^UK]UH\SGYQDYSH\XMZYOZYOUTKSSHSUJUXIVWJUUIYRJUNERNCTSHTXKTYMZ^N]dSXcRR_MS_MQ^L…ma…l`…l`†ma†l]„k^‡la…ia†ja†ka„g]†j_„j^…k_„j^ƒj^†j`‡kaƒj`ƒj`h^i_€g]i^~i]‚i_‚g]„e]„h]‚h\h\i^‚g]ƒf]f\‚g]f\‚g]ƒh^‚g]ƒg_g[ƒh]ƒi]‚h\‚f]ƒf]„i_‚i`‚h_„j_ƒh\ƒi]ƒi^„g^„g^†i_†i^ƒg^ƒh^„i_f\ƒh^„i_„i^ƒi^…j_ƒi^g\g\€h\ƒi]ƒh^‚f`€d]ƒe`„g`ƒf_‚e^‚f_„hb„gaf_ƒha„jc‚ibƒkdƒld‚jd‚kdƒkd‚jc€j`~h^ƒf_„haƒg`„i`„i_ƒh^†j^…h_†ib‡jd‡jb†i`…ic‡jd„h^†j`†h`…i_ƒh^„j_ƒi_ƒh^f\€f\ƒf]ƒf]ƒf]„i_ƒh^ƒh^…h_ƒf^d]ƒf_ƒf^ƒf]‚e]d[ƒf]…h`„g`ƒf_ƒf_ƒf]‚e[„h^„g_„g`‚f_„ha‚f_ƒh^ƒh^‚g]„ha„hb„i_„i_…j`ƒh^‡k`†k`…ib…ibƒhai_…h_ƒh^f\~g^|h]xeZv`Yr^Vp_VlYSgXQbUMcNFaNF]KC_MG[GA\G@[K@]KA]IA`LDcOFdRJbSHeWJf[LaWHd\Mf^Qd`RabQdgV^eU^dTafWahX`iZ_hZ^fZ_g\ah^ej_el``i[[fWXfUWfTXkXWhVXhVXjVSiUPlTPkWPlTLiPNkRMjSQlXQmVQlURmVTn[SmYSmYSmUQpWMpXKnVJkRMjRLkSIgOGeNJgOLiQKhPJgMJgOJgNJgNPiRSiRUlUXoXZr[TkWRjURiVRiVPiUOhTQiSRgQVjUYjU[kX]iW\fV^fXbi\en^fn^el\dk[fo\`kYXhWYiXYgW[hVam[do^el^gm`hpbcl^ck]cm^hqbkpbnobnodopfmpfuqiyskyrjxpiungokbpmeslewmfylfzmg|nh}ohokpm~ok|kiyhgxjh{li}nizlg{jgzgfykg{lgzke|ng€pj~mg€lh~kf|id|je}mg~pj~qkoi€oiƒsm}oiymg{lhpk€mi}jf{igwhd|kh}li|lh|lezjdykdylfzlfxjdwg`ve^xe^|ga~jd€mf~le}jd{hc~je}ie{hcye`yfcwebwgaxga|nhqk~mg~je{g`|ga{fbzfdyea|gczha}kdohnf~le}jc€jd}fahc…oike|icƒmg€jd}fa}gbkelf…of‚lbib‚lc€jd}jcic€le}ible~h`€h_|hc{hb{ib~le{kbzja|ib{hayf_wd]wf_zibzg^{h`|g_xd\vc[qaXs^Yzd`}dawa]s_Zq^Zr]Vq^Wr_Wr_XraXve\uc[vd\r`Wn^UqaXqaXq_Wp]Un\Tq^Wp_Wtd\raXr`Xr^Vs_Wr`XtcZxd]ub[q^WlYQn[Sq_Us`Ysa[k]Wk]VnaZvf]o_YnbYj_Vi`TnaUreXo_Vo_VraYscZrd[td[saUp^Ur_Wvc[taZr_Wn\UkZQrbVwg\|kbxg_yc]vaYxdYxcYwcXt`Xu`ToYQr\Ts^Uq]TnZThWMhWMhXMhWMl\Rn]Sm]UqaWzg[yg[tcWq_Um[OkZOk[Ro`Wzi`jVPaQFdTHhXLk[Nl^Rm^UfXPdWNeVNgXMj\OgXJcTIbSJfTMgUNjYPr`Vj^PgYNiXOfTMcTKcULgVLgVKaSFaSI]QF]QJaUMeUNcSLaSL`TL^TK`UMcWOfXPcUMZPHTLC\RI`TK\PH\LD[NCZQC\PE[PH[RJXNGUJCZNE^RG^TJ\SJZQHZMH\NH^QJXNFTMDLI@OH@XPGZPI\QJ\RJZOG]SI]RF]QG[PG]SIXOEXQD^WI`XNj_UeZPYOFUPDVTIVTGYTKZRJ\RK]TKaYMdZM`XJ^UI[RH]ULbZQc\T]TLZOJ[QI[SJZUI`VMZQGXQFTNDURGYVJVRJQPFTSHRVKRUISVISQISPGTODTQDSRGXXL]^Q`bUY^PTYKUYKUYK„l`‡ocƒl`‚l`‡n^‡m_‡lb‡la„i_„j^†j_ƒh]„j_ƒi]„j^„j^…j`„i_h^ƒj`i^i^h^j_€i^€h^ƒg^ƒc[ƒh[h\€h\€g\g]ƒf]ƒh^f\‚f\f\f\f\g\‚h\gZg[f]c[ƒg\ƒh]h^h^‚h[…j\ƒg[ƒg]„g^ƒf]ƒg\…j]‚h_‚h^€g]f\h^‚i_…k^‚i\„j^ƒh^f\ƒh^‚i]i]ƒh^‚g_d^ƒe`ƒf_‚f_‚d^e_„ha‚f_ƒg`‚g_ƒg`€f_g`€f`e^‚f_‚g^h_h]~h]ƒgaƒg`‚f`„j_…k`ƒh^„i\…j]…h^‡jb‡ja…i_…ib„gaƒh^…g^…h_„h]ƒh^ƒg]ƒg^ƒh^f[f[‚f]ƒf\…g^„i_ƒg]‚f^…h^…h`‚f_‚f_‚e]cZ‚e]ƒe]‚e\„g^„ga„g`„fa„g_‚f[„h]„g]„g_‚f_ƒg`„haƒh^„i_ƒh^„ha„ha„i_„i_„i_†kaˆma‡la†jc„hb‚h`€g]€f]|cY{cYwcWq^SjZNlXPfSKcQJ`MG\LEWHAZF>[I@ZI@]JD`JDcID^MBdSGcRFfTLeXNdXOc[Oa]M^]K]_MY_M\bS_cT^eV\iXZhVYiT^kW\hV^hXahZdh^ee^gf_gjaei_`f[_gZ_j[`k\]k[]iX_k[]n[UlYRnYOkWNiRJgOJgNKiRLjTOjSQkTRlUSkWQkWRjVOkWPnXLpXMqWKmTNlRKmUIkSJjRLjUKjUJhSKfNMjQIgMQkSVmUWnUYlWXnXYo[Xn[SiVUkXUkXTjWShUWnWXlV[lW]nX_nZ_kY\gWaj[dj^lqdil_jk]ooalo`jn_am_bn_al]cl\jsbksbllaopcnpdprgnqeoqfoqgqoevndyoiwpitqizpi}pkymgxngsngnleqmeungymgykevhazkd~nhoi}nj}mjxjgvjfxjh}oj}oi|nhzievgewkfwldyme{nenf~md}id|ic|jd€mg„qlƒpkrl~ni}mg|lf}nhwlf}ng€og€mglg}kgyjg{igxfd|kizkdzje{kewkexkeugayib{ibxg_}eb~gb{g`€mf|lcyja~je~jdzfazgbygewfczhc{ke|mgzkezid|hb~ld~ke|ge|gexc_yfa€jd‚nh„pilewe_xg_~eb€gc„mh„nh{e`|g`jg€je‚lgjd€hb‚jc€kclcka…mg‚mg€og}kdyia{ia}lckdh`hbyd^yg`yhbxibuh`zg`uc\tbZtd]ud]td]yg^ye^s_WtaYsaXtd[zf\kb„ldzf_p^Vp_Xt^Wq\Vq^Wr`Yo_Uo]Tuc\raYo`Wo`Vk]Rj^Sq_Xq^WsaZs`Ytc\sd]p^Ts^Vs^Vt_WsbYraYt`[wc]s`Yp^Uq_UsaVr^Vp_Ym]Yi[Wp^XtcZvc\tc[pcXi]QqeVtgXxe^uc[p_Vo]Tq`XpaXp_To]Uo\VoZVn[Up]Vn]Up_VrbV|l`yh`uc\wa[v`YvaXubVt_Vr^Vo^RjZNjXOjZQjYRhVOgUNgUNkYQl[Rn^Ro_Ro]Ur`TwdVubTvdVwfYs^Sl[Pi^Rpe[sbYhQKbPGcSGeUHgWKj\PfWNdSMdSMdRKeSKhVLgUJfVKhWNiWPhVOiWNgWKbWIgXNjYPfTMfWNcUKdTHaREcVHcVHcWLbWMaUM_SKfWOiYRdVOaUM`UM_SK_RJ[OFWMEUNE_VL_TKaRJ^PH]QGXOB\PD^UJ\SKWMFWME\PFaUK`UK[RH[RIYLFXJCZOFVOFOLCPMBWPGVLDUODWOFXNE^VKaXK`WI_RG^RG^TK[SHYREXTF`WMi^UcWM[RHTPEUWLVYJYXL\ULXNFWNF]SJcXJbWJ^UH[RHXQHYTKYSKWOIXOKZQL[TLXSJ]SJYOG^UL]WL[VIWTGUSIRQGPTIMUJJUHHSFPSKTUKURHXUG[UK]XO\ZP^^T]\RWVLUTJVTI…ka…lb…jc…ld…k^†l`†l`ƒjai^ƒi`k_€i]€i]€i^ƒj^„j^…h_ƒf]‚g]€g]i_€j_€f]€f\ƒh^‚g]‚f\…h_€e\d]‚f^f^ƒf\„i]„h^i^€h^ƒf]d[~f\ƒg_e]f\f\f]e_f\ƒg_ƒg`‚g\ƒi\ƒjZ‚iY„h]ƒf_ƒf`€d^€g_…j^„g]„i_‚g]ƒf`ƒg`…h_„g_…g_ƒh^ƒh^h^„i[ƒh[ƒi]ƒh]€g]g^„d^„e]‚eZg[h_f_„ead^d]€d]€e\~e[~fZfZg[‚h\‚g[‚fZ„g^„g^ƒf]ƒf]ƒh^…j`„j^„h]…h\‰ja†i`…j`„g`„g`ƒg`ƒg`‚h`€e^f_f_g`€f_€g`€f_e^ƒhaƒg`ƒf]„g\…i[‚f^e^ƒg`‚f_‚f_e^i[ƒh^‚f_„g`ƒf\…i^„g^„g^h\„i`„hb„hb…gb„gb…ib‡ia‡j`†h_‡jc†ib†ib‡ic‡jc‰keƒnc…mc‚i_€ha}f^wd\t]Wq_SkYMkUMgPIjPE_KD[IB[JC\H@_JB]LC[HA^KD_MFaNGaOHbOHgVMiYPh[QdZOc\Q_ZP]]OZ^NZcOXfPVdNWdNXjXXkZZn[ZmZ[iX\hV_eXaeYdfZedZid`lecjfbjfaihchi`hj`il`embak^]k]^m^^n]\m[TlTNjSGeOGgQHhPMjROkROiQOiQOiQPjRQkSOkROmTPpWNnULlSMlTMpVLoUKnTOoUNnTMmSQnUPmTNkRUnVXnXYlWZkYXlYZq_UpYVmVXlXYkZ[lZ`m[dp^boZcq\ep^hq`dm]go^gn]ko_tqdwpcyqeyqeuqdsrdpofqoeoncspfushusirnfuphxpjyrjzpizohvngvke{lgoi€ql|qj~ph}ph{ohynjvlivnlxkfwjdzke}mg|iflikf}je}ke}jg€mjmj~ji~ki|khxjcvjbwkd{nf~mh€li}ge|ie{kdlilj€kiljnk}miƒqkmf~mgzlfylhzliƒojƒokmhkf{kewicuhbvha|id{hczhcwgasebzjgzidyjdyhbwd_sc]ve_zib~ohohng}li|hfid}ga€kflfje}jemf€nf€keƒme~ma{j`yib~jg}kd…pg€mg€mewg`zibxf_we^{e_}jd|hc}id|d`ecƒke„le„of~iayf_~jc„kfƒkeƒmg‚le‚jb€ia|hb|hd|fe€lfzg`zg_~fa{e^vc\xe]vf]tf\xe^we]sdYuf\vg]vd]td^raZr`Yub[{g`|gazeZzf\|h`{gat`]q`\ub[p\Tq[SxbWycWtaTweYvcYtcYkYRlZTlZUs\Vs_Xp_Xn^Wo_Xn]ToYToZTpZTpZUoYTpYTt\Vv_Yv`Ys^Vq^Uo^Sw_Zs`YraYs]Xp\Wl[Ur`Ytc[wg[qaTtcXwd[vbZs^Vs^Vr^Vs^Vr^VpZRp\To^Un]Tq]Ut_WrbUp`So_SrbVtdYscZt`Xp^Tq`Tk\Pj\Ti[Tl]TkZQiXOhWNiXOkYPm[Qm]Rk\SiZQkZQkXQlYMq]Rs^Um[Ro_Ul^UhZMhXKhYMh[RgWOgPKcRGdTHgVLgVNkYRjYQdWLbTIbTHeUHiYMiYMpaTsaYfSNbPJaSKaXJbVJ_TH^TG]OFbQIcPJcUHaVJbYMbYMcYLeWKaRKcUNg[Sk`Um`ViYPfTKbPI_PJZNHYSIWRG\OIYOIUNIWQJ^VK\PDXOEXKEXLHYLH`RIbUH]RLZNHWLDXLE\MGZLHVOHZPHWKC]NF[NDXMCUOFWRIYTK^UL`SJ]NCYQFaVOaVQ`SO^RKYPE`SI\PF_TJ[SIXTIYVKSUJWUI^SI\QGXQGYVJXTLYRIZRHXMEYQFVMCTSHWSI_TMbUO`ULa[P_SK[RH[VK][PXZMSXIO]KR\KWWKVRHSMDRKCSNAXVJa]RaWN^UKZTKVTHYWLZVMWUKURJSOI‡nd†mc…lc…kd…j_…j_„i_€g]h_‚g`i^i]k_€i]‚i]‚h\…g_ƒg^ƒh^€g]h^i^h^‚h^ƒh^‚h^€d[‚e\€g\g]e^‚f^‚f\ƒf]‚f]g]g]‚e\e\~g\e_f]f[f[e]f_‚g]‚g^‚f^‚h]‚h[gX‚h[ƒg\„g`ƒf_‚g^h^‚h_f^ƒh^„h_ƒg_„e^e[„g^ƒg^‚g]‚g]‚g]ƒi\„i^ƒi]„i^h^€g]‚h_‚h^h[h[€g]f]ƒf`€c\‚f^€d]‚e[€e[e]g^e]ƒg_‚f^ƒe^‚e\„h_…h_ƒh^‚g]ƒh^ƒi]ƒh]…g\ˆi`…i_„i^„g`‚f_‚f_ƒg`‚f_f_€e_d^f^€e]e\‚h^€g]‚g_e^ƒf^‚dZƒf[ƒf^‚f_‚f_‚f_‚f_f^‚h]‚g]‚g^ƒg^…h_…i^…f_„g^…h_ƒg^†jc„gb…jc†ib‡kd†jc†ib†jc…jc„ib†jc†kd…jc…jc€k_h]}c[xaYu^UmZRfRJcRE`PD\IB]GB]H=aID]JC^JBeOGeOGdRHeSIaQGaSIcVKbWKbWLc\Oa\O^\M[]NX\MW_OUbQWeTXiUViTVjSXlTYnZYo[Zn[YlYZgWZeU_bW^aUabXcaXhd`nffojgmhdlhdjebig`ihahkadk`am_\l\YmYYmXVnVSnWMiUKiTMlTPnUPlTQlTOiRNhPQkSSjSOiROlTQqXJnTJlSMmTNpWOnVOmVPoWOmUSpXTp[Uq[Tp[Zr]YoZ[mZ^n\YmZ[q][q^]n]]lZ`m_cm_ipblpaorcpsdmqdnrepqdrrerrevtgum}tk€ul€vm{tkxqgxqjvpgysivqhuofythypj|rl{pi|oi{nh|nhynh|oi|nh€pj~pj{nh~pjpm~sn{okymjzmkykezjd|lf}mg{jh{hezhczhc{jd}kh€nk~li~ki}ig|jhzle{ng|ph|og}kg}ig‚mkmj‚qj…qmmi€kiƒnllj|minh~le{ke|mg{ni}pk„pk„pkmhkf{jdxicxkdxjc{hczhcygcziezif{jg{keyicyfaxfazh`zha~le~lflf‚nimk~kflfid~jdle~kflgmgle€id‚jb|i]zg`{hc|hchc„nf‡qk~kd{ha{ib{g`id€kc‚nfng~jd€ichc~hb~ibldƒnfkdke€ic~gajd‚kd€jb~i`zgazf`zfc{gb{ga{h`}gc}gayd^taZsaYrbZxd]zh_sdZseZvf^saZtb[uc\r`YsaZwd]tbZtaU{i]|iatb[n^Xn^Xn\UnZSr]UvaWt_Vt`VtbXmZQlZRm\Sn]Ur_Zr\VnZTkZSm]Vp`Yn\VlYQjWPiVOn[Tp\Ws`Zu^Ws]Vq\So[Qo]Rq_Tu_Yp^Xn\Up\Vp[Vl\Vpa[ve^sbXscXtaXt`YtbYtaYq_Wq^Vp]UjXPnYQkYPkZQo]Un\To[So^SqaVrbWtc[q_Xn\TmZTkYQl]Qj\PiYQeWOgXOhXOhVMo\Ts_Wp\Uo\Tm]SiZQgWNkZPlYQn[Rq\UoZQfTKeUMeYNfYNkYPdUJ^QIaRIfQJgVNgWNhXOiYPl\SgWOcWKfWKcUIdWJfWJfUIk\PfUMaOI`MGaSKbYLbTJ\OEWND\SI_UKbWLfXMcXM]TH_VJcXMgYOfYPgZQdZPgZQh[QiYMeVM^MF[LFUJCVNEZSH\PGXMFRKCTMEWNDXMBZNDYMFZNIaUOfXNcVIVKDWLEXNEYNE]PH\NIYNFVLCVMD\QH[PF_QGZQHZQIZQH[QG\PF`PH^UKaWO_TP^SN]SK^UK^SI`VL`WM_WL^XM_XN_\Q_WMaUK`SI[QGXRGWUKZSI]TJ]TI[RFVOCROG\VMe[QcXNdZQ`XQ\QHWLEYSHUTITTITWJQXHVYJ\ZNYRGXNFWMDWQFWTJWSI\SJYOGUNFUSGYWLYULWUKWTLWSK„l`„ka…lbƒja…j`…j`‚g]gae_€g^‚h\€h\i]€i^‚i]ƒh\‚h\f\‚g]h^‚i_h^€g]g]f\eZ‚f\d[‚i[hZf\‚f_€e\f\€d[}f[~f[d[ƒg^€h^e^h^‚h\‚h\ƒh^„ha‚g]ƒh^f\‚g^g[‚hZ‚h]e\‚e]d[‚i]~i\g`€f_‚g]ƒf]ƒf\„f[‚e\‚f]ƒh^ƒh^‚g]ƒh^f\„j`h^h^f\f\i^}gZ~gX~gX~gYeZ€f_d]e^‚e\ƒf]„f]e^€e^‚e_„ha‚f_ƒf_ƒf]„g^ƒh^ƒh^†j`‚h^‚h\„i]ƒg\…g_ƒg]f\‚f_€e]€d]‚f_€d]e^‚f_f\‚g^f\f[eY‚h]‚f^‚e^ƒf_‚e^‚d[e^ƒg`‚f_€e^‚f_‚f_‚g\f\‚g]„i_…i`…h`‡gb‡g`ˆkb‡ia‡ic†ic‚ja‚i_ƒib†jc†id…ic‚kcia‚kcg_~g_|e]waVt\SqWPkTLcOG`MFaMA]J=\I=^HC`JE`MCjQJhULhTLpZOq]Rm]Qf[MbXJ`WI^XI[YIYWHZ\NX]NV_OUbQSdSSeTUiVWmZXo[TmXVkUYoWVoXZq[Zn[XkXXdT[eU[bW\aV]aU\^Tca[gealgdjeckeckfcidagd_fe_ch]`j]VhWRhSTkTTmVToXOkTOlUPnVPmVOkTPmVQkTSlUSjTQhRRlUNkTNmVLlTJkSMlUPlUPlUOkTQlUQlUVpZZraZraZr`Zo]^o^bq_aq`bracradraiqdhl_hlaikaspfuqevoexqgxqixph{sj}tm€unuo„vo†wp†vp†vp†xq€tm‚uo~qj|oizpg|rj~tk~rl€rl€rl€pj~nh€ni€rl~pj}oi}oi}oi}oirpqn€ro}pj{lg|lg{lf}mg}mg|lf{jhyheyjcxic{ke{jg}lh|khli€lj}mh{ke~nh{nfoh|kg€mj„qnƒpm„rk„qj€lf…pn‚nlnnnolg}je|lfoi€pj€ql„qjƒojmhmh€oiykeymdzjb}je}id}jg€mk}mi~ljoilg}jf~lgldle}ldkg‚mkƒomplnhkf}g`}hblemh€mh€mf|ic~fa€h`~i`}ib}id{gbhc…leŒuo…ni}jcke~hb†mgƒmdˆrj‡tlnf|gahb~kd~kcld€kc…nggazd^yb\‚jdƒlfleicxf^zf`~ke~je~kc}ja}fava\vb]vb]ua]ta\wa[uc[tcZsd[uc\raYt_Yq^Wp^Wo^Wm_WpaYueYxg[seXm^Um\Ul_Wn^Un^Vs`Yn[TmZSlZSo\UjWPmZRp^Vn]Tn]TlXQkXPjXPn\UjZSlZSlZQjYPlZSo]Vn\Un[Up[Tq^TlZOp^Sp^Ro_Rp\Uk]Tl\Ur_Xr_Xpa[rd^qb\o^Vr_Xs_Xw`[n\TjXOjWOn[So\Ts`Xq]UnZRk[Qq`Ws`XubZp^Xq_Xp^Wq_Xm[TkYRfVOhWPfWNfWNdWKbQEgWPm]Tq^Vr_Wu^WpZPp\UlZSk\SqbYo^UkXPkZQlXPiVNjVOfWKeWKeXOcSJ`OG]QDbUIgUJfWPfVNeVMdVLbTIcUJgXOhYPdUK`QH_OF`QHbSGbQJcPI^MG^OG]TF_OG\OGZQGWQFXSF\UG`TM`UM^SK]RJ`UL`UMaWM]SI_TJcWKeWKcUI]RHXLCTIBWICWKC]QG\PFWMCULCTLCWME]OG\PFYMDVJDVJD]PG]PEWLEXLEWMCYOE[NE\OG]OHYOFZTKZTK\PHfTMdUN`SK\QG[PF^RH^SI`WMZTJYQJ\SLaZPh_U^UKZQG`VL`VLaWMg^UmeZ`WL`PG_PG[QGZRHYVKYTJWOB^UHYPDYRD\VQd\SbYMaXJcZO^UM^QJXNFZRIUQFTTHRSGRTHXYMYYJWSH[SJ_UKXQHURITQGYOIXNGTOFRPEVTIYYMXVMZVLZUL‡oc…lbƒj`ƒj`…j`‚g]„i_h^€g]€g^‚h\h\i]g[‚i^‚h\g[‚h\‚g]‚g]e]€f`€g]g]€e[f\e\‚e\€iZhZ~e[ƒh^‚g]g\e\~g\}eZ‚e\f\€i^‚ha~f[€h\g[‚g\ƒg_‚g]‚g]g[g[‚h\ƒi]ƒh^ƒg]‚g[€dY€f[~h\d^~d^€e[e\ƒe\ƒeZe\‚g]‚g]ƒh^‚e\ƒg]f\€g^h^€g^h^f\~i^i\~gX€iZfYg\e^‚f_f\‚e\e\ƒf\ƒhbf_‚e_‚f_‚f_„ga‚e\„i_ƒh^‚h^€h^€g]h^e[d[‚f[ƒg\gZe^‚f_e^‚f_e^e^e]f\€e[€e[fZg[f[€d\d]ƒe`‚f_d\ƒga‚f_‚f_ƒg`„haƒh`„g`„h^‚g]†ka…j`…ib‰hd‰keˆkc†i`‡ld‡jd„jb„la‚ha‚ha…ke„le~h`{f^vaYt_Wr]UnYQkSLhNGfLE`JB]J@[K?cJ@bK?cLDdMHhSMjWKmYQpaVl_RpaUmbTf`RbaN_`M[^KX^JV]JU_KX_OXaQ[fVXgVVhVTiWUjUVlZWm[UjYXkXZnWWoYWqZWoXUhVWgTVcRVbUWaSV_RT\OZaVZaX_b[cc]dd\db\dd]`c\`c[^dYXgYTiUQiSPkRSlVRlUNiRRnWQnWOoWOlUTpYTnWXqZTkUVkUWnXSnWSoXNnVPmVOlUSlXQiVRiVTiVVlYYn[[o_^pa_qcaqcdqafqaiscircotirtitogrmdnkbqjbxof~qi{nf}og|niqlsm‚tn‡wq…uo†sqˆvs„spˆvs‰vs‰vsˆto„qlok€pj‚slrjƒrl‚pk…rm†rn‡so…qlƒrm€qk}oi~pjsm€rlrp€qn}lj~mgnimfnioioj}mhmk}lj{ke{keyic|jgzjf{jgnj‚ol‚mi|lf}mg€ojqjƒrnpm‚om‚ok†sl†sl…rl†rpƒpmkl~jj|ielg‚ojoi}mg~nh„rk…sl„pk…ql€nk}kh}ofqi‚ni„ok„pm‚nmnk€om…rn‚ojƒpkƒnjme~ld~jemh‚ml‚om€oi~jeidic}icngzic|id|ib~ga€jd‚ld|f`|gb}id{gb}f`‡nhŠsnƒnh„ohƒmg‰pi‰oi„jb‡pi†rk{h`{ia„mgng€me}h`xc[|e^gazg_~jcƒke€hczf_~leng}jc}id{gazg`zh]|jcxe^zg`zg`|hbvb]s]Xs_XsbYud[saZr^Yu`Yub[r`Yp`Yl_Wrg^yi]m]Qm^Uk[Rk[Tp_XnaXr`Xp]VlYSkYQjXQlVPkUOlYRo\TlZQl[RjZPlZQkYRjWPiWPk[Um\Tq_VrbWm[To]Vp^Wq_Vq^Xo]So]RkYOp^Rq^VobXpbXs`Yq^Wm\Ul]Wl[UmZVo^Vr]Vp[RkXPkXPn[Sn[Sp]Uo\Tm\Sl\Rq^Vxd]wf]p_Vn[ViXPl[TiXQiWPjYRdVNbQKcTKdULgYNh[NhXRjYRm]Sn[SmYOo[QlZSkYRiYRl]TgULhTLiXPo]To[TiWLeWKdVJaUNdRJfVMcVJbXKaSE^OGbRKbTKbSJaSHeVKfWNfWNeVM_SI^SH\PF\PF]NFaQJ^OH^PH[PF\MG[OG[QIVPEVPFZSG]SJ`UM^SK[PH[PH^SK\SI]TJ`TJ^QG_QE]ODYNEWLDYMGZLEXKCXLBXNEYOEULBWNCWLCVKCZOEULBVMDXPFVLDYOETJDTI@UL@UL?[OD^RH^OGYOFWQHXQH`ULgVOgXOcTK^OF[MCXLC\OHZQFZRHUPGVQHZRI]TJ[RH[RHYOE\RH`VLbVL\PFZNDYNDXNDXOEWOEKI=PK@[SG\RF[SF`YJ_WR_XP_UJaXK]UI]TLaSM]SJYPGVPGVRGUTITUKSVHNSDRTETRGUMGSMDPOESSGVMFXOHTOHQPEPQETWKUWKVUKZVL„l`‡pcj^‚i_ƒi^‚h]ƒh]i\i\€hZ„h]„i^‚j^€h\€g[€fZh[‚g[‚g]‚f\e^€e^€g]g]f\€e[€d[€d[h[~fZ~e[f]‚h\‚h\‚f]~g\}f\‚e\‚g]j_€j_~h]i\h[g\‚g]g]g\~gZi]€h]h_g[‚h[‚gZƒhZ€f[}f\e\d\dZ‚f\d\d\d^‚f`e_ƒf_d]‚e^~f_g`g^h^€g]~e[}d[€f[fZ€gZ€f[‚g^‚e]ƒg]‚g]f\fZƒg\‚i`‚g_‚f^ƒg_„g_„g`‚h]ƒh^ƒg]f\€g]f]€g]e[bY‚f[g\gZ€f`f^e^€d]c\d]c]€c]e\€d\€d\e[€c]‚e_„fa„fa‚e]…h^ƒg`‚f_ƒg`‚f_ƒg`ƒg`ƒf`…h`†ja‡lb‡lc‡je‡ifˆjeˆke…kc†kd„hc„jc†kehah`}f^zd\u_WpZQkUMiSKdOGcMEeKDdJCcHAbLCbOD`PDeQIgTJiTMiWQhZPh^NjbUjfXcbScbRabQ[bPWaNWcQVcPUdQSdPTeQVdRZiW\lYWjWTiVSiVShRUjWSk\QhYSkWTjTVoYTnYSnWSlUSiRQeOSfUUgVRdRRdSUeVScUSdUZfX[cVZbVYcWWdXWcWVeXWiXTkWUlVWnWTnYSmVOhPQlSOkTMlWNjUPlWTmXTnXVkVYmYZo[XnZVoZWr]Vq[TnXYm[YlZYkYZn\`r``r_`o]ap^dp_gqdksfmqfsuiuujwsiyqi{oi{mhunexnd}ohoh~nhrl„rpƒqoƒqo‚pn†ro„pn„qm†to‚rm„rn†rn…ol†pnˆsnˆto…rm‚qlph„ql‡snˆtoˆto†rm„ql…ql‚pk‚smƒuoƒuoƒsm„qpol‚olƒpl‚nimh€mhpjƒsm€pk~mj|mjlf~jekf€lj‚mkƒnlnininimhƒpk‡toˆvo†tppmpnˆtq‹xpˆso…qn†tq€ol‚om‚nlnjƒpk€mhlgng‹xq‰yqŒyrŠwqˆtomjpm„sn…tmˆtoƒojmi‚okƒqn†sp†sn€mh‚nimh€mg‚ojni€ljlikivf`xe_ic~hb}hb~kc|hd{gb€jdjd}jcne{fayf`{gb}jdjd„mg€le‚oh…sk‡rl‹rlhbe_†ngˆqk{gakemf}ga}hazf^ze]zd]|fa{i`|h`}f_}e_}ib€ng‚og}jcyf`zg`yf_|j`{h_yg]zg`ye_}jcwd]yb]ye_tc[p_Ws`Zt`[uc[zg`wf_p`Ym`Xrf^q_WkZRkYRmZUnZUmYTm]Vn\Tp]Uo\Rm[QlZPmXNoZRp\Tp]VlYRkWQdUIhXNmZRn[Tp]Xo^Xl[Rl[Rn]Un]Tn\Vp^WlYSp^Wp^Vp\Vp]Ur`VsaXpaXo_Vq]Uq[Um\Ur_Wo\UmZTjXQjXOl[Po^Up`Vl[RjYPo^Up_Vp`WraXs`Xr_WkZPgXOgXQgXQgWPgXPcSLcTLaRGaSIcSLfXPi]Sh]QjYRgTMiXOl[Rk\Pk[OhUOeRMgWOk[Tl[RjXOgVPeVMgUMgVKhYMeYK`ULdSJfULcVL`VI`TGgXPdVM`RIaTJdVLcUMcTKeWNaUK]PG[OFYNDYMD]PFbRJ`QI\PF[PG]RI\RJ^VL_UL]QH[PGZPG\SI^SJ]QHZPGZQHZSJ]TL_RJ_OG]ME\MFWLCYNFWLE]OIZNF\PF\PIWMCXNBXNAUL@VLBUKBWPE[UKWRIUOFVOHXNGVLC\SF`WJ^RF`TH_SJ\SI[SJ[RI\QH_RKcXNdXN_PG\LD[NFZOGYNDUMCXQGXRHYQFZOE[PFZNDTJ@ZPF_UL]SI_SIWOESLAQNCYUJ]YNfdY_YPYPGXNDZQE\TI[QIWLDXNG[PH]TJbYLdUO]OJULCUNEZTLVSITPHQREMSCMTDPQETNFQMCPODNLBVOFWPGUQHPSGLQENUHNTHTVJZXM„l`…m`‚j^ƒi_ƒi]ƒj^ƒi\iZhXgW‚f[fZ~fZg[}fZ€fZhY~gY€e[f\€d^‚f_€h^‚h^f\€e[‚f]ƒg]i]}f[f\€h\€gZƒiY„h^g]f\…h_ƒg]i^}i^h]€iZ€iZ‚h]ƒg]€h]€g]€iZ€i[€g\e]€fY‚hY€eVƒhZf[}d^€dX€dZ~cY€d[d^e^d\e]‚f^ƒf_‚e^c\~f_~h_}f_f\f\e[€c\d\€fZ‚h\e]‚f_c[ƒf]ƒe]€fZh\€h\€h\‚i]ƒi]‚h\…j_ƒg\ƒg]‚f\e\}d[€f\f\€f]e[d[eZ€g[~fZ€f_e^€d]€d]d]€c\c]b]ƒe`‚e^‚e^‚e^ƒf`b_‚d`ƒe`ƒf^‚h\‚f_e^ƒg`ƒg`…ib…ia†ic†ia†ia‡lc‡lc…ke†ieƒid…kcƒjc€ib}f`ga}e_ybZu^Uo[PgTIhQIdMEbKC`IAbKBaJBfMGjQIkQKpZNq^Tn^Rh\Si\Rh[RcYR`[OacMbaS]dSZcR[dRXdPSfPTgUReRReSThUSgTTiVSgTUjWWlYSkWPiUMeQMhOOjVOkYOl[OkWPlURjYQlXPmVOlTLiONhNNiUQlUQlURlUVnYUkYSmVTjVVfUTeRSeUUhXUiYRgVTkYZr_XnZ[p\Wp\QiROgOOjRKgPIhSMhTJfSMfSTlXWlYXmZZlYWkXZo\Zq^\r_Yn\[m\_p_^o^etcdtbao_do[do\hqapuiorgsphvqg{sjyogoi‚pnpkzof|oe~og~ohqjrl„ql‚ojniqkqk€pjƒoj„rm€pjqkƒoj‡qlˆqo‹tr†rm„oj„rl~oh…ql‡snˆto‡sn†sn„qlˆto…snsmsmsmƒsl†snˆtp…pn„omlijhƒpk„ql…uo€oi|mj~ol…ql„pk†rl…po‚mkkjni‚oj„qlƒpk…rm…pm„rkƒpm‚sp…tqxuŒxr‰sq‡spƒso‚qn†tp…pn‚olnj…rmƒpk†umŒyr‡xoˆwoˆup†qm„omƒpoƒsl„ql…ql…qlƒoj„qk„qoƒpn„rm‚niƒojƒoipn‚qnnk~nhyhcyhbvd_zg`|f`€jd‚neƒpglhƒlg…mg€jdohƒrj€lh|ie}lf|jcog‚lf€ng‚pi‚piƒpi‚lff_ƒgaˆniƒmg‚nj~kg|hf~ha„mf€jb€kc{ia{ga}lc~kc~g`jdjezhbxf]}jcyg_yf_xf^s`VsbVvdYveY{i^yf_wd\za^ub\taZr`Ys`Zt_[saYr`Yn^Wn]Vm]Vo_Xp\WiUPgTOlXSmXTo[Wp_Xp]Vq\Tn[Pr_So^Qo[Pp\PnYPn[TlXRlXSj[Po`UmZQn[To[Vk[Vl[Po]Sp^Vo\Tn[TmZSn[Vq^Yt`\{iavd\nYSp]QrcYqaXt_Ws[To\Vr^Tq^Wp^Wm[Tk]SqcVq`Wq`Wo^Um\So^UraXpaXn_Vq^VlZRiXOfWNiXQfUNbTKdULdUKgYMiYMeVLcRKbVNpf]kbXjWQgVPdULeYNdZLcYKgSOdQLiZRm]Un]SlZPfXPgVOgVMhXLdUH\PA\RE_NDcQIdXNaXMbWM_SF`TH\PF]QHeWO_RJaQH`SIZND\QFYPFZPFUJCXMCZLC^PF\OFZNGYQGXRGZQH\QI^MH]JEVNDZPF`TJ^RHYOEXQGUOI[QJ]QJaQK]NFZLE[QG]RJ^RKcUO]PH^QH[OJ]QI^RG`UG]TFXOCUODWRGXUKXVLURIVPJWOFYNF_WJi^QnbUcYJ_VLf\QeXP]OGYMFZQJ^WL]TJ[OE[MEZLDXLE\OE_TK^XM`ZOVKA[LC[NDYMCZND[RI_UKYOF[QGWPEQODPQDTUHWWKWTLRLDULDTI@WMDWOE[QFUJCTHFVJFZRGaXH`RLXKERF@SKBXPGXSIYNGRNBNQALO@SPEYPHZXJUTHQRFQMBWQGUSIPVILUHHRDHREMRETSF†ka‚f]†i_…h_†h_„g^€h]‚j^eY„hZ‚h\g[€fZg[€fZ‚g[€fXgZ‚h\g[f\f\f[‚h\fY‚g]€g^e[}dZ}dZ~e[h^€g^€h]ƒi]ƒi\‚g]€h]e]~f_g`~f\g[€h\g[€d]}c]€g^f[f\~fZ~fZ„i_gZg[€fZeYfZƒh_€e[dZ~cYdZ€e[‚fZ‚gZ~fZ}f[‚h^f[€f_e^~e\€e[dZeZf\€e[€e[ƒh^‚g]‚g]f\f\€e[‚g]„i_‚g]f\€e[ƒi]‚h\f[f\{eZg[€fZeY~f]{d]d_d[€fZ€fZ€d[~bZ€e[f[~cX€d]c\‚f_ƒd[‚d\‚e_€e_€ja|h[~d]€e^€f_€e^‚f_…ibƒh^ƒh^ƒh^„j_‚j_ƒj`ƒj`…kb„gbˆkf…jc…jd…faƒfb~d_}e`}a\z]Yp[WmUPkQJhNHdJCcKEbNEaNB`LCdOGeOIkUOkZQq_VubZ}kbwg_ocYc^SdbW^^S]aR]`R^bQVbQUdQVdQVeSWfTWiVUgVReSShRUjSTkUSjUSkYPhVMdRNcQPdQUiVOgQPiSRlWPmWQpYJkSOkXOlXOmTOlSOkRNkRSkTVmWTmVTlYXm[Zn[XlZSiWQfSShUTkXXo[SnWWoZ\o\]p]Zm\`sa[oZShROfPNiRNkTLkSJfRLgSPiUTkXXlYZn[YkYXiV\n[bsb_paaoddobcobeqcisfjrfjpclnarqeuqg}tl|qkzqj|plplolƒpmol„sp€nhniƒoj‚oj„qnƒqn‚nl€olqn‚pn…sq…pooloj€pj‚oj‚qi„rk‡qp„pm„om„qn‰vs…tq…ql„ql…rm‡toˆupˆupˆvn„slrl…wp‡up†spˆur…spƒpm„om‚mk„pmƒsqƒqo‚nk~igkhpmŠtoˆsn†rm‚oj€oi~nhqnƒqn…pn…on€nk€pm„ql…rm†sn†rp‡tq…ro‚rq‰vu†rqˆsq…spqk„pk…rk†tm„rk„rm‚rn†roˆuq‡tp†sn…smƒqj~nhrk†sn†snˆup…rmƒpl„pk„qj‡tm‡sn…rp…rlˆuo‰up‡to‚ni}idxd_zg_„ofŠul”}vŠql„ok€lgƒokmi‚nimh‚ml}idkf}jengohƒlh€ke‚le„ngƒmgƒnkjeke}kb}ia~ib}hc€odƒqf|jb}jb~gbic€iah`h`~ga}gazf_ug^|jcyd^xb\xa[q]Wr^Wyd\~ha{e^s_Wr_Wq`YsaZvd]yf_xe]r_Wo_Yr`Zn[UlXQkZRiZQhWNfUMhWOk[So]Ut^Xo]Rq\SoYTp[Ts^Wq^RpZPlVOiXOkYRjZSm\Ur\TmYQiVNlYQo^Uo^Vo^Uo^Vn]To\Tq^Vt`XtcZr_Xr_Xq\XpZUr\Xr]Vr_Yq`Yo_Uo]Tt_Wt`Ut_Wr_Wp^Wp^Vp]Wq_Xs`Zq`Wn^Tn^Rk[NlZRj]Sl]SmXPnXPhULdUOfVOjXQhUNlWOiSLhVNeSMcUOf[Rj_Ug^PeVNfULfVMeYOd]S`]RdWOcTMgUNhVOjYRiYRiZVgZSh\RbUH_TH]SH_QH^NHbRKaRKaUI]PC\RI^PH`PI_NI`PL]OM_OH[KE^QHWND[QGZQG`RF_OF_NEaNH^PH\RIYM@VMBWNEZNH^PHaRJZNG]SI`TGcWKcWMeXPdULYNDWLDYNFWMF[PJdWNaSIdTKdSJ^QG^RH_UJ`UI`THfWLbQJ_LF[PH^TK`YN^UK[OH\KG]QH]OFaSIhZQbWNYPH^TK`XO_XOZRI\QIYME[PG[PGXPCWNB]SI^ULbSJYPDWQD]WJ\QI_OJZOGZOE\QD^UHYPDXQGZTI\SKXOFWOFVQHWTKc]Qd\R]UKXMFXKFWJDWLDXMEYMHXNHXMHYOJ[OKULDTLASMBRLDRLFVNDXOETKDULETKCXOHZRHSOEPLDRNDWOFWMDPRIMTGMWFKWENSFMLC„i_‚h]ƒf]„f^‚e\„h^‚h]h\f[‚f\ƒi]€fZƒi]g[€fZg[€fY€fY€fZg[€e[‚g_fZ€fZ€fZd[f\g\€f\€f\g]€f\g]g^‚h\ƒi^‚g\~f\f]f^f`€f]€g\€g[‚g\‚g^~e\~e[~e[~e[~fZ}fYƒh\g[fZfZ~cXg[‚g]€e[~cYdZdZf[€fYfZg[f[f\e[}c]~e^€f_e\f\€e[‚g]f\‚g]‚g]‚g]€e[€e[€e[‚g]f]ƒh^‚g\€e\f\g[g[€eZ€d\}dZ€f[g[‚g[€e]€f_d\dZ€fZdZ€d]~b\d[d[dZ€d]e^€d]‚e\€d\d^€g`g^h]ƒf`‚f_‚f_„ha‚f_„ha„f]†j`†ka…j`„j`ƒj`j_ia€hbf_f`{c[{cZv`Wq\RnZPkUKgQGbLG`HBbGAaF=bHAeMFiUKjUMkVNlYPo[Swc\tg]wi_wj`zndulaieZ_aT`eV^fUZdS[eS[dTTfPTfQRdOVgUWhUWhTTgSThSRhQTjRTlUTjVSiWPhUMeRMdOQhTVoXQjTNiRRmUQlUSnWQmUMiWQmWRoXRoURoVOlRQlTSoWSnWUnWVkWZmYVkXRhUTjWSiVUoZWp]Zq[[pZ_r^_r_\p\\o\ZmYWkWShSTkVUlWTkVRiWUjXWjX^o]`o^bq``l\`kZbm\go`fociogjociobkqemrforfpqfrogxrk|rj{pj~qk~sl}pmol‚ol€mj€nk€olniniƒql‚ojli~li€kiƒqn„sp‚qnƒro„ompl€ql‚qlƒpkƒqk‚qi„pm†qo†roˆtrˆtq…qo‚oj„ql‡to‡toŠvq…rm†rl„ql„rm†tn‡tqƒmk„qnƒpm„rn†qo‡rp‡rp…spƒpm…pnki„om‡rpˆrm…pkƒojƒpkpj€qjƒqnƒolƒnkƒnl‚mknknininimiƒpm…ro‡tsˆtr‡rnƒnk„pl…sm‡rm‰tn…rk„rk„pm†ro†tq‡tr„qm„ql„pl‡tn„uo…uo†to†sn†rm‡tn‡tq‰upˆun†sl†rmƒpm†snŠwr‡to…ql‚ni€lg}jeoh‡rk…ph†nh‚jekf‚nj‚njmh€lg{hc}hc~kf€kg~jd~menfke€jdƒof†pj…oiih€jd…ni‚ldnezha{gb‚of„ogkc‚me„ne€jbjb}f^ybY~f`~hbze_zjbxf_s^Xyc]xb\w`[tbYvbZvaYu`Xs_WtaYvc\{hayg_}hbyd^s^Xp^Zo[VkWRjWQkYQjZSl[Rl[RhYPkZTr_Xs\Wp]Vq^Xq^Wq^Xp^VkYNnXQlXQm[Rn\TmZSlYRlWOqZSo\Ts`Xo]Un]Up_Vp_VraXubYs`Xs`Xr`Zn\UmZSlYRr]Wq\Vp^VkYRlZSq`Wp^Vq^Vq]Vo\Tn[Sr_Wr`Yr`Yo]Vo^Un]Tm\SjYPjZNkZQeZPdVMhUMiSLfTKlZSp]VhVOjWPgSLgTLiTNiVOfTOhVPfYPgYOm[RlZQjXOeXOcYO`YObVNeVOeTMeRKfVOdSL`PKdUNeYP`UH^UI\SIZOE\NG]NGaQIbSIaSG`TI]PF]NF[KE]NH\NI]OHZOGZNFVKAUKAYOE`SIbRIdSJbQI]NG^SK]QF[QHXMFVJD^OHdUM^RJ`TJcXLcVJbSJbQJ\QGYNDZOG[PH_SK_RLcRKbPIcQIfWOaUK^TKaVM^RG`THhYNeWNcUL_SK]SK`WMaWN_RK_OJ`RK\QH]SI]SIdWMcVJbVObXO\TK^TK]QI[NFVKCVKBXNCWNC[QH]SKh[Re[RgaUhaWf[TZMFULB[QE\TGYPCWNDULDRMDVPGSNERMDXSJZYNa]Q^[N]XNXSIZSKWQIXOFVNEWNEVMFYQHXQH^VOa[RZUKQLBQJBRLDUREZTKXQIUOHSOGPNDSRGOPEORGNODLJ@MG=JG?NPCPVGMUENSGLNEƒh^ƒh^ƒh^f\‚f[g[€fZ€fYh[eZh\g[g[‚h\€fZg[€fZ€fZ€fZg[g[g\eZeZg[ƒh^€e[€e[€e[‚g]f\f\ƒh^‚g]‚g\ƒh^ƒh^‚h^f\‚h]g`€e_f\€g]f\~e[€g]€g]|cY}dZ}dZ{cX‚d[‚e\€cZbY‚e\dZ€e[f\dZ}bY‚g]dZ~e[~e[~e[€e[cY€dZ~c]e_e^‚f_ƒg`e^f\€e[f\€e[€e[f\f]f\~cYf]f\€e[d^€e[eYg[€e[d\€e]dY‚f[eZ€dZ~c[~dY~eXeZ~cYc]~b]~cZ€e[dZ~b[c\c\}dZ~d]‚f_ƒg`‚f_‚g]f_ƒg`ƒg`†jc„ha‚hb…i_„i_†ka…j`‚h^g^|g\xc\wc[t_Xq[UnXRnXOjTLePGbLCaIA_F>^FB_F?cLBfODkTKnXQubZr_Wvc[rcZpbYsf\oh^qj_ni^nk`fi]]bUZfU]kYZiWZiWVfTWgVSjSVjTVlUViTXlUTiRUiRSiPTjQSiQRiUOeRQgTPhSNhQLhQPmUTrYSmVPiSRjTVmWRiSUkUPlXPlXSoWUqZTpYRnWQoUSqXQoVSpWUkUVkUVjWWkXVlYTkXVmZXo\\p[^p[`q\]n]_o\^o]_n\_n\]kYap^bq__n\_m]ao^do^hpajqblsclo`km`mmarpdroetofsngspgrpgurjvrjvpj{so}rn~pm€qk€pj~pjnl~mj~mjnk~mjnk€mhlg€mh}jf}jg~kh€kiol€ol‚qn‚pm…pn„qlƒqlƒpk‚oj‚ojƒpk„sm‡so…rl…pl†rm‹up‰vqˆup‡sn†sn†sn…ql‰sn†rm‡to†sp„om‚ljli…ro†spˆsq‡rpˆsq‹vtŠus‰sq†om„nlƒnl„pk†rm…ql…rm†rm‚pjnkkj‚kiƒljƒljlj€le€lf€lg€lg‚nj„on†pl†pk†pk…ql„pk‡snˆrm„ni†qj‰sm‡so‡rq„rm„ql…ql†sn‡to†sn„uoƒtnƒsm‡to‡snˆtn…ro„ql‚oh„qj„pkƒpm…rl‚ojlglg€lh€lg|idog€mf|f`€ibhd‚lf€je|gaidzd_}ga~hc€je|ib{ha{hayha‚me‚memd…oi„ni~hcƒjf†nh}ib~kcxf_vf_„nj…piƒleˆrji]|dX‚ldxaYw`X{b]v`Zr]Wr`YtaZxc\w`[wbZu`Xzg_xd\u`XvaYuaYr_Wub[zf_yc]|f`{d^v_Yp]ZlYUiUPn[Uo]Xn\Tn[QkZRl]Tp`Xvb\r_Xp[Yp[YmYTo\Uq^Wo]RlYQm\Sn]Tn\SnZSpXRoYSyc]wa[r`YlZSn[Tr`Yuc\uc\taZp]VmZSmZUlYTmZSq]VlYQn[Sq^WtaZp^Wn]Tn\Tq^Vs`Xr_WtaYwc\o\Tp]Vo^Uo^Ul[RjYPjYQhWNeWN`UKeXOjWOmXPl[Rr^SnZQeRJiVOgTNjWRlUNjTOePKhTOhVNiVOiTLfSKeSJaSJbULbXN_TL]QI`PIbRKcTL]PH`PI`QJcWM_UK\RH\UJ^TJ]PH_RJaQJcQIbRFaTHbTHcRI^MD[LCXJBXMEXME[PIZPFXMCZND`TJ`QH^NE\MDXLC\QJ`SKbVMZLFYKE]NH`OH_RJ_TJcUI`RG\NE_NGYPG[RI[QHZOG^OHaQJeSLdSK`OH\LFZOH]TM_RL^PI`VL_WI`VJ[RG`SKaUM^SKcVNbTLaQL^QKZOHYSJd^RsgZs`UcXP[PHYNF`UM^RJ]PHXMDVKBUKAZPF\QHaWNbTN`WNf^T`VOZPIXLETLAVOBYPCWMCWLDYOI\UL[TKZTKYSJ]WLYUKZTE[TGZUH\XK]ZPWVKWOFUMDUODTPESRDQPCXVM[YOVTJRMETMDSKCUPBUPFUPGLLBNMBNMBNQEQUINWJKQDJLAIGK:VC9R?5N<„j^„j^‚h\€fY‚f\‚h]f\g]f\‚g\hYgZ€h\€d[c[€c\€e[ƒh^ƒh^„j^ƒf\ƒg[‚hYfX~f^}e]€d^d^€e]f\‚h\g[dZf^f\‚g]ƒh^€f\€e]e^dZe[}aW~e[}dZ~e[}dZ}cZ|cY}dZ€e[‚g]€eZf[€d\€b]|`Y~bZb\}bY|bV|bV|bVcX|c\}c\~dZ}dZ}fYfY}dZ~dZ€e[~cY}aXbYdZ€e[dZ|aWdZ€eZcW}aX~aY~aVbXb\|aY}cY|dYzbVzbW{aX}dYe[}cZ|cY~d\|a[~e[}dZ~e[dZe^c\~d]e]~f\dYd\€d]€f`~e_g_}f_|g]zeZzb\va[q`WqaXj\Sm]TiVNeQIgPHcLEaJB_JB_FA_GAdKEgQIdPGgTIn\PnZQo]VpaZf_Xb`V^aUZ_PZcP\fRYdRXcSUbRVbRVeTTeTTfUTgVUiVXiWZlYYhXZgW]jZZgXZgYXeWWcVWeVZfXVfWUdVUdVYgXYgVYgWYfVYhWWiXVhWZjYYeUZhWXiXQhTOhTRfTUgVSiTSiVUkXYlY\k[`k[]lYal[_iYahY_jY_jZ^k[^kZan\dp^cn_eobiobhpbluhksfmqdonbupfwpgzogtl†up‡sn„rk„rkqjrj~rj|qi}nh~oj}nh~ni€pjoi}nj~ni€pj€pjpjƒqi~oi€qk‚ql}lf|kezjd~kf}keni‚pjƒoj‚ojml{gf€kk€lkmlmloi€lglgkfkf}mg}kfki~kh€lkkj‚mm†rm„pl„pkƒnm†qo„poˆql‡rmƒojƒoj…rm†rm†sq„qn…ro„qn„pl‡to†soˆurˆtq‰urˆsq‰tr‹uq‹uo‡sn…ql„pkniƒljki~mj}nhƒrl‚oj‚smƒtn„qlnimhmhofnflf{gb|gf}gf‚nh„pllj€kizeb~kdmf€lhlkll{jhzlh|kh€oj|mg{kezig}jknj€jh}ge€jhki{jg€ko‚np…qp…rppmoi|le~oh~ni€oiqj|lfoh…rlƒpkmi€ki}hg€kf‚nh‚oiƒojmhƒql‰rm„ni„niˆrm†plƒmh‚le~ja€kcld‚mejbgaw`Y|d^}ga}hbwd]vc_ub]ta[r_ZsbZtaZ{g_yc[xbZ{b[{b[y_Xv_Y{c]~f`x_Yw_XzaY{f]zd^v_[xb\vaYvaYzg[ze\yd\xb\xa\t_Zr^Yvb\r_XmZSn[Sq^VtaZvc\tb[p_Vq]Vs]Uq]Uuc[r_Xp_Wo_Vm^Uo^Ur_Wq^Vt`YraXl[Rn\Sq^Vp^Uq_Yq^Wm\UqYSr[Uq]Wp^Vp]Uu^Vt[Us[UoYRlXQo\Un\Up`Vo^Ul[Rn]Tp_Vn^Tm^Wo_YkZSm\Up_Xp^Vj]Sf[R_SM]TMcXOfXPjZNhXMdRKfSLmZSmYQlZMjYLmYMnXMnXOlWOmWPmXPiWOmZRiVNbQHhUMfTMeUMbSK[OHZMG_MH`MHcQJeRK_NF]ME]PH]PH`RI`QH^QEXLAVMCZRDXPETKBXME[QE`RC`OFfRMbQGaOFaOKcRN^OH_MH`MH]MF_OIaQGcQHdPF^K@_OD_SE\KF\LDZNCZNDZMD]OIgUJfUI_OC]OC[OC]QE[OIXLFTMDWPG\RI[PH\QG[SI`ZPbZPmaWgUL[PGUJCZLG\NIYJDXJAVMBWNETMDPJAWNE]RIWNEWLDYNF[PH[SHUOBPOESOEUMDWLDYPEVMCYMEXNFSJFRLHRKEQIBSKCYOFWNAXNAWNCXOEVKAXNEWLEWLGXOGTMFUKDVNFTPHRPFUSIYVLXUMWPJYOJXOHYRGXSEWKFVLFVMFVPITQGSQFPQCJOAHQEJUILVJOWNNPEJMAEL>JQCKPEJNCHNDFOCGSCETACT@AV>;U@;VC:WD9WD;UD9SC9R?8R?8RA;SC;OA9M?‚h\g[‚g\‚hZƒf]ƒh]€g\h^‚g]ƒh]~fX~gY~fZ€e[e^e_f[g]f\‚h\‚f[„g\‚iY€gZ}f[}e^€e^e_€d\dYg[‚g\~cY€e\g[€e[}bX€eZ~cYb\}bW}bX~cY|cYzaW}dZ|cY}dZ~dZ}cYdZ~cY~eXdYc\~b[c[}bX€d\~cY}cW~dX|aX}bY|dY}dZ}d[}dZ}dZ~fZ}dZ~dZdZdZcY€cZ}bX~cYdZdZdZ|bX~cV~aYbZ~aV~bW}^Y}bZ}bX~cW}bW}bX}aZ~cY€e[dZ~cY}aZc\~cY~cY€e[|aX~b[€e]€d]e]‚f\g]}e]~e^}f_{e]xcZyf\ucWsbVp_Vk^SdYOdYO`VK]OG`MDaJBaIB_E>aG@cLCfOHgOIlWOp\Tk\TmaXnbXl`Xj`Xh`X`_T`aTW_SXaPXdSYfSZhVYgVXeUWeTYhXTfUWiXWjYXlYXkXYlY[jY\iY\iY\g[[fYXeXUbTXeXXfYVfTVfUTdUWdVWcVVbVZdUZfVYhWVfTWeUYfV]gXZjXXlVThRSeRYhXWhUXiWYiWXfU\gW[dT[hV]hW`gYahYdi[ej^hl`ej]gm_fm_ej`gmcnpemqfqvjuxmxukyti|qi~rjrk‚smˆvrˆup‰voˆvo†tmoh~oh~ph~pjqk€pj€pj€ojmh}mj‚pm‚rlqkmh€ngoi‚rloi|lf{kezke|ie|iemhlh€minj~ki{gf~kilj€mk~jh~jfkfƒnh€lg‚mh}je}ie}jg~li€ljlklkmiƒoj„pl†qoˆrp†pn†qlˆto†rm…ql†sn†to†qn…pn‡qoˆsqŠts‰tp†rp†qo‡sqˆrpŠsq‡pn‰uo‰so…ql…qlƒoj‚oj€ljmjnk‚qkƒql‚ojƒsmqk‚qkni€mhmioh}lf|id~jejf€ie„oikh~hf~gf~ifjele~ie|je|ig{kg}ohokohzjdzkd{jg{jg|if}gezdb{fd~jg{jf‚mmƒonƒompk€pkpj€ok~li}mh€pk€pjpkƒsl…rl†snojlhƒok…rl‰up‹wr‰upƒojƒpkvq‡ql‡ql…ni‚kfid€jdid~gbid|faxb\{d^}e_}ga}icvc\tbZzcbwb]u`[u`[u`Zva[wc[vb[xc[kcyc[t_Wn]Uq_Xr`Yq`XubYvcZxc[ze]t^Yv`[u`Y|h^ze^wa[yd\ze]yc\v`Yub\ub[q^Wn\To\Sq]Ts`Yr`Yo]Vn^Tq]Ur]Tr^Vt_WmZRp^Ur`XsaYp_Wp^Vq]Up]TtbYp`UraXo^Um]SmYRlYRkYRs[Vs^Xp]Vp]Vq]Ur\Tt[Ur[Tr\Vt^Wq]Vr^WraXraXp`Wo_Vl\SkZPl[Tm\Un]Up\Um\Rm[Qj\QgYRi\TgZTbUMfWOjYMgVLcPIhUNlZSiWOeVIgVJiUJr]QpZQkVNmXPfSKiVNiVNgTLiXOfTLaOF^MF^OG_QI_RJ_PJ]LF^LEaNG`NGbQI_SK^PG_PG_PG]OGXMDYPEWPCXNDUJCUJAZQD_QDaQHdSL_PF_OE]LH]MG^NH_OI\LF]NF]MFaTKeWOcUL_PGZPEYPE]NE\MD\OD[OD\PFcULhVM_OE\MC]PE\OEXNC[MGWLFXMF^ULaWMcWLdVO\RJVOGXQH]QI^OHZPEVLCUJCVHAWKBZLC[NDVKBRF?RG?ZNE]QFVMDVKCZNIXME\TJVQEQPFSPGYPG[QIZPFYPFYMDUKCWMHWMIVLGSIBRIBWNDUL@XOCVMBMG>P?>P@?P@‚g\ƒi]ƒi]ƒi[f]…j`f\f\f\f\}gYfZ‚g[g\‚g]e\f\€g]f\ƒi\€f[€fXgXgZ€e[‚e_€d^dZ‚f_f\€fZ‚h\dZ~bZfZ~fZ}eYf\|bXzaW~cY}bW~cY}dZ|cY|cY|cY{bXzaW|cY~cY~cY~dX}bX~b[c\}bX}cXeYeYeYdZ}bY|`Y|cX}eY~e[~e[|b[~d^~eZ}cY~cY€e[€dZ~_W}bX}bX~cY}bXdZ~cY€dX}`Y}`X~aWbW}`Y~aZbY~aW~bW~aX~aZ~aXbYcY‚e\~aXbYbY}aXbY€e[c\€d]€c\ƒg^f[}dZzdZxc[yeZxdZscWtcWnaVh\PfYP`TJZMC]NEZJCYHA]G?aIAeJCgKCiNGjSKq[Pr]TvbZxiapf]ib[gcYc`W^\R]_TZ`QYbRVcSWcSVeTWhUWjWWjWZhXZjYYiXYiXZl[XjYWkXWiVViVYhW\iY\hX^hX]gW^iYZgWWgVZjYZkXYjXZhXWcVTaUS^RZcT\fV]hYXeUWeUYfV]jYYjWXkVWjUWiU[iWXiWZhVZhW\gW[eU_gV_gWciYgj^kl_nmarodsmeqlcqndnmclkdjjdrqfvtjvtk|wm~umtl‚qn‚ol€mj…so‰vs‰vs‹upˆtn…ql„qlmg€ni~oh€pjoiƒsm„qlƒpjnlol~nk‚pj‚ok‚oj€pjqk|lf{ke|lf}mfnklilililililh}je}je}jf€mh|iekfjeid‚jfje|icli~kh~jhihljlk~mf‚ql‡rpˆrp‰rp‡om†smŒxsŠvqŠvq‰up†rm†rm‰upŠus‰trˆsq‡rp„om…pn‡qo†om†om‡nm…ql‡sn‡sn…ql†sn‚oj~mj~mjnk„qlƒokmhniqkqk€pj}mg~nh|liyjeyga€lgicƒkelgkfkg‚kgkfjf}jb{ha~id|id}je}kf{hcxg`xg_xf_wd^wea{fd}hf~hg|if}if}li€lj€mjni‚rlpj~phlm~ll|jipl€pj€pjpi€mhlgmj†rmˆtoysˆtpˆtoˆuo†rmŠuq…ql€lg€lg‚ni~id~je€jd~hb{f`~hb}ga{e_~hb~ic{haxf^taZyd]~gfyc]xb]w`[u_Xwa[uc\wd]wc\r_Xs^Xs_Xm]Vn^Wn^Wq_XsbYwe\yc\yd\u_Zr\Wwb[wbZzd^u_Zyc]wbZwbYtaVtaZxe^ub[s`Yq[UmXQp^WsaZo^Wo\Tq]UoYRr]Uu`Xs_Wu`Yu`Xs^Vo\Wq^XwbZt_WudWqaTqaYl\Sl[RmZSq\Vq[Uq]Vq^Wo\Ur_Xr]Uq\Tr]Rq]Rs_Ut`Uu_Uu`Ts`Xq_Vo]Tn[Sm[Rn[Sn[To\Tp]Uq_To]So]Rm\QjZOjZRdSNcOKhUNjXNkYOlXPkYQgUNdSJbVIgWKlZNpZRmXPnXPlYQiVNjWOjXPdSJcRIcRI`OFaPGcQKcTL`OIYLEXKCaOHcPIeRKeSM^QF[MD]NE`PI_PIZMFTIAUL@YOEZNH[OF^TFaRH^NG`PIbSJaSH\LG\LF`PJ`RKaSKdSMcSLcVOaTL]PH]PHYNDZOEaRIcUJ_SF^RE_SHaVLdUL_OF\OEXLAWLBXNDXLB\OFZNE\PF]QGg[Q`SLYOGZQHVOFYNFTHBVLBTJ@ZPFWMCXND[QG\OFZNFSIBUKD\RIZPFXOFVMEXKFWNF\SKYTIQOFQLCQI@YPG[QG\SJZOEVKDWMFVKGUKDTGASJATJAVKBXNDYPFTMD_WN_WO\RKYPI]RK[QH\SLXQJUPHRNEUOFXRGRQFWTJZSJ[PJYOHWLDRLCUQFYWKWWIVZJTZJTWJINAHNDQUJKKCMJCXTMTUJMRFHQD?I=AJ?:TB:TC9TB7TA8VC5UA@T>>Q=;O<N=ƒi]€fZg\ƒi[€e[ƒh^‚g]‚g]‚g]‚g\‚h[€fZ€fZ€fZ€g[~f[€f\€g]|dZfZg[€eYgXgZf\€e[‚g]€e[e^€e[eYg[~cY~cZ|dX|dX|dW~e[|cY|cY~cY~cYdZ}e[}dZ{bX{bX}dZ{bX{bX~cYdZ~cW}bX|aY~bZ~cXeXeY}cW~dY~cY~b[}bY}eY|dX|cY|bX|a[|aZ~e[~dZ~cY~cYcZ~aX|aW}bXdZ~cY~cYdZ|bV}aZ~bZ}bW|cU~b[}aY}`W~bW}aV~bX~aZ}`W~aY€cZ~aX~aXbYaX€bY}bXdZd]|b[~aZ~c[}dZxbWv`WvbZxdYtbXn]RgWLdUI_RGbPG`LC]G?[C>^E?]E@fOGiOHpTMrVOrYRs]UucVtaWxf]ug_ri`nf_cbXbaW]`VYaSVaQXdPXdUWfUUeTUgVVjWYmYZjYZjYXhWXhWVhWWiXUiUSfSThTVeU[hX[gW_gX`jZ_iYXeUYhWYiYZjW[iX[hXXeWYdXZdW\eW_hYak[^gX\gW]iY[iZ]n[[mY[mYZkX\kZZjX[hX\gX[fU_i[_i\jj_jk_nmarncumdwmdzlf{oizphumftlftkhwoi{rk}tm€smpjnhƒnl„om„om…roˆtq†sp…oj„oj†rmƒniƒojƒoj|ke~nh€pjˆto„qlƒpj€olpmƒplƒpm…rmƒniqkoioioiqkoi€mjmi€mjnknklini~kf~kflglg}je|id}hc€hd‚je€lg~je|ifzfc|ge}idlgjd~limjƒnl„nl‡ql‡pk†qlˆto‡snˆtoŠvq‡to‡sn‡sn…ql‡rq‡sqˆsq…pnƒnlƒnl‚ki†om…om…ql†sn„ql…rmƒok‚nh|li|kh‚ol€mhmh€mh€pj‚toqkzkfzlg{mgwigxgezjdlgzf`€hbkfkf‚lg€je~hcidyf`|ib}jc}jczgbzga|idxf`zj`we^yf`{heljmj{if{he|if|if~lf€pjqkoi|ohzmf}kk|ji|jinloi~nh~nhlfog‚piƒpi†tk‡rn‡sn‰up‡sn‚ni‚ni€lg€lgmh}id}id~jeic|fa~hcke‚mg‚lf}kcwe^raZq_Xtb[{e_yb_wa\xb]xb]yb\vb[r`Ysb[wd]xe^vc\t`Yr^Wp]Uq^Wr^Wye]{f^wc[t_Xr\Wq[Vt_WvaYwa\u_Ys^WvbZxcZwcYvd\vd]taZtaZs^Xp\Up]Vo]Vn[Tp]Ur_Wr_Wu`Xu`Xr]Vs^Vp[Sr]Ur`Zt_Yt_WwbZr`Sq`Ro]Up^Un]To\Un\Tm[Tn\Up]Vp]Vq[UnYQp[So]Rr`UuaVs_Us_Tt`Us`Xp]Un[Sn[SlYQn[SlYQmZRp]Ur`Up^SlZOiWLhVOgUNiVQgTNhUNiVLjWNjWPgUNhUOeVMcWNgXNp\UjWOjWOmZRmZRr_WjWOcSJeSJfUKbSKbQHdSJ`PF_NE`PFaRKcQKbPIbOH^LE]LE^RI]OF]MFYICZKEVHCXMEWNBXLBXJD]OG]QE^OF\LG[KE^OG[MB]MGbNI`RJaVM_TL_QHbQHaPJ`OIdTLcSKaPGaPH\MD]ND_SFbVIbVK`TJZMEWKCXKCUKCUJBSH@YMCYMCZNDXMC]QG_SI[PHYOFXOFWNEQH?ULCXMD_VKXNDVLBUKAXOEXPFYQISNGRNFWQJUQFVODYOFVLESJBWPGVRGQKCSLCULCWNEYRGWRGYQGTMCTLEVLEWJDWKCTJATIAUJC_TMf_VjcZb]T^VNYRK\RK`WObWN[TMVOHSNEVQHXRI[SHURHWUJYUL\ULZOH^OLYSLXSLTSISUIUYNT[MRZLLTEHOCMRGGK@IJAIOFEPC>M?=Q>:S=;U>€fZ€fZg[€fXh^‚g]‚e\d[€e[~e[g[‚h\‚h\€h\€h[i[g]~f\f\h[€fZƒi\fW€eYcZcZdZg[c\€e[~dY~dX~cY~cZ|eW|dX{cW}eX|dX|cY~cY~cY}bX|cY}dY|cY{aX|cY}dZ{bX~cX~cY}cW}bX|aV|aW|bU}cU~dX~cY}bY~b[}cW}cW}bW~cX}aW~cY€eZcX|cY~dZ}bX}bX~bX~aX|bX|aW}bX~cY}bX|aWeY~a\~bZ}bWeX~bY|`Y~bX}cW}cW|aW}aZ}aZ}aZ}aXdY~cY~dY~bY~bX}aX}e[{c\{d\{bZ{cZ|eZxbWwaWv`Xr^UmYQfQJ`KE\GA\GA^G>`G>cHAdGBfJDmSNt\TsZSu[Tw`XxbZyd\uf^ve]te[uf]vjbrh_idZdcX_bV]eWZeT\gU\fV\gW\iZYhWXiWZlW[jZZjYWgVXhWWgVWgVSgTTfTQdQQ`PVbRXeUZeU]gW[fVYdU[gW[gW[hW]jZ[iY[gY[eX_i]aj]dk`fk_dj^bh]bj]_j[`j[bl\cl\ck\bk]`iY]gX_eUbh[ag[ek^oj_qkasmdvnexmfzle{ke}mg{mezlfzlg{mj|nj|ni}mi|lg|kf~mi€li‚nkƒoj„qk„qkƒpj‚ojni‚niƒpkmhjenh~nh…rm„ql‚oj‚oi‚nn…po…qo„qn‡ro…pm„rmƒsmqkqk‚qk~oh€ljmk‚nl‚omnl€mk‚oi€mh~kf€mhlg~je{hc}id~id€kf€kg{hc{fd}hf~keieidic}hfmjki‚mi„oimh€mh‚oj„pk‡snˆtoˆso‚pi‡to„ql…ro‡tq…qpƒqn€nk…qn„pm‚nl‚lkoi„smƒpkƒpk„qlnimj€nk„om†sm‚pkpk~om}nl~nlzmi{njujfwgcvfavg`ye`|ic}ic~hf~heke~ic}gd|ecyd`ye`}jc€lf~ig}hfyfbwd^wd^yfa}ignk„ommk{ifwgdxhd}jg{ke}mf|kevhavhazlh}liziezie{kf~ng€pjoi~kfoh„rk…qj†sl…qm…ql…qlmhkf€lgmhmi‚nh|hc|hc€kf€mhkf€lg‚nikf|hc{havf_qaZk\Up^Wu_Ywa_wb\xc^wb]wb\t`Yr`Yvd\vc\uaZu`Zu^Xr^WvaZt]Wu]Wzc[v`Xq]Us`Xr_Yq^Xs`Ys`Xq^Ws`Ys`XubZwd\xe^zf^vbZub[wd]s`Yr_Ym\Un[To[UxcZxc\taYr`Wn\Tm[Sp]Us_WvbZr_Xs^Wu_Wv`XuaWq^UnZRn[Sq]Vo]Vq_Xr`Yo`XsaZq^Wq[Up[Rn[Sr`Uq`Tq`Uo^Sn_RrbUtaZn\TmZRjWOkXPkXPo\Un[To\Uo]Uk\RhXMiVOiUOeTNdSLeSJdRIiTIkWNlYRjXQiXQgXOcUMjYRiYOkYQk\ShZMgTLcRIfULfULbQH^OF]MGaRIdSJcQIbOEgTIdSLcQJdQJ`NGZJD\LG\OG]NG[KDZJC[LEYLE\OGYMCYJBVGC\LG`QF]PF[KFYJEYLC\NE_PL`NG]NGZPGZPG`SIfULdTKaSJ`SJbUKbRGaNE[LD^NE[OD^RG_SIZNEUJCTIBVJCXLEVKDSG@RI?TJ@YMDYLDWKEUKBUKEVMFVLETJCVKDVKDVJCUKBUKAULBULCUKCSLCVOFVPJOMEONDQNEVPCWQCWNDUMCXSIUREUMEVMDYPGWNETPDSPETQEQMCJF>NF?TKCZMEWMCZOEXMGYMGZQIXTKYPIWOHUMFSLEWPFZSHWOHSLEVQHYTK^VM^UKYSKYTJXTIYSI^TL^SMWOIOJBNMBUWKU[MLWGP\IR]KMXGHQC?H;AH<UC>Q@:M<;Q?:SA:QB8O?8L;8Q>8R@;VB9SA9P@8N>g[g[eYeXf\f[e[e[f\g]fZg[€eXhY~gW}gX}g\~f[f\g[€g[€f[gY€fY‚cZ‚cYdYeWc[}bXeY~dX}bX~cZ|dV{dUzaV|dX{cW}dZ|`WdZdZzbX|cYzaW}dZ{bX}e[{bX~bX~cX}cX}bX{`V|aW}cV{bS|aV}aY}aZ}aZ}cW}cW|`X|`Y}bX|aW}cW}cW{bX|cX}aW~cYcZ~aX}bX|aW}bX{`V|aW{`V|aW}`Z}bZ~cXeW}bW~c\{bWyaU{bW|bYzaX{aY{bZ|cY{aX|cX{cV~bXz`VxaWxcXwbZvbZyb[zdZxaVv`UpYOnTMeNHaJD]F@^C?\A=]B>^H=eMBiNFkOJkRMs[V{e^yaYx`Y|e]xd\xe]ug`th`wg`wg_yj`ug[ofZmh\gg\ch[bhZ^gWcjY]gW\fY[fX[iWZiUWhWXhVVfUTeSRaQRbQQfSQcPPcOQ`OQ^NO[KVaQWbRVaQWbRZdTZdUZhY\h[]i\^hZ^jYbm^epeiofmpfnnejjafh_fh^hj^ji]kj^lj_ih^gj[efWgfWjf[ki^kk_tiatkbvndyohzlfzlfxic{kdyib|ldmh~kh}lizifxgcziezjgzkipjmh~leoh€nfƒpi‚ok€mj€mj€mjlili~ng€mh€mh€mi‚ni„pk„qp…qpƒpm†rp†qo…qo„rmrl‚rlqkƒsm€pj‚omml~jjml€ll‚nm‚ol‚ol€mjlilili|kelgkf€lg}je}kdihkh}id€id}ha€jd€kjƒnk‚mk€lg}id{hc}jemh„pk†rm…oj…pk‚qjƒrl€pi‚qnnn€mm€olom‚qn‚ol€lj€miqj‚sl…rmƒpj‚oi€lf‚ol„qm†rp‡sn~mg{ohol{liylizmiwkgtidxicwf`wfaygbzhc{ic{ed~iflezg`}he}hfzee~ie}idmhml|ffxebvc_ua\vc]|hf~jkjh|jgzjgyifzif{he}ngmk}mjxhfxheteb{kd}mg}mg}ng}mh}lg~nh€mg„qk„rk„ri|jazfa{gb{gbkf~jemh~jenhmh|hc}id|hc|gbzfa{gazfa|hcxd`xf_rb[l`Xk^Vp_Xv`Ys`]ua\s_[r_ZsaZsaZs`Xwd]u`Zs]Wt^Yt^Xr`Yr`Yr_WtaZubZvc[wc[vc[s`Zq]Xr`Xs`XraVs`XuaYs`XtaZt`Z~g_{e\vb[tb[o]Wn]Xp`YtaZw`[u`Xr^Vo]Um]Tn]Tn_Tr`Ws`XtaYq^VvaYw`Xv`Wt_Wo\ToZRt_Wq^UsaZq`Zpb[pc[ud]s`Yq\Vo[SlYQlYQlZQk\Rn_Vk`Vm`Vp[To[RmXPmXPlWOo[SlZTkXSkXRk[TjYSgYPiUPfTO_OIbRKiWMjYMmYNmZPjVPkYRiXQj[RmZTiWPfTMgVMeXObWKfTKeVMdSKeTK_PG^PFbQJ`QH`PGbOEaNCdPFgTLeSKdQK^LEWGBTHBUFBXIC]MG\LEYKCUI@WJAWLAZLC[JG[KE\LB]RE_QJYLE[NFYKEZKI^MFZNFVMDZPE^RIaPH\QGXNEZRE[SF[QD^QD]MG\MD[ND^RH^RH[LFWLFSIBRHBUIDSHAUICRJARH?SG?UIDWKDTKFPKDRKDWMFWMFXLFVJDTHCVJCUJ@VMCSJBTJEVJBTJCSKFQKFOIBRLBUP@WQCZQGZQFUQDTRD[SJZQHYPGXPFSNBPMCQQDNMBMMBRKEUKCZLDXODYNEXJDWKFXNGWQH[QJ[QJWNIWPGXUJYUJYRJTNGTNF\TL_WN`VL[RKXQJTPETODTLCUKCVNBNK>ON@NRBEL:DOL=>M=;VE:R@:L;9K9:O<8P=8Q?:Q?>RB?RA`F@aHBgPInWOoWPvZTqXQpZRr^WybZybYzcXzf[{f[yg]xf`ygbzgbzg`ye^ze^vf_vgauiaph_li_mk`kk_ghZagXajZ\jY[kYWfXYhZVfVVfUU`QT]MP[LQ\MQ]MNZJKXIHXGJXHR^MQZLSZMV]RZbW\fY^fY`i\`h[bh\fl_jqgstkwpiskdohdmiblj`pjbsjbribtidsidsj_pg^pg^qi`sjaumdvhbwjdxlfxke{ke{hczh`yjcykexjd~nhmf|kh|leyjbzkezme|li|jb|iake‚nhngngli~ih€mg‚ni‚ohnh€lg€jiljƒnm„om„ok…rl…qn†qo…pn‡ro…qk‚piƒpjnk„qnƒqj‚pi‚lk‚mk€ki€mj€mj‚pm„nlljmh€lgmhni€nl€nknk‚mk‚lj…om€mg~mg~mh{ie€khƒki‚mk‚mk€ki~kf}id}ib{id€mhni‚ni…rm‹to…pm„qoqn€qn|li}jg|ogqkƒropl€nh‚oiƒomƒomljpm|kh€nl‚olƒro€ol€nk}ig‚ljml}jh€mjzig{kfzke~mgxldylcuhbwjdvid|hbkf|hcxcb}hfkj€hf€jg€mf€lf€jgjhzjdxhcra_wcayebldli|ifzhe~jg~khlimh„pkƒmh‚lg}hc|hd‚piƒpj‚om€mkzih{ii~nf€mh‚pl€kj|ffxdawa`ye`zg`~ke|hc}if}le‚ni~ke|fazfavd^qg`vga{gbzd_|fa{e`pcXte\td^sc]ta\q_Xq`Ysd]tb[tc[tb[q^Wq^Zta[taZxe^yc[vaYzc]zd_w_\wb_yf_zh_ra[r`Xu_Yv_Yyb\{e_v_Ys^XsbZr`Yub[vc\rc\tc\taZwb[xe^taZr`Xub[s`Yr_Xs]Wr\Vr[Uq]Wr_Xl^Wq`Wud[p`Tr`Uu`Xq[Uq]WmYUq]Sq^Tn[Ttb[seYpdXrcZqaXm\SgVMiYOjZQkYPk\Ol^Qk`Sm]ShXQoZTs\Wq[Vn[To\UiWPjVNlZSo]VhYRgWPdSL`ULcVNdTMgVOkXRkYQpZRmYQiWNgVOeXPh[SkYRdRI_QEcUIdVIeVIfVIdTHdTGfULfUMgUNdUO`QJ^NG_PIeTKdSJeRL_OF[NDXND[PGYLFWLCUKCVLCWMEVH@YIBRG@VKCTKBYOE[MD_ME[ND]QGZNDYMCWKBYMD[LCXNCVOETODYNDYJAZLC\OE]SIZPF[NC_OBbPHbPIaOH]MF[LAYM?WKEVJDWHAXJBUH?QH>PK?LG8P=;Q>8O;:R;:U>8T=7Q@7Q?8Q=8O>;PA9L@OC>PB:M<8N;8O;8R?7Q>7N<7M;f\‚e\‚g\‚h\g\€h]€g\h]~fZg[~eY€eYfZ~eYg[€g[g[€g\~f\~e[fY€fX}c\€d\dZ}cW}bU~cU|`W|aW~dZ~e[|cY}`W~aX~bY}bXfY}dXzcW}aX}cX}bX}bX}bX~cY}bX}bX|aW|aW}bX|aWy`V}bX}bX|aWybWxcW|aX{`W~bY|`X|aX}bYycVzbX{bY{`W|aV}aV|_Yz_Yy_W{bXzaW}aWzaWzbX{bX|aW}bX|aW}^Uz^U{aW}cW|cW}cU}`X|_V}cX|cWzcWybV{`Ux^Sv[Pv]Rw^Su\Qx`VzbZxbZyd\vc\s`YlYTfSNaMI[GDWC>YD@]B>`EAdJDhOGjRJpYPw`Xx`XzbZyaZv`Xr_WxaYzc[waZzd^zd]|f`{gc}ic{gazg`yc]{f_yg`ziauf^sh_oh_qi`qjaoj`ji^hj]ci[ai[_i[[fYXeWVdTVbRU`PS^NOZJP\KMXHIUEEQAKVDPXGPUFRUHWZN\_T]dWagZag[ej]dg[eh\nlavqgwkewjcth`sibtkbtibvicwjdymgyniyneymdymewkdvjctfayjcykeug`wiczhb{gc{ibyhbyidzkf|ke{ia}jg~kezjczjcyibwgd{ga{gc}idkfkf€kfjd€kf€jf€kflgkd€lg‚mk„om…pn‚mkmi‚nh…pm„onƒnlƒnk„qk‚pi„ql„qnƒpm€nhmfkg‚mjli‚ol~jhljlk‚mkƒojmh‚ni‚ojolmj‚ol„om…om…mlƒoj‚ojpi‚nlmj€kh‚nk„om‚ml‚nhnh€mhkhƒol…pm…qm‹uq‹tp†omƒom‚pmol|jg|ie}kepk„ro„qm„qm„rk‚nl‚nl‚om†rp…qnmjƒpmmjnk~mjkhlkji{ge~jgli~kg~mg~mg€nh€nh{lg{lgyhf|hc|hb{gc€ki‚nkƒnlih€jg€ngƒoi…okki~mg|iezeczfd|gdle~ih~ig}hfljƒmk„onnh‚lgkflglg€ni~kf~kf~khlj{jh}lj|ld~ke}if|hg{geydbwb_wc^vb[xf_{fb~jf~lf€ng~jcyc^wd\zf_vgaxfa{gbze`~hczgbvg]vg_vd_tc]r`Yr_ZraZtb[saZsaZr_Xs`Yta[wd]wd]vb[q\TvaX{f_|e`wb\s`Zt`YraUn\Vq^Wt^Xwa[{e_xc\x`Zvb[taZq_Xq^Ws`ZqaZuc\vc\xd^{hasaZq^WtaZt`Zs`Yu_Ys]WsZTr]WtbZp_XqaXq`Wo_Ss`Wu`Xs]Wo\UmZUm[Qn[Ro^Vo]Vk]Sl_Sm]UiYQiWOiXOjYQgXOkXPiZNj^PmaUk^Tn]Vo[SoZSmZSkYQlZRlZRmZSiWPcUMbTKeVOeUNbVNcVNfVOgWPiWPjXQkWOmYQjWNfUNfUNeUNiWPhWPhWPcTK_OEcRGdTJfWMdTKbRIaQIaRG]PI`SKaQJ_OHaSIcSJdOK^MD[OEZOE[OF^NHYKCUJBWKDUJBQG>VH@XJDVKEVJCXMF]PHaQIYLCYMCYLCXLBZNCYMBYI@UJ@UNCWOD[PF^OFYJA[ND]RH[PF\OE_OF^NEaRK\NF[LEXMBUK?UIBXJCWF?SF>QE>PE=PI>OI>QJAVLCULBRI>RKBQJBQHATJCULDVMDSJ>QH=RK@RJBQG>RF@QFBQHDNFBOHCVNFVLBQK@RJCTMDVPBSN@SLBUJFXMFaTK`UK]TJXOFVSJUQHYQH\RKZNG\OIZPG[RI[SIZQH[SJ^WN^VL[SJUOEVRGWVJYXLYUJZRG\PFWKARH>QJ@LLAMMBQOENNDJMBAH<;G8;S==R?7O=8O=9N;f\€e[€g\~fZ~fZi]g[g[g[i]g[h\~fZ€h\‚i]g[eY€f[~e[f\fZeX~cY}bX}bX~dX}cW~dX~bX}cYxaW|cY|bX{^U|_V|`V|aW}cW|cWzbV|aW}bX|aW}bX{`V|aW~b[}`Y|aW}bX|aW|aW{bX|bX{`V|aWzaWxbX}`Yz^W{_X{_X{_Y}aY|dYzaWw^W|`X|aW|aU{`V{`VzaW{bX{`V|aWx`Vz`V~cY~cY|aW~cY~_V{^U|aW}bX}bX|aW}`W|`V{`V{`VybUyaU{`Vv[QsYOt\Ru^Sv`Uu_Wu_WvaYu`Xo[SfSKaOI]ID[D@[D@\C?`EAeIGeLHiPJlWOs]Tu^St_XxcZ~i`|g^xe]vc[ybZyc[zd^}gb~gc|fc{gazg`yg`}ga{e_~hb|e`yf_we^wf_viavh`ugavharh`ph_lf\ki]ff\cg[\cVYcUXaRV_OS^NR]MR\LP\LJUDKUDNZFOXFNTCSVG[^Q_cWbdXdeYfh\jj^gf[gf[mfYpfZuf]xf]yiayibyhave^wg`{ke{mg{nh|ng|mg|lf}nhyicvf`xe`yhbvf`yicxfayfayfavd_sb`tc`xhazhakfxfazgb{hcyjdvf`veaygcxeb|ge}gd}fcjcicid€je€ighfkfli‚mk€kijg€lg‚mh‚nj‚njmhƒoj…ql„pk…ql„ql‚nikflg€mf€mgli~kh}jjzhh‚mk‚mlmi‚mhƒoj„pkƒpn‡tq„qn„om€kiƒnl…rmƒoj€nj~khmiki€nkƒpm„om‚mk‚mk~liƒml†qo†qo…poˆrp‡rp‡rp†qo‡rp‚nkjhih‚oiƒpl…pnƒnl„ol…ql‚pm„pnˆsqŠsq†om„nl†rp€nknknkli€kiiiih€ki€ki€khƒoj…rm‡ro‡rpƒomli{hfje}id}gf~ig‚lklj‚jili„rkƒpj‚mj€ig€lglhkgkekf{gb€ki€kilj‚mk‚mkmk‚lgid~id}je|jezjdxebwda{hc~kf{ke{keyibkf|if~ih}hfxcbwb_{gb}jb{hb|hc|gd{jb|jb~ib{f^ye]xf^xd_ye`zfa|hc|idxe_yh`wf^ub]ub]ub\xe]we^ub[ub[tbZxd]yc]wd]wd]taZs`Yp]Vua[wd[taYp^Vp]Uo]Tn\Qm[TkYRs]Wv`Z{d^t`Yv_Yt^Xr_Xp]Vp]Vr_Xtb[ub[taZr_XtaZs`YubZtaZr_Xs`Yv`Zt^Xu_Ys]Wo]Vp^Wp_Vs`Xq`Vp]Us^Vq^Wo\ViYRl\Ql[SiWPgWPjZSk]RhXRhWQiVQiVPhVQfVOlYQjZQg[Qi]SeXNiYQjYOjYPkZQjXOiZQiZQiYTdWPaUMeYQfXPgVP_SKaSLfUOgXOiYPhVNgVMgVMfULhUNgUNeRKcRK^OIaSMaTMeTMeRKdTMbRKcSJ`QHaRH`RFaTL`SK^QI^MF\LE\LE]ID[JB[LCYMCYLC^NH]MFWIAVJBXNEVJCWLD`QK[MGXJDXKD]PH^QI[MGWHBXJCYNCYLBVJ>YMCWLBVMCULBZOEZND_NF`RIaRIcTK]OG^NG[OE]PGZOFVKCXMDQH>WKAYKBWIAUI@MD=OF?SK@TKATKBSJAPG>QG=QJAQIARHASIBSIATKBVMBTLBUODTLDPH?PG>QEAPEAND=ME?SLDSLCTNCTLDVPGWQESMBQIDQGCWLDbTKaUK^PG]PHZSJXQH[RI]QK`RL_QLZQG]TK]TJ]TJ_VL^VMYTMWQIRMEWOHSMDRLCTKARI?OE;MD:MGH8:F5:I98J:8M:8M;7L:8M;8K:7K96M93J77M:5K8:N;:N;;N==O=:K:>P<O=>N<L<;M=;M=9K::M<:K;;M<=K>=M?@M=>N>>O?=P=@O=@N<>L:>L9`J?fNCiQFnVKnUJoUJpVPs]Vs`Yvd]vc[zc\ye_yg`{jcvf^xg`xf_~ga|g`€jdidhc€gc€j`h`{g_|g_}fa{hazf]|f^~ia~ia{g_}h`|hbzg`zg`yf^ub[vd[qe]pf]me\idYidXf`V^aTV]QS^NTaQWcQXcPW`PY`O_aRegYklakmbhcXhaWleZme[lcYmcYneYrf\rf]vh_ug_uf^ye]tb[wd]tb[tb[wc^wd_zhamhzha{jbzh`{e`~id}je|hc|hdye`ydcxdcvcbtb_vc]wd]|f`xd^{fd{fdxe_yg_ye`zgbzfazhbxgbxgayf`|ic~je~je|hbwd^zf`{gb|hd}hd~ke|jb}hf}he}jdke€kh‚mk‚mk‚ni‚oh€nglfkh~kgkg~mj|khzhfwfd|ge~igjf‚niƒojmh„pn„pn…qo‡spƒom€li~mj€mj~lhjjzihzki}pl{kh}hf~gg}hgzgf{hf€nl‚om‚ro~nk~nlnknk€ki„om„pnnjnili€lknm‚om€ni€limjƒolˆtqˆtq†ro†qo…pnƒsp„sp‚qn„qn}lk{khnk€nk„qm…rm‰sm‰sn‡tnƒokƒnkkh}jf}jg}jg~kflglg|gf}if|jd~mgmi€kijhkg~kemg~lh€nk~li|if~jgli~kh}kg|fdxebygdxhezif|if{ha{hb}jd|idyicwgcvf`xe`yfc{hekgke|ge|hc|ic|ib}idjg{ia~ic{d^}e_|f`~hb~c`~fayd_xe`wd_vc^{h`yf`xc^v`[yb\{f]zf^|h`|g_{e]}f^}f^wbZv`XtaZp]VmZSr_Ys`\s`Yo_Vo\To\Tq^Wq^Wt`Yv`Zu^Xu`Yr`Yxb\w`Zu]Wt\Vr]Wo\UqZUs]Wo\Uq_Xs`Ywb\vc\ub[wd\vc\u`Yw`Zwe]zf_|e_t^Wp\To\SnZSmZRo\Tn\Tl]Sm`Vk[Sk[TgWQhXRjZShYPgWPgVPgTNiVPhWPeVOhWNdVN_TMbWO^TJ^RF]OG^PHaTKaVMbWN_TLaUP`TN^SKaUMcSIgTLgVOeUNeWNeVKfXKgYLcVLbUK`SI_QI_QJ`RJfVIdSL_OK\NJ^RK_RJ^RIYLEYME[OG^RI`TK]SHYPEYLDZME[NF\MGZLEZMDXMCXNEXLCYJDWI@WLBYOEZPFYOEYLBYOG[OF[ME[LCXK@UJ?THBUICUKCSH@PE?I;?I:>H9@J=I<9F99H;;K;;M=>M@9H:8F8PE>SH@UIASHAQE?SG@XLBYMC[MDZLCZND[OEaPE_MD^KDYF?XHCSGBXJAXKBXJDTF@SF@PC=PHARGAQF>SH@TJ@ULCWKCTIBRF@QG?SIBUMCUIDSJBSI@PJ?RJBOHBNKBPNDRLATNCNLAMK@JJAMKBRODTODSMERLGUMCXOGVMEWNCULCUJGUOJYSKZQGXOFZRHZSJ_VN^UM]UK]RL\RKZOGYQJWOHVLEUJCQE?OD>E:=E:>F:=E8;F9;H:=K==K=?H;AJ=@J==H:BF=@E<;D::E8;G<8I<;L?8G;;I<7G94F85G99H85E71B52D62E42G35D54F5/E32G45E58C53D14B04A14A14C23E2e^€e^f\|eY‚g[fYh\{e[~dZ€e[eYƒhZ€gXg[}eY{eX€dZcZ~cY}bX~aX~aX~aY~bX}`W}aV|`V}aX{aW{`Vz`V|aW|aW{`VzbU{cWzbVxaTx`TzbV{cVyaUzbV}bX|aW{_W}_Z|^X|_X|_V}_W|`U{_V|`V{`V{`Vz`V|cYyaTzaVx`Uz`WyaVy_XyaV{aWz_T{`Wy_UzaWx`TyaUzaWzaWy`Wx^Wz^W{_X{^Xz`Yy_Xx_WzbUzbVwaUs\ToZSiUOdRKaPIaOGbQHeTJiXMgYPgWQcSN`QN\OHUIAWG>WE=^H@bIAhRGmXMo]Uo^Wo^Xo`\n`Zj_XodYrd\sc]ue_|idzf_ugaue^vf`yi_wh[zh^xe_{h`{h^yg\|i_~hbf^|d^~f`zc]zd^~gc~h`}h_{e_{e_~hb}ga{h`zg`xe_xe^zfaye`wf_ue^sc\ud]vf_tc]pe^nf]if\ggZdj[bkZieZlg]me]oe]od^ob]qe\qe[pd[tf]uf^vg^vd]uc\tb[ta\vc^xe`xeayf`xf^we^xe_xebyf^taZxe^xe^ye_zfaxg`zha}jc|ib}ga€id{dcxdbzeczeazhc|id|gbyf`{gd}hfyfdxdbveaxgbwgayicxgbygdvjc{mgyke{hc|hc}id~ggjg‚lgƒmhkg€ii~jg~gf€hfƒkjkinkjh}feidƒmh„ni…oklelflgnhƒoimk‚jh{ge~ig€lj€mjli~kj€lhkfje}he~ih€jf}igyhdxgf}ji€lkkg}jd{he|if€iiƒji„to€qnomzlixlgxkf~kh}ifzgd|idlgmg{mg|nizkh{mipn}mkƒom~li{jh|khmj‚nl‚pmml~lkpn~pkrk€lnzjhwkeylf|lj„pp‰pmƒmk‚pm€ol~ol|nlkk}jj|jl{jhzjgyjeyhizjixjfzjfwha{jc~je}id}jekf|ke{ke~nh€lgni€lg€lg€lg~jj{hgzjdxib{ha~ic{ieyfbzfawe`xf`vibyiczkdxfaxe_yfa{hc}id}idve`sa\wd_ye`zg_}ia~ha}ia}f_~g_zg_wd]}g`|f_{e]|d]ye_}f`}e_}d^zb\{d^€gb}f`|faxd\wd\vc[uc^ta\s`[s`[ta\q^Yo_WmZSlZSjXQmXTq^XtbZwe\tbYvc\v_Zt^Ys]Xs]Vs_Tt`Vu`Wu`XycXzcYycZ|e_|c_x_[saYu`Zw`Y{b\z`Zz`Zyd_yf_zh`ldzf`s_Zn]UkYRkXQgWQgVQfVPeYQeVQiWQjVQhXOfWNdTNfTOgUNeRLdTLcUKdTMeUNcTLbSLcTIbUI^UI]RHaSM\SL]TN_TLaTLaTLcSLfVOjYRhXPj\RibWaZP^SJaPHeTLbRJ_PJ`RL]QK\QJXOFWOEYOFZMG[MG]PHXNF]LEYNFVOFUMCYNFaPI\OI\PK]QLZNIYMFZPF_RJ^OH]NG[MFUJATJ@ZNCWLBWNDXOEXNDXOEYLEUG@XJCWKCVJ@UI?QF?UHCUIFUIETHCVKD\MCZLCYOEXLDXLDYMEWMEXMEXJCWJBWJBSH@UI?TJARH?RG@TF@TC>SE?RF@QG@OE>TGAWJDTJCQG@OG@OG@QKDSKEVICUFAVF@XKCTLBNI@OK@OIAPLBNL>NK=OKBNLHOLFNLBPNDROESOEVMCWNDVMDWNEXPGYPFXPIZRJ\SK]SK_UI_TI^SI_UJ\PHXPFTKCULFRG@QE?RG@TJCSJDOEAHE@EF<>G::G:8F99G;G;=F:?J>=J==I9;F6E;>B8=E70.@1/>1/>01?03@1€d\d]€e[|eYeY~eY}g[{dY}cY~dYfXgX€fX€fZ~eY€g[€f]~cYdZ~cYbYbYeZ}cY{aW|bXz`Vz`V|aV{`V{`V|aW}bX{`VybVzbVzaUyaUyaUzbV{aVy`U|aV|bW}aW|_U}`X{_W{_W|`V|_W|`X{^U{_Vz_U{`V{aWzaWzbVzbVx_UzaWzaV{aYzaW{aW{`V{`V{aWx`V|bUz_T|`V}bX|`Wz_Vz^W{_X{`Y{aZx^Wx^Ww`Us]RoYRfQKfQNaMKaNG\JD[JB_MG`NHdQKeSNaOI^MI\JFYHBWF?YG=[J@`MDfRJlYRn\Usc[qa[qc]qc^pe]rg^tf_vhavfazgczga{haxf`zhazg`{i`zi`yj_zga{h`|j`|i`~h`{f^}g_}g_}ga|f_|ga{ga{e^{f_|f`}ga|f_{e^yg_{hazga{ha{gazeaxf_{ib~me}kd{ibyf_vhbukbsj`qmbom_kk\oi^qi_qg^qe^rd]rc^re\tf^uf_ue_wf_ud]ve]vd]vd]vc^vc^wd_yfbygaxf_xf_yf`xe`xe^xe^|ib{gaxd_xd_xfa{hc|hc}id|hc{hc}gb{gb|ib|hczgb{hc}gbzfa{fd|ge{gexdbwfazidzicyhbyhazibzjd{lf{ke{id}ke}ke~ih‚mj‚oikfkh€kj}ig}geih‚kikilkjh€igkf„nikf€je‚mgƒmhƒnkƒnklkji„mk€ki‚mk‚mkli}jg€kjlhkf€je|ie}ig{fe|ifygdxheyffxfdxe`wfcwfcyhe|jg€ji~mhmj|ii|ljyhfyjdzhf}kh}kh~lf~mg}lf{ke~nj}mj~nkol|lkmj}kh|kg~limjnk€mhli|ji{ljxjf{nilk|lj|mi|mi|kj~kjkiki‚ol‚pm~ol|mj€mi€lj}kk~lknl~oj{lk|ljyheyhevf`|id}id|je}kfmh|le|mgmh€mh€mhmhmhkf}hi|ig|je{hc~jd|faucawc_vc^wd`wgaviave`wgawga{gbyfayfayfawf`sd^sd]ve`wc^we^yg`xe^zgazf_}hb{hayf_{g`{f`|e`zc^wd\zd^{c^f`|d^zd^zb^xb]yd^xb]uc\vc[ta]s`[r_Zr_Zr^Yr^Yq_Wn\Um[To]Vr^Ys`ZvbZvbZs_Xt`Zu`Zu`Zv`Zt^Xt`UwcXwcYwbZ|eZzaXx`Y{a[|c]|c^wc]va[yb[v^Yr\Vt_Xud]{kb}lbzi_wc\o]Vo[SlYRjXQhVOfTOhXRk^UfXPhUOfSNgWOeVNaQKcRKdRKcPIbRIbSJbTKeUNfVOeUNcUKcUIaWMaQIeUPaWP_VN^QH_VMaWNdYPcYObWNg[RngYrqbii]`YM[PG_TI`PJ_QK^QK]RL\RIWNCYPEXNEZLFZMFZMGZOG[PGYMF[QH_SK^RKZNFYNFYNGZNHZOG\RI\RG`SJaTKbSK\NGWKCUKDYNDZPF[RHZQGWNDVLAZKDVIAVJBVIAWLBVJ@TI@SHASHAVJDWLDYOF\OEXMCSJ@TJAUKCVJCSJAUIAUH@WJBTH@QH?RG>TJAQI?TIAQE?QC=RE?SGASIBRG@RF@RF@RGARHBRIBRIBSJCPJCRG?UGATH@TH@SJ@SKBQNCSNFQLCOK?PM>RLCRKEUMFVNEVNC[RI[RIYPFWNDULCZQHXOFYQGVOIUPI[UNZTK\VL]UL]RHWMCXNERJAOG>PIANGAMFANIBMJBJG>JH?CD;@D;>F97E8:G<;H=;I<?J=?J;BM=AL??ID8:B5=F9>H;=G:?I<;H:;H;8E86C65A47D68D85I76G65D35C25C34D27A53?22@24C3/A//A/1?12@22A2/A//@/.A/,>0,>0/>0/<.1YIBZIBUH@VIATJ@TJ@WKAYMDYMCZNDXLB\PFYNDRI?QH>PJ?UKBTKBRF?SH@TG?UH@SIAQH?RF?RG?RG?SH@RG?PE=QD?OD=PF?PF?PD>OC=PD>RF@RHAWMFSJCRGARKAULBUKCUKAUKAVLBWPERJDRJCPK?SNARKBWMD[RH`VK^TJ^SJ[NH\SIXOEWNDYPGYPGWNEULIVLIVNHRLCPJAPKBULCSJASLCPJAMI?OMBHFAEE@EG?DI?AH<=E8?G<=G;;E99E9AMFCMCDMCFKBGLBCJ??H;>I<@J;AK@G8:D702?15B45B44C23A13>.4?/0=.3A17@54>22>23?11?01?02<000/?.+=/+;-.;--7*.6+/5*}b\f_f\|dX€e[e[}f\zdX~eYfZ|eY|dX|dX~cX~bX€cY{aX~e[|cY€dZ}cX}aX{dYycXycYxbVxbXzbX|aWz_U{`V{`V{`U|aWybVyaUzbVx`TzbV{cW~bZ|bW{`Vz`T~bW}bT{aU{aU{aVy^T{_Wy]V{^U{_Vz_U|aWz_Ux_UyaU{cWy`Vy`VyaVz`YzaW{aW{`V{`Vy_Ux_U{`Vz_U{`V{`V|aW{aVy_Xx^Wy_Xx_Xu^Vu]VmWLhRLdPK`KI\HF\FGXHBZJCZJD[KEVEBUDAVC@VB=WD>\F@aJDeNHeQGgUJkZQp`Yrc]tf`zjbzjdyicxjdylc{ndmglg~ig}id|ib|jbkcia|g_jc|jc}jc{kc|ic}jcgb|f_~g_~ia~ia}ia{h`{gazha~hc|faic~ha~iajble{ha|ib{hayf_{haje‚lficicicƒmgngmg‚oh~kd|kczjavhavjbxhavf^uc]yf`xhave^vc\vd^xe_wd]yf_yf_yf_zfaye`ye`ye`yf_yf^zf_}jc|ic{h`{gaxf^zg`wc^wd^~ge{dbxc`zfczgdzhd€jc{h`}jc{ha|id{hc~hc}id~je}id{hc{hczec{fd{fd|hc|ib}jb}iekh|if{jgyheykhlf~kf€mhlg€mh‚pk€lf~je€kfƒpk„oj‚nhjh€ig„ni„ni…ojƒmh…nm…nkljji€kj„oo‡pn„omƒnl„omƒpmƒpm‚nkje‚kgjf}ig{hhzhgxgevebvebvfcufcufcvfcvebvebtebvfc|heydbxebxebwdayfcwfc|kh{jg|kh|jh~mj|lf|kg~li~mj|ki}kj}li{li}nk~ololkh~ng{kf~lk~ll~ompm~ol~mj}kj}kjzifwhezhe|if}if€lf€ni~pj‚oimjmi€llmknj€ljli~jg{jg|kh|lfzlfzlfpi~nhnipkmjli|jgygdwfbvfb{gf{gd~id{gb}he{hexhbwf`wd_xg`vg`vkcxidxjdvf`ud^te_wd_pc]qa[o`Zp`Zl]Vl^Xl_WnbZrc\o`YpaZue_we^uc\vd]vd]tb\vd\s`ZuaZxa[w_Yu^Xr\VpZUt^Yq]Xo[Vr^Yq^Ys`[p]Xr^Yua\v`[s]Yr_Ys`ZtaZr_Xq\Ur[Vs^Uq[Tq\Wr^YsaYxg^|f`xc[{f\xdYxc[{e_€h`}f^zc[w`Xya[zb]wd\xd\u`Yva[q_Xo]Xn^Vk\Rn^RlZOiVMiTLhUMjWQkXQiXPgTOfSNaVJcVMbTNbSMaQKbQKaRHdRIdQIfSKfSK`QIdVIdTMdTMgWPfWOdULbRKgRKcQJgXPcXLfUIeULfVMgWOgWMgVMjYQk[Of]Qc]O`VJ`QG_QH]PI[NHZNHZRHYQFYUF^UKYPFZMF\NH]QJ[QHYQJYMG[MG`QK^RMYQI`VM\QI[PI^RJ^TI`WJ]TGXODXOEWNFWMFWLGWNFWNEULCSJAQF>YHAXHAYKDUH@VJAVMCTJ@[NE[OE]QGZND[OE[OEVIBSI@RI?QJ?SJ?SJ@UJBXJBVIATG?TJBQJASIAUJBRG?QF>SI@RJARHAPF?RHAOF?QF?OF?QH@RHARHAOE>SGAUICUMFSMDULDTKBRH>RG=TKATIETJCULBWNBUKCSLCYRH]VJ^VLZRHYNGVMCWNDWNEVMDTKBRH?REEPD@NDJC:OGAMJ@LJ@MKAKK@HI>EH<F<?H=@J>AK>BL?BMBDLBDJAGJAFI@?C:=F9=F915?25A3.:-2<-2<,5=.3<-4@/8C44=21=1.;/,:.-9-.8,-5*/7,.6++2'+5(.8+/;--8+08+.4).2'.2'f^~f^€f\g[€e[e[}f[{eYfZ}cW|cW{bVeYd[€f\‚g]g]}e[e[}e[}bX}bXzaWz`W{aW{bXz`V{bX{`V{`V{`V|aW{`V{_UyaUx`TyaUyaU{cW{cWyaWyaVzbW|bW|bW{aVz`Uy_Ty`Ty_U{aV{aV{]U{_Vy^Tz_Uz`Vy`Vx`TyaUx_Uy`Vy`Vy_XzaWz`V{`Vz_Uy_UzaWyaXxaWxaWybXzcXzcWz`Yy_Xv]Vu^Vs\TlUMlUJgPGeOHaMF`KF[HDXHAWG@YHAWG@RB;RB;WB>ZF?_KBaNCdPFeRIhUMkZRraZwg`yg`zhazi_zha{jc}kd~mfmd€ldmf€ke€ke€le~jb~id~ib~ib}kclclc{jc}kf}id}gb€ia€ia~i]~h^~ia~ia{h`|ha|g_|g`ic~hb€kcic}id}ic|ib}jc{hazg_kdkd~ic}ib~jcjd‚kejd|ib}kc|ibxg`vhbvhbxjbwf`zh`yh`zgbxe`wc^zeazeayd`yf_xe^{haye`yf`xd_wd]zh`{h`{h`zg`xd^yf^{hawd]yf`ye`wc^xe`xd_wc^zfazfayfa|gb|hd{hb|hd{hczgb~hc|hc~je~jd}kd|jc{gd{gd|hc}je~kf|ic|if}jfzhe{jgxgdwgc|hb}id~ifkg~je€mfjflgƒpkni„oj‚lgƒkj…ml†ok‡ql…oj…ok†pk…nkli‚mj€ji€lj‚ki‚mk‚mkmkli€mj~ke~lf‚lgid|hg|fhzigxffwdbvebvgdthd|ihwfczie|jgvfctg`xdcvc`ta\vd_sa^tbawgdzjgxhdwfewfexhfxjdyie{khzjg|lj}lkzkh{nj|ok~ol}kh~jh{lf}kh~lk€nm~li~nj{lh|kjlj}jiyih{li{mj~likflgohohƒpj…pm‚ol€mknj~mgkh€lj‚omnk}li}li~mk€nl€nk€nk~khmklili|khwgdwfdvgdxecvd_yf`xe`wgbufcuf`vf_vf^wgaviavlbxjdykewjcvf`rb\pa[m^Xp_Ys`[r_Zm\Vm]Wn`Zpa\pb\qa[p`Zsa\r_Zs`[vd_ud^uf`sd^ta[wd]wa[wa[r\VmZSnYRp]Vr^Xo\Vq^Zq_Ys^Yr\Ws^Yub\s_Zs`[r^Yo\Vp]Vs^Xr\Us]Vp[ToZTp[Xp\Wu`YyfZu`XuaW{g\~j^ze^zc]vc[ye]vbZuaYwc[xc\rfYsaXp]Uo\UmYTmZUmYSkWOjVMkWNmWPlVQjXPgVPgVOfVOaSNaRL`TK_RJ\QJ^QK`RJeSKgWJhWLjVNkWOhWNgUMdVKeVLdTMdTMcSLgXOgXMhTLcQJ`QJcVKfVJgTMjWOfSKfVNfVNhWOlYPcWM\SJaTKeSLcSL`SK]RI[QHYPGZSH[UG\SJZQH_QK_QK_RK\QI[QJ]RL[QJ[QJXMFZPJaVN_SM^RL[PIZOG[RG[PHXNERKBQKBTLCULDXLDWLDRI@RI@RH@SG?RF>SG?WJBXJBZLCXJAXLD]QH^SG]QF[OEWKCWIAVIAVKCWMCWMCWLBYLDWJBUH@VIAUJBRKBRGARG@QF>RG?PI?OI@NF@PG?SGARG@RHAPHANG@PG@OF?PG@SIBVKDTJDQHCOHBTLCRHATHASJASHCSJCVMDVOBVLETMFXOHXQGWODVMCWMDULBSJ@SJ@QH?MDEG=BF;?E;@F;>F9>E99C86A57C7>I=@L?@L?CLADKBCG@CH?>G9>H9?I:BH39@58A69A48@35>15;.7<08=1:>4:=449/7=35=23;16;/37,24*14)26+3:.14+-3*-5,-5+,2(-1'.0'11(/0',/%+/%04(15(03'/1&./%..%/.%|e]~g_~dZeYdZdZ|e[zdX|cW~dX~cX~dX~cY€g]‚h^€i`~i]}f[{bY{cYzaV{`Vy`V|cYw_UzaWy`VyaW{_U|aV{`V{aV|aVx]TzbVx`Tx`TyaU{cWzbVxdVxbVxbVwaVy`Uy_Wy`Vx_Vw_Sx`Tw`Sx`Sz^Uz^T{`V{`Vy^Uy`Vx`Tx`Tx_Uw^Ty`Uy_YzaWzaW{`Vz_Uz`Wx`UybZv`VycWzdYycWwaUx^Xx^Ws\Tt]ToXQkUMoVLlTIgPEfPEbND]KB[JCVF?QB:QB9QC8TD;\FAaKCdSGfVGeVHdUHhWPn^Wtd]yg_zf_}e^{j]|i`{ib~kd}jc}jcla‚nb‚me‚lfleib~ke}ke~lenf€mbla{ke}lf}hfic€ib‚hai_k_€ia€ia}h`}h`|h`}i`~hbic}gb}gb|hc~je}jc|ic|ia{h`{ib}jc{hazg`|ibzha~f`hbzf`zhaxgaxhbuibvhbvh`wg_vf_yg^zgazfbxd_ye`{e`yc^|f`{e_{e_ze`xb]yc^zd_|f_}h`}ha{e^xb\vd\xe_xe^wd]xd_xe`yf_xf`zg`zf`{e_}hahg{he{fd{ga{hc{hc}ge{gb~idle}kd}kd~ke€mh~kf}je|idzgdyhexfcvfcxgezhe{hd|h`}hb|eb}fd~hb€jdjekflglg‚mh†pk‡on‰spˆrn†ok…oj‡ql‡ql‡qkƒnj€lglg€ki‚ki~jh~ih~if|if{hfyhc~je~kdjfzdb|fizjhzihwcbudauhdujeyhg{ffzec{hewhbsgaua`ta^n]Xrb\ra^ucbtfbufcsdasdbtfcwhgyjewhdyjfwheyjgtdcsgcvjfwlhxifzif}ig{li}mk}mk}kj}lh}mgymg|jilmjl~mk|pjzlj~mjmh„ojƒqjri‚lk„olkhmioi€ng‚lj„olƒpmnl~lipl‚pm}khli€mj€ki~ig}jg|hfvfbvebuebvgcsdara]ta\vc^tf`secvgavf_ue^ve^sh^si_tf`se_rd^pa[ue_ue_qa[s`[t`[ua\ta\td^qc]p`Zqa[o_Yr_Zs`[p^Yr_Ysb]qa[rc]se_yg`we^xc]wa\t^Xn[Tp]Up^Vq^Vp^Wo]Vo\Wv\Xw^Zt]Xs^Yr`Zq_Zt`[u_[p^Vt^XnXRp[Sn\TlZSnXWnYUu_WvbUt_XuaWvbXwcYr^Ws^YraYuc\vd\tcZq_Wq`Wj_SgZPjYPlXRnZUmYTnWRpVQkVNmWPjTNiTOiXPhYQeWPcUMcTNbTNbTL]PKYNH^QKaRKfVLgWKiXLmYNnYQhVNeSKcTIdVKcSKeUNeUMbSK`REaPDaPGbUMcWNeUKcSLcTLfVOcVNbWOcWOiVO_TK]TKbUNbQL]NH]SG]SHZQH]TK\UK[UIZQGXOE_QK]OI_RK\QI\OI]RL[TM[TMYOH]OJ[PIXMHXLHXLGWKDVKBYOFSLCPI@MH?RKARJ@XKCSG?OF=PG>QH?QH?QG?TJBTH@TG?[LB^LD\LF\ME\NE[LC]MEZJCYJCYJBWLDXNDYMEZNCXKCVIAUH@VJBTJBRLBTICSHBSH@QF>OF=LHD;;C7:C89D79E79G89G99E8A7;D6:E3AI8?D5<@38<17:34925>27>17;17:17<63:47<07;.5:/77,46*24(64,56-56.25-/3*05,65*32'1/%00&02(/1'3/'.-$.0'-/'1/'3-&/,$-*#/-$/-%+* .-#1/!-+,+!,* .+#-*%i^~g\e[dZ}cY|cYzdYzdYv`V{cXzgX{dU|eW~dX}eY{eZ|dV|cV|bV{`Vz`Xy_X|_V}aW{`V{`Vz`Vx^Tt]Sw^Tz]T{^Uz_Uy`VxaW|aW{`V|aWybXwcXvbW{eZwaVy_Uy`Vy`U{_Tz`Ty_Uw^Ty]Ty]Tu\Vw_Vv^Sy`V|bU{aU{aU{`V{_Uw^Ty_Wx^Ww^Tz_U{^U|_V{_Uy`V{aZz`YxaYt_Xt`Xq^Vs\SrZSrXSpVPnULmUIgUIgSKdPI`MG]KD\JCXHCUE@TAXJBZJCWHAXKCYMEXKEXLBYMCXMBUI@WICVLCVKCVJDXKFVJEXKFVKFUIDSJAUKCWNCVMBSIATH?UH?VFBTFARF=P@;RE?QE=SJ?TL@NI;RH?QI@PKBMKAOLBRNEULHSKDQLDOIAULAWMCVIBUKBSLCUMDXNF^QIYMH[LF[IDWF@UF?NB=OE;LD>F==E;=F:J>CLDAIABF=@B8<=49;19>38>3;=18:.::.64,56236538-37,26+23*45,33*52(30*/0(.0)00(21'/0'/1'/4(.2'00'40,2-'/+&.-&,,$0-%1-$/-$0-'.*&-+&,,&--$/*&)$")%!*'")&!)'",*/*+'+'*)++!~f\}f[~dY~cX|aWzaWxbWxbWwaVybXyeX{dX|cX~dY|bY{bXzcU{bU{aU{`Vy_Vx_X|^U{_V{`Vz_U{aWx_Ux^Tz_Uz]Tz_Uw^TxbWz`W|bX}bX|bXzbXwbW{cYxaVy`Vy_Uz_U{`Vz_Ty`Ty`Vy`Uy^Tz^Vw^Vx_Ux_Uw^Ty_Sx^Rx^Sy^Tx^Tx_Uy_Wz_Yx_Uz_U{_Uz_Uz`Ux`U{`Zy_Xy`Xu^Vs]UnXPoXPnWPlTNlTNkVLkTHfRJeRIdQI]KD[HAWF?VB=VB>VC=[IB]LD]ME^TIZTGWWHW[IW\JRYEXUF\YJ^ZL`XNc[Pg^Tpb[oaXtdYtcXxg^zia|haicke‚lf€kelfngkd~ibkdja€ka}kb{ja{ic}idhb~d_~ja}h_|f`{ha|ia{ha}f_|f`zd^|f`zgbzfa{db{fbxe_xf^{g_|g`xe^we^vd]xf_zg`yg`zd^we^yf_zfawd_yfaxe^xd^xe`uf_td]re]tf^vf^xe^xe^}fa|d`wd_ua\vc\we^xd`xdawc^wc^xd_xd_xc^xc^ud\ub[ub[wd]zf`{e`xd_ye`ze`xd_|hcyd_vc_xeayea{gcyfbwc`yfazgc|kiyif{ie}je}kc~mezhbzhayfaxe`wgaxiczgb|id~kfyfa}ic{hbkf€lh~jf}hf~jfkhnj‚ok…pl‰so‡pnˆqn„oi€mfli€kimkkjjk~jhjh}jd~hf~ig}jgzjg{ie{ge{gexfdzigwfdwecxdbzgf{hg|ihyigzigxhfwgcxgczeczecxdau``qa^o`]m^[pa^s`]s`]scatectecsdbtecp`_m``obarecpcana_n``n`^rdbqdbsfdugewigsdcrfcuigvjh{ok{njzmj{nk{lj}lk~kj|iikiƒnk„pkoi}jf{ge~ihki€ki€ki€kikfƒnlƒnk‚nh‚nikflkƒmj‚lj„okkg|hc|hcxhbxeaxebvcbsbap``sdbte`se^ue_ve`ub_uddudbte_pc^mc]ia]kb\i]Xl^Yo]Zp^\q_^pb_rcaudavfbucaud`sb\sb]sb^sa]sb\scZoa[pb\rd^pb]tdbtebrd`yg`zf`xf^wd]ub\w`[s^Zr_Zq^XoYUq[Vn[Sq^Wtb\p`Xo`VtcZvc\s`[r_Zm]Wo]Ws_Xr^Yq]Xr^Yr^Yq]Xo\Vq\Vr^Xq^Wo\Um[VhVQfUPjVQiSNmWRhTOdTNgUOfTNgUNkYRiYReWQgTMhSMjTOmWPkWPiWOfTMcTL`TK`UM]SI^TJ]PI^QK^QKaRJaSKaTJ`SM`SLbTMbSL`QJaPJaRKaQKaRL\PI\OH[OHZKCYJC^OGbVMdXObVMeTMcUM_TL]SK_TLbUM\QIYNG\PI\OI\PI]QJ\RH\PHaSL_QJ\PHZPEYLFZKEYIC]MG]NHYLFZPGXNFWMDYNGUJDUJDQJCRJCWJEWKEXKETHBQH@QI@RJ?TKAUKBVKEWKCRH@PG>RIARH?VJBWL@VL@WMCXMDVJBUHBWICVICZMDYLCWICWICXLDWKCTHATHBTICWLEWKDWKDWJCUJBVLCWMDUHBTI?XKBVHETHCRH@RF?SG@TJASJATMCRLARJAQJAPKBMKAOKBPKANJELJBMLCII?LK@OMARJASKASLCRKBTJAWKBUJDSF@QC=OA;K>7L@;JD;GC;CB8>?6?B9?D;AA<=A:;D9=G;F;;E8;B7;B8;D9?G>6:=6;=599087/66-66-55-53,65,64,22./1--0&.1'//&--&.,'-*%/-#/+%-+&-+&0-'1.$/.&/0&-.$,-#,*$/*%,&"+($,)$,(#,*#-(#-*"-*#)&"+(#-+$.-$/+(,($*&!'& )'!&%+&0*!,%('*)!(*!}d[f\}fY{cW~cY{cXyaWycXxbW{bXxbW|eZ}bX}aX}cY{bX{cW{bV|bVy^Tx]TzaW{^Ux\Sz_U|aWy_Uz`Vz^T}`Wy]Sz_UyaWycX|cYzaW{bX{bXyaWwaVz_Uy_Uz_Vy^Tx^Tz_Uw]Qx_Sx_Uy`Vx^Tz^Wx_Tw]Sw^Ty`Vx_Uw^Tw\Rx^Tx_Ux^Xw^WxaYy_Wy_Wz^V|`Yz_Xy_XxaYv_Wv[Tv]UsYRqWPlVNjUMiTLkVNhRJePHaOHbPI\JCZHAVE>UE>XE@XE?YIC]PF^SI]RFWWHTXHQZIP\HP_HM]FPYESYGTXIRUGUWKZYO]ZOaZNg^Qk\PrbZsaZyd]xd]{ia~jd{hazha|gb{e`|f`}ga~f`~g`|ia{ha{hazg`{e_xb[ze]yc]zd^yf`zfazfa|f`zd^{d^{hazga{gazcazf`yh_yg^xe]yb]xe^vd]xf_xf_we^wd]yc]vc\vd\va]vc^ub^xe]wf^wf]wf]te\re[rf_th_vf_we]wc]|e`we^vd]we^ue_tc_ucayd_vb^vb]wc^ua\uc^vd]uc\uc\wd]wd]xe^vc^vc^wd_wd_yfavc^xe^yf`wc^ye`ydbydbxe`wgawfcvfbwhayfazhb{hbxebyfczgc|hf{keyic|id~kf}jf{ickg~kf}jg}jg}ih}ihjfkf€mh€mh„oj†pkˆpo†pl~kd{h`{gc}jg}hf}hg|gezec}hf~ig~kh}jg~kh|jg{he}jg~kh|ifzheygc{hezhd{gf|hg|hg|hg}ih}ihzhd{hexfcyfcxebyfcwc`q`]o`]rc`sa^wd`ucbtbatbasa`sa`p_]m^[pa^rcarcaqabqabpa_p`^m`^recqfcpdbpdatgetkhukixljwkhzmkvigwhf}ji|ig~ig}hf€lgmi}jezgeyeezec|gelj„om„om…pn…qplj|if‚oj€lgni„nm„nlmh‚ni~kf}jeyjdxgbzgdxebvcbvddvfaue_sc]tb]vd_wd`vbbsa_n_[oc_lc_mgbkdah^[j^[n^\q_]sa_pa`o`^pa_ufdvfdwectd^ra]sb_tc`wgawg_tf`ugatf`rd^sdatebvgbvgaxf`}jc{haziaxc_q^Yp]Xq^Yq]Xt`[o\Wr`Ztb[o]Wn^VqbXs^Xp]Wo\Wn^Xp_YraZub]s_Zo[Vo[Vo[Vn[Tm\TlYSlZSmZSoZVkVPfTOgRMiSNjUOfRNeUOeRMdPJeRKiXPeVP`SNcQKfRLhSKfRIhVKgWKhVOdSL`QJ`SK_TJcWMaWM`UM\QIaVN_UJ_VI\PI^RL^SK]RJZPFWND^OKYNH\OJXNDULCWNE\QI[PH\QI]RJ_TL^RL`SKaTL_RJ[OG\OG^OHXMEWLEWKEZNIWNFWNF_PI_OH\NHZLGXLEUKBXJDXICZJDZJDZKEVHBVIAWKCWLEVLEUICWICULDUKDXLFXJDVHBTF@RF@UJBTJ@VJ@XLDYKEWJBTG?UIAYLDXKCYLDUN?UN@WOBWMCWKDTIAYIGWIBYKE[MG[LFUGBXH@XIBYNEUJBULDSKBZKCZMDXLCXKCXLDVLCWICXKBYMCUIETKEPLCVMBWNDULCRKBTMESKDQLBNJAOMCNLBRLCRLBPKFMKCMMCLMBNPDLNAQKCRKDSMFPG@NF?OE>KD;IA9H@8G?6G@8JB9CA;@B8:>5=C78@57@4:@;:A88B6;C8?F;AFVF?WIAZHC\LE]SI\UIZWIVUGQUFPVFO[IM\GL]GNaJP^JO\IQ]JOXIOWJQWLTVGZYK`YLaXKeZQgXQkZSm\Usb[raZr`YraYr_Yq]Xwa[wa[xa[xbZxe^yf^xe]zd\ye\waYwb[yc]zd^xe^yd_xd_zd^{e_zg`|ibxe_yg`{fa{hcyh_zi`yg_}faye`xd_xe`xe`ub]ua]wa]vc^ua\s`Ytc[uc\wf]wf]ve\vd[sd[te\qe^pc^sc]wd_wd^xe^ud]td^ue_sb]td^uc^yd_ua\vb]wc^ub]ua]vd]vd]tb[wd]wd^xe^xe`xe`wd_wd_yfavc^wd]wd^xd_wc^wb`ydbud^vf`wd_vc^wfawgavcawdayfc{he{hezgd{leyic€mhlg~lg~je€mh}kg}jg~khji{hf}ie}je€mh€mh„oj‡qk„onkg}jc|ib{he|ifzec{fczecxca}hf}hfzif{if{he|if|he€mj~kh}jg}jg~kh|if|if}jf~jg}kglhli}hf|hf{hezgd|jg}igyfcwdawdaxfcxgdxfcwc`tc`vebtd`qa]o_[o^[m_Zo`]qb_pa_o`_o_`m^\p`_na_qdbpdbpebsfdrfdvliwmjxkivjgvhgvhfxig{hgzfd}khljƒnj‚ni}jg{hezfg€ki…pn‰tr‹vt…qo„omkj€ll€lknk€mini€mj~lhniƒpk€mh~keyhc{je~ig|ge|iexfcvf_xfazgb{hcyeaye`wb`s_]sdarebjaZmd]md`nb`ma_na_qa_vdaqb`rcasdbwhfvgesebqb_tebsdavgcuhatg_vhcykexjdwidtebufcthbyjd{hc~je{hawf^t`\q^Yn^Xn^Xq^Yr_Zva\yc^wc]q^Wr_Yr_Yo\Up\Vp]Xm\Vk\Ug]Tr]YmZUlXSnZUlXSnZUl]Ul[UjXRlYRiUPhTOjVQgUPgSNfRMdQLcSMfSLfSMgTOjWReWP_TK`NIfSNgRLgSJfUJiXKfTMeRKeSLbRK`RI`TJ]TJ^SK[NG\SJ^UK]TH]MG]MG^MFZKDZMC\OFWKFWKF\QI[RIWOCYQDYPGXOFXOF^SK^SK[OI\RI`TLaSK^QI[NFWKBVIDUIBTKBULCVNFVNGYJCYJCXIDYKEWKEUKBVHBUGASGATFAWICWHCUIAQG@TLEVLETIDWHGSGATHBVJDRF@TGATF@UJCWLDUKBVJ@VJBXJDYLDXKCWJBXKCYLDXMETM@VOBULBVLCXMEWKDXLFUICVJFXLHVKDWKDZKCXJCXMEWMEULBTLC\NB[NB[ODZNFVJBWKEYKEXKBUKBQFBOHCOLBTPEWQFSMCSKDSKDTLGRMEPMCLJ@LJ@OJARMCPLGPKDQKCPMCOLAPLAOJAMI?NI@HD;EA7B?5B@6?>4>>4>>4??5BA6<@88>59@66@46@44@38?7:B9:B7;C8>B8@B9>A8AC:=>467-17+4<0-8-/8.05,13*,,!.-#+,&)'!*'0*#0*#,* *'!)% *% *&!)&%#($'#&"*&!($($&&'#'"&"$!)(***&*'+% .(#-'"%! % '"'#%!&#&"#&#(%($% #"%%&& ''$$##'&"%"%#$&dZ~cY}bZ{cZ}bX{bX{dZzdYxcX}cYydY|aX|aV|_V{aU|bTzaVz`U{aV{aUy`UyaUz]T{_Uy^T{`Vy_Ux_Uz]Tz`V{bXzaWz`V|bX}aW|bXxbWycXzbXzaVz^W{_Xz^Xw]Wv^Ww_Vy`Uv^Rv`Uu`Tw_Uv]Tx^Rx]Qv]Sx_Uy_Vw_Vx_Vy_Wv]Vt]Uw_Yx_Zw`Xy_Xz`Y|aZzaYv_Wu]Ur\TpZRmXPkVNlWOjVNhUKgVJcSG_NG[LEXHCWGAUE@UH@XKCZNF^RJ^UL[WMUYIPYGN[GNYHLZHJZHJZHK[HM[IO^JP^KP\JPZJPZIPYISWGVXHUUE[WJ[UK[UL`VN]SJbVNcUNbSLaQJiWPkYQlZRlYRnZQq^Ur`ZuaZs_Tt`UubXsaYvaXyd[xb[vd\wd]xe^xb^wc^xe^xe^xg_yg`xc_yf_wf^xh_zgayf`zfayfaxe`yfaxd_ua\xb]s_Zua\ubZr`Zuc\ud\tbZuc[saYtbZtbZra]sa]sb\ub]ub\vd]sd]sc]sb^ta^t`\ua\v`[t_Zt`[r_Zqa[qa[ra\vc^saZuc\vd]vc\vc^xe`vc^wc_wc_vc^xdawd`wd`wd_ub_xeate`vd^uc\vd]vd^sc^ua^webzgc{hbzgbye_wgazjd€mh~kf~kf~kfxha|lfyjczje|lh|kh}hd}jf}jflhkh‚lhjh|gd{hayg`yfbxebwc`vc]xe_ye`zfcyedugcxgdyfczgd|if|kh|lh|jf~kgkg}kg|lgnkom€nlmj€li}jg}ff}ifygdwfc{he{hc{ed{gdxfcwfczhezgdxgdygdudasb_sb_r`]pb_qc`rc`rc`rcasdaqcaqdbpcavigwigxjhsfbsgctgevjhvjgxihygeyfezhgvdbwed}jjjj€kjjgli€ljmm„pk…pnˆrq…pnƒnlƒnmnj€lkkjll€ljnjolnl‚oj‚ojlg~je|kfmi€lh}ie~jf|hd|ic{gd|hf|gf{fc|ga}fezecweduecqd_re_rd_se`qe`rfbscaucbqc`qb_sdatfcuhevjfxjfykhtfdtfdseawjbzlfykevhbvhcufctdavkdykd{hdxe_tb\sbYn[Wl\Vk\Vk\Vrb\wd_|fayd_va\q\Ws`Yr`Yo]VkXRmZVmZUj[Tj_Wm\Vn\WkZTkZTm\Vn\Wj]Tj\Tj[ThYQcRMgVPcWQcUOdTNaQLcPKdQLdSLeSMeRMfSNcSLaVMaPMeQNdPKfSLfTLdSKfRLfSLfTLeSLaRI^RH^RJ\OH\QJ[PHZPHYQF`MH^LF\KD[KD\MF^NH\OJ[OG[PHZPFYOEXOBVMEVKCXME[QI_SJ\PG^SJ`SK`PI^OHVKCSIAUICTJBSKBSMDPIBNGASIAXJDWHEWHEVIBXLDUHCRGARIBSJCRGATGAQE?PF@OJBOIDRIETHDUHBTIBTKDSIBUKDWJDSJCUMDVNDTLAYOFWLFWMDXLDXKCYLDVIAUKCRKATKCVLDXLEUIAYLDXMDTHBVJDWJDXLEYNEXLDZNFXME[QHWNCVMCYOAWMAXLBWMCWMDWMDVKDUKBRH?PFALGALJ@ONDPMDOKCQJCRJCTJDQKCMI@HFHDB68>39?47?44<16=26<12:/7?49C75@54?44B6;A;9B7;C8;A69=3<<77:166-01')- (/",7'-9++3&+/#-.#+* *)')&&+(/-",+('*))&*$(#'"%$% &"$!&$%$$#$#%"&#!"#!'''*'!(# )"&"&"$!%!'#%!# %!$!"$ &#% %!$"##&#&##!"$'"&!$###~dXcZ|a[zb[}cX{bXzdYybXybX{bX{dY}cW~aV|aTz_Qz`RzaW|bX{_U{aVy`Sx`T{]U{_U{`V|aWz`Vy`V{_V|bXwbVz`Wy_U}`W}`W|bXycXwaVxaWx^Ty_Xz`Yw]Vu^Vt^Vt^Ux`TxaTu_Tu_Tw`Uw\Tx^Sx]Qw^Sx_Tv^Ut^Vx^Wx]Wu^Vw`Xv^Xu`Yw`Xw_Wx^Vx^Wv]UpZQrZRoYQmXPkYQiWNhWNgUMfUKbRF^OCWIATF@TC?VFAXJC\OHaUMdZQ`YP]XNSWIO[KJ[GG]GH\HG[HI\KI\KHYLKZKNYJO\KP[JOXGSZJRZIVXHVVGXWGWUFVTJSRHVRHTNEVMDWKDXJCYIB]ME`QHbRIaQFbRGhWLkWRlXQlXMo[Op]Rm\Tr^StaVvcXtaYtaYtaYua\vb]wd]vd]wf^vf]yd`xf_xh_wg^zf`xd_ye`zfayfaxe`vb]vb]wa]s_Zt_[tb[saZtb[rb[tb[taZr`Zp]Vo^Ws^\s^]t`\ua\sa[tb[pe\qc\ta^u`^u^[v]Wv`[s_Zq]Xn\Wn^Xo_Yqa[sc]tb\saZsbYtaYuc]td^ue_vf`ve`ue^wfctc`vf`wgaxhawf_whdve_wd\ub[ve^sdavc`yeaxe`vc^we^yg`wgawhb~ke|id}jd~jfzkcyibxhazjd|lfzkdih~igzfd~jh}gf|ec{fezebyg`xe^xdaue`vdavd]xf`vd^wc`ubatfbvfcvc`yfcxgdyhf{jexga|hc~jdlg|lf}mj}mj|kh|kh€mjnk‚jj~ji{ifzig}lf|idhf|gexgdwfczie}ifzifxgdvebueawfcueaucctcbtdavfbwgaxhcthfvjhwjh}on}om{ljxhesfbtgexljzlkyii{gbxeazgexfeyhhxgjzdg|ff€liƒqm‚ol€ljkfni…pm‚nllk€jj}lf}likmlmllnm~nk~nk€ni€mhmhnh~mjmi€lgmh€kf~je~lf~if~hf~ifjf}fa€gf{fdzgfzhgxfbzhazh`vf_xjcvifvfcucbte`tf`se_qf`uicwjdwkguhevigthesgbrh`whctf`tf`rd^pa_sdathawhawdavd`s`ZtbZn\Wm^Xn`Zob[sd^ta]r`]sa\sb]pa[rc\m^Vk]UkYSjYSkYTgZSi]Vo`Zn`Zn`Zoa[k]Wk]Vj^Uj\UmaXeYR_TN^QL]TN]TM\PKbSMcRMaNHaSKbRLbPMbOKbPKaTJaPLcOMfQOfROgTOcSMbPIfRKhSLhVOdTKaSJ_PJYKFZKH\PK[OGXOE[NDZND[NF\PI\PIYNHZMEXLCYKDUKAVLBXNCVJFXLGXLE\NF^RHaSH^OH^OH[KDZLDWMDVNEUIDSJBSLASMBPKCKG@SI@THBUGCXHEXGCXJBUJCTKDRKDQJCPG@OE>PF?ME>KG>JGAPHCRHCUJDRIBRJCRLDWMFXNHTMFSOFOK@QLAUMDSLDTKBUJBWKCXKCWLDUKCRHDUJFTHDTG@WIA[KCUKAVLCVJDVJDWMDYOEXLEZOGZOGXNDVLBZOCXNDXNDXOEWNDXOEYPFTKDTJATLBSHCNGBLI@KIAJG@JG@OIAOGASICRJAMG>FC9A@6><3::.:=6?@6C@7G@8C>2D?4GB4F@3DB4CB4;?14?.5@24A31?12A34A32=05=26>35?22=33>45A88=33:03;05:/.1)11*+/&(*!()*/"*2$.9)/;)*2"*-+*)(''&()(****'*-0".. )('")!& &!&#%##!#"###%&&'%$"$##' ("&"!$#$ " "!# '!% # #$'$&!%"("%$ !$ %"%!!!"!% %"$!$"}eY~fZzdX{g[{eY|dZ|bX~cY~aX|`V}cW~cX|aW{aV}bX{`RxaV{cXw]Vz^Xz]W|_Wz_U|aW|bV}bX|`X|`Zw_XzbWzcUzcU}aW}`Z{bX{bY{bX{aWzaWy`Vy_Yz`Yw]Vx^Wx^Wx^Wu_Vv_Wv^Wt]Uv_Wt^Ut`Su^Sy]Vz^Wv_Tt`TvbSv`Tv_Wv_Wv`WwaUx]Xx^Xu[Uu\UpYSpWQmXPs\TrZRq[SjXPdULcUI^RFWMCWKAWD>\E?]JC_MEeTKbULe]Qa]QYYMRXKKYIH[JGZHGZGF^GJ]GIXFJYIMXLOUJOXLVXMYWLWVJWVK]VN_WJ]WH[UF^VG[UHYQIXSFXQFWRFULBSH@SHAWHFYLGXKFWKCYKC]LC^ODbQFaODeRGjUOkUOmWRqYTrYTt]Wq^Wo]Vv_Zva\wd^tc]qd[qg]ud\zf^yd\ye]xe]xf^wf]xh_xiaue^xc^v_\y`axb_vd\scZta[ua]uc\vb^r_[o\Yp]Xq_Xr^Yt`[ua\t`[u`\ua\ra\qa[p^Yub\s_Zwc^vc[p_Xh\Vh\Vl^Wr`Xs`Zr`Yo_Xp`Ytb[vb[vd]we^we]yfaxd_ye`vebucatc`xgdxgazjdwe`wc^vd_ta\vc^xe_wd_sc]rd]td^xd_yd_td^ue_wgcxgdyhfxfevlfwjdzke{hc~jhzhfzgbxhbuf_whawe^wd`wdaxebxeayf`xf_zh`qa]rb`vebvcbta`wcbvb_ydcydcydczebyf_{gexfbxia{id{hd|ed}ig~jhjh|iclgoi}nl}mk~lknk€lj}hf|jg{khzifzif{jgwfc{he~jgzgdzgdyfcyfczgczhexhdyheyigyjgxljvigylj{om}qo~qovjgtgeugh{jkygixfiyddvbatbatbcwefxii|gj|gikk}ljyhdzjcyjh{ih}ji~mj}kh€mj‚ol…qoˆomƒjj~gfjj€lk‚nmllli}jg‚okƒmm‚lkmhmh€kj€jkmlli€mgle|fa}gdzfdzgd{hd|heyfc|if|ie}jg|hf|hezicugawfcugdse_vga{ld}kdylfxlfwkfvjfsgcpcaqf`uhbugarc]sb\tc]ugaugatf`rd\se^se^uf^ud\tbZtbZre[qe\ma[pd]nc[od[laZj^Yj\VhZWhZWfZUg]TkbVre[vg_sc\o`XnbXqfYrbVqbYhZT_VQZRP]VV[XU\TP`TNcXP`XQXSM[UL\RK`ON`OO^OM_SQcUObTNcTNaSLdSMeQLeRMeUNaTLaRKbQJbOH\MEaOH\JD[LF[NDZQD^QH^RG^RH]RGXODWMCXGBZKDVLBVLBXIBZGCVHBYJGXMJUJFYKD[MD[PHXMEVLESHCRGDOECRI@QH?UKCQH?MJAOMCPKBOI@SJAUJBWIAWIATICULETNGSMFSIBRHAQG@PG@PIBRLDPNDPLCSJFSGDVHEYLFWLDYPHRUMNPGJH@LI?SJAULAUJBWKD[KDZMEXMEUMDWLEWKDYKDZIDVGAVIBUKAVLCVOEUKDTKESKEXNIYOG\PF]QG_RH[PFWOFYRIXPHVOFWNFUMDXLFUICUKBTMCMJAIGABI=BH=FI>GG=IG=IF35=28A5;E6?F7=C5:=2;=42;?4:A14<-2B/3@04=12:/3@4->01<12;..<+/?*3C1-?-*4',2&36+.-#++!,+!0-'.,#*+)-+1".5),4)+0%+,",*"&$%&!'%,'1!%/(0.6$,*)'$"'&%#)%(%)&'$$##%#(#''%&"##""$$#!$ ##& '& &!(%'$&#%"#!# $!#'# "$##!# "( (!%}dX|dXzcW{f[ycX}dZ~e[~cXcZ~`W}cV|bVz_Uz^Uz_T|bTy`Uz`W|_Yz^Vx^Uy_U}bW}bV|bU|bU}bXb[y`Z|bYzcVzbSz`U|_Y{aX}dZ{bXyaWx_Ux_T{a[y_Xx^Wy`Yx_Xx^Wx^Wx^Wx^Wx^Wy^Ww^VvbVw_Uz^Xy^Vu]TvcVv`SxbWxaYw`XzbZxbWx]Ww^WqZRnXPnXPnXPr]Ut^Vr\SmZRkYPcTK_MFYIATI?WH>ZH@bLEaNGdTMgYQd]S`_S[^RU[MOZJHYIH[JFYHFWGD[FJ[HKXFKXILUINPFRRIXRH]SH^UJ`VMfYPjXMi[MdVIeVIcUJdWM^SF_SG_SI]PG\NF[ME]LEZJDXJDSG?UIAUJAXLCWL?XK?^OD]NF_NGdPIgQKhRLkVPlYRlYRnYSr]Wr_Xq_Xp`WsdZtb[vd]saYub[td\rd[sc]te_sg_rf^sd]tc]v`_vb]xf]uf^xe`vbata[tc^s`^o]Zr`[tb[q^Yr_Zt`[s_Zs`[ta\q_Zq]Xr_Zta\uc]ud^tbZp`Yj]Wi]Wn_YrbZt`[s_[sa\tb\ub[vc[tb[vd]vd]yfaxe`ua\vc_vb_xd_vc^xe`zfawd_xe`xe`vc^vc^ub]wd_tc^sc]ue_ye`wb]vd_ue^wfbwfcwfcvebuibwiczjdxgb{ifxhe{hcvf`uf`se_td^ub]vbbwcbyfcxeawd^xe`scasb_ud`vdbva`s`_vb]wb`u`_va`wb`yeayedxfcxgbxgazfb|fc{fe}if}jg{gb|kf}mf|kkzih}kk~li€mjki€nkmj{if}kh|kg{if~khmj|if{he{if|if}ig{ifyhezhe|lixifykixjhwjh{mk€sq}rpzmjuheufdwgiufgvgiyhfsa`ra`sbavfhyjj{eizfh{iiwecxgexhdxigzjh{ggyiemj‚ol…qnmkli~hh|ggji~ji}ih‚om~kh‚ol„qm€nm~mk€okqm‚qo‚pn€lllj~jfkh~ie|fd{hexebyfcyfc|if}ifyhfyfcydcyecvfctebtd`vhatgawic{lf{iewkesmxmhthdshdrgbsf`se_rd^oa[p`Zq`[rf]viase_xicwhduhbvgaue^ud]te^re^nb[pa[o`Yo`Yo`Yl]Vj[Uj[VjZWhYVg[Ui]UmcWq`Ytb\tb\tb\raYqaWj[SeZQeZS_WP^YS[VR]WR^TNbTLgWPdYR`XP`XMdXPcRNeRPbSPdVRdVPaSM`RL_QKdRMcOKeTLcSLbUM`SKbRK`MG\MF^NH\LF\LF\PH\SH\PHYNE]QH[NEYJBZLCYIDXKDUKBULBTG@WF@WF@VFAWHEWKFWKDZLDYMETHARF?QFBPD@QEBRH@RH?QF>RH@RIARLCRLCRKBTKBWKCYLDZKCUJDQHAPIBQIBRIBSIBRHARIBSLETNERMDQMCTICVJEYLEWLDVMCXQFVXNRSJRQGOMCOI@UMESLBTKBSIAUJBULCTMDWMDUJCUIAQF>SG?WMEXOEXOEXOEXNGWLGWKHYMIYOGXLC[OE\QGYODZOHZOG\OG[NGXKCXKCSKCRIAQI@TMDMJAKIAJJAII?IG=HG=FD:EC9CB8FD:DC8AB8:B66@57A4:D67@28@27>18;26=26=26>38@48@44<01<,08+,5(19-1=/0A03=20:.1<+.9(2=,2:**3'17+14'0.$+).-#31'0.$,,,/ ,/#+/#(,!*,"+*+* )( $%%)'."*3&-6'.5%.3",)'%%#'%'&'%#%'(''$$$&"'&$*"(!!"  !%"##$!$'!'!& &#'%%! !"&!%&"!$!#!# $''!$ |dX}cW{bWycX|cY|cY}dZ}bX~bX}bX~cW{aU{aU{aU|aU|bV}`Xz]W{_Xz`XzaVycU}bV{bS}cT~dV|bWy^Tz`Y{aXyaUyaU{bWy`VzaWy`VzaWx_UzaWzaW{_X{_X|`Y|`Y{_Xy]Vx^Ww]Vx^Wx^Ww]Vy`XvaUw_Vz^Wy]Vw_Vt`UzdYxbVxaYybYu`Xs^Vs]Sr\QnZOkXMm[Po\Sp]Uq]VnZSgTMaPI[KD\HCYFAWG@XI@_NDdRHbTMdYQ`ZQ[[QU]QS]OP^JO_MGZFH[JFYIFWHAWEGWFHUFGTFINDRPHXPF_PFcPEgTIn[Pv_Vz`VzbVwaRw`Rt]Sq\QlYNiXLgVKjXNjXMhUJiWLdSJcTKcWN[PHSJAPJ?PK?PJ=SL?SL@TIAXJBZMD\ME_OGbSKaQJdRKiWPgUNhWNm\Sq^Up^Wp^Vo\Uq_XpaYmaYsa\tb]td]te^qf\tg^tb\wd]ue\sc\r`\s_^qaZrb\qa^o_\sc]qaZr_Zs`[s`[t`\r_Zr_Zr^Yr_Zs`[rb\sb\sd^wd_tc]pb\nb\qc]sc]v__u`_ydbxd_t`Zvc\uc\saZtb[s`[ta\ua]wd^ub]ta\ta\tb\xebxe`wd_xe`xe`vc^vc^vc^xd_te_xe`xe`wd_vgaugavhbvhbwhdufcwgaxhbwgawgbwgeufcyebwebugatf`te_sc\sa`ucavdcveaudaudatc`vdbsc_yfcwcaub`vc_vb^vc`ub_yddxdcubdwecvebvg`zg`{hb}jg€mjyhevf`{jeyic{gf{gfzhg{jg}kh}khjhkhjh~ig€li}hfjh€ki‚mklj~hf}hf{hezhexgdyhdyifvgdyjh{ljyjhzol~qozmk{ihyhgyjgvgeuhfvigxgdsc`sdbtebugftefyfgxfgwefvedufcwhfvgewgeygfxgdzhe}jg|khpm}lh{jiyigxig}ihki‚olnknknk}kj~nkqnƒspƒronlmo€mmji|if{geyebxebyfcyfczfczgdvb_tbbucbxedwfewgfuefsf_vicvjduiewgdwdc|nh€rmzkhsebpb_oa^oaZpb\o`[m_Yn_Zvic{lc{kdxhbwhavedtbarc`sdasc`pc`ma]i]Yn_Ym\VjZSk[TiYSkZUl\VkZVk[Uj[Ui\Tm`Xvb^t`^s`]q^Ym[UiVOcVOdWPbVPdZR_WO\UM^SKbRKhUNgUNhWPbTLeYNfXMgUNgTQdSNcVNaSMbTN`RL`RL_MHbMHaPF`PG_OH_PI^MI\LHZMG[NH\NH[MG\PIXPFZPI[PI\PJ\NGZICZJDUIATI@PI?OI>RG@SD>ZFAYHBWICUGBUICWLDUH@PD>RF@SGAPD@REBRIAQG>SH@SH@UH@UIAULCTMDVMDULCUJBUIARICQIBQIBSKDSKDQIBUKDTJCUKDSLCTMDQLCXJDXMEVKCTKBRMBVRGZYOTSHPNDNI@LF?JA;CA7EA7LF=SLCYRIUNEXOEWNDWMCTKASNCUQFWPGWOFVMDUKDUJDXLFWLHUJCYMC[OEXNEWNDULEUKDVMEUKBUI>VJ?KE=KE=MH>NI@NH@OKDQJ@KD;HC:FA8CB8@?5BA7A@6>=4;>46>23?34=15>23=06?25<17;14;15;249/27.26+/2'03(.1%05(3;,3?.3B/5@44>13:,.5$.0",/ +4&/6*02&+-"**!/0&42'10#--.."00$,-!.-!*($#)(''() +-$(,$)0$+2&.3(+-!)%&$#"'&'%&%%'%%'&# %##"(((" ! %#$"%"" #& %#"# ("##$%& '"""#'"&! }bY|`X|cX}dX{bX|cX}bX}aW{`V}bX|bV}cW{aUz`Ty`T|cV}`W~aYz^W{bW{cWxcT{aU|bT}cU|bT}bW~cYz`Yy_Wz`V{cWzbUy`Vy`WzaWx_U{bXy`Vy`Vz^W{_X{_X{_Xz^Wz^Wx_Xx^Wy`Xx]Ww]Vx^WvaVw_Vy_Yv\Vv^UycXz`WxcXwaVu^Wq\ToZSoXPmWPmXPjXPn\Tn^Um[Ul[TeUN]NGZJCWG@YECYGCVG@WMB`VJaWJ]XO[XNTXMPZMJ[LH[KH]II^JE\IF\JEXFCVF?UBARACQBCPBJNCYTIaRKeOFnWKv_Rh\…f]ƒf]‡j`ˆl_…j]ƒi]ƒg^xaVs]Rv`VxbV{eYt]Qs\Pr]Pr_TveYocY]RIPJAMK>JJNBKF=ID;IDTLATOCOPFOOENLALH=NH;OF;LE4==3:>36?33>26<15;029/4<16;048,14*24)23*0.&*( -*#32(12'25&29(4>+1<*19+19,04(.0$-- /-)2"/5%/4'02&,.",/$..,+(())-- 00$3/$+)*+'()* *+!(( )*!&*!&*!--$((("'$&%'&&%(&)'*%(!&$$'-'$!"! #! " %#%"$ & !  &&$$"#$!  "#$&!%"%"|aWcZ}bWeY{aX}aW}bX|aW{`V{aW~bY~dY|bT{aSz`U}bXyaT|cX}bW|aW|cX}eW}bW~dW}cV~dW{`V|`Y~aZ|`Yy`VzbV{bWybU{bYzaWy`VzaWzaWzbW|_Yz^Wz^W{_Xz^Wz_YxbVwaVxbWvaUwbVwaVw_Ux_Xw^Xy`Zx_Yx`Vz_Zy`WwaVq]TlWPhUOkUNkWOlZRk[Sn`Wi\SgWP_QJZNFWKCWHAYIBXIDWIDYNGZTK[VLZXKUWLQXLKXIG[KF]KC[HBZFG^LF_KE\IBYF>VB>VC@TC@RABPAKQD\UJcTLiSIv[Q~gX…m_ˆk^‰lc‰ndŠpbˆm_†m_ˆobƒj`~eYfZg\…k^‚h[|aT|bVfZ†qeˆwkug[YRHLI?HM?CJ;FM=INAFP>ISBKUDLSDPSGRQEVUGXWJVTIUSGTRGURHXQEZQE]SG`UI^TI^TIaRKfUOhVOiWPgUOhXRh^Uj]Uo_Xk[Tm]Vl_Wm]Vj]Wma]j_ZnaZrb[rc^qb]sd]rc]rc]pa\oaZo`Yp`Yp`Zp`Zqc\tb`sb^rb[rc\rd_rc`ra]vc_xd`xe`ud]sd]rb\rb\qa\qb[rb[p`YpcYqd[pbZo`Zqb]qa_sd]td^uf_te^sc]qa[ub]vc^{gb{hczhczkevhbtf`sd_pc[re^tg_vfase_qd^rd^vebyfcxdcygdyigqe_mb[pd\tfase`ugbtfbsd`qc_wdcwcbvbaxfbzdbydcyecxebxe`wd_wdayedtfbwhd|ihzgezhcwhazifxhetebtf`uhbwjdwgfvedyff{if{if|if}khzieygd}kh€nk‚pmƒpmolmjmi{if~khli|jgwfczif|kh~ol}ihzhgygf|jizjhufdtdbwfdxfewfdvfctcavb^vb`sa^s`]ubbtdcud_ra]oa\qb_rdbqccrcarb`vdcudaxfcwdavfcugdsidrecrecscbudavebzifzigml|ih{he}ji|ig~jiƒonƒql}nizkixgfyhfwfbxf`tc_sb_vebwfczifwfdue_wjfxlhxlivigobcsebqebpd`qeardaygfugdsdasdarc^re^re_xge{igxifwifwhewifxhcxhdue`tc`tb`q`^tc_teaoc^l`[i]XhZUo`Zrc\paZn_Xo_Yl\ViYVl]VobZk_Xi\VeXRbRPaQLbRLdSLdPLePLeSLfRKgTMiVOhVOfSLeTJhVOgTPfRNbQMdTNeTJdTJdSMbRK`RL`QJ^PJaSMcUO`RLaPJ_KFaQIaOG_MF^MFZLE\QHXTJ\VJ]TIXODXPFVNGTPEUPFTOEPJ@OH>MFQI?TIBUJBXJBUKBRI@SJARKBTMDSMCPJCSJCUKCTICRIBPHBUJAWMEYOFXMGYNGWKEVKCUKDTLDSLDVNFWNFUNDQK@NJ?MI>LK@MLALMBKNAJK?PMBUODWMCUNEVNEXMDWMDULCQJAVIBYMFVMEULDSKDTMEVIEXJCVKATJ@OI?OMANUGJQCMODPNCPLBPH?PC6F@6F<5F<5C?7DB9DD;@C9@?5@?5=>4;>3:?47<1=<28:1/6,28.26+12&21'76+43(/.$,*!.-$11'14'-1!/5#-6%+3#-1#03(./%+,!++ *+(2"+2#-2#+.#*.").")+)*)*+, ./ -/,+*+ )+*-!+-#)* *(#%$'%('('$*"'$(())&%&$*#+%+#&$*&"0'$,!&!(&!..%& !"!# "!#  $"#" "!#""!""|aX~aX~aW€fY~bX}bX|`V|aX{aXzaW}aW{`V|bT|bT{`V|aW{eU}fY{bX~bY}aWbW|aW}bX}cW~bY~bZy\W}aY|`Yx^VzbW{cWu`Ry`W{bXy_Ux`VzaWy`V{_X{_X{_X|`Yz]Vy^WwcWuaVvbWuaVvaVvbWy_Vx_Yv_Yw`Zy`Yx_Ty_Yu[Sq[OoZPlXPjVQkUPlXSm[Uk\VgYS`TM]MFWKCTKBSH@UH@\MF[OI[QI^UMVTKTVLQSIMVGKYHGZID\HA[G@ZFC[IB[HA[FB\G>ZD=XBR?ARAMSD\WIbULiUL}eX‚l\ƒk\‚hZ…i_‡mb„n_„l]ƒl]„n_„ob‚j^„k_‡m^‡j\…hZ{_T~aV‚g[Šqc{m…tfi_VRNDGL>EP@FQ@GQBAS?EWCGXEFUEHTEKRFQUGMTFOUFKQEOVINUINTEQTEVVHTSEUSETRCVQFYQFWLD[OF[OI[PJ\RK_SMcTMgXPfZPeYNeVOdWQdZUj`\i\Vp`Yqc]oa[pb\pb\m_Yn`Zpb\pb\l^Xp`Zp^Yr_Zqa^qa]p`Yo_Xoa\pa_mbZrc\tb\vd^rcZoc[rb\rb\rb\rb[qbZrb[odYnbXmaXpc]rc_rc`ue_vf`sd^td^rb\td^uc]wc^zgb}icyicugasdaoaZm`ZpbZpc[re]se_pc]pc]rd^sa^v`^wcbwdbsdblaZnc\od\rd^pb\uhaufasd^qc]wcbwcbvbavb`ydbzebxefwedxhbxhbveaxfctiayje~jh{gfygdugauecsdatebpe_od]pe^sdbufcwedzgc}jf}hf{if|kh|lh}mj€pmnj|mj{khzjgyiftecyjgli{ifyhexhezjgykh}ihzfezhh}kj{ihucbvgetecwedvebua_p]Ywc^ua^t_]s`]s`^s`_qbZpbZpc\p`^pb_l_]rbaudbr`_qa]q_\r_\uebrfbod`pcbp`^r^]rb]ucasb_uec|ji}ljxkexjgyjjzjkylizmg}oi|njxjgyhdwh`wg_vebwfcxgdzifziezifyjcyleukergcpdana`pdaob_odaoc_pc^tc_ra_ra^ra^sc]yjc{lfmk~mjwheqb_rd`rgcwfcudan][ta_tc`sb^ta\o`Zj]Xi\Wj^Wm_Yk`Xoc\j_Wj_Wi]Vj^Xk\Yj^Vg[SdYQbVQ_TP[OK^QJaTLbRKcRKcQKaUKbUKeUMgWPfVObQKeUMdUNdQObPOaQN`SMgWLeUN_QK\LI[MH\NH^PJ^PJ[MH_QKbQKaMH`NH`OH]KD^MF[NFXNEZWL^[M[UG[REXPGWOGTPETPEQLANL@PMBPMBUMCQMBSPEROFUMHYNJVRHTODOHRJBNICRLFSMFTLFUMFSJCQHAWJBUJBSLCRKBVLDWLDXNEVMDVMDSMDQJBPKCPJCRJCSIBULEUMFQJDXMEWLDYNF[OIWKEUIBUJCTKDOJCQKDTKEUIDXNFVNETNCSODOPBLL>MNCKMAKMAOLAQI?TI?UMEWOHUICUGBXLFVJDYJDYLFXLGSLCOIAMJ@SEARE>TKASK@PL@RODLUDLRBMOBRPEQI@J@8PA8J>6F<7C;6B<4E?5G?8C>7C@8?@6;?6>499/9:0;;165,44*52(//&.0(,0&46+53&44&57(13&-1%-0%*/#,0$/4%18'5?+28),2#42$10&.-#)+"&*)-(1!+2#'-',)/"(/")- +."-/#/1%-0*.)+(,(-!%+$'))'&$$$%%''''&+#*&*)'((''%$"%!%!  ""%*% & $*)!'&#"!  !"#%  "   !$!!!!fYbY}dZ~fZzbU{eWycWxaU{bV{`VyaWyaVyaUzcW{bW}eZ}cU~cU}cU~dX}cW~cY}cW|cV|aW{aW{aV|aY|_[z_XzbU{dVycWzbZ|`Vz_VwbVxbW{dYzaW{cXzaWy`Vy`Vw^Wx_Xy`Yx_Xx_Xx_Xy`Yz`Y{`Yz_Xy`YyaWw`Vv`Uq\TpZRoXPkUPkTOjWPgUPgYSf[UaVP]RMXJGTHGTFCVFA[LE]OHaSNeUO_ULWVJNVHMYKHWIGZFGYHE[ID\K@[HA]GBZHC[I?WF@XF@WF?XEBVC@VC=UB@TBKTE]UHgSLt\S}eY€gX~fW}eU|^T‡j_„h]…i^g[h[…kc„j`†j_‡k`‡m^†k]fZ}dY„i`Škcsk‘}trfSUGDRADRBDQADRBIWFFXFEZGBZFCXEFXEIWEIWDLWFIXFEVDBVEIWEHVDMYILXGGSEIVIKSFNSGOQHPNFSPESODQNDUOFTMDVNE\QI\SKYOG\SKaVNaTMeVNiZRm]Wl[Ul`Vm`Wl_Wj^Xn`Xn`Zn`Zp_Yo^\o_Zs`Zp_XmaYlaYnd[of]td^td^re[pe[nc\mb\mc]ob\pa[p`[r`\p_]ma[jaYibYme[mbZqc]oc]re_ud^ue^rd\re]qe\se]te_pc`pc`na_i_[g^Zi][l`]nb]ocZsb]te_r`]o`]rbascbsb_wfcsdarb_rb_qc`ud^vdbxfdrcaqb`qb^r`audbsc^te^vcavcdwd_yfa{gczgbzfb{idwjdzke{iczgbygavf`tdarc`pe^lc]ic]ie\od[re_ufctebyhf{jg~kekfkhlill€lk~lizgdxecxfazgb}id{hezgdygdyfcxfc|if}if{he|ifwfbwgdvebsdcsdarc`udaue`uf_yf`ub_s`^r^]s`]ub]rb\rc]n`Zn`Zpa[qa[o^bra`q`\m]Um^Wn`Xp`Zo`Ym^[n_\na_o``o`]m_\ma]pfbylh}kiulewkhthhrgcsgeujc{ihygf{ki|mjwjgwkgrhbticzkh‚qn~lkwigshgsfeqbasdbn^\j^Zh\Tn_Xk_Zka^l`^n]Zm`\sebvddyedyed}hcwkdxjdyjcyhetdao`]ra^p`]ma^pc\pa[n^Xn\Ul\Uj]Uh[Sk\Uo_Wq][o_Zoc[meZmcZh\UiZWhXRfWQcUO^UL[TK^RN`SMdTNdTMgTMdQJ`QJaRM\NH_OJaQKaRLfSLgTMdTNeUNeWO`SK^OK_PL]OI[MG[NF]QH_NI_NI]NG[LE[LD]NEZNIYKGYJD[LD[OGWLDYNG]QJZOH\TJaXN[RINIBQMEOMENMDPKCOG@UJCWMFXPGZPHYOFWMDWPFTPGRMEVKDWJFWKGUJFULHUMFTLEWLFVKCUH@UKCULCTLCWMC[OE]PH\PIYMGWMFUNDQL>NNDSNEYQGWKETKDQLEUKDYNHXMEZNHWLESIBRLARLBRJCPHAXMDZMCYMEWNEUNERLDRKCRIARK@NK@KKBLLBOI@SH@QICIDUI@VKCSKAMJ@JI?HG=FB9G@7F@9LE>NH?RIAUHANJ?LG=KB9JA8J>8F94D:4C;6D?;?<7>?8=A7D@6C=6?<7;<69?75?328113-3/)/+&1.).-(.+#/-%11'05)48-05)21&33(02&/2'15'/2#)2&,6'2>,0;'+7$-5%24(02&,.",."+- +-)-!,-!*++-!-2&%,%''+!*-")-!(.(-&+(+,.")()''$'%&#$ '$ '%+*"+( ,)".)"&#%! + &#"!! !%!$ $$#!"$" "!! !!  #! ! "! eY~cY~cY|cY|dVzcWycWwaU{bV~bXx_UzaVzbV|dX|cX{bX}cV}cW}bX}bW}bXdZ|eX{cWzaWzaWx_UzaYw^Xx_WzaV{cVxaUx`X|`Vz_UwaVxbWxaWzaWwaVxaVx`VzaWy_Yz_Xv`XxbZxcZv`Xyc[waYwbYt`Xs`XubVqaUp^SpZSlVPjVOkVPhUPhUOfUQbUP_RM\PJWLESG@SEAWHCYKD`RJcWR_VR\YQUXLLVFHXHDXGCXHH\HDYGE\JAZH@[H@]HE\JAZHBZHAYG@XFAXF@VCAWD?XDCVEQYI]UHhUJr[Pv^Rx`Su^Pv`R{_U~bX|bWz`Uy`UzaVg`„i_…i^ˆl`ˆm^‚hZfY~fYƒl`‡laŠnc™w„xX[LIXHGXGDUDCVEEUCFYFBZG@YEEZGI]IEVDGYFGXFFWEDXECYFHYGGXFEWEFWFFWFGWGJWFITEKTGMTGMSFNUEPUHORFQSGQSFUTHRQEPRCQQDTQDVPEYOF\SIbWQ_UMbWNeYPgYRi[Um\Up^Xo^Wr^Yr^Yq]Yk^Vk`WlaZjaXjcZkc[sb]ud^pcZmcYlbZi`Xjb[ka[maZo_[p`]k^[i_Xg_WibYjcYlaYm`Znd[rf_vf`ue_sc_qc_qd]re^tf`rfaoc^k_[f_Zf^Zf\Zh]YfZVk`Xsc]tc`rb_o`]qb_qb`sb_udasc`pa^rc`rc`td^udbtbasbaqb`pb]s``udbra]ueara_tbaxefzggxee{hh{gg{ggwjeyie}kg|jf}lhvfaqd`rfbrf`mb\me^ph`qc[vg`vfcveaygdygd{hc~kgli€nj~kh|hh|if{he{hezgbyfawe_tgcsfbtgdtgctfbvhekh|ifxfctc`vdarb_m^]o_]pb_sa^sb^rb\sb[r`\r`]ta_sa^r`\qa[n_Yn`Zn`Zpa[qa[p^_r`_r^Zp]Wm]Vl]Wp_Yo_Ym^[o`]o`^oa`q_\n`\l`\ma]sebtgdsiesjgrifogdneamd^sedugevhfvheukfwkgwlh|mj}nk}mjzlivifsjhredob_pa_ma]k_[ka[m_[m`[ka[k_Zrb^uf_vfducbr``yfdyhbzjdzjdzhcvebo^[j[Xo^[o`]l_[j^XiZUfVQlZSkZScVOfYQl^Vo_Xs_]qa]k`Xj^Vg\TeYRiYWgWQcSM`PJ^RJ_SJbSPaRL`PJcSMcRKaPI`QKaQK]LFZLF[NHaTNfTMeSMbQKaQJ`RK^QI[NGZMFZMF\OI\OH[NGYNGZNGXOFVLDWNDXNEZMHZKE]MF\LEYKCWKCUJBUKCTKAVKEXPISKEPJCOKDNJCQJDQG@SGATJDVLEXOFZNGXNEYOFXOGTNFVMFTGAWHBSH@ULHRLEOJCPJCRJCSKATG@TIATKBVMDXNDZQG]OGZNGYOIYPIXRHVTGTRIUQHXOFWMFSLEQKDVLEXNGYMGYOFVLDRJAQK@KE;MG?QIAWNDZOEXMFTKBSLBQKBRKBVNERI?OI?II>JI?LF=PF=QGARICMJ@JH>MG>QG>QH?MG?IG=FE;HC:KC:KB9KC:JD:JC6C94E:5E;4C<7?;6=;6=>6RG=PH=KI?MKANH?RJ@TGBSJAMH?NI@MI>NH=NG>NH>NI@JF=JB9IA8LC8I?6F=4D<6B;6B;6D:6E<8F<8C:6@94@94>92D>8>95=;3@@5<>177.74,53,31)-1&05),2,(+%-.$23*46+.2&/4%-2$03$47(46'33$13)16*07*,3'+1#,1#)2&-6)-8',3$,0!/0!02',.")+ *, ()&)))'&($)()(%'&&%'')+.),&)'('(&%%#$!! #$$!!"#%$""# !%   ! !!""""! !#  !!#""{cW|cY~cX~aYzbV{dXzdXxaV{aW|aWyaWyaVzbVx`T|cXzaW}bX|aW{`W~bX}bX}bX|dX{cW|cYzaW|cY{aZzcZycXzaWy`V}aY{_XycWz`WzaWzaWy`Vy`VvaVt`Uv`UxaVz`Yx^Wx^Wz`Y{`Y{`Yy^XzaYxaYx`Yv`Xu_WoYQoXRjXQp^XmaXh\VcVP_RKYJGTFAWHCUI@VLBWMC\PE^UK[WMWWMRXOPXMGXJEYHBXEAZFF]IF[IE^JD[JB\KC]L@\IA]ID\JBZHAYGAYGBZH@YG@[HAZHC[ICZFR]KfcSqaPr]PqXNpWMnVLq[Or\Qq[PpZOq[Pq[Pt^Sz_X…h^„h]…i^„j[|dV‚aU„l^…pa‚k\‚j[l]kj[U`NCYFB[GC]J?]HC\HC[GD_KC^JC]HBYFEXFCXEBZG@[D>ZC@\EAZFAZFB[GA[GB[GC]HCZGCZEB\ED]FC\FE]JC[HE\JG_LF\KE[IE[HG]EG[DGYCLYHNXGQZKOXMPYMQWKQTHSSIURIZSHWPFZSG[RI\RJZPG_VN`UMcVNdWOfWPl\UjZSm_Wk_Wi^Vg`Vg_Vd_VjbYkbYk_YkbZf^Vg_Xg`XkbYmc[nd\nd]of]nd\se^qb_qb_ob`qebrfbqeard^sf^pc[ne^lc^k`\k`\laZnaWqb`rc`sdarc`qb_pa^tc`sb_rb_rc`sdarc`tf`td`udavfbxfbyibudawgcubaucbsb_tc`uhbuhbse`wgawgayhcyhexif{li|mjzkhufcuiethevhbxhbwga{gc~le{hczgd{he|ie|id{he|if|ifmj~lizfcxheyhexheyicue_te^sc`sa^xfcxgdsb_sc`pb_ufctebpa^qb_pa^n_]l][k]Zp_\qa\n^Xo_Yp`Zo_Xn]Yl[Xn\[m]Wj[Uk]Wk]Wm^Xn^Xo_Yq]Xs^\s^]q]Zq_\qa[q_]q`]sb_tc`q^\o^[n]Zn_[j]Yj^Zg^Yj_[j_[i`\h_[ib_ib_odathfsgergcqfbpeaxhfvgevfdujerhbng`nb`k^]l`\nb^mb^pgbmdapcbsgcpeaqd]vc^wdasb]m^Wl^Xma[ob_vc^s_Zs_Zta_r`]l]Zj[XgZVeYUfZTgYShZUhVPiZUeYSdXRfYSi[UeWQbTNbSPbSP`RN\QJaRO_RK_OI^NHbOH_ME_NL_OHZLF]OI]RJ^SK_NH\LF[LFUICWLEXNGYLGVJEXJDUGAXJDXKEXNFXOFULDXNGTIESICUIBYKDYHAZHA]KD\LFVICWJCUJBWLDUHAWJERI?VMCVMDTICSHDRGCQLESLEUKDWKEYLFXKEXNEWNETKBYNF^RJUKCUFDRHETKDYLD[MEWNC\LG[NHYMGXMEXLDYLDVNEUNEZQHXOFTKASJ@XJB[OGZPGVOFXRIWQJUNHQJCUMFVOFUPGUOFSNEVOGULEYPHWQGURDRKCQLCONCNI@KF=LC:LG>RJATKBTKBRI@NF=TH>RI?QJAPLCPJARJAYLCTJBQI@LI=LG=KH82=70<9174,75-43)20&01(76.64+32'22(45+-1*',!,/%24(05'16&.5%.3$.3$24%32%34%13)17+08+.5(+1#.1".5'-3&-3'+/"// .-/1&.0$(**+!)* ())((%%!)$%$#%$$$$()')')%((&&$&##!! !##$#""' % !!"! ""#!" " $  !%"zdX{cY}cY~bY|cW{cYzcYycXz`V~a[{bXyaVy`U{cW{cX|bY{bX|cY|dY|cY{dX{dVycWxbVybXycXycXw`WxbVzbXx`Uy_Xy_XyaZxcWybW{aW|`Wy_UzaWxbVxaVwaVwbWu`Xt_Ww`Xx`Xv^Wv_WxaYw`Xw_Xt\Us^Ur[Uq\Up[Un[Rl]Rf\S]ULZQHXMEVJCUG@WIAWJBZOF\SJ]VJ[XMTXMLWKJXJIXHF[KD[I@[DB]FE]GG]JE\IF\LF\MAZJC[KB\ID\JD\JBZHBZH@XF?XF?ZH@XFBZIC[GM\JceSwgWuaTnXNmUMlVJmXJmWLnWLnWKpXMqXMtZPy]V…h_†j_eYgY|eVz^T|cVfX{dUteUkeTZbRI\JC\ID_KB^J>]HC^KD_KE`LD_KB]IB\HEXGD[HA[E?[D>[C@\CB]IA\HA\H@\FB^GC_HD_LC_IB^GC_HA]H@[H?[GD_KFaME`LC^JB]IF_IC\FF[HI]JI\JK^LJ^OI\LJ\KL\KLZKNZMQXHOUFNSEOSFORGOQFUSIWSIYSJZQH]QHbTM`UKaUNbUPcYRe\Sd\Re]Tj`XlaYi^Wi_Xi`Ykb[nd\pe]oc[pd]pe_pf`oc_oa\p`^na^nb_rfbthcqe_rd^pb\re^nc]nc]m`]o`[pa[qaXk^\ma]nb^rdao`]pb[ra^tc`pa_rc`tebteatf_rd_sc`vebxhcvg_td_udbtbasa`sa_rb^nc\od\pd]re]te^wg`vecwfdtgdthetgdufcwgdvfcvgawe`yfazfazibxfbwecvgdwgcug_yfdyeczgdli{hezgbvfcyheyhexhbue_qa[p`]rb_ufbrb_n_[qa^mb^pd`nc^n`\p`]o`]m^\m^[l]Zp_\n^Zp`Zm]Zm^Xo`Zpa[k[Yk[Ym\Wk\Vi[Uj\Vk\Vn^Xk\Vn]Ys^\q][o^Zn_Xo`^q`\q`]ra^tb^q_\m_Yk^Xk\Uj\Vh\Vg^Vh[WfZTh]Vf\Yi_^kbcoeaqecpdbpe`sgbuiewifqd`rc`od`oeangbnb_k`\l`\mb^of_qjcodarcapcamb_oc`ucap`]pa[m_Ym_Ym`Yn`]ra[s_[ta\tb`o`]l`\i[Xg[Wg[Xf\UfZUeXQfVPdTNcVPbWP]QK^PJ[QI]OK_NL`OM\OL[OK]MI]PJ^QK^QKaQJ`OH]LIZKEZLF]OH[QIZOGYLF[NHYLFXLEUICUKDWLFTIBUICWKEXLFXJDWLDYNGUJCVKEUJBTKCTKBWJBZGA^JD[HBYIDTHAUMCVNEUMDQG@UHEULBTJATJAWJEXKEXKFTPHTMFWMFWLFYOITJDWNDWNEULCXMEWKETHBUHEWMIWNGWICWLCVND\LF[NFZOFXNF[PHYMDSOFVPGZQHWMDVMCWOD[OG[OGZQF[QHXNGXNHWOHVNGWOHWRHUPGXSIWVGWRGSLEWOHWQHSPDPKCMI?MK?LL@KG=LF>RLCUMDXPGVLDTKBTKCUKAWNDVNEUMDSJAUIAVJCUJCOF:0A;2<7-?82>;3==5=85A<7?:6?93>82:4-66+42(1-(1-).+%.+$..(65,42(.-"11$23'-0%+/#02%.0#03$,0!-3#.3$/2".1$/1#-.!./%+0%*0#*0#-.!,. /0!,/!*,!'+)++*'*)+%&'(''%&'$$"&!%"$"%&%!%!&#'&(&'&% !! ! !##$!$%(""  !    !! !"ycWzcX|cX}aW{cW{cYycXxbW|`Y~b[zbWy`U|cW|dX|cX}dZ}dZ|eX|dX}fX|eW|eVybVxaUxcXwaVwaVw`W{aV|aVy`Vy_YwaXycZwdYzbX|aWy_T{aWzaW|aWw_TxaVwdYtaYraXsbYraXsaXsaXtbYtaYs_Xo]Um\Sp]Vq_Xo^Xp^Sg[N]VIVRFPL@TKATI?VJA[KE\NF^SK\TKWTITWKKUIETGFXHH\HD^LC^J@\F@]FC_GC^IEZHG]LF[LG\ME\KBZHBZHBZHD\JC[IBYGAYGAZHE\JBYGBZFK[HZbPxhWvcVqZRmWOnXLjXIlVIoWKqYMsYMrXLsYMy\T‚e\†j_ƒg[gXhZ}bXz_Uz_Sy_SncS_cOR_LIaKA]FC_IB_H?_H?^IC`KA]ID_KC^JC^JGZHH^K@\E?[D@]DC]DA]HB^JA]JA^FB_HA^FC_LC_JB^FB^GE^HD\JD]IC]IC^JD_KC^JD_KE^LE]KE^JF_KF_KF_KE`NC^KD_ID^HH`LI_NK\KIZIHVFHVHHVHKXJMWJNTJOQGSRHWRIWQGYQGXNFWMG]PJbWPbXObYOf\Th\Th[Si^XkaYlb[qe^te]td]se^pd^lb^i]Yj^Zn_\ob^oc_qe`rf`qf`pb\pc]qb]qd\qd^qa^sc]ub]o^Wi^[l`^oc_pd`rd^rd^tdaudarc`sc`tebrc`pb\qc\rcatc`td^tc\sc]tbas``r``sa`pa[nd`lb]ma]rc`sc`tc`vcbtdbrecredpcatfdwfcwfcwd_wd_vb]wb]yhbsc_sc`sdaqd^rg_wdbwcb|if|jgzgbxe`yhevebudbsc]sc]rb]mb^l`\l`]la]nb_m`]la]la]k_[l`\pb_m_[m_^o_]m^[n^[o^Yo_Yl^[k\Xm`Xn`Zl]ZiZXm]Xm^Xj\Vk^Xk\Vl\Vl_Yn]\n\[o]\m^Xk_Vl]Zn]Zo]Zq^\q^[o\Zk`Yk^Xk\Vn_Yi]Wf[ThYVhZSfZTfZWk^]h]^l`_l`_l`^oc_rdaseaod^maZma]nb^ma_ka_lb]l`\oc_pfbog_le]m`]rb_na\k_^i_\l[[j\Xl^Wk_Vl_Wk^VgYUm]Wl\Vo_Yn][fYVeZWiZUeZVcXUdZSaVO`SMcSMaSM_SL_SM\PJ]OJZPH^PL^LK[JI\MJWJF]MHZMGVLDXNGZNF]PGVIEUICYKEZLF\NFYMEXKEZNHYMGXLGUHBXICVLEWMEVLEXLFVKEWKEXLGXLHUIDUJCVKCWMDSODXPGYKDXHBWICVLERI@SMDTODPLCOGBTJEWKEWLFZMGZMEZLD^OGUPJTMGVLEWMGSLDQKCXNEVNDXPFZOGZNHZNHYOIVNGWOHVLEVKDVOFXOGXOGWRIWQHXSHSNCRPGVPGYPGWLDWMCZQGZPG[QH]RH^RH]OI_OK]TLZRJZTL[UL[VM^YP\\IWRGUNFXPKWQITRHSLEPMCRQFTSHTQGUNGWRI[SJ\QIYME[QH[TKZQGZRHYPGXNEVKCUG@TJAQH?MD9F<3D<1A:.B81C81@6.E;4C=6@=6=<3<91;7/<:/=<29:065/74.63+52*70(93*33(-,#.+%/+(-(%/*'.+&1.'1/$0/!+,++ --0/"/2#.1"13$12#15&03$-0#,/#,-",.#,-#,.#+.")+&'(',)++%&&'&'&('*$&%&&'"$"!# !#$!!""" "!#!&$$!$ "  "!!$# #%%%"    # "!  !!~b[~b[€d\}cY{dXzeZ{bX~dZ{`Y}aZ{bX|cY|cY|cY}cY~cY|cZ{bY}dZ}dZ{cW{cW{aU{bV{aX{bXzeYwaXz`XzaWy`Vy`Vx_T}dX|bZ{aZyaZx`ZxaYwbZz`Yy`Yw`XybZw`XuaYs_Xt`Xva[t_Xr_UtdWr_To_SobXmbXncYk_Uf\RaUKYMDUHAUGAUG@\KCYMD[QH]SK\VMXXMSVJLWHFXFAXEB[GE]IA_L@^KC^LB^JA]HC^HE\ME\MC\LC[LD\LDZL?ZH?YGA[JB\JA\JB\JE\JAZHB\JC\HJ\JSaNtfTrcUk[RmYQnYMrWIpVHpYKt[QoVLpZMr]M{_R„h[‡k`„i]‚f[f\zeXt`Sx_Ss^RfaRU`NI^NF_ND_L@`HB^KB^JC^MD_OD`ND`MD`LA^ID\JD^HB^G@\E@]GC^KD\JD]KC^J@\HA_K@`ID^ND^KB^GD`ID`IC_JD\KD\JF^LE_MFaMB^JD`LC\IF\KI_MF_LFaME`KD^KB]JA\IFaMFaMG]JE\HE]JD[IFZHI[MJ[IJXIHVHIVHKWIKWHQWJNREPRFUSHWTHXSG]WN^WN]VMcYSe[TdZSi^[k_\n`^o`]ra^o_\j]\g[ZfZXla_mb^nb^re]re^qc]n_\oa^pa_re^rb\tc_sd`naZk`WgbZjc\pe^tdatb_udbsfbtgcrfboc_qeaqfbuebrd_pc]se_tg`sg^pc]re_pb]qc^ud^qa[rb]p`]qa^qb`pb`ob_qb^rd`tebqfarfbrecqe`rd`sdatc`webub`se^se_pe^od`pb_sdbvc^rd^ukcticse_we`ug`te`tdatc`r`^s_^h_Yj_XkaZpd^oc]l`Yka]la]ma]nb^nc_ja\k`]pe`nc_nb\m`Zm_Ym^\m^[l^Xm_Yj[Yl\Yq_Yn]Yi\Zf[Xe[Vh_Wlb[k\Yo[Zp[Zp]Zn]Xl\Vm`Yi^Xo^Xn]Wk^Xj^Zh\Xf[Wi^[dYUeYUfZSfYUg[Wg[Wg[XdXVgYWi^Xh_Yh_Wm_Zra[l_\j_[j_[la]oa]p_\m`Xo`Zoa[pc]o`^na]p]\l\[iZXi[Wi]YeYTcYUeZVfWTiXUgURhWUiXRiXRjXSjYShXQhWRe[QeYRfZUfZW`TP^SM_PN`PN^RN^RL]RL[QI^OH\MF]MF_OJ`OLZIGWKHVIGYMIXJFWICZKEXKGVIFWJHTHCWLDWMBXPGXNFZMD[MEXKCXMFXLGTIEVKGYNKXJGXIFVOFTNETOETMDUKCYMEYOGZNH[OJSHDZNIZOGULCTKBULCULDTMDVNFWICVJAZMDWLDXLHYKIVMKWLJVKFVLEUNDTODYMJZPJ\PJ]OI^NJ`OMYOHYOGYNF[PHYPFXPEWNDXPFWQHTQGSMDUNETMDUOCRMAVME[NFbTI\VI[TH]TJ]SIaTLbUL`WKaWM`YMbZPaYOaXNYWJWTJWUKWSKXULTPGVTF[VJ[UK\TK\TI\QG^RL_SM[QJ\TKYRI[TKZNJZNIZNHXKCVH>PA8J?:KB9F@2C;-@6-C6/A:8>63>73A<5@>5;:09<328/29046.50+6-*3,,2,+/+(0-(0-&3-%0.$++!+.#+.$*-$++#+/#13'34'33',, -,!25&/3$.. 11#52$53&35&/1$.0$00$.."00!/-#,* +*)(&&()(&&%&#&#&$'%'(&'#$%"'$&! !!!!#!%!& ('!  $"$"&"##$""$%!"  #  !" "#}aZ~b[d[~dZydX{dY{bX{aX|bX}b[|bX}cY|cY}cY|dZ|dZ{aZz`YzaY~dZ{bX{bX}dX{cWzaWzaWycXxbYy_XzaWzaW{bX|dX{cW{aYyaXw`WxbXwaWu`WzaYyaYybZxaYwbZvbYt`Xt^Wv^XpZTp\Sn^QqaVoaUocYqf\dZQ_TK`SJXLCVH@VH@YIC\LE_QI\TK\XNYWLWWLRXLMZLH[JC]HB`G?]GD_K?^K@]JB_KD_LE_KD^KB]J@ZHD^LB\JA[I@ZH@YG>WE?XFB\JC\JB\JD\JA[IA[ID^JH\IM\Ja_Le^PbVMdSKdRHfUGkSEqWNt[RqYPqZPq\Ou]P}eY„k_€h[fZeYybVs^Rp\Ol]P\^ML^KF^MC^JC_K?_J@`KA_MD`PC_PC`NDaNC`MB_LC^KC^KC`IB^GA]JC]JE_LC]KD_K@\H?_J@aIC\LB]JA^GC`ICaKC`KD^NE_LD_LE`MEaMC_KE`MC\JG_NI_NF^LE_KC_KD_KC^JC^JE`LE`LI_LE]IE^KF]KG\JI\MH[JFXICUFFWHHYJIZIIXJHUHJVHLXJMWJMUITVJTUJTSJUTJWTKXTL\SNbYSbXSdYTeYTdWSeYVfZUh[Vn_Zp`[qaZpc[pe^pd^nc`k`]m`^mc[ma[oc_oc_kb\hcZec[id]oe^qc`reatdarfbrfbqeaqearfbrfbtc`ud`td^wgaud^ue^qd^rd^rd^pb\pc]na[ra\sb`tc`tdaqa_p_^qd^sd_teboc_pdapdbsc^sd^tf`rc]sd^tf_sf`tg`se`oa^n`]qd`sc]qd^rgasibsf`ud_qd^qb^n_\p`]p`]r`_k_[k`Znb]pd_pd_l`[k`\l`\ob^pc`nb^l`\nb^qeapd`qe`ob\qc]o_]m^Zl_Xl^Xl^Yk^[k^Xi^Yf]Yd^Zc^XhbZjaZk]Zo[Zo[Zn\Yl]WlZVl^Zi]Xp^Ym[Wj]Xj]YgZVgYVg[WeYUcYUeXReYTdXTg[WfZWcWUeVTcYSe\Uf]Uj]Wm\Uj]Yk`Zi_Zma\j]Xl]Xm_Yn`Zj\Vm^Yk\Zj[XjYWiZWgXSdWSdXSaTNbWSdXTbSPcSPbSOeXTe\Ud[Ug]VcYR_VO`VObYP`VObWS`UQ\QJ\SJ\MI_QL\PLZNJZNIZOJ^PI[NHZLF\NI\MK[MJWLFWMGXLHXLHWIEXKFZKHWGEVGDVGBWJBZNDVNEXNEXLDYMEXNFZQHZMHWKFYNIXLGYJF]LGXPGWOFWPGWOFZOFZMEXOFYMHWKGXLHZMI[OGXOFVNEQJAOJ@NKAPLCSHBUKBVLDVLDVKEWKGSMHTLGVMFVMD[RIZSHYNH[QJ^TL]RLZMJZNKZNIZNG]PH[OGYOGWPEYMFXNEXNFVMEXNFYNFWOEUNAVQFYRL[OJ^TI]VJ`WL^UK^TJeXPfXPcZObYOaWN^WM^XPYTLYUIYSIZQJYPJ\QJ\SKYRFYPE]RK^QJaSKaQI^RK\QJ_ULZOGXPFUNCSHDSHBQF?LA:J>6D70B96C=5<;/<:-<9.?80<8495185/:8099/;;26:.5;.5:034+0-$3)#/'#/*%.+%.+$0,$1*#/-!00%-/$+.#.0&00&34(56*22&.."*++, .3#-1#/0"01#0/!10"03".1"*, ,, -,,-*))'(&+)(&(('$'$%" #!%#('$$# !## ! ""#$ ##&'#   """#$#$"""!"!! #      " %"# " |`Y}aY|cY~eZ|eY|dXzbV|cY|cY|cY~aXcY~cY}e[{eZyeZ}c\{bZ{aZ}c\{cX{bX|dX{dW{bX}dZ|cX{bZ{`Y{bW{`W{bW}eX|cWxbVxbVycWycWycWycVzc[ybZyaXxc[wbZu`Xt_Wt_XqZTq\Vq_VqbUoeZlbXj`Vi`V^SKTIAVI@VIAWJBWJB\NGbSM_WN\[PZ]QU\OS\PKZMJ]LG_KDaJEbKDaKD_KB`MC`LG`OE_OE\LE\MB]JB]KB\JC]K@ZG>YGAXF?WE@XFG]KF\KG^LD]KB\J@ZHB]IG]JI\IS]KWWJYMF]JD^ME]PDhRGoXPpXRoWPp[Rq\Qs]TvaU}dZeY€fYfXyaUl[Mg[Na]NP]KF`LB]IB^J?`H>_J@_MC`PDbOB`NB`MCaNA_LB`MB`MC`LD`LC_KD_KC]KB\JD_LD`LDaLA`KAaIC^LB^KB^IA`KBaMA`MD_OEaND`MC_LEaLC_KE`LC]KE\MG^ND\JD]IA[IB\JC^JB]ID_KD_KF^JE_JB\JD^LF]JEZKG\JDYHBVHEXIEZIFZIEZKDXIEYJEYJCXIEZKJYLJYKMXLNXJQXMSWLSTJSQHZVMYUL\VMZTK]VN_VNeXPhXPm[To\Uk^Vm_Xma[ma\l`\j`\l`Ynb\pd`mb^hb[fdZgd]hb[pf_oc`nc_peapeaod`pd`pd`qeaqdavebwfcudavf`ue_ue_sc`tc`rc_qc_nb^mb^tb_tdaudatc`ua_sa^qc]rc_sdanc_ob_odaud`ve_sd_rd^pd^qe_sg`qc_rc`o`]rdaqebpb\ob\rhaujcsf`rc]la[l`[k_[m^[n_]m^\o^[n_\qb_qearfbod`l`\m]Zra^sb_o_\nb^oc_qeaqearfbpc]n`Zsa[q^Yrb[m_Yk`Zl`Yk_Xi^Zh^Zg_[hb]f`Xi_[j]Yn]Zp]ZkYVgXUlYVj]Yg\WkYVlZWfYUiXUgWTeVSfXUdWSbWScWQeYTeYUg[WdXUbVTfWUdXScYRe\Sj]Wk]Wi]Wh\Vh]Vj^Xi[UhZTk\WhYTi[Uk]WhZThZTj^Zh\VeYSdXReYQdYRdXTeVSbSP`RObVRdZVd]Uf^Vb[TaYR]UN]TM^TPZQM]SPYRKZRKYQHXLEYMGZNGXLHYMJXKI[MG\NH[MG[MG\NHYLFZOGXNFYOHWLJUJEVKHYKFWICUFBYKDXKCYMEWMGUKDWMFXNGWOGXQJ[OGZOGYNF[NF^LE[IBYMGYPIWMFVLEYKEYKEVOFXOIYNJZNJZMH]QIXNGSLEMH@MKBLJBNLDSLCRKBSLCSKBTKBYPIURGZUM]TK]TKaWN_VM_VM]SJZSJUMGNEBQFFZMG]OI[NG_RJZPGTNDZNGVLDYPGWOFWNEYPG]SHXQCUPFWQLUNJ\TLaXNbYPbWOcXPdXQeXPcXPcYP`XQ[VOWTLVRLZVKVPHZRK]SLZOG]SJWSGXQIWMF[NJ^OI_NH[OGWMEZOGXMCSJ@OE;J?8KA:E=6F<8F<8E<6C<9@<499.98.;9096.96/87/89046,77.79.35*27+48,.0$1/$1+ 3.#3.$1.%-+!-( -%1.!22$00"-/!21$33&10%31&11%++)+)+)/*/!14%/2#,/ .- *-),(***++****('*(*('%'$(&(%"# $!$!&#""## !#! "#"$$$# !# "!$!!# !!   !!!  $#!!!}aZzaY{cX~fY}eX|dY|dX{bX~e[}eZ~aX}aWdZf\|f[{f[}c\|bZ|b[}dZ{aX|cY|dX|dX}dZ|cY|dY}c\xbYxcWxcWxbWxbVycWzdXzdXydXzdXycW{eYxaYw`XvaYwbZwbZvaYr_Wr]Vr]Wq^WsdYqeWjaWcZP_UKXMEUJBRG?WIDWKEYNH\QK]TM`YPZ[QU]QT_RQ]OK\JE\JF]KF^IG`KHaKH^LI^LE_ME^NF`PG]NF]ND\LB\JC]KB]JB\JC^KA\IBZH>WEBZHE[IF\JF]KA[IA\JA\IB]HG_KE[HN]KTYLYRG^OF`NE_NFiWLu`Yt_Yo[Ur`XtcXvbZx`Vz`VzaT{cX}gZvhZgaS^aPX`OL_LA`KE`LB_K@bJ@`LDbQC`PCaNCaNA_LB`MB`N@^LBaLB`MD`MD`MD^LE_KEaNA]JB_KD`L?^J@`HC_LC_KC_KA`KA_KA_NE`OFaOC_MB^KB^JB_JE^NC]KA[KE\MC[KG]KB[ID]LC]KF`LD_KE`LC_KA\HC_LC]KD^LG\MD\JBZICZK@WHAYIBZHEYJH]MF[LBYJCZJBZKF\JH]KGZKI[LK\MIYKOXKNWKQYLTZMSXLUXLWXLYWK\XMaWMeXQcUMcYQbYPeZRg[UeYSi]Wi^Vo`Zn`[i^YjaZkd\jd]jc\od]nc_pd`ofbnc_mb^rfbqeathdsebudawfctc`tc`td^sd]sb_p`\o`]oa^nc^mb^sb_udatd`sc]rc\rb\pb\pb]rc`qeaoc`pdbud`rd^qc]pc]oc^na[nc_ob^ra^sa_pc_oe^qd^pd_ticticqe`oa[ma[l`[l`\m^[l^[m^\o^[p_\o`\sc`seapdan`\n^[sb_o_[o_\o`]pb[rc^pa^o`]l_[k_[s_Zs`[r`]n^[m`Zma[l\Zm]Zn`Zm`Yl`]ma]l`\l^[n]Zl\Xk[Xj\Yn\Yi\Xh\XlZWlZWfXUiWTjYVeVRfXTfXUcWSfZSeYTh\Xh\XeYVbVTgWUeXSdXReZRg[Vi\Vi^Xf[TgYSi[UeWRfXRfXRj\Vk]Wj\WeWRj[Uh]Yh\VfZTeYReZRdYQdTRdURaROcVRcWSaWTcWPcWQdXRbVP_SM`SMYOLYOKZQLYPIWOGUNEWKDYMGXLFWKGWKHVJGYJFYKEZLFXKEYKE\OJVLCULCYOHXNGWLHXMIYLFZLF[NFZNE^RJ[NFYMGWLEWMFSKDXOIYQJ\NF^PHYNFXLCZMEZIBZOIZPIUMFWMFVLEXKEUOEWMHWLHXMIYMHZOGXOHRKDNLDNLDNLDQNFRMDOI@TMDUNEZQH^UL[XMa]Qe\SaXOcYPf\Sb[RZTIVPFTMDTLHTKH\OJaRLbTN_SKWOFQJBNGDPJDWSJVRGVRIXRJ^TJ_XKYTJWQMXRN_YQbYOcZQcXPdYQeZQdYQdYQbWP^VO[UNYUOYVPZXOZXO[VOZTNWPIUNFTUJRRHQMGQIEWLGWKEXJDSG?ND;KC:I@6D?3D;5D<5C;4D?7@=4<83?83=7195.97-:5-;6.87,77-6:/48.47,67+03%03$44%22$1/!3- 3/"54%0."+**'1*!42%32%11#/2#55'11#0-"20%0.#,, )*(*)-,1",0!(+-0".1#-/,/)+,,**))))*)*)*'*''$& %#%$%  ##!  "! !"#"#"%# !!#!     !  !"#! !"  z`Y}c[{bX}gX}eV}dX|dX~fZ}g[|f[}cYe[}dZ~e[|dZ|eZ}c[~eZ{cX}eZ~fY}fX{eY{eY€f\|cY}dY~c\xaXxbVzdYycXzdX{dXwbY{e\}f]zcZ|cZz`XybZvaYwbZvaYtaYr_Wq`Wr`Xp_Xp`XkaUg`Q_ZO\SIVJBVH@UHATGAVJE[QK\WO[XQZZPY\QV_SN^PK]NM_MJ^LE_KB\JC\IF]JI^MK\ML\OK]PH\NG]KD]JD]JC_IA]IC_KC`KB^JA]IA]I@ZH?ZH@ZHC[IE[IDZHB]JC^LB]KC^JE`LE_KF^JM]LSYIZUH]PEbRHm]Qsd[vg^n`Xqe[yma{lawfZydYt`VqaUocWefUWaOO_NL_LG^KB`KFaOC`KA`KCbNEbMD_MBbN@_LA`MA`MA_OCaPCaMC`MC^NA^MC`LC`LB`N@^K?^I@`K?^I>^F@]K@]IA]IB]IB]LBZKA]LC`LB]JB^KB]ID^IC[I?ZJAZK@ZKBXIDZGCZLE[MC[IF^LG`KE^JC^JA]IA^KD`ME_LD\MH^LE[KAWIBYJ@YHA[ID\IF]KF\JF]KF\JF\JE^KF_LG_LF^LE\LF]NH[LHZKK[KL\LN]NP_OR]PR[NU\NUXMWVMXWMVWMXYOZYOYUL\VN]WO`WOaXQbWSeYUe[Te^Ti`Ylb[nc]ma]mb^mc_kb^mb^nc_pd`tebvgdrecsecpb_rdaob^ob]m`]pb_qb_o`]pb^ob_tc`udase_re_qe_pe]oa[pb]sdapeapc`pdbpc`m_]n`^l_\m_\pc`mb^ob^p`]p`[pd]nd]l`]od`oc`pd`nb^ma^nb\m^Zn^\n^[n^\n\[o][p^\r`^sb`uectcalaZn`Yqa[td]m_Yg\Vl]WpaZm^Yk\Yi[Wh[Wm\Xn\Zn\\o]\l\Zm]Ym[Yo]Xp]Xp^Yo`[k][m][l]Zk]Wh[Uk[Yk\Zo\Zm_\i]ZlYWjXVfXUh\Uh\VgYSfZTeZTcXQeYSfZUfZVeYUbWTaUSeVTgYTbWQbWOcXReZSfZWeWTfVTfTRcRPdUSiZWiZXi[UeWQfXRh[Tg[XdYVcWRbVQcWQbVP`UQaUQbTPbVRaUQ\RO`SMbTObTN`SM_RL]PJYNJYOI]SKZPIYOIXLGWKFYNHZNJYMJZLG]MHVJFXLHYMGXLFUICWLDXKEXKDZNHYMGXNFVNEZNHYNFXND[QH[PHXLFSG@UJDSJCPG@UICYLF^MF[LFXLEVLDXNF[PHYOHVNGWPHUOGVNFVMFYOFVJEVKGUJFTKFVOEUMFSOGQOFPNFUQIWOHTOEWQHZSK_VMd\Qf\Rc^Vc\Td[Sd[Rd[S`WN_WOaZQ`YN\TK[RK_TOaUQfYSfYS_UNZSLTQGRMKURL^XP_ZO_ZQ]XPeZQe[Rc[SbZVaXU_WNdXSeYRcXQcXPcXPeZRcXQ`VM^UL[SL]VO^WQ_YQ]VQYSOUQKSQGSQGRVJUWLSPIOHCSICND5B>5?=3C:4@92?<2?>399/45)53*66,55+53*4/%6/%31&66*7;.59.58,76+44(11%31%52$0. 2- 44%65'23%-/#21%30&31'22&.2$03%25&24%32&42'/-"0-#-,!++--!,-"*+()+, ,-"/3"./$,.$+)")'(&')(())'$'##""#!#" !#" "#   " "!    !! "# "" }c]~d]{cXzeW~dV~fW~fZ~eY{fZ{eZ}dZ~e[}dZf\~dZ€d[}eY~fZ|dX}fW~fW}fW{eZ|fZ{bX|cY}dYc\ybYycXxbWzdYzdXzdXxc\xbZ{d\ybZ{bZzbZwbZwc[vaYuaYsaXo]Uo_Vo^Vm]Vh\S_WLVRCVOEVKBVIAXHAZKD[LF[PM\TP]ZS[_VS\QO\PO]PK]OG]MH[JJ^KD^JB`OA^LB\JE[IGZMJ\PN]PJ]NI^MF_JC`HB_FA^IB^JA]IB^JC_KA]I?^J?[IA\ID^LC[IB[I@\IC^KB^KC^JC_KC_KA]IF`LK^KQ[IZUGbWKi]PlbUnd[pe[qh[vo`wpasi\qeYkaUd`U_`ST`OLaNE_KF`LD^JA]HE_OC^LB_KD`KC_KE`L@aL?_K@_L@_L?^M?^MB^JA]KA\L@]M@^M>^IA_LA_L@^J>]I@_J>^G>\I@]IC^JB\JDZICXKA\LA[IB\JD\JC\HBZGC[IC\L@ZL@XJCXIDZHCZLCZKBYJE]KD]ID]JA\HB^I@_KA]JA]JBYJE\IE[KBYJBYJBZJA[IC]KC]KB\JD^LE^KF^LH^KF_JF_KD^LC_LC^LF_MF_MG^LI_MI^LJ]MN`RN^ON]QR^RPZOQYPK\OO]ROYNOVKRVLWWNUUKWTLXSM]VQ\VO^YPcXQeYSh[Uk\Yh]Yf]Yh_[j`\k`\qd`scasdarecredoc_oc_od_nb^oc_od`rc`rc`sb_tc`vc`rd_qe^sibqkanh_ob\qb^sdargcqebrecob`l`^k^\l_]n^\o`^l`]m`\ra^qa\na\kaZj_[l`]l`\l`\ma]mb^oa[qa]ra_o^[n\Zr^^o_]ra_tbatbavbavbaob]ob\pb\oa\k_Yh\Wn^Xo_Yj\Uj[XgZVfZWkZWm[[n[]lY[nYZo]Zk\Zl\XiYRn^Wm_YgZXiZXhYVgZUeYSfZVi[Xm[ZiZYfYWjWWiVUi[Yh]Wg[UdZScYRbXQ`UO`UNaUPdXTcXSbWTaVTfWUeVRdVPaVOaVPdYSbUUcTUgUUgUVfUUeVVeVSbSQdUO`SMeXQfXQdYWbVTaVTdXTaVRbVRbXTeYUaVR_SObVR_TP_TLaVP^TM_UNaWP]SL^RL`UNaVM]SJ]QMXKIZMK[OL\OK]PJ]OI[MGWKFWKGWKEVJDUICTIAYIDYJF[MGSIAVKCVLCXOGYOFWNEXODULCTJBTHDTIERGCSHDZLH^LIbNI[LFXMGXQIYQKWPIVMIVNIUPJRMHQLGTJEVJCWJFYMJULHTLGVQHVNHTOJQNHYUO`XSbVQXSH^XOe\Uh_VmaWlbUh_Zg]XdZRg^We\U]XOZSLc\Tg^Tg^Ti]Tj]Vh]Xi]XdZSaXQZUNXXN\UTcZUf]Th^Te[Sg\Xi^Xf[SdZRg\Yf[VcYOeYReYTeYSdZRbWP_UL`WM]SJ^UL\SJ`WO_TM`SM_RNYNJYPLUOGRNDOQCQODNHAMD=K?8I;4K97I;8C96?;5<;4;?5>7083+86+9:-6;+6=,4;07>339./1'11%2."62%43(58,8<089-97,21'64*96+50%2/!2.!00$45(35)25(66*32&0/%00%+/#04(05'.1#//#//#,*/-",),(*(*)))))&&&%'*')''!'$$!$"%'%%$##"! !""##""!#$!  !  gZf\e[dZ|cY|cY~gWhZ}dZ~e[€fY€fZ€fZg[~e[g]f^~dZ~e[~h\xcXyfX{eY{eY{eYzdXzd[zc]xb]xcZydX{dX}dY{cZzd^ya\w^Xx`Zva[uaZwbZsbZs`Yp`Yo\Wp]WoaYi]VcWQ_RMVMETKBWJBWIAZJCYMEZQH[UKXWQWXPW\SU^SS^RR^RN_ML^LI^KE]IC^JB_KA`JCaLE^LI]OK\MK[JN[NJZII\JH^KE^KF^ND^LC^L@^K@_LA_LA]KB^I>^I@`K@`J?[F?[G<]H?^I@_JA]IC]LB\JA^IE`LG_KK\KR[KV\L__Qa`QdbTebUabSaeVihZfeVacU[bRS`OL^MIcJG`KF]KC]KA^J?_JD^LC]KC^K>]JB`L@^LBbMC`KD`LB^JC`JA`K@[F@[GA[HB\LA[LAZK@\NB_PA\K@[K@[I?ZG>ZLA\LC^JB]HB[GCXIBYG@YGA[IB[GEZGEYFB\J@[K@[K@ZICWEFYFCWICXICYGE[IDZFB[D?[G?[H?YI?ZJ>XJ?XK@ZIB[L@YL@YKB\MC]LD\JD]IC\HE^JF`JHaKH`NG_MC]KD^LE_OD^ND^OH^MI_MI_MG^NE]OG_OI^OK^OJ^OI^OH^OI^RJ_QL_RK[MP^OR^OOZLS[NUXMWVMYVNXUM_XQ^WP`XPaXP`XPcZReZVi\Xl\Yq`^pa^oc_oe`pc_qb_sdbpcbodbnf^pe_re^wgbrdaob_sebpd`qfbqgdqidqgbpf_pe_tgavhbrhaoe^ne_mb\oa\m][l^[k`\l`^k_]g\Zj_[jaXjbXi_Xj_XmaZl`\k^Zpa^n_\o`]n_\l]Zl_[na^m_apaaqb`qa`o^\rb_p_^q_]q`]p`Ym^Vm]Vl\Wm\Wk\Yj[Xi[YhZXhZXjZXm[ZoZZkYXk[Zn^Vo^Xk]Wl^Yj\Yg[WfYWcWSdXRbUPdWSdWUfXUeYUg[WgZVeXUcXTgZWfZVdXUdWPaSN_QK]NLaSPcXTg[WbVQbSPgWQcWQbVR^UQ`TQdWUcVSdVTdURcTPfUQbRO`SQ]PM[PL]TL`WOaXPbTRcSQeSRdSPfUScWQeYSdWQdUNcSPdWS_TQ[RK]SK_VM`UM`UN^RL^SK]VMYULYSL[QK[KG]NK\MG]MF^MF[ID[HDWKCXJBWJBWJBWJBVIAXIAVJCWLHTKFSIETKDPKHSLHTJESFBUHCUHBTIBWJCXIEXICYKC\RH[PHYODXPDTOBTPFUNHWOHVPFTNCTLDULGULIXLKYNLVNHSNEUPHVSIYOHZQJZTKd\Si_Wg\Se[Rj_Wi_Xg]Ug\UmaWo_[k_Wj`WhbWeaVb`Vb[Tf^VkbYi]Vl_Yl^XjaVf^Uc[T`YU\XP]ZPbYTd\Uf^WcZR^UNf[Td\Xc[WbXUbWScXQdWObXM_XMYTKYRH\QIYQIXRJXQJ\SL^QL]OI]OI^PJZNHWMFSG@QD>NA:KD;KC;H<9I=;I?;E>7?94@<4=<356,59-:=272+40(54*98/68-5:.6?48?439.55,31(40)82)20$58)69)67(63(/2)57,67+30%.',%2.!44(57*:8-65)14(01'./%,-#+,"++!,,"+)(%-(,'+#(!%$'%-*+'#!&#$%*&)$*% $"#"$"!""!!"    !""'&#"!  !!  ! # !!! "" !!!!{cW~e[}eZ}dZf\g[i\€i[}dY~e[eY€fZ€gZ€g\~d[€g]f[f[~eZ|f[{g[yfZ{d[{eZ{eY{eY{dZ|e\{d[{cY~f[|cY|cY}c\xaZzb[zb[xaYyc[vc[wdWsbUn`Um`Uk^Sn^U`YP[TLXOHSIBTKCTKBTG@WKC[PG]UKZWMZZOTZPQXNQZNQ\PO[OQ^PN_ML^MI_ME]LD`MB`M@cNAbOD`QJbTI^PH]MJ\MG[JC[HD^KG_MG^OD^LCaNBaN=_L>_L@`M@_I?^I?`JB`K@^IB]I<\G>^IA]IB^JA[IB\K?`JAaLDaMF_MJ_NM^MO]MQ^MT`PS_OQ`OO_NN\LO]LM\LK]LF\JE]JC`HD_IC\JA\J?[H@]IB\KC]KA\IC]KA\IB\JC]IB]IC\HC]IC_K@`J@\HA]IA\JB\M@[K@YK@[L@]M?\L?[J?\HXJ@[IB]JB\GAYGAWFBWH@WF>WF?WEAVDCVD@VC?VE@YH?WEAVCCWBBWGBWHBXFBXF?UBAWC>XD=VD?YG?WHAYJBZLA\KB\MAZLB[MC]NC]LC[IB[HB\JD`LC_KDaLF`NE`NE_LC]NF_OE^NF_QG_OI`NI`NE]LE]OD^NH_PI_PJ_QJ`QHcSGaPJcRH`PI`PL`RL`RM_PQ_RT]RU[PUZOW\RV[OV[OX[OXZP[\P\ZO_YSbYTeYTgYTj\XfZUi^Wk^Yl][rcaoc_qebribqf`pd^secqfbqecscareapeaod`peapd`odapeareatgcod`od`ld\mb\ma[l^[j^Zi^Zj_\j^\g[Yg\Yg]Wg^Uj]Xk`Yj]Yl]Zm^[n_[o^Zo^[o_\l^[n_\n`]n^^n_]pa_o`^l][o`]n_^n_\l^Zl^Zk\Xk]Wl]Zj[XjZXhYViZWl\Zh\YhZWjXWiXViWUhZWo]Ym\XjZWhYVgZWfZWeWUdWTfXSdVPdTRgWUdYUfZVdXTg[WfZVfZVh[WgYVeWTcVQaTN_RL\RN]TOcYUcYUaWS_VReWSbVR`UQ`VR`UP`TQcTRcTR_PNaQN`QN^QMZOLZPM\QM^TM^SL_UL`RO_NM`OLaOLbRO_RL_RL`QL`PJ_PL_QMZOLYPHYPH]SJ[PH\QIZNH`VM[SKWRJWQJVLFXLEYKHWJDVKCZKDWHBWGCWIBWJBYLDYKDZMEZMEYJCVJBUJETLHTJEWNFSKHRIEPFARFCRIASJCUKDVIDZLFWICTIAXODVPGXRH\VJYTJWQJTNGXQIVOFUNDVOFWOIVMIUNKXOKUMEZSJVPGXRH^UN]UNc\Sf^UlaYnbWmbXkbWf]Ue[ScZQj^Ul_Zl`YjaWjaVhbXgaWh^Xi`XjaXj^Vk^Vl]WkaXj_We[Tg^Vb[Sc^T`XRaYQe[Te[T_VOaVPbZQaXR`VPaVQ_TM]SI[PGUPFOMCUMDXOFYQJWUMUQJXSLXOHWMFWLFRG@NE>MD>D<5C:3H=6D=4D<4C92A94@93>9299/>=4:;179.7:0=@586-54*77-67-12'57,:@19=07:.9:/43)64+74'33&27(06'24(42(0/'20';6,JA7TH?WIBPG:;7*+'+'72%54'42(,* +*('%#('&$&$)$&""$" %#&"%!!%!"#&$(% )$$!"! !!"# !!" # "  "!$"&$"!"##$ !"# "   ! |eX}dZ}cZ|cY~e[~e[€g]f\e[~e[€fYeY~e[f\g]|f[€hZg[~fZ{eZ|fZ|e]{d\{e[ycXzdX{eYzeX~fZ~f[~e[f\}c\{a[ycY{e[|bYycY{f[ubWtaWraXj\Sg^Sf\Q`UKTOFPHBQHAOD>RG@TJ@ZPGZSH^XNZYNSYKS^NN]MK[KK[KM^MM]MO^ML\NJ\NF[LD_OB`OAbPDdQBbQEbSGaSK_RJ]NE\ME_MB^JA]ID^LD]MB^KB_M@bN>bNYE>XE=YEA\J@YHAYGAYGBXFAWDDXF?VCBXE=VD?ZHA]J<[F>[I=[H?XGBYJBZK=ZJ=[J;YF=[IA]J>ZG>XH@XIAYG@XFAVE?UC@TGAVH@UFAWGAVF=SABUA>S?=Q@>UB?U@?U@?VF?VF?WD=UC;T@=UAVD>VD@VHAXIBYJC]MC]ME^PD]OE^PE^OE\MD^MD_LDaN@_K@aLCaNDaMD_NF_OF\MH_QF_QG`QGaOGaOF_PE^PFaQHcSF`PHbRHcRHcSHdOHdQFbOFaQFaQEaRHaQLaSOaSQ`TQ`TScVPdVObTRbTR`SU`RV_RY[S[[R]XRd^VbYS`XRaZRf]Vf\Uj^Yk_\ma^n`]n`]m_[teaqdbocbsdaqc`qeargcreaqb_nc_k_\pcapdapc`ma^kb\lc\mb[l`\k_[la]k_[j^[h[Xh[Yh\Wi^Vk_Ym_Zm^[k]Yl]Zn]ZmZXn^Zn]Zl\Ym^[l^Zn\[l\Zn_]ma]l`\la]o`]n`]j[Yk\Yk\Zl][i][gYWfZWiZVk[Un^Yj^ZgZVgVSgVSeUReWTlXVlZVjXVgXVdXVdVVgVUhWThXSfWQeVSfWUdXTcWSdXTdXTcWSbVReVSfWTeVSdXTbVQaUM^TP`UQbWS`VR_VR_WScWW`TR]RN_TP_VO]SJ`QN^OL]MJ^RO]PJ]QJZRNYRL[PJ[QJ`SL`SK_QN^OL^OL`PM^OL]NK]MG]MG^NHZLF[NH[OIZNHWKDYNFYNFYMFXLF\PJYPITLFWOHTKDVJCWLHVLEXMEYMEUICUHDWLDWLDXMEXME[PH\QIYLEWKEYMIWMIVMHXOHTKGQGCSHDOG@PIBPKDVMDUKCWKEYMGVMEXQHWUKZWMXUKVUJQMDRMFYPIWQGWPGXQHVOGXOIVPKUNIWPGZSK\SJZQJ`YRf^Xh_Vf^Ui]Vn`UocVmcVh_Ve\Se[Sj_Wj`YkaYi_Vi^Vj_Xk_Xl^Xl^Wm`Xm`Xl^Xn`Zo`\j^Yh\VcXQc[Rd[Rf\UcZSdZSaWPaVOaWPcXPaUN`VObXQ_UN^UK\SJUQGQPFVOEZQHYQKVPHWOHUMFOF?MC7F@8GA9DA9A=6:6/@:3B=3>8/;3+:4.74,96/8>27RE?VF@YLCbWMedY^]R\^RT\MQ_OK^KI`LH_LG_KJ_NG]JH^KG\MH^NH`PF`PDaPA_NFaOGaQF_QH_QI\ON]PF_OE_MBaLB`LC_LD^NB^KA`M?aM=bN^K?]JB`MC_LB^KB^KC_KB^ME_PD^NC]JB^IE]KF_MC_LEaLE`LF_JB^JD_KC^JB]HB^J@_JA\JB^KB_LD`MA]JA]J>^K>\G>YE=XD>YE>YEYG9VC>YF=WE>WE?UFBXH>YE=YF=YF?[H>ZG>YG?VG?VGAVH>TB?UC?UC>SF@UFBUF=RB@VE?UB?S>=Q==Q>=P?=UA;V?=UCVD>VD?VEBYJA\LB]ME`OGbRHbTD^PD^NE_OE`PB`MA`N@`MDbPC`PD_OE_OE]OH_QG`SGaRE`PE`PGaRH`SFbSIbUKdVJbUIbUHeVJfTIdRFdRHdTCcS@aRFcSIcTKcTMdTMeUMgWJeSLgULdSNcQRfUSdTUbWV`UY_S_aW^aV\_T^_T\]S^]Rb`Wc^Vg`Yl^Xl]Xj\Xk]Zn^\q`_oa^j_Zmb]peaqc`qb_nb^nb]na_ob`pcbobblc]jb[kc\nc`mb^oc_k_Zj^[k^\j][j_Zi]Wi]Zmb^rd`o`]m_ZjZTiXUkZWjYVl]Zj[Xl^[m\[n_]pa^mb^k_\k`\l^[k]Zk\ZgYWj[Yk][i][i\Zh\XhZVi\Vm^Wf[WfXTdURfURcTQfWTgVSgVSeVTcURfWUeTUiVTfURgWQgVPcTQbTRcTQeUReVSdURdURdUScUNfXSdTRcWSaUQ`TP`TPbTPbSP^PMcWSaXS]STZQOXMI[OK^RK^SK_QN[LI\PL]QJ\PJ^RKZQJ[RKZQJ`TN`RJaTL`QL_QKbUMaRO\MJYJG\KE\KFZLFZLE[MF]OIYMGXLEXMEYNFXMFXLFZOLWMHQIBUMFWNGULEXMIXNGYPGYPGWNFWLHYMFXLFYMGYMG[OIZNHXMGZNI[PLVLHUMFVRHVMITKGTLEQICRMESRHWQGXOGYOHYOHVPHXTKUWKRRIPOEPMESPHVPJ[TJZRKXPIWOHXPHYRH[TO]VMaZQh^Td\RdYSg_Wf\Ui`Wl`XoaZncXqfYmaWjaXh^Wg]Vh]Uh^Wj_Wj_Wl_Wk]Vl[Xi[Ul_Xm`Xl_Wm`Yl_Xf[WbWSh\Wh\Vg\Tf\SdXRfZTdXRbWP]SL[QJ\TJ^UM`VObXQ_WO_XO]UNROHSLEXNGWKETODRE?PD>MA:G;6E;4B92>81:7/B@765-87.?=4><2:7,96+64*23)37-3<0;@456+54%65(98*59-37+46).0$11%31&76&55%65'33%22%11%47(8<-49*.5(25+25,LJ@{wm™‰•‡žŽ‚¢‘‚{jakaV‘†Ž‚Œ~qi`R>6-,%0) ,')$)#&$$"%#%#!'%#!!##$ '##"#"#"%""!   !#"!       #"&$'$$#!%"'("" $~h\~h]}g\~h]€i^~h^~g_hah_}g\~e[f\}e[h_|e^|e]~g\}f[~g\}fZ}fZ}f[~fZ}eY}c\}d[}d[}eY}f[~f\|f^{e]yeZzh[yf_wd\vbZubZq`Xo^Vi\XfZV_TP_UNYNGUHBRE?UFBXHEZLE]WMhgXgla`gZWbRP^MJ_KG`JFaMEaLEaMC`MC^KD^MGbOHbPGaPFbOEbNB_LE_KF`NE_PG`QJ]OL\LH_PGaNEcOCbNB`MD`PCbO?`M@cO@cO@aNAaN?_L@^KC`LEbNC^KCaND_KE_NE^PE^OD^LEaJG^LE]KC]KD_KE`LF`LFaMG`LG_KF_KE_LBaLE^LC_L?]JA^K@\IB]J=\J?]I?\G>ZC=ZE;XD;WDRA>TA:S@:SA9UBWE=VDRCR@9R?:S<=S@;P>=QB:Q?9TA9SB:TB8R@9SA:TB;UC;TB81;5.64,67.45,57.45,<;098,99-68*16*8?5>F::>21/$0-"42&76(56(45'1/$,, 0.#20&45&56(43'22%44'22&34*46*15'14(36+/3)LKDytr‡~€“†‰ŒšŒ…›‡œ‘‰Ÿ”‹šŠ€|qg[MA7.+".()$&$$#($'%#!$"" $#&$&"& & &"&##"$#'%$#$"!   !!  "!"   ! #'%*#&%$$#'& %'#$#%"%i]i^€j_~h]€j^~g^}f_~f`i`~h]f\e[}g\~g_}e]ze]~g^~h]}g[g[g[€iZhY~fZ€f^~d^}c[~dZ}h]yc]wb[{g_yg[xhZwf_tc\tb[q`Yk]Uh[S`XNZRJTMCSJ@QF;QE:QF@SGCWMHWRKVZOVbRZfYUbSP_OL_KH`ID`IEaMDaNDbODbP@_N?^NFdODcNFcNEaMFaMC_KEaLCbNBbOB`PF_NK_MI_PF^LC_KDcOA`MCcR?`M>`M?aNAaNC_MC_L?^L@_MD^NE_OB^NB`OC]KC\NAZLB\NE_MD`JC]LC`MA_LA`KB`KC_KC_KE`LD^JE`LDaMBaLD`MC_L>]J<\I?^K@]J?\K>[H@]F=ZC=ZD:ZD;VD:TB9SA8SA9R@8P>9PA5P@5P@7RB9QB;QB=PA;N=9L;>Q?;O>:P>>S@PC>QB>R@:P;

;N=?Q>=Q?9S?8S?:TAZG>ZGA]JB_JC_LC_NDaNEbOEaQE`SGaUD]OE_QE^PFaPE_OC]ME`PF`PF`RFaSC^PA^OH`TGbTGfUEdTFbSHaULfXLeWMcUKbTJaTF`RH`UF^TG`SHbUHbTIcUFdUHdTFaRIeRFeRFeSKdULfXLeWMeWPgYOfXNgWQgYPeVSgXRgXQgXNdUPfWNdVSeXVdXXaVYbU[eXV`S]bW__Uc^Vf_Xc^Wa]Uc]Vh_Xh]Vk^Vd[Si_Wh\Xh[Yj\Yj_Yg`Xd`Wi`]j`\nb^nb]k_Zj]Zi[Yi]Yh\Wh^[lb^ja]lb[i_Xh^Vi]Yh\Xj][j_\k`]k`\j_[j_[k_[i^Yk^Xk]Xi\Yh[Xg[WfZTj_Vg]Um^Yj^Xh\Xi]XeYWeYWdZTdYSfYRhZTgZSdXRbZReZShZTjYTjVTnYVkZYgYUeXSdXSf[We[XhZVeVScTQdURdURdUReUOdUPbTNaUQaVR`TR`VRaUR`TPcWSaYUZXSYVRZUP^TP_SO`TP`UO[SP[UOaWPbUOaRKcRLcSLeTMfUNeVNfWOeUNaRJ_PH`TM]QLcSObPNcOKaOK_RJ^QI^PH_OG_OI_QJ]PH\PH\PIZNIVJHTIETIFYNJYPIUOHYLGXLFWLDXNFVLDVKFUJCUJDVKDUKDXNGWMFULFVKHXLHUKFSMDONCQOFTQIQLEQLCVSISRHTNDWPFWPH\VPWUMUTLVTISQHQMHRNHSPIVRIaYPdZTe[Vg]Ui_VlcXmaZk`WjaWlbYg`Xh`Xl_Zob\qd]qd]md\g`Un^Xk^[h\Zh^Yh^Yg^Tj\Wk]VnaYq`Zp`[p^]k]Wi\VdYQd[Rd\U_YR`UPcZR`WN`VO`TQaUTfXRcUOdXRcWP_UOYOHMMDLJELGDKFDMECOEBOEAJA>F;4K;6I:3E:2A8181*84,97/9918;282+1.&02)55,55-23*10%66)98)8<-8>2:C9:>332)1,"3-"2.$32'64&42$10#.,!-+ .,!/2%35)-."//#32(21&32*10&..#02&78.+.$IIJROXOFT`TbgZdrejtqˆ€z†}“ƒ{}tRE9.%-&-(&"$"$#&"$"$"$#$#%%'%%$%& %!" %$$%$#!%%##    " "" !!    #)*2'&-!""#!#!""&%&%%$&%i]‚j^i]‚i]~h]~h]i]h_}d^~ebg[€g\~h^i^}g_{f^{g`|h^~h\}hY€gYg[e[~f[€h\i]~h^|e^g_f]f[g]|f_vb]vc\paZi`Wf_Vd\S]VMWRFSK@SI?QF=QE]H=\G?]H@[G?ZF>YE?\G:YD8TD7RA:R@;R@9R=8S?9PA8N?8PA7M?;P@:P>;N=8K<:L=;M?>L>?M?=N@9N?7O@8P>:P=bQAdTHeSFcSGdTIfWFeVHfWGeYGbUHbTJ_TI\SI[UG[SF[QKbVIaUHaSKdVIbVG_SG_RF_QHbTFbSLdUOeVPcVQdWQhZQg[QfYOdXMeYOgYOgYQhZNhXNhXNhXNeVRhYShYSgXSfXUeXYdZZaZ]b\[g\[fZ\cW]`Ub`Xe`ZebYibXj^XgYScUOcVRcZUbYUcZSh^Vg^Ui_Vi\Zh\Zg]Ve\Ve]Zd\Yk\Xh\Xi`\g^Zj_[i]Zi]Vj_Xlb[lb[mb[k_Xq_^l][k\Zg[Yh]Zg\Zi^Zg\Xg\Xg]Vk^Yi]Wk[Yl]Zk[XhXVfWTgXUfZVfVTgXUgXUg[Wf[WcYVf\Vi_Wi[Vl[ZmZYnZYjWViZXh[Zh\Zh^[iZWfXUeVSeVSfWTfWUgVUdVSaVRaVRdXTcVT`TMaVOaWPaXQaYRaZR^VQ]TP_TR^SOcWPeZPbYUaVScUSbVRbTNcVNcXPeXPdUNeRMaOJaQLYLJ[NI^RIbVL`SL_QMaSL`UI[SF_SHbPIaMH^OH`QI\NH\OIYMG[OKYMGXMGVLEYQJXQJVPITPFUKBYKEUKDTKFPGEQIBTJCVLEXKEUICWKEVJCTJDRJGQLDPLCSOEOPCRPETOFUMGVPKQMISLIXMH[PI]RJYQKXSNSTLTUKRRHONDSQGZVNj]Wj^Xna[obZpc[paYlaZkbYgbWd_Uh_Xi^YjaWlb[la\ka\jaXiaWnaYk`Xg_WhaXibYld[laYmbZqaZn^Wn_Zm_[h_Vg[TeYTeZU`YR[YOaXRaWPaUO`TN\QJ]SMURKVPITLDUKGSMHMLGAC:BB9ID>G@9F>5H?6H;7G<8D<5A92;2+>4,;=144)68,89/88.77-31&..$-2'39.6;023)11$01%9;/8:.48,89BHAPM?QP9D^@G_BGcKOgWYtih†€…yqA2(.) -$,#*"(!'%$"!"!%#&$%#$!!!! " %"%#" %$"!! ! !!! "    !  !"  "$&"# "#! !#(% %"%#$&‚j^‚j^‚i^i]}g]~h]}g[~h^h_~f`i^h]~h\}h]|g`}g`{f\{g]}h\~i[gZ€g\f\f[i\~h\€i_|e`}i_{h^{h\yh]wh^te]pc[j_We]Tb[RZSJTMDPI>PF=QF=RE=SG@XMEWRGTULOXMR\POaSLgTKdRLeSJbPGbPGaOEaNFbNGcPEaMD`LC^KB^KC_KD`MA_LC_LE_LE_JDaQEeTCcPBaND`MD_LD_LD_LD^LD^MC^LB_M?_P@`OA`O@^N@^MA`MA`J?_IA`LC_MC]ND`OH_PG]NG]NG_LD_MC_LGbNBbMBbLF`LGcOCbMB`LC`MB_LC`MC_KBaJ?_M>^M=]J@^K@^K@^K@`K@_JA]IA\H?]H=]H9WF:UC;UC:S?9PB8O@:PA9M>;N?:L>;L;:I9K=>K==N@9N@9SB7P?9Q>:TA7RA:UE:UB9VC:XF[GA\I@_IA_LB]MC\ND^ME^LD`LDaLB`MDcPDdPBdRFdVDcTFfVCcRDcTCaS?`O@aPD_OFbRFdRFdSDbRFdTDdSEeTDeTFgUJeUHdSIdUIfWIeVGeVHeXFaTHaUJ`TG^UF]TF]RF]RHaTH`TJcVHcUGbUG`SG_SF_QE^PFaSKdSNcUNbUOcVQfYOeZQfYOfZNfZMfXPeXReYSiYSiZPfWPfWOfWQgXThYQeWVh[We[Wc[Yc[Xg[XfZYfY\dY_dZ`c\cf\ddYb]U`ZT^VO`XS^XP^VO_UNbWPdXQdWQcWScXSf[Ug\Uf[VcXUg]Xf^Yc]Xd_Zc]Xe\Xi]Xh]Wh^Xj`[j_Yi]Xm]ZjZXiZWgYWfZWeYVg\Xg]Yg[Xg]Vh]Wg[Um]Yl^Yi[VhZUfXTgXTeYUfXTgXUfWTeZVg\Xf\Xg]Ui]WfYSiYWkZYj[ZiZXgYWfZWh\Yh\ZjZWiYVeURjYVhXUeVSeSUcTSaVSbXQcXSbVQ^UO^TM`VObXRcZScZS\TM`VQ`UPdVSi[ThZSfZScXTbVSbWSbWRbXQcXQaTO_QJ_OK_OM]OKWKI]PK_SJeWMcRKaPMcRL_QIZOG^QH]OI^NI]QI]QH[NGYMHWLEXMGYLFXKEYMG[QJZQJYQKURGXNFZLFTJBSJDTKFUJCSIBTJCXMGXLFVJDWLDTLDOICPJEQLCVQHWOGVNEVKFVKGVMJSKHRJFVKF]QK`TN^UOYUQWWNZZQYXN\XOb\Tf]Vg\Vh\Vl_Ytg_re]pd\kaYkbYmcZkaYibZc^Zj`Wi_Xj_[k`\mb\re^sf`laZi`YkaZmb[nb[na[m`Xm_Wn`Yh\Xf[Wd[Sg[UeYUeZW_XT]YTaZS_WP_UN^UM[TMXRKRRISQITOIQMHKID>@:C=9C;7D:5D<5C=6B;3?71?81<80;7.41'72)9:.46+35)9:0<=335+23&/1&-4'49-56*10%/.#0/$44)/0$22&46*63(63(53%0. /-!.* 1-31$31'1/%11&/0$0/'20'.,"1/%00%0/%0/$,+!.,$/-%-/%0/)-/-<:>H;GR7?[8>^9CT>DRAFUHIaXVVLFC8283)+%)!)!)&'%%#" #!" $""!""" !! " $!%##!$# !! !    !    !   !    !   !  ""%$&'ha‚h`‚ha‚hagajai^i]~h]ib|h]|h]|h]}i^}i^}i_}j_~i]~h\~h]‚i_f\€f_}g\}g\i^}h`}hayi^yi\zi\xh[tg\mbZh`Wc\S_XOYSJTMDQH?OD^M=]L>^MA^KA`MB`L>_L@_K@^K?]J?^K>^K?]I=ZG=K?I<=G9=F9;E88D55C25D78D69D7=G78F68H77H89I8:I99J9:L<;Q?:SD9SB9RB;VF:TD8UE8VC9YF9[G;]I>^KA_LAaMA`NC_PB^PD^OD_NDbMDbODbOCcPCcREeTA`RDdTEeTEdSDcTBaQ>aO?`PCcSCcRDdSCeTBcREfUGiXFfUGhWHfVKeWIbTIeWIfWIfWGdUHdWIbUJbVIbVIcWGcVHbUJcWKeXFbUIdWHdVHdWGbUKcWHaRHaTIdVJcUMdVOdWPdXPfZMdXLdXNfZMeYOfXReXQbUSfYSeXQeXRfYQfYRi[ShYSgZTh[QdXUeZWf\UgYUfYVh[Yh\Yg]Yg\\g[\eY\bXZ_VY^U[_X[]SZZPZXO\WP_WS\TOYUP^XPaZQbZQaXQ^SNcYUcZVc[Wc[Vc[Vf[Wg\Xf\Xe\Xf]YdZVeZVf[WfZVh\Xh[WhXUeXTdZVd[Wf[Wh^Wg]VeZTgXReWQfXQgYSgYShZSeYUfXUgXUdURbWSdZVeYSfZTi^WeYUcWSfWUaWUaUSdWUdXWg[YeZXjYViXUiXUgXUgWUbTQ^OR]OO_TPdZScYR`UO^WN^WN`UM`VMaVN`VM`TN_SMaSPeWQhXRhVQeWOdWPaUP^RQ^SPaVR^TM]QK]OK[MJ[OK[OM]OM]QL_RJfUOdQKdPJgURaQK]NG^RL[OKZMIZPHXNFWNEZPHZPI\QK[LFZLFWKEZOIXNGWMFSMF[PI]PJVMFUNGULETKDUKDVLEXNGWLEXLFWLDTLDRKDRLGRLGWNJ\NK]PLYNJVKIPIFMGDVLH_TPeXSeZSe\Xd^Y_^Va_VgcZkcZkaYeXRfZSj^Xnb]pd\oaYmaYlbZnc[qaZmaYha[dbZjb^j^Zk`\qb_sdatc_oc_ma\l`\j^Zn]Zp^[m^[j]Vk^Vi^VbYT_WTcYRdZUfZVdXV`XUaYW\VOYQJXPI[SLZSLRNGNLDKHALFAFB=BA;?@:D;8?62:3.=93=?5=?6;:097.77-56,01'55+::.55)22&87-33(55+28*4;,05'57)53&51#31&1/#21#0.$32'/-#0*#0,"/+ 0-!.)-)!**--!0/%-.$,-#)*0-%.,$*&0-%.+#32)54),,"1/',+#)+!**%')!/-.=47L8S4ANBJ=?B:8>61<9,0*!+#+$+(&&(#$!#"#$%! #"!!##    !  " ""# "# "! ! !!       ! " "##!$!'$ '(#ƒibƒib‚ha‚hai`i_~h\€j_i^h_}i^}h^~i^~i^i^€j_~h\i^i^i^€i^€g]~g_h_i^}i^~hbhb{i_|i^{i\wfZscYl^Wa[R_WNWQGSI@QH?PG>PF>RH@ULDVMGXSKYWPX]RVaTTcURbRK^MHaPIeRIeRGcPEdQEcPEcP?cODdQA`NCcNBaKA`KDbJDaKC_LFaOIaOJ`NH_PGaQFbOEaNE^LE^JH_NI`NE]LF^LF^LG_MFaQD_OC`PDaQBbPA`PFaOEaNB`MA_MA^NB^NF`PE`PC_OFbOB`MD`NE_MDaMCaOD`MD`M>^K>_J?_K?_L?_M@aM>_JAaO?_N?`NB^OB_OC`Q@aN@_MB_LB_L@_L@`M?]I=[H;XEVD;RC;QB?PB@MAAI=@F;AD:AC;@A8?A99>27?27?2:B5?D7?D79D47F66H79K:;N=:M;;P>=TB;UC:UD:VE8UE:XF:XD:ZG:\H;^J;^J?`MAaN>_L?`M@_P@_PB_PC`PEcPEdQBbPBbQBbQCcREeTCcRBbQBbQBbQBbQ?bNAcOBbNCcPCdP@eP@dTFiWGiXGgVHgVHeUHeVHfWHeVHfWHhYFfWGcVHbUJeXJdWHdWGfWKdWLfYLgZJfYJfXHfYFeXJfYLgZKdVKeWKdVLdVOfXQeXOcWNdXMeYNfZMeYNfZOfXQeXSdWUfZSeXPdWRfYQfYPgYRfWSh[SgZTh[QfYRfZRfYSgZTh\Sg[Tg[Uh]Xh[UeXVg[UdYVdYVcZTcVTaTT`VVaWW^XSZSVZQX[R[\RZXNYVMZUM_ZUaXT`UQ^SO`TPaUQbWSbYUd]Xd^YcZUcYUaYUcZVg\YeYVdXTgYVdZVe[WcZVi_WcXRdZScWQg[UdXSeYSeYSfZTdXTcWSeVSaVRaVRcYUeXRdXReXTcWRbVRbVR^VR]TP\TPcXTdYUbXTfUSgVSdVReVSeXT`TP]OR\PPaVRdXR`VO`UN\UN]TM^RL_QKaTNaUP]RL`SMbUNdTNdSMdQMcQKaSM]RNZQNYQM\QL\RK]QK\NH]OM]QL\QM]QM`RM`RK`QJ`PJfTOgSQ`OM`QN_PM\QL]TL[RI\SI^UL^TKXOFYOIZKEYKEZMGXMFXNGVMFUOHZOIVKEULEUOHTKCUICVJDYOHXNGVLEXNGXOHXOHVPITNGVNJXNK[OK^RN[TOVQNMJFXUQcVPh\Xh\Xka]nd`jd]faZb\Te^UlcZnaZoa[ka[laZnb\od\oc[n`XlaYnbZrc]nb\haZb`Xi]Zh\Xj^Zpa]sb_sa^l_[j^Zh\Xk\Xo]YnZXl[Xl[Wj\Vf[Uc[Ua\WdZWf[WcWS`UQ_SR]USYSMXPIXOIRJCPLEKH@JA>G=9E:6D;7@<5B@7>9450+2/*45-6>42=25:-8:.:<056,12'03)<<077,65)10&10&32(39+16(-1#66(65'84&21&/.!:9+53&.,!+'/)"0+#0+"-* /-%0,$+*-,!)+)* '('( +'#,)$+'#.+#/,$30(31'21'10'+*")+"&&)$ &##+&(9/3B5?D:HF8CF5>G8=F9:<52720<9,72)-&)$'$##$#"$##'$ #!$$&&$     "" '& %#$#!#"!     #!! !  !!!!! #!!#""  !#!$!""!&#&#(($()'‚hbƒibƒib„icl_j_€j^l_€j`jc~h`ibi_‚k`ƒh^‚h^€j`h`ga~g_i^k^~g_€i`}i^€kb€jc~hc{ib{i`zg]tdYm_WdXR]ULYPGUKCRI@RH?OI@TODTOEVSHVVLV[PV^TUaTNaRPeTSfTLaPHaQKcQLcQHcPGcPEcPCdQ@eT?cQ@bOAdNCdMBcKDfLCdNEcPD_PE_NH_MGbNFaOD`MHbQH`OK_OJ]OG\NG^PF^OH_NH]LIbPF_OE_OD^ND`PEbSE`PD_PC^OC`PC`PC`PFaQC_OB_OC_LE^LF\KG_MC`MCaND`LDaN?`MAdLAcNCeQBdPAbOBdOBbO@`PBbQDaQCaQEaRBaOFdQE`MEaMB_K@_L@_J?]I=[H?\IB\JAYH=WG?TEDRFFOCDH?DC;EBF@>D?;A?9==5>@5??6DB9BC8YE>YDaM>`MA`M?cL?bO@bQ@aQAbPBdPCcPEdQCbRBbQ@`OCbRAaN@`OB`RA`QAaOAaN>aLAbMDdODdOCfPCiRDfVFhWIkZFhWFgVEfVGeYDdVGfYIiZHj[FhYFfWIeXJeXIdWHfVIhWLeWLfYMgZLgZLh[Kh\HgZJfZNh\LfXLfXLeWNgYOfZOeYQg[Qi]Ng]Rh[OeYNfZOhZQfYThZSh\Sh\Rh[PfYOfYQeYPhZPfXSg[Th[RfXRfXQfWSg[RfYRf\Sh[Ui]Xi\UgZSg[RgZUh]Tf]RfYRgZSg\Sh\Si\PeXUcYVdXVdVT`SQ[OS[QY]SXXOXULXTKYRJYSK\UM\VN^ZQ]YP^XPbZR`ZTc]Vd\WbZUd\Vd[Vd]Yf]Ye\Xe]Ve[Td[TeXSg[Vg[VdXSfZUdXScXTaVRcXTbVR_UQbXTeWPfVRdXTcVSaUQ_UPaWS_UQ^TPcYTaUR`UQcURdWSaUQ_UQ_UQ\SOZQP]QPbVReYS`UPaVP^UO`TNcSObTOaUP_UO`TN`TNaUMcVObQMaOLcQK^PM[PMZQN[QL^QJ_SJbSKbSMcTM_RK_TO`SN]RLaTO_RLaVNcWOeWRcRObSP`QN^TM]VM]SI]SI`ULbVNaUM[OG[NH]PJ]QKXOHWNGUMFTMGZNIYOHWOHXRIXNEYNHZNHZNHYOHXNGXNGZOLZRN\VOZTMXQL^SOeXTeZUg_Y`\V[VPga[pb\sd_rfcqfcog`haZh_Xh`XlbYlbYqg_pe_oe^nd]pe_qe]mbZlbZpbXnb[mc\kb\h_YkaZna]n`Zo`Yo_Yqa[p_\m`Zi]WbXQaUPiYSm[UkYYjYWiZTi]WdZT`XSaXV`VR_UN]SKZPKXOJWMISGCNB>LA>H@9D83C83>40=7094-63+52,/-$--#34+4;/3<04:+9=/89,87+46)46*=:/=;053(76,42(52)56*34(+,!33'43'75*00$21$78'43%/-#-(#.'#/*$,)!/-$20*43.1/&.-#--!,*!** )'"-&$-(&-*%0-(1-&4-'-,"-,"-+#,+"'(&&("'$$*('-)'50397CD8AI:?I59F55=5042*53)1-#)#& $##"&!$$$& #$!! " $!#   " " "!!!%%!#!$#" !"&#'!    "  !  "$!"!##&($##"! "#!!  "!  "!$$%""%$$"**%120i_„kaƒka…lbk_‚m_€k\€j^‚lb‚kd…kdƒib‚i_…j`„j_†k^‚ibga}e_h`i^€j]€h`lcka}h`jc{gbvjbviarc[k`W_UNYOJVKBTH@SF>UH@TJAUNETRFVUHXYNX^RTaTPaTOcVFaPJfRLeQIdPGdSOcRNcRIcQHdQEdR@bN>dR>cP=bN?dNAdMBeMAeLCeNCcPEaRF`PG_MCaLCaKA_LD_OG]NGZMJ[OFZNE[NE[MFZLH\MG^LF]LF]NE^NF^QF`RFaPC^NC]MA^NB_OA`OB_OB`PB_PC^KD[IH[JE\ME_O@]MD^NB^MBaPBfNCgPBdQBdRAdPAeQAaODcRBbQC_QE`RB^OEbQGaPIaRG_PD_NB_NC`M@`J@_L@^KD_ND\M@ZHCXIIWKKSGKLCEB>H>>E?=FA=Q>=T@=WD;VB;XD=ZF?\D=\F<[I:]I?_I@`G?^K?_L?bMAdOAaNBbNAdMAeOBeQ?eQ?dP@fPBeQBeQBbPBbPCcRCbRCcPDcQA`QBaQAbO@`NCbLDcNCbMDcOCePDiRDfUHjYIjYFhWFhWEfVFgZEgZDgYFiZFiYDiZGiYGgYJg[KgYIfUJhWLfXLeWLfYOi[LeYMf]FfXFeXLgZNhZLfXLfXNgYPg[Qg[OfZQg]Ph^RfZRg[NfZMfXQi[QgYPi_SkaQi_Rg^Qe\PdZRi[PhZTiZUiZVgYUhXShYSh[Sf\Ue\Uf[SfZUgYTg[Rh\Si^Tj]Ui_Uh_Rf^Si]Qi^Rk]Oi[RhZRhYPfWThYQeWRdWUdWUaSX_STXMTXKRWJ]XM[WLZXM\ZO[XM^XNZVNZWOZWO`\T]YR]ZSc]Xf_Ze\We]Tf]Ve\Sg[Xg[WgZVdXTeXUdXTdYUcWSbVRaUQ`WS`VRgWPdUQeXUcUTaVR^WPcWSaUQaVR`UQ^SO^SO`SP`VQaVR`WS^WR]XS^UT`WSdWT`TPaVS`WT`SRaSQcQOcRQaUS]VRaWPaWPaVNbVNaQMbPPbRN_ROZPL[SN^SM_SKcTLeULhWNgWPaTLcXOfWQcVPeYRaWPaXOaZQdWRcVQhYVeVS_UL\SJ\RI^TJ`UKaSKaRK^OGZOI[PIZQJZQJXQJUOHYQLYMGYNGUOG[UL]RK^RL[OI\OIXPGZQIYQJYOMZTO\VOc]UkbZoeao`Zma[mc]kb[md]pe^uf_ufarecrfdme_me]lb[mc[qh_qj`qiaof_lb[j_Xmb\pe]k`Xk_XpaXlbZhb\d_ZlaZn^Wn^[p`YpaYrcZo^XiZWl`Xe\S_UL`VNfZRi\TiXXiWUjYTeWQbUO`UP[RQZPL[RJYPFSJ@ME62:5030(./'32*50(0,"/* 41&44(57+59)89+88)85+76*66*64)31&1/$20&20&54)87,53)31'21'/1'02'13&13$00 22#1.%/*&1-)-*&1.'//(00+34/31(21'22&//#2/&2.)0))/)).*&0-(0,%0)".-#+* '%,*"'( ('"(# *)%,+$0,#0)&1+08/3F6:L89G65=5-22(.+"*%("## "!% &"&!&!% %!  !  "!!$ !!&) &* #" !!#!#!!#!"# "%%+"#* " !!!! !  ""   "## !!"!" !#(-$14*-+#!! ""  ""!""!"!!$!$"&$%&%'''&)*$352k_l_j]‚k]lambh_„lb€k`maƒj_‚i^ƒj`ƒj`ƒkaƒj`i^h`hbib~kc~lambleid|idzicti_rh\nbYgZT^PJYLEWJASI@TH@UHBTICSPHRTKRWIR\LR^MTbQSdSPdTJeUJeUHdTGbQGcSHdTKaSNdWIaTIdTEcQAaN@bR?dQ?dO?eR@gR>dN>ePAfREeRGdQEbNC^K>_P@bOA_L@^KA\MB\LDZLG]MCZKD[LE]ND[LHZMGZMGZNF]OD]NGbRC^QC`PB`NC`MD`LD_OD_LC`LCaNB`MB^KD\JF^LD_MC`P>]MA^ND_QHeQJgSIeRFbRDcTAbTD`PF`RF_SE]PJaUH^OG\OI\OH\MG[LD\ME`PDaMD_ME_MD`MB`MAaM?_LB]MFZLMVMMLGKD@JBL@9I?8F:7D97B89;44:5351.43)<;256.34*34*34&34#33%-0"22'21'64)87*86(76*55)68,26*4/'3.%/+"54(42'54(><035(03'02&33'11%22)12(02'-.&./&12+10-11-,,*474/3-,0'23(13(01'34+45+11(/,(2-*1+(/'$0)'/*(0+%.*&/.*,,',+&+($+.#*+",*",*#*+%*+&2/'<838546423/+0,%/-#($(!(!'!'!)$*$'&(% $!  !%#! #!'!(#!+$&-'$)!""##%$%$"$!#!&& ''!))$+(#*% %!!!!""$"!   "  " !   !#$'**&'&"'$ '$ )%#$"!!!/.(51-63.0*&$ #" !!" "!$#''!"#!#%'!%("%)#''",-%+,",-#2/(31+ƒmckak`‚l_‚nc€k`„lbƒka€k`~k`„ka‚i_‚i_ƒj`„ka„kaƒi`‚ibƒkeke€ld~la€la‚kd|ga|icvg_of]d^R\SJVMFUKDUJDUIAUHCWKDWNETQGTXMT]PO^NP_OM`NMaPKbPJdQEcSEdTHeUFcSIcSJeUHaQGaRGaQGbREcSDbSBcR@eSAgR@eQAgR@gR@hSAgRDdQGfSDbP@`LAbS@cP@bN?aMAbN?^LA]JC^KC\KF_OE]LE]MIZNEYLG[NE\MC\LD^ND^PEaOEbOCbNB`MBaPEbODcPDcPEcPFaOE`NG`NFaODaQDaQDaQGaSEcQFaPGaQJdUIcUGbUG`PF]PH]QH\PI\OJ^OI[OK\OI[NH[ME[ME_ND_MHaQG_OE^ND`ODaPCaOEaQI]OLWMKLGLGBLD>I@=JA>H?9F?>G@>GGCESHC[KC_K@_M@^L@^J@^J?_K?bMAcK?cL>eO=bNAeRBeUFgSCeQBePFeRDdRCeSCfVCfUAgTAgSCgQDePAcPCcRCeSBeTAdRAfSAfRBfRCfREdQFeREcPBcPDcPFcQDaRDbSBbTCeUCgVDgVDhWChWFjYGcWIfXHeVGfWHg[Ih^Fi[Hk]FgYFgYJh[IgZJfWGfVIgZJh\Mi_Jd[LcXJbVMeYOg[Oh[LeYLjZQn^Pm]Pk[OiZOiZQh]Rj^Qh\OfZOg[Qi^Pj\OfZPg[Qh\Pi]Oi`Sk^Ri\Ri]Rh\Rh\Qh\Oh[Tj]Yl`Xk^Tj]OiZQkZPi[Qj`Qi_TlaSk^VmaRj_Qj^Oi]Ok^Nl_Qm\MkZOl\Om^Ql_Pk^Qj\NhZOi[NgYNhXOiYOfUOeWPbWQaWS`US^TRZOR[PP\PQYNTXMWWLXSM[TO`VP`XS^WQ^YR]TQ_VRcZVc[We]Yf]Yc]XcZVaXTbYU^YT]YT_WR^YT\YT^[V_[W_ZUaYV`[Wa]X_[Va\Xa[X`XTcZVdZVb[Vc^Ya^Yc^Za[UbYRbYR^UO_XTeYUcWSbVRcXTdXTbVR^UPbVRdYVcYRdXRg[UfXVgXSfUOeWOcXQcWQfWPl\Tm^VgZRj]UhZVj]Xi\YeWVf[VfXSeUNg[SdYQ^TK`WObXQ[RK[PMWNKYQK\RKaSNaRKbSPaTP]TM]TM_VO`WPZTL[TN_WR^VRVOI[UM`UPdYUdXTh]Xla]nd_e`ZaYTi`Zqe^te^uf_ta]ue_ugaugaoc_qebxhbvicsfauievheufbnd`od`sf_victe_p`Zna]k_Zla[ka[h^Yg\Wg^Wi`Ymb[k_Ym^Xk^WiZXi[Wj^Zi]Zl_Xk]Wf\Vd\Te\UdZSgZTjZUhZReWR^PL[NJUIEQFCMB>JA9K@9I?7F<8B:7=6182-71.96299124*<<1<<1=<1;;066*55'65%98+21$44)86,52(:6(85'86(@<0<:-84*21&33(33'67,58*8=.5dLCcPDaOC`NEaMF`LGbNF[MCYLF[ME\MD^OD^MF_PD_ME`MEdOCdPDdQEcPCcPAcOCeQCbODbOFaOFbPE`PEbRGbSF_REbRGaRHbTJaTJaUI_SI]PK^QK]PL]PKZMJZMGXMJZOI\OF[NG]OE]PGaQF_PH_PG^OE^OC^NC`PEaRF[NJVLIKDMGCLE=LC?JA>I@FJBGZNDaPCbNA^OCaQC`PA_O>_M>dNDeOAcNBePBfRCfSAdPAhPCiREhRDhREeRCdPAfV@eT>fT@gR@gQAeN@dRAeTAeT@dSAeTBfUBgSCfSCfRBeQDcQEeRCcPGeRDbODbOFeSDdUEdSEeTEeTEfUFgWFgVLdXJdVIfWIhYFi\Gi_Gj\Ik]FfXFgYKj[Ji[IfWIgXGfWLi]Nj^KfYKdWLfXLfXOhZNhYLfXLjZMj[Nk\Oi[MgYNhZRj^Rk^Oh[Ph\NhZOi[Oi[NhZPh[Oh\Ql_Pl_Qm`Ql_Pj]Sj_Qh\Qh\Rl_Rk_Tj^Tj^Ri^Oi\Rj^Rl`QkaPl_Ol^Oo^Rn_Pl]Qn_Nm^Nl^Nm^Qm\Ok[Ol]Ro`Po`Nk^Qj\Pj\Pi[Om^Mk[Nl\KhVLgXMfZMdXMbVMbVNdUOeVLcUOaTQ`SR\RY]TX[RYZQ[ZRZXQXUNYSM\VO]XQ_WQaXQf\UbZW]SO]SOdYUbXTbZVa[X\XU]ZV\[W^\X]ZV^[V^\W``X^_W_]X`[X`\Va\Wb\Wb\Wb]X_]W_YVa[V`ZSbZTbYSaYUeZVcXTcXTcXTbWScXTbWSbWScXTfZTfZTfZSiXVjYUiYShXQiZUi[Wp]Yl^Wi\Ti\Tj\Vj[Xqa[l\XfZVgWTeVRiXRh[SfZRdXQbXQbZSaYRaWP]RLbZSh^WeXSaUOfURbVRaUPaWPeZSaVO_VRbZU_[V\XRTRISQG^VPdZVk_[pa^qd^rg`id]hcYpf]pe]wi`}ldvhbwhbxjduicqeatie{kdxjeuhesfbrb`rb_pfapdase_vgavd_ub]la]nb_ne^gb[gcZd`W`ZSbZSf\Uh[Ui[UjZThYVg[VeYVg]Vj]XgXSdVPfYTdXScWQaUOcVP`OMXHFRCAPA?M@=H;8D:4F<4D92<4.84087476099256-BF;39,1:+=>/>>0>>0<;-86(34$73(96*22&77+97*63%77'87'77)@?1>=/86'65*56*36(39+2;+2<+18-'.#*2'2;/6>2.6+.2&/2'10'-*%.)%.'$.))/()1+,1,-1-+0.*0,%-*"/,&0,'0,()% )% *&!+"-$ -$ +&!*&!+*$,,'--),-)*+'/.*-,(*'#*'#('#&%!)&!,,(-.*+-&*,#--"*(,()#&!'"$ !"# &"% !"!$""#!!"###$"$ "!! ##("&*! )+&8+1C5*;.9F91:0'0&$,!'*"$(('"#$$% ')#)'!%!  #$%& !  !!(' 22,(("  "')#/.*985/-,.)(*&$)&"'("&& ##&#$!" $!!# " "!!"$%')#),%),&,0*22,.0)+-'-/()-'.2,6=6;>88731-*)%$*$&€haicƒme‚lb‚laƒmb‚la‚mbk`‚lak`‚la‚la‚laƒmb‚maƒib‚jbkckc}kb|kbul`un`mhZebW^\RZWMXNISHAUH@YKDYNEYOGUVKVYMV]PQ`OLbPJfNIfRIhSIhUHjVFiVDhWDhWEhWGgVHhWGdTIeUDeNFgREeRDdSCbSCbTBgUDhWAeTAcRDgSDhTCiUDhTGgTFfSEeQCcPCcPEeRCdQFhREgRGiRFhUDfSGdRDcNGbNJdQF`QF`OFaQD_OFbOGdQE_OE`OFaMEdOCdPBcPCbOAbO@cOAdPBcPAaNDbNFbPFaQHcSHcTHbTIcUIcUIaTH_QL`TL]RG\NI]OJ\OJ[NIXKJZMHZOI^QG^PH_QF_PE_OE`PG_PF]NE\MC\LC]MB]MF`QIaSIXMILDKGBPG@LA>KB>KB?GAGMCF\NCaOAaOE_PE^PE_OD_OEdSAcQIeQGcOGdPFeRFeRDdPAiPDjRAgQCgQBfQEfSAfU@gV@hV>gRAhRCgQ@dUAfV@eUAfVCgWCgWBgTDgSDgSBeQAdQCdQGgVDcRGdREcPC`OCcOFaQF_OGbRHcSIdTGdTHcUIdVHfVHgXEhXEg\HiZGhZFgYFhXJj[IhYKhXHhWGfWHgXMhYLfWLfXKeWJdVJgXLiZKhYJeYJfYNj]MfZKeYNh\Og[NfZNfZMgXOj\Pj\Pm]Sm_Pj\Qk^Ol_Lj]Qm`RnaQl_Rl_Qk]Qj^Ql^Pj]Ql^Qj]Oj]Oi\Qk^Pl_Qm`Lk]Km^In\On_Ml]Nm^Po`On_Mn_Tp`Rp`SpaOn_On_Oo`Qk]Qk]Qn_Nk\Pn]Mm\Km]Jk[Lj\Nj]Mh[MiZLhXLiXMhZLfWPfXPdVSfYRdXSdWTdWWcWU`TUZQX[RXXQYYP]ZSb_W\SOZOK\QL^SO]RM^TO_WT_YV`\W^[Wb^Zc^Z`_Z_`Z[^U\]T_]Xc^Zc]Xe_Zd[WcZVa]Xa]X^WUa[W_YR]XQb[Uc[VcXTcXTcXTcXTdYUbWSaVRcXTeYUdXRg[UhZSiXUiYUfXRi[UlZXkYWmZWl\Wi_Vg\Th[Um\Xo_Xl]Wk[Xg\Xk[Wm]Vm`Xi\UeXSe\UaXSe\Xh]Wmc\me^lb[j_Yl_Yl[Yh[Xe[Te[Ti]Wl`Yi_Zh`[gc]WTO]ZQgcXmd`qeapc`ug`uhbvjcpi`rkbtkbrg^sg^vk_widwicwkeymhymjxlh{jhuhevkgvifqd_sd]pdapd`rd^sc]rb\sa\ma^lb^ld]fa[ebYcaWc\Ud\Ue[UeYSdWQgZTfYVbXS`XQaYSdZSbYPeWQbTN_QKYMGVJDRHBOA?M>/8C2KB?GAIQFE\LD`ND`PF`QF_PD_OHcRDdQDgSDePFdQEaOEdPDeQAeP@fQAgRAgQAgRAfSAgTBhUBhU@hS@gRBfTAdRAgUAgUBfUBfUEhWDgVEfVGhWEgVCeTDfVBeTEdVFcUHeUFcREdQDdQGdTGbRFcSEdTDdTDeTDeVFhXFhWGhWHgYHfZFgYFgZEfWGhYGiXFiVFfUFgVFfTFfTKgWKeULfXKeWJgXGfWHgYHiZIeXJeZJf[KdZLf[Lf[MeYMeYNhZNhZMkZMl[Nm\Pm^Qk]Pl]Mk\Lk^Ni\Nk]Ol_Nk^Lj]Mj]JgWJgXKgXJfWIfVJgXLgZMi[Lk\Nm^Jl]Im\Nm^Ml]Nm^Nm^Ml]Ml]Pn_Pn_Nm^Po`On_SpbQm_Rm_Rl^Ql^Pl\Pl\Mo^Lm^Kl^Lj]Ji[IjYLiZNi[Nk\OjYOkYQlYQl\Ok\NiZOj[QiZOeWPcXPbWQaVS_UU^TU[QSULSSKVSJUPIUPITRI[TPYVQTTNWVQ[ZT^ZU^]W[\U^]U^]Ua\Uh_[e[XeZVeZVbYTc\W^ZT_WW^ZV][Sc`Xg_Xc[SbXTaWSbXTg]YdZV`VRbWSfYUfZVbVOfWQgZShYVh[Vg\UhZVgVTfUUjVUiYVfYTcZQeXSl\Wl]Ul]Wma\oc_sgauhbpc]ma\h]Wh^XeYVh^Yk_Ymb[oe^pf_od`nb_m`]oc`pf_oe_ukcthbph_ogaje`he_ke^pg_vjhuheykgxjdwjdvmdujcujctj`j_Xf]Si`Vna\thbxlfxlgwkgxmhwiftidrhdpf`sg`uhbtgdpb_pc]m`Zm`Zma[ka\k`[jaZf^Wg_Ze\We[WdYU^SPYNJ_UQ`UR^WQYSLWTKZUNWSITOFZOKSHDOC@OC?MB>I?;D:7C:7F=9E?:A:6B;4:51:5-;9/99.:<27<2=B8>@5;;.;=.9>0:B549.>B5DH8@A178)::,77(45'25(25)77,21&67*47)9B58@506+26*57,35*14)36+13*)+!)&$ %+%&")&'%'$*&!'#0)#0+%.*'-)'/)).))/*'1+&0.%0.%*'+( *' (%(' -+$-)!)%+' +("*&"+'!*$!+&"-)&,+','#+(#)(#,,$/-'+(!(&*) (* (+!))+)$""!'&%$'$& $!%##!%"&#$!" ""! !""$"#%$! !!##'$+ &(!'#,"%0'&2(,5,11---())$)*$(*"%&&'!(+%'+%(,&'*$!#!$&# &!#$$" %#(% "    ! !""%(+%)( (&!*'#('"'%%$"#$#$"##!$" #$&'!'% %#&$" $$$$"$&(&) )($$$ $%!+,(/1-594:?8:;5832410331050‚kbƒmd€l`~k^‡nc‚mbk`‚ncƒod„mb‚ncmb€kambƒnd‚nckejb}ma{mavlapf^neZjcU`YJ[QDYMA[JCVLD[QG\TG[[KX_OWcTNhRKgQHfOFePGfQHgRJgPKfQGdQHfSEeUEdTEhVHjYGiXGiXFhXDgUJiUJiVFiUDiUBiTBiVCgWEgXFhWDfUEeTEeUFeRHfSGdQFbOIfSGeRIfPIcQKeULbVMbUNbUKdXIcUJeUHeTGfSFeQDeTEfUCeRCeQAdPBdPDaPDbNDcNDdKFcNFcOGbPFcPDdPEeRBbOEdQHhUEbQIcSKeUHaSIcVLfVJeUGcSFcSGcPI`OG`TD^QGaQE_PI`RLaTHaRIeRGfSGiTDgQEePBbOGeRIeRGbNGbOHdQIaTIdUHaSI[OHNDKG@QF?ND@I@=JA>GB=GCLVIH_NGbQJbSFdTD`QDcQDfRChTBiSChTBgSCfSAfO@hR?gQAfRAfRBfTBhU@gU@hVBgQAgQ?fP@fTBeTCcS?dR@dSBfUFgVFgVEgVGiXFhWDgVBfUCgVAeUDbVEcVIfWIfVGfUGgTFhWEfUBeTChV@gUAiWAjYBjXChWEgVGeWGcVFgYFgXEfWFgVEgUCgSFfUFgVCeTDcSIeUKeSIdUKfVJgWHiXHiXHjYKhYLiYKhXLhXLfWKfWLdXOg[Pj\KhXMlZLlYMk[Nk[Ol]Mk\Ll\Jj]Pj]Mi\Mk^Lk^Hi[Gi[IgVHfUHhWGfUHfVKhWLiZLj[Ml\Ml]Ll]Lk\Nn]Nn]Oo^Pp_Qn^Om]Ll]Mm_Kk\Om^Pn_Ol\Oj\Ql^Rl^Pk\Rl\PjZJj[Lm^Nl_Nl_Nl]KjYOi^Pi\Qj\Pk[OmYRq[Up_Qn^Nn^Nl\Rm^Rk[Ol`Mh[NgYPfZRdYTeZS_US]SS\RSYOQXOOXNTUMQULNSJPVMSYPUYPXUPXVOYWN]XOaXSdXThZVgXTbVQdYUb[W_\Vc[[_ZV\ZSb`Vc_VbZR^WR]UP`XTd[WbYU`WSdXTf[WdXTdWPdVPgXReYVg\Vf\Vg\XiZXgUVkVUkYWeZTe[Th[Uo_YpcYvjarh`tjevmeuidrhaqh`mc[k`\ma]pd^sg`siapg`vlevkgtidujevlhsletlewngvjdtjaslenidphdsieugc{ljxhgzkh{mgzoivoduhbvjdsgajbXd]Tg_Woc]sgauicvjdsgdpd`ma^nc_riephaof^rg`qc_na]l`Zh^WkaZkaZnc[k`Yi]Wl_Yi\Yg[WfZVcWT]RN\SO^UQ\VRYUMPNGQQHIK@ED:JH=F@4:;/:7*=;-:<16;208-;A4;@2/59.47,11'4/%20&6:..3)+-$43)23)*+!,*!+*"+(!&#&# '*"($&$)")" 1+&71,-)"-*#(%")&!*&%+&#.)%/,$.-#-,"+* +*+*!(%'*!/.%,)!-*!)')&*&!(",# -&#,(%'$!)% (% ))"**"+((&)'+**+ '(,*)&*&#!#"&%(%& #!%#'$*&%#%! !" "#$$!$ %'# "#!#$")$&!%$*$&-'*.(01,531++*')%(,'#*$!& %("%("#'!&+%%)# " #$"#!#!! %!# !" !#)+%0.$+)!,)#()#'("#!$"#  %#0/&58/%&''!)(##" "$!! !#$!#&% !!$% +-)8;69=98;643/40/854150,5,oc‚odƒle†kc€mbmb€ncod€nb€nb…lfƒne‚obƒqbpc~ma€ldykbsjapj`kcZf[RaSKYPGXNDYKBYIAZNEYQFXTIYZLW`QUfUUhWNhVHeQHgTBeQBeQEgSFeRHdRKgTHeREgS?ePDfPEePFeRFiUEgUEhWJhWGiVEiUDkVDhVCfUCgWBfVBgWEfWFdUGbTHdQIeRGdQIeRJeSJfSIeSJbSMaRPaTPaTQcVQcZLaXI`UJdVKfVIeUFdTHdTJeVGeVDdQ?eN>bLAbNCaNCaNDdRAdRFaRD`QDdSDdQAfP@fPFfSFdQHbOKeUHcSJdVIeUHeUEeTEeTEdTBbQE`PF^QG^SG`SJaSOfULeWMhXGdUHhWCfSBgRAdPDcRGdTFdTFdUBbSDgXAeTDcRH^NKPEQJARD?PB?NB>JA>H@=IB?HDAEHAJWJJ`QHcSJeVHfSGdQGeRFfSDhTElWFfVDfUBgV@hU?gUBhV?hSBhWCgWBfVEfUFgUDfUAdS@cS@dRCbRC_ODcTDfSAfRChTBhUChXFgXGhYGgYEgVCeTFfUFcUDeVDfWFhWIiXKiUHjYGfUGgVEgVChWAiW?jXBiWEhWFgVIeUEdSEgUKhXKdTJdWEeUBdUJgVIgUEcOGcPJeVIbVH`RKeWMh[KgZLiYMiZMf[Ki\Jh[IhYKiZLgVMgZOi[Nj[LiYMkYLkXPj\Lk\Hl[Ik]Kk]Mi]Pm^Lk\Jl]Ll]Pk\Ri[NgZLfYHfVHhWIiYKiZLh[Oj^PnaMj^Lj]Jk\Lm^Lm_Mn_No`Mn_Lm^Lm`Jm_Il_Lm`Mm`Oj]Rj_Nj]Kj]Jk\Mi[Pj\MkXPm\On^PmaNmbLlcNm_Om_Om]Mk[Sn]Vo_Nn]Nn`MnaMmaLm^Po_PnaNm_Ol_Rk^Rj^Sj^NhYLfWKeVMeVPdWO_SO^TI\PI^OJ[NP\QQYOTULUVLYXNZUNZQKbQP^RK^TL^WO_YQc\Se]TbZWaZV`[Tc\Vb]Vc[W\YU]YVaXWbXX`XUaZVhYVgXUgXUfUShVTjXUeWVdXVgZXfYWgZXeXUeXTh^Ze_[haZkaZsd^vidzlhwkgyljxkiyliymiwjg{khzjgzljymlvkhymj{oi}qk~rnzmk{nl{nmwlhwnjxqirjcpk`ulcxmeyngujcvkf|pk|pl|oj{mg~ni{kesiepidlf`a]X_\V\YTi]Woc]uicqd^qf_pf_jcZkb\nb^qebob_nb^l`_k_]l][o`^m`[k^Yk_Yf]Vf\Vk\Vn\Yj]YdYUc[UaZSZTM[QLZNJYKJPEBLHAGF=FH?HGBG<:B96=94D?:=9194+53+30(/,$/,$30(:7/=:2<:2;:0;<2>@5>D8@@49;/48,48,39-3;/2:036+97+86(66'79-47(7:-58.9=2<@75912* /( 0,%,)$+.#.2'+3&)-!,.$(')('''"%$'!& )#("("-'"-'$'##$"&"&! )!!,%#+$!+(#+0%/6))&"+& (&&&)' *' )&!*&!*&"*!*, .##,""+""(#!)$ *&")#$)%")'()#**#)( +* )'-+!*( $"$!%#&"&!!#"&''''#' #! " !##%$ "!"#$%%)$%'$### $ &!%$) #+!$, %* +-#0-)**$(,&'/''/($+%&+'$)$&&#((")'"##%%' #"!!!$#!"%%""!!"#! %"-,(.-*1/)-*&.,$+)!)'*) $! $/4+>D>CA;%& "#!#"#!%#$&!& %!&% %%$&#'+*/64>E@BF@<<323+()$(+&/0-674€mbmcƒkd‰lfnbod‚nc„od…peƒoc…mh†phoc€pd~oc{lbwhdsfanc^i_YbUQ]NI[ICVJBUKCWLCZOGWTIRXLR[NR`PRfUPhVNhVLhUGeRFeSAcPBbOFdRDdQGeRJfSHgSDgSAfRDgQDeQDfREiTGjWEgUEfTFgVEjXFiWEgWFhUFgXCgVAfUDeUCbRHbSGfSGfSHgTFhTGiUGiUFfSHcSKcTNcTQdWObUOaVKaTIcUGcTHeTIfRFcSHdUHbTJdUGeSDdPAdOAbOBbODdRCdSAdREbSFcSCcREeQCfRBgQEdQGeQEbQIeUGdTHfVIfVIfVFeUEeTFfUFfUF`QE_QF_RHaSIcTMfTKeWNjZLhXHiWDeREgSEcSEbRGbRHcRGdTFeUCdRDeSEdPI]OMPEPHARCAOC?LA=JA>H@=G@=FA=FIAIWJI`PDaOGeTGdQHcPHeRIgTDgSBhSCfUCgUBgUAhVBhVBfU@iVAhVAfUDgWAeRBfP?cQ=aP>bQAaPEbRGbQEdUFhVEgTFiVFkYEiYHiZHj[FiYEhWEgVDhWGeUFgWFhWEgVHiYKjZFhWFhWHhWEgVDhWCiW@hVAgUCdSFdTIfVHdTIhXKfVIcSHcTDbSBcTFeTGdSFdSGdSJdUIbVGaRIeWKgZJh[KiYKhWLhYMk\KkZJiZKiZLhYLiZLk\Nk\Mj[LhYLiZOi[JiZIk[Gk]Lk]Lh[Pl]Nl]Ll]Nl\Sm_Uk]Qf\Oh[JfWJiXKjZOk\Nj]Pk^Ok^Ok^Nk^Ol_Ln_Lm^No`OpaOpaOpaOncNodMoeNpeOncNkaOl^Kj]Gh[Jk\Om]Qk]Om[Pn]On_QpbOnbPqcMm^On_Nm^Qn_Qp_Tq`QqaOpaMoaNpaOoaNn]Qo`Ro`Ro_Ql]Rn_Sn_Oj\Nj[Mj[Oj\Ph[PfXOeXKdVNeVNeVO_SP[OLZNM[MNZMPYLTVNUTNWRJUQJURKVTLZVOYTLYOM^TP_WQb\Td^Wa\V]^V`]Xc\XdZWg\XdYTe[Ud[UdZUcYUfZWeZWeYVh\Yla^j^[j^[k_\rfbtjfrlgqibujc~pizqm~tp{qm|tqyqnzqo~tptpro€qorp€sq‚usuquououqrp}po~qn}qmzokvmhtlftlb~sk€tm€qlqk~qk}qm{okznh{nh{oixlesjfme`jd_e`[d`[eb]k`Zpe^sgarg`pe_pe_lcZmb]mb^m`^i]Yk_[j_Zl`Zk]Yk_Yi_Xh`Wf[U_XQe\Ui[UlYViZVaTS^TQZQLTKFOEANBANABJ@=E?;B@9MMG`_Z7.+3,(94074+84,96,31)1/%31(.,#64+53):9/=<1>=209>/:;/24(46*26*18+4;.46*14'46'44%0-!1.$****+*!/2'68/02)0) .'*&!(% '* '+ &+ )*!0-$,*"(%'%)#%$$&!'$("& ' $ $$%!'"'" ( *#!,$!&#+.$&**%"+$ ($&#&#&"&!)$ +%"(#&*, + +"'"#'# *%#)#$*%$,*"-+&*)#*( ,,#** -."/,%'%" $"&"'"#!&%('((%"$$" " # #!!###&$+!$+"$)%#% $$&$!$!&#'"%+%&.%&,$&) ,,".+()*%(+&+3+,2-)/*&,')/**,())#($ "  !#$% " !"!# +*%530//*&& &"!,'"'" "+*&10,780./'(( '( )(!))"#!%"%#&,/(,1+,*#(&&%$$"#$% &$%$ $ '$))!(*$.0*1638>:EKEJNHDA;630232??>IJHA@=mbmb†nd‡nd€nbmb„od…od‡nd‡nd…mg‚mfme|mdwlbri`md^i_XaXP_RMZLE\JD^KFZMGXRIYTJWXNV]RM`QQdVMfTMgULhUJhUHhSEgRCgQCdOFePGdPEeRHgUIgUHhUCgSAhSEgSDfRCfRCfRDhTCfRDiUChUFhWFiXHgUIhUHhWFhWEhWFhWGeUIfVIeTIfUHgVGhWFhVDgVEhWFfUHeUKeULdUI`RLaSIaRHdRHfSGeRGeREeSHgVIcTHaSE_OF`NAdPAcRHfUHeUFgVEfWIfWIgWGgVEeSEhTEgTHfRGdSFcTGgVFfVEgVIfVIfVFfUGgVGfVEfTFcTFaSF_RKeVKeULfTKgYOl]KhXJgWFfTFfSDaQD`QFaQGbRFbPGdQHeRCbOFcOK]ONOGOEBQEANB>L@ID?FKAGXJHaODbNEcPGaQE`PIdSIfVDeTBfUAgUBhVBhVDhWCfUBeTAhV?fTBhTCjUDjTAhP?eS>bQBdSFeTHcSJdTIgXJgWJiVGgTEgXEiYIiZGiZDhXDhWFjYEiXIiVHhWEhWFiYJj[Ji[FkYDiWCgVFhWEgVEgVDhWCfUDdSHeUGdTGdTFfUKfVJeUIdTEdTEdUEdUCbRCcREbRFcTFcTEdUGfXFgYIi[GiYGjXLkXNm[Mm\IiXLj[IiZIjYJjZLj[IgZMh\Lg\Pi[Lj[Jj[Ij\Ii[Mj^Rl_Pl_Nj]Qk^Sj^Th[Qf]OhZLiZLiYNi[MhZQi]Pj]Rl_Pj]Ok^Pl_QobMl^Nm`QobRpcSqdQpePodMnbNodNmbNkaMn`Jm_Jn^Mo`Pm^Qm_On_On_Nm^Pn_Oo`OpaQpaNn_On_OpaNo`NpaPo`OpaOscMpaMm^Nn_Sn^Rq`Nm\No^Np\No\Nm^Nl]Mk]Nl^Nl]Ni[Mj[KjZKiXJeULbTM^QG`SF_PLbQM`PP_RO[OQYPLUKJOGLRIOSJQQIVPLWQKYUK[VMWTLVULW^SX\Q]YRd\Ui^Wk^WhaXi`Wh_Wg]Yja]ib_mc_oeaofbofbsjfxnj|qm{plzqm|tmƒwq„vpƒxt…yvvrwtwt~wtur€ur‚tr‚usƒtr„ur‚vr‚vruq‚vrtp~so~qnzok}ok{nkznjzoj|qjƒvo…uo€qk~pj|pi{nkxmiznhyohxngtmdtifpfbkc_ic^hc^je`pg`tibof_rhashaob]pc[j^Zma]l_]k`[h\XfXRl^Xj]Ui^We\Ta\RZQKSNGYQJ`RLbPN[KHREFRFDNDAI?;G>B754;98DEDIFFFDC„nc…nc„od„mb‚nc‚nc„od„nc„nc…mbƒognezjcviarh_leZd^U^VL[PGXLA[NB\OC`PJ[TLYYNY\RVaTQdUPhXNhXOiWLhUNjWKhVFjVChTAfRDgSIhUJhUGgUHhUHhUGhUDhUBiUChTBfRCfRCfRDgSEhTCiUCfTFgXLj[JhVJhUIhWHhWHiXEgVHfVJfVMfVLfVJfVIdTGeUGgVCgVDfUDeTHgTGdPFbNIaOHbPHeRFfSFfSEeRFfSFhWJhXGdUHcSIbPHgVIfVHeVHcUFdVHgXHgXHhXGgVFfUEfUDeTIeUHeUGgVGgWGjWDfSHeUIfVFfUHhWHgVFfUGcTEbRGeTHdQIeRLgTKhYLiYLiYIgWFfTEeRHdUFcSEcRGbRHbSF`PGbPIeRHbRK[OOPHPFDNB@NB?I@:F@;HC=GB=FKAG[LFbOEfQDeQGbSIdTIdTFdTCeTAeT?gUAhVCgVDiXDgVDgVAfVDjXBjVElVFmVDjTCiVEhWGgVKgXLhXLfVJgXLhYLgWGeTFfVEhXHhYHiZHhZCgVEiXChWHhUGjWGkZEiYJk\Kj\DjXEjYDgWBfUFgVFfUCdUBcTBcTFdUGeVGdUFeWGfVFcSGdTEcSEeTDcTCbSEdVEdUFeVFgVDgWEfWFgYGhZKm\Jl[KnZLo[Km\Jl\Ik\HiZGjYHjYHiZKi\Kh]Kf]KgZKh[Jj\FhXIiZLk\Ok^Pl_Mi\Oh[Pg[Qg[Nf\Mg\Ol]Nk\Nj[Nh[Rj^Pj]Pk^Ni\Nj]Pk^Nm`Om`Nl_PnaOm`PnaSndOnbMmbMmaLk`NlaLn`Kn_Im]Nn_No^Oo_Nn`Mn_OpaMo`Mm^Oo^On_Ml]Pn_OpaRrcOo`Mn_NpaLp_Ko^Jm]Mo`Op_Mm\Ln]Mp\InZIoZMo^Kn]Oo^Mn\LkZMo^Ln]Ln]Jk[LkZKfWKeUHfVHeUJdSMdRMbQMaSKaTI]QJ[PLZOKXMJWLSUNSUKTTJSVIRVJOVKS_PT^RY[Q^[SaXPcXPcZPf\Sm_Ytgasgdla^lc_pgcqhdyokypl}tp€vrws~vr‚wp„yr€tn„vs„xt„xs†yxtrƒxuyrxtynlsfdxig„unƒtquq€up~rn}rn}rn~rnropm}mj}qm}rnuq‚tpƒtn‚rm~qkznhrfbwkg{oi{qjyoiwohymjxmiukgofbjd_ic^ld]kc\oe^oe^nc\ma[k^Vg[Vf]Xf]Ze]XeZVdYReYQg[TfZSaXR\WPTMFPMEPKDWJDTDBPD@OABLCAHA<@:6?75@77?77>96;:499377142.30(74,75+43)54*34*64)31&31&87+::.53'66';:-;;-<<-<<.<<.;>/8:,68,24(02'+/#48(:D35C24C319-&%+'#-)$+'"'%)' (&)$*%*'+)!/0&.0',,&.*&.(#.)$)"%$"+) *'(&&$%%'"&$'#*'*) '%%!'$&%)'($*!'!&&$#%$# &"% &!'"'"!'" ((!+&#& *".&"+$+'$.+'.+)-()+&'&$'" ($ ''!&()-#$+ %#&#*('%&"&"" " #!!!&' %! !$&(*!'")(*.%,3),0005114..1+,.('*$(-*.3/884562,+&,,&/1+*-').%(,&.-*1/./1,,-)+*&+'"&#"$#" !#!"  !" ! $"!)'&22,650-(&("  ""&#'& "" %& #%"("(!%%%-.(460++!*(&#$"&( -1(7<::<9:95./(+.)-3-5949=8>@9?@;AC>?D?C>>523@?BDDEJIHIGF„nc„nd…od„nbƒod„od‚odƒpe‚od€nc|oazlaui`oe\h`V`ZOZSIWMCXLA[MAYPBXSD\WNY[PV`SXeVWiYQkZOjZOj[LiVLiVKiVKjWDiVAiUAiUBhUFjWEhUHhWIhWGhWEhWDhWCgVBhUChUBgSAfRDgREiRAgQCeSFeULiYJgVIjTJgUHgUFgUFgUFeSHeSIcSIdTJeUHcTHdTGcSHgWFfUCgRDfSGgTHgSLfRJgSJiUEgUDeUGhXFfREhUHgYFfWGeUIdTIeVKdVJcUG_SG`TJdXGfVHgWHhXHgWIhXGgWLgVIfVGfUGhVHfSIfSJfWJfVGgVGgVFfUFfUDdUFfTHfTIhTIgTJfVLeWJfVJfVGgVEeSFgTHgSGgTFgVGfUHcTF_RKdUJeUJdTK]PJOGLGBODAJ@>JA=G>:E?:F@;IC?EJBF[MEdSAeRDfSFdTDcSDcSDeTAeT@fT?gUChWCfUDhWEjYDhWDgXGiYDiUImXGkWFiWEhWIiXKhXLiYJgWHgVHcWLeVLeUIbRGeVGhZKiYKiZIiZGhWGjYGjYGhYFiYFjYEjYGjYJk[GjYDhWChWBfUBdSDeSCbSAcTBeUBeVCeUGeVDgWDgWDfVDgVGhWFgWGfWEcVEdWBdVDeUDgWBgWDgXHhZIgZKl[IjYGl\Ik[Jk[Ij[Hk[DiYHkXHjZIk[HiZIl]Hi\Li\JgZIgZIhYIj[Jk\Kj]Kh[KgZLgYOi[Oh[Nh_Nk_Nn_Ll]Mj\Ni\Nj]Oj]Mj]Lh[JgZLi\Lk]Mk^Lj]Mk^Ki\Lk^Ql^Nk]Jk]Kl]Mm_Ml]Nl]Mm^Lk]Mn^Mo^Kn]Lo_Lo_Mn_Lm^Ll]Ml]Op_Oo]Nn_SqbPn_Nk]Lm^Kn^Jo]In[Il\Jk\Ik]Hk[Ln^Jn\HoZFmXIn^Kn]Mm\LjZJjYJkZLp[Km\Ll^Ij[GiWGiWHiZIhYLhWMgVKeUKdTGeWHdUJcUKaTJaSJaSK^RL]PO[NMZLJYKIZLL_NL]MOZPTZPVTKZSKWTK\TKaUOfYTg[Ve[Vi_Ypfasicyoi|rl€uo~vr€vr€uq‚xq‚wpsm†wt…ws…wstr€tr‚vsƒws‚wtvllshhzlisl€qlƒuqrp{om|qm{tmsmrn…rp€ol}ok}qo€tp€ro€pn{nk{piwnfvjfxlh{pj}pj|oj~rkznk|plwlhsiemeaib^hb[g_Yg`Yla[la[l`Zi\Tf[Va[Ua]Y`\V_XSd[Tg[UeYSdXT^UOTNHRIBLHAKF?LA;J>;E>9F;:D;8?;585.84/<75<858717:136+32*85.32(43(97,77,02'25*65(53'54'87+65(54'65&55'==.;;.99,;CC@FFCGHGA>=787DDEGJIJKIEGA…nc„nc†pd…nb…od†qfƒndofoc}oaul^ri[lcYd[QZRFWQEWKEYKE^LF\OG[TIZXLX]OUaQTfUUgVSkWOlYKjYHhWHiVHkWHlXGkVEiYCiXAjZBjYBiXEk[IhWHjXGiXEiXDhWBfUDjXCiVEjVChSFiSFiTEiSFhVHeWJfXJhVIjUJgTFeRDeQDdQFeRDbOCcRCdSGfUBcREeTHgVIdTHeTFhTDiUDiREiSNhUKhUIiXEfWCeWDeXFgRDhUBfUEhWDdUFdSJcUNfXNbVJ_SIaUH`TFfUFeUFeVHgXHgXFfWLgXKhXGfUHfSKfSOiVJhXJgWIiXHhWFfUGgUFeVHhVFgRHfQIhSHfUKdWLfWHeUEfUCfTDhUGhQEiSCfSFfVIeWIaVKdWIbUHbSI[NIQEJGAMDAI@=H>GLEE[NCdSAdSDfUEeTEeTEeTDfUAfU?gU@gTCgVEhWGhXDhWBiWGfXHhXEfSGiUFhXGhYJiXMjZKgWLgXHgVGhVKeXLcUOeVNgXKhYJh[MhZNiZLhZLm[Kl[HjYIj\Hk[Gl\Im\HkYHjWJl[EhWAgUAgUCeTBdSEbT@cTAeU@dTBgWEfWCgWBgWChXEiXDgVDfTEdUCbUEfYEfXBfVBgTCiYFhYGeWJgZJiYGiYEh\EgZGhZHiZGiZDiXHjWHjYIkZHl[Gl[FkZJi[GfXIgZJhZJj[Jl]Jl_Hg\Lg\Ni_Mh]Oi_Mi`Ll_Kl^Jl]Kj\Lh[Mi\Lh[Li\IgZLj]Ii[Mh^Mh^Lg]Lh]Ni_Kg\Qk]KhYKj[Ij[Jj[Ll\Oj\Ok\Lj[Lm[Jn]Hl[Ko^Ko^Jm^Kl]Kk]Ml^Ln^On]Nl]Qn_Tm`Rk^Jk\Hm]GnYHnZGl\Ij[Gk^Im^Hm]Gl[FjXHnYEm[GlZIjZKiXKhXKiYKkWNn\Jk\Jk\DjWDkWDh[FiYIfVHeUIeUHfWEhWEfUIfVJgWGhWEeTEcVGaRI_NM`NH_NG^OI_MI]OK\PMZONSKRSKQVMSRJUOFYQI]UL[TL`UNaUOg[Uma[qe_shbqhdqhdujfzpitm~um€uq~to}tp{qo|tq}uq…ysvtzopxonypk|rjpkomqp|pn~tp|smtn…uo†ro‚pm}nmznl}pn}pm~rn}qmvmfrjcwkgymi~qk€qkqkql|njxliwkgtjfpgclc_f`Xf_Wjc\mc\pe_k_Ym`Xd[V]ZU]ZV\ZU[WR^WP_UO[OKUIFQECJA>K@9D?8B=6C:3B94>93>61=82<9268.66/782<<678037-37,55+64+47+45)<;/79-36*16*59*47(89+8;,8;,78*97)85&97,:9.67+45+47(47(36*34)10&10'/0',.$+,".2'-1&)*$,*"0-'+'"(&"%##)(&,("(&''*+!)* &(!%)*)!,)!-)"-(#*'!"''+!(*!+(!'%)&'#'$&%&%''()*( '+)2%/4('(&"'%'*)(($)%"%( ('$#$%))#(*$*+&/+',&$0(%/*'.+$))+( ,+.*#*%#)$")&'%!%$!**$'*#)+"$',,#0.',* &%'$'"$"!  #&%#"$#' !"!$%-0'7<3>B;EDAEE@9>63;15?44=497387174/670/3*/6,180/7-591<=7?;8=679305/--)%$$!""#""##"!!##//(++&*)%)+%()$)(%+(#$ !%'*-#04),.'$$')%,0+*1)/1+(& &"+*&9=::C@=CBDHDCEA=A<7>95><;@??A@??;BA=DBBDEECDA?A?DIGJOMJOKFJC„nc‡pi„ph†qi‚odmfmg}mg|mf{kbqh_i]TcVN\OHXLDXLE[OF\RI[UJWWIT\LWcRNcUQgXPgXNhYMiXMiXKiVJkWHjVDiUElWDmXEm[EkYEiYFkZGm[Gm[JkZIl[EjYEhXGjZEgWChSEjUGjVGiXEhVHhWHhXEhXFgVKhWLiWGjVGjVEhUEkWDjSDhRDfPFfSEdTCcREcTHdUHeVKfTIfSIiTIiTHgTIiVEgTGgUIiVJjWFfTFgVJgTIgUIkWDiUBgSCfRJeUMhWIgTIfTIfTIfVEfUEfUFfUGgVJgWHfUHiXHfVHdTIdUJfVGfULeYKeYHgXEfWEgWDfUDeVDeTFfSFgRGfRHfSIfTKgWJeUKdVKfWIfWKfVKhVIhUHgUKfWJcWPbZNdXI_TK\PJPIIFAMB?H?;D?8F@8GC7->?3??4;<2;=396242*;80GE<:;0/1$8:-6:.59.:90<:1@?39<03:,1;+6:(<<-8635+*+"--$35,.3)0+'*($*-)*/*1727=8>CADIHCHFADB@CAEHFFMIBHFDFECDCED?LICFMBIHBEC@OSQUYXOQM†pf‡qg…qg†phƒodpgzmdxldvkbodXf]R]RH]MD[KEVKBZOGZTI_YNZZOW_ORcRPeTMjVMiVKiUGgSHiUIlWFjVGkWGkXDiUFlXHnYHnYEmXFkZGn]Fp\Gq[IlZIm[Hl[FjYHjZKj[IlYGjWIjXHiWHhVIhVLhVHiVGgUMiVOiWMkWJjXGjVFkWGkWGkTGiSFfSFfSDdRFfTIfVJgXLhUKhVJiUJhTJiVIiVIhUGhTEfSFhUEeTFfUJfRGfSFiUDgSCgSEhSIeVIfTKiVIgTHhVFfUFfUGgVGgVFeTGgVGgWHjYGgVIdUJfUIfVGgVHcUFcTDdUEfWHgWIgVGfWEeUFfUFfSFgTFeUIfVKgWKfVHcTIeVGeUMgWKgVJhUIgTKfWKdWJbXLdXJaTL\OGLDIE?JA=H?=G=:F>;E@:C=6EB>DOFD^QFfUFhWDiTIjYHjYGjYFhWDhWChWCiYEjYEiXFhXCgWDhXDgUFgVIhWIhWIjXHiYIlWGgXGgYIgZJhZMk\HfYKi\Li]Lj]Nh\NeZLeXMhZMk\Lk\Kn^Hl\Hl\Gl\Gl\Hm]Hl\Kk\Jj\IiZGhYGgYHhZFgXEhWDgVDgVFiXDgVCfUFhVDhWEjXFkYGjZHiZHf\Gh[HhYFjYDhWEiXGkXHjZHkYGhWHgXFeVFfXFeWHgYKi[JfXHeWFfZFhZFjZFiYHiXIiYKgYJfYJfZKh[JhZLk[Nh_Mk_Mk`Mk`Ki]Kl^Hi[FgZHi\Lj^Ki]Lj^Lj^Ki\JiZKj\Kj\Kk[Mh[JfXGeXGgXIl]Gk]HhYFgXGgXHgXIhYEeVLfXHfWFfWFhYHj[Ij[EjYFkZEjYHl[FkZCiXHiZFgXGhYIj[Ij[EfWFhWGiXHiXGiXFhXFhWGgYFhYGjZDgXDgVFiXEjVChUEiWChUGiXGhYGiWEfVDhYFiZDiXCjYDiTDgVEhWFgVEeTFfWGhYGgXEfWGfWGeVEcSAbOBcM@aMAaMA_M?]LAaK@_JB`LEaOF`PF^OE]MF]LE\HF\HG\KFZJN\KP^OPYMQWLRUJRUIRUJUWMZZOa\Se]Ti^Vi]VlaYoc]nc]uhcyliwmgvleyph}slun€vorl~rl|qk|qm~qn~mkynkznj|qmsp}qm€ro|rnzok{oi{pj{oi{oh|qm~ol~mj{kh{ki{mhwnfvjbwicugaoc]oe_h`[ja[kb]mc^nc^h^YhYWeWUYNJULGTLGNHCNA@K?;H<8D74@61=6/BA8@E;5:/;9.;9-;@0CD9?@69;163-21(?>4<=2=>0=@1:=-8<.6:/9<09;0/AA4<@46>39C67;.9;175*2,"1*!,*"'*$00(15++1&-4)-0)**$+/%,0%+1%,2&-0%,,#.4(,.$)&!'#+)$01+..'+*!,,#-.$),"'(!&+ *,"(% *'#+($,+&)*"**"-.%)* ')), ,+ )'%#'$($(%*( *+"(+"&+"((&$((((*,#(+",0',1(.1)12*76012+-,(.+(*&"*&!)% (% '$*(#./%-,$,(!-*",)!*)!)) **"//)01+),$*.$32'-,!(%$##$$"&$#!" ! $$#"!" $!%")(&675A@@A@>;<8/4/.3.273;<9AA?A?>=;::;5:<4?B;;:50-*/*)(#!,'$'"$"$&"$!  $!)*$+&#"%"!!$#%& %)!(/)3:4::5,(# !!#!&")%!)*!580:;31/(+)",-%),$+,'13-4822923:34;48>;?EBEJHAFDBFCKONNPLJKJPOOEDCGFDLLHIKDJIBGFDFHFNSQRQP…qj„qh†qf…rg€nd}mdvkbogZd]Q`ZK\QE]QEYMBYMDZOG[SJXYMX]QWbUPdRNjWJiVJmVHlTFkTGmUFmTFlTDlWHnYHoZFjVDiUFlXJoWGmXGnYFnZEpZDoWHnYInYIm\Km[Ml[NjZLl]Lk\JjZKhXKjVIgUMjUGjTEiSGeRKgTJgVLjYHjYGjVEjVFiUFgRGgTFfSEeRHgTJhUKiVMiVLjVIgVLiXJiUGgTFgTEhTEhTFiUEgVGhWJgTGfSEhTDgSDgSEhTIfWHeTHgTIhUHgUEfUKiYHgWGgVDfUFhWDhWHjXGiXIhWHhWIhWGgVFeVEeVDeVDfUFdTHdTFcVFdUFfVBdTCdTBdUHfVJgWIeUHcSHeUFdUJeUIdTKgVJeUKfVJdTIeXJfXIcSK\OHLAKD?JA=G>:E=:E>;D=9E?8FB?@LFE`SFdWFfVBfUFhWFhWGhWCgVDhWCgVBgWBfWCgWEiYDhXChXGkZGjXJjYIjYFiXFkXEjVEhWGhYGhYGgXIiXJiZJiZKj[Nm^Ni[NgYKgXLj[IhYKk\Jm]In^Mn_Ik\Ij[HiZJj[Lk\Ij[Ij[GhYHiZGhYHiZEjXDhWEiXDhWCgVBgVFhWEhWEiXEiYHk\Jk\Gi_Ik^GkZGkZHl[Gl[Jl[HjZHjYIj[GhYDeVFhWFgXHgXIgZKgYJf[Hf^Fi]FiZHl\HiYKkZJiZGfXIgZJh[GhXJl[Kh]Ih]Ki^Ii^Hh]Ii^Hi[Gh\Gg]Lj_Jh]Jh]KhZIhYHgXJiXIiXIiXIhWFfVDfUEhXFkYCjXEgXFgXEfWDeVEdUCbSHdUFeVDeVDiYGjZFgXFgXDgWCgWEiYEiYBfWDeVDeVFgXGhYFgXCdUFhWFhWCfUDfUDfUEgVEfWEfWGfWGgVEeTHeUBfUCfVEfWEfWFgWEfWCfSCfUCgVFjYDiXBhVCgVChWCgVCgVCgVDhWDhXGiZEfWEfWFeWDdUEdOBdO@aK@aLBbN>bLCeLCfMDePBcNCdR@`OAbNAaLBaMBbMBaO@^OEcPGbQG_QK^PJZKJ[JNYJO]LT^NUZLXXJ[VIZVL]XM\WLaXNcZQeZRc[Re\Sl`YmcZrg_{og{mg}nhwjdymg{niznhtmfwoi}sl~rl|pj}oiwiczlfzlf~pj}oiqk~pm}nk{kh{liylhsgcvjcuidqe_ma[l`Zk`Yc\Ud\Tg]VdZS`UO]QK_OL[LIPCAQECJA>G@=F<:F<:D;7<70<8156-?F9?H;4<->@1DD6=@0@C5@A7<>475-87-<;138)BE6DG7>@0;>09<06;/6>058-6:.:?3;A2=?3@@42:E96:/38000).)#0*$)&!+-&68,26*02'01)()#&&!,1'+0',0'01'..%0-$12(+) (#'!(% /,'./&./&)*!() +)!)( (* ))!+( *&".+&,*%)&+)!.,$*+"'(&&'&'&&$$"&#'$)#'%&('(('(&)'+*"),#*/&.6-,3),-'00)873-*&,)%(%!)' )&!)% )% *(#0/*12)--$+)!-+#*)!*,#..$34*12(,*"** .,"1/%,*,*'%! #!&$" "" #"! %##")Ŗ:<<:=<786352120222:::?>=?=@CAEFC;84$ " ",)')%!*)#//),,&*'".+&//)-.(.5+5=36=56>44=36<44;77?<BAEKJSNKMHGHEDA@@DDDFFFKMHNLGIIFEJHHMKKJI…tk„ri‚qfnc}mezlctk_kdX^XKXQDYOBYMAZQFZSIXWLXZOT^QScUPeWNkXHjWEkVFlTFmTFmTHoVFnUHoVFoYGnXHoYFkUDiSFjTImUImWInYGnYDlVFoVFlXImYJo[Kl[JiYOjZNk\Ol]Nj[PkZOlXPkYKlUDjTAiSDfSFeRFgUHeUGfUEgVFiUDgSEfSFfSGgTGgTEeRIgTLiWKgSKhWIfVKhXJhWFgRGgTDhTChTDiUEgVGgVHfSGfTFiUDjVBhTDhTFfUFfTFfSFiUEgUEgWHhWHiWJjXGiXFiXEiXFhWHjYGiXEhVKjYIiXEgVEgVEgVEgVGeUKfVHfWEeUGgUGiXDfVAeWFdUJgXJeUJeUHeUGgVLgWIdTJeUKfVJeUJfVEdUFfUIcRK]NJLCIA;D=:E>;D?;B>9DA>CPHGaUFeWGiXEiXHiZGgYDhXCgWDhXCgWBgWDhXDhXGjZGl\EjZEjZFjZHjYFiXGkYElWFkWDhVDhXFgXFhXIkZJiZIj[Hj[Nm^MhZMfXHgXJhZGhYJk\Gl\Im]Jn^Kk\HiZIhXJj[KiZFgXGhYFgXFgXHhZFgXFjZEiYDhXDhXFjZDhXHhWFhWFjZFiYLl]Lk]Ij_Il]FjZGjYIjYJk\JlZHkYIk[HiZIj[Hh[IkZHiZJiZKi\Ki\Mj^Hi_Gi_Gk^Hk]GkZIjWKj[IhZGhZGhZGiYIlYIfXGfXJi[Ij\Hg]Hi]GhYGhZIj\Lj_Ig]HfZGhYHiZGiXEgVFhWGjVEgVFhWCgVDhWCiWCiWFjZEhXEfWDeUCdTEdUFeVDdUBfVCgWDgWEfWFeVDeVDeVBfVCgWBfVDeVDeVEfWFgXEfWEfWGgUFfUHgVFfUHhWEeTDeVCdUDdTEdTFcTDcRDdUDeVDeVDeVFgXDeVBeTDhWDhWDiWDgVChWBfUAeTDjYCiWCiWBhVDhWCgVCgVEgVFhWDfUHgSCdOCdOCeOCgQAeOEeMHgPEdODaMAaM>^LCaMBbL@bJ@aL>_M>`OAdNCcODaPE^MG_LF\II^KJ^KM`MN]JO[IPWFQWKSXKUWKWYJXWHVTF[SI[SJ^SKbTLfUOiZRg\Vi^Wma[re`l`ZlbZpibtmfvmfwmf{oi{mhykeyke|nh|mg}oj|oimk|lhujftidqfbrgcuicsgaqe_nb\k_YfZSaTN`TN_SM\NHWICWICQFBNC?H>:F=9C:7>84<72>83<7/=:2AA6<@3=B64?@5<>2B2:>/89+:8.5;.8>229,26*59-35+22)64+58.1;0COC2:.-1+,,'0)&0*''("04-25'53(-),' # (("-/&++#/,$/,%1+$1*#-+#(%&#%"(%*'"-.%-.%*("*'"*( +)!-*#*)!(* () *+#,)$(')'.,$,*"(*!'&&%&&%%%#'$($ &$'$*( '(&'''**!+-$*/&&.%-3*+0'-.(..(--'(% &#&#'&&#)$ *'"*)$+-(34,43+2/'-.%,.%)/&37,7:001'.-#,+!.,"-*!-+!-+ (*$"#!$ "#   ! !$""!$% ## **&6759;<:<==@>999435545@?ADCD=;;;9898623/+/-++)534965:98<<9/4.%)"&)$' #"# $$''!*&"$!%(%/43>>?=872*(,"! !263IFEEC>=>855/$$&& --'//)44/3<27?6:A85<3:>5D?EHCJGCIEADBADBADDCJJKNPKONJNPKLSNKQNLKJƒqj†vnˆzrqiyjeqe]i_UbZL[REYPDZNE[QGZUJX[MU_PRbROdUMeUKfVFeREfSEgSDfPFgQGiRHjSJlVMnXKpZGlVFkUFiSFhSEgRGiRIjUMnZIkWGkVGkTJmXJlXImYHkWLjZMiYMiYNhZNhYPj[Pi[Pj[MiWFhVChVDfQJgTGdQHbSIfVHiWDfUDgSCgRGfWGgVFfSDcRHeRHgSMiTLiXLhZLhZJiWGhSGgTDhTCjUDjVFiXHhWFgTFiUCiUCjUCkVBhTDeTDgTDgSFiTEiVCgVEhTGjVFiUHkWGjVEiTGjVCiUCjUEkWFiUGgSHiVDgSBfUEgVGfUGdUEfVEgUGjVFiVEfWFgXGfWHfWIfWIfVGfUHgWHhWIeVJeWKgXIgUIjUGhVFfTHdQL^OHLBJCERJHdWGhYGjYFlWGj[EiYFjZDhXEjZChXFjZFkZIjZFjZIn]CkZDl[Fl[Gm[CiWEmWEnXFmWDjWDhWDhXFiYIlZGj[Gj[Hl\Jl]Kj[JgYEfVEhXFhYFk[Gj\Hk^Hl\GjZHhYKi[HhYHk[JgZIgZHfYJh[GdXGgYFk[EiYGk[Gl\Hm]EjZIiYHiZFiYHj[Jk]Lj]Gh]HiZGgVHiXLiZMk\Lj[Lk\Jk\Jk\Jl^Ik]Lj\Lj\Lk]Km^Jm^Jl]Im^Il_Im_Hl^Jm\JnYKm]Ij[GiZFiXFjZGkXJiYFhXFhXFgYEgXFj[GiXJk\Hj\IgYIg[GeXHiZIj[Ii[EgWFhVFhWEgWFhXHiYFhXEhXFiYEiXFjYDgVCeTDfUCfTCcTAcTBfVChWDgWDeVFdUFeUEeUEgWCgVCgVEeWBcTCdUFgXEfVAcTFfUFfUFfUEeTGgVEeTEeUDdSAaP@aPAbO@bNHfXBaR@`PAcRBdSDfS?dSCgUAfQChSDhVDhWCeV@cRCgUCfVBhVAhSAgUAfT@eTAeTEhWCfUHeTEdQCcOAePBhRAfPDdQFeRCbNA`MB`NA`L@aM?`K@bJ@bJBbMBbNAbMAaNDbNC`MB_JD`HD^KD^KGaMF^JI]KL]IIZMK[MK\LKZJLYILYHRTIRSGTRGYUIXQFYPEVPJWPHYQI]SJZPH_VL_VOaVPe[Tl_Ytibuiczle{mg}oizlgwjguifuf`re_tibukcpe^tgaufbre_mc\g]WcWP\OF[OJWJEUHCOF@MC>H@:FB>D@:>;4>:3=91:6.75-75,75*A@4FG8CG7>D5A?2B@3>@3@5@B5@C4>E9?E7>B68;-54+52,11'9:014*,0&-.&*("*)$,)"+/%.:.4A53<1,.)+)%,'$*'$+-'4?42;-69-%!&!#$:B7,+"'%+'1,%3/'0-#,'#)&(%(&'%'$ ,*"+("'% (%!&%*) *(!(* ,2'+0%(,"')"&&!()#+)",+")&'$'$)'+*%$(%&"&$'%(')*!&) '+"(+"*/&(1'(1')/&)+"**$0.'-*$)'%$&##"'%)% (% *)&*-)33+52+00(02)06-2;069125*/2'/1'21'+*#)( +,!)*### "  !"$#""!#%##!-.+==<====BKJNDBEC@@GDD=<;)*).1/56699:898:>:DDBC?>C=93+&& $!!.2,=99B?<:<7550*+&&+%),'+-(6725:3482471:=7AE?@G@?D?AFAJOJIKGGJFJMHDFEGICMMHLLGJJFKJGAD@@C;A=:D?cN>cNFfV?`P@`OAbQ>aN?cO@dTAeS@eP@fPBfT?dRDdUBdTBdT@cRAfR>cO=bP=cQ=cQ>bQAeSBeTFdTEdTBbQ@cPAfR?eP?cS>aQ>`N?bN>aM@dN@cQ9B>:A@:AE>BE=FH>FG=ED8>=1:<1;;0<;.CC3AB0EH3@E9CA6CA6:C68@4==1:;*12#88,9:.:@ACDGHFLCAD><<643*)(+,+8><7=;:><7=:171:C<@F<:<652-)$!#   (!'"$#&"# #&-(:C>;?:;?:=A;{ngvlcuia‘€yˆ|rgWNbPI_MF\OI]TLYZPW^RSbTPgTMjULkVKhTNkYIhYGgVFfQFeLBdLDbJFcNCcNFfRIdRPeTNdOMfOJeNHfPFeSHhUIhTJfSIgSGgWGhXHiXKjXKjUMjVLiXIiXKjVJiVIkWEjVEiWBiUMhXIeSKeSNgUNdVSg\Ui\Qk\Mk\Nl]MiZRk]Tm\Ql[NkZJjZJkZHkZIiZJj[IiZHgXKjZMl]HkZKl[IiYKhXHgVHhWDgWEiXDjYCkYDiXFhXGiXGjZDiXEkWEjVEhSFiYIkZIiXGgVGhWEgVGhWFiWElVBjXBiYDhYEjZDjZDkYAgUFjWHgUEhWFhVGgTFfSHeVJeXFfYCeVDfWFgVEkUDiUDiZGjZGiXHiWHkWGjVJjWEiUJhTO]PKLDFB>F?;D=:D>9A>9D@;DC=EVIHfVHkWIlXGlYHnXFmWGmZGm[Hn]Im]Fl\Gl\Hm]Hl\Im]Hl\Hn[FkYGm[Fk[Ek[Gm_Ho^Hm]Fj[GkZKm[GhWDiTFkXHk[GjYFjYCgVGjWGlZGkZFlZFl[EjZCl[EjZGiZIhYIiZFgXFgYGiYGiYGhXGiZHi[Hk_Ik_LoaHl^Gj\Ei[GkZIj[Ij\GhZHeYFeVFgYCeWGfYIeXKfYLfYLh\Ok_Mj[Mk\Nj^PkbOl^Nl`OpbNqcLpbHo_Ip`Gn_Im_Il^Lo_Mp\Jo^Im\GkZEiXFjZGlYDmVEkXEgXHgXGgXHkXFhYGfXGfWHhYDfVCiXEhZDgYFeVFeVEcUFfUGdTFfUGfVGeXEgXEfYBgVDfWEcUCaTAdSAfRCeTBcRAeTBfTAeT@fTEeXEfWEhTEhTDgTFgWIhXDeTDfUCfRBdPBeRDePCdRDcTCcTCcPBeN_K@aLAfQDdQGdSB_P>aP@eT@dSCeQBbNBbMBcNAdN@^Q?^P@_O@aM@`MAcM@dN>cM=bL?dN>cM?cM@aNAaNAbL@aK@`LA`N>aMA_LB]IC]J@_K<^KBaMB^LG^OD]JD_JB`GA`LB]HD`IC^GI`KE[IBYIC\IB^J?[GA\IAYIBYJBXGC[GDZFEWEEUEEQFEQEHRCJTEHNCJMBKLCOLDQKDSHDUJEWMJVKG\LJXJDWMGYOHdUOl\Zm`\laZk^XgVSeRO^MLZLG[QHVOCNH>LI@AD?ED=@>5><3AC9>C:39>456..0*0912@54A40F33>2!*) 9>3;D5/0%*,!31)-+#./%12(3/(*%!)&!($!($*'(&!(*$(*$(*#)("*& +')'(,!+1&/6+)/$%'!)*#$&*'"(% &"%$**,,!,)!(% '&(&(('(*+",,$.*%-.%,.$)0%).#$)*+"/2',,#*')&)'((+)!/-(-.',+'./*34112*76/63.53.55/24/23*01,13.894;:2/.$%) *+ -,*&&#&#!  !! ""!" !$!() *,$-1.=<BB=BA>?;83460261021,13+?>550('!  &($('#&&### #$  $ $*$2;26:5.2-561./*,-%*+"#(!%!   !$/ED>LMGMOIGICFE@@<776232-:<6CE?MOIGKE@F=FIBGIC@C<<>:BHBJOMKROLMJFB=HDA7:B8=LB;JB3;7143of]g_VaVNYJCZOF^RK]QI\TKXWLW\PW`SUcTNcQLfRKiSHhPJjQJjVHjYGlZFlVEkSDiQGiQGhRFgSJhSPfTVdSScOQbMOdNJdPHdPHgVJhTJgTIgUEfVGhYHiXHiVKiVKiVLjXLkZIiWJiWJlZHkYFkXFkXJiXIgUKhUMhVLfWLdXRi[Oj[Lk\Ml]Pl]Qj\PjYQl\Qk\Nk\Nl^Mk^Ol]Om^Nl]Kj[Kj[Kk\Jl[KjZKhXMiYJhXJjYIiXHjYEiXDjXDiXFiWHhZGiZGkZFjZIkYIkXIl[Ll[KiXIgWGiWFhWHhWFjWBhSEjWEiXFhZDhXChWBfUAfUGhVJiUGhWEgVFgTHfUGdUHcVEeWBcTCdTDgUDiTChTEiYJl[KjYMl[Mn]KlXKiZIjYMgXN[OIHBGA@F?;C<9C=8B>9B?:CDaP=`O<^M;]L<^M=^M=_L?aN?aN>^K=]J?^KAaO@aP=_N>aO>aQ>aQ>`PAaPC`NA_LA_L>]I<[L@]NA\MB]ND_OC_NA]L@]LA]L?[JB^LA]L@\LB]KC_KB]L?ZKA[M?]M@\K@ZG?ZF>[H=\L?]K?ZJAZK@YIAZJB]JC]L?XGA[G>XEBZI>UF=VG=XHXI>ZI:DE>DB8<;1;<37=3:B5;<0=;0;@3=A5@>2AC7AA6EC7DC5BC469)76*34(22(,-#11&..!,) ,* ,)!.+#,*!-*!1)"+(35)69,66,53*41'11&+/&*-$*)$+)$-0'-4*,4*1;1-5,/7/4=216.182CQI>OC6E7/?/07,#!($*-#4=/07*)-"*'!$!&%12+54+**")&!(&!'&'''&!/0*12,./).+')&,) %%%))/#,2&*-"%'!)*$'("*&"&#'#)& *)+* '# ($ )'((*) )+"'*!+*$-+&,)",-$.2''.#',#03+27,-/%++"*( ,,#./$,.(,.(')#+-'.1*+,'.0+53.;84=:566//2*11+661;<8>?;@>755,+-$***(*'(&'$! ! !$" !"""""!" ! #&*!774?>=A;9<75615419:4++%*(!% !"() )+!&(%%%"&%!%'!$##" #(!#'! % %'# !#$!"#!'"+'"   #++'>>;LPKINHCD@AA<>=:;:6773EFAIKFFHB?C>>A<8:5341684>C?EIGEJGFHC73-1-$-,"()#8=7ITLKTOFMGILIaVN_SJ]PF^ME[OH\RI^WN[\PW`TSdSThVOgTHePGePGfNHhQJjQHiSHkWHkZFmXFlWEnWFkTGkUGkUNiT[lZbgT_dQ[cNXcRPeRJeQJiYHhVJjWIiVGhVGhYFjZJkZLjWMkYLkZKk[IkZIjZIkZHjXFjYEkYGjYKm[JlXMlZKhXMh[NfYOi[Nm^Ml]Pk]Oh[NiYMhXNhZMg[Pi_Pi`Sl]Qk]Nj[Pm^Nm^Ll^Mm\LjZIeUHcSMiYJjYLiYJhWJjYKl[Jl[Km\Ki\Jj\Kl^Jk\Lj[KiYJjYKjYNk[LiYJjZGiXIiXFiVBgSBgSHiYGfWFgXFhXEgVFhWHhVJiVHiZGhYGfWHgXGeVIfWCdUDfUDfUFhWEjVFkVHkZIjYLiYMjZOl]LlZOj\Mk\OhZQ[QJHDF>?GA=E>;B:8C=8D@;C?:DE=HXLKgXHkWHkZGkZIm\Fk[Fm]In^Im_Il^Mm^Jk]Hl\Gl\Fl\Dk[Lj]HjZJl]Gm[DmZEo[Hm]Hm]FjYHl[HkZHkWEiUEhUEgVFhWDfVEfWAeTBfUBfUDhXEiYDiYGiYFgXIhYIhYJiZFfWFgYHiZJk[IkZIj[Gi[Jn^Hm]EjYDeTCcRFfSEgWFgXEfXFgYEfXEfWEgVDfUDfUGgVHhWHhWGdXHfYHgXIhYPmaPmaLk\Kk\Jk\Hl]Hm^Hm]GiXGhZFhYIhZHhYKjZFiXFhWBeSDfUBeTFhWEiVDeTCaQF`SDaRDaR@`Q@_PCbSBcT?bR@dT@dWDfXDcTEdUFeVCcRB`SB`SDeVCdUBdSEgVAeUCfVDcUFeVBeUAeTAcRDfUEgVDfUAdS@dTCcYCcYCdXBbVDeWBbV@dS?cR@bQBdSBeR?bNAdO@cO@aR>_P=`M>bM>`O>`O?aP=_N>aO>`O>cO`O>^M@^M@^LC^NBbQ:_N;`P@aR@^O?^ND`PC]MAZJA[J@ZJ@ZLA[MAZL@WKBWJDWKBWI@SGBTH@SGBVJ>SGAUG@TE>SC>RE=PF>QI>TF>SE@SD>QA:OA;PB=PC=PE?RG?QF@SGATGCSFAQCAQC?RBDUF>QB=RDYGA[IAZL@ZK>[HA^KB]J?YH@WCAVDCVEEWIETGGUIKVJJSGENAGPBDO?EOAAK@FJ?JH>GG=JHIB:F>8><4FMBCQCGVHKUH;@6=A9AC:??4=<29909<28:/76*:8-;:/>?3>@4@?5>=2@=2?<0==112$0.$.-#+,",+!+* .* .*$*&!*'+( ,* +)2(":6,33)36)8;/;<077-/2'.5+4<3.1)))!/3'27,-3)+0'*-(+0+2<109//707E=-=/$/#*.$,*$%$ ,3)=D7 ! " 21-6:/.1&0-(,)$(*!(,!++%00*/0(/0'+(!'&('&'$%)+!)+!.-#)+")*!)*!(&(&)' ,)$,+"*('# ($"*(!)*!*-$+/%(*$(*$,-&.*%,*"+-#)-"-2)-3,16-57.12)&'-/'03)-0,)-&&*$+0'/2)/2'221;;9B@=921-;:6AA=;?:;D>9C?:C?:DG=GZMIhWHkWIk[Hm]Lk\Kk[Jl]Ij[Kk\Mk^Mn]Lm\IkZHl[Gn\Fm[Hk\Jk\Im]FkZFlYEmXHn]Il[GkZHlZFkWGkWDgSBeSEgVEgVDfVEfW@dSAeTBfUHhYFgXHi[JiZHiZGhYGjZIj[GhYIi[Ij[Jl[IkZJk\Ll^Hm\Hm[HjYCeSBaNEcPFgWFgXHi[Ij\FgYGhYFhWGiXGiXIkYIiXLl[IiZHhXIgZJi[Oo_Ml]Jj[FgXHhYFjZFjZEjZHjYEfWGeXFdWFdWGgVFgXFgXBcTEfWEeWFgXHhWEdSGcSEaPGdUFcUBaRBbS@aR@aRBcTBdT@dVDfXEdUEdUEdUDdSDbUAaSBcTCeTBeT@eSAeUBdUEeTEeVBdU@eU@aPAcRCeT?bQCdSAbQCcT@aR@aRBcS?aQ@bQ>bN?bO?aPDdSCbQBbQCcRBaP@_PA_O?^M=]L>^M?_N=]K@`O=]L?`O>^L@_O@_NA]MC]OB\NC[MC]O=]N=[N>ZMAYN@YK>VH?SEASGDUIAUH@TICXL>QE=MC;KC@MF>NC;J@:I>>KACQG;K@;K>6D98F;6E:=JC=HD>G>AJ?=E:F<:C9=G==H=?I?>F>@C:=B9=A8?GASEDVGBUDFSHDTG=PB>UD?SE?SE@N@>K?EOFENFJQJPXQOYQEPF?KA=K?@NB?M@=J>AI=CG4CA6BC8>?5?A8DNBAPC>RCFZK?NA5?4;C8@D9@?7@<576-47-;9/43)>90=7.>90::0<;1=:0?:161(/,!//#+' -,")('&($*"% $ $%"&#'$/&82+.,"10&45*:=8:7353.1.,/----)-/+03.6:4BD?BB=:=:482&&! !&#-!$-!'))$&$"*)$%%!!$ "!#&$%!),'(,'+1+,3,,.(*)#+,&+.(&("" -1,>66800)#!!/+*954A>;DA<@=9--(00*06158300+10,::5..)05/>E=:=2-(.)'%$%"#$!),'793=?99<3`MG]OE]UJ^ZK\\O]`TZcVWfXSiZQjYPlYKkWLnYFkVKmYMmYPlWMkVMmXJkXKkYLl[HmXHmVKlWMlWWlVdlXoiVnfTidUcgXVhXOkWLj[GhXGkWGjWIlXKlZGk[Il[Ll[Ll[KiZGhZHm\Kn^Nm]Nm]Il\Jp^Ho]Ho[InZInZKk\Lm^Nl]LkZNk[Pm]Nk[Ok[Lj[JhYIgXJhXGfVEdUIfWHfWIgXLk\Ml]Mm^Mo]JjZKjYJiYHjYEiWGhWHhWLjYLhXJgWKiYKhYLiZKiZMjZOiXRiYOiYNhXNiYNiZKjYGjXKj[HlYFlXGmWGmXGkWEiZHk[IkZIl[HlYGkXHmZHn[Gl[FkYFlXHmXGjVIlXJmYGkWFkWGkXFlXFiWLjYIhWJiXIiZMk\IjYMhXO[PHGAF@>E>;D>:C<9E?:C?:B?9EI>I[MIjYHk[Im]Hm]Ll\Jk[Il\Ik\Kl\Jj[Nn\Kl[Km\Hl[Gl[Hm[Hk[Gk[FjYGkZFhXEhXGkZHlZHl\FkVGlXBgTDgSEgUFhWFhWEfVCdUCgWDgWGgYHj[Ii[Ii[HgWGhYFjZFk[Fl\FkZIj\HiZHjYKl\Kl]Lm_Jm]Jl]HjZEgVEfTGgUHhXLk\Lm^Jk\FhZFhYIk[Jl\Ik[Jk[Jl[Jl\HkZIj[GhZFhYJk\IkZGhZGhYEgXEiYFjZEiYGjXFgWFgYFgYEdVGfWDeVCdUCdUDeVEfWDeVGgXEbSGdTGdTEcUCbVB`QAaR?aR>cSAdTBeTAdWBeWEdUDcTCbTCcRBdT@bR@bQAdSAeTBfVBfV@cREeTCcRCeV@bUAbQBdS@bQ@aP@aPCbQ?aP?aP?`P?aQ>aN>bM=_K@`MA`NB]NB^NC^MC^OB]NB]N>ZK@\M?YK=[J@\L>YJA]M@\L@[KBZKAZJBZLCZMDYMAVKEWKCUJ>QF=QE;KD9E>7@9:C<;G@:IA>B8=A7>B:=A;7:44;28A6;C:K>=K>@LAA@7=?59?5;A6AB7>B7@D8@F9=E79C7BOBEVFARCK?9F:CM?;?4:80:7/87/8:/:5,76-74+;1(<3+64*0-%0*$5-%-&-( )(*& *' )'(&' &##$&' '-$/'!+#-)".*"74+40)+-$+3(5@36?2/7*+-#*+!()&) ,1)2:1:B6:=321,)*$,,$.(!(%*"(&%")*"*,!# % '$&)!(2'0<-5:./-%,&()'- &,%+.),/'-/%,0%06*,-$$#)&+) *)!$&('+*",,#)) *)!)) ,)#,,!-,#*'#(%"*)!(+#)(")'"&& +*%/0,1/+,)$)&(( '(!$(#+*%'&*) &&()!.2,862('#00+;<7=A<:?;ABBFFEFBAFB@A>;FB@B@AB@ADDDIJIDB=43+32'.,#**#'&*'%$&###& #!!!$!#"$%#!%".-*233<9:63/961<9497341065054.;85=9:2///--231695?BMGC:41.)&&"$3.+74/52+(%*'!(.(')$))$++$+*#&( *-(4:068+2/"*%$# $'("*)"&$-.$01(]PHZRHY\NW`PVcRYiXVjYRl\Mk[Nl\PlZMlYIkXHlXJlZNn\Pq[JoYGmWEkVHlXJmYJkXLlXOnYQnYZlWfkYqkVphVlfXbgYUjXMmXMjZJj[HmYGlXJnZMm[Im^Il\Lm\Kl[Ll\Jk]In^Lo_Om^Qn_No`LqaKq`Jp\Lr]Jo[Jk[Jk]Lm\Lm\Nk[Ol\Pm]NjZKj[Lk\KkZGhWHjXDgUDeVFfWFhYHgXJiZJiYIk[Jl[IjYIlZGjYFmYHm\GkZNkZQk[NjZJgWLhXMjZLiXOlYOhWRiWNhYOiYOiYNiYLkZLm[On_Jn[HoYEoXEpYGnXHm]FjZIl[Km\GmZFnXGpZGo\Fn\DmXGpYGpWKoZJmYHkWFkWDjVEjVHnYHlXIkZLkZJk\Ln_MmZKnZMiWKZMEF?GB?F?aR?cS@cSCdU@cUAdVEdUDcTBaRCbQ@dPAdO@bP?cR?cS>bR?bS>bQ?`MBbR@bS>aU@cS>`O=`OAaP@`O?_N>_O?`Q?`R>_P=^M=_L?^KA^LB_K@[LC]MAYKA[MA[MYI=WF=UEAVF?TE@QD=OA>QC@RF>ODARI>OD@NC?I?59>79<79>98?==DA7>99B<;F<>NE>E@3<37@6>H<@H>:A:=C=?E?:A8:A88?84944824=13>37C78B:9@;;A67<3:@639A6?H;>I=;D99=145,46-88/9:/AC6DH82@@4?@8?<7;:26:1=D:=?6=F:@J;G79J;?RD>SB@O@6A49A62>20@2@I;;3;;278.61(01&.+"5( 6)!*%(#+$*")!)#)$)%!)%+* +&) '&'&()') **-!/%!1)%2*%,+#.4)4>1:D52;,-/&*+"(()-$*2(/:/2=09>413,,.(*)#*$%#)#*"' #$%#"$ ,$.,$06,4B33@026).( ,&))18*5?6-5,.3+07,+2&)1%)'!%"*'!,'"(% !#*(+*!0.&*+!)+",-$--$.."00$,)"/,'21'--'*(#*% (% -+'.-)+*&*(#,(!,)!&&!"$#!'$&$*(..(01,.)&+'#1.-8:8@CBEHHGJGHHFHDCB>>=79D?@DABHFHJILMMLMJGCA9:7-42())"(' &$%#&#"'%" " #!! #""$ (%"**,/00763;94:84984:65AA;GGAGGCKGHNIJ@>?==<9;97:7342977:=567/)'"'$ '"(")#'#"!((&*($--&-)"'&"  !#(* /0).2-,2-194:D?BA;;63.,'&*$-.(,'##"!  $).(14.??9;:477100**$&#+(!.+#.-$.-#&+&*-&+,#..$,+!-,"/2+6=2;>074(,'" "''))')&&$() ^YO\^OYdTXeUTgTTkWRmYNkVMmXOkWOjZNkZKkXLlYNmXOmWLoZMnXJjWJmYJlZJm\NnWOmXPoZRn[ZkZil^okWrhWpgYchYShZOk[Mm\Ll[Nn]Kl[Mm\Mj[Lo]Lq]In\Im]Kn_LoaJo_Km]Ml]On_Mn]Lm[Mm\Ln]No_No_Ik]Jm]NldOl_Ol[RnYOnZMk[IkZIjYKhXLi[Jj\HiZChZFiZGhZKh[Kh[Lh[Hj[FiYEiYGjZFjYGjYFn\HkYMkZOl\Mk[Km[Oj]Ki[Kj[KjZKiYLhXNgTOiXNhXOi[Mk\Ml]Lo^Mo_Jm\FkYFlZGm[KnZLn\Mn^Kl\Jl[Mp]Nm\Il[Hm\HoZJo[KoZLo[GnYIoZHnYGkVGjVImWJnXJl[Jk\Kn[Mo\Kn]ImXLgWNXLHF?E@=F>9A<8@<8?<8@=7CA7BHDLbVKk\Hl\Lo_JqaMp_In\Hm\HjYFhXGiXDiXFjYHm[Gm[Hn\Gm[EmXEmXGnYGnYFmYFnYFjYElZCkZCl[Fn\FjZIjYIiXHgXGhYEfXEgYKgZJfZNl_Jk]Ik]Ik]Fk[FjYHl[Im[Il[GiXEi[IgZOj[Ni[Ml]GkZIkYGkWGiXFhWFgXEfWGeWHfYGeXHfYGjYEjWHm]EjYFhXGhYHiZIj[Hl]Fj\GiZHiZHiYEgVHhWGgVHhWHiXFgVGhWEiZEgXFgXGhYGiYCiWHfWDdVBeWCeXCdYBcWGbVEaTFbUC`QDaREaRA_PCbRCcRAcR@cR>cSBaSDcSEbRDaQBaS>_Q@`O@`PAcR?`O?aP>`OC_NB^N@]MBaOBbQ@`PCcQ?_N@`O@`OB^OA]NB]NB_P?]M>[L@\MBZME\OAXJB[K@WHCVFDTEAUI@WH@XH@XI@VIBTJ6QD>UI8LAMD?H?IABKA=E:>I>9J>8F?;F:9?3;?1:B5;D7:E=9@79C:8I<6H:;H;:KB7F;>G=7>5>G@@LC/416<59C7BL?8E:0<5;F<;C<:>7=B89C6:F5:@/:@69B6:D7:A49E:39-45*56*57+58-43*1/%76+75+/.$-+!,* )&*"*!() &("(")"+#,!)"-'+*!*%##$%(&'&+!,!)!,$,("/-"26,.9,/18J=4M;4D6.5*..%/.$*+!,)"*#* '%!!!% %#)+ *-".5(.7(67053*)''($-+;+1E6.<--;+/?0,4(.)!%%&#+$+"*#,% %'!*+&02,)+%(+&+.(+0&,.&-.%+,%01+-1+.0*+,'&'#))%+,$)* ,+ *+!() && $$%"%!&"%#*( 31(0.%-*&,)%0/+873=<=GFHILJDGEACC777100GCDPLJPNKNLJRQMUQLJE@@=541(,++)(%&#$"! #$$$!"#"!!" !%#(( -1,8>9LLK?>;794:<:?B@GNLQUTZXXSMN@<:?;7<;66;389361-31-0,(("" $%$'!'&!#!)&"300((%%'!-.%/+$& "#02-7;44=4:A;6?9;>79;153+63+=<49911( '!!$&*,&+.*)0+OWTRVK11($!'$0.$/0#,)#*+$*-$+/&25-//)30(64,:8/63,+%%"!'#+($&##"''__R[cSZfVYiXSgWSjZRkZNjXOkZOjYLgWKfWJiXLlXMjWOlXNmXNnYLlYKnZImZImZOm[PlYPmYTo]]m\kn^piWtgVqgYbhYTj[LjZLlZMm[Oo]Mm[KkYJjXHmXInZIm\Jn^Ko`Kn_Km]Kk\Nm^Nn]Km\Jm]IkZMo_Oo_Nm^Qn`Pl^QkbSnaOm]Po^Ln]Jm^Im\Jl[IjYJj[Kl]Hl\Jo]Hm\Jk[Kk[Mm\Mk[Nl]Mj[Mk[Nl]LjYLkZFl[Il[KgWNiYMk[Mm\Oi\Oj\Ok\Nj[Ok[MhXMiXLgXKhVMjXOm[LkYJkZMo^Km]Im\Il[Il[MlYNm\Om^Nk^Qo`RqaQn]Nm]Ln]Lo[Mp\LnZKq\Jr]Hq\Gp[Ip[GmYJmWKnYIkZJl[Jl[IlXJl[Ln[MgWLVKFD>D?:?<8@=7C@8AGBMbWKj\Ko^Jn^Fm]In\Hl[GkZIkYGiXGiXEjYFjYHl[Gk[GlZFkZGmZGlYEiVJm[HmZHn[Hm[Fm[Gm[Fm[Ho\Hl[Hl[GkZDiXFjZEjZFk[Kh[Lj]Kk]Jk]Il^Im^Jn]Hl[GlZHjYJlZJkYGhZLh[MgYNhZLj[Jk[HlWGjXFhWFhWHiXHhXDfUEdUGdWGdWDeUEgVEjZEiYFhYHgXFgXEgXGi[GhYIiZHhYHhWKiXIiXIiXIiXIiXGgVGhWCgXDgXHiZFgXEhXCgVIgXEeVCeVCeWDeXCbUFaTEbREbR@]N@]NA_N>^P@aP@bQ>`O?bQ@bSAaQDbSFcPC`OB`O>^O?_N?_N?]M@^NA_O@`O@^N@]M?^MAaPAaP@aP@`P@`OB_PC_PB]OC\NDZLBXKAXK?UH>SE>PC@OCBSFCVGASE@RDCRC>MA?PCATF=QC>OD>ME:RD@WI6H=;K@=LC?NE=LD7B:GABND@MC6D78I>:MD:I@:B96>35?46@65<69<37;218/8@7=G=:E;7>88<48<1>B5;?65<28A57@4>F/A4:<077.79,:=/=A1?@6;?4?E:08-9?425=247-66,76+33(0/',+",) .+!-* *()')'*%)!) (&( (#("("( )"*#&$*')"$"$"%&'&)!+",%-&+&'.#5=27F8,;.2A34@19@65:/48-07,/:.5C79S??Q>?I9-1#04&17'46+,*!.) -'+("$%$ )& () ')#(', ,*%(#'!(&%+/:.1B4,8)1>.1@0/6*+%)''#($*&-,#++ +*$++%*,&')#+.(-1*'0%(0%*0%).%*1()1(.1,)-'**')+%-.',/$))'( (*#(("'%'$'$+("$"+)!0/(,,%,-(,-&02*884?A>ECDGFEA@?<;;EBB?;<342*0.$,+ )'&#%#$"% #$$"""!"#  ')!6726<6=B@YXW;67986777:>>DKJORQIHHF@AD@?:517708?46:210++*$)&$"  %& *,&+,&"$ "$'!'(("(*#66-<7/*"#!/3.6=61801827=88=69:443-52-B@8EB9@HAK_UHgXHkYGjYFk[GkZEiXGkZJlZGiXGiXFjXGk[FjYIkZGiXEgVFiXHiXJiYMkZJkZLn\Hl\EiXFlZGlZHl\FkYIl\Jl]FjZIk[Hj[FiYHfYJhZJk]Jk]Ik]Hk]Jl\Ij[Kj[JiZKj[LiZHi[Lh[KgYNk\JhYFgWDhWBgVCeTEgVGgVEdTBfRCeREbSDaTFcTEbSBdUDeVFeVGfWDeVCgWCcTDcTFeWHgWKhWJfVHhWJjYIiXIiXGgVGgVCeVCeUCdUEgVFhWDgUFdUGfWFeVFeVEeVEdUEcQGeSFdQDbOA_M@_L?_Q>^O?aP>`O@_O>]NC_Q@\NC^LAZIB]LA]MC_OA\L@\LA[K@\LAZK?ZK>XI@YKC]N@ZK?ZKD]QD[MEYLFWK@QE?QBBQEEUH;K?;J>;G<9D7LA>SE@SF7G;9I>?OH?PI9KB9H@>NE=PG;NE:IC6D=?LC>OB0F9:TG;TI>NH=IB9B9;E8:D9=H>;G=6F:7C;7E=:HB5F@7OA:NA@OB;F98@5/2+00*01*/3+77.12)56,68,77*;<-@A69;09=27;058-78.52,41+40)<91<:166,29,37-55+21'30'0+#-+#+' ,%.'.)*&,&'"' +#'(')!)#'!&) *$+&(&'"%(#$#&'!*"'"& (!,%+(*($* BK@3@29E91=12=15?26=17=27=2/8,6B6=TB=N>4>1)-!05(4>-7>/14'.,"//$20&%&%$*)$() )*!'&('&"%+#'!').3*4>0-7)3>.6A1.3''$/,$*&'%--!17*18+/-'**$*+$(("*-'.0*)/%)/$(.#(-#'-"(.#.3+,0+*.(*.(-1',0%+.#(*#'($*)%)'#+(!+* 1/')')')(#'("',&/3*27.26->>:9741/,52.:54?:9<76GDC:::CCCIGGHFEJFDA<:><754*0/%-,"*) %"(%$"##"!#$#   !   "+-'<>;;A?HLLROQC<>A=<588@BBLOOQRRXWXURQFEB1-*//&.5,.6-&+%)'&%&%%%"!%#)% '#  "!&&.&/509>98;244,1-%'!!! "# )/+171+0+-1.=C@;?955033.0.-643:98;72.)$&   $$%)#(/)$.$)/&+-$(&&$&#"$"$% &#)-$-0'+.%$% !#!#!%"" " " UeTSeTThVMeSNiYLgWJdTKdUJeUNhYKiVKjWHhVHhWIgWKgWLfSLhUJiVKkXMmZKjVLhWLfVMfTQhV[gVnj[whXufUnhUaiURjWNjYLjUMmWMmXKlWMmYJnXLo[JnZInZJn\Jo]Ho\Km^Lm\Nn]Kn\InYIq[Hl[Il\Ml]LiZMfYPg[Vg[UgZSfYRj\Oj]PobLp_Jo^Lr`Io\Hn\Jn]Ip[Kp\Kn[LnZOn[Mm[Ml]Nn_Nn^Kj[KlZIjXMi[Nj[Pj\Oi[Oj\Pj\Nk\Pi[Qk[MgWMhXKiXFiXIlYJmYLlYNnYNlXKm\Km\Mm\Mm\LkZLl[PmZNhZKfXMgZQk^Sm_LgWOjZPj[QnZOmZMlYRn[QmZQn[So]Pm[On[Ln[KnZJmYMmZJiXJkZKiXIgWH`QISHC@;C>=B=:?:7@<6A=8A>9C@BNB=G;9A57?44=2=B9@NC?MBBQFCUH;M@8I=>QH>SJ9QHASH;MB@SJ8QG:PH5D>7J@?NC=PC=YK?\P=VL=LI=JC7E;6A89D:9F;:KA;KB4@78D=3KB56@7;E=2?95=65;15@65B:/:42706>3H?6;>459.38-;=224)01*./'12(68/54+32(23'11'1/&/,".(!.&-)!,(!,%,%,%,'(!'( *"')()"("%%()#(#(&*%&(%#%&(")#& )#-&,%+(,*!14+@C;5;1;B86>43;19B9:B8853,0/%10&,*"%#&$#"$"##" !"    )+%355:>>HMNPMOYSTEBA<>>GHHTSS_`^XZWQRPRQMEA<31*.3),6+&*$*)'&))))*))((!#$!$& *0)/7/=D?HOGAE;:;2-+$'$" #! $)$+2+&-&+/*(+)-2-14042020/553898762730/(%" #"$( )$/%.7,05+/0')'&%%#'( 47.FI@8702.*01(76.1/''$$!%"!&$$$$!!!ViVRgUPgUPiWKhWJgVMgVLfUKfULgVIiRIiSDhRCgREdQGfRIcSJfTHgTIiVMkVNiULgRNgSMfRRfT]fTpj[vgYveUnhT_hQRhSLfVMiVLjVNlXJkWLoZKnYMn[Mo[JnZInZIp[HpZIn\Im\Ln^JmXKo\Jp[Im[ImZKlYLjZMhYNj[LfVOhYPhXQk]Ol\KkZLn]Lp_Lq`Jq\Lp\Lp\Lo_Np_No^Om]Sp`Rn^Pm_Pm^Ol^Pm^Pm]Qo^Pm^Nk\Mk[Oj[Mj[Mj[Kk[MjZOiYNhXLjWKkWIjXJk[Nm[Lm[Om[MlZLn]Il[Im\IkZHjYIjYMj[Lj[Nk]IgYKiYHhVMhXJeUMgWOkXLjWLkXQk\Tm]Rl]PjZMjZLk[JmZHkWKlWIjVKhWKfXKgYIfVH_QFMDDB=B=<@;9B<8A;4C=5A>7BA^O>\L@\L@[KB[LBXJCYLCWIEVIETIDRJCQLETKCRHAOFCPFEPG@JA?J@?H>BKA?H>AI?@I>BE@BD=CB:EG<=A6CK=ARF>L@9D9:C88A6E;6>4=H;ANB?OC;OAAH<7@59G=CQJCSK=MB7:M@8H=1B73?63?71>66@94=44?45E93B8,6./605>4;G99F86D:8G@4;64729@88E:/<02=00>24?52<18>45<31:/3:027.4803:36>4>H>BM@24:35925:/56,35+77/<@6418.-1(*.%/5-00,*&"($ ,-$05+45&45&./!+-"-.$()!)(**-,!00%)(&%$#&$)#& $(%,,!&1"7D4>G729-+4*01(--$'%&%)+"$*&"&#*'"+&"+)$('"($ )&!*(",+$,*"-)!,+#,+#++%*,$)+"*."'-',!'*!(+#&,#&-#&,$'*#*( ,)"*)"%( ))$+,&/1(13*04-56133-.+&.(#3.*20,12-CIHPSPTRPNKHKHDFD?KGB<94/-#-+"'$##!!""& $! !  $%!111@EDDIIRQRJFE8847>D<9>268.7:1./)% !   "$+-%+/%/4-694498HJHRSOBA=772561/3-750:4/$! %$ %+"$-")7*/9+5<.27*,0%)-$./)03,-3*69079165079067.41)/+$+')%)(-,!++ )(" !QfSQhTOgUQiWIlWMkWOkWOjVLgTKgSHhPFhP@cKCfQGgSFePHbREcRCcPFfRJfQMeQGdLJdLKcMPdN]dTogYvhZvhWnhT\fOOcNKcQKgTJgTKhUKlXIlXJmYMlYLp\HmYJoZGnYGpZHp^Hn\ImYLoZIlXGkWGnWHnXKoZLo[KlXMm\Hm\Jn]JjYLmYKnZKo[Mo^Km\Jp^Jp\Lp\MnZQpaOo`Om]Ol]Tn_Pj\Rk]Sm_Qk]Qj\Tm^Sl]Qn_Ol]On_Nm^Nl]Ol]Lm\Ol\Rl\Sn]OmZJmYNlZNkZNk\Ol]Pm]Nk]Io^Gl[GkZGkZGjYHkZJj[HiZIj[JlZJnXHjTJhVJfVMhYMjVKkWJkWKjYKiXMiYKkZHjYFkYHjYFjTGhSKjUKgVLfXLfXGcUG\OFMDEB>A;9?:9@:7A;4B=5@=6AA;CLENcVJhXGiUIjXIjYGjYFjYFkYGiXHjYEfUDgVFgVFgVFfUIeUJfVHfYGdWLfYMgZKh[HgZFhZEfVJgWKiXIjWDiTFgYFfXFeVGfWFfUIfVMfXJdXJdWNfZMeZKdWKeWJdVKeWKeWMfXMfXGdVHeYHgXGeVGeVHfVIeVHeVDdTDfUCiT@gRGaQE_PG`QF`PDaNAaKAaQCbRCaQEfUDeTBfVDhTBfSCfSEgVEgUDfVHdTGdTHeUGdTGeUFbSHcRFeUCdSEdSEdQFbNCbRB_OGaRGaOGaPEcNDbOB_N>[KA^N?[M=ZK@[M=YI@ZKDYKDWJDVIEWJBREDPFCKD?GD=DC=GB=GA=E??E@AFBFJE@LD;F>>IA=F=>E>OB8E9G4>49D:=K??QD?TF@H<:D;@MFDTM>PH8MA@PHaU=J?/A4?XM7WM6QI;OH9SG9J?;OBGj[8XKRI7H=6H<7G;3A57E;>TH9MA5?3?OB8XHF`O3G;5B;6=:.405@9:J>6F;4D84C;3@91=58?67A63C75J<2B63925<56?5>K>?M@/?52A;7A;8>942@41A21?/09008.39/6<014,//*7<17?408-4;049/57,65+20&31&99-74)40%/,!.,"10&+)"($*%32%0/"*$+%-("&"'((1&".& ''(!'"& %'(' ,&)'*%&!( '(!&$# %!& )#%$ +(#33*13*$("6=6>A?>KLGOTO]_[\ZUVVNAF=?G359/7:/5:005/*%"!!  #!&'+,"),#03-9>=LNL[\XKJE9<446./4,21+0*&+"$  "%'2$-9*2<-2:)6=./7*'0%*.(,4+2:09@6?B:=>8;C99?569077/./'*+"'&''()%%%$0-'PiWNfUOhVNhVMjVOnYLlWGiPGjQIiPKhQJgPGgRGhSJmXHjVJbPJbPKcQLdRLfUKfSHcNLcONeOReQckVtkZyhZtfUkhU^jRPfNMeOLfTLiVIiVKl[JjYLl[Mm[NpZMp[Lo^Lo_Kq\Io]FkZHjYGhXJiXIiXHkYHlZHm\Hl[Im\Jm\Km]Jm]GlZGkZKl[Kl[Ik\Im]Hm]Jo^Km]Km\Pm^Ml]Mk\Pj]Tk_Sg\Si[Sj\Qi]Rl_Rm`QlaOm`Ol_Pk^Pk]Sn_Tm`Rm_UnaWpaUp`Qp\MnYNi\Nk\Ok^QmaPobLo`Ln^Nm\Lk[KnZIjVNiWNi[LkZKn[JmYJkUJkSGjWIkWIkYLn]Km\Il[LlYIkVJnXHlWGjXGk[MlYIjWHkXJlYKjWMhWMhYKfUG]MGNBBB;A=:6@=6DB9FMDM`SIeWKeWNiZKhWJgXHhYFfXJgZHfVFgVIeUIeUGdTHeUFeUFeUGiWGhWJfYJfYJeYJiYFcTHdVHdVIeXIfVIfVHfWFdUHeVGdTIeVIgUHeWJdVJdTJdUKgXHdWMfXKdVMeWKdVKdVHaTJeVIdVJdWIcVJdVKeUJcSKeUEbRCcRFeTFcSC`PB`ODaQFcQDbOBaLDbOCdPBdRBfUAeTDgVHfWIeXEcVDbTGfVCeSEeUGeWFdUKdWG`TH`TF`RD^PB]MB\MEaOD`MC_LB]QB^QC`OBaLCaMA_OC^MB\JC[LB[N@YMBYMDYNFUKGQIFMDILGGMEDMA;F;:E==B@9?:=?:<<8<<8<@;?HCFTNDOC8E<@MF9E==G==D8=A79?4?C8=>3G:AJ<=N@C\K8G:4=0=G;:MB@SH@MC>F=?MC=RJ>UM;PE;LAARG9ME;SI2KD>VNG_V4D;5I@;UK;XM>XN8PG=HE1@<>OHBRJ9KA9QD:SF:TF8PD2E=7D>:C<;OBCUH>OB;,6/5B93G>7E<9E:/@44E:2A65>45A78H?=LD3@93=75<57B:>LC8F@6>8;@:8:B7;K;;PC2/;031-/-)10,8;537/37.18-5<18?44?25?29B59C73<029-:=100&0,':=67?40;.5?26=078.57+46*68,<>268,57*:9///%-/&)*!)&-'"-/!-,!)%(%*) (('(+ ,#+"&)"("$' ' (% $$!)%&#(&((,()","&!'&(%'!) ( (!,) /,$(($* BKA/:/+6+3:09?6:A725,,/&8;2;=100&,+",' /*"0,!2/ 0.",,"+.#-2'.1&11%11%77+86+32$0/!0/3/!-(&&%!"%;A548-%$..%.5,*2'(-")+ +)!*,"$))'&' *-('*%()$*(!#*#(0(+4+,0*/.(3,'/*",*!-/%,1%,0%.1%00$,-",0%,1&-1'*.&++),-(.-%.+#++#(("),$+,'452/111659@?=?9360DC;C@811(9C6AIA;A:993C?;B=:B;851,,'#)''$&!&!!!' $# !#&$#!! $"%.(@EDRSS[VXTQQLQOUTP]ZVSNJ?=9695NUSFI?GG7AA;;=:6:46:59<<364)/&1-(#*!!$$"&"'+ PiWPlYPkYOiWPlXMkWKlWKlUJmUKlTMjSNkTLjUKiTKiUKiUMfPLePMfQNgRMhRMiSKfRNeQNeOUhSfkWulZyhXvgUnjU^kTQgQOhRLgUMiVHhUFiWGiXLl[LlZMoXMoYKm\Km\IoZJo\HlZGlZEiVHlZHkXJlXKlXLmYJlXMnZJmXMm[Kl[Hl[GkZHl\Ij[Hk[Gl\Fk\Gm[GkZIl[JlYKl[Kk[Mk[OhZPg[OhYQj[Rl]Rl^TpbQn`Sl`Sl`WoaUm_Vm`Wn`Pk^Rm_VoaUn_Rm]Pl\Pj]NgZRk_Rm`SqdPqcJn^Mn]Mo^Io\JmZOnZQo^No]Ko[GnYHoYGmWIkZKm]Km\Kn[Mp]LpZJn[JoZIpZHoYHn[Gm\KkZJl\Jm\Il[Ll[KjZKiXHfUH\MDJ?D@;B;;A99A98>96@<7?<6BA8GQFI^QEaSKdVLfVIdTKdVGdVHcVKeWLeWHfSKeUHbQGcQFcQHdRFcRHdQIcTLbUNcWMdWKdVHbTHbTIcWHbTJdUIeRGeVFcTGdTGcSGcSHdTEbUGbSGbRHbRIbUGbUIcTHcTKdULeVJdULeVHcSJdVJdWIbVJcTHcSKbSIdTFcSDcRDbRFcSEbREbRDaQEcOFeQEcPBbNCdQCdSBeTDdTDcSHeVEbSCaTDcTEeUBcPCbSDaREcTE_PE_PD]OB]NC^NB]MA]LA^JC`MC[KCZND\OE]NE_LE]MDZLF[NG[KFYKDZJ?TFBUJFWKBOF?G?@C>CC>AH@>G;;H:8;I@DTL5C<>I@;C7>@6>C7>C8??57@4JYLEVI9I<=K>>M??QBAWH7G:5?5:F=8I?:LD:GA@ND?QIEZR=TL=NF;PF5QG<[P=YN9PG:GC3A;9E?7C;2A93B;>ZO:TI8MCBWL9PF/J>N`W/>68C?9EA0?76I@2C;7B;0<23B7:LA5F:5A74C88I@5E<5B97?99D9=HAJA;GA27A49E77E92?33>07?327-/1)57117,4>1;D7:>289/45,24,890:=169.:>/75+00&--#,,$)&,& .-",+ )#+' .+#)(&))+") ) )"'!%!$%%& & (!*#.(!*&)*,)-%) &'$)&*%'*!.)!+)+( '&-/&-2))-$,2)6<09?49A559-5:.8<19;/78.21)/.&//%//$11#-/".3'/6+.5*-5(22'22'33(63)/-#.,"-**'&""%& #$*-#%%(%+(*/$)0$+0%*+!+,#*,#%'(%%% ))%&'"%&*) ''"-0*/4.(+%)(#,'"(,").%'0$*4(+5(+5(/0&,0&-4),2)*0(*0().*,/**-#,,"-.&**$04+FFALKJ221:<<44:/35+73.20)42+1,(*'*( (&)%(  ! #!!#$"!"!#&!(#=FBSTTXTTUQRPSQ^^[UTPIGBCD@PTQJSQDJB>?6(%)%($(&!$""!((')$'$&$"$"$%', .2+@E?DGE?D@?GCCJEGLFDC><910'$' "#%.&?JB;?8?;BCBBDBBE=31,-1(48-41()%$$PjYOlYPlYPlYQkYOlXJkVLmXKlVMnULiRNkTLiRKfRLgSMgSOeNMfNKeMNgONhPMhONhRMfPQfPUfQhkWwlZ|hVxgUplW^jTOhSLhULhTLiUHgTIlXIlYJjYKkYJlUKlVLl[Lk[LmXKnYHlVHlWGmWGmWGnXHlXLo[JlXJmYGjWGlXMlYIjXGkZGk[Fj[EhZFkZHl\Im]Io]Hn\GmYImYFkWFkWJlXLjWLhULgUOkXRl\Pl]Ro`Ro_UnaTm_VobUoaVp`Uo_Ro`Qm^Tn`Tk`Sk^Sk_Uk_Wk_Ul`VnbTobRpcNo_Pl^Nm^NraLo]So_Rp[Rq^Os^Ko]Io]Io]Kn_Jn^Mn^JmYMp\KoYJp[Ip[Hp[EnYHq\Hp^Jm]Jn^Hm\Hl[Km^IjZImXFgSE\MEI@F?66A98?:7>:5=;5CB:EREIaSEcTHdTJcSHbRKaRF`RHaSL`SLbTHdRHbPGcPHdQGdPEaNHdPIcSI`RG^PKbULcTH`QIcSIbTHaSG`RGaQIdRFdVFdUFcSJcTHcRHbRDcTDbRFaQHbRHbRHaTFaQHcSJeTHbRIcSIcSGbRF`QF_RG_RIbSF`PJ`QIbRHcSEbRDaQDaQEbRFcSEbRFcSDaQFcSBbQCdSBdSCdSD`QD^PEaREbSEaSEbTBbR@aPA_PD`QA\MD_NE_ME]KC]MC\LB[LB\LA[K@ZHI]MGYMFYMGYJH[KGXLGTKHUJHUJFUGCTF>QCETHEQE?H==B9<=5AC:AG@=F:;H:;G>78?8PF9L@;ND@SJ2D;?LC=E:B9?A8;B8@NC:G<7G<7L>9N@>PDDTF7F?9F@8D>6F?8IB;JD:LE>TKD\T@VN=LE9A:BXM;^P5UJ:SJ:MC6E=+=48ND=`U7VK:SI?SJ4G=7KA@OG+:2ARI6G>4IA4KA3A95?70<16G<5K>5I<5F;2C85F<4B;5@79?83C:8E=8C;6D<6F=5C>9GD;FC2957@8;K?8JBBWN/D;+92/6//-(00%/0%<>46<208./8./>23@44A53>26C58F83C7:G;8B66>33<129//2)37-:A5?F9@C8:9002-13-47.8<1;?28<-65+//%.-#/,#.*!.*!.-#-+ )&*#-' ($''') ( )"'"# $!%"$!#%& ("-' 2,%+%%&-+"+$*#'"&#'%(%(".(!.,!,)(%# &$)) ++!--$36+<@4=@49=17<-16'8:.67,56,.2'-1%.1%01$.1&16,18,/5)/5'//&10&0/%,* )')&'&&%%## '!&% $"'&%!&!%').#+/$&*&(() %#%!#!%% %%%$'&$-,&)-&)-'&(")'!(-#$, &0$)5)*5)'1%+.&,0'.5-+3+'/()0))1-,2-).'*+%+-'*+&;?6CC?B?;843:7442/951;:6AB998.5786.+( (%&%!&"&"$$"%!&"''$(&&'*,"-0)7<6AA@ADBBHFEJHDGD@A>;<661-&"  !"!# '+&,1.,2->@;@A:A>7;;1.1%.,$&%$"##&''*&, (+ (+%+'1$*6).5-*1)',&16.28/46./1,3929>8972,*%7;5IHD<=5//)20/BA><=4-0(48.CE;<:0)&!Tm[Um[Wq_Tn\Un\RmZOjVPmXOjVNiWNkTMhQNhQMgPOdQOeRPeNOgOLfNJgNMgONfNKeNMbLPdNTeNfhSzl[jX|jWojU\jTOiTNjXLgRJgSGgSLkYJiVLlXMm[LmWJkTMj[Nk[MkWNnYKlWJmWKnYInXIoYHp[Io[HmYInZHnYGoZKkXJkZEiXGk[Gl[GiYHiYGiXKm\Im[InZGnYHmYHmZHmYGlXJlXMlXOkXMjWMkXMjZOl\Pn]Sl^Rn`Ro`Pn]RqaRq`Qn^Qo_TrbUobUocTlbVl`Vl`YmaWnbUobUpcUnaXobWoaSoaUqaYn_Tn\Uo_VqbRn^Mm\Lo^Lp`Lp`Kn]KnZJmYLnXIo[IpZIo]Hp[Gp[Hp[In]In^Jn^Im]GkZFjYHlVKkZG]OBF>F@<5AA9EQEIaSCdSGcSJdTGbQKaRF`QF_QK_RKbQIcQHeQJfSHdQIeRHdQFbNGbSFaRC^PGbTHcSGcPJdTF_QH`SG`RGaPIdPEdSFdTGbRFaPIbTIaSDbSFaREaNHaPC]NE`RCaQFbRGbRE`PFaQGaQFbOG`RG`RG`RG^PG_MH\NH`QGaQC`PC`PEbRGdTDaQFbSDaQEbRDaQ@`OBbQDdSD`QC\NE\NHbQC^ME`PD_NA]LB]OB[M@ZLB[KDZKH^LF]KH[MFZKFZKEYJDWHDXIEVGEUJCRFDSEDRCGQIGPIHRKHTJFTHCSCDSBETGAL??F;=A6=A8@D:>D=9B6;G99G<A8;B9;D:@F=:A89E;9F<8I>5K?=UI;PC@PD?MG:LD2C;4D=9IBCVO5FC5KE9QI?VN>OJVM7OE:RH8LC:LB8ND:TJ6WL<_T;YN?XM;NE6F=?IB?G@ME*:2Sf\6LC1J?3I@1=85>75@86I=6L>9M@6J=5J>3D93B74>76D<8H<:K@5H=,957GC;KF2>72?59K>:OFDOC5<16;16<117,03+:@4;C59=1;7C@9=;5@<7HHA;<401'16)1<-4=,7;-*, ()*-!%*(%)''&%$$"$# $##"!" "!!" ! !'%(+&*16/AHDMPNTRRSPO?B?=@=AEADHCAE@G;>F:PE9QDOG>SJ6KBA^OA]Q;VK>UL?OF;G;9D<8E>9E=;KC5G>7LBSGCUH?OI9OG3H@:IB;JC:PE5DB4HD6RHF^WZL=MD:KA=KB7C97H>?ZN=UL4KB4F=5H?2F=CZM3K>1D94D;2?:9A;;G@;L@9NA>RB9MA5H;4D99H=5B7;F=>JA3C:9MA;OD8MA8J>)72?RI=QH/@6:LB8OB:TI:PF8I?3@72:2:A86>39A78@519.,2',4)0=01;/4=16@3;K=/2:/9@43:.49-:?55939=426-/3)27+49-7=.38-;<210&0/$12&01&//'+.%.1%+*"'#' ''( (#)"'!( $# &#% $+#,$( ) ,# ) (!*$*'**+,"*-#,+!;90-' '"&%%%' &&) &!%!$&*+!35(9>06;,39)7;-8=08;079.66*44&0.%+*!//&-/&/0%44(11"22%33'/-".,#(%)&"&' $((*.*#,#*#%!"")#*#&"'%&'&-")-$''(!!$ $%!%"'%)% %' '-&(0)-3,/1*2/%-+ +* (* () .,$.0'.2(,4)+4*-5-4<3382/2.-.*01-37/6<27<345.:93FC>GF>EG7=92847>;583/,)*# %"#"$ $#&#'"$"$ '*$47-/0%+)'%+)++*+!&* #*!'$)*4$)1!(."+0$(/#)2&)2"(2!,3#.5&+3$17)=>8BF@??95/+,(# #$&%)%'!"#!%&"(+"(,"0.$&$ #!"VgVYiZZk[_p_ctecue^sbXo\UjWSgSRgPQgONcLOdNLaJJ_HL^JLcLJeNJeNKcLNcMKcMOfNRgPZhQmlW}o\~j[ziYnjV]jSPiQNiRQhRPhULgSNhUOjXOjWMkYNmVNmWQk\Ql^QmZRm]Rn^Rl\Sm]Rm]Qm]Nm^Ql^Rk\Oi[Ol^Ll]Hl^Hm_Gk[Jm\LlXLiTKgWKfVNjWKhVIiVDiUJj[Jk\Jm\Km\Mn[Pn\Ll\Lm\Oo^Ll]Ml]Lj[Si\Ri[Rl\Sn^On\Nn[Ol\Nn]Im\Hm[Kn^Oq_QobSnaRk_Qh\Uj^Sh\TjaUk`Rk^Ol`Qm`Sl_NnaMm^Nl]KkYIkWHlWGnZIo[Im]Jl[JjZKjZJiVJgWGfWHhWHiUHjSEjWEjVGhUKkXKlYDjVHhWIfXGZP>CSH>QDCTFAUD=N@>I<@J==J>;J=?G@>H;?L==M@BUJ:TFDTL?PH:MFF[SAVN=SK;[M>]Q=[P@XNDVM;H<9H?>PG;MF7J@7JA>TKAWK9PC>MF6NE8OF2G:+>1FXK9LC7LC5N@1G95E;6A90>88A<=H@@QF=RD=O@9M@7I;6G:6E;5C87F:;D=5F<3NA6PC;PB6F:9G@=PG2G<6J>9OA5N@6RD3J<7H;7A57A54B66A96@84=4/6-.4(26,3<16=15<1;E8=M?8N>@SF7F;7C8AJA>J=.>.8A69B69@3:A48=49>5;B53:-.5(.5(08+29-7=27<223(34'25)/3%-/(-1'07,)+"&#%&* *$'!)#(#''!'!& (!+ .'1*"+#)!+") + +#*(-0"/4(.4)21(0.&)#)#)&*)('('&#$!$#&(89/;?47<.49*4:+49+79/88.87*99+44*,/%/4+7<23;C9?@;;:56509:6AB78?57A308+.3&45+23*#'$"###$##$"$"& "! $##""  ! %#%#%%&('++("'+$@CADGEDIFU]WXXYZ\ZY]Z[^\Y[[]^`^bc__]_[WNE>+$-( +)!('(&$&$%$%#(%)')%%&"+%(*".1+>C<=D?HRB@KA?LAPE@KA>SK=QJ>LF>IA=PD:QJ=LE8D?@RI@TL>RI?KH7NG:XN:UH6MC8NE:NE:VL=_TB[Q;LE?MG8RM=ZT@]T4QH7SI7QH;YK5WI6F>2C:3B:3D;8K??RE:K@7F=9KA8I?7I<5G:0@47H=7G<8I==NAAHF1;6082?H>;L>9QB6F;3B78@78>39B<7?719017,09,7@39F<4E<2C8>G?9G<6J=;VFH]O4D84C77E91B44:/;?4CF<@E8>G9>F74;F<8B889634/.0+(+")+&-/*13,..'+1'-6,8A9?A=DECAB?DF@@C>G89C4:@13:+16'26*-.!&%&"%!#!" ##"""$!" ! #!$#!!##   #&"&"&"$#&#'(."04,8?8IOLT\YV][^a_caajiiiklbfiehgagglnkYPM80'**&%'%###$$&&(%*'**(*$(#'%%%%)$:A@Yb_MQKJKB;DAEGBEB:70((#(%$#'%'$%"&##""&'+****') %(**')&("&"&(,"-6).6(+5$*4')1&)/**0%*.#&+"'%&,&452750+% ("$!&$#%'+"38000+//(*,&)) )&&$!#&bnbgpfrwmv{qvzpw~tu~tlzm^n`TgVQcPQdQPeQPeQRfSTgTUiVViVVjWShUVkXVlXWkWVkUZlWbnYup^}n]jYvkZknZ^mYVmXSnYQmVPjXRjYQk[QlZOmYQoYOlXOmYMl\NlYLmXPk[Tl]Ul^Vm^Xm_Xl_Uk]Wh[UgYRfZOi[Pl^Lj[LjZPk\Sn_Pn^Om]Pn_Qo`Om]Tm_Rl^Rl]Rl]Rm]Om]Lm\Nm\Pm]Nl]Mm[LlYNn[Pl[Qk]Qi^Sk^Um_Tm_Ql\Pm]Ql]Nk\MjYKkYJmYKnZIlXKkZLiYKhXJiZHiZHjVHjVIfVIfWLfVLgVNeVJeUDdSFiXEiXGjXHnYElVGkWFkWGlWGiXEgUEgVGhWIiUGhUIhUFfSEeREeRDdPDdQDeQBfTGdTDTH?D;3=<4BC:DSHH_PFcQJeSIcQBbNGbSGdSHeTFbRFcRFcSGcQDaPCbPBaOC`OD`NHcNEaMFbNFcPGdQEcQIdRGbOHcRIdTGbRFaRIcSHcPHcOKbOIaNL`QG`ME_MF`ND_OA^ND_PH`NG`ME^LC\JD]MF_OE_LG]MG[LHZJGZHF[EHZHGZIGYKEWJHZKGYIHZKH[MHZMHXKHTJITJIUHGRFFOCFNCFODGPDFQFCOEEOFDNCELADH=FHAFG@GJAJMDHJ@HJ@IK>HLAFPEGULDTK>PEE[NBVJANDDK@BK@APDAUGAXJC[M>UG@SFCQDCQDI??PC>RC?PF@RH=TFC[NB^O>\KD\TAYQC]UGg[B]S@SK?XNF_V?ZND\PEYM?ODDPE?TJCVO?MG@LE=OC?TL>MF;HBRK4J?1OD4RJ7RG4M@8TF6QC6LA6H:8OA7M@6I<ZI?UH2D84D97F;7G=3D:8C<8D;9H<;J>4@78D<:OB8L?7J<4G:5F96G>9I>:K?:K>6I<,>4=NF9A>&2-0:38B74D77O?;RC;NA:H=8C87@64?45>97>8292.4-291;D2GYLMbUBQG+6-1919C84?3/1&6:/?F:;D6E:@G<7?417,04+.2)22'55'68)58+13*-/'-3)+0').%'''$)$,%-(*& '#&"'"&#'#&#(!*",$ -)!/,$/,$/,$*&%#(",%'%/5,3?43=3+/&-+-))& &"(#'!)#-'!%#)&+) )% '*".4(79,7;05>24<039.46-43*21'1.$12#14'.2(,0'/3)01(23&.-!-))%'"(%+,"')'%)'(& (%(%&#!"!!$!%!&#%#%$$!#$"# "!$"##,1)1706=5EJC=?<672-/('*!),$/1+03-/1(-2)1819A=DGFHFEMNJLNH:<6<>8AD?LQDJLAAA58:.;A47@3:A5C:?<4C;2A64@94>73>;3=<4?C9FVJF_OGcPIdPGbPGdQFcSFcSFcSEbRDaQDaQEaMD`LA_K@_JC_KC_KCaJDdLEaMGbNHdPGaLH`OE^LF^LH`QG_OG^OG_OG`NH_LJ^KJ]LI[KH_KG^KF^KD\JD\KF]NJ^LG[JG\IEZKEZLG[LK\NJZLHWIIYHIXGIXFFTFHVHJWJHTHGTHIUHJTGJUHHTHJTJGPEGMDGPEHNBFI?HI>FG=HI?EKB>E<DG=BA8BB8CA7C@8DB:A?7BA8FGTH?ODAJ>?I>APC@SF@TG>REQE?UL>SJ?TKBXK=UH;UID[QAYOB`VAbWB]SJD;GATL:XN;YL;^P8[M6YK8UG=XJ5NB6WIDk_=aU;ZO/J@<[P=]Q5PC2G;6OD5TK7ZN-K?7TF8WH5NB3E;3H;7NA;QE9MA;TE=[I7I?6G<6E;6H=7I>3E98D<9E<7F:8G;/=38F>6N?5K<5K<3H:4G<3C;8G?9J>6H;4G:5K?CXN6>90<55@88B74C6=VG:TE:M@6@75<5.;02C68D98C87?45=34=58@97C86E:5*.)/1-;@8-3)46+5;/8A4;E8>J=>K=@J>ENC8@529.07,+1'13'66*46)01'*/#+1'-5,+1((+#(( (#+%(%*()& '$&#)&)%!($)$)#*$0(#.*"0-&.+#-*"+( '$)%-' " 5=45D9,8.,5+.2$-- /,%-)#(!'!*%-''%**-.#20+)+#(+"*+ 04)7@46<169011*0-(.,#3/&33$33&+."**!-/$.0%0.%,*!+',()'+) +,!**)()'+&")%(%%##!" %##%&%#&#%#'#$!&#%"#  #!$%")(#+-'24.=@967312-),$(+")+$./*27.9<42702968?=DGGONK]\XYYSNPKGKDGNHNUDHO?BG6=D35@/8D7?G>9A63<2/8-,1%-/#23'04'.5(26*55)/-"'%&&&$"$%$&$%#$""# !"##%'"& $""! #!)'(&&$&$&$%'&) )0(2:3;C<844,04(-.!))&&''&$%#'&&$&$"!!#"'"("*"0;7X`_dhg\^\QUTUXVNOI<92('&&%*&'$$$$$$ $ "#%(&**'+&+&-$+&+%*'*),+1$.1%44(//%+) &#!!" "% )+!$$" %#$$ ! ! !"#!"##%%%#$"#! y~t~€w‚‚xƒ€y~tuuknrgjsecmbamaal_al_\j]YhZ[gY]h[_i\]g[Zi[YiZZi\^l^al^_l\cp_msbztb|m\j[zk[qn]jl^dl^enbbo_ao__o_^o^_oa^ma`nb^m_\l\\m][m[ZmZXl]Zm_Xm^Wl]Wm[VkYTlZTlZUn\PjZNiYMjZPjXOiWQk[Rl\Sl^Sl^Rl^Rl^Tm_Sl]Rk]Qj\Pj\Oj[LiZPl\So^Un^Rn^Pl]Qn_Tm_Tl]Vk\Zj_\l`\naYk^Ti\Tl^Pk[NmZNlYJkXImWHlVIkZIiXKhXJiUIiVFhTBhRCfPDeODaLD_LIaOE_MEaNDaODdQGeRFeRFgREfPHfRHfSGdQIdTCbRGeTGgVFfRFfSDdQEeTEeTEeTGdTFbRFbSEdOH`OFSG>A8>;3A91=72A95@94>:2<<3@D;CUGF_NHdPHcOHaNFaOGbOHdQFbOGcOD`MD`ME`LC^JB^JB^JB^JE_K@_FDcKC_KGaMJaMI_LF_KE\JE]KG_MG^OF]NF]MF[IJ^KG[IHZIGXIEYGH[JH[JG[JEYFF[IJ[JIZIGWIHXJHXJIXKOXMOZMKVHJTGJTEIREKRHIPFIPEFODCLADLAHLAFMBFKBEJAEH?GG>EJ?FI>FE;DB8DB8IG=BD<7:1;?4EI>BB7?=2B;3A;2?:1>8/<6/@<4HH=@E:BJCDRHCTH@QE@UI@VJAQF=HDSG>PC?OB:I=9E:9G<ME8J?=QEAYP@YNA]S?`U;WL@RI?]QCaWB`SGaTCYMCVJCTI?NFAPJCTMAULDXL?NH=JD?MGCXO\P5MC6LC;TL7[L@bVA]T6M>5F>6H>5H;4H;/C97LC;TE8QB4K<6I<2C9/@93B:5F;3E7=RECYL7LB0;54B9:E;9D86F9>WG;QE.>3-5.5<5:G<I:;D69A53=12;01<34B7:E;=F:7B66F91;0490/.),,'02*5:0?B69@38E7:J<>NACOC>H=?H<8@54<129.-4)58+24)34*-.$*1&/8,-7+(/$%)'&)'(%(((''#($&#*( ,'#'#+&!)#+% /)$/,$1/'/,$-*"*'(&)&,'&$5=28B8-6,5=225(*,45,0/))"%#&!*%&#+, -2%35,,0'(,#/-%46,3;06://2)00)/,%1.%30'34$43%..#/.#./#15&1.'(&+',()'*)**+,('*'+' *&!)#''$##!" $&'#&#+( *''$&$(&# # '$&#&"&!)&!(&!//)54.45113,),$+.%-0'03+8>2<>604/.635=D=HKFVXTQRNJJH??=IIJ__cheaa^YNMI(*&>C=AD:0.!)(&&$"$%$%'#%$$$#%#&!'")%/%6?9_hefjjfggZ^\Y[XMLGJKE45+** )+)*''''%%$%!$#%%$)(&*(-(0!(/ '-'++.,/ ,3&36+21'.,"'&'%$%$"   !"$#""""$!    !!$#"#$ "!!  gochmaopdzwnutnqrikpdgoabl^bk^bl__l^_j\^i[bh\ek^ikafl`bl`ak_gnbkodlnciobfl^oo_}qa‚m^kYzl[niYdiXaiZfnadladnabo_`n^`l\`j]`k__k^ZiY]kZ[jY\k\\l`\l_^oa]n`\n`[m^WlZYn^[pbZrbYpbXoaZp`Wo^Uo^Rl[Vn]Uk[Rj\Rj\Sk]Sk]Sk]Qi[Qh\Pi\Qj\Ql\Sl[Vm[Vl]Ri\Tl_Tl^Rj\Vk\Zk^[h\Yh\Wh[Tj\Rj\Pk\Nk\LiXKkYHjWHkVHiYIiXIgTIgTIiVFiTCePCeOEeMBbID`IFbME`LEaMEcNHgQHdPHcOFcOGdOFbOJdRFaNIdSHcSGbRHcTHeQGdQDcOBcRCcQBaQEaQE`PFaQE_NH\NCNC=?8@<6>7/<72=61A74=80<<3=C9DWGD^KD`LHaMH_LD^NGaNGbMFaME`LD_KD_KG_LD^KB^KC_LB\ID]JB_JDaLC^KI`MH^KI\LH]JH]JH\KI]LH\JH\LE\LF]JEZHFZGEWFEVHFWGHXIFWHGWHEVFEVFHWHIWHHTGHTFHQEKSHQTMPTKIOFGNBGLBGJAEFAFIAEI?EH=@C9CE=3;:0BC8::045+59/@@5<>2><1:6.95-95,85+63)<9/DC8;>3:B7@NBCSF?OA?SFBWJCSH8B6;C7BOC>J>NA>QE=QF@PG?MD;KA4E;@TH>[M=WJ?YL?[P;TJ>UL?\QC`UEcVFcVB\OD[OEXLCQIDQKDXPBYPCXL@PJ@NHDSMBWM;RH@TK?VMA[Q7PD3G?6LC9TM>aQAeY7XR;XQ:YO=`S5XIAfX3\LCh[8XK,D8;YK:aR>eW?ZM1H:5NC>WN9SC;I>3?87A9;D101%2-$..".1%,2%+/%''&))-%&'($%%&**!//$..#$%)-"(.#)' +) )''%%$('('(*!58/RTOWVP@:7$ !853LIH;86732NLKTSL@;7)'$"*$PWQVYR' & #"#""$ $&#''(*&*#("'"*!:B;]c^]caceehgh]a`fgfgfe^\XEB:1.$()*'(%)%&##"!&!$%#&%%((-,1&(."'-!%*'-+0"+4'26+-+",*!)+!'+'*'(%"#!  ##$$"!# $ !"!!# " #   ##al]em^jmbnmdllhgkccj^dk]bk\`i[^i\[h[[eYah]eh]ji_ljallchlcikblkcnkcqndqqeppdsnaƒseƒj[|lZwn[klZajY^l[_m`aj``ma[k[ZmZXhWXfVWgZVfWUgWWhWUgYVgZ^i`\f\^j__ma^m`\l_\k\[k]\m^_pc]n`]ma[o_Yo`Uo_Un]VmZVkWSkYSkYSkYTkYPiWRiXRh[Qh[Qi[Si[TjXWjYXi[Vh\Wi^Si]Ui]VjZYg[VdXWeZRdWPeXOhZMgYLiZLhYJjYGjYFhWFgVJjXGeRGeRFgRBePEcRCbNCcK@aH>_ECcJFaMFbNEdOHdPGcOJcPGcOFbME_MG`NHaOKbSI`QG`PHbRGbOGcPEaN?`O?`OC`PC`PE`PGaQF`PFYLCME>@:=83<61;61=60?62>70::2>C:FZIE^KC_KE]IG]JB\KC]JD_KC^IC^JC]ID^JD\JC[IB\I@ZGC[ID\JB^KC]KC[IF]LG\MH]MJ]JI]JFZHGYII\KFYGCZJDZHCYFEYFEXGDUGHUHGVIHUHFTFGUFFRECSEETFFQCFOCINCJLCMKGKKFEI@BE@5?@6=>5?=5?<5<=4=?5>=4?=5:=2;=3<=39;07;08>265+56,47,48,89-66)20*1/'31(44(22%55&98+:;0=D7@K=DSD=L<;MAIZPCSH7B65<1>H<:A69@5F?9E?;NFVH;PD]U<^Q<_Q:`Q;dWCi]3RH1JA<[M;eVAi[?VJ=QCVJ>XN;PJ=QH:KB8H==KC=HA8F@;JA;L>>OB9J=4D98D96D:6E99E9;L>4M>=D<6C;7B69B7;H;7E85?36@46@41=03=35B55@38?48A44A45@35<125,25,.5*5>26@17D65G88J=5D7.9-:?6;@7:>3;?49=27;/.4(-/&./'+/'1:/.<.15*),!)((('(&),,"'&(") ,&(%*$,& -&"+% .(#,'"/-%-+#,*"-+#.,$-+#,+"-(!,( (( *,#-+$1+!0,97+46./3-,+"-+#&"( +'-/$18-5@2*5(,0%*( '%)- .5'06).2'.2'11'/1$00$-* -(.) ,+ ),(%'#,(*&%%%%(&+* ,* ,* ,(*%)%)%%$%$'"$%#$$#%$'%&&&'%$"&!+($+'#$!'''$&#+( ))!(*!)+%,.'/4(-1'13*,/'+1&04,/50)3-HULiqh`ge_bcd_cc]`ZWWPPNOPOJMGKREFPAEN@>G;4D;9J@@RE;L>7G78F45K@5*)' ,'$;70-+"(&%#)*!/*%=;7[b]|„}XWR("#""$!')'((*.")-#(-!$'',&:A:>63=41=41<64<52A85<:1?F:FWGI\JE[GG]ID]JBYGCZHFZIFZHFXEEXFF\ECYGBWFDWIEXIDYIE]I@_JB^KD^LE]KH\NHZLF\LH]KI^IG[FFZGFYHEWJDWGEXGGXGFWHEVHEVEIWGJTGHQFHQFEPFCNDEPCDM@GKBCG>EI=@G@AF>AB8BA7@@3AA3@A8@A7>?6==3>?5;<27;08:1<:2>:4>;6<94>:5;;4:?44;0680;9297+66*8:.68,65,42(5.(0,&0.%32(21&42'43*6;0;F;;K>BOC6A54GK>@SGMEQH?KH@PK=TJQE`U>`W9\N5\P;NB;PG5MD7SG:ZM?`R7WI:LC:MD8OD:QH>SJ@TKCYK?UG=TF7A:6?6;C:@I@9B:=D?9C?7C?6A:5@69D7ANC@NE7IA:MEFZN>TF;N>9K;DaSYsfG_T;LC1?3%0$+*&#&#&'*0$-8(0:%07&13'02&,.#*/!..&10&20&,- +/ ).!&')'($)%&$&$**)(&&'$ $!# #"&'$!#!%!##')#8=6HJFe^[>31$ #"$%&)*'%#'$&' *+$&)"#( -1);<5>;730-;65DBA::89?83>51>63941<63B:6=;3?F:HVFJZHH[EI\FF[GFYHD[IEZHEXEBUBCWCDXCAXEBUEEVHDUGDXGDZGA[GB[HD[IG[IGZIEVHFZLE[JEYGEXEFXFDVDDSGFUGFUEHVGJVIHSHHREKTHMRHINDFJBEJBDMCENBEN@CF?DE>4>>3>>3??4?A8BC:;=49:0;<2:;18:097/;91;90?>6>>9=<7:<57=348.44-9609;/83B[M@[M>[L@ZM5L@7QDFf[9RH?RIBXNB_QEfXEaSCWNDVMCQIETKCTK@SJAQJ@TK>VJ=UH;NB;H?;ID;HC;JBbS@dVBdY>`VAcY?`V:YL9YLCdY=\Q5OD4L>?cUAiZ=`R;QE;PF:ZO7_S:_T5VI:YK;]O9^N>aS9^O6]N<_Q:XK6OB9VG9YJKD96=88B7;E;5B<4A98E97B99D;;E;8693770<>ID:JC=OFASG@SE?RD?WKBWM;NF3D8.>20>045(*)&$#%&,-5$.9%08%.2#-/#-."-0$,,"+)!+* +-"(- '/!)-#'(&%(&'&+) **!#!#%'--"+*,('$"#  ! %# )&""& "#"'&** )&$"#"&(&)$(%'*,#..'&&%$)'"#%!'%#483IOJtulUNE1#%&#%%'&&$$"#!%$''&)',!&.(-!*+ ') &,!$,#, %.#3:06>4,1%#(##$"!!"!#!$"  "!!#&%+)1$'-"(+$VdRWgUWgWVfXWhYXi\VgYWfYVeWXfXXhZ[i[_i\fobinalmaqpfupi|tmvo|uo}yuzs|vo|un€uk†uh„k]l\zm^mj^klboqgppfgpfdpd`oc`pa`oa^m_\l^[k_Wj]Th[UkZUkYThYWi[ViZViXTgVShTTgXQeUTfWTeWTdUTcUPfWQeWPeSSeTRdSRdRQcUSdVUcUXdV]fYai\dncdmedkd`h`^g][cX[dYYbW\fZ\h\[g[\i]]f[ZfZVgZTgZTh[Th[Wj[UiZOgWMgUHfRFdQHbRFaPD`MD`LFbLC_HB_HCaIEaLD`LC_KD`LDaJD_KB]JG_MD_LC_JC\JD[IG[IHZIFXGH[JI\KF]JD[IC\IE_KD_KD_KC]II_MH^LI]LJ]LE]IGXIBI>?<7=82<61>52830<63?73=;2?F;DSBHXDHXCEXCEWCEXEFXGEXGEVCCTBCVCAUBBTECRDETFFUGBSEFYJEZFFYGEVDEVEGUGFTEBUHFXIDVGFTFERBEQCFOCFODHPDKRGIPEHNCJMDNNFONFGHBGGAFGBBG>DK?EJ=BC:@@8BB6=C6=@5<;1;9/<91<:2?=6@?776.98.;;198.98.87-86,<:2>@7:<4=@7:=47:147.42*:4.8>38@55@QIBLG4;61>5CZL[M8PD:UH:YNKC;KDWMEhZ@iZ;aR@dV<^S@aW?^T:YQ<[L?YMCZSdVUK\O?]P>ZM6XJ9UH>VJ=TH=XK?_QZM@WK?TH;QD@SHIE>FD9>=:@=8@9;F>7D9@ME>KC;F<8E==JE5F?6F>7G?5D=7G>;K@;K@9L=:PADWF;J;8B56<16<17<246.38.6?38F99K<6J87E74A57@63=3*0&07+5>35;215,,/&36-6:0/5/04,2://=1*8-)1'(.'+-'))#'$&$((&%&"("'"'#,*&+& +$(#'$)'!))#+)!.,$,*"-+#/,$/-%1+$.+#(&)''%'&*&*(/.#*+"-.%+.$+%!+-#-4(0<.09-.5*+.%,,#(%&!%%"&"+( ,,!21'//%10%3.#4.#5/$-+ *+-+ )'&$(&)'(&+&)&+))(+'+&.(#3-&1+$+&)$*''%&#(%'%"$!%"& $'!12.DC>C@;-(%,,',*%,(#+(#-)%*)$/2)03*.2(/3(04(-2%37,9=4EIBJOHDF=9:0463453;<:STRMPOKOKSUV[]\Z_ZVZURVQMRNFLI=E?=HA3A52A31A038)/3%('!!$'+2!-:&3>,6=.37).1%,-"--&,+$,-$,/$*1%*4')1%!&(*.-#-+!+)))#'#'&*-,",+ /*&##!"!!"!!&$$# )')((''&('&(')')(()))* *+!)+")+#(+#*)&-1,IOL^`[MHD:-*$&#'%(%$!%#%#&&%&'*$+'*+,"() &+ (.#-6&09*,4)(/$%*$(( $$#! !!""!#!! !!%%+ (."%&*+%VdSVgUVjXThYSiWUiWWjYViXSgUThVViZYi[\j[^hZ^hZfn`oodtshyvn}wpyrztyq€zs~woƒwn†sgƒj\lZzn^ql_hh^gj_hj`ah\cj_`k_aj_`i]bk^cnaal`^j^[h\[i\Zj[\j_[i^\j^[h]XgZXfYSfWVgYWhZXi[UfXVgXNgXQgXNfUNeSOeTPdROeVQfVPbTQaSVbTXcU\dY^fZ[b[[c[YbWX`UW`VX_VZcXXdXXfYXgXZdXVbVSdWTeXSgZSgZTgXVjZQgXKeRJeSIcQI_PH`PFaOFbNFaLE_HB_HC`IEaLEaMC_KD_KC_IC^JG_LE]KA\IC`IB]IE]IEXFFYFEXEH[GGZIF[IE[IB[GB\HB]ID]HD\HG]IH[JI\KI[JG[JHUHCG>@=8;61<72?63;63;41=40;:2?F:ASCEXDEXDCXBEYECVEHXGHUEHTDJUFGUFETFESEEQCGREHRDHTFGUGDSCESDHSFHREIQFFNDCQDERFFRFGPEGPDENAEJ?CG=FI@IKCJKBGG=JF>KGALHDHE@EE?BB<@D:@C8@D8>?6>=5?@4<@4=@498.75+96.:81;:0<;1:9.96/86.64,65+76,54*97/<>5:<47:19<326-44+2/'61*=C8=E:8@517*25)//#1.!/-#/.$.+$-)$-'$,*#.)"/+#11'4<05B65>033)2+&4)%/)%'$ )&'&))!02)/.&/+&18.7<3+,#-.%/3**1'0B7CSJ>F@8=6*6-KbT=YK;[LDaT5K?9OC8QF;F>5F=QHCWNDXODYPAYOF\PIaUD^P=VH;PE>PG=NF>QG:OFB\RBeZ=eW>cTBeY?aVBaX=ZS@[U>^Q=YOF_V?[R;_S>bV=dU;gW=`U>VL@VM;\Q=^W>^V;[P@`U>bTBfVBhZ@fW=aT>aS=]P9WJ:[K:_O@_TB[Q>UJ\OA]P@\O7ZK9XJ?[N>YLC^R?^P@_P;XJUJASG?PD=QH?SJ=LE>IECKG@HC:G?=LE?ME>JE;G=8F>8HA7G@8H@:JAMB;K@;OA@WG@RC9E87>16:/8>33<053+48.1?1;L>CVD8J97D78A68A69A6)1'4=04=33:0,0'./&-1(15,050.2+2:/,:.&4(+3))/)'*$'((&-+#'(%!&"("&")& -.$-%!*% '#)'!))#))#+)!,*#-+#+)!.+#.+#0,$,*".+#-+#*)!(* ($)&*)-,")*!**!.*%/1'.7*-7*-5)*1%+.%'*"%'%%" "%%'!)%+) ,,!1-"2-"2-"1-".+ ,, ,*)'(%'$)')'*%*'-+!-+!*'+&,& 3-&4.',(($)&&#&#&#$"!%#('+%-0)./+32.2.*1-*77221+,)%+(#+)$+,&03+69/59.37,26+6:/>>8::7:7DID^_afhifef```edeigihiecea[aZcjcBNC7D:4?76A90;1/:/2=//;)/6'.1$&($$#&*--9'7B0:F307),3&+0$-0'+.$,0%*.#*2%)3&%.!'0#+0'-1(+, *)%' $$(%)%%+))&% $"!"" !&$($' &$$#%#$##!'&'&&((*'*(())'(*+!)-")-!+,$*+#161;@?DJGYWUdYV,$!& %"% #$% %"!!#$&**-".0'34+/0'*+!.1%13(46*24()+!)) .,$0("*"$  $#$""" !! !!!"!##""&%) +-%**$VdTUhUVkYQhXTjWTjXTjXUkYTjXShVRhVUhVTfUYhXVeUXhWcj[imampeuujvulxvmzvnzwn{um~rioak[|kXym^pn`hj`bi_ai_bk]^j^]i]\i\\hX^jY`i\_j^]g]YdZWeXZgYZgYYeZ\h][g][g\\i]Xh[Xh[Yh[WgZWfYXfYXhZXi\Wi[WhZUgWUgWTfXTfXTdVTcUVdUWeW[eV]fY[dXZcWZcXYbVX`WXaVU`TSaURbTQbUUaSScSNaQLaQMcRMbQNdULbSLaRMdQJaOKaOI^LI_NF^ME^LF`JF_GF`JFaIC]IG_LE\ID\IE]JCZJG[JBXHC\IB^HC]ID\HFZGEYFEYFDZGF[IDYGD[HC\HA\G@\EC\DD[EG[HEYFHYIHZIDVGFQFCE??<8:54830<3093093/;2/:91@F;FUFHVFIWGGVEHVGGUFLTIMUINUJMTJIRGIRHHOEHPDLQEKPDJPEIQFHOEGNCEKAGKCDH@CG?EH?GLCFKCGKCFJ@CHB9>C7>B6<=5<>6<>2;>399.;8.75+86-86-98.76,65+42*53+52*24)43)43)65+77-68/57-::232,2.*2/)74+:>5>C8:@43:-69+01"/-"/.$,,!+)!,(!-%!*$ )% *( ..&46,25*/-$*',&2*%/)#)$(#)$*&.,$),"(.$5?5;B8%'-/&05+(;M@AQG:C::@79J=FdS@XK>YKBZN9J?6G;4F=6C;:PF@YODXQCTMEYRE\R@WMBYOAWNDYPCZQEXQI`VA[OcV`T>bQ@dV@aV?YO@YMHD8E>8H@9F@>GA;IC:J?>OCE:=I<::149/6B6HYK?L>5B19C76>44:017-09-0:-2=35;213*-.%./&,1(+2+/2+/7-+7+)4**/&'*#$'(&(&.,"&%*!)"("'#''++"*&!'$&$((!+*$*'")&".+&-*%*'#+'",(#--$/-%/,$.,$-,#*+!($ '#+(.,"+) +,#1-(..%.2&,2%,/$03(,,&#&!#) (,#''#&%%(!)&)(.)1.#0-#-,!..#-.#-+!)&(%(&'&&&*&*(*)+(*&+%*(.-$0/%+) &%&$###"$"&$"%$*!./)/0(00*--'*)%1/*44-/-&+("*'!%&+,%03-8=55;106+28-46<217..6+-5')2!+/#-0#))#$$''**3"2;*-9(*5$.7).4)-4*/5).3()/")1")4$/8'/8,.7-,2(+/#'(%%%&), '*'&(%(')'*&%!$! &$+)!'$%$ #!%$$$$$%$&&%%))()&(&&++!&''('((+ '+"+,'')(064DLIadbtkk:40$$"!"  $% .2*6;035,12)670/.&)',+!*)",+",,#)('&)'"-)!+'&"! !" $!  $%$$!   !$"!!!$')"*+&()#YiWWiVVmZVm[UkXTjWTjWTjWSjWRkXTjWTiWThUWjWXlYWlZ`jZbm]dl]gnakpcmpdqpgqqgurgzqdpa€l[|mZvl\ll]ci^`ka_k`[m][n^Xl]Zm][l[[mZYi[VeYUfZUeZTeYRdVTgUQcRTfUSdVTeVVgZWdXXdXXdWWcVVcXUcW`g^bi]ak^ak^]h[]hZ[gYZfXZeXZeXZdWXcV[hW]jYZgY[g[^j]\h[^g_\e]XdXWdXTeWSeUWgURdSLaQKcQJbPI`NG_PH^OI_PLaPL_NJ]LJ\KK^NE[MD\JE_IF]FE`IF_HE\GEZGEXEDWEAVFBUGBTGBUFAXE@[GBZFE\IEYFE[HCYFB[GCXGCZG@YEA[G@\F@^GB\DBZDDZFFYGFYHEXFEUHENECC??;9832722;3082/930;3098/?E;IQELUGKSEKRCJQDLRFNRHPRIPRHOQLKNGHNGGKBMODMNBLL@IL@GJAEGBBD>EGAFGADC?BA=EC;FD>BA=CB4992972=:6=;4=;1;5/<:2;>4?C::@7D8=D77:1;>58=09:088.86,86,75+54*64*64*64*63+52*52)15)25)76,64*65+87.87-;8252-1.)21*45+980:<27:048+27'-0"0.$0.$))+(!-( +#-# )% ,+%02)//$*&+#'"&%,)!,( *#($)!/$+(!',#0=27C;181)-'14-*0((1(;M?XL@\O=YLAVMTQ?YU@`Y@aW>aR?`PDg[=dX@_UDXOGYRD`XCfZAf[?eZBk_BlaGqfKmbGj_BcXDf[BfZ@dWBfVCiZ>aUC]TC[P=YK=TK@XNA\OC_R@[OA[O?[M@bSAgU@cT?[L=SE>OC?QC:NARIAUHDUJ9J>=DB5E<7C<;B=>G=9H=4E:9C<59478/9<3AJ=CPC<;406-4@57E9+6)19,2<1;A827.27/2;/2>/3?36=213*34*/2().#)/).1*06+)4'&1&&*(+"('+( -+!+)%#*'(!&#**"(*!(#'& && +*%,)#+&!,*%-*%-*%*&"*% -)$*/%,-$-+#0-%0-&++"*&#)' -' -),*!-.%,-&,,".-"/-"11&43*+'#('"*-%(*!*'&&'(( '"('-'.*!,+!,,"*+!,-#)'(&%#'%&%''(&&$%%)&*%*#''+* *))(%#&"$%$%+)!)($&$(./%-.%+-#,,%/1*13,0.$*()&'&(* &+"+.*.2-.3*/6+4919>7=@=@C@]\[igea_ZJHC:82XXVdeg]aaUZWehdkjadc[SQKIIC89258042*&#,)!00&*,!28.6=0/5*/3).2')-!',+-",,",+!)*!%'$)-2".6&2>+4B10;--7++6(.7+3:,-4$19)2<)6>/7?209//8./7*,1!,+"++)++*(')%'(#(+!+++)$!(%)#%!$ $!$"%&$&"%%##$"$&%(()(#$%'&'%&() (*!+/);<6=@>DLIW^\_eaicbIB@)"(" !.0,BH?17,,+$,-%//)+*"-+"-+((%*+&)-%%) %)!&)#)& (&#!""!""  #"#!    "!!##& !%!$eh\ci]^k]Yl]TiYWkZTjWRkWRiXRhYVkWVjWSgTRgWUkYWlZXj\YjY[hX`k^`l`bq_dmafl^ln[xq_}n]kZ{kZskYfiY]h[Zh\[i`Yh][l^[l[ZmZXn\SlXWi[Wk[VlYTjWSgWUfWPiVPgTNfSNdQOeRPfRIaOPeSQcPUbSXbUYbXabYgg^hg_jj`_eZZbX\aTZ_SY^S[`U[aW\aXbfZdf\gh]gh_cg_bh_gmbfmacma`k_^i]\h\]hYYcWU`UR]RS`SO`OM^PL`QL_NN_NM_MI\IL\JJ]JD\ID\JAYGB[HDZFC[DE]DCZCCXE@VE>PB;N??RB=SBBYGBYGDVFFXGEYFG\IF\EGYDEZDEYECXFCYGBXFCZFEYEHZHEVGFVGGUHFTEFQIGKDB@:?84=5191093092.93.82-:7/FD>KMDJLCGH?JH@KJBKIALGCMGBLHDJLF@E?DF@IG=LJAJIAKIADE=BB9BA8DB9BC9C@8A>8C=8A?5C?6D:5?74B>9@@7>9474/85.:7084,82)62)51+50,<73=82<:0?<7@?9?A85:19<369/::.77+76,64*64*20(14$25%34(43(82)80)20(85-45+56,9:079.9:087073/40+30*64*97-98.76,65+52)10%//#--!,* +)+( )%.$'("/81:<70,&,$'+"*!0'$-$!+$&")#.(**!+4)1A64<2)0&.4*28-&1%1?35O@0B:9I>;RDHcU8ND(5-?NFG`U@aSFaTDYME]SHaWCXN8NFC[S@XOC\RE^T=VK?VOAXP>WN?^RHi[DgXDd\Ge^CaXA[QAYO=SI;UM@[RE`VCaUdVDfXCbUE^RDYM=QG@QG>OEBSH>OGTJAXNB[QD\PASF;NCAPF>H@7A95@98F@?TI?QG@PFBNDAMB;I?J>;D:9B:7A87?57:15:.=F;:D826125047103)-0'34*2;0FQD=G;3=15A56A57=518.05)15)13(-/$(1)%.'/6/,0),-(,,&..(''"+*"*(!&$$#' &)%*)*-"&-"&&'&+)+)/) -)!),#*+%,+'))")&*+,'#,)!./&55014--2%--#/,%/*#,&,( 0,$+.#,+"/,$0.'04(-7(+/%*,"'&)&&%$%(*!)#+&+*-,".,".,"/+#+( *()'(&(('&&&&#($*#,$)%'#+)*()'))''&&)'(')& (% **#)*!/+%+'#))$,+&-+'-+),)!*&$#'&**)-"-,$-/%13-7;5HJDFGA966HJJjjjd`aHCDMKLVTQTRQVTT^]\]^]Y^ZXXUJNH=A;788@=<74-/,(/,(/-&1/'46-,2(13'.1%-4'+3&)."(, .-"++-/#16(-4%*2$*0.6%1<-.;--6+)2(,5'18+29,.7,/9-2>23;56?7?I?A6,+!-5,8>4:?6,1(',%'*$'' $$"#  " ! $!%"# ohZmi[dgX[bRZhXYhVVgTXiWVhUUhWXjWYiWYhVWiWWhWYkZWk[XjXXhU[j[[l]\m[^j\cm]lo\up]p^l[ykZrk\eiZ`k]\i]\i]^i^^i]`l\^iY[jYWjXXhZYj[Ym[WjXVhXWgYQiVOhUOgSOeRNeRNdQKdRNcQRcQWcSXbVZcY[bX_dZaeZ`dZY_SW`RX\QUZPU\QT[QX^UYbX^cXaeZeg]cf\bh]ai_ei^_f[bh^dlb_i]ZcW\fWXaUT_SR]RT`RQ`OM^QM]PN_NM^MO]MKYHKZHH[HFZGBWEBVDDXFDWDCUBDWCAT@@QA9I:8F89J<>P@AVDCWEDTCGWFHYHFXEGVDHVCDXCCVDBTDDVHDVEFWEHXGJWIHSGHPFIPDLQEKNGHICA?9<7482/:3060.82.81,93.:60EC:NNEHH?DB9EC;GDDC>BD?DC6;8/?91@>3B;3<4.;2.=91<:1:5173/74,95-70*5.&3-%3+&4,(6/*92-70(94/:8045,33+55,54+;:.43)32(75+52(0,$1."31'42'31'4-&2*$/,$20)44*56,89/9;/76-41+50+4/*1-'63)54*76,43)65+32(0/%/0%..#-+!-,"-' ,%0)!.2*CKD;=74.(-%+#+#*"/&#.&!+#*".%0) /,#.4*5C809/)0&3<21<0,;/5E97OB9H;4;/@E:=H<7H;;J>7B66@89H@1E;=PE>XJC\N,;2-6/BRHB`RBaTKaUDYMH^UIaWAVLYP@ZR@[SA\RGdYHfXA`R>]SA_T:VNB[RBZQBXPA[UB^VC_VBaV9WKA_RFfX>_RA\RCZPBZQCbXFl_Eh\AaVAeYEl`CobHmcDcZHe\IkaEh^Hi`Gi\CfZ;]S=_UEcXD`TCZO@XLE]QC[PAYQD\VDe[Ef[B^SD[QFYPCSKBSGDUJ@QF@QH>OF=NF8SEAWLEYPE^TJaVHYLDWLDSJ=G@9B;5@::HB>SGBTICSH=LA=LBNG@NE:E:>H=8@68?79A87=38:158/8?37@438014-03+-0(/0)12*5<.GPAAL;8D5=K;>M=370-1'/3(26+.4(+/&/70/5.,/)+,&,+%.,',+%,(#)' *' '$&$)#%$'(.0&/1(%&)()')()')()(*,#,,$,,%''!'&)(*&#.+%??9;:767236,12)22*42*0,%,*"++#0/%0.%.*"0-%14(08)/2(++#+)!)%%&%&) -$)$.(/-"/-#+)*(*' )&'$&$)&'&)(** -*!'#)"/(!-(!)&)(** +* ** (($%+)(''%)'"((!(* )(()./$13(++"+( *'(&%"(%)().!-.%,0'4719?9HKF<@::;;QUUcgfb``UQR_``eca[YYTRSTQROPOW[ZX]ZT\VPXSX]]Y[ZMKFHE@?<430(53+57.16+46(36)5;.7=019+.3&24)15)/2&06'16'(. ).+4$.8('5&*6'0:-/9*1;+4;-+3%+3&-6),8/8D93?4)3&*3&,1#,/#+-!-/",.",-!.."+*!%'#&#!5;4HGB "!" $#&$*'!*$%$#%'$%#"%)'*((&)'10),,)DKKbfelpofkkfjhd`^RNMPJEJA:*#&"$#""! "#&'((&',/&16.7801/')$3807;46;215-),"&)$&#$"# !$  !  !vgZvj\lfXcaRdeVdfVdhUajV_iX^iXbiXbiX_gV_iW_jX^iX[lZ\mW]lV^lZ]k[]mZ]l\_jYhkYsmZ~n\jZxj\piZaeV\hXYeVZfV[bX\cX\fW[fVZeUWdVXeW\hZ\j\Zi[WfWUdVQgTPgUPdSQdSRfRMaNJcQLbPO`OUbTWaTWaVT`TS]RXaUT]PT\OV\OV\QT\QSZOS\RR[QQ\QU]QW_TYaTYbVU`PT]NT]QR[ONWJP\OMYKMYKMZIN[KMZLMZLJWHO\KHXHJ\KJXGJXHIVFKWGHVDEUCCVCCUDDUDDSBFTFCPAAN>@M:G97B58B5=H;?L?CSCBTCDUDEVEEUDDTCEQAGRBEXEDVFDSGFSGGSFITGFTFHRGJRHJOEJLBMMBMIBFDA>6?<4@=5DA9@>6@;4@<4CC:AA9?:4;8.=;1;:/>;4;6361.73.85087/:8/;8-;6+:7-;3+90)80):5/:8082+83,20(41)3-&2(!4*#3)"4*$5+$7-&5+$3-&40'30(0.$0-#51(75+20'/.#4.'1,$1*#3(#2($3,%5/(1,$1,#-+#0-&42)55+56,57+54*3/)3-(5+'3,'51(21'31(32(32(10&/.$.0&00&.,"/*!-'1) .,$8;544/4-(/(.&/'!.%!1'$2)$.&-$ -& ,')+ -6+7E9'0&-5+2=21?30B51E8@SF4@4.3(49.;F:8J=6C84<25;48F>3H=;SG>[L/B7,4,)/(@SI?aSB[NEXMFWLE[RI^TGWNCZSG_VE`UFaWB`U>\PA^VBaWDbWF`VD^RAZM@^RB_T>WNC[SBYTE\XDb[CbZB^V?]R=XM?[N@^P>]PC_RG^R@WNGdYHmbFh]>]T@aWCj]Bm`GkaDd[MkbHkaHj`Ji`EcZAdZ=_U@bXHf]GdZD[OC[PE]PAYOBZRF]XOlaE`WBZRCXPKZS@NHCUJDXLATHBUL@SJ>QH;RICULASJDYPAXNGYPDRL=KF=JDQFBVJHXMDSH=J=;D8;B88=45=58:478/8909=48?48>338-26-03*12-32,39,BJ=AK>9F7:G:>L>11).1'-0'-3(-4+08.48304--/)//).,'+("+(#)'"+(!(%&#(#)$%'%.#07-//('!(%)&(&)'&'() )*+,")*!''!&& ''!(%#0,(983;9955125,,0%01'22)23)**!+,#00$.,$-' -+#--#-1&--$++!*))%&& &"(!,%-(,&*(,*+))'(&*&'$)&(%(%'%(&+)!.+#&$'$,(!(%(%((+* ++!)* $%%',*'&)'!+(#'(!()**+-!,."+-"*))')''$(%'$)) *,")+"+.'06/6=6=C=FJEJOMZa^digihfiedbcbkiimkk_]]MKKKLL`ecfijdkgcjhhjnbcca]ZVTLC@8.+#42(56,26+36%29(7<,4=-6>-3;)6<047+.2&14(03%+/ %,(2"0;+.;)1=+3?-0<*2=,4;,27(05&06)08-3823-  !"!$#$#%$ %"##'#*&!#%)'-+"/+$A=9>>:;=:X^^[]]UXV[^ZZZULHC;85.*&-' *$%"$$' !!" $$/0(58203.00,.+%+'!2,'59448305./1("#%%&%$$"!%%$$""$ ""# ! ! }l_yj]siZsj\siYtj\rk]soapm^jjXpk\ni[jgWjhYhiWijWajXclUflWhl]el\dnZajZfj[jiXukX~l\€gXvh[nfWdfU\eTZdS[dTXbVZeWYdUS`PS_PQ]PYaU\dY_h^]fZYdXUaTRcUSdTQcRN`OOaOOaNK`NN`OO\NR\OS]PT_QN]NN]OO]NR\OS]MSZKSZORZOPZNOZNMYMKXKNXJLWJLXJJXGKYHLZHJZKJXJHYJEVHHYKEVHHVFFSCFSCGTDHUEIUEEVEGSCGTDDQAFRBGQBFTBFUCCSACRBEQADO?EMACL??H;@I<2A>7A>6>;3=:2=92=:297/<4.;5-:7/96/>8075+:5+81+70)60+5.)40+52+64-87,85*72'4.'2-%5/%70'93*;6,60)4.'/,$.(!/(!3)"3)"1' 1' 1' 3)"4*#1)"0)"0*#/*!-'1) ,)-) 2,#2+%-&/& 0" 0%"0'#2,%2-%0+",)!-*#0/&32(43*57+75,2.(2,'3*&2*%3/&31'44)65+43)/.$/.$01(10&-+!/) /'0(-*%14-440/+&2)"0,"/*!0*#,&!/)$0+$*%*'(&)-$06-1=24B6)/%/6,/9/0>12B66G:?H>.4+..&13*5>44C88F;380,/*4@86K?AZK5NA-:0/0*3:3?TH>\M>PEMB?OD68>349.58..1(23,44.37.7=5>G>.9/;E;:C:DF=23*+.&.3*2;15?4593+.(-/)--',-',)#-*%(&!(&)&&#(%(%(+!+3'*1')&#+%"'&*( '(() &(%(&(()'( &'&& $$)%$.-(43.643GFA>>5/0&33)27,,0%(,!-.$/.#0.$1.&.+#*) ,."(* ,* +* *'&"%%#&#'&(&('+),**(*((&'%)&*')&)&&$'%(&)&'$(%(%'$(%'&'&)($%%&)* )'(')& )&!%&%&+)--%,-%()!**"*%!*) *'(%(%)( '(+.%/3+1704;6FKHjmknqoelidhfnmkolkkljkiipnnTRRDBBOPPjonihjdfdbddfcgworulh62*<6/60)/-#/.$/1&-4"05%39(6<+3;*3;*3:+06(.2&02&12&01%&.")2$2<,5?.5?-9D07B11;)38)36'25&24'25(56+45*33%-0!,-(,"&*#%$$'&'%$$&)%'%")(#(## #"#""#! #$%("20+:61'%%'"0/&75-63+2/* !021=CB887964651;;53/($"(%!'#)'$"$#% $" )*$26413121.-*&(# ,*$541351)-'=@6:9/'$$##" #"#!"!" "    ! "‡vh‚pbzi\|k^|i\€na‚pfpd€reqd‚pc|l_xjZuiXqgVqiVpiXrkWrhWrj]sj_pl\qj]qk[vl\~q_k\|cVxhZphXgfVcgW`fUbeV_fZ^gX[fW\eV\cU]cW`eZdi^cg`cg__g\YdXXbVVaTU_RS_OTbQQaOQ_OS_PT^RV]QS]NR]LKXKIXIGXGMYINYHQXIRWLU[NPYJMXJKWGIXGJYFHYFEXFFZGFYFFXEFXGHYHFWGDUDCUDDUDGUEESAFUAET@IUCEQAETBCTCDTCEQBDQCFRDFUCDTBBR@CO?DO?CK/9A3;F9@M?APB@P@CQCEQDEPCGQEHSGJSGJQGHMEGLFHLCGLBISGJQHJPFKNEILAHI9593060+71*70)7.+7,,3+):2-;9/=:396.85-97/99187/82*;1*7/(3/(42*5/(60(4.'2.&2+$2+#0)!4/'20'32'64*61'3-#0+$/)!1,"4.#4-$5-%3,$/*#+%*#,"-"0' /&-&-&0(/&.&.( /*!-(.%.&-'.(!0)"0( .%,"- ,",%0+$.,#,* ,)!.+#0.$32(54*88,55+2/(0,'2,'/*$2/%34*56,23*-.%-.$*,!2/(31).+!,'/)0(+&!,*&.,)/&!0(-)/*!1,$-'!/)#.)!,&)'''!14/6;3/6+,4'..&*-$(/%0:.;E95>257.,-$/,$-/&09.2A6WI-=2,0)20+-6.>REXO?YPEaVFf\A^U@[RA]VDb]EgbGicJleEe]GcZD]T@XNB[S@^VCaXGbXC\SCaWDf_KmfJkcEj`FnbItfImfLleMngLohMlfRlgMpiIncLocNodOjaOf`Qi[G_SG_VE\TF^VJcZK`ZMd\H`XG_TFXMHTIBVJBUJBVJ?RI@SJBULASMP\UNYPETL?QI=NG;KC;OGBZOC\PCZNCXKE?AHA7;=79<39;35<238.6;/14*46,23*25./5-8B:5@78?77:3;>315++/),1,292/8.-/*,/)+-'.1+,-',-'+,&()#*) '''%(%*'"('")*"&((& '&!*+"&)(* )+!)+"() +(!('&'$%$&'("'%"+,%,,%420GFA56,;:0;:125,(+!-/%*+"01$55*87/32*++!((**,+!,*!+)'%'%&%)'** (((&)'+),* +(+))&*'(&)'('&%'&'%%"'$&%&%&#&#(#'"%"&#&#(%'%(&(%(% &''&,)!2.(**#,,'+,'+*%,,!/-#.+"+(*&)) )+!02*04.=9HGDMOM_cbcadceddddjfiyy]RO3-&:3*4.%0,$0.$12&49,5:-37*48+27*09*38*38)26(14(35)02&,3&.5'37)16(39)3:*2;+07)/2%,/"/0%+-"./#23'21%))&*&+&+ (-#&'&%'%$"%#%'"%#$&!!! " ##"%'+#GE>B<8+(#*,'76-42),*"!"#& ',(+/+('"&")*$44.871,-&22+EC?-)#%"#!$$%"(&$9=;GKJDC@;<8/.) !))".1*4:1680($' !!            ‰rh„k`„j`ƒi`…nb‡nd†meƒjbƒkak_„l`i^}gY|hYveUwfUwfYxfVyfUzf\|i`yj_wfZzj[zjZƒrb{eV{bVzhWrgUlgXefVeeWffXeeZ^bU_eV]`RadVddZfi^ii_ihchhb_e[\eY]dY^dXX_TXaRWaQWcQYaRX^Q[_UX^SV^PR^LP[LMZKJYHLZIMZHPZIX[MUZLQYHNWFLZFKYDGXBEXDDYCBXFCWDDVDHUDGSCEQAEQAEQAEPAEUEDS?ET?ES?FR?EQA?Q?AR@BRABQB@N@AN?BR@AQ??O>CP?CM=AH9?F7=D6=D7=D7?F5=E39;-4:+6?.;E8EM@INBJNCKODMSGJRHLQFKNEGKEBGACGADIAIK@GH?II@IH>IG;FE6?C8?>6?85<0-90,41(7/(8.*7+*6-*:2-:7.96/64,65,9:1?A76905+&7+&8.'0.&43+41)2,'/)%0("0)!2*!0)1-"0.#0.$1/%5-$1*!2+&-',(/)0)1(/(+$)$'!*+ ,%.',&.(1)!/' ,&*%.) ,'/(1)1+"4,%2*#.&-#,!,#*#+',* ,) ,*!,( /,$/-#10'33)76+35+0.'.+%1-(.+%54*23)01'01'/0&-.$+,!0+$3.&.(+&,'*&,% -&#.'#/$ .%)'+&/)!.(!1+$0*"*&,&,(!21,53.//$*'-+#() %* 28-8=2-/$+*"(&+'*+"%/$1@5HZO181&%292BUH3L=(1(1/*30++6/8L?4BNBAPH=JBCKEFVL@RHAVKF^VD\TA[SG_VGaWD_U?[Q?]REdYDg^@^W@[VB_YFhaChaFjeJmgIhaFcYD^UC\RBZUA^Y@`XD`YB^UCcYEibNrkHleCi^EncIuhKpgLmfKmfJnfNmgQkeJpfOtiMqdQqdPj`SiaRiZKdXI`XG^VG_WIaXI`XLd[Ke[H`TFYLGVIBWKG]QG]PBWNAVM@VLFTQLXPJSLKYQBTLEBAGCBKEAID7?89A:6<547046-27025,6:/37,57-14'29,=G;BNB3?228,25)3:--3(+/*-3.060-5++1*)/(+/),0**-'),&(+%')#$'()!'($%($"'#'#($''$& &*##'!$& &'!'' (("(%"+("&'%&() )+"))#*+"*+#00+23,02%74*99-8:-05)13'..#.2#14)69025+++"(* ,-!++-+!+)+)*'*')(++!)* *(*(*(*(+),*!($'%*(*('&&$('('&#(%''%%$"$!'"%%& $"$"(&+*!*(",)$*+#)*!1+#-*!,-"03*?B926-+-!**+*+))((&)( -/'562=@=KJJKIIOIHHGENNMVSRVUT[]\dbaee_ZZTRRLTXR_db_cd`gedjgillnjja\TC;4,%/(/).,!//"/5)26*.0$.1%-3&.7*37)37(/4%-1%,0$.1&)1$-0%--"+, +.".2&,2&.1%+-!,+!,-#&*&, .4'.2&(."#, #/"$+ '-")+!+* '&'%(&&("$# !#!"" %*.$54+2,%40+/3,..$''**(* #' &!$'!$!%!&& '*$--)&)<=6ED@7400,(&"(#%#!!:@>HMI_a\ghcJMGLQH>?6+-$#!'! "!" !! $!"! !! ‰qe†o`‚k^„ma‡pa‡sc„paj\~eX~dX{bT~eV|dV{dVxcT|gX{fW{eVgX€iZh[~hYi\„k\ŒtdŽzjn_xaT~gXxbSr_Qp^Sl\Sm^Wj]Rk]Pi]Pi\Qh]Qh]Ql]Vl_XlaYhaYf`XeaYecYfd\cb[baYadYbeY`b]`cZ`bV_cT`aR__SU\SR[PPXMOXJRYIW_NZ_PZ^PUZKRYHOWGLVEFVHFYJEYLCXJCVHBSEFMBFPBCQ?BQ?CQ@ERBETBER@ITBHQAGQ@GP@@OB?M@AMAALA@MA@MAFMBAJ?@L@?J=CI=CF7C9AH?CKAGODHNEGNEIQGJRHHNEJOFGKABFDH?CJ>@F:AD9AB7DD8EC8D@9C;7A53<107/,3/+7.*40(2-&5-&91(;8.88/77+:;/=?2AC7<>4:4+2-$1.$30(44+/0&1)"0' /' /' -' /(!2*','"-)#1-%4+%3'/' ,&,'+$-$0#."* ' (* ."+&-'-'/(.) ,(-%,$-&/(2'1'4*#2)!1' 1(/&,#/&+&*(+)+',%/'0)#/)$2-'0-'53)41*0+(1+)3.,0,(1.'43(0/%10&.,"-,!*).*$3*%1& ,%-%.$*$-& /(+%,%+$.$-$.&2)"1)".&-% +% .*%,(#)$,& )% *),* 20%1/$*(*&!-$ ,!+(#"+$9NC>QE24).+!-8,G[N1B515,.0'.,$25,8@6:E;9A:8@:HC>EBAHB>FDNUR;@=>F@CRH>OE9H=6=358/66-64.32.44/58./6+2;0:D8=H=BG=>G<AG;>A39?07>.:@1@F6?E6?F6A7=A7CG>DG>EI@CG>DH?EH@COCHSGEOC?G=@H=BI>?C8;?4:;1>=3;:/?=2?>6?;4=309./6-,3.+6,)3-*1.'6,'7.(94-65-46,8<0;@4;C58?496,51(1/%2/'0.&-+#-%.&-%-%-%-%2,#0-$-.%21(20&/* /& *%+%*#-".",!* &!) (+,'/)-&.'-','".&,&-'2+#/'1'2*#0(!.&0) .'-&.&-'-)*))%(#+%/)#1+&3-(.+$/-$/-%/-%1.(42+1/'10'1.&1.%0.%/,#/-$,) *)!/)!-& ('(%.&-& -( -'-&*#+".$*",%.' /(".)"+( ,)!.,$+( *&*#($'%*(.,"+)(&*&",$,&!&$1<5CWM9E:24)'(=J>EYK1?217./1'10(,.%17->KB>OC:PBAYK?TFATJ>SLCbVKe[H`VD]SGeZIj_AcY@_VDbYDf\Ad[FmbKphOpj?YUH_[G^XF^UHbXGe[Ee^Ig`Hf\Dh\Gi_LmdGibGhaHlaLrePlbNh`QlcPjcJc[SmcOqhSskSogUlfPf`VicSidPg`RjbSjbSe`P`[J[XMaZMb\I_VEZPI]QF\QD`RCaRB[OE[TBXUETPGVNJUKGSLALEEQGDZKAYL@XLD\PF^QF^RAZL?VI=OC>ME>JB>EADJCELFBIE:>9:A;=K@?LB3=2/3*75-96.72+23.57/49.8>38A58A5;B:49-55+2.)0-(1.&12(24*00(00)/0*/0).-(-.(*,&)+%.-$/-%.+%.-&*,$)*#'( '$&%'&(&)( () (,#(+%')#)'"&& (*#(+%'* ),#++#&(**$,*$((#*)%,,&,,'01(--$1,&1/'12)15+07-+2'*,#)+!./&55+64*32'23)45,--$+*",+ ,+ -+!,* *'((-+#-,#*')&-))(*)+*-+,(-&*%+* ))+')%)#'"%% $ % #' #'!,,"/-$-(!-& /+",+ .+%.+&+($.,&31)('+*+(/* /)+')$))+2']h]ƒ}LE?1'"-)!.+#0,&/.'.+'/.(IKIyxw]YXUSRNPNW^\dhfbgecheikhgca\VUG@86/(/*"+&-)!.*"*.",/#/0$/0$*-!'+ --!.3&25)54)0-"+++.-0 -/ +,!+-"-/%+/%-1&14'-/"(*(* %.#'1&&1((3+-7,)2&))(*)+",.%)* &'*&%!"!"!""  #%#"&"$ $ $!($&' ,)!$##"$#$#$""$$'24,01)('+)0,"&$"!(&%#$!"#!" !*(#IHDVTQC@=4-(+"%)'.2(*.%"""#"!##!!! #" !#$"%# "#"$ %!#"#$"'!&†o_‡oaƒl^i_„i^‚h^j_~h]|g\|bYxcWt_Su_SwcWydXvcV~gX|gX{fW{fWfXƒi[Šsd‚t©‚°œ‹xi|bUyaPsZLhQDbLA[E>V@9UB:UA;VA:YB:ZC<[D:ZG;]J=]K=aN@dOCdOBbOGcNFcNGfPFfQGiRGdUJeVJeVMeXNbUMdWOdXQaVN]TJ`ZLa[Mc^OaZQb\Rd]T_^S[_UU]PMYNITICMFCMEHOEBJ?>F=B6?C7@G9@C7;@4?@6AB7??5=A8?B9>A8?B:>A8>B8@L?FREERD@I=?G;?D8==446,76,:8.=:/=:/=@5=<49306/-3,,0+)4,)2-)/,(6+'7-)2.(30+21(68,9>25<06;066,1/%/,".+#,%'")!*#+#,$,$,$/, 12$39,8@35:.-/$+',')$+#,#-#)"' ( *!***#.&+#*"*$)% -&-(!.*"1.&.' 0%,& -' )#,',&*%-'+%*%,&*$+$+%1+$5/(3-&0*#/*#0/%21'86-55+22'01$3/(0-%/,$/+$0,'0,&--"/+#,* ++#,*#0'",( /+!.*-(-%*!&!(!)#,&+( -+!+*!,-#--$,*!*&)$)% (%)'-+!*()',' +%+'./'>I?=QF35+54+)/#AQD227/47.12)/0'16-8?586.56.PHA\QB[RC\REaVHi^Gi]BdZ?bXCbYGi_AeYInbLphHha9SPH_ZG_XIcYGeYAdXFg`MleGh^Ej^MofIlbKjbHh_Gi_JlcNh]Lc[Ne]JaYC\TPkaSofPkbMf^Ld\Of^RhaSieWnhTkcVkbUf`Q_\Qc\Qe]Mb[LaXK_VJ]TH\SB^QCcVHbUGZRCSNCQNHULHTHGRKCPIEUKCXL?UICYMH]QK_SGZO=SG?TGDUJ?ND=H@>G@BFACJE9A;:<68=69D:;D:4;1690==4<;286-36-59/6<19>47;438177134*41'2.*1/,23+31,30+2/*30+1.)1.)//).0),-(/2)/0',-$.*&,,&),&,-'(+$**&*')')')*"*.%*1'*.((*$(*$&)"&)$&,$)-",1%*-$++%,,&-,'+,#*+",-%*+#--(**#/(%/*%32)59-2:,.8)25*/3'34*56,99-77*21(/1'-.$*+!++ ,, +)*(*'-,"*)+)!((****,, --!--!-+ -+!'%*(*****)*)+)*$'!'!*#' '%$& ** +))'-'.) ,(+),*")' ,)!-,!*+/-"+)2-"3-"/)-($#38/UZSQNH90*6,$33)31'2/&.)".)"3/(>D>dfbedaMKGQQM[\YW][afdgljmpnffd\XVC<62,%.*#,+!-,#+* *-#-1&+.#.1%*.#(* .,!02&12&0,!)$%$'+),+.*-*+-.".2&,0$,/ *--0!*-&-")1')3))1'+3((0#+,!('()*+!)(+')#"!+(#.' #!$$#%!)% /+&51,LID+'"$ # %#&%%$%#! "!$#$"#!$$(.2'9:130(,*!.*!*)!%!%"& %%$"!'" %!*%(&%&%"(!$%#" """!"!!"! !$'',++)''&$ % $! #!"&'&%$%…n^†o`‡nc‚i_ƒgY€hY}gY}hZ{eYg[}dY{bW{bW{aV}cW~dYgY~hYzfW{fW~fWƒhZ•{m¨Ž€°—Š´¢“Ž|l~dV}dUv^OrZNgQF[D;T=6L92K:2G5-J8.M:.O<1L:0M;3P=6S@8UB9XC^L?`MA`LDaNFaNH_MFbOG`PG`OF`RFdVJaUGcVNeVOeVN_VN]ZPTYNGPEAJ?>E;>E;AG<@F;8@69@68A78?4>C8AD8ROFVSJTRHVSJTSJUWLVVMTULTTKPTIJRFBM@>D59B27A17>14:.8<079-68,>@4?C7=A5>B6AH;>D7=A5CE8EF<@B78B89B86@53<25>45>5;C7DL?CL?=F9AF9AA579/44*54*75*:8-<9.7:/87/64./,)1-)/-(1+(0,(.*&1($6,(/*%1)%1.%43*67,55+32(0.$-+!+)*#)#)!)!( *")",' 0,$12#49*7A1:D78B5-5(,+!*)+',%)#,%&#&!)!) *)(!-%*!) )#*&")&/-%1/(62+/+$.& ,','*%+%+%("-&-&,$)#)$+( 0*$60)5/(2,%.(!/+#1/&87,77+77*33%55'10(/-%,+$-+#.+&/-&.+!/* .+!/0'--#2)$*(,* .*,&,$*(!'!("+%)'.,".,#,,"+,"+) '&)$'#(%'%''*(('.(!+%+( /0(6?5,9.61(0/$/3(:E94@46>37<337.-0'14+14+04+3.',.&9@65?58B85>44<1:H=;LB>MB?MB@SG?UM=UKC]SDbWKlaCi]@b[Cf[Hh_BeZDf[HnaMneFe^;RMF]XHcXHe[DeZ?cXJmeIjbIj_GmaHmcLodJjaFe\Ed[Ff_Pj`D^TG`UG`VD_VMmbSlcJbZI`XPg_KbZKaZSkbWohVlhZmiXhbXf`XhaTf_OcZNbYM`WN_VL]TH_VMeZM_TETKHUNFTNJXMJVJGUJCQIGWKH\TG\QL]RO^TO_TGWLDWKDVKBRHBOD>H>@I@=B=;C=8?9:=45:15?55@66?56;28=46;25:157/38.5=24<159176055.54)21(0.*0/,04+53-52-31+30+1.)1/*00*-.'+0'/4+-0'-/%,-&./),/)-1+./)-,(*+")*!)*!*,#(/%'0%),'(+%)+%')#%+$%-&*-#*.$),#*-$+-'(,$)*!*+"/0'+,#+-#/.(1+'2-(97/8;.8>/8B19DECPRPfjhnqoqqoc`^B<6/(!)%+*-,"+,"..%,.#+/#*-!'*))*())((+%)"$#&)'+(-%*+, 0/#.2&+/#,."*, ,/ *-)++.")-#(+"*-",.".."**(**()%(!# %#,-)272HLGZ]XG?8$''#% '#MJE972))#43.'"$"%#%$%%'&$"%#%$! $#$"$#&%&.,"$"$!($%$ ")*$*& *"*!%"" &&)(&%#$"#$#!#$!$%$ "!  !! $%$(,3$1:)05&14&-/"$#!!!!21):80+)!(')'‰rfŠreŠrgˆoe†o_…n^k\€k]ƒl^ƒk]g]dZ|aWy\S{^U|`V}cVzdUvcTxcT~eV†k^Ÿ„t´™‹³œ°Ÿ“Œ{k‚jZ|eUp[LoXMfPF^G?ZC=R@7O>5M<1N=1M=/L<.J8/F5,J90J90J90H7.G4.I8.L;0K;.L;0P>3SB5T@5XDYF>[I>^K@aNCdRF`NDbNFeNH_MEYOFUPFHPBCJ=>B89?59B56A27<15:/8<4;=3@@5HF:OIASMEXPHVMFVPH]WP\WPZTMWTKTTIMSFDM@AH8=D59@16<-59,59.8:.7:-<@4?E9@H;>G9?E9?F9@G:CJ=GM@BI=42;10:/4<39>39A6=G;=F;>E:@C9;<122)33)44*77+76*65,77022,-.(-/(/2(2-)-+'+*#0)$2)#.*"-($/.&13)25+01&/*#*'*&*%'")#)"+!+")$)(..%23*03'08*6A29F5:F73=./2(+,"*)+')&*')(+( *#* + * )"-$,%*"(#*% +) 0/&33):9110&/*"-+"+)'&)'(%&$*%+%-%-%*%+'"1-(41+50(/)!-'!0)%22*79/68,6:*25&25'/2'.0&.1'),"-/(//(-,"+)-/%/7+15*.+"/.&/-#-+!-',%,"* *!*#,%+%+(-&-)!-*"*( (%*( *# )%)&'&)( '& .(!*&-*#-,#//'*-%2+".+"/.$77-36,5=25=3.4+.2)25,02),-$-+",/&0:05?56?537/07-5B78I@:HA@PDBUH=OF>PGAYOFcYJk`AfY@a[GiaFi_Df[AdXHk]Eh^Ec[;RMF\WJe[Jj^Ef[Cg\GkcJkcIi_Gm`JpfLndCdXC`VC_XHf`Gd[@YNBYMH_SF@;B=8C:6?58<328/3=57@66>45;18<35<21;035117/2;/19.7:/75,35-13'11&./)/1+17-89/45+33,23+22,//)/0(02(.3*-2)+1&,0%,0).3+*0).2+.0(//'*-$),#)+"+.%(.%%-#*+&)*$)*$&)#&,%%.&,-&'+#*-&+.%+0&*0&*-%-0(,/&*.$04+/3(,)!0-'42(9:.?C4BF6JO>DG:;?5>B8:@4;A368/38-4=.6:-34'4/$/.!.,"/-"*+)')'()))--!,+ +*,+ *'(('*'* 14&8;+55(12%0/$+()$*$'%'#&#& & &)#)%((*)+* '$&$'$*&)&*(+)++((,*+)*'('.% *&!*(#.'.'/-!.2&12&0,"/+"/-#23)88088/:91FD<20(:81?<9761JJF`a]ed`rnjKB>*!(!+'**,-!,+!,+ *, (*''&%)'))** *&)$(&%(&-!&/#)/#(*,+ ,/$+/%(* )**,*-,, /.#*+!&'****'((+*-)+&$#!"*)&565ehg]_\2,#'!'!&!#"& # !! &$%"&"&#'&%%%%'%%#%$#"$#%$$"!#"#&%'$*)&00.;<:XXT‡„€khd,(%0-+?60"! !$$#$"#!#"# ! #"%""%### ! " ! $&&/"/;*0?*2<+/7&)/"#%#"" $$/-%+)!$!$!$!Šqh‰pf‰pf‰pfŠrg‡rf…odƒmb…ib…h`{f\xbWv`Vu_Tx`VzbW|cVzdUyeVxeWzcTdV¢…wµš‹³­œŽˆxhiYvbRoZKqZNhSH`JB]HA]I?bLBaLAaOA`P@[L;XE8YE:XG:SB7N=0L=1O:5J70I7,I9-I8-F5.G8+F5,F5,G3,J8.L;.K9.P>4O=1T@6ZF:[E;\H=`H>bG@^G?WF>SIAKP@HL>DH<9A54>12@.6:.48,68.;:0EB6KF7HD:JD;QI@VKCYOFYQGYNIVKEUMDSNDPPDHL>@H7?G7>C49>/7;.6:.8<069.:@3?G:BK>CM@AH=@F;@I5:B8;J??LB=I>=F<9=214)23)35*/2%02&51+21,.1*.1+.3),4)3/)02(..$1+#3+"0,#,0*/6-/:.09-.2(*)!,'.)!+&& )"'!+ )!(%,,$,3)-5,27,3;/8E79E78C24<-/8,37+01%,, **,."55+/.$+$+!+!) *%2+#0(!.'+&-*"/.%12(56,66,42(0.#0/%.-#,**')&*( -'/("/' /'!+&!)'".)%.+$0+"/*"0)$3,'77178/56+48(36(23(16'05(-1%.1'.1(.1(*.%+/%+5)7F:0=/38,::2//'/-#1+!-&-$-!,!+#,$,&,%/%.$ +'",(#-,%30)1*'+$ *' )&('('!/*#1-%-*",)!*&-(!/* -(.) 6/&40'4:.4;2+3)+1(35,./&,*",+$.3*3<35A74;247-2:09E:0A77F=;L@=QC;H?;KB;PGF`WEf[=aTAb[JleHi`Eg\Eg[CgX@cYD`Y@VRJbYFbYAcV?`UAeZDf^Fe^Hg\Gj_HodCf\@`U?]R?[TFb\F^WJ`WF_Q?WI@VI>REBVHM_RUg^Re_Xlh^qmTgaQbYQcYWi_Wi`Qd\Qa[Qa[IaYKaZK[TDPGHYND^QG[TFXLGUHDRG@NEFRGN]VN[TXd[Yd]Q`UJZNDWHFWIDUHBNE38?44?88;289/55,68/5:027//404:52;029.9;096-/5+.4&04(03+4714=09<148,48-/3)03,13,23)24++0&-3(*1%+/$)3'-7+*3(-2&02(42)(0'(0%(,!,.%)-$'+#))#*)#,,&++%',&'-'+,')+&*,&).$*0%,2&.1*14,/3*7:0?B8:>2FD;::/44*==1AA4EF7HJ:CC7=@8?B::A76@37<33;/4>/9?087*;4+10"/-!.,!*+)(*)****+)/-"0-",(*(*) +.%*.#04&37'12&12'.."+)*&+'$%##&$$"$')!)$('(*,,!'%%#($-)#+'!(&)'$'('($+'(&&%* -&",&!/'.) (+)-,-!.-!20%./%.3(75,43)65,32(-+"54+B=9-)%0/+@?;b`\gc`k_Z+ $% *'.-".*!,+ *+()''($)'&())+')%&'&+"*2(.7-'/$'* (&(* ),$*+#)* &('++,!/2&(.##)%'%'%&$)(+)+('$ ($!'" ?;:/+*-%+'$#!! #!  ! #!&$($'%&&$&'&$"$!'&#"%$%$$""!#!&#)&!$$"477bie|}v{tmMG@61+FFAF>:#"""&$((#)& '#%"#"$$"""#$##!" !" "!"  !##"'$. ,:).@+1>,,7')3#-4'.1&&(%##!""%"%#rhŒqg‰pfŠqg‡qe‰sg…oc‡nb…ma€g\‚e]|dX{cTzbT}dW}bXycY~bZ|`Xt^TjUHxWI ‚vµ›³œ’«–Œymƒj^e[w`UuaVm[PgSKdOFgNBqVJv\Qr]PqbRj^Kq\MpYJqWIpVHhPBbN?aK>]H;YD;WC:TA5SA5K<0K=1L>1K;2H7.E3+D5-B2+G4.G5.E2+G6/K81M:1O<1N>2K?3KA7JE;LJ@EL?;C67@0:?09>/49,9;/58,<>2@B6B?4C>2KA7RFYH?VJAMH?GJ??B9/8:.::0<=1=>2=@4AH;DNAHVHCSC@J;@G:FLCN=CNA?I<8?35;/4<07@4;E:;H;AL@COC/4>/3=0/8,+3'-1"02&+)!,%+!+* *$*+ -1&-3)/3,/5*3;/:D48F67B122(,!@?61+$+'*&-*!4.'3/'-*")&)$+%(&+)!-' .,$,,$69035-/3)-4'-4',/$/,%,/%/3(6;048.05)36+0?/;D659.6>37G<7G=/?33@57J>?ZMA^Q>YLGf^GibIkdFh`IlaCdWH^WIcZIc]I^ZGYTDWT@aTAcY@`XH]YA[VAf]Ef`=\T@]S=YK=WNEaWCZSME>NC4F;BVJF^OCTI>H>GA;IB7FA9G?6B88A77?47<6;;568246058267155/25.67155.23,:;55708:-79,;=189/8908:065-89.67,31,64/85-52.33.10+/1+*.&).%)0%.4).2(/2)34,01+/5+.2**/)+-'+-'))$&+%),&),&*-')-&),&,-$,,%*,&'+%(.$+2%7@4@D87:->?1AJ:AM;RYH@B287*<;-==-BD2FD8EG;BG2)#&!#!# $!#! $%),-'(%('&$&"'#!$%&%&%&%%%%&$'$%#+,*3750/7**. "!"$##"&% si‹si‹siˆpf†pdˆrf†pd‡pd…maj^f\}dX~hYgX}dXbY{eZ{aWsZRgTIhQCz\L¥‡{·ž’¹¢—®›Šsh‡n`ˆnaƒl^k_yg\q^RnYNs[Mu]Qw^SzcWyfWsdRycTycTz`Ry_Qr[LoYJmXImWKjTIhRFeQDeQBaQCbRC`NBZH4P=3N;1M:0M:1M;1I6.G3,E3+F6-B6,>4*E;3JD9GG/9=19=19;/57+56*8:.78,;9.>8-B;0D;1F=3L?6TD;VENH?EEDQCEUHEVICPDAK>DL?EO?EO?FQD?I<:A44;.6>18B4;E8>G:>G<=E:7=257-66,87-65+32(11'21'/2(-/%-.$.1'+0&*2'-2'/8,/7-26+02)18.3>/6@24>13=03;/3=/2;,4;/.1'*('"( +*%..#.2&*1%/5+28-3:.5@18C36A15>02026+08,0=34A62>32<20B69PD;VI6M@DaYHf_MleLjcNj`D`VNc\Nh`NhaK`\K]YH?GYMAZLBXKNaWUe^Q`[Q_ZVe_Yfc\kfWg_Te\Sg_Qf^H^VH\TDUKCSIOaWH[PAOGKVOR[PFND^e_^fbW`ZZb`^gdWa[Q^UQ_SQ\VHVNBOFFNCAIB=JD@478.45,67-57067-67-32.51.86.23./0*02,.0*-/%-/&+0$,1&/3)47.15-14,-4),1&,2&-1%,0%+/%-/)+,&+-',.(*,&*,'++")*"(*$),&).$07*FM@JQD7?3?G6BK<@K;JRD;C<;B87=27:/:=19>276*21%1,#.(!(&,+!.3&.3&+/&14+//'1.%.."32&-*!10&10&.-"0-%:92HHBCB<75,*')'*&(%&!'!*$'%,*,+/--* ,',&)%+()&*)+)++ ,+ +(+'*(+*!.+!-+ )()(++")-"++"*,"+/".2#04&57,67,1-#.,",,!-.#4.$0) +(!#"KMJ_[X81/%)!''')!*#+$,%+&*(*)*)+))''%&(&(&*',!#(%+ +.#+, )+'+%,&, (+(*&+!-1%(, '*(*(*&$$"" (% 0,% #+(#::4=301)$%#%#$"#!%" ! " &&(++* &)*,#&(##$#%&()()))./%,+!*')% ,,(?A@fljgnlmpn[YSD?:)('887;;542*'%#!"!"$$&(*'&&$%%$&$#$#!" !  !#$$&)+"'+!&+$,'3%&2#)1"/<+0D1:A06?.?J8@K;;D57=0./"$"# !" #"‹th‰sgˆrfˆrf…oc†qe‡qe‡oc‡oc‚j^}g[zdXxbV{dX}cYcZ|eXxcXmZO`PCt[MŽo`¨‹~·‘¹¢—¬˜Šsg†m_ˆo_†p`ƒpa~n_|j\taUxcSv^Qt[Ou]Qw`QycRwbSxbSybSybSv`Qr]Nq]Lq\NoZKpZLqYKpZIn[Ms^Os^Pq]NlVGkTFfPAbM?^L=\J5K90G60D7.J@6MB9JC8JGFF:CC8?B5=D4;C25<-8=.7C6=I;=G:?L>DSEGWJGYPHWMEQEDPBDRBBRBFREBK?8>34:/6<18>39@17?27>28>367-52*43)43)10&10&10&43)/.$/-$.,$-.%-1'37,.6'/;+0<.08,07,0;05?24>21<..7*2<-5?/5>.6=1+.%(''#&!+!*$0/%/2&.5'1:+28./8,.9)4?/6@03:-07(48)25&47(49*4;,9<136*0.$.,#/.$--"/-%/-$1/$20&21'43)02&06)-6),4'/5(/6)/6)04)1/'1.%/+!0, .*/,"+).,"41(1/$3/$0-#++./%47-7;36:/59.58,69-26*/3)/3(-2'+3(,6*.=03B65G75H99J<5E77F8;H:?H;9E8/>11<1.0(+' (')%*$*$ /+%./%/2'49-.6+6@48@7=F;@K>>E9-/%*)!1*%2'$,% ,'",(#/,&,'")#&#)&-*",)!/-%43)54*45+46+26+87-65+1/%/.$..$-/$+/#/5*0=1/6++0$-3*2;19A75=3.8..<2;PD1H;5F;@XPLe\Nf_H^WKbYNf\Se^SjbRkbMbZK\UFYSGbYA\S;SK;SKA^S@eVA^S7LC7C97B75F;E]QETH3A59D9=I;4B4GTM;E>9A7>I>CTFJB@IB=E=8?58B87@7A;8=78@98@98=77;467146-12(13'7;/2:,@A5AC7==467-34*77.46158.57-31.20.53+.2,.1+/1,12*./&/.&,-$/1(47.390.6,.6,/7-*0',1'*/$*.")/"*-$(+"(*"(+#*-%*,#-+")' )&!**$).$06)HL@U^QFQDAOA?J92>B6>>/54(51&3.&*( ,)"*/!/4(04+03*34+01'0/#11%--#0.$/-#31'00'67/DB=HC?1.%,&-&+$0) '#(#,'))*)--+'+&+$($(%+( +) )(((('(%,',',(*).- /,"++*)+,!(,"-/$,/"-... 11#22$56*41&,*,-!-."71&/))%(("32.'"$)&!-)$'!) ( )!*#+$.'.'*%'%(')'(&('(((*// /-"++!*+!*+ *.')'+'.!$+$)&(+-"*, ')((()&'($#  #"" !#!/&(!%"$!$"#%" !# %##'()./&12)++ '&'((( *+!-.%36-CF=8;1@95EC?243MPQ`ef_ddUYU][TJHB??>LNL<;7+) %#"$%)&+ %."(0$&+%'%$&&'&$"$"!!  !!!##!%$*'0#&0!)5".=*/;*-6&3=.2A37>21;-/8+.8(-3$*-('$"%#!$#!ˆuh‹uiŠthŠthŠqe‹rfŠqe…ocƒma€j^~fYycWwaVv_Uy_U|aXx`Wq`Uk]QlXMeX—zl®’ƒ¹Ÿ’· •­›‹tf†l^‰p`„o^n_~o_}k\yfW{gVvbQr]Qp[Ns\Mu]Mr^OwaRxaRybSzdUt`Qu_Ps_NubQvcQq]Mt_Pt`OvbQyeTzcSybRyaQu^Os]Mo\MkXIlVGlVHoZLfSGUC:I70J:0`RE`VLPG=KF;HF;EH<=C6>A78*D<1NC;NE>HC:CC7AA6;?1:A18@/5=-8>/1>07C5?K=BOAFVHHZKJ]UO`VHZLGWFDTCBRACPC;F96<128-5:05;15<-5;.505>35?329//8+2;/5=.69/58,0/&+')!)")!*$-+!01'07)1<+38//8,1=-4>.6>.3:-49*26'58)6;,6<-4;,6:.14(/2%/1%/0'.1&0/%//%/0&21'21'21'/2&.2'-3',5',4'/5(.7*03(0.&/+#,) ,*.,!10%.,$0.&34(35&66+34'./%/4)5;17?414*06)29,18+/5(/3'04)-4(,5)/;/0?21C65J;5I:8I;4E7L>?J<3:/..&1*&.%!*$*% +'#,($(#("+$ -("-*".+#/-"/-#/-#/.$33)23)22(-,!/+#/,$/,$-.%-/&25--6+-/%)+#)/&07-68.-0'-1'2<2:LA7F;1;1=MGFXPEWN>OGM^WOaZSd]Sg`Qh`Q_YCQJ?OGC^S=SI6IB@VM>YKB_OE]Q9H=QD;E:5?3;D6:D79C6?K=CJE;C<8A8=H>3:C;@HAAE?8@9;B;7?7:?968.55-45,8:.6<-6=.:?4>B6;@4:>359.58.8;36:/48.33/21.23*03-25/25,45,/0'10&23*03)47.38/5>36?527202-0/).-'*+#*.%..%-.%**!,,#,,#+,#*( (%)% ,+$-/%.3'=>4?M?5A4;E68E=8F@?NF7D;4=2>D8EF:=B55=0;B8>E:C7::,;:,?=197,43*32*36(56+64*42*54*20&+."35)0/$/.$1/%20&00'76/:610,&,&*'.$,$,%(#%!'%'%(&(%*&(")"(#)%,) *))(&%&"(%*)*(*(/)/. ., .-"+, ,-#03(56*,."--!,,,,///2&/-!0-"01%11&50%60%+('$'$'"*"*(#+("(#.&-%-%*#+$)$+')$(#'$'%('('))''0+3-"+&/,#+, '*')(*), *-!*-!,-"/. --('$$$"%"#!# """!! ""&$ $!" ""$!!# %#"'('+*!-)",).) *'.1(36-58/13*55,9914-).,*-11MRS]abXZZpnkTPIJF@GFBA><=92,*"$%#&(.#%.#&0$*5&+3$+/"))((''#(!$$#$#"!!!!  $%&/!,7&1<)3?+1<'.4$/3&-5+-8+.8-%/"(2".4%/1!'%" #"##&&&$ŒvkŒvj‹thŠsg‹rgŠrf‹rf†pdƒma€i^gXzbVv`Vs]UpYQsZTlSK€rjncZxdZˆmbš~q°“…¸ž‘¸¡•§“†Šsf‡n_Šqb„n_n^|k]}k]}j\yiVyhWxfVucTu_Pq\Ko[Lr]Nt^Nu_Pu`Qq^Ov`Rs^OucRxgVudTn_Pp^Oq`PvcSxeTxeTyfU{fUzhVtdRraOt^My`P}eSu]NaMCP=3I8-q_Sk^RYKBRF/9>.7<-89*87)88(>;0F@8C?7><2?A49;17;.6=.7>.:>0:=05=04M@>M?9D728-38.47.26/2:-5>26=09<166)41%10&10&10&10&/.$.-#1-"/.%--'.0*15+5:.6:-2;,0;,39)4;,2>-5>25=22:/19.39-18,48+46,31),*"+'+&)%+&*'./%18+-8(39.1:.2=-4=.4;+37+27'27(38)6;,5;+6:*59-06(-3$/5&,1&,1&12'.1&.2&.2'/1'33)33'02&-2&,3#*2#-3$16'00&/+!/)",,",."13$66,33*04+28*9A19@/;A32:.4;08A52<.02*.4(19,09).5)15)/5++2'+5)0<0/>/0@22G74G75F67E6?L=?N?BOB?N@@M?>I<:A64:.5:-23'/,"-) 03&07)/6*.7+208A5?I=?K>ERE4=2:=4-+"-% *%)%*& ,)")%("*!)#+( )&*(+),(+(,*"++".-#-+ .*#/,$-)!1.&/.%00(.,$,(!*( ',#/0(/-%.-%,.%/6-AOE1<2/2)8A:=G?5590:B69D79=25:/9>2>E8:B5@G;F??C=:@99A9>F?:A9;?99:188.9;068-6<04=1B7@D8=A659.37,5908CG;:@35>04<14:/26+1;309//6*04)29,4;-8;.:<.?@1>?19;.8:0:=/;;.54*21&45*57+17+4;-/2',/$//%0/%33+72,3.)/)$-) (%-&,%*&'#'$(&*$*$(#)$(#$ *$+&+(+)*)('(&((*++, ,* -* 0/"1.$**,,!-/"+0"-.",,!--"++ ,- .0 -.$/,!.+!**-.#2+"0,*')%*$)!) $"#' -%+%*&*$($'%&$)%+%+&('&&'(()'&.)-'*#+&,* )+(''(%'*+*+/.#-,)()'&" !!# !"$$!#!" !!$" #!%$"&,,"*)'%'%&&+/&5=3KRIOSJ@C942*)')%%&!+31HOPXZ[kghLFDB:4E@7A>840)4, )) $&(,#(1&)0%)/$*3&,4(-1%)*(()) $)#$'%&$$"!!! $$,+3$08(/:'1;&05"*/ )3&.;-5C41?/1<+4;*.1'$ $%"%#(%(zk‘zkvgŽtfŒth‹sfˆpd…ob„nb€j^ƒhY~dXzd[r]WgRJcME]C=‰}uœ’Š…ph‹of—{pµ™Š¹ ‘¸¢•¡Ž†oaˆo_‹qdŠuf‡te}l`{i\zg[xgUvfTufVwgWvdUt`Pq^Or^OrZLr\MoZKmZKpXNoZMp_NsdSm_PbUHdTGhYJm]NueTrcQteTl]€q`whXvdUzcTƒgY…kW{cRlVI`MA]K>mYIlYNbMBXA9P?7I?7DA7BC;;>489/77-46+58*69+<@1;A2;@08;-66)8;*9:.=9297/77.79,48/4:/7=07>/9<0:9/7<049,7>1>H;DSDETFEXIDVH@T@FXDHXHAMA;J<9D72:/.3)35.47119/4<04<04:+57'64$10%32(22(10&/.$.-#0-"0/&//)+.(-5*28,86-38.48-9<,7:+4=,3;.3;..8,5;016-16,19.39/04,+,#)))(,*/, -* 11'06*/:*27-3<13=,2;,38*47+17*18+26*59-58,69,7<028*/6&-4%.4(-2(/3%/5&.7*,3)/3)/1(42'00$.1%15'-3$/4$14%11&0-"2-&01'15*26'5:-6:129.5>/AL:>L:?K<7A69B6-3;-28+.5+,3)+3(-7+-8+2@22F53E46D4?O>@PCEQEDL@@G:>F68B26C11:+/5'26*5?0-<+17,/6+0:-7B4=H8EN@ENC?J@=FXIB7<@68>47?64@53B7DUKcuj;A6;A69@8=C<=A;>A<=D=>E=;?83=;3=?59=45;2:>3>B7=A59<259.7;.5<18>/6:-37,56-24)10'67.8:15:/27,17,26038016-/7-08-5=27>4AE:7A48F9HZSJ`W;TK4J@?NA=F79=16=037DWA:_JDxcY‡ocŽtfš~p³›¯›¦“†˜‚u‡n^‰o_‹pdŒue‹yg…ue|m_vdZoaTrdUseSseSueUtcUsbUq_Tq`Tq^Sp]Pn\MnYJoZKn\Nm]Qf\N^VG\RF]REaRFj[Nj]Oi]Oo_OweUyhV~hW€gW‡l^‡p_€jZubQn[Kq]Ls]MgWIcPCXC;TA;P?:N@:KH;FE:<<249.66+76)75*=>/=B1:@14;0.7-36-36,45+54*44'53'15*47+89+;=.9=.6:-58+24)48,7<1>A7@E;AIBBLA?M?CRAHXG?OA=J>9C65:.25(25*7=35?19C34=18>166,42)43)0.%1/%10&11',/$.-%0/'./&./%04'48(87+78+89-68-79-47+24*26,48-39.,5)08-4>04=02:,+2%*."-/#-1"-1$,/#03'26+48-27+39/59.86,54*17+18)18)18)2;+2;,3;+5=03;.26+15)-6(+5(/6).5(/6)-4',2'*1&.1&-1'04*/3(.2(/3)26+26*12)/2(37+08+4=,5?-6A/5?06C7N??M@=O@CSCDO?;D87@38A46@44=109,3;.6@05?028/-7+2?/8G6BPAFTGDRCAL?CK@HKA..&1+$0.%,* )'(&&"&!&!)!*"*#*&+).%!.%!0(!-&-%-%.%,%*$,%-%-$0&-%*'*( )'*'++-,"32(33)/.&0.&10&56-9<36?5AMCDQIGOE:K@BTI?E;9;2:@6I\I>K;3=13>45A46>29B57?539/891<>47>28=/8=07<0:>4:=47927=19A66@83@8ESG@NAENFJYPRf^Vmf[kh^lh`nlesqftr`ki[fd_feabfcef_c^PWNEMBEM@PSLW\VT]SHQHKSJOWM]a\`c^_d_efcdecheeLMHLNFNSGRVJPTHMPDGODBG<@B8@B9:=3<@7;E:@I?BJ@?D9@B7?@7?=5><4?@7@B7<@58?49:4:<49<36:/7;/7;/<@39@43;04;06:19:18;09?4:@:5=508.1:-3;059.58-45,27,6;1>=3=<2/,&.+%-*&-+$,+!43)23(10&/-$2-(2,%/*#-+#..#-0%04(-0(,0(+3*49025/9;4?GC?FD:C?7B;7D;4@56>14;.8?26=019+5<05>2/5)01'10'/2(+3(37+15)65+<;1:;26:0;B5;A348+49,4;/09/47+,2('0$*1(.-%0-%/,).*&.,$-+#+(!.+'1,%0-#42'22&11&43+31'-.#)+,-!01%11&0-%., 1,/,.,.,0)/-1040)0+&.*0+"/+!0.#//#/1#13&1-%/,$,.%./&..&-*",* ,* *(.,"., *((&'$&#)%*$ ' $!2/);5.)#)#)"'&'%'%&$%#%#(&)')'('('&&%'*()"'#"!!" %$&%&%)')%$!$!   !$!!#$!!# !"! !$"$ %$ "$#"$&/$3856;9NTRW\YAF?JPG]cZAH>TB:O@9MA:IE;ED:AA7=<399.=;169-:>148B619;036,13(01'44*.0&*.#,/$-/%,-$,-#.0#15%57)67)46*58,37+16*23)12(13)26+16+39.4=03;J=>K<@N=>M??M=>K;@K;?I<19/02(13)/4(.5(/8*6?13@34A14B25D38H8:I<;N=CTC?L;9B56?26@3/=//;.2=06?22;/3106+09/2=12;/3=/;E97;2=<4?=46:.7:/8<136,57-76.45+89.9=33;04=2<>49:08:19=3=F=FODGOFBG>>A6>?5A>6=;3@A8?@6<@5:?37949;4:=49=27;09=1:A56>35<18=3;=4==4:<2=?6;@86=46<26;05<25;08:088.55*33*55+54*/,&.+&.,&-+$0.&97.56,64+1/(1+'0/)21+12++/&+2'-5*.2)-2)29/6;26737822704:4162.60,5,5>27?1=D6=E84<02;.8B64?3-5)25*79.59-.6*04(15)56+99/47-26,:@2:?19<07;/6=1/7-,3',3)*4(,3)/0'2/'.+',*#-*#*)!*(!*'#*( -+!1/$30&/.#2/'11&.0%-2&16*13(35'33(30#.++(,)-+ ,),+,+,*"+("-).+!,) .,#-,!10%12'/*#.+#0.'..%.,$+( *('&*(.+"-*)&('(&'%(%(#%'"85-5/()#%"&"&$&$'%'%'$&$)%($("'#'%&$##&"%$""$ $ #'#)%'"  "!## #"#!##$'!#"#(&&!$!##!"'%'(+3(>B>RVRIMJ>C>17-4:.28.38/06+*0&14'34(24'28*7?1:B7.7A16<./2%&'&, 0:)2=-7B04>-ŠrfŠrfŠrg‰rc‰qfŠsgˆse‡rc‡sd…rc„qboa{k]l]Q]MBWF>^F7CB7:?6:@5;A49@35<.18+46-15+13(02(11'21'01(22(54*66,88.9:17;.26*35)67+65+65,5;-7?08@2=D7EK@BK@:D74;049.79/:A5BJ?DQCFSEBOA@I==E8;C77?33:/37,59.03(,2&)/$,/%),#,-",/#23&49(28'15)48,25+15+32(21'11'34*03)27,3:-07*-5'.2&/3'15)05&.3%/2'.2&-1&.2'11'14)02(54*36)1:-58(59*49*8=.7=.7>.3:-27+15)37+07*/6)29)38)35)..%,*".,#23(23'.2&04(/6).6(26*/3'01(-0'/5)09,3<08@46@18B25A18E5=H=:F:=J=@L<@O>EUBDSD@P?@M=@J=9@5-3+-/$14)26*16*38)3:+6=131.@/->-2@14>13<03;/6A6P??QAEQCGPC?G97;1./%./$/,'-*#+)(&)''%)%,%,&+&,) -,!/-%.,$-+#('+* -,!,( -*".,$*( +( ,&,' /+$/-%.+$,+!.*!/.$10&/.%+( ,)!-+#1,&3/(0/&01,=@;=B;=F:8H9;J<;F936,<;12=G;5;0;9095,56,46045/22,42*52*53)66*68-39.7=28@3;C6AKAGTKPcZN`YWf`bmjgtrgsphqohppbmkYdb\a`Y]Y_a[\^Xba[OLHKLCZ[Vjlegkebb^``\a_^`]\iihwwuwxxikk[ZYba`ada\`[RYSFNHDKA@D<=>5:;169.=B6?G@KRJMSJB7>>6>?6@@8<@4<@5;?4;=48<37:18<159-9?38?58?59>5:=4??6?<4:907909<38<27:1:;25828;1@@6>;152)4.(/.$.,$-*$+(#.,%,*"0-)64+12)1/'-+%0*'31*<;5460/4-.4,.4.16-38/4907<489320*27+36-15,.3*-1'8<29A67A6;C83A3225:.79-8:/:<079-68-68,8>/9=/;=19;17<117*29/,7*/8-28-56,31'0,$.+",* ,)!,)!*&!(&)'.,!20%2-#/+#./$06+18-08--2&04%54&//!,)+')'-* ))(*()()(%*&*("($ (&*'63+0/%1,#1,#30&-,"+(+)0/%/.$(&*(+')&)())+))'&$%"(' '!)#$"%#'%'%(&('&$&$(!& ''!#$ $!%""#"%##"%#  %!!!! (* +/$&*%)*,&'%""# "'$%&',&(*&!#$%"&++2".5)/6),3&07*9=/6:./2#.5&.9)6@4=E87:00-'0-(9839;137-.1&,0$),!)-!04%4;*4<,1=,/<*-;*)4%&0#(.$&. &+')))('$#&%)(*)')'- %-),)1 0;'/9'.4'+0%*2%19*5<+18'-. )((*&*)2%-8(/<,-:*‹sg‹sg‹sgŠsdŠrgti‰tfˆsd‡rcˆsdƒpal^udWhXM^MB`MBmTJ{cV…la‰rcŒrc–zj­„¹ž“¶Ÿ”zk~fUˆo]„p_‚p_}m\zjYvdSp\Kp`MueTufVvfYqbVl_SnaRl`Rm^Rm^PqaRxhWyjZvgVscVqeWmeVjeVW[OILBBD9EE9CC8FC8SLA^THiZJsbPxeSxdRwgWzhY}k[‚m\„p_lZwfUhWJ[J@TG@KE9KG9JG?FC=FB=IE@FD=BB948=38=26;.6:,37,15+/1(45-23*/0'/0'21(2/(53)88-79,57.57,68,67+78,89,9@09@1;B55=0AE;FK@G:H8:E55B24D3;G;;F:=K=?M<>K:AN>L19C69H:8I88J98F65@0:D78B51>00?./?.0=/3=03=14=09D:9G:9K:BUD@PA@PAEQD@I<:=146*36*48+2.&-*"+( -)"*(+),+ -* ,',(+*!,+#0.&-+#.,$+* ,+!0/$10&01&/0&-/$-.#0/$/-%00'./&01&10%1/%54*53*1/'.,$,)#+)$2,%-( ,)$0.(9:4;;4;E69B6;G:5A339/55+;<4=:132'14)3:/5;/5<17?338-63)62)33(02-45/55/31(40(54*34*58,508?2CJ>GPFJXLGWNK[TVc]enkcnlioolrqflk[dbPZXY^]^b_Z]WY[Uec^ROKEF=XYSceaqqmrrrmhjd`_^]\khhzzzzzzoqrqnppnpqpqnpp\`_KQLFNECG>@A89:0;>3AF;DJCDLEGKE9=4A87=>4;9/62*6/(.-%-*$.+&-*$/-%00%1/'0.%./$0/&0.'4.*71,61,3/*21,45/24.28.490490;>597230+56+78.88056-44+>@69=11AE9BC868,=@3;?/:=.7:+69*58)47'8;-=;2:;157,6=03;018-28-58.56+31&/-",*,* .+#+( +( )'*'.,!2.#40&5.'01&.4)/7..7+,2'13%03$/."-*-(,(+)01%00'33+01&%$(#(% ,)$4/+2/'A>674,1,#1,#1+#.) )'-,"43)//$*((&+&+'*)***+(&)')'(!' '!)#%"%#)#+%+&)#($'#& (!( )#$##""%# %$#" ""! ! ### "!$*.2',1"-/ *.%)&$!$#%$"%$$(!*+$%#&#*)!+/".6%*3&17*/6)-3&/4(.5(-2'08-3=2;E8@H>7;1-)%*&"&(() )."*/#,.&(-"*0$08)5:*5;*/9).8(+6&%1!(2%)0#$.!&,(*))%%"$'%((%(%)&- (."+-,1!-3".2#+/"+0$,4'29(57(-0 ,-)(')(, '0#(2%)6&(5%†nc‡ocˆrf‡rd‹rg‹sh‹rgˆre†qc†qc‡pdk_q^RfTIiSHlTLw\Q‚h]…la‹rfui£†y¶–ˆ·œŽ¹ ”˜‚v‚k\‰p`n^m^|k]wfXq^NlXFo]MudTueXvfYuhYqgWrfUpdUnaSnbSseTzlY|k[yhXufXtiZoj\jhYWYPCF<>B7>?5B@5E?4NG;\QDfYHjZJm_Nl_NpaSraRucTkZ…p_o\wgWjYN\LETICKH>?7=A6<@4<>3<>579/58-68-26+03)/2)03+/1*.1)..$0/%1/&10%44(58)32(43)65+89-8:.8<0=E4?G7;B57?2:>1@D77@25:.78/48.J<L>?M=AJ==E8:?339,/7*/9,28+.2&,/%+.%,0%06)37)48+69,13'00%//$/4)66-53)20&44*04)14)37+26*26*26*/3'05%/3&14),0$-1&.3'-0',0'.3(54'45(08(15'17(49+7>07?03;+47+15).6).5(04(24'/4)/2'13'/2&00&//$11$12%04'27)-5'+5&15)-1%01'-0'-3'/9,2A49G9=I:;H86D57H8:G;8F88E7;G88D5:F5;F91217A39C95B59J9?P?AP@COB>G<7?17:-68,9?17@021&,)!,) +(!*(+)-+!/+!-(,),*!+,#/,$,* +)+),* 10$21(7:/27,.3(03(/0&0,%0/'/1'13)03'56*97/75-31)-*$,)$,)$.("+'",'"/,'52.42.5=07<0:B719B5:C8DK@KVLN[PIWOLZR[fa`kdjqpptskmlcgfchggpnbeeVYUSWRUWQSWPIJEUVLUXQ\`[€xvytoqonnollsqq{wz~|}€}spsvru}€yxzjkkTTQJQJEIBAB9BC9GJ?HMACJCBIBAE?<@::?5=A8>B7?D9>B7BE<:=4?5=>4>A7@D:4:039/35/782<;4<>4BC;BF=<;6:;469/;<3:92>96<98>>8<>4;;075,61+/-%.+&.,'20*32(10&0.%10%23(76+54*71*2-&1.%44+33,8926834905:15:18;241,51,88/::3=>61.(76,<=176.<>47;18=25=2B3;@28>.7;+68(14%23%75+65-67,6;-13)23)35)67+88,::,87(/.!+**'*'*(($)&-)0-!3.$/+"./#+1&/7/.6..3(11$-0$++ -+!/* ,(+)20%.,'-+')**(*%"2-'72-41)/,%0.%//&76,0.%.*!,* *) --#31'.*!.,!-,!*)))&&&%)(()-,!,+(%%!& %#%!'!("'"(#'"'#(#&"& &!&#$"$& "$"$"" " ##%$!""%$''#&#%"% "$#"   !#*,!-/!,.'+(, *)'*(,'%''$'''&"%!+'*+!&- '2 /8'8>/38((0##, )2(2<18D:=H>=D;36,/,(%#%%'(')*,"*-$).%.4)39-/3%,.!', )0$(1&)2&+1$). $,%+'*%(#'"&!'#*#*$-%,!(-"(*)+,- *.'/*4#,8'09)/4#-0+,'*')&,$,$.!&0#'1$€h[~f[k`„pbŠng‡ne‡ndˆoe…oc„od‰oej`r\QkTJnTLpTM|_V‡lbtj“xnš~t±’ˆºœ‹³–‡¹ ”ž‡|ˆpdˆocm_|k^yg[tcVq]MoYGt_PyfXxfZwg[sgWrhVshXqfVpcUreWtgVxkY|j[yhXwgYtk]ol]egWRSK>A8;>4>>4A>5G@7JH:TN@_VEaXGbZKa\Mg[Mo^Pr^OxdSjX|kXwgXkXO\MHTJFNKAFJ:?C8:=2<;3>?56:049.:;-;;0=;378/57-78.7;025+14,/2*-/)+.'.0#0/#21'1/%0/#13#3/&2/&54*7:-69-5;+6?/8A3:C67>17>08=,4;.58-78/48.3<04B48A66?4?G:AL>AO>@Q@?F:;?359-15)08+2/2=-6?/3;+3:*3?.8B46A55A51A14E26A14>.2:,3:-19,/8+18-06+09,6?25@/3A25=33@36E4J>:GFK>EKEFJDEIC=B;@E=AG>BG<=B7DH=FH@:=4C:??:=@8:=4@C:>>6<84>9:;<7<@68<098/63-41)52-52-850B@7;;022'66)36'66)55*4/(12&44+8:/6;25;27@66;26<349123*/,'72-872::577330+;9/;:/3/*<:466/9=29@36>0AE5@C4-9?.:?.;<)46%21%53*0.&55*38)42(31'53(63(99,:;-::)/- *(,(!*('%("("+'.+ ,* ,* -,!.1(182/7.03)11#+.#((,( /+#)%+*+&'" '#((.-",(%0*$/)"+(!)(('-.$23',+ ,*-+ +, *-!4-$.)+),* /1$(*%&$%+) -,".-!.+ .,"('$!#%& ' *$)$'")%'&%#'$#"&##$&& $"$"%#$##!#$("&%'*')'+%)%((#(%#$!!% $&*) ))*)(**.#,/ +0"-1"., **#'&%%!( '#$%(-$.9(7A09@/7<--5&-7*1=0/?12B46C44:-,-!,)$,.%,-!+-/1$.0$ $$)"180-0( %$'(!)-$)/%+3&,2$*0 )0 &,#'$(!'!($+ %."".&1!$+'+!)* ))++ ,/ '0 (6#)6&,7'/8$*/&+&*'*',#*&- (/#(,!}dX{cU}eV‚j\h`†lc„k`‡oc†ldˆmf…pc}hYmZLiVImSKvXSƒe^sm™}wŸ‚~¨Œ„¹™ÀžŽ»™‰½¨Œ~ugŒrb‰te‚o`p`yjYv`RsYKfU…m^€j[yeV|i\{j\xiWyhYvfYtdWugUxkY{gXvhWqiVsiWsl\ccUPOFED:A@6BA7B>5E>6HD9JG;KI568/56-45,.2)+1(,0%-0&12(0/%0/%20%10&10&00&56,9;/9=09?/:?1:?/:>069.6:-3:*08*2:.29.2;.6@04>27B5:D7:G:AN?BQ@:F84<113*24*16+3<08:015*16*-1&.2'15*04(15)05'-2#/3#15'25+03*/2(05*17,2;.79-47+48,37+27+.6(/3'04)/3(/3(13'/0$,0'03)/3(26'/3'59-29,3:-526J9;PA?R@BU@:O<8L95G52C24B35B47B57B5:C78A46=03;.4=05@23A32>05?24218-25+36,2:/.:,08-.8,4=02<03=/5?/4B35?27A4=H:DRCKTHOYMOYSQ\ST^S^d_lnorrwuwuwvtqonkjiill\db``_hjh]a[V^W[c\WaVUXR\a\oqq|{‚}€{|~|~}}xyz}|}z|}u{ztywpuomnkjhgic]`WIPCCJ>DK>EM@JNDCKGEKECF>AF:AJ>Q\OBG;CG;CH=BF;?59?27@4<:2<>6HIECD?>?:A?7?@3=>3:>2=@8=A;6;6:;2<=59?4;>3<<197,74/760782::4FEA:5294/64-75,34*31)31+45'9=0;>58=45=?7<=431)1,':3.>80>;3<:274,AC;..(775:97772870;=18<,;>2<>2<<165*99-A>4>>/:;.13'56+:>04:*36)22'55+32(66+35)32(/-#53(31&20$43%20$..#*,").#'+ ')'$%#*&/*!0,!/, .-$/2'.3'27+36(// 54(-- ++ ,*+)*''! &")&!(%)'('+* *','*$*')',( +)-+ ,, +**( '%+%+(&* */#(*-- ,,((++.."..#/+ )!#$%&&"&$&$%#&%&'(%(&&$'%&$# $%"'%%%%")&$("%#% #!%$($(', &- $*'*$"$#% #"!""!$$'(',), +,&($)&-!+-#,,")-"+.#)-!$(&%#!" !%"+)%.6)9?/>A18<,19,8C7>J99E62?10=/8B28B.5>1;6AC998053+66.23*.1(11'11'0/%-,"1/%1/%0/%20&12(34*;<0=A4>D3@E6:?0:>28=159.6;,28,15*3:.5>05>.8>44;/5>19D7;I:;L:9E84<115,23*16,3;.9<16:/26*04)15)16*35)24(14)05%/4%.4%/6+04)15)36*4:-6>/8;/47+37+26*17*.5(03(.3(.2&.2'.3'14(/3)15)16)28(26(27+19,29,2:,7=05;.6:-7:07;048-15*/3'04(03'/4'08+2;.3;./7)23'24(02&-2%.2&/2&06,15)04).5*.6+3>24F49I<9J=:K>?RB@V@>Q@9L:4F50A02A35A42B44C58F87D63@21>0227C47?35=16>27@46@44@36<26<008-2:/29/3=1-2(03(88.54*/,%*% ,&!+%*%'%*')% -&-) *))(*(0/&16*27+35*32(33(32(22&21'00&.0%01'/1(11'.-$)' +%!-$*#*$*'*( ,+ ,* 2,#2.)54.3509@9>D>=E>CA:@?7;:133)22(33)21(23(33'11%22'22)/7(47*77+87.:=37>46B8EI>GNCYaX@C:ILBFJ@DG<>B8?C8?B9:<2<=3;=3:?4@;=?8<<3;;0:;0=?4;>69>69>7<=5;=4=@5;?5??5<;196/65/993CC=YWS?;8=:5<<56905:18<559158-:=3;A7BI?FKA8=1INHGHC@<672*52*=;2@>7DA;GD>/-&>;5.,%@?8::445-77/7:.58)46*9;.57+22'34(67+23&/1$..$12(37*48+48-57,44*44*13(15)21(0/%-,#1/$.-"/-#-+!,,",.%+,#,-#-,!*'(&('-(1."2/$.,%)* )-"03'03$//!10'.-#-+!-+"*((&+(!*& '$(&&#&%*-!,-#'($#"$#&(%)'-+ /,"*)*()+., +* -0&)/#)+ ,, **''(())))*%#%$#""$!%!&%%#)((&&$$"&$&$$"%",+"..%*.#%&+)!&*),!.2&+/#(,*/"'('*(/"(.")-!-/#((#$"!!!!$"$"+* ++)+), +-!++''%'',!++!)+ (,!)-!)-!&+(($$""#"#%)+#.6)5;,6;+28)6@2>J>?H;5B44?36@3;D4?F5CILQM_gelrojqn`fdghe^YU+"('"&''+)-!+-"++ *+*+ (+!&* &)')*,"*-"+0#)1!&0 &1 -6%.5&,3$+3%)3&'4')3#*5$+3"','+&(#- '0#*4')3(-5,/7.r\Wu_Yr]Wu_XubVuaVuaUvaVxdYyeYydYr]PlWJmTHsXN‚e^‹pk™~xŸ„~¥†®Œ…´‘†¿š‡½™‡²‘¤…v‘ve‘xg‘{i{iŠwevdŽtc•vf°•€Ä©”Á¥’Ũ•¾¡Ž´—…©§~œ„t‡sc~m\zjYvfVqeTndRsgUshXmfUb\L[ZIQQCNRDIL@CG<1@:2IB8`SEgZKaVGbVHcYJYQBLI>A?5<:177.6:/;A48B38@359-02&21&20&0/'0/(41,74/84175065-41)20(52*34+,-$42(31'1/%/.$10&10&10&0/%01'56,@A5@E7DI9AG7:?0=A6=A76:05:,25*27+27,49-4:+78/58-8?2:D89G8:J97D65=247.36-59.3:-7:/6;/37+05)26*25)44*13&24(05(.4%18)/8,6;.48,69*7<-9>/<=259,26*26*16*/6)23)/1&-1&/3(/3'15)26*16'38)16'17'37)2:-19+38,48,67+67+6:/9>259.04'04(-1%24(14(18+1:-1:-/7*02&24'35)/3'/3'04'06+14)15*04).5+09-3>17C68F::K==QA?UB=P?9L;1D24C55C58E76E75D66D65B42?100.<.2@14>14>10:,28-07,/:.2>02039,11'1/'31(30&10&10&/.$/-%.-%/-%0.$.(!*$,$+#,",$+$-' ,+ ,* -+!0*$0.&0/(46-48/6:1QTIEJ?:<19:155)33'30(42'00$11%01&54+37+25*43)76,<>5;>6>G;=E=;D?6;=3;?49@4BA;AA;AB<@A;>?6;<3;;2;<2=>58=2:>4>C7;>49=2;@5=>4>?59:.73-55,:;5DD>aa[FC>DB=;;56<47?6=D=8?9;>75:49A7BKAENB?G;PWTEGB:4/?72@>5=C8BD>HICB@;/,'960<:1B@6:9045+69/6<04;-66-46*26(-1$03'-1%,-#+,"00'04)04)04)28+47,35+35+/4(/5)66+77-12(12)34+11(./%-,#-+%-*%-*!)&('*()'+(2,#1-#*)(* (),/#*, --!+* *(,* +))'+)/+ ,'.) (#'#'$*,!))$$&#""$#(&,+ .,!-, .*/+"+-!0."10&17+)/%&&*('&)'*(+)('*$$$%  !##$% *&)'%#$"&#&#%"&$--",/#)-!)-!*/"+1$-4'-4%.4&.5&07'-/%%'%)',#&*!(-#+/#**''$" #$''(',,"*+!+. &***00$,, &($%%('*&*%))-!+2%,2%(* "!%)-"(-",2&08)/6'/3$.6):C7>K?>G=:C97B57A4?G8?D5@B7GF<=;3>?9beemuvdgf`fe`ccca`SMH8/()$ %#$%#$%'$"&('+), *-!)+*)+*",,")-!)-!(1!)3"(2%+4',4&.5(,5(*3&*1",3$*5%+4$)2%)0#&3%)3&,6+,4).4*05,oc_tibuhctg`ue\ve\ve\td\ve\vc\q_YkXQiSJpVPw[U„hbuo™{ƒ}€y«Š€±Žƒ¸“¹”ƒ³’‚£…v’xf‹sb‹vd‡sbŠuc‰ta‹sa‘wf˜}hl£†s¦Šv²–‚¹œ‹¼¡»¢‘±œŠ¢}ƒsbxjZqcSjbPg_Pi`Oj`Od`Nb_MZYHVYINSEIPC?E9;>58:187/<91A<3E@7TI=[QEXQERJ>OH;HB5=;076,55,46-28,3:-5?/5=.5:.45)22'20&-.'./(1/*30+2.*3-*.-%/+#0-%30(20(23*31'10&10&0/%0/%10&32(0/%01'45+?A4AD8@E7?D5<@4>A6?C9=A76:-7;/;<289/79-58)87-67,8=18A4;F8>K;2=?3:=/469.37,26+27,17,33)01'23)/3(/3'15)16&16'16'05&27(38)05+05*37,56,53)77-47-49.59-37+04(/5(13'25)07*/8+18,17*00'34*45+05)/3'15*06+/4)04)05*06*/7,4;.4=07B6:H<25=03;./;-3=03=04=04257.-*$+% *' *(/-#2/)0-'-,$65,45+36)26*9>/8?069./.&2,%60(1-$54*/.%-,"-+#-+#-,$0)#,%.%+$+#*#,#.&,%+&,)*(+(!.*"0.&0.'21)77.>A667-89/67,43'55)4.(20&31&44(44+23*36+23)34*57-77/:=4@G?E@HMKGMHFNFHSHFUJKZR`idpsrzxy{y~yx{sssbda_d^]e]Ua[[g`bif_ecbcbijghhd\_ZNROijl„†~y€€w~€y}y~tpsnlmidemllrpqolofddSQOPPJMUKTWPUWQRSNKNGGPFLQFFKABD;EE@DD>HGBIKEHIDILCEH?EI>@D8>C:DG>@A8<>4:?4>B8??9AA:BC:AB9AB9>?5==7==6<=4==4>?5>B6>B7;?5AA8>?59:066,63+74,890DD>JJDCC=XUQ\]X09/FOFEPH?F@AE@8>86>7.'#C;8II@=F;JNIVUR?=8.)$64.@@8KI??>5;<19<05:/4:/46+36*05'15'+/#+/$,-#*+!,0%/3(/4)26+3:-26+67-89/69.06)67,79-8:038,36-.3*12(./%0.&.+"+('&*))(*(+(,+!,)(()()()(*)(**(*'(&)''%*)0+0+-))%&%&$)%)%'#$"&"'"'%-+ /-"/+ .* /' '+ -, /-#-1&(,!'&(&,* *))'*(&$&%$# !#"#'"*&)''%%#$!%"%"%%%&''&*(/,5%/6)/7*/6'-4&*1#-4$.1'),#&) (+"$+!'0%04(-0$)*(((($&%(')&(+,".1#*-+) *+ .0$*, )+(*&*%)$((/",3#)0"(*!#&&*27,-4'-4(48)16(.5(/7,8B6;I=;D>7@77@77A59B56;/45+1/&42)><7>A@IMNOTSV[Z^]]\ZYQJF?5.+&!$ %$%&&%&#&'(+ *1$%- ,.#-.$-+#,+"*-!,1$*3$/9(-9-.7,)/$.4)-2(-3'*1!,3$18(+3'*3&,5(,6)+5(*2')0&.4)-3(je`pieskfumfwmcwjdvkewkexle|ohwicjYSgRKu^S}e\‡ogŒtk‘xowm’wlªŒ²»–„¾šŠ´“…Ÿ‚tvf‡q`m]€m]|iY‚n_„o`ˆscuc’xf“zj‘xgŠrbŠrc‘wg‘zi‹xeo_tiXlbTe\O_[N^YMUPDWSCQTAPQCLP@MRCLQBFJ>CE98<36:19<1==2@@6>>3D?4EA7HF;CB7?<1=;088-45+12)16+07+18*5;,4:*49,57,13)01(-/&-.%1/)2/)2.(0-&.,#-,#1.&0-%00'35,03)02'.2'22(00&00&21'10&12(45*>@4;?3<@59=2:>3:>2=A6@C9:A28=1<@5=A6;=18;,64+66+:<0;A5AI;EN>AJ>?49;0:=1;A3AA8:=247-48-27,16+22(01'01'05)-2&-5(16&04'14)15)15*26*25+04)33)44*54*65+48,48,48,26*27(26&/6)06)18+.6)37+34(23)56,44*04)26+36+.6)06)25)04(16)18+25+4:/8@59F8:L>;M?:K>6F96F8:H:=I<:E5:B5;B5:A48>169.7;/2;/1;.39,38+39,09,37/9=54;029./6,07+.7*,4).4+04+.4)-4'-0(/3*05*18.07,19-1;+18*16)35*04)-2)05,38/.6+5>03<.1;+5?38D68F8:E84:0--%,* .,",* 10%43)32)17+8=18=169.36+9;07<.22'/)$3+(/*$0.$.-#,*",*"+( +(!+'"1'$.$-')$)&*%)$+%,$,%+'*'*(!-*"/,$,(!.+#0/&53-30(53*53)32(21'1.'20'42(86-64+:8198/89067.67.35,;<3BH=DIBDICCIE@G?AJ>HQFIUIJXP\hbhmlwvwyw{zy{jlk^b_]d^]d^W_YZa\bfdnpnpnornoomm_`_JLJnpoxxy{w|~u{|uyxuvlmm`badfehecspponm`__ONLWYTX_W^a\b`\ZYUORMJRHJQFIOEEHCEF@EF?KKDJMFGIBFI@NQIHKC@C;AF@EI@EF=AB9>@7>B89;6AC;DD:DE9CF;AF:>?6@A8@A9?@6>?5@B7HIF<@:;C842?44>56?6/4-24,CC;TQIHIB9=9>CAIOP`fgsuurpoZVQ=7/,%)$'%$#%$%$'$)* &,!).$2:.37/33)..%.2(-5)-7)/<-.=23>3/9.39-15*/3'-5%/7(-3'05)06(.4$+2%+3&+4'*3&+3&.5(id_lfanebrhbslfqifrjgskhslgtmfvlbnaVyh[€n^ƒo_ˆteŒshtjuj•{n¬€¶˜‡»”…½š‹²’…œq‹se…q`n_~l\xhX|k[~n_qa‹sbvgˆrc‚m^l`ma†o`„p_~m\reT_WIVMBSKAIFIL@EF9BA49>46=29>3<@4:>27;/;:086-69/8;065,64*65+66,45,37,26*07(59)36&79-48,59.25,14*-0'11&21'20&30&--%0-%/-%0.&./&,/&,4(-3(14*04*21(32(21&10&01(24)47,7:/5906:08<19=1>B6FJ<@H9?F9>D9>B7?C7AD6>>4CD9CE9AE9DIE;5=338.48-24(34*23*12)23*23*13*06,.4(15*99/;;/??3FG=GF=@?59:08=29@3@A6=@58<148-/4),2&22(11'/0&.3',2$,3'/4&.2&.3)14,-1'.2&21(54*32(53)54*33*59-48-614=06?25;.7>02;.28+57+68-59-37+5:19>44;137,07,48..8+.6+.6,-5*,2(05(25,23*25,48-48-49-/;*1:*49+38,04)-3(17.38/18.2;.3<.9D4=E:9E87F6:I;;C7,/&-+!0-"-,/0"44(77-6@28B27?159-56,67,34'/,#.&"0($-(!-,#-,"+)!+)!,)!,'#,'"3*',% *&*()')'(&(#-%+#,$+&)) +*"-*"+&,*"-*"1+'1+&2-&1.&2/'31(1/)10&65*86,84+;61>=4==4=>5??7==4JHAJNDILFORMAF@CGHFNQLMOK[[YZXV7300-(12+?C;9:7;<6<=3>>489/46,26-59-59*43$30$1-%.1&05(39(17'18*5;.47+44)43)32(44)68,37+:>2=C4:D4;F48D3AE49;-33'33'.1$&/.-!++,+!+* -*!.+#*+ )''%(&(%++"0+$+)!+(!)'(&)( 1+$)&)&'%&'+,"/-$.,$&&'&(')',$/)-)/+ )'*')) ,(($('*),'*('%&$%#""%&#% !$&!'#($'%$ # #$ #&#&#'$%%(-.7(+3)*2&-5*-5*09-.6*+4(19,/4',1%-2&/7)23)..&.*"+)!'$,+"/7&3:-.2'*.".2%.2"+-#(,"%-")3&&- %+(,!&+$+*1!,4%(2!,-!,."*, ), &* *-".1#-1&+3).7-6B73B51>5.=35F:>KAGOJdih€„gjbLMD>?67<4AHAENNELLMNO`^][XRJG>?7-+&('&&&%$"&"))!$)%-",2*39266++-!,3'19.4?36B6:J@`kbbkaQSJ9:023).6%.3&.2&13(36(.2!,1$+2%-4'+4'*4')3%hc\iaZkb\me_lgdlfcngbnhculhwli~id‹sk…z‡z‹wlŠpjshŒujzp“zp²”н›½}·“£‹|„re{i\k\{m]yl[|n^~o_p`†rc‡tf„rb}m]viYnfUhcSk`Sj_RncVf]OYTEON?PQFMNBVTFVUGRSBSTEHKAAHCK;CI:BE52?@49=159-9;/37+6:.6:.38+24'63(97+77*8<,4:*08(15(04)04)6:.26*26*79.44(33'00$01&12&/0&0-$3-$2.$/-%.2),5),5*/7*14(23'33&42(22(/4)-4+3:038/6:/48-38-26+;?4FJ@GOBFJ?EH=@C8AA8LLCIKBMRHMQECG;DE:FG18?27A4=@4=@55;028-15*44+35(02'01'/0&.0&01(22(22(34)44*02(.2(11(34*24*35+6:-6:+68,38-2;008./4*45)-5+15*35'78)33(01(//)./(-0(48-55*65)56*79,45+26*06(18)25.48/29.6?46@46A67C54@25?09C38C27A06=06?17@34=07?349/.6,18-27,37,38-29.6;/6:.26*.6(29,1:-18+/6)07*15*15)04(06)29,4;.4;.19,1:,5<,4<,4;,6:.28-17,49,4:-2;.2>.5@0=I96F:337,37,7;/30&.-"10%11%10%.-!*, .,"-+!(%((#)*$#(&!32*.-".,#+''&&&(&'#'#,&-*%/,$-,$,*",-#00&3-&0-$.."/.#10&30*41(40'72)41*76-?@7=:6=>6BEIMIW\Y[Y\^]^NKJJHCDF>EG?KWOZe_fnjikktqtzuy{yzqpo\`[_e`cdcefedgbkmjsuvtuyvsxuqvngmpnrutvqqq~~~yy|{~yz{vyvqtr{x|unvupqroojhg`a\[]XX\VW\S\`ZUYTINIQYQPWMOQKNUNR[VTXSKNGKRGFQEIRGJRGGLCCK@BLA?G=DH?GKBIJADH?CG=AGAOSNIKGGHAGH>IJ>DF=GIA@C;B6;D76A17A1AI9EN:AF5==.75*32&-+!-',(,)*),+!.-#+- +*(%)%+) ,,"+(-',)''&(4907;/(&($&$(*33&>:-41')&+( 0-&-,"'&('*(+*)&(',$)$*%)%)''$*#)%&$$!&&'$$!! %!$(#(&(!%!!!#"#"&$#"#"##&%*, +1#.2&,1&-2'-4**2(*.'-/'-.$,.!36&19)/2*/2(03',/$&**-$-8)9A1:?025%-2#,1"(0#'/#)1$,1%,0$+-"%.)3#,6&,2',3&,2&.-$0/$--!*)*)!)' */%,3)+3)29/<@67:16>18E66G9=JBNSQVRMFA962*35,5;2;B=CKGNTQZYXRPOAEBGJHGFC:5/)&('&&"#!#$#"$#&%''( (* )(0( 1-$?F?R[UCC>FFCJOJGKF?=564)00#,/"-."/0$56*/4$.4#,5',5',3$.3$-0%() c]Ye][f]\lccmjekfafa\j`]nd]rh`ze_…}°™–„t‡thŒsk‹vk‘|r•zˆ}´˜Ž»µŽ}±“‚zksbUsaTzeWxhXyhXyk[~o_€qa…sd…tdƒrczl\i_Oa\L^[M]YNUPDRN@TOASPBVUF`\S\WKb\Na]MXVDVWEQTGFL>CK>BK>@H:?F89B6;@4=A5<>28<05:-67,45*34)22'23(46+76+76,8;/7<.5;-/8)26*05(15(/3'15)/4'35)56+55)11%01%02&/0&0/%2.$30'22(25*08-/7,/5+/4)36+36+54)01'26+39.5:14908;079/68.25*;>3GJ@JPDKREORHILAFH>NPFORISWMRVJJNBBD9>B79B57A59C6:C68=045)34*34*/0'/0'34+57,65+45+9:0;@4:?3BG:HOBJOBGH<39>37=228-16+46,36*24)03(-2&+/%-2(23)12)34*25+16*26+46*44+11(55+77-87,66+57,27.08.16+58,26,36*66*66*44)/0&..(,,&-/'47,33(53(55)65+56,04)48+3:-39029.3<04>/4>14=24=14=04>27@44=03;-3>.7B35@37A55>317-15*25*34*99/8:/59..7)1:,08,1:-/8+.7*.7*.6)29,29,05)38+3<07A47A42;.1:-5=13>.5?/5?06>17>32<02=02=/4?25C2FGKELOKHIEEF?DE;ED9CC:FF=ED;CC:HG>NLCGJADE5<<59<28<0<@4=?6KJEYYSQQKEGA=?9460472AC=?B<;@99?97:434.74+12)6;3FMGQUOIHEEFCC@=0-'52*971;=6OLI@A;4:/39-34)32'/.&14)59,7<,38)56(7:+;=.58(02&12&./$23'22'./&/0'34*58,57+CG:AI<;C7:D7=E8AJDA?B;6,(!$ %$ ""##%&$'%%$$$&)(,),,#17,:>7?=61/,6:4DD?<:140&//#)1!+1#-3&/4)-4&*3#06)17)15&16&--#*( ]YS_YV^XVc]\da\id`f_Xg]Vi\WoaYvd\‡od“}qŽ}pˆwj‹vn“‚y˜ˆ~žŽ…± –ۤ¾§™¬‘€«—‡™ŠyrcWhWJq_R€l]|k[vfVreUsfVuiXyn\{n^wm__YLSSFY^PTXLRVIKL@KL@OOASRDg_RwobpgY`YJXUBYWETWGJQBBKH;=G;:C6:?28<09;/8<08<078.53+53*30(64,67.47,47,47,5;04:/1:/26*26*04(.2&.2&-2&/1%12&33'22&/0$01%/0&1/%30&53)57,6:-6<448116-05,07,.5*/0%.1%37,8<17;047.;<1@@6::0:;1CD:KLBOVIOVJPWJPUKGMBCI>ILCOQHQSGJOB=D8:A68C69B5:D7=E86;/57)45*23)11(01(67-:<0:8087-990?C7AI39?46<129,18+29,08+15)04).2'.3'00*12*34*05)15)49*68,21(/,&0,'93.81*85*54)55-24+26+68,77-44*65+32(0/%11&10(-/&0/%11'42(31&43+63-22,.0&/3)38+09-2.4>/4<04:/6>039-17,27.39/26.2<,6?/5?15=249046.76-42*31'75+66,36+/8*1;.3<01=/.:,-8*19-.7*09,1:-39,5=07B59D78B54>14>14>17A19C66C56C56C66@4.@20A26H:CQC;M?2=020%0.$-+!/*!-+!0/%33)48,59-7;059.48-04*11%03&58,38,36+13',1%04)/3(26+<@8`e\EIDIMGJOF,.%-.$1/%-+!)%+&+$+$/' -&",&,' +( -+ 1/%,-%++!..#30&0/%,,"-2&24)34*890HIA582tpn~zyb]]]ZXb__nmmqnpdacZXXgeefdd_^]WYZgiippsxuwjgie`chgfeefhhhjllgiijllrtuvyytwzvv{rpspmod``ihhoopwvx|zy~~x~yuxsqqzzzvuxwv|y~|x{likmmmijj^aaTUQcc_fie\`YPSNQXNTSMRUOZ]Waa\_]Vbe[t}vSZSLTJEMADNADM?@I??G=FLCFLCGMDFNDBD?HKCFHEDD=AB9BC9DE=CD;GI@JLCQRILNECG>DE@C:<>59>5<=48<3;A5;A5=A6KLDMMGKKEEE?<=75608;5BB<=@:9=79=7BD>;<567.36+6=2>F<<41.&96/HD@HE@D@<;=549/3:-:=0;;-33(36+6;/9=115(54(8=08<037+04(26*59-7:/57,00'12(26+15*7:+=@5DH<@G<=D97?59A69>2.2'//%.0&-1%.1&+-"+* *(,* -+!-/#+,"*+!*+!))&(($%"(%+* +.#18)AK>27,+* **66(73%<6,2+"*!+%,&.*+* +)+)*(*()'.*/+!,()$)#%& &"#$## $%''$$!!)(%( (#*'$##!#!$"$"#!#!$"%$,-!,.",/#(*-/#./#0.%0.$'%)'-+ +),.#03%25&.2"*-+-"-1%26*37*29-2;.2MJ=MNBSYNT^ROXLGPCFM@ORGTUJVRG[TGa[MhbSjiW\\KJO?FL=BM=AL>=I<;D87A48=08<09;/8<08<078.44+42)52*55,78/17,06+28-/5*/4).3)04(05)15).2&-1%-1%12&23'55)33'01%02&/0&23)44*8:.69-6;.9;459205,/4+06,.5*.2&14(48,7;07<13:.8<1>B7>B79>3DI>LPEMUGPWJRXLKSFGPECK@@D;JLCJL@EI=@G;=F;=G;H;9C64<.7=-7;/26+05*/4(48,:?3;:099/7;0?E8AJ=CM@CL?AG:@G:AH;;D7:D6;@6:@5=A69=217+29+29+27+47+03'12(-.$30+1/(23)22(35)49*56+0/&1-'2,'80+:3,;7-32(21(34+37,48,65+65+54*10'/.$1/%31)31'/.$1.$31'20&40(31*2/*00*/3(15*09-1:.5=.5;-4;.58-48-26+25*-0'24-/3,35(57+7;045+32*73-64,52+2/(42(67-:>36>05>22?00>00<.09-/8+/8+2;.2;.2;.8A46C57D68C66@35>12;.7?39E77E75D8:G;7D85J;4H9:K=8K:6H79L;?M2:=18<059.5:/9?5CJ>GKC>?5DD;;<364,73*72)10&-+!-)0+$.'!-' ,&!,&-' +( -+!0.$*,#-,#2/'20&--".1$19,49-45+77.<<5FG@okjb^]`[\e`a`[\YSTOMM987HGFnkmpmooknomrurw{xzxuwurtsqrhhg```lmmkkkhjjorqw{|rvwptunppnlntormihfeemmm~}€‚ƒ‚{‚€{€}vzzwy€|xwzyx|}w|sntmjlqprlnnWZY\]Ycc`bc^^a\VZTZ]WXUS]]Xbd^da\[ZT\^X]e^LRLIPGKRHKRDMTGFOECLBDI@GLCDKAAH>:=4FHAFD@AA;@@9AB8>C:?D;EJAFLBCI@@E<@C:BF=BG>>C:=B8>A8?A7;?49?3:@4@D9DE;EF?@@:BC;@@:??8A@:CC=<=7;<6KMGHIB<<546+38-6>39B68@67@6<@499031):7/>=4:9098/:<338.:B4CI9CE5;<26:/6<14:/-2&14(7;/6:.37+5:.9>2<@4:C256,//%./%02'06'46':=/9=0;?48?4:B7:B6>E:5:/.3'/3'07)07,15*33)-+!+)0/%01',/$*/#*/"-0%+-"*'!)' ('+* +."/7(8E718A44B16A17B27@14:,69*3>.5?/4?.=C717*26*-4),5).5(.5(/3)),#*+")-$&.$;D:GPF4<2+.()/$'-")+&*-%./%./%/.$..$+/'*2.?JHfrrU[[Y\[X]\]`^YVVLEB4+()!'"%# !#!&&%$+'"-*#+*)(,0&07+03(.."+(64-MOGVVM94-3/'14+26&35(66,11'01'.1%/5%-3%.1%LH:HH8JK?G;=C68<08;/5:.8<049-66+75*65*9:/7;/29-17,06*16+03)/1'/4'04(04(-1&.2%/3'02&12&32&66*56*13'22*:<1:<1;?3:@16>/7;169/.3)14)/3'36+25(24(24(48,6<14=16<2;B79A6>E:CI?DL@KQCNWHKUGHQDHREENBFNDIOEFH=DG;EJ?FOCEKABK@@J=:F89D39C39=059-48,37,6:.6;-9;19<19<1:A4?F9CL?EJ>EK>EL?BI<>C7AF9AE=AC9@A79:.58+38)27(38)35)23'0.#,+ /+"/-$/.$21'22'23(22&20'74,74+95,96+;;.33)00'12)67-58,26+38.13,/0)0.$3/&0.#11&2-$5.&2.%0.$/-$1-&31*23+24*15)07,38,38*47,46+46.32(01&./%-/&/2(.0&0.%21(56,47-56,67.42.31,//&34,8=29?429,5>14@2/=/2=04?J@7I:7G9;H;8G67I88N<@P>EWDM]LHRB9<055*22(20'/.$10'88/9:09:.56*55+44*66,11'34'46*59-5;/69.68,54+25*7<1;A6=C7<@453(75,55,76-;9187,56,43)42(52*-*".)"*% ,)!*( +) ,* ,+!++#/,$30(0.&/2'/8(1;,6;.78.41*3/+<;5EFAOOMTPQVPQJEEGB@EA?JJGHIHqqqnlpxsyvrs~||qopsssceeknmfffedevswmkommmv{zqwufmjbhedhgvtu}w{tponmmqqryxzzx|€z|y|w}~w}|}z}~||u{urutpssssabaQTRWWV^_\ab]^`ZTYSSWR]\YY[WZ^T_]TQPHY]WUZRLTIU]SMUJMRHLRFEMCAI?EJAJOFFJA@F=?A7AB:??9AA;>?7?A8?E;CH?EKAAG==C9;@7AD:HJABF=>C:=@7>@7?D8;@5;A69?3=B6=B5??6?@7?@7CB9BA8?=4?;7<;5>?9BC>DC=B?924+37,48/;A9=D:8@65://3*/1(57.98.98-32(47,-3(9B5FL/8?19=/7;-69-.3'-2'-5*38-;:076,01'57-56.26,06).4(/4',.$+,#,,#,* *)*-!27+2>339/$$.0'25*43'/)!,&)#($)&+),* +)(&&%)'*'+) ,* ,('"$&$!& & $"# %## $$%$# !$$ &&33)24)$'#$%#%#$ "%!$!#&!%!%&%#"#!! %!'$*(**+* ('-*#/0&.4(29-226>26>22:.3;/06+04)08).7'/7'-5(,4'+4&*3(,5)18,-4'(+!)+#,-$+/&,2),3)-3*-2(+,'&((()'"+,$/4)52+/,%+*"&+"5@8Uf_^hfCJHCHGY_^chh_^`SNMB;8/&'"%$!%%$''(&'% '%((,("15-5>346-.+!*(;=3X\SOOF2/'20*8=7KL?98.,*!..$,0$-3%-8'.7)19.17-/4(/3'XVPVWPRTIPPF[RIXOFYNF[QG`TIbUK}md|uœŠƒªœ–°¤ž¤”Ž—‚|Šupng„yo~xkwtckoa^bSTWGPQAJK>FG;PJ>PMBKK?GJ>DH;FJ>HNAINBFJ>DF;DI=MTFLXNLYNJXMDPDENCEK@AK@FMCHMBKNAKM?GK;AK>CO?DO?DO=DM@CG:8=179-7;/7;/5=069-88,::.9<019-3:+3:,59-26*23)01'-0%04(15*.2'04(-1&02&01%22&43'67+56+45,59.>A5>E89@06=.8<036+02'02&33'44(26'45(33'47+5=07B65?39C79C79B7;E:?HDK@ILCBH=@I=9F8:G7:G66;,47,25+59.8<09=.7<19>37=28?29?2;B5BE9FK?INACH624,1.%2+"..#0-"3.#3.#3.%/,#20%1.&42*86.46+/4%24*35*12(34*56.32,30(30(43).0$.0$.2&/.'.0(06,2;05>21:./1-13-24.27-4<0/:.6:.4=02?10<.2BVCM_N@I:<>165+46*23'22&55)69-14(42&42'31&20&53)42'43)34'34(26*13'02&.-$/0&17*9>29=158,54(/0&15,9=49=38<067.56,34*30),*"+)!+'#*) ,*",*#+,",,",*!0+%2,'1.&06).:*.7(27+11'/,$2-)3-+9=6=?;>=;?<;963=84JGACD?MNL_``ecee_cc_^dbaTTSOQQX[[aggbddnnozv{rosklmhkk\c^Ya[elelpo|{||v{vrstsrvuwxwx|z|ƒ‚}|‚|‚‚|ƒ‚{€€z~wtvupsolmnllXWXTVTSWSTRRcc`ab][]WTWQRUQVXUW[Uad\[YQZ[TSZSSYNY`URZOT\QLQGIKAFMCCG>MPGTULKNEEH?BB9CA:@?9>>8::4;<3DA:FEHJA?D;?D;=?6A@8>C7=A68?49@5=D62:0/7,/7,/4+8;27:-66(55*03(-4)6?1F9@J==F;7@62:0.7*/3*27,4;108*-4(/7*28*.0#0.$2.%10#36'58)8:+67'58'3;'1<'29&37(57(57,14)05+-6*38-;:098.79/8>289216,/6).7'15*-.$,/$./%-,"/.$+-",0&,6,+0'..(-0*.2',,"+&&!&#(%(&&&*&+))'*((&)'+'!*(*&)$'"(!$!&"& % #!!!%"&"'!& %#%!"  $ !'&),"%*',"%'%%'#&!#'#& $%( %#&&$!"&%(&++.-*)+)-1&-3(.6,3<009./6+05,+3*.7,-7-,6++4)/5&-3$07'/7**4'(2%(/%,4(18+37+,/%*+!+,#*.%)-$/2))*"-.%),#))*)*&".,'04*53/,,'/2)DMDEXLF_UP[UOTRKONFMNV\^]^a_[[SMK+$'#$%#(%%&&'%%"&#%&,# %*$0:37:0>90,++0$%+!#$-+#22-5=657,,,#')!+1%,7)1=--=+-;+-7+-8+/8-&0"WXQYVQUPLTOJWOHZRJYPG\QIiZSp`W‹wo¬š‘³£™¥—–ƒ{•x”~x•~u“u†xpwujhp`aeUVYISTDMM?IH>EC:DB:DC9DC9GG;CE9EG;EL?JM@FH9BE6@G;ITHFWJJ[NKZMIVGGOBAG:@H:CH>AH=AJ;AL:@J=@C;>A9>D9?G;?L>:J9AJ?>E:9>38:.:;0:<08;/7=19B59D78B44=02;/5<059-47-23)11'.4%16'58'68(47'27'36'14&44(44(64+96,29,29,5D7>C7;@6?D;EOBOWLOUJNTJPYLLWIDUB@M=@G;@E;DH>FK?GOCAK?9D86C5:C69@48:/7;/6:-;?3<@49A388/8;19=29?48>4:B7;C5=G:BL?HJ=HI=JL@KPGIKBFF268,38)23&0.#0+"0(!0("/' ,' (&-+#,)!1,%24(;<165+88.57.8=4=D5?E729,3;.5=0:B5;G=CMA=C767,1-#2)"2+$.*"/.$21'/-"1,!10&10&66,46+15)16'41)44*25*15)15*14+/0&02'23)01'./%01'12'05)48-4;06<2/7-03(47/2601823;22<04=24>21:/2;.326@19C26@03<05;017-38,5:,;>4?D8DL>@J=8A45@62?.2@05A55D78I<;PA?P@CSFBKC>E:;A4:?/<;187.57-89066-1/(42(21'31'0-%2/'51+31&31'42(0.%0,%/-$-* 0.#42&89-;<047+21(.0&6:.;?39=/:;-88-88/48-.0&*+!-+!,)!,)!.+#-*!,*"/,#0,!/* 2-#00$36*28,15&03%21'0.$1/%33':=-;?/9<.97,64+:9.>>8CE@CD?^\YKGFRLJPNJSOKHE@HIDWWS`^Zgbannnuwvggg`a\RZPQZPV^Yu|zw{}xuz€y}|~~€xwytsx€„…ƒ~z€x‚{w~wtwljjdeegiiadcW\ZW]\LRN[_ZfhenolUVSTZROWMMSR^cacjdad^_d\W\SU\QX\TTVQNNJILGGKG@F?HLFRWNQWNLRIFJA=F;?F;?A8B?7?<6A?;@B8EEEI?HNBHMBJNCGK?EG?=@7:>4:<6<=7<>5:?49@55?39=2;=3@?5:8073,82+=6.51(1/%10&03)13)/0&/0&54.:=7;A;071*1,,4-19/;B779-:9+67+55)22&55*27+6>09<29B95A94<55<52:4371.3)37+37+26*56,32*0/%-,"0/$11%11%/2&03&25'37'47(15&24)66,26+26*59-3;,57*56+45+37+59-7:.49-58,/3'79.54*1/%)1%/2'.. /-#+,"+.'+1(59/23)21'/-"-+*#%"&#'%'%*$(()(('('*()'+%,&)#%#&#$ & $ # $ $ %!&$%"("&!&&'$ $!$#&&&%%'')')(*')$&&&$!% *"& # !"!!"#"!! # '%*(+)., ,+-../!,0#16)/6)09+08.2;/.:.-9-,6(.7*-6&.6&/4%06',2(*1)*4(-7,/8--6)+2%'/")+--$*,"+0$),$'*!(()+ *-!*,",,%..)33-0.*,.,ALFHTLNWMJSMOXRSZW>C@SWV[]\[[Q[TL%*'!%#&%%'&))+ *()$)#$%(0%7;541(0&,(!-)!)&((((') )(** 03(/6)09,0;,4;-.7*+4',5(07*38+WQIUOFVNFTJCRIDSJBUICYMEYJBZIBhUMvd]ƒsk‡wo†vnˆzq‹{t‹{pˆzn€wnsrgcj[_dUV[KQTDHI;HGA8>?4?>2@B3CH;Q[OFVJIYLK\OJYKFSCCN=AI=>G=?H<B9;>4<@5D59A78?4>B6>B6;@5=C9DN@IREMUHQYKMVIJSEHVCHTCHQCHOCGNBIQCKRHCL@:C88A48=16:-9:.:<0:>2=B5246*16(14(21&1.$0,%1-%0,$-*#+*"++#.,$21(5;1>D:7;146.5818=59D76B51?2/=04D6;L=?LBCNB;D704(23(1/%6/%/,!1/$/.$20%2/%01%0/&/1'15+/4)-3'22)35+37+15)25+32*32(/0&23)23)-1&.2'.4'16)06+39.17,.4)/5)4:.6<43;12=04>15?31;/2;/1;.4=03TE>VD>LA7>4?@8AD8>E6BB7=>4:?3<@567.64+78,67,21&10'41(52)31'1/%20&0-%.+#*(1/$53(02&89-;>248,55*34)7;/9=1;<1:9.78/57,59./3(0/&/.$0-$-*!,* ,* ,*/-#-, /+ 0.#20%57*59-36&13%0/%42(42(87,8>.089.87-87-=;4<;4?>7<;5A=8E>9@@9A=7>=6FHARWO]]W_\Z_`\]_\ZXTWXPHNCW`Wsytw}|qstuqv}v{yxy|z}yx{~‚…„ˆ~‚‚|€‚|‚yu|xtysprghegijmpn`caaedX\ZSYUcfaklkklkRRNX^VJSHRWSagbeicbfabga\`ZT\RGLBFIBLKFHJCDG@GHBLLGQSJTWNPRIFI@AG@AG@CD>CD?CC>@C<@D:FG>II@IKACG44<169/9:1;:065,53*40)3.%1/%1/%10&-/%,1&13*77/BE;>A85>51:1.4./4.38/69.43(41%77+34(00$24(48,4C5?E5>?439,18+28,26,36+48,78,0."/,!** *+"+0&/4)-/%0.$+*(&'#&$%"%#(&)&(')')'*(*&)&-(*%)$&$'%##' %$ &#&"#!%#%#'"& ' ( +#'#)' ++!**('')')')$'%'$&'&%#%!%%#!!$"!#""""   $&$)(,*,+++++,. .0$*/#+1$.4(/8+.6+.7+.7,/7,2:.2:,38)16'26(05(/6+07,18,16*05)/5',2#)+)+!**!+-#)-$),#'*!*/#04(.2',.&13-.5./5/4<82?9FUNW`Y^e`cjeV[V;?;24/340JI@IC:,$'$"$$&&&'))+,.!-+"*('("'")$(() ('+*+)+* )'+* /.%,,"** *,"/3(,3&28+3:.,5()2%+4'5:.9:.RF@UICUICTHBSHDXLG[MG_PJdRMhVOo_W|jcŠwp”ƒ|—‹„–Ž…Š|stg~rdxmemi`ehZbhYZaQRXGHK.IL=Y`TT_UFUJFXKGZKGYHGYGFOB>F=>G<>H:7E55A4;?4<=2=?3?A5;C37B16>34<17;08;/8<06=05;0418?27=1528=07@06?33:/7;/:>2=B6>D:HQDFPBFN?QXILUHFPDLWEOYHPZJOXINXKMWIIRGAI>9@5:>378,66*22&;28@38@39;08CG<<=39:078.35*/5*36+44)30(1/'20(0-%.+$./%.0&/3(58.7A7>G<9@94:34;44=44?42@30A30C42H97N>>J?13=/2<00:-4=01:-4=01:.5<-4;-08-1:.3;03;/79/35+58.6:/3:-5F:AH>?H:9C69D89I=:M@:=3?<4?@5=D5=A2;>1:>2=A58:/67-;>28;/35)11%21&41&/.$/,#.,"/,#-*",(!31'66,23)48-8<138,67*46*7:.57,68.9709<19?46<1:>2;<0:9.32'00$.."--!.,"-,",-!//#21&31&21&55)14%22%75+98-87-88.9?09>2;>29;/98.;9/76+97.:8.;9/=7/>6/<<2@=3@?6CI>NVKW[PSSKKOFIMDa_VWWNJODpworwuZ]]mko€z‚z~{€~}€ƒ…„‰‡†Š€„‚{€}ƒ}z~vsughfpplrusuwthnlflg\b]`d_nqosus[\XQRNNULIRGPWP\`[_c^cgbcd`[]YNWKW]TSVMGH?GJ@DH=DF@IKEQTLRWNLQHEJ@DHCFJCBF>EJAGNBCK@EH?DG>DG>FJ?DH=HMBMNEKNEIKCDH=DH=CI=DN>?F;;E79A65=309/8:/==4:;198.75+32(/-#10&21'01'01'13(36/;=49<36909@75?446114-/1(32(20%20%32'//#11%24(;=18<06>18D7=L>AN@EPD;J>>B768-9;/79-77,54*42*20(0.&0/&31)-+#&(,-#12(01'./%./$-.$/1&/1%46*14(35)12#11#02&68,GL2<>1=@4=A5==8980<;0@>4EF:SVJU`VHWKDVIDWGDWFCWFCOC;F=;E:19=1=?1>A236>19>3:=16;/6=05;05;05=07>17A23=-618=16:.45,23)12(/1&57-;>3:@59?47;078.88.65+35-23)01(00'31)20(44(57+68,6;/8?16?/3>008+16*9=1=C6@H;EOACN=BK9GOAIRFFODISDLVFMXHMXHMWJKUHGQF@G<:>3:<046*45)77+79-9=19>28>17?29DJ>CJ=DICF;=B65:/37,44*35*05*46+53+0/'.,$.,$-+#/-$01&01',3'6<05C8;H=7@85=63?75B94=21<1-8-/?17H9>PBALA13=04=03?37>1<2:?39=1;<2=<2;:0AA8<;1<:0>8094+;7.77-<:0>=3@C9EK@JNCINCHODQUJjj^NPCQZMt|u[`]pnq{w|ƒ}ƒ†„…‚ˆ†„Š„ƒ‡Š‰†…‰‚‚†€|€||y|nooffdwxr|}}txvdig\c]^`\cc^hjifheOPLMOIJNIMUOZ]Wglfilhdea`a]XYURZOZ`VNRIIIABD:BG;CJCIPIOXOMVLDMCBJ@ILBBH=EK?HRBNXGKUCJNDEI>DI=CF=EH?GIANOFMOFDG>DH=CH=EK?BMB7:=368-03&0/%0/%01'12(22)45+24.34*44+47.6<16=299321*0-&0/$1/%30&11%11%13'13'34(24(49*8C2H<@G:CC4:9-52'-)0,!,*+* /-#32(21'*)&%%%$#%#%$)(((*()(-).+ /+ /*,(*&)%'%'$(&'%*'*$&$'&/1(2/&/-#20&.-#+&,'+**(*()'))+*%'&'%%'()* *+!)+'%(#&!$ $!#$$#"!!!"#!""""#$&$*()(()**)))))(')%%''*,"*-"+/$')++!*, +,!.1&37(68*36&.-")((**, +-,+++)(** 01'/0'+-$*/$+0'+0'(-$',"*0$05,.2(671?E><=85.,/0+(*%890<;301',."** .(*&&%'''%&%&($),1!02%+, )/ 13)/.#.+#/-$,,"*+!+/%,0&15*1/&,*!,.#56+/0'++")(++!&)&*$).0$.-"-)I@7SI@YMEZMEXLF^QJ`QHiXPub[Šwn—ˆƒ©˜½µ¯Å¾·¡˜’znhp^Uk]Ph`Sg`XeaYbaVefZfk\X`OJTBDH:@A5DG8CG7>A2:=29>2:=18=4::1<90><1>@5GLBKWJKXLBRE>QB>PB?QC?J?8@87?67@38C47>48A19A1;@0@B3@D6?E5:A67?47<16;.3;.1;-28.48-69-6:-7=.7>.6:.59-37+26+/2',1&/4(/5)-5)17+48,45*34+23*23*03(27,:=2:@50?C6@G9=E78C23;-7;1>B7@F9AI:CN>DN>FP;DM2:>27;/7;/8C3;B3?F9AJ>HH26D69H::F:9A89B89D7@J<@I9@B644)/.$10&/2&04(11%33)13)03*38-4:.24+16+18,/7*.3(35,32(55+48-27,07,.6+.8,/9-/9-0:-0:,0:-/9*/9,/9-.9,/8,0;,1;/3=05>13;/2:/1:/4;-39,15*16+18-2;/5;318.3;.2:*6?04=05>4:C79C6>I=K@;NAG=AI?FM@AD877(35*57,66,63+0-%.*#./#/.#20%20%22&12&44&87*96,65+55,79-8;08:03=?4?A8<=3:8-<9/86+:9-67-<90=;1=>3>>4FD:EK?JSG^dW[^QNSHN[Pephmtr†ƒˆŠ…‹‰‡„Œ‚€‡ƒ‡‡…‹ƒƒ†ƒƒ†~{|}z{uuuopnmnjpsnjkidhc\b\W]X^`[`_Yadc_`^SUOLNGJPJRZRehdmqmjkg`a]\^Y__[WZSRTNGGB?A;?E;DK@AIBHOIIPGMSILQHNQILODHMBEL?MSFSXIQTGMQFCI>DK@GLCILCLNDSQMQQJBE;AF;@G;AJ;?H8?I9@M==M>AQD>MA>K>;G158.25*45,67-34*33(42-20)20(32(57+48+34+1/'.+$10&0/&..$0."22&13'13'32'43(12$6:,38*9=0=D7;G:;D65<-6<-6=.6:/46,12$33%21&65*11&.-#,/"-0"/1#02&,.#,.#11%//#.-!10%0.$.+!.* /,"--"7:.FL48:0*+#(*!()!+***((,-!11%,*G;3O>8^LEbOG^RI_TJaSJjYMiWM†sjÌ»¸ãÙÕÜÚÔÍÉĨŸšsc_fYNd[Ma`Q[^T]aX[aU\[PW[NOXFFQ@@G7AC7FI9FH8AD59>2:>2;?37;17:0:9/;:/<>5?DOB=MA;J?46>2=D7=B9;F4;C38?.>C3?E5;A2;B78?47=218+08,.8+25,24*55)33'7:+=B1:>2:?27=037-37,/2(01'-1&-3(-2'13)21'12)34+55,26+47-3:-7=28>37=25;007,.5+25)24(12'34(44)77+8<,8<-AE6FM>KQCFOC>I8=F7BE;EI>>D79A2?J9BL9DM:DL;>H9CMDIRIJUJFUGFREHQGDKB=F:6=315+38+6=08A49A4:A42>C4=D5?G:@GFJ?EK>KOCKQDEQDFK>349.25+32)53+42*1,%0*#0,$.+#1.'2-&2.%32&25)18*/9,1;.2<07D8=NB8K?:E=6@63?32@44B55E4:F:6@67@6;C8@H:>E68=346,33)21'12&04'65+64+./%24*6:.8>.56-25*06*.7+.6*26-54*67-6:/29.08--6+.5+1:./8-1;01=//<.0:-0:./8./8./:-1;.2=.0:-403=52;03=06@05@05=/5:29C68B58F8?L??MB@KAALA>K>53808=2:<288/85+31'32(74,52*1,%1($3,$62+20&00&./%11'/.$-+!.*#-(!3,%1,$1/$20&/.$00&79.87130(30(75+54)57+7?5=F37=28<358/86/97-87-:9-68.=:1=:187-<;0E@6GKBKTHT[MLQDJTHSeYhum{ƒ„…„‚‡†ƒ‰„‚ˆƒ€‰}„~ƒ|z€|zzy{zxyvvt|}{nomfifhlifecae`\c^Z_Zbd^db]oqqhkgXXTNQHPVNY`[ikjikiefbefa^`XZ[QKKFDB>BA=DE@FLDGQEBGARVPXZQFE=\YQWTLTTNNQLIMFGKEUVMVUKMRGHODMUJIPFIJBLMDQNIFH@@B:@E:@F:C6EG9:?47;058-78-54+43(52,2.'20(21&55).1%./&1/'1.&1/%--#*.#/.#00$/0%/1&21%0-!1. 32'87,86+9:/;D9=G94?.3=-8?0;B6;@6BF:@B7C6=A5;?49?29@0;=18=15:1891=<2=A5EM@MVIJTFBPD9D;9A7:>5:?4:B79C79C47A08B17@19@46<27;39<369.19+/:*.9*18-/6)35)25%59*;@1;C68A49B55?23;.-5(13*.2)16-05,15,7:128/36.38-04*48-59-49/7=36<16=/3:+18)15*26+48-69057/790;=0;A2BK;HRCKUEFPAEL=CJ;BIF8DK:DOAIWHFTHITHDMA:B78=458.45+9:-;?09B27@59A7=E8;?268)55'76+=>2=@4>D8CFJKBEI@DKAAI>2:D88A57:12:/1:/36+22&65*66*33&21&13'5:-4=,3:+17+17-/3+58-27+14,08.0:--8+08+05*25'59-6;.6<15<118,0<-2>11:./7-19..;.-:,.:.4>45>45?36A4:A46<119.3<12<02=19@34=17?56=37;08:.6>38A66@39C9>J?;G<=D<>G<@I=;E84<06<24<15;17:/<=3=?3:<064)54)67+45)32(/.#2*#1+%2/%0/%10&0.#2/%0.#.+#.,$0-&/+&/-%/-&-+#-+#12)99173+2.'53)54)24'68*7:3;>5>C8?B8<=19:,19*12(0+&6-*/'$+'!/-#/."22&/.$01'34*86-53*87-::0:>147,75+:8.<;1:8078/46-77,8:/:9/87-86,87-37+9:098.76,:70?>6BK>LSHGOCKTHPZQanf|}}~ƒ|~†„„†ˆ…‹‰‡†…‚{…|„|yxw{xttxww}gmjckeeme_dcbgdaia`faiojimmiklfhgX^XTXS\`[cgalmiklgfia_cXWYRQSMHGCCF@DF=EJAINEHLECF@hjdab\LNH_`[Z\V[b^KSLCHBDG=RSNSRNRTLNTJOXNLVKDL@GJ?AH@H=9B7:B79B65<01;.:F9:I=@NCGRG@I>BO?F8?@6@E88=337025.44+65*05*/4+02)+.%22(21'12(/1'0/'0.&20'20&3/!2.%./'00)02'12#11#;6+;7+42&68,8@3;I;9F85A16B5:H258-01'//&02(56,46*03$/2#14%6;,46+11(1/(00'.2&10&--#+-"/0&56,KJ@_]RMRFFSE=K=>D9FG;FJ::@02:-59-/.&,& +( +(*) ,, 0,!3/#.-"-) ,* *+ *.!23#0/!++****'(('(((&+%)#)"+"-+ .,!((((+,#./%*$!,& .( ,&*(*&'%+( *')')'**+* '(&'** +* *''--. ++$&"#$!$"$!!$##!"!#!!#$$!%$'&'*&**,+*,*)''& # &$&'())+ +, ++''%"%"&"&!$#&$)&&&%(&, .2)43+-&,&)().#-1$-/"++!))&)"',$*.",* +'+(++)+++ ,-$))"'& $(%)((((%&$&#(#''#$""$ %$($(*'1&09.7@6?H>AK@AOCHLDEA>20,+,'%*")(%)!$,%)3,190,1'31)33*)+#(+"), '(VHAVH@_PHbRJaQKbRJdULfXLfWMcTL^NE[JDVEBYJDYKCZNBUJ=QH:OL>QTGYbU\i[XcXS]RHSGENB?H<;B6=A2>A5;>4:>2;>2:>/;=18<18=4==4>>3G:DNAEOC@L@:H<8H;7D97@77?4;A6/7=227.4906;08;15;.3=/-:)27-37,45*22(67*:>0;@4;A48A46>14:.38,26*05)418>2=B6=>6:<39;159-6:/6.7:/59.59-7:08;1790;?3>E8CL?DOAFPCFOCGN@BJ=?E99@45:/37-2:-9B5;E9;E9?G9EK;DO?JTFHSGIUIBMA9C58=37:/67,:<0?3>@4;?2C8AC9@E9AD9FG8E98F:5E75E:6E:5@63?25>38?49>14>16A438-54)55)76+20&.,"21(48,4<.6<.5;/49058/36-16*03*06,/9,.8+.6*04)37+6:-59-49.4;/39.145?37@39=249.28-6<25=20;/8@39A66?53;15:08>16>35=34<05;26<36;1472:>4:@57=17;033*38-8<079.89/=B6;@476*65*57+13(42(31'4-&1-%.,".-#.,"0.#1,#2-$/,#2.'2/'/,%1.%.+#.,$,+"2/'66-2-&.*#1/%21'57+79,:=3;>517=167-2-&3)&.&",)#.,!0.#11%32(44*89.62)53)87-?>4=>17:-96,98.<;187-64,54,35+=>5??564+75,86-7:/::098.:8.=;3?=5CK@KRGHNCah^v}ww~{~~…‚ƒ‡ƒ…„„†€……ƒ‰‰‚‡ƒ|ƒƒ}„}„wv{utwytt{zz{||ntsgnkhojiijnpmnplqspwzweggehgbec[_ZY^XjmjoqprsrjlgehaZ^VUYRMQKLNGMPGIMCGMBHMEEICCE>jleXYSUVS]]Zab_hljNRMBE@EIAILGLNINNIRWPPYPGQDGODJPDBJ@?G<=D:9@5;B7H>CMFCJC@G>AL??L349046-22(53(24*03)-/&-0'02)/2'/1%-/$//&20'32(44(20#11'./).1*14)/3%45)87,96,10$04(8?2AK@AMEAOC6N[OSVO41++)"')!+,"** (+")0).70GOENTI>>4:<3?B935,&&((OA;RA;\HDcOH`OIaRIcTKfXNcVMcUMdWObUNYLGTGBOD;LC5I@6J?5J@5KD:SUIYaTUaTS^QHTHBMA?I==G:>D6:A5;B7;B7=D8=C4<>38>3:>5?@6@A6?F8=F9=G:@J==I=8D97B86D96@46@48?4:D78E79B67@35?17?48=36;239.7=26<16=05?2.8+35+44*32(32(44*45+:=1;@4:A47>15;.57+59-5;/6>2E88=37=26<16<139.8>38@5AJ>DNBHTHDQDAL?BJ?>F;8@58=26=127-7A28A5;E9@J=?G:BG9GO?FNCDMBANBAL@@I=@D89=1:=1>B6>B7=C8F:AJ=>G:6=226+45+20'4-&1)"2+$41)43+47.55/21,1.'1/'33(03(43+35,06,;B<;I>9J>:MD=OE;I>8F:7E82A31B83B72>42:.7=23:/7<05?13>239.11(10(0,#0+$0*%42)57-603?-4>16A47@56?56>34=058-25*39-7=26@35?2:B65>33;1/8.07-3F:RVL€ƒ}jlkruv}|}‚ƒ‡…†„†ƒƒ‡„ƒˆˆ‚‡ƒ~„†‡}ƒyx}wvz|zy€ƒ„x||xz{uvwywx}|ƒ„‚ƒstrilheidimh{~|€ƒ‚€ƒtywjomcid]`\UYSX\WW[SPVJIODEK@EIBCGACGARVPSVTRTT\__dfh||zSTQFJEEJAFKDGLFWWT_b]PXPNWLKUHIREEMB?G<;C86<0:@49@5C:DHBBE?CGA@H=BK=EO>FL=MQB?D9>D97=247-13)01'12(0/&//'.0'-3(-4)/2$-/#,-#11'65*87*68*89.03*24..4*.3)16*47,76,32(/2'8?2JSFNYJHP@EM@BJ?>F?;KC;KA=J>:D87?15;,06'17)15)35)44*87-88+88+11%32(43)54*/2)-2'-4)-5(6;.=B3@E9DG;HK?EHG678,11%/-".*-(.(*(,+",*"(%'$*%-%+%+),+!(+ (, &*"+/%-.")+-+!-*",-#-+"('(&(&'()('''* %(('(&(&*#)!($($+"'$&#$!$"#%& ' & &' #&% &$)((('()&)'%#&$'%%#"!!% &!%("("'$)%%"&$(("-*")''%&$%' ,.(.+$0.%.-#+* )('&&')* (),0%(,!)+)*('''+) ,,!$)$(#*%+)+!*-#,1&,2'/6,AI>ISI8:231'..$/1&/.!++!),#)/&/7-6>336,;?4:=5RSJCD;.-".-?1.F60YE@dOIaPJaRJ`RHaUK_QJ]OIYNFWKDSIBOF>NE;H@6H>4H=3I=3H?5KG;PSFU[KT[LLSEFNABK@>H<K??J>=F9>@68=3=?6EB8DE9CK;?L?9F::D9=G;8A74=33@47C78B77A35?28B57A46>34<19A68>38?35=28>37>06=042E89?27:/8>/5>/9C3@J:?G8;@2<<2:<39=28=24;05>16<14:/536<16<18?3?E8@H=@K?BNBFTHDPD?I=>H<;E9:B78A6@I9?B6=A59@3;C6=D9@F:=F9=E8>E8:A4H8?H;=F94<.25+34*43)4,%1*"4-&42*9907:04;58=446,/1&02&24(63.43*44+;A7>I?04?.4>18B66@54<22:/09,35,03(5:/6?31=<086,;;/==1>=389/=A7=D;>?257,47-36.46,66+31'/.$-,"-,"-,".,"/) 2+"2-$4/&4/&20&32'20&20&32(21'.-".+$/,$1.&42*54*87-87-8;19@39@3;B59?287.11'2-$0+".("2,$10%41'75*42(64*74*50'94+:7-97-77-77-::-77+66*:9/;:087-;<3FF=:;29:19:18:068-=>4@?5>=4@A8BDCH?GLFEICSWQVZW[]]VWYfhkonnY[XGHCQWMPYNV\Udca]`\TZTNYMJWJIVHCMA=H<F;;B76<059-58-56,34*32)20(12)/4*.7+26)/2&23(45+23(89+:>/9=136-79314.04/;D;@C;=;331'22(8:0@HE95:.45+:;0;:199,88*:<,88,44)11'+-%+1'19.7@3;B3;@1/4;+89-8<,7<-5;*6;(9=*:<-64(03'2K=DM>?E:7;024*00$++ ,+,+",+"+)!)'+(,*.',&+).-#..$+-#)/$(/"+/#,.!-.#.-"./$+, )()'&'%'++!*+!),!'+ ()(')&+#)!'#)&+$& &!(%&#%"%#& %#&' ' '%& &#(&%$&$'%*('%$!! "$%$$""%$&&#$&'34+45,+)!(&&$&$+-';=499052*10%0.$*+!-)$)'"==6DF?69/59045/0/)2.)/,#0-%,)"*))(''%('()* *-"+/$(* (***))++(+&(%)(.-5%+-#,-#-0%/3(28,55FJ>>B7:=3=?620(//#*+?5-E71TD=_MGaPI`OH]QG`SJ]QIWKGUICQG@OF=MD;JB9F@6C90F<1G?3IA3KD5OI;jaRkcS]YJRRDHL>BI<2?E526?38@34?07@26>35=28?2:A37@48@38?25D7AI16=08@49C6=G:=E8>E88>57=47=35<16>37@3;A5E8>E8@G9@G:AG?L>BN@EOB?I<I;F8=B5==4=@5G:=F9E8=@8?B8?C8=C5>ID89C47@34;/47+44+32(/+#/*#3-&50)65,8;28C9:C85;003&01%/0'0,'2/)64,;>3=G<>MB;OF:K@7D:8@56>16?12<22:014+55*8;18;189-28,19.04)33'21&0/&1.&41*43+58.6=19;348.38,46*46+57-87-88,47+47+37-06,37027./3*25+15*05*25)16+18.4>24>14>/3=07A54<219/08-19,35,16,7=2:E7AN@@P?=I;3<126.46,46+56*31)2/'1.&0.$2/%51(41)55*68+/<@5299-2.&2.%2.#2.#4/%71)44(85*31&20&83*:4,86*75*76+54*45+45,78+76+99->>1<:0;9/@A7@A8<=4;=39=369/9?2?B8>B7@D:?D;=C:?E:>D9LODQULV[Vagdzx…ƒ…‰†‰Š„‡‰‡ˆˆˆ‡‰ŠŠŽŒ’ƒ‚‡}|}|~~~~‰‰ˆ‰ŽŒ‘‹ˆŽ‡‚‡‡‚†„……‚†‡†ˆ‚ƒƒz{oqqosp{~|z}|y{|{|€~‚…w{|uxwsttuttsrsbieOUQCJBDJAEJADIAVZU^b]adb_aaTWVnqqeddTUROSMTYPSYP`f]ba_]^YW]VR[RN\QETICQE@MB=H<;E9>G;=F:;A37;-7:/7;09?5;B8?F<18/9<067-87211-140OVP\_ZFD>2.&/-#20&;>2EH;LQAPXLMXMFSKMCCQFBPEH=?H<9@46:004)76-=<18:-6:+5:+49*36)-.#+,#-1(2:-9B4@G7DI818A3:B56?2BC8BE:EG:AD7:>/7:,;;/=>2:=.4;+7<*:=+8=.46*15+4>3?K?HPDGJA7:/58-11'-."/0$/.$0.%--$**")) ++!,(!,( *(,* .-#-,!(-!+/!/3$.1",.#--#+.",- ,- ++((%')(-,"+/$)-")-")))()%)%&'(()%(")"%!'%)')'%"$$&!("% ( &%$&"'$+#($)&&#"# %$!!%*0'38,%*05(7H>=G<;A5;>3;91;80;6/>6,:5)7;+7G:8D85>32:048/47019.2:/3/4=07@38@18A08C69A48?27>16=2/7,37)48*58)8:.7=05<19A3>H;CM@?H;9C79A35;06=26?48B7:A6>C8=F<>G==G;8B65?4:D7=E7>D7?F9AI<=C8=C8?F:CI>@G:L;>J:?J:AM;?K:?K9=G7>H:@J>>H<G;@G5@D9?F;?I;@J:DN>CJ;CJ;?I;?H;>H<>H=@K:D8?D9;A58?36@05?14;.48,45*11&.,$.*"0*#2,&20(54,3@5;F:8@36:.66..0%/+(3.(84+;<1;C937@6;D82;.0;.2;008./7-18-3:-36-2808A7>KQ?2=@2BG>4>?5=>4;?5:>39>3@I?DI?DI>HL@JQFFOFYd\ttxvx}{€ƒ††€ƒƒ…††‰ˆŠŠ‰Œˆ‡‹ƒ‚‡{z}wvw€ƒƒ‚ˆ‚Іƒ‹„€„…„‚~ƒ~{„‚ˆƒ„ˆ‚……{€~tvusutwzy|~}z||‚}„xz|yzzwvwsprokldjlX]]MRNFMEGKCMRIY]Xdhbfie\`[_a`ehfXZZOSP[_YY^TPTK\aXdd^VXRW[U^gaYf_K[RFWI@QD@NB28A4=H=5B85C87@619//6+14)66+89-8;/4:+/9(3<,7=/13)/1'.1'.5)18(>D4HL;=A57@45B51>;3;<29@5=C6:>1?>0<9/=<0;D49?..3$&(''('** (*!(,")+"0/'54*/-#.,!0,'41*B@786-.*-')'*( +( *)/-"/-#.+!)'(()))(&'+)!-+")+ %&#&#''()(*))+ (- *3&+4)+3(.5)/3(14&34&32)43*38+2;/7>6573(,+,")) ,+#*+ (*,+ .-#0.&.,$(,"&-"F:7F83RB;]KB^KEZGBYGBXIDWICWJDSG@NC;MD;MD;GA8A<3B8.B:0D?4GC6TG8bK<”zi‰m^†n_h[NIE7A@2>@1>A457,78/890<>4?C:@C9?>678/65+:9/5>18A44=0214=439/37.69.7;13<04;.6>16?27A57A55@4:=17=16=02;.2:-18+59*68)6:.6:.;>4>B7>D9HLAJO@GN>?F8?GF9@H9@I=?J:>J9>H9?G;@D;=F:CL@HQDGPCAK=?L<@I>@J>?K<@K<@I;>E8CG;BK>CK@>H;@J=GP?HJ?BF;@E:>F<=F:@J>?I<;C6=B5AE9AG;>F9>G7@J:=G6E:=@47;09@37;/58-65+34,45+12(34(23(24)25-57036-56,45+23)77.=@6:A68B68H;/>219./7,-5*05*17,5;07<18@6OA;K=9C96=178-98.;;128-33+2/'4,%2+$1.&23*47+8:+;>/912&0/$.+#-*$--$-/'*-".-$/.$42'76*78,77.:<17;06:.56*78,46+55+55*53)21'10&04(58,57+76+75)30&34(11%20%40%61&93)54*10&54*76,75+86,63(54(<>2<:/87+78-::0A?5>=3:=3=A6AA5==2?A6?B:JRKU`YIQHEOEAK?BL@>J@S^Uclghoomqslqpotsz~ƒ‡ˆˆˆ‡ˆˆ…‡…‚„}z€€…ƒ…ƒ……€†‚~ƒƒ…ƒ…‚„€ƒ„ƒ…†…‡„ƒ…~~wx}uvyzz~|~€vw{rtwxvwzx}vv{suzvz|nttnqufllNVQKSLFKF]^_SUUbgdbhc\d]Za[U[YJOKUZUx}uZ^UU[SZa[Z_YNSLQXQ]i`\i`UcZI_MDSDCRDBVJDXLN]SS_PHO@AB7=@4:D68G9@H>@H>?G=8@66>45<34<07?58?45;057-35*45,34*35(05'/4&/2&4.'.+$-.$12'27,69,55+34+23*04*15+37,FI@@?8;903-$.)!/,!1/%24*9=3>F;@MAGTGBMA?G=BKCGUJ.3=.2=/7C66C63?22;./6++1(.0'48,=>2:?07B17F8BTEM]PBOA7@38A38?29@2:A1>B3?B7;?17>.5;*:=09;03=2=B7BE787,78/68048,57,56,68-26*06*17*/6)36-,0'-0',0&/0%34*54*//%***(((+,*/ -0%-0#--"--,, -/#+-!+-"*-"*.!(/#&/%&.$',#-."-+!+* **!%('*!(+#''&%*%)$'#$!$#%"$"$"$!" #& &)"(#%%(&'$#  ! !" #!(((.")4'6?38C3=H9?632''&'''*+,!*.")2).4+,1%,,"/-#.,"0)%2.&11&/0!,,)(')+',%('"&-$+3)91'/+*))))**),*!,-%*/(&+"#*(-'.+0 ,, ,,"),!&-#-1(*/%-6)/7+/6&06&06)16*5;0@E=EJD;?95=2-0(*'+&(&&(&))),* 0/%--"')E=4G@6OF9ZPA]OI[MGVJDQF@QHARICSH?QF>OE=JA8F?6@:1?4+@7.A<2FA5PC6hPA“{j‰n^ƒl]eZMID7EC5@C3AE7CE;=?68;1;>3@E25=14>17A48B58A82:/38.27,4:/39/5=13;05<16=37>45<2:<05;.5;.09,29,4:.79-69-8<09=1=B6DJ=JNCNTHPXJRZLBK?@I=?H;H;CODHUIJVHISFHQENVHEUFBNABK?>G;=D;9A9<@7:@67>48A3D69D7DK>EI>DHDLAENBFPAIQ@HL@EI>@F;BJ?AI>=G;;E78A4;?3>B6@D8=D7=D6>F8;E736<047,76,73+6-'2,%3,%2+#2)$1-'1/(43+9<18=17<06:/48,53(63*86-::39?68A68C78A76=648136-36+25-36,46-58.35+45+13)54*54)42(8:.=C7;?4:<1:;3:;3?D9?E:07;.25(;:0>A7;A69D88G;/A407,.5*,3(/6+3:/5<15=28A7LA;J95?327-89/99/ILB>D967/42*2.&1,%32)45-7:.9<0:?06=.9?24:.15+46+25*56*:5DE:=B797,/-#,)!,) .-%-.%/.$0/$.,"3/$87+67+97-:9/8:/7;/8:.;<06:/::187-;9/65+55+79-<>2::.76+64)52'55)54(54(42'41&:5*44*10&75+76,65*75+53(54);;079.6:,6;-9<08<0?@4@A5<=1;4<;1?B7DH=@A4>=2>>4@C:INGBHBCLAAI=>HD8>I<:J=BI?@G>;B96=36:15:15=26?37=35<14;04;04:/29-4:+38+37,26+41(1/'12(44+77,9:/65+54*00%10(./'.0'00'0.&10&/+"-*!.-!,+!,,"13)06+8B7EOCCJ?AG2;A4>E:;A65?13/48*.0$*'('(('('))+ .0$17,05*+0$+-#55+32(/+$-+"+, &+)*()--$-*#)("/4-LSJPRGD>551&*(,-"--!)(&* */%5<4AH>:>2)+ .0#/0%*-!')(+ ',"+.%,1'.5+-7)28+;A1@C736+46,35-792671-3)+-$,) )%'&()&)''*)*(** '(GA8LE:SJ>XPD^QJ]RJ[SJTKBQJAUNEYLDTIAOF=J@7E<3A8/?8.@7/@:1E?4L=0jPC—~mŠqa~k\f^PLK=LJ>HN=GK?HL@DH==A66:/=C838<1:=1:<04;15=36>45>47@66@56@42:/19.28-39.5;04<16<16<269058/68.7;/7C6AH9JRCTYMQYLP[MYdWGRF=I==D8:C79A57?4;D7?H;BOCDRFCQEDPBDPCFRDCTCETDCMAAI?;B;6>8:>69?5;E9:D8:D7F=@J?EPC@K;=F97B46A33=06>15<15>3:@4BG:GNAIRCJUEIPCCL?BK>DL@DH>FI@@E9@G;AI>EMBHQBIOAIMBFK?CG38<1:>3;@4;?436A57?47?56=64:36>47>34:/38-49/39.38,33*32(20&54*54*46-:@58>28=39=38=3:?417=238-;:0?B8=C87@47D8/>228-.4).3(/7,19.3;09C638;0KNCW^S;C869/54+32(32(67-59.9=39?36<-7@08B25?131<=1;;/;:/:8-52'46)78,98,66*63)<9.67-23)9:075,65+43)75-:9/<>2=@19>.6>,:>2A5>B6;<2==3?>4>=3CF:DH=3?@6?B9BE=AG=>G;AKOCJ@@KA>L@8I<>B926@44?34?23>15>19@3;>477055,45+59.89/77-86,77+77,32(2/'.,%.+&/,$1-%.)!.,",+"*+,*!+* 21'8:09=28<17:.=>2:A7QC>OA:K@6G<5B85?316+03(20%32'67);=3<@59?48B6;C97?417,15*26*56*6;/5=0AI=CK@@G?E:@G:?C8@D8AE9BD8:<069+7<-5=07?3:=146*01&02&25*37,4:/46,/0%11%79-;@2318I;BQE7:/-))')*'(&($&(*)+,."/1%/2&+-")*!,0%7:0.1&,.$)-")-!'+&))+#)+&11-+.)292DI@=;153*.-%-.$ "&'+,"+0%.2):=5??754+.-"3.'.-$%) &&))*),#-1(.4)-3(15*49,56*/.$)(-+"-+#**!(,"'* '(+)&%$$&%%$)(*)&'&'D:3J@8RF@XKE`OH_QJaTL[PHVLCULCXMEUKBKE;G@8D<3@7.>8-@9/@;2FA5SD7nTF˜€nŠqb|m\dbSJN?EJ;FJ?JNBKNCIMACG<>B7;A6:@4:A49?2<@446>58A66?55>45=04=02:/08-29.4:/2:/4;05;058/76-86-5:-7?14=01:-49-7;/8<17;/:>2>F8AH9KQCNVIOYLNZNQ_SEQF>H=:C9:B7;C8>B:;?99=7:>6?F=DMA?K?>HC79@58?58=29=29<0:?4;@5CG;DHC7?E:@H=GOCHOCJNAGKADG>AD;;>6::1:;2;>49=28<1:>3=>4<=2:<5?A7=C8:>368.84/85+54*32(86,74*60'6.'3,%1+&1+'2+(1*&30+2/)31(86,88-47)65'67,=?58>53;03=1:?49?55<57>7;D9:D8:@54=23<10:.29.47-31(42(75+99/49/7>46?2:D6=G:>H:7A37@4;G5:E58B46@438.25,48-6:-38)49*26)38,18-2:/4:/7;26;36819<2?C7L;=H<9B7?F;DJ?FLA3;048-69/56,57-57-59.6;25=14>.5@07B27A46@36@39@355:?6:8250,33.50'-( *&+' -' ,'-&0*!/+"31&55)78,=:199/8;0<@4=B6>A53>=3>>2;;1:;0?@58;/9:.;;/;4AB7>@4>D4>4@?5BA6CG:>B6?C7@@6@?5@?5?@6AD:?E:AG;DK=JTET\QSZP[c`puvvxzwxw||}{|€…ƒ‚‰‡‚‡†‚‡ƒƒ‚„†„І„Š„‚ˆ‰‡Š‡‡…‹‡ƒ‰‰…‹‰Ž‹†ƒ‡„ƒ…uuxxzytxvlpldhbZa[Z`\rutrttjlk]`^osq^c`]e`]c^_cauvtwzxY]YRVQRVOTXRUYTQVUKOMRUQZ^XRWRJOLGPHELEIPILNIILFEFAJOFDLCEPFBMCHSGDUH?SICVMHYOCTI>NB9J<:?66<25;29B77?55>36@55@47A59C75B64@41?35B36A3:C6=A7;<449.59/<@57;055+42(;:086-32(/-%-+",+"/,$1-&1+#.,"++!&)+* /-#1/%21'//%24);:->=2;?5;I<=OA@OADSF8H:7E9;E96<246*01$01%36,5<16?47A74E6:>29;/9=17>15A1=A16;-38,27+48,26*-4(14(//#55);=.?B37=017+/3'00'01&00$3/$50&1.$0.$/.#00$-/#.2%.2&,0$--#.,#.,!+++* --")+!*+"*-"*/$)2%1;.7B52@8*/$78066+42(3/&0+"0)#,)$++%'*!)*!** +)() *.%-2),2(/5)12(**'&&%(''&(&&)&('&*)-+"&'%$$#%&%&&'$%C<3I@8MC=VJE\OG_RK^RJYPGVNERKBSKBQLBHE;C@7A;2>5,<7*?8-A>1FB4TF6uZK—}l‰p`zl[dgWP[LISDGLAHNBJPBHNAFL@EJ?>E8=D78@102=02G=;A98@7>G=CMAGPCFOA=J??LBGRFEQEBMBAM@@N?GQDCJ?CJ>CI@AG@AF=BJ@ALB=J@?L@EODBQE?NC?KAAJ@@J??G9:A79B79?57?4:?4;>1=A6?C7GIHM@HQAJRFJRGGPEDLBCI>AG;=B7>C:@H>EJ@GK@EG9?B9A6::087,650:=29=169-32)2/*50(20(54*76,30&1-$5,%3,%2-%0-'0,%3-'1/&30'50)51*53)33(65'22'6:.36?48?8;B;:D9:D910=14=125+4/'31'79.16=215+43+35+48+48*25(13)14*16,27-26-37.46.58/4;07>35;04;018-/5+58+16*19+6?2:D7G16@07C2;C68@45<25=16=139-49,5;-6B4:G9BJ?;<4-*$.-'1,$/)"+( -' .'/(0&0*!0.$56*9;/8;/=?42;>28:.:<069-7:.7:/8:.79-79-;=179-68,6;.9=18<059-;=1>@4CC5>@2>B3=B3=D5=D4@B6=?3:=1=A4BF:>C6?@7>>5DC9EE9?C6=C4?C8AB8??6=?5>B6@F:EH?AG;AH8F<9H;7D88E9;H<9E97D75?57@59B6=C65<=29=2BF;;?4,-$85-9:377/42*11'10&--!0-%1.&2-$/-#+* (*.,"-,"0.$.,"-+"21&:9*=F8BF:DF:8=26=26A57B86E9JTJS_R?I=474+/-#31(BC:8:05:/:?4;>3=D7;E5;B4:=1:<15:,3;,4<,8A17@23CC9?;2=6-:8)?8*<8)D@0RC3v\K–xh…l\xkZX\LTaQRaRRWLKRFJQBJQBIPDFLB@G:?H:H8FP?ISAJSFBK>/6>05F<>C=:B9;F<@K?CM@DL?AJ@@I>ALCEQEFRFFSGCSFGVICPDBMAFQEGSFEKABJA=G=:H=KC>G<>E;:B58C79F;3A77B88C68B3@D9CF:EF:EH?H<@G9AH=@G<@G>BG?BE9>@48<36:155-85-64+2/'11'89.8<1:>377.41'33+45*27)56(32)3/*0-%1.&22(56,01&10$9/*6/(2.'10%2.%2-"2/%2-$5/)70+62+65+53&00$.1'C88>05<2;C9;E:=G8:F93A32?35?328-51'0/%59-;C4:G6:F58I;

CXF@SA:K9>K<;G64?.1;-49.35,53-56,45*57+44+23*34,03)37+58-47)25&48).9-1:./6+6;026+35+48,49-7>1;D7QB?RB.7B28@1:?38;247-48-38-4:-4;,8?/8J7>R?HWE6;---!00%0)".( ,(".(!3+!2(1) 0+"21(:=1;A5=A5:A7;C8@I>CM@EM@AH;>E8<@4<>2BD8BC7=A6:A44;/7>16=08>19?29:.8;/:<06:.8;09=16;/6<08<09=1;@3;?3=@2>A1>2;<089.=@4>B6EJ=EF=BB9EE;EE9?C5AF6BF?3;?3=E7CL?GIBBEK@:H=8F<:J?:MA7K?:L?:J>8H;8F:8D87A68>75=48?4:A3>B6?C8BD8@B8@D937,24,:;199535.26-57,12'44'76-41*40'.,"+) --!.-#-,"-,"+* /-#31'55&54%11%+1'7?2IJ>OL=EE5@H7@I8HP@OUDOOD>@66<02;02=37C9=J?9F8CNAQ\NBJ>/4@3/7*-2%./%*0$)2&/0),(,++ +) (&%"#"%#$$%&*, 59+9;/.,!,*)'(&#&%)++**,.".2&-2)08,0<.3A41A64E;5J>2E8%8)5I88F616()1$*/#*-!(, '*&)(+(,*,&+(-"+/%,4,04+-/%..$./%57/GRIGH?93)<8.DF;IND>E8@I=7@8:A:AJ>?F8<@67;0.3'08-2>5APH]jb_c]<61*)!" $$)+$'+$ #&& )*#64+;:0+*'&)(&&''((%&(*() &&&"%#&((+!)+!)* KGBKJAMH>WNAXPFWQFRREOWGNVFPRDLLDLNDIJ8-B8+Q@3p[N‹sd}hYpeTVUFOXJP^SN_QQ^NT_MPWFJOBEJABH=CJ>@J=?IGQAEK@DJ=>E6>H8>I=;I>=G87A37A56@46@25@18A49B59@48;17;09;26<15=22/7?05?57@57?4;A6?D9FK?MXJT_OJWJDUFBQDCLB=H==H=9D:;F<>I?DMDDOF>J@@J@BLBBMDDODFQDGRBEP@EOAEOCFNEEQECOB@KA?H>>G>?F@>J??J??G=;E:;G:7F8D9;C8H<G>AL@?MA>F:?>2;:076-74,84,71-4-(6.'61+7609;438..4)22(31'73)63(40(2.)/-$1/%10&64*21'66,75*2.%3-&2+%5-%2+"7-'70,84.64/86055.44*03)17,>D9BI>9A6;?6AI?CPEAOC=J==G>D:9@6:B9;A85:140(3-&74)@A5OA@R@>O?8E:7B59=1AF99>118.08.3:016+16+/7,2:/1;-5>17=17=26<15<038,1;,2=-6<-8>/8C2>L>?RBBRA9>3/+"2,&3,%1,$/+!31'2.#/(0,"20%99,AB5AC5AA29?3=D7?F9AK=GPCBJ==A6:>3<=4@D8AF;?5=>49>2<1:?0>B4>C8GH>?C8DGH9BH==C8NC?PE?RE8N@;NA=OA?N?9J<7I;5G87D6:C6>>4:=2;?49=3AC9EE;DB8?@3;=/58)76*76,<:/89.59-4;,5<,39*78.44*43)10&1/%/-#0.&.+#.*!0*!1,#3/%33'32'20'31)66+?@486,78,8=.;@2@B7AB8@=687/6607937=45>29B8;D9CI<0CC6AB6>@55A3=F5@F6;A02:,/8,7@47A4;D8=G:H76=0/5)29)09'(,))*(()!*/$,5(,6*0A29J8AN==K<1C64B72<207-690/3),/%-1&).#&,!'.!&-!$,)+). '.!#- $,"(-',2(.8,0:-3=-9=5<=543/.809@:9>8:@8IAI?BJ>BJ26<15=23=04>16?17>17@47A57@48@6;B7=D;BNAS\OR_RHYLBTFBOB@LA=I>:F<;H=@LAANCALB@J@>H?G=:C89B8;C79@67=35=38A59D6D9=D8;A7:B7=F::=197.41)51*92+7.+5+(7/'2-'1/*5607:026+40(4/'72)82+63,31,2.(2.(3/)2-&4/)94.73+4/(4.)3-'4,%1*"3.&20(78/8;27<36:058-27+39.=F:?C:CKBFRHASE=J?>I=>H>434+00&22&79-:A78C8>I<>L>AOA=J;9C65?12:*17(35(12(13)/3+21(21(55,37+38-3:-5?/6=.4;-4:,07+2:.4:-5:.78.56,47,5<.9D3DN@?H<PA8J;3@54>259-26*27+/8-2:/7>36:.48-28-2:/3;.4;.7;//6*18-6?25<.4?/4?/9?03:;0:;0=@5AE9@C7AE8AD8=@4;>2>A6=>3?B3@C4?A5>?5=B7@F;?F:FM@MUHcl_IOCAF<D9BH=DJ?FOBMTGLQDKQFJSGOXLQ_RVcX[g]alcirkq{t{€€‚†ƒ‡‡ƒŠ‡„Ї†Š†ˆŠ‡‡‹‡ˆŒ…†ŠŽ”І‡‹……Š‚ƒ‡…†Šƒ…ˆxz|ryupwtjsocliemkrxvptwkttqzxmqpmpplssqtvfllckjclkgpm[c^P\PS_ULXOOXQSZRUWPUZR]cZ\eZR[QW_XZa[X`XY`YGPELTLNTNW]Z[`[WYUVYRRULIRFDN@AO@DTFGWLFWLGXLCREEQFLXNGWJ?QD>PC>PB>NA:L>6J;9J<:H9?E;>C8@C8BD8IL>HN>HJ=AC676,64*0,%/(#-'"0,#:7.QQDVWJGI>>G:BI:FK:14>28B4=H9=F6@E6@I==D7;A59?3:?47<018.18,/7*4:,5:.26+58(4:+7A03?-1;,3;.-4&.1$-."-+ +)-,!/0$1/$/,!.+ -, 22&5:.06),3&,4'06)15).7+/9(,8'-6+)1'-3%/:*4<,47&0/!,+,(++,*!*(((#)*3%.<*7C48D6:E8EOB4?0/1&*+ +,"-1&.6*,6)1;.6F6>N=>K;9G84F85C62=009,18,&/"(0$+2'*1%*1#-4'(.")'*$+#.'1#'/$)2'+7+5B48I8IH@INCFQDFLAINALUGGWIFWFIUEIUFDOB?E>=A::>3;=/<:197.:8.=7.@:/F>3D@0GC4GC4DB4AD8HNCJZMIZIIXFHVDFQ@AK>BI>BL@ESEFVHCUE=N>BKAAI>CK@JSGGRF>L@=J;9C69C59C67A47A4:>/7;,6;,6=.4>/5?/7=22:/1:.19.2;/7>16@37@45?39A8;C;>I@MULVbWM_QBUGDRD>MBNC=MB=I?=J?=K@:G<:F;>J?AMADPDDPD@KC?K>4:=49=45>38A58B68B6:C6=F9;C9463,4/(4.(:2,7.(7.&6.'4.(1.)6608:034*2,(5,'7/(60)54-21-00*2.*1-(3,'2(%7,)5/(3-(3-)3,)2,'4-&20(43*8;17<34906;28>25:05:/9B6>H=AM@>H>@KA@ODMAAOCCND=LA=LAAKA>F<39001'10&21&43)78.:=3H;7C55?24>128)06'14'04)48.36-31)22*04)37,28-4:/7>16=07<05:/38-27,37,56-75-56,69.;@2AK=CK?AI>=E:>F:?I;32:/48,16*38-17-6<1;A66<15;05;06<18=048,37+27,2;.4>35>/3>.6A1=C5?H9@N=FSF=N@6C56:.43*12(20+//'44*32(31'50)50'65)>@3BD7CD7;;-9;1<=368.79.<<277-78.44)66*9:.@D8?F9BF;@D8=A6<@57;0=A6;?3<@2:<0<>27:/6:/@@4CE9@B6<>2<@4BF:DH@3=>3;=2>D9;A6?F9CJ=KREIQD?E:AG<>D9AG8I;8G92;=1=A4?E6AI:?F8=C45<208-39.69.53*63+5/&54)43)54*65+55+35)01%//$33'22&22%50%4/$1/$21#32$35'87)33'32(13)26+16(66*34(26*48,45+76,?;4;833429>;PWQKSMPQFA@6:9/==1BE9AH:FI9;>032(42*1,(.)%0*$.)"1/%99-DE7Y[MQUFPTDFI:>C6>G::E97@35>05?/7A18B2:C28A48A4/48,38(7<-=F69D58F72?1.6).0%((****,- 1-"1-"0,!/+ .* 30%9A29C42=.0;+.6(3;.1<.4A./;(/8,(/$,2#)3%+4$27(35'.1$*,!-/",-"-1$.5(1:*3>.7B17A37A46B66>3/8-13&/1%.3'39.4=04?07@45C67G76B32?20A37D76B56?35?36@37D65>/.8(,4%49)15&+-(-(/,7'0>,1=/-:,2C823,-+%,1+3614628;55917<1;@6BI?GOINVO\e[jthQSJ<=4?815'!-$$$(&((&)(, +-"00$.0$.0%((%)).*0(,"'*+-!--!++ *)'&'(*+!)-"*/$*0%HH>DG=@I=>M?CI>FH>LQEJWIIVINXIOZINVIEH@BA:BB6EE7AB7>>3<;1==3=;0@?3EI8GJ9DE7?@2>@4AF9GWHFXGIYGEUCBO@EO@DMBBN@FUGFWIGXHEVFEPDDMABKBEMBCNB>J>9E97C69C67A49B66=38;-6:,5:+5=.5?/2=-4<16;027,4:.7<15=2326>46?69A;;B=LB9I=;K@DTI?PE9J?=I?>J@;E;;F>>J>BNBBNBBNCALB>J>>I>>J>>H<@4?A68<16:/6;/9=18?56>57@5;C8;B78>2;>0;;/76.<>6:>76=38@59D8;E99C78>27=08;268/;A8?I?=F=8:174,51*60)7/(91*7-&6.'2-'1-)34-45+22)4.+3+%5-&93,43+33-00*20+3/+2+'2(%4)%3,%3-(2,(2+'3.(4-'5/(53+;<47:17:1:=48A57?45>36@4>J>CQEAPD=M@;M>:J?>NCCRGEQGCNDAKB?H>H;:D7:D78A419*18*08+4:/:>358/45,23)/3(04)6=18B4<<09:.89-88.77,54*36+66-57.23*=C7@I8CK@DL@ENAIREDMADMA9I9:I9=L>;I;6B54=23;018-5<18<139-4:/513:-5.5A19D4=D5?I:?P?DSFBQB8B658.43*02'4.)30'63)30%60'8.'31'98-BC7BD8?@3==.8:/;<299/76,43)74+68,55)54)88,:;0@C9@D9CGD5;@2;?3;@4:>2:>2DF;@A6>@4<@4CG;DHD4;D7:C6CJ>>E8AG;EH>AG<@F;BH=BH=@F`e]kpgdpjkurhqotyz†‰Œ…‡ŒŠˆŒ‰†Ž†„ŒŠ“ЉЇ†‡†ŠŠŽŽ“–“Љ“‹Š“ŽŽ•’“—ŠŒ„‡ˆŠŠŽ…ˆŒ„ˆ|€„ƒ†‹†‡Œ„†Šv}|elh`f_\b[cmffmiV^XS_YTaYP]RPZPRaUQ^UQ]WS_XRYTT[TZa]_f`V^VMTLT[TSZTJVJKWKOZS^c`fmkjpofkjSZUYaXPVJKODILCLMCKOFMULJUK@KABMAEKBEJBCJ?AI>=G=G:=G9=E8>C6==186+<9.<:0>A3BG8AE6;?.07,09.5=369033)42'64+64*31'30&20&32(33'12&02&35)46*57+61&2.#1/$11#23%14%76(45)23)46+15)16&56(24)26*26+77-76,@82961995DGEJPLAEA=:186,86,98.9;0;B5AF5:=/23)1.'-(&/*)0)$-("-+"(':;0MPCXXJMM@>@49>38@57A6:=17;/39+5<-8B2;E54=/6?3:C8AIBIQK]e]ci_PNFIG?=6/8-'-%%$(&+)&&&'), -.!-/#*+ %)'+-2#,4#+.#).")+)+,,!0.$*,!*+!-1&,1&*0%+3'AFIREGRELTGTXHVYJRTFLNAJK=FH9?G:>D7=A5=?3;>2?C6?G7AH8>A5CMA?L??N@CRDFTEHTCBPA?J>?H>=E=:D;;F<9F:7C78B55?27?46<169.69.6;/6>14=.3=/5<25;07;06:05:14<23;13<17>37=79=7<@;AEAFLFMVNGVKBRFDOD?K@LA>NC=MB:H=B436C7;E9;C8:E8=L@BTGAREARE@REARGFVKFWLGXMCRFBNCAI?8;263+66+66,75-64,54*<<0I<@J=>G:6?3129A67=189.25*26+.5'3;-7@2=;-88+57*79+76+54*48+9<08:149.?G;>J;DPCBN@GSDJWFMXKCNA6C7?J?=F;4:/37,38+4:.5:017-28,4:-58,6>13=2FG;@C7?B4<=/8A7BD9CG;BF9?C6AF8BI9BE6E8>E8;A3<@/AC6AC5>C5?C6EJH;:B5A6@F;AGHNCHTFOYKKTHGLD[c[]d^krqsxxty|€ˆˆ‰’…„†„Œ††Š‹”Š‹“‰‰‡ˆ‹‹‡‘••–Ž”ŠŒŽ•Œ”–‘–Œ’‰‰ŽŒ”‰‰…ˆ†ˆŠŒ‰Š…„‰uz{emiae^`g]fpe`gaT^YTaYN\SN\QT`V\e^[e_YdaU`YLVNV]T[b\[a[Y_UU]RNWMISJMYPXc\hpmrwwtyyosrhhjU[WPWOKSHOSINPHRRINRJGMGFMFDOC@J>@I?@H>@F;=D9@H==F9>G:DK>CG;=@4;;/87+96.77,:=2:A39A25;,39+38-6:036,00%43&34'22%20&1/$0.$0/&22&23(24)34)36*35*0-#/,"0/$22'22%13%16'26(36*68,57*67)36'14'15*37,76-76+:4*86-::5AC>BB>1/*0+"5/&72)41'34)79/:?18<023)-*%-*&.)(-(-)!+'!+)"11'?A7JI;AA5=>38<26<119,44*/0%11&78.?E8BK>H<;E99E86B57@55A34A16A07>.<=2:C422>24=/06(25)22&22'01&/, *(++ --!-+ 30%5;+2;+1;,;H<;F:4?41=/2=+3<,49.-3)/7*69.7:,.1".2%*2&08.25-07,5@0ESCJXGBPA2@L14@12B15?219,/4'14(37+05(+4$,5&/6(.5'+0%%*(/!-8'3A/2E23F53E55B5:H9=J94@/4>02;05@19H730.(--'+,'/1,AC>HID01).6.:CDNBDO?CMCI?=E:COBETFGSENTGTYISZEQXCLSBDJ==I8?I9AG8@F7=D5;B4;E5K@?L@CNBCM@CMB36;26:/48.6<15;07?26=03<05;/8<17:15903:03;45;48<6791780<>5BF@OQKKPJMZRHWMFOEDNDCMDAODAPELA>OD>NC?I<=G8;F6J?EOBCL@;F7;C3;C5:E8:D98A67@37A1:A2:@206:,86,76-;;4>D=H<:F:7C77?436*41'60(70*1/%0-)5/*9,)2/*3/+85-74,71*72)6/'3.(2/*2/*31(0/$.+'1-$50&40&/,!/-#11'23)0/%.-#0.$0-$60&:1)4-'5/(4/'33(66,6:/7>37@55?34>24B59D8>G<>QDCWI@SFDVIFXMEVKCSIEZNATH;LA7C:8=4;<39>25:07>48>46<2=D8>G:;G9;H:;G9>H;BK>;E8;F96D69E7IG8>M<9N=AVDDVHB5?C5:=-;@1B299+98*:9*53&85+97,=;2<;1?@6DG9EG9>C4@F5EL;CL:AD5AG9@F;BI<@E8BF6EH8DH9CH9CH8CI:BH9FF;GG;@@4GG;HHH9@K9CO?GPD8B57=178/:;1@E:CI>EK@DJ?KRGIPEGQCJTEIQFMUJT\TV_Xgkglnlwyz†‡‹‡†ƒ‚‹…„ˆŠ“ˆ‹•‰”Œ”Š‹‹–”‘š‹•Œ’Ž”‹“ŒŒ’‰‰••Œ‹”‰‰’Ž——‰‹‘†‰ŽŒ‘‡†Š†„Žy|mrt`c`bgaakc`gcT`ZS_YN\TSbX\j`djgkspiqo_gbT]UV_S\c^[_XZ_VV^SGRFGTH[e_[b`]bbadjfhk`bb[\]SWTKRJOWLJPEORMUVMKNI@G?EMFENC?H;>I>>F<CM@>F9;@47=06;.69139/1:.5B49E78D47;+58+15*/3(/2$23$/3$34%33&21%01%/0&21'22(./%13)15*/3)/.&0.&1.%21'20&:8-.7(07)48,57+77+88)35'25(26+25-55*22&82'53*771?>983/2+&.) 1*!0) -'+(!,+".3'/2',-$)(",($,(%-*-),($*'".-'68/0/"43)45+14+-/&+.#/*#0*"/)!/.$48-9@5BJ?ENB@J=EPAAM>:G75C74F6;M/1=,1;*39)36)33'33*,.%--!)+*.".1&46*54'57(7=/0:-1<01<12=34<0-3%-1%*-$*0(,6)34'//#))&((/#-6,260.6+6D6?O==N?;J<6@52A4;MH<H8>E6>C6CI=HRGCRFAPAMZKHRDCK>DM@FPCFNCAI==F9>G:>G9@J:JQBMWEFP?=G;8D99F8=H<23<12;24<239/6<38<35:06;248.9:1:7/<70CC9WXN[^TV\VR^V?OHFVPIXNESEDPDFTHDQIEOH@KE>LB>L@?J=;C7>E:>E9=E8>H;=H;AN@GOEDMA>K=?L>;I<;E97A5:D716?25=/7:+87+:9-;:0:>34/:1(9.)9.'5.&50)42(12'3+$4*#6-(9/)3*$5,(4.*3-*1.)0-(/.)/.)63+51)6.'7/(2-&42*9:/7>44@53?55;27;07>4;D8OCCRGBVJC\OBYMFXLJUKFUHBQD@MA;D8=O>9F99B79A7AJ>FQDAK>AOA=K==L>@O?;G89>348/.3)4;14<20:/5;02;/6@36@47?27=-=?5DF17B46>43;06>16@28C2:F6;J:@L@09@3:@19=-<=,<@079,9=1;;0?=0>=/>A2BJ:AI=?G;?G=@I;DN@BL;HN=GN=AH9CN=CL>@J=BGA6>D9CH?DJ@CG;DHB6OVHDN=GSAGTEEQCHUGKWJMVILTHQ]OYeXdn_cjb|„‚ŒƒƒŒ„‹‡ˆ‹‰Š‰‰“Œ”Љ“•Ž˜Š“‰Œ‘‘–‘‰‡ŠˆŽ“˜–“œŒ•Š“’ˆ‡†‡‹‰ŠŽ…‡Š„…‰‹{…|‚„innhml^caU`UU`UV`WYa\]eaafejpnotsquvw{|\a`U\Wdhc\a[YbXLXODI=?G9BK<33906@58B66=199-67+13'34'55)32&35)56,12)12(23)13'.3(03)04(26*48,15),2%14'33'44(78,79-47+78,87,98+98)33%62)32(23)34*01(21'45+66.23*77.56,00'+( /(!0',%,) ,, ,, -,!,)!*( )'"*+%-+#.*#-*".*%/-'67155.24,32*,)!,(!-* ,* ,*#.(#-(",)#00&6;0=D9G04=05>358-/2'-1%,0$/3&.4%11(*+!$&(*.1".2"04&0:+6@0K;4H65M;>TCCVEIYHXbSFN?7<18C7,.7',, -)''*,"+/#/4(/3'-1&*.#+.#&- (/!)3!4@.>G<=H9BM?FOBCOAIZLJ_RJ^PK]PJXKFSGEPDCMA?K?>L?;L==J=?L=@K;BJ=FP?GSBBMBL@;J=7E87D66@39B57@56@47A55?24>04?03=309/4<25:127.69049016-26-47.97/<81<:0A?5ED;PQLPWPHQKCXSH\RHZMGXJETJ@OFBKF:E>K?>I<G<>F:K=:F:7@6:C7;E9;F;:D87@5;@68B48A4:C68A49B59A49=.>@2<<2:9/=?5>E7AG33=34>43<058-6<2:C6:D7;I:?M@>MBBPDG[NH]RCZNEVJJTKFTHERG@K?=G;?E;>D99?2:B5;C8=F:=H;@N?@Q@>M=@L?=H;EQBFUDBMAAOAAPBDSEDSC>K::>338,4;/7@37@32=03:-7?2:D7:C69A17>/=C5BJ@K;@K;JWGIWGESCESCBP>LYHMYJBQC=J>9E97@58=29;/7:/7>27>24=15=15;/1;/2:.3;/2:.7?34;/3;04=08A4M>DOB@I>I;AQ@KVGKSH9@478/32)50(45)8>0=G8DL?EL?25*>B6?B5?B5BF7<@16<079,8;+<=.3BK>@H=?H;CM>EP?GM=JOACJ=BK=CL?CM@CK>GMA@D7=@4:A5CI>COCDOBISDHQAIN@FH=HK=HN@CL?AK>EN@FJ=GN>CH::?1:=2CE9@A6FJ@INA?H:DM?HUGKWLJWKLWKJTGV`TYdXVcW_n_fohv{}†‡‡‰‘†‰ˆ‰ŒŒ’ŒŒ’ŒŒ“Љ‘†…ŽŒˆ’‹‹”†‡‰Œ‘‹‹“‹ˆŠ‡Š‡ŽŽ“‘—‹ˆ‘Š’Œ’Œ’ЉŒ‹”ŽŒ“†…€€ˆ„‡~‚„mrr`gd]e`[g^Yd[Xc[W_Y_f``eanrnswubffcefZ^[^a`_d_V[UNUOLTMNWSU]Z[a_UZUY\Ziklz}~†„z}~knmY]XKOIEMDKSJMXKEOEFPGEOFDMCBJ>=D89?49?59?67?5:C7=D;@H<>G:=F88A56?33D69D96@58A75=237,48,05*.5).4)26*36+57+67,45+23)34*57+16*37+04(15)26*47-07*14(01%55)77+57,36*89-97,:7-87*44'0,#/-%23*01)/.&20(52*:8041*1.'0-&-+$+&.' .(-'-* ,,!*))&+',( ,)%--'-*%-)$.)%.,#,,#01'/.(/-%.,$.)"-' .) +* 0+#.(",&!+&+* ,/%3:.4>15A4?M@BPCJSGEOE?MA5D89F85C26A3:G8;K<ERC;E73=-5=.7;/56,00&/-%)+#(+"*+!,,!45'9;+88-79*/7(/8)17+35+03(/1'*-!+."), (,.,#20&*(,+!)(+*,-"07*1;,7=.6D38L:F]KK`NH]LARA6D40<,2;-6D63B41F;AG=AK>EOBGPCFQCHYKNeVG`SD\P>REARGAPD@NC>PDAUH@UF:N?>L;@J>@L;AN>?MA8H<:M>J<.5>.3=14;03;038.48-58.49016-/4+/4+34+64,:9098/::1BD>EKDGOI=RMDXOGXMIWLDPGBKE=H@:E=@KAHSHBNB=H;8H6:G8;E8@H=@G=AG=;D76:A636>38B49C68A49B58A46?1:A08;.:9/;;1BE:FM?DKAEH?<<662-41)64*43*54+42*64-82+6.'6.'60)6/(:4.=60<4,7,(7.'5.'52*32(/.%/-#0.$44(43)20&2/'3-(61,3/*3/*31)64,63+4/(70)6.'3/'20(;9.9<14;/5>25=15:,4;16?39C5;G:?K>>LAAODGWLH\QEXLCSHDNCAMA@MA?I=>F;?G<;A67@3;D8G;?O>AN?BO?AQ@EUCCTB@K?>K??N@APBAM?=H;8?26=08?29C6FSAEQACO>HSEDO?BN?AN>P\NQ]PKYMFPB>H<9D85?3315?23?I<:G7>K;L\JS^OS]MHM?CE:78-41)36,6>34CB7DC8DF:JMBEM@DK>AH=AH;FN@CK:DF:CG:AE9E;@J=BLB7@D9CJ?LUJMXNLYNO\RWbZ]h_P]TUcW]ncanhx~†‰†‰Ž…ˆŠ‹Ž“’’˜–ŠŠ‘„ƒŒ‰ˆ’Љ’†…Ž„ƒŒ‰ˆ’‡†ˆˆ‡†Š‰†‡Œˆ†ŒŒ“ŠŽ’‰Œ•˜•Ÿ’˜Š„…„ŠŠŒ€ƒ…ipoakgcmfbnj]hcXb\[c\[cZae]nrmeheXZXaecZ][ehfW^XU[VRYQZ`[\b^W]XSZTZ_X_b_uvw~„‚‡…ƒ††ilkKOJEJDAIBMULFTGIZMFWJ@PECPE@K@59=5;B7?F?>G<=E:;C87A59B75H98F:4?45?56=256*04+.2)-5+-5+/5,/5,9;058-15*-1&47+37+28+48,69-46*26+4:/4;.37+46*46*46*25)37,88.76+96,::.55)30'20(12)-/&-.%1/'50'4/&1/%.,"-+!,* .(!+'+(*(*((')&)%+%/)"/+%1.)/+'.*&.*#+( --",/"-*"-+#0*#/*!.(1*!.*!/*"/)"-& +&*&)+06*4=03=09D6DO@KSI=G>8D<9E:5D78G65D75F77J;;L>CRC=G:9@19?159-44*.,#-,#./)+,&*+"-+#/.#53'=5,33'+3#0:*23)1/%)-"-0%,,")* '&%&'#'!$!"$"(%)'+,"+0$).!.;*4G6;O>;R@>UC5K90B17F68D3:L<9I;?J>BK>>I::B249*07+09,.8,+8,.9'-3$-+ +),+!-/%*2%*4'+5()4(+8,.;/.5()3$*6$(4"0=/3@13B7:O@EXGHVF=F85?27D57B41;.0<.1=1#1%&/"+2&.2'-0%46.<>6BB=;:6<<58:4?A;CE?C@=>@:381LOI72-/#&%)&%#'&+(,(+) (&('%&%)&- (,!',!)+!*+!()*)*2"/6&'.!)-".1'./'IYNJVKDOEDNCISFMVIHRDCNAEQCO\NQZNM^OJ`RGaSI`SI^PI[ODVIBRE@L@@J>AI>DM@OVIPWKPYLL[MQcVE]SF]TBXMATIDRGDRFAUHAXJ?[J;SD@TDAP@@NB=N=;K<7E:8G;@L>ERACSCIB>G==B95;2BMC@L@=J>:L<?L>@J>AH=BF;:C6F;09:067.@E:DM@FMCDH?<:584.31)54*65+64+54*75-71+7.*80)92+82+82+<5.:2+;/,81)60)53*21&.-#3,#3-$52(42'60(7/+60+50+52,1.&41)63+41)51)91*5-&3/'41)64*65,04,7=29=27=/5<28A5:D79D6:G:?J??MBDTIDTICSHBND@I?=I==H<F;AE;@J>?K??J>=I;?G;>G98?/7>/=D5:D4=F78C3:>2<@4=C5>E6:C3>G7ER>GUCHXFEVEGVE@K=?N>ERBMZJVdUWbVO[OFPB36?28B5=G9;F79F8;G:@OAFTF@M?HUEBQAGXGSbRWcSS]MNVG=D425(/6+6=29B7C:;A7@E:BH=?E98?26<1:@4?C7BF:?D9AG<>B8?C8LODEG@C8>B6DH;?E5BB7CC9?B68@3=G9AJ=?L<@K;?F7>E8AIDL@ELAAE<>C8?C8LTIQ[SUa[akeksokqoX`\]icdslp|y{‚€€„…ƒ…ЉŒŠŠŽ”•ŽŽ”‰‰†…ŽŠŠ’‰ˆƒ‚‹‚І…ދВޒ’‰ŠŒŒ’•‘‘˜‹’Œ”“”™”‘›Š•†…†Œ‰‹ƒ…‡ntrhqorzwitrWa^[e__f_[cY[dYad_Z^Y^b]^b]XZXlon[a\TZUW\X\b]\`[Y]WX[VW^VV\Xeijwy|~~rsqWZUJNI@E=K@BOCAOB:J=2A50?42:/67+76-58.24+16,14+48.6;.38,05)15*49-7;/3:,58,9;/68.38,27,6=05;.8:.13'/2&04(26+69.54*66*:9-79-41)22),-$./&2/'2/&50&40%4/$-+ .,!++0(#)&))()(()')')$+%*%.+#0-&--(-*%,)"*(-,!.."/,$-)!.)"-) /*!.) 1,".)!-*",)!/*!,&** 46+>D8;E79D4=G8?H>7?68@9;E::F97E45E82C64D77C7?J>>F9:E57=.38)37+3:-1:/.9-28*+/ **(%)')+ %- )2%)5'-9.1@49I<:B52<.0@.5E46E67E6:J>?TFFYKJWF3=/3>04F85A4'0#(+!)(##&'))+(*',).,#,($950DC=PQKFJA=?6A;9::6u|votmHD=4'!&&(%&%(&(%+(+((&((&(&,&- )-")-"*+!())* +-",2"/5%-1%--#-.&++%L\OKXLESGCPCHSDNYILWGGREBL?J>8C65?34<03<.4;-2;/1:-5=07;/59-68,38-08-19.19.28-6:/5=24;05:0:?9>F>CKEHSH@G=9=3890<=2=?46A8;D;>F=>G=>F8AG8=E97=E;>G=:A87<366.86.9A58?29>2;=2;=1:3>G:AOA=E:9=495073-64,66,63,65,75,65+60*5-):.+90*4/'93+93-70+70+6/(62*64+11'10&4-&40'65*53)50*7/-51+61,51)4/(40(51(20(2-&6.'5-&50)30(6/)2/)20+8926:/4:,4;17@47@38B59C6=G==H>=J?H>J9CRBKZIGUEAJ??H<:D8C6>B68@39A4;C69B5;C67@3;?2/5>0:D5:B77@45>26@48C7:D87B2=H:@I=J=AOCGUHFSEIXGEWEH[IP]NS`QMXIFOA9@218*5B3;G:?K??K>;I9@M=CK?E9FL>KNCCH;;?4;?3:?2;@0CB7BC7<@3:A3AK<@K:BO>HSBHPABH9@E8EL?KZIQ_MQ]LITBFN?;C5>D6CI;EL?DK>BL=EN?HRBJRGNULMSKAG=?G9?B9CC:FE:IJ@RYNR\Sckfw~}y}w{}rxwr{ww€w~~tzyy|z€ƒ„ˆ‹”•’‘—“ŠŠ‘‹•“—‘’—ŒŠ‹‘ŒŒ”Ž‘—”•™“”˜Ž’–‘‘—““™Ž‘”’“˜’’˜ŽŽ•ŽŒ”„ƒ‹††Ž‰’†ŠŽz‚x}~w~~mtr]fcbidaiaU`UXbWW]WV_VV_VMUNahdejiZb^V]XZ_]Y_[Y`Z\e]Y\XV[TTZT[`_uxwlqjgfaKOGHMCCKAINDHMEEMBEPCHWIM^OI\N@QEE]TKcWJ`ROE>M@;I<>L<>NA8J>=QB13:.17,7>28?37>15=-:>1;<088.58.4:035G86F98A46<-6>.4=-06'.2&04(17,18,26(02&//#(''''&&(', ,4'.8,4C6=M@AN@CSD>R??TA8G87E9BUHJ^PIYL:H;1A36I:5C6-4),+!,&+$(%)&*$(#&"%#'#-*%+'#%$++!22(<62:<6.3,JB8F;:H<=H;9B4:H;?E:9>38=2:J==MCAJ<=G8=G7>G<=G::E89C58@4;?57>58@649055-41)82+49-69-79-=?2>>2;:.8<-<>1>?4;A6;G:7G:9C758/74-85.97/66-53+87.77-54*5/)6-*;0,;1,5.&52)93-5/*60+71*73,53+43(00%2.)35,8>3;?4882<8695083-7/(60(72*4/&1/&3.'5.&80)3/'1/&5,)1+(1-*45-46,49.4905>26?26@27B58@67B8:F;;F<;F<:C99A77?49A6:B7>F;:A648?48=2<=2??3:B66>35=2;A5=B78?4;?0=B3?B3/6<-6@08A26A1?G76F89E4BM=DPB=J<K??L?BRBBTCDWDHUGFTF?J<;D76?29@3;L:K==J;BP?KXEB3?F7EQ>EQ?JWEMYGGPADI:GK=LQEJTDMWGITCJQBBH=>C8AH=BI=EL?FM>DL=EO?HSCR\P`h_jrjYaX@F9DFA56=09@34@26B49F85@33:.6<08>3DJ?=C78?37A2:?0;2829B35@-2>15>019+13'11&11$12&,.#,-#/-%20)+($)'+),* +* ,+!-+!-0)34)1.#-+ -,!-1'.2&*,"** ($-$.$%% #!(&*+*--,+,,."41(0/&,1(/?1:O@;TCG::F:.?3,9.07*48(6<)09*,4$).!)++.#.2'24'23(00$++))''(()**0#*4',9-5C7=L?CUE@WDAXEEYI=N@@K@9K>-D6?QD>RC9O@:J467-/0'12(+,"((&),- ..".,!.,"(+!+/&IYKJXMGTGITIFQDHWIEVIARDIWHR^NHZKBTE>PB=OA>NBKYNH^QI]RH[Q@SI@QFHXML`TObTJ]JCVCAPBERHGRFCN@?I;E<9C:;F=28=/8=18;/;?58?43=11<25?55>57>569178/5818:267.6:06>25=24=33<25>58@5;A7;B75?76=79?6=B9:E9>I=?MB>I>=G:>G:>H<=G<:F<:C9@H===783/51-42-65061-51-50+71,62+32(42)2.)61*3-&64+99.7:.89/9;15:/5>36?36C68B59C68E7;D75@39?38=2;A64>?395,8.*:3/:8.68+:.8?0H9@K;>KG;?F6=G8>N=@R@ARA9F58H:@MA;F:6@49B69E7;D9:B67B6=HL@CLB@I>9C65?27C19E4=I=>J>;H=?QCBSC=E<D9=E;@J@?H;L>CTECVDDWDGPE;K>FXI[gYtvkNMDGE=@B9E8=F9CRAGWGETDGYHFWFDQADN>FN?JO@KREHO@JPBGO@EO@FOCKQBIMAIMAJNBHK@DJ>EJBQVMTYPgkbKRG@I=JN?JNCEJASYMV^R_f_x||†…x}~‚‡ŠŠ“‰Ž“Š‘…ˆŒ‰Œ”–™‘•‘’–“’•”’—“‘—Ž“‘”‘Ž˜–““š‘‘–Œ”’–‘•˜””–•—Ž—Œ–•’•“•™’“™”‘——“œŒ‰’Š‰ŽŒ”ŠŽ’€ƒ‡wz}{{~‡†t}{fpjZh_Zh\UcWRaUTaVS_WX_Z[`_affcmj]c_^c^ae_[cYT`VRZOQZOT\RX_WRYSU\TQWMJQFFODHMBNTHPWKJNGFLBFNAN\NNcUD_QFaXPrgFi]?\NB[M?ZKA[JEZIJZIGXFCTDFYHATEEYLOdWK`R@QG8H=6E76G96G99H::H:7E68A47@6;@7BG?AE>>A8<>2:=259138/:=1==07=,<@3:>38=27;058-77)65+30)10(//%32)07*1;,-;)-8(25*2/'4.(10&.2'+1%./$.-#1+%--")3%-4*.0'/-./&20-,)$)$!,(!)&-(!.)"/)"-& .'!.)!.(!0+#.)!-'.)!0*"5.)1-$/.#10%.* -( )'*( 2.%20&15)4=08A46>12:-6:+48)37(16+-5*-3(,/$-,"0+#.,"-+!.+!-,!/.#)&+( (+ *+/'0( 23+4<,4:*47'/2#47,/6)24(+-!**..".,!+(-$'##"%)', *-!.* /,".,"-, *, ), (2'.7,2=13A44C33C228..5)-4'-4%03'..#0.-- (,!$,!%-"*0#-. ,,)(('%&&''%)'()*. .4&09*09)8D5:H:=OA=PC?SGGWI@SDAXIB[LDYJBSECNB9B7;C8;?465+0-#'()(!.+'*( &) DFAIJ@54-&#'$((!'))$+( 0-#4.&/&,!,&&%#'%,(-+,%- )3&)4')7&.;,6B2;>409-.7*23(,'!+& ,)('+( +' /.%782ObSJ[OEVIEUIETFGXJI\MBVGCUFETFARD@PB@QD>OB?QCDTHCZIF^LD[KAWHDYIE[JK^PPbRVjVM^KFVGKWMIZNIXKDRE=J=H<>I>=I>9H::H;7F74@33<22:028,49-57-48,3:,5=-:D4HQDMXLHSH=K@7E98B6@I;;F9;E88A5:E88E93C66A88C97A79B88=458/4:07<269/7;/8=14<06?5:C78@5:B6:C8:D78C76?46?46>35>39E9?LA@L??I<=F:>H<>G?:F<9D99A6:@5:=28:/4;+69-:9063*41)74,8=278.76,76,97-98.83.66,8?1?G9=4<826/+41*41(60)6/(7.(90):2-61,0,'2.)4/*70+6/,82.96.:;2;C9?IA@OCAMACNCKULHTLEQH>@;:7253.38259356054-64-41)6/)40*30)50,5/)5/(54*89.8;/57-7:/49.3;05?39C79C728=1:=2>=263*4-(2/)98/5;,9:/8>16?2=H;@I>9A6:;2<=3<=19=1>C4@F6DN>AK;H;?H:?KK17<15:/5<1;C8:C86A5;E8:D75?27A37A2E8?F<=F;H;>H:?J>DOBDQBCQAAMA=PAJ^OgreRUKKJABB9@B8>D9>E8>C5=C3CE9=D7BM@GVFEWFEWFK\KFVEEQAFP?FL=HM>FMAEL>EN=ISBLVGKUHMUEHQCIPDKPCFK@GK@BH>GMCKQGZbUFNBLVINUDLRENTJT\OY`Sdkcwxw~~}}~ƒ„‰ŒŽ“”Ž“Œ’““˜’–š“—‘–”‘–ŽŽ”ŒŒ’‘‘˜Ž—‘’—””š‘‘—””‘•’‘“‘’—˜—Ÿ”“œŽ—‹Ž“Œ‘••”“™—”›Œ”ŽŽ“‰‹~‚„txztxx€€w}{mtqakfbmfcog_kb^j`dng`jb`fc[_^dhg^fb_d_bc^\_XV]TR\QMVLNWLNWMOWMNVNMTNLRHHNDGMBKPFPUKSVLKNHCG=DL?ITGI[MAYKAZOPpbEgXD`PE^NB[JAVHBUGAPC=K?@REDYLF[LH]PG`RBZL?VJK=:E8F=DKA:A7A6:?2=A7DG=@B;8;258/49,37+.1'/2)-/%/1&09-0;-/;-1:-57-41)4/(64+25*/5(12(.-#.-%13&25(--%-,#0.$21(1-()&")%!)%)',&-%-&-&/' 2*#/*"2,$0+!,'.) /)"/)#0-$65+55(-*-) ))*(/*!-+!/1&18+9>19@339-38)/4&.4%14).3(+0%.1&--#20&20&/-#+)+),* *),')*,, .'/(10&59,8<.69)47(59)17)24()++, /0$00%.-",&'$'&&(,-!,-!,.#-/$+/")/!(0"'/ ), ), )."*0#,5(.5).0(-1&29-18(+0"'+)(()&* (-#)0$'.!)-&)** ** *(''($$!"!%&*.!05(27(.5'2>04C74H;6M@;NA@TFDZLBWHDUGESC36*)- ,."22'52'2+!*,0-'20(--"')(+%)+"-,%960=94.+%0/%*%(&'%%!(#,&,'''(-!+3$,4&-2#)4'.:,1>1,8(/;+0;+39//9-,8*6;03/&/,&*)(()(**!)+#)/%UgXQdTEZL@VFKZML_PMcTE^NAUHAK>CM@GOCFPCBM>>J:9I;7F84>33;127+48+28-39.29*4>.9C4DM@KUIM\NFWJ>OB:K>?N=BOA@K=;E89F8:G:5F99D87C78D86B67@44:/3>15?25<048,59-8>1:A6AI=CL?@I<9D59D4H;G>>E@9E97?48>39<178.3<,6;-::/63+21(88/6=258.65+:8.86,86+91*55,7@3:E87<264,54*66,<=3?>4;705-*30'5/(50(7/(:0):1*81,60+3-(3-(5/+60+71.84.==7>H=AOEEVJFXJ?RD?NBDRHAPH>LEAF>:>59>45>55@75<37<278-52*60+6/,60-74-41)5/(43(76,89.7;06;06;06?38B6;E9>G=>G=:F;:C96?5:@6;47?28<08>16@39B58A56>38:189069.9=1;B3?E4?D5>D7;E8J:EP@HSDGQAAK;:A29C3;H7@P?CVCFYFI^JLZIMZJGSFIVGHTECR@HQCQ[IPYGGQE9B5:F5=H8;G7>K?GSGBOAAN>@M?AQCHYKGXJ?OA:H:@>398-64*42(45*58,9:068.58.4:/5<17>38@28?25>15>18A4BM@MVICM@@H;>G:>G:;D7@I<:D97D:=L?=J=>I=BK?DOB@N=AQCAWHMbS_j^GKABE<@B8=A6=D7?F7NA?MA:L?;NABWIL[MGWKGZMCYLAWK@VJ@TG?SFAUHBSECREDQCI?AK@AJ?3;A6A7BE>JLFCE@9;58;33<1/8-.6+.4)04).2'/:0/9.2;059043+2/'40(66+59/26+22(00&.2'56(3/#-'0)#2/%.-#,*",)#*'"(%,'-' -' .'!1*#0)".(!1+$0+"/+ 0, /) .' .' ,*!10&0.$,,".,".-#.-#0-$.-"/1$03'56*77+57+27(28).4$22*02'-.$01'23)44*53)0/%.,".,"31'1/%-+!,* ,*1.#4/$-+ 00&89-57+39)16'/5$13%.0$*-",0$-1%.1&-,",+ ,, ..",+ ,* *.!,1"+2#,3$,5$-6&33&++.-!./%01'-.%/,&,.$18)/:*/9(+2#,*!(&'("'*!)."(, &.'-!-1&33)/.$'$&!&!# " &&,-"10".."+2%.:/0C7-B66J>6J>/C61C49E64=-.-+*/- /. /.1-66'65,0/%,,&'#&&) 32*<942+',( ,*!+&('%%$%)'('(&%&+0$1:02<-/:*(7)2A36E75D44@0-8'/6,0>0:I9@H943*** .-#.,#((('&) $) HXJJ\NFZKAWGGWHMaRNgWKeXB[M44<138,6:.49/3:.1;+4>.7A2:C6?J9GTHGYLBTGF::B57@37@4:E7:D99E96D82>22>25?30=.3H;=G:G;:H:F@;F:;F::B78>38=249/5?/7338-87-86,97-85,:2+87.7?47A559074,64,68.8:0:9/;7.82-41)61*82+7/(80(;2+92.82-3-(3-(71,71-40+550;B:ALECVJBWJBTFBQDBODBLCAMEAMF?J@>E<>D;8C96C9:C9:C78;063+7.*5/+71.75.41)5/)20&75+99/8<36;26>47?59B8=F<>G<19:167-58-9>2;B49D4@D9?F:=H8?L<@M@@J>AN>DPAFP@CM>DN>;F58B2;G7@O>CVCEXEFYFO]KLZIESCFSEESAGUCLXHUbNTaNHRE9C6;G6;F6:D6BO@ERDBP@CTADTFDTEEUGCSEAOA:G99<088-65,33)36+39,97.77-56,57,8<17=2:=19>26=0:A4;D7=F9=G:>H;AJ=?H;?F:?E:>G:AI?D8AE9DKODK[PLSGIOEEMBFPEDRGFTJCSHCTI=PCBTF@SD?NA=N<:H<E8B:DHL=?L>45=36>28@25=32;/19-4=/6?27?47?1=H;DSG>MB=I=;E9:C7F:>G;:D7=E9I;>G:?H=:G;;F::D79A5G>=E9;C79A68@57=37=46@549131*20)46.3:/39046.86.97/76.54,73,87/4:159/36-66.56-7;17<179/87.94,32)51*64,50)92+:4,52-72-3-'4-(4/*51-63,7:4=E?=LCEXMCYKBUHCSHBODANCDPGGSJDPFDJA@H>:C:8A7:@79B69;173+90+40+42-75-53*31'30'42):905;16>45=36?5;D:44=25;04;17?46?28@38?2::/78.37,5;09A58A5=E9?I:?J:@M=@KCO?AK;=G8AL;BM=J=APABUDCVDCWDL^KM^MHYHJXHLYHO]IQ`OZiSSaL>H:7@4;D4:C38B4?H;@L>ERAEUB>OA;L?@M@>K>G:CL?>G:9B6;C8>F;@J?IRFOYM@L=>O@BUF@SE:I>=G>>G>@KBAPDJ\NK_RJ\P>F;<=1:<.>C7?E7@H7?F63?D6HM>DN?BL?EMAFNAJSHBI?BH=CG<;?4?A7CF8GJ=BE:@C8@E8DK=IO@MVGW`SS`RQZNQXLP[LRaQO_RO^PR\PY_T\fXemfkpnejfkqk}‚~…‹Š”ˆŽ‘’—š“—”ŽŽ“•””™Ž‘–“˜‘•™“–š’–šŽ’–Ž’–Ž‘—’š˜˜’š‡‹•’—“’”‘–˜Ž—Œ•‹“Š‹“‹Ž““˜““™’’˜”‰‹‡ŒˆˆŠŽ†‰‰y}t{yv{z|z}|uyy||{mqn_c`TZUQXQXaYW_UY`UY`UT[POVLQXMRZUKTNFPIJTJGRFJUHPWLLTGMSILPFIMEKMGHKEDJ@AM?GUGEVIEVJHXOKaWHaVCXOGYPEYOF[NBUHDUHAPDEPDFQEJL@HH>CD:FI?CJACKADPG@MD>NCBTFCWG@QD?O>AMB?L?=HA5;?5DHAORGEH?BD>BD??A:58/37039.05*,2%/3(.2'+5*06-54///%03(27+29,29,03+.2).2(/1&//(77*54(.*",( ,*-/!04(-3)*.(+,&/,%.-%-,$--$,,#,+#.,$0.$.,!+)., .,!,* *),*!-.%12)42(42&54&65'52(1/$1/$10&20%31&22&68)59*05%.0&33(43)31'21'11'2/%-+!*(,* .,"0.$00%1/%43)7>1:A279'03(-4'5>16A39C62=D6=H65:*-1!)-"+."+*,))',* FOBFQAHTDMYGN\LL_QIaSLfXJdWE]S@YM?SF?NBBMAAOA@OBHRBHWJN`RJ]OCSE?L>AJ?@J@>F<=I>=J=BNBBP@GVEK[JM^MEXHEWJKbUF^ND[LCYIBWE;P=;D827A56D71B43B51?22=13;06<25:05;37=69B8>H>?G=D9=D:>F<:E943=33<72502/+31,58/3;058058/86/77.56-46.46-76.85/43-13)36-6926<17=26;066-42*12)44+54+52*51*82+64-62-4,(6.)73.73.64+9=7>GB=KECVKBUHCZNFZOBSH?ODDTHCTHANCCJ@@E<;D:5:18803;089193,81*1/)11*42)43)42'41)41)::14;25=37?59B88@66?55?24>21=/6?35?26>17;349014+33*40(60(30+75.8:16:28>45:228-5;04<16?25=17=.;;/89-26+4:/5>48A79C7;F8:G5;H7G;BKDQA@N=?H=BNCARD@SDBUDCVDH^IFZHL^LP_OS`PVcOTfSTgOGV@8B36=19@19@19@2:B6BL>DQ@CR?8I<;I=;G;;E::B74=27>1:=3>>4::066+68,:9/=;1890<>4:>35:/980:;18;0:?27A09B1?F8@H;=F9=G;>G;=H=BKCFOEHREESCDVD>Q@>J=9@6AC=CE@=D>CMCHXMJ[PAOD39.;;/:<,?C8AG8AI7BJ89?5AA5A?7<:2<=4@B8GH=JJQD?L@@I>FLAFJ?BE;AA8@A7>C:AI?DIB>H?;H=BUHDVH=K=>I=@L@>H=?J=?E8./8,/7.27.17-/4)2.(77+35(/0&//%22#36'6;/08..5./0+21(-0'14+/2),/&/3)03*31'0-#-,-,,*,* -+!+) ,,#32)33(43%65'55'43%31&20%51(10$0/$22&45&55'23$-0&..$/-#0.$20'32(1/%/-#*(,* +*0.%.2&.,"/0&4?2:D3@A1>B4:C59E76C79E9=G;>B27=.6>16@37B62>45>2:C3:@/28&.2&(.&*,")-"(,!(, '+ +-!*/$*0%.3(.3'-2$.3$-3#.5$,6%.8'*4&*0%*1"*.!** +))(,-!06*3;0-7+/8,6<-66'/1".1",-+*(%)'+0"13%/-"*&'&&)),"//&/0&/0&-0&+.%-,"+*,,!+)-(0+!,,+*!*$&$&$((!() )) () ') &.!/8)-,!'&&'**!20)*(+$-)!.,%*/'0XJ@RD?M?@M?AM?DK>IDQCFYJOaRO^PGYJH[LCXJ>Q>ASB>P@>K=?H;=D9;@443?33=25=16;/5;1:@6;B98@66@65>45>24<.9<0B58G;:B:;D:G<=E9=E8>F9>G<;D8=G;H>=F;9A78<165+54(64)64,74-30+2/+22(30&4/&50'51(66,5715707<17?49C78A78@17>06>19A49@49>36@648/53+50)50)52)68,7=17A56B58B6:A559.3:04=04=06>09>/8>26;.67-56.7726:36>39C88D:6D:8F9?HISAGT?@R<>K<1:@-7>+;D3AL;EP@CM?56;+8@29C76>48<0:9,;;/9<08@37@36>18?27<10CF;AF:=G7EOC?N@H==G;8D9?MB@VGEXK>H>;:1:;09B3=I:>G:@E:CA8>=1@>1BI:MUFDO?HRBCI9IN>GN=HO@CK=AE9AC8?@72<@6@C:AC:CC5GG;HL?LREIOCGLAOXJS^RYcYYe\^j^kxjjsj{‚ƒŠ{w|z‡‰‰Œ’Ž‹‘††Œ‰‹‘‹Ž“‹Ž“Ž•““™””š•’™–“™”™”˜Ž••’”Ž“’‘”““—Œ‡‰Œ‰‘–‹’Ž•’˜‘–Ž‹“‰‰ŽŒ•˜”’œ””œ”“™–ޑޒЉ‘…ˆŽ~„tyznuuw{ztutklj[`]Xa]]dZ^dZaf]bg^Y^X[`YV^UT\RTZPSZMPXJSYKRXMOVLLSLHQFGTGGUDJRGQYNSZPIRGJQFIODKQGHOFBK@HRIHPIFOFDTHDVIFZMH[O@TGAWID]O?TGEPFBJ=DF;GH;HL@EF:EG;@B6>D8CK>AJ@?E?>B=EJCCLD>J>>G:AE9BE8AE85BG?MSMCHA9;299.53)22'/3)-0'31+2.*3/',,#25*17,16*48,28.6=09@3:A3:A48@37;08<1;@448,38*5:+2:+7>/B4>C5:A2=M>BWH:K?9I>=NC@I<;A5;@38=23<42>64A/7B02:*15'.1&+/#,,$&(%),.".0!11!,.".0$.0$+/#,0$/3'02'+1$*5%-9'08)/3&'.!*,"*('&((/3'0>.3=/09,.4*/6*-7'06+.2%0/"10!,*))/101 --,, ,,// 02$/3',2'+2'.3&-2!+,!*+,++*+,"**#-,#.,!,+)('(&(*'!*,$.3)14+22(3/&-* )&*%-(.*#-*#$%-4(U]PLOC.1'/5.0?4,?3,B4;QB(;2"0%!- )8*(9.->16G8-:.',%&'!ESFGVHGXGJ\HK[LM^MRfVNfXKf[Hf^B`U=UHJBOABQ@K\KMaML_MHZKARFAQE?PC>PB@K>>K=?M>CN@>H;>H;BJ=BQCDREHVHKYLN_QObSUiXLbRCWI?QC=L?9E99A48A36>06=0=D7BI<F;27?34;/5<29?69A78A77@66@56>34;07<1>B7BG=AH=>G:7F95B88@6G;@H=?G<G:;D88A59A69A7339/8;059.7<16<16:044+53+54+66,=?5>@688267158.25*78/98/:4-92+;4-<5.:8.;>25:/5;15;38;36=49A:=JBBRIFWKEWJ>TJCWJBTFCTFCTG>OB557.75-74,53+56,59-:A4G;8?47:05:/5=04=04>0:@28?26<09<19;25904814:07?49D:8F;8H;;JGQADQ>>N;=H<K>-9@/@F6?I9=F:>I06>17@57?558.;:0;;069.6=16=18?41;B5>C7?G8DO>ITF?M?QD>G==?5;=1CK;BL==E8>A6>>4?A4AC3HM@MQEFL?GL>GL>FI:CJ:EL=EK>EI=CF<=@6AD4AD4=@1:@1?D6CG9CG7EIFK?DG;EG;BD8CHDLA@H;8A36;/6:-8<-5<.9>28>28;014*/1'-4*28-26+45+//#-+ ..&-.$., +)+*,)!02)65-64+//#23(16'33*00&/0&23)12(00'13(55)20%20%54&43%32%20%42'21'21'22'20(-0&,.".-"-+ -.$2-"0+ /,!10$77+<<028:-47*/7,7A6=D4=C3;?/;<-=@17=3*&&+!+.$&(()(* $&'')/%4;/)) ()!&+%6G;FZMH`QF_NCWI:L>6J?>N@CPBERDHQDENADI=FI=FQBHPDFRDFRDL[LO\PL_RI\OASF=PC=M@:H<I=47?57?56>59C7:A77>38>3?E:AG<:D97D85A79@69B7;F:E:>F;>F;=H;E8=D8;C99=458/78/46-57.36-77-8:/6?33>33;13>13<15:/6:/6:/7=26>249/34+55-57-6:.<=4<=569369217,39.8;287/71*;3,?5.>5.;>0=C4:B54>18A6NC@TG?PG@QFAOCCRFCSG?PD>H@=D9;@76@67@46;144*42(31)42*41+2/)60(52(44*56,37,28-35/05*34*8:.<=3:<29A38?2:A4;A6:@59@48:268.56-78/37-5;19?3:B5H<>G;:@58<137,49.19.6>29B4:?4:>3;?49<538/27.7:/7=3:D::H=9K==NA@L=M=>G;:E8;D89C7BLABLB@I-8@/;B3;E59B5?H;CJ;AJ;>I9:E48D47C67@43<16>44;268/97/86.67.47.6;0M?BPBERC@O>=N>>P>=TE=SDANA?C7IM>DL=AF7>B624*9:/CG=2=B3CH:DG;CE9=@5:>3>B5?B39<->B2CH:EL>EN?JSEFNBFOBGPDNTIP]Kgpdw~x‚‰‡ajenypx~{„‡Š‰‡ˆ†ˆ‡ŽŠ‹Œ‹‘Ž”Œ’“Ž“Œ’‰‰••‘‘—–‘—“‘‘•’”˜’“—““—“”“–š“”˜‘’‘‘–““˜Ž––•ŽŽ•Ž”ŒŒ’‹Œ‘Ž–˜““š‘‘—Ž”ŒŒ‘ˆ‹‡Š|€txxlpmlpkfphlsmimfcib\c[]i_cjehojmtoflgkqnour^fZX`UU]RT\RTYPV[RQZORZPQYOPXNOWLLTHORGCH=HNCLTIJSGHSGNTIJRGIRGKSIBK@FLCKODBF;CGGK@JMBCGGK@DLAFODLSKEKDAHAGNCAJ>FJ>ED8CB6>C6:C66=065,42(21'31(32(43)99/78.47.38-15*/3(..%-/$-0'+/&,-&++#12)25*-3(17,28-3:/7@67B5A19=18<178.13*/-'31,26+57-66,54*.,".,"-/#66*86,+).,$00(;<3>?623)-/"/2&/4%15)03(37,47,04)25)98.65+53(53(<8,84)10"0/#0.#1/%0.%20(1/',1&,-#/+ 0+ -+ /+!0+"-)-+!/-"55)2;.3@22B4:C7BI=AJ@9@4;A4DH9I9@H7JUKGRECN=CM;?G:FQBHYHObSMeYIbTE^T?TG@PBCPBAOADRDBREHVIKYIR]MT_PR\OCSG>OC=PA;M?:J;=L=MZLM[MDRDAL>DK>ILAIQAFQBESFEUFHVIJVJJXM?MAL@>M?AOA=G:9D48B2@I8=H<;E78?2:A58@35>15>38C76C76D86C76C64@65?57?57@67?5:B8=G;AK?E9:E:8B89A7;A7;G::B6;B7;C8=E:;E99C7;B5:A58?28@39A4=C58@7:>58;27:19=47<369068-7;/6A44@46>43>14=13:/8;06:/8=26?54;05:/48-8=38=49;18809:569227.8?2=>687/93,91*<4-<5.9=/9B27A46@39C6;F88E8;E:=B;9?8;H?368.46,65-31)21(2/'52*31)34+57.37.06,44.01'35)68,9;08;09>29@3;A6;A68>38=48;136-47.5;27=49B7>G;H<558>36=22:/57-6=29B8:G<AM=AM=>I8>H;=K=@PBFPCH>:C8;C7AOCJWIESABMA?G<;@5:;169+7;,7?09@18>05@0:C6BM?EMH88B59F87F75?37A55>28=39;2;8468.45,56-69/=B7:C7G:=G;@K>CM@EP@MXHFSCBOA>J=FODO^NReUQbVESGCM>NB?SD?UHG]NQ`OU[LIM??G8;>0:;/64*98.>B6=C4?@6<@5?D8@?798-95,>A4>A5CC7??3;>28>2>A8?@6<<1AC7EJ>DJAJUEJTGDNAHQEJSFOZN[hYkvl‚‰†v|{ekiv}x……ŠŽ‹‰Ž‹ˆ’Š‰ŠŠŽ‰Œ‘‹Œ‘ŽŽ”Ž”“ŽŠŒ’•‹‹’“ŽŽ”ŽŽ””•“’–Ž“‘’–•”˜•”˜’–“”˜“•–“”™••š™‘•ŽŽ•ŽŽ”•–“Љ’““˜–‘–Ž’ŒŒ‘„‡‹|otsntqlsmgnhdmcemfcjeqwspwrltljsolurktqclihqn^hd]gZV_TZbWYaW\c[]a[W^TQXNOWNQYOSYPNSJJLAIKAJODOUKGPEIRGPVKHPEISGKTJHNEHMDJLCCH?AF=?EDH=EI>DJ?>F;>F=@H>=E=@H>BJ@HQEINADC8?>3GPCJZNGWJ?L>9A46<.;@1/8L;8O=H7;E4MVJHQDDK=AH7BG;AKJ=?K>?O@BSD@RD=N@?H?;E;9B8;@7=C99C99C8;C88@6=J<F<;C97?46?36>37>47=37;1;@6=E;14;.7;/7;/5=/7?54;16<14:/7?47@58<55938:437.59.>C7AA887.64,;70:70:8/8<18@57A56@36@38B57B79C78@98@9:B;;E;2:?5=C88>37<36<38<328/4<28A6:C9=G<>J=35=26:/7:07;26;1;<6:>56>46?37@45>18<17>49B89D::H;:H:;H9=J:@J>PADP@G;@J>:B8=D79C7=HF9AIH<:E88F87E78D9/:B5ANBAP?ETCJYFERAGRCGQEGUJRbR^n`XfYCPECRE@PF=LCAODAOD?QCAUGC[MLaTRcULTFCF:8?369+66+88-:9/7:/9?/9?3?E9AG;<>365*96+?B6?@3?>3>>1:=18?3=?9;=4AA4HH;CF;BK@IUFGTEJSGJVHM[NTdWalanxqw|uzzx~}w~xs|zv~yƒ†ˆˆ…‡…ކ‰ŠŠŠŠ‹Œ‹‘Ž”““Ž”‘Ž”ŒŒ’•‘‘—‘––”˜’–Ž”‘—”–›”•˜’–“—“•–””™••š’™’Ž˜Ž•’”˜”—›‘’—–•‘‘—•Ž“”Ž’…ˆŠ{~vzyryspvripmgpgholu{zƒˆ‰ƒ‰‡|ƒv}ygnjbif_fa_f`elebla[eZendai_`h_YaXWZSRVMPULQYOPWPKQKMPFKODPTIQWLMTIOVKRYLHQFKSHMTIMRGLOFKPFHMDEJABI@NTKJQGJNCY_Tah^NTKGLCJLDDK@EJ?EI>GK@AI>>F;?G<@I?=F;8A7FM@AD8?B6>F98A44;.36,26+28-39.48-36+24)99-76)43(1/&12*/1'.,$.+#-*".,$00'.2'/1$.-#,,"-.$-0&.0'46+:@4364,0/'27,7>14:.26(8;,67-::167/45*15&42)22(33)55+;9.74)21'00%1/%31&1/$0/"0,",,#0.&1)!2+!0.!//%44*79-24'02#24$31(//%'&,&*%&$#&(+*.--.,.+**+)-( *%*%+(+%*()'()-,!++.-#+)*)*)-+!,,"/-%,+#,-&-2(/6+0:-48)/6'+3$-2&+0%*+"'+!)+",,#..$-0")/,-!*+..11#)+%('+ /3(37*37)15*-2(35*57+26'05&.9(1=/8B55=/26'-/#-/%+,%+."(*'%'&)++/*, &')*,,"++!/.$5:104*)*!+* ,.$*-#./%%+!%*#(("%%$)%/!+7(0B16H79J<;H<:L>9MA:NB:K;:Q??R@BSDAN@?K>=K;6D4QWLOWGFL=EJ:BF:=F8?M=?P?DTHGYKO^UN[OKXJEREDUGCXIBSHCUGBQDCRB=N?:M>>H;8C56D69C69E5AI9KVIUdVPcTHZLDSEEPBEN=EVEMcTMeVOdWQaVN^QDTGBQCARBDWF@VD=QC;N@;L;H5CP>E6:?0:?48?38=16>26@56B62=39E;?NCH<>H;>G;?G<D;?G@?G>=F<8B77A48B65>26>36?38@6:E99E97@5:A5:C68G9:F9?D::D76@23:-48,7:.5<04=44=23:.3<04=23=45;46;549204*69.=@3>=575-64,75-78/9<39<1=B78@56@34?3:C7:C69D86@88B:8?87>5:?<39@49>69>49?59>53;28A6:D9>G<@I??L>@L>:D88@5:B7:B89E84=148-68058.6:19:36934;14=27@37@39?47?48B87B7:E8L<AN@?H<;E9>E8?HH<:E68@/6;/8:1;<3=?57=/5=,7@49A4;D7=E8>D7?F9?J:AK?>F<;D:8D9;G9?K=;F59@29;088/34+33)55)79,5<,7@09A6>F;:D7:G9>L<>N=?P?EUDN[JLZHPZLKVICUJUeVepbT^TIWLI\MFXKDUGCSDATCEYGCYEH\QLaURcUEL@BE98?59<.67+:9/88-88-8;-AH;NUHAI<79.88,:8,>B6?@3;9.=<0;>28@4;@6?A4EE5IJ8AF6DL@FRAHUELYJMZLRcUVi\jumy‚t||z€}„‚}ƒ~u€|v€x„ƒ‰Š”Љ“…ЉЉ‹‰Š‡ŽŽŒ’Ž”•”‘—“‘—ŽŽ”–“”š‘”˜˜•˜”“˜”’”˜’”š—˜š‘•™’–‘”•–—›••™–’œ“™’—’•™•˜œ•—›““™•‘‘—‘‘–•‘’•‘’–‘‘‡‹Š€†ƒ€‡„lusmutnuqx~|‚‰Œƒ‰ƒˆŠ‚‡‡y|`ea]b^ZaZ`g`ioi^g]\e[^h^]e[W_UQYORSLPTKTZOT\RX_YQXTOUJMTIQWLW\P\`TY\RPWJLVHIRFJQFLQENPGMNEPQHNQHJMDVYPKPGIOCPWLIQHEMCELCCE?BH=GL@EI>CH=@G26=037+7;09:.86)31%20&1/(2/'0-%.)"2,%/-$-+"*-",,!.-#0.$..$**"/,$0/$24)7>0;E8@K>AMAFRENWJIREAH:E9=E8;A2:<-88.75/85/77,44&42*34+03(25*67+43'21)1/'//%41&0/!.,4-".+"-+#2)"/* ,+-,"/-"/, /.0.20"1/%//&-.$.,")'#((,"*-!(),+,'-&&)**+'(#'")#+$ &"%#&&+*++,+ *)+* .-#,-"*+!++.-#++"-1&.6(0:)27(19*.6)*2((,#)) &+"*,#+,#-.$*/!'-.0$+,.. //!00$),!+0$07(29*.5'.4'-1(-6+5<01:+0;*1@06H:L@E6BM@FUFK\KPbRBUG:LA@M@EXKNgYMgYMcWTdXTdSK]LEXGAWEDZHCXF@Q@?R@:I9>F7@E6AI:BN>GQAEL@>C69A35>22904<25=57>98A:BMAHWLHVJ@JA@I?F;?H<=F9;C8=E;F=@I?=F<8A8:D>9G<;G<=E:;B7:B7;E946917925:.5=/3:55<319.5;04;05<05<57>36;/8:.::098.950;3/91-;5-:916:17>5:B88C96A86D:5D9:C<:E>:E==D>:<6>:6?G=;C99B79C68A5:>4:804;/9:095,91*92+52*73)78.4;05?35>33;/5:15:15:16=47@56?52<46<4:<4=@5>D8AL;CN>CN=@J==H;3:?57?48?249E;:H=;I=>L@>L@=L>:J<=N>?TA@TB>N??I<;L>;L>;G98@36=08;09;/9<09?37@36>19?24>29D8:F9:D7=G:36:248.68-46)66*58,59-:A4:C6;F87D89F;=J>AMADQAKZFSbMWfQUcRO\NOZQ_f\god]l_PbUJYLHWJDVIATGBWJCZLD[NEZLL]QMYMAJ?>C:D7EG=B@6;:.<<-??.@B7;<188,<<.=B28?0<@4AD8GI>E;@J>>JC:8=89C=:D:AG:IODDH=BD:@D98=27A05>14>17?29>17:/58,3:.8:/65,4/'3/%3/%30&31(20(.*"0*!3,"0-"--!,.".0$+, /.#0.&.,#42(98.:=1>D7BM:PYHPWJCK>18@27:/68-46*04(/3)24+55,96.85,53&51+1-%1/'--#..#.."--",+ ,* .+"-(-(1(!.'-'/-!33$32$1/ 20$,+!()&,)0 /.".-!*+ ()+* (&'&(%)&,&)")"&"'#(%)(++,..0!-,--!00$./%*,$,, ),!(.#.5(18)09'25)13(32(0/%-) +' '*!)-"*0#+/#,1!12".- ./!03$-2#/4%.2$25'36+47,.4)-4)19.1<23>22<1/8,0;/5A37@316+/0&)* *-*,,))(), +2#+1"(0!',!*,"*-++),+/#)0%.3&,/"35'14(,1&(2()4(0;./=,'6'(7*4?.3>-4A.0<*0=,,;)+>,1E57K;:I=?MBDWKCTI:NB8K?>REH[K;L;IOBAJBRCIXIHTFDTDCSCBVFDTCAOB?I?=E9?G9?G6;G8>K<;G9;G9;F7=H8?K?@OAHWGHWJDTG@OFBI?FUIMbVLeXMdXQdXQbTJ\MGYIDVGDWGBWFDTE?RB?P@BL=BJ=BM?BO>BM>FNABJ=;D75?31915?48?69@;G;BL@?H=@I>@H==F=@H?H9@I29<45617827<25=03;45>44<15>02;-3;/5;37=35:.:;/::/76,81-:2.<3.:7.:;26<25>48B8;D97A78C98D9:E=:F>8E=;C<9<6=:6;@7;A836=27@39@3;>39<17>35>36D8?MAAOC@OA@PBCPBFUFBUB>Q>?L>@J=@J=>G906>18>18=17>34;:0>=1??1>@0=@19;-<<1@@4>B4;@3>A4CG;GJ>FI=HL@ORFPYKQZJR]KU`O]h\nyq…‹ˆ{ƒƒ‰ŽŽ†ˆŠ‹Ž‘‹Ž…‡Š’‘“•””’‘”“‘—‘–’‘—“‘—”‘›“‘—”‘—Ž”‘‘—””š’’—’“–““—”™—“œ–”›‘–‘’˜“”š““™”•›““™—““—’’—•”š–”’˜—”•˜””š•”˜—Ÿ””𔕙“–š‘•„…‰{~v||x‚~€ƒ„‡†z€ovtryvtzvfmi_fagnh]ia[f\_j_T_UPZPNYNOYNPXMMVLPXMXaX\e\V]VY^TWYOW[OSYNV^TW`XYcXU_SVaZT]VU[QQVKFNDEOFNVJOVLLSIMQGLQGPTJQXMMUJKSHKTIKTHFPDFOEFNDFLAAG=G:?D7<=5:?9:D=;F<AG15E=?F<=E:9A35>.7@4;A579.99.55*34)15)59.68/98/22(53)20&.,#/.$0/%0/%.-%/-#-+"-+!.,#/.#.,!1-#/+")&.-"34&34%34%/1$+,"(+ &**/ ,***(*,-#.-#)($%))+**()&($(&'$'$*)---.00!,,,()'-,",.$21%04(-3(/5(6=.7?.78-/1$..#++!)* *(%((,!'.!'+ ).-.+, ./#/0$44(12&01%02'-1%*1$-3'/7,/7,1;.3=02/9D59=100&/.$,+!,. */ .,#++ *.",2&-3&-0",-$+-"+-+.*/ -4&/6+18+18)08(,6*,7+-:,-:+4C18I65F3;I:AK97A04A.4B/0>,-=*/;+.@01C49F:;J>=NBDTF?J=-6(DHK@CNCDN@?J99H7=K<;L<QBAN@DQC?QBCPBAM??L>BN@BL?BL?DMA?G<:B78A79D;6C:5E:3D86E:9G<G;F:AJ=FNCBJ?24=/3=-5?/5?18>37<1547@68@67?5:B8:B88C;8D<5C99C99A7:?7AF=;C9;C98A79B8:C97B;7A95?63=36;37815:078/75,2/'62,30+50(42*34*65,:8-;9.=>5>@79<39<37;269/4726:279/88.=?4=C6AK?BL@AK??MA>L@:G=;G<7C84>55=349067.89/79.39.58.48-6;08>36>35>38C78A5;A5:@55;05=1:F:?L@@L@DQCFSECQBFPDGSEBQ??M;@J18?28?29<09>19B6:D7;D7:C6BJ:9A1=F35=25>04=05=.5:0:;178.78.7;07=2<@4BM?JXJNaPK`QJcSOfY^qegsg[eYVbVQ`RXbUU_RKWIHVHHTFEOB>H:BJ;BJ=EL?FM@LSHKTH>@:87085,<:0:8-99-;:1>=3?>5<>2/@B2<<.>=/@B7?B6>C8DF9LOCIMAHM@IL@ORGQYKOXHP\KUbTamcu}v€…‡„ˆˆ‹Ž“‹Œ‰‰Ž”Ž”Œ’•ŽŽ”Ž•‘—•“™–•›’‘—””š’‘–‘–“‘—“’˜–““™“”š‘”™“”–“’—”‘š”‘š•’š‘‘—“’—•“™–”š”’˜‘–’•“’–“’–—•›“‘˜’™Œ–‘’—••›–•ž•”œ’’˜“”™’‘”’‚†‡y}s|{v~}„vzhsnhumnvqflg_fdholipmjsmeme]h]VdVQ`RP\PP\PNXNMXNQXRW_XYaZX`XX`VU]RYbVOYNMXNOZPS]UT^SR\XV\WW^ULSIGQHJYQKRGKRHMUKFMDFPEJSFQYMNXLNVKIQFIPEIPEHQHFOEGNCEH>=C8:A45;?8;C<>J>@F;=E:@F;@E<=D918@2=A59=169-2;.5;/9;145,23'46)77(66*32)0.&.+#.+#41)21)13*14*13*01(./%00&34*67-8<1;?4DE7FE8JG90B=4CD4>C4;E4:D79E98C68=037+15)/3'12&04''.&6=7eogksmiokjniX[TEJ@DH>AH;=D79B5:@55;045+86,53)20&.1$.2&590CE-55*42(/-#-+!,-*/ **"(('+ ,-#,-#+-!)*!)* *-(,(0!+4'-<.3@39D61;..8+-8+.;-.;-2B25F78G8;J<>E55>.5@07D41>..;+19,1=/2?06@54?30@34D97HM??OABWHBWI?QD@QC?N?=J:9I7;H8PD9H;>@:FNFivlhymZmaTfXQbUGWKHTHCRF=L@BTG>TD;QBL@=L@?NAGRKGSGDOACMAGPCS]Mcm^\i\RdWI\QEWPDVNFQFENBGOEIQECOA?L>DM@DNAEOCDNBBK@27@57@88E=6E94E85C87E:BL@BM@.4>08=27=04;,9>/<<188-:2,:2+93,96.:;16;08>57?58@6=A9:?6:@77?88A95@67B88C9:D7D7:B8?G=?G=>F==F?H>;D:;C99A68?36;259058059.48-59.5:/4:/:A6;C89C77A58C78A6:B78>36<1419?2:@38C69F8:H9@M=EP@CL16@28B2;A68=28:078.59.8>39=1E;?I=GUGPaRCYKH`SMh[Vm_Yh\\eY\iZXbUU\PLSFFNAGOBDL?BIFJ?LTIEPC<>9@?886/=;0==0??1B@6@@6?@5<@49=2?1>A2?A5CE9CD9IK>LOBKOCKOBEM@NUHMTEMWIQ^PWeXepgnxsz€…‰Œ‡ŠŽ’‹Š“‘—”•‹‘Ž‹‘Ž•‘—Ž‘–”‘—””š“–›”—œ–’–’’˜‘‘—•“”š“—’”š•˜š•–›–”œ•’›’‘˜‘“˜“™’˜‘Ž—“™‘Ž—”‘š“‘–—–›•’™’–Ž”‘•‘’–“’˜”“œ“’š‘‘—‘“—”“•‘€…„v}|t~|w€{„€jvpaodesidph]ib[b`ipnoutovsfnh`h`[i\Yg[WeYO]RN\QM\QT^XYb[YaZXbWU]TZbYS_ULXMIWKLZNS^QQYPMVRRXRPYOOWMPZQM\THQFNULHSGFPDCNCITKNYOKTKHPGHPFINEJNFJSIJOFMQF@D9;?45AG<@F;A5<=147+88-:7/85-64)66*77(55(20(0.&21)0/'42*35,47.36-25,24*01'/0&15*26+6:.58.76*98.?<195,83)=4-?@0>B3=E6=G;6C74A54:.26*26*-1%/1%8:.CE37;055,36,64*62)12%24):<3BE34@58B87?05?/8C34A04>.3=,8=14=0*3&+2&-3(.9-5A77C7*4'&- //$,* ENA@J=DRDK[ML_NH[JHYHKYHIUEHSCDNB?K>@NA?MAJ9@K=;I=;OB>WGBVI?N@C;9@7ALAHUIWdW_l\^naTbUP]PKZMEYKC\MBZKAYJ@SE?L?GUHJ]OJZLDUHDWJEXKBTHFWKKVOLYMIXGDQFDRFFREU]Q[h[VeZNbVJ]TGWOFUGGSEKTGJSFENBBM@HPDFPCFPDEND@I=9A79A36=38@88A96B77C59C8;D;;F;:D8;A6CI.6=.<=297-;3,;5.95-98-98.88/9;29=49=49=58=4:>57=6;A;8@78A77C69G:=E;9@69=59@6;C97C86;77=69=4<>3@@6>=4:<389/55/42-74/64/74/85075-65-54*76,;;2?C:?E;9>567.66,5719<58=4E9;C69B5=D9>C8>E:>F;:E;=GD8;@448.59/48.49/59/36=07>16@48B56?3;E8?J;EP?DOBBM?@L9@L:>G9=F98@57?47>34;07<159/6@38A4;B5:A49B5=F9M?@RACRAGTDGRA@L>8B37>26=06=07=38=27;17?3329<18<1617;/:>3;?4:A6=F;=F9GUGEWFF\LHbSLgZOiZUgZ[fYT^QEMAEG9EF:CG9DI;CJC6EG;AC:FJ@FK@ai`u€w`b[@B:;:0=<2?>3@B5C@8?A6@C8=B6:=2;=3@?3@A4=?4?C8BF8DF9HK>A7BC8;@5;A4:A6>A68=28A6>E:?A6AD9>A6;>5;@56?47D4B6:<08:.98-96.:6.98,87,36(33)31)20(13*9=29:159.5:/6<139.49.46*26)59.38.57-12(52)65*76*33(30)40+78(F7=G:9D74>237+15)46*23'//#65)97-;90:8.76-?=4?>6DD>>@5AD5EG8BC6<>42:9.32'31'32'35,=?5?>353)8:/76+0-!2.#00&,0$.0&/1',/$/1'13)24)36,11(23(0/$-,!30%24(03(.1'13)01&/2&/. -0"-2"+/#+-!,, ,*--!-,".-!,+,+ .-"//!*,*.,. +,"+* +)-*.-!-. .2"14$28*4J??K?>MAAOB@L>=G:L?=RDO@8D4G=@K>>H;>H;F>34;46=66>39C59A6.8>08:/63*85-96.98-=;186,75+86.;;29;27:16<28?59;5:=69=49B68C66C4:C98=57;25;3;C97B81<65>59A656=D:AI>?H;;D7:D79A4@I;9B37:/58.28-4908=4?C:>D9;C9@I==G;5@45@4=>4:>4:?4;A68?27>16?27@38A4;E8CL=EO@AN@?K<@L:CN==H97B48>3;@58<19:079/77-5>1:A3;A4;B5J28>17?3IWFI[JK_OMfVQj\Ok\UhZLYKDNABI;EF8FD6AC4?E6?F7BI:BG:@D:AD;ILBW\V—‘„‡orj?B8:9.=<2??5>?5?@7?A6>D78?1=?5>=5CA7AB7>B6DH:CF9EF6BF7HL=KPAHPBJSDNZIT^NR`RVi]dvnl|v{†„}ˆ†€‰ˆ€‰‡…Ћޑ““”˜‘•Ž”‘”“’–’‘”’‘”’—“”—›Ÿ’–›’”˜“’–““™””š’—’•š“–š”˜œ”—𔕛—•ž”“œ——ž“—›•‘›•’›”™‘Ž—”‘š—”ž‘‘—’’˜•–𔕙•–𔕙˜™šš ™˜¡•”““˜Ž•†‹‹}„‚jspisqrxy~‚‰ˆ]lg^ne^oedslcok]d]nurv{{vz|otsosqgnj`gb_f`Ze]Zd[Yg]WeYVcWVaSU_SUcWSaZT`ZR_VR`UR_PU^RRYOQ[TX_TW\RPVJck`ktiIKDOTJJREITHHUIKWNOWMJRHCJAAI?DLA@G>BE?5BC84:>48A59C5:D7:D79A42BD88=1515;.<>28=15;/16+36+23*62*76-26*37-03+33.::.;=1;B5>G;A5=F<:C6:D3?H7=E7>C8?E9?H;BK>;A478-41&2,$1.&;<3?@797-2-"11'32(/,"2.#56&05&/4(-4'.2'.1&32(34+02+--'10(0-%/,!0-"./#10'/-$/0'./%+-"--+/+0 +0",/#,, -) /* ,+!(%.,",* 21'22&-0 14$14$/2&-.%+* +*,, +-,1 36&4;+5>02;01:./8+/=*5A02=+2;*18)06'/2'*-"%,)-!*-!+, +*'('*(,)/ .2$12)44(,..-+*!+($/,$/1&&.#)2&)1$-2&)1%).#()%&&),.(, )*+*))(,(/ -4*)/#(. +0 -3$+2%43%35).6+5@36A4/:+49'19'0:*3?15?/5;+,7(0/.9+).!+,+-#&,!(, -, /+!--!/.'25*6=.6>/17,'*#LYII[JGdUAiXEdSG]NDSCDO=FR@ETAFP@?L=H<;C8>C7:;-59.=E8DL>GL@AL?=PBEWGDRC?H;=A5=E7DM@L]QVh\XmaNaUGTIHNGBRHIZOK\OEVI?PDDTGHUGDNAFOCJTHEVH?REGQGGODKQEMSFHOES[QP]OJVIGPF@J@@L@:I<19?169-77,95074/<51=72;40:2,71*<6/:7/98/9:4793881<@7:A79A78@57?5;@59>46<18>58A67@66=67A6:C9;D::A6;>3;7094,;916<23=45;49=3:?87=66?99B:>E=9A:=;8?:3@?7;<29:/4<3;C9CK?BH=AG<>E84;C9=F:=C7=D8;F:8B67>59<37>2;B5BJ==G96=08=04<19B69C7;G;?K>>K?=G:AJ=06?26>18A4=E:=A4:=2:>29=1:>2>C7>J8ITD@K;BK>KUGCLADO?IWHIZMK_ROeWOdUOfXN`TR]RPXNAF:AD8=B62A?4C@6E@7:9/==5?@7AB6FF;FE;DH=DD:F@8EG8IK>JNCLPDJNCOTIU]MVbTbqgx…‚……ˆ‡Ž}„ˆ‚‡ŠŠŒ“–š“”˜’”“’–’‘••”˜“’—“’–“’›–•œ“”š“”˜““˜“”—•“œ—–Ÿ–”Ÿ“•ž“•”— –’š’Ž—•”–•ž–šŸ“—œ“•Ÿ”•ž˜˜¡–•ž–•š—•›••›•–›‘”˜“—›’”›•”—–•”œ‘š˜‘–‘€‚…syxt~xt}ws|z‡‰|„‡cojangalhfqn[gcblaipiqtroqqsuuqwtnsrjolr{ufne]i`]g_XaVYeYTaUUdX\icZgb[c]YaZX`WS\QV`UV`SS`UQ\PPWK^^[ppm^bXJMBORILPGLQHNUKPWJIREKUIGQEELAFIAEF>7?3;@5=A6=@6;?49@5:>18=08>28A4@H;;E74:?57>29B28B6=A6;91;9079.29-48,59,45(31)44+79-<>45=>5>A6:>0:8.75+54&66(33%01%1/$32'33'45)7<-8>09@8:A6=C6=?030(3-*3-(0/&9<1@B6A>54,$1,"3.#.,!20%53)44(/0$1.#0-#3.&40)0.%/+&0-%0*#1+"0) 1) 2+"0-#.-#-.$-.$--#*-).,0#03(+/#*."2/&11&11&..$-.!,+ /-!,+ /0$57+46(45&-0&0-#..",0 /4#55%5;*59,8<16=/6=/9A05=-1:)4;,6;,5:+36+55'02'04)+0&'.#'-"(**+ '+ (-"*2$.8%9?,3:'16'14)31(.+#1+$10&07(-7',6'-5(-2#-1"+0"+-*-+.+-!+,!') *+")-#).$+-&(,"*."+/$+/$+0&-6*4>/5B/2B0.<..4**5&5=.5;,/:**4$+0"03%28+14(2-$.*!+) +++, *, (*+, ,+.2$2=,8F3;H6HPB66,T`PJ[KLfXCjZBeW>ZL9OA>O@@Q?CTADRANC@QE=NB;J?:H<9F;7A66A58@7:C99C79@5;B4@C7BE:=F9;B6>C7?I=:K=9K>;I<9B68?39A4F<=G=9E;:E9:B7;B7>H;CMABMA?K??H>=E;>D9E::E9;E:9A64:/47,68-5:14:03;/4<128036068169/5:/7;/47,99.:51950;62=83:5083.;6-=:1;80:70840962882:>533:/:?78=47=47?48@59B67?57@6;C:9B76=27=2::1:80<:29@67@7:?7>E9?G<>G>?G>BI@AH=@E>@=7>81<:29:1<;1;>5@C;BG=CI>@H=>G:@J==F;:D9::58:46<57>69@67?5;@3:B59B77A58>48;1;B5?G:ENA;D76>18>16A39E8I=>I<>G:;D78B5:C6;C5<@4:A6;A68>49>238?47?49C5=F9=G:?M>ESDKXIJVJCNC@J@@NC=K>;G8?K:BK==G::A2:@3=D78?17>1;A6;A49?2;@4>D7@E8BH;HRBOZJHSDIVIJXJ@PADTEH[NG]PIaUKfXNhZNeWQcWP\QBJ@@G:AF9AH8?F7>H7FL?CI=CE:?D9@F;JMFTWPW[UQVQMMFBC;@B8BD8?A4<<2@A4??4@?4@@4@A6>B7EF:HG;EE;EH=GH>D?7EJ5;?4>>4?>5?>5;=39<2;A45:=4:<3<@4?D7@K>DLA=G:9>257,86+78.26*4:-8@1:C6=E89A67?3;=29<1<>59=3:@5:@0;=2=>1;<-<=-44%22#31%43(44(03'36+6;.5;08>4?E7DI;C:>D8GK;@B374+3/+2/*0/&59/<@432(/)"0-!2/#20$20$44'//"21(1.%50'3.%2/%..$1/%0.%/*!.* 0+ 1+ 0+"0,#+* ,-#..$-,"13%.0!12%/0$/0$..#2-#1.$12&03'./"-/")."*0$.6)6>24;,,1#02(0/%10%29*08)16&28'27*27+07*29+2:)29*18)/6(15(26+27+57)15)28,.4*+1%$*())+"),")-",1$5;*:=.49+.2%37*--$*()'*,!*1",6&.4&-0%..$..#-.#*,!+.#,/$.-!++ (+"'-$,4+*3(',%(/%,4',5(.6*09.1;-5>.5B..@.-;,-4+3<.9B3>F86>003$21"-* ,."+-!.,",())((()()((*'.+!-3'2<.3D27G6>H99?3U_OL[JF]OHhZEi^Eg\>]O>WH>VDBWEASB>QAQD@TG@PB@OC>M@CMC@J@;C<:B8=F<9C79D77@49B5;C8>E;;C9:@6;C96F;8H?7E=7A77@68B5;E7=E:U_Tzˆ|Zk`HZNL^TO^VL\RHXMJZMGWGAQ?BODCMBDLAFK@?H<=G;;F>>H>GPEQ[OXeW[h[S_SJSIGOEHOEHODDN@@C<DLA@J?;E9:C8;D8;A7:3:6.86.96/85-86/89.;;19:196182.:30860;=49=4;A79?47=2;?98?86>48B6;C67A45=36>59C78A64<15<16=09<1<>59@78B8CKAAJ@AG=DI=BG>@?6:3-98088.:8.:<3@A9@F;BH=AI>=F937;57<6:B;;B;6?5:@5;B6:C66A49C78A57=2=A4>G:@I<:D78A4=C68H9;H:=J<>H;@I16?19?3:?/;B6:A48>149A5;D7:C7>G8ANI>>IA>MA=K>9G7AM=CN?>G:;E4?G9BI<9@39?39?49@39A4?F9@G:>G:AII>?I=CK=EL<=E5?F9DK>BG;@B9>E9BI?FNCIPFJPEEJ?EFB6=A6>B5AE5AB6AC6>A6AF:FIEK@FLAHODIRFLUJGOD3?D9>B75?A5;B6;=2:9065+55*24)35(44$44'/.&--)4904@4:D8?I=@J>@H=?G<:D66=167-89/89/47-7;/AE9?F98B58B56@3<@58=29?49A58A49B5:@3?E7BE6BE5>?.=<,65'66(33'23'47+69-49.8<0>C5AG7EI:CH9=C9;?3=A1>?/66*12)22*13)26+37*00$/.#00"44&55'55'55'45'10(74-94+50'43(9:.=;020%,*.*0,!0,!/*!+**)*+!,,".-#,++),*,+,* -,"5.#40&32%/2$25&.1 )/$*1&/8+3;./4(02&0.%0-$00&7?37C40:,1;*.7(.5)/6)16)5:)8?26=008*-1&04)15*29+18+,4(05*14)(*%( &)!)-%,1&28*16'55,25*-1')/#/2'34)).#*0$*3$(2",1%.0%.+$/,$,-$-.%+-$,1&1/#+,!)-$)3(2A4.@1/7-.6*-9+-;-2@1K<;D7KVFGTEDUHG_QHh^LndKn`FgXB^NAVH?VC>SC=SE?WIF_QB^NCZJBZJQDF;>F::F;;F;DMCMWKUbVXj\P`UFVKFSKIUJJTH>H;@D<=D:9B89D::F<7F;9@6:B8:C99C78?4:?49;07<2>F<@I??I=:D75A58@4=C7IODMWKGVIARE=H35>37;24:06>27@59@748334.66167/78/9=2:>2<;2:80:809:178/:;18<1:?45:0671951>5285076-9<3G:AJ>BKAAI?BI?FJ?AG<>>4;9/:<168.:8/:;2=?6AE:BH=DLA>G;E9:B78A8CKAAI?9B8;C89B54=05<19B7?I>>G=;C9;C9:C6;E88B5:D79C67@2@D8H;CL@BK>:@57=2:>28<18<.:?/8@38?1;B5?F9AH<@G:@H=H9CLH8@J;?H<9B5E8?G:?H;4FH=QD?VH=PC>OBFUDBM>=D8479/9:0:;0;=1:?0:=2;:088.54)02#21%22"34&00'/2-6;25@48C7CMA=E:9B7=C96?26;/6:/77-99.67,>=1FE9HJ>CG;?E8AF:J<@IA2>@3>@52?G:8=/2:.0:-0:*)2#,2%.0%0-(.,%-.%+/&+1&+1&02&.1&+1'-8,2A49K<8D6,:,);,,?25H9PC@TE?SE?RC@VGAVH?RE:L?8G<PD8L@6L??SF@PD;K>:I=5E98F87J<7J;8F::J=9M?9K>8G<4D87E:@MB;G=>H<=G;I;;D7;F7;D9@H>AJ@FRGN`RK[REVMFTLHVLFOD?G:9>6;@7M<>I;F;:@5:<37;05=08?49<257.46.67/66/89/8=08?06=16;09=1;;1;;1:;07;48@88@66;3881;7084/86.9;2=@79>336<28919<2:=4<@5=B7AE:?E8>E8=E8DPC@NA@L@?J?@I==H:;E8I>@J??H>>F</:?/9@1;B3=E5AJ=?H<>H;?I<=G9K;;H;E88G6;I:>J<=F9=E9:A6;B5=E8=F9>H;:F8=J<=M?AQCN_QK]MNaPQdSPdRK`OJ`QRhZMbTJ\MD^PIcUHaTEZOEWIAQCDO?@J<@G;DJ@FLA?F5BB7DF9@E7BF;CJ>EJAIMAKLAHI=FG0B?3BC8@C7AB7CC9JK>KN@JN>KOCKQEQVGMUIMVKNUOhrow€~‚…ˆŠ‘”Ž‘•”•™˜™ž•šœ“—š”™›–›ž˜Ÿ’—™’‘˜“”™——ž’‘™“’š“’š’–œ™›¢–™ —˜Ÿ•–”–œ•”–•ž•”•”””𔓙“˜’•š“–’•“—Ÿ”— ˜˜¤™›¤›ž¥–šŸ“–•–ž–˜¡•—ž“–š“–š’•š”—œ–—œ˜› •™ž€„‰‚„‰†‡|€‚v|{rwwu|u~Zga_gb`kditou~{|ƒ…ˆŒŠ‘„ˆ‰|€mspiro{„jsqfpkbnfZg\Xd[T`XVbWXcX\g\WbWNYOVbWY`YX`TV]RXaWR`UGYKHTIEMBBI@K@ALBCLBFLAEJ?@F:=D88A7;F<:J>=OA=OA@Q@DPEDUH@WI?YKH^PI[NGWGBMACG<;=426*3:-5;/58-9:0:<1;=1?C4?A3<>177-54*56)54'1/$20#/.!//(5925=28A59B6>D98?48=28>38<157,47*67):;+?@0?C2EF8DG:FH=FH?EH?AH>=E;=H:ANAFVHETG@H>=D89@3:>1;B5?@3=15?18D2>E79@15<.81:E7?I9./8)07+27-04*47-5:.6>03;,09*.6).6*29.1;/2?0=J:H::E78F9HOCBA6HXMWl_SXNA>3/-"00(29/'0'19-13)*-",)!,,"/4)28,.4(/6)1@2?P@:M;>O>FSDOXLHUEKTEIODFOCFSGE]ODdUEeVD^RGWLDXG=N??J>>H<;E:RD:L?;J@=M@=L>>L>>OA:LAMA@PEBVH>WI;UD7SD7OA6G97L=:QAP]TCPG>L@@L@AI>DNCJXMJ]SM`RNdULeWG`RBUI?OEBNA=K<@M?=L>=J<9E89D2;D6?F5:?69>58A66=49:19<38?65@47A56@4=A5:@6CJCJUKL[MJ[ILVIEL?FGLWIP`RUaUN\OJ[NCRF?F;/9>/7:/98/47-67.65,56,4:*4=,1;/19-4;09=2::1:8/6:59@9:E>8@67;297/:6097/9:19<3;=2=>4=E:>H=D9AH>BK?>H:;E88B5:E4;E9G<>E9=D5DK:EN>BP@FVECRD?NABL@>H<=H;>H:>H9@K:BG;>F9=H;AOABNACM@CK@AI@@H?9E;9C98E::?68;1;<0?@3<@1:?/:A1=D5>G7?H;H;=G9=G8CM>BI:=E7>H9>K;:I8=N=DVFHZKFWK;J=@Q@BO?>K<:E8F9?IL>BPBFWJ@QCK[NK\JK[KK\KE_IE_LFaQIcSBZJBYG@\MEaSFbUG`TCZKEXJMXL?I=BJ>IOCAI<A5@F9BH=FLBLNEMMBGE=HI=CE9>B3A>1@<1@A4>B6@B6BB6FF9KKOPFMQDHNBIPFU]W_gcenlrvy†Š‘””˜‰Ž”–’”›“•–˜ ˜›¢—™¡’”œ””œ”“š••›‘’—‘’—’”—•š¡—¤—𢖙¡•—Ÿ”–ž••”“œ““œ•”‘’—•–›”—œ—šž—˜ –™¡˜š£˜›¥ž©šš¤˜š£—šŸ™™¢Ÿ¥“•Ÿ“—œ’–š’•™”˜œ–˜™™•—œŽ’—ƒ‡Œ‡‹‚†Šy~{qwsmspowwfpl^l``khbojkyrp}zu}ƒˆˆŠŽ„‡tzyiqlu{|„‚s}{jur`mf\f]WcXZe\WeXXdY]i]UaUJVJTaSZ`YXaVW_TT]SOZOFVGFVLERHDPCBOA=NC@SHCNECKBDK@KODHMA=F8G=A8:<149-2;+49+57*::/;=1;?0A2;>089/76+66)33%0+#0."0/$22*27.5?38?4:?5?59>36=389.89/67)66':9(CB.F>CMBFREBPA?PB9L>8?64;05/88(64*86,64*64,55,5:/8>39>5591:?.AC3@@/>?136;07>16>,>G:FM@@E99:.32'32'89-77+20&0.$/-&22*53)/-#/-#.+#/,$,*#/-"10&/0&+,"+).-#,+/-#+)*'+( )&,&+(.,!0/%.,"40%0.&-,#*-#-0&36*14(32$31#44'5=.>I9DN?>B18I:=H68D77B34>.4>.24=9/#4<5O^S`aVA8/-'&*$EQGozqNVL13)02(.+#--#,1%0:-4@02>-0D3:L:=N;?L;@I<@GN@:N?:JRE>OB;H<>K=@L>>H:?J=@M?EWJF\N?WI7UH8QE:QD\k^L^NATD@P@AL=BJ>AJ>FMCCVGF[MG`QHcRG\NCSFDLABL@@K?9F:O[OM_QEYNIXLLUJJLC@A79=36;/4=06>36>38;2890890:>49?48?38A49C68B67E8@K?OWJWaPScPVdRP\KHTBDNAOWLW^TQ]SM\PHXL?M>27?25>24;008-47158.68,4:)3;+3=-2;.49-8:.<=1:=18=05?48D9:E;7@66<5:95;<2:80>:2=;3::0:@4=B;AJAEOE@NA;G;>H;BNBCOBCOCAMBLD?NF@QF@PDBL@CJ@BF@BGB@F@;B;;C9;B9>E>?G=;C89A58@58>46;3;=5?@7DC:AJ=EQCBRDDWGH\MN`ROUHGPDBN@@M??K=@J=BLAANA?OABTGCSGCPG@LC>LB=K@;H=@K>DM@?K>@J=DM@DM@DMBCMBAK=AK>=I==I=9H;7E8:@88>4:@4;?3>=4=92=?4>B7BH;?I<=H;?L>>J>>J>?K?DNBAK?BSCGYKI[OAPB=K=GQEAK>P??NA>J>:C8;C9=E:?H;AJ=@J==K=@OAEVHCSEBPAFPCCNAJUGKWJGWFA\ID_OH[MBUI@F;@C6CD6AA6@@5AB6=A5BI=BNAINAGNABI:BF8JJ?FC:AA8??6>=3CB8DC7BA6DA6FD:KH@FG>IJ@JPBKOEKSHMXMNVLSYP`bYrtqˆ‰‰~€vwzuw{‰Œ‹Ž““—”–•—Ÿ“•œ—™¡’œ‘“‘™”’›•”œ–•›–—¢–˜¢——¡——Ÿ”—Ÿ’•‘”œ’•’•ž•˜œ’•›—œŸ˜¢˜¡šž£›ž¢—šŸš¢—œ¤˜¤—𣒕–˜ —›£”“›”“œ˜’‘™“‘›”””“˜””˜’–‰Œ‡Œ~…‡u{znwtlxqkyocthdtjguil}tfwpgwsy„ƒŠ’‘”—‰Žv{z`few||€…‡x~pxweqkXg]Wf[Vg[YbUWaU[g[S_SPYMYaV]bWW\QUWPRWQS`UJ\OFXJ@QDEVIGXKEVKFULDWJEWJHTJHQGALB?J?=G;>H<;K?CUHI[MKXICSGDVHDXKI^PUfZBPD>J>=E:;?4:>35<.2;.2:.7>16<08<09<0>?3;=.8:*:9+<;.74*3/$0+#.-$23'35)46,77/9=2;A4;C6;C6:B4:@38?27:.76+76*65)98,7?*=F4EL?;-97)42'1/$32(32(66*37+1:,5=29>289/68*@?2DE6AB2=?0AG5CE:7?26>1=?1;=.9?0;?0@C5AA888.21'87-7:.78,54)20&0/$0/%00!,-!,-#-+&,*$/,$,/$-0%./%.-#/-#0-#.-$/.#0+".) +)'((&,+ 00#11$11#22%4+%+#)(-,".-#.."5.0-43'8:/DJ?GM>FE6=A2:D7:G6@L;GS?@R<>J7@E6?B78>21=-09-DTCUgUT_ONYICRC=G45;+:B5:H<>PB@N?ALK=>L>>L;25102=,3>/3A3:H::H7;G37I28F1?H7BG77:/67-/?05I;8RA9RB:K=BMABE:>C:7?69B8BC9A=4%23+LNDkbZA3/,!)&&0/.52/3,%73).0$,.#00&10'79-6>/:E48G5;I8=G98B65A81=4IYIHTFHPEJNDIOBEL?EOB@PAFVKIZRHXMCTI>QD?RE?RE>QC;M?;H=?I=CLACSF=SD=RE?PD=G;:C99A7>G;=E:@I=?NB@SFH_QQi\McUI\OKXKIVIBPCB7>B9NYNN]TEYLCRGDNDDI?;A55<13>26@37@54<17:0::18<28>36=25=27A39C69B58D8AK@GPCOZKM_KM^LL\KLZLJXJHTHKVJLRJISGDPD9H;9C4:C39?38>26<06:/49.37.28/7;069-48*5:-4;/3:07<17<1:;1A8;D9>FJ<@LA?N@>PA?QCARFCQGAQEAQEJ>ENCAOABPBGOCDNAEOBCNBBN@BM??K?=H<:E8:D9;>68>32>C7=E8?H;@J=?L>@NB@MA?K?AMADOC?J=?H?>I<>IO=?J=AN@CPBFTFFTFAOA=H:GQDCUDC]LA^NCYK?RF9OBEM@FK?CKIH@EG=IJ?KNBOSIU\S\e\gri]d\Y`Wafbhmihklbdduwwuxy{~…ˆ“—‘”™“•›–˜Ÿ’‘›‘’›’š”–ž•–œ–˜”– ”–ž—— ˜˜Ÿ—š ”˜•˜ ”—Ÿ˜›¢”™ž”˜—š ˜œ¡—› ™¢’–›•˜˜› ˜›¢š£”—’•œ”—ž’•›“•‘™‹•ŒŽ–’”œ’•›’–“—Ž’•Œ’•Œ’•†Ž‘‡‡r{yr|xkxrjxsn|xw‚zn{vapm_mk‰ŠŒ”•’”˜Œ‘’txxhomqwvw}|u{ymvs_id_lebqh`pf\dYWaVVaVT`UQZOV_TZ`UW[QRTMNVOSdXJ_QJVJJTHIUIITJEQFBOCDUJGXLIYLHXKBRD@QC>NB=M@CUGH\OO_RS\PJWKFTHAREHZMI[M?NA@J>=C8@@6:9057+38+3<18A68?49=279/98/5>07=18<17:.56*22&/,%/-$/2'17+06+04*4;/8?228=2:?4:?46;09>3:=18;.7:.8:-;<-97)65'32&31&10&0/%22%24(29-4;05;/68.66*;:-EB6DC7??0?D4?B68@3:A4>@3?@18<-9=/<>1<=3;<275,::.9<168,33'0.%..$++".-"/0%-/&+-$/0'01',3(+2(-3(-0&+-"--#.-#/.$-) .+!-,")(+( -+"-+ -+/,"/*!.&+$)&(&,(-*0'-)0.$13(;?3@D6?D57?0=G7:D7>H::C63<04>0?M>KZGYdRYaST`QBL;4<,2;.6D8FRBIO@FN@AJ=@H;=E5;B08<-27)07+3;.7>04;,-5%-7)1K9;O9BT@AP>=J:8E72?3/A22F84L=8M?5C53;.+7-/>4@OGIVMEJ@>;2')) -.$2,#4(!-#*((,-*750=9154)/2&-2%.0%02(24*17+5>05D27G5;G84@22@42@5LZLKXKFQEFODIOBIL@LOCNUIIWLCYLD[NCZNQE=N@9I==G;BG=FOBHUHDWF?PD:E:9B77@68B8:B5;B5;@3;@4H<:F<=MBCWKLbVTh\L_SM]PIZLBSEE9EQBHYHFWIHYKL]OJ[MFWJ>PCENBFRFAMA7D66@3:@39=259.47,59.6806:129.4;038,56-68/7924;17;09=2:=2HI?BNAISFGUGDSEGUIDRFFTHGVKJVJGQFCLBFPFBOB?K?>G=?CAB9CD:@HB9>C9@G:?F8?K;CRCHXIDRFGSHKWLJWJQ`RRaSJYK>M?>M?AQE@PC?OD?PCBSFCSGATEBUF?QC=LB=J@@IA?NBCPDBOAEOBBN@CPBBPB@N?>I=:E99A68?5;>3:@49A69A69@59>39?2=C6=F9=F9@J=@K>?MACOD@L@DPDAMABL@?I=>H<=G:?I;?G:D7=E8>F9?K=;K==N?>N=;L:?L>@L?=I;=K:?N@>M?CQCKXJKXJGQECN@?H;>F9=D7@INB@VIEbRHhWJiXHdU@[MAWJBTEGQBHQA?G8?A5AC8BB;DD>EF?@?89?3>A5@C7?C7GK?AF:EI=DJ=GNAFL@DI=FH<@G8IPDFJ>BF;EI=CE;DG;GK?JKBJKBKLAMOBRUMdjaowohsk\f`bkegnifljputdhhjkkfigtyx†Š‹’–—‘•–•˜›‘”˜•”•“”–ž–™Ÿ—› —šŸ˜›£”˜ž˜™Ÿšš ™¡–›ž“–ž“–™œ¡—šŸ—œ¡•™ž“—œ•™ž™ž¢”˜“—œ”˜››¡—™ž•˜ž–šŸ•™ž–š’•’šˆ‹”Œ—“–ž”—Ÿ’–›”˜‘—›•š™™Œ‘w~…Œw~}w‚|‡ˆŒ’‘p{xfqqdqpŠŠ‹““”–š‰vzzipmholmsrpwsgpjV`Z^ic`mganf\c\XaY]f\XaWS\RU]TV[PU[PNVKMYMQdXD]OPZMKTHFPFFQGDQGCRGJ[PGXLGZMFZKCXGAXH:RDEZKI[LI]PR`UQVMMVK@K>?K?DRFAPD;J??K?@G<>@687-57+7;.7B6?I=>F;:=2;<2;:/2:2;C98>578.66+43'11)03(4:/7?34>15;15?19A4;?3?A5@C7<>27;08:046*66*66'88*77):7,;6-<8.:8,99+8;/79-8<069-68,37*68,59-55*77)89+;:,98*77)65)33'0/%.-#0.$/0&/2(26+58.45+2/'74*;6,>:1@?3??2:<0;A4>C7BC6@@2:>/5:+:;0>?59:055*66+4:,58-55)21&-,#)* //%02).1(/5*:>28;/17,15*03'/0&-.$,-#-,".,",* ,* +))(,)".+".* 1*!1)!/%+#+$'#(#+%-$.&.)-,"56,9;/>@26<-8A2@L>FSFFTBEQ>FN=>H97G:9G<;F;7=24;.3?04@/4;,5<.8C65B2AH;?C7:?19>/9A058I<3F85H7:N==P@9K;7B2.6'+=7>OHSc]lwp`b[C>5,&((**+'0)0%'%#573AC=BA889-26*-6&/5*16-16-.2)06+4B19I77G58H79H:9H:R^SO[OKUIMTIFNCHMAIL=IPCIYKF\PCbUC`S>ZL:QC47@6=E=5D7BRDCUG;L@=MCBTG>LA@PEEUJHXNGXKFVIDTGAPB@K>3:=5:>5;A;;E=8F;:F:8B67A5GWGDUHHYLM]PL\OHYLDUGDVICUG@OAA5>>29=17;/59.6:/6:07:14<02:.58/78/68037/6<26;0:>39=2:@5;D9=G:?H<>I>BMC=KA>MD?QDANDALAFPEFUI?QB:F:;G;>G=?H>AK?GRBFUGBQCCRCARECTGBSFGTHFPEEMCFOEERE@P@=L@G=AJ>@J;@K:@N>@M>@L@@K?DMCCMDHWJN]OL[METFBQCESEDUH?PC?PC=NAARECTFBUDEXHHZL?OB;E<J>?K>>J>@I=?I==G;;E99B79A6I<=L>;N>@N?H;>E8>G:?IENADNAEM@BK>CMGKAJMDJOCQUIT[Q[cX_g`coganhnywt|z€…„|‚rwvnsrmqnv||…„‡ŽŽ“”Œ‘’”–•–›”–›—šŸ•™ž™¢—¢–™¡”—ž˜˜žš› •šž‘–™‘’˜•–›”˜œ•˜”—ž’•ž”—œ—› –šŸ—› —› •šŸ––œ——–˜–™ž“—œ’–›‘•š“—œ“—œ”˜”˜”˜–›’˜•› ‘˜œ“œŸ”¢‘•‡ŒŽ•˜šŒ””Ž”˜‹’—‹{„„s}}w…••“•šˆŒŽx}{lsoholnurjqldkf^e`[e_]f`Zd]V^W\c][d[U^TW`VT_RT\QRZOKTIP[ONbUE^PM]NK[NFWLBUMDXLK_RK\QFXLH\OG^PI`QLbTTl`q„wFXJRdUP]QNTLHQE>F:AJ>FPEEQF;H=;E94:/37,7=0=E8=H=GPD=E:;B7<>4;=38;49;49;265+86,73)56,8=2:A7;D8:C6:C5:D7;B5>@4DD8EF:>@4;<29:068,25(78*76)68+:9.=;197-66)69):8-77,47,26*44(54)35)44(66*88,99+;:,9:,99+;;/99-43)10&20&10&22(01'23)/0&/-%1-%4,'51'76,<;1@B4>E6>C7?>287,37+69.89.89/55+43)78)6:+5:*55(11%/0#-/$/,&./&.1&27-B7;;1:8.4/&1,"/+"/.$/-#.,".-#-,".,"+)-&+&.(-'+#+!)!+$)$+%)#-%+&,)/0#58+8:-:=.8:,7:/>D7BJ=DM=?H7AH7=J;:L?6G<7A65;05=25B36B28?07?13>3;I9EO?FSCAP>GVFO[JKVEAL=CI>=D88?35<-6>-4=-2;.-6+/7*/6)-2'.4(5:09>39@41;+3?/5A17B28F6@QC?TECVEDWFEUE?L;6A16=/9G>amgqytX\WGC<=6-.)"*(-, //#/+ /$)%!<=8FIBBC:54+/4(/8(1:+/8,-5+-2'/7+1@04C36F59I8=L;7F5S^TU^TPYNMUILQFHK@GK>H;=K?J\ONcPL[OBPC>I?J<;H:;C99B87A7:D:>I?ALBERDFUFIZKFUF@N?J<8D;7?76;247.9=3;@538?4:C66A59A7:=4?D8FPDFQGIUJHUIFTGDTFDUEBTG@PB;G:29?26;.7>L?AO@FSFHTHCSHDUJ>MA@KABKAJTIJXL>QC8G8;E:@I?>G6C98A6?G=>F;CL?GQEDNBAK?DOBFPCDO@CI=?G;?G=>HH<@I=DNCGQGGXJJYKFSEFQDFTFFTF?PC@MB@KAAKACPBETEHZINaRObSBPD9D9;B8@L@@I>CN@@J<@L<>I<9B59B68?4:@5:>37@29B67A68D8>I<E8L>?PA>PA=PACP?@M>?M@?MAQBDUGGVHIXJIXJCPB>L>AJ=>H;?H;@J=?J==K=BTEF[LFaSCiZDdWJ`VD^O?\LCbTDdWEbUFaSOfWPbU=K@CL@EL@DKFG@IMEDI@DG;CF:BIDHGKBNUIPXKR\POZNNZN`jbalfu€{‡ŽŠŽ‘…Š‹}„†x~u}znttv{z‰|‚†‡Œ‘“•™œ“—›“—•™ž•™ž–˜ “–Ÿ‘”œ•”ž’’™“š’•š”“š—–œ”•š–™ ‘”’š‘”™–™ž–šŸ•™ž—› ˜œ¡–˜œ•—œ™œ¡•™“•š”–š“–›—šŸ—šŸ˜› –™ž“–›•š”šŸ’™ž’˜“™ž”™ž‘•›“˜œ“—™•–‘•—‹’†s{zw~…„„ˆ‰…‰Š‰Œ…†pusgnhjpkjqkkqpnuq_gbahb_g_W_WT_WX`W\dZYaVXbVVbVYbWT]QOXKMZLM_QK_RIaPJaSE[RCZPF_SLfVJ]PK^QKaUK`VSh]g{ruˆ{ŠM\NQbTIXKISHLUILSFINCHODCKA8A89B66;025*79/5;>4:<2:;188.88.77,67-:?49A6?I=?I:>H7>E8?D7@@4EE9GI=?C7>@2<@2;?29=17:/88.48(98-=9096-55)25'76*:<.5:-4:,68*87*56,23*22(54)66+86,9;-;=.;<0<<087-43)51+53*52*10&..$./%/-%/-%2-%.,"21'79.8:-6<,9>0;:/43'.0#25*44+89/78.87+99+7;,66(66&74)53(10$0,%..%/1&/3'47,67.87-B>4?7.3,#0+"-,"-* +*/.$.-#+* *'0).'*',((%'#,#*#'%*)*'+(-+ 12%4:*2=A5=B7=B6>F8;D49H4=M=CO@EPCAOCFWIQ^MP]JIZFIYFISCISDPWHCG<8:/33)26)5<+4=,/8*+2(03(.0%+0%.0'02+-.$,1&*2%*4(-6)/;-7F8EXGF]JHZIIXGEQA.3=-7?42:014,*)$,'"2+#-)#,&-+!79.43*0& .(#983:=465,0/%.0%39*7?13=14@23=.6@16@23>23A23B25A17B2UaYS[RRZONTHNMCMM@JJF9?G:9C88C94E89H;9H<9H;K^OQfURaUMZLISFFQBCN?ELABM>CP?BR@@P?=K::F69A75=16<16=0639?5:?66A45@47@58;29<2:B6BIBELC@J?@J>AM>AM>AK=;E7;D7;E86C75A58B26@/4>-6@05?/6>19>08<08:0:>38@28A2;@78=4;>5=B9AI?CMCCTEBRDFRFFRFGTJEUJBOD@I?BJ@IRGJWJ8J<6E4;G;?F>AJ?GPCO[JL]LEVF@QCFZKI]PI\OGXKGSHJTIJUIFVG?S@7G<8D:;FL?APAGQDAK??I=DNBDMA@K=J=>M>@J?=E;?D;>G;@J>FSGHXJGTFDNADNAHTFFTF>NB=I>?H>?G>@K>FSDJ[MM_PFTFAMA>F;>B8F;>G:>H8=H8;D7:D7:A57=29?49@47A39C78C79F9=H<27<3:A5:C4>G8?IPBBQDETFIYJJYKCRD:KDK?GN>DJ?BF;CD;DE2:@7?D;=D;48>18?27>16;17>339069.59.5:18@5=G7>I7AG:CE9CB7KJ>HK??F9CD5>B229<266.66'85(:3*91(2/%66*:9*:=/7>06=.8;,;:-57067-45,01(./$31(8;-7:,79,99-77,42(50+63,52*30(21&//%0/'.,#+* ,+"..$/3&33$-3$/4&11%21%..$+.#01'23*78-98+88*66(21#85'96(73(32&71+63)24(46*56-55->@5HH>?911,$0/%,.$*&)(++!** *),'/(/),)+*(''&-$+$)',* *)/.#:<-;?/=E2AL8;D5=D8:C69B6:B7;D8>H9=J9=SH:9G;>PCI\LO_OO^QI[NK]NSbPTaNN_KHWDGQABG824'-,#31'2/%43%27&3:*/6).3(+.#--"'* *+",*$..%./&.6)3@4/;0-<.3B48M;9R@CSBFRB@K:9@12=-1=-4;,05(/2)78310+0-',)$,% ,) '* ))"1%!.$ +*"(+!/,#,+!--"-3#08(;D7BO?:H65B.5=209-1=0/;-1;,7>/U`WQYNPSFNM?LMANLBNN@FL;EL>HE?FG>HPFL^RC^P?[M?YKBWFDVEGSEFOBDJ?FMCCMABK?CK@=F:BL?=E97C7:F:=G<I?>J@?MCHVKK]OM_NJ[LKUHGQEGND@H?9A6;B7?E:GNCKVHNXKISFHSGCPCCMAAJ>>F97A58?45;06:/7>15>19>2;@5;A6:?6<@7;@68>86?58B56A269=68@56@46@47A58@57@46=29?4:<8=C:>F:BJ;BH;AC:?A6:?4=B7:B78C59C69B58@59?39?49?1;@1=@7:=58>3D9BK?AOCGUIGTHHTHIVJFUJHWO@MD:GCLAGQEJUHDQCDOCFMBEL@AK>?I<=G8?H7>G:?H;?K>@M?@HHOEIUGCK@?G>K=:F;>H?;F<K?CMBJUFO\IN]IHUF=I>?K??J>@J;AO?@OA?QEGZIAXIGcSQn_Pk[I_QF`OGhWIl]Oi[P^SHRJGOBENADL?DJ>DL?DK>DLAHNDAG;FNBDM@GSEGVHGYIJYMGUIOZNDL?EH9EF;@B9DG>HLCLSGOYIR[NNYKSaT]laerks|yy‹”’”™’•–’˜—ˆ‘„‰Œ‘”„Š‹’“‘–™–šž•˜˜œ¡”—Ÿ”—Ÿ—š¢—š¢”™Ÿ“–œ’–›”˜–™ž–™ž”—ž•˜ ™œ¤—¤–¤–¤”•Ÿ–˜¡™¢šž£™Ÿ§œ¢ªœž¦šŸ¥š¢•˜–™–˜œ–™ž•˜–™ž™œ¡˜¢˜˜š¢–™ž“—š‡‰Ž‰Ž”“–˜œ“”—Ž”Œ‘”‡‚‰Œ‰ˆv~z€ˆkqnmtow|zu{xjomswvzjpnjnkcicbiceoh`lbZh\^i_\e[[cX^f\_i^ZhZU`VS^SW_SVWNRUMQ\VPcYNfYHcTKeVOeWPaTM_RQdWK_RSdWjvjhodZg^Vf[I]QH]RK]PCQEFKBCI??F;?C7:>268,5;06;/8:.<=0=?3;?369-=B79A68@68?38=079-;?3;=3:@58A75?56=138-2:/9A5=H7=I6HH:AC8CJ>EJ?FF;FC8CF9EF:<=3<=47:307/53(41'6/)50)31'56+5;/6?37>4<=3;:079-88+9:-@D879.33)32(45,77-86+:8-88*44'01%53(51&62'51&40%1-$,(.),*..$.0(1/$42(1/%20&20&20%31'20%57+57+58*66(87(77'77'87)64*51)44*55+34*57-48-6:.=A6EC<62-.+%3/).,$-) +*)(,+!+* )')#)%.*-)+*,,-' )')',+!+, /1%;8/ED6FK:>F3=G7=G:9C89A7:B7?I=9G;BPDFWIL]PUfYTfYP_OIZHGXICUFCOCDNB4A1+9(-5'//#/2&+4&16+08+09-)3(+/%** ++,-"-/!.,!*/$-8-7H;=O?5I61D21C17H7=K=6A42=,2>-2>.0:*09,2<03:016,13,/-$,(#2107B;==74)!/*..#11*.*$/*!,-),"*0#*2"5;)<>+::+66-/3(.7,3:/69,76*XbXNVKMRFOPCMNEPMEPNDJO?FIFTHG^PD^P?ZJCWECSEFSEDNA?I=>H==J=;E9?G;;D8=N=AN?CL?@I<35>36?27@39A57@3:C6>G::J<=MA>NCDUJEWJGZLEYHEUGDPBFMBAI>@H>;F:9C7H<:A68?59C76@36?47@48@55=28?49?3;>8;A8?H;?H:@G;;@7;>3:?4:@59@48B58A49B58@5:@5;A6;B4;@35;@5:?4<=2<=28=6=@7>@7?C9BJ?BOCDQGITJLWKN[NQ]RQaTEQIBLAISGMWKEPF;H==L@@MCBOEDSFFVIHWJEWK@QDDTII[PH\RCZOHZOJ\OK^NGXGFSDENBCLDGPEHREDNABL?@J>DJ?BH>?I;=F9=E8=D6?E;>F;@I=@K??H=?H;F<;H;;G9>G:>F;AJ?AJ?BK??H;?H9=G8E6@K:BR@ATA?R@@PB@OB=K??I<=G<>G=;D:;D9M@AO?FUEBSEASFCWHBYJJdTUo`KbUGZMMbSNjZPo`\qcCNDBI?BJ?HQDFOBFOBENAFOBFNEKREEL??F9AK>DP@DM@DMAEPAFQAIQBLQBDNACL?FNAKRFJUGJUGIVFIWJFSHEPE@J=9A4CE:?B8CF=GMCJQFNWGOYLO\NXfZ|‰€„‹€…†ˆŽ’—””š•—˜–›š’˜š’•›•˜•–•–“˜›’–›“—œ–šŸ—š¢—š¢™œ¤™œ¤–œ¡–œ¡˜ž¢—œ¡›Ÿ¤šž£˜¡–›Ÿš £™ž¢–œŸ—œ —˜¡•˜ ™¢—› ˜›¢šœ¦›ž¥•˜Ÿ–™ž•˜”˜•™œ•™ž–™žš¢š¢šž£—¢›ž¢™œ¡•—œ‹“…‰ŒˆŒŽ”•™Œ’‚ˆˆŽ‘”—‹‘•€‹Œ{…†ƒŒ‹r|yemgdmflqojomjollrngmiciefidekfemffqgcodesgclcZbX^f[]eZ_h]WcUW_TV_T]dYWYNQUMT`X_ogLaWOeYRh[PcVO^TR_V[iaXg^Vc[cmd_d\V`UVcXRaVK\PIXLANB?H=3:;/;<0:>4>?5?A6;=1:>28>08>27>27?56=3:>38;/78-78-=>4CH=DE9DD5AF6EH9AB6:<19<37=278*54)95,97-88,6:,6;05?29@6>?6=;068-78.6:.>C78H<8OB>WFDVES`LL^MKWHHQE@OAEREL?DTFCOA>D614=04>11?.0A1/C14@25B48E97C72;18@676.)%!0/.`he[]W4( .)12'23(/-#0-#.,#,.$+/#-0".3#12#.---"+.#)0%,1&./$0.#[dZT[RQVKMQEMNCRMEQMCOQBKN@FD?L>=G:;E8:D7=I;Q?@QAAMABK=?H;9C6:D87@56>36>38?49?48A48A48A48A4:C6=E89G;H<:B7;B7=F9BL?ESGESGDOCCL@BJ?AH>=E<=F;=G;>H;BK>AI<>K=37?47?45>38?4A838>38>2;B58A4;B5:@5E9=E6;C4=?5:>3;?4;<2;:0<:1==7?@:=A8=C9AI?ALBDNIPXQR\QVaSWdVObSP[QITHKTGOYMFPEBKBAUHFXLFVKGXLDTICSHBSJAPF@PECTICVICWKHYOJ[PM`QGXGFUDHRDDOECNDDNCBL@AI>>F;@H=@H=D7G<>I<>I=DJ?EK@EK@CI>BH=ELABJABJA@H@DGA@F<:A6?F9=E9>G<>H<=H;@J=CKA@I=;G;9E98A7:C8;E8=G:;F9=J>;H<H:@I<=F6AJ:BP?BSACYCEXF@RA;F=>G;OC>QB>PAFWFFXGBSFGZMG\MDZKRiZQiZH\NL^QSdVTl\\wf`oc:A5CGAK>DNACL?FPCFQBKVFNWGJO@CJ=EJ>HL@JREIREEOBITCLWFIUGGRGJTJW`VDG=?D9DI>JQFHQDJTFP\NQ^P_mb|‡‡Œ‹‡ŠŽŽ“—”–ž˜™Ÿ˜šœ–œ›–œž”˜“—›•˜’•”™™¢•™ž˜œ ›ž¥œŸ§ ¨œŸ§š¢§š¡¦˜ž£š ¥œ¡¦¡¦–¡–œ ˜œ¡™¢™œ¡•˜ž•™¢“™Ÿ–šŸ–šŸ–™ž–˜ š™¢–˜Ÿ—šŸ˜œ¡–œŸ–›ž–œ¡šž£›ž£š¢š¢›¢™œŸš¡˜›Ÿ’•™’–“˜–—˜”•Ž’“ˆŒ”•‹’‰“Ž“–†…fni^ic`jcjoogljglhipidkbgoehngdkdckdeoe\j_Zh]ZcY[dZZdX_f[^f[XbUZ^SW_TY`UX[QRWN^kaamfWe^[kbWf\TaYR`WX`YfrjXf^Zg__h`]a[PVLV]TP\PLYMFRFDNC=J>AJ?4MNDII?:>35:.8?07A12;/29.6908;077,34+66->=3AC9>D8;D747A47A37C29>3<@7CJ@DJ?HKA5?C7=@0:=/>@1?B4>A219A5;?5A@6@?56:,7:08>2;C66@37C45A05=14289-77+65*42'20%42'45)/2&/.$0/#0.#10$..#56,??1==0<<.::,99+??0=9065*89-89.:9,65'66&75&62#55&65(=>0>B87;039,6=07>/0:)76.20)0,'3/*41))')(*)78.67--+!-+!--!//#//#01')* -.$+,"++!,+!.,#.) .) /-",)++&15.;E8?J:AH=M?:F95C7=OBEVHCO?9F6/D/0B41F53J83H67H76E53P?=Q@7P=BQD:J<:M>G;@J;;E59C79C7:B78@4:B79A6H@I<;F:@J>AI>CMACMA@J=>J>;I:9F89F78B57?49>37=28>37=2:A6:C8>E:>F:?I398.=91<94BA;EHC@HABMDBNDKPMRZSV_UXgYXi[PcTT_TR_RP]OR`QJTIGOHBVJDWKEYMFWLARGBRGCRJAOGCQFETHGXKGZMFTMGWLI\MIYLFTFGTFDNE?J@@I@?H>@H=?G<@I@@I>@H=>F;=E8>E8=C8D9AH>AI>AK?DJ?GMBHNCIODDK@FLAEMCCJCAHACGA<@79;2??4=?4=B8=D;>G:=F9@F9@G:@I?I?=H>;F<PC:J==L=;K98J9;J9>E6>F:?J>?OB>HOB=K?BP?@QDFVFQaON^LDVEAUHCVGBTECUDFXGFZLH]QG[NH]PQfVNcTM_PRcUUdVWk[bxiXcU@C8EF;HMBHNCAJ=KTGLXHLXGMUHGOAHL@EL?HPCDOBENAFOCHSDLWGMVGHM>CJ=CH>H<A6??598-=<2GH?=@769059.6;-3=.2:.59.68099067-46,890?@6AC8@F94@G;HOAGJ:@G9EKC5BI7IN=AC3;@5:@6;=4A?5?@4A1@C3>B19=-;?.3DD:CG<;K;MdPXhWU_QHVHLaRI`RK^PR]NR^NQ_OGVF=P?=P>VHLmaLaRBVF@QDTcSctcSdS;M?:L=>PBASDCTGESFWZQMHD!BGAY^VB:/,'!13(27(33$.,"**#*,"*+!//#00$00%/.%-1%-0$..$+* .,#-.%ZcVV]OQVITUGRUBTNBZPEZWITTFMJ@BB8A@7DD9FHDQBFSGITFJNBHL@HPCDO>BNB@K?AL?@L@=M?>PCPBI;9C6@I?ALB?KAAK?@I>BJ?EMAGRES_RTcUQbUN`SOcVUi[ThXQdXIZMBOC?J>COAJWIJWKDQE?L>AN@?K=AM>BK?AJ>EMBCKACNA48=28=24:/7=2;B7?L>18;/8=18=28>38>38B3:D4B7<@5<:2>:3A;9IIELRNIVNGULERJOYST^VT`UUcUViZPeVXhZVgXTeUVfXS]RKQJCRIAOFDSI@PE=MBDUIIYPDTICPEFSHHWKHYMERIDSGFUIETFEQEDMBGPFDLD@GB?H?AJ?BM@=KAAMCAL@=F;>GC:AEEK@IODMSHKPFGMBCH?=D;=E>=B:9;299/=90;91;=6?B:>B9>B8AC9AD9@E9?F9CI>?G=BG>?H=>J?:G;9G:;H:>H;?L>>K?9L>=NB;M@9I=H<>MA9K>9F;?G=;L?;J<9F8:E7=H9>J;=I>>J@>MABREBTFDVHEZHBUC>QB=OA:K?;K?;K>;K>DMAFOBGPDHSCLWGNWGGM>>F9FL?JPCIOCDM@HREOVHR]MQ_NVdW‰”‰mwoAG<=A6==3<<3AB7?B88;57:27;/9<-3<+59,58-;;2<=47:062<>4:=2=C7:C7;F;8D8:D7DI>CH=@F:?G;CG=?G:?G8DMB7;@7?@7FB9BB49@0:@39@1=C4BH9?H7:D6<@059-8=06=07;/9:036*45)68,::.7:.37+27+46+54*53)32%88)@D5EI:>B35:*@6;?49<29>47:22.&0*$.("/)"+*+**, 03'38+(*/.#0,!/.$/.$/.$++!,,#,.%1/%-, +*+&-(1*"1.%,*!/1&49.7@4:E7;B669.31(45*9D6?TBIUFAL=DRDVk\Vj]ScVPYKR\LS]MUaPDP@4@03<08@3CK>CL??J8QBAVF>RA7M;B\OOgYK_QBRC'3#)3",:*8L:BTA9E41;,2?47B55@02@09N=HdTKl]Vl]I\NFVHN^M>N@=H;;D748--*")&"4;3Z^SB<.'%14)>C8::0/.#-.#*/%.1%02%02%,0%-1&+0%-/#.-"-* +**, MXHOWFQUEQSCQSCWPFZOI\TKTQKMHGCF;DD:HE:JI=HL?FN>BNCNUIcdWUVJLQCGP@COCBOBBNB@NBAREBVIAZLBYJCVG?Q@>N=>N=L>>L=;H:;H:;H:9G98I=7H<8I;9I;;I=AMCBLBAI??H>@J@?LA>OC?PCBPDESGCQEEWIK]NUaTSaTOaTMbVKcTMdVMcVL^RFTHAM@DQCEQEFPDCMA?K=CPBDQBERCFRCCMABK@BJ@?K>8H::A9:D9;F99C7F;CN@ERDBQCDPDBJ?@G;:E98A55=29?4;A4<>2;?3:?46<17=29C4:D4:C6=E9>F;>B7>=5@=5D>=QQNV`ZQ`ZN]VM\ST`ZVbYQaTN^QI]NQh[\n_Xl[UhWTfXQ]RIQJBNGBMGBMF?MBCSGHZMP`UFVKAMCERGHVKBQFDMCFRFFRFFRFDMCCJDCKAAH@@HA@HA=I>?L??D99?68@7<@7>9=?9<>5@=6??6@A5@D8?D:>C<@EJ;;J=9H<:L?6I<9H==OB?WG@^J;TC8E8@C7?G:F;?G<6I;8G9:H:J;O?EWFBWEBWDBWDEVHASECVGATE=A78;2;=3;?4:>57;669378-:9+6;+59,98.;=4;>57;25>07=06;/:?3;A7K>AJ=CMA;D9=O?BPBDOBPWLV]PQXJDOCAL@@H=CK@@G=?GH7=D4AC5?C9>B9?>5C@6A?34=,6>-9?.?B2HJ=BF9:@4>=/=?0<@47>17;/9;25D9:C68A37>2:?1=A1=:/71(1)"4.&43)F<5B45C67D75A65;-@C3H:?M?I^OQeVQ_SKTGCM?FOB@H:>E82:,44+98/;>29>23?/0?/4>/7K:;UD?VGDYJ=SD=_QLl^Un`EWI.<->H89J9BUC@R@>G69?15<07B48G75J79P=C[IG`OMZLFQCDQD=O>128).3%0.$21(39/@E751!--,0%27/22+,*!-0 ,4(16).3$/3$-2&,4(/4*./&0-$.* -- *."IPDHL@JOBKP@OPEWQG^TG`WLXWKKPDDH?BD:FG=HI?GK?EK?FJ:[SClsnWW[HGQAANBCK?BJ@AQG@WK=UJ?RFBWJE\KE\IBUD;L>:L@9E;=C9=C8;E:=J=ANA?NEBKA@I=?K>>N?BO@BSBCUDCTDBTEGWJPaSTe[SeZLaTL`SMbXK`XK\VIXQGUJFQGEPFEPEEREBREAQEBMAHTHEUHDTCBPCAPB?MAF;=E;DH=ELAEP@DQBAM@>G==F=:B8=D8=D7>G8I<>5@<5DA>NPKV^UUaXR_WP]WSdZSd[K]TMaWKaVQf\Xj[Yn_Ti[Q`UIVLBSKDUKCSI@NC@M@GVHP`QL_VEXL@REDTGIVJGSGCOCCNCFPGGQIAGBBEAEJADI@@G>@GBME@NF=KB@G@=F?AOG@NC:B9>=4C@8@@7;A8>@5@D8CH=EH>FF>DA9?=5?;3<<4;@59?587-53-74/;93><6><7<92?>4@>4B@6BA8AC:@EDNB>K?@J=>H;=J;CN;@O<@M==J<OC@\L@cR@\IAQA>J:K=?N@@SD@XHWIAVID\MF]OEZLGYLKYMQ]OS]POXLDNABOCEUGCP@GUGFWIGYMH_QE^PI]NG_PD^PHcUIcVLcWXi]Zl_LXLBG=CG;?H:AE=AG=BG=FNAFO@FO?KP?GN=GQ?EO>CP>DQ@GQ?JTCLVEOYHOYJT]PP\KLWFGSBJTGMXKP]QNWJO\OVeWapb]i\S[POSJKQFMSGKUINYNKXMQ^QN\OP^SS`V[e[hoerxr}ƒ}†‹‰Ž‘–”–ž—˜¢˜› —šŸ•˜•˜—œ —œ ššŸ™š –›Ÿšœ¥œž§œž¦ ¥œ ¥œŸ¤œ ¥œ ¥™ž£šž¢ ¥Ÿ¡¨¡£« ¢ª›¥ Ÿ¨Ÿ¢ªŸ¤«ž£ª ¢«ŸŸ§Ÿ¢© ¢«ž ©›¥›ž£œ ¦£¤­Ÿ¡©™œ¤”—Ÿ–™¡—š¢—š¡”˜œ‰Ž‘‰ˆ}…„|…€}‡‚‰‡ŠŽŽ“”ƒŠ‡nvrmvlcodYi]\mbhxlgukbpi\jb\ia`jbclcbkcclb]k^\k^Yg`Yg_`nbepgambWf[Vf[Yj_Yj`^f[XcWVdYTdXUdWS`UV`SXbW]g``ic\b]\d[Xa[T_VQ]QVdXYg[WfZOcTF[LEYKBTFFRGDNCHP@JO@EG;=>2;;2;<3A6:=28;.57,68,49-4;/6@55<17:2:917;0:<358/8=49C89G;9H=>J>DN>FSCV`QafYFUGBPCDPAIPEMSHLPFMTFIRCGQCGQD?I=AH>FQDBL?;D7=A5@B7BB7AF8>B489+66)88)68)8:.;>3>B7AE:JKB?=7:91;=29>09>/69,76+8>0:<.AHPCFYLH\PJ^PGPE=D9@F9AF7>B69<04;.48,88-35,29/6B75B75E6?Q@AWE@VE.:H3?M;@P??QCGXJGXJFOCAO?@S@ATE@RD8E5.69*65'23)/2'.3&59.6:,/4%00&-,".+!*()+(++0!.3$15)-1%/2(.2',.#.0$12&-/#+-$,-#FOBGPCLQCMQAOOEWSH\SF_WJVVJJNCDHJF9cUF—…sˆ~j^aOIRCDPDDK?>E:?KAATHASGARF@SFI`QMdTL`QDUH?ODF:?K??PC@QD=M@?OC>NC@I>@HL?FREGTEHTEHUHFSFFTGUcW`rgSi]NfYOg\Qf_MaZG[PEWKDUFL[JIYIEVFMYNN_SEXJDODAMA=NB>M@AQCCRD?NA=I>K:AK;CM?AK?BJ?@H=BF=AI=AK=BN@?J==G;>F<>E9AH:CJEO?BM@@J>?H@K??J>;C9;=5?;4EB@PRNSZTMZSL\VN^XQ`[P_YN^VQaYP`UVdYTdWWk]Ti\M\QESJDVNG\PAUIARGBRFI[OK]RIZQDWMCUIG[MJ]QEWMFSGBODBNCDKECF@CB>BE>>C9?C:?C:>C8?D9@I@AMAANCCKA=FE;==5A?7@@8;@7>?5>B8BF;AD;??8>;5<:3<91<:2:?59?4;;197/87.:90><4><4<;2<=3==3?>4=>6AD;BH?AH=>K?>NB?L?@N@@QCCVDCVE@SC;I<I=BOADYJC]MCZJCSBAJ=ANA?LAF;;H==G:9C6:D77C58D6>K==N=BUDDZHAVCCVDCTA@QB@SBC[IE^LC]OC[ME\NF]NBYKATGFVIGTHJSFKTGHQDFPBAK>>L>BM@GREKWIHWIL[OGYMG\MF_PGaTIgWMeXOeXUfZM^RHTH@G4@H=@K>?OBAL@BJ>IQCLWHXcUZ_UL\MDRDBL?@I=CJ@FLAGMAKSHHQDDOB?H22;585-67,6:-7259+66,31'33*.3(:E7HQCLRELO@HL<F6:@35<06:/56,57-3;/9C67G:9L<=Q@=SA;P?8J==TFG]NK`P/9:+4?.7C47E87H:8J<;O>BQECRB>O=>L?7C6.8)+8&'4#*7'1;+39,48*.4).4(.6)19,4>/4>-04+*,!..$10&./#*, *0!-2%.2&.1$-0$*-",,#,.#,.#+-")* ))#JWKHSFGOBHO@NRGTTISQDTPBMLAEI>BF9AE6DG9IK=IK=CF6PF=fTF|j~t``bQKRECMACI>>B7J@GPFHSHJZNMeWLeWL`SHYLBPE>I=?G9H;8F::F:SE:PC>M??I=AI??K?=K?ENBGPCEMBEMBENBDMCQYPbuh[pdOi_VpgWmhScaI\QI]OL_PM^PN`QK]OSaUWh[TeXHUH>L?;L?J=>H<=G=9E:7D76C3=H8CL?DO?FQAFPCCM@ENAAK?AI?AH>AJ>DL@?K=?J:=E;=E9?F9BI:CL;FQ?ETFFTFFQEHRFFOCFOBAK?@MA?K?>F<;>5<:3C?=NOMRYUN]VM^[L^\L^[N_[Sc]Vf]RaUP\PTbVVi\Yk`N^SK\PGZQE]Q@VK@THEWNH\SFYRFUNETLCSIJ^RLdXA\QFWJBQECMCAI@AC<@=9=?8;<6AB9=>5?A8?@5?D;AJ@?J@CKA>F<;D:>I?>E<>?6A>6AA8=@7>?6=>4@B;@@:==8;;5=:5=72;90;;3:=3;;1:8096.;81<91=;3>;3=>4=>45>E;?G=F:AF:=I;@J=BM@DUFCVGDUF@HJ@CKABMA=N@L?>OB@RCCTEDQACP??OABSEF[IG`NH_QG^PI`RC[L?TG@QEEQEEMBCI>EK@ELADJ??H=@J>CM@FOBHPCOWJJTGHTHI]NH`PJdTIdVLcUNbUPZNAPECOCEL@DI=@J=BH>BH=FM@HOBPTFMSDPXKNWJMUIOYLLUHKUHLVHLVILWGOZJQ^LKYGIPCLSFLSENWJNYKKZLZeY`ka~‰‹”‘z~cihMXNKSIOUIKSFMTHOXMR\NWbUSaS[g[dncdlccqfeqjiro”•™œ¡—™¢›ž£Ÿ¢§›ž£šž£™¢˜¢œ£ž¡¦ ¥ž¢¦ž §›¥œŸ¤Ÿ¤ ¥ž ¦š¡›ž£š¡ ¥›ž£š£šœ¤šœ¤š¡š¢”˜œ—šŸœŸ¤œ ¥›œŸ›œ¡›› ™™Ÿ—– ™˜¡¡ž¦œ›¡šš ˜™Ÿ•–œ“–›”—Š’‰‘†Ž‘‰“Š’”Š’Ž“”†Š‹z}~…{…s€xlyqgtlo{su~wrzseujbrgcpfcqfaod`ncaod`qb[n_[laWg_\na^nbbsfYl_\m`]naXi\Yg[Zh\VdXXdX^g\Z`VW_UR^QR]SVdZ^i__i]\h\ZfYZgYVfTR`TTcWTeXYm`RgZI[NCQEBNCGPDLTIFJ?>C834:/58.98+;;/BF;@I=GUHObPCNBEM@HQDJXMVeXFRGESFDRD@M?AJ?BJ?@H=CKAFNCAL@?L==G:>H9EJ>?C89=27;09=28<159.59.:9/87-88.25*05)4<.9?4?C7::0;7296.53)45+57+36*37+77.=:0=<2:>4376,51,43-0;0>QCMRJFJ@IK?LPEBIC7>F98A59B6:D8>H<@K=;E57B18B4=F:8A6.6,/6+48-04(/5)29*3C735C7;M?=SB@REDWGHVF@H=7<157+2>,5@/4?/215B34@/3;1*1%-/%21'01$//#15)/4(03'-/#00$//#1.'++".0%+,",.$++%RcVL\OIVHEP@HPFLSGORCHJ=CF:BE:?D6?F7CI:FKbRAleS^bQHOD?I;AF:AF;=G;DNBGVILbTIbTEZMEVIAOC>I=?I=?I:H<:H<:F:?I=>H=;H;9I;K>AI=@J>BNBAMBCKAJPCIODIQFIQFIQGKTJ[na^tjSpfSpkVmiSc`I^WJ\RJZPL]PN]RO]USaUVgZPbUKXLAOBM@=K==JAK>@I?:F99F6;H8@K>BL@FPCEOB=K;?G<=F:>G;?I:CM=HR@GYLHWJFOEBKADMBDNB?I=>L@@M@=F<;>5<:3B=MA@I??D:@?6=<7:93<<6=;3@>6BA8?A8>G=>I?CJ@@D;BJ@BKA?E6BA9@A8=>5<=4>=7>>8??9:<6;:4;61=62<;499095.56,57.8:0890;<3>@7F9>I;?G:CK>?N@BUF>OA@J=>I>CLCEMBDOCBSELB=J@>K@>J@BMAEMA>K?ASEEYKF[LI]OH[NDVI?RENACMADLABE:@F;CI>@H=?GCJ@BJ>FK>GNAFNAJUGH\MJ`QKbSNcUQbVM[OFNDEREDOBENAGM@DM@EOBFOBENBJQDJRDOUEOWJJTGJTGKUHMXKQ[NOYMMWJQ[NP]NO]LK[IOWLMUJKRHOYKNZLSbTYf\p{u†Ž†Š‹€…†hmnSaYPZOOYLNTGMUIQYNV`QZeUUaU[g[eofirheqgcngoyu…ЉŒ‘“˜›Ÿž¡¦ £¨ž¡¦ ¥œ ¥›Ÿ¤Ÿ¡ª£¥¬¡£¨ ¢§Ÿ¢§œŸ¤›ž£ž¡¦›ž£œž¤œŸ¤›ž£›ž¢š¡›ž£œž¤›ž¢—š¡—šŸ—šŸ—šŸ™œ¡Ÿ¢§ž¡¥œŸ›œžšš šš ˜— —–Ÿœ™ ˜˜ž––œ——•—•—‘–™Ž“–”—Œ”—Ž•—“–Ž‘’‹Œ€~€~„}…€w†}t‚zs€xt€xswo{rk|qixmfticqf`ocancfthdte[n^Yj`Wh_[l^`qdare^l`]j^\i^Zg[Yg[]k_[i]_k^bk`Y`UV_TT_SQ_SSaTVdW`l`]i][h[\iY[j\WeWRaTXj]Ym`OcVCUHBUGBPDIPEDH=@A7@A7>?6;?3:@58>34:/4;.29,5D8>H>?K??K?=F:@H:CD:=>489/:<1:>369/37,58-9:067-47-26+.6(5<.?F9FH?EG>?H>?K@DJ?=B8:C8;E98B7=E<>B<2:/17,04(.2&.3&.5&0>3-5B/3?/2?03=109.19/2=2:J<;G94<248.59+4<-5?/3=01;.1=0/@F:=C8G:BK>CGVMNUFAK?=G:>E8@G;BOC@OB?K>DK<@OAJ_RKeWF\N@RD@PC@NB>I<=K=>K>:K;=K=;I:9G9:G9H<AL?IWKJVJJQELUGKUGLVJLXKJWJLYM[mcd|tTsnLmhPhePb_LcYJ]SHXMJVKLWOMXPO]RSgZM_RJWKGVIK@?K>;H:@K>AM?BK@?K>K:?K:BJ;EP@ITDHUFIVFKYHGVECRBDOBDNBKTJFRE>J=>F=?J?@LADPDCQCHRDL\NKWIDKA?F=AJ@COC?H=@J>BMA?G==?6@=6?=9DEAJQKMZVP^\HXWCQNETPJYUN^XTg_Vi_Zi`YlbUj^Yh]P`TI]QH[OEUJFVKGXLFYLEXNEUJANCEOCDQDIZMJ_SH\OFZM?QCBOCELB<@6>95>:5<94:;4=@6AC;?C8;F:=G;4::1=<2?>6@A:;?7:95=62?62<7298/:6/77-67-78-::0<=3<=3=B7;B7:C78C99C98@77?48C9?J>@OB@WICbSKfWG[N@ODBMAI9@I<@M?EYJATEAPCAK?=G<@G>FI@DK?>M>=G;?F;EJ?GLAFPDCPDDOB@K>=H=:F;?I@AKAAKBAODCTFFXJFVHETHAPC;K>:J==K?AL@?H=@D9?F;@H=BK@?GF;?F;BHFPCJUHHZHH[JK]NN_PO\OLSFJPDIUHESEKSFIPBFQ@GTFHTFHTEKUGMWINWHOXJKUGKVGMYJN\MO]MS]OT_QR_QP^PO_OO_PN\PNYMGSGOYMU`R\k^andu€|‹„†‡ŒŒr{y]kcVbXP[OP\NO[MP\O\dWYbVT^S^iaoxr†‰v~u_f]dke€‡„’——™Ÿ¡œŸ¤ ¥ž¡¦ ¥™¢œ ¤¡© ¨¢¡¨¡¡§Ÿ ¦š¢›ž£›Ÿ£›¢š™ šš ™˜Ÿ˜›Ÿ›ž¢ž¡¤™¢›ž¤™œ¡˜›Ÿ—™ž—–›œ›¡ ¢§ž¡¦›Ÿšœ ™›ž˜™ž˜™Ÿšš¢™› —˜—™ž–™”˜œ”˜œ’—š’˜š••—–Ž—•‹’ƒ‰†„Š……Šƒ‚Š‚{„€{†zŠ|Šw…{txq€vr‚xr„vl{ohuijthr|qs{pmznjzj_pa\mb`pebrehwlmzo_ma`j^\f[ak`hsfdqecocgsgenc[aV[cYYeXSbSRbRVfW[j\_j^[h[^k]XhZVcZR`WWi\RfYNaUDXKDWG@QCHQEEL@?D9?C9>D9F;:F;9H;K?BMA=G;9D9K??K?@I>:A7;>39:078.99.;:087.38,46*8:.:<17<008,36*4;.>D9CJ>=A8;=569.53+41)53+87,89,8:.>;0;9-9=1:>2<<0=6.81)41*++$QSJUYOCE;9:0?D6NRFGK@?C9@A:DC<>A::@7=A7BA5<>099,76*43(56(79+:9/98.55)00$11%22%2/'0.%20&11%00#22#32'34(46*57+67+55*31&/-",)(&+)-+ -+ /-".-",,!..$..$.1%14(57,44(34(24'40'21'55*84*23&3:,=G:?G::A5>A9;A65?12=0:A6>C87<.39,.5)+2%*2%+3&28/8D8;L>7H9:H;8B78A69F;8J<9N@=N?:G76<15=/4?./=,0A15H9:E64=039.29.1:/0>1.;/,7(09-2:25?5:G89A66>2427C66@33:.29+-3#04)24*0/$0,#/,!-+ -+!,+ ,+,, //#./!.,#-,"/1$25'/4&-1%PeYOfZMdVNcTK]PGYJEVFERCAK>?E:=H;@K==I==G;>D:BEONAWTBOSACO?;G<=G;;D6;F9PC=L?CK8@N>DZKIbTLbTL^NDVIDTFAOA@N@?L>?L;@K>;G97C59D7>F:@D8AGE;=G:?J=>H:?G?AI>EOCETGJVGQXIQ\LLYIKYHJZLL\NFWI[mfg‚{Y|vPrlNjdSgaNfXH]OBRBAM?CMALTIN\PReXQdWVdXQaTDWJISGBNA>J>;I:AM@FSDDMCEOCAM=AM;?J9@I9EP@IUEKXHLYIM^LIYHK\HLWHJTHNVLHRH=K>5>:2>;7<>8AGBGRKDNKAKLAECAFEEMIJXQP_YVf_YjaRf]WjbWg]TcWO`UP_TGVKDRFDSGGYKHZLEUJHSHMWHGQADOAFUGGZMFZMFYLHWKJUI>E:=74>:6<:5=>8<@9=D:?E:;F:8H<;E9;C89A6:B8;?6>?6??6@>6A>6;>2:;0<;2@?5?A8I@:D8<@9:A6D;>QB@YI@VIANDFPD@KABG>CC:BD9>I:I9?M=@NABNCBJBEODETFFUGCPCEPDBLA>J>=J>8F;@K?>HEQDDSCDSBBSAFUFKVILUHORFRVJT_QHTFU_QGP@HSDEVFL]LP]MIUEJUGOXKU\LQZIP[JP]LN]LM_MT_OUaQTaSN^OQbURcUPaUO_TMZNR^SZgZ]j\apgw€~†‹”’™˜w}]kdYg^S`UUbTWgYSdU^dYXaVW_Xitmy‚}w}zgjaae^gkfw|{†Ž‘˜˜œŸ¤š¢ ¥ ¥œ ¥œ ¥šŸ¦›¦œ›¥ŸŸ¤ž¤š¢›ž£ ¥››¡˜˜ž™™Ÿ™˜—™š¡™œ —šž™œ¡˜› ™œŸ—™š™œ›ŸŸ£™œŸ˜› –™ž”—œ˜œ ˜› —šž–™œ˜šž“˜›’–™•˜”—Ž”—”•”’ˆ„‰€‹ƒ}‹ƒ‡ƒ’†‚’‡}†|‡|‚…{Š~t„xo€umuq‚ujymmymy‚u{vtymr|pn~nl{kgwkgvkiwiv…xrqcm`_i[muh}„wqzoithamaiuiencai]dmc_i\UdTQcQXiXXhX^j^]i]]h]WdXUbXR_YO`UNbUQdWG[NAUF=OAAQC@OA>H<G>6B9<=3;<245+37+48,7=1;9174-85,98.44)35)46,;@6BKA>I?I=39;19:/:8/98.54*/2%34)69-:=2>C7;B6==1;>2=B7AI>=E;2BE6=A2@E7@D9<@5=B8<<2@@6BG;DJ;>@0;=288-55*66(35&59)>=288-44(11%33&23$31&1/$0.#33'10%32&34(34(46*58+78+22%-+!-, )'-+ -+ ,)//"00%.."0-%.,"0-$03%23%33%12$54'65'73)11%0/$53$23$1;,?M?DPB7?47>39@67>3:;.05&4?-3>,8A/:@/:=.6:+07(-4(-5)+3(22*4:/3A3:K==I=8?56>62?43E83F75B59B31;//:+/<+2?/0@14D59F3;C3;=18;05;02:029.4:-5<15>66E:=RCBJ@>E;8=2=C67?03?.1>11;//7*17+78+33%./%10%1,#2-$-*,+-(+(+*,, ,.+/ .,".-!46';?/:?/39*QbUNbRSgWTiZNgXG^OI^OHZLDVH>OAGK@KMAPRDORDHOCDMC=C:>B9=F9>M?ASD?MACKACLACPDJYLOaSQdUN_RHYLFWJDTFCQC@J>?L<>H78C18B2;D89D:G:@K>@LACM@@N@APBGVHMXKU^SVbPN]NI\MH\MI\OM]QNbZ`zu`|TupRngNeZK\OBNB>G;>F9BI:>F7BNALVKT]SVg\Wj]SdWI[NFUIBMAAK?ISFLUHKTEEQC>L>>J=@I=AE:GO@JTEJVFJWGMZLR_PR`NKYHKVHLVJJRFDLBBJAAN?DSCETFGUIGVHHWLIOFEG>F<7A95<;4><4?A7@G<>:?C>FMIMXSTc]M^WObZRg^Qe\Sf\SgZSeZJYNBLBEOEJVLJXMKZJKXJMYLKWJJSHFQEETHL[NL]OJ]NJWLCE>D<9>85?>9E::E::B8;C9:C9;C97A79A77?5C6;B7E;>B>8;69=7;;3<:0A;1<;1:<5:=99=8:;6;839718<28A4?J<=I>;A;;@8<@7G<>J=>JB=MA@SDAQDCN@DMBAL@ERDDUF@UDDWJEUI@K?=E9@D9BF;@F;CMAHRELXJEOAEO?ENA?K;?N=@P?@NB@MADNBERCFUEFVDCRAERCBOA=L>9I<?L>>L=@K?DOC@J>?G;=B::=97A4:C4>G8AK:CN?BL?BQEJOCOQENUHOZJR^Mbi\ZaTOWJKUHGQDKUHS^T[g[QaPHXFGWFM\KL^PO[OQYMR[OO[LO`OS`NQ_PM\PN^SUg\Tg[PfWK`NK_NZl^Wg[]kcdvny†„‰““˜–šƒˆ‰r|v_jbYdZ]h]^i__j``i_XcZZg\kvlszqsxphlajoeipiuzv~‚ƒ•˜š—› ¢› ¤›ž¦šž£¢¥›Ÿ¢œ £™œ¡™œ¡›ž¤•— ™œ¡š¢–š”—›•™›•™›–šŸ–›Ÿ˜ •šœ˜œ š¢•–Ÿ””š–˜›˜™—™œ•—›‘–—”˜™”•–––˜•˜˜––‘•”“’”‘•’Ž•˜‘š’‹™‘‡–‡ƒ•Œ„—Ž’††™‡‘‡†›ŽŒŸ‘‰š‹™‚…tvpwu„}svlxnu~t}†|v~spxmp|puuu€tr{pz‚v„‹{€zcme`l`jpf}€uw|qembhodkoepshjodhncek``j_ZeYYeXXeW[gX[i[Zl^Yk\Wi\ScVUbVI`TKaUSgZSfWDXIBWFBPF>K@;I>>LA?K>;E9HAEQIFVJJYLWeVM_QHXJDUGFVGCRDCTFAO=@P@=L?5D98D:;E;>=3;:/::-::-66+98.47'38(4;+:@1CC7GC8DF:BE9?D8=E:;E9;G:@D8;<042(3/$62'74)99/67-46*66*;;/65)5.(0+#30(1/%54*85,;;/BA5@4@C7=B6:D57@4,77(33'10&65+57+58)48(03$13(23)52)/3(.6)15)55(56)25*59.:<0916B6;H9?G;;@59<3@F>=E?;A93=34?58C99C9CL?AL??K@>G=>D9@I=DSCDVHDRFCMB?K@?MABQEI[ML_PK]OHZLEWHCTFDOCBK?@J==G9;D6:C4:C7H:=J;?L?>L@@K?@NBESGIWLNYMR[PQ\OL[MGZKF[LJ\OM]QK_VPhcOkhSokSjbGYM?JA9B8@SEDTFL^QQh[Qk]PgXI]QDVICSFFUHIXJJYKIUHFSE?N@?K?>E:@B7BJ>HRFGUFGYGJ[IO^MReSM^MFVHHUHHSGDODCLC@N>CTBDUHCQFETFBMB>D:>A8;A8;B8>B8=E9CL@DL@CG>A?7A94>;6?=4>?49@6:?>9?@;94CD<;?59@4?F99C79B69A69A6;C99C89B89A75?B8?E9AF9@H;=E9=G;?H<>G=;2=>3>A:=B<=A;:;69619508808>4AJ?=F:?K=?OAASEH[OGWJBL@>F;@E:?D9?E:?GJ?CQEAQBCRCCPADNBCNB>J>?MACQEBODEOC@L@F:CL>AK=AK?BL@BPDOYNISHIXJQaSYeU`gZRYLKTFMTGIREMVIT^TR`SLXHGVEHYGK[IJ[MLYKR[OS\QO]MRdSSaPQ`PWgZZl`Vj]Sh\VfWSdSR`O\h[WaVaiakwsƒ‹‹“˜™¢˜šŽ”’xƒ|^i`amberfp}qp}ripi`jcZe^hrlpvqmrlhsjvyu€{r{xu|{“”˜›œŸ£™› š›¢›¢™šŸšœ ˜šž—™ž™š ™šŸ•––™ž—šž•˜œ”—œ–šœ—›œ—˜™›–˜™–˜˜˜šœ—˜œ•––––”•“Œ”‘‹‘‹’‹’‹ŠŽ‹ŽŒ“„Œ‚މˆ”Ž…‘Šƒ†Œ˜ŽŸ“‘¢– “Ž ”‘¤—’¤˜•£™•¤›–¦›“¢˜™§›œ©¤™£™Ž•‹}†|z‰}x‰}uƒxjwl|†}‰}…{t|rr€tw†yx…yxƒwx‚vmvjiqkdsibrfishoxmepdgtheqdembipeela`i^ek`cj_XcWXeXYgYYgYYh\Zl_^rfVk\TgYVfXI]PL]PP_RNZOBOBJWJHSJAK@@H>?H>@I==G:;@58=28>17=04=07B47@54;/47,98/88.47,59/8?5?I>BMAJSIEMCCKBAKACRGBSGCTGGXJM`SI\PN`TNaSM_RBTG?Q@>PA9K=9I>;H=>I>>?69=1;=26;/6:/8<36<.8=/59+;=1>>3CB8FG;FG;DF:?A7=A7>B8=A49;//.#0/$33'98-:<1:;179,:;1=<111&2+%2.&42(53)42)33(44(66*:;/EG;BD9:>2/23'-.$21&45,69,57*13&24*88095,36+4:/8;/87+66*27,7=058-47+37)15(00$10%.,"+')%*$-%+&+).- 10#11#1.#1.#/,!,)/, 1."4-$/) -* -,"+*,) .+ -1&26+/,$/)!/&".-$11'9<08=.8@/9B06>019-07*/6)04)/2%/2%.5&-9(1B00C07J6:G;6A43=/2<.2=1/<1-8*,8)/<-2>/0<-6B38E809,28,:=3FLDQZRORMIQI?F?9F<9C:S[R`d`]\WOKGD>6>:142'01%-2%08+39,00%,'+',+!-,"//#,/!-0,, %)'* ,* -*+..,!-+ -+ 01"49)8?.MaTVgZ^n`]l^Qj\KcUBZL@TGBTE>N@AM?CPABOA?L>AM?DM@BPBCPBDQCERDCPD>K?>I?>G;ALOB@QDAQCGVHG[LDWHBUF@PDCMA@H=BJ@>E:D9;J<=N@>QB>K??MACQFHTHLWKGQEDQCGWIFXKK]PL]OL[NI]SNe\OgaH_XAQJF<=I>=D:<>57;28@68@6?B9@J?FQFDNDDH=A>5C;3@=8?;5=@5>F;?I>>B:B@8C@8A?7?A8AF=MVLMYQIWOHWPHYNIYNFUJN\PS^QSYOLNEAC:KMDEMBGPENXLS_SO_RAREFSFP]OSaSN^QKVJJI@A>6=<4?B7=D8;A5=D7=E::C8;C79B69B5>G:=F<;D::B8>E<>C:>D:?G;AJ<@J=AK>=G;C=@@9<91=729605718=79A99A:8C88B8:C9;B89A79A78A7L@?K>=G;=E:;D8;D7:E8>K=BQCEUHHTHCLACH=>D9HBK>?H;BIAMAAOCDPDCMAAL@>H<I<9B67=28<16:/25,6907>4:B7BL?DJABH>AM?DQCCSF>RBAVINcVVkbTi`LbVMcWF^P?VIFYI@UG=OC?PCANB>H;>C:24=37A56;0:8.:9/<<2;=2@?3BA7?=2?>3>>3??5<>1::.11%23'46*49-:>0=B489/68-78.32(51*63)94+54*32'33'00$55)==1EF:?@4AA5BM=9D55?36;18;.BC5GM026(/2'33'23*78-8:.11(13)660>?58?64<18<09:069.19.8>28?25;.26*05*53'00$,*+%+%,&0'+&-*.. 33!42!1-!-)-),(+'-)/) -) ,* 1,#/*!.'.**+ ))-'!.#.$*')'**-0"39*7A04A13?/3=039,26*04'07&2:)19*4@/2?/5A35C55B34@.4@/3@11@24A01=-1<,4>.8C29F47D53@;FLEKSLENG;D>ELGMMGNJEE@982+.*"64*::../#()+* +,!((+(.,!//#11%44(11$/-"'**-",+ ,, *- -+!,*+),, -/#16)NhY[qccvi]obTk`PfYI]PGXKEVHCSEDRDCSECTE@RDCTFCRDFPAKUHKUHIUIGRFCNB?L@DNAFQBHVFJYIMWJHWKDUHAUEASDETFHVGEWICVGCVGAQC?J?@I>@L?@H=>C:;B7QBBXICTG?OCAOCDPDFQFCNB@LB@OCCUHI[NHVJJUIDVJEYNI^TEWNBOG>H>>B>FMGCPH?NC>PDAUGARCDRDIXKOgXOjYG_NM\OKWLKXLNZMGWIDUGEWJHYLGVHBL@;D6>C6AI?GRGFUGHYJL^ML^LF]NI^PGYLCUHCRF>L@=KA?O>=O>@QC=J@9F7:?7<=4;>56@6:C9>D:=JCERHFNDAF;>=3B@4<<9;=5>C8@K?AMA>D:?>5A>6EB:>=5AC:CG>GPHFPIBPE@MCALBFPDLZNS^RV\QLPGDD;FF=BF;GMBU\RS_SP^R>LAESEM[NPcRMeVM^OCKABA8>@6@F;AG<:C8=C8=B7E:@F;>I=AJ>@J=?I<>K=I9?I<@J=9=<75=D:@H=>A8=<3<:59716608;58>7;D<I?=G;;E9J=ALABPDBMA@H=?E:=C8;C7?B9:A6>F;@J>?H;=F9@FCM@ENBAH=?F>G>J>>I=?I=>H<;E8>H:>G:>F<=F;>F;CK?GQAGQAGQET^R]eXV`SK[POdXYi]W`SDM@HNADI=FJ>DI=GPBMUJISGKTHLVIN[IN[IK[KL[MVbTR`RSaPXhVZl[]p_\n`Yk^Xk\[n_bl_T^PPUKQWLV[OY]Rmpo|||ŽŒŽ”“•”—˜’—˜†Š}ƒv||€……‹‘‰Ž‘‰„ƒrwufkjourƒ‹…‹Ž”“‹‘‡Œ‹„††–••“•™“•˜“—˜–˜™–™š”–™“––•˜™•˜˜“•–’––‘””••—–‘˜—’™™’™—Ž•“Ž•’™”˜‘‹–އ’Ž…‘‹’ŠŠ›Žˆ™‹‹›‹™Ž‰”Œˆ“‹†’Š‹–ŽŒ—Ž• ˜–£˜™¥š›¤šž¥šŸ¤™£§ª¦¢­§¤¬¦£®¨£©£Ÿ«¥ §¥Ÿ§¥ ¦¥¤¢™£¡™¢Ÿ•›™“˜•‘”‹…ƒ~Œ€wŠ}u…zv…z}zˆp}ukxpm~sntv†|w‡|kyngvkp|ui|ri€rm€sn€tp†{nƒwn€ugujfrf`l`\g[]dYZcXT_STcW[m_]k^^c^ZcZXe[^m`XfXKWGIYHHRDGOBCH>EH?HJD@E>:>578/9:1:>3:B6>C:BGF;;I:>N@AM?:C8=C8;>447/27.793=B8=E9G;BJBIVHGVGDVECVGH]QWkbizsfxpVh_Uj^DZM@VIHXJEVIDUIFVIIWIJUDHRFDMBAF;9A66A59E95?349/67-98.8:/59.@@1==.<:/:8-;:.;:/;;-::-55)77+69-5;0:?/;?26;067.89/68+64*41'72)84)76*13'33'77+@@4==1<;/==2>G79B3=F91==/>B3=C46>/29*7:-66*34+79.<>2<=357-<<6IOFFPF4>5GMC?C87?49A7AGE637,37,22&11%-+ -(.(-&/&-')',+1-1.0+ -)+&*&-)-(*(+)+)-(0(1&.**+((,&+"(")#,')',,!4;+9D47I87D45?/5=6KJAVXOLMD75,20&1/%/-#((,,#1.#44(24'35)22&1/$-+ *,/2%22&21%,0$0.",*.,"-+!-,#+.$Ul`^sfeyl_pcRf[QcXM_SJYLLZLJXJGREGUGCTFCUGDVHGWJPVGXaSU`TLYMIUJFTFBQEBM@DO?AO?HWFLUHHVHGXJEZKJ^NSdS`o^UeYIYMGXL@QC?O@EQABN?FOCDMA=F;>H<J?LB>NC?PEARE@MACLAASFGZMI[OFVJ=H>OCPCAPBCNADRGMbUNgYF^OGWJIXKHUIHVJHWHL\NK\OM\PMZM@J=:D7=F:>F5A>6BA8=@7HLQHMTIJSHFODDNALWIJ]KHbORhZGTH@@8>A8@G=B9=C9@F;?E9BE9>J>?L@?J>@J>@H=BJ?EOCAK??I=?I<=G:F6=8:=6=D9=F:=D9<@7:=3:<3782582:?6>D::E9;F:G=?G>>F<=C9:B6=G:AMBAMA?K=?IF9@8GCI=CFD;?G=@J@?I??H>>F;=E9=F9?H;AI>@H=AJ=GQBJTDLVFS^NS\PYfUYdXTbYUh^ReYP]PGREHPCDH5=<3:<2=F:=I>JYMBM@=E9IOCEH@8;48;5=>7>B8=E7=H:CQFO\UTfZXg[P_QO`RVg[fwps}xgsmdqgZj]GXKGYKOVKGPD=HB7AI=AK<:C69@38=19=/:=0=?2DB5DC5;<.78,59,69,CD5AA396+77+<<1:<2;A157:168,69*32(41'71&73(76*14&55)66*77+53(64)A?3=D3=D5@G9BG:EG9=>.;;/8:-8=.49*78)87(45*79,:=0<>1:;1@A8LPKdke’˜‡‰‚YYPORJMOKX\U[_T7=-47)15)21#0/!/-#/,!-*-'0*!-* *)*),*+'/,!0-".*.+ /, +()'+* ,+!*(*%-%,'&%%$,%+#'$)"-%+%**-3';F7=O==J:7@06=07@37@558-23(11&24)05*06,0;.5@19B18A13>04?24?43>14=12;,0:*4<+29-7>1>G:>G:6:3672/2(02)22)==4::220'0-%.-$/0'+,"--"/-#1."22#.2#/1$1/%.'!.-"-2%15&54&63)./%+) *'0+#-* ,* ,-#Vg[[j_VfYUcWO`WO_UN\RMYMISFDOBBF=?EL:@N>IRBKVITeVQfVOcTUhVgvfdogVcZO_SIZLAS@EUCDUADP@FQCBL@AMBCQDCOCBMD@LD?LD>OE?TGAVJEVJESHCNDDNDDQFCQF@QFOADVHCUG=OB=I>?I?@PGL]SEWL9M@:L>BPB=M@ARFLdXQm_Pj\LcUG\OFXKGYLI[ML`PP_SMZNIUI@L>=F:=H9ERFKXKFWLBSHAPD@L@;D9@K;?L<>K=DG>MQGFSMBME?L@;M@:J>;D8;;4972>;7?;5A@:=>7<@7=C9;B8;B7BI>LRFP[MMZKGTFHSGJTJFMDCC>BB;FH?CF=DI>DJ?CG:FM=FUDDZJOcUCQE@A8=@88?89A9=D==C<@@>C8@D7;H<@L@COCAK>CL@CK@BJ?@H=@H==F9=F98C4=D66I=>KA>NC=JA:E=9E:;D:I=>H;?H;CJ=BI<=F9A8=@7:C89A6;B7=C8EI?EL@GNBHNBEI>EG>@E>G==G=AI>KTENXGMXEOZHR_LWbSUhWUfYRaXNcZG`SG^NLZMFQCAH;DI=BJ<5=@6>F9?L>HYNG[QN]UVe\ZfYLZLM[QYga]a\hnghqfWaVLXIERCLMC>A69>4=E7AJ:IQ>HVDBK;;>2;=0BF6FM;AE906>15=0GI9DC587*85+:9/98/5;.8<1:;47907:.;>.;:174*71&71&86*59*88,66*55)42'42'<:.>@1;+AC69<,68):=.;=1;=2B>:ONIca\VNIKB;D@8?>>Z[UFH>58(25&//#.+1.., +*+),*,* *),,",*"+) -' +(!.,#.-"1/#/.+**()(-,",+!.) +&)!(!)".$,!(#)")!,$,*-2&0BO>=E58?36?44A43<+07(07'19)/;*-:*1:-5>16=/29*.6)/8-*6,,7+.8,19,29+19*47+6;.K=?L?AN@GTGS]MfqadtbRcQLYFWaNcn_]l_PcVK^QEUHBO?AN@COB@NBAPDASEEZJARC>NA;J>9H??NE?NEAOCFUIDTICTHBSIAQIDWHARD>M??L>AL?CNA=Q?CSCCQC>L=NE:I@:I>@PD=J9>K=APERbZVncNj]LeXJbVG_TE\NDZLAWJAPEFSGBL@AJ?>G:?H;>G<I?AJ@CLCCH>@H>@H?>G;>F;?F;=I<8F9=K?@NB>MA>I>CRGFWJBTFAUGBSFCOCDLAFOCSZNK\OEVI?NA>L@>J>=G;<>79:1;<2;<1>A6@7>B7BJ=OYJN[NKZMK]NJ[MMYLIRECG?GF=B@8AD;CF;GE@G;BLAJUJHUHAOAB>7?<2=C8I>@E>@A6?A8@E3>=4C:>B9>@9BK@=I=?G;>F<@D>CG@BI>=B6=J:G=>F:=F9>F;?G==E;?I<=F8=H78=@9<@8E9@J=@L=DO?DK?FH>BI>ELBHOBHO@HO?EK:CI=BL?=K=;I;IRCNTENRAPTDMUDKWDMYMS^S[g[\f[[fZ_i]Zj\[i[bl_bm`bocgwkfylbtg]ma_qc_pc_qdgqdmwkzƒy€ˆ‡‰‹‘†Š„{~{vyxƒ“””’‘•‘‹•‰’‹uwkvlnxnt{q}†~ƒ‘‰ˆ˜‡˜Œ›–ˆœ”„™ƒ˜ˆŽŸ”‘ –“¤˜¡•Ÿ“‘¢”—¢•£—œ¦žž§  ¨¡Ÿ§¥›¡¨§¨Ÿ¤¦£§žŸ¥œœ¥›š¥œœ¥›œ¤šœ¥›–Ÿ••ž”• • “‘ž“•¡•œŸ’”¤—’¡”¢”Œ¤“Š¥”Š¢’‹Ÿ‘Ÿ“Ÿ’ ’‹Ÿ‹ŸŸŒ¡”‰ ’¤—¤–‘£—“¢––£œ–£œŽœ•‡•Žy‰ƒ“ˆ‹˜›–Š•’{…„lxvy…‚Žš•‚މtymyrm{pn~ssyz†€Œ‰}Šƒvzvwu{wqxrt}ux€vryobg]ZdV_j\[k\SeWRbURaVZe[eukk}v\riSj\J`PIZLFVJKUMCME@LCAQDAN@@J?:C89A75;;5;<6:@:CKEDQIAPIJ]SYh^OZOBK@LXNIXNX_Zcjb[fYW`RHO?FJ>IJ4?A7AG>JOE>B78<0>A6=D6:G;AMA>G:=A1HK;FQ?FM@DH=AG;:C63?27E7GM?=B2:=-?A1?>2;9.?;0>;0:9.88,99-<;/<@097+:4):6+;9.79,67/34*75+64*42(31)54&;:-AA3DD6>B2>B39A09?/9>/78-88-;:1?A542>.2>*5@+7B.6D/2A/7B.449,07).6*-6*+6*,7+.8,.6+06*.7)09,8A4GPC1;.35*7/-:247*;;/==287-31)/,#/)$,*#04)58,34&1/ ,- ,+!..#21'52(10%).#+3'.7+/5&34%42#--"+* *)-+ )**.!S[MW_SS\QP\PPWKNUJMTIJQFGNDFLCGOEKXLO_RUdXR`RLVJKUEN^QL^PITIHODBI??I<>J<FSEN\NV_SZgX[m^QcRJZHN[IXgY_obTgZNaTIXKETDDUG@OBANBARE@SEAVGCO?>J=G<@J>AK?CMBDNCDNDCQEERFERFCUF?OA:J;?JBK>>M<@M>COBAL??L?;J>>I=>I?>IA:F=:E::D8=D7?F:@F=ENENZQL[PH[QGZNDWKFXMDUH?PD?MBCOCBK?AI>@H=?G:?I=CNBCPEBNDGQGDLEAI?AJABKB@K?@J>@H=>H<=H@6::1<:1=<3@A8>B9CG@AE>?E:BHAIE7;A2;>33:=2:<29<1<@5:@5>D9@H>@F=@E<;@57=26>29A49@4=D7>J=CNBAK@AJ??H=AI@>E8;E8G<=C8;C7=E8>E;>D:=D9>F8=E8?G8=F8D9B7?E;@I=@M?CL@BJ>CG=BI>DLBGOBJPCFN>EL;GK?FOB@M?>L>=H;=F9BN?AM>BN?IUFLVJHWJL[MXdTWeVQeTNcUM^QM_RIaSFbUHbUHZKIRDJM>FL=EN>IN=IQCLRDLPCJO@NWFJWEQ^QS_RXcWXbU]gZbl_\m`aqdfsgbpeguil|ptƒytxr~twƒxmzogxjjwklyouw|‡€„މ…ƒŽ‡uyozsy‚|†„‰…—ˆ™Ž…–Š€’„w‰zm~poxm‚Œ‚•‘ ˜’¡˜–£œ“£šŸ–‹›’ –™¦› « ¢©£ ¨¢§¡ž§Ÿ ¦ž £›ž¤Ÿ¥œ¤™›£™™ •™¡”—ž•˜Ÿ––¡—” •“¢—”¢˜‘ •Ÿ”‘ •Žž”’Šš†œŽˆ›Ž‰šŠ›ŽŒž‘‹Ÿ‘Žž“¢”‹¥–¨™‘¥™’£˜£—Ž¢–¤™‘¦›“¦›”¦›–¥ž”£–¥Ÿ˜§ ›¦ ™¢™¡š¢ž’š–…‰ƒŽ‡Œ—™ŸŸ•››Ž””‰†…}„€‡…‹•y…q€yp€vnup~xuƒ||†„q~wp{up|rjpnvzu€ypyrlulgmdcmadoc]k^TdYPbUSaUVcYftlm}vh|rTk]H_NFYIIYKKXLFOD@K?>J=>G;@F<9A8F;AJ?KUIMVJOUKEMBBI>IQGKPHDGA=A:9=58<49=29?4:C8@L?DREIXMM_UTdYDQDEOCFSHQ^UZa\W`WV_TKVHEN?@H;@G;EKACI@9@56;09<1<>68:033)67+9<.9>.7A69C87?3:1?C59D26@05<,16+45*65,68,7:.37+7;/=@4?@4:9021'51)51(41'20'1.%40(;80?>432&// ,,/+-))*,-#.-#3-$/+".*!/) /) /'/(!0*.+1- 1- 1,!0*#/,!.,!1/$.* -$'!&!("*$*%'#'!&!'$*-!4=0;J;>L>AN@?N@ESEVfYcl^`oa^paPeVK_PJ]N[n_fxkZl_TfYJ[NFXJFYJEUGBSFBSF?SE>RC@L@?J??G==E;@F:AH;DPECNDALACOCERFDSECOCBOCAL@AI>?G;?E9=H8=G8?H;AK>>K>;L?@MA=K@>I@?IB=D:=B7?B8CE:AD;@C:@E=I=>H@?I??G=>F;?F;BL@DQFHVJIYMEUIFRGCNFCNCBND?MB?M@AL@@J>>H<4;=4=B:@J;CM>=E9>B:CG=EK@FPBHTGHWIHWIFRDGQDJLEHF>CEF;=B:>B9BI?NXLP[ODPD=:6>=5@E;GTFERDDM@CG=AE>CFA@D>AF=AE;>E??E=@F=8?A:=B8;C5@E6;A1??5<=3>?5;<2:;1<<2>C8CMB>F==E<F<>F<;C9=D:>D8@F;AH=:A5;A6=C8=C8C:=C8E8?E8@J:AJ<@H=AI>=A7@D8CG?DK@BNADNBCI??C:BI=EMCKUGGPCGPCCL>EK@DL@CL@>K?>I@O?CRCBPCBQCDRECQEJVJGVJM^PTaVN]QFZMGZKHXLI^PHbTCaTFbUOdVJZLFQDGQADM>IM>HQFMRGMTGQXKT^PN[MT^QNXKR]OXbU`i\ksf`sfgylk{paqfbsij{ry…|‡|†~z…{s‚vmqm~qp€tj{pz‹‚…•‹š”Œ™€Žƒo}rsxz†~‹—”¥š’¢—’¢–’¡”Œš‚‚wu‡…𣙠¦ ž¥ŸŸ¦žž§ —¢™”Ÿ——¢š §Ÿ¡§ž¢¤Ÿš¡š——”𔑗‘“—’𔓒›‘›‘Žš›’Ÿ—‘ •ŽŸ”¢–¢•Ž¡—Ž¢–Ž£˜¢–Œ¡•‹ •„š˜‹—‹‚˜Œ†š†šŠŸ“Ž¡˜‘¤›”ªŸ–¨Ÿ˜§Ÿ™¥Ÿ–¦ž—¨¢•¦ –¥ ˜¥¡š£¡™  š  š¡¡Ÿ¥¤ž££¢¢Ÿ¢¡œ Ÿ“˜—ŠŽ†ŠˆŽ•‘Ÿ¤¨™ž¢šŸ¢’—™‰t{u‰’…ŽŠt€zs{t„}s„}x†€tƒ|y„‚syr~wlzpnvspzxiwqiumkvor|tisgisiergYj_Td[T`YVdXanir‚{izsVj^NdRHYJGXGKXJHREDM@?H:@C:>C::A:?F?>F;34:/::176,75*53(56(48)5:.3:/9>3;<3AIE7DKA5@B6AB6@@4?@3;=16:-73)3.%0.#41'45(/2&54(43'44$43$55)47+42)43)43)45+47-9?3;G87C3:D38@426*/3'44(67+79-<>2CC7??3=904/&31'31'32(//$0+#2+$.+&0,$0/%--!,+0* -)--#..$0-#1,#-(.) .) /*!,'/'/)0)-&1(2* /&0+ .,!0.$+)*$'!'!'%*)**)(,&+%(%&'(0&/B29A24>15:/6?17E58N8@WABU?FT@BT@;K;5D67H58H57G6:H89I88J97I88F6?L=@M9?N:BNDNAFOCLUJFMC6916909<3<@6>A8=A8:>3-1&/0%-0#0,$00&.0$/1%.0!0/!.,!--!00&-0&05)06)-4'.3'-2'01(00(1.(/.%0-#/-#20&.-#,+"V_TPZOSbUNcTJWKHSGFPDHRFDSFL]PQeXQi[Tn^Ul\TfXS`RJZIHYLGWKIRHDLA?H=AN@COBDQCCSDETFM]Nhreiwibtg]rdSk]Qj\Xqdf{nYm`QeXNbUFZMFYJCUGBSFCTG>QC>RB=NA?NB=J@=I==H9@L:>NCDSHBPDHUHEUFCTECNBCL@AL?CJ??F;BI=?H9=F8@I>K>3:=59>69@6>C:?B;?A<>C<=C=@G@>F=;D:>H>=F<>G<@K?FQEK\ORcVPaUM]REUICNFFQG>LA=K@=K?CNBBK@BL@FPDEOCCNBAMACOCGQDCOCEQFIVKIXLJ[MM]RTcXRbWQ`UQcXNdXN]SGWLJXMJWMDOE?I>=?4>=3@?6;=4D>F<>GE?9>A8C5?@6=>4>?5;=3;=3=?5=G8>G;DMBBL@>HFD9?F9AH;AL;DN@DNBAI>>C8DE:AE<@H=DLABNA?G=?C:@GA:>D>AIBBLDEOCAJ?@F;=C8BH=DH=GJ@AF;@E>BIB@G@;B;9@9NDARHEXOK\QKYMKZNO]Rdsjx}tw`qdGXJBRDCOBBMDCMFCLBAJA9A66>39>389/77,75)::+:<,8;.9=2AB8CB8BG=@OCEUGFTFCNA=H;AK>BM?>F;;D6=E6?H7@H8BI:203:-08-8F6BVDB[DCWAIXEG\FCVFDWH@S@>R>AP@LPD/3(/1%.0$--"00&13'13'02$01".."/1&/2(26+18,,5(.5%16(45*12)0-'.,%0.%/-#-,"0.$/-#0.$TdYGWLK]PN`PJZODRGHRFJUIWeX\m_`sebxi]teYpa[n]WgVR`PHZMEUHFOFDNAAMADQCDSECRDDSEJYKK[MXcTao_bte_uf]vhXufUtfWseRl]NdVIaSB\OGZLGXKFVJCSF@QD=OANA=M@9H:>M=L?>I>K=;L?=K?;I>7C;7B:8@67=28;58=59?6:B7?C<=@:>?:=A:=D=I?>K@FUITfZQdWPdXJ\QDTHDPHBODDRG@ODCOCDOCDK@BMADOCAMA?L@ANBAMABK>EMAENDBLBCOCHSFHUJLYMKXMMZOScWPcVN_RL^PHWJHVIEQD=G;>A7<=4@B8@E;?G=AMACOAHTHHTJCMB@I=DIFOCFKDHKBDKAEPFFUIDNBBKEFOFBJ>>E9>C9DF@EHACD;BFAK>AI>@H=@G=@H<>C;>C:=D8>D7>C8>@7>=6>?7=B9;B8;B7?D9@E:>C8@E:D9@I@H<E:BH<E9;B7>E:?F;>E:>E;CL>CNBDPEELC@D;DD9BE:CJ>FOB@M?BK??E;BJ?DLAFNCFPDFPDEOCCI>AH=CJ?AI>AI>@J>AKABL@AK?BM?EPAEPBDO@GWGHZJGUGDQDBQDEVHG[NFaSGiZKk^UobSeXKdVKfVIZLHREJTFJPFJRFPZMWcUUdUVfVTcTO^NQ_PUdT_i[frcl|orƒur„vn€tj{pv…yyŠ€†•‹ƒŽ…~ˆ}€Š‚€„wƒx|ˆ}ƒƒ•”ž¦ž¤¦Ÿž šŸ–•˜‘•Šš’¢¤ž¡£œŸš—›–•ƒ‰ƒ…Žƒ†‚“™–œ“˜ž”••“ž“‘ž““Ž”‘–•Ÿ˜’£–’¢•‘¡–Œœ’‡–†•ˆ—‘Ž– ™Ÿš š‘ ›—Ÿž”ŸœŽž—ŽŸ˜•£Ÿ˜¤¢™¤¢˜¥¢š¤¢˜¢¡š£¡– ž”žœ‘žœŽœšŒš™žœ‘žœ–¡™  œ£¤¡¤œ £ž¡£¡¡¤ž £ £ž ¤¢£¨œ¡›ž¡ ¢Ÿ¡Ÿ £œŸ¢¡£œ ¡”™™””€‡†}ƒƒˆŽ–›žœ¡¥™ž¢˜ž”›™†€‰ƒ…ŽŠ‰‘ŽŒ“‘Ž••Ž•”‹“ŽƒŒ†…ŽŠ‚‰„v|wowngojhtmgvokxro|vkxqr{qjtjcpf[k`Yi_\i`Zjbiwru}s€{jzoVk\L]OK]LM`OHZIDREAJ@BMGAOIDULDQF?J>@G<=D9?E:DJ?LQFEK??G==F;>HH==K@?OEGWMGYNFYNJ^SQcZQbWQbVM^QSbVcqhz~~ŠƒetiPaT?NACQECMAAK@CJ@CK?:F99F:=G;@H<;?3;=.=?0@B1CD5CG8@A4=<2@D9COCI_OL^PDRDBL?BL>@J<9@53;08B2CN=YdSFQADI>GG=><185+:8.99/2/(/.&02'12(41&60$51'52%73$23#15()0$27+24)43(57,4:.:D8CL?>F:38<09?3;B5?B6:=198-56*56*67*44(42&32&/.$/-#0.%/,"0-".+#0)!1*"-,"-,".) 1,#/) .,"/.#0.$+*/, .+!.'+$+#-%-%,&*(*(*'-' *'(&,+,*+(+(-$)!+%-.%18--8,08*3<+9A09?.;A17@26>37C5>O=CU?DXC;N8:M:@QDBTG=P>=M;9F59D49D47E50?/4A1:F7:I:6B4:D6DLKFJ>DE;AE;?H=?J>;G;;F:;E9?J>AK?=L<=L==E:=F<7>76=69>5>@6><8=>7:@5:@5=>7>>8=>::@:;C<:D<:G>:J>:JCMABI=@H=?G=AH>EMBFNBEPDFPDEOCFPDIWJO^RPaRK\NHWIFUGCPB@K??NADOCFQFISJCOC@J<@H9FL?DHL3=B9>F<;C9>ED9@G@E:EL>;C66?29B79@5=C8DG?E:@F;?G<=D:=F=@I=?G<@H=?G<BM>DQAFPCFLAFNCAI=BJ>EPDCL@DOCCH=BH=FLAFMBAI>?I=AG@CH@DK@DL?GP?EM@H=CH>ELA?E:?G;BJ>@J=DPCEQDAN@@PADVEJ]LH^MC[JJcSUg]TeZL]QL]PCRG`md}„€~†€kxnTbVAPDEQEIRCGNABI;>G<:F:?MAFWJIVI@I<@E6AB3CD4HK9LO?BC464);?4GQFQhYOaSFUGDM@@H;;D7=E;;F96A1MYG^jXNZHJOCDC9=9094+63*0/%.+$.-&15*11'40%6-!3-$4/$40$55(7:.LTI/6(58,55)69-:B59E7>C7=C7>G9CN@@K<:F6=C6;B59B5;D7@G:?D86>11:,0:,2:-5:-35)-1!/0#/-#1/$3/$2,!/,$3)#2*#.+"-+!0,"0+"1+"/,#/-#.-#++ ++*))(*#+#,&,%,),*)'+',%*(*(+'+'*") ,!,#.(#22)2:.2=.5>04?.6?.6<+7>.6A13=36@37A0@M;J]HBWBARAO?:H67A3=K:>N>6I85G68I9=H>9D82;.8<0>A199)63+20(32(65*25)26*46*9;/76-/.$.,$/,$+.#/1%03%.1"/2#-2",5(-5)2;019./45'66'42(34(12'4/&75,31)/-%/*"0(!KcTE^OH\QL]SVZOS[OIVJNXLS_TXj^^nc]i]\k^`te`wgbxf^paSgUM`PN^MLZIR`NVbTMaTIeWJfXL`SO^MPaJQ[HUYJU^SWncUwkRugNnaJdWIbTE\NF]NGZNCTI?NC>MBBQFDTICTEAN>AK>@I9G;7E9?F:DE;EE9EJ=CM?AI>=G;8E97E:;K>@N@@QC:L?9I=6G;7F:8E8;C99A78@68@59@69@66?96@69A6:A6:?5=@7>?;;A:;C<:E>J@:H=;H>APFHZMJ\OHZMCRGALACL@ELAFMCCLABI?AGGODFTHReXI[OCUHDQFCMA@I=:D>;C?H>CLC>KBDSGGUIFSFDNBDMADKADQEENBGL@DECK@BK?BK??I=BJ?DG=DC:>C:=@7?@7=A67DG@AI>?J;BK>?I<=G:=H;AK=?I>J>>H;:B7=C8=C9DN?LWGS^OZdVO[NNZOKTJ@H?@E=?B>J=AI>CMBEPEEQC@L>?I@K=@M=HQFHUHCTDCUDDVFJZLK]QJaTIdXLiZOhXMaQM[KNcTMeUL]QFRFFQFKWIJUHWaTVaTdqdYgYR_TXf[Xi]Zh[dodt}r€†€p~ts…yˆ•‹–ž˜˜Ÿšž¢Ÿ¢œž ››Ÿ•”“‘›Œ}xƒv|„x„ŠŽ•Š‘šŽ‘››š‡•Š„’†…”ˆˆ™‹œŠœŠœŒ “ž” •Ÿ”Ÿ”–•¡š—¤š¤¡›¥¡œ£ ¡ ›¡ ›¡¡œ£¤™¢¡™  ™ Ÿ˜žž™ž™žšŸŸœŸ¡œž¢ž¡¤ž¡¥œŸ¤š¢™œ¡™¡ ¤ ¥ Ÿ£¢¡¥¢¢¥¡ ¤¡ ¥¢¡¥žŸ¥ŸŸ¥š£ ¥ ¥œ ¤œ¡¡ž¡£ ¥ Ÿ§žž¤žŸ£ Ÿ£ŸŸ£Ÿ ¤¢¥© ¤¨œ¡¤ ¤›ž¢›ž£šžŸœ ¡šžŸŸ “——‹’•›š‘š˜‰”‘˜Ÿ Ÿ¡¦žž¥ŸŸ§•šˆ‘Ž––•››šž›Ÿ—™•™ŽŽ‘ƒˆ†{‡}jzmhthipjlzomzsjvpisns|xzƒ€xƒ{islnxrnxrhskepehumlzsjysk|tiymWgXRaOWiZ[nbVk\NbU@QHAPKJ^XH`XF]SHYKJUFFTCCNADMCAHABG??E=@J>;I@;ODDXPCRIDQF@QEDXJOgVK`OHYMK[OUg_[lcUf]Vf[_kaeofyƒ{Љaj_O`QEZID[HHUHELADI>?I=>I=?J>CJ@GLAEG=@B6:=/;=/GF9NSBLVFFLBL@;L>SbP^iX^fS[XIDC5<;.44)45)23(11'31'60*6.'3.%1,#1.&1/'31)65+?>5KL@9<394,73+6:08D58H6AC9?E7BJ9CM;CK;.0;-.6)-3'./"0/&/.$//%2/'/,",+ -)$0+'/,$0+ 0-#.--,-.--)++)-&-'*'))*)-) /*!/) /'-&)())*(+'*$+"+%)'22)9;07>05F4;F9:D75@15?/3=-3<,4<053@F:68,62'5.%1($-'#NeWMfXKaUJ\PLYLJZMIYLN[OTbX]pdcrhZh\[l`[rbd}mh~l\seRgYRfWPbSMZLMZKP[NK]ROj]Pj\MbQN[KSaKT_LQ[KJUINbVVpfVseRl^E]O@TF?QDASEATJCTICSIBQFBRGCTIBRE?K??H;@F;=F;OB7G:6D88E97D8:B98A78@69B89A78A75@97A88A57?4;@6;E=@I?CKAAPE@OE=LA8H>:LA;LBAPEAPEFUIAMCAJ?CH?@H=AI??F<BK?BKA@J=H@?G>?G=?H;?J>ALAERFKWKJVJDPDJUIMXLIVMBKA@G;DICKAHQDKWJM\PGXMGWLP^UP`YM[RJTHISFGQEGPEDNBBJ?@G=CG=BH=AJ?DJ?CJ?AH=AG<@B8??4?C:>A8=A6=A6AJ=?L>CM@@J=BIL@DLAAK??MA?J;?I;?G;>F:?H?B:=A:BGIQEFTGKWIBN@AI=BJ=AI<@HCK?AJ?@J@DJ?CK@FPDCPB>K=>J=1:7-:9/?A3JUBT`OHRG=H=DTED_PD\NBUHBPD?J>>J=ARGHZLFVHWcSck[X\JB?2@=/98*98-9:-:;/58*11%40'3-%3.&52&74,97.75,02(9;1@C9?>384,95.7<08?18>.:>3>C5@I9BL;FO?@G8C7D58@2;A16=,:?/9A37?34=048,03'11'//%01'2.&/."0.#0,&/+&-+!0,"2/$10#10"11#11"--",) ,&,&,* *+!,* ,* /*!.* ,',&)',* ,),&-$*!*#)',+!//#04'6A1;E89C59A57B13<-18)06+3:,9C2FRABTD9M?6N@>TGCWLF\OCYLE\JE\JF\GAUB@Q>?K<5@59F5?L3:9.75+=<2MPFJJ?54)41%5-$2,%.("PdXQfZPcVM_SJYKFXKFXKM[O\i^gyngxmdrg_pcXpbXrc^teSm`LeXKbTIZNCTEFTECODEXLKcWVm_UfUT`LW`OXcQR`PFWJK[OM\SMbUI]ODUGDTFARCJ[KKbTK^RI\OHYMBSG>QD>OBF<@E<@FF;=I<K@9G;BL@ESGCPDIPFEUJCTI?SGRF=PCANE@LC>JA>F??G@BIA@I>>D;>C9@C:>D9LSFIXLFWJEVHCTFGUDDO>?F=?H==G;>H?I?;I>CK?BI:?HHOBGQEJVIL[MP_SQbUJ]RK\SP`XQd[L\RHWLITHEQDDQCBPDCMA?F;=E;?G=?H>CH=BH=AG?5CM@?L>BK>@J=CJIQEIYHJZIGUEFRCDQABL=GO?IVFM\N^k]CI?CB9=B7>F9@I=DPBHVHERCDNA@J=EL@EK@BI?>G=DG;EK@CMA>L>>N@@N?AMAAMABL@AH>@HCH?AL?EUDHZIIZKI[MN\QK]QG^TJbWOdXJ]OIWLIUIOUJNODGN@GVEO[MT]PX_R^eXnwjdma_m]k|ko‚pnƒsmus…{str‡x‚˜ˆž‘‘Ÿ”‘ •¢–“¤™“¢˜¡•‘¦™¤—‹ž“Š›’Š™’‰—‘…•ƒ”Šƒ•ˆ…—Š‰š‹œ“–œ–œ–Ž›”Ž™’“˜˜ Ÿš¢£›¢ šŸž™žžœ  Ÿ Ÿ¡£ž¡¥Ÿ¢¥¡ ¤ŸŸ£¡¡§ ¥ Ÿ©žž¦žž¤ŸŸ¥žŸ¤ž¡¥¡Ÿ¥¡ ¤  ¤¡ ¤ Ÿ£  ¤œŸ¥œŸ¤ ¥ ¥ ¥œ ¤  ¦¢£¨¡¢§ŸŸ¥¢¢¨££©¢¢¨¡¡§ ¢§ £¨ž¡¦Ÿ£¨¢¥©¡¤¨Ÿ£§¢¢¨ ¡¥¡¡¥¡¡¥ ¡¥¡¢¦¢¥©¡¤¨¡¤¨ž¡¦ž¡¦ž¡¥¡¥ ¢¦ ¤¥¡£© ¥ ¥ž¢¦› £š £Ÿ ¤žž¤¢ ¦ ž¤š›¡•›ž˜š¢˜›¡™œ¡˜› •˜‘”™’‘‚ˆƒs}up}ulvqv}zˆŒ€‡ƒhrkiwokzrm|tx‚z~ˆƒ‡†|„ƒ{ƒ‚}…‚p{xepliunkxnisg]fW]iV_l_aocZl^P`TJXSG^PG]QM`WObXRh\Tm_QgXI^PI\OJ[PIZOJZNJYLEWJK`WH]TM_UVcWPaTN_RG[MH\OH_PMdVTj^Yl`^mabmc]f\U^UZaXUVNOSIJTGJVGHTBHQDNQDKK?FHE8P_NNaOIVL-7:*67*32'40&53(<:1?=365+35+@E:DK@77-97-5804<16<098*7;/;C6=G7>I9BL<@J:I9:B38?/:A2;C69B79A32:-.3'03)/3(-1%0-$10$--!.,%.-$//$21#0/!.. //!.- 00"40'/*!/*!,(** ),!,* +),* .( ,',(,*"+) -)-&0'/$+%%$(&+&/.#-3&07,2<.8@3/07(.6,09,9C5ESEReWOeYE\N>UGD[MAYK@ZJ>WG>RB=P>8I7=J8>G86>04<,3<+3;*19(27(.2&0/%/0$.."//#33%22$04(48,05).0$)- /2'05%/4&-0&+/$/3%/0"/3$46'/2&/4'5;/;A6GK?AA661)/+#1/'11):7.51'3/$50%1+#0*%PaVSeXSeVObTO]OK\OJ\OT_U^j_fujfwlgwlg{oYsePk\Vk^Pl^Oh\LbVDVIFVJJUJFUIGZOLdXQgYZkZ[fSS\LQ]LM_LFXGEUHFPF?QDEUHKXJMZLKWHUeUXk^SgZI]PEYLASF=OB>LA=J?=F<=F;@H=>F;>H;@K>H>?M@AL@F?@G@@HABJBJTGF[NEZMCXJBUF@OAAL>?FJ>@I>AH?BJ@=I>>I>>D:AD;@F=@I>FQEDPDESGGWJDUG@LB@L?AK;?I9@I;?I<>HH<=E;G=AH=CI>EJ?CG<@D9AK?@I@9AI=BM>AK=BL?ENAAOABL?@J=AH;CKB@KA@L@CMAGREHYKGXFETD@L<@J>DNAERDGQEHSGMZLP\OLUIHMCKLGNPKPQLQTKJMDBE;?E:>D:BGBK>EO?HWGJZJK[JGWGIWGIVGNXGS^NScQS`RCI?@B9?F;EMACL?HREISD@M=BJ>CK>CI>CG<>B9@C;BD:CH=@I==J<@M?COABPEERFCOC@J>DMADL@AKAEPDFVEEWFFWGKYKJYKIZNI]QMaUReXSeXO_TKZMLTIKOCHQCDWFN[NU]PV`Sah[fnaak^frbk}luˆwu‹{uˆ|r…|s‰w}–‡…žŽ¡•¡˜Ž¢š“§–¨ š«¢–§ –¨ “©¡–¢ž— ”›–œ‘œ˜›–”Ž•—•¢ž—¤¡–¢Ÿ–ž›–žœ˜ž™žœ £œ ¥Ÿ £ž¢œ¡¤£¨¢¡§£¡¨Ÿ¡¦¢ §¡Ÿ¥£¢¨¢£¨Ÿ¢§£¡ª ¦¢¡ªŸž§Ÿ¤Ÿ¢§£¡¨£¡§¢ ¦  ¤¡ ¤  ¤ž ¦œŸ¤ ¥œŸ¤ž¡¦ž¢§¢£¨£¤ªŸ ¥Ÿ ¦¡¢¨£¤ª¢¢¨£¢©¢¥ª£¦«Ÿ¢§¡¥ª££©¤¥©¤¥©¡¤§ž¡¦ ¤¨¢£§¡¢¦  ¥¡¤¨¡¤¨¡¤¨ž¡§ž¡¦Ÿ¢¨ž¡¥ £§ £§ ¢ªž © £©Ÿ¢§ ¦œ ¥žž¤ž£žž¢ž¡œž£š¢›¤™›£š¢™¡™œ “–†Œ‡z€{r|vpztiso„‹‡‡†y€{nyrkznl{skysw{|†Šˆ}…†€‰‡~††r{wgsnhumn|pv‚v|„y^o_\l`Xf[SdVPaTP`XM`RL\QM]RPaXPfYRi]Xn`KcTKbTKbTJ_RMaURdVObVI_SK`VZla`qeRcVOaTPaTL`SLeWQk]_thbtibod_i__h^clbX`WQWMTZORZOKUHHNBFOBLNBHG;CF:DH:0=7-<6-;7.M??L=BOCITFHPCHM>AB4??/B=3A=2<:/<;0;<0;>29=19?2;D7AIAJ:;D7;E8AJ=GQDGQDFOB@L>8C68A5F9?H:01;00:.4=06C5?QEE^TEYLDWJGZKNbSI]N.3>-4;,7<.2;*39)58)/6'/6'.5&/6(.5(07*29)18)18)48,48+48,.3&-1%38+6<,18).7)3;-47*58)05&/5&.4$/2'4:-:A49:174,3.&4/'0/%.0&2.$1.$20%.,!.)!1+$M]OPaSQbUO`QSdVSeYQeX[j]]laash`qf_od\sgSobOj]Rh[Pi\OhZMbUHZLEUGGVHK`RNeXOh[QhZXiX[fVT]QNZJIZIFYGEWIESHAQEDRFNZOWeXSbVYj\Yj^OaTFZMFXKCSGBREBOCALA?L@>K>=I=:G:=I<H>>J>G=>IH?=FD;FKBCLBESGI[MF`QGaSD\M=QD@ODAMCDKD?I>=J>>J>?H=?C=@E;?J@>I>?E;@D:>D;@K>KUIGSGHSGHVKFVIBSH@OB>J=@I:AJ>?J>?L@ERFIUIEQECMAAL@BJA?F:DGK>BL@FMBHOCEJ??G<>F;@J?AI=AA;>@9AJ>BN>CL>BL?EOBAN@DMAAJ=AI;DK@CNBANAITFHTEK^LH[KDUFBOBCMADNBCPCGOFFRFJYKP\NJRGGJAGG?KJCTSNTWQFJBBG?BF<>B:?C<=E<@I=ENAHVHKYKN]ON]ON]ON]NU`OUcRRcRR`T@K>AI=FMCJSHFPCMWJITCBO>AK@CJ?CGD7:?4=?4;;/97,86,77,=>3DN>LVHCJAGLEMWKJNDBK?EOCHUGEQB=H8CJ>GK>GI=IK=>B37;-:7.<;1<;1=>2>A5=@4?E7;B59@59?2:=.==.<>1<;/86+::.8;07>3QTIJI?45.26.;A6?A7>?2:>2>C8DK@HN@GM>EOBFQDGUGN]PP^RIXKDSG>J>?H=EL@IPAEP13A56@47?31:/5DL==K=8C95>23>.3<,6<-5;,4<,08)/4)-4(,6'+7%.8(3=-6@03=-/:)09*27(5:+5:*/6'/7'4;,6;,3<,7A17C26<-36(-6&+4$+4$/7(3;+-4%//&21'61(0.#11',1%0.&00&/0$./#.*!1)"IXHL\LM_NOaPTiZVnaSl_Ypb]thWqeYk`ZmaZrePm`Kh\OcXSj\Uh[UhYSfWPaSL\MLdVLfWIdVMdWO`SUaPQ^QO\MM\JGXFDWHDXLFVKETIHVKSaUYj^Vh[TeVM_QFYKEXIBQDCPBBMABOB@OB@QCASB=P?=M=?JBOCFVGFVGBSE?PC>MC?NB>F@>G<:D88A6;B8?C:=F;?J>>M@CKEDPHDUJDUIGVJAM@J?;I==B<@A:?F?>E=?A<:B9@J>LVKKVKGSGHSHHWJGXNBRE>K>?L>@L@?J?APEESGDPECMA?H<@H=@E;CE:DG8JO@OYKO]OOaTTeZVg[Ug]JZQN[UQ`VVcYVaYU_UR_RIYIDID>B=@DBH=?H>?I>@HAJ>DP?EO@BL?AK?CPBCNA?I;DK>HPEHTFGTDLWGM[HH\HGYKEUHCOCDODCMCALBHQGJWKP^QO[NJRGEG?KH?ROGWXOZZUEHC@D?FG>CD>AD?C8?F;@J>AK>DM@FNACSGCTDBUC@S@DVGJZLJ]QLaRKaPGYIFVGN[MPcONbPL^OO^O[gYgrcisdXdULYKIQGMTIJVKHZLLZMQ]OT]PT^QU_SVbX_ocl~qxŠ}{Œ€~Žƒ†”Š‹™“” žœ¢£ž¥¥›¥¥ž¤¥ž£¥ž¢¥œŸ¢œ¡¥¡¥¢¤›Ÿ¢›Ÿ£ £œ¢¢œ¤£ž£§ž¢¦ £§Ÿ¢¦£¤¨£¤¨¡¤¨Ÿ¡¥Ÿ ¤¡¢¦££¤££¥¡¤ª¡¤©Ÿ¢§ž ¨ ¨Ÿ¡ªž¡¦¢£¨ŸŸ¥ ¡¥¢¦ª£ª«§¤­¦¥®¡¤©¤§¬£§¬¢§¬££­¡£« £¨ £¨¢¥© £¥¢¥ª ¤¨ž¢§¢¥ª£¦«¡¤©¡¤©£¥ª£§¬ £¨£¦«¡¥ª¢¡§¡ ¦£¥«£¥«£¦«£§¬¥¤­££©¡¢¥Ÿ¢¥¡¤§Ÿ¢¦ £§ž¡¥ £§££§¡¡¥£¤¨ ¢ªŸ¢¨¡¤© £¨¡¤©¢¥¨¡¤«Ÿ¢§ž¢¦ž¡¦¢£§ ¡¥œž¦ž¡¥ ¥¦ ¥§ž£§Ÿ¢©£¡§Ÿ ¦ ¤¨Ÿ¤¥œ¡¡“˜—†Ž‹†Ž‹ˆ…{‚~„}„u€|t€xs€utvt~z{ƒ‚‡„Ї~‡„{„„Žˆ‚„€‰twl}phynizrgwp]{p[tmZqg[qaWm]Vk]MeWKfZFi[MoaMjZRjZTh]QeZShXRgYObUSg[Vm^[qc]sg[pd]oc]ob[rd_uh`phWlbZnbZrd`seesf_i]\eYcpe_odTcVS`TQ_SKZMCNACF;?H8AE6FJF7;:2;:/<<3<@4<@4>D8?E;?E<GO>GQ;NK?HH=9;/78.98.64*11&44%22"22'44'45$57(35&25&54&23'10%/-"0.#0.".,"1.$0,!1-#.,!/-"--!.."+, 1-.+.+"1/*01*,/%0,".,"-,"1/%+,")1&01(45+37,37,39,6=01@46@46<1-5*6A:s‚}gwl=L?@L<36=07=.8?07=.2=-09,07-.4)-8)-9)17(7>.7>/5;,08(17(27(27(38(4;+7>0:C3;?16?0;F68D57>.37(+6&+5%-7&/9)/9)08)02'32'31&10$14%.4&04+.1',0$-.".+"0)"ESGFUGLXHT_NSfWVn^SrcNpaRrdUsfRm]Pj[Ul`Qg[McVK`SPaRQ`SXh\[n^UlYQmWPgUJcRLdVK`SL]PJVFGWFGVDEUDDWFJ[NQaVPbYI\OFXJQcSUhXTgXO_SJ\NDZKBWHASE@NCCQCCSFH[II^MCYG>UC>QC?PB>K==G:BL?HREGVKKZOCTI@RG=QF>SFCNB>I=G;=I=C=>F>>F;DKECMH?PH>QGESHBL?@J>BMBALBCLC?E>=CF=@E<=B;;@:CRBJXJHQDENAMWJJ[JGUEERCBO>FRBKVFEWGCTFDTE>I=>HDQBBRDDTCL[MGTFCN@FPDKSJNTKKREIOBFK?GKAKQGCG@@G;BI=FOAHQBKTDJQBEN@BN@@MA>L@?H=DI@KUEOYKLXKMZLJZHJ\IC[ICWHAREAOCAOBESELVINXMT\TSZRJSHCK?EE?DGAX`WMVLEJAHJ@GRFEMB?G<@H>DNCJXLL\KJWHLXLJXLL^PNbSPbPMaNN`MQ_NJWHBOBHPGJSHLUHIREFOBCM@?G<>F;>B7=A6>B8=C9?C7=E8@IDG;HI>IJ@KLCIK@BD:I;4>=0@?1?>0A?6DC;=@4;;2>>2;>/:@0;E4?H?=E;G6EI9EI=@@4::08;058.//$2/&01&24&53%52$43&73*44)25)25*53*4.'00$11"23#22"..20%1. 1.#0.$0.$/,!.+0.$2,#/*"20(45*-,!0+#/-#.."-/#-0&+/&30&22(56,/4)39/NWKQTK8>445,41,33.=FABMC6=1A2;C68C7:D77A43>11:-:?2>?27:*4>-2<-4:+27(17&08)6?2:E93>309-3=-59*23&98-87+7=,:D2=B3;B38C36D44=16>13?-0=*.:&0;)4<+49*23"24%/1"03#/3#25&*7#4<-69-0-#/+!-)DSGFVIFVGJWGI\MNfVUrcTrcRm_VnaUlZQhXQdWO_TO`TN^RN]PO]QRbVZm_Vm]Tn]Rn\JfVJfXKdVL_QIXIISCGQ@FR@GUCN[MXeZTi^NaUK^OQcSObSK^PM]PK^OI^NFZKFXIDSGIUIDREGVJHZLFZICYIBWJBTGBQE@MABOCHVIHXML\QJZOEVKDWKBTHBOB?K?=I=:G;:E;;FJA?J>7E98C8>E>?F??G?>H>?JC@MF=OH@RI?LA@J=BMCHPGDLBBJ@=D>@I@FUJHUJ?N?BQDEXJD]MCYK@SI8GAB;?C;<@7>B9=B9=D;AK>@NAESEJUGJUFIXIJYJKYJIUFDRCKVGOZKJYKIWIFRDBJ?>E:AGBJ?FOCITGGSEJXJU`VVaWGOFV]VV\W]b\T^THQGGODLSIQZPBMBCJ?ENBGPDJTGKTFLTFGRAEQBAPADRDAK?GODLWHMZKKYKJXJGZGK^KE\JEYHDREAK@BL@DNBIRGKTIPXPMTLJRGEKACB=FJ@PXNJRHIMDLNDHRGGODDLA@H=AL@LYMN^MJYIMZMHVJM_QL`RM]NKZILZIQ\LISEDMABKAFODJPCGM@AJ=?H=>FA7?B7>A6DM@DRDBRDFSCJXHObPNeXPk\VocPcVRcVTfUTdXQcVTeX\k^grewt\j[VdV[eWU_RPXKNXKMYLO]ON]OSaST`RYbUYaV\gZhwk„‹˜’—¡Ÿ›¡ œ£¢ž¢£¡¥¡£§¥¤ª¡¤©¡£©  ¦¡¡§£¢¨£¡§  ¦¡¡§¡¡§¢¢¨¢¢¨££©¥¤¨¡¢¦¡¢¦¢¢¦¤¥©¤§«££§¢£§££§££§¦¦ª§§«¢¥ª¤¦ª§§«¥¥«¥¥«¥£©¤¥ª¥¤ª¦¥¬¦¥«¥§¬¥ª®¨¦¯§§¬¥§¬¤§«£¦«¡¤¬¥¥«¥¥ª£¤¨££§¦¥ª§¥«¤¥«¥¥«¦§«¢¥©¢¥©¢¦¨¥©©¤¨ª¢§ª¢¦ª¤§­¤¥¬£¦«¥¨­¨«°¦ª®£¨¬¢§ª£§­ £ª£¢«§¥®¦¨¬£§ª£¦­¢¥«£¦«£¦«¤§«¤§«§¦ª¤¦ª¦§«¥§ª£¦ª¢¥ª£¦§¥§¬¤¤¬¡¡«ž ¦£¥©¢¢¨¤§¬£¦ª¢¥©¤§« ¥©¡¥¦¤§«¤©¬Ÿ¤§Ÿ¥¥š¡ ›¢¡“›˜‡s{u‚‹…|†~Š‚xƒ|~ˆ„€‹ˆŠˆƒ•”–”ƒŒ‰{„x~ˆ’•ƒ‡x…|otm~uj|tf|pd|pbzmayl[thVpcRodSn`Sk_XnbWpbRm_Zpdbvim~rj{p]mdYlb[sml€zwˆxˆy‹ƒpƒ|dwjj|qk|sj{rkzpcuhlxlr~p_j^O[OOXLV_TZcYXdZP\PHSGDK@EJ=FH7CF6EH:GI;BF8BG8CG=CJ>BK=?H;>E7=D4<=258,:9.98-77*88):5+65*<:1<<2::.54);;/;;.?>1:9+;9/>=4AD9AD9>A6I8DJ?BG2:;-89+79*9:*8:*42(32(31'43)22(44*86*75)77+<>2@D9?3:9/6:/47-43)72).0%15%97)73&75*55)66*45&22%44)0/%0/#21#43%33$31#3/#2."0-#1/%10%0,!-*-+0* /+"0.&..%.,".-#21&//"*- -/#/1(21'21'44*57-59.BD9EF<47,12)50*//*)/)2:1:C67?2;C5:B6.;F4BF8?G8>I85A44>18@36@12=-4>-2;*39)35'/2!14$26%16$18&4<+;F4@H857+,+",+!,+BTGCUHDVHGVFGWKOeWUn`WqcXnaZm_Xn[UkZQeXOcWQbWRaUTaUP]QQ_SUgYXoaWqbVpbMhZIdVOfXSfWO^PKUEGP?FQ@FR@HUFO^POgYQj\Uh[Ui[PdWDZNHZMIZMGXKFWJFWJFVIKUKDOE?MB@PB@QDGWJ@WKAUIAQFCQFANCGUIIZOL\QJZOHXMKXNDRFANA?K?H<9G;7B89C;:E==H@AMB>OF>QH>SJ@QHBJ@@NCDLCAE<@E<@J@BQGFWJ?OB>L@BSEBVG=UECTH>NC9E=AIB>H?::@:AC<>A7>B9@F;?F<;C9;C9>A8>A;>F@G=GPEKUGIVFEVHN`RReYSf^WgbUeaOf\Oc[QcWUdYS]SIQGFJAFMCFODHQEITHMXK[c]OWPSZVjolgljgkj\d]PVPHNEMTIV^RISFINEFODFPDIUIHREMVIMXHKXFFVEEVDDP@HRCJYHKZKFXJHYKGZHH\II^KIZJFQE@G>@E?H?HMGHMGJOGAF=@B9IMDCLBHQFJODHK@HPEFNCFNCBJ?CM@EPCKZKJZKM[PGYKK\NJ]MLWJJTHJTFKTGFMBBH=GMDFL@DH=DH<@F;@G;DI@BF=AB8CD:AD8>C7CB8BD:@F;@H=?G<@H=AH=EQCAO@HREMZJO`OQdWTl^YpdUfYUcVUgVVcXUdW[j^eqejvieocVfZSbUYfXW`TWaTU_RQ^PR_QQ_PS_RV_R]gZ_i\_j]kym{ˆ‘›˜›¡¢Ÿ£¤œ¡¡Ÿ ¤Ÿ ¤¢¢¦£¢¨¢£¨¢¢¨¡¡§££©¢¢¨¢£©££©¢¡§££©¤¤ª££©£¢©¥¦ª¢£§¢£§¢¥©¢¥©¤§«£¥©¢¥©£§ª£¦ª¦¨¬¤¦ª¢¥©¥¨¬£¦ª££©££©¢¢¨¢¥ª¢¥ª £¨¡¤©£¦«¤§¬§¦¯¦¦¬¥¨¬¥¨¬¤§«£¦­¤§¬¥§¬¥¦ª¤¥©¦¥ª©¦¬¥¥«¦¦¬¤£©£¦ª¢¥©£§«¥©©¥©ª¦©­¤§¬¤§­¤¦®¤§¬¥¨¬¨«¯§ª®¦©­¥¨¬£§ª¤§¬¦§°¥§¯¤§«¤§«¦¨°¦¨°¥§­¦©®¦¨­¢¦«§¦ª¥§«©ª®¦¨¬£¦ª¤§«¢¥©£¦ª£¥­£¥­ £©¡¤¨¦¨©¨©¬¥¦ª£¦ª¥¨­¥¨¬¥©«¦©­¤¨«¤§«£§¨£©¨ž¦£•“…ŒŠˆŠ†…€‡‘‹Œ“‘™”––‡ŽŒ””˜¡™•ƒŒ‰w€~}†ƒŠ“’–”Š“Žz…}r€xqxnvhzocukbtigyn_thUi]RmcQk_Rj^]ti]viXrf\tjdzpn‚yl~tm}uk|smƒ~yŒˆƒ‘Œ†’y…o}wn~uqxx„~}‹„y†l{rr}sq|r]j]O[ONZNVbUPZQLUKHRFEMBAH>AG;DD4CC5CE8DHBJ<=G:@L;HJ?EG;CE9?A5;;/77,9<08<-69*6:,5;)38(33(43'22(33)01'34*;7,63(32(54*12)57-66,><2GGG:CG;>=176,69/>A6<:/2/%24)7:+54&51&75+826D69H:?I;DHG:AK>:C65:.46*74&01%,0%13(58,09*3=-5?04>13=01<-1<+3=-0:+18+18+7A0>K8EL=AK:=G9:D78@3:A59B66?23=-5<,:=/88,/4%49*5:*5=-7>/6@09B15=,/1%,, -,"+,"HYLJ\OJ[NL\NR_SWi\Vm`WoaWl_\n`Xq^Vp_Tn`Qj\RgZQdWXbUWbTYfZ_qd_uiXshWpdOgZLcUReVZi[]hZUbRJWGGVDI[HPdTSj[Rl^Sk]Um_Sg\Pf[KdVK]PHZLDUHFVIKXMN[OPZQDOE?J@>LA?OB?QD>UI@UIBTICSGETIIYNM^SP_TN^SIWLFSIFQGANAAMA?K@?K@ALB;F<I>>IACNF?I>=F<;G<:E<9C<7A;RI@SH?PDEMCCLCBH?@A8@B9>H>AQFDQF;I=>K?EVIEXI=SD?MA>H>9@D>??8><4>A8AI>@J>=F<@:>B;@EDLCBJ@IQGHQFMWKcjddkhuy{x|}jnpkpniliOQKMNFMMEORGKREFODGPDIUIIUIIWILXJLYHKZHGXGGTBCP>FR@IXHJYJHXJGXJGZHI\IK^KP`QISG?G=?D:@G;?D;AECI@EJAEK@DJ?DH=BH>CI>DLAAI>BJ?GPDGRDLYKM[OJXLIWIFUEJSHHREJSEHQDHQELTIIODCGEG=CE9BE9@E8CC9AD:@F<>F;@H>@H=EL@EODCPCISFN[MO`QTgZTk]Qh\ReXTeXSeTUdX^l`htggsgdqd`nbXl_Zj][g\[eX[eYZdWUbTUbTWaTT^QV`Sak^cmaerdo|pƒŽ†‘˜—œŸ£Ÿ¡¢Ÿ ¤Ÿ ¤ ¡¥££§¤¢¨ ¡§  ¦¢¢¨££©¥¥«¥¥«¤§¬¤§¬¤§¬¤§¬£¦«£¦«§§«¥¦ª£¤¨¤¨¬¦©­¦©­£¦ª¥¨¬£¦ª¤¦ª¦©­¤§«¥¨¬¤¦ª¢¥©¥¥«££©££©¡¥ª¢¥ª£¦«£¦«£¥ª¥§¬§¦¯§¦¬¥¨¬§ª®¦©­¥¨¯¨«¯¥©­¥¦ª¦§«§§¬§§­£¦«¢¦«¤¨¬§¦¬§§­¦¥¬¦ª«¦ªª¥¨¬¥¨­¥§­¦©¯¦©­§ª®¦©­¦©­¦©­§ª®¨©­§ª¯§ª¯¦ª®ª­²ª­°ª¬´§ª°¥¨­¨«°§ª¯£§ª¨§ªª«¯ª¬¯¥§ª£§ª¥¨¬¤¨«¡¥©¦¨­¦©®¥¨¬¤§«ª¬­©ª­¥¦ª¦¨­¥¨­¥¨­¥©«¥¨¬£¦ª£¦ª¤¨¨¥©©›¢Ÿ‡Ž‹‡Ž‹†‡y€{{‚}˜••š˜˜œœ™ž•š™—Ÿž™¡žŽ—”…‹|†‚€ˆ†ˆ“‘Іt€yqwqxq‚yn€satf^pc\oaVgZWh\QiaSk`[se`xk\ukayqe}ui€xkzk€xr„}yŠƒˆ“‘—•ˆ…Œ‰ˆ‚w~yn}uy‡‹“‘’š˜…Š{‡€{…~w‚y\g^S^RS_SWdWKULCLBFNC@H=CG=CJ=DE9BB8BC:DEEI=EB8@B6?C7=D7AH:>E6;?3;=1>>0<<.<;,88)75+87,:;1<=388/:90:9,:;/9<0>@4CD7FF7KLBPRGKPEAJ=>G:>H@4=?3;;.:A753*0-#89/;=197,3.%85-8;09:-:8)97(48(,5'54(42'1/$/-"0,!0,!1,"0-#0-%.+#/+!-*21%2+"1-$?;7>>60-$,/$.2$26&22$43'86+64)75*53&33'44(12%20%0.#0+"5.$3/&-2'04(2<06D8>NAENCFK<>F9>G:@J==E99>169,35'-3&*2&,3'0:,/?/1<+3=-5>15@22<,.<*/=-1<-0:.3<.7B0>J8>H9@I=CM@@I<:@5?C8;B8=F97@26@0F<>G=?J??J?=G=?G=?F=@I@=G@=G@OD:J?=J@BJDCF@>>9=?6;?6;C:BNBHZMHZN>TF@L@>G<C5=92>@6@J>COBAOB:F<;C;AC=?E>AMCFXKGWJEUEK\KLXKNYLMWKHRFIQFIRFHOFHOEFH@AE;ED:CC9@B:>A9?D;CH>FMCFMBEQDJZMRdWUf[UfZUf[Vf[We\Ze]`ibYeZN[OHPJELFDLDHQHIRHQZPekfx~|~…‚†svy\b`_a]ZZUTRMJKALNEMRGJSGLVJJWJKZLK[KL[KN]NL\KKXGHUDJWFKYGJZIKZKHWIIWIIWFL[JRcSdpdNYLAI>?ID9?D;AF=AGBJ?FLAEJ?DNAGRFIVJGTHFRCGRAITGKVIHTEGTCP]MMYIKQGDK>DI=FK?FKAGNDGQCFOAGN@GMACI=@G;AH>BJ@DMCCKA@I?AF=CLABOCBPEKXIN\NNaRPcWNfXIaUOcVSeWTjXWh\_naaocdrf_pccviczncuj]i]ZdX\fYXeVVcUXcVXaTV_RWaTcm`x…xlylt~t~‰’—–¢£¦¡¡¦ž ¤ž ¤ ¢¥£¥©¢¥¨£¢©¢¢¨¦¦¬§§­¤¦«£§«¤§¬§ª¯¦©®¥¨­¥¨­£¦«¥¦ª¤§«¤§¬¥¨¬¦©­¥«®¤§«¥¨¬¤§«¦¨¬¨«¯¦©­¤©¬¥¨¬¤§«£§¬£¦«¤¤ª¤¤ª¢¤©¢¥ª£¦«¦¥«¨¦¬§¦¯§§­¥¨¬¥¨¬¥¨­¥¨°¨«°¦©­¥©­¦¨¬¦§¬¦¦¬¤§«¤§¬¦ª®¨¨®§§¯¥¤®¥¨¬¥§¬©©¬ªª®¨ª¯¨«¯¨¬°¨«°¨ª®ª«¯¨¨®¨§­©««ª¬¯¨«°§«°ª­²©¬°§ª¯§ª¯§ª­¨«®§ª­§«¬«ª¬©¬¬©«¬§ªª¦««©­®¦¨­¥§¬§©­¥¦ª¦¨«¨«¬­«±©©¯¦¨¬©ª®©©®¦¨­¦ª«¦©­¤§«¤¦ª£¥¦¡£¤—›˜’Ž‚‡…{‚~pxt{‚ˆ“‘“™™Ÿ¡¢¡££¢¢š¢¢£¡–œšŒ“ƒŠ‡~„‚‰…„‹‹xƒ~qvp€tpumsj|odwjdwjZl_UgYUgZZldcwle{m_vh_vmm‚}yˆ…„“‘…•’|Œ†~Œ†~Š„–š™Œ‘ƒ…€yzpxon~yŠ’˜–”——‘–”‰‚ˆƒ}„}p{q^i_]i[TcSISJKTJFLAFK@CH=BIA7BC9DE9CD8@A7@B7;B5;C6FM??G7<@4>B4>B2<C5=A1;@/9<07;,59*9;,77'43#45'44(12%10&31(31)52+53+44*66,56,66,86)64&88(;<->B3CI;DO=AM=@N?BPBKWGFSBCE9:9-<9078.89/54*51(9:/<>2;8-2,$73-;9/;:/8:-8:+47+16*68)45*43)0.$-,"// 3.$/+".+#/,$3/&2/$/-&1*#0+&73.00&42(78-57,58+66)55)65,96+53(54)45)14(02'20$10$1."5/$2/$.3'16*6>3CNBCNDDL>BH99A19C3I<@J;;A66:08<19?6:B62=-/<+5A03=/4>.6@/7?/5?/5C27J79E63=-/5%-0!.-#--$K[PN]RP_TVbV]_VVaVVk]XteVtdPn]Wj\Sh[PgZUk[]o]hvcx~mv~mo{iexi\uhYukTxmWxkYugYscVk]SfYSbWS_SP]OL\NJ_RHbVJfYIdYLdZKcXIcUKgUFaQBXIL@F<>H=@K@@M@>G=;D:AE==C::E>:E>;D>=E>;HB:IA8I<7D99D;;B=D?:=;6>A9:A7>E:?F:CE=CI?EOEN]QI\O@UG@J@@C8>B89G::G;=E9?<5?;3@@8?K>AOB;M?9I>;D;>A<>E;AMCDVIEVIKYKLZKOZNMXLKUIHQFGODFNCGNGGMECH?@C:A@6?>4?C8=@6=@7?D;BG?EJBFPFKXMPbUQcUSgXWj\[f\XaX^d_irjhuiZj\MWP@KBDMFMVOMWMT^TqvoˆŠˆ‹Ž‘…ˆ}€‚gkkdjc_d^TXSLQHKQGJRIMVIP[NKZJGXHGWFM[KK[MIYJHVHJWGKWGM[JKXHHUGGTFDRDIWEN[JZeYishMWKAJ?GRCFSBGI?EF;@E6AE7@F:?E:BG>>D9AF;DI=BJ=AJDM@IRFITHKUJJTFOWGHVJQ`QN^LQaOPbNK\KNVJKSFJOCJOCJQGLTKJWEITBOXKKTFDKACKACMCHSIHSJDNDBJ@BH?FPDBQDEUHKXLL\ML`PQcVNgYLgZQgZQeWQhVXi]Zk^[j]^naatgmsn†|s…yjvk_i]YeWXgWVdVYdWU_QU]PT]Qlvjvwlwms~sz‚|“‘  £¡£¨Ÿ£¨¡¤©£¦«¥¨¬¥©­¨¥«¤£©§§­¦¦¬£§¬¤§¬¦©¯¦©¯¤§¬¥©­¤§¬£§¬§§«£¦ª¢¥©£¦ª£¨¬¤ª¬¢§ª¡§ª¢§ª¦ª­¥ª­¦«®¥«®¦«®§«®¤§¬¤¨­¤¤ª¦¥«¤£ª£¦«¤¤ª¨¦¬©¥«¨¦¯©¨®¥¨¬§ª®¨«°¥¨°¦©­§ª®§ª­¤§«§§¬¨§®§ª®¥¨­¦ª¯¨§¯¨§°§¦®¥¨¯¦¨®®«²­¬°©¬®¦ª«¦ª«¦©­©ª®©ª®©¨¯¨§¬««¬¨«­¥©®§¬°©¬°¨«¯¥©ª¦ª«¤©©¤¨©§««§¬«ª©«¥§¨¨ª«§©ª¥ª«©¬®¨§®¦¦«¨©­¦¨ª§©ª§©ª­«±©§­¦§«©ª®¨©«£§¨¥ª«¨«¯¦©­¢¤§ ¢£š•–’Ž‹…u|yq{xz„†’’”œœž¡¡ £¤Ÿ¤¥œ££Ÿ¤¥š  •”„‹ˆxz{„}{„‚y„€u„zr„wr„xlƒue|od{mi}p[oaWj]Yk__ngfxnfyli}q|އ”˜––››—–‡Œ…ƒ‘–“’–•‹’Žy‚}{†~s€tn{qp‚}‹•™š™›œ™›œ’ˆ‹‡‚p{sepfboc[j[U_UPYNELACGB6BD6EF6CC3@C8>B79B5:C7@G9>E5>B6@D68<-=<0=81<5185-66-78.6;079-68,87(67*6<0;A4IK,8<.69+9:,<;,84%62#33%44'31&1/%2-%2-&21(22*24*35+26,24)74+30'32&77+7<1=D:;K:<1@>3:<288.95,;7-78.<>275*5/'41+?9298.16*4;.5:.58-59+56,67,33)43(33%4.&0,#0-%2/'84,74*1,(1(%3-(/+&12'42&:90<;199-57+22)23*73)52'00$02&-2&-2&21%00$10%3-"0.#.3%28,3:.:@7CI=CK.18)27(35&17'37(78*6:+5A/8D2>I8;C37A18D38E4>K<228.48.69/8=33:/3?.6F46E42B07C4:C6;D68C5:J<@VGCSB@L;7?.14%0/$/,$N]RQ^ST`UTaX\`VY`V\e\]mb]qeUnaWl_Ui\Sh[Ym^bk[…€s•‹y†uuykbsfUrdXwiY}lVyiWufYseUobJdWI^SP`RTcQOaOK]MIXKIZLH]NK^QN^RL_RKdXH`RBWI@PC@L@>G;>E:@H?BKBEQFHWKM`SJ\PL^QJZLFUHCQFCQIDSNJVQGUOESLCQIBNFBKC>GD?H@BK@?J>>J?;HB>OA;I=:E>:E=:E;:E;AC>?G@@PH=PH?PHK>=H<=I==F<=E=@G@@E=5F<9E;8E:AI=DMBEPDIUIIVIFRD?F3A@6>G>BKC?J@=H>>G=BI?>K>?OBCSGBRDGUGMWJHZGHWHEQEFQGDMCDLACLBDLBAG>>C:>@7@A8>A8A@7A@6CA7BFE;AC:AE;BH>F9?D5AD5CC5CA4GJ:CF7>C4@E8@E9:A4?A4=>/>>,<=.@<3?94<@/;@3:=1:;/:9,;;+=:0:8-:9+A@2HG9NM?NN?AE:?GEN?DWDIWEJTCDH8>>2>;2;;,;:,;9.98+77'66$52$21#66(22$00"21#61&43'17+6<136+86,64,33*23)15*49.;A6?K:?H8>D4:>/AG8CN=BG8:?/818A6E8=C6?@476+45)35&67&68(5:+6?0:F1>N==OAMA?J>=G;;C8=G<:G=:I>M]RUh^I^TGWKEUICPDERFESICRIESMBQJBQI?OG>KC;H?>HC>F>>F:=F9;C9=H>AOB?LA?KB>IA=H?:H@AXOC[R?WM>TJAMB>J>BKAAI??F<=D96?57<3;>5<>6F<>F<CLACNCKVKJVKDOD?G=IRHMUKGPF@J@DNE>NA=G<=B:>@6BB8@F@BJCAKA>I?AJ@EMCCNBCPDDPE@N@EOBGQDCRACSDHTGEPFCLBAJ?AH?CH?BF=?A9?@7?@7>@;BB;@>7?@6?E;CLABOACLAFMFHOIN\TUg_]ibZa\UXTehejrpvƒQXQ?@;OLJ]_YGJDOPF]]Xtsq€€€„†…‚‡‚„‹‚z‡€jvo^jaXbXR]RYcX`g\]eXU^PEN@EMBDJAEPCGSEIUGIUGJUHIUGGPEFPDHRFFQEDPCFRDLTHMXKFUGHYKN[ONXNGPDDJ?DH=BFBG=BGC4BF:?F99A4;>2?/>;1>:3:=0;<0::/;:/;;/;;.;6220&65+8:09>46;26:/59-49+.6*/7+58+44*0.&2/(32&33#6/*0,%.,#//&44*34*89-89,65)53)66,44)74'74*20'1/'32(54)76)64(64)34'11%32(47)38*3:-7A2=E7CJ/9@3:C7=H8?P>AUDAN>;F57D45F7=N>;L<@N?=H97?25A46G99J<.31%0.$/.$P`VOaVRcXScZTd]T_VUYP]\RbaWhgZ[h\WbVXeVal\vvg’…wŸy„sotd\qcRqdSreQrcOm^Ql]Rl^WpbLgYScVdnbbp`TfTMaSJ\OKYIHZIETFFQDEOC@NA@K@@L@BL@AK?>F;=F:>I>:I=ARGLaXWkdD[RETK@NCAMBDQCAPC@PC>ME;JB:KB=NCG=@H;>C7:@6@E;=H;@J?BLD>IA?G?;D:=F<;J?@WK=XJ>XL=VJBMF=E>?G=@F<=B7=A69@77:1>=4?>6:@:7D<=F<;B8=E;>FI?AMCESHCQC?L?BKA>F<=@:@BBL?DL?AN@DRCEREDNBBL@@J>AFA7?@6@B8<@:>@:>@:?A:?FAI?BJ@@H>AI>?G;BJ?CL?CL?DL@BM=AK?AJ=AI>BI>CLAEQCMZLR_QWeYYg[Vh[VgYRcUScUXcVgn`xzkv{losd[bST]MLXJQ^QWdTQ^QKXJHUGJUIKTHHRFIUIIVJJWLHSHLUIJXLO]QQ_SM]OXeWZgYUh\Ti\XpbZseXncXm`Ul^Vi\SgZWmbcvn|‰‚›šŒ•”Œ”’y…}iwl^o_ak`\g[WcWUaUYbV\dY]f\irhoxnv}w’–ššž£¢¢¨¤¥©¥¦ª¤¨©¤©©¦§«¨©­¦§«¨§«¨§«¨§«¦¨«§§«¨¦¬©§­¤¦«¤§®§¥«§¥«©§­§¥«©§­©§­©©­©¨­©¨¬©¨¬©©­§¨¬¨¨®¨©¯§¨¬©ª®©«¯ªª®¥¨­©¨®¨¦¬©§­©©¯¦ª¯ª©­¬«¯«ª¯ª©­¨§«©¨¬ª©«¨§©©¨«¨§©©¨ª§¦¨ª©®­¬°©©­§¨¬¥¨¬¢¥©£¤¨§§¬¨©­©ª®¨©­§¨¬§ª¯©¬±§ª®§ª®¨«¯§ª®¨©­©«¯§¨¬§¨«¦§«§§ª¦§«¥¦ª¦§«¦§«§¨¬¤¥©§¨¬§¨¬¥¦ª¡¢¦£¤¨¤£¨¢¤¬¤¥©¥¦¨¦¨©¨¨«¦¦ª¦§«¦§«¤¤¨££¨¦§«¥¥©¢£§§§¬¢¦§ž¢¡‹Œˆ‹‰Œ“’”œ›“›š‘™˜Ž”“•”Ž‘’““”“”šžž¡¢  ¡–››Ž•’Ž‘”™•—•š˜˜¢ Œ–‘„Žˆ~‹†w…x„€nyUjabzpd{rdzrd}ri‚vo…yu‡~Œ—•˜žžœžœ—𙂆…††œ¡¢šŸŸ’››Šˆs~{~Š„ˆ„Œ‚‹‹’‘–›š—™™’—–—›“š–owobj`SXOWXOJH?HHAGG=OLBRRCPRDMRCPUILPFEJ?@F:=D6>F6>D7E8>D7=A2=?/??1>=298/::.77,:9086.<;0<=0>=3@@3==1==0??0>?0BC5==286-:7/;<1:;189/<=2<>19;.98.64*12(65+54*3/&63(34(6:.;B7?F<39.86/96/56,66,47-59-7=0>A6KL?KJ>18?29@358,46*43)0.$3.%/,$-+"11)=;185,4.%A?588/8;27;29=38<059.28+3;-68-89/64,53)64'86&62)31'23'47+15)/3(55'31'20%20&42(53*62'61'31'53)43(66+77)66)97,86,22',-#5<+8@.7@0:D4AG8EL=BI:>F6;D6:A6:@5;=45>25=19B5:C6F;>J3@I@@HB@LA;I<6D89F::I:5D6:<-11$0.#1/$/-$.,"PaVTbWXdYZd\W_VXZRYYO\[P^`S_dUV`SWaRVaQbl[rra–‡wzŽ…spxiYqcPobNj]Oj]Pk\NgYUk]Um^KbTQaTdobjxjXk\OhYNdVM]OI[NHYKISFEO?CO>CL@DLABJ?DL@BK?@H=DPBIYLFYNSh`Qi`G[TFULERFCPBBOA@M??QCAOD=LA:J?KA=F:=D9>B6=A6>B7?C9>E9BJ?ALD?JB>E=>F@PE@QF5:>35;39;2<:2=?7B::C8=FCK>BMAERDGQDHRFDNAAJ@AF;>C8>B7>B7>C8<@5:?6;@8DRBBSDEWJP^V`jgY`[MVOFMGAJ@AI?@H=AI>CJ?ENAFOBENABK?BN>DN?AL?BL?AK?HQFKXJKYKO^QWeYVeYZh\UfYRcVUdWZeXiqcwyj|‚sfl\XaTR\NNZLMZLWdVS`SKWJFRFNZNJWKISEHVHIXIN]ON\NLYJK\OQaTQ`RT`RWeWYgYSgXUj[\qc\rdYobVj^Sj\ReXTfZZpebwm€Ž‡•˜’–™’—–‚‰„mxndufgrfal`YfYWcWYbV\dW\dZbk_kshv}s„€ŠŒ™šŸ¢£§¤¥©¥§ª§¨©¥§§ª¨­ª¨¬©¨¬©¨¬©¨¬­¬°¨¨¬¨§«¨§«§¦¬¤¥ª£¦ª©§ª¨¤©©¥©¨¤©¬¨¬ª¦«ª¦«¬§­ª©­¬ª¯¨¨¬§¨¬§¨¬ª«¯©ª®©ª®©ª®¨©­¦¦¬¨¨­¨§¬©§­«ª°§§­«ª®ª©­ª©­©¨¬©©­ª©­©¨ªª©¬©¨ªª©«§§©¨§©ªª®¨§«§¨¬§¨¬¦©­¥¨¬¥¥ªª«¯ª«°¨©®©ª¯©ª®¨¬±¦©®¦©®©¬°¨ª¯¥¨¬¨¨®¨©­©ª®ª«¯©ª®¦¦¬¦§«¥¦ª§¨¬¥¦ª¥¦ª¤¥©¤¨¬¥¨¬¤§«£¦ª£¦ª£¦ª¦¨°¤§«¥§«¨¨¬¦§«¥§ª¤¦ª¤§«Ÿ£§¡¤¨¥¨¬¤§«¤§«¢¦ª¢¥¦ŸŸ–””š—™  ¤¤¢£•™š”••𛕗—”—˜”•–››Ÿ¢£¤¦§¡¡¦›¡ ““–™—œ  ˜žŸ˜¡ š¡Ÿ•œ™Œ•’~ˆ……‘„w†ƒsˆ€m†}j‚zmƒzo†|oˆ|q†z{Œ„›˜šŸŸ›ž“——v}{—˜œ££Ÿ¢¤—¡ …Ž…Žˆ”‹–“œš’™˜–•”™˜–›š› Ÿ£¡–›—€ˆY`VY`UPRHJH@B@;DA8GG;QRCQRDQUEOSGHNBFKBDMCDNA?J9CM@@I<=D8=E8AH;CI2;=2??3>>398/<:2??4?@4>=3<;2<=1<<0<=1>>1>G=H;@J>AL@HREAG;9>26;/7:19;29:1@A7@A7>@4:<1=;255+34*34*10&5/&82':5*85*:8.9;087-8909;278.26+27,37+58,8:.::/AC6:<059-15)4:-3:-;B5/9C64>37?49A57@56@45?27A49A5>D9;C9AP@BUBTbOQ]M=K@:NAAVG>U@?S?>M>AK?=RBFREGM@8<152+5/'95+69.9@78>969/-3(1:.8A5AI;>D7;9/31&.,"0.$-+!/-#Wf[Xf[X`VY^XYZPWUL[UL[XL]`TZbVUaQXbSYfT`kXqq_•ˆw•‹z†ƒtn{mYufLk[LdUH^RH]PK_RRdWSfXH\NFXIUaScrfRhZLgYMgZSeXIbTI_PIWIFOCCM>DM@DM@BL?CL?AK>?H:ITGVfXPcVOgYMdVFZOIVLGUIEQCBM@?M@=K?>I=>J>:J=;J>:I>;G=A9AE>>E?E6;>69=49<38<3:C8AG>CK?CL?BMB=J>;F=AJCBND@I??H=@I@CNDAQFBPCBOB@J@=F<@F?@C>?>9AA=@F@DNCBOBDOBCMAAK?@L@BM??I>G=?F;>E:9@68@5>E:HTDN[LDOAAMABJBBKBJRHSXSSXQSYQ^g^UbWQ`TNXNGOHHQIIWORaUV_SU`U`k^`h^\bYv{qƒ†‹Š‚‹Š‘‡Œ‹€~q}wi}zoxvmz^aYNTKLVKKQFPYMYfYITHFNCHNCEI>FK@HPEISGDOA@M?EMBFREETGFXKUbYaifekiW_[BIC@HA@FB4AG:JQFLQDCJ@AI@BJABL?EP@ENBFNC>F<>G:>G:AH;@J=BH;@B4BB5=@4;?1?A4=>2<>3?A6>A5>C6=>4;<289057+7:->A5BNBIWJERCBO@?J>BLAFVIP]OP[JAJ:428;28<0=A5>C6<@3:?4;<3:<2:;178.31'62(77+86+63'84+86-:;04908>59?46:/39.18+68-56+58,58-6:.48-57-58,37,8>1:=158(52(3/%5/%3.%1.%/-$1/%3/&4.'50)0/$23&55(31&30&51)65+46+33)33(76+66*22&10#54)69-JQETYO@C932)21#02$46'22(01%31&83(42(21'45*04&06&29*47)53(42'45)35+57+67,56+7909?7:B:CF=BI?:D8=H<;G:AL?AN@:G96D4:E4:@47;/4;.K>BQACTEDVHLbQMbRHYJVeUQ[NHVD?SA@UCIWIU[OX\RRSODC:87,7;.7;389372*34)29.2:/3:-57+64*21(22)..$0/%0.$Si]Xh]XcXY`XX[PVWJ[UK^YO_`V]dYZhX\iX\kYbo[qs`†tŒˆxx|lbufOm]NkYOeTGYMHYNHVJCRFGWJHYJDTFLZMP_SE^QA_RFdVUl`Oi\IbUGXLFQDBNBBL?BL?@J=@JMVI]k]\p`Tj[LcTFZKGVKCPCDPBCNAAOA;H=@I<=I;=J>9G;;G<;E;BAJ@>H>9D:9D:78>9:<88:28>49@7=G=@GA>E>AEBAE@=C>;B;;D:CMCNXIOYKDQDI?BLB>J?K@;F>C=CMBERECPBDNBAMACNCBOABL?AJ=CKAENBGQDEOACM@=F;?H<:C6G:BK=@J=>F7=E:=H=?J?DTEN^KP_NKZKGSGDPDDNBGODKPGOSKHRGYfYYk]\o`X]WJNHBHBO[SXcZZaVW^SU[PZ]Sllcywpyvr„w…ƒ{~|srrgjg[ieZ]ZPa_Uff`_`[_g_XaUQVLKSHOZOFQEENDJOEJMCKPEW^RU^SEQCBMAEK@EODERFJXLYbZW^Ybfg_ecNUPEMEINDIK@OREOTGGNBHQDFRACP@BPCBOBDQCDQBGSDLWGMYNQaTUfYTeZ]mbdrheqf`lbTbVdpcfobipaeiY_fXYcWT`UUaT_j]^i]T`TLXMHWKXfZSaUUaSWeWWgYVgYScUSbTRcUUeWVbT^k]^k_Zh\XhZ^n`dvgeykbzlWpaWj]\ladwkhvvŠˆ•—˜šžšœš–˜ŠŠ‰v|wq~tq|phth_m_\fY^fX^fW^f\_f[jpdqvkuyqƒ~ŠŒ•–—¢ ¥¦¤ª©¦««¨©ª¦«©¥ªª¦«©¨¬ª©­¨©­©©¬©¦ªª¦«¬¨­««¯§ª®ªª¬«ª¬¬¬­®¬®««¬­¬®¯¬°¬ª®ª«¯ª«¯¨«¯¤©¬«­®ª¬­ª¬­«¬°«¬°©ª¯ª¬¬¬«­¬©«­«¬¬«­¬­­¨¬°¨¬°¨­±§¬¯§¬¯¦«®¨«°¦©¯¨«°¦ª¯¦©­¦©¯§ª®§ª®¨©­§¨¬¨§«ª¨¬©©¯¬­²¬®°ª¬­ªª°¨¨®¦ª¯¥¨­¦©­¦©­¥¨¬¥©¬¨¨±¦¨­¦«®§¬¯¨ª®¨¦°ª©®©¨®¨¨®©©¯¦ª°§ª¯§ª°¤¨®¥ª®¦ª®¨­¯§¬­©­²¥¨­¦©®¦©®¨©®ª«®¤§ª¥¨¬¥¨¬§ª®¦©®¦©­¦ª®¦ª®¦¨©¡££šŸŸŸ¦££§ª¦¨­§¨¬ž¡¥—ž¡˜¢¥–šœ–œƒ‹ˆˆŽ’˜—£¥©¤¨«¡ªª¡©¨¡§§¤¨ª¢©­¥ª­¡¥§¢¥¥œ¡ ’’“››•¢£’œœƒ‹‰}Šƒr†}q‹……“‘x…ƒw†‚‹™–”Ÿž¨¦Ÿ¥¨š£¦’¦¦£§§¤¥¥£¡—œš‹’Œ•’˜˜Ž˜™šž •šš“˜™›Ÿ¡¢£ ¥§ŸŸ¡Š‹_g\P[KFO?EM?GD9BA6@D6CIG>AK>CN>ENDCMA=F;0=@5;B5;B49A1>>4;<29:079.8:/3:>3D4?D6>B7;=17:/>D7=?399-<9-7;0:;099.76,77-7:05=29A78@56>37>38A389/25*25*/5*5:/7<1=<266,03(6:.69*45&42%62&82'72'42'42(42(3/'5/(3.&10$33%76%52%6/&3.&0.%10&20%10%00$33'22'10&33(47+49/5:043+50)32%13$/4$15'13&11&0/#0/$0/&04(07(/9(1:*47*10%42'56+59.62*2.&1.(43.9>:>DA@B<K;9G58C29?/78,79*5?26C89H<>O?G[IM`NReVUf[Xi]XeWP\JNZHCWDEZIIXJCJ>PUKz‚|]aY<>19?06:=A;@EAD?;B8:C99F99G;;K>:F;8A78@69=7>A;:;75:36=76@5>A9=C9:D9:B9J>9E::E:;C;?E??GBFNJCND@KA>I?CNAAK??I?AJ>AM@ERBKXIQ]ORaPR`RLYNHRJFPFHPFGQGINDJJBOTKV`UisjZaWBB9DB9WWNY`VV`VYgZ]dZXYNa]Vpofx|rag]Y_S^aW\bWS\ONZKS]RV_TX_UXaW^f\_d[OQKMKGLICGE@HLEV^WHJEKOHdhb^a[LRHCIAEJBHOEGSGLXK_jaVbZ_gecmgYbX\dXZ`UOSJNTJOUILSEMTEHPCFMADNAFPBGSEEQEJTHMVKMZNUeXTi]Wk_`pehsiozgdp`albbpfamabl^bj[ZeUZeTV`RWbR]hXWeWQbTMcTQhXYm]YhZ[kZ]n^Yk\TgXUeXVbWW`VZfY\i[Zk]]l^[j__l^fuif{of|qe|p`tg\pc_sgexou„~|…‚Ž’‘—œ›šœž–—˜‹‡ŽŠ€‰ƒzƒ}mzr`ka`g]bj^_k]_i]_i]eoeownoxqz‚{ƒ…€“”›žž  §¨«¨¨­¨¦­©¨­«§¬«§¬«¨©­«­«ª®ªª®««¯««¯­­±¬¬°©¬­©­®«®±©­±¨«°«­²¨­°ª¬°¬«¯¬«¯¨ª®¦«®¬¬±­®³­®²ª­±«®²«®²­®²¬¬°ªª®§¨¬©«¯©­±¨¬¬©­­¨«¯§ª®¨ª¯¨«°«©¯¬ª°«ª°¬«°ª¨¯ª©¯¨ª®¨ª¯§ª®¦©®¦©®¨«°ªª°¬¬²««°ªª°©©¯©©¯¦ª®¥¨­§ª¯¦©°§©°¨ª²©­±§¬±¥¨®¨«°ª®³©­²©¬°©¬°©¬°¨«¯¨«¯§ª®¦«®¨ª¯©¬°©¬°«¬°ª¬°§ª°¦ª¯§ª¯£§¬ª©¯«ª°§©³¦©¯ª­±©­®©¬®¦©®¬«¯©ª®¥©­Ÿ¤¥š¢£¦¦¥¨­¤©­§«¬¢§¨¡¦ª¡¦ª™žœ›¡ Ž˜˜”•—ž¡¨ª®¦©­§ª­¦¨­¤§«¦©­ª­²¤««¡§§£§¨£¢–•˜¡Ÿ¡§¦™Ÿž—––”…Ž‚‹ˆŒ{†ƒ~ŒŠžš£¤¢¦ª¤©¬¤ª¬ ¦© ¥¨¢§©Ÿ£¦¢¢Ž””…ŽŠ–”—•••œŸ–ž£› £¢£¢¨¦Ÿ¦£Ÿœžˆ‹†gqgUbVKZLFREHNBCI>@M<@H;>K<@HA67?28?2>B6>B6;?3@D8J>GUGS[OQTGLMA=A4=B3:@2:B3A6CC:BC;@F??H?3<26?2399145-25.5907>08A0=>636-03*38-6:058-67)55'64&51&43(21'44'12%11%00$11%44(66'69(68)67*54)62*21$2.#/,!22(44+0-$0.$11$24&35(43*41+21'12'48,3;,4<+5:)44(02&25'59+29)2:*47,26*44(57'5:+8@.8A49?417,28.6>5=8=30@=:>B?;A<78386/33'22&13'79,37(26)05+18,5>/58+6:,3>F=>F=>D:>D9AE:@D9>B8F:?G<@H97@68@6;>5:?68C7>G;>F>@FA?EADLCLTHLVJMXKFTH>LA@L?@K?@J?>F=J@>H>?G=?G=BJCDPGHXMK\QLZP@LA@H@@HABICBJACK@ENACLB?LCALBAH:BH;BJ@GNGFODCNADNADNCFMBBLAEOCIRDFTELYKT`TXcUXbVV_UPXPLULRZPIULKPGKJCILELPGVYOPRJEB;D@9URLad\aj`jrjqwoVUOZVP^]VnpitvpSUOPRKW[UU]TT\SV^VR[RZcYV]S_dZX]RKQGGJ@JIBFE>INF^e^IKELNIfib[`XGLCFJACKADNCHTHMYMV`XXaZ\c][c\ai_dlbV]SGMELPJMSIMTHMTFLREHOCAO@CSDEUGEVHHVILYMU`VZk_[mb]od_ncfshird_l^]h^^la`l^bn]XdTWbRT^NS^MVaQWbQRcVSfWSj[Zpa]oa[i\_l]`oa\m`UgYUeYTdWYh]^m`\m^^n`\n`]mb]pcbymb}re€sdq_yi_qd`sfj{qv…}|‡“•›™—›š›”šš”™˜–”‡ŽŠn{tdpiai_`h]am`encendiqhvw{‚|~…€‡ƒ†‹ˆ”˜— ¢¤©©®©©¯««±¬«°ªª®¬¬°°­±¯­°­¯³­­±°±µ¯°´¬­±¯¯³­±µ«®³ª®±«­±ª­°«®²ª¬°¬®²­®²«­°ª¬°ª­±«¬±¬¬±°¯´¬¯´­°´¬¯´®°³ª¬°«ª­­¬°©«¯©«¯¨¬®©­°ª­±©¬°¨«°¨¬±ªª°ªª°««±««±««±©©¯«¬°©«¯§©­§ª¯¨ª¯§«¯¬¬²®®´­­³¬¬²©©¯««±¨«¯¨«°©¬±§ª¯§ª±©«´©¬²¨«°©¬±©¬±«¯³¨«°«­±«­±¬®²ª¬°«­±§©­§¬¯©¬°ª­±«®²¬­±ª«¯§ª¯§ª¯¦©®¤§¬©©¯¬«±©ª³¨«±ª­±ª­²ª­²©­±«­²©¬°§ª¯¤¨«¢§ª¨¬®§ª°¨«°©­®¦ª«¨«°¤¦«§«®¢¨ªž¥§˜  œ¢¤¢§ª¨«¯§ª®§ª®§ª­©¬°«­±¥©­¤©¬¥¨ª ¥§›¢¢œ§¦¥ªª¡¦¦“›šŽ—•‚Š|‡„„‹ˆ‰‡†”‘“ ŸŸ§©¥«®¨­°§¬¯¥ª­¥ª­¤©¬ž£¦’—˜‡ŽŽˆ‘’Œ•–Ž˜˜˜——œ¡› ¤ £¥¢££¢¤£¡Ÿ™™™…‰…isjVbUJSGKTHOUGNSGAG?4AC7>A3::/99/34+9<2=B7?E9:?3;C6:D7;E89C6G9EH<46:06<2DK>T\N77/34+26+25*67.56+69-78*56*55):.9C21;B2;E514;/6>29C69=427-6;0>A5=>17:+64*57)37&28'6<.8=2:G;@PDOcTPfVEYK?RA?YKD]OG_Q>SF9J=BPEH_NJbQVgXXXMHB8;5+2,&42-AD?FKDCI?5:145,23)/1&12'35)34(49.6?26A1:@09@08A4UcXZ`WUVMSVLVRJTSIWVL_ZQdeZbj_^rfdzo]vlYnbjtgvwgkocYeWM^PEYKH\OCXKEYLEWJETGDSFFTHFTHETHCTGFWIFWIJ[MTeXUgVVj\Wm`OdXL_SGXKCTEDUHHYLIZMARF>PE?L@AMBAQF=NBAPEALB@KA>H=>H;@J=@J>>I?>G==D=B<@CG:=F<=GE<7A6:C9;?49?4;E8>K=>I>=G==H>AMBIVHJVEGTGBQG?OD>MB?L@FPBAJ>@H=G=?G=CI>GPGIVLN_TQcVIZN@MAAH>@E<@D>@H=AI?BK>AJAAMF?IACI=AH:DMABLEEPE@M?BK?AI=GLBIREJUGLWGLVJLXMQ\RV`SV`SV_UQZPLXMLZOGYRISLJOHFJEGKEQNHLNGGC>GA=[UPec_koivyvƒ†ƒjidUTPkhdljfijica`WTT`a__caW]XW_XOXORZQPVJSYLPUHHSDHPBGK?EH>LOFX]UFI@JMCSVMINEINCIOEGPFFQFESGJUIOYOMUKQYNQYNOWMNVLNVMFNGHLFINFKQFMTGKRDHP@GUCGUEHWJLZLKWKP\PX`Xfphericphancepfbk_[eZ]h^`m`bo`^lYTcTO]OQ^PYcV_j]YfXTgXUj[Ul]UjZUfWXeW\i[aoa_n`^obZk^[l_\nb^pbatedvgbuf_qf_tj_xm^|q`~pd€q]xgYj[_pcjymp}tr}v}ˆŽ”˜›ž  £¤¨ž£¦—œž“™˜y„iun]g^aj`cqckukktkpxq€ˆ‚˜””›™Œ“’ˆ›¡ §©­«¬±®­³®¯µ¬¯´ª­²®®²®¯²®®²«­²­°µ¬¯´®°µ­°µ¯±¶ª®µ­°µ«®³¬¯³®°µ­±³­±¶¬­³°°µ­¬²¬­³«¯´­­³¯¯µ°¯µ®±¶­°µ­°µª®³ª«°¬¬²­«±««°««±«­±­¯³­®²«¬±«¬±ªª°¨«°­¯´¬¯´«®³ª­²©«±­­±¬ª¯ª«¯§ª°«­²ª¯´®­³°°µ­­³¬¬²¬¬²¬¬²ª­²©¬±«®³©­²ª¬²¬¯´¯­³®­´¬¬³««±¬¬²­­³¬¬²­­²­­³¬¬²¬¬²«¬²ª®²«®²«®²«®²¬­±ª«¯©¬±ª­²¨«°¨«°ª­²«­²©ª³¨ª²ª­²©¬±ª¬³ª¬´«®¶ª­³ª­²§©®«¬±­®²¨¬±©¬±©­®©¬®©¬°©¬±§ª¯¨¬°£¨«™Ÿ¡› ¡§¬­¨ª°§ª¯¨«°¨«°ª­²©«¯§©®¨¨®©¬±¤¨¬¡©«¢¬°¤ª«¢§¨Ÿ¥¥–Ÿž†ŽŒ‰‘’™—Š““——˜¢¢¢«¬¦«®§¬¯¥«­¥ª­¦«®¤ª¬œ £‰’‘‡‘‡‘‘––š›“œœŸ£§šŸ¡‘•–‰Ž‘–”£ž‹{ƒ}doeUaUIQFLQEQVGLPCBH=ENCKYIL^LT\PKTGLTJOWNKTIEOCENDJPEIREGSFFSGELBGM>AI9G8AC4>B3:B3F7=E9:B5;@4:A48A58C79?:ScZx€ydc]A@7<>417*23'12&55(44(78,;>1BM>AJ>=C8B5AF6GE7A>486+99-35)45+68+7:+69*58)76+41)31)6/(2,%.,$--$-+!//%.0%27+8>35:/.2(33'45)27)8>0>C5=B1=@4;=037++1&-3(29/9D5I7>G7BF8EJ;=C59A49=26:/7:.79-88,64)55)56)8:+9?.9A3:C65F9>PCObUQhXRfWL_P:\MLl]Ql^OfXK\PIVJBYJScUX^QMK@;9.77,=;288.14+>D:JSH28B49E46@/3<,,8*T]TW[RVWMSVKVRITRJVSL]WQad[eoe`sl`xoZsiTl_WeWW\PP\NO[MIWKCTGAREASFBVICUHBPDFQEERFDRFBPD=K?>K?EVHI[LZn\XjZWl^VmaPh\KaUM_SH\OEZMBWJAUH?SG?RG@KA>J@8F:I?;F<>G;>G:@I<=G;B:=B7AE9EJ;DJ;CN=FP??I<HD99?47<38=4>@9?D:DJ?AI>@H=@J>?I==E;:D:6?58;0BPAAOA?K??K?DQCJWIKYIM[NL]OHXMBTF@OCBPA>K>AI>@H=FRGHTG@OF=LC>J?@I?CK@MTIKUKHWJQcUJ]OEWI>M?@H=DJ@?E;>C:>F;@I<1>:/?<1=:/99/=>3;?28>/?G7@G8@A4AE6>E7BI;CK.9B1:C6F8?B78=28=4;@5;;1<;1<<0:;/8<08=27<39>57>2>F8FK;OL>HF9?@48:.49./5*59-6:,58)79+35*46+2/(6/(3.&11&./$.-#2.%0/%/.%44*66,75+<8-85*78*88*;;-=<.9:.35*15*07,08-3;1:D8>H;4>1:C6=F8?F;?E4DI9DG8BE6=A1>C5=A68=17:.67+99-76*78+7;+:?0=B4;D48A45A64C69J=EWJM`QK^OOl]]vhdxk[l_VbVHRF;K@6>5/1)?B9EMCGTIHJ?@B9EJA6>5AK@`k^XXR22+34*34*68,:<0:?29C48F3;D4;C6:G9PXNTULUTMSUMWTJVTMWTOYTPcc]irievnawlYugUnaTfWWaTM^PGWIFTHBPDEUHEVIDWJCUHAPDFQEDOCCOC>MA?NBESGHYLI\LWn[ThYPfZUnbSnaPh[Sj[NeXKbUG^R@VJL@>L@?NB:G<H<9G<CM=AL>>I<;G:;D8?I==G;;C7;C7=B9;@6:@69?59@6=D:CH@AG@@H>?F=BJ?BK?A7?H;=I=?K?BNABOBDQDHTGHXGN_OO`TOaTFXJBTEDRG>MAAL@DODERG@OB>LDAME@KBBLBIRFNWKMVKKXKOaSL^PFUGGTDERECMAAI?@G=CH>CK>ENCBMH>GB@EEK@@EBG>GLBFLANRFUZOX_T[`Y`d_bda~€~~zzoup_f__f`[h]XdXVcVZhYVfWObQO_SP^RXcX\k^ZnaXnaXnaUk]Ui\Ui\ReWRfYSiZ^reewjewj^ndZl``pecsfixjo}oqrnyodthbvk`xm^yl_wj]uf^ugavh^pft€y‡“˜”’›™ž¢£¤¨¬¨¨®¨ª¯¥¨­¡£§šš|Їqwgqhlymmxqr}uy€}•›š¤§ª¦§­¤¨«©¬¯«­²¬­²­¬³¯¯¶¬°³ª­²¨ª°««°®­¶®¬µ¬¯³«¯´­°µ¬¯´¬¯´¬¯´­°¶­°µ­°µ¯²·¯±·¯²¸®®´®¯µ®±¶¯²·®¯µ¯¯µ¯®¶±°¸±°¸®°·­°¶¬¯µ®¯´«¬²®¬²®¬²«¬²¬®³­¬¶®®¶­­³®®´®®´­¯³­¬³®®´®­´­­³­¬³®®´¬¯³­®²­®²¬«²­¬²®­³­­³¯¯µ¯¯µ­­³­­³«ª±¬¯´­°µ®±µ¬¯³«¯²¯³µ²¯µ±®´¯¯µ­¯´¬®´ª®³®¯µ­¯´«­²­¯´¬®³¬®´«°³¬¯³¬¯³­°´®®²¬­±¬¬²®®´¬¯´«®³§«°ª­²«¯°«®²ª­²«®²«®³­°´®±¶­°´«­²«¬°ª¬¯¬­¯¬¬³®®³®°±°²³««±¬¬²¬®³¬¬±ª«¯¤¦«¤©­¦­±©¬±¨«°¨«°©¬±©¬±¨«°©­°©­°¬­±¨ª®§©¯¥©®¤©«¥ª«£©©¡¦§Ÿ¥¤ ¦¥ ¨©¤¥› ££¦¡¨«¤¬®¦©­¥©­¤§«¥¨¬§ª®¤¨«¥©ž¥¨Ÿ¤§ ¤¨¢¦©¡¦ª¤¤—žž„Œ‚‹Š˜‘}Œ„r€ul|p`se]m`O[PMUKHODMUIKSKLVMP`TXk]Xl_Uf[TbYL[QJ\OI`QI[LGUELYHK\KH\MFVIEM@DI=EK2;;/:;/:;/88.;@2=C3CK>DI=CM>=G:=D99A5:B76GA9EA996.76,77-45+68,67+99-9;/8=19A5?H=BJ?GMCBK>?E7>B3JI;CE9@F:?H<7@67=3:<167,55)46+68.74,6.'3/%00#/2#..0+$.+$10)1/'43*87,;:,99+9:,67(87)77(68,7;/7>17>16?28@4=C8GH;DC5EC5B@2@?3=?2I>QWNTULURMUUOYWNUVOYWSZUQ_^Yfnhhvkcwl\vhVp`TgXTaTMcTI\MCQEFSGEUHDUHEWJCUHBPDALABL@BMA:K>AODGTJK]PLaPNhTTg[Og[TodSqcQk^LeVIbUFaSBZMAUJ>ND>H?@H?OA>I=G:G<BL@=G;7:@6:C8BKABJ@?I>;G;B7=A5;D7:E9@I=BM@CNBEOCEOCGXHL_ON`RI\OEXJCVGBRG=MBBPFDRHDSHARF@KD?JCEODDODJUHHSFLUIMXKL]OM]OL[JNYHGXJCRD@LBDMBGMBFMAGQDEQJ@ID;@8FJ@JRJKTKMXMP_QP\ONYLJRGKSILTJKTGOZKNXJQ[NU]WOVMNUIKODbjbitmpyw}‚lpoW_YNTNGICIICFFAA>:zy”xwwqkmwtt€ƒmojSRMQLGjfc…‚~urn`^XIJDIMFMNBNOCLPDLSGJTHFQEKSHNXLNYLLVIMWJHQDHRFFPDGTFMZLO\NR_PU^SJUJHVKGVKFWIFVFFSEGQFS\RT\QJOFHMAHOABH=AE?AE?BF@CH?HQES[PWaZbidfmjkpo}}}…†„svs`d_\d]XaYWeZ[g\ZgYVcUO_QK^OK\ON[OT_SRbUPfXKdWVm_Ym_Wk^Xl_Tj\Tk]Wqb[tf^se`rf\lbZnbgshgrepzmx‚vjsgelc^pb`th^xlYwjWtf_|ma{m_wkevmt‚|†’ˆ’–žŸ¢¦ª¤¨¬©¨®§¨®£¦«¤¦©“žƒ‘Žuƒ}tvpsq}vuy~„”– £¨©ª°¬«¯«ª°¬«±­¬²­­³¯¯µ­®²­­³®®³­«´®«´¯«µ¬­²®®´®¯´®®´¬­²¯°µ­°µ¬¯³­°µ¬®¶¯±¹­¯·¯®´«­³«¯´¬±µ¬­³®­³°¯¸®­·¯®·®°¸®¯¸®°¹®®³­­³­«±­­³«­³­±µ­¬³°­¶®«´°®´¯­³­¬°¯­³°®´¯­³¯­³¯­³¯®´¬°´«®²«­±°­²°­³³­´®®´®®´­­³¬¬±­­³­­³¬¯´¬¯´®±µ­°³­°²¬±²±®´¯®´¯¯µª®³©­²ª¯´­°µ¬¯´ª­²¨¬±«®³­°µ¬°´¬¯³«¯²­°´®®²«¬°­­³­¬²©¬±©¬±«¯´ª®²«±¯¬±±¨«¯«®²«®±¬¯±®¯³®¯³«­°«¬®©«¬ª¬¬««²­­²®°±®®±¬­²¬«²¬®°­®²¬¬¯§¨®¨«²¥¬³©¬±©¬±¨«°¨ª°©¬±§ª¯¦­®¨¬­«­°©©®¨ª¯¨©¯¥«­¥ª¬¨¬­§¬­¦««¥ª¨¥¬¯¡§ª ¥¨¢§ª£©¬¢ª­©«¯§©®¥¨¬¥¨¬¥©¬¤¨«¢©¬¢¨«¤§ª¦§«¤§«¢¥©£¥¦Ÿ££™–†Š„†swkzoZm_Wm^Xl^RbVMXOISFMULKSLJVNO_UReXTc[Q^UU]WYdYO`SMbQLdQK]KM]JI]KF\LCWIFNDHNCIK?KJ=FG=?C:@G:CF:>B7<@4:?38A49<0=C3?H6>F5;A17:-==3BE;@I=?I=?HG:;C7A=0EA7@A5<>488052*42)55+47,36*67+:9-<:18909=5;B7@GC:@B5HG7GH:FI38<048(8;+7@05>.4.8:-99/<<3;?5@I=?MB?4BLAYlczŒ„†ROJ84,1.&55)6:+7>-9D0;<26;09@4;?4DL@AP@IUER]NTfVQeVReVReXUj\Zqc[rfTj^McWJ]NG[KFWICTF?OB=J:AK=DM@CL?@K>;I=;I;;G9F:AI>CL?CK>EJ>CK>CL@AL@?O>BO?DNABL?=E:=D8G;>F;@IBBMBAKA@OABM??H:?C7>B6=C6E;?HCK@GOHJSLHRFJSGGODBK?CI?CI?CF>FHBNPFWZQtvpmrmfojs}zrtoz{wsupeicae`Y]VT^R[eYUaUS`TM[PM[OJWNJXLL\OO`SOaVTf\Vo_Um_VnbWnbVn_Sj[Xl_[obYndXndZpc^qcctghvin{kgyh`pbama_qdbxj]xjYuiZuh`}oazq\xo^wolyŒ††ˆ’•šž¡¨£¤­¦¨°§¨­¦§«¡¤©•œ‡‘ކ’Œˆ“ކŒw†~xƒ€~ˆ†•–¤¨©ªª°§ª¯¨«¯§«°§ª°ª­²®²¶®®´©­²ª¯´ª­²«®³«¬²¬«´¬«´¬«µ¯®¸­¬¶®®·­­³°¯¶®®³¯®´°°¶®®´­®²­­±¬®²¬¯³¬¯³¬¯³¯­¶±®·¯­¶²¯¸±­·±®·¯«´®«³®¬²¬¬²®®³¬­°°®²¯¯³­®²®¯³­¯³¬­±¯­³°®´¯­³®¬²¯®´±¯µ¯°´­®³®®´­­¶®¬¶®¬¶¬®³¬¯´¬¯´®­·­¬¶®­¶°®´®®´¯¯µ¯¯µ¬¯´¬¯´®®´­­³­­³¬¯´¬¯´¬¯´«®³¬¯´ª­²©¬±ª®²­°µ­®´­­³®®´°°¶¬¬²««±©­²«­²­¬²­­³«¯´«¯´¯¯´­®´¬¬²ª®³­°´­°µ­­³­®³¬¬²¦ª¯¨«¯ª­±««±­­³­­³©­²ª­²©­²««°«­°«¬±©¨²ªª²ª¬®§ª²¨¬³¨¬±¨®°¨­°©®°©®±§¬¯§¬¯¤©¬£©¬¦«®¥«°¤«¯¨¯²«°³¬±²¦««©§­§§­¦©°¢ª¬£ª­£ª­¦«¬¤««¡¨«¢©¬¢§«¢¨­¥ª­¥©®¤¨®£¨­Ÿ§¨Ÿ§§¡¦¨¡¥¥”™˜†Ž‹w‚lzsawlaznXqeSk`Ug\N]QSYSS\SVdXQaVN_TRcXVb[WbZXcY\i^O_RJ]LG^NI]NGZJM[LMVKLSIJPFIOBKP@IN@BH=@D>CI=BG=CF>AC9AC7EE5>A2@B5>B5=A4;@3:>.:?3MA@N?EP?GNDISHFRFDQCEQCFPCAMC=E:=C6F:BF;@D6;@29@49@35;-69+46*67,63+74*79+6;,78/67-9=2;?4;?4>A6DGJH=EF:;@29D4:E6=F:>H>?J??K??LE9;D98B8LTHU\J<;0GH=BD:>B78?34=0:9+65*64,45,68/57-75-42)44*01&33&54(20'20)10'/0&12(7:/9?29=.7;*49(5<,4=,<;057)38'7<,B6;D3;B390FK=JTEGRE:KBEXNCYMEVIM]PO]MHJ@7=07>/9@1@D4CF5<@4;>7FJFMRKRWNW[UEC;2,&60&83'6;*8E/=G2=F78B76C;7D:6D9XaVZ_T[`X[d_\f^`ibajb]jb^md_sj\rkWqgSmaQk]Tl]RhXLfVG`PG]OF]OF^OB\MB\LBXJBTFCSE?OA@PBAWEK\KQcROiYQm]OjZWmaWna[rd^ufUl\K_PEXIBTFAPC=M@@LA?J?@K=AK>AL>@J=?J>:I;=K=BMADNBEOCCPDGQEDNBBL@BI>?GAH;BK=CL?@O?BO@DOABM>BK=@H:=F;>E9?F8?F8>F9:C8>D7?D9;C9=F<@KA@MB?QCBOB=G:>F:@E9>E8?C:>E:>H;@M?GQEKUJFVLGWLHYLJ[NK\NL^PIYJGWGETFHUGEREDQDBM@?GCPAI[KQ^RR_SJVKEPEGPDFODAM?DNCKUHNYHMXHGOEEODFKBCC=?@9DKAJWKO\QP]RP]TKXNLYNP]RTbTUaUN[OP\PNVLLSJIOHFODFMDLQG[[Vb^ZeaajmkekfU^VLTKBH?DE?FB>JB?[TSnkkmnnmkia`_klktws__XQQHUVLYYPWYOX[RLQIIOGHNCGMANRFNSGFNBHQEOXMQZNR\OR\OOXLLWGITGKVILWJNYLNYLKWILUKMWMJXLKWLLZLHREJPEFNCIPFGMCHNDFLCFPDHPEGQEDLBCJ@BI@MSIbf]cg_UXSgoiszwab_fiegkequokoiRYQO\PUbVQ_SN^QM\PK]NM[SKZNM]PM]OScVXh\Rj[Sl^[pd_uhZpbShZTfWUgZZnb]rf^reaufduhiwietc[n]Xk\[i]Zna]ug_xkXuhZvi\yk^yo\wm`ypdxoivou|v‘”–œŸ¢¢¥«¥¦­§¦­¦§¬Ÿ£¨˜ –œ˜¡ —¡ •œœ†’ƒŽŒ‹“’–›¥©®©ª¯¨«°¨«°¨«°¨«°¨«°¬¯´­­³¬¯´©­²«¯´ª­²«¬±¬«³¬¬³­­´°¯¶°¯·­­´¬®³®¯µ®°µ®¯µ­®´¬®³«¬±ª¬±ª®³¬¯´«®³¬¯´­­´­­´¬¬³®®µ®­µ¬¬³®«´­ª±®¬²¬¬²­­³¬­±¯®³¬­²«®²¬®³¬¯´ª®³­­´­­³­­³®®´­­³¬¬³®¯³¬­²«¬±¬«´¬¬´­«µª®±¬®´¬¯µ®®´­¬´¯®¸¬­²­­´¯¯µ­¯´¬¯µ¬°´¯®µ­­³­­³ª­²«®³¬¯´¬¯´­°µ«®³¬¯´¬¯´ª®³­­³®®´¯¯µ­®´­­³­­³ª­²¬­³­­³­­³«¯´ª®³®­³¬¬²««±¬°´«®³«®³­®²¬­±ª­±ª¬±©¬°¨«±©©®««±¨«°ª­²ª¬±¨¬±¨¬±§«­¨­°¦ª²ª­³¨­®¨¬°¨­°©­²©­²¨¬°§¬±¨­°§¬¯§¬¯¥ª­¤©¬§«¯¦­®¨­°©­°©­±ª®±©¬¯§¨®¤§¬§«¯§­°§¬¯§«®¥«¬¥¬­¥«®¤ª­¤ª­¥ª®¤¨«£§«¥©®¢¦«¡¨ª ©©£§ª¢¦¨•››…Ž‹t|hyrjvn…|_vmYpf\phZlcWe\Wg]XkaWkaSh^Wj^`pdftkalfaodYj^RfXLbUI^OJ^OP`RN\MDQDHTHHTEJUCEO?CMAAKABK>DLADJB?F=@F9AI8BE7?A6<=3=?2.;?2GREKVJIXKFVIDSFDQECQFHPF?E8;E7:C7?D9?C6;@58>39?57=16:,47,33*64*65+68+6:+58-79.<=3==3;;2>=3BD:CD9ED9FF:>C52FG288*45*45+46-7;06;18>19@27?109+39-8=1;9176-54+55+45+68.8<.8<,:;+69*9=/9>38;/49,9@/9A0=B1>A1=<398.77-99/:<2:;078-/1&05)56+:;0@A6J>KVIT\OKRC>@56:.5<-7>/;@0>A08=1894451:;2ILA^]WTRH@913)"4.&25'6?/>D2:A3:B8:C;9C96A5]dYcj_cjbcniatk`pg^kc[iaWkb[siYsjXrhTnbSk_Ul^Tk]OjZLgWLfVNhXHbRGbREZJEXJEWHCTFBWGF[NJbOOcQPeVLiYPraQscVqdYseXpa\n_UiWI\JDVHAQD?MA?J@@I?BJ@@J=@J=@J=COCBNB?MA>M@=K?@NBCPDCOCDREHTEEOADNADMCCJ@>G=@F:CJ=FL?AH;BJ=>H;@L?AM@CN>CN>CMF:BI<>E8?F;9C8@C8?C:G=QE=NC;H>>G==C9;@7?B9>E:AK>IVHJYM_ncM]RFVKFUIJXLKZLIYKJ[IIXGIVFERCDPCGPCAI>BI>DJ?DLAGRFM[OR`TP^RLWKJQGHNCEK@BJ=BJ@HRGMXHHSEENDEKBDH?AB9?B9CK?FSGOXNNXPJTNIVNJXNN`RObUPaTLZNLVJMTIHLABG?CI?CI>JLFONHQLIPOKCEAQXQQYQGPEAK?@C>BB=HD?LGDfd`fgdbe`_b]^a]^b\PULNUHPXLRYMPVLRWLNTJJNFGN?FKM?DM=FMAEK@>GG8=B6=?4=<3;:.>@0<@->A4=C6AK>EOBDO@CM=DRDJYLN_QK\QFWLAQHHVLFOD@G:=G:=G:?E;@B6<@7;?7;@7:?48<07;059.78.8:.9;/:=.49.9<2A@6>=397-;7.;<2:;0>>2BC7<@38A1?F3=E4?F8?F8?H;?IELABH:BF6GH=GG=GKAFJ?@D9:?3;<068-59.49.9@4:@3:D17B07C1EP@?I94;-::065+87-86,87-88-:=.:=-:=-;>.;>37<15=05?08B17?.48)67*53(43)23)15*5;/:A4;?424*23*44*77,=<1>C4:?2>@4?A5/;<.C6BF;BE6:;,;=18;/6:.7=-8=.8=.:>2571:;4DC9A@5:7/=6-91'6+%3+$21(.3)/.#/2'49/5=3;C85?0ei^lmckogktmbwm]ne\jbVf]Uh_VmdYqfZrhYnbTh\Wj]]pcWo`Uo_Rl\PjZMgWG^OM\PJXLLXNJ\OK^ROfXUjY[l_Zn_Sp`RrcWxiWukYtf[pc\o^UhVJ]HGWKESGAMAALABK@>G<>G:@L>=K>GSGHTHDNDBQD?OB=NA@RE?PDBSFCO@ERCEPBDNABL@BJ??F9?F:>G:@IALDN>BL??I;@F:AIF>>F:?G==E;?H>PE?PE;K@=H>;C9:A7>A8>D9DNAITGSbU^peVf[M^RKYMGVIDQEFRFERAGSCAN>DO?DNABL?AI>CK@ENBFOCKVJLZOR^RQ\PMTJHNCGJ@FG=AF:EJAGQDISEFOBCJC@AGOAJQDFMBHMAJUER]LVaQU_RW_SMVIOaS[i[\i[]k]TcUL]OS\QT`SRcVUgXZn^VhYSdXRbVR`TGTHBMABJAGQEISGJUIFQEEQEGTHNWMKSIKPGLRHW]RX`USXO[d\ekfgng^g]R]QFYKK^NK^OL^ORbURcUO`UO_SPaTP_QUeUZiXVj\\qcfxldujWi\QcUQcTRdTXiXVmZVm\Rk\Yl_Zk]XkYVm\Sl\QdWPcUTi\Wpb\thVnbTm`Xqg^wm]ulatliyqp~v‚Šƒ’™•˜¡¤¨¥¨­¨©¯§¨«¦¨®¤¨­¦©¯¦ª¯¦©®Ÿ¥©ž¤¨¤©¬¤¨­©¬±­°µª­²ª­²ª­²«®³¬¯´©¬±®­³®¯µ­°µ«®³¯±¶¯°µ««±­­³¯¯µ®®´°°¶¬¬²«­²«®³¬°´¬¯³­°µ«®³«ª³ª¬´¬®¶«­µ¬¯¶¬¯·­°µ®±¶­°µ­°µ¬¯´¬¯³¬«´°°·¯°¶®®´®®³°±µ®±¶®°µ­°µ­°µ­±¶¬°µ­°µ­°µ­°µ­°µ¬¯´®±¶¯°´¯°µ¯¯µ¯¯µ¯¯´¬¬²­¬³¯¯µ¯®´«¯³®±µ¬°³®®´¬®´©­±¬¯´¬¯´¬°µ«®³ª­²ª­²«ª±¬¬²®®´«®³ª¬±¨«°«ª°¬¬±¬¬²­­´ªª°©©¯¬¬²«¬±¬¬²©­²©ª°ªª°ªª°¨¬°«¯´««±««±¬¬²ª­²©¬±ª®²¬°´«®²ª¬±ª®³©­±§ª²§ª¯¨«°©¬±¨¬±¨¬±§«°ª­´©®°©®°¨¬²ª®µ§¬°©®¯ª¯²«¯³ª®³§«±§«²¨­°¦«®¥ª­¦«®¦«®¦«®¨¬­ª®¯¨ª¯¨«¯§ª¯¦ª¯¥«®¦¬¯¦«®¨ª¯©®®¨¬­¦¬¯¥«®¦«®©­±©¬°¨«¯§«¬¦©­§©­¥ª­¥«ª¤ª© ¦ªŸ¥¨›¢£˜–s~j{vl}zv‚p~zm{xfys^vm\xkg‚wg€vbyoZoh]skg{nhwqz†ƒ…Žˆr‚v[qdYk^Yk^UhYMaRG^NKZLJVGHRCMWGITCEOAGL=GL>DK>BII;@K=?I=@O>JZJN]PN^QFWMCUKGUJENBG;=C6=?3;=39>57;37=37;/4:/8=2;@42=>2=A6>A6CA7>=2=<2?;2:9/<<1;;/;>29?19@1C2;B3>E7BI=DJ;FM?EL?DH;BE7=?0:?3DI=DH=?B7@A5;<06:.8<06;/69/8>1:A1>C2;C/9A0@G6@F78=.8:.46+67-46,45+/1&11$47(9=-;@2<@59=29A4;D68B239*04'23'51*43)10'58.5=05?17;/69/78/64,99.<<.=C3?D6=A6<@5;=08;,7;,=>0AA3@C49@15A0=>577,87*77)68)25)29+4:-58-7;/5:-6;,68,9;/;>2;?4:@16>08;08929;2>=0<;.<6/81'6.%7-&6.'0,'530B?5@?5;?4=B8>E9?E8af[gh^lpfqzsdzm`vjXocUj^Wl_[ob\pd[obZl^Zj\`nagwi`yk]vgUqbRm^MgXHaRK]PK]PNaSK_RLeVPi[Vo_]rc\qbWseVvgXvgVvlWpe[na[l^SeUK]LKYLLZMDREBOC>K?OB8K>@REATE?QBBOCDPCDQCDNACM?BM>BJ=?J=@L>>K=?K=?I@J>DMAEPCAMAAL>BK?CMBBLD>IB=K@>KA:G<;H=;F;>IGQDVcVdtiZk^PaTM[OIVJDOCBMBBN@BM>CM@@J=AJ=AI=BK@GQDISGERGIUKIWONVLJQHHMEFJAFH@CE;BC:AE=@J>EOACM?CF@B?;A?9?@6?E:EOCAOBGOFISKITLJXNJYLHYKHXMJVLKSHCJ?DI>DI=EI>AE>>E>DLEMSMIOGGOGHPFHPFGPEGPEDL@FI@EF>EF>GIBHKCCH@IQGPWMNSIHMCIQDMXFP]MLYILXIMXJKWJJWIJREISEITEHRDHPBIOANWFU^NXaRXcS^j[T`SZm^^n`erdcpbWgYN`RR_OQ`PPbSThYXk]Vi[SeYSdXN]QDPDBK@BI@AJ>FOCGRFGPDGSEJWINVMHNEGMBIOCKTGJUFPXMY`WZa\Zb\WaWO[NI\MJ]NHYKN_QQaSP`RM_RM]RN^SN`SPaUVhXUk\]qdcwkcuiTfYNaSLcTLbSQfUUkYPiYOiYTi[Zl]Zm][tbTp`MdVPaTTfYXm`[pdZoc[nbZqf_vkbvldwmfzpl€u|ˆ€‚Œˆ‡Ž£££©«¦ª¬««¬¨«®§ª¯¨ª³¨ª³¨ª°§ª°¥©­ª¬±©¬°«®°®¯±¬¯³ª­²¬¯³­°µ¬¯´«®³°®²®°³­°´¯±µ°±µ±°´¬­²­®³­­²­®²®¯´­­²¯®´®­³¯®´°¯µ°¯µ®­³­¬²®­³­¬²¬­³­¯´­®´­±µ­°´«¯³¬¯´­°´ª­±¬®·¯²¸¬°´­®´­®³®¯³°¯´¯¯´®°´­¯´­°´«¯³ª­²«®³¬¯´¬¯´¬¯´«¯´¯°´®®³­®³¯°µ¬­²­­²«¬²¬­²¬­±®°µ«®±«®±«®³¬°µª­²¨¬±«¯´«¯´«®³ª¬±ª­²ªª°ª«°ªª°¬¯³ª®²¬­±©ª®®­°­«¯«­°ª«¯¨©­¨©­¨©­©ª®¦ª­§©¬ª«¯©ª®¨­°©¯±ª«¯©ª®«¬°©¬°§ª®©¬°«­´©¬±§ª°¨­±¨¬±¨­°©¬±«®³§«°¨¬±«®³©®²¨ª³«¯²©®¯ª­³¨«²¨¬°¨­±©®±ª®³©­²§«¯§«¯§¬¯§«¯¦«®¨­°§¬¯§­¯©­¯ª­°©­°ª®±¦¬®¦­®¦­°¨­°ª®±¨¬­©®¯©­®¦­±¦¬¯§­¯©¬°§«­ª«¬©­­ª­¯©¬°¦©­¦««¤ª¨£§ª¥©«£¨©–žž„x„‚s„‚‹…Ž‹‹•’x†eyphtl‚wpƒy{Œ…yˆ‚s‚~xŠ„’Ž‹•––—†ŽŠq|qRdYWfZ]l`[l]RgWLfSM_QGWIEQEJVGLXJJVFCO?EQ@HRCGQCAJ=>F9;I6?I9>B6=>3:?2E;=E9?I9DP?AL=KVFO[KLYLK[NFWKERFBI=;@17@0>E7@C8AA49=17<28=3:B5:A37=47?2:B5=D6:=1<<08;1:<1:<1==3==3<<2>=3<<1:<0>A5BF9@F7@C8BF:@E7IM=@E5>?0:;,:@3AG;>C8:9045*66+8:-79.9<18;08<.:?/=@/?E3>D3AH7?D4/6=.67,22'71)42)10'35)37*6;,29+38,89/36+4:)7?+;A1;C6:A64=?5AMA?MA=LAAODFQFBPE?PD:NA>TFAVF>RCAMBBNBEQCDO@EP@DP>FPCERCAPB?OA?I=?H>@I>FOEBQDAQBAN@BNB?KA9G@PD:G9=H;AL@>K?=K?>K?=G;AF=BH=EI=HPCQ\P^k`\n`TcWN[ONZNGRFAL@BM@AK>?IA8A@6?B;=FB>9?A6=C7GQE=K?>I?ALBBMCESGDSECRCEOEGNEEK@BG<@G;?F:DFGJAELBDMBCK@JODHLBJNBMSEOYHQ]MN\KO\LL[MKZLHXJJTHGSEIVHERBGQAHQ@PWFV]L[eU^hX_m^Zi\[o`^oafseaoaSdVPcTRbPPaOPcTReWWh\RbWMZQJVJJTGEK@EG=EF>BJ?EMBHQEJSFISFFQBIOFHMDHMDGNAFO@ITDNWLW_WS[VS[UP\PM[LI[MIZLN_QP_QN]PP_QJ\NK\PM^TM_VNbVQgZSj[[rd`vi]qfPcVOdULeWKeVQiWSjXLeVMfYQgYYm_Yo][tbTp`NfXTbWUdXXj]Zk`\mb]mb]rfexldxle{pd{oh€spxr}y€‹‰›™–žŸ¦¤¦§¦§§©¥¨¬¦¨¯¥¦®§§­§¨­¨ª­ª¨¬«ª«¬«¬¬­­©¬±©¬±ª­²©¬±ª­²¨«±¬¬¯­­±¬¯²ª­±¬¬°­¬°«¬°«¬°«¬°ª«¯«¬°«¬°­«±¯¬²­ª±­ª±¬«±­«±®«¯­«¯­¬°®¬±®®²®®²¬­±«¬°¬­±«¬°ª«¯¬­±©¬´©¬³¨«°¨ª¯«¬°¬®±°¯³°¯²®¯²«­±«­±ª«¯««²ªª°©ª°©ª°«¬²¬­³­­³¬¬±««¯¬­±«¬°©«¯ªª°ª«°­®±ª­±©­¯¨­®ª­²ª¬±¨ª¯©­²©­²©¬±©¬±¨ª°¨ª°««±ªª°©©¯ª¬°ª¬°«­°«ª®¬«¯­«¯««¯ª«¯¨©­¨©­©ª®ª«¯©¬°©«¯¨©­©ª¯©­±ª®±ª«¯©ª®«¬°©¬°§ª®©¬°©ª³§©²¨¬±ª¯²©®¯§®®©¬±ª®³§«°©¬±©­³¨®²ªª³««°ª¬­«¬²ªª±¨ª®§«²¨¬²©­²©­±§¬°§¬®§¬¯§¬¯¨­°¨¬°¨¬¯§¬°§ª¯§«°¦«¯¦¬¯¦®®¨¯°§­°¨«°©«­¦ª«¨¬­§­­¦¬°¥«¯¨¬°¨¬¯ª¬®¨ªª©ª«©¬®¥©­¥©«¥ªª£©§¤©©§¬¬£¨©Ÿ¤¥–Ÿ œž–¦£–Ÿž˜›•swo€xksq‚yo~vvƒ~Ž‹ˆ–’Š™•œ›“™ž’–—‡‹‡u~s_oeXg[\j]Zj[QgVSl[H_QF[NDVIGXKHYJGXJDXGDWFCTCDTCCPBCNBAS?BM<>G8>B8?E:@I=>G<KTDNUGJUEJYJDUFBNBAE:@C5;A2CJ:CD8BC4926?2;C5>D6:A76>29C3298.:<18:/68.9=27;037-98.9:/<>2:>3=A4?D6?B:=B8=D6>E7@H8FOBLSDEK<@C5>>/<<.@A2>E8=C729>.6<,7<-77,53+3-&30(20&33'25'47(3;*27*25+48,3=*4A*;A48A65>29B7=D8:?0<;-36'5;,:@2:=/57(43)44)22$03$.4%,5'37,45+31)10(14*04*57,46*57+68,3:-1:/79/56-57+7;*8>-9=19;177+31&30%60(6/*42'66*8;04:.6<138/`h\lncmqfx…ygƒyZukXsjXpgYpi[oiarfbredpderdfreiuif|pjƒwj†ybznVrdFiYIdYKeXLgWRo]SrbOqbWscUrdOkaVne\yn\€sb‚s^pZugWi\UdVUdVQ^NLXIKWGHTDDSBBQC>L@BLBAJACLACOBGUEFRBGTEAQBCTGBPEAMB@LEBIAEK@CK@CK?FM?EPDDPDEPEBOAAL>AJ>>L;@M@AIA@HA@F@EJB=QC?PC@LA>H<G;>GA?NF;LA=I==H;;I;MA>L@=K?;J=;J<GKAKQFT_SUeUSdVSdWM_RI[OFUJ@ODAPD@M@H=CNEKXJP\OPYNO[PLYNFVKFPJBKEBLF?JBCHB?D;=D;=E:@I?EODDPDCODCE:@A8@A:@E=BMB?L@CJ>AI>>F??HA=I@>K@=E;?G=?G=?FD;BF;AH;CK@XaWdneQ]UJUKGQGFPDAK>CM>FPBGOECJAFJ@EH?EIBCKBGMBEMBFMBJQGMSISXMQ[NPZMS]PPZMOXLMXJFTHGUIKYKFPCHPBKPAIRCPZJV`QXeVZiYZiYWh\Yi^_maWf[TfXRgXUgVTaRWaVWeYZj\XeWKUGFOCFJ@EGG;?H9@J:=G;H8GPCDPCCSBGUHS\OUZOPRGLQFHPFFMA>G::D7=G:BJ=AF:=@46:.9=1:=1<@1>A2:>1:?/>C2@B3@?4?=58?48=26;099/89/67-88,8:+:=.AJ@AG:2==5?=3AA4>A27=-59,57-77(44%:7*::,;<0:>3:=4>A729=/7=/32:>1>=4;;278.;A4;>29@37C23>.5=27;275040,61'63(44(/1&-1&,3'17'32&21'/1)/4,/3)33)56+46*9;.7:,8:,3:-67+77,6;.7?1:?16?/5:+14'65+@>4HE=A956/)4/'83)>:2<6/[dYfkaiqiiypf€vd|r]vk^uj^si^sibtgdughugltfsxj}rsƒwq‡{sŠ}n…yaymRodRk^Ri]Rk[Uo`WscSqcTrdTtfTpf^uib{nbsc…v`‚s\yk]qd_pb_qc]k]TbTLZLDSEDRDCQCBP@FRCITEEPBERAER?GPADPA>K=?L@>MAAND;KA?I>?G<>J=@N@BM@ANBBNBAMA@L?AK>@J=?M=@M@AL@AJBALB@K@:L?=K?@K?=E:E:?H?BOD=OB>L>>PA?PC=OB?OC?NA>L>@M??LAAJ?KMDTVMZaUZfWTdVVfYScWN^RHWLFUJFWJDQEDMCAI>FNCSZRMZNP\ONYMMYMKWLCTHFOGFQHEPGBMDAJ?CI>BK@CMBBL@GQEGRECOACJ?AFF=>C9:@6@D9@D9DI>JPFW_TMTJHNHGMECLACLABL?EOAHQFIPFEL@EH>EKAFMCGMBGNCGODKSHMTIQWLPZMNXLPZMMWKJTHJTGHUIFUHJXJFRFIRDKQBHOCIQEOWLR[OYcXZgYWh\XfZTcVUcWXj\Wk\ViX[gX[fYXfZXi\R`RHPE@HG:E8AD8:=29<18<0:>2;@1<@1;D4@7=C7;@59<15;07<17<1:<.;>1;=02AF:AH=@I>AIB38<.68-66*44'88,88,::0:>2:=3;@5:A48?19A2:D39B28@38>39?37=06=.49/6;/4;-9?1:A58@57@15@15>16?18<168-91(40'23*38.37,59*77*99.:>38?4>D8AG9AC9:=289/49-48,6;0:?07=09=28:064+72+64)54(32&.1%15*.2&,3%00$33)14*28-/3(22&14&35(69)49*5:*2:*9;-<>08>2:C7=C86>/9>/9:-85+><2NLAD?985,4/&4/&5/'7/*YdYaiabmfaskd|rc{q^vj`wi^vh]vgauhevilwjtxiƒp„v}‡ww‡zt‡zq‚wgyo^uk^th[seZqcVn^Sl\Un`UsfSufVrfcznlrf}nes`}n_zkhylm|ngxjcqeYi\N_RHVIGTHEREFSBGRCISCKVFGSCAO?EN?CL>=H;@L@BPDCQEAPECLC@J>>L@>N@@M??J@=I>?K?>J>@J=AK>AO>>K<MA>I=?G<=C8@E:@H=BJ??MA=NABH=?F;BJ?AI>AG:=C3@G7CK@ENCLXIWaNX^LSWJNRFFOCCMAAM?=F:9C69@3@C7>>2?@6==3:>2;?3=B5=D7=G7AL;AI9=D7>B7?A7BB8?A79>3:A6:B77>4;?3?B6>@4:>39>3:?5>G9AH9=A5:>3;@6;B8>G=?E9>E7:D47@3<>4;@3B89@4;B58@39B5.6=1A29>37?4;B69>0:>.<;/;:.64)75+55*77+64*51&3+#7.*[i^^h`eqihvogtcznbvkcxjaxi_yibxldwkhthx|mˆsƒt‚†wxƒurtqtn|shzqh|odxkcwjZnaShYTiZTpeRsfZvhg}os„wk~ofzmaxjbuhfpejsfhugctf[m`SgYK]OK[NKXLFRGDOBGREHTGHVIETHEOBDOBEOBBPBCQEBREGPFEJ@DJ?AL@?MA@L@>I?>I?@K@@L@AK?BK@AOABM@?K>BPBCTGCVIBNB?J>;D8:B7>G;AI?BK=@NB:L?=NA=L@ATGAXLCYLBUHBSFGUIHVHBNCBK@DHBJOFU\R[dWZgYZf[T`TR^SP[QLWNLZNP^RUdYVdXTaVS^VM^SJWKLYMNZNKYMETIGSGIVJHVJJXLLWLLVJKTKGPDGRBGRBFPBENBHVJFQEAI>CM?ELAAH=GLAGL@GK>JL@HI?GI?EJAENBGRFFRFDQCCOBELAHNCKRDOVEOSILSHKUIMVJPZNW_TX`VT\RJTHLUJLWKP\PP\PQ_RP_QMZLHUFGQAHLBIMDJOFLQHTXP[`WVbSR`QN]OSdVSdVRbUN^NMWKKSIFRHIUJHRFDKABH=CGHG@GKBFLCGI?GLAFMBHQEJUIMYMJ\JK[KO\NP^PQ`QUhUTfURhYQi]MbVN_RXdUag\TbVRhZVm_SbUOWLNWLPZKQ]KLXJN[OO]OSeWRdVQdUQdUQgXOgXXl]Yp`XtaXtdXqdSi^Wl^WoaXpd]rfYl_Zk]amchrigskcqeanc`nbbohgwohwp}‰ƒ“’™›œŸž Ÿž ¡Ÿ £¡£¤¡£¦¢¤¨¢£¨£¤¦¤¤¤£¥¢£¤¡¢¤©¤¥§£¤¥££¦¥¥¥¥¥¦¦¦¤£¥£¢¤¤£¦¥¤¦¤£¥¤¤¦¨£¥¨£¥§¢¤©¥¦¨£¥©¥§¤¥¦¤¥¦§¤¦¦¤¤ª¤¥ª¤¥¨¤¦¨¥§¨¥§§¤¦¨¥§¨¥§§¥¥§¥¦©¦§©¥ª¥¢¦©¥ª¦¥©§¦ª§¦¨§¦¨ª©«§¦¨¥§¨§¨©©§ª¨¥§©¥§©£¦¨¦¦§¥¤¨¦¦¨¦¦¨¦¦¨¦¦¥¤¦¤¤¥£¦¦§¨©¦¤¦ª¥§¥£¥¥¥¦§¦¨¨§©¦¦¨¦¥¦¦§«¦¨¨¦¨¨¦§¨¥§§¦©¨ª¨«¨§©ª©«§¦¨¨§©¨§©ª§©ª§©«¨ª¨§©¨§©¨§©¨§©¨§©§¦¨§§§¨©©§§§£¦©¤¥©¨§ª§¦ª§¦ª¨§«¥¦ª¨§«§¦ª¦¥©¨§ª©¥©£¥¦¥§§¥¦§¥§¨¤¥¥£¥¥¥¤§¤¤¥©¦¨©¨ª§¨¨¤©¨¤¥¦§¥§¥¤¦©¨¨«©©©§§¦¥§¦¦§§§§¨¨¨¦¦§¦¥©£¥¦¥§¨§¦¨¨¨¨§§§§§§¥¥¥¥¥¤¤£¥¦¥¦¦¥¦¥¤¨¦¥¥¤¤¤§§§¥¥¥¦¦¦¥¤¤¡¥££¦¤£¦¤¥§§¤¦¦¢¤¥¤¦¦¤¦§£¤§£¤¨¢¤¥¡¤¤¨¦¦¥¤¤¥££¤££££¥ž¢¢œž‘“’‘’—–•™˜•”„ƒr{qktjjrh\dZY^TU_VaodYf[S^RT]PYaTWaTTaSSgXQgXRi\Ul`Wo^Wo]Wn_Um^Rk]Rl^MeXNdVRcVSdSQaOLZIDU@EQADN@EMBGODCK@AE8?F5>G7AI>AJ>@JH:?H:DL;EL=DHF8?H;>G:;D6=E7=D7CD:@E:>D;AH?IVEGSC=H9EOE@E:;A49C6;C6@E818<,?@5=>286-33)68.@J?AM<>J88E26@/4>-4>.6A4:B7:C88@58@59A5?D4CE8CD787,53(1.&2,"74*@C7:A48A48C68:17906:0;B5FRB>L8>I9@K:DK=35:/4<03<04?08C37B0:C1AB6<<066*35&24%58)18*78,79-18*39*9;*88*68)7:+7=,6>-7@/7A0@E5DH818<-88*64)54(77+68,77*65&62'3-%7/(^ma_h^fmcltifvkjwmnyokwkm{oq„wr…s…|v„y…y†‚tŠrƒuw€sm|mr€up}qj{og|nf|o\sgVk_N`SN_ONeXUqc[whj€qt„xj}qbtg[naVh\VaVZdW`m_]sdXqaRj[MeUL`QIZLHUICRDDRDETFCTHARHBSEETEFTFIUGEUFCSEEOCCI>@GNB>M@>J??J@?J@@K@AK??J=?KA?J>AI=EQCGVJBTIANB=H<MD?LDDTLDXPEXODXNHXNIZNBSFBMCBLCCMEMVOTaUWfYVfXScWO`RP_SQ`UM^SQ\PTdWUg[RdYK^QK\SJ[PIYNJYMMYMFTHBQDFPDLYMMZNO\QP\QJTJDOHFPEHRCFQAFPBGOEJWLKVIENA;E8@HDJ@DL>JSEKWGJTFHRDKTGHQDGODGLADI=EK?HPDFPCFSFGSFDTFBNABJAJOEMTEPYFRVLPWLOYMOZNS]QZdX`h[V_SMWKMXKQ^QVcWWcWUcVRaSKZLJVHHSCEMBGOCJPEHPDHODRYNT_PP^NM[NK\NSbTP]QIUGIPDEJA@H>AK@EMADLBCH?AGBL@DJ@DG?GJDMPIINEGK?EK@FOCGRFHUIHWKL\LKZLO\OO\OP^PP`RRaQOcUNdZLcWQcV\k[_gZVdVVhZUfXO\NKSGLTJR[LPYKJSHGOFOXNR_QTcUSdVQeVOeVNgXUj\Tm\Tp]VpaSk]Vi^Vl^Yqc]uibyj]oa_n_`ka]h_aka_mbbpd_nbcrmhxrhzr{‹…ˆ’“——››œš›žžŸžŸ žŸ¢¡Ÿ¤£¢£¢¡££¢ ¢¡ ¢¢§¢£¦¢¢¤¢¢  ¡¤¥¥¡¤¤¤£££¢¢¥¤¤££¢¥¥¤¤£££¢¡£¢¢¥££¤£¢¤¢¢¥££¢¢££££¢£¢££¢¤¤¢§¥£§¤¦¦£¥¦£¥¤¡£¦£¥§¤¦£¡£¤¢¤¥£¥¥£¤¤¢¤¦¥¦¤¢¥¦¤¦¦¤¦¤£¤¦¥¤¤££¦£¥¥£¦¥¢¤¥¡¤¦£¥£¢¤¦¤¤¥££¦¤¤¦¤¤¦¤¤¦¤¤¥¢¤£¡£¢£¤¤£¥§¤¦¨£¥¦¥¤¦¥¥©¨¨§§¦¦¥¥§¦¦§¥§§¦§§¦¦¦¦¥¦¦¦¨¦¦¥¤¦¥¤¦¥¤¦¥¤¦§¦¨¥¤¦¨¤¦¨¥¦©§¨§¤¥¥¥¦¦¥¦¥¥¦¥¥¦¥¥¥¦¦¥¤¥¤¤¥£¤¥¥¢££¢¡¢¤¤¤¦¤¥¦£¤§§§¦¦§§¥¦§¥¦§¥¥¨¥¥¦¥¥¦¦¦¨§§§§¦¥¥¥¥¥¤¦£¦££¤¨¦¦¦¦¦¥¥¥¡§¥¤£¥¥¤¥£¤¤¨¥¥§¦¥§¥¤¥¤¤¦¥¥¦¥¤¥¤¤¦¥¥¦¤¨¦¥§¥¤¦¥¥¥¦¦¦¦¥¦¥¥¥¥¦¥¥¥¤¥¥¤¥¥¥¦¤¦¤£¦§¥¥§¥¥¥££§¥¥§¥¥¦¥¥¥§¥¤§¥¤¦¦¥§§¥§§¦¨§¤¦¦£¥¥¥¦©¤¦¨£¥¥¥¦§§¦¦¦¤¤¦££§¥¥¤¤¤¡¢¢¡ Ÿ˜™˜—›š—›™•™•Œ}‚{flfkpkdke[cZYbWOcW[qcWk]L[NOXJRTIJQCNYLRbTQdUYj]]naViZThZXk^Vn^Up_Po_Pk\MfXPgYQgUM`OHZHETAEQADMADLAHPEBK>>G9I7?I=CLAFNAMVIMUKJRLCKECNCBQCDNBDN@@E8@C7=@4>D7EH>?D::B7CLACQDGUFLXGFPB@H=CI?CH>AF;BD8@F:=F:>H;>H;>D7:C7?E9EJ?HMA?H;@K??O>DQACN@BLAAL@@NCDNEAGG7;F7=I88D28C28B26C26A39C7;F9=G8>G7BE7??264)63(40&2/%.+"76,@C4>B47?0CM>?E7>D79>18A57B58F8?K;=H8;C3=?4;=18;,77)56'78(4;+37(37*2:+7<-88&88,67)48+28)5=.9C26@/;?1/5;+68)57(36'25&54)54(76'75(52&52(`qcenaik_gh[bh]jj`rqhuqm{}v‰‰ˆ˜•ˆ™“†‡‘…‚„v…~o~{quzohvjixjm{mhzkcyj`wjWnbOeXJ]OIYGK]QPhX[uch}nk}qcwm`tgXqbTj]TfYUdVYl]\ud\xfWtaSo\PgVOaPJ]LHYGFXEEXEDWGAWICXKGYLK[MKZLM\NGYJESFCLAAK?AQE:NA:M@?JA@K@?I=@K?>KB>G>BJ?BL@EQF@PF?K@>J==H<>H<9F:@MACUIATJAOG@KFBOKCUMBTNHZRL^WEYP?PGCODKWNQ^VWf]\na[ob[l^UeYRbVVgZUeZQbWR_SUdXPdXH`SD]QH^THZOGXMETHFSHCRE@OAFQFP]QO^SRaWO[SKVNEOIFSHISFHSDIQFHOGHVJJUIEN@BK=BK>HRHMXGKWFHUGGVHM]OFWICRFFQFFMBFNAKVGLYILYGKWGIUGFRDAMAAKABJBIACG>@F;DI>>G;@J=DJ=CI?CJCMSNUXPKNEFL@GMCFODHUIHWKFWJHVHIVINWMQ[PMYLLZLN[KL^PI^TLcYQdVVgWXbVR_QS_QP]OITGISEKTKV`SU^RHPHINIMSLQ[NR^OO`RObTLaSPgYUm]Tn]Vr_YsdUm`Ymb^re[te_xjbxj]m^bm^^i`\g^`nc^l``nb[j^l{texomƒwt‰}|‹‡‘Š‘–“—š™›žž¢ Ÿ žžŸž›Ÿ››Ÿž›Ÿ ŸœŸŸ ¡žŸœ›ž ž˜œš™œžžœœœššŸœ›˜™œššŸ›ššžœœ žžŸ žžžššš›œœž ¡¡Ÿ žœœ¡ŸŸŸœ žžžœššœŸœŸžŸœœž      ¢ ¢¢ž Ÿ¢Ÿ žœœ›¢ž£ŸŸ£ ¡¡  ŸŸ ¡¡¡  ž¢¡ ¡ Ÿ¢¡ ¢¡ ¢¡ ¡ ŸžŸžžŸž ¡ ¤¡¡£Ÿž¢¡ ¥¢¢£¡¡¥££¤£¢¤¡¡¥¢¢¦¡£§££§¢£¦¢¡§£££££¤¤¤£¤£¤¤¥¤¤¤¢££¨£¤¦¤¤¦¤¤¥£¢¤££¤£¤¥¥¥££££¤¤¤¥£££¡££¢¢¢¢ ¡ ¡¡ ¡¢¡¥£££¡¡££¢¥£££¡¡¥£¢§££¦¡¢¢¢¢¢£££££¥¥¥££¢¢¢¢¢¢¢¡¡¡¥££¤¤¤¤¥£¡¦££¢¢£¤£¤¢££¡ ¤¢ ¤¢¢¤¢£¤¢¢¥¤¢¥¤¢¥¢£¤ ¥¤¢£¤¢¤¢¢¢££££¤££¤¢¢¤¢£¤¢£££¤¤¤££££££¥¢¢¥££¤¢¢¤¢¢¦¤¤¦££¢£¤ ¡£¡££¢¤¤¢¥¤¢¦£¢¥¤¢£¤¢££ ¡£¢£¤ £¢¤¡¢¥¡¢£žŸ¤ ¡¢  ž¡ ¢ žŸ˜ž™”š•’˜’–—‘ˆŠ„vytlpk_e_YbZT`UQfWUn^Sl\LbSKXIJTDIQAIVHK]NK_PUi[RcVJXMO_TSeXTk\So_No^On_JhXHcSKcTI_MH[JDTCJUFENBENBGOCBJ=@L;>L8@NEN@GM@AC7>@4ANCASE?RC@R@?PA>MBBOEDNDBNCDG;?E9>H:@L?DL?EI=>GH8@L>H:?H7>G6?I;I=CNADOBJVHIVHEQAETGBQA>M;;F5;E6E6<@344(22&21&10&41*76*77)58)5:+:@3AG7?D5;@2GZFKZKHUG=G:9C39?09?/9A5G9DM@BG9;?058.69-7:+77)67'66%19&6:*7;,9B37<,88'65+78,48,4<.4=.9C28B59=15;.6?1:F57A14=.5:,7<,;>08=.7>/<9/86+65'77'23$66)gtlmqhmnajm]ondpmctnezsk„w”‘‹–š–•š•Љ‚…}€{sxoxxmqylkxjkwghsddsd_rf^vhUoaMeUJ]MGWFJTIObQTmZYt`]xiUwjZvhZqdXk`QdZO`TYeYeugk~obyj\ug^sfSh[LcTG^OF]MF\ME[MG[OE^PH`RLaTJ]PN_NN\IJUEEOAENAEOBAPC=F<K?@I>EI@DLABK??G>=G=;H<:I=9H9>JFSFFTI@NC>JBALD?RFEWKL]ON]NGQFAK@FOFSbZVkcWne[ne_peVj_Wk]WhZ[j\TeXN_SP^SSaVTdYL^UJ^UH]UJ[OFWJFUJGUIHWJFUFHWKJ\PH\NM`RP_QPZMFQGFREIVFMXHMWJKUIGRHGRHFQGEODCK@HOEFTJHXMDUJIZOHYNGXMHVKJTIGODHNAJQBLVFNWHMTEKSFGNAFK>CHBK?>GBI>DH=DD:GG=BE;AH=IH?BF;FJAT]RX]TFIADK>IQDHREITIGTHIWKJTGJTHLVJKTILUKPXMK\MHZNLaXPd[Ue[WcXK[ML[MNYLOXKLTGISENYI_i[V_RENCFPFFPFITINZNO]OO`ONeROjWPj[Uo_YqcXrdZwh_~pnv`xl_xljƒwxŠv‚xame^kcesh`ncbpdWh[t{k}wqˆ€rŠ€o†|}„‰›”˜©¡£°¨§¯ª¤­§£¬¦¢¬¥¡ª¤¥®¨¥¯¨¦°ª¦¯©¨®ª§¯©¨®©£­¦Ÿ©¢¤®¦¤®¨¥¯ª¤®¨ž¨¤£¬©›¤¡Ÿ¦¢¤«¨£«¨¢¬§ ©¦ ©¦¢¨£¡§¢ ¦¡Ÿ¤¢¡§¤£¨§¡ª§ ©¦ž§¤Ÿ¥£›¢Ÿ› ™Ÿ›¡Ÿœ¢Ÿœ¢Ÿž¤¡£¡›¤Ÿœ¦ Ÿ¦¡¥ › ›–œ™—™™™œ›™œ™˜œš› œšŸ›™Ÿš‘—‘ž¤ž£Ÿž¤Ÿœ¢œš¢›¡œš¡œ–œ—“›•–ž˜££œš ™œ¢› ¦  ¤ž¥œŸ§žž¥žž¥Ÿ¤œ£œŸœŸŸ›˜›——š–œŸ™Ÿ£ž ¤ ž£Ÿ£Ÿœ¢ž£žž¡Ÿ š›š˜œœ—š•œš”›œ—šœ–œœ—››–ž˜Ÿ ›šŸš™žš›Ÿšžžš ŸœŸœ™šžž›žŸšš™¡œœŸ› œŸœ  Ÿž›žœ¡ŸžŸœž ›Ÿœžš šž¡›¡ ›¡ š  ˜ŸŸ˜ŸŸ™¡Ÿ›  ž¢¡Ÿ¡¡Ÿ¡¡Ÿ¢¡Ÿ Ÿž ž ž¡Ÿžž žŸ¡žžœ¡¡Ÿ¡¡Ÿ¢¡Ÿ¢¢ ¤£¡  ž¢¢Ÿ¡¡Ÿžžœ££¡¢¢ £¡ §¡ž¦£ ¢ ž Ÿž¢ŸŸ¥Ÿ ¢¡¢¢Ÿ¢Ÿœ£Ÿœ£Ÿœ¤ œ¢¡šŸž™œ›š—–”•”’Žˆ†{wdh_\cW`h]]h\WjZTp]NjZO_QMWJIVHH[LN_QI[MN[OUaT`j\ci^W`UO^SUk]Rn^OlXMgUH_MJ`MJ^LK\KK\KI\KM_OIWIGTFGTGAOC@MA>N?@O?EO?BI=HK@KPFIUJHWKIUHIQDIPCGTDLTEJL=BB4>D49C3II=CI;FQABPBCTH?OCBKAMACMABOBBUDCOABI9FJ:HQ@KUEIQCDOCFODGPDFO?EL<@J8BO>KVDOUFKRCHQDLTGAK?AJ=CL?AK;@K;@L>M;@F59C58F9CQFBOBFPCIZGEWDCWDOaPTdRP^NL\NAPDAQCAPC@OADRE>VG@SCQ?AO?:C5<@-8:)43'2/%50&63)46-14*25)73(61):7/<;1;;2CF=FPEAPBDVFIZIP]LKUG;B6-5A/8A1;A39@19@1:@5=C8;C89C59A.4=*7@-=F2PB?KA=G=>H<K;K?=G=BJ??H=>J<=H==J@>LDCOGETHGTIHUHFPDCJ@BI?FQERbXZne\si_qf]maXi^\m`^l^Zi[N_RIZNJ^RMbVOeXI`SHaTIbUM`SJ]PL\QJZMM\OM]LIZMHZKG\NNaRSbSQ[MDODFREIVFMYIOYJMXKKZLHUHGUHHREEOCGQDIUJJWMJXMKZOKYNHWMIWLJTIJSGHPCGQBJUDKUFITDGPCCL?EL@CK?DI>CJ?FPDJSFHTGLTGJTHIUIFSFN\NMWJMUIKSHMWINWJLXLS`Vn{tƒƒZeZWcYYg[SdVOaSQaTPaTRcVK]NJYJKXHITGIUHO]OLZNN]QZj^YnaTj\ObUN`SK^OEUGDLCAJ?@I?AJ?CK?DK@EJ?CE;DD:EE;AD9BI>DH=BH=EKAJNGNRHGJ@EJ>JREJREKUJMXLMZNLVIMVJLWKLWKMYNQ\QJ_PKcUOj_Oh_Sg\UeYL_PL]OKXJLWJIUGKWJL[JZgYR\NDKAHPFHQGIVJKYKP\NN]OPdTQgWRj[Vn`Xqc\vhc€qlŒ~y„w‹‚{Ž…ƒ”Œ„’‹x†itigshbpe^l`aocbrft{sƒ|•Œr‹‚r‰€•‹Ž££´®«¸³­¹´¬·²©µ±¨µ°§´°ª·²«¸³­ºµ­ºµ®¶´­¸³­·³©µ¯¨¶¯ª¸±­¹´¬¹µ©µ²§´±¨´²§³±«´±«¶²«µ²ª´±§´±©µ²ª³¯¦°«¥¯¬©²®­µ³®¶µªµ³©µ³¨²°©³±©³°©²¯¤¯¬§²¯§³¯©´±®¹¶­¸µ¬¶´¬µ²¬µ³¨²¯¥­«ž¦£¡«ª¨±¯©²¯ª²°«³°«´±©²«ª²¬«³®§°«¨°«§°ª£°©¢®©¢®¨¥±¬£¯ª¥°«¥±¬£°«¥²­£¯«¥±¬¥²¬¦³¬¦³¬¨µ­¨´°¥±­§³®§±¯¤®« ª¨¢¬¨ ª¥ «§¨²­¦±«¤°©¥¯©¤®¨¥°©¢®«Ÿª¤š¤ž˜¢œ–Ÿš—¡™—¢œ™£›¤žœ¥ŸŸ¨¢ž¨¡–£›§¢§¢œ¥¡›£ž˜Ÿ™š£žž¦¡›¤Ÿ§¢ž¨£œ§¢¨¢œ§¡™£›¤žœ¥Ÿž¥Ÿž¥¢œ£ž™ š˜Ÿš•›–š£›œ¥Ÿ™£œ—¡™” —–Ÿ™•Ÿ˜–˜šŸš›¡œ£š š—œ—œ¡›œ ›š š™ š˜Ÿ™›¡œœ¤žœ¢š¢œ›¢¤ž›¢˜Ÿšš š™Ÿ™œ¡œ¤žž£žž ›™œ˜’—’’—”’—“•™•’—‘””—’–™“š—™œ–—Ÿ–—ž˜—™‘𕇒†‚Œ„nxoZcY_i_bmbanb^i]QeXOhYMaSH[ME[MJ`QOfWKcTCXIJ[LR\O[\PPTHJVJIZMRiXTkYLbRLaPOaQM_ON]MQ`OQcRQaQR^QP_QM\OCUHESEFVFETBBN=AJ;IK@GMACMADQCGQDDK=EL=EO?IO@DH:?C5?D6@E9EGAL?OB@L@ARDBWFESGCL?EL=KVGMWJGNBDNCDPCGQDKUELVFPYIM^JL[GO[JNYJFPDBOA>K??M??M??M@>M=FUDOYHGYHFZKL^PSaRHZHFP?H<9=-45'44(32'41&96+;@76?43:-:;/64+65-:7-62)97/@A7AIAG9AH:BM@CPBDQ??J9:A47:07;-6:*7:+8;,88*99+89-;>2;@4=A5>B4<=-69-5;.4>.3?.7@359.8>.:>1<@59?4/:A1;E4?I8AJ=@H8I??I=?G>H>>I=?L>>J=;I;C8?E:=G=?J@AMFCOFEMFFODDK@DJ?CH=FKDHSHWg[^qe_ui`rfYk^WeZXfZYfYSbUM^RJYNL`TRfYPcVH^OKaRRgVSgZPfXSfZPcVQbURaQM_OJ]NNaRObSTbTN[LERGIVIJWGIVFHSDITGJZLIWIFSEGQDDOBFSFGSGISGKUIJTHHTHGTHIVKJVJLVJJTGJTGKVHGVHGUGGSFEQDEQEGQFELACL@FPDJTGJSFGPCFPDGTGDUGGXJLYKMWJMWKOYLLWKMYMXbXo{ry€v`i^]g]VeYRbWPcWSdVRcURbTM]NNZJIUEHSGJVJKYMK]PN_TUe[RdXUfYQcVN^QL]OEUHFJCDJBCLBCLBCLBDMAFK@EG=HEBI=CGFKPB@PCASDG]KL]QHTHFQDFQECOCHQEFUFFSEHREKVFPZK_iY_mXVdNOYIMXHAL>CMAATFCWHCWHCVGGYKN^OQ_QI]NC[MGYKI[LH[KCWDAO@AJ>DLCALB?PDESCIZIObSTj[ShYQeV`k[V`QIUFEVDDXF=SA=TGBTDM@IWKPVKCF;8<1:8.75+74+87.@D9GN@MYHOYIS\LPYIHQAEP?DNBDO@BN<>G79?3:<37:,69*;>/8;,69*7:+;;/<=126,48,:=069)4:/19-4>04?16>28<119?27@3;E8@IHK>;F:;I=;I=9G;=L>:I<>K?>I>>H>9D9?C7@F;@I?AMC>LD@MECHA@EDH=DH>AJBO@DPCGNBGM=CM=AE6AG8AJ2;?3RE:PD@THCYLE^PD\LBUHFTILVLJXLHZMO^PK[MH[LK]OIYMVg[TeUP`POZJJUE@K;;G7;I;>G8AH8=F7;B6<<375.58-9A48?/6<-7;*4?3;L?IXLIRG?E:9@588/55+23'36+38-CK?HQCFP?NZIU`OQ\LFQABLBM<;A389/85+68+47(:=.79+69*58)98-89-37,6:.59,59)/8+4<05?3:B7H;?I<>F6:?08;,<<2=>4îÖÍéÚÎïãÖÜȽѹ©Î¶¦É²¢Á¬›¸¤”±žŽ¤‘…š‡{›ˆ{›‰{¡Ž~¡™Œ{ˆ‰xy„striuhfpe^j]\h\UdVQaSN^QGVJHTGBQEDRFHQGHPFFSHKXPO[PN^QIbTRm_VndXf[VcYXf^_rj\|pV}qTyqUtjWqdWm_Wl\OeUGYNHYMHWJP^PWcXMZPM]RRbWP`TGWJHTHGQFAK?>G;G<H<@I>;F;=F9@I=?K@>KA;HAE?>H?AMAGTIIWNJZQVg[]qfZofZrhQh]KbUM`WOdXPdWPcVO^SLXPKVINXLJTHGREGQDLVIVcWZk^Ti]Sj\NcVObQNcROaTP_UJZQKZNMZNLYOLZMIYHJXHHUFJWIN^TJXOBMDHSIFUKEWMCPDBK@AG=FK@DJ?IRGLYLLZLL\NO_QM[MN\OJZLDVGESHFTHETHHTIHRFIUIQ`TVhYSdVO`Q9B6O]PNaRJ^QIYLKWLJWIEQFFQGITJJVIHTHQZNZcWYeYSaVQbVObWSh[hxl\f[R[PQXLKREDNCHQDKVFOYKR[PRZRRZONWKNWKITHGUFGUGGRGJTILUIHQFGREGSDGNCELABJ?CJ?BI>BJ?DL>EJ=EHFLAEM@IREKUHKVJJXLK[NMYMS`RVcUSaTScSXjX[h[Zj_Zof]siewm]l`XfYR`RM[MQaSRdUObSO_RKYMO[OLYNIYLJ[NL_SM]RQ^SRcVUhZZqcb{lhtl†ytŽs‰~r†}r„{esj_kdjtmsyzŠƒ`pd`qebtjezou‹•ŒŠŸ™¢“¦¢–¨¤—©¦˜ª¨¨¹·¯À¾±¾½²¾½²¿¾±¿¾´ÁÀ³À¿µÂÁµÂÁ´ÁÀ´ÁÀ³¿Â³¿À´ÁµÃÁ´ÂÁµÃÁ´ÀÀ³ÀÀ²¿¾³À¿³À¿²Á½´¿½³¿½´À¾²À¾³À¾²À½²ÀÀ³ÀÁ´ÁÁ²¿¿³Á¿µÃÁ³À¿³À¿³À¿´ÂÁµÃÁ´ÂÁ´¿¿µÀÀ¶ÀÁ¶ÀÁ¶ÁÁ¶ÁÁ·ÂµÀÀµÁÁ´ÀÀ³ÂÀ´ÃÁ´¿¿·ÂÁ¶ÂÀ´À¾µÀ¾¶Á¾³À¾³À¾³À¾´Á¿µÂÀ´Á¾³À¿³À¿µÂÁ³Á¿²¿½²À½µÀ¾¶Á¿·Á¿´¾¼¶Á¾µÀ¾³Á½´Á¾³À¾µÂÀ³À¿²¿¾´¿À´ÁÀ±¾¼²¾½±¿¼²¿¼µÁ½´À¼³¿»µÁ½´À¼³¿¼±¾¼±¿»²À¼±¾»°¾º±¿¹±¿¼±¿¼²¿¼±¿¼±¾»°¾º²¼¹´¿¼³¾»³¾»³¾»³¾»´À¼²¿»²¼¹´¿¼´¾»µ¾»²¾»²¿»²¾º°¾º±¿¼°¾º°½»¯½¹°¾º¯½¹®½¸®¾·®»¹®¼¹­¼µ¬»µ«¸µ«¹·¯¼¹¯¼¸°½º¯»¸¯¼¹°½¹®½¸¦´°ª¹µ­¼¹«»·©º¶­¼¸­¼¸­»¸¬»·¬»·­»·¬»¸­¼¸®½¹®½¹­¼¸¬»·®»µ®½¶¬¼µª»¶«¼µ­½·­»¶«¹´¬»µ©¹´§·±¥µ¯«¹´­º¶®¸¶¬¶´¤²«˜¨ |’Еޕ{ˆu‹‚tŒƒ ”ˆ¡—Zodut‡zVbVV^QOWJOVJKPDMQEORFHNBLVJTcVVj\RjYLeSPdZM`UL\QGYLIXJHWIOZJKYJM^PP`SM^QJYLJWHMXIJTCFP@GSDBM@DLABODCOCHQDENBBL?>I9AJ:GM?JPBFL?@G;9A78>27;08=-7>29A4?E<@OBCVGO_NJXHIYHM_PKYLIWLIYNQ\PSZMJUGHPEGQDCK>DJ>JPBV]KV^OV_PT]QNVKGOC@TFI_PJcUH_P@REGSHGVKGYOAZOKaXRk_OoaQj^D[PCXNM_SReVSfVRdVN_RL]PFTG?J?;E:BQDGSFCK??E8:A57?36@3;@2?A2>C7=@7>;463.58/7?3@K;?I99@26@35E97G<=E<=C8:@468.78,45*15(3:/:D:JQFFPDIVHUdVSaRIVGEQBDPABM>9B59=/67)87,66+79-68,7:.58,87+45)48-6:.6:-5;*7=-:A37=16>26?15@07>-19+5=29@58A5:D7:B3:C47A29B4:D6I?>J>=K>H<>H;HA>IAAMDGVKQcXJ_TRh_dxlbwn\skTmdJcYIaVNe[Of[IaSJ]PGVMGRIHRDDMADOCCNCEPFIUJU^R[i\Yk_Tk]RhYOdSQeTQcWM\ULXRLZQM[OHXMHVIETDKZIMZKLYKH\MK[MFSFJWIFVICVHDTECM@AICG7CF7>G74:>18?1;D64>14:2UdW‡š‰YhXKVFITDHYJM[NP^RP^RS^QSWIHRBIRBIPC@F9CH:VXLITEGTGQ`TSbUJYLFTGK\NL_RF\OJ^Ro|sEOE8D9izrm‚zAWPRncY}oSld=YQB]TMhZNdSL_LG\OL_RSdW\g\PUL>>6AE5;C99D9=H;=C5;A38@37=355/31+03)1;.;G6@K=?G:=E88E:8F;?G=>A767,62)74)55&56+28.4<4?G.:=-7:.7;.2:*5?-9C2;D6:B7H;8D27B27A1:D4H8@J<=G77A19E6=J=µ›ûíßÿÿôÿôäéÏÁÞÄ´ÙÀ°Ô¼¬Ë¸ªÀ°£±¡˜©›ªŒ£›ˆž˜†šŠ‹Ž~v~oiyjh{mduianc\l`WgZWgW[kZXhWO]OLXMIUKIRHFOEELDDJDAK@DOCCMAEOBCNACMAJMEKMGOVOZkb`}rU|oQvjJnbHi]KfYG[METCHSFFWIJ\MP^PQ]OQ]PVeUardTeYLYNITIOWLFSEDOBAL??J>=I>8H=@J>BK@@K?>J>?K@@L@AK?=H<:E;;F=:E<E;>G=?K@=LA;MDASJJ[PQbWOeWWm_m~pn€skzqWhaJ\UH]TQ`YK[ULZRHTKDSGAQEHSGGSDERCDRBCPBEPFLWKTbUVj[TiZPcUP^SRcUTdVP_RK^OI\NE[LHWJGRFISDMWKJWLFTKHTILVJLVJKUIGVH@RCDMC?K?@H=CG;EI=CK>COEFQGITJMYQ\i`erkRYTFOHGRIDNDEODJTGLWKO[OUcWYi]XcYPYPUaR[j]Yk^RaWN_SKZNITIKRLJUMIUJFUIJXMQYPUaVPbUQcVO_SKWLQVP[dZR]RMWJNTGLNCGRFJVJGYIL^MHZHJYJJUJMZNLZNL]OPcTLaRO^PJWIERDFQEISGISFHRBEPCGVHIVJKTKJPFEN@CL>DL?FNDEMBHPFFUFHWFIXJKXILZLN[M^hXeo_doa^k][k^[l_XqaZpb_pebtg]obObSO`RKZLP\OR^PVbUUaUTaSRdVSfWRdWSgXRj[Wl^Wm`VmbXpf\vib~na‚vj‡}x‘‡…š‘€”‹p‚yx‰€mƒz`zpf|sj}tfzqf{td|uh‚zm‡~‚›“™°©«¹³«·´©µµ¨µµ©µµª··¯½¼±¾¾±½½²¾¾µÀÀ¶ÁÁ´ÀÀ³¿¿³¿¿³¿¿³¿¿³ÀÀ¶À¾´¿¾´¿½´¿½´À¾¶Á¿¶ÀÀµ¿¾´¿½±¿½³Â¾³Á½¶¿¼µ¿¼´¾¾²½½²¾À²¾Áµ¾Â¶¾¾·¿¾µ¾¾³¾À±Á½¶ÁÀ²¾¾±À¿±ÁÀ±ÁÀ´ÀÀ³Á¿´ÃÀ±Â¿±Â¿³Á¿¶ÂÀ·Á¿¸À¿·ÀÀ¸ÁÁ¶¿À¶¿À¶ÁÀµÂÀ´ÂÀ³Á¿´ÂÀ´ÂÀ´ÂÀ³Á¿´ÂÀ°Â¾°Á½²Á¾³À¾¶Á¿¶ÀÀ¶ÀÀ·ÂÁ¶¿À³Â¿³Á¿³Á¿³Á¿³Á¿²À¾³Á¿´ÂÀ³À¿°ÀÀ±Á²Âµÿ´Á¾·À¿µ¿½µÁ¾´Â¾±À¼²Á½±À¼³Á½²À½±À½´¿¿³ÁÁ²À¿®¼»±¿½¯½¼³À½²¿½³¿À±¿À³À¿±¿½²¿¾±¾½²¿½²¿½²¿½°½»°½½±½¾±½¿²¾¿µ¿½²½º¯½»¯½¼®¼»¯¼»±¾½±¾½²Á¿±¾¼°½»°½»®»¹®½»±¾¼¯½»°½½®¼»¯¼º¯¼º¬»¹­½º¬¾»­½º°½»²¿½±¾½®¼»®¼¼¯½»®»¹­»¹³½¼²½»²½»±¿»®½¹­»·®»º°½»°½»¯¼º°½»¯¼º°½»¯¼»¯¼º­º¸­º¸®»¹®¾¸¯½º¬º¹­»º«º·¬»¶«º¶«º¶¬»¸«¹·©·µ¨µ´ ´®£µ± °­ž®ª™¨¢Š™qƒvr‚tgtfVaSck^_fZS[KKRCEJ;EGA5=C98C87D56;<3>C7=F8?M>?M<@J>;B7=?5=<275,31)44+47,;B7;F9;G:8G6:F9CLABGA>?656-45(54)46*14(37*9>08>8AM?PaNVjZOcWJ]PP`UJZNBOC@K>?H:7=.77,63(76+69*:;,=9*61(20'7:.D8=?37>1;<198-64)99.9:/:D4;F6=H8?I:=G7BH@EMFFVNQf]YtjWvlNpbMnbMnbIdXEYKBQDDSFG[MJ]OQaSP^PP_RQbQSeWQaUHVLJUJKUJHTGFQDENBDNB?L?=L?BMAEOBCPCANA@L?@M?=K??K@=J?@KA>H?;E<;C9>D;?E<=E;>H>=J?DI>DI>AJ=BJA@J?ALBISJT_Y]iaX^ZJSLCMGCNCDNCKUIL[NQbUUhZWj^ReWN_SZhZ]m`Ue\N_UJ[PHXMIWKMYQMYPIYLIWJJXMKUKM\PK\ON_RHWJFPFGMBDL@IUFMWIKSGMRGHTHIWKOaPN`ON\LN[MNYNR]QR_SQbSRdUL_PMYKIUGFOBFPCIREISGJRBITFJXJJVKLUJNSJIPEGOCHPDJRGIRFJSFIYHJYIN]OLYKN[MSaTeoaepabpa]m_Zk^\m`ZpbYmaXi^Yh]TcXM]PO\PNZNPYNV_RW`TUaSTdXQgYPi\Wm`XoaUqbSn_WrdYtg[wj`~pg†wjŠrŽ„u„x„€“‹‘‰‹•‘‰š“€”ŒuŠ‚m‚{k‚zp‡‚n„€q‰„}•‘¦¡£¸´¬¹³­º·­¸¸®¹¹¯º»¯ºº°½¼°¼¼±¼¼²¾¾µ¾¿´¾¾±¾½±¾½¯¼»±½¼±¾½²¿¾´¾¼´¾¼³¾¼²¾»´¿½²¾»´¾½´¿½°½¼³À½±¾½°½½²½»²¾»²½½³½½±¾À±½¿³¼¿´¾½´¼»³½¾³½¿±À¼¶À¿±¿½°½¼²¿¾µÁÀ´À¿µÁ¿´Á¿´Á¿´Á¿´Á¿¶Á¿³Á¿´ÂÀ´ÂÁ³ÀÀ´ÁÀ³ÀÀ¸ÂÁ¸ÃÁ·ÃÁµÁ¿µÂÀ³Á¿·ÃÁµÁ¿µÂÀ³À¾³À¾²¿½¶À¾¶Á¿¶Á¿·ÂÀ·ÁÀ¸ÂÁ¶ÃÁµÂÀ¶ÃÁ´ÂÀµÂÀ´Á¿·ÃÀµÂÀ´ÂÀ¶ÃµÃôÃöÃÀ¶ÂÀ¸ÀÀ¹ÁÁµÁÀ´Á¾µÁ¿µÁ¿µÁ¿¶ÂÀ¶ÁÀ¶ÁÀ·ÂÁ·ÂÁµÀ¿µÀ¿´À¿µÀ¿·Á¿¶Á¿¶Áô¿Á´ÁÀµÃÁµÁ¿´À¾µÁ¿´À¾´À¾µÁ¿´¿¾µÀÁ·Âö¿¿µÀ¾¶À½²À¾²¿½²¿½²¿½²¿½³À¾µÂÀ³À¾´À¾²¿½µÂÀµÂÀ´ÂÀ²¿¾³À¿²À¿²À¿³À¾±¿½°¿½±À¾²Á¿´ÁÀµÀ¾²À½³Á¾²¾½±½¾²¾¾±½¾´½½´¿¾´¿½²¿½²¿¼°¾»³¿½²¿¼±½»²¾¼±½»³¿¼°½¼²¿½²¾½±¾¼¯¼º±¾¼²¾»±½º°¼»±¼»°¼¹±½¹¯¾º°¾º®¼¹­»¹¯¼º­»¹ª¹µ§·´©¶¶§µ³¦²¯”¢›w‰}r‚un{nak^`h[[`TNZIIRCFM>@I=D7=F:D9?H>=H;;C8?E:=C8@E:AF;AGA7E=67B5=F9FI>=C:MYLM[LMUFBC=>?967/68.;A5?I;AM=FQ@MTG>A7<<2;:179,75,55,28-6?3;G99I:7F89F8/7;/67+56*49*79*;6)62*44*4:/;B6=D8I9=E6I@I>@I>AJ@CLBBLAAJ@AKAETJLfYQm_VpdYqeTtcRqcRpeMe[G\QFVKGVNJ_UIaTPcUM^PLaOOcQNaPHZMFWLESJFSJLWLISHJRGGODEPCAOADNAEOBAN@BOAAN@BPB=NBBQGGUJCNDBLB>G=?E;@EOA@PBGTFR]QQ[OJSIGPFDMCFNDFNCBK@DMAEOCBNBEODCH>BF:H;;MFBH=?C8BD:@B8ENAFOCOVIOYLLXGS`NThW]k^Yg[Wl_PgY]taL\LDM?JMADGE:?E:EC7@A:CLAHVGFQC@H@=B:=B89>4I=;C88>49=269/99-58,38-3C:;<297,97+77(7:+8?0E6:A2:E8:G:9G;=MAHXKSdSWiXRaRM\OEXIBSEAJ=|sf‚tg‡ylˆ|m†xm„ylvfykzvhxujyxmƒ†y„Š~z…xtƒxv†zq…xn‚ugznbuh`tg\qcbrgewjaqb]l^R`RM\OJVGFQCAJ=@H=@E:AE;@G=?F?K>AN@@M?ANABRGERGDQGBLBAI?C:?FF<ELAEOAESGCMFEJCCG>@GO>DPDBK?CNDAM@EI>=H9CJ?CH5AD;EG>FI@HJABE<0:8-98.88-59-8<3:@5;F8>K=FTFGQDCMC@J=:D77>15:.37,35)36+29,5=27A5=H4=>5=;087,9:+:>.9@0=D5BG>LABMCGWLRj]XsfRnaOj]MgXKcWI_UG]SCYMEZMC]SGdYEdXMg\Og\MhZE`SD\OF\MMbTUj\Uj]QdVKZMITHHSGCQDCPCDNCCLA@K@AMBALB@K@BMDBLC@J@?H>?I=?J=>E;G>>FGREJRG?HCK?CL@HRIFPEGK@@G:=G:=K=BOBJTGMUHIWIKZKHWICQCDOBFOB?E:?C7BD9BE9BH4DJ=AI<>D7=D5BD7AE9A5?C7BF::B47>0;<4BB;FG<;=357,;;0;D=BL@DPCJTHHTF=1;;069.6;+:C7EQD=L>48@69E9AJ=?B7::-67-58-:90<;09<16>27A3;E79A36<09:/;9.54(66)G7?J:>H8@J:?K;FQALZGETDBRE=OB>RF?UEE]OF_PHaPEaNBXF>H:edWjgYql^upctncpoanqbgl_el_kpelqfluio{ou„vsƒto€nm€qh„s[€pW}oZxl\rhYqfXm_QcTM[MMUJLRHIPEDI>@G:AL;BL;BLAK?>LADOEK\QSf[ZthVtgKk^NdVG^QG\SH^TG]PE^PGbVFeZDe[Mi^RlbLi^Ic[E_SC[MI^NNdVRi[SeWL^PJXKERFBODBQFBKBDMCALBCNDAMC@KABICAH@>E;BJ@?H=G=>G=;H=;H=@I?BI@BLABL@EOCGQDESCGWGPVMHQJCQIBPI?NDDNECREBSF=OBBSGFUIGTHLUILVNQ]VQ_ZSbZQcXPeXNbTPdUUfXPbTFWKIUFIVFK[JL[JGSDHRCHSCP[OLZOMYOMZOJUHDSIDSKETIAMB@H?HLAPXKYeYO[TDJFGHACH=EI@HMDIODIQFHPDGPDISGIPDGJ?GH>IODITIL\UO_VVc[Yf^Vd[Q`VQaTZcYOQHMNCKRFJWHP[NOXNOZOSaPRbRM\OQ\PLWIJTEERBFUFESGMSHLRHNWJPZMQ_SR`XVg^Vg[OaSO^OQZNY`UZdTVdTPdRNdUL`QK]OMZPKWLKXJO[MQ\LQ\KR\OVdWL^QMaTL_SGXKIXLIVJJUJKTJLSKLSKKWJLYLLXLM\PO\QQ`USe]Xkb[oe[ocUi]OcWOaTJ]MJZIMZIO]NP]OPbPTeTUeVVeYYh^Xj_^mcfwli{oi{oj„wf‰{o…{ntk{neugatg^sh_qb_pb`re_teb{lcos‡{†|~xqvrƒyzƒx‚ƒ~ˆ†‡‚}ˆ„~І‹‡Š‚Šƒ‰„Œ‹…„Œ‚Ž…Ž†ŽŒ„…†…Ž‹„‹†ŒˆŠˆ‚І‚Ї‚†‹…~†ƒ{Ї€ˆ†‡‡ˆ„Š…‹…€Ž‡‚Šƒ}Šƒ|‡‚|Š„†Šƒ~Š‚|Šz…z†v†|t‰}yŠ}|Œ‚|†‡ƒ”Œˆ”‹••šž—¥«©©°®§²¯¨³°¦³°«¶³«·±ª¶°«¶±¬¸³¬·´­¸µªº³ª»²ª»²«º²ª¹±¬º³°»³±¼µ®»´­º²®¼´®»´°¹·°¹¶°»µ­»µ­¾´®¿´¯À·¯À¶¯¿¶¯À·¯À·°Á¸®½¹°¿¼±¿º¯½·²À¹±¾¶±À¸²¿¹´¾»´¾»²¿º±À¸²¿¹´Àº³¿¹³¿¹´À¹³¿¹±À¼±¿»³Á½³¿»¶¿¼¶À¼µÁ¿³Á¾²Àº²Â»±¿½°¾¼±¿»±¿»³Á½²À¼²À¼²À¼²Àº²Á¼±À¼²Â½²Ä¼¯Â¹²Â»±Áº²Ã»´Ã½²Â»´Ä¾³Ä¿²À¼²À¼²Á¼³Â¾±Á½³Á¼±¿¼´Á¿³À¾²À½²À»±¿»²Á½²Â¾¯Â¾±Â¾³Ã¿²À¿±¿½±À¼²Á½²Á½²À¼´¿¼´À¼´¿»²¿¹³Á»´Â»²Á»²Àº°¾¸°¾¸²Á»±¿º²À¼¯½¹°¿»±¾»°¾º°¾º±»»²¾»±½·±½¹±¼º°»»²¼»°»¸²½»³½º²½º±¼¹¬»¶®¼¸­»·®»¸¬ºµ¥´¬Š™xŒƒ€™Žgu[siYmc\l[TgUTjX[tdQjZRi[OgUQhWRk[Tk^Rj[Tj[[m`Um_On_Kn\TrbVp`RjWTiXP`SM\QR_TP^RS_PP`QL]OJ^OF[KCUFDXMM]RP[MMVGJQDIODIQ@GRAESEDPCGPF9@7DL=AF;@H=EPFEPDFJ@DF:BH;>H;>G:DJ=HK?EWIH[LK^OH[LFVHLXKOSIDG;AD5@C7=B7>C9=E:AB8DE8D88I8=M=?M?>J>AF;FB:>B8;@6?E8?D7DH9AE5AD4>A2BF5DD5>@.?A0@C56:1:@9GODKUGAJ>AN@>J=AN@>F:?D5DF7AF5?D4;=168,58,38*7C5L[LL\OHUHFO>HM?@J?BL@BL<=F78?16>07>/9@3:?46;069035.BHK@?L;BG;;@5@K;AK;;H8=J:GVDDVEBUFH\NLaRH[OH[LBZIC]JDUDAH:afW`j[dk\ln`gl`fi]hi_ch^fpecshevkbpfoymvun~phzlbvie‚sX|lZ|l_xgarbane_ncSaWLZNKUIITFFMECMBBK?@J;AJ>DK?CNBBK@CK@CMACOD?PCAXMN`WVg\Zl`VmaJhWJaUEYNFXOF[NC[MG`OD`Q?\LIbSQj^OkbFf]GbYG]SHXOGUKKWMP^SSbXN_SFWJFVLCQHBNGAPEAOC=PA>TE=QD@LD?K@?J@@J@DMCAH>CF=>F:?H@>JD:IA>JAAL@BL??I=CMAEOCCNCDOCEPDEOCDNCCLC@LE@NDDRFFVJDUGGWIN^MIWHJZNOaTRdXSd[ObZN`YM^SI]PJ_RJ_TK]QHYNM\MO^OO\NKVIIPFGLCEOBVeSR`POXNNWNIXKCRHITLGPJGNGBG=EJ>SPLZc\RaXGQFDI>HJ>GG?JNDHOFCMCCMBDMCKVDLTGINEHMFFRJJ[PNbZQa[Vd^Uc]ScYQbUPdYVcZOSMIKDJRIMYOG[OHYPM]PP`NP^NIXLMTMJTIGQDIVHLXKHTHKSHLUIRZOP[OO^SPbVSg]Uh[SeUQ`NUaQ[fVYeXUcUReVPeVMbSLaRLYKIWIL[MN]OLXKLWJU`TYi\Vj[QgXLcRI`NJ\OJ[NLWMMVLGPGJTLJXMIWKLZNP^RQ_SQ`TSg[Xl`Wk^Ui\Ul^Tm]OeUM]ONXJPXKS_NVdTTh[Ri[Rj\Rj^YnbYl`_obhxlh}sa}ue…{l‡}pugwldobal``l``l``nbaoacraara`vgd|moymq{osxlyxm{|qu{p~yqxqh{wmyzo{|p€{q„|s‚{rƒ|s…~uƒ~u€}uƒ{u€~u‚‚w€v…x‡yƒvƒ~tƒ|s{r€zq|yp}yn~zozqzq~yp{woztmxtj|wm~ulvm|pi}ulvm{rh|sjzphwnewkdxlfxlfymh~tltnzp…~v‡„~‰‹‡—’žª¤¥³¬©¸±©¸²­»µª¸²­»´­½µ­½¶­¼µ­¼¹­¼¸¬»·®¼µ­¼´®¼´­½µ­¾µ­¾µ­¾¹«¼·­¾º¬½¶­¾·¬¾µ®½·¯¿·­¿¶®À·®½¸°¾¼®½¸°À»¯Áº¯À¹±À¹²Á¹±¿¹°¾¸±À»µ¿½²½º²¾»°¿¹±À½±¿½°¾¼±¿¼²Â»¯¾»±À¼²À¼°¿»²¾»³¾»µ¾»´¾»±¿»±¾¼³À¾³¾¼´¾»³½º²¿»±¾»±¿»¯¾º¯¿»¯¿»°¿»±À¼²À¼³Á½´¾½²¾¼±¾¼²À¼²À¼¯¾¹²¿¹´À½´À¼´À¼µÁ¾±½»²¿½³¿¾²¿½²¿½²¾¼°¾¼µ½¼µÁ¿³À¾²À½±¿½´¿½±¿»²À¼±¿»²À¼²À¼³Á½³¾»²¾»³¿¼³¿¼³¿¼´¿¼µ½¼¶½½³»º³¾»²½º±½º®¾»®½»®½º­º¹¯»º°¾»°½¸²¾¸³¾¸±»µ±½·­¼¶±º¹¯·¶²º¹²º¸°¹¶´¼¸¯»¸¯º¸®¹·±¼º±¼º°»¸°º¸®º·­»·¬»·¬¹´¤®¨Š–‚•Ž˜r„i‚y^rkXqbXpbWna[qdWk^Wj[VlYUn]SoaWofWlaZk`\p`^te[ufTk_Uj]ReXSeVQeWM`UNaWQbVPaURcUQdXSgYQdXM^SGXLFSMNYNT]OU[JPUEKOBO[JS`MITCEP?BL=BK?EL?ENADOCCSGDSF=N@@4@B5@C5@C8>B5>@4?@4=A4:A3=G6CP>BSA@O>BK=GKF;@I=?M=>M:D4=>275,86-GF>DB:BA5;=3AE:FJ=@E6BD5CC3CF7HI:ED8=;076,79.7>.ETB\kYZ_PGK@EPFBR@@K=;A5?A6=A39A1:E59A58=0?@6:>38>2:B6DPAFYHBZJHaSQi]Ui[DMA>?3@A5;>1:>/?<1?7.90)<5.78,5;-6?09=289/98/8>25?/29)6:*>;0@=2;:19;2@E7?H9>G;@H=>G<:B7@E9CL@BPCGXJTbTWdSTfSRaUQ`RWgUUaOKRG_eXZeV]fXbeXdfVefWfhZcj[do`cuegvicpdgrfmznfvjcxkezlc}n^znZxi[ve]tcWj]Xh]RbVP^RLYNHUIENGDNDCMADNAENBDLBBMAANBAQDCTGCRFDRFF\OPhZOgZKeWJeVHcTH`PEZLJ[OBVIDYLI`QF^PCZLF[NKbVKeZHd[GaVD[PEVKESGETHHYLRbXM^RGXKDUHFTJERKATIBSH@RDAVHDWKANC@LA>LAANCDNCCJ@DH?>F;@I?=IA=G;?I>AK@CMABL@BK>BK?BNADNADLBBLAEPEESGKVKO\QIZNM]PQ_RSaTRbVQbXWg\Tf]Qc[M`XM^SM_TK_SK]RJ[PM]QQ`RUcUT^RNWLMSJGLCDKAP_PPaSIVKKSKFQCENDIQHEJDBHACFKOEGOEDMCBLBGPFJSFLTHNSJGNEIUJJ[ON_VRd\XkcUg_RdZQbVRbXT\SJLFGHBHOFN[PL\RO]VLULNYKNWKJRJIPIISHKUHOYLMYLLXMKVJPYMR\PR\PP_RTcWTeZUgZRcUQ_NVbRXbTXfXXgYVhZUgXXiZUdVU`RLXKN]ORaRQ`RTbT[h\]m_Ym^Vj[NcSNbQN_RO^RQ\RT_UTaVP^QJXLP^QR`TQ_SR`TO^RUh\Wl`Vl_Sk]WpbVqbThZM]OMWKQ[NS_PRfTUk^UoaWqbWocYqdXoc]qccvld|qbuh…zlvlynkwjhsgbl_]k]\k]^ma^naaqb`rbcvhdwkp~rrs|‚w}|qvtjw€~t„v€}sxyoƒƒyƒ}tvn~ul}vm}vm}wl~yn|wo€|s€~v}t{r€zr~ypyp‚{r‚{r~xo{vmxuiytk{vm{vm{vn{unxrkytkztizqgvneznhxpf{ri|sj{riypgwneuicxlfxlfwmfvleznh{ul‚|tŽŠ„’”¤ž¯¹´®¾·±Áº°À¹²Â»±Áº±Áº²Â»²Â»±Áº¯¿¹°¿»±À½²Àº±¿º°¿¹¯À¹±Àº±Áº²À½±¿º±¿»±À¹±¿¹²Á»¯¿¸¯Âº®Â¹¬Á¹¯Á¼°¿½­¾º®À¼­Â¼¯Âº±Áº±Àº°Á¹±Áº²Áº²Â¼°À¼±Á¾°Á¼®Á¾­¿¼¯Á¾®À½®Á»®À»±Á½°À¼¯¾º³Á½±À¼²¾¼²¿¼°¿»°Á»°À»±À»´¿¼³¾»´¾¼²¿¼±¿¼²À¼±¾¼±¾¼±¾¼³¾½³¾¼³¾»²¾¼±¾¼±¿»²Á»±À»°À¹±À¸¯¿¸±¿º³À»´¿¼³¾»°¾¼²¿½±¿¼±¿¼°¾¼¯½»µ¾»³¿¼²Á½°¿»¯¾º°¾º°¾º°¾º°¾º°¾º±¿»±À¼²¾»²¿»²¿»²¾»²¾»²¿»³½»³½»±¼¹°»¸¯»·¯¼·­º¸®»¹®¼º­º¸­º¸­º¸®¼¸­º·¯¹¶®¸¶¬¹¶¬º¶¬¸¶«¸µ¬¹¶®»·­¹¶­º¶®¸¶®¹¶­¸¶®¹·¬·´¬·³¬¸¶«·¶ª¸µ©¸³ªµ³¥®©—£ž™§¡’¤œŒ¡™vŒ„`ul`xi`vhWl`Uh\UfYVhZVkYTk[Sk]Um`Xl_[l^etcfwjVm_Tl`Tk]Ti[ViZQeXRfZPdXObSM^PO_SN_RJ]PQdXNbVIZOHXQKXNS]OU]LV[KQUHKYGR]MLWGFP@DN@GQDHPCGPDGTHGTHHVHHSFBL>?I:>H;?H;>F:AHI==H<=G;?G:=E8A5=?3?A5=@4D4DM=FSDBO?DL=FKE:>F;?J;>L9?G:>@6><3A?5>@3;>/99-65+43*:8/88.AC6ILC:A63;/9B4?E7?B4CH9MOCGG;=;097-54*4<.>K=TcU^iZR_QI[OP`OP\MAI=;B69D5;F6@6<=3;>39?4:E8=PCEWKFXNP\QLNDDA7:9.67-::/98-74*61);8.9=09A1;D8:?49:067.8=28A49@27;.66+::.8:/=A5=E5@I9=H9AK>DL@DJ?HL@FOCGTEETDAO>FQBIUDDMBBL>HO?PSCPOE\bU\eX\dW^`TcbWgf[il]dk\dp^gxfiwgfrecobftifwli~ri~oeyl`vj\thXsdRn^RhZTh\RdVL\QJXLGTLEQIEPHBMCEPFCKACMCFMB@MA?REAUHESGFPEEUHMdVKgXKgXHbRH^NH^LI_MJ]NGYLHYLBUFBTICUHDTHHZLOcYJaXHaTG[NHYLHWJHYLL_RNaVL_SJ[NFTHGUJJYPF\SFXLFWLDYLCUHDPDAPBAPBBQCBPADMAEM?@J?AK@>KAH=>G;CK>DNAFPBENADNADPCIXKPYPVcXQ_UL\QTbVWdYP`TQbWWh^Te\K^VK^WScYQbWM^SL\QMZPNZPR_SU`TOYLJRHLOFGKBLLGO[PL^RGTMDKC@E:DH=GJ@CE<@B=BD=QTM__YPVOMUNGLCBC;BE@J=BL?CLAAJ?AK>CM@AK>COCGRFGQECOC?L??M?>L>@J=;D72?A5;>2=A5>=2@D8EP?DRBDM=DJ8EG8?C5@D9@H=AK=;E4=B6=>3>;2=;1<;0::.97,85+44*54*:=1GI=LSJH<=G;;D8:A4>F9FL?EG;>;0;9.75*15,7@5=HP?BPD8C67?4<@5<>4?>48=47?4:D9>L@D9:>1@?0HD5?8/^dWZbV\dW`dWec[hg^fg]bi^coabqdiuegrfbnecqfevki}pn€qizneym^uiXseQn_KeVOdWM_QKXNJXMGVMFRJGRJFPIDODENDBK?EK@BLAAPC@NBBK@HK@GOCP^ROfWPgYK_PL[MH]KH\JJ]KL\NGSIFQHAPECODGTFO[ORcWMaVG]PK^QJ[NJXLH[OI`SLbVL_RM^QM[NL\PN^RF\SFVNIXNFVLETHCNCCSDCRDDSEAPBBM@CL?AM@;H<=K@>G>?F@J>BK>CM?ENAEQCJWIR\QV`WL[ON[STaZXd\O]VN`WWh_RcZM_WL^XSdYQbWN`UMZPPXOQYPT`T\fZMWLHLCJMDEH?JHCJVLHYMFRJBF@@A8A@6DB9BC:DD;@@:VTPde_MRLHMFEC=BA9BFAM?BOADPEALA@M@?L>DQCNZNO]QIVKITFAPBASEBRDBM@>E;=E8E6=?3>?3@A5?=2><2<;2<:/87,89,67)57+9<0CMACMAF;CL?IOBAC7:9.64)65)63.86.=?5C8<@49=7/:A/=D4?F9?D9:>436,4:.6=06@3:D7=D7:B5?F9CH<>H8@I9:E5:C4AK;BLBJHM?BK:BH==?2<>.==-95+]bVY`U[cWaeY^dXej^`g\]g[^i^cobivgkxkhulcpiarefwhl|nk|pdym`vk[tiWqcOh[L`TL\PLYNKXMHWLGQFFQFGOGENDBK?BM?BK@AK?AL@?I=AH>EJ?GQFQ]RSdXQcVJ[MJZMGYJGYJFYIFVHCNBDKDAMBFODIREOYLUeXN_UJ]PO^RO\QJZOK^TI`UIaVJ_RL]OP_QP`SPbUGYQCPHGPJFSJAPEDRCFTGFVIBSF?PB@MA@K>H>G:?H?=D<=E;>FBL?DNBGSEMTIOYNP[QLZNQ_UVcZSb\N_WVf^Sc[OaYRe]RcZM^VGVNLWOMSMNOJXaW`h_AG>GKBIKBGH?GKCJVIKXLJOIBC?@B9@?9B@9BA8EEB@;AC=FE?GGBCI@BJ@CK@EPBFKAHOCGPBFP@HQDHQEHTIJVMGVNHYPJ[PKZMHPGJOGOPJLNHMTLOYP_g[lqmcheQVNT]SZe[T]SR[RV\WRXTbhbouncidSZTMXNNYMPZKWbPYgTZhXYfYTbVUdXYi\YgY[j[^m_cpa^gZV\OLTINSHNSHLSHJRGLVJN\LP]OQ[NOYLNZMN[PPeWThZ\n`]maXj\[n`Zk^Zk]Xi\Wh[Zj^\ma`rg]thZrf[pfXh`UaZS_TS]RVbVXeZZl^Zo_Yn`WoaZug\xk^zm_{nc|qh~uh~vl~upxouqhtnhrqipwmnyoiznfykftmfukauiavjcxnk}tl~ro‚tuwrskwqmxtp~|twp~tm~u}{r{unzogzoh{ri{qi|tj€yp~r„€x‡‚|…y…€x€u}{t}yqxo}tk}ukyth{wn€~v€}u|zqyvowtoxrmysl}vm|sjwmfvjetlbwmczqhypgvletjdwmeyohzpivngskdwohysl~yoƒ€r‹}”•‰Ÿ¢™¡¥ ¥©¤ª®©¨¬¦©­¨©­¨©­©¬¯«¬±«©®§ª®§©®¦ª®¦©¬¥¨­¤¦ª£¦¬£¥¬£§¬¤¨­¦§­¦§«¥§«§©¬¨¥«¦¥©¤©«£ª­¤¨­£¨®¦¬­§ª®¦¨®¦©°§ª±§«¯¥«¯¤ª¯¦©°¦©±©¬µ®©³««¯©­³ª¬³©ª²©©³ª¨²««µ«¬µ¬­µ¬­µ¬­´«°µ¬«·®¬µ­®¶¬­µ«¯¹­¯¸¬¬¸±«·°¬¸±­·°­¸±¯¹²®¸°­¹°®º±­¹±¬º±­º°°º±¯¹°°»±°¾±¯¼°°¿³¯¾²¯¾±°½²³Àµ±½²²½´²¾µ±½´³À¶°¼³±¾µ±¾µ´¾µ°¾µ°¾¶°¿·±¿·²¿·²½¸°¼¶°¼¶¯»µ¯»µ°»¶±¼¶±»µ¯º´±¼¶°»µ¯º´°¸³ª²­§±©¥²ª¤°¨¡¬£¤®¥¦¯¥¢«¡¢©Ÿ¢©Ÿ¢§Ÿ¡§ž¢¦ž ¥œ¡¤¢¦ž¢§Ÿ£¤Ÿ¢¤¤¥ž¡¤š¢¤›¤¦œ¡¥ŸŸ¤Ÿ¤ž¥žš¤œ—¡™œ¡š› ˜›ž——œ“—–‹‡”ކl}qfwko€rgwi`qd]mbZj_VgZXj[Zl[QcWO`SN_QP^OS_PS]QOWKOZOP`UM^Q\m`_p`[jYZiZXhZ]m_gtddp`^k^RcVQhYNhXI]NL^NO_SP]SU_TW_UPXNJTGCPDGPDHNAFNAEPCBTBDQCCOBFRGEQEGOCFNAFPAEO@HQDHREGSFERDDRCDOBHRDQYNXaUPZOMSGDOBARD?PB>GA5?A4@C7;819<2;D85D3BL:JQ>FF9AB3BE6HJ?FI=?B7>B6AD9?B5@A5<=1;:199/78+88)88*76*;:0:=1CG=19;/=?0FENBGRIL\OO^OM[KHVFI[JOdUTbZIYNKZOM[OCMBBJ>?F=;E:>J=FSFITFCNB@D:<:186,9=2=C6:>24;-5<-7?.6?,;A/>F4=C5=@4:?349-37+7<-3=.9C4;C6=C6D;;A6=C6BC9EG;GH;@D4<;1;9-:8*66'65*^bW\bW\dY_cY^gWakZ^iYbl^bn`hrfkyln|ql{retkcsehxgq|nl}pbyl\uk^uj^rfSlaL_SKYNMWLMYMIXJGQDENDDNCCKABJ?BK=AL?@MABQHGWMM]SQbWK_REYLEVJEWKEVHCQDBL@FIBCNCGPDIQDPZMQ_QK\OIZOHXMHVKGVNK`VLe\G`VJ_RM^PO^OP`RJ\NESK@ICCIDBNEBPEIVHJXLHZLFWIARE@OBI?9B8;C7=D7>F<CJAAH@AI?@H>BH=AJ>BL>@L?GOCJSGJVJIVKIVKR_UVd^Vf_Tc]Vf_ObZRf\O`WGWNGSKHSKLPJKKFU^S]dZAF=ILCFG>GG>CL@HSELVIKLFFFA=A9??;AA:CD:GG3EFF;?A69A4=B5=?3?>2<>2=?4982@D<@K@=I:AL9CJ6CC5AA3?@2CC6AB7@@7>B7@D7BG7CH9AC8?@7<>3:>035'76*:8+;8.;;.CE7CG;<@4DF9>A3=A2AG:KM>IO@=M?9MAAMDI[NP`QKZIJXFARBEWIHXOCSI>RF;L@>NACOCBJ?:E::H;EUDIYIAPB1=D7?E6@5>B6@C7=E9@L?>N?@H??D:>@7?@7@?598/;:*95+<6+:4&85&61(\aW\dY]dXadY_eU_fYai]blajwkm|os}xr}xkzrfvjetgivfj{pf~r`zq]vh\pdXo_[g\R\QNVKMUINYJMZIISFHOCFKBJNEBK@BOAEK@GNCFMBEOCCNBEQEHTHHUIGXKIZOL\RI[OGUHCQC@OAAOA@I>DJ@CKEENDDNAGREKWJKVKLWPHSJGVII\NPg[Nh[LbUJ]PKZNNZNKZNEWJDSH@MC?LDBOEESHIXJS^SLZNFWMCTIBRDAN@@MA@L@@I=;C8;F:9F:F;AI>BJ?AI>@H=?GE;?G=AKACNDHQHJSILTJW_T[e`Vd^Ve^UgaSc\O^YLVPHRKENGFLEDKCEKBQTKLNEEH?ILBDH?CG>CQDGOEIRICNFDJBED:BA9BC:CE=FG@HD?OIEUTKUVOGHBFB=C@8CF;EJ@FJADLBFNCKSHFPDDNDFRFHREFPDGOEFMEHLGFMEHQGLXMHVMDRLGPFPTLUQLPLFV\QS_TU[Rhjc||wWUO\ZRmlccebbdbflgae_`aZ_^Ude\QVMLUJLVIHVGP]MWdTYfYZj_Wg\XfZWdYZgY\h[\h]U_ULUJKUILUHJSFJREIPCGNBLREKSGMUJRXMRZPP\OL\ON^SRbWVfZXh[WiZTjZTiYThYTeWUbTUdVXgYUhZXi]Wd]T`ZR[UV_WU]VS\TU^VXaZYd\\g^^oa`wh]vh]zlh‚uiuj}qq€tv{quukxri{phypgzvmw}qy‚xp~sn}rizldxkg}qkwp‚wptt‚rspv|qxxn}yp{q€{rypysj{tk~wn}vmyqk{qjzqh{ri{sj|vl}xo|s‚}sƒw‡z†‚zŠ‹ƒ†‰‡z~xp€|t||t€w}u}|r~}r~}s|zq{wowrlzqkxoixmhulcwohwohtlevkgthethavlezohwoh{sl|tl{up}xq|s‚€w…™™Ž›™‘¤¤›¥¦Ÿ¢£¤¥¡£¤ «©¤­®§¦© ©ª ©¦¤“Ÿ™™•Ž—™–—Ž“‘‡”…›’‡š‘‡™‡—Œ„–‹„ƒ}Šxˆw‰€yŠ‚{Ž„}z„€Ž†}‘‡{“Š}Œ†y‰…z‹†y‰„xЇzˆ…z‹ˆ~‹‰Žˆ~ŠŒ‰~Œ‰~Œˆ~‰‡}Žˆ‚‘‹…‡Œ…}‹‡ŠŠ€‡‡‚‘ŠŠˆ|ŽŠ~Ž‹~”Šƒ‘ˆ•Œ…˜Ž‡›‘‹ž””™‰”†–’ˆ—’‰—“ˆ˜•‹—•‹™—––Œ––Œ——˜™™™ž›’¡Ÿ•¡ •£¢˜£¥š¤¦›¤¥š¦¥›£¦š£¦›¥¥ ¨¨ž¨©ž¨ªŸ©«¡¨¬£§¬ ¨¬ ©¯£¦¬¡©¯¤©¯¤©®£ª¬¤­­¥¬°§ª­§§­¦§­¦¨­§¦­¥¦®¦¥­¦¢¬¤¥­¦§­¦ª©£§£›Ÿš–„‰Š€Œ‚’„”Œ†Ž†ƒ‹ƒ‡„ˆ‚ˆ€Œ†zއ}‹ƒ|Љ“†“…Š‚‚y|~u|wpxtkxwkuyk{†yy‰u‚vqug~oe|mipv‰zoƒnbn_\dZZf[Xi[[lZTj^PfZNcVPaSL[MNXLNWLJWKL\OL\PQ]QV^SXbWUbVO]QFRFJUJLUJYfZXj]Un`Tm_OgZOcVQcXOWMQOETMCRSGJSCEL?BM?COACRDERFHTG@VDBUDDVGGUJFTHFTIKTGMVIISFHRELWJLYKKSEEJ?HH@CF@OA=H<5?=3=<2=?3?B6BC6=<.<<3?E;@MA@PC@OA>K;CG6CE4DC5??0>A4CC6?=2>61:3.52.35.6;2D7AKCD;DE:DB9@<5=93:6/85+=A4AK?@PD@QDBRFJVGKZLN^QPbUXm]JcOHUICUH@QGAOGAPGCVJDVG9H:;G9GQCHSFBN@;D8:?4:>49;5;A5>G4=J7@I9CG8BD6?D4=D1:@29?/>@4BB3@B2EI6BKD5>G7CO??L>AI=AF:BE8BB6@?2=<-66+:9*85&97(87)77+^i]Zf[YcY]eZ`gZ_g[^g\bkakxmt‚uryqxn€vfvkctghvjl€re~q[wkZqeWnaVm_ScXM[PLWKLWINXJOZKIWGHSEGPDFPFHVJDUIFPCGREJWIO[NJXKDSGGVHFUHFWII[NHZMFXKESFAQC>N@?K>BJ=DK?CLBDNCEQCEQDGRFITJHSKGRHIWKL^QNdWKcWK^QFVJGTHHTHFTGBSFEQF@MCCOFHUJHUIIVHO]RK[OFWLCUJDTGETEBQD>J==I?J==J=>H<>G;AJ?ENBCLAAJ?@IF;@H>@J@CMCENDKTJKTJOWMR^VR`YVe^ZiaWf_TaZIUMDNFCKDDKDDH?CG>ILDEH@EH@JMEEH@EHADQFGODHOHFNHIOHDCCA;AD=CK@GOFKTHR[OQ\PLWJLULHRFGQEFPDDNCGPHGJCFLCJSHLXLGUKEULGWINWLNRLMPJ[f^cujXbV_e]Š‹†YYTWUPggaehe\b^cjcilgZ\TRRIORIKQHKTIIVGHUGLYIOYJQ\OVcWVf[Zi]Zh\[iZZgYZeZRZPHRGJRGLUJIRGIRGKTHKTIJSHKSHPYMW^SW_TS^RLYMKYMP^QR_RRaTRdVQgVQeVRcUSaSSaSUcUTcTQaURbVQ_UR_VT`UXeZXbWU`TT_TYeYYdY[h]_nc^rf^vic|pitl~tk|pnzntxmwvlytkyqhyvl}r~‚wx€vuuu€urto~sr‚yu…|vƒxutv~qzt|u{zr€{s‚}t|s€{r|vm}wn}vm~wn~tm|qj{ph|pi}tk}uk~vm€yp€zp‚|u€~vˆ…}”•¢ ›™”“މ‡‚}ƒz~xƒ€{w€}u~|s~{r}{r{xozumysk|tl{qiulcxngyrkxqjxohylitjc{qj}tm|tm}un~vovn~vnwp†‚{”‘‹—•Ž —­¨£«ª¥§¨¤¬¯¬¬°®²²­°±¬©«¤¦©Ÿ¦¢™ž––Ÿ›”£¡™••ŒŠ‘‹€‡}…|Š‚yŠ~w‡}tƒwpyo~wp€xpvrƒxr…xq„ys†zs‰u†r€{n~{p€ylylƒ|p€|q€|qƒt†€uŠ„y…€wƒ~t|r€}s‹‚{ –‡}u„|s|s~}s‚|sƒ~t‚|sƒ~s‚}qznƒzpyo…|r‡}t„{”‰€„{ƒzq†€vƒtƒ‚u‚€t‡ƒy„€v‚u…‚x„ƒy‡†{„wŠ…{އ~’‹–…–‘†™“‡œ•ŠŸ•Œ•Œœ•Œ›–›“Ž™“‹—’ˆ”“ˆ›ššš›šœ‘Ÿž’£¢–¢Ÿ”¢Ÿ”¤Ÿ–¢ž”¢” •ŸŸ–ž –  ˜¢ ™¡ ™¢¢™Ÿ¡˜Ÿ¡˜ŸŸ—¢ž˜¨ ›­¤©Ÿ–˜†‡~‰‰~›—–’‰“‡‹†‚‘…ƒ‘†€‘†”‰‚“†•ˆƒ•†‹…|‚}r}zo~|s|{r~vmwqgspeƒ‡{Š~xˆ}o‡zp‡zg|olrl}qr‚vn~odm__fX\eYZhZfqe]tfVl`Qj\QeXTeXVfWQ\QQ`TQbUO`TNZNR[OTaTWbV\fZ_h\YaW`i`jvi[k_Rh[Sk^Sj_Ri^Uf[LYNJOEKOBOSHMWGHODFQDKXMHXLHWKIYLCVGBRDEUHIVKJ[PEVKDQEAPDBSFJ\OKXLDMAEP?KVFGRDAL=FO@IO>JUEJVGAM>CM@BM=AJ;BH:AG:BH;AHG:>G:BL@DQD?D9?B7AA7>?4?=2;:0>;0=@4?H;CPDJUHKVKFXHCUHAQEJZLRaRM\KFUDASE?QEAOD@NDASGEXIAPB>J<=G:DNAENAAJ:9A2=A5;>6H6AL8?G5AE5@B3BD4CF7<@1;=/;;/==/=>/>D1;E6=G8=E9=E8:@38@1:C3;E5?I:=K:BQ@AQ?FJ?AG:EH>298*;8*97(76(66)_h_YdZWdZ^f\ai^_g\\e[]h^gtil|omsl€se|newlcshethfzja|mTreZrf\rfXobSh\NaTK\OKZLMZLO\ML[IJUGERFIUKHWOJ\SK]NIXJM^PUeWRcRH[JFXGEVGFUGHXJGVIDQFCTGCRFAPB@K>BJ=CK>CL?COAAMAAOCBODCMDDRH@MBETFJZMH\OF[OGVJERFBLAFQEBOCAOCDOCCMCCNDGRHHTGIUGHXKDVJBVKCVJCUGETFASEAPB@OABN@AN@CM@AK?BL@FPDFPDEOCCM@AK=?J;=G:>H;=G;@J>BKABKACLBHQHIRHJTJJYQL[SR_WVbZVaYU^VJVNDOGCLEFLCEH?HH?KJFFF@OOISSMHHBIJDKVLGLFDIDIOJKPKED@EAGFBCC?CD@EE9EJ?FICGFAFD?BD?AJ?GQEMWKVbVVcUNZLMTJHQFEOCDNBDNEFRIJMCJPEKTIMYMFTHFVJEXIJVJMRKMRKangmvfthfne„…‚UTONLJbb^_d^SYTW^W^cZTXOOQHLQHIRFJVIHTHIVHHTFKQDKSIUaTXeYXgZ[i]Zi[R_QT]SMUKJPFKPEHQEJTHMWKMYMMYMKWLMYMWcW\fZ\f[T^RLXLNXKQ[OR]PSaSSfURgVRdVRbUUaUZdX[fZWcWUaUSaUR`TTcUWfXYiYYgYXeWYfWZgYWdVYeXZi_\ne_tkg{rn}umyqoynrynvwmvukusi{yo‚wx‚x}‚yzx{‚yz‚yw€wx‚zy‚xzwys|}qv~x|v}w}uƒ|s€{rzq€{r{r€yp€vo|qk|qi~sk~tl~uk€wnxozqyr€}uŠŠš›–­«§©¦¢›•’‹‡ƒ“ŒŽŠ…†ƒ~†ƒ~ƒ€w~{s~zs}|r~|r|wn|wn{ujxrgyofyqhysk}wpxqzrkunf~wnxoxo{tk~wnvl}tjwn‡z“‹™—“ª¤Ÿ¬¨¤¦¤ ©ª¨±µ´²¶µ±±­§©¥¢¤žžž—š–˜‰˜’‰žš“žœ”…‰…|‡‚w†|uƒzr‚ypwm‚xm{rfytg{ul{up~upumul~rl€um„|s{pywlxxlxj}wj~ynxnyn{p„~s‚{r€{r~zp}yn|ym‘‡~…}‚wo€wn}xo{yo~{m}yk}zl€ym}wmzujzqg{qg|rh…yoŒ}t€w‰{s€vk‚zn~{m~}o{|k€{n‚|o|n~{m~{m}o„}p…|p†}qƒzŽ„z‡}› ’†¡’‰ ’Š •›‘ˆ—Š‚”‰€“Љ|Š~މ|ƒŒ—†–”‰}”Š~’ˆŽƒy„z”Š‚Šˆ…|’Œ”ƒ•…”Ž…•†•ˆ’Ђބ|˜‰ƒ‡–‡Œ€u‚t„s‡zˆ}“‹ƒ‰|Œ}Œ}„€ƒŠ~zŠ{x…|t{riwqfzuj}t„y„|pvpcwwk‘š…’‡zŒ€s€wŒu†zo~vhypg|rhzoaoa_k[`qaduh^ldNhZWpcVpcVpbVl_RfXP^SQaTOaSN]PHTIKWLM]OR\OTWMXYPU[QTaU[eYQ`SNbVTj^UncVndScXQ`VL\PHWIHSFKVEPWMJUIIVKJZOL^TF[PM\PGTG@NCBQFM]SI[SBTIG_RMgZPgZUdXQYOLXFN_NK^ONaRM\KNUEO[KLZK=I9>H7@F6>C3><2<<2<;1:9/<:/86+FL?P\KIYHGUHHPEGI@>G9AG:CE9AF:BH=DMBDN@HSFJQEEMBCK?CM@JMA@A5<:/:7,==/?@1>D5?D6?F:=E9BK?EOECJ?GNBEI=AF7@C4=?1@?1<=27<09@3?E:CH>CPCFRFCOC=JLABVFHZLERD@I=AJ=?H;=G6;C0:A1=B8BG2@A5=@2?@0@?3<:/;E4;F7BL@J<@H8>E6?O>DQAERAGK?@D8BIAK?AJ@CLBCLBFOEFOEJSIIWOJXPOZRNUOOVOOVOHSKDNFENDDH@FJAHI?DG@GICSUOPQLGJCLOIOYQHMFGIBU]UTYTDEADAAC=AD>4;;1><2><2=;1=:1;B5FQBL[JETCCK@>C:AG=2CD:RSJEM@ENBFTEGWIJXDHYHRbSLUJENC@L=E5@I=BI:FJ9AE6=C6=B57>0;@1BC3@@3@@4<<1;>2EL=DN>CM>AO>BO?BN>?J8>I=BOABN>BO?ERBDS@AH=@IOYIT]NIO>@?275+84):6+64)66*[aXZdY[gZ]fY\f[\fY[hYan^cpadsefyjg|lcyl`vi]sg^sg]sc[whWwgZtgXqbXp`Xl_RfYK_RI\OIYMHVJM[MJXKIVIDREGSIQ]UOeZOe[MaVK_RL_PJ]NLYLHVIHUHFTH@OC@ODBQFFQFHRFNWKKWIHUCIQEDPDDTIARGAQDFTGGWJCTCBO?AM=@M@BNCBO@BNA@N@BPBAOA?N@COBAOB?NBBSECUGASBBSFEVJFZNGYMJYLJUGHUICRFBSGBSGAQEAPECPDDRFFTHIWKHUIDRFERDCPCANABNB@L@?K?DKBENDFOEFNDENDFQGFRIEPGDLCEKCGNFGOFFMEFLBFLCCH?BHED;BD:CGBF>DLBJSHLUHJSFMXKLWHEMBBJ?DMACMAHSIO[RS\QR\RMXOL[QM^TM`SI[PIULNPIOPJ^d[wvlviY^TSQJSPJLNFPVMNYNOYNOWLMSHKQFJSHLQGMSHR[PNWKJSHIPEIKCHOEMVILWJNXKPZOMUHHPCGNELPGKQGHODIMDJRHMVLNZPO_TP_UUfYWi\Xm_Wm_RgZMaTK[LO]OQ^QXfY[m_Wk^Vi\Yj]XfZXeY[g[UbVUdXVfYZi[XgYYgZYfZVhZ[k^^na^j]\h[_i]^jabqhhxngxljymp{ot}rrynrwkrukuwm}€u„ˆ}„‡}„„z€€wx|v~~u~~t|{vzxs|zqzyp~r~t€}t~vƒ€w„x†}t‚~uƒ‚x„ƒy‚uzr|unwpxo|tk|ul}xmyp‚ypƒxpƒyr„~w”’Š ¡›¥§¡¤¢š˜’—Ÿ£˜œ’’•‹Ž†‡Š…‡|„„z„‚z€}w}{qzvmzuk|vkwl}wm{yo}s€u}{s}ypzq{vm|vm}vm~woƒ{oxn€yq…zŒˆ„—”‘›™’›—’ž˜¥§£³¶³¥¨§œš•‘ŽŠ‹††‚zˆxˆ€w‚v†…|‰Š€†ˆ‚‚x|qxpxo‚yo€vkzrd{re|vg{tiysm|vpxo€ym…}tƒ|t…‚z–“‹‚xutiyti{vkxuk{xl{ykyzl…tŒ…~ƒ|v~xp{xkzzi{yj}yl|wi|wk{wlzwlwxkyxlwtg{tjzpgymfypfypg{rh|sitkƒxo‚uk{qeysgzvh}yk{vh{yj}{lxwhzwiyxjzyk{wi|yl„‚vŽˆœ•Ž —ƽ´ÊÀ·ÔÊÀÐøɽ²Á·¬¸­ ¯¦š›šŠ‰‡…zЇ{‘Šž”™’Š‹ƒyˆ‚w„€sƒ€p‚|n„|nƒzmƒ|o„~rƒv…ƒw{r~yq„}wˆ€z…p„{o‚wm€sisi€uhug€sd‚tf€ug~shˆu”„‘Є𖱭¨Ÿ–‘ƒxr†xq~ulzujzwlˆ†}œ™‘œ™’œ›•”–ž¢œ²¹¯¬²§™›‘’ˆ€‰p}ur…|t‰‘…z‡|jvk}‚Ž“‹—ŽŽ€m~rh|sf{rl‚x`wiReXN`SPbUO`SPaTK\OJXIKVIIRHGNGHQFEOBFTHP]QQbTPeVRjZPhYScXTdYQcVScUO\OLWGESFEREERECPECUICWJIVJFRFGSGHVJHXLJ]QNaVQfZWk_PbWKVLEKCGSELZOR`UUdYK[OETFJ^JKZGGQ@FK<@F8D8@H1>BNAAOAETFGVH?K=;E8F;>E6@F8@G;>H<=H;;H8;G5=D4?3;=369.=D6CH;CM=?N<@Q?EVDBO@AI>CL??L?AQ@DXEH\IFWFGZIPcRZjYdn\RWF<K>?M?APB@PBBSD?QCERECPD@QDASFBWHCXGEUICUIATIBQFHUHIREDMEBPH>OF?RI>QHAQHAQEBSFFVIIYLHYLETIJWKGRFEQDHSICNDALBDLBJRHJSIISIHRIDOECNDENDBH>CH?EKBCLBIMDINEFKBEKA?GFJADE:GF=ED9CHCH=?G;AB6>>4?;2A81=6/=91<=4AIDG7FH9GIK=?L>ERBPYJMTHPUJPTIGH>>>6;:,99,;9,88+57*68-8:2B6@C:AG;FODENDBI>@JH==L?>N@ASAAR=?J8:C48<1:=262=@3?H8AP=/:8/;6-;6-97-77)Xg_VdZXcY\eZ[i\[hX]kY_m[`p_`pbcufhykjzmbth_th]uh`ug`zk`|m\yj\ug]rc_pbXk[TgVRaRQ`SMcWMh]Pk^Ng[NbVM\PP[OK`TNbUN_RP`SM]OIZLLXMHWJGXKFVKEUJEUIFWIJZJKYHWdS\m[WjWK]KEWFEUEESGCQEESHBTHBRF@OD>I>AJA@G?=I=?J?@K?BPECPDDQE@QF@QFAPHFUMGXKFYJFRHDNDDLAEK@GMBGMAEMB@NB@OFCMEFNEAMBAPE=SG@ZNEZNJYLIXJHVJGUJIWLJZNJZMEVGHQFHPFISIESIFTIBNDGQD@I=CGADHBGMBCK@DKAFKBGLCFL@AG<@F;EI>EJ@CKADKAHNCJOCIMDGKBFJCIMGKNIBGBEJDIH@GG=DHE?CKBFNDHOBIPCGNCCMBDLADM@GPCR[OS^TR[TR]TWdYUgYTfYSfZQ`WJ[PITILQHOVLMYNHUJJTJKNELNEKMDORIHVIM]NO_OLWHLUIMTIMVHKTHLTIJPEIPDHOAMPDLPENSIHPEGPEDOBKO?KQBIPEGOEFNDHQFLOFJQFJUFO]NSbUUeYXl]]qd\seYrdXpdQi]PeYQdXQ`WVf[Xj\Yn_Sn`Uk^]na\j^]maWi\WeYZfZ\hX\hYYh[[k^]n`aqb`paao`ao``m_dqdk{nl~qhzmgxmn|rm~wlvomskmvjpzk{‚r€„z†{|†{y„z|‡}}ˆ€†{‚ƒxƒv‚v~uƒ|w€|rzrzq€zq|sƒ}u€~r‚€s…ƒx…‚v„v|s‚{p€zn{o~yo{rƒ{r‚xr„|u‚{r„}tˆ‚y’ƒ”š¡– £—•—‹„“‘‡““ˆ‘”‡Ž“„Š~‰‡}†ƒzƒ€{‚w{szq~{q}zq€tr{zp~{t€|xxu}yl‚zqzrvoumwnwq|vo€yr…€w‰ˆ~Ž„‘”Š–š¥˜§›™¡”—ЋބŒ‰†ƒyƒ€v}tƒ{r€€uƒƒy„‡~‚†{€vt|q{pymwjyl}viyti€vl}wm|r€€vƒ~u†|tzp‰wƒ{€xowm€~o}n‚{m€{n€}rƒ…y‡„wƒ}rzp€€t~€q~~m|m}q||qz{q|}r€u€~s‚t{p~xl~uk|sh{phzog|qh|ph~ul}wnuj}vh~xj|xi}ym}yn{|m~}pzq|s}|p}~o}p{}q‹Œ‚®¬¤¦ ›¼³¯Â»³ÍÁ¼Ï¼ÌÀºÍÁ»Ç¾·È¼´¾¶­±®¤£¦¢™¦¬£²µ¬¦¤š‹‚Œ‰‘–ˆ‘Œ—„†Šy„‚t†€sƒ€s‹Š{‰„ª®¤¦¨¢Š•“‹¼º°¶®¢„u|sƒ~s„~p„}nƒzn„q‚}o€|o‚|qއ|š”Œ¤–¸¯«¿²¯•ˆ†‚ss‡yq~ph„xpŒ‚|•Œ…“Œ¦›—¼­ª¿°°¾³±Ä¹¶Ä³¯µ­¡˜šŽ|ˆzy†y‚Š~Ž…™„„}uqni”‘Œ•‘…Š„z{‚wexk`th`sgawl`sfVk]OcVSfYTcUS^POYLNXJLUINXLN\OJ[NG\OPgYQi\Rg[ReYQcWP^SMYMMUIOVKHPGJSKP]OJWIFTFHUGGUJIYPJYNMWKN]LL_NL`PK\MIZOHUKOWMNVLMZOK]QI^OJ]OHWKO_Q_p^j{i]nYQ`JMXFHTBAL;CK;CJ>BD9=<1A>2?;2<83<=4@F8EK:EG;CLADWGK[JEQDAK>FM?BI9?H7@G6BK>GQFGQEEO?CL8FL9FM;@H8?F7>E5BF6>A5:A3@J=DO>ISCIO?FPCLXKP]N]hWQXI>B3??3@<3>70=6/96-89/>=3??4@B6@B6>C8>F:>LACPEDOEDQDCQDASEBWAFUEIQGJRJHRGFTFFOB?H<>H=E;BF=?I:;E8>K=DNAFO?AI7AM==H88B27>/:D49E3:E8FWELaNLbPH^QQdVNbQIeRVt^\zceygbtcUgVUfVRaQGUCA@4;:/<;1;;0<FD>AI?DLBFM@CJ=DJ?AJ?AJ>CK>JQDOXLS]RU[UW`VYf[WfYVgZSeZTcWJZOHSHKPGMTJJXLJXMMWMOVLINFKPGMQHIYKQcTTfVPbRM\OKXLP[KNVIJRGIQFIODHOCJMDKNDKOELQFHNCGMBMPBNQELSHIQFHODJRGMSGNVIR]MYfVYj[Yk]Ym_[obYm`Xl_Ui]Sf[SfXSeZUeZXj^Xl`XpaVpb\rebsfcqe`pcZl_Yh]Zj]\k^^m`]na^pdctfdugdsebqcbpbbpbhtil{ol}pfwkgwlo}sh}smypozpoznr~qzu}‚x{ƒzy…{xˆ~{Š‚Œ†‚Š‚‚„{ˆ‚y„ƒx…‚yƒ~vƒ~v}u}t‚~v„€w†ƒzƒv„‚x‡„z‹…~†x„w…~t€zr‚}t|sƒ|r„{r…zs…{t…}u‡xІ}‘Žƒ›œ“¡£—¡£–——‹ŒŠŠ‡€Œ…Œ‚‡‰‡…|…{ƒ€{‚€wƒ~u|s|s|s€u~}s}s|u€}w~{v€|q€zp‚yr€xq~vnypƒ|u{tƒ}v„v‰ˆ}‹‚•–ˆ˜›š¡”ž¥™™Ÿ”“ˆŒ„‹ˆ~†„z‚‚x‚w…~uƒu……x„‡}„‡~ƒxƒx…€u€{pzp€{m€zm}vizvivkzn‚sƒƒv~q‚yp}ul‚ypwm~ul€xn~xmxm~uiwm}rƒƒx‚~tzo}wn‚w€tq‚r€s€v{€u|u„x……{†…z…‚w…€w{p~vl|ti{rf~ui}uiwk~zn{q~{o~~p‚ƒtƒ…w‚„w‚†v‚…xƒƒxƒƒx‚‚u‚„u„y}ƒv’™Œ£¦›£¥š¨¦œ±±¦µµ©¹·«¸¶©··«µµ©µ´§­¯£¦­¡ ©ž©¢¬¡¡§ž—™ŽŽ„ƒ“›Œ˜¥••¡Ž–†‰Š}††xŠ‹|‘”ƒ“œ¥®¢¡¨žž¤™¥©ž³¶« ŠŒ€…‡|ƒxƒƒv„‚s„tƒƒt„…w‚„v„„yŽƒ¥ •¼µ«¾´«¹¬¥«œ•¬œ—¯’¯“¬›’§—™‹„‚{‘‰œ‹ ’’£–±Ÿ—½«¢«Ÿ•“ƒ‹‹€‹ƒŠŠ€‰~€vwyqˆ•‰…zs}yppxmdugbrgbqfcsh]naUdWVbUP\PP]OO^PPZMLUHIRFMZNM\PM_RRh[ZqcYpaQhYOcUM_QN_RM[NMWHIQFENBERIKYNKYMIVHJYKIYMHZNH[ON]PM\ML`PNbRL\MLXOJRHKOFJPFJUJN^QMeSOfVQeWOcTWl\cxfcubTeTM]KNZIJTFFPBDMACI=>@4=>2<<3=;5@D9CI;AG5BC8AE:DQCLWHGOBBF:EF:BD5BF5>B3@E9GNDIPDCKH;NZLVcVNXHX^OX[LAB1?>0?8,>:.==.>@0>?4>@5>C6?E8?HF8CG8AF4@I9CLI9=K=MB@NFAI?CJ@DOB>NCE[MNhYH\MFSHDOCFWIHWJLYNSaVYe[XcYM[PGUJFUJFQGHQFGMDFPDDLAEK@EK@CI>AI=AI?BJ@DI@EJ?EI>CGFNDLVLLXLIUHDLBFMCLNFHI@IF@IG@KLANKBHFCH>>G<@H>?G=AI?CJ=CJ=DJ=FLABI=GMAJTGPYMX`UY`X[dYZfYWdXUeXUfZTbUL[NJUHMTFLTGEUHLYMO[OPYNMVKKSIJQFM\NWiZYn_Vj]Ui\TeYUaOOYKMUJKSHHPEIODJNFIMDKNDMOFKMBLMCPRFOTHRXMMUJJQEKRCNUIR\NYeUZiY[n]\o`Yo`Xl_Vi\VgZSdYRbVTgXVi[Vi]WjaYnbZrf]wicxkixlitibqeZl_Yj_\nb]occsiatibuhl}ojyketfetfcrdbrchvkj{nj{oevkhynk|qmtr€vuuq{qs|s|~xz€yxzw…}w‡€{†ŠƒŽˆ…‡€ˆ…|ˆ‡{Ї}‰„y†„}…‚z…ƒ{†„|‡…}ˆ†~‡„{ˆ„|‹…}‹…~‹…~‰z†€z„~y…x„~w†|uˆ{s‰|v‰~wˆ‚yˆƒzŒŠ€’…››œœ›”“‡Š…|‰ƒ~‰†}Š‚‰ˆ‡‡}……}‚|„|†ƒ{vƒ~u‚}t‚|uƒ|t€zr{tƒx„‚z€~v}t|s|t„}t‚{s„}tƒ}vƒ}v„~x†‚yˆ†|‚”“†––‰˜›Ž›ž“–š”‹•ŠŒŒ‚ˆ†|„…{…†|‡ƒy‡…v‡‡z†Š~ƒˆ‚†}€…{…ƒxt†v…u€{m~xl}{l€yl‚|o‚‚s‚„uƒ€r„zq€umtltl~sk~tl}tk}qirj|riyp‚wƒ}rxo}vo‚€wƒƒx‚€u€r€t‚‚y€w‚v„vƒ‡}ˆ‰€‹ˆ€‹‡…€x‚}u~zoxm~xmymyo€}rƒ†{“—‹–›Œ•‹’›‰–‡—ˆ’–Š’—‹Ž„’”ˆ‘”…Œ„’š˜¡”ž¨˜£«¤«›¨¯ž«±¡«²¡®³¢¬±¡©°Ÿª¯ ¦­ž£¬œ¡¬¢«ž¡ªŸ¨ž™ –—’”›Ž›¥– «œš¥•˜ “‘…’”‡•™ˆ˜žœ§—¢­ž¡©ž ¨¥­Ÿ¢©š£““›‹‹„‰‚ˆ‰}ƒƒwƒ‚tƒƒu…‡x†ˆz„‘©Ÿ–£™‘ ”¢‘Œ¢‘‹¡Ž‰£ˆ£‰£‰£‹’|•„…‚”†ƒ“„‚‚˜‡¥Ž‰¨Ž‡£‰ƒ—‚|“„}‰‡}~„yz‚vy„yy…y~‡}uxmwvkswmkxlbtg^odbpe\laYfZX`TZ[QVYNR^PQbTU`QXbUxuUbVL\PRfZ[m__td[qbSj[PfVM`OQdUO`OP]MKXHETGCTHGXNL]QK[ML\NQdTI^OH^QL[NJWJKZLN]OHRFFNF=C9HJAJMBKSFS_QPgTPeSNaRK]PObTTjZXkYQcSN]PM\MHUHEQEEPDENBCK>?E8=A7=?9AE:BI;BH7AA5?@6?G9JSFHMAEGIK@EI;AF6B?2?>4DEHL@@J>GPCHREGPBY^NPUFDE5A?0B>/CA1BC3BE4?C8?G:9D6@K>DPCDQDEXHCVDASCASBDUDBQA@L=AJ?DH@FNCJSFFSAFN>CJ;BI:>C4>>0A?0>?1BC7AE8?C7@C3CE5CG8CH9CI:AH9@K;?J9=H=COCETGHZKI`QPhYVl]SdUL[OOdVRj]WnaQi[NdYGaSJdVJhXLiYK`OGTE<@4DD9@C4;E5^jabjbaj_bl`cmadn_eo_fqaivghxllwkhtidsgexkc{n`}n]{ka~p`}p_|o_|n[xh\ocWm^Um^Vl\[th`€raxn_vj]sgYmaVh[VgZUfYO_RK\OL]PL\NJYKIYMJXLKVJJTJKXMJXMJZNN^RScWXi[[l][k]Tj\RfWPcTP^RMXLJUIKTGOYLLZLJWJGUIESGDOCDPDGRFDRFGUIIXLJUIGUJGWLJ[PGZMFWIFTICMD@J?BL@DNBDRDAMA>NC>LAAI?BJ>BQCBQEB\LGbQI^NIWJEODFSIHVJO^QWeYZh\Ye[Q_SJXLHVJIUIIRGJQFGPDEMBCI>AHCF;BE;EEBH<@K=AGDM@FPCFLAEMAFQAMXHU^RU`TZaVYbWVaWT`VO_TSeXRbRObPOZLMSFKSGHWKP[OR]RUaUS_SNYMOYMP^PWh[]ob[pb_reZmaWbRQ[MNXLKSHKRGJSGMRIJOFMPGLPEOPFOPFPUISYMQYNOWLOXKMUFNXIU_RXeXWgY[m_\q`XqbTh[UfYUbWTbWUfZUhZUj\Vl`TlaYqe]ui`xjhymq{przomxlcrfcrgbrgctifznfymg{oo{nl{mkykiykgvhiwii{njzojzojzol}snus‚v|…z{ƒyrysvyt|x{‚{yƒ{w…}z‰‚~‰ƒ“Œ†ŠŒŽ‡ƒŒ€‹‹Š€Šˆ‰‡Šˆ€Ž„‹ƒŠ‰Š„Š„‡‚Œ†Œ„}…~‰ƒˆ‚}‡|†xŠ~x‹€wŒ~y‚|‰‚z‰‡}Œ‚“‘†˜“Š™•Š™•Š”…‘‰‡‚‹ˆ€Š‡ІЇ‚‰†‚„ƒ}ˆƒ~†„{…‚y‚w‚}t€{s„zwxtƒ}x…ƒ{…ƒ{‚‚y}uƒ~u…€w„}t„}t…~uƒ}v„~w‡zŠ…|ˆ‡}Œ‚Ž’…—•Š˜—‘’‡’”‰”‰ŽŽ„‡†|‡Š€ˆŒ‡‡|Šˆy‰‰|‹Žƒ‰Ž…‚‹€„ˆ„…z€vƒvt‚~t|o~sƒ~r~p€r‚…t…r…{quk€vl~tj~tj|rh|qi~rj€sk{ph~xo‚€vƒ~s„zpzr‡…}‡‰ƒ‚wƒ€s„t„€v‚t‚€vƒ‚u†‹ŒŒ„Ž‹ƒŽˆŒ…~…x‡z…x†€y€zt‚{t‡xŒ‹ƒ‘’ƒ”ƒ“„”…’“‡””ˆ”•‡““†’‘†–”ˆ•˜‹“–Š™ž¢“ž¥”¡¥•¥¥–¦¦—¨¨˜¨§—§§˜¤¤”¦§—¤¤–¢¤–¡¢”££–¡ –Ÿ ˜ž –›Ÿ”—›› “š¡‘ ’™›––Œ•”Š›œœž›¡’ž¤–ž¢–Ÿ¢– £•¡¤–ž –˜‰ƒ……{‡…{†‚x…„v†…w‡†yŒ‰|“Žƒ˜‘†™Š‡š‰‡Ÿ‹žŒœŠŠœ‰‰š‰‡š‰‡›Šˆ—ˆ‡™Š‹›‹ŒšŽ›‰Œ™‡Š—‡‰š‡ˆŸ„„›ƒ}‚|˜~x’€y†ƒy~†zz‰}x‹~zŒ|q~rmvkjwkexk`vhbti^nbWi^TbVTYOWWMUUKQ[NQcUR\PcmaisgR^SL[PH[ORbVUgZYn_Ul]Wn[UmZWiZUfUTbPQ^NL^NJ^QM_XN_TL[MRaSUjWSk\L`RNYNLRHKSHIPDHK@GLCQSJ]\SOOENQEUZNZgUTaPOZLQ\PTdVSdVScUTeWTeWWfXN\PCRFHSGGUGGQDCM@>G>C8E8MXKQXLGNBGNB=E7?6BEFM@KQEFJ2BA3DC7AB6@F:DK@JWIJYKJYLGSHCVHI[NHZMAQEEQEFPFGNCCK@AJ?DMAFQBDR@CJ?CJ=>E8=A5??4?<1;9.==1>?5=A5=A4=@1=@1?D5>E5DM>GQADP?:A4DK=JQELYKTcV]qc]tc\n_SeXMdYKi^RpgYriRk`Qk^Sm^Up`OhYJZJ5>.8:+DC4AB4>B6cnddmcdlbfpcbocgqdeo_dn_hsfjviirhgqgfvifyld}o_}ma~ob~pc}ra{o_{m_|l_wiXtdXsc[sed~p_~s_vlZpcYj_Yh]Zj]SdWR^RO^RPaTL]PL[MJXJIXLKVJKTIJVKM\QM`TMcWNeYPi\Rk]Um_Xn`Oh[MdWMaTN_RGUIJVJLYLLZMJWKFVJDSGBRFFRFFRFGSGDRFGUIJXLNWNLXPL[TI]TFXMDUGESHANCDOCGRFERF?OA@KA>MB?NCCMBCRDBXFG[ND`OEcOF]KETGCOEFOHGQGNYNVfW^l_Zi\S`TKYMFTHJVIFODHODDMBBK?AH;@G:@F:>E;@I??H>@H>AF;CE;BC9DH=INEV_U[h]^l`RaSENDGQFIOFCG=CFBH=AH>GOCJTEIODGQCLXHO^MTaRS^RV_SU`TP\QP_URbWQdVRdUPdSP]NKRFIODJUJT[P]fZ[g[XdYR]QPZNO^OVdWXi^`peevj_nbVbUOYLQ[OPZNOWJKUFJPEJPEKQELQEKQCNTER[JQ[NR]QQ\OOZMQYMR[OS]RSaTSdX[na_tfWp`Ti[UgZUdXUeZVg\Tj\Vk_Woc[tg_wjbzlg{no}pw|qz~tv}rn{omxmkymj{pl|qnro€rv€ss}pq{nr~pp{no{nm~sj{pjzoiypk}ukux„y|„{w€ws}vw~y€€{|„{|…{{‡~~‹†’‹Š•‹”Œ““‹’†’’‡‘‡‘‘ˆ‘†Œ‹‚„†Ž…Œƒ‡‚‡Žˆ€Ž†ˆ€ˆ€Ž‡€Œ†Š„}‹…~Ž…~Ž„~’…†‰€Œ‚“„—‘‡š‘Š˜‡™’‡˜†•Ž„”ŒƒŒ‚Œ‰€‹†Œ‡‚Š…†„{‰…€†ƒ{‡…{„‚x…‚xƒ{tyt‚yu„~y‡‚}‡„}ƒ€zƒ€y†y‡‚xƒ€u…€w„}t„~w†€y‰ƒ|‰…|ŒŠ€Šˆ~ŒŠ€‘Žƒ–†“„•’†•”ˆ•Š‘††‰…‹“‡Ž„‹‹~ŠŒ€“ˆ‹ˆ‰„‡Œ€‚ˆ}ƒ†{……{‚ut‚tƒ‚x†‚w…‚wƒƒvƒ…v‡„uƒyp€vl€vlwm€vlukwnulukwk|p……y…‚t‚|p‚~t‰‰ˆ…‡{„„yƒvƒ€v}t„ƒv††wŠ‹’„“‹†|Ž„{Œ†|‹‚|‹„~‰ƒ}‡{‰z|އ{‰|‰{‘Š}“Š€”Œƒ–‹‚•‚—’„–‘„•ƒ—†™’ˆ—“ˆ–“‡š—‹ ›Ž šŒ£šŸ—Ÿ™Ž¡š ™ —Œž•‰—‰—‹™’†›“‰”Šž•Ž™“Š–’‰˜”‰š–‰•Ž“~”‚”…™“‹™”Œš•Œœ—‰Ÿ™Žœ•‹›•‹—Œ šŒ˜Š“„‹‰ˆ…{‡„yˆ†w…‡y……wˆ‡y‹‡zŒ‚xvŒyt’~{˜†„šŠŠ™ŠŒ—ˆ‹—‡ˆ™ŠŒ›Œ©œš¯¢Ÿ¤—’²¤Ÿ¸£¢ª––˜ˆ‰š‡‡ƒ…›…‚š‚~š€|”€zŠ‚z††|ƒ‰€Šz‰{v†wo~qm{olzncwjcykhynethZlaVeXS\PSYMQVLOZLPaS]i]aj_YbWU]TOZOJWLLYORaUTgZTk]Ul]Wm\]p`XjYTaQSaQN_RNbUNaXQaUR^PQ`QWj[Ul]RgXOYLFKBMRHNTJKOEGPARWL]]SWVLKJ@ONDMUFOVIPUJQYNWcTUdSScQTcSYhY_oaVeWJYLITHEQEDRDDQD@J>H9SZMRVLGKAEJ?BK>=G8?A5@@4DA7CB5>=/??1<<1<>2@C:@D;BE<>A7@C7AD8AG:AI?AL@JUIKTHKRGHMBHL@IOBEL?DA7>=2>=2BA4@>5==4<@5;D8BPBAREGWIFSGEWIL]OL^QKYMKTJCJ@IODGOEFPDJWIIXIHXILTHENBC8;C5;B3;A6CJ>CL@DM@CL?BJ>AD4BG9BK=AM?CTEM`RWm[^l]XgZUl_Vxj\€r^~sUrfPj\SgYSbS;I87<->D3@E4>C2>B5=@4hrgcj`blaepcdrfcqdep_ak\gpdnvjlujoxnl{ogzme€p]|la|mc~p`yoazo_yk`{ld}q_}o^|kb{mnˆzi‡|c}s^viWk_Yi]VgZTeXU`TQbUQbUK]PJZLKYKGZMGXKGWJK\QNeXMi\Rn`Nl_Mn`NoaQpaTqbRn_LgXJ`RK\PIYLP\PN_RP`UN]RHXMGVMDSJFRFGSGEQEGUHESHFTHIPIMXQKZSEXPBSIAQFESHCOEGSGJVJAOC>OAAMC=OC@PEGVIG[KD_LK`SLiWIhSG`NGVJBOFDIDEMEGRGP_OXjYUfVXbVQ]QIVKHSHDPDGOD?H>>F;?F7?F7>E:=E;?H>?H>@H>@F:DF;BC9CI>LTJYdZ\j_VdWM[NFNGBLBCK@@H=@GKFALJBED9MK@JNFGNHBJBCH@BHHOAEK@BK@HQENXHNTIJUFO^MN_OQaRM[OQ^NP]PP]RM]UO_UPdWRhVRgWR_RLOEORIV^U`fZcm`bl_\i[S^QPZMNXKKYLP^SWd[\g]ZdXP\QQ\RU^SU_SPZKNXFNTINTHKTGKUEPZIU^NWdRR`PR_SSaWVaVXbVT_SR^RT`XYh`Zl`YoaUn^Vk^Xh[Vg[Wh]Uk_Vl`Yrf[sh_yle~ojol~qvu‚x……{}w{…yx‚tuututuu‚uvƒs|ƒv~„x}…x|…wx‚uw‚tqƒyp€uk{pm|un€vlxu„zwƒwsxq„{v„}{‚~‡|Š~€Š€‰’ˆ™’š’”š——™—––Œ•™——˜–Œ•“‰–”Š–”Š•“‰”’ˆ’Œ…‘Œ„’‰ƒ”„•Ž…—…“‹’‹‰€‘‹„”…“‰…™Œ†–އ‘Ž…“‘‡˜‘‰ž”‹Ÿ“’Œœ’ˆ›’‡™ƒ—ƒŽƒŒ‹€ˆ€Œ‡ƒ‰„|††{‹…€Š‡~ˆ‡}‡†|Ї}ˆx‰z…~w†€{ˆƒ~ˆ~…~{‰…€Šˆ~Š…{‡ƒx†w‡xˆƒ|‰ƒ|Š…~‹‚ŽŒ‚‹‰‹Š”‘ˆ—‡˜„–ƒš–‡–Š•–Œ’–Œ•‰˜Œ”‰’”ˆ”‰•Œ–Š’†Ž’†ˆ„Šƒ†‡~…„y„‚w†ƒx‡†}‰†}ˆ„z‡‡|†ˆz‡„v†{rƒyo‚xn‡}s€vk€wm‚xn„yp‚ym„|oˆ†wˆ‹|†…u…r‡…x‡‹Š’…Œ‘‚†Ž‡‹€ƒ†{…†|…‰|†Œ{ŽŽ‚–†–ЀހwŽ„z…{Ž…{Žˆ~Œˆ~Œ‡}‡}‘…|‘u‘s‘t“ƒw—…}™…€›ˆžŽ„ž“…¡˜Š›‘…˜Œ„œ’ˆ›’‡”‰¦œ’­¡—®ž•ª›•§š“¥š“¦œ•¡• ŠŸ”‰’ˆš‘‡—Ž„–‹ƒšŽ†£“Œ¡“Œž”‹ž”Š¢—Œ»¬¡®¢’›Žƒ›Ž‡’ŒŸ“¢–‘«š’¦—¤”Œ£•Œ¦—©›‘¢™š”‰Œ‚ŠŠ~‡ˆyˆ‰z…‹|…Š|ˆŒ}ЇzƒyŽvŽ{q–ƒz”„}—ˆ…šŽ—ŒŒ›‰Šœ‹ŠŒˆÂ±«àÒÈÏÁ´êÛÏÿúóÓ½“„€œŠˆ‡…š…ƒœ„š€|—€|”{„{‹„~†„{€ƒu{ƒtx‚svuw€uo}ql|pmwlhribpe]k_\h\WcWT_SS`QUbTUaTYbVT[QU[QOXMMUMKWOQ`VTeZOeWQhYUk[^nbWeVS`RQ_QPaSPcWNaUTbWVaTT`RPaTPgZOiXM\OGPFEOFGTIIRGHTCGP@JM@KH@IE=JE?GM@QWKKRGNYJL[KM_MO]LR_PYgWYgXQ_SN]PLVJFQDAPBERDHSHFMEEH>BL=JVDGNABI>?I:GH>DD:DA:EE;CGA5CB5DA3A?1>D:?E;?D:?B7?E9AH;@I2>@6BK>ESECTFERECPCDWDHZHGYHN[KNVGJL@EMBEOBKVJN]NKZNDTGITDGTCBQ@?M;=J7@6@F;?G<:E6;E6:D79D6BN@DPCENBBI:?F6AI8DO?ETCBWG?WGR`P[dU^hZTgZUtfY}nY{qZyjYqc_o`lsc[^MFD6HLJ8AGGLAFL@EK?@FKIAHF>IG@KMDKOEGL@DI?@I>?J>FRDHQFGMCGNBHQBKUDIVKIZMHZMM^QM]QM]OQ\RMZNIZMM_RMaVOaZNbUNfXNaRMXJRXMZaUgndntiipdcm_VcRM\MLYLKVJPZNT^R[fZ]k_Rm^SgXWeWXaTQZNOYLOYJNWJPUHTYMU]RYcWXhVUeTTcUUcVWfXZi\Xe\Vd]Wh]Xj^[pd[pdXqcTn`Rk]Ul`WnbVl`Unc[sg`wje|nj{om}plpx„w†‰}‹ŠЉ€‰‹ƒ‡Œ‚†‹‚ˆ}„ˆ|‚„w‡‡{ˆ‡}‹‰€Š€‡†}…ˆ}„Š|}Š€v„zpwk}to‚zoƒ|u„|tƒ|s„{wŠ{ˆ€€‡…Š~‡Œ‚‰‘‡“›‘™Ÿ•šŸ“›ž•›•›Ÿ”Ÿ•ž“Ÿ ”Ÿ ˜šš’š™‘œ’›š™—Œ™’‹˜‘Š˜“‹™“•‹•‹—‘‰•‰•‰•ˆ™“Œ˜“Œ˜”™–Ž˜—›™™¡›¤–’¡—Ÿ•‹ž“‰›‡˜’‰““Бކ’Œ…ˆ…~†ŒŠ‹ˆ‹‰~ŒŠ‡€Š„}ˆˆŠ‡Šˆ€ˆ†}‰‚†Ž†…}‰…|‰„{Šˆ}‹…~‹‰€‹ƒ…“…•‚”ŽŠ–‘‰•’…–‘ƒ–„˜†”“ˆ™—•—•ž”—“˜•–”Š–”Š˜”Š”†’’‰’’ˆ‘“†’†ˆŒ€‡ˆ|‡†{‰†{ŠŠ|ЉŠˆŠ‡‹‚Іy…{rƒ|r‡€v…~p‡q„}n…|r‡s‡t„…uŒ€Š“€Š‹‡ˆ|‡…{ŠŠ~Šƒ‹“†Œ•ˆ‹„ŽŽ‹Œ}ŒŽŒ‘†š–Š‚y‘~u“x’ƒ{’„z”…|”‡~•…|—„|“€x•t•t•t‘t•„|œ‰„›‹…Œƒ¤”ˆ§—‹œ„˜…Ÿ’ˆŸ“а ™·§ º§¡¹¥ °¡š° š²¤œ°¢š¨˜‘¤”¡”Œž‘‰‡™Œ™~ “„¨—Ž¥˜Ž£—Œ ”Ѝ˜Œ±¡•¢“ˆ …ž„žŽ‡¥–¬ž—°¢—¬ž•¨š”©š•¬”± ”°ž—¦—˜‡‘‰Š{ŠŽz‡”‰’€€’“‰}–ˆz—„|šˆ€šŠ„—ˆ…š‹‰œŽœŠŸŒ‹¤·ŸžÇ®¨É®¥ÿ÷èÿÿöçÉÿ¢Ÿ£‹˜…‡˜†ƒ™…ƒš…šƒ~œƒ}œ‚|”y‘ƒyІy„„v‚wƒw…‚zz€tpyllvioxlftibpd\l^]l^[hZZf[T_VP`VXeYWbSS\PMULKSMIWKP]NRdTTjYSh[Yk_[hYU`UT]QU^QT`PPaLU]OT`RQaSL_PTfXXiZUkZP\PHNGHQJT^R_hYGPDGK>HEINCNSIHMBFJ@FOCDVHOXEM[IReRWl[PcRM`NMZJESE@OC?QDRdVJ\KESGDUFKXHJSE@G==I?BK?EGC8;C5@D8@>5@@5?@6BB8@@6CB8AOCCOABN>BL>@I;?F:@F5:=3?F;HQFGUGDWIBWGATGETHHSFKUILUILWHKTIDREHZKK\NGUGIQGKWEM^LH[IEXGEUD;I<;E5>D5BG8BIG<>G:DL;FO>DK;FM>GQAHVFI\KOdQMfOMhORfT`fU]]NHUGPiY_wh`ykYqdYmaiufno`VQ@MK>HM=DO=BNC=?BFMCFNADMA?H=DD;EEDH=GI=DL@BHIK@KQEPUEQ[KWhVZm]WiZUfYSbTGVJDTHFXLPcVNaRSaQSdS_kZY^OJOCFOC@NADKAFI?BH<=C6AB6@A4>@4>A5?B6?A5CC7G;?J=@NBIXNHZPEULAOEBK??FED9;:-99+88*88,<:2<=3BRCFOCCM?GS@LZGIWFETCO\MUcTUgX]p`Zn\^s]btb^jYO[KQhYYvf`{m_yj\vfXn`Xk[MXEOUALPAEN>DQ?@N<@K=@I=o}vlwrfohfndiqfgpcjtgmwgqwgzny‚sw€stsv„xu…zwˆ}sŠ~p‰|l…|k†xj€sj}of|re‚wd…znˆ~o‡}m…|j…{h‚ue~rdzmcuhaqd^pcYk^Yj]Wi\RcVSfXTh\VlaUlbXqg`yo`yncxjcxk^re\qb^paZk]Th[L_RL[MIYKLYOJXMJUKHTHIWIMZLKWKGSIHQEFQEDPDAMACOCDPDAPDAL?DJ@ELBEPFDVJH\SH\RFWLHUHISGGREFPDCK@FNDGPGKWOGTMBUIFXLGYKIXJIVIFQDHQGJUIO[OR`TTdWWgYWhYRcVN]QKUIIOEIKBBI=@E<@E<@E@;@B;>A8DD;BD:GG>QOERRHMRFKPEHLBHJ@DJCDKAGPCHQDCM@@J=FI=HK@HLAFIAFKEDJDFHBCF>AD;CG=CJ?DLAENBHQFIPFKUIGUHI[JK]PJ[NGXKJXLKXMLXNKYMKYLQ`RTeWSfYLaWPbVLaVK[SLTMNRJV^Tdmcirhhqgjul`pcYk^Wf^S`VQ_SVdX]l^`ra`qc[k\\gZ^gZ_j\]j\XfZXfZYf[[h\\i]_l`]ma]na\kbXg^\l`_oc^pcareaseasf`secwfayjayj]qdZnaZnaWk_Wmaarggrghrhcrfk~ow‚x†Œ‘…˜“…™“ˆ›–‹Ÿ–Š—‹š–‹˜“Š™“ŠŸ– ›’Ÿ›’™›™——”‰……‚‹‚€‹ƒ€‹ƒ€Šƒ~‰ƒˆކ‡”‹€‡†Ž‡‰…”Œ•œ•Ÿ£œ¨«¡­¬¢ª¬¢¬­£¬«¡«©Ÿ­¨Ÿ®ª ª©ž¨§¦¥›©§ ¥¦¡¢œ¡¢™žž•ž•žž–¡ž™¡ž™¢Ÿš£ ›¥¢›¤¢š¤£˜¢¢—¦£›©¦žª¨ ©¦ž©¦«¤›¬¡›©¢šª¡˜¨”£›“Ÿœ’™›“˜š‘•–Œ‡Ž†‘‡‘‡“‘‰‘ކކŒ„‘†—•—••–•“‹“‘‰—‘Š”•Š””Š“”‰“‘‰”’ДЕ”Š”’Š˜•˜•œ–Œ™”ˆš•š˜Žž˜‹ž•ˆš„›Œ…™„›Œ„›Ž†š“‰›‘ˆœŒ…š†œ‡›Ž†™…™Ž†˜†—’‡•’‡””ˆ’”ˆ”•‰””‡•—‹’”‹’“‰’’‰Ž‹ƒŠŒŠ€ŒƒŽƒ„Œ~‹‰y€Œ}‘‚“–†•— ”— “”™’–Š—‹’–¥—¤•’¤–”£“”Ÿ”ž• ›—‰—Ž‚—‰}šˆ}™ˆ}•ˆ|š‰~–‡|—‰}—ˆ}—‡|˜‡{˜„}—„x•…y—‡{™‡€žŒ…™‡›‡ ”Ф—¡’‰ ‘ˆ£–Œ¤—´¥œ¿¬¦Á¯§Àª¤½ª§¼©¤º§¢¹¦¡¶¤¯ž—¬š”¦—‘¤”ŸˆŸ‘†¢•‰¦–”¦—“¢—¡–Ž“ˆ”‡£–Šœ‘†˜Ž„ž‘‡©š“¶¤ž½¨¢¹¤ž·¢ ¶¢¼¥ž½§ž¼¨¡´¤©—¤œ“›–‹š”‡™•‹™•Œš•Œ›”ˆ–€—‹~›ƒƒšŠ‚˜Œ˜Œ…˜‡œŽŒŸŸŒ¡Œ¦­•“¯–”²—•³–”«£Š‰ŸŒŠŠœ‰Œœ†ˆœˆ‡ŸŠ† ‰ƒžŠƒ¡Šƒ¤‹žŠ‘…{‡ƒw†„y}‚vv€su}qs|pt~tnznbrf^ob\pcYrdXqd^ne\k`YfZTcXQbXRc]Vk^Wi\Uj\Qk[ZscXk\VhYQaTIXLHSIFRGGRGIXIN\OPaSSdVPaSO_QFPCCG=GH@HLAIK@KJCA8B@5JJ@KOCFM@EK>FPCDPBJOBVUI[WLUVJQVITaS\l^Xl\ShXTeWO_SL\RK]QLaULbUTeUSeTR`ORZKOVHLXHBTGBOBENCFNCAF9EE9BD5@D6@F8BH:AF7BE6AH=CL?FO@LVGJTHEOBAKBCLBAJ@?J@GVJL]SIbXEZQFULQYRMQHBD:=;1:8,88*88*99.97/==1<=3:A6@M??RCF[LGfUFcSE_OKcSNcQJ[JCTGKXJKTCLTDOZJHYII\KOcPOeQJ`JJ]FHYBFO>GL;DK>D7z‰ƒp{xhpjhmfkqfgodksfkuftzk|qz„t|…y|…xy†zz‡}w‡|xŒ€wƒs‹l„zo„wpƒtmtgƒtf†wk‡xk…xm‡yoˆ~m†ykuh|peylexk`ti`ui\rfZpdXnbUl`Yoc[sh\um`xpf~rgql}pdwj[pbYm`[m`Vf[PaTM\NN[MLXJKVKFSIJUGKTHLVIM[MMZMJUIIUIHTHEQEDPDDOCEPCDRFFPEGPFFOEGTKK\TL`WJ^UIZOJXLMXLJTGHRFEMBGLCDJAFOGCOFAPEDTHETFCOBDNAEMBCMBCMCITHOZNWdXWgZXeYSaULXLGPEIPGEJAAI??GDH??B9>A8@C:DE;FG=LKAMMCMMDIK@IJ@HJ?CIBDLBDM@CM?BL?BK>GOBHPCGNCGOEKRICKDCGABD>EE=BEDL>GLAFKAKQGHQGIWJJ[KJ]NHYKIZMHVJIWLLZOK[NN^PRaSTeWQdVKaUPaUK`UL\TJRJRUMYaV`j^eocfoejrhfsi_nc_ldZg]VfYXi\]l^^m]am``k]_i\^h[_l^^l^^maVgZ]ob_pcbtgduhfwjbqi\ld_nf^nb`qdardaqebrh`pe_rdcvebwh`te[pa\m`^pbXk^Xm`_peeohfoeguipq„Š€†•“…𔇖ˆŸ™Ž¡¡ž’¢ – ž”¤¡—¨¢›­¦œ«¤›©¢™§¢™ŸŸ•”˜†”‰„’ˆ‚ˆ„‘‰ˆ‡‚‘‰†’Šˆ”Œƒ“Š„’Ї‰Ž–Œ•œ–˜Ÿ˜£¦ ­­£±¯¥±°¦´²©³±§±«¢³­£µ®¦²¯¥°®¤°®¤¯«¤¯¬¤®©¥©ª¡¥¥œ¥¤œ¤¡š¦£ž©¦¡ª§¢ª§¢ª© ®«£­¬¡­¬¡´¯ªµ±«²±¨³°¨²®¦³­¤µ«¤²¬¥®¦Ÿ¯¤œ©£˜¤¢˜ —œž––™‘”—Ž˜™”–Œ—”•“‹”’Š“ˆ—”Œ–“‹—˜™š‘œ”˜™—”Œœ™™œ‘˜›–—™š‘›™‘›˜’š˜œš’¡ž– š“Ÿ™œ—‰™‘¡›‘ž—Œž”ŠšƒžŽ…†¡Ž‡žŒ…žˆŸ‘ˆ¢Ž‡ ‡ ‡†ž‡œ†›…›†™‘‡™•Š—•Šš—Œœ™Ž™—Ž””Š”“‹“ˆ’…—ˆŽ…“”Š–šŽ–šŽŽ‘‚‘ƒŽ‘•–ˆŸ •š •›¡”›’œ’šž’œ§™ž¬žš­ž—§š›ª›ž©™ ªš—ž›“‡š„žŽ‚œŽ‚›œŒ˜Œ€™ŽšƒšŽ‚—Š~˜‰šŠ€›‹šŠ›Š‚Ÿ†Ÿ—Œž•‹ —¢˜£˜Œ¢”ˆ ”Š¦š´¥œ¿®¥Ä¯©Ã­§Â­¨¾ª¥¾«¤À¬¥À­¦Á­¦¹¤Ÿ´Ÿš¬—‘¥‘Š¥’Ц•¥–“©š—©š”§š’¡—‹ ˜‹£œœ“ˆ—…œ’ˆ±¢™Ã³©¼©¢¸¦ º§¡º¨¡¾«£¼§ž¾©¢º§Ÿ´¥±¥œ­¡—©’¥™‘ •Ÿ—ŽŸ™Ž˜’ˆ˜„𓆛‘„”‰•Š˜…™‡›ŒŸ‘¢‘£’¤‘¥‘¨”•§“’¤Ž¡ŠœŒ‰›Ž‹ž‹ŽŸŽ¡ŒŸˆ ˆ¦‰ª‰¨†š€†…xyƒv|€svtq~rr|pp{osut€tixlcthbwiazlc|netidqf\l_Wh\Tg]UlbXpcTh\PfXOhZTk\WiZSdVQbTP^RN]PJUKHSJIZLOaSR`RM^PL]OHYKKYMKVJGPEDOCGQBHL>JG>B?6BA7IJ@IOBHOCJREESFETFQXKNLAQMCLL@NPDPWKUeV\m^]qbWgYQcUQbVK\TH\PQfYPcRH^LN`OO\LJXGG[HBWJCSFDPDCOBDL?EG;CH9BH:AI:BKK>BMB?J@BNDGUNM^ULaY^me^g`VVODA9?;3<:/;9-88*99+;:/=;3@>4:;0>D:HSERcUTgXIgXGeWDcSEaQLcUObSIZNO[MPVHKSBP]LOaQG^QI`RNcTLbPH[HFUCBN>BK;GN?DNBDRECVHESCHXGHYKH\MI_POhWZk^Wi\Zl_Xi[ao_htcem\TcQSiWOeVSeWQcUWaQFRBRbQesdiucR]HJP=BG7DJ:IM?NOALJ<‘Ÿœz…‚ntmorinujlujkuilvirxmy~s|†v‚Š~…Ž‚‚‚„…ƒ‘†~„{†uƒo†|nƒvotq‚vr‹|k‰yiƒtj‚uk„xm…{o†zo…xkuh‚sg€rd}qe~resb{oZvi]xkc{md|q`{re}thrl€qpum€s[tfXpfYodSf[QcUQaSLZLNXKHSHGRIGQEJVHJWIP\MN\NJWKHWIJXJIVHFQDDNADN@CMCGTIJZOGYOK\SM_UO`YN^VKZOIVJIUGJSFDPDENBEK@ELBCMB?NAAMEBNBCOACL?GPCIPCFLCEKBDKBKSJV_UT`UU_TS^SOYOKWNKXMLYOEOEAK@GREFREEMABK?BG?@EFJ?FH=DGCK>@I8AKFI@AD;DKAFQDHVHL[MGXJGVJGYLJZOK[PJ]OQaPQ`OTdSSfXOfWPbSK`SJYQLRJRUKY`S_h]emabi]mshkqffmbak`Zh]XfZWeY[j\^j]\i[ZhZZhZ[j[_m_an`]lb_pdctjfxkgxkl}phynfwm_qf`qg`qeatfbsfbrg]kd[ja]na`sb]p`]pa[m^\n_^ob]m`Ym^^pe_pgdsjmxl~‡xŒ‚’’…˜•‡š•‡Ÿ›Ž¦¡—«§©¨žªªž®¬¡³¯¥º´ª¼´ªÀ·®½µ¬·²©ª¨ŸœŸ–™š‘Ž˜‘‹˜ˆ–…’…’ŠŠ“‹‹•‡“‹‡”Œ•Ž‘˜’™ š¡¥ ­®¨¹¸®½·¯¿¸¯Â»²Àº±¾·®¼´­½¶¯¸µ¬¸¶­¼¶®¼¶®¿·¯»±©³¬¥¯©¢®¨¡­©¡¯¬§°­¨µ²«µ±«¸µ­»¹±»¸¯¾¼³À¼·¾ºµ¼¹³Á¾¶¾º³½´®Áº°º¶®»´­¶¬¥®¨žªªž§¦  ¡œž šœž˜œ—Ÿ˜››’š˜’˜•˜•˜”Žš˜š™‘šœ“œŸ– —ž•¡ ˜¡ —Ÿž•ž” ¡—¡¡˜Ÿž•Ÿ•¡ —¥Ÿ˜¢›”¥Ÿ•¥ “§ –¦Ÿ”¢™¡•Œ ’‰Ÿ‡’‰¤“¤”‹¢—Œ¡”Ц”Š£’‰ ‘ˆ¡”ŠŸ•‹ “Šž…†ž’ˆ•ЕЛ”Š”Šš”Š—“Š—“‰—”Š—“Šš“Š–“‹™—ž¡—œ£–•œŽ–œ¡”£¤–¥£™¢ž“ ›¡™žš¡œ‘¡ž“ ¤˜¡ª§²¥¤°££­ž¥¬£¥—ž›Žž•ˆŸ”‡ ”ˆ “‡ž“†“‡ž‘…š’…›“†œ•ˆ›’…š‘„›†›ŽƒœŽ‚Ž‚¢‘†¦”Œ¦š‘¡˜ŽŸ—ޣ𑡙Ÿ•ˆŸ•ˆ©œ¾­¤Â¯§Æ°¨È°©Ä®¨Ã¬¥Á«£Ã­£Å¯¦À« ¹¢œ¶Ÿ˜¬˜‘§“‹¦•‹§–Œ«›•¯ž˜± ˜¯¢˜ª •¥¢šœ–Š˜•ˆ•‰¸ªŸÄ±§Á­¦¾«¤¾­¤½«¢¿«¢¿©žÄ­ Á¬¡¼©Ÿ»©¡¶¥™²¡•®”«”¨Ÿ• ››™š—Œœ—‹›’‡—‹—‹‚™†œ”‹Ÿ”Ž£˜’¥˜“£”‘¡¤‘‘¡“’¢’‘ž‹š‰†›ˆœ‘‹ŸžŽŽ ‘ŒžŒ ŽŒ¨‹§ŠŽ…yƒtx€q|qz„uxƒwvux€w{‡{t€tgujgujgxmi|nlomzmmzmerg_qd\qeXreZqeVj_Rg]OfZVl_XhWR^QQ]NP_PRaRO\QNZNRbSSbTN]OHZLGZKOeVPaTJYMN\NPaQKZJIO?JI>CC7BB7DF;FJ?IOCKQCOXJSZL_^RVSFOMAPNCOQCNSFT_O[lZZm[ZjXUeWM]QJZOJ\QNaTM\LK[MP_RO\OIYIDYFDWIGVJGVJDTGGUGGNAGM@EM@HQEFOCBK>BI<>G=DM@CM>EM>FNAJPDKXHIUGENCEOEIWLJYLJ[RVbZQTK:8/<6.>80<:/<:.;;-<<.>>3?=5>?4@B8BGGPFOBGVGDVGGOGEODIREJSEJQCEL?GKBFI@DH?IMBPYONXMOWMOYNNYOL\QO`VJ]QHVLCQEESGHUIEQC>K=AI?EMCJRGHQFMUJOXKHPFCI@CI>CI>BH<@F9CF=EH?CJ=BI:EL=GOADTHGWJHUHJTGGPDAI>BEAEDAED?BC:BD:AE9CF=EG>DH?EI@GNCJTHKXHO[MKYMJ[OJZQJ]SJ`OL_MTbQQbQSeVNdVObQG]OHWMKQJRUJW_O_jZdm]bfXjk_mmcde[]g\]h\YfZXeY]h\^g]XhZXgZVfXXh[[i\_k_^mdbrigznfzmhylm}ql~qj|ofwl`qf_rd_qb_pc[jbXf_Wg`\k`^m_\n][l\Yj\\l^`n`\l`]ob^sh^tldtkpzm‚ƒu••†—”… œ¦¤™«ª ±«¤¶²©¯«¢¹´©À¸­Ä»¯Å»°¿¶¬Ãº±»´¬®­¥¢¤œ¢¤› ¤ š–ž—“•Ž˜“Ž™‘•––Ž™‘”›”™¡œž¥ «°ª¶·²´±©½·­Äº°Â¸®Ã¹±Ä»²Å¾·Æ¿·Á½¸Â¼´Ç¿¸ÊÁ¸Ê¾¶Å¸¯¼¯©·ª¤·­§´®§»¶±¾»¶¿»²ÅÀ¸Ç»ÅÀ¸Â¼µÌÇ¿ÚÖÑçäßÝÙÕÞÛÓàÛÔãÜÖÌÅ»¿¼³¹³¬¾µ®³¯¥±²¥¯«¦¨§¡¥¦ ¤¦ £¥Ÿ¤¡› ¢—Ÿž˜ œ—Ÿœ˜Ÿ›• ž”Ÿœ•  —¢¥œ¢¦£§ž§ª¡¨¥ž¥£›¤¡š¦¨¦§¥§œ¥¨Ÿ®¬¤«¦Ÿ«£œ¨¢˜ª¤–¬¤š«¡—¦›“§š’¥˜£—¡˜¨›“§š‘¦›’¦›§™Ž¥•Œ£–Œ£™¢™Ž¢— “‰ŸŽ…¡“Š¡–Œ –Œ¡•Š ”Š’‹“Š–›–œ—Žž˜Ÿ˜Ÿœ“¢¥š¢©œž¨›Ÿªš¦ªŸ¥¤š¦ –© –¥œ£˜‹¡˜Ž¤›‘¥š¢›‘¡ •£¥™¢§›ž£—¢¥–¥¥—¢¢™Œ¡—Š£–‹¥™¡˜‹Ÿ–‰ ˜‹¡˜‹ž–‰ ™Œž™ŒŸ™Œ–‰ž“‹œ‘†ž’† ‘†¤”‰¦”Œ¥˜Ž£™¢›’¢œ’¢›¡š‹¢˜Œ¯¢•¼«¢¾ª£À©¡Áª£Å¯¥Â¬¡Á«¡Á¬ŸÀ«žº¦™µ¤›² —®Ÿ“©œ¨œ¤š­œ”°Ÿ–±Ÿ–²¡˜¬¡”©¡”¤Ÿ•Ÿ›ŽšŒ¦Ÿ’¹¬Ÿ½« ¿¨Ÿ½¦¾©ŸÃ­¡Â«žÅª ÄªÂªŸÃ­¢Ã¬£Á¬ Â«ž¹¨›²¥™§ “¤Ÿ•š››œ‘Ÿ›‘“‹›Ž†œˆŸ–ŒŸ™£š«¡—¬£™¨™’¤•¤”‘£“‘¦“‘ŸŒ‰™Š„ž‰£–Ž • “¢“¢“¡’ Ž¥’Ž¡Š˜‹„xˆt„~r„‚s‚†y€†{…{€ƒz}‚xr€sjxmeshnzpo}om{lr}lr~njxkgxjd{l\vg^vj\peZnd[pd[naTbRSYNNVIMZHN_LM]MMZNO]OQ_QN]OOaSPeVOfWL^QKYMP^QObQHUEOWFII=BC7DE;DE;FG=EG>HI:IJYRDZZLabUTUGIN?U_O[iWWiT[jVWfUSbSGXLJ[NN_RV^POWMQZOMUKAN?CVDDUHGUIJZMI\OEWIIUGFOCFODEPCCMAHQEENBEOCDOBGQAGN@GMAMQFP]LNZKKTHGQFGRFHVIGWLITHLPEGE;><1:7,;9.<:-:;,>>1>=2?<5BD9AC8>C8GPCQ\OLXJJWPJ^VKdZMf\OdYUbWLSL:F;@PBH[LEZLJaRHgSLiVIcONcQQfSTfRL^SBOC?H>BKAFPGJXNWcV^k_\j`_mfYh_TeYWhYXhZXj\`qc]l\_lWXkXHaMCWEAH=KL@FKALNBJODITHJUILXIJTCHT?EP>?E6@C3BA3AA/´ÄÄ~ˆ„z}vtypr{smyop|pv~sz‚x}Šƒ†Œ„ž¤™¸À¶ÀÎÉÉÙÖ¨»²¤¯ªŸ¬§”¢›‰yŠ„zކy‹‚w‹‚yŽ…wŠ{‹|‹v‘‚vƒwŽr‡~pˆ~pŠ€}’…Œ£˜š‘uŽ…n…|l€vosj~rg~uf€sist‰zm…we€tZzpUshXocVgYTdYRaTR\LT^NP[NGVJJSJIRHKVKQ\QLYMLYMOVJMSINVKIQGHOELPEGOFPXQYcYXdYP_UJ[QLYLHWJFXKGVKHSKHOHKOFLKBLMBJTHTdYGWMOSNKVJIVHPZM`h^^g_HOHFKEJIEKIDIKECKBIRDKUIM[PRbWSfZObUR_QFUHASEIYMFRGENCFPBMXKRZOWZNY^PU_OJSHGOECLBEI@CG;BE9KK?HJ>IL@KMBIMAKOCKQGLTJISJDOEFNDBF=?GCG>CJ?DK@IPCOUIO\LS`RM]ON_QReZNbVPbTPaTTeWVgYThZPi[Q_SLVKMTJLPHLRIX^Wck`^e[^e[cja^e\[bYZfV\fZak`]f\\eZ\f[Zd^^h^]f[]f\]f]aia`qdmznnxpismfuml~v}‹‚tƒvkynesk_ld_ma_k`XdYWdXZf\\ia[jb]k]_k__i]bmbcqgduldvl_qfgvjt~qwyl~qˆ‡xŽŠ|•‘‡™‘¯¬¥¿º¶ÑÐËÉÈÄÓÒÏÞÜÙíéåöñìøôðøôïöóïîéæÜÙØÅÂÀ·¸µ®«¨¨¦¢¨¦ ¢¦ž™£™—ž˜’š“”œ”˜Ÿ—¤¢ª¢¢¨¦®±°¼¿½ÛÛØóòðóóò÷õñöôñõòîëãàÖÍÉÜÒÎÜØÓÖÑÍÝ×ÒèáÞâÙÕÑÆÂĹ²¾²©À²©Ä¸°Ä½·ÓÐÌåãÞÌÉÅâàÜúøõøöôÿýûÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿòñíÊž¹³ª»¹®µ³«²°¨°®¥­«¢¬«¢¨¦ž©¨ª¨ž¥§ž¨©¡¤§¡¥¦¨ž§¨Ÿ­®¥²³ª®¯¦¯°§°®¤«ª ¯®¤±¯¥±°¦´²¨¹´ª»´«´¬¥°© ®ª «¨›«¥ž­£°£›°Ÿ˜¯–¬š“©ž—­¢™­¤˜­¤—« —©ž–ªŸ•§œ’©œ’ªž•¨œ’¥˜Ž¨•§”Ž©™§›‘¦š“¤™‘£˜£š¦“£œ–¢ž”¤¢—¡œ’¢Ÿ”¦¥™­­¡®°¤©­¡«§ª£˜®¥˜³¨›ªŸ’¦¥§ ’¥ž¤œ¤œ©¢”¦¢—£ •§£™¨¤š¥¡–¦¡–§Ÿ’§¦™Ž« ’¨¡‘¤¡‘¤ž‘¥ “¤œ¦ž‘¤œŽ¤›Ž¥š¤—‹£•‰¥˜Š¡“†¦–‰¥˜¤›¦Ÿ‘§¢’¥ ‘¤Ÿ§ ”²ª¸ªžº«žºªžÀ¯£¾¯£½®¢»­¡»¬ ¸ªžµ§›¯¡”¯¢–¬ —© ˜¨ –¤ž’¬Ÿ“¬ž”­ž•¬¡–¬¤—®§™¦¤š¤ •¤‘¦‘«¢•¯¥˜²¥–°£”²¢•µ ”²œ‘¯Ÿ“¶¡“³¢’·¦˜´¢•³Ÿ“¯›¬ž®¢—¬¤š¥¡–Ÿž‘Ÿ¡‘¤¡›™š”Œž—£•ªŸ“­Ÿ”«œ“¨—ަ˜Œ¥˜‰¡—Ÿ•ŽŸ•š’‹¡™‘¢œ”ªž•¥—¢—Ž¥˜‘£™‘ •ާ•ŽŸ’Š”Œ„‰Šƒzˆw‡ƒu„„v††|…„|zxxvƒym~sv…{{…ypxmnzmt{o~~ssz€vosere~pcykdvi`qcZg[KZNLUKMVJPYLV_STaTKZOO\MQbUPfYVl__sg^qcQ^QP`WOgZShZgsdLMBHG9ED8II=DF:CD9BD:CD9CD:EF6>?6B@8?@6BG;NYLO`OJcPK]KK^OMdYJaWNeYPgWG[MKYLMVLJ\ONfUQlXQgSKZKISFQ[NQcSJdPT_OKVGJSELUIJVIJVIOYLR\OZhW`pbZn`Rg[PeYQg\[pc`vhcxf_r`^s`eyhUgVN^MDOBCK=HQDJRDKSFKSFHOBEJ=GO?IOACJ:AB7B@5D@4±ÀÀƒˆ{wpvlovonxmq{p…y–›¥“™’®°¥ÕØÐøýûúÿÿÎÙÒ›§ ¾Éߘƒ”Œ|ˆ|“‰|ƒw€ww‹~„‰˜•‰yxŒt‡~wŠz†‡˜Œ®¦‹ ˜}Špzl|tgznf{sd|rc{rf}pnƒtl‚vi‚v_zoXrgYobZk]Wh]ScVR_OT_OUbRL]OKUKHRHJVKMYMKXLLZNLWLJVJIWKGTHHTHITHITIISGJSHJTIEQFHTILZLJZMFXKGXMJXNKWOHTNIPIGKCU]R_i^U\UT\VT_UYeY^eZŒ“ŠmztOYRLSMJKFEG?EGACJAIOCHQEO[QRaVIZMJZMQ[MKZKDTGIZMJVINWKNXGP[NT^RUZOTYNR\OLTIGOEEMCELB@HEI@DJ?DMBGPBNUIM]LO^QL^ON`SSeYQcXP`RM]PS`TSdWTgZTh[R]RLUIIOFLPGQULWZT]dZ€‡}“›xwpxnai_ak_fpdhpf\eZai_^g[]e_\d[[dY[eZ_g^gmgfnc[`V{|vˆŠ…~‚}š£ž’ž™gtlgtjgqlepi`j_ZeZWcVXbUXeXYf[Wc[ZgZ\i\`i]gshjvlhvneuibpdmxlmtipqeusi{o‰„{ŒƒŸ›•ØÔÐþúøÿÿÿÿÿÿÿÿÿÿÿÿÿÿþÿÿþÿÿüÿþýÿÿþÿÿÿÿÿÿÿÿÿûüúØÖÖÊÆÃ»»¶³¸°¦®¥¤©£¡§¡¡§¡¢©£­³®°·±©®¬ª®¬×ÛØþÿþÿÿþÿÿþýÿýþÿýÿÿüÿÿÿïíêù÷õÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿüúÖÌÆÅº³È¼¶É½¸ÔÎÌÿýýÿÿÿþþýÿÿþþýþÿÿÿþþýýýýýýýýýýýýýýýýýýýþþýúüúÿÿÿØÒξ¶°ÅºÃÀº¿¼µ»¸²½»´º·±´±«·µ¬½»³¶·®³³¬±³­²´¯³³¬³´¬¼½µ·¸°¾¿·ÀÁ¹º¹®·¶¬¼º±½¼²½»±À¾´¿¼³Àº²·°«¾µ®·°§·°¥²­¥±¬£±¨Ÿ®¤œ°¥œ¯¦›±§Ÿµª¡¶­ ´«ž¯¥›°¥°¤š®£™®£™°¥›®£™¬¡–ª›”¨›’­ •®£˜®¢˜©ž–¨§ž’ª —ª¡˜±ª¡²« ®¥›­¥š°ªŸ¿¼±±¯£®­¡°­ °¨œ¶® ¶«Ÿ°§™®¥—©¡”ª¢•¬£—¦Ÿ’¨¡”«¤—©¤™©¤™­¨±©ž±©ž´¬¡°£•©Ž¬ ’®¥—­§˜«¨™¬¦šª¤˜© •ª¢–© ”§ž’¨œ‘¤™Œ¤–Š£•‰¢–‡¦—‰¤™©Ÿ”ª¤–®««¨š¯¨³¯¡¸±¤¸®¢¸«Ÿ»­¡¾°¤À²§ÂµªÂ¶¬Á·«½´©º²¦³«²ªž¯§œ®§®¨œ¨¢•ª¡”¬¢•­¢—­¤—²ª¶±¥²®¤®§œ©Ÿ•¦œ’¨Ÿ“«¡–¬¤–ª¢”ª “®ž‘«œ©Ÿ’ªž’©ž“­¢—¯£™±£™­ž“¨™Œª •ª¦›©§œ£¢–¤£”§Ÿ”¨ ”¦Ÿ’¥ž•§¡–¥¡—«¥š¬¦¨•§›”¤œ“£›‘¥ž”¥ž”¥Ÿ•£“¥ –§¢˜£ž– š’¦Ÿ–«£˜¨ –¤š“£š‘—™—‘…Š€‰ЇxŠ‹~Š‚‚„|‚{{…{{…{v…z}‹€|…yu}rs~rv€r}„wƒwwtmrhsj€qg{mdwiatfXk]ThYVeZO]PP\NYdVUbUP_TWfUUeUWgY\l_^qc^qbRgXPe[Pk^Ul]UcTHNCGF9GE:FE9ED8DB9HD:JI?MLBGI=GG;KH=NL>PQAML@NLBTVJW]PR]LQYIOXJLVJNWJDM@BI=HK@IKALPFHNCEODGTHGXMGXLGUIESGHSJLUNQ[PP\QGQFIPDJUHK^PI]PE[LFYIJ[MLXLHPEFPGLYMLYMGSEAKGN@IOBPUIJNC>B7:91:7.<:0<:0=;2=;3@>6?>6@E:HSGL]NLdSScRXi[Xi]PaWO`TVeXM`NN]OGWILaSVm]Ym[HZG>H9CIBJ:DL=BJ;CE:DD9GC8®½¼~ˆƒ|wltlrwpr{qzt‹‹¹»²àèà·¼µÆÇ¼ÿý÷º¾»ÃÊÇÂÊħ°©¢®¥œ”’ˆwŒƒs‹v‰}uŠ}z€~ƒž’« —¥ž‡–‡Œ„}Œ„ކ€†€ˆ„•|‰oxiwphzqg}td}sd|rj~rr‚wr„yrˆ|k‚vcyk^rd]n`Yk]VfXR`PO\LN^ML^NLWMITJGSIMYMLYNKYMP[OMZNJXMGWJGVHGUGHUGGQEFNCGMBGOBMWJR^PN]PI[NGXMIYPM[TIWUJSNORL@I?:C;Y`YU`[WaYaf[ooe £›ž©£^jeLUNHMGEH=EJ@FLBKMDKOFHPFGRFKVJKVIGRBIXGHZJN]MP\LRZKW`NUcRVaTU\RQXOKWMMVKKSHJRHEMCAJ>EO?FNCGOBENAHQDKTGKTFLUJKVJFQGGNDGHBFB=EEKJ?ML@QN?NJ=MK@ONBPPCJN=HN=JP@NTEFJ>BE9EH;FD:FG=CJ?EMBFLCELBDQDEPE@K?CI@DIBFIBEOCISGKTGKRCKSDK]LL`QL`PNaPRcSR`TMXNJVJLXLLXMMZLMZLITGHOBHOBGOCBJ?JRGIQF@B9??5?=3?=3@>5?=5><4>>6?EEK@KKCGLCHMCDL?IQDMTGMYILZIM]LS_PT]NW\LV`LYeTYfYZbXS]SL[OO[NOXLLUJFNCIUHIWGJTGNXKKUHKUGIQENWJOYNJWKISIFODFG@HB=GE=GF=FG>FI@FI@DG>EF@CG=EJ@BJ?COAN\NObQNaRN`QK\PN^SL]QNZPN[PO`SO`SQcVPbTNWLMUJNTJRXNdf]ssmŽ‹àâÞ¥¨£hkemrlelcfi`hlc”˜’~‚|nvoai^\d]ZcX^f]ckbgmh}|©­§‡Œ‡y{y§§¥‰‹‰Ÿ¤ ÿÿÿûÿÿÖÛÚÈÌÌÇÍÊpxndlc]eZZcVWaTWaTYcW]j[_k_cpcmxnœ¥œ‚‰‚tynag\W\SUZReh^pmfwuk~|tutlš–’ÞÖÑÿþüÿÿÿÿþþÿþüÿÿþýýüþýÿûýýÿþÿþüþÿýÿþýÿüþþþþþþþýÿýüýþüÿÿÿôöõÏÍÌÄÃÁ»»¹ÂÅÄØÝÛûþþþÿÿúüüýýýþþþþþþþþþþþþþþþþþþÿþþÿþþÿþþýþþþþþþþþþþþþþþÿþþÿþÿúøøúø÷ÿÿÿþýýþýÿýþÿüþÿüþÿüþÿüþÿüþÿþþþþþþþþþþþþþþþþþþÿýÿüýÿþþýöñò×ÐÐèääøøöÿÿÿÿÿÿÿÿÿëìêêìêÿÿúÿÿÿüýúôôñôôóæèæäãâ÷õõÿÿÿþþýþþýüúùãàÛÛØÓâßÛ÷õòþýùúøõÿÿûÿÿÿÿÿþàÛÛǾƿ¸Ç»µÇºµÂ·¯Äº²Ã½´Â½´ÇÀ·ÅÀ·ÃÀ·ÕÑÉÁ»³ÈÀ·ÇÀ·¿¸¯¾·®¹²©»³ª·°§µ¬¢¶®£·®¡²ª´¨·«¢µ¬ ·¬¥º¯§¾²­ÎżÞÖÌØÊÀÐÀ¸ÚËÁúó깬¢ÕǾǿ²Æ½°Âº­¾¶©½´§º±¤¸¯¢¹°£¼´§Á¹¬¿¸«Á»­Å»²¾´ªÂ¸®Ç½³ÓɾòéßãÔÅǹ«¿´¦ÉÀ³Îƹǿ²É½³Ã¶¬¼¯¦º­¤³¨ž­¢™¬¢˜­¡—ªž•¨® ”±¤—¯¨Ÿ³¯¤·´¦¾»­Àº°Äº±ËƸËÄ·ÌÆ»ËÅºÎÆ¼ÐǾÓËÃÝ×ÐßÚÔçåÞììæÒÒËÂù¼»²»¸°½»±º·®·³§³²¨µ±¥¼´§½¸¬Â¾µôòìÿÿûÓÊ瘑±£œ±¨Ÿ¬©ž®© ©©©¨ž«¨š«¦™ª©š¬§™­ªœ²¯¡¸µ§µ¯¢¯¨š¯¥›¯©Ÿ³±¦´µ©¶·«´´§°¬£±¬ µ®¡·°¢µ±¥º¸­ÃõÊɻųº·©¹µ©²°¥µµ¦µµ§ºº¬µ´§··©¸¸ª¹¹ª··¨ÈǶçäÑ×ϽǸ¨»°¦±ªŸ©£˜¢ž“›—Œš—Š˜™Š’™ŠŒ•‰Œ‘†’‡“‡‘…’‡Œ’‡Ž’‡ˆŽƒ€Šˆˆ~Œ‰€Š‡}‰†}„{ywr€rkzlard^sd[vgWveYqe\te[m^WfXR`SQ_TNaOVeTZcUYcVXiZYr`btfO\SQ[QMSGMOANLBHI7IG:ML>KL=EG:HH;HG;JG9IE9EA7IGLO@HI;CC5BC6NPDOTGOVJPVKJNCIH?HCEJ=GQAKUDOVGQXGN[IGYKK]LRcRYgWSaUO^RKYMLZMIVHJWIQ^PMXKKTGJSFJRGHPEIQFCK@DH?DD;A@6B@6@>5@>6@?6?B8@FVYIRUGIM>IQCJREIQEOXJZdTcn]RaRScURcVM]SO^UMYQELBDI=NPAORDFJ>IOBDL?CL@DR@GWEH[HL]KN\JFR@CN>GTDJUEIREEHAF=DI@CG@EF=CH=DJ?GM@GKAMOFNXLP\PP^QQ\OSZLVXKU]KWcSVeXWcYQ]TL]POaRMZMKSHGODLWIN]LQ[OS]PPZMNWJIREJSFLULENFBJ@CKAEFFH>GH>EGMLAHF:GF7BB6AC8EI>NVF_eVbdVKI@EC8FC:FD:DB9CA9GF>KK@DD6EG;FN@IRBPUEUZJT_MRaTWgUXfTVcSR`RN`SIYKKZKIREGPCJSFLUHFPBGPAGQDJREGNBDK?AF=BD;DC9A?5A@7@>5@@5=A6>H;DPCYi]ctgcse`pbdwi`wi[wi_€qZwl\sgTk]XrcYreWi_SeYO\O;C5AE9CC8AA8B@4EC6FD9GFHK=CG7FK;DK=EN@GTAIXFI\IK^KKYGDO=BP@DSBHVEMWJHOBEG;Ÿ¯«—~}u~yvxxrzzq€{r¸®¥ñêâçåßòðëÚÓËäÚÓàÝÜÌÑϸÀº“¥šž”ŽŸ“‡™’‡|Žƒƒ‡…–Œ £ŸÙÝØÞäßžš³¹´«·±¢¸®Ž¦œ€˜Ž„{‰~y†}w„yruqsqyoivicteatceuelylnus…xp‚spqk~pf{masfWi_Qc[PaVN_SL]OJZPGXLHWKJXLLYMIUHFMCGNEKVJM[MK[KIVGFRBGPEHOHIPIJUHJWFFVHIUHGRFGPGHQIHQIGQEPTHmlc £š®µ®z~{]e^vƒwZiYU]LTWHOQENQDIMAEJ?GLCGJDBFBBFEI?FG@KTIOZOMYMOXLQWJXXKV\LVbSUfYR_SP_RM^RQdUR`SNWLMUIPZKP]MR\NQ[NT^POXKKREMTGMQLqxru}s5=2BD:IGJJC;rxovyhMO?Y]NPOAQMAPJ?LD7IC7GF:GI=ORFQRCMH?KG=IE:ED9AD9@E>SWEcdSYSFFB5@B6?F;DEG:DSEVeWapccm`ZdW^m_g|pb€q_ƒt]~u[tj^tgQh[VKKcWQdVOZMDH?4CGGNII:DG?HKBGIAEGFC9JFFA=MH?NMCPQBWVHb`S@B6GD:DB8A>4DA6A?4CA7@B6CE9HJ?LRGIRDKVDOYHOVELPDJOCDKACLAETEM]KR_LMXFOSCTREPSIKTFLTEORBSREQRHNMBMKAHD=DD;FF;GD8@E9DI=DK@ISHXf[asg_ncR]RXeX`rddyjcxh[vie{kh‚p`ƒr^u^ur[rghyl\gZEJ=AA7DC9D?6<=3HQDMYKR^NYfTS[JGO>FME:>F;@F;@FGJ@IKBJKAFH>DEGF:d`Q‚sdF6)QJ>ZUJ_YOOLB5>=2>=2;:.?<2A=4DB9FEGSES]LYaPU[KQVFKOA>C6EL=PTDNQAPPBGG:KM@JJ>FF:AHC7GNBag[jnccdXPKAHC8HK?FOBJSFHP@IP?HLFN;DMDNBJSIJSIKUIGNDHQDEL>EJ;HM>KMAGNAHQDLTGMRFQSHJOFJQFJRGFNCISFKUHKVFJTFISGHRFHPHFMEBL@@I>AI?BG>DLDIOGJUJMYNQYQLULOWMOYLMVIOYKWaU\h\ZfZWdWO`UQ_TP\RQ]PR_SUdVVaVQWLGJ@EL@FJ?NKBWNBecYXZPBBIJ?JL@CE;GFHF„Š}ööì×À±qYOQB@DA?3??3A:2A92A<7@?7DD;KL@OPGMPEPSGSXKJSCGQAGSDJRA[]MY\LOVH`i]qxgRUEBB2MP@OQBTTFAC2@@1JK>AHN^RZobfyl_pbYl`Ytge€qd|mjxmixkj{jgxh[hZEK@<>2CD7A@2AA3A@2>>0@=2>=2<>2AC7AB6=<0DD7E?5GA6DD9BF9GK?GL?IL?KK?EE8FF:DE9EF:EK>FM>IN?IO@JUEJVDMXJERDCPBGTEO]JUYMSYIT\KT[JTWHSSG™Ÿ…€tysprmsqiywn|s„{–ˆ£¥œ»ÁºÃÇÁàâÜáæÝßäÛÐ×ÎËÑÊÆÍÆª²«§¯¥²¹¯§­£ÔÑÍÿÿýûþý÷ûúäìæùþúàéåÃÏÊ¥´¬›ª¡–¡•›£—š¢œ›¢šœ¢™ž¥š–Ÿ•¢ª£¤¬¥Œš’„‘‰xƒyy‡|r…zu†w‰~Ž„~‡}ÃÉÃñû÷°ÆÂbxr]uk[pfZocUi]QcTN^PLZLJUHMXKMYMN[OLZNO]QN\PKXLLWJKTGIRFDM?FNCJRGJRHITHFOCGPCDL>FM=IN?IMAHPCISFKUHIRDLREJTHJTHHRFGQDISFIVHITDHTCISEFQEHQGGQGEQEFODCLADI@FMFIQIHTIJTKP[RP[TQYPMWMNWJQZM[eW]fZYg[Wf[L_SL_RN_RM^QPcVPbUMYNHNBDF;CI>EI>HH=SJ>SNDONEGD?FF@EKEDMCJSIT_ST`TO[PT_RQ^TQ\ROYNLWJIWGIYHL\NP`RVdXWh[Yj]Uh[Xl_]nafxkfyl\k^T]QQUNQXMW_TT\Q\bXch_jofgkafg\zxnoi`ª¢™°¨§Š‚àÛÝÿüÿøö÷ÕÕÕ»À¾ÇÉÆ}}x‹‡‚ÉÁ½ƒ­Ÿ›·¬¦”ŒŽ‰„›—•³®®ÿÿþØÚئ¦¥Æ¿Àñëëïì뻺¸„„bibdmcanccpecshcshetjcsgcpdcpddnafodeme—œ—pxr^e_fphfsenykmwkq{qu}ryvzv„Š€‚ˆ„†ŒŒ†’—’Ž‘Œ˜–‘Ÿ›“ ™’Ǿ´¿¼µ¯¬¤ºµ°Æ¾¹ôëéûøöÿþþÿþýýþüüþþýþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþÿþþÿþþþþþþþþÿþþÿþþþþþþþþþþþþþþþþþþþþþýÿþýÿÿþýÿüøôéäöèáùòîýû÷üýùþý÷üû÷ûÿúþÿþþþþþþþþþþþþþþþþþþþþýÿÿýÿÿýÿÿýÿÿýÿþýÿþýÿþþþþþþþþþþþþüýýÿúúý÷öÿúõþþöüúñÿüôÿùòúòêþ÷îý÷íÿüñÿûòúðéûñìÿþùýþùþûúÿþþÿþþÿþþþþþþþþüþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþÿýÿÿýÿþýÿþþþþþþþþþüþþÿþþÿÿýÿÿüüùöîëçüýüþÿþûþýüýýüýýüþþþþþþþþþþþþþþýýÿüþÿüþÿýþþþþþþþþýþþüþÿþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþýÿþýÿþýÿÿýÿÿüÿÿþþþþýýþüþþûýþúüýúûýýýýýÿýýÿÿþÞÒÊ¢‘†œˆ«ž—ÍÁ¶šŽ€„†{vuj{nlynl{nlou†yy‹}uŒ}dpa{l_qc\qhYtg\viYrb_xi\xi^odM`R;K=bk]UVLIG?HJ4NNAOM>@8*TJ=OH:ID;E?7?=3=;0>>2??2@=4=;2:<6=A7AFOTDnn`Ÿ›Œƒ}nMG<1>=2<FH@ED>GG@EKAHNEOWMVbWVeXSbUScUQ`TN\PO\PLZNGYKH[MJ[PN_SWfZane_oe[kaYlbapfethctgXfYS[PSWMW]SWaUV_T`g`hnjltnxvotjnpe‚w¬§Ÿ‘Œˆ«¢£ûøù÷ñóöððöñðÞßÞ¼»¹‡‡†…–’Ž—’މ‡‚}x‹ˆ~}t¬¨¢ÙÓÐçæââáÝÙÖÖÖË̺®­¿¸´ÓÍËvuogmcdncbpdeshiwl{ˆ~hujerfeodepdeoairfah^z~wv}saj_ahbgpejtfmwnnzqu€tx„w…Žƒ~‡|z€w}{ˆ‹†‡‡‰ˆŽ•‹˜›“£¤›³²©¬²¦¨¬¢­®¥¼¹±Á¸²Ë½¸ãÜÙòîìþÿýüÿýýþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþÿþþÿþþþþþþþþÿþþÿþþþþþþþþþþþþþþþþþþþþþþþþþþþÿýÿýýÿþüÿþüÿýþþÿþûþýüýûÿýüûþýÿþþÿþþÿþþÿþþÿþþÿþþþýÿÿýÿÿýÿÿýÿÿýÿþýÿþýÿþþþþþþþþþþþþþýÿüÿþÿýþÿþþýÿýúÿüüÿýþÿþÿÿýÿÿýÿþúýþ÷ýýøÿþùÿÿýÿþüÿþüþÿÿüþýüþÿýþþÿþþÿþþþþþüþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþýÿþýÿþþþþþþþþþþþþþÿþþþþþþýüýüþþþÿÿÿýýýþþþþþþýþþþþþþþþýþþýþþýþþýÿýýÿýýÿýýþÿþþþþþþþþþþþþýþÿþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþÿýþþþþÿýþýÿþýÿþýÿÿýÿÿýÿÿýÿÿþþÿþþþþþÿþþÿþÿþþþýþþÿýûöôﵦ›•Œ„ £›ììäîéß³§švriztjxjitfam_crco{ozŠ~m†wi‰xd€p_raXj_^rff{kppn}qbvl_qh^qd¹Á²ääØ{tfIF:MLAFE:EC8FD9DB8FC8DD:GC9HB9PLA]XNd`T‚zm~uirlaROD‰}‰}q]A9Q?6`VK„ynTL?@?1EB7DC7pn_Á¹ª~tfE=0IH>FD:BA7?=2>;0=:/=<1>>4@D:BJ@EM@KQCKNDJPEITFGREFRCFQBEUDHTEJTDIPACK?TYQ§¤“ô¨’w?=2KRDprd¥žUL?HB8HI?QQGTRGHI?OOERSIch\fnatr…~ZaVCOGSg_Wl`RcVSdWKdUQj[YeYSSILK@FF:BD9>1A@0A?2@?2?=1A>1B>2C?3BC8B@5DB7BC6EF:GE:CF:FHHH>FI=GO@LVFJUELVFJWGFVEIYHKYLLYKO]KT_MX`P\`Qˆˆ…~}zstnmogqodxulvoˆ|w¦ž–øøïçìè½Ã¼Àú¹º²¨¬ ¦«ž¹½´±·®§¯¥°µ«ÆÅ½ÜÕÎúùõÿþûþüüóòïêçßáßÒÑÒÉËÑÈÂͱ¼²¬¶®²º³¹¼³¶¹°Ãƾòôíûþýùþý÷þúäðë»ÇÁ†’‰|Š‚w‹ƒtŠƒu‹€zŠ|‚‡x‚—–€ŒŠkxr_ocZl_UhYNbUR_SQ]PU`SXeWYi[TfWLdUJcUMfXWoaVm_K^QHQKHQGJTHMXHJTDJTGGWECTBHUDIRFDNAFOBHSFIPDRTHORFLVIIXIM[OO\PN\NN]OM[LIVFIVGJSFISCHSCGTDEUEDOCFNCHLAGJ>CK=@K=EI>JPEOVKLVLGSJBOGDRFHSFLXJS`RUeXL^SPZNMVHLSCLSCMUEHQBCKBFKAEI>?E:?E:DD7FH=DI@DGAEF?GJ?FNBLPGR[QWdXRdWQcVOaSK]PJ[NK\OK\OJ]PK_QL_TRbZ^ldp|vr{eun_qicqiaof^mcYeZU\QW\PW_R[eXaja_gb´¹¸©³­ƒŒ„aj_msg~€w«©¤ÛÙÔ¡š—ñîíæßÞ±¥¦ÐÅÄÇÃÃçäâ‰kkeŽˆª©¤½½»¢Ÿš‹toe¤•°¥¡úñîòëèâØÖǼº¾³°ƒ}xunkwvolrggqdgugiwlwƒx~‰dnbfpdhrffpddnaemaimbbf\dk^agZ`g`emblvhmvmkvn{ˆ|¤²£‡’…}…{x€v~‚|ƒ††Žƒ‡…Š“‰’›‘›£™¢¨Ÿ¨«¡©¬¢ª¯¥½À¶ÁÁ¸ÂÀ¶ÐÇÄàÛ×þþüûÿýýþþþýÿþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþüþþûÿþûÿþýþþþþþþþþþþþþþþþþþþþþþþþÿþýÿÿýüþþüþþüþþþþÿÿþþüÿÿúþþþþþÿþþþþþüÿýüÿýüÿýüÿýüÿýüÿýüþþýÿýþÿýþÿýüÿýúÿýýþþþÿþþÿûþÿüþÿýþþÿúÿþÿþþÿýýþþþþýýÿüþýþÿýýÿÿýÿÿýþþÿþüÿýýÿÿýþþþþþþþþýþþüþþûþÿýþþÿþþÿþþýþþüþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþüÿýýÿýþÿýþþþþþþþþþÿþýýþþüþþúþÿûþÿúüüþþþÿÿÿþýýÿþþÿþþþþþüÿýüÿýüÿýüÿýýÿýþÿýÿþýþþþþþþþþþþþþÿþýþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþÿýþÿýþÿýþÿýþÿýþÿýþÿýþÿýüþþüþþûÿþüþþÿýÿüýÿúÿþûþýþÿúóñê¿®¦‡…}×àÚøÿúýÿùîä×wofuvmkuhcm`‘œ¼Ëº~ƒyp{pjqj†vj„sctdXbVgse|†wƒtmoeemgv‚zÊÕÇÿÿûʵ¦—‚seYJUSHCA7HF;JH=1?9,PK=^TITJ@SI@TL@YN@YJGLC9PG8TF5OD5FD6AB6DF7VVG^SEOA3OB5AB8DD;DB8CA6C?4B=2B;0CA7EJ?KPEGK>ILLJ?EJADI@GH?DI@HLBJKACD:ORF`fYy‚rkuiIXPJaYPg\QdWPgXFgWHeWO^RDG=@@8EF9?>5A?6B?6C<3C;/@?0<<-<;-<;->=/A@2AC7FD9BB6>@4@B5FB7FE8HF9HE8HG9GE7DE8HEIH?HJ?EM=ENAITCHSCESCCSBFUFKWKN[LQ\KQXGQSCQPB„ƒ~wyumrlgohjshpuj}zox¢“Œðéåó÷ôÄÍȹĽ¶¿¶©±§®¸®¯¹­«µªµ¼µÁþµ²«Å¾¶èÜÕùõòÿýþýþÿþÿÿþþüóøóÙàÛË×ѾÌĸÀ¸»¿¹ÃƼÀ»èéåþþþüüüþþÿýüüõûúÂÏÌŠ˜“xˆ‚x‡v…v‹v‚zt|tmrk“ˆ–hymXk\Yi[UdWSaUN`QN]QScW[k`Yj]UgWLaVOeXWk^]ocdqgYe^M_PJZJJWGKVGGSGHTHIVHHUHHWIIVHGQDKRELQEKPBHO@JPCIQENWLP]UTbVO`SRbUL]OIXLHVKISHMUJLTJKVIGSFERIFQDEN>CK;DK>>F>DFIFKG=BE:SdW‘£‘‚rH;1^XLqn_JD6MENI>GB7FA7ID:KE9FB2CB6ED9GG:MIFNCJNDJJ@GMCGREGWIGXJHVIFQEHRGGRFHTDLWGJSFKOETQHTNFPKBNMAIN>HO?MRGGQEDPDDPCFMBMNCLJ@JLAJOCPQEMQFSZPbbX\cYWfYQgXVm]Uk]UiUMaQHYN.91EK@TTIKG=FC:BB7B@5A<2B90?9.@:0@;->=->>.EC;ED9?=2B>4E<6D;8HE:JF8HE8IF7HH8EF7GBGK>GL=CL=EN@FQCGQDFRCISEKWEITCMUGNSFQQDOOA~}yturlrkiqjlsiswm}zpƒz£”Žâ×Òíïí×àÛÉÔÏâèãìðíâèâáèá×Þ×ÈÍÉåæáÕÓÌßÚÐáÛÔ÷ôòüüýûýþýýþþþýþÿüçíèÑØÓÍÖÐÅÌÆÓ×ÐòóïüüúÿÿýüýüÿþþüýýóõðÃÍÆ£³ª‘¡—”‰vƒxŒu…zs~smukptkŒŽ…x„|\j_Yi[WgYXfYS_TR`QWeWVg[Wg\ReXPcVLaUReX]ob_qd_oe]kdReXO_QN[LJWIJVKLVLKWJIWIIXJKWIKTGLTGKPEIPCFNAGNBIQGOVMO_TRcWRbTSbTN\NKXLKYMLXLNWKOXLLVIHUGGSIHTFJTDLTCJQCAH@DJ>EJ>GL@FJ>EJ?CG?FK?CI>HMBQXNPZPHUJJQFEL@JPEGNCFPBEPCJQEEKABH=BEIGQKAKI@KE;C>4A<3GB9DB5DB4CC6CB6FF8JG9ID8MHHM@JQDISFHSFITGGPCEI=HH=EL>HOAQSGJLBIPGRXJS\NRaSWj\duhfwkfs\^lYNWI‹Ž€¦£”yp`=;.GF9BA5><2B=4>6.>:.>;.@=/?<.@>2@>3<;1=<2A?4C?6B<4C<6DD6FD6EA3ED5GG8DG7DD9DD:DD9EG;IL?GK=FP>FP=GR?IUAJVCNZFQ\JP[JNUHLQEOREOQBwwsnrlhohgohoslrwm~{s‘†}Ÿ‡Êº³ëêåøûú÷ýüþÿÿÿÿþýÿÿúÿýþÿÿÙÚ×ÞàÚãâÚçåÚúùõþÿüüþþüþÿýþþÿþýÿþýøûøèíëÏÔÎÝáÜûú÷þþþÿþÿþþþþþþýýýþþþöùôÔßٴŽ–§…™uŽv†ypslxmhrfgpegnc^f`]h\VdVSbTP^QR_RWaS]j[_ob]obWi]McVOaVQaV^obbsf\maUg_Vg[PbUL[NMZMKVKKYOHVIGWHKYKJWILWIISFJQGFNDGQDHRFLUKMVLM\QPbUQ`RQ`RP]PO[OO]QO]QO[OKWKIUIGSGGRHHTGMWFLVFKQEFKAEL>BK;FL?DK>GI>GH>EI>EI>KODPVMR[QKVLFREJPEIMBJODGRFM_QNWP?F?AE?@EIN@KTFLUHIRFEQELWKNYNKZOK[OIZMJ[NHYOHYPHYPL\QJ^RK_RLaTShYRh[UfZhphŒŒ‡ËÒͮþŒš–etn`ri_qehykaoa_hX]fWej[fg\hcZŒ~}|rx{snxo€ˆ|ƒ‚{˾Àòïì’‹˜’¾¹¶ÎËÇðòñÃÇÑ’ËÅÂÝÕÓ•ŽŠ—‘„}{„~{yup}ytxtl€ys~zp}yn{ulnlbkk`pqigoeendgrgpyow~u‚†|†‹…„ˆeh_fi`logprnu~ty~uikbmogdkbambgoehsglviq{nr|poyousz€u|„zx…z|ˆ~‰’ˆ‹˜” ˜›¤œ©¯«ÛßÛÇËÆ¼¼¸ÆÇøºµàáÝÚÜ×¾ÙÛÖîïìþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþùþûÿÿÿ­¤Ÿº³¨¥ “—…Š|‰Ž«­ž™’‰Š‡{x}mlxjfrfepffpeV^T_bYYc\UaWai^}|n|wjgcWXZPbcWheX`\SZWLUUFTPEPPEIJ>JH=JGMK@RSDrk[jYG[NCUNBQOASOBNJ?HF=JD9ID9EA6GE;FF9EF8HH8HG8JH:LG:IE;JE:HG8HG:DB8A?5CA7A?4BB6CF;IPEKSIKSHGNCJMDFOCP\NQcRIZLDTGBRFBTGK_QMaTIZOFUJLSMJPHHNDFJ@JNCRVJKSEKSDLWGJUEGP@EJ;DJ;BM=FO?NQFKLCKOINVGPZJFTELZNVaVYdYYcOMUCPSDjfX‘†vfUEDC3ED7@>3@>4@>4>:0@=.?<.>;->=0=;0=;0<<2>=3@?5EC8CA7A?5FG9EE7GE7ED6EE7DG8EKDHFG=FN>ITCISAKWEKWDN\KXcOT_NKRCJQEIPALSDqsmmqkhphipipsmrwr||s‹€{œ‹…¼¬¤öïëþÿýúÿþþþÿÿýÿþÿýüþþÿÿÿïñîÊÉÃÖÔÍñïçùüúüÿþüþþýþþþþþÿþþÿþþþþþÿÿþÿÿÿÿÿÿÿþûþþÿþýÿþýÿþþþþþþþþþüüýüÿÿÓáÝ–¥ †˜sŒ‚pƒvhznctharf_ma]k^^f_]g\UdVTcUR`SR^ST^OTbSaqbcuh]pdUjaSeZRdWZk]are\ocUj]Tf]QbUN]QNZNLYNLZOKYLM[MMZLKXJKXJIWHITJGSGJTGJTGMXLQZPK[ON]PP_QP_QNZNP[QN\PN]PM[OIWKGRGGSGGPFEOCKVFKUEGPCINDEL=DK>BK?DL?GK?HJ>EI>DH=JNCUZRW_UJTKMWJMRGONEMNDMUJ\i\S]UDKEBF@EH>HNBKRCJSGFOBISFNXLP\PKYMJ[QK]QHYLGXKKZQIWPHYPIYNJZPM^PM_RQcTQdXUeWbg]ˆ„ñô𩸱˜¤ž„‹gunn~szŠ|fug[gZ[gZ`k\u{nppgrog|}q|€v„ŒƒŒ”ˆŠ‰‚­¡¢ÚÒΗŒŒ†èãÞóððÑËËÏÍË”ŠŒ}¶©¥’Ž„€Š…vsotpk‰†rqionfmocrtgqrfnmckndiocisiepfkwlyx¥¬¢·º³¦§¢wyrilcgjapojwvqrzrfjahi`ijaci`akagoehpflvipzmozonypt~rv~txww‡|€Ž„‘˜‘™¦ž¤°©¥­¨ÚàÜÿÿÿÿÿÿÿÿÿÿÿÿëìêãäâÛÝÛìíëÿÿÿÿÿÿþþþþýÿþþþþÿýþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþýþýýúù½·³£¤™—‰“Ÿˆ’‚‚‹|Ž‚ÆÄµ‰Š}pzmnymgsgfrfowm{wnohbkdcqfgqeno`ol]fdW`aWbeXfk[_cYXZOUXHRQFNPDMMAMH=KH>GHMJ=NM?GC6LF4CD;FKBHQFHSGITFLPGJRFLYLRbQJ]NHZKE\LH`RJcWKdXLdWJ_TJVKFPFENDEMCJNDKODHNAIQDMVILUHGOBGNCEN?BN>GRBNSDLODINDP[LZeTV`SISGHRGMSJYcTOWJIKALG=C9/PB7KI:PNBGE<@>4?>2?>2@?0??0AA3?>0@=3@>3;;1@@6>=3BA7BB7EE8DG8FH9HH:GG9GH;GI>EK;EKFK@X_U]g\P]RS^QS]OQWKLRGIOET\Q]h]HPGFIAFI?JODHQAHOAINBLRES]ONZNLYMJ[PL]QJZMJYMLZQJVOFWKIYMHXLJWLJVKNYNN^RVcWacZІ}Û×Òšœ•œ¤›‡‡z…}z…}‡”Šs}q`lcZe\dre{…ybi_rtlz€t‡Šƒ˜›“–™Ž˜—Ž•‹˜‹„{v™’ŠâØÔÜÓÏÔÇÇ¥ž”Šˆurrgc~voztmqpktslsrjsrimqfiochqelsglpfhmbelbhqgkxkgvir}svx®´®ÀÁ¾ÊËÉrvqgngzvsuottoz~tlohdgacgachabi^ekciqfjthoymlxmmxor{qu}swƒxxŠ‘‰•ž—™£ž«´®¹À¼ÿÿÿúýûüþüüüûüüûÿÿÿÿÿÿúûúÿÿþýýýþýþþýÿþýÿþþþþÿýþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþöóóØÔÓäèàßåÛ·ºª}~u„yÍÏ£¢”pqdmsfjoeai]cl_mugrwllodch`dnchrehl]jj]deX^cXagY_eU[^SY\PZ]NWWKQTHQQEPK@IGNNAjj\ЇyPH?IB;KI@NMBNN@HH:JJ=GHJK=IK=HIHH>DE;EF:BC:BD:?F;EOCIYHFWEHPGHQFJVIM]LO`PJ\MI\KK`QNcUMcXKaTK_SMXMEQFCNBCK@FK@GH>EI=KPDKQEIOCEMAFNAGOCFRBGRBKRBIOAGPCHUGS`RZdWU`ST\QT\QU[RIMDIKASRHYUKKEB0@@3??2B@3BA3B@4D@4>@4=?4=>4?@6BC6EG8DJ;FJ:GH=EE9EF;DE:BG8DH9GK;EF:DD8EF;FI@HNDNVKR\PNZLK[LR`LOZGKQBNUFQ]LRdQnrlquolujipgœ¡›š£œ|‚|…€{˜‰‚­›’æÑÉùóîþÿþÿþÿÿþþüþþþýÿÿýþýú÷ûøôþüúýþüþýþÿþÿÿþþÿþþþþþþþþüþÿþýÿþþþþþþþþþüþþþÿýþÿýþÿýþþþþþþýýýþýüÈÌÈ›¨ ‘ž•‚’…wŠ}o€vhypduk\ldYe]X`XXaYXeZSdVPcTOaTRdVQaWSdXUfXUfXYj\Wh[Rh^Vh[_m`bqcfwi`sfWk_UfYWfWP_OM]KN]NEVHHVHKWIIUGJXJGYJIXLIYKGXEIZGO]LQ^NQYMMXJMZLJYLJXMO_TTbUNaRN_SJ\OHWKHSIKSHKVIKWIISFFNBFK@JK?CJ?DKEDNFEMCFLAEK@EK@HMBR[QYdZTcW\j\Yi[SdVLZNJSHQWNVbUPXLJLBLLBKMADK=HM>NREPTISZMOZNN[OL]QJZNM[OKYMKWNFQIIWJKYNN[OOYOKTIKTKOYOU`U_dZdaVpg^€wo©¯£˜Ÿ”•Ž~…€{ƒ{ksiZ`Zbibgpf»Ã¹ag_mpjt}qvystsm{xpŒŒ€““‰ƒ|v{wnŽ„Á¼´—Œ†Š|yuutmixvqxvqppinnehnekoejlbei^ch\en_eoehsghpegpegneishiwhkvju€v~‰‚ÙÞÜþÿÿÔÕÕ^c`ˆŽˆ“š_cZ`bYcaWad]agbdkefkcfh]glekrgisgnyllwln{r{ƒx‰w…z{Œ„€‘ˆš“¡«¥­´±Ýáàþÿþýýýÿþþýýýþýþýýýýýýüüüýýýþþþþýÿþýÿþýÿþýÿþÿýþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþüýþþüüÿÿÿÿÿûÿÿú¤’…znj„yÒÒÇ‘Žvsfqpdhf^bdYbhYjrbnuehl_WZPemb˜Šu{nnpdeg]ZbWZaS\_PZYPXYNUXGRSHQTHQRFMI?KG<_bT¤¢‘beTOQDPMDLJAKJBNK?QREkl]nj\PG=PG@JJBSTIQQDUUGPPDMMAFI=IK@LQBPTFNSCNRBLO@KN=IL?GI?KKBHK@IJ@HK@FLAISEL^LJ^JMVMKTIKXJO\LO^MN\NKYEM[JQ_SP_TO_RO]POXKISFISFHSEEK?DE;CF=FI@FJAFKBDJACI@HOEHSFITEISBGP?CN?ESGMXMP\NLXJGTGJUHOPFLK@KK?KK=FF8ED7A@3A@5B=5@?4?A1?E/DB7@@5??2DC5@A1CB2?@5<=3?@6AB8CF9EJ9@F9EK;FI=EF9CE:EGGKBHKBIKAII@FKFFODHOAKRBHOAFK?IRELXJHXJGVHMXJOWIJKCEEJI?KKAFJ>ED8C@6B<5B=4A@4BB4BD3@A1CB4CB4DB4HD8BF9AB7@A7CH=DM?AP>EN=EK;FHNWHmrfsulxwnˆˆ˜“Ÿ¨ {}~y‹ƒ{—Œ‚ª–¹¡›Ç°©äÓÈÿý÷ýýýþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþýþýþýãëꪳ®–¡š‡”‰zŠ~pvj|seymcwkYmaUf[VgZXgYXgZVgZXg[ScWSbWNeXQi[Tm_Tl_UnaWocYqc[qccuheukbrg]ncUi]PdWOaTOaSPaRL]ON_QO]ONZLLXJMYLKYKLVJNXKLYKJXJN]OQbQVhYWi[QcUQ_SR`RXeVTeWRdVPcUL_QHWJGUHGTGIVHGUIGRFFODEKADL?BJ>DJ@FMBFNBFOBFMCENBISGLYMN]QQ`SVcWWdXVfYR_SNXMQYOTaTWbTQYLMTGJOEHMFKSCNVGNWKPZMT_QVaUSbORcPSbRN\OLXKMWLQ_MSeT[o_Vi[KYOMYQQ^RO`TUfZ\f\mul|ˆflcdh^\_V^aWej`¬²©ˆ‚v}w‰†”˜prmy}xt{snypkypnzqrxosum“‹~~tpnesohxxrŽŽŒµ¹³×ÚÕ‡‹…–™“†ˆƒ}€{sxqqto^b]hohhrhcqddqeal_clcfoefpegtjm{poyru{sÎÎÈÿÿÿÿÿÿåââ‹ŒŠ•–‘À½¹ïíèx~wnqg{xr|r­·¬‘˜Žuxoy€t{€vszpˆ}vvz„z‚ƒ}y~vx€v}…|…އ|‚€ÏËÇÔÐËÖÎÊåßÝþüýÿýþýþþýþþýþþýþþýþþýþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþüþþÿýÿúýýþü÷½¨›‰ŽŒ€t{zp~ypxxkoxgnpdhl_ioblqcfi^cbYUTO_cY¬¯¤œœ‘df[ag\Y`UV\Q_eZafY\aTSWJTXHUWJSUISUIQSHPQGVTHWXLSVIOSFOQFPQDRQFQVHZ\O|pmd[GC:JJ>NG>LH>KI?abUtrdUSFA?3IH>NNCNQDNRBRPGLNDMWMVbWUaTR[MMSIKPEOUIRYLW`QZfVYbVT]QMWJMWJGREEQDJOEHSFDRCMVIQ[MUeTUdYRcVK^QKZNJSHFL@DJ;CI>CKADLBHPDGOCHNGFNCFNADJ;FJILAH;BHLKASTHUPEOG:GA8IE;LLBLPEKPBONDHJAIPGGPGPXNQZMOSIKMCOPGRUHW\Q\dVgk\]cTT]PT^QLXMGTIHQEHTGN\NPXLOYJIUFT\TO]TMcWNcVQ_QOUIKNBHNBGODHQEGREGQEGOFINDMPEDHBL?LQDNOCKOCJTGL[MLPDJNBPOCOOAIJ4B>5BB6@@4@@4B@7DB8EC9DE8FGLP@NTEMVIRYKNUEMRDOWFS_NTdOpsjstjxxm}|s|„uŒx…wz~u~u€xŠ…}–‹ˆª™“»ª¡»«¡áÓÏÿÿÿýýýþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþýþüþÿýûüúêöò½ËÅš©£…–u‡zk~pdtj_pe[laWi\WdXZeZXfWWeWZgVWeUVcRVdTUfYZj_\odf|pe}s[tkZqeWmaYk`Yk^Ui\QgYOcUMaTOaTI[NM^QJZNNYMMYMLYMNZNMZNOZOMZLLVIMVJMWKM\OSeY[qc]rdQbUJXMQ]NZdTWg\Wg\WeZN\QJXMJXMP[OQ\PLWJLTIMRFGI?BHGB;LJBWUK[SILC9H?6GC:GFDNALQDOOCKMAEOBDTFJQEHL@IK?IJHN=FM;GLFJ>HKBGJAJNCKOBLKALK>IM>KP@PWGQ[KT]PR]LP[KS`MSbPTdPptkouiptjqujqzms€tv‚uw}tz}s}€wƒƒyˆ„ž’Œ¬ —½°¦øôðþýýþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþýÿþþþþþþýþüÿÿÿäæáÈÏÊÁÊÄš§ ƒ’‹sƒxiykbrg]obWi\TdWWcW\fYZg[[k]WhZUgYRdSWhXZl`\ocbxjk‚xj‚y]ukXqdXnbUj]Vh[TfYPcVNcSM_PK]PL[NM\ONZOJZMHYMM`SO_SM]PR_SO\QNYMOWLU^UXf]dtjavidvlP_UN[OR^QYeTXj]VfXSaTP]OJXKIXKT`UYeXQ^RO[OKTGFNADKCEMEHQHKRJGPEJTFHTILXLJWKMYNP_SVdXSdXOaTL]ON[MQYJSXHOUIKPDRWHQWGOXKMWJOYNR]RVaVUbVQaTO`RVaVS_UL[RN]TM[TP]UXi]`rfbtg`reXj\N`QTYQSXPYYQlg^”‡txnV^VSZQR\PT\P[`TcgZee\^^T‚„yuska\X£›—£¡ …ƒ‚Œ‹‰ÌÎÆâáØš–mjekh_vph²©¥üù÷üúøðçåú÷õ÷õóÚÚ×ÌÐËÍÊÊÛÙ×ÈǨ©¤“˜•gol”š’aj`emfcldckdcibdlefjchf^smf‡|v‰zt¾°ªŸš’~}tpmdmibkkbih_hg^`_WdcZji`qofolfomfmnenqhx}rx~rt|us~uv„y{Љ…‘‹‹”™”›ž—¬®¦ÈÇÂþýúþýýþþþþýýÿþþÿÿÿþýýþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþüþþýûûÿÿÿõá×à¶­¥šÁÀ° ¤–Š‚vvlmodlsggsafpau|ompfhj^·º¬€rjcZPngZhcUkj[“†rwm_e\ZdY]j^^nb[k^\fVV[MVUJUSIWUK^_U}|r§¥š²¯¤\VIOL>MLIL>KO@OVEFJ;?B6BB6CC5DD7DD7EG9DE:BD9ED5CD6EG;IO@SXHUZFLRDJL@GH>IJAILAIOCLQAGK?GK?ILAHL@KOCKLBLPELSDPZHS[JRYJQ]KR_NTbQUdSWdSXeTmsjnukjrgmwkmvlp|qr~su|sy}tzvu‰„~—Ѝž–¸¯¥úøòþýüþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþýÿþýÿþþþþþüÿÿÿØÚ×®±¬šŸŒ•‘~Šƒqthvibsg^pcXi\XfZ[gY\eYkymn€r^qcZm_Uk\Yo`\tg_wlf€sl‡|hƒy[vmVqdSk_Ti]SdWSeXQcVPaSQbTP_RN\PP\PS]SPeXZqcVm_LbUPbUR`TS`VMWORYRX`Zryjzsh{q}†ixpTaYR`TS_QVhZUeWTbTO\OJYJJYKO`TRcWSeXPbUK[MFUGHRJGPJHOJIQIHQFKRFHVIJWKJVJO[OQ\PWaUUdWR`TLZMO\NRYMRWJNRHNRFQUGQWHLVGJUGNWMYbYVbWTcWPaTQcUXeWTbUN_QOaTRcVTeYWi^eviduh]naUdVP_PW]STYPWWN]XOXUKUZNRZOS\QT`TR^RUaSYbVklb‚„z{|rgd\qfdwif««©ª­¨ilg¡¥žÛàÖ²·¬Ÿ›–rphmh_yof–ˆåÚÔã×ÑÛÇÁîàØÞÒÊóîçøõëÑÎËÖÐÎÀ½¸³²®‘Ž€…ƒ¡¨Ÿiqicleckdmslmpkbhb^d\^bXgf^pncvujrd\id[ejaildoogef_af_cg_dg`cf`eicfjdkickjckmcqriuwlvxmtysw~vyƒyŒ‚ƒŽ‡†ŒŠ’Ž•™ž–¯°§¹´¯ß×Ôîììÿÿÿÿÿþú÷øüúúÿþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþÿþÿýýôòíǯ£È¥šž˜Šœ™ŠŠ‹~ƒ‡|{}rqujmwinweoyh–›Žz{ohdXph\iZRmh\lm]jl[fhYu|movk^f\\f\\j`Wg]Wi`aiZ\`S]\QXWJSRGdd[††|‹‡}xmdZPCVQDKM=WUIbSH^H>VH=PJ@HA8IF;MH>HE>GG>IE>NB;LC9JB9FA9ED;EH>RVJZ`M[\LVVJMNBNSEOYIPYOV\QRUJKLBPPGZZQc\PYUGRQCQRFMPDGL?JKAKPDKREPQGfi[ˆ’‚TRDKI;NOAGN>DO>JWDMVILWHR_MLXIIRFFMCJMBDI>EMBKVJMXLHWJPYLMWIFQCCL?FNBGOBGNDIOFKLBLMDMNCKLAMMBMQDLRBJQADH9AB6BC3DE5DD6DF7EG8CE8FE6JI;FHJH=FF9FF8FD8KF=ML@TRGNNBOOCSQGOMDZUL\XNOM@KJKF;KH=KL@LNBVXMRUIVSILOCMUIQ\OeqclwhS\TNWLLXKMZMKXMHUJKNGDLABL@IRDITHCRFP_IZdQabRjjZUSFFJ=LJBJPDHMALMANPDJOEINCKRGPYMRZNINBAE9KO>MP@FKMMALNBMODORFUVJd^UNL?PPAMM@JI>LG?KMCLNCJKAJJ@IK>FIGLAHNBKPEJKBKQFIWKPaSYj]TcUU^TP[OKVJITGKVKKTJIOFBMA@K>>G:EOCHVJO\IV_N^_O__RYYNRSHKKAKQEMTFNQDMQEGPEJSGKTHQYMPXLPUIIK@QRBgh[LOBGJ=FI=HK@CJ;FM?BI=AF:CIESCN\MJXKKWJLUGNWGPVIMRDNTEOVGOYJSaSVeTTbTWfXXfX[jZ]m[`jZ`jZ_hX]fWYbTU^Pgoijpkpvqtyp~wx€zˆˆ«·¯‰“sxtƒ~y„{Š„}–†±¥»¯¥Áª¥çÙÕÿýýÿþþýýÿÿþþþþþþýÿýþÿþýÿþþþÿþþþþþþþþþþþþþþþþþþþþÿýÿþþþþÿýô÷òÁÇÀ¨¯¦•Ÿ’„Ž‚~ˆ|y…zu„ynthzmcuh`ncbnb`m_[i[_k\^m_]na`thaulbxna{o^{o_{qd{rg{rczq`zlZrfTl`Ti]PfZNdXPcSNaQRdWTfYXd[[f^uqgyzs˜‘irkbne_pc”¤˜™¦œt|rx~u|~vqtkqrijkfjpl\mfQe\QaWQeYReZOeYSh\Uh\OcVQ`RUdVRcUSdVPcTJ[LFVIFSGMWKJTHJTHMWJLULMUKMUJIRFFQEHVJO]RO_TPcTQdUTdVM[PITMFRGJUILYJLVINXMNYLS_QR_SO^QK\PO`VO\OO]QQ^SQ_QNXKS\NS]RUcVRcUTgXSfVUhVShZWiZYgYS\PQXMOWLPWMQZPS]RT]SU]TZ_Ude[hi`cc[db[faZe`Ykh_ppfpoevnfpe\ncZbcZde\`aVacXcg]gkbnmfsskyxn|wm†~sƒynÌÁ¸ÒÈÃ˾¥žš™•‹‰njfqng‚y ¡˜ˆ‡‚kkg]c[bf]]bY]cX`f[dj_fjbejaaf\bh]hncipcch^af]af\fi`jofglcilgflefmfkrklrkpuoqzotsvwŠ€‰”‹‰”Œ•‘š’”œ•š¡š¢©¢¯´¯¿»ºÇÄÀÒÒÌÏÏÉö÷õüÿÿþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþÿþþÿûýðåãéÝ×ôãÛѾµª›“‘”‰…ƒ…ˆ}Šz„ys}nnugmqeqsfjk`jk`vqjyriqk_speecYee[X\Qcg\ei^adZ]`UVYNWaT`i\aj[]aUUXLQRFQWLRUKOOCPQERTF[]Oik\icXPF=QHALG?QKBRKBNJ@KJANPDOQERRFPTIQVJKRDBJ=DF;GH>JI?LODOTGTZNJPDPREZTGQO@OPAVWLRRHKJBEK@HMBHMBJKBKLALKADH=BH=HPELUIIRFJRGKOFJRHLZOPbUUgZReXR`TR_RO\NNWJMUJMUKLTJESEGVIMXHQ\OM]PR[KV[OY[ORUIRTJNQFILAHPCMVIQXJNUHKWIKYKP]OOYLMVIMRFHK@HH;EE9IICJ=CM@FQALWHQ^NN\NR`RLYINZJPZINYHLVFS^NYfYZh[YjX[j]\i]`labm`ak^ck\ep`hscbm\[gWXfUiplmrnqxrt}u|€ƒ€››–½Àºª°«xyv|w|u‡‚|–†¨¡˜²¬¢± ™ÙÍÆÿýúÿÿüÿÿþÿÿþÿÿýÿÿýþüþýþÿþýÿÿþýþþþþþþþþþþþþþþþþþþÿýÿþÿþðôñÒØÒ·À¶ ¨’ž‘ˆ‘„‰}{†{u‚wkzoexmfvkbpe_k_YfZXfZ\j[[l^Zpaaznd}rf}u_zpWvkXrh[offxmk‚ui€t_wkTl`WpcSj^Tj^UgWQdUTfYVfZ^lc^ha`]UebZ“•Ž­µ®eribncij_mmauwklpdhpdbl`hkb}~x†€cqjRe\QbYYg]R`UP`UPcXOfZHaUPcUUgYTgXViZTiZLcTJ\OIXLKUIISGIRGJTHNWLLTJMUJKSHJVHIWIM[OP^RO`SQaUSbWQ_TFWNHWLKYMP\PQ\QS]SR_RO_PP^RO`SO_RO_RT\QS[POXMPXKPWJNSGKXLP_RTfXReVSgWUhWXjZXfY[hZXbVR]PNXLSWLRVLUZSUYSW\R[`U^e\_g[`dY\_T\_T^_Tld[ddZbg\fh^ei^ek`]h^ZbW\`TaaU`dY_cZai^nuksyntxnvwk€|r„xr–ˆ¬žš»°¬ªŸ˜xqbc]bc[abY\^Tmmecc]ai^bj`_g]]eZ^f[`h]`h^bf^_eZ`f[hncfna_d\`e\cg_emcjofimdjniinhiqjkskounuytr|ru€vxƒz‚…‹–ŽŠ•Œ”˜”›–›¢¢«¤©²«µ¸µÃÄÀËÎÊÒÕÑüþþüþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþÿÿÿþþÿûýÿùìêãÁ¼³¦¡˜›š”—ŽŒ†‰Œ“‡Œ“†yƒuu}nw~przmosgil`ii_qlgrmenjagdXccYef\clack``h^_h]\dYXaV`j]fpcek^X\PRUHSUHRSITSIURGTPEVSEa_Qa`RUNBSG?QHALG?OI?PKBOMCNMCLNBOQENODNSDPUHNTHJQDJLAHI?NMCNQFPVL^fY€uii]\WJML@JMAGLAYXNROEJKALMCKJ@KJ@JH>PMDFNCPZMLWKP]QLWKKTHKNEKPFKSIT`TVdWXeYUfYScUS`RO\NNXMLTJJWJN^QK\KNZJNZJM[LS\OQZMSZMOWLPWKNVKNTGIREFPCMWIOZMK[MN`RO_RMZLOYLNWJJQDDG=JI@GGJI=KN@JP@JTHQWHOSDKO@IOAIRERTFQVFNUEV_N[cSSYKN\LR`QTdTO_ON[LT_Q[fXYcXYdYXcV[fXbo_pyfpziitb^iYXdT[iXlslkohª°«Þè䕤 ‹‘މЄ€{z}vzzu{xs|xrƒ~wŠˆ}––Ф¨›¶´ªÄ¹±Å°¨Ã©¡Ç³©ÏÀµØÉ»èßÔÿÿüþþþýþþþþþÿþþþþþþþþþþþþþþþþþþþþþÿÿÒÚײ»· ª¤š¡œ•¢š…ˆz„zt~tm{nhwlcumdukaodaoc`mb_mc^pgYqf_zl^{lc|pe{p[xoVshUmcTdYWf[^pd\rfYqeSoaNj]Qi]NfZRbWRaVR^SS]SS]SWaUO_UW^TZ_VXbXV^V[[WS[UY_YS[VQ[USb[Wh`WeX]gY`i]ZfYP[Pai_lxZlbNZNLSHMNFPPKPYRR[ST]TRZRT^VO]SL\QJUKGPFHPFKPGOVKMZOKVJKSHKTGMVIR\OT^QU_RT^ST\TZe]Yf]VbUO]PUcWTbWRaUR`TSdVUfXTeWTeWRbTN]OL[OJZNIYML]OJ\MK^OMaTNbTOcUShZVgXXhWS\OPUKX\VY^XS\SP\PR^POYOU^XXa[UbXWeW^d[_cY]]R\\RYZOW\OY]SUaWS\VV[U\[T^\T]_U[]SZ`SZaUY`T]cXck^dm`iuifthhtjhqhoxnkshkodklahh_bc[]d_]f\\g[cj_fncbj`ejael`dk`ag\_fY^dWbh_diaej_cg\eg]eh\efabhackdirhs{qpxmkoijrkpxq—vww|vy€{~…‚ˆ†„‹Š–‘‹˜Œ›’ž—–¢Ÿžª¦¥±ª­¹¯³¾¸ºÅÁÃÎËÒ×Öôö÷ÿÿÿþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþüüüêâÚÉú¹²¬ÓÊÂäÞש¨ž‘—¯º¯×àÙêõéÍÓ  „‡y…x}ƒwquinncnmbhkegj`imakrceo^_iY^e\ekbjpgksiirggpd^k\`jZbjZdiY[]NRRDTRDPOARODRPFWTJWTJWPGWJCUGAPKANMAKJ=RRHTTJSRHUUIQQENOCPP?OOBNNDLLBKI?KF=KH@OPFSUKZZNTJ=VF:QLBLKANPGVWMc^Pf\MUWKSWKNSHJRFHQGMVKQ[NU`RJVHGTFJUGMWJDPDFQEGQDHREGRCP\MTgVXkZUhWRdVM]QFVLK]ONbRI]JGUDJUDIXHN[MR_QO]ORcRTeUPbR]dYVaWMZRR_VQ`VOeWWjYVgURaQWeUVeTI[JFOCFM?KK=LK=LM=MP@JTHQWIQSCKLLH9MJFK?KRBQXIOTHLNBLM>IP>GR?KSCMN@NLAMMBOPDRSGPSFRWGOTEQWGW_Ndn^bna]l_aqduv†||ppwf`hYcn^`o^usr‡~y…{uqkizxsqvpmwmnwnswowvpuvpxxp|s{tŠ„}—“‹œœ”œœ•¢¡œœœ–Ÿž•ª¦›Æ°¨ÙÇÀûôðÿþüþþþüþÿþþþþþþøôó÷óóÚÖÖÌÒÌòôóúÿÿèõõ¹ËÇ”ª¦™°ªŽ¢Ÿ~’u†p‚znsj|nnxplxnk|ogyldwm_sj_pg[maVl`VnbYrdZte_ui]sgXl`TfZN`TNaUJcWOg]Mg\Ph^Qf[MaUQdWWh^Te\RaYRbXPbUPcVN]RQZPS\RTcYMd[K^WL\VL]UTb^bqn¹ÆÅ_pkO[VMVMOWLNTIOTKRYNPTLLOFLOFKKBVXL_dZ]dZNWMGPEHRGKTJJPFKNDIMBIPEKTHQ\OS^TP[QNXOLWMP\OQ]QR]QR_SP]QP[NUaSYh[Wh[UdWUdY\g[]g[YbSVbVW`UV\QNSJJRHJQHL[OM]PM^PPdVN_RN\RNXMQ^QP]QQ^PM]OO^ORdSVdTWcVS^RJYML^SNcVWh\\ia]g_bndalbmynq}rs€uitj\f\X_WU\TW_XZbYy~spwjŸ¦˜X`VTXPSXOWYPY\S^aXaf_`g]_g]`i_ak_`m`arggujn{mdpcdnaƒŽpylemar|ogrdgvghzlctgdrfbmcdmcfncgleflbemb`g`af\`f\fj^glcjrgktjkvllukluknvlowoqyrw}xzƒ‹“…“‹ކƒ’‹ˆ–Œš”–—¤¢ ­«¥´²ÔáßÈÕÔ½ÊÇÐÙØÚáßòöõüýüþþþýýýþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþÿÿÿÿÿÿööõéàÞÙÑÊûú÷þýùþþ÷ü÷éöéÜÿüõÿÿþþüýþûüÿÿüûûõ¾¾¶˜ •z‡~x‡~qy‰}|‚w`f[gnckvjhvjmwkjpffkafne`g]_c[_dX]bW\_SZ]NZZJWXIXVMTSIVUJXXL]]P[[MZXMXUIVSERPERSGPSJSUJQSGNRCTYJWYMVWLRRDQOCMPAOQEQPEPNDLNDLNEMNDOPFOQEMPAQQFPMBMMAKO@RWHffXZZMTYLPWJSVGRTEMRCFNAKREKUHNXKR\OOXLOYMNZNKYMLXLLUJOWLIZOL\PQbUM^QK\OJ[NN_RWdXQ`RN\MKWKGVIM]NRcUPbURdWZkaO`WIYNQcWVl^XrbVp`WpaWndWpcTj^Uf[XdWRZMPVINRDNN@NM?LJ@JI@JMBLSAOYFOXKKRFOVEIUEO[KNYINSDKN@IQAKUHT]NSYJRUFUUFPNCQSFX\PYbT[fZ]i]YdXksdgl]gk\go`]hX[fVssp{tpvp}wsvtnuyqpzpnzosyqwvrz|vzys|xt€zrƒ~w‹„™™”—Ž“–•–Œœ™‘¢¡–¹ª£Ì¾·ïçâÿÿýþýüùþþýþûÿÿÿåâáľºÓÏÌíðìþÿýûþýóýû¾ÎÍ µ±ÃÚÕš±®†˜yŽˆuˆ€v†{q‚wq{tn|ss‚xuˆ|k‚wd}s]ukVpcVpdVsfXwhYzjaym\th[thQk_KeYSj^RkaTlcUleQh^PeZSeXRcVRaWPcZL_VK_UK`SM_RK[NP[QP\RL_SNgYPg]Pe\Te^`ni™•ÅÏˤ²®JWQMVMNVKNTILQHPSINQIMPGLOELPESTHY\SW[RKOFFKBKSIJSILQFMPFILCILCFNENWMP\TPZPLXLJWJP\PUaUU`VTdWQcUR_QVcSTfTUeYUeXXbXZfZ[dXZdTXbVX`UV]ROTKLPGGNDFRFJWJJZLK[MLYNKWMOXLNYMLYKP\OR_PRaPScQScRTdUO]QK[OOaUPeXTeZanflvoovplukm|t|‹„‚’Šn~ukyrXd]V\UWZT\aX\bWŽ“‡ptg\aYW\R[`WZ_VVZQ[^T]b[\dZ[eZZfY[g\`m_`mceodksfhobipd‹’…~ˆ}jsi|†|™¢™aoex‡}€Ž‚anbdodktiowmnunw€u‡dkdae_bg]dl_hnejsilukmynoxnnvlmwlqyqxƒ{„Žˆ˜¢Ž—“‚އ‚ˆ‡•Œš”Ÿ˜“£›¨§ª¶¶ÐÛÛõüü¾ÆÆÌÖÖçíìûþþýýýþþþþþþüþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþýýýþþýõðîèáÝþùõúôòïâÜÿíàîèØÿÿ÷ÿÿþû÷øÿýüÿÿüÿýôÿÿùîçÝÕÒɃ†z{v¥§œ««¡`^Tsrhnrhnvks{rpukothfmbek`ccYabXaaV]_SY\MW[IV[HUVLWXNWZPZ\P_bU[^OXXMUSGUUGWVHTUJTYN_^T\ZNUSFUTFVTIVTJUSGRRCRRDSTEWWHUUFNOEMNDOPFQSHNQEMPDQRFRPEMMB[aRŸ¤–‚‚sYXMUXLTZNTVGUTFQTELPDLSGNWJMWJNWHKUFLXLKXLJXLJXLMXLOXMJYNM]RP`UM^QM[NMZLJXLL[MN_QScVM^QGXLI[KK\NM^QK]QO_UQd[SdYWh\cxidxibtg^ob^ld^md\oc\na^oaUfXT`SMXHJRBKQBJOCJNCJK?KR@OYHV_RT^ONXGO\KP`OS^NOVGNUFKWFK`QTfV]jX^fUXZMNMBSRFSUIT[NQZN\fZbl`xƒt‘š‹‚Š{el]cl\^iYnrotsnttjstmrtk~„ztsr{psxputptuquvrzwrzxq{{rƒ„z‡‰~Œ†‘ˆ’•Œ˜™šš¸°«ÒÈÂåÙÑóìèÿÿüÿÿÿÿÿÿûûøÈÊÅÆÃÀèäàýü÷ÿþúÿÿÿðòñÉÐЫ¸´ÑáÜ­ÆÂ¥¢”~‰w‡z‰w{p~wq‚wt‰}o†{h‚w\{oVtgTqd[xj]{l[}ml‚wksju[zlOm`Wnb]qig|tWkdPc\RcYRaUT_SR`WPd[J`XJbWKcUM^RI[NK\OM^RK\QL]RVh^RbZZf`dmfyy³¸°vzLVNMVMLTJKRIKPHJOHNQLLOIHKDJNELREPSJOQHKMDNQHRYPNVLLQFNQGKMDFI@FLDMVMOXMNXLNZMQ^OS_QTaUXgZUhZUiZTcVZhXXiXUaVTaTT`UYbVXbVXcSWaTYcWT^RMUJFMCGNDKRHISGHUHJYKIWJLXMPZPP\PP\OTbSVfTVfUSaTSaTUcWM[PN^RUdZZj]esh}‡…‹‡†€‡ˆ}„€— œ™£ž˜‘jtlY`YVZRUWN[]T]`UŠ‹‰‰~V[QX`U]fXYbUX]QZ]SW^T[dY[fYYfXZi]]l`aladmajnb“‡hncmvlnyovw®µ­¬µ¬eme‹”hrfdmairgoyoz…zr}u¶Â·™¢›mumeiccj_embjrgowlpznq{opympxmqzpu}t|…~Œ–”™Ž˜“ˆ’Œ†“Š™“Žœ–‘ š™¨¡¡¯­·ÃÁñ÷öñööÌÑÐäéèþþÿýýýþÿÿÿþþþþþüþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþÿÿÿÿÿÿÿýûøòòóìèþñåøäÙúìãìÚÔȪ¥Ý¼æÓËͶ­¼¢˜èÚÑêáØ‹„zŒ‰‰}zxmplcji_eg]ltj|…{…{y~skthej^dbWccXii\cfW^bR]cR_fT\cT[bTW_PYaS`fZ[bUUVKSTGUVG[]MX\N[^Teh\`aTWWIWUHXVLVUKYXKVVHUXIUXHXZH\[J[[NUUHSVHQTHLQEMRGOSGPRFPRFQXIƒ‡xnl^YYNWZNRXLWXIVTGRSDOQEOTHPYLQ[NNXKLUHMXLNXLKXLKVJJUILUJMWJNZNO\PN_RP_QN]KNYMP]PO`RQdUOaSO_SJ]OL]OM\PP_SQaUTeYUi^Xl__rdj{mo}plti]ha[i^Zj]^pahzjZk\Q]PLXIITDMXHNVGIPCPRDKQ?PYGS]MPYJNWFJWJRbTXdSX_PS]KPaNVk[_r`aq^XaQHK>POEUREUWHW\NZcT\fYdoabobfoclwhr{ktnkuejploulouioxnoxm—ž“£©žsynvyrototvswwsvwqxxrvxozt‚…zˆŒŠ…’‰–˜Žšš¶°­÷îìéÙÕÜËÃëÜÖìàÛÑÅÄÏÍÉØßÛÃÅÀÊÆÁÑËÇÛ×Ï¿»·­ª¨µ·µ³º¶¶Á»ÉÞÚ¿ÓΆ—“‡—’˜¦¢”¢ž„‰vƒ}p‚wo†ziua}q\{o\yl^xkb{na{leqt‡{x†{w‰}crSnbZnakzs‰˜‘hwrTc]Ve[N[OU\QS_VPc[Lf\KeZKdVSdVL`SJaSH]PJYNR[QO]SR^VZ`[hohz}s{|qv{uR[QQYOMTKKSKMQLJOIHLHHNIHNGGPDJPFLODOOFOOEXYP\aUOWLPTHNPFJKBGJAHMGKSKLVKNWKO\MR^OTaSUcUVfYRgXShYVhY\j\Yi[ZeYWbUT]TT`TXdWXeTZeVU_RT^QHQDJRFLTIMRILTIJUHIWIHWILZNNZPO\QR`TXhYVfWSdUS^RQ]SR`UO]RN\QVdY_l_u€tŒ”Љ»À»›¢››™˜ žy{v„€noidd^XYO[[QZZP]\S\[SYVNYaUYcUZeTYcQV]NW\PWaUZeX[hY[k][k_Yi`^l^_i\ƒ‹}u~pfqfn|rt€sus®·«™ž“[bV…Œoujhodjshw„yvƒx€‡¼ËÁ€Šƒhojfjddkcirfkshmwkq|oqznmvlovlu}ru~u‡€•˜“†Œ‡ˆŠ“Œš“‘—–£›©¢ª¸¶ÃÎÌêïíüþþýýýüýüýýýÿÿÿÿýýÿþþýþþüþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþüþÿþþþþþúÿÿýÿüÿÿúÛÀ¸Ã§¹ž¾¡’»¥—ªŸ±•²˜“³ž˜Ÿ‰—‰‡‡}‚ƒwyymondklahndjsis{r{€v{€vw€uouhjh^eeWggYegX`fUbjZfq`do^]jXZeUWbRXbTZcW]`U[]OY\J\]M[_Q[_U^fYel^Y]NSWHW[QVZPYZMWYKX\K[_N^aM`bNcdQ_`P\^NUZNRXLOUJMUHQTHQTITYJ[]O^[MYXMW[OOSGWXIUTFRSDOTENTFMVINXKNYLR[OQYNPZNOYMNZNOZNNYLNWILVIJWKP`SVfWTaQOYMNZMN_QPdUOaSO`RL]QKZNP\PQ^RN]QQbULfZMgZWm^`rd_k^ai^Yi_Wi]UgWTcROZHQXHNWKOWIMUEQZGQYGOUEWYMSWFRZGSZLOVGNUCLZNSbT[gW\cSS_LTfQarbv†tu€lryg^^QPNEQO@RTDTZIVbP`n[ao^fvhhwipymmyhp{kz†ujogoxnqzpqxnwvqx{sqyns{qovntvru|vtytswrtwrvzr{}t}ˆ‰Ž…‰ŒŠ„–•Œ›—¹²«õòìôðëØÐÍÉÀº´§ º¬£ßØÕùýýÝååÈÎËÅÈÀ¯«§¨¥ ¥¥¤¥ž«®§óõïêþý²ÇĈ•“¤°®ÝðîºØÖ‰  rŽ‹jŠ…l‰€guc}og|pc{ni„vj†wb~r_yodxok}uhyp_qhUf[SdZ[fYipfdmb[h`ZhaWa[T[RQ\TTe\Re]NdYNcWOhXShZObUL\QO[RNZRI[NO^RP[Q‹€w‚{S]UPTOW_XNYOJTIHRFJQDLNELOGGNGFMFHJFLMHKNDKNCLOERVK\aVV\QQTILOEJNEGJALPFMRGMRGMWKLXLRYOT\RT^TU`URaUVdXXg[]k^]k^Zd[WeZTaWP_TWeYYeZYfZWdWR\OKVHKXIMXJLXKOYLLVJKXKL\NI^OJ[NMaRQcTWbTV^TVaWM]WO_VPaVQ^SWaU^eYdh\ppe‹ˆŒˆƒ¹¸´¯±°‹¨§¤~~xyugjb]cXZ]TVZPY_TZ_U\bV\cWXcWZdXWbTW`SY`UY_TXbVVdXWk^Yl_[k^]h\]eYaf[ˆ‹€…{o}unƒ|q}tx|s¥£šž”fk`fh]fkafqf_jb¤žæëåØÞÚ¸·²Š‡knhhlfjniimfmtgpvku}st{qmvjpymu|uz€y}†~€‹……ˆ†ˆ…ކД™’‘ž›•¥¡ž®«©¹·ÐÖÕýþþûýýüþþÿþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþÿþýþÿüþÿþýþþýúÿÿüϲ¦³¦˜¯©œ­¤˜®£™¥ •£Ÿ’™˜˜—’“‰‹Š€ˆˆzzƒss|poujpwiw~otyoy|qwt{‡y}‰{y„wrylfk`ji]sqdlqciocmqglqedl^_fWZdT\bV]bY_g[`gZafW]dV\fX_m`dub_iX]\M][LYZMR[PY]RX\RW]RX_Q\bUaeVbfXacU_`S`aUYbQR^JT^QU[PSXMSXMWYKY[LXYOYXOVUMRUJQVLMWHOSGNSGMSHNUKMUJQYOX^OW\QQXPOZPN^PJ^LP[INWIRXKW]PV_QYeTQdRO^RO\QP^POaQQcXXhXQ`RL\NO]QVh[L_QOYOPZNU`RWcTXeXUaURaVWg\Zm`\pcXkZUeQR]SP[PPYLQWJVXLWYNRYLRYKR[LNXHMXHQ[IM_NRfTXjYYfVYfUXkVSiV\mXqyeqr_`]MROAVRGUTHTWIW^OWcSbq`huddp_jve§’¤¨”{{gnrmsztqzqu|ttwrtyst{srzpryptzqy€yz~yvytvwsvxp}~t…‹…’—–Š“‰–™‘§ œÂ¹±ÌÅ¿ÁºµàÚÕÕÌÇ®¥¹¬¤Æ¾¹ÛÙÔØÙÖÞàÜÉËÆ«©£¨¨¢°±¨œ”›š’ÖÖÎíúø§µ°˜Ÿ›¿À¼ýÿÿíþü¤¼¼pŽ‹k‡mŒ„i†{^|o`wj]vhgsi‚to…{x‹„o‚zj}ufwnYj^SdYQbVVbWYaW]d[Wd\Uc\S[VPZOMZRM`WKbYLbXMcVQfZYnaQdXM_SN_SM^QHZNQ]S^cZ„ˆ‹Š]e_fngX`ZNXNKTJJRGHOCLPGHOFIPGIQIGLFGKFJODKPEKQFJPENUJPWLQTILOEJMDFI@LPFNRGNTIKUJLYMOXOR[QO\QQaUPbURdWWh[Wj[Zk]]kb\k`Vg\UeYYfYYeYVaVVaUNZNNYLLXKNYLNWLOYMMVJJWKL\PJ\PK\OOcUReVR`PU`RP^RO\SP]UM]SQ]SXcWW`TZaThi_pneŒ‰‚À¾·¬­§ËÍɸº¸‰Š‰tyshmf_f[Z\VUYRW]TW^SW`V`h^ak_XaUYdTYdTYbUX`UZeYWi[Xl_Xl_Zj^ZfZ]dY]eZYcXiwju†}s†~q}snrjcc[acYfl`df\cj_eoe^i`ÈÌÆÙÛײ¶±–•stnlnhjniipjfoflqerwov{tnvmpwnu}qr|uw‚|z‰€|‹ƒ~Œ„އ…‘‰‰”Œ™“”¢žœª¨£±¯°À½ÛáàÿÿÿûþþüþþÿþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþÿýýþÿýþÿþþýþýúÿÿýÀ±¦¢ ”ÉÌÁµ³¨£ž”¡¡—Ÿœ’™˜Ž’•‹‹Ž…†Š~ƒ‡{~†uzsuxnxzm|q€wy~uzƒw~Š}|‰z{…w{r…ww|lqveiucjzhn|mnyjdp__jX]gW_fX^aUZcV_cV`eU^cT_hZgqedp`[cRZ]M[]NZ[P\_T]aU\`UZbV[dW]eXbi]dl``h\afZafY_hXYeRZgXYeZT_SR^QZeVS_NXYNWXNUWNW\PW`TT`OQZNPXMMUKMVKMWMQZQafXZ_TPXMPZOO_OM^KS]MR[LRZMOVIOWHU_OTcUVaVP[OLWIL\LRcVVi[WhZWfXbobZh\UcXR\OOZLQ\KU`PWdUVbUSbWXh]`thi|nfxhao\[cYV`TPYMPZLR[NPWLR[NQ[MZdSZdT\fVZdTTfTWlZXm[_n]\jYYkYWjYWfSNUCQQAURCTRDUSFVVGX[LU]Mcm\x„q‚Šzoxgnve€†t ¢~ptqv~xv{w~yw}{u|xv~xtvpzps|rx}w{€zz|xwvrxvo}|s‡†ƒžšš¡™“Ÿ–¢¬¦¢®¨¡®§¡£–›˜™”ž™‘¨œ™« ™·®¦ßÚÐÝÜ×£¦¢–˜’˜—‘ކ‘†™—«§Ÿ·¼¸¦«¤¡Ÿ˜­¥Ÿôñíèíê­Á¿~š–kŒ†i…k…|a{rb{mc}lm…wp„wzŠ‚™Ž˜sƒ~dwnWh\QbUUgY]ja]e]YbZR]VP^XQYTMZOK]QJ`VJcYMdXPdWRcZ[maQg[NdVPgXMaSK]RPZOXVOZUNRSK`g]y{gphPYOJRHKQFIMBGMDGPFHPGJSIGPFGLCINEKQGLUJKTHLVJMVKNRGJNDJMDHKBJNDNRGJQFJWKIZMP]RT^UN]SSgYSfYTfYSfWUhYVi[Wh^]ncYla_nc]j^XbVU]TR[QMWMLXLNXLLVJJTHMWKJVJKXLL^QI[NO^SRgXRfURaPS_ON\KRYRT\TWaWT_UYdXV^SV^R`cYmkbsqg~|t«©¢ÎÑÎÎÑÏ–”‚‰…x€xfndY_YU\UX_WW^WYbXgpf^i\YcV\gWZeU[eX[eXXe[Xi]Xk_Yla]laUaV]dY[h\\oai~qu‡}o€wo{oipfhmcemcckadh]cg^hneeka¶²®ïéæËÆÂ›˜‘onfjmdipghqgfpfkqgormuysryspxpu~tq|wx…~|‹…|„~ކƒˆ…“Š—’Ÿ™–¤¢ž¬««¹¸»ÊÇíôôþþþüþþüþþÿþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþÿýýþþþýÿþþþÿþûÿþúûúóáæÝùý÷òñë´°¨›šžœ“——ŽŽ‘‹ˆŽ†ƒ‹‚Š~ˆxxtv}qv{mwzlxypu|rw€v‰}}‡z‡w€†v„‚uynwsgx{lyƒs{…to|kgvfap`^j]_eYabX_cWaaT``R\]O^cUck_afW]dT]fT]dU^bVdd[bg\bj^`j][dW\eYdobeqffqgcncdnbfn__hV^l^`nb^naYg[Xk[SdSV[OVZOVZQXbX]l^VhYQ_TP\QLZOQ^TO[SOZRZaSW`SR[ONXKO]KUaOQ[KQXKPVJOTHLTGNXHQ[NX_VUZOPXIQ_MUfYUk[VhZVeWZgY\fZVaTS\LPZJQ]KR^LYcUZeXZf^]mc`pehxlp|ofpb]aXX^QR[LT^OU_RS]RO[MR]O[eXep`eo_bk\XgUWjW\m[al[]fW\fX[hZ`j[[_OSTDRQBSRESVFY\L\_O\`PglYv{hu{jgk[Z]MgiY‡‰z•—‡twu}†ƒ~Š„w‚|v€u|w‚v‚{p~vn}qsysy~yyzuvuqxuo}t~z••¡¥ Ÿª¤¡¨¢Ÿ™›™‘‘‡”’Š•“Š’‘‰“’Š™‘‹”‹¡—Šœ–‹‰‰‚“’‰ŽŠŽ†‰‹‚ŒƒŽ„ŽŽ…““Š–“‰¦ž•Àº±–—‹ˆv‹†tŠ…p‡nƒ|jye€rj„vr†y€‘„{‡ƒ‡Š˜”m|v]pgSg[SdWXfYbofahaZc\P^UO]UPZRL[OK_SMf\Oj`OgYM`SO]VTf^NcXIcTMeVLcRK\PLVLTSKUQITTLTYQS[PPXNMVLLPHKPGHODFMBHQFMWKJUHHQEJQEJNELSIJTHIUIMVJOXJNRGJNDJMDILCKNDMQEJOFKWMJZPP]QS_TTfXRhZTgZSdVUeXVgYUhYXi_]ncfwlcthanbQ\OQXOOXMMWMMYMQZNKSHLTIMWKMYML[OL]QI[NMYON`SOcRSaQS]NOZMTYPW_UT^SRZPRZPSZPU^P]bWilbyyqމ®¬§òóòíïîÃÉÆ™¢Ÿt{vjrgV]W^d][b[W^W`h_clb^eZW`T[fYZeXYfY[g[Xf[Yi]Zk`[l`Ye[V_UYbV\i]ashl€uo€vo}qeufbl`engitlcmbci^ee\ef]okdtibˆ{uznjuskkmdhkbhpfhrhhrhlrijqklrmqwrszuu~tu€yz…{Š‚‚އ†‘‰‰”Œ‡–’‰š•“¡Ÿ™§¥¤²²¯¼¼Ç×Ôúÿÿþþþüþþüþþÿþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþüþþýþþþþþþþþþþþþÿþþýúúÿûüý÷ÿý÷ãÙС›š›‘‘“ŠŠ‘‰‡Ž‡‰‚Š~~‹zuturv€qu~nv{qvsvt|…{{…y‰{…Ž}‚ƒ{{xp€vytƒ€r}powlkwkdrgbmcci_``XaeXdfWccS__O^aRah[eiZdk[^iY^iY]eYch^fm`eob_l]\j\^j]docftghshksiipecm_eq_bobamabnb_mabpa^m[Z_RV\PV]TV`VXh[Vk[Xi^Wh]ScXP`ULYQKXOT]QS^QP]ON\NP\MQ\KRXJLTGLUJOXLQYLOVGNWKSULQRILPBP]LSdWXpb]obUdUYcUZcVS\OR]MPZIOYHVbQ[eXYcVVbY\i]`ma]i\ai\beYYZPY\OT[JQ[JU`RUcXSbUSaSZgYbl_bl\_iYZbSZhWXhS`iTQTETWJV\R`fWcfVUYIVVG\\N[`P^aQ`dTdeTfhUgiU\dT—…Ž’‚‡ŠzV]L£”uzv…Š‹›”~†|ˆyˆ„{‰†y…‚u„}oxpyqovqrwqrsoutm|yq€|v…{¢žšÂÇæ®¨–›“І‹†‰‹€‰Œ€ŠŒ‚‰Œƒƒƒ•‘ˆ…‰††ƒ…†ˆƒ„ˆ€„{~ƒ{}‚yƒ„{„‡|ˆŠŒ‹‚w~ƒyt~vt…}sŠr‡q„|p…}i…yh€ul€so€sp}sn{qmztdtlWjbQeXO_TR]SV`X\b[XbWP`TM`RL\OO_QRgZTobPl^RfZRaUR^VSdYNcWMeWNdVOcTKXOLTNKQHOSIMQHMQGLRINSJNQHJPFHPFGQHJPDKRGLUIKTHIREJQCMNGKQHITGGSGOXKNVILPEIMCILCILDHLBIMBJOFKVKL[PQ\Pgti_ocUj\UfXUbTWcVUbSTcSZf]cpem|rjxmeocXcWSXNS\QP[OUaTPYNMTGNTKNWMMZOP`UP`UK[OOULL[NL]PO[NNWKNVMPTKU[RU\SQZPSXOUYOT]QZbViofx~xˆ‹ˆÂÂÁùùøûþýÿÿÿÕÞÛt{upunY\Tae^\bYX_T]e[^h]Y_WW_U_h\^j_\j`Yh^Zg\Yg[VeZYeZYbWX_UYdX_k`erjkxpn{pftg_ra_madrigwnbodci^ce\cf]hf^qh`qg`niakmdilbglchpfjtjnwmnwmoxppxsu~wr}uvƒy{ˆ~z‰‚‘ˆ…‘‹‰•—“Š™•‘žœ–¦¤Ÿ°¯®¿À¾ÐÑÒàßüÿÿÿÿÿüþþüþþÿþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþüþþýþþþþþþþþýþþûþþÿþýúýùýûöùîçÝÏÅ´¬Ÿ°µ©›¡••‹‹“‰ˆŽƒ”‰ž¦–…Œ„Œ€ƒ‹}{„tzx|‚ty€txw~ˆ}Š•ˆ†“ƒ|Œ}™ —‘–ŒvuÉÕÈÅÏÀŽ‚pujozogtjirgci^bgZfiZfgWddTbfVaiZahZcl\^iX\fX_k_`maerehvhcrcdrfisgmvkr~o¬²¤¿¾³ef[^hY_q`aqccqecpdhtim{khtd`jZX`UU]QT^UVfZ\n`[pb`sfZl`UeYN\QKWNJXLN\RScWRcVQ]PPYMOVINUIPXMRZORYMOWJPVIRSIPPFLOBMZKYl`awiarfVdWXaUR\NPYMPXHS\LQ\KWaQYbVW`UT]QVaSWaRPVGTTFSNCQOEVWI[_MU]JS^O]f]Xj]UfYZh[^i\]gYYaSX`V\k\\nYamX_dRXZJTWLWZLZ]M]aN[_M^aP`dW_aRccTddUccSbaPX_Q“„çä×°­UVF•›Š}‚|€‹ƒ}Ž…‹›’¤»²˜ª¤|‹ˆy‡…z‰†u†€sws}wrxsrupttmzxp}u~to«¡ŸèæâŸ¨ „†€Œ‚~ˆ}‡z†y‚ˆ~‚yƒ…z„†|ƒ†€€…€|ƒ}|„~w}vy|ww~uv~ss{qr{qy|s|ƒwytw~rv|qu€uvƒwp…ym†yn†zm…yk…ygƒyc|q`ugare`nbaob[ia\lcTg]M_VN^RP\RRZSV]SV_TN_RMcROaPTeXSh\Pj]Pi]K_RP]OR_TQ`UNbVNdWL_RL\ONVMLVNFRHGRHJSHLQFMQHMPGLNEINEENDGQGMQFJODIREHQDLREMRDNOHKPHISGKUHLUIMREKODJNDHKBHKBJNCGJ@NPHIRHP^S^j]}Š~_obViZTbTT]PS\ONYIQ_PW_V\e[`ladpfdnb^g[Y_UV_TR^PUaSPZLNTFPULNWMKXMQaVP`UP_TTWNLWLIXLLUKNSMNRLOTKQVMQYORVMVYOXZQW_R\fYnwoz~¿ÄÃûÿÿþþýùûûûÿþµ½¹]d^gjd^bY_cY^cXZ`U\cXZaT[]Y]c]OWPNXQ]jcVd^XcZVbYW`XV^WW]VY_WYdX\f\bjcjqjenc_m_]o^`occrjdunjyngm``h_aj`dh_kkbpoejnbhmdflccjahpfksipyop{os~tvƒyu‚zv„yz‰}y€}‘„€•‹„–Š™–š˜›™’ žšª©¤·¶ºÍÏÆÛÜÚèèüÿÿýýýüþþüþþÿþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþüþþýþþÿþþþþþýþþûþÿÿþþüÿûþÿúöê䯶ªµ­ž¯³¦Ÿ¦›”›‘•Šˆ‹”•ˆ  ‘Œ‹’’‡‹‚‡yƒ†}‡v€†x…{†~x„yÃÑÃòõéùûòýþò®©šÖÒÂòîÞú÷äÔÖÅlvgo~nmyico]ciZeiYjk[egVej[bjZboaal\ak[dobethctjfxigxjj{mlymq|pxuz…rŠ‹z€xkqlaeob_wfcxjfylizmm~qt…uo~mep`[cXYaV^h^aoc\m`Yo_`vfZm_VgZS_SNYNM]SM^TSg[Vh[VcWT\RTYLPWLPYNR[QQYMRWKOVGRSIVSINREM[LYnbatg_pcYfZ[dWU]PPZKRYLS[KS]LU^QU^SV^UU\P\cU‡~ª¯žmj\XOEUQGWVH`bOX_LT[N[cZYl_[k^\l^]j\[eW\cWVcY_uf`yd_pYT_KS]KYXLXXJZ^J\aL\bM[bM\]QYYMYXL][M``RfcUceZc]Stk_mbTpk[yxgŠˆŽŒ†’މ’б¿¼­¸·€‡‡|„„|ˆ…x†€x|{€}z}{tvuttsuvu|yuƒ}w†‡y…‡~ƒŒƒz‡}wv|‚w|u}~u|}wy|uxx|t~‚xyvwzuvxruystxsrzsnyqq{pt}tt}rq{qo|nuƒstvt†}n†}hyh€wjumsgzn`sg^qdXh_]ld_peZocSkaPd[MaXH]VO_XR]VQYPR]PQaRRhVThYVjZSfYNeWK_RM[PJZSM^UP`WM\QIXNFVLJVJJUIKSIGPFGOFJPJGPFIPEIODHNCHNGHQIHQDHPDKPEIODIPFGQFKQGJQGISFKVILWGJTCLMCLMDHKBHKBJKFJLELRFKTIZ`U}~u¤¬£eukP]XU^VQYNO[JNWKSWMUZNY]P`h_hsn[ca\_ZV^S_j^T`TSZOPXKLVJRXMR[OO\QPaUO`UM^SNZSNYPP[PQ[NOXMOYNMVJOUKRSMSPMQSNSZP\aVcj_pukwupõôòüÿÿÿÿÿÿþüÿÿÿ¢¤Ÿkrn_geW`XX^XZ[XY[VY^UY_U]c\LXS‘£ ƒ”‘Ye^Z`VU]VV]VV^WW_XV`V[dY[dY\dZ`g_bj`al_\i[\ob_pdcpgluonuobicemabi_af^fi`gi`jk`ii_dk`epfirikumkyrm~ss}x|ƒ|ƒ}Š„}ˆ}ˆ‘‰‚”ŒŠš“œ–ž˜ š”§£ ²±¬¿ÁÊÞã¼ÏÖïøöûÿþþþþþþþþþþýþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþüþýÿÿûñéààÓÇĺ«««ž£•œ£–œ“‹‚Œ‘‡”†Š‚‹ƒˆ‹‚‡‹Œ…‹’ƒˆ‰~ƒ…{€…}ˆ~ª´¨ãØÎåÖÉÓ´¦‹si™ˆ{³Ÿ‘ȸ¨™|ns{ljveiqadk^cj\cl]fo_gp_dp^eq^dp_bqajxkivkjwkhxmqs}‡ws~mp~qs„z|€s{}qx}nmvgfuceyfb}jlpqvpvqƒvruitg]l^Ym`_ti`uiXi`WoaZrf_rg`lbXdZOaSQbSObTRdWUeXUaWT\UXZST[QR\OR]OTYLTUJOWIPWJOUJNTIMXMWi\bl``l]VcSZhWYfVR`SS[NR\OV_SS\OU^PW`TObSVdU[eUfi\aaWTTKVWLUaTQbQZbS_dX[dYZdV^i^[i]Xh\XfZYgZ[o`h{kj{jkxhlvg[cUY]MZ\L]]N`aP]_OZ_N]YO\[NZ^OX`N^fUfm[lk\nm^nk[kjZjm\_gS ¯«Œœ˜‹›–˜§¡‚–“xІ|‹y„‚{€z{z…}{ƒ|v|xvzwstqsuryvs{u~yrxum}w|„}vzv~ux€uz~tx}uwztvzsy{r{}s{~sw}ru~sv{utystxrqvpqyrnwpqzpqzpu~uozpmxmo|or€tpvo…zjvm„xlupuhzm^qd\naXh^_le]ncVm`Qj`Pf]WldPi_Qd[Q_WQ\RR_SQcUQiXRhZVi[Th[PgYOdXO\QMYRMWPJULITIFQGJTJKWKLWLITJKSIIRIHPHFOEIPFIODJPEIOGHQHIPEIODMQFGMCIOFGPGHPGGQGHSHGTFJTGKSELNDLOEKMDHLCKNGINEJOFNWLY^Uab[pwpSbZN[UOYPPYMN\MNZMOWMMYMU`R^j`r€|”’nokswp}…}MUKSXNQVLLVJRXMR[OR_SO`SO`SN`SM^VN^UN_SP`UM\RJWNMWKMSIQRLRQLPSLT[Rdf]dg]pnd~tnÙÐÍÿÿÿìÞÞÀ´´½¶µruujy{›®¯š—KRNY`ZW]UYaY\e]^ebhtrºËÊk|{P]YS[WT^UV_XXaZYaZ[c\[cZ[eY^f\^f\ai_^j][i[\lb\h`dmfjqhotlgkbck`dk`ejccd`eg`gi`fh]cl`epfiqhmvno|upyvƒy†‡…•˜v‡‰“‘’‹ˆƒ’‹‹š“ž™’ ›•£ Ÿ®«©¸¶¶ÄÇÊØÝØæíøÿýúþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþüþýÿÿüñêåÌĽ·°¦ªªž«®¢Àĸ««¡’“‰”š–šŒ‘–ˆŠ’ƒ…‚‹|Œ’„”ˆŠ‰ƒƒz€†~‡†„Œ‡„ysgˆwlˆ{typi}ukql[}zl|€rm{nixkgseel`fmahpdlufhrceo`er`fucj{km}okznq~rsƒw‹}…Œ}z€qy‚w~Š€xvxmtynqzmo|mnooƒrw†xvƒwrsw…ytƒugwf]o^aufeykgylm}qm}m]sd]re]nbWdYTfXReWRfXUg[Vf[WaYV]VSYQSZORYMSYIPVHOUHP[NRZNRVKMRGMUIR\RXbVXdVUbRZgW[hZ[h\\eYXbTV_SV_RY`SY`TQcUWfWYbR[_P[ZMXVKOUIao`y„sssebcV\dXYcV]i[[k\\k]WdV]i[^m`mzkp|lhra`eXY_QZ]N\^N[\L]^NZ\LY\MYYNWZO\bTfn]pyeowcprall[oo_nn^gj[³ºª¼ËÄ—¦£‘¢ŸÃÓÑ©º·ªÀ½ª¿¼}‘Ž~‡…ƒy„|w‚zvyu|vsxrrtnttqxxsxxpxxpuyrt|uu|wu|vwuu}st|tr{stysrwnv|qu{przot|qs|uqyrpuorvpquoqwos}ruvr}uo}tlxnozpp~pqsqƒxksn‚toƒuorhzm`re`pc[j_^ja[k`Vl`LfZPh\VncVqgSh_TeZSbWTfYUh[Qk[Ul^Xj]Wj]OgYPcWO[QNWMOWNMVLMVLJUKKVLKTJJUKKVLKTJHRHGPEFNDGODHPEHPEKRJGPIMOFMQHLOFIOFJRHHQGHRKFRJDRGHSIGSGJRFKODMPFJOFLQHMTKJRHLOJMVNPVOSVPW]VP\TLYPMVKKVKM^PJ[OMXNL^PWeWq~t|‡…˜œœPMJ±±­…Š„NSLSUOPSKLTJQYNT_SSaUPaSN`RQ`RQb[Rb[RdZSdZK]SIYQLXMMUKLQHOQIOSJSYPZ\V]`Wie[zle°›–ÓÀ½‘ww…ss—™x‚…¡µºÙó÷cmqNYVZcYZdY[f\_idZa[—“æð’O[TU^VUcYUcXXc[^f_aib_e_\e[^f\^f\`h^`j``mafsnq|uai_`f\ag\di^^fZcj_dhb]a\ad_fgbdiaeoegshlsloxpp}tw„‚t…ˆŒ¤«íÿÿ³ÆÌr…І•€ŽŠ…“ŽŽœ—Ÿ›•£žšª©¦¶¶¬¼½ºÈÊÃÐÕëöøùþýüþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþÿþþýþþþÿýÿþüýüúùøööõîñòëÕØÎ¤¢™¢£™Ÿ¥šž¨šš£–•Ÿ’Œ–ˆˆ‘„—‹•™Ž‹‰……|†ŒƒŒ”ŠŽ”Šœ¤š°¯¤§¢˜•ˆ˜•‘‘…¡¥” £“}…xixlo€unyojpeiodhpehpejsgjtgftdgwhl}oqƒtost„w‰—‰—Ÿ‡Œ}~sy{qy}wwypqulx~sz‚wz†yv„xx‡yŽtst~qutm}peud]o_^sabwhqs†“…Š“dwe^wg_tfZj]Xi\RhZUi\Wh]Xf[W`ZW_WR\QT\QUXKTXIOUGOWJO[PRYORTIPNFMMFPRKUaTZgYXeWYhZXgY[j\\k][j[TbUTaST_RWdVUgZXgXXbRX[KXXHWWIGOBx€rêèÚíåÙsj^W\OUcU[kZ]m\_l\[eUW_QZdWiscr{ju{jcfXYZNW\L[\L\]M^_O_aQ[aPZ_UV^S^fYgrar{hr{ftwdoq^jl\hk[dgZ–šŽ”š•Œ—‘“ ·ÃÁ’šš¯¾»±ÈÂ…œ—|Œy‰†zˆ€z‡vƒ{p{spyqptnquqpvpqxoqvmryqsyst{vu|uu|ss{qoyooypqvosxns{ps{przor{pr{tqyrpuonrlosmrwpv~st~up|vnztlxrlwoq}prtr„wp„wn‚tl€qjzlfwiasfcuh]m`]j^Yj_Uk_Pk]Qi]Tk^UobUl_Vh\Uf[Wi\Xm_Un`Tk_Wi^Wj^Rh\NaUN[NLWMMYOKYNKXOJYNIXLJSIKTJKYNJXMFQGFOEIPGHQFIQFIRFKRJIOIKMDLQHLSJPXNMUKKUKLXPFTLHUMJUKKSJJOFLOFLQGKQFJSGNXLLWJMRLKTLKTMQUOSWPOYQMXNNWLNZNN_SL_RPZRS_TYdW‡› Ÿ¸¹¹‡~}ec_mok`d^TTNNPKQWPW`VR\RR`TPaTTbUVdWVaXWc[Vb\Ub\Q_XO^VMZOKUKMVLOUKQVMQVMSZSV]RadYph]rk}og†{x–“—Œ˜œÒâææøût}GPM[eZ_j]Zg\]jbei_[_Whlc`f\U^SYbUWg\\j_`kaaledkd]d^^g]]e[_g]ai_cmcbndq€|cpi^i^_i]^h\]f\]fYdlabg`^b^ae`cgbekceoegsjnvopyrsyy…‡¢§Öíó¸ÒݵËÓ©»Á…ƒ‘ˆ—“ŽœšŽ›–§¤¡µ·£¸¹©¿À¾ÑÓÎÝÞïúüüþþüþþüþþþþþþþþÿþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþÿþþýþþüþþÿþþþýýùüûüûóÿÿüäãÚ±¯¥¯¯¥£¬žŸ©¤­¡¤¬£ ©Ÿ˜ ˜’š”˜›’‡‘†‘™Ž™£—’‰™›’«¬ŸÎȺÖ˹±¦»º­¶º§¿¾± ¢˜q{qt€uqyplrfjpdjqfjrgltijrhiwikzmq‚tu†zs„ww†y~Šz‰z€„u||qttkkmfnqgptkszqx€vu~t{ƒyz‰{r„uqƒt{„wz†xlpfwfatcbwfbufkzlt~qvygctba|k]vh^re^pcXm`Xk^Yh]WeZWaWT]SR_SW`TTZKVZKV]OT^QQ\RRZNUVLSSINNFQTPZfX`l_YeZXfZYh[VfXYl__se[obZnaZoaXl_]pc^n`_iYTZIVWIVVHVWKbaS£˜Š¶¢•gZMTUJQ_R\k\`p^esafqc`gZYcVV_NZ`OTZI\]N[\PW\MV[MX\MY\MY^OY_QYaWaj_`i\fm^ltbnwdtxelq_hm]ej[lpenrfƒŠ…•ˆ“„ŠŽ””ˆ•’‰›•‹¡œƒ™–x‹†w‡€s‚{pwr{ttxppwtpxspzsr|sqxqsxspxqu|srxmnvjpxlnwknskowmq{or~qq{orzopyru|utxrptnquoowoqznp{qn|utƒlyvq{wu„wt„wn~tk~ri~pg}ngziduhbuhhxnare]k^Yk`XnbTmaTi\Ui\Uj]Wl_SfYXj][laZpcZqeWodUi_Sg[PfZN`TMYMKYKLYNL[OK\QM^RIZOLRJLVMKZOFVKFTHJTHLPHHOEHRFISGIPHKNIKNHINHJTKKWMLXMJVLKYNJXMFSIKUKMRHHJAMPGMQGHOEKTHMYMKWJIOHHPHIQIKOFMRGLUJKXKMWKKZNM]SM]SU]UXaW_g[]d]v~| ¡YRQWUQ[]WfidPRKJOF[eZYb\O\TR_VR`TR_SVaUZbVU^TWaZUaZP`XO`VM[SLXMMYLOWLRYMSXOTYOS\QZbTdcXje[uqgwwr…‚¼ÄÃŒ••º¿Â¯²³ipmV\W]cZai]]f[WcYY^T_cXY[Q\aT\eXZfXXf[^laalbdoggpj_gb_g^_g]ai_hpgisl]ha‡”Žcof\h[[eX\fYXbW]eZ^f[_f_^e_af_bh`ekddnfislltmnyqs…|z‰Š¢µ¹åøûõÿÿÄÖÚ{ŠŒ†”ˆ—“Š™—’¤¢Ÿ°¯¸ËË£·½³É̾ÓÕÃ×ÙÚèêñúûÿþþþþþüþþüþþþþþÿþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþÿþþüÿþûþþþþþþþÿúþþýúöýýøÿÿûÒÎħ§œØÝÒàâÛ·¹°£¥Ÿ¦ž§¡¢¯¨”š“™œ”™Ÿ”œŠ“ˆ—š’–•Šœ¯«•‰€ˆ~“–…œœŒ‘‚‚x|‚xutqynsznmshluhmujmtjmvlmymt€u{‰}…”ˆ„„‘…ƒ~|„w€…y}vx|qsymnrgmtiqzo’œ‘™¢˜‹’ˆ›Ž†›‹´Ã³Ãȸ‚sy…xkxlarebtfaugjxkt~qs{ml}ogrczm`wj_wiYl^Wj[Zi[VcVXfYVdWR`SUbTT`QUaQWbT[eXU]SRXMQTGSVIRVMX^X^j]anb\j^]k_aoc\m`Ug[^re^sf_vh`ykd}ocxk`qdXeVS[MVYMTVKXSGWUFTKHMBJQEMREJNBNPFIJDIMDJOFJOFLQHMQIIOFHQGHQGJTHKSHIPENUHQWLQVKPTHSWKU^NOXJTSJRVJOQHQQENUHN^NPWMNSHNRGNRGOTIMTIOVLSXOXYR`_Y’“ŽjkgUYPSWNQTKQUKQVMOWMSYNPYNPWORZRPWMU[PX\QW]SW_Ugoh™¢œ«µ°ZfaYaYfncluipvkppgwmh‘ŒŠ†ŠŠv…Œltnnunmtmvx­¹²¸¿¹vto½­®¾°±ÝÐÒÐÍÍ••–£¨¨hmghmffk`bhbbhaflinvt‰gsmovox}v‹•‹³Á¼ž˜y‡ƒ~‰†„Œž¦¥”››–Ÿ¤¤’——–”Ž˜’˜•’›˜—¢Ÿžª¨¤±°ª¸··ÁÄÃÏÑÒàâãïïöûýýüþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþüþÿýþÿÿÿþùòîòéßõëâþüüþþýüþþÿÿþýþü÷õ󳮦Âû¸À·»Å¾ÌÕÏýÿÿþýýþýýþûýþüþýþÿûþÿÿÿüýÿýþþýøòðàÓ˺©›­©œ¢Ÿ–ÐÏÌÿÿÿýýüÿÿüúõîæÛÒ×ÏÄ´¯¢ƒ„z²¹®ðóê­±¥¢¨›u{nzƒwÇÎÆÒÐâ§›•ž‘†‹€{…zo‚ujrh~pfzmbwhe{li~njzmhzkk~oj|ogylj|pg|mk~on€rw†xusltghqhhsh|Š~¡ªŠ”ƒ~„t‡{Œ„‘„ƒƒwƒ„y•šŽÚÙÊÅ¿±‡z†ˆyƒˆy…ˆ|››Ž™™hi]lpafl\dl[biZfl]diZcgYelZktcowfpwemqejobhrbiudl|giyhcq_kpbfl]irboqv…wy†x~Š”‡‘œŽ¥®œèêÝø÷ëáÚÍÔÊ»¿²¤©½¿íÿÿéüúíþüÿýþþüþôüýêþÿâüüµÍÏôþÿõÿýêúúäÿÿÈæíŽ©³²ÒÑ¥Åȇ¦«Ž¨­““|‹ˆ|‡…u„v„vƒ}s~xs}wz‚~ƒ‹ˆŒ–”Š–•¢¯²ìûûæÿÿÌôõ·º”­¯˜©©”©¥ÀØÕêúúôÿÿöüýüÿýþÿþþüþýÿÿØë馢ƒ™’y‰nxgvo^ld_i_^g][cX]dXcnc^jc]d^ZdXYeWW_URZOOWLKRGJRGJSHNYKQ_SQaXN]VP\TT_SUd\SaWR_SMZNT_SW`VQaWR]VOUPLRLGOFFQEIPGJPGJQGKSIKTJJSIORHKODINDEJ@FKCHKEGMCLQGGMAFJ>HK@HJAFLAHNCLOCJPDGNDELEGLBJNFJOFJMEKMGMOJKRHMTKMWKLVJKTILTGMTHNTGOSGTXMTZNOVJQVKSXMPPGRQGOTJMZNOVLMSIMRHNRHLTJQZOQ[OQWLVVKURIIF=QPHOTKPTKRUKQVKOVKQZNR[NRZOQXQRYQSZOU\NT\PY_U^eZkqk¨­¨üþý“’SVQfkbfqeisgtxn€}u}{—žŸ¾ÐÑl|{eljmtlkni}€y×Þ×~†~x|v’ˆ„—‹‰À¶´“‹¢¡Ÿ„…ƒjqmjrlckcdhbdgbkmjtzt†‹owqntnuztt~us~y{‰ƒz‰„|‹†…“…’™š¢®­– ž˜”™”œ–‘Ÿ˜•¢Ÿ™¦£ ­¬§¶µ¯À¾¿ÐÐÓáàåïïóúúúýýýýþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþûþÿþþþÿþþóïêÙÑÈâÙÍþüúþþþþýÿýýþÿýýÿÿþûùöããàçìèéîëøüúûþûüýýýýÿþÿÿýýÿýýÿýþþÿþýýþýÿÿþæÝÚÕÊÃÝÖÌìéàÿÿÿÿÿÿýþþýþþþÿýóðêßÙÑæÚÑÄ»®‚—ˆ–‘ÔÖËÞßÒŠŠ{‘“‰‡~}{m­°¢ýýõĽµklao„to‚vnto‚up„uwŠ|p…vmpl€pmrh{newiiyll}oo€rr‚ts‚ttsq}onxno~q{‹™¦˜Š‘ƒ¡£–¿¾³ÃÁ¶ÞÞÒÑÒÆ‘‘†prf¥Ÿ”ÝÕȰªœˆŠ{•‹˜‹‹‰zqpbssgnocim^dkZhm^il]gj[nq`rvfqvfotaorcopdnncmsejtdkvekzhkwfmsbln]lr`jwfu‚pŽ}‹—‡¨—¯º©­²¤©«ŸÒÏÆÿÿÿÿÿÿÿÿúÙæèñýýôýý÷üûúþýýþÿöûüíüýçüþÒæéæò÷æù÷åýûÔêïÏæïµÐÙåÿÿÍòó¶ßã¶ØÜ„šƒ|†„v…uƒ€v…~v‚|vy~‚‚‚‰ˆ‹•”†’’ÄÎÎ÷ÿÿøüýèþÿœ¿Á–°³—¨«­ÂÂòÿü÷þýþþþÿýþþÿþùýû÷ûýÕà⬾¼Š œ•ŽwŠ€r„}iyresj`j`_g\`eZ^fX\h]cqh[b[[eWYdTW_TS[POXMIRGISGKUIKZKQaTVg_[leUf\P^ROXQMULPZNS]QS\QQZPM_TQ]TOVOLRIFODGSEHQGGOFLTKNVKOULNSJQNEKJAJKCHIDEIDFLFHJDHLCHL@EJ>DJ@EJAHNCIODHOBGPCIQFCNFIODINDHMDJMDLNHOPJNRINULLUIITHISGKSGITFHQCMPFPTIRTLMRIPXMOVJMMCOMEOPIJUKNTKKOFMRIOTKQYOS\RR[MSYKSUGRUFRYLNXKQWMOSKOTJOUKNXLOYLR]NR[PSZSU[TV[QX_PV_SY`V`e\rtn¥¤¡”’‘qlm_[Y`e\al`bobisgnzmt}xÔãäÏçê™®±cklmqlsoiuoj©¨¢ˆŒ†wzt}y†‚‰…€ŽŒ‡Œ†ˆŒ†š–muqbkdegagicmlfjmgksliqkmsktztv{x„~}‹„}‰€‘†—’…“‘¤¡­ª‘Ÿ›Žœ•–¡š•¢™¨¤­«¦·´®¿¾·ÈÉÞòïóÿÿøþýýýýþþýþÿüþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþÿþýÿþýþþþýýýüýûüþùÿÿýÿþýýüþýüþþþþÿýýÿþþÿÿÿüÿÿüÿÿýþþþýüýÿüüÿýüþþüþþÿÿýÿÿüþýÿùþÿüýüÿÿýÿÿþûÿþýýøüûùýþÿüþÿýþÿþÿýýþûÿÿúûïæžƒ‹‹}…~‹“†ÑÓÅùù쪦–‘„…„{Š~|‚t•‘ˆ‹}u€wk„su‡zs…xs…xtˆyx‹|q…vm€qpƒun„th{ohxljvkiykhwio~opqn}oo~ppstƒxvˆ{Œ€|ƒv‚ƒw…}r{xmœœ¦ªž±³¥©§œzujƒzn…}oŽ€¥®šËÓ½ÕÒÁŒ}qodppemodko`ml^kj\mk\vrcvuevveqvcppaqncrqfotfkuedqcjyip~lt{ipt`lu`nye{…q‡’’‰¨´¡ÆÒ¿êñèùû÷øù÷ÿýýýþþøþüéóò÷ýüýþýÿÿþÿÿÿßìíÜðòïûþöüýöþÿîüùòùùõþýêüüßñòôÿÿôþþãóöÐíöÛúû… ¥}Ž{‡†z„‚y€|{zyz|‚}uƒ††Ž’“›šÆÏÎýþþöÿý¾ØÙœÀÄ¥¾ÄÆÑ×ûÿÿÿýýÿþþÿþþÿþþþþþýýýóúû§ÆÆ™°­ˆ£ |”u‡„nƒ|mwcti]ma\h\\f\_g]hrf|‡{iti[i\XfXW_RT[MSXMNUJNTIQVMS\PUbY^pkj~z`spRd_LYPKVJOXIRYKT[OSZPN[OS_SPZNKTJGOEKQGIPIKOIPVPOXQLYRMVPKOJBNHDKGKJGJIECKEIMDHKBHKAFJ?FK@GLAGRCHREFPDFNCIPGJMHMKBKMDJOFFNBIODLSHKUJLVJLUKHPGGNFKQHKQEGNAKQFMTILRHOTKOWMPSJOMFQNFPPESWLPSJRPGROHPTIR[OT^RQ]NPYIPVGUVKOWJMWKPUJQYMNXJR[NQZOQZPT[QT\SS\RT^SS]QU^SY`SYbV`e[utn¬§¤°¬©bhcYbY_i^_k^fqfjrkpzt€ˆ‰äõöÒîñ©ÅË~–`hcjrmoqlfd^tulq{qu{v}„{…‹‚…ˆ…‘‰—š…”–ovvfifdkfdkfejgisjmunipiluno{sp~vz„{‰ƒ‡€Š˜¥¢§°¯œ©§–¢ ‘ž›™œš˜¦¤¥±¯ ¬¬ª··³À¸ÉËÆÚÚþÿÿúýüþþþþþþÿþþÿþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþýýþýþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþýýýüýüþýþÿÿÿþþþþþþþþþýþÿüþÿþþþÿþþþþþþÿýýüüÿýýÿþÿýþÿùýþþÿûûüûÿöï»›‘Ÿ‹~Œ‰}‡v‡ŽŠ‘‚†ˆyŽ€ŒŒ~…€ˆ‘†ˆ”‡~t‹€‚†}r†|xŒr†}qyt„{w‡{rƒvnqn‚snƒto„um€rl}okxlguim{oo~ql{mo~pn„rs‡wu„xy…y}‡{„Žƒ‘–Œš£™ÓÝÔüÿýÿÿÿÿÿÿëñéõòäùïÜ‘Š{³­Ÿ©ŸŽˆ‚u…y|wiln_lpampalqaopaonaqpdsteruemselsdlsdnvgr}mr}ln{nr~ls~lp{kr~nr‚kuly†s„’Žœ• ‘ÄÐÀýþúûüûýüýÿþÿÿþÿüú÷ÓÞÞùþÿðôöæéëíñô¿ÎÑÕéìîùûûýþýþýùÿýþÿþýþþöýýùÿÿúûýðùù§¸½Åßèáûý‘¨®~x…ƒw~xzv}xv|ww~zv€ƒ‡‡Ž“•š£¤ÜäãþÿÿöþýÚòó¿Ä¯ÅË÷ÿÿ÷ýýÿþþþþþþþþþþþþþþüþþòþþ¸ÛÚž¶´‡§¤}™“t‹‡mzh}tdujare]i]`k`goehrfeqeerf`ocYi[W`SQXMNUJNTINUJOWMUZPXbYcqit†n~vYh_O^RLWJLVFMUGNVKMVMNXLR]PQZNJRHHMDJOFDQCIUIMVLMWOT\VW]YWWOKPHIMENNFJNCGQEGNDHMDFJAFJ?HLALNDIQDGPCGQEGNDJNEGJCJG?ILCGLCGMBKQFLQFJSHLUJJRHHPFIQHJRIMSGHNBJOCMRGPUIQVKQYMPSJSQIOMEMNEOTHOSKRQISPIQVKPYMU_SS`RPZJRVJSXLQYLPXMQXMSZOS\OQZMS\QR[QT]SU_US`VT`TV_SW`U[^TV^S[`Wpnf~zt~vcgc_d]_h\aj^cncgrhr{s€†„ðøùÝíñµÇËr€„gjfksmpzsrxrqyskxru|w}……‘‹Œ›—”§ªÅÚݤ´¶isqgmignhemfhlghphiqjkskmunozsqwuƒ~|Œˆ‡˜”‰›˜™§¤—£ —¤¢™¦¤—¥£žœ’ŸÂÐά¹¹£³²°À¿¸ÉÉÆÔÕßìíüþþýýýÿÿÿþþþþþþÿþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþýýýþþþþþþþþþþþþüüüýüýýþýþþþþþþþþþþþþýþÿýþþþþþþþþþþþþþþýýþôïëæßÚÿÿÿýýüýüùûùõ̺°®’…¢†ˆ~‡ƒu~‡{ˆ“†’šŠŒ‡{y‡z‰‘ƒŽ™ˆž¦•‘…Š}|ˆ}zŒxŠp‚yo‚ys†zr…xp‚um€sn‚uq†ypƒwk}phxkiwkjwlk{ln}oprp„ss†xstv€wwƒv~Š|”š‘™ÊÏÅøùòÿÿÿþùôæÛÒõëݶ¥š‹”–‡}‹Œ}ˆ†xqovgkuenvgjtbmsforgnqeqvhqwhmtenufnwhozjq}msnkwkitbhq`jsdjscr|hwl{†r„œ§—°¹©ÈѾÿÿÿýýúþýÿÿýÿýþþýÿþ¶ÂÃÐÛݽÇË´¾Â¬¸¾°ÂÈÆÕØáëîÿÿÿÿþýÿÿþÿþýÿþýÿþþÿþþþþþäï𢳷³ËѰÇ͉œ ~ŒŒx…‚v€|w‚{v}xv~zv|}ƒ‚†ŒŒ—š¡ª­òùøÿÿÿ÷üüêÿÿŸ¾ÂÉÞâÿÿÿùþýýþþýþþþþþþþþþþþýþÿôþÿ´ÕÔ²²Œ¨¤›—uˆl„|dzravjctgaqdkvljukmynkyncqe_pcXi\XcWR\QPZNLUKNWMPYOUYOV^TT^SWcX\g[YeYUbUOYKLXGLTHKSIJPKNVKQYNLTIIOFGLCIOEESFIYNUe]ftqlyyFUUBJEJRKJPFKODHOBJSFJRHGNDGLCHLAILAMMDJOBJODBJ?EK@GKBGJAJKBIKBFLCFLAIPDLQFMQFLQGJOGFOEKSJLUKLPGKNDLPEQUJSWKTXLPWJTVLUULOPIPTKRVMOUKRSJQOGNSHQZOT]RR[NQYLRVJSWKPXKOYLPXMR[OU^QQ[NT]RT]STaVTcXVdYUbVYaVV_S[]WW_TZ^VbbXfdZjkaad^af]af]aj_epdcpdpxmvxrœ™™°³´ëóôv‚ƒlsnkxu\nhs€|jspqyv{€}€ˆ…™–“¤¦¶ÌÐÛòø‚——huthpmgniiqjimgjoikoilslouorzsswtƒ}~‘Œ‡œ™…š—Ž›ž«©ž«©›¨¦“¡Ÿ‘Ÿ¢°®ÀÎ̦¶µª½»´ÉÈÃÕÓèóòøýþýþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþýýýýýýþþþþþþþþþýýýþþþþþþþþþþþþþþþþþþÿþýÿþýþþþþþþþþþþþþÿÿÿøóí¸¤˜íÞ×ÿûøÿÿýþÿùùûñþþõµ³¥€„y~€q~…z~ˆ}„‚~†|{…z|Š€ˆ{„‚‡”…‡‘ƒƒŒ}…xy„yy„zuƒxt‚xu‡{u‡xt†y|ŽxŠ}v‰|r…xotk}pl|pjyll{mo}pnopr|ŒŒy„zv‚v}‰{|‚xÉÍÄìîäÏȽɹ¯º¢™’wmž~£ Ž¢§›’˜‹‹ƒt€sˆŠ|}†vs~nr}mq{nq{nnvknvkovjpxkoufpxilxhnzjp}mw„u~‰}v€mqvfptfuyiy€l‚‡tƒ‰x‹”ƒž¦•ØßÍáåÔùøïÿÿúþþþüþÿûÿÿúÿþ§µ¶£®³¤³¶¶ÄÊ¿ÕÙ·ÈͳÀÄÉÔÖþÿÿÿþüþþýýþýþþüÿýýüýýùþþáðò¥·»§»À±´†–˜Œx†ƒvƒ~w{v€zv}v~€‰†„‘‘”Ÿ£«³·ùûüþÿýúþýèýþÏîò¹ÐÖÛæèéïîûÿþýþþÿýýÿþþûýýûþýöÿÿ·ÔÓš§©“§¥†œ—{‘Œm…}j€xi}rhzmm|pv„yr‚xm|ql|qeviare[naTcWR`TQ_SR]SR^TT]SVYSV[RU]RYbW^fY\eXYcUT_OOYLMVKKRJJRJNVJQZOMUJKPGLQHKPGNVOL]WyŒyŒ\ty“¶ºv‘’M_^NWSLSJKPGJMEHLCINEFKBFJ?IMBKMBLMCIMBGLADJ?EI?HI@JKAHMBGNBGLCHLCKNEMPGMPFIODKPEMSHMTILPGMQGPTISWLSWKTXMSWKTXLTWNPTMQWMS[QPZPSULQPHPVJNVKRXMQYNQXMQWLPWJRZMQZMRZOU]QV`SU_RS]RR\RS_UWeZVdYZh[[cXW`UZ]VW_WY`V`aW`bW^bV_g]bh_diaemahrgdrcpwmuxpwtqwsq~€€frpasqg~{ÁØÖ„’hnnx{zy~~††ƒ‘“¢¥Þíññÿÿ†™~Љgnkiqkhohjogimhlrlkslmunoxqwxv‡€‚“¤·¶ê÷÷x‡…•£Ÿ©¶´ ­ª—¤¢•£¡¡®¬°¾¼«½¼¸ÌÊÇØØåóòùÿÿüüüþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþÿþýÿþýÿþýþþþþþþýýüõíêÁ© Â§›º ˜½«¦óéäð×Ò×´§Ç¬ Â·®»µ¬”Š}}t}‚w}†{†‰€†Šž¤¬¶¬‘œ’„|„}‹{ƒx~„v…Š~†‹‚€‡}‚‹‘„‚”†“…|€t†yt†yn‚uqƒtpqrrpnmnnr|Œ€‚Ž„~‡}z…y|ˆ{‰“†Ž“†·¸©ãÚÍÿúîÿÿùµ£™²¯ ÒÛÌõûõòôïðñêèèÚØÓLj{…ˆyzrz€qv€ss}pr|poymv~q{„vw{lowho{kjzik{jy‡v–Šš£‘Œ’{}oz}o‚†r‰Œ|’˜‡¤“˜›ŒÃŸõóêþÿùýþþüþþýþýýüûž®°§¶¹ª¼¼ÇÛÜÐèé³ÅƵÀļÉËïùùûþýþÿþûÿþûýþþýýúýþòÿÿÓç阬¯™«­‘¡¢ƒ’’zˆ†v„€vƒ}r}xw‚|vƒx†„‚Œ‰«¾Ã¬´ºÿÿÿþÿýþþþëüý¼ÚÞªÃËÊ×ÞÙåèÿÿÿýþþÿþþþþþùýüùÿÿÞèì¹»•¡¤’¤£‰Ÿ›wˆo†~k‚zi€tkqqƒvyŠ~vˆ€o€uj{pevk`qf]nbWj]TeZWg\VeZUbWS`WT\TS\PV`TZcV\eZ\dYXaTS]PNYLOZNOXLMTJOVKOWLPYMKTJMVLNVNRVTbrr¥º¿ ¨¢¸¾Òôõe‚ŠEW[S]ZKVNHQIILFILCJMDGJAGLAINCGMBLLBKLBHL@EJ?GK@HI?JMBJODGMBINEIMDLNEKNELOEKODLPEKQEMRFMPEORFORHQTISVKUWLUXMVYPW\RSZPV]ST_RT_UUZQRRILRGLTIQWLQWMSYNQWLQXMR[OT]PR[PWaTU_RU_RR]RR\RT^TXcYYe[ZfZ[eYZcXZbXVbVV`TZaV^dX`j]]j^`j`dkafndhsfeufishfripunxxtrusq~}ƒ™šÂר£µµjwxqyymwu_mp›¨«šª­€”¶ÃÈÒÜà”¥§‡hnklsmhpfjoelqllsljtllwoo|svxw…€âï𨶷r}|£«¨ž«¨” Ÿ–£¢š¨§¥³±¬»¹µÊÈÕææêôóúÿþýþýþþýÿþþþþþþþþþþþþþþüþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþýþÿýþþÿþýþýüÿÿýÿÿûþýøË¸¯¬•бŸ–³§ŸÊ¿µÚŽÙÅ·¶§™µ²§ÙØÍ§¢’€s|‚vˆ‘†’•Œ””Œ ŸšËÒÉ´¸±Š’‹„”‹†•Š{ƒy‚†w‡Š}„‰~…‹€Š’†‡‚Žƒ‡”‰……|‡}{ˆ~zˆ}sŠ{t‡xs‚urnops…tu‡zx†|{†}{„z}…{„€–ˆšŸ‘Ÿ¡’¼¹¬ÑÍÀæáÕ·®¤È˾ÿÿÿùýûÿþþÿÿûüù𾲦¡–Љ‡y†Š{‚ˆy}…u|„w|†yu}qxr†v€€qpwhnyjo~mqot€p|ƒx|ƒr~ƒr}€q€„u„‹xƒ‰y“›‹¥®¸¿²Üá×ñõîÿÿýþþüûýýÿþýÿüøÿÿþŸ²³£´³¨»º­ÄÁ¡¼º¨·¹·ÂżÍÏ÷ÿÿñøøüøùüþÿûþþþüþøûþÂÓÔž·¹”ª«‰œ›‡–•|Šˆv…„w…x…~tzv‚|vƒ{Šˆ|މ²ËÊÖíó²»Ãø÷ûÿÿÿÿþþêûýÂàæÃÛåÂÓÝÂÐ×ÿÿÿþýýÿÿÿýýü÷ýüÛçåºÉÏ‹«­–¤¦‰žœ€™”u’‰pŠi€xh~ri|ppuu…zo‚yj}th|pcwk^pe^pcXl_Yk`\lb\lbVd[TaYT_VV`UU_RXaU]f\ZbZX^SQYNP[OU`TU^RQ[MR[PR]PNXLMVMOXNPYPMRR€‘•¨­irx¸ÂÅöÿÿ¯ÄËYbe]a_OYOGUIFPDLLCIJ@HKCHNCHQFENCOMCLJAIMBEI>HK@GG>GKAHMBHNCHMDIMDJLBHLDJNDKODKODMOCLNBORFQSGQRGRTITUKUWMWXOX[QW]UT]SU`SXdVR`VRXORTKPVKNUJNUJUXORXORYORZOU]RV_RT^RU^RU_RV`ST`UT]TT[QV_UXaW]g[\fZ^g[^h\Yg[XeY[eY[dX_k_^pa`maakafndgsefvfgrhbshcqhkokpvtyˆ„™¥®ÆÔÛ§´·eor|ŒŠ…ž›ÅÝÝãùùâøøÖææ¦´µÄË΢°´€‡‰lpnltmgqgjrhpunowplwoo}uo|tt€x}‰ƒ‰–“ðøù¶ÁÄ|ƒƒ›Ÿª§™¦¤ž­«©·´³Á¿¦µ³Íäâê÷÷úþþÿþþþÿþþÿýÿþþÿþþþþþþþþüþþüþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþüþÿüþÿÿþýÿþûóðìõðêÿüóÏÀµ±¥œ¥ž—¥£™´²¢¶±¥´¥™£”†³ª æÜЫ›‹“„“ž‘ž‘˜Ÿ”‚…{“‰Ÿ“¨£š£¡˜€Š›…Šz‰’…z…wyƒwr|pyƒuw‚x‹•Œ¤›‰’ˆ~ˆ~}‰~tŽ~{Žw‡wr€ppqw‰y€’‡ƒ’ˆ~ˆ€}…|€‡}‡|‚Œ|‡Žž¤–µº«âä×õõëàÔ̸¹¯øû÷ýûýÿýÿúýûû÷ì´©¯¤—œšŒ”„ƒŒ}ˆŒ|…‹{‡z…x|q€q€~px}ouow„twƒsx„sytv|lv|k~‚t•†—¢œ¤•Ÿ©™»Å¶ÛäÙ÷ýøúþýüþÿüþÿýÿÿÿþüïéàÐĸ—®°š¶·¥¿Á¡µ¸¤»À¯ÂÉ­¾ÄµÃÃÄÐÏ»ÄÆÔØÛöÿÿñýüòýÿÊÙß´ÌÑ®ÈÍ™´µƒ›œ€”’{ŠzŒ†{‰v†‚v†‚v„z„‚‰……‘޽ÏÐêÿÿÅßåÐÜßÿþÿþþÿóýýáøöÝúúÑëî´ÆÎþÿûþÿþüýÿúþÿÉÓÕµÁç·¸ ³µ‰¡¡|ž›}—z•Œs‡nˆ€h€wf|rh{rk~ug|uf{rfwocti_sfZob]na\n`apcbnb[fZWaUV`SZbXU_US]UW_VX`VXcTV`TZcX]e[_eZY_TY_TT]RNZNMYMOXLTYNTWOˆˆ­²°{||snnƒ}zZ^ZNQNKQLIOJIPHEMFMJEKIEHIEHLFILFKOFOKDNMCKJ@IK?HJ?GK?JKAJLBHMDIODIOCKPBJNCJNCINCNMCNNDOOELTERUJUTKTRJTWLOXKXVMYVRYYTX[TW`VXfXX`TQYNQXLQWLPTIQTIRTPQZPR^QT^PO[PO]WU^TY_U\aWWbV[eYX^SS[QX]TZ_V\eZ_i_^ja^laZi^Yi_Zh^_ja_ka`nf^me_mcbpddsggvietoermfnhhmklon†‰ŠÐÔÛÄÉÎt{‹zŠ‘©¿Æàõõòúúÿÿÿ„‘”juy†††˜  z€szxhojfofjrhmsinvlr{pq|rqsr€x‡‚ƒ‹‡–‘„ˆ“›Ž›™žš¦®­±·¹¶ÅɱÄÅÉØ×þÿÿ÷ýûýþþÿþþÿýýÿÿÿþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþÿþþÿýüû÷ôÚÓ;µ¬ØÌÀ̳³°¥¦¥›£¡–¢¡–ž”“‘‰®¬¡ÁÀ±¶³ ”†µ´®£°©µÀ¹ÇÎÅËÍÃÞÕÈ—’†ˆ‰~…€Š}…Žƒ‹’„‚Œ€z‡{u„yw…|sz’¡‘¡²¤¦²¦”š‚†~}ˆ~ƒ“†~ƒv†yx†zˆ}Š—ŒŽ—‹‡ƒ†ƒ…ƒˆ”ƒ“›“™ —˜ ”¥°¤áëâûÿøýüúçéäøøöþÿýþÿþþþþÿÿüÝÕÎÆ¹­¾¸©¬«Ÿ’ˆ‚‰|ˆŽ‚‰Œ€†‡{€ƒv~„u{…yz‡{w‡y{‹~z‡x‰y~Šy|†vwq{€r†w˜œ‰ª­ŸÔØÆíòäÿÿýüýüÿþþüÿÿûÿþúþüýûöÿÿùÞ˼¬ÆÆÍëê©ÆÆ¹ÎÏÏêí¸ÓÚªÄÉ©½¾ªº»²¿Ã×ãåóÿþðûúðþÿÝðô®ËϱÉÊ£¹ºƒ˜˜”’|Ž‹Œ…›–ŠšzŒ‰x†„{‡…„’ššž­±ÉàåÜñô¿ÉÐòñóþýþûþþ÷ÿþóþÿóÿÿÌÙàäìëöüýëðò»ÃÅ«¶¸¥´³Ÿ­¬­À¿¡·¶Š¦£Š¦¡ƒ–x“‹rŒƒk‚xjvi|rg{qfse|rbwjcwjbvh^td^ob]naaoc^l`]j^ZeYXdVXcXUcWS`VU`VZcXZdU_h]_g\[dYZcXYbWY`UU^RM[OLYMOZNOWMZ^RV[QYaXeib^^WPLEXXSRTPJNFLOHINGGMCIKCIJCJKFKLGKOEKPDLLDLKBJKBIJ@JJ?II>HK?GK@GMDLSHMUINTEMPELNDKMCLOELODKMCLUGRVJVUKSSITXMRZLUXNTWMWYQZ_VXaVYdWY`VR[PW\RRXMSVKPUJTWLPYOR[RR[RP[RQ`XXcX\cZYaWWdYVcWXcWW_WY`X\bZ^e^`ka\j_^mb\mb^nc\ma^mabmbdreeshdrgbqfctheuidukdrhdndfmdlpjsvqnlmŽmrp–›„‹‹æêìûÿÿüÿÿüÿÿ¼ÍЮ½ÀŽ’“€‰ˆ‘™˜sywjqlgogkrirvmnulqzqt}tr}vsx{†~ƒŽˆ†Šœ˜Ž›š²¿¿­¿¾¨¶¶ª¹ºÀÔÔÆ××òûûùýüüþþÿÿÿÿÿÿÿþþýýýþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþÿþþþþýþÿþýýÿÿýÿÿÿûþ÷îêßÒÈ»ØÏÆ­§š•‡˜”†›šŽ¢¢—»»®ÿÿûÿþïž•Š|}sØÞÓÿÿÿÿÿÿÌ»°·°¢¡œ™™Šƒ‰}yv}…y|†z|‡zwƒx{„{{„{€ˆ˜‹ž©ÐÖÊ—œ‚Œˆ”‰Š™‰™Œ…•ˆ‚€~Š~ޙГ‘Š•Šžœ¨œ²º­–›Ž¹¿±áäÙÿýöýþûÿÿþþÿýþÿýþþþþþþÿÿýöðì°¥›Ÿ™›šš˜Ž’ƒŽ“„Œ†Š~‚‰|~‡{€Š}}‹{{}~Œ|€‰x~‡w†v|ux|o„†wœŸ°¯¢¥¦•äçØþþúýýüþÿýþýþþþþþÿûýùòêÚÎìÙÊæùùçþÿÛññíüûçüþÄãê®ÎÔ¦¼¿«¹»¬ºÀÉØÚùÿÿöüýñýÿàõø¦ÄÈ ´´ŒŸ„—”ƒ“’‚“‘Šš˜«Ã®ÇÃw‹ˆ}Šzˆ†‰““– ¡¬½ÁÍâèâóù¬·¿ÖÜàþÿÿÿþýÿþýýüýöýþìøúÄÑÓ¼ÉË­¹»Ÿ«­ ¯®™©©™ª§Ž££­ÅÅ¡º»›¶¶¨¦}˜{”Šm‚yk}ukumƒwkƒwk‚th{nhymhykgwictgctgevifviesg_la\k\[k]UeYVf[Wf[UcVWaQ]fZ]h\U`VWdXVdXW_SS]RR`TL]PN]QP]RY]RY_Tck`gnd\aV\\SUVMNOFOPHOPFIKAJKAIMDGKCILCMOFLQEKOCJNEHLCMMEII@KIAMKBILAELAEMBJSIMUIJSENNDMNDMPFLQFIODKPFMTGPVIRSITUKRWKRYLU\OV]PSZMW_QXaU\eXYcWX`UX_TSYNQVKVZOVYKQWNQYTTXWV_Zw‡}eqg\dZ\f\Zi_ZlcZh_[d]_h`_ic`kc`lb^laaphaqh`qhariaogbpfhthivjhxmgwljzqculbrfbod`j^elatxprwqojfpqjt|q†~|zv”ŒŠÀ¸¾äàãüÿÿ¿Ñ׎“rxx„†‘ltojqlmqkmriptnotnpwpu|wt}wv‚|xˆ}…‰—Žœ™Ÿ­­îüüòÿÿÔääµÉÊðþþóüûüþüÿþþÿýýöôôúøøýþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþÿþýýþÿüþÿûýþüýýýþýýÿûÿÿú¸©¶¦ž¤›‘”“”ˆ›¡–š£˜Ž”ˆ™”…´§•¬¤•ƒƒt‘’…À¶­áÏÄ¿¤™}wjql`…ƒx’††Œ€~†{}…{‡}s|qqxnv{p}€u{„z‚Žƒš”™¢¦š˜Ÿ’“œ‘•ž•‘‘šŒ…–…†•…›Ž£­œ•Ÿ˜—¸Ä·ñöëìïã²³£¬¬žÞÝÒðíãþýüýþüýþüþþþþþþþþþûüüùöõòìçöõïÎÍÃÑ̼½®ž ‘“„ˆ‚…Ž‚‡’…„€„“‚…•„ˆ˜†Š•ƒ„‹z…r~ƒs‚s~€t‚„w“—‡Ÿ““ƒÊʼÿÿÿüüüüÿýÿþþÿþþÿüø÷òêɾ°ÛÌ»îüüîýýðüûøýýïûýæþÿÌëñœ¯³ªµ·­¸¼»ÉÎùÿþûüýòýÿÌâæ¶¸›®«£¢Šœœ Ÿ‰™š™¦¨¹Ð;ÕÏzŽˆ{ŒˆŠƒ§µ´ÒëîÑïõÒåë¶ÄËçõøòùùþýþÿýüÿýý÷ýýóÿÿÂÔÖ³ÃŦ´³«ª™¨¦Ÿ±­Ž¢¤Ñíî­ÉÍ™°¶ ·¾Œ©®ƒ›’˜Žt‡~o„wj€tn†{p‡xp„wp~roznp}omzlfvkctigwlhxmgwlbsg^o`]obWk_ZnbYk_SdWXbT\g[]j^[i^Xi\RdWVaUUaTR`SR_SP^QQ^RU[TV[SUYRW\STXOSUNSTJOPGLNDOMDMLBIH>GKBGKBKLCKMBOSFJRBGNBHNCINCMMCLJBLJAIMAFNBHPELUKLTIJQDJLBNOENQGMQGIPEJPENTIQVJSWKUZNSYLV\QW`S[dWXaTYcUXaT_gZ]g[ZcXX`UTZOTYNTXMWYJTYORXSSXU_fa~ƒ\e[^f\^h`n}vr„{Vd^Zf^bmi[fcU`]^kbbpe`phgvnizqevmaogdoghtiiwkjzon~sk}tatk^le`lcblaelft{umroomitysszsqvp}zw„…‘„‰¿º¼õüüåðôÂÍÑ”›‹–“ˆ‘pxsksljrkotknsmpxprzsy{vyx‚|{€‚“‰‡˜‘“¡ ºÇÆóüþöûý¯¹½èòóóüûýýüÿÿþÿÿÿçèèÛÛÛþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþÿþýýþÿüþÿûþÿýÿÿþýþÿÿüüïèꟴ¢š©£˜Œ•‹•¢šÐàÙÿÿÿèçܶªµ¨ž¢œ’‡…€y†~½±©ñíáçãØ¥ •”•‰‡Ž‚‚‚‹„|…|oxnmujtyn}t|‚z}‡|›¤—ËÐÁ²³§“–‹…ƒ’šž¦›™Œˆ•…‰—„–‰™Ÿ ’”˜“––ž’ÌÍÁÞÜÏÕÓĨ©ÒØÎÿÿúþÿÿþþþþþþþþþþþþýþþüþÿÿþþýüüþýúõõî±­¢¸·ª¦¨™›¡’’›šš™‹’žŸŽšˆ‡‘€„Šy}€nz}n~rƒw„ˆ{‘–‡®®ŸÅÆ·²´©ÿÿÿüüüýÿýûýýûþüùùòþýóþüðíçÙÝèéê÷÷ôúùÿþþýþþâøû©ËÏœ°³©´µ¯¾ÀÁÏÓñö÷øÿÿÌáã©ÄÉ£¸º›°¯—­«’§¥–§¦˜§¥’ Ÿˆ™—|‰€‰}Œ†‚ŽŒ‡’‘ÂËËäýýÖ÷üºÐ×ãíñõþÿëö÷øúûþüýþüýüÿÿïúú¬¼¼ªº¹ž«©”¢Ÿ–¤¡¨·´¸ÌËòÿÿ¬ÆÈˆ—›·ÆÊˆ ¡—Ž’‰tˆ|k€ti€tl…xn„xpƒwmsn}qm|pk|ofwmarg_pfbshdtiarg^p`]pbXk^Zma[l_VhZYgW\i]^l`]mb[l_SeXVdVVeWO^OO]OVaTT_RSXRRVOQVKQTJQSIPPGOQILMDJLBJJAIH>JI?FJBIKDLICLMCMTFJUDJQCKRDNRGNPEMMCJKALO@IMBGNCJQGMSIJPDKPEKPEKPELQFLQFMRGQXLSYMT\NW^PV]QZ`Uah\`j\\hX\gX[f[_g]]gZWaUT\QQYNSYNTYNWXNT[PS\QX\Sah^‹•‹cg^cf_[a\„‘‹jysXfc]icdrpvƒ‚x‡ƒl|scrfeqiiwolzrgum`jcbmeethjznk|qk|rizocuicpgdofckaai_gnghoiknisxrmsmnrnrtq€€“‹ÀÀÀãèêÍÒמ¤¨u{„‹‡{‚|pxrowpmunmunmwmqzqw€x{‡}v‚{{‡€€‘…„•Œˆ–“˜¢¢ÉÏÏÿÿÿõöøÈÏÓõûüþþþÿýþ÷÷ùêììÕ××ëîîüþþüýþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþÿþþýþþüþþûýþþþýûúøâÔÏÕÀ¶Æ±¥® —™””…‰‘ˆÁÊÂõúöùûöþûñ°œ¡“Š¡“Œ‹†ˆŽ‡“–ÒÌÀØÓȼ´«¡ ”€ˆ{ƒ„’ˆ|‹€s€vp{oqznws‚…|}†z…Ž·º¬½¼±”“Œ§¯£®¶«¤—𣖔žŽ™Š’˜‹”„–‡•˜˜ž–—¢”‹’…˜™‹¶¶ªÜÞÖìòîùýúþýÿþýÿþþþþþþþþþþÿýüþþÿýÿÿýÿýýýÿÿÿÞÚÔ”’‡¤¥šŸ¦š‘œ—¤•–¤”™Œ‘—¤–{†t‚ˆy‡‡y€ƒt€ƒt‚…y…y}„tˆx–œÎÒÃëîæÿÿþýýþþÿýüþþýþûÿÿúÿÿøþýõýýöÕâäòþþöýüþýþüþüæÿÿ¤ÌÍ£¼¼ª¹¸¯ÄÃÁÒÖâììå÷öºÛÛ®ÏÔ«ÂÄŸººŸ¶¶™®­¢ Žœˆ–”…‘„‹‚‘ˆ…‚ˆŽ˜–°±°äûûÚúüÍàææêíÿÿÿäêìÏÒÖÿþÿÿÿÿåééÆÎÏ—¦¤ž¬©ž™›•‘Ÿœ¡°®·ÈÃðÿÿ“¨¥Ž•”‘–”zŒ†{„w‹€p…wn‚viuj„vj…xj‚uj‚ug~re}rd{rgzmdvj`rf`rg`th^qd^pa]paZobZna\naWhZXjZWh[Yk]\lbYl^Vi\VfXUdWO]OR\OT]PRZMQYNRWJSVGVVGSSETSFNOIKMGKKEHI?GF>LKCHJELJELJEQPHOVILWHLSBLRCLQBOTEMPDLNBLM?JLBHNBJOFNSIPTILSHKRFIPFMPENQGPSHRXNV]QX_PX_PX_S\bYdj_cl`\i[Yi[]i^Yd\[gZVaTU]RS[PTYOSYNWYQT\PU^OZ^O]aUW_Uac[ec^bc_ksocomenm^kekzww‡…ˆ˜•ixqhwlitl`ldgtljumcnedkddulk|rgxniznk{nfwjdreepcdn_cl_dl`akajngrtlqtjnphntmt{uˆˆ‡¦©§­¯°¹¶¼­­¯‚Š…{‚{rzrmtmpyrlwonzqp{oo}pw…yy†{y‡|~Œ„’ˆ…”‰–”•›»¼¼õóòÊÌÑéòó÷ýüþüü÷÷øçðòçëëÎÔÓõùùøþüþÿÿÿþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþÿüÿÿûûúôõëæÑŬ¢“¦¡—œ™™”‰˜šŽµ±§öïêÿùñùæÚ²”ƒ˜Ž‰ˆ{„‡}‰‹Œ„ˆŽƒˆz’ˆ|œ’ˆŠ‡{Š~‚”‡~Ž‚~„~‚w‡|vƒxww„{Š~„Ž~“–ˆ¥¢š±®©îùëüÿöôøíÉζ»¯ž¤˜œ¥™˜¡’𤕦𠫡¥´¦¥»­²¿²ÄÊÀíðêÿÿÿýûýþýÿþýÿþýÿþþþþþþþÿýþÿýÿýÿþýÿûþÿýþüÿÿü÷öñö÷ðÞçÚäêߨáÒÂϽ¥­¢˜‹ ¬žÏÙËšŸ‘‰‰|‰Œ}†Š{‹ƒ— ²º«³¾ª¨±¢áèÚÿÿýûüûþþÿþþýÿýþþú÷ûöòóîéñíèýüøµÁÃ÷ÿÿüýýÿüýýþþéûû£Á©ÄÁ¯ÂÀ±ÄÄåñðøÿÿøþÿñþþÓíî²ÕÖ£ÂÛººŸº»’§¨ŽœŠ–“†”…ŒŒˆ}Œˆ‡Ž–¢Ÿ ¸½¿éóôÞç긼À²®²¯°±º¶·ÍÈɽ¼¼¬°°§¯­—¡œ•œ—™’‡˜Žž•™¤œ¡§£Œ˜’}އ¢šx‹„xˆu†|p‚xo‚ykxj€ujƒwg€sfte|td{sf}sc{nazpbzpazp^wmayo\tj_pf^pcasf_pcYh_Ub[WcWP]QS_TWeYWeYVcWXbWTbXP\TRYOTWNRWJKSIMSHPQGOQGPRFPRGNOHJKELNHIMCHM@LQBNQGMOGJMFNRJOUKLUHJRGJSFKTGNVFJRCJPAHLAIIAOLDPODNRFOUMPXMPWLRWKOTIPWJNVIUYNZ]QY`QXbR[eX`i_cthiyn\g^Wc[Ye_YhaVg\WdZWbVT[QRZOQYMO\ST]UV]VX_XX`U\e[dlb[aY^d^`h`dmghtn[ebŠ˜ Ÿ™¤¤crqVhh`pq€ŽŽs€~ami_nh`ohhxqjyrgungxnizofylerl`pgbod`nbenbembhmdkqgjrgisghullzr{zŽŠ¡ž{yxtxt|ƒ|}{rysjxpowtxq{qp|tp}uuyu…}yˆ€ކ~’‰…—Œš”™ ¢¥¦§§¬óö÷ùýþûþÿîööèïðòùùõùúÓ×Úñöøöûýúýþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþÿýþÿýüÿþüÿþûþýùýýÿÿþõòêµ°£”“‡›™ŽšŽ‹€‘‚u£Š}•|p¢Œ€ˆ~…„|€‡|Œ‚„Œƒ…ˆ~†ƒv’…¥¥™ ¥š‚œ‘Œ›‡–‹‡”‰‚y„xus~ƒ{‡|…‹}‘–…šœ¹»²ÖÞÐúüöþþüøöôÕÐɾ¹ª¥¦›Ÿ¥š™¥™Ÿ«ž¬¶¨²¸«ÖÝÌüýõøøîæåÞýþùþÿýþþþþþþþþþþþþþþþþþþþþþþþþþþÿþþÿþþþüûüýûû÷ûúøüõÿýôþûíÝæÑÖ×Ɉ}¡¨™ØßÏÿÿö§¡“Œ‘€‡€ˆ”ƒ…¸Ä²ÑÜÈ¡œ¤žæàÕÿÿùþþúýýþÿýýúüùûÿöþüôðêâûøóÓØÚüÿÿûüüýýýþÿÿÒãæ¥ÁÄ«ÀÀºÇÆåðñúÿþüýýýýþùûþñýÿàòôçýýÊçæ«ÊË–µ´‹£¡‰š—…–’…’€Ž{І|‹‡‹“•—“•™–•ž›™ŸŸ™›™š˜£§¦§©¨¡¢¢šœœšŸžŽ˜–Š“‰‹…‹‡–‰™‘Ž™“‘™”—‘•¡œž¬¦Šs‡€q…{n‚yn€ykwi}ui}sjsh~tbxobzpc}rb}odymi~qjsi}qg{obwkbsg^pdbsf^ma[g]T_WW_TSZOQZOS[OU]RT[QV`TP^SQ^UPXNTWMPVJKSILQFMNDLNBNPDMOCMNFMMGMNGLOELQCQWGMVJKTILUJLUJLVIMWHHRDLUHQXKRYKOWHMSDIPCIJCLJBKJ@MQEQTMOUKPVKQUJRVKPWJOXKQYMU_RXbSZdW\gZ\h]…•ŒyˆWe^SaZYk`ZlbYh]YdZWaUU\QY^SW^RR^RT^UY`XX_Xahbrztcogakcdkd^d`hqllxqakakuls~xixrZmjš²®Ãáá§¾¾k~{n{yyƒ€hrmevlfwlgxnk|snvmuhuoerheshdoddmbhlegnehqfirfgrgkvmnyt}‚|‹Œ‰‹ŠŠƒ„„ƒŠˆ}‡„r|vjupo|tuƒ{z‡€†q~vrwv„|w†~{Š‚~ކ•Šˆ›”“Ÿšœ¥£ÄÊÎÿÿÿõùúæêëÐÕÖãçèûÿÿçîð¶ÀÀÜåäøüýüþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþýþþþþýþÿýûú÷÷öñþýùýýüüøôêáØ¿µ¨œš‹¯°¤ÑÛÐåèà×Ú˰¯ ®¬œ•–‡‰ƒ{ƒ„z‰~†’‡‡‘‡ƒ‹ˆŒ€Ž‘…”—‹“—Œ€ˆ|ÇÏÅÿÿþ¯³©ƒ‰}„‹‚{ƒy}„|€…~‚‰}‡€•†”𢦛¹À´óöðÿýþþúùðëäÿÿõððæÇŸÚÜÏ×Ü϶¼®ÄÍÀÉÍÂÕ×Îíîçÿÿûÿþýþþýþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþñððøóòûýúüüöâ×ÍÒǸÿÿõÿÿûÂø‘‘‚—–‰­«ššŠ’“ƒŒŽ€Œ‹›ŸŽÁ°¨¢”›™‰«« ìîåÿÿþþýýÿýþþÿúÿÿ÷ÿÿ÷öòêüûôäççüûýúþýþÿÿøýþïÿÿ¤½ÁµÅÆøýýùþÿüþüÿþýÿýþÿýþüýýøþþõþýêþýÇæç—¹¸Š¤£œˆœ™ƒ”’ƒ’’{Œ‹|Ї…ŠŒ“Œ•‘”’‘”’Ž”‘’™”‘š™’˜—•›š•›š•”‡‘‹‰€ˆ†‰•’†—’†–‘‰”އ•Œ†ˆ•ŽŒ˜}†s‹lƒzm‚ylxi{thyql|sl}rj}rbwnbypc}p`}of|pk€tk€tl‚vf{o`vjasf^obZl]XgYWcXWaUX`UV[QSYNTYOV\PVZOU`RR`SNYOT\RVZRRYONVLLSHQTINPDMNBJNBONEOOGLMCLMCMQCRXHP[NP[NNXKOXKOWHLRCIRFNUHPVIQXKTYKQVFJQDJKEMKCONCNNCLNGMSGPUJNTHOSHPVJRZMS]PU^QXaTYaT[cXdka©²¬w€x\f`SbW`qe]pbZf\_g]Y_TU[PW]RW_RU`TX`UW_UV]Wjpk~‡eoiamgbkf[b]cjegojfnbfqfn|sx‰„¹Î̽ÓÒÝöö¦¤_po„‘jtqjqmfvjhymk~uq‚yu‡€mxiwqgvnq~tgqgdkdlnihphgqghshitjmwov}xzz…‹…ƒˆ†x~~†’ŒŠjwv†€{ƒ}}‡…“‹zŒƒs‚zv…|x‡x‰€{Œƒ€‘ˆ†—‹Œ‘Œœ“‘Ÿš—¢ ³¾¾ÿÿÿûÿÿª­®º»¼àâãÿÿÿÖääÃÐÏÝææüÿÿþþþÿýþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþüþþþþþþýýüøôâØÐýûóÿþøòèãÁª ¼® ©¥˜·º«×ÖÈÛÚÍ®®ØÔÅæáÖŸ–‹„€w†‡|‰}ƒ„’†„„„Ž‚rznnrg„ˆ}ˆ‚•‰ÔÑÆ¿¾³Š‹Šˆ€‰€‹…€ˆ~Š~‰“„‹•„“‰‘…´¼±þÿûÿýüþûù¾±«¯Ÿ”úôäÿÿòü÷éãÝÑ¢¢˜ÆÏÂÿÿþüýøÿþüÿþýþþýûýþþþþþþþþþþþþþþþþþþþþþþþþþþþþÿÿÿýýýýüüýùùüûùüùõôï縬ŸËɸüûóÿÿøïëàˆy¤¢’™œˆ•–†‚Ž–”…œšˆ œ‹¤¦–¬µ§ÚáØÿÿÿÿýþüýýÿÿüã×ÑõªÐÆ»ôòèÐÔÔõ÷÷éíìËÕÔùýÿòÿÿ›±´àìíþÿÿüýÿþÿþþþýÿþýÿþþþþþýþþþýüóüýäûü™¶¸¥¥“Ÿ†›—ƒ”’€|ŽŒ{Іƒ‹ˆ„‹††ŠˆŒŽŽŠ†Œ‹…†‘†’Š•“‹–•‡’{†„ˆ†›—žšƒ—‘…“‚‘ˆ„‘ˆ}‡€w…|xŒ‚qŠ€l„xm‚ymxm}ugvoiynl}rk}rh|pg~rhsf~qf~rh€tgsd|p`xl[sg]rd\qc[l_XfZWdWXcUT`TU`TU_SR[PV^SV`TVbSQ`SR_TV]SV]ST^RPXPOWLRVJSUILPELPENOGMNENOELNBKODPTHOYMS\PS[LRWHSWHRUFNUEOVHQWKSWKPTHQUIORFKLFLMDLNDLOCLNGNQGQSHRSIOSHQVJR[NW^OX^RZ^S[^T_aVmnd“•Žjnh^e[]f\`m`Zh[Ze[X`VV]RU[OU[PW^RW`TV^TZ_V\`Zgnimupbnfeoh`lc\f^`hacjcckagqiiuq›©§´ÂÅ¿ÏÓ½ÅÇ“œœgrqš˜{‡„jvsm{ql{sn€yyއnƒ~k}yiwsiyslzseqjjqjkpkgngfrhiwljxmoxru{v”’…Šrzws}z~ŒŠ•¤¢¥  šy‚|{ƒ}…“Šz‹ryxˆx‰€zŠ|Ž…€“Š‹–Ž›“‹˜’ž˜›¦£©´³ÿÿÿÎÔÔ¨­®¸½¾ÌÑÒÔרÇÕÕùÿÿøÿþüÿþÿþþÿþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþýÿüúØÎÇßÒÇüùòå×ÍÉ´©º¯£­¬Ÿª°¥ÕÖÈíìàúøíêâÓÓǽ¦“Ї…{…‡|{„x€„‘‚Ÿ”ÃËÀÁꥦœ‘—‹‡‚ŽŽ‚Ž„“ˆŒ–Œ‡–‚ˆ‚Љˆ„‹•ˆ—Š•Ÿ’—œ‘ØÜÕýüüÿÿþü÷òªœ”¿¶¨ïàÑÛ̽ÒÈ»××ÎÕÜÖþÿþüýüÿþþÿþþþýþüþÿþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþýÿýýÿþýÿüÿýùøõíÆÅ¹ÌȾ÷ôëûøð²§›¬ª™˜Š“™ˆŽ’ƒ‹€“„–˜ˆ›žŒœˆ™žÊÓÆúÿüûýüÿþþúÿþÿþüÿöL ïæØÿÿô¼ÆÄ²»º»ÇÆÇÔÑÇÍίÂÄ¥º½Þéçûþüüþþýþþýþþýþþýþþþþþüýþþþýùÿÿíÿÿ ·º‘¤¢” œŠ˜‡•’‚‘}‚‚‹…€‡„‚ˆ‡ˆˆ‚‰Š€ˆˆ‹Š~ˆ†ƒ‹…‘ˆ•“†“‘}‹†€‹†ƒ‘~’Š}“Š…”…“ˆ„{Ž‚xt‹s‹~s‡{q†zqƒ{nvfvkhymdynh}pg{nm€sk}pnumƒtkse{m`vh^tf]reWobYpdYkaXi^YgZYfWUcXQ_ST`TQ]QW`TXaUWcUSbVVdWZaWYaUUcVT]TS[PVZLRXHORGMPGMNEOSGLRDLQDJRDOWJQXNSYNU[LU[LWZLTVJSYJOVGPUGNSFPTHQTGOOCNMGKLCKMCKPDKNGNQGQQGOQFQRHOUHPZMW[LX[OXYOX[O__UceYad[dj__h^blb^h^\g\XcYU^TV^TTZPT\QT]PU]SW\TZ_Wae_ele`ha^f]`g_\e[^g\_h]`i^_h^dnft€{ÂÉɳ¹»”y{zy}{ƒ‚kxtl{vp~xuzixt­¿»‹¡£¡‹›wˆ‡o€}u†€guloyqounltmjvlk{pn|tp{sz€~«³³mvu¹ÂÀx…‚‡“‘œš«¦{‰†v‚|y„~z‡w‡€t…|wˆwˆv‰€}‡€”Š…’Ž{‰„|‰„˜›§¥¸ÃÅôÿÿµÀÀ®¹¹¶ÁÀ²»»ËÖÖí÷÷õýüùýüýþþþþýÿþýþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþýþýÿþþÿÿþýÿþøßØÐ×Ë½ÖÆºÈ½±¯¬¢¶»°ÉÎÄéîãÿÿöýþñâÝЖŽœ–ˆ‘†‡Šˆ‚‡ƒ†‚†‚ƒŒƒ¨®¤¼½µ¤¤›¢¦› ¨ž‰ƒ•Š–Ÿ“™¢˜™¢˜‹”‹‰…‰…‹”ˆ’›¢¬Ÿ›¦˜£§œ§«£øøöýüûÿÿÿØÒÎǺÊĸãÞÑõñçÿÿÿÿÿÿûýýýþþþþþþþþýþþüþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþýþýþþþýýÿûþýþþùÿÿúèßÒº±¤¤™Œ¤ž‘¬«œž¢“— ’—‰•†’—ˆ˜ŸŽµ¾ª¸¿ª«²¡»Ä¸ÿÿÿûýüýþþùþýÿÿÿÀ±¨Â¸ªÉ±òëݶÅöÇĵĵÀ¿¸Á¿¶ÊËÁÖ×ÑÝÚçìèúýüÿþÿþýÿþýÿþþþýýþüüýøþÿÓÞ☪°Š¡¥‘¤£Ž ™ŽŸ˜Š˜•†•‘„—’…–„ˆ…‹…€‰ƒzˆ„~Œˆ}Ї€Š‡‡†ƒ‹‰„‘Š™—Š™—†–“ƒ‘Œ~‹†{‹„{†—Ž…–ކ“‡…vŽ‚ss€xŽƒyŽvŠ|t„zq‚whzmgyk`zoc}of{lgzllynpzqrtp~rgwjbre`pc`qd]ui\sj\ohYj`Xg\UcUUbUWbVV_SV^SV\QZ_TUaUVdX\h\_e[`hZVfSV_WS\PSZKTXJOUHMPGLQHQXKOVHKTEMVHNVLPYOS]QV_QXbTW`RRXMOWGMTDPUFOSHPSGPQGPMBSPJLLDMRGKQDIOGNPFQQGPRHSUJQVIKTGT[LPXJPWKSXOX]Qbi\dnaama_nb\la[i`Zg_VcYVaXV_TS]QV_SP[NTYRY\WX]Wglfiph`j`be\_eZbj_]gZZdW_gX\fZeocktjqwquur‚}}{†‚Œ††•tƒ~qzr~y{„ƒœ¹ËÊyœ¯®…––¾ÑÔÎäân‚}pwo{qqzqs{slwok{qnvmyr†Šž©« ¬¬Øáà\jd€‹ˆ–ŸœŽ˜–~Іxƒw„y„~y…u‡}t‡w‹‚xŠ‚{ˆ~”Šƒ—”±ÃÀâóñ£¶´ÁÑÑ¡±³ôþýŸ®­±À¾ÂÑÐÜìêðþþûÿÿÿÿÿÿÿÿþþþýÿýýÿýþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþÿþýþþÿûþÿüýþÿÿúÿÿúïæØæÜÏÓÐÄÊÑÆèðçþÿø÷ôíÕÆ¼ÿýóìßÒÍĶ¿½¯—˜ˆŒ‰ƒ¡¨›ËÒÄ¢ª›––—˜§¤›Š‚¡¥š½È¼ÓÛÑÔÝÓ¹¾´‘–‹“•Œ‘”‰Ž“ˆŽ”‰•Š˜ŒÏØËùüôÉÎÀª­¤ùýùøüüúýüýþüýüù÷÷óøùðïñéýþûüüýüþþýþþþþþþþþýÿýüÿýþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþÿþþÿüÿÿýÿüýÿýþýüùôôîàÈÀ±ÕÎÀº¸«››£¦—¡§–›—š‹œŸ™ ´¿ªèñÞÉÏÀ¶¸®ÿÿûüþþûÿþûþÿÿþýÙÑÊéãÓìçÕöê×¶Ä·ÅÄ´ÆÆ°ÂòÈÇÁÕ×ÒèêÉÝßÔáâõ÷øüýýþýýÿþþÿþþúýýøÿÿÈá㪿À¤¹º“¬©£ž œŸ˜‰œ™‡™ˆœˆš—ˆ—”‡Žƒ‹‰|†|†€€ˆ„†ƒ€ˆ„Љ›•£ž¢ž žŠ—”€‹‹ƒ—„—Œƒ“ˆƒˆ{‰€y‰~y‹€xyƒ’…~ƒvˆzqƒxdukevkd~tcxlk{mkwfkuflthjtjgujcth[rdWpcYqgY{o_zoavmZndUh[UcVW]XU\TV^SV]PW]QX_UVbVWfZ`l_ek`bi[\h[U]QS[PRXMRUKRRHVUKRUKTXMQVKOXLQZNT^QS[SR[RU\R]cYZ^TRWLRRFQSFMSBQWEOUGRTIOQIMSJJTIIRFIODMOCQMGOOGIPELUHQWGWYHXYORTJRVKSZNS[Q^f[bl_cnabj``j`^h^]g\]g[YbVS_STaUU_TVZOWWOX]T[d]nxr…‹^eb_b]^b]xw\fZW`T^eY^j^fpeltmpuqsxu}‚€z‡„ƒ’‹Ž’m{qz‰sƒ€}Žˆ…”³À½žª¨ÉÖÔÇÔÓ³ÃÆž Ygen{wnyrmxnq}xo~zhwppxmsxmƒ|—›šÒÖ×Úàßgmm~ƒz|xt~vx„{zˆ€{Š‚zˆ„‚‘y‰yŒz€{‚|…ƒ•†™ÌÞÛ•¦£ÁÏѲ¾Á½ËÎ×Üܤ°³³ÅÇÖçéðùûùüüæéíÆÉÎåèíøùûþüþÿþýÿþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþÿþýÿýÿüþÿÿÿþÿþ÷ÒË¿ÎÁ³ËöÔÒÅÌÎÂëíáþþñüýëïëßÄ·¬À­Ÿ¸¬›£¢˜“‹†‡|„ˆ}‡‚—‹š •’ ™“𔑒ŒˆŒƒ¥šÅËÀι¿µ«ëåß¾¶¬¤£—”Ÿ‘¡”“š˜›œšŒßÞÎÌÆ¹£ –ñðìûýûÿþþÿþþýþþüýüþÿÿÿþÿýþýþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþÿþþþþþþþýýñéá¼´«×ÔÊâã×½¿°®¯ž¬ª›¨¥”¢£“ž¤™¢—««Ÿ§¯°·¨ÔÚÐüþùþþýýýýÿþûýõíÓŹØÏ¾ÿÿô÷ó篽½£¸¸­ÄůÊË¿ÜÜ¨ÃÆãúûËäèÄÖØÚââþÿÿþýýÿþþþþþúþýöþýßõöµÌΣ»»”«©¥¡‘¡‘££Ÿ¥££¡’£¢”¢ŸŒ˜–€Š{†€Š„}ˆ„|†„„‰ˆ…­¾¾›±±”¯°‹¨©¤¤„—•Œ‰˜”‹™’‡–Žƒˆ{Šƒw‡|u…zz‹€~„{‹}‚x‰|q‚wiyniynezqdvkiwjhreenaembemb_j^\n^]se_wjc{oa|nbyo_xnZriXm_[h[[d^Zd[]f[[eX[dYYaWYdY]i_ak`inchnaal]V`TPWMRYNSVKSUKVVLQTKRUMRUMQYOT\ST^SV]RT[PSYOX^SY_SQVJUWKOTFNVFPYIPWHPUINQIOULMWKJTHJQEMPEQOFOQGPWIKVGPVGUYIWXNQTIQUJPVKU]Q[bX_i\bl_bka]f[]f\^g\ZdXXbVWbVUcWS^RUXNZZQZ^VY`Y‘š“qxs]b__cZmqjmtk\e[[cXag]_jagrhipjpypszqv}uv€{{…~Œ™ŽƒyŠ…m€|x‹‡Ž™p{y}…„v}|£©§ÒÜÜ¾ÆÆv~}szwpvplslƒ‘s…ƒk{wdodmtgx{u„…‚º½»§¬«pvtpwrw|wx…}y„|ˆ€yƒ~‹™—–¦¦g|vv‡~|‹{‰€}Œƒ~Ššª¥èôò®º·ÇÏϲº»àèêÁÊÊ ª«½ÊÌÒÞàÿÿÿðööôøùçìíÝãæëðóûþþýþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþÿþýþýÿýþÿþþüÿþùÿÿ÷üúñ÷öîäãÛÅĺÇĹâÜÏííäÿÿÿÿÿÿÒÉÀ¬£—¤¡•—™Ž•Ї”ˆˆ˜‹›‰•‰ƒ“‰•‘ˆ“—°¶ª½Àµ°²¨¡”««žÜÛйº­™‰“Ÿ“–Ÿ“–œ‘—›œ®®žÇÅ·œ‘ÄÆÁÿÿÿýýýÿþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþýþòðëËÆ¼ÕÓÆÕÔÇæéÛéìáÑÏų±¡©©™¬°¤´·«´´£´¶§ÚÛÏÿÿÿýþûþýÿýýÿÿÿþðëä˵ÞÖÆåÝÍðç×ðüýâóôÏççÊèêåÿÿàùùãþýÑíñ½ÒÔäïðûþýýýýÿþþþþþúþýøÿþßóô·ÐÒŸ»»—¯¬’¦£”§¤•¬§˜®«—®®•¬«Ÿ³²•§¦œšƒ“Žƒ‘†‘Ž}ˆ…~ŠŠ‰‘‘˜™¶ÄÆäôõçùúÜôõ©ÉÈ…œ›‚‘„‹‹•‘…“€‡|‹ƒx‡}v†{xˆ}x‰|v‡zt…xqƒuv†{qtjymixqgtkkujhpecl`cmajqbcm^ao``uc^tf]uibuhdxmc}r_zoXobZfZZe\^i_^j\ZfZZfZYdZ_f_[g]_i]fk^lpcgqa\eYT]RT[PUYNVYMWZNTZNTZNSZNS\PYaVWaUZ_TZ^SW[OW^QW^QU\OU[ORZMR[LPZKPZMPWLTWLPUKLVJKUIMTIPUJSSETWISZKQXIRXJSXHTXMSWLSYNSXOU[PZbW_iZal_^h]ZcYZcXXeYWaUV`TXcYVdYR]RX\QZ[SZ^Uag]ˆ…‡ƒbd^`aXhlakpf^d[\c[`f__lffqkhskpzot~twuy€y{‚zz†}w†~zˆ‘¨¦Øéè†›šžž¡«©†‚y~|ltppzvmvss}yowsszuŸ ²ÃÄ©·´\f\pvjovn{…„~uytovpu}sl}tuyˆx~y¤±°xŒŒ”«§Ÿ™z}}…{†{‹ˆ†Š‹“Ž‘–”£¨¦¦«©µ¹¹±¾¼¬³µ¼ÃÆÀÇÊ»ÃÆÞçæûÿþûÿÿìðôðô÷ùþÿûþÿþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþÿþþþþþþþþþþüÿü÷õñçõ÷òþþûýÿúùøô¿º±¹°¦×ÔÑÿÿÿýüýÿÿûÌǼ¨¢˜—Ÿ”‘œŒ¡“Ÿ’‰–І“‡ˆ…–—Œ–˜½À³òñæùóêéáØûöíã×Í –ˆ£ ’›£—›¢—™¡—•‘›¡”™žÓÓÆ÷øòóõóýÿþÿþþÿþþþþþþþþþþþþþþþþþýýýþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþÿþþïëäåßÑåßÑîìàÿÿÿÿÿøÝÚ̵´¡·¹ªÄŶ»¹¦ÂñÅÅ·ÙÙÎþÿûýþýüþþúÿýüû÷ðíæôîàßØÆæÙÈùþþ÷þþñÿÿâö÷Êåê¿ÖÜÝòöÏäçÓäåóúúþþþþþþþþþþþþýþþúüýîýþÀÚݤ›³³–ª¨š¯­š·²•²®¡½½¸Ôԧ”¯­£ ƒ“…“Š•’ƒŽ‚ŽŽˆ—””¡žÓÜÙúþþõüüôüüÔï𣥎‚ЉƒŠ€‰€ˆ~Œ†v…}u…zx‰|y‰|rƒypws‚ws„woshwkfqljtjjrhgpdcl`dncirdfp`ftbbraatf]qd`obfthlƒy_ynXma[eYYfZ^l`\j_^mbYh]]l`\f\\h]\f[fk_iobhrc[h]YaUVZOZ^S[aUY`RZcRWbPT^MT^N[eU\fW[`VZ_TV]QU\PW]PV]PW]RS\PT^OR_PR\OQYNTULQVKLVJMWKNUJRVLUXITYIT[LSZKRYJV]NWZNUYMU[NT\NW^QX_RWbQ^g[^h\XbWWcVWcWXaTWaVXbXWe\T_TX[OYZPWZQ^cY`e[_cY^aX\`U^bW[`W\bY\d]`iadokiuoiworyw†{}‹‚w€{x|t€{s‚~l}¼ÒеÑÑj‚‚ª½¼™§¤ƒ‹€‹†~Œ„y‰ƒr~uƒt~hsoš¦¨ÍÛÝanjkrhlqelskyvrzytxzsrwopxnr~tp‚yr~w|‚{z|œš”¨¨˜­ªv„~z‚|}‚~~‰ƒ}‹ˆ‰Ž‰–‘”𔕛–› œ¦©§§±°¦±¯ÉÒÕºÂÅÀÊÍéôõþÿÿüþþöøûûüÿþýÿþýÿþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþÿýüëêåúøóÿüüÿýýÿþþýþûÿÿüéêâõòñüüüýýúõòꬢ”®¦˜ –•‘›Œ˜ŒšŽšŽ˜ŠŒ‘„Ž„„‰}„ˆx’‘ƒ»¯¦êâÚ¯¢–¢”ˆ¯ªš«°«³§¥°¥ ¬¢ ®¡²¾±ÐÛÎÏÒÃææÝþÿûþÿýþþþÿþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþýþÿýûÐǼ×Ì¿´¬¡ÍÈÂõóìúùí÷õçêëßåæ×èåÖÏпÇǶÞÞÑýþ÷ýþúüþýùþüþþûÿþùÿÿ÷ôñâúöåÿþÿþýÿ÷üüöÿÿÎæé½ÑÖµÆÌÀÒÓàììùþýþþþþþþþþþþþþþþþýýþïýþÉåæ§ÉÈ¥º» ³µ ¸·ÁÛØÌääÑíîÚö÷Îìí¤ÅÄ“¨©‰™˜…‘…Œ†‘ˆ–“œ™§±®ûþýýýüþýüúýüÓåæœ­®ƒ|†„z„€zƒ}Š„Šƒw…~v†{yŠ}w‰zmvnƒwqƒxk}pfxkctghumq}rqzoirfgqedqeend`i\_i[[gWYhW\l^_m_frfjynfymWg\[eZZfX]j]bodcqhcqe_macpcaqcdpdhodhoc^l_]h]ZaW[`UY^RYaSWaQWbPWbOS\LR\NZdVYbUYbXYaWV^TX_TV]QX_RW]RS[OQ[OP\OWaTS\PWWLUYNRZONYLNWMQXNUYMV[NRYKT[MV^PW`SW^QT[NU\OV]PW^QW_RW_PV`QV`TZeXWcWWfXYcUXbWYd]UbZT_SX\OXXOY\Q_cXbi^ah_ZaWYaVZ`V]bY^h^`jabqghtnhuoizu‰š–‡œ—}“u‡„Š›˜™¨§«¸¹}ŽÙéèÁÚÚž°³½Îί¼»‡•’y†„y‹‚r„€oƒƒŒž‰–•x‚œ¢¡ÕÚÙ„Š‡lnepsgmtlrtptupwzqsxos|stws€yuwwxy„{އ˜©££±­{ˆ‚y€z}„ˆƒŒˆˆ‹Œ•‘𔛤žž¦ ¤«¥­µ³¬¸·¿ÎÏÌÚÞáîñëö÷îðñõ÷øöøüûýýÿþþÿþýþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþýÿþþþþþþÿýü÷öóýüøþþýÿþþÿþþþþþúýûýÿþÿÿûþþÿþýûþýöÎÄ·µ­¡£¥™›¡•’œ™Œ“›Ž˜ž’•ž‘’•‰‘–ˆŸ¥š©°¤ž ”¨®¤âãÚèçÞ·±¥ÒÕÆÔãϳ»®¯¹®¨³ª¤°¦¨³¨ÏØÌ´´¦©¨éçäþÿýþýþýþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþÿüþÿÿÿôïêÞ×ÑÇ»³¿µ­ÉùþùêþüîÿþõÿÿùÛÙÑËÌÃÒÒÊååßþþúþÿüþÿýüÿýþþþÿþþýýùÿÿ÷îêÞÿýüÿþýýþþøþüÝõøÌáã¿ÑÔÄ×ÙßïíùÿýýþþþþþþþþþþþþþþþýþñýÿÑïï²ÔÔ¯ÆÆ®ÁŸ··èùøîÿÿæüþÜõ÷ßúûÀàß”§«Œœ‡”’‰‘މ“Žœ˜•¡ ÍÒÓÿÿÿþýÿøûüêòò‚‘Œš™€Žyˆƒy„~|„~~†z…~z†~u…zx‰{yŒ}o†zlƒvkui|oevjcuggwnl|pmzmiuefqbeqdcpgZdZZcV]gX_jZ`n^ap`hsfktjfrh\g][dYZeWXeXalbjxnkypdrfetebufetfhqfgoe_la^h]ZaX]aW\aTZbTZdVX`SWaUU_SXaVX_VX_WVbZUaX]f\\dZYaWX^S`f\V]QPZMS]QV`SS[QZZOX\QR[OR[OQYOSYPU[PW]RX^ST[NU]PV_R[cUW^QV]PU\OU]OUZNT\MU_PXbVZeYXeXWfX[fVYbWXc[S`XT_SW[NZ]SW[PZ^T]cX[eYYeX[cY[cY]e[clbancdtijxncrkzˆ•ª¨ƒœœœ¶¹Ðê颷¸¼ÌÏœž{‡‰»ÇÈ¢°²›§¨“ŸŸ’œ›‚ŒŒz…„€Œ®¿½³ÄǬ¯z„„Ž•“’’Žsutuvqsqgqqgmtlnsqquoswosypq{rr~xw{t€vu„yv†z{Š€‡–ŒŽ”‹ƒz…}{†~‹„„ˆ‡Œ‡“Žœ˜–¥¡˜¥  ª¤¨°­©µ´ÆÙÚêýýÜêíéñõßççÛãæòùüùýþýÿþÿþüþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþýÿþýÿÿþýÿýüÿýüÿþüûÿüúÿþüþþýüþÿþþÿþýúÿýüýÿþúüúôò¹±¨ª¨ ¯³§£ª›¤—›¨šš£–—‘˜’•—Œ‘–Š”›¦¯¤šž“âíåÿÿûÿÿýùøðÔÈ»¥¢“™›¤¨ž°·­¬´ª¯µªº½²¹¶ª½º°È¿ÿÿÿþýýüýýþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþûþýüþþýÿÿÿÿþùöï×ÍÃÑÊÀéáÐåÝÌÓÎÅúùöÿÿýýþÿüÿÿüÿÿþýþÿþÿþüÿÿþþÿýÿþþÿúþþüýùøõëÿÿÿÿþþþýÿüüþåüüØõôÑíêÏåãïùùûþþþþþþþþþþþþþþþþþþþþñýüÞôôÂÜá²ÏÒ²ÆÈ¶ÆÄõùøþýþüüüúýýîþýäùû£»¼”©ª‡•—‰–”ˆ’𥣧²´ðööýÿþÿûüýþÿ¶Â™™œ™Žˆx‰y‡€|‡}…€ˆ‚|‡z†€{†}€‹yˆqƒzh}qcznfzlfyjhvjfxlavl_qgbocgncal`^i]ZeX_i]`l__l`eqektikticqf\i^[dZZeYZfZ_k_guin{ofviftiftiepfgpfemdcla`ga\bY^eW\fV]h[XdYUbUWdUXdWTbUVdXYgZWeZWe[\g`[f^Zd[ZcYfpfQ^TNZOU_VU[RSWNX\PX]OX_OW_OV[PXYSW^RX_TX`UU\OW]Q[_PY\P[\P[]QWZOUXMSYLQ]MV_OXcSWhZTgXWfX\dXX`UU`WU`XU_TT]PU\RT[QW_TYdX\fZ[eXVhWZfY^f\bh_epeftghwjmwsm{}¸ÐÓÅÞÞïþüáù÷ºÈÆÃÎΩ¹ºƒ•˜§²·¤µ¸¥²³ªµ³’›˜€Žˆ|‡ƒ”’ÆÐÐw‚‘££ŒŸƒ‹~€|yytrumosimumlvoquksxntzowuv~vt|uqvtzv‚|{…~~‰‚ƒŽ„~‡‚|†€{†~|‡‚…‚‘†‡‘‰‰•Ž“Ÿ›š§£š§¤œ­¦Ÿ«©¨µ³ÏÛÝí÷úêõøäðòåòñíúøôûûúÿþýþþÿþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþüþþýÿÿýþþþÿþîîêÏѽ¿²³±§²­£«§œ›œšœ’‘’†‘„˜›¤¤›°±©ÄǸòïáèÙÉãÏÂ×̾òñçÿÿöÖØÊ­°¤º¿³´¾¯¹Ä´½Å´½Â²ëíãþÿþûýýÿþýþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþÿýÿþýÿüÿýþÿüÿÿûõñêÎÇ¸ËÆ´ÉųÜÝÌüûòÿþøþþþþþýþþþþþþþþþþþþþýÿþýÿþþþþþþýýýüüúþÿÿüþþüþÿúýþäõõÖççìùø÷ÿÿûþþþþþþþþþþþþþþþþþþþþþþþóÿýãööÃÜà¹ÔÖºÑÑÒãàüÿÿþþýÿÿÿûþþøÿÿÈÜÞ²ÔÓ­ÊÉ…›™Š––‡Ž¥ª©ÐÕÕýÿÿúûûþþþ¹Á–¨ª¡¡‡–“‚’}‰„މ€‹’¢¡‚”“r…ƒp}yˆ|Šy‰€t‡|h~re|pd|og|phqeznavmbsjapdam`]j_[g\_i__i^^j__mbdnclrhirgepe^k`[dZ\eY]eZ^g[bl`ithithctidtidthiukfrhfoeckd^g\\eW_hY[g[ZeZVdVXfX[h\]j^]j^]i^[i\WeY]i_\g^\h\al`fqgXdZVbWV`VX^TX[RX]QX]PV^NY`QW]QX[TX_TV_TV_TV_RY_R]cV\_S[^R[_TVZMU[NRWKT_NX_PZdVWfXVhZZgZYdYYdYVaWV`VV_TU]RV^TV^TXbV[eY\fZ[gZYjZZfY^f\_e\aj`freivku~zkuxÛìîôÿÿôúùíýý§´´“ £•©©·ÉË«·» ¨«“ž‡‘ޅЇ†‘‹Š›–ÓßÛŠƒ–”®¿¼‹–—quqsvqsvnqvmpxppzrtzqtzqt|rqxpt~uq{tuvuyw‚|xƒ}€Œ„ŒŠƒ}‡€|†~~ˆ€‡Š‡‰‰“ŒŒ•“›™©ªž¬©«º·ÆÔÑ«·¶ÔáâÝèêóúü÷üÿöýûöüûùýýûþþþþþÿþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþüþþýýÿýþþÿüüþþûþýô¿À´–šŽ’”‰©ªŸ ¥–™¢–°·©©¬›’˜—Ÿ”¡£—°¬ ÕÎÂàÔ˾·®ÅÁ¹ÑξåâÕóóéÖÖ˿·ËÏÁóöéâãÔ¬¬ úûùûüýþýüþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþýÿþþþýÿýþÿüþýûÿÿüîìãÞÜÐÔÒÆÑÐÃø÷ðÿþüþþþþþþþþþþþþþþþþþþþýÿþþþþþþþþþþþþþþþÿÿÿþþþýýþýÿÿÖäãæííýýÿþþþþýýþþþþþþþþþþþþþþþþþþþþþøþýòýüîûþçøùßîîïúùüýýÿþþÿþþýýýûÿÿ½ÍÐÅäàÕí쀕’‹˜–ƒŠ‰¨­«ÙÙÙçééþÿÿÐÕÔ«¬ ·ºˆ¡¡…——„‘Ž…~‰¤·³â÷ø¹º•±²Ž©§x‰x‹‚u…yq„ynƒwhshugudƒuc~rezniyodujcsi]la]k_`i`dmccmcbpehpgipfjogdpd`l`_h]_i]^h\_j^^j]`m`eqectievkizom}qhwldtidogcmbak^ak^^i\\g\[k]\k]_maamabnb_k_[hZZfZYdZZfZ]j]an_^lb[g\T_W\e[ZaWY]TU]RX`RW\PY^Q[bU[cYYaVWaUWbVXcWX_TYaV[`UY_TV\QTZNRZLW_RV_R]cV[cVVcWVfY\h\Xg[Zh\\f]WbXW`UT\QV_UV_UYcWZdX[g\^k]]l_^i\\dY^f]^g]dodgtlzƒ€ˆøýþÿÿÿþþþçðó¹ÄÈÐÜÝÀÓÕÀÓӀޒ–™™š‡–“xˆƒ€‰}‰„ƒ“‹„‰„Žˆž«¨²À¾}‰‡mtqsztpwnu}su}su€wwvu~sz„|†ˆz…~u‚{wyw‚zxƒ|z‡€‚ކ}‹ƒ|‡}|ˆ€‚‹ƒƒŠ…‡‰‡‹‰—“’š˜–  ¨±²Ÿ¬«¿ÍËÃÓÏ©¸¶»ÅÈÞåçúÿÿúüýüýýýþýüýýþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþüþþüþþþýÿÿýýÿûýÿÿüõîé÷÷ñìîæÂ¬ÒÔÈßèÙóõê©¥—·¶§¼Á³°¼®ÆÆ¿ÞÞØþþúýýúûúøðîìÑί«ŸßÜÕÿÿüüüøûû÷ÿÿøôñæØÔÍøùöûýýýýýþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþÿýþÿýþÿýÿÿÿýýýþþþÿÿþÿÿûüüøùøõýüøþýüþþþþþþþþþþþþþþþþþþþÿýþÿýþþþþþþþþþþþþíêéû÷øÿýþþüýðûû÷üýþþþÿþþþþþûÿþþþþþþþþþþþþþþþþþþþÿþþýþÿúþÿùþþùÿÿùþýýþþÿþþÿþþûÿýòùú°¿Â°¾¼”£ ‚Œ…‘Ž‚‹ˆ™ žŸ ¡¥¬¬Œ”“Ž—–ÀÎÎïÿÿž··€‘‘†“‘ˆ‘ކ“ØéåìþþÓìíÁßà›¸¶™“z„rƒwp€vpƒwl‚vkƒxk…xd†xd€scznezng{oavjZod]mbclbdlbeoeeshfoeekbfmccobanbcma_nbbqe^pcaqd_qdatfexlgznl|qizohynj{pgvjgtihthepc`m``nb_n``oadrfhthgsfcoc]i]\g\XcY[g[]j]_m\]l`[i]]gZ^f[\cXZaUYbXZaVZ_S[`TY`U[cXYaVYcWXdWWcXU`TW`UY^UX_US\QU]RXaSXbUW_R\bVZcWYfZWg[\h^Yi^Yh]XeYYcWYbWW_UW`VV_UWaUWdX]h]boaapb]j^[fY]f\ah`dmgmytmyw~……±¯±¹´´åàÞîòø÷ÿÿòþþ÷ÿÿßî~}¤¡‡žš¤ Œ †“މ•‘Š’–š¬´°ŽŒu|u}ys|su~tvvy„zx‚vs~v~ˆ‚³¼·|‡€x‚xwzz…||‡}~Œƒ‡„‘‰~‹ƒŽ†€‹…‚‰„‡ŒŠŒ‘’™–“›™Ÿ¦¥£­®¤°°âîì¾ÑÌ¹ÈÆÉÔÔðöøûþÿýýýÿþþÿþþÿþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþüþþüþþþýÿÿþþþùùÖÍɽ¨£ãÙÒûûòÿÿúÎÊÁ®«ŸÈɸÙÔÆ²¦šÝÓÉéèÞþÿúÿÿþýÿþùþüûÿþýýýþüýÿÿÿÿþýñðîþþþýýýüýýÿÿüåá×äÞÖÿÿþüýþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþÿýþÿýþþþþþþþþþýþþüþÿüþþýýýýþüþþþÿþþþþþþþþþþþþþþþþþþþþþÿýþÿýþÿýþþþÿÿÿýþýÆÅÃÛØÖûúùÿÿÿùýþúþýûýýþþþýÿýüÿýþþþþþþþþþþþþþþþþþþþþþÿþþÿþýþþþýýýþýýÿþþÿþþýþþûÿþÝè韱³¡ª§‹–”†’ƒŽ‹‡†ŒŠÁÌÎÕä㤳±¡«©–ŸžŸ¬«“§¦‚”‘†”‰“—‘ÍÔÐÿÿÿöÿÿæüûÀØÖ„š”wˆs…zovpvs…zo„xn…yj„yfscqb}nb{n^riYqd]ocalaembhrgguidngcjaelbcqddsedqb[l_asfewidviatgatghxnizogxnhxnhynizojzom{piuigsgcpdesffqceqcgrffuifvjbre`jb\f^]h__j`bqd_o_^ob]j^^g\]e[ah^_g\\e[[cY]`V^cW]dYWbVW^SX`TWaVU_VU^TV_VW_WV^UU_TYcVYeWYeWZcX^cY\eZ\j_Yi_Zg^Wh\WdYU_TXcWWcXVbWV_UU^TUbVYeY]i]aoaala]i]^h\_g^aicfokv‚”¤¡¸ÁÀ¡¢¢š–”ŸŸšøúü÷üüúýýûýüèôõºÐÒ‘«®¶ÎÏ£¹º‰ŸŸ®ÇÈ¢½½£¥’¥¥žž}„„jsr—¦¤ƒŽr~yu€xv€vz…zy…{wƒvt}u¤­¨•š}†{…{}…~~ˆ~Š€€Žƒ…”‰„”Œ‘Œ„”ƒ‘Š‚‹……‹†‹‘™“–šž¦¦¢­«£®«¶ÃÀ»ËÇÅÒÒï÷÷øüýýþþÿþýÿþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþüþþýþÿüýýÿþÿûøôöèãñéßâÚÌÓȽÀµ§¹³¥Ã½¯°§›µ¬£¹²¨¤£˜Åɽõõòýþüüþþûþþþþþÿÿþýüýýüýþþÿüþþûþþûýÿÿþþïéäʺÿÿþüýþüýþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþýþÿþþþþþþþþþüþþúÿþýþÿýþÿþþþþþþýþþýþþþþþþþþþþþþþþþþþþþþþýÿþþþþÿýþÿüüþúýÿú½ÁÀÑÕÓòõôúþýÿþþþþþÿÿÿþþþÿÿýÿþýþþþþþþþþþþþþþþþýþþúÿþüÿýýÿýþÿýÿÿþþþþÿþþþþþüþþøÿÿ×æç±³–«¤Š—‚“ŽƒŒ†ŒŠ“‘èøúïÿÿ¬¿¼ž¨§–™––™˜Š˜—„’„’ŒŒ—˜œ—¯°¬ÑÌÌàåãÁÓТœ€’Œ|ˆ€u…~q‚yswtƒxt‡zt‰zsˆ}l‡yeƒu`qa|nbwm`yl`sgeqdgpdkthkylbph_i`aka`pd_qddrd`nbdqffuifuidthfwjk{pk{pj{ofxljzpj{oh{nl{phtidpdesfcrdhqcfoacocguiewjaseajc]f_`kciukkymfug_pc_l``i^dj_dk`embaka]d[_bZ`dZ]eYYeWX]RZ`VV_TW`VXaWZaZYbYZcZYbWZfZYfYVcU\eZ^f[_h_^mb]of\iaYf^WdXU_R\fYXeZUdZW`UXbXZfZ\h\]i^_n`_k_]j\[h[^h_cjekpo~ŒŠµÇć–“ˆŒ‰šš– ©¢ýÿþûþüÿýúÿþüöþþáûü°ÏÕÇà䮿¢±´×ìĔ¯¶Âà㩪lz{˜§¦Öîêy‰‡p~zw„{xƒyz†yxƒwx‚vyy†ŒŠ‘—”€‡ƒ{„z|„}‹€Œ€€Ž‚†•‰‡–„—“•¤ ‰—”‹…ƒŒ†‹’‹Ž–•œ—Ÿ¨¤¥®«©³±¬¹µºÈÆÝèç÷þÿùýþþþþþÿüþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþýþþüþÿýÿÿüþýýýøÿþöûøíðåØúñâÖÎÀ³²¢·®¡²«¡­© «¬£¼¾µÂźìñêÿÿþþýýÿþþýþþýÿüÿüÿþþýþþüþÿüýþüþþýüýþýúöïíçþûøýþÿûýýþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþüþÿþýÿÿþþþþþûÿþùÿýÿÿüþþýþþþþþþüþþüþþþþþþþþþþþþþþþþþþþþþýÿþýÿþÿýþÿûýýøùüô¶¾¶ÇÓÌíôñÿþÿÿþþþþþþþþüþþüþþþþþþþþýþþüþþüþþþþþþþþþýÿýþÿûþþûÿþüþýþþýÿüýøÿýûýýýüÿÂÕו­©“§§ˆ™—„ˆŽ‰†ˆ„™—•º¹º”›š‘œ™˜•Œ‘…‹‡ƒƒ‹’‰„˜Œ‘Ÿ–¢›ª°«ÃÑÊ”¥œŒ˜~ŒƒvƒwŽ„xŒ„v†€u…{w‡|y‹~sŠ€s‡~n†{au[}rdƒxbzb{pcthmzkivheuhcnh`mdeocfqdbn_aoa_se`vgdxijxilwlixmp~sk€vd}tc|rf|ohqf~qgzncpffpdfqegsgbrg`nb^l`eteguffsddmbamaaocl|pnqhxjctg`mb`i_cg_hmdhndcj`ai_`i^_k_[j^UhYZdWWaTYdVZeW[eX\fZ\fZ\fZZh[Zi[\hZ^h\_hZ_j]^l`_qe^od[mcYgZVaVW`VYd[[h]YgYWe[Xf\\j_\j__k_]i]\j_]h\]g[bk_dnelxo„ЉÊÑϺÃÀy„Ž”šš•éååÿÿÿþÿþÿÿÿûÿÿðþÿÀÑ×ÊÔד˜—•š™¿ÌЭÂÉÚîòæûýˆž¢€‘”ÈÚܸÎÐ‹Š€‰w…||ˆ|y„{w‚|{|ƒ~€‚~„~ƒˆ‚‡€‚Šƒ‚Œ‚Œ‚ƒ‘‡ˆ“›—Ÿ­©’žš„‰…‰Š’Œ‹–Œ”™§Ÿ ­¦¤²¬«¹³¾ËÉéðïþþþÿþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþÿþþÿýþüþüþýöÒÁ¸Ë¼°¹·©´±§¶µ©·¸¬²·«¿Ç¼ÚàÙùúúûýþýþþþþþþþÿþþÿþþþþþþþþþüýüûüûþþþþþþþþþÿþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþýþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþýþýýüü±¸´ÇÒÍìóòþÿÿþþþþþþþþþÿþþþþþþþþþþþþþþþþþþþþþþþþþþÿýÿüüýûüüúûûûûûþýüÿÿÿÿÿÿÿÿÿëøúÃß⟴³”¦¥†•“‚ŽŠŠ…†Š…††ƒ‚|z}{…ЇŒ}Ї‰™‹Ÿ›ƒ’Ž„”†™ —™¤ž¨²®¾Ïɦ·±‰—ƒ’‰z…€—Ž‚”Œ|Œ…{‰‚xˆ~y‹s‹‚u‰q‰€f„zaƒxf…{d„{c{qh{np}oozlftgargethdregtfdqdcrfjvkn~snto~rk|ng}on}rnwm€whyph|re~phwezpapebmcdoccpd`od_mb_mahvjlxlividrf_pcdwjlrmth|ngxkfrgbjaajabi_bj``h_bj`fncdoc_maYl]YfYYdW[hZ\i[ZgYZhY`i]^j_\k^[i\]j]`k_cl`_j^`maaqfbqf^la_j^ZdYYbY[dZ[h]Xj]]j_]k``ma\j]_l_^j]]g]]h\ah]_g\dldjskx}{twusxv|†‚‰‹ŽŽ‰Ç¾ÁÞØØèáàðêéåááÎÏЧª®¤¦§‹‹‰™œ–ž¡ÄÑÙÍßäÜïòu…‡¥®°«²´³¾½Žš˜~‰„}‹yˆ|x‡}z†€{ƒt{v}~ˆŒŠ‚ˆ…‡Œ†“‹ƒˆ„‡„†ƒŠŒš–¨²±›”‡‘‹ˆ‹Œ“Œ—‘–—£›©¡¦²ª°»´ºÇÅäêêÿþþÿþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþÿýÿúþüÿÿÿÕÈÀÊÀ·¸¸¬±²¥«¬Ÿµ¸©²·©Äɽùüóÿÿÿþþûÿÿþþÿýþýÿþýÿþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþ­´³ÃÌËêñðþþþþþþþþþÿþþÿþþÿþþþþþþþþþþþþþþýýýüýýúüüüüþþþÿÿÿÿÜÝÝÏÏÎÎÌÊÚÙÙâãàÙÝÝÚòõ×üüœª°šª©‡˜“„ЀЂˆƒ‚…‚{„~‚†€…ƒ‚Ëåã”°­“‡—†™’Š¡—˜«¤£ ’¨¤Šž™†˜’ˆ‘„‡š‘™ª¡†•~†zŠy‹€sŒ€uŠu€l‹}hŠ|jˆ{h„{htmrt€rp|ogsgcviizmixjhwijxlivmo{ui{ss‰€u‡{r„vknm~qo€tmzqktmgvmc}pgwe{q`nfalb_j`[i^Yh]aoddrglzoozpnymdsfaqcgylizol~rizphylhvkipjbjc\e[^g[^i_dlbfnbeocbqd[n_Xi[YhZ]k]`oa\k]_n`cpbdqdcqe_mb_laama`nc_mb^labpfaocama`j]\dYZbXYcYYg\Yk^apbapbbl__i\`k^^h[^f\ah^bh]_f[fmdntostrtrpw{vz‚|~‡‹°¨©¹³³Ã½½© šŠ…ƒŠ…„ƒ€|‹‹†ŠŒ”–ÀÈÎØêí×èë|ˆŠ˜œœ”˜•‘š˜š”ƒ‘‰~‹ƒ{Šƒ}‹…€‹Ž›š‚މ–•®»ºœ›q~{m{v„“‹‡އ€‰Œ•“–¡›‘™“‡‹‰‘‹‹“‹Ž˜““——¡›¡«£­µ®¶¿¸»ÈÆëòñÿÿÿÿþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþúþüýþûîèâ¼¶®ññéïñèÒÓɺ»­·¹«¶¹­¾À¶ëéßÿÿùÿþûÿÿýþýÿüþÿþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþª±¯¾ÈÇèïîþþþüþþÿÿÿÿþþþþþûýýùýüûþýüþþþþþûýüñõôùþýôøùÝããÁÆÅµ»º»¿¾¿ÂÀ¿¿¿«¯«¥¬©ãüüÑõö¡°µ˜¦¤Š™•ƒˆ~Œƒ~ˆ}…~w…yx‚y}ƒ~~€•ŸžëûûªÉÇ€—“Ž Œ¢š•¬¥–¬§²ÉƦ¢ŒŸ›„›’‚•‹‚“‡Œœ“¨¶¯§´®z†€zŠ‚‡vŽxyƒsƒlŠ}l‡zj‚zjuotpqo|ohvjgzmj|mjykm{oo{ro|tk}yž·²±ÊÄs…~v„xp{mn~qm}pmwoipigume~rg~ubul_mb]h]Zf\\j^^pbfthfthlymmwmitjfqdfrfkwkq|rnzqjvogxlguldogaib^h_`kaambfndhpefnccqeYm][k]Zk][l^`oa`oaapbfschuigujbpecpfama\la]la_mbanceoeambak^[eXXcXYe[]lb^pd_pcboa_i]`i\^gZ[eX_g^_e\ae[cg^gmelsmrusuvqvzsvvx€y‹Ž‰°®®¡¤¢“–•—•”˜–“‰ˆ„„„€ˆ€‡‰‹““¼ÄÇæøúéûü”££|‚Œ‘…Œ‡Ž—”’›—ˆ’Œ…‘‹Œ†„‘Œ†˜—ÌßÝÃÖÕ¤¹º±ÅÆ–ªª»ÆÈ¼ÈÈœ—„’Œ‰‚‰‰“ˆ“‹“މ’ŠŒ”˜‘˜“•Ÿ™›¦Ÿ£­§ª´®¶¾º»ÇÅèïîþÿÿÿþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþýþþüþþþÿýþýûôòïúüöýþ÷ÿÿÿææÛ®®¢ÈɼÅȼÊȽåäÛ÷ôñüûûþþþüþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþ¦¬«·ÁÀ×ßÝúüùýÿÿþýýÿÿÿûüûôüúê÷ôóúùõúùéëëÙÞÝÑÙØÓßݸÂíº¸®¹¸­¹·¬¶³®µ²«®®®¹´ùÿýðþþÐèꊚ’Ÿœ†•‘ˆ€‚~‹{‡~u„xr‚x|†€‰‹ƒŒŠ¶ÇÞµ¶£¢ ´°¤»¶š¯«´ÅÀÏé媻¸œ¬©§Ÿ‹ –‹˜’‘“• š• ›„ƒ’Œ‰{„‚”ˆƒ–‰z“‡tŽq†znxrƒxv†yt„wm~ql|pj~qm~qp~qu€ss~st}uu…€Þòï±ËÇo„uƒyq}po}ojyngtlhskjyqh}tmrgvkcod_j]\j]Zk^^o`fueguhiwkjvifrfdqfishnwnu}sp{qlxnhyniwnfqjcng`md_odcrggqgkpfiqfere^pb^oa^oabqcaoaboadoagudiwkdskbqj^kb\i]\l_^k``k`bme\k`[ja\l\]k^Yf[[ia\lc\pc^m``l_]dYae[^cY\cY^f_ah_`e]djaflggmhipmptnsyot}rv~u€„„…„„ŠŠ~‡‡“š™Ž”’„Œ‰ƒ‹…‡||†‚ƒ‰‡ÏÖÕõÿÿìúù{‰ˆŒ•”‹•”£³°¢©¦•›™‹”…މ‚І‡Ž‹°»¹Ûê覺»¹ÏÏìÿÿðÿÿÕÞáž©«“žœ•Ÿ›˜‘†’‹Š“‡‹ˆ“‹˜œ•œ“”œ”˜¡š§¡£®©ª·´¸ÅÂÆÓÑêñðþÿÿÿþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþýþþÿþþÿýÿüýýüþüýýûýþûÿÿúñíæÕÔÉÕÕÊäèÞîïäÿÿùÿýüýýþþýÿþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþ¤ª©³¼»ÅÎÉÝÝÙíîîýýýþþþúþþíúøÝïìÛåäÑØ×ÊÎÍÈÏÎÄÐεÆÂ¶ÈǰÂÁª¼¸¦¶´¤²¯ ¬©Ÿ£¥¸ÇÃùÿûúüüüÿÿ°®‘š†“Œ„€…y‰~v…{z€yux‡•Žš”„‘Ž ´°­ÀÀ»Í͸Í˯È•¨£¨±°ÃÝ×½ÎÊ›ª¦œ²¬—«¦š–š‘…ˆ~†‚†’˜¦¢€’‹€’ˆˆ—Œˆ˜˜‹wƒs‡zrxv…y}‹y‹~qƒulto€uqvtsw€twtxwŠ‘ŒêøöÒèæh€{•q…zp|nhwlctkhwol{tlun|qgsgak^_j]]l]\n^asafueeuefueiugfsfarhetkjxmmzpn}qfxjj{peskcoifsleqjbrgbrggqgjqfksggsh_rcbseevgdtfereeobeoacragvjdsk\kdVd\ZfZ`obdqfdoebme`mg\ld[n^\obYi^Yh`Zlc[oc_oc^j^]cZ`cZ_bZ_f^_gaaiabi_elchnignhirnpwov}sy„v{ƒz‚}ˆ‡†Œ“’µÁêµ¶ƒŒ}Іƒ‘zƒ|…„ŽŒ±´´ÿÿÿõüüŠ’“…Œª¶·¦··Ž—’“𗇋…Šˆˆ‹‰…‡†¤¦¦Ñ××ÈÓÓæ÷÷èøùéøù×Þ墩­ž§¦¥®ªˆ‹Š’…‘‹…‘‹ˆ–Ž•” —ž”—Ÿ•𤛩££±­®½»È×Õõÿÿêñðüýýÿþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþÿýÿýÿÿýÿûýþüþþýûúþûýÿýüþúö÷ôíéêà÷úòõùðøûöûýþÿþÿþýÿþÿýþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþ¢¦¡²¶±ÀÿÌÐÎÓÜÛïöõûþþýþþôþüÙîëÍßßÁÒÑ»ËÊ»ËÊÀÔÒÄÙ×ä÷ø¦¿½¦½¼¥·´Ÿ¬ª™¦¤ž¦£·¼¸íìééèçÈËË|‚…•‰Š†ŠŠƒy„~r€zuyw€zŸ¦¤§µ³œ©¨³¿¾¿Ùұų¿½œ¦ž˜—”—”£®§¼ÇÀ¬µ²£®«–¢›¨¢Ž“†‹„…†ž®¦§»´…•“~”Œƒ“‹ƒ“‰}’‡x„q‡~r†yy‹~~|Š~u„xr‚wtƒtv…uw‚tu}rw}sƒ‡’‘›ŸžŒ›š›¶²‘«§h~wp}qjynhwmi}sk|rk|slzoepd^i]]k]^l]dn^apbfrfgrggshfuidvhduhixkiwkhthkwkp{oh{pdtidsgjxmfwkathcsfeshbpgcphcsh`qegugizofxncsicpedm`grhgujeuj[l_YcW_fZipegpdfndephapg_me[k`_mb`mb^j`alb`mb_i]]eZ^bYbbZ``Zcd_aj`ek`hk`glbirhivojxqo{ryv€ˆ}zˆ{z‰€z‡ƒŸ¯®±ÁÀ‰”“”œœ‰–”‚Ž}‰†yƒ}…}މ¤œœ®©¥»º¸‘“““—™·¾½­µµ™Ÿ—œ›–›™“Œƒ‹„ƒŠƒ’Š››—ª©¨ÚÖÕèääíèæ ›œ™™¯°®©®«†‰Š”ŽŠ•Œ‰”Œ—˜¡™–Ÿ˜•–š¢›œ§Ÿ¡¬¥§²®´Á½çñððóñØÚØÿþýÿþþÿþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþýýýýýýýýÿþþÿýÿÿþÿÿÿÿüüüûúúüýýþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþ›¢§±«¬»¶¹ÊÆ×âáëôòúþþÿþþúþþîüúÊßݹÍ˸ÈǾÍÌÑáàñþþóÿÿÌàà¬ÂÀ¡³±›¨¦™§¤ž¨¤§¬©œŸšƒˆ‰—˜Œ•‡‘‹€‹…|‰ƒx…uƒ}r~w}„~‡ˆ“˜Š”š¡žêþ÷ÅØÔ’¡œ“ –““—’—ž—•—‹”‘Žœ˜šª¦­¿¸‰”‹}†}œ¬£ÂØÏ®ÈÄ›˜—}‡|„z‘…v‚v‹‚w‹€xŠ~xŠ}zŠ}w‡{u…{s„wv…yuƒwusu~s„Œ“Œ£¥ŸÏØÔñÿý·ÉÄk}up}qkznmrr‚xo€vn~ufxmbpe`maZm^`qberbasearedsgcrgbrf`rcfvihxkjzmhxlkzom}qj{qhxmeujixohxnbtkath_qg_rhasiatgZn_gwjhzmhzoevkaoccl`fpfhujfvk\m`WeY_j^cla`k``k_amb_ma\h\\j__mb^la`lablb_j`[eY]dY]bY_aY_a[ae_clcgodelaembithl|rv‚zy‚v€†}…‹€ˆ~†ˆ†»ËǺÈÇŒ––œ¤¤€Œ‰´¿ÂƒŽx‚|††‡Š††‡~†ˆ”—”§®«†Š—– ¨§ ©§‰’Ž™”¡«§Ÿ¥™˜¡¤¢¬«ª˜”’’ŒŠ—“’ަ§£“˜’Š‘‹Š’Œ––‘™’–ž—™¡šš£œœ¨¡¬¤¥°©­µ°½ÅÁèðîçêéÌÍÌüüüþýýþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþÿÿÿþþþþþþþþþÿþþÿþþÿþþþþþýýýþþþýýýþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþ˜ › ¬¦©¸µ¶ÉÅÏÝÛãîìøüüÿþþûýüùÿÿÊäâ·ÌË´ÅÄºÇÆåîî÷ÿÿøýÿãòò±ÆÇ¢´²™¦¤–¤ ›¦£›¤Ÿ˜ š”›—“œ™’œ›Š•‘‰•‚Š{‰ƒ}‹…y‡xƒ}}ƒ}…}‡†…‹‚¡¢šë÷ðÀÌÆ‹—“ž“‘œ—“•Ž˜“—¤ ª¹¶›«¦¡±¬Š–Œxw´Å¸òÿÿÅæß–³°ƒ–y‡z„y„u‚yƒz…z{€}€zŠy‰€t†}vˆu†}tƒwu€s{…xˆ{’•‹§¨¢µ½¸‰—‘p~xnznl|om€rt…yotk}peyleshanb`rdasddrdbrdesgeqgdpedqdfseetdhwjm~qk}pj}ri|sl|qnto€wl}tl|ugwpbtk_qh\me`qf`rdZn]ethizmgymewkbqdamadmdgtidti\oa\m`[l_\i^[h][h\^gZ[eY\eX]g^bodbpebpe`mb]h^]gZ]fZ\bX_c[be^ag`bngfpgepeepfkzou†z|‰‚{‡~„…ˆˆ†Ž‡…‡™¡ž¯½¹x†…‡’’œ¤¥©±°­¶¹t~||†€~†~ƒyƒ„‡„ˆ†ˆ‰Œ“Ž–‹’Œš˜ÆÒа½»‰–”ÚçæÔâߨ³¬–ž˜•š˜šœ›˜—•š–’˜•“‘‹”•Ž“‹‡”Š˜‘‘™’”œ•”•”Ÿ—›¦ž¡¬¢¡­¤¨±ª±º³¾Ä¿ÐÖÑÑØÕÕØ×ýþýýýýþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþÿýýÿýýÿþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþ—ž˜Ÿ¦¤­µ´·ÁÂÀÐÍËÙ×ñ÷õþüýýýýýÿÿÀÛÖ°ÉĶɯ²¿¼úþþûÿþúþÿîüü±ÇÈœ¯¯—¥¢–¢›“ž›’ž™™“‹–‘‰”“†‘†“Œ†’€Žˆ{‰ƒ„’Œ}‹…{†€~…}~„y|„y„ˆ}’‘ˆŽ”‰šž™•š“Ž–ŠŠ“†‘—’£š¿ÐÊŸ¯­¿ÍÊ­¸¶Ž˜•Š”Šˆ‘‡°·®¼ÎŘ®©”«§‚˜‘yŽ…xŽƒw‘„rŒyŒƒ{‡|‘‡€‘†}Žƒ|Ž„z„s‡‚vІx‹†u‡€u„xx„t{„xƒyƒ}qytjvomztn{pptrƒyr†znth{mgxohtjfshgvjfugitghtgdpdeoefoeiqfiqegvehxjj|oi{nh}rg|rl|qpvqwn€wm~tizqgvmbpi`me_la^k_^l\bqefwjgxjizldsgbpefqedqeevi`qf^odZlaZj_[k_ZfZXbTYaUYaTdmahthbsf`qd_l`[h\`k]`i]dj_hmcdlcfmfdrfgukftlftlns{Ž‚‰{Š…w‡‚u†}Š…“‘§°¯¡±¯ÎÞÝ~‹Š ¨¦ÄÊÉÊÒÒp{xx„~Š‚{„z~…|Š€†‘‰†‰„‡Œ“‹“Š—¢ŸÁÎÌ”¢ ¦¶´ðýú´¿½¡­¦š–”›˜–›™”—‘•–‘’”Žˆ‹Ž‡‘ˆ‹‡Ž”ŠŽ–”œ••œ•“Ÿ—˜£›œ§Ÿ¤®§§²ª¯·°¶½¸ÃÉÄËÒÍÎÕÒâçäýÿýþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþýÿÿþýüúøø÷óýüüýüþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþ™¢ŸŸ©¦ªµ³ºÆÇÉÚ×ÒãàÚäãúüüüþþûÿÿÍæã¶ÎʲžÉÇòöõÿþþùüüîüüºÔÔ’§§•¢ ’›–—”‰•‘„’Œ„“Œ†’ŽƒŠ‡ƒ‰€Œ†Œ‡—‘‡’Œ|Šƒ}‡~zƒxz„v…|……~†ˆŒŽŠ‰Žˆˆ†•‰“˜‘¥³¬áð뫾»œ®ª”¢Ÿ‘œ™œ”’™ ¥œš¦›¡˜®»·¡™{‹„{ƒuƒr€y„wŽ…|‘‡}’†‘†{…s‡~ƒ™•”¬¨™¯­}‘xˆvƒvxxƒŠ…¾ÇÃ{‹‡v†syp~ws„|yŒ‚wƒtŠmƒvl~vkzqjzoh{ni{nm|nmzmivjgujgvkjxlkxjn{nl|ol}pj|ogymh{npvqƒxjsjrm€sntl|pbpf[g_Ze]ak``k^brffvijzkhyieuhdsgbrfbrectfcti_rfZoc\l`]l``la^h\ZbX^eZenckwkgwjbsf_l`[g[_l^cl_enbgodfoedoegthiwlhwnkzst„|„–Ž‹xˆ†¶ÊÊÔèæ¢¸¸”§¨´ÀÁàóò«¿¿q~}’š—“Ž–‘v|x„~ˆ•z…~}†~~‰‚ƒŠ¡®©µÀ¼˜’•©³±ÔàÞ¾ËÈ·Á¿ÔÙÖ¿Â¾š¤ž—“™ ”™—“™’–Ž‹ŠŠŠ‹‘ЋВ‹‘•ŒŽ•”›””œ•”Ÿ—˜£›œ©¡¤®©ª´¯²¼¸¼Ã¿ÆÎÊÅÎÊÍÖÓêñîüÿýþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþÿþÿþþýÿÿúññìüûúÿþÿþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþ—¡Ÿœ«§»ÑÏ´ÎÍÇÚ×ÎáÞáîìúþþûþþ÷þýÜõðÆÝÙ±ÄÁ¶ÂÀæêéÿÿÿùýýîÿþÝö÷‹¡¡“ Ÿ—’‹”‘‡”…”Œ„’‹„‘ЄЂŒ†€Š„Œ–‘œ–~ˆ‰ƒx‡y…|y„xv‚vz‚z€‚~†}„ЇƒŽˆ‚†š”—»À¼Ùáà Ïáß¹ÌÊž´°‘£™’’™’›‘• –™¢š„’Œ†|Ž„uƒsŽxŒƒwŽ…y‡€”‰•‰•Œ¯Æ½ÄÝØÑê祿½‹¡œ}†{‡||ƒ€— žÍÝÜ™°¬j{u„}u„€{‡–Ž€˜{’ˆvŽƒoˆ~nƒzo„xiƒvj„vnso‚sk~qg}qi€si€ri~okymn}qmrj|oewjj{nq‚xo‚vhqjrn‚qr…ug{o\pcVg]`ogfti_m`_pdgwjjziiyhcuhasf`reareatfduj_qf]pe^mabqedpe]e^XaZZcZdlbhtgduhdwj_ob`j_^j[ak^ck`dla_i_`kaivglxlm|tr€{~‰˜§¤•”‹˜™ßðóíÿÿ¿ÓÖ½ÑÔ°ÀÃõÿÿÆÝÞ±À¾‘™”ƒŠƒz„z‚ކžª¤“ ›s€z{‡ƒŒ‰‘›š¶Â¨§“žœ˜•œ£¢ÖßÞÈÒβ¹µ£¤Ÿ ›–›¡œÆÊÈ£¡šžœ›¢œ•“–’ŠŒ‹‘‹Ž•Ž––ޓ𓕖•œ––¡™›¦žŸ¬¤ª±°±¹·¹ÀÀ¾ÉÇÈÓÐäðíàêçð÷õûÿüþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþýÿþþüÿþúÿÿùþþüþýþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþž¥Ÿ¥±¬òÿÿÝõóØíêßðîðüúøþýúþýúþýòýÿØðñ«Å½ÇÅÊÊÆÅ˱´³ÑÙÙÇÔÔŠ›‰›˜‡—‘†“…“…•…”Œ˜•‡’„ކy…§¼³—¢„‹†z‡‚z‡}x†{tƒxsuw„x}‡|~‹ƒ‘ˆ…‘‹Š“’š–£­¨ÀÎÌ¸ÇÆÅÒÐøÿÿæøø²ÎΗ«¨Œœ”š‘œ““Œƒ—ˆ~’…~–‡y“…vŽ‚s‹v‚€•‹ƒ”ˆ™—»ÒÎÂÜØª¼¸ÕãàÏßᕪ¬ˆžš|ƒƒ‘ŠŽ‡‘–q€wv†~w‰€{‰‚‰”ŒŒ”†¢—ƒž”ƒ•u‡sŠ‚o†}o‰}m†zt‰}n†ymvnƒwk„xm…yj}qlxkn|nl|ogzmdxkhsn…yn…ym‚vk~sntq€ufzobqg]mb|‰~aqg_pdewhl{mmzlm}ofzlbyi^sgasheujgujcsfarebl`clacnd_i_ZbZ\`Y_h]doccpfdrfgshbm_^l_^j\_h[`i\bk^gpdgqdiwjp}py‚z—•™¥¥€‡‡±´´ùýýìøø´ÄÃÔââÜíïìüþ»ÈÌš§ªš¨¨ÅÕÒ‡›”|‡¥±«…Šz…}}‡…©®­ÈËȺ»¹˜›š‘–•Ÿ¤¨øÿÿÎÜݦ´´«´³œ ž«³±ÃÊÉ §¦«´±–Ÿ›•žš’š–––’™Ž’›’“›••–™¡›•Ÿ—˜£›žª¢¤±©°·²¸Ä¾¾ÊÅÇÑÎÚáÞúþüüýýýýýþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþÿþþÿþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþ—¡œÃÌÈüÿÿ÷þþöÿþúÿÿûþýþþþÿþþþþþôþÿÜóò¬ÅøÅô»¶¬¶­²¶¶Ÿ¨¦‰—•‡š–„–‘ƒ”ƒ‘‹ƒ“Œ…–‰š’—¨¡š”Š”†˜®¦Ÿª¢„‹ƒ~Š€~ˆ{ˆzˆ~z†}|†|ˆ}‚„‘‡Œ–’›˜œ¥¡ÁÌÆîööãììõþýöüûóÿÿÏåæ©¼¹Žž—œ‘›“œ“†—Š…’†ƒ“‡”†~“†|„wŒ€y‘……™…“·ÈÅÏáÞèýûŸ£³¯ÈÜÛÇÞà™²¯–¨Š™{‰x†}|ˆ‚x‡€zŒ„ƒ’‘ž˜™«¢Œ§Ÿ•®¨‹ œ|•Žx†tŠq‹€oŠ|sŠ~sŠ~s„yq…yp‡zl„xk}rmzmivijxliymjzoput‰}r‡{n‚vl€tm€tlsf{obrgfvkŠ—Œixmaqegwjo}orqu‚tnri}ne|nexjfxjfsheqgeqfckaaj_\g]\dZYaWZ`W]fZ`j^`la`nd[h^ZgZbmb]h\bj_ej`ckafodmrhpvl~ƒzƒ„‘”’§¨ˆ——µº¼úúûÿÿÿ¸»¼ÓÖ×ôø÷ôùúÁÈɯººÂÐÎÕé䜕“ šž©¤~†€z„|z…}“’—“””šœ—‘–’“™˜›££íö÷ùÿÿí÷÷ÁÎͧ²±ÏÛÙÍÙ×»ÇÅ«µ²¿ÈÅ·À½—¥¢—¤ž’›•—Ÿ–¥ž¨¯ª²¸²˜ ™›¢œœ§Ÿ¡®¦©·¯µÁ»ÀÌÅÊÕÑÛâßòöõýÿþýýýþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþ ¯«ÆÏÌÿÿÿþýüþþþÿþþÿüýÿüýÿþþýþýôþÿåùú»ÓÓ±ÃÀ«ºµ§·¯¦¯¬™¥£“¢ ˆ™•ƒ”Ž„•Œ…”Œƒ•Œ„—‹ž•œ¯¦’¢™€„–‘ˆ–‘„‘ˆƒŽ…|Š~€ˆ‚z…~~‡|†€‡€‚‰‚ƒŒ‚‰“‹‘š–œ¥¢¨±®àêçûÿÿúþþûþýüþýßèéÏãäÂ×Ô¯©Ÿ“Ž›“Ž”‡š†“‡†•ˆ”ˆ•‰z‘…{„~“Šƒ•Ž“¤ ãñï´ÆÃ—¨¥•”ÙãáðÿÿÐæé˜¬¬‹š“Ÿ”w…}}Š‚‹…މ’ŽŽŸœ–¥¡˜¨£Õéæ¼ÑБ§§ƒ™•|‰y†tŽ„qŽƒtƒvŒ€t…zv‡|p†zlƒwnuizmevkewlgxmo€uq€xs„yu†{p„xluj~rh}qgxm`qf`oddrgapedthftfm{nw‚wx„xp€tmqg~oexjhxjgsgeogbnebibah`]e[YaWY_U]aV\fWbk_dne]jc{ˆ‚Œš“clcglcdi`hndgpeiqfosmwzt††Œ‰…‡‹Š“¡ž¶ÇÊØÞàíçꮪ«››šŸœ®­«ÍÌË£¤¢®²±×ßÝìõóŽ––‘Š’~„yƒ{{†~‹Œ‰”—’ВЕޕÖÝØõùøùûúèíí²»»ºÇÇñýüÜéèáíìÄÏÌ¿ÉÆÅÏÌñüüž­©˜’Ÿ¥ §­¨µºµŸ£šŸ™¥žŸª¢¥³«­¾µ½ÊÃËÖÒéðíøüúûüüÿþþþþþÿÿÿþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþ©³±¿ÈÇòööüþüþþþþþþÿþþþþþüþþùýüèùùÝðñ£¼¼¤º¸ ¶± ¶®ž¬¦–¥Ÿžš†—’„–Ž„•Œ†”ˆ˜‹”¤›¤¶®‡š’¯ÆÄš­«Š—•}‡‚“Š’‡ƒŒ‰~ˆ„|ˆ‚z„~|‡€„‹„……•š¢Ÿ¦®«ºÃÀòù÷þüþþþÿþþþýüüÊÑÓª»¼ ´´”¦ Ž “œ•‰™‘‡š‡™Œ„˜‹•‰€—‹|–‹{”‹†™ˆ™”¬½ºÇØÕ·ÆÄ­¼º©¬ªñõóõÿÿçóó’ ŸŠ“{Š€|Š‚~‹‚ˆ„“Œ…—Ÿ®¬·ÅÁôüüöÿþãòò¡¸º†œ˜‚–‘{‘ˆy“‰v’ˆy‘ˆt‹€y‹vˆ}p‡{o†zn‚vhse}qe€sixmƒyp„{q‚wu†{s„ypug{pcwkcsh^nc^la\j_]k`_ndbpdhuiq~rr}sm{qhwmcxjexhjzigtfepeblfah_ai_]cY]cX]dX^eXak[ck_dmd`ic”ž˜oztqvnkofineinefoefrhntnv€y‡Žˆ~‚†‹¤³¯äðòèëîÛÙÛ»À¿¨³±¹ÇÄ¡©§¨­©›ž˜œ˜ª©¥ÉÇÓˆ‰ˆƒ}…€yz|ƒ|ƒ†€‰†ˆ„‰‘†Œ“‹˜Ÿ˜¿¾¸üøôóïìÛÖÖ¼¾¿ñøùàìéÏÚØ÷þþÎ×ÔåîëñøöÝç爎ž¢ž¦¨¡³³®¹·³¥©£¢œ¤ž¡­¤©·¯°Á¸ÆÑÎî÷ôúÿýüþþÿþþÿþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþ°¶·ÃÊÊþÿÿùÿþýþþþþþþþþüþþúþý÷ýüÞôòÃ×ÙÁØØÖïî¾ÙÔ¢¹³™«£’¢›œ–‰™‘…–ƒ”‰†“‹™“Šš“µÆ¿ºÌÄ¥µ¯ãÿÿ¬ÂÂŽŸœ±®Ÿµ¯‚—ƒ‰{ˆƒ{‰‚|‰‚}Š‚Œ……‘‡Œ—›£Ÿ«±°Ûàßüÿþþýÿýýþþþþýýýòùú×ë쟴³–ª¤’£™Ž–‡˜…šˆ‘…šŽ–Š~•‹~•Œ•‹š•Ÿ¯¬®Â¿ÉÜÛÊÝÛÃÓѳ¸³ÖØÑÑÓÏ¥¬«‘›Œ™‘‡•ŽŽ‡‹„‚‡‰™‡š¾ÊÈõÿüùýüüýþûÿÿÛïò†›‰ž—–}˜Š~—Ž}“Œy‘†{‘…wŒ€qŠ}oˆ{o…yhuiƒxh…zg„ziƒzlƒ{t†{uˆ}q‚wgxmcti`qf_pe]la^j`_i`\h^\j_brefuijynl{qiwoesldtigxiixgftccqd_mc`k__i]]dY^dY\dY\eY^jYaj\ekbkqi±¶°ˆˆuypnqhlofinehqgjtjqyntƒxŽž–¼Ç‘™”¸Â½ÿÿÿÚÞß®±²ºÄÄöÿÿûÿÿÂÐΜ¦£”š”–—ŠƒŒ‰ƒ‡‚~…€€ˆ‚‰„Š‚‡€‚†€…„ƒ„‡’‡‹“‹™—¸±ªÎÅÁ¢š–¡š—¤¡žÛØØåèçô÷÷úþþãèæ¢©¦÷ûúÙààŽ–“§ª¥¥¦Ÿ¦§Ÿ¦¦Ÿ ¦ŸŸ¦Ÿ¡©¢¦°©­»³»ÉÀÏØÖùÿýüýýþþþþþþþýþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþ­³³ÓÔØÿÿÿûþþþþþþþþÿþþÿþþüþþ÷þüçÿþÌâáÒèçèÿÿÕîíš±«˜«£ŒŸ˜Šš“†•ƒ•Šƒ“‰‹“Š–’¤²®°¿»œ«§ºÇÃãÿÿ º»˜¬­Òéè¼ØÔ‚™–‡•ކz‹ƒ|„‚„……”œ•—¡±·¶ìííÿÿþþþÿüþÿüþþûüýôþþêþþ¿ÖÔ™®©™«¢‘ šŠœ”…›ˆš„˜Œ€”‡€“‹‘ˆ|Œƒœ—¼ÍÉÕéçã÷öÕéçÆ×Ô±½µ¨®£œ– §¢Ž˜‘¤›“ œ„‹…Ž……–Š”¨›¼ÆÁýÿÿýýûÿýþúüÿâóõŠ¢¡ˆž™„œ“„„œ”ƒ—€›€—‹vo‰|oŠ}m„xx‹‚q‡~m‡|i‚ygxr‡tŠ€q…yi{ofvk\la^mb[k`Zj_^i_^i_^j`_mbctgewjiynn~ukyqguohvkjwjhvefudbrd^obapc_j]^f[^g[\eZZeZ]gX]fXcg\mney}ssynpsilndjncjpelvko{ozr{‰~½ÑÈ¥³­sxsª¬¨ÉÑбµµÂÉÉïøø÷üüÿþÿÉÓÖŒ•”–˜–ŒŒ‘‡‰Ž…‚‰ƒ~‡€‹…‰“‡Ž‡€†~€…‹‚‡—Œ‡”‰‰ˆ“•‘ž—’¢œ— ž™¥¤ž¥¤Ÿ§£¡ËÇÈøö÷þþþüýüÏÒÑÓØÕÑÝÚ°¹µ¨±ª ©ž¢©ž¢¨ž ¨¡¢ª£¦±©ªµ¬³¿·¿ÌÄÜâàþÿÿýýýþþþýþþýþÿþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþª·¹îóöÿÿÿÿþþÿþþýþþýþþÿþþýýýøþþÞñîÂÒϽÎÇèôï°¾¹œª¨—¦¢ š‡™’„–Œ„“Š…’‡‹•™¬¨×ôò”®­“Ÿœ®­§ÅÊÆ£­¨ÁÐÌâñ𘩥yˆ„‘†……„†……†ˆ“Œˆš”£š¡ª¤¹¾¼úûûüÿÿüÿþþÿýþÿýýÿýøýüøþþÔê㟵«©¼³—«¡Š”†›’‰š†—Ž‚•Œ‚“‰…’Š…‘ˆž§éíçúýüûÿÿõÿÿ¸ÉȵÀ¾œ¦£§Ÿ™¤–¡š– š™•†ˆ‚‡‘‰Š™’«¥½ÂÁòîïüÿÿÿÿÿýýýîþü˜¯®¢ž‹œ“Šž’£œ’Ÿž‰£š~—x„rˆw‚{‘†z’‹p‰i€vitq†}r‰€r‰}o„xk|qduj^qe\pd^od\i^_h^bka`kaaoeixigykl€smtk}on}mltlhuifwjduhdtgbmeama\i^]j__j`^e[`b\`f\ei`fgbjkfmqijqeinekqdjqdlsflvipzpt|q‡|ÀÁ¸ËÌĘœ™•œššŸ¡³·¸øýü÷üûúþýûþýßíêž™– ™‹•‹‰“Š„ŽˆƒŒ‚‚Ѕކ™‚…{…~…ƒ‡œ–ˆ‘‹‹‘‰‘ˆ•”˜˜”•™”› œ ¨££¬¨ääåÿÿÿüýÿ÷üûþÿÿÛßÞÈÈÅ´¶°¬°ª¥©£§«¤¨°¦¥®§¦°¨ª²«¯·°»Â»ÆÌÆíòðýÿÿýÿÿþþþÿþþÿþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþ´¼¿ôùúüýþÿÿýÿþþýþþýþþÿþþüýýõýüÔéèÉÝÚ»ÌÇ©º²š«¥Ÿ¯©–¤ ‹—†™’ƒ“Šƒ‘ˆ†’ˆŠ“ˆ¼ÉÄöÿÿÏàÞ—¢ž ¦Ÿ™“¥±¬•£ ŒyŽŠ‚˜’‚”Œ‚”‰ƒ“ˆ‚’ˆƒ”Œˆ›“Œ œ¢²­¨¦ÎÕÒúýýüþþýþþþþþÿþþþýýûþþùþýàñí®©¢±«™¨¡Žž–‰›‘Йބ”‰ƒ“ˆƒ”‰‚’‡‹–Œ›¢˜®±©º½¹ÆÊÈéòòÔã⟯°¨¸¶•¥ •¥‹™‘…’‹ƒ“Œ‰™‘„•Œ‡—Ž’ ™¯ºµÎÒÒõòóûþþþÿÿýýýñÿÿŸ´µž›–‹š”¥º¶“­­«£€™“wކu‹ƒw…}•Œ‹¢~“‹m‚wj~ruŠ€p†~q…yl€sk|qbvj]sh^tj^pd\k`blbakaandaqfmtikwkm}rlrh{ngyljumftiewjexkeui`mc^i^\i]^i__i_ah^ac]_g\eibgidikeknhhpehpgjrhnthouipxmt|sx€tƒx}u{~v‹Œ¥£ºÃÄúÿÿûþýðïïÎÊÊÿûúÃÉɘžœ”›•Œ”‹…‘‡Ž„‚‹‚€‰‚‚…„‡Šƒx†|ˆ€„Š‘ž˜ˆ”Žˆ‰ˆ‡ŠŽ‰“Ž”™”’˜“¤Ÿ ¦¡öùø÷ûúüþüýýýúûûÞÞÝÖØÕ²µ±¬°ª§­¦«±«ª³ª«´®­¶¯±¹²µ½¶¿Ç¿ÏÖÏöûúüÿþüþþþþþþþþÿþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþÂÅÆøùùþþþýþþÿþþýþþþþþÿþþûþþóüûÑçç¿ÔÓ»ÏË´ÄÀ¥¸°—¬¤’¢Ÿ‰›–ƒ”„”…’‹‹˜•ž’¤­¦ÇÑΜ¥¤Ž™•’Ÿ—Žž–³¿»¡¬ª“ ž¡³°‘©¢‹›“‡˜†—ކ˜ˆœ•†š“«ÂÀ¹ÊÉÌØ×úþþùüûûþûÿþþÿþþÿþþþþþýüüÿþþÎÜÜ“¡Ÿ“Ÿ•¡›‘ž•‹›ˆ•Šƒ“‡„–‰…•‰…•ˆŽšŽ™¡˜«²ª²·²›¢ ÅÏÎÀÏÏÙï𦻼˜­©‹Ÿ˜…–ކ—Žˆž–Ž¥œ‡œ’ž•˜¤ ·À½Úàßÿÿÿúþýþþþýüü÷ÿÿ­¾À–¢ •—™”ÕéèÇê롾º™•vˆv…wŽ…xމ˜®©m‚ym‚vtˆ||„p†{pƒtnsmtfyp_vm^vm`uh_qfcqfboeaqe`sfiqejullzqhxogwmfvjeujhxmfzng{oexl^nd`k_]i]_j`bka`h]ae_cladjaglcgkckqhjqgirklskmujoujsyqu|vvt|ƒy€†z‰Ž…Ž”ª³¯Øàßüÿÿùüüììì±®¯¾»º®´¶£¬ª•Ÿœ‹—…’ˆ‚„‚Œ…Œ„‚…€„}Š€|Š€‚›’Žœ–‹˜•…Œ†ŽŠ‡‘‹Ž•—’“˜“¢¦¡®¯«ñðêÿÿÿÿÿüÿþüóðïÌÊÊÈËÆ´¸³¬²­«²ª¯¶¯°·±®º±²¼´·¿¸»Ã¼ÅÍÅÖÜÖøûúüþþýÿÿþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþÌÏÏðîîÿÿÿüþþþþþýþþýþþÿþþûþÿéùõÃÕ×Ñââ»Íʮ½žµ­”¬£¡žŒœ˜ˆ—‘…“‰—‘›”“¡–•Ÿ—Š“˜•‘žšŒž•“¡–›¦¡¦¦¡¬¬ª¸µ¡µ­œ—Žœ•Ž•“£›“£žƒŽÞïîçõô÷þþúýýþþýþÿýÿþýÿÿÿþýüúø÷ËÉÈòññÒÜÛŽ›˜Ž˜”Œ–Œ˜‡•Š…“ˆƒ“†…–‰‡™ŒŠšŽž’–£˜¥°¦³»¶éóðæóñÌÞÞîÿÿÞóó§¼¹‡›”†™…—Ž™°¨‹¢™‰Ÿ•“¦Ÿ¢°«±¹¸ÒØ×ÿÿÿüþþýþþýüýøÿÿ¬»¼›§¥œ¢”––éøøÙúû“°¯…Ÿœ}”y‡y‰~”¤¸²n‚zq‚v}‚|‚r†zpsn€tn€wd{qbxm^vj^skarhcqfbpebsfcuhcujixnk{slwohsjjrhewlj|qi}qksfvk_qfbnbcobfoegpfck`cjcclbfndhmdiofirhlujlwomwnnwlpvkovnsysu~tyw‡}Š’‰‘˜“©²®ÔÙØþþÿûýýíòñ­·µ©¶µ¡³´•§§‰œ™„–‘‡”‹††‚އŒ„€…‚|Œ‚„…”‡“ ””¡š™’†Œ†Šˆ”ŒŠ—Ž—’™’¡¤ž¯®©·©£ÓĽãÙÑôïêÑÐÌÖÙØÂÇŶ½¸±¶±¯¶±³»´¶¿·¶Á»ºÂ¼½Ä¿ÀÇÂÉÏË×ÞØøøùüþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþËÍÌçäãÿÿÿüþþþþþûþþþþþÿþþüÿÿÙéæÁÐÏñþýîûû³ÇĨÀº”®¦¤ŸŒœ˜‹™•Š–“‰˜’“ œ–ª¤“¤¡–¦£•¤ ”¤ ˜”Ÿ•“ œ¤¶³§¸·–§¤ —‘š“¡›—¥Ÿ¨¶°›¨¥–¡ŸÔáßÐÙ×àããþýýÿÿÿÿÿÿöòïìêæêëææè䤦¡°²­¯½·’ž˜‰”‡‘ˆ……„‘…†•Š…–‹Šœ‹‘‹ž’ •—¤š›¦ÎÕÐøþýðûúóÿÿÑâá´Åá´®‰™’‰˜Š™’«½¶˜«¤”© œ±©©¸µ¾ËÊßæåÿÿÿûÿþüýýþýýöÿÿ²ÀÛ«ª–Ÿš¢ îóôéýýÍè苤¡}”|‘‰‚–ƒ–Ž¢wˆ€t„yzŒwˆ{otn€sr…zo„{i~ucylcxhcwmdtlerhdqfcsgdvicuhizol{sftlergivjj}pn€tk|sixpbsgasefsgmxlhpgfndfoeelegqgkshluiirflujkukoxnr{qs{pqznqzor{rv~wzƒx~‡}ˆ’ˆŽ˜‘¤®§¹¼ºùúúüýýíóò¹ÆÃÀÐÏ×åæÚëë«Á¿Å×Õ‹œ—‡•Œ…‘Œƒˆ€‡~Žƒ€„€‘„…‘ƒˆ’†™˜Š“Љ‘ˆ‡–Ž›“™’’™’¡¤ž±±«½³¯¶¬¦Áº±ÈĺÔÕÐÚáÞÝâàÈÎÌÄËÆ¿Ç½ÇÁ¾ÉÂÁËÅÂËÅÅÌÇÇÎÉÍÓÎßåàûûûþþþþþþþþþþþþýþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþ¿ÂÁÞÝÚù÷øüÿÿþþþûþþÿþþÿþþøÿýæöôíöõöþþñýÿãôò·ÏÌœ¸²’¦¡‘¡™™—‰–“›ª¦ªÂ¿¶´˜°¬™°ª—«¢”¦œ‘Ÿ•Œ¢›ÕíìÃÜÛ‹£ž•§ž”¥¡š¬¦¢¶®½ÎÈ¥³°¨§ÀÈÄÀÅÁ¾ßÜÙãÞÜÔÏη±­ÆÃ½ÆÈÁÏÕή¶¯¶½¶¤²¨Œ›ˆ’ˆƒŽ„„…Š˜‰™ˆ™Š”Šž–¡˜‹ž•™¡–œ¢šÜÝÙÿÿÿõúúüÿÿ©¶³™¦¢›©¢‰–Žš“Š—‘”¡š ™“¦žž²ª³ÆÃÜêêñúøýüüûþþýþþÿüýìùø´ÁĘ«©•¢œ£¡œ¼»ºïûû¥ÀÀˆ¡œ~”Œ}’…~…zŒ…{ˆu‡~tƒyu†xs…vn€rp„xr†~l‚zlxi}ofzhfypfumfrhepgdsffximwklwlhvlbti_uh^xjj}pm~rjzpetkbrfarekymnymhpehpfgoedofgshlwlpzlt}oq|qnzpqzps|pt|pt}qr}qtvvx|„{€‹‡”Š‘”š¥ŸÍÓÑÿÿÿÿþþüüüùüþøÿÿþÿÿúÿÿéùù¸ÎË‚–’…–‘‡”„’‚‘Š€…‚“‡ƒ†Ž†ŽˆŽƒ‰…Š‘†Œ”ˆˆ˜Žž–’œ”’˜‘›ž˜©«¥¶¿¹ÉÌžÀ¶ÃÄ»Õ×Ðîôðúÿþóú÷âéæÈÓÌÈÓÌÍÖÏÎØÒÏ×ÒÐ×ÒÎÕÐÓÚÔãêåÿþÿþþþýýýþþþüþþüþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþ½¿¿ÊÍÍëîìýÿýüÿýûþÿüþÿüýþüýþüýûüýüÿýþüþÿè÷öÎåâ­À¼—¥¡’ŸœŽœ˜Ž™–‹–“¯¸¶äúû½ÕÓ¢·´š°«ŠŸš”¨£™®«¶ÅÁêÿüÝõô—¯®œ«¨©º³¤³®²ÄÁßòð»ÏΚ¦¨»ÇÂÃÍǼ¾º½¸³¶²®¼¿¹·º¶¶¸·¯²±µ¹´¥ª¢¢©ž¦ž‰’Šƒ„ƒƒŽ…†”Š„•‰ˆ˜‹‘¡–˜ªž™¨Ÿ”œ••Ÿ˜£®£¸¼µÖÕÐÿÿÿüÿÿ®À¿™¤£—¤ …–‡–ˆ’Š–’›˜¡ž•£ŸÍÔÒôõôûúùþþþþþþþýÿ÷ùû×ää¾ËÇœ¨¤˜Ÿ™ ž™°°¬ÙãàÀÕ·ž—{’‰|”‹wŽ…y‡u„uˆ~t…zo‚wnuq‚tm…|rˆr†{p‚wn~so}ri{rdukctiexjdujdukm|pfxkeyk`tgbsfixkl{qlzoivjboc`obctfsonznfnhhohjrggocktlqxrq|vqyu„|q|rp|rrtxww€vwwvƒxz…~|Œ}„ƒ•Œž™š¦åîéÿþüÿýþÿþþýþýÿþýÿýüúýü÷ÿÿÇ×Ó‰œ”Œœ’‰˜„”‹‚‘‰€‘ˆ€ˆ}†ƒƒƒŒ‚ƒŒ‚ƒŒ‚††‹”ŠŠ—•Ÿ—™”™š –¤«ŸÍÓͳº³´»´ÁÅ¿äçæþÿÿûþýñöôåëèÏÖÔÓÝÚéôñåìêÚãàÚáßÑØÕØÝÛäêèýüýþþþÿÿÿþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþ¶¸·ÁÀÀãâáÿÿþýþüýþÿýþÿüýþýþþþÿþüþýÿþýúúûïø÷©¸µ¤°¬–¡Ÿš—Œ–”˜•™–—Ÿœ¬»»­½ºŸ¯«¢³°‘§¢Êßܬ¿¼¶Ã¿åóð¼ÒÒ“®¬©½¹¸ÉÇÏÙØî÷öôÿÿèöö•¡¢´ÀºÆÏʬ°«®«¥²±«®³­§«¦°´°§®ªŸ¦¡œ¦ž“ž“–‰“‡ƒƒŽ‚‚ƒ…“†Šš—§›š«¡•¥”˜—¢›Ÿ©¡ ¤ðîêýþýÿÿÿ–¦¥¦´²˜¦£‰™’…”ƒ‘ˆˆ‘Œ‹˜“Ÿš¡¯«±º·®±°ÔÐÏÿÿÿþþþûýþÕÝß²ÄÄ¡°¯”£ž•Ÿ—œž˜Ÿ¤ž ­§…”„›“~•–Ž|•‹y‘‡x‡u†}s„xt…yl€tm}qlyq‡~p„xn‚vo€um}rhxncsgfuhjxkguihwmgvkhylfwjevietggshhwlitjfrfcoccoccremxhluiksjkrkjqgiremvkt{sx{š¨ ‹›‘w€vtux‚xzƒyz†{yˆ}|‹€‹„€…€“†ƒ•‘žš›¥ÛßÛÿÿÿÿþþüþþüÿþþýüþýýþÿÿÁÌ˨¸µ–©¢ –‰˜ˆ—ƒ’Š‚“Š‚“Š‘‰ƒƒ‚‹‚‚‹†…†…ˆ’‡‹—’œ•“š‘•™˜”¥­¢ÔÛÕ²¹²¸¿·ÅËÇüþþûþþýÿýýÿýúýûéïëéïíùýûôú÷òøõóöôíñïêîìôøöýýýþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþ®¯¯¼¸¶ÒÍÌîêêÿÿýÿýüþýÿýüþõùøòøõùüûóöõýÿÿ·ÁÀ›˜›ª¥—¦£’ œ“ ”¢ž’Ÿœ¨µ±°¿¼’¡™§¢œ¬¥¬¿»çúøÁÓѤ®©³º¶åôóÓêéÚïëÉÙÙûÿÿüüÿøýýùÿÿœ¨¦«³­³¿¸¥­©¢¥ŸŸ¡›š¡š¡¥Ÿ¥ª¤¤Ÿ«¶°–£œˆ—‘‰“‰…ƒƒ€…‚Œ€ƒ…„”‰ž’›¬¢›¯¦˜ª¢”¡™˜£ Ÿ¨¢—›”ðíêýýú»À¿‹›š¡³±•¦¢‰˜”‡”ƒ’І“‹ˆ—ŽŒ›”³¾¼­µ±±¶µÈÃÂóòñýþþúþþæññ×ì릷´•§¢’¡š–ž—•Ÿ—’£œŒ£›…•™‘‚š’ˆ¡—š{’ˆ{Š‚x…}ounul{pj~up…}nƒxoƒwlsh{oiymgsfgremvilvjlxmhwofujesgdrfgqfeneeqgfqhepdfpdeqfeselvfltimujkriktikthnwky€u…†»ÉÁ|Œ‚z…{z…}{ƒ|yƒ|}ˆ€~„”‰„‘Š„€’„…”“˜ž¤žÁ½¹÷ôòÿýýüþþýýüÿÿÿÿüþ÷ùúËØØ¹Ëʘ­©£œ‹š’ˆ—‡–Ž…”Œ„“‹‚‘‰‚„Ž„„ƒ†…‰†‹‡–Œ”“”œ’“š‘›Ÿ—¢©Ÿ³»µ´¼µ·¿¸ãèäüÿÿùýþÿÿÿþýýûûûúûûüþþúýýüþþþþþÿÿÿýýýþþþþýýþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþª«©²®®Â¾¼ÚÖÒîììýüûÿýýýÿÿèïíÕàÝÒÓÏÂÇÅ¿ÌÉ•§¤³ËÆ¢Á¸¢º´š¯ª¤¶±¡±­Ž¡ÏáÞßøô¦Ÿ—¬¹´«¹´ºÉÆŸ°¬«±¬îîíôýýáóóìûúùÿÿüýþÿüüøûûÄÏË“ œ §¡ÄÏɪ¶°š ™•›•“›”™ž˜ž£ § ºÆÀœ©¥‡—’ƒ’ˆ‚…ƒ†ƒƒ‚„’‡…—Œ’¡˜”¥œ°Æ¾£·²™§¤¹Èئ££©¤¬©¥—–“ž¥£Óáá¼ÒÐ’¥¢œ—‰•…™†–މ——£¤±ª¬³±µ½º¶±®ùøøýÿÿûÿþòýýêþý¤¶´‘¥¡“¤ž“¡™•£›’¥œŠ¢š‡ž–ƒ›“…•’« „“|”Š}ކz‰s…|m€tntlxmƒzmƒwlƒwh~rj}rixkfqckrelsfjtkhukfyqhwncrfitheoddmcgpfkvlhthhthhuihsfktglthksihrhjujmymp{o}„z‘™’°¾µ‰š‘~Ž…Œ„~‰}‡~‹ƒ‘ˆŸ–ƒ‘Š„‚“†‡“‹”œ™ž¦ ·­«ØÌËÿüýÿþþÿþþ×ÐÏêèéûýÿõþþ ²°°¬”¦žŽž–Š˜ˆ—‡–Ž„“‹ˆƒ‘†Ž„†…Š“‰Œ’ˆ”‹Ž•‹š¡˜”œ’—Ÿ•›¡˜ª®¥´¼µ¶¿·ºÁºôøõùÿýýþÿÿþþÿþþþþþþþþþþþþþþÿþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþ£¦¤¨§¥¶´¯ÉÆÃÔÕÑôòòÿÿÿûÿþåñï½ÏÈÇÌÇÃÑ̽ÍʵÅÁØíèØõì·ÐË™®ª ±­Ÿ¯«˜«¦¼ÒÍÛïí”§¡Ž›“¬µ®¯·± ¬¥£³­«¯¨ðïëþÿÿåëëÎÒÎîîìÿþýÿÿÿÏÕÒ©¶±¥²¬–˜ÓßÙ»ÉÄœ¨ “›”‘š“•š”› šš¡›©´¬•¡œ…”Ž”‰‘…‚Ž‚‚Ž€ƒ‘……•‹‰˜“¡š®§àõðÂØÔ›®«Üñ𞱯¨¤¢¥¡¯³®ÕßÛõÿÿÛñðŠ¡žœ˜Žš”ˆž–Œ›–—˜¢œœ¤ž¢¬¥¬¶®·µ²ýÿüûýûüýý÷ýýîýü§·¶”©¦š®§›©¡–¦ž¤›Œ¢šŠ ˜Š ˜Ž¤œ™°¦Ž¥œ‚™‘€‘ЇuŠm„zr…{o‡}n†|p‡{m‚vi}qi{ogvihrflthishjyoi|tš¯ªk~uhxmjvihqfhpihtimxnesggvjitigtfkthkvijuijyll|pn~suƒwŠ“œ—‡–‘ƒ—‘ŒŸ˜ƒ’Š~‹ƒ}‰Ž†Š™‘š¬¢ˆ•€„ƒ‘…‰•–Ÿœœ¨ ¯­ª¼´²ßÖ×þýþÎÎͯ®­ÜÙØúýýôýü¨¸´¬»µ™¦ž“¡™Œ›“Œ›“‹—‡”Œ…‘‰‡‰ˆ‘ЇˆŠ’‹”ޕޕ˜Ž›¢™—Ÿ–™¡—œ¡›±´¯¹¿¸ºÀ¹ÆÌÅþÿûüþýþýÿþþþþþþþþþþþþþþþþþþÿþþÿþþþþþþþþþþþýþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþ¢ž¡¢ž«¬§¸º¶ÅÇÃäåãÿÿÿúÿÿÌÚØ«Âº´À»®Ã¼«½¹¯¸µºÃ¿¸É®½¢²®œª¦ ­ª®½¹¡³¯”›’˜“•—œŸ–˜ –ª ¢¯¨¹½´ÛÝÔÚÝÚ˜™—·°ªÑÊÆüøõóõðÇÔ͵Ľ¦²¬¡§¢²¾¹ªºµ›©¡¢­¥˜¢›”™••›•––•Ÿ—˜’ˆ”€–Œ€‘‡Ž‚ƒ†•‹‡šŒš““¡›±Â¼àöòÃÚ×±ÄÁçþþ·ÐÍž®«¥Ÿž¦¡ÔàÝôÿÿßöõ†Ÿ›™—¦²­§¾·Œš˜š§£š£ž›¢›§ž£°¤²³®ÉËÈùúùþþþôöõ¸Â¡±°ž³®®Áºš«¢œ­£‘¦¥œ¢š£š‘§ž˜¬£‘¨žˆ —„–Ž~‘ˆxŽ…oˆ~rˆq‹qŠqˆ|kul}rfxlgthgrfjsgmwmexo”®¨§À¼l€yn}qjxkjujdnflwmixmevigwjeuhgtfkujjujkxml|pp‚vs‡z|Œ‰“ŒŒ•‘Ž œ¼ÑΓ©¤†—„Œ„†”‹’ ˜–¥œƒŽ‡…†„‘…Š•˜¤Ÿž«£¬·±¿¾»ÉÀÂîîí¶»¹ÓÛÙÿÿÿüÿþâë飱­¬¹±Ÿ© ”£šŽ–Œœ”Ž›“‰–‡“Š‹“ŒŒ”‹“ŒŽ–—‘™‘•š•›‘—Ÿ•š¢˜¢§¡µ¸²³¸²¼À¹Àüõõòÿÿÿÿýþþþþþþþþþþþþþþþþþþþÿþþÿþþþþþþþþüþþüþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþ– ™žŸŸ¤¢¡«®©µ¼³ÇËÄÖÜÖßèá´Ã¼«»·©º±©¸°ª·°¥±«¥±«œ©£ ²«¥º±—®©¸ÌÆÉÝØ£¼· ­©›•ˆ“‰Œ•‹Ž•˜œ– ¨ ¬¯©¡¢š™˜­®¥®®¤±¬£¦Ÿ˜¦¦¢´½¼§·³¢±®¥¬§¢¨¢¢«£ ­¥½ÏÉ•«¥˜¢›–¢˜–Ÿ——Ÿ›Ž™•‰›’‡šŽ’…€’…‚”††•‹Œ™“Œœ”š«¥ÅÖÔäóðñùøÿÿÿúÿÿÚçæš®«›¨¥§ª¤»¾¸ìòñÑÛÙŒž—ޤµËÆ­ÃÀŽž™—¥ —£˜£¥ž¡¨¡©¬£¶¸¯ääßããß›¡œ£®©§³°°Á½²ÈÄÄÜÙ¢¸¸˜¬¬‘§¢•§£•¦£—ª¦œ³­–®©’¬¨…Ÿ™}–s‘ˆpŒ‚r„n†oŠp†|p€uo}pozmkwlgukfwmj|ol{q¶À¾½ÔÑq‚p}uoynkvjjwjkvllynjznizmkxkoyljypjxqm|uq€yu†~|„•ŽŒœ˜ÀÎÌùÿÿÐà߆œœŠž•„“„Š‹•š¤ž—¡›†‘ˆ„ˆ‡‘Љ–‘š©¢§¹±³¼º¤¬ª¼ÁÁËÏϾÄÅôúúüüýöýý¼ÊÆ®ºµ ­§ž°§—¥ •¢ž”œ—‘™“ޔޖ™Ž‘™Ž‘™‘™‘’œ””Ÿ—•¡•• ”š¤˜ž¦œ¤¬¢¬´¬±µ°¾¿ºÌÉÄÞÙÔýûøÿþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþ“œ–—™šžœ›£¨¡ª²¬²¹³¿ÈÁ³À¸¨¸±¤¶®Ÿ²ª¡´¬¥¶¯Ÿ®©Ÿ®ª£±®Ÿ³®¤º¶œ±¬Óãßàî럱¬’ŸšŽš“†‘‡‰‘‡Š’‰•Ž•œ•šŸ™˜œ”¡¥œ¢¦ ¥›¤©§¨ ÐÔÐîùøÎàݹÈŧ·°Ÿª¤•œ–˜¢žÙëéÈàÝ‹™–Ÿ¨¡Ÿ¬¥š°¬‹ ›–ˆ›’ƒ—‹ƒ”ˆ„–Љ˜Ž›•Ÿ–§¶±ÐÝÛöÿÿøþýüýýûÿþëùø®ÄÁ–¦¢Ÿ¦ ¬¬§´¶³–œ˜›¥Ÿ™¦Ÿ·Ä¿¶ÂÁ‘™”¢ž˜£Ÿœ¨¡©¢ ¬¤¦®¦°¶°­±«¤©¥´½º°½»®½¹»ÉÆìúùðÿÿÉÞÝ­ÄÄœ´¯–«§—¬¨œ±­š³®¡¾¸›·³‹¨¢}™”x“Šv‘‡u†p€q‹p†znto~sn|pk{mk{ok{pm~pr€u˜•™«¨qzp{qs{pkwkjvjmyol|ql~qm~qo~qoqm~tlurƒ{s„}yŠƒ€‘‹ˆš—¯½»øÿÿòûüîüü‹žž•¥ œ•‡“‡’Œˆ“†’ŒŽ†„‡ˆ’ŒŽš” ¯©®À¸·ÇúÈÄÁËÉÁÉÈÃÊÊõûúÿþþ÷üü±¿»ª·´·È¬Á»¢´°˜§¤“Ÿ™’›–™“Œ™‘•Ÿ”– –”ž–“ ˜˜¤œ˜£™¤˜š¥›Ÿ§Ÿ¡¨ ¦­¦­±¬¶¼·ÄÈÂÈÊÄÚØÒ÷õóÿÿýþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþ‘›”—š˜™™—œ¢›ž©¥©µ®­º´¬½´£¶­³§œ±©¡¹°£¹³ž³®¡¶±¢³®´ÉƸÑÌ«À»£±­– ”Ÿœ›“‹˜†‘‰Š”Œ•”“œ’— –•ž”˜ –™¢˜™£™™¦›¡§Ÿäéåõþýóÿþïùù­Å¿¢±«›£Ÿš¡ é÷÷âùúž®¯œ¡Ÿ³Á½Ðñí—º´š¥ž‹Ÿ–ƒ—Ž„•Œ…–ˆ—‘›•˜¥°»·óúùùþýüþýÿþþüþüñþý¶ÐÌ¥Ÿ§Ÿ¡£¡¥ŸŸ¥Ÿ§°©¥¯©ž§¢¥Ÿš¤¢š¤¡ª§œª¥–¥¡¢°¬¤²«¦±«¬´±¼ÈŬ½º°Ä²¿ÄÍÌùÿþöýýñÿþÐèæž¶³œ³±œ±¯ž´²²ÉÈËçä£Ã¾¬§…Ÿšw”Š}–w†rŒsŠp…yq‚wm~smul}npuottƒuy†y|…€x„}uvqyor{ooznkxll}po€sn€sp‚uotq‚vqˆzt‰}vƒxŠ‚~І˜”•¦¢ÞççûÿþúýýôýþŠ››¤´­“¡›‹—‘‡”‡‡ƒˆ†“ŠŒ–’ž—«¹³®¼µ½Ð̽ÍÉËÕÒÃÈÆÂÆÅäçæüûùÃÊΏµ¼ÊÆíûùÜñîºÎÉž¯¬™©¢“ š—’Ÿ–—¥ž•£›”£›–¥™§¡›¨¢ ©£Ÿ©£Ÿ©£¡«¥¨®©³·²¾Æ¿ÄËÄÅÉÃÚÝ×ùú÷þþýþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþ‘š•”—––˜•™¡—Ÿª¦§µ¯§¸±¥¹°¢¸­Ÿµªž³¬Ÿ¶®¡¹±Ÿ¶±¨½·ÂÕÐïþýÖìè¯Åê¹´¡ª§—¢žŽ›“‰–ˆ“‹Œ—‘š“–™– –” •“ •’ –’ –™§›¨¬¤ååàþÿýùüüüþþØñ쟰¬¦££«©öÿÿäö÷´ÃÅ› ŸÍØÖâÿÿ¹ØÔž©¥ŽŸ–…–Œ„”Œˆ•ˆ–›•™¥°¹´÷ûûûýýþþþÿþþþþüøÿÿÍâߌŸ™›§Ÿ˜Ÿ˜•Ÿ˜˜¥œŸ­§«¥«¥¢¯©¥±® ¯«¥µ±¢³°¾Ð͹Îʤ´­§´°¯¾º¶ÄÁ±Ä°ÆÅ°Â¿ÐÙØÿþþýþþóýýéüû¸ÐΠ´²Ÿ¯®ËÝÜïÿÿòÿÿ§Éš~š”}—Žz“‹s‹€t‹r‡zqvmuk~tpƒtr‚xs‚{x†zހޅ|…}u}uq{qt~to|qn|po€snrp‚un€so‚up…xq‹}w‚|‘‡“Š’¤›•¦¡¯½¼ò÷öÿþýÿÿþï÷öšªª¦µ±“£œ‰–…’‹ƒ“‹…–Œ„’Šˆ–‘œ•—¡›¸Ã½ÔàÚäñî¼ÇüÁ¾º»¸ÂÁ¼ÝÛ×ÞßۺýÈÖÑòþûïüûÙëè±ÅÀ§¼·¥¸±ž­§—¤Ÿš¨ ›¬£œ®¥ž¯§Ÿ¯¨¨¸±¬¥¡«¥ ¬¦¡­§¦°ª­´®¸½¸ÃÌÄÆÏÇÊÒËÕÝÕùüùþþÿþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþ›”•š™–˜”š¡—£²ª«º´¥¹°¥º±¡¶­ ³«¥¸®¢¸­¢º±§½´ºÌÄðü÷óÿþàòñµËÈ·ËȬ½¹¯¨”£–œ’‰•Œ–‘š“Œ—˜‘›‘“¡–’¡— ˜“¢š˜¦ž«¬§ÊÄ¿ÿþüýüûüüýëüû­½º‘šÆÎÌÿÿÿ¦¯®¹Åű¹¶ßèæñÿÿÊÞÝŽš–‰˜‡•Ї”‹‡•Žš‘“™§Ÿ­µ±÷úùýýýÿþþýþþþýüîôóÂÎ̉•‘” ™ž–”¢–š¨¡®« ±­¦·´­¼¹¦·³¦·µª¾»µËÉíÿÿºÒÏŸ°©®¼¶«¸³¬»¸­¿½¸ÎËÇ×ÖÛãâÿÿÿÿýþúþýöÿÿËàÞ™¨§¶ÁÁûÿÿòúú÷ÿÿ¸×Õ¯ªˆ¦¡„Ÿ™€›’z”Œz’‡t‹€s‡{t…zs…yq„wr…xs‚{u„|Ž‚¡”ˆ“}Šƒq~wqxv…|qupƒto€sr‚uq€tq‚uo‚vrˆ|wƒ€–Š‚—Š‡šª»´—§ŸÒâàÆÍÉîíèÿÿÿáéæ«½»›®©‘£žŠ™“‰–ކ•Œˆ˜Šš’Žœ”•Ÿ™Ÿ¦¡¶¿¹ÆÏÉçïì¶½¹«®¨°°¬µ¶±»¼·¾ÄÀÃÏÊàíêõýúùÿþðø÷ËÜÙÁÕѰަ·°ž«¥©¡°§µÈ¿¾ÎȱÁ¹´Ã¾ ¯©«µ¯¨³¬¥³¬©µ®°¹±¼Á¹ÄÌÃÈÑÆÏØÏÜãÜûüûÿþÿþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþ‘—”™–•™”˜ •ž­¢¥¶¬¡¶­¢·¯¢µ®¦¶°¨¸®¨»¯ªÀ´°Å¹ÁÒÉÖâÛúÿÿÑàà¾ÖÑÈÞÛ¶ÍÈ¡»²œªŸ•£šŽš”Žš”Œ—Š••Š‘›‘ •‘¡—‘¢š”£›”¦¨®¦ÉÅÀóñìÿÿÿûýýòÿÿ»ÇÆ›˜¼ÅÀ×Üט™—¼Ä𺶴¼¹ÐÖ×´¾¿ˆ—”†“………Š”ŒŒ–ŽŒ——¤˜œ«¤­¶±úûûýüüÿþþûýýòôò¾Ä¢¢”™•Ž™’‹ž•™¥œš§¡±¿½»ËÊ¥¶´¾Î˾ÓЯÅÂ´ÊÆßôóïÿÿ¹ÓÑ£´«²À¹©¶°¥´°¼ÏËÈÞÛÑßÞãééþÿÿÿþþýüüÿÿÿ×èæ£°®ËÑÐÿÿÿûûûÿÿÿ©ÆÄ—¶³‰©£‡¤žƒŸ—{˜Ž{“‹w…xŒ‚vˆ}wˆ{x‹}w‰~u†€zˆ…‚”›²¨Œ¤œzˆ‡u„x‰…y‹ƒtˆ{s†vrƒutut€uu…xs„zrˆ||‘ˆ‚—Žƒ˜‹“¥™ºË¿´ÄºÐàÝìóîŹÌ˹º£¹³©¿º•¨¤ž™”Œ™Œ›ŽŸ–“¢™ž¨¢©¯«²¹µÍÔÏÍÖѬ²­¤«¦§¬¦«³«³½´ºÃÀÈÕÒòýúÚßÝÉËÉíïîêúöÈÙÕ¸ÊĬ½¶¢°ª¢­¦¦¹¯ÍÞֵſÀÐÊ®»¶«¸´½ÅÀ³¿¸­»³®½µµ¿µ¾ÃºÅÍÃÎÖÍÖßÕäéäÿÿÿÿüþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþ“ ˜’ž–•ž–—”¤Ÿ£±¨¢¶­¤¹°«¼³®½´®ºµ²Âº¯Ã¼·ÎÅ¿ÖÌÃÙÎÜîêíþúßòòÉâݳÌȬºž³«–¨¡’ž˜˜“—Ž—Ž—’œ“–¢˜“ ••¤™–¤™š¥ž§®¬ÃÂÀÎÆÂàÚÕù÷ôûÿÿÏÔÒ˜›š§¦¡œ˜”¦£ž½Á¼®¯ª›˜”Œ‰‹ŽŠ‰‘‹„Ž„‘„‡—‹ž•¥´­¢¯¨­¸³­³­ññíüûúýüüøúú´º¶®¶®ž¨œœ‘Š›‘ —˜¥¢£³°çø÷ÏßÞâîîûÿÿôÿÿÏÞÜáòðíùùÌÚØ ®«±¿¹­»¶©º²¦¶²ÍÜØÛèåéõõ÷ýüÿþýýüûøüüÙåå½ÔÑ¿ÏÍÈÏÎÿÿÿûüüùþý²ËÍ—·³®©¥¢š‚™“€“‰zŽ…x…yƒy‹€|ŒzŒƒy‰€€Ž‡’¢˜°Â¹ˆ“z‹yŠ€‚“z‹†‰™’|Œn‚us„ztƒxv‡|vŒv‚}•‰ƒ™Ž‡š’“¤œ©¹²§´¯Þðîãîî·Á¾½Å¿­¹²ËÜÔñÿÿÒè妺´’Ÿ™’ž—ž—”¥œ—¦¢©¸µ¢­­¬³²³¸¸·¾º©´¬¤±§¥²§ª·¯±¾·¾ÌÅÎÚÓÓÜÖÓÚ×ÝäáøþüøýýãìëÅÑδ¿§¶°¦·®¬¹±×ãÛÇÐÈÂËúû¾ÉÁ½ÈÀ´Áº°À¹¸ÅÀ¼Å¿ÃÊÀÇÓÇÑÛÏÞæÜòùóýÿþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþ‘ ˜’ ˜”Ÿ–—ž”›¥¥±©¨º°«¿¶¯Ä»°Ä»²Å¾¶ËüÑÉÅÙÑÚêâïûõýÿÿøýýñüüÐêå¸×ѧƼ§»´¢³¬–£œ‘œ•Œ—Š•Ž˜Ž”Ÿ•”Ÿ•”¡–“¡–—¥š—£œž¨¤¬°¬´°©¹µ­ØÙÕÇËÉ‘“’•“”Œ™–‘š˜’›¢›‘”‹•—’ޓއ‹„‹‚ƒŒ„Œ™“”§¡ÏâޱǟÅÁ¬µ¯ìïëêìë÷üýãì쪷³£°«—¥Ž“œ’’ ˜š£Ÿ»ÇÃòþþõÿþùÿÿøüûúýüùþýøÿþêóò¸ÆÄºÉǰ¿º±Áº°À¹¥²¯×âÞÈÑÍíôôüþþÿþýþÿÿï÷öÆÔÔÖêçÖãáÍÓÒðïïþÿÿüÿÿ×íï¬Éǘ´¯•«§¢ƒš“‚”Œ~“‰~“‡{‘…|Ž‚}z‹‚xˆ{Šˆ—§¸¯‰Ÿ–|ƒ”‹–¬À¾¦º³}ˆq…yw‡|z‰~yŠyƒy‘…—‹‡š ˜™¥¬¶¯²ºµôþüêõô·Â¿²¼¹Þèãùÿÿóüüøÿÿ¦º¶’£œ” ™“ ™•¢›ž¬§­¾»¬¾¼îýüÎÞܯ·³¯»µ¬¹²¦¶¯¬º´¹ÄÀÊ×ÑÝçáùÿüÿÿÿýÿþûþüúûûÙÞܾɯ·ÅÁ±¾¶°¼³°½´´½µ¹À¹¹Á¹¼Ã¼ÂÊÄÀÌ·Ľ¶Ç¿ÍÜÕÄÎÇÊÑÈÞæßèïéëóîùýùüþýþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþ¡˜•¥• —–ž“𣧲«¯¼¶±Ã»´ÊÂ´ÏÆ·ÐÇÀ×ÐÍàØìùöùÿýúþýÿýþþüýøýþìþüâûøÆåۭ¹œ­¥”¡™‘œ’ЕЕ‰—Œ›Žœ“¡•–¤˜—¥™•£šž©¥¢ª££§Ÿµ¹¯±¶±“–•‘“ŽŽŽŠ‡’‰’•Œ™Ž—ŒŠ‘Š‘˜‘•œ—‡’ƒ‰‚…އ‹˜’¬¼¸äöóÁÕѺÆÀ¦®©÷úööøõ÷ýûõÿÿ±ÂÀ´ÆÃ•¦¡‹›’“” • §¢³¹¶ëîíüÿÿüþþÿþþÿýþÿþÿúýýõüüÐßܺÎ˶ȲĽ®¾·®¹·½ÄÁ¾ÂÁ÷úûûýýÿþþûýýßêèÉÙÙôÿÿñúùßãâÕÕÕÿÿÿúýüðþÿÏæä›¶²œ²­’¥ ˆ–„™‘…›—‹•‰~’†zŒ~xŠ‚z‹‚†•Ÿ–¢´«‡›’“‰„–Ž‹˜Üíê ²­€“‹tˆ{|Œ}Žƒ}Žƒ|’‡|“Š„™Œœ“Žœ”“Ÿ—¡§¡¤¨£ëîêÛâ߬º¶·Ã¿ùýþþþþþüþûÿÿ¥ºµ˜ª£—¥ž›¦žŸ¯¦§¶±¢²¯ËÛÙúÿÿ±Ã¿·ÂÀ´Â¿¯¿¸¯¿¸µÂ¿ÃÏÍÝæãöüùûþýüýûþûûüýûûúöàäáÌØÕÂÐʼÈÁ¸Â¸´¿¹ºÁº½Ä½ÂÆÀÀÇÀ¾È¿¼Ê¾¹É¿ËÚÓÓáÚÌÕÏÙàØøþýùþýúüüüþþýþþýýýþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþ¢™–§ž–£š–Ÿ•𣍳­¶Ä¾¹ÊüÓËÁ×ÏÉàØÖèâéöó÷ÿüûýýÿýýþþþÿþþüþÿîüúÝïíºÍÆ °­˜© “¢–’ž”˜Œ™‘Š™Ž’Žœ‘—¥šš¨š¨”ž•¨µ±£®¨™¡— ªŸŸª£˜¢œŽ—‘‡Ž†ƒŠ‚ˆ’ˆ‹—‹Ž˜ŒŒ–І…‰’‹‹•ŽŠ–€„…’œ“¤¬£§¯¨©¯©¢©£¯²«ØÖÏÿþûüþýöüûßïíÖç壳¯‘¡š‘œ“— ”¡§¡©¬§àÞÛÿÿþÿýýýýýÿþþÿþþüÿþõþýæöôÎâßÁÔϸÉŲÁ¾°¼µ½Ä¿ÑÓÎÿÿÿýüüýüþúþÿáìêÜìéùÿþ÷üûúûûäææóòòþÿÿöþþíýý©ÃÀ¢ºµ—«¦¤ Œ¡˜Œ¡™„—‚–‹“ˆ|„y„~‡Ÿ——¦ž²Ã¹Œž•†—†“Œ“ ™ÎÚס­¨†|‚|‚~Žƒ~‘ˆ€“Š€—ŽŠ› —Žœ”‘•›¢œ¨­¨²¶°¯·²­º³ÀÊÇÿÿÿÿüýþüþüÿÿ«»·šª¤¡­§¢°¨§¼³¦·±³Á¼åëêÿÿÿÖÛ×µ¿¾¿ÌɸǸÆÃ¼ÊÇÕàÞúÿþúþýþÿýÿýüþÿýíïíÙÝØØàÚÐÜØÃÓË¿Ïǽ˾ÉÿÈÂÄËÄÅÌÅÅÍÄÁËÁ¿ÍÂÇÔÌÔßÚÝçäÒÛÕïõñýýÿýþÿüþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþ“£›—§Ÿ›© ›¥š¡¦¢±»µÍÞ×ÊÞÖØêãæôîïúøöÿýûþþýþþþþþþþþüþþþþþýþÿìôó½Ìɰ¿¸ž¯¬›«¢˜¥šŸ‘š‘Œ˜‘Ž”˜¨ž’¡—ž«¢¦´«›©Ÿ— —œª¤š¦Ÿ’’”¡•˜§ž—¤ˆ–‚Œƒˆ~ƒ‚†’…‰’†…ƒŠ€‚Œ„‡‚ƒ‚ƒ‡“†”œ ¦œ£™ž£™š¢—¬®¥¹·®ÛØÏêé廿»ÄÏʹÅÀ•£ž‘ž˜“ž•š¢—Ÿ© ª­¦Çýüùöÿþþüþÿûþþþþþþþþûÿþöÿþðýü×êæ¿ÒεÆÂ¶Ä¾ÀÈÂÍÔÎüýûýýþþþþøüüæððãôñýþþýýýüþþùúúòóóþýýýþþñþü£º¹©À¾¢¶²š­§”«¥–©£‰›•Šš’ƒ•“Š”‹‡š‘—¦ž›ª¢£³«‹œ“‡–Ї•Œ‰”‹˜™’…“Œ€’…€‘†€’ˆ€”‹ƒ˜…š’‹’’¢˜Ÿ—”£š™¦Ÿ¤®©ªµ­¯¼³®¹±ÄËÅììèÿÿýÿýÿîóó¢°­ª¸²ž¬¦¢´«®Á¹³Â¼ÈÐÎÍÒÐÓ×Ô¹¼¶»ÅÄÀÍʼËÅÃÑËÒÞÚóúúüýþýþþþþþþþþÿÿÿäèæÙäÝåëè÷ýúõûúáîêÇÙÑÊ×ÓÌÔÏÎ×ÐÓÛÓÐÚÐÎØÎË×ÍÝæàêñïéîïíññùüûÿþþÿýÿþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþ“¢™˜¨Ÿ«¢›¨ž««§ÃÌÅéü÷æùôóþûûÿüüþÿþýþÿýýÿþþýþþýÿýÿþþÿþþýþÿñûùÌÜÙ´ÇÀ¦·²ž®¥š©”¢”“Ž›•“¢œ™¨¢—¥Ÿ³¾·˜¥Ÿ–£š¡—Ž™”†•ŒŽ™’ž‘’¢š’ž—ˆ’‰„ƒ~†{‚‰}‚Š~‚‰ŠŠ~…ƒ…ƒ†‘…‡‘‡‰“‰’›ž¨ –¤œŠ›‘’Ÿ‘¤—ª©žµ³¨«¬¢¦ª¤¤¨ ™¢š”Ÿ™œ—”ž•¦›Ÿ­¢®³©ÄÁ¸âÝØÿþýùþÿûÿþþþþÿýþÿýþþþþúþýèû÷ÎáÜÂÒÏ¾ÍÆÇÐÊÈÎÉçèæÿÿÿúûþßäæÚåäèöóþüüÿþþüþþûþþóôôø÷÷ÿþþøÿÿ·Í̸Ïέ½¤¸±¥º·™¬©ž›ž™„””Ž‚—Œž”“£›‘ ˜ˆ˜‡—†˜‹ƒ•‡…–‰Žœ‘Ÿ–†—Ž…•‰„–‹ƒ–‡š‘‰Ÿ—ˆž–ŒŸ”£™¢™’¥›š¬¤¢²«£¶«­½±¸Â¹ÅÊÂÑÑÉïíçÿÿÿàçæ±¾»¹Ã¼ºÉµÊÁ³À¹¸ÃÀ×áÝçïíçîéèóîÏÚÖÉÔÏÉÕÏÔàÚêòîùÿýÿüÿÿþÿþþþûÿÿûÿþñøõçñìøúùÿþÿÿþÿóûùÙêåÙçã×äÞàëäôüöâïåÚçÛÞæáùþüûþþûýþýüÿýüþÿþþÿþýÿþþÿþþþþþþýÿþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþ— ›—¡ ©¤¢©¥­³­ÐÕÕüþÿûþÿüþþþþþþþþþþþþþþþþþþþþþþþýþÿÿýÿýþþøýýÞïë·ÎÊ©¾¶¢µ«œ­¢•¦™Ÿ“ž’“œ–•Ÿ™Ÿ¨¤½ÆÃ²Á¾»ÔÐ¥œŸ–‡–Ž‹•Ž—’Œ”Žˆ“‹‚Žƒ~‰~~ˆ~Œ€~‹ˆ|{†z|ˆ|€Ž‚…“‡„”‰‡–‹ˆ•“Ÿ—•‹š’š–¡”ž¦™£ªž¥®¤¡®§ž« ”¥š“£˜•Ÿ–˜¢—œ¨ž¥«¦¬±«¿Á»ØÖÑùø÷ÿþÿþþþþþþÿþþÿþþþþþþþþøþÿòýüÎàÛÈÜ×ÉÝÕÆ×ÏÝäÝäéæ×ÞÜÚàáåííõþüûÿþýþþþþþÿÿÿüûûãääíïíÏÜٳʟÏ˱ÈÅÙñï®ÉÇŸ°­¬¦¤š‡Ÿ–‡š’ˆ–ŽŠš’ŒŸ–ŒŸ–Œ —‹ž•„›Ž‚—Œ„—ŒˆšŒœ‘Œœ‰ž’‡œ’‡œ”¢™‘¤š‘¥—¥š–§Ÿ–¥Ÿ™¦ Ÿ­¦¨¸®¬¿·¯Á¹ºÊÃÍÙÕêðîöûûýÿÿÛáÞ½ÉÅÃÒÏÑåàÕëæÅÔÒÄÏÍðôôùüûüüýþþÿáïí×ãâÙãáçíëùýüýþþþþþþþþþþþþþþýþþüüüÿÿÿþþþÿþþýýýþþþøùùõúùó÷öûýýúýüúýýóúùúûúýþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþ”š—¢Ÿ¦¤¨¯­­²­åçæýÿÿüþÿþþþþþþþþþþþþþþþþþþþþþþþþüþþÿþþþþþúþþïûúÇÛØ°Ç§¼µ ²©˜¨œ•¢—”•’š‘–¡™¥¬§°·µÙåäàõó©¾µšª£‰—‰“‹Š’‰‡‡‚ƒŒ‚~‰€Œ|‰}ˆ||†z~ˆ|Œ€„‘……“††—Œ†˜†˜‡™Š™’‰˜Ž‘’ž‘– ”œ¦™¨ª¢š§ž’¤š“£™—¡˜¦œ©Ÿ¤­§«²«¿Á»àßÛÿýûÿÿÿþþþþþþþþþþþþþþþþþþüþþùÿþêöóâðìçóïæòíßêãÔÝØÕÝÛëïðøüýûþýýþþþþþþþþþþþþÿÿÞááÄÅÄÙãáãñðöÿÿõþþøÿÿ½×Ô¥·´ ¯©“§ ’ª¢Ž¢š‹“‹ž•£™Œ£™¢™ŠŸ–…Ÿ“„œ’‚›„›ˆ“Œ –ޤ—¢˜¤›“© ”¬¡–­¡–¬¡š¬¢¬¤ž®¦¥µ¬°Ã·¾ÓËÃÕÍÄÑËï÷õûÿþúüûöôñÉÉÅÆÉÄåëæ÷ÿüïùôÖâààèæóù÷üýýþþþüýýöÿþýÿÿúÿþúýüýþþþþþþþþþþþþþþþþþþþþþþþýþþþþþþþþÿÿÿýþþþþþûþþýÿÿýýýþþþûýýûÿÿþÿÿþþþýýýþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþ–¢œ›§¢Ÿ«¥«¶°µ¹µêíìýÿÿþýÿþþþþþþþþþþþþþþþþþþþþþþþþþÿýþþýÿþþúýýôþþìúùÀÚÔ°Ç£¶¯œ¬£›¦ž™ š•Ÿ“™¢™ž¦ŸÒÕÓùÿÿëþý›­©ª¸³‰—‚ƒ‚Œ‚€‚ƒŒ‚|ˆ|~Š~}‰}}‰}Š~~ˆ|€Š~„Ž‚‡‘‡‹—Œž–£™Ž§œ‡ž”‹‘›Š›Ž ““ž’˜¢™˜¦›˜¦Ÿš©¡’¥›’¤›œ¨  ª£ ¯§¦±«¬µ°¿Á¼õôòÿÿþýýýþþþþþþþþþþþþþþþþþþÿþþüþþùýü÷þûúÿþøþûÛêçÐÞÚáêéüÿÿýýýÿýþÿþþÿþþÿþþþþþüÿÿéïí¿ÇÄÞèæøÿÿþþþýüýÿÿÿÀ×Ô¦»¹¡±®•«£ ¶®š°ª§ŸŒ£›’ª¢“«£‘©¡Œ¢šŠ£™‡¡—‡ž•†”Œ¡˜£š“©¤œ•ª¢›³ª¶ÏÆž¸¯³§œ¯¦ ³ª¨¹°²Ãº¿ÐÆßñìÓãÝêóñùþüüýýùøøÍÊÆÃý¿Á»ÌÍÈÜàÛèìçôüúôùùøûûþþþþþþþþþüþþýýýýýýþþþÿÿÿþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþÿýýÿýýýþþþþþþþþþþþÿÿÿþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþ𥛡¬¢§µª®½²¿À¼ìììÿÿÿþýÿþþþþþþþþþþþþþþþþþþþþþþþþþÿýþþýÿþþþþþøþÿöþþÙðî·Íɦ¹² ±¨š§Ÿš¥Ÿœ§œ˜¤™«±ªÿÿþöúûøÿÿ«¼¸—¦ †”Œ…†ƒ‚Œ~‚‚‹€}‰}{‡{}Š}}Š||ˆ||ˆ{ƒ‹€ˆ†‰•ŠŒš–ª¡š¯¦™±§£—Œ’Žœ‘‹›ŽŽ’‘Ÿ””¢——¥›©¹®ž¬¥Ÿ°©—¨¡ ¬¦ «¥¥µ®«¹·¯¸´ÅÈÃÿÿÿýýûüþþþþþþþþþþþþþþþþþþþþÿþþÿþþþþþüþþüÿýüþüêûöÑàÜíõóùýûÿþþÿýþÿþþÿþþÿþþþþþùýýùÿÿÄÒÍÕâàùÿÿþþþÿýÿóõö¾ÏÑÌàÞ¨½¸š«¤¡´®§¼¸Ž¦—±©—²©˜²ª˜¯§§ ‘¤› ˜‹”¡˜‘¢™”¥”¨œ–¨ Ÿ°«¶ÇÃÖìç¬Å¼¥»²¤·®«¾µºËÂÂÒÉåóìôÿþøÿÿúÿýüþýÿÿÿòóò²¹³¼Â¼¾Æ¿ÉÐɺ»ÐÖÐþÿÿùýüþþþþþþþþþýþþÿþþÿþþÿþþÿþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþÿþþÿþþþþþþþþÿþþÿþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþš¢˜ ª «µ«±¾´ÉÈÄíëëþÿÿþýÿþþþüþþþþþþþþþþþþþþþþþþþþþþþþþþÿþþþþþüþþùýüëûûÁÕϱ¬š¬£ª»³ž­¢˜¥›ÆËÅÿþûýþü÷þýÓâÞ —‰—ކ‘‡Ž~Ž€Œ€}Š}|ˆ||‰|~‹}}Š|‹Š~†…Œ˜†•¿Ò˸ÐÇ—¬££´¬•¦šŽž“Œ›‘‘ž–•¡››¨ ´Â¸²½¹­½·¡³­£²­¢²­ÏäßµÆÃ®¹¶¾Ä¿øøôþÿýüÿþþþþþþþþþþþþþþþþþþþÿþþþþþþþþþþþþþþüýýëùøãðîçñîúþüþÿýþýþýþþþþþÿþþþþþúýýþÿÿÉÖÑÁÌÊùûûþýþþÿÿèóòê÷ùæø÷°Ä¿©·´©µ±Ÿ²­ž´¯ªÂ½ªÃ½©Å¿¨Ã½˜±¬–¥ž—Žœ•ž—’ š”£›•§ž£±ª£°¬ÖßßòÿýÆ×Ô©¼¸±ÅÀ¿ÑÊÒàÙðøõúÿþùÿýûýýþýýÿÿÿÿÿÿàæäª¹³³Â»ÏÜÖôýù»Ã½îôðüýýþþþþþþÿþþþþþýþþÿþþÿþþþþþýþþýþþüþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþÿþþþþþýþþýþþþþþÿþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþšŸœ ¦£ª±­±½¹ÊÈÅéççÿþýþýÿþþþüþþþþþþþþþþþþþþþþþþþþþýÿÿýÿÿþþÿþþÿþýýþüëùöÕãß¹ËêÀµŸ¶ª¶ÍĺËÀ¢±¨²¸±äàÝÿÿþûþúÎÜÖ‡—Œ™Ž…†‚~€~‹~|‡|~‹}Œ~~‹~€Œ€‡‘…𛓍¹²êýùÒé㨼µœ¨ ˜¢˜’ ”†šŒŽš‘ž•” ™“Ÿ™” ˜§³ª²¹·ÀÍÊÄÔдÿÊÝÙéýûÖç奱¯¿ÅÀÿÿþüþüùþýÿþþþþþþþþþþþþþþþþþþþþþþþþþþþþþüþÿúýþñúûêõòéñîöýøüÿþüþÿüþþýþþþþþÿþþýýýþÿÿÚáÞ·»¹öõõþüüùýý×åäôýÿîþýÀÒή¹·ª´±§¸³°ÃÀ¶ÌÉ±ÊÆÄßÛØñíÑé嚪¤Œ›•Œ›•œ—‘ ™”£œ™ª¡¦²¬¹À¾ÏÔÔüÿÿóýüéúúÕåâÊÛÖôýúúýýþýþþþþÿýþÿýþüüüÿÿÿÑÙÙ­¾¹¼ÌÇé÷ôêóòÀÉÅôùøüüüÿÿÿÿþþÿþþýþþüþþüþþüþþüþþüþþüþþüþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþÿþþýþþûÿþûÿþýþþÿþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþ˜¡œŸ©¢¨²ª¶½¶ÈËÃááÛýüüÿþýÿþþüþþþþþþþþþþþþþþþþþþþþüþþþþþÿýþÿüýÿþÿýýþùÿÿöÿþãõô»ÓР¶¯¤±©¤®¢ª±¥´¸­ÉÆ¿ÿÿûÿÿÿ·Á¼Œ–ŽŒ•Œ…ŽƒƒŽ‚‚Ž‚†Ž…‚Œ€Œ€Œ€‚}‹€|Œ„œ’©ž¬¸¯åìèÊ×ÓŸ«¤•Ÿ•Ž—‹šŽ˜–’–¡›‘Ÿ™Œœ”‘œ“™¢˜¤«¤¹Ã¿ë÷öðüüùÿÿ÷þüâíí¨´³ÅËÉÿÿÿýýþùýþþþþþþþþþþþþþþþþþþþþþþýþþüþþüþþÿþþýüüíùöÝæåò÷öýþÿþþþþþþþþþþþþþþþûþþýþþõ÷÷ÖàÝÈÌÉÞÜ×ÿÿüûûöÑÕÒßçàðûöÖäà¹Ç䳫«¹±´Ã¿ÉÜØÞìëïùúóþþçõô™¤£›¥ •ž–’•“¡—–¨šª¢²¾¹ÇÔÍßæãÿÿÿüüû÷ýýìööòúùþýýÿþýûÿýüþþþþþþþþýÿüÿÿÿÍÔѵÀ¸»ÉÁÜçáãíæÕÙÖüýüûþÿüþýûýþþÿÿþþÿþüÿþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþ™¤ž¢®¦ª³«²º³ÄɾÙÚÔüûúþýýþþþüþþþþþþþþþþþþþþþþþþþþúÿþüþþþþþþþþýýýÿÿÿûûûúýüöÿÿÕé禸³ž©¤¦¯¦©°¦°´©¶¸­ÈÈÁ¸·³‰–Ž–Š’‰ˆ†„‚Ž‚„†„‘†‚Ž‚}Œ€‚„€Œ‚ƒƒ…Ž„Œ”Š›¡˜±µ°¬°©œ–œ«£™Œ—‹˜‹–‹• •ž«¢Ž“Œš‘›’—Ÿ• ¥›³·°øûúúüûúýüøüüóüû¹ÄÃÇÎÊÿÿÿýýýûþÿþþþþþþþþþþþþþþþþþþþþþþþþýþþýþþýþþûýüòúùæìë÷ûûýþþþþþýþþþþþþþþþþþüþþÿÿÿáääñùø×ÛØÂÁ½ßÞÙÝÞÚµºµÐÙÒÎ×Ñãñì²Á½¦µ®¬¼´¯½µ¼ÉÆÙäâúüüúþýóúùÇÑÏ¢¬¦•–“›”–¡˜Ÿ¬Ÿ¢¬ª¿ÊÈàéèòøøûýþüüýþûýúýþùþþÿýÿÿýÿþýÿÿýþÿþþþþþûþþûÿÿÅÐα¿¸¾ÊķĽÏ×Òøûûýýýÿþþÿþýûù÷ûù÷û÷÷ÿüüþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþ›¨ ¢®¦¨³¬®¹¯¾Å»ÐÒÌööôþýþþþþüþþþþþþþþþþþþþþþþþþþþýþþþÿþýÿüÿÿÿýÿþéëèÈÂÀù÷õûÿýâïî§¶³ž©¥ ©£§®§«¯§ª¯¤¦«¢¢¨Ÿ–¢š˜ˆ‘…‡„„„‚‚‘†ƒ“†}‚„„…‡’‰†…ˆ’ˆŽ–Œ“˜”•¨«¥¥µ­›«¡“ –Œ˜ŒŒ—‹Ž™’ ’‘ ”‰›Ž›‘š”˜Ÿ¡—«¨¡ñëéýýýÿþþûýýùÿÿÇÐÎÃÇÅÿÿÿþýüûþÿþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþúûûãæåÐÖÔëïíýþýþÿýþþþüþþþþþþþþþþþüþþøùùóööûÿÿåé赺µÃÅÁÁÆÀ¿Æ¿ÜäÝÏ×Ó×ãàÁÎÊ¿Ðʳޝº³ÓÝ×õûùÿýüþÿþÏÖÑÏÙ×£®¦˜¡˜–œ—™ ˜¥¬¡¯µ°èïëþÿÿêíêüûúþýýÿÿÿþýüùýüüÿþþýÿþýÿþþÿÿýþþþþýþþýÿÿ½Å¯¼¸ºÆÀÓÝ×üÿÿûýýþüÿÿÿÿÿÿüñðêíìçóðìþûøþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþœ©¡£°¨¬º¯®º¯¹Â¸ÊÑÉêëéÿÿÿýýýþþþþþþþþþþþþþþþþþþþþþÿþýÿýüýýûïïëØ×ÒÊÊÆÎÌÄÚØÓäæä°½¹ °¬œ§£Ÿ§¤Ÿ¦ £«¡¡«¡¡ª ¦“£›‹™‹•‹ˆ…„„}ƒ~ƒ’…’…‡”‹†”Œƒ“ˆ†•‰‹—Œ–Œ•–¹¾¸±Äº¥·®’¢˜ž“Žš’ž˜¦—ž‹™ŽšŽ—‘𙑮ª£Î¾ìåãìèçþþþøÿþÕÜÛ·»¹úööÿþþüþþþþþþþþþþþþþþÿÿÿþþþúüüÿÿÿÿþþþþþêììÒ×ÖÅËÅêìéÿÿþþÿýýþþüþþþþþþþþþþþýÿÿúüüûýýüÿÿñööÊÒΰ¸µºÂ¼ÆÎÆÉÑÊÊÓÍÍÖÒì÷ößëé¶ÆÂ²À¸ßèæúÿþ÷ø÷ÓÖÕÕàÛÚâß¡­¤Ÿªž›¡ž¡›¤¨ž««¡²±¨îëåÙÓÌòðêðéåÑÌÈÿÿÿÿÿþûÿýúþýýþþùþþüþþþýýÿýûûøø½¸¸¬´°±¹²ïóðûýüþþÿþýþûýýýÿýùû÷íïèóöñüüøþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþÿÿÿþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþ©¢¨¹­°Àµª¹­¶¿µÅÌÄÞßÝùùùÿÿÿþþþþþþþþþþþþþþþþþþþþþþÿýüþüãéäÌÔÎËÒËÈÏǸ¸´¹³¤«¥ºÇ¤³­ ­¥ ©¤§¡§ž¨žžª¡œ©£”§› •Š™‰”‡„‚„‚‘„€’„”…„–Š’¢˜‰˜‘†™Ž‰šœ‘Ž™¦ŸÀÈÁ¸Ë·È¡›”¤œ’ž”˜¢–•£—Ž›‰–‹‹–‹Š–Š™˜œ”¥¤œ±¬¤­¥ŸÃ¼¶äàßÿÿÿÚàÞ¶·³éäáÿþþýýýþþþþþþþþþþþþþþþþþþíñíø÷õø÷õìêèÐÓÐÀÈÄÇÇÂÈÉÄïïìÿþýýþþüþþþþþþþþþþþüþþüþþüþþýýýþÿÿ×ãâ§µ±´Áºµ¾²¶¿¸»Â¾ÕÜÚûÿÿæîîÍÕÓÔߨëñðýÿÿêééÅËÉíù÷³¼·¨Ÿ¤¯¥¬³¯¤ª£˜œ“«ªŸ®«¡Á»°Ç¿µÊÀ·¾¶¬ÜÙÔäØÔöëéüöòþÿûþÿûþÿýþÿýÿÿýëäáÎÇ𨥪­¨µ¶°úøôþýúÿÿþÿþÿûþÿûþþúýùô÷òúýøüüøþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþýþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþ ­£´Ä¹¸É½©¹®±»±¿Æ¾ÓÖÓðññÿÿÿÿÿÿþþþþþþþþþþþþþþþþþþ÷ÿüåðìËÚÓÅÔ̼ÊÁ·Æ¼»ÏúÈÁ¿ÊŽÌÅ¢³ª¤±¨Ÿ«¥Ÿª¤¡­£žª¢œ¨¢—©¡–®¢¤˜‘¡•ŒšŽ…“†…”„ƒ”‡„•‡„—‡Š—« ¡™Ÿ–—¦›–¢˜•ž• ¥Ÿ¥ª£ÀÒÌÖé夶²«¦—£š–Ÿ””ž–Š•‡’ˆ‰”ŠŠ–Š‹˜Œ”›•š ˜£¦œ¬¬£¹´¬ÂºµÍÔÓËÑδ¶²ØÓÐôîîýþýþþþþþþþþþþþþýýýÿÿÿáåàÜÝ×ÜÚÔÓÓÍÂÆÀ¶¿¹¾½·ÆÄÀëéäÿÿþýþýûþþþþþþþþþþþýÿÿýþþûþþÿüýüÿÿßë못·±¿¹³½³µÀ¸ÕÛØùûûûýýùüüùÿÿúýüúüúÿÿÿéäç÷ùúéõ󨯫©³ª®»°¹ÅÀ¨¯©½Åº¯¯¦­«£±¬¥³®¨¹´°Ä¿¹ÙÕÐÒ¼ºâÅÂíÚÕ÷ñéùôìùòïøïìèÞÚÒÌÇÀ¾¶¬®¤°¬¨½¹´ÛÕÐþýøÿþüýýüþýþÿÿÿäááüúöôñíýû÷ýþþþþþþþþþþþþþþÿþþþþþþþþþþþþþþþþþþþþþþþþþþþþþÿþþüüûüûûüüûþýþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþ›§ œ­¡¢®¤¦°¦¬µ«¹À¸ÏÐÊáßÜÿþþýþýýüÿþüþÿþÿþþþþÿýþÿýþýþöýüÞìë½ÐγÆÁ¬¼·åøøËàÝÆØÖÊÚÕ§¸¯¦·®¤³®¡²®¨µ³­³²ž¯¨Íë㶯œ®§—§œ•Ÿ•—އ”‹†“Љ”Š‹—Œš’Ÿ—£š¦œ´®“§¡—Ÿ•¡¤›¢ª¦øÿÿòÿÿ»ÓÏž¬¨¥“›’•ŽŠ•І”ˆŠ–‰‰“Љ•Ž””—’™—£§¢±¹²ÁÌÆßõñãîí¸º¹ÊÅÂÞØÔýû÷þüþÿýþÿþþÿþþüÿþóøõÒßÜÉÐÍÁÅÁ¿À¼µºµ³º³³»·ÁÇÅêìëÿÿÿýýýÿþÿûýýýþþÿþþÿýýÿþþýúûþüûÿÿÿæïî­½¹¯½·±¼´¸À¸çìéúþþýþþýþþÿþþÿÿýÿýÿÿýÿüüüýÿÿÜãߣª¢®¶¯±¸²Á¼ÀÈÁÎÝÔ¢¦§«¡ª«¡¬¬¢­¬£¸µ°À¿µ½·¯È¼µÔƽÓÄ»ÒúÝÉÃн¹É¾ºÁ¼·²°©§§«¬£µ±©Ç¿·üøôÿþüýýýüþýÿÿýÑÌÈãÞÖáÚÓûùôýûúýýþüþÿüþÿÿþýÿþýÿÿýþÿýþÿýþÿýþÿýþÿýúþþýþþÿþþÿüûþ÷òõìâüôéÿûöÿþýþýÿþýþÿþýÿþüÿþþÿþþþýÿþþþûþüýýüüýýüþÿüþÿýþþÿþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþœ¨¡˜¨Ÿ­¢£­£¦°¥²¹±ÀýÏÏËéèãýýüþþþýýýýýýþþþþþþþþýþþþøýüóþýÉÙÖ«º·¼ÊÅïøøÕàß»ÌÇÅÚÕ¡¸²›´¬®¾»§¼·¯ÃÀ¥´²ÏßÜèþùÄÙÕš¯§˜«¡’£™Š˜Š•ˆ•‹—‹–ŽŒ˜—¥œ«¢¶ÌÅÉåàµ°Ž˜‘ž˜¹¹·ÿÿÿñùøðÿýš¦¡˜¡˜’›•Œ‰•Ї•‰‰”‡Š”‰†’‡‰’Œ˜•›• ¥ž¶¾¶ÍÕÏÞîëÏÚØ¦¬¨¾½¹ÌÈÃïèäÿÿþÿþþÿýýüýüýÿÿåìéäïêÌÓλ¾º³´°®³­¯µ®±´³ÔÖÔáàßÿÿÿþþÿÿÿÿûüûôóð÷ôðÿÿýüûøÛÖÓçÞÝâãáÓÝÛ¶ÅÀ°½¸´¾¶µ½²ÙßÙûþýüþþýþþýþþýþþüþþýýþûþüîóð»Æ¿¬³ªª³ª¬´¬µ·°ÔÝÓÖåÙ«¯©§«¡¨­¢§©Ÿ©ª °­¨ª®¦º½µÁŽÌÌľµÃ½µÈ½´Ã¼¶¼¸²²°«¥¦Ÿ£§œ¦§Ÿ³±¨ÆÀ¸óíéöóñüþþüûúçäáÒÍÈÏÆ¿ÕÍÆäÜØîêèÿÿÿþýþýýÿýþÿþþþýÿýþþýþÿýþþþþþþþþþþþûÿÿüÿüûõðííæáéâÚïåÜðåÝýøòýöôÿüûýþþÿþþÿýÿþýÿþýÿþÿýýþûõóíýüøþþýýþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþ™¥—¨œ«  ­¢£±¦¬µ¬µ½µÀþÐÑÍéèä÷øõþÿüþÿýþÿýþýÿýýþýþýþÿÿðúø·ÆÂ´Ã¼°½·­¶°§²¬­¾·êûùÖêæÙíëÙæâç÷÷¼ÒдÈÄêøõûÿÿé÷ô§º´©À·…š’Šš‘™“‰—‰–Ž‹–Ž™‘›¤œ¡«£íúùèÿÿÍæä‡”Ž žš°ª©ëÞÜÿÿÿÑ×Ó «¥–Ÿ–’—Œ’‰Š–Ї•‰Š“‡Š’‡†‘††“‹Ž–“›”¢©¢¯¶±ÁÇÂÀËȰ»´¤«¦¯²¬ÃÀºÛÐÌèæáûøõÿÿýÿÿþõ÷ö¾ÄÁ²¹³­³®­®«ª¬¦¨«¥ª®§­«§ÊÇÃÑÎÍëçæýþüäåâרÓâßÚäàÙߨÑÖÑÊÔÑÊ×ÑÎÑÔÒÚäá²Á¼³Áº·Â¹¹Á´ÐÔÌúûùýþüþþþýþþþþþþþýÿÿýÿÿþãæà»Â¹±¹¯­·­²»°»À·¶¼¶¿Ìö½¶©°¨¥« ¥©žª¬¢®¯¦¶»µ»Å½ÆÓÍØãÝ«°«²²¬µµª¸»´ÐÕ΢©¢¡¦Ÿ£˜£¥¯®¥¾¹±ÔÏÊ÷õóüÿþþýýßÞÛÑÐÊÑÍÈÐËÆÔÎÉèâÝÿÿýÿýüÿþþýþÿúþÿüþÿüþÿþþþþþþþþþÿþþÿÿüÿÿûðìèçâßæáÜáÝ×åÛÔßÓËêÛÑðãÚùôïþýýüþÿüþÿþýÿþÿþÿýüûûöõòéûúóþüûþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþ™¦ž›©ž­£ž­¢£±¦ª·­±¹²ºÁºÇÌÆÒÔÎÕ×ÐÝàÙîïëýþüþþþüüýôõóÔÙØ­¸²±¿¹©·±©µ¯¯½´¦µ®ÔäÝôþý÷ÿþöýüüÿÿõýüðýûÐàܺ޶º±®·±±¾¸»ÍÇŠ•‹›“˜‡•Œ†“‹‡•˜›£œ¢©¢³¿½ÝòñÕïî…‘Žžš—ª Ÿ´¤¡½·³˜Ÿš‘ ™‘––‹”Љ–Œ…–‹Š•Љ“†ˆ•‡…”‹‹˜š¢›ª±­¥­§¦®©µ¼·¦­¨Ÿ¨ ¨¬§¹·±Çþ×ÑÉãÜÖñêäßÛ×¹·³³´¯­³­¥«¤¦ª¤£¥Ÿ¢¦ ¡¥Ÿ©§¤¶²®¹·²ÔÓÏõöôâæâÒÖÑÉÌÃÂÁ¹ÃÁ¸ÇƼÅźÉÉÄÏÕÑØâßÂÐ̾Ìżǽ¾ÆºÓ×ÎþýúÿýýÿþýþÿýÿÿþýúøìéåêçâËÌýÀ¸³»±·Á·¹Áº¸»¶º¿ºÖÞÚ¶Àº«µ­§¯£§­¢ª®£´¶¬ÇÇÁÙßÙñùöáè稭ª¬¬¥ª°¦ÎÕÍÌ×Ïž¨  ¥ž –¢£šª¨Ÿº´¬ØÓÎÿÿÿýþþûýýøüùõ÷óÕØÒÌÌÆÓÒÍáØÓèÞÚüõòÿüúýýüûþþüþÿýþþÿÿÿþþþÿýýþýúñëäñëäßÜÓÞÚÔèäßÔÑÌÔÌÅÖÊÁàÑÆâÖÌíæàÿþúüþüþýýþþþþüúüúööôìõòèüúôÿþüþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþœ¨¡œ«Ÿ­¢š« ¤®¥©´«¬¹¯±¼³½Æ½ÂÊÂÆÌÄÈÏÈÍÓÍßãÞçêé×Ûڻ¼±¹´°¼µ¦µ®¦¶­¢²ª¨´®¯¼µéõïàæâææãÿýûüüüþþýþÿÿñùù¤­¦««¢ ¦ž±¸±ÈÐʆ‘‰ˆ”І“‡…“І”Œ‘–“¡™© ­·¯¢§¥ìùúÖèè•“žœ—›š’¤œ˜¡Ÿ™¿ÉÆÐåዟ˜˜“Žš“ƒ”Œ¢šŠ˜ŽŒ—†•‡ˆ•‹™ ©¡´¼·¦°ª®º¶«¸¯¢¬£Ÿ¦ž¦©¢­±©¶º±ÃÄ»ÎÎÅÐÎÆÅĽ¹º²­¯§¢©Ÿ¥œ¢œ¢œŸ¤›¡œ ¥ž«®¨¹»¶ÊÌÇÓ×ÒåêåÇÎʸ¾¹´¸´¶¹±¸º²º¾´¼À»ÇÎÉÄÏÊÈÖÏÇÒËÃÍÄÆÏÄÏÒËèåàýûöÿþúýý÷ïíçÒÍÇÈļ¸ÃÇ¿»Á»®¶¯ÌÖÏØàÜó÷ôüÿþüÿÿ¾Ëų¿¶¯¹®¬´©°´ª´¸­À¾´¿½·÷ø÷ðòò¨«§ª­¦¨«¡ÖÝÕÂËÄ®¸°œ ˜žž” Ÿ—§£›­¤ÚÒÎÿÿÿýýýýüýûþýøüøÃÈÂÌÏÉÒÑÌÌÅ¿ÑÆ¿áÔËóçàþ÷ñÿþúþüýÿÿÿÿþýÿÿüþüøîêåÞÖÑÒÊÄÓÍÅ×ÔËíëäÓÑÊÉļÉļ×ÐÆ×ÎÆáØÐóëâùøñÿÿûÿþûúöòõòìõóêùöñþýùýýüýþÿþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþ©¡Ÿ­¢ž®£œ­¢¤­¥§±¨¥³¨¨¸­±½²³¾´ºÁ»¼Å¾¾Ç¿ÀÆÂÀÈÃÁÆÂ·¿¹±»¶©¶¯¤´¬¢³ªŸ¯¥«°«¯¶±«³®¬²­¹¸´ñîìÿÿÿú÷ø××׼ř’œŸ–›¡–Ÿ¢˜˜–‘‹†‰’‡ƒ’„Ž˜‘‡•޼ÍÄŸ°§ž«£·Ä¼ÒÓÑÿÿÿ¾ÇÉŽŽ›™’–Œ”“Ž¡¤ èöôßøö§¿º•Ÿœ‹™“¨º´›®©Œš“œ’Šš™Ž• –ž© ¨¡˜¤ŸÌÛÕªº°¡¬¡ ¤›£§ž¦­£¨³¨±¼´¹Á¹¼Ã¹µ¼±ª±¦Ÿ§¥šœ¥š— –™¡šœ¤œ¢š£™¢¨¢µ¼¶ÄËÄÁÇÂÑ×Ó´À½¼ÆÄ©°®­³®¬³­²º³¼Ã¼ÙáÛÒÞ×ÖäßÖáÙÎÙÐÍ×ÎÐÔÎ×ÓÎâÝ×åàØÚ×ÎÒÑÇÊËÀÉÍÁÉÎÃâìäÂÏÉ·¼·áëçôýúûÿþùûüûÿÿÏÝ×ÄÒÉ·Ä·µ¾²µ¼±½Áµ»»²Á½·îëëõóó²µ±®¶®©§žÊÍÆÆÍưµ¯š›” ž“žœ•§ ™¬ ™ÊÀ»ÿýûÿýýÿýþþüûÿÿÿÉÉÃÄÀ½Èÿ¼µÈ¿¶ÖȾäÔÊùíäý÷ïýûùÿýûÿýúûøòõðéÜÔÎÒÊÆËľſ¶ÊɽäâÙÌÊÂÁÀµÆÄ¼ÌÉÄÉ¿ÒËÂåÚÐòîãÿþøûöïòîçöôìýüóûüúüüüüþÿüþÿýþþÿþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþŸ®£®¡ž­¡Ÿ¬¢¢«Ÿ¢­¡¤²¥¥³§§µ©«¶«­¸±²·³³¸´µ»¶´¹µ®¸²¬³®¬µ°§´­¢±©¢´«Ÿ²©§³©¦¯¥ª¯§­°©µ´®Â¾¸ÇÈÄ¿¾»¶¶±ž¡š›¡š”œ”˜‘‘‹‘Šˆ‡ˆ‘ˆŠ“‡Ž™ŽŽŸ”íü÷·ÉÀ¦¯¨´¶²¾º±¼º´‡Šƒ‘‘Š’ŽŠ“‰Ÿ¢œèêæäçå¡©¤˜¡žŸ¬¦ÁÐËœ¯¬Ž ¢´®¡šŠ™®À¶Ÿ®¨“ŸœÓáàÙñî «¤Ÿ©¡§œŸ§¨¡®¢¤´§ª¹­®¹¯¨°§ § š š—¢š•ž——Ÿ•™¡—¡©Ÿ™£˜›¢˜¡¨ž©±¦¸À·ÁÉÄÈÏÎÂÑÍÒáÜ£²«¥²««³­°¸°ÄÌÊùÿÿêõôÌ×ÔæòïêóîìùõÚâÝÐÏÉÏÍÈÉÍÃËÓÈÐÒÊÄÏÈÆÏËÚÛÜÿÿÿÔâÞÉÏÊýÿÿþüþÿýÿÿþÿýþüîúòÌØÐÅÎÆÂÊÀ¿Å¼ÅÊÁ¿Á¶¸·ªçäÛàÞÕ½¾·°µ°¡£™¿Â¸ÅÈ¿­¯©™š”¡ œ ž›¡ž˜­¤›À¯§çÚÔÿýúÿüüÿþÿûøùÞáݹ»³¶¶ªº´®¾¸±ÆÀ¸ÓÍÄøñçõïåýóëÿÿøþÿùòëçæÚÒÑËÁÄÄ»¿¿¶½¼²ÃÁ·×ÓÈËÆ¹½º²Â¿·ÊǽÃÀ¹Éļ×ÒÊçà×íäÛìæÜïëäüúöýýúþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþœ¬¡™ª›ªŸœªŸœ¨Ÿœ© ž­£ °§¥²©¨´«¨³«©±«©°ª¬³­«³­¨²«£¯©£®¨£®¨¨³­ªµ®¤¯¨¤¯¦¢­¤¢ª¢¥«¥®²¬ª®§ž¢Ÿ¢¦¡ ¢ž¢¥ ——˜Œ”‰ˆŽŠˆˆ‡’‰‹•‰Ž—‘ž’Úåߨ¶® ª¢¤«¥¨ª ”˜’˜’“˜”ŒŠŽˆ“•©«¦šœ•–œ– §¢˜¡œ»ÆÀÑÜ×›ª§­½¹²Ä½˜§¡Žž“ÊÛѤµ®´Â¿ðÿÿÛòñ”Ÿ˜Ÿ¨ ¡ªŸ¦œœ¦›©žŸ®£¦µªªµ«Ÿ¨Ÿš¡›–ž—’›”š“”œ’™¡–¦­¤–Ÿ•˜ž—œ¢š¡¨ž§­£ËÐÊáåáØàÜåïê ª¥¥¯§­´­®²¬ÙÝÚÿÿÿ÷þüõúúùÿþûÿýøÿýìòðÔØÓÉÌÆÈÌÃÍÓÉÏÔËÌÕÎ×ßÛûüüþÿÿéñîÒØÓÿÿÿûþþýýþüþþùþüôü÷áèâçîçÎÕÎÏØÎÙß×¼Áºº¼³ÈȼÂÀ¶¾¾µ«­¥¬«¢¿¿¶ÀÁ¸§¨£˜š”°±­—𖥦Ÿ¨¢™µ§ŸÓƾòéåüþýþýýýýýìð쩬¤±¯¥¯¬¦´²«¿º²Å¿¶àÚÐëåÙã×ÏòîæÿÿýàÙÔÑÈÁÃÀ¶º»²º¹°¸·­º¸­Â¿´¿¼°¸·¯¹¸°½¼´À½µÃÁ¹ÏÌÄØÒÊÝ×ÏæâÙôðëÿÿüûþýþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþš©¢šªž˜¨—¦›—¨Ÿ—§Ÿš©¡œª£ ­¥¤¯§£°¨¢­¥¥¬¦©²ªªµ­¢¯§¡­¥Ÿª¥£®¨¥²¬¤°ª¢®©£¯¨¢­§ž©£¢¬¤¦±©³¼´²¿»·Ã¿ «¥¥ ’›•Œ•Š“‡‡†‹‰ˆ“‹Œš‘™™–Ÿ”œ¥›£ª£¡©¢›¥Ÿ§—£š±»µ– š–“—Ÿ™«ª¤›œ—› š¤ž—¢› ¨¢˜¢œ¤¯©ÃÑÊ®»µ”£š“¢• ¯¤˜¦ÌÕÒûÿÿÁÒÑ¥°¨™£›¦®¨›¤™™£™›¦œ« ¥³¨¥°¦ž§•ž”“›‘Ž™‘Ž˜“›‘™¡—¥­£“œ’•›•–ž–œ¡™¥ªžµ·¯½¾·º¼¸»¿¹¦¬¥¤«¥­²ª´·®ßÜÙÿÿÿüþþýýýýþþþÿýýþþøüúÛãÞÆÎÇÄÊÁÍÎÅÉÏÆ×ÞØïôñüþþýþýúýúÙÛÖÿÿÿÿÿýþþýýþþüýýùýù÷ú÷ùþùìñíèïêáéãÔÛ×ÙߨÇÉÁ·¸®­­£­«¡«ª ¥£šœ”ž–¢¤¸º´ª¯ªž¤ž“°¥œÃ·¯ëãàþÿÿýýýþýûèì褧 ­ª£¬¬¤±°¨¸µ®¾»±ÆÀ¸ÍǽÓŽÙÐÇÿü÷ÚÕÎÍʾ½´··±´µ­²°¨´³©¶´ª·¶ª²´«´·­·º±½½´ÀÀ¸ÉÉÀÐÍÇØÕÍäáÛûúõþþýûþÿþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþ™¨ ™«¡˜¨•¥š•¥–¦–¥š§Ÿ™¦ž›¨ œ©¡©¡œ§Ÿ¡¬¤¤°¨¡®¦¤¬¦¥®¨³Âº§¸²©¾º¡¹³¤²¯Ÿ­ª«¦©¤Ÿ¬¥°½´ÓåáÙéå°Âº˜¨¢ž—‰—Žˆ“ˆ‰ˆ‰‰‘Ÿ—œª¡œ“‘–ž”˜ —£« ›¢›”–™¡—­º²µÃ½œª¤•Ÿš•—™ž™œŸš—™“™—˜¡–™¢—–ž——Ÿ˜Ÿ¨Ÿ¤¯¦™¥œ‘•™Ÿ•¥›¦­¦ÂÅÁ§ª¨£ª©¡«¤š£œŸ§Ÿ“›”– –™¤™›©ž¢®¤Ÿ©Ÿ˜¢˜“œ’˜Ž‰•Ž˜‘™”œ’œ¤š“œ‘‘™’–”›¡–¡¤™¤¦¦¦ ¥¥ž¦¨¢¤¨ ¤ª «±§»¾µÔÏÇúøôÿþüÿþþÿþþÿþþÿþþþÿÿåìçÊÕÍÅÌÄÆÉÀÆÍÃÝßÚýýûþþþýýýÿÿýÒÌÈþúôïçåÿþúÿûýÿýýùùùþÿýüþýúýüûÿþõüøýÿÿûÿÿ¼Ã¼¶»²©ªŸ©§ž§§œ£¢˜ŸŸ–™™ž —©«¢´¸³™ —œž•¦ ™µ¨¢ìæàþþþþýüüùöÅÈÁ¢¤ª©Ÿ§«¢­¯¦¸·¯¹¸®»º°À¾´È¾¶ÏļÓÌÂÐÍÄÕÖϹ»µ»º´³´­¯°§°±§³³¨³´¨®³ª°µ«µ¸¯¸»²¾À·ÅƽËÌÅÔÕÌâãÜûûöþÿþüþÿþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþ›«¤šª¢™©Ÿ–¦›•¤›—¤›– ˜˜£š—£š–¤›–¥œ˜¦˜¢™ž© ž¬¢ž®¤¤¬¥©³¬¸Å¿ÑàÝðÿþÔçä¯Á½®¾¼¢±­£²¬¥±ª¤°¨­»´ÂÑʱÁ¹™«¡Žœ“™‰•‰‹“‹š’¦¶®¢²©’ž’–“” “𦛣°¥”œ’–š‘•‹½ÆÀ³À»¬»·Ÿ¬§™¤“œ˜•œ—•š”–“•’“œ“›”—ž–›¤™Ÿ¨«·®š“¡§œ®¶­©°ª¸ºµ°°¬­²®¡ª¥•ž˜“›”“›”“•—¢™š¥žž©¡œ§ž”Ÿ•‘š˜ŽŠ•Ž—˜Ž˜“›“œ’”ž’’›˜Ÿ”¤™ £›¢¤ž£§ ¤ª ¢ª¡¢ª ª°¥º¿³ÎɾàÛÕýýûþýýþþþÿþþÿþþüýýúþüØÞÙÆÎÆÇÏÆÇÍÄÞÚÖþýûüýýýþýþüúÙÏÈäÚÒÝÓÍòéåþùùÿýþýüýþýþýþþýþþúþýúþþúýþýÿÿ¿Ç­·¬©¯¥¤§ž £˜Ÿ –œ’š˜œ™‘¤£™°°«”˜“—™’¡œ”«¢šòíæÿÿÿþùõËü±±¨¥©Ÿ¦¨Ÿª¬¢³³ª¸¹¯¹»±´¶­¸¹¯¹º¯À¹°Ã¹±ÓÓÉçêä¶¶²¾¿¹°°«­¯¦®°§®±§±³©°´«±´«µ¸¯¶º±¼½´Á¹ÇËÁÐÒÉßàÕúøóÿÿüýþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþ¬¥˜¨¡™« —§œ˜¥™™¤˜™£—˜¢–—¤˜”£––¦›˜¨œ•£˜˜¦››ªŸ®¢¡®¦§²«¢¬¦ïõôùþþúþýéøøÕçåµÅÁ¶Â¿¯¸³¨±ª£©¢ž¦œ–Ÿ–”ž“•Ÿ”—Œ˜‹‘›“–£›£µ¬“¥›Œ™”œ‘–¤˜œ®¡¦¶«™¡—••™š•°¶°’˜ÏÝØ¸Ä¿œ•¯¼º›§¡˜’“š‘’š”‘‘š‘—Ÿ•˜ •›¦š¨´©Žž•Ÿ¥ž½ÉÁ®º²§®§¡¥Ÿœ£œ”ž™’›•—‘˜‘“œ”“–” —–¡™—¢˜’“’œ‘—ŒŒ–Ž—•‹’š—ž•–ž•”ž’”ž‘š¢–¥š¤œŸ¥Ÿž§¡© ¥®£¤­¡¬²§¹¿´ÌȽÙ×ÏûúøüýþüþÿüþÿûþÿýýýýÿýîòíÍÕÎôýõÓÖÎÔÎÊüúùúüûüÿýûù÷ÎÅ¿ÜÕÍåß×óïëëéèÿýÿþýÿþýÿþýÿþþþþþþþþþýüþÿÿÿÕßÚÚåݵ¾µ¡¦ŸŸ¢˜Ÿ¢—›œ’˜—™–Œ˜›˜’‘”Ž“•™—¦–ÜÕÍæÞÙãØÒÀ·®¯®¢£§œ¤§ž°¯¥·¹¯À¸¾Á¹¶¼²±µ¬­µª»¹®¼¶¬ØØÎåé⹸µÃÄÀ±³­­°¨­°§¯´¨¯µ©³¶¬±¶­µ¹°¹º±½¾µÀÁ¸ÇËÀÐÓÈÝÝÒøöïÿÿûÿþýþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþšª ™¨ ™¦ž—¤•¤˜”¡——£™˜¢˜— —™£™—¦›—¥›•£˜š£ž§ £«¤¦ª¤¥°¨°¸°ÑÔÐÿÿþýüþúüüìýû¨Á¼ÅÖÓÒâݫލ´® ­¦©Ÿ™¥›• —’œ•œ‘›§ž™£›¢˜‘“›“˜¤š™©Ÿœ¬¢–¤‘™“’–‘ž¦ÆÏÅ ¥œ±·±–ŽŽš“ãôò£°¬•”•“˜Ž– ”—Ÿ”›£›—ž˜“›•‘˜™–š‘Ÿ¢™œ¢—¢˜›¢™™Ÿš˜¡›•›–”š’“šŽ™ŽŽ™•ž”ž”‘•œ–•Ÿ˜‘š““Ž’Œ‘““˜—‘—“”œ”–ž•›£™ž¦œ¥š ¨¢«Ÿ¤®£¦²©©±ª°¹®ºÀµÇÌÁØÙÑüûùýþüýþýûÿþÿþþþþþþþþúúúñòòûýþêòìÎÊÅíãßÿÿûÿÿýïìíº²«ÈÆÂëñìíñïØÕÕþûüüþýüþþþþþþþþÿþþÿþþýþþþÿÿèíêäêæ®±­«ª¦Ÿ¢˜šŸ•˜’–˜Š••ˆ˜•‡••‰““ˆ’‘ˆ˜•Œ«¢™·­¢½­¥½±¨°«¢§¦ž¡§›¦­Ÿ²¶©¶¼±ÀÈ¿Á˼¼´·±±´¨¶·­ÄúÖÓË×Ó̺´¯ÆÄº´³ª°´©°´©³¶«¶¶¬µ¶«¶¸­¸»²¹¼³½ÀµÄÆ»ÈÌÂÓÔÌáÞÖ÷ôïÿÿýüþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþ˜¨™©ž”¤›•¥›“¤˜“¤—”¤˜•¥š–¥š˜§˜¨˜§œ˜¦›žª£ ¬£œ© ˜¢œ§³«°¹±»¼µÞÝÙüþýüÿÿèøõ¯À¼×âßüÿÿËáÝ¥³°¥´­›ª¡—¤˜•¡—‘œ“”Ÿ–– ™—Ÿ™“š“˜ž˜¦±¦°¾´•¦š“Ž˜’™‘”œ’¢¨Ÿšž••™‘‹Œ“‹ûÿÿ¦¸´–‘“–Ž——Ž •¦µª™¦œ•œ––“–Ž“•Š“˜‘˜Ž”›•ž’›£›Ÿ§¡¤Ÿ•œ”ޓЖ‹Ž–‹—Œ™Œ•Ÿ”˜¢šš¦Ÿ• ˜‘œ“Ž“Œ’Œ‹‘‹“™–’•‘–•— –œ¤šž¦œ¡©ž¥®¢¦®¤©²¨ªµ­«¶­³¼±½Å»ÌÒÇÞäÜüýûþýþþýÿýýÿþþþþþþþþþüüüþþþüýýøüúãÞÛÐÅÁú÷òÿÿþÀ¼ºµ¶­ÆÊÂùýøèìèÛÝÙþýûüþþþþþþþþþþþþþþÿþþþüüþÿþúüúûüùµ·²¥¥ž¡˜—ž““š“˜‹””ˆ•“…“’‡‘’‡†•”‹£Ÿ”§¢˜±©ž²¬¢§¤›¡¢˜ž£—©­¡³¹°ÜâÚÿÿÿôú÷ËÓͪ´­µ½³ÁÇ¿ÊÎÅÌÍÄÉÉÀ²¯¨À¾´··­²¶«¸¼±µ¹®´µ«³·«·¼±¶½³·½´¿Ã¸ÇË¿ÉÏÄÖØÍâà×õòîÿÿýüþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþ™¨ ˜¨”§š”¦™“¢•”£–“¢—’¢˜—§Ÿœ¬¤œªžœªŸ ­¡¨¶¯£²ª¤³«ÁÔ̱¸®·­¸º±ÂĽÀÉÂÃÌÇæòî­¶³íñïúÿÿîüüÂÓÏ¥¶±ž¯¦–¦š•¢—“Ÿ“‘œ’‹—Œ“œ”—ž˜•”¥›¯¸®ºÇ½¢¯£“¡•”’šŽ˜—•˜–—Ž™–‘•“üÿÿ°ºµŒ“‹•—Ž˜—Œ£¢™ÅÓȱ¼²•ž•–‘•Œ‘“Š‘˜“œ‘— •¥­£¨±©©°©ª­©™–Ž”ˆŽ“‰“‰Ž–‹˜Š’›œ¤ž «£”Ÿ—š’Ž•Œ“ŒŒ”‹˜Ž”œ’•’–ž”™¡—œ¥› ©Ÿ¤­£¨°¦«´ª­¸®¬¸°¯¼´¹Ä»¾É¿ÕßÓîôìþþýÿþþÿýÿÿýÿþþþþþþþþþÿÿþýýüýüûýþþÿþýÓÎÉéåßñòë¾¾¸ÀƼÁÆ»íïæÛÛÒëëäýþúþÿÿþþþþþþþþþþþþþþþÿýüýüùáàÝáãÞ£¥ž©«¢¤›–ž”’š‘™‘•‰‘“†“”ŠŽ…Ž…“”‰™™œœ’¤¡—¥¤šŸ•œ •ž¡–©«¡­²­ùúúþþþýÿÿàæä¬º´ÇÍÈÅÊÅÒÔÎÈÊÁËÉÀ¸·­¼½´·¸®¹½²ÂÆ»´¸­±µª´¸¬¸¾³¹Á·»Ã¹ÀǼÉÍÁÍÔÈØÚÏæäÜ÷ôðÿÿÿþüÿþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþœ«£™©—§›•¥—”Ÿ“• ”“ž“•Ÿ•™¦œ›§Ÿ™¨œ™§œž¬ ¤±©›© ÑàØòÿþÂÔÊ´Á¶¾Â¹ÁĽÛäÝ÷ÿûýÿÿëîííïîýÿÿöÿÿÏßݧ¹³Ÿ°§—§“£–‘ •›’‘œ’‘œ’‘›–Ÿ•— —ž©¢Ÿ­¡•¤™’ ”Ž›‹˜Š•Š—Œ‘–Œ—˜œš‘ •¿º·œ™’‘†•”‰’”Š˜š›ž•’˜’—Ž‹•‹Œ•Љ’ˆŒ”‰ž¦œ• –𦛥­£œ¢˜•–’“‹“ˆŠ’…Œ”ˆ•Š™‹‘™£¬¡¯·°• ™Žœ‘Ž•ŽŽ–‘™™’›‘”“–ž”˜ –¦œ¡«¡¦±§ª¶«¯¸²´¿¸°½µ·Ä¼ÃÏÇÙãÛëôéîôíýÿüÿþþÿýÿÿýÿÿþýþþþüþÿÿÿþÿüûÿþùýþþÿÿÿÜÛÖÐÎÉöùñÂÈÂËÏÅ¿Á¶ÉļÌĽñìæúöîÿþþþþþþþþþþþþþþþþþÿÿÿääàÕÔÐëêå±´­«®¥ §–ž•”œ‘’𔉑’ˆ‘“‰Ž„‹ƒ’”‰‘•Š–šŸ•œ •™ž’˜‘ž¡–¬¬¡¾¾¸ÿÿÿþýÿûþÿñø÷ßì庹¶Ø×ӯľÃÀ¸Á¿´¼¹®½¿¶º»²¿¿¶ÃǼ¸¼°³º­¸¼±¼Ã¸½Å»¿Ç¾ÄËÀÌÐÄÑ×ÌÚÞÓåçÝôôïÿþýÿýþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþœ¨Ÿš¦›˜£—𣗒”’œ“’œ‘–Ÿ–˜£˜—¢—–¤™™¦›¨ž¢ª¤«µ­ÝåßäîéÂÑÊÂÒÈÂÊÁéîéþÿÿûýýüþüô÷öîóñíóñûÿÿâí믽·œ«£›«Ÿ—§œ’¢˜“ ˜’¡—’¡•”¤—“¢–¯½²¸Ê௩œ­£•¥š‘ “œŽ˜™Ž˜Œ•š‘›ž•›š’œ“›•••ˆ’•‡‘…“–Œ•—Ž’–Œ‘–Љ’…†„„ƒ–‰ª²§¥®¦˜’“™‘“‰‰’‰Š’‡Š”‡Š”‡Ž—‹‘˜ˆ’˜˜Ÿ•™¢™’ž”Žœ‘Ž˜™”ž”‘›‘’œ’– •›£—œ¥š ©Ÿ¢­£ªµ¬°½´µÃ½½ÍžÎÃÁÑÆÓÞ×ò÷ôõùóó÷óþþþþþþþýÿýþþÿþýýþÿüþÿþþÿýú÷û÷ñÿÿÿÿÿÿâãÝ»¹³ÖÖÏÑ×ÑÐÑɺº±ÆÃ»ÒÌÄîåÝñæàýûûýþþþþþþþþþþþüþþþýýúøøÆÅÃÝÞÙÚÞÚ­´«¡¥œ˜”•ž“•›’‘–‹”•‹”‰„Žƒ‘’†’”‰”™™œ’œ •—‘™‘Ÿ •§¦ËÁ·ÿýùÿýþýþÿþÿÿÍÐÌ­©¢Éƽ¹¸®¸¸­¹º®º»°º¿¶½¿¶ÆÇ½¿Â·ºÀ³¸¿³ÁĸÆËÀÄÊÀÅÌÂÌÐÆÒÕÉÚß×èêáäæÝóóìýùöÿüüþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþ™¥›—ž•™Ÿ•˜”Œ–Œ›”Žž”‘¡””¢•’¡”‘Ÿ•–£™›¤š§¯©±·±¯³­°¶°ºÉÀÑãÚÞêäûþýþýþÿþþýüýøýûí÷õÈÑÌÊËǼÅÁ¶Á»³Â·µÄº™©¡–¦Ÿ–¥ž”¤š“¤—˜©›”¥˜ÚêàßôñÁÖЪ¼´˜¨Ÿ“¢–œ’›“ž’’ž’– •—Ÿ–’•””Ž”‰Œ”„Œ’…“ˆ•—‘š˜‹”‡‰ƒ‡‹‚Š„’‡”œ‘‘™’—“‹’‘ˆ‘•˜Ÿ•Ž™Œ‰—‰‰–ˆŒ—‹‘šŠ—‹“˜Ž™‘œ’’›‘’“˜£™–¡——¢˜˜£šœ¤˜¦š ª ¤°¦ª¸¯´Áº¾ÍÆÊÛÓ½ÎÄÍÛÑãìæùþúûýúýþýÿýýþþþýþýûÿýÿÿýýþÿüþÿüþþÿÿüëäÜúññù÷ôÞÛÖǾºÇÀ¼ÄÅÀÅÆÀ·¹³ÅÇÂÏÏÈæßÛêÞÙöóôÿÿÿþþþþþþüþþýþþýýýÿÿÿÓÒÑÿÿÿÞâÞ§®¨Ÿ¢™šž•—œ“–›’’•Œ‘“ŠŒ‘ˆŽ‘…‘’†““‡““ˆ•–˜™–™—›™‘¡¡–¨¦Æ³¦æÝÔÿÿýüýþøöõÑÌɧ¥œµµ¨²µª²¸«²º®²¼­¸¼¶ÄžÉÊÀÅÆ¼¾Ã¶»ÄµÇɽÌÎÄÆÊÀÓ×ÎÖÙÎÜÞÓïòíÿÿüõøðüüóüùôÿüúÿþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþ¥›— –•ž”•ž”Ž’ž“’ ••¢—”Ÿ”“”’ ”˜£–˜¡–²¶­¿Ä¼®²­²¼°ÇÏÆ¹À¹õøõþÿÿüþûþýþÿÿþýÿÿîñïÑÒÐÌËÇÄÍÇèôóÓæçÆÜÚ ³­œª¢œ©¡˜¨œ’¦—”¨šŸ³¦êöòíöóÇÓÌŸ¬¥¢®¦ž¨¡™¡œ—£™š£˜›¢—œ£˜š¡˜”›–”š•••˜‘‘‹•”ޓЋ’ˆ‹“‰‡†‡Ž…‡Ž„‹”…”›Œ”œ—’˜Žž«¤©µ®—Œ˜™Ž‘“’›‘‘™“’œ•ž“ŽŸ’Ÿ–“¡–˜§›—¦šš¦œ›¦›¦žŸª¡£®¤¥²§­º±µÄ»ÍÚÕëøóÒàÕÝéßêóìöýùÿþüÿþýÿÿÿþþþüþÿüþÿþþýÿÿþþþüüÿüþýùèߨØÍÂÝÐÊÚÒÏ»¹¶¸µ¯¼´¬±®¦ºµ®ÍÈÁÓÍÃßØÎæßÖöòðÿÿÿüýþüþÿÿþýÿþýÿýýýüüúúúþÿþÝàÜ¡¥ Ÿ” –˜’•›‘–‹”‰“ˆ‘†Ž‘‡†‘†’–‹“–•”‹•—‹— —§£œ¸©¤ÓÆ¿ûøñÿÿ÷äàÙµ¯ª¯°¦¯²¨²¶ª´¹­ºÀ¶¹½·ÂĺÅǽÇËÀÆÊ¿ÂǼ¿ÄºÆÊ¿ÑÕÊÔ×Ê×ÛÐÖÙÐåçáýþþüýüûüüüýüûûûýýüþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþœ¤šš¢˜•”•Ÿ”Ÿ”Žœ‘ž’“Ÿ•š‘œ’‘Ÿ“•Ÿ”˜¡—œ£™¡§Ÿ¤¬£§®¤©®¤±³¬À¿¹çãàÿþýÿÿþùøöÐÑÍ»¿»±´®²µ°èêçûÿÿêø÷ßîí­¿¸¢±©—ª ”¦š”¦˜™ª›¦±¦½Å¼µÁº“ ™¥µ¬©¸°¨¶±œª¦œ¨ŸŸ©Ÿž§›™¢—™¢™–ž˜¤³®ž©¤™£›—•Ÿ”‹–Š‹ˆŠŽ…‡Ž„‰‘‡‰’ˆŠ’‰˜‹”‘˜¡—¡°¤’”œ’µÂ¸¶Ã¹™’œ”Ÿ’’Ÿ‘“ž’œ—Ÿ—™£š’Ÿ““¤–—¦—§œ›©š¨œœ©žœ¨ ©¡Ÿ¬£¤³§©·¬°À¶¾ÍÆÛäáøÿüêñêîõð÷ü÷ûÿüÿþýþþþþþþþþþþþþüþÿüþÿþýþüýþúþþÿÿþÛÕÑÐÈ¿ÐÈÂÑÎɺ»·³´¬¯¬¡®«¤´¯¨Â¼µË¹ÎļÓÉÀñçáÿÿüÿÿýýþÿüþþýþÿûüüÿýþÿÿÿÿÿÿÖÓΞž–¢¢——šŽ™œ‘”™’–Š”ˆ’’‰†Ž…ބބ‘‘‡’•Œ’’ˆ”–Š–œ¡–¦¤œ·¬§ÐƽÝÒÉùô꼸¯´²©­±¦­±¦±¶©¶¼±ÅÊÁÄÉÁÈÌÁÉÏÃÌÑÆËÑÆÅÌÀÅÌÁÊÎÂÐÔÈáæÚóöìüþùûüùþþþþþþþþþýýýýýýþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþœ¥›—Ÿ•–Ÿ”– ”•Ÿ•‘“›‘‘›’›‘‘›’’ •–Ÿ•–ž”—Ÿ•œ¥› ¨ž¡«Ÿ¥®¢¯³¨¼º²ÈüÑÊÄÑÎÅÁÀ·°²ª­±ª©°©°¶¯À½¸ïðëÃÊǰ½¸²Áº¨·¯ ¯§˜§š§›Ÿ©ª±¨²·±§µ­¬»³ÒâÚÇÚÑÎâÛ£¸¶¥³©£¯¥ «¡ž¦œœ¤ž¦ŸÄÖÒŸ¯©ª¢‘Ÿ”›§œŒ›‹ˆˆ…‡…‰‘†™˜’Ÿ—˜ ™®¹±¡²§–§œ“¢—ž­¡š¥š›’œ”Ÿ‘”¡“‘ ”ž’š¤˜¢¬ –¥˜•¨˜˜¨ž–¦›š«ž™§››ªžœ©¡ž«££±¦¨µª®¼°»É¾ÉÕÍôø÷ýþþüýüüüüÿþþÿþþþþþþþþþþþþþþþþþþþþþüûýùúÿÿÿþþþöõóÏÈÄÎÉÄžºÄ¾¼¿¹µ¼²¬®£©§Ÿ¬¨ ¶­§¸¯¦À´¬Ãµ­ÜÊÀøíäÿýùÿÿýüþÿúþÿúýþûööàÔÒæÛ׺²«£¢˜žž’—˜Œ•™’•Š‘”ˆ‘”‡’‘‡‘‘‡……Ž„’’ˆ“ˆ““‰”–Œ–’›¢—¦¥›¸¶¬ÓËÂä×Ëÿýöľ³¯´ª¬²§©¯¤°·«½Ã¸ÍÓÇËÐÇÖÜÐÜá×ÜáØáèÝ×ÞÔÎÖÌÒÕÉÝáÕòôëýþùþÿýüýüþþþþþþþþþþþþýýýþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþž¢š –—ž”•Ÿ““ž”’“’“›‘‘œ’›‘“ž”“ž“•“—Ÿ•›¤šž¨™©ž«Ÿ©²¦®µª»»³Á¿·¾½²À·±·¬¦®¤¤¬¡£©£«ª¡¥¦ ¯´®ÏÖÑÁÍŵļ®·¯¤¬¤Ÿ§£¯¥©µ¬¢°§È×ѺÉÀÊÙÐÑâÙñÿÿ³Éķö«¶­¬·­¤°¨¦Ÿµ½µÔâÞ°»·’–•“•Ÿ“Ž—‰‹”ŠŠ’ˆ‰‘‡Ž–Œ–ž•¢« ™¥œ–Ÿ˜³½¶·Ç¿Ÿ±§–¦›•¡—‘œ‘Ž˜Œ™Ž“Ÿ“‘Ÿ“¡“”¢•§œ ªž¬Ÿš¬žž­¤­¡œ­ š«žž¬ ª¢¡®¥¥³¨«¸¬´Â¶ÁÎÃÕߨúúúþÿÿÿüþÿýÿÿþþÿþþþþþþþþþþþýýýþþþÿÿÿôïéóéåðæáùöñðíæÔÌÄÇÅ¿·³¯¾º·ÇËÅÄÊÀ¬­£ª§Ÿª¦ž°©¢±¨ž¶«£¼°©Ð¼°ãÓÈûòéÿûöþþüþþÿÿÿÿýöõÏÁ¾Ñý¾¸¯žž’›š‘—˜Ž“˜Œ‘”Š“ˆ‘’ˆ…‘†…†…†Ž‘‡““‰’•Š”œ‘™¡– £™«­£´°¦Áº®ÈÀ²´µ«®´ª¬°¥¯²¨·º¯¿Ä¹ÕÙÍÏÒÇäêÞôøñûýúûÿüæîåØáÖßã×ìðçûü÷þÿþþþþþýÿþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþŸ¢œœ —˜Ÿ“•Ÿ’”“•ž”““’“’“š‘œ“‘›‘‘š”ž”™£˜˜¦™˜¥šœ¨œ¤®¤©²¨®¶­´»±¶»±¯¶«¥®¢ž©œž©ž¨ §œ§­£­³©ÍÕ˹û¸Å½°¼´¨´¬¤°§¥²©²ÂºÕåÞåöóÇ×оËÃÁÌÅöÿýÊÚÓ¸Á¶µ¿´»Ç¿°¸°¦®§—Ÿ”©²¬›¢œ‘—‘™—Œ—‹ˆ”Љ”Љ’ˆ‹“‰“‰›Ÿ—˜¡–˜ •¤œ–¢™˜¨ ‘ —Ž™™—˜Žš‘œ’Š’ ”œ§š¦°¤«Ÿ¬¾±¤µ¬œ¬¡®¡­¡ž®£ ®¦¦¯¥ª´©²½±»Å¸ÎÖÌáêàþýûÿþþÿýÿÿýÿÿþþÿþýüþÿþþþþþþÿþÿþþþþýûéãÙåÚÔåÛÖÚ×ÐÍÊÃǺÇþ¸°¬½·²ÒÒÌ×ÙÓ±¯ª£¡™¢ž—¨¢›¬¥­§ž²ª¡Â´ªÖɽêÞÓûðèÿùôÿüùöòìäÝת¢›»´¬¶µª›Ÿ”•–‘”Œ’‹“‹Ž’‹“‹Ž††ƒŒƒŽ„†Ž’†””Š“–“œ’˜¡– ¥˜©­¤¬­£°±¦²²§ÄȽÄÉÀ·º¯¿Â¸¾¾¶À¿¶ÌÍÂÖ×Ëôöïýÿüüýüüþýöúöéîèðóëûýøýþüþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþýýýýýýüüüþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþ ¡› ——Ÿ“•Ÿ’˜ •— –“œ’‘œ’‘’›‘‘›“’œ““œ’–ž”˜£—”¢•š¡˜šŸ™¡© ¦®¥¨±§ª²¨®¶®§±§ª ›©š§š›§™™¨œŸ«Ÿ¢«Ÿ¢¨£¬¢ºÆ½Éßխ¸´Ã»Ÿ¬£ÐÞÕôþúêüúÔâÞ¿ÈÁÄËÄÎÖÌÈÐÆÀɽÀɾ¼Å¾²¹´¦­¥“–Ž´º±±¸¯•‹•‹‹–Œ‹™Ž†—Œ‡—Œ‰“‰•‹“Š‘ˆŒ”‡’–Šš’— –’Ÿ—œ•Ž™‘“š”—‘•މ•‰—‰œž”˜¡—¤¬¢œ©Ÿ±Ä··É¿®¤œ­ ž°£¢²§¤²ª§±§¬µª¸ÁµÂ˾àåÜùýöýþüüÿýüþÿüþÿüþýüÿýüþÿüþÿþþþþÿÿýüûåäâÛØÓÒËÇÕÏÌØÖÓÉËÆ¸¸²¹³®·¬§µ¬¨ÊÇÂÙÙÕ¬©§¥Ÿ˜¡–£ ˜¤¢˜¦¤™ª©Ÿ¿µ­ÒÈ¿ÙÍÁíÞÔöæßàÎÇÖÊÁÌúª§¨¨ž§­¢–“’“Ž’Ž“Œ“Ž•““ˆŽ’‡‰ŽƒŒ…‹„†Ž’†””‹“–”“—¡–ž£˜£§ž¥©¡¨®£¯·¬×ÝÔ·»³¾¾´ÊÉÀĺÇüÉǽßÝÑÿÿþÿýýýýþþýþýþüúþúüýøþÿüþþþþþÿþþþþÿýþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþýýýüüüûûûþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþ ¡Ÿœž™œ¡˜š¡•›Ÿ”™¡—Ž”•‘¡•‘ ’•‘’ž‘“£–˜¥™—¢˜™¡–˜¡–›£šŸ¨£¡ª¦¡®¥¥±¦§²¥¢­ ž¨œœ¦š™£—œ¥™š¨Ÿª ¦ª¢¦¨Ÿ©« ¹¿²éùïèúòÍÞÕ²»¶ïöóòýüóýýçñíÅÎÇÁÊ¿ÅÐÆÈÓËÅÑÉÃÌÅ´¼³ª°§¡¥œš”¨ª¡ª­¤–š‘Ž”Š˜Ž˜Ž‹˜ŒŠ—‹‹”Œ‘˜‘•ŽŒ‘ˆˆ‘†‹“ˆŒ–‹‘››Œ˜ŒŽ™›‘‘š‘š˜Œ—“ “•’œ¡—Ÿ¥¨­¦£ªŸ ªžŸ­Ÿž­Ÿ¥¶§¦¹«ª²ª¯¸®¾Ä¹ÒÕËôõðüÿûþþþþþþþþþþþþþþþþþþþþþþýþþýÿÿýþûúúÞÝÛÚÕÑÏÊÇÇ¿ÅÁ½À»¶¼¶²··®²ª£³§¡È¾·ÕÍÇ©¡š£ž—¢œ•£Ÿ—¥¢š¦£›ª§Ÿ»¶­ÌƽʹÜÑËéÜÖÑÁ¼Á½´¶´ª¨¦›¬­¡­³©•”’–Œ•˜’–Ž“‹”Œ”‹‘Š’ˆŒ„Žƒƒ‘†”‰’˜Œ”›”‘—¡•™¤˜¡©ž£« ¦®£±·¬Ö×ÍÓÐÆ½Â·ÂÅ»ÅĹÍÍÃÊÈÃõõóþýüÿþýÿþýÿþþþþþüþÿüþþüþþüþþüÿýüÿýüÿýþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþüüüýýýþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþ¡œœ¡›˜ –˜¢–Ÿ¥›¢œ–ž—š¡š¤¬¢ž¨œ” “Ÿ®¢¥¶©›­¡˜§œ™£™—£—™¦œ¨¢¦µ°¼ÌIJ·¨µ­ ¬£›¦›—¡•”ž’—¡•œ¥™¥›ž¨ž£«¡¥«¡·»¯ÝçÞÞëàßë⺿ºÙàÙöþúâïìÆÒÌÁÌÂÃÎÃÈÓÉÑÞÒáïèºÈ¿¬µ®§¯¥¡¦œŸ–œ —™›’•Œ•Œ˜ŽŽ—Œ‹˜‹‰•Š‹—˜‘Ž—ŽŠ“‰‡„‰†Š”ˆ—‹˜Œ‹–Š•‹‘™˜Ž’œ’ššŽŸ‘’Ÿ’š–œ’œ¡šœ¤œ›¢˜§›Ÿ«ŸŸ®¢¦¶©ª¼®®¸­¸ÁµËÒÆÞàÙýýúüÿþþþþþþþþþþþþþþþþþþþþþþþþþþýÿÿþÿúùøÝÜØÒÒÎÌËÆÅ¾»·²°­¨±«§°®¥­¤®¢œµ­¦µ¯¨¡š“¢›”£–£œ•¢–¦¡š¦¢š´®¥Àº±À¸¯¾¶¯¼²«½±«²®¨ª¨Ÿ¥¤™­°£²¸¬”œ’•›’™ž•“˜•Œ“˜•Œ•Š”‰“‡Ž‘…Ž…‡•‰’˜”›”œ‘˜¢–š¤˜ ¦›£ªŸª¯¤°´©¸¸®¹·¬¸»¯µ¸¬ÀÀ´ÉÈ¿Ø×Òþþüýýýýþÿýþÿþþþþþþþþþýþÿýýÿýþþýþþýÿýýÿýþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþýýýýýýþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþž¤Ÿœ£œœ¥›®º®ž«¥ ©£¡› ¢¨®¤œ¦š‘š‘ÁÎÄÜìá¶Æº©žš£™™¦™¨Ÿ¬¶°ñø÷õÿüÛêä±Â»¡¯©˜§œ—¢––Ÿ’™£“ ¥™Ÿ¨œ¤³¨®»³¤®¤±·­¿Ã¹¿Æ½º¿¶ÃÄ»ÔÖÒð÷ôãñé½ËÄÈÓÉÈÑÇÉÔÉæñçóýúÎÛÕ°½µ«¶­¢« œ¢˜œŸ–•™•’˜Ž“œ’˜Ž‹•‰Œ•ŠŠ•‹Ž™Ž†•Š…’‡Š’†ˆ…‹“‰Š•‰Š”ˆ‹•‰Š’ˆ•‹Ž–Œš™’ž’œšŽŽ––ž”š¢—œ¥˜ž§œ¡­¡¤°¤ª¹¬±¿´¸Â¶ÃÌÁßäÝóóðþþýüþÿþþþþþþþþþþþþþþþþþþþþþþþþþþþÿÿÿø÷öÙØÓÐÒÎÌÌÉÀÀ»»·²­©¥©¦ž¨¢›§œ•¬Ÿ™«¤œ •ž˜‘¥›”¤›”¡™’£œ•¥– š”§ —¨£šª¥œ®¨¡°©¢¯©¡«§£§£œ Ÿ•¨ªž©®¢™¡•œ¦œŸ§”˜“˜œ¡˜’–Ž’˜ŒŽ”ˆŽ•ˆŽ’†’ˆ’‹’™Ž”œ‘’š•Ÿ“™£—š£˜ ¥š¥«Ÿ¬®¤±²¨´²¨³±¨µ¶¨±±¤¼»±ÅùÞÜÖÿþûüþÿüþÿüþÿýþÿþþþÿþýþýÿþýÿþýÿþýÿþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþÿÿÿýýýþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþ¡©¢¢©¢¡©ŸÏÙÏÀÓФ´° ª¤œ¤™¡—–Ÿ•—ž•£ª ¬´ªš¢˜š¡—š¢˜ž¤š¢§žÃÆÁÿÿÿõûúóûù©¹´¦·®™¦ž—£—”ž’›¥–Ÿ¢–¢«Ÿ¶ÅºÁÓɦ´©«´©¯±«°´¬´¹®¼½´ÇËÿÉóĹÂÑÇÙáÚèðêõûööý÷÷þûäïéÁÍÇ®»³¤­£¡™¢™—œ““˜Ž“˜‘—‹’‰‹”ˆŠ“ˆŒ•‹‰”Š‹—Œ†•†Ž•Š‹“ˆŒ”‰‹“ˆŠ”ˆŠ”ˆŒ”Š•‹™šŽšž“’ž’‘‘œ™”œ’š¢˜›¥™Ÿ©¦¯£¨´©¯º±ÅÓÉÆÐÄÑÙÎñõðýýüþþÿûýþþþþþþþþþþþþþþþþþþþþþþþþþþþþÿÿÿîîê××ÐÓÔÐÍÎÇÀÀº¶´®®¬£«¨ §¡š§›•©ž˜¤ž— •ž˜‘¤›”¢™’Ÿ—Ÿ—–— š“£–¢ž—¤¢˜§¥›©¨¦¢ž£¡™ Ÿ•¢¢–¢—¦™¨±§œ£™›Ÿ–™Ÿ–›¢˜“›‘“›‘š–‰Ž•ˆ”Š’–Ž”œ’•’“‘˜¢–œ¦šœ¦šž£˜¥§«¬¢¯­£±±§°¯¤²²¥²²¦·¶¬ÂÀ¹ØÕÍÿþ÷ÿþûýþþüýþüþÿýþÿÿþýÿÿÿþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþýýýýýýüüüþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþ¦­¥©¬¢¦«¤äæáôÿÿ¾Îˤ²¬¢­¥¤œœ¢š™˜šŸ™–”•›‘˜ž•™Ÿ–¡¢š©§ Å½ÿÿÿûýüõúù´Å¾«¹²›ª¢•¥™“ •˜¤˜œ¦™£¬¢§¶«±Â¶¨·¬¦µ©¬±¬¬´«±¹­¸À³ÍÓÊÜéâÛéàì÷ïôùõýÿþýþýüÿûýþþüÿÿ×áܾË®¹¯¢¬ ¤© ¢§ž—œ““˜•Œ‹‡Š“‡‰‘‡‡†Š’ˆ‹–‰Œ—ˆ•ˆŒ“†‹”‡‹•‡•ˆŒ•ˆ‹”‹Œ•‹™™š’’ž“‘‘Ÿ”‘“”Ÿ”š¢˜§™ž¨›¥°£¬µ¬¼Æ½òûõËÕÉÝäÞüÿýýýýÿþþüþþþþþþþþþþþþþþþþþþþþþþþþþþþþþÿýüããÞÕÖÌÓÑÌÎËŽ¹¶³²©ª¨ ¦¤›¤ž˜¤š“¤›“£œ•¢œ”¡—Ÿ˜‘œ•Ž•š”Ž–‘Š—’‹˜—Žš™‘œœ“œ’¢¡—§§¦£œ£¢™  •¢¢–¡¤™ ¥›ª³©› —£¥œ«°§¯¹®¸Äº›£˜š£˜˜‹˜‹–Š‘˜Ž•ž’– ”˜¢–›¥™œ¦šœ¥šž¤™£¦œ¦§©©Ÿ¤¦›ª­¢­­¢¬¬¡´²©¾»±ÐɾìãÖþûôÿþüýþþüþÿýþþÿþýþþûÿÿüÿÿýþýýÿÿþÿþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþýýýþþþþþþýýýûûûüüüþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþª°§­°§¥¦žæäâùÿÿÇÑб¿¹ÂÎŤ©£¤¤žš¢œ•––œ—”““œ’– –œ¡—©ª¢¹¶²üüùúüüùþÿÁÏÇ©¸°œª£—¥‘¡••¤™›ªŸ¤±¦½ÉÁµÂ·¨º¬­À±©´®©·¬®½¯¸ÂµÅÐÄÖäÞæñèøÿúûÿþþþþþýýþþþÿüýÿÿÿíôðËØÐ´Â¶¨´¨©°¦§«£Ÿ£š˜”“˜”ŠŠ’‡‡„ˆ‡“ˆŽ•Š—ˆ•‡Œ“†Ž•ˆ–‰Œ•ˆ’š™˜Ž‘›‘’›‘š’œ’–Ÿ•’ •’ •“¢•™¤—œ£˜¨›¡«ž©³§«´ªÑØÒýÿÿâêäéïëúþþþþþþþýüÿýþþþþþþþþþþþþþþþþþþþþþþþþþþþöôóÝÞ×ÑÑÈËÆÁÅÁ¼º·°±®¦¨¦ž¢ ˜¡ž–¢™’Ÿ– š“¢›”¢–›•Ž˜’‹˜”Œ˜•Œ”’Š“ˆ’•Œ•˜˜™™š¢¢˜®¬¢³´«ª©Ÿ¦¦š¥¥™¦¨Ÿ¡¥œœ£™Ÿ£šµ¸¯¥«¢ËÖ̳ķ¤¬¤– ”’›Ž”œŽ˜‹‘™Œ“ž’—¢–— ”™£—š¤˜š¥˜›¢— ¦š§¨ž§©žÐÖʶ½±ª­¤§ª ±°§¹µ¬Ç¿²ÙÎÀòéÞÿþ÷þýüüþÿþþþÿþýýþøúøòûú÷þüùÿþýÿþüþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþýýýýýýýýýþþþýýýüüüýýýþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþ°³­µ´¯¯®©ÊËÄñ÷õ©¯ªÂÇÃßè⦬§££Ÿ›¤›š¤™©”Ÿ•• –˜¡—š¢˜¨®¥­°¦ñîëÿÿÿÍÙ×§µ¯¢¯¦¡¬¡œ¦š˜£˜©Ÿ¥¬ ÄÕÎÕíçÑãÞÂÍǸŻ®·¯°º²²¿µ¹ÅºÅÐÄÔÝÒçëãùûöþÿýþþþþþþþþþþýýûýþôûøÔߨÂËÁ®¹«©±¨§¯¥›£™™¡—“›‘Œ–Œ†•‡‡…Š…‡”‹•‹Ž‘†Ž“†–‡Œ•ˆ–Š™“œ’‘›‘›‘›‘œ‘ž”’£–“£––¥™—£—˜£—š¤˜›¥¡©¡«³¨°¶¬ëìåìëäÛÛÚúüúþþüþþþþþþþþÿþþþþþþþþþþþþþþþþþþüÿýüÿýþÿýðñîØØÑÍÎÄÃżÂÁ¸¹¶®±®¦«¨ ¤£š ˜¡›–œ– ™¡“™ž–˜“Š›—“—–‘•–“”Š––‹™™Ž•™Ž™’¤¥Ãú±´®­¯¥¨¦œªª ¬­¦¡œœ ™³µ¯¿ÀºÅÅ¿øúö»Â¼©­§š ˜”’“œ’’™Ž’˜’›‘•Ÿ““ ’– “™¢—›¢™™¤š §œ§« ±µ«ÝäܶÁº­«¦ª¨¡±°¦µ´©¿»¯ÍǺäÐÇñàÙþùõÿýûÿüùûôðøéáôêÞ÷îäþøõÿþþüÿüþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþýýýýýýýýýýýýýýýüüüþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþ°¸²±¶°¶¸±¸µ°ÐØÒ·½¸ÅËÆÚäÞ¨°ª¥¦¢œ¡™œ£›¢«¢š¥œ—¢™• —™¡—¢«¡ª®¤àÜÙÿÿÿãîìÆÏÊ£±¨—§›—¦š—¦š¥°¦¨°¨ïûøÛì黯Á¸À¸±¿´°·±µ¾¶µÀ¶½È¾ÊÓÈÕÞÓëìæýÿûþþþþþþþþþþþþÿþþüýýøþüí÷ñÆÓɰ¾²¨±§¥®¤ž¦œš¢˜–ž”Ž˜Ž‰”ˆ‡‘…‰…Š…‹†Š‡……“†”†Ž–Š“›‘•Ÿ•“œ’›‘‘›‘‘“’ž””¤—•¤˜˜¥™—¢—œ¦šœ¦šœ§Ÿ£«¢®¶«¶»°òôìèèáèçæÿÿÿýþýþþþþþþþþþþþþþþþþþþþþþþþþþþþüÿýþþýÿÿþíîé×ÚÒËÌÂÀúÁÀ¸»¸°±®¦¯¬¤¥£›Ÿœ˜ œ–ž˜‘Ÿ™Ÿ›‘œšŽŸ—Ž–ž›•œ›•–—Ž•–——Œ˜—™™œœ’¤¢™ÆÂ¹Á½·³±¨¨§§§´²©Ÿ›– ¤šÑÓʰ±§¦¨ŸÌÏÆ¬µªž¤š–œ’–ž”›¤š‘—–Œ–™“š”– “™¢–›¢˜›¦›¡©Ÿž¢˜ÏÒÈñõí´¸³ªª ©«¡¬¯¤¶¶«¼º°ÅÀ¶ÙÎÀçÜÐñãÙ÷éâôäÛíÝÒæÚÒæÝÐìäÚûöñÿþÿüþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþýýýþþþþþþþþþýýýþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþ°¿¸¼ÇÁ¶¸²¶³®ëñíÎÒÎÉÏÊÆÑ˨±«¤§¢ž˜˜œ–™ šœ§Ÿš¤œ™’˜Ÿ•ž§©®¥À¿·ÖØÓ¼Å¨¯ª—¤žÁÖÍ¢µ¬œ¬£›¦žÁÍÅõÿú¾ÇÁ®´¯²¼±­»®­¸®³¾´¾È¼ÆÎÇÚáÚäèâøùõýþûþþþþþþþþþþþþÿýþÿÿÿúýü÷ýúÌÙϴĸ®¸®¨±¦¦œ›£š•ž”™Ž–‹‰’‡ˆŽƒ‰„ˆŽ„‰ŽƒŒ„Ž…’‡Ž”…•‡—‹‘›‘’›‘•ž”“ž”• –• ––¥˜™¦š˜£—•¡•™£—œ¦šž© ¤­£¯·¬µº±ËÍÆòïêüýüþþýþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþóóðÛÝ×ËÏÅÇÈ¿ÁÁ¸º¸°´²ª°®¦¦§ž¢ ˜¡Ÿ— ™“ œ’¡“žœ’¡™ž™‘£ š¢žšš˜–•Š–•‹˜—™˜ŽŸ“§¡™¯¦½´­µ´«¦­¡ž£˜¢¢˜¢›’¼½´ÜÝÔ ¡˜®²©¦ª¡š –•™•œœ¢—£©ž˜ž•“Š–•“–Œ‘™Œ”ž‘˜¢–›¤™¥ž ¨§« ¼¼³ßß׳´­©­¢¨«Ÿ®±¦µ¸­º¹°ÄºÐÎÁâÙÎåÔÉèÔÉæÔÇäÕÇÝÖÍâÛÏêåÚû÷óÿþþüþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþïüúÖâ๾¹¸¸³¾Á»²³­ÏÔÍÇÑÉ®¸±¢¦ œœ•”–•œ•¢ª£š¥œ™‘•“Ÿ©ž¥¬¡´´¬ÍÐÊÒÚ×¢¨£ÊÔÏôÿÿ¾ÒÊ›ª¢Ÿ©¡¾Êȟ©¯¨¸¿¸²½±°¼°²½³¹ÄºÉÑÊåìåÿÿþýÿüþÿüþþþþþþþýÿþþþþÿýÿýþÿþþýþþúÿýÛçß½ÌÁ´À´§²¦Ÿ§œ¥š–ž“’œ’—Œ“ˆ‰„‹’†‹…‹„ޅބޑ†•†Œ“…‘˜‹“›‘“œ’•ž”•ž”“ž”—¢˜™¤˜™¥™—£—–¡•›¥™¡ªž¡«¢§±¥°¸­º¿µÜÝÖÿÿüÿþþþþþþþþþþþþÿýþÿýþþþþþþþþþþþþþþþþþþþþþþþþþþþøù÷æçâÔ×ÎÍÎÆÆÆ¾¿¼µ¼º²³³ª©¬££¤š¦£›¢œ• ›’¢Ÿ• ž” ›’ž˜‘£— œ—™–Ž–•‹—•‹–•‹–•‹š¥Ÿ–¯§žºµ±ÈÊÅõýøÝæß¯´««¨ž·´­Äº¨©Ÿ®±¨¢¦™ž”–šŽ—›ŽœŸ”ª­£Ÿ–‘•Œ–“‹“•Š’™Œ•Ÿ’™£—¦œ¥ž¡§ž§¬¢°±§»¹°¬ª¤ª® ¨®¢ª²¥·º°¼¼³ÆÂºÖÓËàØÑÚÏÇÛÐÈØÑÇÕÑÇÛÖÎôñåêçÝúõóÿýÿýÿÿþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþöýüôúúÃÊŬ´®±°««¨£¹º´®¶¯ª³«Ÿ¢œšš‘’—˜œ¤š˜ –Ž–Š•“›¤™ž§œ¨«¡´·¯°·±£¨£÷ýûøÿÿñøö¨±«¥­¥¬µª°´ª³¸¯ÓàÔ»ËÁµÀ·¶Å¹ÄÏÄßåÞýÿûûýûúýüþþþþþþþýÿþýÿþþþþÿýÿþþþþþþþþúýüîöñÊ×θƺ¬¶«£¬ ›£˜—Ÿ”‘˜Ž‘•ЕД‡Œ•‡Ž”†Ž“…‘‡Ž‘†•‡‘™ŠŽ–Š‘™Ž–ž”•“•ž”–Ÿ••ž”š¤šš¤˜š¤˜˜¡–˜¢•›¥š¢¬ ¤¯¥©³§³»°¸¼´ëëçÿÿþÿþþþþþþþþþÿýþÿýþÿýþþþþþþþþþþþþþþþþþþÿþþþýÿþþþþþýõöòÝâÙØ×ÒÍÌÇÈÄÀÆÃ¾¾¿¹²´®««¢©¨Ÿ¦¤›¦¢™£¡˜¤£š¢ž•ž˜‘Ÿ˜“Ÿš”™–Ž••Š—”–”‹™˜Žœš¦¢˜µ°¦ÂÁ¾ñôñøþûñö󶺳··­ ž“¥¤š¯°¦´¹­¤˜™’—›˜›š™¥¥šœŸ”“™Œ’“Š–‹’šŽ– “™¤˜§œž¥Ÿ §Ÿ¦«¡­®¤«¬£©¨ ©« ¬°¤²¶«»½²½¼³ÊǾÙÖÒéæàÑÐÇÑÐÅÎÍÃÓÐÈãâÚúúñáÞÕûú÷ÿüþüþÿþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþüþýúüüÑÛÖ¢°§­©¤§¢£¡œ¤›¡›™›•”™’—‹Œ•ˆ—‹—Š–‰’š– •›£˜¡¤™¨ª£ ¦ŸÁÉÄÿÿÿãäã½½½œŸœ£§Ÿ¨®¡®°¦¿È¼óÿüçöñ¿ÊÄ¿ËÀÔÞÓñõïþÿûþþýüþþþþþþýÿþýÿþýÿþýÿþÿýüÿýþþþþþþýÿÿùÿýíøðÎÛϵÀ´¦¯£Ÿ¦›˜Ÿ”“›–˜•‹•‰Ž—Š–ˆ•…•‰•‡’™Š˜Œ–‹’š‘•“—Ÿ••ž”–Ÿ•˜¡—— –™£—™¢–˜¢–™£—§›¥¯£¤¯¤©³§²º¯¼À·êëçÿÿýÿþÿþþþþþþþÿýþÿýþÿýþþþþþþþþþþþþþþþþþþÿþþÿýÿþþþþþýûÿúîóìääÝÙØÓÓÐËÓÒÍÌÍÇ·»µµµ¬¯¯¥®¬¡©¦ž¨¤œ§¥ž¦¤š š“ž–‘”˜”Œ““‰˜“™—––‹¦¥›®®¢±¯£ÜÙØÿÿÿûûûùúùããݶ´¬ž™©¨ž¹»±ª¯¤ž£˜™œ‘˜›’˜™™™››ŽšœŽ“–ˆŽ”ŠŽ•Š™Œ” ’™¤˜Ÿ¨Ÿ¥  ¨Ÿ¤« ©®£©­¢§©Ÿª«¡®¯¤³µ«·¸®¼º°ÑÌÃæêàæêàÎÓÆÍÑÄÔÐÇͼïïè÷øðõôëÿþüýüþýÿÿþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþÿþþÿÿÿÛÝܯ´°¨©¢ ¢œœ¢›œ£œ˜–’—™Ž—ŒŒ–ŠŒ”‰•Š—Œ—Œ˜ •™¡–š •¥§œ¨¨ž»µ®»·¯’ˆ˜™›Ÿ—¢™¦©ž¯¯§ÉÆÂÿÿÿùüûêóíÅÍÄæíçûþüüþþýþþþÿýþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþýþþýþÿíõî¸Ä¼ªµ¬¡ª š£˜˜•—›‘™Š˜ˆŒ–‰–‰•ˆ–‹’š”‘‘š‘›Ž’œ˜ •𢖗Ÿ”š¢—˜¡•— •— —™¢—™¤•š¥”Ÿ¨™¥¯ ¥¯¤ª´¨¶¿³ÁúàÜÔþü÷üüþûþÿþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþýýûüüõõëçêßÛÞ×ìòìÜáÙÀŻ»´·³«µ³«²´ª«¬£¬ª¢¦¦œ¡ –œš›—š”˜’Œ˜’‹œ›’’•²¶­¥¦­ª¢õ÷òÿýúýüöçßÛ±©¡¬¦¡¢—±°¦ÆÇº£¤˜›Ÿ’—‘˜š˜›•™Ž˜œŽš ‘’šˆ”•‰‘”ˆ“˜‹–œ‘š£˜ ªž¡©Ÿ ¦§ª ©­¢¥¬¡¥¬¡§®¦®²©±²¥¯­¢½¹¯ÍÈ¿ûÿÿâáßÐÏÊÚßÕâæÜËǽéçÜöõêýúõÿþúÿþþþýÿþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþýý÷ø÷¸¼¸¥®¨¢¤›œŸ–˜ –˜ •”š•Œ—ŠŒ–ŠŒ–ŠŒ”‰–‹“›‘•ž’—¡•–Ÿ”˜¡•£˜¡¤™¤¤››š’¢£šŸ¢™šž•¡˜¥ªŸ®°©ÜÚ×ÿÿþùûùçìèÙÞÖúýøüÿüüþþþþþþÿýþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþýþýôøôÁɪ´ª¥­£ž¦œ˜ž”™’™ŠŽ—ˆ–‰•ˆŽ”‡–‹™¡–š¢˜– ”– ”– “˜¤—™£—™¢—š£—š¡—™ •š¡–™¢—œ¦—œ¦—Ÿªœ¤¯£§°¤­¶«·¾³Ãź×ÑÊûõðþþþÿþþÿÿÿþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþýýýÿÿûûû÷øûöýþüàâÛÈǿǺ»¸¯ÆÆ¾ÆÇ¾°±¨«­£¨¦¤¢™ •›™™—Ž˜——“‹˜˜›ž•··¯°¬¤×ÑÊþÿúûøðÚÏÇ´©¡©¢˜¢’›š´²©Åù Ÿ•š’–›•˜Ž–š–›Ž–šŽ™ ’•Ž•˜Œ“—‹–œ‘—’œ¤™¥®£¡©Ÿ¢© ¨¬¢¨­¢¨¯¤¥®¢¨®¥­¯¦­­¢³°¥µ°§ÒÍÄüþúäãÜéèáúýõáâÛÎÌÃÝÜÕïíçüüøýýúþþþþþÿþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþÿÿÿÒ×Ò­´®¥­¤¢¦›™ž“˜ž““›‘‘™Ž•Š™ŒŒ–‰Ž–‹Ž–‹’™š —š£™œ¦œÃÎÄ™¤š¥›› —œ¡˜ —›ž–›ž•›ž• —¢©ž³µ®ÖÒÎÿÿýØ×ÓÃÃÀñõïüÿüûýýþþþþþþþÿýþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþÿýþÿýîñì½Ã½¨°§¢«¡¤››ž•—›“—‹•ˆ”ˆ‘•Š”‰“™‘¡©¡œ¤š˜¡—˜¢——¡•˜¥˜™¥˜˜¤˜š¤˜›¢—ž¢—š¡•›£–›¤—œ¦š©¡­¡¨°£®¶ª¹¾³ÄùÓÍÄðåÞþú÷ÿþûÿþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþýÿÿÿýýýþýûâßÙÔÑÇÊǿǎÜÞÔÌÍij´««¬£¬¨¡¨¦ž ¡˜žž”šš—˜Ž™–ŽŸ–¡ —¨¥´«¤ÖÊÄü÷îùòèÛÑÇ®¥›¥ •š˜—•Š§¥›©¨ž“•—Œ•™’—‰–š—›–˜ž“–‘–œ•œš •£˜¡©Ÿ¢ª ¤­£¥«¢¦¬¡¦¬¡§®£¦°£§ª¡ª¬¡®­£¶³©¸²ªßÚÐþÿúñðäìêâÿÿüááÚÓÒÌúúøýþûüýûûûûþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþèíèäêåÀÉÀ¦°¦œ¢——’•›”šŽ–ŠŽ–‹–ˆ•Š•‹‘˜•™™Ÿ–’š·Â·ìôí­¹¯¡©Ÿœ¤™™¢—˜ –› ˜˜ž•—œ“š¡—©±ª½Á¸ÇÆÀÀ½·ÈÈÂÎÏËþþûþþýþþþþþþþÿýþÿýþþþþþþþþþþþþþþþþþþþþþþþþþþþþÿýýþüÿÿÿÓÕÏÁÆÀª³¨¢© œ£™™ž–•™Ž‘–Š“ˆ“ˆŽ‘‡‘”Œ’˜‘˜Ÿ–™¡–˜¡—™¢—™£—š¦š™¦š—¥™˜¤˜¥šž¢—›¢•œ£˜›£˜›¥™©œ¡­¡§°£¬µ¨¹¾±ÅÅ»ÑÌÂãÚÑïèàÿûôÿýûþþþýþþþÿýþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþýÿþýÿþýÿþüûçåß×ÒÌÔÓÈ×ÖÌÛÚÐÏÎ͏­®®¤®«£¬«£¥§žž£—œŸ”›œ‘›œ”¯¯¦¥£›ª£›¶«¥Ç¹³Áµ«ÑÅ»Á·­®§œœš˜˜—”Šœ’ Ÿ•š›’–—Ž•–’—‰”™Œ–™Ÿ”£™œ¤›œ¡–›¡–¥š¡ªŸ­µ«ÆÎĬµ«¤­£¨®£¨®¤©±¦§±¤¨¬¡ª®£®¯¥¶¶­ÉǽÐËÃêåÙüúðñðåùøîÛØÐèçáÿÿÿýýýþýýûûûþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþñøóëóïÓß×¥±§œ¢—˜’–š”™Ž—Œ–‹Œ”Š•‹Ž–Š’˜‘˜‹—‘š¢˜½Æ»ÞçÝ®¸®¥­£›£˜—Ÿ•–ž”–ž“•“— – ¨ž¯¶±ÇÍÅÄǼÌÏÅÙÜÔæìåÿþÿþþýýýþþþÿþþýüÿýþþþþþþþþþþþþþþþþþþþþþþþþþÿýýþüÿÿþóóðÊÏÈÉÎȤ¬£¢¬¢›¤š— –•œ‘“˜Ž’•‹“Š’Š•‘™Ž—Ÿ”—Ÿ•™¢–™£–§šŸ¨žªžœ©š¨œž¨œ£˜œ£™¥›ž¦œ¥› «ž¤¯¡¦°£­·ªÂɼįºÔÏÆÛÓÊá×ÌôîæÿþýýýýüþþþÿýþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþýÿüþÿýýþüþýõôðáÞÖÛÚÑÙ×ÍÐÍÃÊǽ»·®±°¥²®ª¶·°±¸¯©¯¤¡¤™ž‘¨ª¡Äż°®¥¨¡›¾´­Å¹²Ä·­ðåÜʸ¢“š™Ž——™—Œššž¡—šž––™’˜š””šŽ“šŽ–œ‘š •¥šª²§¢§œ¢¨¦®£¦®¤ÁËÀñúñØàפ­¤«²§©°¥¨±¦¨²¥ª°¢«±¥±µ¬¾Á¸ÐÑǽ¼²ÓËÂìëàÖÕÊÞ×ÍÕÐÇêêáÿÿÿÿþüÿþýýýüþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþøýýöÿýæñ뤱¨œ¤š˜œ““—”—Ž•Œ‹”Š”ŒŽ–‘˜’˜Œ‘™‹— ¤ž¬³¬³»´­µ­¢ª£¤™¡–™¡—–Ÿ––Ÿ•™£™£­£­´¯¼Âº±´ªÕÚÏéïèéóëýûûÿþþÿýÿþýÿþÿýýÿýþþþþþþþþþþþþþþþþþþþýÿþþþþÿýÿþýö÷óÎÐËÇÌÄËÓ˨²¨¢­£š¦œ™¢˜•Ÿ“”š‘’–’•Œ–Ž—”›˜ •š¢–˜¢•›¥˜¨š¤¬¡¢­¡ž­ Ÿ®¢Ÿ«Ÿž¦›¥œ ¨ ¢ª¢¢ª ¥­¡§±¡¥° »Å·Ï×ʿ÷ÑÎÄÔÍÅÙÍÀðæÞüùöýýýûýüýÿýþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþÿýüþýüþþûþüýþùøøòçæÛÔÑÈÑÌÂÊû½º±¶µª¶¶°áãÜÆÎİ·¬Ÿ¡–¢¡•¢¥œÔÖͪ§žŸ˜‘ÛÒ˶­¥¶ª¡³¨Ÿ«¦œ¡ž•˜–Ž—˜Ž––Šž ”¥ªŸ–ž”šŸ™™–•›”™•›™ ”¦®£®¶¬¦©ž¥ªŸ©°§¨±¨ÙâÙüÿÿÈÑÇ®·­¬³¨ª²§¦°¥¨³¦«´¥®·«³»±ÈÏÅöøñÁ¹×ÎÄÔÓÈÐÎÂÖÎÄÚÒÇßÞÔøóîýùõÿüùÿþýþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþùøõô÷ñøøô¢¤ž¡¢œ—˜•–’–Œ”‰‹•‰Ž˜Œ”ž’”ž’’›•šœž•Ÿ¤™¦ª¡¬²¨§«¥©¬§¤©£›¦›ž§™¢˜˜¡—œ£›¥¬£¬°¥³¸­ÆÍÁÛß×ø÷ðÚ×Ïÿþÿþþþþþþÿþþÿþþÿþþþþþþþþþþþþþþþþþþýÿþýÿÿýþþüù÷õðÛÚÔÊËÄÅÏÃÁË¿¯¸­¦°£œ¥›™¢˜–ž”’š’›‘“š•ž’”›‘“– •˜¢—›¤™ž¨œ ª¥±¥¦²¦§²¥¥¯¤£­  ªž¡­¡¡®¡¢°¡¥¯££­Ÿ¦± «³¨ÈÍÂÜÜÒÇÅ»ÄÁ¸ÇÄ»ÏÌÂÛÔË÷óëûýöûýûþýþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþýþûåæâÓØÏÊÎÄÂĹÃ÷¸½¶úþúÎÓÌ»¿·¤¨›¢¤–¥¡–ÒÎİ­¢§¥šôóé´²§¶¯¢¯¨›©¡”¤™Œ™—‹œ™Ž£¡–«©žžž’¥§›šž’ž¢”–œ˜›’žŸ—­¯¦¯¸­¨¬¡¨®¢±²§«¨ ÞÛ×ÿÿÿÙÛв¶«¯´©ª°¥«³¨¬µ©±¸¯µ¹±´¸²×ÙÓÿÿÿ×ÞÙÓÏÇÑÏÈÌÌÃÐÏÅÖÑÈÞÙÎäÛÍóëàÿûóÿÿúþþýüþÿþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþÇÇÁÇÇÁ©ª£¡¡š–˜Ž”•‹•–‘”ŠŽ•ДЙ•Ÿ“– ”𣗙Ÿ”œ¡•›¢—§¬£®¶¬ª²«¡©£¥®¨£«¡¥®£ž§œš¢˜›¢˜ §«­¢ÑÖÌÙßÔÚÝÔÝÝÕëèáÿÿÿýþýþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþÿÿÿù÷ñÞÜÓÍÍÄÅÆ¾ÃʾºÁ¶´¼±¤­¢¦œ™¢™—Ÿ“— ”–ž“—Ÿ”˜Ÿ–˜ –˜¡•™£—š£™Ÿ© £®¢§²¥¦µ©¦µ©¦³§§´¨¡­¡¦°¥¥³§¤±¥¦³¦¦³¥¦±¤©³¥«³¨±¶«¿Á·¿¿µ¼½²ÁÁ·ÌÈÁÔÍÄõòìþþúýþýÿüÿýýþþþþýýýþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþýþýÿÿÿùüøêîéíîçÖÔÌØÖÒÿÿÿÓÓξ¿¸¬ª ¤¢–§¡—³«¡´©Ÿ¥›Ã»°»¶«ÅÅ»ª§£ –£”Ÿ™š˜Ž‘¤£˜££—  ”¦§›žž’¤¤—œž“”¡•¬©¡¨¯£©«¢«¯£®¯¢¼¶­Æ¿·ØÖÏÄź¸¹°¯³¨ª²§¬¶«´¿²µÀµ¿Æ¼¯³¨ùúôÿÿÿÒÔÍÉÆ¾ÙÖÎÎÎÄÑÐÆ×ÕÊÜÙÎæà×ùõîüøñþýøüþýüþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþ··²²²©°®§Ÿ•™š‘’“‹’“‰•–ŒŽ“ˆŠ’ˆ•›™ –˜¢–¬´ª¡¨¤§œ¢©ž¯´ªµ½³³»´´¾¸¯½¸¥®¢ž¦›—Ÿ”›¡–œ£–Ÿ¦™¦¦»¾³²¶ªµ·°Â¿·ðìæýýþþýÿþýÿüþÿüþÿüþÿþþþþþþþþþþþþþÿýþÿýýüùðîèÚØÏÉȾÂŹº½³¹½²³¸®¸¿´¦®£¥š˜¢—›¤•š£•š¢—𢗙¡—›¢šœ¤™œ¦šŸ©ž ­¡¥±¥ª¸«ÀÏÇÂÒǺ˾ª»®¥µ©¨¶¬§¶¨§µ©©µ©©¶¨¨¶§ªµ¨¯µª­²§³¶«»¾´º¾³¼Ã¸ÇļÑÌÆóïìþÿýüýþÿüÿüüüýýýýýýþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþýýýüýþüÿþÿÿûéæáäâÞÿÿÿ´´±·¹²½½´¬®¡§¦›®§œ¬ž”«“¦“ÓÐÄèîäÁꦥ›£¡–Ÿž“¡Ÿ•žž“¤¤˜¢¢–žž’  ”¡Ÿ”§¥™žŸ”Ÿž• –©¦ž«¯¦ ¦¨®£±´©¿¼®ÊŹâàÕº¶¯±²§¯µª®·¬²¾²¹Ç¼¾Ë¾Á˽½ÀµäâÙÿÿùêäݺ¹¯àßÕ×ÖÌÖÕËÜÛÑÙØÏôóîÿýûùùöýýûýþýþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþ¬°¦¨© £¡˜œ’—˜‘‡•“ˆ’”Š•ˆ–‰“—œ¡–¤ª ÊÓÇ­´©¥«¡¤«ž·½²ÊÎÅæìæóø÷äð쥬£§¯£ž¦œž¤™¤—¥—¥§œ¤©­³¨¸º²ÌÈÀåÝÖþýþýýýÿÿÿþþþüþþüþþþþþþþþþþþþÿýþÿýÿÿýñòíÐÑÈËËÁ¿Âµ¹½±³¹®µ¸®¶»°ÂȽ¬´©Ÿ¨¨›œ¥—œ¥—›¥—ž¦›¥›ž¦›¥šŸ§œ¢¬ ª³§³¾²§²¦öýùäðé»Ì¾¹Ë¾±À´®»±­·­¬¸¬¬¸¬®·««µ¨ª´§®´©®³¨²¶«¶º¯ºÁ¶ºÂ¶ÃúÎÊÃöòïþÿýüýþÿýÿýýýýýýýýýþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþýþÿüþÿüÿþþþüûøóõöðÿÿÿÜàÛäèáÈÎ⦛ª¯¢®®¢¥œ’¦“©¢˜òñæöúó¹½´£¢š£¡š§¤œ³±¨²²¥¥¥™žž’‘ž‘Ÿ’Ÿ•œ¢–ž¢˜ ¡—¤§ÔÞÔíó뱺°±¼¯ÂÄ¶ÚØÌÖÖÊ´±ª®¯¦¬µ¨µÀ³¾Ê¿ÅÐÅÄÓÆÇÑÃÉÍÀÓÐÇÏÉÀ¼³ÅĺÐÏÅËÊÀØ×ÎÞÝÓâäÚÿÿÿúúúüüüþþþþþþþÿýþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþ¢©Ÿ ¥šœž“šš••‹’†’‘‡”•Š”ˆ”‡”–‹™’ §œ³»°§°¥¦­£©¯¡«¬¡¿¿µÝÝ×ûýûüÿÿÃ˵½µ¥­£ž¦›œ¤˜œ¤—ž£˜£¨§®£³¶­ÆÃ»ÝÖÐûøøÿýþÿýýÿÿþþþþüýüþþÿþþþþÿýþÿýþÿûøùõààÙÈÉ¿¾À¶¹»¯³¸­±¹®³µ­¯³ª¡©žŸ¨Ÿ«žž¬ž ªœž¨š ª£­¡¤®¡¢­ Ÿ§ž£« ©±¤®µ¨²·­×ÛÓÿÿÿøþùåòçÏßѼǽµ¼´±º¯¯·­¬µª®µª¬³¨®¶ª­³¨®³¨°µªµ¸®¼Á¶¾Ä¹ÈÊ¿ÑÏÇóñíþÿýüþýÿþýÿÿÿýýýýýýþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþÿüýþþüýþýþþýýüýúöüúòõõíòôíßáØÇÊÀ¬­¢²²§­®¢¤¢—£ž“«¢˜ÝÖÌÿþ÷ÓÒʤ¡—ª§²³©ðïæ³³§¨§›žž“‘ž’Ÿ’›“¢–ž£–žž”¿À¸íõíÄÇÁ ªž³»¯ãäÚôôê×Õ˹¶±®³©±º­ÂÏÀÆÑÆÓÜÔÛåÙÐØÌÐÒÈÖÕËÖÔËÍÉÀÈÊ¿ÒÑÆËÊÀÑÑÇßáØõøðüýýüýüýýüþÿþþþýþÿýþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþ›¥™š¡–™œ–—‹“’ˆ‘‘†‘†’“†“‡•‰š™Ÿ¢˜­³¨ÈÐźÁ¶¬µ©¬¯£¬¬¡½¸±ÑËÇûú÷ÿþþÊÓÍ´½·¨°ªž¨œœ¥™š¢–œ¢—Ÿ§œ¥­¢­²©¾¼³×ÏÉíçäþüúÿþú÷öóüûøþþûÿþþþþþþÿýüýûùû÷ÞàÛÍÎÆÃúºº°´¶«®´©­µ«¯µ¬©°§¤¬¡¤®£ ­ Ÿ¯ ¤­¡¢¬Ÿ¥¯¢§±¤§±¤§±¤§®¥©°¥«°¤´¹¬¼¼²îìæþþýèëçÌ×ÌÔáÓÂËÀ¶º´µº±±¶­¯´«¯µª®²§°µª­´©¯´©´¶¬´µ¬½¿µÁƺÌÐÃÖÔÊóñíÿÿýýÿýÿþþþþþýýýþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþÿýþúýÿýþÿÿýþÿÿÿýÿÿûÿýõü÷íýûóíéàÅÁ¶±­ ³­¢«©¤¢—¤Ÿ”³§µ£›ÍżÍļ²ª¡¡”ÐÏÇËÌü¹®©¥›¢ ”žž“ ”˜œŸ”žŸ”œœŸœ»º°ðñìàÛפ£š»½³ùøò¼´­¿¹³½½¶­²§À̼ÚçØÍÙÌîõíñøïÝäÙÜàÖ××ÎÒÒÊÔÔËÕÖÊÏÏÄÑÐÆÒÑÆãåÜøüôþýúÿýýþÿýþÿýþÿýþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþ—£š–ž”’™”—–”Œ“‘‰‘…“‡–•‹˜˜Œ›Ÿ§ªžÄÈ¿ÝæÜÃί½¯¬°¡«­¡¯®¦½º²ÙÖÏèçÞÁƼµ½²°¹¯ž¦™ —›ž•¤˜ ¦š§¬¡®²§¼º²ÎÉÂâÚÑëäÚçßÕáÙÎíãÜùîêûöôþýûþþýÿýüïïêÒÕÌÆÇ»¹½µ²µ¯¯³§¯µ§­·©©µ©©µ§©·©§´¦¨µ¨§³¨§²£§±¡§±£©²¦­¹¬¬»¬ª·©¬µª®¶«¯¹®½Â·ãâÙüü÷ÛÞ×ÎÕʼƺ´½±µ¼°°¹®¯¸¬±º®®¶«­´©­µª¯¶«¯´ª³´«¸¹°¼¿´ÇÌÀØÙÎÕÓÊíçâÿþýýýþüþÿüþþýþþÿÿÿþþþþþþþýÿþþþþþþþþþþþþþþþþþþþþþþþþþýÿþþþþþýüüùÿöëúíãùíäøîçúõìëâ×É¿¶óïèõðèÈǼµ´ª´´«·¸¯©ª ¢¡—¦ —­¡˜³£™ÖÍÀ·¯¤µ°§ª¥œåâÙÊǼ«§™·µª°²¨ ¡˜£¡™¢•ž’œ›š˜¡œ‘¬¥š©¤š£¬ªžÏÑÄùùô¾¿³ÆÅ»¹¼¯­±£ØÝÏÍÔÈèëèýýþýÿýÿÿÿîðêÖÚÒÛßÔäèÜÖÜÑÐÔÉÏÐÆÖ×ÍæåÙþþôüüüýýýþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþ–¡—“œ’‘—Ž”˜—”Œ–“Œ’†“‘‡“”Š–™Ž £”®±¦ÔÙÐüÿüÏÙμɼ´Ä´¥°£©®¥®®¦³¯¦ÆÀ·ÚÜÓµº¯¯¶¬œ¤š”œ’š –™ ”¤™¢©žª®£´µ¬¿½µÐÊÀØÓÈÕÎÄ×ÏÅÚÑÈáÖÑäÜÓù÷ñ÷÷îèæÝÝÞÒÊÏÂÆÊººÀ¸¯¶®±´ª²·«­¶ªµÃ¹½Ë¿·Ä¶³Á³³¿²¯º­­¸©®·ª³º®´½°ÁʾÊ×ɯ»°³»¯µ¼±´¾²¿Å»ÏÍÃÎÌÃÑÕÊØàÕÃͺù¹¿µ¸¼±¶»°¶»°²·¬²·¬¶º¯±¸«²·¬µµ­¹º±½¿µÃƺÍÌÃ×ÒÉêãÝÿùõÿÿýÿÿÿþýüþþüþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþýÿþþþþÿþûû÷÷íàåÛÐêáÙûôîøöïÖÑÉØÏÆÿýöíèàÎÍÃÁÀ¶Ä¸ºº²§© ¤¤š¦¢˜¨¢™°¦œÁº¬¾·««¥œ­§žÂº°°©Ÿ¨¨›ëîãÝâڿü›•››’ž’˜—Œ—•‹œ™§¢˜«¦›­ª ®ª ´°¥ÃÀµ¼»±ÆÇ½»½²³·ªÖÚÎÞà×ÿÿÿüýþþÿýþÿýúû÷ïñìüý÷ûûöÝâ×ÒÖËרÎÙÛÏêëßýþñüüüýýýþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþ•¡—•““š“–—•Œ•“‹…•”Š”–Œ™ ”ªª°±ªáâßýÿýøþ÷áëßÙçÙ­¹­ª±§¯°§®«£±¯£¡¢–›ž“–›–“›Ž–Ÿ’—¡–š¤˜§›£« ­°¥´¶¬¿¸¯Â»±Ä½³Ã¼³Æ½¶ÌļÙÒÅõóçþþöÜØÍÙÛÍËÔÆÊÏÁ¼Ä¼¶¾¶·º¯©®£ÏÔÎî÷óÃÐÅÅÑÅÈÓÆ½ÇºÃÌ¿³½±µ¾±ÇË¿¸¾±æêãÛâÙ·Áµ»Â·¼Â·ºÅ¹ÄʾÐÐÄÒÓÆêíãçîäÊÓɾǽÀż¿Ã·¾Â·¼À´»¿´¸¼°¸»±¶¾°²¸¬µ¶­¹º±ÁÁ·ÆÆ»ËǾÚÓÊìãÚêãÛ÷ôîóñëöóðÿþüþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþýÿýýýÿÿÿúúöèàÔàÙÏâÛÓÿÿüÛØÔÑÐÉÐÉÀôïçñëâÙØÎÇÅ»ËÊÀÉž½½´ª«¢¦¦œ¥£™«§±«ž«¥š§Ÿ•¯¨Ÿ¸®¤ •‰ÔÓÈýýõâäÞ®°ª—™’™–‘˜˜––‹™™Ÿ’¡Ÿ”¤¢—§§›¬§œ³« ¹¯¥Ìɾ¾À¶±²¨¼»°ÄĹîîçÿÿÿüþÿþþþþÿýþþýÿÿýþþýþþþéìãàãÚåèÝÞàÕòóéøúðüûûþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþ—£™–Ÿ••œ’•˜—˜–”Œ–”‹•”Š˜š¢§›±°¦º¹±ööôüýûâçâÖÝÕÉÎÁ²³ªªª¡­®¥§ªŸŸ •£¦šŸ“—›–š”œ˜ “•Ÿ“œ¦š›¥™¢ªŸ§­¢¨¨žª§³®¥´¯¨´¯©¸³¬¿º³ÐƽÚÕËÝØÏÕÐÈàß××ÞÕÏÓÊÕÝÖÈÏÈ»½³»½³øúö÷ýùËÓËÂËÀÛä×ÑÚÍÒÚοȾ½Â¸ÙÚÏ»¾²øúò÷ûöÌÕÊÊÏÃÇÌÁÂË¿ÎÕÈרÌÝÝÐíðæíõëÌÔÎÇÐÇÄÊÀÇÊ¿ÆÊ¿ÃÇ¼ÂÆ»¿Ã¸¾Á¶»À²¶º®´·®·¸¯Á¿·ÅºÉ¹ÐÉÀìãÚâÛÒáÛÒæâØòìçÿüùþþþüþþýþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþýÿýýýþÿþûüøæãÙÝÙÐôñìýû÷ÙÙÒÒÒÉÎÈ¿ÚÕÌÍÈ¿ÖÐÈÒÑÆ¸¶«ÄºÂ¹ª®£¦ªŸ¦§ž­­¢®«§¤™£Ÿ•ª£š°¦œ­¡•èáØÿÿüú÷ñÄ¿ºš–’›˜˜˜——‹™™ ¡•¡¡•££—§§ª¥œ¯¦¸¯¤¿¼±µ·«³²¨À¾³ÂÁ¶ûúõþýýûýþþÿþþþþþþþÿÿÿþþþýüþüþùôöðþÿúèêãùúòûüóüýýýýýþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþ• —–Ÿ•“š•˜˜š‘˜˜˜–Œ—–Œœ›‘«ªžµ´«äáÞÿÿÿüüüùú÷øúõÏÒȹº°©«¢£§ž¡¦š¢”ž¤˜œ¡–”˜”™—ž’“‘“œ’•“— ”ž¥š¢¥š¢¢—¦¢˜ª¤œª¥ž¬§£¯¬¦µ³ªÂ½¶ÉǽÑÎÅÝ×Ñöõòûÿÿûþúÿÿÿáæà¸¸¯ÑÐÅÿÿûúúöÏÑʾÁ·ÇÌÁÍÒÇÛà×åëåÂĻöÔÒÉø÷òõøõíôëÖÙÏÑÖÌËÔÆ×ÞÑÝÝÏëìà÷úñæìå×àØÐÙÎÐ×ÊÑÖÉÑÖÊÏÔÇÌÑÅÈÍÀÃȽÀŶº¾³¶º°·¸¯¾º³Áº³Ã½²ÈÂ·ÌÆ½ÏÉ¿×ÏÇߨÐêâÙúöñÿþþüþÿýþÿþÿýþþþþþþþþþþþþþþþþþþþþþþþþþýÿþþþþÿþüýùõôîïìèýýùÿþúàÝÖÑÐż³ÞÙÐÎÉÀÍÉÀÆÅ»­«¡ÌÊÂÕÔÌ´¶¬¦¨žª«¡¯¯£­©ž¥¢˜¢ž”¤¡˜¨¡”ª¢•º©È»²Áµ¯§ —›——–•—‹–˜Œ˜šŽ›‘Ÿ ”¢£—¥£™§¤›©¦œ±®£²°¥±°¦³±§ÇŹÜ×Ìùöîÿÿýüþÿþþþþþþþþþþþÿþþþþÿýýýüýþûûüùîðíþÿûýÿûþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþ‘œ‘‘š“™–™•™š™‘œš›–ž™‘²­£¶´¬øöôÿÿÿþýýýþýýÿûçòé»È½§°¦ ¨ž¢–Ÿ¡”¦šœ¥š—œ‘•›“š™‘˜“›•ž“œ¢—œž“››Ÿ›‘¢•£Ÿ™¥ œ¨¥Ÿ®¬¤¶µ«ÃĸÖÔÉíçàÿÿþøþýþþýùýüþÿþ¹¶­ÑÎÃÊǺ¶¯Á¾¶¾¿´ÊÌÁæéâòõðõúöÇÉÀÃÁµìèßÿþùûþûûÿ÷èëáØÝÑáêÞïõèññäýþóüþøöüöçïçÝçÛÝäÕÚä×Ûå×ÛãÕØâÕÓÜÏËÔÈÈÍ¿½Áµ¹¼²¶¶®º¶¯¼´¬½¹®Á½²Â½´ÉüÓËÅÚÒÍçÞÕ÷óíÿþýüþÿüþÿþÿýþþþþþþþþþþþþþþþþþþþþþþþþþýÿÿÿÿþþþþÿûýþþýýüÿþýèæàÑÎÄÌɽ¿º±Ä¿¶Ã¾´Â½´¾»²²°¦»¹±ÍÌÄÂĺµµ«¨¦œ­« ¬¨¢¡–žœ’Ÿ“£ “¥ ‘°¡’³¤˜©“¡›’—™Ž‘•‰•—‹•—‹™›œž’Ÿ¡•¡¢–¢ —¥£™§§¬­ ­¬¡´±¤·¶©ØÓÆéã×ßÜÒÿÿÿúýÿþþþþþþþþþþÿýþÿýþÿýþþÿþýÿýýýüüýþþþûýýþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþ˜šŽ•˜‹”—Œ”™Ž™šš›œœœš ž“¯« Æ¼²þþùüÿþÿýÿÿýþûþþ÷ú÷ÉÑǬµ¨¡¨ž¢—›Ÿ“œ¤—œ –’š’š‘™Ž‘›Ž•˜•™‘˜œ•—œ“™œ—š›šœšŸž” Ÿ•¦¥›¬ª ­®¤½¹¯ÏÊ¿æâÙÿÿÿÿýýþüýÿÿÿâàØÁÁ¶ÊɼÉÉ»ÇÆ½¾¿²ÁÁ²ÑÒÆÿÿÿýüýüýùÎÌÂÌÉ»ìåÞöñïýýúýþúñôîìïåúýóúüöýýüþüþýþýþþýùúõô÷ðô÷íù÷ïûúòõ÷îðôìêñèßçÝÒÛѾŻ¾Â·º¾²¸¹®··®º»­¼¼®¿¿³ÄùÏÌÅÙÕÏåÛÔöíçÿüûÿþþüþþþÿýþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþúüýÿýýÿÿÿÒÎÇÇÅ»ÈÈ»º¹±¹¶®¶³«·µ«¶´ª¶µ«ÁÁ·ÄÅ»ÔÓɨ¦œ¨¦œª¨Ÿ©§¥£™¢”¡œ“£¡– ž’£”ª£š¥¢™“˜˜Ž˜—Ž——‹—™šž’¡•Ÿ¡•¢¢–¡ ’¥£—¦£™«§Ÿ¯®¡³´¦¶¶§äàÓåÜÓîèåÿÿÿúÿþþýÿÿþþþþþþþþþþþüþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþ–™”—‹•™Ž”˜Ž—™ŒŸž’ž’Ÿœ‘£ •¬¦›ÍùûøóþÿþÿýÿÿýþûþþýþþÞäܲ»¯¤¬¢Ÿ¢™šž“œ£—˜ž““š‘™Ž’š‘š—›–œ‘™ž•–š‘”–Œ™˜˜—˜—œ›‘ž“¤£™©¨ž««¢µ³¨È¶ßÙÏøöðüù÷þûúèåáĹ¿¿³ÀÀ³ÉɽÄù¿¾±ÆÅ¶ééÞÿÿÿüüþÿÿþÚÚÑÍËÀñíçÿÿÿþÿýüýüùûöýþøýÿùýÿüýýþþþþþþþþþþþÿüþÿüþÿüÿÿþÿþþþÿýÿÿÿýÿýùýûåëåÇÏÅÁȽ½Âµ¸½²¶¹¯ºº¯¼½²ÁÁ¶ÆÅ»ÏÎÄØÖÍáÜÒíãÜûóðþþýüþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþûþÿÿÿÿõòïÆÃ¼ÈĺÁ¾²·µ¬´±ª´²¨¶´ªµ´ª½½±Á½µÈĺÑÐÆ®¬¢§¦›«©Ÿª©Ÿ¦¤šŸœ“£Ÿ–¦¤™ŸŸ“¢ž•¤¢˜¢¡—›œ’šš›š™™™œ¡•¡¥™¡£—££˜¥¤–¥¤˜§¤š©¨¯¯£µ¸©¸¶ªÕÐÄßÖÌíåàÿÿÿûþúÿýüÿýýÿþþþþþþþþýþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþ•™’™Œ’™Ž“›š›‘ŸŸ•£¡—¡Ÿ• š‘¯§ŸÇ½²êåßÿþýÿþþÿþþþþþýÿÿéïèµ½´¨¯¨œ ™œž•—Ÿ‘“šŽ”š”š“œ”–ž‘˜ ’—œ‘™š—•—”Œ”“‰•”Š˜—ž“¡ –¥¤š­«£¸´ªÈµ×ÐÄÖÑÈúøóóôïÐÏÈÊÌÁÀÁ¶¸¹­¾À´¾»°¿½±Å÷ùùñÿþýþýÿÿÿýÛÛÒåäÚúøõþýþûþüþþþýþýþÿûþÿýýýþþýÿþþþþþþþþþþþþþþþþýÿþýÿþýÿþýÿþüÿýüÿüüþùþûÛâÚÊÔÈÁɾ»Â·¹¾³¼½´¼½´Á·ÆÇ½ÒÑÅÜÜÑçåØíæÝôïèþýúüÿþýþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþýþüÿþýáÞÙÉüÀ»²¸µª´²©²±§´²¨·µ«¼»°Ã÷¼³Á»²¶±¨ª©ž§¤š¦¤š®­£­«¡š˜Ž¦¤š¥¤˜žœ“ ¡–Ÿ•š“œ’œ›‘ž‘›ž’¡• ¤˜¡¤˜¢¤˜¦¦—¦¥š©¦œª©Ÿ³³¨·»«¹·­ÇÁ¶ÒÉÀÞÕÍÿÿÿúøñùöóÿüúÿÿÿþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþ“š—Š™•œ‘› •Ÿ¢—¡¡–¤¢˜£ž•­§½³«ÞÔÌþýùþýüþþþþþþþÿÿêíè·¾´©¬§ š˜™–™Ž’–Š‘™‹’˜Œ“›Ž–ž’•ž‘—œ–˜‹—–Œ–”‹–“Š•”Š“’ˆ——Œœ›¡ •¥¤™¬ª£¹¶­ÊǼÜÙÎðìäþüøýþúðòìßãÙÅʽµº®µ¸¬·¸«¿½±Èȼôòéÿÿýÿýüÿÿùø÷îüüõÿýûÿþÿýÿýþþþþþþþþþþþþþþÿþýÿþþþþþþþþþþýÿþýÿþýÿüþþýþþþþþþþþþþþÿþþüÿüéïéÓÜÑÆÐľź¿Ã¸º¾µÃżÆÇ½É˾ÒÓÇâáÓïðåíèßïêâÿþùþþýþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþýþþþÿþûýúößÙÔÇÁº¸²ª´¯¦°¯¥®¬¢°®¤²±¦ÇÅºÆÆº¾»°¸¶«²²¥©©¥¦š¤¤—­®¤ª©Ÿ›‘¢¡–¤¤—›‘žŸ•ž¢—Ÿ¥š¡–œŸ•ŸŸ•Ÿ“ž •Ÿ¦™ §š£¦š¤¦š¡£—¦§›¨§­¬¢´·¬²·«º·¯Ä¿¶ÎƼÝÔÉÿûñ÷óéïìåÿüúþýýþýÿþþÿþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþ”’›Ž•œ›¡–¤¬¡¡§ ¢˜¢¢˜¦¤š©¥¹°§ÔÇÀùóïþþúýþýÿþþþÿþô÷ð½Ã·ª¯¦Ÿ —𛑓—Œ”˜‹’—ˆ“šŠ’™Œ—œ‘”š‘–Š”–‰””‡––‰””Š––‰––Š™™œœ¢¢•©¨±¬¦½»²×ÖÌííãûúöÿþýþþþýþûúûõ×Ûк½±µ¹­¶¸­½½°Ì˽ãàÔùøíúøðìåÞÝÖÍü÷ðÿÿÿþüýÿþüþþýþþýÿÿÿþþþþýÿþýÿþþþþþþþþþþþþþýÿþýÿþÿýþÿýþÿýþÿýþÿýþÿýþþýùüùÞæÜËÖÉÅËÁÅȾÂȾÐÔÉÓ×ÌÐÑÇÓÔÈóóèøûôôïêñíçüúõþÿûþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþýýýÿÿþÿþþÿÿúùôîÜÔÍÇ¿¸µ°©®¬£«ª ¬ª ­« ²¯¤ÊɾÇȹ¿Ä¸²¶ª±µ©ª®¢¤¨œ£¦š«¬¢««¡¡ – ž•žŸ’Ÿ“ž”Ÿ¤™¡¨ž¥›Ÿ¦›¢§¢¥™ž£—£©œ¢©œ¢§›¥¨œ¤§›¦§ªª¢®°¦¶¹®´º®¶¸ªÀ¿²ÊÇ»ÝÕËäÛÑïçÝñëàÿÿúÿýýüþÿýþþÿþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþ•ž‘•ž‘˜Ÿ’­¯¥©³§°º®¢©¦¨ž©©Ÿ©§ž°¨ ÐºîàÜÿÿþýþüÿþþÿþüñõíºÁ³§¬¢Ÿ–˜šŽ‘•Š’–‰“–‰—ˆ’˜Š“™“–“”‰”“…”“…“”‡”–Š––Š••Š››  ”§§›¬«Ÿ·°ªÊŽôõëýþ÷üþüþþÿüýÿüÿýùüöÛá×¶½±²¸«´º­½¾±ÏÎÀÝÛÌæáÒÛÖÇØÊÁÓÈ¼ßØÎùñïÿÿÿýùöüûùýþýþþþþþþþþþþþþþþþþþþþþþþÿýþÿýþÿýÿþþþþþþþþþþþýþþýþþÿþþýþüâéàÓÛÐÌÑÆÍÏÄÊÑÄÜâÖÚÞÓØÙÏÔÔÉñðèüþýÿüùúôðûúõýýûþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþýþþúùúèߨåÚÓØÎǽµ¯°¬¥«©¡ª©Ÿª©ž­« ´³§ÀÀ³×ØÊÎØËÆÏ»ķ°¹¬©°££©©«¡ªª ¤¢˜¢¡—Ÿ¡”Ÿ¡•Ÿ –¡¥›¢ªŸž©œ¡«Ÿ¤­¡§©£¨œ¤¬Ÿ§¯¡£ª§©¥ªž©« ®¯¥±³©±·¬±¶«²·¨¹»¬ÆÄ¶ÓÍÀÝÖËßÖÍîçÜÿþøþýüüþÿýýÿÿþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþ˜Ÿ’›¡”£¥š»½²ëóìçîæ©¯¦««¡±­¢±¨žµ« Å¸±ÚÌÈôëçýúõýüóþÿÿóôí¹»®¦¦™ŸŸ’™™Ž‘–‹‘”ДД‰Œ•†–‡Ž†‘†“‡‘•†‘–Š•‰š—˜˜›œ“¤¦›«­ ´²¨·µ«ßÛÔÿÿýúþþüýÿÿýÿþýÿÿÿþùûôçê޿³¶¹©µ¹­½¿²ÔÒÆùöéÿþóðïá×ÑÆ×ÐÅÝÕÊãÛÎñãÙçÙÎùïäÿûõþÿüþýÿÿýÿüþÿþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþýýýÿÿÿìïæÛßÓÓ×ËÑÔÈÖÓËÜÜÓßãØÜáÖÚÝÒù÷òýÿþþþýýþýûûûýýüþþþþþþþþþþþþþþþþþþþþþþþþþýÿþýÿýýýÿÿýðëè×ÎÈÙÏÈÐǾ¼µ¬°¬¡ª¨žª§žª§ž°¯¤´¶ªËÎÂñöìæíéßçàÅÏÃÃË¿°¹¬¡ª´º®´¹­¥§›£¦šž ”Ÿ£—Ÿ¥˜£ª¥« £« ¥­¢¨°¦§°¤§¯¤®²§ª®¤¦¬¢¢«Ÿ¦¯¢­±¤²µ©±¹¬°·ª´´©µ¸©»½®ÁÁµÊʾ×ÕÊÙ×ËçãÙþüöþÿýþþþþþþÿþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþ™ž’¡¤˜›‘Ø×Îûÿýþÿÿ²¶¯¶·­®« ¯¦œ°¬ž¸±§È»³Í¾¸ÛÍÄêáÖõñî¼¹²¬¬ž¡¥–š ’’™Ž’˜“Š‘ˆ”‰”†Š”„ކ’†”ˆ•†‘”‰”™™•Ž”¢£™§¨ž²°¥¹·ªÂ»±âÛÕÿÿüûþþüþÿÿýÿÿýÿÿÿÿçéáÉÎÁ±·©³·¨´¸­¼½±Â·ËɺØ×ÉÙÙËËÌÀרÌäáÖÜÙËÝØËæàÒðæÜû÷ðüýûþýÿÿýÿüþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþýýþÿÿþîñèßã××ÛÎÓ×ËÔÓÈÚÚÏäçÛãèÝäæÝþþùýþýþþþýýýýýýþþþÿÿÿþþþþþþþþþþþþþþþþþþþþþþþþþýÿþþþÿþûãßÚØÎÇÌ»Ľ´¸±©°ª¡«ªŸª§Ÿ®«¢´³§¼¼°ÚÙÎþýöùýù÷úõèíãËÑÆ·½°§« ÌÓÆ«±¥§ª¤¦š¡£–£¦š¡¨›§®¡©¯¤§¯¤©±¦®¶«­µª¯¶«³¸­«°¥«±¦¨¯¥­µ¨±´©µ¸«ÉÏüÁµ·¶«µ¸©º¼®ÁÁµÉɽÓÒÇÖÖËçåÝÿÿûþÿüþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþ™‘¡•¡¡–áßÖþÿþúúù±³®¯¯¥¬©ž­§œ©¦œ¶¯¥Â¶°ØÌÅúõñöïéÖÓʶµª®°¡ ¥–™Ÿ“’š•š‘”‹‘ˆ‘‡‹‘‚”…‘ˆ’‡‘“ˆ•‡•˜–›Žšš“Ÿ –£¤š®®£·µ©¼º¬ÈÀ¶âØÐÿýùýÿýüÿþÿýÿÿÿÿüûøÖÙÏÂÆºµ»«±¶§²¸¬º¼°¼¼°ÂÁ³Ì˽ÓÕÆÌÐÅåèÛøùïÒÓÇ××ÈÜÝÏèáÖúùòüþüþýÿÿýþüþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþýÿÿÿþïòêåéÝßãרÜÐÛÚÍãåÖæèÛçèÞòóíþüûþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþÿýþüùÙÖÏÒÉÁžµ»¶­²°¦¯«¢¯ª¡¬ª¢°®¥µ³¨ÃÁµÚÔËüùñþýûÿÿÿÙØÑÎÏŽ¾´²µªÇÍñ¶«¨©ž£¤š¦§¦ªŸ¥« «±¦®´©­µª²º¯µ½²µ»°´º¯·½²¹¿´´º¯«±§¶½°¶·«Á·ØÞҾķºº®·¹­º»®¾¾²ÇÇ»ÐÏÄ×ÕËêçáýüøýýýþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþ˜‘›Ÿ”§¨œ¼º°ìëèÿÿÿÉÉ´±ª¬©žª§›®¦ ·®©¸¯¬äÞÜÿÿÿûÿþòõëÅȼ°´¨¥§›žž”›“–›’”‹‡’“‰“…Ž“†’‡‘“‡’”ˆ’•†”˜Œ˜œžŸ–¢£™«ª¡¶·ª¾¼®¿¾°ÏÈ»ßÔËýú÷þþýüþþþþþÿýüîîèÝÝÔÁʵ¹­²·«²º­¶»¯¸º®¿¿°ÆÆ¸ØÚËÌËÂéèàüûòÕÔÉØÕËàÞÑàÚÐÿÿùüþþþýÿÿýÿüÿýþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþÿýÿÿÿýêêãììâïðåâãÛààÒïîàðïäöøîþþúþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþÿýôóîØÕÍÍŽ¾»²»º°µ´«³±§²®¥²¬¥¶´«º¸­ÂÀµÖÑÆñçÞÿýúÿý÷áßÖÁÀ¶»¼²´µ¬²·¬­²§¨ª ¦§¨©Ÿ¯²§¬²§°¶«²¸­±¸­¹ÁµÀȾÀź»Á¶ÇÍÂÌÒÇ´º¯´¸­¼Áµµ¶ªÍÎÂçëßÀÇ»¼¼°ºº®»¼°½¿³ÈÈ¿ÚÛÑØÚÏóôîýüúÿýýþþþþþþüþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþ•ž¢—¥§œ·µªÜÙÒÿÿûº¸¯¨§§¥š§£˜¬¤œµ«¥´«¥éäßÿÿÿ÷ýýûÿ÷ÏÓÉ®²§ ¢™”𙑒˜‘”‹‘‰’’ˆ‘”†“…’‘ˆ”“‡“•‰“–‡–˜Œ—›ž”¨¦œ¶´©Â¿µÈÊ¼ÂÆ¶ÔÓÅäÞÕúöñýýýûþþýþþþüøñòèóôêÂÆº³¹¬¶½°±º­·½°¹½±¼À°ÃÇ¸ÕØÉÓÏÅÑÌÂÙÖÍÌÊ¿ÚÙÍÝÜÑâÜÔÿÿúúþýÿýÿþþþþÿýþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþÿþþþýúêëãøùðÿÿùúúõØÚÏççÝõóêÿÿùþþýýþÿþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþÿüù÷ñÙØÎÌǽÀ¾³¼»±¾¿µ¹·®³­¦¶°©¹¶®½½±ÆÅºØÓÉëãÙõîæßØÍÈĸÀÀ³º»­·º¯³¹®°µª«¬¢«¬¢­­£°³¨±¶¬µ»¯¹¾³¹Á¶ÎØÊäìßÊÍÂÇÌÂÙàÕÏÕʹ¿´º¼²ÂƺÄÁ¶ÉɾõøíÕÛν¾³¾¾²¼½²Á¸ÍÎÄÞà×àâØüÿüýþþÿþÿÿýÿþþþüþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþ”ž‘™¢– £˜®­¤¾º®©§›¬ª ž‘¢¡–¢ –§¢–¬¥˜¸¯¥ÎĺõñëÿÿÿßÜׯ¬§£¤žšž—‘™Ž–Œ‘—Œ‘“‹’”‹““ˆ‘’…“…“‘‰””ˆ““‡“•ˆ•—‹šœ¢ –®«¡¿½³ÕÔÆÞáÒÐÖÅàâÔåáØõñêþþüýÿþþþýüúóççÞçèܽÁµ¶½°·½²·¿²·¿²¸½²¾Â²ÅȹÆÊ»ÉÅ½ÈÆ¼ÆÄ»ÊÉ¿ÝÝÑâä×ßÚÒÿÿúûÿþýþþÿÿýþÿýþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþýúúûó÷øîþÿöÿþúÿþþèçá÷õðÿü÷ÿÿüÿþþüþÿþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþÿüîîçÖÕÊÌɽÁÁ¶ÂúÃÄ»½º²·°ª»³¬¹·®ÄźËÍÀÓÐÆÕÎÆÕÌÂÏǼÃÁ²¾¾¯¹¾­·¼­·¼²µ»°¯±§¯±§±²¨²¶«¸½³»Á¸ÀÆ»½Å¹äíáÙáÕÔÖÌÑ×ÌÙßÔáçܶº°¸¹¯¿Á´ÆÅºÕÔÉôøëËÐÄÅÇ»ÀÀ´ÁÁ¶ÄÅ»×ÙÎãçÝõ÷ðûÿüýÿýÿýþÿýÿýýÿüþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþ–œ‘› –¡¤›©ª «¬ ¶·¬»¼°Ÿ – Ÿ”¥Ÿ—£¢–¨¡—·¬¤½²ªðéâìêâÂÀ¶©ª Ÿ¢——›“–‹”•‹’–‰”Дޑ‰Ž’ˆ‹„Ž’†”“ˆ—•Œ”•‹™™¡›”ª¤¹µªÕÒÇýýóÿÿú÷øôîîäÛÛÏñëãÿýøÿþýÿýÿýüóáÛÐÌȽ¾½²º¿²·À²¼Â²¾Ã´¾ÂµÁȼÃɾÀǹ¸ÂóÃŵɯ»ÒÐÆ×ÔÉßÛÎúùñÿýûþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþÿþÿýúüüöûüóüþùþÿüüþýüúúûüüýûùÿýøÿýûûþÿüþþüþþþþþþþþÿþþÿþþþþþþþþþþþþþþþþþþþþþþþüþþüÿýþÿúëéâÙÖÌÏÉÂȻǹÄÁ¸¼¹¯¹¸¬»µ®Ã¼¶ÌǾÖÓÊÛÜÒÜàÖÔÑÈÇǺÁ²¾À´¼¼´»¼±½»¶¹»µ¯µ¬±·«´¶¨¼»¬ÁźÎÑÅÏÔÇÍÓÈýÿúúüúôöòãåÞøùðåçÛ½¿³»»°Ã·ÍË¿éèÚþþõÙÝѿż»¼´ÄźÉÍÀ×ÛÐíóìùýüÿþþÿþýÿþýþþþþþþüþÿþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþ“𛡕Ÿ£™¥¦œ§¨³µ©¹½°¡¡˜ž“¡œ“ ž“¤ž”®¤›½³ªß×ÏËÈÀ±°¦¤£™™’•™Ž’–‹”•‹“ˆ”‰Ž“ŠŽ“ДДˆ“‡—•Š—–Œ˜™Žœœ’§¢š³­¤À»³óòéÿýøþýùýþüøúòÙÙÍëçÞùóìÿþúðíëÚÕÊÌǼ¿»°¹¹­¼¿³»Âµ¿Å³ÃɹÆÊ¾ÈÐÂÉÐÃÃË»ÂĹįµÄÅ´ÆÅºÊȾÐÍÃÝÚÌíêâþüùþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþýþüúþýùþþùþÿûþÿýþþþÿþýýýýþýûþúöýûöýþýýþþþþþþþþþþþþþþÿþþþþþþþþþþþþþþþþþþþþþþþýþþþÿýþýúèäÜÞ×ÍÔËÅËüľ¶À»²¼¸®¾»±ÆÁ¸ÏÊÃ×ÓÊëçàõõïöúòרÏÌÌ¿ÃŶÁÄ¸ÃÆ»¾Â³¿À¸¼À·µ¼±¶¼±¸º­ÃµÍÎÃ×ÚÏÓÕËåçßýÿûýÿýþÿþÿÿÿÿÿùåèÞ¹½±¹½±Â½²ÆÁ´ÔÏÁßÞÐàßÕÄݹÎÏÄÐÓÈÕØÏùú÷ÿþÿþþþýþþýþÿýþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþ–Ÿ’™ –›¡•¢£™¥§›¥ªž¢¦šž“›œ™ ’¢’©¡—³ª¢¼¶­º¶¬«©Ÿ¡¢˜”—Œ“—Œ•Š“‰“ˆ•Š“ˆ–‹‘–‹’–‹’–Šš˜—–‹šš ¡—©¥œ½¶«×ÓËþþúþüûÿÿþþþþðóêÙÙÎãáÓß×ÌÜÔÊΞÆÂ·À¾³¸µª´µ©»¾²ÂƹÅËºÓØÉÓÖÊÍÕÈÏÖÇÄ˽ÁǼÀŵ¿Â³Ã÷ÆÄ»ÏÍÁÛØÊêéßþüúþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþýýýÿýýýüüþþþþþþþþþþýþÿý÷ûûúþýüýúöõðìþûúþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþýüýüøæÞ×ßÕÌ×ÐÇÑÉÁɹĽ³Â¾µÈûÓÑÆßÜÓîëåÿýúþþüþÿýïðëÕÚÍÈͽÆÊ¾ÀƺÂË»ÄÆ¼Àĸ½Ã·¶½±¼¿´ÈǽÔÕÈéçÞéêáÿÿûþþýýüþþýÿýýýüþúöùóÈÎĻĶÀ¼³¾º¯ÃÀ³ÇƸ×ÙÍÎÎÄÆÇ½ÔÕÊÉÊÀÞà×ÿÿþÿüþÿþþýþÿüþÿüþÿýþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþ˜¡”˜¡” ¦™¡¥˜ ¤˜£¦šž¢–šŸ’ššŽš˜Œž™Ž ›¢œ‘«¥›®¨Ÿ¬§ž¦¤š›š‘–š•˜“ˆ“ˆŽ’‡•ŠŽ•ˆ—Š’—Œ”˜“—‹›œ››œ¥¦šµ²¦ËźíêäÿÿþÿþþþýÿÿýýøùðÝÝÒÕÓÆÐʽÐɼÍÅ»ÁÀµºº®´µ©¶·«¾À´ÌÎÂÒÕÊìðåÚÝÔîôêêðåÝãÖËÐÆÅʼÁǶÃĹÇÅ»Í̾ØÔÇìêâÿþüþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþýýýÿþþûøï÷öóüýüýù÷ðêäþüøþþýþþÿþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþÿþýùöòêäÝà×ÎÔÍÄÐÉÀÎÆ½ÊƽÌǾÔÑÈçåÚíëäþýûþýýþþþþÿýûþüëîåÒÓÈÒÖËïöëËÔÇÌÑÄÆÊ¾Äȼ¾Á¶ÄÅ»ÐÎÄííãøöïþüùþýýÿþþþýÿþýÿþýÿüþýýþûÒÙϼĸ¾¿µ½¾±ÂõÅǸÏÕÉÍÔÉÆÈ¼ÒÓÈÆÇ½àÝÖûøóÿûøÿÿüÿÿýþþÿüþÿýþÿÿþýþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþ™¢•— “™¢“ ¥–Ÿ£˜ ¥™ ¥™—˜™Š™˜Š›—‰š—Š›—ŒŸ›¤ •¥ –£ž•𙗙ޑ—ŒŒ“ˆ’‡Œ…•‰‘˜Š‘˜Š’˜Œ–š˜œœ ž“¡¢–©«·µ¦ÔÎÄÿÿûÿþþýýÿýþýÿÿüôóêÕÒÉÊʼÅĶÅĶÃÁµ¼¼±·¹­¶¹­µ¸¬ÈʾÝÜÑúû÷ÿÿÿùùöþÿþþÿüöüôÚãÙÊÔÅÆÍ¼ÆÈ¼ÈƼÐÐÁÛØËëéàÿýûþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþýþþþþýÿÿýþÿþýÿþüùõë÷õðýýýûøôèàØüõíþüûþþþýýýþþþþþþüþþþþþþþþþþþþþþþþþþþþÿþþþþþÿÿýùøôðíæàÜÓÜ×ÍÖÔÊÒÏÅÑÎÅÕÓËáÞÖûúñÿÿüüýýýýÿþýÿÿÿýýÿþööðÒÒÉóóîÿÿüäìãÒÖÊÎÒÅÈÍÁÂŹÌÍÁÞàÓûûõúúõÿþýÿýþýþþýÿýþýÿþýÿþþþýþûÚÝÕÀø¾Á·À·ÁõÃŶØÜÏÕÛÎÃùÉÊ¿ÆÇ¼ÏÍÃÚÒÈðäÚþøíþûõÿþýýþÿýþþÿþýþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþ• “›£”𢓡¦˜¡¥™£¨›¤˜šŸ—™Š˜—ˆ™–ˆš—‰—”ˆš— › œ‘™™˜—˜’˜Ž”‰‹‘‡”‰•‰–‡’™Š•›˜œ‘˜œ‘¡Ÿ”¥§˜¬®Ÿµ³¥íèÝÿÿþÿýÿüþÿüþûþþøÞÙÏËǾµ¾¿±½À´¸º°·¸«²¶ª¶º­»À³ÏÏÄñïåÿþÿýüþþýÿýþÿüÿýûþûøÿøàéÛÍÕÄÈÌÀÎÏÃÓÒÃÞÛÎöôìÿþúþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþüÿýþþþþþþÿþþýûøøøñòìàþü÷ýþþû÷õæÜÕïåÜ÷ôôÿÿÿþþþþþþüþþüþþþþþþþþþþþþþþþþþþþþÿþþÿþþþÿýüþùúüóõôëíëßâßÕÙÙÏÜÚÑçåÞôòìÿþøýþûûþþüþÿýþÿÿþþþÿþøùóïìæÿÿþýýü÷ýøðóê÷úðÎÑÅÍÏÃÒÔÆìîáÿÿýýýüýüþüþÿüþýüÿýþÿýþÿýþýüþþüÛØÑÊÊ¿ÄºÇźÆÅ¶ÄõÍÎÁÌÎÂÄù¿ÁµÂŹÐ;ÞÕÇéÜÎðäÕúòæýû÷ýýýþýýþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþœž”Ÿ¢—£—£©ž¬¯¥©®££­š¡’œœ‘›–—–Š—•‹˜”Ž™–›˜˜—Œ™–‰––ˆ”–ˆ“–ˆ–—‰––‰”–Š•—Š”š‰’š‰”œŽ”œ›žœ¡¢¥•¨©™³°¤¿·­ïéãÿÿþüüÿýþÿÿÿýíéßËʹÄÄ´¿¾°¼½±¼»°¶¸®¶º®·¾­¹Â­Åɹáà×þýúÿÿýÿþýÿþþþÿýþÿýüÿýýþüòôíÝßÔÐÒÅÔÕÊàßÖÛÚÏýûôþÿýüþþýþþþÿýþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþüÿüûÿþûþþÿþüýúòïåÙíäÜÿþûüþüõõóÚÔÎëÞÕõíçÿýúýþþüþÿýÿþÿÿüÿþÿÿýþÿþþÿþþþþþþþþûþþýþþÿþþÿýýþýýüýÿÿÿûüþøò÷ðø÷ñýûùüþýýÿýþÿýþÿýþÿþþþþþþÿþþþýýüûûûþþþþþþþþþÿþÿýþùçíáÆÍ¾Þà×ëêäþþüþÿüþþþýýýýýýýýýþýÿÿüþÿýþðéåÐÎÇÇÊÂÅþÆÃ¼Ä¸Ä¸ÊɼÆÅ¶ÁÀ´ÅŹÃŹÉË¿ÔÔÈÚÙÍéâÕôðçûøõüýýüþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþž •¢¤™¢¦›©¯¤®¶ª°¸¬¦¯ ›¡”™’˜š›™—•Š—•‹˜•Œ˜–Œ—•Š˜•Š”’‡’”ˆ’”ˆ“”ˆ––Š–˜Œ–™Œ–›‹’š‰•”šžŽ¡’¡¥•ªª›´±¤ÈÁ¸áÜÒþüùüýþúþþüÿúòóèÝàÓÆÊ¾¼Â³·¾±µ¼°´¼°·¾²¼¾°ÂóÌʾüûöþþýþýÿýþþýþþýÿýþÿýþÿýþÿýûü÷ãçÜÚÞÒÜßÔßá×äá×úúòþÿýýþþþþþþÿýþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþýÿýûþþüþþÿÿýöñêíäÚçÜÕýùôÿþüêäàÖÎÆåÛÐíãÚþøòþþýýþÿýÿþþÿýþþÿþþþþþþþþþþýÿþýÿýþþýþþÿþþÿþþýþþýþþÿþýûÿýüÿþÿþýþþüüþþþþþþýÿþýÿþþþþþþþþþþþþþþþýþýþþþþþþþþþüüÿýþýúÿøÒØÍóóìÿÿÿüýüþÿýþþûú÷ôøõðÿü÷üöðúõïìåÞÜÖÍÙØÌÇȼøÂÀ·Ã¸Â¸ËËÀÄŻöÂ÷ÂĸÉË¿ÓÔÈÖÓÉãßÓïìàüúïþüõÿþüüþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþ¡¢˜¤¤›¬®¤³¹®±¹®±·ª©¬ ¢£—› ”–Ÿ“›™Œ—–ˆ—•Š˜–‹—–‡—–ˆ–”‰”’ˆ“’ˆ’“‰”•‹•–Œ”—‹•™—›Ž•˜ž‘•œ›ž’ ¢”¥©™«ªœµ´§ÃÀµ×ÒÆù÷ñÿÿþýýûûü÷ýÿ÷ïðçÞâØÁÆ»¸Àµµ¿²³½°¶¾³¼¾±Ã½±×ÏÇÿÿýüþþþýÿýýÿüþþüþþýþþþÿýþþÿûüùúýõëïääéßäêàèåÚø÷ðÿþüþþþþþþþÿýþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþÿþüìèáäÛÒá×Íóéáøìæ×ÊÄÝÒÊÝÖÉëßÓùîçÿùõÿþûÿýûÿþúþÿþþþýþþþþþþüþÿýþÿÿþþÿþþÿþþþþþþÿýüÿþþýÿûþÿüýýÿüýÿþþüýýÿýÿÿýÿþýÿþýÿþþþþÿýþþþþþþþþþþþþþþþþþþüýÿüÿýúÿúôôñÿÿþþüþûýýþþýÿÿýîèàôëâñæÛòäÚúñääßÑÝÛÏÐÍÁÇ÷Á¿µÀ¿´Â÷ÆÈ¾ÎÒÇÃǼÄďůºÇɽÉË¿ÓÒÇÐÎÃÜÝÑñðáûóäüöéþüöûüþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþ¦¨œ£¥™»¿²·»¯³µ©¬­¡ª©ž££™ £—œ ”𙋙™‹˜—‰—–ˆ˜—Š—–ˆ”“‰•”Š–”Š•”Š––Œ–——›™‘˜œ›ž’—ž‘˜Ÿ’ŸŸ•¡£—¨¨š­­Ÿ³´§½¾²ÓʽæÜÓóîçýúôûùñúúòóðé×ÖÍÅÅ»¼ÀµºÀ´µ¿°´»°»»°ÈÁ·ÕÍÄÿýøýþûÿýýüûúþÿÿüþþýþþÿþþÿþÿþÿýøúóñõê÷ûðñôêâÞÓùõíÿþüþþþþþþþÿýþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþýûüüø×ÒËÚÓÊÛÒÈÕǾÕžÖÊ¿ÜÔÈáÛÍïâÖôèÝýõíþûõþüøü÷óýùôÿüùÿüúýýýþþþüýÿÿþþÿþþþþþþÿüþÿýÿÿýÿüÿÿýþÿÿþûõóùôóÿþüÿýýÿþþÿýÿþýÿþýÿþÿýþþþþþþþþþþþþþþþÿÿÿÿþÿÿÿþüüùýþúýýýþýÿüþÿþýüÿÿúâÚÒñéÝíãÕæÚÏßÕÌÞØÎåãÙÁ¾´Ã¾´À¾±¿¿°ÃƸÓÔÊÛßÓÇËÁÆÇ»ÚÝÐÒÔÈËÎÁÑÐÄÓÏÄßàÔñïÞûõäþøëþý÷ûüþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþ¬¬ ­­¡¼¾²¶º®À¾±Õ×̺¿µ¤¬ ¢§ž¢•žœ‘›š™˜Šš™‹˜—Š—•‹˜˜Œ—•Š–”‰•”‰™šŽ—šŽ•›Ž™œ‘—›‘˜œ’š’šŸ“  —¥¥š©©œ­­Ÿ³·©¹¾²Îȼ×ÎÄà×ÌäÛÐåàÔÝÜÏÑËÂÏÌÂ÷¼À´¹¿±·¾¯µ»¯¹º­ÃÀ´×ÑÅïêßùõìôêæòìéýüúþÿýýþþÿþþþýÿþÿüýýõêëÞîîâíìâßÚÎõðèÿýüþþþþþþþÿýþþþþþþþþþþþþþþþþþþþþþþþþþþþþþýÿÿþýýýþþýÿýüýú÷îëäÑÌÃÒÍÂÒÉÀÎÆ½ÏǼ˸ÖÍÃåÝÑìâ×íâØóèßòäÜòäÛòãÜóåÞ÷ìåûóíÿüúÿýüþýþÿýþýþþþÿýþÿýÿþüÿþûÿÿüÿÿüýúôçÚÓîäßÿþúýûóþüøÿüüÿýÿþýÿýÿýþþþþþþþþþþþþþþþþþýÿþúúøóþûöÿÿúþýüûþÿÿþþþýüÿþúßÜÓåáÕÞÚËÕÑÆÓÌÃÙÒÈÛÖËÅĹ¿Á´¾¾°¿¾°ÌÌÀÜÞÑããÙÜÝÒËÍÁìîâÖØÌËÍÁÖÖÊÎÊÀçåØäâÖôòçþüõþþûýþÿþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþ³´¨¸¸­ÃĹ¹¼°ÞÞÐþÿùÒáÕ ±¥¡® ¤• Ÿ•š™Ž˜˜‰˜—‰—–Š™–•˜Š––ˆ—–ˆ——‰šœ˜œ—ž’–œ˜›’™“¡–¢–¢£šªª ªªŸ°±¢´¹«»ÂµÉǼÖÒÆÚÖÈÝÙÊâáÑàßÑÍË¾ÇÆ¸½Á±ºÀ²µÀ°¯»ª´¹­¶¹«ÃÄ´×ÖÅêäÔöîßïâÙñçßþýøþÿýþýþþýÿýþþÿÿþìëãÕÔÇâÞÑáÜÏãÛÒòíåÿüúþþþþþþþÿýþþþþþþþþþþþþþþþþþþþÿþþþþþþþþýþþþþûúúûüùÿÿüñîèØÖÍÎȾÆÄ¸ÊÀ¸Ä¿¶À¾³Á¾²ÊùèÝÓèàÖâØÏåØÍåÕÉêØÍéÖÌëØÍíÝÒëß×óíçþûùþþýüýþüýýûþûÿÿüþûøøðêñëßíçÚÞÕÇèÖËèØÐ÷ðçüúñúùñÿþýÿýÿþýþüÿþþþþþþþþþþþþþþþþüüýüõììäÛèáÙùöðýþøûÿýþþþÿüüÿÿþâãÚÜÞÓÔÕÇÉοÌ̾ÌÈºÊÆ¸Çȸ¿Æµ¾¾²¼½°ÊɽÚÙÎ÷öëÞÜÒÐÓÇ÷ùîÙÛÏÎÑÄÚØÌÓÏÄðéÝüùñþüúüýýýþþýýýþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþ¶¼¬ÌÓÆÏÕÉÀĺøööþÿÿîó𳺯«²¦Ÿ¢š›Ÿ’—›˜›Œ˜›Œ—šŠ—™Š•—‹™•Š™•Š˜˜œž’Ÿ¡•› ™ž›¢”™ ’£”£¦˜ª©Ÿ¬®¢¯²¤´¹ªºÀ²½Ã·ÌοÛÝÎÜÞÏÚÜÎÙÚÌÐÓÄÊË»ÁÅ´¸¿°µ¾®µ»¬´¹«µº«»¿°ÍÍ¿ÓÑÄÜØÌ÷ôêîåÛéãÙýûõýýúýþÿüýÿþýÿÿÿÿæäÜÙÓÉÞ×ÉÚÓÄàÙÌñïæýþüýþþþþþÿþþÿþýýÿýüþþûþþüþþüÿüýþùûþûûþùÿÿôý÷îõíæñêàÿþõèæÝÎËÁÇûĽ¶Á¿µÀ½µ¿º²Á¹±ÍÁºàÒÉãßÔÝÕËÙÎÄÙÌÂÝÐÇÝÐÇÝÐÇàÔÊâÖÌíàØùñéÿüóýøîýøîÿúõýûôóêàîãÚäÛÎéßÓâÙÍÙÒÅÚÓÆáÚÏéÜÒòêâÿüúþýýýþÿþýÿþüÿýþþûþüýþüÿþüþüúóçâëá×âÝÑîìáýü÷þþýþýÿýýüÿÿÿÚÖÐÚØÍÔÒÅÉ˼Ì˽ÉÉ»ÆÈ¼ËÐÃÇÎÁ¾Â³½¾³ÆÆ»ÙÙËðîáØ×ÌÓÑÈæãÛÔÕÌÖÔÊâÞÕÏÊÁïîæÿÿüüýýüþÿÿýÿÿþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþñóëÿÿû÷øóüüùýþýþÿÿìñîºÂ¶ª²¦ž¦œ¢——œ˜›Ÿ’››Žš™Œ—˜š•Šœ˜Ž›š ¢—¢¢–¡’£”¤•¤•¡¥–©­«­£²¶¨´¹ª»Á±ÃǸÌÐÂèëÚäçÖáäÔáäÔÙÜÌÑÔÄÉͽÁÅ·¹¿°³¼¬µ¼­·¼­¹¿°ÇË¼ÖØÊÎÍ¿ÔÐÆãàÔäÚÐìéßÿýõÿýùÿüùÿýýýþýÿÿÿêéáÕÕÉÛØÌ×ÓÆãÞÑðîåþýúüþþþþþÿþþþÿýýþþýþþüþüþþøûûóþúòûúóüüôûõéôëÝèàÖäÚÑÝØÌÔÑÇÇÆ»ÂÁ¶Â¾´¾¼±¾»²¼¸°¾¶¯Åº³ÑĺØÒÈØÑÆÔÉÀÏÄ»ÑżÐżÓȽ×ËÁÛÍÅáÕÍèßÖñêáñçÝùñçôíäéãÚãÜÓãÜÑÜÔÊÙÒÈÔÎÃÒÌÁÙÓÉÞÚÐÞÓÇåÝÕüùõýýüýþþþþþþýÿþþþýþýýüøûøóíçâæÝÕåßÕêæÜääÙýþùþÿþþýÿýþýÿÿþæãÝÛÚÐÑÐÅÊ˾Ë˾ÉʽÏÐÄÙÝÒÇÎÂÀǸÁùÆÅ½ÕÕÈêéÞÜÖÎÐÏÅÏÏÅÓÒÈØ×ÍÜÙÏÊŽÿþöþýúþþþýýÿüýÿþþÿþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþÿÿýýþüþýýýüýüþýýÿÿñõñÂʽ®·© ¨ž¢—™ž“šž“ž”ž’š™˜™˜œ˜£¡—¨©Ÿ¢¢˜ ¡• £– ¤˜ §š§«Ÿ²´§´º¯ºÀ±¸¾¯ÌξÓׯèéÚûýòðòæõ÷êíðäêìáãäÙÍÑÅÆÊ½¼Ä³¸¿°¹¿°¸½¯¿Â²ËοÎÑÂÌÎÀÕÔÉ×ÔÉØÒÅôñéþýóðîæñíåý÷ñÿýöýûõàÝÕØÖËÓÑÆÒÐÅåßÒôòéþþúüþþþþþÿþþþþþþþþþþþþüùüùðûöëÿúðüúñÿÿøóïâéä×ÞÛÐÙÑÈÑËÁÊȽÄÅ·¿À²ÁÁ²¾»°ºº¯º¸°¾·°À·¯Æ¼³ÒÊÂÚÑÊμʿ¸Ç½¶È¾¶ËÁ·ÐƼÔÈÀ×ÎÅÝÕÌßÙÐæÚÒëáÙÞ×ÎáÝÓèæÜÔÒÈÓÐÆÒÏÄÈÅ»ÌÊÀ×ÖÌÕÓÈÝÓÆàÛÏöóêþþúþÿüþþþþüÿþþþýþüýûöõñèìäÙâÞÕåä×èèÛææÝþþûþþþþýýÿÿþúøõïìç×ÕËÍÎÃÌÌÀÎÏÂËÉ¿ÓÓÉÝÞÔÐÔÉÆÌ¿ÃÆ½ÅƾÍÍÂËȽÐÈÂÐÏÄÒÑÆÒÒÆ×ÕÊÖÕÊÕÐÇîìâÿÿùÿýûÿþþýþÿüþÿþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþÿýþÿÿüþþûýþþþýþþþöøóÇÎÀ­µ¦¢ª ¢—šŸ”›Ÿ”š›‘œ›‘›‘™š ›‘¤ —®­£»½³­¬¢¦¦š£¤˜¢¦š§«ž¯³§¹½±ÇÍÂÈÌÀ¿ÄµåçÚêìàûúñþýùþýùÿþûþýúÿÿüüüøÙàÔÎÓÇÄȼÁÆ·½Â³ºÀ°ÂŶÄɺÊÐÁ×ÙËÜÛÐÒÏÄÔÎÀïëßüúóôîçóíäôïãôíäߨÏÜÕÌÚÒÉÕÏÃÚÓÈåßÒûúñÿÿûüþþþþþÿþþþþþþþþþþþþþúøöë÷òãþúðüú÷ÿÿýòñéáàÖÖÖÎÔÏÆËȾÈȼÂŶ¾Á³¿¿±¾¾°¼¼°»º¯º·¯½¸®Ä»²ÈÀ¹ÕËÃɽ·Åº³À¸°Ã¼´Ç¾´ÊÀ¶ÏżÐǾÙÒÉÜ×ÎàÖÎà×ÎÔÌÄêæÝêêßÎÏÅÇÆ¼ÈƼÃÁ·ÈƼÖÔÊÚ×ÍØÑÅàÚÎðîäÿÿ÷þþûþþþþþþþþþþÿýÿýøöòèìæ×ááÔììßççÝåçÞÿÿüÿþýýþüÿÿü÷óîëèߨ×ÌÎÐÃÓÒÆÒÑÅÍÌÀÐÏÂÓÔÇÑÔÈÇ˾ÈÊÁÇÇ¿ÑÏÄÒÏÄÓÍÇÔÕÆØ×ÉØÖË×ÕÊÖÔÉÖÖËèäØöñèþùôÿýùÿÿüýþüþþþþþþÿÿÿþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþ÷óððîëÿÿýÿþüÿþûÿÿÿðïêÉÊ¿²¶§ ¦›œ ’›ž‘œž‘šœ›ž“œž“Ÿ‘¤ “«¨œÅŸÎÑ𰣪¨¦§›¥©¬°¤´·«½ÁµÞáÕÕØÌÊÎÃøúñþÿùýüøþþþýýýþþþýýþýýýüýþñøíÞâØÉÍÁÅȺ¿Äµ¿Å´ÅÆ·É;çìßÜâÓÑÓÇÌ˾ÕÐÀãÜÐöôëú÷ðóïçïëáëèÜòïä×ÔÊÖÑÆÓÏÁÛÖÈèáÔþþõÿÿýüþþþþþÿþþþÿýþýÿþýÿÿþüùøíïëÜúöêþýøÿÿÿèåàÞÜÓÓÔËËÊ¿ÇÇ»ÂøÀ·ÁÁ¶À¿´¾¾¯½½°¼¼²º¹¯½¹¯¿¸¯Ä»±Å¼²Â¸®Âº°¿¹¯¾»±Å¾²Å¼²Ë¹ÏÈ¿ÚÕÌ×ÕË×ÓËÕÑÆÍɾìçÝìêàÇÆ½ÁÁµ¾¿³ÂÀµÃÁ·ÈÆ»ÏËÁÕÎÂÞÙÎðíãÿýöþýûþþÿþþþþþþþþþþþúø÷îêçÚåãÔèçÚäãÙõôîÿÿýýþüÿÿùþüõëåÛÛÕÊÓÒÅÐÒÃÔÔÈÒÒÅÏÌÀÎ̾Ë̼ÏÏÀÉ˽ÉÉ¿ÌËÂÏÐÂÓÒÅÚ×ÍáåÓîîÞààÒÚ×É×ÕËÚØÍèåÖæÜÑìáÖýñêýøðÿýõþþþÿÿÿýýýþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþȼ¶ÑÆÀÕËÄýû÷ÿþûêæå½¹»º®©ª¡–œžŽ›Ž™ž›Ÿ“™Ÿ’ £”§¢•¯¬žÙÙË×ÙË­®Ÿ¬©©©©¬ ¹¼°ÈÌ¿º¾²ãä×ÙÛÎÔÖËÿÿüúüùûýþýþýþÿýýþüþÿýÿÿþüþûùþ÷äéÞÏÑÅÇɽÃǸÀÈ·ÆÅ·Ó×ÇþÿõçìàÅÇ»ÎÍÀÖÐÀîìáÿþøÿÿúþüöýúñíñåÿÿúÞßÕÙÙÌÙÚËÝÝÌîêÝÿÿ÷ÿÿüüþþþþþÿþþÿÿÿþþþþüþýýû÷÷íîíÞùóäûùðýûöåà×ßÙÎÔÑÆÉÊ¿ÃǼÂźÁÁ·ÂÁ¸Â¿·¾¿¯¾¿±½¾´¾¼²¾»±À»²Ä»²Äº°Ã¸®À¸®¿»¯¾¼±Â¼±Ã¼±È¿¶ËÄ»ÓÐÆÓÒÈÑÑÉÈɾÐÍÁØÔÉËȾÂÀ¶¾¾±ÀÀ²ÂÁ³ÃµÈÅ·ËÈ»ÕÎÄàÚÑõóéÿþùþþþþýÿþÿþýþþüþÿþþýûûóîîâìèÙçåØïìãÿÿúýýúûú÷ÿýôôïåàÙÌÖÏÁÔÒÂÔÕÄ××ÉÑÐÂÏ̽ÌʺÊɹÊʸË˽ÎÎÃÑÑÆÑÓÄÙÜÍïðæõùèúûêòðáåáÔÜÚÏëêÞëçÙá×ËêÛÎñã×õëßùõéýüüþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþÅÁµÆÂ·ÏÎÄõõëóòêÓÒÇËÍÁ¸»¬¥«›œ£’ ‘›Ÿ›žšŸ‘›Ÿ”œŸ”¤¡“ª£–±¦š¿µ¨¯©›©¨š¥§˜««²²£ÇÆ»ÈÆ½ÁÀµÏн××ÈíîåÿÿüþþþüþÿþþþþþþþþþÿÿÿþþþýþþúýóâåÜÏÔÊÈɾÄÇ·ÅɶÉȹÏÍ¿êêÜãã×ÄŹÍÏÃÔÐÃïíéÿþÿüÿþüþûÿþýúøìÿÿùçêââæÞââÕäàÐö÷ñÿÿþþþþþýÿþþþþþþþýÿþýýÿþúÿýòóñåñíàûòçòèÞêÞÕÞÕÊÜÚÌÔÔÅÊʼÆÇ¹ÆÄºÄ¸Å·ÆÂ³Á¿µÁÀ¶¿¿µ½À´»¿³¾À´ÂÀ³¿¼±¼¹°¼º°¾¼²¾½¯Á¾±Á½³Áº±Ç¿¸ËȾÌËÀËË¿ÆÄ¹ÉǼÊȽÂ÷»À³½¼±½½±ÂÀ¶Ã´ÈÅ·Í˽×ÒÂãàÔýýùþýýÿþþÿþþþþþþþþþþþþþþüýýùùùïðâðïãüúòþýõÿýõû÷íÿüðïëàÜÚÏÛÖÉÚÕÆáÝÏíéáÔÒÇÎÏÂÈʺËË»ÎͼÎÏÀÏÐÄÒÔÉßà×ëíæþÿúþûùýûó÷öìçäÞåãÛõóéáÞÑÛÖÉáØÌåÛÏìä×óìßûóêÿþöþþüýþÿÿüÿÿüþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþ¿½³Â¾²ÏÌÁëëßòòèþþ÷ËÏÄ®³§¦­Ÿ¦— ‘ ‘ ‘šŸ‘¡•Ÿ£—£¢”¨¥—¯¨›±ª«§™¦¥–¨©š­®¡´´§¸¹­ÁÀµÍÊÀÙÚÌëêáüüöÿþýþþþýþþþþþþþþþþþþþþþþþþþþýþúñôíÚÞÒÏÑÃÇË»ÇʺÉÈ»ËʼÈǹË˽ÉȽÑÏÄÕÑÄÿýúÿýÿüþþýÿüÿÿÿóñçýþôþÿòûýòëëÜðïàþÿúýþýÿÿÿþýÿþþþþþþþýþþýú÷õíòïäíçÙíçØîêÝéáÕáØÌâÛÎçæÚàãÖÐÐÃËÌÀÇÆ¼ÆÄºÇÇ»ËʽÆÅ»ÀÁ·ÁĹ¾Â¶À¶Á¶Ä¶ÂÀµ¿½³À¾´Á¿´Á¿³Á¿µÁ¾´Á¼³ÄÀ·ÃÁ¶ÃĶÂÁ¶À¿´Á¿´ÂÀµ¿À´¹¾±½¼°¼»°¿½²Ã´ÆÅ·ÐÍ¿×ÔÆðîæÿþüþþþþþþþþþþþþþþþþþþþþþýýýþþþüþôö÷îÿýõóðæû÷ìîêÝÿÿòíèÚàÛÍ×ÔÇãàÓúùððïèÕÕÊÎÑÃÉ̼ÏÑÂÓÓÅÛÜÕööðùúõ÷øõÿÿþýþüþýþÿÿûÿý÷ýûøôòîêéßÞÝÒ×ÓÈÚÓÈÝÕÌçßÕóëáôéßþøïþýúÿþýþþÿþþÿþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþ¹¸®À¾²ÎË¿èå×þþøÿÿÿÖ×Ϋ®£¥ª¡•šžŽ ‘Ÿ¢“ž£”Ÿ¢—ž¢–£¥–§¦˜«¨š±® ®¬ž©©›¬¬ ²²¦´´¨¼¹­ÆÅ·çæÙýýùþþûÿþüþþþþþþþÿýþþþþþþþþþþþþþþþþþþþÿÿûý÷æéÞÙÜÌÏÑÃÌÎÂËÎÀÈʼÅÅ·ÈɺÌÊ¿ÎÊÀãÝÑÿÿÿþüþüþþýÿüÿÿÿôòèïìàîè×öïÞåàÑ÷óèýÿúþþþþþþþýÿþþþþþþÿþûùøñòðçñíàæàÑäÛÌäâÕäâÓÞØËçâØúùñëîäÛßÔÏÑÆËÍÁÆÇ¾ÕÖÌîðçÊÏįɾÄȽÅÇºÇÆ»ÉźÉǼÇĺĸÃÁ·Ä¸Ä·ÃÁ¹Á¿·Â¿¶À¾²ÀÁ³¿Ã³¿À´ÀÀ³¼»°¿½²¼½±»¾²¼º¯½»°¿½²ÁÁ²ÆÅ·ÎοÚÕËöõïÿþþþýÿüþÿüÿýþþþþþþþþþþþþþþþýýýúþøýüøÿþ÷÷õêùõèôëÝÿùëëåÖäÞÐÙÕÊòðèÿÿøûûõÛßÓÌÑÃÎÐÁÏÑÄÚÚÐ÷ù÷ýÿþýþþÿþþýüþþýÿüþÿýÿüýþûýþýÿÿýðñéØ×ÍÙ×ÍÕÑÈÝÖÍëäÜñêáñâ×÷íäý÷ñÿýùþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþ³¶«¼¼¯ÎÍÂÚÖÊÞØÓÝØÓ­ª ­«¡£¤˜ ¡•› ‘ ¢”Ÿ¤–Ÿ£—¡–£¦•§©š­¬ž®­Ÿ®­Ÿ­¬ž±±¥´´¨»¹®Ä·ÑÐÂ÷÷ëþþüÿýþþýÿþýÿþÿýþÿýþþþþþþþþþþþþþþþþþþÿþÿýþüöúðçéÜÚÜÏÖØÍÐÖÆÉ;ÇÊ»ËʽÌÊ¿ÏÌÁáÛÎÿþûþüþûýýýÿüÿÿÿøòëåÜÐâØÈàÕÇäÚÎñæßÿÿýýýüþþþþýÿþþþþþþÿýøøõîíëàéæ×áÜÍÜÕÈåæ×ãáÓàÝÏàÝÑýýöþÿûìîæËÎÃÒÒÇÒÒÆéêäÿÿÿÔØÍÈÌÁÉÍÂÊÊ¿ÎÍÂÏËÀÌÊ¿ËÊÀÊÇ¾ÈÆ½ÆÄºÅøÁ¾·Ã¹À¾³¿¿²ÀÁ²»À±½¿³¼½±º¸­¼º¯¿¿³º¼°½»°½»°À¾³ÁÀ²ÆÅ·Í;ÛÔËøõðÿþþþýÿüþÿüÿýþþþþþþþþþþþþþþþþþþüþþüýûýýõöõêüúîõñßòîßëãÔèáÔÜØÎÿÿúýýüþÿüíðæÙÜÎÒÕÆÑÔÇèéÞÿþÿþýüþýþþýÿþýÿþýÿüþÿüÿýþþþþýÿþþþõøðîëáÕÔÊÕÑÈÛÖÍõîäìãÙîÞÔóçÞúôêþü÷ÿÿüüþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþ°´¨½ÀµÄǻø»¶­­§Ÿ­«¡§¦›£¤–¡£”ž¡“Ÿ¢“Ÿ¡“¡¦˜¡¤˜ž£—¤§—«­ž±±£³²¤³±£³±£··¨»¹«ËʽÍËÀÖÑÆýüõþýýþýÿþýÿþýÿþÿýþÿýþþþþþþþþþþþþþþþþþþþþÿþþþýýüöõðäæÚàãÒÕÛÌÐÔÅËοÍÎÀÏÎÃÙØÍÚÖÉûøôþûþüÿþýÿüÿÿÿôîçòëã÷òéþúñõïèéß×ÿÿýýýýþþþþýÿþþþþýýÿüøóðæìêÞÜÛÎÖÕÈÓÐÅçëÛããÔáÞÐáÞÑýüõþþûðòìÍÍÃÙÙÌÝÝÒüû÷üþýîïæÎÑÆÍÒÇÏÑÅÔÕÉÔÑÆÒÑÆÐÏÆÌÊÂÊÈÀÇÆ½ÇǼÅûĸÂÁµÁÀ±Á¶º¼±º¾±¼¼°»¹®»¹®»º¯»»¯½¸®»¹®½»°À¿±ÆÄ·Ë̾ÜÔÆöñéÿÿýþþþýþþýþþþþþþþþþþþþþþþþþþþþýþÿþþýüýõüûïýüí÷öçòðãíèÛìæÙßÛÒÿþûþþÿüþÿùùõçæÚÒÑÁÕÔÈüûòÿÿúÿÿûþüúÿþüþþýþþþýþþþÿýþþþÿýÿýüúÿÿûáÜÑÖÓÈÓÐÄÜ×ÌîæÜíâØèÛÓîãÚóìãÿÿúþþýüþÿþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþ±¸«³¸­µ·®³³ªµ¶¬°²§«®¢¡©š §—ž§•¥¨™¢¥–£¦—¢¨™¤¨œ¤§œ©«ž±±¤¸¸ª¹·©¶³¥¼·ª¿¾®ÇÅ·ÛÙËÚ×ÍÚÖÍùõíýÿþýýþþýÿþýÿþÿýþÿýþþþþþþþþþþþþþþþþþþþÿýþýÿþýÿþûü÷øîîòàçëÜèëÜÐÓÄÔ×ÉæçÚÞÞÓçâÕÿþûþüþüþþýÿüÿþÿýûòýý÷ûÿýüþþ÷ôñ÷ñéýÿúþþþþþþÿýÿýþýýýýüöñíéàæãÙ××ËÏÐÅÐÑÇÓÔÆÞÝÏãßÐîéÝùøñÿþýõõðÖÔËãàÒèåÛÿÿýüþþóóìÕØÍÕÙÎÙÝÐÝÞÑÝÜÐÛÛÐÕÔËÒÑÉÎÌÅËÉÁÊÉ¿ÉǽÇŻŵÃÁµÂ¶½½³¹½±»¼°¼º¯½»°½¼°»»¯½º¯¾º¯¾»±ÁÀ²ÄĶËʼÚÒÃëãØþûõÿýûÿýýþþþþþþþþþþþþþþþþþþþþþÿüÿÿÿþþýöüýñüûîýþïòñçöòåîèÛîèÞýú÷þüþþýÿÿÿþïîãÐÍ¿çåÖõóèñëáæáØù÷ðÿýøÿþüüÿýþþþþÿýÿþþÿüÿþþûÿÿüêåÚÚÖÈÓÐÂÙÒÆÞÕÉáÕÊåÛÓîåÜ÷ñéÿÿûþþþýþÿþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþ±¸«°·ª°²¦®°¤°±¨²³¨«¯¡¨­ž¤ª›§®¡©±¥£¨¥§œª­¡¥«ž¤«ž±¯¦·¶ª¹º¨Åƶ»»«¿½°ÄÀ±ÑÊ»ßÖÈãÚÍéãÙóòéýÿÿýþþþþþþþþþþþþþþþýÿþýÿþýÿþýÿþýÿþþÿþÿýÿþýÿþþÿþþÿüýþýüûÿýøúòÝÞÑæåÛúùñßãÖßÚÏÿþøÿþüÿþþüýþúþþþýþÿýþýþÿûþýþüùýóìÿÿýùþüüþþÿýþÿýþùþûúøðëèßÝÛÐÙ×ÌÑÏÆÐÎÇÖÔÇßÛÌëä×ôðæüüöþþüòîæÖÑÇæã×íåÝý÷óÿýþõôíàÞÕàßÓääÕêêÙèèÖçä×áßÔÜÚÏÖÔÉÒÑÇÏÎÄÌÉÁÉǾÃùÂÁ·Ä¸À¾³¼¾²¼º¯¼º¯¼º¯¼¾±º¾±»¼²»»°¾¿°ÁÀ²ÆÃ·ÌȾÖÍÀæÚÎøìãÿüôüÿûûþþþþþþþþþþþþþþþþþþþþþþþýýýüýýüüüýüûýüûÿüùùôëíå×òêÝýûõûýþüýÿÿÿÿéæÞÙÒÆñêßýõì÷éÜæÚÎõðæþý÷ýþûýþþÿýÿÿýþýþüþüøúôìíâØÛÔÉ×ÑÆÙÐÆÝÔËÝÓËßÖÎçÜÙìáÚ÷îçÿÿþýþþÿþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþ¯¶ª­´¨­°¥««¡­®¥²³¨ª® ¦«œ¥ªœ«±¥±¶¨©® ¦­Ÿ«±£¬°¢¯°£¹¹«À¿³âãÙññçÉȼ¿¾°ÚÚÎßÜÐÙÒÈóíäüûôúúôüþþüþþüþþüþþüþþýþþÿþýÿþýÿþýÿþýÿþýÿþþýþÿýþÿþþþÿþþÿþþÿþþýÿýûþöìîåýüøýýùÛÙÒÝÙÍðëäÿþúþýûýþýüþýÿþüÿúøÿþüÿþûîçâíàÙÿúõüÿúüÿþþþþÿþþúþüÿþùñðèâãØÛÜÐÒÒÆÑÐÆÙÖÈÞÛÍîîàþýóÿþøñðíäà×××ÌááÓîéÝ÷óéÿÿýòðçåãÛêèÞòðæùøîõöêôñèõóêçåÛÞÛÑÚØÍ×ÔÉÓÎÅÎËÁÈÅ»ÅùÄ÷¾¿±¾¾²¼»°½»°½»°¾¿³»¾²»º²¼¼±¾½±À¿²ÇĸÎÊ¿×ÎÁâÖÊðåÛúõîþþúýþþþþþþþþþþþþþþþþþþþþþþþþþþþþýþþþþþþþþþÿþýÿûóöîáõìàýùñþþüýþýÿÿþäà×ÞØÌàÚÍáÙÏêáÒçÜÐðæÛþ÷ðÿýüýÿÿûÿýýþûÿýùöîèìÝÕáÐÇØÐÆÕÏÃÕÏÄÞØÏÞØÏàÚÑæÞØêá×öîåýýúýþþÿþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþ­²¨¬²§¬®¤ª«¡¬­¤¯±¦¨«§©š¦ªœª­¡°²£¨­ž¢¬ª³£¯°¢¾·ªÃ²ÝÜÒÿÿüÿþüàÞÖßÜÍÿÿúø÷ðæäÚÿÿùÿÿûüýýþþþþÿþþÿýýÿýýþþýþþþþþþþþþþþþþýþþþþþþþýÿüþÿüþÿüþþÿþþÿþþÿýþüÿùúý÷üúúÿþþÝÕÓØÐÆäÜÒñéâÿÿüþûøýúøäÙÒèÜÖöìåþüöîæÞåÖÏøíäþùòüþüúÿþýýÿÿýÿÿýýùû÷ëíåÜÜÑÙÛÍÕÕÆâÜÏíêÞøøíüþõþþ÷äßÛÞÚÐÜÛÐééÚòëÜíéÛððäñíãõóêüùõýü÷ÿþûüýûþýûÿýøôñéëäÜçàÔàÙÌÜÔÊÕÐÄÍÉ¿ÅĶÅÄ·ÁÁ³¾½²½»°½»°¾¼±¾¿³¿¿³¿¼´»º°»º°Ã¿´ÈøÎȽÒÎÀáÕËêà×øóìþüúÿþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþýþÿÿýùöîäùðä÷ïæÿüöÿþüÿýùèâÙÜÖÈØÑÃÚÓÈàÞÏàØÉïà×þïêÿüúýþþýþøÿÿüýõðìÜÕãÔËÛÎÄÔÍÃÒÍÂØÕÉãÞÕäßÖâÝÔéâØèàÓòêßúúõþþÿÿþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþ¯²§¯³¨¬®¤ª«¡©ª¡¦¨¦©š¦©š¦©›¦§›©ªœ¥ªœ£¬¬°¢µ³¥ËµÛÚÌüûõþýþÿÿÿ÷óîôïáÿÿúÿþ÷êèÞéäÝþþúüüüÿüúÿýûþüöþü÷ÿþúÿýüþþþÿþþÿÿÿÿÿÿþþþþþþÿþÿþýþþÿÿüþþÿþþÿþþÿýþþþúýüõþýüõððÖÊÈÚÍÁÛÐÅàÕÊëß×èÜÖÚÎÉÖÊÀåÕÌûôëÿÿ÷ôíäéÙÓïâÖñéàüúöúþýüýÿÿýÿÿÿÿýýüúûõèêàââÔàÝÍèàÕòïäþþõÿÿöøöíߨÏàØÎâÜÑøóçûòçýôéþûðüøñÿüùÿþúÿþþþýÿüþÿþþþþýýþü÷ôòêèãÙæÞÑáØÏÞØÍØÓÉËÊ¼ÇÆ¸Á³ÿµ¾¼±Á¿´ÀÁ´¿¿³¾¾²¿½³½»±¿º°ÆÀ¸ÌÅ»ÐÊ¿ÔÐÄàÕËêßÖ÷óìÿþûÿýÿþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþüþþÿüøúòêôëÞõìáúñèöòìâÜÓÜ×ËÛÒÉÚÓÅàÛÍèèÛ÷òçäÓÊòàÙýðìÿþûýôî÷èáìÚÓßÑÉ×ÏÄÎʾÒËÀÓÍÂÚÖËòìãçäÛæãÙíæÜìäÖöîãúúöüýþÿþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþÌÐIJ¶ª®°¥«¬¡ªª¡¥§œ¦©š¦§™§¨›§§›¤©¥ªž«­¢²²§¼·®àÖÍúúõüýûýýþþÿþúôïóéàÿþùÿÿýëåÚæßÕÿÿÿû÷÷ôìèüõïöîæôíäúóíÿúöÿú÷ü÷ô÷ñíïèäÿÿýþùöü÷ôÿþüþÿûüþþýþþÿþþÿþÿþú÷ðèàèÛ×ÕÉÄÐÆ¾ÏŸ×Í¿ÙÏÂßÔÈÝÒÈßÒË×ÍÇÝÐÊìâÙóðèíäÞìÛ×èßÐðãÙþ÷ñþýýüþþÿýÿÿþýþÿýüýúö÷îîëßèâÓòíâðëáõïç÷òëçá×ßÚÐáÙÎæàÖíåÝöíæÿøôÿþúÿýûþþýÿþýþþþþýÿþýþüþÿþþÿýþûþûööôêñîãéåÜïìâÝÚÏÒÐÆËÉ½ÆÆ¸Ç·ÄÁ¶Ã·Â¶ÁÀ´ÄÀµÀ¼³¿º²Â»´ÈÀ¹ÍÅ»ÒÉÀÖÎÄãÖÍðåÜüöòþÿþýýÿþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþýÿþÿþúùóëõëàòæÛòèàöðææÞÕÞÔË×ÎÄØÑÃßÙÍýýôõîèÚÉÀêÕÎëÛÓîâÜïÛÔìÚÒåÖÏÙÎÆÏÇ¾ÌÆ½ÓÉ¿ÖÍÃÛÔÉõñèñìãõñçîåßïåÛûòêýýúþþþÿþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþäèÜ»¿³¬¯£³µ¨°²©§¨¦©š¦¦˜¦¦™§¨œŸ¨ž¥© ­«£¸±©Æ½¶úøòÿýýýþþûýýÿþüûôîßÒÊõíæâ×ÎÌÁ³ÛÒÅûöðçÞÝÙÉÃãÔÌéÜÒåÚÏéÞÕçÜÖñãÙðàÖäÕËçØÎæØÍìÝÒïâÜùòìþüøþÿýýþþþýÿþÿþþùôñâÙê×ÑàÒÉÓͽËȺÐ̽ÒϼÓÎÀÕÏÃÓËÂÑÈÅÙÎÊáÖÐÞ×ÐßÖÑçØÕáÞÏëÝÓûíéÿÿûýÿýÿþýÿþýÿÿþýþúþýöùóéõëÝüûñôìåìßÙã×ÐÜÔÊÝÚÍãÝÐîìáýûôþüûÿýþúýÿþþÿþýÿýýýþþþþÿýÿþýýþÿûþþýþüýÿùþþ÷þþõýýöÿÿùîîäØ×ÍÌËÁËÉ¾ÌÆ»ÈÅºÆÆºÃ÷ÄĸÅÁµÃ½µÁ¼µÄ»·Ê»ÎÅ»ÓÉ¿ÚÑÇå×ÎñäÜÿüøýþüüþÿþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþÿýÿýù÷ðèòçÝðãÚíáÙéáÕâÙÍÚÐÆØÎÄÕÎÀèâÖÿÿüïéàÖÉÀáÐÅæÔÉåÓÉáÏÈàÒÊÖÍÄÓÊÁϼҼÓȾÕËÁá×Íÿÿûþúñøòêþøõôêãþõîþýûýþþÿÿþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþþxrdp-0.9.5/xorg/tests/xdemo/common.h000644 001751 001751 00000001546 13125122134 017320 0ustar00metameta000000 000000 /** * xrdp: A Remote Desktop Protocol server. * * Copyright (C) Laxmikant Rashinkar 2012 * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ #ifndef __XDEMO_H #define __XDEMO_H #define DEBUG #ifdef DEBUG #define dprint(x...) printf(x) #else #define dprint(x...) #endif struct pic_info { int width; int height; char *pixel_data; }; #endif xrdp-0.9.5/xorg/tests/xdemo/xdemo.c000644 001751 001751 00000055055 13133557325 017160 0ustar00metameta000000 000000 /** * xrdp: A Remote Desktop Protocol server. * * Copyright (C) Laxmikant Rashinkar 2012 * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ #include #include #include #include #include #include #include #include #include #include #include #include #include "common.h" // LK_TODO // http://tronche.com/gui/x/xlib/GC/convenience-functions/fill-tile-and-stipple.html // fill stipple // drawfonts: XDrawString, XDrawImageString XDrawText XLoadFont XTextExtents // http://www.ac3.edu.au/SGI_Developer/books/XLib_PG/sgi_html/apa.html // http://www.ac3.edu.au/SGI_Developer/books/XLib_PG/sgi_html/index.html // use jpg lib to convert bmp to jpg and vice versa #define MAX_COLORS 5 #define SCROLL_JUMP 1 // scroll in increments of g_winHeight #define SCROLL_SMOOTH1 2 // scroll using XPutImage + XCopyArea #define SCROLL_SMOOTH2 3 // scroll using XPutImage only #define SCROLL_SMOOTH3 4 // scroll using XPutImage only #define SCROLL_SMOOTH4 5 // scroll using XPutImage only int parse_bmp(char *filename, struct pic_info *); int drawBMP(char *filename, int scroll_type); int signal_tcp_proxy(char *proxy_app); // globals Display *g_disp; Window g_win; XColor g_colors[MAX_COLORS]; GC g_gc; int g_winWidth; int g_winHeight; int g_delay_dur; void start_timer(struct timeval *tv) { gettimeofday(tv, NULL); } uint32_t time_elapsed_ms(struct timeval tv) { struct timeval tv_now; uint32_t dur; gettimeofday(&tv_now, NULL); dur = ((tv_now.tv_sec - tv.tv_sec) * 1000) + ((tv_now.tv_usec - tv.tv_usec) / 1000); return dur; } uint32_t time_elapsed_us(struct timeval tv) { struct timeval tv_now; uint32_t dur; gettimeofday(&tv_now, NULL); dur = ((tv_now.tv_sec - tv.tv_sec) * 1000000) + (tv_now.tv_usec - tv.tv_usec); return dur; } int drawLines(int count) { int x1; int y1; int x2; int y2; int i; int index; if (count <= 0) { return 0; // nothing to do } srandom(time(NULL)); XClearArea(g_disp, g_win, 0, 0, g_winWidth, g_winHeight, 0); for (i = 0, index = 0; i < count; i++) { x1 = random() % g_winWidth; y1 = random() % g_winHeight; x2 = random() % g_winWidth; y2 = random() % g_winHeight; XSetForeground(g_disp, g_gc, g_colors[index++].pixel); if (index == MAX_COLORS) { index = 0; } // from-to XDrawLine(g_disp, g_win, g_gc, x1, y1, x2, y2); XFlush(g_disp); usleep(g_delay_dur); } return 0; } // LK_TODO support user defined w and h int drawRectangles(int count) { int x1; int y1; int w; int h; int i; int index; if (count <= 0) { return 0; // nothing to do } srandom(time(NULL)); XClearArea(g_disp, g_win, 0, 0, g_winWidth, g_winHeight, 0); for (i = 0, index = 0; i < count; i++) { x1 = random() % g_winWidth; y1 = random() % g_winHeight; w = 160; h = 140; XSetForeground(g_disp, g_gc, g_colors[index++].pixel); if (index == MAX_COLORS) { index = 0; } //XDrawRectangle(g_disp, g_win, g_gc, x1, y1, w, h); XFillRectangle(g_disp, g_win, g_gc, x1, y1, w, h); XFlush(g_disp); usleep(g_delay_dur); } return 0; } int drawFont(int count, char *msg) { int x1; int y1; int i; int index; #ifdef CHANGE_FONT_SIZE int w; int h; int actual_count; char **font_list; #endif if (count <= 0) { return 0; // nothing to do } srandom(time(NULL)); XClearArea(g_disp, g_win, 0, 0, g_winWidth, g_winHeight, 0); #ifdef CHANGE_FONT_SIZE font_list = XListFonts(g_disp, "−*−courier−*−*−*−*−0−0−*−*−*−0−*−*", 2000, &actual_count); if (!font_list) { printf("actual_count=%d\n", actual_count); for (i = 0; i < actual_count; i++) { printf("%s\n", font_list[i]); } XFreeFontNames(font_list); } else { printf("XListFonts() returned NULL\n"); } #endif srandom(time(NULL)); for (i = 0, index = 0; i < count; i++) { x1 = random() % g_winWidth; y1 = random() % g_winHeight; XSetForeground(g_disp, g_gc, g_colors[index++].pixel); if (index == MAX_COLORS) { index = 0; } XDrawString(g_disp, g_win, g_gc, x1, y1, msg, strlen(msg)); XFlush(g_disp); usleep(g_delay_dur); } return 0; // nothing to do } static void drawoffscreen(void) { int depth; Pixmap pixmap1; Pixmap pixmap2; printf("draw off screen, should see green rect\n"); depth = DefaultDepth(g_disp, DefaultScreen(g_disp)); /* blue */ pixmap1 = XCreatePixmap(g_disp, g_win, 64, 64, depth); XSetForeground(g_disp, g_gc, 0x000000ff); XFillRectangle(g_disp, pixmap1, g_gc, 0, 0, 64, 64); /* green */ pixmap2 = XCreatePixmap(g_disp, g_win, 64, 64, depth); XSetForeground(g_disp, g_gc, 0x0000ff00); XFillRectangle(g_disp, pixmap2, g_gc, 0, 0, 64, 64); /* copy green to blue */ XCopyArea(g_disp, pixmap2, pixmap1, g_gc, 0, 0, 64, 64, 0, 0); /* put on screen */ XCopyArea(g_disp, pixmap1, g_win, g_gc, 0, 0, 64, 64, 128, 128); XFreePixmap(g_disp, pixmap1); XFreePixmap(g_disp, pixmap2); } /** * display a usage message */ static void usage(void) { printf("usage: xdemo [-l] [-r] [-s] [-f ] [-i ] [-g ] [-c ] [-o ] [-d ] -z\n"); printf(" -l draw lines\n"); printf(" -r draw fill rectangles\n"); printf(" -s draw stipple rectangles\n"); printf(" -f draw string using fonts\n"); printf(" -i draw image\n"); printf(" -g geometry, default is 640x480\n"); printf(" -c iteration count, default is 5000\n"); printf(" -d loop delay in micro seconds, default 1000\n"); printf(" -o \n"); printf(" -z zero proxy counters for specified application\n"); printf(" -j offscreen to offscreen test\n\n"); } int main(int argc, char **argv) { XEvent evt; Colormap colormap; struct timeval tv; int screenNumber; long eventMask; unsigned long white; unsigned long black; Status rc; int iters; int opt; int draw_lines; int draw_rects; int draw_stipples; int draw_fonts; int draw_image; int draw_offscreen; int zero_counters; int scroll_type; char image_file[256]; char proxy_app[256]; char msg[4096]; // set some defaults g_winWidth = 640; g_winHeight = 480; iters = 5000; draw_lines = 1; draw_rects = 1; draw_stipples = 1; draw_fonts = 1; draw_image = 1; draw_offscreen = 1; g_delay_dur = 1000; scroll_type = SCROLL_SMOOTH1; zero_counters = 0; strcpy(image_file, "yosemite.bmp"); strcpy(msg, "To be or not to be!"); // process cmd line args opterr = 0; while ((opt = getopt(argc, argv, "lrsjg:c:f:i:d:o:z:")) != -1) { switch (opt) { case 'j': draw_lines = 0; draw_rects = 0; draw_stipples = 0; draw_fonts = 0; draw_image = 0; draw_offscreen = 1; break; case 'g': if (sscanf(optarg, "%dx%d", &g_winWidth, &g_winHeight) != 2) { fprintf(stderr, "\nerror: invalid geometry specified\n\n"); usage(); return -1; } break; case 'c': if (sscanf(optarg, "%d", &iters) != 1) { fprintf(stderr, "\nerror: invalid count specified\n\n"); usage(); return -1; } break; case 'l': draw_lines = 1; draw_rects = 0; draw_stipples = 0; draw_fonts = 0; draw_image = 0; draw_offscreen = 0; break; case 'r': draw_rects = 1; draw_lines = 0; draw_stipples = 0; draw_fonts = 0; draw_image = 0; draw_offscreen = 0; break; case 's': draw_stipples = 1; draw_lines = 0; draw_rects = 0; draw_fonts = 0; draw_image = 0; draw_offscreen = 0; break; case 'f': if (strlen(optarg) <= 0) { fprintf(stderr, "\nerror: -f option requires an argument\n\n"); usage(); return -1; } draw_fonts = 1; strncpy(msg, optarg, 4096); draw_lines = 0; draw_rects = 0; draw_stipples = 0; draw_image = 0; draw_offscreen = 0; break; case 'i': if (strlen(optarg) <= 0) { fprintf(stderr, "\nerror: -i option requires an argument\n\n"); usage(); return -1; } draw_image = 1; strncpy(image_file, optarg, 255); draw_lines = 0; draw_rects = 0; draw_stipples = 0; draw_fonts = 0; draw_offscreen = 0; break; case 'h': usage(); return 0; break; case 'v': printf("xdemo Ver 1.0\n"); return 0; break; case 'd': if (sscanf(optarg, "%d", &g_delay_dur) != 1) { fprintf(stderr, "\nerror: -d option requires an argument\n\n"); usage(); return -1; } break; case 'z': if (strlen(optarg) <= 0) { fprintf(stderr, "\nerror: invalid proxy application specified\n\n"); usage(); return -1; } strcpy(proxy_app, optarg); printf("##### LK_TODO: proxy_app=%s\n", proxy_app); zero_counters = 1; break; case 'o': if (strcmp(optarg, "jump") == 0) { scroll_type = SCROLL_JUMP; } else if (strcmp(optarg, "smooth1") == 0) { scroll_type = SCROLL_SMOOTH1; } else if (strcmp(optarg, "smooth2") == 0) { scroll_type = SCROLL_SMOOTH2; } else if (strcmp(optarg, "smooth3") == 0) { scroll_type = SCROLL_SMOOTH3; } else if (strcmp(optarg, "smooth4") == 0) { scroll_type = SCROLL_SMOOTH4; } else { fprintf(stderr, "\ninvalid scroll type specified\n\n"); usage(); return -1; } break; default: usage(); return -1; } } // must have at least one operation if ((!draw_lines) && (!draw_rects) && (!draw_stipples) && (!draw_fonts) && (!draw_image) && (!draw_offscreen)) { usage(); return -1; } g_disp = XOpenDisplay(NULL); if (!g_disp) { dprint("error opening X display\n"); exit(-1); } screenNumber = DefaultScreen(g_disp); white = WhitePixel(g_disp, screenNumber); black = BlackPixel(g_disp, screenNumber); g_win = XCreateSimpleWindow(g_disp, DefaultRootWindow(g_disp), 50, 50, // origin g_winWidth, g_winHeight, // size 0, black, // border white ); // backgd XMapWindow(g_disp, g_win); //eventMask = StructureNotifyMask | MapNotify | VisibilityChangeMask; eventMask = StructureNotifyMask | VisibilityChangeMask; XSelectInput(g_disp, g_win, eventMask); g_gc = XCreateGC(g_disp, g_win, 0, // mask of values NULL ); // array of values #if 0 do { dprint("about to call XNextEvent(...)\n"); XNextEvent(g_disp, &evt);// calls XFlush dprint("returned from XNextEvent(...)\n"); } //while(evt.type != MapNotify); while (evt.type != VisibilityNotify) { ; } #endif // get access to the screen's color map colormap = DefaultColormap(g_disp, screenNumber); // alloc red color rc = XAllocNamedColor(g_disp, colormap, "red", &g_colors[0], &g_colors[0]); if (rc == 0) { printf("XAllocNamedColor - failed to allocated 'red' color.\n"); exit(1); } rc = XAllocNamedColor(g_disp, colormap, "green", &g_colors[1], &g_colors[1]); if (rc == 0) { printf("XAllocNamedColor - failed to allocated 'green' color.\n"); exit(1); } rc = XAllocNamedColor(g_disp, colormap, "blue", &g_colors[2], &g_colors[2]); if (rc == 0) { printf("XAllocNamedColor - failed to allocated 'blue' color.\n"); exit(1); } rc = XAllocNamedColor(g_disp, colormap, "yellow", &g_colors[3], &g_colors[3]); if (rc == 0) { printf("XAllocNamedColor - failed to allocated 'yellow' color.\n"); exit(1); } rc = XAllocNamedColor(g_disp, colormap, "orange", &g_colors[4], &g_colors[4]); if (rc == 0) { printf("XAllocNamedColor - failed to allocated 'orange' color.\n"); exit(1); } if (zero_counters) { signal_tcp_proxy(proxy_app); } if (draw_lines) { start_timer(&tv); drawLines(iters); printf("drew %d lines in %d ms\n", iters, time_elapsed_ms(tv)); } if (draw_rects) { start_timer(&tv); drawRectangles(iters); printf("drew %d rects in %d ms\n", iters, time_elapsed_ms(tv)); } if (draw_stipples) { start_timer(&tv); // LK_TODO } if (draw_fonts) { start_timer(&tv); drawFont(iters, msg); printf("drew %d strings in %d ms\n", iters, time_elapsed_ms(tv)); } if (draw_image) { start_timer(&tv); drawBMP(image_file, scroll_type); printf("drew BMP in %d ms\n", time_elapsed_ms(tv)); } if (draw_offscreen) { } if (zero_counters) { signal_tcp_proxy(proxy_app); } eventMask = ButtonPressMask | ButtonReleaseMask | KeyPressMask; XSelectInput(g_disp, g_win, eventMask); do { XNextEvent(g_disp, &evt); // calls XFlush() if (evt.type == KeyPress) { if (draw_offscreen) { drawoffscreen(); } } } while (evt.type != ButtonRelease); XDestroyWindow(g_disp, g_win); XCloseDisplay(g_disp); return 0; } int drawBMP(char *filename, int scroll_type) { struct pic_info pic_info; XImage *image; Visual *visual; Pixmap pixmap; int depth; int i; int j; if (parse_bmp(filename, &pic_info) < 0) { exit(-1); } XClearArea(g_disp, g_win, 0, 0, g_winWidth, g_winHeight, 0); depth = DefaultDepth(g_disp, DefaultScreen(g_disp)); visual = DefaultVisual(g_disp, DefaultScreen(g_disp)); // create empty pixmap pixmap = XCreatePixmap(g_disp, g_win, pic_info.width, pic_info.height, depth); // create an image from pixel data image = XCreateImage(g_disp, visual, depth, ZPixmap, 0, pic_info.pixel_data, pic_info.width, pic_info.height, 32, 0); if (pic_info.height <= g_winHeight) { // image is too small to scroll XFlush(g_disp); XPutImage(g_disp, g_win, g_gc, image, 0, 0, 0, 0, pic_info.width, pic_info.height); XFlush(g_disp); return 0; } // copy image to pixelmap XPutImage(g_disp, pixmap, g_gc, image, 0, 0, 0, 0, pic_info.width, pic_info.height); if (scroll_type == SCROLL_JUMP) { if (pic_info.height <= g_winHeight) { // image too small - no scrolling required XFlush(g_disp); XCopyArea(g_disp, // connection to X server pixmap, // source drawable g_win, // dest drawable g_gc, // graphics context 0, 0, // source x,y pic_info.width, // width pic_info.height, // height 0, 0); // dest x,y XFlush(g_disp); return 0; } j = pic_info.height / g_winHeight; if (pic_info.height % g_winHeight != 0) { // need to include the last part of the image j++; } XFlush(g_disp); for (i = 0; i < j; i++) { XCopyArea(g_disp, // connection to X server pixmap, // source drawable g_win, // dest drawable g_gc, // graphics context 0, i * g_winHeight, // source x,y pic_info.width, // width pic_info.height, // height 0, 0); // dest x,y XFlush(g_disp); sleep(3); } } /* ** smooth scroll the image */ // number of lines to be scrolled j = pic_info.height - g_winHeight; if (scroll_type == SCROLL_SMOOTH1) { printf("running SCROLL_SMOOTH1\n"); XFlush(g_disp); XPutImage(g_disp, g_win, g_gc, image, 0, 0, 0, 0, pic_info.width, pic_info.height); XFlush(g_disp); usleep(10000); for (i = 0; i < j; i++) { XCopyArea(g_disp, g_win, g_win, g_gc, 0, 1, g_winWidth, g_winHeight - 1, 0, 0); XPutImage(g_disp, g_win, g_gc, image, 0, g_winHeight + i, 0, g_winHeight - 1 , pic_info.width, 1); XFlush(g_disp); usleep(10000); } return 0; } if (scroll_type == SCROLL_SMOOTH2) { printf("running SCROLL_SMOOTH2\n"); XFlush(g_disp); for (i = 0; i < j; i++) { XPutImage(g_disp, g_win, g_gc, image, 0, i, 0, 0, pic_info.width, pic_info.height - i); XFlush(g_disp); usleep(10000); } } if (scroll_type == SCROLL_SMOOTH3) { printf("running SCROLL_SMOOTH3\n"); XFlush(g_disp); XCopyArea(g_disp, pixmap, g_win, g_gc, 0, 0, pic_info.width, pic_info.height, 0, 0); XFlush(g_disp); usleep(10000); for (i = 0; i < j; i++) { XCopyArea(g_disp, g_win, g_win, g_gc, 0, 1, g_winWidth, g_winHeight - 1, 0, 0); XCopyArea(g_disp, pixmap, g_win, g_gc, 0, g_winHeight + i, pic_info.width, 1, 0, g_winHeight - 1); XFlush(g_disp); usleep(10000); } return 0; } if (scroll_type == SCROLL_SMOOTH4) { printf("running SCROLL_SMOOTH4\n"); XFlush(g_disp); for (i = 0; i < j; i++) { XCopyArea(g_disp, pixmap, g_win, g_gc, 0, i, pic_info.width, pic_info.height - i, 0, 0); XFlush(g_disp); usleep(10000); } } return 0; } int process_bmp_event(void) { XEvent ev; long event_mask; event_mask = ExposureMask | ButtonPressMask | ButtonReleaseMask | StructureNotifyMask; XSelectInput(g_disp, g_win, event_mask); XNextEvent(g_disp, &ev); switch (ev.type) { case Expose: printf("got expose event\n"); break; default: printf("did not get expose event\n"); break; } return 0; } /** * send a SIGUSR1 to process tcp_proxy, causing it to clear counters * * @return 0 on success, -1 on failure */ int signal_tcp_proxy(char *proc_name) { FILE *fp; char *cptr; char buf[2048]; int pids[10]; int status = 0; int num_procs; int i; sprintf(buf, "pidof %s", proc_name); if ((fp = popen(buf, "r")) == NULL ) { printf("xdemo: popen() failed\n"); return -1; } cptr = fgets(buf, 2047, fp); if (cptr == NULL) { pclose(fp); return -1; } num_procs = sscanf(buf, "%d %d %d %d %d %d %d %d %d %d", &pids[0], &pids[1], &pids[2], &pids[3], &pids[4], &pids[5], &pids[6], &pids[7], &pids[8], &pids[9]); if (num_procs > 0) { for (i = 0; i < num_procs; i++) { kill(pids[i], SIGUSR1); printf("sent SIGUSR1 to process %d\n", pids[i]); } } pclose(fp); return status; } xrdp-0.9.5/xorg/tests/nx/client.sh000755 001751 001751 00000000350 13125122134 016775 0ustar00metameta000000 000000 #!/bin/sh xhost + # delete chache directory for testing rm -r .nx if ! [ -d .nx ] then mkdir .nx fi export LD_LIBRARY_PATH=$PWD ./nxproxy -S nx/nx,session=session,id=jay,root=.nx,connect=127.0.0.1:10,delta=1,stream=1,data=1 xrdp-0.9.5/xorg/tests/nx/server.sh000755 001751 001751 00000001144 13125122134 017027 0ustar00metameta000000 000000 #!/bin/sh export LD_LIBRARY_PATH=$PWD #./nxagent -R -bs -dpi 96 -geometry 1024x768 -noshpix -display nx/nx,link=adsl,delta=1,stream=1,data=1,a8taint=0,cache=4M:9 :9 # with cache #./nxagent -D -bs -ac -dpi 96 -geometry 1024x768 -noshpix -display nx/nx,link=adsl,delta=1,stream=1,data=1,cache=4M:9 :9 # without cache #./nxagent -D -bs -ac -dpi 96 -geometry 1024x768 -noshpix -display nx/nx,link=adsl,delta=1,stream=1,data=1,cache=0M:9 :9 # cache not set, defaulting, client script clears directory ./nxagent -D -bs -ac -dpi 96 -geometry 1024x768 -noshpix -display nx/nx,link=adsl,delta=1,stream=1,data=1:9 :9 xrdp-0.9.5/xorg/X11R7.6/rdp/000755 001751 001751 00000000000 13220727405 015116 5ustar00metameta000000 000000 xrdp-0.9.5/xorg/X11R7.6/pixman-0.30.0.patch000644 001751 001751 00000000532 13133557325 017367 0ustar00metameta000000 000000 --- a/pixman/pixman-mmx.c +++ b/pixman/pixman-mmx.c @@ -89,7 +89,7 @@ _mm_mulhi_pu16 (__m64 __A, __m64 __B) return __A; } -# ifdef __OPTIMIZE__ +# if defined(__OPTIMIZE__) && !defined(__clang__) extern __inline __m64 __attribute__((__gnu_inline__, __always_inline__, __artificial__)) _mm_shuffle_pi16 (__m64 __A, int8_t const __N) { xrdp-0.9.5/xorg/X11R7.6/buildx.sh000755 001751 001751 00000015313 13133557325 016167 0ustar00metameta000000 000000 #!/bin/sh # buildx.sh: a script for building X11R7.6 X server for use with xrdp # # Copyright 2011-2013 Jay Sorg Jay.Sorg@gmail.com # # Authors # Jay Sorg Jay.Sorg@gmail.com # Laxmikant Rashinkar LK.Rashinkar@gmail.com # # Licensed under the Apache License, Version 2.0 (the "License"); # you may not use this file except in compliance with the License. # You may obtain a copy of the License at # # http://www.apache.org/licenses/LICENSE-2.0 # # Unless required by applicable law or agreed to in writing, software # distributed under the License is distributed on an "AS IS" BASIS, # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. # See the License for the specific language governing permissions and # limitations under the License. # debian packages needed # flex bison libxml2-dev intltool xsltproc xutils-dev python-libxml2 g++ xutils download_all_files() { # download files in parallel using keepalive - a little bit faster # than calling wget for a single file more than 100 times urls= for f in `cut -f1 -d: x11_file_list.txt`; do if ! test -s "downloads/$f"; then urls="$urls ${download_url}/$f" fi done if test -n "$urls"; then echo $urls | \ xargs -P2 -n $(expr $num_modules / 2 + 1) \ wget \ --directory-prefix=downloads \ --no-verbose \ --timestamping \ --continue fi status=$? return $status } remove_modules() { local mod_file mod_dir mod_args if [ -d cookies ]; then rm cookies/* fi if [ ! -d build_dir ]; then echo "" echo "build_dir does not exist; nothing to delete" echo "" exit 0 fi while IFS=: read mod_file mod_dir mod_args do (cd build_dir; [ -d $mod_dir ] && rm -rf $mod_dir) done < $data_file } extract_it() { local mod_file mod_name mod_args comp mod_file=$1 mod_name=$2 mod_args=$3 if [ -e cookies/$mod_name.extracted ]; then return 0 fi cd build_dir # if pkg has not yet been extracted, do so now if [ ! -d $mod_name ]; then case "$mod_file" in *.tar.bz2) comp=j ;; *.tar.gz) comp=z ;; *.tar.xz) comp=J ;; *.tar) comp= ;; *) echo "unknown compressed module $mod_name" ; exit 1 ;; esac if ! tar x${comp}f ../downloads/$mod_file > /dev/null then echo "error extracting module $mod_name" exit 1 fi fi # patch and configure module - we only need to do this once cd $mod_name # check for patches if [ -e ../../$mod_name.patch ]; then patch -N -p1 < ../../$mod_name.patch fi # now configure echo "executing ./configure --prefix=$PREFIX_DIR $mod_args" if ! ./configure --prefix=$PREFIX_DIR $mod_args then echo "configuration failed for module $mod_name" exit 1 fi cd ../.. touch cookies/$mod_name.extracted } make_it() { local mod_file mod_name mod_args mod_file=$1 mod_name=$2 mod_args=$3 count=`expr $count + 1` # if a cookie with $mod_name exists... if [ -e cookies/$mod_name.installed ]; then # ...package has already been installed return 0 fi echo "" echo "*** processing module $mod_name ($count of $num_modules) ***" echo "" if ! extract_it $mod_file $mod_name "$mod_args" then echo "" echo "extract failed for module $mod_name" echo "" exit 1 fi # make module if [ ! -e cookies/$mod_name.made ]; then if ! make -j $NPROC -C build_dir/$mod_name then echo "" echo "make failed for module $mod_name" echo "" exit 1 fi touch cookies/$mod_name.made fi # install module if ! make -C build_dir/$mod_name install then echo "" echo "make install failed for module $mod_name" echo "" exit 1 fi touch cookies/$mod_name.installed return 0 } # this is where we store list of modules to be processed data_file=x11_file_list.txt # this is the default download location for most modules # changed now to server1.xrdp.org # was www.x.org/releases/X11R7.6/src/everything download_url=http://server1.xrdp.org/xrdp/X11R7.6 num_modules=`wc -l < $data_file` count=0 ########################## # program flow starts here ########################## if [ $# -lt 1 ]; then echo "" echo "usage: buildx.sh " echo "usage: buildx.sh clean" echo "usage: buildx.sh default" echo "usage: buildx.sh drop - set env and run bash in rdp dir" echo "" exit 1 fi # remove all modules if [ "$1" = "clean" ]; then echo "removing source modules" remove_modules exit 0 fi if [ "$1" = "default" ]; then export PREFIX_DIR=$PWD/staging else export PREFIX_DIR=$1 fi # prefix dir must exist... if [ ! -d $PREFIX_DIR ]; then echo "$PREFIX_DIR does not exist, creating it" if ! mkdir -p $PREFIX_DIR; then echo "$PREFIX_DIR cannot be created - cannot continue" exit 1 fi fi # ...and be writable if [ ! -w $PREFIX_DIR ]; then echo "$PREFIX_DIR is not writable - cannot continue" exit 1 fi echo "installation directory: $PREFIX_DIR" export PKG_CONFIG_PATH=$PREFIX_DIR/lib/pkgconfig:$PREFIX_DIR/share/pkgconfig export PATH=$PREFIX_DIR/bin:$PATH export LDFLAGS=-Wl,-rpath=$PREFIX_DIR/lib export CFLAGS="-I$PREFIX_DIR/include -fPIC -O2" # create a downloads dir if [ ! -d downloads ]; then if ! mkdir downloads then echo "error creating downloads directory" exit 1 fi fi # this is where we do the actual build if [ ! -d build_dir ]; then if ! mkdir build_dir then echo "error creating build_dir directory" exit 1 fi fi # this is where we store cookie files if [ ! -d cookies ]; then if ! mkdir cookies then echo "error creating cookies directory" exit 1 fi fi if ! NPROC=`nproc`; then NPROC=1 fi if ! download_all_files; then echo "" echo "download failed - aborting build" echo "rerun this script to resume download/build" echo "" exit 1 fi while IFS=: read mod_file mod_dir mod_args do mod_args=`eval echo $mod_args` make_it $mod_file $mod_dir "$mod_args" done < $data_file echo "build for X OK" X11RDPBASE=$PREFIX_DIR export X11RDPBASE if ! make -C rdp then echo "error building rdp" exit 1 fi # this will copy the build X server with the other X server binaries cd rdp cp X11rdp $X11RDPBASE/bin/X11rdp strip $X11RDPBASE/bin/X11rdp if [ "$2" = "drop" ]; then echo "" echo "dropping you in dir, type exit to get out" bash exit 1 fi echo "All done" xrdp-0.9.5/xorg/X11R7.6/.gitignore000644 001751 001751 00000000034 13127114621 016312 0ustar00metameta000000 000000 build_dir cookies downloads xrdp-0.9.5/xorg/X11R7.6/xkeyboard-config-2.0.patch000644 001751 001751 00000006604 13127114621 021104 0ustar00metameta000000 000000 diff -rupP xkeyboard-config-2.0.orig/rules/HDR xkeyboard-config-2.0/rules/HDR --- xkeyboard-config-2.0.orig/rules/HDR 2016-06-28 19:31:02.814647638 +0900 +++ xkeyboard-config-2.0/rules/HDR 2016-06-28 19:33:58.251517616 +0900 @@ -15,6 +15,7 @@ ! model layout[3] variant[3] = symbols ! model layout[4] variant[4] = symbols ! model = symbols +! model layout = symbols ! layout variant = compat ! layout[1] variant[1] = compat ! layout[2] variant[2] = compat diff -rupP xkeyboard-config-2.0.orig/rules/Makefile.am xkeyboard-config-2.0/rules/Makefile.am --- xkeyboard-config-2.0.orig/rules/Makefile.am 2016-06-28 19:31:02.814647638 +0900 +++ xkeyboard-config-2.0/rules/Makefile.am 2016-06-28 20:58:22.276629031 +0900 @@ -41,6 +41,7 @@ HDR compat/base.ml2v2_s.part extras/bas HDR compat/base.ml3v3_s.part extras/base.ml3v3_s.part \ HDR compat/base.ml4v4_s.part extras/base.ml4v4_s.part \ HDR base.m_s.part \ +HDR base.ml_s1.part \ HDR compat/base.lv_c.part \ HDR compat/base.l1v1_c.part \ HDR compat/base.l2v2_c.part \ @@ -114,6 +115,7 @@ HDR extras/base.ml2v2_s.part \ HDR extras/base.ml3v3_s.part \ HDR extras/base.ml4v4_s.part \ HDR base.m_s.part \ +HDR base.ml_s1.part \ HDR \ HDR \ HDR \ @@ -183,6 +185,7 @@ base.ml2_s.part \ base.ml3_s.part \ base.ml4_s.part \ base.m_s.part \ +base.ml_s1.part \ base.ml_c.part \ base.ml1_c.part \ base.m_t.part \ diff -rupP xkeyboard-config-2.0.orig/rules/Makefile.in xkeyboard-config-2.0/rules/Makefile.in --- xkeyboard-config-2.0.orig/rules/Makefile.in 2016-06-28 19:31:02.850647811 +0900 +++ xkeyboard-config-2.0/rules/Makefile.in 2016-06-28 21:00:57.569398853 +0900 @@ -239,6 +239,7 @@ SUBDIRS = bin compat extras @USE_COMPAT_RULES_FALSE@HDR extras/base.ml3v3_s.part \ @USE_COMPAT_RULES_FALSE@HDR extras/base.ml4v4_s.part \ @USE_COMPAT_RULES_FALSE@HDR base.m_s.part \ +@USE_COMPAT_RULES_FALSE@HDR base.ml_s1.part \ @USE_COMPAT_RULES_FALSE@HDR \ @USE_COMPAT_RULES_FALSE@HDR \ @USE_COMPAT_RULES_FALSE@HDR \ @@ -275,6 +276,7 @@ SUBDIRS = bin compat extras @USE_COMPAT_RULES_TRUE@HDR compat/base.ml3v3_s.part extras/base.ml3v3_s.part \ @USE_COMPAT_RULES_TRUE@HDR compat/base.ml4v4_s.part extras/base.ml4v4_s.part \ @USE_COMPAT_RULES_TRUE@HDR base.m_s.part \ +@USE_COMPAT_RULES_TRUE@HDR base.ml_s1.part \ @USE_COMPAT_RULES_TRUE@HDR compat/base.lv_c.part \ @USE_COMPAT_RULES_TRUE@HDR compat/base.l1v1_c.part \ @USE_COMPAT_RULES_TRUE@HDR compat/base.l2v2_c.part \ @@ -378,6 +380,7 @@ base.ml2_s.part \ base.ml3_s.part \ base.ml4_s.part \ base.m_s.part \ +base.ml_s1.part \ base.ml_c.part \ base.ml1_c.part \ base.m_t.part \ diff -rupP xkeyboard-config-2.0.orig/rules/base.ml_s1.part xkeyboard-config-2.0/rules/base.ml_s1.part --- xkeyboard-config-2.0.orig/rules/base.ml_s1.part 1970-01-01 09:00:00.000000000 +0900 +++ xkeyboard-config-2.0/rules/base.ml_s1.part 2016-06-28 19:59:05.238990192 +0900 @@ -0,0 +1 @@ + $inetkbds jp = +jp(henkan) diff -rupP xkeyboard-config-2.0.orig/symbols/jp xkeyboard-config-2.0/symbols/jp --- xkeyboard-config-2.0.orig/symbols/jp 2016-06-28 19:31:03.046648788 +0900 +++ xkeyboard-config-2.0/symbols/jp 2016-06-28 19:32:57.367215702 +0900 @@ -105,6 +105,14 @@ xkb_symbols "common" { }; }; +partial alphanumeric_keys +xkb_symbols "henkan" { + key { + type[Group1]= "PC_ALT_LEVEL2", + symbols[Group1]= [ Henkan, Mode_switch ] + }; +}; + // OADG109A map partial alphanumeric_keys xkb_symbols "OADG109A" { xrdp-0.9.5/xorg/X11R7.6/libXext-1.2.0.patch000644 001751 001751 00000000553 13124203623 017422 0ustar00metameta000000 000000 diff --git a/src/Xge.c b/src/Xge.c index 7a583e5..2ea5d27 100644 --- a/src/Xge.c +++ b/src/Xge.c @@ -294,7 +294,7 @@ _xgeEventToWire(Display* dpy, XEvent* re, xEvent* event) /* * Extensions need to register callbacks for their events. */ -Bool +_X_HIDDEN Bool xgeExtRegister(Display* dpy, int offset, XExtensionHooks* callbacks) { XGEExtNode* newExt; xrdp-0.9.5/xorg/X11R7.6/libpciaccess-0.12.0.patch000644 001751 001751 00000001211 13133557325 020512 0ustar00metameta000000 000000 diff -ur a/src/common_interface.c b/src/common_interface.c --- a/src/common_interface.c +++ b/src/common_interface.c @@ -51,6 +51,20 @@ # define HTOLE_32(x) (x) #endif /* linux */ +#elif defined(__GNUC__) || defined(__clang__) + +#if __BYTE_ORDER == __BIG_ENDIAN +# define LETOH_16(x) __builtin_bswap16(x) +# define HTOLE_16(x) __builtin_bswap16(x) +# define LETOH_32(x) __builtin_bswap32(x) +# define HTOLE_32(x) __builtin_bswap32(x) +#else +# define LETOH_16(x) (x) +# define HTOLE_16(x) (x) +# define LETOH_32(x) (x) +# define HTOLE_32(x) (x) +#endif /* gcc or clang */ + #elif defined(__sun) #include xrdp-0.9.5/xorg/X11R7.6/cleanx.sh000755 001751 001751 00000003204 13125122134 016131 0ustar00metameta000000 000000 #!/bin/sh # # all directories can be read only except # Read Write # share/X11/xkb/compiled/ if test $# -lt 1 then echo "" echo "usage: clean_build_dir.sh " echo "" exit 1 fi BASEDIR=$1 if ! test -d $BASEDIR then echo "error directory $BASEDIR does not exist" exit 1 fi if ! test -w $BASEDIR then echo "error directory $BASEDIR is not writable" exit 1 fi echo cleaning $BASEDIR if ! test -x $BASEDIR/bin/X11rdp then echo "error $BASEDIR/bin/X11rdp does not exist" fi bin_check_file() { if [ "$1" = "X11rdp" ] then return 0 fi if [ "$1" = "xkbcomp" ] then return 0 fi rm -f $1 return 0 } HOLDPATH=$PWD cd $BASEDIR # remove unused directories rm -fr man/ rm -fr include/ rm -fr lib/python2.7/ rm -fr lib/pkgconfig/ rm -fr share/pkgconfig/ rm -fr share/gtk-doc rm -fr share/doc rm -fr share/man rm -fr share/aclocal rm -fr share/intltool rm -fr share/util-macros # remove development files rm -f lib/*.a rm -f lib/*.la rm -f lib/xorg/modules/*.a rm -f lib/xorg/modules/*.la # remove symbols #strip lib/*.so #strip lib/xorg/modules/*.so # remove hardware specific files rm -f lib/dri/i915_dri.so rm -f lib/dri/i965_dri.so rm -f lib/dri/mach64_dri.so rm -f lib/dri/mga_dri.so rm -f lib/dri/r128_dri.so rm -f lib/dri/r200_dri.so rm -f lib/dri/r300_dri.so rm -f lib/dri/r600_dri.so rm -f lib/dri/radeon_dri.so rm -f lib/dri/savage_dri.so #strip lib/dri/swrast_dri.so rm -f lib/dri/tdfx_dri.so rm -f lib/dri/unichrome_dri.so # remove extra bin tools cd bin for i in * do if ! test -d "$i" then bin_check_file $i fi done cd .. cd $HOLDPATH xrdp-0.9.5/xorg/X11R7.6/x11_file_list.txt000644 001751 001751 00000026136 13133557325 017552 0ustar00metameta000000 000000 util-macros-1.11.0.tar.bz2 : util-macros-1.11.0 : xf86driproto-2.1.0.tar.bz2 : xf86driproto-2.1.0 : dri2proto-2.3.tar.bz2 : dri2proto-2.3 : glproto-1.4.12.tar.bz2 : glproto-1.4.12 : libpciaccess-0.12.0.tar.bz2 : libpciaccess-0.12.0 : libpthread-stubs-0.3.tar.bz2 : libpthread-stubs-0.3 : libdrm-2.4.26.tar.bz2 : libdrm-2.4.26 : damageproto-1.2.1.tar.bz2 : damageproto-1.2.1 : xproto-7.0.20.tar.bz2 : xproto-7.0.20 : makedepend-1.0.3.tar.bz2 : makedepend-1.0.3 : libxml2-sources-2.7.8.tar.gz : libxml2-2.7.8 : libpng-1.2.46.tar.gz : libpng-1.2.46 : pixman-0.30.0.tar.bz2 : pixman-0.30.0 : --disable-gtk freetype-2.4.6.tar.bz2 : freetype-2.4.6 : fontconfig-2.8.0.tar.gz : fontconfig-2.8.0 : --disable-docs cairo-1.8.8.tar.gz : cairo-1.8.8 : expat-2.0.1.tar.gz : expat-2.0.1 : xextproto-7.1.2.tar.bz2 : xextproto-7.1.2 : xcb-proto-1.6.tar.bz2 : xcb-proto-1.6 : libXau-1.0.6.tar.bz2 : libXau-1.0.6 : libXdmcp-1.1.0.tar.bz2 : libXdmcp-1.1.0 : libxcb-1.7.tar.bz2 : libxcb-1.7 : xtrans-1.2.6.tar.bz2 : xtrans-1.2.6 : kbproto-1.0.5.tar.bz2 : kbproto-1.0.5 : inputproto-2.0.1.tar.bz2 : inputproto-2.0.1 : libX11-1.4.0.tar.bz2 : libX11-1.4.0 : libXext-1.2.0.tar.bz2 : libXext-1.2.0 : libICE-1.0.7.tar.bz2 : libICE-1.0.7 : libSM-1.2.0.tar.bz2 : libSM-1.2.0 : libXt-1.0.9.tar.bz2 : libXt-1.0.9 : fixesproto-4.1.2.tar.bz2 : fixesproto-4.1.2 : libXfixes-4.0.5.tar.bz2 : libXfixes-4.0.5 : libXdamage-1.1.3.tar.bz2 : libXdamage-1.1.3 : MesaLib-7.10.3.tar.bz2 : Mesa-7.10.3 : --with-expat=$PREFIX_DIR --disable-gallium randrproto-1.3.2.tar.bz2 : randrproto-1.3.2 : renderproto-0.11.1.tar.bz2 : renderproto-0.11.1 : xcmiscproto-1.2.1.tar.bz2 : xcmiscproto-1.2.1 : xf86vidmodeproto-2.3.tar.bz2 : xf86vidmodeproto-2.3 : xf86bigfontproto-1.2.0.tar.bz2 : xf86bigfontproto-1.2.0 : scrnsaverproto-1.2.1.tar.bz2 : scrnsaverproto-1.2.1 : bigreqsproto-1.1.1.tar.bz2 : bigreqsproto-1.1.1 : resourceproto-1.1.1.tar.bz2 : resourceproto-1.1.1 : fontsproto-2.1.1.tar.bz2 : fontsproto-2.1.1 : xf86dgaproto-2.1.tar.bz2 : xf86dgaproto-2.1 : videoproto-2.3.1.tar.bz2 : videoproto-2.3.1 : compositeproto-0.4.2.tar.bz2 : compositeproto-0.4.2 : recordproto-1.14.1.tar.bz2 : recordproto-1.14.1 : xineramaproto-1.2.tar.bz2 : xineramaproto-1.2 : libxslt-1.1.26.tar.gz : libxslt-1.1.26 : libxkbfile-1.0.7.tar.bz2 : libxkbfile-1.0.7 : libfontenc-1.1.0.tar.bz2 : libfontenc-1.1.0 : libXfont-1.4.3.tar.bz2 : libXfont-1.4.3 : libXmu-1.1.0.tar.bz2 : libXmu-1.1.0 : libXxf86vm-1.1.1.tar.bz2 : libXxf86vm-1.1.1 : libXpm-3.5.9.tar.bz2 : libXpm-3.5.9 : libXaw-1.0.8.tar.bz2 : libXaw-1.0.8 : mkfontdir-1.0.6.tar.bz2 : mkfontdir-1.0.6 : mkfontscale-1.0.8.tar.bz2 : mkfontscale-1.0.8 : xkbcomp-1.2.0.tar.bz2 : xkbcomp-1.2.0 : xdriinfo-1.0.4.tar.bz2 : xdriinfo-1.0.4 : applewmproto-1.4.1.tar.bz2 : applewmproto-1.4.1 : xorg-server-1.9.3.tar.bz2 : xorg-server-1.9.3 : --with-fontrootdir=$PREFIX_DIR/share/fonts/X11 --with-sha1=libcrypto --disable-dmx --without-dtrace bdftopcf-1.0.3.tar.bz2 : bdftopcf-1.0.3 : intltool-0.41.1.tar.gz : intltool-0.41.1 : xkeyboard-config-2.0.tar.bz2 : xkeyboard-config-2.0 : font-util-1.2.0.tar.bz2 : font-util-1.2.0 : --with-fontrootdir=$PREFIX_DIR/share/fonts/X11 font-adobe-75dpi-1.0.3.tar.bz2 : font-adobe-75dpi-1.0.3 : --with-fontrootdir=$PREFIX_DIR/share/fonts/X11 font-adobe-100dpi-1.0.3.tar.bz2 : font-adobe-100dpi-1.0.3 : --with-fontrootdir=$PREFIX_DIR/share/fonts/X11 font-adobe-utopia-75dpi-1.0.4.tar.bz2 : font-adobe-utopia-75dpi-1.0.4 : --with-fontrootdir=$PREFIX_DIR/share/fonts/X11 font-adobe-utopia-100dpi-1.0.4.tar.bz2 : font-adobe-utopia-100dpi-1.0.4 : --with-fontrootdir=$PREFIX_DIR/share/fonts/X11 font-adobe-utopia-type1-1.0.4.tar.bz2 : font-adobe-utopia-type1-1.0.4 : --with-fontrootdir=$PREFIX_DIR/share/fonts/X11 font-alias-1.0.3.tar.bz2 : font-alias-1.0.3 : --with-fontrootdir=$PREFIX_DIR/share/fonts/X11 font-arabic-misc-1.0.3.tar.bz2 : font-arabic-misc-1.0.3 : --with-fontrootdir=$PREFIX_DIR/share/fonts/X11 font-bh-75dpi-1.0.3.tar.bz2 : font-bh-75dpi-1.0.3 : --with-fontrootdir=$PREFIX_DIR/share/fonts/X11 font-bh-100dpi-1.0.3.tar.bz2 : font-bh-100dpi-1.0.3 : --with-fontrootdir=$PREFIX_DIR/share/fonts/X11 font-bh-lucidatypewriter-75dpi-1.0.3.tar.bz2 : font-bh-lucidatypewriter-75dpi-1.0.3 : --with-fontrootdir=$PREFIX_DIR/share/fonts/X11 font-bh-lucidatypewriter-100dpi-1.0.3.tar.bz2 : font-bh-lucidatypewriter-100dpi-1.0.3 : --with-fontrootdir=$PREFIX_DIR/share/fonts/X11 font-bh-ttf-1.0.3.tar.bz2 : font-bh-ttf-1.0.3 : --with-fontrootdir=$PREFIX_DIR/share/fonts/X11 font-bh-type1-1.0.3.tar.bz2 : font-bh-type1-1.0.3 : --with-fontrootdir=$PREFIX_DIR/share/fonts/X11 font-bitstream-75dpi-1.0.3.tar.bz2 : font-bitstream-75dpi-1.0.3 : --with-fontrootdir=$PREFIX_DIR/share/fonts/X11 font-bitstream-100dpi-1.0.3.tar.bz2 : font-bitstream-100dpi-1.0.3 : --with-fontrootdir=$PREFIX_DIR/share/fonts/X11 font-bitstream-type1-1.0.3.tar.bz2 : font-bitstream-type1-1.0.3 : --with-fontrootdir=$PREFIX_DIR/share/fonts/X11 font-cronyx-cyrillic-1.0.3.tar.bz2 : font-cronyx-cyrillic-1.0.3 : --with-fontrootdir=$PREFIX_DIR/share/fonts/X11 font-cursor-misc-1.0.3.tar.bz2 : font-cursor-misc-1.0.3 : --with-fontrootdir=$PREFIX_DIR/share/fonts/X11 font-daewoo-misc-1.0.3.tar.bz2 : font-daewoo-misc-1.0.3 : --with-fontrootdir=$PREFIX_DIR/share/fonts/X11 font-dec-misc-1.0.3.tar.bz2 : font-dec-misc-1.0.3 : --with-fontrootdir=$PREFIX_DIR/share/fonts/X11 font-ibm-type1-1.0.3.tar.bz2 : font-ibm-type1-1.0.3 : --with-fontrootdir=$PREFIX_DIR/share/fonts/X11 font-isas-misc-1.0.3.tar.bz2 : font-isas-misc-1.0.3 : --with-fontrootdir=$PREFIX_DIR/share/fonts/X11 font-jis-misc-1.0.3.tar.bz2 : font-jis-misc-1.0.3 : --with-fontrootdir=$PREFIX_DIR/share/fonts/X11 font-micro-misc-1.0.3.tar.bz2 : font-micro-misc-1.0.3 : --with-fontrootdir=$PREFIX_DIR/share/fonts/X11 font-misc-cyrillic-1.0.3.tar.bz2 : font-misc-cyrillic-1.0.3 : --with-fontrootdir=$PREFIX_DIR/share/fonts/X11 font-misc-ethiopic-1.0.3.tar.bz2 : font-misc-ethiopic-1.0.3 : --with-fontrootdir=$PREFIX_DIR/share/fonts/X11 font-misc-meltho-1.0.3.tar.bz2 : font-misc-meltho-1.0.3 : --with-fontrootdir=$PREFIX_DIR/share/fonts/X11 font-misc-misc-1.1.2.tar.bz2 : font-misc-misc-1.1.2 : --with-fontrootdir=$PREFIX_DIR/share/fonts/X11 font-mutt-misc-1.0.3.tar.bz2 : font-mutt-misc-1.0.3 : --with-fontrootdir=$PREFIX_DIR/share/fonts/X11 font-schumacher-misc-1.1.2.tar.bz2 : font-schumacher-misc-1.1.2 : --with-fontrootdir=$PREFIX_DIR/share/fonts/X11 font-screen-cyrillic-1.0.4.tar.bz2 : font-screen-cyrillic-1.0.4 : --with-fontrootdir=$PREFIX_DIR/share/fonts/X11 font-sony-misc-1.0.3.tar.bz2 : font-sony-misc-1.0.3 : --with-fontrootdir=$PREFIX_DIR/share/fonts/X11 font-sun-misc-1.0.3.tar.bz2 : font-sun-misc-1.0.3 : --with-fontrootdir=$PREFIX_DIR/share/fonts/X11 font-winitzki-cyrillic-1.0.3.tar.bz2 : font-winitzki-cyrillic-1.0.3 : --with-fontrootdir=$PREFIX_DIR/share/fonts/X11 font-xfree86-type1-1.0.4.tar.bz2 : font-xfree86-type1-1.0.4 : --with-fontrootdir=$PREFIX_DIR/share/fonts/X11 xrdp-0.9.5/xorg/X11R7.6/xorg-server-1.9.3.patch000644 001751 001751 00000000410 13133557325 020303 0ustar00metameta000000 000000 --- a/configure +++ b/configure @@ -21551,6 +21551,7 @@ if test "x$with_sha1" = xlibcrypto; then if test "x$HAVE_LIBCRYPTO" = xyes; then SHA1_LIBS=-lcrypto + SHA1_CFLAGS="$OPENSSL_CFLAGS" else SHA1_LIBS="$OPENSSL_LIBS" SHA1_CFLAGS="$OPENSSL_CFLAGS" xrdp-0.9.5/xorg/X11R7.6/Mesa-7.10.3.patch000644 001751 001751 00000000336 13133557325 016772 0ustar00metameta000000 000000 --- a/src/mesa/x86-64/xform4.S +++ b/src/mesa/x86-64/xform4.S @@ -118,7 +118,7 @@ .byte 0x00, 0x00, 0x00, 0x00 .byte 0x00, 0x00, 0x00, 0x00 .byte 0x00, 0x00, 0x00, 0x00 -.float 0f+1.0 +.float 1.0 .text .align 16 xrdp-0.9.5/xorg/X11R7.6/rdp/rdpmisc.c000644 001751 001751 00000041712 13174271344 016734 0ustar00metameta000000 000000 /* Copyright 2005-2013 Jay Sorg Permission to use, copy, modify, distribute, and sell this software and its documentation for any purpose is hereby granted without fee, provided that the above copyright notice appear in all copies and that both that copyright notice and this permission notice appear in supporting documentation. The above copyright notice and this permission notice shall be included in all copies or substantial portions of the Software. THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE OPEN GROUP BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. the rest */ #include "rdp.h" #include Bool noFontCacheExtension = 1; static int g_crc_seed = 0xffffffff; static int g_crc_table[256] = { 0x00000000, 0x77073096, 0xee0e612c, 0x990951ba, 0x076dc419, 0x706af48f, 0xe963a535, 0x9e6495a3, 0x0edb8832, 0x79dcb8a4, 0xe0d5e91e, 0x97d2d988, 0x09b64c2b, 0x7eb17cbd, 0xe7b82d07, 0x90bf1d91, 0x1db71064, 0x6ab020f2, 0xf3b97148, 0x84be41de, 0x1adad47d, 0x6ddde4eb, 0xf4d4b551, 0x83d385c7, 0x136c9856, 0x646ba8c0, 0xfd62f97a, 0x8a65c9ec, 0x14015c4f, 0x63066cd9, 0xfa0f3d63, 0x8d080df5, 0x3b6e20c8, 0x4c69105e, 0xd56041e4, 0xa2677172, 0x3c03e4d1, 0x4b04d447, 0xd20d85fd, 0xa50ab56b, 0x35b5a8fa, 0x42b2986c, 0xdbbbc9d6, 0xacbcf940, 0x32d86ce3, 0x45df5c75, 0xdcd60dcf, 0xabd13d59, 0x26d930ac, 0x51de003a, 0xc8d75180, 0xbfd06116, 0x21b4f4b5, 0x56b3c423, 0xcfba9599, 0xb8bda50f, 0x2802b89e, 0x5f058808, 0xc60cd9b2, 0xb10be924, 0x2f6f7c87, 0x58684c11, 0xc1611dab, 0xb6662d3d, 0x76dc4190, 0x01db7106, 0x98d220bc, 0xefd5102a, 0x71b18589, 0x06b6b51f, 0x9fbfe4a5, 0xe8b8d433, 0x7807c9a2, 0x0f00f934, 0x9609a88e, 0xe10e9818, 0x7f6a0dbb, 0x086d3d2d, 0x91646c97, 0xe6635c01, 0x6b6b51f4, 0x1c6c6162, 0x856530d8, 0xf262004e, 0x6c0695ed, 0x1b01a57b, 0x8208f4c1, 0xf50fc457, 0x65b0d9c6, 0x12b7e950, 0x8bbeb8ea, 0xfcb9887c, 0x62dd1ddf, 0x15da2d49, 0x8cd37cf3, 0xfbd44c65, 0x4db26158, 0x3ab551ce, 0xa3bc0074, 0xd4bb30e2, 0x4adfa541, 0x3dd895d7, 0xa4d1c46d, 0xd3d6f4fb, 0x4369e96a, 0x346ed9fc, 0xad678846, 0xda60b8d0, 0x44042d73, 0x33031de5, 0xaa0a4c5f, 0xdd0d7cc9, 0x5005713c, 0x270241aa, 0xbe0b1010, 0xc90c2086, 0x5768b525, 0x206f85b3, 0xb966d409, 0xce61e49f, 0x5edef90e, 0x29d9c998, 0xb0d09822, 0xc7d7a8b4, 0x59b33d17, 0x2eb40d81, 0xb7bd5c3b, 0xc0ba6cad, 0xedb88320, 0x9abfb3b6, 0x03b6e20c, 0x74b1d29a, 0xead54739, 0x9dd277af, 0x04db2615, 0x73dc1683, 0xe3630b12, 0x94643b84, 0x0d6d6a3e, 0x7a6a5aa8, 0xe40ecf0b, 0x9309ff9d, 0x0a00ae27, 0x7d079eb1, 0xf00f9344, 0x8708a3d2, 0x1e01f268, 0x6906c2fe, 0xf762575d, 0x806567cb, 0x196c3671, 0x6e6b06e7, 0xfed41b76, 0x89d32be0, 0x10da7a5a, 0x67dd4acc, 0xf9b9df6f, 0x8ebeeff9, 0x17b7be43, 0x60b08ed5, 0xd6d6a3e8, 0xa1d1937e, 0x38d8c2c4, 0x4fdff252, 0xd1bb67f1, 0xa6bc5767, 0x3fb506dd, 0x48b2364b, 0xd80d2bda, 0xaf0a1b4c, 0x36034af6, 0x41047a60, 0xdf60efc3, 0xa867df55, 0x316e8eef, 0x4669be79, 0xcb61b38c, 0xbc66831a, 0x256fd2a0, 0x5268e236, 0xcc0c7795, 0xbb0b4703, 0x220216b9, 0x5505262f, 0xc5ba3bbe, 0xb2bd0b28, 0x2bb45a92, 0x5cb36a04, 0xc2d7ffa7, 0xb5d0cf31, 0x2cd99e8b, 0x5bdeae1d, 0x9b64c2b0, 0xec63f226, 0x756aa39c, 0x026d930a, 0x9c0906a9, 0xeb0e363f, 0x72076785, 0x05005713, 0x95bf4a82, 0xe2b87a14, 0x7bb12bae, 0x0cb61b38, 0x92d28e9b, 0xe5d5be0d, 0x7cdcefb7, 0x0bdbdf21, 0x86d3d2d4, 0xf1d4e242, 0x68ddb3f8, 0x1fda836e, 0x81be16cd, 0xf6b9265b, 0x6fb077e1, 0x18b74777, 0x88085ae6, 0xff0f6a70, 0x66063bca, 0x11010b5c, 0x8f659eff, 0xf862ae69, 0x616bffd3, 0x166ccf45, 0xa00ae278, 0xd70dd2ee, 0x4e048354, 0x3903b3c2, 0xa7672661, 0xd06016f7, 0x4969474d, 0x3e6e77db, 0xaed16a4a, 0xd9d65adc, 0x40df0b66, 0x37d83bf0, 0xa9bcae53, 0xdebb9ec5, 0x47b2cf7f, 0x30b5ffe9, 0xbdbdf21c, 0xcabac28a, 0x53b39330, 0x24b4a3a6, 0xbad03605, 0xcdd70693, 0x54de5729, 0x23d967bf, 0xb3667a2e, 0xc4614ab8, 0x5d681b02, 0x2a6f2b94, 0xb40bbe37, 0xc30c8ea1, 0x5a05df1b, 0x2d02ef8d }; #define CRC_START(in_crc) (in_crc) = g_crc_seed #define CRC_PASS(in_pixel, in_crc) \ (in_crc) = g_crc_table[((in_crc) ^ (in_pixel)) & 0xff] ^ ((in_crc) >> 8) #define CRC_END(in_crc) (in_crc) = ((in_crc) ^ g_crc_seed) /******************************************************************************/ /* print a time-stamped message to the log file (stderr). */ void rdpLog(char *format, ...) { va_list args; char buf[256]; time_t clock; va_start(args, format); time(&clock); strftime(buf, 255, "%d/%m/%y %T ", localtime(&clock)); fprintf(stderr, "%s", buf); vfprintf(stderr, format, args); fflush(stderr); va_end(args); } /******************************************************************************/ int rdpBitsPerPixel(int depth) { if (depth == 1) { return 1; } else if (depth <= 8) { return 8; } else if (depth <= 16) { return 16; } else { return 32; } } /******************************************************************************/ void rdpClientStateChange(CallbackListPtr *cbl, pointer myData, pointer clt) { dispatchException &= ~DE_RESET; /* hack - force server not to reset */ } /******************************************************************************/ int DPMSSupported(void) { return 0; } /******************************************************************************/ int DPSMGet(int *level) { return -1; } /******************************************************************************/ void DPMSSet(int level) { } /******************************************************************************/ void AddOtherInputDevices(void) { } /******************************************************************************/ void OpenInputDevice(DeviceIntPtr dev, ClientPtr client, int *status) { } /******************************************************************************/ int SetDeviceValuators(register ClientPtr client, DeviceIntPtr dev, int *valuators, int first_valuator, int num_valuators) { return BadMatch; } /******************************************************************************/ int SetDeviceMode(register ClientPtr client, DeviceIntPtr dev, int mode) { return BadMatch; } /******************************************************************************/ int ChangeKeyboardDevice(DeviceIntPtr old_dev, DeviceIntPtr new_dev) { return BadMatch; } /******************************************************************************/ int ChangeDeviceControl(register ClientPtr client, DeviceIntPtr dev, void *control) { return BadMatch; } /******************************************************************************/ int ChangePointerDevice(DeviceIntPtr old_dev, DeviceIntPtr new_dev, unsigned char x, unsigned char y) { return BadMatch; } /******************************************************************************/ void CloseInputDevice(DeviceIntPtr d, ClientPtr client) { } /* the g_ functions from os_calls.c */ /*****************************************************************************/ int g_tcp_recv(int sck, void *ptr, int len, int flags) { return recv(sck, ptr, len, flags); } /*****************************************************************************/ void g_tcp_close(int sck) { if (sck == 0) { return; } shutdown(sck, 2); close(sck); } /*****************************************************************************/ int g_tcp_last_error_would_block(int sck) { return (errno == EWOULDBLOCK) || (errno == EINPROGRESS); } /*****************************************************************************/ void g_sleep(int msecs) { usleep(msecs * 1000); } /*****************************************************************************/ int g_tcp_send(int sck, void *ptr, int len, int flags) { return send(sck, ptr, len, flags); } /*****************************************************************************/ void * g_malloc(int size, int zero) { char *rv; //#ifdef _XSERVER64 #if 1 /* I thought xalloc would work here but I guess not, why, todo */ rv = (char *)malloc(size); #else rv = (char *)Xalloc(size); #endif if (zero) { if (rv != 0) { memset(rv, 0, size); } } return rv; } /*****************************************************************************/ void g_free(void *ptr) { if (ptr != 0) { //#ifdef _XSERVER64 #if 1 /* I thought xfree would work here but I guess not, why, todo */ free(ptr); #else Xfree(ptr); #endif } } /*****************************************************************************/ void g_sprintf(char *dest, char *format, ...) { va_list ap; va_start(ap, format); vsprintf(dest, format, ap); va_end(ap); } /*****************************************************************************/ int g_tcp_socket(void) { int rv; int i; i = 1; rv = socket(PF_INET, SOCK_STREAM, 0); setsockopt(rv, IPPROTO_TCP, TCP_NODELAY, (void *)&i, sizeof(i)); setsockopt(rv, SOL_SOCKET, SO_REUSEADDR, (void *)&i, sizeof(i)); return rv; } /*****************************************************************************/ int g_tcp_local_socket_dgram(void) { return socket(AF_UNIX, SOCK_DGRAM, 0); } /*****************************************************************************/ int g_tcp_local_socket_stream(void) { return socket(AF_UNIX, SOCK_STREAM, 0); } /*****************************************************************************/ void g_memcpy(void *d_ptr, const void *s_ptr, int size) { memcpy(d_ptr, s_ptr, size); } /*****************************************************************************/ int g_tcp_set_no_delay(int sck) { int i; i = 1; setsockopt(sck, IPPROTO_TCP, TCP_NODELAY, (void *)&i, sizeof(i)); return 0; } /*****************************************************************************/ int g_tcp_set_non_blocking(int sck) { unsigned long i; i = fcntl(sck, F_GETFL); i = i | O_NONBLOCK; fcntl(sck, F_SETFL, i); return 0; } /*****************************************************************************/ int g_tcp_accept(int sck) { struct sockaddr_in s; unsigned int i; i = sizeof(struct sockaddr_in); memset(&s, 0, i); return accept(sck, (struct sockaddr *)&s, &i); } /*****************************************************************************/ int g_tcp_select(int sck1, int sck2, int sck3) { fd_set rfds; struct timeval time; int max; int rv; time.tv_sec = 0; time.tv_usec = 0; FD_ZERO(&rfds); if (sck1 > 0) { FD_SET(((unsigned int)sck1), &rfds); } if (sck2 > 0) { FD_SET(((unsigned int)sck2), &rfds); } if (sck3 > 0) { FD_SET(((unsigned int)sck3), &rfds); } max = sck1; if (sck2 > max) { max = sck2; } if (sck3 > max) { max = sck3; } rv = select(max + 1, &rfds, 0, 0, &time); if (rv > 0) { rv = 0; if (FD_ISSET(((unsigned int)sck1), &rfds)) { rv = rv | 1; } if (FD_ISSET(((unsigned int)sck2), &rfds)) { rv = rv | 2; } if (FD_ISSET(((unsigned int)sck3), &rfds)) { rv = rv | 4; } } else { rv = 0; } return rv; } /*****************************************************************************/ int g_tcp_bind(int sck, char *port) { struct sockaddr_in s; memset(&s, 0, sizeof(struct sockaddr_in)); s.sin_family = AF_INET; s.sin_port = htons(atoi(port)); s.sin_addr.s_addr = INADDR_ANY; return bind(sck, (struct sockaddr *)&s, sizeof(struct sockaddr_in)); } /*****************************************************************************/ int g_tcp_local_bind(int sck, char *port) { struct sockaddr_un s; memset(&s, 0, sizeof(struct sockaddr_un)); s.sun_family = AF_UNIX; strcpy(s.sun_path, port); return bind(sck, (struct sockaddr *)&s, sizeof(struct sockaddr_un)); } /*****************************************************************************/ int g_tcp_listen(int sck) { return listen(sck, 2); } /*****************************************************************************/ /* returns boolean */ int g_create_dir(const char *dirname) { return mkdir(dirname, (mode_t) - 1) == 0; } /*****************************************************************************/ /* returns boolean, non zero if the directory exists */ int g_directory_exist(const char *dirname) { struct stat st; if (stat(dirname, &st) == 0) { return S_ISDIR(st.st_mode); } else { return 0; } } /*****************************************************************************/ /* returns error */ int g_chmod_hex(const char *filename, int flags) { int fl; fl = 0; fl |= (flags & 0x4000) ? S_ISUID : 0; fl |= (flags & 0x2000) ? S_ISGID : 0; fl |= (flags & 0x1000) ? S_ISVTX : 0; fl |= (flags & 0x0400) ? S_IRUSR : 0; fl |= (flags & 0x0200) ? S_IWUSR : 0; fl |= (flags & 0x0100) ? S_IXUSR : 0; fl |= (flags & 0x0040) ? S_IRGRP : 0; fl |= (flags & 0x0020) ? S_IWGRP : 0; fl |= (flags & 0x0010) ? S_IXGRP : 0; fl |= (flags & 0x0004) ? S_IROTH : 0; fl |= (flags & 0x0002) ? S_IWOTH : 0; fl |= (flags & 0x0001) ? S_IXOTH : 0; return chmod(filename, fl); } /*****************************************************************************/ /* returns directory where UNIX sockets are located */ const char * g_socket_dir(void) { const char *socket_dir; socket_dir = getenv("XRDP_SOCKET_PATH"); if (socket_dir == NULL || socket_dir[0] == '\0') { socket_dir = "/tmp/.xrdp"; } return socket_dir; } /* produce a hex dump */ void hexdump(unsigned char *p, unsigned int len) { unsigned char *line; int i; int thisline; int offset; offset = 0; line = p; while (offset < len) { ErrorF("%04x ", offset); thisline = len - offset; if (thisline > 16) { thisline = 16; } for (i = 0; i < thisline; i++) { ErrorF("%02x ", line[i]); } for (; i < 16; i++) { ErrorF(" "); } for (i = 0; i < thisline; i++) { ErrorF("%c", (line[i] >= 0x20 && line[i] < 0x7f) ? line[i] : '.'); } ErrorF("\n"); offset += thisline; line += thisline; } } /* stub for XpClient* functions. */ /*****************************************************************************/ Bool XpClientIsBitmapClient(ClientPtr client) { return 1; } /*****************************************************************************/ Bool XpClientIsPrintClient(ClientPtr client, FontPathElementPtr fpe) { return 0; } /*****************************************************************************/ int PrinterOptions(int argc, char **argv, int i) { return i; } /*****************************************************************************/ void PrinterInitOutput(ScreenInfo *pScreenInfo, int argc, char **argv) { } /*****************************************************************************/ void PrinterUseMsg(void) { } /*****************************************************************************/ void PrinterInitGlobals(void) { } /*****************************************************************************/ void FontCacheExtensionInit(INITARGS) { } /******************************************************************************/ void RegionAroundSegs(RegionPtr reg, xSegment *segs, int nseg) { int index; BoxRec box; RegionRec treg; index = 0; while (index < nseg) { if (segs[index].x1 < segs[index].x2) { box.x1 = segs[index].x1; box.x2 = segs[index].x2; } else { box.x1 = segs[index].x2; box.x2 = segs[index].x1; } box.x2++; if (segs[index].y1 < segs[index].y2) { box.y1 = segs[index].y1; box.y2 = segs[index].y2; } else { box.y1 = segs[index].y2; box.y2 = segs[index].y1; } box.y2++; RegionInit(&treg, &box, 0); RegionUnion(reg, reg, &treg); RegionUninit(&treg); index++; } } /******************************************************************************/ int get_crc(char* data, int data_bytes) { int crc; int index; CRC_START(crc); for (index = 0; index < data_bytes; index++) { CRC_PASS(data[index], crc); } CRC_END(crc); return crc; } /*****************************************************************************/ int get_mstime(void) { struct timeval tp; gettimeofday(&tp, 0); return (tp.tv_sec * 1000) + (tp.tv_usec / 1000); } xrdp-0.9.5/xorg/X11R7.6/rdp/rdpCopyPlane.c000644 001751 001751 00000016032 13125122134 017654 0ustar00metameta000000 000000 /* Copyright 2005-2013 Jay Sorg Permission to use, copy, modify, distribute, and sell this software and its documentation for any purpose is hereby granted without fee, provided that the above copyright notice appear in all copies and that both that copyright notice and this permission notice appear in supporting documentation. The above copyright notice and this permission notice shall be included in all copies or substantial portions of the Software. THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE OPEN GROUP BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. */ #include "rdp.h" #include "rdpdraw.h" #define LDEBUG 0 #define LOG_LEVEL 1 #define LLOG(_level, _args) \ do { if (_level < LOG_LEVEL) { ErrorF _args ; } } while (0) #define LLOGLN(_level, _args) \ do { if (_level < LOG_LEVEL) { ErrorF _args ; ErrorF("\n"); } } while (0) extern rdpScreenInfoRec g_rdpScreen; /* from rdpmain.c */ extern DevPrivateKeyRec g_rdpGCIndex; /* from rdpmain.c */ extern DevPrivateKeyRec g_rdpWindowIndex; /* from rdpmain.c */ extern DevPrivateKeyRec g_rdpPixmapIndex; /* from rdpmain.c */ extern int g_Bpp; /* from rdpmain.c */ extern ScreenPtr g_pScreen; /* from rdpmain.c */ extern Bool g_wrapPixmap; /* from rdpmain.c */ extern int g_do_dirty_os; /* in rdpmain.c */ extern int g_do_dirty_ons; /* in rdpmain.c */ extern rdpPixmapRec g_screenPriv; /* in rdpmain.c */ extern GCOps g_rdpGCOps; /* from rdpdraw.c */ extern int g_con_number; /* in rdpup.c */ /******************************************************************************/ RegionPtr rdpCopyPlaneOrg(DrawablePtr pSrc, DrawablePtr pDst, GCPtr pGC, int srcx, int srcy, int w, int h, int dstx, int dsty, unsigned long bitPlane) { RegionPtr rv; rdpGCPtr priv; GCFuncs *oldFuncs; GC_OP_PROLOGUE(pGC); rv = pGC->ops->CopyPlane(pSrc, pDst, pGC, srcx, srcy, w, h, dstx, dsty, bitPlane); GC_OP_EPILOGUE(pGC); return rv; } /******************************************************************************/ RegionPtr rdpCopyPlane(DrawablePtr pSrc, DrawablePtr pDst, GCPtr pGC, int srcx, int srcy, int w, int h, int dstx, int dsty, unsigned long bitPlane) { RegionPtr rv; RegionRec clip_reg; RegionRec box_reg; RegionRec reg1; RegionRec reg2; int cd; int num_clips; int j; int got_id; int dirty_type; int post_process; int reset_surface; BoxRec box; BoxPtr pbox; struct image_data id; WindowPtr pDstWnd; PixmapPtr pDstPixmap; rdpPixmapRec *pDstPriv; rdpPixmapRec *pDirtyPriv; LLOGLN(10, ("rdpCopyPlane:")); /* do original call */ rv = rdpCopyPlaneOrg(pSrc, pDst, pGC, srcx, srcy, w, h, dstx, dsty, bitPlane); dirty_type = 0; pDirtyPriv = 0; post_process = 0; reset_surface = 0; got_id = 0; if (pDst->type == DRAWABLE_PIXMAP) { pDstPixmap = (PixmapPtr)pDst; pDstPriv = GETPIXPRIV(pDstPixmap); if (xrdp_is_os(pDstPixmap, pDstPriv)) { post_process = 1; if (g_do_dirty_os) { LLOGLN(10, ("rdpCopyPlane: getting dirty")); pDstPriv->is_dirty = 1; pDirtyPriv = pDstPriv; dirty_type = RDI_IMGLL; } else { rdpup_switch_os_surface(pDstPriv->rdpindex); reset_surface = 1; rdpup_get_pixmap_image_rect(pDstPixmap, &id); got_id = 1; } } } else { if (pDst->type == DRAWABLE_WINDOW) { pDstWnd = (WindowPtr)pDst; if (pDstWnd->viewable) { post_process = 1; if (g_do_dirty_ons) { LLOGLN(10, ("rdpCopyPlane: getting dirty")); g_screenPriv.is_dirty = 1; pDirtyPriv = &g_screenPriv; dirty_type = RDI_IMGLL; } else { rdpup_get_screen_image_rect(&id); got_id = 1; } } } } if (!post_process) { return rv; } RegionInit(&clip_reg, NullBox, 0); cd = rdp_get_clip(&clip_reg, pDst, pGC); if (cd == 1) { if (dirty_type != 0) { box.x1 = pDst->x + dstx; box.y1 = pDst->y + dsty; box.x2 = box.x1 + w; box.y2 = box.y1 + h; RegionInit(®1, &box, 0); draw_item_add_img_region(pDirtyPriv, ®1, GXcopy, dirty_type, TAG_COPYPLANE); RegionUninit(®1); } else if (got_id) { rdpup_begin_update(); rdpup_send_area(&id, pDst->x + dstx, pDst->y + dsty, w, h); rdpup_end_update(); } } else if (cd == 2) { num_clips = REGION_NUM_RECTS(&clip_reg); if (num_clips > 0) { if (dirty_type != 0) { box.x1 = pDst->x + dstx; box.y1 = pDst->y + dsty; box.x2 = box.x1 + w; box.y2 = box.y1 + h; RegionInit(®1, &box, 0); RegionInit(®2, NullBox, 0); RegionCopy(®2, &clip_reg); RegionIntersect(®1, ®1, ®2); draw_item_add_img_region(pDirtyPriv, ®1, GXcopy, dirty_type, TAG_COPYPLANE); RegionUninit(®1); RegionUninit(®2); } else if (got_id) { rdpup_begin_update(); box.x1 = pDst->x + dstx; box.y1 = pDst->y + dsty; box.x2 = box.x1 + w; box.y2 = box.y1 + h; RegionInit(&box_reg, &box, 0); RegionIntersect(&clip_reg, &clip_reg, &box_reg); num_clips = REGION_NUM_RECTS(&clip_reg); if (num_clips < 10) { for (j = num_clips - 1; j >= 0; j--) { box = REGION_RECTS(&clip_reg)[j]; rdpup_send_area(&id, box.x1, box.y1, box.x2 - box.x1, box.y2 - box.y1); } } else { pbox = RegionExtents(&clip_reg); rdpup_send_area(&id, pbox->x1, pbox->y1, pbox->x2 - pbox->x1, pbox->y2 - pbox->y1); } RegionUninit(&box_reg); rdpup_end_update(); } } } RegionUninit(&clip_reg); if (reset_surface) { rdpup_switch_os_surface(-1); } return rv; } xrdp-0.9.5/xorg/X11R7.6/rdp/rdpPolyGlyphBlt.h000644 001751 001751 00000002160 13125122134 020355 0ustar00metameta000000 000000 /* Copyright 2005-2013 Jay Sorg Permission to use, copy, modify, distribute, and sell this software and its documentation for any purpose is hereby granted without fee, provided that the above copyright notice appear in all copies and that both that copyright notice and this permission notice appear in supporting documentation. The above copyright notice and this permission notice shall be included in all copies or substantial portions of the Software. THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE OPEN GROUP BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. */ #ifndef __RDPPOLYGLYPHBLT_H #define __RDPPOLYGLYPHBLT_H void rdpPolyGlyphBlt(DrawablePtr pDrawable, GCPtr pGC, int x, int y, unsigned int nglyph, CharInfoPtr* ppci, pointer pglyphBase); #endif xrdp-0.9.5/xorg/X11R7.6/rdp/rdpkeyboardevdev.h000644 001751 001751 00000002075 13125122134 020623 0ustar00metameta000000 000000 /* Copyright 2013-2014 Jay Sorg Permission to use, copy, modify, distribute, and sell this software and its documentation for any purpose is hereby granted without fee, provided that the above copyright notice appear in all copies and that both that copyright notice and this permission notice appear in supporting documentation. The above copyright notice and this permission notice shall be included in all copies or substantial portions of the Software. THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE OPEN GROUP BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. keyboard map for base rules */ #ifndef _RDPKEYBOARDEVDEV_H #define _RDPKEYBOARDEVDEV_H void KbdAddEvent_evdev(int down, int param1, int param2, int param3, int param4); #endif xrdp-0.9.5/xorg/X11R7.6/rdp/rdpPolylines.c000644 001751 001751 00000020161 13125122134 017736 0ustar00metameta000000 000000 /* Copyright 2005-2013 Jay Sorg Permission to use, copy, modify, distribute, and sell this software and its documentation for any purpose is hereby granted without fee, provided that the above copyright notice appear in all copies and that both that copyright notice and this permission notice appear in supporting documentation. The above copyright notice and this permission notice shall be included in all copies or substantial portions of the Software. THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE OPEN GROUP BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. */ #include "rdp.h" #include "rdpdraw.h" #define LDEBUG 0 #define LOG_LEVEL 1 #define LLOG(_level, _args) \ do { if (_level < LOG_LEVEL) { ErrorF _args ; } } while (0) #define LLOGLN(_level, _args) \ do { if (_level < LOG_LEVEL) { ErrorF _args ; ErrorF("\n"); } } while (0) extern rdpScreenInfoRec g_rdpScreen; /* from rdpmain.c */ extern DevPrivateKeyRec g_rdpGCIndex; /* from rdpmain.c */ extern DevPrivateKeyRec g_rdpWindowIndex; /* from rdpmain.c */ extern DevPrivateKeyRec g_rdpPixmapIndex; /* from rdpmain.c */ extern int g_Bpp; /* from rdpmain.c */ extern ScreenPtr g_pScreen; /* from rdpmain.c */ extern Bool g_wrapPixmap; /* from rdpmain.c */ extern int g_do_dirty_os; /* in rdpmain.c */ extern int g_do_dirty_ons; /* in rdpmain.c */ extern rdpPixmapRec g_screenPriv; /* in rdpmain.c */ extern GCOps g_rdpGCOps; /* from rdpdraw.c */ extern int g_con_number; /* in rdpup.c */ /******************************************************************************/ static void rdpPolylinesOrg(DrawablePtr pDrawable, GCPtr pGC, int mode, int npt, DDXPointPtr pptInit) { rdpGCPtr priv; GCFuncs *oldFuncs; GC_OP_PROLOGUE(pGC); pGC->ops->Polylines(pDrawable, pGC, mode, npt, pptInit); GC_OP_EPILOGUE(pGC); } /******************************************************************************/ void rdpPolylines(DrawablePtr pDrawable, GCPtr pGC, int mode, int npt, DDXPointPtr pptInit) { RegionRec clip_reg; int num_clips; int cd; int i; int j; int got_id; int dirty_type; int post_process; int reset_surface; BoxRec box; xSegment *segs; int nseg; struct image_data id; WindowPtr pDstWnd; PixmapPtr pDstPixmap; rdpPixmapRec *pDstPriv; rdpPixmapRec *pDirtyPriv; LLOGLN(10, ("rdpPolylines:")); LLOGLN(10, (" npt %d mode %d x %d y %d", npt, mode, pDrawable->x, pDrawable->y)); #if 0 LLOGLN(0, (" points")); for (i = 0; i < npt; i++) { LLOGLN(0, (" %d %d", pptInit[i].x, pptInit[i].y)); } #endif /* convert lines to line segments */ nseg = npt - 1; segs = 0; if (npt > 1) { segs = (xSegment *)g_malloc(sizeof(xSegment) * nseg, 0); segs[0].x1 = pptInit[0].x + pDrawable->x; segs[0].y1 = pptInit[0].y + pDrawable->y; if (mode == CoordModeOrigin) { segs[0].x2 = pptInit[1].x + pDrawable->x; segs[0].y2 = pptInit[1].y + pDrawable->y; for (i = 2; i < npt; i++) { segs[i - 1].x1 = segs[i - 2].x2; segs[i - 1].y1 = segs[i - 2].y2; segs[i - 1].x2 = pptInit[i].x + pDrawable->x; segs[i - 1].y2 = pptInit[i].y + pDrawable->y; } } else { segs[0].x2 = segs[0].x1 + pptInit[1].x; segs[0].y2 = segs[0].y1 + pptInit[1].y; for (i = 2; i < npt; i++) { segs[i - 1].x1 = segs[i - 2].x2; segs[i - 1].y1 = segs[i - 2].y2; segs[i - 1].x2 = segs[i - 1].x1 + pptInit[i].x; segs[i - 1].y2 = segs[i - 1].y1 + pptInit[i].y; } } } else { LLOGLN(0, ("rdpPolylines: weird npt [%d]", npt)); } #if 0 LLOGLN(0, (" segments")); for (i = 0; i < nseg; i++) { LLOGLN(0, (" %d %d %d %d", segs[i].x1, segs[i].y1, segs[i].x2, segs[i].y2)); } #endif /* do original call */ rdpPolylinesOrg(pDrawable, pGC, mode, npt, pptInit); dirty_type = 0; pDirtyPriv = 0; post_process = 0; reset_surface = 0; got_id = 0; if (pDrawable->type == DRAWABLE_PIXMAP) { pDstPixmap = (PixmapPtr)pDrawable; pDstPriv = GETPIXPRIV(pDstPixmap); if (xrdp_is_os(pDstPixmap, pDstPriv)) { post_process = 1; if (g_do_dirty_os) { LLOGLN(10, ("rdpPolylines: getting dirty")); pDstPriv->is_dirty = 1; pDirtyPriv = pDstPriv; dirty_type = RDI_IMGLL; } else { rdpup_switch_os_surface(pDstPriv->rdpindex); reset_surface = 1; rdpup_get_pixmap_image_rect(pDstPixmap, &id); got_id = 1; } } } else { if (pDrawable->type == DRAWABLE_WINDOW) { pDstWnd = (WindowPtr)pDrawable; if (pDstWnd->viewable) { post_process = 1; if (g_do_dirty_ons) { LLOGLN(10, ("rdpPolylines: getting dirty")); g_screenPriv.is_dirty = 1; pDirtyPriv = &g_screenPriv; dirty_type = RDI_IMGLL; } else { rdpup_get_screen_image_rect(&id); got_id = 1; } } } } if (!post_process) { g_free(segs); return; } RegionInit(&clip_reg, NullBox, 0); cd = rdp_get_clip(&clip_reg, pDrawable, pGC); if (cd == 1) { if (segs != 0) { if (dirty_type != 0) { RegionUninit(&clip_reg); RegionInit(&clip_reg, NullBox, 0); RegionAroundSegs(&clip_reg, segs, nseg); draw_item_add_line_region(pDirtyPriv, &clip_reg, pGC->fgPixel, pGC->alu, pGC->lineWidth, segs, nseg, 0); } else if (got_id) { rdpup_begin_update(); rdpup_set_fgcolor(pGC->fgPixel); rdpup_set_opcode(pGC->alu); rdpup_set_pen(0, pGC->lineWidth); for (i = 0; i < nseg; i++) { rdpup_draw_line(segs[i].x1, segs[i].y1, segs[i].x2, segs[i].y2); } rdpup_set_opcode(GXcopy); rdpup_end_update(); } } } else if (cd == 2) { num_clips = REGION_NUM_RECTS(&clip_reg); if (nseg != 0 && num_clips > 0) { if (dirty_type != 0) { draw_item_add_line_region(pDirtyPriv, &clip_reg, pGC->fgPixel, pGC->alu, pGC->lineWidth, segs, nseg, 0); } else if (got_id) { rdpup_begin_update(); rdpup_set_fgcolor(pGC->fgPixel); rdpup_set_opcode(pGC->alu); rdpup_set_pen(0, pGC->lineWidth); for (j = num_clips - 1; j >= 0; j--) { box = REGION_RECTS(&clip_reg)[j]; rdpup_set_clip(box.x1, box.y1, box.x2 - box.x1, box.y2 - box.y1); for (i = 0; i < nseg; i++) { rdpup_draw_line(segs[i].x1, segs[i].y1, segs[i].x2, segs[i].y2); } } rdpup_reset_clip(); rdpup_set_opcode(GXcopy); rdpup_end_update(); } } } g_free(segs); RegionUninit(&clip_reg); if (reset_surface) { rdpup_switch_os_surface(-1); } } xrdp-0.9.5/xorg/X11R7.6/rdp/rdpdraw.c000644 001751 001751 00000123453 13127114621 016731 0ustar00metameta000000 000000 /* Copyright 2005-2013 Jay Sorg Permission to use, copy, modify, distribute, and sell this software and its documentation for any purpose is hereby granted without fee, provided that the above copyright notice appear in all copies and that both that copyright notice and this permission notice appear in supporting documentation. The above copyright notice and this permission notice shall be included in all copies or substantial portions of the Software. THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE OPEN GROUP BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. Xserver drawing ops and funcs */ #include "rdp.h" #include "gcops.h" #include "rdpdraw.h" #include "rdpCopyArea.h" #include "rdpPolyFillRect.h" #include "rdpPutImage.h" #include "rdpPolyRectangle.h" #include "rdpPolylines.h" #include "rdpPolySegment.h" #include "rdpFillSpans.h" #include "rdpSetSpans.h" #include "rdpCopyPlane.h" #include "rdpPolyPoint.h" #include "rdpPolyArc.h" #include "rdpFillPolygon.h" #include "rdpPolyFillArc.h" #include "rdpPolyText8.h" #include "rdpPolyText16.h" #include "rdpImageText8.h" #include "rdpImageText16.h" #include "rdpImageGlyphBlt.h" #include "rdpPolyGlyphBlt.h" #include "rdpPushPixels.h" #include "rdpglyph.h" #define LOG_LEVEL 1 #define LLOG(_level, _args) \ do { if (_level < LOG_LEVEL) { ErrorF _args ; } } while (0) #define LLOGLN(_level, _args) \ do { if (_level < LOG_LEVEL) { ErrorF _args ; ErrorF("\n"); } } while (0) extern rdpScreenInfoRec g_rdpScreen; /* from rdpmain.c */ extern DevPrivateKeyRec g_rdpGCIndex; /* from rdpmain.c */ extern DevPrivateKeyRec g_rdpWindowIndex; /* from rdpmain.c */ extern DevPrivateKeyRec g_rdpPixmapIndex; /* from rdpmain.c */ extern int g_Bpp; /* from rdpmain.c */ extern ScreenPtr g_pScreen; /* from rdpmain.c */ extern Bool g_wrapPixmap; /* from rdpmain.c */ extern WindowPtr g_invalidate_window; /* in rdpmain.c */ extern int g_use_rail; /* in rdpmain.c */ extern int g_do_dirty_os; /* in rdpmain.c */ extern int g_do_dirty_ons; /* in rdpmain.c */ extern rdpPixmapRec g_screenPriv; /* in rdpmain.c */ extern int g_con_number; /* in rdpmain.c */ extern int g_do_glyph_cache; /* in rdpmain.c */ ColormapPtr g_rdpInstalledColormap; GCFuncs g_rdpGCFuncs = { rdpValidateGC, rdpChangeGC, rdpCopyGC, rdpDestroyGC, rdpChangeClip, rdpDestroyClip, rdpCopyClip }; GCOps g_rdpGCOps = { rdpFillSpans, rdpSetSpans, rdpPutImage, rdpCopyArea, rdpCopyPlane, rdpPolyPoint, rdpPolylines, rdpPolySegment, rdpPolyRectangle, rdpPolyArc, rdpFillPolygon, rdpPolyFillRect, rdpPolyFillArc, rdpPolyText8, rdpPolyText16, rdpImageText8, rdpImageText16, rdpImageGlyphBlt, rdpPolyGlyphBlt, rdpPushPixels }; /******************************************************************************/ /* return 0, draw nothing */ /* return 1, draw with no clip */ /* return 2, draw using clip */ int rdp_get_clip(RegionPtr pRegion, DrawablePtr pDrawable, GCPtr pGC) { WindowPtr pWindow; RegionPtr temp; BoxRec box; int rv; rv = 0; if (pDrawable->type == DRAWABLE_PIXMAP) { switch (pGC->clientClipType) { case CT_NONE: rv = 1; break; case CT_REGION: rv = 2; RegionCopy(pRegion, pGC->pCompositeClip); break; default: rdpLog("unimp clip type %d\n", pGC->clientClipType); break; } if (rv == 2) /* check if the clip is the entire pixmap */ { box.x1 = 0; box.y1 = 0; box.x2 = pDrawable->width; box.y2 = pDrawable->height; if (RegionContainsRect(pRegion, &box) == rgnIN) { rv = 1; } } } else if (pDrawable->type == DRAWABLE_WINDOW) { pWindow = (WindowPtr)pDrawable; if (pWindow->viewable) { if (pGC->subWindowMode == IncludeInferiors) { temp = &pWindow->borderClip; } else { temp = &pWindow->clipList; } if (RegionNotEmpty(temp)) { switch (pGC->clientClipType) { case CT_NONE: rv = 2; RegionCopy(pRegion, temp); break; case CT_REGION: rv = 2; RegionCopy(pRegion, pGC->clientClip); RegionTranslate(pRegion, pDrawable->x + pGC->clipOrg.x, pDrawable->y + pGC->clipOrg.y); RegionIntersect(pRegion, pRegion, temp); break; default: rdpLog("unimp clip type %d\n", pGC->clientClipType); break; } if (rv == 2) /* check if the clip is the entire screen */ { box.x1 = 0; box.y1 = 0; box.x2 = g_rdpScreen.width; box.y2 = g_rdpScreen.height; if (RegionContainsRect(pRegion, &box) == rgnIN) { rv = 1; } } } } } return rv; } /******************************************************************************/ void GetTextBoundingBox(DrawablePtr pDrawable, FontPtr font, int x, int y, int n, BoxPtr pbox) { int maxAscent; int maxDescent; int maxCharWidth; if (FONTASCENT(font) > FONTMAXBOUNDS(font, ascent)) { maxAscent = FONTASCENT(font); } else { maxAscent = FONTMAXBOUNDS(font, ascent); } if (FONTDESCENT(font) > FONTMAXBOUNDS(font, descent)) { maxDescent = FONTDESCENT(font); } else { maxDescent = FONTMAXBOUNDS(font, descent); } if (FONTMAXBOUNDS(font, rightSideBearing) > FONTMAXBOUNDS(font, characterWidth)) { maxCharWidth = FONTMAXBOUNDS(font, rightSideBearing); } else { maxCharWidth = FONTMAXBOUNDS(font, characterWidth); } pbox->x1 = pDrawable->x + x; pbox->y1 = pDrawable->y + y - maxAscent; pbox->x2 = pbox->x1 + maxCharWidth * n; pbox->y2 = pbox->y1 + maxAscent + maxDescent; if (FONTMINBOUNDS(font, leftSideBearing) < 0) { pbox->x1 += FONTMINBOUNDS(font, leftSideBearing); } } /******************************************************************************/ #define GC_FUNC_PROLOGUE(_pGC) \ { \ priv = (rdpGCPtr)(dixGetPrivateAddr(&(_pGC->devPrivates), &g_rdpGCIndex)); \ (_pGC)->funcs = priv->funcs; \ if (priv->ops != 0) \ { \ (_pGC)->ops = priv->ops; \ } \ } /******************************************************************************/ #define GC_FUNC_EPILOGUE(_pGC) \ { \ priv->funcs = (_pGC)->funcs; \ (_pGC)->funcs = &g_rdpGCFuncs; \ if (priv->ops != 0) \ { \ priv->ops = (_pGC)->ops; \ (_pGC)->ops = &g_rdpGCOps; \ } \ } /******************************************************************************/ static void rdpValidateGC(GCPtr pGC, unsigned long changes, DrawablePtr d) { rdpGCRec *priv; int wrap; RegionPtr pRegion; LLOGLN(10, ("rdpValidateGC:")); GC_FUNC_PROLOGUE(pGC); pGC->funcs->ValidateGC(pGC, changes, d); if (g_wrapPixmap) { wrap = 1; } else { wrap = (d->type == DRAWABLE_WINDOW) && ((WindowPtr)d)->viewable; if (wrap) { if (pGC->subWindowMode == IncludeInferiors) { pRegion = &(((WindowPtr)d)->borderClip); } else { pRegion = &(((WindowPtr)d)->clipList); } wrap = RegionNotEmpty(pRegion); } } priv->ops = 0; if (wrap) { priv->ops = pGC->ops; } GC_FUNC_EPILOGUE(pGC); } /******************************************************************************/ static void rdpChangeGC(GCPtr pGC, unsigned long mask) { rdpGCRec *priv; LLOGLN(10, ("in rdpChangeGC")); GC_FUNC_PROLOGUE(pGC); pGC->funcs->ChangeGC(pGC, mask); GC_FUNC_EPILOGUE(pGC); } /******************************************************************************/ static void rdpCopyGC(GCPtr src, unsigned long mask, GCPtr dst) { rdpGCRec *priv; LLOGLN(10, ("in rdpCopyGC")); GC_FUNC_PROLOGUE(dst); dst->funcs->CopyGC(src, mask, dst); GC_FUNC_EPILOGUE(dst); } /******************************************************************************/ static void rdpDestroyGC(GCPtr pGC) { rdpGCRec *priv; LLOGLN(10, ("in rdpDestroyGC")); GC_FUNC_PROLOGUE(pGC); pGC->funcs->DestroyGC(pGC); GC_FUNC_EPILOGUE(pGC); } /******************************************************************************/ static void rdpChangeClip(GCPtr pGC, int type, pointer pValue, int nrects) { rdpGCRec *priv; LLOGLN(10, ("in rdpChangeClip")); GC_FUNC_PROLOGUE(pGC); pGC->funcs->ChangeClip(pGC, type, pValue, nrects); GC_FUNC_EPILOGUE(pGC); } /******************************************************************************/ static void rdpDestroyClip(GCPtr pGC) { rdpGCRec *priv; LLOGLN(10, ("in rdpDestroyClip")); GC_FUNC_PROLOGUE(pGC); pGC->funcs->DestroyClip(pGC); GC_FUNC_EPILOGUE(pGC); } /******************************************************************************/ static void rdpCopyClip(GCPtr dst, GCPtr src) { rdpGCRec *priv; LLOGLN(0, ("in rdpCopyClip")); GC_FUNC_PROLOGUE(dst); dst->funcs->CopyClip(dst, src); GC_FUNC_EPILOGUE(dst); } /******************************************************************************/ #define GC_OP_PROLOGUE(_pGC) \ { \ priv = (rdpGCPtr)dixGetPrivateAddr(&(pGC->devPrivates), &g_rdpGCIndex); \ oldFuncs = _pGC->funcs; \ (_pGC)->funcs = priv->funcs; \ (_pGC)->ops = priv->ops; \ } /******************************************************************************/ #define GC_OP_EPILOGUE(_pGC) \ { \ priv->ops = (_pGC)->ops; \ (_pGC)->funcs = oldFuncs; \ (_pGC)->ops = &g_rdpGCOps; \ } /******************************************************************************/ Bool rdpCloseScreen(int i, ScreenPtr pScreen) { LLOGLN(10, ("in rdpCloseScreen")); pScreen->CloseScreen = g_rdpScreen.CloseScreen; pScreen->CreateGC = g_rdpScreen.CreateGC; //pScreen->PaintWindowBackground = g_rdpScreen.PaintWindowBackground; //pScreen->PaintWindowBorder = g_rdpScreen.PaintWindowBorder; pScreen->CopyWindow = g_rdpScreen.CopyWindow; pScreen->ClearToBackground = g_rdpScreen.ClearToBackground; pScreen->RestoreAreas = g_rdpScreen.RestoreAreas; return 1; } /******************************************************************************/ int draw_item_add(rdpPixmapRec *priv, struct rdp_draw_item *di) { priv->is_alpha_dirty_not = 0; if (priv->draw_item_tail == 0) { priv->draw_item_tail = di; priv->draw_item_head = di; } else { di->prev = priv->draw_item_tail; priv->draw_item_tail->next = di; priv->draw_item_tail = di; } if (priv == &g_screenPriv) { rdpScheduleDeferredUpdate(); } return 0; } /******************************************************************************/ int draw_item_remove(rdpPixmapRec *priv, struct rdp_draw_item *di) { if (di->prev != 0) { di->prev->next = di->next; } if (di->next != 0) { di->next->prev = di->prev; } if (priv->draw_item_head == di) { priv->draw_item_head = di->next; } if (priv->draw_item_tail == di) { priv->draw_item_tail = di->prev; } if (di->type == RDI_LINE) { if (di->u.line.segs != 0) { g_free(di->u.line.segs); } } if (di->type == RDI_TEXT) { delete_rdp_text(di->u.text.rtext); } RegionDestroy(di->reg); g_free(di); return 0; } /******************************************************************************/ int draw_item_remove_all(rdpPixmapRec *priv) { struct rdp_draw_item *di; di = priv->draw_item_head; while (di != 0) { draw_item_remove(priv, di); di = priv->draw_item_head; } return 0; } /******************************************************************************/ int region_get_pixel_count(RegionPtr reg) { int index; int count; int pixels; int width; int height; BoxRec box; pixels = 0; count = REGION_NUM_RECTS(reg); for (index = 0; index < count; index++) { box = REGION_RECTS(reg)[index]; width = box.x2 - box.x1; height = box.y2 - box.y1; pixels += width * height; } return pixels; } /******************************************************************************/ /* returns boolean */ int region_in_region(RegionPtr reg_small, int sreg_pcount, RegionPtr reg_big) { int rv; RegionRec reg; rv = 0; RegionInit(®, NullBox, 0); RegionIntersect(®, reg_small, reg_big); if (sreg_pcount == -1) { sreg_pcount = region_get_pixel_count(reg_small); } if (sreg_pcount == 0) { /* empty region not even in */ return 0; } if (region_get_pixel_count(®) == sreg_pcount) { rv = 1; } RegionUninit(®); return rv; } /******************************************************************************/ static int remove_empties(rdpPixmapRec* priv) { struct rdp_draw_item* di; struct rdp_draw_item* di_prev; int rv; rv = 0; /* remove draw items with empty regions */ di = priv->draw_item_head; di_prev = 0; while (di != 0) { if (!RegionNotEmpty(di->reg)) { LLOGLN(10, ("remove_empties: removing empty item type %d", di->type)); draw_item_remove(priv, di); di = di_prev == 0 ? priv->draw_item_head : di_prev->next; rv++; } else { di_prev = di; di = di->next; } } return rv; } /******************************************************************************/ static int dump_draw_list(rdpPixmapRec* priv) { struct rdp_draw_item* di; int index; int count; BoxRec box; LLOGLN(0, ("dump_draw_list:")); di = priv->draw_item_head; while (di != 0) { LLOGLN(0, (" type %d", di->type)); count = REGION_NUM_RECTS(di->reg); if (count == 0) { LLOGLN(0, (" empty region")); } else { box = RegionExtents(di->reg)[0]; LLOGLN(0, (" region list follows extents x1 %d y1 %d x2 %d y2 %d", box.x1, box.y1, box.x2, box.y2)); for (index = 0; index < count; index++) { box = REGION_RECTS(di->reg)[index]; LLOGLN(0, (" index %d x1 %d y1 %d x2 %d y2 %d", index, box.x1, box.y1, box.x2, box.y2)); } } di = di->next; } return 0; } /******************************************************************************/ /* returns boolean */ static int region_intersect_at_all(RegionPtr reg_small, RegionPtr reg_big) { int rv; RegionRec reg; if (!RegionNotEmpty(reg_small)) { return 0; } rv = 0; RegionInit(®, NullBox, 0); RegionIntersect(®, reg_big, reg_big); if (RegionNotEmpty(®)) { rv = 1; } RegionUninit(®); return rv; } /******************************************************************************/ int draw_item_pack(PixmapPtr pix, rdpPixmapRec *priv) { struct rdp_draw_item *di; struct rdp_draw_item *di_prev; BoxRec box; RegionRec treg; #if 1 if (pix != 0) { box.x1 = 0; box.x2 = pix->drawable.width; box.y1 = 0; box.y2 = pix->drawable.height; RegionInit(&treg, &box, 0); di = priv->draw_item_head; di_prev = 0; while (di != 0) { RegionIntersect(di->reg, di->reg, &treg); di_prev = di; di = di->next; } RegionUninit(&treg); remove_empties(priv); } #endif #if 1 /* look for repeating draw types */ if (priv->draw_item_head != 0) { if (priv->draw_item_head->next != 0) { di_prev = priv->draw_item_head; di = priv->draw_item_head->next; while (di != 0) { #if 0 if ((di_prev->type == RDI_IMGLL || di_prev->type == RDI_IMGLY) && (di->type == RDI_IMGLL || di->type == RDI_IMGLY)) { LLOGLN(10, ("draw_item_pack: packing RDI_IMGLL and RDI_IMGLY")); di_prev->type = RDI_IMGLY; RegionUnion(di_prev->reg, di_prev->reg, di->reg); draw_item_remove(priv, di); di = di_prev->next; } #else if ((di_prev->type == RDI_IMGLL) && (di->type == RDI_IMGLL)) { LLOGLN(10, ("draw_item_pack: packing RDI_IMGLL")); RegionUnion(di_prev->reg, di_prev->reg, di->reg); draw_item_remove(priv, di); di = di_prev->next; } #endif else if ((di_prev->type == RDI_IMGLY) && (di->type == RDI_IMGLY)) { LLOGLN(10, ("draw_item_pack: packing RDI_IMGLY")); RegionUnion(di_prev->reg, di_prev->reg, di->reg); draw_item_remove(priv, di); di = di_prev->next; } else { di_prev = di; di = di_prev->next; } } } } remove_empties(priv); #endif #if 0 if (priv->draw_item_tail != 0) { if (priv->draw_item_tail->prev != 0) { di = priv->draw_item_tail; while (di->prev != 0) { di_prev = di->prev; while (di_prev != 0) { if ((di->type == RDI_TEXT) && (di_prev->type == RDI_IMGLY)) { if (region_intersect_at_all(di->reg, di_prev->reg)) { di_prev->type = RDI_IMGLL; } } di_prev = di_prev->prev; } di = di->prev; } } } remove_empties(priv); #endif #if 0 /* subtract regions */ if (priv->draw_item_tail != 0) { if (priv->draw_item_tail->prev != 0) { di = priv->draw_item_tail; while (di->prev != 0) { /* skip subtract flag * draw items like line can't be used to clear(subtract) previous * draw items since they are not opaque * eg they can not be the 'S' in 'D = M - S' * the region for line draw items is the clip region */ if ((di->flags & 1) == 0) { di_prev = di->prev; while (di_prev != 0) { if (region_in_region(di_prev->reg, -1, di->reg)) { /* empty region so this draw item will get removed below */ RegionEmpty(di_prev->reg); } di_prev = di_prev->prev; } } di = di->prev; } } } remove_empties(priv); #endif return 0; } static char g_strings[][32] = { "Composite", /* 0 */ "CopyArea", /* 1 */ "PolyFillRect", /* 2 */ "PutImage", /* 3 */ "PolyRectangle", /* 4 */ "CopyPlane", /* 5 */ "PolyArc", /* 6 */ "FillPolygon", /* 7 */ "PolyFillArc", /* 8 */ "ImageText8", /* 9 */ "PolyText8", /* 10 */ "PolyText16", /* 11 */ "ImageText16", /* 12 */ "ImageGlyphBlt", /* 13 */ "PolyGlyphBlt", /* 14 */ "PushPixels", /* 15 */ "Other" }; /******************************************************************************/ int draw_item_add_img_region(rdpPixmapRec *priv, RegionPtr reg, int opcode, int type, int code) { struct rdp_draw_item *di; LLOGLN(10, ("draw_item_add_img_region: %s", g_strings[code])); di = (struct rdp_draw_item *)g_malloc(sizeof(struct rdp_draw_item), 1); di->type = type; di->reg = RegionCreate(NullBox, 0); RegionCopy(di->reg, reg); di->u.img.opcode = opcode; draw_item_add(priv, di); return 0; } /******************************************************************************/ int draw_item_add_fill_region(rdpPixmapRec *priv, RegionPtr reg, int color, int opcode) { struct rdp_draw_item *di; LLOGLN(10, ("draw_item_add_fill_region:")); di = (struct rdp_draw_item *)g_malloc(sizeof(struct rdp_draw_item), 1); di->type = RDI_FILL; di->u.fill.fg_color = color; di->u.fill.opcode = opcode; di->reg = RegionCreate(NullBox, 0); RegionCopy(di->reg, reg); draw_item_add(priv, di); return 0; } /******************************************************************************/ int draw_item_add_line_region(rdpPixmapRec *priv, RegionPtr reg, int color, int opcode, int width, xSegment *segs, int nseg, int is_segment) { struct rdp_draw_item *di; LLOGLN(10, ("draw_item_add_line_region:")); di = (struct rdp_draw_item *)g_malloc(sizeof(struct rdp_draw_item), 1); di->type = RDI_LINE; di->u.line.fg_color = color; di->u.line.opcode = opcode; di->u.line.width = width; di->u.line.segs = (xSegment *)g_malloc(sizeof(xSegment) * nseg, 1); memcpy(di->u.line.segs, segs, sizeof(xSegment) * nseg); di->u.line.nseg = nseg; if (is_segment) { di->u.line.flags = 1; } di->reg = RegionCreate(NullBox, 0); di->flags |= 1; RegionCopy(di->reg, reg); draw_item_add(priv, di); return 0; } /******************************************************************************/ int draw_item_add_srcblt_region(rdpPixmapRec *priv, RegionPtr reg, int srcx, int srcy, int dstx, int dsty, int cx, int cy) { struct rdp_draw_item *di; LLOGLN(10, ("draw_item_add_srcblt_region:")); di = (struct rdp_draw_item *)g_malloc(sizeof(struct rdp_draw_item), 1); di->type = RDI_SCRBLT; di->u.scrblt.srcx = srcx; di->u.scrblt.srcy = srcy; di->u.scrblt.dstx = dstx; di->u.scrblt.dsty = dsty; di->u.scrblt.cx = cx; di->u.scrblt.cy = cy; di->reg = RegionCreate(NullBox, 0); RegionCopy(di->reg, reg); draw_item_add(priv, di); return 0; } /******************************************************************************/ int draw_item_add_text_region(rdpPixmapRec* priv, RegionPtr reg, int color, int opcode, struct rdp_text* rtext) { struct rdp_draw_item* di; LLOGLN(10, ("draw_item_add_text_region:")); di = (struct rdp_draw_item*)g_malloc(sizeof(struct rdp_draw_item), 1); di->type = RDI_TEXT; di->u.text.fg_color = color; di->u.text.opcode = opcode; di->u.text.rtext = rtext; di->reg = RegionCreate(NullBox, 0); RegionCopy(di->reg, reg); draw_item_add(priv, di); return 0; } /******************************************************************************/ PixmapPtr rdpCreatePixmap(ScreenPtr pScreen, int width, int height, int depth, unsigned usage_hint) { PixmapPtr rv; rdpPixmapRec *priv; int org_width; org_width = width; /* width must be a multiple of 4 in rdp */ width = (width + 3) & ~3; LLOGLN(10, ("rdpCreatePixmap: width %d org_width %d depth %d screen depth %d", width, org_width, depth, g_rdpScreen.depth)); pScreen->CreatePixmap = g_rdpScreen.CreatePixmap; rv = pScreen->CreatePixmap(pScreen, width, height, depth, usage_hint); pScreen->CreatePixmap = rdpCreatePixmap; priv = GETPIXPRIV(rv); priv->rdpindex = -1; priv->kind_width = width; pScreen->ModifyPixmapHeader(rv, org_width, 0, 0, 0, 0, 0); if ((org_width == 0) && (height == 0)) { LLOGLN(10, ("rdpCreatePixmap: setting is_scratch")); priv->is_scratch = 1; } return rv; } extern struct rdpup_os_bitmap *g_os_bitmaps; /******************************************************************************/ Bool rdpDestroyPixmap(PixmapPtr pPixmap) { Bool rv; ScreenPtr pScreen; rdpPixmapRec *priv; LLOGLN(10, ("rdpDestroyPixmap:")); priv = GETPIXPRIV(pPixmap); LLOGLN(10, ("status %d refcnt %d", priv->status, pPixmap->refcnt)); if (pPixmap->refcnt < 2) { if (XRDP_IS_OS(priv)) { if (priv->rdpindex >= 0) { rdpup_remove_os_bitmap(priv->rdpindex); rdpup_delete_os_surface(priv->rdpindex); } } } pScreen = pPixmap->drawable.pScreen; pScreen->DestroyPixmap = g_rdpScreen.DestroyPixmap; rv = pScreen->DestroyPixmap(pPixmap); pScreen->DestroyPixmap = rdpDestroyPixmap; return rv; } /*****************************************************************************/ int xrdp_is_os(PixmapPtr pix, rdpPixmapPtr priv) { RegionRec reg1; BoxRec box; int width; int height; struct image_data id; if (XRDP_IS_OS(priv)) { /* update time stamp */ rdpup_update_os_use(priv->rdpindex); } else { width = pix->drawable.width; height = pix->drawable.height; if ((pix->usage_hint == 0) && (pix->drawable.depth >= g_rdpScreen.depth) && (width > 0) && (height > 0) && (priv->kind_width > 0) && (priv->is_scratch == 0) && (priv->use_count >= 0)) { width = (width + 3) & ~3; priv->rdpindex = rdpup_add_os_bitmap(pix, priv); if (priv->rdpindex >= 0) { priv->status = 1; rdpup_create_os_surface(priv->rdpindex, width, height); box.x1 = 0; box.y1 = 0; box.x2 = width; box.y2 = height; if (g_do_dirty_os) { LLOGLN(10, ("xrdp_is_os: priv->con_number %d g_con_number %d", priv->con_number, g_con_number)); LLOGLN(10, ("xrdp_is_os: priv->use_count %d", priv->use_count)); if (priv->con_number != g_con_number) { LLOGLN(10, ("xrdp_is_os: queuing invalidating all")); draw_item_remove_all(priv); RegionInit(®1, &box, 0); draw_item_add_img_region(priv, ®1, GXcopy, RDI_IMGLY, 16); RegionUninit(®1); priv->is_dirty = 1; priv->con_number = g_con_number; } } else { rdpup_get_pixmap_image_rect(pix, &id); rdpup_switch_os_surface(priv->rdpindex); rdpup_begin_update(); rdpup_send_area(&id, box.x1, box.y1, box.x2 - box.x1, box.y2 - box.y1); rdpup_end_update(); rdpup_switch_os_surface(-1); } priv->use_count++; return 1; } else { LLOGLN(10, ("xrdp_is_os: rdpup_add_os_bitmap failed")); } } priv->use_count++; return 0; } priv->use_count++; return 1; } /******************************************************************************/ Bool rdpCreateWindow(WindowPtr pWindow) { ScreenPtr pScreen; rdpWindowRec *priv; Bool rv; LLOGLN(10, ("rdpCreateWindow:")); priv = GETWINPRIV(pWindow); LLOGLN(10, (" %p status %d", priv, priv->status)); pScreen = pWindow->drawable.pScreen; pScreen->CreateWindow = g_rdpScreen.CreateWindow; rv = pScreen->CreateWindow(pWindow); pScreen->CreateWindow = rdpCreateWindow; if (g_use_rail) { } return rv; } /******************************************************************************/ Bool rdpDestroyWindow(WindowPtr pWindow) { ScreenPtr pScreen; rdpWindowRec *priv; Bool rv; LLOGLN(10, ("rdpDestroyWindow:")); priv = GETWINPRIV(pWindow); pScreen = pWindow->drawable.pScreen; pScreen->DestroyWindow = g_rdpScreen.DestroyWindow; rv = pScreen->DestroyWindow(pWindow); pScreen->DestroyWindow = rdpDestroyWindow; if (g_use_rail) { #ifdef XRDP_WM_RDPUP LLOGLN(10, (" rdpup_delete_window")); rdpup_delete_window(pWindow, priv); #endif } return rv; } /******************************************************************************/ Bool rdpPositionWindow(WindowPtr pWindow, int x, int y) { ScreenPtr pScreen; rdpWindowRec *priv; Bool rv; LLOGLN(10, ("rdpPositionWindow:")); priv = GETWINPRIV(pWindow); pScreen = pWindow->drawable.pScreen; pScreen->PositionWindow = g_rdpScreen.PositionWindow; rv = pScreen->PositionWindow(pWindow, x, y); pScreen->PositionWindow = rdpPositionWindow; if (g_use_rail) { if (priv->status == 1) { LLOGLN(10, ("rdpPositionWindow:")); LLOGLN(10, (" x %d y %d", x, y)); } } return rv; } /******************************************************************************/ Bool rdpRealizeWindow(WindowPtr pWindow) { ScreenPtr pScreen; rdpWindowRec *priv; Bool rv; LLOGLN(10, ("rdpRealizeWindow:")); priv = GETWINPRIV(pWindow); pScreen = pWindow->drawable.pScreen; pScreen->RealizeWindow = g_rdpScreen.RealizeWindow; rv = pScreen->RealizeWindow(pWindow); pScreen->RealizeWindow = rdpRealizeWindow; if (g_use_rail) { if ((pWindow != g_invalidate_window) && (pWindow->parent != 0)) { if (XR_IS_ROOT(pWindow->parent)) { LLOGLN(10, ("rdpRealizeWindow:")); LLOGLN(10, (" pWindow %p id 0x%x pWindow->parent %p id 0x%x x %d " "y %d width %d height %d", pWindow, (int)(pWindow->drawable.id), pWindow->parent, (int)(pWindow->parent->drawable.id), pWindow->drawable.x, pWindow->drawable.y, pWindow->drawable.width, pWindow->drawable.height)); priv->status = 1; #ifdef XRDP_WM_RDPUP rdpup_create_window(pWindow, priv); #endif } } } return rv; } /******************************************************************************/ Bool rdpUnrealizeWindow(WindowPtr pWindow) { ScreenPtr pScreen; rdpWindowRec *priv; Bool rv; LLOGLN(10, ("rdpUnrealizeWindow:")); priv = GETWINPRIV(pWindow); pScreen = pWindow->drawable.pScreen; pScreen->UnrealizeWindow = g_rdpScreen.UnrealizeWindow; rv = pScreen->UnrealizeWindow(pWindow); pScreen->UnrealizeWindow = rdpUnrealizeWindow; if (g_use_rail) { if (priv->status == 1) { LLOGLN(10, ("rdpUnrealizeWindow:")); priv->status = 0; if (pWindow->overrideRedirect) { #ifdef XRDP_WM_RDPUP /* * Popups are unmapped by X server, so probably * they will be mapped again. Thereby we should * just hide those popups instead of destroying * them. */ LLOGLN(10, (" rdpup_show_window")); rdpup_show_window(pWindow, priv, 0x0); /* 0x0 - do not show the window */ #endif } } } return rv; } /******************************************************************************/ Bool rdpChangeWindowAttributes(WindowPtr pWindow, unsigned long mask) { ScreenPtr pScreen; rdpWindowRec *priv; Bool rv; LLOGLN(10, ("rdpChangeWindowAttributes:")); priv = GETWINPRIV(pWindow); pScreen = pWindow->drawable.pScreen; pScreen->ChangeWindowAttributes = g_rdpScreen.ChangeWindowAttributes; rv = pScreen->ChangeWindowAttributes(pWindow, mask); pScreen->ChangeWindowAttributes = rdpChangeWindowAttributes; if (g_use_rail) { } return rv; } /******************************************************************************/ void rdpWindowExposures(WindowPtr pWindow, RegionPtr pRegion, RegionPtr pBSRegion) { ScreenPtr pScreen; rdpWindowRec *priv; LLOGLN(10, ("rdpWindowExposures:")); priv = GETWINPRIV(pWindow); pScreen = pWindow->drawable.pScreen; pScreen->WindowExposures = g_rdpScreen.WindowExposures; pScreen->WindowExposures(pWindow, pRegion, pBSRegion); if (g_use_rail) { } pScreen->WindowExposures = rdpWindowExposures; } /******************************************************************************/ Bool rdpCreateGC(GCPtr pGC) { rdpGCRec *priv; Bool rv; LLOGLN(10, ("in rdpCreateGC\n")); priv = GETGCPRIV(pGC); g_pScreen->CreateGC = g_rdpScreen.CreateGC; rv = g_pScreen->CreateGC(pGC); if (rv) { priv->funcs = pGC->funcs; priv->ops = 0; pGC->funcs = &g_rdpGCFuncs; } else { rdpLog("error in rdpCreateGC, CreateGC failed\n"); } g_pScreen->CreateGC = rdpCreateGC; return rv; } /******************************************************************************/ void rdpCopyWindow(WindowPtr pWin, DDXPointRec ptOldOrg, RegionPtr pOldRegion) { RegionRec reg; RegionRec reg1; RegionRec clip; int dx; int dy; int i; int j; int num_clip_rects; int num_reg_rects; BoxRec box1; BoxRec box2; BoxPtr box3; LLOGLN(10, ("rdpCopyWindow:")); LLOGLN(10, ("rdpCopyWindow: new x %d new y %d old x %d old y %d", pWin->drawable.x, pWin->drawable.y, ptOldOrg.x, ptOldOrg.y)); RegionInit(®, NullBox, 0); RegionCopy(®, pOldRegion); RegionInit(&clip, NullBox, 0); RegionCopy(&clip, &pWin->borderClip); dx = pWin->drawable.x - ptOldOrg.x; dy = pWin->drawable.y - ptOldOrg.y; if (g_do_dirty_ons) { rdpup_check_dirty_screen(&g_screenPriv); } g_pScreen->CopyWindow = g_rdpScreen.CopyWindow; g_pScreen->CopyWindow(pWin, ptOldOrg, pOldRegion); g_pScreen->CopyWindow = rdpCopyWindow; num_clip_rects = REGION_NUM_RECTS(&clip); num_reg_rects = REGION_NUM_RECTS(®); LLOGLN(10, ("rdpCopyWindow: num_clip_rects %d num_reg_rects %d", num_clip_rects, num_reg_rects)); if ((num_clip_rects == 0) || (num_reg_rects == 0)) { return; } rdpup_begin_update(); /* when there is a huge list of screen copies, just send as bitmap firefox dragging test does this */ if ((num_clip_rects > 16) && (num_reg_rects > 16)) { box3 = RegionExtents(®); rdpup_send_area(0, box3->x1 + dx, box3->y1 + dy, box3->x2 - box3->x1, box3->y2 - box3->y1); } else { /* should maybe sort the rects instead of checking dy < 0 */ /* If we can depend on the rects going from top to bottom, left to right we are ok */ if (dy < 0 || (dy == 0 && dx < 0)) { for (j = 0; j < num_clip_rects; j++) { box1 = REGION_RECTS(&clip)[j]; LLOGLN(10, ("clip x %d y %d w %d h %d", box1.x1, box1.y1, box1.x2 - box1.x1, box1.y2 - box1.y1)); rdpup_set_clip(box1.x1, box1.y1, box1.x2 - box1.x1, box1.y2 - box1.y1); for (i = 0; i < num_reg_rects; i++) { box2 = REGION_RECTS(®)[i]; LLOGLN(10, ("reg x %d y %d w %d h %d", box2.x1, box2.y1, box2.x2 - box2.x1, box2.y2 - box2.y1)); rdpup_screen_blt(box2.x1 + dx, box2.y1 + dy, box2.x2 - box2.x1, box2.y2 - box2.y1, box2.x1, box2.y1); } } } else { for (j = num_clip_rects - 1; j >= 0; j--) { box1 = REGION_RECTS(&clip)[j]; LLOGLN(10, ("clip x %d y %d w %d h %d", box1.x1, box1.y1, box1.x2 - box1.x1, box1.y2 - box1.y1)); rdpup_set_clip(box1.x1, box1.y1, box1.x2 - box1.x1, box1.y2 - box1.y1); for (i = num_reg_rects - 1; i >= 0; i--) { box2 = REGION_RECTS(®)[i]; LLOGLN(10, ("reg x %d y %d w %d h %d", box2.x1, box2.y1, box2.x2 - box2.x1, box2.y2 - box2.y1)); rdpup_screen_blt(box2.x1 + dx, box2.y1 + dy, box2.x2 - box2.x1, box2.y2 - box2.y1, box2.x1, box2.y1); } } } } rdpup_reset_clip(); rdpup_end_update(); RegionUninit(®); RegionUninit(&clip); } /******************************************************************************/ void rdpClearToBackground(WindowPtr pWin, int x, int y, int w, int h, Bool generateExposures) { int j; BoxRec box; RegionRec reg; LLOGLN(10, ("in rdpClearToBackground")); g_pScreen->ClearToBackground = g_rdpScreen.ClearToBackground; g_pScreen->ClearToBackground(pWin, x, y, w, h, generateExposures); if (!generateExposures) { if (w > 0 && h > 0) { box.x1 = x; box.y1 = y; box.x2 = box.x1 + w; box.y2 = box.y1 + h; } else { box.x1 = pWin->drawable.x; box.y1 = pWin->drawable.y; box.x2 = box.x1 + pWin->drawable.width; box.y2 = box.y1 + pWin->drawable.height; } RegionInit(®, &box, 0); RegionIntersect(®, ®, &pWin->clipList); if (g_do_dirty_ons) { draw_item_add_img_region(&g_screenPriv, ®, GXcopy, RDI_IMGLY, 16); } else { rdpup_begin_update(); for (j = REGION_NUM_RECTS(®) - 1; j >= 0; j--) { box = REGION_RECTS(®)[j]; rdpup_send_area(0, box.x1, box.y1, box.x2 - box.x1, box.y2 - box.y1); } rdpup_end_update(); } RegionUninit(®); } g_pScreen->ClearToBackground = rdpClearToBackground; } /******************************************************************************/ RegionPtr rdpRestoreAreas(WindowPtr pWin, RegionPtr prgnExposed) { RegionRec reg; RegionPtr rv; int j; BoxRec box; LLOGLN(0, ("in rdpRestoreAreas")); RegionInit(®, NullBox, 0); RegionCopy(®, prgnExposed); g_pScreen->RestoreAreas = g_rdpScreen.RestoreAreas; rv = g_pScreen->RestoreAreas(pWin, prgnExposed); if (g_do_dirty_ons) { draw_item_add_img_region(&g_screenPriv, ®, GXcopy, RDI_IMGLY, 16); } else { rdpup_begin_update(); for (j = REGION_NUM_RECTS(®) - 1; j >= 0; j--) { box = REGION_RECTS(®)[j]; rdpup_send_area(0, box.x1, box.y1, box.x2 - box.x1, box.y2 - box.y1); } rdpup_end_update(); } RegionUninit(®); g_pScreen->RestoreAreas = rdpRestoreAreas; return rv; } /******************************************************************************/ void rdpInstallColormap(ColormapPtr pmap) { ColormapPtr oldpmap; oldpmap = g_rdpInstalledColormap; if (pmap != oldpmap) { if (oldpmap != (ColormapPtr)None) { WalkTree(pmap->pScreen, TellLostMap, (char *)&oldpmap->mid); } /* Install pmap */ g_rdpInstalledColormap = pmap; WalkTree(pmap->pScreen, TellGainedMap, (char *)&pmap->mid); /*rfbSetClientColourMaps(0, 0);*/ } /*g_rdpScreen.InstallColormap(pmap);*/ } /******************************************************************************/ void rdpUninstallColormap(ColormapPtr pmap) { ColormapPtr curpmap; curpmap = g_rdpInstalledColormap; if (pmap == curpmap) { if (pmap->mid != pmap->pScreen->defColormap) { //curpmap = (ColormapPtr)LookupIDByType(pmap->pScreen->defColormap, // RT_COLORMAP); //pmap->pScreen->InstallColormap(curpmap); } } } /******************************************************************************/ int rdpListInstalledColormaps(ScreenPtr pScreen, Colormap *pmaps) { *pmaps = g_rdpInstalledColormap->mid; return 1; } /******************************************************************************/ void rdpStoreColors(ColormapPtr pmap, int ndef, xColorItem *pdefs) { } /******************************************************************************/ Bool rdpSaveScreen(ScreenPtr pScreen, int on) { return 1; } xrdp-0.9.5/xorg/X11R7.6/rdp/rdpPushPixels.h000644 001751 001751 00000002070 13125122134 020070 0ustar00metameta000000 000000 /* Copyright 2005-2013 Jay Sorg Permission to use, copy, modify, distribute, and sell this software and its documentation for any purpose is hereby granted without fee, provided that the above copyright notice appear in all copies and that both that copyright notice and this permission notice appear in supporting documentation. The above copyright notice and this permission notice shall be included in all copies or substantial portions of the Software. THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE OPEN GROUP BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. */ #ifndef __RDPPUSHPIXELS_H #define __RDPPUSHPIXELS_H void rdpPushPixels(GCPtr pGC, PixmapPtr pBitMap, DrawablePtr pDst, int w, int h, int x, int y); #endif xrdp-0.9.5/xorg/X11R7.6/rdp/rdpFillPolygon.h000644 001751 001751 00000002123 13125122134 020221 0ustar00metameta000000 000000 /* Copyright 2005-2013 Jay Sorg Permission to use, copy, modify, distribute, and sell this software and its documentation for any purpose is hereby granted without fee, provided that the above copyright notice appear in all copies and that both that copyright notice and this permission notice appear in supporting documentation. The above copyright notice and this permission notice shall be included in all copies or substantial portions of the Software. THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE OPEN GROUP BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. */ #ifndef __RDPFILLPOLYGON_H #define __RDPFILLPOLYGON_H void rdpFillPolygon(DrawablePtr pDrawable, GCPtr pGC, int shape, int mode, int count, DDXPointPtr pPts); #endif xrdp-0.9.5/xorg/X11R7.6/rdp/rdpkeyboardbase.h000644 001751 001751 00000002072 13125122134 020421 0ustar00metameta000000 000000 /* Copyright 2013-2014 Jay Sorg Permission to use, copy, modify, distribute, and sell this software and its documentation for any purpose is hereby granted without fee, provided that the above copyright notice appear in all copies and that both that copyright notice and this permission notice appear in supporting documentation. The above copyright notice and this permission notice shall be included in all copies or substantial portions of the Software. THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE OPEN GROUP BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. keyboard map for base rules */ #ifndef _RDPKEYBOARDBASE_H #define _RDPKEYBOARDBASE_H void KbdAddEvent_base(int down, int param1, int param2, int param3, int param4); #endif xrdp-0.9.5/xorg/X11R7.6/rdp/Makefile000644 001751 001751 00000007121 13133557325 016564 0ustar00metameta000000 000000 # X11RDPBASE is the top-level X11rdp install directory ifeq ($(X11RDPBASE),) $(error X11RDPBASE needs to be set) endif BINBASE = $(X11RDPBASE)/bin INCBASE = $(X11RDPBASE)/include LIBBASE = $(X11RDPBASE)/lib INSTALL = /usr/bin/install -c XSRCBASE = ../build_dir/xorg-server-1.9.3 OBJS = rdpmain.o rdpdraw.o rdpinput.o rdpmisc.o rdpup.o rdprandr.o \ rdpCopyArea.o rdpPolyFillRect.o rdpPutImage.o rdpPolyRectangle.o \ rdpPolylines.o rdpPolySegment.o rdpFillSpans.o rdpSetSpans.o \ rdpCopyPlane.o rdpPolyPoint.o rdpPolyArc.o rdpFillPolygon.o \ rdpPolyFillArc.o rdpPolyText8.o rdpPolyText16.o \ rdpImageText8.o rdpImageText16.o rdpImageGlyphBlt.o rdpPolyGlyphBlt.o \ rdpPushPixels.o rdpxv.o rdpglyph.o rdpComposite.o \ rdpkeyboard.o rdpkeyboardevdev.o rdpkeyboardbase.o \ miinitext.o \ fbcmap_mi.o # in Xorg 7.1, fbcmap.c was used but now it looks like fbcmap_mi.c should # be used #fbcmap_mi.o #fbcmap.o LIBS = \ $(XSRCBASE)/dix/.libs/libmain.a \ librdp.a \ $(XSRCBASE)/dbe/.libs/libdbe.a \ $(XSRCBASE)/dix/.libs/libdix.a \ $(XSRCBASE)/fb/.libs/libfb.a \ $(XSRCBASE)/mi/.libs/libmi.a \ $(XSRCBASE)/randr/.libs/librandr.a \ $(XSRCBASE)/render/.libs/librender.a \ $(XSRCBASE)/os/.libs/libos.a \ $(XSRCBASE)/record/.libs/librecord.a \ $(XSRCBASE)/xkb/.libs/libxkb.a \ $(XSRCBASE)/Xext/.libs/libXext.a \ $(XSRCBASE)/Xi/.libs/libXi.a \ $(XSRCBASE)/glx/.libs/libglx.a \ $(XSRCBASE)/xfixes/.libs/libxfixes.a \ $(XSRCBASE)/damageext/.libs/libdamageext.a \ $(XSRCBASE)/miext/damage/.libs/libdamage.a LLIBS = -Wl,-rpath=$(LIBBASE) -lfreetype -lz -lm -lXfont -lXau \ -lXdmcp -lpixman-1 -lrt -ldl -lcrypto -lGL -lXdamage CFLAGS = -g -O2 -Wall -fno-strength-reduce \ -I$(INCBASE) \ -I$(INCBASE)/X11 \ -I$(INCBASE)/X11/fonts \ -I$(INCBASE)/X11/extensions \ -I$(INCBASE)/xorg \ -I$(INCBASE)/pixman-1 \ -I../../../common \ -D_POSIX_C_SOURCE=199309L -D_SVID_SOURCE -D_REENTRANT \ -DGLX_USE_MESA -DXRECORD -D_GNU_SOURCE -DXAPPGROUP \ -DTOGCUP -DSINGLEDEPTH -DXFree86Server \ -DDBE -DEVI -DXVMC -DFONTCACHE -DGCCUSESGAS -DSTATIC_COLOR \ -DAVOID_GLYPHBLT -DFUNCPROTO=15 -DNARROWPROTO -DDDXOSFATALERROR \ -DPART_NET -DDDXTIME -D_HAVE_XALLOC_DECLS \ -DDAMAGE \ -DXFIXES \ -DSMART_SCHEDULE -DSERVER_LOCK -DGLXEXT -DSHAPE -DRENDER -DRANDR \ -DBIGREQS -D_POSIX_SOURCE -D_BSD_SOURCE -DSCREENSAVER \ -DXCMISC -DXTEST -DXTRAP -DXV -DXSYNC -DMITMISC -DPANORAMIX \ -DDPMSExtension -DXvExtension -DXvMCExtension -DXResExtension \ -DMITSHM -DPIXPRIV -DNDEBUG -DDDXOSINIT -DXKB -DXINPUT #-DDAMAGE # -pedantic # -DXCSECURITY -DXF86BIGFONT # these are defined in xorg-server.h # -D_XOPEN_SOURCE=500L # -DX_BYTE_ORDER=X_LITTLE_ENDIAN # -DSMART_SCHEDULE -DSERVER_LOCK -DGLXEXT -DSHAPE -DRENDER -DRANDR # -DBIGREQS -D_POSIX_SOURCE -D_BSD_SOURCE -DSCREENSAVER -DXF86BIGFONT # -DXCMISC -DXTEST -DXTRAP -DXV -DXSYNC -DMITMISC -DPANORAMIX # -DDPMSExtension -DXvExtension -DXvMCExtension -DXResExtension # -DMITSHM -DPIXPRIV -DNDEBUG -DDDXOSINIT # these are not needed I think # -Dlinux -D__i386__ LDFLAGS = -L$(LIBBASE) -Wl,-rpath,$(LIBBASE) all: X11rdp X11rdp: $(OBJS) $(AR) rvu librdp.a $(OBJS) ranlib librdp.a $(CC) $(LDFLAGS) -o X11rdp $(LIBS) $(LLIBS) clean: rm -f $(OBJS) librdp.a miinitext.o: ../build_dir/xorg-server-1.9.3/mi/miinitext.c Makefile $(CC) $(CFLAGS) -I../build_dir/xorg-server-1.9.3/Xext -c ../build_dir/xorg-server-1.9.3/mi/miinitext.c fbcmap.o: ../build_dir/xorg-server-1.9.3/fb/fbcmap.c $(CC) $(CFLAGS) -c ../build_dir/xorg-server-1.9.3/fb/fbcmap.c fbcmap_mi.o: ../build_dir/xorg-server-1.9.3/fb/fbcmap_mi.c $(CC) $(CFLAGS) -c ../build_dir/xorg-server-1.9.3/fb/fbcmap_mi.c install: all $(INSTALL) X11rdp $(BINBASE)/X11rdp xrdp-0.9.5/xorg/X11R7.6/rdp/rdpPolyPoint.h000644 001751 001751 00000002061 13125122134 017721 0ustar00metameta000000 000000 /* Copyright 2005-2013 Jay Sorg Permission to use, copy, modify, distribute, and sell this software and its documentation for any purpose is hereby granted without fee, provided that the above copyright notice appear in all copies and that both that copyright notice and this permission notice appear in supporting documentation. The above copyright notice and this permission notice shall be included in all copies or substantial portions of the Software. THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE OPEN GROUP BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. */ #ifndef __RDPPOLYPOINT_H #define __RDPPOLYPOINT_H void rdpPolyPoint(DrawablePtr pDrawable, GCPtr pGC, int mode, int npt, DDXPointPtr in_pts); #endif xrdp-0.9.5/xorg/X11R7.6/rdp/rdpFillSpans.c000644 001751 001751 00000006616 13125122134 017664 0ustar00metameta000000 000000 /* Copyright 2005-2013 Jay Sorg Permission to use, copy, modify, distribute, and sell this software and its documentation for any purpose is hereby granted without fee, provided that the above copyright notice appear in all copies and that both that copyright notice and this permission notice appear in supporting documentation. The above copyright notice and this permission notice shall be included in all copies or substantial portions of the Software. THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE OPEN GROUP BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. */ #include "rdp.h" #include "rdpdraw.h" #define LDEBUG 0 #define LOG_LEVEL 1 #define LLOG(_level, _args) \ do { if (_level < LOG_LEVEL) { ErrorF _args ; } } while (0) #define LLOGLN(_level, _args) \ do { if (_level < LOG_LEVEL) { ErrorF _args ; ErrorF("\n"); } } while (0) extern rdpScreenInfoRec g_rdpScreen; /* from rdpmain.c */ extern DevPrivateKeyRec g_rdpGCIndex; /* from rdpmain.c */ extern DevPrivateKeyRec g_rdpWindowIndex; /* from rdpmain.c */ extern DevPrivateKeyRec g_rdpPixmapIndex; /* from rdpmain.c */ extern int g_Bpp; /* from rdpmain.c */ extern ScreenPtr g_pScreen; /* from rdpmain.c */ extern Bool g_wrapPixmap; /* from rdpmain.c */ extern GCOps g_rdpGCOps; /* from rdpdraw.c */ extern int g_con_number; /* in rdpup.c */ /******************************************************************************/ static void rdpFillSpansOrg(DrawablePtr pDrawable, GCPtr pGC, int nInit, DDXPointPtr pptInit, int *pwidthInit, int fSorted) { rdpGCPtr priv; GCFuncs *oldFuncs; GC_OP_PROLOGUE(pGC); pGC->ops->FillSpans(pDrawable, pGC, nInit, pptInit, pwidthInit, fSorted); GC_OP_EPILOGUE(pGC); } /******************************************************************************/ void rdpFillSpans(DrawablePtr pDrawable, GCPtr pGC, int nInit, DDXPointPtr pptInit, int *pwidthInit, int fSorted) { RegionRec clip_reg; int cd; int got_id; struct image_data id; WindowPtr pDstWnd; PixmapPtr pDstPixmap; rdpPixmapRec *pDstPriv; LLOGLN(0, ("rdpFillSpans: todo")); /* do original call */ rdpFillSpansOrg(pDrawable, pGC, nInit, pptInit, pwidthInit, fSorted); got_id = 0; if (pDrawable->type == DRAWABLE_PIXMAP) { pDstPixmap = (PixmapPtr)pDrawable; pDstPriv = GETPIXPRIV(pDstPixmap); if (xrdp_is_os(pDstPixmap, pDstPriv)) { rdpup_switch_os_surface(pDstPriv->rdpindex); rdpup_get_pixmap_image_rect(pDstPixmap, &id); got_id = 1; } } else { if (pDrawable->type == DRAWABLE_WINDOW) { pDstWnd = (WindowPtr)pDrawable; if (pDstWnd->viewable) { rdpup_get_screen_image_rect(&id); got_id = 1; } } } if (!got_id) { return; } RegionInit(&clip_reg, NullBox, 0); cd = rdp_get_clip(&clip_reg, pDrawable, pGC); if (cd == 1) { } else if (cd == 2) { } RegionUninit(&clip_reg); rdpup_switch_os_surface(-1); } xrdp-0.9.5/xorg/X11R7.6/rdp/rdpPolyText16.c000644 001751 001751 00000013456 13125122134 017730 0ustar00metameta000000 000000 /* Copyright 2005-2013 Jay Sorg Permission to use, copy, modify, distribute, and sell this software and its documentation for any purpose is hereby granted without fee, provided that the above copyright notice appear in all copies and that both that copyright notice and this permission notice appear in supporting documentation. The above copyright notice and this permission notice shall be included in all copies or substantial portions of the Software. THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE OPEN GROUP BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. */ #include "rdp.h" #include "rdpdraw.h" #define LDEBUG 0 #define LOG_LEVEL 1 #define LLOG(_level, _args) \ do { if (_level < LOG_LEVEL) { ErrorF _args ; } } while (0) #define LLOGLN(_level, _args) \ do { if (_level < LOG_LEVEL) { ErrorF _args ; ErrorF("\n"); } } while (0) extern rdpScreenInfoRec g_rdpScreen; /* from rdpmain.c */ extern DevPrivateKeyRec g_rdpGCIndex; /* from rdpmain.c */ extern DevPrivateKeyRec g_rdpWindowIndex; /* from rdpmain.c */ extern DevPrivateKeyRec g_rdpPixmapIndex; /* from rdpmain.c */ extern int g_Bpp; /* from rdpmain.c */ extern ScreenPtr g_pScreen; /* from rdpmain.c */ extern Bool g_wrapPixmap; /* from rdpmain.c */ extern int g_do_dirty_os; /* in rdpmain.c */ extern int g_do_dirty_ons; /* in rdpmain.c */ extern rdpPixmapRec g_screenPriv; /* in rdpmain.c */ extern GCOps g_rdpGCOps; /* from rdpdraw.c */ extern int g_con_number; /* in rdpup.c */ /******************************************************************************/ int rdpPolyText16Org(DrawablePtr pDrawable, GCPtr pGC, int x, int y, int count, unsigned short *chars) { int rv; rdpGCPtr priv; GCFuncs *oldFuncs; GC_OP_PROLOGUE(pGC); rv = pGC->ops->PolyText16(pDrawable, pGC, x, y, count, chars); GC_OP_EPILOGUE(pGC); return rv; } /******************************************************************************/ int rdpPolyText16(DrawablePtr pDrawable, GCPtr pGC, int x, int y, int count, unsigned short *chars) { RegionRec reg; RegionRec reg1; int num_clips; int cd; int j; int rv; int got_id; int dirty_type; int post_process; int reset_surface; BoxRec box; struct image_data id; WindowPtr pDstWnd; PixmapPtr pDstPixmap; rdpPixmapRec *pDstPriv; rdpPixmapRec *pDirtyPriv; LLOGLN(10, ("rdpPolyText16:")); if (count != 0) { GetTextBoundingBox(pDrawable, pGC->font, x, y, count, &box); } /* do original call */ rv = rdpPolyText16Org(pDrawable, pGC, x, y, count, chars); dirty_type = 0; pDirtyPriv = 0; post_process = 0; reset_surface = 0; got_id = 0; if (pDrawable->type == DRAWABLE_PIXMAP) { pDstPixmap = (PixmapPtr)pDrawable; pDstPriv = GETPIXPRIV(pDstPixmap); if (xrdp_is_os(pDstPixmap, pDstPriv)) { post_process = 1; if (g_do_dirty_os) { LLOGLN(10, ("rdpPolyText16: getting dirty")); pDstPriv->is_dirty = 1; pDirtyPriv = pDstPriv; dirty_type = RDI_IMGLY; } else { rdpup_switch_os_surface(pDstPriv->rdpindex); reset_surface = 1; rdpup_get_pixmap_image_rect(pDstPixmap, &id); got_id = 1; } } } else { if (pDrawable->type == DRAWABLE_WINDOW) { pDstWnd = (WindowPtr)pDrawable; if (pDstWnd->viewable) { post_process = 1; if (g_do_dirty_ons) { LLOGLN(10, ("rdpPolyText16: getting dirty")); g_screenPriv.is_dirty = 1; pDirtyPriv = &g_screenPriv; dirty_type = RDI_IMGLL; } else { rdpup_get_screen_image_rect(&id); got_id = 1; } } } } if (!post_process) { return rv; } RegionInit(®, NullBox, 0); if (count == 0) { cd = 0; } else { cd = rdp_get_clip(®, pDrawable, pGC); } if (cd == 1) { if (dirty_type != 0) { RegionInit(®1, &box, 0); draw_item_add_img_region(pDirtyPriv, ®1, GXcopy, dirty_type, TAG_POLYTEXT16); RegionUninit(®1); } else if (got_id) { rdpup_begin_update(); rdpup_send_area(&id, box.x1, box.y1, box.x2 - box.x1, box.y2 - box.y1); rdpup_end_update(); } } else if (cd == 2) { RegionInit(®1, &box, 0); RegionIntersect(®, ®, ®1); num_clips = REGION_NUM_RECTS(®); if (num_clips > 0) { if (dirty_type != 0) { draw_item_add_img_region(pDirtyPriv, ®, GXcopy, dirty_type, TAG_POLYTEXT16); } else if (got_id) { rdpup_begin_update(); for (j = num_clips - 1; j >= 0; j--) { box = REGION_RECTS(®)[j]; rdpup_send_area(&id, box.x1, box.y1, box.x2 - box.x1, box.y2 - box.y1); } rdpup_end_update(); } } RegionUninit(®1); } RegionUninit(®); if (reset_surface) { rdpup_switch_os_surface(-1); } return rv; } xrdp-0.9.5/xorg/X11R7.6/rdp/rdpImageGlyphBlt.c000644 001751 001751 00000013616 13125122134 020457 0ustar00metameta000000 000000 /* Copyright 2005-2013 Jay Sorg Permission to use, copy, modify, distribute, and sell this software and its documentation for any purpose is hereby granted without fee, provided that the above copyright notice appear in all copies and that both that copyright notice and this permission notice appear in supporting documentation. The above copyright notice and this permission notice shall be included in all copies or substantial portions of the Software. THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE OPEN GROUP BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. */ #include "rdp.h" #include "rdpdraw.h" #define LDEBUG 0 #define LOG_LEVEL 1 #define LLOG(_level, _args) \ do { if (_level < LOG_LEVEL) { ErrorF _args ; } } while (0) #define LLOGLN(_level, _args) \ do { if (_level < LOG_LEVEL) { ErrorF _args ; ErrorF("\n"); } } while (0) extern rdpScreenInfoRec g_rdpScreen; /* from rdpmain.c */ extern DevPrivateKeyRec g_rdpGCIndex; /* from rdpmain.c */ extern DevPrivateKeyRec g_rdpWindowIndex; /* from rdpmain.c */ extern DevPrivateKeyRec g_rdpPixmapIndex; /* from rdpmain.c */ extern int g_Bpp; /* from rdpmain.c */ extern ScreenPtr g_pScreen; /* from rdpmain.c */ extern Bool g_wrapPixmap; /* from rdpmain.c */ extern int g_do_dirty_os; /* in rdpmain.c */ extern int g_do_dirty_ons; /* in rdpmain.c */ extern rdpPixmapRec g_screenPriv; /* in rdpmain.c */ extern GCOps g_rdpGCOps; /* from rdpdraw.c */ extern int g_con_number; /* in rdpup.c */ /******************************************************************************/ void rdpImageGlyphBltOrg(DrawablePtr pDrawable, GCPtr pGC, int x, int y, unsigned int nglyph, CharInfoPtr *ppci, pointer pglyphBase) { rdpGCPtr priv; GCFuncs *oldFuncs; GC_OP_PROLOGUE(pGC); pGC->ops->ImageGlyphBlt(pDrawable, pGC, x, y, nglyph, ppci, pglyphBase); GC_OP_EPILOGUE(pGC); } /******************************************************************************/ void rdpImageGlyphBlt(DrawablePtr pDrawable, GCPtr pGC, int x, int y, unsigned int nglyph, CharInfoPtr *ppci, pointer pglyphBase) { RegionRec reg; RegionRec reg1; int num_clips; int cd; int j; int got_id; int dirty_type; int post_process; int reset_surface; BoxRec box; struct image_data id; WindowPtr pDstWnd; PixmapPtr pDstPixmap; rdpPixmapRec *pDstPriv; rdpPixmapRec *pDirtyPriv; LLOGLN(10, ("rdpImageGlyphBlt:")); if (nglyph != 0) { GetTextBoundingBox(pDrawable, pGC->font, x, y, nglyph, &box); } /* do original call */ rdpImageGlyphBltOrg(pDrawable, pGC, x, y, nglyph, ppci, pglyphBase); dirty_type = 0; pDirtyPriv = 0; post_process = 0; reset_surface = 0; got_id = 0; if (pDrawable->type == DRAWABLE_PIXMAP) { pDstPixmap = (PixmapPtr)pDrawable; pDstPriv = GETPIXPRIV(pDstPixmap); if (xrdp_is_os(pDstPixmap, pDstPriv)) { post_process = 1; if (g_do_dirty_os) { LLOGLN(10, ("rdpImageGlyphBlt: getting dirty")); pDstPriv->is_dirty = 1; pDirtyPriv = pDstPriv; dirty_type = RDI_IMGLL; } else { rdpup_switch_os_surface(pDstPriv->rdpindex); reset_surface = 1; rdpup_get_pixmap_image_rect(pDstPixmap, &id); got_id = 1; } } } else { if (pDrawable->type == DRAWABLE_WINDOW) { pDstWnd = (WindowPtr)pDrawable; if (pDstWnd->viewable) { post_process = 1; if (g_do_dirty_ons) { LLOGLN(10, ("rdpImageGlyphBlt: getting dirty")); g_screenPriv.is_dirty = 1; pDirtyPriv = &g_screenPriv; dirty_type = RDI_IMGLL; } else { rdpup_get_screen_image_rect(&id); got_id = 1; } } } } if (!post_process) { return; } RegionInit(®, NullBox, 0); if (nglyph == 0) { cd = 0; } else { cd = rdp_get_clip(®, pDrawable, pGC); } if (cd == 1) { if (dirty_type != 0) { RegionInit(®1, &box, 0); draw_item_add_img_region(pDirtyPriv, ®1, GXcopy, dirty_type, TAG_IMAGEGLYPHBLT); RegionUninit(®1); } else if (got_id) { rdpup_begin_update(); rdpup_send_area(&id, box.x1, box.y1, box.x2 - box.x1, box.y2 - box.y1); rdpup_end_update(); } } else if (cd == 2) { RegionInit(®1, &box, 0); RegionIntersect(®, ®, ®1); num_clips = REGION_NUM_RECTS(®); if (num_clips > 0) { if (dirty_type != 0) { draw_item_add_img_region(pDirtyPriv, ®, GXcopy, dirty_type, TAG_IMAGEGLYPHBLT); } else if (got_id) { rdpup_begin_update(); for (j = num_clips - 1; j >= 0; j--) { box = REGION_RECTS(®)[j]; rdpup_send_area(&id, box.x1, box.y1, box.x2 - box.x1, box.y2 - box.y1); } rdpup_end_update(); } } RegionUninit(®1); } RegionUninit(®); if (reset_surface) { rdpup_switch_os_surface(-1); } return; } xrdp-0.9.5/xorg/X11R7.6/rdp/rdpkeyboard.h000644 001751 001751 00000004543 13125122134 017573 0ustar00metameta000000 000000 /* Copyright 2013-2014 Jay Sorg Permission to use, copy, modify, distribute, and sell this software and its documentation for any purpose is hereby granted without fee, provided that the above copyright notice appear in all copies and that both that copyright notice and this permission notice appear in supporting documentation. The above copyright notice and this permission notice shall be included in all copies or substantial portions of the Software. THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE OPEN GROUP BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. keyboard map for base rules */ #ifndef _RDPKEYBOARD_H #define _RDPKEYBOARD_H #define MIN_KEY_CODE 8 #define MAX_KEY_CODE 255 #define NO_OF_KEYS ((MAX_KEY_CODE - MIN_KEY_CODE) + 1) #define GLYPHS_PER_KEY 2 #define RDPSCAN_Tab 15 #define RDPSCAN_Return 28 /* ext is used to know KP or not */ #define RDPSCAN_Control 29 /* ext is used to know L or R */ #define RDPSCAN_Shift_L 42 #define RDPSCAN_Slash 53 #define RDPSCAN_Shift_R 54 #define RDPSCAN_KP_Multiply 55 #define RDPSCAN_Alt 56 /* ext is used to know L or R */ #define RDPSCAN_Caps_Lock 58 #define RDPSCAN_Pause 69 #define RDPSCAN_Scroll_Lock 70 #define RDPSCAN_KP_7 71 /* KP7 or home */ #define RDPSCAN_KP_8 72 /* KP8 or up */ #define RDPSCAN_KP_9 73 /* KP9 or page up */ #define RDPSCAN_KP_4 75 /* KP4 or left */ #define RDPSCAN_KP_6 77 /* KP6 or right */ #define RDPSCAN_KP_1 79 /* KP1 or home */ #define RDPSCAN_KP_2 80 /* KP2 or up */ #define RDPSCAN_KP_3 81 /* KP3 or page down */ #define RDPSCAN_KP_0 82 /* KP0 or insert */ #define RDPSCAN_KP_Decimal 83 /* KP. or delete */ #define RDPSCAN_89 89 #define RDPSCAN_90 90 #define RDPSCAN_LWin 91 #define RDPSCAN_RWin 92 #define RDPSCAN_Menu 93 #define RDPSCAN_115 115 #define RDPSCAN_126 126 void rdpEnqueueKey(int type, int scancode); void check_keysa(void); void sendDownUpKeyEvent(int type, int x_scancode); #endif xrdp-0.9.5/xorg/X11R7.6/rdp/rdpPutImage.c000644 001751 001751 00000014267 13125122134 017505 0ustar00metameta000000 000000 /* Copyright 2005-2013 Jay Sorg Permission to use, copy, modify, distribute, and sell this software and its documentation for any purpose is hereby granted without fee, provided that the above copyright notice appear in all copies and that both that copyright notice and this permission notice appear in supporting documentation. The above copyright notice and this permission notice shall be included in all copies or substantial portions of the Software. THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE OPEN GROUP BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. */ #include "rdp.h" #include "rdpdraw.h" #define LDEBUG 0 #define LOG_LEVEL 1 #define LLOG(_level, _args) \ do { if (_level < LOG_LEVEL) { ErrorF _args ; } } while (0) #define LLOGLN(_level, _args) \ do { if (_level < LOG_LEVEL) { ErrorF _args ; ErrorF("\n"); } } while (0) extern rdpScreenInfoRec g_rdpScreen; /* from rdpmain.c */ extern DevPrivateKeyRec g_rdpGCIndex; /* from rdpmain.c */ extern DevPrivateKeyRec g_rdpWindowIndex; /* from rdpmain.c */ extern DevPrivateKeyRec g_rdpPixmapIndex; /* from rdpmain.c */ extern int g_Bpp; /* from rdpmain.c */ extern ScreenPtr g_pScreen; /* from rdpmain.c */ extern Bool g_wrapPixmap; /* from rdpmain.c */ extern int g_do_dirty_os; /* in rdpmain.c */ extern int g_do_dirty_ons; /* in rdpmain.c */ extern rdpPixmapRec g_screenPriv; /* in rdpmain.c */ extern GCOps g_rdpGCOps; /* from rdpdraw.c */ extern int g_con_number; /* in rdpup.c */ /******************************************************************************/ static void rdpPutImageOrg(DrawablePtr pDst, GCPtr pGC, int depth, int x, int y, int w, int h, int leftPad, int format, char *pBits) { rdpGCPtr priv; GCFuncs *oldFuncs; GC_OP_PROLOGUE(pGC); pGC->ops->PutImage(pDst, pGC, depth, x, y, w, h, leftPad, format, pBits); GC_OP_EPILOGUE(pGC); } /******************************************************************************/ void rdpPutImage(DrawablePtr pDst, GCPtr pGC, int depth, int x, int y, int w, int h, int leftPad, int format, char *pBits) { RegionRec clip_reg; int cd; int j; int reset_surface; int post_process; int got_id; int dirty_type; BoxRec box; struct image_data id; WindowPtr pDstWnd; PixmapPtr pDstPixmap; rdpPixmapRec *pDstPriv; rdpPixmapRec *pDirtyPriv; RegionRec reg1; RegionRec reg2; LLOGLN(10, ("rdpPutImage:")); LLOGLN(10, ("rdpPutImage: drawable id 0x%x", (int)(pDst->id))); LLOGLN(10, ("rdpPutImage: x %d y %d w %d h %d is_window %d", x, y, w, h, pDst->type == DRAWABLE_WINDOW)); /* do original call */ rdpPutImageOrg(pDst, pGC, depth, x, y, w, h, leftPad, format, pBits); dirty_type = 0; pDirtyPriv = 0; post_process = 0; reset_surface = 0; got_id = 0; if (pDst->type == DRAWABLE_PIXMAP) { pDstPixmap = (PixmapPtr)pDst; pDstPriv = GETPIXPRIV(pDstPixmap); if (xrdp_is_os(pDstPixmap, pDstPriv)) { post_process = 1; if (g_do_dirty_os) { LLOGLN(10, ("rdpPutImage: getting dirty")); pDstPriv->is_dirty = 1; pDirtyPriv = pDstPriv; dirty_type = RDI_IMGLY; } else { rdpup_switch_os_surface(pDstPriv->rdpindex); reset_surface = 1; rdpup_get_pixmap_image_rect(pDstPixmap, &id); got_id = 1; } } } else { if (pDst->type == DRAWABLE_WINDOW) { pDstWnd = (WindowPtr)pDst; if (pDstWnd->viewable) { post_process = 1; if (g_do_dirty_ons) { LLOGLN(10, ("rdpPutImage: getting dirty")); g_screenPriv.is_dirty = 1; pDirtyPriv = &g_screenPriv; dirty_type = RDI_IMGLY; } else { rdpup_get_screen_image_rect(&id); got_id = 1; } } } } if (!post_process) { return; } RegionInit(&clip_reg, NullBox, 0); cd = rdp_get_clip(&clip_reg, pDst, pGC); if (cd == 1) { if (dirty_type != 0) { box.x1 = pDst->x + x; box.y1 = pDst->y + y; box.x2 = box.x1 + w; box.y2 = box.y1 + h; RegionInit(®1, &box, 0); draw_item_add_img_region(pDirtyPriv, ®1, GXcopy, dirty_type, TAG_PUTIMAGE); RegionUninit(®1); } else if (got_id) { rdpup_begin_update(); rdpup_send_area(&id, pDst->x + x, pDst->y + y, w, h); rdpup_end_update(); } } else if (cd == 2) { if (dirty_type != 0) { box.x1 = pDst->x + x; box.y1 = pDst->y + y; box.x2 = box.x1 + w; box.y2 = box.y1 + h; RegionInit(®1, &box, 0); RegionInit(®2, NullBox, 0); RegionCopy(®2, &clip_reg); RegionIntersect(®1, ®1, ®2); draw_item_add_img_region(pDirtyPriv, ®1, GXcopy, dirty_type, TAG_PUTIMAGE); RegionUninit(®1); RegionUninit(®2); } else if (got_id) { rdpup_begin_update(); for (j = REGION_NUM_RECTS(&clip_reg) - 1; j >= 0; j--) { box = REGION_RECTS(&clip_reg)[j]; rdpup_set_clip(box.x1, box.y1, (box.x2 - box.x1), (box.y2 - box.y1)); rdpup_send_area(&id, pDst->x + x, pDst->y + y, w, h); } rdpup_reset_clip(); rdpup_end_update(); } } RegionUninit(&clip_reg); if (reset_surface) { rdpup_switch_os_surface(-1); } } xrdp-0.9.5/xorg/X11R7.6/rdp/rdpImageText16.h000644 001751 001751 00000002102 13125122134 020016 0ustar00metameta000000 000000 /* Copyright 2005-2013 Jay Sorg Permission to use, copy, modify, distribute, and sell this software and its documentation for any purpose is hereby granted without fee, provided that the above copyright notice appear in all copies and that both that copyright notice and this permission notice appear in supporting documentation. The above copyright notice and this permission notice shall be included in all copies or substantial portions of the Software. THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE OPEN GROUP BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. */ #ifndef __RDPIMAGETEXT16_H #define __RDPIMAGETEXT16_H void rdpImageText16(DrawablePtr pDrawable, GCPtr pGC, int x, int y, int count, unsigned short* chars); #endif xrdp-0.9.5/xorg/X11R7.6/rdp/rdpCopyArea.c000644 001751 001751 00000046315 13125122134 017474 0ustar00metameta000000 000000 /* Copyright 2005-2013 Jay Sorg Permission to use, copy, modify, distribute, and sell this software and its documentation for any purpose is hereby granted without fee, provided that the above copyright notice appear in all copies and that both that copyright notice and this permission notice appear in supporting documentation. The above copyright notice and this permission notice shall be included in all copies or substantial portions of the Software. THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE OPEN GROUP BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. */ #include "rdp.h" #include "rdpdraw.h" #define LDEBUG 0 #define LOG_LEVEL 1 #define LLOG(_level, _args) \ do { if (_level < LOG_LEVEL) { ErrorF _args ; } } while (0) #define LLOGLN(_level, _args) \ do { if (_level < LOG_LEVEL) { ErrorF _args ; ErrorF("\n"); } } while (0) extern rdpScreenInfoRec g_rdpScreen; /* from rdpmain.c */ extern DevPrivateKeyRec g_rdpGCIndex; /* from rdpmain.c */ extern DevPrivateKeyRec g_rdpWindowIndex; /* from rdpmain.c */ extern DevPrivateKeyRec g_rdpPixmapIndex; /* from rdpmain.c */ extern int g_Bpp; /* from rdpmain.c */ extern ScreenPtr g_pScreen; /* from rdpmain.c */ extern Bool g_wrapPixmap; /* from rdpmain.c */ extern int g_can_do_pix_to_pix; /* from rdpmain.c */ extern int g_do_dirty_os; /* in rdpmain.c */ extern int g_do_dirty_ons; /* in rdpmain.c */ extern rdpPixmapRec g_screenPriv; /* in rdpmain.c */ extern GCOps g_rdpGCOps; /* from rdpdraw.c */ extern int g_con_number; /* in rdpup.c */ /******************************************************************************/ static RegionPtr rdpCopyAreaOrg(DrawablePtr pSrc, DrawablePtr pDst, GCPtr pGC, int srcx, int srcy, int w, int h, int dstx, int dsty) { rdpGCPtr priv; GCFuncs *oldFuncs; RegionPtr rv; GC_OP_PROLOGUE(pGC); rv = pGC->ops->CopyArea(pSrc, pDst, pGC, srcx, srcy, w, h, dstx, dsty); GC_OP_EPILOGUE(pGC); return rv; } /******************************************************************************/ static RegionPtr rdpCopyAreaWndToWnd(WindowPtr pSrcWnd, WindowPtr pDstWnd, GCPtr pGC, int srcx, int srcy, int w, int h, int dstx, int dsty) { int cd; int lsrcx; int lsrcy; int ldstx; int ldsty; int num_clips; int dx; int dy; int j; BoxRec box; RegionPtr rv; RegionRec clip_reg; LLOGLN(10, ("rdpCopyAreaWndToWnd:")); RegionInit(&clip_reg, NullBox, 0); cd = rdp_get_clip(&clip_reg, &(pDstWnd->drawable), pGC); lsrcx = pSrcWnd->drawable.x + srcx; lsrcy = pSrcWnd->drawable.y + srcy; ldstx = pDstWnd->drawable.x + dstx; ldsty = pDstWnd->drawable.y + dsty; if (cd == 1) { rdpup_begin_update(); rdpup_screen_blt(ldstx, ldsty, w, h, lsrcx, lsrcy); rdpup_end_update(); } else if (cd == 2) { num_clips = REGION_NUM_RECTS(&clip_reg); if (num_clips > 0) { rdpup_begin_update(); dx = ldstx - lsrcx; dy = ldsty - lsrcy; if ((dy < 0) || ((dy == 0) && (dx < 0))) { for (j = 0; j < num_clips; j++) { box = REGION_RECTS(&clip_reg)[j]; LLOGLN(10, (" index %d x1 %d y1 %d x2 %d y2 %d", j, box.x1, box.y1, box.x2, box.y2)); rdpup_set_clip(box.x1, box.y1, box.x2 - box.x1, box.y2 - box.y1); rdpup_screen_blt(ldstx, ldsty, w, h, lsrcx, lsrcy); } } else { for (j = num_clips - 1; j >= 0; j--) { box = REGION_RECTS(&clip_reg)[j]; LLOGLN(10, (" index %d x1 %d y1 %d x2 %d y2 %d", j, box.x1, box.y1, box.x2, box.y2)); rdpup_set_clip(box.x1, box.y1, box.x2 - box.x1, box.y2 - box.y1); rdpup_screen_blt(ldstx, ldsty, w, h, lsrcx, lsrcy); } } rdpup_reset_clip(); rdpup_end_update(); } } RegionUninit(&clip_reg); rv = rdpCopyAreaOrg(&(pSrcWnd->drawable), &(pDstWnd->drawable), pGC, srcx, srcy, w, h, dstx, dsty); return rv; } /******************************************************************************/ static RegionPtr rdpCopyAreaWndToPixmap(WindowPtr pSrcWnd, PixmapPtr pDstPixmap, rdpPixmapRec *pDstPriv, GCPtr pGC, int srcx, int srcy, int w, int h, int dstx, int dsty) { int cd; int lsrcx; int lsrcy; int ldstx; int ldsty; int num_clips; int j; BoxRec box; RegionPtr rv; RegionRec clip_reg; LLOGLN(10, ("rdpCopyAreaWndToPixmap:")); RegionInit(&clip_reg, NullBox, 0); cd = rdp_get_clip(&clip_reg, &(pDstPixmap->drawable), pGC); lsrcx = pSrcWnd->drawable.x + srcx; lsrcy = pSrcWnd->drawable.y + srcy; ldstx = pDstPixmap->drawable.x + dstx; ldsty = pDstPixmap->drawable.y + dsty; if (cd == 1) { rdpup_switch_os_surface(pDstPriv->rdpindex); rdpup_begin_update(); rdpup_screen_blt(ldstx, ldsty, w, h, lsrcx, lsrcy); rdpup_end_update(); rdpup_switch_os_surface(-1); } else if (cd == 2) { num_clips = REGION_NUM_RECTS(&clip_reg); if (num_clips > 0) { rdpup_switch_os_surface(pDstPriv->rdpindex); rdpup_begin_update(); for (j = 0; j < num_clips; j++) { box = REGION_RECTS(&clip_reg)[j]; rdpup_set_clip(box.x1, box.y1, box.x2 - box.x1, box.y2 - box.y1); rdpup_screen_blt(ldstx, ldsty, w, h, lsrcx, lsrcy); } rdpup_reset_clip(); rdpup_end_update(); rdpup_switch_os_surface(-1); } } RegionUninit(&clip_reg); rv = rdpCopyAreaOrg(&(pSrcWnd->drawable), &(pDstPixmap->drawable), pGC, srcx, srcy, w, h, dstx, dsty); return rv; } /******************************************************************************/ /* draw from an off screen pixmap to a visible window */ static RegionPtr rdpCopyAreaPixmapToWnd(PixmapPtr pSrcPixmap, rdpPixmapRec *pSrcPriv, WindowPtr pDstWnd, GCPtr pGC, int srcx, int srcy, int w, int h, int dstx, int dsty) { int lsrcx; int lsrcy; int ldstx; int ldsty; int cd; int j; int num_clips; RegionPtr rv; RegionRec clip_reg; BoxRec box; LLOGLN(10, ("rdpCopyAreaPixmapToWnd:")); RegionInit(&clip_reg, NullBox, 0); cd = rdp_get_clip(&clip_reg, &(pDstWnd->drawable), pGC); ldstx = pDstWnd->drawable.x + dstx; ldsty = pDstWnd->drawable.y + dsty; lsrcx = pSrcPixmap->drawable.x + srcx; lsrcy = pSrcPixmap->drawable.y + srcy; if (cd == 1) { rdpup_begin_update(); rdpup_paint_rect_os(ldstx, ldsty, w, h, pSrcPriv->rdpindex, lsrcx, lsrcy); rdpup_end_update(); } else if (cd == 2) { num_clips = REGION_NUM_RECTS(&clip_reg); if (num_clips > 0) { rdpup_begin_update(); LLOGLN(10, ("rdpCopyAreaPixmapToWnd: num_clips %d", num_clips)); for (j = 0; j < num_clips; j++) { box = REGION_RECTS(&clip_reg)[j]; LLOGLN(10, ("rdpCopyAreaPixmapToWnd: %d %d %d %d", box.x1, box.y1, box.x2, box.y2)); rdpup_set_clip(box.x1, box.y1, box.x2 - box.x1, box.y2 - box.y1); LLOGLN(10, ("rdpCopyAreaPixmapToWnd: %d %d", w, h)); rdpup_paint_rect_os(ldstx, ldsty, w, h, pSrcPriv->rdpindex, lsrcx, lsrcy); } rdpup_reset_clip(); rdpup_end_update(); } } RegionUninit(&clip_reg); rv = rdpCopyAreaOrg(&(pSrcPixmap->drawable), &(pDstWnd->drawable), pGC, srcx, srcy, w, h, dstx, dsty); return rv; } /******************************************************************************/ /* draw from an off screen pixmap to an off screen pixmap */ static RegionPtr rdpCopyAreaPixmapToPixmap(PixmapPtr pSrcPixmap, rdpPixmapRec *pSrcPriv, PixmapPtr pDstPixmap, rdpPixmapRec *pDstPriv, GCPtr pGC, int srcx, int srcy, int w, int h, int dstx, int dsty) { int lsrcx; int lsrcy; int ldstx; int ldsty; int cd; int j; int num_clips; int dx; int dy; RegionPtr rv; RegionRec clip_reg; BoxRec box; LLOGLN(10, ("rdpCopyAreaPixmapToPixmap:")); RegionInit(&clip_reg, NullBox, 0); cd = rdp_get_clip(&clip_reg, &(pDstPixmap->drawable), pGC); LLOGLN(10, ("rdpCopyAreaPixmapToPixmap: cd %d", cd)); ldstx = pDstPixmap->drawable.x + dstx; ldsty = pDstPixmap->drawable.y + dsty; lsrcx = pSrcPixmap->drawable.x + srcx; lsrcy = pSrcPixmap->drawable.y + srcy; if (cd == 1) { rdpup_switch_os_surface(pDstPriv->rdpindex); rdpup_begin_update(); rdpup_paint_rect_os(ldstx, ldsty, w, h, pSrcPriv->rdpindex, lsrcx, lsrcy); LLOGLN(10, ("%d %d %d %d %d %d", ldstx, ldsty, w, h, lsrcx, lsrcy)); rdpup_end_update(); rdpup_switch_os_surface(-1); } else if (cd == 2) { num_clips = REGION_NUM_RECTS(&clip_reg); if (num_clips > 0) { rdpup_switch_os_surface(pDstPriv->rdpindex); rdpup_begin_update(); dx = ldstx - lsrcx; dy = ldsty - lsrcy; LLOGLN(10, ("rdpCopyAreaPixmapToPixmap: num_clips %d", num_clips)); if ((dy < 0) || ((dy == 0) && (dx < 0))) { for (j = 0; j < num_clips; j++) { box = REGION_RECTS(&clip_reg)[j]; rdpup_set_clip(box.x1, box.y1, box.x2 - box.x1, box.y2 - box.y1); rdpup_paint_rect_os(ldstx, ldsty, w, h, pSrcPriv->rdpindex, lsrcx, lsrcy); LLOGLN(10, ("%d %d %d %d %d %d", ldstx, ldsty, w, h, lsrcx, lsrcy)); } } else { for (j = num_clips - 1; j >= 0; j--) { box = REGION_RECTS(&clip_reg)[j]; rdpup_set_clip(box.x1, box.y1, box.x2 - box.x1, box.y2 - box.y1); rdpup_paint_rect_os(ldstx, ldsty, w, h, pSrcPriv->rdpindex, lsrcx, lsrcy); LLOGLN(10, ("%d %d %d %d %d %d", ldstx, ldsty, w, h, lsrcx, lsrcy)); } } rdpup_reset_clip(); rdpup_end_update(); rdpup_switch_os_surface(-1); } } RegionUninit(&clip_reg); rv = rdpCopyAreaOrg(&(pSrcPixmap->drawable), &(pDstPixmap->drawable), pGC, srcx, srcy, w, h, dstx, dsty); return rv; } /******************************************************************************/ RegionPtr rdpCopyArea(DrawablePtr pSrc, DrawablePtr pDst, GCPtr pGC, int srcx, int srcy, int w, int h, int dstx, int dsty) { RegionPtr rv; RegionRec clip_reg; RegionRec box_reg; RegionRec reg1; int num_clips; int cd; int j; int can_do_screen_blt; int got_id; int dirty_type; int post_process; int reset_surface; struct image_data id; BoxRec box; BoxPtr pbox; PixmapPtr pSrcPixmap; PixmapPtr pDstPixmap; rdpPixmapRec *pSrcPriv; rdpPixmapRec *pDstPriv; rdpPixmapRec *pDirtyPriv; WindowPtr pDstWnd; WindowPtr pSrcWnd; LLOGLN(10, ("rdpCopyArea: x %d y %d w %d h %d", dstx, dsty, w, h)); if (pSrc->type == DRAWABLE_WINDOW) { pSrcWnd = (WindowPtr)pSrc; if (pSrcWnd->viewable) { rdpup_check_dirty_screen(&g_screenPriv); if (pDst->type == DRAWABLE_WINDOW) { pDstWnd = (WindowPtr)pDst; if (pDstWnd->viewable) { can_do_screen_blt = pGC->alu == GXcopy; if (can_do_screen_blt) { return rdpCopyAreaWndToWnd(pSrcWnd, pDstWnd, pGC, srcx, srcy, w, h, dstx, dsty); } } } else if (pDst->type == DRAWABLE_PIXMAP) { pDstPixmap = (PixmapPtr)pDst; pDstPriv = GETPIXPRIV(pDstPixmap); if (xrdp_is_os(pDstPixmap, pDstPriv)) { can_do_screen_blt = pGC->alu == GXcopy; if (can_do_screen_blt) { rdpup_check_dirty(pDstPixmap, pDstPriv); return rdpCopyAreaWndToPixmap(pSrcWnd, pDstPixmap, pDstPriv, pGC, srcx, srcy, w, h, dstx, dsty); } } else { LLOGLN(10, ("rdpCopyArea: 1")); } } } } if (pSrc->type == DRAWABLE_PIXMAP) { pSrcPixmap = (PixmapPtr)pSrc; pSrcPriv = GETPIXPRIV(pSrcPixmap); LLOGLN(10, ("rdpCopyArea: 3 %d %d", pSrcPixmap->usage_hint, pSrcPriv->is_scratch)); if (xrdp_is_os(pSrcPixmap, pSrcPriv)) { if (pDst->type == DRAWABLE_WINDOW) { pDstWnd = (WindowPtr)pDst; if (pDstWnd->viewable) { rdpup_check_dirty_screen(&g_screenPriv); rdpup_check_dirty(pSrcPixmap, pSrcPriv); return rdpCopyAreaPixmapToWnd(pSrcPixmap, pSrcPriv, pDstWnd, pGC, srcx, srcy, w, h, dstx, dsty); } } else if (pDst->type == DRAWABLE_PIXMAP) { pDstPixmap = (PixmapPtr)pDst; pDstPriv = GETPIXPRIV(pDstPixmap); if (xrdp_is_os(pDstPixmap, pDstPriv)) { if (g_can_do_pix_to_pix) { rdpup_check_dirty(pSrcPixmap, pSrcPriv); rdpup_check_dirty(pDstPixmap, pDstPriv); return rdpCopyAreaPixmapToPixmap(pSrcPixmap, pSrcPriv, pDstPixmap, pDstPriv, pGC, srcx, srcy, w, h, dstx, dsty); } } else { LLOGLN(10, ("rdpCopyArea: 4")); } } } else { LLOGLN(10, ("rdpCopyArea: 2 %d %d", pSrcPixmap->usage_hint, pSrcPriv->is_scratch)); } } LLOGLN(10, ("rdpCopyArea: fallback")); /* do original call */ rv = rdpCopyAreaOrg(pSrc, pDst, pGC, srcx, srcy, w, h, dstx, dsty); dirty_type = 0; pDirtyPriv = 0; post_process = 0; reset_surface = 0; got_id = 0; if (pDst->type == DRAWABLE_PIXMAP) { pDstPixmap = (PixmapPtr)pDst; pDstPriv = GETPIXPRIV(pDstPixmap); if (xrdp_is_os(pDstPixmap, pDstPriv)) { post_process = 1; if (g_do_dirty_os) { LLOGLN(10, ("rdpCopyArea: getting dirty")); pDstPriv->is_dirty = 1; pDirtyPriv = pDstPriv; dirty_type = RDI_IMGLY; } else { rdpup_switch_os_surface(pDstPriv->rdpindex); reset_surface = 1; rdpup_get_pixmap_image_rect(pDstPixmap, &id); got_id = 1; } } else { LLOGLN(10, ("rdpCopyArea: 3")); } } else { if (pDst->type == DRAWABLE_WINDOW) { pDstWnd = (WindowPtr)pDst; if (pDstWnd->viewable) { post_process = 1; if (g_do_dirty_ons) { LLOGLN(10, ("rdpCopyArea: getting dirty")); g_screenPriv.is_dirty = 1; pDirtyPriv = &g_screenPriv; dirty_type = RDI_IMGLY; } else { rdpup_get_screen_image_rect(&id); got_id = 1; } } } } if (!post_process) { return rv; } LLOGLN(10, ("rdpCopyArea: post_process")); RegionInit(&clip_reg, NullBox, 0); cd = rdp_get_clip(&clip_reg, pDst, pGC); if (cd == 1) { if (dirty_type != 0) { box.x1 = pDst->x + dstx; box.y1 = pDst->y + dsty; box.x2 = box.x1 + w; box.y2 = box.y1 + h; RegionInit(®1, &box, 0); draw_item_add_img_region(pDirtyPriv, ®1, GXcopy, dirty_type, TAG_COPYAREA); RegionUninit(®1); } else if (got_id) { rdpup_begin_update(); rdpup_send_area(&id, pDst->x + dstx, pDst->y + dsty, w, h); rdpup_end_update(); } } else if (cd == 2) { num_clips = REGION_NUM_RECTS(&clip_reg); if (num_clips > 0) { if (dirty_type != 0) { box.x1 = pDst->x + dstx; box.y1 = pDst->y + dsty; box.x2 = box.x1 + w; box.y2 = box.y1 + h; RegionInit(&box_reg, &box, 0); RegionIntersect(&clip_reg, &clip_reg, &box_reg); draw_item_add_img_region(pDirtyPriv, &clip_reg, GXcopy, dirty_type, TAG_COPYAREA); RegionUninit(&box_reg); } else if (got_id) { rdpup_begin_update(); box.x1 = pDst->x + dstx; box.y1 = pDst->y + dsty; box.x2 = box.x1 + w; box.y2 = box.y1 + h; RegionInit(&box_reg, &box, 0); RegionIntersect(&clip_reg, &clip_reg, &box_reg); num_clips = REGION_NUM_RECTS(&clip_reg); if (num_clips < 10) { for (j = num_clips - 1; j >= 0; j--) { box = REGION_RECTS(&clip_reg)[j]; rdpup_send_area(&id, box.x1, box.y1, box.x2 - box.x1, box.y2 - box.y1); } } else { pbox = RegionExtents(&clip_reg); rdpup_send_area(&id, pbox->x1, pbox->y1, pbox->x2 - pbox->x1, pbox->y2 - pbox->y1); } RegionUninit(&box_reg); rdpup_end_update(); } } } RegionUninit(&clip_reg); if (reset_surface) { rdpup_switch_os_surface(-1); } return rv; } xrdp-0.9.5/xorg/X11R7.6/rdp/rdpPolyFillRect.c000644 001751 001751 00000024331 13127114621 020337 0ustar00metameta000000 000000 /* Copyright 2005-2013 Jay Sorg Permission to use, copy, modify, distribute, and sell this software and its documentation for any purpose is hereby granted without fee, provided that the above copyright notice appear in all copies and that both that copyright notice and this permission notice appear in supporting documentation. The above copyright notice and this permission notice shall be included in all copies or substantial portions of the Software. THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE OPEN GROUP BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. */ #include "rdp.h" #include "rdpdraw.h" #define LDEBUG 0 #define LOG_LEVEL 1 #define LLOG(_level, _args) \ do { if (_level < LOG_LEVEL) { ErrorF _args ; } } while (0) #define LLOGLN(_level, _args) \ do { if (_level < LOG_LEVEL) { ErrorF _args ; ErrorF("\n"); } } while (0) extern rdpScreenInfoRec g_rdpScreen; /* from rdpmain.c */ extern DevPrivateKeyRec g_rdpGCIndex; /* from rdpmain.c */ extern DevPrivateKeyRec g_rdpWindowIndex; /* from rdpmain.c */ extern DevPrivateKeyRec g_rdpPixmapIndex; /* from rdpmain.c */ extern int g_Bpp; /* from rdpmain.c */ extern ScreenPtr g_pScreen; /* from rdpmain.c */ extern Bool g_wrapPixmap; /* from rdpmain.c */ extern int g_do_dirty_os; /* in rdpmain.c */ extern int g_do_dirty_ons; /* in rdpmain.c */ extern rdpPixmapRec g_screenPriv; /* in rdpmain.c */ extern GCOps g_rdpGCOps; /* from rdpdraw.c */ extern int g_con_number; /* in rdpup.c */ /******************************************************************************/ static void rdpPolyFillRectOrg(DrawablePtr pDrawable, GCPtr pGC, int nrectFill, xRectangle *prectInit) { rdpGCPtr priv; GCFuncs *oldFuncs; GC_OP_PROLOGUE(pGC); pGC->ops->PolyFillRect(pDrawable, pGC, nrectFill, prectInit); GC_OP_EPILOGUE(pGC); } /******************************************************************************/ void rdpPolyFillRect(DrawablePtr pDrawable, GCPtr pGC, int nrectFill, xRectangle *prectInit) { int j; int cd; int num_clips; RegionRec clip_reg; RegionPtr fill_reg; BoxRec box; int got_id; int dirty_type; int post_process; int reset_surface; struct image_data id; WindowPtr pDstWnd; PixmapPtr pDstPixmap; rdpPixmapRec *pDstPriv; rdpPixmapRec *pDirtyPriv; LLOGLN(10, ("rdpPolyFillRect:")); /* make a copy of rects */ fill_reg = RegionFromRects(nrectFill, prectInit, CT_NONE); /* do original call */ rdpPolyFillRectOrg(pDrawable, pGC, nrectFill, prectInit); dirty_type = 0; pDirtyPriv = 0; post_process = 0; reset_surface = 0; if (pDrawable->type == DRAWABLE_PIXMAP) { pDstPixmap = (PixmapPtr)pDrawable; pDstPriv = GETPIXPRIV(pDstPixmap); if (pDstPixmap->devPrivate.ptr == g_rdpScreen.pfbMemory) { /* treat like root window */ post_process = 1; if (g_do_dirty_ons) { LLOGLN(10, ("rdpPolyFillRect: getting dirty")); g_screenPriv.is_dirty = 1; pDirtyPriv = &g_screenPriv; dirty_type = (FillTiled == pGC->fillStyle) ? RDI_IMGLY : RDI_IMGLL; } else { rdpup_get_screen_image_rect(&id); got_id = 1; } } else if (xrdp_is_os(pDstPixmap, pDstPriv)) { post_process = 1; if (g_do_dirty_os) { LLOGLN(10, ("rdpPolyFillRect: getting dirty")); pDstPriv->is_dirty = 1; pDirtyPriv = pDstPriv; dirty_type = (FillTiled == pGC->fillStyle) ? RDI_IMGLY : RDI_IMGLL; } else { rdpup_switch_os_surface(pDstPriv->rdpindex); reset_surface = 1; rdpup_get_pixmap_image_rect(pDstPixmap, &id); got_id = 1; } } } else { if (pDrawable->type == DRAWABLE_WINDOW) { pDstWnd = (WindowPtr)pDrawable; if (pDstWnd->viewable) { post_process = 1; if (g_do_dirty_ons) { LLOGLN(10, ("rdpPolyFillRect: getting dirty")); g_screenPriv.is_dirty = 1; pDirtyPriv = &g_screenPriv; dirty_type = (FillTiled == pGC->fillStyle) ? RDI_IMGLY : RDI_IMGLL; } else { rdpup_get_screen_image_rect(&id); got_id = 1; } } } } if (!post_process) { RegionDestroy(fill_reg); LLOGLN(10, ("rdpPolyFillRect: out, post_process not set")); return; } RegionTranslate(fill_reg, pDrawable->x, pDrawable->y); RegionInit(&clip_reg, NullBox, 0); cd = rdp_get_clip(&clip_reg, pDrawable, pGC); LLOGLN(10, ("rdpPolyFillRect: cd %d", cd)); if (cd == 1) /* no clip */ { if (dirty_type != 0) { if (pGC->fillStyle == 0 && /* solid fill */ (pGC->alu == GXclear || pGC->alu == GXset || pGC->alu == GXinvert || pGC->alu == GXnoop || pGC->alu == GXand || pGC->alu == GXcopy /*|| pGC->alu == GXxor*/)) /* todo, why doesn't xor work? */ { draw_item_add_fill_region(pDirtyPriv, fill_reg, pGC->fgPixel, pGC->alu); } else { draw_item_add_img_region(pDirtyPriv, fill_reg, GXcopy, dirty_type, TAG_POLYFILLRECT); } } else if (got_id) { rdpup_begin_update(); if (pGC->fillStyle == 0 && /* solid fill */ (pGC->alu == GXclear || pGC->alu == GXset || pGC->alu == GXinvert || pGC->alu == GXnoop || pGC->alu == GXand || pGC->alu == GXcopy /*|| pGC->alu == GXxor*/)) /* todo, why doesn't xor work? */ { rdpup_set_fgcolor(pGC->fgPixel); rdpup_set_opcode(pGC->alu); for (j = REGION_NUM_RECTS(fill_reg) - 1; j >= 0; j--) { box = REGION_RECTS(fill_reg)[j]; rdpup_fill_rect(box.x1, box.y1, box.x2 - box.x1, box.y2 - box.y1); } rdpup_set_opcode(GXcopy); } else /* non solid fill */ { for (j = REGION_NUM_RECTS(fill_reg) - 1; j >= 0; j--) { box = REGION_RECTS(fill_reg)[j]; rdpup_send_area(&id, box.x1, box.y1, box.x2 - box.x1, box.y2 - box.y1); } } rdpup_end_update(); } } else if (cd == 2) /* clip */ { RegionIntersect(&clip_reg, &clip_reg, fill_reg); num_clips = REGION_NUM_RECTS(&clip_reg); if (num_clips > 0) { if (dirty_type != 0) { if (pGC->fillStyle == 0 && /* solid fill */ (pGC->alu == GXclear || pGC->alu == GXset || pGC->alu == GXinvert || pGC->alu == GXnoop || pGC->alu == GXand || pGC->alu == GXcopy /*|| pGC->alu == GXxor*/)) /* todo, why doesn't xor work? */ { LLOGLN(10, ("rdpPolyFillRect: 3")); draw_item_add_fill_region(pDirtyPriv, &clip_reg, pGC->fgPixel, pGC->alu); } else { LLOGLN(10, ("rdpPolyFillRect: 4")); draw_item_add_img_region(pDirtyPriv, &clip_reg, GXcopy, dirty_type, TAG_POLYFILLRECT); } } else if (got_id) { rdpup_begin_update(); LLOGLN(10, ("2 %x", pGC->fgPixel)); if (pGC->fillStyle == 0 && /* solid fill */ (pGC->alu == GXclear || pGC->alu == GXset || pGC->alu == GXinvert || pGC->alu == GXnoop || pGC->alu == GXand || pGC->alu == GXcopy /*|| pGC->alu == GXxor*/)) /* todo, why doesn't xor work? */ { rdpup_set_fgcolor(pGC->fgPixel); rdpup_set_opcode(pGC->alu); for (j = num_clips - 1; j >= 0; j--) { box = REGION_RECTS(&clip_reg)[j]; rdpup_fill_rect(box.x1, box.y1, box.x2 - box.x1, box.y2 - box.y1); } rdpup_set_opcode(GXcopy); } else /* non solid fill */ { for (j = num_clips - 1; j >= 0; j--) { box = REGION_RECTS(&clip_reg)[j]; rdpup_send_area(&id, box.x1, box.y1, box.x2 - box.x1, box.y2 - box.y1); } } rdpup_end_update(); } } } RegionUninit(&clip_reg); RegionDestroy(fill_reg); if (reset_surface) { rdpup_switch_os_surface(-1); } } xrdp-0.9.5/xorg/X11R7.6/rdp/rdpSetSpans.c000644 001751 001751 00000011225 13125122134 017521 0ustar00metameta000000 000000 /* Copyright 2005-2013 Jay Sorg Permission to use, copy, modify, distribute, and sell this software and its documentation for any purpose is hereby granted without fee, provided that the above copyright notice appear in all copies and that both that copyright notice and this permission notice appear in supporting documentation. The above copyright notice and this permission notice shall be included in all copies or substantial portions of the Software. THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE OPEN GROUP BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. */ #include "rdp.h" #include "rdpdraw.h" #define LDEBUG 0 #define LOG_LEVEL 1 #define LLOG(_level, _args) \ do { if (_level < LOG_LEVEL) { ErrorF _args ; } } while (0) #define LLOGLN(_level, _args) \ do { if (_level < LOG_LEVEL) { ErrorF _args ; ErrorF("\n"); } } while (0) extern rdpScreenInfoRec g_rdpScreen; /* from rdpmain.c */ extern DevPrivateKeyRec g_rdpGCIndex; /* from rdpmain.c */ extern DevPrivateKeyRec g_rdpWindowIndex; /* from rdpmain.c */ extern DevPrivateKeyRec g_rdpPixmapIndex; /* from rdpmain.c */ extern int g_Bpp; /* from rdpmain.c */ extern ScreenPtr g_pScreen; /* from rdpmain.c */ extern Bool g_wrapPixmap; /* from rdpmain.c */ extern int g_do_dirty_os; /* in rdpmain.c */ extern int g_do_dirty_ons; /* in rdpmain.c */ extern rdpPixmapRec g_screenPriv; /* in rdpmain.c */ extern GCOps g_rdpGCOps; /* from rdpdraw.c */ extern int g_con_number; /* in rdpup.c */ /******************************************************************************/ void rdpSetSpansOrg(DrawablePtr pDrawable, GCPtr pGC, char *psrc, DDXPointPtr ppt, int *pwidth, int nspans, int fSorted) { rdpGCPtr priv; GCFuncs *oldFuncs; GC_OP_PROLOGUE(pGC); pGC->ops->SetSpans(pDrawable, pGC, psrc, ppt, pwidth, nspans, fSorted); GC_OP_EPILOGUE(pGC); } /******************************************************************************/ void rdpSetSpans(DrawablePtr pDrawable, GCPtr pGC, char *psrc, DDXPointPtr ppt, int *pwidth, int nspans, int fSorted) { RegionRec clip_reg; int cd; int got_id; int dirty_type; int post_process; int reset_surface; struct image_data id; WindowPtr pDstWnd; PixmapPtr pDstPixmap; rdpPixmapRec *pDstPriv; rdpPixmapRec *pDirtyPriv; LLOGLN(0, ("rdpSetSpans: todo")); /* do original call */ rdpSetSpansOrg(pDrawable, pGC, psrc, ppt, pwidth, nspans, fSorted); dirty_type = 0; pDirtyPriv = 0; post_process = 0; reset_surface = 0; got_id = 0; if (pDrawable->type == DRAWABLE_PIXMAP) { pDstPixmap = (PixmapPtr)pDrawable; pDstPriv = GETPIXPRIV(pDstPixmap); if (xrdp_is_os(pDstPixmap, pDstPriv)) { post_process = 1; if (g_do_dirty_os) { LLOGLN(10, ("rdpSetSpans: getting dirty")); pDstPriv->is_dirty = 1; pDirtyPriv = pDstPriv; dirty_type = RDI_IMGLY; } else { rdpup_switch_os_surface(pDstPriv->rdpindex); reset_surface = 1; rdpup_get_pixmap_image_rect(pDstPixmap, &id); got_id = 1; } } } else { if (pDrawable->type == DRAWABLE_WINDOW) { pDstWnd = (WindowPtr)pDrawable; if (pDstWnd->viewable) { post_process = 1; if (g_do_dirty_ons) { LLOGLN(10, ("rdpSetSpans: getting dirty")); g_screenPriv.is_dirty = 1; pDirtyPriv = &g_screenPriv; dirty_type = RDI_IMGLL; } else { rdpup_get_screen_image_rect(&id); got_id = 1; } } } } if (!post_process) { return; } RegionInit(&clip_reg, NullBox, 0); cd = rdp_get_clip(&clip_reg, pDrawable, pGC); if (cd == 1) { if (dirty_type != 0) { } else if (got_id) { } } else if (cd == 2) { if (dirty_type != 0) { } else if (got_id) { } } RegionUninit(&clip_reg); if (reset_surface) { rdpup_switch_os_surface(-1); } } xrdp-0.9.5/xorg/X11R7.6/rdp/rdprandr.c000644 001751 001751 00000032214 13133557325 017105 0ustar00metameta000000 000000 /* Copyright 2011-2013 Jay Sorg Permission to use, copy, modify, distribute, and sell this software and its documentation for any purpose is hereby granted without fee, provided that the above copyright notice appear in all copies and that both that copyright notice and this permission notice appear in supporting documentation. The above copyright notice and this permission notice shall be included in all copies or substantial portions of the Software. THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE OPEN GROUP BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. RandR extension implementation */ #include "rdp.h" #include "rdprandr.h" #if 1 #define DEBUG_OUT(arg) #else #define DEBUG_OUT(arg) ErrorF arg #endif extern rdpScreenInfoRec g_rdpScreen; /* from rdpmain.c */ extern DeviceIntPtr g_pointer; /* in rdpmain.c */ extern DeviceIntPtr g_keyboard; /* in rdpmain.c */ extern ScreenPtr g_pScreen; /* in rdpmain.c */ extern WindowPtr g_invalidate_window; /* in rdpmain.c */ static XID g_wid = 0; static int g_panning = 0; #define LOG_LEVEL 1 #define LLOG(_level, _args) \ do { if (_level < LOG_LEVEL) { ErrorF _args ; } } while (0) #define LLOGLN(_level, _args) \ do { if (_level < LOG_LEVEL) { ErrorF _args ; ErrorF("\n"); } } while (0) /******************************************************************************/ Bool rdpRRRegisterSize(ScreenPtr pScreen, int width, int height) { int mmwidth; int mmheight; RRScreenSizePtr pSize; ErrorF("rdpRRRegisterSize: width %d height %d\n", width, height); mmwidth = PixelToMM(width); mmheight = PixelToMM(height); pSize = RRRegisterSize(pScreen, width, height, mmwidth, mmheight); /* Tell RandR what the current config is */ RRSetCurrentConfig(pScreen, RR_Rotate_0, 0, pSize); return TRUE; } /******************************************************************************/ Bool rdpRRSetConfig(ScreenPtr pScreen, Rotation rotateKind, int rate, RRScreenSizePtr pSize) { ErrorF("rdpRRSetConfig:\n"); return TRUE; } /******************************************************************************/ Bool rdpRRGetInfo(ScreenPtr pScreen, Rotation *pRotations) { ErrorF("rdpRRGetInfo:\n"); *pRotations = RR_Rotate_0; return TRUE; } /******************************************************************************/ /* for lack of a better way, a window is created that covers the area and when its deleted, it's invalidated */ static int rdpInvalidateArea(ScreenPtr pScreen, int x, int y, int cx, int cy) { WindowPtr pWin; int result; int attri; XID attributes[4]; Mask mask; DEBUG_OUT(("rdpInvalidateArea:\n")); mask = 0; attri = 0; attributes[attri++] = pScreen->blackPixel; mask |= CWBackPixel; attributes[attri++] = xTrue; mask |= CWOverrideRedirect; if (g_wid == 0) { g_wid = FakeClientID(0); } pWin = CreateWindow(g_wid, pScreen->root, x, y, cx, cy, 0, InputOutput, mask, attributes, 0, serverClient, wVisual(pScreen->root), &result); if (result == 0) { g_invalidate_window = pWin; MapWindow(pWin, serverClient); DeleteWindow(pWin, None); g_invalidate_window = pWin; } return 0; } /******************************************************************************/ Bool rdpRRScreenSetSize(ScreenPtr pScreen, CARD16 width, CARD16 height, CARD32 mmWidth, CARD32 mmHeight) { PixmapPtr screenPixmap; BoxRec box; ErrorF("rdpRRScreenSetSize: width %d height %d mmWidth %d mmHeight %d\n", width, height, (int)mmWidth, (int)mmHeight); if ((width < 1) || (height < 1)) { ErrorF(" error width %d height %d\n", width, height); return FALSE; } g_rdpScreen.width = width; g_rdpScreen.height = height; g_rdpScreen.paddedWidthInBytes = PixmapBytePad(g_rdpScreen.width, g_rdpScreen.depth); g_rdpScreen.sizeInBytes = g_rdpScreen.paddedWidthInBytes * g_rdpScreen.height; pScreen->width = width; pScreen->height = height; pScreen->mmWidth = mmWidth; pScreen->mmHeight = mmHeight; screenPixmap = pScreen->GetScreenPixmap(pScreen); if (screenPixmap != 0) { ErrorF(" resizing screenPixmap [%p] to %dx%d, currently at %dx%d\n", (void *)screenPixmap, width, height, screenPixmap->drawable.width, screenPixmap->drawable.height); if (g_rdpScreen.sizeInBytes > g_rdpScreen.sizeInBytesAlloc) { g_free(g_rdpScreen.pfbMemory); g_rdpScreen.pfbMemory = (char*)g_malloc(g_rdpScreen.sizeInBytes, 1); g_rdpScreen.sizeInBytesAlloc = g_rdpScreen.sizeInBytes; ErrorF("new buffer size %d\n", g_rdpScreen.sizeInBytes); } pScreen->ModifyPixmapHeader(screenPixmap, width, height, g_rdpScreen.depth, g_rdpScreen.bitsPerPixel, g_rdpScreen.paddedWidthInBytes, g_rdpScreen.pfbMemory); ErrorF(" pixmap resized to %dx%d\n", screenPixmap->drawable.width, screenPixmap->drawable.height); } DEBUG_OUT((" root window %p\n", (void *)pScreen->root)); box.x1 = 0; box.y1 = 0; box.x2 = width; box.y2 = height; RegionInit(&pScreen->root->winSize, &box, 1); RegionInit(&pScreen->root->borderSize, &box, 1); RegionReset(&pScreen->root->borderClip, &box); RegionBreak(&pScreen->root->clipList); pScreen->root->drawable.width = width; pScreen->root->drawable.height = height; ResizeChildrenWinSize(pScreen->root, 0, 0, 0, 0); RRGetInfo(pScreen, 1); RRScreenSizeNotify(pScreen); rdpInvalidateArea(g_pScreen, 0, 0, g_rdpScreen.width, g_rdpScreen.height); ErrorF(" screen resized to %dx%d\n", pScreen->width, pScreen->height); return TRUE; } /******************************************************************************/ Bool rdpRRCrtcSet(ScreenPtr pScreen, RRCrtcPtr crtc, RRModePtr mode, int x, int y, Rotation rotation, int numOutputs, RROutputPtr *outputs) { ErrorF("rdpRRCrtcSet:\n"); return TRUE; } /******************************************************************************/ Bool rdpRRCrtcSetGamma(ScreenPtr pScreen, RRCrtcPtr crtc) { ErrorF("rdpRRCrtcSetGamma:\n"); return TRUE; } /******************************************************************************/ Bool rdpRRCrtcGetGamma(ScreenPtr pScreen, RRCrtcPtr crtc) { ErrorF("rdpRRCrtcGetGamma:\n"); crtc->gammaSize = 1; if (crtc->gammaRed == NULL) { crtc->gammaRed = g_malloc(32, 1); } if (crtc->gammaBlue == NULL) { crtc->gammaBlue = g_malloc(32, 1); } if (crtc->gammaGreen == NULL) { crtc->gammaGreen = g_malloc(32, 1); } return TRUE; } /******************************************************************************/ Bool rdpRROutputSetProperty(ScreenPtr pScreen, RROutputPtr output, Atom property, RRPropertyValuePtr value) { ErrorF("rdpRROutputSetProperty:\n"); return TRUE; } /******************************************************************************/ Bool rdpRROutputValidateMode(ScreenPtr pScreen, RROutputPtr output, RRModePtr mode) { ErrorF("rdpRROutputValidateMode:\n"); return TRUE; } /******************************************************************************/ void rdpRRModeDestroy(ScreenPtr pScreen, RRModePtr mode) { ErrorF("rdpRRModeDestroy:\n"); } /******************************************************************************/ Bool rdpRROutputGetProperty(ScreenPtr pScreen, RROutputPtr output, Atom property) { ErrorF("rdpRROutputGetProperty:\n"); return TRUE; } /******************************************************************************/ Bool rdpRRGetPanning(ScreenPtr pScrn, RRCrtcPtr crtc, BoxPtr totalArea, BoxPtr trackingArea, INT16 *border) { ErrorF("rdpRRGetPanning:\n"); if (!g_panning) { return FALSE; } if (totalArea != 0) { totalArea->x1 = 0; totalArea->y1 = 0; totalArea->x2 = g_rdpScreen.width; totalArea->y2 = g_rdpScreen.height; } if (trackingArea != 0) { trackingArea->x1 = 0; trackingArea->y1 = 0; trackingArea->x2 = g_rdpScreen.width; trackingArea->y2 = g_rdpScreen.height; } if (border != 0) { border[0] = 0; border[1] = 0; border[2] = 0; border[3] = 0; } return TRUE; } /******************************************************************************/ Bool rdpRRSetPanning(ScreenPtr pScrn, RRCrtcPtr crtc, BoxPtr totalArea, BoxPtr trackingArea, INT16 *border) { ErrorF("rdpRRSetPanning:\n"); return TRUE; } /******************************************************************************/ static RROutputPtr rdpRRAddOutput(const char *aname, int x, int y, int width, int height) { RRModePtr mode; RRCrtcPtr crtc; RROutputPtr output; xRRModeInfo modeInfo; char name[64]; const int vfreq = 50; sprintf (name, "%dx%d", width, height); memset (&modeInfo, 0, sizeof(modeInfo)); modeInfo.width = width; modeInfo.height = height; modeInfo.hTotal = width; modeInfo.vTotal = height; modeInfo.dotClock = vfreq * width * height; modeInfo.nameLength = strlen(name); mode = RRModeGet(&modeInfo, name); if (mode == 0) { LLOGLN(0, ("rdpRRAddOutput: RRModeGet failed")); return 0; } crtc = RRCrtcCreate(g_pScreen, NULL); if (crtc == 0) { LLOGLN(0, ("rdpRRAddOutput: RRCrtcCreate failed")); RRModeDestroy(mode); return 0; } output = RROutputCreate(g_pScreen, aname, strlen(aname), NULL); if (output == 0) { LLOGLN(0, ("rdpRRAddOutput: RROutputCreate failed")); RRCrtcDestroy(crtc); RRModeDestroy(mode); return 0; } if (!RROutputSetClones(output, NULL, 0)) { LLOGLN(0, ("rdpRRAddOutput: RROutputSetClones failed")); } if (!RROutputSetModes(output, &mode, 1, 0)) { LLOGLN(0, ("rdpRRAddOutput: RROutputSetModes failed")); } if (!RROutputSetCrtcs(output, &crtc, 1)) { LLOGLN(0, ("rdpRRAddOutput: RROutputSetCrtcs failed")); } if (!RROutputSetConnection(output, RR_Connected)) { LLOGLN(0, ("rdpRRAddOutput: RROutputSetConnection failed")); } RRCrtcNotify(crtc, mode, x, y, RR_Rotate_0, NULL, 1, &output); return output; } /******************************************************************************/ static void RRSetPrimaryOutput(rrScrPrivPtr pScrPriv, RROutputPtr output) { if (pScrPriv->primaryOutput == output) { return; } /* clear the old primary */ if (pScrPriv->primaryOutput) { RROutputChanged(pScrPriv->primaryOutput, 0); pScrPriv->primaryOutput = NULL; } /* set the new primary */ if (output) { pScrPriv->primaryOutput = output; RROutputChanged(output, 0); } pScrPriv->layoutChanged = TRUE; } /******************************************************************************/ int rdpRRSetRdpOutputs(void) { rrScrPrivPtr pRRScrPriv; int index; int width; int height; char text[256]; RROutputPtr output; pRRScrPriv = rrGetScrPriv(g_pScreen); LLOGLN(0, ("rdpRRSetRdpOutputs: numCrtcs %d", pRRScrPriv->numCrtcs)); while (pRRScrPriv->numCrtcs > 0) { RRCrtcDestroy(pRRScrPriv->crtcs[0]); } LLOGLN(0, ("rdpRRSetRdpOutputs: numOutputs %d", pRRScrPriv->numOutputs)); while (pRRScrPriv->numOutputs > 0) { RROutputDestroy(pRRScrPriv->outputs[0]); } if (g_rdpScreen.client_info.monitorCount == 0) { rdpRRAddOutput("rdp0", 0, 0, g_rdpScreen.width, g_rdpScreen.height); } else { for (index = 0; index < g_rdpScreen.client_info.monitorCount; index++) { snprintf(text, 255, "rdp%d", index); width = g_rdpScreen.client_info.minfo[index].right - g_rdpScreen.client_info.minfo[index].left + 1; height = g_rdpScreen.client_info.minfo[index].bottom - g_rdpScreen.client_info.minfo[index].top + 1; output = rdpRRAddOutput(text, g_rdpScreen.client_info.minfo[index].left, g_rdpScreen.client_info.minfo[index].top, width, height); if ((output != 0) && (g_rdpScreen.client_info.minfo[index].is_primary)) { RRSetPrimaryOutput(pRRScrPriv, output); } } } #if 0 for (index = 0; index < pRRScrPriv->numOutputs; index++) { RROutputSetCrtcs(pRRScrPriv->outputs[index], pRRScrPriv->crtcs, pRRScrPriv->numCrtcs); } #endif return 0; } xrdp-0.9.5/xorg/X11R7.6/rdp/rdpmain.c000644 001751 001751 00000054201 13174271344 016722 0ustar00metameta000000 000000 /* Copyright 2005-2013 Jay Sorg Permission to use, copy, modify, distribute, and sell this software and its documentation for any purpose is hereby granted without fee, provided that the above copyright notice appear in all copies and that both that copyright notice and this permission notice appear in supporting documentation. The above copyright notice and this permission notice shall be included in all copies or substantial portions of the Software. THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE OPEN GROUP BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. This is the main file called from main.c Sets up the functions */ #include "rdp.h" #include "rdprandr.h" #include "rdpglyph.h" #if 1 #define DEBUG_OUT(arg) #else #define DEBUG_OUT(arg) ErrorF arg #endif #ifndef XRDP_DISABLE_LINUX_ABSTRACT #ifdef __linux__ #define XRDP_DISABLE_LINUX_ABSTRACT 1 #else #define XRDP_DISABLE_LINUX_ABSTRACT 0 #endif #endif #if XRDP_DISABLE_LINUX_ABSTRACT /* because including is problematic * we dup a small struct * we need to set flags to zero to turn off abstract sockets */ struct _MyXtransport { char *TransName; int flags; }; /* in xtrans-1.2.6/Xtranssock.c */ extern struct _MyXtransport _XSERVTransSocketLocalFuncs; #endif rdpScreenInfoRec g_rdpScreen; /* the one screen */ ScreenPtr g_pScreen = 0; DevPrivateKeyRec g_rdpGCIndex; DevPrivateKeyRec g_rdpWindowIndex; DevPrivateKeyRec g_rdpPixmapIndex; /* main mouse and keyboard devices */ DeviceIntPtr g_pointer = 0; DeviceIntPtr g_keyboard = 0; /* true if client is enhanced rdp client(freerdp) */ int g_can_do_pix_to_pix = 0; int g_do_dirty_os = 1; /* delay remoting off screen bitmaps */ int g_do_dirty_ons = 1; /* delay remoting screen */ int g_do_glyph_cache = 0; /* rdpup.c may set this */ int g_do_alpha_glyphs = 1; int g_do_composite = 0; /* rdpup.c may set this */ Bool g_wrapWindow = 1; Bool g_wrapPixmap = 1; int g_codec_mode = 0; /* 0 = standard rdp, 1 = rfx */ rdpPixmapRec g_screenPriv; /* if true, running in RemoteApp / RAIL mode */ int g_use_rail = 0; int g_con_number = 0; /* increments for each connection */ WindowPtr g_invalidate_window = 0; int g_doing_font = 0; /* if true, use a unix domain socket instead of a tcp socket */ int g_use_uds = 0; char g_uds_data[256] = ""; /* data */ char g_uds_cont[256] = ""; /* control */ int g_shift_down = 0; int g_alt_down = 0; int g_ctrl_down = 0; int g_pause_spe = 0; int g_tab_down = 0; /* set all these at once, use function set_bpp */ int g_bpp = 16; int g_Bpp = 2; int g_Bpp_mask = 0xffff; static int g_firstTime = 1; static int g_redBits = 5; static int g_greenBits = 6; static int g_blueBits = 5; static int g_initOutputCalled = 0; /* Common pixmap formats */ static PixmapFormatRec g_formats[MAXFORMATS] = { { 1, 1, BITMAP_SCANLINE_PAD }, { 4, 8, BITMAP_SCANLINE_PAD }, { 8, 8, BITMAP_SCANLINE_PAD }, { 15, 16, BITMAP_SCANLINE_PAD }, { 16, 16, BITMAP_SCANLINE_PAD }, { 24, 32, BITMAP_SCANLINE_PAD }, { 32, 32, BITMAP_SCANLINE_PAD }, }; static int g_numFormats = 7; static miPointerSpriteFuncRec g_rdpSpritePointerFuncs = { /* these are in rdpinput.c */ rdpSpriteRealizeCursor, rdpSpriteUnrealizeCursor, rdpSpriteSetCursor, rdpSpriteMoveCursor, rdpSpriteDeviceCursorInitialize, rdpSpriteDeviceCursorCleanup }; static miPointerScreenFuncRec g_rdpPointerCursorFuncs = { /* these are in rdpinput.c */ rdpCursorOffScreen, rdpCrossScreen, rdpPointerWarpCursor, rdpPointerEnqueueEvent, rdpPointerNewEventScreen }; int glGetBufferSubData(void); /******************************************************************************/ /* returns error, zero is good */ static int set_bpp(int bpp) { int rv; rv = 0; g_bpp = bpp; if (g_bpp == 8) { g_Bpp = 1; g_Bpp_mask = 0xff; g_redBits = 3; g_greenBits = 3; g_blueBits = 2; } else if (g_bpp == 15) { g_Bpp = 2; g_Bpp_mask = 0x7fff; g_redBits = 5; g_greenBits = 5; g_blueBits = 5; } else if (g_bpp == 16) { g_Bpp = 2; g_Bpp_mask = 0xffff; g_redBits = 5; g_greenBits = 6; g_blueBits = 5; } else if (g_bpp == 24) { g_Bpp = 4; g_Bpp_mask = 0xffffff; g_redBits = 8; g_greenBits = 8; g_blueBits = 8; } else if (g_bpp == 32) { g_Bpp = 4; g_Bpp_mask = 0xffffff; g_redBits = 8; g_greenBits = 8; g_blueBits = 8; } else if (g_bpp == 33) { /* will never happen */ glGetBufferSubData(); } else { rv = 1; } return rv; } /******************************************************************************/ static void rdpWakeupHandler(int i, pointer blockData, unsigned long err, pointer pReadmask) { g_pScreen->WakeupHandler = g_rdpScreen.WakeupHandler; g_pScreen->WakeupHandler(i, blockData, err, pReadmask); g_pScreen->WakeupHandler = rdpWakeupHandler; } /******************************************************************************/ static void rdpBlockHandler1(pointer blockData, OSTimePtr pTimeout, pointer pReadmask) { } /******************************************************************************/ static void rdpWakeupHandler1(pointer blockData, int result, pointer pReadmask) { rdpup_check(); } #if 0 /******************************************************************************/ static Bool rdpDeviceCursorInitialize(DeviceIntPtr pDev, ScreenPtr pScreen) { ErrorF("rdpDeviceCursorInitializeProcPtr:\n"); return 1; } /******************************************************************************/ static void rdpDeviceCursorCleanup(DeviceIntPtr pDev, ScreenPtr pScreen) { ErrorF("rdpDeviceCursorCleanupProcPtr:\n"); } #endif #if 0 /******************************************************************************/ Bool rdpCreateColormap(ColormapPtr pCmap) { ErrorF("rdpCreateColormap:\n"); return 1; } /******************************************************************************/ static void rdpDestroyColormap(ColormapPtr pColormap) { ErrorF("rdpDestroyColormap:\n"); } #endif /******************************************************************************/ void rdpSetUDSRights(void) { char unixSocketName[128]; sprintf(unixSocketName, "/tmp/.X11-unix/X%s", display); chmod(unixSocketName, 0700); } /******************************************************************************/ /* returns boolean, true if everything is ok */ static Bool rdpScreenInit(int index, ScreenPtr pScreen, int argc, char **argv) { int dpix; int dpiy; int ret; Bool vis_found; VisualPtr vis; PictureScreenPtr ps; rrScrPrivPtr pRRScrPriv; g_pScreen = pScreen; memset(&g_screenPriv, 0, sizeof(g_screenPriv)); /*dpix = 75; dpiy = 75; */ dpix = PixelDPI; dpiy = PixelDPI; if (monitorResolution != 0) { dpix = monitorResolution; dpiy = monitorResolution; } g_rdpScreen.paddedWidthInBytes = PixmapBytePad(g_rdpScreen.width, g_rdpScreen.depth); g_rdpScreen.bitsPerPixel = rdpBitsPerPixel(g_rdpScreen.depth); ErrorF("\n"); ErrorF("X11rdp, an X server for xrdp\n"); ErrorF("Version %s\n", X11RDPVER); ErrorF("Copyright (C) 2005-2015 Jay Sorg\n"); ErrorF("See http://www.xrdp.org for information on xrdp.\n"); #if defined(XORG_VERSION_CURRENT) && defined (XVENDORNAME) ErrorF("Underlying X server release %d, %s\n", XORG_VERSION_CURRENT, XVENDORNAME); #endif #if defined(XORG_RELEASE) ErrorF("Xorg %s\n", XORG_RELEASE); #endif ErrorF("Screen width %d height %d depth %d bpp %d\n", g_rdpScreen.width, g_rdpScreen.height, g_rdpScreen.depth, g_rdpScreen.bitsPerPixel); ErrorF("dpix %d dpiy %d\n", dpix, dpiy); if (g_rdpScreen.pfbMemory == 0) { g_rdpScreen.sizeInBytes = (g_rdpScreen.paddedWidthInBytes * g_rdpScreen.height); ErrorF("buffer size %d\n", g_rdpScreen.sizeInBytes); g_rdpScreen.pfbMemory = (char *)g_malloc(g_rdpScreen.sizeInBytes, 1); g_rdpScreen.sizeInBytesAlloc = g_rdpScreen.sizeInBytes; } if (g_rdpScreen.pfbMemory == 0) { rdpLog("rdpScreenInit g_malloc failed\n"); return 0; } miClearVisualTypes(); if (defaultColorVisualClass == -1) { defaultColorVisualClass = TrueColor; } if (!miSetVisualTypes(g_rdpScreen.depth, miGetDefaultVisualMask(g_rdpScreen.depth), 8, defaultColorVisualClass)) { rdpLog("rdpScreenInit miSetVisualTypes failed\n"); return 0; } miSetPixmapDepths(); switch (g_rdpScreen.bitsPerPixel) { case 8: ret = fbScreenInit(pScreen, g_rdpScreen.pfbMemory, g_rdpScreen.width, g_rdpScreen.height, dpix, dpiy, g_rdpScreen.paddedWidthInBytes, 8); break; case 16: ret = fbScreenInit(pScreen, g_rdpScreen.pfbMemory, g_rdpScreen.width, g_rdpScreen.height, dpix, dpiy, g_rdpScreen.paddedWidthInBytes / 2, 16); break; case 32: ret = fbScreenInit(pScreen, g_rdpScreen.pfbMemory, g_rdpScreen.width, g_rdpScreen.height, dpix, dpiy, g_rdpScreen.paddedWidthInBytes / 4, 32); break; default: ErrorF("rdpScreenInit: error\n"); return 0; } if (!ret) { ErrorF("rdpScreenInit: error\n"); return 0; } miInitializeBackingStore(pScreen); /* this is for rgb, not bgr, just doing rgb for now */ vis = g_pScreen->visuals + (g_pScreen->numVisuals - 1); while (vis >= pScreen->visuals) { if ((vis->class | DynamicClass) == DirectColor) { vis->offsetBlue = 0; vis->blueMask = (1 << g_blueBits) - 1; vis->offsetGreen = g_blueBits; vis->greenMask = ((1 << g_greenBits) - 1) << vis->offsetGreen; vis->offsetRed = g_blueBits + g_greenBits; vis->redMask = ((1 << g_redBits) - 1) << vis->offsetRed; } vis--; } if (g_rdpScreen.bitsPerPixel > 4) { fbPictureInit(pScreen, 0, 0); } if (!dixRegisterPrivateKey(&g_rdpGCIndex, PRIVATE_GC, sizeof(rdpGCRec))) { FatalError("rdpScreenInit: dixRegisterPrivateKey PRIVATE_GC failed\n"); } if (!dixRegisterPrivateKey(&g_rdpWindowIndex, PRIVATE_WINDOW, sizeof(rdpWindowRec))) { FatalError("rdpScreenInit: dixRegisterPrivateKey PRIVATE_WINDOW failed\n"); } if (!dixRegisterPrivateKey(&g_rdpPixmapIndex, PRIVATE_PIXMAP, sizeof(rdpPixmapRec))) { FatalError("rdpScreenInit: dixRegisterPrivateKey PRIVATE_PIXMAP failed\n"); } /* Random screen procedures */ g_rdpScreen.CloseScreen = pScreen->CloseScreen; /* GC procedures */ g_rdpScreen.CreateGC = pScreen->CreateGC; /* Pixmap procedures */ g_rdpScreen.CreatePixmap = pScreen->CreatePixmap; g_rdpScreen.DestroyPixmap = pScreen->DestroyPixmap; /* Window Procedures */ g_rdpScreen.CreateWindow = pScreen->CreateWindow; g_rdpScreen.DestroyWindow = pScreen->DestroyWindow; g_rdpScreen.ChangeWindowAttributes = pScreen->ChangeWindowAttributes; g_rdpScreen.RealizeWindow = pScreen->RealizeWindow; g_rdpScreen.UnrealizeWindow = pScreen->UnrealizeWindow; g_rdpScreen.PositionWindow = pScreen->PositionWindow; g_rdpScreen.WindowExposures = pScreen->WindowExposures; g_rdpScreen.CopyWindow = pScreen->CopyWindow; g_rdpScreen.ClearToBackground = pScreen->ClearToBackground; /* Backing store procedures */ g_rdpScreen.RestoreAreas = pScreen->RestoreAreas; g_rdpScreen.WakeupHandler = pScreen->WakeupHandler; g_rdpScreen.CreateColormap = pScreen->CreateColormap; g_rdpScreen.DestroyColormap = pScreen->DestroyColormap; ps = GetPictureScreenIfSet(pScreen); if (ps) { g_rdpScreen.CreatePicture = ps->CreatePicture; g_rdpScreen.DestroyPicture = ps->DestroyPicture; g_rdpScreen.Composite = ps->Composite; g_rdpScreen.Glyphs = ps->Glyphs; } pScreen->blackPixel = g_rdpScreen.blackPixel; pScreen->whitePixel = g_rdpScreen.whitePixel; /* Random screen procedures */ pScreen->CloseScreen = rdpCloseScreen; pScreen->WakeupHandler = rdpWakeupHandler; if (ps) { ps->CreatePicture = rdpCreatePicture; ps->DestroyPicture = rdpDestroyPicture; ps->Composite = rdpComposite; ps->Glyphs = rdpGlyphs; } pScreen->SaveScreen = rdpSaveScreen; /* GC procedures */ pScreen->CreateGC = rdpCreateGC; if (g_wrapPixmap) { /* Pixmap procedures */ pScreen->CreatePixmap = rdpCreatePixmap; pScreen->DestroyPixmap = rdpDestroyPixmap; } if (g_wrapWindow) { /* Window Procedures */ pScreen->CreateWindow = rdpCreateWindow; pScreen->DestroyWindow = rdpDestroyWindow; pScreen->ChangeWindowAttributes = rdpChangeWindowAttributes; pScreen->RealizeWindow = rdpRealizeWindow; pScreen->UnrealizeWindow = rdpUnrealizeWindow; pScreen->PositionWindow = rdpPositionWindow; pScreen->WindowExposures = rdpWindowExposures; } pScreen->CopyWindow = rdpCopyWindow; pScreen->ClearToBackground = rdpClearToBackground; /* Backing store procedures */ pScreen->RestoreAreas = rdpRestoreAreas; #if 0 pScreen->CreateColormap = rdpCreateColormap; pScreen->DestroyColormap = rdpDestroyColormap; #endif miPointerInitialize(pScreen, &g_rdpSpritePointerFuncs, &g_rdpPointerCursorFuncs, 1); #if 0 pScreen->DeviceCursorInitialize = rdpDeviceCursorInitialize; pScreen->DeviceCursorCleanup = rdpDeviceCursorCleanup; #endif vis_found = 0; vis = g_pScreen->visuals + (g_pScreen->numVisuals - 1); while (vis >= pScreen->visuals) { if (vis->vid == pScreen->rootVisual) { vis_found = 1; } vis--; } if (!vis_found) { rdpLog("rdpScreenInit: couldn't find root visual\n"); exit(1); } ret = 1; if (ret) { ret = fbCreateDefColormap(pScreen); if (!ret) { ErrorF("rdpScreenInit: fbCreateDefColormap failed\n"); } } if (ret) { ret = rdpup_init(); if (!ret) { ErrorF("rdpScreenInit: rdpup_init failed\n"); } } if (ret) { RegisterBlockAndWakeupHandlers(rdpBlockHandler1, rdpWakeupHandler1, NULL); } if (!RRScreenInit(pScreen)) { ErrorF("rdpmain.c: RRScreenInit: screen init failed\n"); } else { pRRScrPriv = rrGetScrPriv(pScreen); ErrorF("pRRScrPriv %p\n", pRRScrPriv); pRRScrPriv->rrSetConfig = rdpRRSetConfig; pRRScrPriv->rrGetInfo = rdpRRGetInfo; pRRScrPriv->rrScreenSetSize = rdpRRScreenSetSize; pRRScrPriv->rrCrtcSet = rdpRRCrtcSet; pRRScrPriv->rrCrtcGetGamma = rdpRRCrtcGetGamma; pRRScrPriv->rrCrtcSetGamma = rdpRRCrtcSetGamma; pRRScrPriv->rrOutputSetProperty = rdpRROutputSetProperty; pRRScrPriv->rrOutputValidateMode = rdpRROutputValidateMode; pRRScrPriv->rrModeDestroy = rdpRRModeDestroy; pRRScrPriv->rrOutputGetProperty = rdpRROutputGetProperty; pRRScrPriv->rrGetPanning = rdpRRGetPanning; pRRScrPriv->rrSetPanning = rdpRRSetPanning; } rdpGlyphInit(); //rdpXvInit(pScreen); rdpSetUDSRights(); ErrorF("rdpScreenInit: ret %d\n", ret); return ret; } /******************************************************************************/ /* this is the first function called, it can be called many times returns the number or parameters processed if it doesn't apply to the rdp part, return 0 */ int ddxProcessArgument(int argc, char **argv, int i) { if (g_firstTime) { memset(&g_rdpScreen, 0, sizeof(g_rdpScreen)); g_rdpScreen.width = 1024; g_rdpScreen.height = 768; g_rdpScreen.depth = 24; set_bpp(24); g_rdpScreen.blackPixel = 1; g_firstTime = 0; RRExtensionInit(); } if (strcmp(argv[i], "-geometry") == 0) { if (i + 1 >= argc) { UseMsg(); } if (sscanf(argv[i + 1], "%dx%d", &g_rdpScreen.width, &g_rdpScreen.height) != 2) { ErrorF("Invalid geometry %s\n", argv[i + 1]); UseMsg(); } return 2; } if (strcmp(argv[i], "-depth") == 0) { if (i + 1 >= argc) { UseMsg(); } g_rdpScreen.depth = atoi(argv[i + 1]); if (set_bpp(g_rdpScreen.depth) != 0) { UseMsg(); } return 2; } if (strcmp(argv[i], "-uds") == 0) { g_use_uds = 1; return 1; } return 0; } /******************************************************************************/ void OsVendorInit(void) { #if XRDP_DISABLE_LINUX_ABSTRACT /* turn off the Linux abstract unix domain sockets TRANS_ABSTRACT */ /* TRANS_NOLISTEN = 1 << 3 */ _XSERVTransSocketLocalFuncs.flags = 0; #endif } /******************************************************************************/ /* ddxInitGlobals - called by |InitGlobals| from os/util.c */ void ddxInitGlobals(void) { } /******************************************************************************/ int XkbDDXSwitchScreen(DeviceIntPtr dev, KeyCode key, XkbAction *act) { ErrorF("XkbDDXSwitchScreen:\n"); return 1; } /******************************************************************************/ int XkbDDXPrivate(DeviceIntPtr dev, KeyCode key, XkbAction *act) { ErrorF("XkbDDXPrivate:\n"); return 0; } /******************************************************************************/ int XkbDDXTerminateServer(DeviceIntPtr dev, KeyCode key, XkbAction *act) { ErrorF("XkbDDXTerminateServer:\n"); GiveUp(1); return 0; } /******************************************************************************/ /* InitOutput is called every time the server resets. It should call AddScreen for each screen (but we only ever have one), and in turn this will call rdpScreenInit. */ void InitOutput(ScreenInfo *screenInfo, int argc, char **argv) { int i; ErrorF("InitOutput:\n"); g_initOutputCalled = 1; /* initialize pixmap formats */ screenInfo->imageByteOrder = IMAGE_BYTE_ORDER; screenInfo->bitmapScanlineUnit = BITMAP_SCANLINE_UNIT; screenInfo->bitmapScanlinePad = BITMAP_SCANLINE_PAD; screenInfo->bitmapBitOrder = BITMAP_BIT_ORDER; screenInfo->numPixmapFormats = g_numFormats; for (i = 0; i < g_numFormats; i++) { screenInfo->formats[i] = g_formats[i]; } if (!AddCallback(&ClientStateCallback, rdpClientStateChange, NULL)) { rdpLog("InitOutput: AddCallback failed\n"); return; } /* initialize screen */ if (AddScreen(rdpScreenInit, argc, argv) == -1) { FatalError("Couldn't add screen\n"); } ErrorF("InitOutput: out\n"); } /******************************************************************************/ void InitInput(int argc, char **argv) { int rc; ErrorF("InitInput:\n"); rc = AllocDevicePair(serverClient, "X11rdp", &g_pointer, &g_keyboard, rdpMouseProc, rdpKeybdProc, 0); if (rc != Success) { FatalError("Failed to init X11rdp default devices.\n"); } mieqInit(); } /******************************************************************************/ void ddxGiveUp(void) { char unixSocketName[128]; ErrorF("ddxGiveUp:\n"); g_free(g_rdpScreen.pfbMemory); if (g_initOutputCalled) { sprintf(unixSocketName, "/tmp/.X11-unix/X%s", display); unlink(unixSocketName); sprintf(unixSocketName, "%s/xrdp_disconnect_display_%s", g_socket_dir(), display); unlink(unixSocketName); if (g_uds_data[0] != 0) { unlink(g_uds_data); } } } /******************************************************************************/ Bool LegalModifier(unsigned int key, DeviceIntPtr pDev) { return 1; /* true */ } /******************************************************************************/ void ProcessInputEvents(void) { mieqProcessInputEvents(); } /******************************************************************************/ /* needed for some reason? todo needs to be rfb */ void rfbRootPropertyChange(PropertyPtr pProp) { } /******************************************************************************/ void AbortDDX(void) { ddxGiveUp(); } /******************************************************************************/ void OsVendorFatalError(void) { } /******************************************************************************/ /* print the command list parameters and exit the program */ void ddxUseMsg(void) { ErrorF("\n"); ErrorF("X11rdp specific options\n"); ErrorF("-geometry WxH set framebuffer width & height\n"); ErrorF("-depth D set framebuffer depth\n"); ErrorF("-uds create and listen on xrdp_display_x\n"); ErrorF("\n"); exit(1); } /******************************************************************************/ void OsVendorPreInit(void) { } /******************************************************************************/ void CloseInput(void) { ErrorF("CloseInput\n"); } /******************************************************************************/ void DDXRingBell(int volume, int pitch, int duration) { ErrorF("DDXRingBell\n"); } /******************************************************************************/ void DeleteInputDeviceRequest(DeviceIntPtr dev) { ErrorF("DeleteInputDeviceRequest\n"); } xrdp-0.9.5/xorg/X11R7.6/rdp/rdpPolySegment.h000644 001751 001751 00000002036 13125122134 020234 0ustar00metameta000000 000000 /* Copyright 2005-2013 Jay Sorg Permission to use, copy, modify, distribute, and sell this software and its documentation for any purpose is hereby granted without fee, provided that the above copyright notice appear in all copies and that both that copyright notice and this permission notice appear in supporting documentation. The above copyright notice and this permission notice shall be included in all copies or substantial portions of the Software. THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE OPEN GROUP BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. */ #ifndef __RDPPOLYSEGMENT_H #define __RDPPOLYSEGMENT_H void rdpPolySegment(DrawablePtr pDrawable, GCPtr pGC, int nseg, xSegment* pSegs); #endif xrdp-0.9.5/xorg/X11R7.6/rdp/rdpglyph.c000644 001751 001751 00000060760 13127114621 017120 0ustar00metameta000000 000000 /* Copyright 2012 Jay Sorg Permission to use, copy, modify, distribute, and sell this software and its documentation for any purpose is hereby granted without fee, provided that the above copyright notice appear in all copies and that both that copyright notice and this permission notice appear in supporting documentation. The above copyright notice and this permission notice shall be included in all copies or substantial portions of the Software. THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE OPEN GROUP BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. */ /* http://msdn.microsoft.com/en-us/library/cc241863(v=prot.20).aspx 4.6.1 "d" Character This topic has not yet been rated - Rate this topic The following shows glyph image data (1 bpp format) for character "d" extracted from a Cache Glyph (Revision 2) (section 2.2.2.2.1.2.6) Secondary Drawing Order. Glyph width = 5 pixels Glyph height = 9 pixels Glyph origin = (0, -9), marked with an "X" on the image grid Bitmap = { 0x08, 0x08, 0x08, 0x78, 0x88, 0x88, 0x88, 0x88, 0x78 } http://msdn.microsoft.com/en-us/library/cc241864(v=prot.20).aspx 4.6.2 "p" Character This topic has not yet been rated - Rate this topic The following shows glyph image data (1 bpp format) for character "p" extracted from a Cache Glyph (Revision 2) (section 2.2.2.2.1.2.6) Secondary Drawing Order. Glyph width = 5 pixels Glyph height = 8 pixels Glyph origin = (0, -6), marked with an "X" on the image grid Bitmap = { 0xF0, 0x88, 0x88, 0x88, 0x88, 0xF0, 0x80, 0x80 } */ #include "rdp.h" #include "rdpdraw.h" #include "rdpglyph.h" extern DevPrivateKeyRec g_rdpPixmapIndex; /* from rdpmain.c */ extern int g_do_dirty_os; /* in rdpmain.c */ extern int g_do_alpha_glyphs; /* in rdpmain.c */ extern int g_do_glyph_cache; /* in rdpmain.c */ extern int g_doing_font; /* in rdpmain.c */ extern ScreenPtr g_pScreen; /* in rdpmain.c */ extern rdpScreenInfoRec g_rdpScreen; /* in rdpmain.c */ #define LOG_LEVEL 1 #define LLOG(_level, _args) \ do { if (_level < LOG_LEVEL) { ErrorF _args ; } } while (0) #define LLOGLN(_level, _args) \ do { if (_level < LOG_LEVEL) { ErrorF _args ; ErrorF("\n"); } } while (0) struct font_cache { int offset; int baseline; int width; int height; int crc; int stamp; }; static struct font_cache g_font_cache[12][256]; static int g_stamp = 0; /*****************************************************************************/ static void set_mono_pixel(char* data, int x, int y, int width, int pixel) { int start; int shift; width = (width + 7) / 8; start = (y * width) + x / 8; shift = x % 8; if (pixel != 0) { data[start] = data[start] | (0x80 >> shift); } else { data[start] = data[start] & ~(0x80 >> shift); } } /*****************************************************************************/ static int lget_pixel(char* data, int x, int y, int depth, int stride_bytes) { int start; int shift; if (depth == 1) { start = (y * stride_bytes) + x / 8; shift = x % 8; return (data[start] & (0x01 << shift)) ? 0xff : 0; } else if (depth == 8) { return data[y * stride_bytes + x]; } return 0; } /******************************************************************************/ static int glyph_get_data(ScreenPtr pScreen, GlyphPtr glyph, struct rdp_font_char* rfd) { int i; int j; int src_xoff; int src_yoff; int src_stride_bytes; int dst_stride_bytes; int hh; int ww; int src_depth; unsigned char pixel; PicturePtr pPicture; pixman_image_t *src; uint32_t* pi32; char* pi8; pPicture = GlyphPicture(glyph)[pScreen->myNum]; if (pPicture == 0) { return 0; } src = image_from_pict(pPicture, FALSE, &src_xoff, &src_yoff); if (src == 0) { return 0; } src_stride_bytes = pixman_image_get_stride(src); if (g_do_alpha_glyphs) { dst_stride_bytes = (glyph->info.width + 3) & ~3; rfd->bpp = 8; } else { dst_stride_bytes = (((glyph->info.width + 7) / 8) + 3) & ~3; rfd->bpp = 1; } src_depth = pixman_image_get_depth(src); ww = pixman_image_get_width(src); hh = pixman_image_get_height(src); if ((ww != glyph->info.width) || (hh != glyph->info.height) || ((src_depth != 1) && (src_depth != 8))) { LLOGLN(0, ("glyph_get_data: bad glyph")); free_pixman_pict(pPicture, src); return 0; } rfd->data_bytes = glyph->info.height * dst_stride_bytes; rfd->data = (char*)g_malloc(rfd->data_bytes, 1); rfd->offset = -glyph->info.x; rfd->baseline = -glyph->info.y; rfd->width = glyph->info.width; rfd->height = glyph->info.height; pi32 = pixman_image_get_data(src); pi8 = (char*)pi32; for (j = 0; j < rfd->height; j++) { for (i = 0; i < rfd->width; i++) { pixel = lget_pixel(pi8, i, j, src_depth, src_stride_bytes); if (g_do_alpha_glyphs) { rfd->data[j * dst_stride_bytes + i] = pixel; } else { if (pixel > 0x7f) { set_mono_pixel(rfd->data, i, j, rfd->width, 1); } else { set_mono_pixel(rfd->data, i, j, rfd->width, 0); } } } } free_pixman_pict(pPicture, src); return 0; } /******************************************************************************/ struct rdp_text* create_rdp_text(ScreenPtr pScreen, int nlists, GlyphListPtr lists, GlyphPtr* glyphs) { struct rdp_text* rv; struct rdp_text* rtext; struct rdp_text* last_rtext; BoxRec box; RegionRec reg1; int n; int lxoff; int lyoff; int count; int lx; int ly; int font_index; int max_height; int min_height; int force_new; GlyphPtr glyph; struct rdp_font_char* rfd; LLOGLN(10, ("create_rdp_text: nlists %d", nlists)); max_height = 0; min_height = 0x7fffffff; lx = lists->xOff; ly = lists->yOff; lxoff = 0; lyoff = 0; force_new = 0; rtext = (struct rdp_text*)g_malloc(sizeof(struct rdp_text), 1); rtext->reg = RegionCreate(NullBox, 0); rtext->flags = 3; rtext->mixmode = 0; rtext->x = lx; rtext->y = ly; rv = rtext; last_rtext = rtext; count = 0; while (nlists--) { LLOGLN(10, ("lists->xOff %d lists->yOff %d", lists->xOff, lists->yOff)); if (count != 0) { lx += lists->xOff; ly += lists->yOff; force_new = 1; } count++; n = lists->len; lists++; while (n--) { glyph = *glyphs++; /* process glyph here */ if ((glyph->info.width > 0) && (glyph->info.height > 0)) { if (force_new) { LLOGLN(10, ("create_rdp_text: too many chars")); force_new = 0; rtext = (struct rdp_text*)g_malloc(sizeof(struct rdp_text), 1); rtext->reg = RegionCreate(NullBox, 0); rtext->flags = 3; rtext->mixmode = 0; rtext->x = lx; rtext->y = ly; last_rtext->next = rtext; last_rtext = rtext; lxoff = 0; lyoff = 0; } LLOGLN(10, ("x %d y %d width %d height %d xOff %d yOff %d " "num_chars %d lxoff %d lyoff %d lx %d ly %d", glyph->info.x, glyph->info.y, glyph->info.width, glyph->info.height, glyph->info.xOff, glyph->info.yOff, rtext->num_chars, lxoff, lyoff, lx, ly)); rfd = (struct rdp_font_char*)g_malloc(sizeof(struct rdp_font_char), 1); rtext->chars[rtext->num_chars] = rfd; box.x1 = lx - glyph->info.x; box.y1 = ly - glyph->info.y; box.x2 = box.x1 + glyph->info.width; box.y2 = box.y1 + glyph->info.height; if (glyph->info.height > max_height) { max_height = glyph->info.height; } if (glyph->info.height < min_height) { min_height = glyph->info.height; } RegionInit(®1, &box, 0); RegionUnion(rtext->reg, ®1, rtext->reg); RegionUninit(®1); glyph_get_data(pScreen, glyph, rfd); rfd->incby = lxoff; lxoff = glyph->info.xOff; lyoff = glyph->info.yOff; rtext->num_chars++; if (rtext->num_chars > 63) { force_new = 1; } } else { lxoff += glyph->info.xOff; lyoff += glyph->info.yOff; } lx += glyph->info.xOff; ly += glyph->info.yOff; } } if (max_height > 10) { font_index = 8; } else if (max_height < 7) { font_index = 6; } else { font_index = 7; } LLOGLN(10, ("create_rdp_text: min_height %d max_height %d font_index %d", min_height, max_height, font_index)); rtext = rv; while (rtext != 0) { rtext->font = font_index; rtext = rtext->next; } return rv; } /******************************************************************************/ int delete_rdp_text(struct rdp_text* rtext) { int index; if (rtext == 0) { return 0; } for (index = 0; index < rtext->num_chars; index++) { if (rtext->chars[index] != 0) { g_free(rtext->chars[index]->data); g_free(rtext->chars[index]); } } RegionDestroy(rtext->reg); delete_rdp_text(rtext->next); g_free(rtext); return 0; } /******************************************************************************/ static int get_color(PicturePtr pPicture) { int src_xoff; int src_yoff; int rv; uint32_t* pi32; pixman_image_t *src; src = image_from_pict(pPicture, FALSE, &src_xoff, &src_yoff); if (src == 0) { return 0; } pi32 = pixman_image_get_data(src); if (pi32 == 0) { return 0; } rv = *pi32; LLOGLN(10, ("get_color: 0x%8.8x width %d height %d ", rv, pixman_image_get_width(src), pixman_image_get_height(src))); free_pixman_pict(pPicture, src); return rv; } /******************************************************************************/ static int find_or_add_char(int font, struct rdp_font_char* rfd) { int crc; int index; int char_index; int oldest; crc = get_crc(rfd->data, rfd->data_bytes); LLOGLN(10, ("find_or_add_char: crc 0x%8.8x", crc)); char_index = 0; oldest = 0x7fffffff; for (index = 0; index < 250; index++) { if ((g_font_cache[font][index].crc == crc) && (g_font_cache[font][index].width == rfd->width) && (g_font_cache[font][index].height == rfd->height) && (g_font_cache[font][index].offset == rfd->offset) && (g_font_cache[font][index].baseline == rfd->baseline)) { g_stamp++; g_font_cache[font][index].stamp = g_stamp; LLOGLN(10, ("find_or_add_char: found char at %d %d", font, index)); return index; } if (g_font_cache[font][index].stamp < oldest) { oldest = g_font_cache[font][index].stamp; char_index = index; } } g_stamp++; g_font_cache[font][char_index].stamp = g_stamp; g_font_cache[font][char_index].crc = crc; g_font_cache[font][char_index].width = rfd->width; g_font_cache[font][char_index].height = rfd->height; g_font_cache[font][char_index].offset = rfd->offset; g_font_cache[font][char_index].baseline = rfd->baseline; LLOGLN(10, ("find_or_add_char: adding char at %d %d", font, char_index)); if (rfd->bpp == 8) { rdpup_add_char_alpha(font, char_index, rfd->offset, rfd->baseline, rfd->width, rfd->height, rfd->data, rfd->data_bytes); } else { rdpup_add_char(font, char_index, rfd->offset, rfd->baseline, rfd->width, rfd->height, rfd->data, rfd->data_bytes); } return char_index; } /******************************************************************************/ int rdp_text_chars_to_data(struct rdp_text* rtext) { int index; int data_bytes; int char_index; struct rdp_font_char* rfd; LLOGLN(10, ("rdp_text_chars_to_data: rtext->num_chars %d", rtext->num_chars)); data_bytes = 0; for (index = 0; index < rtext->num_chars; index++) { rfd = rtext->chars[index]; if (rfd == 0) { LLOGLN(0, ("rdp_text_chars_to_data: error rfd is nil")); continue; } char_index = find_or_add_char(rtext->font, rfd); rtext->data[data_bytes] = char_index; data_bytes++; if (rfd->incby > 127) { rtext->data[data_bytes] = 0x80; data_bytes++; rtext->data[data_bytes] = (rfd->incby >> 0) & 0xff; data_bytes++; rtext->data[data_bytes] = (rfd->incby >> 8) & 0xff; data_bytes++; } else { rtext->data[data_bytes] = rfd->incby; data_bytes++; } } rtext->data_bytes = data_bytes; return 0; } /******************************************************************************/ /* typedef struct _GlyphList { INT16 xOff; INT16 yOff; CARD8 len; PictFormatPtr format; } GlyphListRec, *GlyphListPtr; */ /* see glyphstr.h but the following is not in there typedef struct _XGlyphInfo { unsigned short width; unsigned short height; short x; short y; short xOff; short yOff; } XGlyphInfo; */ static void rdpGlyphu(CARD8 op, PicturePtr pSrc, PicturePtr pDst, PictFormatPtr maskFormat, INT16 xSrc, INT16 ySrc, int nlists, GlyphListPtr lists, GlyphPtr* glyphs, BoxPtr extents) { BoxRec box; RegionRec reg1; RegionRec reg2; DrawablePtr p; int dirty_type; int j; int num_clips; int post_process; int reset_surface; int got_id; int fg_color; WindowPtr pDstWnd; PixmapPtr pDstPixmap; rdpPixmapRec* pDstPriv; rdpPixmapRec* pDirtyPriv; struct image_data id; struct rdp_text* rtext; struct rdp_text* trtext; LLOGLN(10, ("rdpGlyphu: xSrc %d ySrc %d", xSrc, ySrc)); p = pDst->pDrawable; dirty_type = 0; pDirtyPriv = 0; post_process = 0; reset_surface = 0; got_id = 0; if (p->type == DRAWABLE_PIXMAP) { pDstPixmap = (PixmapPtr)p; pDstPriv = GETPIXPRIV(pDstPixmap); if (XRDP_IS_OS(pDstPriv)) { rdpup_check_dirty(pDstPixmap, pDstPriv); post_process = 1; if (g_do_dirty_os) { LLOGLN(10, ("rdpGlyphu: getting dirty")); pDstPriv->is_dirty = 1; dirty_type = RDI_IMGLL; pDirtyPriv = pDstPriv; } else { rdpup_switch_os_surface(pDstPriv->rdpindex); reset_surface = 1; rdpup_get_pixmap_image_rect(pDstPixmap, &id); got_id = 1; LLOGLN(10, ("rdpGlyphu: offscreen")); } } } else { if (p->type == DRAWABLE_WINDOW) { pDstWnd = (WindowPtr)p; if (pDstWnd->viewable) { post_process = 1; rdpup_get_screen_image_rect(&id); got_id = 1; LLOGLN(10, ("rdpGlyphu: screen")); } } } if (!post_process) { return; } rtext = create_rdp_text(pDst->pDrawable->pScreen, nlists, lists, glyphs); if (rtext == 0) { LLOGLN(0, ("rdpGlyphu: create_rdp_text failed")); return; } fg_color = get_color(pSrc); LLOGLN(10, ("rdpGlyphu: pDst->clientClipType %d pCompositeClip %p", pDst->clientClipType, pDst->pCompositeClip)); if (pDst->pCompositeClip != 0) { box.x1 = p->x + extents->x1; box.y1 = p->y + extents->y1; box.x2 = p->x + extents->x2; box.y2 = p->y + extents->y2; RegionInit(®1, &box, 0); RegionInit(®2, NullBox, 0); RegionCopy(®2, pDst->pCompositeClip); RegionIntersect(®1, ®1, ®2); if (dirty_type != 0) { LLOGLN(10, ("1")); draw_item_add_text_region(pDirtyPriv, ®1, fg_color, GXcopy, rtext); rtext = 0; } else if (got_id) { num_clips = REGION_NUM_RECTS(®1); if (num_clips > 0) { LLOGLN(10, (" num_clips %d", num_clips)); rdpup_begin_update(); rdpup_set_fgcolor(fg_color); trtext = rtext; while (trtext != 0) { rdp_text_chars_to_data(trtext); for (j = num_clips - 1; j >= 0; j--) { box = REGION_RECTS(®1)[j]; LLOGLN(10, ("2")); rdpup_set_clip(box.x1, box.y1, box.x2 - box.x1, box.y2 - box.y1); LLOGLN(10, ("rdpGlyphu: rdpup_draw_text")); box = RegionExtents(trtext->reg)[0]; rdpup_draw_text(trtext->font, trtext->flags, trtext->mixmode, box.x1 + p->x, box.y1 + p->y, box.x2 + p->x, box.y2 + p->y, //box.x1 + p->x, box.y1 + p->y, //box.x2 + p->x, box.y2 + p->y, 0, 0, 0, 0, trtext->x + p->x, trtext->y + p->y, trtext->data, trtext->data_bytes); } trtext = trtext->next; } rdpup_reset_clip(); rdpup_end_update(); } } RegionUninit(®1); RegionUninit(®2); } else { box.x1 = p->x + extents->x1; box.y1 = p->y + extents->y1; box.x2 = p->x + extents->x2; box.y2 = p->y + extents->y2; if (dirty_type != 0) { RegionInit(®1, &box, 0); LLOGLN(10, ("3")); draw_item_add_text_region(pDirtyPriv, ®1, fg_color, GXcopy, rtext); rtext = 0; RegionUninit(®1); } else if (got_id) { rdpup_begin_update(); LLOGLN(10, ("4")); rdpup_set_fgcolor(fg_color); trtext = rtext; while (trtext != 0) { LLOGLN(10, ("rdpGlyphu: rdpup_draw_text")); rdp_text_chars_to_data(trtext); box = RegionExtents(trtext->reg)[0]; rdpup_draw_text(trtext->font, trtext->flags, trtext->mixmode, box.x1 + p->x, box.y1 + p->y, box.x2 + p->x, box.y2 + p->y, //box.x1 + p->x, box.y1 + p->y, //box.x2 + p->x, box.y2 + p->y, 0, 0, 0, 0, trtext->x + p->x, trtext->y + p->y, trtext->data, trtext->data_bytes); trtext = trtext->next; } rdpup_end_update(); } } if (reset_surface) { rdpup_switch_os_surface(-1); } delete_rdp_text(rtext); } /******************************************************************************/ static void GlyphExtents(int nlist, GlyphListPtr list, GlyphPtr* glyphs, BoxPtr extents) { int x1; int x2; int y1; int y2; int n; int x; int y; GlyphPtr glyph; x = 0; y = 0; extents->x1 = MAXSHORT; extents->x2 = MINSHORT; extents->y1 = MAXSHORT; extents->y2 = MINSHORT; while (nlist--) { x += list->xOff; y += list->yOff; n = list->len; list++; while (n--) { glyph = *glyphs++; x1 = x - glyph->info.x; if (x1 < MINSHORT) { x1 = MINSHORT; } y1 = y - glyph->info.y; if (y1 < MINSHORT) { y1 = MINSHORT; } x2 = x1 + glyph->info.width; if (x2 > MAXSHORT) { x2 = MAXSHORT; } y2 = y1 + glyph->info.height; if (y2 > MAXSHORT) { y2 = MAXSHORT; } if (x1 < extents->x1) { extents->x1 = x1; } if (x2 > extents->x2) { extents->x2 = x2; } if (y1 < extents->y1) { extents->y1 = y1; } if (y2 > extents->y2) { extents->y2 = y2; } x += glyph->info.xOff; y += glyph->info.yOff; } } } /******************************************************************************/ static void rdpGlypht(CARD8 op, PicturePtr pSrc, PicturePtr pDst, PictFormatPtr maskFormat, INT16 xSrc, INT16 ySrc, int nlists, GlyphListPtr lists, GlyphPtr* glyphs) { BoxRec extents; GlyphExtents(nlists, lists, glyphs, &extents); if ((extents.x2 <= extents.x1) || (extents.y2 <= extents.y1)) { return; } rdpGlyphu(op, pSrc, pDst, maskFormat, xSrc, ySrc, nlists, lists, glyphs, &extents); } /******************************************************************************/ /* make sure no glyph is too big */ /* returns boolean */ static int rdpGlyphCheck(int nlist, GlyphListPtr list, GlyphPtr* glyphs) { int n; GlyphPtr glyph; while (nlist--) { n = list->len; list++; while (n--) { glyph = *glyphs++; if ((glyph->info.width * glyph->info.height) > 8192) { LLOGLN(10, ("rdpGlyphCheck: too big")); return 0; } } } return 1; } /******************************************************************************/ void rdpGlyphs(CARD8 op, PicturePtr pSrc, PicturePtr pDst, PictFormatPtr maskFormat, INT16 xSrc, INT16 ySrc, int nlists, GlyphListPtr lists, GlyphPtr* glyphs) { PictureScreenPtr ps; LLOGLN(10, ("rdpGlyphs: op %d xSrc %d ySrc %d maskFormat %p", op, xSrc, ySrc, maskFormat)); LLOGLN(10, ("rdpGlyphs: g_do_glyph_cache %d", g_do_glyph_cache)); if (g_do_glyph_cache && rdpGlyphCheck(nlists, lists, glyphs)) { g_doing_font = 2; rdpGlypht(op, pSrc, pDst, maskFormat, xSrc, ySrc, nlists, lists, glyphs); ps = GetPictureScreen(g_pScreen); ps->Glyphs = g_rdpScreen.Glyphs; ps->Glyphs(op, pSrc, pDst, maskFormat, xSrc, ySrc, nlists, lists, glyphs); ps->Glyphs = rdpGlyphs; } else { g_doing_font = 1; rdpup_set_hints(1, 1); ps = GetPictureScreen(g_pScreen); ps->Glyphs = g_rdpScreen.Glyphs; ps->Glyphs(op, pSrc, pDst, maskFormat, xSrc, ySrc, nlists, lists, glyphs); ps->Glyphs = rdpGlyphs; rdpup_set_hints(0, 1); } g_doing_font = 0; LLOGLN(10, ("rdpGlyphs: out")); } /******************************************************************************/ int rdpGlyphInit(void) { memset(&g_font_cache, 0, sizeof(g_font_cache)); return 0; } xrdp-0.9.5/xorg/X11R7.6/rdp/rdpup.c000644 001751 001751 00000245411 13174271344 016427 0ustar00metameta000000 000000 /* Copyright 2005-2013 Jay Sorg Permission to use, copy, modify, distribute, and sell this software and its documentation for any purpose is hereby granted without fee, provided that the above copyright notice appear in all copies and that both that copyright notice and this permission notice appear in supporting documentation. The above copyright notice and this permission notice shall be included in all copies or substantial portions of the Software. THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE OPEN GROUP BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. */ #include "rdp.h" #include "xrdp_rail.h" #include "rdpglyph.h" #include "rdprandr.h" #include #include #include #include #define LOG_LEVEL 1 #define LLOG(_level, _args) \ do { if (_level < LOG_LEVEL) { ErrorF _args ; } } while (0) #define LLOGLN(_level, _args) \ do { if (_level < LOG_LEVEL) { ErrorF _args ; ErrorF("\n"); } } while (0) static int g_use_shmem = 1; /* turns on or off */ static int g_shmemid = -1; static char *g_shmemptr = 0; static int g_shmem_lineBytes = 0; static RegionPtr g_shm_reg = 0; static int g_rect_id_ack = 0; static int g_rect_id = 0; static int g_listen_sck = 0; static int g_sck = 0; static int g_sck_closed = 0; static int g_connected = 0; static int g_dis_listen_sck = 0; //static int g_dis_sck = 0; //static int g_dis_sck_closed = 0; //static int g_dis_connected = 0; static int g_begin = 0; static struct stream *g_out_s = 0; static struct stream *g_in_s = 0; static int g_button_mask = 0; static int g_cursor_x = 0; static int g_cursor_y = 0; static OsTimerPtr g_timer = 0; static int g_scheduled = 0; static int g_count = 0; static int g_rdpindex = -1; extern DevPrivateKeyRec g_rdpWindowIndex; /* from rdpmain.c */ extern ScreenPtr g_pScreen; /* from rdpmain.c */ extern int g_Bpp; /* from rdpmain.c */ extern int g_Bpp_mask; /* from rdpmain.c */ extern rdpScreenInfoRec g_rdpScreen; /* from rdpmain.c */ extern int g_do_glyph_cache; /* from rdpmain.c */ extern int g_can_do_pix_to_pix; /* from rdpmain.c */ extern int g_use_rail; /* from rdpmain.c */ extern int g_do_composite; /* from rdpmain.c */ /* true is to use unix domain socket */ extern int g_use_uds; /* in rdpmain.c */ extern char g_uds_data[]; /* in rdpmain.c */ extern int g_do_dirty_ons; /* in rdpmain.c */ extern rdpPixmapRec g_screenPriv; /* in rdpmain.c */ extern int g_con_number; /* in rdpmain.c */ struct rdpup_os_bitmap { int used; PixmapPtr pixmap; rdpPixmapPtr priv; int stamp; }; #define USE_MAX_OS_BYTES 1 #define MAX_OS_BYTES (16 * 1024 * 1024) static struct rdpup_os_bitmap *g_os_bitmaps = 0; static int g_max_os_bitmaps = 0; static int g_os_bitmap_stamp = 0; static int g_os_bitmap_alloc_size = 0; static int g_pixmap_byte_total = 0; static int g_pixmap_num_used = 0; struct rdpup_top_window { WindowPtr wnd; struct rdpup_top_window *next; }; /* 0 GXclear, 0 1 GXnor, DPon 2 GXandInverted, DPna 3 GXcopyInverted, Pn 4 GXandReverse, PDna 5 GXinvert, Dn 6 GXxor, DPx 7 GXnand, DPan 8 GXand, DPa 9 GXequiv, DPxn a GXnoop, D b GXorInverted, DPno c GXcopy, P d GXorReverse, PDno e GXor, DPo f GXset 1 */ static int g_rdp_opcodes[16] = { 0x00, /* GXclear 0x0 0 */ 0x88, /* GXand 0x1 src AND dst */ 0x44, /* GXandReverse 0x2 src AND NOT dst */ 0xcc, /* GXcopy 0x3 src */ 0x22, /* GXandInverted 0x4 NOT src AND dst */ 0xaa, /* GXnoop 0x5 dst */ 0x66, /* GXxor 0x6 src XOR dst */ 0xee, /* GXor 0x7 src OR dst */ 0x11, /* GXnor 0x8 NOT src AND NOT dst */ 0x99, /* GXequiv 0x9 NOT src XOR dst */ 0x55, /* GXinvert 0xa NOT dst */ 0xdd, /* GXorReverse 0xb src OR NOT dst */ 0x33, /* GXcopyInverted 0xc NOT src */ 0xbb, /* GXorInverted 0xd NOT src OR dst */ 0x77, /* GXnand 0xe NOT src OR NOT dst */ 0xff /* GXset 0xf 1 */ }; static int g_do_kill_disconnected = 0; /* turn on or off */ static OsTimerPtr g_dis_timer = 0; static int g_disconnect_scheduled = 0; static CARD32 g_disconnect_timeout_s = 60; /* 60 seconds */ static CARD32 g_disconnect_time_ms = 0; /* time of disconnect in milliseconds */ static int g_do_multimon = 0; /* multimon - turn on or off */ /******************************************************************************/ static CARD32 rdpDeferredDisconnectCallback(OsTimerPtr timer, CARD32 now, pointer arg) { CARD32 lnow_ms; LLOGLN(10, ("rdpDeferredDisconnectCallback")); if (g_connected) { /* this should not happen */ LLOGLN(0, ("rdpDeferredDisconnectCallback: connected")); if (g_dis_timer != 0) { LLOGLN(0, ("rdpDeferredDisconnectCallback: canceling g_dis_timer")); TimerCancel(g_dis_timer); TimerFree(g_dis_timer); g_dis_timer = 0; } g_disconnect_scheduled = 0; return 0; } else { LLOGLN(10, ("rdpDeferredDisconnectCallback: not connected")); } lnow_ms = GetTimeInMillis(); if (lnow_ms - g_disconnect_time_ms > g_disconnect_timeout_s * 1000) { LLOGLN(0, ("rdpDeferredDisconnectCallback: exit X11rdp")); kill(getpid(), SIGTERM); return 0; } g_dis_timer = TimerSet(g_dis_timer, 0, 1000 * 10, rdpDeferredDisconnectCallback, 0); return 0; } /*****************************************************************************/ static int rdpup_disconnect(void) { int index; LLOGLN(0, ("rdpup_disconnect:")); if (g_do_kill_disconnected) { if (!g_disconnect_scheduled) { LLOGLN(0, ("rdpup_disconnect: starting g_dis_timer")); g_dis_timer = TimerSet(g_dis_timer, 0, 1000 * 10, rdpDeferredDisconnectCallback, 0); g_disconnect_scheduled = 1; } g_disconnect_time_ms = GetTimeInMillis(); } RemoveEnabledDevice(g_sck); g_connected = 0; g_tcp_close(g_sck); g_sck = 0; g_sck_closed = 1; g_pixmap_byte_total = 0; g_pixmap_num_used = 0; g_rdpindex = -1; if (g_max_os_bitmaps > 0) { for (index = 0; index < g_max_os_bitmaps; index++) { if (g_os_bitmaps[index].used) { if (g_os_bitmaps[index].priv != 0) { g_os_bitmaps[index].priv->status = 0; } } } } g_os_bitmap_alloc_size = 0; g_max_os_bitmaps = 0; g_free(g_os_bitmaps); g_os_bitmaps = 0; g_use_rail = 0; g_do_glyph_cache = 0; g_do_composite = 0; return 0; } /*****************************************************************************/ /* returns -1 on error */ int rdpup_add_os_bitmap(PixmapPtr pixmap, rdpPixmapPtr priv) { int index; int rv; int oldest; int oldest_index; int this_bytes; LLOGLN(10, ("rdpup_add_os_bitmap:")); if (!g_connected) { LLOGLN(10, ("rdpup_add_os_bitmap: test error 1")); return -1; } if (g_os_bitmaps == 0) { LLOGLN(10, ("rdpup_add_os_bitmap: test error 2")); return -1; } this_bytes = pixmap->devKind * pixmap->drawable.height; if (this_bytes > MAX_OS_BYTES) { LLOGLN(10, ("rdpup_add_os_bitmap: error, too big this_bytes %d " "width %d height %d", this_bytes, pixmap->drawable.height, pixmap->drawable.height)); return -1; } oldest = 0x7fffffff; oldest_index = -1; rv = -1; index = 0; while (index < g_max_os_bitmaps) { if (g_os_bitmaps[index].used == 0) { g_os_bitmaps[index].used = 1; g_os_bitmaps[index].pixmap = pixmap; g_os_bitmaps[index].priv = priv; g_os_bitmaps[index].stamp = g_os_bitmap_stamp; g_os_bitmap_stamp++; g_pixmap_num_used++; rv = index; break; } else { if (g_os_bitmaps[index].stamp < oldest) { oldest = g_os_bitmaps[index].stamp; oldest_index = index; } } index++; } if (rv == -1) { if (oldest_index == -1) { LLOGLN(0, ("rdpup_add_os_bitmap: error")); } else { LLOGLN(10, ("rdpup_add_os_bitmap: too many pixmaps removing " "oldest_index %d", oldest_index)); rdpup_remove_os_bitmap(oldest_index); rdpup_delete_os_surface(oldest_index); g_os_bitmaps[oldest_index].used = 1; g_os_bitmaps[oldest_index].pixmap = pixmap; g_os_bitmaps[oldest_index].priv = priv; g_os_bitmaps[oldest_index].stamp = g_os_bitmap_stamp; g_os_bitmap_stamp++; g_pixmap_num_used++; rv = oldest_index; } } if (rv < 0) { LLOGLN(10, ("rdpup_add_os_bitmap: test error 3")); return rv; } g_os_bitmap_alloc_size += this_bytes; LLOGLN(10, ("rdpup_add_os_bitmap: this_bytes %d g_os_bitmap_alloc_size %d", this_bytes, g_os_bitmap_alloc_size)); #if USE_MAX_OS_BYTES while (g_os_bitmap_alloc_size > MAX_OS_BYTES) { LLOGLN(10, ("rdpup_add_os_bitmap: must delete g_pixmap_num_used %d", g_pixmap_num_used)); /* find oldest */ oldest = 0x7fffffff; oldest_index = -1; index = 0; while (index < g_max_os_bitmaps) { if (g_os_bitmaps[index].used && (g_os_bitmaps[index].stamp < oldest)) { oldest = g_os_bitmaps[index].stamp; oldest_index = index; } index++; } if (oldest_index == -1) { LLOGLN(0, ("rdpup_add_os_bitmap: error 1")); break; } if (oldest_index == rv) { LLOGLN(0, ("rdpup_add_os_bitmap: error 2")); break; } rdpup_remove_os_bitmap(oldest_index); rdpup_delete_os_surface(oldest_index); } #endif LLOGLN(10, ("rdpup_add_os_bitmap: new bitmap index %d", rv)); LLOGLN(10, ("rdpup_add_os_bitmap: g_pixmap_num_used %d " "g_os_bitmap_stamp 0x%8.8x", g_pixmap_num_used, g_os_bitmap_stamp)); return rv; } /*****************************************************************************/ int rdpup_remove_os_bitmap(int rdpindex) { PixmapPtr pixmap; rdpPixmapPtr priv; int this_bytes; LLOGLN(10, ("rdpup_remove_os_bitmap: index %d stamp %d", rdpindex, g_os_bitmaps[rdpindex].stamp)); if (g_os_bitmaps == 0) { LLOGLN(10, ("rdpup_remove_os_bitmap: test error 1")); return 1; } if ((rdpindex < 0) && (rdpindex >= g_max_os_bitmaps)) { LLOGLN(10, ("rdpup_remove_os_bitmap: test error 2")); return 1; } if (g_os_bitmaps[rdpindex].used) { pixmap = g_os_bitmaps[rdpindex].pixmap; priv = g_os_bitmaps[rdpindex].priv; draw_item_remove_all(priv); this_bytes = pixmap->devKind * pixmap->drawable.height; g_os_bitmap_alloc_size -= this_bytes; LLOGLN(10, ("rdpup_remove_os_bitmap: this_bytes %d " "g_os_bitmap_alloc_size %d", this_bytes, g_os_bitmap_alloc_size)); g_os_bitmaps[rdpindex].used = 0; g_os_bitmaps[rdpindex].pixmap = 0; g_os_bitmaps[rdpindex].priv = 0; g_pixmap_num_used--; priv->status = 0; priv->con_number = 0; priv->use_count = 0; } else { LLOGLN(0, ("rdpup_remove_os_bitmap: error")); } LLOGLN(10, ("rdpup_remove_os_bitmap: g_pixmap_num_used %d", g_pixmap_num_used)); return 0; } /*****************************************************************************/ int rdpup_update_os_use(int rdpindex) { LLOGLN(10, ("rdpup_update_use: index %d stamp %d", rdpindex, g_os_bitmaps[rdpindex].stamp)); if (g_os_bitmaps == 0) { return 1; } if ((rdpindex < 0) && (rdpindex >= g_max_os_bitmaps)) { return 1; } if (g_os_bitmaps[rdpindex].used) { g_os_bitmaps[rdpindex].stamp = g_os_bitmap_stamp; g_os_bitmap_stamp++; } else { LLOGLN(0, ("rdpup_update_use: error rdpindex %d", rdpindex)); } return 0; } /*****************************************************************************/ /* returns error */ static int rdpup_send(char *data, int len) { int sent; LLOGLN(10, ("rdpup_send - sending %d bytes", len)); if (g_sck_closed) { return 1; } while (len > 0) { sent = g_tcp_send(g_sck, data, len, 0); if (sent == -1) { if (g_tcp_last_error_would_block(g_sck)) { g_sleep(1); } else { LLOGLN(0, ("rdpup_send: g_tcp_send failed(returned -1)")); rdpup_disconnect(); return 1; } } else if (sent == 0) { LLOGLN(0, ("rdpup_send: g_tcp_send failed(returned zero)")); rdpup_disconnect(); return 1; } else { data += sent; len -= sent; } } return 0; } /******************************************************************************/ static int rdpup_send_msg(struct stream *s) { int len; int rv; rv = 1; if (s != 0) { len = (int)(s->end - s->data); if (len > s->size) { rdpLog("overrun error len %d count %d\n", len, g_count); } s_pop_layer(s, iso_hdr); out_uint16_le(s, 3); out_uint16_le(s, g_count); out_uint32_le(s, len - 8); rv = rdpup_send(s->data, len); } if (rv != 0) { rdpLog("error in rdpup_send_msg\n"); } return rv; } /******************************************************************************/ static int rdpup_send_pending(void) { int rv; rv = 0; if (g_connected && g_begin) { LLOGLN(10, ("end %d", g_count)); out_uint16_le(g_out_s, 2); out_uint16_le(g_out_s, 4); g_count++; s_mark_end(g_out_s); if (rdpup_send_msg(g_out_s) != 0) { LLOGLN(0, ("rdpup_send_pending: rdpup_send_msg failed")); rv = 1; } } g_count = 0; g_begin = 0; return rv; } /******************************************************************************/ static CARD32 rdpDeferredUpdateCallback(OsTimerPtr timer, CARD32 now, pointer arg) { LLOGLN(10, ("rdpDeferredUpdateCallback")); if (g_do_dirty_ons) { if (g_rect_id == g_rect_id_ack) { rdpup_check_dirty_screen(&g_screenPriv); } else { LLOGLN(0, ("rdpDeferredUpdateCallback: skipping")); } } else { rdpup_send_pending(); } g_scheduled = 0; return 0; } /******************************************************************************/ void rdpScheduleDeferredUpdate(void) { if (!g_scheduled) { g_scheduled = 1; g_timer = TimerSet(g_timer, 0, 40, rdpDeferredUpdateCallback, 0); } } /******************************************************************************/ /* returns error */ static int rdpup_recv(char *data, int len) { int rcvd; if (g_sck_closed) { return 1; } while (len > 0) { rcvd = g_tcp_recv(g_sck, data, len, 0); if (rcvd == -1) { if (g_tcp_last_error_would_block(g_sck)) { g_sleep(1); } else { LLOGLN(0, ("rdpup_recv: g_tcp_recv failed(returned -1)")); rdpup_disconnect(); return 1; } } else if (rcvd == 0) { LLOGLN(0, ("rdpup_recv: g_tcp_recv failed(returned 0)")); rdpup_disconnect(); return 1; } else { data += rcvd; len -= rcvd; } } return 0; } /******************************************************************************/ static int rdpup_recv_msg(struct stream *s) { int len; int rv; rv = 1; if (s != 0) { init_stream(s, 4); rv = rdpup_recv(s->data, 4); if (rv == 0) { in_uint32_le(s, len); if (len > 3) { init_stream(s, len); rv = rdpup_recv(s->data, len - 4); } } } if (rv != 0) { rdpLog("error in rdpup_recv_msg\n"); } return rv; } /*****************************************************************************/ /* wait 'millis' milliseconds for the socket to be able to receive */ /* returns boolean */ static int sck_can_recv(int sck, int millis) { fd_set rfds; struct timeval time; int rv; time.tv_sec = millis / 1000; time.tv_usec = (millis * 1000) % 1000000; FD_ZERO(&rfds); if (sck > 0) { FD_SET(((unsigned int)sck), &rfds); rv = select(sck + 1, &rfds, 0, 0, &time); if (rv > 0) { return 1; } } return 0; } /******************************************************************************/ /* this from miScreenInit pScreen->mmWidth = (xsize * 254 + dpix * 5) / (dpix * 10); pScreen->mmHeight = (ysize * 254 + dpiy * 5) / (dpiy * 10); */ static int process_screen_size_msg(int width, int height, int bpp) { int mmwidth; int mmheight; int bytes; Bool ok; LLOGLN(0, ("process_screen_size_msg: set width %d height %d bpp %d", width, height, bpp)); g_rdpScreen.rdp_width = width; g_rdpScreen.rdp_height = height; g_rdpScreen.rdp_bpp = bpp; if (bpp < 15) { g_rdpScreen.rdp_Bpp = 1; g_rdpScreen.rdp_Bpp_mask = 0xff; } else if (bpp == 15) { g_rdpScreen.rdp_Bpp = 2; g_rdpScreen.rdp_Bpp_mask = 0x7fff; } else if (bpp == 16) { g_rdpScreen.rdp_Bpp = 2; g_rdpScreen.rdp_Bpp_mask = 0xffff; } else if (bpp > 16) { g_rdpScreen.rdp_Bpp = 4; g_rdpScreen.rdp_Bpp_mask = 0xffffff; } if (g_use_shmem) { if (g_shmemptr != 0) { shmdt(g_shmemptr); g_shmemptr = 0; } bytes = g_rdpScreen.rdp_width * g_rdpScreen.rdp_height * g_rdpScreen.rdp_Bpp; g_shmemid = shmget(IPC_PRIVATE, bytes, IPC_CREAT | 0777); if (g_shmemid != -1) { g_shmemptr = shmat(g_shmemid, 0, 0); if (g_shmemptr == (void *) -1) { LLOGLN(0, ("process_screen_size_msg: shmat failed for %d " "bytes g_shmemid %d", bytes, g_shmemid)); g_shmemptr = 0; shmctl(g_shmemid, IPC_RMID, NULL); g_shmemid = -1; } else { shmctl(g_shmemid, IPC_RMID, NULL); } LLOGLN(0, ("process_screen_size_msg: g_shmemid %d g_shmemptr %p", g_shmemid, g_shmemptr)); g_shmem_lineBytes = g_rdpScreen.rdp_Bpp * g_rdpScreen.rdp_width; if (g_shm_reg != 0) { RegionDestroy(g_shm_reg); } g_shm_reg = RegionCreate(NullBox, 0); } } mmwidth = PixelToMM(width); mmheight = PixelToMM(height); if ((g_rdpScreen.width != width) || (g_rdpScreen.height != height)) { LLOGLN(0, (" calling RRScreenSizeSet")); ok = RRScreenSizeSet(g_pScreen, width, height, mmwidth, mmheight); LLOGLN(0, (" RRScreenSizeSet ok=[%d]", ok)); } return 0; } /******************************************************************************/ static int l_bound_by(int val, int low, int high) { if (val > high) { val = high; } if (val < low) { val = low; } return val; } /******************************************************************************/ static int rdpup_send_caps(void) { struct stream *ls; int len; int rv; int cap_count; int cap_bytes; make_stream(ls); init_stream(ls, 8192); s_push_layer(ls, iso_hdr, 8); cap_count = 0; cap_bytes = 0; #if 0 out_uint16_le(ls, 0); out_uint16_le(ls, 4); cap_count++; cap_bytes += 4; out_uint16_le(ls, 1); out_uint16_le(ls, 4); cap_count++; cap_bytes += 4; #endif s_mark_end(ls); len = (int)(ls->end - ls->data); s_pop_layer(ls, iso_hdr); out_uint16_le(ls, 2); /* caps */ out_uint16_le(ls, cap_count); /* num caps */ out_uint32_le(ls, cap_bytes); /* caps len after header */ rv = rdpup_send(ls->data, len); if (rv != 0) { LLOGLN(0, ("rdpup_send_caps: rdpup_send failed")); } free_stream(ls); return rv; } /******************************************************************************/ static int process_version_msg(int param1, int param2, int param3, int param4) { LLOGLN(0, ("process_version_msg: version %d %d %d %d", param1, param2, param3, param4)); if ((param1 > 0) || (param2 > 0) || (param3 > 0) || (param4 > 0)) { rdpup_send_caps(); } return 0; } /******************************************************************************/ static int rdpup_send_rail(void) { WindowPtr wnd; rdpWindowRec *priv; wnd = g_pScreen->root; if (wnd != 0) { wnd = wnd->lastChild; while (wnd != 0) { if (wnd->realized) { priv = GETWINPRIV(wnd); priv->status = 1; rdpup_create_window(wnd, priv); } wnd = wnd->prevSib; } } return 0; } #define XR_BUTTON1 1 #define XR_BUTTON2 2 #define XR_BUTTON3 4 #define XR_BUTTON4 8 #define XR_BUTTON5 16 #define XR_BUTTON6 32 #define XR_BUTTON7 64 /******************************************************************************/ static int rdpup_process_msg(struct stream *s) { int msg_type; int msg; int param1; int param2; int param3; int param4; int bytes; int i1; int flags; int x; int y; int cx; int cy; int index; RegionRec reg; BoxRec box; in_uint16_le(s, msg_type); if (msg_type == 103) { in_uint32_le(s, msg); in_uint32_le(s, param1); in_uint32_le(s, param2); in_uint32_le(s, param3); in_uint32_le(s, param4); LLOGLN(10, ("rdpup_process_msg - msg %d param1 %d param2 %d param3 %d " "param4 %d", msg, param1, param2, param3, param4)); switch (msg) { case 15: /* key down */ case 16: /* key up */ KbdAddEvent(msg == 15, param1, param2, param3, param4); break; case 17: /* from RDP_INPUT_SYNCHRONIZE */ KbdSync(param1); break; case 100: /* without the minus 2, strange things happen when dragging past the width or height */ g_cursor_x = l_bound_by(param1, 0, g_rdpScreen.width - 2); g_cursor_y = l_bound_by(param2, 0, g_rdpScreen.height - 2); PtrAddEvent(g_button_mask, g_cursor_x, g_cursor_y); break; case 101: /* left button up */ g_button_mask = g_button_mask & (~XR_BUTTON1); PtrAddEvent(g_button_mask, g_cursor_x, g_cursor_y); break; case 102: /* left button down */ g_cursor_x = l_bound_by(param1, 0, g_rdpScreen.width - 2); g_cursor_y = l_bound_by(param2, 0, g_rdpScreen.height - 2); g_button_mask = g_button_mask | XR_BUTTON1; PtrAddEvent(g_button_mask, g_cursor_x, g_cursor_y); break; case 103: /* right button up */ g_button_mask = g_button_mask & (~XR_BUTTON3); PtrAddEvent(g_button_mask, g_cursor_x, g_cursor_y); break; case 104: /* right button down */ g_cursor_x = l_bound_by(param1, 0, g_rdpScreen.width - 2); g_cursor_y = l_bound_by(param2, 0, g_rdpScreen.height - 2); g_button_mask = g_button_mask | XR_BUTTON3; PtrAddEvent(g_button_mask, g_cursor_x, g_cursor_y); break; case 105: /* middle button down */ g_button_mask = g_button_mask & (~XR_BUTTON2); PtrAddEvent(g_button_mask, g_cursor_x, g_cursor_y); break; case 106: /* middle button up */ g_cursor_x = l_bound_by(param1, 0, g_rdpScreen.width - 2); g_cursor_y = l_bound_by(param2, 0, g_rdpScreen.height - 2); g_button_mask = g_button_mask | XR_BUTTON2; PtrAddEvent(g_button_mask, g_cursor_x, g_cursor_y); break; case 107: /* button 4 up */ g_button_mask = g_button_mask & (~XR_BUTTON4); PtrAddEvent(g_button_mask, g_cursor_x, g_cursor_y); break; case 108: /* button 4 down */ g_cursor_x = l_bound_by(param1, 0, g_rdpScreen.width - 2); g_cursor_y = l_bound_by(param2, 0, g_rdpScreen.height - 2); g_button_mask = g_button_mask | XR_BUTTON4; PtrAddEvent(g_button_mask, g_cursor_x, g_cursor_y); break; case 109: /* button 5 up */ g_button_mask = g_button_mask & (~XR_BUTTON5); PtrAddEvent(g_button_mask, g_cursor_x, g_cursor_y); break; case 110: /* button 5 down */ g_cursor_x = l_bound_by(param1, 0, g_rdpScreen.width - 2); g_cursor_y = l_bound_by(param2, 0, g_rdpScreen.height - 2); g_button_mask = g_button_mask | XR_BUTTON5; PtrAddEvent(g_button_mask, g_cursor_x, g_cursor_y); break; case 111: /* button 6 up */ g_button_mask = g_button_mask & (~XR_BUTTON6); PtrAddEvent(g_button_mask, g_cursor_x, g_cursor_y); break; case 112: /* button 6 down */ g_cursor_x = l_bound_by(param1, 0, g_rdpScreen.width - 2); g_cursor_y = l_bound_by(param2, 0, g_rdpScreen.height - 2); g_button_mask = g_button_mask | XR_BUTTON6; PtrAddEvent(g_button_mask, g_cursor_x, g_cursor_y); break; case 113: /* button 7 up */ g_button_mask = g_button_mask & (~XR_BUTTON7); PtrAddEvent(g_button_mask, g_cursor_x, g_cursor_y); break; case 114: /* button 7 down */ g_cursor_x = l_bound_by(param1, 0, g_rdpScreen.width - 2); g_cursor_y = l_bound_by(param2, 0, g_rdpScreen.height - 2); g_button_mask = g_button_mask | XR_BUTTON7; PtrAddEvent(g_button_mask, g_cursor_x, g_cursor_y); break; case 200: rdpup_begin_update(); rdpup_send_area(0, (param1 >> 16) & 0xffff, param1 & 0xffff, (param2 >> 16) & 0xffff, param2 & 0xffff); rdpup_end_update(); break; case 300: process_screen_size_msg(param1, param2, param3); break; case 301: process_version_msg(param1, param2, param3, param4); break; } } else if (msg_type == 104) { in_uint32_le(s, bytes); if (bytes > sizeof(g_rdpScreen.client_info)) { bytes = sizeof(g_rdpScreen.client_info); } memcpy(&(g_rdpScreen.client_info), s->p - 4, bytes); g_rdpScreen.client_info.size = bytes; LLOGLN(0, ("rdpup_process_msg: got client info bytes %d", bytes)); LLOGLN(0, (" jpeg support %d", g_rdpScreen.client_info.jpeg)); i1 = g_rdpScreen.client_info.offscreen_support_level; LLOGLN(0, (" offscreen support %d", i1)); i1 = g_rdpScreen.client_info.offscreen_cache_size; LLOGLN(0, (" offscreen size %d", i1)); i1 = g_rdpScreen.client_info.offscreen_cache_entries; LLOGLN(0, (" offscreen entries %d", i1)); if (g_rdpScreen.client_info.offscreen_support_level > 0) { if (g_rdpScreen.client_info.offscreen_cache_entries > 0) { g_max_os_bitmaps = g_rdpScreen.client_info.offscreen_cache_entries; g_free(g_os_bitmaps); g_os_bitmaps = (struct rdpup_os_bitmap *) g_malloc(sizeof(struct rdpup_os_bitmap) * g_max_os_bitmaps, 1); } } if (g_rdpScreen.client_info.rail_support_level > 0) { g_use_rail = 1; #ifdef XRDP_WM_RDPUP rdpup_send_rail(); #endif } if (g_rdpScreen.client_info.orders[0x1b]) /* 27 NEG_GLYPH_INDEX_INDEX */ { LLOGLN(0, (" client supports glyph cache but server disabled")); //g_do_glyph_cache = 1; } if (g_rdpScreen.client_info.order_flags_ex & 0x100) { g_do_composite = 1; } if (g_do_glyph_cache) { LLOGLN(0, (" using glyph cache")); } if (g_do_composite) { LLOGLN(0, (" using client composite")); } LLOGLN(10, ("order_flags_ex 0x%x", g_rdpScreen.client_info.order_flags_ex)); if (g_rdpScreen.client_info.offscreen_cache_entries == 2000) { LLOGLN(0, (" client can do offscreen to offscreen blits")); g_can_do_pix_to_pix = 1; } else { LLOGLN(0, (" client can not do offscreen to offscreen blits")); g_can_do_pix_to_pix = 0; } if (g_rdpScreen.client_info.pointer_flags & 1) { LLOGLN(0, (" client can do new(color) cursor")); } else { LLOGLN(0, (" client can not do new(color) cursor")); } if (g_rdpScreen.client_info.monitorCount > 0) { LLOGLN(0, (" client can do multimon")); LLOGLN(0, (" client monitor data, monitorCount= %d", g_rdpScreen.client_info.monitorCount)); box.x1 = g_rdpScreen.client_info.minfo[0].left; box.y1 = g_rdpScreen.client_info.minfo[0].top; box.x2 = g_rdpScreen.client_info.minfo[0].right; box.y2 = g_rdpScreen.client_info.minfo[0].bottom; g_do_multimon = 1; /* adjust monitor info so it's not negative */ for (index = 1; index < g_rdpScreen.client_info.monitorCount; index++) { box.x1 = min(box.x1, g_rdpScreen.client_info.minfo[index].left); box.y1 = min(box.y1, g_rdpScreen.client_info.minfo[index].top); box.x2 = max(box.x2, g_rdpScreen.client_info.minfo[index].right); box.y2 = max(box.y2, g_rdpScreen.client_info.minfo[index].bottom); } for (index = 0; index < g_rdpScreen.client_info.monitorCount; index++) { g_rdpScreen.client_info.minfo[index].left -= box.x1; g_rdpScreen.client_info.minfo[index].top -= box.y1; g_rdpScreen.client_info.minfo[index].right -= box.x1; g_rdpScreen.client_info.minfo[index].bottom -= box.y1; LLOGLN(0, (" left %d top %d right %d bottom %d", g_rdpScreen.client_info.minfo[index].left, g_rdpScreen.client_info.minfo[index].top, g_rdpScreen.client_info.minfo[index].right, g_rdpScreen.client_info.minfo[index].bottom)); } rdpRRSetRdpOutputs(); RRTellChanged(g_pScreen); } else { LLOGLN(0, (" client can not do multimon")); g_do_multimon = 0; rdpRRSetRdpOutputs(); RRTellChanged(g_pScreen); } rdpLoadLayout(&(g_rdpScreen.client_info)); } else if (msg_type == 105) { LLOGLN(10, ("rdpup_process_msg: got msg 105")); in_uint32_le(s, flags); in_uint32_le(s, g_rect_id_ack); in_uint32_le(s, x); in_uint32_le(s, y); in_uint32_le(s, cx); in_uint32_le(s, cy); LLOGLN(10, ("rdpup_process_msg: %d %d %d %d", x, y, cx ,cy)); LLOGLN(10, ("rdpup_process_msg: rect_id %d rect_id_ack %d", g_rect_id, g_rect_id_ack)); box.x1 = x; box.y1 = y; box.x2 = box.x1 + cx; box.y2 = box.y1 + cy; RegionInit(®, &box, 0); LLOGLN(10, ("rdpup_process_msg: %d %d %d %d", box.x1, box.y1, box.x2, box.y2)); RegionSubtract(g_shm_reg, g_shm_reg, ®); RegionUninit(®); } else { rdpLog("unknown message type in rdpup_process_msg %d\n", msg_type); } return 0; } /******************************************************************************/ void rdpup_get_screen_image_rect(struct image_data *id) { id->width = g_rdpScreen.width; id->height = g_rdpScreen.height; id->bpp = g_rdpScreen.rdp_bpp; id->Bpp = g_rdpScreen.rdp_Bpp; id->lineBytes = g_rdpScreen.paddedWidthInBytes; id->pixels = g_rdpScreen.pfbMemory; id->shmem_pixels = g_shmemptr; id->shmem_id = g_shmemid; id->shmem_offset = 0; id->shmem_lineBytes = g_shmem_lineBytes; } /******************************************************************************/ void rdpup_get_pixmap_image_rect(PixmapPtr pPixmap, struct image_data *id) { id->width = pPixmap->drawable.width; id->height = pPixmap->drawable.height; id->bpp = g_rdpScreen.rdp_bpp; id->Bpp = g_rdpScreen.rdp_Bpp; id->lineBytes = pPixmap->devKind; id->pixels = (char *)(pPixmap->devPrivate.ptr); id->shmem_pixels = 0; id->shmem_id = 0; id->shmem_offset = 0; id->shmem_lineBytes = 0; } /******************************************************************************/ int rdpup_init(void) { char text[256]; char *ptext; int i; const char *socket_dir; socket_dir = g_socket_dir(); if (!g_directory_exist(socket_dir)) { if (!g_create_dir(socket_dir)) { LLOGLN(0, ("rdpup_init: g_create_dir(%s) failed", socket_dir)); return 0; } g_chmod_hex(socket_dir, 0x1777); } i = atoi(display); if (i < 1) { return 0; } if (g_in_s == 0) { make_stream(g_in_s); init_stream(g_in_s, 8192); } if (g_out_s == 0) { make_stream(g_out_s); init_stream(g_out_s, 8192 * g_Bpp + 100); } if (g_use_uds) { g_sprintf(g_uds_data, "%s/xrdp_display_%s", socket_dir, display); if (g_listen_sck == 0) { g_listen_sck = g_tcp_local_socket_stream(); if (g_tcp_local_bind(g_listen_sck, g_uds_data) != 0) { LLOGLN(0, ("rdpup_init: g_tcp_local_bind failed")); return 0; } g_tcp_listen(g_listen_sck); AddEnabledDevice(g_listen_sck); } } else { g_sprintf(text, "62%2.2d", i); if (g_listen_sck == 0) { g_listen_sck = g_tcp_socket(); if (g_tcp_bind(g_listen_sck, text) != 0) { return 0; } g_tcp_listen(g_listen_sck); AddEnabledDevice(g_listen_sck); } } g_dis_listen_sck = g_tcp_local_socket_dgram(); if (g_dis_listen_sck != 0) { g_sprintf(text, "%s/xrdp_disconnect_display_%s", socket_dir, display); if (g_tcp_local_bind(g_dis_listen_sck, text) == 0) { AddEnabledDevice(g_dis_listen_sck); } else { rdpLog("g_tcp_local_bind failed [%s]\n", text); } } ptext = getenv("XRDP_SESMAN_MAX_IDLE_TIME"); if (ptext != 0) { } ptext = getenv("XRDP_SESMAN_MAX_DISC_TIME"); if (ptext != 0) { i = atoi(ptext); if (i > 0) { g_do_kill_disconnected = 1; g_disconnect_timeout_s = atoi(ptext); } } ptext = getenv("XRDP_SESMAN_KILL_DISCONNECTED"); if (ptext != 0) { i = atoi(ptext); if (i != 0) { g_do_kill_disconnected = 1; } } if (g_do_kill_disconnected && (g_disconnect_timeout_s < 60)) { g_disconnect_timeout_s = 60; } rdpLog("kill disconnected [%d] timeout [%d] sec\n", g_do_kill_disconnected, g_disconnect_timeout_s); return 1; } /******************************************************************************/ int rdpup_check(void) { int sel; int new_sck; char buf[8]; sel = g_tcp_select(g_listen_sck, g_sck, g_dis_listen_sck); if (sel & 1) { new_sck = g_tcp_accept(g_listen_sck); if (new_sck == -1) { } else { if (g_sck != 0) { /* should maybe ask is user wants to allow here with timeout */ rdpLog("replacing connection, already got a connection\n"); rdpup_disconnect(); } rdpLog("got a connection\n"); g_sck = new_sck; g_tcp_set_non_blocking(g_sck); g_tcp_set_no_delay(g_sck); g_connected = 1; g_sck_closed = 0; g_begin = 0; g_con_number++; rdpGlyphInit(); AddEnabledDevice(g_sck); if (g_dis_timer != 0) { LLOGLN(0, ("rdpup_check: canceling g_dis_timer")); TimerCancel(g_dis_timer); TimerFree(g_dis_timer); g_dis_timer = 0; } g_disconnect_scheduled = 0; } } if (sel & 2) { if (rdpup_recv_msg(g_in_s) == 0) { rdpup_process_msg(g_in_s); } } if (sel & 4) { if (g_tcp_recv(g_dis_listen_sck, buf, 4, 0) > 0) { if (g_sck != 0) { rdpLog("disconnecting session via user request\n"); rdpup_disconnect(); } } } return 0; } /******************************************************************************/ int rdpup_begin_update(void) { LLOGLN(10, ("rdpup_begin_update:")); if (g_connected) { if (g_begin) { return 0; } init_stream(g_out_s, 0); s_push_layer(g_out_s, iso_hdr, 8); out_uint16_le(g_out_s, 1); /* begin update */ out_uint16_le(g_out_s, 4); /* size */ LLOGLN(10, ("begin %d", g_count)); g_begin = 1; g_count = 1; } return 0; } /******************************************************************************/ int rdpup_end_update(void) { LLOGLN(10, ("rdpup_end_update")); if (g_connected && g_begin) { if (g_do_dirty_ons) { /* in this mode, end update is only called in check dirty */ rdpup_send_pending(); } else { rdpScheduleDeferredUpdate(); } } return 0; } /******************************************************************************/ int rdpup_pre_check(int in_size) { int rv; rv = 0; if (!g_begin) { rdpup_begin_update(); } if ((g_out_s->p - g_out_s->data) > (g_out_s->size - (in_size + 20))) { s_mark_end(g_out_s); if (rdpup_send_msg(g_out_s) != 0) { LLOGLN(0, ("rdpup_pre_check: rdpup_send_msg failed")); rv = 1; } g_count = 0; init_stream(g_out_s, 0); s_push_layer(g_out_s, iso_hdr, 8); } return rv; } /******************************************************************************/ int rdpup_fill_rect(short x, short y, int cx, int cy) { if (g_connected) { LLOGLN(10, (" rdpup_fill_rect")); rdpup_pre_check(12); out_uint16_le(g_out_s, 3); /* fill rect */ out_uint16_le(g_out_s, 12); /* size */ g_count++; out_uint16_le(g_out_s, x); out_uint16_le(g_out_s, y); out_uint16_le(g_out_s, cx); out_uint16_le(g_out_s, cy); } return 0; } /******************************************************************************/ int rdpup_screen_blt(short x, short y, int cx, int cy, short srcx, short srcy) { if (g_connected) { LLOGLN(10, (" rdpup_screen_blt x %d y %d cx %d cy %d srcx %d srcy %d", x, y, cx, cy, srcx, srcy)); rdpup_pre_check(16); out_uint16_le(g_out_s, 4); /* screen blt */ out_uint16_le(g_out_s, 16); /* size */ g_count++; out_uint16_le(g_out_s, x); out_uint16_le(g_out_s, y); out_uint16_le(g_out_s, cx); out_uint16_le(g_out_s, cy); out_uint16_le(g_out_s, srcx); out_uint16_le(g_out_s, srcy); } return 0; } /******************************************************************************/ int rdpup_set_clip(short x, short y, int cx, int cy) { if (g_connected) { LLOGLN(10, (" rdpup_set_clip")); rdpup_pre_check(12); out_uint16_le(g_out_s, 10); /* set clip */ out_uint16_le(g_out_s, 12); /* size */ g_count++; out_uint16_le(g_out_s, x); out_uint16_le(g_out_s, y); out_uint16_le(g_out_s, cx); out_uint16_le(g_out_s, cy); } return 0; } /******************************************************************************/ int rdpup_reset_clip(void) { if (g_connected) { LLOGLN(10, (" rdpup_reset_clip")); rdpup_pre_check(4); out_uint16_le(g_out_s, 11); /* reset clip */ out_uint16_le(g_out_s, 4); /* size */ g_count++; } return 0; } #define COLOR8(r, g, b) \ ((((r) >> 5) << 0) | (((g) >> 5) << 3) | (((b) >> 6) << 6)) #define COLOR15(r, g, b) \ ((((r) >> 3) << 10) | (((g) >> 3) << 5) | (((b) >> 3) << 0)) #define COLOR16(r, g, b) \ ((((r) >> 3) << 11) | (((g) >> 2) << 5) | (((b) >> 3) << 0)) #define COLOR24(r, g, b) \ ((((r) >> 0) << 0) | (((g) >> 0) << 8) | (((b) >> 0) << 16)) #define SPLITCOLOR32(r, g, b, c) \ { \ r = ((c) >> 16) & 0xff; \ g = ((c) >> 8) & 0xff; \ b = (c) & 0xff; \ } int convert_pixel(int in_pixel) { int red; int green; int blue; int rv; rv = 0; if (g_rdpScreen.depth == 24) { if (g_rdpScreen.rdp_bpp >= 24) { rv = in_pixel; SPLITCOLOR32(red, green, blue, rv); rv = COLOR24(red, green, blue); } else if (g_rdpScreen.rdp_bpp == 16) { rv = in_pixel; SPLITCOLOR32(red, green, blue, rv); rv = COLOR16(red, green, blue); } else if (g_rdpScreen.rdp_bpp == 15) { rv = in_pixel; SPLITCOLOR32(red, green, blue, rv); rv = COLOR15(red, green, blue); } else if (g_rdpScreen.rdp_bpp == 8) { rv = in_pixel; SPLITCOLOR32(red, green, blue, rv); rv = COLOR8(red, green, blue); } } else if (g_rdpScreen.depth == g_rdpScreen.rdp_bpp) { return in_pixel; } return rv; } int convert_pixels(void *src, void *dst, int num_pixels) { unsigned int pixel; unsigned int red; unsigned int green; unsigned int blue; unsigned int *src32; unsigned int *dst32; unsigned short *dst16; unsigned char *dst8; int index; if (g_rdpScreen.depth == g_rdpScreen.rdp_bpp) { memcpy(dst, src, num_pixels * g_Bpp); return 0; } if (g_rdpScreen.depth == 24) { src32 = (unsigned int *)src; if (g_rdpScreen.rdp_bpp >= 24) { dst32 = (unsigned int *)dst; for (index = 0; index < num_pixels; index++) { pixel = *src32; *dst32 = pixel; dst32++; src32++; } } else if (g_rdpScreen.rdp_bpp == 16) { dst16 = (unsigned short *)dst; for (index = 0; index < num_pixels; index++) { pixel = *src32; SPLITCOLOR32(red, green, blue, pixel); pixel = COLOR16(red, green, blue); *dst16 = pixel; dst16++; src32++; } } else if (g_rdpScreen.rdp_bpp == 15) { dst16 = (unsigned short *)dst; for (index = 0; index < num_pixels; index++) { pixel = *src32; SPLITCOLOR32(red, green, blue, pixel); pixel = COLOR15(red, green, blue); *dst16 = pixel; dst16++; src32++; } } else if (g_rdpScreen.rdp_bpp == 8) { dst8 = (unsigned char *)dst; for (index = 0; index < num_pixels; index++) { pixel = *src32; SPLITCOLOR32(red, green, blue, pixel); pixel = COLOR8(red, green, blue); *dst8 = pixel; dst8++; src32++; } } } return 0; } /******************************************************************************/ int alpha_pixels(void* src, void* dst, int num_pixels) { unsigned int* src32; unsigned char* dst8; int index; src32 = (unsigned int*)src; dst8 = (unsigned char*)dst; for (index = 0; index < num_pixels; index++) { *dst8 = (*src32) >> 24; dst8++; src32++; } return 0; } /******************************************************************************/ int rdpup_set_fgcolor(int fgcolor) { if (g_connected) { LLOGLN(10, (" rdpup_set_fgcolor")); rdpup_pre_check(8); out_uint16_le(g_out_s, 12); /* set fgcolor */ out_uint16_le(g_out_s, 8); /* size */ g_count++; fgcolor = fgcolor & g_Bpp_mask; fgcolor = convert_pixel(fgcolor) & g_rdpScreen.rdp_Bpp_mask; out_uint32_le(g_out_s, fgcolor); } return 0; } /******************************************************************************/ int rdpup_set_bgcolor(int bgcolor) { if (g_connected) { LLOGLN(10, (" rdpup_set_bgcolor")); rdpup_pre_check(8); out_uint16_le(g_out_s, 13); /* set bg color */ out_uint16_le(g_out_s, 8); /* size */ g_count++; bgcolor = bgcolor & g_Bpp_mask; bgcolor = convert_pixel(bgcolor) & g_rdpScreen.rdp_Bpp_mask; out_uint32_le(g_out_s, bgcolor); } return 0; } /******************************************************************************/ int rdpup_set_opcode(int opcode) { if (g_connected) { LLOGLN(10, (" rdpup_set_opcode")); rdpup_pre_check(6); out_uint16_le(g_out_s, 14); /* set opcode */ out_uint16_le(g_out_s, 6); /* size */ g_count++; out_uint16_le(g_out_s, g_rdp_opcodes[opcode & 0xf]); } return 0; } /******************************************************************************/ int rdpup_set_pen(int style, int width) { if (g_connected) { LLOGLN(10, (" rdpup_set_pen")); rdpup_pre_check(8); out_uint16_le(g_out_s, 17); /* set pen */ out_uint16_le(g_out_s, 8); /* size */ g_count++; out_uint16_le(g_out_s, style); out_uint16_le(g_out_s, width); } return 0; } /******************************************************************************/ int rdpup_draw_line(short x1, short y1, short x2, short y2) { if (g_connected) { LLOGLN(10, (" rdpup_draw_line")); rdpup_pre_check(12); out_uint16_le(g_out_s, 18); /* draw line */ out_uint16_le(g_out_s, 12); /* size */ g_count++; out_uint16_le(g_out_s, x1); out_uint16_le(g_out_s, y1); out_uint16_le(g_out_s, x2); out_uint16_le(g_out_s, y2); } return 0; } /******************************************************************************/ int rdpup_set_cursor(short x, short y, char *cur_data, char *cur_mask) { int size; if (g_connected) { LLOGLN(10, (" rdpup_set_cursor")); size = 8 + 32 * (32 * 3) + 32 * (32 / 8); rdpup_pre_check(size); out_uint16_le(g_out_s, 19); /* set cursor */ out_uint16_le(g_out_s, size); /* size */ g_count++; x = MAX(0, x); x = MIN(31, x); y = MAX(0, y); y = MIN(31, y); out_uint16_le(g_out_s, x); out_uint16_le(g_out_s, y); out_uint8a(g_out_s, cur_data, 32 * (32 * 3)); out_uint8a(g_out_s, cur_mask, 32 * (32 / 8)); } return 0; } /******************************************************************************/ int rdpup_set_cursor_ex(short x, short y, char *cur_data, char *cur_mask, int bpp) { int size; int Bpp; if (g_connected) { LLOGLN(10, (" rdpup_set_cursor_ex")); Bpp = (bpp == 0) ? 3 : (bpp + 7) / 8; size = 10 + 32 * (32 * Bpp) + 32 * (32 / 8); rdpup_pre_check(size); out_uint16_le(g_out_s, 51); /* set cursor ex */ out_uint16_le(g_out_s, size); /* size */ g_count++; x = MAX(0, x); x = MIN(31, x); y = MAX(0, y); y = MIN(31, y); out_uint16_le(g_out_s, x); out_uint16_le(g_out_s, y); out_uint16_le(g_out_s, bpp); out_uint8a(g_out_s, cur_data, 32 * (32 * Bpp)); out_uint8a(g_out_s, cur_mask, 32 * (32 / 8)); } return 0; } /******************************************************************************/ int rdpup_create_os_surface(int rdpindex, int width, int height) { LLOGLN(10, ("rdpup_create_os_surface:")); if (g_connected) { LLOGLN(10, (" rdpup_create_os_surface width %d height %d", width, height)); rdpup_pre_check(12); out_uint16_le(g_out_s, 20); out_uint16_le(g_out_s, 12); g_count++; out_uint32_le(g_out_s, rdpindex); out_uint16_le(g_out_s, width); out_uint16_le(g_out_s, height); } return 0; } /******************************************************************************/ int rdpup_create_os_surface_bpp(int rdpindex, int width, int height, int bpp) { LLOGLN(10, ("rdpup_create_os_surface_bpp:")); if (g_connected) { LLOGLN(10, (" width %d height %d bpp %d", width, height, bpp)); rdpup_pre_check(13); out_uint16_le(g_out_s, 31); out_uint16_le(g_out_s, 13); g_count++; out_uint32_le(g_out_s, rdpindex); out_uint16_le(g_out_s, width); out_uint16_le(g_out_s, height); out_uint8(g_out_s, bpp); } return 0; } /******************************************************************************/ int rdpup_switch_os_surface(int rdpindex) { LLOGLN(10, ("rdpup_switch_os_surface:")); if (g_connected) { if (g_rdpindex == rdpindex) { return 0; } g_rdpindex = rdpindex; LLOGLN(10, ("rdpup_switch_os_surface: rdpindex %d", rdpindex)); /* switch surface */ rdpup_pre_check(8); out_uint16_le(g_out_s, 21); out_uint16_le(g_out_s, 8); out_uint32_le(g_out_s, rdpindex); g_count++; } return 0; } /******************************************************************************/ int rdpup_delete_os_surface(int rdpindex) { LLOGLN(10, ("rdpup_delete_os_surface: rdpindex %d", rdpindex)); if (g_connected) { LLOGLN(10, ("rdpup_delete_os_surface: rdpindex %d", rdpindex)); rdpup_pre_check(8); out_uint16_le(g_out_s, 22); out_uint16_le(g_out_s, 8); g_count++; out_uint32_le(g_out_s, rdpindex); } return 0; } /******************************************************************************/ static int get_single_color(struct image_data *id, int x, int y, int w, int h) { int rv; int i; int j; int p; unsigned char *i8; unsigned short *i16; unsigned int *i32; p = 0; rv = -1; if (g_Bpp == 1) { for (i = 0; i < h; i++) { i8 = (unsigned char *)(id->pixels + ((y + i) * id->lineBytes) + (x * g_Bpp)); if (i == 0) { p = *i8; } for (j = 0; j < w; j++) { if (i8[j] != p) { return -1; } } } rv = p; } else if (g_Bpp == 2) { for (i = 0; i < h; i++) { i16 = (unsigned short *)(id->pixels + ((y + i) * id->lineBytes) + (x * g_Bpp)); if (i == 0) { p = *i16; } for (j = 0; j < w; j++) { if (i16[j] != p) { return -1; } } } rv = p; } else if (g_Bpp == 4) { for (i = 0; i < h; i++) { i32 = (unsigned int *)(id->pixels + ((y + i) * id->lineBytes) + (x * g_Bpp)); if (i == 0) { p = *i32; } for (j = 0; j < w; j++) { if (i32[j] != p) { return -1; } } } rv = p; } return rv; } /******************************************************************************/ /* split the bitmap up into 64 x 64 pixel areas or send using shared memory */ void rdpup_send_area(struct image_data *id, int x, int y, int w, int h) { char *s; char *d; int i; int single_color; int lx; int ly; int lh; int lw; int size; int safety; struct image_data lid; BoxRec box; RegionRec reg; LLOGLN(10, ("rdpup_send_area: id %p x %d y %d w %d h %d", id, x, y, w, h)); if (id == 0) { rdpup_get_screen_image_rect(&lid); id = &lid; } if (x >= id->width) { return; } if (y >= id->height) { return; } if (x < 0) { w += x; x = 0; } if (y < 0) { h += y; y = 0; } if (w <= 0) { return; } if (h <= 0) { return; } if (x + w > id->width) { w = id->width - x; } if (y + h > id->height) { h = id->height - y; } LLOGLN(10, ("%d", w * h)); if (g_connected && g_begin) { LLOGLN(10, (" rdpup_send_area")); if (id->shmem_pixels != 0) { LLOGLN(10, ("rdpup_send_area: using shmem")); box.x1 = x; box.y1 = y; box.x2 = box.x1 + w; box.y2 = box.y1 + h; LLOGLN(10, ("rdpup_send_area: 1 x %d y %d w %d h %d", x, y, w, h)); safety = 0; while (RegionContainsRect(g_shm_reg, &box)) { /* instead of rdpup_end_update, call rdpup_send_pending */ rdpup_send_pending(); rdpup_begin_update(); safety++; if (safety > 100) { LLOGLN(0, ("rdpup_send_area: shmem timeout")); break; } if (sck_can_recv(g_sck, 100)) { if (rdpup_recv_msg(g_in_s) == 0) { rdpup_process_msg(g_in_s); } } } s = id->pixels; s += y * id->lineBytes; s += x * g_Bpp; d = id->shmem_pixels + id->shmem_offset; d += y * id->shmem_lineBytes; d += x * g_rdpScreen.rdp_Bpp; ly = y; while (ly < y + h) { convert_pixels(s, d, w); s += id->lineBytes; d += id->shmem_lineBytes; ly += 1; } size = 36; rdpup_pre_check(size); out_uint16_le(g_out_s, 60); out_uint16_le(g_out_s, size); g_count++; LLOGLN(10, ("rdpup_send_area: 2 x %d y %d w %d h %d", x, y, w, h)); out_uint16_le(g_out_s, x); out_uint16_le(g_out_s, y); out_uint16_le(g_out_s, w); out_uint16_le(g_out_s, h); out_uint32_le(g_out_s, 0); g_rect_id++; out_uint32_le(g_out_s, g_rect_id); out_uint32_le(g_out_s, id->shmem_id); out_uint32_le(g_out_s, id->shmem_offset); out_uint16_le(g_out_s, id->width); out_uint16_le(g_out_s, id->height); out_uint16_le(g_out_s, x); out_uint16_le(g_out_s, y); RegionInit(®, &box, 0); RegionUnion(g_shm_reg, g_shm_reg, ®); RegionUninit(®); return; } ly = y; while ((ly < y + h) && g_connected) { lx = x; while (lx < x + w) { lw = MIN(64, (x + w) - lx); lh = MIN(64, (y + h) - ly); single_color = get_single_color(id, lx, ly, lw, lh); if (single_color != -1) { LLOGLN(10, ("%d sending single color", g_count)); rdpup_set_fgcolor(single_color); rdpup_fill_rect(lx, ly, lw, lh); } else { size = lw * lh * id->Bpp + 24; rdpup_pre_check(size); out_uint16_le(g_out_s, 5); out_uint16_le(g_out_s, size); g_count++; out_uint16_le(g_out_s, lx); out_uint16_le(g_out_s, ly); out_uint16_le(g_out_s, lw); out_uint16_le(g_out_s, lh); out_uint32_le(g_out_s, lw * lh * id->Bpp); for (i = 0; i < lh; i++) { s = (id->pixels + ((ly + i) * id->lineBytes) + (lx * g_Bpp)); convert_pixels(s, g_out_s->p, lw); g_out_s->p += lw * id->Bpp; } out_uint16_le(g_out_s, lw); out_uint16_le(g_out_s, lh); out_uint16_le(g_out_s, 0); out_uint16_le(g_out_s, 0); } lx += 64; } ly += 64; } } } /******************************************************************************/ /* split the bitmap up into 64 x 64 pixel areas */ void rdpup_send_alpha_area(struct image_data* id, int x, int y, int w, int h) { char* s; int i; int lx; int ly; int lh; int lw; int size; struct image_data lid; LLOGLN(10, ("rdpup_send_alpha_area: id %p x %d y %d w %d h %d", id, x, y, w, h)); if (id == 0) { rdpup_get_screen_image_rect(&lid); id = &lid; } if (x >= id->width) { return; } if (y >= id->height) { return; } if (x < 0) { w += x; x = 0; } if (y < 0) { h += y; y = 0; } if (w <= 0) { return; } if (h <= 0) { return; } if (x + w > id->width) { w = id->width - x; } if (y + h > id->height) { h = id->height - y; } LLOGLN(10, ("%d", w * h)); if (g_connected && g_begin) { LLOGLN(10, (" rdpup_send_area")); ly = y; while ((ly < y + h) && g_connected) { lx = x; while ((lx < x + w) && g_connected) { lw = MIN(64, (x + w) - lx); lh = MIN(64, (y + h) - ly); size = lw * lh + 25; rdpup_pre_check(size); out_uint16_le(g_out_s, 32); /* server_paint_rect_bpp */ out_uint16_le(g_out_s, size); g_count++; out_uint16_le(g_out_s, lx); out_uint16_le(g_out_s, ly); out_uint16_le(g_out_s, lw); out_uint16_le(g_out_s, lh); out_uint32_le(g_out_s, lw * lh); for (i = 0; i < lh; i++) { s = (id->pixels + ((ly + i) * id->lineBytes) + (lx * g_Bpp)); alpha_pixels(s, g_out_s->p, lw); g_out_s->p += lw; } out_uint16_le(g_out_s, lw); out_uint16_le(g_out_s, lh); out_uint16_le(g_out_s, 0); out_uint16_le(g_out_s, 0); out_uint8(g_out_s, 8); lx += 64; } ly += 64; } } } /******************************************************************************/ void rdpup_paint_rect_os(int x, int y, int cx, int cy, int rdpindex, int srcx, int srcy) { if (g_connected) { rdpup_pre_check(20); out_uint16_le(g_out_s, 23); out_uint16_le(g_out_s, 20); g_count++; out_uint16_le(g_out_s, x); out_uint16_le(g_out_s, y); out_uint16_le(g_out_s, cx); out_uint16_le(g_out_s, cy); out_uint32_le(g_out_s, rdpindex); out_uint16_le(g_out_s, srcx); out_uint16_le(g_out_s, srcy); } } /******************************************************************************/ void rdpup_set_hints(int hints, int mask) { if (g_connected) { rdpup_pre_check(12); out_uint16_le(g_out_s, 24); out_uint16_le(g_out_s, 12); g_count++; out_uint32_le(g_out_s, hints); out_uint32_le(g_out_s, mask); } } /******************************************************************************/ void rdpup_create_window(WindowPtr pWindow, rdpWindowRec *priv) { int bytes; int index; int flags; int num_window_rects; int num_visibility_rects; int title_bytes; int style; int ext_style; int root_id; char title[256]; LLOGLN(10, ("rdpup_create_window: id 0x%8.8x", (int)(pWindow->drawable.id))); if (g_connected) { root_id = pWindow->drawable.pScreen->root->drawable.id; if (pWindow->overrideRedirect) { style = XR_STYLE_TOOLTIP; ext_style = XR_EXT_STYLE_TOOLTIP; } else { style = XR_STYLE_NORMAL; ext_style = XR_EXT_STYLE_NORMAL; } flags = WINDOW_ORDER_TYPE_WINDOW | WINDOW_ORDER_STATE_NEW; strcpy(title, "title"); title_bytes = strlen(title); num_window_rects = 1; num_visibility_rects = 1; /* calculate bytes */ bytes = (2 + 2) + (5 * 4) + (2 + title_bytes) + (12 * 4) + (2 + num_window_rects * 8) + (4 + 4) + (2 + num_visibility_rects * 8) + 4; rdpup_pre_check(bytes); out_uint16_le(g_out_s, 25); out_uint16_le(g_out_s, bytes); g_count++; out_uint32_le(g_out_s, pWindow->drawable.id); /* window_id */ out_uint32_le(g_out_s, pWindow->parent->drawable.id); /* owner_window_id */ flags |= WINDOW_ORDER_FIELD_OWNER; out_uint32_le(g_out_s, style); /* style */ out_uint32_le(g_out_s, ext_style); /* extended_style */ flags |= WINDOW_ORDER_FIELD_STYLE; out_uint32_le(g_out_s, 0x05); /* show_state */ flags |= WINDOW_ORDER_FIELD_SHOW; out_uint16_le(g_out_s, title_bytes); /* title_info */ out_uint8a(g_out_s, title, title_bytes); flags |= WINDOW_ORDER_FIELD_TITLE; out_uint32_le(g_out_s, 0); /* client_offset_x */ out_uint32_le(g_out_s, 0); /* client_offset_y */ flags |= WINDOW_ORDER_FIELD_CLIENT_AREA_OFFSET; out_uint32_le(g_out_s, pWindow->drawable.width); /* client_area_width */ out_uint32_le(g_out_s, pWindow->drawable.height); /* client_area_height */ flags |= WINDOW_ORDER_FIELD_CLIENT_AREA_SIZE; out_uint32_le(g_out_s, 0); /* rp_content */ out_uint32_le(g_out_s, root_id); /* root_parent_handle */ flags |= WINDOW_ORDER_FIELD_ROOT_PARENT; out_uint32_le(g_out_s, pWindow->drawable.x); /* window_offset_x */ out_uint32_le(g_out_s, pWindow->drawable.y); /* window_offset_y */ flags |= WINDOW_ORDER_FIELD_WND_OFFSET; out_uint32_le(g_out_s, 0); /* window_client_delta_x */ out_uint32_le(g_out_s, 0); /* window_client_delta_y */ flags |= WINDOW_ORDER_FIELD_WND_CLIENT_DELTA; out_uint32_le(g_out_s, pWindow->drawable.width); /* window_width */ out_uint32_le(g_out_s, pWindow->drawable.height); /* window_height */ flags |= WINDOW_ORDER_FIELD_WND_SIZE; out_uint16_le(g_out_s, num_window_rects); /* num_window_rects */ for (index = 0; index < num_window_rects; index++) { out_uint16_le(g_out_s, 0); /* left */ out_uint16_le(g_out_s, 0); /* top */ out_uint16_le(g_out_s, pWindow->drawable.width); /* right */ out_uint16_le(g_out_s, pWindow->drawable.height); /* bottom */ } flags |= WINDOW_ORDER_FIELD_WND_RECTS; out_uint32_le(g_out_s, pWindow->drawable.x); /* visible_offset_x */ out_uint32_le(g_out_s, pWindow->drawable.y); /* visible_offset_y */ flags |= WINDOW_ORDER_FIELD_VIS_OFFSET; out_uint16_le(g_out_s, num_visibility_rects); /* num_visibility_rects */ for (index = 0; index < num_visibility_rects; index++) { out_uint16_le(g_out_s, 0); /* left */ out_uint16_le(g_out_s, 0); /* top */ out_uint16_le(g_out_s, pWindow->drawable.width); /* right */ out_uint16_le(g_out_s, pWindow->drawable.height); /* bottom */ } flags |= WINDOW_ORDER_FIELD_VISIBILITY; out_uint32_le(g_out_s, flags); /* flags */ } } /******************************************************************************/ void rdpup_delete_window(WindowPtr pWindow, rdpWindowRec *priv) { LLOGLN(10, ("rdpup_delete_window: id 0x%8.8x", (int)(pWindow->drawable.id))); if (g_connected) { rdpup_pre_check(8); out_uint16_le(g_out_s, 26); out_uint16_le(g_out_s, 8); g_count++; out_uint32_le(g_out_s, pWindow->drawable.id); /* window_id */ } } /******************************************************************************/ void rdpup_show_window(WindowPtr pWindow, rdpWindowRec* priv, int showState) { LLOGLN(10, ("rdpup_show_window: id 0x%8.8x state 0x%x", pWindow->drawable.id, showState)); if (g_connected) { int flags = WINDOW_ORDER_TYPE_WINDOW; rdpup_pre_check(16); out_uint16_le(g_out_s, 27); out_uint16_le(g_out_s, 16); g_count++; out_uint32_le(g_out_s, pWindow->drawable.id); flags |= WINDOW_ORDER_FIELD_SHOW; out_uint32_le(g_out_s, flags); out_uint32_le(g_out_s, showState); } } /******************************************************************************/ int rdpup_check_dirty(PixmapPtr pDirtyPixmap, rdpPixmapRec *pDirtyPriv) { int index; int clip_index; int count; int num_clips; BoxRec box; xSegment *seg; struct image_data id; struct rdp_draw_item *di; struct rdp_text* rtext; struct rdp_text* trtext; if (pDirtyPriv == 0) { return 0; } if (pDirtyPriv->is_dirty == 0) { return 0; } LLOGLN(10, ("rdpup_check_dirty: got dirty")); rdpup_switch_os_surface(pDirtyPriv->rdpindex); rdpup_get_pixmap_image_rect(pDirtyPixmap, &id); rdpup_begin_update(); draw_item_pack(pDirtyPixmap, pDirtyPriv); di = pDirtyPriv->draw_item_head; while (di != 0) { LLOGLN(10, ("rdpup_check_dirty: type %d", di->type)); switch (di->type) { case RDI_FILL: rdpup_set_fgcolor(di->u.fill.fg_color); rdpup_set_opcode(di->u.fill.opcode); count = REGION_NUM_RECTS(di->reg); for (index = 0; index < count; index++) { box = REGION_RECTS(di->reg)[index]; LLOGLN(10, (" RDI_FILL %d %d %d %d", box.x1, box.y1, box.x2, box.y2)); rdpup_fill_rect(box.x1, box.y1, box.x2 - box.x1, box.y2 - box.y1); } rdpup_set_opcode(GXcopy); break; case RDI_IMGLL: rdpup_set_hints(1, 1); rdpup_set_opcode(di->u.img.opcode); count = REGION_NUM_RECTS(di->reg); for (index = 0; index < count; index++) { box = REGION_RECTS(di->reg)[index]; LLOGLN(10, (" RDI_IMGLL %d %d %d %d", box.x1, box.y1, box.x2, box.y2)); rdpup_send_area(&id, box.x1, box.y1, box.x2 - box.x1, box.y2 - box.y1); } rdpup_set_opcode(GXcopy); rdpup_set_hints(0, 1); break; case RDI_IMGLY: rdpup_set_opcode(di->u.img.opcode); count = REGION_NUM_RECTS(di->reg); for (index = 0; index < count; index++) { box = REGION_RECTS(di->reg)[index]; LLOGLN(10, (" RDI_IMGLY %d %d %d %d", box.x1, box.y1, box.x2, box.y2)); rdpup_send_area(&id, box.x1, box.y1, box.x2 - box.x1, box.y2 - box.y1); } rdpup_set_opcode(GXcopy); break; case RDI_LINE: LLOGLN(10, (" RDI_LINE")); num_clips = REGION_NUM_RECTS(di->reg); if (num_clips > 0) { rdpup_set_fgcolor(di->u.line.fg_color); rdpup_set_opcode(di->u.line.opcode); rdpup_set_pen(0, di->u.line.width); for (clip_index = num_clips - 1; clip_index >= 0; clip_index--) { box = REGION_RECTS(di->reg)[clip_index]; rdpup_set_clip(box.x1, box.y1, box.x2 - box.x1, box.y2 - box.y1); for (index = 0; index < di->u.line.nseg; index++) { seg = di->u.line.segs + index; LLOGLN(10, (" RDI_LINE %d %d %d %d", seg->x1, seg->y1, seg->x2, seg->y2)); rdpup_draw_line(seg->x1, seg->y1, seg->x2, seg->y2); } } } rdpup_reset_clip(); rdpup_set_opcode(GXcopy); break; case RDI_SCRBLT: LLOGLN(10, (" RDI_SCRBLT")); break; case RDI_TEXT: LLOGLN(10, (" RDI_TEXT")); num_clips = REGION_NUM_RECTS(di->reg); if (num_clips > 0) { LLOGLN(10, (" num_clips %d", num_clips)); rdpup_set_fgcolor(di->u.text.fg_color); rdpup_set_opcode(di->u.text.opcode); rtext = di->u.text.rtext; trtext = rtext; while (trtext != 0) { rdp_text_chars_to_data(trtext); for (clip_index = num_clips - 1; clip_index >= 0; clip_index--) { box = REGION_RECTS(di->reg)[clip_index]; rdpup_set_clip(box.x1, box.y1, box.x2 - box.x1, box.y2 - box.y1); LLOGLN(10, (" %d %d %d %d", box.x1, box.y1, box.x2, box.y2)); box = RegionExtents(trtext->reg)[0]; rdpup_draw_text(trtext->font, trtext->flags, trtext->mixmode, box.x1, box.y1, box.x2, box.y2, //box.x1, box.y1, box.x2, box.y2, 0, 0, 0, 0, trtext->x, trtext->y, trtext->data, trtext->data_bytes); } trtext = trtext->next; } } rdpup_reset_clip(); rdpup_set_opcode(GXcopy); break; } di = di->next; } draw_item_remove_all(pDirtyPriv); rdpup_end_update(); pDirtyPriv->is_dirty = 0; rdpup_switch_os_surface(-1); return 0; } /******************************************************************************/ int rdpup_check_dirty_screen(rdpPixmapRec *pDirtyPriv) { int index; int clip_index; int count; int num_clips; BoxRec box; xSegment *seg; struct image_data id; struct rdp_draw_item *di; if (pDirtyPriv == 0) { return 0; } if (pDirtyPriv->is_dirty == 0) { return 0; } LLOGLN(10, ("rdpup_check_dirty_screen: got dirty")); rdpup_get_screen_image_rect(&id); rdpup_begin_update(); draw_item_pack(0, pDirtyPriv); di = pDirtyPriv->draw_item_head; while (di != 0) { LLOGLN(10, ("rdpup_check_dirty_screen: type %d", di->type)); switch (di->type) { case RDI_FILL: rdpup_set_fgcolor(di->u.fill.fg_color); rdpup_set_opcode(di->u.fill.opcode); count = REGION_NUM_RECTS(di->reg); for (index = 0; index < count; index++) { box = REGION_RECTS(di->reg)[index]; LLOGLN(10, (" RDI_FILL %d %d %d %d", box.x1, box.y1, box.x2, box.y2)); rdpup_fill_rect(box.x1, box.y1, box.x2 - box.x1, box.y2 - box.y1); } rdpup_set_opcode(GXcopy); break; case RDI_IMGLL: rdpup_set_hints(1, 1); rdpup_set_opcode(di->u.img.opcode); count = REGION_NUM_RECTS(di->reg); for (index = 0; index < count; index++) { box = REGION_RECTS(di->reg)[index]; LLOGLN(10, (" RDI_IMGLL x %d y %d w %d h %d", box.x1, box.y1, box.x2 - box.x1, box.y2 - box.y1)); rdpup_send_area(&id, box.x1, box.y1, box.x2 - box.x1, box.y2 - box.y1); } rdpup_set_opcode(GXcopy); rdpup_set_hints(0, 1); break; case RDI_IMGLY: rdpup_set_opcode(di->u.img.opcode); count = REGION_NUM_RECTS(di->reg); for (index = 0; index < count; index++) { box = REGION_RECTS(di->reg)[index]; LLOGLN(10, (" RDI_IMGLY %d %d %d %d", box.x1, box.y1, box.x2, box.y2)); rdpup_send_area(&id, box.x1, box.y1, box.x2 - box.x1, box.y2 - box.y1); } rdpup_set_opcode(GXcopy); break; case RDI_LINE: LLOGLN(10, (" RDI_LINE")); num_clips = REGION_NUM_RECTS(di->reg); if (num_clips > 0) { rdpup_set_fgcolor(di->u.line.fg_color); rdpup_set_opcode(di->u.line.opcode); rdpup_set_pen(0, di->u.line.width); for (clip_index = num_clips - 1; clip_index >= 0; clip_index--) { box = REGION_RECTS(di->reg)[clip_index]; rdpup_set_clip(box.x1, box.y1, box.x2 - box.x1, box.y2 - box.y1); for (index = 0; index < di->u.line.nseg; index++) { seg = di->u.line.segs + index; LLOGLN(10, (" RDI_LINE %d %d %d %d", seg->x1, seg->y1, seg->x2, seg->y2)); rdpup_draw_line(seg->x1, seg->y1, seg->x2, seg->y2); } } } rdpup_reset_clip(); rdpup_set_opcode(GXcopy); break; case RDI_SCRBLT: LLOGLN(10, (" RDI_SCRBLT")); break; } di = di->next; } draw_item_remove_all(pDirtyPriv); rdpup_end_update(); pDirtyPriv->is_dirty = 0; return 0; } /******************************************************************************/ int rdpup_check_alpha_dirty(PixmapPtr pDirtyPixmap, rdpPixmapRec* pDirtyPriv) { struct image_data id; LLOGLN(10, ("rdpup_check_alpha_dirty: width %d height %d", pDirtyPixmap->drawable.width, pDirtyPixmap->drawable.height)); if (pDirtyPriv == 0) { return 0; } LLOGLN(10, ("rdpup_check_alpha_dirty: is_alpha_dirty_not %d", pDirtyPriv->is_alpha_dirty_not)); if (pDirtyPriv->is_alpha_dirty_not) { return 0; } pDirtyPriv->is_alpha_dirty_not = 1; rdpup_switch_os_surface(pDirtyPriv->rdpindex); rdpup_get_pixmap_image_rect(pDirtyPixmap, &id); rdpup_begin_update(); rdpup_send_alpha_area(&id, 0, 0, pDirtyPixmap->drawable.width, pDirtyPixmap->drawable.height); rdpup_end_update(); rdpup_switch_os_surface(-1); return 0; } /******************************************************************************/ int rdpup_add_char(int font, int character, short x, short y, int cx, int cy, char* bmpdata, int bmpdata_bytes) { if (g_connected) { LLOGLN(10, (" rdpup_add_char")); rdpup_pre_check(18 + bmpdata_bytes); out_uint16_le(g_out_s, 28); /* add char */ out_uint16_le(g_out_s, 18 + bmpdata_bytes); /* size */ g_count++; out_uint16_le(g_out_s, font); out_uint16_le(g_out_s, character); out_uint16_le(g_out_s, x); out_uint16_le(g_out_s, y); out_uint16_le(g_out_s, cx); out_uint16_le(g_out_s, cy); out_uint16_le(g_out_s, bmpdata_bytes); out_uint8a(g_out_s, bmpdata, bmpdata_bytes); } return 0; } /******************************************************************************/ int rdpup_add_char_alpha(int font, int character, short x, short y, int cx, int cy, char* bmpdata, int bmpdata_bytes) { if (g_connected) { LLOGLN(10, (" rdpup_add_char_alpha")); rdpup_pre_check(18 + bmpdata_bytes); out_uint16_le(g_out_s, 29); /* add char alpha */ out_uint16_le(g_out_s, 18 + bmpdata_bytes); /* size */ g_count++; out_uint16_le(g_out_s, font); out_uint16_le(g_out_s, character); out_uint16_le(g_out_s, x); out_uint16_le(g_out_s, y); out_uint16_le(g_out_s, cx); out_uint16_le(g_out_s, cy); out_uint16_le(g_out_s, bmpdata_bytes); out_uint8a(g_out_s, bmpdata, bmpdata_bytes); } return 0; } /******************************************************************************/ int rdpup_draw_text(int font, int flags, int mixmode, short clip_left, short clip_top, short clip_right, short clip_bottom, short box_left, short box_top, short box_right, short box_bottom, short x, short y, char* data, int data_bytes) { if (g_connected) { LLOGLN(10, (" rdpup_draw_text")); rdpup_pre_check(32 + data_bytes); out_uint16_le(g_out_s, 30); /* draw text */ out_uint16_le(g_out_s, 32 + data_bytes); /* size */ g_count++; out_uint16_le(g_out_s, font); out_uint16_le(g_out_s, flags); out_uint16_le(g_out_s, mixmode); out_uint16_le(g_out_s, clip_left); out_uint16_le(g_out_s, clip_top); out_uint16_le(g_out_s, clip_right); out_uint16_le(g_out_s, clip_bottom); out_uint16_le(g_out_s, box_left); out_uint16_le(g_out_s, box_top); out_uint16_le(g_out_s, box_right); out_uint16_le(g_out_s, box_bottom); out_uint16_le(g_out_s, x); out_uint16_le(g_out_s, y); out_uint16_le(g_out_s, data_bytes); out_uint8a(g_out_s, data, data_bytes); } return 0; } /******************************************************************************/ int rdpup_composite(short srcidx, int srcformat, short srcwidth, CARD8 srcrepeat, PictTransform* srctransform, CARD8 mskflags, short mskidx, int mskformat, short mskwidth, CARD8 mskrepeat, CARD8 op, short srcx, short srcy, short mskx, short msky, short dstx, short dsty, short width, short height, int dstformat) { if (g_connected) { LLOGLN(10, (" rdpup_composite")); rdpup_pre_check(84); out_uint16_le(g_out_s, 33); out_uint16_le(g_out_s, 84); /* size */ g_count++; out_uint16_le(g_out_s, srcidx); out_uint32_le(g_out_s, srcformat); out_uint16_le(g_out_s, srcwidth); out_uint8(g_out_s, srcrepeat); if (srctransform == 0) { out_uint8s(g_out_s, 10 * 4); } else { out_uint32_le(g_out_s, 1); out_uint32_le(g_out_s, srctransform->matrix[0][0]); out_uint32_le(g_out_s, srctransform->matrix[0][1]); out_uint32_le(g_out_s, srctransform->matrix[0][2]); out_uint32_le(g_out_s, srctransform->matrix[1][0]); out_uint32_le(g_out_s, srctransform->matrix[1][1]); out_uint32_le(g_out_s, srctransform->matrix[1][2]); out_uint32_le(g_out_s, srctransform->matrix[2][0]); out_uint32_le(g_out_s, srctransform->matrix[2][1]); out_uint32_le(g_out_s, srctransform->matrix[2][2]); } out_uint8(g_out_s, mskflags); out_uint16_le(g_out_s, mskidx); out_uint32_le(g_out_s, mskformat); out_uint16_le(g_out_s, mskwidth); out_uint8(g_out_s, mskrepeat); out_uint8(g_out_s, op); out_uint16_le(g_out_s, srcx); out_uint16_le(g_out_s, srcy); out_uint16_le(g_out_s, mskx); out_uint16_le(g_out_s, msky); out_uint16_le(g_out_s, dstx); out_uint16_le(g_out_s, dsty); out_uint16_le(g_out_s, width); out_uint16_le(g_out_s, height); out_uint32_le(g_out_s, dstformat); } return 0; } xrdp-0.9.5/xorg/X11R7.6/rdp/rdpxv.c000644 001751 001751 00000032224 13127114621 016424 0ustar00metameta000000 000000 /* Copyright 2013 Jay Sorg Permission to use, copy, modify, distribute, and sell this software and its documentation for any purpose is hereby granted without fee, provided that the above copyright notice appear in all copies and that both that copyright notice and this permission notice appear in supporting documentation. The above copyright notice and this permission notice shall be included in all copies or substantial portions of the Software. THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE OPEN GROUP BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. XVideo extension */ #include "rdp.h" #include #include #include "xvdix.h" #include extern rdpScreenInfoRec g_rdpScreen; /* from rdpmain.c */ static DevPrivateKey g_XvScreenKey; static char g_xv_adaptor_name[] = "xrdp XVideo adaptor"; static char g_xv_encoding_name[] = "XV_IMAGE"; #define GET_XV_SCREEN(pScreen) \ ((XvScreenPtr)dixLookupPrivate(&(pScreen)->devPrivates, g_XvScreenKey)) #define LOG_LEVEL 1 #define LLOG(_level, _args) \ do { if (_level < LOG_LEVEL) { ErrorF _args ; } } while (0) #define LLOGLN(_level, _args) \ do { if (_level < LOG_LEVEL) { ErrorF _args ; ErrorF("\n"); } } while (0) #define T_NUM_ENCODINGS 1 static XvEncodingRec g_encodings[T_NUM_ENCODINGS]; #define T_NUM_FORMATS 1 static XvFormatRec g_formats[T_NUM_FORMATS]; #define T_NUM_PORTS 1 static XvPortRec g_ports[T_NUM_PORTS]; #define FOURCC_RV15 0x35315652 #define FOURCC_RV16 0x36315652 #define FOURCC_RV24 0x34325652 #define FOURCC_RV32 0x32335652 #define T_NUM_IMAGES 8 static XvImageRec g_images[T_NUM_IMAGES] = { { FOURCC_RV15,XvRGB,LSBFirst, {'R','V','1','5',0,0,0,0,0,0,0,0,0,0,0,0}, 16, XvPacked, 1, 15, 0x001f, 0x03e0, 0x7c00, 0, 0, 0, 0, 0, 0, 0, 0, 0, {'R','V','B',0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0}, XvTopToBottom }, { FOURCC_RV16,XvRGB,LSBFirst, {'R','V','1','6',0,0,0,0,0,0,0,0,0,0,0,0}, 16, XvPacked, 1, 16, 0x001f, 0x07e0, 0xf800, 0, 0, 0, 0, 0, 0, 0, 0, 0, {'R','V','B',0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0}, XvTopToBottom }, { FOURCC_RV24,XvRGB,LSBFirst, {'R','V','2','4',0,0,0,0,0,0,0,0,0,0,0,0}, 32, XvPacked, 1, 24, 0x000000ff, 0x0000ff00, 0x00ff0000, 0, 0, 0, 0, 0, 0, 0, 0, 0, {'R','V','B',0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0}, XvTopToBottom }, { FOURCC_RV32, XvRGB, LSBFirst, {'R','V','3','2',0,0,0,0,0,0,0,0,0,0,0,0}, 32, XvPacked, 1, 32, 0x000000ff, 0x0000ff00, 0x00ff0000, 0, 0, 0, 0, 0, 0, 0, 0, 0, {'R','V','B',0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0}, XvTopToBottom }, XVIMAGE_YV12, XVIMAGE_YUY2, XVIMAGE_UYVY, XVIMAGE_I420 }; /*****************************************************************************/ static int rdpXvAllocatePort(unsigned long port, XvPortPtr pPort, XvPortPtr* ppPort) { LLOGLN(0, ("rdpXvAllocatePort:")); *ppPort = pPort; return Success; } /*****************************************************************************/ static int rdpXvFreePort(XvPortPtr pPort) { LLOGLN(0, ("rdpXvFreePort:")); return Success; } /*****************************************************************************/ static int rdpXvPutVideo(ClientPtr client, DrawablePtr pDraw, XvPortPtr pPort, GCPtr pGC, INT16 vid_x, INT16 vid_y, CARD16 vid_w, CARD16 vid_h, INT16 drw_x, INT16 drw_y, CARD16 drw_w, CARD16 drw_h) { LLOGLN(0, ("rdpXvPutVideo:")); return Success; } /*****************************************************************************/ static int rdpXvPutStill(ClientPtr client, DrawablePtr pDraw, XvPortPtr pPort, GCPtr pGC, INT16 vid_x, INT16 vid_y, CARD16 vid_w, CARD16 vid_h, INT16 drw_x, INT16 drw_y, CARD16 drw_w, CARD16 drw_h) { LLOGLN(0, ("rdpXvPutStill:")); return Success; } /*****************************************************************************/ static int rdpXvGetVideo(ClientPtr client, DrawablePtr pDraw, XvPortPtr pPort, GCPtr pGC, INT16 vid_x, INT16 vid_y, CARD16 vid_w, CARD16 vid_h, INT16 drw_x, INT16 drw_y, CARD16 drw_w, CARD16 drw_h) { LLOGLN(0, ("rdpXvGetVideo:")); return Success; } /*****************************************************************************/ static int rdpXvGetStill(ClientPtr client, DrawablePtr pDraw, XvPortPtr pPort, GCPtr pGC, INT16 vid_x, INT16 vid_y, CARD16 vid_w, CARD16 vid_h, INT16 drw_x, INT16 drw_y, CARD16 drw_w, CARD16 drw_h) { LLOGLN(0, ("rdpXvGetStill:")); return Success; } /*****************************************************************************/ static int rdpXvStopVideo(ClientPtr client, XvPortPtr pPort, DrawablePtr pDraw) { LLOGLN(0, ("rdpXvStopVideo:")); return Success; } /*****************************************************************************/ static int rdpXvSetPortAttribute(ClientPtr client, XvPortPtr pPort, Atom attribute, INT32 value) { LLOGLN(0, ("rdpXvSetPortAttribute:")); return Success; } /*****************************************************************************/ static int rdpXvGetPortAttribute(ClientPtr client, XvPortPtr pPort, Atom attribute, INT32* p_value) { LLOGLN(0, ("rdpXvGetPortAttribute:")); return Success; } /*****************************************************************************/ static int rdpXvQueryBestSize(ClientPtr client, XvPortPtr pPort, CARD8 motion, CARD16 vid_w, CARD16 vid_h, CARD16 drw_w, CARD16 drw_h, unsigned int *p_w, unsigned int *p_h) { LLOGLN(0, ("rdpXvQueryBestSize:")); return Success; } /*****************************************************************************/ static int rdpXvPutImage(ClientPtr client, DrawablePtr pDraw, XvPortPtr pPort, GCPtr pGC, INT16 src_x, INT16 src_y, CARD16 src_w, CARD16 src_h, INT16 drw_x, INT16 drw_y, CARD16 drw_w, CARD16 drw_h, XvImagePtr format, unsigned char* data, Bool sync, CARD16 width, CARD16 height) { LLOGLN(0, ("rdpXvPutImage:")); return Success; } /*****************************************************************************/ static int rdpXvPrintFormat(int id) { switch (id) { case FOURCC_YV12: /* big buck bunny 480p h264 */ /* vob files too */ LLOGLN(0, ("FOURCC_YV12")); break; case FOURCC_I420: LLOGLN(0, ("FOURCC_I420")); break; case FOURCC_RV15: LLOGLN(0, ("FOURCC_RV15")); break; case FOURCC_RV16: LLOGLN(0, ("FOURCC_RV16")); break; case FOURCC_YUY2: LLOGLN(0, ("FOURCC_YUY2")); break; case FOURCC_UYVY: LLOGLN(0, ("FOURCC_UYVY")); break; case FOURCC_RV24: LLOGLN(0, ("FOURCC_RV24")); break; default: LLOGLN(0, ("other")); break; } return 0; } /*****************************************************************************/ static int rdpXvQueryImageAttributes(ClientPtr client, XvPortPtr pPort, XvImagePtr format, CARD16* width, CARD16* height, int* pitches, int* offsets) { int size; int tmp; LLOGLN(0, ("rdpXvQueryImageAttributes:")); size = 0; /* this is same code as all drivers currently have */ if (*width > 2046) { *width = 2046; } if (*height > 2046) { *height = 2046; } /* make w multiple of 4 so that resizing works properly */ *width = (*width + 3) & ~3; if (offsets) { offsets[0] = 0; } LLOGLN(0, ("format %x", format->id)); rdpXvPrintFormat(format->id); switch (format->id) { case FOURCC_YV12: case FOURCC_I420: /* make h be even */ *height = (*height + 1) & ~1; /* make w be multiple of 4 (ie. pad it) */ size = (*width + 3) & ~3; /* width of a Y row => width of image */ if (pitches != 0) { pitches[0] = size; } /* offset of U plane => w*h */ size *= *height; if (offsets != 0) { offsets[1] = size; } /* width of U, V row => width/2 */ tmp = ((*width >> 1) +3) & ~3; if (pitches != 0) { pitches[1] = pitches[2] = tmp; } /* offset of V => Y plane + U plane (w*h + w/2*h/2) */ tmp *= (*height >> 1); size += tmp; size += tmp; if (offsets != 0) { offsets[2] = size; } size += tmp; break; case FOURCC_RV15: case FOURCC_RV16: case FOURCC_YUY2: case FOURCC_UYVY: size = (*width) * 2; if (pitches) { pitches[0] = size; } size *= *height; break; case FOURCC_RV24: size = (*width) * 3; if (pitches) { pitches[0] = size; } size *= *height; break; default: LLOGLN(0, ("rdpXvQueryImageAttributes: error")); break; } return size; } /*****************************************************************************/ static Bool rdpXvCloseScreen(int i, ScreenPtr pScreen) { XvScreenPtr pxvs = GET_XV_SCREEN(pScreen); LLOGLN(0, ("rdpXvCloseScreen:")); free(pxvs->pAdaptors); return 0; } /*****************************************************************************/ static int rdpXvQueryAdaptors(ScreenPtr pScreen, XvAdaptorPtr* p_pAdaptors, int* p_nAdaptors) { XvScreenPtr pxvs = GET_XV_SCREEN(pScreen); LLOGLN(0, ("rdpXvQueryAdaptors:")); *p_nAdaptors = pxvs->nAdaptors; *p_pAdaptors = pxvs->pAdaptors; return Success; } #ifdef MITSHM #endif /*****************************************************************************/ static int rdpXvInitAdaptors(ScreenPtr pScreen) { XvScreenPtr pxvs = GET_XV_SCREEN(pScreen); XvAdaptorPtr pAdaptor; pAdaptor = malloc(sizeof(XvAdaptorRec)); memset(pAdaptor, 0, sizeof(XvAdaptorRec)); pAdaptor->type = XvInputMask | XvOutputMask | XvImageMask | XvVideoMask | XvStillMask; pAdaptor->pScreen = pScreen; pAdaptor->name = g_xv_adaptor_name; pAdaptor->nEncodings = T_NUM_ENCODINGS; pAdaptor->pEncodings = g_encodings; pAdaptor->nFormats = T_NUM_FORMATS; pAdaptor->pFormats = g_formats; pAdaptor->nImages = T_NUM_IMAGES; pAdaptor->pImages = g_images; pAdaptor->nPorts = T_NUM_PORTS; pAdaptor->pPorts = g_ports; pAdaptor->ddAllocatePort = rdpXvAllocatePort; pAdaptor->ddFreePort = rdpXvFreePort; pAdaptor->ddPutVideo = rdpXvPutVideo; pAdaptor->ddPutStill = rdpXvPutStill; pAdaptor->ddGetVideo = rdpXvGetVideo; pAdaptor->ddGetStill = rdpXvGetStill; pAdaptor->ddStopVideo = rdpXvStopVideo; pAdaptor->ddSetPortAttribute = rdpXvSetPortAttribute; pAdaptor->ddGetPortAttribute = rdpXvGetPortAttribute; pAdaptor->ddQueryBestSize = rdpXvQueryBestSize; pAdaptor->ddPutImage = rdpXvPutImage; pAdaptor->ddQueryImageAttributes = rdpXvQueryImageAttributes; pxvs->pAdaptors = pAdaptor; memset(g_encodings, 0, sizeof(g_encodings)); g_encodings[0].id = FakeClientID(0); g_encodings[0].pScreen = pScreen; g_encodings[0].name = g_xv_encoding_name; g_encodings[0].width = 2046; g_encodings[0].height = 2046; g_encodings[0].rate.numerator = 1; g_encodings[0].rate.denominator = 1; memset(g_formats, 0, sizeof(g_formats)); g_formats[0].depth = g_rdpScreen.depth; g_formats[0].visual = pScreen->rootVisual; memset(g_ports, 0, sizeof(g_ports)); g_ports[0].id = FakeClientID(0); g_ports[0].pAdaptor = pAdaptor; g_ports[0].pNotify = 0; g_ports[0].pDraw = 0; g_ports[0].grab.id = 0; g_ports[0].grab.client = 0; g_ports[0].time = currentTime; g_ports[0].devPriv.ptr = 0; pAdaptor->base_id = g_ports[0].id; AddResource(g_ports[0].id, XvRTPort, g_ports); pxvs->nAdaptors = 1; pxvs->pAdaptors = pAdaptor; return 0; } /*****************************************************************************/ /* returns error */ int rdpXvInit(ScreenPtr pScreen) { XvScreenPtr pxvs; LLOGLN(0, ("rdpXvInit:")); XvScreenInit(pScreen); g_XvScreenKey = XvGetScreenKey(); pxvs = GET_XV_SCREEN(pScreen); pxvs->nAdaptors = 0; pxvs->ddCloseScreen = rdpXvCloseScreen; pxvs->ddQueryAdaptors = rdpXvQueryAdaptors; rdpXvInitAdaptors(pScreen); return 0; } xrdp-0.9.5/xorg/X11R7.6/rdp/rdpComposite.c000644 001751 001751 00000063136 13127114621 017737 0ustar00metameta000000 000000 /* Copyright 2012-2013 Jay Sorg Permission to use, copy, modify, distribute, and sell this software and its documentation for any purpose is hereby granted without fee, provided that the above copyright notice appear in all copies and that both that copyright notice and this permission notice appear in supporting documentation. The above copyright notice and this permission notice shall be included in all copies or substantial portions of the Software. THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE OPEN GROUP BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. */ #include "rdp.h" #include "rdpdraw.h" #define LDEBUG 0 #define LOG_LEVEL 1 #define LLOG(_level, _args) \ do { if (_level < LOG_LEVEL) { ErrorF _args ; } } while (0) #define LLOGLN(_level, _args) \ do { if (_level < LOG_LEVEL) { ErrorF _args ; ErrorF("\n"); } } while (0) extern rdpScreenInfoRec g_rdpScreen; /* from rdpmain.c */ extern DevPrivateKeyRec g_rdpGCIndex; /* from rdpmain.c */ extern DevPrivateKeyRec g_rdpWindowIndex; /* from rdpmain.c */ extern DevPrivateKeyRec g_rdpPixmapIndex; /* from rdpmain.c */ extern int g_Bpp; /* from rdpmain.c */ extern ScreenPtr g_pScreen; /* from rdpmain.c */ extern Bool g_wrapPixmap; /* from rdpmain.c */ extern int g_can_do_pix_to_pix; /* from rdpmain.c */ extern int g_do_dirty_os; /* in rdpmain.c */ extern int g_do_dirty_ons; /* in rdpmain.c */ extern rdpPixmapRec g_screenPriv; /* in rdpmain.c */ extern int g_do_glyph_cache; /* in rdpmain.c */ extern int g_doing_font; /* in rdpmain.c */ extern int g_do_composite; /* in rdpmain.c */ extern GCOps g_rdpGCOps; /* from rdpdraw.c */ extern int g_con_number; /* in rdpup.c */ extern int g_crc_seed; /* in rdpmisc.c */ extern int g_crc_table[]; /* in rdpmisc.c */ /******************************************************************************/ int rdpCreatePicture(PicturePtr pPicture) { PictureScreenPtr ps; int rv; LLOGLN(10, ("rdpCreatePicture:")); ps = GetPictureScreen(g_pScreen); ps->CreatePicture = g_rdpScreen.CreatePicture; rv = ps->CreatePicture(pPicture); ps->CreatePicture = rdpCreatePicture; return rv; } /******************************************************************************/ void rdpDestroyPicture(PicturePtr pPicture) { PictureScreenPtr ps; LLOGLN(10, ("rdpDestroyPicture:")); ps = GetPictureScreen(g_pScreen); ps->DestroyPicture = g_rdpScreen.DestroyPicture; ps->DestroyPicture(pPicture); ps->DestroyPicture = rdpDestroyPicture; } /******************************************************************************/ static int print_format(PictFormatShort format) { switch (format) { case PIXMAN_a2r10g10b10: LLOGLN(0, (" PIXMAN_x2r10g10b10")); break; case PIXMAN_x2r10g10b10: LLOGLN(0, (" PIXMAN_x2r10g10b10")); break; case PIXMAN_a2b10g10r10: LLOGLN(0, (" PIXMAN_a2b10g10r10")); break; case PIXMAN_x2b10g10r10: LLOGLN(0, (" PIXMAN_x2b10g10r10")); break; case PIXMAN_a8r8g8b8: LLOGLN(0, (" PIXMAN_a8r8g8b8")); break; case PIXMAN_x8r8g8b8: LLOGLN(0, (" PIXMAN_x8r8g8b8")); break; case PIXMAN_a8b8g8r8: LLOGLN(0, (" PIXMAN_a8b8g8r8")); break; case PIXMAN_x8b8g8r8: LLOGLN(0, (" PIXMAN_x8b8g8r8")); break; case PIXMAN_b8g8r8a8: LLOGLN(0, (" PIXMAN_b8g8r8a8")); break; case PIXMAN_b8g8r8x8: LLOGLN(0, (" PIXMAN_b8g8r8x8")); break; /* 24bpp formats */ case PIXMAN_r8g8b8: LLOGLN(0, (" PIXMAN_r8g8b8")); break; case PIXMAN_b8g8r8: LLOGLN(0, (" PIXMAN_b8g8r8")); break; /* 16bpp formats */ case PIXMAN_r5g6b5: LLOGLN(0, (" PIXMAN_r5g6b5")); break; case PIXMAN_b5g6r5: LLOGLN(0, (" PIXMAN_b5g6r5")); break; case PIXMAN_a1r5g5b5: LLOGLN(0, (" PIXMAN_a1r5g5b5")); break; case PIXMAN_x1r5g5b5: LLOGLN(0, (" PIXMAN_x1r5g5b5")); break; case PIXMAN_a1b5g5r5: LLOGLN(0, (" PIXMAN_a1b5g5r5")); break; case PIXMAN_x1b5g5r5: LLOGLN(0, (" PIXMAN_x1b5g5r5")); break; case PIXMAN_a4r4g4b4: LLOGLN(0, (" PIXMAN_a4r4g4b4")); break; case PIXMAN_x4r4g4b4: LLOGLN(0, (" PIXMAN_x4r4g4b4")); break; case PIXMAN_a4b4g4r4: LLOGLN(0, (" PIXMAN_a4b4g4r4")); break; case PIXMAN_x4b4g4r4: LLOGLN(0, (" PIXMAN_x4b4g4r4")); break; /* 8bpp formats */ case PIXMAN_a8: LLOGLN(0, (" PIXMAN_a8")); break; case PIXMAN_r3g3b2: LLOGLN(0, (" PIXMAN_r3g3b2")); break; case PIXMAN_b2g3r3: LLOGLN(0, (" PIXMAN_b2g3r3")); break; case PIXMAN_a2r2g2b2: LLOGLN(0, (" PIXMAN_a2r2g2b2")); break; case PIXMAN_a2b2g2r2: LLOGLN(0, (" PIXMAN_a2b2g2r2")); break; case PIXMAN_c8: LLOGLN(0, (" PIXMAN_c8")); break; case PIXMAN_g8: LLOGLN(0, (" PIXMAN_g8")); break; case PIXMAN_x4a4: LLOGLN(0, (" PIXMAN_x4a4")); break; /* 4bpp formats */ case PIXMAN_a4: LLOGLN(0, (" PIXMAN_a4")); break; case PIXMAN_r1g2b1: LLOGLN(0, (" PIXMAN_r1g2b1")); break; case PIXMAN_b1g2r1: LLOGLN(0, (" PIXMAN_b1g2r1")); break; case PIXMAN_a1r1g1b1: LLOGLN(0, (" PIXMAN_a1r1g1b1")); break; case PIXMAN_a1b1g1r1: LLOGLN(0, (" PIXMAN_a1b1g1r1")); break; case PIXMAN_c4: LLOGLN(0, (" PIXMAN_c4")); break; case PIXMAN_g4: LLOGLN(0, (" PIXMAN_g4")); break; /* 1bpp formats */ case PIXMAN_a1: LLOGLN(0, (" PIXMAN_a1")); break; case PIXMAN_g1: LLOGLN(0, (" PIXMAN_g1")); break; } return 0; } /******************************************************************************/ static int composite_print(CARD8 op, PicturePtr pSrc, PicturePtr pMask, PicturePtr pDst, INT16 xSrc, INT16 ySrc, INT16 xMask, INT16 yMask, INT16 xDst, INT16 yDst, CARD16 width, CARD16 height) { PixmapPtr pSrcPixmap; PixmapPtr pDstPixmap; rdpPixmapRec* pSrcPriv; rdpPixmapRec* pDstPriv; LLOGLN(0, ("composite_print: op %d xSrc %d ySrc %d xDst %d yDst %d " "width %d height %d", op, xSrc, ySrc, xDst, yDst, width, height)); if (pSrc != 0) { LLOGLN(0, (" src depth %d width %d height %d repeat %d repeatType %d " "dither %d filter %d alphaMap %p componentAlpha %d", pSrc->pDrawable->depth, pSrc->pDrawable->width, pSrc->pDrawable->height, pSrc->repeat, pSrc->repeatType, pSrc->dither, pSrc->filter, pSrc->alphaMap, pSrc->componentAlpha)); LLOGLN(0, (" transform %p", pSrc->transform)); LLOGLN(0, (" detail format red %d red mask %d green %d green mask %d " "blue %d blue mask %d", pSrc->pFormat->direct.red, pSrc->pFormat->direct.redMask, pSrc->pFormat->direct.green, pSrc->pFormat->direct.greenMask, pSrc->pFormat->direct.blue, pSrc->pFormat->direct.blueMask)); print_format(pSrc->format); if (pSrc->pDrawable->type == DRAWABLE_PIXMAP) { pSrcPixmap = (PixmapPtr)(pSrc->pDrawable); pSrcPriv = GETPIXPRIV(pSrcPixmap); LLOGLN(0, (" DRAWABLE_PIXMAP pSrcPriv %p status %d", pSrcPriv, pSrcPriv->status)); } else if (pSrc->pDrawable->type == DRAWABLE_WINDOW) { LLOGLN(0, (" DRAWABLE_WINDOW")); } else { LLOGLN(0, (" OTHER")); } } if (pMask != 0) { LLOGLN(0, (" msk depth %d width %d height %d repeat %d repeatType %d", pMask->pDrawable->depth, pMask->pDrawable->width, pMask->pDrawable->height, pMask->repeat, pMask->repeatType)); print_format(pMask->format); } if (pDst != 0) { LLOGLN(0, (" dst depth %d width %d height %d repeat %d repeatType %d " "dither %d filter %d alphaMap %p", pDst->pDrawable->depth, pDst->pDrawable->width, pDst->pDrawable->height, pDst->repeat, pDst->repeatType, pDst->dither, pDst->filter, pDst->alphaMap)); LLOGLN(0, (" transform %p", pDst->transform)); print_format(pDst->format); if (pDst->pDrawable->type == DRAWABLE_PIXMAP) { pDstPixmap = (PixmapPtr)(pDst->pDrawable); pDstPriv = GETPIXPRIV(pDstPixmap); LLOGLN(0, (" DRAWABLE_PIXMAP pDstPriv %p status %d", pDstPriv, pDstPriv->status)); } else if (pDst->pDrawable->type == DRAWABLE_WINDOW) { LLOGLN(0, (" DRAWABLE_WINDOW")); } else { LLOGLN(0, (" OTHER")); } } return 0; } /******************************************************************************/ static int src_alpha_needed(CARD8 op) { int rv; rv = 0; switch (op) { case 3: /* Over */ case 6: /* InReverse */ case 8: /* OutReverse */ case 9: /* Atop */ case 10: /* AtopReverse */ case 11: /* Xor */ case 13: /* Saturate */ case 17: /* DisjointOver */ case 18: /* DisjointOverReverse */ case 19: /* DisjointIn */ case 20: /* DisjointInReverse */ case 21: /* DisjointOut */ case 22: /* DisjointOutReverse */ case 23: /* DisjointAtop */ case 24: /* DisjointAtopReverse */ case 25: /* DisjointXor */ case 29: /* ConjointOver */ case 30: /* ConjointOverReverse */ case 31: /* ConjointIn */ case 32: /* ConjointInReverse */ case 33: /* ConjointOut */ case 34: /* ConjointOutReverse */ case 35: /* ConjointAtop */ case 36: /* ConjointAtopReverse */ case 37: /* ConjointXor */ rv = 1; break; } return rv; } /******************************************************************************/ static int dst_alpha_needed(CARD8 op) { int rv; rv = 0; switch (op) { case 4: /* OverReverse */ case 5: /* In */ case 7: /* Out */ case 9: /* Atop */ case 10: /* AtopReverse */ case 11: /* Xor */ case 13: /* Saturate */ case 17: /* DisjointOver */ case 18: /* DisjointOverReverse */ case 19: /* DisjointIn */ case 20: /* DisjointInReverse */ case 21: /* DisjointOut */ case 22: /* DisjointOutReverse */ case 23: /* DisjointAtop */ case 24: /* DisjointAtopReverse */ case 25: /* DisjointXor */ case 29: /* ConjointOver */ case 30: /* ConjointOverReverse */ case 31: /* ConjointIn */ case 32: /* ConjointInReverse */ case 33: /* ConjointOut */ case 34: /* ConjointOutReverse */ case 35: /* ConjointAtop */ case 36: /* ConjointAtopReverse */ case 37: /* ConjointXor */ rv = 1; break; } return rv; } struct msk_info { int flags; int idx; int format; int width; int repeat; }; static char g_com_fail_strings[][128] = { "OK", "src not remotable", "dst not remotable", "msk not remotable" }; /******************************************************************************/ /* returns boolean */ static int check_drawables(CARD8 op, PicturePtr pSrc, PicturePtr pMask, PicturePtr pDst, INT16 xSrc, INT16 ySrc, INT16 xMask, INT16 yMask, INT16 xDst, INT16 yDst, CARD16 width, CARD16 height, struct msk_info* msk) { int rv; int fail_reason; PixmapPtr pSrcPixmap; PixmapPtr pDstPixmap; PixmapPtr pMskPixmap; rdpPixmapRec* pSrcPriv; rdpPixmapRec* pDstPriv; rdpPixmapRec* pMskPriv; fail_reason = 0; pSrcPixmap = 0; pDstPixmap = 0; pMskPixmap = 0; pSrcPriv = 0; pDstPriv = 0; pMskPriv = 0; rv = 0; if (pSrc != 0) { if (pSrc->pDrawable != 0) { if (pSrc->pDrawable->type == DRAWABLE_PIXMAP) { pSrcPixmap = (PixmapPtr)(pSrc->pDrawable); pSrcPriv = GETPIXPRIV(pSrcPixmap); if (xrdp_is_os(pSrcPixmap, pSrcPriv)) { if (pDst != 0) { if (pDst->pDrawable != 0) { if (pDst->pDrawable->type == DRAWABLE_PIXMAP) { pDstPixmap = (PixmapPtr)(pDst->pDrawable); pDstPriv = GETPIXPRIV(pDstPixmap); if (xrdp_is_os(pDstPixmap, pDstPriv)) { rv = 1; } else { fail_reason = 2; } } } } } else { fail_reason = 1; } } } } if (rv) { if (pMask != 0) { #if 1 rv = 0; if (pMask->pDrawable != 0) { if (pMask->pDrawable->type == DRAWABLE_PIXMAP) { pMskPixmap = (PixmapPtr)(pMask->pDrawable); pMskPriv = GETPIXPRIV(pMskPixmap); if (xrdp_is_os(pMskPixmap, pMskPriv)) { rv = 1; msk->flags = 1; msk->idx = pMskPriv->rdpindex; msk->format = pMask->format; msk->width = pMask->pDrawable->width; msk->repeat = pMask->repeatType; } else { fail_reason = 3; } } } #endif } } if (rv == 0) { LLOGLN(10, ("check_drawables: can not remote [%s]", g_com_fail_strings[fail_reason])); #if 0 composite_print(op, pSrc, pMask, pDst, xSrc, ySrc, xMask, yMask, xDst, yDst, width, height); #endif } else { LLOGLN(10, ("check_drawables: can remote [%s]", g_com_fail_strings[fail_reason])); #if 0 composite_print(op, pSrc, pMask, pDst, xSrc, ySrc, xMask, yMask, xDst, yDst, width, height); #endif } return rv; } /******************************************************************************/ static int rdpRemoteComposite(CARD8 op, PicturePtr pSrc, PicturePtr pMask, PicturePtr pDst, INT16 xSrc, INT16 ySrc, INT16 xMask, INT16 yMask, INT16 xDst, INT16 yDst, CARD16 width, CARD16 height) { int ok_to_remote; PixmapPtr pSrcPixmap; PixmapPtr pMskPixmap; PixmapPtr pDstPixmap; rdpPixmapRec* pSrcPriv; rdpPixmapRec* pMskPriv; rdpPixmapRec* pDstPriv; BoxRec box; RegionRec reg1; RegionRec reg2; DrawablePtr p; int j; int num_clips; struct msk_info msk; LLOGLN(10, ("rdpRemoteComposite:")); memset(&msk, 0, sizeof(msk)); ok_to_remote = check_drawables(op, pSrc, pMask, pDst, xSrc, ySrc, xMask, yMask, xDst, yDst, width, height, &msk); if (!ok_to_remote) { return 1; } ValidatePicture(pSrc); pSrcPixmap = (PixmapPtr)(pSrc->pDrawable); pSrcPriv = GETPIXPRIV(pSrcPixmap); rdpup_check_dirty(pSrcPixmap, pSrcPriv); if (PIXMAN_FORMAT_A(pSrc->format) > 0) { if (src_alpha_needed(op)) { rdpup_check_alpha_dirty(pSrcPixmap, pSrcPriv); } } ValidatePicture(pDst); pDstPixmap = (PixmapPtr)(pDst->pDrawable); pDstPriv = GETPIXPRIV(pDstPixmap); rdpup_check_dirty(pDstPixmap, pDstPriv); if (PIXMAN_FORMAT_A(pDst->format) > 0) { if (dst_alpha_needed(op)) { rdpup_check_alpha_dirty(pDstPixmap, pDstPriv); } } if (pMask != 0) { ValidatePicture(pMask); pMskPixmap = (PixmapPtr)(pMask->pDrawable); pMskPriv = GETPIXPRIV(pMskPixmap); rdpup_check_dirty(pMskPixmap, pMskPriv); if (PIXMAN_FORMAT_A(msk.format) > 0) { rdpup_check_alpha_dirty(pMskPixmap, pMskPriv); } } p = pDst->pDrawable; rdpup_switch_os_surface(pDstPriv->rdpindex); if (pDst->pCompositeClip != 0) { box.x1 = xDst; box.y1 = yDst; box.x2 = box.x1 + width; box.y2 = box.y1 + height; RegionInit(®1, &box, 0); RegionInit(®2, NullBox, 0); RegionCopy(®2, pDst->pCompositeClip); RegionIntersect(®1, ®1, ®2); RegionTranslate(®1, p->x, p->y); num_clips = REGION_NUM_RECTS(®1); if (num_clips > 0) { LLOGLN(10, ("num_clips %d", num_clips)); rdpup_begin_update(); for (j = num_clips - 1; j >= 0; j--) { box = REGION_RECTS(®1)[j]; rdpup_set_clip(box.x1, box.y1, box.x2 - box.x1, box.y2 - box.y1); LLOGLN(10, ("pSrc->format 0x%x 0x%x 0x%x %d %d %d %d %d %d %d %d", pSrc->format, msk.format, pDst->format, xSrc, ySrc, xMask, yMask, xDst, yDst, width, height)); rdpup_composite(pSrcPriv->rdpindex, pSrc->format, pSrc->pDrawable->width, pSrc->repeatType, pSrc->transform, msk.flags, msk.idx, msk.format, msk.width, msk.repeat, op, xSrc, ySrc, xMask, yMask, xDst, yDst, width, height, pDst->format); } rdpup_reset_clip(); rdpup_end_update(); } RegionUninit(®1); RegionUninit(®2); } else { rdpup_begin_update(); rdpup_composite(pSrcPriv->rdpindex, pSrc->format, pSrc->pDrawable->width, pSrc->repeatType, pSrc->transform, msk.flags, msk.idx, msk.format, msk.width, msk.repeat, op, xSrc, ySrc, xMask, yMask, xDst, yDst, width, height, pDst->format); rdpup_end_update(); } rdpup_switch_os_surface(-1); return 0; } /******************************************************************************/ static void rdpCompositeOrg(CARD8 op, PicturePtr pSrc, PicturePtr pMask, PicturePtr pDst, INT16 xSrc, INT16 ySrc, INT16 xMask, INT16 yMask, INT16 xDst, INT16 yDst, CARD16 width, CARD16 height) { PictureScreenPtr ps; ps = GetPictureScreen(g_pScreen); ps->Composite = g_rdpScreen.Composite; ps->Composite(op, pSrc, pMask, pDst, xSrc, ySrc, xMask, yMask, xDst, yDst, width, height); ps->Composite = rdpComposite; } /******************************************************************************/ /* it looks like all the antialias draws go through here op is one of the following #define PictOpMinimum 0 #define PictOpClear 0 #define PictOpSrc 1 #define PictOpDst 2 #define PictOpOver 3 #define PictOpOverReverse 4 #define PictOpIn 5 #define PictOpInReverse 6 #define PictOpOut 7 #define PictOpOutReverse 8 #define PictOpAtop 9 #define PictOpAtopReverse 10 #define PictOpXor 11 #define PictOpAdd 12 #define PictOpSaturate 13 #define PictOpMaximum 13 see for porter duff http://www.svgopen.org/2005/papers/abstractsvgopen/ */ void rdpComposite(CARD8 op, PicturePtr pSrc, PicturePtr pMask, PicturePtr pDst, INT16 xSrc, INT16 ySrc, INT16 xMask, INT16 yMask, INT16 xDst, INT16 yDst, CARD16 width, CARD16 height) { BoxRec box; RegionRec reg1; RegionRec reg2; DrawablePtr p; int dirty_type; int j; int num_clips; int post_process; int reset_surface; int got_id; WindowPtr pDstWnd; PixmapPtr pDstPixmap; rdpPixmapRec* pDstPriv; rdpPixmapRec* pDirtyPriv; struct image_data id; LLOGLN(10, ("rdpComposite:")); if (g_doing_font == 2) { rdpCompositeOrg(op, pSrc, pMask, pDst, xSrc, ySrc, xMask, yMask, xDst, yDst, width, height); return; } #if 0 if (g_do_glyph_cache && g_do_alpha_glyphs) { if (pSrc->pDrawable->width == 1 && pSrc->pDrawable->height == 1) { if (pMask != 0) { /* TODO: here we can try to send it as a glyph */ } } } #endif /* try to remote the composite call */ if (g_do_composite && rdpRemoteComposite(op, pSrc, pMask, pDst, xSrc, ySrc, xMask, yMask, xDst, yDst, width, height) == 0) { rdpCompositeOrg(op, pSrc, pMask, pDst, xSrc, ySrc, xMask, yMask, xDst, yDst, width, height); return; } rdpCompositeOrg(op, pSrc, pMask, pDst, xSrc, ySrc, xMask, yMask, xDst, yDst, width, height); LLOGLN(10, ("rdpComposite: op %d %p %p %p w %d h %d", op, pSrc, pMask, pDst, width, height)); p = pDst->pDrawable; pDstPriv = 0; dirty_type = 0; pDirtyPriv = 0; post_process = 0; reset_surface = 0; got_id = 0; if (p->type == DRAWABLE_PIXMAP) { pDstPixmap = (PixmapPtr)p; pDstPriv = GETPIXPRIV(pDstPixmap); if (XRDP_IS_OS(pDstPriv)) { post_process = 1; if (g_do_dirty_os) { LLOGLN(10, ("rdpComposite: getting dirty")); pDstPriv->is_dirty = 1; dirty_type = g_doing_font ? RDI_IMGLL : RDI_IMGLY; pDirtyPriv = pDstPriv; } else { rdpup_switch_os_surface(pDstPriv->rdpindex); reset_surface = 1; rdpup_get_pixmap_image_rect(pDstPixmap, &id); got_id = 1; LLOGLN(10, ("rdpComposite: offscreen")); } } } else { if (p->type == DRAWABLE_WINDOW) { pDstWnd = (WindowPtr)p; if (pDstWnd->viewable) { post_process = 1; if (g_do_dirty_ons) { LLOGLN(10, ("rdpComposite: getting dirty")); g_screenPriv.is_dirty = 1; pDirtyPriv = &g_screenPriv; dirty_type = g_doing_font ? RDI_IMGLL : RDI_IMGLY; } else { rdpup_get_screen_image_rect(&id); got_id = 1; } } } } if (!post_process) { return; } if (pDst->pCompositeClip != 0) { box.x1 = p->x + xDst; box.y1 = p->y + yDst; box.x2 = box.x1 + width; box.y2 = box.y1 + height; RegionInit(®1, &box, 0); RegionInit(®2, NullBox, 0); RegionCopy(®2, pDst->pCompositeClip); RegionIntersect(®1, ®1, ®2); if (dirty_type != 0) { draw_item_add_img_region(pDirtyPriv, ®1, GXcopy, dirty_type, TAG_COMPOSITE); } else if (got_id) { num_clips = REGION_NUM_RECTS(®1); if (num_clips > 0) { rdpup_begin_update(); for (j = num_clips - 1; j >= 0; j--) { box = REGION_RECTS(®1)[j]; rdpup_send_area(&id, box.x1, box.y1, box.x2 - box.x1, box.y2 - box.y1); } rdpup_end_update(); } } RegionUninit(®1); RegionUninit(®2); } else { box.x1 = p->x + xDst; box.y1 = p->y + yDst; box.x2 = box.x1 + width; box.y2 = box.y1 + height; if (dirty_type != 0) { RegionInit(®1, &box, 0); draw_item_add_img_region(pDirtyPriv, ®1, GXcopy, dirty_type, TAG_COMPOSITE); RegionUninit(®1); } else if (got_id) { rdpup_begin_update(); rdpup_send_area(&id, box.x1, box.y1, box.x2 - box.x1, box.y2 - box.y1); rdpup_end_update(); } } if (reset_surface) { rdpup_switch_os_surface(-1); } } xrdp-0.9.5/xorg/X11R7.6/rdp/rdpPolyText8.c000644 001751 001751 00000013417 13125122134 017646 0ustar00metameta000000 000000 /* Copyright 2005-2013 Jay Sorg Permission to use, copy, modify, distribute, and sell this software and its documentation for any purpose is hereby granted without fee, provided that the above copyright notice appear in all copies and that both that copyright notice and this permission notice appear in supporting documentation. The above copyright notice and this permission notice shall be included in all copies or substantial portions of the Software. THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE OPEN GROUP BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. */ #include "rdp.h" #include "rdpdraw.h" #define LDEBUG 0 #define LOG_LEVEL 1 #define LLOG(_level, _args) \ do { if (_level < LOG_LEVEL) { ErrorF _args ; } } while (0) #define LLOGLN(_level, _args) \ do { if (_level < LOG_LEVEL) { ErrorF _args ; ErrorF("\n"); } } while (0) extern rdpScreenInfoRec g_rdpScreen; /* from rdpmain.c */ extern DevPrivateKeyRec g_rdpGCIndex; /* from rdpmain.c */ extern DevPrivateKeyRec g_rdpWindowIndex; /* from rdpmain.c */ extern DevPrivateKeyRec g_rdpPixmapIndex; /* from rdpmain.c */ extern int g_Bpp; /* from rdpmain.c */ extern ScreenPtr g_pScreen; /* from rdpmain.c */ extern Bool g_wrapPixmap; /* from rdpmain.c */ extern int g_do_dirty_os; /* in rdpmain.c */ extern int g_do_dirty_ons; /* in rdpmain.c */ extern rdpPixmapRec g_screenPriv; /* in rdpmain.c */ extern GCOps g_rdpGCOps; /* from rdpdraw.c */ extern int g_con_number; /* in rdpup.c */ /******************************************************************************/ int rdpPolyText8Org(DrawablePtr pDrawable, GCPtr pGC, int x, int y, int count, char *chars) { int rv; rdpGCPtr priv; GCFuncs *oldFuncs; GC_OP_PROLOGUE(pGC); rv = pGC->ops->PolyText8(pDrawable, pGC, x, y, count, chars); GC_OP_EPILOGUE(pGC); return rv; } /******************************************************************************/ int rdpPolyText8(DrawablePtr pDrawable, GCPtr pGC, int x, int y, int count, char *chars) { RegionRec reg; RegionRec reg1; int num_clips; int cd; int j; int rv; int got_id; int dirty_type; int post_process; int reset_surface; BoxRec box; struct image_data id; WindowPtr pDstWnd; PixmapPtr pDstPixmap; rdpPixmapRec *pDstPriv; rdpPixmapRec *pDirtyPriv; LLOGLN(10, ("rdpPolyText8:")); if (count != 0) { GetTextBoundingBox(pDrawable, pGC->font, x, y, count, &box); } /* do original call */ rv = rdpPolyText8Org(pDrawable, pGC, x, y, count, chars); dirty_type = 0; pDirtyPriv = 0; post_process = 0; reset_surface = 0; got_id = 0; if (pDrawable->type == DRAWABLE_PIXMAP) { pDstPixmap = (PixmapPtr)pDrawable; pDstPriv = GETPIXPRIV(pDstPixmap); if (xrdp_is_os(pDstPixmap, pDstPriv)) { post_process = 1; if (g_do_dirty_os) { LLOGLN(10, ("rdpPolyText8: getting dirty")); pDstPriv->is_dirty = 1; pDirtyPriv = pDstPriv; dirty_type = RDI_IMGLY; } else { rdpup_switch_os_surface(pDstPriv->rdpindex); reset_surface = 1; rdpup_get_pixmap_image_rect(pDstPixmap, &id); got_id = 1; } } } else { if (pDrawable->type == DRAWABLE_WINDOW) { pDstWnd = (WindowPtr)pDrawable; if (pDstWnd->viewable) { post_process = 1; if (g_do_dirty_ons) { LLOGLN(10, ("rdpPolyText8: getting dirty")); g_screenPriv.is_dirty = 1; pDirtyPriv = &g_screenPriv; dirty_type = RDI_IMGLL; } else { rdpup_get_screen_image_rect(&id); got_id = 1; } } } } if (!post_process) { return rv; } RegionInit(®, NullBox, 0); if (count == 0) { cd = 0; } else { cd = rdp_get_clip(®, pDrawable, pGC); } if (cd == 1) { if (dirty_type != 0) { RegionInit(®1, &box, 0); draw_item_add_img_region(pDirtyPriv, ®1, GXcopy, dirty_type, TAG_POLYTEXT8); RegionUninit(®1); } else if (got_id) { rdpup_begin_update(); rdpup_send_area(&id, box.x1, box.y1, box.x2 - box.x1, box.y2 - box.y1); rdpup_end_update(); } } else if (cd == 2) { RegionInit(®1, &box, 0); RegionIntersect(®, ®, ®1); num_clips = REGION_NUM_RECTS(®); if (num_clips > 0) { if (dirty_type != 0) { draw_item_add_img_region(pDirtyPriv, ®, GXcopy, dirty_type, TAG_POLYTEXT8); } else if (got_id) { rdpup_begin_update(); for (j = num_clips - 1; j >= 0; j--) { box = REGION_RECTS(®)[j]; rdpup_send_area(&id, box.x1, box.y1, box.x2 - box.x1, box.y2 - box.y1); } rdpup_end_update(); } } RegionUninit(®1); } RegionUninit(®); if (reset_surface) { rdpup_switch_os_surface(-1); } return rv; } xrdp-0.9.5/xorg/X11R7.6/rdp/rdpPolyRectangle.h000644 001751 001751 00000002071 13125122134 020535 0ustar00metameta000000 000000 /* Copyright 2005-2013 Jay Sorg Permission to use, copy, modify, distribute, and sell this software and its documentation for any purpose is hereby granted without fee, provided that the above copyright notice appear in all copies and that both that copyright notice and this permission notice appear in supporting documentation. The above copyright notice and this permission notice shall be included in all copies or substantial portions of the Software. THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE OPEN GROUP BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. */ #ifndef __RDPPOLYRECTANGLE_H #define __RDPPOLYRECTANGLE_H void rdpPolyRectangle(DrawablePtr pDrawable, GCPtr pGC, int nrects, xRectangle* rects); #endif xrdp-0.9.5/xorg/X11R7.6/rdp/rdpPolyArc.c000644 001751 001751 00000015377 13125122134 017346 0ustar00metameta000000 000000 /* Copyright 2005-2013 Jay Sorg Permission to use, copy, modify, distribute, and sell this software and its documentation for any purpose is hereby granted without fee, provided that the above copyright notice appear in all copies and that both that copyright notice and this permission notice appear in supporting documentation. The above copyright notice and this permission notice shall be included in all copies or substantial portions of the Software. THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE OPEN GROUP BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. */ #include "rdp.h" #include "rdpdraw.h" #define LDEBUG 0 #define LOG_LEVEL 1 #define LLOG(_level, _args) \ do { if (_level < LOG_LEVEL) { ErrorF _args ; } } while (0) #define LLOGLN(_level, _args) \ do { if (_level < LOG_LEVEL) { ErrorF _args ; ErrorF("\n"); } } while (0) extern rdpScreenInfoRec g_rdpScreen; /* from rdpmain.c */ extern DevPrivateKeyRec g_rdpGCIndex; /* from rdpmain.c */ extern DevPrivateKeyRec g_rdpWindowIndex; /* from rdpmain.c */ extern DevPrivateKeyRec g_rdpPixmapIndex; /* from rdpmain.c */ extern int g_Bpp; /* from rdpmain.c */ extern ScreenPtr g_pScreen; /* from rdpmain.c */ extern Bool g_wrapPixmap; /* from rdpmain.c */ extern int g_do_dirty_os; /* in rdpmain.c */ extern int g_do_dirty_ons; /* in rdpmain.c */ extern rdpPixmapRec g_screenPriv; /* in rdpmain.c */ extern GCOps g_rdpGCOps; /* from rdpdraw.c */ extern int g_con_number; /* in rdpup.c */ /******************************************************************************/ void rdpPolyArcOrg(DrawablePtr pDrawable, GCPtr pGC, int narcs, xArc *parcs) { rdpGCPtr priv; GCFuncs *oldFuncs; GC_OP_PROLOGUE(pGC); pGC->ops->PolyArc(pDrawable, pGC, narcs, parcs); GC_OP_EPILOGUE(pGC); } /******************************************************************************/ void rdpPolyArc(DrawablePtr pDrawable, GCPtr pGC, int narcs, xArc *parcs) { RegionRec clip_reg; RegionPtr tmpRegion; int cd; int lw; int extra; int i; int num_clips; int got_id; int dirty_type; int post_process; int reset_surface; xRectangle *rects; BoxRec box; struct image_data id; WindowPtr pDstWnd; PixmapPtr pDstPixmap; rdpPixmapRec *pDstPriv; rdpPixmapRec *pDirtyPriv; LLOGLN(10, ("rdpPolyArc:")); rects = 0; if (narcs > 0) { rects = (xRectangle *)g_malloc(narcs * sizeof(xRectangle), 0); lw = pGC->lineWidth; if (lw == 0) { lw = 1; } extra = lw / 2; for (i = 0; i < narcs; i++) { rects[i].x = (parcs[i].x - extra) + pDrawable->x; rects[i].y = (parcs[i].y - extra) + pDrawable->y; rects[i].width = parcs[i].width + lw; rects[i].height = parcs[i].height + lw; } } /* do original call */ rdpPolyArcOrg(pDrawable, pGC, narcs, parcs); dirty_type = 0; pDirtyPriv = 0; post_process = 0; reset_surface = 0; got_id = 0; if (pDrawable->type == DRAWABLE_PIXMAP) { pDstPixmap = (PixmapPtr)pDrawable; pDstPriv = GETPIXPRIV(pDstPixmap); if (xrdp_is_os(pDstPixmap, pDstPriv)) { post_process = 1; if (g_do_dirty_os) { LLOGLN(10, ("rdpPolyArc: getting dirty")); pDstPriv->is_dirty = 1; pDirtyPriv = pDstPriv; dirty_type = RDI_IMGLL; } else { rdpup_switch_os_surface(pDstPriv->rdpindex); reset_surface = 1; rdpup_get_pixmap_image_rect(pDstPixmap, &id); got_id = 1; } } } else { if (pDrawable->type == DRAWABLE_WINDOW) { pDstWnd = (WindowPtr)pDrawable; if (pDstWnd->viewable) { post_process = 1; if (g_do_dirty_ons) { LLOGLN(10, ("rdpPolyArc: getting dirty")); g_screenPriv.is_dirty = 1; pDirtyPriv = &g_screenPriv; dirty_type = RDI_IMGLL; } else { rdpup_get_screen_image_rect(&id); got_id = 1; } } } } if (!post_process) { g_free(rects); return; } RegionInit(&clip_reg, NullBox, 0); cd = rdp_get_clip(&clip_reg, pDrawable, pGC); if (cd == 1) { if (rects != 0) { tmpRegion = RegionFromRects(narcs, rects, CT_NONE); num_clips = REGION_NUM_RECTS(tmpRegion); if (num_clips > 0) { if (dirty_type != 0) { draw_item_add_img_region(pDirtyPriv, tmpRegion, GXcopy, dirty_type, TAG_POLYARC); } else if (got_id) { rdpup_begin_update(); for (i = num_clips - 1; i >= 0; i--) { box = REGION_RECTS(tmpRegion)[i]; rdpup_send_area(&id, box.x1, box.y1, box.x2 - box.x1, box.y2 - box.y1); } rdpup_end_update(); } } RegionDestroy(tmpRegion); } } else if (cd == 2) { if (rects != 0) { tmpRegion = RegionFromRects(narcs, rects, CT_NONE); RegionIntersect(tmpRegion, tmpRegion, &clip_reg); num_clips = REGION_NUM_RECTS(tmpRegion); if (num_clips > 0) { if (dirty_type != 0) { draw_item_add_img_region(pDirtyPriv, tmpRegion, GXcopy, dirty_type, TAG_POLYARC); } else if (got_id) { rdpup_begin_update(); for (i = num_clips - 1; i >= 0; i--) { box = REGION_RECTS(tmpRegion)[i]; rdpup_send_area(&id, box.x1, box.y1, box.x2 - box.x1, box.y2 - box.y1); } rdpup_end_update(); } } RegionDestroy(tmpRegion); } } RegionUninit(&clip_reg); g_free(rects); if (reset_surface) { rdpup_switch_os_surface(-1); } } xrdp-0.9.5/xorg/X11R7.6/rdp/rdpPolyFillArc.c000644 001751 001751 00000015443 13125122134 020147 0ustar00metameta000000 000000 /* Copyright 2005-2013 Jay Sorg Permission to use, copy, modify, distribute, and sell this software and its documentation for any purpose is hereby granted without fee, provided that the above copyright notice appear in all copies and that both that copyright notice and this permission notice appear in supporting documentation. The above copyright notice and this permission notice shall be included in all copies or substantial portions of the Software. THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE OPEN GROUP BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. */ #include "rdp.h" #include "rdpdraw.h" #define LDEBUG 0 #define LOG_LEVEL 1 #define LLOG(_level, _args) \ do { if (_level < LOG_LEVEL) { ErrorF _args ; } } while (0) #define LLOGLN(_level, _args) \ do { if (_level < LOG_LEVEL) { ErrorF _args ; ErrorF("\n"); } } while (0) extern rdpScreenInfoRec g_rdpScreen; /* from rdpmain.c */ extern DevPrivateKeyRec g_rdpGCIndex; /* from rdpmain.c */ extern DevPrivateKeyRec g_rdpWindowIndex; /* from rdpmain.c */ extern DevPrivateKeyRec g_rdpPixmapIndex; /* from rdpmain.c */ extern int g_Bpp; /* from rdpmain.c */ extern ScreenPtr g_pScreen; /* from rdpmain.c */ extern Bool g_wrapPixmap; /* from rdpmain.c */ extern int g_do_dirty_os; /* in rdpmain.c */ extern int g_do_dirty_ons; /* in rdpmain.c */ extern rdpPixmapRec g_screenPriv; /* in rdpmain.c */ extern GCOps g_rdpGCOps; /* from rdpdraw.c */ extern int g_con_number; /* in rdpup.c */ /******************************************************************************/ void rdpPolyFillArcOrg(DrawablePtr pDrawable, GCPtr pGC, int narcs, xArc *parcs) { rdpGCPtr priv; GCFuncs *oldFuncs; GC_OP_PROLOGUE(pGC); pGC->ops->PolyFillArc(pDrawable, pGC, narcs, parcs); GC_OP_EPILOGUE(pGC); } /******************************************************************************/ void rdpPolyFillArc(DrawablePtr pDrawable, GCPtr pGC, int narcs, xArc *parcs) { RegionRec clip_reg; RegionPtr tmpRegion; int cd; int lw; int extra; int i; int num_clips; int got_id; int dirty_type; int post_process; int reset_surface; xRectangle *rects; BoxRec box; struct image_data id; WindowPtr pDstWnd; PixmapPtr pDstPixmap; rdpPixmapRec *pDstPriv; rdpPixmapRec *pDirtyPriv; LLOGLN(10, ("rdpPolyFillArc:")); rects = 0; if (narcs > 0) { rects = (xRectangle *)g_malloc(narcs * sizeof(xRectangle), 0); lw = pGC->lineWidth; if (lw == 0) { lw = 1; } extra = lw / 2; for (i = 0; i < narcs; i++) { rects[i].x = (parcs[i].x - extra) + pDrawable->x; rects[i].y = (parcs[i].y - extra) + pDrawable->y; rects[i].width = parcs[i].width + lw; rects[i].height = parcs[i].height + lw; } } /* do original call */ rdpPolyFillArcOrg(pDrawable, pGC, narcs, parcs); dirty_type = 0; pDirtyPriv = 0; post_process = 0; reset_surface = 0; got_id = 0; if (pDrawable->type == DRAWABLE_PIXMAP) { pDstPixmap = (PixmapPtr)pDrawable; pDstPriv = GETPIXPRIV(pDstPixmap); if (xrdp_is_os(pDstPixmap, pDstPriv)) { post_process = 1; if (g_do_dirty_os) { LLOGLN(10, ("rdpPolyFillArc: getting dirty")); pDstPriv->is_dirty = 1; pDirtyPriv = pDstPriv; dirty_type = RDI_IMGLY; } else { rdpup_switch_os_surface(pDstPriv->rdpindex); reset_surface = 1; rdpup_get_pixmap_image_rect(pDstPixmap, &id); got_id = 1; } } } else { if (pDrawable->type == DRAWABLE_WINDOW) { pDstWnd = (WindowPtr)pDrawable; if (pDstWnd->viewable) { post_process = 1; if (g_do_dirty_ons) { LLOGLN(10, ("rdpPolyFillArc: getting dirty")); g_screenPriv.is_dirty = 1; pDirtyPriv = &g_screenPriv; dirty_type = RDI_IMGLL; } else { rdpup_get_screen_image_rect(&id); got_id = 1; } } } } if (!post_process) { g_free(rects); return; } RegionInit(&clip_reg, NullBox, 0); cd = rdp_get_clip(&clip_reg, pDrawable, pGC); if (cd == 1) { if (rects != 0) { tmpRegion = RegionFromRects(narcs, rects, CT_NONE); num_clips = REGION_NUM_RECTS(tmpRegion); if (num_clips > 0) { if (dirty_type != 0) { draw_item_add_img_region(pDirtyPriv, tmpRegion, GXcopy, dirty_type, TAG_POLYFILLARC); } else if (got_id) { rdpup_begin_update(); for (i = num_clips - 1; i >= 0; i--) { box = REGION_RECTS(tmpRegion)[i]; rdpup_send_area(&id, box.x1, box.y1, box.x2 - box.x1, box.y2 - box.y1); } rdpup_end_update(); } } RegionDestroy(tmpRegion); } } else if (cd == 2) { if (rects != 0) { tmpRegion = RegionFromRects(narcs, rects, CT_NONE); RegionIntersect(tmpRegion, tmpRegion, &clip_reg); num_clips = REGION_NUM_RECTS(tmpRegion); if (num_clips > 0) { if (dirty_type != 0) { draw_item_add_img_region(pDirtyPriv, tmpRegion, GXcopy, dirty_type, TAG_POLYFILLARC); } else if (got_id) { rdpup_begin_update(); for (i = num_clips - 1; i >= 0; i--) { box = REGION_RECTS(tmpRegion)[i]; rdpup_send_area(&id, box.x1, box.y1, box.x2 - box.x1, box.y2 - box.y1); } rdpup_end_update(); } } RegionDestroy(tmpRegion); } } RegionUninit(&clip_reg); g_free(rects); if (reset_surface) { rdpup_switch_os_surface(-1); } } xrdp-0.9.5/xorg/X11R7.6/rdp/rdpImageText8.h000644 001751 001751 00000002064 13125122134 017746 0ustar00metameta000000 000000 /* Copyright 2005-2013 Jay Sorg Permission to use, copy, modify, distribute, and sell this software and its documentation for any purpose is hereby granted without fee, provided that the above copyright notice appear in all copies and that both that copyright notice and this permission notice appear in supporting documentation. The above copyright notice and this permission notice shall be included in all copies or substantial portions of the Software. THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE OPEN GROUP BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. */ #ifndef __RDPIMAGETEXT8_H #define __RDPIMAGETEXT8_H void rdpImageText8(DrawablePtr pDrawable, GCPtr pGC, int x, int y, int count, char* chars); #endif xrdp-0.9.5/xorg/X11R7.6/rdp/rdpFillSpans.h000644 001751 001751 00000002110 13125122134 017652 0ustar00metameta000000 000000 /* Copyright 2005-2013 Jay Sorg Permission to use, copy, modify, distribute, and sell this software and its documentation for any purpose is hereby granted without fee, provided that the above copyright notice appear in all copies and that both that copyright notice and this permission notice appear in supporting documentation. The above copyright notice and this permission notice shall be included in all copies or substantial portions of the Software. THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE OPEN GROUP BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. */ #ifndef __RDPFILLSPANS_H #define __RDPFILLSPANS_H void rdpFillSpans(DrawablePtr pDrawable, GCPtr pGC, int nInit, DDXPointPtr pptInit, int* pwidthInit, int fSorted); #endif xrdp-0.9.5/xorg/X11R7.6/rdp/rdpPolyText16.h000644 001751 001751 00000002075 13125122134 017730 0ustar00metameta000000 000000 /* Copyright 2005-2013 Jay Sorg Permission to use, copy, modify, distribute, and sell this software and its documentation for any purpose is hereby granted without fee, provided that the above copyright notice appear in all copies and that both that copyright notice and this permission notice appear in supporting documentation. The above copyright notice and this permission notice shall be included in all copies or substantial portions of the Software. THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE OPEN GROUP BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. */ #ifndef __RDPPOLYTEXT16_H #define __RDPPOLYTEXT16_H int rdpPolyText16(DrawablePtr pDrawable, GCPtr pGC, int x, int y, int count, unsigned short* chars); #endif xrdp-0.9.5/xorg/X11R7.6/rdp/gcops.h000644 001751 001751 00000002431 13125122134 016372 0ustar00metameta000000 000000 /* Copyright 2005-2013 Jay Sorg Permission to use, copy, modify, distribute, and sell this software and its documentation for any purpose is hereby granted without fee, provided that the above copyright notice appear in all copies and that both that copyright notice and this permission notice appear in supporting documentation. The above copyright notice and this permission notice shall be included in all copies or substantial portions of the Software. THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE OPEN GROUP BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. */ static void rdpValidateGC(GCPtr pGC, unsigned long changes, DrawablePtr d); static void rdpChangeGC(GCPtr pGC, unsigned long mask); static void rdpCopyGC(GCPtr src, unsigned long mask, GCPtr dst); static void rdpDestroyGC(GCPtr pGC); static void rdpChangeClip(GCPtr pGC, int type, pointer pValue, int nrects); static void rdpDestroyClip(GCPtr pGC); static void rdpCopyClip(GCPtr dst, GCPtr src); xrdp-0.9.5/xorg/X11R7.6/rdp/rdpImageGlyphBlt.h000644 001751 001751 00000002165 13125122134 020461 0ustar00metameta000000 000000 /* Copyright 2005-2013 Jay Sorg Permission to use, copy, modify, distribute, and sell this software and its documentation for any purpose is hereby granted without fee, provided that the above copyright notice appear in all copies and that both that copyright notice and this permission notice appear in supporting documentation. The above copyright notice and this permission notice shall be included in all copies or substantial portions of the Software. THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE OPEN GROUP BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. */ #ifndef __RDPIMAGEGLYPHBLT_H #define __RDPIMAGEGLYPHBLT_H void rdpImageGlyphBlt(DrawablePtr pDrawable, GCPtr pGC, int x, int y, unsigned int nglyph, CharInfoPtr* ppci, pointer pglyphBase); #endif xrdp-0.9.5/xorg/X11R7.6/rdp/rdp.h~000644 001751 001751 00000047041 13206667237 016272 0ustar00metameta000000 000000 /* Copyright 2005-2013 Jay Sorg Permission to use, copy, modify, distribute, and sell this software and its documentation for any purpose is hereby granted without fee, provided that the above copyright notice appear in all copies and that both that copyright notice and this permission notice appear in supporting documentation. The above copyright notice and this permission notice shall be included in all copies or substantial portions of the Software. THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE OPEN GROUP BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. */ #if defined(__arm__) && !defined(__arm32__) #define __arm32__ #endif #include "xorg-server.h" #include #include #include #include #include #include #include #include #include #include #include #include #include "X.h" #define NEED_EVENTS #include "Xproto.h" #include "Xos.h" #include "scrnintstr.h" #include "servermd.h" #define PSZ 8 //#include "cfb.h" #include "mibstore.h" #include "colormapst.h" #include "gcstruct.h" #include "input.h" #include "mipointer.h" #include "dixstruct.h" #include "propertyst.h" #include "Xatom.h" #include "dix.h" #include "X11/keysym.h" #include "dixfontstr.h" #include "fontstruct.h" #include "cursorstr.h" #include "picturestr.h" #include "XKBstr.h" #include "inputstr.h" #include "randrstr.h" #include "mi.h" #include "fb.h" #include "micmap.h" #include "events.h" #include "exevents.h" #include "xserver-properties.h" #include "xkbsrv.h" /* in xrdp/common */ #include "xrdp_client_info.h" #include "xrdp_constants.h" //#include "colormapst.h" #define X11RDPVER "0.9.4" #define PixelDPI 100 #define PixelToMM(_size) (((_size) * 254 + (PixelDPI) * 5) / ((PixelDPI) * 10)) #define TAG_COMPOSITE 0 #define TAG_COPYAREA 1 #define TAG_POLYFILLRECT 2 #define TAG_PUTIMAGE 3 #define TAG_POLYRECTANGLE 4 #define TAG_COPYPLANE 5 #define TAG_POLYARC 6 #define TAG_FILLPOLYGON 7 #define TAG_POLYFILLARC 8 #define TAG_IMAGETEXT8 9 #define TAG_POLYTEXT8 10 #define TAG_POLYTEXT16 11 #define TAG_IMAGETEXT16 12 #define TAG_IMAGEGLYPHBLT 13 #define TAG_POLYGLYPHBLT 14 #define TAG_PUSHPIXELS 15 struct image_data { int width; int height; int bpp; int Bpp; int lineBytes; char* pixels; char* shmem_pixels; int shmem_id; int shmem_offset; int shmem_lineBytes; }; /* Per-screen (framebuffer) structure. There is only one of these, since we don't allow the X server to have multiple screens. */ struct _rdpScreenInfoRec { int width; int paddedWidthInBytes; int height; int depth; int bitsPerPixel; int sizeInBytes; /* size of current used frame buffer */ int sizeInBytesAlloc; /* size of current alloc frame buffer, always >= sizeInBytes */ char* pfbMemory; Pixel blackPixel; Pixel whitePixel; /* wrapped screen functions */ /* Random screen procedures */ CloseScreenProcPtr CloseScreen; /* GC procedures */ CreateGCProcPtr CreateGC; /* Pixmap procedures */ CreatePixmapProcPtr CreatePixmap; DestroyPixmapProcPtr DestroyPixmap; /* Window Procedures */ CreateWindowProcPtr CreateWindow; DestroyWindowProcPtr DestroyWindow; PositionWindowProcPtr PositionWindow; RealizeWindowProcPtr RealizeWindow; UnrealizeWindowProcPtr UnrealizeWindow; ChangeWindowAttributesProcPtr ChangeWindowAttributes; WindowExposuresProcPtr WindowExposures; CreateColormapProcPtr CreateColormap; DestroyColormapProcPtr DestroyColormap; CopyWindowProcPtr CopyWindow; ClearToBackgroundProcPtr ClearToBackground; ScreenWakeupHandlerProcPtr WakeupHandler; CreatePictureProcPtr CreatePicture; DestroyPictureProcPtr DestroyPicture; CompositeProcPtr Composite; GlyphsProcPtr Glyphs; /* Backing store procedures */ RestoreAreasProcPtr RestoreAreas; int rdp_width; int rdp_height; int rdp_bpp; int rdp_Bpp; int rdp_Bpp_mask; struct xrdp_client_info client_info; }; typedef struct _rdpScreenInfoRec rdpScreenInfoRec; typedef rdpScreenInfoRec* rdpScreenInfoPtr; struct _rdpGCRec { GCFuncs* funcs; GCOps* ops; }; typedef struct _rdpGCRec rdpGCRec; typedef rdpGCRec* rdpGCPtr; #define GETGCPRIV(_pGC) \ (rdpGCPtr)dixGetPrivateAddr(&(_pGC->devPrivates), &g_rdpGCIndex) struct _rdpWindowRec { int status; }; typedef struct _rdpWindowRec rdpWindowRec; typedef rdpWindowRec* rdpWindowPtr; #define GETWINPRIV(_pWindow) \ (rdpWindowPtr)dixGetPrivateAddr(&(_pWindow->devPrivates), &g_rdpWindowIndex) #define XR_IS_ROOT(_pWindow) ((_pWindow)->drawable.pScreen->root == (_pWindow)) /* for tooltips */ #define XR_STYLE_TOOLTIP (0x80000000) #define XR_EXT_STYLE_TOOLTIP (0x00000080 | 0x00000008) /* for normal desktop windows */ /* WS_TILEDWINDOW (WS_OVERLAPPED | WS_CAPTION | WS_SYSMENU | WS_THICKFRAME | WS_MINIMIZEBOX | WS_MAXIMIZEBOX) */ #define XR_STYLE_NORMAL (0x00C00000 | 0x00080000 | 0x00040000 | 0x00010000 | 0x00020000) #define XR_EXT_STYLE_NORMAL (0x00040000) /* for dialogs */ #define XR_STYLE_DIALOG (0x80000000) #define XR_EXT_STYLE_DIALOG (0x00040000) #define RDI_FILL 1 #define RDI_IMGLL 2 /* lossless */ #define RDI_IMGLY 3 /* lossy */ #define RDI_LINE 4 #define RDI_SCRBLT 5 #define RDI_TEXT 6 struct urdp_draw_item_fill { int opcode; int fg_color; int bg_color; int pad0; }; struct urdp_draw_item_img { int opcode; int pad0; }; struct urdp_draw_item_line { int opcode; int fg_color; int bg_color; int width; xSegment* segs; int nseg; int flags; }; struct urdp_draw_item_scrblt { int srcx; int srcy; int dstx; int dsty; int cx; int cy; }; struct urdp_draw_item_text { int opcode; int fg_color; struct rdp_text* rtext; /* in rdpglyph.h */ }; union urdp_draw_item { struct urdp_draw_item_fill fill; struct urdp_draw_item_img img; struct urdp_draw_item_line line; struct urdp_draw_item_scrblt scrblt; struct urdp_draw_item_text text; }; struct rdp_draw_item { int type; /* RDI_FILL, RDI_IMGLL, ... */ int flags; struct rdp_draw_item* prev; struct rdp_draw_item* next; RegionPtr reg; union urdp_draw_item u; }; #define XRDP_USE_COUNT_THRESHOLD 1 struct _rdpPixmapRec { int status; int rdpindex; int con_number; int is_dirty; int is_scratch; int is_alpha_dirty_not; /* number of times used in a remote operation if this gets above XRDP_USE_COUNT_THRESHOLD then we force remote the pixmap */ int use_count; int kind_width; struct rdp_draw_item* draw_item_head; struct rdp_draw_item* draw_item_tail; }; typedef struct _rdpPixmapRec rdpPixmapRec; typedef rdpPixmapRec* rdpPixmapPtr; #define GETPIXPRIV(_pPixmap) \ (rdpPixmapPtr)dixGetPrivateAddr(&(_pPixmap->devPrivates), &g_rdpPixmapIndex) #define XRDP_IS_OS(_priv) (_priv->status != 0) /* rdpmisc.c */ void rdpLog(char *format, ...); int rdpBitsPerPixel(int depth); void rdpClientStateChange(CallbackListPtr* cbl, pointer myData, pointer clt); int g_tcp_recv(int sck, void* ptr, int len, int flags); void g_tcp_close(int sck); int g_tcp_last_error_would_block(int sck); void g_sleep(int msecs); int g_tcp_send(int sck, void* ptr, int len, int flags); void* g_malloc(int size, int zero); void g_free(void* ptr); void g_sprintf(char* dest, char* format, ...); int g_tcp_socket(void); int g_tcp_local_socket_dgram(void); int g_tcp_local_socket_stream(void); void g_memcpy(void* d_ptr, const void* s_ptr, int size); int g_tcp_set_no_delay(int sck); int g_tcp_set_non_blocking(int sck); int g_tcp_accept(int sck); int g_tcp_select(int sck1, int sck2, int sck3); int g_tcp_bind(int sck, char* port); int g_tcp_local_bind(int sck, char* port); int g_tcp_listen(int sck); int g_create_dir(const char* dirname); int g_directory_exist(const char* dirname); int g_chmod_hex(const char* filename, int flags); const char * g_socket_dir(void); void hexdump(unsigned char *p, unsigned int len); void RegionAroundSegs(RegionPtr reg, xSegment* segs, int nseg); int get_crc(char* data, int data_bytes); int get_mstime(void); /* rdpdraw.c */ Bool rdpCloseScreen(int i, ScreenPtr pScreen); int draw_item_add(rdpPixmapRec* priv, struct rdp_draw_item* di); int draw_item_remove(rdpPixmapRec* priv, struct rdp_draw_item* di); int draw_item_remove_all(rdpPixmapRec* priv); int draw_item_pack(PixmapPtr pix, rdpPixmapRec* priv); int draw_item_add_img_region(rdpPixmapRec* priv, RegionPtr reg, int opcode, int type, int code); int draw_item_add_fill_region(rdpPixmapRec* priv, RegionPtr reg, int color, int opcode); int draw_item_add_line_region(rdpPixmapRec* priv, RegionPtr reg, int color, int opcode, int width, xSegment* segs, int nsegs, int is_segment); int draw_item_add_srcblt_region(rdpPixmapRec* priv, RegionPtr reg, int srcx, int srcy, int dstx, int dsty, int cx, int cy); int draw_item_add_text_region(rdpPixmapRec* priv, RegionPtr reg, int color, int opcode, struct rdp_text* rtext); PixmapPtr rdpCreatePixmap(ScreenPtr pScreen, int width, int height, int depth, unsigned usage_hint); Bool rdpDestroyPixmap(PixmapPtr pPixmap); int xrdp_is_os(PixmapPtr pix, rdpPixmapPtr priv); Bool rdpCreateWindow(WindowPtr pWindow); Bool rdpDestroyWindow(WindowPtr pWindow); Bool rdpPositionWindow(WindowPtr pWindow, int x, int y); Bool rdpRealizeWindow(WindowPtr pWindow); Bool rdpUnrealizeWindow(WindowPtr pWindow); Bool rdpChangeWindowAttributes(WindowPtr pWindow, unsigned long mask); void rdpWindowExposures(WindowPtr pWindow, RegionPtr pRegion, RegionPtr pBSRegion); Bool rdpCreateGC(GCPtr pGC); void rdpCopyWindow(WindowPtr pWin, DDXPointRec ptOldOrg, RegionPtr pOldRegion); void rdpClearToBackground(WindowPtr pWin, int x, int y, int w, int h, Bool generateExposures); RegionPtr rdpRestoreAreas(WindowPtr pWin, RegionPtr prgnExposed); void rdpInstallColormap(ColormapPtr pmap); void rdpUninstallColormap(ColormapPtr pmap); int rdpListInstalledColormaps(ScreenPtr pScreen, Colormap* pmaps); void rdpStoreColors(ColormapPtr pmap, int ndef, xColorItem* pdefs); Bool rdpSaveScreen(ScreenPtr pScreen, int on); Bool rdpRealizeCursor(ScreenPtr pScreen, CursorPtr pCursor); Bool rdpUnrealizeCursor(ScreenPtr pScreen, CursorPtr pCursor); void rdpCursorLimits(ScreenPtr pScreen, CursorPtr pCursor, BoxPtr pHotBox, BoxPtr pTopLeftBox); void rdpConstrainCursor(ScreenPtr pScreen, BoxPtr pBox); Bool rdpSetCursorPosition(ScreenPtr pScreen, int x, int y, Bool generateEvent); Bool rdpDisplayCursor(ScreenPtr pScreen, CursorPtr pCursor); void rdpRecolorCursor(ScreenPtr pScreen, CursorPtr pCursor, Bool displayed); /* rdpglyph.c */ /* look in rdpglyph.h */ /* rdpComposite.c */ int rdpCreatePicture(PicturePtr pPicture); void rdpDestroyPicture(PicturePtr pPicture); void rdpComposite(CARD8 op, PicturePtr pSrc, PicturePtr pMask, PicturePtr pDst, INT16 xSrc, INT16 ySrc, INT16 xMask, INT16 yMask, INT16 xDst, INT16 yDst, CARD16 width, CARD16 height); /* rdpinput.c */ int rdpKeybdProc(DeviceIntPtr pDevice, int onoff); int rdpMouseProc(DeviceIntPtr pDevice, int onoff); Bool rdpCursorOffScreen(ScreenPtr* ppScreen, int* x, int* y); void rdpCrossScreen(ScreenPtr pScreen, Bool entering); void rdpPointerWarpCursor(DeviceIntPtr pDev, ScreenPtr pScr, int x, int y); void rdpPointerEnqueueEvent(DeviceIntPtr pDev, InternalEvent* event); void rdpPointerNewEventScreen(DeviceIntPtr pDev, ScreenPtr pScr, Bool fromDIX); Bool rdpSpriteRealizeCursor(DeviceIntPtr pDev, ScreenPtr pScr, CursorPtr pCurs); Bool rdpSpriteUnrealizeCursor(DeviceIntPtr pDev, ScreenPtr pScr, CursorPtr pCurs); void rdpSpriteSetCursor(DeviceIntPtr pDev, ScreenPtr pScr, CursorPtr pCurs, int x, int y); void rdpSpriteMoveCursor(DeviceIntPtr pDev, ScreenPtr pScr, int x, int y); Bool rdpSpriteDeviceCursorInitialize(DeviceIntPtr pDev, ScreenPtr pScr); void rdpSpriteDeviceCursorCleanup(DeviceIntPtr pDev, ScreenPtr pScr); void PtrAddEvent(int buttonMask, int x, int y); void KbdAddEvent(int down, int param1, int param2, int param3, int param4); void KbdSync(int param1); int rdpLoadLayout(struct xrdp_client_info *client_info); /* rdpup.c */ int rdpup_add_os_bitmap(PixmapPtr pixmap, rdpPixmapPtr priv); int rdpup_remove_os_bitmap(int rdpindex); int rdpup_update_os_use(int rdpindex); void rdpup_get_screen_image_rect(struct image_data* id); void rdpup_get_pixmap_image_rect(PixmapPtr pPixmap, struct image_data* id); int rdpup_init(void); int rdpup_check(void); int rdpup_begin_update(void); int rdpup_end_update(void); int rdpup_fill_rect(short x, short y, int cx, int cy); int rdpup_screen_blt(short x, short y, int cx, int cy, short srcx, short srcy); int rdpup_set_clip(short x, short y, int cx, int cy); int rdpup_reset_clip(void); int rdpup_set_fgcolor(int fgcolor); int rdpup_set_bgcolor(int bgcolor); int rdpup_set_opcode(int opcode); int rdpup_paint_rect(short x, short y, int cx, int cy, char* bmpdata, int width, int height, short srcx, short srcy); int rdpup_set_pen(int style, int width); int rdpup_draw_line(short x1, short y1, short x2, short y2); void rdpup_send_area(struct image_data* id, int x, int y, int w, int h); int rdpup_set_cursor(short x, short y, char* cur_data, char* cur_mask); int rdpup_set_cursor_ex(short x, short y, char *cur_data, char *cur_mask, int bpp); int rdpup_create_os_surface(int rdpindex, int width, int height); int rdpup_create_os_surface_bpp(int rdpindex, int width, int height, int bpp); int rdpup_switch_os_surface(int rdpindex); int rdpup_delete_os_surface(int rdpindex); void rdpup_paint_rect_os(int x, int y, int cx, int cy, int rdpindex, int srcx, int srcy); void rdpup_set_hints(int hints, int mask); void rdpup_create_window(WindowPtr pWindow, rdpWindowRec* priv); void rdpup_delete_window(WindowPtr pWindow, rdpWindowRec* priv); int rdpup_check_dirty(PixmapPtr pDirtyPixmap, rdpPixmapRec* pDirtyPriv); int rdpup_check_alpha_dirty(PixmapPtr pDirtyPixmap, rdpPixmapRec* pDirtyPriv); int rdpup_check_dirty_screen(rdpPixmapRec* pDirtyPriv); int rdpup_add_char(int font, int character, short x, short y, int cx, int cy, char* bmpdata, int bmpdata_bytes); int rdpup_add_char_alpha(int font, int character, short x, short y, int cx, int cy, char* bmpdata, int bmpdata_bytes); int rdpup_draw_text(int font, int flags, int mixmode, short clip_left, short clip_top, short clip_right, short clip_bottom, short box_left, short box_top, short box_right, short box_bottom, short x, short y, char* data, int data_bytes); int rdpup_composite(short srcidx, int srcformat, short srcwidth, CARD8 srcrepeat, PictTransform* srctransform, CARD8 mskflags, short mskidx, int mskformat, short mskwidth, CARD8 mskrepeat, CARD8 op, short srcx, short srcy, short mskx, short msky, short dstx, short dsty, short width, short height, int dstformat); void rdpScheduleDeferredUpdate(void); int rdpXvInit(ScreenPtr pScreen); #if defined(X_BYTE_ORDER) # if X_BYTE_ORDER == X_LITTLE_ENDIAN # define L_ENDIAN # else # define B_ENDIAN # endif #else # error Unknown endianness in rdp.h #endif /* check if we need to align data */ /* check if we need to align data */ #if defined(__sparc__) || defined(__alpha__) || defined(__hppa__) || \ defined(__AIX__) || defined(__PPC__) || defined(__mips__) || \ defined(__ia64__) || defined(__ppc__) || defined(__arm__) #define NEED_ALIGN #endif /* parser state */ struct stream { char* p; char* end; char* data; int size; /* offsets of various headers */ char* iso_hdr; char* mcs_hdr; char* sec_hdr; char* rdp_hdr; char* channel_hdr; char* next_packet; }; /******************************************************************************/ #define s_push_layer(s, h, n) \ { \ (s)->h = (s)->p; \ (s)->p += (n); \ } /******************************************************************************/ #define s_pop_layer(s, h) \ { \ (s)->p = (s)->h; \ } /******************************************************************************/ #if defined(B_ENDIAN) || defined(NEED_ALIGN) #define out_uint16_le(s, v) \ { \ *((s)->p) = (unsigned char)((v) >> 0); \ (s)->p++; \ *((s)->p) = (unsigned char)((v) >> 8); \ (s)->p++; \ } #else #define out_uint16_le(s, v) \ { \ *((unsigned short*)((s)->p)) = (unsigned short)(v); \ (s)->p += 2; \ } #endif /******************************************************************************/ #define out_uint8(s, v) \ { \ *((s)->p) = (unsigned char)((v) >> 0); \ (s)->p++; \ } /******************************************************************************/ #define init_stream(s, v) \ { \ if ((v) > (s)->size) \ { \ g_free((s)->data); \ (s)->data = (char*)g_malloc((v), 0); \ (s)->size = (v); \ } \ (s)->p = (s)->data; \ (s)->end = (s)->data; \ (s)->next_packet = 0; \ } /******************************************************************************/ #define out_uint8p(s, v, n) \ { \ g_memcpy((s)->p, (v), (n)); \ (s)->p += (n); \ } /******************************************************************************/ #define out_uint8a(s, v, n) \ { \ out_uint8p((s), (v), (n)); \ } /******************************************************************************/ #define out_uint8s(s, n) do \ { \ memset((s)->p, 0, (n)); \ (s)->p += (n); \ } while (0) /******************************************************************************/ #if defined(B_ENDIAN) || defined(NEED_ALIGN) #define out_uint32_le(s, v) \ { \ *((s)->p) = (unsigned char)((v) >> 0); \ (s)->p++; \ *((s)->p) = (unsigned char)((v) >> 8); \ (s)->p++; \ *((s)->p) = (unsigned char)((v) >> 16); \ (s)->p++; \ *((s)->p) = (unsigned char)((v) >> 24); \ (s)->p++; \ } #else #define out_uint32_le(s, v) \ { \ *((unsigned int*)((s)->p)) = (v); \ (s)->p += 4; \ } #endif /******************************************************************************/ #if defined(B_ENDIAN) || defined(NEED_ALIGN) #define in_uint32_le(s, v) \ { \ (v) = (unsigned int) \ ( \ (*((unsigned char*)((s)->p + 0)) << 0) | \ (*((unsigned char*)((s)->p + 1)) << 8) | \ (*((unsigned char*)((s)->p + 2)) << 16) | \ (*((unsigned char*)((s)->p + 3)) << 24) \ ); \ (s)->p += 4; \ } #else #define in_uint32_le(s, v) \ { \ (v) = *((unsigned int*)((s)->p)); \ (s)->p += 4; \ } #endif /******************************************************************************/ #if defined(B_ENDIAN) || defined(NEED_ALIGN) #define in_uint16_le(s, v) \ { \ (v) = (unsigned short) \ ( \ (*((unsigned char*)((s)->p + 0)) << 0) | \ (*((unsigned char*)((s)->p + 1)) << 8) \ ); \ (s)->p += 2; \ } #else #define in_uint16_le(s, v) \ { \ (v) = *((unsigned short*)((s)->p)); \ (s)->p += 2; \ } #endif /******************************************************************************/ #define s_mark_end(s) \ { \ (s)->end = (s)->p; \ } /******************************************************************************/ #define make_stream(s) \ { \ (s) = (struct stream*)g_malloc(sizeof(struct stream), 1); \ } /******************************************************************************/ #define free_stream(s) do \ { \ if ((s) != 0) \ { \ g_free((s)->data); \ } \ g_free((s)); \ } while (0) xrdp-0.9.5/xorg/X11R7.6/rdp/rdpPolyPoint.c000644 001751 001751 00000020217 13125122134 017717 0ustar00metameta000000 000000 /* Copyright 2005-2013 Jay Sorg Permission to use, copy, modify, distribute, and sell this software and its documentation for any purpose is hereby granted without fee, provided that the above copyright notice appear in all copies and that both that copyright notice and this permission notice appear in supporting documentation. The above copyright notice and this permission notice shall be included in all copies or substantial portions of the Software. THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE OPEN GROUP BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. */ #include "rdp.h" #include "rdpdraw.h" #define LDEBUG 0 #define LOG_LEVEL 1 #define LLOG(_level, _args) \ do { if (_level < LOG_LEVEL) { ErrorF _args ; } } while (0) #define LLOGLN(_level, _args) \ do { if (_level < LOG_LEVEL) { ErrorF _args ; ErrorF("\n"); } } while (0) extern rdpScreenInfoRec g_rdpScreen; /* from rdpmain.c */ extern DevPrivateKeyRec g_rdpGCIndex; /* from rdpmain.c */ extern DevPrivateKeyRec g_rdpWindowIndex; /* from rdpmain.c */ extern DevPrivateKeyRec g_rdpPixmapIndex; /* from rdpmain.c */ extern int g_Bpp; /* from rdpmain.c */ extern ScreenPtr g_pScreen; /* from rdpmain.c */ extern Bool g_wrapPixmap; /* from rdpmain.c */ extern int g_do_dirty_os; /* in rdpmain.c */ extern int g_do_dirty_ons; /* in rdpmain.c */ extern rdpPixmapRec g_screenPriv; /* in rdpmain.c */ extern GCOps g_rdpGCOps; /* from rdpdraw.c */ extern int g_con_number; /* in rdpup.c */ /******************************************************************************/ void rdpPolyPointOrg(DrawablePtr pDrawable, GCPtr pGC, int mode, int npt, DDXPointPtr in_pts) { rdpGCPtr priv; GCFuncs *oldFuncs; GC_OP_PROLOGUE(pGC); pGC->ops->PolyPoint(pDrawable, pGC, mode, npt, in_pts); GC_OP_EPILOGUE(pGC); } /******************************************************************************/ void rdpPolyPoint(DrawablePtr pDrawable, GCPtr pGC, int mode, int npt, DDXPointPtr in_pts) { RegionRec clip_reg; RegionRec reg1; RegionRec reg2; int num_clips; int cd; int x; int y; int i; int j; int got_id; int dirty_type; int post_process; int reset_surface; BoxRec box; BoxRec total_box; DDXPointPtr pts; DDXPointRec stack_pts[32]; struct image_data id; WindowPtr pDstWnd; PixmapPtr pDstPixmap; rdpPixmapRec *pDstPriv; rdpPixmapRec *pDirtyPriv; LLOGLN(10, ("rdpPolyPoint:")); LLOGLN(10, ("rdpPolyPoint: npt %d", npt)); if (npt > 32) { pts = (DDXPointPtr)g_malloc(sizeof(DDXPointRec) * npt, 0); } else { pts = stack_pts; } for (i = 0; i < npt; i++) { pts[i].x = pDrawable->x + in_pts[i].x; pts[i].y = pDrawable->y + in_pts[i].y; if (i == 0) { total_box.x1 = pts[0].x; total_box.y1 = pts[0].y; total_box.x2 = pts[0].x; total_box.y2 = pts[0].y; } else { if (pts[i].x < total_box.x1) { total_box.x1 = pts[i].x; } if (pts[i].y < total_box.y1) { total_box.y1 = pts[i].y; } if (pts[i].x > total_box.x2) { total_box.x2 = pts[i].x; } if (pts[i].y > total_box.y2) { total_box.y2 = pts[i].y; } } /* todo, use this total_box */ } /* do original call */ rdpPolyPointOrg(pDrawable, pGC, mode, npt, in_pts); dirty_type = 0; pDirtyPriv = 0; post_process = 0; reset_surface = 0; got_id = 0; if (pDrawable->type == DRAWABLE_PIXMAP) { pDstPixmap = (PixmapPtr)pDrawable; pDstPriv = GETPIXPRIV(pDstPixmap); if (xrdp_is_os(pDstPixmap, pDstPriv)) { post_process = 1; if (g_do_dirty_os) { LLOGLN(10, ("rdpPolyPoint: getting dirty")); pDstPriv->is_dirty = 1; pDirtyPriv = pDstPriv; dirty_type = RDI_IMGLL; } else { rdpup_switch_os_surface(pDstPriv->rdpindex); reset_surface = 1; rdpup_get_pixmap_image_rect(pDstPixmap, &id); got_id = 1; } } } else { if (pDrawable->type == DRAWABLE_WINDOW) { pDstWnd = (WindowPtr)pDrawable; if (pDstWnd->viewable) { post_process = 1; if (g_do_dirty_ons) { LLOGLN(10, ("rdpPolyPoint: getting dirty")); g_screenPriv.is_dirty = 1; pDirtyPriv = &g_screenPriv; dirty_type = RDI_IMGLL; } else { rdpup_get_screen_image_rect(&id); got_id = 1; } } } } if (!post_process) { return; } RegionInit(&clip_reg, NullBox, 0); cd = rdp_get_clip(&clip_reg, pDrawable, pGC); if (cd == 1) { if (npt > 0) { if (dirty_type != 0) { RegionInit(®1, NullBox, 0); for (i = 0; i < npt; i++) { box.x1 = pts[i].x; box.y1 = pts[i].y; box.x2 = box.x1 + 1; box.y2 = box.y1 + 1; RegionInit(®2, &box, 0); RegionUnion(®1, ®1, ®2); RegionUninit(®2); } draw_item_add_fill_region(pDirtyPriv, ®1, pGC->fgPixel, pGC->alu); RegionUninit(®1); } else if (got_id) { rdpup_begin_update(); rdpup_set_fgcolor(pGC->fgPixel); for (i = 0; i < npt; i++) { x = pts[i].x; y = pts[i].y; rdpup_fill_rect(x, y, 1, 1); } rdpup_end_update(); } } } else if (cd == 2) { num_clips = REGION_NUM_RECTS(&clip_reg); if (npt > 0 && num_clips > 0) { if (dirty_type != 0) { RegionInit(®1, NullBox, 0); for (i = 0; i < npt; i++) { box.x1 = pts[i].x; box.y1 = pts[i].y; box.x2 = box.x1 + 1; box.y2 = box.y1 + 1; RegionInit(®2, &box, 0); RegionUnion(®1, ®1, ®2); RegionUninit(®2); } RegionIntersect(®1, ®1, &clip_reg); draw_item_add_fill_region(pDirtyPriv, ®1, pGC->fgPixel, pGC->alu); RegionUninit(®1); } else if (got_id) { rdpup_begin_update(); rdpup_set_fgcolor(pGC->fgPixel); for (j = num_clips - 1; j >= 0; j--) { box = REGION_RECTS(&clip_reg)[j]; rdpup_set_clip(box.x1, box.y1, box.x2 - box.x1, box.y2 - box.y1); for (i = 0; i < npt; i++) { x = pts[i].x; y = pts[i].y; rdpup_fill_rect(x, y, 1, 1); } } rdpup_reset_clip(); rdpup_end_update(); } } } RegionUninit(&clip_reg); if (pts != stack_pts) { g_free(pts); } if (reset_surface) { rdpup_switch_os_surface(-1); } } xrdp-0.9.5/xorg/X11R7.6/rdp/rdpPushPixels.c000644 001751 001751 00000013665 13125122134 020077 0ustar00metameta000000 000000 /* Copyright 2005-2013 Jay Sorg Permission to use, copy, modify, distribute, and sell this software and its documentation for any purpose is hereby granted without fee, provided that the above copyright notice appear in all copies and that both that copyright notice and this permission notice appear in supporting documentation. The above copyright notice and this permission notice shall be included in all copies or substantial portions of the Software. THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE OPEN GROUP BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. */ #include "rdp.h" #include "rdpdraw.h" #define LDEBUG 0 #define LOG_LEVEL 1 #define LLOG(_level, _args) \ do { if (_level < LOG_LEVEL) { ErrorF _args ; } } while (0) #define LLOGLN(_level, _args) \ do { if (_level < LOG_LEVEL) { ErrorF _args ; ErrorF("\n"); } } while (0) extern rdpScreenInfoRec g_rdpScreen; /* from rdpmain.c */ extern DevPrivateKeyRec g_rdpGCIndex; /* from rdpmain.c */ extern DevPrivateKeyRec g_rdpWindowIndex; /* from rdpmain.c */ extern DevPrivateKeyRec g_rdpPixmapIndex; /* from rdpmain.c */ extern int g_Bpp; /* from rdpmain.c */ extern ScreenPtr g_pScreen; /* from rdpmain.c */ extern Bool g_wrapPixmap; /* from rdpmain.c */ extern int g_do_dirty_os; /* in rdpmain.c */ extern int g_do_dirty_ons; /* in rdpmain.c */ extern rdpPixmapRec g_screenPriv; /* in rdpmain.c */ extern GCOps g_rdpGCOps; /* from rdpdraw.c */ extern int g_con_number; /* in rdpup.c */ /******************************************************************************/ void rdpPushPixelsOrg(GCPtr pGC, PixmapPtr pBitMap, DrawablePtr pDst, int w, int h, int x, int y) { rdpGCPtr priv; GCFuncs *oldFuncs; GC_OP_PROLOGUE(pGC); pGC->ops->PushPixels(pGC, pBitMap, pDst, w, h, x, y); GC_OP_EPILOGUE(pGC); } /******************************************************************************/ void rdpPushPixels(GCPtr pGC, PixmapPtr pBitMap, DrawablePtr pDst, int w, int h, int x, int y) { RegionRec clip_reg; RegionRec box_reg; RegionRec reg1; int num_clips; int cd; int j; int got_id; int dirty_type; int post_process; int reset_surface; BoxRec box; struct image_data id; WindowPtr pDstWnd; PixmapPtr pDstPixmap; rdpPixmapRec *pDstPriv; rdpPixmapRec *pDirtyPriv; LLOGLN(10, ("rdpPushPixels:")); /* do original call */ rdpPushPixelsOrg(pGC, pBitMap, pDst, w, h, x, y); dirty_type = 0; pDirtyPriv = 0; post_process = 0; reset_surface = 0; got_id = 0; if (pDst->type == DRAWABLE_PIXMAP) { pDstPixmap = (PixmapPtr)pDst; pDstPriv = GETPIXPRIV(pDstPixmap); if (xrdp_is_os(pDstPixmap, pDstPriv)) { post_process = 1; if (g_do_dirty_os) { LLOGLN(10, ("rdpPushPixels: getting dirty")); pDstPriv->is_dirty = 1; pDirtyPriv = pDstPriv; dirty_type = RDI_IMGLY; } else { rdpup_switch_os_surface(pDstPriv->rdpindex); reset_surface = 1; rdpup_get_pixmap_image_rect(pDstPixmap, &id); got_id = 1; } } } else { if (pDst->type == DRAWABLE_WINDOW) { pDstWnd = (WindowPtr)pDst; if (pDstWnd->viewable) { post_process = 1; if (g_do_dirty_ons) { LLOGLN(10, ("rdpPushPixels: getting dirty")); g_screenPriv.is_dirty = 1; pDirtyPriv = &g_screenPriv; dirty_type = RDI_IMGLL; } else { rdpup_get_screen_image_rect(&id); got_id = 1; } } } } if (!post_process) { return; } memset(&box, 0, sizeof(box)); RegionInit(&clip_reg, NullBox, 0); cd = rdp_get_clip(&clip_reg, pDst, pGC); if (cd == 1) { if (dirty_type != 0) { box.x1 = pDst->x + x; box.y1 = pDst->y + y; box.x2 = box.x1 + w; box.y2 = box.y1 + h; RegionInit(®1, &box, 0); draw_item_add_img_region(pDirtyPriv, ®1, GXcopy, dirty_type, TAG_PUSHPIXELS); RegionUninit(®1); } else if (got_id) { rdpup_begin_update(); rdpup_send_area(0, pDst->x + x, pDst->y + y, w, h); rdpup_end_update(); } } else if (cd == 2) { box.x1 = pDst->x + x; box.y1 = pDst->y + y; box.x2 = box.x1 + w; box.y2 = box.y1 + h; RegionInit(&box_reg, &box, 0); RegionIntersect(&clip_reg, &clip_reg, &box_reg); num_clips = REGION_NUM_RECTS(&clip_reg); if (num_clips > 0) { if (dirty_type != 0) { RegionInit(®1, &box, 0); draw_item_add_img_region(pDirtyPriv, &clip_reg, GXcopy, dirty_type, TAG_PUSHPIXELS); RegionUninit(®1); } else if (got_id) { rdpup_begin_update(); for (j = num_clips - 1; j >= 0; j--) { box = REGION_RECTS(&clip_reg)[j]; rdpup_send_area(0, box.x1, box.y1, box.x2 - box.x1, box.y2 - box.y1); } rdpup_end_update(); } } RegionUninit(&box_reg); } RegionUninit(&clip_reg); if (reset_surface) { rdpup_switch_os_surface(-1); } } xrdp-0.9.5/xorg/X11R7.6/rdp/rdpFillPolygon.c000644 001751 001751 00000015044 13125122134 020222 0ustar00metameta000000 000000 /* Copyright 2005-2013 Jay Sorg Permission to use, copy, modify, distribute, and sell this software and its documentation for any purpose is hereby granted without fee, provided that the above copyright notice appear in all copies and that both that copyright notice and this permission notice appear in supporting documentation. The above copyright notice and this permission notice shall be included in all copies or substantial portions of the Software. THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE OPEN GROUP BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. */ #include "rdp.h" #include "rdpdraw.h" #define LDEBUG 0 #define LOG_LEVEL 1 #define LLOG(_level, _args) \ do { if (_level < LOG_LEVEL) { ErrorF _args ; } } while (0) #define LLOGLN(_level, _args) \ do { if (_level < LOG_LEVEL) { ErrorF _args ; ErrorF("\n"); } } while (0) extern rdpScreenInfoRec g_rdpScreen; /* from rdpmain.c */ extern DevPrivateKeyRec g_rdpGCIndex; /* from rdpmain.c */ extern DevPrivateKeyRec g_rdpWindowIndex; /* from rdpmain.c */ extern DevPrivateKeyRec g_rdpPixmapIndex; /* from rdpmain.c */ extern int g_Bpp; /* from rdpmain.c */ extern ScreenPtr g_pScreen; /* from rdpmain.c */ extern Bool g_wrapPixmap; /* from rdpmain.c */ extern int g_do_dirty_os; /* in rdpmain.c */ extern int g_do_dirty_ons; /* in rdpmain.c */ extern rdpPixmapRec g_screenPriv; /* in rdpmain.c */ extern GCOps g_rdpGCOps; /* from rdpdraw.c */ extern int g_con_number; /* in rdpup.c */ /******************************************************************************/ void rdpFillPolygonOrg(DrawablePtr pDrawable, GCPtr pGC, int shape, int mode, int count, DDXPointPtr pPts) { rdpGCPtr priv; GCFuncs *oldFuncs; GC_OP_PROLOGUE(pGC); pGC->ops->FillPolygon(pDrawable, pGC, shape, mode, count, pPts); GC_OP_EPILOGUE(pGC); } /******************************************************************************/ void rdpFillPolygon(DrawablePtr pDrawable, GCPtr pGC, int shape, int mode, int count, DDXPointPtr pPts) { RegionRec clip_reg; RegionRec box_reg; RegionRec reg1; int num_clips; int cd; int maxx; int maxy; int minx; int miny; int i; int j; int got_id; int dirty_type; int post_process; int reset_surface; BoxRec box; struct image_data id; WindowPtr pDstWnd; PixmapPtr pDstPixmap; rdpPixmapRec *pDstPriv; rdpPixmapRec *pDirtyPriv; LLOGLN(10, ("rdpFillPolygon:")); box.x1 = 0; box.y1 = 0; box.x2 = 0; box.y2 = 0; if (count > 0) { maxx = pPts[0].x; maxy = pPts[0].y; minx = maxx; miny = maxy; for (i = 1; i < count; i++) { if (pPts[i].x > maxx) { maxx = pPts[i].x; } if (pPts[i].x < minx) { minx = pPts[i].x; } if (pPts[i].y > maxy) { maxy = pPts[i].y; } if (pPts[i].y < miny) { miny = pPts[i].y; } } box.x1 = pDrawable->x + minx; box.y1 = pDrawable->y + miny; box.x2 = pDrawable->x + maxx + 1; box.y2 = pDrawable->y + maxy + 1; } /* do original call */ rdpFillPolygonOrg(pDrawable, pGC, shape, mode, count, pPts); dirty_type = 0; pDirtyPriv = 0; post_process = 0; reset_surface = 0; got_id = 0; if (pDrawable->type == DRAWABLE_PIXMAP) { pDstPixmap = (PixmapPtr)pDrawable; pDstPriv = GETPIXPRIV(pDstPixmap); if (xrdp_is_os(pDstPixmap, pDstPriv)) { post_process = 1; if (g_do_dirty_os) { LLOGLN(10, ("rdpFillPolygon: getting dirty")); pDstPriv->is_dirty = 1; pDirtyPriv = pDstPriv; dirty_type = RDI_IMGLL; } else { rdpup_switch_os_surface(pDstPriv->rdpindex); reset_surface = 1; rdpup_get_pixmap_image_rect(pDstPixmap, &id); got_id = 1; } } } else { if (pDrawable->type == DRAWABLE_WINDOW) { pDstWnd = (WindowPtr)pDrawable; if (pDstWnd->viewable) { post_process = 1; if (g_do_dirty_ons) { LLOGLN(10, ("rdpFillPolygon: getting dirty")); g_screenPriv.is_dirty = 1; pDirtyPriv = &g_screenPriv; dirty_type = RDI_IMGLL; } else { rdpup_get_screen_image_rect(&id); got_id = 1; } } } } if (!post_process) { return; } RegionInit(&clip_reg, NullBox, 0); cd = rdp_get_clip(&clip_reg, pDrawable, pGC); if (cd == 1) { if (dirty_type != 0) { RegionInit(®1, &box, 0); draw_item_add_img_region(pDirtyPriv, ®1, GXcopy, dirty_type, TAG_FILLPOLYGON); RegionUninit(®1); } else if (got_id) { rdpup_begin_update(); rdpup_send_area(&id, box.x1, box.y1, box.x2 - box.x1, box.y2 - box.y1); rdpup_end_update(); } } else if (cd == 2) { RegionInit(&box_reg, &box, 0); RegionIntersect(&clip_reg, &clip_reg, &box_reg); num_clips = REGION_NUM_RECTS(&clip_reg); if (num_clips > 0) { if (dirty_type != 0) { draw_item_add_img_region(pDirtyPriv, &clip_reg, GXcopy, dirty_type, TAG_FILLPOLYGON); } else if (got_id) { rdpup_begin_update(); for (j = num_clips - 1; j >= 0; j--) { box = REGION_RECTS(&clip_reg)[j]; rdpup_send_area(&id, box.x1, box.y1, box.x2 - box.x1, box.y2 - box.y1); } rdpup_end_update(); } } RegionUninit(&box_reg); } RegionUninit(&clip_reg); if (reset_surface) { rdpup_switch_os_surface(-1); } } xrdp-0.9.5/xorg/X11R7.6/rdp/rdpkeyboardbase.c000644 001751 001751 00000022755 13127114621 020432 0ustar00metameta000000 000000 /* Copyright 2005-2014 Jay Sorg Permission to use, copy, modify, distribute, and sell this software and its documentation for any purpose is hereby granted without fee, provided that the above copyright notice appear in all copies and that both that copyright notice and this permission notice appear in supporting documentation. The above copyright notice and this permission notice shall be included in all copies or substantial portions of the Software. THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE OPEN GROUP BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. keyboard map for base rules */ #include "rdp.h" #include "rdpkeyboard.h" #include "rdpkeyboardbase.h" extern DeviceIntPtr g_keyboard; /* in rdpmain.c */ extern int g_shift_down; /* in rdpmain.c */ extern int g_alt_down; /* in rdpmain.c */ extern int g_ctrl_down; /* in rdpmain.c */ extern int g_pause_spe; /* in rdpmain.c */ extern int g_tab_down; /* in rdpmain.c */ #define LOG_LEVEL 1 #define LLOGLN(_level, _args) \ do { if (_level < LOG_LEVEL) { ErrorF _args ; ErrorF("\n"); } } while (0) #define XSCAN_Tab 23 #define XSCAN_Return 36 /* above right shift */ #define XSCAN_Control_L 37 #define XSCAN_Shift_L 50 #define XSCAN_slash 61 #define XSCAN_Shift_R 62 #define XSCAN_KP_Multiply 63 #define XSCAN_Alt_L 64 #define XSCAN_Caps_Lock 66 /* caps lock */ #define XSCAN_Num_Lock 77 /* num lock */ #define XSCAN_KP_7 79 #define XSCAN_KP_8 80 #define XSCAN_KP_9 81 #define XSCAN_KP_4 83 #define XSCAN_KP_6 85 #define XSCAN_KP_1 87 #define XSCAN_KP_2 88 #define XSCAN_KP_3 89 #define XSCAN_KP_0 90 #define XSCAN_KP_Decimal 91 /* "/ ?" on br keyboard */ #define XSCAN_97 97 /* ------------------------------? */ #define XSCAN_Enter 108 /* 104 */ /* on keypad */ #define XSCAN_Control_R 109 /* 105 */ #define XSCAN_KP_Divide 112 /* 106 */ #define XSCAN_Print 111 /* 107 */ #define XSCAN_Alt_R 113 /* 108 */ #define XSCAN_Home 97 /* 110 */ #define XSCAN_Up 98 /* 111 */ #define XSCAN_Prior 99 /* 112 */ #define XSCAN_Left 100 /* 113 */ #define XSCAN_Right 102 /* 114 */ #define XSCAN_End 103 /* 115 */ #define XSCAN_Down 104 /* 116 */ #define XSCAN_Next 105 /* 117 */ #define XSCAN_Insert 106 /* 118 */ #define XSCAN_Delete 107 /* 119 */ #define XSCAN_Pause 110 /* 127 */ /* . on br keypad */ #define XSCAN_129 129 /* ------------------------------? */ #define XSCAN_LWin 115 /* 133 */ #define XSCAN_RWin 116 /* 134 */ #define XSCAN_Menu 117 /* 135 */ #define XSCAN_LMeta 156 #define XSCAN_RMeta 156 #define XSCAN_211 211 /* "/ ?" on br keyboard, "\ _" on jp keyboard */ /******************************************************************************/ void KbdAddEvent_base(int down, int param1, int param2, int param3, int param4) { int rdp_scancode; int x_scancode; int is_ext; int is_spe; int type; LLOGLN(10, ("KbdAddEvent_base: down=0x%x param1=0x%x param2=0x%x " "param3=0x%x param4=0x%x", down, param1, param2, param3, param4)); if (g_keyboard == 0) { return; } type = down ? KeyPress : KeyRelease; rdp_scancode = param3; is_ext = param4 & 256; /* 0x100 */ is_spe = param4 & 512; /* 0x200 */ x_scancode = 0; switch (rdp_scancode) { case RDPSCAN_Caps_Lock: /* caps lock */ case RDPSCAN_Shift_L: /* left shift */ case RDPSCAN_Shift_R: /* right shift */ case RDPSCAN_Scroll_Lock: /* scroll lock */ x_scancode = rdp_scancode + MIN_KEY_CODE; if (x_scancode > 0) { /* left or right shift */ if ((rdp_scancode == RDPSCAN_Shift_L) || (rdp_scancode == RDPSCAN_Shift_R)) { g_shift_down = down ? x_scancode : 0; } rdpEnqueueKey(type, x_scancode); } break; case RDPSCAN_Alt: /* left - right alt button */ if (is_ext) { x_scancode = XSCAN_Alt_R; /* right alt button */ } else { x_scancode = XSCAN_Alt_L; /* left alt button */ } g_alt_down = down ? x_scancode : 0; rdpEnqueueKey(type, x_scancode); break; case RDPSCAN_Tab: /* tab */ if (!down && !g_tab_down) { check_keysa(); /* leave x_scancode 0 here, we don't want the tab key up */ } else { sendDownUpKeyEvent(type, XSCAN_Tab); } g_tab_down = down; break; case RDPSCAN_Control: /* left or right ctrl */ /* this is to handle special case with pause key sending control first */ if (is_spe) { if (down) { g_pause_spe = 1; /* leave x_scancode 0 here, we don't want the control key down */ } } else { x_scancode = is_ext ? XSCAN_Control_R : XSCAN_Control_L; g_ctrl_down = down ? x_scancode : 0; rdpEnqueueKey(type, x_scancode); } break; case RDPSCAN_Pause: /* Pause or Num Lock */ if (g_pause_spe) { x_scancode = XSCAN_Pause; if (!down) { g_pause_spe = 0; } } else { x_scancode = g_ctrl_down ? XSCAN_Pause : XSCAN_Num_Lock; } rdpEnqueueKey(type, x_scancode); break; case RDPSCAN_Return: /* Enter or Return */ x_scancode = is_ext ? XSCAN_Enter : XSCAN_Return; sendDownUpKeyEvent(type, x_scancode); break; case RDPSCAN_Slash: /* / */ x_scancode = is_ext ? XSCAN_KP_Divide : XSCAN_slash; sendDownUpKeyEvent(type, x_scancode); break; case RDPSCAN_KP_Multiply: /* * on KP or Print Screen */ x_scancode = is_ext ? XSCAN_Print : XSCAN_KP_Multiply; sendDownUpKeyEvent(type, x_scancode); break; case RDPSCAN_KP_7: /* 7 or Home */ x_scancode = is_ext ? XSCAN_Home : XSCAN_KP_7; sendDownUpKeyEvent(type, x_scancode); break; case RDPSCAN_KP_8: /* 8 or Up */ x_scancode = is_ext ? XSCAN_Up : XSCAN_KP_8; sendDownUpKeyEvent(type, x_scancode); break; case RDPSCAN_KP_9: /* 9 or PgUp */ x_scancode = is_ext ? XSCAN_Prior : XSCAN_KP_9; sendDownUpKeyEvent(type, x_scancode); break; case RDPSCAN_KP_4: /* 4 or Left */ x_scancode = is_ext ? XSCAN_Left : XSCAN_KP_4; sendDownUpKeyEvent(type, x_scancode); break; case RDPSCAN_KP_6: /* 6 or Right */ x_scancode = is_ext ? XSCAN_Right : XSCAN_KP_6; sendDownUpKeyEvent(type, x_scancode); break; case RDPSCAN_KP_1: /* 1 or End */ x_scancode = is_ext ? XSCAN_End : XSCAN_KP_1; sendDownUpKeyEvent(type, x_scancode); break; case RDPSCAN_KP_2: /* 2 or Down */ x_scancode = is_ext ? XSCAN_Down : XSCAN_KP_2; sendDownUpKeyEvent(type, x_scancode); break; case RDPSCAN_KP_3: /* 3 or PgDn */ x_scancode = is_ext ? XSCAN_Next : XSCAN_KP_3; sendDownUpKeyEvent(type, x_scancode); break; case RDPSCAN_KP_0: /* 0 or Insert */ x_scancode = is_ext ? XSCAN_Insert : XSCAN_KP_0; sendDownUpKeyEvent(type, x_scancode); break; case RDPSCAN_KP_Decimal: /* . or Delete */ x_scancode = is_ext ? XSCAN_Delete : XSCAN_KP_Decimal; sendDownUpKeyEvent(type, x_scancode); break; case RDPSCAN_LWin: /* left win key */ rdpEnqueueKey(type, XSCAN_LWin); break; case RDPSCAN_RWin: /* right win key */ rdpEnqueueKey(type, XSCAN_RWin); break; case RDPSCAN_Menu: /* menu key */ rdpEnqueueKey(type, XSCAN_Menu); break; case RDPSCAN_89: /* left meta */ rdpEnqueueKey(type, XSCAN_LMeta); break; case RDPSCAN_90: /* right meta */ rdpEnqueueKey(type, XSCAN_RMeta); break; case RDPSCAN_115: rdpEnqueueKey(type, XSCAN_211); /* "/ ?" on br keyboard, "\ _" on jp keyboard */ break; case RDPSCAN_126: rdpEnqueueKey(type, XSCAN_129); /* . on br keypad */ break; default: x_scancode = rdp_scancode + MIN_KEY_CODE; if (x_scancode > 0) { LLOGLN(10, ("KbdAddEvent_base: rdp_scancode %d x_scancode %d", rdp_scancode, x_scancode)); sendDownUpKeyEvent(type, x_scancode); } break; } } xrdp-0.9.5/xorg/X11R7.6/rdp/rdpCopyPlane.h000644 001751 001751 00000002220 13125122134 017653 0ustar00metameta000000 000000 /* Copyright 2005-2013 Jay Sorg Permission to use, copy, modify, distribute, and sell this software and its documentation for any purpose is hereby granted without fee, provided that the above copyright notice appear in all copies and that both that copyright notice and this permission notice appear in supporting documentation. The above copyright notice and this permission notice shall be included in all copies or substantial portions of the Software. THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE OPEN GROUP BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. */ #ifndef __RDPCOPYPLANE_H #define __RDPCOPYPLANE_H RegionPtr rdpCopyPlane(DrawablePtr pSrcDrawable, DrawablePtr pDstDrawable, GCPtr pGC, int srcx, int srcy, int width, int height, int dstx, int dsty, unsigned long bitPlane); #endif xrdp-0.9.5/xorg/X11R7.6/rdp/rdp.h000644 001751 001751 00000047041 13220727405 016062 0ustar00metameta000000 000000 /* Copyright 2005-2013 Jay Sorg Permission to use, copy, modify, distribute, and sell this software and its documentation for any purpose is hereby granted without fee, provided that the above copyright notice appear in all copies and that both that copyright notice and this permission notice appear in supporting documentation. The above copyright notice and this permission notice shall be included in all copies or substantial portions of the Software. THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE OPEN GROUP BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. */ #if defined(__arm__) && !defined(__arm32__) #define __arm32__ #endif #include "xorg-server.h" #include #include #include #include #include #include #include #include #include #include #include #include #include "X.h" #define NEED_EVENTS #include "Xproto.h" #include "Xos.h" #include "scrnintstr.h" #include "servermd.h" #define PSZ 8 //#include "cfb.h" #include "mibstore.h" #include "colormapst.h" #include "gcstruct.h" #include "input.h" #include "mipointer.h" #include "dixstruct.h" #include "propertyst.h" #include "Xatom.h" #include "dix.h" #include "X11/keysym.h" #include "dixfontstr.h" #include "fontstruct.h" #include "cursorstr.h" #include "picturestr.h" #include "XKBstr.h" #include "inputstr.h" #include "randrstr.h" #include "mi.h" #include "fb.h" #include "micmap.h" #include "events.h" #include "exevents.h" #include "xserver-properties.h" #include "xkbsrv.h" /* in xrdp/common */ #include "xrdp_client_info.h" #include "xrdp_constants.h" //#include "colormapst.h" #define X11RDPVER "0.9.5" #define PixelDPI 100 #define PixelToMM(_size) (((_size) * 254 + (PixelDPI) * 5) / ((PixelDPI) * 10)) #define TAG_COMPOSITE 0 #define TAG_COPYAREA 1 #define TAG_POLYFILLRECT 2 #define TAG_PUTIMAGE 3 #define TAG_POLYRECTANGLE 4 #define TAG_COPYPLANE 5 #define TAG_POLYARC 6 #define TAG_FILLPOLYGON 7 #define TAG_POLYFILLARC 8 #define TAG_IMAGETEXT8 9 #define TAG_POLYTEXT8 10 #define TAG_POLYTEXT16 11 #define TAG_IMAGETEXT16 12 #define TAG_IMAGEGLYPHBLT 13 #define TAG_POLYGLYPHBLT 14 #define TAG_PUSHPIXELS 15 struct image_data { int width; int height; int bpp; int Bpp; int lineBytes; char* pixels; char* shmem_pixels; int shmem_id; int shmem_offset; int shmem_lineBytes; }; /* Per-screen (framebuffer) structure. There is only one of these, since we don't allow the X server to have multiple screens. */ struct _rdpScreenInfoRec { int width; int paddedWidthInBytes; int height; int depth; int bitsPerPixel; int sizeInBytes; /* size of current used frame buffer */ int sizeInBytesAlloc; /* size of current alloc frame buffer, always >= sizeInBytes */ char* pfbMemory; Pixel blackPixel; Pixel whitePixel; /* wrapped screen functions */ /* Random screen procedures */ CloseScreenProcPtr CloseScreen; /* GC procedures */ CreateGCProcPtr CreateGC; /* Pixmap procedures */ CreatePixmapProcPtr CreatePixmap; DestroyPixmapProcPtr DestroyPixmap; /* Window Procedures */ CreateWindowProcPtr CreateWindow; DestroyWindowProcPtr DestroyWindow; PositionWindowProcPtr PositionWindow; RealizeWindowProcPtr RealizeWindow; UnrealizeWindowProcPtr UnrealizeWindow; ChangeWindowAttributesProcPtr ChangeWindowAttributes; WindowExposuresProcPtr WindowExposures; CreateColormapProcPtr CreateColormap; DestroyColormapProcPtr DestroyColormap; CopyWindowProcPtr CopyWindow; ClearToBackgroundProcPtr ClearToBackground; ScreenWakeupHandlerProcPtr WakeupHandler; CreatePictureProcPtr CreatePicture; DestroyPictureProcPtr DestroyPicture; CompositeProcPtr Composite; GlyphsProcPtr Glyphs; /* Backing store procedures */ RestoreAreasProcPtr RestoreAreas; int rdp_width; int rdp_height; int rdp_bpp; int rdp_Bpp; int rdp_Bpp_mask; struct xrdp_client_info client_info; }; typedef struct _rdpScreenInfoRec rdpScreenInfoRec; typedef rdpScreenInfoRec* rdpScreenInfoPtr; struct _rdpGCRec { GCFuncs* funcs; GCOps* ops; }; typedef struct _rdpGCRec rdpGCRec; typedef rdpGCRec* rdpGCPtr; #define GETGCPRIV(_pGC) \ (rdpGCPtr)dixGetPrivateAddr(&(_pGC->devPrivates), &g_rdpGCIndex) struct _rdpWindowRec { int status; }; typedef struct _rdpWindowRec rdpWindowRec; typedef rdpWindowRec* rdpWindowPtr; #define GETWINPRIV(_pWindow) \ (rdpWindowPtr)dixGetPrivateAddr(&(_pWindow->devPrivates), &g_rdpWindowIndex) #define XR_IS_ROOT(_pWindow) ((_pWindow)->drawable.pScreen->root == (_pWindow)) /* for tooltips */ #define XR_STYLE_TOOLTIP (0x80000000) #define XR_EXT_STYLE_TOOLTIP (0x00000080 | 0x00000008) /* for normal desktop windows */ /* WS_TILEDWINDOW (WS_OVERLAPPED | WS_CAPTION | WS_SYSMENU | WS_THICKFRAME | WS_MINIMIZEBOX | WS_MAXIMIZEBOX) */ #define XR_STYLE_NORMAL (0x00C00000 | 0x00080000 | 0x00040000 | 0x00010000 | 0x00020000) #define XR_EXT_STYLE_NORMAL (0x00040000) /* for dialogs */ #define XR_STYLE_DIALOG (0x80000000) #define XR_EXT_STYLE_DIALOG (0x00040000) #define RDI_FILL 1 #define RDI_IMGLL 2 /* lossless */ #define RDI_IMGLY 3 /* lossy */ #define RDI_LINE 4 #define RDI_SCRBLT 5 #define RDI_TEXT 6 struct urdp_draw_item_fill { int opcode; int fg_color; int bg_color; int pad0; }; struct urdp_draw_item_img { int opcode; int pad0; }; struct urdp_draw_item_line { int opcode; int fg_color; int bg_color; int width; xSegment* segs; int nseg; int flags; }; struct urdp_draw_item_scrblt { int srcx; int srcy; int dstx; int dsty; int cx; int cy; }; struct urdp_draw_item_text { int opcode; int fg_color; struct rdp_text* rtext; /* in rdpglyph.h */ }; union urdp_draw_item { struct urdp_draw_item_fill fill; struct urdp_draw_item_img img; struct urdp_draw_item_line line; struct urdp_draw_item_scrblt scrblt; struct urdp_draw_item_text text; }; struct rdp_draw_item { int type; /* RDI_FILL, RDI_IMGLL, ... */ int flags; struct rdp_draw_item* prev; struct rdp_draw_item* next; RegionPtr reg; union urdp_draw_item u; }; #define XRDP_USE_COUNT_THRESHOLD 1 struct _rdpPixmapRec { int status; int rdpindex; int con_number; int is_dirty; int is_scratch; int is_alpha_dirty_not; /* number of times used in a remote operation if this gets above XRDP_USE_COUNT_THRESHOLD then we force remote the pixmap */ int use_count; int kind_width; struct rdp_draw_item* draw_item_head; struct rdp_draw_item* draw_item_tail; }; typedef struct _rdpPixmapRec rdpPixmapRec; typedef rdpPixmapRec* rdpPixmapPtr; #define GETPIXPRIV(_pPixmap) \ (rdpPixmapPtr)dixGetPrivateAddr(&(_pPixmap->devPrivates), &g_rdpPixmapIndex) #define XRDP_IS_OS(_priv) (_priv->status != 0) /* rdpmisc.c */ void rdpLog(char *format, ...); int rdpBitsPerPixel(int depth); void rdpClientStateChange(CallbackListPtr* cbl, pointer myData, pointer clt); int g_tcp_recv(int sck, void* ptr, int len, int flags); void g_tcp_close(int sck); int g_tcp_last_error_would_block(int sck); void g_sleep(int msecs); int g_tcp_send(int sck, void* ptr, int len, int flags); void* g_malloc(int size, int zero); void g_free(void* ptr); void g_sprintf(char* dest, char* format, ...); int g_tcp_socket(void); int g_tcp_local_socket_dgram(void); int g_tcp_local_socket_stream(void); void g_memcpy(void* d_ptr, const void* s_ptr, int size); int g_tcp_set_no_delay(int sck); int g_tcp_set_non_blocking(int sck); int g_tcp_accept(int sck); int g_tcp_select(int sck1, int sck2, int sck3); int g_tcp_bind(int sck, char* port); int g_tcp_local_bind(int sck, char* port); int g_tcp_listen(int sck); int g_create_dir(const char* dirname); int g_directory_exist(const char* dirname); int g_chmod_hex(const char* filename, int flags); const char * g_socket_dir(void); void hexdump(unsigned char *p, unsigned int len); void RegionAroundSegs(RegionPtr reg, xSegment* segs, int nseg); int get_crc(char* data, int data_bytes); int get_mstime(void); /* rdpdraw.c */ Bool rdpCloseScreen(int i, ScreenPtr pScreen); int draw_item_add(rdpPixmapRec* priv, struct rdp_draw_item* di); int draw_item_remove(rdpPixmapRec* priv, struct rdp_draw_item* di); int draw_item_remove_all(rdpPixmapRec* priv); int draw_item_pack(PixmapPtr pix, rdpPixmapRec* priv); int draw_item_add_img_region(rdpPixmapRec* priv, RegionPtr reg, int opcode, int type, int code); int draw_item_add_fill_region(rdpPixmapRec* priv, RegionPtr reg, int color, int opcode); int draw_item_add_line_region(rdpPixmapRec* priv, RegionPtr reg, int color, int opcode, int width, xSegment* segs, int nsegs, int is_segment); int draw_item_add_srcblt_region(rdpPixmapRec* priv, RegionPtr reg, int srcx, int srcy, int dstx, int dsty, int cx, int cy); int draw_item_add_text_region(rdpPixmapRec* priv, RegionPtr reg, int color, int opcode, struct rdp_text* rtext); PixmapPtr rdpCreatePixmap(ScreenPtr pScreen, int width, int height, int depth, unsigned usage_hint); Bool rdpDestroyPixmap(PixmapPtr pPixmap); int xrdp_is_os(PixmapPtr pix, rdpPixmapPtr priv); Bool rdpCreateWindow(WindowPtr pWindow); Bool rdpDestroyWindow(WindowPtr pWindow); Bool rdpPositionWindow(WindowPtr pWindow, int x, int y); Bool rdpRealizeWindow(WindowPtr pWindow); Bool rdpUnrealizeWindow(WindowPtr pWindow); Bool rdpChangeWindowAttributes(WindowPtr pWindow, unsigned long mask); void rdpWindowExposures(WindowPtr pWindow, RegionPtr pRegion, RegionPtr pBSRegion); Bool rdpCreateGC(GCPtr pGC); void rdpCopyWindow(WindowPtr pWin, DDXPointRec ptOldOrg, RegionPtr pOldRegion); void rdpClearToBackground(WindowPtr pWin, int x, int y, int w, int h, Bool generateExposures); RegionPtr rdpRestoreAreas(WindowPtr pWin, RegionPtr prgnExposed); void rdpInstallColormap(ColormapPtr pmap); void rdpUninstallColormap(ColormapPtr pmap); int rdpListInstalledColormaps(ScreenPtr pScreen, Colormap* pmaps); void rdpStoreColors(ColormapPtr pmap, int ndef, xColorItem* pdefs); Bool rdpSaveScreen(ScreenPtr pScreen, int on); Bool rdpRealizeCursor(ScreenPtr pScreen, CursorPtr pCursor); Bool rdpUnrealizeCursor(ScreenPtr pScreen, CursorPtr pCursor); void rdpCursorLimits(ScreenPtr pScreen, CursorPtr pCursor, BoxPtr pHotBox, BoxPtr pTopLeftBox); void rdpConstrainCursor(ScreenPtr pScreen, BoxPtr pBox); Bool rdpSetCursorPosition(ScreenPtr pScreen, int x, int y, Bool generateEvent); Bool rdpDisplayCursor(ScreenPtr pScreen, CursorPtr pCursor); void rdpRecolorCursor(ScreenPtr pScreen, CursorPtr pCursor, Bool displayed); /* rdpglyph.c */ /* look in rdpglyph.h */ /* rdpComposite.c */ int rdpCreatePicture(PicturePtr pPicture); void rdpDestroyPicture(PicturePtr pPicture); void rdpComposite(CARD8 op, PicturePtr pSrc, PicturePtr pMask, PicturePtr pDst, INT16 xSrc, INT16 ySrc, INT16 xMask, INT16 yMask, INT16 xDst, INT16 yDst, CARD16 width, CARD16 height); /* rdpinput.c */ int rdpKeybdProc(DeviceIntPtr pDevice, int onoff); int rdpMouseProc(DeviceIntPtr pDevice, int onoff); Bool rdpCursorOffScreen(ScreenPtr* ppScreen, int* x, int* y); void rdpCrossScreen(ScreenPtr pScreen, Bool entering); void rdpPointerWarpCursor(DeviceIntPtr pDev, ScreenPtr pScr, int x, int y); void rdpPointerEnqueueEvent(DeviceIntPtr pDev, InternalEvent* event); void rdpPointerNewEventScreen(DeviceIntPtr pDev, ScreenPtr pScr, Bool fromDIX); Bool rdpSpriteRealizeCursor(DeviceIntPtr pDev, ScreenPtr pScr, CursorPtr pCurs); Bool rdpSpriteUnrealizeCursor(DeviceIntPtr pDev, ScreenPtr pScr, CursorPtr pCurs); void rdpSpriteSetCursor(DeviceIntPtr pDev, ScreenPtr pScr, CursorPtr pCurs, int x, int y); void rdpSpriteMoveCursor(DeviceIntPtr pDev, ScreenPtr pScr, int x, int y); Bool rdpSpriteDeviceCursorInitialize(DeviceIntPtr pDev, ScreenPtr pScr); void rdpSpriteDeviceCursorCleanup(DeviceIntPtr pDev, ScreenPtr pScr); void PtrAddEvent(int buttonMask, int x, int y); void KbdAddEvent(int down, int param1, int param2, int param3, int param4); void KbdSync(int param1); int rdpLoadLayout(struct xrdp_client_info *client_info); /* rdpup.c */ int rdpup_add_os_bitmap(PixmapPtr pixmap, rdpPixmapPtr priv); int rdpup_remove_os_bitmap(int rdpindex); int rdpup_update_os_use(int rdpindex); void rdpup_get_screen_image_rect(struct image_data* id); void rdpup_get_pixmap_image_rect(PixmapPtr pPixmap, struct image_data* id); int rdpup_init(void); int rdpup_check(void); int rdpup_begin_update(void); int rdpup_end_update(void); int rdpup_fill_rect(short x, short y, int cx, int cy); int rdpup_screen_blt(short x, short y, int cx, int cy, short srcx, short srcy); int rdpup_set_clip(short x, short y, int cx, int cy); int rdpup_reset_clip(void); int rdpup_set_fgcolor(int fgcolor); int rdpup_set_bgcolor(int bgcolor); int rdpup_set_opcode(int opcode); int rdpup_paint_rect(short x, short y, int cx, int cy, char* bmpdata, int width, int height, short srcx, short srcy); int rdpup_set_pen(int style, int width); int rdpup_draw_line(short x1, short y1, short x2, short y2); void rdpup_send_area(struct image_data* id, int x, int y, int w, int h); int rdpup_set_cursor(short x, short y, char* cur_data, char* cur_mask); int rdpup_set_cursor_ex(short x, short y, char *cur_data, char *cur_mask, int bpp); int rdpup_create_os_surface(int rdpindex, int width, int height); int rdpup_create_os_surface_bpp(int rdpindex, int width, int height, int bpp); int rdpup_switch_os_surface(int rdpindex); int rdpup_delete_os_surface(int rdpindex); void rdpup_paint_rect_os(int x, int y, int cx, int cy, int rdpindex, int srcx, int srcy); void rdpup_set_hints(int hints, int mask); void rdpup_create_window(WindowPtr pWindow, rdpWindowRec* priv); void rdpup_delete_window(WindowPtr pWindow, rdpWindowRec* priv); int rdpup_check_dirty(PixmapPtr pDirtyPixmap, rdpPixmapRec* pDirtyPriv); int rdpup_check_alpha_dirty(PixmapPtr pDirtyPixmap, rdpPixmapRec* pDirtyPriv); int rdpup_check_dirty_screen(rdpPixmapRec* pDirtyPriv); int rdpup_add_char(int font, int character, short x, short y, int cx, int cy, char* bmpdata, int bmpdata_bytes); int rdpup_add_char_alpha(int font, int character, short x, short y, int cx, int cy, char* bmpdata, int bmpdata_bytes); int rdpup_draw_text(int font, int flags, int mixmode, short clip_left, short clip_top, short clip_right, short clip_bottom, short box_left, short box_top, short box_right, short box_bottom, short x, short y, char* data, int data_bytes); int rdpup_composite(short srcidx, int srcformat, short srcwidth, CARD8 srcrepeat, PictTransform* srctransform, CARD8 mskflags, short mskidx, int mskformat, short mskwidth, CARD8 mskrepeat, CARD8 op, short srcx, short srcy, short mskx, short msky, short dstx, short dsty, short width, short height, int dstformat); void rdpScheduleDeferredUpdate(void); int rdpXvInit(ScreenPtr pScreen); #if defined(X_BYTE_ORDER) # if X_BYTE_ORDER == X_LITTLE_ENDIAN # define L_ENDIAN # else # define B_ENDIAN # endif #else # error Unknown endianness in rdp.h #endif /* check if we need to align data */ /* check if we need to align data */ #if defined(__sparc__) || defined(__alpha__) || defined(__hppa__) || \ defined(__AIX__) || defined(__PPC__) || defined(__mips__) || \ defined(__ia64__) || defined(__ppc__) || defined(__arm__) #define NEED_ALIGN #endif /* parser state */ struct stream { char* p; char* end; char* data; int size; /* offsets of various headers */ char* iso_hdr; char* mcs_hdr; char* sec_hdr; char* rdp_hdr; char* channel_hdr; char* next_packet; }; /******************************************************************************/ #define s_push_layer(s, h, n) \ { \ (s)->h = (s)->p; \ (s)->p += (n); \ } /******************************************************************************/ #define s_pop_layer(s, h) \ { \ (s)->p = (s)->h; \ } /******************************************************************************/ #if defined(B_ENDIAN) || defined(NEED_ALIGN) #define out_uint16_le(s, v) \ { \ *((s)->p) = (unsigned char)((v) >> 0); \ (s)->p++; \ *((s)->p) = (unsigned char)((v) >> 8); \ (s)->p++; \ } #else #define out_uint16_le(s, v) \ { \ *((unsigned short*)((s)->p)) = (unsigned short)(v); \ (s)->p += 2; \ } #endif /******************************************************************************/ #define out_uint8(s, v) \ { \ *((s)->p) = (unsigned char)((v) >> 0); \ (s)->p++; \ } /******************************************************************************/ #define init_stream(s, v) \ { \ if ((v) > (s)->size) \ { \ g_free((s)->data); \ (s)->data = (char*)g_malloc((v), 0); \ (s)->size = (v); \ } \ (s)->p = (s)->data; \ (s)->end = (s)->data; \ (s)->next_packet = 0; \ } /******************************************************************************/ #define out_uint8p(s, v, n) \ { \ g_memcpy((s)->p, (v), (n)); \ (s)->p += (n); \ } /******************************************************************************/ #define out_uint8a(s, v, n) \ { \ out_uint8p((s), (v), (n)); \ } /******************************************************************************/ #define out_uint8s(s, n) do \ { \ memset((s)->p, 0, (n)); \ (s)->p += (n); \ } while (0) /******************************************************************************/ #if defined(B_ENDIAN) || defined(NEED_ALIGN) #define out_uint32_le(s, v) \ { \ *((s)->p) = (unsigned char)((v) >> 0); \ (s)->p++; \ *((s)->p) = (unsigned char)((v) >> 8); \ (s)->p++; \ *((s)->p) = (unsigned char)((v) >> 16); \ (s)->p++; \ *((s)->p) = (unsigned char)((v) >> 24); \ (s)->p++; \ } #else #define out_uint32_le(s, v) \ { \ *((unsigned int*)((s)->p)) = (v); \ (s)->p += 4; \ } #endif /******************************************************************************/ #if defined(B_ENDIAN) || defined(NEED_ALIGN) #define in_uint32_le(s, v) \ { \ (v) = (unsigned int) \ ( \ (*((unsigned char*)((s)->p + 0)) << 0) | \ (*((unsigned char*)((s)->p + 1)) << 8) | \ (*((unsigned char*)((s)->p + 2)) << 16) | \ (*((unsigned char*)((s)->p + 3)) << 24) \ ); \ (s)->p += 4; \ } #else #define in_uint32_le(s, v) \ { \ (v) = *((unsigned int*)((s)->p)); \ (s)->p += 4; \ } #endif /******************************************************************************/ #if defined(B_ENDIAN) || defined(NEED_ALIGN) #define in_uint16_le(s, v) \ { \ (v) = (unsigned short) \ ( \ (*((unsigned char*)((s)->p + 0)) << 0) | \ (*((unsigned char*)((s)->p + 1)) << 8) \ ); \ (s)->p += 2; \ } #else #define in_uint16_le(s, v) \ { \ (v) = *((unsigned short*)((s)->p)); \ (s)->p += 2; \ } #endif /******************************************************************************/ #define s_mark_end(s) \ { \ (s)->end = (s)->p; \ } /******************************************************************************/ #define make_stream(s) \ { \ (s) = (struct stream*)g_malloc(sizeof(struct stream), 1); \ } /******************************************************************************/ #define free_stream(s) do \ { \ if ((s) != 0) \ { \ g_free((s)->data); \ } \ g_free((s)); \ } while (0) xrdp-0.9.5/xorg/X11R7.6/rdp/rdpPolyGlyphBlt.c000644 001751 001751 00000013645 13125122134 020362 0ustar00metameta000000 000000 /* Copyright 2005-2013 Jay Sorg Permission to use, copy, modify, distribute, and sell this software and its documentation for any purpose is hereby granted without fee, provided that the above copyright notice appear in all copies and that both that copyright notice and this permission notice appear in supporting documentation. The above copyright notice and this permission notice shall be included in all copies or substantial portions of the Software. THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE OPEN GROUP BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. */ #include "rdp.h" #include "rdpdraw.h" #define LDEBUG 0 #define LOG_LEVEL 1 #define LLOG(_level, _args) \ do { if (_level < LOG_LEVEL) { ErrorF _args ; } } while (0) #define LLOGLN(_level, _args) \ do { if (_level < LOG_LEVEL) { ErrorF _args ; ErrorF("\n"); } } while (0) extern rdpScreenInfoRec g_rdpScreen; /* from rdpmain.c */ extern DevPrivateKeyRec g_rdpGCIndex; /* from rdpmain.c */ extern DevPrivateKeyRec g_rdpWindowIndex; /* from rdpmain.c */ extern DevPrivateKeyRec g_rdpPixmapIndex; /* from rdpmain.c */ extern int g_Bpp; /* from rdpmain.c */ extern ScreenPtr g_pScreen; /* from rdpmain.c */ extern Bool g_wrapPixmap; /* from rdpmain.c */ extern int g_do_dirty_os; /* in rdpmain.c */ extern int g_do_dirty_ons; /* in rdpmain.c */ extern rdpPixmapRec g_screenPriv; /* in rdpmain.c */ extern GCOps g_rdpGCOps; /* from rdpdraw.c */ extern int g_con_number; /* in rdpup.c */ /******************************************************************************/ void rdpPolyGlyphBltOrg(DrawablePtr pDrawable, GCPtr pGC, int x, int y, unsigned int nglyph, CharInfoPtr *ppci, pointer pglyphBase) { rdpGCPtr priv; GCFuncs *oldFuncs; GC_OP_PROLOGUE(pGC); pGC->ops->PolyGlyphBlt(pDrawable, pGC, x, y, nglyph, ppci, pglyphBase); GC_OP_EPILOGUE(pGC); } /******************************************************************************/ void rdpPolyGlyphBlt(DrawablePtr pDrawable, GCPtr pGC, int x, int y, unsigned int nglyph, CharInfoPtr *ppci, pointer pglyphBase) { RegionRec reg; RegionRec reg1; int num_clips; int cd; int j; int got_id; int dirty_type; int post_process; int reset_surface; BoxRec box; struct image_data id; WindowPtr pDstWnd; PixmapPtr pDstPixmap; rdpPixmapRec *pDstPriv; rdpPixmapRec *pDirtyPriv; LLOGLN(10, ("rdpPolyGlyphBlt:")); if (nglyph != 0) { GetTextBoundingBox(pDrawable, pGC->font, x, y, nglyph, &box); } /* do original call */ rdpPolyGlyphBltOrg(pDrawable, pGC, x, y, nglyph, ppci, pglyphBase); dirty_type = 0; pDirtyPriv = 0; post_process = 0; reset_surface = 0; got_id = 0; if (pDrawable->type == DRAWABLE_PIXMAP) { pDstPixmap = (PixmapPtr)pDrawable; pDstPriv = GETPIXPRIV(pDstPixmap); if (xrdp_is_os(pDstPixmap, pDstPriv)) { post_process = 1; if (g_do_dirty_os) { LLOGLN(10, ("rdpPolyGlyphBlt: getting dirty")); pDstPriv->is_dirty = 1; pDirtyPriv = pDstPriv; dirty_type = RDI_IMGLY; } else { rdpup_switch_os_surface(pDstPriv->rdpindex); reset_surface = 1; rdpup_get_pixmap_image_rect(pDstPixmap, &id); got_id = 1; } } } else { if (pDrawable->type == DRAWABLE_WINDOW) { pDstWnd = (WindowPtr)pDrawable; if (pDstWnd->viewable) { post_process = 1; if (g_do_dirty_ons) { LLOGLN(10, ("rdpPolyGlyphBlt: getting dirty")); g_screenPriv.is_dirty = 1; pDirtyPriv = &g_screenPriv; dirty_type = RDI_IMGLL; } else { rdpup_get_screen_image_rect(&id); got_id = 1; } } } } if (!post_process) { return; } RegionInit(®, NullBox, 0); if (nglyph == 0) { cd = 0; } else { cd = rdp_get_clip(®, pDrawable, pGC); } if (cd == 1) { if (dirty_type != 0) { RegionInit(®1, &box, 0); draw_item_add_img_region(pDirtyPriv, ®1, GXcopy, dirty_type, TAG_POLYGLYPHBLT); RegionUninit(®1); } else if (got_id) { rdpup_begin_update(); rdpup_send_area(&id, box.x1, box.y1, box.x2 - box.x1, box.y2 - box.y1); rdpup_end_update(); } } else if (cd == 2) { RegionInit(®1, &box, 0); RegionIntersect(®, ®, ®1); num_clips = REGION_NUM_RECTS(®); if (num_clips > 0) { if (dirty_type != 0) { draw_item_add_img_region(pDirtyPriv, ®, GXcopy, dirty_type, TAG_POLYGLYPHBLT); } else if (got_id) { rdpup_begin_update(); for (j = num_clips - 1; j >= 0; j--) { box = REGION_RECTS(®)[j]; rdpup_send_area(&id, box.x1, box.y1, box.x2 - box.x1, box.y2 - box.y1); } rdpup_end_update(); } } RegionUninit(®1); } RegionUninit(®); if (reset_surface) { rdpup_switch_os_surface(-1); } return; } xrdp-0.9.5/xorg/X11R7.6/rdp/rdpkeyboardevdev.c000644 001751 001751 00000022177 13127114621 020627 0ustar00metameta000000 000000 /* Copyright 2005-2014 Jay Sorg Permission to use, copy, modify, distribute, and sell this software and its documentation for any purpose is hereby granted without fee, provided that the above copyright notice appear in all copies and that both that copyright notice and this permission notice appear in supporting documentation. The above copyright notice and this permission notice shall be included in all copies or substantial portions of the Software. THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE OPEN GROUP BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. keyboard map for evdev rules */ #include "rdp.h" #include "rdpkeyboard.h" #include "rdpkeyboardevdev.h" extern DeviceIntPtr g_keyboard; /* in rdpmain.c */ extern int g_shift_down; /* in rdpmain.c */ extern int g_alt_down; /* in rdpmain.c */ extern int g_ctrl_down; /* in rdpmain.c */ extern int g_pause_spe; /* in rdpmain.c */ extern int g_tab_down; /* in rdpmain.c */ #define LOG_LEVEL 1 #define LLOGLN(_level, _args) \ do { if (_level < LOG_LEVEL) { ErrorF _args ; ErrorF("\n"); } } while (0) #define XSCAN_Tab 23 #define XSCAN_Return 36 /* above right shift */ #define XSCAN_Control_L 37 #define XSCAN_Shift_L 50 #define XSCAN_slash 61 #define XSCAN_Shift_R 62 #define XSCAN_KP_Multiply 63 #define XSCAN_Alt_L 64 #define XSCAN_Caps_Lock 66 /* caps lock */ #define XSCAN_Num_Lock 77 /* num lock */ #define XSCAN_KP_7 79 #define XSCAN_KP_8 80 #define XSCAN_KP_9 81 #define XSCAN_KP_4 83 #define XSCAN_KP_6 85 #define XSCAN_KP_1 87 #define XSCAN_KP_2 88 #define XSCAN_KP_3 89 #define XSCAN_KP_0 90 #define XSCAN_KP_Decimal 91 /* "/ ?" on br keyboard */ #define XSCAN_97 97 #define XSCAN_Enter 104 /* on keypad */ #define XSCAN_Control_R 105 #define XSCAN_KP_Divide 106 #define XSCAN_Print 107 #define XSCAN_Alt_R 108 #define XSCAN_Home 110 #define XSCAN_Up 111 #define XSCAN_Prior 112 #define XSCAN_Left 113 #define XSCAN_Right 114 #define XSCAN_End 115 #define XSCAN_Down 116 #define XSCAN_Next 117 #define XSCAN_Insert 118 #define XSCAN_Delete 119 #define XSCAN_Pause 127 /* . on br keypad */ #define XSCAN_129 129 #define XSCAN_LWin 133 #define XSCAN_RWin 134 #define XSCAN_Menu 135 #define XSCAN_LMeta 156 #define XSCAN_RMeta 156 /******************************************************************************/ void KbdAddEvent_evdev(int down, int param1, int param2, int param3, int param4) { int rdp_scancode; int x_scancode; int is_ext; int is_spe; int type; LLOGLN(10, ("KbdAddEvent_evdev: down=0x%x param1=0x%x param2=0x%x " "param3=0x%x param4=0x%x", down, param1, param2, param3, param4)); if (g_keyboard == 0) { return; } type = down ? KeyPress : KeyRelease; rdp_scancode = param3; is_ext = param4 & 256; /* 0x100 */ is_spe = param4 & 512; /* 0x200 */ x_scancode = 0; switch (rdp_scancode) { case RDPSCAN_Caps_Lock: /* caps lock */ case RDPSCAN_Shift_L: /* left shift */ case RDPSCAN_Shift_R: /* right shift */ case RDPSCAN_Scroll_Lock: /* scroll lock */ x_scancode = rdp_scancode + MIN_KEY_CODE; if (x_scancode > 0) { /* left or right shift */ if ((rdp_scancode == RDPSCAN_Shift_L) || (rdp_scancode == RDPSCAN_Shift_R)) { g_shift_down = down ? x_scancode : 0; } rdpEnqueueKey(type, x_scancode); } break; case RDPSCAN_Alt: /* left - right alt button */ if (is_ext) { x_scancode = XSCAN_Alt_R; /* right alt button */ } else { x_scancode = XSCAN_Alt_L; /* left alt button */ } g_alt_down = down ? x_scancode : 0; rdpEnqueueKey(type, x_scancode); break; case RDPSCAN_Tab: /* tab */ if (!down && !g_tab_down) { check_keysa(); /* leave x_scancode 0 here, we don't want the tab key up */ } else { sendDownUpKeyEvent(type, XSCAN_Tab); } g_tab_down = down; break; case RDPSCAN_Control: /* left or right ctrl */ /* this is to handle special case with pause key sending control first */ if (is_spe) { if (down) { g_pause_spe = 1; /* leave x_scancode 0 here, we don't want the control key down */ } } else { x_scancode = is_ext ? XSCAN_Control_R : XSCAN_Control_L; g_ctrl_down = down ? x_scancode : 0; rdpEnqueueKey(type, x_scancode); } break; case RDPSCAN_Pause: /* Pause or Num Lock */ if (g_pause_spe) { x_scancode = XSCAN_Pause; if (!down) { g_pause_spe = 0; } } else { x_scancode = g_ctrl_down ? XSCAN_Pause : XSCAN_Num_Lock; } rdpEnqueueKey(type, x_scancode); break; case RDPSCAN_Return: /* Enter or Return */ x_scancode = is_ext ? XSCAN_Enter : XSCAN_Return; sendDownUpKeyEvent(type, x_scancode); break; case RDPSCAN_Slash: /* / */ x_scancode = is_ext ? XSCAN_KP_Divide : XSCAN_slash; sendDownUpKeyEvent(type, x_scancode); break; case RDPSCAN_KP_Multiply: /* * on KP or Print Screen */ x_scancode = is_ext ? XSCAN_Print : XSCAN_KP_Multiply; sendDownUpKeyEvent(type, x_scancode); break; case RDPSCAN_KP_7: /* 7 or Home */ x_scancode = is_ext ? XSCAN_Home : XSCAN_KP_7; sendDownUpKeyEvent(type, x_scancode); break; case RDPSCAN_KP_8: /* 8 or Up */ x_scancode = is_ext ? XSCAN_Up : XSCAN_KP_8; sendDownUpKeyEvent(type, x_scancode); break; case RDPSCAN_KP_9: /* 9 or PgUp */ x_scancode = is_ext ? XSCAN_Prior : XSCAN_KP_9; sendDownUpKeyEvent(type, x_scancode); break; case RDPSCAN_KP_4: /* 4 or Left */ x_scancode = is_ext ? XSCAN_Left : XSCAN_KP_4; sendDownUpKeyEvent(type, x_scancode); break; case RDPSCAN_KP_6: /* 6 or Right */ x_scancode = is_ext ? XSCAN_Right : XSCAN_KP_6; sendDownUpKeyEvent(type, x_scancode); break; case RDPSCAN_KP_1: /* 1 or End */ x_scancode = is_ext ? XSCAN_End : XSCAN_KP_1; sendDownUpKeyEvent(type, x_scancode); break; case RDPSCAN_KP_2: /* 2 or Down */ x_scancode = is_ext ? XSCAN_Down : XSCAN_KP_2; sendDownUpKeyEvent(type, x_scancode); break; case RDPSCAN_KP_3: /* 3 or PgDn */ x_scancode = is_ext ? XSCAN_Next : XSCAN_KP_3; sendDownUpKeyEvent(type, x_scancode); break; case RDPSCAN_KP_0: /* 0 or Insert */ x_scancode = is_ext ? XSCAN_Insert : XSCAN_KP_0; sendDownUpKeyEvent(type, x_scancode); break; case RDPSCAN_KP_Decimal: /* . or Delete */ x_scancode = is_ext ? XSCAN_Delete : XSCAN_KP_Decimal; sendDownUpKeyEvent(type, x_scancode); break; case RDPSCAN_LWin: /* left win key */ rdpEnqueueKey(type, XSCAN_LWin); break; case RDPSCAN_RWin: /* right win key */ rdpEnqueueKey(type, XSCAN_RWin); break; case RDPSCAN_Menu: /* menu key */ rdpEnqueueKey(type, XSCAN_Menu); break; case RDPSCAN_89: /* left meta */ rdpEnqueueKey(type, XSCAN_LMeta); break; case RDPSCAN_90: /* right meta */ rdpEnqueueKey(type, XSCAN_RMeta); break; case RDPSCAN_115: rdpEnqueueKey(type, XSCAN_97); /* "/ ?" on br keyboard */ break; case RDPSCAN_126: rdpEnqueueKey(type, XSCAN_129); /* . on br keypad */ break; default: x_scancode = rdp_scancode + MIN_KEY_CODE; if (x_scancode > 0) { LLOGLN(10, ("KbdAddEvent_evdev: rdp_scancode %d x_scancode %d", rdp_scancode, x_scancode)); sendDownUpKeyEvent(type, x_scancode); } break; } } xrdp-0.9.5/xorg/X11R7.6/rdp/rdpPolylines.h000644 001751 001751 00000002062 13125122134 017743 0ustar00metameta000000 000000 /* Copyright 2005-2013 Jay Sorg Permission to use, copy, modify, distribute, and sell this software and its documentation for any purpose is hereby granted without fee, provided that the above copyright notice appear in all copies and that both that copyright notice and this permission notice appear in supporting documentation. The above copyright notice and this permission notice shall be included in all copies or substantial portions of the Software. THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE OPEN GROUP BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. */ #ifndef __RDPPOLYLINES_H #define __RDPPOLYLINES_H void rdpPolylines(DrawablePtr pDrawable, GCPtr pGC, int mode, int npt, DDXPointPtr pptInit); #endif xrdp-0.9.5/xorg/X11R7.6/rdp/rdpdraw.h000644 001751 001751 00000003146 13125122134 016726 0ustar00metameta000000 000000 /* Copyright 2005-2013 Jay Sorg Permission to use, copy, modify, distribute, and sell this software and its documentation for any purpose is hereby granted without fee, provided that the above copyright notice appear in all copies and that both that copyright notice and this permission notice appear in supporting documentation. The above copyright notice and this permission notice shall be included in all copies or substantial portions of the Software. THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE OPEN GROUP BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. */ #ifndef __RDPDRAW_H #define __RDPDRAW_H /******************************************************************************/ #define GC_OP_PROLOGUE(_pGC) \ { \ priv = (rdpGCPtr)dixGetPrivateAddr(&(pGC->devPrivates), &g_rdpGCIndex); \ oldFuncs = _pGC->funcs; \ (_pGC)->funcs = priv->funcs; \ (_pGC)->ops = priv->ops; \ } /******************************************************************************/ #define GC_OP_EPILOGUE(_pGC) \ { \ priv->ops = (_pGC)->ops; \ (_pGC)->funcs = oldFuncs; \ (_pGC)->ops = &g_rdpGCOps; \ } int rdp_get_clip(RegionPtr pRegion, DrawablePtr pDrawable, GCPtr pGC); void GetTextBoundingBox(DrawablePtr pDrawable, FontPtr font, int x, int y, int n, BoxPtr pbox); #endif xrdp-0.9.5/xorg/X11R7.6/rdp/rdpPolyText8.h000644 001751 001751 00000002057 13125122134 017651 0ustar00metameta000000 000000 /* Copyright 2005-2013 Jay Sorg Permission to use, copy, modify, distribute, and sell this software and its documentation for any purpose is hereby granted without fee, provided that the above copyright notice appear in all copies and that both that copyright notice and this permission notice appear in supporting documentation. The above copyright notice and this permission notice shall be included in all copies or substantial portions of the Software. THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE OPEN GROUP BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. */ #ifndef __RDPPOLYTEXT8_H #define __RDPPOLYTEXT8_H int rdpPolyText8(DrawablePtr pDrawable, GCPtr pGC, int x, int y, int count, char* chars); #endif xrdp-0.9.5/xorg/X11R7.6/rdp/rdpPolyRectangle.c000644 001751 001751 00000022526 13125122134 020537 0ustar00metameta000000 000000 /* Copyright 2005-2013 Jay Sorg Permission to use, copy, modify, distribute, and sell this software and its documentation for any purpose is hereby granted without fee, provided that the above copyright notice appear in all copies and that both that copyright notice and this permission notice appear in supporting documentation. The above copyright notice and this permission notice shall be included in all copies or substantial portions of the Software. THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE OPEN GROUP BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. */ #include "rdp.h" #include "rdpdraw.h" #define LDEBUG 0 #define LOG_LEVEL 1 #define LLOG(_level, _args) \ do { if (_level < LOG_LEVEL) { ErrorF _args ; } } while (0) #define LLOGLN(_level, _args) \ do { if (_level < LOG_LEVEL) { ErrorF _args ; ErrorF("\n"); } } while (0) extern rdpScreenInfoRec g_rdpScreen; /* from rdpmain.c */ extern DevPrivateKeyRec g_rdpGCIndex; /* from rdpmain.c */ extern DevPrivateKeyRec g_rdpWindowIndex; /* from rdpmain.c */ extern DevPrivateKeyRec g_rdpPixmapIndex; /* from rdpmain.c */ extern int g_Bpp; /* from rdpmain.c */ extern ScreenPtr g_pScreen; /* from rdpmain.c */ extern Bool g_wrapPixmap; /* from rdpmain.c */ extern int g_do_dirty_os; /* in rdpmain.c */ extern int g_do_dirty_ons; /* in rdpmain.c */ extern rdpPixmapRec g_screenPriv; /* in rdpmain.c */ extern GCOps g_rdpGCOps; /* from rdpdraw.c */ extern int g_con_number; /* in rdpup.c */ /******************************************************************************/ static void rdpPolyRectangleOrg(DrawablePtr pDrawable, GCPtr pGC, int nrects, xRectangle *rects) { rdpGCPtr priv; GCFuncs *oldFuncs; GC_OP_PROLOGUE(pGC); pGC->ops->PolyRectangle(pDrawable, pGC, nrects, rects); GC_OP_EPILOGUE(pGC); } /******************************************************************************/ /* tested with pGC->lineWidth = 0, 1, 2, 4 and opcodes 3 and 6 */ void rdpPolyRectangle(DrawablePtr pDrawable, GCPtr pGC, int nrects, xRectangle *rects) { RegionRec clip_reg; RegionPtr fill_reg; int num_clips; int cd; int lw; int i; int j; int up; int down; int got_id; int dirty_type; int post_process; int reset_surface; xRectangle *regRects; xRectangle *r; xRectangle *rect1; BoxRec box; struct image_data id; WindowPtr pDstWnd; PixmapPtr pDstPixmap; rdpPixmapRec *pDstPriv; rdpPixmapRec *pDirtyPriv; LLOGLN(10, ("rdpPolyRectangle:")); /* make a copy of rects */ rect1 = (xRectangle *)g_malloc(sizeof(xRectangle) * nrects, 0); for (i = 0; i < nrects; i++) { rect1[i] = rects[i]; } /* do original call */ rdpPolyRectangleOrg(pDrawable, pGC, nrects, rects); dirty_type = 0; pDirtyPriv = 0; post_process = 0; reset_surface = 0; got_id = 0; if (pDrawable->type == DRAWABLE_PIXMAP) { pDstPixmap = (PixmapPtr)pDrawable; pDstPriv = GETPIXPRIV(pDstPixmap); if (xrdp_is_os(pDstPixmap, pDstPriv)) { post_process = 1; if (g_do_dirty_os) { LLOGLN(10, ("rdpPolyRectangle: getting dirty")); pDstPriv->is_dirty = 1; pDirtyPriv = pDstPriv; dirty_type = RDI_IMGLL; } else { rdpup_switch_os_surface(pDstPriv->rdpindex); reset_surface = 1; rdpup_get_pixmap_image_rect(pDstPixmap, &id); got_id = 1; } } } else { if (pDrawable->type == DRAWABLE_WINDOW) { pDstWnd = (WindowPtr)pDrawable; if (pDstWnd->viewable) { post_process = 1; if (g_do_dirty_ons) { LLOGLN(10, ("rdpPolyRectangle: getting dirty")); g_screenPriv.is_dirty = 1; pDirtyPriv = &g_screenPriv; dirty_type = RDI_IMGLL; } else { rdpup_get_screen_image_rect(&id); got_id = 1; } } } } if (!post_process) { g_free(rect1); return; } RegionInit(&clip_reg, NullBox, 0); cd = rdp_get_clip(&clip_reg, pDrawable, pGC); regRects = 0; if ((cd != 0) && (nrects > 0)) { regRects = (xRectangle *)g_malloc(nrects * 4 * sizeof(xRectangle), 0); lw = pGC->lineWidth; if (lw < 1) { lw = 1; } up = lw / 2; down = 1 + (lw - 1) / 2; for (i = 0; i < nrects; i++) { r = regRects + i * 4; r->x = (rect1[i].x + pDrawable->x) - up; r->y = (rect1[i].y + pDrawable->y) - up; r->width = rect1[i].width + up + down; r->height = lw; r++; r->x = (rect1[i].x + pDrawable->x) - up; r->y = (rect1[i].y + pDrawable->y) + down; r->width = lw; r->height = MAX(rect1[i].height - (up + down), 0); r++; r->x = ((rect1[i].x + rect1[i].width) + pDrawable->x) - up; r->y = (rect1[i].y + pDrawable->y) + down; r->width = lw; r->height = MAX(rect1[i].height - (up + down), 0); r++; r->x = (rect1[i].x + pDrawable->x) - up; r->y = ((rect1[i].y + rect1[i].height) + pDrawable->y) - up; r->width = rect1[i].width + up + down; r->height = lw; } } if (cd == 1) { if (regRects != 0) { if (dirty_type != 0) { fill_reg = RegionFromRects(nrects * 4, regRects, CT_NONE); if (pGC->lineStyle == LineSolid) { draw_item_add_fill_region(pDirtyPriv, fill_reg, pGC->fgPixel, pGC->alu); } else { draw_item_add_img_region(pDirtyPriv, fill_reg, GXcopy, dirty_type, TAG_POLYRECTANGLE); } RegionDestroy(fill_reg); } else if (got_id) { rdpup_begin_update(); if (pGC->lineStyle == LineSolid) { rdpup_set_fgcolor(pGC->fgPixel); rdpup_set_opcode(pGC->alu); for (i = 0; i < nrects * 4; i++) { r = regRects + i; rdpup_fill_rect(r->x, r->y, r->width, r->height); } rdpup_set_opcode(GXcopy); } else { for (i = 0; i < nrects * 4; i++) { r = regRects + i; rdpup_send_area(&id, r->x, r->y, r->width, r->height); } } rdpup_end_update(); } } } else if (cd == 2) { if (regRects != 0) { fill_reg = RegionFromRects(nrects * 4, regRects, CT_NONE); RegionIntersect(&clip_reg, &clip_reg, fill_reg); num_clips = REGION_NUM_RECTS(&clip_reg); if (num_clips > 0) { if (dirty_type != 0) { if (pGC->lineStyle == LineSolid) { draw_item_add_fill_region(pDirtyPriv, &clip_reg, pGC->fgPixel, pGC->alu); } else { draw_item_add_img_region(pDirtyPriv, &clip_reg, GXcopy, dirty_type, TAG_POLYRECTANGLE); } } else if (got_id) { rdpup_begin_update(); if (pGC->lineStyle == LineSolid) { rdpup_set_fgcolor(pGC->fgPixel); rdpup_set_opcode(pGC->alu); for (j = num_clips - 1; j >= 0; j--) { box = REGION_RECTS(&clip_reg)[j]; rdpup_fill_rect(box.x1, box.y1, box.x2 - box.x1, box.y2 - box.y1); } rdpup_set_opcode(GXcopy); } else { for (j = num_clips - 1; j >= 0; j--) { box = REGION_RECTS(&clip_reg)[j]; rdpup_send_area(&id, box.x1, box.y1, box.x2 - box.x1, box.y2 - box.y1); } } rdpup_end_update(); } } RegionDestroy(fill_reg); } } RegionUninit(&clip_reg); g_free(regRects); g_free(rect1); if (reset_surface) { rdpup_switch_os_surface(-1); } } xrdp-0.9.5/xorg/X11R7.6/rdp/rdpPolyArc.h000644 001751 001751 00000002017 13125122134 017336 0ustar00metameta000000 000000 /* Copyright 2005-2013 Jay Sorg Permission to use, copy, modify, distribute, and sell this software and its documentation for any purpose is hereby granted without fee, provided that the above copyright notice appear in all copies and that both that copyright notice and this permission notice appear in supporting documentation. The above copyright notice and this permission notice shall be included in all copies or substantial portions of the Software. THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE OPEN GROUP BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. */ #ifndef __RDPPOLYARC_H #define __RDPPOLYARC_H void rdpPolyArc(DrawablePtr pDrawable, GCPtr pGC, int narcs, xArc* parcs); #endif xrdp-0.9.5/xorg/X11R7.6/rdp/rdpinput.c000644 001751 001751 00000064006 13127114621 017131 0ustar00metameta000000 000000 /* Copyright 2005-2014 Jay Sorg Permission to use, copy, modify, distribute, and sell this software and its documentation for any purpose is hereby granted without fee, provided that the above copyright notice appear in all copies and that both that copyright notice and this permission notice appear in supporting documentation. The above copyright notice and this permission notice shall be included in all copies or substantial portions of the Software. THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE OPEN GROUP BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. keyboard and mouse stuff */ /* control notes */ /* rdesktop sends control before scan code 69 but it doesn't set the flags right so control down is used to determine between pause and num lock */ /* this should be fixed in rdesktop */ /* g_pause_spe flag for special control sent by ms client before scan code 69 is sent to tell that it's pause, not num lock. both pause and num lock use scan code 69 */ /* tab notes */ /* mstsc send tab up without a tab down to mark the mstsc has gained focus this should make sure control alt and shift are all up rdesktop does not do this */ /* this should be fixed in rdesktop */ #include "rdp.h" #include #include #include "rdpkeyboard.h" #include "rdpkeyboardbase.h" #include "rdpkeyboardevdev.h" #define LOG_LEVEL 1 #define LLOG(_level, _args) \ do { if (_level < LOG_LEVEL) { ErrorF _args ; } } while (0) #define LLOGLN(_level, _args) \ do { if (_level < LOG_LEVEL) { ErrorF _args ; ErrorF("\n"); } } while (0) extern ScreenPtr g_pScreen; /* in rdpmain.c */ extern DeviceIntPtr g_pointer; /* in rdpmain.c */ extern DeviceIntPtr g_keyboard; /* in rdpmain.c */ extern rdpScreenInfoRec g_rdpScreen; /* from rdpmain.c */ extern int g_shift_down; /* in rdpmain.c */ extern int g_alt_down; /* in rdpmain.c */ extern int g_ctrl_down; /* in rdpmain.c */ static int g_old_button_mask = 0; static int g_old_x = 0; static int g_old_y = 0; /* this is toggled every time num lock key is released, not like the above *_down vars */ static int g_scroll_lock_down = 0; static OsTimerPtr g_kbtimer = 0; static OsTimerPtr g_timer = 0; static int g_x = 0; static int g_y = 0; static int g_timer_scheduled = 0; static int g_delay_motion = 1; /* turn on or off */ static int g_use_evdev = 0; /* Copied from Xvnc/lib/font/util/utilbitmap.c */ static unsigned char g_reverse_byte[0x100] = { 0x00, 0x80, 0x40, 0xc0, 0x20, 0xa0, 0x60, 0xe0, 0x10, 0x90, 0x50, 0xd0, 0x30, 0xb0, 0x70, 0xf0, 0x08, 0x88, 0x48, 0xc8, 0x28, 0xa8, 0x68, 0xe8, 0x18, 0x98, 0x58, 0xd8, 0x38, 0xb8, 0x78, 0xf8, 0x04, 0x84, 0x44, 0xc4, 0x24, 0xa4, 0x64, 0xe4, 0x14, 0x94, 0x54, 0xd4, 0x34, 0xb4, 0x74, 0xf4, 0x0c, 0x8c, 0x4c, 0xcc, 0x2c, 0xac, 0x6c, 0xec, 0x1c, 0x9c, 0x5c, 0xdc, 0x3c, 0xbc, 0x7c, 0xfc, 0x02, 0x82, 0x42, 0xc2, 0x22, 0xa2, 0x62, 0xe2, 0x12, 0x92, 0x52, 0xd2, 0x32, 0xb2, 0x72, 0xf2, 0x0a, 0x8a, 0x4a, 0xca, 0x2a, 0xaa, 0x6a, 0xea, 0x1a, 0x9a, 0x5a, 0xda, 0x3a, 0xba, 0x7a, 0xfa, 0x06, 0x86, 0x46, 0xc6, 0x26, 0xa6, 0x66, 0xe6, 0x16, 0x96, 0x56, 0xd6, 0x36, 0xb6, 0x76, 0xf6, 0x0e, 0x8e, 0x4e, 0xce, 0x2e, 0xae, 0x6e, 0xee, 0x1e, 0x9e, 0x5e, 0xde, 0x3e, 0xbe, 0x7e, 0xfe, 0x01, 0x81, 0x41, 0xc1, 0x21, 0xa1, 0x61, 0xe1, 0x11, 0x91, 0x51, 0xd1, 0x31, 0xb1, 0x71, 0xf1, 0x09, 0x89, 0x49, 0xc9, 0x29, 0xa9, 0x69, 0xe9, 0x19, 0x99, 0x59, 0xd9, 0x39, 0xb9, 0x79, 0xf9, 0x05, 0x85, 0x45, 0xc5, 0x25, 0xa5, 0x65, 0xe5, 0x15, 0x95, 0x55, 0xd5, 0x35, 0xb5, 0x75, 0xf5, 0x0d, 0x8d, 0x4d, 0xcd, 0x2d, 0xad, 0x6d, 0xed, 0x1d, 0x9d, 0x5d, 0xdd, 0x3d, 0xbd, 0x7d, 0xfd, 0x03, 0x83, 0x43, 0xc3, 0x23, 0xa3, 0x63, 0xe3, 0x13, 0x93, 0x53, 0xd3, 0x33, 0xb3, 0x73, 0xf3, 0x0b, 0x8b, 0x4b, 0xcb, 0x2b, 0xab, 0x6b, 0xeb, 0x1b, 0x9b, 0x5b, 0xdb, 0x3b, 0xbb, 0x7b, 0xfb, 0x07, 0x87, 0x47, 0xc7, 0x27, 0xa7, 0x67, 0xe7, 0x17, 0x97, 0x57, 0xd7, 0x37, 0xb7, 0x77, 0xf7, 0x0f, 0x8f, 0x4f, 0xcf, 0x2f, 0xaf, 0x6f, 0xef, 0x1f, 0x9f, 0x5f, 0xdf, 0x3f, 0xbf, 0x7f, 0xff }; #if 0 /******************************************************************************/ static void rdpSendBell(void) { LLOGLN(10, ("rdpSendBell:")); } #endif /******************************************************************************/ void KbdDeviceOn(void) { LLOGLN(10, ("KbdDeviceOn:")); } /******************************************************************************/ void KbdDeviceOff(void) { LLOGLN(10, ("KbdDeviceOff:")); } /******************************************************************************/ void rdpBell(int volume, DeviceIntPtr pDev, pointer ctrl, int cls) { LLOGLN(0, ("rdpBell:")); } /******************************************************************************/ static CARD32 rdpInDeferredUpdateCallback(OsTimerPtr timer, CARD32 now, pointer arg) { LLOGLN(10, ("rdpInDeferredUpdateCallback:")); /* our keyboard device */ XkbSetRepeatKeys(g_keyboard, -1, AutoRepeatModeOff); /* the main one for the server */ XkbSetRepeatKeys(inputInfo.keyboard, -1, AutoRepeatModeOff); return 0; } /******************************************************************************/ void rdpChangeKeyboardControl(DeviceIntPtr pDev, KeybdCtrl *ctrl) { XkbControlsPtr ctrls; LLOGLN(0, ("rdpChangeKeyboardControl:")); ctrls = 0; if (pDev != 0) { if (pDev->key != 0) { if (pDev->key->xkbInfo != 0) { if (pDev->key->xkbInfo->desc != 0) { if (pDev->key->xkbInfo->desc->ctrls != 0) { ctrls = pDev->key->xkbInfo->desc->ctrls; } } } } } if (ctrls != 0) { if (ctrls->enabled_ctrls & XkbRepeatKeysMask) { LLOGLN(10, ("rdpChangeKeyboardControl: autoRepeat on")); /* schedule to turn off the autorepeat after 100 ms so any app * polling it will be happy it's on */ g_kbtimer = TimerSet(g_kbtimer, 0, 100, rdpInDeferredUpdateCallback, 0); } else { LLOGLN(10, ("rdpChangeKeyboardControl: autoRepeat off")); } } } /******************************************************************************/ /* 0x00000401 Arabic (101) 0x00000402 Bulgarian 0x00000404 Chinese (Traditional) - US Keyboard 0x00000405 Czech 0x00000406 Danish 0x00000407 German 0x00000408 Greek 0x00000409 US 0x0000040A Spanish 0x0000040B Finnish 0x0000040C French 0x0000040D Hebrew 0x0000040E Hungarian 0x0000040F Icelandic 0x00000410 Italian 0x00000411 Japanese 0x00000412 Korean 0x00000413 Dutch 0x00000414 Norwegian 0x00000415 Polish (Programmers) 0x00000416 Portuguese (Brazilian ABNT) 0x00000418 Romanian 0x00000419 Russian 0x0000041A Croatian 0x0000041B Slovak 0x0000041C Albanian 0x0000041D Swedish 0x0000041E Thai Kedmanee 0x0000041F Turkish Q 0x00000420 Urdu 0x00000422 Ukrainian 0x00000423 Belarusian 0x00000424 Slovenian 0x00000425 Estonian 0x00000426 Latvian 0x00000427 Lithuanian IBM 0x00000429 Farsi 0x0000042A Vietnamese 0x0000042B Armenian Eastern 0x0000042C Azeri Latin 0x0000042F FYRO Macedonian 0x00000437 Georgian 0x00000438 Faroese 0x00000439 Devanagari - INSCRIPT 0x0000043A Maltese 47-key 0x0000043B Norwegian with Sami 0x0000043F Kazakh 0x00000440 Kyrgyz Cyrillic 0x00000444 Tatar 0x00000445 Bengali 0x00000446 Punjabi 0x00000447 Gujarati 0x00000449 Tamil 0x0000044A Telugu 0x0000044B Kannada 0x0000044C Malayalam 0x0000044E Marathi 0x00000450 Mongolian Cyrillic 0x00000452 United Kingdom Extended 0x0000045A Syriac 0x00000461 Nepali 0x00000463 Pashto 0x00000465 Divehi Phonetic 0x0000046E Luxembourgish 0x00000481 Maori 0x00000804 Chinese (Simplified) - US Keyboard 0x00000807 Swiss German 0x00000809 United Kingdom 0x0000080A Latin American 0x0000080C Belgian French 0x00000813 Belgian (Period) 0x00000816 Portuguese 0x0000081A Serbian (Latin) 0x0000082C Azeri Cyrillic 0x0000083B Swedish with Sami 0x00000843 Uzbek Cyrillic 0x0000085D Inuktitut Latin 0x00000C0C Canadian French (legacy) 0x00000C1A Serbian (Cyrillic) 0x00001009 Canadian French 0x0000100C Swiss French 0x0000141A Bosnian 0x00001809 Irish 0x0000201A Bosnian Cyrillic */ /******************************************************************************/ int rdpLoadLayout(struct xrdp_client_info *client_info) { XkbRMLVOSet set; XkbSrvInfoPtr xkbi; XkbDescPtr xkb; KeySymsPtr keySyms; DeviceIntPtr pDev; KeyCode first_key; CARD8 num_keys; int keylayout = client_info->keylayout; LLOGLN(0, ("rdpLoadLayout: keylayout 0x%8.8x variant %s display %s", keylayout, client_info->variant, display)); memset(&set, 0, sizeof(set)); if (g_use_evdev) { set.rules = "evdev"; } else { set.rules = "base"; } set.model = "pc105"; set.layout = "us"; set.variant = ""; set.options = ""; if (strlen(client_info->model) > 0) { set.model = client_info->model; } if (strlen(client_info->variant) > 0) { set.variant = client_info->variant; } if (strlen(client_info->layout) > 0) { set.layout = client_info->layout; } if (strlen(client_info->options) > 0) { set.options = client_info->options; } retry: /* free some stuff so we can call InitKeyboardDeviceStruct again */ xkbi = g_keyboard->key->xkbInfo; xkb = xkbi->desc; XkbFreeKeyboard(xkb, 0, TRUE); free(xkbi); g_keyboard->key->xkbInfo = NULL; free(g_keyboard->kbdfeed); g_keyboard->kbdfeed = NULL; free(g_keyboard->key); g_keyboard->key = NULL; /* init keyboard and reload the map */ if (!InitKeyboardDeviceStruct(g_keyboard, &set, rdpBell, rdpChangeKeyboardControl)) { LLOGLN(0, ("rdpLoadLayout: InitKeyboardDeviceStruct failed")); return 1; } /* notify the X11 clients eg. X_ChangeKeyboardMapping */ keySyms = XkbGetCoreMap(g_keyboard); if (keySyms) { first_key = keySyms->minKeyCode; num_keys = (keySyms->maxKeyCode - keySyms->minKeyCode) + 1; XkbApplyMappingChange(g_keyboard, keySyms, first_key, num_keys, NULL, serverClient); for (pDev = inputInfo.devices; pDev; pDev = pDev->next) { if ((pDev->coreEvents || pDev == inputInfo.keyboard) && pDev->key) { XkbApplyMappingChange(pDev, keySyms, first_key, num_keys, NULL, serverClient); } } } else { /* sometimes, variant doesn't support all layouts */ set.variant = ""; goto retry; } return 0; } /******************************************************************************/ int rdpKeybdProc(DeviceIntPtr pDevice, int onoff) { DevicePtr pDev; XkbRMLVOSet set; int ok; LLOGLN(10, ("rdpKeybdProc:")); pDev = (DevicePtr)pDevice; switch (onoff) { case DEVICE_INIT: LLOGLN(10, ("rdpKeybdProc: DEVICE_INIT")); memset(&set, 0, sizeof(set)); if (g_use_evdev) { set.rules = "evdev"; } else { set.rules = "base"; } set.model = "pc105"; set.layout = "us"; set.variant = ""; set.options = ""; ok = InitKeyboardDeviceStruct(pDevice, &set, rdpBell, rdpChangeKeyboardControl); LLOGLN(10, ("rdpKeybdProc: InitKeyboardDeviceStruct %d", ok)); break; case DEVICE_ON: LLOGLN(10, ("rdpKeybdProc: DEVICE_ON")); pDev->on = 1; KbdDeviceOn(); break; case DEVICE_OFF: LLOGLN(10, ("rdpKeybdProc: DEVICE_OFF")); pDev->on = 0; KbdDeviceOff(); break; case DEVICE_CLOSE: LLOGLN(10, ("rdpKeybdProc: DEVICE_CLOSE")); if (pDev->on) { pDev->on = 0; KbdDeviceOff(); } break; } return Success; } /******************************************************************************/ void PtrDeviceControl(DeviceIntPtr dev, PtrCtrl *ctrl) { LLOGLN(10, ("PtrDeviceControl:")); } /******************************************************************************/ void PtrDeviceInit(void) { LLOGLN(10, ("PtrDeviceInit:")); } /******************************************************************************/ void PtrDeviceOn(DeviceIntPtr pDev) { LLOGLN(10, ("PtrDeviceOn:")); } /******************************************************************************/ void PtrDeviceOff(void) { LLOGLN(10, ("PtrDeviceOff:")); } /******************************************************************************/ static void rdpMouseCtrl(DeviceIntPtr pDevice, PtrCtrl *pCtrl) { LLOGLN(0, ("rdpMouseCtrl:")); } /******************************************************************************/ int rdpMouseProc(DeviceIntPtr pDevice, int onoff) { BYTE map[8]; DevicePtr pDev; Atom btn_labels[8]; Atom axes_labels[2]; LLOGLN(10, ("rdpMouseProc:")); pDev = (DevicePtr)pDevice; switch (onoff) { case DEVICE_INIT: PtrDeviceInit(); map[0] = 0; map[1] = 1; map[2] = 2; map[3] = 3; map[4] = 4; map[5] = 5; map[6] = 6; map[7] = 7; btn_labels[0] = XIGetKnownProperty(BTN_LABEL_PROP_BTN_LEFT); btn_labels[1] = XIGetKnownProperty(BTN_LABEL_PROP_BTN_MIDDLE); btn_labels[2] = XIGetKnownProperty(BTN_LABEL_PROP_BTN_RIGHT); btn_labels[3] = XIGetKnownProperty(BTN_LABEL_PROP_BTN_WHEEL_UP); btn_labels[4] = XIGetKnownProperty(BTN_LABEL_PROP_BTN_WHEEL_DOWN); btn_labels[5] = XIGetKnownProperty(BTN_LABEL_PROP_BTN_HWHEEL_LEFT); btn_labels[6] = XIGetKnownProperty(BTN_LABEL_PROP_BTN_HWHEEL_RIGHT); axes_labels[0] = XIGetKnownProperty(AXIS_LABEL_PROP_REL_X); axes_labels[1] = XIGetKnownProperty(AXIS_LABEL_PROP_REL_Y); InitPointerDeviceStruct(pDev, map, 7, btn_labels, rdpMouseCtrl, GetMotionHistorySize(), 2, axes_labels); break; case DEVICE_ON: pDev->on = 1; PtrDeviceOn(pDevice); break; case DEVICE_OFF: pDev->on = 0; PtrDeviceOff(); break; case DEVICE_CLOSE: if (pDev->on) { PtrDeviceOff(); } break; } return Success; } /******************************************************************************/ Bool rdpCursorOffScreen(ScreenPtr *ppScreen, int *x, int *y) { LLOGLN(10, ("rdpCursorOffScreen:")); return 0; } /******************************************************************************/ void rdpCrossScreen(ScreenPtr pScreen, Bool entering) { LLOGLN(10, ("rdpCrossScreen:")); } /******************************************************************************/ void rdpPointerWarpCursor(DeviceIntPtr pDev, ScreenPtr pScr, int x, int y) { LLOGLN(0, ("rdpPointerWarpCursor:")); miPointerWarpCursor(pDev, pScr, x, y); } /******************************************************************************/ void rdpPointerEnqueueEvent(DeviceIntPtr pDev, InternalEvent *event) { LLOGLN(0, ("rdpPointerEnqueueEvent:")); } /******************************************************************************/ void rdpPointerNewEventScreen(DeviceIntPtr pDev, ScreenPtr pScr, Bool fromDIX) { LLOGLN(0, ("rdpPointerNewEventScreen:")); } /******************************************************************************/ Bool rdpSpriteRealizeCursor(DeviceIntPtr pDev, ScreenPtr pScr, CursorPtr pCurs) { LLOGLN(10, ("rdpSpriteRealizeCursor:")); return 1; } /******************************************************************************/ Bool rdpSpriteUnrealizeCursor(DeviceIntPtr pDev, ScreenPtr pScr, CursorPtr pCurs) { LLOGLN(10, ("rdpSpriteUnrealizeCursor:")); return 1; } /******************************************************************************/ int get_pixel_safe(char *data, int x, int y, int width, int height, int bpp) { int start; int shift; int c; unsigned int *src32; if (x < 0) { return 0; } if (y < 0) { return 0; } if (x >= width) { return 0; } if (y >= height) { return 0; } if (bpp == 1) { width = (width + 7) / 8; start = (y * width) + x / 8; shift = x % 8; c = (unsigned char)(data[start]); #if (X_BYTE_ORDER == X_LITTLE_ENDIAN) return (g_reverse_byte[c] & (0x80 >> shift)) != 0; #else return (c & (0x80 >> shift)) != 0; #endif } else if (bpp == 32) { src32 = (unsigned int*)data; return src32[y * width + x]; } return 0; } /******************************************************************************/ void set_pixel_safe(char *data, int x, int y, int width, int height, int bpp, int pixel) { int start; int shift; unsigned int *dst32; if (x < 0) { return; } if (y < 0) { return; } if (x >= width) { return; } if (y >= height) { return; } if (bpp == 1) { width = (width + 7) / 8; start = (y * width) + x / 8; shift = x % 8; if (pixel & 1) { data[start] = data[start] | (0x80 >> shift); } else { data[start] = data[start] & ~(0x80 >> shift); } } else if (bpp == 24) { *(data + (3 * (y * width + x)) + 0) = pixel >> 0; *(data + (3 * (y * width + x)) + 1) = pixel >> 8; *(data + (3 * (y * width + x)) + 2) = pixel >> 16; } else if (bpp == 32) { dst32 = (unsigned int*)data; dst32[y * width + x] = pixel; } } /******************************************************************************/ void rdpSpriteSetCursor(DeviceIntPtr pDev, ScreenPtr pScr, CursorPtr pCurs, int x, int y) { char cur_data[32 * (32 * 4)]; char cur_mask[32 * (32 / 8)]; char *mask; char *data; int i; int j; int w; int h; int p; int xhot; int yhot; int paddedRowBytes; int fgcolor; int bgcolor; int bpp; if (pCurs == 0) { return; } if (pCurs->bits == 0) { return; } w = pCurs->bits->width; h = pCurs->bits->height; if ((pCurs->bits->argb != 0) && (g_rdpScreen.client_info.pointer_flags & 1)) { bpp = 32; paddedRowBytes = PixmapBytePad(w, 32); xhot = pCurs->bits->xhot; yhot = pCurs->bits->yhot; data = (char *)(pCurs->bits->argb); memset(cur_data, 0, sizeof(cur_data)); memset(cur_mask, 0, sizeof(cur_mask)); for (j = 0; j < 32; j++) { for (i = 0; i < 32; i++) { p = get_pixel_safe(data, i, j, paddedRowBytes / 4, h, 32); set_pixel_safe(cur_data, i, 31 - j, 32, 32, 32, p); } } } else { bpp = 0; paddedRowBytes = PixmapBytePad(w, 1); xhot = pCurs->bits->xhot; yhot = pCurs->bits->yhot; data = (char *)(pCurs->bits->source); mask = (char *)(pCurs->bits->mask); fgcolor = (((pCurs->foreRed >> 8) & 0xff) << 16) | (((pCurs->foreGreen >> 8) & 0xff) << 8) | ((pCurs->foreBlue >> 8) & 0xff); bgcolor = (((pCurs->backRed >> 8) & 0xff) << 16) | (((pCurs->backGreen >> 8) & 0xff) << 8) | ((pCurs->backBlue >> 8) & 0xff); memset(cur_data, 0, sizeof(cur_data)); memset(cur_mask, 0, sizeof(cur_mask)); for (j = 0; j < 32; j++) { for (i = 0; i < 32; i++) { p = get_pixel_safe(mask, i, j, paddedRowBytes * 8, h, 1); set_pixel_safe(cur_mask, i, 31 - j, 32, 32, 1, !p); if (p != 0) { p = get_pixel_safe(data, i, j, paddedRowBytes * 8, h, 1); p = p ? fgcolor : bgcolor; set_pixel_safe(cur_data, i, 31 - j, 32, 32, 24, p); } } } } rdpup_begin_update(); rdpup_set_cursor_ex(xhot, yhot, cur_data, cur_mask, bpp); rdpup_end_update(); } /******************************************************************************/ void rdpSpriteMoveCursor(DeviceIntPtr pDev, ScreenPtr pScr, int x, int y) { LLOGLN(10, ("rdpSpriteMoveCursor:")); } /******************************************************************************/ Bool rdpSpriteDeviceCursorInitialize(DeviceIntPtr pDev, ScreenPtr pScr) { LLOGLN(0, ("rdpSpriteDeviceCursorInitialize:")); return 1; } /******************************************************************************/ void rdpSpriteDeviceCursorCleanup(DeviceIntPtr pDev, ScreenPtr pScr) { LLOGLN(0, ("rdpSpriteDeviceCursorCleanup:")); } /******************************************************************************/ static void rdpEnqueueMotion(int x, int y) { int i; int n; int valuators[2]; EventListPtr rdp_events; xEvent *pev; LLOGLN(10, ("rdpEnqueueMotion: x %d y %d", x, y)); # if 0 if (x < 128) { rdpup_begin_update(); rdpup_send_area(0, 0, 0, 1024, 768); rdpup_end_update(); } #endif miPointerSetPosition(g_pointer, &x, &y); valuators[0] = x; valuators[1] = y; GetEventList(&rdp_events); n = GetPointerEvents(rdp_events, g_pointer, MotionNotify, 0, POINTER_ABSOLUTE | POINTER_SCREEN, 0, 2, valuators); for (i = 0; i < n; i++) { pev = (rdp_events + i)->event; mieqEnqueue(g_pointer, (InternalEvent *)pev); } } /******************************************************************************/ static void rdpEnqueueButton(int type, int buttons) { int i; int n; EventListPtr rdp_events; xEvent *pev; LLOGLN(10, ("rdpEnqueueButton:")); i = GetEventList(&rdp_events); n = GetPointerEvents(rdp_events, g_pointer, type, buttons, 0, 0, 0, 0); for (i = 0; i < n; i++) { pev = (rdp_events + i)->event; mieqEnqueue(g_pointer, (InternalEvent *)pev); } } /******************************************************************************/ static CARD32 rdpDeferredInputCallback(OsTimerPtr timer, CARD32 now, pointer arg) { LLOGLN(10, ("rdpDeferredInputCallback:")); g_timer_scheduled = 0; if ((g_old_x != g_x) || (g_old_y != g_y)) { rdpEnqueueMotion(g_x, g_y); g_old_x = g_x; g_old_y = g_x; } return 0; } /******************************************************************************/ void PtrAddEvent(int buttonMask, int x, int y) { int i; int type; int buttons; int send_now; LLOGLN(10, ("PtrAddEvent: x %d y %d", x, y)); if (g_pointer == 0) { return; } send_now = (buttonMask ^ g_old_button_mask) || (g_delay_motion == 0); LLOGLN(10, ("PtrAddEvent: send_now %d g_timer_scheduled %d", send_now, g_timer_scheduled)); if (send_now) { if (g_timer_scheduled) { g_timer_scheduled = 0; TimerCancel(g_timer); } if ((g_old_x != x) || (g_old_y != y)) { rdpEnqueueMotion(x, y); g_old_x = x; g_old_y = y; } for (i = 0; i < 5; i++) { if ((buttonMask ^ g_old_button_mask) & (1 << i)) { if (buttonMask & (1 << i)) { type = ButtonPress; buttons = i + 1; rdpEnqueueButton(type, buttons); } else { type = ButtonRelease; buttons = i + 1; rdpEnqueueButton(type, buttons); } } } g_old_button_mask = buttonMask; } else { g_x = x; g_y = y; if (!g_timer_scheduled) { g_timer_scheduled = 1; g_timer = TimerSet(g_timer, 0, 60, rdpDeferredInputCallback, 0); } } } /******************************************************************************/ void KbdAddEvent(int down, int param1, int param2, int param3, int param4) { if (g_use_evdev) { KbdAddEvent_evdev(down, param1, param2, param3, param4); } else { KbdAddEvent_base(down, param1, param2, param3, param4); } } /******************************************************************************/ /* notes - scroll lock doesn't seem to be a modifier in X */ void KbdSync(int param1) { int xkb_state; if (g_keyboard == 0) { return; } xkb_state = XkbStateFieldFromRec(&(g_keyboard->key->xkbInfo->state)); if ((!(xkb_state & 0x02)) != (!(param1 & 4))) /* caps lock */ { LLOGLN(0, ("KbdSync: toggling caps lock")); KbdAddEvent(1, 58, 0, 58, 0); KbdAddEvent(0, 58, 49152, 58, 49152); } if ((!(xkb_state & 0x10)) != (!(param1 & 2))) /* num lock */ { LLOGLN(0, ("KbdSync: toggling num lock")); KbdAddEvent(1, 69, 0, 69, 0); KbdAddEvent(0, 69, 49152, 69, 49152); } if ((!(g_scroll_lock_down)) != (!(param1 & 1))) /* scroll lock */ { LLOGLN(0, ("KbdSync: toggling scroll lock")); KbdAddEvent(1, 70, 0, 70, 0); KbdAddEvent(0, 70, 49152, 70, 49152); } } xrdp-0.9.5/xorg/X11R7.6/rdp/rdpPolyFillArc.h000644 001751 001751 00000002033 13125122134 020143 0ustar00metameta000000 000000 /* Copyright 2005-2013 Jay Sorg Permission to use, copy, modify, distribute, and sell this software and its documentation for any purpose is hereby granted without fee, provided that the above copyright notice appear in all copies and that both that copyright notice and this permission notice appear in supporting documentation. The above copyright notice and this permission notice shall be included in all copies or substantial portions of the Software. THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE OPEN GROUP BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. */ #ifndef __RDPPOLYFILLARC_H #define __RDPPOLYFILLARC_H void rdpPolyFillArc(DrawablePtr pDrawable, GCPtr pGC, int narcs, xArc* parcs); #endif xrdp-0.9.5/xorg/X11R7.6/rdp/rdpImageText8.c000644 001751 001751 00000013411 13125122134 017737 0ustar00metameta000000 000000 /* Copyright 2005-2013 Jay Sorg Permission to use, copy, modify, distribute, and sell this software and its documentation for any purpose is hereby granted without fee, provided that the above copyright notice appear in all copies and that both that copyright notice and this permission notice appear in supporting documentation. The above copyright notice and this permission notice shall be included in all copies or substantial portions of the Software. THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE OPEN GROUP BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. */ #include "rdp.h" #include "rdpdraw.h" #define LDEBUG 0 #define LOG_LEVEL 1 #define LLOG(_level, _args) \ do { if (_level < LOG_LEVEL) { ErrorF _args ; } } while (0) #define LLOGLN(_level, _args) \ do { if (_level < LOG_LEVEL) { ErrorF _args ; ErrorF("\n"); } } while (0) extern rdpScreenInfoRec g_rdpScreen; /* from rdpmain.c */ extern DevPrivateKeyRec g_rdpGCIndex; /* from rdpmain.c */ extern DevPrivateKeyRec g_rdpWindowIndex; /* from rdpmain.c */ extern DevPrivateKeyRec g_rdpPixmapIndex; /* from rdpmain.c */ extern int g_Bpp; /* from rdpmain.c */ extern ScreenPtr g_pScreen; /* from rdpmain.c */ extern Bool g_wrapPixmap; /* from rdpmain.c */ extern int g_do_dirty_os; /* in rdpmain.c */ extern int g_do_dirty_ons; /* in rdpmain.c */ extern rdpPixmapRec g_screenPriv; /* in rdpmain.c */ extern GCOps g_rdpGCOps; /* from rdpdraw.c */ extern int g_con_number; /* in rdpup.c */ /******************************************************************************/ void rdpImageText8Org(DrawablePtr pDrawable, GCPtr pGC, int x, int y, int count, char *chars) { rdpGCPtr priv; GCFuncs *oldFuncs; GC_OP_PROLOGUE(pGC); pGC->ops->ImageText8(pDrawable, pGC, x, y, count, chars); GC_OP_EPILOGUE(pGC); } /******************************************************************************/ void rdpImageText8(DrawablePtr pDrawable, GCPtr pGC, int x, int y, int count, char *chars) { RegionRec reg; RegionRec reg1; int num_clips; int cd; int j; int got_id; int dirty_type; int post_process; int reset_surface; BoxRec box; struct image_data id; WindowPtr pDstWnd; PixmapPtr pDstPixmap; rdpPixmapRec *pDstPriv; rdpPixmapRec *pDirtyPriv; LLOGLN(10, ("rdpImageText8:")); if (count != 0) { GetTextBoundingBox(pDrawable, pGC->font, x, y, count, &box); } /* do original call */ rdpImageText8Org(pDrawable, pGC, x, y, count, chars); dirty_type = 0; pDirtyPriv = 0; post_process = 0; reset_surface = 0; got_id = 0; if (pDrawable->type == DRAWABLE_PIXMAP) { pDstPixmap = (PixmapPtr)pDrawable; pDstPriv = GETPIXPRIV(pDstPixmap); if (xrdp_is_os(pDstPixmap, pDstPriv)) { post_process = 1; if (g_do_dirty_os) { LLOGLN(10, ("rdpImageText8: getting dirty")); pDstPriv->is_dirty = 1; pDirtyPriv = pDstPriv; dirty_type = RDI_IMGLL; } else { rdpup_switch_os_surface(pDstPriv->rdpindex); reset_surface = 1; rdpup_get_pixmap_image_rect(pDstPixmap, &id); got_id = 1; } } } else { if (pDrawable->type == DRAWABLE_WINDOW) { pDstWnd = (WindowPtr)pDrawable; if (pDstWnd->viewable) { post_process = 1; if (g_do_dirty_ons) { LLOGLN(10, ("rdpImageText8: getting dirty")); g_screenPriv.is_dirty = 1; pDirtyPriv = &g_screenPriv; dirty_type = RDI_IMGLL; } else { rdpup_get_screen_image_rect(&id); got_id = 1; } } } } if (!post_process) { return; } RegionInit(®, NullBox, 0); if (count == 0) { cd = 0; } else { cd = rdp_get_clip(®, pDrawable, pGC); } if (cd == 1) { if (dirty_type != 0) { RegionInit(®1, &box, 0); draw_item_add_img_region(pDirtyPriv, ®1, GXcopy, dirty_type, TAG_IMAGETEXT8); RegionUninit(®1); } else if (got_id) { rdpup_begin_update(); rdpup_send_area(&id, box.x1, box.y1, box.x2 - box.x1, box.y2 - box.y1); rdpup_end_update(); } } else if (cd == 2) { RegionInit(®1, &box, 0); RegionIntersect(®, ®, ®1); num_clips = REGION_NUM_RECTS(®); if (num_clips > 0) { if (dirty_type != 0) { draw_item_add_img_region(pDirtyPriv, ®, GXcopy, dirty_type, TAG_IMAGETEXT8); } else if (got_id) { rdpup_begin_update(); for (j = num_clips - 1; j >= 0; j--) { box = REGION_RECTS(®)[j]; rdpup_send_area(&id, box.x1, box.y1, box.x2 - box.x1, box.y2 - box.y1); } rdpup_end_update(); } } RegionUninit(®1); } RegionUninit(®); if (reset_surface) { rdpup_switch_os_surface(-1); } return; } xrdp-0.9.5/xorg/X11R7.6/rdp/rdpPolySegment.c000644 001751 001751 00000015722 13125122134 020235 0ustar00metameta000000 000000 /* Copyright 2005-2013 Jay Sorg Permission to use, copy, modify, distribute, and sell this software and its documentation for any purpose is hereby granted without fee, provided that the above copyright notice appear in all copies and that both that copyright notice and this permission notice appear in supporting documentation. The above copyright notice and this permission notice shall be included in all copies or substantial portions of the Software. THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE OPEN GROUP BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. */ #include "rdp.h" #include "rdpdraw.h" #define LDEBUG 0 #define LOG_LEVEL 1 #define LLOG(_level, _args) \ do { if (_level < LOG_LEVEL) { ErrorF _args ; } } while (0) #define LLOGLN(_level, _args) \ do { if (_level < LOG_LEVEL) { ErrorF _args ; ErrorF("\n"); } } while (0) extern rdpScreenInfoRec g_rdpScreen; /* from rdpmain.c */ extern DevPrivateKeyRec g_rdpGCIndex; /* from rdpmain.c */ extern DevPrivateKeyRec g_rdpWindowIndex; /* from rdpmain.c */ extern DevPrivateKeyRec g_rdpPixmapIndex; /* from rdpmain.c */ extern int g_Bpp; /* from rdpmain.c */ extern ScreenPtr g_pScreen; /* from rdpmain.c */ extern Bool g_wrapPixmap; /* from rdpmain.c */ extern int g_do_dirty_os; /* in rdpmain.c */ extern int g_do_dirty_ons; /* in rdpmain.c */ extern rdpPixmapRec g_screenPriv; /* in rdpmain.c */ extern GCOps g_rdpGCOps; /* from rdpdraw.c */ extern int g_con_number; /* in rdpup.c */ /******************************************************************************/ void rdpPolySegmentOrg(DrawablePtr pDrawable, GCPtr pGC, int nseg, xSegment *pSegs) { rdpGCPtr priv; GCFuncs *oldFuncs; GC_OP_PROLOGUE(pGC); pGC->ops->PolySegment(pDrawable, pGC, nseg, pSegs); GC_OP_EPILOGUE(pGC); } /******************************************************************************/ void rdpPolySegment(DrawablePtr pDrawable, GCPtr pGC, int nseg, xSegment *pSegs) { RegionRec clip_reg; int cd; int i; int j; int got_id; int dirty_type; int post_process; int reset_surface; xSegment *segs; BoxRec box; struct image_data id; WindowPtr pDstWnd; PixmapPtr pDstPixmap; rdpPixmapRec *pDstPriv; rdpPixmapRec *pDirtyPriv; LLOGLN(10, ("rdpPolySegment:")); LLOGLN(10, (" nseg %d", nseg)); segs = 0; if (nseg) /* get the rects */ { segs = (xSegment *)g_malloc(nseg * sizeof(xSegment), 0); for (i = 0; i < nseg; i++) { segs[i].x1 = pSegs[i].x1 + pDrawable->x; segs[i].y1 = pSegs[i].y1 + pDrawable->y; segs[i].x2 = pSegs[i].x2 + pDrawable->x; segs[i].y2 = pSegs[i].y2 + pDrawable->y; } } /* do original call */ rdpPolySegmentOrg(pDrawable, pGC, nseg, pSegs); dirty_type = 0; pDirtyPriv = 0; post_process = 0; reset_surface = 0; got_id = 0; if (pDrawable->type == DRAWABLE_PIXMAP) { pDstPixmap = (PixmapPtr)pDrawable; pDstPriv = GETPIXPRIV(pDstPixmap); if (xrdp_is_os(pDstPixmap, pDstPriv)) { post_process = 1; if (g_do_dirty_os) { LLOGLN(10, ("rdpPolySegment: getting dirty")); pDstPriv->is_dirty = 1; pDirtyPriv = pDstPriv; dirty_type = RDI_IMGLL; } else { rdpup_switch_os_surface(pDstPriv->rdpindex); reset_surface = 1; rdpup_get_pixmap_image_rect(pDstPixmap, &id); got_id = 1; } } } else { if (pDrawable->type == DRAWABLE_WINDOW) { pDstWnd = (WindowPtr)pDrawable; if (pDstWnd->viewable) { post_process = 1; if (g_do_dirty_ons) { LLOGLN(10, ("rdpPolySegment: getting dirty")); g_screenPriv.is_dirty = 1; pDirtyPriv = &g_screenPriv; dirty_type = RDI_IMGLL; } else { rdpup_get_screen_image_rect(&id); got_id = 1; } } } } if (!post_process) { g_free(segs); return; } RegionInit(&clip_reg, NullBox, 0); cd = rdp_get_clip(&clip_reg, pDrawable, pGC); LLOGLN(10, ("rdpPolySegment: cd %d", cd)); if (cd == 1) /* no clip */ { if (segs != 0) { if (dirty_type != 0) { RegionUninit(&clip_reg); RegionInit(&clip_reg, NullBox, 0); RegionAroundSegs(&clip_reg, segs, nseg); draw_item_add_line_region(pDirtyPriv, &clip_reg, pGC->fgPixel, pGC->alu, pGC->lineWidth, segs, nseg, 1); } else if (got_id) { rdpup_begin_update(); rdpup_set_fgcolor(pGC->fgPixel); rdpup_set_opcode(pGC->alu); rdpup_set_pen(0, pGC->lineWidth); for (i = 0; i < nseg; i++) { rdpup_draw_line(segs[i].x1, segs[i].y1, segs[i].x2, segs[i].y2); } rdpup_set_opcode(GXcopy); rdpup_end_update(); } } } else if (cd == 2) /* clip */ { if (segs != 0) { if (dirty_type != 0) { draw_item_add_line_region(pDirtyPriv, &clip_reg, pGC->fgPixel, pGC->alu, pGC->lineWidth, segs, nseg, 1); } else if (got_id) { rdpup_begin_update(); rdpup_set_fgcolor(pGC->fgPixel); rdpup_set_opcode(pGC->alu); rdpup_set_pen(0, pGC->lineWidth); for (j = REGION_NUM_RECTS(&clip_reg) - 1; j >= 0; j--) { box = REGION_RECTS(&clip_reg)[j]; rdpup_set_clip(box.x1, box.y1, box.x2 - box.x1, box.y2 - box.y1); for (i = 0; i < nseg; i++) { rdpup_draw_line(segs[i].x1, segs[i].y1, segs[i].x2, segs[i].y2); LLOGLN(10, (" %d %d %d %d", segs[i].x1, segs[i].y1, segs[i].x2, segs[i].y2)); } } rdpup_reset_clip(); rdpup_set_opcode(GXcopy); rdpup_end_update(); } } } g_free(segs); RegionUninit(&clip_reg); if (reset_surface) { rdpup_switch_os_surface(-1); } } xrdp-0.9.5/xorg/X11R7.6/rdp/.gitignore000644 001751 001751 00000000007 13133557325 017110 0ustar00metameta000000 000000 X11rdp xrdp-0.9.5/xorg/X11R7.6/rdp/rdpglyph.h000644 001751 001751 00000003172 13125122134 017113 0ustar00metameta000000 000000 /* Copyright 2012-2013 Jay Sorg Permission to use, copy, modify, distribute, and sell this software and its documentation for any purpose is hereby granted without fee, provided that the above copyright notice appear in all copies and that both that copyright notice and this permission notice appear in supporting documentation. The above copyright notice and this permission notice shall be included in all copies or substantial portions of the Software. THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE OPEN GROUP BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. */ #ifndef __RDPGLYPH_H #define __RDPGLYPH_H struct rdp_font_char { int offset; /* x */ int baseline; /* y */ int width; /* cx */ int height; /* cy */ int incby; int bpp; char* data; int data_bytes; }; struct rdp_text { RegionPtr reg; int font; int x; int y; int flags; int mixmode; char data[256]; int data_bytes; struct rdp_font_char* chars[256]; int num_chars; struct rdp_text* next; }; int delete_rdp_text(struct rdp_text* rtext); int rdp_text_chars_to_data(struct rdp_text* rtext); void rdpGlyphs(CARD8 op, PicturePtr pSrc, PicturePtr pDst, PictFormatPtr maskFormat, INT16 xSrc, INT16 ySrc, int nlists, GlyphListPtr lists, GlyphPtr* glyphs); int rdpGlyphInit(void); #endif xrdp-0.9.5/xorg/X11R7.6/rdp/rdprandr.h000644 001751 001751 00000004334 13127114621 017103 0ustar00metameta000000 000000 /* Copyright 2011-2013 Jay Sorg Permission to use, copy, modify, distribute, and sell this software and its documentation for any purpose is hereby granted without fee, provided that the above copyright notice appear in all copies and that both that copyright notice and this permission notice appear in supporting documentation. The above copyright notice and this permission notice shall be included in all copies or substantial portions of the Software. THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE OPEN GROUP BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. */ #ifndef _RDPRANDR_H #define _RDPRANDR_H Bool rdpRRRegisterSize(ScreenPtr pScreen, int width, int height); Bool rdpRRGetInfo(ScreenPtr pScreen, Rotation* pRotations); Bool rdpRRSetConfig(ScreenPtr pScreen, Rotation rotateKind, int rate, RRScreenSizePtr pSize); Bool rdpRRScreenSetSize(ScreenPtr pScreen, CARD16 width, CARD16 height, CARD32 mmWidth, CARD32 mmHeight); Bool rdpRRCrtcSet(ScreenPtr pScreen, RRCrtcPtr crtc, RRModePtr mode, int x, int y, Rotation rotation, int numOutputs, RROutputPtr* outputs); Bool rdpRRCrtcSetGamma(ScreenPtr pScreen, RRCrtcPtr crtc); Bool rdpRRCrtcGetGamma(ScreenPtr pScreen, RRCrtcPtr crtc); Bool rdpRROutputSetProperty(ScreenPtr pScreen, RROutputPtr output, Atom property, RRPropertyValuePtr value); Bool rdpRROutputValidateMode(ScreenPtr pScreen, RROutputPtr output, RRModePtr mode); void rdpRRModeDestroy(ScreenPtr pScreen, RRModePtr mode); Bool rdpRROutputGetProperty(ScreenPtr pScreen, RROutputPtr output, Atom property); Bool rdpRRGetPanning(ScreenPtr pScrn, RRCrtcPtr crtc, BoxPtr totalArea, BoxPtr trackingArea, INT16* border); Bool rdpRRSetPanning(ScreenPtr pScrn, RRCrtcPtr crtc, BoxPtr totalArea, BoxPtr trackingArea, INT16* border); int rdpRRSetRdpOutputs(void); #endif xrdp-0.9.5/xorg/X11R7.6/rdp/rdpkeyboard.c000644 001751 001751 00000005134 13125122134 017563 0ustar00metameta000000 000000 /* Copyright 2005-2014 Jay Sorg Permission to use, copy, modify, distribute, and sell this software and its documentation for any purpose is hereby granted without fee, provided that the above copyright notice appear in all copies and that both that copyright notice and this permission notice appear in supporting documentation. The above copyright notice and this permission notice shall be included in all copies or substantial portions of the Software. THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE OPEN GROUP BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. keyboard */ #include "rdp.h" #include "rdpkeyboard.h" #include "rdpkeyboardevdev.h" #define LOG_LEVEL 1 #define LLOGLN(_level, _args) \ do { if (_level < LOG_LEVEL) { ErrorF _args ; ErrorF("\n"); } } while (0) extern DeviceIntPtr g_keyboard; /* in rdpmain.c */ extern int g_shift_down; /* in rdpmain.c */ extern int g_alt_down; /* in rdpmain.c */ extern int g_ctrl_down; /* in rdpmain.c */ extern int g_pause_spe; /* in rdpmain.c */ extern int g_tab_down; /* in rdpmain.c */ /******************************************************************************/ void rdpEnqueueKey(int type, int scancode) { int i; int n; EventListPtr rdp_events; xEvent *pev; i = GetEventList(&rdp_events); n = GetKeyboardEvents(rdp_events, g_keyboard, type, scancode); for (i = 0; i < n; i++) { pev = (rdp_events + i)->event; mieqEnqueue(g_keyboard, (InternalEvent *)pev); } } /******************************************************************************/ void check_keysa(void) { if (g_ctrl_down != 0) { rdpEnqueueKey(KeyRelease, g_ctrl_down); g_ctrl_down = 0; } if (g_alt_down != 0) { rdpEnqueueKey(KeyRelease, g_alt_down); g_alt_down = 0; } if (g_shift_down != 0) { rdpEnqueueKey(KeyRelease, g_shift_down); g_shift_down = 0; } } /******************************************************************************/ void sendDownUpKeyEvent(int type, int x_scancode) { /* if type is keydown, send keyup + keydown */ if (type == KeyPress) { rdpEnqueueKey(KeyRelease, x_scancode); rdpEnqueueKey(KeyPress, x_scancode); } else { rdpEnqueueKey(KeyRelease, x_scancode); } } xrdp-0.9.5/xorg/X11R7.6/rdp/rdpPutImage.h000644 001751 001751 00000002116 13125122134 017500 0ustar00metameta000000 000000 /* Copyright 2005-2013 Jay Sorg Permission to use, copy, modify, distribute, and sell this software and its documentation for any purpose is hereby granted without fee, provided that the above copyright notice appear in all copies and that both that copyright notice and this permission notice appear in supporting documentation. The above copyright notice and this permission notice shall be included in all copies or substantial portions of the Software. THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE OPEN GROUP BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. */ #ifndef __RDPPUTIMAGE_H #define __RDPPUTIMAGE_H void rdpPutImage(DrawablePtr pDst, GCPtr pGC, int depth, int x, int y, int w, int h, int leftPad, int format, char* pBits); #endif xrdp-0.9.5/xorg/X11R7.6/rdp/rdpImageText16.c000644 001751 001751 00000013450 13125122134 020021 0ustar00metameta000000 000000 /* Copyright 2005-2013 Jay Sorg Permission to use, copy, modify, distribute, and sell this software and its documentation for any purpose is hereby granted without fee, provided that the above copyright notice appear in all copies and that both that copyright notice and this permission notice appear in supporting documentation. The above copyright notice and this permission notice shall be included in all copies or substantial portions of the Software. THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE OPEN GROUP BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. */ #include "rdp.h" #include "rdpdraw.h" #define LDEBUG 0 #define LOG_LEVEL 1 #define LLOG(_level, _args) \ do { if (_level < LOG_LEVEL) { ErrorF _args ; } } while (0) #define LLOGLN(_level, _args) \ do { if (_level < LOG_LEVEL) { ErrorF _args ; ErrorF("\n"); } } while (0) extern rdpScreenInfoRec g_rdpScreen; /* from rdpmain.c */ extern DevPrivateKeyRec g_rdpGCIndex; /* from rdpmain.c */ extern DevPrivateKeyRec g_rdpWindowIndex; /* from rdpmain.c */ extern DevPrivateKeyRec g_rdpPixmapIndex; /* from rdpmain.c */ extern int g_Bpp; /* from rdpmain.c */ extern ScreenPtr g_pScreen; /* from rdpmain.c */ extern Bool g_wrapPixmap; /* from rdpmain.c */ extern int g_do_dirty_os; /* in rdpmain.c */ extern int g_do_dirty_ons; /* in rdpmain.c */ extern rdpPixmapRec g_screenPriv; /* in rdpmain.c */ extern GCOps g_rdpGCOps; /* from rdpdraw.c */ extern int g_con_number; /* in rdpup.c */ /******************************************************************************/ void rdpImageText16Org(DrawablePtr pDrawable, GCPtr pGC, int x, int y, int count, unsigned short *chars) { rdpGCPtr priv; GCFuncs *oldFuncs; GC_OP_PROLOGUE(pGC); pGC->ops->ImageText16(pDrawable, pGC, x, y, count, chars); GC_OP_EPILOGUE(pGC); } /******************************************************************************/ void rdpImageText16(DrawablePtr pDrawable, GCPtr pGC, int x, int y, int count, unsigned short *chars) { RegionRec reg; RegionRec reg1; int num_clips; int cd; int j; int got_id; int dirty_type; int post_process; int reset_surface; BoxRec box; struct image_data id; WindowPtr pDstWnd; PixmapPtr pDstPixmap; rdpPixmapRec *pDstPriv; rdpPixmapRec *pDirtyPriv; LLOGLN(10, ("rdpImageText16:")); if (count != 0) { GetTextBoundingBox(pDrawable, pGC->font, x, y, count, &box); } /* do original call */ rdpImageText16Org(pDrawable, pGC, x, y, count, chars); dirty_type = 0; pDirtyPriv = 0; post_process = 0; reset_surface = 0; got_id = 0; if (pDrawable->type == DRAWABLE_PIXMAP) { pDstPixmap = (PixmapPtr)pDrawable; pDstPriv = GETPIXPRIV(pDstPixmap); if (xrdp_is_os(pDstPixmap, pDstPriv)) { post_process = 1; if (g_do_dirty_os) { LLOGLN(10, ("rdpImageText16: getting dirty")); pDstPriv->is_dirty = 1; pDirtyPriv = pDstPriv; dirty_type = RDI_IMGLY; } else { rdpup_switch_os_surface(pDstPriv->rdpindex); reset_surface = 1; rdpup_get_pixmap_image_rect(pDstPixmap, &id); got_id = 1; } } } else { if (pDrawable->type == DRAWABLE_WINDOW) { pDstWnd = (WindowPtr)pDrawable; if (pDstWnd->viewable) { post_process = 1; if (g_do_dirty_ons) { LLOGLN(10, ("rdpImageText16: getting dirty")); g_screenPriv.is_dirty = 1; pDirtyPriv = &g_screenPriv; dirty_type = RDI_IMGLL; } else { rdpup_get_screen_image_rect(&id); got_id = 1; } } } } if (!post_process) { return; } RegionInit(®, NullBox, 0); if (count == 0) { cd = 0; } else { cd = rdp_get_clip(®, pDrawable, pGC); } if (cd == 1) { if (dirty_type != 0) { RegionInit(®1, &box, 0); draw_item_add_img_region(pDirtyPriv, ®1, GXcopy, dirty_type, TAG_IMAGETEXT16); RegionUninit(®1); } else if (got_id) { rdpup_begin_update(); rdpup_send_area(&id, box.x1, box.y1, box.x2 - box.x1, box.y2 - box.y1); rdpup_end_update(); } } else if (cd == 2) { RegionInit(®1, &box, 0); RegionIntersect(®, ®, ®1); num_clips = REGION_NUM_RECTS(®); if (num_clips > 0) { if (dirty_type != 0) { draw_item_add_img_region(pDirtyPriv, ®, GXcopy, dirty_type, TAG_IMAGETEXT16); } else if (got_id) { rdpup_begin_update(); for (j = num_clips - 1; j >= 0; j--) { box = REGION_RECTS(®)[j]; rdpup_send_area(&id, box.x1, box.y1, box.x2 - box.x1, box.y2 - box.y1); } rdpup_end_update(); } } RegionUninit(®1); } RegionUninit(®); if (reset_surface) { rdpup_switch_os_surface(-1); } return; } xrdp-0.9.5/xorg/X11R7.6/rdp/rdpCopyArea.h000644 001751 001751 00000002116 13125122134 017470 0ustar00metameta000000 000000 /* Copyright 2005-2013 Jay Sorg Permission to use, copy, modify, distribute, and sell this software and its documentation for any purpose is hereby granted without fee, provided that the above copyright notice appear in all copies and that both that copyright notice and this permission notice appear in supporting documentation. The above copyright notice and this permission notice shall be included in all copies or substantial portions of the Software. THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE OPEN GROUP BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. */ #ifndef __RDPCOPYAREA_H #define __RDPCOPYAREA_H RegionPtr rdpCopyArea(DrawablePtr pSrc, DrawablePtr pDst, GCPtr pGC, int srcx, int srcy, int w, int h, int dstx, int dsty); #endif xrdp-0.9.5/xorg/X11R7.6/rdp/rdpPolyFillRect.h000644 001751 001751 00000002074 13125122134 020340 0ustar00metameta000000 000000 /* Copyright 2005-2013 Jay Sorg Permission to use, copy, modify, distribute, and sell this software and its documentation for any purpose is hereby granted without fee, provided that the above copyright notice appear in all copies and that both that copyright notice and this permission notice appear in supporting documentation. The above copyright notice and this permission notice shall be included in all copies or substantial portions of the Software. THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE OPEN GROUP BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. */ #ifndef __RDPPOLYFILLRECT_H #define __RDPPOLYFILLRECT_H void rdpPolyFillRect(DrawablePtr pDrawable, GCPtr pGC, int nrectFill, xRectangle* prectInit); #endif xrdp-0.9.5/xorg/X11R7.6/rdp/rdpSetSpans.h000644 001751 001751 00000002111 13125122134 017520 0ustar00metameta000000 000000 /* Copyright 2005-2013 Jay Sorg Permission to use, copy, modify, distribute, and sell this software and its documentation for any purpose is hereby granted without fee, provided that the above copyright notice appear in all copies and that both that copyright notice and this permission notice appear in supporting documentation. The above copyright notice and this permission notice shall be included in all copies or substantial portions of the Software. THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE OPEN GROUP BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. */ #ifndef __RDPSETSPANS_H #define __RDPSETSPANS_H void rdpSetSpans(DrawablePtr pDrawable, GCPtr pGC, char* psrc, DDXPointPtr ppt, int* pwidth, int nspans, int fSorted); #endif xrdp-0.9.5/common/xrdp_rail.h000644 001751 001751 00000011114 13125122133 016036 0ustar00metameta000000 000000 /** * xrdp: A Remote Desktop Protocol server. * * Copyright (C) Jay Sorg 2012-2014 * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ #if !defined(_RAIL_H) #define _RAIL_H /* ORDER_TYPE_WINDOW WINDOW_ORDER_TYPE_WINDOW WINDOW_ORDER_ICON WINDOW_ORDER_CACHED_ICON WINDOW_ORDER_STATE_DELETED WINDOW_ORDER_STATE_NEW on WINDOW_ORDER_STATE_NEW off WINDOW_ORDER_TYPE_NOTIFY WINDOW_ORDER_STATE_DELETED WINDOW_ORDER_STATE_NEW on WINDOW_ORDER_STATE_NEW off WINDOW_ORDER_TYPE_DESKTOP WINDOW_ORDER_FIELD_DESKTOP_NONE on WINDOW_ORDER_FIELD_DESKTOP_NONE off */ /* Window Order Header Flags */ #define WINDOW_ORDER_TYPE_WINDOW 0x01000000 #define WINDOW_ORDER_TYPE_NOTIFY 0x02000000 #define WINDOW_ORDER_TYPE_DESKTOP 0x04000000 #define WINDOW_ORDER_STATE_NEW 0x10000000 #define WINDOW_ORDER_STATE_DELETED 0x20000000 #define WINDOW_ORDER_FIELD_OWNER 0x00000002 #define WINDOW_ORDER_FIELD_STYLE 0x00000008 #define WINDOW_ORDER_FIELD_SHOW 0x00000010 #define WINDOW_ORDER_FIELD_TITLE 0x00000004 #define WINDOW_ORDER_FIELD_CLIENT_AREA_OFFSET 0x00004000 #define WINDOW_ORDER_FIELD_CLIENT_AREA_SIZE 0x00010000 #define WINDOW_ORDER_FIELD_RP_CONTENT 0x00020000 #define WINDOW_ORDER_FIELD_ROOT_PARENT 0x00040000 #define WINDOW_ORDER_FIELD_WND_OFFSET 0x00000800 #define WINDOW_ORDER_FIELD_WND_CLIENT_DELTA 0x00008000 #define WINDOW_ORDER_FIELD_WND_SIZE 0x00000400 #define WINDOW_ORDER_FIELD_WND_RECTS 0x00000100 #define WINDOW_ORDER_FIELD_VIS_OFFSET 0x00001000 #define WINDOW_ORDER_FIELD_VISIBILITY 0x00000200 #define WINDOW_ORDER_FIELD_ICON_BIG 0x00002000 #define WINDOW_ORDER_ICON 0x40000000 #define WINDOW_ORDER_CACHED_ICON 0x80000000 #define WINDOW_ORDER_FIELD_NOTIFY_VERSION 0x00000008 #define WINDOW_ORDER_FIELD_NOTIFY_TIP 0x00000001 #define WINDOW_ORDER_FIELD_NOTIFY_INFO_TIP 0x00000002 #define WINDOW_ORDER_FIELD_NOTIFY_STATE 0x00000004 #define WINDOW_ORDER_FIELD_DESKTOP_NONE 0x00000001 #define WINDOW_ORDER_FIELD_DESKTOP_HOOKED 0x00000002 #define WINDOW_ORDER_FIELD_DESKTOP_ARC_COMPLETED 0x00000004 #define WINDOW_ORDER_FIELD_DESKTOP_ARC_BEGAN 0x00000008 #define WINDOW_ORDER_FIELD_DESKTOP_ZORDER 0x00000010 #define WINDOW_ORDER_FIELD_DESKTOP_ACTIVE_WND 0x00000020 struct rail_icon_info { int bpp; int width; int height; int cmap_bytes; int mask_bytes; int data_bytes; char *mask; char *cmap; char *data; }; struct rail_window_rect { short left; short top; short right; short bottom; }; struct rail_notify_icon_infotip { int timeout; int flags; char *text; char *title; }; struct rail_window_state_order { int owner_window_id; int style; int extended_style; int show_state; char *title_info; int client_offset_x; int client_offset_y; int client_area_width; int client_area_height; int rp_content; int root_parent_handle; int window_offset_x; int window_offset_y; int window_client_delta_x; int window_client_delta_y; int window_width; int window_height; int num_window_rects; struct rail_window_rect *window_rects; int visible_offset_x; int visible_offset_y; int num_visibility_rects; struct rail_window_rect *visibility_rects; }; struct rail_notify_state_order { int version; char *tool_tip; struct rail_notify_icon_infotip infotip; int state; int icon_cache_entry; int icon_cache_id; struct rail_icon_info icon_info; }; struct rail_monitored_desktop_order { int active_window_id; int num_window_ids; int *window_ids; }; #endif xrdp-0.9.5/common/pixman-region16.c000644 001751 001751 00000004423 13127114621 017003 0ustar00metameta000000 000000 /* * Copyright © 2008 Red Hat, Inc. * * Permission to use, copy, modify, distribute, and sell this software * and its documentation for any purpose is hereby granted without * fee, provided that the above copyright notice appear in all copies * and that both that copyright notice and this permission notice * appear in supporting documentation, and that the name of * Red Hat, Inc. not be used in advertising or publicity pertaining to * distribution of the software without specific, written prior * permission. Red Hat, Inc. makes no representations about the * suitability of this software for any purpose. It is provided "as * is" without express or implied warranty. * * RED HAT, INC. DISCLAIMS ALL WARRANTIES WITH REGARD TO THIS * SOFTWARE, INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY AND * FITNESS, IN NO EVENT SHALL RED HAT, INC. BE LIABLE FOR ANY SPECIAL, * INDIRECT OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER * RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN ACTION * OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF OR * IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. * * Author: Soren Sandmann */ /* taken from pixman 0.34 altered to compile without all of pixman */ #if defined(HAVE_CONFIG_H) #include "config_ac.h" #endif #include #include #include #if defined(HAVE_STDINT_H) #include #endif #include "pixman-region.h" #if !defined(UINT32_MAX) #define UINT32_MAX (4294967295U) #endif #if !defined(INT16_MIN) #define INT16_MIN (-32767-1) #endif #if !defined(INT16_MAX) #define INT16_MAX (32767) #endif #define PIXMAN_EXPORT #define FALSE 0 #define TRUE 1 #define MIN(x1, x2) ((x1) < (x2) ? (x1) : (x2)) #define MAX(x1, x2) ((x1) > (x2) ? (x1) : (x2)) typedef pixman_box16_t box_type_t; typedef pixman_region16_data_t region_data_type_t; typedef pixman_region16_t region_type_t; typedef signed int overflow_int_t; #define PREFIX(x) pixman_region##x #define PIXMAN_REGION_MAX INT16_MAX #define PIXMAN_REGION_MIN INT16_MIN #define FUNC "func" #define critical_if_fail(expr) int _pixman_log_error(const char *func, const char *format, ...) { return 0; } #include "pixman-region.c" xrdp-0.9.5/common/list.c000644 001751 001751 00000012175 13174271344 015045 0ustar00metameta000000 000000 /** * xrdp: A Remote Desktop Protocol server. * * Copyright (C) Jay Sorg 2004-2014 * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. * * simple list */ #if defined(HAVE_CONFIG_H) #include #endif #include "arch.h" #include "os_calls.h" #include "list.h" /*****************************************************************************/ struct list * list_create(void) { struct list *self; self = (struct list *)g_malloc(sizeof(struct list), 1); self->grow_by = 10; self->alloc_size = 10; self->items = (tbus *)g_malloc(sizeof(tbus) * 10, 1); return self; } /*****************************************************************************/ void list_delete(struct list *self) { int i; if (self == 0) { return; } if (self->auto_free) { for (i = 0; i < self->count; i++) { g_free((void *)self->items[i]); self->items[i] = 0; } } g_free(self->items); g_free(self); } /*****************************************************************************/ void list_add_item(struct list *self, tbus item) { tbus *p; int i; if (self->count >= self->alloc_size) { i = self->alloc_size; self->alloc_size += self->grow_by; p = (tbus *)g_malloc(sizeof(tbus) * self->alloc_size, 1); g_memcpy(p, self->items, sizeof(tbus) * i); g_free(self->items); self->items = p; } self->items[self->count] = item; self->count++; } /*****************************************************************************/ tbus list_get_item(const struct list *self, int index) { if (index < 0 || index >= self->count) { return 0; } return self->items[index]; } /*****************************************************************************/ void list_clear(struct list *self) { int i; if (self->auto_free) { for (i = 0; i < self->count; i++) { g_free((void *)self->items[i]); self->items[i] = 0; } } g_free(self->items); self->count = 0; self->grow_by = 10; self->alloc_size = 10; self->items = (tbus *)g_malloc(sizeof(tbus) * 10, 1); } /*****************************************************************************/ int list_index_of(struct list *self, tbus item) { int i; for (i = 0; i < self->count; i++) { if (self->items[i] == item) { return i; } } return -1; } /*****************************************************************************/ void list_remove_item(struct list *self, int index) { int i; if (index >= 0 && index < self->count) { if (self->auto_free) { g_free((void *)self->items[index]); self->items[index] = 0; } for (i = index; i < (self->count - 1); i++) { self->items[i] = self->items[i + 1]; } self->count--; } } /*****************************************************************************/ void list_insert_item(struct list *self, int index, tbus item) { tbus *p; int i; if (index == self->count) { list_add_item(self, item); return; } if (index >= 0 && index < self->count) { self->count++; if (self->count > self->alloc_size) { i = self->alloc_size; self->alloc_size += self->grow_by; p = (tbus *)g_malloc(sizeof(tbus) * self->alloc_size, 1); g_memcpy(p, self->items, sizeof(tbus) * i); g_free(self->items); self->items = p; } for (i = (self->count - 2); i >= index; i--) { self->items[i + 1] = self->items[i]; } self->items[index] = item; } } /*****************************************************************************/ /* append one list to another using strdup for each item in the list */ /* begins copy at start_index, a zero based index on the source list */ void list_append_list_strdup(struct list *self, struct list *dest, int start_index) { int index; tbus item; char *dup; for (index = start_index; index < self->count; index++) { item = list_get_item(self, index); dup = g_strdup((char *)item); list_add_item(dest, (tbus)dup); } } /*****************************************************************************/ void list_dump_items(struct list *self) { int index; if (self->count == 0) { g_writeln("List is empty"); } for (index = 0; index < self->count; index++) { g_writeln("%d: %p", index, (void *) list_get_item(self, index)); } } xrdp-0.9.5/common/ssl_calls.c000644 001751 001751 00000055261 13220727201 016042 0ustar00metameta000000 000000 /** * xrdp: A Remote Desktop Protocol server. * * Copyright (C) Jay Sorg 2004-2014 * Copyright (C) Idan Freiberg 2013-2014 * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. * * ssl calls */ #if defined(HAVE_CONFIG_H) #include #endif #include /* needed for openssl headers */ #include #include #include #include #include #include #include #include #include "os_calls.h" #include "arch.h" #include "ssl_calls.h" #include "trans.h" #include "log.h" #define SSL_WANT_READ_WRITE_TIMEOUT 100 #if OPENSSL_VERSION_NUMBER < 0x10100000L static inline HMAC_CTX * HMAC_CTX_new(void) { HMAC_CTX *hmac_ctx = g_new(HMAC_CTX, 1); HMAC_CTX_init(hmac_ctx); return hmac_ctx; } static inline void HMAC_CTX_free(HMAC_CTX *hmac_ctx) { HMAC_CTX_cleanup(hmac_ctx); g_free(hmac_ctx); } static inline void RSA_get0_key(const RSA *key, const BIGNUM **n, const BIGNUM **e, const BIGNUM **d) { *n = key->n; *d = key->d; } #endif /* OPENSSL_VERSION_NUMBER >= 0x10100000L */ /*****************************************************************************/ int ssl_init(void) { SSL_load_error_strings(); SSL_library_init(); return 0; } /*****************************************************************************/ int ssl_finish(void) { return 0; } /* rc4 stuff */ /*****************************************************************************/ void * ssl_rc4_info_create(void) { return g_malloc(sizeof(RC4_KEY), 1); } /*****************************************************************************/ void ssl_rc4_info_delete(void *rc4_info) { g_free(rc4_info); } /*****************************************************************************/ void ssl_rc4_set_key(void *rc4_info, char *key, int len) { RC4_set_key((RC4_KEY *)rc4_info, len, (tui8 *)key); } /*****************************************************************************/ void ssl_rc4_crypt(void *rc4_info, char *data, int len) { RC4((RC4_KEY *)rc4_info, len, (tui8 *)data, (tui8 *)data); } /* sha1 stuff */ /*****************************************************************************/ void * ssl_sha1_info_create(void) { return g_malloc(sizeof(SHA_CTX), 1); } /*****************************************************************************/ void ssl_sha1_info_delete(void *sha1_info) { g_free(sha1_info); } /*****************************************************************************/ void ssl_sha1_clear(void *sha1_info) { SHA1_Init((SHA_CTX *)sha1_info); } /*****************************************************************************/ void ssl_sha1_transform(void *sha1_info, const char *data, int len) { SHA1_Update((SHA_CTX *)sha1_info, data, len); } /*****************************************************************************/ void ssl_sha1_complete(void *sha1_info, char *data) { SHA1_Final((tui8 *)data, (SHA_CTX *)sha1_info); } /* md5 stuff */ /*****************************************************************************/ void * ssl_md5_info_create(void) { return g_malloc(sizeof(MD5_CTX), 1); } /*****************************************************************************/ void ssl_md5_info_delete(void *md5_info) { g_free(md5_info); } /*****************************************************************************/ void ssl_md5_clear(void *md5_info) { MD5_Init((MD5_CTX *)md5_info); } /*****************************************************************************/ void ssl_md5_transform(void *md5_info, char *data, int len) { MD5_Update((MD5_CTX *)md5_info, data, len); } /*****************************************************************************/ void ssl_md5_complete(void *md5_info, char *data) { MD5_Final((tui8 *)data, (MD5_CTX *)md5_info); } /* FIPS stuff */ /*****************************************************************************/ void * ssl_des3_encrypt_info_create(const char *key, const char* ivec) { EVP_CIPHER_CTX *des3_ctx; const tui8 *lkey; const tui8 *livec; des3_ctx = EVP_CIPHER_CTX_new(); lkey = (const tui8 *) key; livec = (const tui8 *) ivec; EVP_EncryptInit_ex(des3_ctx, EVP_des_ede3_cbc(), NULL, lkey, livec); EVP_CIPHER_CTX_set_padding(des3_ctx, 0); return des3_ctx; } /*****************************************************************************/ void * ssl_des3_decrypt_info_create(const char *key, const char* ivec) { EVP_CIPHER_CTX *des3_ctx; const tui8 *lkey; const tui8 *livec; des3_ctx = EVP_CIPHER_CTX_new(); lkey = (const tui8 *) key; livec = (const tui8 *) ivec; EVP_DecryptInit_ex(des3_ctx, EVP_des_ede3_cbc(), NULL, lkey, livec); EVP_CIPHER_CTX_set_padding(des3_ctx, 0); return des3_ctx; } /*****************************************************************************/ void ssl_des3_info_delete(void *des3) { EVP_CIPHER_CTX *des3_ctx; des3_ctx = (EVP_CIPHER_CTX *) des3; if (des3_ctx != 0) { EVP_CIPHER_CTX_free(des3_ctx); } } /*****************************************************************************/ int ssl_des3_encrypt(void *des3, int length, const char *in_data, char *out_data) { EVP_CIPHER_CTX *des3_ctx; int len; const tui8 *lin_data; tui8 *lout_data; des3_ctx = (EVP_CIPHER_CTX *) des3; lin_data = (const tui8 *) in_data; lout_data = (tui8 *) out_data; len = 0; EVP_EncryptUpdate(des3_ctx, lout_data, &len, lin_data, length); return 0; } /*****************************************************************************/ int ssl_des3_decrypt(void *des3, int length, const char *in_data, char *out_data) { EVP_CIPHER_CTX *des3_ctx; int len; const tui8 *lin_data; tui8 *lout_data; des3_ctx = (EVP_CIPHER_CTX *) des3; lin_data = (const tui8 *) in_data; lout_data = (tui8 *) out_data; len = 0; EVP_DecryptUpdate(des3_ctx, lout_data, &len, lin_data, length); return 0; } /*****************************************************************************/ void * ssl_hmac_info_create(void) { HMAC_CTX *hmac_ctx; hmac_ctx = HMAC_CTX_new(); return hmac_ctx; } /*****************************************************************************/ void ssl_hmac_info_delete(void *hmac) { HMAC_CTX *hmac_ctx; hmac_ctx = (HMAC_CTX *) hmac; if (hmac_ctx != 0) { HMAC_CTX_free(hmac_ctx); } } /*****************************************************************************/ void ssl_hmac_sha1_init(void *hmac, const char *data, int len) { HMAC_CTX *hmac_ctx; hmac_ctx = (HMAC_CTX *) hmac; HMAC_Init_ex(hmac_ctx, data, len, EVP_sha1(), NULL); } /*****************************************************************************/ void ssl_hmac_transform(void *hmac, const char *data, int len) { HMAC_CTX *hmac_ctx; const tui8 *ldata; hmac_ctx = (HMAC_CTX *) hmac; ldata = (const tui8*) data; HMAC_Update(hmac_ctx, ldata, len); } /*****************************************************************************/ void ssl_hmac_complete(void *hmac, char *data, int len) { HMAC_CTX *hmac_ctx; tui8* ldata; tui32 llen; hmac_ctx = (HMAC_CTX *) hmac; ldata = (tui8 *) data; llen = len; HMAC_Final(hmac_ctx, ldata, &llen); } /*****************************************************************************/ static void ssl_reverse_it(char *p, int len) { int i; int j; char temp; i = 0; j = len - 1; while (i < j) { temp = p[i]; p[i] = p[j]; p[j] = temp; i++; j--; } } /*****************************************************************************/ int ssl_mod_exp(char *out, int out_len, const char *in, int in_len, const char *mod, int mod_len, const char *exp, int exp_len) { BN_CTX *ctx; BIGNUM *lmod; BIGNUM *lexp; BIGNUM *lin; BIGNUM *lout; int rv; char *l_out; char *l_in; char *l_mod; char *l_exp; l_out = (char *)g_malloc(out_len, 1); l_in = (char *)g_malloc(in_len, 1); l_mod = (char *)g_malloc(mod_len, 1); l_exp = (char *)g_malloc(exp_len, 1); g_memcpy(l_in, in, in_len); g_memcpy(l_mod, mod, mod_len); g_memcpy(l_exp, exp, exp_len); ssl_reverse_it(l_in, in_len); ssl_reverse_it(l_mod, mod_len); ssl_reverse_it(l_exp, exp_len); ctx = BN_CTX_new(); lmod = BN_new(); lexp = BN_new(); lin = BN_new(); lout = BN_new(); BN_bin2bn((tui8 *)l_mod, mod_len, lmod); BN_bin2bn((tui8 *)l_exp, exp_len, lexp); BN_bin2bn((tui8 *)l_in, in_len, lin); BN_mod_exp(lout, lin, lexp, lmod, ctx); rv = BN_bn2bin(lout, (tui8 *)l_out); if (rv <= out_len) { ssl_reverse_it(l_out, rv); g_memcpy(out, l_out, out_len); } else { rv = 0; } BN_free(lin); BN_free(lout); BN_free(lexp); BN_free(lmod); BN_CTX_free(ctx); g_free(l_out); g_free(l_in); g_free(l_mod); g_free(l_exp); return rv; } /*****************************************************************************/ /* returns error generates a new rsa key exp is passed in and mod and pri are passed out */ int ssl_gen_key_xrdp1(int key_size_in_bits, const char *exp, int exp_len, char *mod, int mod_len, char *pri, int pri_len) { BIGNUM *my_e; RSA *my_key; char *lexp; char *lmod; char *lpri; int error; int len; int diff; if ((exp_len != 4) || ((mod_len != 64) && (mod_len != 256)) || ((pri_len != 64) && (pri_len != 256))) { return 1; } diff = 0; lexp = (char *)g_malloc(exp_len, 1); lmod = (char *)g_malloc(mod_len, 1); lpri = (char *)g_malloc(pri_len, 1); g_memcpy(lexp, exp, exp_len); ssl_reverse_it(lexp, exp_len); my_e = BN_new(); BN_bin2bn((tui8 *)lexp, exp_len, my_e); my_key = RSA_new(); error = RSA_generate_key_ex(my_key, key_size_in_bits, my_e, 0) == 0; const BIGNUM *n; const BIGNUM *d; RSA_get0_key(my_key, &n, NULL, &d); if (error == 0) { len = BN_num_bytes(n); error = (len < 1) || (len > mod_len); diff = mod_len - len; } if (error == 0) { BN_bn2bin(n, (tui8 *)(lmod + diff)); ssl_reverse_it(lmod, mod_len); } if (error == 0) { len = BN_num_bytes(d); error = (len < 1) || (len > pri_len); diff = pri_len - len; } if (error == 0) { BN_bn2bin(d, (tui8 *)(lpri + diff)); ssl_reverse_it(lpri, pri_len); } if (error == 0) { g_memcpy(mod, lmod, mod_len); g_memcpy(pri, lpri, pri_len); } BN_free(my_e); RSA_free(my_key); g_free(lexp); g_free(lmod); g_free(lpri); return error; } /*****************************************************************************/ struct ssl_tls * ssl_tls_create(struct trans *trans, const char *key, const char *cert) { struct ssl_tls *self; int pid; char buf[1024]; self = (struct ssl_tls *) g_malloc(sizeof(struct ssl_tls), 1); if (self != NULL) { self->trans = trans; self->cert = (char *) cert; self->key = (char *) key; pid = g_getpid(); g_snprintf(buf, 1024, "xrdp_%8.8x_tls_rwo", pid); self->rwo = g_create_wait_obj(buf); } return self; } /*****************************************************************************/ int ssl_tls_print_error(const char *func, SSL *connection, int value) { switch (SSL_get_error(connection, value)) { case SSL_ERROR_ZERO_RETURN: g_writeln("ssl_tls_print_error: %s: Server closed TLS connection", func); return 1; case SSL_ERROR_WANT_READ: case SSL_ERROR_WANT_WRITE: return 0; case SSL_ERROR_SYSCALL: g_writeln("ssl_tls_print_error: %s: I/O error", func); return 1; case SSL_ERROR_SSL: g_writeln("ssl_tls_print_error: %s: Failure in SSL library (protocol error?)", func); return 1; default: g_writeln("ssl_tls_print_error: %s: Unknown error", func); return 1; } } /*****************************************************************************/ int ssl_tls_accept(struct ssl_tls *self, long ssl_protocols, const char *tls_ciphers) { int connection_status; long options = 0; /** * SSL_OP_NO_SSLv2 * SSLv3 is used by, eg. Microsoft RDC for Mac OS X. */ options |= SSL_OP_NO_SSLv2; /** * Disable SSL protocols not listed in ssl_protocols. */ options |= ssl_protocols; #if defined(SSL_OP_NO_COMPRESSION) /** * SSL_OP_NO_COMPRESSION: * * The Microsoft RDP server does not advertise support * for TLS compression, but alternative servers may support it. * This was observed between early versions of the FreeRDP server * and the FreeRDP client, and caused major performance issues, * which is why we're disabling it. */ options |= SSL_OP_NO_COMPRESSION; #endif /** * SSL_OP_TLS_BLOCK_PADDING_BUG: * * The Microsoft RDP server does *not* support TLS padding. * It absolutely needs to be disabled otherwise it won't work. */ options |= SSL_OP_TLS_BLOCK_PADDING_BUG; /** * SSL_OP_DONT_INSERT_EMPTY_FRAGMENTS: * * Just like TLS padding, the Microsoft RDP server does not * support empty fragments. This needs to be disabled. */ options |= SSL_OP_DONT_INSERT_EMPTY_FRAGMENTS; self->ctx = SSL_CTX_new(SSLv23_server_method()); /* set context options */ SSL_CTX_set_mode(self->ctx, SSL_MODE_ACCEPT_MOVING_WRITE_BUFFER | SSL_MODE_ENABLE_PARTIAL_WRITE); SSL_CTX_set_options(self->ctx, options); if (g_strlen(tls_ciphers) > 1) { if (SSL_CTX_set_cipher_list(self->ctx, tls_ciphers) == 0) { g_writeln("ssl_tls_accept: invalid cipher options"); return 1; } } SSL_CTX_set_read_ahead(self->ctx, 1); if (self->ctx == NULL) { g_writeln("ssl_tls_accept: SSL_CTX_new failed"); return 1; } if (SSL_CTX_use_RSAPrivateKey_file(self->ctx, self->key, SSL_FILETYPE_PEM) <= 0) { g_writeln("ssl_tls_accept: SSL_CTX_use_RSAPrivateKey_file failed"); return 1; } if (SSL_CTX_use_certificate_chain_file(self->ctx, self->cert) <= 0) { g_writeln("ssl_tls_accept: SSL_CTX_use_certificate_chain_file failed"); return 1; } self->ssl = SSL_new(self->ctx); if (self->ssl == NULL) { g_writeln("ssl_tls_accept: SSL_new failed"); return 1; } if (SSL_set_fd(self->ssl, self->trans->sck) < 1) { g_writeln("ssl_tls_accept: SSL_set_fd failed"); return 1; } while(1) { connection_status = SSL_accept(self->ssl); if (connection_status <= 0) { if (ssl_tls_print_error("SSL_accept", self->ssl, connection_status)) { return 1; } /** * retry when SSL_get_error returns: * SSL_ERROR_WANT_READ * SSL_ERROR_WANT_WRITE */ switch (SSL_get_error(self->ssl, connection_status)) { case SSL_ERROR_WANT_READ: g_sck_can_recv(self->trans->sck, SSL_WANT_READ_WRITE_TIMEOUT); break; case SSL_ERROR_WANT_WRITE: g_sck_can_send(self->trans->sck, SSL_WANT_READ_WRITE_TIMEOUT); break; } } else { break; } } g_writeln("ssl_tls_accept: TLS connection accepted"); return 0; } /*****************************************************************************/ /* returns error, */ int ssl_tls_disconnect(struct ssl_tls *self) { int status; if (self == NULL) { return 0; } if (self->ssl == NULL) { return 0; } status = SSL_shutdown(self->ssl); if (status != 1) { status = SSL_shutdown(self->ssl); if (status <= 0) { if (ssl_tls_print_error("SSL_shutdown", self->ssl, status)) { return 1; } /** * retry when SSL_get_error returns: * SSL_ERROR_WANT_READ * SSL_ERROR_WANT_WRITE */ } } return 0; } /*****************************************************************************/ void ssl_tls_delete(struct ssl_tls *self) { if (self != NULL) { if (self->ssl) SSL_free(self->ssl); if (self->ctx) SSL_CTX_free(self->ctx); g_delete_wait_obj(self->rwo); g_free(self); } } /*****************************************************************************/ int ssl_tls_read(struct ssl_tls *tls, char *data, int length) { int status; int break_flag; while(1) { status = SSL_read(tls->ssl, data, length); switch (SSL_get_error(tls->ssl, status)) { case SSL_ERROR_NONE: break_flag = 1; break; /** * retry when SSL_get_error returns: * SSL_ERROR_WANT_READ * SSL_ERROR_WANT_WRITE */ case SSL_ERROR_WANT_READ: g_sck_can_recv(tls->trans->sck, SSL_WANT_READ_WRITE_TIMEOUT); continue; case SSL_ERROR_WANT_WRITE: g_sck_can_send(tls->trans->sck, SSL_WANT_READ_WRITE_TIMEOUT); continue; /* socket closed */ case SSL_ERROR_ZERO_RETURN: return 0; default: ssl_tls_print_error("SSL_read", tls->ssl, status); status = -1; break_flag = 1; break; } if (break_flag) { break; } } if (SSL_pending(tls->ssl) > 0) { g_set_wait_obj(tls->rwo); } return status; } /*****************************************************************************/ int ssl_tls_write(struct ssl_tls *tls, const char *data, int length) { int status; int break_flag; while(1) { status = SSL_write(tls->ssl, data, length); switch (SSL_get_error(tls->ssl, status)) { case SSL_ERROR_NONE: break_flag = 1; break; /** * retry when SSL_get_error returns: * SSL_ERROR_WANT_READ * SSL_ERROR_WANT_WRITE */ case SSL_ERROR_WANT_READ: g_sck_can_recv(tls->trans->sck, SSL_WANT_READ_WRITE_TIMEOUT); continue; case SSL_ERROR_WANT_WRITE: g_sck_can_send(tls->trans->sck, SSL_WANT_READ_WRITE_TIMEOUT); continue; /* socket closed */ case SSL_ERROR_ZERO_RETURN: return 0; default: ssl_tls_print_error("SSL_write", tls->ssl, status); status = -1; break_flag = 1; break; } if (break_flag) { break; } } return status; } /*****************************************************************************/ /* returns boolean */ int ssl_tls_can_recv(struct ssl_tls *tls, int sck, int millis) { if (SSL_pending(tls->ssl) > 0) { return 1; } g_reset_wait_obj(tls->rwo); return g_sck_can_recv(sck, millis); } /*****************************************************************************/ const char * ssl_get_version(const struct ssl_st *ssl) { return SSL_get_version(ssl); } /*****************************************************************************/ const char * ssl_get_cipher_name(const struct ssl_st *ssl) { return SSL_get_cipher_name(ssl); } /*****************************************************************************/ int ssl_get_protocols_from_string(const char *str, long *ssl_protocols) { long protocols; long bad_protocols; int rv; if ((str == NULL) || (ssl_protocols == NULL)) { return 1; } rv = 0; protocols = 0; #if defined(SSL_OP_NO_SSLv3) protocols |= SSL_OP_NO_SSLv3; #endif #if defined(SSL_OP_NO_TLSv1) protocols |= SSL_OP_NO_TLSv1; #endif #if defined(SSL_OP_NO_TLSv1_1) protocols |= SSL_OP_NO_TLSv1_1; #endif #if defined(SSL_OP_NO_TLSv1_2) protocols |= SSL_OP_NO_TLSv1_2; #endif bad_protocols = protocols; if (g_pos(str, ",TLSv1.2,") >= 0) { #if defined(SSL_OP_NO_TLSv1_2) log_message(LOG_LEVEL_DEBUG, "TLSv1.2 enabled"); protocols &= ~SSL_OP_NO_TLSv1_2; #else log_message(LOG_LEVEL_WARNING, "TLSv1.2 enabled by config, " "but not supported by system OpenSSL"); rv |= (1 << 1); #endif } if (g_pos(str, ",TLSv1.1,") >= 0) { #if defined(SSL_OP_NO_TLSv1_1) log_message(LOG_LEVEL_DEBUG, "TLSv1.1 enabled"); protocols &= ~SSL_OP_NO_TLSv1_1; #else log_message(LOG_LEVEL_WARNING, "TLSv1.1 enabled by config, " "but not supported by system OpenSSL"); rv |= (1 << 2); #endif } if (g_pos(str, ",TLSv1,") >= 0) { #if defined(SSL_OP_NO_TLSv1) log_message(LOG_LEVEL_DEBUG, "TLSv1 enabled"); protocols &= ~SSL_OP_NO_TLSv1; #else log_message(LOG_LEVEL_WARNING, "TLSv1 enabled by config, " "but not supported by system OpenSSL"); rv |= (1 << 3); #endif } if (g_pos(str, ",SSLv3,") >= 0) { #if defined(SSL_OP_NO_SSLv3) log_message(LOG_LEVEL_DEBUG, "SSLv3 enabled"); protocols &= ~SSL_OP_NO_SSLv3; #else log_message(LOG_LEVEL_WARNING, "SSLv3 enabled by config, " "but not supported by system OpenSSL"); rv |= (1 << 4); #endif } if (protocols == bad_protocols) { log_message(LOG_LEVEL_WARNING, "No SSL/TLS protocols enabled. " "At least one protocol should be enabled to accept " "TLS connections."); rv |= (1 << 5); } *ssl_protocols = protocols; return rv; } xrdp-0.9.5/common/xrdp_client_info.h000644 001751 001751 00000007721 13174271344 017426 0ustar00metameta000000 000000 /** * xrdp: A Remote Desktop Protocol server. * * Copyright (C) Jay Sorg 2004-2014 * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. * * xrdp / xserver info / caps */ #if !defined(XRDP_CLIENT_INFO_H) #define XRDP_CLIENT_INFO_H struct monitor_info { int left; int top; int right; int bottom; int is_primary; }; struct xrdp_client_info { int size; /* bytes for this structure */ int bpp; int width; int height; /* bitmap cache info */ int cache1_entries; int cache1_size; int cache2_entries; int cache2_size; int cache3_entries; int cache3_size; int bitmap_cache_persist_enable; /* 0 or 2 */ int bitmap_cache_version; /* ored 1 = original version, 2 = v2, 4 = v3 */ /* pointer info */ int pointer_cache_entries; /* other */ int use_bitmap_comp; int use_bitmap_cache; int op1; /* use smaller bitmap header, non cache */ int op2; /* use smaller bitmap header in bitmap cache */ int desktop_cache; int use_compact_packets; /* rdp5 smaller packets */ char hostname[32]; int build; int keylayout; char username[256]; char password[256]; char domain[256]; char program[256]; char directory[256]; int rdp_compression; int rdp_autologin; int crypt_level; /* 1, 2, 3 = low, medium, high */ int channels_allowed; /* 0 = no channels 1 = channels */ int sound_code; /* 1 = leave sound at server */ int is_mce; int rdp5_performanceflags; int brush_cache_code; /* 0 = no cache 1 = 8x8 standard cache 2 = arbitrary dimensions */ char client_ip[256]; int max_bpp; int jpeg; /* non standard bitmap cache v2 cap */ int offscreen_support_level; int offscreen_cache_size; int offscreen_cache_entries; int rfx; /* CAPSETTYPE_RAIL */ int rail_support_level; /* CAPSETTYPE_WINDOW */ int wnd_support_level; int wnd_num_icon_caches; int wnd_num_icon_cache_entries; /* codecs */ int rfx_codec_id; int rfx_prop_len; char rfx_prop[64]; int ns_codec_id; int ns_prop_len; char ns_prop[64]; int jpeg_codec_id; int jpeg_prop_len; char jpeg_prop[64]; int v3_codec_id; int rfx_min_pixel; char orders[32]; int order_flags_ex; int use_bulk_comp; int pointer_flags; /* 0 color, 1 new, 2 no new */ int use_fast_path; int require_credentials; /* when true, credentials *must* be passed on cmd line */ char client_addr[256]; char client_port[256]; int security_layer; /* 0 = rdp, 1 = tls , 2 = hybrid */ int multimon; /* 0 = deny , 1 = allow */ int monitorCount; /* number of monitors detected (max = 16) */ struct monitor_info minfo[16]; /* client monitor data */ struct monitor_info minfo_wm[16]; /* client monitor data, non-negative values */ int keyboard_type; int keyboard_subtype; int png_codec_id; int png_prop_len; char png_prop[64]; int vendor_flags[4]; int mcs_connection_type; int mcs_early_capability_flags; int max_fastpath_frag_bytes; int capture_code; int capture_format; char certificate[1024]; char key_file[1024]; /* X11 keyboard layout - inferred from keyboard type/subtype */ char model[16]; char layout[16]; char variant[16]; char options[256]; /* !!!!!!!!!!!!!!!!!!!!!!!!!! */ /* NO CHANGES ABOVE THIS LINE */ /* !!!!!!!!!!!!!!!!!!!!!!!!!! */ /* codec */ int h264_codec_id; int h264_prop_len; char h264_prop[64]; int use_frame_acks; int max_unacknowledged_frame_count; long ssl_protocols; char *tls_ciphers; int client_os_major; int client_os_minor; int no_orders_supported; }; #endif xrdp-0.9.5/common/base64.h000644 001751 001751 00000001536 13206666623 015166 0ustar00metameta000000 000000 /** * xrdp: A Remote Desktop Protocol server. * * Copyright (C) Koichiro Iwao 2017 * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. * * Base64 encoder / decoder */ #if !defined(SSL_CALLS_H) #define SSL_CALLS_H #include "arch.h" size_t base64_decoded_bytes(const char *src); char * base64_decode(char *dst, const char *src, size_t len); #endif xrdp-0.9.5/common/log.h000644 001751 001751 00000010574 13220727201 014647 0ustar00metameta000000 000000 /** * xrdp: A Remote Desktop Protocol server. * * Copyright (C) Jay Sorg 2004-2014 * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ #ifndef LOG_H #define LOG_H #include #include "arch.h" /* logging buffer size */ #define LOG_BUFFER_SIZE 1024 /* logging levels */ enum logLevels { LOG_LEVEL_ALWAYS = 0, LOG_LEVEL_ERROR, LOG_LEVEL_WARNING, LOG_LEVEL_INFO, LOG_LEVEL_DEBUG, LOG_LEVEL_TRACE }; /* startup return values */ enum logReturns { LOG_STARTUP_OK = 0, LOG_ERROR_MALLOC, LOG_ERROR_NULL_FILE, LOG_ERROR_FILE_OPEN, LOG_ERROR_NO_CFG, LOG_ERROR_FILE_NOT_OPEN, LOG_GENERAL_ERROR }; #define SESMAN_CFG_LOGGING "Logging" #define SESMAN_CFG_LOG_FILE "LogFile" #define SESMAN_CFG_LOG_LEVEL "LogLevel" #define SESMAN_CFG_LOG_ENABLE_SYSLOG "EnableSyslog" #define SESMAN_CFG_LOG_SYSLOG_LEVEL "SyslogLevel" /* enable threading */ /*#define LOG_ENABLE_THREAD*/ #ifdef XRDP_DEBUG #define LOG_DBG(args...) log_message(LOG_LEVEL_DEBUG, args); #else #define LOG_DBG(args...) #endif struct log_config { const char *program_name; char *log_file; int fd; enum logLevels log_level; int enable_syslog; enum logLevels syslog_level; pthread_mutex_t log_lock; pthread_mutexattr_t log_lock_attr; }; /* internal functions, only used in log.c if this ifdef is defined.*/ #ifdef LOGINTERNALSTUFF /** * * @brief Starts the logging subsystem * @param l_cfg logging system configuration * @return * */ enum logReturns internal_log_start(struct log_config *l_cfg); /** * * @brief Shuts down the logging subsystem * @param l_cfg pointer to the logging subsystem to stop * */ enum logReturns internal_log_end(struct log_config *l_cfg); /** * Converts a log level to a string * @param lvl, the loglevel * @param str pointer where the string will be stored. */ void internal_log_lvl2str(const enum logLevels lvl, char *str); /** * * @brief Converts a string to a log level * @param s The string to convert * @return The corresponding level or LOG_LEVEL_DEBUG if error * */ enum logLevels internal_log_text2level(const char *s); /** * A function that init our struct that holds all state and * also init its content. * @return LOG_STARTUP_OK or LOG_ERROR_MALLOC */ enum logReturns internalInitAndAllocStruct(void); /** * Read configuration from a file and store the values in lists. * @param file * @param lc * @param param_n * @param param_v * @param applicationName, the application name used in the log events. * @return */ enum logReturns internal_config_read_logging(int file, struct log_config *lc, struct list *param_n, struct list *param_v, const char *applicationName); /*End of internal functions*/ #endif /** * This function initialize the log facilities according to the configuration * file, that is described by the in parameter. * @param iniFile * @param applicationName, the name that is used in the log for the running application * @return LOG_STARTUP_OK on success */ enum logReturns log_start(const char *iniFile, const char *applicationName); /** * An alternative log_start where the caller gives the params directly. * @param iniParams * @return */ enum logReturns log_start_from_param(const struct log_config *iniParams); /** * Function that terminates all logging * @return */ enum logReturns log_end(void); /** * the log function that all files use to log an event. * @param lvl, the loglevel * @param msg, the logtext. * @param ... * @return */ enum logReturns log_message(const enum logLevels lvl, const char *msg, ...) printflike(2, 3); /** * This function returns the configured file name for the logfile * @param replybuf the buffer where the reply is stored * @param bufsize how big is the reply buffer. * @return */ char *getLogFile(char *replybuf, int bufsize); #endif xrdp-0.9.5/common/Makefile.in000644 001751 001751 00000057357 13220730773 016004 0ustar00metameta000000 000000 # Makefile.in generated by automake 1.15.1 from Makefile.am. # @configure_input@ # Copyright (C) 1994-2017 Free Software Foundation, Inc. # This Makefile.in is free software; the Free Software Foundation # gives unlimited permission to copy and/or distribute it, # with or without modifications, as long as this notice is preserved. # This program is distributed in the hope that it will be useful, # but WITHOUT ANY WARRANTY, to the extent permitted by law; without # even the implied warranty of MERCHANTABILITY or FITNESS FOR A # PARTICULAR PURPOSE. @SET_MAKE@ VPATH = @srcdir@ am__is_gnu_make = { \ if test -z '$(MAKELEVEL)'; then \ false; \ elif test -n '$(MAKE_HOST)'; then \ true; \ elif test -n '$(MAKE_VERSION)' && test -n '$(CURDIR)'; then \ true; \ else \ false; \ fi; \ } am__make_running_with_option = \ case $${target_option-} in \ ?) ;; \ *) echo "am__make_running_with_option: internal error: invalid" \ "target option '$${target_option-}' specified" >&2; \ exit 1;; \ esac; \ has_opt=no; \ sane_makeflags=$$MAKEFLAGS; \ if $(am__is_gnu_make); then \ sane_makeflags=$$MFLAGS; \ else \ case $$MAKEFLAGS in \ *\\[\ \ ]*) \ bs=\\; \ sane_makeflags=`printf '%s\n' "$$MAKEFLAGS" \ | sed "s/$$bs$$bs[$$bs $$bs ]*//g"`;; \ esac; \ fi; \ skip_next=no; \ strip_trailopt () \ { \ flg=`printf '%s\n' "$$flg" | sed "s/$$1.*$$//"`; \ }; \ for flg in $$sane_makeflags; do \ test $$skip_next = yes && { skip_next=no; continue; }; \ case $$flg in \ *=*|--*) continue;; \ -*I) strip_trailopt 'I'; skip_next=yes;; \ -*I?*) strip_trailopt 'I';; \ -*O) strip_trailopt 'O'; skip_next=yes;; \ -*O?*) strip_trailopt 'O';; \ -*l) strip_trailopt 'l'; skip_next=yes;; \ -*l?*) strip_trailopt 'l';; \ -[dEDm]) skip_next=yes;; \ -[JT]) skip_next=yes;; \ esac; \ case $$flg in \ *$$target_option*) has_opt=yes; break;; \ esac; \ done; \ test $$has_opt = yes am__make_dryrun = (target_option=n; $(am__make_running_with_option)) am__make_keepgoing = (target_option=k; $(am__make_running_with_option)) pkgdatadir = $(datadir)/@PACKAGE@ pkgincludedir = $(includedir)/@PACKAGE@ pkglibdir = $(libdir)/@PACKAGE@ pkglibexecdir = $(libexecdir)/@PACKAGE@ am__cd = CDPATH="$${ZSH_VERSION+.}$(PATH_SEPARATOR)" && cd install_sh_DATA = $(install_sh) -c -m 644 install_sh_PROGRAM = $(install_sh) -c install_sh_SCRIPT = $(install_sh) -c INSTALL_HEADER = $(INSTALL_DATA) transform = $(program_transform_name) NORMAL_INSTALL = : PRE_INSTALL = : POST_INSTALL = : NORMAL_UNINSTALL = : PRE_UNINSTALL = : POST_UNINSTALL = : build_triplet = @build@ host_triplet = @host@ @XRDP_DEBUG_TRUE@am__append_1 = -DXRDP_DEBUG subdir = common ACLOCAL_M4 = $(top_srcdir)/aclocal.m4 am__aclocal_m4_deps = $(top_srcdir)/m4/ax_append_compile_flags.m4 \ $(top_srcdir)/m4/ax_append_flag.m4 \ $(top_srcdir)/m4/ax_cflags_warn_all.m4 \ $(top_srcdir)/m4/ax_check_compile_flag.m4 \ $(top_srcdir)/m4/ax_gcc_func_attribute.m4 \ $(top_srcdir)/m4/ax_require_defined.m4 \ $(top_srcdir)/m4/ax_type_socklen_t.m4 \ $(top_srcdir)/m4/libtool.m4 $(top_srcdir)/m4/ltoptions.m4 \ $(top_srcdir)/m4/ltsugar.m4 $(top_srcdir)/m4/ltversion.m4 \ $(top_srcdir)/m4/lt~obsolete.m4 $(top_srcdir)/m4/pkg.m4 \ $(top_srcdir)/configure.ac am__configure_deps = $(am__aclocal_m4_deps) $(CONFIGURE_DEPENDENCIES) \ $(ACLOCAL_M4) DIST_COMMON = $(srcdir)/Makefile.am $(include_HEADERS) \ $(am__DIST_COMMON) mkinstalldirs = $(install_sh) -d CONFIG_HEADER = $(top_builddir)/config_ac.h CONFIG_CLEAN_FILES = CONFIG_CLEAN_VPATH_FILES = am__vpath_adj_setup = srcdirstrip=`echo "$(srcdir)" | sed 's|.|.|g'`; am__vpath_adj = case $$p in \ $(srcdir)/*) f=`echo "$$p" | sed "s|^$$srcdirstrip/||"`;; \ *) f=$$p;; \ esac; am__strip_dir = f=`echo $$p | sed -e 's|^.*/||'`; am__install_max = 40 am__nobase_strip_setup = \ srcdirstrip=`echo "$(srcdir)" | sed 's/[].[^$$\\*|]/\\\\&/g'` am__nobase_strip = \ for p in $$list; do echo "$$p"; done | sed -e "s|$$srcdirstrip/||" am__nobase_list = $(am__nobase_strip_setup); \ for p in $$list; do echo "$$p $$p"; done | \ sed "s| $$srcdirstrip/| |;"' / .*\//!s/ .*/ ./; s,\( .*\)/[^/]*$$,\1,' | \ $(AWK) 'BEGIN { files["."] = "" } { files[$$2] = files[$$2] " " $$1; \ if (++n[$$2] == $(am__install_max)) \ { print $$2, files[$$2]; n[$$2] = 0; files[$$2] = "" } } \ END { for (dir in files) print dir, files[dir] }' am__base_list = \ sed '$$!N;$$!N;$$!N;$$!N;$$!N;$$!N;$$!N;s/\n/ /g' | \ sed '$$!N;$$!N;$$!N;$$!N;s/\n/ /g' am__uninstall_files_from_dir = { \ test -z "$$files" \ || { test ! -d "$$dir" && test ! -f "$$dir" && test ! -r "$$dir"; } \ || { echo " ( cd '$$dir' && rm -f" $$files ")"; \ $(am__cd) "$$dir" && rm -f $$files; }; \ } am__installdirs = "$(DESTDIR)$(moduledir)" "$(DESTDIR)$(includedir)" LTLIBRARIES = $(module_LTLIBRARIES) am__DEPENDENCIES_1 = libcommon_la_DEPENDENCIES = $(am__DEPENDENCIES_1) \ $(am__DEPENDENCIES_1) am__libcommon_la_SOURCES_DIST = arch.h base64.h base64.c defines.h \ fifo.c fifo.h file.c file.h list.c list.h list16.c list16.h \ log.c log.h os_calls.c os_calls.h parse.h rail.h ssl_calls.c \ ssl_calls.h thread_calls.c thread_calls.h trans.c trans.h \ pixman-region16.c pixman-region.h @XRDP_PIXMAN_FALSE@am__objects_1 = pixman-region16.lo am_libcommon_la_OBJECTS = base64.lo fifo.lo file.lo list.lo list16.lo \ log.lo os_calls.lo ssl_calls.lo thread_calls.lo trans.lo \ $(am__objects_1) libcommon_la_OBJECTS = $(am_libcommon_la_OBJECTS) AM_V_lt = $(am__v_lt_@AM_V@) am__v_lt_ = $(am__v_lt_@AM_DEFAULT_V@) am__v_lt_0 = --silent am__v_lt_1 = AM_V_P = $(am__v_P_@AM_V@) am__v_P_ = $(am__v_P_@AM_DEFAULT_V@) am__v_P_0 = false am__v_P_1 = : AM_V_GEN = $(am__v_GEN_@AM_V@) am__v_GEN_ = $(am__v_GEN_@AM_DEFAULT_V@) am__v_GEN_0 = @echo " GEN " $@; am__v_GEN_1 = AM_V_at = $(am__v_at_@AM_V@) am__v_at_ = $(am__v_at_@AM_DEFAULT_V@) am__v_at_0 = @ am__v_at_1 = DEFAULT_INCLUDES = -I.@am__isrc@ -I$(top_builddir) depcomp = $(SHELL) $(top_srcdir)/depcomp am__depfiles_maybe = depfiles am__mv = mv -f COMPILE = $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) \ $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) LTCOMPILE = $(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) \ $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) \ $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) \ $(AM_CFLAGS) $(CFLAGS) AM_V_CC = $(am__v_CC_@AM_V@) am__v_CC_ = $(am__v_CC_@AM_DEFAULT_V@) am__v_CC_0 = @echo " CC " $@; am__v_CC_1 = CCLD = $(CC) LINK = $(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) \ $(LIBTOOLFLAGS) --mode=link $(CCLD) $(AM_CFLAGS) $(CFLAGS) \ $(AM_LDFLAGS) $(LDFLAGS) -o $@ AM_V_CCLD = $(am__v_CCLD_@AM_V@) am__v_CCLD_ = $(am__v_CCLD_@AM_DEFAULT_V@) am__v_CCLD_0 = @echo " CCLD " $@; am__v_CCLD_1 = SOURCES = $(libcommon_la_SOURCES) DIST_SOURCES = $(am__libcommon_la_SOURCES_DIST) am__can_run_installinfo = \ case $$AM_UPDATE_INFO_DIR in \ n|no|NO) false;; \ *) (install-info --version) >/dev/null 2>&1;; \ esac HEADERS = $(include_HEADERS) am__tagged_files = $(HEADERS) $(SOURCES) $(TAGS_FILES) $(LISP) # Read a list of newline-separated strings from the standard input, # and print each of them once, without duplicates. Input order is # *not* preserved. am__uniquify_input = $(AWK) '\ BEGIN { nonempty = 0; } \ { items[$$0] = 1; nonempty = 1; } \ END { if (nonempty) { for (i in items) print i; }; } \ ' # Make sure the list of sources is unique. This is necessary because, # e.g., the same source file might be shared among _SOURCES variables # for different programs/libraries. am__define_uniq_tagged_files = \ list='$(am__tagged_files)'; \ unique=`for i in $$list; do \ if test -f "$$i"; then echo $$i; else echo $(srcdir)/$$i; fi; \ done | $(am__uniquify_input)` ETAGS = etags CTAGS = ctags am__DIST_COMMON = $(srcdir)/Makefile.in $(top_srcdir)/depcomp DISTFILES = $(DIST_COMMON) $(DIST_SOURCES) $(TEXINFOS) $(EXTRA_DIST) ACLOCAL = @ACLOCAL@ AMTAR = @AMTAR@ AM_DEFAULT_VERBOSITY = @AM_DEFAULT_VERBOSITY@ AR = @AR@ AUTOCONF = @AUTOCONF@ AUTOHEADER = @AUTOHEADER@ AUTOMAKE = @AUTOMAKE@ AWK = @AWK@ CC = @CC@ CCDEPMODE = @CCDEPMODE@ CFLAGS = @CFLAGS@ CPP = @CPP@ CPPFLAGS = @CPPFLAGS@ CYGPATH_W = @CYGPATH_W@ DEFS = @DEFS@ DEPDIR = @DEPDIR@ DLLTOOL = @DLLTOOL@ DLOPEN_LIBS = @DLOPEN_LIBS@ DSYMUTIL = @DSYMUTIL@ DUMPBIN = @DUMPBIN@ ECHO_C = @ECHO_C@ ECHO_N = @ECHO_N@ ECHO_T = @ECHO_T@ EGREP = @EGREP@ EXEEXT = @EXEEXT@ FDKAAC_CFLAGS = @FDKAAC_CFLAGS@ FDKAAC_LIBS = @FDKAAC_LIBS@ FGREP = @FGREP@ FREERDP_CFLAGS = @FREERDP_CFLAGS@ FREERDP_LIBS = @FREERDP_LIBS@ FUSE_CFLAGS = @FUSE_CFLAGS@ FUSE_LIBS = @FUSE_LIBS@ GREP = @GREP@ INSTALL = @INSTALL@ INSTALL_DATA = @INSTALL_DATA@ INSTALL_PROGRAM = @INSTALL_PROGRAM@ INSTALL_SCRIPT = @INSTALL_SCRIPT@ INSTALL_STRIP_PROGRAM = @INSTALL_STRIP_PROGRAM@ LD = @LD@ LDFLAGS = @LDFLAGS@ LIBOBJS = @LIBOBJS@ LIBS = @LIBS@ LIBTOOL = @LIBTOOL@ LIPO = @LIPO@ LN_S = @LN_S@ LTLIBOBJS = @LTLIBOBJS@ LT_SYS_LIBRARY_PATH = @LT_SYS_LIBRARY_PATH@ MAKEINFO = @MAKEINFO@ MANIFEST_TOOL = @MANIFEST_TOOL@ MKDIR_P = @MKDIR_P@ NM = @NM@ NMEDIT = @NMEDIT@ OBJDUMP = @OBJDUMP@ OBJEXT = @OBJEXT@ OPENSSL = @OPENSSL@ OPENSSL_CFLAGS = @OPENSSL_CFLAGS@ OPENSSL_LIBS = @OPENSSL_LIBS@ OTOOL = @OTOOL@ OTOOL64 = @OTOOL64@ PACKAGE = @PACKAGE@ PACKAGE_BUGREPORT = @PACKAGE_BUGREPORT@ PACKAGE_NAME = @PACKAGE_NAME@ PACKAGE_STRING = @PACKAGE_STRING@ PACKAGE_TARNAME = @PACKAGE_TARNAME@ PACKAGE_URL = @PACKAGE_URL@ PACKAGE_VERSION = @PACKAGE_VERSION@ PAM_RULES = @PAM_RULES@ PATH_SEPARATOR = @PATH_SEPARATOR@ PIXMAN_CFLAGS = @PIXMAN_CFLAGS@ PIXMAN_LIBS = @PIXMAN_LIBS@ PKG_CONFIG = @PKG_CONFIG@ PKG_CONFIG_LIBDIR = @PKG_CONFIG_LIBDIR@ PKG_CONFIG_PATH = @PKG_CONFIG_PATH@ RANLIB = @RANLIB@ SED = @SED@ SET_MAKE = @SET_MAKE@ SHELL = @SHELL@ STRIP = @STRIP@ TurboJpegIncDir = @TurboJpegIncDir@ TurboJpegLibDir = @TurboJpegLibDir@ VERSION = @VERSION@ XMKMF = @XMKMF@ X_CFLAGS = @X_CFLAGS@ X_EXTRA_LIBS = @X_EXTRA_LIBS@ X_LIBS = @X_LIBS@ X_PRE_LIBS = @X_PRE_LIBS@ abs_builddir = @abs_builddir@ abs_srcdir = @abs_srcdir@ abs_top_builddir = @abs_top_builddir@ abs_top_srcdir = @abs_top_srcdir@ ac_ct_AR = @ac_ct_AR@ ac_ct_CC = @ac_ct_CC@ ac_ct_DUMPBIN = @ac_ct_DUMPBIN@ am__include = @am__include@ am__leading_dot = @am__leading_dot@ am__quote = @am__quote@ am__tar = @am__tar@ am__untar = @am__untar@ bindir = @bindir@ build = @build@ build_alias = @build_alias@ build_cpu = @build_cpu@ build_os = @build_os@ build_vendor = @build_vendor@ builddir = @builddir@ datadir = @datadir@ datarootdir = @datarootdir@ docdir = @docdir@ dvidir = @dvidir@ exec_prefix = @exec_prefix@ host = @host@ host_alias = @host_alias@ host_cpu = @host_cpu@ host_os = @host_os@ host_vendor = @host_vendor@ htmldir = @htmldir@ includedir = @includedir@ infodir = @infodir@ install_sh = @install_sh@ libdir = @libdir@ libexecdir = @libexecdir@ localedir = @localedir@ localstatedir = @localstatedir@ mandir = @mandir@ mkdir_p = @mkdir_p@ moduledir = @moduledir@ oldincludedir = @oldincludedir@ pdfdir = @pdfdir@ pkgconfigdir = @pkgconfigdir@ prefix = @prefix@ program_transform_name = @program_transform_name@ psdir = @psdir@ sbindir = @sbindir@ sharedstatedir = @sharedstatedir@ socketdir = @socketdir@ srcdir = @srcdir@ subdirs = @subdirs@ sysconfdir = @sysconfdir@ systemdsystemunitdir = @systemdsystemunitdir@ target_alias = @target_alias@ top_build_prefix = @top_build_prefix@ top_builddir = @top_builddir@ top_srcdir = @top_srcdir@ @XRDP_PIXMAN_FALSE@PIXMAN_SOURCES = pixman-region16.c pixman-region.h @XRDP_PIXMAN_TRUE@PIXMAN_SOURCES = EXTRA_DIST = pixman-region.c include_HEADERS = \ xrdp_client_info.h \ xrdp_constants.h \ xrdp_rail.h \ xrdp_sockets.h AM_CPPFLAGS = -DXRDP_CFG_PATH=\"${sysconfdir}/xrdp\" \ -DXRDP_SBIN_PATH=\"${sbindir}\" \ -DXRDP_SHARE_PATH=\"${datadir}/xrdp\" \ -DXRDP_PID_PATH=\"${localstatedir}/run\" \ -DXRDP_LOG_PATH=\"${localstatedir}/log\" \ -DXRDP_SOCKET_PATH=\"${socketdir}\" $(am__append_1) AM_CFLAGS = $(OPENSSL_CFLAGS) module_LTLIBRARIES = \ libcommon.la libcommon_la_SOURCES = \ arch.h \ base64.h \ base64.c \ defines.h \ fifo.c \ fifo.h \ file.c \ file.h \ list.c \ list.h \ list16.c \ list16.h \ log.c \ log.h \ os_calls.c \ os_calls.h \ os_calls.h \ parse.h \ rail.h \ ssl_calls.c \ ssl_calls.h \ thread_calls.c \ thread_calls.h \ trans.c \ trans.h \ $(PIXMAN_SOURCES) libcommon_la_LIBADD = \ -lpthread \ $(OPENSSL_LIBS) \ $(DLOPEN_LIBS) all: all-am .SUFFIXES: .SUFFIXES: .c .lo .o .obj $(srcdir)/Makefile.in: $(srcdir)/Makefile.am $(am__configure_deps) @for dep in $?; do \ case '$(am__configure_deps)' in \ *$$dep*) \ ( cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh ) \ && { if test -f $@; then exit 0; else break; fi; }; \ exit 1;; \ esac; \ done; \ echo ' cd $(top_srcdir) && $(AUTOMAKE) --foreign common/Makefile'; \ $(am__cd) $(top_srcdir) && \ $(AUTOMAKE) --foreign common/Makefile Makefile: $(srcdir)/Makefile.in $(top_builddir)/config.status @case '$?' in \ *config.status*) \ cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh;; \ *) \ echo ' cd $(top_builddir) && $(SHELL) ./config.status $(subdir)/$@ $(am__depfiles_maybe)'; \ cd $(top_builddir) && $(SHELL) ./config.status $(subdir)/$@ $(am__depfiles_maybe);; \ esac; $(top_builddir)/config.status: $(top_srcdir)/configure $(CONFIG_STATUS_DEPENDENCIES) cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh $(top_srcdir)/configure: $(am__configure_deps) cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh $(ACLOCAL_M4): $(am__aclocal_m4_deps) cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh $(am__aclocal_m4_deps): install-moduleLTLIBRARIES: $(module_LTLIBRARIES) @$(NORMAL_INSTALL) @list='$(module_LTLIBRARIES)'; test -n "$(moduledir)" || list=; \ list2=; for p in $$list; do \ if test -f $$p; then \ list2="$$list2 $$p"; \ else :; fi; \ done; \ test -z "$$list2" || { \ echo " $(MKDIR_P) '$(DESTDIR)$(moduledir)'"; \ $(MKDIR_P) "$(DESTDIR)$(moduledir)" || exit 1; \ echo " $(LIBTOOL) $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=install $(INSTALL) $(INSTALL_STRIP_FLAG) $$list2 '$(DESTDIR)$(moduledir)'"; \ $(LIBTOOL) $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=install $(INSTALL) $(INSTALL_STRIP_FLAG) $$list2 "$(DESTDIR)$(moduledir)"; \ } uninstall-moduleLTLIBRARIES: @$(NORMAL_UNINSTALL) @list='$(module_LTLIBRARIES)'; test -n "$(moduledir)" || list=; \ for p in $$list; do \ $(am__strip_dir) \ echo " $(LIBTOOL) $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=uninstall rm -f '$(DESTDIR)$(moduledir)/$$f'"; \ $(LIBTOOL) $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=uninstall rm -f "$(DESTDIR)$(moduledir)/$$f"; \ done clean-moduleLTLIBRARIES: -test -z "$(module_LTLIBRARIES)" || rm -f $(module_LTLIBRARIES) @list='$(module_LTLIBRARIES)'; \ locs=`for p in $$list; do echo $$p; done | \ sed 's|^[^/]*$$|.|; s|/[^/]*$$||; s|$$|/so_locations|' | \ sort -u`; \ test -z "$$locs" || { \ echo rm -f $${locs}; \ rm -f $${locs}; \ } libcommon.la: $(libcommon_la_OBJECTS) $(libcommon_la_DEPENDENCIES) $(EXTRA_libcommon_la_DEPENDENCIES) $(AM_V_CCLD)$(LINK) -rpath $(moduledir) $(libcommon_la_OBJECTS) $(libcommon_la_LIBADD) $(LIBS) mostlyclean-compile: -rm -f *.$(OBJEXT) distclean-compile: -rm -f *.tab.c @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/base64.Plo@am__quote@ @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/fifo.Plo@am__quote@ @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/file.Plo@am__quote@ @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/list.Plo@am__quote@ @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/list16.Plo@am__quote@ @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/log.Plo@am__quote@ @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/os_calls.Plo@am__quote@ @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/pixman-region16.Plo@am__quote@ @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/ssl_calls.Plo@am__quote@ @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/thread_calls.Plo@am__quote@ @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/trans.Plo@am__quote@ .c.o: @am__fastdepCC_TRUE@ $(AM_V_CC)$(COMPILE) -MT $@ -MD -MP -MF $(DEPDIR)/$*.Tpo -c -o $@ $< @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) $(DEPDIR)/$*.Tpo $(DEPDIR)/$*.Po @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='$<' object='$@' libtool=no @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(COMPILE) -c -o $@ $< .c.obj: @am__fastdepCC_TRUE@ $(AM_V_CC)$(COMPILE) -MT $@ -MD -MP -MF $(DEPDIR)/$*.Tpo -c -o $@ `$(CYGPATH_W) '$<'` @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) $(DEPDIR)/$*.Tpo $(DEPDIR)/$*.Po @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='$<' object='$@' libtool=no @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(COMPILE) -c -o $@ `$(CYGPATH_W) '$<'` .c.lo: @am__fastdepCC_TRUE@ $(AM_V_CC)$(LTCOMPILE) -MT $@ -MD -MP -MF $(DEPDIR)/$*.Tpo -c -o $@ $< @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) $(DEPDIR)/$*.Tpo $(DEPDIR)/$*.Plo @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='$<' object='$@' libtool=yes @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(LTCOMPILE) -c -o $@ $< mostlyclean-libtool: -rm -f *.lo clean-libtool: -rm -rf .libs _libs install-includeHEADERS: $(include_HEADERS) @$(NORMAL_INSTALL) @list='$(include_HEADERS)'; test -n "$(includedir)" || list=; \ if test -n "$$list"; then \ echo " $(MKDIR_P) '$(DESTDIR)$(includedir)'"; \ $(MKDIR_P) "$(DESTDIR)$(includedir)" || exit 1; \ fi; \ for p in $$list; do \ if test -f "$$p"; then d=; else d="$(srcdir)/"; fi; \ echo "$$d$$p"; \ done | $(am__base_list) | \ while read files; do \ echo " $(INSTALL_HEADER) $$files '$(DESTDIR)$(includedir)'"; \ $(INSTALL_HEADER) $$files "$(DESTDIR)$(includedir)" || exit $$?; \ done uninstall-includeHEADERS: @$(NORMAL_UNINSTALL) @list='$(include_HEADERS)'; test -n "$(includedir)" || list=; \ files=`for p in $$list; do echo $$p; done | sed -e 's|^.*/||'`; \ dir='$(DESTDIR)$(includedir)'; $(am__uninstall_files_from_dir) ID: $(am__tagged_files) $(am__define_uniq_tagged_files); mkid -fID $$unique tags: tags-am TAGS: tags tags-am: $(TAGS_DEPENDENCIES) $(am__tagged_files) set x; \ here=`pwd`; \ $(am__define_uniq_tagged_files); \ shift; \ if test -z "$(ETAGS_ARGS)$$*$$unique"; then :; else \ test -n "$$unique" || unique=$$empty_fix; \ if test $$# -gt 0; then \ $(ETAGS) $(ETAGSFLAGS) $(AM_ETAGSFLAGS) $(ETAGS_ARGS) \ "$$@" $$unique; \ else \ $(ETAGS) $(ETAGSFLAGS) $(AM_ETAGSFLAGS) $(ETAGS_ARGS) \ $$unique; \ fi; \ fi ctags: ctags-am CTAGS: ctags ctags-am: $(TAGS_DEPENDENCIES) $(am__tagged_files) $(am__define_uniq_tagged_files); \ test -z "$(CTAGS_ARGS)$$unique" \ || $(CTAGS) $(CTAGSFLAGS) $(AM_CTAGSFLAGS) $(CTAGS_ARGS) \ $$unique GTAGS: here=`$(am__cd) $(top_builddir) && pwd` \ && $(am__cd) $(top_srcdir) \ && gtags -i $(GTAGS_ARGS) "$$here" cscopelist: cscopelist-am cscopelist-am: $(am__tagged_files) list='$(am__tagged_files)'; \ case "$(srcdir)" in \ [\\/]* | ?:[\\/]*) sdir="$(srcdir)" ;; \ *) sdir=$(subdir)/$(srcdir) ;; \ esac; \ for i in $$list; do \ if test -f "$$i"; then \ echo "$(subdir)/$$i"; \ else \ echo "$$sdir/$$i"; \ fi; \ done >> $(top_builddir)/cscope.files distclean-tags: -rm -f TAGS ID GTAGS GRTAGS GSYMS GPATH tags distdir: $(DISTFILES) @srcdirstrip=`echo "$(srcdir)" | sed 's/[].[^$$\\*]/\\\\&/g'`; \ topsrcdirstrip=`echo "$(top_srcdir)" | sed 's/[].[^$$\\*]/\\\\&/g'`; \ list='$(DISTFILES)'; \ dist_files=`for file in $$list; do echo $$file; done | \ sed -e "s|^$$srcdirstrip/||;t" \ -e "s|^$$topsrcdirstrip/|$(top_builddir)/|;t"`; \ case $$dist_files in \ */*) $(MKDIR_P) `echo "$$dist_files" | \ sed '/\//!d;s|^|$(distdir)/|;s,/[^/]*$$,,' | \ sort -u` ;; \ esac; \ for file in $$dist_files; do \ if test -f $$file || test -d $$file; then d=.; else d=$(srcdir); fi; \ if test -d $$d/$$file; then \ dir=`echo "/$$file" | sed -e 's,/[^/]*$$,,'`; \ if test -d "$(distdir)/$$file"; then \ find "$(distdir)/$$file" -type d ! -perm -700 -exec chmod u+rwx {} \;; \ fi; \ if test -d $(srcdir)/$$file && test $$d != $(srcdir); then \ cp -fpR $(srcdir)/$$file "$(distdir)$$dir" || exit 1; \ find "$(distdir)/$$file" -type d ! -perm -700 -exec chmod u+rwx {} \;; \ fi; \ cp -fpR $$d/$$file "$(distdir)$$dir" || exit 1; \ else \ test -f "$(distdir)/$$file" \ || cp -p $$d/$$file "$(distdir)/$$file" \ || exit 1; \ fi; \ done check-am: all-am check: check-am all-am: Makefile $(LTLIBRARIES) $(HEADERS) installdirs: for dir in "$(DESTDIR)$(moduledir)" "$(DESTDIR)$(includedir)"; do \ test -z "$$dir" || $(MKDIR_P) "$$dir"; \ done install: install-am install-exec: install-exec-am install-data: install-data-am uninstall: uninstall-am install-am: all-am @$(MAKE) $(AM_MAKEFLAGS) install-exec-am install-data-am installcheck: installcheck-am install-strip: if test -z '$(STRIP)'; then \ $(MAKE) $(AM_MAKEFLAGS) INSTALL_PROGRAM="$(INSTALL_STRIP_PROGRAM)" \ install_sh_PROGRAM="$(INSTALL_STRIP_PROGRAM)" INSTALL_STRIP_FLAG=-s \ install; \ else \ $(MAKE) $(AM_MAKEFLAGS) INSTALL_PROGRAM="$(INSTALL_STRIP_PROGRAM)" \ install_sh_PROGRAM="$(INSTALL_STRIP_PROGRAM)" INSTALL_STRIP_FLAG=-s \ "INSTALL_PROGRAM_ENV=STRIPPROG='$(STRIP)'" install; \ fi mostlyclean-generic: clean-generic: distclean-generic: -test -z "$(CONFIG_CLEAN_FILES)" || rm -f $(CONFIG_CLEAN_FILES) -test . = "$(srcdir)" || test -z "$(CONFIG_CLEAN_VPATH_FILES)" || rm -f $(CONFIG_CLEAN_VPATH_FILES) maintainer-clean-generic: @echo "This command is intended for maintainers to use" @echo "it deletes files that may require special tools to rebuild." clean: clean-am clean-am: clean-generic clean-libtool clean-moduleLTLIBRARIES \ mostlyclean-am distclean: distclean-am -rm -rf ./$(DEPDIR) -rm -f Makefile distclean-am: clean-am distclean-compile distclean-generic \ distclean-tags dvi: dvi-am dvi-am: html: html-am html-am: info: info-am info-am: install-data-am: install-includeHEADERS install-moduleLTLIBRARIES install-dvi: install-dvi-am install-dvi-am: install-exec-am: install-html: install-html-am install-html-am: install-info: install-info-am install-info-am: install-man: install-pdf: install-pdf-am install-pdf-am: install-ps: install-ps-am install-ps-am: installcheck-am: maintainer-clean: maintainer-clean-am -rm -rf ./$(DEPDIR) -rm -f Makefile maintainer-clean-am: distclean-am maintainer-clean-generic mostlyclean: mostlyclean-am mostlyclean-am: mostlyclean-compile mostlyclean-generic \ mostlyclean-libtool pdf: pdf-am pdf-am: ps: ps-am ps-am: uninstall-am: uninstall-includeHEADERS uninstall-moduleLTLIBRARIES .MAKE: install-am install-strip .PHONY: CTAGS GTAGS TAGS all all-am check check-am clean clean-generic \ clean-libtool clean-moduleLTLIBRARIES cscopelist-am ctags \ ctags-am distclean distclean-compile distclean-generic \ distclean-libtool distclean-tags distdir dvi dvi-am html \ html-am info info-am install install-am install-data \ install-data-am install-dvi install-dvi-am install-exec \ install-exec-am install-html install-html-am \ install-includeHEADERS install-info install-info-am \ install-man install-moduleLTLIBRARIES install-pdf \ install-pdf-am install-ps install-ps-am install-strip \ installcheck installcheck-am installdirs maintainer-clean \ maintainer-clean-generic mostlyclean mostlyclean-compile \ mostlyclean-generic mostlyclean-libtool pdf pdf-am ps ps-am \ tags tags-am uninstall uninstall-am uninstall-includeHEADERS \ uninstall-moduleLTLIBRARIES .PRECIOUS: Makefile # Tell versions [3.59,3.63) of GNU make to not export all variables. # Otherwise a system limit (for SysV at least) may be exceeded. .NOEXPORT: xrdp-0.9.5/common/fifo.c000644 001751 001751 00000006744 13174271344 015022 0ustar00metameta000000 000000 /** * xrdp: A Remote Desktop Protocol server. * * Copyright (C) Laxmikant Rashinkar 2004-2014 * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. * * FIFO implementation to store pointer to data struct */ #if defined(HAVE_CONFIG_H) #include #endif #include "fifo.h" #include "os_calls.h" /** * Create new fifo data struct * * @return pointer to new FIFO or NULL if system out of memory *****************************************************************************/ FIFO * fifo_create(void) { return (FIFO *) g_malloc(sizeof(FIFO), 1); } /** * Delete specified FIFO *****************************************************************************/ void fifo_delete(FIFO *self) { USER_DATA *udp; if (!self) return; if (!self->head) { /* FIFO is empty */ g_free(self); return; } if (self->head == self->tail) { /* only one item in FIFO */ if (self->auto_free) g_free(self->head->item); g_free(self->head); g_free(self); return; } /* more then one item in FIFO */ while (self->head) { udp = self->head; if (self->auto_free) g_free(udp->item); self->head = udp->next; g_free(udp); } g_free(self); } /** * Add an item to the specified FIFO * * @param self FIFO to operate on * @param item item to add to specified FIFO * * @return 0 on success, -1 on error *****************************************************************************/ int fifo_add_item(FIFO *self, void *item) { USER_DATA *udp; if (!self || !item) return -1; if ((udp = (USER_DATA *) g_malloc(sizeof(USER_DATA), 0)) == 0) return -1; udp->item = item; udp->next = 0; /* if fifo is empty, add to head */ if (!self->head) { self->head = udp; self->tail = udp; return 0; } /* add to tail */ self->tail->next = udp; self->tail = udp; return 0; } /** * Return an item from top of FIFO * * @param self FIFO to operate on * * @return top item from FIFO or NULL if FIFO is empty *****************************************************************************/ void * fifo_remove_item(FIFO *self) { void *item; USER_DATA *udp; if (!self || !self->head) return 0; if (self->head == self->tail) { /* only one item in FIFO */ item = self->head->item; g_free(self->head); self->head = 0; self->tail = 0; return item; } /* more then one item in FIFO */ udp = self->head; item = self->head->item; self->head = self->head->next; g_free(udp); return item; } /** * Return FIFO status * * @param self FIFO to operate on * * @return true if FIFO is empty, false otherwise *****************************************************************************/ int fifo_is_empty(FIFO *self) { if (!self) return 1; return (self->head == 0); } xrdp-0.9.5/common/list16.c000644 001751 001751 00000010356 13174271344 015213 0ustar00metameta000000 000000 /** * xrdp: A Remote Desktop Protocol server. * * Copyright (C) Jay Sorg 2004-2014 * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. * * simple list */ #if defined(HAVE_CONFIG_H) #include #endif #include "arch.h" #include "os_calls.h" #include "list16.h" /*****************************************************************************/ struct list16 * list16_create(void) { struct list16 *self; self = (struct list16 *)g_malloc(sizeof(struct list16), 0); list16_init(self); return self; } /*****************************************************************************/ void list16_delete(struct list16 *self) { if (self == 0) { return; } list16_deinit(self); g_free(self); } /*****************************************************************************/ void list16_init(struct list16* self) { g_memset(self, 0, sizeof(struct list16)); self->max_count = 4; self->items = self->mitems; } /*****************************************************************************/ void list16_deinit(struct list16* self) { if (self->items != self->mitems) { g_free(self->items); } } /*****************************************************************************/ void list16_add_item(struct list16 *self, tui16 item) { tui16 *p; int i; if (self->count >= self->max_count) { i = self->max_count; self->max_count += 4; p = (tui16 *)g_malloc(sizeof(tui16) * self->max_count, 1); g_memcpy(p, self->items, sizeof(tui16) * i); if (self->items != self->mitems) { g_free(self->items); } self->items = p; } self->items[self->count] = item; self->count++; } /*****************************************************************************/ tui16 list16_get_item(struct list16 *self, int index) { if (index < 0 || index >= self->count) { return 0; } return self->items[index]; } /*****************************************************************************/ void list16_clear(struct list16 *self) { if (self->items != self->mitems) { g_free(self->items); } self->count = 0; self->max_count = 4; self->items = self->mitems; } /*****************************************************************************/ int list16_index_of(struct list16 *self, tui16 item) { int i; for (i = 0; i < self->count; i++) { if (self->items[i] == item) { return i; } } return -1; } /*****************************************************************************/ void list16_remove_item(struct list16 *self, int index) { int i; if (index >= 0 && index < self->count) { for (i = index; i < (self->count - 1); i++) { self->items[i] = self->items[i + 1]; } self->count--; } } /*****************************************************************************/ void list16_insert_item(struct list16 *self, int index, tui16 item) { tui16 *p; int i; if (index == self->count) { list16_add_item(self, item); return; } if (index >= 0 && index < self->count) { self->count++; if (self->count > self->max_count) { i = self->max_count; self->max_count += 4; p = (tui16 *)g_malloc(sizeof(tui16) * self->max_count, 1); g_memcpy(p, self->items, sizeof(tui16) * i); if (self->items != self->mitems) { g_free(self->items); } self->items = p; } for (i = (self->count - 2); i >= index; i--) { self->items[i + 1] = self->items[i]; } self->items[index] = item; } } xrdp-0.9.5/common/trans.h000644 001751 001751 00000007512 13220727201 015213 0ustar00metameta000000 000000 /** * xrdp: A Remote Desktop Protocol server. * * Copyright (C) Jay Sorg 2004-2014 * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. * * generic transport */ #if !defined(TRANS_H) #define TRANS_H #include "arch.h" #include "parse.h" #define TRANS_MODE_TCP 1 #define TRANS_MODE_UNIX 2 #define TRANS_MODE_VSOCK 3 #define TRANS_TYPE_LISTENER 1 #define TRANS_TYPE_SERVER 2 #define TRANS_TYPE_CLIENT 3 #define TRANS_STATUS_DOWN 0 #define TRANS_STATUS_UP 1 struct trans; /* forward declaration */ struct xrdp_tls; typedef int (*ttrans_data_in)(struct trans* self); typedef int (*ttrans_conn_in)(struct trans* self, struct trans* new_self); typedef int (*tis_term)(void); typedef int (*trans_recv_proc) (struct trans *self, char *ptr, int len); typedef int (*trans_send_proc) (struct trans *self, const char *data, int len); typedef int (*trans_can_recv_proc) (struct trans *self, int sck, int millis); /* optional source info */ #define XRDP_SOURCE_NONE 0 #define XRDP_SOURCE_CLIENT 1 #define XRDP_SOURCE_SESMAN 2 #define XRDP_SOURCE_CHANSRV 3 #define XRDP_SOURCE_MOD 4 struct source_info { int cur_source; int source[7]; }; struct trans { tbus sck; /* socket handle */ int mode; /* 1 tcp, 2 unix socket, 3 vsock */ int status; int type1; /* 1 listener 2 server 3 client */ ttrans_data_in trans_data_in; ttrans_conn_in trans_conn_in; void* callback_data; int header_size; struct stream* in_s; struct stream* out_s; char* listen_filename; tis_term is_term; /* used to test for exit */ struct stream* wait_s; char addr[256]; char port[256]; int no_stream_init_on_data_in; int extra_flags; /* user defined */ struct ssl_tls *tls; const char *ssl_protocol; /* e.g. TLSv1, TLSv1.1, TLSv1.2, unknown */ const char *cipher_name; /* e.g. AES256-GCM-SHA384 */ trans_recv_proc trans_recv; trans_send_proc trans_send; trans_can_recv_proc trans_can_recv; struct source_info *si; int my_source; }; struct trans* trans_create(int mode, int in_size, int out_size); void trans_delete(struct trans* self); int trans_get_wait_objs(struct trans* self, tbus* objs, int* count); int trans_get_wait_objs_rw(struct trans *self, tbus *robjs, int *rcount, tbus *wobjs, int *wcount, int *timeout); int trans_check_wait_objs(struct trans* self); int trans_force_read_s(struct trans* self, struct stream* in_s, int size); int trans_force_write_s(struct trans* self, struct stream* out_s); int trans_force_read(struct trans* self, int size); int trans_force_write(struct trans* self); int trans_write_copy(struct trans* self); int trans_write_copy_s(struct trans* self, struct stream* out_s); int trans_connect(struct trans* self, const char* server, const char* port, int timeout); int trans_listen_address(struct trans* self, char* port, const char* address); int trans_listen(struct trans* self, char* port); struct stream* trans_get_in_s(struct trans* self); struct stream* trans_get_out_s(struct trans* self, int size); int trans_set_tls_mode(struct trans *self, const char *key, const char *cert, long ssl_protocols, const char *tls_ciphers); int trans_shutdown_tls_mode(struct trans *self); int trans_tcp_force_read_s(struct trans *self, struct stream *in_s, int size); #endif xrdp-0.9.5/common/os_calls.h000644 001751 001751 00000020267 13220727201 015665 0ustar00metameta000000 000000 /** * xrdp: A Remote Desktop Protocol server. * * Copyright (C) Jay Sorg 2004-2014 * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. * * generic operating system calls */ #if !defined(OS_CALLS_H) #define OS_CALLS_H #include "arch.h" #define g_tcp_can_recv g_sck_can_recv #define g_tcp_can_send g_sck_can_send #define g_tcp_recv g_sck_recv #define g_tcp_send g_sck_send #define g_tcp_close g_sck_close #define g_tcp_last_error_would_block g_sck_last_error_would_block #define g_tcp_set_non_blocking g_sck_set_non_blocking #define g_tcp_local_socket g_sck_local_socket #define g_tcp_local_connect g_sck_local_connect #define g_tcp_listen g_sck_listen #define g_tcp_local_bind g_sck_local_bind #define g_tcp_select g_sck_select #define g_close_wait_obj g_delete_wait_obj int g_rm_temp_dir(void); int g_mk_socket_path(const char* app_name); void g_init(const char* app_name); void g_deinit(void); void* g_malloc(int size, int zero); void g_free(void* ptr); void g_printf(const char *format, ...) printflike(1, 2); void g_sprintf(char* dest, const char* format, ...) \ printflike(2, 3); int g_snprintf(char* dest, int len, const char* format, ...) \ printflike(3, 4); void g_writeln(const char* format, ...) printflike(1, 2); void g_write(const char* format, ...) printflike(1, 2); void g_hexdump(const char *p, int len); void g_memset(void* ptr, int val, int size); void g_memcpy(void* d_ptr, const void* s_ptr, int size); int g_getchar(void); int g_tcp_set_no_delay(int sck); int g_tcp_set_keepalive(int sck); int g_tcp_socket(void); int g_sck_set_send_buffer_bytes(int sck, int bytes); int g_sck_get_send_buffer_bytes(int sck, int *bytes); int g_sck_set_recv_buffer_bytes(int sck, int bytes); int g_sck_get_recv_buffer_bytes(int sck, int *bytes); int g_sck_local_socket(void); int g_sck_vsock_socket(void); int g_sck_get_peer_cred(int sck, int *pid, int *uid, int *gid); void g_sck_close(int sck); int g_tcp_connect(int sck, const char* address, const char* port); int g_sck_local_connect(int sck, const char* port); int g_sck_set_non_blocking(int sck); int g_tcp_bind(int sck, const char *port); int g_sck_local_bind(int sck, const char* port); int g_sck_vsock_bind(int sck, const char* port); int g_tcp_bind_address(int sck, const char* port, const char* address); int g_sck_listen(int sck); int g_tcp_accept(int sck); int g_sck_accept(int sck, char *addr, int addr_bytes, char *port, int port_bytes); int g_sck_recv(int sck, void* ptr, int len, int flags); int g_sck_send(int sck, const void* ptr, int len, int flags); int g_sck_last_error_would_block(int sck); int g_sck_socket_ok(int sck); int g_sck_can_send(int sck, int millis); int g_sck_can_recv(int sck, int millis); int g_sck_select(int sck1, int sck2); void g_write_ip_address(int rcv_sck, char* ip_address, int bytes); void g_sleep(int msecs); tintptr g_create_wait_obj(const char *name); tintptr g_create_wait_obj_from_socket(tintptr socket, int write); void g_delete_wait_obj_from_socket(tintptr wait_obj); int g_set_wait_obj(tintptr obj); int g_reset_wait_obj(tintptr obj); int g_is_wait_obj_set(tintptr obj); int g_delete_wait_obj(tintptr obj); int g_obj_wait(tintptr* read_objs, int rcount, tintptr* write_objs, int wcount,int mstimeout); void g_random(char* data, int len); int g_abs(int i); int g_memcmp(const void* s1, const void* s2, int len); int g_file_open(const char* file_name); int g_file_open_ex(const char *file_name, int aread, int awrite, int acreate, int atrunc); int g_file_close(int fd); int g_file_read(int fd, char* ptr, int len); int g_file_write(int fd, const char *ptr, int len); int g_file_seek(int fd, int offset); int g_file_lock(int fd, int start, int len); int g_chmod_hex(const char* filename, int flags); int g_chown(const char* name, int uid, int gid); int g_mkdir(const char* dirname); char* g_get_current_dir(char* dirname, int maxlen); int g_set_current_dir(const char *dirname); int g_file_exist(const char* filename); int g_file_readable(const char *filename); int g_directory_exist(const char* dirname); int g_create_dir(const char* dirname); int g_create_path(const char* path); int g_remove_dir(const char* dirname); int g_file_delete(const char* filename); int g_file_get_size(const char* filename); int g_strlen(const char* text); const char *g_strchr(const char *text, int c); char* g_strcpy(char* dest, const char* src); char* g_strncpy(char* dest, const char* src, int len); char* g_strcat(char* dest, const char* src); char* g_strdup(const char* in); char* g_strndup(const char* in, const unsigned int maxlen); int g_strcmp(const char* c1, const char* c2); int g_strncmp(const char* c1, const char* c2, int len); int g_strncmp_d(const char* c1, const char* c2, const char delim, int len); int g_strcasecmp(const char* c1, const char* c2); int g_strncasecmp(const char* c1, const char* c2, int len); int g_atoi(const char* str); int g_htoi(char* str); int g_bytes_to_hexstr(const void *bytes, int num_bytes, char *out_str, int bytes_out_str); int g_pos(const char* str, const char* to_find); int g_mbstowcs(twchar* dest, const char* src, int n); int g_wcstombs(char* dest, const twchar* src, int n); int g_strtrim(char* str, int trim_flags); long g_load_library(char* in); int g_free_library(long lib); void* g_get_proc_address(long lib, const char* name); int g_system(char* aexec); char* g_get_strerror(void); int g_get_errno(void); int g_execvp(const char* p1, char* args[]); int g_execlp3(const char* a1, const char* a2, const char* a3); void g_signal_child_stop(void (*func)(int)); void g_signal_segfault(void (*func)(int)); void g_signal_hang_up(void (*func)(int)); void g_signal_user_interrupt(void (*func)(int)); void g_signal_terminate(void (*func)(int)); void g_signal_pipe(void (*func)(int)); void g_signal_usr1(void (*func)(int)); int g_fork(void); int g_setgid(int pid); int g_initgroups(const char* user, int gid); int g_getuid(void); int g_getgid(void); int g_setuid(int pid); int g_setsid(void); int g_setlogin(const char *name); int g_waitchild(void); int g_waitpid(int pid); void g_clearenv(void); int g_setenv(const char* name, const char* value, int rewrite); char* g_getenv(const char* name); int g_exit(int exit_code); int g_getpid(void); int g_sigterm(int pid); int g_getuser_info(const char* username, int* gid, int* uid, char** shell, char** dir, char** gecos); int g_getgroup_info(const char* groupname, int* gid); int g_check_user_in_group(const char* username, int gid, int* ok); int g_time1(void); int g_time2(void); int g_time3(void); int g_save_to_bmp(const char* filename, char* data, int stride_bytes, int width, int height, int depth, int bits_per_pixel); int g_text2bool(const char *s); void * g_shmat(int shmid); int g_shmdt(const void *shmaddr); int g_gethostname(char *name, int len); int g_mirror_memcpy(void *dst, const void *src, int len); /* glib-style wrappers */ #define g_new(struct_type, n_structs) \ (struct_type *) malloc(sizeof(struct_type) * (n_structs)) #define g_new0(struct_type, n_structs) \ (struct_type *) calloc((n_structs), sizeof(struct_type)) #endif xrdp-0.9.5/common/file.h000644 001751 001751 00000002136 13174271344 015012 0ustar00metameta000000 000000 /** * xrdp: A Remote Desktop Protocol server. * * Copyright (C) Jay Sorg 2004-2014 * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. * * read a config file */ #if !defined(FILE_H) #define FILE_H #include "arch.h" int file_read_sections(int fd, struct list* names); int file_by_name_read_sections(const char* file_name, struct list* names); int file_read_section(int fd, const char* section, struct list* names, struct list* values); int file_by_name_read_section(const char* file_name, const char* section, struct list* names, struct list* values); #endif xrdp-0.9.5/common/thread_calls.h000644 001751 001751 00000002170 13174271344 016516 0ustar00metameta000000 000000 /** * xrdp: A Remote Desktop Protocol server. * * Copyright (C) Jay Sorg 2004-2014 * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. * * thread calls */ #if !defined(THREAD_CALLS_H) #define THREAD_CALLS_H #include "arch.h" int tc_thread_create(THREAD_RV (THREAD_CC * start_routine)(void*), void* arg); tbus tc_get_threadid(void); int tc_threadid_equal(tbus tid1, tbus tid2); tbus tc_mutex_create(void); void tc_mutex_delete(tbus mutex); int tc_mutex_lock(tbus mutex); int tc_mutex_unlock(tbus mutex); tbus tc_sem_create(int init_count); void tc_sem_delete(tbus sem); int tc_sem_dec(tbus sem); int tc_sem_inc(tbus sem); #endif xrdp-0.9.5/common/pixman-region.h000644 001751 001751 00000005510 13127114621 016637 0ustar00metameta000000 000000 /** * xrdp: A Remote Desktop Protocol server. * * Copyright (C) Jay Sorg 2016 * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. * * region, from pixman.h */ #if !defined(PIXMAN_PIXMAN_H__) #define PIXMAN_PIXMAN_H__ typedef int pixman_bool_t; struct pixman_region16_data { long size; long numRects; }; struct pixman_box16 { signed short x1, y1, x2, y2; }; struct pixman_region16 { struct pixman_box16 extents; struct pixman_region16_data *data; }; enum _pixman_region_overlap_t { PIXMAN_REGION_OUT, PIXMAN_REGION_IN, PIXMAN_REGION_PART }; typedef enum _pixman_region_overlap_t pixman_region_overlap_t; typedef struct pixman_region16_data pixman_region16_data_t; typedef struct pixman_box16 pixman_box16_t; typedef struct pixman_region16 pixman_region16_t; /* creation/destruction */ void pixman_region_init (pixman_region16_t *region); void pixman_region_init_rect (pixman_region16_t *region, int x, int y, unsigned int width, unsigned int height); void pixman_region_fini (pixman_region16_t *region); pixman_bool_t pixman_region_union (pixman_region16_t *new_reg, pixman_region16_t *reg1, pixman_region16_t *reg2); pixman_bool_t pixman_region_subtract (pixman_region16_t *reg_d, pixman_region16_t *reg_m, pixman_region16_t *reg_s); pixman_bool_t pixman_region_intersect (pixman_region16_t *new_reg, pixman_region16_t *reg1, pixman_region16_t *reg2); pixman_box16_t * pixman_region_rectangles (pixman_region16_t *region, int *n_rects); #endif xrdp-0.9.5/common/rail.h000644 001751 001751 00000010750 13125122133 015006 0ustar00metameta000000 000000 /** * xrdp: A Remote Desktop Protocol server. * * Copyright (C) Jay Sorg 2012-2014 * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ #if !defined(_RAIL_H) #define _RAIL_H /* ORDER_TYPE_WINDOW WINDOW_ORDER_TYPE_WINDOW WINDOW_ORDER_ICON WINDOW_ORDER_CACHED_ICON WINDOW_ORDER_STATE_DELETED WINDOW_ORDER_STATE_NEW on WINDOW_ORDER_STATE_NEW off WINDOW_ORDER_TYPE_NOTIFY WINDOW_ORDER_STATE_DELETED WINDOW_ORDER_STATE_NEW on WINDOW_ORDER_STATE_NEW off WINDOW_ORDER_TYPE_DESKTOP WINDOW_ORDER_FIELD_DESKTOP_NONE on WINDOW_ORDER_FIELD_DESKTOP_NONE off */ /* Window Order Header Flags */ #define WINDOW_ORDER_TYPE_WINDOW 0x01000000 #define WINDOW_ORDER_TYPE_NOTIFY 0x02000000 #define WINDOW_ORDER_TYPE_DESKTOP 0x04000000 #define WINDOW_ORDER_STATE_NEW 0x10000000 #define WINDOW_ORDER_STATE_DELETED 0x20000000 #define WINDOW_ORDER_FIELD_OWNER 0x00000002 #define WINDOW_ORDER_FIELD_STYLE 0x00000008 #define WINDOW_ORDER_FIELD_SHOW 0x00000010 #define WINDOW_ORDER_FIELD_TITLE 0x00000004 #define WINDOW_ORDER_FIELD_CLIENT_AREA_OFFSET 0x00004000 #define WINDOW_ORDER_FIELD_CLIENT_AREA_SIZE 0x00010000 #define WINDOW_ORDER_FIELD_RP_CONTENT 0x00020000 #define WINDOW_ORDER_FIELD_ROOT_PARENT 0x00040000 #define WINDOW_ORDER_FIELD_WND_OFFSET 0x00000800 #define WINDOW_ORDER_FIELD_WND_CLIENT_DELTA 0x00008000 #define WINDOW_ORDER_FIELD_WND_SIZE 0x00000400 #define WINDOW_ORDER_FIELD_WND_RECTS 0x00000100 #define WINDOW_ORDER_FIELD_VIS_OFFSET 0x00001000 #define WINDOW_ORDER_FIELD_VISIBILITY 0x00000200 #define WINDOW_ORDER_FIELD_ICON_BIG 0x00002000 #define WINDOW_ORDER_ICON 0x40000000 #define WINDOW_ORDER_CACHED_ICON 0x80000000 #define WINDOW_ORDER_FIELD_NOTIFY_VERSION 0x00000008 #define WINDOW_ORDER_FIELD_NOTIFY_TIP 0x00000001 #define WINDOW_ORDER_FIELD_NOTIFY_INFO_TIP 0x00000002 #define WINDOW_ORDER_FIELD_NOTIFY_STATE 0x00000004 #define WINDOW_ORDER_FIELD_DESKTOP_NONE 0x00000001 #define WINDOW_ORDER_FIELD_DESKTOP_HOOKED 0x00000002 #define WINDOW_ORDER_FIELD_DESKTOP_ARC_COMPLETED 0x00000004 #define WINDOW_ORDER_FIELD_DESKTOP_ARC_BEGAN 0x00000008 #define WINDOW_ORDER_FIELD_DESKTOP_ZORDER 0x00000010 #define WINDOW_ORDER_FIELD_DESKTOP_ACTIVE_WND 0x00000020 struct rail_icon_info { int bpp; int width; int height; int cmap_bytes; int mask_bytes; int data_bytes; char* mask; char* cmap; char* data; }; struct rail_window_rect { short left; short top; short right; short bottom; }; struct rail_notify_icon_infotip { int timeout; int flags; char* text; char* title; }; struct rail_window_state_order { int owner_window_id; int style; int extended_style; int show_state; char* title_info; int client_offset_x; int client_offset_y; int client_area_width; int client_area_height; int rp_content; int root_parent_handle; int window_offset_x; int window_offset_y; int window_client_delta_x; int window_client_delta_y; int window_width; int window_height; int num_window_rects; struct rail_window_rect* window_rects; int visible_offset_x; int visible_offset_y; int num_visibility_rects; struct rail_window_rect* visibility_rects; }; struct rail_notify_state_order { int version; char* tool_tip; struct rail_notify_icon_infotip infotip; int state; int icon_cache_entry; int icon_cache_id; struct rail_icon_info icon_info; }; struct rail_monitored_desktop_order { int active_window_id; int num_window_ids; int* window_ids; }; #endif xrdp-0.9.5/common/Makefile.am000644 001751 001751 00000002042 13220727201 015740 0ustar00metameta000000 000000 if XRDP_PIXMAN PIXMAN_SOURCES = else PIXMAN_SOURCES = pixman-region16.c pixman-region.h endif EXTRA_DIST = pixman-region.c include_HEADERS = \ xrdp_client_info.h \ xrdp_constants.h \ xrdp_rail.h \ xrdp_sockets.h AM_CPPFLAGS = \ -DXRDP_CFG_PATH=\"${sysconfdir}/xrdp\" \ -DXRDP_SBIN_PATH=\"${sbindir}\" \ -DXRDP_SHARE_PATH=\"${datadir}/xrdp\" \ -DXRDP_PID_PATH=\"${localstatedir}/run\" \ -DXRDP_LOG_PATH=\"${localstatedir}/log\" \ -DXRDP_SOCKET_PATH=\"${socketdir}\" if XRDP_DEBUG AM_CPPFLAGS += -DXRDP_DEBUG endif AM_CFLAGS = $(OPENSSL_CFLAGS) module_LTLIBRARIES = \ libcommon.la libcommon_la_SOURCES = \ arch.h \ base64.h \ base64.c \ defines.h \ fifo.c \ fifo.h \ file.c \ file.h \ list.c \ list.h \ list16.c \ list16.h \ log.c \ log.h \ os_calls.c \ os_calls.h \ os_calls.h \ parse.h \ rail.h \ ssl_calls.c \ ssl_calls.h \ thread_calls.c \ thread_calls.h \ trans.c \ trans.h \ $(PIXMAN_SOURCES) libcommon_la_LIBADD = \ -lpthread \ $(OPENSSL_LIBS) \ $(DLOPEN_LIBS) xrdp-0.9.5/common/fifo.h000644 001751 001751 00000002202 13174271344 015010 0ustar00metameta000000 000000 /** * xrdp: A Remote Desktop Protocol server. * * Copyright (C) Laxmikant Rashinkar 2004-2014 * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. * * FIFO implementation to store pointer to data struct */ #ifndef _FIFO_H #define _FIFO_H #include "arch.h" typedef struct user_data USER_DATA; struct user_data { USER_DATA *next; void *item; }; typedef struct fifo { USER_DATA *head; USER_DATA *tail; int auto_free; } FIFO; FIFO * fifo_create(void); void fifo_delete(FIFO *self); int fifo_add_item(FIFO *self, void *item); void * fifo_remove_item(FIFO *self); int fifo_is_empty(FIFO *self); #endif xrdp-0.9.5/common/list16.h000644 001751 001751 00000002446 13174271344 015221 0ustar00metameta000000 000000 /** * xrdp: A Remote Desktop Protocol server. * * Copyright (C) Jay Sorg 2004-2014 * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. * * simple list */ #if !defined(LIST16_H) #define LIST16_H #include "arch.h" /* list */ struct list16 { tui16* items; int count; int max_count; tui16 mitems[4]; }; struct list16* list16_create(void); void list16_delete(struct list16* self); void list16_init(struct list16* self); void list16_deinit(struct list16* self); void list16_add_item(struct list16* self, tui16 item); tui16 list16_get_item(struct list16* self, int index); void list16_clear(struct list16* self); int list16_index_of(struct list16* self, tui16 item); void list16_remove_item(struct list16* self, int index); void list16_insert_item(struct list16* self, int index, tui16 item); #endif xrdp-0.9.5/common/trans.c000644 001751 001751 00000056145 13220727201 015214 0ustar00metameta000000 000000 /** * xrdp: A Remote Desktop Protocol server. * * Copyright (C) Jay Sorg 2004-2014 * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. * * generic transport */ #if defined(HAVE_CONFIG_H) #include #endif #include "os_calls.h" #include "trans.h" #include "arch.h" #include "parse.h" #include "ssl_calls.h" #define MAX_SBYTES 0 /*****************************************************************************/ int trans_tls_recv(struct trans *self, char *ptr, int len) { if (self->tls == NULL) { return 1; } return ssl_tls_read(self->tls, ptr, len); } /*****************************************************************************/ int trans_tls_send(struct trans *self, const char *data, int len) { if (self->tls == NULL) { return 1; } return ssl_tls_write(self->tls, data, len); } /*****************************************************************************/ int trans_tls_can_recv(struct trans *self, int sck, int millis) { if (self->tls == NULL) { return 1; } return ssl_tls_can_recv(self->tls, sck, millis); } /*****************************************************************************/ int trans_tcp_recv(struct trans *self, char *ptr, int len) { return g_tcp_recv(self->sck, ptr, len, 0); } /*****************************************************************************/ int trans_tcp_send(struct trans *self, const char *data, int len) { return g_tcp_send(self->sck, data, len, 0); } /*****************************************************************************/ int trans_tcp_can_recv(struct trans *self, int sck, int millis) { return g_sck_can_recv(sck, millis); } /*****************************************************************************/ struct trans * trans_create(int mode, int in_size, int out_size) { struct trans *self = (struct trans *) NULL; self = (struct trans *) g_malloc(sizeof(struct trans), 1); if (self != NULL) { make_stream(self->in_s); init_stream(self->in_s, in_size); make_stream(self->out_s); init_stream(self->out_s, out_size); self->mode = mode; self->tls = 0; /* assign tcp calls by default */ self->trans_recv = trans_tcp_recv; self->trans_send = trans_tcp_send; self->trans_can_recv = trans_tcp_can_recv; } return self; } /*****************************************************************************/ void trans_delete(struct trans *self) { if (self == 0) { return; } free_stream(self->in_s); free_stream(self->out_s); if (self->sck > 0) { g_tcp_close(self->sck); } self->sck = 0; if (self->listen_filename != 0) { g_file_delete(self->listen_filename); g_free(self->listen_filename); } if (self->tls != 0) { ssl_tls_delete(self->tls); } g_free(self); } /*****************************************************************************/ int trans_get_wait_objs(struct trans *self, tbus *objs, int *count) { if (self == 0) { return 1; } if (self->status != TRANS_STATUS_UP) { return 1; } objs[*count] = self->sck; (*count)++; if (self->tls != 0) { if (self->tls->rwo != 0) { objs[*count] = self->tls->rwo; (*count)++; } } return 0; } /*****************************************************************************/ int trans_get_wait_objs_rw(struct trans *self, tbus *robjs, int *rcount, tbus *wobjs, int *wcount, int *timeout) { if (self == 0) { return 1; } if (self->status != TRANS_STATUS_UP) { return 1; } if ((self->si != 0) && (self->si->source[self->my_source] > MAX_SBYTES)) { } else { if (trans_get_wait_objs(self, robjs, rcount) != 0) { return 1; } } if (self->wait_s != 0) { wobjs[*wcount] = self->sck; (*wcount)++; } return 0; } /*****************************************************************************/ int trans_send_waiting(struct trans *self, int block) { struct stream *temp_s; int bytes; int sent; int timeout; int cont; timeout = block ? 100 : 0; cont = 1; while (cont) { if (self->wait_s != 0) { temp_s = self->wait_s; if (g_tcp_can_send(self->sck, timeout)) { bytes = (int) (temp_s->end - temp_s->p); sent = self->trans_send(self, temp_s->p, bytes); if (sent > 0) { temp_s->p += sent; if (temp_s->source != 0) { temp_s->source[0] -= sent; } if (temp_s->p >= temp_s->end) { self->wait_s = temp_s->next; free_stream(temp_s); } } else if (sent == 0) { return 1; } else { if (!g_tcp_last_error_would_block(self->sck)) { return 1; } } } else if (block) { /* check for term here */ if (self->is_term != 0) { if (self->is_term()) { /* term */ return 1; } } } } else { break; } cont = block; } return 0; } /*****************************************************************************/ int trans_check_wait_objs(struct trans *self) { tbus in_sck = (tbus) 0; struct trans *in_trans = (struct trans *) NULL; int read_bytes = 0; int to_read = 0; int read_so_far = 0; int rv = 0; int cur_source; if (self == 0) { return 1; } if (self->status != TRANS_STATUS_UP) { return 1; } rv = 0; if (self->type1 == TRANS_TYPE_LISTENER) /* listening */ { if (g_sck_can_recv(self->sck, 0)) { in_sck = g_sck_accept(self->sck, self->addr, sizeof(self->addr), self->port, sizeof(self->port)); if (in_sck == -1) { if (g_tcp_last_error_would_block(self->sck)) { /* ok, but shouldn't happen */ } else { /* error */ self->status = TRANS_STATUS_DOWN; return 1; } } if (in_sck != -1) { if (self->trans_conn_in != 0) /* is function assigned */ { in_trans = trans_create(self->mode, self->in_s->size, self->out_s->size); in_trans->sck = in_sck; in_trans->type1 = TRANS_TYPE_SERVER; in_trans->status = TRANS_STATUS_UP; in_trans->is_term = self->is_term; g_strncpy(in_trans->addr, self->addr, sizeof(self->addr) - 1); g_strncpy(in_trans->port, self->port, sizeof(self->port) - 1); g_sck_set_non_blocking(in_sck); if (self->trans_conn_in(self, in_trans) != 0) { trans_delete(in_trans); } } else { g_tcp_close(in_sck); } } } } else /* connected server or client (2 or 3) */ { if (self->si != 0 && self->si->source[self->my_source] > MAX_SBYTES) { } else if (self->trans_can_recv(self, self->sck, 0)) { cur_source = 0; if (self->si != 0) { cur_source = self->si->cur_source; self->si->cur_source = self->my_source; } read_so_far = (int) (self->in_s->end - self->in_s->data); to_read = self->header_size - read_so_far; if (to_read > 0) { read_bytes = self->trans_recv(self, self->in_s->end, to_read); if (read_bytes == -1) { if (g_tcp_last_error_would_block(self->sck)) { /* ok, but shouldn't happen */ } else { /* error */ self->status = TRANS_STATUS_DOWN; if (self->si != 0) { self->si->cur_source = cur_source; } return 1; } } else if (read_bytes == 0) { /* error */ self->status = TRANS_STATUS_DOWN; if (self->si != 0) { self->si->cur_source = cur_source; } return 1; } else { self->in_s->end += read_bytes; } } read_so_far = (int) (self->in_s->end - self->in_s->data); if (read_so_far == self->header_size) { if (self->trans_data_in != 0) { rv = self->trans_data_in(self); if (self->no_stream_init_on_data_in == 0) { init_stream(self->in_s, 0); } } } if (self->si != 0) { self->si->cur_source = cur_source; } } if (trans_send_waiting(self, 0) != 0) { /* error */ self->status = TRANS_STATUS_DOWN; return 1; } } return rv; } /*****************************************************************************/ int trans_force_read_s(struct trans *self, struct stream *in_s, int size) { int rcvd; if (self->status != TRANS_STATUS_UP) { return 1; } while (size > 0) { /* make sure stream has room */ if ((in_s->end + size) > (in_s->data + in_s->size)) { return 1; } rcvd = self->trans_recv(self, in_s->end, size); if (rcvd == -1) { if (g_tcp_last_error_would_block(self->sck)) { if (!self->trans_can_recv(self, self->sck, 100)) { /* check for term here */ if (self->is_term != 0) { if (self->is_term()) { /* term */ self->status = TRANS_STATUS_DOWN; return 1; } } } } else { /* error */ self->status = TRANS_STATUS_DOWN; return 1; } } else if (rcvd == 0) { /* error */ self->status = TRANS_STATUS_DOWN; return 1; } else { in_s->end += rcvd; size -= rcvd; } } return 0; } /*****************************************************************************/ int trans_force_read(struct trans *self, int size) { return trans_force_read_s(self, self->in_s, size); } /*****************************************************************************/ int trans_force_write_s(struct trans *self, struct stream *out_s) { int size; int total; int sent; if (self->status != TRANS_STATUS_UP) { return 1; } size = (int) (out_s->end - out_s->data); total = 0; if (trans_send_waiting(self, 1) != 0) { self->status = TRANS_STATUS_DOWN; return 1; } while (total < size) { sent = self->trans_send(self, out_s->data + total, size - total); if (sent == -1) { if (g_tcp_last_error_would_block(self->sck)) { if (!g_tcp_can_send(self->sck, 100)) { /* check for term here */ if (self->is_term != 0) { if (self->is_term()) { /* term */ self->status = TRANS_STATUS_DOWN; return 1; } } } } else { /* error */ self->status = TRANS_STATUS_DOWN; return 1; } } else if (sent == 0) { /* error */ self->status = TRANS_STATUS_DOWN; return 1; } else { total = total + sent; } } return 0; } /*****************************************************************************/ int trans_force_write(struct trans *self) { return trans_force_write_s(self, self->out_s); } /*****************************************************************************/ int trans_write_copy_s(struct trans *self, struct stream *out_s) { int size; int sent; struct stream *wait_s; struct stream *temp_s; char *out_data; if (self->status != TRANS_STATUS_UP) { return 1; } /* try to send any left over */ if (trans_send_waiting(self, 0) != 0) { /* error */ self->status = TRANS_STATUS_DOWN; return 1; } out_data = out_s->data; sent = 0; size = (int) (out_s->end - out_s->data); if (self->wait_s == 0) { /* if no left over, try to send this new data */ if (g_tcp_can_send(self->sck, 0)) { sent = self->trans_send(self, out_s->data, size); if (sent > 0) { out_data += sent; size -= sent; } else if (sent == 0) { return 1; } else { if (!g_tcp_last_error_would_block(self->sck)) { return 1; } } } } if (size < 1) { return 0; } /* did not send right away, have to copy */ make_stream(wait_s); init_stream(wait_s, size); if (self->si != 0) { if ((self->si->cur_source != 0) && (self->si->cur_source != self->my_source)) { self->si->source[self->si->cur_source] += size; wait_s->source = self->si->source + self->si->cur_source; } } out_uint8a(wait_s, out_data, size); s_mark_end(wait_s); wait_s->p = wait_s->data; if (self->wait_s == 0) { self->wait_s = wait_s; } else { temp_s = self->wait_s; while (temp_s->next != 0) { temp_s = temp_s->next; } temp_s->next = wait_s; } return 0; } /*****************************************************************************/ int trans_write_copy(struct trans* self) { return trans_write_copy_s(self, self->out_s); } /*****************************************************************************/ int trans_connect(struct trans *self, const char *server, const char *port, int timeout) { int error; int now; int start_time; start_time = g_time3(); if (self->sck != 0) { g_tcp_close(self->sck); self->sck = 0; } if (self->mode == TRANS_MODE_TCP) /* tcp */ { self->sck = g_tcp_socket(); if (self->sck < 0) { self->status = TRANS_STATUS_DOWN; return 1; } g_tcp_set_non_blocking(self->sck); while (1) { error = g_tcp_connect(self->sck, server, port); if (error == 0) { break; } else { if (timeout < 1) { self->status = TRANS_STATUS_DOWN; return 1; } now = g_time3(); if (now - start_time < timeout) { g_sleep(timeout / 5); } else { self->status = TRANS_STATUS_DOWN; return 1; } } } } else if (self->mode == TRANS_MODE_UNIX) /* unix socket */ { self->sck = g_tcp_local_socket(); if (self->sck < 0) { self->status = TRANS_STATUS_DOWN; return 1; } g_tcp_set_non_blocking(self->sck); while (1) { error = g_tcp_local_connect(self->sck, port); if (error == 0) { break; } else { if (timeout < 1) { self->status = TRANS_STATUS_DOWN; return 1; } now = g_time3(); if (now - start_time < timeout) { g_sleep(timeout / 5); } else { self->status = TRANS_STATUS_DOWN; return 1; } } } } else { self->status = TRANS_STATUS_DOWN; return 1; } if (error == -1) { if (g_tcp_last_error_would_block(self->sck)) { now = g_time3(); if (now - start_time < timeout) { timeout = timeout - (now - start_time); } else { timeout = 0; } if (g_tcp_can_send(self->sck, timeout)) { self->status = TRANS_STATUS_UP; /* ok */ self->type1 = TRANS_TYPE_CLIENT; /* client */ return 0; } } return 1; } self->status = TRANS_STATUS_UP; /* ok */ self->type1 = TRANS_TYPE_CLIENT; /* client */ return 0; } /*****************************************************************************/ /** * @return 0 on success, 1 on failure */ int trans_listen_address(struct trans *self, char *port, const char *address) { if (self->sck != 0) { g_tcp_close(self->sck); } if (self->mode == TRANS_MODE_TCP) /* tcp */ { self->sck = g_tcp_socket(); if (self->sck < 0) return 1; g_tcp_set_non_blocking(self->sck); if (g_tcp_bind_address(self->sck, port, address) == 0) { if (g_tcp_listen(self->sck) == 0) { self->status = TRANS_STATUS_UP; /* ok */ self->type1 = TRANS_TYPE_LISTENER; /* listener */ return 0; } } } else if (self->mode == TRANS_MODE_UNIX) /* unix socket */ { g_free(self->listen_filename); self->listen_filename = 0; g_file_delete(port); self->sck = g_tcp_local_socket(); if (self->sck < 0) return 1; g_tcp_set_non_blocking(self->sck); if (g_tcp_local_bind(self->sck, port) == 0) { self->listen_filename = g_strdup(port); if (g_tcp_listen(self->sck) == 0) { g_chmod_hex(port, 0x0660); self->status = TRANS_STATUS_UP; /* ok */ self->type1 = TRANS_TYPE_LISTENER; /* listener */ return 0; } } } else if (self->mode == TRANS_MODE_VSOCK) /* vsock socket */ { self->sck = g_sck_vsock_socket(); if (self->sck < 0) { return 1; } g_tcp_set_non_blocking(self->sck); if (g_sck_vsock_bind(self->sck, port) == 0) { if (g_tcp_listen(self->sck) == 0) { self->status = TRANS_STATUS_UP; /* ok */ self->type1 = TRANS_TYPE_LISTENER; /* listener */ return 0; } } } return 1; } /*****************************************************************************/ int trans_listen(struct trans *self, char *port) { return trans_listen_address(self, port, "0.0.0.0"); } /*****************************************************************************/ struct stream * trans_get_in_s(struct trans *self) { struct stream *rv = (struct stream *) NULL; if (self == NULL) { rv = (struct stream *) NULL; } else { rv = self->in_s; } return rv; } /*****************************************************************************/ struct stream * trans_get_out_s(struct trans *self, int size) { struct stream *rv = (struct stream *) NULL; if (self == NULL) { rv = (struct stream *) NULL; } else { init_stream(self->out_s, size); rv = self->out_s; } return rv; } /*****************************************************************************/ /* returns error */ int trans_set_tls_mode(struct trans *self, const char *key, const char *cert, long ssl_protocols, const char *tls_ciphers) { self->tls = ssl_tls_create(self, key, cert); if (self->tls == NULL) { g_writeln("trans_set_tls_mode: ssl_tls_create malloc error"); return 1; } if (ssl_tls_accept(self->tls, ssl_protocols, tls_ciphers) != 0) { g_writeln("trans_set_tls_mode: ssl_tls_accept failed"); return 1; } /* assign tls functions */ self->trans_recv = trans_tls_recv; self->trans_send = trans_tls_send; self->trans_can_recv = trans_tls_can_recv; self->ssl_protocol = ssl_get_version(self->tls->ssl); self->cipher_name = ssl_get_cipher_name(self->tls->ssl); return 0; } /*****************************************************************************/ /* returns error */ int trans_shutdown_tls_mode(struct trans *self) { if (self->tls != NULL) { return ssl_tls_disconnect(self->tls); } /* assign callback back to tcp cal */ self->trans_recv = trans_tcp_recv; self->trans_send = trans_tcp_send; self->trans_can_recv = trans_tcp_can_recv; return 0; } xrdp-0.9.5/common/parse.h000644 001751 001751 00000033634 13127114621 015204 0ustar00metameta000000 000000 /** * xrdp: A Remote Desktop Protocol server. * * Copyright (C) Jay Sorg 2004-2014 * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. * * Parsing structs and macros * * based on parse.h from rdesktop * this is a super fast stream method, you bet * needed functions g_malloc, g_free, g_memset, g_memcpy */ #if !defined(PARSE_H) #define PARSE_H #include "arch.h" #if defined(L_ENDIAN) #elif defined(B_ENDIAN) #else #error Unknown endianness. #endif /* parser state */ struct stream { char *p; char *end; char *data; int size; int pad0; /* offsets of various headers */ char *iso_hdr; char *mcs_hdr; char *sec_hdr; char *rdp_hdr; char *channel_hdr; /* other */ char *next_packet; struct stream *next; int *source; }; /******************************************************************************/ #define s_check(s) ((s)->p <= (s)->end) /******************************************************************************/ #define s_check_rem(s, n) ((s)->p + (n) <= (s)->end) /******************************************************************************/ #define s_check_rem_out(s, n) ((s)->p + (n) <= (s)->data + (s)->size) /******************************************************************************/ #define s_check_end(s) ((s)->p == (s)->end) /******************************************************************************/ #define make_stream(s) \ (s) = (struct stream*)g_malloc(sizeof(struct stream), 1) /******************************************************************************/ #define init_stream(s, v) do \ { \ if ((v) > (s)->size) \ { \ g_free((s)->data); \ (s)->data = (char*)g_malloc((v), 0); \ (s)->size = (v); \ } \ (s)->p = (s)->data; \ (s)->end = (s)->data; \ (s)->next_packet = 0; \ } while (0) /******************************************************************************/ #define free_stream(s) do \ { \ if ((s) != 0) \ { \ g_free((s)->data); \ } \ g_free((s)); \ } while (0) /******************************************************************************/ #define s_push_layer(s, h, n) do \ { \ (s)->h = (s)->p; \ (s)->p += (n); \ } while (0) /******************************************************************************/ #define s_pop_layer(s, h) \ (s)->p = (s)->h /******************************************************************************/ #define s_mark_end(s) \ (s)->end = (s)->p #define in_sint8(s, v) do \ { \ (v) = *((signed char*)((s)->p)); \ (s)->p++; \ } while (0) /******************************************************************************/ #define in_uint8(s, v) do \ { \ (v) = *((unsigned char*)((s)->p)); \ (s)->p++; \ } while (0) /******************************************************************************/ #define in_uint8_peek(s, v) do { v = *s->p; } while (0) /******************************************************************************/ #if defined(B_ENDIAN) || defined(NEED_ALIGN) #define in_sint16_le(s, v) do \ { \ (v) = (signed short) \ ( \ (*((unsigned char*)((s)->p + 0)) << 0) | \ (*((unsigned char*)((s)->p + 1)) << 8) \ ); \ (s)->p += 2; \ } while (0) #else #define in_sint16_le(s, v) do \ { \ (v) = *((signed short*)((s)->p)); \ (s)->p += 2; \ } while (0) #endif /******************************************************************************/ #if defined(B_ENDIAN) || defined(NEED_ALIGN) #define in_uint16_le(s, v) do \ { \ (v) = (unsigned short) \ ( \ (*((unsigned char*)((s)->p + 0)) << 0) | \ (*((unsigned char*)((s)->p + 1)) << 8) \ ); \ (s)->p += 2; \ } while (0) #else #define in_uint16_le(s, v) do \ { \ (v) = *((unsigned short*)((s)->p)); \ (s)->p += 2; \ } while (0) #endif /******************************************************************************/ #define in_uint16_be(s, v) do \ { \ (v) = *((unsigned char*)((s)->p)); \ (s)->p++; \ (v) <<= 8; \ (v) |= *((unsigned char*)((s)->p)); \ (s)->p++; \ } while (0) /******************************************************************************/ #if defined(B_ENDIAN) || defined(NEED_ALIGN) #define in_uint32_le(s, v) do \ { \ (v) = (unsigned int) \ ( \ (*((unsigned char*)((s)->p + 0)) << 0) | \ (*((unsigned char*)((s)->p + 1)) << 8) | \ (*((unsigned char*)((s)->p + 2)) << 16) | \ (*((unsigned char*)((s)->p + 3)) << 24) \ ); \ (s)->p += 4; \ } while (0) #else #define in_uint32_le(s, v) do \ { \ (v) = *((unsigned int*)((s)->p)); \ (s)->p += 4; \ } while (0) #endif /******************************************************************************/ #if defined(B_ENDIAN) || defined(NEED_ALIGN) #define in_uint64_le(s, v) do \ { \ (v) = (tui64) \ ( \ (((tui64)(*((unsigned char*)((s)->p + 0)))) << 0) | \ (((tui64)(*((unsigned char*)((s)->p + 1)))) << 8) | \ (((tui64)(*((unsigned char*)((s)->p + 2)))) << 16) | \ (((tui64)(*((unsigned char*)((s)->p + 3)))) << 24) | \ (((tui64)(*((unsigned char*)((s)->p + 4)))) << 32) | \ (((tui64)(*((unsigned char*)((s)->p + 5)))) << 40) | \ (((tui64)(*((unsigned char*)((s)->p + 6)))) << 48) | \ (((tui64)(*((unsigned char*)((s)->p + 7)))) << 56) \ ); \ (s)->p += 8; \ } while (0) #else #define in_uint64_le(s, v) do \ { \ (v) = *((tui64*)((s)->p)); \ (s)->p += 8; \ } while (0) #endif /******************************************************************************/ #define in_uint32_be(s, v) do \ { \ (v) = *((unsigned char*)((s)->p)); \ (s)->p++; \ (v) <<= 8; \ (v) |= *((unsigned char*)((s)->p)); \ (s)->p++; \ (v) <<= 8; \ (v) |= *((unsigned char*)((s)->p)); \ (s)->p++; \ (v) <<= 8; \ (v) |= *((unsigned char*)((s)->p)); \ (s)->p++; \ } while (0) /******************************************************************************/ #define out_uint8(s, v) do \ { \ *((s)->p) = (unsigned char)(v); \ (s)->p++; \ } while (0) /******************************************************************************/ #if defined(B_ENDIAN) || defined(NEED_ALIGN) #define out_uint16_le(s, v) do \ { \ *((s)->p) = (unsigned char)((v) >> 0); \ (s)->p++; \ *((s)->p) = (unsigned char)((v) >> 8); \ (s)->p++; \ } while (0) #else #define out_uint16_le(s, v) do \ { \ *((unsigned short*)((s)->p)) = (unsigned short)(v); \ (s)->p += 2; \ } while (0) #endif /******************************************************************************/ #define out_uint16_be(s, v) do \ { \ *((s)->p) = (unsigned char)((v) >> 8); \ (s)->p++; \ *((s)->p) = (unsigned char)((v) >> 0); \ (s)->p++; \ } while (0) /******************************************************************************/ #if defined(B_ENDIAN) || defined(NEED_ALIGN) #define out_uint32_le(s, v) do \ { \ *((s)->p) = (unsigned char)((v) >> 0); \ (s)->p++; \ *((s)->p) = (unsigned char)((v) >> 8); \ (s)->p++; \ *((s)->p) = (unsigned char)((v) >> 16); \ (s)->p++; \ *((s)->p) = (unsigned char)((v) >> 24); \ (s)->p++; \ } while (0) #else #define out_uint32_le(s, v) do \ { \ *((unsigned int*)((s)->p)) = (v); \ (s)->p += 4; \ } while (0) #endif /******************************************************************************/ #if defined(B_ENDIAN) || defined(NEED_ALIGN) #define out_uint64_le(s, v) do \ { \ *((s)->p) = (unsigned char)((v) >> 0); \ (s)->p++; \ *((s)->p) = (unsigned char)((v) >> 8); \ (s)->p++; \ *((s)->p) = (unsigned char)((v) >> 16); \ (s)->p++; \ *((s)->p) = (unsigned char)((v) >> 24); \ (s)->p++; \ *((s)->p) = (unsigned char)((v) >> 32); \ (s)->p++; \ *((s)->p) = (unsigned char)((v) >> 40); \ (s)->p++; \ *((s)->p) = (unsigned char)((v) >> 48); \ (s)->p++; \ *((s)->p) = (unsigned char)((v) >> 56); \ (s)->p++; \ } while (0) #else #define out_uint64_le(s, v) do \ { \ *((tui64*)((s)->p)) = (v); \ (s)->p += 8; \ } while (0) #endif /******************************************************************************/ #define out_uint32_be(s, v) do \ { \ *((s)->p) = (unsigned char)((v) >> 24); \ s->p++; \ *((s)->p) = (unsigned char)((v) >> 16); \ s->p++; \ *((s)->p) = (unsigned char)((v) >> 8); \ s->p++; \ *((s)->p) = (unsigned char)(v); \ (s)->p++; \ } while (0) /******************************************************************************/ #define in_uint8p(s, v, n) do \ { \ (v) = (s)->p; \ (s)->p += (n); \ } while (0) /******************************************************************************/ #define in_uint8a(s, v, n) do \ { \ g_memcpy((v), (s)->p, (n)); \ (s)->p += (n); \ } while (0) /******************************************************************************/ #define in_uint8s(s, n) \ (s)->p += (n) /******************************************************************************/ #define out_uint8p(s, v, n) do \ { \ g_memcpy((s)->p, (v), (n)); \ (s)->p += (n); \ } while (0) /******************************************************************************/ #define out_uint8a(s, v, n) \ out_uint8p((s), (v), (n)) /******************************************************************************/ #define out_uint8s(s, n) do \ { \ g_memset((s)->p, 0, (n)); \ (s)->p += (n); \ } while (0) /* * @brief allocate a new stream * * @param _s opaque handle to the new stream * @param _l length of new stream ******************************************************************************/ #define xstream_new(_s, _l) \ do \ { \ make_stream((_s)); \ init_stream((_s), (_l)); \ } while (0) /** * @brief release a previously allocated stream * * @param _s opaque handle returned by stream_new() *****************************************************************************/ #define xstream_free(_s) free_stream(_s) #define xstream_rd_u8(_s, _var) in_uint8(_s, _var) #define xstream_rd_u16_le(_s, _var) in_uint16_le(_s, _var) #define xstream_rd_u32_le(_s, _var) in_uint32_le(_s, _var) #define xstream_rd_s8_le(_s, _var) in_sint8(_s, _var) #define xstream_rd_s16_le(_s, _var) in_sint16_le(_s, _var) #define xstream_rd_s32_le(_s, _var) TODO #define xstream_wr_u8(_s, _var) out_uint8(_s, _var) #define xstream_wr_u16_le(_s, _var) out_uint16_le(_s, _var) #define xstream_wr_u32_le(_s, _var) out_uint32_le(_s, _var) #define xstream_wr_s8(_s, _var) TODO #define xstream_wr_s16_le(_s, _var) TODO #define xstream_wr_s32_le(_s, _var) TODO #define xstream_rd_u64_le(_s, _v) \ do \ { \ _v = \ (tui64)(*((unsigned char *)_s->p)) | \ (((tui64) (*(((unsigned char *)_s->p) + 1))) << 8) | \ (((tui64) (*(((unsigned char *)_s->p) + 2))) << 16) | \ (((tui64) (*(((unsigned char *)_s->p) + 3))) << 24) | \ (((tui64) (*(((unsigned char *)_s->p) + 4))) << 32) | \ (((tui64) (*(((unsigned char *)_s->p) + 5))) << 40) | \ (((tui64) (*(((unsigned char *)_s->p) + 6))) << 48) | \ (((tui64) (*(((unsigned char *)_s->p) + 7))) << 56); \ _s->p += 8; \ } while (0) #define xstream_wr_u64_le(_s, _v) \ do \ { \ *(((unsigned char *) _s->p) + 0) = (unsigned char) ((_v >> 0) & 0xff); \ *(((unsigned char *) _s->p) + 1) = (unsigned char) ((_v >> 8) & 0xff); \ *(((unsigned char *) _s->p) + 2) = (unsigned char) ((_v >> 16) & 0xff); \ *(((unsigned char *) _s->p) + 3) = (unsigned char) ((_v >> 24) & 0xff); \ *(((unsigned char *) _s->p) + 4) = (unsigned char) ((_v >> 32) & 0xff); \ *(((unsigned char *) _s->p) + 5) = (unsigned char) ((_v >> 40) & 0xff); \ *(((unsigned char *) _s->p) + 6) = (unsigned char) ((_v >> 48) & 0xff); \ *(((unsigned char *) _s->p) + 7) = (unsigned char) ((_v >> 56) & 0xff); \ _s->p += 8; \ } while (0) /* copy data into stream */ #define xstream_copyin(_s, _dest, _len) \ do \ { \ g_memcpy((_s)->p, (_dest), (_len)); \ (_s)->p += (_len); \ } while (0) /* copy data out of stream */ #define xstream_copyout(_dest, _s, _len) \ do \ { \ g_memcpy((_dest), (_s)->p, (_len)); \ (_s)->p += (_len); \ } while (0) #define xstream_rd_string(_dest, _s, _len) \ do \ { \ g_memcpy((_dest), (_s)->p, (_len)); \ (_s)->p += (_len); \ } while (0) #define xstream_wr_string(_s, _src, _len) \ do \ { \ g_memcpy((_s)->p, (_src), (_len)); \ (_s)->p += (_len); \ } while (0) #define xstream_len(_s) (int) ((_s)->p - (_s)->data) #define xstream_seek(_s, _len) (_s)->p += (_len) #endif xrdp-0.9.5/common/base64.c000644 001751 001751 00000003543 13206666623 015161 0ustar00metameta000000 000000 /** * xrdp: A Remote Desktop Protocol server. * * Copyright (C) Koichiro Iwao 2017 * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. * * Base64 encoder / decoder */ #if defined(HAVE_CONFIG_H) #include #endif #include "os_calls.h" #include #include size_t base64_decoded_bytes(const char *src) { size_t len; size_t padding; len = g_strlen(src); padding = 0; if (src[len - 1] == '=') { padding++; if (src[len - 2] == '=') { padding++; } } return len * 3 / 4 - padding; } /*****************************************************************************/ char * base64_decode(char *dst, const char *src, size_t len) { BIO *b64; BIO *bio; char *b64str; size_t estimated_decoded_bytes; size_t decoded_bytes; b64str = g_strdup(src); estimated_decoded_bytes = base64_decoded_bytes(b64str); dst[estimated_decoded_bytes] = '\0'; b64 = BIO_new(BIO_f_base64()); bio = BIO_new_mem_buf(b64str, len); bio = BIO_push(b64, bio); BIO_set_flags(bio, BIO_FLAGS_BASE64_NO_NL); decoded_bytes = BIO_read(bio , dst, len); BIO_free_all(bio); /* if input is corrupt, return empty string */ if (estimated_decoded_bytes != decoded_bytes) { g_strncpy(dst, "", sizeof("")); } return dst; } xrdp-0.9.5/common/log.c000644 001751 001751 00000037647 13220727201 014654 0ustar00metameta000000 000000 /** * xrdp: A Remote Desktop Protocol server. * * Copyright (C) Jay Sorg 2004-2014 * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ #if defined(HAVE_CONFIG_H) #include #endif #include #include #include #include #include #include #include #include "list.h" #include "file.h" #include "os_calls.h" #include "thread_calls.h" /* Add a define here so that the log.h will hold more information * when compiled from this C file. * When compiled normally the log.h file only contain the public parts * of the operators in this file. */ #define LOGINTERNALSTUFF #include "log.h" /* Here we store the current state and configuration of the log */ static struct log_config *g_staticLogConfig = NULL; /* This file first start with all private functions. In the end of the file the public functions is defined */ /** * * @brief Opens log file * @param fname log file name * @return see open(2) return values * */ int internal_log_file_open(const char *fname) { int ret = -1; if (fname != NULL) { ret = open(fname, O_WRONLY | O_CREAT | O_APPEND | O_SYNC, S_IRUSR | S_IWUSR); } #ifdef FD_CLOEXEC if (ret != -1) { fcntl(ret, F_SETFD, FD_CLOEXEC); } #endif return ret; } /** * * @brief Converts xrdp log level to syslog logging level * @param xrdp logging level * @return syslog equivalent logging level * */ int internal_log_xrdp2syslog(const enum logLevels lvl) { switch (lvl) { case LOG_LEVEL_ALWAYS: return LOG_CRIT; case LOG_LEVEL_ERROR: return LOG_ERR; case LOG_LEVEL_WARNING: return LOG_WARNING; case LOG_LEVEL_INFO: return LOG_INFO; case LOG_LEVEL_DEBUG: case LOG_LEVEL_TRACE: return LOG_DEBUG; default: g_writeln("Undefined log level - programming error"); return LOG_DEBUG; } } /** * @brief Converts xrdp log levels to textual logging levels * @param lvl logging level * @param str pointer to a string, must be allocated before * @return The log string in str pointer. * */ void internal_log_lvl2str(const enum logLevels lvl, char *str) { switch (lvl) { case LOG_LEVEL_ALWAYS: snprintf(str, 9, "%s", "[CORE ] "); break; case LOG_LEVEL_ERROR: snprintf(str, 9, "%s", "[ERROR] "); break; case LOG_LEVEL_WARNING: snprintf(str, 9, "%s", "[WARN ] "); break; case LOG_LEVEL_INFO: snprintf(str, 9, "%s", "[INFO ] "); break; case LOG_LEVEL_DEBUG: snprintf(str, 9, "%s", "[DEBUG] "); break; case LOG_LEVEL_TRACE: snprintf(str, 9, "%s", "[TRACE] "); break; default: snprintf(str, 9, "%s", "PRG ERR!"); g_writeln("Programming error - undefined log level!!!"); } } /******************************************************************************/ enum logReturns internal_log_start(struct log_config *l_cfg) { enum logReturns ret = LOG_GENERAL_ERROR; if (0 == l_cfg) { ret = LOG_ERROR_MALLOC; return ret; } /* if logfile is NULL, we return error */ if (0 == l_cfg->log_file) { g_writeln("log_file not properly assigned"); return ret; } /* if progname is NULL, we return error */ if (0 == l_cfg->program_name) { g_writeln("program_name not properly assigned"); return ret; } /* open file */ l_cfg->fd = internal_log_file_open(l_cfg->log_file); if (-1 == l_cfg->fd) { return LOG_ERROR_FILE_OPEN; } /* if syslog is enabled, open it */ if (l_cfg->enable_syslog) { openlog(l_cfg->program_name, LOG_CONS | LOG_PID, LOG_DAEMON); } #ifdef LOG_ENABLE_THREAD pthread_mutexattr_init(&(l_cfg->log_lock_attr)); pthread_mutex_init(&(l_cfg->log_lock), &(l_cfg->log_lock_attr)); #endif return LOG_STARTUP_OK; } /******************************************************************************/ enum logReturns internal_log_end(struct log_config *l_cfg) { enum logReturns ret = LOG_GENERAL_ERROR; /* if log is closed, quit silently */ if (0 == l_cfg) { return ret; } if (-1 != l_cfg->fd) { /* closing logfile... */ g_file_close(l_cfg->fd); } /* if syslog is enabled, close it */ if (l_cfg->enable_syslog) { closelog(); } /* freeing allocated memory */ if (0 != l_cfg->log_file) { g_free(l_cfg->log_file); l_cfg->log_file = 0; } ret = LOG_STARTUP_OK; return ret; } /** * Converts a string representing th log level to a value * @param buf * @return */ enum logLevels internal_log_text2level(const char *buf) { if (0 == g_strcasecmp(buf, "0") || 0 == g_strcasecmp(buf, "core")) { return LOG_LEVEL_ALWAYS; } else if (0 == g_strcasecmp(buf, "1") || 0 == g_strcasecmp(buf, "error")) { return LOG_LEVEL_ERROR; } else if (0 == g_strcasecmp(buf, "2") || 0 == g_strcasecmp(buf, "warn") || 0 == g_strcasecmp(buf, "warning")) { return LOG_LEVEL_WARNING; } else if (0 == g_strcasecmp(buf, "3") || 0 == g_strcasecmp(buf, "info")) { return LOG_LEVEL_INFO; } else if (0 == g_strcasecmp(buf, "4") || 0 == g_strcasecmp(buf, "debug")) { return LOG_LEVEL_DEBUG; } else if (0 == g_strcasecmp(buf, "5") || 0 == g_strcasecmp(buf, "trace")) { return LOG_LEVEL_TRACE; } g_writeln("Your configured log level is corrupt - we use debug log level"); return LOG_LEVEL_DEBUG; } enum logReturns internalReadConfiguration(const char *inFilename, const char *applicationName) { int fd; enum logReturns ret = LOG_GENERAL_ERROR; struct list *sec; struct list *param_n; struct list *param_v; if (inFilename == NULL) { g_writeln("The inifile is null to readConfiguration!"); return ret; } fd = g_file_open(inFilename); if (-1 == fd) { ret = LOG_ERROR_NO_CFG; g_writeln("We could not open the configuration file to read log parameters"); return ret; } /* we initialize the memory for the configuration and set all content to zero. */ ret = internalInitAndAllocStruct(); if (ret != LOG_STARTUP_OK) { g_file_close(fd); return ret; } sec = list_create(); sec->auto_free = 1; file_read_sections(fd, sec); param_n = list_create(); param_n->auto_free = 1; param_v = list_create(); param_v->auto_free = 1; /* read logging config */ ret = internal_config_read_logging(fd, g_staticLogConfig, param_n, param_v, applicationName); if (ret != LOG_STARTUP_OK) { g_file_close(fd); return ret; } /* cleanup */ list_delete(sec); list_delete(param_v); list_delete(param_n); g_file_close(fd); return ret; } /******************************************************************************/ enum logReturns internal_config_read_logging(int file, struct log_config *lc, struct list *param_n, struct list *param_v, const char *applicationName) { int i; char *buf; char *temp_buf; list_clear(param_v); list_clear(param_n); /* setting defaults */ lc->program_name = applicationName; lc->log_file = 0; lc->fd = 0; lc->log_level = LOG_LEVEL_DEBUG; lc->enable_syslog = 0; lc->syslog_level = LOG_LEVEL_DEBUG; file_read_section(file, SESMAN_CFG_LOGGING, param_n, param_v); for (i = 0; i < param_n->count; i++) { buf = (char *)list_get_item(param_n, i); if (0 == g_strcasecmp(buf, SESMAN_CFG_LOG_FILE)) { lc->log_file = g_strdup((char *)list_get_item(param_v, i)); if (lc->log_file != NULL) { if (lc->log_file[0] != '/') { temp_buf = (char *)g_malloc(512, 0); g_snprintf(temp_buf, 511, "%s/%s", XRDP_LOG_PATH, lc->log_file); g_free(lc->log_file); lc->log_file = temp_buf; } } } if (0 == g_strcasecmp(buf, SESMAN_CFG_LOG_LEVEL)) { lc->log_level = internal_log_text2level((char *)list_get_item(param_v, i)); } if (0 == g_strcasecmp(buf, SESMAN_CFG_LOG_ENABLE_SYSLOG)) { lc->enable_syslog = g_text2bool((char *)list_get_item(param_v, i)); } if (0 == g_strcasecmp(buf, SESMAN_CFG_LOG_SYSLOG_LEVEL)) { lc->syslog_level = internal_log_text2level((char *)list_get_item(param_v, i)); } } if (0 == lc->log_file) { lc->log_file = g_strdup("./sesman.log"); } /* try to create path if not exist */ g_create_path(lc->log_file); g_printf("logging configuration:\r\n"); g_printf("\tLogFile: %s\r\n", lc->log_file); g_printf("\tLogLevel: %i\r\n", lc->log_level); g_printf("\tEnableSyslog: %i\r\n", lc->enable_syslog); g_printf("\tSyslogLevel: %i\r\n", lc->syslog_level); return LOG_STARTUP_OK; } enum logReturns internalInitAndAllocStruct(void) { enum logReturns ret = LOG_GENERAL_ERROR; g_staticLogConfig = g_new0(struct log_config, 1); if (g_staticLogConfig != NULL) { g_staticLogConfig->fd = -1; g_staticLogConfig->enable_syslog = 0; ret = LOG_STARTUP_OK; } else { g_writeln("could not allocate memory for log struct"); ret = LOG_ERROR_MALLOC; } return ret; } /* * Here below the public functions */ enum logReturns log_start_from_param(const struct log_config *iniParams) { enum logReturns ret = LOG_GENERAL_ERROR; if (g_staticLogConfig != NULL) { log_message(LOG_LEVEL_ALWAYS, "Log already initialized"); return ret; } if (iniParams == NULL) { g_writeln("inparam to log_start_from_param is NULL"); return ret; } else { /*Copy the struct information*/ ret = internalInitAndAllocStruct(); if (ret != LOG_STARTUP_OK) { g_writeln("internalInitAndAllocStruct failed"); return ret; } g_staticLogConfig->enable_syslog = iniParams->enable_syslog; g_staticLogConfig->fd = iniParams->fd; g_staticLogConfig->log_file = g_strdup(iniParams->log_file); g_staticLogConfig->log_level = iniParams->log_level; g_staticLogConfig->log_lock = iniParams->log_lock; g_staticLogConfig->log_lock_attr = iniParams->log_lock_attr; g_staticLogConfig->program_name = iniParams->program_name; g_staticLogConfig->syslog_level = iniParams->syslog_level; ret = internal_log_start(g_staticLogConfig); if (ret != LOG_STARTUP_OK) { g_writeln("Could not start log"); if (g_staticLogConfig != NULL) { g_free(g_staticLogConfig); g_staticLogConfig = NULL; } } } return ret; } /** * This function initialize the log facilities according to the configuration * file, that is described by the in parameter. * @param iniFile * @param applicationName, the name that is used in the log for the running application * @return 0 on success */ enum logReturns log_start(const char *iniFile, const char *applicationName) { enum logReturns ret = LOG_GENERAL_ERROR; if (applicationName == NULL) { g_writeln("Programming error your application name cannot be null"); return ret; } ret = internalReadConfiguration(iniFile, applicationName); if (ret == LOG_STARTUP_OK) { ret = internal_log_start(g_staticLogConfig); if (ret != LOG_STARTUP_OK) { g_writeln("Could not start log"); if (g_staticLogConfig != NULL) { g_free(g_staticLogConfig); g_staticLogConfig = NULL; } } } else { g_writeln("Error reading configuration for log based on config: %s", iniFile); } return ret; } /** * Function that terminates all logging * @return */ enum logReturns log_end(void) { enum logReturns ret = LOG_GENERAL_ERROR; ret = internal_log_end(g_staticLogConfig); if (g_staticLogConfig != NULL) { g_free(g_staticLogConfig); g_staticLogConfig = NULL; } return ret; } enum logReturns log_message(const enum logLevels lvl, const char *msg, ...) { char buff[LOG_BUFFER_SIZE + 31]; /* 19 (datetime) 4 (space+cr+lf+\0) */ va_list ap; int len = 0; enum logReturns rv = LOG_STARTUP_OK; int writereply = 0; time_t now_t; struct tm *now; if (g_staticLogConfig == NULL) { g_writeln("The log reference is NULL - log not initialized properly"); return LOG_ERROR_NO_CFG; } if (0 > g_staticLogConfig->fd && g_staticLogConfig->enable_syslog == 0) { return LOG_ERROR_FILE_NOT_OPEN; } now_t = time(&now_t); now = localtime(&now_t); snprintf(buff, 21, "[%.4d%.2d%.2d-%.2d:%.2d:%.2d] ", now->tm_year + 1900, now->tm_mon + 1, now->tm_mday, now->tm_hour, now->tm_min, now->tm_sec); internal_log_lvl2str(lvl, buff + 20); va_start(ap, msg); len = vsnprintf(buff + 28, LOG_BUFFER_SIZE, msg, ap); va_end(ap); /* checking for truncated messages */ if (len > LOG_BUFFER_SIZE) { log_message(LOG_LEVEL_WARNING, "next message will be truncated"); } /* forcing the end of message string */ #ifdef _WIN32 buff[len + 28] = '\r'; buff[len + 29] = '\n'; buff[len + 30] = '\0'; #else #ifdef _MACOS buff[len + 28] = '\r'; buff[len + 29] = '\0'; #else buff[len + 28] = '\n'; buff[len + 29] = '\0'; #endif #endif if (g_staticLogConfig->enable_syslog && (lvl <= g_staticLogConfig->syslog_level)) { /* log to syslog*/ /* %s fix compiler warning 'not a string literal' */ syslog(internal_log_xrdp2syslog(lvl), "(%d)(%lld)%s", g_getpid(), (long long) tc_get_threadid(), buff + 20); } if (lvl <= g_staticLogConfig->log_level) { /* log to console */ g_printf("%s", buff); /* log to application logfile */ #ifdef LOG_ENABLE_THREAD pthread_mutex_lock(&(g_staticLogConfig->log_lock)); #endif if (g_staticLogConfig->fd > 0) { writereply = g_file_write(g_staticLogConfig->fd, buff, g_strlen(buff)); if (writereply <= 0) { rv = LOG_ERROR_NULL_FILE; } } #ifdef LOG_ENABLE_THREAD pthread_mutex_unlock(&(g_staticLogConfig->log_lock)); #endif } return rv; } /** * Return the configured log file name * @return */ char * getLogFile(char *replybuf, int bufsize) { if (g_staticLogConfig) { if (g_staticLogConfig->log_file) { g_strncpy(replybuf, g_staticLogConfig->log_file, bufsize); } else { g_sprintf(replybuf, "The log_file name is NULL"); } } else { g_snprintf(replybuf, bufsize, "The log is not properly started"); } return replybuf; } xrdp-0.9.5/common/ssl_calls.h000644 001751 001751 00000006242 13206023530 016040 0ustar00metameta000000 000000 /** * xrdp: A Remote Desktop Protocol server. * * Copyright (C) Jay Sorg 2004-2014 * Copyright (C) Idan Freiberg 2013-2014 * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ #if !defined(SSL_CALLS_H) #define SSL_CALLS_H #include "arch.h" int ssl_init(void); int ssl_finish(void); void* ssl_rc4_info_create(void); void ssl_rc4_info_delete(void* rc4_info); void ssl_rc4_set_key(void* rc4_info, char* key, int len); void ssl_rc4_crypt(void* rc4_info, char* data, int len); void* ssl_sha1_info_create(void); void ssl_sha1_info_delete(void* sha1_info); void ssl_sha1_clear(void* sha1_info); void ssl_sha1_transform(void* sha1_info, const char *data, int len); void ssl_sha1_complete(void* sha1_info, char* data); void* ssl_md5_info_create(void); void ssl_md5_info_delete(void* md5_info); void ssl_md5_clear(void* md5_info); void ssl_md5_transform(void* md5_info, char* data, int len); void ssl_md5_complete(void* md5_info, char* data); void * ssl_des3_encrypt_info_create(const char *key, const char* ivec); void * ssl_des3_decrypt_info_create(const char *key, const char* ivec); void ssl_des3_info_delete(void *des3); int ssl_des3_encrypt(void *des3, int length, const char *in_data, char *out_data); int ssl_des3_decrypt(void *des3, int length, const char *in_data, char *out_data); void * ssl_hmac_info_create(void); void ssl_hmac_info_delete(void *hmac); void ssl_hmac_sha1_init(void *hmac, const char *data, int len); void ssl_hmac_transform(void *hmac, const char *data, int len); void ssl_hmac_complete(void *hmac, char *data, int len); int ssl_mod_exp(char *out, int out_len, const char *in, int in_len, const char *mod, int mod_len, const char *exp, int exp_len); int ssl_gen_key_xrdp1(int key_size_in_bits, const char* exp, int exp_len, char* mod, int mod_len, char* pri, int pri_len); /* ssl_tls */ struct ssl_tls { struct ssl_st *ssl; /* SSL * */ struct ssl_ctx_st *ctx; /* SSL_CTX * */ char *cert; char *key; struct trans *trans; tintptr rwo; /* wait obj */ }; /* xrdp_tls.c */ struct ssl_tls * ssl_tls_create(struct trans *trans, const char *key, const char *cert); int ssl_tls_accept(struct ssl_tls *self, long ssl_protocols, const char *tls_ciphers); int ssl_tls_disconnect(struct ssl_tls *self); void ssl_tls_delete(struct ssl_tls *self); int ssl_tls_read(struct ssl_tls *tls, char *data, int length); int ssl_tls_write(struct ssl_tls *tls, const char *data, int length); int ssl_tls_can_recv(struct ssl_tls *tls, int sck, int millis); const char * ssl_get_version(const struct ssl_st *ssl); const char * ssl_get_cipher_name(const struct ssl_st *ssl); int ssl_get_protocols_from_string(const char *str, long *ssl_protocols); #endif xrdp-0.9.5/common/list.h000644 001751 001751 00000002526 13174271344 015051 0ustar00metameta000000 000000 /** * xrdp: A Remote Desktop Protocol server. * * Copyright (C) Jay Sorg 2004-2014 * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. * * simple list */ #if !defined(LIST_H) #define LIST_H #include "arch.h" /* list */ struct list { tintptr* items; int count; int alloc_size; int grow_by; int auto_free; }; struct list* list_create(void); void list_delete(struct list* self); void list_add_item(struct list* self, tintptr item); tintptr list_get_item(const struct list *self, int index); void list_clear(struct list* self); int list_index_of(struct list* self, tintptr item); void list_remove_item(struct list* self, int index); void list_insert_item(struct list* self, int index, tintptr item); void list_append_list_strdup(struct list* self, struct list* dest, int start_index); void list_dump_items(struct list* self); #endif xrdp-0.9.5/common/thread_calls.c000644 001751 001751 00000011733 13174271344 016516 0ustar00metameta000000 000000 /** * xrdp: A Remote Desktop Protocol server. * * Copyright (C) Jay Sorg 2004-2014 * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. * * thread calls */ #if defined(HAVE_CONFIG_H) #include #endif #if defined(_WIN32) #include #elif defined(__APPLE__) #include #include #include #else #include #include #endif #include "arch.h" #include "thread_calls.h" #include "os_calls.h" /*****************************************************************************/ /* returns error */ #if defined(_WIN32) int tc_thread_create(unsigned long (__stdcall *start_routine)(void *), void *arg) { int rv = 0; DWORD thread_id = 0; HANDLE thread = (HANDLE)0; /* CreateThread returns handle or zero on error */ thread = CreateThread(0, 0, start_routine, arg, 0, &thread_id); rv = !thread; CloseHandle(thread); return rv; } #else int tc_thread_create(void * (* start_routine)(void *), void *arg) { int rv = 0; pthread_t thread = (pthread_t)0; g_memset(&thread, 0x00, sizeof(pthread_t)); /* pthread_create returns error */ rv = pthread_create(&thread, 0, start_routine, arg); if (!rv) { rv = pthread_detach(thread); } return rv; } #endif /*****************************************************************************/ tbus tc_get_threadid(void) { #if defined(_WIN32) return (tbus)GetCurrentThreadId(); #else return (tbus)pthread_self(); #endif } /*****************************************************************************/ /* returns boolean */ int tc_threadid_equal(tbus tid1, tbus tid2) { #if defined(_WIN32) return tid1 == tid2; #else return pthread_equal((pthread_t)tid1, (pthread_t)tid2); #endif } /*****************************************************************************/ tbus tc_mutex_create(void) { #if defined(_WIN32) return (tbus)CreateMutex(0, 0, 0); #else pthread_mutex_t *lmutex; lmutex = (pthread_mutex_t *)g_malloc(sizeof(pthread_mutex_t), 0); pthread_mutex_init(lmutex, 0); return (tbus)lmutex; #endif } /*****************************************************************************/ void tc_mutex_delete(tbus mutex) { #if defined(_WIN32) CloseHandle((HANDLE)mutex); #else pthread_mutex_t *lmutex; lmutex = (pthread_mutex_t *)mutex; pthread_mutex_destroy(lmutex); g_free(lmutex); #endif } /*****************************************************************************/ int tc_mutex_lock(tbus mutex) { #if defined(_WIN32) WaitForSingleObject((HANDLE)mutex, INFINITE); return 0; #else pthread_mutex_lock((pthread_mutex_t *)mutex); return 0; #endif } /*****************************************************************************/ int tc_mutex_unlock(tbus mutex) { int rv = 0; #if defined(_WIN32) ReleaseMutex((HANDLE)mutex); #else if (mutex != 0) { rv = pthread_mutex_unlock((pthread_mutex_t *)mutex); } #endif return rv; } /*****************************************************************************/ tbus tc_sem_create(int init_count) { #if defined(_WIN32) HANDLE sem; sem = CreateSemaphore(0, init_count, init_count + 10, 0); return (tbus)sem; #elif defined(__APPLE__) dispatch_semaphore_t sem = dispatch_semaphore_create(init_count); return (tbus)sem; #else sem_t *sem = (sem_t *)NULL; sem = (sem_t *)g_malloc(sizeof(sem_t), 0); sem_init(sem, 0, init_count); return (tbus)sem; #endif } /*****************************************************************************/ void tc_sem_delete(tbus sem) { #if defined(_WIN32) CloseHandle((HANDLE)sem); #elif defined(__APPLE__) dispatch_release((dispatch_semaphore_t)sem); #else sem_t *lsem; lsem = (sem_t *)sem; sem_destroy(lsem); g_free(lsem); #endif } /*****************************************************************************/ int tc_sem_dec(tbus sem) { #if defined(_WIN32) WaitForSingleObject((HANDLE)sem, INFINITE); return 0; #elif defined(__APPLE__) dispatch_semaphore_wait((dispatch_semaphore_t)sem, DISPATCH_TIME_FOREVER); return 0; #else sem_wait((sem_t *)sem); return 0; #endif } /*****************************************************************************/ int tc_sem_inc(tbus sem) { #if defined(_WIN32) ReleaseSemaphore((HANDLE)sem, 1, 0); return 0; #elif defined(__APPLE__) dispatch_semaphore_signal((dispatch_semaphore_t)sem); return 0; #else sem_post((sem_t *)sem); return 0; #endif } xrdp-0.9.5/common/pixman-region.c000644 001751 001751 00000233717 13174271344 016656 0ustar00metameta000000 000000 /* * Copyright 1987, 1988, 1989, 1998 The Open Group * * Permission to use, copy, modify, distribute, and sell this software and its * documentation for any purpose is hereby granted without fee, provided that * the above copyright notice appear in all copies and that both that * copyright notice and this permission notice appear in supporting * documentation. * * The above copyright notice and this permission notice shall be included in * all copies or substantial portions of the Software. * * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE * OPEN GROUP BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN * AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN * CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. * * Except as contained in this notice, the name of The Open Group shall not be * used in advertising or otherwise to promote the sale, use or other dealings * in this Software without prior written authorization from The Open Group. * * Copyright 1987, 1988, 1989 by * Digital Equipment Corporation, Maynard, Massachusetts. * * All Rights Reserved * * Permission to use, copy, modify, and distribute this software and its * documentation for any purpose and without fee is hereby granted, * provided that the above copyright notice appear in all copies and that * both that copyright notice and this permission notice appear in * supporting documentation, and that the name of Digital not be * used in advertising or publicity pertaining to distribution of the * software without specific, written prior permission. * * DIGITAL DISCLAIMS ALL WARRANTIES WITH REGARD TO THIS SOFTWARE, INCLUDING * ALL IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS, IN NO EVENT SHALL * DIGITAL BE LIABLE FOR ANY SPECIAL, INDIRECT OR CONSEQUENTIAL DAMAGES OR * ANY DAMAGES WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, * WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, * ARISING OUT OF OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS * SOFTWARE. * * Copyright © 1998 Keith Packard * * Permission to use, copy, modify, distribute, and sell this software and its * documentation for any purpose is hereby granted without fee, provided that * the above copyright notice appear in all copies and that both that * copyright notice and this permission notice appear in supporting * documentation, and that the name of Keith Packard not be used in * advertising or publicity pertaining to distribution of the software without * specific, written prior permission. Keith Packard makes no * representations about the suitability of this software for any purpose. It * is provided "as is" without express or implied warranty. * * KEITH PACKARD DISCLAIMS ALL WARRANTIES WITH REGARD TO THIS SOFTWARE, * INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS, IN NO * EVENT SHALL KEITH PACKARD BE LIABLE FOR ANY SPECIAL, INDIRECT OR * CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM LOSS OF USE, * DATA OR PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR OTHER * TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR * PERFORMANCE OF THIS SOFTWARE. */ #if defined(HAVE_CONFIG_H) #include #endif #define PIXREGION_NIL(reg) ((reg)->data && !(reg)->data->numRects) /* not a region */ #define PIXREGION_NAR(reg) ((reg)->data == pixman_broken_data) #define PIXREGION_NUMRECTS(reg) ((reg)->data ? (reg)->data->numRects : 1) #define PIXREGION_SIZE(reg) ((reg)->data ? (reg)->data->size : 0) #define PIXREGION_RECTS(reg) \ ((reg)->data ? (box_type_t *)((reg)->data + 1) \ : &(reg)->extents) #define PIXREGION_BOXPTR(reg) ((box_type_t *)((reg)->data + 1)) #define PIXREGION_BOX(reg, i) (&PIXREGION_BOXPTR (reg)[i]) #define PIXREGION_TOP(reg) PIXREGION_BOX (reg, (reg)->data->numRects) #define PIXREGION_END(reg) PIXREGION_BOX (reg, (reg)->data->numRects - 1) #define GOOD_RECT(rect) ((rect)->x1 < (rect)->x2 && (rect)->y1 < (rect)->y2) #define BAD_RECT(rect) ((rect)->x1 > (rect)->x2 || (rect)->y1 > (rect)->y2) #ifdef XRDP_DEBUG #define GOOD(reg) \ do \ { \ if (!PREFIX (_selfcheck (reg))) \ _pixman_log_error (FUNC, "Malformed region " # reg); \ } while (0) #else #define GOOD(reg) #endif static const box_type_t PREFIX (_empty_box_) = { 0, 0, 0, 0 }; static const region_data_type_t PREFIX (_empty_data_) = { 0, 0 }; #if defined (__llvm__) && !defined (__clang__) static const volatile region_data_type_t PREFIX (_broken_data_) = { 0, 0 }; #else static const region_data_type_t PREFIX (_broken_data_) = { 0, 0 }; #endif static box_type_t *pixman_region_empty_box = (box_type_t *)&PREFIX (_empty_box_); static region_data_type_t *pixman_region_empty_data = (region_data_type_t *)&PREFIX (_empty_data_); static region_data_type_t *pixman_broken_data = (region_data_type_t *)&PREFIX (_broken_data_); static pixman_bool_t pixman_break (region_type_t *region); /* * The functions in this file implement the Region abstraction used extensively * throughout the X11 sample server. A Region is simply a set of disjoint * (non-overlapping) rectangles, plus an "extent" rectangle which is the * smallest single rectangle that contains all the non-overlapping rectangles. * * A Region is implemented as a "y-x-banded" array of rectangles. This array * imposes two degrees of order. First, all rectangles are sorted by top side * y coordinate first (y1), and then by left side x coordinate (x1). * * Furthermore, the rectangles are grouped into "bands". Each rectangle in a * band has the same top y coordinate (y1), and each has the same bottom y * coordinate (y2). Thus all rectangles in a band differ only in their left * and right side (x1 and x2). Bands are implicit in the array of rectangles: * there is no separate list of band start pointers. * * The y-x band representation does not minimize rectangles. In particular, * if a rectangle vertically crosses a band (the rectangle has scanlines in * the y1 to y2 area spanned by the band), then the rectangle may be broken * down into two or more smaller rectangles stacked one atop the other. * * ----------- ----------- * | | | | band 0 * | | -------- ----------- -------- * | | | | in y-x banded | | | | band 1 * | | | | form is | | | | * ----------- | | ----------- -------- * | | | | band 2 * -------- -------- * * An added constraint on the rectangles is that they must cover as much * horizontal area as possible: no two rectangles within a band are allowed * to touch. * * Whenever possible, bands will be merged together to cover a greater vertical * distance (and thus reduce the number of rectangles). Two bands can be merged * only if the bottom of one touches the top of the other and they have * rectangles in the same places (of the same width, of course). * * Adam de Boor wrote most of the original region code. Joel McCormack * substantially modified or rewrote most of the core arithmetic routines, and * added pixman_region_validate in order to support several speed improvements * to pixman_region_validate_tree. Bob Scheifler changed the representation * to be more compact when empty or a single rectangle, and did a bunch of * gratuitous reformatting. Carl Worth did further gratuitous reformatting * while re-merging the server and client region code into libpixregion. * Soren Sandmann did even more gratuitous reformatting. */ /* true iff two Boxes overlap */ #define EXTENTCHECK(r1, r2) \ (!( ((r1)->x2 <= (r2)->x1) || \ ((r1)->x1 >= (r2)->x2) || \ ((r1)->y2 <= (r2)->y1) || \ ((r1)->y1 >= (r2)->y2) ) ) /* true iff (x,y) is in Box */ #define INBOX(r, x, y) \ ( ((r)->x2 > x) && \ ((r)->x1 <= x) && \ ((r)->y2 > y) && \ ((r)->y1 <= y) ) /* true iff Box r1 contains Box r2 */ #define SUBSUMES(r1, r2) \ ( ((r1)->x1 <= (r2)->x1) && \ ((r1)->x2 >= (r2)->x2) && \ ((r1)->y1 <= (r2)->y1) && \ ((r1)->y2 >= (r2)->y2) ) static size_t PIXREGION_SZOF (size_t n) { size_t size = n * sizeof(box_type_t); if (n > UINT32_MAX / sizeof(box_type_t)) return 0; if (sizeof(region_data_type_t) > UINT32_MAX - size) return 0; return size + sizeof(region_data_type_t); } static region_data_type_t * alloc_data (size_t n) { size_t sz = PIXREGION_SZOF (n); if (!sz) return NULL; return (region_data_type_t *) malloc(sz); } #define FREE_DATA(reg) if ((reg)->data && (reg)->data->size) free ((reg)->data) #define RECTALLOC_BAIL(region, n, bail) \ do \ { \ if (!(region)->data || \ (((region)->data->numRects + (n)) > (region)->data->size)) \ { \ if (!pixman_rect_alloc (region, n)) \ goto bail; \ } \ } while (0) #define RECTALLOC(region, n) \ do \ { \ if (!(region)->data || \ (((region)->data->numRects + (n)) > (region)->data->size)) \ { \ if (!pixman_rect_alloc (region, n)) { \ return FALSE; \ } \ } \ } while (0) #define ADDRECT(next_rect, nx1, ny1, nx2, ny2) \ do \ { \ next_rect->x1 = nx1; \ next_rect->y1 = ny1; \ next_rect->x2 = nx2; \ next_rect->y2 = ny2; \ next_rect++; \ } \ while (0) #define NEWRECT(region, next_rect, nx1, ny1, nx2, ny2) \ do \ { \ if (!(region)->data || \ ((region)->data->numRects == (region)->data->size)) \ { \ if (!pixman_rect_alloc (region, 1)) \ return FALSE; \ next_rect = PIXREGION_TOP (region); \ } \ ADDRECT (next_rect, nx1, ny1, nx2, ny2); \ region->data->numRects++; \ critical_if_fail (region->data->numRects <= region->data->size); \ } while (0) #define DOWNSIZE(reg, numRects) \ do \ { \ if (((numRects) < ((reg)->data->size >> 1)) && \ ((reg)->data->size > 50)) \ { \ region_data_type_t * new_data; \ size_t data_size = PIXREGION_SZOF (numRects); \ \ if (!data_size) \ { \ new_data = NULL; \ } \ else \ { \ new_data = (region_data_type_t *) \ realloc ((reg)->data, data_size); \ } \ \ if (new_data) \ { \ new_data->size = (numRects); \ (reg)->data = new_data; \ } \ } \ } while (0) PIXMAN_EXPORT pixman_bool_t PREFIX (_equal) (region_type_t *reg1, region_type_t *reg2) { int i; box_type_t *rects1; box_type_t *rects2; if (reg1->extents.x1 != reg2->extents.x1) return FALSE; if (reg1->extents.x2 != reg2->extents.x2) return FALSE; if (reg1->extents.y1 != reg2->extents.y1) return FALSE; if (reg1->extents.y2 != reg2->extents.y2) return FALSE; if (PIXREGION_NUMRECTS (reg1) != PIXREGION_NUMRECTS (reg2)) return FALSE; rects1 = PIXREGION_RECTS (reg1); rects2 = PIXREGION_RECTS (reg2); for (i = 0; i != PIXREGION_NUMRECTS (reg1); i++) { if (rects1[i].x1 != rects2[i].x1) return FALSE; if (rects1[i].x2 != rects2[i].x2) return FALSE; if (rects1[i].y1 != rects2[i].y1) return FALSE; if (rects1[i].y2 != rects2[i].y2) return FALSE; } return TRUE; } int PREFIX (_print) (region_type_t *rgn) { int num, size; int i; box_type_t * rects; num = PIXREGION_NUMRECTS (rgn); size = PIXREGION_SIZE (rgn); rects = PIXREGION_RECTS (rgn); fprintf (stderr, "num: %d size: %d\n", num, size); fprintf (stderr, "extents: %d %d %d %d\n", rgn->extents.x1, rgn->extents.y1, rgn->extents.x2, rgn->extents.y2); for (i = 0; i < num; i++) { fprintf (stderr, "%d %d %d %d \n", rects[i].x1, rects[i].y1, rects[i].x2, rects[i].y2); } fprintf (stderr, "\n"); return(num); } PIXMAN_EXPORT void PREFIX (_init) (region_type_t *region) { region->extents = *pixman_region_empty_box; region->data = pixman_region_empty_data; } PIXMAN_EXPORT void PREFIX (_init_rect) (region_type_t * region, int x, int y, unsigned int width, unsigned int height) { region->extents.x1 = x; region->extents.y1 = y; region->extents.x2 = x + width; region->extents.y2 = y + height; if (!GOOD_RECT (®ion->extents)) { if (BAD_RECT (®ion->extents)) _pixman_log_error (FUNC, "Invalid rectangle passed"); PREFIX (_init) (region); return; } region->data = NULL; } PIXMAN_EXPORT void PREFIX (_init_with_extents) (region_type_t *region, box_type_t *extents) { if (!GOOD_RECT (extents)) { if (BAD_RECT (extents)) _pixman_log_error (FUNC, "Invalid rectangle passed"); PREFIX (_init) (region); return; } region->extents = *extents; region->data = NULL; } PIXMAN_EXPORT void PREFIX (_fini) (region_type_t *region) { GOOD (region); FREE_DATA (region); } PIXMAN_EXPORT int PREFIX (_n_rects) (region_type_t *region) { return PIXREGION_NUMRECTS (region); } PIXMAN_EXPORT box_type_t * PREFIX (_rectangles) (region_type_t *region, int *n_rects) { if (n_rects) *n_rects = PIXREGION_NUMRECTS (region); return PIXREGION_RECTS (region); } static pixman_bool_t pixman_break (region_type_t *region) { FREE_DATA (region); region->extents = *pixman_region_empty_box; region->data = pixman_broken_data; return FALSE; } static pixman_bool_t pixman_rect_alloc (region_type_t * region, int n) { region_data_type_t *data; if (!region->data) { n++; region->data = alloc_data (n); if (!region->data) return pixman_break (region); region->data->numRects = 1; *PIXREGION_BOXPTR (region) = region->extents; } else if (!region->data->size) { region->data = alloc_data (n); if (!region->data) return pixman_break (region); region->data->numRects = 0; } else { size_t data_size; if (n == 1) { n = region->data->numRects; if (n > 500) /* XXX pick numbers out of a hat */ n = 250; } n += region->data->numRects; data_size = PIXREGION_SZOF (n); if (!data_size) { data = NULL; } else { data = (region_data_type_t *) realloc (region->data, PIXREGION_SZOF (n)); } if (!data) return pixman_break (region); region->data = data; } region->data->size = n; return TRUE; } PIXMAN_EXPORT pixman_bool_t PREFIX (_copy) (region_type_t *dst, region_type_t *src) { GOOD (dst); GOOD (src); if (dst == src) return TRUE; dst->extents = src->extents; if (!src->data || !src->data->size) { FREE_DATA (dst); dst->data = src->data; return TRUE; } if (!dst->data || (dst->data->size < src->data->numRects)) { FREE_DATA (dst); dst->data = alloc_data (src->data->numRects); if (!dst->data) return pixman_break (dst); dst->data->size = src->data->numRects; } dst->data->numRects = src->data->numRects; memmove ((char *)PIXREGION_BOXPTR (dst), (char *)PIXREGION_BOXPTR (src), dst->data->numRects * sizeof(box_type_t)); return TRUE; } /*====================================================================== * Generic Region Operator *====================================================================*/ /*- *----------------------------------------------------------------------- * pixman_coalesce -- * Attempt to merge the boxes in the current band with those in the * previous one. We are guaranteed that the current band extends to * the end of the rects array. Used only by pixman_op. * * Results: * The new index for the previous band. * * Side Effects: * If coalescing takes place: * - rectangles in the previous band will have their y2 fields * altered. * - region->data->numRects will be decreased. * *----------------------------------------------------------------------- */ static inline int pixman_coalesce (region_type_t * region, /* Region to coalesce */ int prev_start, /* Index of start of previous band */ int cur_start) /* Index of start of current band */ { box_type_t *prev_box; /* Current box in previous band */ box_type_t *cur_box; /* Current box in current band */ int numRects; /* Number rectangles in both bands */ int y2; /* Bottom of current band */ /* * Figure out how many rectangles are in the band. */ numRects = cur_start - prev_start; critical_if_fail (numRects == region->data->numRects - cur_start); if (!numRects) return cur_start; /* * The bands may only be coalesced if the bottom of the previous * matches the top scanline of the current. */ prev_box = PIXREGION_BOX (region, prev_start); cur_box = PIXREGION_BOX (region, cur_start); if (prev_box->y2 != cur_box->y1) return cur_start; /* * Make sure the bands have boxes in the same places. This * assumes that boxes have been added in such a way that they * cover the most area possible. I.e. two boxes in a band must * have some horizontal space between them. */ y2 = cur_box->y2; do { if ((prev_box->x1 != cur_box->x1) || (prev_box->x2 != cur_box->x2)) return (cur_start); prev_box++; cur_box++; numRects--; } while (numRects); /* * The bands may be merged, so set the bottom y of each box * in the previous band to the bottom y of the current band. */ numRects = cur_start - prev_start; region->data->numRects -= numRects; do { prev_box--; prev_box->y2 = y2; numRects--; } while (numRects); return prev_start; } /* Quicky macro to avoid trivial reject procedure calls to pixman_coalesce */ #define COALESCE(new_reg, prev_band, cur_band) \ do \ { \ if (cur_band - prev_band == new_reg->data->numRects - cur_band) \ prev_band = pixman_coalesce (new_reg, prev_band, cur_band); \ else \ prev_band = cur_band; \ } while (0) /*- *----------------------------------------------------------------------- * pixman_region_append_non_o -- * Handle a non-overlapping band for the union and subtract operations. * Just adds the (top/bottom-clipped) rectangles into the region. * Doesn't have to check for subsumption or anything. * * Results: * None. * * Side Effects: * region->data->numRects is incremented and the rectangles overwritten * with the rectangles we're passed. * *----------------------------------------------------------------------- */ static inline pixman_bool_t pixman_region_append_non_o (region_type_t * region, box_type_t * r, box_type_t * r_end, int y1, int y2) { box_type_t *next_rect; int new_rects; new_rects = r_end - r; critical_if_fail (y1 < y2); critical_if_fail (new_rects != 0); /* Make sure we have enough space for all rectangles to be added */ RECTALLOC (region, new_rects); next_rect = PIXREGION_TOP (region); region->data->numRects += new_rects; do { critical_if_fail (r->x1 < r->x2); ADDRECT (next_rect, r->x1, y1, r->x2, y2); r++; } while (r != r_end); return TRUE; } #define FIND_BAND(r, r_band_end, r_end, ry1) \ do \ { \ ry1 = r->y1; \ r_band_end = r + 1; \ while ((r_band_end != r_end) && (r_band_end->y1 == ry1)) { \ r_band_end++; \ } \ } while (0) #define APPEND_REGIONS(new_reg, r, r_end) \ do \ { \ int new_rects; \ if ((new_rects = r_end - r)) { \ RECTALLOC_BAIL (new_reg, new_rects, bail); \ memmove ((char *)PIXREGION_TOP (new_reg), (char *)r, \ new_rects * sizeof(box_type_t)); \ new_reg->data->numRects += new_rects; \ } \ } while (0) /*- *----------------------------------------------------------------------- * pixman_op -- * Apply an operation to two regions. Called by pixman_region_union, pixman_region_inverse, * pixman_region_subtract, pixman_region_intersect.... Both regions MUST have at least one * rectangle, and cannot be the same object. * * Results: * TRUE if successful. * * Side Effects: * The new region is overwritten. * overlap set to TRUE if overlap_func ever returns TRUE. * * Notes: * The idea behind this function is to view the two regions as sets. * Together they cover a rectangle of area that this function divides * into horizontal bands where points are covered only by one region * or by both. For the first case, the non_overlap_func is called with * each the band and the band's upper and lower extents. For the * second, the overlap_func is called to process the entire band. It * is responsible for clipping the rectangles in the band, though * this function provides the boundaries. * At the end of each band, the new region is coalesced, if possible, * to reduce the number of rectangles in the region. * *----------------------------------------------------------------------- */ typedef pixman_bool_t (*overlap_proc_ptr) (region_type_t *region, box_type_t * r1, box_type_t * r1_end, box_type_t * r2, box_type_t * r2_end, int y1, int y2); static pixman_bool_t pixman_op (region_type_t * new_reg, /* Place to store result */ region_type_t * reg1, /* First region in operation */ region_type_t * reg2, /* 2d region in operation */ overlap_proc_ptr overlap_func, /* Function to call for over- * lapping bands */ int append_non1, /* Append non-overlapping bands * in region 1 ? */ int append_non2 /* Append non-overlapping bands * in region 2 ? */ ) { box_type_t *r1; /* Pointer into first region */ box_type_t *r2; /* Pointer into 2d region */ box_type_t *r1_end; /* End of 1st region */ box_type_t *r2_end; /* End of 2d region */ int ybot; /* Bottom of intersection */ int ytop; /* Top of intersection */ region_data_type_t *old_data; /* Old data for new_reg */ int prev_band; /* Index of start of * previous band in new_reg */ int cur_band; /* Index of start of current * band in new_reg */ box_type_t * r1_band_end; /* End of current band in r1 */ box_type_t * r2_band_end; /* End of current band in r2 */ int top; /* Top of non-overlapping band */ int bot; /* Bottom of non-overlapping band*/ int r1y1; /* Temps for r1->y1 and r2->y1 */ int r2y1; int new_size; int numRects; /* * Break any region computed from a broken region */ if (PIXREGION_NAR (reg1) || PIXREGION_NAR (reg2)) return pixman_break (new_reg); /* * Initialization: * set r1, r2, r1_end and r2_end appropriately, save the rectangles * of the destination region until the end in case it's one of * the two source regions, then mark the "new" region empty, allocating * another array of rectangles for it to use. */ r1 = PIXREGION_RECTS (reg1); new_size = PIXREGION_NUMRECTS (reg1); r1_end = r1 + new_size; numRects = PIXREGION_NUMRECTS (reg2); r2 = PIXREGION_RECTS (reg2); r2_end = r2 + numRects; critical_if_fail (r1 != r1_end); critical_if_fail (r2 != r2_end); old_data = (region_data_type_t *)NULL; if (((new_reg == reg1) && (new_size > 1)) || ((new_reg == reg2) && (numRects > 1))) { old_data = new_reg->data; new_reg->data = pixman_region_empty_data; } /* guess at new size */ if (numRects > new_size) new_size = numRects; new_size <<= 1; if (!new_reg->data) new_reg->data = pixman_region_empty_data; else if (new_reg->data->size) new_reg->data->numRects = 0; if (new_size > new_reg->data->size) { if (!pixman_rect_alloc (new_reg, new_size)) { free (old_data); return FALSE; } } /* * Initialize ybot. * In the upcoming loop, ybot and ytop serve different functions depending * on whether the band being handled is an overlapping or non-overlapping * band. * In the case of a non-overlapping band (only one of the regions * has points in the band), ybot is the bottom of the most recent * intersection and thus clips the top of the rectangles in that band. * ytop is the top of the next intersection between the two regions and * serves to clip the bottom of the rectangles in the current band. * For an overlapping band (where the two regions intersect), ytop clips * the top of the rectangles of both regions and ybot clips the bottoms. */ ybot = MIN (r1->y1, r2->y1); /* * prev_band serves to mark the start of the previous band so rectangles * can be coalesced into larger rectangles. qv. pixman_coalesce, above. * In the beginning, there is no previous band, so prev_band == cur_band * (cur_band is set later on, of course, but the first band will always * start at index 0). prev_band and cur_band must be indices because of * the possible expansion, and resultant moving, of the new region's * array of rectangles. */ prev_band = 0; do { /* * This algorithm proceeds one source-band (as opposed to a * destination band, which is determined by where the two regions * intersect) at a time. r1_band_end and r2_band_end serve to mark the * rectangle after the last one in the current band for their * respective regions. */ critical_if_fail (r1 != r1_end); critical_if_fail (r2 != r2_end); FIND_BAND (r1, r1_band_end, r1_end, r1y1); FIND_BAND (r2, r2_band_end, r2_end, r2y1); /* * First handle the band that doesn't intersect, if any. * * Note that attention is restricted to one band in the * non-intersecting region at once, so if a region has n * bands between the current position and the next place it overlaps * the other, this entire loop will be passed through n times. */ if (r1y1 < r2y1) { if (append_non1) { top = MAX (r1y1, ybot); bot = MIN (r1->y2, r2y1); if (top != bot) { cur_band = new_reg->data->numRects; if (!pixman_region_append_non_o (new_reg, r1, r1_band_end, top, bot)) goto bail; COALESCE (new_reg, prev_band, cur_band); } } ytop = r2y1; } else if (r2y1 < r1y1) { if (append_non2) { top = MAX (r2y1, ybot); bot = MIN (r2->y2, r1y1); if (top != bot) { cur_band = new_reg->data->numRects; if (!pixman_region_append_non_o (new_reg, r2, r2_band_end, top, bot)) goto bail; COALESCE (new_reg, prev_band, cur_band); } } ytop = r1y1; } else { ytop = r1y1; } /* * Now see if we've hit an intersecting band. The two bands only * intersect if ybot > ytop */ ybot = MIN (r1->y2, r2->y2); if (ybot > ytop) { cur_band = new_reg->data->numRects; if (!(*overlap_func)(new_reg, r1, r1_band_end, r2, r2_band_end, ytop, ybot)) { goto bail; } COALESCE (new_reg, prev_band, cur_band); } /* * If we've finished with a band (y2 == ybot) we skip forward * in the region to the next band. */ if (r1->y2 == ybot) r1 = r1_band_end; if (r2->y2 == ybot) r2 = r2_band_end; } while (r1 != r1_end && r2 != r2_end); /* * Deal with whichever region (if any) still has rectangles left. * * We only need to worry about banding and coalescing for the very first * band left. After that, we can just group all remaining boxes, * regardless of how many bands, into one final append to the list. */ if ((r1 != r1_end) && append_non1) { /* Do first non_overlap1Func call, which may be able to coalesce */ FIND_BAND (r1, r1_band_end, r1_end, r1y1); cur_band = new_reg->data->numRects; if (!pixman_region_append_non_o (new_reg, r1, r1_band_end, MAX (r1y1, ybot), r1->y2)) { goto bail; } COALESCE (new_reg, prev_band, cur_band); /* Just append the rest of the boxes */ APPEND_REGIONS (new_reg, r1_band_end, r1_end); } else if ((r2 != r2_end) && append_non2) { /* Do first non_overlap2Func call, which may be able to coalesce */ FIND_BAND (r2, r2_band_end, r2_end, r2y1); cur_band = new_reg->data->numRects; if (!pixman_region_append_non_o (new_reg, r2, r2_band_end, MAX (r2y1, ybot), r2->y2)) { goto bail; } COALESCE (new_reg, prev_band, cur_band); /* Append rest of boxes */ APPEND_REGIONS (new_reg, r2_band_end, r2_end); } free (old_data); if (!(numRects = new_reg->data->numRects)) { FREE_DATA (new_reg); new_reg->data = pixman_region_empty_data; } else if (numRects == 1) { new_reg->extents = *PIXREGION_BOXPTR (new_reg); FREE_DATA (new_reg); new_reg->data = (region_data_type_t *)NULL; } else { DOWNSIZE (new_reg, numRects); } return TRUE; bail: free (old_data); return pixman_break (new_reg); } /*- *----------------------------------------------------------------------- * pixman_set_extents -- * Reset the extents of a region to what they should be. Called by * pixman_region_subtract and pixman_region_intersect as they can't * figure it out along the way or do so easily, as pixman_region_union can. * * Results: * None. * * Side Effects: * The region's 'extents' structure is overwritten. * *----------------------------------------------------------------------- */ static void pixman_set_extents (region_type_t *region) { box_type_t *box, *box_end; if (!region->data) return; if (!region->data->size) { region->extents.x2 = region->extents.x1; region->extents.y2 = region->extents.y1; return; } box = PIXREGION_BOXPTR (region); box_end = PIXREGION_END (region); /* * Since box is the first rectangle in the region, it must have the * smallest y1 and since box_end is the last rectangle in the region, * it must have the largest y2, because of banding. Initialize x1 and * x2 from box and box_end, resp., as good things to initialize them * to... */ region->extents.x1 = box->x1; region->extents.y1 = box->y1; region->extents.x2 = box_end->x2; region->extents.y2 = box_end->y2; critical_if_fail (region->extents.y1 < region->extents.y2); while (box <= box_end) { if (box->x1 < region->extents.x1) region->extents.x1 = box->x1; if (box->x2 > region->extents.x2) region->extents.x2 = box->x2; box++; } critical_if_fail (region->extents.x1 < region->extents.x2); } /*====================================================================== * Region Intersection *====================================================================*/ /*- *----------------------------------------------------------------------- * pixman_region_intersect_o -- * Handle an overlapping band for pixman_region_intersect. * * Results: * TRUE if successful. * * Side Effects: * Rectangles may be added to the region. * *----------------------------------------------------------------------- */ /*ARGSUSED*/ static pixman_bool_t pixman_region_intersect_o (region_type_t *region, box_type_t * r1, box_type_t * r1_end, box_type_t * r2, box_type_t * r2_end, int y1, int y2) { int x1; int x2; box_type_t * next_rect; next_rect = PIXREGION_TOP (region); critical_if_fail (y1 < y2); critical_if_fail (r1 != r1_end && r2 != r2_end); do { x1 = MAX (r1->x1, r2->x1); x2 = MIN (r1->x2, r2->x2); /* * If there's any overlap between the two rectangles, add that * overlap to the new region. */ if (x1 < x2) NEWRECT (region, next_rect, x1, y1, x2, y2); /* * Advance the pointer(s) with the leftmost right side, since the next * rectangle on that list may still overlap the other region's * current rectangle. */ if (r1->x2 == x2) { r1++; } if (r2->x2 == x2) { r2++; } } while ((r1 != r1_end) && (r2 != r2_end)); return TRUE; } PIXMAN_EXPORT pixman_bool_t PREFIX (_intersect) (region_type_t * new_reg, region_type_t * reg1, region_type_t * reg2) { GOOD (reg1); GOOD (reg2); GOOD (new_reg); /* check for trivial reject */ if (PIXREGION_NIL (reg1) || PIXREGION_NIL (reg2) || !EXTENTCHECK (®1->extents, ®2->extents)) { /* Covers about 20% of all cases */ FREE_DATA (new_reg); new_reg->extents.x2 = new_reg->extents.x1; new_reg->extents.y2 = new_reg->extents.y1; if (PIXREGION_NAR (reg1) || PIXREGION_NAR (reg2)) { new_reg->data = pixman_broken_data; return FALSE; } else { new_reg->data = pixman_region_empty_data; } } else if (!reg1->data && !reg2->data) { /* Covers about 80% of cases that aren't trivially rejected */ new_reg->extents.x1 = MAX (reg1->extents.x1, reg2->extents.x1); new_reg->extents.y1 = MAX (reg1->extents.y1, reg2->extents.y1); new_reg->extents.x2 = MIN (reg1->extents.x2, reg2->extents.x2); new_reg->extents.y2 = MIN (reg1->extents.y2, reg2->extents.y2); FREE_DATA (new_reg); new_reg->data = (region_data_type_t *)NULL; } else if (!reg2->data && SUBSUMES (®2->extents, ®1->extents)) { return PREFIX (_copy) (new_reg, reg1); } else if (!reg1->data && SUBSUMES (®1->extents, ®2->extents)) { return PREFIX (_copy) (new_reg, reg2); } else if (reg1 == reg2) { return PREFIX (_copy) (new_reg, reg1); } else { /* General purpose intersection */ if (!pixman_op (new_reg, reg1, reg2, pixman_region_intersect_o, FALSE, FALSE)) return FALSE; pixman_set_extents (new_reg); } GOOD (new_reg); return(TRUE); } #define MERGERECT(r) \ do \ { \ if (r->x1 <= x2) \ { \ /* Merge with current rectangle */ \ if (x2 < r->x2) \ x2 = r->x2; \ } \ else \ { \ /* Add current rectangle, start new one */ \ NEWRECT (region, next_rect, x1, y1, x2, y2); \ x1 = r->x1; \ x2 = r->x2; \ } \ r++; \ } while (0) /*====================================================================== * Region Union *====================================================================*/ /*- *----------------------------------------------------------------------- * pixman_region_union_o -- * Handle an overlapping band for the union operation. Picks the * left-most rectangle each time and merges it into the region. * * Results: * TRUE if successful. * * Side Effects: * region is overwritten. * overlap is set to TRUE if any boxes overlap. * *----------------------------------------------------------------------- */ static pixman_bool_t pixman_region_union_o (region_type_t *region, box_type_t * r1, box_type_t * r1_end, box_type_t * r2, box_type_t * r2_end, int y1, int y2) { box_type_t *next_rect; int x1; /* left and right side of current union */ int x2; critical_if_fail (y1 < y2); critical_if_fail (r1 != r1_end && r2 != r2_end); next_rect = PIXREGION_TOP (region); /* Start off current rectangle */ if (r1->x1 < r2->x1) { x1 = r1->x1; x2 = r1->x2; r1++; } else { x1 = r2->x1; x2 = r2->x2; r2++; } while (r1 != r1_end && r2 != r2_end) { if (r1->x1 < r2->x1) MERGERECT (r1); else MERGERECT (r2); } /* Finish off whoever (if any) is left */ if (r1 != r1_end) { do { MERGERECT (r1); } while (r1 != r1_end); } else if (r2 != r2_end) { do { MERGERECT (r2); } while (r2 != r2_end); } /* Add current rectangle */ NEWRECT (region, next_rect, x1, y1, x2, y2); return TRUE; } PIXMAN_EXPORT pixman_bool_t PREFIX(_intersect_rect) (region_type_t *dest, region_type_t *source, int x, int y, unsigned int width, unsigned int height) { region_type_t region; region.data = NULL; region.extents.x1 = x; region.extents.y1 = y; region.extents.x2 = x + width; region.extents.y2 = y + height; return PREFIX(_intersect) (dest, source, ®ion); } PIXMAN_EXPORT pixman_bool_t PREFIX (_union) (region_type_t *new_reg, region_type_t *reg1, region_type_t *reg2) { /* Return TRUE if some overlap * between reg1, reg2 */ GOOD (reg1); GOOD (reg2); GOOD (new_reg); /* checks all the simple cases */ /* * Region 1 and 2 are the same */ if (reg1 == reg2) return PREFIX (_copy) (new_reg, reg1); /* * Region 1 is empty */ if (PIXREGION_NIL (reg1)) { if (PIXREGION_NAR (reg1)) return pixman_break (new_reg); if (new_reg != reg2) return PREFIX (_copy) (new_reg, reg2); return TRUE; } /* * Region 2 is empty */ if (PIXREGION_NIL (reg2)) { if (PIXREGION_NAR (reg2)) return pixman_break (new_reg); if (new_reg != reg1) return PREFIX (_copy) (new_reg, reg1); return TRUE; } /* * Region 1 completely subsumes region 2 */ if (!reg1->data && SUBSUMES (®1->extents, ®2->extents)) { if (new_reg != reg1) return PREFIX (_copy) (new_reg, reg1); return TRUE; } /* * Region 2 completely subsumes region 1 */ if (!reg2->data && SUBSUMES (®2->extents, ®1->extents)) { if (new_reg != reg2) return PREFIX (_copy) (new_reg, reg2); return TRUE; } if (!pixman_op (new_reg, reg1, reg2, pixman_region_union_o, TRUE, TRUE)) return FALSE; new_reg->extents.x1 = MIN (reg1->extents.x1, reg2->extents.x1); new_reg->extents.y1 = MIN (reg1->extents.y1, reg2->extents.y1); new_reg->extents.x2 = MAX (reg1->extents.x2, reg2->extents.x2); new_reg->extents.y2 = MAX (reg1->extents.y2, reg2->extents.y2); GOOD (new_reg); return TRUE; } /* Convenience function for performing union of region with a * single rectangle */ PIXMAN_EXPORT pixman_bool_t PREFIX (_union_rect) (region_type_t *dest, region_type_t *source, int x, int y, unsigned int width, unsigned int height) { region_type_t region; region.extents.x1 = x; region.extents.y1 = y; region.extents.x2 = x + width; region.extents.y2 = y + height; if (!GOOD_RECT (®ion.extents)) { if (BAD_RECT (®ion.extents)) _pixman_log_error (FUNC, "Invalid rectangle passed"); return PREFIX (_copy) (dest, source); } region.data = NULL; return PREFIX (_union) (dest, source, ®ion); } /*====================================================================== * Batch Rectangle Union *====================================================================*/ #define EXCHANGE_RECTS(a, b) \ { \ box_type_t t; \ t = rects[a]; \ rects[a] = rects[b]; \ rects[b] = t; \ } static void quick_sort_rects ( box_type_t rects[], int numRects) { int y1; int x1; int i, j; box_type_t *r; /* Always called with numRects > 1 */ do { if (numRects == 2) { if (rects[0].y1 > rects[1].y1 || (rects[0].y1 == rects[1].y1 && rects[0].x1 > rects[1].x1)) { EXCHANGE_RECTS (0, 1); } return; } /* Choose partition element, stick in location 0 */ EXCHANGE_RECTS (0, numRects >> 1); y1 = rects[0].y1; x1 = rects[0].x1; /* Partition array */ i = 0; j = numRects; do { r = &(rects[i]); do { r++; i++; } while (i != numRects && (r->y1 < y1 || (r->y1 == y1 && r->x1 < x1))); r = &(rects[j]); do { r--; j--; } while (y1 < r->y1 || (y1 == r->y1 && x1 < r->x1)); if (i < j) EXCHANGE_RECTS (i, j); } while (i < j); /* Move partition element back to middle */ EXCHANGE_RECTS (0, j); /* Recurse */ if (numRects - j - 1 > 1) quick_sort_rects (&rects[j + 1], numRects - j - 1); numRects = j; } while (numRects > 1); } /*- *----------------------------------------------------------------------- * pixman_region_validate -- * * Take a ``region'' which is a non-y-x-banded random collection of * rectangles, and compute a nice region which is the union of all the * rectangles. * * Results: * TRUE if successful. * * Side Effects: * The passed-in ``region'' may be modified. * overlap set to TRUE if any retangles overlapped, * else FALSE; * * Strategy: * Step 1. Sort the rectangles into ascending order with primary key y1 * and secondary key x1. * * Step 2. Split the rectangles into the minimum number of proper y-x * banded regions. This may require horizontally merging * rectangles, and vertically coalescing bands. With any luck, * this step in an identity transformation (ala the Box widget), * or a coalescing into 1 box (ala Menus). * * Step 3. Merge the separate regions down to a single region by calling * pixman_region_union. Maximize the work each pixman_region_union call does by using * a binary merge. * *----------------------------------------------------------------------- */ static pixman_bool_t validate (region_type_t * badreg) { /* Descriptor for regions under construction in Step 2. */ typedef struct { region_type_t reg; int prev_band; int cur_band; } region_info_t; region_info_t stack_regions[64]; int numRects; /* Original numRects for badreg */ region_info_t *ri; /* Array of current regions */ int num_ri; /* Number of entries used in ri */ int size_ri; /* Number of entries available in ri */ int i; /* Index into rects */ int j; /* Index into ri */ region_info_t *rit; /* &ri[j] */ region_type_t *reg; /* ri[j].reg */ box_type_t *box; /* Current box in rects */ box_type_t *ri_box; /* Last box in ri[j].reg */ region_type_t *hreg; /* ri[j_half].reg */ pixman_bool_t ret = TRUE; if (!badreg->data) { GOOD (badreg); return TRUE; } numRects = badreg->data->numRects; if (!numRects) { if (PIXREGION_NAR (badreg)) return FALSE; GOOD (badreg); return TRUE; } if (badreg->extents.x1 < badreg->extents.x2) { if ((numRects) == 1) { FREE_DATA (badreg); badreg->data = (region_data_type_t *) NULL; } else { DOWNSIZE (badreg, numRects); } GOOD (badreg); return TRUE; } /* Step 1: Sort the rects array into ascending (y1, x1) order */ quick_sort_rects (PIXREGION_BOXPTR (badreg), numRects); /* Step 2: Scatter the sorted array into the minimum number of regions */ /* Set up the first region to be the first rectangle in badreg */ /* Note that step 2 code will never overflow the ri[0].reg rects array */ ri = stack_regions; size_ri = sizeof (stack_regions) / sizeof (stack_regions[0]); num_ri = 1; ri[0].prev_band = 0; ri[0].cur_band = 0; ri[0].reg = *badreg; box = PIXREGION_BOXPTR (&ri[0].reg); ri[0].reg.extents = *box; ri[0].reg.data->numRects = 1; badreg->extents = *pixman_region_empty_box; badreg->data = pixman_region_empty_data; /* Now scatter rectangles into the minimum set of valid regions. If the * next rectangle to be added to a region would force an existing rectangle * in the region to be split up in order to maintain y-x banding, just * forget it. Try the next region. If it doesn't fit cleanly into any * region, make a new one. */ for (i = numRects; --i > 0;) { box++; /* Look for a region to append box to */ for (j = num_ri, rit = ri; --j >= 0; rit++) { reg = &rit->reg; ri_box = PIXREGION_END (reg); if (box->y1 == ri_box->y1 && box->y2 == ri_box->y2) { /* box is in same band as ri_box. Merge or append it */ if (box->x1 <= ri_box->x2) { /* Merge it with ri_box */ if (box->x2 > ri_box->x2) ri_box->x2 = box->x2; } else { RECTALLOC_BAIL (reg, 1, bail); *PIXREGION_TOP (reg) = *box; reg->data->numRects++; } goto next_rect; /* So sue me */ } else if (box->y1 >= ri_box->y2) { /* Put box into new band */ if (reg->extents.x2 < ri_box->x2) reg->extents.x2 = ri_box->x2; if (reg->extents.x1 > box->x1) reg->extents.x1 = box->x1; COALESCE (reg, rit->prev_band, rit->cur_band); rit->cur_band = reg->data->numRects; RECTALLOC_BAIL (reg, 1, bail); *PIXREGION_TOP (reg) = *box; reg->data->numRects++; goto next_rect; } /* Well, this region was inappropriate. Try the next one. */ } /* for j */ /* Uh-oh. No regions were appropriate. Create a new one. */ if (size_ri == num_ri) { size_t data_size; /* Oops, allocate space for new region information */ size_ri <<= 1; data_size = size_ri * sizeof(region_info_t); if (data_size / size_ri != sizeof(region_info_t)) goto bail; if (ri == stack_regions) { rit = (region_info_t *) malloc(data_size); if (!rit) goto bail; memcpy (rit, ri, num_ri * sizeof (region_info_t)); } else { rit = (region_info_t *) realloc (ri, data_size); if (!rit) goto bail; } ri = rit; rit = &ri[num_ri]; } num_ri++; rit->prev_band = 0; rit->cur_band = 0; rit->reg.extents = *box; rit->reg.data = (region_data_type_t *)NULL; /* MUST force allocation */ if (!pixman_rect_alloc (&rit->reg, (i + num_ri) / num_ri)) goto bail; next_rect: ; } /* for i */ /* Make a final pass over each region in order to COALESCE and set * extents.x2 and extents.y2 */ for (j = num_ri, rit = ri; --j >= 0; rit++) { reg = &rit->reg; ri_box = PIXREGION_END (reg); reg->extents.y2 = ri_box->y2; if (reg->extents.x2 < ri_box->x2) reg->extents.x2 = ri_box->x2; COALESCE (reg, rit->prev_band, rit->cur_band); if (reg->data->numRects == 1) /* keep unions happy below */ { FREE_DATA (reg); reg->data = (region_data_type_t *)NULL; } } /* Step 3: Union all regions into a single region */ while (num_ri > 1) { int half = num_ri / 2; for (j = num_ri & 1; j < (half + (num_ri & 1)); j++) { reg = &ri[j].reg; hreg = &ri[j + half].reg; if (!pixman_op (reg, reg, hreg, pixman_region_union_o, TRUE, TRUE)) ret = FALSE; if (hreg->extents.x1 < reg->extents.x1) reg->extents.x1 = hreg->extents.x1; if (hreg->extents.y1 < reg->extents.y1) reg->extents.y1 = hreg->extents.y1; if (hreg->extents.x2 > reg->extents.x2) reg->extents.x2 = hreg->extents.x2; if (hreg->extents.y2 > reg->extents.y2) reg->extents.y2 = hreg->extents.y2; FREE_DATA (hreg); } num_ri -= half; if (!ret) goto bail; } *badreg = ri[0].reg; if (ri != stack_regions) free (ri); GOOD (badreg); return ret; bail: for (i = 0; i < num_ri; i++) FREE_DATA (&ri[i].reg); if (ri != stack_regions) free (ri); return pixman_break (badreg); } /*====================================================================== * Region Subtraction *====================================================================*/ /*- *----------------------------------------------------------------------- * pixman_region_subtract_o -- * Overlapping band subtraction. x1 is the left-most point not yet * checked. * * Results: * TRUE if successful. * * Side Effects: * region may have rectangles added to it. * *----------------------------------------------------------------------- */ /*ARGSUSED*/ static pixman_bool_t pixman_region_subtract_o (region_type_t * region, box_type_t * r1, box_type_t * r1_end, box_type_t * r2, box_type_t * r2_end, int y1, int y2) { box_type_t * next_rect; int x1; x1 = r1->x1; critical_if_fail (y1 < y2); critical_if_fail (r1 != r1_end && r2 != r2_end); next_rect = PIXREGION_TOP (region); do { if (r2->x2 <= x1) { /* * Subtrahend entirely to left of minuend: go to next subtrahend. */ r2++; } else if (r2->x1 <= x1) { /* * Subtrahend precedes minuend: nuke left edge of minuend. */ x1 = r2->x2; if (x1 >= r1->x2) { /* * Minuend completely covered: advance to next minuend and * reset left fence to edge of new minuend. */ r1++; if (r1 != r1_end) x1 = r1->x1; } else { /* * Subtrahend now used up since it doesn't extend beyond * minuend */ r2++; } } else if (r2->x1 < r1->x2) { /* * Left part of subtrahend covers part of minuend: add uncovered * part of minuend to region and skip to next subtrahend. */ critical_if_fail (x1 < r2->x1); NEWRECT (region, next_rect, x1, y1, r2->x1, y2); x1 = r2->x2; if (x1 >= r1->x2) { /* * Minuend used up: advance to new... */ r1++; if (r1 != r1_end) x1 = r1->x1; } else { /* * Subtrahend used up */ r2++; } } else { /* * Minuend used up: add any remaining piece before advancing. */ if (r1->x2 > x1) NEWRECT (region, next_rect, x1, y1, r1->x2, y2); r1++; if (r1 != r1_end) x1 = r1->x1; } } while ((r1 != r1_end) && (r2 != r2_end)); /* * Add remaining minuend rectangles to region. */ while (r1 != r1_end) { critical_if_fail (x1 < r1->x2); NEWRECT (region, next_rect, x1, y1, r1->x2, y2); r1++; if (r1 != r1_end) x1 = r1->x1; } return TRUE; } /*- *----------------------------------------------------------------------- * pixman_region_subtract -- * Subtract reg_s from reg_m and leave the result in reg_d. * S stands for subtrahend, M for minuend and D for difference. * * Results: * TRUE if successful. * * Side Effects: * reg_d is overwritten. * *----------------------------------------------------------------------- */ PIXMAN_EXPORT pixman_bool_t PREFIX (_subtract) (region_type_t *reg_d, region_type_t *reg_m, region_type_t *reg_s) { GOOD (reg_m); GOOD (reg_s); GOOD (reg_d); /* check for trivial rejects */ if (PIXREGION_NIL (reg_m) || PIXREGION_NIL (reg_s) || !EXTENTCHECK (®_m->extents, ®_s->extents)) { if (PIXREGION_NAR (reg_s)) return pixman_break (reg_d); return PREFIX (_copy) (reg_d, reg_m); } else if (reg_m == reg_s) { FREE_DATA (reg_d); reg_d->extents.x2 = reg_d->extents.x1; reg_d->extents.y2 = reg_d->extents.y1; reg_d->data = pixman_region_empty_data; return TRUE; } /* Add those rectangles in region 1 that aren't in region 2, do yucky subtraction for overlaps, and just throw away rectangles in region 2 that aren't in region 1 */ if (!pixman_op (reg_d, reg_m, reg_s, pixman_region_subtract_o, TRUE, FALSE)) return FALSE; /* * Can't alter reg_d's extents before we call pixman_op because * it might be one of the source regions and pixman_op depends * on the extents of those regions being unaltered. Besides, this * way there's no checking against rectangles that will be nuked * due to coalescing, so we have to examine fewer rectangles. */ pixman_set_extents (reg_d); GOOD (reg_d); return TRUE; } /*====================================================================== * Region Inversion *====================================================================*/ /*- *----------------------------------------------------------------------- * pixman_region_inverse -- * Take a region and a box and return a region that is everything * in the box but not in the region. The careful reader will note * that this is the same as subtracting the region from the box... * * Results: * TRUE. * * Side Effects: * new_reg is overwritten. * *----------------------------------------------------------------------- */ PIXMAN_EXPORT pixman_bool_t PREFIX (_inverse) (region_type_t *new_reg, /* Destination region */ region_type_t *reg1, /* Region to invert */ box_type_t * inv_rect) /* Bounding box for inversion */ { region_type_t inv_reg; /* Quick and dirty region made from the * bounding box */ GOOD (reg1); GOOD (new_reg); /* check for trivial rejects */ if (PIXREGION_NIL (reg1) || !EXTENTCHECK (inv_rect, ®1->extents)) { if (PIXREGION_NAR (reg1)) return pixman_break (new_reg); new_reg->extents = *inv_rect; FREE_DATA (new_reg); new_reg->data = (region_data_type_t *)NULL; return TRUE; } /* Add those rectangles in region 1 that aren't in region 2, * do yucky subtraction for overlaps, and * just throw away rectangles in region 2 that aren't in region 1 */ inv_reg.extents = *inv_rect; inv_reg.data = (region_data_type_t *)NULL; if (!pixman_op (new_reg, &inv_reg, reg1, pixman_region_subtract_o, TRUE, FALSE)) return FALSE; /* * Can't alter new_reg's extents before we call pixman_op because * it might be one of the source regions and pixman_op depends * on the extents of those regions being unaltered. Besides, this * way there's no checking against rectangles that will be nuked * due to coalescing, so we have to examine fewer rectangles. */ pixman_set_extents (new_reg); GOOD (new_reg); return TRUE; } /* In time O(log n), locate the first box whose y2 is greater than y. * Return @end if no such box exists. */ static box_type_t * find_box_for_y (box_type_t *begin, box_type_t *end, int y) { box_type_t *mid; if (end == begin) return end; if (end - begin == 1) { if (begin->y2 > y) return begin; else return end; } mid = begin + (end - begin) / 2; if (mid->y2 > y) { /* If no box is found in [begin, mid], the function * will return @mid, which is then known to be the * correct answer. */ return find_box_for_y (begin, mid, y); } else { return find_box_for_y (mid, end, y); } } /* * rect_in(region, rect) * This routine takes a pointer to a region and a pointer to a box * and determines if the box is outside/inside/partly inside the region. * * The idea is to travel through the list of rectangles trying to cover the * passed box with them. Anytime a piece of the rectangle isn't covered * by a band of rectangles, part_out is set TRUE. Any time a rectangle in * the region covers part of the box, part_in is set TRUE. The process ends * when either the box has been completely covered (we reached a band that * doesn't overlap the box, part_in is TRUE and part_out is false), the * box has been partially covered (part_in == part_out == TRUE -- because of * the banding, the first time this is true we know the box is only * partially in the region) or is outside the region (we reached a band * that doesn't overlap the box at all and part_in is false) */ PIXMAN_EXPORT pixman_region_overlap_t PREFIX (_contains_rectangle) (region_type_t * region, box_type_t * prect) { box_type_t * pbox; box_type_t * pbox_end; int part_in, part_out; int numRects; int x, y; GOOD (region); numRects = PIXREGION_NUMRECTS (region); /* useful optimization */ if (!numRects || !EXTENTCHECK (®ion->extents, prect)) return(PIXMAN_REGION_OUT); if (numRects == 1) { /* We know that it must be PIXMAN_REGION_IN or PIXMAN_REGION_PART */ if (SUBSUMES (®ion->extents, prect)) return(PIXMAN_REGION_IN); else return(PIXMAN_REGION_PART); } part_out = FALSE; part_in = FALSE; /* (x,y) starts at upper left of rect, moving to the right and down */ x = prect->x1; y = prect->y1; /* can stop when both part_out and part_in are TRUE, or we reach prect->y2 */ for (pbox = PIXREGION_BOXPTR (region), pbox_end = pbox + numRects; pbox != pbox_end; pbox++) { /* getting up to speed or skipping remainder of band */ if (pbox->y2 <= y) { if ((pbox = find_box_for_y (pbox, pbox_end, y)) == pbox_end) break; } if (pbox->y1 > y) { part_out = TRUE; /* missed part of rectangle above */ if (part_in || (pbox->y1 >= prect->y2)) break; y = pbox->y1; /* x guaranteed to be == prect->x1 */ } if (pbox->x2 <= x) continue; /* not far enough over yet */ if (pbox->x1 > x) { part_out = TRUE; /* missed part of rectangle to left */ if (part_in) break; } if (pbox->x1 < prect->x2) { part_in = TRUE; /* definitely overlap */ if (part_out) break; } if (pbox->x2 >= prect->x2) { y = pbox->y2; /* finished with this band */ if (y >= prect->y2) break; x = prect->x1; /* reset x out to left again */ } else { /* * Because boxes in a band are maximal width, if the first box * to overlap the rectangle doesn't completely cover it in that * band, the rectangle must be partially out, since some of it * will be uncovered in that band. part_in will have been set true * by now... */ part_out = TRUE; break; } } if (part_in) { if (y < prect->y2) return PIXMAN_REGION_PART; else return PIXMAN_REGION_IN; } else { return PIXMAN_REGION_OUT; } } /* PREFIX(_translate) (region, x, y) * translates in place */ PIXMAN_EXPORT void PREFIX (_translate) (region_type_t *region, int x, int y) { overflow_int_t x1, x2, y1, y2; int nbox; box_type_t * pbox; GOOD (region); region->extents.x1 = x1 = region->extents.x1 + x; region->extents.y1 = y1 = region->extents.y1 + y; region->extents.x2 = x2 = region->extents.x2 + x; region->extents.y2 = y2 = region->extents.y2 + y; if (((x1 - PIXMAN_REGION_MIN) | (y1 - PIXMAN_REGION_MIN) | (PIXMAN_REGION_MAX - x2) | (PIXMAN_REGION_MAX - y2)) >= 0) { if (region->data && (nbox = region->data->numRects)) { for (pbox = PIXREGION_BOXPTR (region); nbox--; pbox++) { pbox->x1 += x; pbox->y1 += y; pbox->x2 += x; pbox->y2 += y; } } return; } if (((x2 - PIXMAN_REGION_MIN) | (y2 - PIXMAN_REGION_MIN) | (PIXMAN_REGION_MAX - x1) | (PIXMAN_REGION_MAX - y1)) <= 0) { region->extents.x2 = region->extents.x1; region->extents.y2 = region->extents.y1; FREE_DATA (region); region->data = pixman_region_empty_data; return; } if (x1 < PIXMAN_REGION_MIN) region->extents.x1 = PIXMAN_REGION_MIN; else if (x2 > PIXMAN_REGION_MAX) region->extents.x2 = PIXMAN_REGION_MAX; if (y1 < PIXMAN_REGION_MIN) region->extents.y1 = PIXMAN_REGION_MIN; else if (y2 > PIXMAN_REGION_MAX) region->extents.y2 = PIXMAN_REGION_MAX; if (region->data && (nbox = region->data->numRects)) { box_type_t * pbox_out; for (pbox_out = pbox = PIXREGION_BOXPTR (region); nbox--; pbox++) { pbox_out->x1 = x1 = pbox->x1 + x; pbox_out->y1 = y1 = pbox->y1 + y; pbox_out->x2 = x2 = pbox->x2 + x; pbox_out->y2 = y2 = pbox->y2 + y; if (((x2 - PIXMAN_REGION_MIN) | (y2 - PIXMAN_REGION_MIN) | (PIXMAN_REGION_MAX - x1) | (PIXMAN_REGION_MAX - y1)) <= 0) { region->data->numRects--; continue; } if (x1 < PIXMAN_REGION_MIN) pbox_out->x1 = PIXMAN_REGION_MIN; else if (x2 > PIXMAN_REGION_MAX) pbox_out->x2 = PIXMAN_REGION_MAX; if (y1 < PIXMAN_REGION_MIN) pbox_out->y1 = PIXMAN_REGION_MIN; else if (y2 > PIXMAN_REGION_MAX) pbox_out->y2 = PIXMAN_REGION_MAX; pbox_out++; } if (pbox_out != pbox) { if (region->data->numRects == 1) { region->extents = *PIXREGION_BOXPTR (region); FREE_DATA (region); region->data = (region_data_type_t *)NULL; } else { pixman_set_extents (region); } } } GOOD (region); } PIXMAN_EXPORT void PREFIX (_reset) (region_type_t *region, box_type_t *box) { GOOD (region); critical_if_fail (GOOD_RECT (box)); region->extents = *box; FREE_DATA (region); region->data = NULL; } PIXMAN_EXPORT void PREFIX (_clear) (region_type_t *region) { GOOD (region); FREE_DATA (region); region->extents = *pixman_region_empty_box; region->data = pixman_region_empty_data; } /* box is "return" value */ PIXMAN_EXPORT int PREFIX (_contains_point) (region_type_t * region, int x, int y, box_type_t * box) { box_type_t *pbox, *pbox_end; int numRects; GOOD (region); numRects = PIXREGION_NUMRECTS (region); if (!numRects || !INBOX (®ion->extents, x, y)) return(FALSE); if (numRects == 1) { if (box) *box = region->extents; return(TRUE); } pbox = PIXREGION_BOXPTR (region); pbox_end = pbox + numRects; pbox = find_box_for_y (pbox, pbox_end, y); for (;pbox != pbox_end; pbox++) { if ((y < pbox->y1) || (x < pbox->x1)) break; /* missed it */ if (x >= pbox->x2) continue; /* not there yet */ if (box) *box = *pbox; return(TRUE); } return(FALSE); } PIXMAN_EXPORT int PREFIX (_not_empty) (region_type_t * region) { GOOD (region); return(!PIXREGION_NIL (region)); } PIXMAN_EXPORT box_type_t * PREFIX (_extents) (region_type_t * region) { GOOD (region); return(®ion->extents); } /* * Clip a list of scanlines to a region. The caller has allocated the * space. FSorted is non-zero if the scanline origins are in ascending order. * * returns the number of new, clipped scanlines. */ PIXMAN_EXPORT pixman_bool_t PREFIX (_selfcheck) (region_type_t *reg) { int i, numRects; if ((reg->extents.x1 > reg->extents.x2) || (reg->extents.y1 > reg->extents.y2)) { return FALSE; } numRects = PIXREGION_NUMRECTS (reg); if (!numRects) { return ((reg->extents.x1 == reg->extents.x2) && (reg->extents.y1 == reg->extents.y2) && (reg->data->size || (reg->data == pixman_region_empty_data))); } else if (numRects == 1) { return (!reg->data); } else { box_type_t * pbox_p, * pbox_n; box_type_t box; pbox_p = PIXREGION_RECTS (reg); box = *pbox_p; box.y2 = pbox_p[numRects - 1].y2; pbox_n = pbox_p + 1; for (i = numRects; --i > 0; pbox_p++, pbox_n++) { if ((pbox_n->x1 >= pbox_n->x2) || (pbox_n->y1 >= pbox_n->y2)) { return FALSE; } if (pbox_n->x1 < box.x1) box.x1 = pbox_n->x1; if (pbox_n->x2 > box.x2) box.x2 = pbox_n->x2; if ((pbox_n->y1 < pbox_p->y1) || ((pbox_n->y1 == pbox_p->y1) && ((pbox_n->x1 < pbox_p->x2) || (pbox_n->y2 != pbox_p->y2)))) { return FALSE; } } return ((box.x1 == reg->extents.x1) && (box.x2 == reg->extents.x2) && (box.y1 == reg->extents.y1) && (box.y2 == reg->extents.y2)); } } PIXMAN_EXPORT pixman_bool_t PREFIX (_init_rects) (region_type_t *region, const box_type_t *boxes, int count) { box_type_t *rects; int displacement; int i; /* if it's 1, then we just want to set the extents, so call * the existing method. */ if (count == 1) { PREFIX (_init_rect) (region, boxes[0].x1, boxes[0].y1, boxes[0].x2 - boxes[0].x1, boxes[0].y2 - boxes[0].y1); return TRUE; } PREFIX (_init) (region); /* if it's 0, don't call pixman_rect_alloc -- 0 rectangles is * a special case, and causing pixman_rect_alloc would cause * us to leak memory (because the 0-rect case should be the * static pixman_region_empty_data data). */ if (count == 0) return TRUE; if (!pixman_rect_alloc (region, count)) return FALSE; rects = PIXREGION_RECTS (region); /* Copy in the rects */ memcpy (rects, boxes, sizeof(box_type_t) * count); region->data->numRects = count; /* Eliminate empty and malformed rectangles */ displacement = 0; for (i = 0; i < count; ++i) { box_type_t *box = &rects[i]; if (box->x1 >= box->x2 || box->y1 >= box->y2) displacement++; else if (displacement) rects[i - displacement] = rects[i]; } region->data->numRects -= displacement; /* If eliminating empty rectangles caused there * to be only 0 or 1 rectangles, deal with that. */ if (region->data->numRects == 0) { FREE_DATA (region); PREFIX (_init) (region); return TRUE; } if (region->data->numRects == 1) { region->extents = rects[0]; FREE_DATA (region); region->data = NULL; GOOD (region); return TRUE; } /* Validate */ region->extents.x1 = region->extents.x2 = 0; return validate (region); } xrdp-0.9.5/common/defines.h000644 001751 001751 00000007060 13125122133 015474 0ustar00metameta000000 000000 /** * xrdp: A Remote Desktop Protocol server. * * Copyright (C) Jay Sorg 2004-2014 * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. * * main define/macro file */ #ifndef DEFINES_H #define DEFINES_H /* check for debug */ #ifdef XRDP_DEBUG #define DEBUG(args) g_writeln args; #define LIB_DEBUG(_mod, _text) _mod->server_msg(_mod, _text, 1); #else #define DEBUG(args) #define LIB_DEBUG(_mod, _text) #endif /* other macros */ #undef MIN #define MIN(x1, x2) ((x1) < (x2) ? (x1) : (x2)) #undef MAX #define MAX(x1, x2) ((x1) > (x2) ? (x1) : (x2)) #undef HIWORD #define HIWORD(in) (((in) & 0xffff0000) >> 16) #undef LOWORD #define LOWORD(in) ((in) & 0x0000ffff) #undef MAKELONG #define MAKELONG(lo, hi) ((((hi) & 0xffff) << 16) | ((lo) & 0xffff)) #define MAKERECT(r, x, y, cx, cy) \ { (r).left = x; (r).top = y; (r).right = (x) + (cx); (r).bottom = (y) + (cy); } #define ISRECTEMPTY(r) (((r).right <= (r).left) || ((r).bottom <= (r).top)) #define RECTOFFSET(r, dx, dy) \ { (r).left += dx; (r).top += dy; (r).right += dx; (r).bottom += dy; } #define GETPIXEL8(d, x, y, w) (*(((unsigned char*)d) + ((y) * (w) + (x)))) #define GETPIXEL16(d, x, y, w) (*(((unsigned short*)d) + ((y) * (w) + (x)))) #define GETPIXEL32(d, x, y, w) (*(((unsigned int*)d) + ((y) * (w) + (x)))) #define SETPIXEL8(d, x, y, w, v) \ (*(((unsigned char*)d) + ((y) * (w) + (x))) = (v)) #define SETPIXEL16(d, x, y, w, v) \ (*(((unsigned short*)d) + ((y) * (w) + (x))) = (v)) #define SETPIXEL32(d, x, y, w, v) \ (*(((unsigned int*)d) + ((y) * (w) + (x))) = (v)) #define COLOR8(r, g, b) \ ( \ (((r) >> 5) << 0) | \ (((g) >> 5) << 3) | \ (((b) >> 6) << 6) \ ) #define COLOR15(r, g, b) ((((r) >> 3) << 10) | (((g) >> 3) << 5) | ((b) >> 3)) #define COLOR16(r, g, b) ((((r) >> 3) << 11) | (((g) >> 2) << 5) | ((b) >> 3)) #define COLOR24RGB(r, g, b) (((r) << 16) | ((g) << 8) | (b)) #define COLOR24BGR(r, g, b) (((b) << 16) | ((g) << 8) | (r)) #define HRED(c) ((c & 0xff0000) >> 16) #define HGREEN(c) ((c & 0x00ff00) >> 8) #define HBLUE(c) ((c & 0x0000ff)) #define HCOLOR(bpp,c) \ ( \ (bpp==8?COLOR8(HRED(c),HGREEN(c),HBLUE(c)): \ (bpp==15?COLOR15(HRED(c),HGREEN(c),HBLUE(c)): \ (bpp==16?COLOR16(HRED(c),HGREEN(c),HBLUE(c)): \ (bpp>=24?COLOR24BGR(HRED(c),HGREEN(c),HBLUE(c)):c) \ ) \ ) \ ) \ ) #define SPLITCOLOR15(r, g, b, c) \ { \ r = (((c) >> 7) & 0xf8) | (((c) >> 12) & 0x7); \ g = (((c) >> 2) & 0xf8) | (((c) >> 8) & 0x7); \ b = (((c) << 3) & 0xf8) | (((c) >> 2) & 0x7); \ } #define SPLITCOLOR16(r, g, b, c) \ { \ r = (((c) >> 8) & 0xf8) | (((c) >> 13) & 0x7); \ g = (((c) >> 3) & 0xfc) | (((c) >> 9) & 0x3); \ b = (((c) << 3) & 0xf8) | (((c) >> 2) & 0x7); \ } #define SPLITCOLOR32(r, g, b, c) \ { \ r = ((c) >> 16) & 0xff; \ g = ((c) >> 8) & 0xff; \ b = (c) & 0xff; \ } /* font macros */ #define FONT_DATASIZE(f) \ ((((f)->height * (((f)->width + 7) / 8)) + 3) & ~3); /* use crc for bitmap cache lookups */ #define USE_CRC #define XR_RGB2BGR(a_ulColor) \ (a_ulColor & 0xFF000000) | \ ((a_ulColor & 0x00FF0000) >> 16) | \ (a_ulColor & 0x0000FF00) | \ ((a_ulColor & 0x000000FF) << 16) #endif xrdp-0.9.5/common/xrdp_sockets.h000644 001751 001751 00000003146 13174271344 016605 0ustar00metameta000000 000000 /** * xrdp: A Remote Desktop Protocol server. * * Copyright (C) Jay Sorg 2004-2014 * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. * * names of UNIX sockets for inter-process communication */ #if !defined(XRDP_SOCKETS_H) #define XRDP_SOCKETS_H /* basename of socket files */ #define XRDP_CHANSRV_BASE_STR "xrdp_chansrv_socket_%d" #define CHANSRV_PORT_OUT_BASE_STR "xrdp_chansrv_audio_out_socket_%d" #define CHANSRV_PORT_IN_BASE_STR "xrdp_chansrv_audio_in_socket_%d" #define CHANSRV_API_BASE_STR "xrdpapi_%d" #define XRDP_X11RDP_BASE_STR "xrdp_display_%d" #define XRDP_DISCONNECT_BASE_STR "xrdp_disconnect_display_%d" /* fullpath of sockets */ #define XRDP_CHANSRV_STR XRDP_SOCKET_PATH "/" XRDP_CHANSRV_BASE_STR #define CHANSRV_PORT_OUT_STR XRDP_SOCKET_PATH "/" CHANSRV_PORT_OUT_BASE_STR #define CHANSRV_PORT_IN_STR XRDP_SOCKET_PATH "/" CHANSRV_PORT_IN_BASE_STR #define CHANSRV_API_STR XRDP_SOCKET_PATH "/" CHANSRV_API_BASE_STR #define XRDP_X11RDP_STR XRDP_SOCKET_PATH "/" XRDP_X11RDP_BASE_STR #define XRDP_DISCONNECT_STR XRDP_SOCKET_PATH "/" XRDP_DISCONNECT_BASE_STR #endif xrdp-0.9.5/common/os_calls.c000644 001751 001751 00000247366 13220727201 015673 0ustar00metameta000000 000000 /** * xrdp: A Remote Desktop Protocol server. * * Copyright (C) Jay Sorg 2004-2014 * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. * * generic operating system calls * * put all the os / arch define in here you want */ /* To test for Windows (64 bit or 32 bit) use _WIN32 and _WIN64 in addition for 64 bit windows. _WIN32 is defined for both. To test for Linux use __linux__. To test for BSD use BSD */ #if defined(HAVE_CONFIG_H) #include "config_ac.h" #endif #if defined(_WIN32) #include #include #else /* fix for solaris 10 with gcc 3.3.2 problem */ #if defined(sun) || defined(__sun) #define ctid_t id_t #endif #include #include #include #include #include #if defined(XRDP_ENABLE_VSOCK) #include #endif #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #endif #include #include #include #include #include /* this is so we can use #ifdef BSD later */ /* This is the recommended way of detecting BSD in the FreeBSD Porter's Handbook. */ #if (defined(__unix__) || defined(unix)) && !defined(USG) #include #endif #include "os_calls.h" #include "arch.h" #include "log.h" /* for clearenv() */ #if defined(_WIN32) #else extern char **environ; #endif #if defined(__linux__) #include #endif /* sys/ucred.h needs to be included to use struct xucred * in FreeBSD and OS X. No need for other BSDs except GNU/kFreeBSD */ #if defined(__FreeBSD__) || defined(__APPLE__) || defined(__FreeBSD_kernel__) #include #endif /* for solaris */ #if !defined(PF_LOCAL) #define PF_LOCAL AF_UNIX #endif #if !defined(INADDR_NONE) #define INADDR_NONE ((unsigned long)-1) #endif /*****************************************************************************/ int g_rm_temp_dir(void) { return 0; } /*****************************************************************************/ int g_mk_socket_path(const char *app_name) { if (!g_directory_exist(XRDP_SOCKET_PATH)) { if (!g_create_path(XRDP_SOCKET_PATH"/")) { /* if failed, still check if it got created by someone else */ if (!g_directory_exist(XRDP_SOCKET_PATH)) { log_message(LOG_LEVEL_ERROR, "g_mk_socket_path: g_create_path(%s) failed", XRDP_SOCKET_PATH); return 1; } } g_chmod_hex(XRDP_SOCKET_PATH, 0x1777); } return 0; } /*****************************************************************************/ void g_init(const char *app_name) { #if defined(_WIN32) WSADATA wsadata; WSAStartup(2, &wsadata); #endif /* In order to get g_mbstowcs and g_wcstombs to work properly with UTF-8 non-ASCII characters, LC_CTYPE cannot be "C" or blank. To select UTF-8 encoding without specifying any countries/languages, "C.UTF-8" is used but provided in few systems. See also: https://sourceware.org/glibc/wiki/Proposals/C.UTF-8 */ char *lc_ctype; lc_ctype = setlocale(LC_CTYPE, "C.UTF-8"); if (lc_ctype == NULL) { /* use en_US.UTF-8 instead if not available */ setlocale(LC_CTYPE, "en_US.UTF-8"); } g_mk_socket_path(app_name); } /*****************************************************************************/ void g_deinit(void) { #if defined(_WIN32) WSACleanup(); #endif g_rm_temp_dir(); } /*****************************************************************************/ /* allocate memory, returns a pointer to it, size bytes are allocated, if zero is non zero, each byte will be set to zero */ void * g_malloc(int size, int zero) { char *rv; rv = (char *)malloc(size); if (zero) { if (rv != 0) { memset(rv, 0, size); } } return rv; } /*****************************************************************************/ /* free the memory pointed to by ptr, ptr can be zero */ void g_free(void *ptr) { if (ptr != 0) { free(ptr); } } /*****************************************************************************/ /* output text to stdout, try to use g_write / g_writeln instead to avoid linux / windows EOL problems */ void g_printf(const char *format, ...) { va_list ap; va_start(ap, format); vfprintf(stdout, format, ap); va_end(ap); } /*****************************************************************************/ void g_sprintf(char *dest, const char *format, ...) { va_list ap; va_start(ap, format); vsprintf(dest, format, ap); va_end(ap); } /*****************************************************************************/ int g_snprintf(char *dest, int len, const char *format, ...) { int err; va_list ap; va_start(ap, format); err = vsnprintf(dest, len, format, ap); va_end(ap); return err; } /*****************************************************************************/ void g_writeln(const char *format, ...) { va_list ap; va_start(ap, format); vfprintf(stdout, format, ap); va_end(ap); #if defined(_WIN32) g_printf("\r\n"); #else g_printf("\n"); #endif } /*****************************************************************************/ void g_write(const char *format, ...) { va_list ap; va_start(ap, format); vfprintf(stdout, format, ap); va_end(ap); } /*****************************************************************************/ /* produce a hex dump */ void g_hexdump(const char *p, int len) { unsigned char *line; int i; int thisline; int offset; line = (unsigned char *)p; offset = 0; while (offset < len) { g_printf("%04x ", offset); thisline = len - offset; if (thisline > 16) { thisline = 16; } for (i = 0; i < thisline; i++) { g_printf("%02x ", line[i]); } for (; i < 16; i++) { g_printf(" "); } for (i = 0; i < thisline; i++) { g_printf("%c", (line[i] >= 0x20 && line[i] < 0x7f) ? line[i] : '.'); } g_writeln("%s", ""); offset += thisline; line += thisline; } } /*****************************************************************************/ void g_memset(void *ptr, int val, int size) { memset(ptr, val, size); } /*****************************************************************************/ void g_memcpy(void *d_ptr, const void *s_ptr, int size) { memcpy(d_ptr, s_ptr, size); } /*****************************************************************************/ int g_getchar(void) { return getchar(); } /*****************************************************************************/ /*Returns 0 on success*/ int g_tcp_set_no_delay(int sck) { int ret = 1; /* error */ int option_value; socklen_t option_len; option_len = sizeof(option_value); /* SOL_TCP IPPROTO_TCP */ if (getsockopt(sck, IPPROTO_TCP, TCP_NODELAY, (char *)&option_value, &option_len) == 0) { if (option_value == 0) { option_value = 1; option_len = sizeof(option_value); if (setsockopt(sck, IPPROTO_TCP, TCP_NODELAY, (char *)&option_value, option_len) == 0) { ret = 0; /* success */ } else { g_writeln("Error setting tcp_nodelay"); } } } else { g_writeln("Error getting tcp_nodelay"); } return ret; } /*****************************************************************************/ /*Returns 0 on success*/ int g_tcp_set_keepalive(int sck) { int ret = 1; /* error */ int option_value; socklen_t option_len; option_len = sizeof(option_value); /* SOL_TCP IPPROTO_TCP */ if (getsockopt(sck, SOL_SOCKET, SO_KEEPALIVE, (char *)&option_value, &option_len) == 0) { if (option_value == 0) { option_value = 1; option_len = sizeof(option_value); if (setsockopt(sck, SOL_SOCKET, SO_KEEPALIVE, (char *)&option_value, option_len) == 0) { ret = 0; /* success */ } else { g_writeln("Error setting tcp_keepalive"); } } } else { g_writeln("Error getting tcp_keepalive"); } return ret; } /*****************************************************************************/ /* returns a newly created socket or -1 on error */ /* in win32 a socket is an unsigned int, in linux, it's an int */ int g_tcp_socket(void) { int rv; int option_value; socklen_t option_len; #if defined(XRDP_ENABLE_IPV6) rv = (int)socket(AF_INET6, SOCK_STREAM, 0); if (rv < 0) { switch (errno) { case EAFNOSUPPORT: /* if IPv6 not supported, retry IPv4 */ log_message(LOG_LEVEL_INFO, "IPv6 not supported, falling back to IPv4"); rv = (int)socket(AF_INET, SOCK_STREAM, 0); break; default: log_message(LOG_LEVEL_ERROR, "g_tcp_socket: %s", g_get_strerror()); return -1; } } #else rv = (int)socket(AF_INET, SOCK_STREAM, 0); #endif if (rv < 0) { log_message(LOG_LEVEL_ERROR, "g_tcp_socket: %s", g_get_strerror()); return -1; } #if defined(XRDP_ENABLE_IPV6) option_len = sizeof(option_value); if (getsockopt(rv, IPPROTO_IPV6, IPV6_V6ONLY, (char*)&option_value, &option_len) == 0) { if (option_value != 0) { #if defined(XRDP_ENABLE_IPV6ONLY) option_value = 1; #else option_value = 0; #endif option_len = sizeof(option_value); if (setsockopt(rv, IPPROTO_IPV6, IPV6_V6ONLY, (char*)&option_value, option_len) < 0) { log_message(LOG_LEVEL_ERROR, "g_tcp_socket: setsockopt() failed"); } } } #endif option_len = sizeof(option_value); if (getsockopt(rv, SOL_SOCKET, SO_REUSEADDR, (char *)&option_value, &option_len) == 0) { if (option_value == 0) { option_value = 1; option_len = sizeof(option_value); if (setsockopt(rv, SOL_SOCKET, SO_REUSEADDR, (char *)&option_value, option_len) < 0) { log_message(LOG_LEVEL_ERROR, "g_tcp_socket: setsockopt() failed"); } } } option_len = sizeof(option_value); if (getsockopt(rv, SOL_SOCKET, SO_SNDBUF, (char *)&option_value, &option_len) == 0) { if (option_value < (1024 * 32)) { option_value = 1024 * 32; option_len = sizeof(option_value); if (setsockopt(rv, SOL_SOCKET, SO_SNDBUF, (char *)&option_value, option_len) < 0) { log_message(LOG_LEVEL_ERROR, "g_tcp_socket: setsockopt() failed"); } } } return rv; } /*****************************************************************************/ /* returns error */ int g_sck_set_send_buffer_bytes(int sck, int bytes) { int option_value; socklen_t option_len; option_value = bytes; option_len = sizeof(option_value); if (setsockopt(sck, SOL_SOCKET, SO_SNDBUF, (char *)&option_value, option_len) != 0) { return 1; } return 0; } /*****************************************************************************/ /* returns error */ int g_sck_get_send_buffer_bytes(int sck, int *bytes) { int option_value; socklen_t option_len; option_value = 0; option_len = sizeof(option_value); if (getsockopt(sck, SOL_SOCKET, SO_SNDBUF, (char *)&option_value, &option_len) != 0) { return 1; } *bytes = option_value; return 0; } /*****************************************************************************/ /* returns error */ int g_sck_set_recv_buffer_bytes(int sck, int bytes) { int option_value; socklen_t option_len; option_value = bytes; option_len = sizeof(option_value); if (setsockopt(sck, SOL_SOCKET, SO_RCVBUF, (char *)&option_value, option_len) != 0) { return 1; } return 0; } /*****************************************************************************/ /* returns error */ int g_sck_get_recv_buffer_bytes(int sck, int *bytes) { int option_value; socklen_t option_len; option_value = 0; option_len = sizeof(option_value); if (getsockopt(sck, SOL_SOCKET, SO_RCVBUF, (char *)&option_value, &option_len) != 0) { return 1; } *bytes = option_value; return 0; } /*****************************************************************************/ int g_sck_local_socket(void) { #if defined(_WIN32) return -1; #else return socket(PF_LOCAL, SOCK_STREAM, 0); #endif } /*****************************************************************************/ int g_sck_vsock_socket(void) { #if defined(XRDP_ENABLE_VSOCK) return socket(PF_VSOCK, SOCK_STREAM, 0); #else return -1; #endif } /*****************************************************************************/ /* returns error */ int g_sck_get_peer_cred(int sck, int *pid, int *uid, int *gid) { #if defined(SO_PEERCRED) socklen_t ucred_length; struct myucred { pid_t pid; uid_t uid; gid_t gid; } credentials; ucred_length = sizeof(credentials); if (getsockopt(sck, SOL_SOCKET, SO_PEERCRED, &credentials, &ucred_length)) { return 1; } if (pid != 0) { *pid = credentials.pid; } if (uid != 0) { *uid = credentials.uid; } if (gid != 0) { *gid = credentials.gid; } return 0; #elif defined(LOCAL_PEERCRED) /* FreeBSD, OS X reach here*/ struct xucred xucred; unsigned int xucred_length; xucred_length = sizeof(xucred); if (getsockopt(sck, SOL_SOCKET, LOCAL_PEERCRED, &xucred, &xucred_length)) { return 1; } if (pid !=0) { *pid = 0; /* can't get pid in FreeBSD, OS X */ } if (uid != 0) { *uid = xucred.cr_uid; } if (gid != 0) { *gid = xucred.cr_gid; } return 0; #else return 1; #endif } /*****************************************************************************/ void g_sck_close(int sck) { #if defined(_WIN32) closesocket(sck); #else char sockname[128]; union { struct sockaddr sock_addr; struct sockaddr_in sock_addr_in; #if defined(XRDP_ENABLE_IPV6) struct sockaddr_in6 sock_addr_in6; #endif #if defined(XRDP_ENABLE_VSOCK) struct sockaddr_vm sock_addr_vm; #endif } sock_info; socklen_t sock_len = sizeof(sock_info); memset(&sock_info, 0, sizeof(sock_info)); if (getsockname(sck, &sock_info.sock_addr, &sock_len) == 0) { switch (sock_info.sock_addr.sa_family) { case AF_INET: { struct sockaddr_in *sock_addr_in = &sock_info.sock_addr_in; g_snprintf(sockname, sizeof(sockname), "AF_INET %s:%d", inet_ntoa(sock_addr_in->sin_addr), ntohs(sock_addr_in->sin_port)); break; } #if defined(XRDP_ENABLE_IPV6) case AF_INET6: { char addr[48]; struct sockaddr_in6 *sock_addr_in6 = &sock_info.sock_addr_in6; g_snprintf(sockname, sizeof(sockname), "AF_INET6 %s port %d", inet_ntop(sock_addr_in6->sin6_family, &sock_addr_in6->sin6_addr, addr, sizeof(addr)), ntohs(sock_addr_in6->sin6_port)); break; } #endif case AF_UNIX: g_snprintf(sockname, sizeof(sockname), "AF_UNIX"); break; #if defined(XRDP_ENABLE_VSOCK) case AF_VSOCK: { struct sockaddr_vm *sock_addr_vm = &sock_info.sock_addr_vm; g_snprintf(sockname, sizeof(sockname), "AF_VSOCK cid %d port %d", sock_addr_vm->svm_cid, sock_addr_vm->svm_port); break; } #endif default: g_snprintf(sockname, sizeof(sockname), "unknown family %d", sock_info.sock_addr.sa_family); break; } } else { log_message(LOG_LEVEL_WARNING, "getsockname() failed on socket %d: %s", sck, g_get_strerror()); if (errno == EBADF || errno == ENOTSOCK) { return; } g_snprintf(sockname, sizeof(sockname), "unknown"); } if (close(sck) == 0) { log_message(LOG_LEVEL_DEBUG, "Closed socket %d (%s)", sck, sockname); } else { log_message(LOG_LEVEL_WARNING, "Cannot close socket %d (%s): %s", sck, sockname, g_get_strerror()); } #endif } #if defined(XRDP_ENABLE_IPV6) /*****************************************************************************/ /* Helper function for g_tcp_connect. */ static int connect_loopback(int sck, const char *port) { struct sockaddr_in6 sa; struct sockaddr_in s; int res; // First IPv6 g_memset(&sa, 0, sizeof(sa)); sa.sin6_family = AF_INET6; sa.sin6_addr = in6addr_loopback; // IPv6 ::1 sa.sin6_port = htons((tui16)atoi(port)); res = connect(sck, (struct sockaddr*)&sa, sizeof(sa)); if (res == -1 && errno == EINPROGRESS) { return -1; } if (res == 0 || (res == -1 && errno == EISCONN)) { return 0; } // else IPv4 g_memset(&s, 0, sizeof(s)); s.sin_family = AF_INET; s.sin_addr.s_addr = htonl(INADDR_LOOPBACK); // IPv4 127.0.0.1 s.sin_port = htons((tui16)atoi(port)); res = connect(sck, (struct sockaddr*)&s, sizeof(s)); if (res == -1 && errno == EINPROGRESS) { return -1; } if (res == 0 || (res == -1 && errno == EISCONN)) { return 0; } // else IPv6 with IPv4 address g_memset(&sa, 0, sizeof(sa)); sa.sin6_family = AF_INET6; inet_pton(AF_INET6, "::FFFF:127.0.0.1", &sa.sin6_addr); sa.sin6_port = htons((tui16)atoi(port)); res = connect(sck, (struct sockaddr*)&sa, sizeof(sa)); if (res == -1 && errno == EINPROGRESS) { return -1; } if (res == 0 || (res == -1 && errno == EISCONN)) { return 0; } return -1; } #endif /*****************************************************************************/ /* returns error, zero is good */ /* The connection might get to be in progress, if so -1 is returned. */ /* The caller needs to call again to check if succeed. */ #if defined(XRDP_ENABLE_IPV6) int g_tcp_connect(int sck, const char *address, const char *port) { int res = 0; struct addrinfo p; struct addrinfo *h = (struct addrinfo *)NULL; struct addrinfo *rp = (struct addrinfo *)NULL; g_memset(&p, 0, sizeof(struct addrinfo)); p.ai_socktype = SOCK_STREAM; p.ai_protocol = IPPROTO_TCP; p.ai_flags = AI_ADDRCONFIG | AI_V4MAPPED; p.ai_family = AF_INET6; if (g_strcmp(address, "127.0.0.1") == 0) { return connect_loopback(sck, port); } else { res = getaddrinfo(address, port, &p, &h); } if (res != 0) { log_message(LOG_LEVEL_ERROR, "g_tcp_connect(%d, %s, %s): getaddrinfo() failed: %s", sck, address, port, gai_strerror(res)); } if (res > -1) { if (h != NULL) { for (rp = h; rp != NULL; rp = rp->ai_next) { res = connect(sck, (struct sockaddr *)(rp->ai_addr), rp->ai_addrlen); if (res == -1 && errno == EINPROGRESS) { break; /* Return -1 */ } if (res == 0 || (res == -1 && errno == EISCONN)) { res = 0; break; /* Success */ } } freeaddrinfo(h); } } return res; } #else int g_tcp_connect(int sck, const char* address, const char* port) { struct sockaddr_in s; struct hostent* h; int res; g_memset(&s, 0, sizeof(struct sockaddr_in)); s.sin_family = AF_INET; s.sin_port = htons((tui16)atoi(port)); s.sin_addr.s_addr = inet_addr(address); if (s.sin_addr.s_addr == INADDR_NONE) { h = gethostbyname(address); if (h != 0) { if (h->h_name != 0) { if (h->h_addr_list != 0) { if ((*(h->h_addr_list)) != 0) { s.sin_addr.s_addr = *((int*)(*(h->h_addr_list))); } } } } } res = connect(sck, (struct sockaddr*)&s, sizeof(struct sockaddr_in)); /* Mac OSX connect() returns -1 for already established connections */ if (res == -1 && errno == EISCONN) { res = 0; } return res; } #endif /*****************************************************************************/ /* returns error, zero is good */ int g_sck_local_connect(int sck, const char *port) { #if defined(_WIN32) return -1; #else struct sockaddr_un s; memset(&s, 0, sizeof(struct sockaddr_un)); s.sun_family = AF_UNIX; strncpy(s.sun_path, port, sizeof(s.sun_path)); s.sun_path[sizeof(s.sun_path) - 1] = 0; return connect(sck, (struct sockaddr *)&s, sizeof(struct sockaddr_un)); #endif } /*****************************************************************************/ int g_sck_set_non_blocking(int sck) { unsigned long i; #if defined(_WIN32) i = 1; ioctlsocket(sck, FIONBIO, &i); #else i = fcntl(sck, F_GETFL); i = i | O_NONBLOCK; if (fcntl(sck, F_SETFL, i) < 0) { log_message(LOG_LEVEL_ERROR, "g_sck_set_non_blocking: fcntl() failed"); } #endif return 0; } #if defined(XRDP_ENABLE_IPV6) /*****************************************************************************/ /* returns error, zero is good */ int g_tcp_bind(int sck, const char *port) { struct sockaddr_in6 sa; struct sockaddr_in s; int errno6; // First IPv6 g_memset(&sa, 0, sizeof(sa)); sa.sin6_family = AF_INET6; sa.sin6_addr = in6addr_any; // IPv6 :: sa.sin6_port = htons((tui16)atoi(port)); if (bind(sck, (struct sockaddr*)&sa, sizeof(sa)) == 0) { return 0; } errno6 = errno; // else IPv4 g_memset(&s, 0, sizeof(s)); s.sin_family = AF_INET; s.sin_addr.s_addr = htonl(INADDR_ANY); // IPv4 0.0.0.0 s.sin_port = htons((tui16)atoi(port)); if (bind(sck, (struct sockaddr*)&s, sizeof(s)) == 0) { return 0; } log_message(LOG_LEVEL_ERROR, "g_tcp_bind(%d, %s) failed " "bind IPv6 (errno=%d) and IPv4 (errno=%d).", sck, port, errno6, errno); return -1; } #else int g_tcp_bind(int sck, const char* port) { struct sockaddr_in s; memset(&s, 0, sizeof(struct sockaddr_in)); s.sin_family = AF_INET; s.sin_port = htons((tui16)atoi(port)); s.sin_addr.s_addr = INADDR_ANY; return bind(sck, (struct sockaddr*)&s, sizeof(struct sockaddr_in)); } #endif /*****************************************************************************/ int g_sck_local_bind(int sck, const char *port) { #if defined(_WIN32) return -1; #else struct sockaddr_un s; memset(&s, 0, sizeof(struct sockaddr_un)); s.sun_family = AF_UNIX; strncpy(s.sun_path, port, sizeof(s.sun_path)); s.sun_path[sizeof(s.sun_path) - 1] = 0; return bind(sck, (struct sockaddr *)&s, sizeof(struct sockaddr_un)); #endif } /*****************************************************************************/ int g_sck_vsock_bind(int sck, const char *port) { #if defined(XRDP_ENABLE_VSOCK) struct sockaddr_vm s; g_memset(&s, 0, sizeof(struct sockaddr_vm)); s.svm_family = AF_VSOCK; s.svm_port = atoi(port); s.svm_cid = VMADDR_CID_ANY; return bind(sck, (struct sockaddr *)&s, sizeof(struct sockaddr_vm)); #else return -1; #endif } #if defined(XRDP_ENABLE_IPV6) /*****************************************************************************/ /* Helper function for g_tcp_bind_address. */ static int bind_loopback(int sck, const char *port) { struct sockaddr_in6 sa; struct sockaddr_in s; int errno6; int errno4; // First IPv6 g_memset(&sa, 0, sizeof(sa)); sa.sin6_family = AF_INET6; sa.sin6_addr = in6addr_loopback; // IPv6 ::1 sa.sin6_port = htons((tui16)atoi(port)); if (bind(sck, (struct sockaddr*)&sa, sizeof(sa)) == 0) { return 0; } errno6 = errno; // else IPv4 g_memset(&s, 0, sizeof(s)); s.sin_family = AF_INET; s.sin_addr.s_addr = htonl(INADDR_LOOPBACK); // IPv4 127.0.0.1 s.sin_port = htons((tui16)atoi(port)); if (bind(sck, (struct sockaddr*)&s, sizeof(s)) == 0) { return 0; } errno4 = errno; // else IPv6 with IPv4 address g_memset(&sa, 0, sizeof(sa)); sa.sin6_family = AF_INET6; inet_pton(AF_INET6, "::FFFF:127.0.0.1", &sa.sin6_addr); sa.sin6_port = htons((tui16)atoi(port)); if (bind(sck, (struct sockaddr*)&sa, sizeof(sa)) == 0) { return 0; } log_message(LOG_LEVEL_ERROR, "bind_loopback(%d, %s) failed; " "IPv6 ::1 (errno=%d), IPv4 127.0.0.1 (errno=%d) and IPv6 ::FFFF:127.0.0.1 (errno=%d).", sck, port, errno6, errno4, errno); return -1; } /*****************************************************************************/ /* Helper function for g_tcp_bind_address. */ /* Returns error, zero is good. */ static int getaddrinfo_bind(int sck, const char *port, const char *address) { int res; int error; struct addrinfo hints; struct addrinfo *list; struct addrinfo *i; res = -1; g_memset(&hints, 0, sizeof(hints)); hints.ai_family = AF_UNSPEC; hints.ai_flags = 0; hints.ai_socktype = SOCK_STREAM; hints.ai_protocol = IPPROTO_TCP; error = getaddrinfo(address, port, &hints, &list); if (error == 0) { i = list; while ((i != 0) && (res < 0)) { res = bind(sck, i->ai_addr, i->ai_addrlen); i = i->ai_next; } freeaddrinfo(list); } else { log_message(LOG_LEVEL_ERROR, "getaddrinfo error: %s", gai_strerror(error)); return -1; } return res; } /*****************************************************************************/ /* Binds a socket to a port. If no specified address the port will be bind */ /* to 'any', i.e. available on all network. */ /* For bind to local host, see valid address strings below. */ /* Returns error, zero is good. */ int g_tcp_bind_address(int sck, const char *port, const char *address) { int res; if ((address == 0) || (address[0] == 0) || (g_strcmp(address, "0.0.0.0") == 0) || (g_strcmp(address, "::") == 0)) { return g_tcp_bind(sck, port); } if ((g_strcmp(address, "127.0.0.1") == 0) || (g_strcmp(address, "::1") == 0) || (g_strcmp(address, "localhost") == 0)) { return bind_loopback(sck, port); } // Let getaddrinfo translate the address string... // IPv4: ddd.ddd.ddd.ddd // IPv6: x:x:x:x:x:x:x:x%, or x::x:x:x:x% res = getaddrinfo_bind(sck, port, address); if (res != 0) { // If fail and it is an IPv4 address, try with the mapped address struct in_addr a; if ((inet_aton(address, &a) == 1) && (strlen(address) <= 15)) { char sz[7+15+1]; sprintf(sz, "::FFFF:%s", address); res = getaddrinfo_bind(sck, port, sz); if (res == 0) { return 0; } } log_message(LOG_LEVEL_ERROR, "g_tcp_bind_address(%d, %s, %s) Failed!", sck, port, address); return -1; } return 0; } #else int g_tcp_bind_address(int sck, const char* port, const char* address) { struct sockaddr_in s; memset(&s, 0, sizeof(struct sockaddr_in)); s.sin_family = AF_INET; s.sin_port = htons((tui16)atoi(port)); s.sin_addr.s_addr = INADDR_ANY; if (inet_aton(address, &s.sin_addr) < 0) { return -1; /* bad address */ } return bind(sck, (struct sockaddr*)&s, sizeof(struct sockaddr_in)); } #endif /*****************************************************************************/ /* returns error, zero is good */ int g_sck_listen(int sck) { return listen(sck, 2); } /*****************************************************************************/ int g_tcp_accept(int sck) { int ret; char msg[256]; union { struct sockaddr sock_addr; struct sockaddr_in sock_addr_in; #if defined(XRDP_ENABLE_IPV6) struct sockaddr_in6 sock_addr_in6; #endif } sock_info; socklen_t sock_len = sizeof(sock_info); memset(&sock_info, 0, sock_len); ret = accept(sck, (struct sockaddr *)&sock_info, &sock_len); if (ret > 0) { switch(sock_info.sock_addr.sa_family) { case AF_INET: { struct sockaddr_in *sock_addr_in = &sock_info.sock_addr_in; g_snprintf(msg, sizeof(msg), "A connection received from %s port %d", inet_ntoa(sock_addr_in->sin_addr), ntohs(sock_addr_in->sin_port)); log_message(LOG_LEVEL_INFO, "%s", msg); break; } #if defined(XRDP_ENABLE_IPV6) case AF_INET6: { struct sockaddr_in6 *sock_addr_in6 = &sock_info.sock_addr_in6; char addr[256]; inet_ntop(sock_addr_in6->sin6_family, &sock_addr_in6->sin6_addr, addr, sizeof(addr)); g_snprintf(msg, sizeof(msg), "A connection received from %s port %d", addr, ntohs(sock_addr_in6->sin6_port)); log_message(LOG_LEVEL_INFO, "%s", msg); break; } #endif } } return ret; } /*****************************************************************************/ int g_sck_accept(int sck, char *addr, int addr_bytes, char *port, int port_bytes) { int ret; char msg[256]; union { struct sockaddr sock_addr; struct sockaddr_in sock_addr_in; #if defined(XRDP_ENABLE_IPV6) struct sockaddr_in6 sock_addr_in6; #endif struct sockaddr_un sock_addr_un; #if defined(XRDP_ENABLE_VSOCK) struct sockaddr_vm sock_addr_vm; #endif } sock_info; socklen_t sock_len = sizeof(sock_info); memset(&sock_info, 0, sock_len); ret = accept(sck, (struct sockaddr *)&sock_info, &sock_len); if (ret > 0) { switch(sock_info.sock_addr.sa_family) { case AF_INET: { struct sockaddr_in *sock_addr_in = &sock_info.sock_addr_in; g_snprintf(addr, addr_bytes, "%s", inet_ntoa(sock_addr_in->sin_addr)); g_snprintf(port, port_bytes, "%d", ntohs(sock_addr_in->sin_port)); g_snprintf(msg, sizeof(msg), "AF_INET connection received from %s port %s", addr, port); break; } #if defined(XRDP_ENABLE_IPV6) case AF_INET6: { struct sockaddr_in6 *sock_addr_in6 = &sock_info.sock_addr_in6; inet_ntop(sock_addr_in6->sin6_family, &sock_addr_in6->sin6_addr, addr, addr_bytes); g_snprintf(port, port_bytes, "%d", ntohs(sock_addr_in6->sin6_port)); g_snprintf(msg, sizeof(msg), "AF_INET6 connection received from %s port %s", addr, port); break; } #endif case AF_UNIX: { g_strncpy(addr, "", addr_bytes - 1); g_strncpy(port, "", port_bytes - 1); g_snprintf(msg, sizeof(msg), "AF_UNIX connection received"); break; } #if defined(XRDP_ENABLE_VSOCK) case AF_VSOCK: { struct sockaddr_vm *sock_addr_vm = &sock_info.sock_addr_vm; g_snprintf(addr, addr_bytes - 1, "%d", sock_addr_vm->svm_cid); g_snprintf(port, addr_bytes - 1, "%d", sock_addr_vm->svm_port); g_snprintf(msg, sizeof(msg), "AF_VSOCK connection received from cid: %s port: %s", addr, port); break; } #endif default: { g_strncpy(addr, "", addr_bytes - 1); g_strncpy(port, "", port_bytes - 1); g_snprintf(msg, sizeof(msg), "connection received, unknown socket family %d", sock_info.sock_addr.sa_family); break; } } log_message(LOG_LEVEL_INFO, "Socket %d: %s", ret, msg); } return ret; } /*****************************************************************************/ /* * TODO: this function writes not only IP address, name is confusing */ void g_write_ip_address(int rcv_sck, char *ip_address, int bytes) { char *addr; int port; int ok; union { struct sockaddr sock_addr; struct sockaddr_in sock_addr_in; #if defined(XRDP_ENABLE_IPV6) struct sockaddr_in6 sock_addr_in6; #endif struct sockaddr_un sock_addr_un; } sock_info; ok = 0; socklen_t sock_len = sizeof(sock_info); memset(&sock_info, 0, sock_len); #if defined(XRDP_ENABLE_IPV6) addr = (char *)g_malloc(INET6_ADDRSTRLEN, 1); #else addr = (char *)g_malloc(INET_ADDRSTRLEN, 1); #endif if (getpeername(rcv_sck, (struct sockaddr *)&sock_info, &sock_len) == 0) { switch(sock_info.sock_addr.sa_family) { case AF_INET: { struct sockaddr_in *sock_addr_in = &sock_info.sock_addr_in; g_snprintf(addr, INET_ADDRSTRLEN, "%s", inet_ntoa(sock_addr_in->sin_addr)); port = ntohs(sock_addr_in->sin_port); ok = 1; break; } #if defined(XRDP_ENABLE_IPV6) case AF_INET6: { struct sockaddr_in6 *sock_addr_in6 = &sock_info.sock_addr_in6; inet_ntop(sock_addr_in6->sin6_family, &sock_addr_in6->sin6_addr, addr, INET6_ADDRSTRLEN); port = ntohs(sock_addr_in6->sin6_port); ok = 1; break; } #endif default: { break; } } if (ok) { g_snprintf(ip_address, bytes, "%s:%d - socket: %d", addr, port, rcv_sck); } } if (!ok) { g_snprintf(ip_address, bytes, "NULL:NULL - socket: %d", rcv_sck); } g_free(addr); } /*****************************************************************************/ void g_sleep(int msecs) { #if defined(_WIN32) Sleep(msecs); #else usleep(msecs * 1000); #endif } /*****************************************************************************/ int g_sck_last_error_would_block(int sck) { #if defined(_WIN32) return WSAGetLastError() == WSAEWOULDBLOCK; #else return (errno == EWOULDBLOCK) || (errno == EAGAIN) || (errno == EINPROGRESS); #endif } /*****************************************************************************/ int g_sck_recv(int sck, void *ptr, int len, int flags) { #if defined(_WIN32) return recv(sck, (char *)ptr, len, flags); #else return recv(sck, ptr, len, flags); #endif } /*****************************************************************************/ int g_sck_send(int sck, const void *ptr, int len, int flags) { #if defined(_WIN32) return send(sck, (const char *)ptr, len, flags); #else return send(sck, ptr, len, flags); #endif } /*****************************************************************************/ /* returns boolean */ int g_sck_socket_ok(int sck) { int opt; socklen_t opt_len; opt_len = sizeof(opt); if (getsockopt(sck, SOL_SOCKET, SO_ERROR, (char *)(&opt), &opt_len) == 0) { if (opt == 0) { return 1; } } return 0; } /*****************************************************************************/ /* wait 'millis' milliseconds for the socket to be able to write */ /* returns boolean */ int g_sck_can_send(int sck, int millis) { fd_set wfds; struct timeval time; int rv; time.tv_sec = millis / 1000; time.tv_usec = (millis * 1000) % 1000000; FD_ZERO(&wfds); if (sck > 0) { FD_SET(((unsigned int)sck), &wfds); rv = select(sck + 1, 0, &wfds, 0, &time); if (rv > 0) { return 1; } } return 0; } /*****************************************************************************/ /* wait 'millis' milliseconds for the socket to be able to receive */ /* returns boolean */ int g_sck_can_recv(int sck, int millis) { fd_set rfds; struct timeval time; int rv; g_memset(&time, 0, sizeof(time)); time.tv_sec = millis / 1000; time.tv_usec = (millis * 1000) % 1000000; FD_ZERO(&rfds); if (sck > 0) { FD_SET(((unsigned int)sck), &rfds); rv = select(sck + 1, &rfds, 0, 0, &time); if (rv > 0) { return 1; } } return 0; } /*****************************************************************************/ int g_sck_select(int sck1, int sck2) { fd_set rfds; struct timeval time; int max; int rv; g_memset(&time, 0, sizeof(struct timeval)); FD_ZERO(&rfds); if (sck1 > 0) { FD_SET(((unsigned int)sck1), &rfds); } if (sck2 > 0) { FD_SET(((unsigned int)sck2), &rfds); } max = sck1; if (sck2 > max) { max = sck2; } rv = select(max + 1, &rfds, 0, 0, &time); if (rv > 0) { rv = 0; if (FD_ISSET(((unsigned int)sck1), &rfds)) { rv = rv | 1; } if (FD_ISSET(((unsigned int)sck2), &rfds)) { rv = rv | 2; } } else { rv = 0; } return rv; } /*****************************************************************************/ /* returns boolean */ static int g_fd_can_read(int fd) { fd_set rfds; struct timeval time; int rv; g_memset(&time, 0, sizeof(time)); FD_ZERO(&rfds); FD_SET(((unsigned int)fd), &rfds); rv = select(fd + 1, &rfds, 0, 0, &time); if (rv == 1) { return 1; } return 0; } /*****************************************************************************/ /* returns error */ /* O_NONBLOCK = 0x00000800 */ static int g_set_nonblock(int fd) { int error; int flags; error = fcntl(fd, F_GETFL); if (error < 0) { return 1; } flags = error; if ((flags & O_NONBLOCK) != O_NONBLOCK) { flags |= O_NONBLOCK; error = fcntl(fd, F_SETFL, flags); if (error < 0) { return 1; } } return 0; } /*****************************************************************************/ /* returns 0 on error */ tintptr g_create_wait_obj(const char *name) { #ifdef _WIN32 tintptr obj; obj = (tintptr)CreateEvent(0, 1, 0, name); return obj; #else int fds[2]; int error; error = pipe(fds); if (error != 0) { return 0; } if (g_set_nonblock(fds[0]) != 0) { close(fds[0]); close(fds[1]); return 0; } if (g_set_nonblock(fds[1]) != 0) { close(fds[0]); close(fds[1]); return 0; } return (fds[1] << 16) | fds[0]; #endif } /*****************************************************************************/ /* returns 0 on error */ tintptr g_create_wait_obj_from_socket(tintptr socket, int write) { #ifdef _WIN32 /* Create and return corresponding event handle for WaitForMultipleObjects */ WSAEVENT event; long lnetevent = 0; g_memset(&event, 0, sizeof(WSAEVENT)); event = WSACreateEvent(); lnetevent = (write ? FD_WRITE : FD_READ) | FD_CLOSE; if (WSAEventSelect(socket, event, lnetevent) == 0) { return (tbus)event; } else { return 0; } #else return socket; #endif } /*****************************************************************************/ void g_delete_wait_obj_from_socket(tintptr wait_obj) { #ifdef _WIN32 if (wait_obj == 0) { return; } WSACloseEvent((HANDLE)wait_obj); #else #endif } /*****************************************************************************/ /* returns error */ int g_set_wait_obj(tintptr obj) { #ifdef _WIN32 if (obj == 0) { return 0; } SetEvent((HANDLE)obj); return 0; #else int error; int fd; int written; int to_write; char buf[4] = "sig"; if (obj == 0) { return 0; } fd = obj & 0xffff; if (g_fd_can_read(fd)) { /* already signalled */ return 0; } fd = obj >> 16; to_write = 4; written = 0; while (written < to_write) { error = write(fd, buf + written, to_write - written); if (error == -1) { error = errno; if ((error == EAGAIN) || (error == EWOULDBLOCK) || (error == EINPROGRESS) || (error == EINTR)) { /* ok */ } else { return 1; } } else if (error > 0) { written += error; } else { return 1; } } return 0; #endif } /*****************************************************************************/ /* returns error */ int g_reset_wait_obj(tintptr obj) { #ifdef _WIN32 if (obj == 0) { return 0; } ResetEvent((HANDLE)obj); return 0; #else char buf[4]; int error; int fd; if (obj == 0) { return 0; } fd = obj & 0xffff; while (g_fd_can_read(fd)) { error = read(fd, buf, 4); if (error == -1) { error = errno; if ((error == EAGAIN) || (error == EWOULDBLOCK) || (error == EINPROGRESS) || (error == EINTR)) { /* ok */ } else { return 1; } } else if (error == 0) { return 1; } } return 0; #endif } /*****************************************************************************/ /* returns boolean */ int g_is_wait_obj_set(tintptr obj) { #ifdef _WIN32 if (obj == 0) { return 0; } if (WaitForSingleObject((HANDLE)obj, 0) == WAIT_OBJECT_0) { return 1; } return 0; #else if (obj == 0) { return 0; } return g_fd_can_read(obj & 0xffff); #endif } /*****************************************************************************/ /* returns error */ int g_delete_wait_obj(tintptr obj) { #ifdef _WIN32 if (obj == 0) { return 0; } /* Close event handle */ CloseHandle((HANDLE)obj); return 0; #else if (obj == 0) { return 0; } close(obj & 0xffff); close(obj >> 16); return 0; #endif } /*****************************************************************************/ /* returns error */ int g_obj_wait(tintptr *read_objs, int rcount, tintptr *write_objs, int wcount, int mstimeout) { #ifdef _WIN32 HANDLE handles[256]; DWORD count; DWORD error; int j; int i; j = 0; count = rcount + wcount; for (i = 0; i < rcount; i++) { handles[j++] = (HANDLE)(read_objs[i]); } for (i = 0; i < wcount; i++) { handles[j++] = (HANDLE)(write_objs[i]); } if (mstimeout < 1) { mstimeout = INFINITE; } error = WaitForMultipleObjects(count, handles, FALSE, mstimeout); if (error == WAIT_FAILED) { return 1; } return 0; #else fd_set rfds; fd_set wfds; struct timeval time; struct timeval *ptime; int i = 0; int res = 0; int max = 0; int sck = 0; max = 0; if (mstimeout < 1) { ptime = 0; } else { g_memset(&time, 0, sizeof(struct timeval)); time.tv_sec = mstimeout / 1000; time.tv_usec = (mstimeout % 1000) * 1000; ptime = &time; } FD_ZERO(&rfds); FD_ZERO(&wfds); /* Find the highest descriptor number in read_obj */ if (read_objs != NULL) { for (i = 0; i < rcount; i++) { sck = read_objs[i] & 0xffff; if (sck > 0) { FD_SET(sck, &rfds); if (sck > max) { max = sck; /* max holds the highest socket/descriptor number */ } } } } else if (rcount > 0) { g_writeln("Programming error read_objs is null"); return 1; /* error */ } if (write_objs != NULL) { for (i = 0; i < wcount; i++) { sck = (int)(write_objs[i]); if (sck > 0) { FD_SET(sck, &wfds); if (sck > max) { max = sck; /* max holds the highest socket/descriptor number */ } } } } else if (wcount > 0) { g_writeln("Programming error write_objs is null"); return 1; /* error */ } res = select(max + 1, &rfds, &wfds, 0, ptime); if (res < 0) { /* these are not really errors */ if ((errno == EAGAIN) || (errno == EWOULDBLOCK) || (errno == EINPROGRESS) || (errno == EINTR)) /* signal occurred */ { return 0; } return 1; /* error */ } return 0; #endif } /*****************************************************************************/ void g_random(char *data, int len) { #if defined(_WIN32) int index; srand(g_time1()); for (index = 0; index < len; index++) { data[index] = (char)rand(); /* rand returns a number between 0 and RAND_MAX */ } #else int fd; memset(data, 0x44, len); fd = open("/dev/urandom", O_RDONLY); if (fd == -1) { fd = open("/dev/random", O_RDONLY); } if (fd != -1) { if (read(fd, data, len) != len) { } close(fd); } #endif } /*****************************************************************************/ int g_abs(int i) { return abs(i); } /*****************************************************************************/ int g_memcmp(const void *s1, const void *s2, int len) { return memcmp(s1, s2, len); } /*****************************************************************************/ /* returns -1 on error, else return handle or file descriptor */ int g_file_open(const char *file_name) { #if defined(_WIN32) return (int)CreateFileA(file_name, GENERIC_READ | GENERIC_WRITE, FILE_SHARE_READ | FILE_SHARE_WRITE, 0, OPEN_ALWAYS, FILE_ATTRIBUTE_NORMAL, 0); #else int rv; rv = open(file_name, O_RDWR | O_CREAT, S_IRUSR | S_IWUSR); if (rv == -1) { /* can't open read / write, try to open read only */ rv = open(file_name, O_RDONLY); } return rv; #endif } /*****************************************************************************/ /* returns -1 on error, else return handle or file descriptor */ int g_file_open_ex(const char *file_name, int aread, int awrite, int acreate, int atrunc) { #if defined(_WIN32) return -1; #else int rv; int flags; flags = 0; if (aread && awrite) { flags |= O_RDWR; } else if (aread) { flags |= O_RDONLY; } else if (awrite) { flags |= O_WRONLY; } if (acreate) { flags |= O_CREAT; } if (atrunc) { flags |= O_TRUNC; } rv = open(file_name, flags, S_IRUSR | S_IWUSR); return rv; #endif } /*****************************************************************************/ /* returns error, always 0 */ int g_file_close(int fd) { #if defined(_WIN32) CloseHandle((HANDLE)fd); #else close(fd); #endif return 0; } /*****************************************************************************/ /* read from file, returns the number of bytes read or -1 on error */ int g_file_read(int fd, char *ptr, int len) { #if defined(_WIN32) if (ReadFile((HANDLE)fd, (LPVOID)ptr, (DWORD)len, (LPDWORD)&len, 0)) { return len; } else { return -1; } #else return read(fd, ptr, len); #endif } /*****************************************************************************/ /* write to file, returns the number of bytes written or -1 on error */ int g_file_write(int fd, const char *ptr, int len) { #if defined(_WIN32) if (WriteFile((HANDLE)fd, (LPVOID)ptr, (DWORD)len, (LPDWORD)&len, 0)) { return len; } else { return -1; } #else return write(fd, ptr, len); #endif } /*****************************************************************************/ /* move file pointer, returns offset on success, -1 on failure */ int g_file_seek(int fd, int offset) { #if defined(_WIN32) int rv; rv = (int)SetFilePointer((HANDLE)fd, offset, 0, FILE_BEGIN); if (rv == (int)INVALID_SET_FILE_POINTER) { return -1; } else { return rv; } #else return (int)lseek(fd, offset, SEEK_SET); #endif } /*****************************************************************************/ /* do a write lock on a file */ /* return boolean */ int g_file_lock(int fd, int start, int len) { #if defined(_WIN32) return LockFile((HANDLE)fd, start, 0, len, 0); #else struct flock lock; lock.l_type = F_WRLCK; lock.l_whence = SEEK_SET; lock.l_start = start; lock.l_len = len; if (fcntl(fd, F_SETLK, &lock) == -1) { return 0; } return 1; #endif } /*****************************************************************************/ /* returns error */ int g_chmod_hex(const char *filename, int flags) { #if defined(_WIN32) return 0; #else int fl; fl = 0; fl |= (flags & 0x4000) ? S_ISUID : 0; fl |= (flags & 0x2000) ? S_ISGID : 0; fl |= (flags & 0x1000) ? S_ISVTX : 0; fl |= (flags & 0x0400) ? S_IRUSR : 0; fl |= (flags & 0x0200) ? S_IWUSR : 0; fl |= (flags & 0x0100) ? S_IXUSR : 0; fl |= (flags & 0x0040) ? S_IRGRP : 0; fl |= (flags & 0x0020) ? S_IWGRP : 0; fl |= (flags & 0x0010) ? S_IXGRP : 0; fl |= (flags & 0x0004) ? S_IROTH : 0; fl |= (flags & 0x0002) ? S_IWOTH : 0; fl |= (flags & 0x0001) ? S_IXOTH : 0; return chmod(filename, fl); #endif } /*****************************************************************************/ /* returns error, zero is ok */ int g_chown(const char *name, int uid, int gid) { return chown(name, uid, gid); } /*****************************************************************************/ /* returns error, always zero */ int g_mkdir(const char *dirname) { #if defined(_WIN32) return 0; #else return mkdir(dirname, S_IRWXU); #endif } /*****************************************************************************/ /* gets the current working directory and puts up to maxlen chars in dirname always returns 0 */ char * g_get_current_dir(char *dirname, int maxlen) { #if defined(_WIN32) GetCurrentDirectoryA(maxlen, dirname); return 0; #else if (getcwd(dirname, maxlen) == 0) { } return 0; #endif } /*****************************************************************************/ /* returns error, zero on success and -1 on failure */ int g_set_current_dir(const char *dirname) { #if defined(_WIN32) if (SetCurrentDirectoryA(dirname)) { return 0; } else { return -1; } #else return chdir(dirname); #endif } /*****************************************************************************/ /* returns boolean, non zero if the file exists */ int g_file_exist(const char *filename) { #if defined(_WIN32) return 0; // use FileAge(filename) <> -1 #else return access(filename, F_OK) == 0; #endif } /*****************************************************************************/ /* returns boolean, non zero if the file is readable */ int g_file_readable(const char *filename) { #if defined(_WIN32) return _waccess(filename, 04) == 0; #else return access(filename, R_OK) == 0; #endif } /*****************************************************************************/ /* returns boolean, non zero if the directory exists */ int g_directory_exist(const char *dirname) { #if defined(_WIN32) return 0; // use GetFileAttributes and check return value // is not -1 and FILE_ATTRIBUTE_DIRECTORY bit is set #else struct stat st; if (stat(dirname, &st) == 0) { return S_ISDIR(st.st_mode); } else { return 0; } #endif } /*****************************************************************************/ /* returns boolean */ int g_create_dir(const char *dirname) { #if defined(_WIN32) return CreateDirectoryA(dirname, 0); // test this #else return mkdir(dirname, (mode_t) - 1) == 0; #endif } /*****************************************************************************/ /* will try to create directories up to last / in name example /tmp/a/b/c/readme.txt will try to create /tmp/a/b/c returns boolean */ int g_create_path(const char *path) { char *pp; char *sp; char *copypath; int status; status = 1; copypath = g_strdup(path); pp = copypath; sp = strchr(pp, '/'); while (sp != 0) { if (sp != pp) { *sp = 0; if (!g_directory_exist(copypath)) { if (!g_create_dir(copypath)) { status = 0; break; } } *sp = '/'; } pp = sp + 1; sp = strchr(pp, '/'); } g_free(copypath); return status; } /*****************************************************************************/ /* returns boolean */ int g_remove_dir(const char *dirname) { #if defined(_WIN32) return RemoveDirectoryA(dirname); // test this #else return rmdir(dirname) == 0; #endif } /*****************************************************************************/ /* returns non zero if the file was deleted */ int g_file_delete(const char *filename) { #if defined(_WIN32) return DeleteFileA(filename); #else return unlink(filename) != -1; #endif } /*****************************************************************************/ /* returns file size, -1 on error */ int g_file_get_size(const char *filename) { #if defined(_WIN32) return -1; #else struct stat st; if (stat(filename, &st) == 0) { return (int)(st.st_size); } else { return -1; } #endif } /*****************************************************************************/ /* returns length of text */ int g_strlen(const char *text) { if (text == NULL) { return 0; } return strlen(text); } /*****************************************************************************/ /* locates char in text */ const char * g_strchr(const char* text, int c) { if (text == NULL) { return 0; } return strchr(text,c); } /*****************************************************************************/ /* returns dest */ char * g_strcpy(char *dest, const char *src) { if (src == 0 && dest != 0) { dest[0] = 0; return dest; } if (dest == 0 || src == 0) { return 0; } return strcpy(dest, src); } /*****************************************************************************/ /* returns dest */ char * g_strncpy(char *dest, const char *src, int len) { char *rv; if (src == 0 && dest != 0) { dest[0] = 0; return dest; } if (dest == 0 || src == 0) { return 0; } rv = strncpy(dest, src, len); dest[len] = 0; return rv; } /*****************************************************************************/ /* returns dest */ char * g_strcat(char *dest, const char *src) { if (dest == 0 || src == 0) { return dest; } return strcat(dest, src); } /*****************************************************************************/ /* if in = 0, return 0 else return newly alloced copy of in */ char * g_strdup(const char *in) { int len; char *p; if (in == 0) { return 0; } len = g_strlen(in); p = (char *)g_malloc(len + 1, 0); if (p != NULL) { g_strcpy(p, in); } return p; } /*****************************************************************************/ /* if in = 0, return 0 else return newly alloced copy of input string * if the input string is larger than maxlen the returned string will be * truncated. All strings returned will include null termination*/ char * g_strndup(const char *in, const unsigned int maxlen) { unsigned int len; char *p; if (in == 0) { return 0; } len = g_strlen(in); if (len > maxlen) { len = maxlen - 1; } p = (char *)g_malloc(len + 2, 0); if (p != NULL) { g_strncpy(p, in, len + 1); } return p; } /*****************************************************************************/ int g_strcmp(const char *c1, const char *c2) { return strcmp(c1, c2); } /*****************************************************************************/ int g_strncmp(const char *c1, const char *c2, int len) { return strncmp(c1, c2, len); } /*****************************************************************************/ /* compare up to delim */ int g_strncmp_d(const char *s1, const char *s2, const char delim, int n) { char c1; char c2; c1 = 0; c2 = 0; while (n > 0) { c1 = *(s1++); c2 = *(s2++); if ((c1 == 0) || (c1 != c2) || (c1 == delim) || (c2 == delim)) { return c1 - c2; } n--; } return c1 - c2; } /*****************************************************************************/ int g_strcasecmp(const char *c1, const char *c2) { #if defined(_WIN32) return stricmp(c1, c2); #else return strcasecmp(c1, c2); #endif } /*****************************************************************************/ int g_strncasecmp(const char *c1, const char *c2, int len) { #if defined(_WIN32) return strnicmp(c1, c2, len); #else return strncasecmp(c1, c2, len); #endif } /*****************************************************************************/ int g_atoi(const char *str) { if (str == 0) { return 0; } return atoi(str); } /*****************************************************************************/ int g_htoi(char *str) { int len; int index; int rv; int val; int shift; rv = 0; len = strlen(str); index = len - 1; shift = 0; while (index >= 0) { val = 0; switch (str[index]) { case '1': val = 1; break; case '2': val = 2; break; case '3': val = 3; break; case '4': val = 4; break; case '5': val = 5; break; case '6': val = 6; break; case '7': val = 7; break; case '8': val = 8; break; case '9': val = 9; break; case 'a': case 'A': val = 10; break; case 'b': case 'B': val = 11; break; case 'c': case 'C': val = 12; break; case 'd': case 'D': val = 13; break; case 'e': case 'E': val = 14; break; case 'f': case 'F': val = 15; break; } rv = rv | (val << shift); index--; shift += 4; } return rv; } /*****************************************************************************/ /* returns number of bytes copied into out_str */ int g_bytes_to_hexstr(const void *bytes, int num_bytes, char *out_str, int bytes_out_str) { int rv; int index; char *lout_str; const tui8 *lbytes; rv = 0; lbytes = (const tui8 *) bytes; lout_str = out_str; for (index = 0; index < num_bytes; index++) { if (bytes_out_str < 3) { break; } g_snprintf(lout_str, bytes_out_str, "%2.2x", lbytes[index]); lout_str += 2; bytes_out_str -= 2; rv += 2; } return rv; } /*****************************************************************************/ int g_pos(const char *str, const char *to_find) { const char *pp; pp = strstr(str, to_find); if (pp == 0) { return -1; } return (pp - str); } /*****************************************************************************/ int g_mbstowcs(twchar *dest, const char *src, int n) { wchar_t *ldest; int rv; ldest = (wchar_t *)dest; rv = mbstowcs(ldest, src, n); return rv; } /*****************************************************************************/ int g_wcstombs(char *dest, const twchar *src, int n) { const wchar_t *lsrc; int rv; lsrc = (const wchar_t *)src; rv = wcstombs(dest, lsrc, n); return rv; } /*****************************************************************************/ /* returns error */ /* trim spaces and tabs, anything <= space */ /* trim_flags 1 trim left, 2 trim right, 3 trim both, 4 trim through */ /* this will always shorten the string or not change it */ int g_strtrim(char *str, int trim_flags) { int index; int len; int text1_index; int got_char; wchar_t *text; wchar_t *text1; len = mbstowcs(0, str, 0); if (len < 1) { return 0; } if ((trim_flags < 1) || (trim_flags > 4)) { return 1; } text = (wchar_t *)malloc(len * sizeof(wchar_t) + 8); text1 = (wchar_t *)malloc(len * sizeof(wchar_t) + 8); text1_index = 0; mbstowcs(text, str, len + 1); switch (trim_flags) { case 4: /* trim through */ for (index = 0; index < len; index++) { if (text[index] > 32) { text1[text1_index] = text[index]; text1_index++; } } text1[text1_index] = 0; break; case 3: /* trim both */ got_char = 0; for (index = 0; index < len; index++) { if (got_char) { text1[text1_index] = text[index]; text1_index++; } else { if (text[index] > 32) { text1[text1_index] = text[index]; text1_index++; got_char = 1; } } } text1[text1_index] = 0; len = text1_index; /* trim right */ for (index = len - 1; index >= 0; index--) { if (text1[index] > 32) { break; } } text1_index = index + 1; text1[text1_index] = 0; break; case 2: /* trim right */ /* copy it */ for (index = 0; index < len; index++) { text1[text1_index] = text[index]; text1_index++; } /* trim right */ for (index = len - 1; index >= 0; index--) { if (text1[index] > 32) { break; } } text1_index = index + 1; text1[text1_index] = 0; break; case 1: /* trim left */ got_char = 0; for (index = 0; index < len; index++) { if (got_char) { text1[text1_index] = text[index]; text1_index++; } else { if (text[index] > 32) { text1[text1_index] = text[index]; text1_index++; got_char = 1; } } } text1[text1_index] = 0; break; } wcstombs(str, text1, text1_index + 1); free(text); free(text1); return 0; } /*****************************************************************************/ long g_load_library(char *in) { #if defined(_WIN32) return (long)LoadLibraryA(in); #else return (long)dlopen(in, RTLD_LOCAL | RTLD_LAZY); #endif } /*****************************************************************************/ int g_free_library(long lib) { if (lib == 0) { return 0; } #if defined(_WIN32) return FreeLibrary((HMODULE)lib); #else return dlclose((void *)lib); #endif } /*****************************************************************************/ /* returns NULL if not found */ void * g_get_proc_address(long lib, const char *name) { if (lib == 0) { return 0; } #if defined(_WIN32) return GetProcAddress((HMODULE)lib, name); #else return dlsym((void *)lib, name); #endif } /*****************************************************************************/ /* does not work in win32 */ int g_system(char *aexec) { #if defined(_WIN32) return 0; #else return system(aexec); #endif } /*****************************************************************************/ /* does not work in win32 */ char * g_get_strerror(void) { #if defined(_WIN32) return 0; #else return strerror(errno); #endif } /*****************************************************************************/ int g_get_errno(void) { #if defined(_WIN32) return GetLastError(); #else return errno; #endif } /*****************************************************************************/ /* does not work in win32 */ int g_execvp(const char *p1, char *args[]) { #if defined(_WIN32) return 0; #else int rv; g_rm_temp_dir(); rv = execvp(p1, args); g_mk_socket_path(0); return rv; #endif } /*****************************************************************************/ /* does not work in win32 */ int g_execlp3(const char *a1, const char *a2, const char *a3) { #if defined(_WIN32) return 0; #else int rv; g_rm_temp_dir(); rv = execlp(a1, a2, a3, (void *)0); g_mk_socket_path(0); return rv; #endif } /*****************************************************************************/ /* does not work in win32 */ void g_signal_child_stop(void (*func)(int)) { #if defined(_WIN32) #else signal(SIGCHLD, func); #endif } /*****************************************************************************/ void g_signal_segfault(void (*func)(int)) { #if defined(_WIN32) #else signal(SIGSEGV, func); #endif } /*****************************************************************************/ /* does not work in win32 */ void g_signal_hang_up(void (*func)(int)) { #if defined(_WIN32) #else signal(SIGHUP, func); #endif } /*****************************************************************************/ /* does not work in win32 */ void g_signal_user_interrupt(void (*func)(int)) { #if defined(_WIN32) #else signal(SIGINT, func); #endif } /*****************************************************************************/ /* does not work in win32 */ void g_signal_terminate(void (*func)(int)) { #if defined(_WIN32) #else signal(SIGTERM, func); #endif } /*****************************************************************************/ /* does not work in win32 */ void g_signal_pipe(void (*func)(int)) { #if defined(_WIN32) #else signal(SIGPIPE, func); #endif } /*****************************************************************************/ /* does not work in win32 */ void g_signal_usr1(void (*func)(int)) { #if defined(_WIN32) #else signal(SIGUSR1, func); #endif } /*****************************************************************************/ /* does not work in win32 */ int g_fork(void) { #if defined(_WIN32) return 0; #else int rv; rv = fork(); if (rv == 0) /* child */ { g_mk_socket_path(0); } return rv; #endif } /*****************************************************************************/ /* does not work in win32 */ int g_setgid(int pid) { #if defined(_WIN32) return 0; #else return setgid(pid); #endif } /*****************************************************************************/ /* returns error, zero is success, non zero is error */ /* does not work in win32 */ int g_initgroups(const char *user, int gid) { #if defined(_WIN32) return 0; #else return initgroups(user, gid); #endif } /*****************************************************************************/ /* does not work in win32 */ /* returns user id */ int g_getuid(void) { #if defined(_WIN32) return 0; #else return getuid(); #endif } /*****************************************************************************/ /* does not work in win32 */ /* returns user id */ int g_getgid(void) { #if defined(_WIN32) return 0; #else return getgid(); #endif } /*****************************************************************************/ /* does not work in win32 */ /* On success, zero is returned. On error, -1 is returned */ int g_setuid(int pid) { #if defined(_WIN32) return 0; #else return setuid(pid); #endif } /*****************************************************************************/ int g_setsid(void) { #if defined(_WIN32) return -1; #else return setsid(); #endif } /*****************************************************************************/ int g_setlogin(const char *name) { #ifdef BSD return setlogin(name); #else return -1; #endif } /*****************************************************************************/ /* does not work in win32 returns pid of process that exits or zero if signal occurred */ int g_waitchild(void) { #if defined(_WIN32) return 0; #else int wstat; int rv; rv = waitpid(0, &wstat, WNOHANG); if (rv == -1) { if (errno == EINTR) /* signal occurred */ { rv = 0; } } return rv; #endif } /*****************************************************************************/ /* does not work in win32 returns pid of process that exits or zero if signal occurred */ int g_waitpid(int pid) { #if defined(_WIN32) return 0; #else int rv = 0; if (pid < 0) { rv = -1; } else { rv = waitpid(pid, 0, 0); if (rv == -1) { if (errno == EINTR) /* signal occurred */ { rv = 0; } } } return rv; #endif } /*****************************************************************************/ /* does not work in win32 */ void g_clearenv(void) { #if defined(_WIN32) #else #if defined(BSD) environ[0] = 0; #else environ = 0; #endif #endif } /*****************************************************************************/ /* does not work in win32 */ int g_setenv(const char *name, const char *value, int rewrite) { #if defined(_WIN32) return 0; #else return setenv(name, value, rewrite); #endif } /*****************************************************************************/ /* does not work in win32 */ char * g_getenv(const char *name) { #if defined(_WIN32) return 0; #else return getenv(name); #endif } /*****************************************************************************/ int g_exit(int exit_code) { _exit(exit_code); return 0; } /*****************************************************************************/ int g_getpid(void) { #if defined(_WIN32) return (int)GetCurrentProcessId(); #else return (int)getpid(); #endif } /*****************************************************************************/ /* does not work in win32 */ int g_sigterm(int pid) { #if defined(_WIN32) return 0; #else return kill(pid, SIGTERM); #endif } /*****************************************************************************/ /* returns 0 if ok */ /* the caller is responsible to free the buffs */ /* does not work in win32 */ int g_getuser_info(const char *username, int *gid, int *uid, char **shell, char **dir, char **gecos) { #if defined(_WIN32) return 1; #else struct passwd *pwd_1; pwd_1 = getpwnam(username); if (pwd_1 != 0) { if (gid != 0) { *gid = pwd_1->pw_gid; } if (uid != 0) { *uid = pwd_1->pw_uid; } if (dir != 0) { *dir = g_strdup(pwd_1->pw_dir); } if (shell != 0) { *shell = g_strdup(pwd_1->pw_shell); } if (gecos != 0) { *gecos = g_strdup(pwd_1->pw_gecos); } return 0; } return 1; #endif } /*****************************************************************************/ /* returns 0 if ok */ /* does not work in win32 */ int g_getgroup_info(const char *groupname, int *gid) { #if defined(_WIN32) return 1; #else struct group *g; g = getgrnam(groupname); if (g != 0) { if (gid != 0) { *gid = g->gr_gid; } return 0; } return 1; #endif } /*****************************************************************************/ /* returns error */ /* if zero is returned, then ok is set */ /* does not work in win32 */ int g_check_user_in_group(const char *username, int gid, int *ok) { #if defined(_WIN32) return 1; #else struct group *groups; int i; groups = getgrgid(gid); if (groups == 0) { return 1; } *ok = 0; i = 0; while (0 != groups->gr_mem[i]) { if (0 == g_strcmp(groups->gr_mem[i], username)) { *ok = 1; break; } i++; } return 0; #endif } /*****************************************************************************/ /* returns the time since the Epoch (00:00:00 UTC, January 1, 1970), measured in seconds. for windows, returns the number of seconds since the machine was started. */ int g_time1(void) { #if defined(_WIN32) return GetTickCount() / 1000; #else return time(0); #endif } /*****************************************************************************/ /* returns the number of milliseconds since the machine was started. */ int g_time2(void) { #if defined(_WIN32) return (int)GetTickCount(); #else struct tms tm; clock_t num_ticks = 0; g_memset(&tm, 0, sizeof(struct tms)); num_ticks = times(&tm); return (int)(num_ticks * 10); #endif } /*****************************************************************************/ /* returns time in milliseconds, uses gettimeofday does not work in win32 */ int g_time3(void) { #if defined(_WIN32) return 0; #else struct timeval tp; gettimeofday(&tp, 0); return (tp.tv_sec * 1000) + (tp.tv_usec / 1000); #endif } /******************************************************************************/ /******************************************************************************/ struct bmp_magic { char magic[2]; }; struct bmp_hdr { unsigned int size; /* file size in bytes */ unsigned short reserved1; unsigned short reserved2; unsigned int offset; /* offset to image data, in bytes */ }; struct dib_hdr { unsigned int hdr_size; int width; int height; unsigned short nplanes; unsigned short bpp; unsigned int compress_type; unsigned int image_size; int hres; int vres; unsigned int ncolors; unsigned int nimpcolors; }; /******************************************************************************/ int g_save_to_bmp(const char* filename, char* data, int stride_bytes, int width, int height, int depth, int bits_per_pixel) { struct bmp_magic bm; struct bmp_hdr bh; struct dib_hdr dh; int bytes; int fd; int index; int i1; int pixel; int extra; int file_stride_bytes; char* line; char* line_ptr; if ((depth == 24) && (bits_per_pixel == 32)) { } else if ((depth == 32) && (bits_per_pixel == 32)) { } else { g_writeln("g_save_to_bpp: unimp"); return 1; } bm.magic[0] = 'B'; bm.magic[1] = 'M'; /* scan lines are 32 bit aligned, bottom 2 bits must be zero */ file_stride_bytes = width * ((depth + 7) / 8); extra = file_stride_bytes; extra = extra & 3; extra = (4 - extra) & 3; file_stride_bytes += extra; bh.size = sizeof(bm) + sizeof(bh) + sizeof(dh) + height * file_stride_bytes; bh.reserved1 = 0; bh.reserved2 = 0; bh.offset = sizeof(bm) + sizeof(bh) + sizeof(dh); dh.hdr_size = sizeof(dh); dh.width = width; dh.height = height; dh.nplanes = 1; dh.bpp = depth; dh.compress_type = 0; dh.image_size = height * file_stride_bytes; dh.hres = 0xb13; dh.vres = 0xb13; dh.ncolors = 0; dh.nimpcolors = 0; fd = open(filename, O_RDWR | O_CREAT | O_TRUNC, S_IRUSR | S_IWUSR); if (fd == -1) { g_writeln("g_save_to_bpp: open error"); return 1; } bytes = write(fd, &bm, sizeof(bm)); if (bytes != sizeof(bm)) { g_writeln("g_save_to_bpp: write error"); } bytes = write(fd, &bh, sizeof(bh)); if (bytes != sizeof(bh)) { g_writeln("g_save_to_bpp: write error"); } bytes = write(fd, &dh, sizeof(dh)); if (bytes != sizeof(dh)) { g_writeln("g_save_to_bpp: write error"); } data += stride_bytes * height; data -= stride_bytes; if ((depth == 24) && (bits_per_pixel == 32)) { line = (char *) malloc(file_stride_bytes); memset(line, 0, file_stride_bytes); for (index = 0; index < height; index++) { line_ptr = line; for (i1 = 0; i1 < width; i1++) { pixel = ((int*)data)[i1]; *(line_ptr++) = (pixel >> 0) & 0xff; *(line_ptr++) = (pixel >> 8) & 0xff; *(line_ptr++) = (pixel >> 16) & 0xff; } bytes = write(fd, line, file_stride_bytes); if (bytes != file_stride_bytes) { g_writeln("g_save_to_bpp: write error"); } data -= stride_bytes; } free(line); } else if (depth == bits_per_pixel) { for (index = 0; index < height; index++) { bytes = write(fd, data, width * (bits_per_pixel / 8)); if (bytes != width * (bits_per_pixel / 8)) { g_writeln("g_save_to_bpp: write error"); } data -= stride_bytes; } } else { g_writeln("g_save_to_bpp: unimp"); } close(fd); return 0; } /*****************************************************************************/ /* returns boolean */ int g_text2bool(const char *s) { if ( (g_atoi(s) != 0) || (0 == g_strcasecmp(s, "true")) || (0 == g_strcasecmp(s, "on")) || (0 == g_strcasecmp(s, "yes"))) { return 1; } return 0; } /*****************************************************************************/ /* returns pointer or nil on error */ void * g_shmat(int shmid) { #if defined(_WIN32) return 0; #else return shmat(shmid, 0, 0); #endif } /*****************************************************************************/ /* returns -1 on error 0 on success */ int g_shmdt(const void *shmaddr) { #if defined(_WIN32) return -1; #else return shmdt(shmaddr); #endif } /*****************************************************************************/ /* returns -1 on error 0 on success */ int g_gethostname(char *name, int len) { return gethostname(name, len); } static unsigned char g_reverse_byte[0x100] = { 0x00, 0x80, 0x40, 0xc0, 0x20, 0xa0, 0x60, 0xe0, 0x10, 0x90, 0x50, 0xd0, 0x30, 0xb0, 0x70, 0xf0, 0x08, 0x88, 0x48, 0xc8, 0x28, 0xa8, 0x68, 0xe8, 0x18, 0x98, 0x58, 0xd8, 0x38, 0xb8, 0x78, 0xf8, 0x04, 0x84, 0x44, 0xc4, 0x24, 0xa4, 0x64, 0xe4, 0x14, 0x94, 0x54, 0xd4, 0x34, 0xb4, 0x74, 0xf4, 0x0c, 0x8c, 0x4c, 0xcc, 0x2c, 0xac, 0x6c, 0xec, 0x1c, 0x9c, 0x5c, 0xdc, 0x3c, 0xbc, 0x7c, 0xfc, 0x02, 0x82, 0x42, 0xc2, 0x22, 0xa2, 0x62, 0xe2, 0x12, 0x92, 0x52, 0xd2, 0x32, 0xb2, 0x72, 0xf2, 0x0a, 0x8a, 0x4a, 0xca, 0x2a, 0xaa, 0x6a, 0xea, 0x1a, 0x9a, 0x5a, 0xda, 0x3a, 0xba, 0x7a, 0xfa, 0x06, 0x86, 0x46, 0xc6, 0x26, 0xa6, 0x66, 0xe6, 0x16, 0x96, 0x56, 0xd6, 0x36, 0xb6, 0x76, 0xf6, 0x0e, 0x8e, 0x4e, 0xce, 0x2e, 0xae, 0x6e, 0xee, 0x1e, 0x9e, 0x5e, 0xde, 0x3e, 0xbe, 0x7e, 0xfe, 0x01, 0x81, 0x41, 0xc1, 0x21, 0xa1, 0x61, 0xe1, 0x11, 0x91, 0x51, 0xd1, 0x31, 0xb1, 0x71, 0xf1, 0x09, 0x89, 0x49, 0xc9, 0x29, 0xa9, 0x69, 0xe9, 0x19, 0x99, 0x59, 0xd9, 0x39, 0xb9, 0x79, 0xf9, 0x05, 0x85, 0x45, 0xc5, 0x25, 0xa5, 0x65, 0xe5, 0x15, 0x95, 0x55, 0xd5, 0x35, 0xb5, 0x75, 0xf5, 0x0d, 0x8d, 0x4d, 0xcd, 0x2d, 0xad, 0x6d, 0xed, 0x1d, 0x9d, 0x5d, 0xdd, 0x3d, 0xbd, 0x7d, 0xfd, 0x03, 0x83, 0x43, 0xc3, 0x23, 0xa3, 0x63, 0xe3, 0x13, 0x93, 0x53, 0xd3, 0x33, 0xb3, 0x73, 0xf3, 0x0b, 0x8b, 0x4b, 0xcb, 0x2b, 0xab, 0x6b, 0xeb, 0x1b, 0x9b, 0x5b, 0xdb, 0x3b, 0xbb, 0x7b, 0xfb, 0x07, 0x87, 0x47, 0xc7, 0x27, 0xa7, 0x67, 0xe7, 0x17, 0x97, 0x57, 0xd7, 0x37, 0xb7, 0x77, 0xf7, 0x0f, 0x8f, 0x4f, 0xcf, 0x2f, 0xaf, 0x6f, 0xef, 0x1f, 0x9f, 0x5f, 0xdf, 0x3f, 0xbf, 0x7f, 0xff }; /*****************************************************************************/ /* mirror each byte while copying */ int g_mirror_memcpy(void *dst, const void *src, int len) { tui8 *dst8; const tui8 *src8; dst8 = (tui8 *) dst; src8 = (const tui8 *) src; while (len > 0) { *dst8 = g_reverse_byte[*src8]; dst8++; src8++; len--; } return 0; } xrdp-0.9.5/common/file.c000644 001751 001751 00000022747 13206666623 015023 0ustar00metameta000000 000000 /** * xrdp: A Remote Desktop Protocol server. * * Copyright (C) Jay Sorg 2004-2014 * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. * * read a config file */ #if defined(HAVE_CONFIG_H) #include #endif #include "arch.h" #include "os_calls.h" #include "list.h" #include "file.h" #include "parse.h" #define FILE_MAX_LINE_BYTES 2048 static int file_read_ini_line(struct stream *s, char *text, int text_bytes); /*****************************************************************************/ /* look up for a section name within str (i.e. pattern [section_name]) * if a section name is found, this function return 1 and copy the section * inplace of str. */ static int line_lookup_for_section_name(char *str, int str_bytes) { int name_index_start; int index; char c; name_index_start = -1; index = 0; while ((c = str[index]) != 0) { if (c == '[') { name_index_start = index + 1; } else if (c == ']' && name_index_start > 0) { if (name_index_start + index >= str_bytes) { return 0; } for (index = index - name_index_start; index > 0; index--) { str[0] = str[name_index_start]; str++; } str[0] = 0; return 1; } ++index; } return 0; } /*****************************************************************************/ /* returns error returns 0 if everything is ok returns 1 if problem reading file */ static int l_file_read_sections(int fd, int max_file_size, struct list *names) { struct stream *s; char text[FILE_MAX_LINE_BYTES]; int len; int rv; rv = 0; g_file_seek(fd, 0); g_memset(text, 0, FILE_MAX_LINE_BYTES); list_clear(names); make_stream(s); init_stream(s, max_file_size); len = g_file_read(fd, s->data, max_file_size); if (len > 0) { s->end = s->p + len; while (file_read_ini_line(s, text, FILE_MAX_LINE_BYTES) == 0) { if (line_lookup_for_section_name(text, FILE_MAX_LINE_BYTES) != 0) { list_add_item(names, (tbus)g_strdup(text)); } } } else if (len < 0) { rv = 1; } free_stream(s); return rv; } /*****************************************************************************/ /* Read a line in the stream 's', removing comments. * returns error * returns 0 if everything is ok * returns 1 if problem reading file */ static int file_read_ini_line(struct stream *s, char *text, int text_bytes) { int i; int skip_to_end; int at_end; char c; skip_to_end = 0; if (!s_check_rem(s, 1)) { return 1; } i = 0; in_uint8(s, c); while (c != 10 && c != 13) { /* these mean skip the rest of the line */ if (c == '#' || c == '!' || c == ';') { skip_to_end = 1; } if (!skip_to_end) { text[i] = c; i++; if (i >= text_bytes) { return 1; } } if (s_check_rem(s, 1)) { in_uint8(s, c); } else { c = 0; break; } } if (c == 10 || c == 13) { at_end = 0; while (c == 10 || c == 13) { if (s_check_rem(s, 1)) { in_uint8(s, c); } else { at_end = 1; break; } } if (!at_end) { s->p--; } } text[i] = 0; return 0; } /*****************************************************************************/ /* returns error */ static int file_split_name_value(char *text, char *name, char *value) { int len; int i; int value_index; int name_index; int on_to; value_index = 0; name_index = 0; on_to = 0; name[0] = 0; value[0] = 0; len = g_strlen(text); for (i = 0; i < len; i++) { if (text[i] == '=' && !on_to) { on_to = 1; } else if (on_to) { value[value_index] = text[i]; value_index++; value[value_index] = 0; } else { name[name_index] = text[i]; name_index++; name[name_index] = 0; } } g_strtrim(name, 3); /* trim both right and left */ g_strtrim(value, 3); /* trim both right and left */ return 0; } /*****************************************************************************/ /* return error */ static int l_file_read_section(int fd, int max_file_size, const char *section, struct list *names, struct list *values) { struct stream *s; char *data; char *text; char *name; char *value; char *lvalue; int len; int file_size; data = (char *) g_malloc(FILE_MAX_LINE_BYTES * 3, 0); text = data; name = text + FILE_MAX_LINE_BYTES; value = name + FILE_MAX_LINE_BYTES; file_size = 32 * 1024; /* 32 K file size limit */ g_file_seek(fd, 0); g_memset(text, 0, FILE_MAX_LINE_BYTES); list_clear(names); list_clear(values); make_stream(s); init_stream(s, file_size); len = g_file_read(fd, s->data, file_size); if (len > 0) { s->end = s->p + len; while (file_read_ini_line(s, text, FILE_MAX_LINE_BYTES) == 0) { if (line_lookup_for_section_name(text, FILE_MAX_LINE_BYTES) != 0) { if (g_strcasecmp(section, text) == 0) { while (file_read_ini_line(s, text, FILE_MAX_LINE_BYTES) == 0) { if (line_lookup_for_section_name(text, FILE_MAX_LINE_BYTES) != 0) { break; } if (g_strlen(text) > 0) { file_split_name_value(text, name, value); list_add_item(names, (tbus)g_strdup(name)); if (value[0] == '$') { lvalue = g_getenv(value + 1); if (lvalue != 0) { list_add_item(values, (tbus)g_strdup(lvalue)); } else { list_add_item(values, (tbus)g_strdup("")); } } else { list_add_item(values, (tbus)g_strdup(value)); } } } free_stream(s); g_free(data); return 0; } } } } free_stream(s); g_free(data); return 1; } /*****************************************************************************/ /* returns error returns 0 if everything is ok returns 1 if problem reading file */ /* 32 K file size limit */ int file_read_sections(int fd, struct list *names) { return l_file_read_sections(fd, 32 * 1024, names); } /*****************************************************************************/ /* return error */ /* this function should be preferred over file_read_sections because it can read any file size */ int file_by_name_read_sections(const char *file_name, struct list *names) { int fd; int file_size; int rv; file_size = g_file_get_size(file_name); if (file_size < 1) { return 1; } fd = g_file_open_ex(file_name, 1, 0, 0, 0); if (fd < 0) { return 1; } rv = l_file_read_sections(fd, file_size, names); g_file_close(fd); return rv; } /*****************************************************************************/ /* return error */ /* 32 K file size limit */ int file_read_section(int fd, const char *section, struct list *names, struct list *values) { return l_file_read_section(fd, 32 * 1024, section, names, values); } /*****************************************************************************/ /* return error */ /* this function should be preferred over file_read_section because it can read any file size */ int file_by_name_read_section(const char *file_name, const char *section, struct list *names, struct list *values) { int fd; int file_size; int rv; file_size = g_file_get_size(file_name); if (file_size < 1) { return 1; } fd = g_file_open_ex(file_name, 1, 0, 0, 0); if (fd < 0) { return 1; } rv = l_file_read_section(fd, file_size, section, names, values); g_file_close(fd); return rv; } xrdp-0.9.5/common/arch.h000644 001751 001751 00000007131 13174271344 015010 0ustar00metameta000000 000000 /** * xrdp: A Remote Desktop Protocol server. * * Copyright (C) Jay Sorg 2004-2014 * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ #if !defined(ARCH_H) #define ARCH_H #include #if defined(HAVE_STDINT_H) #include #else typedef signed char int8_t; typedef unsigned char uint8_t; typedef signed short int16_t; typedef unsigned short uint16_t; typedef signed int int32_t; typedef unsigned int uint32_t; #if defined(_WIN64) typedef signed __int64 int64_t; typedef unsigned __int64 uint64_t; typedef signed __int64 intptr_t; typedef unsigned __int64 uintptr_t; #else typedef signed long long int64_t; typedef unsigned long long uint64_t; typedef signed long intptr_t; typedef unsigned long uintptr_t; #endif #endif typedef int bool_t; /* you can define L_ENDIAN or B_ENDIAN and NEED_ALIGN or NO_NEED_ALIGN in the makefile to override */ /* check endianness */ #if !(defined(L_ENDIAN) || defined(B_ENDIAN)) #if !defined(__BYTE_ORDER) && defined(__linux__) #include #endif #if defined(BYTE_ORDER) #if BYTE_ORDER == BIG_ENDIAN #define B_ENDIAN #else #define L_ENDIAN #endif #endif #if !(defined(L_ENDIAN) || defined(B_ENDIAN)) #if defined(__sparc__) || defined(__PPC__) || defined(__ppc__) || \ defined(__hppa__) #define B_ENDIAN #else #define L_ENDIAN #endif #endif #endif /* check if we need to align data */ #if !(defined(NEED_ALIGN) || defined(NO_NEED_ALIGN)) #if defined(__sparc__) || defined(__alpha__) || defined(__hppa__) || \ defined(__AIX__) || defined(__PPC__) || defined(__mips__) || \ defined(__ia64__) || defined(__ppc__) || defined(__arm__) #define NEED_ALIGN #elif defined(__x86__) || defined(__x86_64__) || \ defined(__AMD64__) || defined(_M_IX86) || defined (_M_AMD64) || \ defined(__i386__) || defined(__aarch64__) #define NO_NEED_ALIGN #else #warning unknown arch #endif #endif /* defines for thread creation factory functions */ #if defined(_WIN32) #define THREAD_RV unsigned long #define THREAD_CC __stdcall #else #define THREAD_RV void* #define THREAD_CC #endif #if defined(_WIN32) #if defined(__BORLANDC__) #define EXPORT_CC _export __cdecl #else #define EXPORT_CC #endif #else #define EXPORT_CC #endif #ifndef DEFINED_Ts #define DEFINED_Ts typedef int8_t ti8; typedef uint8_t tui8; typedef int8_t tsi8; typedef int16_t ti16; typedef uint16_t tui16; typedef int16_t tsi16; typedef int32_t ti32; typedef uint32_t tui32; typedef int32_t tsi32; typedef int64_t ti64; typedef uint64_t tui64; typedef int64_t tsi64; typedef bool_t tbool; typedef intptr_t tbus; typedef intptr_t tintptr; /* wide char, socket */ #if defined(_WIN32) typedef unsigned short twchar; typedef unsigned int tsock; #else typedef int twchar; typedef int tsock; #endif #endif /* DEFINED_Ts */ /* format string verification */ #if defined(HAVE_FUNC_ATTRIBUTE_FORMAT) #define printflike(arg_format, arg_first_check) \ __attribute__((__format__(__printf__, arg_format, arg_first_check))) #else #define printflike(arg_format, arg_first_check) #endif /* module interface */ #ifdef __cplusplus extern "C" { #endif tintptr mod_init(void); int mod_exit(tintptr); #ifdef __cplusplus } #endif #endif xrdp-0.9.5/common/xrdp_constants.h000644 001751 001751 00000075522 13220727201 017143 0ustar00metameta000000 000000 /** * xrdp: A Remote Desktop Protocol server. * Miscellaneous protocol constants * * Copyright (C) Matthew Chapman 1999-2008 * Copyright (C) Jay Sorg 2004-2014 * Copyright (C) Kevin Zhou 2012 * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ #if !defined(XRDP_CONSTANTS_H) #define XRDP_CONSTANTS_H /* TCP port for Remote Desktop Protocol */ #define TCP_PORT_RDP 3389 /****************************************************************************** * * xrdp constants * ******************************************************************************/ #define INFO_CLIENT_NAME_BYTES 32 #define XRDP_MAX_BITMAP_CACHE_ID 3 #define XRDP_MAX_BITMAP_CACHE_IDX 2000 #define XRDP_BITMAP_CACHE_ENTRIES 2048 #define XR_MIN_KEY_CODE 8 #define XR_MAX_KEY_CODE 256 /* * Constants come from ITU-T Recommendations */ #define ISO_PDU_CR 0xE0 /* X.224 Connection Request */ #define ISO_PDU_CC 0xD0 /* X.224 Connection Confirm */ #define ISO_PDU_DR 0x80 /* Disconnect Request */ #define ISO_PDU_DT 0xF0 /* Data */ #define ISO_PDU_ER 0x70 /* Error */ /* MCS PDU codes (T.125) */ #define MCS_EDRQ 1 /* Erect Domain Request */ #define MCS_DPUM 8 /* Disconnect Provider Ultimatum */ #define MCS_AURQ 10 /* Attach User Request */ #define MCS_AUCF 11 /* Attach User Confirm */ #define MCS_CJRQ 14 /* Channel Join Request */ #define MCS_CJCF 15 /* Channel Join Confirm */ #define MCS_SDRQ 25 /* Send Data Request */ #define MCS_SDIN 26 /* Send Data Indication */ /* * Constants come from Remote Desktop Protocol */ /* RDP Security Negotiation codes */ #define RDP_NEG_REQ 0x01 /* MS-RDPBCGR 2.2.1.1.1 */ #define RDP_NEG_RSP 0x02 /* MS-RDPBCGR 2.2.1.2.1 */ #define RDP_NEG_FAILURE 0x03 /* MS-RDPBCGR 2.2.1.2.2 */ #define RDP_CORRELATION_INFO 0x06 /* MS-RDPBCGR 2.2.1.1.2 */ /* Protocol types codes (MS-RDPBCGR 2.2.1.1.1) */ #define PROTOCOL_RDP 0x00000000 #define PROTOCOL_SSL 0x00000001 #define PROTOCOL_HYBRID 0x00000002 #define PROTOCOL_RDSTLS 0x00000004 #define PROTOCOL_HYBRID_EX 0x00000008 /* Negotiation packet flags (MS-RDPBCGR 2.2.1.2.1) */ #define EXTENDED_CLIENT_DATA_SUPPORTED 0x01 #define DYNVC_GFX_PROTOCOL_SUPPORTED 0x02 #define NEGRSP_RESERVED 0x04 #define RESTRICTED_ADMIN_MODE_SUPPORTED 0x08 #define REDIRECTED_AUTHENTICATION_MODE_SUPPORTED 0x10 /* RDP Negotiation Failure Codes (MS-RDPBCGR 2.2.1.2.2) */ #define SSL_REQUIRED_BY_SERVER 0x00000001 #define SSL_NOT_ALLOWED_BY_SERVER 0x00000002 #define SSL_CERT_NOT_ON_SERVER 0x00000003 #define INCONSISTENT_FLAGS 0x00000004 #define HYBRID_REQUIRED_BY_SERVER 0x00000005 #define SSL_WITH_USER_AUTH_REQUIRED_BY_SERVER 0x00000006 /* Client Core Data: connectionType (MS-RDPBCGR 2.2.1.3.2) */ #define CONNECTION_TYPE_MODEM 0x01 #define CONNECTION_TYPE_BROADBAND_LOW 0x02 #define CONNECTION_TYPE_SATELLITE 0x03 #define CONNECTION_TYPE_BROADBAND_HIGH 0x04 #define CONNECTION_TYPE_WAN 0x05 #define CONNECTION_TYPE_LAN 0x06 #define CONNECTION_TYPE_AUTODETECT 0x07 /* Client Core Data: colorDepth, postBeta2ColorDepth (MS-RDPBCGR 2.2.1.3.2) */ #define RNS_UD_COLOR_4BPP 0xCA00 #define RNS_UD_COLOR_8BPP 0xCA01 #define RNS_UD_COLOR_16BPP_555 0xCA02 #define RNS_UD_COLOR_16BPP_565 0xCA03 #define RNS_UD_COLOR_24BPP 0xCA04 /* Slow-Path Input Event: messageType (MS-RDPBCGR 2.2.8.1.1.3.1.1) */ /* TODO: to be renamed */ #define RDP_INPUT_SYNCHRONIZE 0 #define RDP_INPUT_CODEPOINT 1 #define RDP_INPUT_VIRTKEY 2 #define RDP_INPUT_SCANCODE 4 #define RDP_INPUT_UNICODE 5 #define RDP_INPUT_MOUSE 0x8001 #define RDP_INPUT_MOUSEX 0x8002 #define FASTPATH_INPUT_ENCRYPTED 0x2 /* Fast-Path Input Event: eventCode (MS-RDPBCGR 2.2.8.1.2.2) */ #define FASTPATH_INPUT_EVENT_SCANCODE 0x0 #define FASTPATH_INPUT_EVENT_MOUSE 0x1 #define FASTPATH_INPUT_EVENT_MOUSEX 0x2 #define FASTPATH_INPUT_EVENT_SYNC 0x3 #define FASTPATH_INPUT_EVENT_UNICODE 0x4 #define FASTPATH_INPUT_EVENT_QOE_TIMESTAMP 0x6 /* Fast-Path Keyboard Event: eventHeader (MS-RDPBCGR 2.2.8.2.2.1) */ #define FASTPATH_INPUT_KBDFLAGS_RELEASE 0x01 #define FASTPATH_INPUT_KBDFLAGS_EXTENDED 0x02 #define FASTPATH_INPUT_KBDFLAGS_EXTENDED1 0x04 /* Server Fast-Path Update PDU: action (MS-RDPBCGR 2.2.0.1.2) */ #define FASTPATH_OUTPUT_ACTION_FASTPATH 0x0 #define FASTPATH_OUTPUT_ACTION_X224 0x3 /* Server Fast-Path Update PDU: flags (MS-RDPBCGR 2.2.0.1.2) */ #define FASTPATH_OUTPUT_ACTION_FASTPATH 0x0 #define FASTPATH_OUTPUT_SECURE_CHECKSUM 0x1 #define FASTPATH_OUTPUT_ENCRYPTED 0x2 /* Fast-Path Update: updateCode (MS-RDPBCGR 2.2.9.1.2.1) */ #define FASTPATH_UPDATETYPE_ORDERS 0x0 #define FASTPATH_UPDATETYPE_BITMAP 0x1 #define FASTPATH_UPDATETYPE_PALETTE 0x2 #define FASTPATH_UPDATETYPE_SYNCHRONIZE 0x3 #define FASTPATH_UPDATETYPE_SURFCMDS 0x4 #define FASTPATH_UPDATETYPE_PTR_NULL 0x5 #define FASTPATH_UPDATETYPE_PTR_DEFAULT 0x6 #define FASTPATH_UPDATETYPE_PTR_POSITION 0x8 #define FASTPATH_UPDATETYPE_COLOR 0x9 #define FASTPATH_UPDATETYPE_CACHED 0xA #define FASTPATH_UPDATETYPE_POINTER 0xB /* Fast-Path Update: fragmentation (MS-RDPBCGR 2.2.9.1.2.1) */ #define FASTPATH_FRAGMENT_SINGLE 0x0 #define FASTPATH_FRAGMENT_LAST 0x1 #define FASTPATH_FRAGMENT_FIRST 0x2 #define FASTPATH_FRAGMENT_NEXT 0x3 #define FASTPATH_OUTPUT_COMPRESSION_USED 0x2 /* Mouse Event: pointerFlags (MS-RDPBCGR 2.2.8.1.1.3.1.1.3) */ #define PTRFLAGS_HWHEEL 0x0400 #define PTRFLAGS_WHEEL 0x0200 #define PTRFLAGS_WHEEL_NEGATIVE 0x0100 #define WheelRotationMask 0x01FF #define PTRFLAGS_MOVE 0x0800 #define PTRFLAGS_DOWN 0x8000 #define PTRFLAGS_BUTTON1 0x1000 #define PTRFLAGS_BUTTON2 0x2000 #define PTRFLAGS_BUTTON3 0x4000 /* Extended Mouse Event: pointerFlags (MS-RDPBCGR 2.2.8.1.1.3.1.1.4) */ #define PTRXFLAGS_DOWN 0x8000 #define PTRXFLAGS_BUTTON1 0x0001 #define PTRXFLAGS_BUTTON2 0x0002 /* General Capability Set: osMajorType (MS-RDPBCGR 2.2.7.1.1) */ #define OSMAJORTYPE_UNSPECIFIED 0x0000 #define OSMAJORTYPE_WINDOWS 0x0001 #define OSMAJORTYPE_OS2 0x0002 #define OSMAJORTYPE_MACINTOSH 0x0003 #define OSMAJORTYPE_UNIX 0x0004 #define OSMAJORTYPE_IOS 0x0005 #define OSMAJORTYPE_OSX 0x0006 #define OSMAJORTYPE_ANDROID 0x0007 #define OSMAJORTYPE_CHROME_OS 0x0008 /* General Capability Set: osMinorType (MS-RDPBCGR 2.2.7.1.1) */ #define OSMINORTYPE_UNSPECIFIED 0x0000 #define OSMINORTYPE_WINDOWS_31X 0x0001 #define OSMINORTYPE_WINDOWS_95 0x0002 #define OSMINORTYPE_WINDOWS_NT 0x0003 #define OSMINORTYPE_OS2_V21 0x0004 #define OSMINORTYPE_POWER_PC 0x0005 #define OSMINORTYPE_MACINTOSH 0x0006 #define OSMINORTYPE_NATIVE_XSERVER 0x0007 #define OSMINORTYPE_PSEUDO_XSERVER 0x0008 #define OSMINORTYPE_WINDOWS_RT 0x0009 /* Extended Info Packet: performanceFlags (MS-RDPBCGR 2.2.1.11.1.1.1) */ /* TODO: to be renamed */ #define RDP5_DISABLE_NOTHING 0x00 #define RDP5_NO_WALLPAPER 0x01 #define RDP5_NO_FULLWINDOWDRAG 0x02 #define RDP5_NO_MENUANIMATIONS 0x04 #define RDP5_NO_THEMING 0x08 #define RDP5_NO_CURSOR_SHADOW 0x20 #define RDP5_NO_CURSORSETTINGS 0x40 /* disables cursor blinking */ /* Virtual channel options */ /* Channel Definition Structure: options (MS-RDPBCGR 2.2.1.3.4.1) */ #define REMOTE_CONTROL_PERSISTENT 0x00100000 /* NOTE: XR_ prefixed to avoid conflict with FreeRDP */ #define XR_CHANNEL_OPTION_SHOW_PROTOCOL 0x00200000 #define XR_CHANNEL_OPTION_COMPRESS 0x00400000 #define XR_CHANNEL_OPTION_COMPRESS_RDP 0x00800000 #define XR_CHANNEL_OPTION_PRI_LOW 0x02000000 #define XR_CHANNEL_OPTION_PRI_MED 0x04000000 #define XR_CHANNEL_OPTION_PRI_HIGH 0x08000000 #define XR_CHANNEL_OPTION_ENCRYPT_CS 0x10000000 #define XR_CHANNEL_OPTION_ENCRYPT_SC 0x20000000 #define XR_CHANNEL_OPTION_ENCRYPT_RDP 0x40000000 #define XR_CHANNEL_OPTION_INITIALIZED 0x80000000 /* RDPDR: Device Announce Header: DeviceType (MS-RDPEFS 2.2.1.3) */ /* TODO: to be renamed */ #define DEVICE_TYPE_SERIAL 0x01 #define DEVICE_TYPE_PARALLEL 0x02 #define DEVICE_TYPE_PRINTER 0x04 #define DEVICE_TYPE_DISK 0x08 #define DEVICE_TYPE_SCARD 0x20 /* Order Capability Set: orderSupportExFlags (MS-RDPBCGR 2.2.7.1.3) */ #define XR_ORDERFLAGS_EX_CACHE_BITMAP_REV3_SUPPORT 0x0002 #define XR_ORDERFLAGS_EX_ALTSEC_FRAME_MARKER_SUPPORT 0x0004 #define XR_ORDERFLAGS_EX_OFFSCREEN_COMPOSITE_SUPPORT 0x0100 /* Order Capability Set: orderSupport (MS-RDPBCGR 2.2.7.1.3) */ #define TS_NEG_DSTBLT_INDEX 0x00 #define TS_NEG_PATBLT_INDEX 0x01 #define TS_NEG_SCRBLT_INDEX 0x02 #define TS_NEG_MEMBLT_INDEX 0x03 #define TS_NEG_MEM3BLT_INDEX 0x04 /* 0x05 */ /* 0x06 */ #define TS_NEG_DRAWNINEGRID_INDEX 0x07 #define TS_NEG_LINETO_INDEX 0x08 #define TS_NEG_MULTI_DRAWNINEGRID_INDEX 0x09 /* 0x0A */ #define TS_NEG_SAVEBITMAP_INDEX 0x0B /* 0x0C */ /* 0x0D */ /* 0x0E */ #define TS_NEG_MULTIDSTBLT_INDEX 0x0F #define TS_NEG_MULTIPATBLT_INDEX 0x10 #define TS_NEG_MULTISCRBLT_INDEX 0x11 #define TS_NEG_MULTIOPAQUERECT_INDEX 0x12 #define TS_NEG_FAST_INDEX_INDEX 0x13 #define TS_NEG_POLYGON_SC_INDEX 0x14 #define TS_NEG_POLYGON_CB_INDEX 0x15 #define TS_NEG_POLYLINE_INDEX 0x16 /* 0x17 */ #define TS_NEG_FAST_GLYPH_INDEX 0x18 #define TS_NEG_ELLIPSE_SC_INDEX 0x19 #define TS_NEG_ELLIPSE_CB_INDEX 0x1A #define TS_NEG_INDEX_INDEX 0x1B /* 0x1C */ /* 0x1D */ /* 0x1E */ /* 0x1F */ /* General Capability Set: extraFlags (MS-RDPBCGR 2.2.7.1.1) */ #define TS_CAPS_PROTOCOLVERSION 0x0200 #define FASTPATH_OUTPUT_SUPPORTED 0x0001 #define NO_BITMAP_COMPRESSION_HDR 0x0400 #define LONG_CREDENTIALS_SUPPORTED 0x0004 #define AUTORECONNECT_SUPPORTED 0x0008 #define ENC_SALTED_CHECKSUM 0x0010 /* Order Capability Set: orderFlags (MS-RDPBCGR 2.2.7.1.3) */ #define NEGOTIATEORDERSUPPORT 0x0002 #define ZEROBOUNDSDELTASUPPORT 0x0008 #define COLORINDEXSUPPORT 0x0020 #define SOLIDPATTERNBRUSHONLY 0x0040 #define ORDERFLAGS_EXTRA_FLAGS 0x0080 /* Input Capability Set: inputFlags (MS-RDPBCGR 2.2.7.1.6) */ #define INPUT_FLAG_SCANCODES 0x0001 #define INPUT_FLAG_MOUSEX 0x0004 #define INPUT_FLAG_FASTPATH_INPUT 0x0008 #define INPUT_FLAG_UNICODE 0x0010 #define INPUT_FLAG_FASTPATH_INPUT2 0x0020 #define INPUT_FLAG_UNUSED1 0x0040 #define INPUT_FLAG_UNUSED2 0x0080 #define TS_INPUT_FLAG_MOUSE_HWHEEL 0x0100 #define TS_INPUT_FLAG_QOE_TIMESTAMPS 0x0200 /* Desktop Composition Capability Set: CompDeskSupportLevel (MS-RDPBCGR 2.2.7.2.8) */ #define COMPDESK_NOT_SUPPORTED 0x0000 #define COMPDESK_SUPPORTED 0x0001 /* Surface Commands Capability Set: cmdFlags (MS-RDPBCGR 2.2.7.2.9) */ #define SURFCMDS_SETSURFACEBITS 0x00000002 #define SURFCMDS_FRAMEMARKER 0x00000010 #define SURFCMDS_STREAMSUFRACEBITS 0x00000040 /* Bitmap Codec: codecGUID (MS-RDPBCGR 2.2.7.2.10.1.1) */ /* CODEC_GUID_NSCODEC CA8D1BB9-000F-154F-589FAE2D1A87E2D6 */ #define XR_CODEC_GUID_NSCODEC \ "\xb9\x1b\x8d\xca\x0f\x00\x4f\x15\x58\x9f\xae\x2d\x1a\x87\xe2\xd6" /* CODEC_GUID_REMOTEFX 76772F12-BD72-4463-AFB3B73C9C6F7886 */ #define XR_CODEC_GUID_REMOTEFX \ "\x12\x2F\x77\x76\x72\xBD\x63\x44\xAF\xB3\xB7\x3C\x9C\x6F\x78\x86" /* CODEC_GUID_IMAGE_REMOTEFX 2744CCD4-9D8A-4E74-803C-0ECBEEA19C54 */ #define XR_CODEC_GUID_IMAGE_REMOTEFX \ "\xD4\xCC\x44\x27\x8A\x9D\x74\x4E\x80\x3C\x0E\xCB\xEE\xA1\x9C\x54" /* MFVideoFormat_H264 0x34363248-0000-0010-800000AA00389B71 */ #define XR_CODEC_GUID_H264 \ "\x48\x32\x36\x34\x00\x00\x10\x00\x80\x00\x00\xAA\x00\x38\x9B\x71" /* CODEC_GUID_JPEG 1BAF4CE6-9EED-430C-869ACB8B37B66237 */ #define XR_CODEC_GUID_JPEG \ "\xE6\x4C\xAF\x1B\xED\x9E\x0C\x43\x86\x9A\xCB\x8B\x37\xB6\x62\x37" /* CODEC_GUID_PNG 0E0C858D-28E0-45DB-ADAA0F83E57CC560 */ #define XR_CODEC_GUID_PNG \ "\x8D\x85\x0C\x0E\xE0\x28\xDB\x45\xAD\xAA\x0F\x83\xE5\x7C\xC5\x60" /* Surface Command Type (MS-RDPBCGR 2.2.9.1.2.1.10.1) */ #define CMDTYPE_SET_SURFACE_BITS 0x0001 #define CMDTYPE_FRAME_MARKER 0x0004 #define CMDTYPE_STREAM_SURFACE_BITS 0x0006 /* RDP5 disconnect PDU */ /* Set Error Info PDU Data: errorInfo (MS-RDPBCGR 2.2.5.1.1) */ /* TODO: to be renamed */ #define exDiscReasonNoInfo 0x0000 #define exDiscReasonAPIInitiatedDisconnect 0x0001 #define exDiscReasonAPIInitiatedLogoff 0x0002 #define exDiscReasonServerIdleTimeout 0x0003 #define exDiscReasonServerLogonTimeout 0x0004 #define exDiscReasonReplacedByOtherConnection 0x0005 #define exDiscReasonOutOfMemory 0x0006 #define exDiscReasonServerDeniedConnection 0x0007 #define exDiscReasonServerDeniedConnectionFips 0x0008 #define exDiscReasonLicenseInternal 0x0100 #define exDiscReasonLicenseNoLicenseServer 0x0101 #define exDiscReasonLicenseNoLicense 0x0102 #define exDiscReasonLicenseErrClientMsg 0x0103 #define exDiscReasonLicenseHwidDoesntMatchLicense 0x0104 #define exDiscReasonLicenseErrClientLicense 0x0105 #define exDiscReasonLicenseCantFinishProtocol 0x0106 #define exDiscReasonLicenseClientEndedProtocol 0x0107 #define exDiscReasonLicenseErrClientEncryption 0x0108 #define exDiscReasonLicenseCantUpgradeLicense 0x0109 #define exDiscReasonLicenseNoRemoteConnections 0x010a /* Info Packet (TS_INFO_PACKET): flags (MS-RDPBCGR 2.2.1.11.1.1) */ /* TODO: to be renamed */ #define RDP_LOGON_AUTO 0x0008 #define RDP_LOGON_NORMAL 0x0033 #define RDP_COMPRESSION 0x0080 #define RDP_LOGON_BLOB 0x0100 #define RDP_LOGON_LEAVE_AUDIO 0x2000 /* Compression Flags (MS-RDPBCGR 3.1.8.2.1) */ /* TODO: to be renamed, not used anywhere */ #define RDP_MPPC_COMPRESSED 0x20 #define RDP_MPPC_RESET 0x40 #define RDP_MPPC_FLUSH 0x80 #define RDP_MPPC_DICT_SIZE 8192 /* RDP 4.0 | MS-RDPBCGR 3.1.8 */ /* Drawing Order: controlFlags (MS-RDPEGDI 2.2.2.2.1, ) */ /* TODO: to be renamed */ #define RDP_ORDER_STANDARD 0x01 #define RDP_ORDER_SECONDARY 0x02 #define RDP_ORDER_BOUNDS 0x04 #define RDP_ORDER_CHANGE 0x08 #define RDP_ORDER_DELTA 0x10 #define RDP_ORDER_LASTBOUNDS 0x20 #define RDP_ORDER_SMALL 0x40 #define RDP_ORDER_TINY 0x80 /* Drawing Order: orderType (MS-RDPEGDI 2.2.2.2.1.1.2) ? */ #define RDP_ORDER_DESTBLT 0 #define RDP_ORDER_PATBLT 1 #define RDP_ORDER_SCREENBLT 2 #define RDP_ORDER_LINE 9 #define RDP_ORDER_RECT 10 #define RDP_ORDER_DESKSAVE 11 #define RDP_ORDER_MEMBLT 13 #define RDP_ORDER_TRIBLT 14 #define RDP_ORDER_POLYLINE 22 #define RDP_ORDER_TEXT2 27 #define RDP_ORDER_COMPOSITE 37 /* 0x25 */ /* Secondary Drawing Order Header: orderType (MS-RDPEGDI 2.2.2.2.1.2.1.1) */ /* TODO: to be renamed */ #define RDP_ORDER_RAW_BMPCACHE 0 #define RDP_ORDER_COLCACHE 1 #define RDP_ORDER_BMPCACHE 2 #define RDP_ORDER_FONTCACHE 3 #define RDP_ORDER_RAW_BMPCACHE2 4 #define RDP_ORDER_BMPCACHE2 5 #define RDP_ORDER_BRUSHCACHE 7 #define RDP_ORDER_BMPCACHE3 8 /* Maps to generalCapabilitySet in T.128 page 138 */ /* Capability Set: capabilitySetType (MS-RDPBCGR 2.2.1.13.1.1.1) */ /* TODO: to be renamed */ #define RDP_CAPSET_GENERAL 0x0001 #define RDP_CAPLEN_GENERAL 0x18 #define RDP_CAPSET_BITMAP 0x0002 #define RDP_CAPLEN_BITMAP 0x1C #define RDP_CAPSET_ORDER 0x0003 #define RDP_CAPLEN_ORDER 0x58 #define ORDER_CAP_NEGOTIATE 2 #define ORDER_CAP_NOSUPPORT 4 #define RDP_CAPSET_BMPCACHE 0x0004 #define RDP_CAPLEN_BMPCACHE 0x28 #define RDP_CAPSET_CONTROL 0x0005 #define RDP_CAPLEN_CONTROL 0x0C #define RDP_CAPSET_ACTIVATE 0x0007 #define RDP_CAPLEN_ACTIVATE 0x0C #define RDP_CAPSET_POINTER 0x0008 #define RDP_CAPLEN_POINTER 0x0a #define RDP_CAPLEN_POINTER_MONO 0x08 #define RDP_CAPSET_SHARE 0x0009 #define RDP_CAPLEN_SHARE 0x08 #define RDP_CAPSET_COLCACHE 0x000A #define RDP_CAPLEN_COLCACHE 0x08 #define RDP_CAPSET_SOUND 0x000C #define RDP_CAPSET_INPUT 0x000D #define RDP_CAPLEN_INPUT 0x58 #define RDP_CAPSET_FONT 0x000E #define RDP_CAPLEN_FONT 0x04 #define RDP_CAPSET_BRUSHCACHE 0x000F #define RDP_CAPLEN_BRUSHCACHE 0x08 #define RDP_CAPSET_GLYPHCACHE 0x0010 #define RDP_CAPSET_OFFSCREENCACHE 0x0011 #define RDP_CAPSET_BITMAP_OFFSCREEN 0x0012 #define RDP_CAPLEN_BITMAP_OFFSCREEN 0x08 #define RDP_CAPSET_BMPCACHE2 0x0013 #define RDP_CAPLEN_BMPCACHE2 0x28 #define BMPCACHE2_FLAG_PERSIST ((long)1<<31) #define RDP_CAPSET_VIRCHAN 0x0014 #define RDP_CAPLEN_VIRCHAN 0x08 #define RDP_CAPSET_DRAWNINEGRIDCACHE 0x0015 #define RDP_CAPSET_DRAWGDIPLUS 0x0016 #define RDP_CAPSET_RAIL 0x0017 #define RDP_CAPSET_WINDOW 0x0018 #define RDP_CAPSET_COMPDESK 0x0019 #define RDP_CAPLEN_COMPDESK 0x06 #define RDP_CAPSET_MULTIFRAGMENT 0x001A #define RDP_CAPLEN_MULTIFRAGMENT 0x08 #define RDP_CAPSET_LPOINTER 0x001B #define RDP_CAPLEN_LPOINTER 0x06 #define RDP_CAPSET_FRAME_ACKNOWLEDGE 0x001E #define RDP_CAPLEN_FRAME_ACKNOWLEDGE 0x08 #define RDP_CAPSET_SURFCMDS 0x001C #define RDP_CAPLEN_SURFCMDS 0x0C #define RDP_CAPSET_BMPCODECS 0x001D #define RDP_CAPLEN_BMPCODECS 0x1C /* TS_SECURITY_HEADER: flags (MS-RDPBCGR 2.2.8.1.1.2.1) */ /* TODO: to be renamed */ #define SEC_CLIENT_RANDOM 0x0001 /* SEC_EXCHANGE_PKT? */ #define SEC_ENCRYPT 0x0008 #define SEC_LOGON_INFO 0x0040 /* SEC_INFO_PKT */ #define SEC_LICENCE_NEG 0x0080 /* SEC_LICENSE_PKT */ #define SEC_TAG_SRV_INFO 0x0c01 /* SC_CORE */ #define SEC_TAG_SRV_CRYPT 0x0c02 /* SC_SECURITY */ #define SEC_TAG_SRV_CHANNELS 0x0c03 /* SC_NET? */ /* TS_UD_HEADER: type (MS-RDPBCGR (2.2.1.3.1) */ /* TODO: to be renamed */ #define SEC_TAG_CLI_INFO 0xc001 /* CS_CORE? */ #define SEC_TAG_CLI_CRYPT 0xc002 /* CS_SECURITY? */ #define SEC_TAG_CLI_CHANNELS 0xc003 /* CS_CHANNELS? */ #define SEC_TAG_CLI_4 0xc004 /* CS_CLUSTER? */ #define SEC_TAG_CLI_MONITOR 0xc005 /* CS_MONITOR */ /* Server Proprietary Certificate (MS-RDPBCGR 2.2.1.4.3.1.1) */ /* TODO: to be renamed */ #define SEC_TAG_PUBKEY 0x0006 /* BB_RSA_KEY_BLOB */ #define SEC_TAG_KEYSIG 0x0008 /* BB_SIGNATURE_KEY_BLOB */ /* LicensingMessage (MS-RDPELE 2.2.2) */ /* TODO: to be renamed */ #define LICENCE_TAG_DEMAND 0x01 /* LICNSE_REQUEST */ #define LICENCE_TAG_AUTHREQ 0x02 /* PLATFORM_CHALLENGE */ #define LICENCE_TAG_ISSUE 0x03 /* NEW_LICENSE */ #define LICENCE_TAG_REISSUE 0x04 /* UPGRADE_LICENSE */ #define LICENCE_TAG_PRESENT 0x12 /* LICENSE_INFO */ #define LICENCE_TAG_REQUEST 0x13 /* NEW_LICENSE_REQUEST */ #define LICENCE_TAG_AUTHRESP 0x15 /* PLATFORM_CHALLENGE_RESPONSE */ #define LICENCE_TAG_RESULT 0xff /* LICENSE_BINARY_BLOB (MS-RDPBCGR 2.2.1.12.1.2) */ #define LICENCE_TAG_USER 0x000f /* BB_CLIENT_USER_NAME_BLOB */ #define LICENCE_TAG_HOST 0x0010 /* BB_CLIENT_MACHINE_NAME_BLOB */ /* Share Data Header: pduType2 (MS-RDPBCGR 2.2.8.1.1.1.2) */ /* TODO: to be renamed */ #define RDP_DATA_PDU_UPDATE 2 /* PDUTYPE2_UPDATE */ #define RDP_DATA_PDU_CONTROL 20 #define RDP_DATA_PDU_POINTER 27 #define RDP_DATA_PDU_INPUT 28 #define RDP_DATA_PDU_SYNCHRONISE 31 #define RDP_DATA_PDU_PLAY_SOUND 34 #define RDP_DATA_PDU_LOGON 38 #define RDP_DATA_PDU_FONT2 39 #define RDP_DATA_PDU_DISCONNECT 47 /* Control PDU Data: action (MS-RDPBCGR 2.2.1.15.1) */ /* TODO: to be renamed */ #define RDP_CTL_REQUEST_CONTROL 1 /* CTRLACTION_REQUEST_CONTROL */ #define RDP_CTL_GRANT_CONTROL 2 #define RDP_CTL_DETACH 3 #define RDP_CTL_COOPERATE 4 /* Slow-Path Graphics Update: updateType (MS-RDPBCGR 2.2.9.1.1.3.1) */ /* TODO: to be renamed */ #define RDP_UPDATE_ORDERS 0 #define RDP_UPDATE_BITMAP 1 #define RDP_UPDATE_PALETTE 2 #define RDP_UPDATE_SYNCHRONIZE 3 /* Server Pointer Update PDU: messageType (MS-RDPBCGR 2.2.9.1.1.4) */ /* TODO: to be renamed */ #define RDP_POINTER_SYSTEM 1 /* TS_PTRMSGTYPE_SYSTEM */ #define RDP_POINTER_MOVE 3 #define RDP_POINTER_COLOR 6 #define RDP_POINTER_CACHED 7 #define RDP_POINTER_POINTER 8 /* System Pointer Update: systemPointerType (MS-RDPBCGR 2.2.9.1.1.4.3) */ #define RDP_NULL_POINTER 0 #define RDP_DEFAULT_POINTER 0x7F00 /* Keyboard Event: keyboardFlags (MS-RDPBCGR 2.2.8.1.1.3.1.1.1) */ /* TODO: to be renamed */ #define KBD_FLAG_RIGHT 0x0001 #define KBD_FLAG_EXT 0x0100 /* KBDFLAGS_EXTENDED */ #define KBD_FLAG_QUIET 0x1000 #define KBD_FLAG_DOWN 0x4000 #define KBD_FLAG_UP 0x8000 /* Synchronize Event: toggleFlags (MS-RDPBCGR 2.2.8.1.1.3.1.1.5) */ /* TODO: to be renamed */ #define KBD_FLAG_SCROLL 0x0001 /* TS_SYNC_SCROLL_LOCK */ #define KBD_FLAG_NUMLOCK 0x0002 #define KBD_FLAG_CAPITAL 0x0004 #define TS_SYNC_KANA_LOCK 0x0008 /****************************************************************************** * * Constants come from other Microsoft products * *****************************************************************************/ /* Sound format constants - see also RFC 2361 and MS-RDPAI */ #define WAVE_FORMAT_PCM 0x0001 #define WAVE_FORMAT_ADPCM 0x0002 #define WAVE_FORMAT_ALAW 0x0006 #define WAVE_FORMAT_MULAW 0x0007 #define WAVE_FORMAT_MPEGLAYER3 0x0055 #define WAVE_FORMAT_OPUS 0x0069 #define WAVE_FORMAT_AAC 0xA106 /* https://technet.microsoft.com/ja-jp/library/aa387685.aspx */ #define SEC_RSA_MAGIC 0x31415352 /* RSA1 */ /* NTSTATUS Values (MS-ERREF 2.3.1) */ /* used for RDPDR */ #define STATUS_SUCCESS 0x00000000 #define STATUS_PENDING 0x00000103 #define STATUS_NO_MORE_FILES 0x80000006 #define STATUS_DEVICE_PAPER_EMPTY 0x8000000e #define STATUS_DEVICE_POWERED_OFF 0x8000000f #define STATUS_DEVICE_OFF_LINE 0x80000010 #define STATUS_DEVICE_BUSY 0x80000011 #define STATUS_INVALID_HANDLE 0xc0000008 #define STATUS_INVALID_PARAMETER 0xc000000d #define STATUS_NO_SUCH_FILE 0xc000000f #define STATUS_INVALID_DEVICE_REQUEST 0xc0000010 #define STATUS_ACCESS_DENIED 0xc0000022 #define STATUS_OBJECT_NAME_COLLISION 0xc0000035 #define STATUS_DISK_FULL 0xc000007f #define STATUS_FILE_IS_A_DIRECTORY 0xc00000ba #define STATUS_NOT_SUPPORTED 0xc00000bb #define STATUS_TIMEOUT 0xc0000102 #define STATUS_CANCELLED 0xc0000120 /* MS-SMB2 2.2.13 */ /* TODO: not used anywhere */ #define FILE_DIRECTORY_FILE 0x00000001 #define FILE_NON_DIRECTORY_FILE 0x00000040 #define FILE_OPEN_FOR_FREE_SPACE_QUERY 0x00800000 /* * not yet sorted out */ #define MCS_CONNECT_INITIAL 0x7f65 #define MCS_CONNECT_RESPONSE 0x7f66 #define BER_TAG_BOOLEAN 1 #define BER_TAG_INTEGER 2 #define BER_TAG_OCTET_STRING 4 #define BER_TAG_RESULT 10 #define MCS_TAG_DOMAIN_PARAMS 0x30 #define MCS_GLOBAL_CHANNEL 1003 #define MCS_USERCHANNEL_BASE 1001 /* RDP secure transport constants */ /* not used anywhere */ #define SEC_RANDOM_SIZE 32 #define SEC_MODULUS_SIZE 64 #define SEC_PADDING_SIZE 8 #define SEC_EXPONENT_SIZE 4 /* RDP licensing constants */ #define LICENCE_TOKEN_SIZE 10 #define LICENCE_HWID_SIZE 20 #define LICENCE_SIGNATURE_SIZE 16 /* RDP PDU codes */ #define RDP_PDU_DEMAND_ACTIVE 1 #define RDP_PDU_CONFIRM_ACTIVE 3 #define RDP_PDU_REDIRECT 4 #define RDP_PDU_DEACTIVATE 6 #define RDP_PDU_DATA 7 /* See T.128 */ /* not used anywhere */ #define RDP_KEYPRESS 0 #define RDP_KEYRELEASE (KBD_FLAG_DOWN | KBD_FLAG_UP) /* Raster operation masks */ #define ROP2_S(rop3) (rop3 & 0xf) #define ROP2_P(rop3) ((rop3 & 0x3) | ((rop3 & 0x30) >> 2)) #define ROP2_COPY 0xc #define ROP2_XOR 0x6 #define ROP2_AND 0x8 #define ROP2_NXOR 0x9 #define ROP2_OR 0xe #define MIX_TRANSPARENT 0 #define MIX_OPAQUE 1 #define TEXT2_VERTICAL 0x04 #define TEXT2_IMPLICIT_X 0x20 /* RDP bitmap cache (version 2) constants */ #define BMPCACHE2_C0_CELLS 0x78 #define BMPCACHE2_C1_CELLS 0x78 #define BMPCACHE2_C2_CELLS 0x150 #define BMPCACHE2_NUM_PSTCELLS 0x9f6 #define PDU_FLAG_FIRST 0x01 #define PDU_FLAG_LAST 0x02 #define RDP_SOURCE "MSTSC" /* Keymap flags */ #define MapRightShiftMask (1 << 0) #define MapLeftShiftMask (1 << 1) #define MapShiftMask (MapRightShiftMask | MapLeftShiftMask) #define MapRightAltMask (1 << 2) #define MapLeftAltMask (1 << 3) #define MapAltGrMask MapRightAltMask #define MapRightCtrlMask (1 << 4) #define MapLeftCtrlMask (1 << 5) #define MapCtrlMask (MapRightCtrlMask | MapLeftCtrlMask) #define MapRightWinMask (1 << 6) #define MapLeftWinMask (1 << 7) #define MapWinMask (MapRightWinMask | MapLeftWinMask) #define MapNumLockMask (1 << 8) #define MapCapsLockMask (1 << 9) #define MapLocalStateMask (1 << 10) #define MapInhibitMask (1 << 11) #define MASK_ADD_BITS(var, mask) (var |= mask) #define MASK_REMOVE_BITS(var, mask) (var &= ~mask) #define MASK_HAS_BITS(var, mask) ((var & mask)>0) #define MASK_CHANGE_BIT(var, mask, active) \ (var = ((var & ~mask) | (active ? mask : 0))) /* Clipboard constants, "borrowed" from GCC system headers in the w32 cross compiler */ #define CF_TEXT 1 #define CF_BITMAP 2 #define CF_METAFILEPICT 3 #define CF_SYLK 4 #define CF_DIF 5 #define CF_TIFF 6 #define CF_OEMTEXT 7 #define CF_DIB 8 #define CF_PALETTE 9 #define CF_PENDATA 10 #define CF_RIFF 11 #define CF_WAVE 12 #define CF_UNICODETEXT 13 #define CF_ENHMETAFILE 14 #define CF_HDROP 15 #define CF_LOCALE 16 #define CF_MAX 17 #define CF_OWNERDISPLAY 128 #define CF_DSPTEXT 129 #define CF_DSPBITMAP 130 #define CF_DSPMETAFILEPICT 131 #define CF_DSPENHMETAFILE 142 #define CF_PRIVATEFIRST 512 #define CF_PRIVATELAST 767 #define CF_GDIOBJFIRST 768 #define CF_GDIOBJLAST 1023 /* RDPDR constants */ #define RDPDR_MAX_DEVICES 0x10 /* drawable types */ #define WND_TYPE_BITMAP 0 #define WND_TYPE_WND 1 #define WND_TYPE_SCREEN 2 #define WND_TYPE_BUTTON 3 #define WND_TYPE_IMAGE 4 #define WND_TYPE_EDIT 5 #define WND_TYPE_LABEL 6 #define WND_TYPE_COMBO 7 #define WND_TYPE_SPECIAL 8 #define WND_TYPE_LISTBOX 9 #define WND_TYPE_OFFSCREEN 10 /* button states */ #define BUTTON_STATE_UP 0 #define BUTTON_STATE_DOWN 1 /* messages */ #define WM_PAINT 3 #define WM_KEYDOWN 15 #define WM_KEYUP 16 #define WM_MOUSEMOVE 100 #define WM_LBUTTONUP 101 #define WM_LBUTTONDOWN 102 #define WM_RBUTTONUP 103 #define WM_RBUTTONDOWN 104 #define WM_BUTTON3UP 105 #define WM_BUTTON3DOWN 106 #define WM_BUTTON4UP 107 #define WM_BUTTON4DOWN 108 #define WM_BUTTON5UP 109 #define WM_BUTTON5DOWN 110 #define WM_BUTTON6UP 111 #define WM_BUTTON6DOWN 112 #define WM_BUTTON7UP 113 #define WM_BUTTON7DOWN 114 #define WM_INVALIDATE 200 #define CB_ITEMCHANGE 300 #define FASTPATH_MAX_PACKET_SIZE 0x3fff #define XR_RDP_SCAN_LSHIFT 42 #define XR_RDP_SCAN_ALT 56 #endif xrdp-0.9.5/vnc/vnc.h000644 001751 001751 00000011206 13174243273 014155 0ustar00metameta000000 000000 /** * xrdp: A Remote Desktop Protocol server. * * Copyright (C) Jay Sorg 2004-2015 * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. * * libvnc */ /* include other h files */ #include "arch.h" #include "parse.h" #include "os_calls.h" #include "defines.h" #define CURRENT_MOD_VER 3 struct vnc { int size; /* size of this struct */ int version; /* internal version */ /* client functions */ int (*mod_start)(struct vnc* v, int w, int h, int bpp); int (*mod_connect)(struct vnc* v); int (*mod_event)(struct vnc* v, int msg, long param1, long param2, long param3, long param4); int (*mod_signal)(struct vnc* v); int (*mod_end)(struct vnc* v); int (*mod_set_param)(struct vnc *v, const char *name, const char *value); int (*mod_session_change)(struct vnc* v, int, int); int (*mod_get_wait_objs)(struct vnc* v, tbus* read_objs, int* rcount, tbus* write_objs, int* wcount, int* timeout); int (*mod_check_wait_objs)(struct vnc* v); tintptr mod_dumby[100 - 9]; /* align, 100 minus the number of mod functions above */ /* server functions */ int (*server_begin_update)(struct vnc* v); int (*server_end_update)(struct vnc* v); int (*server_fill_rect)(struct vnc* v, int x, int y, int cx, int cy); int (*server_screen_blt)(struct vnc* v, int x, int y, int cx, int cy, int srcx, int srcy); int (*server_paint_rect)(struct vnc* v, int x, int y, int cx, int cy, char* data, int width, int height, int srcx, int srcy); int (*server_set_cursor)(struct vnc* v, int x, int y, char* data, char* mask); int (*server_palette)(struct vnc* v, int* palette); int (*server_msg)(struct vnc* v, const char *msg, int code); int (*server_is_term)(struct vnc* v); int (*server_set_clip)(struct vnc* v, int x, int y, int cx, int cy); int (*server_reset_clip)(struct vnc* v); int (*server_set_fgcolor)(struct vnc* v, int fgcolor); int (*server_set_bgcolor)(struct vnc* v, int bgcolor); int (*server_set_opcode)(struct vnc* v, int opcode); int (*server_set_mixmode)(struct vnc* v, int mixmode); int (*server_set_brush)(struct vnc* v, int x_origin, int y_origin, int style, char* pattern); int (*server_set_pen)(struct vnc* v, int style, int width); int (*server_draw_line)(struct vnc* v, int x1, int y1, int x2, int y2); int (*server_add_char)(struct vnc* v, int font, int character, int offset, int baseline, int width, int height, char* data); int (*server_draw_text)(struct vnc* v, int font, int flags, int mixmode, int clip_left, int clip_top, int clip_right, int clip_bottom, int box_left, int box_top, int box_right, int box_bottom, int x, int y, char* data, int data_len); int (*server_reset)(struct vnc* v, int width, int height, int bpp); int (*server_query_channel)(struct vnc* v, int index, char* channel_name, int* channel_flags); int (*server_get_channel_id)(struct vnc* v, const char *name); int (*server_send_to_channel)(struct vnc* v, int channel_id, char* data, int data_len, int total_data_len, int flags); int (*server_bell_trigger)(struct vnc* v); tintptr server_dumby[100 - 25]; /* align, 100 minus the number of server functions above */ /* common */ tintptr handle; /* pointer to self as long */ tintptr wm; tintptr painter; tintptr si; /* mod data */ int server_width; int server_height; int server_bpp; int mod_width; int mod_height; int mod_bpp; char mod_name[256]; int mod_mouse_state; int palette[256]; int vnc_desktop; char username[256]; char password[256]; char ip[256]; char port[256]; int sck_closed; int shift_state; /* 0 up, 1 down */ int keylayout; int clip_chanid; struct stream *clip_data_s; int delay_ms; struct trans *trans; int got_guid; tui8 guid[16]; }; xrdp-0.9.5/vnc/Makefile.in000644 001751 001751 00000052073 13220730775 015272 0ustar00metameta000000 000000 # Makefile.in generated by automake 1.15.1 from Makefile.am. # @configure_input@ # Copyright (C) 1994-2017 Free Software Foundation, Inc. # This Makefile.in is free software; the Free Software Foundation # gives unlimited permission to copy and/or distribute it, # with or without modifications, as long as this notice is preserved. # This program is distributed in the hope that it will be useful, # but WITHOUT ANY WARRANTY, to the extent permitted by law; without # even the implied warranty of MERCHANTABILITY or FITNESS FOR A # PARTICULAR PURPOSE. @SET_MAKE@ VPATH = @srcdir@ am__is_gnu_make = { \ if test -z '$(MAKELEVEL)'; then \ false; \ elif test -n '$(MAKE_HOST)'; then \ true; \ elif test -n '$(MAKE_VERSION)' && test -n '$(CURDIR)'; then \ true; \ else \ false; \ fi; \ } am__make_running_with_option = \ case $${target_option-} in \ ?) ;; \ *) echo "am__make_running_with_option: internal error: invalid" \ "target option '$${target_option-}' specified" >&2; \ exit 1;; \ esac; \ has_opt=no; \ sane_makeflags=$$MAKEFLAGS; \ if $(am__is_gnu_make); then \ sane_makeflags=$$MFLAGS; \ else \ case $$MAKEFLAGS in \ *\\[\ \ ]*) \ bs=\\; \ sane_makeflags=`printf '%s\n' "$$MAKEFLAGS" \ | sed "s/$$bs$$bs[$$bs $$bs ]*//g"`;; \ esac; \ fi; \ skip_next=no; \ strip_trailopt () \ { \ flg=`printf '%s\n' "$$flg" | sed "s/$$1.*$$//"`; \ }; \ for flg in $$sane_makeflags; do \ test $$skip_next = yes && { skip_next=no; continue; }; \ case $$flg in \ *=*|--*) continue;; \ -*I) strip_trailopt 'I'; skip_next=yes;; \ -*I?*) strip_trailopt 'I';; \ -*O) strip_trailopt 'O'; skip_next=yes;; \ -*O?*) strip_trailopt 'O';; \ -*l) strip_trailopt 'l'; skip_next=yes;; \ -*l?*) strip_trailopt 'l';; \ -[dEDm]) skip_next=yes;; \ -[JT]) skip_next=yes;; \ esac; \ case $$flg in \ *$$target_option*) has_opt=yes; break;; \ esac; \ done; \ test $$has_opt = yes am__make_dryrun = (target_option=n; $(am__make_running_with_option)) am__make_keepgoing = (target_option=k; $(am__make_running_with_option)) pkgdatadir = $(datadir)/@PACKAGE@ pkgincludedir = $(includedir)/@PACKAGE@ pkglibdir = $(libdir)/@PACKAGE@ pkglibexecdir = $(libexecdir)/@PACKAGE@ am__cd = CDPATH="$${ZSH_VERSION+.}$(PATH_SEPARATOR)" && cd install_sh_DATA = $(install_sh) -c -m 644 install_sh_PROGRAM = $(install_sh) -c install_sh_SCRIPT = $(install_sh) -c INSTALL_HEADER = $(INSTALL_DATA) transform = $(program_transform_name) NORMAL_INSTALL = : PRE_INSTALL = : POST_INSTALL = : NORMAL_UNINSTALL = : PRE_UNINSTALL = : POST_UNINSTALL = : build_triplet = @build@ host_triplet = @host@ @XRDP_DEBUG_TRUE@am__append_1 = -DXRDP_DEBUG subdir = vnc ACLOCAL_M4 = $(top_srcdir)/aclocal.m4 am__aclocal_m4_deps = $(top_srcdir)/m4/ax_append_compile_flags.m4 \ $(top_srcdir)/m4/ax_append_flag.m4 \ $(top_srcdir)/m4/ax_cflags_warn_all.m4 \ $(top_srcdir)/m4/ax_check_compile_flag.m4 \ $(top_srcdir)/m4/ax_gcc_func_attribute.m4 \ $(top_srcdir)/m4/ax_require_defined.m4 \ $(top_srcdir)/m4/ax_type_socklen_t.m4 \ $(top_srcdir)/m4/libtool.m4 $(top_srcdir)/m4/ltoptions.m4 \ $(top_srcdir)/m4/ltsugar.m4 $(top_srcdir)/m4/ltversion.m4 \ $(top_srcdir)/m4/lt~obsolete.m4 $(top_srcdir)/m4/pkg.m4 \ $(top_srcdir)/configure.ac am__configure_deps = $(am__aclocal_m4_deps) $(CONFIGURE_DEPENDENCIES) \ $(ACLOCAL_M4) DIST_COMMON = $(srcdir)/Makefile.am $(am__DIST_COMMON) mkinstalldirs = $(install_sh) -d CONFIG_HEADER = $(top_builddir)/config_ac.h CONFIG_CLEAN_FILES = CONFIG_CLEAN_VPATH_FILES = am__vpath_adj_setup = srcdirstrip=`echo "$(srcdir)" | sed 's|.|.|g'`; am__vpath_adj = case $$p in \ $(srcdir)/*) f=`echo "$$p" | sed "s|^$$srcdirstrip/||"`;; \ *) f=$$p;; \ esac; am__strip_dir = f=`echo $$p | sed -e 's|^.*/||'`; am__install_max = 40 am__nobase_strip_setup = \ srcdirstrip=`echo "$(srcdir)" | sed 's/[].[^$$\\*|]/\\\\&/g'` am__nobase_strip = \ for p in $$list; do echo "$$p"; done | sed -e "s|$$srcdirstrip/||" am__nobase_list = $(am__nobase_strip_setup); \ for p in $$list; do echo "$$p $$p"; done | \ sed "s| $$srcdirstrip/| |;"' / .*\//!s/ .*/ ./; s,\( .*\)/[^/]*$$,\1,' | \ $(AWK) 'BEGIN { files["."] = "" } { files[$$2] = files[$$2] " " $$1; \ if (++n[$$2] == $(am__install_max)) \ { print $$2, files[$$2]; n[$$2] = 0; files[$$2] = "" } } \ END { for (dir in files) print dir, files[dir] }' am__base_list = \ sed '$$!N;$$!N;$$!N;$$!N;$$!N;$$!N;$$!N;s/\n/ /g' | \ sed '$$!N;$$!N;$$!N;$$!N;s/\n/ /g' am__uninstall_files_from_dir = { \ test -z "$$files" \ || { test ! -d "$$dir" && test ! -f "$$dir" && test ! -r "$$dir"; } \ || { echo " ( cd '$$dir' && rm -f" $$files ")"; \ $(am__cd) "$$dir" && rm -f $$files; }; \ } am__installdirs = "$(DESTDIR)$(moduledir)" LTLIBRARIES = $(module_LTLIBRARIES) libvnc_la_DEPENDENCIES = $(top_builddir)/common/libcommon.la am_libvnc_la_OBJECTS = vnc.lo libvnc_la_OBJECTS = $(am_libvnc_la_OBJECTS) AM_V_lt = $(am__v_lt_@AM_V@) am__v_lt_ = $(am__v_lt_@AM_DEFAULT_V@) am__v_lt_0 = --silent am__v_lt_1 = libvnc_la_LINK = $(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) \ $(LIBTOOLFLAGS) --mode=link $(CCLD) $(AM_CFLAGS) $(CFLAGS) \ $(libvnc_la_LDFLAGS) $(LDFLAGS) -o $@ AM_V_P = $(am__v_P_@AM_V@) am__v_P_ = $(am__v_P_@AM_DEFAULT_V@) am__v_P_0 = false am__v_P_1 = : AM_V_GEN = $(am__v_GEN_@AM_V@) am__v_GEN_ = $(am__v_GEN_@AM_DEFAULT_V@) am__v_GEN_0 = @echo " GEN " $@; am__v_GEN_1 = AM_V_at = $(am__v_at_@AM_V@) am__v_at_ = $(am__v_at_@AM_DEFAULT_V@) am__v_at_0 = @ am__v_at_1 = DEFAULT_INCLUDES = -I.@am__isrc@ -I$(top_builddir) depcomp = $(SHELL) $(top_srcdir)/depcomp am__depfiles_maybe = depfiles am__mv = mv -f COMPILE = $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) \ $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) LTCOMPILE = $(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) \ $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) \ $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) \ $(AM_CFLAGS) $(CFLAGS) AM_V_CC = $(am__v_CC_@AM_V@) am__v_CC_ = $(am__v_CC_@AM_DEFAULT_V@) am__v_CC_0 = @echo " CC " $@; am__v_CC_1 = CCLD = $(CC) LINK = $(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) \ $(LIBTOOLFLAGS) --mode=link $(CCLD) $(AM_CFLAGS) $(CFLAGS) \ $(AM_LDFLAGS) $(LDFLAGS) -o $@ AM_V_CCLD = $(am__v_CCLD_@AM_V@) am__v_CCLD_ = $(am__v_CCLD_@AM_DEFAULT_V@) am__v_CCLD_0 = @echo " CCLD " $@; am__v_CCLD_1 = SOURCES = $(libvnc_la_SOURCES) DIST_SOURCES = $(libvnc_la_SOURCES) am__can_run_installinfo = \ case $$AM_UPDATE_INFO_DIR in \ n|no|NO) false;; \ *) (install-info --version) >/dev/null 2>&1;; \ esac am__tagged_files = $(HEADERS) $(SOURCES) $(TAGS_FILES) $(LISP) # Read a list of newline-separated strings from the standard input, # and print each of them once, without duplicates. Input order is # *not* preserved. am__uniquify_input = $(AWK) '\ BEGIN { nonempty = 0; } \ { items[$$0] = 1; nonempty = 1; } \ END { if (nonempty) { for (i in items) print i; }; } \ ' # Make sure the list of sources is unique. This is necessary because, # e.g., the same source file might be shared among _SOURCES variables # for different programs/libraries. am__define_uniq_tagged_files = \ list='$(am__tagged_files)'; \ unique=`for i in $$list; do \ if test -f "$$i"; then echo $$i; else echo $(srcdir)/$$i; fi; \ done | $(am__uniquify_input)` ETAGS = etags CTAGS = ctags am__DIST_COMMON = $(srcdir)/Makefile.in $(top_srcdir)/depcomp DISTFILES = $(DIST_COMMON) $(DIST_SOURCES) $(TEXINFOS) $(EXTRA_DIST) ACLOCAL = @ACLOCAL@ AMTAR = @AMTAR@ AM_DEFAULT_VERBOSITY = @AM_DEFAULT_VERBOSITY@ AR = @AR@ AUTOCONF = @AUTOCONF@ AUTOHEADER = @AUTOHEADER@ AUTOMAKE = @AUTOMAKE@ AWK = @AWK@ CC = @CC@ CCDEPMODE = @CCDEPMODE@ CFLAGS = @CFLAGS@ CPP = @CPP@ CPPFLAGS = @CPPFLAGS@ CYGPATH_W = @CYGPATH_W@ DEFS = @DEFS@ DEPDIR = @DEPDIR@ DLLTOOL = @DLLTOOL@ DLOPEN_LIBS = @DLOPEN_LIBS@ DSYMUTIL = @DSYMUTIL@ DUMPBIN = @DUMPBIN@ ECHO_C = @ECHO_C@ ECHO_N = @ECHO_N@ ECHO_T = @ECHO_T@ EGREP = @EGREP@ EXEEXT = @EXEEXT@ FDKAAC_CFLAGS = @FDKAAC_CFLAGS@ FDKAAC_LIBS = @FDKAAC_LIBS@ FGREP = @FGREP@ FREERDP_CFLAGS = @FREERDP_CFLAGS@ FREERDP_LIBS = @FREERDP_LIBS@ FUSE_CFLAGS = @FUSE_CFLAGS@ FUSE_LIBS = @FUSE_LIBS@ GREP = @GREP@ INSTALL = @INSTALL@ INSTALL_DATA = @INSTALL_DATA@ INSTALL_PROGRAM = @INSTALL_PROGRAM@ INSTALL_SCRIPT = @INSTALL_SCRIPT@ INSTALL_STRIP_PROGRAM = @INSTALL_STRIP_PROGRAM@ LD = @LD@ LDFLAGS = @LDFLAGS@ LIBOBJS = @LIBOBJS@ LIBS = @LIBS@ LIBTOOL = @LIBTOOL@ LIPO = @LIPO@ LN_S = @LN_S@ LTLIBOBJS = @LTLIBOBJS@ LT_SYS_LIBRARY_PATH = @LT_SYS_LIBRARY_PATH@ MAKEINFO = @MAKEINFO@ MANIFEST_TOOL = @MANIFEST_TOOL@ MKDIR_P = @MKDIR_P@ NM = @NM@ NMEDIT = @NMEDIT@ OBJDUMP = @OBJDUMP@ OBJEXT = @OBJEXT@ OPENSSL = @OPENSSL@ OPENSSL_CFLAGS = @OPENSSL_CFLAGS@ OPENSSL_LIBS = @OPENSSL_LIBS@ OTOOL = @OTOOL@ OTOOL64 = @OTOOL64@ PACKAGE = @PACKAGE@ PACKAGE_BUGREPORT = @PACKAGE_BUGREPORT@ PACKAGE_NAME = @PACKAGE_NAME@ PACKAGE_STRING = @PACKAGE_STRING@ PACKAGE_TARNAME = @PACKAGE_TARNAME@ PACKAGE_URL = @PACKAGE_URL@ PACKAGE_VERSION = @PACKAGE_VERSION@ PAM_RULES = @PAM_RULES@ PATH_SEPARATOR = @PATH_SEPARATOR@ PIXMAN_CFLAGS = @PIXMAN_CFLAGS@ PIXMAN_LIBS = @PIXMAN_LIBS@ PKG_CONFIG = @PKG_CONFIG@ PKG_CONFIG_LIBDIR = @PKG_CONFIG_LIBDIR@ PKG_CONFIG_PATH = @PKG_CONFIG_PATH@ RANLIB = @RANLIB@ SED = @SED@ SET_MAKE = @SET_MAKE@ SHELL = @SHELL@ STRIP = @STRIP@ TurboJpegIncDir = @TurboJpegIncDir@ TurboJpegLibDir = @TurboJpegLibDir@ VERSION = @VERSION@ XMKMF = @XMKMF@ X_CFLAGS = @X_CFLAGS@ X_EXTRA_LIBS = @X_EXTRA_LIBS@ X_LIBS = @X_LIBS@ X_PRE_LIBS = @X_PRE_LIBS@ abs_builddir = @abs_builddir@ abs_srcdir = @abs_srcdir@ abs_top_builddir = @abs_top_builddir@ abs_top_srcdir = @abs_top_srcdir@ ac_ct_AR = @ac_ct_AR@ ac_ct_CC = @ac_ct_CC@ ac_ct_DUMPBIN = @ac_ct_DUMPBIN@ am__include = @am__include@ am__leading_dot = @am__leading_dot@ am__quote = @am__quote@ am__tar = @am__tar@ am__untar = @am__untar@ bindir = @bindir@ build = @build@ build_alias = @build_alias@ build_cpu = @build_cpu@ build_os = @build_os@ build_vendor = @build_vendor@ builddir = @builddir@ datadir = @datadir@ datarootdir = @datarootdir@ docdir = @docdir@ dvidir = @dvidir@ exec_prefix = @exec_prefix@ host = @host@ host_alias = @host_alias@ host_cpu = @host_cpu@ host_os = @host_os@ host_vendor = @host_vendor@ htmldir = @htmldir@ includedir = @includedir@ infodir = @infodir@ install_sh = @install_sh@ libdir = @libdir@ libexecdir = @libexecdir@ localedir = @localedir@ localstatedir = @localstatedir@ mandir = @mandir@ mkdir_p = @mkdir_p@ moduledir = @moduledir@ oldincludedir = @oldincludedir@ pdfdir = @pdfdir@ pkgconfigdir = @pkgconfigdir@ prefix = @prefix@ program_transform_name = @program_transform_name@ psdir = @psdir@ sbindir = @sbindir@ sharedstatedir = @sharedstatedir@ socketdir = @socketdir@ srcdir = @srcdir@ subdirs = @subdirs@ sysconfdir = @sysconfdir@ systemdsystemunitdir = @systemdsystemunitdir@ target_alias = @target_alias@ top_build_prefix = @top_build_prefix@ top_builddir = @top_builddir@ top_srcdir = @top_srcdir@ AM_CPPFLAGS = -DXRDP_CFG_PATH=\"${sysconfdir}/xrdp\" \ -DXRDP_SBIN_PATH=\"${sbindir}\" \ -DXRDP_SHARE_PATH=\"${datadir}/xrdp\" \ -DXRDP_PID_PATH=\"${localstatedir}/run\" \ -I$(top_srcdir)/common $(am__append_1) module_LTLIBRARIES = \ libvnc.la libvnc_la_SOURCES = \ vnc.c \ vnc.h libvnc_la_LIBADD = \ $(top_builddir)/common/libcommon.la libvnc_la_LDFLAGS = -avoid-version -module all: all-am .SUFFIXES: .SUFFIXES: .c .lo .o .obj $(srcdir)/Makefile.in: $(srcdir)/Makefile.am $(am__configure_deps) @for dep in $?; do \ case '$(am__configure_deps)' in \ *$$dep*) \ ( cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh ) \ && { if test -f $@; then exit 0; else break; fi; }; \ exit 1;; \ esac; \ done; \ echo ' cd $(top_srcdir) && $(AUTOMAKE) --foreign vnc/Makefile'; \ $(am__cd) $(top_srcdir) && \ $(AUTOMAKE) --foreign vnc/Makefile Makefile: $(srcdir)/Makefile.in $(top_builddir)/config.status @case '$?' in \ *config.status*) \ cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh;; \ *) \ echo ' cd $(top_builddir) && $(SHELL) ./config.status $(subdir)/$@ $(am__depfiles_maybe)'; \ cd $(top_builddir) && $(SHELL) ./config.status $(subdir)/$@ $(am__depfiles_maybe);; \ esac; $(top_builddir)/config.status: $(top_srcdir)/configure $(CONFIG_STATUS_DEPENDENCIES) cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh $(top_srcdir)/configure: $(am__configure_deps) cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh $(ACLOCAL_M4): $(am__aclocal_m4_deps) cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh $(am__aclocal_m4_deps): install-moduleLTLIBRARIES: $(module_LTLIBRARIES) @$(NORMAL_INSTALL) @list='$(module_LTLIBRARIES)'; test -n "$(moduledir)" || list=; \ list2=; for p in $$list; do \ if test -f $$p; then \ list2="$$list2 $$p"; \ else :; fi; \ done; \ test -z "$$list2" || { \ echo " $(MKDIR_P) '$(DESTDIR)$(moduledir)'"; \ $(MKDIR_P) "$(DESTDIR)$(moduledir)" || exit 1; \ echo " $(LIBTOOL) $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=install $(INSTALL) $(INSTALL_STRIP_FLAG) $$list2 '$(DESTDIR)$(moduledir)'"; \ $(LIBTOOL) $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=install $(INSTALL) $(INSTALL_STRIP_FLAG) $$list2 "$(DESTDIR)$(moduledir)"; \ } uninstall-moduleLTLIBRARIES: @$(NORMAL_UNINSTALL) @list='$(module_LTLIBRARIES)'; test -n "$(moduledir)" || list=; \ for p in $$list; do \ $(am__strip_dir) \ echo " $(LIBTOOL) $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=uninstall rm -f '$(DESTDIR)$(moduledir)/$$f'"; \ $(LIBTOOL) $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=uninstall rm -f "$(DESTDIR)$(moduledir)/$$f"; \ done clean-moduleLTLIBRARIES: -test -z "$(module_LTLIBRARIES)" || rm -f $(module_LTLIBRARIES) @list='$(module_LTLIBRARIES)'; \ locs=`for p in $$list; do echo $$p; done | \ sed 's|^[^/]*$$|.|; s|/[^/]*$$||; s|$$|/so_locations|' | \ sort -u`; \ test -z "$$locs" || { \ echo rm -f $${locs}; \ rm -f $${locs}; \ } libvnc.la: $(libvnc_la_OBJECTS) $(libvnc_la_DEPENDENCIES) $(EXTRA_libvnc_la_DEPENDENCIES) $(AM_V_CCLD)$(libvnc_la_LINK) -rpath $(moduledir) $(libvnc_la_OBJECTS) $(libvnc_la_LIBADD) $(LIBS) mostlyclean-compile: -rm -f *.$(OBJEXT) distclean-compile: -rm -f *.tab.c @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/vnc.Plo@am__quote@ .c.o: @am__fastdepCC_TRUE@ $(AM_V_CC)$(COMPILE) -MT $@ -MD -MP -MF $(DEPDIR)/$*.Tpo -c -o $@ $< @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) $(DEPDIR)/$*.Tpo $(DEPDIR)/$*.Po @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='$<' object='$@' libtool=no @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(COMPILE) -c -o $@ $< .c.obj: @am__fastdepCC_TRUE@ $(AM_V_CC)$(COMPILE) -MT $@ -MD -MP -MF $(DEPDIR)/$*.Tpo -c -o $@ `$(CYGPATH_W) '$<'` @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) $(DEPDIR)/$*.Tpo $(DEPDIR)/$*.Po @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='$<' object='$@' libtool=no @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(COMPILE) -c -o $@ `$(CYGPATH_W) '$<'` .c.lo: @am__fastdepCC_TRUE@ $(AM_V_CC)$(LTCOMPILE) -MT $@ -MD -MP -MF $(DEPDIR)/$*.Tpo -c -o $@ $< @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) $(DEPDIR)/$*.Tpo $(DEPDIR)/$*.Plo @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='$<' object='$@' libtool=yes @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(LTCOMPILE) -c -o $@ $< mostlyclean-libtool: -rm -f *.lo clean-libtool: -rm -rf .libs _libs ID: $(am__tagged_files) $(am__define_uniq_tagged_files); mkid -fID $$unique tags: tags-am TAGS: tags tags-am: $(TAGS_DEPENDENCIES) $(am__tagged_files) set x; \ here=`pwd`; \ $(am__define_uniq_tagged_files); \ shift; \ if test -z "$(ETAGS_ARGS)$$*$$unique"; then :; else \ test -n "$$unique" || unique=$$empty_fix; \ if test $$# -gt 0; then \ $(ETAGS) $(ETAGSFLAGS) $(AM_ETAGSFLAGS) $(ETAGS_ARGS) \ "$$@" $$unique; \ else \ $(ETAGS) $(ETAGSFLAGS) $(AM_ETAGSFLAGS) $(ETAGS_ARGS) \ $$unique; \ fi; \ fi ctags: ctags-am CTAGS: ctags ctags-am: $(TAGS_DEPENDENCIES) $(am__tagged_files) $(am__define_uniq_tagged_files); \ test -z "$(CTAGS_ARGS)$$unique" \ || $(CTAGS) $(CTAGSFLAGS) $(AM_CTAGSFLAGS) $(CTAGS_ARGS) \ $$unique GTAGS: here=`$(am__cd) $(top_builddir) && pwd` \ && $(am__cd) $(top_srcdir) \ && gtags -i $(GTAGS_ARGS) "$$here" cscopelist: cscopelist-am cscopelist-am: $(am__tagged_files) list='$(am__tagged_files)'; \ case "$(srcdir)" in \ [\\/]* | ?:[\\/]*) sdir="$(srcdir)" ;; \ *) sdir=$(subdir)/$(srcdir) ;; \ esac; \ for i in $$list; do \ if test -f "$$i"; then \ echo "$(subdir)/$$i"; \ else \ echo "$$sdir/$$i"; \ fi; \ done >> $(top_builddir)/cscope.files distclean-tags: -rm -f TAGS ID GTAGS GRTAGS GSYMS GPATH tags distdir: $(DISTFILES) @srcdirstrip=`echo "$(srcdir)" | sed 's/[].[^$$\\*]/\\\\&/g'`; \ topsrcdirstrip=`echo "$(top_srcdir)" | sed 's/[].[^$$\\*]/\\\\&/g'`; \ list='$(DISTFILES)'; \ dist_files=`for file in $$list; do echo $$file; done | \ sed -e "s|^$$srcdirstrip/||;t" \ -e "s|^$$topsrcdirstrip/|$(top_builddir)/|;t"`; \ case $$dist_files in \ */*) $(MKDIR_P) `echo "$$dist_files" | \ sed '/\//!d;s|^|$(distdir)/|;s,/[^/]*$$,,' | \ sort -u` ;; \ esac; \ for file in $$dist_files; do \ if test -f $$file || test -d $$file; then d=.; else d=$(srcdir); fi; \ if test -d $$d/$$file; then \ dir=`echo "/$$file" | sed -e 's,/[^/]*$$,,'`; \ if test -d "$(distdir)/$$file"; then \ find "$(distdir)/$$file" -type d ! -perm -700 -exec chmod u+rwx {} \;; \ fi; \ if test -d $(srcdir)/$$file && test $$d != $(srcdir); then \ cp -fpR $(srcdir)/$$file "$(distdir)$$dir" || exit 1; \ find "$(distdir)/$$file" -type d ! -perm -700 -exec chmod u+rwx {} \;; \ fi; \ cp -fpR $$d/$$file "$(distdir)$$dir" || exit 1; \ else \ test -f "$(distdir)/$$file" \ || cp -p $$d/$$file "$(distdir)/$$file" \ || exit 1; \ fi; \ done check-am: all-am check: check-am all-am: Makefile $(LTLIBRARIES) installdirs: for dir in "$(DESTDIR)$(moduledir)"; do \ test -z "$$dir" || $(MKDIR_P) "$$dir"; \ done install: install-am install-exec: install-exec-am install-data: install-data-am uninstall: uninstall-am install-am: all-am @$(MAKE) $(AM_MAKEFLAGS) install-exec-am install-data-am installcheck: installcheck-am install-strip: if test -z '$(STRIP)'; then \ $(MAKE) $(AM_MAKEFLAGS) INSTALL_PROGRAM="$(INSTALL_STRIP_PROGRAM)" \ install_sh_PROGRAM="$(INSTALL_STRIP_PROGRAM)" INSTALL_STRIP_FLAG=-s \ install; \ else \ $(MAKE) $(AM_MAKEFLAGS) INSTALL_PROGRAM="$(INSTALL_STRIP_PROGRAM)" \ install_sh_PROGRAM="$(INSTALL_STRIP_PROGRAM)" INSTALL_STRIP_FLAG=-s \ "INSTALL_PROGRAM_ENV=STRIPPROG='$(STRIP)'" install; \ fi mostlyclean-generic: clean-generic: distclean-generic: -test -z "$(CONFIG_CLEAN_FILES)" || rm -f $(CONFIG_CLEAN_FILES) -test . = "$(srcdir)" || test -z "$(CONFIG_CLEAN_VPATH_FILES)" || rm -f $(CONFIG_CLEAN_VPATH_FILES) maintainer-clean-generic: @echo "This command is intended for maintainers to use" @echo "it deletes files that may require special tools to rebuild." clean: clean-am clean-am: clean-generic clean-libtool clean-moduleLTLIBRARIES \ mostlyclean-am distclean: distclean-am -rm -rf ./$(DEPDIR) -rm -f Makefile distclean-am: clean-am distclean-compile distclean-generic \ distclean-tags dvi: dvi-am dvi-am: html: html-am html-am: info: info-am info-am: install-data-am: install-moduleLTLIBRARIES install-dvi: install-dvi-am install-dvi-am: install-exec-am: install-html: install-html-am install-html-am: install-info: install-info-am install-info-am: install-man: install-pdf: install-pdf-am install-pdf-am: install-ps: install-ps-am install-ps-am: installcheck-am: maintainer-clean: maintainer-clean-am -rm -rf ./$(DEPDIR) -rm -f Makefile maintainer-clean-am: distclean-am maintainer-clean-generic mostlyclean: mostlyclean-am mostlyclean-am: mostlyclean-compile mostlyclean-generic \ mostlyclean-libtool pdf: pdf-am pdf-am: ps: ps-am ps-am: uninstall-am: uninstall-moduleLTLIBRARIES .MAKE: install-am install-strip .PHONY: CTAGS GTAGS TAGS all all-am check check-am clean clean-generic \ clean-libtool clean-moduleLTLIBRARIES cscopelist-am ctags \ ctags-am distclean distclean-compile distclean-generic \ distclean-libtool distclean-tags distdir dvi dvi-am html \ html-am info info-am install install-am install-data \ install-data-am install-dvi install-dvi-am install-exec \ install-exec-am install-html install-html-am install-info \ install-info-am install-man install-moduleLTLIBRARIES \ install-pdf install-pdf-am install-ps install-ps-am \ install-strip installcheck installcheck-am installdirs \ maintainer-clean maintainer-clean-generic mostlyclean \ mostlyclean-compile mostlyclean-generic mostlyclean-libtool \ pdf pdf-am ps ps-am tags tags-am uninstall uninstall-am \ uninstall-moduleLTLIBRARIES .PRECIOUS: Makefile # Tell versions [3.59,3.63) of GNU make to not export all variables. # Otherwise a system limit (for SysV at least) may be exceeded. .NOEXPORT: xrdp-0.9.5/vnc/Makefile.am000644 001751 001751 00000000665 13133557325 015262 0ustar00metameta000000 000000 AM_CPPFLAGS = \ -DXRDP_CFG_PATH=\"${sysconfdir}/xrdp\" \ -DXRDP_SBIN_PATH=\"${sbindir}\" \ -DXRDP_SHARE_PATH=\"${datadir}/xrdp\" \ -DXRDP_PID_PATH=\"${localstatedir}/run\" \ -I$(top_srcdir)/common if XRDP_DEBUG AM_CPPFLAGS += -DXRDP_DEBUG endif module_LTLIBRARIES = \ libvnc.la libvnc_la_SOURCES = \ vnc.c \ vnc.h libvnc_la_LIBADD = \ $(top_builddir)/common/libcommon.la libvnc_la_LDFLAGS = -avoid-version -module xrdp-0.9.5/vnc/vnc.c000644 001751 001751 00000121553 13174271344 014157 0ustar00metameta000000 000000 /** * xrdp: A Remote Desktop Protocol server. * * Copyright (C) Jay Sorg 2004-2015 * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. * * libvnc */ #if defined(HAVE_CONFIG_H) #include #endif #include "vnc.h" #include "log.h" #include "trans.h" #include "ssl_calls.h" #define LLOG_LEVEL 1 #define LLOGLN(_level, _args) \ do \ { \ if (_level < LLOG_LEVEL) \ { \ g_write("xrdp:vnc [%10.10u]: ", g_time3()); \ g_writeln _args ; \ } \ } \ while (0) #define AS_LOG_MESSAGE log_message static int lib_mod_process_message(struct vnc *v, struct stream *s); /******************************************************************************/ static int lib_send_copy(struct vnc *v, struct stream *s) { return trans_write_copy_s(v->trans, s); } /******************************************************************************/ /* taken from vncauth.c */ /* performing the des3 crypt on the password so it can not be seen on the wire 'bytes' in, contains 16 bytes server random out, random and 'passwd' conbined */ static void rfbEncryptBytes(char *bytes, const char *passwd) { char key[24]; void *des; int len; /* key is simply password padded with nulls */ g_memset(key, 0, sizeof(key)); len = MIN(g_strlen(passwd), 8); g_mirror_memcpy(key, passwd, len); des = ssl_des3_encrypt_info_create(key, 0); ssl_des3_encrypt(des, 8, bytes, bytes); ssl_des3_info_delete(des); des = ssl_des3_encrypt_info_create(key, 0); ssl_des3_encrypt(des, 8, bytes + 8, bytes + 8); ssl_des3_info_delete(des); } /******************************************************************************/ /* sha1 hash 'passwd', create a string from the hash and call rfbEncryptBytes */ static void rfbHashEncryptBytes(char *bytes, const char *passwd) { char passwd_hash[20]; char passwd_hash_text[40]; void *sha1; int passwd_bytes; /* create password hash from password */ passwd_bytes = g_strlen(passwd); sha1 = ssl_sha1_info_create(); ssl_sha1_transform(sha1, "xrdp_vnc", 8); ssl_sha1_transform(sha1, passwd, passwd_bytes); ssl_sha1_transform(sha1, passwd, passwd_bytes); ssl_sha1_complete(sha1, passwd_hash); ssl_sha1_info_delete(sha1); g_snprintf(passwd_hash_text, 39, "%2.2x%2.2x%2.2x%2.2x", (tui8)passwd_hash[0], (tui8)passwd_hash[1], (tui8)passwd_hash[2], (tui8)passwd_hash[3]); passwd_hash_text[39] = 0; rfbEncryptBytes(bytes, passwd_hash_text); } /******************************************************************************/ static int lib_process_channel_data(struct vnc *v, int chanid, int flags, int size, struct stream *s, int total_size) { int type; int status; int length; int clip_bytes; int index; int format; struct stream *out_s; if (chanid == v->clip_chanid) { in_uint16_le(s, type); in_uint16_le(s, status); in_uint32_le(s, length); //g_writeln("clip data type %d status %d length %d", type, status, length); //g_hexdump(s->p, s->end - s->p); switch (type) { case 2: /* CLIPRDR_FORMAT_ANNOUNCE */ AS_LOG_MESSAGE(LOG_LEVEL_DEBUG, "CLIPRDR_FORMAT_ANNOUNCE - " "status %d length %d", status, length); make_stream(out_s); init_stream(out_s, 8192); out_uint16_le(out_s, 3); // msg-type: CLIPRDR_FORMAT_ACK out_uint16_le(out_s, 1); // msg-status-code: CLIPRDR_RESPONSE out_uint32_le(out_s, 0); // null (?) out_uint8s(out_s, 4); // pad s_mark_end(out_s); length = (int)(out_s->end - out_s->data); v->server_send_to_channel(v, v->clip_chanid, out_s->data, length, length, 3); free_stream(out_s); #if 0 // Send the CLIPRDR_DATA_REQUEST message to the cliprdr channel. // make_stream(out_s); init_stream(out_s, 8192); out_uint16_le(out_s, 4); // msg-type: CLIPRDR_DATA_REQUEST out_uint16_le(out_s, 0); // msg-status-code: CLIPRDR_REQUEST out_uint32_le(out_s, 4); // sizeof supported-format-list. out_uint32_le(out_s, 1); // supported-format-list: CF_TEXT out_uint8s(out_s, 0); // pad (garbage pad?) s_mark_end(out_s); length = (int)(out_s->end - out_s->data); v->server_send_to_channel(v, v->clip_chanid, out_s->data, length, length, 3); free_stream(out_s); #endif break; case 3: /* CLIPRDR_FORMAT_ACK */ AS_LOG_MESSAGE(LOG_LEVEL_DEBUG, "CLIPRDR_FORMAT_ACK - " "status %d length %d", status, length); break; case 4: /* CLIPRDR_DATA_REQUEST */ AS_LOG_MESSAGE(LOG_LEVEL_DEBUG, "CLIPRDR_DATA_REQUEST - " "status %d length %d", status, length); format = 0; if (length >= 4) { in_uint32_le(s, format); } /* only support CF_TEXT and CF_UNICODETEXT */ if ((format != 1) && (format != 13)) { break; } make_stream(out_s); init_stream(out_s, 8192); out_uint16_le(out_s, 5); out_uint16_le(out_s, 1); if (format == 13) /* CF_UNICODETEXT */ { out_uint32_le(out_s, v->clip_data_s->size * 2 + 2); for (index = 0; index < v->clip_data_s->size; index++) { out_uint8(out_s, v->clip_data_s->data[index]); out_uint8(out_s, 0); } out_uint8s(out_s, 2); } else if (format == 1) /* CF_TEXT */ { out_uint32_le(out_s, v->clip_data_s->size + 1); for (index = 0; index < v->clip_data_s->size; index++) { out_uint8(out_s, v->clip_data_s->data[index]); } out_uint8s(out_s, 1); } out_uint8s(out_s, 4); /* pad */ s_mark_end(out_s); length = (int)(out_s->end - out_s->data); v->server_send_to_channel(v, v->clip_chanid, out_s->data, length, length, 3); free_stream(out_s); break; case 5: /* CLIPRDR_DATA_RESPONSE */ AS_LOG_MESSAGE(LOG_LEVEL_DEBUG, "CLIPRDR_DATA_RESPONSE - " "status %d length %d", status, length); clip_bytes = MIN(length, 256); // - Read the response data from the cliprdr channel, stream 's'. // - Send the response data to the vnc server, stream 'out_s'. // make_stream(out_s); // Send the RFB message type (CLIENT_CUT_TEXT) to the vnc server. init_stream(out_s, clip_bytes + 1 + 3 + 4 + 16); out_uint8(out_s, 6); // RFB msg type: CLIENT_CUT_TEXT out_uint8s(out_s, 3); // padding // Send the length of the cut-text to the vnc server. out_uint32_be(out_s, clip_bytes); // Send the cut-text (as read from 's') to the vnc server. for (index = 0; index < clip_bytes; index++) { char cur_char = '\0'; in_uint8(s, cur_char); // text in from 's' out_uint8(out_s, cur_char); // text out to 'out_s' } s_mark_end(out_s); lib_send_copy(v, out_s); free_stream(out_s); break; default: { log_message(LOG_LEVEL_DEBUG, "VNC clip information unhandled"); break; } } } else { log_message(LOG_LEVEL_DEBUG, "lib_process_channel_data: unknown chanid: " "%d :(v->clip_chanid) %d", chanid, v->clip_chanid); } return 0; } /******************************************************************************/ int lib_mod_event(struct vnc *v, int msg, long param1, long param2, long param3, long param4) { struct stream *s; int key; int error; int x; int y; int cx; int cy; int size; int total_size; int chanid; int flags; char *data; error = 0; make_stream(s); if (msg == 0x5555) /* channel data */ { chanid = LOWORD(param1); flags = HIWORD(param1); size = (int)param2; data = (char *)param3; total_size = (int)param4; if ((size >= 0) && (size <= (32 * 1024)) && (data != 0)) { init_stream(s, size); out_uint8a(s, data, size); s_mark_end(s); s->p = s->data; error = lib_process_channel_data(v, chanid, flags, size, s, total_size); } else { error = 1; } } else if ((msg >= 15) && (msg <= 16)) /* key events */ { key = param2; if (key > 0) { if (key == 65027) /* altgr */ { if (v->shift_state) { /* fix for mstsc sending left control down with altgr */ init_stream(s, 8192); out_uint8(s, 4); out_uint8(s, 0); /* down flag */ out_uint8s(s, 2); out_uint32_be(s, 65507); /* left control */ s_mark_end(s); lib_send_copy(v, s); } } init_stream(s, 8192); out_uint8(s, 4); out_uint8(s, msg == 15); /* down flag */ out_uint8s(s, 2); out_uint32_be(s, key); s_mark_end(s); error = lib_send_copy(v, s); if (key == 65507) /* left control */ { v->shift_state = msg == 15; } } } else if (msg >= 100 && msg <= 110) /* mouse events */ { switch (msg) { case 100: break; /* WM_MOUSEMOVE */ case 101: v->mod_mouse_state &= ~1; break; /* WM_LBUTTONUP */ case 102: v->mod_mouse_state |= 1; break; /* WM_LBUTTONDOWN */ case 103: v->mod_mouse_state &= ~4; break; /* WM_RBUTTONUP */ case 104: v->mod_mouse_state |= 4; break; /* WM_RBUTTONDOWN */ case 105: v->mod_mouse_state &= ~2; break; case 106: v->mod_mouse_state |= 2; break; case 107: v->mod_mouse_state &= ~8; break; case 108: v->mod_mouse_state |= 8; break; case 109: v->mod_mouse_state &= ~16; break; case 110: v->mod_mouse_state |= 16; break; } init_stream(s, 8192); out_uint8(s, 5); out_uint8(s, v->mod_mouse_state); out_uint16_be(s, param1); out_uint16_be(s, param2); s_mark_end(s); error = lib_send_copy(v, s); } else if (msg == 200) /* invalidate */ { /* FramebufferUpdateRequest */ init_stream(s, 8192); out_uint8(s, 3); out_uint8(s, 0); x = (param1 >> 16) & 0xffff; out_uint16_be(s, x); y = param1 & 0xffff; out_uint16_be(s, y); cx = (param2 >> 16) & 0xffff; out_uint16_be(s, cx); cy = param2 & 0xffff; out_uint16_be(s, cy); s_mark_end(s); error = lib_send_copy(v, s); } free_stream(s); return error; } //****************************************************************************** int get_pixel_safe(char *data, int x, int y, int width, int height, int bpp) { int start = 0; int shift = 0; if (x < 0) { return 0; } if (y < 0) { return 0; } if (x >= width) { return 0; } if (y >= height) { return 0; } if (bpp == 1) { width = (width + 7) / 8; start = (y * width) + x / 8; shift = x % 8; return (data[start] & (0x80 >> shift)) != 0; } else if (bpp == 4) { width = (width + 1) / 2; start = y * width + x / 2; shift = x % 2; if (shift == 0) { return (data[start] & 0xf0) >> 4; } else { return data[start] & 0x0f; } } else if (bpp == 8) { return *(((unsigned char *)data) + (y * width + x)); } else if (bpp == 15 || bpp == 16) { return *(((unsigned short *)data) + (y * width + x)); } else if (bpp == 24 || bpp == 32) { return *(((unsigned int *)data) + (y * width + x)); } else { log_message(LOG_LEVEL_ERROR, "error in get_pixel_safe bpp %d", bpp); } return 0; } /******************************************************************************/ void set_pixel_safe(char *data, int x, int y, int width, int height, int bpp, int pixel) { int start = 0; int shift = 0; if (x < 0) { return; } if (y < 0) { return; } if (x >= width) { return; } if (y >= height) { return; } if (bpp == 1) { width = (width + 7) / 8; start = (y * width) + x / 8; shift = x % 8; if (pixel & 1) { data[start] = data[start] | (0x80 >> shift); } else { data[start] = data[start] & ~(0x80 >> shift); } } else if (bpp == 15 || bpp == 16) { *(((unsigned short *)data) + (y * width + x)) = pixel; } else if (bpp == 24) { *(data + (3 * (y * width + x)) + 0) = pixel >> 0; *(data + (3 * (y * width + x)) + 1) = pixel >> 8; *(data + (3 * (y * width + x)) + 2) = pixel >> 16; } else { log_message(LOG_LEVEL_ERROR, "error in set_pixel_safe bpp %d", bpp); } } /******************************************************************************/ int split_color(int pixel, int *r, int *g, int *b, int bpp, int *palette) { if (bpp == 8) { if (pixel >= 0 && pixel < 256 && palette != 0) { *r = (palette[pixel] >> 16) & 0xff; *g = (palette[pixel] >> 8) & 0xff; *b = (palette[pixel] >> 0) & 0xff; } } else if (bpp == 15) { *r = ((pixel >> 7) & 0xf8) | ((pixel >> 12) & 0x7); *g = ((pixel >> 2) & 0xf8) | ((pixel >> 8) & 0x7); *b = ((pixel << 3) & 0xf8) | ((pixel >> 2) & 0x7); } else if (bpp == 16) { *r = ((pixel >> 8) & 0xf8) | ((pixel >> 13) & 0x7); *g = ((pixel >> 3) & 0xfc) | ((pixel >> 9) & 0x3); *b = ((pixel << 3) & 0xf8) | ((pixel >> 2) & 0x7); } else if (bpp == 24 || bpp == 32) { *r = (pixel >> 16) & 0xff; *g = (pixel >> 8) & 0xff; *b = pixel & 0xff; } else { log_message(LOG_LEVEL_ERROR, "error in split_color bpp %d", bpp); } return 0; } /******************************************************************************/ int make_color(int r, int g, int b, int bpp) { if (bpp == 24) { return (r << 16) | (g << 8) | b; } else { log_message(LOG_LEVEL_ERROR, "error in make_color bpp %d", bpp); } return 0; } /******************************************************************************/ int lib_framebuffer_update(struct vnc *v) { char *d1; char *d2; char cursor_data[32 * (32 * 3)]; char cursor_mask[32 * (32 / 8)]; char text[256]; int num_recs; int i; int j; int k; int x; int y; int cx; int cy; int srcx; int srcy; unsigned int encoding; int Bpp; int pixel; int r; int g; int b; int error; int need_size; struct stream *s; struct stream *pixel_s; num_recs = 0; Bpp = (v->mod_bpp + 7) / 8; if (Bpp == 3) { Bpp = 4; } make_stream(pixel_s); make_stream(s); init_stream(s, 8192); error = trans_force_read_s(v->trans, s, 3); if (error == 0) { in_uint8s(s, 1); in_uint16_be(s, num_recs); error = v->server_begin_update(v); } for (i = 0; i < num_recs; i++) { if (error != 0) { break; } init_stream(s, 8192); error = trans_force_read_s(v->trans, s, 12); if (error == 0) { in_uint16_be(s, x); in_uint16_be(s, y); in_uint16_be(s, cx); in_uint16_be(s, cy); in_uint32_be(s, encoding); if (encoding == 0) /* raw */ { need_size = cx * cy * Bpp; init_stream(pixel_s, need_size); error = trans_force_read_s(v->trans, pixel_s, need_size); if (error == 0) { error = v->server_paint_rect(v, x, y, cx, cy, pixel_s->data, cx, cy, 0, 0); } } else if (encoding == 1) /* copy rect */ { init_stream(s, 8192); error = trans_force_read_s(v->trans, s, 4); if (error == 0) { in_uint16_be(s, srcx); in_uint16_be(s, srcy); error = v->server_screen_blt(v, x, y, cx, cy, srcx, srcy); } } else if (encoding == 0xffffff11) /* cursor */ { g_memset(cursor_data, 0, 32 * (32 * 3)); g_memset(cursor_mask, 0, 32 * (32 / 8)); j = cx * cy * Bpp; k = ((cx + 7) / 8) * cy; init_stream(s, j + k); error = trans_force_read_s(v->trans, s, j + k); if (error == 0) { in_uint8p(s, d1, j); in_uint8p(s, d2, k); for (j = 0; j < 32; j++) { for (k = 0; k < 32; k++) { pixel = get_pixel_safe(d2, k, 31 - j, cx, cy, 1); set_pixel_safe(cursor_mask, k, j, 32, 32, 1, !pixel); if (pixel) { pixel = get_pixel_safe(d1, k, 31 - j, cx, cy, v->mod_bpp); split_color(pixel, &r, &g, &b, v->mod_bpp, v->palette); pixel = make_color(r, g, b, 24); set_pixel_safe(cursor_data, k, j, 32, 32, 24, pixel); } } } /* keep these in 32x32, vnc cursor can be a lot bigger */ if (x > 31) { x = 31; } if (y > 31) { y = 31; } error = v->server_set_cursor(v, x, y, cursor_data, cursor_mask); } } else if (encoding == 0xffffff21) /* desktop size */ { v->mod_width = cx; v->mod_height = cy; error = v->server_reset(v, cx, cy, v->mod_bpp); } else { g_sprintf(text, "VNC error in lib_framebuffer_update encoding = %8.8x", encoding); v->server_msg(v, text, 1); } } } if (error == 0) { error = v->server_end_update(v); } if (error == 0) { /* FramebufferUpdateRequest */ init_stream(s, 8192); out_uint8(s, 3); out_uint8(s, 1); out_uint16_be(s, 0); out_uint16_be(s, 0); out_uint16_be(s, v->mod_width); out_uint16_be(s, v->mod_height); s_mark_end(s); error = lib_send_copy(v, s); } free_stream(s); free_stream(pixel_s); return error; } /******************************************************************************/ /* clip data from the vnc server */ int lib_clip_data(struct vnc *v) { struct stream *s; struct stream *out_s; int size; int error; free_stream(v->clip_data_s); v->clip_data_s = 0; make_stream(s); init_stream(s, 8192); error = trans_force_read_s(v->trans, s, 7); if (error == 0) { in_uint8s(s, 3); in_uint32_be(s, size); make_stream(v->clip_data_s); init_stream(v->clip_data_s, size); error = trans_force_read_s(v->trans, v->clip_data_s, size); } if (error == 0) { make_stream(out_s); init_stream(out_s, 8192); out_uint16_le(out_s, 2); out_uint16_le(out_s, 0); out_uint32_le(out_s, 0x90); out_uint8(out_s, 0x0d); out_uint8s(out_s, 35); out_uint8(out_s, 0x10); out_uint8s(out_s, 35); out_uint8(out_s, 0x01); out_uint8s(out_s, 35); out_uint8(out_s, 0x07); out_uint8s(out_s, 35); out_uint8s(out_s, 4); s_mark_end(out_s); size = (int)(out_s->end - out_s->data); error = v->server_send_to_channel(v, v->clip_chanid, out_s->data, size, size, 3); free_stream(out_s); } free_stream(s); return error; } /******************************************************************************/ int lib_palette_update(struct vnc *v) { struct stream *s; int first_color; int num_colors; int i; int r; int g; int b; int error; make_stream(s); init_stream(s, 8192); error = trans_force_read_s(v->trans, s, 5); if (error == 0) { in_uint8s(s, 1); in_uint16_be(s, first_color); in_uint16_be(s, num_colors); init_stream(s, 8192); error = trans_force_read_s(v->trans, s, num_colors * 6); } if (error == 0) { for (i = 0; i < num_colors; i++) { in_uint16_be(s, r); in_uint16_be(s, g); in_uint16_be(s, b); r = r >> 8; g = g >> 8; b = b >> 8; v->palette[first_color + i] = (r << 16) | (g << 8) | b; } error = v->server_begin_update(v); } if (error == 0) { error = v->server_palette(v, v->palette); } if (error == 0) { error = v->server_end_update(v); } free_stream(s); return error; } /******************************************************************************/ int lib_bell_trigger(struct vnc *v) { int error; error = v->server_bell_trigger(v); return error; } /******************************************************************************/ int lib_mod_signal(struct vnc *v) { g_writeln("lib_mod_signal: not used"); return 0; } /******************************************************************************/ static int lib_mod_process_message(struct vnc *v, struct stream *s) { char type; int error; char text[256]; in_uint8(s, type); error = 0; if (error == 0) { if (type == 0) /* framebuffer update */ { error = lib_framebuffer_update(v); } else if (type == 1) /* palette */ { error = lib_palette_update(v); } else if (type == 2) /* bell */ { error = lib_bell_trigger(v); } else if (type == 3) /* clipboard */ { log_message(LOG_LEVEL_DEBUG, "VNC got clip data"); error = lib_clip_data(v); } else { g_sprintf(text, "VNC unknown in lib_mod_signal %d", type); v->server_msg(v, text, 1); } } return error; } /******************************************************************************/ int lib_mod_start(struct vnc *v, int w, int h, int bpp) { v->server_begin_update(v); v->server_set_fgcolor(v, 0); v->server_fill_rect(v, 0, 0, w, h); v->server_end_update(v); v->server_width = w; v->server_height = h; v->server_bpp = bpp; return 0; } /******************************************************************************/ static int lib_open_clip_channel(struct vnc *v) { char init_data[12] = { 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0 }; v->clip_chanid = v->server_get_channel_id(v, "cliprdr"); if (v->clip_chanid >= 0) { v->server_send_to_channel(v, v->clip_chanid, init_data, 12, 12, 3); } return 0; } /******************************************************************************/ static int lib_data_in(struct trans *trans) { struct vnc *self; struct stream *s; LLOGLN(10, ("lib_data_in:")); if (trans == 0) { return 1; } self = (struct vnc *)(trans->callback_data); s = trans_get_in_s(trans); if (s == 0) { return 1; } if (lib_mod_process_message(self, s) != 0) { g_writeln("lib_data_in: lib_mod_process_message failed"); return 1; } init_stream(s, 0); return 0; } /******************************************************************************/ /* return error */ int lib_mod_connect(struct vnc *v) { char cursor_data[32 * (32 * 3)]; char cursor_mask[32 * (32 / 8)]; char con_port[256]; char text[256]; struct stream *s; struct stream *pixel_format; int error; int i; int check_sec_result; struct source_info *si; v->server_msg(v, "VNC started connecting", 0); check_sec_result = 1; /* check if bpp is supported for rdp connection */ switch (v->server_bpp) { case 8: case 15: case 16: case 24: case 32: break; default: v->server_msg(v, "VNC error - only supporting 8, 15, 16, 24 and 32 " "bpp rdp connections", 0); return 1; } if (g_strcmp(v->ip, "") == 0) { v->server_msg(v, "VNC error - no ip set", 0); return 1; } make_stream(s); g_sprintf(con_port, "%s", v->port); make_stream(pixel_format); v->trans = trans_create(TRANS_MODE_TCP, 8 * 8192, 8192); if (v->trans == 0) { v->server_msg(v, "VNC error: trans_create() failed", 0); free_stream(s); free_stream(pixel_format); return 1; } v->sck_closed = 0; if (v->delay_ms > 0) { g_sprintf(text, "Waiting %d ms for VNC to start...", v->delay_ms); v->server_msg(v, text, 0); g_sleep(v->delay_ms); } g_sprintf(text, "VNC connecting to %s %s", v->ip, con_port); v->server_msg(v, text, 0); si = (struct source_info *) (v->si); v->trans->si = si; v->trans->my_source = XRDP_SOURCE_MOD; error = trans_connect(v->trans, v->ip, con_port, 3000); if (error == 0) { v->server_msg(v, "VNC tcp connected", 0); /* protocol version */ init_stream(s, 8192); error = trans_force_read_s(v->trans, s, 12); if (error == 0) { s->p = s->data; out_uint8a(s, "RFB 003.003\n", 12); s_mark_end(s); error = trans_force_write_s(v->trans, s); } /* sec type */ if (error == 0) { init_stream(s, 8192); error = trans_force_read_s(v->trans, s, 4); } if (error == 0) { in_uint32_be(s, i); g_sprintf(text, "VNC security level is %d (1 = none, 2 = standard)", i); v->server_msg(v, text, 0); if (i == 1) /* none */ { check_sec_result = 0; } else if (i == 2) /* dec the password and the server random */ { init_stream(s, 8192); error = trans_force_read_s(v->trans, s, 16); if (error == 0) { init_stream(s, 8192); if (v->got_guid) { char guid_str[64]; g_bytes_to_hexstr(v->guid, 16, guid_str, 64); rfbHashEncryptBytes(s->data, guid_str); } else { rfbEncryptBytes(s->data, v->password); } s->p += 16; s_mark_end(s); error = trans_force_write_s(v->trans, s); check_sec_result = 1; // not needed } } else if (i == 0) { log_message(LOG_LEVEL_DEBUG, "VNC Server will disconnect"); error = 1; } else { log_message(LOG_LEVEL_DEBUG, "VNC unsupported security level"); error = 1; } } } if (error != 0) { log_message(LOG_LEVEL_DEBUG, "VNC error %d after security negotiation", error); } if (error == 0 && check_sec_result) { /* sec result */ init_stream(s, 8192); error = trans_force_read_s(v->trans, s, 4); if (error == 0) { in_uint32_be(s, i); if (i != 0) { v->server_msg(v, "VNC password failed", 0); error = 2; } else { v->server_msg(v, "VNC password ok", 0); } } } if (error == 0) { v->server_msg(v, "VNC sending share flag", 0); init_stream(s, 8192); s->data[0] = 1; s->p++; s_mark_end(s); error = trans_force_write_s(v->trans, s); /* share flag */ } else { log_message(LOG_LEVEL_DEBUG, "VNC error before sending share flag"); } if (error == 0) { v->server_msg(v, "VNC receiving server init", 0); init_stream(s, 8192); error = trans_force_read_s(v->trans, s, 4); /* server init */ } else { log_message(LOG_LEVEL_DEBUG, "VNC error before receiving server init"); } if (error == 0) { in_uint16_be(s, v->mod_width); in_uint16_be(s, v->mod_height); init_stream(pixel_format, 8192); v->server_msg(v, "VNC receiving pixel format", 0); error = trans_force_read_s(v->trans, pixel_format, 16); } else { log_message(LOG_LEVEL_DEBUG, "VNC error before receiving pixel format"); } if (error == 0) { v->mod_bpp = v->server_bpp; init_stream(s, 8192); v->server_msg(v, "VNC receiving name length", 0); error = trans_force_read_s(v->trans, s, 4); /* name len */ } else { log_message(LOG_LEVEL_DEBUG, "VNC error before receiving name length"); } if (error == 0) { in_uint32_be(s, i); if (i > 255 || i < 0) { error = 3; } else { init_stream(s, 8192); v->server_msg(v, "VNC receiving name", 0); error = trans_force_read_s(v->trans, s, i); /* name len */ g_memcpy(v->mod_name, s->data, i); v->mod_name[i] = 0; } } else { log_message(LOG_LEVEL_DEBUG, "VNC error before receiving name"); } /* should be connected */ if (error == 0) { /* SetPixelFormat */ init_stream(s, 8192); out_uint8(s, 0); out_uint8(s, 0); out_uint8(s, 0); out_uint8(s, 0); init_stream(pixel_format, 8192); if (v->mod_bpp == 8) { out_uint8(pixel_format, 8); /* bits per pixel */ out_uint8(pixel_format, 8); /* depth */ #if defined(B_ENDIAN) out_uint8(pixel_format, 1); /* big endian */ #else out_uint8(pixel_format, 0); /* big endian */ #endif out_uint8(pixel_format, 0); /* true color flag */ out_uint16_be(pixel_format, 0); /* red max */ out_uint16_be(pixel_format, 0); /* green max */ out_uint16_be(pixel_format, 0); /* blue max */ out_uint8(pixel_format, 0); /* red shift */ out_uint8(pixel_format, 0); /* green shift */ out_uint8(pixel_format, 0); /* blue shift */ out_uint8s(pixel_format, 3); /* pad */ } else if (v->mod_bpp == 15) { out_uint8(pixel_format, 16); /* bits per pixel */ out_uint8(pixel_format, 15); /* depth */ #if defined(B_ENDIAN) out_uint8(pixel_format, 1); /* big endian */ #else out_uint8(pixel_format, 0); /* big endian */ #endif out_uint8(pixel_format, 1); /* true color flag */ out_uint16_be(pixel_format, 31); /* red max */ out_uint16_be(pixel_format, 31); /* green max */ out_uint16_be(pixel_format, 31); /* blue max */ out_uint8(pixel_format, 10); /* red shift */ out_uint8(pixel_format, 5); /* green shift */ out_uint8(pixel_format, 0); /* blue shift */ out_uint8s(pixel_format, 3); /* pad */ } else if (v->mod_bpp == 16) { out_uint8(pixel_format, 16); /* bits per pixel */ out_uint8(pixel_format, 16); /* depth */ #if defined(B_ENDIAN) out_uint8(pixel_format, 1); /* big endian */ #else out_uint8(pixel_format, 0); /* big endian */ #endif out_uint8(pixel_format, 1); /* true color flag */ out_uint16_be(pixel_format, 31); /* red max */ out_uint16_be(pixel_format, 63); /* green max */ out_uint16_be(pixel_format, 31); /* blue max */ out_uint8(pixel_format, 11); /* red shift */ out_uint8(pixel_format, 5); /* green shift */ out_uint8(pixel_format, 0); /* blue shift */ out_uint8s(pixel_format, 3); /* pad */ } else if (v->mod_bpp == 24 || v->mod_bpp == 32) { out_uint8(pixel_format, 32); /* bits per pixel */ out_uint8(pixel_format, 24); /* depth */ #if defined(B_ENDIAN) out_uint8(pixel_format, 1); /* big endian */ #else out_uint8(pixel_format, 0); /* big endian */ #endif out_uint8(pixel_format, 1); /* true color flag */ out_uint16_be(pixel_format, 255); /* red max */ out_uint16_be(pixel_format, 255); /* green max */ out_uint16_be(pixel_format, 255); /* blue max */ out_uint8(pixel_format, 16); /* red shift */ out_uint8(pixel_format, 8); /* green shift */ out_uint8(pixel_format, 0); /* blue shift */ out_uint8s(pixel_format, 3); /* pad */ } out_uint8a(s, pixel_format->data, 16); v->server_msg(v, "VNC sending pixel format", 0); s_mark_end(s); error = trans_force_write_s(v->trans, s); } if (error == 0) { /* SetEncodings */ init_stream(s, 8192); out_uint8(s, 2); out_uint8(s, 0); out_uint16_be(s, 4); out_uint32_be(s, 0); /* raw */ out_uint32_be(s, 1); /* copy rect */ out_uint32_be(s, 0xffffff11); /* cursor */ out_uint32_be(s, 0xffffff21); /* desktop size */ v->server_msg(v, "VNC sending encodings", 0); s_mark_end(s); error = trans_force_write_s(v->trans, s); } if (error == 0) { error = v->server_reset(v, v->mod_width, v->mod_height, v->mod_bpp); } if (error == 0) { /* FramebufferUpdateRequest */ init_stream(s, 8192); out_uint8(s, 3); out_uint8(s, 0); out_uint16_be(s, 0); out_uint16_be(s, 0); out_uint16_be(s, v->mod_width); out_uint16_be(s, v->mod_height); v->server_msg(v, "VNC sending framebuffer update request", 0); s_mark_end(s); error = trans_force_write_s(v->trans, s); } if (error == 0) { if (v->server_bpp != v->mod_bpp) { v->server_msg(v, "VNC error - server bpp and client bpp do not match", 0); error = 1; } } if (error == 0) { /* set almost null cursor, this is the little dot cursor */ g_memset(cursor_data, 0, 32 * (32 * 3)); g_memset(cursor_data + (32 * (32 * 3) - 1 * 32 * 3), 0xff, 9); g_memset(cursor_data + (32 * (32 * 3) - 2 * 32 * 3), 0xff, 9); g_memset(cursor_data + (32 * (32 * 3) - 3 * 32 * 3), 0xff, 9); g_memset(cursor_mask, 0xff, 32 * (32 / 8)); v->server_msg(v, "VNC sending cursor", 0); error = v->server_set_cursor(v, 3, 3, cursor_data, cursor_mask); } free_stream(s); free_stream(pixel_format); if (error == 0) { v->server_msg(v, "VNC connection complete, connected ok", 0); lib_open_clip_channel(v); } else { v->server_msg(v, "VNC error - problem connecting", 0); } if (error != 0) { trans_delete(v->trans); v->trans = 0; v->server_msg(v, "some problem", 0); return 1; } else { v->server_msg(v, "connected ok", 0); v->trans->trans_data_in = lib_data_in; v->trans->header_size = 1; v->trans->callback_data = v; } return error; } /******************************************************************************/ int lib_mod_end(struct vnc *v) { if (v->vnc_desktop != 0) { } free_stream(v->clip_data_s); return 0; } /******************************************************************************/ int lib_mod_set_param(struct vnc *v, const char *name, const char *value) { if (g_strcasecmp(name, "username") == 0) { g_strncpy(v->username, value, 255); } else if (g_strcasecmp(name, "password") == 0) { g_strncpy(v->password, value, 255); } else if (g_strcasecmp(name, "ip") == 0) { g_strncpy(v->ip, value, 255); } else if (g_strcasecmp(name, "port") == 0) { g_strncpy(v->port, value, 255); } else if (g_strcasecmp(name, "keylayout") == 0) { v->keylayout = g_atoi(value); } else if (g_strcasecmp(name, "delay_ms") == 0) { v->delay_ms = g_atoi(value); } else if (g_strcasecmp(name, "guid") == 0) { v->got_guid = 1; g_memcpy(v->guid, value, 16); } return 0; } /******************************************************************************/ /* return error */ int lib_mod_get_wait_objs(struct vnc *v, tbus *read_objs, int *rcount, tbus *write_objs, int *wcount, int *timeout) { LLOGLN(10, ("lib_mod_get_wait_objs:")); if (v != 0) { if (v->trans != 0) { trans_get_wait_objs_rw(v->trans, read_objs, rcount, write_objs, wcount, timeout); } } return 0; } /******************************************************************************/ /* return error */ int lib_mod_check_wait_objs(struct vnc *v) { int rv; rv = 0; if (v != 0) { if (v->trans != 0) { rv = trans_check_wait_objs(v->trans); } } return rv; } /******************************************************************************/ tintptr EXPORT_CC mod_init(void) { struct vnc *v; v = (struct vnc *)g_malloc(sizeof(struct vnc), 1); /* set client functions */ v->size = sizeof(struct vnc); v->version = CURRENT_MOD_VER; v->handle = (tintptr) v; v->mod_connect = lib_mod_connect; v->mod_start = lib_mod_start; v->mod_event = lib_mod_event; v->mod_signal = lib_mod_signal; v->mod_end = lib_mod_end; v->mod_set_param = lib_mod_set_param; v->mod_get_wait_objs = lib_mod_get_wait_objs; v->mod_check_wait_objs = lib_mod_check_wait_objs; return (tintptr) v; } /******************************************************************************/ int EXPORT_CC mod_exit(tintptr handle) { struct vnc *v = (struct vnc *) handle; log_message(LOG_LEVEL_DEBUG, "VNC mod_exit"); if (v == 0) { return 0; } trans_delete(v->trans); g_free(v); return 0; } xrdp-0.9.5/xup/xup.h000644 001751 001751 00000017133 13133557325 014237 0ustar00metameta000000 000000 /** * xrdp: A Remote Desktop Protocol server. * * Copyright (C) Jay Sorg 2004-2015 * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. * * libxup main header file */ /* include other h files */ #include "arch.h" #include "parse.h" #include "os_calls.h" #include "defines.h" #include "xrdp_client_info.h" #include "xrdp_rail.h" #define CURRENT_MOD_VER 3 struct mod { int size; /* size of this struct */ int version; /* internal version */ /* client functions */ int (*mod_start)(struct mod* v, int w, int h, int bpp); int (*mod_connect)(struct mod* v); int (*mod_event)(struct mod* v, int msg, tbus param1, tbus param2, tbus param3, tbus param4); int (*mod_signal)(struct mod* v); int (*mod_end)(struct mod* v); int (*mod_set_param)(struct mod *v, const char *name, const char *value); int (*mod_session_change)(struct mod* v, int, int); int (*mod_get_wait_objs)(struct mod* v, tbus* read_objs, int* rcount, tbus* write_objs, int* wcount, int* timeout); int (*mod_check_wait_objs)(struct mod* v); int (*mod_frame_ack)(struct mod* v, int flags, int frame_id); tintptr mod_dumby[100 - 10]; /* align, 100 minus the number of mod functions above */ /* server functions */ int (*server_begin_update)(struct mod* v); int (*server_end_update)(struct mod* v); int (*server_fill_rect)(struct mod* v, int x, int y, int cx, int cy); int (*server_screen_blt)(struct mod* v, int x, int y, int cx, int cy, int srcx, int srcy); int (*server_paint_rect)(struct mod* v, int x, int y, int cx, int cy, char* data, int width, int height, int srcx, int srcy); int (*server_set_cursor)(struct mod* v, int x, int y, char* data, char* mask); int (*server_palette)(struct mod* v, int* palette); int (*server_msg)(struct mod* v, const char *msg, int code); int (*server_is_term)(struct mod* v); int (*server_set_clip)(struct mod* v, int x, int y, int cx, int cy); int (*server_reset_clip)(struct mod* v); int (*server_set_fgcolor)(struct mod* v, int fgcolor); int (*server_set_bgcolor)(struct mod* v, int bgcolor); int (*server_set_opcode)(struct mod* v, int opcode); int (*server_set_mixmode)(struct mod* v, int mixmode); int (*server_set_brush)(struct mod* v, int x_origin, int y_origin, int style, char* pattern); int (*server_set_pen)(struct mod* v, int style, int width); int (*server_draw_line)(struct mod* v, int x1, int y1, int x2, int y2); int (*server_add_char)(struct mod* v, int font, int character, int offset, int baseline, int width, int height, char* data); int (*server_draw_text)(struct mod* v, int font, int flags, int mixmode, int clip_left, int clip_top, int clip_right, int clip_bottom, int box_left, int box_top, int box_right, int box_bottom, int x, int y, char* data, int data_len); int (*server_reset)(struct mod* v, int width, int height, int bpp); int (*server_query_channel)(struct mod* v, int index, char* channel_name, int* channel_flags); int (*server_get_channel_id)(struct mod* v, const char *name); int (*server_send_to_channel)(struct mod* v, int channel_id, char* data, int data_len, int total_data_len, int flags); int (*server_bell_trigger)(struct mod* v); /* off screen bitmaps */ int (*server_create_os_surface)(struct mod* v, int rdpindex, int width, int height); int (*server_switch_os_surface)(struct mod* v, int rdpindex); int (*server_delete_os_surface)(struct mod* v, int rdpindex); int (*server_paint_rect_os)(struct mod* v, int x, int y, int cx, int cy, int rdpindex, int srcx, int srcy); int (*server_set_hints)(struct mod* v, int hints, int mask); /* rail */ int (*server_window_new_update)(struct mod* v, int window_id, struct rail_window_state_order* window_state, int flags); int (*server_window_delete)(struct mod* v, int window_id); int (*server_window_icon)(struct mod* v, int window_id, int cache_entry, int cache_id, struct rail_icon_info* icon_info, int flags); int (*server_window_cached_icon)(struct mod* v, int window_id, int cache_entry, int cache_id, int flags); int (*server_notify_new_update)(struct mod* v, int window_id, int notify_id, struct rail_notify_state_order* notify_state, int flags); int (*server_notify_delete)(struct mod* v, int window_id, int notify_id); int (*server_monitored_desktop)(struct mod* v, struct rail_monitored_desktop_order* mdo, int flags); int (*server_set_cursor_ex)(struct mod* v, int x, int y, char* data, char* mask, int bpp); int (*server_add_char_alpha)(struct mod* v, int font, int character, int offset, int baseline, int width, int height, char* data); int (*server_create_os_surface_bpp)(struct mod* v, int rdpindex, int width, int height, int bpp); int (*server_paint_rect_bpp)(struct mod* v, int x, int y, int cx, int cy, char* data, int width, int height, int srcx, int srcy, int bpp); int (*server_composite)(struct mod* v, int srcidx, int srcformat, int srcwidth, int srcrepeat, int* srctransform, int mskflags, int mskidx, int mskformat, int mskwidth, int mskrepeat, int op, int srcx, int srcy, int mskx, int msky, int dstx, int dsty, int width, int height, int dstformat); int (*server_paint_rects)(struct mod* v, int num_drects, short *drects, int num_crects, short *crects, char *data, int width, int height, int flags, int frame_id); tintptr server_dumby[100 - 43]; /* align, 100 minus the number of server functions above */ /* common */ tintptr handle; /* pointer to self as long */ tintptr wm; tintptr painter; tintptr si; /* mod data */ int width; int height; int bpp; int sck_closed; char username[256]; char password[256]; char ip[256]; char port[256]; int shift_state; struct xrdp_client_info client_info; int screen_shmem_id; int screen_shmem_id_mapped; /* boolean */ char *screen_shmem_pixels; struct trans *trans; }; xrdp-0.9.5/xup/Makefile.am000644 001751 001751 00000000665 13133557325 015310 0ustar00metameta000000 000000 AM_CPPFLAGS = \ -DXRDP_CFG_PATH=\"${sysconfdir}/xrdp\" \ -DXRDP_SBIN_PATH=\"${sbindir}\" \ -DXRDP_SHARE_PATH=\"${datadir}/xrdp\" \ -DXRDP_PID_PATH=\"${localstatedir}/run\" \ -I$(top_srcdir)/common if XRDP_DEBUG AM_CPPFLAGS += -DXRDP_DEBUG endif module_LTLIBRARIES = \ libxup.la libxup_la_SOURCES = \ xup.c \ xup.h libxup_la_LIBADD = \ $(top_builddir)/common/libcommon.la libxup_la_LDFLAGS = -avoid-version -module xrdp-0.9.5/xup/Makefile.in000644 001751 001751 00000052073 13220730775 015320 0ustar00metameta000000 000000 # Makefile.in generated by automake 1.15.1 from Makefile.am. # @configure_input@ # Copyright (C) 1994-2017 Free Software Foundation, Inc. # This Makefile.in is free software; the Free Software Foundation # gives unlimited permission to copy and/or distribute it, # with or without modifications, as long as this notice is preserved. # This program is distributed in the hope that it will be useful, # but WITHOUT ANY WARRANTY, to the extent permitted by law; without # even the implied warranty of MERCHANTABILITY or FITNESS FOR A # PARTICULAR PURPOSE. @SET_MAKE@ VPATH = @srcdir@ am__is_gnu_make = { \ if test -z '$(MAKELEVEL)'; then \ false; \ elif test -n '$(MAKE_HOST)'; then \ true; \ elif test -n '$(MAKE_VERSION)' && test -n '$(CURDIR)'; then \ true; \ else \ false; \ fi; \ } am__make_running_with_option = \ case $${target_option-} in \ ?) ;; \ *) echo "am__make_running_with_option: internal error: invalid" \ "target option '$${target_option-}' specified" >&2; \ exit 1;; \ esac; \ has_opt=no; \ sane_makeflags=$$MAKEFLAGS; \ if $(am__is_gnu_make); then \ sane_makeflags=$$MFLAGS; \ else \ case $$MAKEFLAGS in \ *\\[\ \ ]*) \ bs=\\; \ sane_makeflags=`printf '%s\n' "$$MAKEFLAGS" \ | sed "s/$$bs$$bs[$$bs $$bs ]*//g"`;; \ esac; \ fi; \ skip_next=no; \ strip_trailopt () \ { \ flg=`printf '%s\n' "$$flg" | sed "s/$$1.*$$//"`; \ }; \ for flg in $$sane_makeflags; do \ test $$skip_next = yes && { skip_next=no; continue; }; \ case $$flg in \ *=*|--*) continue;; \ -*I) strip_trailopt 'I'; skip_next=yes;; \ -*I?*) strip_trailopt 'I';; \ -*O) strip_trailopt 'O'; skip_next=yes;; \ -*O?*) strip_trailopt 'O';; \ -*l) strip_trailopt 'l'; skip_next=yes;; \ -*l?*) strip_trailopt 'l';; \ -[dEDm]) skip_next=yes;; \ -[JT]) skip_next=yes;; \ esac; \ case $$flg in \ *$$target_option*) has_opt=yes; break;; \ esac; \ done; \ test $$has_opt = yes am__make_dryrun = (target_option=n; $(am__make_running_with_option)) am__make_keepgoing = (target_option=k; $(am__make_running_with_option)) pkgdatadir = $(datadir)/@PACKAGE@ pkgincludedir = $(includedir)/@PACKAGE@ pkglibdir = $(libdir)/@PACKAGE@ pkglibexecdir = $(libexecdir)/@PACKAGE@ am__cd = CDPATH="$${ZSH_VERSION+.}$(PATH_SEPARATOR)" && cd install_sh_DATA = $(install_sh) -c -m 644 install_sh_PROGRAM = $(install_sh) -c install_sh_SCRIPT = $(install_sh) -c INSTALL_HEADER = $(INSTALL_DATA) transform = $(program_transform_name) NORMAL_INSTALL = : PRE_INSTALL = : POST_INSTALL = : NORMAL_UNINSTALL = : PRE_UNINSTALL = : POST_UNINSTALL = : build_triplet = @build@ host_triplet = @host@ @XRDP_DEBUG_TRUE@am__append_1 = -DXRDP_DEBUG subdir = xup ACLOCAL_M4 = $(top_srcdir)/aclocal.m4 am__aclocal_m4_deps = $(top_srcdir)/m4/ax_append_compile_flags.m4 \ $(top_srcdir)/m4/ax_append_flag.m4 \ $(top_srcdir)/m4/ax_cflags_warn_all.m4 \ $(top_srcdir)/m4/ax_check_compile_flag.m4 \ $(top_srcdir)/m4/ax_gcc_func_attribute.m4 \ $(top_srcdir)/m4/ax_require_defined.m4 \ $(top_srcdir)/m4/ax_type_socklen_t.m4 \ $(top_srcdir)/m4/libtool.m4 $(top_srcdir)/m4/ltoptions.m4 \ $(top_srcdir)/m4/ltsugar.m4 $(top_srcdir)/m4/ltversion.m4 \ $(top_srcdir)/m4/lt~obsolete.m4 $(top_srcdir)/m4/pkg.m4 \ $(top_srcdir)/configure.ac am__configure_deps = $(am__aclocal_m4_deps) $(CONFIGURE_DEPENDENCIES) \ $(ACLOCAL_M4) DIST_COMMON = $(srcdir)/Makefile.am $(am__DIST_COMMON) mkinstalldirs = $(install_sh) -d CONFIG_HEADER = $(top_builddir)/config_ac.h CONFIG_CLEAN_FILES = CONFIG_CLEAN_VPATH_FILES = am__vpath_adj_setup = srcdirstrip=`echo "$(srcdir)" | sed 's|.|.|g'`; am__vpath_adj = case $$p in \ $(srcdir)/*) f=`echo "$$p" | sed "s|^$$srcdirstrip/||"`;; \ *) f=$$p;; \ esac; am__strip_dir = f=`echo $$p | sed -e 's|^.*/||'`; am__install_max = 40 am__nobase_strip_setup = \ srcdirstrip=`echo "$(srcdir)" | sed 's/[].[^$$\\*|]/\\\\&/g'` am__nobase_strip = \ for p in $$list; do echo "$$p"; done | sed -e "s|$$srcdirstrip/||" am__nobase_list = $(am__nobase_strip_setup); \ for p in $$list; do echo "$$p $$p"; done | \ sed "s| $$srcdirstrip/| |;"' / .*\//!s/ .*/ ./; s,\( .*\)/[^/]*$$,\1,' | \ $(AWK) 'BEGIN { files["."] = "" } { files[$$2] = files[$$2] " " $$1; \ if (++n[$$2] == $(am__install_max)) \ { print $$2, files[$$2]; n[$$2] = 0; files[$$2] = "" } } \ END { for (dir in files) print dir, files[dir] }' am__base_list = \ sed '$$!N;$$!N;$$!N;$$!N;$$!N;$$!N;$$!N;s/\n/ /g' | \ sed '$$!N;$$!N;$$!N;$$!N;s/\n/ /g' am__uninstall_files_from_dir = { \ test -z "$$files" \ || { test ! -d "$$dir" && test ! -f "$$dir" && test ! -r "$$dir"; } \ || { echo " ( cd '$$dir' && rm -f" $$files ")"; \ $(am__cd) "$$dir" && rm -f $$files; }; \ } am__installdirs = "$(DESTDIR)$(moduledir)" LTLIBRARIES = $(module_LTLIBRARIES) libxup_la_DEPENDENCIES = $(top_builddir)/common/libcommon.la am_libxup_la_OBJECTS = xup.lo libxup_la_OBJECTS = $(am_libxup_la_OBJECTS) AM_V_lt = $(am__v_lt_@AM_V@) am__v_lt_ = $(am__v_lt_@AM_DEFAULT_V@) am__v_lt_0 = --silent am__v_lt_1 = libxup_la_LINK = $(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) \ $(LIBTOOLFLAGS) --mode=link $(CCLD) $(AM_CFLAGS) $(CFLAGS) \ $(libxup_la_LDFLAGS) $(LDFLAGS) -o $@ AM_V_P = $(am__v_P_@AM_V@) am__v_P_ = $(am__v_P_@AM_DEFAULT_V@) am__v_P_0 = false am__v_P_1 = : AM_V_GEN = $(am__v_GEN_@AM_V@) am__v_GEN_ = $(am__v_GEN_@AM_DEFAULT_V@) am__v_GEN_0 = @echo " GEN " $@; am__v_GEN_1 = AM_V_at = $(am__v_at_@AM_V@) am__v_at_ = $(am__v_at_@AM_DEFAULT_V@) am__v_at_0 = @ am__v_at_1 = DEFAULT_INCLUDES = -I.@am__isrc@ -I$(top_builddir) depcomp = $(SHELL) $(top_srcdir)/depcomp am__depfiles_maybe = depfiles am__mv = mv -f COMPILE = $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) \ $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) LTCOMPILE = $(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) \ $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) \ $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) \ $(AM_CFLAGS) $(CFLAGS) AM_V_CC = $(am__v_CC_@AM_V@) am__v_CC_ = $(am__v_CC_@AM_DEFAULT_V@) am__v_CC_0 = @echo " CC " $@; am__v_CC_1 = CCLD = $(CC) LINK = $(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) \ $(LIBTOOLFLAGS) --mode=link $(CCLD) $(AM_CFLAGS) $(CFLAGS) \ $(AM_LDFLAGS) $(LDFLAGS) -o $@ AM_V_CCLD = $(am__v_CCLD_@AM_V@) am__v_CCLD_ = $(am__v_CCLD_@AM_DEFAULT_V@) am__v_CCLD_0 = @echo " CCLD " $@; am__v_CCLD_1 = SOURCES = $(libxup_la_SOURCES) DIST_SOURCES = $(libxup_la_SOURCES) am__can_run_installinfo = \ case $$AM_UPDATE_INFO_DIR in \ n|no|NO) false;; \ *) (install-info --version) >/dev/null 2>&1;; \ esac am__tagged_files = $(HEADERS) $(SOURCES) $(TAGS_FILES) $(LISP) # Read a list of newline-separated strings from the standard input, # and print each of them once, without duplicates. Input order is # *not* preserved. am__uniquify_input = $(AWK) '\ BEGIN { nonempty = 0; } \ { items[$$0] = 1; nonempty = 1; } \ END { if (nonempty) { for (i in items) print i; }; } \ ' # Make sure the list of sources is unique. This is necessary because, # e.g., the same source file might be shared among _SOURCES variables # for different programs/libraries. am__define_uniq_tagged_files = \ list='$(am__tagged_files)'; \ unique=`for i in $$list; do \ if test -f "$$i"; then echo $$i; else echo $(srcdir)/$$i; fi; \ done | $(am__uniquify_input)` ETAGS = etags CTAGS = ctags am__DIST_COMMON = $(srcdir)/Makefile.in $(top_srcdir)/depcomp DISTFILES = $(DIST_COMMON) $(DIST_SOURCES) $(TEXINFOS) $(EXTRA_DIST) ACLOCAL = @ACLOCAL@ AMTAR = @AMTAR@ AM_DEFAULT_VERBOSITY = @AM_DEFAULT_VERBOSITY@ AR = @AR@ AUTOCONF = @AUTOCONF@ AUTOHEADER = @AUTOHEADER@ AUTOMAKE = @AUTOMAKE@ AWK = @AWK@ CC = @CC@ CCDEPMODE = @CCDEPMODE@ CFLAGS = @CFLAGS@ CPP = @CPP@ CPPFLAGS = @CPPFLAGS@ CYGPATH_W = @CYGPATH_W@ DEFS = @DEFS@ DEPDIR = @DEPDIR@ DLLTOOL = @DLLTOOL@ DLOPEN_LIBS = @DLOPEN_LIBS@ DSYMUTIL = @DSYMUTIL@ DUMPBIN = @DUMPBIN@ ECHO_C = @ECHO_C@ ECHO_N = @ECHO_N@ ECHO_T = @ECHO_T@ EGREP = @EGREP@ EXEEXT = @EXEEXT@ FDKAAC_CFLAGS = @FDKAAC_CFLAGS@ FDKAAC_LIBS = @FDKAAC_LIBS@ FGREP = @FGREP@ FREERDP_CFLAGS = @FREERDP_CFLAGS@ FREERDP_LIBS = @FREERDP_LIBS@ FUSE_CFLAGS = @FUSE_CFLAGS@ FUSE_LIBS = @FUSE_LIBS@ GREP = @GREP@ INSTALL = @INSTALL@ INSTALL_DATA = @INSTALL_DATA@ INSTALL_PROGRAM = @INSTALL_PROGRAM@ INSTALL_SCRIPT = @INSTALL_SCRIPT@ INSTALL_STRIP_PROGRAM = @INSTALL_STRIP_PROGRAM@ LD = @LD@ LDFLAGS = @LDFLAGS@ LIBOBJS = @LIBOBJS@ LIBS = @LIBS@ LIBTOOL = @LIBTOOL@ LIPO = @LIPO@ LN_S = @LN_S@ LTLIBOBJS = @LTLIBOBJS@ LT_SYS_LIBRARY_PATH = @LT_SYS_LIBRARY_PATH@ MAKEINFO = @MAKEINFO@ MANIFEST_TOOL = @MANIFEST_TOOL@ MKDIR_P = @MKDIR_P@ NM = @NM@ NMEDIT = @NMEDIT@ OBJDUMP = @OBJDUMP@ OBJEXT = @OBJEXT@ OPENSSL = @OPENSSL@ OPENSSL_CFLAGS = @OPENSSL_CFLAGS@ OPENSSL_LIBS = @OPENSSL_LIBS@ OTOOL = @OTOOL@ OTOOL64 = @OTOOL64@ PACKAGE = @PACKAGE@ PACKAGE_BUGREPORT = @PACKAGE_BUGREPORT@ PACKAGE_NAME = @PACKAGE_NAME@ PACKAGE_STRING = @PACKAGE_STRING@ PACKAGE_TARNAME = @PACKAGE_TARNAME@ PACKAGE_URL = @PACKAGE_URL@ PACKAGE_VERSION = @PACKAGE_VERSION@ PAM_RULES = @PAM_RULES@ PATH_SEPARATOR = @PATH_SEPARATOR@ PIXMAN_CFLAGS = @PIXMAN_CFLAGS@ PIXMAN_LIBS = @PIXMAN_LIBS@ PKG_CONFIG = @PKG_CONFIG@ PKG_CONFIG_LIBDIR = @PKG_CONFIG_LIBDIR@ PKG_CONFIG_PATH = @PKG_CONFIG_PATH@ RANLIB = @RANLIB@ SED = @SED@ SET_MAKE = @SET_MAKE@ SHELL = @SHELL@ STRIP = @STRIP@ TurboJpegIncDir = @TurboJpegIncDir@ TurboJpegLibDir = @TurboJpegLibDir@ VERSION = @VERSION@ XMKMF = @XMKMF@ X_CFLAGS = @X_CFLAGS@ X_EXTRA_LIBS = @X_EXTRA_LIBS@ X_LIBS = @X_LIBS@ X_PRE_LIBS = @X_PRE_LIBS@ abs_builddir = @abs_builddir@ abs_srcdir = @abs_srcdir@ abs_top_builddir = @abs_top_builddir@ abs_top_srcdir = @abs_top_srcdir@ ac_ct_AR = @ac_ct_AR@ ac_ct_CC = @ac_ct_CC@ ac_ct_DUMPBIN = @ac_ct_DUMPBIN@ am__include = @am__include@ am__leading_dot = @am__leading_dot@ am__quote = @am__quote@ am__tar = @am__tar@ am__untar = @am__untar@ bindir = @bindir@ build = @build@ build_alias = @build_alias@ build_cpu = @build_cpu@ build_os = @build_os@ build_vendor = @build_vendor@ builddir = @builddir@ datadir = @datadir@ datarootdir = @datarootdir@ docdir = @docdir@ dvidir = @dvidir@ exec_prefix = @exec_prefix@ host = @host@ host_alias = @host_alias@ host_cpu = @host_cpu@ host_os = @host_os@ host_vendor = @host_vendor@ htmldir = @htmldir@ includedir = @includedir@ infodir = @infodir@ install_sh = @install_sh@ libdir = @libdir@ libexecdir = @libexecdir@ localedir = @localedir@ localstatedir = @localstatedir@ mandir = @mandir@ mkdir_p = @mkdir_p@ moduledir = @moduledir@ oldincludedir = @oldincludedir@ pdfdir = @pdfdir@ pkgconfigdir = @pkgconfigdir@ prefix = @prefix@ program_transform_name = @program_transform_name@ psdir = @psdir@ sbindir = @sbindir@ sharedstatedir = @sharedstatedir@ socketdir = @socketdir@ srcdir = @srcdir@ subdirs = @subdirs@ sysconfdir = @sysconfdir@ systemdsystemunitdir = @systemdsystemunitdir@ target_alias = @target_alias@ top_build_prefix = @top_build_prefix@ top_builddir = @top_builddir@ top_srcdir = @top_srcdir@ AM_CPPFLAGS = -DXRDP_CFG_PATH=\"${sysconfdir}/xrdp\" \ -DXRDP_SBIN_PATH=\"${sbindir}\" \ -DXRDP_SHARE_PATH=\"${datadir}/xrdp\" \ -DXRDP_PID_PATH=\"${localstatedir}/run\" \ -I$(top_srcdir)/common $(am__append_1) module_LTLIBRARIES = \ libxup.la libxup_la_SOURCES = \ xup.c \ xup.h libxup_la_LIBADD = \ $(top_builddir)/common/libcommon.la libxup_la_LDFLAGS = -avoid-version -module all: all-am .SUFFIXES: .SUFFIXES: .c .lo .o .obj $(srcdir)/Makefile.in: $(srcdir)/Makefile.am $(am__configure_deps) @for dep in $?; do \ case '$(am__configure_deps)' in \ *$$dep*) \ ( cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh ) \ && { if test -f $@; then exit 0; else break; fi; }; \ exit 1;; \ esac; \ done; \ echo ' cd $(top_srcdir) && $(AUTOMAKE) --foreign xup/Makefile'; \ $(am__cd) $(top_srcdir) && \ $(AUTOMAKE) --foreign xup/Makefile Makefile: $(srcdir)/Makefile.in $(top_builddir)/config.status @case '$?' in \ *config.status*) \ cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh;; \ *) \ echo ' cd $(top_builddir) && $(SHELL) ./config.status $(subdir)/$@ $(am__depfiles_maybe)'; \ cd $(top_builddir) && $(SHELL) ./config.status $(subdir)/$@ $(am__depfiles_maybe);; \ esac; $(top_builddir)/config.status: $(top_srcdir)/configure $(CONFIG_STATUS_DEPENDENCIES) cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh $(top_srcdir)/configure: $(am__configure_deps) cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh $(ACLOCAL_M4): $(am__aclocal_m4_deps) cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh $(am__aclocal_m4_deps): install-moduleLTLIBRARIES: $(module_LTLIBRARIES) @$(NORMAL_INSTALL) @list='$(module_LTLIBRARIES)'; test -n "$(moduledir)" || list=; \ list2=; for p in $$list; do \ if test -f $$p; then \ list2="$$list2 $$p"; \ else :; fi; \ done; \ test -z "$$list2" || { \ echo " $(MKDIR_P) '$(DESTDIR)$(moduledir)'"; \ $(MKDIR_P) "$(DESTDIR)$(moduledir)" || exit 1; \ echo " $(LIBTOOL) $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=install $(INSTALL) $(INSTALL_STRIP_FLAG) $$list2 '$(DESTDIR)$(moduledir)'"; \ $(LIBTOOL) $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=install $(INSTALL) $(INSTALL_STRIP_FLAG) $$list2 "$(DESTDIR)$(moduledir)"; \ } uninstall-moduleLTLIBRARIES: @$(NORMAL_UNINSTALL) @list='$(module_LTLIBRARIES)'; test -n "$(moduledir)" || list=; \ for p in $$list; do \ $(am__strip_dir) \ echo " $(LIBTOOL) $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=uninstall rm -f '$(DESTDIR)$(moduledir)/$$f'"; \ $(LIBTOOL) $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=uninstall rm -f "$(DESTDIR)$(moduledir)/$$f"; \ done clean-moduleLTLIBRARIES: -test -z "$(module_LTLIBRARIES)" || rm -f $(module_LTLIBRARIES) @list='$(module_LTLIBRARIES)'; \ locs=`for p in $$list; do echo $$p; done | \ sed 's|^[^/]*$$|.|; s|/[^/]*$$||; s|$$|/so_locations|' | \ sort -u`; \ test -z "$$locs" || { \ echo rm -f $${locs}; \ rm -f $${locs}; \ } libxup.la: $(libxup_la_OBJECTS) $(libxup_la_DEPENDENCIES) $(EXTRA_libxup_la_DEPENDENCIES) $(AM_V_CCLD)$(libxup_la_LINK) -rpath $(moduledir) $(libxup_la_OBJECTS) $(libxup_la_LIBADD) $(LIBS) mostlyclean-compile: -rm -f *.$(OBJEXT) distclean-compile: -rm -f *.tab.c @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/xup.Plo@am__quote@ .c.o: @am__fastdepCC_TRUE@ $(AM_V_CC)$(COMPILE) -MT $@ -MD -MP -MF $(DEPDIR)/$*.Tpo -c -o $@ $< @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) $(DEPDIR)/$*.Tpo $(DEPDIR)/$*.Po @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='$<' object='$@' libtool=no @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(COMPILE) -c -o $@ $< .c.obj: @am__fastdepCC_TRUE@ $(AM_V_CC)$(COMPILE) -MT $@ -MD -MP -MF $(DEPDIR)/$*.Tpo -c -o $@ `$(CYGPATH_W) '$<'` @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) $(DEPDIR)/$*.Tpo $(DEPDIR)/$*.Po @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='$<' object='$@' libtool=no @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(COMPILE) -c -o $@ `$(CYGPATH_W) '$<'` .c.lo: @am__fastdepCC_TRUE@ $(AM_V_CC)$(LTCOMPILE) -MT $@ -MD -MP -MF $(DEPDIR)/$*.Tpo -c -o $@ $< @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) $(DEPDIR)/$*.Tpo $(DEPDIR)/$*.Plo @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='$<' object='$@' libtool=yes @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(LTCOMPILE) -c -o $@ $< mostlyclean-libtool: -rm -f *.lo clean-libtool: -rm -rf .libs _libs ID: $(am__tagged_files) $(am__define_uniq_tagged_files); mkid -fID $$unique tags: tags-am TAGS: tags tags-am: $(TAGS_DEPENDENCIES) $(am__tagged_files) set x; \ here=`pwd`; \ $(am__define_uniq_tagged_files); \ shift; \ if test -z "$(ETAGS_ARGS)$$*$$unique"; then :; else \ test -n "$$unique" || unique=$$empty_fix; \ if test $$# -gt 0; then \ $(ETAGS) $(ETAGSFLAGS) $(AM_ETAGSFLAGS) $(ETAGS_ARGS) \ "$$@" $$unique; \ else \ $(ETAGS) $(ETAGSFLAGS) $(AM_ETAGSFLAGS) $(ETAGS_ARGS) \ $$unique; \ fi; \ fi ctags: ctags-am CTAGS: ctags ctags-am: $(TAGS_DEPENDENCIES) $(am__tagged_files) $(am__define_uniq_tagged_files); \ test -z "$(CTAGS_ARGS)$$unique" \ || $(CTAGS) $(CTAGSFLAGS) $(AM_CTAGSFLAGS) $(CTAGS_ARGS) \ $$unique GTAGS: here=`$(am__cd) $(top_builddir) && pwd` \ && $(am__cd) $(top_srcdir) \ && gtags -i $(GTAGS_ARGS) "$$here" cscopelist: cscopelist-am cscopelist-am: $(am__tagged_files) list='$(am__tagged_files)'; \ case "$(srcdir)" in \ [\\/]* | ?:[\\/]*) sdir="$(srcdir)" ;; \ *) sdir=$(subdir)/$(srcdir) ;; \ esac; \ for i in $$list; do \ if test -f "$$i"; then \ echo "$(subdir)/$$i"; \ else \ echo "$$sdir/$$i"; \ fi; \ done >> $(top_builddir)/cscope.files distclean-tags: -rm -f TAGS ID GTAGS GRTAGS GSYMS GPATH tags distdir: $(DISTFILES) @srcdirstrip=`echo "$(srcdir)" | sed 's/[].[^$$\\*]/\\\\&/g'`; \ topsrcdirstrip=`echo "$(top_srcdir)" | sed 's/[].[^$$\\*]/\\\\&/g'`; \ list='$(DISTFILES)'; \ dist_files=`for file in $$list; do echo $$file; done | \ sed -e "s|^$$srcdirstrip/||;t" \ -e "s|^$$topsrcdirstrip/|$(top_builddir)/|;t"`; \ case $$dist_files in \ */*) $(MKDIR_P) `echo "$$dist_files" | \ sed '/\//!d;s|^|$(distdir)/|;s,/[^/]*$$,,' | \ sort -u` ;; \ esac; \ for file in $$dist_files; do \ if test -f $$file || test -d $$file; then d=.; else d=$(srcdir); fi; \ if test -d $$d/$$file; then \ dir=`echo "/$$file" | sed -e 's,/[^/]*$$,,'`; \ if test -d "$(distdir)/$$file"; then \ find "$(distdir)/$$file" -type d ! -perm -700 -exec chmod u+rwx {} \;; \ fi; \ if test -d $(srcdir)/$$file && test $$d != $(srcdir); then \ cp -fpR $(srcdir)/$$file "$(distdir)$$dir" || exit 1; \ find "$(distdir)/$$file" -type d ! -perm -700 -exec chmod u+rwx {} \;; \ fi; \ cp -fpR $$d/$$file "$(distdir)$$dir" || exit 1; \ else \ test -f "$(distdir)/$$file" \ || cp -p $$d/$$file "$(distdir)/$$file" \ || exit 1; \ fi; \ done check-am: all-am check: check-am all-am: Makefile $(LTLIBRARIES) installdirs: for dir in "$(DESTDIR)$(moduledir)"; do \ test -z "$$dir" || $(MKDIR_P) "$$dir"; \ done install: install-am install-exec: install-exec-am install-data: install-data-am uninstall: uninstall-am install-am: all-am @$(MAKE) $(AM_MAKEFLAGS) install-exec-am install-data-am installcheck: installcheck-am install-strip: if test -z '$(STRIP)'; then \ $(MAKE) $(AM_MAKEFLAGS) INSTALL_PROGRAM="$(INSTALL_STRIP_PROGRAM)" \ install_sh_PROGRAM="$(INSTALL_STRIP_PROGRAM)" INSTALL_STRIP_FLAG=-s \ install; \ else \ $(MAKE) $(AM_MAKEFLAGS) INSTALL_PROGRAM="$(INSTALL_STRIP_PROGRAM)" \ install_sh_PROGRAM="$(INSTALL_STRIP_PROGRAM)" INSTALL_STRIP_FLAG=-s \ "INSTALL_PROGRAM_ENV=STRIPPROG='$(STRIP)'" install; \ fi mostlyclean-generic: clean-generic: distclean-generic: -test -z "$(CONFIG_CLEAN_FILES)" || rm -f $(CONFIG_CLEAN_FILES) -test . = "$(srcdir)" || test -z "$(CONFIG_CLEAN_VPATH_FILES)" || rm -f $(CONFIG_CLEAN_VPATH_FILES) maintainer-clean-generic: @echo "This command is intended for maintainers to use" @echo "it deletes files that may require special tools to rebuild." clean: clean-am clean-am: clean-generic clean-libtool clean-moduleLTLIBRARIES \ mostlyclean-am distclean: distclean-am -rm -rf ./$(DEPDIR) -rm -f Makefile distclean-am: clean-am distclean-compile distclean-generic \ distclean-tags dvi: dvi-am dvi-am: html: html-am html-am: info: info-am info-am: install-data-am: install-moduleLTLIBRARIES install-dvi: install-dvi-am install-dvi-am: install-exec-am: install-html: install-html-am install-html-am: install-info: install-info-am install-info-am: install-man: install-pdf: install-pdf-am install-pdf-am: install-ps: install-ps-am install-ps-am: installcheck-am: maintainer-clean: maintainer-clean-am -rm -rf ./$(DEPDIR) -rm -f Makefile maintainer-clean-am: distclean-am maintainer-clean-generic mostlyclean: mostlyclean-am mostlyclean-am: mostlyclean-compile mostlyclean-generic \ mostlyclean-libtool pdf: pdf-am pdf-am: ps: ps-am ps-am: uninstall-am: uninstall-moduleLTLIBRARIES .MAKE: install-am install-strip .PHONY: CTAGS GTAGS TAGS all all-am check check-am clean clean-generic \ clean-libtool clean-moduleLTLIBRARIES cscopelist-am ctags \ ctags-am distclean distclean-compile distclean-generic \ distclean-libtool distclean-tags distdir dvi dvi-am html \ html-am info info-am install install-am install-data \ install-data-am install-dvi install-dvi-am install-exec \ install-exec-am install-html install-html-am install-info \ install-info-am install-man install-moduleLTLIBRARIES \ install-pdf install-pdf-am install-ps install-ps-am \ install-strip installcheck installcheck-am installdirs \ maintainer-clean maintainer-clean-generic mostlyclean \ mostlyclean-compile mostlyclean-generic mostlyclean-libtool \ pdf pdf-am ps ps-am tags tags-am uninstall uninstall-am \ uninstall-moduleLTLIBRARIES .PRECIOUS: Makefile # Tell versions [3.59,3.63) of GNU make to not export all variables. # Otherwise a system limit (for SysV at least) may be exceeded. .NOEXPORT: xrdp-0.9.5/xup/xup.c000644 001751 001751 00000121025 13201006747 014217 0ustar00metameta000000 000000 /** * xrdp: A Remote Desktop Protocol server. * * Copyright (C) Jay Sorg 2004-2015 * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. * * libxup main file */ #if defined(HAVE_CONFIG_H) #include #endif #include "xup.h" #include "log.h" #include "trans.h" #define LOG_LEVEL 1 #define LLOG(_level, _args) \ do { if (_level < LOG_LEVEL) { g_write _args ; } } while (0) #define LLOGLN(_level, _args) \ do { if (_level < LOG_LEVEL) { g_writeln _args ; } } while (0) static int lib_mod_process_message(struct mod *mod, struct stream *s); /******************************************************************************/ static int lib_send_copy(struct mod *mod, struct stream *s) { return trans_write_copy_s(mod->trans, s); } /******************************************************************************/ /* return error */ int lib_mod_start(struct mod *mod, int w, int h, int bpp) { LIB_DEBUG(mod, "in lib_mod_start"); mod->width = w; mod->height = h; mod->bpp = bpp; LIB_DEBUG(mod, "out lib_mod_start"); return 0; } /******************************************************************************/ static int lib_mod_log_peer(struct mod *mod) { int my_pid; int pid; int uid; int gid; my_pid = g_getpid(); if (g_sck_get_peer_cred(mod->trans->sck, &pid, &uid, &gid) == 0) { log_message(LOG_LEVEL_INFO, "lib_mod_log_peer: xrdp_pid=%d connected " "to X11rdp_pid=%d X11rdp_uid=%d X11rdp_gid=%d " "client_ip=%s client_port=%s", my_pid, pid, uid, gid, mod->client_info.client_addr, mod->client_info.client_port); } else { log_message(LOG_LEVEL_ERROR, "lib_mod_log_peer: g_sck_get_peer_cred " "failed"); } return 0; } /******************************************************************************/ static int lib_data_in(struct trans *trans) { struct mod *self; struct stream *s; int len; LLOGLN(10, ("lib_data_in:")); if (trans == 0) { return 1; } self = (struct mod *)(trans->callback_data); s = trans_get_in_s(trans); if (s == 0) { return 1; } switch (trans->extra_flags) { case 1: s->p = s->data; in_uint8s(s, 4); /* processed later in lib_mod_process_message */ in_uint32_le(s, len); if (len < 0 || len > 128 * 1024) { g_writeln("lib_data_in: bad size"); return 1; } if (len > 0) { trans->header_size = len + 8; trans->extra_flags = 2; break; } /* fall through */ case 2: s->p = s->data; if (lib_mod_process_message(self, s) != 0) { g_writeln("lib_data_in: lib_mod_process_message failed"); return 1; } init_stream(s, 0); trans->header_size = 8; trans->extra_flags = 1; break; } return 0; } /******************************************************************************/ /* return error */ int lib_mod_connect(struct mod *mod) { int error; int len; int i; int use_uds; struct stream *s; char con_port[256]; struct source_info *si; LIB_DEBUG(mod, "in lib_mod_connect"); mod->server_msg(mod, "started connecting", 0); /* only support 8, 15, 16, 24, and 32 bpp connections from rdp client */ if (mod->bpp != 8 && mod->bpp != 15 && mod->bpp != 16 && mod->bpp != 24 && mod->bpp != 32) { mod->server_msg(mod, "error - only supporting 8, 15, 16, 24, and 32 bpp rdp connections", 0); LIB_DEBUG(mod, "out lib_mod_connect error"); return 1; } if (g_strcmp(mod->ip, "") == 0) { mod->server_msg(mod, "error - no ip set", 0); LIB_DEBUG(mod, "out lib_mod_connect error"); return 1; } make_stream(s); g_sprintf(con_port, "%s", mod->port); use_uds = 0; if (con_port[0] == '/') { use_uds = 1; } error = 0; mod->sck_closed = 0; i = 0; if (use_uds) { mod->trans = trans_create(TRANS_MODE_UNIX, 8 * 8192, 8192); if (mod->trans == 0) { free_stream(s); return 1; } } else { mod->trans = trans_create(TRANS_MODE_TCP, 8 * 8192, 8192); if (mod->trans == 0) { free_stream(s); return 1; } } si = (struct source_info *) (mod->si); mod->trans->si = si; mod->trans->my_source = XRDP_SOURCE_MOD; while (1) { /* mod->server_msg(mod, "connecting...", 0); */ error = -1; if (trans_connect(mod->trans, mod->ip, con_port, 3000) == 0) { LLOGLN(0, ("lib_mod_connect: connected to Xserver " "(Xorg or X11rdp) sck %lld", (long long) (mod->trans->sck))); error = 0; } if (error == 0) { break; } i++; if (i >= 60) { mod->server_msg(mod, "connection problem, giving up", 0); break; } g_sleep(500); } if (error == 0) { if (use_uds) { lib_mod_log_peer(mod); } } if (error == 0) { /* send version message */ init_stream(s, 8192); s_push_layer(s, iso_hdr, 4); out_uint16_le(s, 103); out_uint32_le(s, 301); out_uint32_le(s, 0); out_uint32_le(s, 0); out_uint32_le(s, 0); out_uint32_le(s, 1); s_mark_end(s); len = (int)(s->end - s->data); s_pop_layer(s, iso_hdr); out_uint32_le(s, len); lib_send_copy(mod, s); } if (error == 0) { /* send screen size message */ init_stream(s, 8192); s_push_layer(s, iso_hdr, 4); out_uint16_le(s, 103); out_uint32_le(s, 300); out_uint32_le(s, mod->width); out_uint32_le(s, mod->height); out_uint32_le(s, mod->bpp); out_uint32_le(s, 0); s_mark_end(s); len = (int)(s->end - s->data); s_pop_layer(s, iso_hdr); out_uint32_le(s, len); lib_send_copy(mod, s); } if (error == 0) { /* send invalidate message */ init_stream(s, 8192); s_push_layer(s, iso_hdr, 4); out_uint16_le(s, 103); out_uint32_le(s, 200); /* x and y */ i = 0; out_uint32_le(s, i); /* width and height */ i = ((mod->width & 0xffff) << 16) | mod->height; out_uint32_le(s, i); out_uint32_le(s, 0); out_uint32_le(s, 0); s_mark_end(s); len = (int)(s->end - s->data); s_pop_layer(s, iso_hdr); out_uint32_le(s, len); lib_send_copy(mod, s); } free_stream(s); if (error != 0) { trans_delete(mod->trans); mod->trans = 0; mod->server_msg(mod, "some problem", 0); LIB_DEBUG(mod, "out lib_mod_connect error"); return 1; } else { mod->server_msg(mod, "connected ok", 0); mod->trans->trans_data_in = lib_data_in; mod->trans->header_size = 8; mod->trans->callback_data = mod; mod->trans->no_stream_init_on_data_in = 1; mod->trans->extra_flags = 1; } LIB_DEBUG(mod, "out lib_mod_connect"); return 0; } /******************************************************************************/ /* return error */ int lib_mod_event(struct mod *mod, int msg, tbus param1, tbus param2, tbus param3, tbus param4) { struct stream *s; int len; int key; int rv; LIB_DEBUG(mod, "in lib_mod_event"); make_stream(s); if ((msg >= 15) && (msg <= 16)) /* key events */ { key = param2; if (key > 0) { if (key == 65027) /* altgr */ { if (mod->shift_state) { g_writeln("special"); /* fix for mstsc sending left control down with altgr */ /* control down / up msg param1 param2 param3 param4 15 0 65507 29 0 16 0 65507 29 49152 */ init_stream(s, 8192); s_push_layer(s, iso_hdr, 4); out_uint16_le(s, 103); out_uint32_le(s, 16); /* key up */ out_uint32_le(s, 0); out_uint32_le(s, 65507); /* left control */ out_uint32_le(s, 29); /* RDP scan code */ out_uint32_le(s, 0xc000); /* flags */ s_mark_end(s); len = (int)(s->end - s->data); s_pop_layer(s, iso_hdr); out_uint32_le(s, len); lib_send_copy(mod, s); } } if (key == 65507) /* left control */ { mod->shift_state = msg == 15; } } } init_stream(s, 8192); s_push_layer(s, iso_hdr, 4); out_uint16_le(s, 103); out_uint32_le(s, msg); out_uint32_le(s, param1); out_uint32_le(s, param2); out_uint32_le(s, param3); out_uint32_le(s, param4); s_mark_end(s); len = (int)(s->end - s->data); s_pop_layer(s, iso_hdr); out_uint32_le(s, len); rv = lib_send_copy(mod, s); free_stream(s); LIB_DEBUG(mod, "out lib_mod_event"); return rv; } /******************************************************************************/ /* return error */ static int process_server_fill_rect(struct mod *mod, struct stream *s) { int rv; int x; int y; int cx; int cy; in_sint16_le(s, x); in_sint16_le(s, y); in_uint16_le(s, cx); in_uint16_le(s, cy); rv = mod->server_fill_rect(mod, x, y, cx, cy); return rv; } /******************************************************************************/ /* return error */ static int process_server_screen_blt(struct mod *mod, struct stream *s) { int rv; int x; int y; int cx; int cy; int srcx; int srcy; in_sint16_le(s, x); in_sint16_le(s, y); in_uint16_le(s, cx); in_uint16_le(s, cy); in_sint16_le(s, srcx); in_sint16_le(s, srcy); rv = mod->server_screen_blt(mod, x, y, cx, cy, srcx, srcy); return rv; } /******************************************************************************/ /* return error */ static int process_server_paint_rect(struct mod *mod, struct stream *s) { int rv; int x; int y; int cx; int cy; int len_bmpdata; char *bmpdata; int width; int height; int srcx; int srcy; in_sint16_le(s, x); in_sint16_le(s, y); in_uint16_le(s, cx); in_uint16_le(s, cy); in_uint32_le(s, len_bmpdata); in_uint8p(s, bmpdata, len_bmpdata); in_uint16_le(s, width); in_uint16_le(s, height); in_sint16_le(s, srcx); in_sint16_le(s, srcy); rv = mod->server_paint_rect(mod, x, y, cx, cy, bmpdata, width, height, srcx, srcy); return rv; } /******************************************************************************/ /* return error */ static int process_server_set_clip(struct mod *mod, struct stream *s) { int rv; int x; int y; int cx; int cy; in_sint16_le(s, x); in_sint16_le(s, y); in_uint16_le(s, cx); in_uint16_le(s, cy); rv = mod->server_set_clip(mod, x, y, cx, cy); return rv; } /******************************************************************************/ /* return error */ static int process_server_reset_clip(struct mod *mod, struct stream *s) { int rv; rv = mod->server_reset_clip(mod); return rv; } /******************************************************************************/ /* return error */ static int process_server_set_fgcolor(struct mod *mod, struct stream *s) { int rv; int fgcolor; in_uint32_le(s, fgcolor); rv = mod->server_set_fgcolor(mod, fgcolor); return rv; } /******************************************************************************/ /* return error */ static int process_server_set_bgcolor(struct mod *mod, struct stream *s) { int rv; int bgcolor; in_uint32_le(s, bgcolor); rv = mod->server_set_bgcolor(mod, bgcolor); return rv; } /******************************************************************************/ /* return error */ static int process_server_set_opcode(struct mod *mod, struct stream *s) { int rv; int opcode; in_uint16_le(s, opcode); rv = mod->server_set_opcode(mod, opcode); return rv; } /******************************************************************************/ /* return error */ static int process_server_set_pen(struct mod *mod, struct stream *s) { int rv; int style; int width; in_uint16_le(s, style); in_uint16_le(s, width); rv = mod->server_set_pen(mod, style, width); return rv; } /******************************************************************************/ /* return error */ static int process_server_draw_line(struct mod *mod, struct stream *s) { int rv; int x1; int y1; int x2; int y2; in_sint16_le(s, x1); in_sint16_le(s, y1); in_sint16_le(s, x2); in_sint16_le(s, y2); rv = mod->server_draw_line(mod, x1, y1, x2, y2); return rv; } /******************************************************************************/ /* return error */ static int process_server_set_cursor(struct mod *mod, struct stream *s) { int rv; int x; int y; char cur_data[32 * (32 * 3)]; char cur_mask[32 * (32 / 8)]; in_sint16_le(s, x); in_sint16_le(s, y); in_uint8a(s, cur_data, 32 * (32 * 3)); in_uint8a(s, cur_mask, 32 * (32 / 8)); rv = mod->server_set_cursor(mod, x, y, cur_data, cur_mask); return rv; } /******************************************************************************/ /* return error */ static int process_server_create_os_surface(struct mod *mod, struct stream *s) { int rv; int rdpid; int width; int height; in_uint32_le(s, rdpid); in_uint16_le(s, width); in_uint16_le(s, height); rv = mod->server_create_os_surface(mod, rdpid, width, height); return rv; } /******************************************************************************/ /* return error */ static int process_server_switch_os_surface(struct mod *mod, struct stream *s) { int rv; int rdpid; in_uint32_le(s, rdpid); rv = mod->server_switch_os_surface(mod, rdpid); return rv; } /******************************************************************************/ /* return error */ static int process_server_delete_os_surface(struct mod *mod, struct stream *s) { int rv; int rdpid; in_uint32_le(s, rdpid); rv = mod->server_delete_os_surface(mod, rdpid); return rv; } /******************************************************************************/ /* return error */ static int process_server_paint_rect_os(struct mod *mod, struct stream *s) { int rv; int x; int y; int cx; int cy; int rdpid; int srcx; int srcy; in_sint16_le(s, x); in_sint16_le(s, y); in_uint16_le(s, cx); in_uint16_le(s, cy); in_uint32_le(s, rdpid); in_sint16_le(s, srcx); in_sint16_le(s, srcy); rv = mod->server_paint_rect_os(mod, x, y, cx, cy, rdpid, srcx, srcy); return rv; } /******************************************************************************/ /* return error */ static int process_server_set_hints(struct mod *mod, struct stream *s) { int rv; int hints; int mask; in_uint32_le(s, hints); in_uint32_le(s, mask); rv = mod->server_set_hints(mod, hints, mask); return rv; } /******************************************************************************/ /* return error */ static int process_server_window_new_update(struct mod *mod, struct stream *s) { int flags; int window_id; int title_bytes; int index; int bytes; int rv; struct rail_window_state_order rwso; g_memset(&rwso, 0, sizeof(rwso)); in_uint32_le(s, window_id); in_uint32_le(s, rwso.owner_window_id); in_uint32_le(s, rwso.style); in_uint32_le(s, rwso.extended_style); in_uint32_le(s, rwso.show_state); in_uint16_le(s, title_bytes); if (title_bytes > 0) { rwso.title_info = g_new(char, title_bytes + 1); in_uint8a(s, rwso.title_info, title_bytes); rwso.title_info[title_bytes] = 0; } in_uint32_le(s, rwso.client_offset_x); in_uint32_le(s, rwso.client_offset_y); in_uint32_le(s, rwso.client_area_width); in_uint32_le(s, rwso.client_area_height); in_uint32_le(s, rwso.rp_content); in_uint32_le(s, rwso.root_parent_handle); in_uint32_le(s, rwso.window_offset_x); in_uint32_le(s, rwso.window_offset_y); in_uint32_le(s, rwso.window_client_delta_x); in_uint32_le(s, rwso.window_client_delta_y); in_uint32_le(s, rwso.window_width); in_uint32_le(s, rwso.window_height); in_uint16_le(s, rwso.num_window_rects); if (rwso.num_window_rects > 0) { bytes = sizeof(struct rail_window_rect) * rwso.num_window_rects; rwso.window_rects = (struct rail_window_rect *)g_malloc(bytes, 0); for (index = 0; index < rwso.num_window_rects; index++) { in_uint16_le(s, rwso.window_rects[index].left); in_uint16_le(s, rwso.window_rects[index].top); in_uint16_le(s, rwso.window_rects[index].right); in_uint16_le(s, rwso.window_rects[index].bottom); } } in_uint32_le(s, rwso.visible_offset_x); in_uint32_le(s, rwso.visible_offset_y); in_uint16_le(s, rwso.num_visibility_rects); if (rwso.num_visibility_rects > 0) { bytes = sizeof(struct rail_window_rect) * rwso.num_visibility_rects; rwso.visibility_rects = (struct rail_window_rect *)g_malloc(bytes, 0); for (index = 0; index < rwso.num_visibility_rects; index++) { in_uint16_le(s, rwso.visibility_rects[index].left); in_uint16_le(s, rwso.visibility_rects[index].top); in_uint16_le(s, rwso.visibility_rects[index].right); in_uint16_le(s, rwso.visibility_rects[index].bottom); } } in_uint32_le(s, flags); mod->server_window_new_update(mod, window_id, &rwso, flags); rv = 0; g_free(rwso.title_info); g_free(rwso.window_rects); g_free(rwso.visibility_rects); return rv; } /******************************************************************************/ /* return error */ static int process_server_window_delete(struct mod *mod, struct stream *s) { int window_id; int rv; in_uint32_le(s, window_id); mod->server_window_delete(mod, window_id); rv = 0; return rv; } /******************************************************************************/ /* return error */ static int process_server_window_show(struct mod* mod, struct stream* s) { int window_id; int rv; int flags; struct rail_window_state_order rwso; g_memset(&rwso, 0, sizeof(rwso)); in_uint32_le(s, window_id); in_uint32_le(s, flags); in_uint32_le(s, rwso.show_state); mod->server_window_new_update(mod, window_id, &rwso, flags); rv = 0; return rv; } /******************************************************************************/ /* return error */ static int process_server_add_char(struct mod *mod, struct stream *s) { int rv; int font; int character; int x; int y; int cx; int cy; int len_bmpdata; char *bmpdata; in_uint16_le(s, font); in_uint16_le(s, character); in_sint16_le(s, x); in_sint16_le(s, y); in_uint16_le(s, cx); in_uint16_le(s, cy); in_uint16_le(s, len_bmpdata); in_uint8p(s, bmpdata, len_bmpdata); rv = mod->server_add_char(mod, font, character, x, y, cx, cy, bmpdata); return rv; } /******************************************************************************/ /* return error */ static int process_server_add_char_alpha(struct mod *mod, struct stream *s) { int rv; int font; int character; int x; int y; int cx; int cy; int len_bmpdata; char *bmpdata; in_uint16_le(s, font); in_uint16_le(s, character); in_sint16_le(s, x); in_sint16_le(s, y); in_uint16_le(s, cx); in_uint16_le(s, cy); in_uint16_le(s, len_bmpdata); in_uint8p(s, bmpdata, len_bmpdata); rv = mod->server_add_char_alpha(mod, font, character, x, y, cx, cy, bmpdata); return rv; } /******************************************************************************/ /* return error */ static int process_server_draw_text(struct mod *mod, struct stream *s) { int rv; int font; int flags; int mixmode; int clip_left; int clip_top; int clip_right; int clip_bottom; int box_left; int box_top; int box_right; int box_bottom; int x; int y; int len_bmpdata; char *bmpdata; in_uint16_le(s, font); in_uint16_le(s, flags); in_uint16_le(s, mixmode); in_sint16_le(s, clip_left); in_sint16_le(s, clip_top); in_sint16_le(s, clip_right); in_sint16_le(s, clip_bottom); in_sint16_le(s, box_left); in_sint16_le(s, box_top); in_sint16_le(s, box_right); in_sint16_le(s, box_bottom); in_sint16_le(s, x); in_sint16_le(s, y); in_uint16_le(s, len_bmpdata); in_uint8p(s, bmpdata, len_bmpdata); rv = mod->server_draw_text(mod, font, flags, mixmode, clip_left, clip_top, clip_right, clip_bottom, box_left, box_top, box_right, box_bottom, x, y, bmpdata, len_bmpdata); return rv; } /******************************************************************************/ /* return error */ static int process_server_create_os_surface_bpp(struct mod *mod, struct stream *s) { int rv; int rdpid; int width; int height; int bpp; in_uint32_le(s, rdpid); in_uint16_le(s, width); in_uint16_le(s, height); in_uint8(s, bpp); rv = mod->server_create_os_surface_bpp(mod, rdpid, width, height, bpp); return rv; } /******************************************************************************/ /* return error */ static int process_server_paint_rect_bpp(struct mod *mod, struct stream *s) { int rv; int x; int y; int cx; int cy; int len_bmpdata; char *bmpdata; int width; int height; int srcx; int srcy; int bpp; in_sint16_le(s, x); in_sint16_le(s, y); in_uint16_le(s, cx); in_uint16_le(s, cy); in_uint32_le(s, len_bmpdata); in_uint8p(s, bmpdata, len_bmpdata); in_uint16_le(s, width); in_uint16_le(s, height); in_sint16_le(s, srcx); in_sint16_le(s, srcy); in_uint8(s, bpp); rv = mod->server_paint_rect_bpp(mod, x, y, cx, cy, bmpdata, width, height, srcx, srcy, bpp); return rv; } /******************************************************************************/ /* return error */ static int process_server_composite(struct mod *mod, struct stream *s) { int rv; int srcidx; int srcformat; int srcwidth; int srcrepeat; int transform[10]; int mskflags; int mskidx; int mskformat; int mskwidth; int mskrepeat; int op; int srcx; int srcy; int mskx; int msky; int dstx; int dsty; int width; int height; int dstformat; in_uint16_le(s, srcidx); in_uint32_le(s, srcformat); in_uint16_le(s, srcwidth); in_uint8(s, srcrepeat); g_memcpy(transform, s->p, 40); in_uint8s(s, 40); in_uint8(s, mskflags); in_uint16_le(s, mskidx); in_uint32_le(s, mskformat); in_uint16_le(s, mskwidth); in_uint8(s, mskrepeat); in_uint8(s, op); in_sint16_le(s, srcx); in_sint16_le(s, srcy); in_sint16_le(s, mskx); in_sint16_le(s, msky); in_sint16_le(s, dstx); in_sint16_le(s, dsty); in_uint16_le(s, width); in_uint16_le(s, height); in_uint32_le(s, dstformat); rv = mod->server_composite(mod, srcidx, srcformat, srcwidth, srcrepeat, transform, mskflags, mskidx, mskformat, mskwidth, mskrepeat, op, srcx, srcy, mskx, msky, dstx, dsty, width, height, dstformat); return rv; } /******************************************************************************/ /* return error */ static int process_server_set_pointer_ex(struct mod *mod, struct stream *s) { int rv; int x; int y; int bpp; int Bpp; char cur_data[32 * (32 * 4)]; char cur_mask[32 * (32 / 8)]; in_sint16_le(s, x); in_sint16_le(s, y); in_uint16_le(s, bpp); Bpp = (bpp == 0) ? 3 : (bpp + 7) / 8; in_uint8a(s, cur_data, 32 * (32 * Bpp)); in_uint8a(s, cur_mask, 32 * (32 / 8)); rv = mod->server_set_cursor_ex(mod, x, y, cur_data, cur_mask, bpp); return rv; } /******************************************************************************/ /* return error */ static int send_paint_rect_ack(struct mod *mod, int flags, int x, int y, int cx, int cy, int frame_id) { int len; struct stream *s; make_stream(s); init_stream(s, 8192); s_push_layer(s, iso_hdr, 4); out_uint16_le(s, 105); out_uint32_le(s, flags); out_uint32_le(s, frame_id); out_uint32_le(s, x); out_uint32_le(s, y); out_uint32_le(s, cx); out_uint32_le(s, cy); s_mark_end(s); len = (int)(s->end - s->data); s_pop_layer(s, iso_hdr); out_uint32_le(s, len); lib_send_copy(mod, s); free_stream(s); return 0; } /******************************************************************************/ /* return error */ static int process_server_paint_rect_shmem(struct mod *amod, struct stream *s) { int rv; int x; int y; int cx; int cy; int flags; int frame_id; int shmem_id; int shmem_offset; int width; int height; int srcx; int srcy; char *bmpdata; in_sint16_le(s, x); in_sint16_le(s, y); in_uint16_le(s, cx); in_uint16_le(s, cy); in_uint32_le(s, flags); in_uint32_le(s, frame_id); in_uint32_le(s, shmem_id); in_uint32_le(s, shmem_offset); in_uint16_le(s, width); in_uint16_le(s, height); in_sint16_le(s, srcx); in_sint16_le(s, srcy); bmpdata = 0; rv = 0; if (amod->screen_shmem_id_mapped == 0) { amod->screen_shmem_id = shmem_id; amod->screen_shmem_pixels = (char *) g_shmat(amod->screen_shmem_id); if (amod->screen_shmem_pixels == (void*)-1) { /* failed */ amod->screen_shmem_id = 0; amod->screen_shmem_pixels = 0; amod->screen_shmem_id_mapped = 0; } else { amod->screen_shmem_id_mapped = 1; } } if (amod->screen_shmem_pixels != 0) { bmpdata = amod->screen_shmem_pixels + shmem_offset; } if (bmpdata != 0) { rv = amod->server_paint_rect(amod, x, y, cx, cy, bmpdata, width, height, srcx, srcy); } send_paint_rect_ack(amod, flags, x, y, cx, cy, frame_id); return rv; } /******************************************************************************/ /* return error */ static int send_paint_rect_ex_ack(struct mod *mod, int flags, int frame_id) { int len; struct stream *s; make_stream(s); init_stream(s, 8192); s_push_layer(s, iso_hdr, 4); out_uint16_le(s, 106); out_uint32_le(s, flags); out_uint32_le(s, frame_id); s_mark_end(s); len = (int)(s->end - s->data); s_pop_layer(s, iso_hdr); out_uint32_le(s, len); lib_send_copy(mod, s); free_stream(s); return 0; } /******************************************************************************/ /* return error */ static int process_server_paint_rect_shmem_ex(struct mod *amod, struct stream *s) { int num_drects; int num_crects; int flags; int frame_id; int shmem_id; int shmem_offset; int width; int height; int index; int rv; tsi16 *ldrects; tsi16 *ldrects1; tsi16 *lcrects; tsi16 *lcrects1; char *bmpdata; /* dirty pixels */ in_uint16_le(s, num_drects); ldrects = (tsi16 *) g_malloc(2 * 4 * num_drects, 0); ldrects1 = ldrects; for (index = 0; index < num_drects; index++) { in_sint16_le(s, ldrects1[0]); in_sint16_le(s, ldrects1[1]); in_sint16_le(s, ldrects1[2]); in_sint16_le(s, ldrects1[3]); ldrects1 += 4; } /* copied pixels */ in_uint16_le(s, num_crects); lcrects = (tsi16 *) g_malloc(2 * 4 * num_crects, 0); lcrects1 = lcrects; for (index = 0; index < num_crects; index++) { in_sint16_le(s, lcrects1[0]); in_sint16_le(s, lcrects1[1]); in_sint16_le(s, lcrects1[2]); in_sint16_le(s, lcrects1[3]); lcrects1 += 4; } in_uint32_le(s, flags); in_uint32_le(s, frame_id); in_uint32_le(s, shmem_id); in_uint32_le(s, shmem_offset); in_uint16_le(s, width); in_uint16_le(s, height); bmpdata = 0; if (flags == 0) /* screen */ { if (amod->screen_shmem_id_mapped == 0) { amod->screen_shmem_id = shmem_id; amod->screen_shmem_pixels = (char *) g_shmat(amod->screen_shmem_id); if (amod->screen_shmem_pixels == (void*)-1) { /* failed */ amod->screen_shmem_id = 0; amod->screen_shmem_pixels = 0; amod->screen_shmem_id_mapped = 0; } else { amod->screen_shmem_id_mapped = 1; } } if (amod->screen_shmem_pixels != 0) { bmpdata = amod->screen_shmem_pixels + shmem_offset; } } if (bmpdata != 0) { rv = amod->server_paint_rects(amod, num_drects, ldrects, num_crects, lcrects, bmpdata, width, height, flags, frame_id); } else { rv = 1; } //g_writeln("frame_id %d", frame_id); //send_paint_rect_ex_ack(amod, flags, frame_id); g_free(lcrects); g_free(ldrects); return rv; } /******************************************************************************/ /* return error */ static int lib_mod_process_orders(struct mod *mod, int type, struct stream *s) { int rv; LLOGLN(10, ("lib_mod_process_orders: type %d", type)); rv = 0; switch (type) { case 1: /* server_begin_update */ rv = mod->server_begin_update(mod); break; case 2: /* server_end_update */ rv = mod->server_end_update(mod); break; case 3: /* server_fill_rect */ rv = process_server_fill_rect(mod, s); break; case 4: /* server_screen_blt */ rv = process_server_screen_blt(mod, s); break; case 5: /* server_paint_rect */ rv = process_server_paint_rect(mod, s); break; case 10: /* server_set_clip */ rv = process_server_set_clip(mod, s); break; case 11: /* server_reset_clip */ rv = process_server_reset_clip(mod, s); break; case 12: /* server_set_fgcolor */ rv = process_server_set_fgcolor(mod, s); break; case 13: /* server_set_bgcolor */ rv = process_server_set_bgcolor(mod, s); break; case 14: /* server_set_opcode */ rv = process_server_set_opcode(mod, s); break; case 17: /* server_set_pen */ rv = process_server_set_pen(mod, s); break; case 18: /* server_draw_line */ rv = process_server_draw_line(mod, s); break; case 19: /* server_set_cursor */ rv = process_server_set_cursor(mod, s); break; case 20: /* server_create_os_surface */ rv = process_server_create_os_surface(mod, s); break; case 21: /* server_switch_os_surface */ rv = process_server_switch_os_surface(mod, s); break; case 22: /* server_delete_os_surface */ rv = process_server_delete_os_surface(mod, s); break; case 23: /* server_paint_rect_os */ rv = process_server_paint_rect_os(mod, s); break; case 24: /* server_set_hints */ rv = process_server_set_hints(mod, s); break; case 25: /* server_window_new_update */ rv = process_server_window_new_update(mod, s); break; case 26: /* server_window_delete */ rv = process_server_window_delete(mod, s); break; case 27: /* server_window_new_update - show */ rv = process_server_window_show(mod, s); break; case 28: /* server_add_char */ rv = process_server_add_char(mod, s); break; case 29: /* server_add_char_alpha */ rv = process_server_add_char_alpha(mod, s); break; case 30: /* server_draw_text */ rv = process_server_draw_text(mod, s); break; case 31: /* server_create_os_surface_bpp */ rv = process_server_create_os_surface_bpp(mod, s); break; case 32: /* server_paint_rect_bpp */ rv = process_server_paint_rect_bpp(mod, s); break; case 33: /* server_composite */ rv = process_server_composite(mod, s); break; case 51: /* server_set_pointer_ex */ rv = process_server_set_pointer_ex(mod, s); break; case 60: /* server_paint_rect_shmem */ rv = process_server_paint_rect_shmem(mod, s); break; case 61: /* server_paint_rect_shmem_ex */ rv = process_server_paint_rect_shmem_ex(mod, s); break; default: g_writeln("lib_mod_process_orders: unknown order type %d", type); rv = 0; break; } return rv; } /******************************************************************************/ /* return error */ static int lib_send_client_info(struct mod *mod) { struct stream *s; int len; g_writeln("lib_send_client_info:"); make_stream(s); init_stream(s, 8192); s_push_layer(s, iso_hdr, 4); out_uint16_le(s, 104); g_memcpy(s->p, &(mod->client_info), sizeof(mod->client_info)); s->p += sizeof(mod->client_info); s_mark_end(s); len = (int)(s->end - s->data); s_pop_layer(s, iso_hdr); out_uint32_le(s, len); lib_send_copy(mod, s); free_stream(s); return 0; } /******************************************************************************/ /* return error */ static int lib_mod_process_message(struct mod *mod, struct stream *s) { int num_orders; int index; int rv; int len; int type; char *phold; LLOGLN(10, ("lib_mod_process_message:")); rv = 0; if (rv == 0) { in_uint16_le(s, type); in_uint16_le(s, num_orders); in_uint32_le(s, len); LLOGLN(10, ("lib_mod_process_message: type %d", type)); if (type == 1) /* original order list */ { for (index = 0; index < num_orders; index++) { in_uint16_le(s, type); rv = lib_mod_process_orders(mod, type, s); if (rv != 0) { break; } } } else if (type == 2) /* caps */ { g_writeln("lib_mod_process_message: type 2 len %d", len); for (index = 0; index < num_orders; index++) { phold = s->p; in_uint16_le(s, type); in_uint16_le(s, len); switch (type) { default: g_writeln("lib_mod_process_message: unknown cap type %d len %d", type, len); break; } s->p = phold + len; } lib_send_client_info(mod); } else if (type == 3) /* order list with len after type */ { for (index = 0; index < num_orders; index++) { phold = s->p; in_uint16_le(s, type); in_uint16_le(s, len); rv = lib_mod_process_orders(mod, type, s); if (rv != 0) { break; } s->p = phold + len; } } else { g_writeln("unknown type %d", type); } } return rv; } /******************************************************************************/ /* return error */ int lib_mod_signal(struct mod *mod) { g_writeln("lib_mod_signal: not used"); return 0; } /******************************************************************************/ /* return error */ int lib_mod_end(struct mod *mod) { if (mod->screen_shmem_pixels != 0) { g_shmdt(mod->screen_shmem_pixels); mod->screen_shmem_pixels = 0; } return 0; } /******************************************************************************/ /* return error */ int lib_mod_set_param(struct mod *mod, const char *name, const char *value) { if (g_strcasecmp(name, "username") == 0) { g_strncpy(mod->username, value, 255); } else if (g_strcasecmp(name, "password") == 0) { g_strncpy(mod->password, value, 255); } else if (g_strcasecmp(name, "ip") == 0) { g_strncpy(mod->ip, value, 255); } else if (g_strcasecmp(name, "port") == 0) { g_strncpy(mod->port, value, 255); } else if (g_strcasecmp(name, "client_info") == 0) { g_memcpy(&(mod->client_info), value, sizeof(mod->client_info)); } return 0; } /******************************************************************************/ /* return error */ int lib_mod_get_wait_objs(struct mod *mod, tbus *read_objs, int *rcount, tbus *write_objs, int *wcount, int *timeout) { if (mod != 0) { if (mod->trans != 0) { trans_get_wait_objs_rw(mod->trans, read_objs, rcount, write_objs, wcount, timeout); } } return 0; } /******************************************************************************/ /* return error */ int lib_mod_check_wait_objs(struct mod *mod) { int rv; rv = 0; if (mod != 0) { if (mod->trans != 0) { rv = trans_check_wait_objs(mod->trans); } } return rv; } /******************************************************************************/ /* return error */ int lib_mod_frame_ack(struct mod *amod, int flags, int frame_id) { LLOGLN(10, ("lib_mod_frame_ack: flags 0x%8.8x frame_id %d", flags, frame_id)); send_paint_rect_ex_ack(amod, flags, frame_id); return 0; } /******************************************************************************/ tintptr EXPORT_CC mod_init(void) { struct mod *mod; mod = (struct mod *)g_malloc(sizeof(struct mod), 1); mod->size = sizeof(struct mod); mod->version = CURRENT_MOD_VER; mod->handle = (tintptr) mod; mod->mod_connect = lib_mod_connect; mod->mod_start = lib_mod_start; mod->mod_event = lib_mod_event; mod->mod_signal = lib_mod_signal; mod->mod_end = lib_mod_end; mod->mod_set_param = lib_mod_set_param; mod->mod_get_wait_objs = lib_mod_get_wait_objs; mod->mod_check_wait_objs = lib_mod_check_wait_objs; mod->mod_frame_ack = lib_mod_frame_ack; return (tintptr) mod; } /******************************************************************************/ int EXPORT_CC mod_exit(tintptr handle) { struct mod *mod = (struct mod *) handle; if (mod == 0) { return 0; } trans_delete(mod->trans); g_free(mod); return 0; } xrdp-0.9.5/instfiles/km-0000040b.ini000644 001751 001751 00000025177 13127114621 016507 0ustar00metameta000000 000000 [noshift] Key8=65406:0 Key9=65307:27 Key10=49:49 Key11=50:50 Key12=51:51 Key13=52:52 Key14=53:53 Key15=54:54 Key16=55:55 Key17=56:56 Key18=57:57 Key19=48:48 Key20=43:43 Key21=65105:180 Key22=65288:8 Key23=65289:9 Key24=113:113 Key25=119:119 Key26=101:101 Key27=114:114 Key28=116:116 Key29=121:121 Key30=117:117 Key31=105:105 Key32=111:111 Key33=112:112 Key34=229:229 Key35=65111:168 Key36=65293:13 Key37=65507:0 Key38=97:97 Key39=115:115 Key40=100:100 Key41=102:102 Key42=103:103 Key43=104:104 Key44=106:106 Key45=107:107 Key46=108:108 Key47=246:246 Key48=228:228 Key49=167:167 Key50=65505:0 Key51=39:39 Key52=122:122 Key53=120:120 Key54=99:99 Key55=118:118 Key56=98:98 Key57=110:110 Key58=109:109 Key59=44:44 Key60=46:46 Key61=45:45 Key62=65506:0 Key63=65450:42 Key64=65513:0 Key65=32:32 Key66=65509:0 Key67=65470:0 Key68=65471:0 Key69=65472:0 Key70=65473:0 Key71=65474:0 Key72=65475:0 Key73=65476:0 Key74=65477:0 Key75=65478:0 Key76=65479:0 Key77=65407:0 Key78=65300:0 Key79=65429:0 Key80=65431:0 Key81=65434:0 Key82=65453:45 Key83=65430:0 Key84=65437:0 Key85=65432:0 Key86=65451:43 Key87=65436:0 Key88=65433:0 Key89=65435:0 Key90=65438:0 Key91=65439:0 Key92=65377:0 Key93=0:0 Key94=60:60 Key95=65480:0 Key96=65481:0 Key97=65360:0 Key98=65362:0 Key99=65365:0 Key100=65361:0 Key101=0:0 Key102=65363:0 Key103=65367:0 Key104=65364:0 Key105=65366:0 Key106=65379:0 Key107=65535:127 Key108=65421:13 Key109=65508:0 Key110=65299:0 Key111=65377:0 Key112=65455:47 Key113=65027:0 Key114=269025049:0 Key115=65515:0 Key116=65312:0 Key117=0:0 Key118=269025153:0 Key119=269025093:0 Key120=269025094:0 Key121=269025095:0 Key122=269025096:0 Key123=0:0 Key124=65027:0 Key125=0:0 Key126=65469:61 Key127=0:0 Key128=0:0 Key129=0:0 Key130=0:0 Key131=0:0 Key132=0:0 Key133=0:0 Key134=0:0 Key135=0:0 Key136=0:0 Key137=0:0 [shift] Key8=65406:0 Key9=65307:27 Key10=33:33 Key11=34:34 Key12=35:35 Key13=164:164 Key14=37:37 Key15=38:38 Key16=47:47 Key17=40:40 Key18=41:41 Key19=61:61 Key20=63:63 Key21=65104:96 Key22=65288:8 Key23=65056:0 Key24=81:81 Key25=87:87 Key26=69:69 Key27=82:82 Key28=84:84 Key29=89:89 Key30=85:85 Key31=73:73 Key32=79:79 Key33=80:80 Key34=197:197 Key35=65106:94 Key36=65293:13 Key37=65507:0 Key38=65:65 Key39=83:83 Key40=68:68 Key41=70:70 Key42=71:71 Key43=72:72 Key44=74:74 Key45=75:75 Key46=76:76 Key47=214:214 Key48=196:196 Key49=189:189 Key50=65505:0 Key51=42:42 Key52=90:90 Key53=88:88 Key54=67:67 Key55=86:86 Key56=66:66 Key57=78:78 Key58=77:77 Key59=59:59 Key60=58:58 Key61=95:95 Key62=65506:0 Key63=65450:42 Key64=65032:0 Key65=32:32 Key66=65509:0 Key67=65470:0 Key68=65471:0 Key69=65472:0 Key70=65473:0 Key71=65474:0 Key72=65475:0 Key73=65476:0 Key74=65477:0 Key75=65478:0 Key76=65479:0 Key77=65407:0 Key78=65300:0 Key79=65463:55 Key80=65464:56 Key81=65465:57 Key82=65453:45 Key83=65460:52 Key84=65461:53 Key85=65462:54 Key86=65451:43 Key87=65457:49 Key88=65458:50 Key89=65459:51 Key90=65456:48 Key91=65452:44 Key92=65377:0 Key93=0:0 Key94=62:62 Key95=65480:0 Key96=65481:0 Key97=65360:0 Key98=65362:0 Key99=65365:0 Key100=65361:0 Key101=0:0 Key102=65363:0 Key103=65367:0 Key104=65364:0 Key105=65366:0 Key106=65379:0 Key107=65535:127 Key108=65421:13 Key109=65508:0 Key110=65299:0 Key111=65377:0 Key112=65455:47 Key113=65027:0 Key114=269025049:0 Key115=65515:0 Key116=65312:0 Key117=0:0 Key118=269025153:0 Key119=269025093:0 Key120=269025094:0 Key121=269025095:0 Key122=269025096:0 Key123=0:0 Key124=65027:0 Key125=65513:0 Key126=65469:61 Key127=65515:0 Key128=65517:0 Key129=0:0 Key130=0:0 Key131=0:0 Key132=0:0 Key133=0:0 Key134=0:0 Key135=0:0 Key136=0:0 Key137=0:0 [altgr] Key8=65406:0 Key9=65307:27 Key10=161:161 Key11=64:64 Key12=163:163 Key13=36:36 Key14=8364:8364 Key15=165:165 Key16=123:123 Key17=91:91 Key18=93:93 Key19=125:125 Key20=92:92 Key21=177:177 Key22=65288:8 Key23=65289:9 Key24=64:64 Key25=435:322 Key26=8364:8364 Key27=174:174 Key28=254:254 Key29=2299:8592 Key30=2302:8595 Key31=2301:8594 Key32=5053:339 Key33=254:254 Key34=65111:168 Key35=65107:126 Key36=65293:13 Key37=65507:0 Key38=170:170 Key39=223:223 Key40=240:240 Key41=496:273 Key42=959:331 Key43=689:295 Key44=65121:0 Key45=930:312 Key46=435:322 Key47=248:248 Key48=230:230 Key49=182:182 Key50=65505:0 Key51=180:180 Key52=171:171 Key53=187:187 Key54=169:169 Key55=2770:8220 Key56=2771:8221 Key57=110:110 Key58=181:181 Key59=65115:184 Key60=183:183 Key61=65120:0 Key62=65506:0 Key63=65450:42 Key64=65513:0 Key65=32:32 Key66=65509:0 Key67=65470:0 Key68=65471:0 Key69=65472:0 Key70=65473:0 Key71=65474:0 Key72=65475:0 Key73=65476:0 Key74=65477:0 Key75=65478:0 Key76=65479:0 Key77=65407:0 Key78=65300:0 Key79=65429:0 Key80=65431:0 Key81=65434:0 Key82=65453:45 Key83=65430:0 Key84=65437:0 Key85=65432:0 Key86=65451:43 Key87=65436:0 Key88=65433:0 Key89=65435:0 Key90=65438:0 Key91=65439:0 Key92=65377:0 Key93=0:0 Key94=124:124 Key95=65480:0 Key96=65481:0 Key97=65360:0 Key98=65362:0 Key99=65365:0 Key100=65361:0 Key101=0:0 Key102=65363:0 Key103=65367:0 Key104=65364:0 Key105=65366:0 Key106=65379:0 Key107=65535:127 Key108=65421:13 Key109=65508:0 Key110=65299:0 Key111=65377:0 Key112=65455:47 Key113=65027:0 Key114=269025049:0 Key115=65515:0 Key116=65312:0 Key117=0:0 Key118=269025153:0 Key119=269025093:0 Key120=269025094:0 Key121=269025095:0 Key122=269025096:0 Key123=0:0 Key124=65027:0 Key125=0:0 Key126=65469:61 Key127=0:0 Key128=0:0 Key129=0:0 Key130=0:0 Key131=0:0 Key132=0:0 Key133=0:0 Key134=0:0 Key135=0:0 Key136=0:0 Key137=0:0 [shiftaltgr] Key8=65406:0 Key9=65307:27 Key10=185:185 Key11=178:178 Key12=179:179 Key13=188:188 Key14=162:162 Key15=2757:8541 Key16=247:247 Key17=171:171 Key18=187:187 Key19=176:176 Key20=191:191 Key21=172:172 Key22=65288:8 Key23=65056:0 Key24=2009:937 Key25=419:321 Key26=162:162 Key27=174:174 Key28=222:222 Key29=165:165 Key30=2300:8593 Key31=697:305 Key32=5052:338 Key33=222:222 Key34=65112:176 Key35=65114:711 Key36=65293:13 Key37=65507:0 Key38=186:186 Key39=167:167 Key40=208:208 Key41=170:170 Key42=957:330 Key43=673:294 Key44=65122:0 Key45=38:38 Key46=419:321 Key47=216:216 Key48=198:198 Key49=190:190 Key50=65505:0 Key51=215:215 Key52=60:60 Key53=62:62 Key54=169:169 Key55=2768:8216 Key56=2769:8217 Key57=78:78 Key58=186:186 Key59=65116:731 Key60=65110:729 Key61=65110:729 Key62=65506:0 Key63=65450:42 Key64=65032:0 Key65=160:160 Key66=65509:0 Key67=65470:0 Key68=65471:0 Key69=65472:0 Key70=65473:0 Key71=65474:0 Key72=65475:0 Key73=65476:0 Key74=65477:0 Key75=65478:0 Key76=65479:0 Key77=65407:0 Key78=65300:0 Key79=65463:55 Key80=65464:56 Key81=65465:57 Key82=65453:45 Key83=65460:52 Key84=65461:53 Key85=65462:54 Key86=65451:43 Key87=65457:49 Key88=65458:50 Key89=65459:51 Key90=65456:48 Key91=65452:44 Key92=65377:0 Key93=0:0 Key94=166:166 Key95=65480:0 Key96=65481:0 Key97=65360:0 Key98=65362:0 Key99=65365:0 Key100=65361:0 Key101=0:0 Key102=65363:0 Key103=65367:0 Key104=65364:0 Key105=65366:0 Key106=65379:0 Key107=65535:127 Key108=65421:13 Key109=65508:0 Key110=65299:0 Key111=65377:0 Key112=65455:47 Key113=65027:0 Key114=269025049:0 Key115=65515:0 Key116=65312:0 Key117=0:0 Key118=269025153:0 Key119=269025093:0 Key120=269025094:0 Key121=269025095:0 Key122=269025096:0 Key123=0:0 Key124=65027:0 Key125=65513:0 Key126=65469:61 Key127=65515:0 Key128=65517:0 Key129=0:0 Key130=0:0 Key131=0:0 Key132=0:0 Key133=0:0 Key134=0:0 Key135=0:0 Key136=0:0 Key137=0:0 [capslock] Key8=65406:0 Key9=65307:27 Key10=49:49 Key11=50:50 Key12=51:51 Key13=52:52 Key14=53:53 Key15=54:54 Key16=55:55 Key17=56:56 Key18=57:57 Key19=48:48 Key20=43:43 Key21=65105:180 Key22=65288:8 Key23=65289:9 Key24=81:81 Key25=87:87 Key26=69:69 Key27=82:82 Key28=84:84 Key29=89:89 Key30=85:85 Key31=73:73 Key32=79:79 Key33=80:80 Key34=197:197 Key35=65111:168 Key36=65293:13 Key37=65507:0 Key38=65:65 Key39=83:83 Key40=68:68 Key41=70:70 Key42=71:71 Key43=72:72 Key44=74:74 Key45=75:75 Key46=76:76 Key47=214:214 Key48=196:196 Key49=167:167 Key50=65505:0 Key51=39:39 Key52=90:90 Key53=88:88 Key54=67:67 Key55=86:86 Key56=66:66 Key57=78:78 Key58=77:77 Key59=44:44 Key60=46:46 Key61=45:45 Key62=65506:0 Key63=65450:42 Key64=65513:0 Key65=32:32 Key66=65509:0 Key67=65470:0 Key68=65471:0 Key69=65472:0 Key70=65473:0 Key71=65474:0 Key72=65475:0 Key73=65476:0 Key74=65477:0 Key75=65478:0 Key76=65479:0 Key77=65407:0 Key78=65300:0 Key79=65429:0 Key80=65431:0 Key81=65434:0 Key82=65453:45 Key83=65430:0 Key84=65437:0 Key85=65432:0 Key86=65451:43 Key87=65436:0 Key88=65433:0 Key89=65435:0 Key90=65438:0 Key91=65439:0 Key92=65377:0 Key93=0:0 Key94=60:60 Key95=65480:0 Key96=65481:0 Key97=65360:0 Key98=65362:0 Key99=65365:0 Key100=65361:0 Key101=0:0 Key102=65363:0 Key103=65367:0 Key104=65364:0 Key105=65366:0 Key106=65379:0 Key107=65535:127 Key108=65421:13 Key109=65508:0 Key110=65299:0 Key111=65377:0 Key112=65455:47 Key113=65027:0 Key114=269025049:0 Key115=65515:0 Key116=65312:0 Key117=0:0 Key118=269025153:0 Key119=269025093:0 Key120=269025094:0 Key121=269025095:0 Key122=269025096:0 Key123=0:0 Key124=65027:0 Key125=0:0 Key126=65469:61 Key127=0:0 Key128=0:0 Key129=0:0 Key130=0:0 Key131=0:0 Key132=0:0 Key133=0:0 Key134=0:0 Key135=0:0 Key136=0:0 Key137=0:0 [shiftcapslock] Key8=65406:0 Key9=65307:27 Key10=33:33 Key11=34:34 Key12=35:35 Key13=164:164 Key14=37:37 Key15=38:38 Key16=47:47 Key17=40:40 Key18=41:41 Key19=61:61 Key20=63:63 Key21=65104:96 Key22=65288:8 Key23=65056:0 Key24=113:113 Key25=119:119 Key26=101:101 Key27=114:114 Key28=116:116 Key29=121:121 Key30=117:117 Key31=105:105 Key32=111:111 Key33=112:112 Key34=229:229 Key35=65106:94 Key36=65293:13 Key37=65507:0 Key38=97:97 Key39=115:115 Key40=100:100 Key41=102:102 Key42=103:103 Key43=104:104 Key44=106:106 Key45=107:107 Key46=108:108 Key47=246:246 Key48=228:228 Key49=189:189 Key50=65505:0 Key51=42:42 Key52=122:122 Key53=120:120 Key54=99:99 Key55=118:118 Key56=98:98 Key57=110:110 Key58=109:109 Key59=59:59 Key60=58:58 Key61=95:95 Key62=65506:0 Key63=65450:42 Key64=65032:0 Key65=32:32 Key66=65509:0 Key67=65470:0 Key68=65471:0 Key69=65472:0 Key70=65473:0 Key71=65474:0 Key72=65475:0 Key73=65476:0 Key74=65477:0 Key75=65478:0 Key76=65479:0 Key77=65407:0 Key78=65300:0 Key79=65463:55 Key80=65464:56 Key81=65465:57 Key82=65453:45 Key83=65460:52 Key84=65461:53 Key85=65462:54 Key86=65451:43 Key87=65457:49 Key88=65458:50 Key89=65459:51 Key90=65456:48 Key91=65452:44 Key92=65377:0 Key93=0:0 Key94=62:62 Key95=65480:0 Key96=65481:0 Key97=65360:0 Key98=65362:0 Key99=65365:0 Key100=65361:0 Key101=0:0 Key102=65363:0 Key103=65367:0 Key104=65364:0 Key105=65366:0 Key106=65379:0 Key107=65535:127 Key108=65421:13 Key109=65508:0 Key110=65299:0 Key111=65377:0 Key112=65455:47 Key113=65027:0 Key114=269025049:0 Key115=65515:0 Key116=65312:0 Key117=0:0 Key118=269025153:0 Key119=269025093:0 Key120=269025094:0 Key121=269025095:0 Key122=269025096:0 Key123=0:0 Key124=65027:0 Key125=65513:0 Key126=65469:61 Key127=65515:0 Key128=65517:0 Key129=0:0 Key130=0:0 Key131=0:0 Key132=0:0 Key133=0:0 Key134=0:0 Key135=0:0 Key136=0:0 Key137=0:0 xrdp-0.9.5/instfiles/Makefile.in000644 001751 001751 00000065030 13220730774 016500 0ustar00metameta000000 000000 # Makefile.in generated by automake 1.15.1 from Makefile.am. # @configure_input@ # Copyright (C) 1994-2017 Free Software Foundation, Inc. # This Makefile.in is free software; the Free Software Foundation # gives unlimited permission to copy and/or distribute it, # with or without modifications, as long as this notice is preserved. # This program is distributed in the hope that it will be useful, # but WITHOUT ANY WARRANTY, to the extent permitted by law; without # even the implied warranty of MERCHANTABILITY or FITNESS FOR A # PARTICULAR PURPOSE. @SET_MAKE@ VPATH = @srcdir@ am__is_gnu_make = { \ if test -z '$(MAKELEVEL)'; then \ false; \ elif test -n '$(MAKE_HOST)'; then \ true; \ elif test -n '$(MAKE_VERSION)' && test -n '$(CURDIR)'; then \ true; \ else \ false; \ fi; \ } am__make_running_with_option = \ case $${target_option-} in \ ?) ;; \ *) echo "am__make_running_with_option: internal error: invalid" \ "target option '$${target_option-}' specified" >&2; \ exit 1;; \ esac; \ has_opt=no; \ sane_makeflags=$$MAKEFLAGS; \ if $(am__is_gnu_make); then \ sane_makeflags=$$MFLAGS; \ else \ case $$MAKEFLAGS in \ *\\[\ \ ]*) \ bs=\\; \ sane_makeflags=`printf '%s\n' "$$MAKEFLAGS" \ | sed "s/$$bs$$bs[$$bs $$bs ]*//g"`;; \ esac; \ fi; \ skip_next=no; \ strip_trailopt () \ { \ flg=`printf '%s\n' "$$flg" | sed "s/$$1.*$$//"`; \ }; \ for flg in $$sane_makeflags; do \ test $$skip_next = yes && { skip_next=no; continue; }; \ case $$flg in \ *=*|--*) continue;; \ -*I) strip_trailopt 'I'; skip_next=yes;; \ -*I?*) strip_trailopt 'I';; \ -*O) strip_trailopt 'O'; skip_next=yes;; \ -*O?*) strip_trailopt 'O';; \ -*l) strip_trailopt 'l'; skip_next=yes;; \ -*l?*) strip_trailopt 'l';; \ -[dEDm]) skip_next=yes;; \ -[JT]) skip_next=yes;; \ esac; \ case $$flg in \ *$$target_option*) has_opt=yes; break;; \ esac; \ done; \ test $$has_opt = yes am__make_dryrun = (target_option=n; $(am__make_running_with_option)) am__make_keepgoing = (target_option=k; $(am__make_running_with_option)) pkgdatadir = $(datadir)/@PACKAGE@ pkgincludedir = $(includedir)/@PACKAGE@ pkglibdir = $(libdir)/@PACKAGE@ pkglibexecdir = $(libexecdir)/@PACKAGE@ am__cd = CDPATH="$${ZSH_VERSION+.}$(PATH_SEPARATOR)" && cd install_sh_DATA = $(install_sh) -c -m 644 install_sh_PROGRAM = $(install_sh) -c install_sh_SCRIPT = $(install_sh) -c INSTALL_HEADER = $(INSTALL_DATA) transform = $(program_transform_name) NORMAL_INSTALL = : PRE_INSTALL = : POST_INSTALL = : NORMAL_UNINSTALL = : PRE_UNINSTALL = : POST_UNINSTALL = : build_triplet = @build@ host_triplet = @host@ @LINUX_TRUE@am__append_1 = \ @LINUX_TRUE@ pam.d \ @LINUX_TRUE@ pulse @HAVE_SYSTEMD_FALSE@@LINUX_TRUE@am__append_2 = \ @HAVE_SYSTEMD_FALSE@@LINUX_TRUE@ default \ @HAVE_SYSTEMD_FALSE@@LINUX_TRUE@ init.d @FREEBSD_TRUE@am__append_3 = \ @FREEBSD_TRUE@ pam.d \ @FREEBSD_TRUE@ rc.d \ @FREEBSD_TRUE@ pulse subdir = instfiles ACLOCAL_M4 = $(top_srcdir)/aclocal.m4 am__aclocal_m4_deps = $(top_srcdir)/m4/ax_append_compile_flags.m4 \ $(top_srcdir)/m4/ax_append_flag.m4 \ $(top_srcdir)/m4/ax_cflags_warn_all.m4 \ $(top_srcdir)/m4/ax_check_compile_flag.m4 \ $(top_srcdir)/m4/ax_gcc_func_attribute.m4 \ $(top_srcdir)/m4/ax_require_defined.m4 \ $(top_srcdir)/m4/ax_type_socklen_t.m4 \ $(top_srcdir)/m4/libtool.m4 $(top_srcdir)/m4/ltoptions.m4 \ $(top_srcdir)/m4/ltsugar.m4 $(top_srcdir)/m4/ltversion.m4 \ $(top_srcdir)/m4/lt~obsolete.m4 $(top_srcdir)/m4/pkg.m4 \ $(top_srcdir)/configure.ac am__configure_deps = $(am__aclocal_m4_deps) $(CONFIGURE_DEPENDENCIES) \ $(ACLOCAL_M4) DIST_COMMON = $(srcdir)/Makefile.am \ $(am__dist_startscript_SCRIPTS_DIST) $(dist_startscript_DATA) \ $(am__DIST_COMMON) mkinstalldirs = $(install_sh) -d CONFIG_HEADER = $(top_builddir)/config_ac.h CONFIG_CLEAN_FILES = CONFIG_CLEAN_VPATH_FILES = am__dist_startscript_SCRIPTS_DIST = xrdp.sh am__vpath_adj_setup = srcdirstrip=`echo "$(srcdir)" | sed 's|.|.|g'`; am__vpath_adj = case $$p in \ $(srcdir)/*) f=`echo "$$p" | sed "s|^$$srcdirstrip/||"`;; \ *) f=$$p;; \ esac; am__strip_dir = f=`echo $$p | sed -e 's|^.*/||'`; am__install_max = 40 am__nobase_strip_setup = \ srcdirstrip=`echo "$(srcdir)" | sed 's/[].[^$$\\*|]/\\\\&/g'` am__nobase_strip = \ for p in $$list; do echo "$$p"; done | sed -e "s|$$srcdirstrip/||" am__nobase_list = $(am__nobase_strip_setup); \ for p in $$list; do echo "$$p $$p"; done | \ sed "s| $$srcdirstrip/| |;"' / .*\//!s/ .*/ ./; s,\( .*\)/[^/]*$$,\1,' | \ $(AWK) 'BEGIN { files["."] = "" } { files[$$2] = files[$$2] " " $$1; \ if (++n[$$2] == $(am__install_max)) \ { print $$2, files[$$2]; n[$$2] = 0; files[$$2] = "" } } \ END { for (dir in files) print dir, files[dir] }' am__base_list = \ sed '$$!N;$$!N;$$!N;$$!N;$$!N;$$!N;$$!N;s/\n/ /g' | \ sed '$$!N;$$!N;$$!N;$$!N;s/\n/ /g' am__uninstall_files_from_dir = { \ test -z "$$files" \ || { test ! -d "$$dir" && test ! -f "$$dir" && test ! -r "$$dir"; } \ || { echo " ( cd '$$dir' && rm -f" $$files ")"; \ $(am__cd) "$$dir" && rm -f $$files; }; \ } am__installdirs = "$(DESTDIR)$(startscriptdir)" \ "$(DESTDIR)$(startscriptdir)" \ "$(DESTDIR)$(systemdsystemunitdir)" SCRIPTS = $(dist_startscript_SCRIPTS) AM_V_P = $(am__v_P_@AM_V@) am__v_P_ = $(am__v_P_@AM_DEFAULT_V@) am__v_P_0 = false am__v_P_1 = : AM_V_GEN = $(am__v_GEN_@AM_V@) am__v_GEN_ = $(am__v_GEN_@AM_DEFAULT_V@) am__v_GEN_0 = @echo " GEN " $@; am__v_GEN_1 = AM_V_at = $(am__v_at_@AM_V@) am__v_at_ = $(am__v_at_@AM_DEFAULT_V@) am__v_at_0 = @ am__v_at_1 = SOURCES = DIST_SOURCES = RECURSIVE_TARGETS = all-recursive check-recursive cscopelist-recursive \ ctags-recursive dvi-recursive html-recursive info-recursive \ install-data-recursive install-dvi-recursive \ install-exec-recursive install-html-recursive \ install-info-recursive install-pdf-recursive \ install-ps-recursive install-recursive installcheck-recursive \ installdirs-recursive pdf-recursive ps-recursive \ tags-recursive uninstall-recursive am__can_run_installinfo = \ case $$AM_UPDATE_INFO_DIR in \ n|no|NO) false;; \ *) (install-info --version) >/dev/null 2>&1;; \ esac DATA = $(dist_startscript_DATA) $(systemdsystemunit_DATA) RECURSIVE_CLEAN_TARGETS = mostlyclean-recursive clean-recursive \ distclean-recursive maintainer-clean-recursive am__recursive_targets = \ $(RECURSIVE_TARGETS) \ $(RECURSIVE_CLEAN_TARGETS) \ $(am__extra_recursive_targets) AM_RECURSIVE_TARGETS = $(am__recursive_targets:-recursive=) TAGS CTAGS \ distdir am__tagged_files = $(HEADERS) $(SOURCES) $(TAGS_FILES) $(LISP) # Read a list of newline-separated strings from the standard input, # and print each of them once, without duplicates. Input order is # *not* preserved. am__uniquify_input = $(AWK) '\ BEGIN { nonempty = 0; } \ { items[$$0] = 1; nonempty = 1; } \ END { if (nonempty) { for (i in items) print i; }; } \ ' # Make sure the list of sources is unique. This is necessary because, # e.g., the same source file might be shared among _SOURCES variables # for different programs/libraries. am__define_uniq_tagged_files = \ list='$(am__tagged_files)'; \ unique=`for i in $$list; do \ if test -f "$$i"; then echo $$i; else echo $(srcdir)/$$i; fi; \ done | $(am__uniquify_input)` ETAGS = etags CTAGS = ctags DIST_SUBDIRS = pam.d pulse default init.d rc.d am__DIST_COMMON = $(srcdir)/Makefile.in DISTFILES = $(DIST_COMMON) $(DIST_SOURCES) $(TEXINFOS) $(EXTRA_DIST) am__relativize = \ dir0=`pwd`; \ sed_first='s,^\([^/]*\)/.*$$,\1,'; \ sed_rest='s,^[^/]*/*,,'; \ sed_last='s,^.*/\([^/]*\)$$,\1,'; \ sed_butlast='s,/*[^/]*$$,,'; \ while test -n "$$dir1"; do \ first=`echo "$$dir1" | sed -e "$$sed_first"`; \ if test "$$first" != "."; then \ if test "$$first" = ".."; then \ dir2=`echo "$$dir0" | sed -e "$$sed_last"`/"$$dir2"; \ dir0=`echo "$$dir0" | sed -e "$$sed_butlast"`; \ else \ first2=`echo "$$dir2" | sed -e "$$sed_first"`; \ if test "$$first2" = "$$first"; then \ dir2=`echo "$$dir2" | sed -e "$$sed_rest"`; \ else \ dir2="../$$dir2"; \ fi; \ dir0="$$dir0"/"$$first"; \ fi; \ fi; \ dir1=`echo "$$dir1" | sed -e "$$sed_rest"`; \ done; \ reldir="$$dir2" ACLOCAL = @ACLOCAL@ AMTAR = @AMTAR@ AM_DEFAULT_VERBOSITY = @AM_DEFAULT_VERBOSITY@ AR = @AR@ AUTOCONF = @AUTOCONF@ AUTOHEADER = @AUTOHEADER@ AUTOMAKE = @AUTOMAKE@ AWK = @AWK@ CC = @CC@ CCDEPMODE = @CCDEPMODE@ CFLAGS = @CFLAGS@ CPP = @CPP@ CPPFLAGS = @CPPFLAGS@ CYGPATH_W = @CYGPATH_W@ DEFS = @DEFS@ DEPDIR = @DEPDIR@ DLLTOOL = @DLLTOOL@ DLOPEN_LIBS = @DLOPEN_LIBS@ DSYMUTIL = @DSYMUTIL@ DUMPBIN = @DUMPBIN@ ECHO_C = @ECHO_C@ ECHO_N = @ECHO_N@ ECHO_T = @ECHO_T@ EGREP = @EGREP@ EXEEXT = @EXEEXT@ FDKAAC_CFLAGS = @FDKAAC_CFLAGS@ FDKAAC_LIBS = @FDKAAC_LIBS@ FGREP = @FGREP@ FREERDP_CFLAGS = @FREERDP_CFLAGS@ FREERDP_LIBS = @FREERDP_LIBS@ FUSE_CFLAGS = @FUSE_CFLAGS@ FUSE_LIBS = @FUSE_LIBS@ GREP = @GREP@ INSTALL = @INSTALL@ INSTALL_DATA = @INSTALL_DATA@ INSTALL_PROGRAM = @INSTALL_PROGRAM@ INSTALL_SCRIPT = @INSTALL_SCRIPT@ INSTALL_STRIP_PROGRAM = @INSTALL_STRIP_PROGRAM@ LD = @LD@ LDFLAGS = @LDFLAGS@ LIBOBJS = @LIBOBJS@ LIBS = @LIBS@ LIBTOOL = @LIBTOOL@ LIPO = @LIPO@ LN_S = @LN_S@ LTLIBOBJS = @LTLIBOBJS@ LT_SYS_LIBRARY_PATH = @LT_SYS_LIBRARY_PATH@ MAKEINFO = @MAKEINFO@ MANIFEST_TOOL = @MANIFEST_TOOL@ MKDIR_P = @MKDIR_P@ NM = @NM@ NMEDIT = @NMEDIT@ OBJDUMP = @OBJDUMP@ OBJEXT = @OBJEXT@ OPENSSL = @OPENSSL@ OPENSSL_CFLAGS = @OPENSSL_CFLAGS@ OPENSSL_LIBS = @OPENSSL_LIBS@ OTOOL = @OTOOL@ OTOOL64 = @OTOOL64@ PACKAGE = @PACKAGE@ PACKAGE_BUGREPORT = @PACKAGE_BUGREPORT@ PACKAGE_NAME = @PACKAGE_NAME@ PACKAGE_STRING = @PACKAGE_STRING@ PACKAGE_TARNAME = @PACKAGE_TARNAME@ PACKAGE_URL = @PACKAGE_URL@ PACKAGE_VERSION = @PACKAGE_VERSION@ PAM_RULES = @PAM_RULES@ PATH_SEPARATOR = @PATH_SEPARATOR@ PIXMAN_CFLAGS = @PIXMAN_CFLAGS@ PIXMAN_LIBS = @PIXMAN_LIBS@ PKG_CONFIG = @PKG_CONFIG@ PKG_CONFIG_LIBDIR = @PKG_CONFIG_LIBDIR@ PKG_CONFIG_PATH = @PKG_CONFIG_PATH@ RANLIB = @RANLIB@ SED = @SED@ SET_MAKE = @SET_MAKE@ SHELL = @SHELL@ STRIP = @STRIP@ TurboJpegIncDir = @TurboJpegIncDir@ TurboJpegLibDir = @TurboJpegLibDir@ VERSION = @VERSION@ XMKMF = @XMKMF@ X_CFLAGS = @X_CFLAGS@ X_EXTRA_LIBS = @X_EXTRA_LIBS@ X_LIBS = @X_LIBS@ X_PRE_LIBS = @X_PRE_LIBS@ abs_builddir = @abs_builddir@ abs_srcdir = @abs_srcdir@ abs_top_builddir = @abs_top_builddir@ abs_top_srcdir = @abs_top_srcdir@ ac_ct_AR = @ac_ct_AR@ ac_ct_CC = @ac_ct_CC@ ac_ct_DUMPBIN = @ac_ct_DUMPBIN@ am__include = @am__include@ am__leading_dot = @am__leading_dot@ am__quote = @am__quote@ am__tar = @am__tar@ am__untar = @am__untar@ bindir = @bindir@ build = @build@ build_alias = @build_alias@ build_cpu = @build_cpu@ build_os = @build_os@ build_vendor = @build_vendor@ builddir = @builddir@ datadir = @datadir@ datarootdir = @datarootdir@ docdir = @docdir@ dvidir = @dvidir@ exec_prefix = @exec_prefix@ host = @host@ host_alias = @host_alias@ host_cpu = @host_cpu@ host_os = @host_os@ host_vendor = @host_vendor@ htmldir = @htmldir@ includedir = @includedir@ infodir = @infodir@ install_sh = @install_sh@ libdir = @libdir@ libexecdir = @libexecdir@ localedir = @localedir@ localstatedir = @localstatedir@ mandir = @mandir@ mkdir_p = @mkdir_p@ moduledir = @moduledir@ oldincludedir = @oldincludedir@ pdfdir = @pdfdir@ pkgconfigdir = @pkgconfigdir@ prefix = @prefix@ program_transform_name = @program_transform_name@ psdir = @psdir@ sbindir = @sbindir@ sharedstatedir = @sharedstatedir@ socketdir = @socketdir@ srcdir = @srcdir@ subdirs = @subdirs@ sysconfdir = @sysconfdir@ systemdsystemunitdir = @systemdsystemunitdir@ target_alias = @target_alias@ top_build_prefix = @top_build_prefix@ top_builddir = @top_builddir@ top_srcdir = @top_srcdir@ EXTRA_DIST = \ keymap-names.txt \ xrdp.sh \ xrdp-sesman.service.in \ xrdp.service.in # # substitute directories in service file # CLEANFILES = \ xrdp-sesman.service \ xrdp.service SUBST_VARS = sed \ -e 's|@sbindir[@]|$(sbindir)|g' \ -e 's|@sysconfdir[@]|$(sysconfdir)|g' \ -e 's|@localstatedir[@]|$(localstatedir)|g' subst_verbose = $(subst_verbose_@AM_V@) subst_verbose_ = $(subst_verbose_@AM_DEFAULT_V@) subst_verbose_0 = @echo " SUBST $@"; SUFFIXES = .in # # files for all platforms # startscriptdir = $(sysconfdir)/xrdp dist_startscript_DATA = \ km-00000407.ini \ km-00000409.ini \ km-0000040a.ini \ km-0000040b.ini \ km-0000040c.ini \ km-00000410.ini \ km-00000411.ini \ km-00000412.ini \ km-00000414.ini \ km-00000415.ini \ km-00000416.ini \ km-00000419.ini \ km-0000041d.ini \ km-00000807.ini \ km-00000809.ini \ km-0000080c.ini \ km-00000813.ini \ km-00000816.ini \ km-0000100c.ini \ km-00010409.ini # # platform specific files # SUBDIRS = $(am__append_1) $(am__append_2) $(am__append_3) @LINUX_TRUE@dist_startscript_SCRIPTS = xrdp.sh @HAVE_SYSTEMD_TRUE@@LINUX_TRUE@systemdsystemunit_DATA = \ @HAVE_SYSTEMD_TRUE@@LINUX_TRUE@ xrdp-sesman.service \ @HAVE_SYSTEMD_TRUE@@LINUX_TRUE@ xrdp.service all: all-recursive .SUFFIXES: .SUFFIXES: .in $(srcdir)/Makefile.in: $(srcdir)/Makefile.am $(am__configure_deps) @for dep in $?; do \ case '$(am__configure_deps)' in \ *$$dep*) \ ( cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh ) \ && { if test -f $@; then exit 0; else break; fi; }; \ exit 1;; \ esac; \ done; \ echo ' cd $(top_srcdir) && $(AUTOMAKE) --foreign instfiles/Makefile'; \ $(am__cd) $(top_srcdir) && \ $(AUTOMAKE) --foreign instfiles/Makefile Makefile: $(srcdir)/Makefile.in $(top_builddir)/config.status @case '$?' in \ *config.status*) \ cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh;; \ *) \ echo ' cd $(top_builddir) && $(SHELL) ./config.status $(subdir)/$@ $(am__depfiles_maybe)'; \ cd $(top_builddir) && $(SHELL) ./config.status $(subdir)/$@ $(am__depfiles_maybe);; \ esac; $(top_builddir)/config.status: $(top_srcdir)/configure $(CONFIG_STATUS_DEPENDENCIES) cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh $(top_srcdir)/configure: $(am__configure_deps) cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh $(ACLOCAL_M4): $(am__aclocal_m4_deps) cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh $(am__aclocal_m4_deps): install-dist_startscriptSCRIPTS: $(dist_startscript_SCRIPTS) @$(NORMAL_INSTALL) @list='$(dist_startscript_SCRIPTS)'; test -n "$(startscriptdir)" || list=; \ if test -n "$$list"; then \ echo " $(MKDIR_P) '$(DESTDIR)$(startscriptdir)'"; \ $(MKDIR_P) "$(DESTDIR)$(startscriptdir)" || exit 1; \ fi; \ for p in $$list; do \ if test -f "$$p"; then d=; else d="$(srcdir)/"; fi; \ if test -f "$$d$$p"; then echo "$$d$$p"; echo "$$p"; else :; fi; \ done | \ sed -e 'p;s,.*/,,;n' \ -e 'h;s|.*|.|' \ -e 'p;x;s,.*/,,;$(transform)' | sed 'N;N;N;s,\n, ,g' | \ $(AWK) 'BEGIN { files["."] = ""; dirs["."] = 1; } \ { d=$$3; if (dirs[d] != 1) { print "d", d; dirs[d] = 1 } \ if ($$2 == $$4) { files[d] = files[d] " " $$1; \ if (++n[d] == $(am__install_max)) { \ print "f", d, files[d]; n[d] = 0; files[d] = "" } } \ else { print "f", d "/" $$4, $$1 } } \ END { for (d in files) print "f", d, files[d] }' | \ while read type dir files; do \ if test "$$dir" = .; then dir=; else dir=/$$dir; fi; \ test -z "$$files" || { \ echo " $(INSTALL_SCRIPT) $$files '$(DESTDIR)$(startscriptdir)$$dir'"; \ $(INSTALL_SCRIPT) $$files "$(DESTDIR)$(startscriptdir)$$dir" || exit $$?; \ } \ ; done uninstall-dist_startscriptSCRIPTS: @$(NORMAL_UNINSTALL) @list='$(dist_startscript_SCRIPTS)'; test -n "$(startscriptdir)" || exit 0; \ files=`for p in $$list; do echo "$$p"; done | \ sed -e 's,.*/,,;$(transform)'`; \ dir='$(DESTDIR)$(startscriptdir)'; $(am__uninstall_files_from_dir) mostlyclean-libtool: -rm -f *.lo clean-libtool: -rm -rf .libs _libs install-dist_startscriptDATA: $(dist_startscript_DATA) @$(NORMAL_INSTALL) @list='$(dist_startscript_DATA)'; test -n "$(startscriptdir)" || list=; \ if test -n "$$list"; then \ echo " $(MKDIR_P) '$(DESTDIR)$(startscriptdir)'"; \ $(MKDIR_P) "$(DESTDIR)$(startscriptdir)" || exit 1; \ fi; \ for p in $$list; do \ if test -f "$$p"; then d=; else d="$(srcdir)/"; fi; \ echo "$$d$$p"; \ done | $(am__base_list) | \ while read files; do \ echo " $(INSTALL_DATA) $$files '$(DESTDIR)$(startscriptdir)'"; \ $(INSTALL_DATA) $$files "$(DESTDIR)$(startscriptdir)" || exit $$?; \ done uninstall-dist_startscriptDATA: @$(NORMAL_UNINSTALL) @list='$(dist_startscript_DATA)'; test -n "$(startscriptdir)" || list=; \ files=`for p in $$list; do echo $$p; done | sed -e 's|^.*/||'`; \ dir='$(DESTDIR)$(startscriptdir)'; $(am__uninstall_files_from_dir) install-systemdsystemunitDATA: $(systemdsystemunit_DATA) @$(NORMAL_INSTALL) @list='$(systemdsystemunit_DATA)'; test -n "$(systemdsystemunitdir)" || list=; \ if test -n "$$list"; then \ echo " $(MKDIR_P) '$(DESTDIR)$(systemdsystemunitdir)'"; \ $(MKDIR_P) "$(DESTDIR)$(systemdsystemunitdir)" || exit 1; \ fi; \ for p in $$list; do \ if test -f "$$p"; then d=; else d="$(srcdir)/"; fi; \ echo "$$d$$p"; \ done | $(am__base_list) | \ while read files; do \ echo " $(INSTALL_DATA) $$files '$(DESTDIR)$(systemdsystemunitdir)'"; \ $(INSTALL_DATA) $$files "$(DESTDIR)$(systemdsystemunitdir)" || exit $$?; \ done uninstall-systemdsystemunitDATA: @$(NORMAL_UNINSTALL) @list='$(systemdsystemunit_DATA)'; test -n "$(systemdsystemunitdir)" || list=; \ files=`for p in $$list; do echo $$p; done | sed -e 's|^.*/||'`; \ dir='$(DESTDIR)$(systemdsystemunitdir)'; $(am__uninstall_files_from_dir) # This directory's subdirectories are mostly independent; you can cd # into them and run 'make' without going through this Makefile. # To change the values of 'make' variables: instead of editing Makefiles, # (1) if the variable is set in 'config.status', edit 'config.status' # (which will cause the Makefiles to be regenerated when you run 'make'); # (2) otherwise, pass the desired values on the 'make' command line. $(am__recursive_targets): @fail=; \ if $(am__make_keepgoing); then \ failcom='fail=yes'; \ else \ failcom='exit 1'; \ fi; \ dot_seen=no; \ target=`echo $@ | sed s/-recursive//`; \ case "$@" in \ distclean-* | maintainer-clean-*) list='$(DIST_SUBDIRS)' ;; \ *) list='$(SUBDIRS)' ;; \ esac; \ for subdir in $$list; do \ echo "Making $$target in $$subdir"; \ if test "$$subdir" = "."; then \ dot_seen=yes; \ local_target="$$target-am"; \ else \ local_target="$$target"; \ fi; \ ($(am__cd) $$subdir && $(MAKE) $(AM_MAKEFLAGS) $$local_target) \ || eval $$failcom; \ done; \ if test "$$dot_seen" = "no"; then \ $(MAKE) $(AM_MAKEFLAGS) "$$target-am" || exit 1; \ fi; test -z "$$fail" ID: $(am__tagged_files) $(am__define_uniq_tagged_files); mkid -fID $$unique tags: tags-recursive TAGS: tags tags-am: $(TAGS_DEPENDENCIES) $(am__tagged_files) set x; \ here=`pwd`; \ if ($(ETAGS) --etags-include --version) >/dev/null 2>&1; then \ include_option=--etags-include; \ empty_fix=.; \ else \ include_option=--include; \ empty_fix=; \ fi; \ list='$(SUBDIRS)'; for subdir in $$list; do \ if test "$$subdir" = .; then :; else \ test ! -f $$subdir/TAGS || \ set "$$@" "$$include_option=$$here/$$subdir/TAGS"; \ fi; \ done; \ $(am__define_uniq_tagged_files); \ shift; \ if test -z "$(ETAGS_ARGS)$$*$$unique"; then :; else \ test -n "$$unique" || unique=$$empty_fix; \ if test $$# -gt 0; then \ $(ETAGS) $(ETAGSFLAGS) $(AM_ETAGSFLAGS) $(ETAGS_ARGS) \ "$$@" $$unique; \ else \ $(ETAGS) $(ETAGSFLAGS) $(AM_ETAGSFLAGS) $(ETAGS_ARGS) \ $$unique; \ fi; \ fi ctags: ctags-recursive CTAGS: ctags ctags-am: $(TAGS_DEPENDENCIES) $(am__tagged_files) $(am__define_uniq_tagged_files); \ test -z "$(CTAGS_ARGS)$$unique" \ || $(CTAGS) $(CTAGSFLAGS) $(AM_CTAGSFLAGS) $(CTAGS_ARGS) \ $$unique GTAGS: here=`$(am__cd) $(top_builddir) && pwd` \ && $(am__cd) $(top_srcdir) \ && gtags -i $(GTAGS_ARGS) "$$here" cscopelist: cscopelist-recursive cscopelist-am: $(am__tagged_files) list='$(am__tagged_files)'; \ case "$(srcdir)" in \ [\\/]* | ?:[\\/]*) sdir="$(srcdir)" ;; \ *) sdir=$(subdir)/$(srcdir) ;; \ esac; \ for i in $$list; do \ if test -f "$$i"; then \ echo "$(subdir)/$$i"; \ else \ echo "$$sdir/$$i"; \ fi; \ done >> $(top_builddir)/cscope.files distclean-tags: -rm -f TAGS ID GTAGS GRTAGS GSYMS GPATH tags distdir: $(DISTFILES) @srcdirstrip=`echo "$(srcdir)" | sed 's/[].[^$$\\*]/\\\\&/g'`; \ topsrcdirstrip=`echo "$(top_srcdir)" | sed 's/[].[^$$\\*]/\\\\&/g'`; \ list='$(DISTFILES)'; \ dist_files=`for file in $$list; do echo $$file; done | \ sed -e "s|^$$srcdirstrip/||;t" \ -e "s|^$$topsrcdirstrip/|$(top_builddir)/|;t"`; \ case $$dist_files in \ */*) $(MKDIR_P) `echo "$$dist_files" | \ sed '/\//!d;s|^|$(distdir)/|;s,/[^/]*$$,,' | \ sort -u` ;; \ esac; \ for file in $$dist_files; do \ if test -f $$file || test -d $$file; then d=.; else d=$(srcdir); fi; \ if test -d $$d/$$file; then \ dir=`echo "/$$file" | sed -e 's,/[^/]*$$,,'`; \ if test -d "$(distdir)/$$file"; then \ find "$(distdir)/$$file" -type d ! -perm -700 -exec chmod u+rwx {} \;; \ fi; \ if test -d $(srcdir)/$$file && test $$d != $(srcdir); then \ cp -fpR $(srcdir)/$$file "$(distdir)$$dir" || exit 1; \ find "$(distdir)/$$file" -type d ! -perm -700 -exec chmod u+rwx {} \;; \ fi; \ cp -fpR $$d/$$file "$(distdir)$$dir" || exit 1; \ else \ test -f "$(distdir)/$$file" \ || cp -p $$d/$$file "$(distdir)/$$file" \ || exit 1; \ fi; \ done @list='$(DIST_SUBDIRS)'; for subdir in $$list; do \ if test "$$subdir" = .; then :; else \ $(am__make_dryrun) \ || test -d "$(distdir)/$$subdir" \ || $(MKDIR_P) "$(distdir)/$$subdir" \ || exit 1; \ dir1=$$subdir; dir2="$(distdir)/$$subdir"; \ $(am__relativize); \ new_distdir=$$reldir; \ dir1=$$subdir; dir2="$(top_distdir)"; \ $(am__relativize); \ new_top_distdir=$$reldir; \ echo " (cd $$subdir && $(MAKE) $(AM_MAKEFLAGS) top_distdir="$$new_top_distdir" distdir="$$new_distdir" \\"; \ echo " am__remove_distdir=: am__skip_length_check=: am__skip_mode_fix=: distdir)"; \ ($(am__cd) $$subdir && \ $(MAKE) $(AM_MAKEFLAGS) \ top_distdir="$$new_top_distdir" \ distdir="$$new_distdir" \ am__remove_distdir=: \ am__skip_length_check=: \ am__skip_mode_fix=: \ distdir) \ || exit 1; \ fi; \ done check-am: all-am check: check-recursive all-am: Makefile $(SCRIPTS) $(DATA) installdirs: installdirs-recursive installdirs-am: for dir in "$(DESTDIR)$(startscriptdir)" "$(DESTDIR)$(startscriptdir)" "$(DESTDIR)$(systemdsystemunitdir)"; do \ test -z "$$dir" || $(MKDIR_P) "$$dir"; \ done install: install-recursive install-exec: install-exec-recursive install-data: install-data-recursive uninstall: uninstall-recursive install-am: all-am @$(MAKE) $(AM_MAKEFLAGS) install-exec-am install-data-am installcheck: installcheck-recursive install-strip: if test -z '$(STRIP)'; then \ $(MAKE) $(AM_MAKEFLAGS) INSTALL_PROGRAM="$(INSTALL_STRIP_PROGRAM)" \ install_sh_PROGRAM="$(INSTALL_STRIP_PROGRAM)" INSTALL_STRIP_FLAG=-s \ install; \ else \ $(MAKE) $(AM_MAKEFLAGS) INSTALL_PROGRAM="$(INSTALL_STRIP_PROGRAM)" \ install_sh_PROGRAM="$(INSTALL_STRIP_PROGRAM)" INSTALL_STRIP_FLAG=-s \ "INSTALL_PROGRAM_ENV=STRIPPROG='$(STRIP)'" install; \ fi mostlyclean-generic: clean-generic: -test -z "$(CLEANFILES)" || rm -f $(CLEANFILES) distclean-generic: -test -z "$(CONFIG_CLEAN_FILES)" || rm -f $(CONFIG_CLEAN_FILES) -test . = "$(srcdir)" || test -z "$(CONFIG_CLEAN_VPATH_FILES)" || rm -f $(CONFIG_CLEAN_VPATH_FILES) maintainer-clean-generic: @echo "This command is intended for maintainers to use" @echo "it deletes files that may require special tools to rebuild." @FREEBSD_FALSE@@LINUX_FALSE@install-data-hook: clean: clean-recursive clean-am: clean-generic clean-libtool mostlyclean-am distclean: distclean-recursive -rm -f Makefile distclean-am: clean-am distclean-generic distclean-tags dvi: dvi-recursive dvi-am: html: html-recursive html-am: info: info-recursive info-am: install-data-am: install-dist_startscriptDATA \ install-dist_startscriptSCRIPTS install-systemdsystemunitDATA @$(NORMAL_INSTALL) $(MAKE) $(AM_MAKEFLAGS) install-data-hook install-dvi: install-dvi-recursive install-dvi-am: install-exec-am: install-html: install-html-recursive install-html-am: install-info: install-info-recursive install-info-am: install-man: install-pdf: install-pdf-recursive install-pdf-am: install-ps: install-ps-recursive install-ps-am: installcheck-am: maintainer-clean: maintainer-clean-recursive -rm -f Makefile maintainer-clean-am: distclean-am maintainer-clean-generic mostlyclean: mostlyclean-recursive mostlyclean-am: mostlyclean-generic mostlyclean-libtool pdf: pdf-recursive pdf-am: ps: ps-recursive ps-am: uninstall-am: uninstall-dist_startscriptDATA \ uninstall-dist_startscriptSCRIPTS \ uninstall-systemdsystemunitDATA .MAKE: $(am__recursive_targets) install-am install-data-am \ install-strip .PHONY: $(am__recursive_targets) CTAGS GTAGS TAGS all all-am check \ check-am clean clean-generic clean-libtool cscopelist-am ctags \ ctags-am distclean distclean-generic distclean-libtool \ distclean-tags distdir dvi dvi-am html html-am info info-am \ install install-am install-data install-data-am \ install-data-hook install-dist_startscriptDATA \ install-dist_startscriptSCRIPTS install-dvi install-dvi-am \ install-exec install-exec-am install-html install-html-am \ install-info install-info-am install-man install-pdf \ install-pdf-am install-ps install-ps-am install-strip \ install-systemdsystemunitDATA installcheck installcheck-am \ installdirs installdirs-am maintainer-clean \ maintainer-clean-generic mostlyclean mostlyclean-generic \ mostlyclean-libtool pdf pdf-am ps ps-am tags tags-am uninstall \ uninstall-am uninstall-dist_startscriptDATA \ uninstall-dist_startscriptSCRIPTS \ uninstall-systemdsystemunitDATA .PRECIOUS: Makefile .in: $(subst_verbose)$(SUBST_VARS) $< > $@ # # install-data-hook for each platform # TODO: subst these directories as well as service files # # must be tab below @LINUX_TRUE@install-data-hook: @LINUX_TRUE@ if [ -f $(DESTDIR)$(sysconfdir)/init.d/xrdp ]; then \ @LINUX_TRUE@ sed -i 's|__BASE__|$(prefix)|' $(DESTDIR)$(sysconfdir)/init.d/xrdp; \ @LINUX_TRUE@ fi # must be tab below @FREEBSD_TRUE@install-data-hook: @FREEBSD_TRUE@ sed -i '' 's|%%PREFIX%%|$(prefix)|g' $(DESTDIR)$(sysconfdir)/rc.d/xrdp # Tell versions [3.59,3.63) of GNU make to not export all variables. # Otherwise a system limit (for SysV at least) may be exceeded. .NOEXPORT: xrdp-0.9.5/instfiles/km-0000100c.ini000644 001751 001751 00000020762 13127114621 016500 0ustar00metameta000000 000000 [noshift] Key8=0:0 Key9=65307:27 Key10=49:49 Key11=50:50 Key12=51:51 Key13=52:52 Key14=53:53 Key15=54:54 Key16=55:55 Key17=56:56 Key18=57:57 Key19=48:48 Key20=39:39 Key21=65106:94 Key22=65288:8 Key23=65289:9 Key24=113:113 Key25=119:119 Key26=101:101 Key27=114:114 Key28=116:116 Key29=122:122 Key30=117:117 Key31=105:105 Key32=111:111 Key33=112:112 Key34=232:232 Key35=65111:168 Key36=65293:13 Key37=65507:0 Key38=97:97 Key39=115:115 Key40=100:100 Key41=102:102 Key42=103:103 Key43=104:104 Key44=106:106 Key45=107:107 Key46=108:108 Key47=233:233 Key48=224:224 Key49=167:167 Key50=65505:0 Key51=36:36 Key52=121:121 Key53=120:120 Key54=99:99 Key55=118:118 Key56=98:98 Key57=110:110 Key58=109:109 Key59=44:44 Key60=46:46 Key61=45:45 Key62=65506:0 Key63=65450:42 Key64=65513:0 Key65=32:32 Key66=65509:0 Key67=65470:0 Key68=65471:0 Key69=65472:0 Key70=65473:0 Key71=65474:0 Key72=65475:0 Key73=65476:0 Key74=65477:0 Key75=65478:0 Key76=65479:0 Key77=65407:0 Key78=65300:0 Key79=65429:0 Key80=65431:0 Key81=65434:0 Key82=65453:45 Key83=65430:0 Key84=65437:0 Key85=65432:0 Key86=65451:43 Key87=65436:0 Key88=65433:0 Key89=65435:0 Key90=65438:0 Key91=65439:0 Key92=0:0 Key93=65406:0 Key94=60:60 Key95=65480:0 Key96=65481:0 Key97=65360:0 Key98=65362:0 Key99=65365:0 Key100=65361:0 Key101=0:0 Key102=65363:0 Key103=65367:0 Key104=65364:0 Key105=65366:0 Key106=65379:0 Key107=65535:127 Key108=65421:13 Key109=65508:0 Key110=65299:0 Key111=65377:0 Key112=65455:47 Key113=65027:0 Key114=0:0 Key115=0:0 Key116=0:0 Key117=0:0 Key118=0:0 Key119=0:0 Key120=0:0 Key121=0:0 Key122=0:0 Key123=0:0 Key124=65027:0 Key125=0:0 Key126=65469:61 Key127=0:0 Key128=0:0 Key129=0:0 Key130=0:0 Key131=0:0 Key132=0:0 Key133=0:0 Key134=0:0 Key135=0:0 Key136=0:0 Key137=0:0 [shift] Key8=0:0 Key9=65307:27 Key10=43:43 Key11=34:34 Key12=42:42 Key13=231:231 Key14=37:37 Key15=38:38 Key16=47:47 Key17=40:40 Key18=41:41 Key19=61:61 Key20=63:63 Key21=65104:96 Key22=65288:8 Key23=65056:0 Key24=81:81 Key25=87:87 Key26=69:69 Key27=82:82 Key28=84:84 Key29=90:90 Key30=85:85 Key31=73:73 Key32=79:79 Key33=80:80 Key34=252:252 Key35=33:33 Key36=65293:13 Key37=65507:0 Key38=65:65 Key39=83:83 Key40=68:68 Key41=70:70 Key42=71:71 Key43=72:72 Key44=74:74 Key45=75:75 Key46=76:76 Key47=246:246 Key48=228:228 Key49=176:176 Key50=65505:0 Key51=163:163 Key52=89:89 Key53=88:88 Key54=67:67 Key55=86:86 Key56=66:66 Key57=78:78 Key58=77:77 Key59=59:59 Key60=58:58 Key61=95:95 Key62=65506:0 Key63=65450:42 Key64=65511:0 Key65=32:32 Key66=65509:0 Key67=65470:0 Key68=65471:0 Key69=65472:0 Key70=65473:0 Key71=65474:0 Key72=65475:0 Key73=65476:0 Key74=65477:0 Key75=65478:0 Key76=65479:0 Key77=65273:0 Key78=65300:0 Key79=65463:55 Key80=65464:56 Key81=65465:57 Key82=65453:45 Key83=65460:52 Key84=65461:53 Key85=65462:54 Key86=65451:43 Key87=65457:49 Key88=65458:50 Key89=65459:51 Key90=65456:48 Key91=65454:46 Key92=0:0 Key93=65406:0 Key94=62:62 Key95=65480:0 Key96=65481:0 Key97=65360:0 Key98=65362:0 Key99=65365:0 Key100=65361:0 Key101=0:0 Key102=65363:0 Key103=65367:0 Key104=65364:0 Key105=65366:0 Key106=65379:0 Key107=65535:127 Key108=65421:13 Key109=65508:0 Key110=65299:0 Key111=65377:0 Key112=65455:47 Key113=65312:0 Key114=0:0 Key115=0:0 Key116=0:0 Key117=0:0 Key118=0:0 Key119=0:0 Key120=0:0 Key121=0:0 Key122=0:0 Key123=0:0 Key124=65027:0 Key125=65513:0 Key126=65469:61 Key127=65515:0 Key128=65517:0 Key129=0:0 Key130=0:0 Key131=0:0 Key132=0:0 Key133=0:0 Key134=0:0 Key135=0:0 Key136=0:0 Key137=0:0 [altgr] Key8=0:0 Key9=65307:27 Key10=124:124 Key11=64:64 Key12=35:35 Key13=188:188 Key14=189:189 Key15=172:172 Key16=166:166 Key17=162:162 Key18=93:93 Key19=125:125 Key20=65105:180 Key21=65107:126 Key22=65288:8 Key23=65289:9 Key24=64:64 Key25=435:322 Key26=8364:8364 Key27=182:182 Key28=956:359 Key29=2299:8592 Key30=2302:8595 Key31=2301:8594 Key32=248:248 Key33=254:254 Key34=91:91 Key35=93:93 Key36=65293:13 Key37=65507:0 Key38=230:230 Key39=223:223 Key40=240:240 Key41=496:273 Key42=959:331 Key43=689:295 Key44=106:106 Key45=930:312 Key46=435:322 Key47=65105:180 Key48=123:123 Key49=172:172 Key50=65505:0 Key51=125:125 Key52=171:171 Key53=187:187 Key54=162:162 Key55=2770:8220 Key56=2771:8221 Key57=110:110 Key58=181:181 Key59=2211:0 Key60=183:183 Key61=65120:0 Key62=65506:0 Key63=65450:42 Key64=65513:0 Key65=32:32 Key66=65509:0 Key67=65470:0 Key68=65471:0 Key69=65472:0 Key70=65473:0 Key71=65474:0 Key72=65475:0 Key73=65476:0 Key74=65477:0 Key75=65478:0 Key76=65479:0 Key77=65407:0 Key78=65300:0 Key79=65429:0 Key80=65431:0 Key81=65434:0 Key82=65453:45 Key83=65430:0 Key84=65437:0 Key85=65432:0 Key86=65451:43 Key87=65436:0 Key88=65433:0 Key89=65435:0 Key90=65438:0 Key91=65439:0 Key92=0:0 Key93=65406:0 Key94=92:92 Key95=65480:0 Key96=65481:0 Key97=65360:0 Key98=65362:0 Key99=65365:0 Key100=65361:0 Key101=0:0 Key102=65363:0 Key103=65367:0 Key104=65364:0 Key105=65366:0 Key106=65379:0 Key107=65535:127 Key108=65421:13 Key109=65508:0 Key110=65299:0 Key111=0:0 Key112=65455:47 Key113=65027:0 Key114=0:0 Key115=0:0 Key116=0:0 Key117=0:0 Key118=0:0 Key119=0:0 Key120=0:0 Key121=0:0 Key122=0:0 Key123=0:0 Key124=65027:0 Key125=0:0 Key126=65469:61 Key127=0:0 Key128=0:0 Key129=0:0 Key130=0:0 Key131=0:0 Key132=0:0 Key133=0:0 Key134=0:0 Key135=0:0 Key136=0:0 Key137=0:0 [capslock] Key8=0:0 Key9=65307:27 Key10=49:49 Key11=50:50 Key12=51:51 Key13=52:52 Key14=53:53 Key15=54:54 Key16=55:55 Key17=56:56 Key18=57:57 Key19=48:48 Key20=39:39 Key21=65106:94 Key22=65288:8 Key23=65289:9 Key24=81:81 Key25=87:87 Key26=69:69 Key27=82:82 Key28=84:84 Key29=90:90 Key30=85:85 Key31=73:73 Key32=79:79 Key33=80:80 Key34=200:200 Key35=65111:168 Key36=65293:13 Key37=65507:0 Key38=65:65 Key39=83:83 Key40=68:68 Key41=70:70 Key42=71:71 Key43=72:72 Key44=74:74 Key45=75:75 Key46=76:76 Key47=201:201 Key48=192:192 Key49=167:167 Key50=65505:0 Key51=36:36 Key52=89:89 Key53=88:88 Key54=67:67 Key55=86:86 Key56=66:66 Key57=78:78 Key58=77:77 Key59=44:44 Key60=46:46 Key61=45:45 Key62=65506:0 Key63=65450:42 Key64=65513:0 Key65=32:32 Key66=65509:0 Key67=65470:0 Key68=65471:0 Key69=65472:0 Key70=65473:0 Key71=65474:0 Key72=65475:0 Key73=65476:0 Key74=65477:0 Key75=65478:0 Key76=65479:0 Key77=65407:0 Key78=65300:0 Key79=65429:0 Key80=65431:0 Key81=65434:0 Key82=65453:45 Key83=65430:0 Key84=65437:0 Key85=65432:0 Key86=65451:43 Key87=65436:0 Key88=65433:0 Key89=65435:0 Key90=65438:0 Key91=65439:0 Key92=0:0 Key93=65406:0 Key94=60:60 Key95=65480:0 Key96=65481:0 Key97=65360:0 Key98=65362:0 Key99=65365:0 Key100=65361:0 Key101=0:0 Key102=65363:0 Key103=65367:0 Key104=65364:0 Key105=65366:0 Key106=65379:0 Key107=65535:127 Key108=65421:13 Key109=65508:0 Key110=65299:0 Key111=65377:0 Key112=65455:47 Key113=65027:0 Key114=0:0 Key115=0:0 Key116=0:0 Key117=0:0 Key118=0:0 Key119=0:0 Key120=0:0 Key121=0:0 Key122=0:0 Key123=0:0 Key124=65027:0 Key125=0:0 Key126=65469:61 Key127=0:0 Key128=0:0 Key129=0:0 Key130=0:0 Key131=0:0 Key132=0:0 Key133=0:0 Key134=0:0 Key135=0:0 Key136=0:0 Key137=0:0 [shiftcapslock] Key8=0:0 Key9=65307:27 Key10=43:43 Key11=34:34 Key12=42:42 Key13=199:199 Key14=37:37 Key15=38:38 Key16=47:47 Key17=40:40 Key18=41:41 Key19=61:61 Key20=63:63 Key21=65104:96 Key22=65288:8 Key23=65056:0 Key24=113:113 Key25=119:119 Key26=101:101 Key27=114:114 Key28=116:116 Key29=122:122 Key30=117:117 Key31=105:105 Key32=111:111 Key33=112:112 Key34=220:220 Key35=33:33 Key36=65293:13 Key37=65507:0 Key38=97:97 Key39=115:115 Key40=100:100 Key41=102:102 Key42=103:103 Key43=104:104 Key44=106:106 Key45=107:107 Key46=108:108 Key47=214:214 Key48=196:196 Key49=176:176 Key50=65505:0 Key51=163:163 Key52=121:121 Key53=120:120 Key54=99:99 Key55=118:118 Key56=98:98 Key57=110:110 Key58=109:109 Key59=59:59 Key60=58:58 Key61=95:95 Key62=65506:0 Key63=65450:42 Key64=65511:0 Key65=32:32 Key66=65509:0 Key67=65470:0 Key68=65471:0 Key69=65472:0 Key70=65473:0 Key71=65474:0 Key72=65475:0 Key73=65476:0 Key74=65477:0 Key75=65478:0 Key76=65479:0 Key77=65273:0 Key78=65300:0 Key79=65463:55 Key80=65464:56 Key81=65465:57 Key82=65453:45 Key83=65460:52 Key84=65461:53 Key85=65462:54 Key86=65451:43 Key87=65457:49 Key88=65458:50 Key89=65459:51 Key90=65456:48 Key91=65454:46 Key92=0:0 Key93=65406:0 Key94=62:62 Key95=65480:0 Key96=65481:0 Key97=65360:0 Key98=65362:0 Key99=65365:0 Key100=65361:0 Key101=0:0 Key102=65363:0 Key103=65367:0 Key104=65364:0 Key105=65366:0 Key106=65379:0 Key107=65535:127 Key108=65421:13 Key109=65508:0 Key110=65299:0 Key111=65377:0 Key112=65455:47 Key113=65312:0 Key114=0:0 Key115=0:0 Key116=0:0 Key117=0:0 Key118=0:0 Key119=0:0 Key120=0:0 Key121=0:0 Key122=0:0 Key123=0:0 Key124=65027:0 Key125=65513:0 Key126=65469:61 Key127=65515:0 Key128=65517:0 Key129=0:0 Key130=0:0 Key131=0:0 Key132=0:0 Key133=0:0 Key134=0:0 Key135=0:0 Key136=0:0 Key137=0:0 xrdp-0.9.5/instfiles/km-00000407.ini000644 001751 001751 00000025277 13127114621 016435 0ustar00metameta000000 000000 [noshift] Key8=65406:0 Key9=65307:27 Key10=49:49 Key11=50:50 Key12=51:51 Key13=52:52 Key14=53:53 Key15=54:54 Key16=55:55 Key17=56:56 Key18=57:57 Key19=48:48 Key20=223:223 Key21=65105:180 Key22=65288:8 Key23=65289:9 Key24=113:113 Key25=119:119 Key26=101:101 Key27=114:114 Key28=116:116 Key29=122:122 Key30=117:117 Key31=105:105 Key32=111:111 Key33=112:112 Key34=252:252 Key35=43:43 Key36=65293:13 Key37=65507:0 Key38=97:97 Key39=115:115 Key40=100:100 Key41=102:102 Key42=103:103 Key43=104:104 Key44=106:106 Key45=107:107 Key46=108:108 Key47=246:246 Key48=228:228 Key49=65106:94 Key50=65505:0 Key51=35:35 Key52=121:121 Key53=120:120 Key54=99:99 Key55=118:118 Key56=98:98 Key57=110:110 Key58=109:109 Key59=44:44 Key60=46:46 Key61=45:45 Key62=65506:0 Key63=65450:42 Key64=65513:0 Key65=32:32 Key66=65509:0 Key67=65470:0 Key68=65471:0 Key69=65472:0 Key70=65473:0 Key71=65474:0 Key72=65475:0 Key73=65476:0 Key74=65477:0 Key75=65478:0 Key76=65479:0 Key77=65407:0 Key78=65300:0 Key79=65429:0 Key80=65431:0 Key81=65434:0 Key82=65453:45 Key83=65430:0 Key84=65437:0 Key85=65432:0 Key86=65451:43 Key87=65436:0 Key88=65433:0 Key89=65435:0 Key90=65438:0 Key91=65439:0 Key92=65377:0 Key93=0:0 Key94=60:60 Key95=65480:0 Key96=65481:0 Key97=65360:0 Key98=65362:0 Key99=65365:0 Key100=65361:0 Key101=0:0 Key102=65363:0 Key103=65367:0 Key104=65364:0 Key105=65366:0 Key106=65379:0 Key107=65535:127 Key108=65421:13 Key109=65508:0 Key110=65299:0 Key111=65377:0 Key112=65455:47 Key113=65027:0 Key114=269025049:0 Key115=65515:0 Key116=65312:0 Key117=0:0 Key118=269025153:0 Key119=269025093:0 Key120=269025094:0 Key121=269025095:0 Key122=269025096:0 Key123=0:0 Key124=65027:0 Key125=0:0 Key126=65469:61 Key127=0:0 Key128=0:0 Key129=0:0 Key130=0:0 Key131=0:0 Key132=0:0 Key133=0:0 Key134=0:0 Key135=0:0 Key136=0:0 Key137=0:0 [shift] Key8=65406:0 Key9=65307:27 Key10=33:33 Key11=34:34 Key12=167:167 Key13=36:36 Key14=37:37 Key15=38:38 Key16=47:47 Key17=40:40 Key18=41:41 Key19=61:61 Key20=63:63 Key21=65104:96 Key22=65288:8 Key23=65056:0 Key24=81:81 Key25=87:87 Key26=69:69 Key27=82:82 Key28=84:84 Key29=90:90 Key30=85:85 Key31=73:73 Key32=79:79 Key33=80:80 Key34=220:220 Key35=42:42 Key36=65293:13 Key37=65507:0 Key38=65:65 Key39=83:83 Key40=68:68 Key41=70:70 Key42=71:71 Key43=72:72 Key44=74:74 Key45=75:75 Key46=76:76 Key47=214:214 Key48=196:196 Key49=176:176 Key50=65505:0 Key51=39:39 Key52=89:89 Key53=88:88 Key54=67:67 Key55=86:86 Key56=66:66 Key57=78:78 Key58=77:77 Key59=59:59 Key60=58:58 Key61=95:95 Key62=65506:0 Key63=65450:42 Key64=65032:0 Key65=32:32 Key66=65509:0 Key67=65470:0 Key68=65471:0 Key69=65472:0 Key70=65473:0 Key71=65474:0 Key72=65475:0 Key73=65476:0 Key74=65477:0 Key75=65478:0 Key76=65479:0 Key77=65407:0 Key78=65300:0 Key79=65463:55 Key80=65464:56 Key81=65465:57 Key82=65453:45 Key83=65460:52 Key84=65461:53 Key85=65462:54 Key86=65451:43 Key87=65457:49 Key88=65458:50 Key89=65459:51 Key90=65456:48 Key91=65452:44 Key92=65377:0 Key93=0:0 Key94=62:62 Key95=65480:0 Key96=65481:0 Key97=65360:0 Key98=65362:0 Key99=65365:0 Key100=65361:0 Key101=0:0 Key102=65363:0 Key103=65367:0 Key104=65364:0 Key105=65366:0 Key106=65379:0 Key107=65535:127 Key108=65421:13 Key109=65508:0 Key110=65299:0 Key111=65377:0 Key112=65455:47 Key113=65027:0 Key114=269025049:0 Key115=65515:0 Key116=65312:0 Key117=0:0 Key118=269025153:0 Key119=269025093:0 Key120=269025094:0 Key121=269025095:0 Key122=269025096:0 Key123=0:0 Key124=65027:0 Key125=65513:0 Key126=65469:61 Key127=65515:0 Key128=65517:0 Key129=0:0 Key130=0:0 Key131=0:0 Key132=0:0 Key133=0:0 Key134=0:0 Key135=0:0 Key136=0:0 Key137=0:0 [altgr] Key8=65406:0 Key9=65307:27 Key10=185:185 Key11=178:178 Key12=179:179 Key13=188:188 Key14=189:189 Key15=172:172 Key16=123:123 Key17=91:91 Key18=93:93 Key19=125:125 Key20=92:92 Key21=65115:184 Key22=65288:8 Key23=65289:9 Key24=64:64 Key25=435:322 Key26=8364:8364 Key27=182:182 Key28=956:359 Key29=2299:8592 Key30=2302:8595 Key31=2301:8594 Key32=248:248 Key33=254:254 Key34=65111:168 Key35=126:126 Key36=65293:13 Key37=65507:0 Key38=230:230 Key39=16777599:383 Key40=240:240 Key41=496:273 Key42=959:331 Key43=689:295 Key44=65120:0 Key45=930:312 Key46=435:322 Key47=65113:733 Key48=65106:94 Key49=16785458:8242 Key50=65505:0 Key51=2769:8217 Key52=187:187 Key53=171:171 Key54=162:162 Key55=2814:8222 Key56=2770:8220 Key57=2771:8221 Key58=181:181 Key59=183:183 Key60=16785446:8230 Key61=2730:8211 Key62=65506:0 Key63=65450:42 Key64=65513:0 Key65=32:32 Key66=65509:0 Key67=65470:0 Key68=65471:0 Key69=65472:0 Key70=65473:0 Key71=65474:0 Key72=65475:0 Key73=65476:0 Key74=65477:0 Key75=65478:0 Key76=65479:0 Key77=65407:0 Key78=65300:0 Key79=65429:0 Key80=65431:0 Key81=65434:0 Key82=65453:45 Key83=65430:0 Key84=65437:0 Key85=65432:0 Key86=65451:43 Key87=65436:0 Key88=65433:0 Key89=65435:0 Key90=65438:0 Key91=65439:0 Key92=65377:0 Key93=0:0 Key94=124:124 Key95=65480:0 Key96=65481:0 Key97=65360:0 Key98=65362:0 Key99=65365:0 Key100=65361:0 Key101=0:0 Key102=65363:0 Key103=65367:0 Key104=65364:0 Key105=65366:0 Key106=65379:0 Key107=65535:127 Key108=65421:13 Key109=65508:0 Key110=65299:0 Key111=65377:0 Key112=65455:47 Key113=65027:0 Key114=269025049:0 Key115=65515:0 Key116=65312:0 Key117=0:0 Key118=269025153:0 Key119=269025093:0 Key120=269025094:0 Key121=269025095:0 Key122=269025096:0 Key123=0:0 Key124=65027:0 Key125=0:0 Key126=65469:61 Key127=0:0 Key128=0:0 Key129=0:0 Key130=0:0 Key131=0:0 Key132=0:0 Key133=0:0 Key134=0:0 Key135=0:0 Key136=0:0 Key137=0:0 [shiftaltgr] Key8=65406:0 Key9=65307:27 Key10=161:161 Key11=2755:8539 Key12=163:163 Key13=164:164 Key14=2756:8540 Key15=2757:8541 Key16=2758:8542 Key17=2761:8482 Key18=177:177 Key19=176:176 Key20=191:191 Key21=65116:731 Key22=65288:8 Key23=65056:0 Key24=2009:937 Key25=419:321 Key26=8364:8364 Key27=174:174 Key28=940:358 Key29=165:165 Key30=2300:8593 Key31=697:305 Key32=216:216 Key33=222:222 Key34=65112:176 Key35=175:175 Key36=65293:13 Key37=65507:0 Key38=198:198 Key39=16785054:7838 Key40=208:208 Key41=170:170 Key42=957:330 Key43=673:294 Key44=65110:729 Key45=38:38 Key46=419:321 Key47=65120:0 Key48=65114:711 Key49=16785459:8243 Key50=65505:0 Key51=65109:728 Key52=16785466:8250 Key53=16785465:8249 Key54=169:169 Key55=2813:8218 Key56=2768:8216 Key57=2769:8217 Key58=186:186 Key59=215:215 Key60=247:247 Key61=2729:8212 Key62=65506:0 Key63=65450:42 Key64=65032:0 Key65=32:32 Key66=65509:0 Key67=65470:0 Key68=65471:0 Key69=65472:0 Key70=65473:0 Key71=65474:0 Key72=65475:0 Key73=65476:0 Key74=65477:0 Key75=65478:0 Key76=65479:0 Key77=65407:0 Key78=65300:0 Key79=65463:55 Key80=65464:56 Key81=65465:57 Key82=65453:45 Key83=65460:52 Key84=65461:53 Key85=65462:54 Key86=65451:43 Key87=65457:49 Key88=65458:50 Key89=65459:51 Key90=65456:48 Key91=65452:44 Key92=65377:0 Key93=0:0 Key94=166:166 Key95=65480:0 Key96=65481:0 Key97=65360:0 Key98=65362:0 Key99=65365:0 Key100=65361:0 Key101=0:0 Key102=65363:0 Key103=65367:0 Key104=65364:0 Key105=65366:0 Key106=65379:0 Key107=65535:127 Key108=65421:13 Key109=65508:0 Key110=65299:0 Key111=65377:0 Key112=65455:47 Key113=65027:0 Key114=269025049:0 Key115=65515:0 Key116=65312:0 Key117=0:0 Key118=269025153:0 Key119=269025093:0 Key120=269025094:0 Key121=269025095:0 Key122=269025096:0 Key123=0:0 Key124=65027:0 Key125=65513:0 Key126=65469:61 Key127=65515:0 Key128=65517:0 Key129=0:0 Key130=0:0 Key131=0:0 Key132=0:0 Key133=0:0 Key134=0:0 Key135=0:0 Key136=0:0 Key137=0:0 [capslock] Key8=65406:0 Key9=65307:27 Key10=49:49 Key11=50:50 Key12=51:51 Key13=52:52 Key14=53:53 Key15=54:54 Key16=55:55 Key17=56:56 Key18=57:57 Key19=48:48 Key20=16785054:7838 Key21=65105:180 Key22=65288:8 Key23=65289:9 Key24=81:81 Key25=87:87 Key26=69:69 Key27=82:82 Key28=84:84 Key29=90:90 Key30=85:85 Key31=73:73 Key32=79:79 Key33=80:80 Key34=220:220 Key35=43:43 Key36=65293:13 Key37=65507:0 Key38=65:65 Key39=83:83 Key40=68:68 Key41=70:70 Key42=71:71 Key43=72:72 Key44=74:74 Key45=75:75 Key46=76:76 Key47=214:214 Key48=196:196 Key49=65106:94 Key50=65505:0 Key51=35:35 Key52=89:89 Key53=88:88 Key54=67:67 Key55=86:86 Key56=66:66 Key57=78:78 Key58=77:77 Key59=44:44 Key60=46:46 Key61=45:45 Key62=65506:0 Key63=65450:42 Key64=65513:0 Key65=32:32 Key66=65509:0 Key67=65470:0 Key68=65471:0 Key69=65472:0 Key70=65473:0 Key71=65474:0 Key72=65475:0 Key73=65476:0 Key74=65477:0 Key75=65478:0 Key76=65479:0 Key77=65407:0 Key78=65300:0 Key79=65429:0 Key80=65431:0 Key81=65434:0 Key82=65453:45 Key83=65430:0 Key84=65437:0 Key85=65432:0 Key86=65451:43 Key87=65436:0 Key88=65433:0 Key89=65435:0 Key90=65438:0 Key91=65439:0 Key92=65377:0 Key93=0:0 Key94=60:60 Key95=65480:0 Key96=65481:0 Key97=65360:0 Key98=65362:0 Key99=65365:0 Key100=65361:0 Key101=0:0 Key102=65363:0 Key103=65367:0 Key104=65364:0 Key105=65366:0 Key106=65379:0 Key107=65535:127 Key108=65421:13 Key109=65508:0 Key110=65299:0 Key111=65377:0 Key112=65455:47 Key113=65027:0 Key114=269025049:0 Key115=65515:0 Key116=65312:0 Key117=0:0 Key118=269025153:0 Key119=269025093:0 Key120=269025094:0 Key121=269025095:0 Key122=269025096:0 Key123=0:0 Key124=65027:0 Key125=0:0 Key126=65469:61 Key127=0:0 Key128=0:0 Key129=0:0 Key130=0:0 Key131=0:0 Key132=0:0 Key133=0:0 Key134=0:0 Key135=0:0 Key136=0:0 Key137=0:0 [shiftcapslock] Key8=65406:0 Key9=65307:27 Key10=33:33 Key11=34:34 Key12=167:167 Key13=36:36 Key14=37:37 Key15=38:38 Key16=47:47 Key17=40:40 Key18=41:41 Key19=61:61 Key20=63:63 Key21=65104:96 Key22=65288:8 Key23=65056:0 Key24=113:113 Key25=119:119 Key26=101:101 Key27=114:114 Key28=116:116 Key29=122:122 Key30=117:117 Key31=105:105 Key32=111:111 Key33=112:112 Key34=252:252 Key35=42:42 Key36=65293:13 Key37=65507:0 Key38=97:97 Key39=115:115 Key40=100:100 Key41=102:102 Key42=103:103 Key43=104:104 Key44=106:106 Key45=107:107 Key46=108:108 Key47=246:246 Key48=228:228 Key49=176:176 Key50=65505:0 Key51=39:39 Key52=121:121 Key53=120:120 Key54=99:99 Key55=118:118 Key56=98:98 Key57=110:110 Key58=109:109 Key59=59:59 Key60=58:58 Key61=95:95 Key62=65506:0 Key63=65450:42 Key64=65032:0 Key65=32:32 Key66=65509:0 Key67=65470:0 Key68=65471:0 Key69=65472:0 Key70=65473:0 Key71=65474:0 Key72=65475:0 Key73=65476:0 Key74=65477:0 Key75=65478:0 Key76=65479:0 Key77=65407:0 Key78=65300:0 Key79=65463:55 Key80=65464:56 Key81=65465:57 Key82=65453:45 Key83=65460:52 Key84=65461:53 Key85=65462:54 Key86=65451:43 Key87=65457:49 Key88=65458:50 Key89=65459:51 Key90=65456:48 Key91=65452:44 Key92=65377:0 Key93=0:0 Key94=62:62 Key95=65480:0 Key96=65481:0 Key97=65360:0 Key98=65362:0 Key99=65365:0 Key100=65361:0 Key101=0:0 Key102=65363:0 Key103=65367:0 Key104=65364:0 Key105=65366:0 Key106=65379:0 Key107=65535:127 Key108=65421:13 Key109=65508:0 Key110=65299:0 Key111=65377:0 Key112=65455:47 Key113=65027:0 Key114=269025049:0 Key115=65515:0 Key116=65312:0 Key117=0:0 Key118=269025153:0 Key119=269025093:0 Key120=269025094:0 Key121=269025095:0 Key122=269025096:0 Key123=0:0 Key124=65027:0 Key125=65513:0 Key126=65469:61 Key127=65515:0 Key128=65517:0 Key129=0:0 Key130=0:0 Key131=0:0 Key132=0:0 Key133=0:0 Key134=0:0 Key135=0:0 Key136=0:0 Key137=0:0 xrdp-0.9.5/instfiles/rc.d/000755 001751 001751 00000000000 13220731022 015240 5ustar00metameta000000 000000 xrdp-0.9.5/instfiles/km-00000809.ini000644 001751 001751 00000034400 13127114621 016427 0ustar00metameta000000 000000 [noshift] Key8=65406:0 Key9=65307:27 Key10=49:49 Key11=50:50 Key12=51:51 Key13=52:52 Key14=53:53 Key15=54:54 Key16=55:55 Key17=56:56 Key18=57:57 Key19=48:48 Key20=45:45 Key21=61:61 Key22=65288:8 Key23=65289:9 Key24=113:113 Key25=119:119 Key26=101:101 Key27=114:114 Key28=116:116 Key29=121:121 Key30=117:117 Key31=105:105 Key32=111:111 Key33=112:112 Key34=91:91 Key35=93:93 Key36=65293:13 Key37=65507:0 Key38=97:97 Key39=115:115 Key40=100:100 Key41=102:102 Key42=103:103 Key43=104:104 Key44=106:106 Key45=107:107 Key46=108:108 Key47=59:59 Key48=39:39 Key49=96:96 Key50=65505:0 Key51=35:35 Key52=122:122 Key53=120:120 Key54=99:99 Key55=118:118 Key56=98:98 Key57=110:110 Key58=109:109 Key59=44:44 Key60=46:46 Key61=47:47 Key62=65506:0 Key63=65450:42 Key64=65513:0 Key65=32:32 Key66=65509:0 Key67=65470:0 Key68=65471:0 Key69=65472:0 Key70=65473:0 Key71=65474:0 Key72=65475:0 Key73=65476:0 Key74=65477:0 Key75=65478:0 Key76=65479:0 Key77=65407:0 Key78=65300:0 Key79=65429:0 Key80=65431:0 Key81=65434:0 Key82=65453:45 Key83=65430:0 Key84=65437:0 Key85=65432:0 Key86=65451:43 Key87=65436:0 Key88=65433:0 Key89=65435:0 Key90=65438:0 Key91=65439:0 Key92=65377:0 Key93=0:0 Key94=92:92 Key95=65480:0 Key96=65481:0 Key97=65360:0 Key98=65362:0 Key99=65365:0 Key100=65361:0 Key101=0:0 Key102=65363:0 Key103=65367:0 Key104=65364:0 Key105=65366:0 Key106=65379:0 Key107=65535:127 Key108=65421:13 Key109=65508:0 Key110=65299:0 Key111=65377:0 Key112=65455:47 Key113=65027:0 Key114=269025049:0 Key115=65515:0 Key116=65516:0 Key117=0:0 Key118=269025153:0 Key119=269025093:0 Key120=269025094:0 Key121=269025095:0 Key122=269025096:0 Key123=0:0 Key124=65027:0 Key125=0:0 Key126=65469:61 Key127=0:0 Key128=0:0 Key129=0:0 Key130=0:0 Key131=0:0 Key132=0:0 Key133=0:0 Key134=0:0 Key135=0:0 Key136=0:0 Key137=0:0 [shift] Key8=65406:0 Key9=65307:27 Key10=33:33 Key11=34:34 Key12=163:163 Key13=36:36 Key14=37:37 Key15=94:94 Key16=38:38 Key17=42:42 Key18=40:40 Key19=41:41 Key20=95:95 Key21=43:43 Key22=65288:8 Key23=65056:0 Key24=81:81 Key25=87:87 Key26=69:69 Key27=82:82 Key28=84:84 Key29=89:89 Key30=85:85 Key31=73:73 Key32=79:79 Key33=80:80 Key34=123:123 Key35=125:125 Key36=65293:13 Key37=65507:0 Key38=65:65 Key39=83:83 Key40=68:68 Key41=70:70 Key42=71:71 Key43=72:72 Key44=74:74 Key45=75:75 Key46=76:76 Key47=58:58 Key48=64:64 Key49=172:172 Key50=65505:0 Key51=126:126 Key52=90:90 Key53=88:88 Key54=67:67 Key55=86:86 Key56=66:66 Key57=78:78 Key58=77:77 Key59=60:60 Key60=62:62 Key61=63:63 Key62=65506:0 Key63=65450:42 Key64=65511:0 Key65=32:32 Key66=65509:0 Key67=65470:0 Key68=65471:0 Key69=65472:0 Key70=65473:0 Key71=65474:0 Key72=65475:0 Key73=65476:0 Key74=65477:0 Key75=65478:0 Key76=65479:0 Key77=65407:0 Key78=65300:0 Key79=65463:55 Key80=65464:56 Key81=65465:57 Key82=65453:45 Key83=65460:52 Key84=65461:53 Key85=65462:54 Key86=65451:43 Key87=65457:49 Key88=65458:50 Key89=65459:51 Key90=65456:48 Key91=65454:46 Key92=65377:0 Key93=0:0 Key94=124:124 Key95=65480:0 Key96=65481:0 Key97=65360:0 Key98=65362:0 Key99=65365:0 Key100=65361:0 Key101=0:0 Key102=65363:0 Key103=65367:0 Key104=65364:0 Key105=65366:0 Key106=65379:0 Key107=65535:127 Key108=65421:13 Key109=65508:0 Key110=65299:0 Key111=65377:0 Key112=65455:47 Key113=65312:0 Key114=269025049:0 Key115=65515:0 Key116=65516:0 Key117=0:0 Key118=269025153:0 Key119=269025093:0 Key120=269025094:0 Key121=269025095:0 Key122=269025096:0 Key123=0:0 Key124=65027:0 Key125=65513:0 Key126=65469:61 Key127=65515:0 Key128=65517:0 Key129=0:0 Key130=0:0 Key131=0:0 Key132=0:0 Key133=0:0 Key134=0:0 Key135=0:0 Key136=0:0 Key137=0:0 [altgr] Key8=65406:0 Key9=65307:27 Key10=185:185 Key11=178:178 Key12=179:179 Key13=8364:8364 Key14=189:189 Key15=190:190 Key16=123:123 Key17=91:91 Key18=93:93 Key19=125:125 Key20=92:92 Key21=65115:184 Key22=65288:8 Key23=65289:9 Key24=64:64 Key25=435:322 Key26=101:101 Key27=182:182 Key28=956:359 Key29=2299:8592 Key30=2302:8595 Key31=2301:8594 Key32=248:248 Key33=254:254 Key34=65111:168 Key35=65107:126 Key36=65293:13 Key37=65507:0 Key38=230:230 Key39=223:223 Key40=240:240 Key41=496:273 Key42=959:331 Key43=689:295 Key44=65121:0 Key45=930:312 Key46=435:322 Key47=65105:180 Key48=65106:94 Key49=124:124 Key50=65505:0 Key51=65104:96 Key52=171:171 Key53=187:187 Key54=162:162 Key55=2770:8220 Key56=2771:8221 Key57=110:110 Key58=181:181 Key59=2211:0 Key60=183:183 Key61=65120:0 Key62=65506:0 Key63=65450:42 Key64=65513:0 Key65=32:32 Key66=65509:0 Key67=65470:0 Key68=65471:0 Key69=65472:0 Key70=65473:0 Key71=65474:0 Key72=65475:0 Key73=65476:0 Key74=65477:0 Key75=65478:0 Key76=65479:0 Key77=65407:0 Key78=65300:0 Key79=65429:0 Key80=65431:0 Key81=65434:0 Key82=65453:45 Key83=65430:0 Key84=65437:0 Key85=65432:0 Key86=65451:43 Key87=65436:0 Key88=65433:0 Key89=65435:0 Key90=65438:0 Key91=65439:0 Key92=65377:0 Key93=0:0 Key94=124:124 Key95=65480:0 Key96=65481:0 Key97=65360:0 Key98=65362:0 Key99=65365:0 Key100=65361:0 Key101=0:0 Key102=65363:0 Key103=65367:0 Key104=65364:0 Key105=65366:0 Key106=65379:0 Key107=65535:127 Key108=65421:13 Key109=65508:0 Key110=65299:0 Key111=65377:0 Key112=65455:47 Key113=65027:0 Key114=269025049:0 Key115=65515:0 Key116=65516:0 Key117=0:0 Key118=269025153:0 Key119=269025093:0 Key120=269025094:0 Key121=269025095:0 Key122=269025096:0 Key123=0:0 Key124=65027:0 Key125=0:0 Key126=65469:61 Key127=0:0 Key128=0:0 Key129=0:0 Key130=0:0 Key131=0:0 Key132=0:0 Key133=0:0 Key134=0:0 Key135=0:0 Key136=0:0 Key137=0:0 [shiftaltgr] Key8=65406:0 Key9=65307:27 Key10=161:161 Key11=2755:8539 Key12=163:163 Key13=188:188 Key14=2756:8540 Key15=2757:8541 Key16=2758:8542 Key17=2761:8482 Key18=177:177 Key19=176:176 Key20=191:191 Key21=65116:731 Key22=65288:8 Key23=65056:0 Key24=2009:937 Key25=419:321 Key26=69:69 Key27=174:174 Key28=940:358 Key29=165:165 Key30=2300:8593 Key31=697:305 Key32=216:216 Key33=222:222 Key34=65112:176 Key35=65108:175 Key36=65293:13 Key37=65507:0 Key38=198:198 Key39=167:167 Key40=208:208 Key41=170:170 Key42=957:330 Key43=673:294 Key44=65122:0 Key45=38:38 Key46=419:321 Key47=65113:733 Key48=65114:711 Key49=124:124 Key50=65505:0 Key51=65109:728 Key52=60:60 Key53=62:62 Key54=169:169 Key55=2768:8216 Key56=2769:8217 Key57=78:78 Key58=186:186 Key59=215:215 Key60=247:247 Key61=65110:729 Key62=65506:0 Key63=65450:42 Key64=65511:0 Key65=32:32 Key66=65509:0 Key67=65470:0 Key68=65471:0 Key69=65472:0 Key70=65473:0 Key71=65474:0 Key72=65475:0 Key73=65476:0 Key74=65477:0 Key75=65478:0 Key76=65479:0 Key77=65407:0 Key78=65300:0 Key79=65463:55 Key80=65464:56 Key81=65465:57 Key82=65453:45 Key83=65460:52 Key84=65461:53 Key85=65462:54 Key86=65451:43 Key87=65457:49 Key88=65458:50 Key89=65459:51 Key90=65456:48 Key91=65454:46 Key92=65377:0 Key93=0:0 Key94=166:166 Key95=65480:0 Key96=65481:0 Key97=65360:0 Key98=65362:0 Key99=65365:0 Key100=65361:0 Key101=0:0 Key102=65363:0 Key103=65367:0 Key104=65364:0 Key105=65366:0 Key106=65379:0 Key107=65535:127 Key108=65421:13 Key109=65508:0 Key110=65299:0 Key111=65377:0 Key112=65455:47 Key113=65312:0 Key114=269025049:0 Key115=65515:0 Key116=65516:0 Key117=0:0 Key118=269025153:0 Key119=269025093:0 Key120=269025094:0 Key121=269025095:0 Key122=269025096:0 Key123=0:0 Key124=65027:0 Key125=65513:0 Key126=65469:61 Key127=65515:0 Key128=65517:0 Key129=0:0 Key130=0:0 Key131=0:0 Key132=0:0 Key133=0:0 Key134=0:0 Key135=0:0 Key136=0:0 Key137=0:0 [capslock] Key8=65406:0 Key9=65307:27 Key10=49:49 Key11=50:50 Key12=51:51 Key13=52:52 Key14=53:53 Key15=54:54 Key16=55:55 Key17=56:56 Key18=57:57 Key19=48:48 Key20=45:45 Key21=61:61 Key22=65288:8 Key23=65289:9 Key24=81:81 Key25=87:87 Key26=69:69 Key27=82:82 Key28=84:84 Key29=89:89 Key30=85:85 Key31=73:73 Key32=79:79 Key33=80:80 Key34=91:91 Key35=93:93 Key36=65293:13 Key37=65507:0 Key38=65:65 Key39=83:83 Key40=68:68 Key41=70:70 Key42=71:71 Key43=72:72 Key44=74:74 Key45=75:75 Key46=76:76 Key47=59:59 Key48=39:39 Key49=96:96 Key50=65505:0 Key51=35:35 Key52=90:90 Key53=88:88 Key54=67:67 Key55=86:86 Key56=66:66 Key57=78:78 Key58=77:77 Key59=44:44 Key60=46:46 Key61=47:47 Key62=65506:0 Key63=65450:42 Key64=65513:0 Key65=32:32 Key66=65509:0 Key67=65470:0 Key68=65471:0 Key69=65472:0 Key70=65473:0 Key71=65474:0 Key72=65475:0 Key73=65476:0 Key74=65477:0 Key75=65478:0 Key76=65479:0 Key77=65407:0 Key78=65300:0 Key79=65429:0 Key80=65431:0 Key81=65434:0 Key82=65453:45 Key83=65430:0 Key84=65437:0 Key85=65432:0 Key86=65451:43 Key87=65436:0 Key88=65433:0 Key89=65435:0 Key90=65438:0 Key91=65439:0 Key92=65377:0 Key93=0:0 Key94=92:92 Key95=65480:0 Key96=65481:0 Key97=65360:0 Key98=65362:0 Key99=65365:0 Key100=65361:0 Key101=0:0 Key102=65363:0 Key103=65367:0 Key104=65364:0 Key105=65366:0 Key106=65379:0 Key107=65535:127 Key108=65421:13 Key109=65508:0 Key110=65299:0 Key111=65377:0 Key112=65455:47 Key113=65027:0 Key114=269025049:0 Key115=65515:0 Key116=65516:0 Key117=0:0 Key118=269025153:0 Key119=269025093:0 Key120=269025094:0 Key121=269025095:0 Key122=269025096:0 Key123=0:0 Key124=65027:0 Key125=0:0 Key126=65469:61 Key127=0:0 Key128=0:0 Key129=0:0 Key130=0:0 Key131=0:0 Key132=0:0 Key133=0:0 Key134=0:0 Key135=0:0 Key136=0:0 Key137=0:0 [capslockaltgr] Key8=65406:0 Key9=65307:27 Key10=185:185 Key11=178:178 Key12=179:179 Key13=8364:8364 Key14=189:189 Key15=190:190 Key16=123:123 Key17=91:91 Key18=93:93 Key19=125:125 Key20=92:92 Key21=65115:184 Key22=65288:8 Key23=65289:9 Key24=64:64 Key25=419:321 Key26=69:69 Key27=182:182 Key28=940:358 Key29=2299:8592 Key30=2302:8595 Key31=2301:8594 Key32=216:216 Key33=222:222 Key34=65111:168 Key35=65107:126 Key36=65293:13 Key37=65507:0 Key38=198:198 Key39=223:223 Key40=208:208 Key41=464:272 Key42=957:330 Key43=673:294 Key44=65121:0 Key45=930:312 Key46=419:321 Key47=65105:180 Key48=65106:94 Key49=124:124 Key50=65505:0 Key51=65104:96 Key52=171:171 Key53=187:187 Key54=162:162 Key55=2770:8220 Key56=2771:8221 Key57=78:78 Key58=924:0 Key59=2211:0 Key60=183:183 Key61=65120:0 Key62=65506:0 Key63=65450:42 Key64=65513:0 Key65=32:32 Key66=65509:0 Key67=65470:0 Key68=65471:0 Key69=65472:0 Key70=65473:0 Key71=65474:0 Key72=65475:0 Key73=65476:0 Key74=65477:0 Key75=65478:0 Key76=65479:0 Key77=65407:0 Key78=65300:0 Key79=65429:0 Key80=65431:0 Key81=65434:0 Key82=65453:45 Key83=65430:0 Key84=65437:0 Key85=65432:0 Key86=65451:43 Key87=65436:0 Key88=65433:0 Key89=65435:0 Key90=65438:0 Key91=65439:0 Key92=65377:0 Key93=0:0 Key94=124:124 Key95=65480:0 Key96=65481:0 Key97=65360:0 Key98=65362:0 Key99=65365:0 Key100=65361:0 Key101=0:0 Key102=65363:0 Key103=65367:0 Key104=65364:0 Key105=65366:0 Key106=65379:0 Key107=65535:127 Key108=65421:13 Key109=65508:0 Key110=65299:0 Key111=65377:0 Key112=65455:47 Key113=65027:0 Key114=269025049:0 Key115=65515:0 Key116=65516:0 Key117=0:0 Key118=269025153:0 Key119=269025093:0 Key120=269025094:0 Key121=269025095:0 Key122=269025096:0 Key123=0:0 Key124=65027:0 Key125=0:0 Key126=65469:61 Key127=0:0 Key128=0:0 Key129=0:0 Key130=0:0 Key131=0:0 Key132=0:0 Key133=0:0 Key134=0:0 Key135=0:0 Key136=0:0 Key137=0:0 [shiftcapslock] Key8=65406:0 Key9=65307:27 Key10=33:33 Key11=34:34 Key12=163:163 Key13=36:36 Key14=37:37 Key15=94:94 Key16=38:38 Key17=42:42 Key18=40:40 Key19=41:41 Key20=95:95 Key21=43:43 Key22=65288:8 Key23=65056:0 Key24=113:113 Key25=119:119 Key26=101:101 Key27=114:114 Key28=116:116 Key29=121:121 Key30=117:117 Key31=105:105 Key32=111:111 Key33=112:112 Key34=123:123 Key35=125:125 Key36=65293:13 Key37=65507:0 Key38=97:97 Key39=115:115 Key40=100:100 Key41=102:102 Key42=103:103 Key43=104:104 Key44=106:106 Key45=107:107 Key46=108:108 Key47=58:58 Key48=64:64 Key49=172:172 Key50=65505:0 Key51=126:126 Key52=122:122 Key53=120:120 Key54=99:99 Key55=118:118 Key56=98:98 Key57=110:110 Key58=109:109 Key59=60:60 Key60=62:62 Key61=63:63 Key62=65506:0 Key63=65450:42 Key64=65511:0 Key65=32:32 Key66=65509:0 Key67=65470:0 Key68=65471:0 Key69=65472:0 Key70=65473:0 Key71=65474:0 Key72=65475:0 Key73=65476:0 Key74=65477:0 Key75=65478:0 Key76=65479:0 Key77=65407:0 Key78=65300:0 Key79=65463:55 Key80=65464:56 Key81=65465:57 Key82=65453:45 Key83=65460:52 Key84=65461:53 Key85=65462:54 Key86=65451:43 Key87=65457:49 Key88=65458:50 Key89=65459:51 Key90=65456:48 Key91=65454:46 Key92=65377:0 Key93=0:0 Key94=124:124 Key95=65480:0 Key96=65481:0 Key97=65360:0 Key98=65362:0 Key99=65365:0 Key100=65361:0 Key101=0:0 Key102=65363:0 Key103=65367:0 Key104=65364:0 Key105=65366:0 Key106=65379:0 Key107=65535:127 Key108=65421:13 Key109=65508:0 Key110=65299:0 Key111=65377:0 Key112=65455:47 Key113=65312:0 Key114=269025049:0 Key115=65515:0 Key116=65516:0 Key117=0:0 Key118=269025153:0 Key119=269025093:0 Key120=269025094:0 Key121=269025095:0 Key122=269025096:0 Key123=0:0 Key124=65027:0 Key125=65513:0 Key126=65469:61 Key127=65515:0 Key128=65517:0 Key129=0:0 Key130=0:0 Key131=0:0 Key132=0:0 Key133=0:0 Key134=0:0 Key135=0:0 Key136=0:0 Key137=0:0 [shiftcapslockaltgr] Key8=65406:0 Key9=65307:27 Key10=161:161 Key11=2755:8539 Key12=163:163 Key13=188:188 Key14=2756:8540 Key15=2757:8541 Key16=2758:8542 Key17=2761:8482 Key18=177:177 Key19=176:176 Key20=191:191 Key21=65116:731 Key22=65288:8 Key23=65056:0 Key24=2009:937 Key25=435:322 Key26=101:101 Key27=174:174 Key28=956:359 Key29=165:165 Key30=2300:8593 Key31=697:305 Key32=248:248 Key33=254:254 Key34=65112:176 Key35=65108:175 Key36=65293:13 Key37=65507:0 Key38=230:230 Key39=167:167 Key40=240:240 Key41=170:170 Key42=959:331 Key43=689:295 Key44=65122:0 Key45=38:38 Key46=435:322 Key47=65113:733 Key48=65114:711 Key49=124:124 Key50=65505:0 Key51=65109:728 Key52=60:60 Key53=62:62 Key54=169:169 Key55=2768:8216 Key56=2769:8217 Key57=110:110 Key58=186:186 Key59=215:215 Key60=247:247 Key61=65110:729 Key62=65506:0 Key63=65450:42 Key64=65511:0 Key65=32:32 Key66=65509:0 Key67=65470:0 Key68=65471:0 Key69=65472:0 Key70=65473:0 Key71=65474:0 Key72=65475:0 Key73=65476:0 Key74=65477:0 Key75=65478:0 Key76=65479:0 Key77=65407:0 Key78=65300:0 Key79=65463:55 Key80=65464:56 Key81=65465:57 Key82=65453:45 Key83=65460:52 Key84=65461:53 Key85=65462:54 Key86=65451:43 Key87=65457:49 Key88=65458:50 Key89=65459:51 Key90=65456:48 Key91=65454:46 Key92=65377:0 Key93=0:0 Key94=166:166 Key95=65480:0 Key96=65481:0 Key97=65360:0 Key98=65362:0 Key99=65365:0 Key100=65361:0 Key101=0:0 Key102=65363:0 Key103=65367:0 Key104=65364:0 Key105=65366:0 Key106=65379:0 Key107=65535:127 Key108=65421:13 Key109=65508:0 Key110=65299:0 Key111=65377:0 Key112=65455:47 Key113=65312:0 Key114=269025049:0 Key115=65515:0 Key116=65516:0 Key117=0:0 Key118=269025153:0 Key119=269025093:0 Key120=269025094:0 Key121=269025095:0 Key122=269025096:0 Key123=0:0 Key124=65027:0 Key125=65513:0 Key126=65469:61 Key127=65515:0 Key128=65517:0 Key129=0:0 Key130=0:0 Key131=0:0 Key132=0:0 Key133=0:0 Key134=0:0 Key135=0:0 Key136=0:0 Key137=0:0 xrdp-0.9.5/instfiles/default/000755 001751 001751 00000000000 13220731022 016036 5ustar00metameta000000 000000 xrdp-0.9.5/instfiles/km-00000409.ini000644 001751 001751 00000024662 13127114621 016434 0ustar00metameta000000 000000 [noshift] Key8=65406:0 Key9=65307:27 Key10=49:49 Key11=50:50 Key12=51:51 Key13=52:52 Key14=53:53 Key15=54:54 Key16=55:55 Key17=56:56 Key18=57:57 Key19=48:48 Key20=45:45 Key21=61:61 Key22=65288:8 Key23=65289:9 Key24=113:113 Key25=119:119 Key26=101:101 Key27=114:114 Key28=116:116 Key29=121:121 Key30=117:117 Key31=105:105 Key32=111:111 Key33=112:112 Key34=91:91 Key35=93:93 Key36=65293:13 Key37=65507:0 Key38=97:97 Key39=115:115 Key40=100:100 Key41=102:102 Key42=103:103 Key43=104:104 Key44=106:106 Key45=107:107 Key46=108:108 Key47=59:59 Key48=39:39 Key49=96:96 Key50=65505:0 Key51=92:92 Key52=122:122 Key53=120:120 Key54=99:99 Key55=118:118 Key56=98:98 Key57=110:110 Key58=109:109 Key59=44:44 Key60=46:46 Key61=47:47 Key62=65506:0 Key63=65450:42 Key64=65513:0 Key65=32:32 Key66=65509:0 Key67=65470:0 Key68=65471:0 Key69=65472:0 Key70=65473:0 Key71=65474:0 Key72=65475:0 Key73=65476:0 Key74=65477:0 Key75=65478:0 Key76=65479:0 Key77=65407:0 Key78=65300:0 Key79=65429:0 Key80=65431:0 Key81=65434:0 Key82=65453:45 Key83=65430:0 Key84=65437:0 Key85=65432:0 Key86=65451:43 Key87=65436:0 Key88=65433:0 Key89=65435:0 Key90=65438:0 Key91=65439:0 Key92=65377:0 Key93=0:0 Key94=60:60 Key95=65480:0 Key96=65481:0 Key97=65360:0 Key98=65362:0 Key99=65365:0 Key100=65361:0 Key101=0:0 Key102=65363:0 Key103=65367:0 Key104=65364:0 Key105=65366:0 Key106=65379:0 Key107=65535:127 Key108=65421:13 Key109=65508:0 Key110=65299:0 Key111=65377:0 Key112=65455:47 Key113=65514:0 Key114=269025049:0 Key115=65515:0 Key116=65312:0 Key117=0:0 Key118=269025153:0 Key119=269025093:0 Key120=269025094:0 Key121=269025095:0 Key122=269025096:0 Key123=0:0 Key124=65027:0 Key125=0:0 Key126=65469:61 Key127=0:0 Key128=0:0 Key129=0:0 Key130=0:0 Key131=0:0 Key132=0:0 Key133=0:0 Key134=0:0 Key135=0:0 Key136=0:0 Key137=0:0 [shift] Key8=65406:0 Key9=65307:27 Key10=33:33 Key11=64:64 Key12=35:35 Key13=36:36 Key14=37:37 Key15=94:94 Key16=38:38 Key17=42:42 Key18=40:40 Key19=41:41 Key20=95:95 Key21=43:43 Key22=65288:8 Key23=65056:0 Key24=81:81 Key25=87:87 Key26=69:69 Key27=82:82 Key28=84:84 Key29=89:89 Key30=85:85 Key31=73:73 Key32=79:79 Key33=80:80 Key34=123:123 Key35=125:125 Key36=65293:13 Key37=65507:0 Key38=65:65 Key39=83:83 Key40=68:68 Key41=70:70 Key42=71:71 Key43=72:72 Key44=74:74 Key45=75:75 Key46=76:76 Key47=58:58 Key48=34:34 Key49=126:126 Key50=65505:0 Key51=124:124 Key52=90:90 Key53=88:88 Key54=67:67 Key55=86:86 Key56=66:66 Key57=78:78 Key58=77:77 Key59=60:60 Key60=62:62 Key61=63:63 Key62=65506:0 Key63=65450:42 Key64=65032:0 Key65=32:32 Key66=65509:0 Key67=65470:0 Key68=65471:0 Key69=65472:0 Key70=65473:0 Key71=65474:0 Key72=65475:0 Key73=65476:0 Key74=65477:0 Key75=65478:0 Key76=65479:0 Key77=65407:0 Key78=65300:0 Key79=65463:55 Key80=65464:56 Key81=65465:57 Key82=65453:45 Key83=65460:52 Key84=65461:53 Key85=65462:54 Key86=65451:43 Key87=65457:49 Key88=65458:50 Key89=65459:51 Key90=65456:48 Key91=65454:46 Key92=65377:0 Key93=0:0 Key94=62:62 Key95=65480:0 Key96=65481:0 Key97=65360:0 Key98=65362:0 Key99=65365:0 Key100=65361:0 Key101=0:0 Key102=65363:0 Key103=65367:0 Key104=65364:0 Key105=65366:0 Key106=65379:0 Key107=65535:127 Key108=65421:13 Key109=65508:0 Key110=65299:0 Key111=65377:0 Key112=65455:47 Key113=65032:0 Key114=269025049:0 Key115=65515:0 Key116=65312:0 Key117=0:0 Key118=269025153:0 Key119=269025093:0 Key120=269025094:0 Key121=269025095:0 Key122=269025096:0 Key123=0:0 Key124=65027:0 Key125=65513:0 Key126=65469:61 Key127=65515:0 Key128=65517:0 Key129=0:0 Key130=0:0 Key131=0:0 Key132=0:0 Key133=0:0 Key134=0:0 Key135=0:0 Key136=0:0 Key137=0:0 [altgr] Key8=65406:0 Key9=65307:27 Key10=49:49 Key11=50:50 Key12=51:51 Key13=52:52 Key14=53:53 Key15=54:54 Key16=55:55 Key17=56:56 Key18=57:57 Key19=48:48 Key20=45:45 Key21=61:61 Key22=65288:8 Key23=65289:9 Key24=113:113 Key25=119:119 Key26=101:101 Key27=114:114 Key28=116:116 Key29=121:121 Key30=117:117 Key31=105:105 Key32=111:111 Key33=112:112 Key34=91:91 Key35=93:93 Key36=65293:13 Key37=65507:0 Key38=97:97 Key39=115:115 Key40=100:100 Key41=102:102 Key42=103:103 Key43=104:104 Key44=106:106 Key45=107:107 Key46=108:108 Key47=59:59 Key48=39:39 Key49=96:96 Key50=65505:0 Key51=92:92 Key52=122:122 Key53=120:120 Key54=99:99 Key55=118:118 Key56=98:98 Key57=110:110 Key58=109:109 Key59=44:44 Key60=46:46 Key61=47:47 Key62=65506:0 Key63=65450:42 Key64=65513:0 Key65=32:32 Key66=65509:0 Key67=65470:0 Key68=65471:0 Key69=65472:0 Key70=65473:0 Key71=65474:0 Key72=65475:0 Key73=65476:0 Key74=65477:0 Key75=65478:0 Key76=65479:0 Key77=65407:0 Key78=65300:0 Key79=65429:0 Key80=65431:0 Key81=65434:0 Key82=65453:45 Key83=65430:0 Key84=65437:0 Key85=65432:0 Key86=65451:43 Key87=65436:0 Key88=65433:0 Key89=65435:0 Key90=65438:0 Key91=65439:0 Key92=65377:0 Key93=0:0 Key94=124:124 Key95=65480:0 Key96=65481:0 Key97=65360:0 Key98=65362:0 Key99=65365:0 Key100=65361:0 Key101=0:0 Key102=65363:0 Key103=65367:0 Key104=65364:0 Key105=65366:0 Key106=65379:0 Key107=65535:127 Key108=65421:13 Key109=65508:0 Key110=65299:0 Key111=65377:0 Key112=65455:47 Key113=65514:0 Key114=269025049:0 Key115=65515:0 Key116=65312:0 Key117=0:0 Key118=269025153:0 Key119=269025093:0 Key120=269025094:0 Key121=269025095:0 Key122=269025096:0 Key123=0:0 Key124=65027:0 Key125=0:0 Key126=65469:61 Key127=0:0 Key128=0:0 Key129=0:0 Key130=0:0 Key131=0:0 Key132=0:0 Key133=0:0 Key134=0:0 Key135=0:0 Key136=0:0 Key137=0:0 [shiftaltgr] Key8=65406:0 Key9=65307:27 Key10=33:33 Key11=64:64 Key12=35:35 Key13=36:36 Key14=37:37 Key15=94:94 Key16=38:38 Key17=42:42 Key18=40:40 Key19=41:41 Key20=95:95 Key21=43:43 Key22=65288:8 Key23=65056:0 Key24=81:81 Key25=87:87 Key26=69:69 Key27=82:82 Key28=84:84 Key29=89:89 Key30=85:85 Key31=73:73 Key32=79:79 Key33=80:80 Key34=123:123 Key35=125:125 Key36=65293:13 Key37=65507:0 Key38=65:65 Key39=83:83 Key40=68:68 Key41=70:70 Key42=71:71 Key43=72:72 Key44=74:74 Key45=75:75 Key46=76:76 Key47=58:58 Key48=34:34 Key49=126:126 Key50=65505:0 Key51=124:124 Key52=90:90 Key53=88:88 Key54=67:67 Key55=86:86 Key56=66:66 Key57=78:78 Key58=77:77 Key59=60:60 Key60=62:62 Key61=63:63 Key62=65506:0 Key63=65450:42 Key64=65032:0 Key65=32:32 Key66=65509:0 Key67=65470:0 Key68=65471:0 Key69=65472:0 Key70=65473:0 Key71=65474:0 Key72=65475:0 Key73=65476:0 Key74=65477:0 Key75=65478:0 Key76=65479:0 Key77=65407:0 Key78=65300:0 Key79=65463:55 Key80=65464:56 Key81=65465:57 Key82=65453:45 Key83=65460:52 Key84=65461:53 Key85=65462:54 Key86=65451:43 Key87=65457:49 Key88=65458:50 Key89=65459:51 Key90=65456:48 Key91=65454:46 Key92=65377:0 Key93=0:0 Key94=166:166 Key95=65480:0 Key96=65481:0 Key97=65360:0 Key98=65362:0 Key99=65365:0 Key100=65361:0 Key101=0:0 Key102=65363:0 Key103=65367:0 Key104=65364:0 Key105=65366:0 Key106=65379:0 Key107=65535:127 Key108=65421:13 Key109=65508:0 Key110=65299:0 Key111=65377:0 Key112=65455:47 Key113=65032:0 Key114=269025049:0 Key115=65515:0 Key116=65312:0 Key117=0:0 Key118=269025153:0 Key119=269025093:0 Key120=269025094:0 Key121=269025095:0 Key122=269025096:0 Key123=0:0 Key124=65027:0 Key125=65513:0 Key126=65469:61 Key127=65515:0 Key128=65517:0 Key129=0:0 Key130=0:0 Key131=0:0 Key132=0:0 Key133=0:0 Key134=0:0 Key135=0:0 Key136=0:0 Key137=0:0 [capslock] Key8=65406:0 Key9=65307:27 Key10=49:49 Key11=50:50 Key12=51:51 Key13=52:52 Key14=53:53 Key15=54:54 Key16=55:55 Key17=56:56 Key18=57:57 Key19=48:48 Key20=45:45 Key21=61:61 Key22=65288:8 Key23=65289:9 Key24=81:81 Key25=87:87 Key26=69:69 Key27=82:82 Key28=84:84 Key29=89:89 Key30=85:85 Key31=73:73 Key32=79:79 Key33=80:80 Key34=91:91 Key35=93:93 Key36=65293:13 Key37=65507:0 Key38=65:65 Key39=83:83 Key40=68:68 Key41=70:70 Key42=71:71 Key43=72:72 Key44=74:74 Key45=75:75 Key46=76:76 Key47=59:59 Key48=39:39 Key49=96:96 Key50=65505:0 Key51=92:92 Key52=90:90 Key53=88:88 Key54=67:67 Key55=86:86 Key56=66:66 Key57=78:78 Key58=77:77 Key59=44:44 Key60=46:46 Key61=47:47 Key62=65506:0 Key63=65450:42 Key64=65513:0 Key65=32:32 Key66=65509:0 Key67=65470:0 Key68=65471:0 Key69=65472:0 Key70=65473:0 Key71=65474:0 Key72=65475:0 Key73=65476:0 Key74=65477:0 Key75=65478:0 Key76=65479:0 Key77=65407:0 Key78=65300:0 Key79=65429:0 Key80=65431:0 Key81=65434:0 Key82=65453:45 Key83=65430:0 Key84=65437:0 Key85=65432:0 Key86=65451:43 Key87=65436:0 Key88=65433:0 Key89=65435:0 Key90=65438:0 Key91=65439:0 Key92=65377:0 Key93=0:0 Key94=60:60 Key95=65480:0 Key96=65481:0 Key97=65360:0 Key98=65362:0 Key99=65365:0 Key100=65361:0 Key101=0:0 Key102=65363:0 Key103=65367:0 Key104=65364:0 Key105=65366:0 Key106=65379:0 Key107=65535:127 Key108=65421:13 Key109=65508:0 Key110=65299:0 Key111=65377:0 Key112=65455:47 Key113=65514:0 Key114=269025049:0 Key115=65515:0 Key116=65312:0 Key117=0:0 Key118=269025153:0 Key119=269025093:0 Key120=269025094:0 Key121=269025095:0 Key122=269025096:0 Key123=0:0 Key124=65027:0 Key125=0:0 Key126=65469:61 Key127=0:0 Key128=0:0 Key129=0:0 Key130=0:0 Key131=0:0 Key132=0:0 Key133=0:0 Key134=0:0 Key135=0:0 Key136=0:0 Key137=0:0 [shiftcapslock] Key8=65406:0 Key9=65307:27 Key10=33:33 Key11=64:64 Key12=35:35 Key13=36:36 Key14=37:37 Key15=94:94 Key16=38:38 Key17=42:42 Key18=40:40 Key19=41:41 Key20=95:95 Key21=43:43 Key22=65288:8 Key23=65056:0 Key24=113:113 Key25=119:119 Key26=101:101 Key27=114:114 Key28=116:116 Key29=121:121 Key30=117:117 Key31=105:105 Key32=111:111 Key33=112:112 Key34=123:123 Key35=125:125 Key36=65293:13 Key37=65507:0 Key38=97:97 Key39=115:115 Key40=100:100 Key41=102:102 Key42=103:103 Key43=104:104 Key44=106:106 Key45=107:107 Key46=108:108 Key47=58:58 Key48=34:34 Key49=126:126 Key50=65505:0 Key51=124:124 Key52=122:122 Key53=120:120 Key54=99:99 Key55=118:118 Key56=98:98 Key57=110:110 Key58=109:109 Key59=60:60 Key60=62:62 Key61=63:63 Key62=65506:0 Key63=65450:42 Key64=65032:0 Key65=32:32 Key66=65509:0 Key67=65470:0 Key68=65471:0 Key69=65472:0 Key70=65473:0 Key71=65474:0 Key72=65475:0 Key73=65476:0 Key74=65477:0 Key75=65478:0 Key76=65479:0 Key77=65407:0 Key78=65300:0 Key79=65463:55 Key80=65464:56 Key81=65465:57 Key82=65453:45 Key83=65460:52 Key84=65461:53 Key85=65462:54 Key86=65451:43 Key87=65457:49 Key88=65458:50 Key89=65459:51 Key90=65456:48 Key91=65454:46 Key92=65377:0 Key93=0:0 Key94=62:62 Key95=65480:0 Key96=65481:0 Key97=65360:0 Key98=65362:0 Key99=65365:0 Key100=65361:0 Key101=0:0 Key102=65363:0 Key103=65367:0 Key104=65364:0 Key105=65366:0 Key106=65379:0 Key107=65535:127 Key108=65421:13 Key109=65508:0 Key110=65299:0 Key111=65377:0 Key112=65455:47 Key113=65032:0 Key114=269025049:0 Key115=65515:0 Key116=65312:0 Key117=0:0 Key118=269025153:0 Key119=269025093:0 Key120=269025094:0 Key121=269025095:0 Key122=269025096:0 Key123=0:0 Key124=65027:0 Key125=65513:0 Key126=65469:61 Key127=65515:0 Key128=65517:0 Key129=0:0 Key130=0:0 Key131=0:0 Key132=0:0 Key133=0:0 Key134=0:0 Key135=0:0 Key136=0:0 Key137=0:0 xrdp-0.9.5/instfiles/km-00000807.ini000644 001751 001751 00000020762 13127114621 016433 0ustar00metameta000000 000000 [noshift] Key8=0:0 Key9=65307:27 Key10=49:49 Key11=50:50 Key12=51:51 Key13=52:52 Key14=53:53 Key15=54:54 Key16=55:55 Key17=56:56 Key18=57:57 Key19=48:48 Key20=39:39 Key21=65106:94 Key22=65288:8 Key23=65289:9 Key24=113:113 Key25=119:119 Key26=101:101 Key27=114:114 Key28=116:116 Key29=122:122 Key30=117:117 Key31=105:105 Key32=111:111 Key33=112:112 Key34=252:252 Key35=65111:168 Key36=65293:13 Key37=65507:0 Key38=97:97 Key39=115:115 Key40=100:100 Key41=102:102 Key42=103:103 Key43=104:104 Key44=106:106 Key45=107:107 Key46=108:108 Key47=246:246 Key48=228:228 Key49=167:167 Key50=65505:0 Key51=36:36 Key52=121:121 Key53=120:120 Key54=99:99 Key55=118:118 Key56=98:98 Key57=110:110 Key58=109:109 Key59=44:44 Key60=46:46 Key61=45:45 Key62=65506:0 Key63=65450:42 Key64=65513:0 Key65=32:32 Key66=65509:0 Key67=65470:0 Key68=65471:0 Key69=65472:0 Key70=65473:0 Key71=65474:0 Key72=65475:0 Key73=65476:0 Key74=65477:0 Key75=65478:0 Key76=65479:0 Key77=65407:0 Key78=65300:0 Key79=65429:0 Key80=65431:0 Key81=65434:0 Key82=65453:45 Key83=65430:0 Key84=65437:0 Key85=65432:0 Key86=65451:43 Key87=65436:0 Key88=65433:0 Key89=65435:0 Key90=65438:0 Key91=65439:0 Key92=0:0 Key93=65406:0 Key94=60:60 Key95=65480:0 Key96=65481:0 Key97=65360:0 Key98=65362:0 Key99=65365:0 Key100=65361:0 Key101=0:0 Key102=65363:0 Key103=65367:0 Key104=65364:0 Key105=65366:0 Key106=65379:0 Key107=65535:127 Key108=65421:13 Key109=65508:0 Key110=65299:0 Key111=65377:0 Key112=65455:47 Key113=65027:0 Key114=0:0 Key115=0:0 Key116=0:0 Key117=0:0 Key118=0:0 Key119=0:0 Key120=0:0 Key121=0:0 Key122=0:0 Key123=0:0 Key124=65027:0 Key125=0:0 Key126=65469:61 Key127=0:0 Key128=0:0 Key129=0:0 Key130=0:0 Key131=0:0 Key132=0:0 Key133=0:0 Key134=0:0 Key135=0:0 Key136=0:0 Key137=0:0 [shift] Key8=0:0 Key9=65307:27 Key10=43:43 Key11=34:34 Key12=42:42 Key13=231:231 Key14=37:37 Key15=38:38 Key16=47:47 Key17=40:40 Key18=41:41 Key19=61:61 Key20=63:63 Key21=65104:96 Key22=65288:8 Key23=65056:0 Key24=81:81 Key25=87:87 Key26=69:69 Key27=82:82 Key28=84:84 Key29=90:90 Key30=85:85 Key31=73:73 Key32=79:79 Key33=80:80 Key34=232:232 Key35=33:33 Key36=65293:13 Key37=65507:0 Key38=65:65 Key39=83:83 Key40=68:68 Key41=70:70 Key42=71:71 Key43=72:72 Key44=74:74 Key45=75:75 Key46=76:76 Key47=233:233 Key48=224:224 Key49=176:176 Key50=65505:0 Key51=163:163 Key52=89:89 Key53=88:88 Key54=67:67 Key55=86:86 Key56=66:66 Key57=78:78 Key58=77:77 Key59=59:59 Key60=58:58 Key61=95:95 Key62=65506:0 Key63=65450:42 Key64=65511:0 Key65=32:32 Key66=65509:0 Key67=65470:0 Key68=65471:0 Key69=65472:0 Key70=65473:0 Key71=65474:0 Key72=65475:0 Key73=65476:0 Key74=65477:0 Key75=65478:0 Key76=65479:0 Key77=65273:0 Key78=65300:0 Key79=65463:55 Key80=65464:56 Key81=65465:57 Key82=65453:45 Key83=65460:52 Key84=65461:53 Key85=65462:54 Key86=65451:43 Key87=65457:49 Key88=65458:50 Key89=65459:51 Key90=65456:48 Key91=65454:46 Key92=0:0 Key93=65406:0 Key94=62:62 Key95=65480:0 Key96=65481:0 Key97=65360:0 Key98=65362:0 Key99=65365:0 Key100=65361:0 Key101=0:0 Key102=65363:0 Key103=65367:0 Key104=65364:0 Key105=65366:0 Key106=65379:0 Key107=65535:127 Key108=65421:13 Key109=65508:0 Key110=65299:0 Key111=65377:0 Key112=65455:47 Key113=65312:0 Key114=0:0 Key115=0:0 Key116=0:0 Key117=0:0 Key118=0:0 Key119=0:0 Key120=0:0 Key121=0:0 Key122=0:0 Key123=0:0 Key124=65027:0 Key125=65513:0 Key126=65469:61 Key127=65515:0 Key128=65517:0 Key129=0:0 Key130=0:0 Key131=0:0 Key132=0:0 Key133=0:0 Key134=0:0 Key135=0:0 Key136=0:0 Key137=0:0 [altgr] Key8=0:0 Key9=65307:27 Key10=124:124 Key11=64:64 Key12=35:35 Key13=188:188 Key14=189:189 Key15=172:172 Key16=166:166 Key17=162:162 Key18=93:93 Key19=125:125 Key20=65105:180 Key21=65107:126 Key22=65288:8 Key23=65289:9 Key24=64:64 Key25=435:322 Key26=8364:8364 Key27=182:182 Key28=956:359 Key29=2299:8592 Key30=2302:8595 Key31=2301:8594 Key32=248:248 Key33=254:254 Key34=91:91 Key35=93:93 Key36=65293:13 Key37=65507:0 Key38=230:230 Key39=223:223 Key40=240:240 Key41=496:273 Key42=959:331 Key43=689:295 Key44=106:106 Key45=930:312 Key46=435:322 Key47=65105:180 Key48=123:123 Key49=172:172 Key50=65505:0 Key51=125:125 Key52=171:171 Key53=187:187 Key54=162:162 Key55=2770:8220 Key56=2771:8221 Key57=110:110 Key58=181:181 Key59=2211:0 Key60=183:183 Key61=65120:0 Key62=65506:0 Key63=65450:42 Key64=65513:0 Key65=32:32 Key66=65509:0 Key67=65470:0 Key68=65471:0 Key69=65472:0 Key70=65473:0 Key71=65474:0 Key72=65475:0 Key73=65476:0 Key74=65477:0 Key75=65478:0 Key76=65479:0 Key77=65407:0 Key78=65300:0 Key79=65429:0 Key80=65431:0 Key81=65434:0 Key82=65453:45 Key83=65430:0 Key84=65437:0 Key85=65432:0 Key86=65451:43 Key87=65436:0 Key88=65433:0 Key89=65435:0 Key90=65438:0 Key91=65439:0 Key92=0:0 Key93=65406:0 Key94=92:92 Key95=65480:0 Key96=65481:0 Key97=65360:0 Key98=65362:0 Key99=65365:0 Key100=65361:0 Key101=0:0 Key102=65363:0 Key103=65367:0 Key104=65364:0 Key105=65366:0 Key106=65379:0 Key107=65535:127 Key108=65421:13 Key109=65508:0 Key110=65299:0 Key111=0:0 Key112=65455:47 Key113=65027:0 Key114=0:0 Key115=0:0 Key116=0:0 Key117=0:0 Key118=0:0 Key119=0:0 Key120=0:0 Key121=0:0 Key122=0:0 Key123=0:0 Key124=65027:0 Key125=0:0 Key126=65469:61 Key127=0:0 Key128=0:0 Key129=0:0 Key130=0:0 Key131=0:0 Key132=0:0 Key133=0:0 Key134=0:0 Key135=0:0 Key136=0:0 Key137=0:0 [capslock] Key8=0:0 Key9=65307:27 Key10=49:49 Key11=50:50 Key12=51:51 Key13=52:52 Key14=53:53 Key15=54:54 Key16=55:55 Key17=56:56 Key18=57:57 Key19=48:48 Key20=39:39 Key21=65106:94 Key22=65288:8 Key23=65289:9 Key24=81:81 Key25=87:87 Key26=69:69 Key27=82:82 Key28=84:84 Key29=90:90 Key30=85:85 Key31=73:73 Key32=79:79 Key33=80:80 Key34=220:220 Key35=65111:168 Key36=65293:13 Key37=65507:0 Key38=65:65 Key39=83:83 Key40=68:68 Key41=70:70 Key42=71:71 Key43=72:72 Key44=74:74 Key45=75:75 Key46=76:76 Key47=214:214 Key48=196:196 Key49=167:167 Key50=65505:0 Key51=36:36 Key52=89:89 Key53=88:88 Key54=67:67 Key55=86:86 Key56=66:66 Key57=78:78 Key58=77:77 Key59=44:44 Key60=46:46 Key61=45:45 Key62=65506:0 Key63=65450:42 Key64=65513:0 Key65=32:32 Key66=65509:0 Key67=65470:0 Key68=65471:0 Key69=65472:0 Key70=65473:0 Key71=65474:0 Key72=65475:0 Key73=65476:0 Key74=65477:0 Key75=65478:0 Key76=65479:0 Key77=65407:0 Key78=65300:0 Key79=65429:0 Key80=65431:0 Key81=65434:0 Key82=65453:45 Key83=65430:0 Key84=65437:0 Key85=65432:0 Key86=65451:43 Key87=65436:0 Key88=65433:0 Key89=65435:0 Key90=65438:0 Key91=65439:0 Key92=0:0 Key93=65406:0 Key94=60:60 Key95=65480:0 Key96=65481:0 Key97=65360:0 Key98=65362:0 Key99=65365:0 Key100=65361:0 Key101=0:0 Key102=65363:0 Key103=65367:0 Key104=65364:0 Key105=65366:0 Key106=65379:0 Key107=65535:127 Key108=65421:13 Key109=65508:0 Key110=65299:0 Key111=65377:0 Key112=65455:47 Key113=65027:0 Key114=0:0 Key115=0:0 Key116=0:0 Key117=0:0 Key118=0:0 Key119=0:0 Key120=0:0 Key121=0:0 Key122=0:0 Key123=0:0 Key124=65027:0 Key125=0:0 Key126=65469:61 Key127=0:0 Key128=0:0 Key129=0:0 Key130=0:0 Key131=0:0 Key132=0:0 Key133=0:0 Key134=0:0 Key135=0:0 Key136=0:0 Key137=0:0 [shiftcapslock] Key8=0:0 Key9=65307:27 Key10=43:43 Key11=34:34 Key12=42:42 Key13=199:199 Key14=37:37 Key15=38:38 Key16=47:47 Key17=40:40 Key18=41:41 Key19=61:61 Key20=63:63 Key21=65104:96 Key22=65288:8 Key23=65056:0 Key24=113:113 Key25=119:119 Key26=101:101 Key27=114:114 Key28=116:116 Key29=122:122 Key30=117:117 Key31=105:105 Key32=111:111 Key33=112:112 Key34=200:200 Key35=33:33 Key36=65293:13 Key37=65507:0 Key38=97:97 Key39=115:115 Key40=100:100 Key41=102:102 Key42=103:103 Key43=104:104 Key44=106:106 Key45=107:107 Key46=108:108 Key47=201:201 Key48=192:192 Key49=176:176 Key50=65505:0 Key51=163:163 Key52=121:121 Key53=120:120 Key54=99:99 Key55=118:118 Key56=98:98 Key57=110:110 Key58=109:109 Key59=59:59 Key60=58:58 Key61=95:95 Key62=65506:0 Key63=65450:42 Key64=65511:0 Key65=32:32 Key66=65509:0 Key67=65470:0 Key68=65471:0 Key69=65472:0 Key70=65473:0 Key71=65474:0 Key72=65475:0 Key73=65476:0 Key74=65477:0 Key75=65478:0 Key76=65479:0 Key77=65273:0 Key78=65300:0 Key79=65463:55 Key80=65464:56 Key81=65465:57 Key82=65453:45 Key83=65460:52 Key84=65461:53 Key85=65462:54 Key86=65451:43 Key87=65457:49 Key88=65458:50 Key89=65459:51 Key90=65456:48 Key91=65454:46 Key92=0:0 Key93=65406:0 Key94=62:62 Key95=65480:0 Key96=65481:0 Key97=65360:0 Key98=65362:0 Key99=65365:0 Key100=65361:0 Key101=0:0 Key102=65363:0 Key103=65367:0 Key104=65364:0 Key105=65366:0 Key106=65379:0 Key107=65535:127 Key108=65421:13 Key109=65508:0 Key110=65299:0 Key111=65377:0 Key112=65455:47 Key113=65312:0 Key114=0:0 Key115=0:0 Key116=0:0 Key117=0:0 Key118=0:0 Key119=0:0 Key120=0:0 Key121=0:0 Key122=0:0 Key123=0:0 Key124=65027:0 Key125=65513:0 Key126=65469:61 Key127=65515:0 Key128=65517:0 Key129=0:0 Key130=0:0 Key131=0:0 Key132=0:0 Key133=0:0 Key134=0:0 Key135=0:0 Key136=0:0 Key137=0:0 xrdp-0.9.5/instfiles/km-00000816.ini000644 001751 001751 00000025174 13127114621 016435 0ustar00metameta000000 000000 [noshift] Key8=65406:0 Key9=65307:27 Key10=49:49 Key11=50:50 Key12=51:51 Key13=52:52 Key14=53:53 Key15=54:54 Key16=55:55 Key17=56:56 Key18=57:57 Key19=48:48 Key20=39:39 Key21=171:171 Key22=65288:8 Key23=65289:9 Key24=113:113 Key25=119:119 Key26=101:101 Key27=114:114 Key28=116:116 Key29=121:121 Key30=117:117 Key31=105:105 Key32=111:111 Key33=112:112 Key34=43:43 Key35=65105:180 Key36=65293:13 Key37=65507:0 Key38=97:97 Key39=115:115 Key40=100:100 Key41=102:102 Key42=103:103 Key43=104:104 Key44=106:106 Key45=107:107 Key46=108:108 Key47=231:231 Key48=186:186 Key49=92:92 Key50=65505:0 Key51=65107:126 Key52=122:122 Key53=120:120 Key54=99:99 Key55=118:118 Key56=98:98 Key57=110:110 Key58=109:109 Key59=44:44 Key60=46:46 Key61=45:45 Key62=65506:0 Key63=65450:42 Key64=65513:0 Key65=32:32 Key66=65509:0 Key67=65470:0 Key68=65471:0 Key69=65472:0 Key70=65473:0 Key71=65474:0 Key72=65475:0 Key73=65476:0 Key74=65477:0 Key75=65478:0 Key76=65479:0 Key77=65407:0 Key78=65300:0 Key79=65429:0 Key80=65431:0 Key81=65434:0 Key82=65453:45 Key83=65430:0 Key84=65437:0 Key85=65432:0 Key86=65451:43 Key87=65436:0 Key88=65433:0 Key89=65435:0 Key90=65438:0 Key91=65439:0 Key92=65377:0 Key93=0:0 Key94=60:60 Key95=65480:0 Key96=65481:0 Key97=65360:0 Key98=65362:0 Key99=65365:0 Key100=65361:0 Key101=0:0 Key102=65363:0 Key103=65367:0 Key104=65364:0 Key105=65366:0 Key106=65379:0 Key107=65535:127 Key108=65421:13 Key109=65508:0 Key110=65299:0 Key111=65377:0 Key112=65455:47 Key113=65027:0 Key114=269025049:0 Key115=65515:0 Key116=65312:0 Key117=0:0 Key118=269025153:0 Key119=269025093:0 Key120=269025094:0 Key121=269025095:0 Key122=269025096:0 Key123=0:0 Key124=65027:0 Key125=0:0 Key126=65469:61 Key127=0:0 Key128=0:0 Key129=0:0 Key130=0:0 Key131=0:0 Key132=0:0 Key133=0:0 Key134=0:0 Key135=0:0 Key136=0:0 Key137=0:0 [shift] Key8=65406:0 Key9=65307:27 Key10=33:33 Key11=34:34 Key12=35:35 Key13=36:36 Key14=37:37 Key15=38:38 Key16=47:47 Key17=40:40 Key18=41:41 Key19=61:61 Key20=63:63 Key21=187:187 Key22=65288:8 Key23=65056:0 Key24=81:81 Key25=87:87 Key26=69:69 Key27=82:82 Key28=84:84 Key29=89:89 Key30=85:85 Key31=73:73 Key32=79:79 Key33=80:80 Key34=42:42 Key35=65104:96 Key36=65293:13 Key37=65507:0 Key38=65:65 Key39=83:83 Key40=68:68 Key41=70:70 Key42=71:71 Key43=72:72 Key44=74:74 Key45=75:75 Key46=76:76 Key47=199:199 Key48=170:170 Key49=124:124 Key50=65505:0 Key51=65106:94 Key52=90:90 Key53=88:88 Key54=67:67 Key55=86:86 Key56=66:66 Key57=78:78 Key58=77:77 Key59=59:59 Key60=58:58 Key61=95:95 Key62=65506:0 Key63=65450:42 Key64=65032:0 Key65=32:32 Key66=65509:0 Key67=65470:0 Key68=65471:0 Key69=65472:0 Key70=65473:0 Key71=65474:0 Key72=65475:0 Key73=65476:0 Key74=65477:0 Key75=65478:0 Key76=65479:0 Key77=65407:0 Key78=65300:0 Key79=65463:55 Key80=65464:56 Key81=65465:57 Key82=65453:45 Key83=65460:52 Key84=65461:53 Key85=65462:54 Key86=65451:43 Key87=65457:49 Key88=65458:50 Key89=65459:51 Key90=65456:48 Key91=65454:46 Key92=65377:0 Key93=0:0 Key94=62:62 Key95=65480:0 Key96=65481:0 Key97=65360:0 Key98=65362:0 Key99=65365:0 Key100=65361:0 Key101=0:0 Key102=65363:0 Key103=65367:0 Key104=65364:0 Key105=65366:0 Key106=65379:0 Key107=65535:127 Key108=65421:13 Key109=65508:0 Key110=65299:0 Key111=65377:0 Key112=65455:47 Key113=65027:0 Key114=269025049:0 Key115=65515:0 Key116=65312:0 Key117=0:0 Key118=269025153:0 Key119=269025093:0 Key120=269025094:0 Key121=269025095:0 Key122=269025096:0 Key123=0:0 Key124=65027:0 Key125=65513:0 Key126=65469:61 Key127=65515:0 Key128=65517:0 Key129=0:0 Key130=0:0 Key131=0:0 Key132=0:0 Key133=0:0 Key134=0:0 Key135=0:0 Key136=0:0 Key137=0:0 [altgr] Key8=65406:0 Key9=65307:27 Key10=185:185 Key11=64:64 Key12=163:163 Key13=167:167 Key14=189:189 Key15=172:172 Key16=123:123 Key17=91:91 Key18=93:93 Key19=125:125 Key20=92:92 Key21=65115:184 Key22=65288:8 Key23=65289:9 Key24=64:64 Key25=435:322 Key26=8364:8364 Key27=182:182 Key28=956:359 Key29=2299:8592 Key30=2302:8595 Key31=2301:8594 Key32=248:248 Key33=254:254 Key34=65111:168 Key35=65107:126 Key36=65293:13 Key37=65507:0 Key38=230:230 Key39=223:223 Key40=240:240 Key41=496:273 Key42=959:331 Key43=689:295 Key44=65121:0 Key45=930:312 Key46=435:322 Key47=65105:180 Key48=65106:94 Key49=172:172 Key50=65505:0 Key51=65104:96 Key52=171:171 Key53=187:187 Key54=162:162 Key55=2770:8220 Key56=2771:8221 Key57=110:110 Key58=181:181 Key59=2211:0 Key60=183:183 Key61=65120:0 Key62=65506:0 Key63=65450:42 Key64=65513:0 Key65=32:32 Key66=65509:0 Key67=65470:0 Key68=65471:0 Key69=65472:0 Key70=65473:0 Key71=65474:0 Key72=65475:0 Key73=65476:0 Key74=65477:0 Key75=65478:0 Key76=65479:0 Key77=65407:0 Key78=65300:0 Key79=65429:0 Key80=65431:0 Key81=65434:0 Key82=65453:45 Key83=65430:0 Key84=65437:0 Key85=65432:0 Key86=65451:43 Key87=65436:0 Key88=65433:0 Key89=65435:0 Key90=65438:0 Key91=65439:0 Key92=65377:0 Key93=0:0 Key94=92:92 Key95=65480:0 Key96=65481:0 Key97=65360:0 Key98=65362:0 Key99=65365:0 Key100=65361:0 Key101=0:0 Key102=65363:0 Key103=65367:0 Key104=65364:0 Key105=65366:0 Key106=65379:0 Key107=65535:127 Key108=65421:13 Key109=65508:0 Key110=65299:0 Key111=65377:0 Key112=65455:47 Key113=65027:0 Key114=269025049:0 Key115=65515:0 Key116=65312:0 Key117=0:0 Key118=269025153:0 Key119=269025093:0 Key120=269025094:0 Key121=269025095:0 Key122=269025096:0 Key123=0:0 Key124=65027:0 Key125=0:0 Key126=65469:61 Key127=0:0 Key128=0:0 Key129=0:0 Key130=0:0 Key131=0:0 Key132=0:0 Key133=0:0 Key134=0:0 Key135=0:0 Key136=0:0 Key137=0:0 [shiftaltgr] Key8=65406:0 Key9=65307:27 Key10=161:161 Key11=2755:8539 Key12=163:163 Key13=36:36 Key14=2756:8540 Key15=2757:8541 Key16=2758:8542 Key17=2761:8482 Key18=177:177 Key19=176:176 Key20=191:191 Key21=65116:731 Key22=65288:8 Key23=65056:0 Key24=2009:937 Key25=419:321 Key26=162:162 Key27=174:174 Key28=940:358 Key29=165:165 Key30=2300:8593 Key31=697:305 Key32=216:216 Key33=222:222 Key34=65112:176 Key35=65108:175 Key36=65293:13 Key37=65507:0 Key38=198:198 Key39=167:167 Key40=208:208 Key41=170:170 Key42=957:330 Key43=673:294 Key44=65122:0 Key45=38:38 Key46=419:321 Key47=65113:733 Key48=65114:711 Key49=172:172 Key50=65505:0 Key51=65109:728 Key52=60:60 Key53=62:62 Key54=169:169 Key55=2768:8216 Key56=2769:8217 Key57=78:78 Key58=186:186 Key59=215:215 Key60=247:247 Key61=65110:729 Key62=65506:0 Key63=65450:42 Key64=65032:0 Key65=32:32 Key66=65509:0 Key67=65470:0 Key68=65471:0 Key69=65472:0 Key70=65473:0 Key71=65474:0 Key72=65475:0 Key73=65476:0 Key74=65477:0 Key75=65478:0 Key76=65479:0 Key77=65407:0 Key78=65300:0 Key79=65463:55 Key80=65464:56 Key81=65465:57 Key82=65453:45 Key83=65460:52 Key84=65461:53 Key85=65462:54 Key86=65451:43 Key87=65457:49 Key88=65458:50 Key89=65459:51 Key90=65456:48 Key91=65454:46 Key92=65377:0 Key93=0:0 Key94=92:92 Key95=65480:0 Key96=65481:0 Key97=65360:0 Key98=65362:0 Key99=65365:0 Key100=65361:0 Key101=0:0 Key102=65363:0 Key103=65367:0 Key104=65364:0 Key105=65366:0 Key106=65379:0 Key107=65535:127 Key108=65421:13 Key109=65508:0 Key110=65299:0 Key111=65377:0 Key112=65455:47 Key113=65027:0 Key114=269025049:0 Key115=65515:0 Key116=65312:0 Key117=0:0 Key118=269025153:0 Key119=269025093:0 Key120=269025094:0 Key121=269025095:0 Key122=269025096:0 Key123=0:0 Key124=65027:0 Key125=65513:0 Key126=65469:61 Key127=65515:0 Key128=65517:0 Key129=0:0 Key130=0:0 Key131=0:0 Key132=0:0 Key133=0:0 Key134=0:0 Key135=0:0 Key136=0:0 Key137=0:0 [capslock] Key8=65406:0 Key9=65307:27 Key10=49:49 Key11=50:50 Key12=51:51 Key13=52:52 Key14=53:53 Key15=54:54 Key16=55:55 Key17=56:56 Key18=57:57 Key19=48:48 Key20=39:39 Key21=171:171 Key22=65288:8 Key23=65289:9 Key24=81:81 Key25=87:87 Key26=69:69 Key27=82:82 Key28=84:84 Key29=89:89 Key30=85:85 Key31=73:73 Key32=79:79 Key33=80:80 Key34=43:43 Key35=65105:180 Key36=65293:13 Key37=65507:0 Key38=65:65 Key39=83:83 Key40=68:68 Key41=70:70 Key42=71:71 Key43=72:72 Key44=74:74 Key45=75:75 Key46=76:76 Key47=199:199 Key48=186:186 Key49=92:92 Key50=65505:0 Key51=65107:126 Key52=90:90 Key53=88:88 Key54=67:67 Key55=86:86 Key56=66:66 Key57=78:78 Key58=77:77 Key59=44:44 Key60=46:46 Key61=45:45 Key62=65506:0 Key63=65450:42 Key64=65513:0 Key65=32:32 Key66=65509:0 Key67=65470:0 Key68=65471:0 Key69=65472:0 Key70=65473:0 Key71=65474:0 Key72=65475:0 Key73=65476:0 Key74=65477:0 Key75=65478:0 Key76=65479:0 Key77=65407:0 Key78=65300:0 Key79=65429:0 Key80=65431:0 Key81=65434:0 Key82=65453:45 Key83=65430:0 Key84=65437:0 Key85=65432:0 Key86=65451:43 Key87=65436:0 Key88=65433:0 Key89=65435:0 Key90=65438:0 Key91=65439:0 Key92=65377:0 Key93=0:0 Key94=60:60 Key95=65480:0 Key96=65481:0 Key97=65360:0 Key98=65362:0 Key99=65365:0 Key100=65361:0 Key101=0:0 Key102=65363:0 Key103=65367:0 Key104=65364:0 Key105=65366:0 Key106=65379:0 Key107=65535:127 Key108=65421:13 Key109=65508:0 Key110=65299:0 Key111=65377:0 Key112=65455:47 Key113=65027:0 Key114=269025049:0 Key115=65515:0 Key116=65312:0 Key117=0:0 Key118=269025153:0 Key119=269025093:0 Key120=269025094:0 Key121=269025095:0 Key122=269025096:0 Key123=0:0 Key124=65027:0 Key125=0:0 Key126=65469:61 Key127=0:0 Key128=0:0 Key129=0:0 Key130=0:0 Key131=0:0 Key132=0:0 Key133=0:0 Key134=0:0 Key135=0:0 Key136=0:0 Key137=0:0 [shiftcapslock] Key8=65406:0 Key9=65307:27 Key10=33:33 Key11=34:34 Key12=35:35 Key13=36:36 Key14=37:37 Key15=38:38 Key16=47:47 Key17=40:40 Key18=41:41 Key19=61:61 Key20=63:63 Key21=187:187 Key22=65288:8 Key23=65056:0 Key24=113:113 Key25=119:119 Key26=101:101 Key27=114:114 Key28=116:116 Key29=121:121 Key30=117:117 Key31=105:105 Key32=111:111 Key33=112:112 Key34=42:42 Key35=65104:96 Key36=65293:13 Key37=65507:0 Key38=97:97 Key39=115:115 Key40=100:100 Key41=102:102 Key42=103:103 Key43=104:104 Key44=106:106 Key45=107:107 Key46=108:108 Key47=231:231 Key48=170:170 Key49=124:124 Key50=65505:0 Key51=65106:94 Key52=122:122 Key53=120:120 Key54=99:99 Key55=118:118 Key56=98:98 Key57=110:110 Key58=109:109 Key59=59:59 Key60=58:58 Key61=95:95 Key62=65506:0 Key63=65450:42 Key64=65032:0 Key65=32:32 Key66=65509:0 Key67=65470:0 Key68=65471:0 Key69=65472:0 Key70=65473:0 Key71=65474:0 Key72=65475:0 Key73=65476:0 Key74=65477:0 Key75=65478:0 Key76=65479:0 Key77=65407:0 Key78=65300:0 Key79=65463:55 Key80=65464:56 Key81=65465:57 Key82=65453:45 Key83=65460:52 Key84=65461:53 Key85=65462:54 Key86=65451:43 Key87=65457:49 Key88=65458:50 Key89=65459:51 Key90=65456:48 Key91=65454:46 Key92=65377:0 Key93=0:0 Key94=62:62 Key95=65480:0 Key96=65481:0 Key97=65360:0 Key98=65362:0 Key99=65365:0 Key100=65361:0 Key101=0:0 Key102=65363:0 Key103=65367:0 Key104=65364:0 Key105=65366:0 Key106=65379:0 Key107=65535:127 Key108=65421:13 Key109=65508:0 Key110=65299:0 Key111=65377:0 Key112=65455:47 Key113=65027:0 Key114=269025049:0 Key115=65515:0 Key116=65312:0 Key117=0:0 Key118=269025153:0 Key119=269025093:0 Key120=269025094:0 Key121=269025095:0 Key122=269025096:0 Key123=0:0 Key124=65027:0 Key125=65513:0 Key126=65469:61 Key127=65515:0 Key128=65517:0 Key129=0:0 Key130=0:0 Key131=0:0 Key132=0:0 Key133=0:0 Key134=0:0 Key135=0:0 Key136=0:0 Key137=0:0 xrdp-0.9.5/instfiles/km-00000416.ini000644 001751 001751 00000021720 13127114621 016422 0ustar00metameta000000 000000 [noshift] Key8=0:0 Key9=65307:27 Key10=49:49 Key11=50:50 Key12=51:51 Key13=52:52 Key14=53:53 Key15=54:54 Key16=55:55 Key17=56:56 Key18=57:57 Key19=48:48 Key20=45:45 Key21=61:61 Key22=65288:8 Key23=65289:9 Key24=113:113 Key25=119:119 Key26=101:101 Key27=114:114 Key28=116:116 Key29=121:121 Key30=117:117 Key31=105:105 Key32=111:111 Key33=112:112 Key34=65105:180 Key35=91:91 Key36=65293:13 Key37=65507:0 Key38=97:97 Key39=115:115 Key40=100:100 Key41=102:102 Key42=103:103 Key43=104:104 Key44=106:106 Key45=107:107 Key46=108:108 Key47=231:231 Key48=65107:126 Key49=39:39 Key50=65505:0 Key51=93:93 Key52=122:122 Key53=120:120 Key54=99:99 Key55=118:118 Key56=98:98 Key57=110:110 Key58=109:109 Key59=44:44 Key60=46:46 Key61=59:59 Key62=65506:0 Key63=65450:42 Key64=65513:0 Key65=32:32 Key66=65509:0 Key67=65470:0 Key68=65471:0 Key69=65472:0 Key70=65473:0 Key71=65474:0 Key72=65475:0 Key73=65476:0 Key74=65477:0 Key75=65478:0 Key76=65479:0 Key77=65407:0 Key78=65300:0 Key79=65429:0 Key80=65431:0 Key81=65434:0 Key82=65453:45 Key83=65430:0 Key84=65437:0 Key85=65432:0 Key86=65451:43 Key87=65436:0 Key88=65433:0 Key89=65435:0 Key90=65438:0 Key91=65439:0 Key92=65027:0 Key93=0:0 Key94=92:92 Key95=65480:0 Key96=65481:0 Key97=47:47 Key98=65318:0 Key99=65317:0 Key100=65315:0 Key101=65319:0 Key102=65314:0 Key103=0:0 Key104=65421:13 Key105=65508:0 Key106=65455:47 Key107=65377:0 Key108=65027:0 Key109=65290:10 Key110=65360:0 Key111=65362:0 Key112=65365:0 Key113=65361:0 Key114=65363:0 Key115=65367:0 Key116=65364:0 Key117=65366:0 Key118=65379:0 Key119=65535:127 Key120=0:0 Key121=269025042:0 Key122=269025041:0 Key123=269025043:0 Key124=269025066:0 Key125=65469:61 Key126=177:177 Key127=65299:0 Key128=269025098:0 Key129=65454:46 Key130=65329:0 Key131=65332:0 Key132=0:0 Key133=65515:0 Key134=65516:0 Key135=65383:0 Key136=65385:0 Key137=65382:0 [shift] Key8=0:0 Key9=65307:27 Key10=33:33 Key11=64:64 Key12=35:35 Key13=36:36 Key14=37:37 Key15=65111:168 Key16=38:38 Key17=42:42 Key18=40:40 Key19=41:41 Key20=95:95 Key21=43:43 Key22=65288:8 Key23=65056:0 Key24=81:81 Key25=87:87 Key26=69:69 Key27=82:82 Key28=84:84 Key29=89:89 Key30=85:85 Key31=73:73 Key32=79:79 Key33=80:80 Key34=65104:96 Key35=123:123 Key36=65293:13 Key37=65507:0 Key38=65:65 Key39=83:83 Key40=68:68 Key41=70:70 Key42=71:71 Key43=72:72 Key44=74:74 Key45=75:75 Key46=76:76 Key47=199:199 Key48=65106:94 Key49=34:34 Key50=65505:0 Key51=125:125 Key52=90:90 Key53=88:88 Key54=67:67 Key55=86:86 Key56=66:66 Key57=78:78 Key58=77:77 Key59=60:60 Key60=62:62 Key61=58:58 Key62=65506:0 Key63=65450:42 Key64=65511:0 Key65=32:32 Key66=65509:0 Key67=65470:0 Key68=65471:0 Key69=65472:0 Key70=65473:0 Key71=65474:0 Key72=65475:0 Key73=65476:0 Key74=65477:0 Key75=65478:0 Key76=65479:0 Key77=65407:0 Key78=65300:0 Key79=65463:55 Key80=65464:56 Key81=65465:57 Key82=65453:45 Key83=65460:52 Key84=65461:53 Key85=65462:54 Key86=65451:43 Key87=65457:49 Key88=65458:50 Key89=65459:51 Key90=65456:48 Key91=65452:44 Key92=65027:0 Key93=0:0 Key94=124:124 Key95=65480:0 Key96=65481:0 Key97=63:63 Key98=65318:0 Key99=65317:0 Key100=65315:0 Key101=65319:0 Key102=65314:0 Key103=0:0 Key104=65421:13 Key105=65508:0 Key106=65455:47 Key107=65377:0 Key108=65027:0 Key109=65290:10 Key110=65360:0 Key111=65362:0 Key112=65365:0 Key113=65361:0 Key114=65363:0 Key115=65367:0 Key116=65364:0 Key117=65366:0 Key118=65379:0 Key119=65535:127 Key120=0:0 Key121=269025042:0 Key122=269025041:0 Key123=269025043:0 Key124=269025066:0 Key125=65469:61 Key126=177:177 Key127=65299:0 Key128=269025098:0 Key129=65454:46 Key130=65329:0 Key131=65332:0 Key132=0:0 Key133=65515:0 Key134=65516:0 Key135=65383:0 Key136=65385:0 Key137=65382:0 [altgr] Key8=0:0 Key9=65307:27 Key10=185:185 Key11=178:178 Key12=179:179 Key13=163:163 Key14=162:162 Key15=172:172 Key16=123:123 Key17=91:91 Key18=93:93 Key19=125:125 Key20=92:92 Key21=167:167 Key22=65288:8 Key23=65289:9 Key24=47:47 Key25=63:63 Key26=8364:8364 Key27=174:174 Key28=956:359 Key29=2299:8592 Key30=2302:8595 Key31=2301:8594 Key32=248:248 Key33=254:254 Key34=180:180 Key35=170:170 Key36=65293:13 Key37=65507:0 Key38=230:230 Key39=223:223 Key40=240:240 Key41=496:273 Key42=959:331 Key43=689:295 Key44=106:106 Key45=930:312 Key46=435:322 Key47=65105:180 Key48=126:126 Key49=172:172 Key50=65505:0 Key51=186:186 Key52=171:171 Key53=187:187 Key54=169:169 Key55=2770:8220 Key56=2771:8221 Key57=110:110 Key58=181:181 Key59=2211:0 Key60=183:183 Key61=65120:0 Key62=65506:0 Key63=65450:42 Key64=65513:0 Key65=32:32 Key66=65509:0 Key67=65470:0 Key68=65471:0 Key69=65472:0 Key70=65473:0 Key71=65474:0 Key72=65475:0 Key73=65476:0 Key74=65477:0 Key75=65478:0 Key76=65479:0 Key77=65407:0 Key78=65300:0 Key79=65429:0 Key80=65431:0 Key81=65434:0 Key82=65453:45 Key83=65430:0 Key84=65437:0 Key85=65432:0 Key86=65451:43 Key87=65436:0 Key88=65433:0 Key89=65435:0 Key90=65438:0 Key91=65439:0 Key92=65027:0 Key93=0:0 Key94=186:186 Key95=65480:0 Key96=65481:0 Key97=176:176 Key98=65318:0 Key99=65317:0 Key100=65315:0 Key101=65319:0 Key102=65314:0 Key103=0:0 Key104=65421:13 Key105=65508:0 Key106=65455:47 Key107=65377:0 Key108=65027:0 Key109=65290:10 Key110=65360:0 Key111=65362:0 Key112=65365:0 Key113=65361:0 Key114=65363:0 Key115=65367:0 Key116=65364:0 Key117=65366:0 Key118=65379:0 Key119=65535:127 Key120=0:0 Key121=269025042:0 Key122=269025041:0 Key123=269025043:0 Key124=269025066:0 Key125=65469:61 Key126=177:177 Key127=65299:0 Key128=269025098:0 Key129=65454:46 Key130=65329:0 Key131=65332:0 Key132=0:0 Key133=65515:0 Key134=65516:0 Key135=65383:0 Key136=65385:0 Key137=65382:0 [capslock] Key8=0:0 Key9=65307:27 Key10=49:49 Key11=50:50 Key12=51:51 Key13=52:52 Key14=53:53 Key15=54:54 Key16=55:55 Key17=56:56 Key18=57:57 Key19=48:48 Key20=45:45 Key21=61:61 Key22=65288:8 Key23=65289:9 Key24=81:81 Key25=87:87 Key26=69:69 Key27=82:82 Key28=84:84 Key29=89:89 Key30=85:85 Key31=73:73 Key32=79:79 Key33=80:80 Key34=65105:180 Key35=91:91 Key36=65293:13 Key37=65507:0 Key38=65:65 Key39=83:83 Key40=68:68 Key41=70:70 Key42=71:71 Key43=72:72 Key44=74:74 Key45=75:75 Key46=76:76 Key47=199:199 Key48=65107:126 Key49=39:39 Key50=65505:0 Key51=93:93 Key52=90:90 Key53=88:88 Key54=67:67 Key55=86:86 Key56=66:66 Key57=78:78 Key58=77:77 Key59=44:44 Key60=46:46 Key61=59:59 Key62=65506:0 Key63=65450:42 Key64=65513:0 Key65=32:32 Key66=65509:0 Key67=65470:0 Key68=65471:0 Key69=65472:0 Key70=65473:0 Key71=65474:0 Key72=65475:0 Key73=65476:0 Key74=65477:0 Key75=65478:0 Key76=65479:0 Key77=65407:0 Key78=65300:0 Key79=65429:0 Key80=65431:0 Key81=65434:0 Key82=65453:45 Key83=65430:0 Key84=65437:0 Key85=65432:0 Key86=65451:43 Key87=65436:0 Key88=65433:0 Key89=65435:0 Key90=65438:0 Key91=65439:0 Key92=65027:0 Key93=0:0 Key94=92:92 Key95=65480:0 Key96=65481:0 Key97=47:47 Key98=65318:0 Key99=65317:0 Key100=65315:0 Key101=65319:0 Key102=65314:0 Key103=0:0 Key104=65421:13 Key105=65508:0 Key106=65455:47 Key107=65377:0 Key108=65027:0 Key109=65290:10 Key110=65360:0 Key111=65362:0 Key112=65365:0 Key113=65361:0 Key114=65363:0 Key115=65367:0 Key116=65364:0 Key117=65366:0 Key118=65379:0 Key119=65535:127 Key120=0:0 Key121=269025042:0 Key122=269025041:0 Key123=269025043:0 Key124=269025066:0 Key125=65469:61 Key126=177:177 Key127=65299:0 Key128=269025098:0 Key129=65454:46 Key130=65329:0 Key131=65332:0 Key132=0:0 Key133=65515:0 Key134=65516:0 Key135=65383:0 Key136=65385:0 Key137=65382:0 [shiftcapslock] Key8=0:0 Key9=65307:27 Key10=33:33 Key11=64:64 Key12=35:35 Key13=36:36 Key14=37:37 Key15=65111:168 Key16=38:38 Key17=42:42 Key18=40:40 Key19=41:41 Key20=95:95 Key21=43:43 Key22=65288:8 Key23=65056:0 Key24=113:113 Key25=119:119 Key26=101:101 Key27=114:114 Key28=116:116 Key29=121:121 Key30=117:117 Key31=105:105 Key32=111:111 Key33=112:112 Key34=65104:96 Key35=123:123 Key36=65293:13 Key37=65507:0 Key38=97:97 Key39=115:115 Key40=100:100 Key41=102:102 Key42=103:103 Key43=104:104 Key44=106:106 Key45=107:107 Key46=108:108 Key47=231:231 Key48=65106:94 Key49=34:34 Key50=65505:0 Key51=125:125 Key52=122:122 Key53=120:120 Key54=99:99 Key55=118:118 Key56=98:98 Key57=110:110 Key58=109:109 Key59=60:60 Key60=62:62 Key61=58:58 Key62=65506:0 Key63=65450:42 Key64=65511:0 Key65=32:32 Key66=65509:0 Key67=65470:0 Key68=65471:0 Key69=65472:0 Key70=65473:0 Key71=65474:0 Key72=65475:0 Key73=65476:0 Key74=65477:0 Key75=65478:0 Key76=65479:0 Key77=65407:0 Key78=65300:0 Key79=65463:55 Key80=65464:56 Key81=65465:57 Key82=65453:45 Key83=65460:52 Key84=65461:53 Key85=65462:54 Key86=65451:43 Key87=65457:49 Key88=65458:50 Key89=65459:51 Key90=65456:48 Key91=65452:44 Key92=65027:0 Key93=0:0 Key94=124:124 Key95=65480:0 Key96=65481:0 Key97=63:63 Key98=65318:0 Key99=65317:0 Key100=65315:0 Key101=65319:0 Key102=65314:0 Key103=0:0 Key104=65421:13 Key105=65508:0 Key106=65455:47 Key107=65377:0 Key108=65027:0 Key109=65290:10 Key110=65360:0 Key111=65362:0 Key112=65365:0 Key113=65361:0 Key114=65363:0 Key115=65367:0 Key116=65364:0 Key117=65366:0 Key118=65379:0 Key119=65535:127 Key120=0:0 Key121=269025042:0 Key122=269025041:0 Key123=269025043:0 Key124=269025066:0 Key125=65469:61 Key126=177:177 Key127=65299:0 Key128=269025098:0 Key129=65454:46 Key130=65329:0 Key131=65332:0 Key132=0:0 Key133=65515:0 Key134=65516:0 Key135=65383:0 Key136=65385:0 Key137=65382:0 xrdp-0.9.5/instfiles/km-00000411.ini000644 001751 001751 00000034026 13127114621 016420 0ustar00metameta000000 000000 [noshift] Key8=65406:0 Key9=65307:27 Key10=49:49 Key11=50:50 Key12=51:51 Key13=52:52 Key14=53:53 Key15=54:54 Key16=55:55 Key17=56:56 Key18=57:57 Key19=48:48 Key20=45:45 Key21=94:94 Key22=65288:8 Key23=65289:9 Key24=113:113 Key25=119:119 Key26=101:101 Key27=114:114 Key28=116:116 Key29=121:121 Key30=117:117 Key31=105:105 Key32=111:111 Key33=112:112 Key34=64:64 Key35=91:91 Key36=65293:13 Key37=65507:0 Key38=97:97 Key39=115:115 Key40=100:100 Key41=102:102 Key42=103:103 Key43=104:104 Key44=106:106 Key45=107:107 Key46=108:108 Key47=59:59 Key48=58:58 Key49=65322:0 Key50=65505:0 Key51=93:93 Key52=122:122 Key53=120:120 Key54=99:99 Key55=118:118 Key56=98:98 Key57=110:110 Key58=109:109 Key59=44:44 Key60=46:46 Key61=47:47 Key62=65506:0 Key63=65450:42 Key64=65513:0 Key65=32:32 Key66=65328:0 Key67=65470:0 Key68=65471:0 Key69=65472:0 Key70=65473:0 Key71=65474:0 Key72=65475:0 Key73=65476:0 Key74=65477:0 Key75=65478:0 Key76=65479:0 Key77=65407:0 Key78=65300:0 Key79=65429:0 Key80=65431:0 Key81=65434:0 Key82=65453:45 Key83=65430:0 Key84=65437:0 Key85=65432:0 Key86=65451:43 Key87=65436:0 Key88=65433:0 Key89=65435:0 Key90=65438:0 Key91=65439:0 Key92=65377:0 Key93=0:0 Key94=60:60 Key95=65480:0 Key96=65481:0 Key97=65360:0 Key98=65362:0 Key99=65365:0 Key100=65361:0 Key101=0:0 Key102=65363:0 Key103=65367:0 Key104=65364:0 Key105=65366:0 Key106=65379:0 Key107=65535:127 Key108=65421:13 Key109=65508:0 Key110=65299:0 Key111=65377:0 Key112=65455:47 Key113=65514:0 Key114=269025049:0 Key115=65515:0 Key116=65516:0 Key117=0:0 Key118=269025153:0 Key119=269025093:0 Key120=269025094:0 Key121=269025095:0 Key122=269025096:0 Key123=92:92 Key124=65027:0 Key125=0:0 Key126=65469:61 Key127=0:0 Key128=0:0 Key129=65315:0 Key130=0:0 Key131=65314:0 Key132=0:0 Key133=165:165 Key134=0:0 Key135=0:0 Key136=0:0 Key137=0:0 [shift] Key8=65406:0 Key9=65307:27 Key10=33:33 Key11=34:34 Key12=35:35 Key13=36:36 Key14=37:37 Key15=38:38 Key16=39:39 Key17=40:40 Key18=41:41 Key19=48:48 Key20=61:61 Key21=126:126 Key22=65288:8 Key23=65056:0 Key24=81:81 Key25=87:87 Key26=69:69 Key27=82:82 Key28=84:84 Key29=89:89 Key30=85:85 Key31=73:73 Key32=79:79 Key33=80:80 Key34=96:96 Key35=123:123 Key36=65293:13 Key37=65507:0 Key38=65:65 Key39=83:83 Key40=68:68 Key41=70:70 Key42=71:71 Key43=72:72 Key44=74:74 Key45=75:75 Key46=76:76 Key47=43:43 Key48=42:42 Key49=65322:0 Key50=65505:0 Key51=125:125 Key52=90:90 Key53=88:88 Key54=67:67 Key55=86:86 Key56=66:66 Key57=78:78 Key58=77:77 Key59=60:60 Key60=62:62 Key61=63:63 Key62=65506:0 Key63=65450:42 Key64=65511:0 Key65=32:32 Key66=65509:0 Key67=65470:0 Key68=65471:0 Key69=65472:0 Key70=65473:0 Key71=65474:0 Key72=65475:0 Key73=65476:0 Key74=65477:0 Key75=65478:0 Key76=65479:0 Key77=65407:0 Key78=65300:0 Key79=65463:55 Key80=65464:56 Key81=65465:57 Key82=65453:45 Key83=65460:52 Key84=65461:53 Key85=65462:54 Key86=65451:43 Key87=65457:49 Key88=65458:50 Key89=65459:51 Key90=65456:48 Key91=65454:46 Key92=65377:0 Key93=0:0 Key94=62:62 Key95=65480:0 Key96=65481:0 Key97=65360:0 Key98=65362:0 Key99=65365:0 Key100=65361:0 Key101=0:0 Key102=65363:0 Key103=65367:0 Key104=65364:0 Key105=65366:0 Key106=65379:0 Key107=65535:127 Key108=65421:13 Key109=65508:0 Key110=65299:0 Key111=65377:0 Key112=65455:47 Key113=65512:0 Key114=269025049:0 Key115=65515:0 Key116=65516:0 Key117=0:0 Key118=269025153:0 Key119=269025093:0 Key120=269025094:0 Key121=269025095:0 Key122=269025096:0 Key123=95:95 Key124=65027:0 Key125=65513:0 Key126=65469:61 Key127=65515:0 Key128=65517:0 Key129=65315:0 Key130=0:0 Key131=65314:0 Key132=0:0 Key133=124:124 Key134=0:0 Key135=0:0 Key136=0:0 Key137=0:0 [altgr] Key8=65406:0 Key9=65307:27 Key10=49:49 Key11=50:50 Key12=51:51 Key13=52:52 Key14=53:53 Key15=54:54 Key16=55:55 Key17=56:56 Key18=57:57 Key19=48:48 Key20=45:45 Key21=94:94 Key22=65288:8 Key23=65289:9 Key24=113:113 Key25=119:119 Key26=101:101 Key27=114:114 Key28=116:116 Key29=121:121 Key30=117:117 Key31=105:105 Key32=111:111 Key33=112:112 Key34=64:64 Key35=91:91 Key36=65293:13 Key37=65507:0 Key38=97:97 Key39=115:115 Key40=100:100 Key41=102:102 Key42=103:103 Key43=104:104 Key44=106:106 Key45=107:107 Key46=108:108 Key47=59:59 Key48=58:58 Key49=65322:0 Key50=65505:0 Key51=93:93 Key52=122:122 Key53=120:120 Key54=99:99 Key55=118:118 Key56=98:98 Key57=110:110 Key58=109:109 Key59=44:44 Key60=46:46 Key61=47:47 Key62=65506:0 Key63=65450:42 Key64=65513:0 Key65=32:32 Key66=65328:0 Key67=65470:0 Key68=65471:0 Key69=65472:0 Key70=65473:0 Key71=65474:0 Key72=65475:0 Key73=65476:0 Key74=65477:0 Key75=65478:0 Key76=65479:0 Key77=65407:0 Key78=65300:0 Key79=65429:0 Key80=65431:0 Key81=65434:0 Key82=65453:45 Key83=65430:0 Key84=65437:0 Key85=65432:0 Key86=65451:43 Key87=65436:0 Key88=65433:0 Key89=65435:0 Key90=65438:0 Key91=65439:0 Key92=65377:0 Key93=0:0 Key94=124:124 Key95=65480:0 Key96=65481:0 Key97=65360:0 Key98=65362:0 Key99=65365:0 Key100=65361:0 Key101=0:0 Key102=65363:0 Key103=65367:0 Key104=65364:0 Key105=65366:0 Key106=65379:0 Key107=65535:127 Key108=65421:13 Key109=65508:0 Key110=65299:0 Key111=65377:0 Key112=65455:47 Key113=65514:0 Key114=269025049:0 Key115=65515:0 Key116=65516:0 Key117=0:0 Key118=269025153:0 Key119=269025093:0 Key120=269025094:0 Key121=269025095:0 Key122=269025096:0 Key123=0:0 Key124=65027:0 Key125=0:0 Key126=65469:61 Key127=0:0 Key128=0:0 Key129=65315:0 Key130=0:0 Key131=65314:0 Key132=0:0 Key133=165:165 Key134=0:0 Key135=0:0 Key136=0:0 Key137=0:0 [shiftaltgr] Key8=65406:0 Key9=65307:27 Key10=33:33 Key11=34:34 Key12=35:35 Key13=36:36 Key14=37:37 Key15=38:38 Key16=39:39 Key17=40:40 Key18=41:41 Key19=48:48 Key20=61:61 Key21=126:126 Key22=65288:8 Key23=65056:0 Key24=81:81 Key25=87:87 Key26=69:69 Key27=82:82 Key28=84:84 Key29=89:89 Key30=85:85 Key31=73:73 Key32=79:79 Key33=80:80 Key34=96:96 Key35=123:123 Key36=65293:13 Key37=65507:0 Key38=65:65 Key39=83:83 Key40=68:68 Key41=70:70 Key42=71:71 Key43=72:72 Key44=74:74 Key45=75:75 Key46=76:76 Key47=43:43 Key48=42:42 Key49=65322:0 Key50=65505:0 Key51=125:125 Key52=90:90 Key53=88:88 Key54=67:67 Key55=86:86 Key56=66:66 Key57=78:78 Key58=77:77 Key59=60:60 Key60=62:62 Key61=63:63 Key62=65506:0 Key63=65450:42 Key64=65511:0 Key65=32:32 Key66=65509:0 Key67=65470:0 Key68=65471:0 Key69=65472:0 Key70=65473:0 Key71=65474:0 Key72=65475:0 Key73=65476:0 Key74=65477:0 Key75=65478:0 Key76=65479:0 Key77=65407:0 Key78=65300:0 Key79=65463:55 Key80=65464:56 Key81=65465:57 Key82=65453:45 Key83=65460:52 Key84=65461:53 Key85=65462:54 Key86=65451:43 Key87=65457:49 Key88=65458:50 Key89=65459:51 Key90=65456:48 Key91=65454:46 Key92=65377:0 Key93=0:0 Key94=166:166 Key95=65480:0 Key96=65481:0 Key97=65360:0 Key98=65362:0 Key99=65365:0 Key100=65361:0 Key101=0:0 Key102=65363:0 Key103=65367:0 Key104=65364:0 Key105=65366:0 Key106=65379:0 Key107=65535:127 Key108=65421:13 Key109=65508:0 Key110=65299:0 Key111=65377:0 Key112=65455:47 Key113=65512:0 Key114=269025049:0 Key115=65515:0 Key116=65516:0 Key117=0:0 Key118=269025153:0 Key119=269025093:0 Key120=269025094:0 Key121=269025095:0 Key122=269025096:0 Key123=0:0 Key124=65027:0 Key125=65513:0 Key126=65469:61 Key127=65515:0 Key128=65517:0 Key129=65315:0 Key130=0:0 Key131=65314:0 Key132=0:0 Key133=124:124 Key134=0:0 Key135=0:0 Key136=0:0 Key137=0:0 [capslock] Key8=65406:0 Key9=65307:27 Key10=49:49 Key11=50:50 Key12=51:51 Key13=52:52 Key14=53:53 Key15=54:54 Key16=55:55 Key17=56:56 Key18=57:57 Key19=48:48 Key20=45:45 Key21=94:94 Key22=65288:8 Key23=65289:9 Key24=81:81 Key25=87:87 Key26=69:69 Key27=82:82 Key28=84:84 Key29=89:89 Key30=85:85 Key31=73:73 Key32=79:79 Key33=80:80 Key34=64:64 Key35=91:91 Key36=65293:13 Key37=65507:0 Key38=65:65 Key39=83:83 Key40=68:68 Key41=70:70 Key42=71:71 Key43=72:72 Key44=74:74 Key45=75:75 Key46=76:76 Key47=59:59 Key48=58:58 Key49=65322:0 Key50=65505:0 Key51=93:93 Key52=90:90 Key53=88:88 Key54=67:67 Key55=86:86 Key56=66:66 Key57=78:78 Key58=77:77 Key59=44:44 Key60=46:46 Key61=47:47 Key62=65506:0 Key63=65450:42 Key64=65513:0 Key65=32:32 Key66=65328:0 Key67=65470:0 Key68=65471:0 Key69=65472:0 Key70=65473:0 Key71=65474:0 Key72=65475:0 Key73=65476:0 Key74=65477:0 Key75=65478:0 Key76=65479:0 Key77=65407:0 Key78=65300:0 Key79=65429:0 Key80=65431:0 Key81=65434:0 Key82=65453:45 Key83=65430:0 Key84=65437:0 Key85=65432:0 Key86=65451:43 Key87=65436:0 Key88=65433:0 Key89=65435:0 Key90=65438:0 Key91=65439:0 Key92=65377:0 Key93=0:0 Key94=60:60 Key95=65480:0 Key96=65481:0 Key97=65360:0 Key98=65362:0 Key99=65365:0 Key100=65361:0 Key101=0:0 Key102=65363:0 Key103=65367:0 Key104=65364:0 Key105=65366:0 Key106=65379:0 Key107=65535:127 Key108=65421:13 Key109=65508:0 Key110=65299:0 Key111=65377:0 Key112=65455:47 Key113=65514:0 Key114=269025049:0 Key115=65515:0 Key116=65516:0 Key117=0:0 Key118=269025153:0 Key119=269025093:0 Key120=269025094:0 Key121=269025095:0 Key122=269025096:0 Key123=0:0 Key124=65027:0 Key125=0:0 Key126=65469:61 Key127=0:0 Key128=0:0 Key129=65315:0 Key130=0:0 Key131=65314:0 Key132=0:0 Key133=165:165 Key134=0:0 Key135=0:0 Key136=0:0 Key137=0:0 [capslockaltgr] Key8=65406:0 Key9=65307:27 Key10=49:49 Key11=50:50 Key12=51:51 Key13=52:52 Key14=53:53 Key15=54:54 Key16=55:55 Key17=56:56 Key18=57:57 Key19=48:48 Key20=45:45 Key21=94:94 Key22=65288:8 Key23=65289:9 Key24=81:81 Key25=87:87 Key26=69:69 Key27=82:82 Key28=84:84 Key29=89:89 Key30=85:85 Key31=73:73 Key32=79:79 Key33=80:80 Key34=64:64 Key35=91:91 Key36=65293:13 Key37=65507:0 Key38=65:65 Key39=83:83 Key40=68:68 Key41=70:70 Key42=71:71 Key43=72:72 Key44=74:74 Key45=75:75 Key46=76:76 Key47=59:59 Key48=58:58 Key49=65322:0 Key50=65505:0 Key51=93:93 Key52=90:90 Key53=88:88 Key54=67:67 Key55=86:86 Key56=66:66 Key57=78:78 Key58=77:77 Key59=44:44 Key60=46:46 Key61=47:47 Key62=65506:0 Key63=65450:42 Key64=65513:0 Key65=32:32 Key66=65328:0 Key67=65470:0 Key68=65471:0 Key69=65472:0 Key70=65473:0 Key71=65474:0 Key72=65475:0 Key73=65476:0 Key74=65477:0 Key75=65478:0 Key76=65479:0 Key77=65407:0 Key78=65300:0 Key79=65429:0 Key80=65431:0 Key81=65434:0 Key82=65453:45 Key83=65430:0 Key84=65437:0 Key85=65432:0 Key86=65451:43 Key87=65436:0 Key88=65433:0 Key89=65435:0 Key90=65438:0 Key91=65439:0 Key92=65377:0 Key93=0:0 Key94=124:124 Key95=65480:0 Key96=65481:0 Key97=65360:0 Key98=65362:0 Key99=65365:0 Key100=65361:0 Key101=0:0 Key102=65363:0 Key103=65367:0 Key104=65364:0 Key105=65366:0 Key106=65379:0 Key107=65535:127 Key108=65421:13 Key109=65508:0 Key110=65299:0 Key111=65377:0 Key112=65455:47 Key113=65514:0 Key114=269025049:0 Key115=65515:0 Key116=65516:0 Key117=0:0 Key118=269025153:0 Key119=269025093:0 Key120=269025094:0 Key121=269025095:0 Key122=269025096:0 Key123=0:0 Key124=65027:0 Key125=0:0 Key126=65469:61 Key127=0:0 Key128=0:0 Key129=65315:0 Key130=0:0 Key131=65314:0 Key132=0:0 Key133=165:165 Key134=0:0 Key135=0:0 Key136=0:0 Key137=0:0 [shiftcapslock] Key8=65406:0 Key9=65307:27 Key10=33:33 Key11=34:34 Key12=35:35 Key13=36:36 Key14=37:37 Key15=38:38 Key16=39:39 Key17=40:40 Key18=41:41 Key19=48:48 Key20=61:61 Key21=126:126 Key22=65288:8 Key23=65056:0 Key24=113:113 Key25=119:119 Key26=101:101 Key27=114:114 Key28=116:116 Key29=121:121 Key30=117:117 Key31=105:105 Key32=111:111 Key33=112:112 Key34=96:96 Key35=123:123 Key36=65293:13 Key37=65507:0 Key38=97:97 Key39=115:115 Key40=100:100 Key41=102:102 Key42=103:103 Key43=104:104 Key44=106:106 Key45=107:107 Key46=108:108 Key47=43:43 Key48=42:42 Key49=65322:0 Key50=65505:0 Key51=125:125 Key52=122:122 Key53=120:120 Key54=99:99 Key55=118:118 Key56=98:98 Key57=110:110 Key58=109:109 Key59=60:60 Key60=62:62 Key61=63:63 Key62=65506:0 Key63=65450:42 Key64=65511:0 Key65=32:32 Key66=65509:0 Key67=65470:0 Key68=65471:0 Key69=65472:0 Key70=65473:0 Key71=65474:0 Key72=65475:0 Key73=65476:0 Key74=65477:0 Key75=65478:0 Key76=65479:0 Key77=65407:0 Key78=65300:0 Key79=65463:55 Key80=65464:56 Key81=65465:57 Key82=65453:45 Key83=65460:52 Key84=65461:53 Key85=65462:54 Key86=65451:43 Key87=65457:49 Key88=65458:50 Key89=65459:51 Key90=65456:48 Key91=65454:46 Key92=65377:0 Key93=0:0 Key94=62:62 Key95=65480:0 Key96=65481:0 Key97=65360:0 Key98=65362:0 Key99=65365:0 Key100=65361:0 Key101=0:0 Key102=65363:0 Key103=65367:0 Key104=65364:0 Key105=65366:0 Key106=65379:0 Key107=65535:127 Key108=65421:13 Key109=65508:0 Key110=65299:0 Key111=65377:0 Key112=65455:47 Key113=65512:0 Key114=269025049:0 Key115=65515:0 Key116=65516:0 Key117=0:0 Key118=269025153:0 Key119=269025093:0 Key120=269025094:0 Key121=269025095:0 Key122=269025096:0 Key123=0:0 Key124=65027:0 Key125=65513:0 Key126=65469:61 Key127=65515:0 Key128=65517:0 Key129=65315:0 Key130=0:0 Key131=65314:0 Key132=0:0 Key133=124:124 Key134=0:0 Key135=0:0 Key136=0:0 Key137=0:0 [shiftcapslockaltgr] Key8=65406:0 Key9=65307:27 Key10=33:33 Key11=34:34 Key12=35:35 Key13=36:36 Key14=37:37 Key15=38:38 Key16=39:39 Key17=40:40 Key18=41:41 Key19=48:48 Key20=61:61 Key21=126:126 Key22=65288:8 Key23=65056:0 Key24=113:113 Key25=119:119 Key26=101:101 Key27=114:114 Key28=116:116 Key29=121:121 Key30=117:117 Key31=105:105 Key32=111:111 Key33=112:112 Key34=96:96 Key35=123:123 Key36=65293:13 Key37=65507:0 Key38=97:97 Key39=115:115 Key40=100:100 Key41=102:102 Key42=103:103 Key43=104:104 Key44=106:106 Key45=107:107 Key46=108:108 Key47=43:43 Key48=42:42 Key49=65322:0 Key50=65505:0 Key51=125:125 Key52=122:122 Key53=120:120 Key54=99:99 Key55=118:118 Key56=98:98 Key57=110:110 Key58=109:109 Key59=60:60 Key60=62:62 Key61=63:63 Key62=65506:0 Key63=65450:42 Key64=65511:0 Key65=32:32 Key66=65509:0 Key67=65470:0 Key68=65471:0 Key69=65472:0 Key70=65473:0 Key71=65474:0 Key72=65475:0 Key73=65476:0 Key74=65477:0 Key75=65478:0 Key76=65479:0 Key77=65407:0 Key78=65300:0 Key79=65463:55 Key80=65464:56 Key81=65465:57 Key82=65453:45 Key83=65460:52 Key84=65461:53 Key85=65462:54 Key86=65451:43 Key87=65457:49 Key88=65458:50 Key89=65459:51 Key90=65456:48 Key91=65454:46 Key92=65377:0 Key93=0:0 Key94=166:166 Key95=65480:0 Key96=65481:0 Key97=65360:0 Key98=65362:0 Key99=65365:0 Key100=65361:0 Key101=0:0 Key102=65363:0 Key103=65367:0 Key104=65364:0 Key105=65366:0 Key106=65379:0 Key107=65535:127 Key108=65421:13 Key109=65508:0 Key110=65299:0 Key111=65377:0 Key112=65455:47 Key113=65512:0 Key114=269025049:0 Key115=65515:0 Key116=65516:0 Key117=0:0 Key118=269025153:0 Key119=269025093:0 Key120=269025094:0 Key121=269025095:0 Key122=269025096:0 Key123=0:0 Key124=65027:0 Key125=65513:0 Key126=65469:61 Key127=65515:0 Key128=65517:0 Key129=65315:0 Key130=0:0 Key131=65314:0 Key132=0:0 Key133=124:124 Key134=0:0 Key135=0:0 Key136=0:0 Key137=0:0 xrdp-0.9.5/instfiles/xrdp.service.in000644 001751 001751 00000000636 13174271344 017401 0ustar00metameta000000 000000 [Unit] Description=xrdp daemon Documentation=man:xrdp(8) man:xrdp.ini(5) Requires=xrdp-sesman.service After=network.target xrdp-sesman.service [Service] Type=forking PIDFile=@localstatedir@/run/xrdp.pid EnvironmentFile=-@sysconfdir@/sysconfig/xrdp EnvironmentFile=-@sysconfdir@/default/xrdp ExecStart=@sbindir@/xrdp $XRDP_OPTIONS ExecStop=@sbindir@/xrdp $XRDP_OPTIONS --kill [Install] WantedBy=multi-user.target xrdp-0.9.5/instfiles/km-0000041d.ini000644 001751 001751 00000025177 13127114621 016512 0ustar00metameta000000 000000 [noshift] Key8=65406:0 Key9=65307:27 Key10=49:49 Key11=50:50 Key12=51:51 Key13=52:52 Key14=53:53 Key15=54:54 Key16=55:55 Key17=56:56 Key18=57:57 Key19=48:48 Key20=43:43 Key21=65105:180 Key22=65288:8 Key23=65289:9 Key24=113:113 Key25=119:119 Key26=101:101 Key27=114:114 Key28=116:116 Key29=121:121 Key30=117:117 Key31=105:105 Key32=111:111 Key33=112:112 Key34=229:229 Key35=65111:168 Key36=65293:13 Key37=65507:0 Key38=97:97 Key39=115:115 Key40=100:100 Key41=102:102 Key42=103:103 Key43=104:104 Key44=106:106 Key45=107:107 Key46=108:108 Key47=246:246 Key48=228:228 Key49=167:167 Key50=65505:0 Key51=39:39 Key52=122:122 Key53=120:120 Key54=99:99 Key55=118:118 Key56=98:98 Key57=110:110 Key58=109:109 Key59=44:44 Key60=46:46 Key61=45:45 Key62=65506:0 Key63=65450:42 Key64=65513:0 Key65=32:32 Key66=65509:0 Key67=65470:0 Key68=65471:0 Key69=65472:0 Key70=65473:0 Key71=65474:0 Key72=65475:0 Key73=65476:0 Key74=65477:0 Key75=65478:0 Key76=65479:0 Key77=65407:0 Key78=65300:0 Key79=65429:0 Key80=65431:0 Key81=65434:0 Key82=65453:45 Key83=65430:0 Key84=65437:0 Key85=65432:0 Key86=65451:43 Key87=65436:0 Key88=65433:0 Key89=65435:0 Key90=65438:0 Key91=65439:0 Key92=65377:0 Key93=0:0 Key94=60:60 Key95=65480:0 Key96=65481:0 Key97=65360:0 Key98=65362:0 Key99=65365:0 Key100=65361:0 Key101=0:0 Key102=65363:0 Key103=65367:0 Key104=65364:0 Key105=65366:0 Key106=65379:0 Key107=65535:127 Key108=65421:13 Key109=65508:0 Key110=65299:0 Key111=65377:0 Key112=65455:47 Key113=65027:0 Key114=269025049:0 Key115=65515:0 Key116=65312:0 Key117=0:0 Key118=269025153:0 Key119=269025093:0 Key120=269025094:0 Key121=269025095:0 Key122=269025096:0 Key123=0:0 Key124=65027:0 Key125=0:0 Key126=65469:61 Key127=0:0 Key128=0:0 Key129=0:0 Key130=0:0 Key131=0:0 Key132=0:0 Key133=0:0 Key134=0:0 Key135=0:0 Key136=0:0 Key137=0:0 [shift] Key8=65406:0 Key9=65307:27 Key10=33:33 Key11=34:34 Key12=35:35 Key13=164:164 Key14=37:37 Key15=38:38 Key16=47:47 Key17=40:40 Key18=41:41 Key19=61:61 Key20=63:63 Key21=65104:96 Key22=65288:8 Key23=65056:0 Key24=81:81 Key25=87:87 Key26=69:69 Key27=82:82 Key28=84:84 Key29=89:89 Key30=85:85 Key31=73:73 Key32=79:79 Key33=80:80 Key34=197:197 Key35=65106:94 Key36=65293:13 Key37=65507:0 Key38=65:65 Key39=83:83 Key40=68:68 Key41=70:70 Key42=71:71 Key43=72:72 Key44=74:74 Key45=75:75 Key46=76:76 Key47=214:214 Key48=196:196 Key49=189:189 Key50=65505:0 Key51=42:42 Key52=90:90 Key53=88:88 Key54=67:67 Key55=86:86 Key56=66:66 Key57=78:78 Key58=77:77 Key59=59:59 Key60=58:58 Key61=95:95 Key62=65506:0 Key63=65450:42 Key64=65032:0 Key65=32:32 Key66=65509:0 Key67=65470:0 Key68=65471:0 Key69=65472:0 Key70=65473:0 Key71=65474:0 Key72=65475:0 Key73=65476:0 Key74=65477:0 Key75=65478:0 Key76=65479:0 Key77=65407:0 Key78=65300:0 Key79=65463:55 Key80=65464:56 Key81=65465:57 Key82=65453:45 Key83=65460:52 Key84=65461:53 Key85=65462:54 Key86=65451:43 Key87=65457:49 Key88=65458:50 Key89=65459:51 Key90=65456:48 Key91=65452:44 Key92=65377:0 Key93=0:0 Key94=62:62 Key95=65480:0 Key96=65481:0 Key97=65360:0 Key98=65362:0 Key99=65365:0 Key100=65361:0 Key101=0:0 Key102=65363:0 Key103=65367:0 Key104=65364:0 Key105=65366:0 Key106=65379:0 Key107=65535:127 Key108=65421:13 Key109=65508:0 Key110=65299:0 Key111=65377:0 Key112=65455:47 Key113=65027:0 Key114=269025049:0 Key115=65515:0 Key116=65312:0 Key117=0:0 Key118=269025153:0 Key119=269025093:0 Key120=269025094:0 Key121=269025095:0 Key122=269025096:0 Key123=0:0 Key124=65027:0 Key125=65513:0 Key126=65469:61 Key127=65515:0 Key128=65517:0 Key129=0:0 Key130=0:0 Key131=0:0 Key132=0:0 Key133=0:0 Key134=0:0 Key135=0:0 Key136=0:0 Key137=0:0 [altgr] Key8=65406:0 Key9=65307:27 Key10=161:161 Key11=64:64 Key12=163:163 Key13=36:36 Key14=8364:8364 Key15=165:165 Key16=123:123 Key17=91:91 Key18=93:93 Key19=125:125 Key20=92:92 Key21=177:177 Key22=65288:8 Key23=65289:9 Key24=64:64 Key25=435:322 Key26=8364:8364 Key27=174:174 Key28=254:254 Key29=2299:8592 Key30=2302:8595 Key31=2301:8594 Key32=5053:339 Key33=254:254 Key34=65111:168 Key35=65107:126 Key36=65293:13 Key37=65507:0 Key38=170:170 Key39=223:223 Key40=240:240 Key41=496:273 Key42=959:331 Key43=689:295 Key44=65121:0 Key45=930:312 Key46=435:322 Key47=248:248 Key48=230:230 Key49=182:182 Key50=65505:0 Key51=180:180 Key52=171:171 Key53=187:187 Key54=169:169 Key55=2770:8220 Key56=2771:8221 Key57=110:110 Key58=181:181 Key59=65115:184 Key60=183:183 Key61=65120:0 Key62=65506:0 Key63=65450:42 Key64=65513:0 Key65=32:32 Key66=65509:0 Key67=65470:0 Key68=65471:0 Key69=65472:0 Key70=65473:0 Key71=65474:0 Key72=65475:0 Key73=65476:0 Key74=65477:0 Key75=65478:0 Key76=65479:0 Key77=65407:0 Key78=65300:0 Key79=65429:0 Key80=65431:0 Key81=65434:0 Key82=65453:45 Key83=65430:0 Key84=65437:0 Key85=65432:0 Key86=65451:43 Key87=65436:0 Key88=65433:0 Key89=65435:0 Key90=65438:0 Key91=65439:0 Key92=65377:0 Key93=0:0 Key94=124:124 Key95=65480:0 Key96=65481:0 Key97=65360:0 Key98=65362:0 Key99=65365:0 Key100=65361:0 Key101=0:0 Key102=65363:0 Key103=65367:0 Key104=65364:0 Key105=65366:0 Key106=65379:0 Key107=65535:127 Key108=65421:13 Key109=65508:0 Key110=65299:0 Key111=65377:0 Key112=65455:47 Key113=65027:0 Key114=269025049:0 Key115=65515:0 Key116=65312:0 Key117=0:0 Key118=269025153:0 Key119=269025093:0 Key120=269025094:0 Key121=269025095:0 Key122=269025096:0 Key123=0:0 Key124=65027:0 Key125=0:0 Key126=65469:61 Key127=0:0 Key128=0:0 Key129=0:0 Key130=0:0 Key131=0:0 Key132=0:0 Key133=0:0 Key134=0:0 Key135=0:0 Key136=0:0 Key137=0:0 [shiftaltgr] Key8=65406:0 Key9=65307:27 Key10=185:185 Key11=178:178 Key12=179:179 Key13=188:188 Key14=162:162 Key15=2757:8541 Key16=247:247 Key17=171:171 Key18=187:187 Key19=176:176 Key20=191:191 Key21=172:172 Key22=65288:8 Key23=65056:0 Key24=2009:937 Key25=419:321 Key26=162:162 Key27=174:174 Key28=222:222 Key29=165:165 Key30=2300:8593 Key31=697:305 Key32=5052:338 Key33=222:222 Key34=65112:176 Key35=65114:711 Key36=65293:13 Key37=65507:0 Key38=186:186 Key39=167:167 Key40=208:208 Key41=170:170 Key42=957:330 Key43=673:294 Key44=65122:0 Key45=38:38 Key46=419:321 Key47=216:216 Key48=198:198 Key49=190:190 Key50=65505:0 Key51=215:215 Key52=60:60 Key53=62:62 Key54=169:169 Key55=2768:8216 Key56=2769:8217 Key57=78:78 Key58=186:186 Key59=65116:731 Key60=65110:729 Key61=65110:729 Key62=65506:0 Key63=65450:42 Key64=65032:0 Key65=160:160 Key66=65509:0 Key67=65470:0 Key68=65471:0 Key69=65472:0 Key70=65473:0 Key71=65474:0 Key72=65475:0 Key73=65476:0 Key74=65477:0 Key75=65478:0 Key76=65479:0 Key77=65407:0 Key78=65300:0 Key79=65463:55 Key80=65464:56 Key81=65465:57 Key82=65453:45 Key83=65460:52 Key84=65461:53 Key85=65462:54 Key86=65451:43 Key87=65457:49 Key88=65458:50 Key89=65459:51 Key90=65456:48 Key91=65452:44 Key92=65377:0 Key93=0:0 Key94=166:166 Key95=65480:0 Key96=65481:0 Key97=65360:0 Key98=65362:0 Key99=65365:0 Key100=65361:0 Key101=0:0 Key102=65363:0 Key103=65367:0 Key104=65364:0 Key105=65366:0 Key106=65379:0 Key107=65535:127 Key108=65421:13 Key109=65508:0 Key110=65299:0 Key111=65377:0 Key112=65455:47 Key113=65027:0 Key114=269025049:0 Key115=65515:0 Key116=65312:0 Key117=0:0 Key118=269025153:0 Key119=269025093:0 Key120=269025094:0 Key121=269025095:0 Key122=269025096:0 Key123=0:0 Key124=65027:0 Key125=65513:0 Key126=65469:61 Key127=65515:0 Key128=65517:0 Key129=0:0 Key130=0:0 Key131=0:0 Key132=0:0 Key133=0:0 Key134=0:0 Key135=0:0 Key136=0:0 Key137=0:0 [capslock] Key8=65406:0 Key9=65307:27 Key10=49:49 Key11=50:50 Key12=51:51 Key13=52:52 Key14=53:53 Key15=54:54 Key16=55:55 Key17=56:56 Key18=57:57 Key19=48:48 Key20=43:43 Key21=65105:180 Key22=65288:8 Key23=65289:9 Key24=81:81 Key25=87:87 Key26=69:69 Key27=82:82 Key28=84:84 Key29=89:89 Key30=85:85 Key31=73:73 Key32=79:79 Key33=80:80 Key34=197:197 Key35=65111:168 Key36=65293:13 Key37=65507:0 Key38=65:65 Key39=83:83 Key40=68:68 Key41=70:70 Key42=71:71 Key43=72:72 Key44=74:74 Key45=75:75 Key46=76:76 Key47=214:214 Key48=196:196 Key49=167:167 Key50=65505:0 Key51=39:39 Key52=90:90 Key53=88:88 Key54=67:67 Key55=86:86 Key56=66:66 Key57=78:78 Key58=77:77 Key59=44:44 Key60=46:46 Key61=45:45 Key62=65506:0 Key63=65450:42 Key64=65513:0 Key65=32:32 Key66=65509:0 Key67=65470:0 Key68=65471:0 Key69=65472:0 Key70=65473:0 Key71=65474:0 Key72=65475:0 Key73=65476:0 Key74=65477:0 Key75=65478:0 Key76=65479:0 Key77=65407:0 Key78=65300:0 Key79=65429:0 Key80=65431:0 Key81=65434:0 Key82=65453:45 Key83=65430:0 Key84=65437:0 Key85=65432:0 Key86=65451:43 Key87=65436:0 Key88=65433:0 Key89=65435:0 Key90=65438:0 Key91=65439:0 Key92=65377:0 Key93=0:0 Key94=60:60 Key95=65480:0 Key96=65481:0 Key97=65360:0 Key98=65362:0 Key99=65365:0 Key100=65361:0 Key101=0:0 Key102=65363:0 Key103=65367:0 Key104=65364:0 Key105=65366:0 Key106=65379:0 Key107=65535:127 Key108=65421:13 Key109=65508:0 Key110=65299:0 Key111=65377:0 Key112=65455:47 Key113=65027:0 Key114=269025049:0 Key115=65515:0 Key116=65312:0 Key117=0:0 Key118=269025153:0 Key119=269025093:0 Key120=269025094:0 Key121=269025095:0 Key122=269025096:0 Key123=0:0 Key124=65027:0 Key125=0:0 Key126=65469:61 Key127=0:0 Key128=0:0 Key129=0:0 Key130=0:0 Key131=0:0 Key132=0:0 Key133=0:0 Key134=0:0 Key135=0:0 Key136=0:0 Key137=0:0 [shiftcapslock] Key8=65406:0 Key9=65307:27 Key10=33:33 Key11=34:34 Key12=35:35 Key13=164:164 Key14=37:37 Key15=38:38 Key16=47:47 Key17=40:40 Key18=41:41 Key19=61:61 Key20=63:63 Key21=65104:96 Key22=65288:8 Key23=65056:0 Key24=113:113 Key25=119:119 Key26=101:101 Key27=114:114 Key28=116:116 Key29=121:121 Key30=117:117 Key31=105:105 Key32=111:111 Key33=112:112 Key34=229:229 Key35=65106:94 Key36=65293:13 Key37=65507:0 Key38=97:97 Key39=115:115 Key40=100:100 Key41=102:102 Key42=103:103 Key43=104:104 Key44=106:106 Key45=107:107 Key46=108:108 Key47=246:246 Key48=228:228 Key49=189:189 Key50=65505:0 Key51=42:42 Key52=122:122 Key53=120:120 Key54=99:99 Key55=118:118 Key56=98:98 Key57=110:110 Key58=109:109 Key59=59:59 Key60=58:58 Key61=95:95 Key62=65506:0 Key63=65450:42 Key64=65032:0 Key65=32:32 Key66=65509:0 Key67=65470:0 Key68=65471:0 Key69=65472:0 Key70=65473:0 Key71=65474:0 Key72=65475:0 Key73=65476:0 Key74=65477:0 Key75=65478:0 Key76=65479:0 Key77=65407:0 Key78=65300:0 Key79=65463:55 Key80=65464:56 Key81=65465:57 Key82=65453:45 Key83=65460:52 Key84=65461:53 Key85=65462:54 Key86=65451:43 Key87=65457:49 Key88=65458:50 Key89=65459:51 Key90=65456:48 Key91=65452:44 Key92=65377:0 Key93=0:0 Key94=62:62 Key95=65480:0 Key96=65481:0 Key97=65360:0 Key98=65362:0 Key99=65365:0 Key100=65361:0 Key101=0:0 Key102=65363:0 Key103=65367:0 Key104=65364:0 Key105=65366:0 Key106=65379:0 Key107=65535:127 Key108=65421:13 Key109=65508:0 Key110=65299:0 Key111=65377:0 Key112=65455:47 Key113=65027:0 Key114=269025049:0 Key115=65515:0 Key116=65312:0 Key117=0:0 Key118=269025153:0 Key119=269025093:0 Key120=269025094:0 Key121=269025095:0 Key122=269025096:0 Key123=0:0 Key124=65027:0 Key125=65513:0 Key126=65469:61 Key127=65515:0 Key128=65517:0 Key129=0:0 Key130=0:0 Key131=0:0 Key132=0:0 Key133=0:0 Key134=0:0 Key135=0:0 Key136=0:0 Key137=0:0 xrdp-0.9.5/instfiles/km-0000080c.ini000644 001751 001751 00000021060 13127114621 016477 0ustar00metameta000000 000000 [noshift] Key8=0:0 Key9=65307:27 Key10=38:38 Key11=233:233 Key12=34:34 Key13=39:39 Key14=40:40 Key15=167:167 Key16=232:232 Key17=33:33 Key18=231:231 Key19=224:224 Key20=41:41 Key21=45:45 Key22=65288:8 Key23=65289:9 Key24=97:97 Key25=122:122 Key26=101:101 Key27=114:114 Key28=116:116 Key29=121:121 Key30=117:117 Key31=105:105 Key32=111:111 Key33=112:112 Key34=65106:94 Key35=36:36 Key36=65293:13 Key37=65507:0 Key38=113:113 Key39=115:115 Key40=100:100 Key41=102:102 Key42=103:103 Key43=104:104 Key44=106:106 Key45=107:107 Key46=108:108 Key47=109:109 Key48=249:249 Key49=178:178 Key50=65505:0 Key51=181:181 Key52=119:119 Key53=120:120 Key54=99:99 Key55=118:118 Key56=98:98 Key57=110:110 Key58=44:44 Key59=59:59 Key60=58:58 Key61=61:61 Key62=65506:0 Key63=65450:42 Key64=65513:0 Key65=32:32 Key66=65509:0 Key67=65470:0 Key68=65471:0 Key69=65472:0 Key70=65473:0 Key71=65474:0 Key72=65475:0 Key73=65476:0 Key74=65477:0 Key75=65478:0 Key76=65479:0 Key77=65407:0 Key78=65300:0 Key79=65429:0 Key80=65431:0 Key81=65434:0 Key82=65453:45 Key83=65430:0 Key84=65437:0 Key85=65432:0 Key86=65451:43 Key87=65436:0 Key88=65433:0 Key89=65435:0 Key90=65438:0 Key91=65439:0 Key92=0:0 Key93=65406:0 Key94=60:60 Key95=65480:0 Key96=65481:0 Key97=65360:0 Key98=65362:0 Key99=65365:0 Key100=65361:0 Key101=0:0 Key102=65363:0 Key103=65367:0 Key104=65364:0 Key105=65366:0 Key106=65379:0 Key107=65535:127 Key108=65421:13 Key109=65508:0 Key110=65299:0 Key111=65377:0 Key112=65455:47 Key113=65027:0 Key114=0:0 Key115=65515:0 Key116=65516:0 Key117=65383:0 Key118=0:0 Key119=0:0 Key120=0:0 Key121=0:0 Key122=0:0 Key123=0:0 Key124=65027:0 Key125=0:0 Key126=65469:61 Key127=0:0 Key128=0:0 Key129=0:0 Key130=0:0 Key131=0:0 Key132=0:0 Key133=0:0 Key134=0:0 Key135=0:0 Key136=0:0 Key137=0:0 [shift] Key8=0:0 Key9=65307:27 Key10=49:49 Key11=50:50 Key12=51:51 Key13=52:52 Key14=53:53 Key15=54:54 Key16=55:55 Key17=56:56 Key18=57:57 Key19=48:48 Key20=176:176 Key21=95:95 Key22=65288:8 Key23=65056:0 Key24=65:65 Key25=90:90 Key26=69:69 Key27=82:82 Key28=84:84 Key29=89:89 Key30=85:85 Key31=73:73 Key32=79:79 Key33=80:80 Key34=65111:168 Key35=42:42 Key36=65293:13 Key37=65507:0 Key38=81:81 Key39=83:83 Key40=68:68 Key41=70:70 Key42=71:71 Key43=72:72 Key44=74:74 Key45=75:75 Key46=76:76 Key47=77:77 Key48=37:37 Key49=179:179 Key50=65505:0 Key51=163:163 Key52=87:87 Key53=88:88 Key54=67:67 Key55=86:86 Key56=66:66 Key57=78:78 Key58=63:63 Key59=46:46 Key60=47:47 Key61=43:43 Key62=65506:0 Key63=65450:42 Key64=65511:0 Key65=32:32 Key66=65509:0 Key67=65470:0 Key68=65471:0 Key69=65472:0 Key70=65473:0 Key71=65474:0 Key72=65475:0 Key73=65476:0 Key74=65477:0 Key75=65478:0 Key76=65479:0 Key77=65273:0 Key78=65300:0 Key79=65463:55 Key80=65464:56 Key81=65465:57 Key82=65453:45 Key83=65460:52 Key84=65461:53 Key85=65462:54 Key86=65451:43 Key87=65457:49 Key88=65458:50 Key89=65459:51 Key90=65456:48 Key91=65454:46 Key92=0:0 Key93=65406:0 Key94=62:62 Key95=65480:0 Key96=65481:0 Key97=65360:0 Key98=65362:0 Key99=65365:0 Key100=65361:0 Key101=0:0 Key102=65363:0 Key103=65367:0 Key104=65364:0 Key105=65366:0 Key106=65379:0 Key107=65535:127 Key108=65421:13 Key109=65508:0 Key110=65299:0 Key111=65377:0 Key112=65455:47 Key113=65027:0 Key114=0:0 Key115=65515:0 Key116=65516:0 Key117=65383:0 Key118=0:0 Key119=0:0 Key120=0:0 Key121=0:0 Key122=0:0 Key123=0:0 Key124=65027:0 Key125=65513:0 Key126=65469:61 Key127=65515:0 Key128=65517:0 Key129=0:0 Key130=0:0 Key131=0:0 Key132=0:0 Key133=0:0 Key134=0:0 Key135=0:0 Key136=0:0 Key137=0:0 [altgr] Key8=0:0 Key9=65307:27 Key10=124:124 Key11=64:64 Key12=35:35 Key13=188:188 Key14=189:189 Key15=94:94 Key16=123:123 Key17=91:91 Key18=123:123 Key19=125:125 Key20=92:92 Key21=65115:184 Key22=65288:8 Key23=65289:9 Key24=64:64 Key25=435:322 Key26=8364:8364 Key27=182:182 Key28=956:359 Key29=2299:8592 Key30=2302:8595 Key31=2301:8594 Key32=5053:339 Key33=254:254 Key34=91:91 Key35=93:93 Key36=65293:13 Key37=65507:0 Key38=230:230 Key39=223:223 Key40=240:240 Key41=496:273 Key42=959:331 Key43=689:295 Key44=106:106 Key45=930:312 Key46=435:322 Key47=65105:180 Key48=65105:180 Key49=172:172 Key50=65505:0 Key51=65104:96 Key52=171:171 Key53=187:187 Key54=162:162 Key55=2770:8220 Key56=2771:8221 Key57=110:110 Key58=65115:184 Key59=2211:0 Key60=183:183 Key61=65107:126 Key62=65506:0 Key63=65450:42 Key64=65513:0 Key65=32:32 Key66=65509:0 Key67=65470:0 Key68=65471:0 Key69=65472:0 Key70=65473:0 Key71=65474:0 Key72=65475:0 Key73=65476:0 Key74=65477:0 Key75=65478:0 Key76=65479:0 Key77=65407:0 Key78=65300:0 Key79=65429:0 Key80=65431:0 Key81=65434:0 Key82=65453:45 Key83=65430:0 Key84=65437:0 Key85=65432:0 Key86=65451:43 Key87=65436:0 Key88=65433:0 Key89=65435:0 Key90=65438:0 Key91=65439:0 Key92=0:0 Key93=65406:0 Key94=92:92 Key95=65480:0 Key96=65481:0 Key97=65360:0 Key98=65362:0 Key99=65365:0 Key100=65361:0 Key101=0:0 Key102=65363:0 Key103=65367:0 Key104=65364:0 Key105=65366:0 Key106=65379:0 Key107=65535:127 Key108=65421:13 Key109=65508:0 Key110=65299:0 Key111=65377:0 Key112=65455:47 Key113=65027:0 Key114=0:0 Key115=65515:0 Key116=65516:0 Key117=65383:0 Key118=0:0 Key119=0:0 Key120=0:0 Key121=0:0 Key122=0:0 Key123=0:0 Key124=65027:0 Key125=0:0 Key126=65469:61 Key127=0:0 Key128=0:0 Key129=0:0 Key130=0:0 Key131=0:0 Key132=0:0 Key133=0:0 Key134=0:0 Key135=0:0 Key136=0:0 Key137=0:0 [capslock] Key8=0:0 Key9=65307:27 Key10=38:38 Key11=201:201 Key12=34:34 Key13=39:39 Key14=40:40 Key15=167:167 Key16=200:200 Key17=33:33 Key18=199:199 Key19=192:192 Key20=41:41 Key21=45:45 Key22=65288:8 Key23=65289:9 Key24=65:65 Key25=90:90 Key26=69:69 Key27=82:82 Key28=84:84 Key29=89:89 Key30=85:85 Key31=73:73 Key32=79:79 Key33=80:80 Key34=65106:94 Key35=36:36 Key36=65293:13 Key37=65507:0 Key38=81:81 Key39=83:83 Key40=68:68 Key41=70:70 Key42=71:71 Key43=72:72 Key44=74:74 Key45=75:75 Key46=76:76 Key47=77:77 Key48=217:217 Key49=178:178 Key50=65505:0 Key51=924:0 Key52=87:87 Key53=88:88 Key54=67:67 Key55=86:86 Key56=66:66 Key57=78:78 Key58=44:44 Key59=59:59 Key60=58:58 Key61=61:61 Key62=65506:0 Key63=65450:42 Key64=65513:0 Key65=32:32 Key66=65509:0 Key67=65470:0 Key68=65471:0 Key69=65472:0 Key70=65473:0 Key71=65474:0 Key72=65475:0 Key73=65476:0 Key74=65477:0 Key75=65478:0 Key76=65479:0 Key77=65407:0 Key78=65300:0 Key79=65429:0 Key80=65431:0 Key81=65434:0 Key82=65453:45 Key83=65430:0 Key84=65437:0 Key85=65432:0 Key86=65451:43 Key87=65436:0 Key88=65433:0 Key89=65435:0 Key90=65438:0 Key91=65439:0 Key92=0:0 Key93=65406:0 Key94=60:60 Key95=65480:0 Key96=65481:0 Key97=65360:0 Key98=65362:0 Key99=65365:0 Key100=65361:0 Key101=0:0 Key102=65363:0 Key103=65367:0 Key104=65364:0 Key105=65366:0 Key106=65379:0 Key107=65535:127 Key108=65421:13 Key109=65508:0 Key110=65299:0 Key111=65377:0 Key112=65455:47 Key113=65027:0 Key114=0:0 Key115=65515:0 Key116=65516:0 Key117=65383:0 Key118=0:0 Key119=0:0 Key120=0:0 Key121=0:0 Key122=0:0 Key123=0:0 Key124=65027:0 Key125=0:0 Key126=65469:61 Key127=0:0 Key128=0:0 Key129=0:0 Key130=0:0 Key131=0:0 Key132=0:0 Key133=0:0 Key134=0:0 Key135=0:0 Key136=0:0 Key137=0:0 [shiftcapslock] Key8=0:0 Key9=65307:27 Key10=49:49 Key11=50:50 Key12=51:51 Key13=52:52 Key14=53:53 Key15=54:54 Key16=55:55 Key17=56:56 Key18=57:57 Key19=48:48 Key20=176:176 Key21=95:95 Key22=65288:8 Key23=65056:0 Key24=97:97 Key25=122:122 Key26=101:101 Key27=114:114 Key28=116:116 Key29=121:121 Key30=117:117 Key31=105:105 Key32=111:111 Key33=112:112 Key34=65111:168 Key35=42:42 Key36=65293:13 Key37=65507:0 Key38=113:113 Key39=115:115 Key40=100:100 Key41=102:102 Key42=103:103 Key43=104:104 Key44=106:106 Key45=107:107 Key46=108:108 Key47=109:109 Key48=37:37 Key49=179:179 Key50=65505:0 Key51=163:163 Key52=119:119 Key53=120:120 Key54=99:99 Key55=118:118 Key56=98:98 Key57=110:110 Key58=63:63 Key59=46:46 Key60=47:47 Key61=43:43 Key62=65506:0 Key63=65450:42 Key64=65511:0 Key65=32:32 Key66=65509:0 Key67=65470:0 Key68=65471:0 Key69=65472:0 Key70=65473:0 Key71=65474:0 Key72=65475:0 Key73=65476:0 Key74=65477:0 Key75=65478:0 Key76=65479:0 Key77=65273:0 Key78=65300:0 Key79=65463:55 Key80=65464:56 Key81=65465:57 Key82=65453:45 Key83=65460:52 Key84=65461:53 Key85=65462:54 Key86=65451:43 Key87=65457:49 Key88=65458:50 Key89=65459:51 Key90=65456:48 Key91=65454:46 Key92=0:0 Key93=65406:0 Key94=62:62 Key95=65480:0 Key96=65481:0 Key97=65360:0 Key98=65362:0 Key99=65365:0 Key100=65361:0 Key101=0:0 Key102=65363:0 Key103=65367:0 Key104=65364:0 Key105=65366:0 Key106=65379:0 Key107=65535:127 Key108=65421:13 Key109=65508:0 Key110=65299:0 Key111=65377:0 Key112=65455:47 Key113=65027:0 Key114=0:0 Key115=65515:0 Key116=65516:0 Key117=65383:0 Key118=0:0 Key119=0:0 Key120=0:0 Key121=0:0 Key122=0:0 Key123=0:0 Key124=65027:0 Key125=65513:0 Key126=65469:61 Key127=65515:0 Key128=65517:0 Key129=0:0 Key130=0:0 Key131=0:0 Key132=0:0 Key133=0:0 Key134=0:0 Key135=0:0 Key136=0:0 Key137=0:0 xrdp-0.9.5/instfiles/Makefile.am000644 001751 001751 00000003350 13220727201 016453 0ustar00metameta000000 000000 EXTRA_DIST = \ keymap-names.txt \ xrdp.sh \ xrdp-sesman.service.in \ xrdp.service.in # # substitute directories in service file # CLEANFILES= \ xrdp-sesman.service \ xrdp.service SUBST_VARS = sed \ -e 's|@sbindir[@]|$(sbindir)|g' \ -e 's|@sysconfdir[@]|$(sysconfdir)|g' \ -e 's|@localstatedir[@]|$(localstatedir)|g' subst_verbose = $(subst_verbose_@AM_V@) subst_verbose_ = $(subst_verbose_@AM_DEFAULT_V@) subst_verbose_0 = @echo " SUBST $@"; SUFFIXES = .in .in: $(subst_verbose)$(SUBST_VARS) $< > $@ # # files for all platforms # startscriptdir=$(sysconfdir)/xrdp dist_startscript_DATA = \ km-00000407.ini \ km-00000409.ini \ km-0000040a.ini \ km-0000040b.ini \ km-0000040c.ini \ km-00000410.ini \ km-00000411.ini \ km-00000412.ini \ km-00000414.ini \ km-00000415.ini \ km-00000416.ini \ km-00000419.ini \ km-0000041d.ini \ km-00000807.ini \ km-00000809.ini \ km-0000080c.ini \ km-00000813.ini \ km-00000816.ini \ km-0000100c.ini \ km-00010409.ini # # platform specific files # SUBDIRS = if LINUX SUBDIRS += \ pam.d \ pulse dist_startscript_SCRIPTS = xrdp.sh if HAVE_SYSTEMD systemdsystemunit_DATA = \ xrdp-sesman.service \ xrdp.service else SUBDIRS += \ default \ init.d endif # HAVE_SYSTEMD endif # LINUX if FREEBSD SUBDIRS += \ pam.d \ rc.d \ pulse endif # # install-data-hook for each platform # TODO: subst these directories as well as service files # if LINUX # must be tab below install-data-hook: if [ -f $(DESTDIR)$(sysconfdir)/init.d/xrdp ]; then \ sed -i 's|__BASE__|$(prefix)|' $(DESTDIR)$(sysconfdir)/init.d/xrdp; \ fi endif if FREEBSD # must be tab below install-data-hook: sed -i '' 's|%%PREFIX%%|$(prefix)|g' $(DESTDIR)$(sysconfdir)/rc.d/xrdp endif xrdp-0.9.5/instfiles/pulse/000755 001751 001751 00000000000 13220731022 015542 5ustar00metameta000000 000000 xrdp-0.9.5/instfiles/km-0000040c.ini000644 001751 001751 00000021050 13127114621 016472 0ustar00metameta000000 000000 [noshift] Key8=0:0 Key9=65307:27 Key10=38:38 Key11=233:233 Key12=34:34 Key13=39:39 Key14=40:40 Key15=45:45 Key16=232:232 Key17=95:95 Key18=231:231 Key19=224:224 Key20=41:41 Key21=61:61 Key22=65288:8 Key23=65289:9 Key24=97:97 Key25=122:122 Key26=101:101 Key27=114:114 Key28=116:116 Key29=121:121 Key30=117:117 Key31=105:105 Key32=111:111 Key33=112:112 Key34=65106:94 Key35=36:36 Key36=65293:13 Key37=65507:0 Key38=113:113 Key39=115:115 Key40=100:100 Key41=102:102 Key42=103:103 Key43=104:104 Key44=106:106 Key45=107:107 Key46=108:108 Key47=109:109 Key48=249:249 Key49=178:178 Key50=65505:0 Key51=42:42 Key52=119:119 Key53=120:120 Key54=99:99 Key55=118:118 Key56=98:98 Key57=110:110 Key58=44:44 Key59=59:59 Key60=58:58 Key61=33:33 Key62=65506:0 Key63=65450:42 Key64=65513:0 Key65=32:32 Key66=65509:0 Key67=65470:0 Key68=65471:0 Key69=65472:0 Key70=65473:0 Key71=65474:0 Key72=65475:0 Key73=65476:0 Key74=65477:0 Key75=65478:0 Key76=65479:0 Key77=65407:0 Key78=65300:0 Key79=65429:0 Key80=65431:0 Key81=65434:0 Key82=65453:45 Key83=65430:0 Key84=65437:0 Key85=65432:0 Key86=65451:43 Key87=65436:0 Key88=65433:0 Key89=65435:0 Key90=65438:0 Key91=65439:0 Key92=0:0 Key93=65406:0 Key94=60:60 Key95=65480:0 Key96=65481:0 Key97=65360:0 Key98=65362:0 Key99=65365:0 Key100=65361:0 Key101=0:0 Key102=65363:0 Key103=65367:0 Key104=65364:0 Key105=65366:0 Key106=65379:0 Key107=65535:127 Key108=65421:13 Key109=65508:0 Key110=65299:0 Key111=65377:0 Key112=65455:47 Key113=65027:0 Key114=0:0 Key115=65515:0 Key116=65516:0 Key117=65383:0 Key118=0:0 Key119=0:0 Key120=0:0 Key121=0:0 Key122=0:0 Key123=0:0 Key124=65027:0 Key125=0:0 Key126=65469:61 Key127=0:0 Key128=0:0 Key129=0:0 Key130=0:0 Key131=0:0 Key132=0:0 Key133=0:0 Key134=0:0 Key135=0:0 Key136=0:0 Key137=0:0 [shift] Key8=0:0 Key9=65307:27 Key10=49:49 Key11=50:50 Key12=51:51 Key13=52:52 Key14=53:53 Key15=54:54 Key16=55:55 Key17=56:56 Key18=57:57 Key19=48:48 Key20=176:176 Key21=43:43 Key22=65288:8 Key23=65056:0 Key24=65:65 Key25=90:90 Key26=69:69 Key27=82:82 Key28=84:84 Key29=89:89 Key30=85:85 Key31=73:73 Key32=79:79 Key33=80:80 Key34=65111:168 Key35=163:163 Key36=65293:13 Key37=65507:0 Key38=81:81 Key39=83:83 Key40=68:68 Key41=70:70 Key42=71:71 Key43=72:72 Key44=74:74 Key45=75:75 Key46=76:76 Key47=77:77 Key48=37:37 Key49=126:126 Key50=65505:0 Key51=181:181 Key52=87:87 Key53=88:88 Key54=67:67 Key55=86:86 Key56=66:66 Key57=78:78 Key58=63:63 Key59=46:46 Key60=47:47 Key61=167:167 Key62=65506:0 Key63=65450:42 Key64=65511:0 Key65=32:32 Key66=65509:0 Key67=65470:0 Key68=65471:0 Key69=65472:0 Key70=65473:0 Key71=65474:0 Key72=65475:0 Key73=65476:0 Key74=65477:0 Key75=65478:0 Key76=65479:0 Key77=65273:0 Key78=65300:0 Key79=65463:55 Key80=65464:56 Key81=65465:57 Key82=65453:45 Key83=65460:52 Key84=65461:53 Key85=65462:54 Key86=65451:43 Key87=65457:49 Key88=65458:50 Key89=65459:51 Key90=65456:48 Key91=65454:46 Key92=0:0 Key93=65406:0 Key94=62:62 Key95=65480:0 Key96=65481:0 Key97=65360:0 Key98=65362:0 Key99=65365:0 Key100=65361:0 Key101=0:0 Key102=65363:0 Key103=65367:0 Key104=65364:0 Key105=65366:0 Key106=65379:0 Key107=65535:127 Key108=65421:13 Key109=65508:0 Key110=65299:0 Key111=65377:0 Key112=65455:47 Key113=65027:0 Key114=0:0 Key115=65515:0 Key116=65516:0 Key117=65383:0 Key118=0:0 Key119=0:0 Key120=0:0 Key121=0:0 Key122=0:0 Key123=0:0 Key124=65027:0 Key125=65513:0 Key126=65469:61 Key127=65515:0 Key128=65517:0 Key129=0:0 Key130=0:0 Key131=0:0 Key132=0:0 Key133=0:0 Key134=0:0 Key135=0:0 Key136=0:0 Key137=0:0 [altgr] Key8=0:0 Key9=65307:27 Key10=185:185 Key11=126:126 Key12=35:35 Key13=123:123 Key14=91:91 Key15=124:124 Key16=96:96 Key17=92:92 Key18=94:94 Key19=64:64 Key20=93:93 Key21=125:125 Key22=65288:8 Key23=65289:9 Key24=230:230 Key25=171:171 Key26=8364:8364 Key27=182:182 Key28=956:359 Key29=2299:8592 Key30=2302:8595 Key31=2301:8594 Key32=248:248 Key33=254:254 Key34=65111:168 Key35=164:164 Key36=65293:13 Key37=65507:0 Key38=64:64 Key39=223:223 Key40=240:240 Key41=496:273 Key42=959:331 Key43=689:295 Key44=106:106 Key45=930:312 Key46=435:322 Key47=181:181 Key48=65106:94 Key49=172:172 Key50=65505:0 Key51=65104:96 Key52=435:322 Key53=187:187 Key54=162:162 Key55=2770:8220 Key56=2771:8221 Key57=110:110 Key58=65105:180 Key59=2211:0 Key60=183:183 Key61=65120:0 Key62=65506:0 Key63=65450:42 Key64=65513:0 Key65=32:32 Key66=65509:0 Key67=65470:0 Key68=65471:0 Key69=65472:0 Key70=65473:0 Key71=65474:0 Key72=65475:0 Key73=65476:0 Key74=65477:0 Key75=65478:0 Key76=65479:0 Key77=65407:0 Key78=65300:0 Key79=65429:0 Key80=65431:0 Key81=65434:0 Key82=65453:45 Key83=65430:0 Key84=65437:0 Key85=65432:0 Key86=65451:43 Key87=65436:0 Key88=65433:0 Key89=65435:0 Key90=65438:0 Key91=65439:0 Key92=0:0 Key93=65406:0 Key94=124:124 Key95=65480:0 Key96=65481:0 Key97=65360:0 Key98=65362:0 Key99=65365:0 Key100=65361:0 Key101=0:0 Key102=65363:0 Key103=65367:0 Key104=65364:0 Key105=65366:0 Key106=65379:0 Key107=65535:127 Key108=65421:13 Key109=65508:0 Key110=65299:0 Key111=0:0 Key112=65455:47 Key113=65027:0 Key114=0:0 Key115=65515:0 Key116=65516:0 Key117=65383:0 Key118=0:0 Key119=0:0 Key120=0:0 Key121=0:0 Key122=0:0 Key123=0:0 Key124=65027:0 Key125=0:0 Key126=65469:61 Key127=0:0 Key128=0:0 Key129=0:0 Key130=0:0 Key131=0:0 Key132=0:0 Key133=0:0 Key134=0:0 Key135=0:0 Key136=0:0 Key137=0:0 [capslock] Key8=0:0 Key9=65307:27 Key10=38:38 Key11=201:201 Key12=34:34 Key13=39:39 Key14=40:40 Key15=45:45 Key16=200:200 Key17=95:95 Key18=199:199 Key19=192:192 Key20=41:41 Key21=61:61 Key22=65288:8 Key23=65289:9 Key24=65:65 Key25=90:90 Key26=69:69 Key27=82:82 Key28=84:84 Key29=89:89 Key30=85:85 Key31=73:73 Key32=79:79 Key33=80:80 Key34=65106:94 Key35=36:36 Key36=65293:13 Key37=65507:0 Key38=81:81 Key39=83:83 Key40=68:68 Key41=70:70 Key42=71:71 Key43=72:72 Key44=74:74 Key45=75:75 Key46=76:76 Key47=77:77 Key48=217:217 Key49=178:178 Key50=65505:0 Key51=42:42 Key52=87:87 Key53=88:88 Key54=67:67 Key55=86:86 Key56=66:66 Key57=78:78 Key58=44:44 Key59=59:59 Key60=58:58 Key61=33:33 Key62=65506:0 Key63=65450:42 Key64=65513:0 Key65=32:32 Key66=65509:0 Key67=65470:0 Key68=65471:0 Key69=65472:0 Key70=65473:0 Key71=65474:0 Key72=65475:0 Key73=65476:0 Key74=65477:0 Key75=65478:0 Key76=65479:0 Key77=65407:0 Key78=65300:0 Key79=65429:0 Key80=65431:0 Key81=65434:0 Key82=65453:45 Key83=65430:0 Key84=65437:0 Key85=65432:0 Key86=65451:43 Key87=65436:0 Key88=65433:0 Key89=65435:0 Key90=65438:0 Key91=65439:0 Key92=0:0 Key93=65406:0 Key94=60:60 Key95=65480:0 Key96=65481:0 Key97=65360:0 Key98=65362:0 Key99=65365:0 Key100=65361:0 Key101=0:0 Key102=65363:0 Key103=65367:0 Key104=65364:0 Key105=65366:0 Key106=65379:0 Key107=65535:127 Key108=65421:13 Key109=65508:0 Key110=65299:0 Key111=65377:0 Key112=65455:47 Key113=65027:0 Key114=0:0 Key115=65515:0 Key116=65516:0 Key117=65383:0 Key118=0:0 Key119=0:0 Key120=0:0 Key121=0:0 Key122=0:0 Key123=0:0 Key124=65027:0 Key125=0:0 Key126=65469:61 Key127=0:0 Key128=0:0 Key129=0:0 Key130=0:0 Key131=0:0 Key132=0:0 Key133=0:0 Key134=0:0 Key135=0:0 Key136=0:0 Key137=0:0 [shiftcapslock] Key8=0:0 Key9=65307:27 Key10=49:49 Key11=50:50 Key12=51:51 Key13=52:52 Key14=53:53 Key15=54:54 Key16=55:55 Key17=56:56 Key18=57:57 Key19=48:48 Key20=176:176 Key21=43:43 Key22=65288:8 Key23=65056:0 Key24=97:97 Key25=122:122 Key26=101:101 Key27=114:114 Key28=116:116 Key29=121:121 Key30=117:117 Key31=105:105 Key32=111:111 Key33=112:112 Key34=65111:168 Key35=163:163 Key36=65293:13 Key37=65507:0 Key38=113:113 Key39=115:115 Key40=100:100 Key41=102:102 Key42=103:103 Key43=104:104 Key44=106:106 Key45=107:107 Key46=108:108 Key47=109:109 Key48=37:37 Key49=126:126 Key50=65505:0 Key51=924:0 Key52=119:119 Key53=120:120 Key54=99:99 Key55=118:118 Key56=98:98 Key57=110:110 Key58=63:63 Key59=46:46 Key60=47:47 Key61=167:167 Key62=65506:0 Key63=65450:42 Key64=65511:0 Key65=32:32 Key66=65509:0 Key67=65470:0 Key68=65471:0 Key69=65472:0 Key70=65473:0 Key71=65474:0 Key72=65475:0 Key73=65476:0 Key74=65477:0 Key75=65478:0 Key76=65479:0 Key77=65273:0 Key78=65300:0 Key79=65463:55 Key80=65464:56 Key81=65465:57 Key82=65453:45 Key83=65460:52 Key84=65461:53 Key85=65462:54 Key86=65451:43 Key87=65457:49 Key88=65458:50 Key89=65459:51 Key90=65456:48 Key91=65454:46 Key92=0:0 Key93=65406:0 Key94=62:62 Key95=65480:0 Key96=65481:0 Key97=65360:0 Key98=65362:0 Key99=65365:0 Key100=65361:0 Key101=0:0 Key102=65363:0 Key103=65367:0 Key104=65364:0 Key105=65366:0 Key106=65379:0 Key107=65535:127 Key108=65421:13 Key109=65508:0 Key110=65299:0 Key111=65377:0 Key112=65455:47 Key113=65027:0 Key114=0:0 Key115=65515:0 Key116=65516:0 Key117=65383:0 Key118=0:0 Key119=0:0 Key120=0:0 Key121=0:0 Key122=0:0 Key123=0:0 Key124=65027:0 Key125=65513:0 Key126=65469:61 Key127=65515:0 Key128=65517:0 Key129=0:0 Key130=0:0 Key131=0:0 Key132=0:0 Key133=0:0 Key134=0:0 Key135=0:0 Key136=0:0 Key137=0:0 xrdp-0.9.5/instfiles/xrdp-sesman.service.in000644 001751 001751 00000000703 13174271344 020660 0ustar00metameta000000 000000 [Unit] Description=xrdp session manager Documentation=man:xrdp-sesman(8) man:sesman.ini(5) After=network.target StopWhenUnneeded=true BindsTo=xrdp.service [Service] Type=forking PIDFile=@localstatedir@/run/xrdp-sesman.pid EnvironmentFile=-@sysconfdir@/sysconfig/xrdp EnvironmentFile=-@sysconfdir@/default/xrdp ExecStart=@sbindir@/xrdp-sesman $SESMAN_OPTIONS ExecStop=@sbindir@/xrdp-sesman $SESMAN_OPTIONS --kill [Install] WantedBy=multi-user.target xrdp-0.9.5/instfiles/km-00000410.ini000644 001751 001751 00000025157 13127114621 016424 0ustar00metameta000000 000000 [noshift] Key8=65406:0 Key9=65307:27 Key10=49:49 Key11=50:50 Key12=51:51 Key13=52:52 Key14=53:53 Key15=54:54 Key16=55:55 Key17=56:56 Key18=57:57 Key19=48:48 Key20=39:39 Key21=236:236 Key22=65288:8 Key23=65289:9 Key24=113:113 Key25=119:119 Key26=101:101 Key27=114:114 Key28=116:116 Key29=121:121 Key30=117:117 Key31=105:105 Key32=111:111 Key33=112:112 Key34=232:232 Key35=43:43 Key36=65293:13 Key37=65507:0 Key38=97:97 Key39=115:115 Key40=100:100 Key41=102:102 Key42=103:103 Key43=104:104 Key44=106:106 Key45=107:107 Key46=108:108 Key47=242:242 Key48=224:224 Key49=92:92 Key50=65505:0 Key51=249:249 Key52=122:122 Key53=120:120 Key54=99:99 Key55=118:118 Key56=98:98 Key57=110:110 Key58=109:109 Key59=44:44 Key60=46:46 Key61=45:45 Key62=65506:0 Key63=65450:42 Key64=65513:0 Key65=32:32 Key66=65509:0 Key67=65470:0 Key68=65471:0 Key69=65472:0 Key70=65473:0 Key71=65474:0 Key72=65475:0 Key73=65476:0 Key74=65477:0 Key75=65478:0 Key76=65479:0 Key77=65407:0 Key78=65300:0 Key79=65429:0 Key80=65431:0 Key81=65434:0 Key82=65453:45 Key83=65430:0 Key84=65437:0 Key85=65432:0 Key86=65451:43 Key87=65436:0 Key88=65433:0 Key89=65435:0 Key90=65438:0 Key91=65439:0 Key92=65377:0 Key93=0:0 Key94=60:60 Key95=65480:0 Key96=65481:0 Key97=65360:0 Key98=65362:0 Key99=65365:0 Key100=65361:0 Key101=0:0 Key102=65363:0 Key103=65367:0 Key104=65364:0 Key105=65366:0 Key106=65379:0 Key107=65535:127 Key108=65421:13 Key109=65508:0 Key110=65299:0 Key111=65377:0 Key112=65455:47 Key113=65027:0 Key114=269025049:0 Key115=65515:0 Key116=65312:0 Key117=0:0 Key118=269025153:0 Key119=269025093:0 Key120=269025094:0 Key121=269025095:0 Key122=269025096:0 Key123=0:0 Key124=65027:0 Key125=0:0 Key126=65469:61 Key127=0:0 Key128=0:0 Key129=0:0 Key130=0:0 Key131=0:0 Key132=0:0 Key133=0:0 Key134=0:0 Key135=0:0 Key136=0:0 Key137=0:0 [shift] Key8=65406:0 Key9=65307:27 Key10=33:33 Key11=34:34 Key12=163:163 Key13=36:36 Key14=37:37 Key15=38:38 Key16=47:47 Key17=40:40 Key18=41:41 Key19=61:61 Key20=63:63 Key21=94:94 Key22=65288:8 Key23=65056:0 Key24=81:81 Key25=87:87 Key26=69:69 Key27=82:82 Key28=84:84 Key29=89:89 Key30=85:85 Key31=73:73 Key32=79:79 Key33=80:80 Key34=233:233 Key35=42:42 Key36=65293:13 Key37=65507:0 Key38=65:65 Key39=83:83 Key40=68:68 Key41=70:70 Key42=71:71 Key43=72:72 Key44=74:74 Key45=75:75 Key46=76:76 Key47=231:231 Key48=176:176 Key49=124:124 Key50=65505:0 Key51=167:167 Key52=90:90 Key53=88:88 Key54=67:67 Key55=86:86 Key56=66:66 Key57=78:78 Key58=77:77 Key59=59:59 Key60=58:58 Key61=95:95 Key62=65506:0 Key63=65450:42 Key64=65032:0 Key65=32:32 Key66=65509:0 Key67=65470:0 Key68=65471:0 Key69=65472:0 Key70=65473:0 Key71=65474:0 Key72=65475:0 Key73=65476:0 Key74=65477:0 Key75=65478:0 Key76=65479:0 Key77=65407:0 Key78=65300:0 Key79=65463:55 Key80=65464:56 Key81=65465:57 Key82=65453:45 Key83=65460:52 Key84=65461:53 Key85=65462:54 Key86=65451:43 Key87=65457:49 Key88=65458:50 Key89=65459:51 Key90=65456:48 Key91=65454:46 Key92=65377:0 Key93=0:0 Key94=62:62 Key95=65480:0 Key96=65481:0 Key97=65360:0 Key98=65362:0 Key99=65365:0 Key100=65361:0 Key101=0:0 Key102=65363:0 Key103=65367:0 Key104=65364:0 Key105=65366:0 Key106=65379:0 Key107=65535:127 Key108=65421:13 Key109=65508:0 Key110=65299:0 Key111=65377:0 Key112=65455:47 Key113=65027:0 Key114=269025049:0 Key115=65515:0 Key116=65312:0 Key117=0:0 Key118=269025153:0 Key119=269025093:0 Key120=269025094:0 Key121=269025095:0 Key122=269025096:0 Key123=0:0 Key124=65027:0 Key125=65513:0 Key126=65469:61 Key127=65515:0 Key128=65517:0 Key129=0:0 Key130=0:0 Key131=0:0 Key132=0:0 Key133=0:0 Key134=0:0 Key135=0:0 Key136=0:0 Key137=0:0 [altgr] Key8=65406:0 Key9=65307:27 Key10=185:185 Key11=178:178 Key12=179:179 Key13=188:188 Key14=189:189 Key15=172:172 Key16=123:123 Key17=91:91 Key18=93:93 Key19=125:125 Key20=96:96 Key21=126:126 Key22=65288:8 Key23=65289:9 Key24=64:64 Key25=435:322 Key26=8364:8364 Key27=182:182 Key28=956:359 Key29=2299:8592 Key30=2302:8595 Key31=2301:8594 Key32=248:248 Key33=254:254 Key34=91:91 Key35=93:93 Key36=65293:13 Key37=65507:0 Key38=230:230 Key39=223:223 Key40=240:240 Key41=496:273 Key42=959:331 Key43=689:295 Key44=65121:0 Key45=930:312 Key46=435:322 Key47=64:64 Key48=35:35 Key49=172:172 Key50=65505:0 Key51=65104:96 Key52=171:171 Key53=187:187 Key54=162:162 Key55=2770:8220 Key56=2771:8221 Key57=241:241 Key58=181:181 Key59=65105:180 Key60=183:183 Key61=65108:175 Key62=65506:0 Key63=65450:42 Key64=65513:0 Key65=32:32 Key66=65509:0 Key67=65470:0 Key68=65471:0 Key69=65472:0 Key70=65473:0 Key71=65474:0 Key72=65475:0 Key73=65476:0 Key74=65477:0 Key75=65478:0 Key76=65479:0 Key77=65407:0 Key78=65300:0 Key79=65429:0 Key80=65431:0 Key81=65434:0 Key82=65453:45 Key83=65430:0 Key84=65437:0 Key85=65432:0 Key86=65451:43 Key87=65436:0 Key88=65433:0 Key89=65435:0 Key90=65438:0 Key91=65439:0 Key92=65377:0 Key93=0:0 Key94=171:171 Key95=65480:0 Key96=65481:0 Key97=65360:0 Key98=65362:0 Key99=65365:0 Key100=65361:0 Key101=0:0 Key102=65363:0 Key103=65367:0 Key104=65364:0 Key105=65366:0 Key106=65379:0 Key107=65535:127 Key108=65421:13 Key109=65508:0 Key110=65299:0 Key111=65377:0 Key112=65455:47 Key113=65027:0 Key114=269025049:0 Key115=65515:0 Key116=65312:0 Key117=0:0 Key118=269025153:0 Key119=269025093:0 Key120=269025094:0 Key121=269025095:0 Key122=269025096:0 Key123=0:0 Key124=65027:0 Key125=0:0 Key126=65469:61 Key127=0:0 Key128=0:0 Key129=0:0 Key130=0:0 Key131=0:0 Key132=0:0 Key133=0:0 Key134=0:0 Key135=0:0 Key136=0:0 Key137=0:0 [shiftaltgr] Key8=65406:0 Key9=65307:27 Key10=161:161 Key11=65113:733 Key12=65107:126 Key13=2755:8539 Key14=2756:8540 Key15=2757:8541 Key16=2758:8542 Key17=2761:8482 Key18=177:177 Key19=65116:731 Key20=191:191 Key21=65106:94 Key22=65288:8 Key23=65056:0 Key24=2009:937 Key25=419:321 Key26=162:162 Key27=174:174 Key28=940:358 Key29=165:165 Key30=2300:8593 Key31=697:305 Key32=216:216 Key33=222:222 Key34=123:123 Key35=125:125 Key36=65293:13 Key37=65507:0 Key38=198:198 Key39=167:167 Key40=208:208 Key41=170:170 Key42=957:330 Key43=673:294 Key44=65122:0 Key45=38:38 Key46=419:321 Key47=65115:184 Key48=65112:176 Key49=166:166 Key50=65505:0 Key51=65109:728 Key52=60:60 Key53=62:62 Key54=169:169 Key55=2768:8216 Key56=2769:8217 Key57=209:209 Key58=186:186 Key59=215:215 Key60=65111:168 Key61=247:247 Key62=65506:0 Key63=65450:42 Key64=65032:0 Key65=32:32 Key66=65509:0 Key67=65470:0 Key68=65471:0 Key69=65472:0 Key70=65473:0 Key71=65474:0 Key72=65475:0 Key73=65476:0 Key74=65477:0 Key75=65478:0 Key76=65479:0 Key77=65407:0 Key78=65300:0 Key79=65463:55 Key80=65464:56 Key81=65465:57 Key82=65453:45 Key83=65460:52 Key84=65461:53 Key85=65462:54 Key86=65451:43 Key87=65457:49 Key88=65458:50 Key89=65459:51 Key90=65456:48 Key91=65454:46 Key92=65377:0 Key93=0:0 Key94=187:187 Key95=65480:0 Key96=65481:0 Key97=65360:0 Key98=65362:0 Key99=65365:0 Key100=65361:0 Key101=0:0 Key102=65363:0 Key103=65367:0 Key104=65364:0 Key105=65366:0 Key106=65379:0 Key107=65535:127 Key108=65421:13 Key109=65508:0 Key110=65299:0 Key111=65377:0 Key112=65455:47 Key113=65027:0 Key114=269025049:0 Key115=65515:0 Key116=65312:0 Key117=0:0 Key118=269025153:0 Key119=269025093:0 Key120=269025094:0 Key121=269025095:0 Key122=269025096:0 Key123=0:0 Key124=65027:0 Key125=65513:0 Key126=65469:61 Key127=65515:0 Key128=65517:0 Key129=0:0 Key130=0:0 Key131=0:0 Key132=0:0 Key133=0:0 Key134=0:0 Key135=0:0 Key136=0:0 Key137=0:0 [capslock] Key8=65406:0 Key9=65307:27 Key10=49:49 Key11=50:50 Key12=51:51 Key13=52:52 Key14=53:53 Key15=54:54 Key16=55:55 Key17=56:56 Key18=57:57 Key19=48:48 Key20=39:39 Key21=204:204 Key22=65288:8 Key23=65289:9 Key24=81:81 Key25=87:87 Key26=69:69 Key27=82:82 Key28=84:84 Key29=89:89 Key30=85:85 Key31=73:73 Key32=79:79 Key33=80:80 Key34=200:200 Key35=43:43 Key36=65293:13 Key37=65507:0 Key38=65:65 Key39=83:83 Key40=68:68 Key41=70:70 Key42=71:71 Key43=72:72 Key44=74:74 Key45=75:75 Key46=76:76 Key47=210:210 Key48=192:192 Key49=92:92 Key50=65505:0 Key51=217:217 Key52=90:90 Key53=88:88 Key54=67:67 Key55=86:86 Key56=66:66 Key57=78:78 Key58=77:77 Key59=44:44 Key60=46:46 Key61=45:45 Key62=65506:0 Key63=65450:42 Key64=65513:0 Key65=32:32 Key66=65509:0 Key67=65470:0 Key68=65471:0 Key69=65472:0 Key70=65473:0 Key71=65474:0 Key72=65475:0 Key73=65476:0 Key74=65477:0 Key75=65478:0 Key76=65479:0 Key77=65407:0 Key78=65300:0 Key79=65429:0 Key80=65431:0 Key81=65434:0 Key82=65453:45 Key83=65430:0 Key84=65437:0 Key85=65432:0 Key86=65451:43 Key87=65436:0 Key88=65433:0 Key89=65435:0 Key90=65438:0 Key91=65439:0 Key92=65377:0 Key93=0:0 Key94=60:60 Key95=65480:0 Key96=65481:0 Key97=65360:0 Key98=65362:0 Key99=65365:0 Key100=65361:0 Key101=0:0 Key102=65363:0 Key103=65367:0 Key104=65364:0 Key105=65366:0 Key106=65379:0 Key107=65535:127 Key108=65421:13 Key109=65508:0 Key110=65299:0 Key111=65377:0 Key112=65455:47 Key113=65027:0 Key114=269025049:0 Key115=65515:0 Key116=65312:0 Key117=0:0 Key118=269025153:0 Key119=269025093:0 Key120=269025094:0 Key121=269025095:0 Key122=269025096:0 Key123=0:0 Key124=65027:0 Key125=0:0 Key126=65469:61 Key127=0:0 Key128=0:0 Key129=0:0 Key130=0:0 Key131=0:0 Key132=0:0 Key133=0:0 Key134=0:0 Key135=0:0 Key136=0:0 Key137=0:0 [shiftcapslock] Key8=65406:0 Key9=65307:27 Key10=33:33 Key11=34:34 Key12=163:163 Key13=36:36 Key14=37:37 Key15=38:38 Key16=47:47 Key17=40:40 Key18=41:41 Key19=61:61 Key20=63:63 Key21=94:94 Key22=65288:8 Key23=65056:0 Key24=113:113 Key25=119:119 Key26=101:101 Key27=114:114 Key28=116:116 Key29=121:121 Key30=117:117 Key31=105:105 Key32=111:111 Key33=112:112 Key34=201:201 Key35=42:42 Key36=65293:13 Key37=65507:0 Key38=97:97 Key39=115:115 Key40=100:100 Key41=102:102 Key42=103:103 Key43=104:104 Key44=106:106 Key45=107:107 Key46=108:108 Key47=199:199 Key48=176:176 Key49=124:124 Key50=65505:0 Key51=167:167 Key52=122:122 Key53=120:120 Key54=99:99 Key55=118:118 Key56=98:98 Key57=110:110 Key58=109:109 Key59=59:59 Key60=58:58 Key61=95:95 Key62=65506:0 Key63=65450:42 Key64=65032:0 Key65=32:32 Key66=65509:0 Key67=65470:0 Key68=65471:0 Key69=65472:0 Key70=65473:0 Key71=65474:0 Key72=65475:0 Key73=65476:0 Key74=65477:0 Key75=65478:0 Key76=65479:0 Key77=65407:0 Key78=65300:0 Key79=65463:55 Key80=65464:56 Key81=65465:57 Key82=65453:45 Key83=65460:52 Key84=65461:53 Key85=65462:54 Key86=65451:43 Key87=65457:49 Key88=65458:50 Key89=65459:51 Key90=65456:48 Key91=65454:46 Key92=65377:0 Key93=0:0 Key94=62:62 Key95=65480:0 Key96=65481:0 Key97=65360:0 Key98=65362:0 Key99=65365:0 Key100=65361:0 Key101=0:0 Key102=65363:0 Key103=65367:0 Key104=65364:0 Key105=65366:0 Key106=65379:0 Key107=65535:127 Key108=65421:13 Key109=65508:0 Key110=65299:0 Key111=65377:0 Key112=65455:47 Key113=65027:0 Key114=269025049:0 Key115=65515:0 Key116=65312:0 Key117=0:0 Key118=269025153:0 Key119=269025093:0 Key120=269025094:0 Key121=269025095:0 Key122=269025096:0 Key123=0:0 Key124=65027:0 Key125=65513:0 Key126=65469:61 Key127=65515:0 Key128=65517:0 Key129=0:0 Key130=0:0 Key131=0:0 Key132=0:0 Key133=0:0 Key134=0:0 Key135=0:0 Key136=0:0 Key137=0:0 xrdp-0.9.5/instfiles/km-00000419.ini000644 001751 001751 00000026070 13127114621 016430 0ustar00metameta000000 000000 [noshift] Key8=65406:0 Key9=65307:27 Key10=49:49 Key11=50:50 Key12=51:51 Key13=52:52 Key14=53:53 Key15=54:54 Key16=55:55 Key17=56:56 Key18=57:57 Key19=48:48 Key20=45:45 Key21=61:61 Key22=65288:8 Key23=65289:9 Key24=1738:1081 Key25=1731:1094 Key26=1749:1091 Key27=1739:1082 Key28=1733:1077 Key29=1742:1085 Key30=1735:1075 Key31=1755:1096 Key32=1757:1097 Key33=1754:1079 Key34=1736:1093 Key35=1759:1098 Key36=65293:13 Key37=65507:0 Key38=1734:1092 Key39=1753:1099 Key40=1751:1074 Key41=1729:1072 Key42=1744:1087 Key43=1746:1088 Key44=1743:1086 Key45=1740:1083 Key46=1732:1076 Key47=1750:1078 Key48=1756:1101 Key49=1699:1105 Key50=65505:0 Key51=92:92 Key52=1745:1103 Key53=1758:1095 Key54=1747:1089 Key55=1741:1084 Key56=1737:1080 Key57=1748:1090 Key58=1752:1100 Key59=1730:1073 Key60=1728:1102 Key61=46:46 Key62=65506:0 Key63=65450:42 Key64=65513:0 Key65=32:32 Key66=65509:0 Key67=65470:0 Key68=65471:0 Key69=65472:0 Key70=65473:0 Key71=65474:0 Key72=65475:0 Key73=65476:0 Key74=65477:0 Key75=65478:0 Key76=65479:0 Key77=65407:0 Key78=65300:0 Key79=65429:0 Key80=65431:0 Key81=65434:0 Key82=65453:45 Key83=65430:0 Key84=65437:0 Key85=65432:0 Key86=65451:43 Key87=65436:0 Key88=65433:0 Key89=65435:0 Key90=65438:0 Key91=65439:0 Key92=65377:0 Key93=0:0 Key94=47:47 Key95=65480:0 Key96=65481:0 Key97=65360:0 Key98=65362:0 Key99=65365:0 Key100=65361:0 Key101=0:0 Key102=65363:0 Key103=65367:0 Key104=65364:0 Key105=65366:0 Key106=65379:0 Key107=65535:127 Key108=65421:13 Key109=65508:0 Key110=65299:0 Key111=65377:0 Key112=65455:47 Key113=65514:0 Key114=269025049:0 Key115=65515:0 Key116=65312:0 Key117=0:0 Key118=269025153:0 Key119=269025093:0 Key120=269025094:0 Key121=269025095:0 Key122=269025096:0 Key123=0:0 Key124=65027:0 Key125=0:0 Key126=65469:61 Key127=0:0 Key128=0:0 Key129=0:0 Key130=0:0 Key131=0:0 Key132=0:0 Key133=0:0 Key134=0:0 Key135=0:0 Key136=0:0 Key137=0:0 [shift] Key8=65406:0 Key9=65307:27 Key10=33:33 Key11=34:34 Key12=1712:8470 Key13=59:59 Key14=37:37 Key15=58:58 Key16=63:63 Key17=42:42 Key18=40:40 Key19=41:41 Key20=95:95 Key21=43:43 Key22=65288:8 Key23=65056:0 Key24=1770:1049 Key25=1763:1062 Key26=1781:1059 Key27=1771:1050 Key28=1765:1045 Key29=1774:1053 Key30=1767:1043 Key31=1787:1064 Key32=1789:1065 Key33=1786:1047 Key34=1768:1061 Key35=1791:1066 Key36=65293:13 Key37=65507:0 Key38=1766:1060 Key39=1785:1067 Key40=1783:1042 Key41=1761:1040 Key42=1776:1055 Key43=1778:1056 Key44=1775:1054 Key45=1772:1051 Key46=1764:1044 Key47=1782:1046 Key48=1788:1069 Key49=1715:1025 Key50=65505:0 Key51=47:47 Key52=1777:1071 Key53=1790:1063 Key54=1779:1057 Key55=1773:1052 Key56=1769:1048 Key57=1780:1058 Key58=1784:1068 Key59=1762:1041 Key60=1760:1070 Key61=44:44 Key62=65506:0 Key63=65450:42 Key64=65032:0 Key65=32:32 Key66=65509:0 Key67=65470:0 Key68=65471:0 Key69=65472:0 Key70=65473:0 Key71=65474:0 Key72=65475:0 Key73=65476:0 Key74=65477:0 Key75=65478:0 Key76=65479:0 Key77=65407:0 Key78=65300:0 Key79=65463:55 Key80=65464:56 Key81=65465:57 Key82=65453:45 Key83=65460:52 Key84=65461:53 Key85=65462:54 Key86=65451:43 Key87=65457:49 Key88=65458:50 Key89=65459:51 Key90=65456:48 Key91=65452:44 Key92=65377:0 Key93=0:0 Key94=124:124 Key95=65480:0 Key96=65481:0 Key97=65360:0 Key98=65362:0 Key99=65365:0 Key100=65361:0 Key101=0:0 Key102=65363:0 Key103=65367:0 Key104=65364:0 Key105=65366:0 Key106=65379:0 Key107=65535:127 Key108=65421:13 Key109=65508:0 Key110=65299:0 Key111=65377:0 Key112=65455:47 Key113=65032:0 Key114=269025049:0 Key115=65515:0 Key116=65312:0 Key117=0:0 Key118=269025153:0 Key119=269025093:0 Key120=269025094:0 Key121=269025095:0 Key122=269025096:0 Key123=0:0 Key124=65027:0 Key125=65513:0 Key126=65469:61 Key127=65515:0 Key128=65517:0 Key129=0:0 Key130=0:0 Key131=0:0 Key132=0:0 Key133=0:0 Key134=0:0 Key135=0:0 Key136=0:0 Key137=0:0 [altgr] Key8=65406:0 Key9=65307:27 Key10=49:49 Key11=50:50 Key12=51:51 Key13=52:52 Key14=53:53 Key15=54:54 Key16=55:55 Key17=56:56 Key18=57:57 Key19=48:48 Key20=45:45 Key21=61:61 Key22=65288:8 Key23=65289:9 Key24=1738:1081 Key25=1731:1094 Key26=1749:1091 Key27=1739:1082 Key28=1733:1077 Key29=1742:1085 Key30=1735:1075 Key31=1755:1096 Key32=1757:1097 Key33=1754:1079 Key34=1736:1093 Key35=1759:1098 Key36=65293:13 Key37=65507:0 Key38=1734:1092 Key39=1753:1099 Key40=1751:1074 Key41=1729:1072 Key42=1744:1087 Key43=1746:1088 Key44=1743:1086 Key45=1740:1083 Key46=1732:1076 Key47=1750:1078 Key48=1756:1101 Key49=1699:1105 Key50=65505:0 Key51=92:92 Key52=1745:1103 Key53=1758:1095 Key54=1747:1089 Key55=1741:1084 Key56=1737:1080 Key57=1748:1090 Key58=1752:1100 Key59=1730:1073 Key60=1728:1102 Key61=46:46 Key62=65506:0 Key63=65450:42 Key64=65513:0 Key65=32:32 Key66=65509:0 Key67=65470:0 Key68=65471:0 Key69=65472:0 Key70=65473:0 Key71=65474:0 Key72=65475:0 Key73=65476:0 Key74=65477:0 Key75=65478:0 Key76=65479:0 Key77=65407:0 Key78=65300:0 Key79=65429:0 Key80=65431:0 Key81=65434:0 Key82=65453:45 Key83=65430:0 Key84=65437:0 Key85=65432:0 Key86=65451:43 Key87=65436:0 Key88=65433:0 Key89=65435:0 Key90=65438:0 Key91=65439:0 Key92=65377:0 Key93=0:0 Key94=124:124 Key95=65480:0 Key96=65481:0 Key97=65360:0 Key98=65362:0 Key99=65365:0 Key100=65361:0 Key101=0:0 Key102=65363:0 Key103=65367:0 Key104=65364:0 Key105=65366:0 Key106=65379:0 Key107=65535:127 Key108=65421:13 Key109=65508:0 Key110=65299:0 Key111=65377:0 Key112=65455:47 Key113=65514:0 Key114=269025049:0 Key115=65515:0 Key116=65312:0 Key117=0:0 Key118=269025153:0 Key119=269025093:0 Key120=269025094:0 Key121=269025095:0 Key122=269025096:0 Key123=0:0 Key124=65027:0 Key125=0:0 Key126=65469:61 Key127=0:0 Key128=0:0 Key129=0:0 Key130=0:0 Key131=0:0 Key132=0:0 Key133=0:0 Key134=0:0 Key135=0:0 Key136=0:0 Key137=0:0 [shiftaltgr] Key8=65406:0 Key9=65307:27 Key10=33:33 Key11=34:34 Key12=1712:8470 Key13=59:59 Key14=37:37 Key15=58:58 Key16=63:63 Key17=42:42 Key18=40:40 Key19=41:41 Key20=95:95 Key21=43:43 Key22=65288:8 Key23=65056:0 Key24=1770:1049 Key25=1763:1062 Key26=1781:1059 Key27=1771:1050 Key28=1765:1045 Key29=1774:1053 Key30=1767:1043 Key31=1787:1064 Key32=1789:1065 Key33=1786:1047 Key34=1768:1061 Key35=1791:1066 Key36=65293:13 Key37=65507:0 Key38=1766:1060 Key39=1785:1067 Key40=1783:1042 Key41=1761:1040 Key42=1776:1055 Key43=1778:1056 Key44=1775:1054 Key45=1772:1051 Key46=1764:1044 Key47=1782:1046 Key48=1788:1069 Key49=1715:1025 Key50=65505:0 Key51=47:47 Key52=1777:1071 Key53=1790:1063 Key54=1779:1057 Key55=1773:1052 Key56=1769:1048 Key57=1780:1058 Key58=1784:1068 Key59=1762:1041 Key60=1760:1070 Key61=44:44 Key62=65506:0 Key63=65450:42 Key64=65032:0 Key65=32:32 Key66=65509:0 Key67=65470:0 Key68=65471:0 Key69=65472:0 Key70=65473:0 Key71=65474:0 Key72=65475:0 Key73=65476:0 Key74=65477:0 Key75=65478:0 Key76=65479:0 Key77=65407:0 Key78=65300:0 Key79=65463:55 Key80=65464:56 Key81=65465:57 Key82=65453:45 Key83=65460:52 Key84=65461:53 Key85=65462:54 Key86=65451:43 Key87=65457:49 Key88=65458:50 Key89=65459:51 Key90=65456:48 Key91=65452:44 Key92=65377:0 Key93=0:0 Key94=166:166 Key95=65480:0 Key96=65481:0 Key97=65360:0 Key98=65362:0 Key99=65365:0 Key100=65361:0 Key101=0:0 Key102=65363:0 Key103=65367:0 Key104=65364:0 Key105=65366:0 Key106=65379:0 Key107=65535:127 Key108=65421:13 Key109=65508:0 Key110=65299:0 Key111=65377:0 Key112=65455:47 Key113=65032:0 Key114=269025049:0 Key115=65515:0 Key116=65312:0 Key117=0:0 Key118=269025153:0 Key119=269025093:0 Key120=269025094:0 Key121=269025095:0 Key122=269025096:0 Key123=0:0 Key124=65027:0 Key125=65513:0 Key126=65469:61 Key127=65515:0 Key128=65517:0 Key129=0:0 Key130=0:0 Key131=0:0 Key132=0:0 Key133=0:0 Key134=0:0 Key135=0:0 Key136=0:0 Key137=0:0 [capslock] Key8=65406:0 Key9=65307:27 Key10=49:49 Key11=50:50 Key12=51:51 Key13=52:52 Key14=53:53 Key15=54:54 Key16=55:55 Key17=56:56 Key18=57:57 Key19=48:48 Key20=45:45 Key21=61:61 Key22=65288:8 Key23=65289:9 Key24=1770:1049 Key25=1763:1062 Key26=1781:1059 Key27=1771:1050 Key28=1765:1045 Key29=1774:1053 Key30=1767:1043 Key31=1787:1064 Key32=1789:1065 Key33=1786:1047 Key34=1768:1061 Key35=1791:1066 Key36=65293:13 Key37=65507:0 Key38=1766:1060 Key39=1785:1067 Key40=1783:1042 Key41=1761:1040 Key42=1776:1055 Key43=1778:1056 Key44=1775:1054 Key45=1772:1051 Key46=1764:1044 Key47=1782:1046 Key48=1788:1069 Key49=1715:1025 Key50=65505:0 Key51=92:92 Key52=1777:1071 Key53=1790:1063 Key54=1779:1057 Key55=1773:1052 Key56=1769:1048 Key57=1780:1058 Key58=1784:1068 Key59=1762:1041 Key60=1760:1070 Key61=46:46 Key62=65506:0 Key63=65450:42 Key64=65513:0 Key65=32:32 Key66=65509:0 Key67=65470:0 Key68=65471:0 Key69=65472:0 Key70=65473:0 Key71=65474:0 Key72=65475:0 Key73=65476:0 Key74=65477:0 Key75=65478:0 Key76=65479:0 Key77=65407:0 Key78=65300:0 Key79=65429:0 Key80=65431:0 Key81=65434:0 Key82=65453:45 Key83=65430:0 Key84=65437:0 Key85=65432:0 Key86=65451:43 Key87=65436:0 Key88=65433:0 Key89=65435:0 Key90=65438:0 Key91=65439:0 Key92=65377:0 Key93=0:0 Key94=47:47 Key95=65480:0 Key96=65481:0 Key97=65360:0 Key98=65362:0 Key99=65365:0 Key100=65361:0 Key101=0:0 Key102=65363:0 Key103=65367:0 Key104=65364:0 Key105=65366:0 Key106=65379:0 Key107=65535:127 Key108=65421:13 Key109=65508:0 Key110=65299:0 Key111=65377:0 Key112=65455:47 Key113=65514:0 Key114=269025049:0 Key115=65515:0 Key116=65312:0 Key117=0:0 Key118=269025153:0 Key119=269025093:0 Key120=269025094:0 Key121=269025095:0 Key122=269025096:0 Key123=0:0 Key124=65027:0 Key125=0:0 Key126=65469:61 Key127=0:0 Key128=0:0 Key129=0:0 Key130=0:0 Key131=0:0 Key132=0:0 Key133=0:0 Key134=0:0 Key135=0:0 Key136=0:0 Key137=0:0 [shiftcapslock] Key8=65406:0 Key9=65307:27 Key10=33:33 Key11=34:34 Key12=1712:8470 Key13=59:59 Key14=37:37 Key15=58:58 Key16=63:63 Key17=42:42 Key18=40:40 Key19=41:41 Key20=95:95 Key21=43:43 Key22=65288:8 Key23=65056:0 Key24=1738:1081 Key25=1731:1094 Key26=1749:1091 Key27=1739:1082 Key28=1733:1077 Key29=1742:1085 Key30=1735:1075 Key31=1755:1096 Key32=1757:1097 Key33=1754:1079 Key34=1736:1093 Key35=1759:1098 Key36=65293:13 Key37=65507:0 Key38=1734:1092 Key39=1753:1099 Key40=1751:1074 Key41=1729:1072 Key42=1744:1087 Key43=1746:1088 Key44=1743:1086 Key45=1740:1083 Key46=1732:1076 Key47=1750:1078 Key48=1756:1101 Key49=1699:1105 Key50=65505:0 Key51=47:47 Key52=1745:1103 Key53=1758:1095 Key54=1747:1089 Key55=1741:1084 Key56=1737:1080 Key57=1748:1090 Key58=1752:1100 Key59=1730:1073 Key60=1728:1102 Key61=44:44 Key62=65506:0 Key63=65450:42 Key64=65032:0 Key65=32:32 Key66=65509:0 Key67=65470:0 Key68=65471:0 Key69=65472:0 Key70=65473:0 Key71=65474:0 Key72=65475:0 Key73=65476:0 Key74=65477:0 Key75=65478:0 Key76=65479:0 Key77=65407:0 Key78=65300:0 Key79=65463:55 Key80=65464:56 Key81=65465:57 Key82=65453:45 Key83=65460:52 Key84=65461:53 Key85=65462:54 Key86=65451:43 Key87=65457:49 Key88=65458:50 Key89=65459:51 Key90=65456:48 Key91=65452:44 Key92=65377:0 Key93=0:0 Key94=124:124 Key95=65480:0 Key96=65481:0 Key97=65360:0 Key98=65362:0 Key99=65365:0 Key100=65361:0 Key101=0:0 Key102=65363:0 Key103=65367:0 Key104=65364:0 Key105=65366:0 Key106=65379:0 Key107=65535:127 Key108=65421:13 Key109=65508:0 Key110=65299:0 Key111=65377:0 Key112=65455:47 Key113=65032:0 Key114=269025049:0 Key115=65515:0 Key116=65312:0 Key117=0:0 Key118=269025153:0 Key119=269025093:0 Key120=269025094:0 Key121=269025095:0 Key122=269025096:0 Key123=0:0 Key124=65027:0 Key125=65513:0 Key126=65469:61 Key127=65515:0 Key128=65517:0 Key129=0:0 Key130=0:0 Key131=0:0 Key132=0:0 Key133=0:0 Key134=0:0 Key135=0:0 Key136=0:0 Key137=0:0 xrdp-0.9.5/instfiles/km-00010409.ini000644 001751 001751 00000033246 13220727201 016431 0ustar00metameta000000 000000 [noshift] Key8=65406:0 Key9=65307:27 Key10=49:49 Key11=50:50 Key12=51:51 Key13=52:52 Key14=53:53 Key15=54:54 Key16=55:55 Key17=56:56 Key18=57:57 Key19=48:48 Key20=91:91 Key21=93:93 Key22=65288:8 Key23=65289:9 Key24=39:39 Key25=44:44 Key26=46:46 Key27=112:112 Key28=121:121 Key29=102:102 Key30=103:103 Key31=99:99 Key32=114:114 Key33=108:108 Key34=47:47 Key35=61:61 Key36=65293:13 Key37=65507:0 Key38=97:97 Key39=111:111 Key40=101:101 Key41=117:117 Key42=105:105 Key43=100:100 Key44=104:104 Key45=116:116 Key46=110:110 Key47=115:115 Key48=45:45 Key49=96:96 Key50=65505:0 Key51=92:92 Key52=59:59 Key53=113:113 Key54=106:106 Key55=107:107 Key56=120:120 Key57=98:98 Key58=109:109 Key59=119:119 Key60=118:118 Key61=122:122 Key62=65506:0 Key63=65450:42 Key64=65513:0 Key65=32:32 Key66=65509:0 Key67=65470:0 Key68=65471:0 Key69=65472:0 Key70=65473:0 Key71=65474:0 Key72=65475:0 Key73=65476:0 Key74=65477:0 Key75=65478:0 Key76=65479:0 Key77=65407:0 Key78=65300:0 Key79=65429:0 Key80=65431:0 Key81=65434:0 Key82=65453:45 Key83=65430:0 Key84=65437:0 Key85=65432:0 Key86=65451:43 Key87=65436:0 Key88=65433:0 Key89=65435:0 Key90=65438:0 Key91=65439:0 Key92=0:0 Key93=0:0 Key94=60:60 Key95=65480:0 Key96=65481:0 Key97=65360:0 Key98=65362:0 Key99=65365:0 Key100=65361:0 Key101=0:0 Key102=65363:0 Key103=65367:0 Key104=65364:0 Key105=65366:0 Key106=65379:0 Key107=65535:127 Key108=65421:13 Key109=65508:0 Key110=65299:0 Key111=65377:0 Key112=65455:47 Key113=65516:0 Key114=0:0 Key115=65515:0 Key116=65514:0 Key117=65383:0 Key118=0:0 Key119=0:0 Key120=0:0 Key121=0:0 Key122=0:0 Key123=0:0 Key124=65027:0 Key125=0:0 Key126=65469:61 Key127=0:0 Key128=0:0 Key129=0:0 Key130=0:0 Key131=0:0 Key132=0:0 Key133=0:0 Key134=65454:46 Key135=0:0 Key136=0:0 Key137=0:0 [shift] Key8=65406:0 Key9=65307:27 Key10=33:33 Key11=64:64 Key12=35:35 Key13=36:36 Key14=37:37 Key15=94:94 Key16=38:38 Key17=42:42 Key18=40:40 Key19=41:41 Key20=123:123 Key21=125:125 Key22=65288:8 Key23=65056:0 Key24=34:34 Key25=60:60 Key26=62:62 Key27=80:80 Key28=89:89 Key29=70:70 Key30=71:71 Key31=67:67 Key32=82:82 Key33=76:76 Key34=63:63 Key35=43:43 Key36=65293:13 Key37=65507:0 Key38=65:65 Key39=79:79 Key40=69:69 Key41=85:85 Key42=73:73 Key43=68:68 Key44=72:72 Key45=84:84 Key46=78:78 Key47=83:83 Key48=95:95 Key49=126:126 Key50=65505:0 Key51=124:124 Key52=58:58 Key53=81:81 Key54=74:74 Key55=75:75 Key56=88:88 Key57=66:66 Key58=77:77 Key59=87:87 Key60=86:86 Key61=90:90 Key62=65506:0 Key63=65450:42 Key64=65511:0 Key65=32:32 Key66=65509:0 Key67=65470:0 Key68=65471:0 Key69=65472:0 Key70=65473:0 Key71=65474:0 Key72=65475:0 Key73=65476:0 Key74=65477:0 Key75=65478:0 Key76=65479:0 Key77=65407:0 Key78=65300:0 Key79=65463:55 Key80=65464:56 Key81=65465:57 Key82=65453:45 Key83=65460:52 Key84=65461:53 Key85=65462:54 Key86=65451:43 Key87=65457:49 Key88=65458:50 Key89=65459:51 Key90=65456:48 Key91=65454:46 Key92=0:0 Key93=0:0 Key94=62:62 Key95=65480:0 Key96=65481:0 Key97=65360:0 Key98=65362:0 Key99=65365:0 Key100=65361:0 Key101=0:0 Key102=65363:0 Key103=65367:0 Key104=65364:0 Key105=65366:0 Key106=65379:0 Key107=65535:127 Key108=65421:13 Key109=65508:0 Key110=65299:0 Key111=65377:0 Key112=65455:47 Key113=65516:0 Key114=0:0 Key115=65515:0 Key116=65512:0 Key117=65383:0 Key118=0:0 Key119=0:0 Key120=0:0 Key121=0:0 Key122=0:0 Key123=0:0 Key124=65027:0 Key125=65513:0 Key126=65469:61 Key127=65515:0 Key128=65517:0 Key129=0:0 Key130=0:0 Key131=0:0 Key132=0:0 Key133=0:0 Key134=65454:46 Key135=0:0 Key136=0:0 Key137=0:0 [altgr] Key8=65406:0 Key9=65307:27 Key10=49:49 Key11=50:50 Key12=51:51 Key13=52:52 Key14=53:53 Key15=65106:94 Key16=55:55 Key17=56:56 Key18=65104:96 Key19=48:48 Key20=91:91 Key21=65107:126 Key22=65288:8 Key23=65289:9 Key24=65105:180 Key25=65115:184 Key26=65110:729 Key27=112:112 Key28=121:121 Key29=102:102 Key30=103:103 Key31=99:99 Key32=114:114 Key33=108:108 Key34=47:47 Key35=61:61 Key36=65293:13 Key37=65507:0 Key38=97:97 Key39=111:111 Key40=101:101 Key41=117:117 Key42=105:105 Key43=100:100 Key44=104:104 Key45=116:116 Key46=110:110 Key47=115:115 Key48=45:45 Key49=65104:96 Key50=65505:0 Key51=92:92 Key52=65116:731 Key53=113:113 Key54=106:106 Key55=107:107 Key56=120:120 Key57=98:98 Key58=109:109 Key59=119:119 Key60=118:118 Key61=122:122 Key62=65506:0 Key63=65450:42 Key64=65513:0 Key65=32:32 Key66=65509:0 Key67=65470:0 Key68=65471:0 Key69=65472:0 Key70=65473:0 Key71=65474:0 Key72=65475:0 Key73=65476:0 Key74=65477:0 Key75=65478:0 Key76=65479:0 Key77=65407:0 Key78=65300:0 Key79=65429:0 Key80=65431:0 Key81=65434:0 Key82=65453:45 Key83=65430:0 Key84=65437:0 Key85=65432:0 Key86=65451:43 Key87=65436:0 Key88=65433:0 Key89=65435:0 Key90=65438:0 Key91=65439:0 Key92=0:0 Key93=0:0 Key94=124:124 Key95=65480:0 Key96=65481:0 Key97=65360:0 Key98=65362:0 Key99=65365:0 Key100=65361:0 Key101=0:0 Key102=65363:0 Key103=65367:0 Key104=65364:0 Key105=65366:0 Key106=65379:0 Key107=65535:127 Key108=65421:13 Key109=65508:0 Key110=65299:0 Key111=65377:0 Key112=65455:47 Key113=65516:0 Key114=0:0 Key115=65515:0 Key116=65514:0 Key117=65383:0 Key118=0:0 Key119=0:0 Key120=0:0 Key121=0:0 Key122=0:0 Key123=0:0 Key124=65027:0 Key125=0:0 Key126=65469:61 Key127=0:0 Key128=0:0 Key129=0:0 Key130=0:0 Key131=0:0 Key132=0:0 Key133=0:0 Key134=65454:46 Key135=0:0 Key136=0:0 Key137=0:0 [shiftaltgr] Key8=65406:0 Key9=65307:27 Key10=33:33 Key11=64:64 Key12=35:35 Key13=36:36 Key14=37:37 Key15=65106:94 Key16=38:38 Key17=42:42 Key18=0:0 Key19=41:41 Key20=123:123 Key21=0:0 Key22=65288:8 Key23=65056:0 Key24=65111:168 Key25=65114:711 Key26=183:183 Key27=80:80 Key28=89:89 Key29=70:70 Key30=71:71 Key31=67:67 Key32=82:82 Key33=76:76 Key34=63:63 Key35=43:43 Key36=65293:13 Key37=65507:0 Key38=65:65 Key39=79:79 Key40=69:69 Key41=85:85 Key42=73:73 Key43=68:68 Key44=72:72 Key45=84:84 Key46=78:78 Key47=83:83 Key48=95:95 Key49=65107:126 Key50=65505:0 Key51=124:124 Key52=65113:733 Key53=81:81 Key54=74:74 Key55=75:75 Key56=88:88 Key57=66:66 Key58=77:77 Key59=87:87 Key60=86:86 Key61=90:90 Key62=65506:0 Key63=65450:42 Key64=65511:0 Key65=32:32 Key66=65509:0 Key67=65470:0 Key68=65471:0 Key69=65472:0 Key70=65473:0 Key71=65474:0 Key72=65475:0 Key73=65476:0 Key74=65477:0 Key75=65478:0 Key76=65479:0 Key77=65407:0 Key78=65300:0 Key79=65463:55 Key80=65464:56 Key81=65465:57 Key82=65453:45 Key83=65460:52 Key84=65461:53 Key85=65462:54 Key86=65451:43 Key87=65457:49 Key88=65458:50 Key89=65459:51 Key90=65456:48 Key91=65454:46 Key92=0:0 Key93=0:0 Key94=166:166 Key95=65480:0 Key96=65481:0 Key97=65360:0 Key98=65362:0 Key99=65365:0 Key100=65361:0 Key101=0:0 Key102=65363:0 Key103=65367:0 Key104=65364:0 Key105=65366:0 Key106=65379:0 Key107=65535:127 Key108=65421:13 Key109=65508:0 Key110=65299:0 Key111=65377:0 Key112=65455:47 Key113=65516:0 Key114=0:0 Key115=65515:0 Key116=65512:0 Key117=65383:0 Key118=0:0 Key119=0:0 Key120=0:0 Key121=0:0 Key122=0:0 Key123=0:0 Key124=65027:0 Key125=65513:0 Key126=65469:61 Key127=65515:0 Key128=65517:0 Key129=0:0 Key130=0:0 Key131=0:0 Key132=0:0 Key133=0:0 Key134=65454:46 Key135=0:0 Key136=0:0 Key137=0:0 [capslock] Key8=65406:0 Key9=65307:27 Key10=49:49 Key11=50:50 Key12=51:51 Key13=52:52 Key14=53:53 Key15=54:54 Key16=55:55 Key17=56:56 Key18=57:57 Key19=48:48 Key20=91:91 Key21=93:93 Key22=65288:8 Key23=65289:9 Key24=39:39 Key25=44:44 Key26=46:46 Key27=80:80 Key28=89:89 Key29=70:70 Key30=71:71 Key31=67:67 Key32=82:82 Key33=76:76 Key34=47:47 Key35=61:61 Key36=65293:13 Key37=65507:0 Key38=65:65 Key39=79:79 Key40=69:69 Key41=85:85 Key42=73:73 Key43=68:68 Key44=72:72 Key45=84:84 Key46=78:78 Key47=83:83 Key48=45:45 Key49=96:96 Key50=65505:0 Key51=92:92 Key52=59:59 Key53=81:81 Key54=74:74 Key55=75:75 Key56=88:88 Key57=66:66 Key58=77:77 Key59=87:87 Key60=86:86 Key61=90:90 Key62=65506:0 Key63=65450:42 Key64=65513:0 Key65=32:32 Key66=65509:0 Key67=65470:0 Key68=65471:0 Key69=65472:0 Key70=65473:0 Key71=65474:0 Key72=65475:0 Key73=65476:0 Key74=65477:0 Key75=65478:0 Key76=65479:0 Key77=65407:0 Key78=65300:0 Key79=65429:0 Key80=65431:0 Key81=65434:0 Key82=65453:45 Key83=65430:0 Key84=65437:0 Key85=65432:0 Key86=65451:43 Key87=65436:0 Key88=65433:0 Key89=65435:0 Key90=65438:0 Key91=65439:0 Key92=0:0 Key93=0:0 Key94=60:60 Key95=65480:0 Key96=65481:0 Key97=65360:0 Key98=65362:0 Key99=65365:0 Key100=65361:0 Key101=0:0 Key102=65363:0 Key103=65367:0 Key104=65364:0 Key105=65366:0 Key106=65379:0 Key107=65535:127 Key108=65421:13 Key109=65508:0 Key110=65299:0 Key111=65377:0 Key112=65455:47 Key113=65516:0 Key114=0:0 Key115=65515:0 Key116=65514:0 Key117=65383:0 Key118=0:0 Key119=0:0 Key120=0:0 Key121=0:0 Key122=0:0 Key123=0:0 Key124=65027:0 Key125=0:0 Key126=65469:61 Key127=0:0 Key128=0:0 Key129=0:0 Key130=0:0 Key131=0:0 Key132=0:0 Key133=0:0 Key134=65454:46 Key135=0:0 Key136=0:0 Key137=0:0 [capslockaltgr] Key8=65406:0 Key9=65307:27 Key10=49:49 Key11=50:50 Key12=51:51 Key13=52:52 Key14=53:53 Key15=65106:94 Key16=55:55 Key17=56:56 Key18=65104:96 Key19=48:48 Key20=91:91 Key21=65107:126 Key22=65288:8 Key23=65289:9 Key24=65105:180 Key25=65115:184 Key26=65110:729 Key27=80:80 Key28=89:89 Key29=70:70 Key30=71:71 Key31=67:67 Key32=82:82 Key33=76:76 Key34=47:47 Key35=61:61 Key36=65293:13 Key37=65507:0 Key38=65:65 Key39=79:79 Key40=69:69 Key41=85:85 Key42=73:73 Key43=68:68 Key44=72:72 Key45=84:84 Key46=78:78 Key47=83:83 Key48=45:45 Key49=65104:96 Key50=65505:0 Key51=92:92 Key52=65116:731 Key53=81:81 Key54=74:74 Key55=75:75 Key56=88:88 Key57=66:66 Key58=77:77 Key59=87:87 Key60=86:86 Key61=90:90 Key62=65506:0 Key63=65450:42 Key64=65513:0 Key65=32:32 Key66=65509:0 Key67=65470:0 Key68=65471:0 Key69=65472:0 Key70=65473:0 Key71=65474:0 Key72=65475:0 Key73=65476:0 Key74=65477:0 Key75=65478:0 Key76=65479:0 Key77=65407:0 Key78=65300:0 Key79=65429:0 Key80=65431:0 Key81=65434:0 Key82=65453:45 Key83=65430:0 Key84=65437:0 Key85=65432:0 Key86=65451:43 Key87=65436:0 Key88=65433:0 Key89=65435:0 Key90=65438:0 Key91=65439:0 Key92=0:0 Key93=0:0 Key94=124:124 Key95=65480:0 Key96=65481:0 Key97=65360:0 Key98=65362:0 Key99=65365:0 Key100=65361:0 Key101=0:0 Key102=65363:0 Key103=65367:0 Key104=65364:0 Key105=65366:0 Key106=65379:0 Key107=65535:127 Key108=65421:13 Key109=65508:0 Key110=65299:0 Key111=65377:0 Key112=65455:47 Key113=65516:0 Key114=0:0 Key115=65515:0 Key116=65514:0 Key117=65383:0 Key118=0:0 Key119=0:0 Key120=0:0 Key121=0:0 Key122=0:0 Key123=0:0 Key124=65027:0 Key125=0:0 Key126=65469:61 Key127=0:0 Key128=0:0 Key129=0:0 Key130=0:0 Key131=0:0 Key132=0:0 Key133=0:0 Key134=65454:46 Key135=0:0 Key136=0:0 Key137=0:0 [shiftcapslock] Key8=65406:0 Key9=65307:27 Key10=33:33 Key11=64:64 Key12=35:35 Key13=36:36 Key14=37:37 Key15=94:94 Key16=38:38 Key17=42:42 Key18=40:40 Key19=41:41 Key20=123:123 Key21=125:125 Key22=65288:8 Key23=65056:0 Key24=34:34 Key25=60:60 Key26=62:62 Key27=112:112 Key28=121:121 Key29=102:102 Key30=103:103 Key31=99:99 Key32=114:114 Key33=108:108 Key34=63:63 Key35=43:43 Key36=65293:13 Key37=65507:0 Key38=97:97 Key39=111:111 Key40=101:101 Key41=117:117 Key42=105:105 Key43=100:100 Key44=104:104 Key45=116:116 Key46=110:110 Key47=115:115 Key48=95:95 Key49=126:126 Key50=65505:0 Key51=124:124 Key52=58:58 Key53=113:113 Key54=106:106 Key55=107:107 Key56=120:120 Key57=98:98 Key58=109:109 Key59=119:119 Key60=118:118 Key61=122:122 Key62=65506:0 Key63=65450:42 Key64=65511:0 Key65=32:32 Key66=65509:0 Key67=65470:0 Key68=65471:0 Key69=65472:0 Key70=65473:0 Key71=65474:0 Key72=65475:0 Key73=65476:0 Key74=65477:0 Key75=65478:0 Key76=65479:0 Key77=65407:0 Key78=65300:0 Key79=65463:55 Key80=65464:56 Key81=65465:57 Key82=65453:45 Key83=65460:52 Key84=65461:53 Key85=65462:54 Key86=65451:43 Key87=65457:49 Key88=65458:50 Key89=65459:51 Key90=65456:48 Key91=65454:46 Key92=0:0 Key93=0:0 Key94=62:62 Key95=65480:0 Key96=65481:0 Key97=65360:0 Key98=65362:0 Key99=65365:0 Key100=65361:0 Key101=0:0 Key102=65363:0 Key103=65367:0 Key104=65364:0 Key105=65366:0 Key106=65379:0 Key107=65535:127 Key108=65421:13 Key109=65508:0 Key110=65299:0 Key111=65377:0 Key112=65455:47 Key113=65516:0 Key114=0:0 Key115=65515:0 Key116=65512:0 Key117=65383:0 Key118=0:0 Key119=0:0 Key120=0:0 Key121=0:0 Key122=0:0 Key123=0:0 Key124=65027:0 Key125=65513:0 Key126=65469:61 Key127=65515:0 Key128=65517:0 Key129=0:0 Key130=0:0 Key131=0:0 Key132=0:0 Key133=0:0 Key134=65454:46 Key135=0:0 Key136=0:0 Key137=0:0 [shiftcapslockaltgr] Key8=65406:0 Key9=65307:27 Key10=33:33 Key11=64:64 Key12=35:35 Key13=36:36 Key14=37:37 Key15=65106:94 Key16=38:38 Key17=42:42 Key18=0:0 Key19=41:41 Key20=123:123 Key21=0:0 Key22=65288:8 Key23=65056:0 Key24=65111:168 Key25=65114:711 Key26=183:183 Key27=112:112 Key28=121:121 Key29=102:102 Key30=103:103 Key31=99:99 Key32=114:114 Key33=108:108 Key34=63:63 Key35=43:43 Key36=65293:13 Key37=65507:0 Key38=97:97 Key39=111:111 Key40=101:101 Key41=117:117 Key42=105:105 Key43=100:100 Key44=104:104 Key45=116:116 Key46=110:110 Key47=115:115 Key48=95:95 Key49=65107:126 Key50=65505:0 Key51=124:124 Key52=65113:733 Key53=113:113 Key54=106:106 Key55=107:107 Key56=120:120 Key57=98:98 Key58=109:109 Key59=119:119 Key60=118:118 Key61=122:122 Key62=65506:0 Key63=65450:42 Key64=65511:0 Key65=32:32 Key66=65509:0 Key67=65470:0 Key68=65471:0 Key69=65472:0 Key70=65473:0 Key71=65474:0 Key72=65475:0 Key73=65476:0 Key74=65477:0 Key75=65478:0 Key76=65479:0 Key77=65407:0 Key78=65300:0 Key79=65463:55 Key80=65464:56 Key81=65465:57 Key82=65453:45 Key83=65460:52 Key84=65461:53 Key85=65462:54 Key86=65451:43 Key87=65457:49 Key88=65458:50 Key89=65459:51 Key90=65456:48 Key91=65454:46 Key92=0:0 Key93=0:0 Key94=166:166 Key95=65480:0 Key96=65481:0 Key97=65360:0 Key98=65362:0 Key99=65365:0 Key100=65361:0 Key101=0:0 Key102=65363:0 Key103=65367:0 Key104=65364:0 Key105=65366:0 Key106=65379:0 Key107=65535:127 Key108=65421:13 Key109=65508:0 Key110=65299:0 Key111=65377:0 Key112=65455:47 Key113=65516:0 Key114=0:0 Key115=65515:0 Key116=65512:0 Key117=65383:0 Key118=0:0 Key119=0:0 Key120=0:0 Key121=0:0 Key122=0:0 Key123=0:0 Key124=65027:0 Key125=65513:0 Key126=65469:61 Key127=65515:0 Key128=65517:0 Key129=0:0 Key130=0:0 Key131=0:0 Key132=0:0 Key133=0:0 Key134=65454:46 Key135=0:0 Key136=0:0 Key137=0:0 xrdp-0.9.5/instfiles/keymap-names.txt000644 001751 001751 00000007147 13127114621 017561 0ustar00metameta000000 000000 0x00000436 af Afrikaans 0x0000041C sq Albanian 0x00000001 ar Arabic 0x00000401 ar-sa Arabic (Saudi Arabia) 0x00000801 ar-iq Arabic (Iraq) 0x00000C01 ar-eg Arabic (Egypt) 0x00001001 ar-ly Arabic (Libya) 0x00001401 ar-dz Arabic (Algeria) 0x00001801 ar-ma Arabic (Morocco) 0x00001C01 ar-tn Arabic (Tunisia) 0x00002001 ar-om Arabic (Oman) 0x00002401 ar-ye Arabic (Yemen) 0x00002801 ar-sy Arabic (Syria) 0x00002C01 ar-jo Arabic (Jordan) 0x00003001 ar-lb Arabic (Lebanon) 0x00003401 ar-kw Arabic (Kuwait) 0x00003801 ar-ae Arabic (U.A.E.) 0x00003C01 ar-bh Arabic (Bahrain) 0x00004001 ar-qa Arabic (Qatar) 0x0000042D eu Basque 0x00000402 bg Bulgarian 0x00000423 be Belarusian 0x00000403 ca Catalan 0x00000004 zh Chinese 0x00000404 zh-tw Chinese (Taiwan) 0x00000804 zh-cn Chinese (China) 0x00000C04 zh-hk Chinese (Hong Kong SAR) 0x00001004 zh-sg Chinese (Singapore) 0x0000041A hr Croatian 0x00000405 cs Czech 0x00000406 da Danish 0x00000413 nl Dutch (Netherlands) 0x00000813 nl-be Dutch (Belgium) 0x00000009 en English 0x00000409 en-us English (United States) 0x00000809 en-gb English (United Kingdom) 0x00000C09 en-au English (Australia) 0x00001009 en-ca English (Canada) 0x00001409 en-nz English (New Zealand) 0x00001809 en-ie English (Ireland) 0x00001C09 en-za English (South Africa) 0x00002009 en-jm English (Jamaica) 0x00002809 en-bz English (Belize) 0x00002C09 en-tt English (Trinidad) 0x00000425 et Estonian 0x00000438 fo Faeroese 0x00000429 fa Farsi 0x0000040B fi Finnish 0x0000040C fr French (France) 0x0000080C fr-be French (Belgium) 0x00000C0C fr-ca French (Canada) 0x0000100C fr-ch French (Switzerland) 0x0000140C fr-lu French (Luxembourg) 0x0000043C gd Gaelic 0x00000407 de German (Germany) 0x00000807 de-ch German (Switzerland) 0x00000C07 de-at German (Austria) 0x00001007 de-lu German (Luxembourg) 0x00001407 de-li German (Liechtenstein) 0x00000408 el Greek 0x0000040D he Hebrew 0x00000439 hi Hindi 0x0000040E hu Hungarian 0x0000040F is Icelandic 0x00000421 in Indonesian 0x00000410 it Italian (Italy) 0x00000810 it-ch Italian (Switzerland) 0x00000411 ja Japanese 0x00000412 ko Korean 0x00000426 lv Latvian 0x00000427 lt Lithuanian 0x0000042F mk FYRO Macedonian 0x0000043E ms Malay (Malaysia) 0x0000043A mt Maltese 0x00000414 no Norwegian (Bokmal) 0x00000814 no Norwegian (Nynorsk) 0x00000415 pl Polish 0x00000416 pt-br Portuguese (Brazil) 0x00000816 pt Portuguese (Portugal) 0x00000417 rm Rhaeto-Romanic 0x00000418 ro Romanian 0x00000818 ro-mo Romanian (Moldova) 0x00000419 ru Russian 0x00000819 ru-mo Russian (Moldova) 0x00000C1A sr Serbian (Cyrillic) 0x0000081A sr Serbian (Latin) 0x0000041B sk Slovak 0x00000424 sl Slovenian 0x0000042E sb Sorbian 0x0000040A es Spanish (Traditional Sort) 0x0000080A es-mx Spanish (Mexico) 0x00000C0A es Spanish (International Sort) 0x0000100A es-gt Spanish (Guatemala) 0x0000140A es-cr Spanish (Costa Rica) 0x0000180A es-pa Spanish (Panama) 0x00001C0A es-do Spanish (Dominican Republic) 0x0000200A es-ve Spanish (Venezuela) 0x0000240A es-co Spanish (Colombia) 0x0000280A es-pe Spanish (Peru) 0x00002C0A es-ar Spanish (Argentina) 0x0000300A es-ec Spanish (Ecuador) 0x0000340A es-cl Spanish (Chile) 0x0000380A es-uy Spanish (Uruguay) 0x00003C0A es-py Spanish (Paraguay) 0x0000400A es-bo Spanish (Bolivia) 0x0000440A es-sv Spanish (El Salvador) 0x0000480A es-hn Spanish (Honduras) 0x00004C0A es-ni Spanish (Nicaragua) 0x0000500A es-pr Spanish (Puerto Rico) 0x00000430 sx Sutu 0x0000041D sv Swedish 0x0000081D sv-fi Swedish (Finland) 0x0000041E th Thai 0x00000431 ts Tsonga 0x00000432 tn Tswana 0x0000041F tr Turkish 0x00000422 uk Ukrainian 0x00000420 ur Urdu 0x0000042A vi Vietnamese 0x00000434 xh Xhosa 0x0000043D ji Yiddish 0x00000435 zu Zulu xrdp-0.9.5/instfiles/km-00000414.ini000644 001751 001751 00000021225 13127114621 016420 0ustar00metameta000000 000000 [noshift] Key8=65406:0 Key9=65307:27 Key10=49:49 Key11=50:50 Key12=51:51 Key13=52:52 Key14=53:53 Key15=54:54 Key16=55:55 Key17=56:56 Key18=57:57 Key19=48:48 Key20=43:43 Key21=92:92 Key22=65288:8 Key23=65289:9 Key24=113:113 Key25=119:119 Key26=101:101 Key27=114:114 Key28=116:116 Key29=121:121 Key30=117:117 Key31=105:105 Key32=111:111 Key33=112:112 Key34=229:229 Key35=65111:168 Key36=65293:13 Key37=65507:0 Key38=97:97 Key39=115:115 Key40=100:100 Key41=102:102 Key42=103:103 Key43=104:104 Key44=106:106 Key45=107:107 Key46=108:108 Key47=248:248 Key48=230:230 Key49=124:124 Key50=65505:0 Key51=39:39 Key52=122:122 Key53=120:120 Key54=99:99 Key55=118:118 Key56=98:98 Key57=110:110 Key58=109:109 Key59=44:44 Key60=46:46 Key61=45:45 Key62=65506:0 Key63=65450:42 Key64=65513:0 Key65=32:32 Key66=65509:0 Key67=65470:0 Key68=65471:0 Key69=65472:0 Key70=65473:0 Key71=65474:0 Key72=65475:0 Key73=65476:0 Key74=65477:0 Key75=65478:0 Key76=65479:0 Key77=65407:0 Key78=65300:0 Key79=65429:0 Key80=65431:0 Key81=65434:0 Key82=65453:45 Key83=65430:0 Key84=65437:0 Key85=65432:0 Key86=65451:43 Key87=65436:0 Key88=65433:0 Key89=65435:0 Key90=65438:0 Key91=65439:0 Key92=0:0 Key93=0:0 Key94=60:60 Key95=65480:0 Key96=65481:0 Key97=65360:0 Key98=65362:0 Key99=65365:0 Key100=65361:0 Key101=0:0 Key102=65363:0 Key103=65367:0 Key104=65364:0 Key105=65366:0 Key106=65379:0 Key107=65535:127 Key108=65421:13 Key109=65508:0 Key110=65299:0 Key111=65377:0 Key112=65455:47 Key113=65027:0 Key114=0:0 Key115=65515:0 Key116=65516:0 Key117=65383:0 Key118=0:0 Key119=0:0 Key120=0:0 Key121=0:0 Key122=0:0 Key123=0:0 Key124=65027:0 Key125=0:0 Key126=65469:61 Key127=0:0 Key128=0:0 Key129=269025074:0 Key130=0:0 Key131=0:0 Key132=0:0 Key133=0:0 Key134=65454:46 Key135=0:0 Key136=0:0 Key137=0:0 [shift] Key8=65406:0 Key9=65307:27 Key10=33:33 Key11=34:34 Key12=35:35 Key13=164:164 Key14=37:37 Key15=38:38 Key16=47:47 Key17=40:40 Key18=41:41 Key19=61:61 Key20=63:63 Key21=65104:96 Key22=65288:8 Key23=65056:0 Key24=81:81 Key25=87:87 Key26=69:69 Key27=82:82 Key28=84:84 Key29=89:89 Key30=85:85 Key31=73:73 Key32=79:79 Key33=80:80 Key34=197:197 Key35=65106:94 Key36=65293:13 Key37=65507:0 Key38=65:65 Key39=83:83 Key40=68:68 Key41=70:70 Key42=71:71 Key43=72:72 Key44=74:74 Key45=75:75 Key46=76:76 Key47=216:216 Key48=198:198 Key49=167:167 Key50=65505:0 Key51=42:42 Key52=90:90 Key53=88:88 Key54=67:67 Key55=86:86 Key56=66:66 Key57=78:78 Key58=77:77 Key59=59:59 Key60=58:58 Key61=95:95 Key62=65506:0 Key63=65450:42 Key64=65511:0 Key65=32:32 Key66=65032:0 Key67=65470:0 Key68=65471:0 Key69=65472:0 Key70=65473:0 Key71=65474:0 Key72=65475:0 Key73=65476:0 Key74=65477:0 Key75=65478:0 Key76=65479:0 Key77=65407:0 Key78=65300:0 Key79=65463:55 Key80=65464:56 Key81=65465:57 Key82=65453:45 Key83=65460:52 Key84=65461:53 Key85=65462:54 Key86=65451:43 Key87=65457:49 Key88=65458:50 Key89=65459:51 Key90=65456:48 Key91=65452:44 Key92=0:0 Key93=0:0 Key94=62:62 Key95=65480:0 Key96=65481:0 Key97=65360:0 Key98=65362:0 Key99=65365:0 Key100=65361:0 Key101=0:0 Key102=65363:0 Key103=65367:0 Key104=65364:0 Key105=65366:0 Key106=65379:0 Key107=65535:127 Key108=65421:13 Key109=65508:0 Key110=65299:0 Key111=65377:0 Key112=65455:47 Key113=65027:0 Key114=0:0 Key115=65515:0 Key116=65516:0 Key117=65383:0 Key118=0:0 Key119=0:0 Key120=0:0 Key121=0:0 Key122=0:0 Key123=0:0 Key124=65027:0 Key125=65513:0 Key126=65469:61 Key127=65515:0 Key128=65517:0 Key129=269025074:0 Key130=0:0 Key131=0:0 Key132=0:0 Key133=0:0 Key134=65454:46 Key135=0:0 Key136=0:0 Key137=0:0 [altgr] Key8=65406:0 Key9=65307:27 Key10=161:161 Key11=64:64 Key12=163:163 Key13=36:36 Key14=189:189 Key15=165:165 Key16=123:123 Key17=91:91 Key18=93:93 Key19=125:125 Key20=177:177 Key21=65105:180 Key22=65288:8 Key23=65289:9 Key24=64:64 Key25=435:322 Key26=8364:8364 Key27=174:174 Key28=254:254 Key29=2299:8592 Key30=2302:8595 Key31=2301:8594 Key32=5053:339 Key33=2032:960 Key34=65111:168 Key35=65107:126 Key36=65293:13 Key37=65507:0 Key38=170:170 Key39=223:223 Key40=240:240 Key41=496:273 Key42=959:331 Key43=689:295 Key44=106:106 Key45=930:312 Key46=435:322 Key47=65105:180 Key48=65106:94 Key49=166:166 Key50=65505:0 Key51=65113:733 Key52=171:171 Key53=187:187 Key54=169:169 Key55=2770:8220 Key56=2771:8221 Key57=110:110 Key58=181:181 Key59=65115:184 Key60=2734:8230 Key61=2730:8211 Key62=65506:0 Key63=16786117:8901 Key64=65513:0 Key65=160:160 Key66=65509:0 Key67=65470:0 Key68=65471:0 Key69=65472:0 Key70=65473:0 Key71=65474:0 Key72=65475:0 Key73=65476:0 Key74=65477:0 Key75=65478:0 Key76=65479:0 Key77=65407:0 Key78=65300:0 Key79=65429:0 Key80=65431:0 Key81=65434:0 Key82=16785938:8722 Key83=65430:0 Key84=65437:0 Key85=65432:0 Key86=16777259:43 Key87=65436:0 Key88=65433:0 Key89=65435:0 Key90=65438:0 Key91=65439:0 Key92=0:0 Key93=0:0 Key94=189:189 Key95=65480:0 Key96=65481:0 Key97=65360:0 Key98=65362:0 Key99=65365:0 Key100=65361:0 Key101=0:0 Key102=65363:0 Key103=65367:0 Key104=65364:0 Key105=65366:0 Key106=65379:0 Key107=65535:127 Key108=65421:13 Key109=65508:0 Key110=65299:0 Key111=65377:0 Key112=16785941:8725 Key113=65027:0 Key114=0:0 Key115=65515:0 Key116=65516:0 Key117=65383:0 Key118=0:0 Key119=0:0 Key120=0:0 Key121=0:0 Key122=0:0 Key123=0:0 Key124=65027:0 Key125=0:0 Key126=65469:61 Key127=0:0 Key128=0:0 Key129=269025074:0 Key130=0:0 Key131=0:0 Key132=0:0 Key133=0:0 Key134=65454:46 Key135=0:0 Key136=0:0 Key137=0:0 [capslock] Key8=65406:0 Key9=65307:27 Key10=49:49 Key11=50:50 Key12=51:51 Key13=52:52 Key14=53:53 Key15=54:54 Key16=55:55 Key17=56:56 Key18=57:57 Key19=48:48 Key20=43:43 Key21=92:92 Key22=65288:8 Key23=65289:9 Key24=81:81 Key25=87:87 Key26=69:69 Key27=82:82 Key28=84:84 Key29=89:89 Key30=85:85 Key31=73:73 Key32=79:79 Key33=80:80 Key34=197:197 Key35=65111:168 Key36=65293:13 Key37=65507:0 Key38=65:65 Key39=83:83 Key40=68:68 Key41=70:70 Key42=71:71 Key43=72:72 Key44=74:74 Key45=75:75 Key46=76:76 Key47=216:216 Key48=198:198 Key49=124:124 Key50=65505:0 Key51=39:39 Key52=90:90 Key53=88:88 Key54=67:67 Key55=86:86 Key56=66:66 Key57=78:78 Key58=77:77 Key59=44:44 Key60=46:46 Key61=45:45 Key62=65506:0 Key63=65450:42 Key64=65513:0 Key65=32:32 Key66=65509:0 Key67=65470:0 Key68=65471:0 Key69=65472:0 Key70=65473:0 Key71=65474:0 Key72=65475:0 Key73=65476:0 Key74=65477:0 Key75=65478:0 Key76=65479:0 Key77=65407:0 Key78=65300:0 Key79=65429:0 Key80=65431:0 Key81=65434:0 Key82=65453:45 Key83=65430:0 Key84=65437:0 Key85=65432:0 Key86=65451:43 Key87=65436:0 Key88=65433:0 Key89=65435:0 Key90=65438:0 Key91=65439:0 Key92=0:0 Key93=0:0 Key94=60:60 Key95=65480:0 Key96=65481:0 Key97=65360:0 Key98=65362:0 Key99=65365:0 Key100=65361:0 Key101=0:0 Key102=65363:0 Key103=65367:0 Key104=65364:0 Key105=65366:0 Key106=65379:0 Key107=65535:127 Key108=65421:13 Key109=65508:0 Key110=65299:0 Key111=65377:0 Key112=65455:47 Key113=65027:0 Key114=0:0 Key115=65515:0 Key116=65516:0 Key117=65383:0 Key118=0:0 Key119=0:0 Key120=0:0 Key121=0:0 Key122=0:0 Key123=0:0 Key124=65027:0 Key125=0:0 Key126=65469:61 Key127=0:0 Key128=0:0 Key129=269025074:0 Key130=0:0 Key131=0:0 Key132=0:0 Key133=0:0 Key134=65454:46 Key135=0:0 Key136=0:0 Key137=0:0 [shiftcapslock] Key8=65406:0 Key9=65307:27 Key10=33:33 Key11=34:34 Key12=35:35 Key13=164:164 Key14=37:37 Key15=38:38 Key16=47:47 Key17=40:40 Key18=41:41 Key19=61:61 Key20=63:63 Key21=65104:96 Key22=65288:8 Key23=65056:0 Key24=113:113 Key25=119:119 Key26=101:101 Key27=114:114 Key28=116:116 Key29=121:121 Key30=117:117 Key31=105:105 Key32=111:111 Key33=112:112 Key34=229:229 Key35=65106:94 Key36=65293:13 Key37=65507:0 Key38=97:97 Key39=115:115 Key40=100:100 Key41=102:102 Key42=103:103 Key43=104:104 Key44=106:106 Key45=107:107 Key46=108:108 Key47=248:248 Key48=230:230 Key49=167:167 Key50=65505:0 Key51=42:42 Key52=122:122 Key53=120:120 Key54=99:99 Key55=118:118 Key56=98:98 Key57=110:110 Key58=109:109 Key59=59:59 Key60=58:58 Key61=95:95 Key62=65506:0 Key63=65450:42 Key64=65511:0 Key65=32:32 Key66=65032:0 Key67=65470:0 Key68=65471:0 Key69=65472:0 Key70=65473:0 Key71=65474:0 Key72=65475:0 Key73=65476:0 Key74=65477:0 Key75=65478:0 Key76=65479:0 Key77=65407:0 Key78=65300:0 Key79=65463:55 Key80=65464:56 Key81=65465:57 Key82=65453:45 Key83=65460:52 Key84=65461:53 Key85=65462:54 Key86=65451:43 Key87=65457:49 Key88=65458:50 Key89=65459:51 Key90=65456:48 Key91=65452:44 Key92=0:0 Key93=0:0 Key94=62:62 Key95=65480:0 Key96=65481:0 Key97=65360:0 Key98=65362:0 Key99=65365:0 Key100=65361:0 Key101=0:0 Key102=65363:0 Key103=65367:0 Key104=65364:0 Key105=65366:0 Key106=65379:0 Key107=65535:127 Key108=65421:13 Key109=65508:0 Key110=65299:0 Key111=65377:0 Key112=65455:47 Key113=65027:0 Key114=0:0 Key115=65515:0 Key116=65516:0 Key117=65383:0 Key118=0:0 Key119=0:0 Key120=0:0 Key121=0:0 Key122=0:0 Key123=0:0 Key124=65027:0 Key125=65513:0 Key126=65469:61 Key127=65515:0 Key128=65517:0 Key129=269025074:0 Key130=0:0 Key131=0:0 Key132=0:0 Key133=0:0 Key134=65454:46 Key135=0:0 Key136=0:0 Key137=0:0 xrdp-0.9.5/instfiles/km-00000813.ini000644 001751 001751 00000021060 13127114621 016420 0ustar00metameta000000 000000 [noshift] Key8=0:0 Key9=65307:27 Key10=38:38 Key11=233:233 Key12=34:34 Key13=39:39 Key14=40:40 Key15=167:167 Key16=232:232 Key17=33:33 Key18=231:231 Key19=224:224 Key20=41:41 Key21=45:45 Key22=65288:8 Key23=65289:9 Key24=97:97 Key25=122:122 Key26=101:101 Key27=114:114 Key28=116:116 Key29=121:121 Key30=117:117 Key31=105:105 Key32=111:111 Key33=112:112 Key34=65106:94 Key35=36:36 Key36=65293:13 Key37=65507:0 Key38=113:113 Key39=115:115 Key40=100:100 Key41=102:102 Key42=103:103 Key43=104:104 Key44=106:106 Key45=107:107 Key46=108:108 Key47=109:109 Key48=249:249 Key49=178:178 Key50=65505:0 Key51=181:181 Key52=119:119 Key53=120:120 Key54=99:99 Key55=118:118 Key56=98:98 Key57=110:110 Key58=44:44 Key59=59:59 Key60=58:58 Key61=61:61 Key62=65506:0 Key63=65450:42 Key64=65513:0 Key65=32:32 Key66=65509:0 Key67=65470:0 Key68=65471:0 Key69=65472:0 Key70=65473:0 Key71=65474:0 Key72=65475:0 Key73=65476:0 Key74=65477:0 Key75=65478:0 Key76=65479:0 Key77=65407:0 Key78=65300:0 Key79=65429:0 Key80=65431:0 Key81=65434:0 Key82=65453:45 Key83=65430:0 Key84=65437:0 Key85=65432:0 Key86=65451:43 Key87=65436:0 Key88=65433:0 Key89=65435:0 Key90=65438:0 Key91=65439:0 Key92=0:0 Key93=65406:0 Key94=60:60 Key95=65480:0 Key96=65481:0 Key97=65360:0 Key98=65362:0 Key99=65365:0 Key100=65361:0 Key101=0:0 Key102=65363:0 Key103=65367:0 Key104=65364:0 Key105=65366:0 Key106=65379:0 Key107=65535:127 Key108=65421:13 Key109=65508:0 Key110=65299:0 Key111=65377:0 Key112=65455:47 Key113=65027:0 Key114=0:0 Key115=65515:0 Key116=65516:0 Key117=65383:0 Key118=0:0 Key119=0:0 Key120=0:0 Key121=0:0 Key122=0:0 Key123=0:0 Key124=65027:0 Key125=0:0 Key126=65469:61 Key127=0:0 Key128=0:0 Key129=0:0 Key130=0:0 Key131=0:0 Key132=0:0 Key133=0:0 Key134=0:0 Key135=0:0 Key136=0:0 Key137=0:0 [shift] Key8=0:0 Key9=65307:27 Key10=49:49 Key11=50:50 Key12=51:51 Key13=52:52 Key14=53:53 Key15=54:54 Key16=55:55 Key17=56:56 Key18=57:57 Key19=48:48 Key20=176:176 Key21=95:95 Key22=65288:8 Key23=65056:0 Key24=65:65 Key25=90:90 Key26=69:69 Key27=82:82 Key28=84:84 Key29=89:89 Key30=85:85 Key31=73:73 Key32=79:79 Key33=80:80 Key34=65111:168 Key35=42:42 Key36=65293:13 Key37=65507:0 Key38=81:81 Key39=83:83 Key40=68:68 Key41=70:70 Key42=71:71 Key43=72:72 Key44=74:74 Key45=75:75 Key46=76:76 Key47=77:77 Key48=37:37 Key49=179:179 Key50=65505:0 Key51=163:163 Key52=87:87 Key53=88:88 Key54=67:67 Key55=86:86 Key56=66:66 Key57=78:78 Key58=63:63 Key59=46:46 Key60=47:47 Key61=43:43 Key62=65506:0 Key63=65450:42 Key64=65511:0 Key65=32:32 Key66=65509:0 Key67=65470:0 Key68=65471:0 Key69=65472:0 Key70=65473:0 Key71=65474:0 Key72=65475:0 Key73=65476:0 Key74=65477:0 Key75=65478:0 Key76=65479:0 Key77=65273:0 Key78=65300:0 Key79=65463:55 Key80=65464:56 Key81=65465:57 Key82=65453:45 Key83=65460:52 Key84=65461:53 Key85=65462:54 Key86=65451:43 Key87=65457:49 Key88=65458:50 Key89=65459:51 Key90=65456:48 Key91=65454:46 Key92=0:0 Key93=65406:0 Key94=62:62 Key95=65480:0 Key96=65481:0 Key97=65360:0 Key98=65362:0 Key99=65365:0 Key100=65361:0 Key101=0:0 Key102=65363:0 Key103=65367:0 Key104=65364:0 Key105=65366:0 Key106=65379:0 Key107=65535:127 Key108=65421:13 Key109=65508:0 Key110=65299:0 Key111=65377:0 Key112=65455:47 Key113=65027:0 Key114=0:0 Key115=65515:0 Key116=65516:0 Key117=65383:0 Key118=0:0 Key119=0:0 Key120=0:0 Key121=0:0 Key122=0:0 Key123=0:0 Key124=65027:0 Key125=65513:0 Key126=65469:61 Key127=65515:0 Key128=65517:0 Key129=0:0 Key130=0:0 Key131=0:0 Key132=0:0 Key133=0:0 Key134=0:0 Key135=0:0 Key136=0:0 Key137=0:0 [altgr] Key8=0:0 Key9=65307:27 Key10=124:124 Key11=64:64 Key12=35:35 Key13=188:188 Key14=189:189 Key15=94:94 Key16=123:123 Key17=91:91 Key18=123:123 Key19=125:125 Key20=92:92 Key21=65115:184 Key22=65288:8 Key23=65289:9 Key24=64:64 Key25=435:322 Key26=8364:8364 Key27=182:182 Key28=956:359 Key29=2299:8592 Key30=2302:8595 Key31=2301:8594 Key32=5053:339 Key33=254:254 Key34=91:91 Key35=93:93 Key36=65293:13 Key37=65507:0 Key38=230:230 Key39=223:223 Key40=240:240 Key41=496:273 Key42=959:331 Key43=689:295 Key44=106:106 Key45=930:312 Key46=435:322 Key47=65105:180 Key48=65105:180 Key49=172:172 Key50=65505:0 Key51=65104:96 Key52=171:171 Key53=187:187 Key54=162:162 Key55=2770:8220 Key56=2771:8221 Key57=110:110 Key58=65115:184 Key59=2211:0 Key60=183:183 Key61=65107:126 Key62=65506:0 Key63=65450:42 Key64=65513:0 Key65=32:32 Key66=65509:0 Key67=65470:0 Key68=65471:0 Key69=65472:0 Key70=65473:0 Key71=65474:0 Key72=65475:0 Key73=65476:0 Key74=65477:0 Key75=65478:0 Key76=65479:0 Key77=65407:0 Key78=65300:0 Key79=65429:0 Key80=65431:0 Key81=65434:0 Key82=65453:45 Key83=65430:0 Key84=65437:0 Key85=65432:0 Key86=65451:43 Key87=65436:0 Key88=65433:0 Key89=65435:0 Key90=65438:0 Key91=65439:0 Key92=0:0 Key93=65406:0 Key94=92:92 Key95=65480:0 Key96=65481:0 Key97=65360:0 Key98=65362:0 Key99=65365:0 Key100=65361:0 Key101=0:0 Key102=65363:0 Key103=65367:0 Key104=65364:0 Key105=65366:0 Key106=65379:0 Key107=65535:127 Key108=65421:13 Key109=65508:0 Key110=65299:0 Key111=65377:0 Key112=65455:47 Key113=65027:0 Key114=0:0 Key115=65515:0 Key116=65516:0 Key117=65383:0 Key118=0:0 Key119=0:0 Key120=0:0 Key121=0:0 Key122=0:0 Key123=0:0 Key124=65027:0 Key125=0:0 Key126=65469:61 Key127=0:0 Key128=0:0 Key129=0:0 Key130=0:0 Key131=0:0 Key132=0:0 Key133=0:0 Key134=0:0 Key135=0:0 Key136=0:0 Key137=0:0 [capslock] Key8=0:0 Key9=65307:27 Key10=38:38 Key11=201:201 Key12=34:34 Key13=39:39 Key14=40:40 Key15=167:167 Key16=200:200 Key17=33:33 Key18=199:199 Key19=192:192 Key20=41:41 Key21=45:45 Key22=65288:8 Key23=65289:9 Key24=65:65 Key25=90:90 Key26=69:69 Key27=82:82 Key28=84:84 Key29=89:89 Key30=85:85 Key31=73:73 Key32=79:79 Key33=80:80 Key34=65106:94 Key35=36:36 Key36=65293:13 Key37=65507:0 Key38=81:81 Key39=83:83 Key40=68:68 Key41=70:70 Key42=71:71 Key43=72:72 Key44=74:74 Key45=75:75 Key46=76:76 Key47=77:77 Key48=217:217 Key49=178:178 Key50=65505:0 Key51=924:0 Key52=87:87 Key53=88:88 Key54=67:67 Key55=86:86 Key56=66:66 Key57=78:78 Key58=44:44 Key59=59:59 Key60=58:58 Key61=61:61 Key62=65506:0 Key63=65450:42 Key64=65513:0 Key65=32:32 Key66=65509:0 Key67=65470:0 Key68=65471:0 Key69=65472:0 Key70=65473:0 Key71=65474:0 Key72=65475:0 Key73=65476:0 Key74=65477:0 Key75=65478:0 Key76=65479:0 Key77=65407:0 Key78=65300:0 Key79=65429:0 Key80=65431:0 Key81=65434:0 Key82=65453:45 Key83=65430:0 Key84=65437:0 Key85=65432:0 Key86=65451:43 Key87=65436:0 Key88=65433:0 Key89=65435:0 Key90=65438:0 Key91=65439:0 Key92=0:0 Key93=65406:0 Key94=60:60 Key95=65480:0 Key96=65481:0 Key97=65360:0 Key98=65362:0 Key99=65365:0 Key100=65361:0 Key101=0:0 Key102=65363:0 Key103=65367:0 Key104=65364:0 Key105=65366:0 Key106=65379:0 Key107=65535:127 Key108=65421:13 Key109=65508:0 Key110=65299:0 Key111=65377:0 Key112=65455:47 Key113=65027:0 Key114=0:0 Key115=65515:0 Key116=65516:0 Key117=65383:0 Key118=0:0 Key119=0:0 Key120=0:0 Key121=0:0 Key122=0:0 Key123=0:0 Key124=65027:0 Key125=0:0 Key126=65469:61 Key127=0:0 Key128=0:0 Key129=0:0 Key130=0:0 Key131=0:0 Key132=0:0 Key133=0:0 Key134=0:0 Key135=0:0 Key136=0:0 Key137=0:0 [shiftcapslock] Key8=0:0 Key9=65307:27 Key10=49:49 Key11=50:50 Key12=51:51 Key13=52:52 Key14=53:53 Key15=54:54 Key16=55:55 Key17=56:56 Key18=57:57 Key19=48:48 Key20=176:176 Key21=95:95 Key22=65288:8 Key23=65056:0 Key24=97:97 Key25=122:122 Key26=101:101 Key27=114:114 Key28=116:116 Key29=121:121 Key30=117:117 Key31=105:105 Key32=111:111 Key33=112:112 Key34=65111:168 Key35=42:42 Key36=65293:13 Key37=65507:0 Key38=113:113 Key39=115:115 Key40=100:100 Key41=102:102 Key42=103:103 Key43=104:104 Key44=106:106 Key45=107:107 Key46=108:108 Key47=109:109 Key48=37:37 Key49=179:179 Key50=65505:0 Key51=163:163 Key52=119:119 Key53=120:120 Key54=99:99 Key55=118:118 Key56=98:98 Key57=110:110 Key58=63:63 Key59=46:46 Key60=47:47 Key61=43:43 Key62=65506:0 Key63=65450:42 Key64=65511:0 Key65=32:32 Key66=65509:0 Key67=65470:0 Key68=65471:0 Key69=65472:0 Key70=65473:0 Key71=65474:0 Key72=65475:0 Key73=65476:0 Key74=65477:0 Key75=65478:0 Key76=65479:0 Key77=65273:0 Key78=65300:0 Key79=65463:55 Key80=65464:56 Key81=65465:57 Key82=65453:45 Key83=65460:52 Key84=65461:53 Key85=65462:54 Key86=65451:43 Key87=65457:49 Key88=65458:50 Key89=65459:51 Key90=65456:48 Key91=65454:46 Key92=0:0 Key93=65406:0 Key94=62:62 Key95=65480:0 Key96=65481:0 Key97=65360:0 Key98=65362:0 Key99=65365:0 Key100=65361:0 Key101=0:0 Key102=65363:0 Key103=65367:0 Key104=65364:0 Key105=65366:0 Key106=65379:0 Key107=65535:127 Key108=65421:13 Key109=65508:0 Key110=65299:0 Key111=65377:0 Key112=65455:47 Key113=65027:0 Key114=0:0 Key115=65515:0 Key116=65516:0 Key117=65383:0 Key118=0:0 Key119=0:0 Key120=0:0 Key121=0:0 Key122=0:0 Key123=0:0 Key124=65027:0 Key125=65513:0 Key126=65469:61 Key127=65515:0 Key128=65517:0 Key129=0:0 Key130=0:0 Key131=0:0 Key132=0:0 Key133=0:0 Key134=0:0 Key135=0:0 Key136=0:0 Key137=0:0 xrdp-0.9.5/instfiles/pam.d/000755 001751 001751 00000000000 13220731021 015410 5ustar00metameta000000 000000 xrdp-0.9.5/instfiles/km-00000412.ini000644 001751 001751 00000035221 13133557325 016430 0ustar00metameta000000 000000 [noshift] Key8=65406:0 Key9=65307:27 Key10=49:49 Key11=50:50 Key12=51:51 Key13=52:52 Key14=53:53 Key15=54:54 Key16=55:55 Key17=56:56 Key18=57:57 Key19=48:48 Key20=45:45 Key21=61:61 Key22=65288:8 Key23=65289:9 Key24=113:113 Key25=119:119 Key26=101:101 Key27=114:114 Key28=116:116 Key29=121:121 Key30=117:117 Key31=105:105 Key32=111:111 Key33=112:112 Key34=91:91 Key35=93:93 Key36=65293:13 Key37=65507:0 Key38=97:97 Key39=115:115 Key40=100:100 Key41=102:102 Key42=103:103 Key43=104:104 Key44=106:106 Key45=107:107 Key46=108:108 Key47=59:59 Key48=39:39 Key49=96:96 Key50=65505:0 Key51=92:92 Key52=122:122 Key53=120:120 Key54=99:99 Key55=118:118 Key56=98:98 Key57=110:110 Key58=109:109 Key59=44:44 Key60=46:46 Key61=47:47 Key62=65506:0 Key63=65450:42 Key64=65513:0 Key65=32:32 Key66=65509:0 Key67=65470:0 Key68=65471:0 Key69=65472:0 Key70=65473:0 Key71=65474:0 Key72=65475:0 Key73=65476:0 Key74=65477:0 Key75=65478:0 Key76=65479:0 Key77=65407:0 Key78=65300:0 Key79=65429:0 Key80=65431:0 Key81=65434:0 Key82=65453:45 Key83=65430:0 Key84=65437:0 Key85=65432:0 Key86=65451:43 Key87=65436:0 Key88=65433:0 Key89=65435:0 Key90=65438:0 Key91=65439:0 Key92=0:0 Key93=0:0 Key94=60:60 Key95=65480:0 Key96=65481:0 Key97=65360:0 Key98=65362:0 Key99=65365:0 Key100=65361:0 Key101=0:0 Key102=65363:0 Key103=65367:0 Key104=65364:0 Key105=65366:0 Key106=65379:0 Key107=65535:127 Key108=65421:13 Key109=65508:0 Key110=65299:0 Key111=65377:0 Key112=65455:47 Key113=65514:0 Key114=0:0 Key115=65515:0 Key116=65516:0 Key117=65383:0 Key118=0:0 Key119=0:0 Key120=0:0 Key121=0:0 Key122=0:0 Key123=0:0 Key124=65027:0 Key125=0:0 Key126=65469:61 Key127=0:0 Key128=0:0 Key129=0:0 Key130=0:0 Key131=0:0 Key132=0:0 Key133=0:0 Key134=65454:46 Key135=0:0 Key136=0:0 Key137=0:0 [shift] Key8=65406:0 Key9=65307:27 Key10=33:33 Key11=64:64 Key12=35:35 Key13=36:36 Key14=37:37 Key15=94:94 Key16=38:38 Key17=42:42 Key18=40:40 Key19=41:41 Key20=95:95 Key21=43:43 Key22=65288:8 Key23=65056:0 Key24=81:81 Key25=87:87 Key26=69:69 Key27=82:82 Key28=84:84 Key29=89:89 Key30=85:85 Key31=73:73 Key32=79:79 Key33=80:80 Key34=123:123 Key35=125:125 Key36=65293:13 Key37=65507:0 Key38=65:65 Key39=83:83 Key40=68:68 Key41=70:70 Key42=71:71 Key43=72:72 Key44=74:74 Key45=75:75 Key46=76:76 Key47=58:58 Key48=34:34 Key49=126:126 Key50=65505:0 Key51=124:124 Key52=90:90 Key53=88:88 Key54=67:67 Key55=86:86 Key56=66:66 Key57=78:78 Key58=77:77 Key59=60:60 Key60=62:62 Key61=63:63 Key62=65506:0 Key63=65450:42 Key64=65511:0 Key65=32:32 Key66=65509:0 Key67=65470:0 Key68=65471:0 Key69=65472:0 Key70=65473:0 Key71=65474:0 Key72=65475:0 Key73=65476:0 Key74=65477:0 Key75=65478:0 Key76=65479:0 Key77=65407:0 Key78=65300:0 Key79=65463:55 Key80=65464:56 Key81=65465:57 Key82=65453:45 Key83=65460:52 Key84=65461:53 Key85=65462:54 Key86=65451:43 Key87=65457:49 Key88=65458:50 Key89=65459:51 Key90=65456:48 Key91=65454:46 Key92=0:0 Key93=0:0 Key94=62:62 Key95=65480:0 Key96=65481:0 Key97=65360:0 Key98=65362:0 Key99=65365:0 Key100=65361:0 Key101=0:0 Key102=65363:0 Key103=65367:0 Key104=65364:0 Key105=65366:0 Key106=65379:0 Key107=65535:127 Key108=65421:13 Key109=65508:0 Key110=65299:0 Key111=65377:0 Key112=65455:47 Key113=65512:0 Key114=0:0 Key115=65515:0 Key116=65516:0 Key117=65383:0 Key118=0:0 Key119=0:0 Key120=0:0 Key121=0:0 Key122=0:0 Key123=0:0 Key124=65027:0 Key125=65513:0 Key126=65469:61 Key127=65515:0 Key128=65517:0 Key129=0:0 Key130=0:0 Key131=0:0 Key132=0:0 Key133=0:0 Key134=65454:46 Key135=0:0 Key136=0:0 Key137=0:0 [altgr] Key8=65406:0 Key9=65307:27 Key10=49:49 Key11=50:50 Key12=51:51 Key13=52:52 Key14=53:53 Key15=54:54 Key16=55:55 Key17=56:56 Key18=57:57 Key19=48:48 Key20=45:45 Key21=61:61 Key22=65288:8 Key23=65289:9 Key24=113:113 Key25=119:119 Key26=101:101 Key27=114:114 Key28=116:116 Key29=121:121 Key30=117:117 Key31=105:105 Key32=111:111 Key33=112:112 Key34=91:91 Key35=93:93 Key36=65293:13 Key37=65507:0 Key38=97:97 Key39=115:115 Key40=100:100 Key41=102:102 Key42=103:103 Key43=104:104 Key44=106:106 Key45=107:107 Key46=108:108 Key47=59:59 Key48=39:39 Key49=96:96 Key50=65505:0 Key51=92:92 Key52=122:122 Key53=120:120 Key54=99:99 Key55=118:118 Key56=98:98 Key57=110:110 Key58=109:109 Key59=44:44 Key60=46:46 Key61=47:47 Key62=65506:0 Key63=65450:42 Key64=65513:0 Key65=32:32 Key66=65509:0 Key67=65470:0 Key68=65471:0 Key69=65472:0 Key70=65473:0 Key71=65474:0 Key72=65475:0 Key73=65476:0 Key74=65477:0 Key75=65478:0 Key76=65479:0 Key77=65407:0 Key78=65300:0 Key79=65429:0 Key80=65431:0 Key81=65434:0 Key82=65453:45 Key83=65430:0 Key84=65437:0 Key85=65432:0 Key86=65451:43 Key87=65436:0 Key88=65433:0 Key89=65435:0 Key90=65438:0 Key91=65439:0 Key92=0:0 Key93=0:0 Key94=124:124 Key95=65480:0 Key96=65481:0 Key97=65360:0 Key98=65362:0 Key99=65365:0 Key100=65361:0 Key101=0:0 Key102=65363:0 Key103=65367:0 Key104=65364:0 Key105=65366:0 Key106=65379:0 Key107=65535:127 Key108=65421:13 Key109=65508:0 Key110=65299:0 Key111=65377:0 Key112=65455:47 Key113=65514:0 Key114=0:0 Key115=65515:0 Key116=65516:0 Key117=65383:0 Key118=0:0 Key119=0:0 Key120=0:0 Key121=0:0 Key122=0:0 Key123=0:0 Key124=65027:0 Key125=0:0 Key126=65469:61 Key127=0:0 Key128=0:0 Key129=0:0 Key130=0:0 Key131=0:0 Key132=0:0 Key133=0:0 Key134=65454:46 Key135=0:0 Key136=0:0 Key137=0:0 [shiftaltgr] Key8=65406:0 Key9=65307:27 Key10=33:33 Key11=64:64 Key12=35:35 Key13=36:36 Key14=37:37 Key15=94:94 Key16=38:38 Key17=42:42 Key18=40:40 Key19=41:41 Key20=95:95 Key21=43:43 Key22=65288:8 Key23=65056:0 Key24=81:81 Key25=87:87 Key26=69:69 Key27=82:82 Key28=84:84 Key29=89:89 Key30=85:85 Key31=73:73 Key32=79:79 Key33=80:80 Key34=123:123 Key35=125:125 Key36=65293:13 Key37=65507:0 Key38=65:65 Key39=83:83 Key40=68:68 Key41=70:70 Key42=71:71 Key43=72:72 Key44=74:74 Key45=75:75 Key46=76:76 Key47=58:58 Key48=34:34 Key49=126:126 Key50=65505:0 Key51=124:124 Key52=90:90 Key53=88:88 Key54=67:67 Key55=86:86 Key56=66:66 Key57=78:78 Key58=77:77 Key59=60:60 Key60=62:62 Key61=63:63 Key62=65506:0 Key63=65450:42 Key64=65511:0 Key65=32:32 Key66=65509:0 Key67=65470:0 Key68=65471:0 Key69=65472:0 Key70=65473:0 Key71=65474:0 Key72=65475:0 Key73=65476:0 Key74=65477:0 Key75=65478:0 Key76=65479:0 Key77=65407:0 Key78=65300:0 Key79=65463:55 Key80=65464:56 Key81=65465:57 Key82=65453:45 Key83=65460:52 Key84=65461:53 Key85=65462:54 Key86=65451:43 Key87=65457:49 Key88=65458:50 Key89=65459:51 Key90=65456:48 Key91=65454:46 Key92=0:0 Key93=0:0 Key94=166:166 Key95=65480:0 Key96=65481:0 Key97=65360:0 Key98=65362:0 Key99=65365:0 Key100=65361:0 Key101=0:0 Key102=65363:0 Key103=65367:0 Key104=65364:0 Key105=65366:0 Key106=65379:0 Key107=65535:127 Key108=65421:13 Key109=65508:0 Key110=65299:0 Key111=65377:0 Key112=65455:47 Key113=65512:0 Key114=0:0 Key115=65515:0 Key116=65516:0 Key117=65383:0 Key118=0:0 Key119=0:0 Key120=0:0 Key121=0:0 Key122=0:0 Key123=0:0 Key124=65027:0 Key125=65513:0 Key126=65469:61 Key127=65515:0 Key128=65517:0 Key129=0:0 Key130=0:0 Key131=0:0 Key132=0:0 Key133=0:0 Key134=65454:46 Key135=0:0 Key136=0:0 Key137=0:0 [capslock] Key8=65406:0 Key9=65307:27 Key10=49:49 Key11=50:50 Key12=51:51 Key13=52:52 Key14=53:53 Key15=54:54 Key16=55:55 Key17=56:56 Key18=57:57 Key19=48:48 Key20=45:45 Key21=61:61 Key22=65288:8 Key23=65289:9 Key24=81:81 Key25=87:87 Key26=69:69 Key27=82:82 Key28=84:84 Key29=89:89 Key30=85:85 Key31=73:73 Key32=79:79 Key33=80:80 Key34=91:91 Key35=93:93 Key36=65293:13 Key37=65507:0 Key38=65:65 Key39=83:83 Key40=68:68 Key41=70:70 Key42=71:71 Key43=72:72 Key44=74:74 Key45=75:75 Key46=76:76 Key47=59:59 Key48=39:39 Key49=96:96 Key50=65505:0 Key51=92:92 Key52=90:90 Key53=88:88 Key54=67:67 Key55=86:86 Key56=66:66 Key57=78:78 Key58=77:77 Key59=44:44 Key60=46:46 Key61=47:47 Key62=65506:0 Key63=65450:42 Key64=65513:0 Key65=32:32 Key66=65509:0 Key67=65470:0 Key68=65471:0 Key69=65472:0 Key70=65473:0 Key71=65474:0 Key72=65475:0 Key73=65476:0 Key74=65477:0 Key75=65478:0 Key76=65479:0 Key77=65407:0 Key78=65300:0 Key79=65429:0 Key80=65431:0 Key81=65434:0 Key82=65453:45 Key83=65430:0 Key84=65437:0 Key85=65432:0 Key86=65451:43 Key87=65436:0 Key88=65433:0 Key89=65435:0 Key90=65438:0 Key91=65439:0 Key92=0:0 Key93=0:0 Key94=60:60 Key95=65480:0 Key96=65481:0 Key97=65360:0 Key98=65362:0 Key99=65365:0 Key100=65361:0 Key101=0:0 Key102=65363:0 Key103=65367:0 Key104=65364:0 Key105=65366:0 Key106=65379:0 Key107=65535:127 Key108=65421:13 Key109=65508:0 Key110=65299:0 Key111=65377:0 Key112=65455:47 Key113=65514:0 Key114=0:0 Key115=65515:0 Key116=65516:0 Key117=65383:0 Key118=0:0 Key119=0:0 Key120=0:0 Key121=0:0 Key122=0:0 Key123=0:0 Key124=65027:0 Key125=0:0 Key126=65469:61 Key127=0:0 Key128=0:0 Key129=0:0 Key130=0:0 Key131=0:0 Key132=0:0 Key133=0:0 Key134=65454:46 Key135=0:0 Key136=0:0 Key137=0:0 [capslockaltgr] Key8=65406:0 Key9=65307:27 Key10=49:49 Key11=50:50 Key12=51:51 Key13=52:52 Key14=53:53 Key15=54:54 Key16=55:55 Key17=56:56 Key18=57:57 Key19=48:48 Key20=45:45 Key21=61:61 Key22=65288:8 Key23=65289:9 Key24=81:81 Key25=87:87 Key26=69:69 Key27=82:82 Key28=84:84 Key29=89:89 Key30=85:85 Key31=73:73 Key32=79:79 Key33=80:80 Key34=91:91 Key35=93:93 Key36=65293:13 Key37=65507:0 Key38=65:65 Key39=83:83 Key40=68:68 Key41=70:70 Key42=71:71 Key43=72:72 Key44=74:74 Key45=75:75 Key46=76:76 Key47=59:59 Key48=39:39 Key49=96:96 Key50=65505:0 Key51=92:92 Key52=90:90 Key53=88:88 Key54=67:67 Key55=86:86 Key56=66:66 Key57=78:78 Key58=77:77 Key59=44:44 Key60=46:46 Key61=47:47 Key62=65506:0 Key63=65450:42 Key64=65513:0 Key65=32:32 Key66=65509:0 Key67=65470:0 Key68=65471:0 Key69=65472:0 Key70=65473:0 Key71=65474:0 Key72=65475:0 Key73=65476:0 Key74=65477:0 Key75=65478:0 Key76=65479:0 Key77=65407:0 Key78=65300:0 Key79=65429:0 Key80=65431:0 Key81=65434:0 Key82=65453:45 Key83=65430:0 Key84=65437:0 Key85=65432:0 Key86=65451:43 Key87=65436:0 Key88=65433:0 Key89=65435:0 Key90=65438:0 Key91=65439:0 Key92=0:0 Key93=0:0 Key94=124:124 Key95=65480:0 Key96=65481:0 Key97=65360:0 Key98=65362:0 Key99=65365:0 Key100=65361:0 Key101=0:0 Key102=65363:0 Key103=65367:0 Key104=65364:0 Key105=65366:0 Key106=65379:0 Key107=65535:127 Key108=65421:13 Key109=65508:0 Key110=65299:0 Key111=65377:0 Key112=65455:47 Key113=65514:0 Key114=0:0 Key115=65515:0 Key116=65516:0 Key117=65383:0 Key118=0:0 Key119=0:0 Key120=0:0 Key121=0:0 Key122=0:0 Key123=0:0 Key124=65027:0 Key125=0:0 Key126=65469:61 Key127=0:0 Key128=0:0 Key129=0:0 Key130=0:0 Key131=0:0 Key132=0:0 Key133=0:0 Key134=65454:46 Key135=0:0 Key136=0:0 Key137=0:0 [shiftcapslock] Key8=65406:0 Key9=65307:27 Key10=33:33 Key11=64:64 Key12=35:35 Key13=36:36 Key14=37:37 Key15=94:94 Key16=38:38 Key17=42:42 Key18=40:40 Key19=41:41 Key20=95:95 Key21=43:43 Key22=65288:8 Key23=65056:0 Key24=113:113 Key25=119:119 Key26=101:101 Key27=114:114 Key28=116:116 Key29=121:121 Key30=117:117 Key31=105:105 Key32=111:111 Key33=112:112 Key34=123:123 Key35=125:125 Key36=65293:13 Key37=65507:0 Key38=97:97 Key39=115:115 Key40=100:100 Key41=102:102 Key42=103:103 Key43=104:104 Key44=106:106 Key45=107:107 Key46=108:108 Key47=58:58 Key48=34:34 Key49=126:126 Key50=65505:0 Key51=124:124 Key52=122:122 Key53=120:120 Key54=99:99 Key55=118:118 Key56=98:98 Key57=110:110 Key58=109:109 Key59=60:60 Key60=62:62 Key61=63:63 Key62=65506:0 Key63=65450:42 Key64=65511:0 Key65=32:32 Key66=65509:0 Key67=65470:0 Key68=65471:0 Key69=65472:0 Key70=65473:0 Key71=65474:0 Key72=65475:0 Key73=65476:0 Key74=65477:0 Key75=65478:0 Key76=65479:0 Key77=65407:0 Key78=65300:0 Key79=65463:55 Key80=65464:56 Key81=65465:57 Key82=65453:45 Key83=65460:52 Key84=65461:53 Key85=65462:54 Key86=65451:43 Key87=65457:49 Key88=65458:50 Key89=65459:51 Key90=65456:48 Key91=65454:46 Key92=0:0 Key93=0:0 Key94=62:62 Key95=65480:0 Key96=65481:0 Key97=65360:0 Key98=65362:0 Key99=65365:0 Key100=65361:0 Key101=0:0 Key102=65363:0 Key103=65367:0 Key104=65364:0 Key105=65366:0 Key106=65379:0 Key107=65535:127 Key108=65421:13 Key109=65508:0 Key110=65299:0 Key111=65377:0 Key112=65455:47 Key113=65512:0 Key114=0:0 Key115=65515:0 Key116=65516:0 Key117=65383:0 Key118=0:0 Key119=0:0 Key120=0:0 Key121=0:0 Key122=0:0 Key123=0:0 Key124=65027:0 Key125=65513:0 Key126=65469:61 Key127=65515:0 Key128=65517:0 Key129=0:0 Key130=0:0 Key131=0:0 Key132=0:0 Key133=0:0 Key134=65454:46 Key135=0:0 Key136=0:0 Key137=0:0 [shiftcapslockaltgr] Key8=65406:0 Key9=65307:27 Key10=33:33 Key11=64:64 Key12=35:35 Key13=36:36 Key14=37:37 Key15=94:94 Key16=38:38 Key17=42:42 Key18=40:40 Key19=41:41 Key20=95:95 Key21=43:43 Key22=65288:8 Key23=65056:0 Key24=113:113 Key25=119:119 Key26=101:101 Key27=114:114 Key28=116:116 Key29=121:121 Key30=117:117 Key31=105:105 Key32=111:111 Key33=112:112 Key34=123:123 Key35=125:125 Key36=65293:13 Key37=65507:0 Key38=97:97 Key39=115:115 Key40=100:100 Key41=102:102 Key42=103:103 Key43=104:104 Key44=106:106 Key45=107:107 Key46=108:108 Key47=58:58 Key48=34:34 Key49=126:126 Key50=65505:0 Key51=124:124 Key52=122:122 Key53=120:120 Key54=99:99 Key55=118:118 Key56=98:98 Key57=110:110 Key58=109:109 Key59=60:60 Key60=62:62 Key61=63:63 Key62=65506:0 Key63=65450:42 Key64=65511:0 Key65=32:32 Key66=65509:0 Key67=65470:0 Key68=65471:0 Key69=65472:0 Key70=65473:0 Key71=65474:0 Key72=65475:0 Key73=65476:0 Key74=65477:0 Key75=65478:0 Key76=65479:0 Key77=65407:0 Key78=65300:0 Key79=65463:55 Key80=65464:56 Key81=65465:57 Key82=65453:45 Key83=65460:52 Key84=65461:53 Key85=65462:54 Key86=65451:43 Key87=65457:49 Key88=65458:50 Key89=65459:51 Key90=65456:48 Key91=65454:46 Key92=0:0 Key93=0:0 Key94=166:166 Key95=65480:0 Key96=65481:0 Key97=65360:0 Key98=65362:0 Key99=65365:0 Key100=65361:0 Key101=0:0 Key102=65363:0 Key103=65367:0 Key104=65364:0 Key105=65366:0 Key106=65379:0 Key107=65535:127 Key108=65421:13 Key109=65508:0 Key110=65299:0 Key111=65377:0 Key112=65455:47 Key113=65512:0 Key114=0:0 Key115=65515:0 Key116=65516:0 Key117=65383:0 Key118=0:0 Key119=0:0 Key120=0:0 Key121=0:0 Key122=0:0 Key123=0:0 Key124=65027:0 Key125=65513:0 Key126=65469:61 Key127=65515:0 Key128=65517:0 Key129=0:0 Key130=0:0 Key131=0:0 Key132=0:0 Key133=0:0 Key134=65454:46 Key135=0:0 Key136=0:0 Key137=0:0 Key209=65329:0 Key210=65332:0 xrdp-0.9.5/instfiles/km-00000415.ini000644 001751 001751 00000025242 13127114621 016424 0ustar00metameta000000 000000 [noshift] Key8=65406:0 Key9=65307:27 Key10=49:49 Key11=50:50 Key12=51:51 Key13=52:52 Key14=53:53 Key15=54:54 Key16=55:55 Key17=56:56 Key18=57:57 Key19=48:48 Key20=45:45 Key21=61:61 Key22=65288:8 Key23=65289:9 Key24=113:113 Key25=119:119 Key26=101:101 Key27=114:114 Key28=116:116 Key29=121:121 Key30=117:117 Key31=105:105 Key32=111:111 Key33=112:112 Key34=91:91 Key35=93:93 Key36=65293:13 Key37=65507:0 Key38=97:97 Key39=115:115 Key40=100:100 Key41=102:102 Key42=103:103 Key43=104:104 Key44=106:106 Key45=107:107 Key46=108:108 Key47=59:59 Key48=39:39 Key49=96:96 Key50=65505:0 Key51=92:92 Key52=122:122 Key53=120:120 Key54=99:99 Key55=118:118 Key56=98:98 Key57=110:110 Key58=109:109 Key59=44:44 Key60=46:46 Key61=47:47 Key62=65506:0 Key63=65450:42 Key64=65513:0 Key65=32:32 Key66=65509:0 Key67=65470:0 Key68=65471:0 Key69=65472:0 Key70=65473:0 Key71=65474:0 Key72=65475:0 Key73=65476:0 Key74=65477:0 Key75=65478:0 Key76=65479:0 Key77=65407:0 Key78=65300:0 Key79=65429:0 Key80=65431:0 Key81=65434:0 Key82=65453:45 Key83=65430:0 Key84=65437:0 Key85=65432:0 Key86=65451:43 Key87=65436:0 Key88=65433:0 Key89=65435:0 Key90=65438:0 Key91=65439:0 Key92=65377:0 Key93=0:0 Key94=60:60 Key95=65480:0 Key96=65481:0 Key97=65360:0 Key98=65362:0 Key99=65365:0 Key100=65361:0 Key101=0:0 Key102=65363:0 Key103=65367:0 Key104=65364:0 Key105=65366:0 Key106=65379:0 Key107=65535:127 Key108=65421:13 Key109=65508:0 Key110=65299:0 Key111=65377:0 Key112=65455:47 Key113=65027:0 Key114=269025049:0 Key115=65515:0 Key116=65312:0 Key117=0:0 Key118=269025153:0 Key119=269025093:0 Key120=269025094:0 Key121=269025095:0 Key122=269025096:0 Key123=0:0 Key124=65027:0 Key125=0:0 Key126=65469:61 Key127=0:0 Key128=0:0 Key129=0:0 Key130=0:0 Key131=0:0 Key132=0:0 Key133=0:0 Key134=0:0 Key135=0:0 Key136=0:0 Key137=0:0 [shift] Key8=65406:0 Key9=65307:27 Key10=33:33 Key11=64:64 Key12=35:35 Key13=36:36 Key14=37:37 Key15=94:94 Key16=38:38 Key17=42:42 Key18=40:40 Key19=41:41 Key20=95:95 Key21=43:43 Key22=65288:8 Key23=65056:0 Key24=81:81 Key25=87:87 Key26=69:69 Key27=82:82 Key28=84:84 Key29=89:89 Key30=85:85 Key31=73:73 Key32=79:79 Key33=80:80 Key34=123:123 Key35=125:125 Key36=65293:13 Key37=65507:0 Key38=65:65 Key39=83:83 Key40=68:68 Key41=70:70 Key42=71:71 Key43=72:72 Key44=74:74 Key45=75:75 Key46=76:76 Key47=58:58 Key48=34:34 Key49=126:126 Key50=65505:0 Key51=124:124 Key52=90:90 Key53=88:88 Key54=67:67 Key55=86:86 Key56=66:66 Key57=78:78 Key58=77:77 Key59=60:60 Key60=62:62 Key61=63:63 Key62=65506:0 Key63=65450:42 Key64=65032:0 Key65=32:32 Key66=65509:0 Key67=65470:0 Key68=65471:0 Key69=65472:0 Key70=65473:0 Key71=65474:0 Key72=65475:0 Key73=65476:0 Key74=65477:0 Key75=65478:0 Key76=65479:0 Key77=65407:0 Key78=65300:0 Key79=65463:55 Key80=65464:56 Key81=65465:57 Key82=65453:45 Key83=65460:52 Key84=65461:53 Key85=65462:54 Key86=65451:43 Key87=65457:49 Key88=65458:50 Key89=65459:51 Key90=65456:48 Key91=65452:44 Key92=65377:0 Key93=0:0 Key94=62:62 Key95=65480:0 Key96=65481:0 Key97=65360:0 Key98=65362:0 Key99=65365:0 Key100=65361:0 Key101=0:0 Key102=65363:0 Key103=65367:0 Key104=65364:0 Key105=65366:0 Key106=65379:0 Key107=65535:127 Key108=65421:13 Key109=65508:0 Key110=65299:0 Key111=65377:0 Key112=65455:47 Key113=65027:0 Key114=269025049:0 Key115=65515:0 Key116=65312:0 Key117=0:0 Key118=269025153:0 Key119=269025093:0 Key120=269025094:0 Key121=269025095:0 Key122=269025096:0 Key123=0:0 Key124=65027:0 Key125=65513:0 Key126=65469:61 Key127=65515:0 Key128=65517:0 Key129=0:0 Key130=0:0 Key131=0:0 Key132=0:0 Key133=0:0 Key134=0:0 Key135=0:0 Key136=0:0 Key137=0:0 [altgr] Key8=65406:0 Key9=65307:27 Key10=2237:8800 Key11=178:178 Key12=179:179 Key13=162:162 Key14=8364:8364 Key15=189:189 Key16=167:167 Key17=183:183 Key18=171:171 Key19=187:187 Key20=2730:8211 Key21=65115:184 Key22=65288:8 Key23=65289:9 Key24=2032:960 Key25=5053:339 Key26=490:281 Key27=169:169 Key28=223:223 Key29=2299:8592 Key30=2302:8595 Key31=2301:8594 Key32=243:243 Key33=254:254 Key34=65111:168 Key35=65107:126 Key36=65293:13 Key37=65507:0 Key38=433:261 Key39=438:347 Key40=240:240 Key41=230:230 Key42=959:331 Key43=2769:8217 Key44=16777817:601 Key45=2734:8230 Key46=435:322 Key47=65105:180 Key48=65106:94 Key49=172:172 Key50=65505:0 Key51=65104:96 Key52=447:380 Key53=444:378 Key54=486:263 Key55=2814:8222 Key56=2771:8221 Key57=497:324 Key58=181:181 Key59=2236:8804 Key60=2238:8805 Key61=65120:0 Key62=65506:0 Key63=65450:42 Key64=65513:0 Key65=160:160 Key66=65509:0 Key67=65470:0 Key68=65471:0 Key69=65472:0 Key70=65473:0 Key71=65474:0 Key72=65475:0 Key73=65476:0 Key74=65477:0 Key75=65478:0 Key76=65479:0 Key77=65407:0 Key78=65300:0 Key79=65429:0 Key80=65431:0 Key81=65434:0 Key82=65453:45 Key83=65430:0 Key84=65437:0 Key85=65432:0 Key86=65451:43 Key87=65436:0 Key88=65433:0 Key89=65435:0 Key90=65438:0 Key91=65439:0 Key92=65377:0 Key93=0:0 Key94=124:124 Key95=65480:0 Key96=65481:0 Key97=65360:0 Key98=65362:0 Key99=65365:0 Key100=65361:0 Key101=0:0 Key102=65363:0 Key103=65367:0 Key104=65364:0 Key105=65366:0 Key106=65379:0 Key107=65535:127 Key108=65421:13 Key109=65508:0 Key110=65299:0 Key111=65377:0 Key112=65455:47 Key113=65027:0 Key114=269025049:0 Key115=65515:0 Key116=65312:0 Key117=0:0 Key118=269025153:0 Key119=269025093:0 Key120=269025094:0 Key121=269025095:0 Key122=269025096:0 Key123=0:0 Key124=65027:0 Key125=0:0 Key126=65469:61 Key127=0:0 Key128=0:0 Key129=0:0 Key130=0:0 Key131=0:0 Key132=0:0 Key133=0:0 Key134=0:0 Key135=0:0 Key136=0:0 Key137=0:0 [shiftaltgr] Key8=65406:0 Key9=65307:27 Key10=161:161 Key11=191:191 Key12=163:163 Key13=188:188 Key14=16785456:8240 Key15=2270:8743 Key16=16785992:8776 Key17=190:190 Key18=177:177 Key19=176:176 Key20=2729:8212 Key21=65116:731 Key22=65288:8 Key23=65056:0 Key24=2009:937 Key25=5052:338 Key26=458:280 Key27=174:174 Key28=2761:8482 Key29=165:165 Key30=2300:8593 Key31=16785812:8596 Key32=211:211 Key33=222:222 Key34=65112:176 Key35=65108:175 Key36=65293:13 Key37=65507:0 Key38=417:260 Key39=422:346 Key40=208:208 Key41=198:198 Key42=957:330 Key43=16785442:8226 Key44=16777615:399 Key45=65123:0 Key46=419:321 Key47=65113:733 Key48=65114:711 Key49=2271:8744 Key50=65505:0 Key51=65109:728 Key52=431:379 Key53=428:377 Key54=454:262 Key55=2768:8216 Key56=2770:8220 Key57=465:323 Key58=2242:8734 Key59=215:215 Key60=247:247 Key61=65110:729 Key62=65506:0 Key63=65450:42 Key64=65032:0 Key65=160:160 Key66=65509:0 Key67=65470:0 Key68=65471:0 Key69=65472:0 Key70=65473:0 Key71=65474:0 Key72=65475:0 Key73=65476:0 Key74=65477:0 Key75=65478:0 Key76=65479:0 Key77=65407:0 Key78=65300:0 Key79=65463:55 Key80=65464:56 Key81=65465:57 Key82=65453:45 Key83=65460:52 Key84=65461:53 Key85=65462:54 Key86=65451:43 Key87=65457:49 Key88=65458:50 Key89=65459:51 Key90=65456:48 Key91=65452:44 Key92=65377:0 Key93=0:0 Key94=166:166 Key95=65480:0 Key96=65481:0 Key97=65360:0 Key98=65362:0 Key99=65365:0 Key100=65361:0 Key101=0:0 Key102=65363:0 Key103=65367:0 Key104=65364:0 Key105=65366:0 Key106=65379:0 Key107=65535:127 Key108=65421:13 Key109=65508:0 Key110=65299:0 Key111=65377:0 Key112=65455:47 Key113=65027:0 Key114=269025049:0 Key115=65515:0 Key116=65312:0 Key117=0:0 Key118=269025153:0 Key119=269025093:0 Key120=269025094:0 Key121=269025095:0 Key122=269025096:0 Key123=0:0 Key124=65027:0 Key125=65513:0 Key126=65469:61 Key127=65515:0 Key128=65517:0 Key129=0:0 Key130=0:0 Key131=0:0 Key132=0:0 Key133=0:0 Key134=0:0 Key135=0:0 Key136=0:0 Key137=0:0 [capslock] Key8=65406:0 Key9=65307:27 Key10=49:49 Key11=50:50 Key12=51:51 Key13=52:52 Key14=53:53 Key15=54:54 Key16=55:55 Key17=56:56 Key18=57:57 Key19=48:48 Key20=45:45 Key21=61:61 Key22=65288:8 Key23=65289:9 Key24=81:81 Key25=87:87 Key26=69:69 Key27=82:82 Key28=84:84 Key29=89:89 Key30=85:85 Key31=73:73 Key32=79:79 Key33=80:80 Key34=91:91 Key35=93:93 Key36=65293:13 Key37=65507:0 Key38=65:65 Key39=83:83 Key40=68:68 Key41=70:70 Key42=71:71 Key43=72:72 Key44=74:74 Key45=75:75 Key46=76:76 Key47=59:59 Key48=39:39 Key49=96:96 Key50=65505:0 Key51=92:92 Key52=90:90 Key53=88:88 Key54=67:67 Key55=86:86 Key56=66:66 Key57=78:78 Key58=77:77 Key59=44:44 Key60=46:46 Key61=47:47 Key62=65506:0 Key63=65450:42 Key64=65513:0 Key65=32:32 Key66=65509:0 Key67=65470:0 Key68=65471:0 Key69=65472:0 Key70=65473:0 Key71=65474:0 Key72=65475:0 Key73=65476:0 Key74=65477:0 Key75=65478:0 Key76=65479:0 Key77=65407:0 Key78=65300:0 Key79=65429:0 Key80=65431:0 Key81=65434:0 Key82=65453:45 Key83=65430:0 Key84=65437:0 Key85=65432:0 Key86=65451:43 Key87=65436:0 Key88=65433:0 Key89=65435:0 Key90=65438:0 Key91=65439:0 Key92=65377:0 Key93=0:0 Key94=60:60 Key95=65480:0 Key96=65481:0 Key97=65360:0 Key98=65362:0 Key99=65365:0 Key100=65361:0 Key101=0:0 Key102=65363:0 Key103=65367:0 Key104=65364:0 Key105=65366:0 Key106=65379:0 Key107=65535:127 Key108=65421:13 Key109=65508:0 Key110=65299:0 Key111=65377:0 Key112=65455:47 Key113=65027:0 Key114=269025049:0 Key115=65515:0 Key116=65312:0 Key117=0:0 Key118=269025153:0 Key119=269025093:0 Key120=269025094:0 Key121=269025095:0 Key122=269025096:0 Key123=0:0 Key124=65027:0 Key125=0:0 Key126=65469:61 Key127=0:0 Key128=0:0 Key129=0:0 Key130=0:0 Key131=0:0 Key132=0:0 Key133=0:0 Key134=0:0 Key135=0:0 Key136=0:0 Key137=0:0 [shiftcapslock] Key8=65406:0 Key9=65307:27 Key10=33:33 Key11=64:64 Key12=35:35 Key13=36:36 Key14=37:37 Key15=94:94 Key16=38:38 Key17=42:42 Key18=40:40 Key19=41:41 Key20=95:95 Key21=43:43 Key22=65288:8 Key23=65056:0 Key24=113:113 Key25=119:119 Key26=101:101 Key27=114:114 Key28=116:116 Key29=121:121 Key30=117:117 Key31=105:105 Key32=111:111 Key33=112:112 Key34=123:123 Key35=125:125 Key36=65293:13 Key37=65507:0 Key38=97:97 Key39=115:115 Key40=100:100 Key41=102:102 Key42=103:103 Key43=104:104 Key44=106:106 Key45=107:107 Key46=108:108 Key47=58:58 Key48=34:34 Key49=126:126 Key50=65505:0 Key51=124:124 Key52=122:122 Key53=120:120 Key54=99:99 Key55=118:118 Key56=98:98 Key57=110:110 Key58=109:109 Key59=60:60 Key60=62:62 Key61=63:63 Key62=65506:0 Key63=65450:42 Key64=65032:0 Key65=32:32 Key66=65509:0 Key67=65470:0 Key68=65471:0 Key69=65472:0 Key70=65473:0 Key71=65474:0 Key72=65475:0 Key73=65476:0 Key74=65477:0 Key75=65478:0 Key76=65479:0 Key77=65407:0 Key78=65300:0 Key79=65463:55 Key80=65464:56 Key81=65465:57 Key82=65453:45 Key83=65460:52 Key84=65461:53 Key85=65462:54 Key86=65451:43 Key87=65457:49 Key88=65458:50 Key89=65459:51 Key90=65456:48 Key91=65452:44 Key92=65377:0 Key93=0:0 Key94=62:62 Key95=65480:0 Key96=65481:0 Key97=65360:0 Key98=65362:0 Key99=65365:0 Key100=65361:0 Key101=0:0 Key102=65363:0 Key103=65367:0 Key104=65364:0 Key105=65366:0 Key106=65379:0 Key107=65535:127 Key108=65421:13 Key109=65508:0 Key110=65299:0 Key111=65377:0 Key112=65455:47 Key113=65027:0 Key114=269025049:0 Key115=65515:0 Key116=65312:0 Key117=0:0 Key118=269025153:0 Key119=269025093:0 Key120=269025094:0 Key121=269025095:0 Key122=269025096:0 Key123=0:0 Key124=65027:0 Key125=65513:0 Key126=65469:61 Key127=65515:0 Key128=65517:0 Key129=0:0 Key130=0:0 Key131=0:0 Key132=0:0 Key133=0:0 Key134=0:0 Key135=0:0 Key136=0:0 Key137=0:0 xrdp-0.9.5/instfiles/km-0000040a.ini000644 001751 001751 00000021024 13127114621 016471 0ustar00metameta000000 000000 [noshift] Key8=0:0 Key9=65307:27 Key10=49:49 Key11=50:50 Key12=51:51 Key13=52:52 Key14=53:53 Key15=54:54 Key16=55:55 Key17=56:56 Key18=57:57 Key19=48:48 Key20=39:39 Key21=161:161 Key22=65288:8 Key23=65289:9 Key24=113:113 Key25=119:119 Key26=101:101 Key27=114:114 Key28=116:116 Key29=121:121 Key30=117:117 Key31=105:105 Key32=111:111 Key33=112:112 Key34=65104:96 Key35=43:43 Key36=65293:13 Key37=65507:0 Key38=97:97 Key39=115:115 Key40=100:100 Key41=102:102 Key42=103:103 Key43=104:104 Key44=106:106 Key45=107:107 Key46=108:108 Key47=241:241 Key48=65105:180 Key49=186:186 Key50=65505:0 Key51=231:231 Key52=122:122 Key53=120:120 Key54=99:99 Key55=118:118 Key56=98:98 Key57=110:110 Key58=109:109 Key59=44:44 Key60=46:46 Key61=45:45 Key62=65506:0 Key63=65450:42 Key64=65364:0 Key65=32:32 Key66=65509:0 Key67=65470:0 Key68=65471:0 Key69=65472:0 Key70=65473:0 Key71=65474:0 Key72=65475:0 Key73=65476:0 Key74=65477:0 Key75=65478:0 Key76=65479:0 Key77=65407:0 Key78=65300:0 Key79=65429:0 Key80=65431:0 Key81=65434:0 Key82=65453:45 Key83=65430:0 Key84=65437:0 Key85=65432:0 Key86=65451:43 Key87=65436:0 Key88=65433:0 Key89=65435:0 Key90=65438:0 Key91=65439:0 Key92=0:0 Key93=0:0 Key94=60:60 Key95=65480:0 Key96=65481:0 Key97=65360:0 Key98=65362:0 Key99=65365:0 Key100=65361:0 Key101=0:0 Key102=65363:0 Key103=65367:0 Key104=65364:0 Key105=65366:0 Key106=65379:0 Key107=65535:127 Key108=65421:13 Key109=65508:0 Key110=65299:0 Key111=65377:0 Key112=65455:47 Key113=65514:0 Key114=0:0 Key115=65515:0 Key116=65516:0 Key117=65383:0 Key118=0:0 Key119=0:0 Key120=0:0 Key121=0:0 Key122=0:0 Key123=0:0 Key124=65027:0 Key125=0:0 Key126=65469:61 Key127=0:0 Key128=0:0 Key129=0:0 Key130=0:0 Key131=0:0 Key132=0:0 Key133=0:0 Key134=0:0 Key135=0:0 Key136=0:0 Key137=0:0 [shift] Key8=0:0 Key9=65307:27 Key10=33:33 Key11=34:34 Key12=183:183 Key13=36:36 Key14=37:37 Key15=38:38 Key16=47:47 Key17=40:40 Key18=41:41 Key19=61:61 Key20=63:63 Key21=191:191 Key22=65288:8 Key23=65056:0 Key24=81:81 Key25=87:87 Key26=69:69 Key27=82:82 Key28=84:84 Key29=89:89 Key30=85:85 Key31=73:73 Key32=79:79 Key33=80:80 Key34=65106:94 Key35=42:42 Key36=65293:13 Key37=65507:0 Key38=65:65 Key39=83:83 Key40=68:68 Key41=70:70 Key42=71:71 Key43=72:72 Key44=74:74 Key45=75:75 Key46=76:76 Key47=209:209 Key48=65111:168 Key49=170:170 Key50=65505:0 Key51=199:199 Key52=90:90 Key53=88:88 Key54=67:67 Key55=86:86 Key56=66:66 Key57=78:78 Key58=77:77 Key59=59:59 Key60=58:58 Key61=95:95 Key62=65506:0 Key63=65450:42 Key64=65364:0 Key65=32:32 Key66=65509:0 Key67=65470:0 Key68=65471:0 Key69=65472:0 Key70=65473:0 Key71=65474:0 Key72=65475:0 Key73=65476:0 Key74=65477:0 Key75=65478:0 Key76=65479:0 Key77=65273:0 Key78=65300:0 Key79=65463:55 Key80=65464:56 Key81=65465:57 Key82=65453:45 Key83=65460:52 Key84=65461:53 Key85=65462:54 Key86=65451:43 Key87=65457:49 Key88=65458:50 Key89=65459:51 Key90=65456:48 Key91=65454:46 Key92=0:0 Key93=0:0 Key94=62:62 Key95=65480:0 Key96=65481:0 Key97=65360:0 Key98=65362:0 Key99=65365:0 Key100=65361:0 Key101=0:0 Key102=65363:0 Key103=65367:0 Key104=65364:0 Key105=65366:0 Key106=65379:0 Key107=65535:127 Key108=65421:13 Key109=65508:0 Key110=65299:0 Key111=65377:0 Key112=65455:47 Key113=65512:0 Key114=0:0 Key115=65515:0 Key116=65516:0 Key117=65383:0 Key118=0:0 Key119=0:0 Key120=0:0 Key121=0:0 Key122=0:0 Key123=0:0 Key124=65027:0 Key125=65513:0 Key126=65469:61 Key127=65515:0 Key128=65517:0 Key129=0:0 Key130=0:0 Key131=0:0 Key132=0:0 Key133=0:0 Key134=0:0 Key135=0:0 Key136=0:0 Key137=0:0 [altgr] Key8=0:0 Key9=65307:27 Key10=124:124 Key11=64:64 Key12=35:35 Key13=126:126 Key14=189:189 Key15=172:172 Key16=123:123 Key17=91:91 Key18=93:93 Key19=125:125 Key20=92:92 Key21=126:126 Key22=65288:8 Key23=65289:9 Key24=64:64 Key25=435:322 Key26=8364:8364 Key27=182:182 Key28=956:359 Key29=2299:8592 Key30=2302:8595 Key31=2301:8594 Key32=248:248 Key33=254:254 Key34=91:91 Key35=93:93 Key36=65293:13 Key37=65507:0 Key38=230:230 Key39=223:223 Key40=240:240 Key41=496:273 Key42=959:331 Key43=689:295 Key44=106:106 Key45=930:312 Key46=435:322 Key47=126:126 Key48=123:123 Key49=92:92 Key50=65505:0 Key51=125:125 Key52=171:171 Key53=187:187 Key54=162:162 Key55=2770:8220 Key56=2771:8221 Key57=110:110 Key58=181:181 Key59=2211:0 Key60=183:183 Key61=65120:0 Key62=65506:0 Key63=65450:42 Key64=65364:0 Key65=32:32 Key66=65509:0 Key67=65470:0 Key68=65471:0 Key69=65472:0 Key70=65473:0 Key71=65474:0 Key72=65475:0 Key73=65476:0 Key74=65477:0 Key75=65478:0 Key76=65479:0 Key77=65407:0 Key78=65300:0 Key79=65429:0 Key80=65431:0 Key81=65434:0 Key82=65453:45 Key83=65430:0 Key84=65437:0 Key85=65432:0 Key86=65451:43 Key87=65436:0 Key88=65433:0 Key89=65435:0 Key90=65438:0 Key91=65439:0 Key92=0:0 Key93=0:0 Key94=124:124 Key95=65480:0 Key96=65481:0 Key97=65360:0 Key98=65362:0 Key99=65365:0 Key100=65361:0 Key101=0:0 Key102=65363:0 Key103=65367:0 Key104=65364:0 Key105=65366:0 Key106=65379:0 Key107=65535:127 Key108=65421:13 Key109=65508:0 Key110=65299:0 Key111=0:0 Key112=65455:47 Key113=65514:0 Key114=0:0 Key115=65515:0 Key116=65516:0 Key117=65383:0 Key118=0:0 Key119=0:0 Key120=0:0 Key121=0:0 Key122=0:0 Key123=0:0 Key124=65027:0 Key125=0:0 Key126=65469:61 Key127=0:0 Key128=0:0 Key129=0:0 Key130=0:0 Key131=0:0 Key132=0:0 Key133=0:0 Key134=0:0 Key135=0:0 Key136=0:0 Key137=0:0 [capslock] Key8=0:0 Key9=65307:27 Key10=49:49 Key11=50:50 Key12=51:51 Key13=52:52 Key14=53:53 Key15=54:54 Key16=55:55 Key17=56:56 Key18=57:57 Key19=48:48 Key20=39:39 Key21=161:161 Key22=65288:8 Key23=65289:9 Key24=81:81 Key25=87:87 Key26=69:69 Key27=82:82 Key28=84:84 Key29=89:89 Key30=85:85 Key31=73:73 Key32=79:79 Key33=80:80 Key34=65104:96 Key35=43:43 Key36=65293:13 Key37=65507:0 Key38=65:65 Key39=83:83 Key40=68:68 Key41=70:70 Key42=71:71 Key43=72:72 Key44=74:74 Key45=75:75 Key46=76:76 Key47=209:209 Key48=65105:180 Key49=186:186 Key50=65505:0 Key51=199:199 Key52=90:90 Key53=88:88 Key54=67:67 Key55=86:86 Key56=66:66 Key57=78:78 Key58=77:77 Key59=44:44 Key60=46:46 Key61=45:45 Key62=65506:0 Key63=65450:42 Key64=65364:0 Key65=32:32 Key66=65509:0 Key67=65470:0 Key68=65471:0 Key69=65472:0 Key70=65473:0 Key71=65474:0 Key72=65475:0 Key73=65476:0 Key74=65477:0 Key75=65478:0 Key76=65479:0 Key77=65407:0 Key78=65300:0 Key79=65429:0 Key80=65431:0 Key81=65434:0 Key82=65453:45 Key83=65430:0 Key84=65437:0 Key85=65432:0 Key86=65451:43 Key87=65436:0 Key88=65433:0 Key89=65435:0 Key90=65438:0 Key91=65439:0 Key92=0:0 Key93=0:0 Key94=60:60 Key95=65480:0 Key96=65481:0 Key97=65360:0 Key98=65362:0 Key99=65365:0 Key100=65361:0 Key101=0:0 Key102=65363:0 Key103=65367:0 Key104=65364:0 Key105=65366:0 Key106=65379:0 Key107=65535:127 Key108=65421:13 Key109=65508:0 Key110=65299:0 Key111=65377:0 Key112=65455:47 Key113=65514:0 Key114=0:0 Key115=65515:0 Key116=65516:0 Key117=65383:0 Key118=0:0 Key119=0:0 Key120=0:0 Key121=0:0 Key122=0:0 Key123=0:0 Key124=65027:0 Key125=0:0 Key126=65469:61 Key127=0:0 Key128=0:0 Key129=0:0 Key130=0:0 Key131=0:0 Key132=0:0 Key133=0:0 Key134=0:0 Key135=0:0 Key136=0:0 Key137=0:0 [shiftcapslock] Key8=0:0 Key9=65307:27 Key10=33:33 Key11=34:34 Key12=183:183 Key13=36:36 Key14=37:37 Key15=38:38 Key16=47:47 Key17=40:40 Key18=41:41 Key19=61:61 Key20=63:63 Key21=191:191 Key22=65288:8 Key23=65056:0 Key24=113:113 Key25=119:119 Key26=101:101 Key27=114:114 Key28=116:116 Key29=121:121 Key30=117:117 Key31=105:105 Key32=111:111 Key33=112:112 Key34=65106:94 Key35=42:42 Key36=65293:13 Key37=65507:0 Key38=97:97 Key39=115:115 Key40=100:100 Key41=102:102 Key42=103:103 Key43=104:104 Key44=106:106 Key45=107:107 Key46=108:108 Key47=241:241 Key48=65111:168 Key49=170:170 Key50=65505:0 Key51=231:231 Key52=122:122 Key53=120:120 Key54=99:99 Key55=118:118 Key56=98:98 Key57=110:110 Key58=109:109 Key59=59:59 Key60=58:58 Key61=95:95 Key62=65506:0 Key63=65450:42 Key64=65364:0 Key65=32:32 Key66=65509:0 Key67=65470:0 Key68=65471:0 Key69=65472:0 Key70=65473:0 Key71=65474:0 Key72=65475:0 Key73=65476:0 Key74=65477:0 Key75=65478:0 Key76=65479:0 Key77=65273:0 Key78=65300:0 Key79=65463:55 Key80=65464:56 Key81=65465:57 Key82=65453:45 Key83=65460:52 Key84=65461:53 Key85=65462:54 Key86=65451:43 Key87=65457:49 Key88=65458:50 Key89=65459:51 Key90=65456:48 Key91=65454:46 Key92=0:0 Key93=0:0 Key94=62:62 Key95=65480:0 Key96=65481:0 Key97=65360:0 Key98=65362:0 Key99=65365:0 Key100=65361:0 Key101=0:0 Key102=65363:0 Key103=65367:0 Key104=65364:0 Key105=65366:0 Key106=65379:0 Key107=65535:127 Key108=65421:13 Key109=65508:0 Key110=65299:0 Key111=65377:0 Key112=65455:47 Key113=65512:0 Key114=0:0 Key115=65515:0 Key116=65516:0 Key117=65383:0 Key118=0:0 Key119=0:0 Key120=0:0 Key121=0:0 Key122=0:0 Key123=0:0 Key124=65027:0 Key125=65513:0 Key126=65469:61 Key127=65515:0 Key128=65517:0 Key129=0:0 Key130=0:0 Key131=0:0 Key132=0:0 Key133=0:0 Key134=0:0 Key135=0:0 Key136=0:0 Key137=0:0 xrdp-0.9.5/instfiles/xrdp.sh000755 001751 001751 00000004750 13124203623 015740 0ustar00metameta000000 000000 #!/bin/sh # xrdp control script # Written : 1-13-2006 - Mark Balliet - posicat@pobox.com # maintaned by Jay Sorg # chkconfig: 2345 11 89 # description: starts xrdp ### BEGIN INIT INFO # Provides: xrdp # Required-Start: # Required-Stop: # Should-Start: # Should-Stop: # Default-Start: 2 3 4 5 # Default-Stop: 0 1 6 # Short-Description: Start and stop xrdp # Description: starts xrdp ### END INIT INFO SBINDIR=/usr/local/sbin LOG=/dev/null CFGDIR=/etc/xrdp if ! test -x $SBINDIR/xrdp then echo "xrdp is not executable" exit 0 fi if ! test -x $SBINDIR/xrdp-sesman then echo "xrdp-sesman is not executable" exit 0 fi if ! test -x $CFGDIR/startwm.sh then echo "startwm.sh is not executable" exit 0 fi xrdp_start() { echo -n "Starting: xrdp and sesman . . " $SBINDIR/xrdp >> $LOG $SBINDIR/xrdp-sesman >> $LOG echo "." sleep 1 return 0; } xrdp_stop() { echo -n "Stopping: xrdp and sesman . . " $SBINDIR/xrdp-sesman --kill >> $LOG $SBINDIR/xrdp --kill >> $LOG echo "." return 0; } is_xrdp_running() { ps u --noheading -C xrdp | grep -q -i xrdp if test $? -eq 0 then return 1; else return 0; fi } is_sesman_running() { ps u --noheading -C xrdp-sesman | grep -q -i xrdp-sesman if test $? -eq 0 then return 1; else return 0; fi } check_up() { # Cleanup : If sesman isn't running, but the pid exists, erase it. is_sesman_running if test $? -eq 0 then if test -e /var/run/xrdp-sesman.pid then rm /var/run/xrdp-sesman.pid fi fi # Cleanup : If xrdp isn't running, but the pid exists, erase it. is_xrdp_running if test $? -eq 0 then if test -e /var/run/xrdp.pid then rm /var/run/xrdp.pid fi fi return 0; } case "$1" in start) check_up is_xrdp_running if ! test $? -eq 0 then echo "xrdp is already loaded" exit 1 fi is_sesman_running if ! test $? -eq 0 then echo "sesman is already loaded" exit 1 fi xrdp_start ;; stop) check_up is_xrdp_running if test $? -eq 0 then echo "xrdp is not loaded." fi is_sesman_running if test $? -eq 0 then echo "sesman is not loaded." fi xrdp_stop ;; force-reload|restart) check_up echo "Restarting xrdp ..." xrdp_stop is_xrdp_running while ! test $? -eq 0 do check_up sleep 1 is_xrdp_running done xrdp_start ;; *) echo "Usage: xrdp.sh {start|stop|restart|force-reload}" exit 1 esac exit 0 xrdp-0.9.5/instfiles/init.d/000755 001751 001751 00000000000 13220731022 015577 5ustar00metameta000000 000000 xrdp-0.9.5/instfiles/init.d/xrdp000644 001751 001751 00000012061 13174271344 016515 0ustar00metameta000000 000000 #!/bin/sh -e # # start/stop xrdp and sesman daemons # ### BEGIN INIT INFO # Provides: xrdp # Required-Start: $network $remote_fs # Required-Stop: $network $remote_fs # Default-Start: 2 3 4 5 # Default-Stop: 0 1 6 # Short-Description: Start xrdp and sesman daemons # Description: XRDP uses the Remote Desktop Protocol to present a # graphical login to a remote client allowing connection # to a VNC server or another RDP server. ### END INIT INFO PATH=/usr/local/sbin:/usr/local/bin:/sbin:/bin:/usr/sbin:/usr/bin BASE=__BASE__ DAEMON=${BASE}/sbin/xrdp SDAEMON=${BASE}/sbin/xrdp-sesman PIDDIR=/var/run/ SESMAN_START=yes #USERID=xrdp # the X11rdp backend only works as root at the moment - GH 20/03/2013 USERID=root NAME=xrdp DESC="Remote Desktop Protocol server" test -x $DAEMON || exit 0 . /lib/lsb/init-functions check_root() { if [ "$(id -u)" != "0" ]; then log_failure_msg "You must be root to start, stop or restart $NAME." exit 4 fi } force_stop() { DELAY=1 PROCLIST="xrdp-sesman xrdp-sessvc xrdp-chansrv X11rdp Xvnc" for p in $PROCLIST; do pgrep -x $p >/dev/null && pkill -x $p sleep $DELAY pgrep -x $p >/dev/null && pkill -9 -x $p done # let's not kill ourselves - the init script is called xrdp as well pgrep -fx $DAEMON >/dev/null && pkill -fx $DAEMON sleep $DELAY pgrep -fx $DAEMON >/dev/null && pkill -9 -fx $DAEMON rm -f $PIDDIR/xrdp*.pid } if [ -r /etc/default/$NAME ]; then . /etc/default/$NAME fi # Tasks that can only be run as root if [ "$(id -u)" = "0" ]; then # Check for pid dir if [ ! -d $PIDDIR ] ; then mkdir $PIDDIR fi chown $USERID:$USERID $PIDDIR fi case "$1" in start) check_root exitval=0 log_daemon_msg "Starting $DESC " if pidofproc -p $PIDDIR/$NAME.pid $DAEMON > /dev/null; then log_progress_msg "$NAME apparently already running" log_end_msg 0 exit 0 fi log_progress_msg $NAME start-stop-daemon --start --quiet --oknodo --pidfile $PIDDIR/$NAME.pid \ --chuid $USERID:$USERID --exec $DAEMON >/dev/null exitval=$? if [ "$SESMAN_START" = "yes" ] ; then log_progress_msg "sesman" start-stop-daemon --start --quiet --oknodo --pidfile $PIDDIR/xrdp-sesman.pid \ --exec $SDAEMON >/dev/null value=$? [ $value -gt 0 ] && exitval=$value fi # Make pidfile readables for all users (for status to work) [ -e $PIDDIR/xrdp-sesman.pid ] && chmod 0644 $PIDDIR/xrdp-sesman.pid [ -e $PIDDIR/$NAME.pid ] && chmod 0644 $PIDDIR/$NAME.pid # Note: Unfortunately, xrdp currently takes too long to create # the pidffile unless properly patched log_end_msg $exitval ;; stop) check_root [ -n "$XRDP_UPGRADE" -a "$RESTART_ON_UPGRADE" = "no" ] && { echo "Upgrade in progress, no restart of xrdp." exit 0 } exitval=0 log_daemon_msg "Stopping RDP Session manager " log_progress_msg "sesman" if pidofproc -p $PIDDIR/xrdp-sesman.pid $SDAEMON > /dev/null; then start-stop-daemon --stop --quiet --oknodo --pidfile $PIDDIR/xrdp-sesman.pid \ --chuid $USERID:$USERID --exec $SDAEMON exitval=$? else log_progress_msg "apparently not running" fi log_progress_msg $NAME if pidofproc -p $PIDDIR/$NAME.pid $DAEMON > /dev/null; then start-stop-daemon --stop --quiet --oknodo --pidfile $PIDDIR/$NAME.pid \ --exec $DAEMON value=$? [ $value -gt 0 ] && exitval=$value else log_progress_msg "apparently not running" fi log_end_msg $exitval ;; force-stop) $0 stop # because it doesn't always die the right way force_stop ;; restart|force-reload) check_root $0 stop # Wait for things to settle down sleep 1 $0 start ;; reload) log_warning_msg "Reloading $NAME daemon: not implemented, as the daemon" log_warning_msg "cannot re-read the config file (use restart)." ;; status) exitval=0 log_daemon_msg "Checking status of $DESC" "$NAME" if pidofproc -p $PIDDIR/$NAME.pid $DAEMON > /dev/null; then log_progress_msg "running" log_end_msg 0 else log_progress_msg "apparently not running" log_end_msg 1 || true exitval=1 fi if [ "$SESMAN_START" = "yes" ] ; then log_daemon_msg "Checking status of RDP Session Manager" "sesman" if pidofproc -p $PIDDIR/xrdp-sesman.pid $SDAEMON > /dev/null; then log_progress_msg "running" log_end_msg 0 else log_progress_msg "apparently not running" log_end_msg 1 || true exitval=1 fi fi exit $exitval ;; *) N=/etc/init.d/$NAME echo "Usage: $N {start|stop|force-stop|restart|force-reload|status}" >&2 exit 1 ;; esac exit 0 xrdp-0.9.5/instfiles/init.d/Makefile.in000644 001751 001751 00000037544 13220730774 017676 0ustar00metameta000000 000000 # Makefile.in generated by automake 1.15.1 from Makefile.am. # @configure_input@ # Copyright (C) 1994-2017 Free Software Foundation, Inc. # This Makefile.in is free software; the Free Software Foundation # gives unlimited permission to copy and/or distribute it, # with or without modifications, as long as this notice is preserved. # This program is distributed in the hope that it will be useful, # but WITHOUT ANY WARRANTY, to the extent permitted by law; without # even the implied warranty of MERCHANTABILITY or FITNESS FOR A # PARTICULAR PURPOSE. @SET_MAKE@ VPATH = @srcdir@ am__is_gnu_make = { \ if test -z '$(MAKELEVEL)'; then \ false; \ elif test -n '$(MAKE_HOST)'; then \ true; \ elif test -n '$(MAKE_VERSION)' && test -n '$(CURDIR)'; then \ true; \ else \ false; \ fi; \ } am__make_running_with_option = \ case $${target_option-} in \ ?) ;; \ *) echo "am__make_running_with_option: internal error: invalid" \ "target option '$${target_option-}' specified" >&2; \ exit 1;; \ esac; \ has_opt=no; \ sane_makeflags=$$MAKEFLAGS; \ if $(am__is_gnu_make); then \ sane_makeflags=$$MFLAGS; \ else \ case $$MAKEFLAGS in \ *\\[\ \ ]*) \ bs=\\; \ sane_makeflags=`printf '%s\n' "$$MAKEFLAGS" \ | sed "s/$$bs$$bs[$$bs $$bs ]*//g"`;; \ esac; \ fi; \ skip_next=no; \ strip_trailopt () \ { \ flg=`printf '%s\n' "$$flg" | sed "s/$$1.*$$//"`; \ }; \ for flg in $$sane_makeflags; do \ test $$skip_next = yes && { skip_next=no; continue; }; \ case $$flg in \ *=*|--*) continue;; \ -*I) strip_trailopt 'I'; skip_next=yes;; \ -*I?*) strip_trailopt 'I';; \ -*O) strip_trailopt 'O'; skip_next=yes;; \ -*O?*) strip_trailopt 'O';; \ -*l) strip_trailopt 'l'; skip_next=yes;; \ -*l?*) strip_trailopt 'l';; \ -[dEDm]) skip_next=yes;; \ -[JT]) skip_next=yes;; \ esac; \ case $$flg in \ *$$target_option*) has_opt=yes; break;; \ esac; \ done; \ test $$has_opt = yes am__make_dryrun = (target_option=n; $(am__make_running_with_option)) am__make_keepgoing = (target_option=k; $(am__make_running_with_option)) pkgdatadir = $(datadir)/@PACKAGE@ pkgincludedir = $(includedir)/@PACKAGE@ pkglibdir = $(libdir)/@PACKAGE@ pkglibexecdir = $(libexecdir)/@PACKAGE@ am__cd = CDPATH="$${ZSH_VERSION+.}$(PATH_SEPARATOR)" && cd install_sh_DATA = $(install_sh) -c -m 644 install_sh_PROGRAM = $(install_sh) -c install_sh_SCRIPT = $(install_sh) -c INSTALL_HEADER = $(INSTALL_DATA) transform = $(program_transform_name) NORMAL_INSTALL = : PRE_INSTALL = : POST_INSTALL = : NORMAL_UNINSTALL = : PRE_UNINSTALL = : POST_UNINSTALL = : build_triplet = @build@ host_triplet = @host@ subdir = instfiles/init.d ACLOCAL_M4 = $(top_srcdir)/aclocal.m4 am__aclocal_m4_deps = $(top_srcdir)/m4/ax_append_compile_flags.m4 \ $(top_srcdir)/m4/ax_append_flag.m4 \ $(top_srcdir)/m4/ax_cflags_warn_all.m4 \ $(top_srcdir)/m4/ax_check_compile_flag.m4 \ $(top_srcdir)/m4/ax_gcc_func_attribute.m4 \ $(top_srcdir)/m4/ax_require_defined.m4 \ $(top_srcdir)/m4/ax_type_socklen_t.m4 \ $(top_srcdir)/m4/libtool.m4 $(top_srcdir)/m4/ltoptions.m4 \ $(top_srcdir)/m4/ltsugar.m4 $(top_srcdir)/m4/ltversion.m4 \ $(top_srcdir)/m4/lt~obsolete.m4 $(top_srcdir)/m4/pkg.m4 \ $(top_srcdir)/configure.ac am__configure_deps = $(am__aclocal_m4_deps) $(CONFIGURE_DEPENDENCIES) \ $(ACLOCAL_M4) DIST_COMMON = $(srcdir)/Makefile.am $(dist_startscript_SCRIPTS) \ $(am__DIST_COMMON) mkinstalldirs = $(install_sh) -d CONFIG_HEADER = $(top_builddir)/config_ac.h CONFIG_CLEAN_FILES = CONFIG_CLEAN_VPATH_FILES = am__vpath_adj_setup = srcdirstrip=`echo "$(srcdir)" | sed 's|.|.|g'`; am__vpath_adj = case $$p in \ $(srcdir)/*) f=`echo "$$p" | sed "s|^$$srcdirstrip/||"`;; \ *) f=$$p;; \ esac; am__strip_dir = f=`echo $$p | sed -e 's|^.*/||'`; am__install_max = 40 am__nobase_strip_setup = \ srcdirstrip=`echo "$(srcdir)" | sed 's/[].[^$$\\*|]/\\\\&/g'` am__nobase_strip = \ for p in $$list; do echo "$$p"; done | sed -e "s|$$srcdirstrip/||" am__nobase_list = $(am__nobase_strip_setup); \ for p in $$list; do echo "$$p $$p"; done | \ sed "s| $$srcdirstrip/| |;"' / .*\//!s/ .*/ ./; s,\( .*\)/[^/]*$$,\1,' | \ $(AWK) 'BEGIN { files["."] = "" } { files[$$2] = files[$$2] " " $$1; \ if (++n[$$2] == $(am__install_max)) \ { print $$2, files[$$2]; n[$$2] = 0; files[$$2] = "" } } \ END { for (dir in files) print dir, files[dir] }' am__base_list = \ sed '$$!N;$$!N;$$!N;$$!N;$$!N;$$!N;$$!N;s/\n/ /g' | \ sed '$$!N;$$!N;$$!N;$$!N;s/\n/ /g' am__uninstall_files_from_dir = { \ test -z "$$files" \ || { test ! -d "$$dir" && test ! -f "$$dir" && test ! -r "$$dir"; } \ || { echo " ( cd '$$dir' && rm -f" $$files ")"; \ $(am__cd) "$$dir" && rm -f $$files; }; \ } am__installdirs = "$(DESTDIR)$(startscriptdir)" SCRIPTS = $(dist_startscript_SCRIPTS) AM_V_P = $(am__v_P_@AM_V@) am__v_P_ = $(am__v_P_@AM_DEFAULT_V@) am__v_P_0 = false am__v_P_1 = : AM_V_GEN = $(am__v_GEN_@AM_V@) am__v_GEN_ = $(am__v_GEN_@AM_DEFAULT_V@) am__v_GEN_0 = @echo " GEN " $@; am__v_GEN_1 = AM_V_at = $(am__v_at_@AM_V@) am__v_at_ = $(am__v_at_@AM_DEFAULT_V@) am__v_at_0 = @ am__v_at_1 = SOURCES = DIST_SOURCES = am__can_run_installinfo = \ case $$AM_UPDATE_INFO_DIR in \ n|no|NO) false;; \ *) (install-info --version) >/dev/null 2>&1;; \ esac am__tagged_files = $(HEADERS) $(SOURCES) $(TAGS_FILES) $(LISP) am__DIST_COMMON = $(srcdir)/Makefile.in DISTFILES = $(DIST_COMMON) $(DIST_SOURCES) $(TEXINFOS) $(EXTRA_DIST) ACLOCAL = @ACLOCAL@ AMTAR = @AMTAR@ AM_DEFAULT_VERBOSITY = @AM_DEFAULT_VERBOSITY@ AR = @AR@ AUTOCONF = @AUTOCONF@ AUTOHEADER = @AUTOHEADER@ AUTOMAKE = @AUTOMAKE@ AWK = @AWK@ CC = @CC@ CCDEPMODE = @CCDEPMODE@ CFLAGS = @CFLAGS@ CPP = @CPP@ CPPFLAGS = @CPPFLAGS@ CYGPATH_W = @CYGPATH_W@ DEFS = @DEFS@ DEPDIR = @DEPDIR@ DLLTOOL = @DLLTOOL@ DLOPEN_LIBS = @DLOPEN_LIBS@ DSYMUTIL = @DSYMUTIL@ DUMPBIN = @DUMPBIN@ ECHO_C = @ECHO_C@ ECHO_N = @ECHO_N@ ECHO_T = @ECHO_T@ EGREP = @EGREP@ EXEEXT = @EXEEXT@ FDKAAC_CFLAGS = @FDKAAC_CFLAGS@ FDKAAC_LIBS = @FDKAAC_LIBS@ FGREP = @FGREP@ FREERDP_CFLAGS = @FREERDP_CFLAGS@ FREERDP_LIBS = @FREERDP_LIBS@ FUSE_CFLAGS = @FUSE_CFLAGS@ FUSE_LIBS = @FUSE_LIBS@ GREP = @GREP@ INSTALL = @INSTALL@ INSTALL_DATA = @INSTALL_DATA@ INSTALL_PROGRAM = @INSTALL_PROGRAM@ INSTALL_SCRIPT = @INSTALL_SCRIPT@ INSTALL_STRIP_PROGRAM = @INSTALL_STRIP_PROGRAM@ LD = @LD@ LDFLAGS = @LDFLAGS@ LIBOBJS = @LIBOBJS@ LIBS = @LIBS@ LIBTOOL = @LIBTOOL@ LIPO = @LIPO@ LN_S = @LN_S@ LTLIBOBJS = @LTLIBOBJS@ LT_SYS_LIBRARY_PATH = @LT_SYS_LIBRARY_PATH@ MAKEINFO = @MAKEINFO@ MANIFEST_TOOL = @MANIFEST_TOOL@ MKDIR_P = @MKDIR_P@ NM = @NM@ NMEDIT = @NMEDIT@ OBJDUMP = @OBJDUMP@ OBJEXT = @OBJEXT@ OPENSSL = @OPENSSL@ OPENSSL_CFLAGS = @OPENSSL_CFLAGS@ OPENSSL_LIBS = @OPENSSL_LIBS@ OTOOL = @OTOOL@ OTOOL64 = @OTOOL64@ PACKAGE = @PACKAGE@ PACKAGE_BUGREPORT = @PACKAGE_BUGREPORT@ PACKAGE_NAME = @PACKAGE_NAME@ PACKAGE_STRING = @PACKAGE_STRING@ PACKAGE_TARNAME = @PACKAGE_TARNAME@ PACKAGE_URL = @PACKAGE_URL@ PACKAGE_VERSION = @PACKAGE_VERSION@ PAM_RULES = @PAM_RULES@ PATH_SEPARATOR = @PATH_SEPARATOR@ PIXMAN_CFLAGS = @PIXMAN_CFLAGS@ PIXMAN_LIBS = @PIXMAN_LIBS@ PKG_CONFIG = @PKG_CONFIG@ PKG_CONFIG_LIBDIR = @PKG_CONFIG_LIBDIR@ PKG_CONFIG_PATH = @PKG_CONFIG_PATH@ RANLIB = @RANLIB@ SED = @SED@ SET_MAKE = @SET_MAKE@ SHELL = @SHELL@ STRIP = @STRIP@ TurboJpegIncDir = @TurboJpegIncDir@ TurboJpegLibDir = @TurboJpegLibDir@ VERSION = @VERSION@ XMKMF = @XMKMF@ X_CFLAGS = @X_CFLAGS@ X_EXTRA_LIBS = @X_EXTRA_LIBS@ X_LIBS = @X_LIBS@ X_PRE_LIBS = @X_PRE_LIBS@ abs_builddir = @abs_builddir@ abs_srcdir = @abs_srcdir@ abs_top_builddir = @abs_top_builddir@ abs_top_srcdir = @abs_top_srcdir@ ac_ct_AR = @ac_ct_AR@ ac_ct_CC = @ac_ct_CC@ ac_ct_DUMPBIN = @ac_ct_DUMPBIN@ am__include = @am__include@ am__leading_dot = @am__leading_dot@ am__quote = @am__quote@ am__tar = @am__tar@ am__untar = @am__untar@ bindir = @bindir@ build = @build@ build_alias = @build_alias@ build_cpu = @build_cpu@ build_os = @build_os@ build_vendor = @build_vendor@ builddir = @builddir@ datadir = @datadir@ datarootdir = @datarootdir@ docdir = @docdir@ dvidir = @dvidir@ exec_prefix = @exec_prefix@ host = @host@ host_alias = @host_alias@ host_cpu = @host_cpu@ host_os = @host_os@ host_vendor = @host_vendor@ htmldir = @htmldir@ includedir = @includedir@ infodir = @infodir@ install_sh = @install_sh@ libdir = @libdir@ libexecdir = @libexecdir@ localedir = @localedir@ localstatedir = @localstatedir@ mandir = @mandir@ mkdir_p = @mkdir_p@ moduledir = @moduledir@ oldincludedir = @oldincludedir@ pdfdir = @pdfdir@ pkgconfigdir = @pkgconfigdir@ prefix = @prefix@ program_transform_name = @program_transform_name@ psdir = @psdir@ sbindir = @sbindir@ sharedstatedir = @sharedstatedir@ socketdir = @socketdir@ srcdir = @srcdir@ subdirs = @subdirs@ sysconfdir = @sysconfdir@ systemdsystemunitdir = @systemdsystemunitdir@ target_alias = @target_alias@ top_build_prefix = @top_build_prefix@ top_builddir = @top_builddir@ top_srcdir = @top_srcdir@ startscriptdir = $(sysconfdir)/init.d dist_startscript_SCRIPTS = xrdp all: all-am .SUFFIXES: $(srcdir)/Makefile.in: $(srcdir)/Makefile.am $(am__configure_deps) @for dep in $?; do \ case '$(am__configure_deps)' in \ *$$dep*) \ ( cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh ) \ && { if test -f $@; then exit 0; else break; fi; }; \ exit 1;; \ esac; \ done; \ echo ' cd $(top_srcdir) && $(AUTOMAKE) --foreign instfiles/init.d/Makefile'; \ $(am__cd) $(top_srcdir) && \ $(AUTOMAKE) --foreign instfiles/init.d/Makefile Makefile: $(srcdir)/Makefile.in $(top_builddir)/config.status @case '$?' in \ *config.status*) \ cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh;; \ *) \ echo ' cd $(top_builddir) && $(SHELL) ./config.status $(subdir)/$@ $(am__depfiles_maybe)'; \ cd $(top_builddir) && $(SHELL) ./config.status $(subdir)/$@ $(am__depfiles_maybe);; \ esac; $(top_builddir)/config.status: $(top_srcdir)/configure $(CONFIG_STATUS_DEPENDENCIES) cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh $(top_srcdir)/configure: $(am__configure_deps) cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh $(ACLOCAL_M4): $(am__aclocal_m4_deps) cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh $(am__aclocal_m4_deps): install-dist_startscriptSCRIPTS: $(dist_startscript_SCRIPTS) @$(NORMAL_INSTALL) @list='$(dist_startscript_SCRIPTS)'; test -n "$(startscriptdir)" || list=; \ if test -n "$$list"; then \ echo " $(MKDIR_P) '$(DESTDIR)$(startscriptdir)'"; \ $(MKDIR_P) "$(DESTDIR)$(startscriptdir)" || exit 1; \ fi; \ for p in $$list; do \ if test -f "$$p"; then d=; else d="$(srcdir)/"; fi; \ if test -f "$$d$$p"; then echo "$$d$$p"; echo "$$p"; else :; fi; \ done | \ sed -e 'p;s,.*/,,;n' \ -e 'h;s|.*|.|' \ -e 'p;x;s,.*/,,;$(transform)' | sed 'N;N;N;s,\n, ,g' | \ $(AWK) 'BEGIN { files["."] = ""; dirs["."] = 1; } \ { d=$$3; if (dirs[d] != 1) { print "d", d; dirs[d] = 1 } \ if ($$2 == $$4) { files[d] = files[d] " " $$1; \ if (++n[d] == $(am__install_max)) { \ print "f", d, files[d]; n[d] = 0; files[d] = "" } } \ else { print "f", d "/" $$4, $$1 } } \ END { for (d in files) print "f", d, files[d] }' | \ while read type dir files; do \ if test "$$dir" = .; then dir=; else dir=/$$dir; fi; \ test -z "$$files" || { \ echo " $(INSTALL_SCRIPT) $$files '$(DESTDIR)$(startscriptdir)$$dir'"; \ $(INSTALL_SCRIPT) $$files "$(DESTDIR)$(startscriptdir)$$dir" || exit $$?; \ } \ ; done uninstall-dist_startscriptSCRIPTS: @$(NORMAL_UNINSTALL) @list='$(dist_startscript_SCRIPTS)'; test -n "$(startscriptdir)" || exit 0; \ files=`for p in $$list; do echo "$$p"; done | \ sed -e 's,.*/,,;$(transform)'`; \ dir='$(DESTDIR)$(startscriptdir)'; $(am__uninstall_files_from_dir) mostlyclean-libtool: -rm -f *.lo clean-libtool: -rm -rf .libs _libs tags TAGS: ctags CTAGS: cscope cscopelist: distdir: $(DISTFILES) @srcdirstrip=`echo "$(srcdir)" | sed 's/[].[^$$\\*]/\\\\&/g'`; \ topsrcdirstrip=`echo "$(top_srcdir)" | sed 's/[].[^$$\\*]/\\\\&/g'`; \ list='$(DISTFILES)'; \ dist_files=`for file in $$list; do echo $$file; done | \ sed -e "s|^$$srcdirstrip/||;t" \ -e "s|^$$topsrcdirstrip/|$(top_builddir)/|;t"`; \ case $$dist_files in \ */*) $(MKDIR_P) `echo "$$dist_files" | \ sed '/\//!d;s|^|$(distdir)/|;s,/[^/]*$$,,' | \ sort -u` ;; \ esac; \ for file in $$dist_files; do \ if test -f $$file || test -d $$file; then d=.; else d=$(srcdir); fi; \ if test -d $$d/$$file; then \ dir=`echo "/$$file" | sed -e 's,/[^/]*$$,,'`; \ if test -d "$(distdir)/$$file"; then \ find "$(distdir)/$$file" -type d ! -perm -700 -exec chmod u+rwx {} \;; \ fi; \ if test -d $(srcdir)/$$file && test $$d != $(srcdir); then \ cp -fpR $(srcdir)/$$file "$(distdir)$$dir" || exit 1; \ find "$(distdir)/$$file" -type d ! -perm -700 -exec chmod u+rwx {} \;; \ fi; \ cp -fpR $$d/$$file "$(distdir)$$dir" || exit 1; \ else \ test -f "$(distdir)/$$file" \ || cp -p $$d/$$file "$(distdir)/$$file" \ || exit 1; \ fi; \ done check-am: all-am check: check-am all-am: Makefile $(SCRIPTS) installdirs: for dir in "$(DESTDIR)$(startscriptdir)"; do \ test -z "$$dir" || $(MKDIR_P) "$$dir"; \ done install: install-am install-exec: install-exec-am install-data: install-data-am uninstall: uninstall-am install-am: all-am @$(MAKE) $(AM_MAKEFLAGS) install-exec-am install-data-am installcheck: installcheck-am install-strip: if test -z '$(STRIP)'; then \ $(MAKE) $(AM_MAKEFLAGS) INSTALL_PROGRAM="$(INSTALL_STRIP_PROGRAM)" \ install_sh_PROGRAM="$(INSTALL_STRIP_PROGRAM)" INSTALL_STRIP_FLAG=-s \ install; \ else \ $(MAKE) $(AM_MAKEFLAGS) INSTALL_PROGRAM="$(INSTALL_STRIP_PROGRAM)" \ install_sh_PROGRAM="$(INSTALL_STRIP_PROGRAM)" INSTALL_STRIP_FLAG=-s \ "INSTALL_PROGRAM_ENV=STRIPPROG='$(STRIP)'" install; \ fi mostlyclean-generic: clean-generic: distclean-generic: -test -z "$(CONFIG_CLEAN_FILES)" || rm -f $(CONFIG_CLEAN_FILES) -test . = "$(srcdir)" || test -z "$(CONFIG_CLEAN_VPATH_FILES)" || rm -f $(CONFIG_CLEAN_VPATH_FILES) maintainer-clean-generic: @echo "This command is intended for maintainers to use" @echo "it deletes files that may require special tools to rebuild." clean: clean-am clean-am: clean-generic clean-libtool mostlyclean-am distclean: distclean-am -rm -f Makefile distclean-am: clean-am distclean-generic dvi: dvi-am dvi-am: html: html-am html-am: info: info-am info-am: install-data-am: install-dist_startscriptSCRIPTS install-dvi: install-dvi-am install-dvi-am: install-exec-am: install-html: install-html-am install-html-am: install-info: install-info-am install-info-am: install-man: install-pdf: install-pdf-am install-pdf-am: install-ps: install-ps-am install-ps-am: installcheck-am: maintainer-clean: maintainer-clean-am -rm -f Makefile maintainer-clean-am: distclean-am maintainer-clean-generic mostlyclean: mostlyclean-am mostlyclean-am: mostlyclean-generic mostlyclean-libtool pdf: pdf-am pdf-am: ps: ps-am ps-am: uninstall-am: uninstall-dist_startscriptSCRIPTS .MAKE: install-am install-strip .PHONY: all all-am check check-am clean clean-generic clean-libtool \ cscopelist-am ctags-am distclean distclean-generic \ distclean-libtool distdir dvi dvi-am html html-am info info-am \ install install-am install-data install-data-am \ install-dist_startscriptSCRIPTS install-dvi install-dvi-am \ install-exec install-exec-am install-html install-html-am \ install-info install-info-am install-man install-pdf \ install-pdf-am install-ps install-ps-am install-strip \ installcheck installcheck-am installdirs maintainer-clean \ maintainer-clean-generic mostlyclean mostlyclean-generic \ mostlyclean-libtool pdf pdf-am ps ps-am tags-am uninstall \ uninstall-am uninstall-dist_startscriptSCRIPTS .PRECIOUS: Makefile # Tell versions [3.59,3.63) of GNU make to not export all variables. # Otherwise a system limit (for SysV at least) may be exceeded. .NOEXPORT: xrdp-0.9.5/instfiles/init.d/Makefile.am000644 001751 001751 00000000106 13127114621 017636 0ustar00metameta000000 000000 startscriptdir = $(sysconfdir)/init.d dist_startscript_SCRIPTS = xrdp xrdp-0.9.5/instfiles/pam.d/xrdp-sesman.debian000644 001751 001751 00000000150 13203173200 021011 0ustar00metameta000000 000000 #%PAM-1.0 @include common-auth @include common-account @include common-session @include common-password xrdp-0.9.5/instfiles/pam.d/xrdp-sesman.freebsd000644 001751 001751 00000000206 13206666623 021226 0ustar00metameta000000 000000 #%PAM-1.0 auth include system account include system password include system session include system xrdp-0.9.5/instfiles/pam.d/mkpamrules000755 001751 001751 00000001334 13206666623 017542 0ustar00metameta000000 000000 #!/bin/sh # Find suitable PAM config file rules="$1" srcdir="$2" outfile="$3" service="xrdp-sesman" pamdir="/etc/pam.d" guess_rules () { if test -s "$pamdir/password-auth"; then rules="redhat" return fi if test -s "$pamdir/common-account"; then if grep "^@include" "$pamdir/passwd" >/dev/null 2>&1; then rules="debian" else rules="suse" fi return fi if test ! -f "$pamdir/system-auth" -a -s "$pamdir/system"; then rules="freebsd" return fi rules="unix" return } if test "$rules" = "auto"; then guess_rules fi if test -s "$srcdir/$service.$rules"; then ln -nsf "$srcdir/$service.$rules" "$outfile" else echo "Cannot find $srcdir/$service.$rules" exit 1 fi xrdp-0.9.5/instfiles/pam.d/Makefile.am000644 001751 001751 00000000717 13206666623 017474 0ustar00metameta000000 000000 PAM_FILES = \ xrdp-sesman.debian \ xrdp-sesman.redhat \ xrdp-sesman.suse \ xrdp-sesman.freebsd \ xrdp-sesman.unix EXTRA_DIST = $(PAM_FILES) mkpamrules CLEANFILES = xrdp-sesman if SESMAN_NOPAM PAMFILE = else if SESMAN_PAMUSERPASS PAMFILE = else if SESMAN_KERBEROS PAMFILE = else PAMFILE = xrdp-sesman endif endif endif pamddir = $(sysconfdir)/pam.d pamd_DATA = \ $(PAMFILE) xrdp-sesman: mkpamrules $(srcdir)/mkpamrules $(PAM_RULES) $(srcdir) $@ xrdp-0.9.5/instfiles/pam.d/xrdp-sesman.redhat000644 001751 001751 00000000242 13203173200 021040 0ustar00metameta000000 000000 #%PAM-1.0 auth include password-auth account include password-auth session include password-auth password include password-auth xrdp-0.9.5/instfiles/pam.d/xrdp-sesman.unix000644 001751 001751 00000000232 13133557325 020573 0ustar00metameta000000 000000 #%PAM-1.0 auth include system-auth account include system-auth password include system-auth session include system-auth xrdp-0.9.5/instfiles/pam.d/xrdp-sesman.suse000644 001751 001751 00000000244 13203173200 020552 0ustar00metameta000000 000000 #%PAM-1.0 auth include common-auth account include common-account session include common-session password include common-password xrdp-0.9.5/instfiles/pam.d/Makefile.in000644 001751 001751 00000036756 13220730774 017514 0ustar00metameta000000 000000 # Makefile.in generated by automake 1.15.1 from Makefile.am. # @configure_input@ # Copyright (C) 1994-2017 Free Software Foundation, Inc. # This Makefile.in is free software; the Free Software Foundation # gives unlimited permission to copy and/or distribute it, # with or without modifications, as long as this notice is preserved. # This program is distributed in the hope that it will be useful, # but WITHOUT ANY WARRANTY, to the extent permitted by law; without # even the implied warranty of MERCHANTABILITY or FITNESS FOR A # PARTICULAR PURPOSE. @SET_MAKE@ VPATH = @srcdir@ am__is_gnu_make = { \ if test -z '$(MAKELEVEL)'; then \ false; \ elif test -n '$(MAKE_HOST)'; then \ true; \ elif test -n '$(MAKE_VERSION)' && test -n '$(CURDIR)'; then \ true; \ else \ false; \ fi; \ } am__make_running_with_option = \ case $${target_option-} in \ ?) ;; \ *) echo "am__make_running_with_option: internal error: invalid" \ "target option '$${target_option-}' specified" >&2; \ exit 1;; \ esac; \ has_opt=no; \ sane_makeflags=$$MAKEFLAGS; \ if $(am__is_gnu_make); then \ sane_makeflags=$$MFLAGS; \ else \ case $$MAKEFLAGS in \ *\\[\ \ ]*) \ bs=\\; \ sane_makeflags=`printf '%s\n' "$$MAKEFLAGS" \ | sed "s/$$bs$$bs[$$bs $$bs ]*//g"`;; \ esac; \ fi; \ skip_next=no; \ strip_trailopt () \ { \ flg=`printf '%s\n' "$$flg" | sed "s/$$1.*$$//"`; \ }; \ for flg in $$sane_makeflags; do \ test $$skip_next = yes && { skip_next=no; continue; }; \ case $$flg in \ *=*|--*) continue;; \ -*I) strip_trailopt 'I'; skip_next=yes;; \ -*I?*) strip_trailopt 'I';; \ -*O) strip_trailopt 'O'; skip_next=yes;; \ -*O?*) strip_trailopt 'O';; \ -*l) strip_trailopt 'l'; skip_next=yes;; \ -*l?*) strip_trailopt 'l';; \ -[dEDm]) skip_next=yes;; \ -[JT]) skip_next=yes;; \ esac; \ case $$flg in \ *$$target_option*) has_opt=yes; break;; \ esac; \ done; \ test $$has_opt = yes am__make_dryrun = (target_option=n; $(am__make_running_with_option)) am__make_keepgoing = (target_option=k; $(am__make_running_with_option)) pkgdatadir = $(datadir)/@PACKAGE@ pkgincludedir = $(includedir)/@PACKAGE@ pkglibdir = $(libdir)/@PACKAGE@ pkglibexecdir = $(libexecdir)/@PACKAGE@ am__cd = CDPATH="$${ZSH_VERSION+.}$(PATH_SEPARATOR)" && cd install_sh_DATA = $(install_sh) -c -m 644 install_sh_PROGRAM = $(install_sh) -c install_sh_SCRIPT = $(install_sh) -c INSTALL_HEADER = $(INSTALL_DATA) transform = $(program_transform_name) NORMAL_INSTALL = : PRE_INSTALL = : POST_INSTALL = : NORMAL_UNINSTALL = : PRE_UNINSTALL = : POST_UNINSTALL = : build_triplet = @build@ host_triplet = @host@ subdir = instfiles/pam.d ACLOCAL_M4 = $(top_srcdir)/aclocal.m4 am__aclocal_m4_deps = $(top_srcdir)/m4/ax_append_compile_flags.m4 \ $(top_srcdir)/m4/ax_append_flag.m4 \ $(top_srcdir)/m4/ax_cflags_warn_all.m4 \ $(top_srcdir)/m4/ax_check_compile_flag.m4 \ $(top_srcdir)/m4/ax_gcc_func_attribute.m4 \ $(top_srcdir)/m4/ax_require_defined.m4 \ $(top_srcdir)/m4/ax_type_socklen_t.m4 \ $(top_srcdir)/m4/libtool.m4 $(top_srcdir)/m4/ltoptions.m4 \ $(top_srcdir)/m4/ltsugar.m4 $(top_srcdir)/m4/ltversion.m4 \ $(top_srcdir)/m4/lt~obsolete.m4 $(top_srcdir)/m4/pkg.m4 \ $(top_srcdir)/configure.ac am__configure_deps = $(am__aclocal_m4_deps) $(CONFIGURE_DEPENDENCIES) \ $(ACLOCAL_M4) DIST_COMMON = $(srcdir)/Makefile.am $(am__DIST_COMMON) mkinstalldirs = $(install_sh) -d CONFIG_HEADER = $(top_builddir)/config_ac.h CONFIG_CLEAN_FILES = CONFIG_CLEAN_VPATH_FILES = AM_V_P = $(am__v_P_@AM_V@) am__v_P_ = $(am__v_P_@AM_DEFAULT_V@) am__v_P_0 = false am__v_P_1 = : AM_V_GEN = $(am__v_GEN_@AM_V@) am__v_GEN_ = $(am__v_GEN_@AM_DEFAULT_V@) am__v_GEN_0 = @echo " GEN " $@; am__v_GEN_1 = AM_V_at = $(am__v_at_@AM_V@) am__v_at_ = $(am__v_at_@AM_DEFAULT_V@) am__v_at_0 = @ am__v_at_1 = SOURCES = DIST_SOURCES = am__can_run_installinfo = \ case $$AM_UPDATE_INFO_DIR in \ n|no|NO) false;; \ *) (install-info --version) >/dev/null 2>&1;; \ esac am__vpath_adj_setup = srcdirstrip=`echo "$(srcdir)" | sed 's|.|.|g'`; am__vpath_adj = case $$p in \ $(srcdir)/*) f=`echo "$$p" | sed "s|^$$srcdirstrip/||"`;; \ *) f=$$p;; \ esac; am__strip_dir = f=`echo $$p | sed -e 's|^.*/||'`; am__install_max = 40 am__nobase_strip_setup = \ srcdirstrip=`echo "$(srcdir)" | sed 's/[].[^$$\\*|]/\\\\&/g'` am__nobase_strip = \ for p in $$list; do echo "$$p"; done | sed -e "s|$$srcdirstrip/||" am__nobase_list = $(am__nobase_strip_setup); \ for p in $$list; do echo "$$p $$p"; done | \ sed "s| $$srcdirstrip/| |;"' / .*\//!s/ .*/ ./; s,\( .*\)/[^/]*$$,\1,' | \ $(AWK) 'BEGIN { files["."] = "" } { files[$$2] = files[$$2] " " $$1; \ if (++n[$$2] == $(am__install_max)) \ { print $$2, files[$$2]; n[$$2] = 0; files[$$2] = "" } } \ END { for (dir in files) print dir, files[dir] }' am__base_list = \ sed '$$!N;$$!N;$$!N;$$!N;$$!N;$$!N;$$!N;s/\n/ /g' | \ sed '$$!N;$$!N;$$!N;$$!N;s/\n/ /g' am__uninstall_files_from_dir = { \ test -z "$$files" \ || { test ! -d "$$dir" && test ! -f "$$dir" && test ! -r "$$dir"; } \ || { echo " ( cd '$$dir' && rm -f" $$files ")"; \ $(am__cd) "$$dir" && rm -f $$files; }; \ } am__installdirs = "$(DESTDIR)$(pamddir)" DATA = $(pamd_DATA) am__tagged_files = $(HEADERS) $(SOURCES) $(TAGS_FILES) $(LISP) am__DIST_COMMON = $(srcdir)/Makefile.in DISTFILES = $(DIST_COMMON) $(DIST_SOURCES) $(TEXINFOS) $(EXTRA_DIST) ACLOCAL = @ACLOCAL@ AMTAR = @AMTAR@ AM_DEFAULT_VERBOSITY = @AM_DEFAULT_VERBOSITY@ AR = @AR@ AUTOCONF = @AUTOCONF@ AUTOHEADER = @AUTOHEADER@ AUTOMAKE = @AUTOMAKE@ AWK = @AWK@ CC = @CC@ CCDEPMODE = @CCDEPMODE@ CFLAGS = @CFLAGS@ CPP = @CPP@ CPPFLAGS = @CPPFLAGS@ CYGPATH_W = @CYGPATH_W@ DEFS = @DEFS@ DEPDIR = @DEPDIR@ DLLTOOL = @DLLTOOL@ DLOPEN_LIBS = @DLOPEN_LIBS@ DSYMUTIL = @DSYMUTIL@ DUMPBIN = @DUMPBIN@ ECHO_C = @ECHO_C@ ECHO_N = @ECHO_N@ ECHO_T = @ECHO_T@ EGREP = @EGREP@ EXEEXT = @EXEEXT@ FDKAAC_CFLAGS = @FDKAAC_CFLAGS@ FDKAAC_LIBS = @FDKAAC_LIBS@ FGREP = @FGREP@ FREERDP_CFLAGS = @FREERDP_CFLAGS@ FREERDP_LIBS = @FREERDP_LIBS@ FUSE_CFLAGS = @FUSE_CFLAGS@ FUSE_LIBS = @FUSE_LIBS@ GREP = @GREP@ INSTALL = @INSTALL@ INSTALL_DATA = @INSTALL_DATA@ INSTALL_PROGRAM = @INSTALL_PROGRAM@ INSTALL_SCRIPT = @INSTALL_SCRIPT@ INSTALL_STRIP_PROGRAM = @INSTALL_STRIP_PROGRAM@ LD = @LD@ LDFLAGS = @LDFLAGS@ LIBOBJS = @LIBOBJS@ LIBS = @LIBS@ LIBTOOL = @LIBTOOL@ LIPO = @LIPO@ LN_S = @LN_S@ LTLIBOBJS = @LTLIBOBJS@ LT_SYS_LIBRARY_PATH = @LT_SYS_LIBRARY_PATH@ MAKEINFO = @MAKEINFO@ MANIFEST_TOOL = @MANIFEST_TOOL@ MKDIR_P = @MKDIR_P@ NM = @NM@ NMEDIT = @NMEDIT@ OBJDUMP = @OBJDUMP@ OBJEXT = @OBJEXT@ OPENSSL = @OPENSSL@ OPENSSL_CFLAGS = @OPENSSL_CFLAGS@ OPENSSL_LIBS = @OPENSSL_LIBS@ OTOOL = @OTOOL@ OTOOL64 = @OTOOL64@ PACKAGE = @PACKAGE@ PACKAGE_BUGREPORT = @PACKAGE_BUGREPORT@ PACKAGE_NAME = @PACKAGE_NAME@ PACKAGE_STRING = @PACKAGE_STRING@ PACKAGE_TARNAME = @PACKAGE_TARNAME@ PACKAGE_URL = @PACKAGE_URL@ PACKAGE_VERSION = @PACKAGE_VERSION@ PAM_RULES = @PAM_RULES@ PATH_SEPARATOR = @PATH_SEPARATOR@ PIXMAN_CFLAGS = @PIXMAN_CFLAGS@ PIXMAN_LIBS = @PIXMAN_LIBS@ PKG_CONFIG = @PKG_CONFIG@ PKG_CONFIG_LIBDIR = @PKG_CONFIG_LIBDIR@ PKG_CONFIG_PATH = @PKG_CONFIG_PATH@ RANLIB = @RANLIB@ SED = @SED@ SET_MAKE = @SET_MAKE@ SHELL = @SHELL@ STRIP = @STRIP@ TurboJpegIncDir = @TurboJpegIncDir@ TurboJpegLibDir = @TurboJpegLibDir@ VERSION = @VERSION@ XMKMF = @XMKMF@ X_CFLAGS = @X_CFLAGS@ X_EXTRA_LIBS = @X_EXTRA_LIBS@ X_LIBS = @X_LIBS@ X_PRE_LIBS = @X_PRE_LIBS@ abs_builddir = @abs_builddir@ abs_srcdir = @abs_srcdir@ abs_top_builddir = @abs_top_builddir@ abs_top_srcdir = @abs_top_srcdir@ ac_ct_AR = @ac_ct_AR@ ac_ct_CC = @ac_ct_CC@ ac_ct_DUMPBIN = @ac_ct_DUMPBIN@ am__include = @am__include@ am__leading_dot = @am__leading_dot@ am__quote = @am__quote@ am__tar = @am__tar@ am__untar = @am__untar@ bindir = @bindir@ build = @build@ build_alias = @build_alias@ build_cpu = @build_cpu@ build_os = @build_os@ build_vendor = @build_vendor@ builddir = @builddir@ datadir = @datadir@ datarootdir = @datarootdir@ docdir = @docdir@ dvidir = @dvidir@ exec_prefix = @exec_prefix@ host = @host@ host_alias = @host_alias@ host_cpu = @host_cpu@ host_os = @host_os@ host_vendor = @host_vendor@ htmldir = @htmldir@ includedir = @includedir@ infodir = @infodir@ install_sh = @install_sh@ libdir = @libdir@ libexecdir = @libexecdir@ localedir = @localedir@ localstatedir = @localstatedir@ mandir = @mandir@ mkdir_p = @mkdir_p@ moduledir = @moduledir@ oldincludedir = @oldincludedir@ pdfdir = @pdfdir@ pkgconfigdir = @pkgconfigdir@ prefix = @prefix@ program_transform_name = @program_transform_name@ psdir = @psdir@ sbindir = @sbindir@ sharedstatedir = @sharedstatedir@ socketdir = @socketdir@ srcdir = @srcdir@ subdirs = @subdirs@ sysconfdir = @sysconfdir@ systemdsystemunitdir = @systemdsystemunitdir@ target_alias = @target_alias@ top_build_prefix = @top_build_prefix@ top_builddir = @top_builddir@ top_srcdir = @top_srcdir@ PAM_FILES = \ xrdp-sesman.debian \ xrdp-sesman.redhat \ xrdp-sesman.suse \ xrdp-sesman.freebsd \ xrdp-sesman.unix EXTRA_DIST = $(PAM_FILES) mkpamrules CLEANFILES = xrdp-sesman @SESMAN_KERBEROS_FALSE@@SESMAN_NOPAM_FALSE@@SESMAN_PAMUSERPASS_FALSE@PAMFILE = xrdp-sesman @SESMAN_KERBEROS_TRUE@@SESMAN_NOPAM_FALSE@@SESMAN_PAMUSERPASS_FALSE@PAMFILE = @SESMAN_NOPAM_FALSE@@SESMAN_PAMUSERPASS_TRUE@PAMFILE = @SESMAN_NOPAM_TRUE@PAMFILE = pamddir = $(sysconfdir)/pam.d pamd_DATA = \ $(PAMFILE) all: all-am .SUFFIXES: $(srcdir)/Makefile.in: $(srcdir)/Makefile.am $(am__configure_deps) @for dep in $?; do \ case '$(am__configure_deps)' in \ *$$dep*) \ ( cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh ) \ && { if test -f $@; then exit 0; else break; fi; }; \ exit 1;; \ esac; \ done; \ echo ' cd $(top_srcdir) && $(AUTOMAKE) --foreign instfiles/pam.d/Makefile'; \ $(am__cd) $(top_srcdir) && \ $(AUTOMAKE) --foreign instfiles/pam.d/Makefile Makefile: $(srcdir)/Makefile.in $(top_builddir)/config.status @case '$?' in \ *config.status*) \ cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh;; \ *) \ echo ' cd $(top_builddir) && $(SHELL) ./config.status $(subdir)/$@ $(am__depfiles_maybe)'; \ cd $(top_builddir) && $(SHELL) ./config.status $(subdir)/$@ $(am__depfiles_maybe);; \ esac; $(top_builddir)/config.status: $(top_srcdir)/configure $(CONFIG_STATUS_DEPENDENCIES) cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh $(top_srcdir)/configure: $(am__configure_deps) cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh $(ACLOCAL_M4): $(am__aclocal_m4_deps) cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh $(am__aclocal_m4_deps): mostlyclean-libtool: -rm -f *.lo clean-libtool: -rm -rf .libs _libs install-pamdDATA: $(pamd_DATA) @$(NORMAL_INSTALL) @list='$(pamd_DATA)'; test -n "$(pamddir)" || list=; \ if test -n "$$list"; then \ echo " $(MKDIR_P) '$(DESTDIR)$(pamddir)'"; \ $(MKDIR_P) "$(DESTDIR)$(pamddir)" || exit 1; \ fi; \ for p in $$list; do \ if test -f "$$p"; then d=; else d="$(srcdir)/"; fi; \ echo "$$d$$p"; \ done | $(am__base_list) | \ while read files; do \ echo " $(INSTALL_DATA) $$files '$(DESTDIR)$(pamddir)'"; \ $(INSTALL_DATA) $$files "$(DESTDIR)$(pamddir)" || exit $$?; \ done uninstall-pamdDATA: @$(NORMAL_UNINSTALL) @list='$(pamd_DATA)'; test -n "$(pamddir)" || list=; \ files=`for p in $$list; do echo $$p; done | sed -e 's|^.*/||'`; \ dir='$(DESTDIR)$(pamddir)'; $(am__uninstall_files_from_dir) tags TAGS: ctags CTAGS: cscope cscopelist: distdir: $(DISTFILES) @srcdirstrip=`echo "$(srcdir)" | sed 's/[].[^$$\\*]/\\\\&/g'`; \ topsrcdirstrip=`echo "$(top_srcdir)" | sed 's/[].[^$$\\*]/\\\\&/g'`; \ list='$(DISTFILES)'; \ dist_files=`for file in $$list; do echo $$file; done | \ sed -e "s|^$$srcdirstrip/||;t" \ -e "s|^$$topsrcdirstrip/|$(top_builddir)/|;t"`; \ case $$dist_files in \ */*) $(MKDIR_P) `echo "$$dist_files" | \ sed '/\//!d;s|^|$(distdir)/|;s,/[^/]*$$,,' | \ sort -u` ;; \ esac; \ for file in $$dist_files; do \ if test -f $$file || test -d $$file; then d=.; else d=$(srcdir); fi; \ if test -d $$d/$$file; then \ dir=`echo "/$$file" | sed -e 's,/[^/]*$$,,'`; \ if test -d "$(distdir)/$$file"; then \ find "$(distdir)/$$file" -type d ! -perm -700 -exec chmod u+rwx {} \;; \ fi; \ if test -d $(srcdir)/$$file && test $$d != $(srcdir); then \ cp -fpR $(srcdir)/$$file "$(distdir)$$dir" || exit 1; \ find "$(distdir)/$$file" -type d ! -perm -700 -exec chmod u+rwx {} \;; \ fi; \ cp -fpR $$d/$$file "$(distdir)$$dir" || exit 1; \ else \ test -f "$(distdir)/$$file" \ || cp -p $$d/$$file "$(distdir)/$$file" \ || exit 1; \ fi; \ done check-am: all-am check: check-am all-am: Makefile $(DATA) installdirs: for dir in "$(DESTDIR)$(pamddir)"; do \ test -z "$$dir" || $(MKDIR_P) "$$dir"; \ done install: install-am install-exec: install-exec-am install-data: install-data-am uninstall: uninstall-am install-am: all-am @$(MAKE) $(AM_MAKEFLAGS) install-exec-am install-data-am installcheck: installcheck-am install-strip: if test -z '$(STRIP)'; then \ $(MAKE) $(AM_MAKEFLAGS) INSTALL_PROGRAM="$(INSTALL_STRIP_PROGRAM)" \ install_sh_PROGRAM="$(INSTALL_STRIP_PROGRAM)" INSTALL_STRIP_FLAG=-s \ install; \ else \ $(MAKE) $(AM_MAKEFLAGS) INSTALL_PROGRAM="$(INSTALL_STRIP_PROGRAM)" \ install_sh_PROGRAM="$(INSTALL_STRIP_PROGRAM)" INSTALL_STRIP_FLAG=-s \ "INSTALL_PROGRAM_ENV=STRIPPROG='$(STRIP)'" install; \ fi mostlyclean-generic: clean-generic: -test -z "$(CLEANFILES)" || rm -f $(CLEANFILES) distclean-generic: -test -z "$(CONFIG_CLEAN_FILES)" || rm -f $(CONFIG_CLEAN_FILES) -test . = "$(srcdir)" || test -z "$(CONFIG_CLEAN_VPATH_FILES)" || rm -f $(CONFIG_CLEAN_VPATH_FILES) maintainer-clean-generic: @echo "This command is intended for maintainers to use" @echo "it deletes files that may require special tools to rebuild." clean: clean-am clean-am: clean-generic clean-libtool mostlyclean-am distclean: distclean-am -rm -f Makefile distclean-am: clean-am distclean-generic dvi: dvi-am dvi-am: html: html-am html-am: info: info-am info-am: install-data-am: install-pamdDATA install-dvi: install-dvi-am install-dvi-am: install-exec-am: install-html: install-html-am install-html-am: install-info: install-info-am install-info-am: install-man: install-pdf: install-pdf-am install-pdf-am: install-ps: install-ps-am install-ps-am: installcheck-am: maintainer-clean: maintainer-clean-am -rm -f Makefile maintainer-clean-am: distclean-am maintainer-clean-generic mostlyclean: mostlyclean-am mostlyclean-am: mostlyclean-generic mostlyclean-libtool pdf: pdf-am pdf-am: ps: ps-am ps-am: uninstall-am: uninstall-pamdDATA .MAKE: install-am install-strip .PHONY: all all-am check check-am clean clean-generic clean-libtool \ cscopelist-am ctags-am distclean distclean-generic \ distclean-libtool distdir dvi dvi-am html html-am info info-am \ install install-am install-data install-data-am install-dvi \ install-dvi-am install-exec install-exec-am install-html \ install-html-am install-info install-info-am install-man \ install-pamdDATA install-pdf install-pdf-am install-ps \ install-ps-am install-strip installcheck installcheck-am \ installdirs maintainer-clean maintainer-clean-generic \ mostlyclean mostlyclean-generic mostlyclean-libtool pdf pdf-am \ ps ps-am tags-am uninstall uninstall-am uninstall-pamdDATA .PRECIOUS: Makefile xrdp-sesman: mkpamrules $(srcdir)/mkpamrules $(PAM_RULES) $(srcdir) $@ # Tell versions [3.59,3.63) of GNU make to not export all variables. # Otherwise a system limit (for SysV at least) may be exceeded. .NOEXPORT: xrdp-0.9.5/instfiles/pulse/default.pa000644 001751 001751 00000000404 13125122133 017507 0ustar00metameta000000 000000 .nofail .fail load-module module-augment-properties load-module module-always-sink .ifexists module-xrdp-sink.so load-module module-xrdp-sink .endif .ifexists module-xrdp-source.so load-module module-xrdp-source .endif load-module module-native-protocol-unix xrdp-0.9.5/instfiles/pulse/Makefile.in000644 001751 001751 00000036036 13220730774 017634 0ustar00metameta000000 000000 # Makefile.in generated by automake 1.15.1 from Makefile.am. # @configure_input@ # Copyright (C) 1994-2017 Free Software Foundation, Inc. # This Makefile.in is free software; the Free Software Foundation # gives unlimited permission to copy and/or distribute it, # with or without modifications, as long as this notice is preserved. # This program is distributed in the hope that it will be useful, # but WITHOUT ANY WARRANTY, to the extent permitted by law; without # even the implied warranty of MERCHANTABILITY or FITNESS FOR A # PARTICULAR PURPOSE. @SET_MAKE@ VPATH = @srcdir@ am__is_gnu_make = { \ if test -z '$(MAKELEVEL)'; then \ false; \ elif test -n '$(MAKE_HOST)'; then \ true; \ elif test -n '$(MAKE_VERSION)' && test -n '$(CURDIR)'; then \ true; \ else \ false; \ fi; \ } am__make_running_with_option = \ case $${target_option-} in \ ?) ;; \ *) echo "am__make_running_with_option: internal error: invalid" \ "target option '$${target_option-}' specified" >&2; \ exit 1;; \ esac; \ has_opt=no; \ sane_makeflags=$$MAKEFLAGS; \ if $(am__is_gnu_make); then \ sane_makeflags=$$MFLAGS; \ else \ case $$MAKEFLAGS in \ *\\[\ \ ]*) \ bs=\\; \ sane_makeflags=`printf '%s\n' "$$MAKEFLAGS" \ | sed "s/$$bs$$bs[$$bs $$bs ]*//g"`;; \ esac; \ fi; \ skip_next=no; \ strip_trailopt () \ { \ flg=`printf '%s\n' "$$flg" | sed "s/$$1.*$$//"`; \ }; \ for flg in $$sane_makeflags; do \ test $$skip_next = yes && { skip_next=no; continue; }; \ case $$flg in \ *=*|--*) continue;; \ -*I) strip_trailopt 'I'; skip_next=yes;; \ -*I?*) strip_trailopt 'I';; \ -*O) strip_trailopt 'O'; skip_next=yes;; \ -*O?*) strip_trailopt 'O';; \ -*l) strip_trailopt 'l'; skip_next=yes;; \ -*l?*) strip_trailopt 'l';; \ -[dEDm]) skip_next=yes;; \ -[JT]) skip_next=yes;; \ esac; \ case $$flg in \ *$$target_option*) has_opt=yes; break;; \ esac; \ done; \ test $$has_opt = yes am__make_dryrun = (target_option=n; $(am__make_running_with_option)) am__make_keepgoing = (target_option=k; $(am__make_running_with_option)) pkgdatadir = $(datadir)/@PACKAGE@ pkgincludedir = $(includedir)/@PACKAGE@ pkglibdir = $(libdir)/@PACKAGE@ pkglibexecdir = $(libexecdir)/@PACKAGE@ am__cd = CDPATH="$${ZSH_VERSION+.}$(PATH_SEPARATOR)" && cd install_sh_DATA = $(install_sh) -c -m 644 install_sh_PROGRAM = $(install_sh) -c install_sh_SCRIPT = $(install_sh) -c INSTALL_HEADER = $(INSTALL_DATA) transform = $(program_transform_name) NORMAL_INSTALL = : PRE_INSTALL = : POST_INSTALL = : NORMAL_UNINSTALL = : PRE_UNINSTALL = : POST_UNINSTALL = : build_triplet = @build@ host_triplet = @host@ subdir = instfiles/pulse ACLOCAL_M4 = $(top_srcdir)/aclocal.m4 am__aclocal_m4_deps = $(top_srcdir)/m4/ax_append_compile_flags.m4 \ $(top_srcdir)/m4/ax_append_flag.m4 \ $(top_srcdir)/m4/ax_cflags_warn_all.m4 \ $(top_srcdir)/m4/ax_check_compile_flag.m4 \ $(top_srcdir)/m4/ax_gcc_func_attribute.m4 \ $(top_srcdir)/m4/ax_require_defined.m4 \ $(top_srcdir)/m4/ax_type_socklen_t.m4 \ $(top_srcdir)/m4/libtool.m4 $(top_srcdir)/m4/ltoptions.m4 \ $(top_srcdir)/m4/ltsugar.m4 $(top_srcdir)/m4/ltversion.m4 \ $(top_srcdir)/m4/lt~obsolete.m4 $(top_srcdir)/m4/pkg.m4 \ $(top_srcdir)/configure.ac am__configure_deps = $(am__aclocal_m4_deps) $(CONFIGURE_DEPENDENCIES) \ $(ACLOCAL_M4) DIST_COMMON = $(srcdir)/Makefile.am $(dist_pulse_DATA) \ $(am__DIST_COMMON) mkinstalldirs = $(install_sh) -d CONFIG_HEADER = $(top_builddir)/config_ac.h CONFIG_CLEAN_FILES = CONFIG_CLEAN_VPATH_FILES = AM_V_P = $(am__v_P_@AM_V@) am__v_P_ = $(am__v_P_@AM_DEFAULT_V@) am__v_P_0 = false am__v_P_1 = : AM_V_GEN = $(am__v_GEN_@AM_V@) am__v_GEN_ = $(am__v_GEN_@AM_DEFAULT_V@) am__v_GEN_0 = @echo " GEN " $@; am__v_GEN_1 = AM_V_at = $(am__v_at_@AM_V@) am__v_at_ = $(am__v_at_@AM_DEFAULT_V@) am__v_at_0 = @ am__v_at_1 = SOURCES = DIST_SOURCES = am__can_run_installinfo = \ case $$AM_UPDATE_INFO_DIR in \ n|no|NO) false;; \ *) (install-info --version) >/dev/null 2>&1;; \ esac am__vpath_adj_setup = srcdirstrip=`echo "$(srcdir)" | sed 's|.|.|g'`; am__vpath_adj = case $$p in \ $(srcdir)/*) f=`echo "$$p" | sed "s|^$$srcdirstrip/||"`;; \ *) f=$$p;; \ esac; am__strip_dir = f=`echo $$p | sed -e 's|^.*/||'`; am__install_max = 40 am__nobase_strip_setup = \ srcdirstrip=`echo "$(srcdir)" | sed 's/[].[^$$\\*|]/\\\\&/g'` am__nobase_strip = \ for p in $$list; do echo "$$p"; done | sed -e "s|$$srcdirstrip/||" am__nobase_list = $(am__nobase_strip_setup); \ for p in $$list; do echo "$$p $$p"; done | \ sed "s| $$srcdirstrip/| |;"' / .*\//!s/ .*/ ./; s,\( .*\)/[^/]*$$,\1,' | \ $(AWK) 'BEGIN { files["."] = "" } { files[$$2] = files[$$2] " " $$1; \ if (++n[$$2] == $(am__install_max)) \ { print $$2, files[$$2]; n[$$2] = 0; files[$$2] = "" } } \ END { for (dir in files) print dir, files[dir] }' am__base_list = \ sed '$$!N;$$!N;$$!N;$$!N;$$!N;$$!N;$$!N;s/\n/ /g' | \ sed '$$!N;$$!N;$$!N;$$!N;s/\n/ /g' am__uninstall_files_from_dir = { \ test -z "$$files" \ || { test ! -d "$$dir" && test ! -f "$$dir" && test ! -r "$$dir"; } \ || { echo " ( cd '$$dir' && rm -f" $$files ")"; \ $(am__cd) "$$dir" && rm -f $$files; }; \ } am__installdirs = "$(DESTDIR)$(pulsedir)" DATA = $(dist_pulse_DATA) am__tagged_files = $(HEADERS) $(SOURCES) $(TAGS_FILES) $(LISP) am__DIST_COMMON = $(srcdir)/Makefile.in DISTFILES = $(DIST_COMMON) $(DIST_SOURCES) $(TEXINFOS) $(EXTRA_DIST) ACLOCAL = @ACLOCAL@ AMTAR = @AMTAR@ AM_DEFAULT_VERBOSITY = @AM_DEFAULT_VERBOSITY@ AR = @AR@ AUTOCONF = @AUTOCONF@ AUTOHEADER = @AUTOHEADER@ AUTOMAKE = @AUTOMAKE@ AWK = @AWK@ CC = @CC@ CCDEPMODE = @CCDEPMODE@ CFLAGS = @CFLAGS@ CPP = @CPP@ CPPFLAGS = @CPPFLAGS@ CYGPATH_W = @CYGPATH_W@ DEFS = @DEFS@ DEPDIR = @DEPDIR@ DLLTOOL = @DLLTOOL@ DLOPEN_LIBS = @DLOPEN_LIBS@ DSYMUTIL = @DSYMUTIL@ DUMPBIN = @DUMPBIN@ ECHO_C = @ECHO_C@ ECHO_N = @ECHO_N@ ECHO_T = @ECHO_T@ EGREP = @EGREP@ EXEEXT = @EXEEXT@ FDKAAC_CFLAGS = @FDKAAC_CFLAGS@ FDKAAC_LIBS = @FDKAAC_LIBS@ FGREP = @FGREP@ FREERDP_CFLAGS = @FREERDP_CFLAGS@ FREERDP_LIBS = @FREERDP_LIBS@ FUSE_CFLAGS = @FUSE_CFLAGS@ FUSE_LIBS = @FUSE_LIBS@ GREP = @GREP@ INSTALL = @INSTALL@ INSTALL_DATA = @INSTALL_DATA@ INSTALL_PROGRAM = @INSTALL_PROGRAM@ INSTALL_SCRIPT = @INSTALL_SCRIPT@ INSTALL_STRIP_PROGRAM = @INSTALL_STRIP_PROGRAM@ LD = @LD@ LDFLAGS = @LDFLAGS@ LIBOBJS = @LIBOBJS@ LIBS = @LIBS@ LIBTOOL = @LIBTOOL@ LIPO = @LIPO@ LN_S = @LN_S@ LTLIBOBJS = @LTLIBOBJS@ LT_SYS_LIBRARY_PATH = @LT_SYS_LIBRARY_PATH@ MAKEINFO = @MAKEINFO@ MANIFEST_TOOL = @MANIFEST_TOOL@ MKDIR_P = @MKDIR_P@ NM = @NM@ NMEDIT = @NMEDIT@ OBJDUMP = @OBJDUMP@ OBJEXT = @OBJEXT@ OPENSSL = @OPENSSL@ OPENSSL_CFLAGS = @OPENSSL_CFLAGS@ OPENSSL_LIBS = @OPENSSL_LIBS@ OTOOL = @OTOOL@ OTOOL64 = @OTOOL64@ PACKAGE = @PACKAGE@ PACKAGE_BUGREPORT = @PACKAGE_BUGREPORT@ PACKAGE_NAME = @PACKAGE_NAME@ PACKAGE_STRING = @PACKAGE_STRING@ PACKAGE_TARNAME = @PACKAGE_TARNAME@ PACKAGE_URL = @PACKAGE_URL@ PACKAGE_VERSION = @PACKAGE_VERSION@ PAM_RULES = @PAM_RULES@ PATH_SEPARATOR = @PATH_SEPARATOR@ PIXMAN_CFLAGS = @PIXMAN_CFLAGS@ PIXMAN_LIBS = @PIXMAN_LIBS@ PKG_CONFIG = @PKG_CONFIG@ PKG_CONFIG_LIBDIR = @PKG_CONFIG_LIBDIR@ PKG_CONFIG_PATH = @PKG_CONFIG_PATH@ RANLIB = @RANLIB@ SED = @SED@ SET_MAKE = @SET_MAKE@ SHELL = @SHELL@ STRIP = @STRIP@ TurboJpegIncDir = @TurboJpegIncDir@ TurboJpegLibDir = @TurboJpegLibDir@ VERSION = @VERSION@ XMKMF = @XMKMF@ X_CFLAGS = @X_CFLAGS@ X_EXTRA_LIBS = @X_EXTRA_LIBS@ X_LIBS = @X_LIBS@ X_PRE_LIBS = @X_PRE_LIBS@ abs_builddir = @abs_builddir@ abs_srcdir = @abs_srcdir@ abs_top_builddir = @abs_top_builddir@ abs_top_srcdir = @abs_top_srcdir@ ac_ct_AR = @ac_ct_AR@ ac_ct_CC = @ac_ct_CC@ ac_ct_DUMPBIN = @ac_ct_DUMPBIN@ am__include = @am__include@ am__leading_dot = @am__leading_dot@ am__quote = @am__quote@ am__tar = @am__tar@ am__untar = @am__untar@ bindir = @bindir@ build = @build@ build_alias = @build_alias@ build_cpu = @build_cpu@ build_os = @build_os@ build_vendor = @build_vendor@ builddir = @builddir@ datadir = @datadir@ datarootdir = @datarootdir@ docdir = @docdir@ dvidir = @dvidir@ exec_prefix = @exec_prefix@ host = @host@ host_alias = @host_alias@ host_cpu = @host_cpu@ host_os = @host_os@ host_vendor = @host_vendor@ htmldir = @htmldir@ includedir = @includedir@ infodir = @infodir@ install_sh = @install_sh@ libdir = @libdir@ libexecdir = @libexecdir@ localedir = @localedir@ localstatedir = @localstatedir@ mandir = @mandir@ mkdir_p = @mkdir_p@ moduledir = @moduledir@ oldincludedir = @oldincludedir@ pdfdir = @pdfdir@ pkgconfigdir = @pkgconfigdir@ prefix = @prefix@ program_transform_name = @program_transform_name@ psdir = @psdir@ sbindir = @sbindir@ sharedstatedir = @sharedstatedir@ socketdir = @socketdir@ srcdir = @srcdir@ subdirs = @subdirs@ sysconfdir = @sysconfdir@ systemdsystemunitdir = @systemdsystemunitdir@ target_alias = @target_alias@ top_build_prefix = @top_build_prefix@ top_builddir = @top_builddir@ top_srcdir = @top_srcdir@ pulsedir = $(sysconfdir)/xrdp/pulse dist_pulse_DATA = default.pa all: all-am .SUFFIXES: $(srcdir)/Makefile.in: $(srcdir)/Makefile.am $(am__configure_deps) @for dep in $?; do \ case '$(am__configure_deps)' in \ *$$dep*) \ ( cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh ) \ && { if test -f $@; then exit 0; else break; fi; }; \ exit 1;; \ esac; \ done; \ echo ' cd $(top_srcdir) && $(AUTOMAKE) --foreign instfiles/pulse/Makefile'; \ $(am__cd) $(top_srcdir) && \ $(AUTOMAKE) --foreign instfiles/pulse/Makefile Makefile: $(srcdir)/Makefile.in $(top_builddir)/config.status @case '$?' in \ *config.status*) \ cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh;; \ *) \ echo ' cd $(top_builddir) && $(SHELL) ./config.status $(subdir)/$@ $(am__depfiles_maybe)'; \ cd $(top_builddir) && $(SHELL) ./config.status $(subdir)/$@ $(am__depfiles_maybe);; \ esac; $(top_builddir)/config.status: $(top_srcdir)/configure $(CONFIG_STATUS_DEPENDENCIES) cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh $(top_srcdir)/configure: $(am__configure_deps) cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh $(ACLOCAL_M4): $(am__aclocal_m4_deps) cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh $(am__aclocal_m4_deps): mostlyclean-libtool: -rm -f *.lo clean-libtool: -rm -rf .libs _libs install-dist_pulseDATA: $(dist_pulse_DATA) @$(NORMAL_INSTALL) @list='$(dist_pulse_DATA)'; test -n "$(pulsedir)" || list=; \ if test -n "$$list"; then \ echo " $(MKDIR_P) '$(DESTDIR)$(pulsedir)'"; \ $(MKDIR_P) "$(DESTDIR)$(pulsedir)" || exit 1; \ fi; \ for p in $$list; do \ if test -f "$$p"; then d=; else d="$(srcdir)/"; fi; \ echo "$$d$$p"; \ done | $(am__base_list) | \ while read files; do \ echo " $(INSTALL_DATA) $$files '$(DESTDIR)$(pulsedir)'"; \ $(INSTALL_DATA) $$files "$(DESTDIR)$(pulsedir)" || exit $$?; \ done uninstall-dist_pulseDATA: @$(NORMAL_UNINSTALL) @list='$(dist_pulse_DATA)'; test -n "$(pulsedir)" || list=; \ files=`for p in $$list; do echo $$p; done | sed -e 's|^.*/||'`; \ dir='$(DESTDIR)$(pulsedir)'; $(am__uninstall_files_from_dir) tags TAGS: ctags CTAGS: cscope cscopelist: distdir: $(DISTFILES) @srcdirstrip=`echo "$(srcdir)" | sed 's/[].[^$$\\*]/\\\\&/g'`; \ topsrcdirstrip=`echo "$(top_srcdir)" | sed 's/[].[^$$\\*]/\\\\&/g'`; \ list='$(DISTFILES)'; \ dist_files=`for file in $$list; do echo $$file; done | \ sed -e "s|^$$srcdirstrip/||;t" \ -e "s|^$$topsrcdirstrip/|$(top_builddir)/|;t"`; \ case $$dist_files in \ */*) $(MKDIR_P) `echo "$$dist_files" | \ sed '/\//!d;s|^|$(distdir)/|;s,/[^/]*$$,,' | \ sort -u` ;; \ esac; \ for file in $$dist_files; do \ if test -f $$file || test -d $$file; then d=.; else d=$(srcdir); fi; \ if test -d $$d/$$file; then \ dir=`echo "/$$file" | sed -e 's,/[^/]*$$,,'`; \ if test -d "$(distdir)/$$file"; then \ find "$(distdir)/$$file" -type d ! -perm -700 -exec chmod u+rwx {} \;; \ fi; \ if test -d $(srcdir)/$$file && test $$d != $(srcdir); then \ cp -fpR $(srcdir)/$$file "$(distdir)$$dir" || exit 1; \ find "$(distdir)/$$file" -type d ! -perm -700 -exec chmod u+rwx {} \;; \ fi; \ cp -fpR $$d/$$file "$(distdir)$$dir" || exit 1; \ else \ test -f "$(distdir)/$$file" \ || cp -p $$d/$$file "$(distdir)/$$file" \ || exit 1; \ fi; \ done check-am: all-am check: check-am all-am: Makefile $(DATA) installdirs: for dir in "$(DESTDIR)$(pulsedir)"; do \ test -z "$$dir" || $(MKDIR_P) "$$dir"; \ done install: install-am install-exec: install-exec-am install-data: install-data-am uninstall: uninstall-am install-am: all-am @$(MAKE) $(AM_MAKEFLAGS) install-exec-am install-data-am installcheck: installcheck-am install-strip: if test -z '$(STRIP)'; then \ $(MAKE) $(AM_MAKEFLAGS) INSTALL_PROGRAM="$(INSTALL_STRIP_PROGRAM)" \ install_sh_PROGRAM="$(INSTALL_STRIP_PROGRAM)" INSTALL_STRIP_FLAG=-s \ install; \ else \ $(MAKE) $(AM_MAKEFLAGS) INSTALL_PROGRAM="$(INSTALL_STRIP_PROGRAM)" \ install_sh_PROGRAM="$(INSTALL_STRIP_PROGRAM)" INSTALL_STRIP_FLAG=-s \ "INSTALL_PROGRAM_ENV=STRIPPROG='$(STRIP)'" install; \ fi mostlyclean-generic: clean-generic: distclean-generic: -test -z "$(CONFIG_CLEAN_FILES)" || rm -f $(CONFIG_CLEAN_FILES) -test . = "$(srcdir)" || test -z "$(CONFIG_CLEAN_VPATH_FILES)" || rm -f $(CONFIG_CLEAN_VPATH_FILES) maintainer-clean-generic: @echo "This command is intended for maintainers to use" @echo "it deletes files that may require special tools to rebuild." clean: clean-am clean-am: clean-generic clean-libtool mostlyclean-am distclean: distclean-am -rm -f Makefile distclean-am: clean-am distclean-generic dvi: dvi-am dvi-am: html: html-am html-am: info: info-am info-am: install-data-am: install-dist_pulseDATA install-dvi: install-dvi-am install-dvi-am: install-exec-am: install-html: install-html-am install-html-am: install-info: install-info-am install-info-am: install-man: install-pdf: install-pdf-am install-pdf-am: install-ps: install-ps-am install-ps-am: installcheck-am: maintainer-clean: maintainer-clean-am -rm -f Makefile maintainer-clean-am: distclean-am maintainer-clean-generic mostlyclean: mostlyclean-am mostlyclean-am: mostlyclean-generic mostlyclean-libtool pdf: pdf-am pdf-am: ps: ps-am ps-am: uninstall-am: uninstall-dist_pulseDATA .MAKE: install-am install-strip .PHONY: all all-am check check-am clean clean-generic clean-libtool \ cscopelist-am ctags-am distclean distclean-generic \ distclean-libtool distdir dvi dvi-am html html-am info info-am \ install install-am install-data install-data-am \ install-dist_pulseDATA install-dvi install-dvi-am install-exec \ install-exec-am install-html install-html-am install-info \ install-info-am install-man install-pdf install-pdf-am \ install-ps install-ps-am install-strip installcheck \ installcheck-am installdirs maintainer-clean \ maintainer-clean-generic mostlyclean mostlyclean-generic \ mostlyclean-libtool pdf pdf-am ps ps-am tags-am uninstall \ uninstall-am uninstall-dist_pulseDATA .PRECIOUS: Makefile # Tell versions [3.59,3.63) of GNU make to not export all variables. # Otherwise a system limit (for SysV at least) may be exceeded. .NOEXPORT: xrdp-0.9.5/instfiles/pulse/Makefile.am000644 001751 001751 00000000101 13127114621 017574 0ustar00metameta000000 000000 pulsedir = $(sysconfdir)/xrdp/pulse dist_pulse_DATA = default.pa xrdp-0.9.5/instfiles/default/xrdp000644 001751 001751 00000000254 13125122133 016740 0ustar00metameta000000 000000 # Do we need to start sesman ? SESMAN_START=yes # Do we restart xrdp on upgrade ? If not set to no, any xrdp session will # be shutdown on upgrade. # RESTART_ON_UPGRADE=no xrdp-0.9.5/instfiles/default/Makefile.in000644 001751 001751 00000036237 13220730774 020133 0ustar00metameta000000 000000 # Makefile.in generated by automake 1.15.1 from Makefile.am. # @configure_input@ # Copyright (C) 1994-2017 Free Software Foundation, Inc. # This Makefile.in is free software; the Free Software Foundation # gives unlimited permission to copy and/or distribute it, # with or without modifications, as long as this notice is preserved. # This program is distributed in the hope that it will be useful, # but WITHOUT ANY WARRANTY, to the extent permitted by law; without # even the implied warranty of MERCHANTABILITY or FITNESS FOR A # PARTICULAR PURPOSE. @SET_MAKE@ VPATH = @srcdir@ am__is_gnu_make = { \ if test -z '$(MAKELEVEL)'; then \ false; \ elif test -n '$(MAKE_HOST)'; then \ true; \ elif test -n '$(MAKE_VERSION)' && test -n '$(CURDIR)'; then \ true; \ else \ false; \ fi; \ } am__make_running_with_option = \ case $${target_option-} in \ ?) ;; \ *) echo "am__make_running_with_option: internal error: invalid" \ "target option '$${target_option-}' specified" >&2; \ exit 1;; \ esac; \ has_opt=no; \ sane_makeflags=$$MAKEFLAGS; \ if $(am__is_gnu_make); then \ sane_makeflags=$$MFLAGS; \ else \ case $$MAKEFLAGS in \ *\\[\ \ ]*) \ bs=\\; \ sane_makeflags=`printf '%s\n' "$$MAKEFLAGS" \ | sed "s/$$bs$$bs[$$bs $$bs ]*//g"`;; \ esac; \ fi; \ skip_next=no; \ strip_trailopt () \ { \ flg=`printf '%s\n' "$$flg" | sed "s/$$1.*$$//"`; \ }; \ for flg in $$sane_makeflags; do \ test $$skip_next = yes && { skip_next=no; continue; }; \ case $$flg in \ *=*|--*) continue;; \ -*I) strip_trailopt 'I'; skip_next=yes;; \ -*I?*) strip_trailopt 'I';; \ -*O) strip_trailopt 'O'; skip_next=yes;; \ -*O?*) strip_trailopt 'O';; \ -*l) strip_trailopt 'l'; skip_next=yes;; \ -*l?*) strip_trailopt 'l';; \ -[dEDm]) skip_next=yes;; \ -[JT]) skip_next=yes;; \ esac; \ case $$flg in \ *$$target_option*) has_opt=yes; break;; \ esac; \ done; \ test $$has_opt = yes am__make_dryrun = (target_option=n; $(am__make_running_with_option)) am__make_keepgoing = (target_option=k; $(am__make_running_with_option)) pkgdatadir = $(datadir)/@PACKAGE@ pkgincludedir = $(includedir)/@PACKAGE@ pkglibdir = $(libdir)/@PACKAGE@ pkglibexecdir = $(libexecdir)/@PACKAGE@ am__cd = CDPATH="$${ZSH_VERSION+.}$(PATH_SEPARATOR)" && cd install_sh_DATA = $(install_sh) -c -m 644 install_sh_PROGRAM = $(install_sh) -c install_sh_SCRIPT = $(install_sh) -c INSTALL_HEADER = $(INSTALL_DATA) transform = $(program_transform_name) NORMAL_INSTALL = : PRE_INSTALL = : POST_INSTALL = : NORMAL_UNINSTALL = : PRE_UNINSTALL = : POST_UNINSTALL = : build_triplet = @build@ host_triplet = @host@ subdir = instfiles/default ACLOCAL_M4 = $(top_srcdir)/aclocal.m4 am__aclocal_m4_deps = $(top_srcdir)/m4/ax_append_compile_flags.m4 \ $(top_srcdir)/m4/ax_append_flag.m4 \ $(top_srcdir)/m4/ax_cflags_warn_all.m4 \ $(top_srcdir)/m4/ax_check_compile_flag.m4 \ $(top_srcdir)/m4/ax_gcc_func_attribute.m4 \ $(top_srcdir)/m4/ax_require_defined.m4 \ $(top_srcdir)/m4/ax_type_socklen_t.m4 \ $(top_srcdir)/m4/libtool.m4 $(top_srcdir)/m4/ltoptions.m4 \ $(top_srcdir)/m4/ltsugar.m4 $(top_srcdir)/m4/ltversion.m4 \ $(top_srcdir)/m4/lt~obsolete.m4 $(top_srcdir)/m4/pkg.m4 \ $(top_srcdir)/configure.ac am__configure_deps = $(am__aclocal_m4_deps) $(CONFIGURE_DEPENDENCIES) \ $(ACLOCAL_M4) DIST_COMMON = $(srcdir)/Makefile.am $(dist_startscript_DATA) \ $(am__DIST_COMMON) mkinstalldirs = $(install_sh) -d CONFIG_HEADER = $(top_builddir)/config_ac.h CONFIG_CLEAN_FILES = CONFIG_CLEAN_VPATH_FILES = AM_V_P = $(am__v_P_@AM_V@) am__v_P_ = $(am__v_P_@AM_DEFAULT_V@) am__v_P_0 = false am__v_P_1 = : AM_V_GEN = $(am__v_GEN_@AM_V@) am__v_GEN_ = $(am__v_GEN_@AM_DEFAULT_V@) am__v_GEN_0 = @echo " GEN " $@; am__v_GEN_1 = AM_V_at = $(am__v_at_@AM_V@) am__v_at_ = $(am__v_at_@AM_DEFAULT_V@) am__v_at_0 = @ am__v_at_1 = SOURCES = DIST_SOURCES = am__can_run_installinfo = \ case $$AM_UPDATE_INFO_DIR in \ n|no|NO) false;; \ *) (install-info --version) >/dev/null 2>&1;; \ esac am__vpath_adj_setup = srcdirstrip=`echo "$(srcdir)" | sed 's|.|.|g'`; am__vpath_adj = case $$p in \ $(srcdir)/*) f=`echo "$$p" | sed "s|^$$srcdirstrip/||"`;; \ *) f=$$p;; \ esac; am__strip_dir = f=`echo $$p | sed -e 's|^.*/||'`; am__install_max = 40 am__nobase_strip_setup = \ srcdirstrip=`echo "$(srcdir)" | sed 's/[].[^$$\\*|]/\\\\&/g'` am__nobase_strip = \ for p in $$list; do echo "$$p"; done | sed -e "s|$$srcdirstrip/||" am__nobase_list = $(am__nobase_strip_setup); \ for p in $$list; do echo "$$p $$p"; done | \ sed "s| $$srcdirstrip/| |;"' / .*\//!s/ .*/ ./; s,\( .*\)/[^/]*$$,\1,' | \ $(AWK) 'BEGIN { files["."] = "" } { files[$$2] = files[$$2] " " $$1; \ if (++n[$$2] == $(am__install_max)) \ { print $$2, files[$$2]; n[$$2] = 0; files[$$2] = "" } } \ END { for (dir in files) print dir, files[dir] }' am__base_list = \ sed '$$!N;$$!N;$$!N;$$!N;$$!N;$$!N;$$!N;s/\n/ /g' | \ sed '$$!N;$$!N;$$!N;$$!N;s/\n/ /g' am__uninstall_files_from_dir = { \ test -z "$$files" \ || { test ! -d "$$dir" && test ! -f "$$dir" && test ! -r "$$dir"; } \ || { echo " ( cd '$$dir' && rm -f" $$files ")"; \ $(am__cd) "$$dir" && rm -f $$files; }; \ } am__installdirs = "$(DESTDIR)$(startscriptdir)" DATA = $(dist_startscript_DATA) am__tagged_files = $(HEADERS) $(SOURCES) $(TAGS_FILES) $(LISP) am__DIST_COMMON = $(srcdir)/Makefile.in DISTFILES = $(DIST_COMMON) $(DIST_SOURCES) $(TEXINFOS) $(EXTRA_DIST) ACLOCAL = @ACLOCAL@ AMTAR = @AMTAR@ AM_DEFAULT_VERBOSITY = @AM_DEFAULT_VERBOSITY@ AR = @AR@ AUTOCONF = @AUTOCONF@ AUTOHEADER = @AUTOHEADER@ AUTOMAKE = @AUTOMAKE@ AWK = @AWK@ CC = @CC@ CCDEPMODE = @CCDEPMODE@ CFLAGS = @CFLAGS@ CPP = @CPP@ CPPFLAGS = @CPPFLAGS@ CYGPATH_W = @CYGPATH_W@ DEFS = @DEFS@ DEPDIR = @DEPDIR@ DLLTOOL = @DLLTOOL@ DLOPEN_LIBS = @DLOPEN_LIBS@ DSYMUTIL = @DSYMUTIL@ DUMPBIN = @DUMPBIN@ ECHO_C = @ECHO_C@ ECHO_N = @ECHO_N@ ECHO_T = @ECHO_T@ EGREP = @EGREP@ EXEEXT = @EXEEXT@ FDKAAC_CFLAGS = @FDKAAC_CFLAGS@ FDKAAC_LIBS = @FDKAAC_LIBS@ FGREP = @FGREP@ FREERDP_CFLAGS = @FREERDP_CFLAGS@ FREERDP_LIBS = @FREERDP_LIBS@ FUSE_CFLAGS = @FUSE_CFLAGS@ FUSE_LIBS = @FUSE_LIBS@ GREP = @GREP@ INSTALL = @INSTALL@ INSTALL_DATA = @INSTALL_DATA@ INSTALL_PROGRAM = @INSTALL_PROGRAM@ INSTALL_SCRIPT = @INSTALL_SCRIPT@ INSTALL_STRIP_PROGRAM = @INSTALL_STRIP_PROGRAM@ LD = @LD@ LDFLAGS = @LDFLAGS@ LIBOBJS = @LIBOBJS@ LIBS = @LIBS@ LIBTOOL = @LIBTOOL@ LIPO = @LIPO@ LN_S = @LN_S@ LTLIBOBJS = @LTLIBOBJS@ LT_SYS_LIBRARY_PATH = @LT_SYS_LIBRARY_PATH@ MAKEINFO = @MAKEINFO@ MANIFEST_TOOL = @MANIFEST_TOOL@ MKDIR_P = @MKDIR_P@ NM = @NM@ NMEDIT = @NMEDIT@ OBJDUMP = @OBJDUMP@ OBJEXT = @OBJEXT@ OPENSSL = @OPENSSL@ OPENSSL_CFLAGS = @OPENSSL_CFLAGS@ OPENSSL_LIBS = @OPENSSL_LIBS@ OTOOL = @OTOOL@ OTOOL64 = @OTOOL64@ PACKAGE = @PACKAGE@ PACKAGE_BUGREPORT = @PACKAGE_BUGREPORT@ PACKAGE_NAME = @PACKAGE_NAME@ PACKAGE_STRING = @PACKAGE_STRING@ PACKAGE_TARNAME = @PACKAGE_TARNAME@ PACKAGE_URL = @PACKAGE_URL@ PACKAGE_VERSION = @PACKAGE_VERSION@ PAM_RULES = @PAM_RULES@ PATH_SEPARATOR = @PATH_SEPARATOR@ PIXMAN_CFLAGS = @PIXMAN_CFLAGS@ PIXMAN_LIBS = @PIXMAN_LIBS@ PKG_CONFIG = @PKG_CONFIG@ PKG_CONFIG_LIBDIR = @PKG_CONFIG_LIBDIR@ PKG_CONFIG_PATH = @PKG_CONFIG_PATH@ RANLIB = @RANLIB@ SED = @SED@ SET_MAKE = @SET_MAKE@ SHELL = @SHELL@ STRIP = @STRIP@ TurboJpegIncDir = @TurboJpegIncDir@ TurboJpegLibDir = @TurboJpegLibDir@ VERSION = @VERSION@ XMKMF = @XMKMF@ X_CFLAGS = @X_CFLAGS@ X_EXTRA_LIBS = @X_EXTRA_LIBS@ X_LIBS = @X_LIBS@ X_PRE_LIBS = @X_PRE_LIBS@ abs_builddir = @abs_builddir@ abs_srcdir = @abs_srcdir@ abs_top_builddir = @abs_top_builddir@ abs_top_srcdir = @abs_top_srcdir@ ac_ct_AR = @ac_ct_AR@ ac_ct_CC = @ac_ct_CC@ ac_ct_DUMPBIN = @ac_ct_DUMPBIN@ am__include = @am__include@ am__leading_dot = @am__leading_dot@ am__quote = @am__quote@ am__tar = @am__tar@ am__untar = @am__untar@ bindir = @bindir@ build = @build@ build_alias = @build_alias@ build_cpu = @build_cpu@ build_os = @build_os@ build_vendor = @build_vendor@ builddir = @builddir@ datadir = @datadir@ datarootdir = @datarootdir@ docdir = @docdir@ dvidir = @dvidir@ exec_prefix = @exec_prefix@ host = @host@ host_alias = @host_alias@ host_cpu = @host_cpu@ host_os = @host_os@ host_vendor = @host_vendor@ htmldir = @htmldir@ includedir = @includedir@ infodir = @infodir@ install_sh = @install_sh@ libdir = @libdir@ libexecdir = @libexecdir@ localedir = @localedir@ localstatedir = @localstatedir@ mandir = @mandir@ mkdir_p = @mkdir_p@ moduledir = @moduledir@ oldincludedir = @oldincludedir@ pdfdir = @pdfdir@ pkgconfigdir = @pkgconfigdir@ prefix = @prefix@ program_transform_name = @program_transform_name@ psdir = @psdir@ sbindir = @sbindir@ sharedstatedir = @sharedstatedir@ socketdir = @socketdir@ srcdir = @srcdir@ subdirs = @subdirs@ sysconfdir = @sysconfdir@ systemdsystemunitdir = @systemdsystemunitdir@ target_alias = @target_alias@ top_build_prefix = @top_build_prefix@ top_builddir = @top_builddir@ top_srcdir = @top_srcdir@ startscriptdir = $(sysconfdir)/default dist_startscript_DATA = xrdp all: all-am .SUFFIXES: $(srcdir)/Makefile.in: $(srcdir)/Makefile.am $(am__configure_deps) @for dep in $?; do \ case '$(am__configure_deps)' in \ *$$dep*) \ ( cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh ) \ && { if test -f $@; then exit 0; else break; fi; }; \ exit 1;; \ esac; \ done; \ echo ' cd $(top_srcdir) && $(AUTOMAKE) --foreign instfiles/default/Makefile'; \ $(am__cd) $(top_srcdir) && \ $(AUTOMAKE) --foreign instfiles/default/Makefile Makefile: $(srcdir)/Makefile.in $(top_builddir)/config.status @case '$?' in \ *config.status*) \ cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh;; \ *) \ echo ' cd $(top_builddir) && $(SHELL) ./config.status $(subdir)/$@ $(am__depfiles_maybe)'; \ cd $(top_builddir) && $(SHELL) ./config.status $(subdir)/$@ $(am__depfiles_maybe);; \ esac; $(top_builddir)/config.status: $(top_srcdir)/configure $(CONFIG_STATUS_DEPENDENCIES) cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh $(top_srcdir)/configure: $(am__configure_deps) cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh $(ACLOCAL_M4): $(am__aclocal_m4_deps) cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh $(am__aclocal_m4_deps): mostlyclean-libtool: -rm -f *.lo clean-libtool: -rm -rf .libs _libs install-dist_startscriptDATA: $(dist_startscript_DATA) @$(NORMAL_INSTALL) @list='$(dist_startscript_DATA)'; test -n "$(startscriptdir)" || list=; \ if test -n "$$list"; then \ echo " $(MKDIR_P) '$(DESTDIR)$(startscriptdir)'"; \ $(MKDIR_P) "$(DESTDIR)$(startscriptdir)" || exit 1; \ fi; \ for p in $$list; do \ if test -f "$$p"; then d=; else d="$(srcdir)/"; fi; \ echo "$$d$$p"; \ done | $(am__base_list) | \ while read files; do \ echo " $(INSTALL_DATA) $$files '$(DESTDIR)$(startscriptdir)'"; \ $(INSTALL_DATA) $$files "$(DESTDIR)$(startscriptdir)" || exit $$?; \ done uninstall-dist_startscriptDATA: @$(NORMAL_UNINSTALL) @list='$(dist_startscript_DATA)'; test -n "$(startscriptdir)" || list=; \ files=`for p in $$list; do echo $$p; done | sed -e 's|^.*/||'`; \ dir='$(DESTDIR)$(startscriptdir)'; $(am__uninstall_files_from_dir) tags TAGS: ctags CTAGS: cscope cscopelist: distdir: $(DISTFILES) @srcdirstrip=`echo "$(srcdir)" | sed 's/[].[^$$\\*]/\\\\&/g'`; \ topsrcdirstrip=`echo "$(top_srcdir)" | sed 's/[].[^$$\\*]/\\\\&/g'`; \ list='$(DISTFILES)'; \ dist_files=`for file in $$list; do echo $$file; done | \ sed -e "s|^$$srcdirstrip/||;t" \ -e "s|^$$topsrcdirstrip/|$(top_builddir)/|;t"`; \ case $$dist_files in \ */*) $(MKDIR_P) `echo "$$dist_files" | \ sed '/\//!d;s|^|$(distdir)/|;s,/[^/]*$$,,' | \ sort -u` ;; \ esac; \ for file in $$dist_files; do \ if test -f $$file || test -d $$file; then d=.; else d=$(srcdir); fi; \ if test -d $$d/$$file; then \ dir=`echo "/$$file" | sed -e 's,/[^/]*$$,,'`; \ if test -d "$(distdir)/$$file"; then \ find "$(distdir)/$$file" -type d ! -perm -700 -exec chmod u+rwx {} \;; \ fi; \ if test -d $(srcdir)/$$file && test $$d != $(srcdir); then \ cp -fpR $(srcdir)/$$file "$(distdir)$$dir" || exit 1; \ find "$(distdir)/$$file" -type d ! -perm -700 -exec chmod u+rwx {} \;; \ fi; \ cp -fpR $$d/$$file "$(distdir)$$dir" || exit 1; \ else \ test -f "$(distdir)/$$file" \ || cp -p $$d/$$file "$(distdir)/$$file" \ || exit 1; \ fi; \ done check-am: all-am check: check-am all-am: Makefile $(DATA) installdirs: for dir in "$(DESTDIR)$(startscriptdir)"; do \ test -z "$$dir" || $(MKDIR_P) "$$dir"; \ done install: install-am install-exec: install-exec-am install-data: install-data-am uninstall: uninstall-am install-am: all-am @$(MAKE) $(AM_MAKEFLAGS) install-exec-am install-data-am installcheck: installcheck-am install-strip: if test -z '$(STRIP)'; then \ $(MAKE) $(AM_MAKEFLAGS) INSTALL_PROGRAM="$(INSTALL_STRIP_PROGRAM)" \ install_sh_PROGRAM="$(INSTALL_STRIP_PROGRAM)" INSTALL_STRIP_FLAG=-s \ install; \ else \ $(MAKE) $(AM_MAKEFLAGS) INSTALL_PROGRAM="$(INSTALL_STRIP_PROGRAM)" \ install_sh_PROGRAM="$(INSTALL_STRIP_PROGRAM)" INSTALL_STRIP_FLAG=-s \ "INSTALL_PROGRAM_ENV=STRIPPROG='$(STRIP)'" install; \ fi mostlyclean-generic: clean-generic: distclean-generic: -test -z "$(CONFIG_CLEAN_FILES)" || rm -f $(CONFIG_CLEAN_FILES) -test . = "$(srcdir)" || test -z "$(CONFIG_CLEAN_VPATH_FILES)" || rm -f $(CONFIG_CLEAN_VPATH_FILES) maintainer-clean-generic: @echo "This command is intended for maintainers to use" @echo "it deletes files that may require special tools to rebuild." clean: clean-am clean-am: clean-generic clean-libtool mostlyclean-am distclean: distclean-am -rm -f Makefile distclean-am: clean-am distclean-generic dvi: dvi-am dvi-am: html: html-am html-am: info: info-am info-am: install-data-am: install-dist_startscriptDATA install-dvi: install-dvi-am install-dvi-am: install-exec-am: install-html: install-html-am install-html-am: install-info: install-info-am install-info-am: install-man: install-pdf: install-pdf-am install-pdf-am: install-ps: install-ps-am install-ps-am: installcheck-am: maintainer-clean: maintainer-clean-am -rm -f Makefile maintainer-clean-am: distclean-am maintainer-clean-generic mostlyclean: mostlyclean-am mostlyclean-am: mostlyclean-generic mostlyclean-libtool pdf: pdf-am pdf-am: ps: ps-am ps-am: uninstall-am: uninstall-dist_startscriptDATA .MAKE: install-am install-strip .PHONY: all all-am check check-am clean clean-generic clean-libtool \ cscopelist-am ctags-am distclean distclean-generic \ distclean-libtool distdir dvi dvi-am html html-am info info-am \ install install-am install-data install-data-am \ install-dist_startscriptDATA install-dvi install-dvi-am \ install-exec install-exec-am install-html install-html-am \ install-info install-info-am install-man install-pdf \ install-pdf-am install-ps install-ps-am install-strip \ installcheck installcheck-am installdirs maintainer-clean \ maintainer-clean-generic mostlyclean mostlyclean-generic \ mostlyclean-libtool pdf pdf-am ps ps-am tags-am uninstall \ uninstall-am uninstall-dist_startscriptDATA .PRECIOUS: Makefile # Tell versions [3.59,3.63) of GNU make to not export all variables. # Otherwise a system limit (for SysV at least) may be exceeded. .NOEXPORT: xrdp-0.9.5/instfiles/default/Makefile.am000644 001751 001751 00000000104 13127114621 020073 0ustar00metameta000000 000000 startscriptdir = $(sysconfdir)/default dist_startscript_DATA = xrdp xrdp-0.9.5/instfiles/rc.d/Makefile.am000644 001751 001751 00000000104 13127114621 017275 0ustar00metameta000000 000000 startscriptdir = $(sysconfdir)/rc.d dist_startscript_SCRIPTS = xrdp xrdp-0.9.5/instfiles/rc.d/Makefile.in000644 001751 001751 00000037534 13220730774 017336 0ustar00metameta000000 000000 # Makefile.in generated by automake 1.15.1 from Makefile.am. # @configure_input@ # Copyright (C) 1994-2017 Free Software Foundation, Inc. # This Makefile.in is free software; the Free Software Foundation # gives unlimited permission to copy and/or distribute it, # with or without modifications, as long as this notice is preserved. # This program is distributed in the hope that it will be useful, # but WITHOUT ANY WARRANTY, to the extent permitted by law; without # even the implied warranty of MERCHANTABILITY or FITNESS FOR A # PARTICULAR PURPOSE. @SET_MAKE@ VPATH = @srcdir@ am__is_gnu_make = { \ if test -z '$(MAKELEVEL)'; then \ false; \ elif test -n '$(MAKE_HOST)'; then \ true; \ elif test -n '$(MAKE_VERSION)' && test -n '$(CURDIR)'; then \ true; \ else \ false; \ fi; \ } am__make_running_with_option = \ case $${target_option-} in \ ?) ;; \ *) echo "am__make_running_with_option: internal error: invalid" \ "target option '$${target_option-}' specified" >&2; \ exit 1;; \ esac; \ has_opt=no; \ sane_makeflags=$$MAKEFLAGS; \ if $(am__is_gnu_make); then \ sane_makeflags=$$MFLAGS; \ else \ case $$MAKEFLAGS in \ *\\[\ \ ]*) \ bs=\\; \ sane_makeflags=`printf '%s\n' "$$MAKEFLAGS" \ | sed "s/$$bs$$bs[$$bs $$bs ]*//g"`;; \ esac; \ fi; \ skip_next=no; \ strip_trailopt () \ { \ flg=`printf '%s\n' "$$flg" | sed "s/$$1.*$$//"`; \ }; \ for flg in $$sane_makeflags; do \ test $$skip_next = yes && { skip_next=no; continue; }; \ case $$flg in \ *=*|--*) continue;; \ -*I) strip_trailopt 'I'; skip_next=yes;; \ -*I?*) strip_trailopt 'I';; \ -*O) strip_trailopt 'O'; skip_next=yes;; \ -*O?*) strip_trailopt 'O';; \ -*l) strip_trailopt 'l'; skip_next=yes;; \ -*l?*) strip_trailopt 'l';; \ -[dEDm]) skip_next=yes;; \ -[JT]) skip_next=yes;; \ esac; \ case $$flg in \ *$$target_option*) has_opt=yes; break;; \ esac; \ done; \ test $$has_opt = yes am__make_dryrun = (target_option=n; $(am__make_running_with_option)) am__make_keepgoing = (target_option=k; $(am__make_running_with_option)) pkgdatadir = $(datadir)/@PACKAGE@ pkgincludedir = $(includedir)/@PACKAGE@ pkglibdir = $(libdir)/@PACKAGE@ pkglibexecdir = $(libexecdir)/@PACKAGE@ am__cd = CDPATH="$${ZSH_VERSION+.}$(PATH_SEPARATOR)" && cd install_sh_DATA = $(install_sh) -c -m 644 install_sh_PROGRAM = $(install_sh) -c install_sh_SCRIPT = $(install_sh) -c INSTALL_HEADER = $(INSTALL_DATA) transform = $(program_transform_name) NORMAL_INSTALL = : PRE_INSTALL = : POST_INSTALL = : NORMAL_UNINSTALL = : PRE_UNINSTALL = : POST_UNINSTALL = : build_triplet = @build@ host_triplet = @host@ subdir = instfiles/rc.d ACLOCAL_M4 = $(top_srcdir)/aclocal.m4 am__aclocal_m4_deps = $(top_srcdir)/m4/ax_append_compile_flags.m4 \ $(top_srcdir)/m4/ax_append_flag.m4 \ $(top_srcdir)/m4/ax_cflags_warn_all.m4 \ $(top_srcdir)/m4/ax_check_compile_flag.m4 \ $(top_srcdir)/m4/ax_gcc_func_attribute.m4 \ $(top_srcdir)/m4/ax_require_defined.m4 \ $(top_srcdir)/m4/ax_type_socklen_t.m4 \ $(top_srcdir)/m4/libtool.m4 $(top_srcdir)/m4/ltoptions.m4 \ $(top_srcdir)/m4/ltsugar.m4 $(top_srcdir)/m4/ltversion.m4 \ $(top_srcdir)/m4/lt~obsolete.m4 $(top_srcdir)/m4/pkg.m4 \ $(top_srcdir)/configure.ac am__configure_deps = $(am__aclocal_m4_deps) $(CONFIGURE_DEPENDENCIES) \ $(ACLOCAL_M4) DIST_COMMON = $(srcdir)/Makefile.am $(dist_startscript_SCRIPTS) \ $(am__DIST_COMMON) mkinstalldirs = $(install_sh) -d CONFIG_HEADER = $(top_builddir)/config_ac.h CONFIG_CLEAN_FILES = CONFIG_CLEAN_VPATH_FILES = am__vpath_adj_setup = srcdirstrip=`echo "$(srcdir)" | sed 's|.|.|g'`; am__vpath_adj = case $$p in \ $(srcdir)/*) f=`echo "$$p" | sed "s|^$$srcdirstrip/||"`;; \ *) f=$$p;; \ esac; am__strip_dir = f=`echo $$p | sed -e 's|^.*/||'`; am__install_max = 40 am__nobase_strip_setup = \ srcdirstrip=`echo "$(srcdir)" | sed 's/[].[^$$\\*|]/\\\\&/g'` am__nobase_strip = \ for p in $$list; do echo "$$p"; done | sed -e "s|$$srcdirstrip/||" am__nobase_list = $(am__nobase_strip_setup); \ for p in $$list; do echo "$$p $$p"; done | \ sed "s| $$srcdirstrip/| |;"' / .*\//!s/ .*/ ./; s,\( .*\)/[^/]*$$,\1,' | \ $(AWK) 'BEGIN { files["."] = "" } { files[$$2] = files[$$2] " " $$1; \ if (++n[$$2] == $(am__install_max)) \ { print $$2, files[$$2]; n[$$2] = 0; files[$$2] = "" } } \ END { for (dir in files) print dir, files[dir] }' am__base_list = \ sed '$$!N;$$!N;$$!N;$$!N;$$!N;$$!N;$$!N;s/\n/ /g' | \ sed '$$!N;$$!N;$$!N;$$!N;s/\n/ /g' am__uninstall_files_from_dir = { \ test -z "$$files" \ || { test ! -d "$$dir" && test ! -f "$$dir" && test ! -r "$$dir"; } \ || { echo " ( cd '$$dir' && rm -f" $$files ")"; \ $(am__cd) "$$dir" && rm -f $$files; }; \ } am__installdirs = "$(DESTDIR)$(startscriptdir)" SCRIPTS = $(dist_startscript_SCRIPTS) AM_V_P = $(am__v_P_@AM_V@) am__v_P_ = $(am__v_P_@AM_DEFAULT_V@) am__v_P_0 = false am__v_P_1 = : AM_V_GEN = $(am__v_GEN_@AM_V@) am__v_GEN_ = $(am__v_GEN_@AM_DEFAULT_V@) am__v_GEN_0 = @echo " GEN " $@; am__v_GEN_1 = AM_V_at = $(am__v_at_@AM_V@) am__v_at_ = $(am__v_at_@AM_DEFAULT_V@) am__v_at_0 = @ am__v_at_1 = SOURCES = DIST_SOURCES = am__can_run_installinfo = \ case $$AM_UPDATE_INFO_DIR in \ n|no|NO) false;; \ *) (install-info --version) >/dev/null 2>&1;; \ esac am__tagged_files = $(HEADERS) $(SOURCES) $(TAGS_FILES) $(LISP) am__DIST_COMMON = $(srcdir)/Makefile.in DISTFILES = $(DIST_COMMON) $(DIST_SOURCES) $(TEXINFOS) $(EXTRA_DIST) ACLOCAL = @ACLOCAL@ AMTAR = @AMTAR@ AM_DEFAULT_VERBOSITY = @AM_DEFAULT_VERBOSITY@ AR = @AR@ AUTOCONF = @AUTOCONF@ AUTOHEADER = @AUTOHEADER@ AUTOMAKE = @AUTOMAKE@ AWK = @AWK@ CC = @CC@ CCDEPMODE = @CCDEPMODE@ CFLAGS = @CFLAGS@ CPP = @CPP@ CPPFLAGS = @CPPFLAGS@ CYGPATH_W = @CYGPATH_W@ DEFS = @DEFS@ DEPDIR = @DEPDIR@ DLLTOOL = @DLLTOOL@ DLOPEN_LIBS = @DLOPEN_LIBS@ DSYMUTIL = @DSYMUTIL@ DUMPBIN = @DUMPBIN@ ECHO_C = @ECHO_C@ ECHO_N = @ECHO_N@ ECHO_T = @ECHO_T@ EGREP = @EGREP@ EXEEXT = @EXEEXT@ FDKAAC_CFLAGS = @FDKAAC_CFLAGS@ FDKAAC_LIBS = @FDKAAC_LIBS@ FGREP = @FGREP@ FREERDP_CFLAGS = @FREERDP_CFLAGS@ FREERDP_LIBS = @FREERDP_LIBS@ FUSE_CFLAGS = @FUSE_CFLAGS@ FUSE_LIBS = @FUSE_LIBS@ GREP = @GREP@ INSTALL = @INSTALL@ INSTALL_DATA = @INSTALL_DATA@ INSTALL_PROGRAM = @INSTALL_PROGRAM@ INSTALL_SCRIPT = @INSTALL_SCRIPT@ INSTALL_STRIP_PROGRAM = @INSTALL_STRIP_PROGRAM@ LD = @LD@ LDFLAGS = @LDFLAGS@ LIBOBJS = @LIBOBJS@ LIBS = @LIBS@ LIBTOOL = @LIBTOOL@ LIPO = @LIPO@ LN_S = @LN_S@ LTLIBOBJS = @LTLIBOBJS@ LT_SYS_LIBRARY_PATH = @LT_SYS_LIBRARY_PATH@ MAKEINFO = @MAKEINFO@ MANIFEST_TOOL = @MANIFEST_TOOL@ MKDIR_P = @MKDIR_P@ NM = @NM@ NMEDIT = @NMEDIT@ OBJDUMP = @OBJDUMP@ OBJEXT = @OBJEXT@ OPENSSL = @OPENSSL@ OPENSSL_CFLAGS = @OPENSSL_CFLAGS@ OPENSSL_LIBS = @OPENSSL_LIBS@ OTOOL = @OTOOL@ OTOOL64 = @OTOOL64@ PACKAGE = @PACKAGE@ PACKAGE_BUGREPORT = @PACKAGE_BUGREPORT@ PACKAGE_NAME = @PACKAGE_NAME@ PACKAGE_STRING = @PACKAGE_STRING@ PACKAGE_TARNAME = @PACKAGE_TARNAME@ PACKAGE_URL = @PACKAGE_URL@ PACKAGE_VERSION = @PACKAGE_VERSION@ PAM_RULES = @PAM_RULES@ PATH_SEPARATOR = @PATH_SEPARATOR@ PIXMAN_CFLAGS = @PIXMAN_CFLAGS@ PIXMAN_LIBS = @PIXMAN_LIBS@ PKG_CONFIG = @PKG_CONFIG@ PKG_CONFIG_LIBDIR = @PKG_CONFIG_LIBDIR@ PKG_CONFIG_PATH = @PKG_CONFIG_PATH@ RANLIB = @RANLIB@ SED = @SED@ SET_MAKE = @SET_MAKE@ SHELL = @SHELL@ STRIP = @STRIP@ TurboJpegIncDir = @TurboJpegIncDir@ TurboJpegLibDir = @TurboJpegLibDir@ VERSION = @VERSION@ XMKMF = @XMKMF@ X_CFLAGS = @X_CFLAGS@ X_EXTRA_LIBS = @X_EXTRA_LIBS@ X_LIBS = @X_LIBS@ X_PRE_LIBS = @X_PRE_LIBS@ abs_builddir = @abs_builddir@ abs_srcdir = @abs_srcdir@ abs_top_builddir = @abs_top_builddir@ abs_top_srcdir = @abs_top_srcdir@ ac_ct_AR = @ac_ct_AR@ ac_ct_CC = @ac_ct_CC@ ac_ct_DUMPBIN = @ac_ct_DUMPBIN@ am__include = @am__include@ am__leading_dot = @am__leading_dot@ am__quote = @am__quote@ am__tar = @am__tar@ am__untar = @am__untar@ bindir = @bindir@ build = @build@ build_alias = @build_alias@ build_cpu = @build_cpu@ build_os = @build_os@ build_vendor = @build_vendor@ builddir = @builddir@ datadir = @datadir@ datarootdir = @datarootdir@ docdir = @docdir@ dvidir = @dvidir@ exec_prefix = @exec_prefix@ host = @host@ host_alias = @host_alias@ host_cpu = @host_cpu@ host_os = @host_os@ host_vendor = @host_vendor@ htmldir = @htmldir@ includedir = @includedir@ infodir = @infodir@ install_sh = @install_sh@ libdir = @libdir@ libexecdir = @libexecdir@ localedir = @localedir@ localstatedir = @localstatedir@ mandir = @mandir@ mkdir_p = @mkdir_p@ moduledir = @moduledir@ oldincludedir = @oldincludedir@ pdfdir = @pdfdir@ pkgconfigdir = @pkgconfigdir@ prefix = @prefix@ program_transform_name = @program_transform_name@ psdir = @psdir@ sbindir = @sbindir@ sharedstatedir = @sharedstatedir@ socketdir = @socketdir@ srcdir = @srcdir@ subdirs = @subdirs@ sysconfdir = @sysconfdir@ systemdsystemunitdir = @systemdsystemunitdir@ target_alias = @target_alias@ top_build_prefix = @top_build_prefix@ top_builddir = @top_builddir@ top_srcdir = @top_srcdir@ startscriptdir = $(sysconfdir)/rc.d dist_startscript_SCRIPTS = xrdp all: all-am .SUFFIXES: $(srcdir)/Makefile.in: $(srcdir)/Makefile.am $(am__configure_deps) @for dep in $?; do \ case '$(am__configure_deps)' in \ *$$dep*) \ ( cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh ) \ && { if test -f $@; then exit 0; else break; fi; }; \ exit 1;; \ esac; \ done; \ echo ' cd $(top_srcdir) && $(AUTOMAKE) --foreign instfiles/rc.d/Makefile'; \ $(am__cd) $(top_srcdir) && \ $(AUTOMAKE) --foreign instfiles/rc.d/Makefile Makefile: $(srcdir)/Makefile.in $(top_builddir)/config.status @case '$?' in \ *config.status*) \ cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh;; \ *) \ echo ' cd $(top_builddir) && $(SHELL) ./config.status $(subdir)/$@ $(am__depfiles_maybe)'; \ cd $(top_builddir) && $(SHELL) ./config.status $(subdir)/$@ $(am__depfiles_maybe);; \ esac; $(top_builddir)/config.status: $(top_srcdir)/configure $(CONFIG_STATUS_DEPENDENCIES) cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh $(top_srcdir)/configure: $(am__configure_deps) cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh $(ACLOCAL_M4): $(am__aclocal_m4_deps) cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh $(am__aclocal_m4_deps): install-dist_startscriptSCRIPTS: $(dist_startscript_SCRIPTS) @$(NORMAL_INSTALL) @list='$(dist_startscript_SCRIPTS)'; test -n "$(startscriptdir)" || list=; \ if test -n "$$list"; then \ echo " $(MKDIR_P) '$(DESTDIR)$(startscriptdir)'"; \ $(MKDIR_P) "$(DESTDIR)$(startscriptdir)" || exit 1; \ fi; \ for p in $$list; do \ if test -f "$$p"; then d=; else d="$(srcdir)/"; fi; \ if test -f "$$d$$p"; then echo "$$d$$p"; echo "$$p"; else :; fi; \ done | \ sed -e 'p;s,.*/,,;n' \ -e 'h;s|.*|.|' \ -e 'p;x;s,.*/,,;$(transform)' | sed 'N;N;N;s,\n, ,g' | \ $(AWK) 'BEGIN { files["."] = ""; dirs["."] = 1; } \ { d=$$3; if (dirs[d] != 1) { print "d", d; dirs[d] = 1 } \ if ($$2 == $$4) { files[d] = files[d] " " $$1; \ if (++n[d] == $(am__install_max)) { \ print "f", d, files[d]; n[d] = 0; files[d] = "" } } \ else { print "f", d "/" $$4, $$1 } } \ END { for (d in files) print "f", d, files[d] }' | \ while read type dir files; do \ if test "$$dir" = .; then dir=; else dir=/$$dir; fi; \ test -z "$$files" || { \ echo " $(INSTALL_SCRIPT) $$files '$(DESTDIR)$(startscriptdir)$$dir'"; \ $(INSTALL_SCRIPT) $$files "$(DESTDIR)$(startscriptdir)$$dir" || exit $$?; \ } \ ; done uninstall-dist_startscriptSCRIPTS: @$(NORMAL_UNINSTALL) @list='$(dist_startscript_SCRIPTS)'; test -n "$(startscriptdir)" || exit 0; \ files=`for p in $$list; do echo "$$p"; done | \ sed -e 's,.*/,,;$(transform)'`; \ dir='$(DESTDIR)$(startscriptdir)'; $(am__uninstall_files_from_dir) mostlyclean-libtool: -rm -f *.lo clean-libtool: -rm -rf .libs _libs tags TAGS: ctags CTAGS: cscope cscopelist: distdir: $(DISTFILES) @srcdirstrip=`echo "$(srcdir)" | sed 's/[].[^$$\\*]/\\\\&/g'`; \ topsrcdirstrip=`echo "$(top_srcdir)" | sed 's/[].[^$$\\*]/\\\\&/g'`; \ list='$(DISTFILES)'; \ dist_files=`for file in $$list; do echo $$file; done | \ sed -e "s|^$$srcdirstrip/||;t" \ -e "s|^$$topsrcdirstrip/|$(top_builddir)/|;t"`; \ case $$dist_files in \ */*) $(MKDIR_P) `echo "$$dist_files" | \ sed '/\//!d;s|^|$(distdir)/|;s,/[^/]*$$,,' | \ sort -u` ;; \ esac; \ for file in $$dist_files; do \ if test -f $$file || test -d $$file; then d=.; else d=$(srcdir); fi; \ if test -d $$d/$$file; then \ dir=`echo "/$$file" | sed -e 's,/[^/]*$$,,'`; \ if test -d "$(distdir)/$$file"; then \ find "$(distdir)/$$file" -type d ! -perm -700 -exec chmod u+rwx {} \;; \ fi; \ if test -d $(srcdir)/$$file && test $$d != $(srcdir); then \ cp -fpR $(srcdir)/$$file "$(distdir)$$dir" || exit 1; \ find "$(distdir)/$$file" -type d ! -perm -700 -exec chmod u+rwx {} \;; \ fi; \ cp -fpR $$d/$$file "$(distdir)$$dir" || exit 1; \ else \ test -f "$(distdir)/$$file" \ || cp -p $$d/$$file "$(distdir)/$$file" \ || exit 1; \ fi; \ done check-am: all-am check: check-am all-am: Makefile $(SCRIPTS) installdirs: for dir in "$(DESTDIR)$(startscriptdir)"; do \ test -z "$$dir" || $(MKDIR_P) "$$dir"; \ done install: install-am install-exec: install-exec-am install-data: install-data-am uninstall: uninstall-am install-am: all-am @$(MAKE) $(AM_MAKEFLAGS) install-exec-am install-data-am installcheck: installcheck-am install-strip: if test -z '$(STRIP)'; then \ $(MAKE) $(AM_MAKEFLAGS) INSTALL_PROGRAM="$(INSTALL_STRIP_PROGRAM)" \ install_sh_PROGRAM="$(INSTALL_STRIP_PROGRAM)" INSTALL_STRIP_FLAG=-s \ install; \ else \ $(MAKE) $(AM_MAKEFLAGS) INSTALL_PROGRAM="$(INSTALL_STRIP_PROGRAM)" \ install_sh_PROGRAM="$(INSTALL_STRIP_PROGRAM)" INSTALL_STRIP_FLAG=-s \ "INSTALL_PROGRAM_ENV=STRIPPROG='$(STRIP)'" install; \ fi mostlyclean-generic: clean-generic: distclean-generic: -test -z "$(CONFIG_CLEAN_FILES)" || rm -f $(CONFIG_CLEAN_FILES) -test . = "$(srcdir)" || test -z "$(CONFIG_CLEAN_VPATH_FILES)" || rm -f $(CONFIG_CLEAN_VPATH_FILES) maintainer-clean-generic: @echo "This command is intended for maintainers to use" @echo "it deletes files that may require special tools to rebuild." clean: clean-am clean-am: clean-generic clean-libtool mostlyclean-am distclean: distclean-am -rm -f Makefile distclean-am: clean-am distclean-generic dvi: dvi-am dvi-am: html: html-am html-am: info: info-am info-am: install-data-am: install-dist_startscriptSCRIPTS install-dvi: install-dvi-am install-dvi-am: install-exec-am: install-html: install-html-am install-html-am: install-info: install-info-am install-info-am: install-man: install-pdf: install-pdf-am install-pdf-am: install-ps: install-ps-am install-ps-am: installcheck-am: maintainer-clean: maintainer-clean-am -rm -f Makefile maintainer-clean-am: distclean-am maintainer-clean-generic mostlyclean: mostlyclean-am mostlyclean-am: mostlyclean-generic mostlyclean-libtool pdf: pdf-am pdf-am: ps: ps-am ps-am: uninstall-am: uninstall-dist_startscriptSCRIPTS .MAKE: install-am install-strip .PHONY: all all-am check check-am clean clean-generic clean-libtool \ cscopelist-am ctags-am distclean distclean-generic \ distclean-libtool distdir dvi dvi-am html html-am info info-am \ install install-am install-data install-data-am \ install-dist_startscriptSCRIPTS install-dvi install-dvi-am \ install-exec install-exec-am install-html install-html-am \ install-info install-info-am install-man install-pdf \ install-pdf-am install-ps install-ps-am install-strip \ installcheck installcheck-am installdirs maintainer-clean \ maintainer-clean-generic mostlyclean mostlyclean-generic \ mostlyclean-libtool pdf pdf-am ps ps-am tags-am uninstall \ uninstall-am uninstall-dist_startscriptSCRIPTS .PRECIOUS: Makefile # Tell versions [3.59,3.63) of GNU make to not export all variables. # Otherwise a system limit (for SysV at least) may be exceeded. .NOEXPORT: xrdp-0.9.5/instfiles/rc.d/xrdp000644 001751 001751 00000004751 13127114621 016155 0ustar00metameta000000 000000 #!/bin/sh # # Copyright (c) 1992-2015 The FreeBSD Project. All rights reserved. # # 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. # # THIS SOFTWARE IS PROVIDED BY THE AUTHOR AND CONTRIBUTORS ``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 OR CONTRIBUTORS 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. # # $FreeBSD$ # # REQUIRE: DAEMON # PROVIDE: xrdp xrdp_sesman # . /etc/rc.subr name="xrdp" rcvar=xrdp_enable xrdp_daemons="xrdp" # Read settings and set default values. load_rc_config "$name" : ${xrdp_enable="NO"} # Enable/disable dependent daemon. if [ -n "${rcvar}" ] && checkyesno "xrdp_sesman_enable"; then xrdp_daemons="xrdp xrdp_sesman" fi # Commands. extra_commands="reload status" start_cmd="xrdp_cmd" stop_cmd="xrdp_cmd" status_cmd="xrdp_cmd" reload_cmd="xrdp_cmd" rcvar_cmd="xrdp_cmd" # Command wrapper to call each of them per daemon. xrdp_cmd() { local name rcvar command pidfile xrdp_daemons # Prevent recursive calling. unset "${rc_arg}_cmd" # Stop processes in the reverse to order. if [ "${rc_arg}" = "stop" ] ; then xrdp_daemons=$(reverse_list ${xrdp_daemons}) fi # Apply to all the daemons. for name in ${xrdp_daemons}; do rcvar=${name}_enable if [ "${name}" = "xrdp_sesman" ]; then command="%%PREFIX%%/sbin/xrdp-sesman" pidfile="/var/run/xrdp-sesman.pid" else command="%%PREFIX%%/sbin/${name}" pidfile="/var/run/${name}.pid" fi run_rc_command "${_rc_prefix}${rc_arg}" ${rc_extra_args} done } run_rc_command "$1" xrdp-0.9.5/neutrinordp/xrdp-neutrinordp.c000644 001751 001751 00000207036 13220727201 020467 0ustar00metameta000000 000000 /** * FreeRDP: A Remote Desktop Protocol Server * freerdp wrapper * * Copyright 2011-2013 Jay Sorg * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ #if defined(HAVE_CONFIG_H) #include #endif #include "xrdp-neutrinordp.h" #include "xrdp-color.h" #include "xrdp_rail.h" #include "log.h" #include #ifdef XRDP_DEBUG #define LOG_LEVEL 99 #else #define LOG_LEVEL 1 #endif #define LLOG(_level, _args) \ do { if (_level < LOG_LEVEL) { g_write _args ; } } while (0) #define LLOGLN(_level, _args) \ do { if (_level < LOG_LEVEL) { g_writeln _args ; } } while (0) struct mod_context { rdpContext _p; struct mod *modi; }; typedef struct mod_context modContext; /*****************************************************************************/ static void verifyColorMap(struct mod *mod) { int i; for (i = 0; i < 255; i++) { if (mod->colormap[i] != 0) { return ; } } LLOGLN(0, ("The colormap is all NULL")); } /*****************************************************************************/ /* return error */ static int lxrdp_start(struct mod *mod, int w, int h, int bpp) { rdpSettings *settings; LLOGLN(10, ("lxrdp_start: w %d h %d bpp %d", w, h, bpp)); settings = mod->inst->settings; settings->width = w; settings->height = h; settings->color_depth = bpp; mod->bpp = bpp; settings->encryption = 1; settings->tls_security = 1; settings->nla_security = 0; settings->rdp_security = 1; return 0; } /******************************************************************************/ /* return error */ static int lxrdp_connect(struct mod *mod) { boolean ok; LLOGLN(10, ("lxrdp_connect:")); ok = freerdp_connect(mod->inst); LLOGLN(0, ("lxrdp_connect: freerdp_connect returned %d", ok)); if (!ok) { LLOGLN(0, ("Failure to connect")); #ifdef ERRORSTART if (connectErrorCode != 0) { char buf[128]; if (connectErrorCode < ERRORSTART) { if (strerror_r(connectErrorCode, buf, 128) != 0) { g_snprintf(buf, 128, "Errorcode from connect : %d", connectErrorCode); } } else { switch (connectErrorCode) { case PREECONNECTERROR: g_snprintf(buf, 128, "The error code from connect is " "PREECONNECTERROR"); break; case UNDEFINEDCONNECTERROR: g_snprintf(buf, 128, "The error code from connect is " "UNDEFINEDCONNECTERROR"); break; case POSTCONNECTERROR: g_snprintf(buf, 128, "The error code from connect is " "POSTCONNECTERROR"); break; case DNSERROR: g_snprintf(buf, 128, "The DNS system generated an error"); break; case DNSNAMENOTFOUND: g_snprintf(buf, 128, "The DNS system could not find the " "specified name"); break; case CONNECTERROR: g_snprintf(buf, 128, "A general connect error was returned"); break; case MCSCONNECTINITIALERROR: g_snprintf(buf, 128, "The error code from connect is " "MCSCONNECTINITIALERROR"); break; case TLSCONNECTERROR: g_snprintf(buf, 128, "Error in TLS handshake"); break; case AUTHENTICATIONERROR: g_snprintf(buf, 128, "Authentication error check your password " "and username"); break; case INSUFFICIENTPRIVILEGESERROR: g_snprintf(buf, 128, "Insufficent privileges on target server"); break; default: g_snprintf(buf, 128, "Unhandled Errorcode from connect : %d", connectErrorCode); break; } } log_message(LOG_LEVEL_INFO, buf); mod->server_msg(mod, buf, 0); } #endif log_message(LOG_LEVEL_INFO, "freerdp_connect Failed to " "destination :%s:%d", mod->inst->settings->hostname, mod->inst->settings->port); return 1; } else { log_message(LOG_LEVEL_INFO, "freerdp_connect returned Success to " "destination :%s:%d", mod->inst->settings->hostname, mod->inst->settings->port); } return 0; } /******************************************************************************/ /* return error */ static int lxrdp_event(struct mod *mod, int msg, long param1, long param2, long param3, long param4) { int x; int y; int cx; int cy; int flags; int size; int total_size; int chanid; int lchid; char *data; LLOGLN(12, ("lxrdp_event: msg %d", msg)); switch (msg) { case 15: /* key down */ /* Before we handle the first character we synchronize capslock and numlock. */ /* We collect the state during the first synchronize ( see msg 17) */ if (!mod->bool_keyBoardSynced) { LLOGLN(11, ("Additional Sync event handled : %d", mod->keyBoardLockInfo)); mod->inst->input->SynchronizeEvent(mod->inst->input, mod->keyBoardLockInfo); mod->bool_keyBoardSynced = 1; } mod->inst->input->KeyboardEvent(mod->inst->input, param4, param3); break; case 16: /* key up */ mod->inst->input->KeyboardEvent(mod->inst->input, param4, param3); break; case 17: /* Synchronize */ LLOGLN(11, ("Synchronized event handled : %ld", param1)); /* In some situations the Synchronize event come to early. Therefore we store this information and use it when we receive the first keyboard event Without this fix numlock and capslock can come out of sync. */ mod->inst->input->SynchronizeEvent(mod->inst->input, param1); if (!mod->bool_keyBoardSynced) { mod->keyBoardLockInfo = param1; } break; case 100: /* mouse move */ LLOGLN(12, ("mouse move %ld %ld", param1, param2)); x = param1; y = param2; flags = PTR_FLAGS_MOVE; mod->inst->input->MouseEvent(mod->inst->input, flags, x, y); break; case 101: /* left button up */ LLOGLN(12, ("left button up %ld %ld", param1, param2)); x = param1; y = param2; flags = PTR_FLAGS_BUTTON1; mod->inst->input->MouseEvent(mod->inst->input, flags, x, y); break; case 102: /* left button down */ LLOGLN(12, ("left button down %ld %ld", param1, param2)); x = param1; y = param2; flags = PTR_FLAGS_BUTTON1 | PTR_FLAGS_DOWN; mod->inst->input->MouseEvent(mod->inst->input, flags, x, y); break; case 103: /* right button up */ LLOGLN(12, ("right button up %ld %ld", param1, param2)); x = param1; y = param2; flags = PTR_FLAGS_BUTTON2; mod->inst->input->MouseEvent(mod->inst->input, flags, x, y); break; case 104: /* right button down */ LLOGLN(12, ("right button down %ld %ld", param1, param2)); x = param1; y = param2; flags = PTR_FLAGS_BUTTON2 | PTR_FLAGS_DOWN; mod->inst->input->MouseEvent(mod->inst->input, flags, x, y); break; case 105: /* middle button up */ LLOGLN(12, ("middle button up %ld %ld", param1, param2)); x = param1; y = param2; flags = PTR_FLAGS_BUTTON3; mod->inst->input->MouseEvent(mod->inst->input, flags, x, y); break; case 106: /* middle button down */ LLOGLN(12, ("middle button down %ld %ld", param1, param2)); x = param1; y = param2; flags = PTR_FLAGS_BUTTON3 | PTR_FLAGS_DOWN; mod->inst->input->MouseEvent(mod->inst->input, flags, x, y); break; case 107: /* wheel up */ flags = PTR_FLAGS_WHEEL | 0x0078; mod->inst->input->MouseEvent(mod->inst->input, flags, 0, 0); break; case 108: break; case 109: /* wheel down */ flags = PTR_FLAGS_WHEEL | PTR_FLAGS_WHEEL_NEGATIVE | 0x0088; mod->inst->input->MouseEvent(mod->inst->input, flags, 0, 0); break; case 110: break; case 200: LLOGLN(10, ("Invalidate request sent from client")); x = (param1 >> 16) & 0xffff; y = (param1 >> 0) & 0xffff; cx = (param2 >> 16) & 0xffff; cy = (param2 >> 0) & 0xffff; mod->inst->SendInvalidate(mod->inst, -1, x, y, cx, cy); break; case 0x5555: chanid = LOWORD(param1); flags = HIWORD(param1); size = (int)param2; data = (char *)param3; total_size = (int)param4; LLOGLN(12, ("lxrdp_event: client to server ,chanid= %d flags= %d", chanid, flags)); if ((chanid < 0) || (chanid >= mod->inst->settings->num_channels)) { LLOGLN(0, ("lxrdp_event: error chanid %d", chanid)); break; } lchid = mod->inst->settings->channels[chanid].channel_id; switch (flags & 3) { case 3: mod->inst->SendChannelData(mod->inst, lchid, (tui8 *)data, total_size); break; case 2: /* end */ g_memcpy(mod->chan_buf + mod->chan_buf_valid, data, size); mod->chan_buf_valid += size; mod->inst->SendChannelData(mod->inst, lchid, (tui8 *)(mod->chan_buf), total_size); g_free(mod->chan_buf); mod->chan_buf = 0; mod->chan_buf_bytes = 0; mod->chan_buf_valid = 0; break; case 1: /* start */ g_free(mod->chan_buf); mod->chan_buf = (char *)g_malloc(total_size, 0); mod->chan_buf_bytes = total_size; mod->chan_buf_valid = 0; g_memcpy(mod->chan_buf + mod->chan_buf_valid, data, size); mod->chan_buf_valid += size; break; default: /* middle */ g_memcpy(mod->chan_buf + mod->chan_buf_valid, data, size); mod->chan_buf_valid += size; break; } break; default: LLOGLN(0, ("Unhandled message type in eventhandler %d", msg)); break; } return 0; } /******************************************************************************/ /* return error */ static int lxrdp_signal(struct mod *mod) { LLOGLN(10, ("lxrdp_signal:")); return 0; } /******************************************************************************/ /* return error */ static int lxrdp_end(struct mod *mod) { int i; int j; for (j = 0; j < 4; j++) { for (i = 0; i < 4096; i++) { g_free(mod->bitmap_cache[j][i].data); } } for (i = 0; i < 64; i++) { if (mod->brush_cache[i].data != mod->brush_cache[i].b8x8) { g_free(mod->brush_cache[i].data); } } LLOGLN(10, ("lxrdp_end:")); return 0; } /******************************************************************************/ /* return error */ static int lxrdp_set_param(struct mod *mod, const char *name, const char *value) { rdpSettings *settings; LLOGLN(10, ("lxrdp_set_param: name [%s] value [%s]", name, value)); settings = mod->inst->settings; if (g_strcmp(name, "hostname") == 0) { } else if (g_strcmp(name, "ip") == 0) { settings->hostname = g_strdup(value); } else if (g_strcmp(name, "port") == 0) { settings->port = g_atoi(value); } else if (g_strcmp(name, "keylayout") == 0) { } else if (g_strcmp(name, "name") == 0) { } else if (g_strcmp(name, "lib") == 0) { } else if (g_strcmp(name, "username") == 0) { g_strncpy(mod->username, value, 255); } else if (g_strcmp(name, "domain") == 0) { g_strncpy(mod->domain, value, 255); } else if (g_strcmp(name, "password") == 0) { g_strncpy(mod->password, value, 255); } else if (g_strcmp(name, "client_info") == 0) { g_memcpy(&(mod->client_info), value, sizeof(mod->client_info)); /* This is a Struct and cannot be printed in next else*/ LLOGLN(10, ("Client_info struct ignored")); } else if (g_strcmp(name, "program") == 0) { settings->shell = g_strdup(value); } else if (g_strcmp(name, "nla") == 0) { settings->nla_security = g_text2bool(value); } else { LLOGLN(0, ("lxrdp_set_param: unknown name [%s] value [%s]", name, value)); } return 0; } /******************************************************************************/ static int lxrdp_session_change(struct mod *mod, int a, int b) { LLOGLN(0, ("lxrdp_session_change: - no code here")); return 0; } /******************************************************************************/ static int lxrdp_get_wait_objs(struct mod *mod, tbus *read_objs, int *rcount, tbus *write_objs, int *wcount, int *timeout) { void **rfds; void **wfds; boolean ok; LLOGLN(12, ("lxrdp_get_wait_objs:")); rfds = (void **)read_objs; wfds = (void **)write_objs; ok = freerdp_get_fds(mod->inst, rfds, rcount, wfds, wcount); if (!ok) { LLOGLN(0, ("lxrdp_get_wait_objs: freerdp_get_fds failed")); return 1; } return 0; } /******************************************************************************/ static int lxrdp_check_wait_objs(struct mod *mod) { boolean ok; LLOGLN(12, ("lxrdp_check_wait_objs:")); ok = freerdp_check_fds(mod->inst); if (!ok) { LLOGLN(0, ("lxrdp_check_wait_objs: freerdp_check_fds failed")); return 1; } return 0; } /******************************************************************************/ static void lfreerdp_begin_paint(rdpContext *context) { struct mod *mod; LLOGLN(12, ("lfreerdp_begin_paint:")); mod = ((struct mod_context *)context)->modi; mod->server_begin_update(mod); } /******************************************************************************/ static void lfreerdp_end_paint(rdpContext *context) { struct mod *mod; LLOGLN(12, ("lfreerdp_end_paint:")); mod = ((struct mod_context *)context)->modi; mod->server_end_update(mod); } /******************************************************************************/ static void lfreerdp_set_bounds(rdpContext *context, rdpBounds *bounds) { struct mod *mod; int x; int y; int cx; int cy; LLOGLN(12, ("lfreerdp_set_bounds: %p", bounds)); mod = ((struct mod_context *)context)->modi; if (bounds != 0) { x = bounds->left; y = bounds->top; cx = (bounds->right - bounds->left) + 1; cy = (bounds->bottom - bounds->top) + 1; mod->server_set_clip(mod, x, y, cx, cy); } else { mod->server_reset_clip(mod); } } /******************************************************************************/ static void lfreerdp_bitmap_update(rdpContext *context, BITMAP_UPDATE *bitmap) { struct mod *mod; int index; int cx; int cy; int server_bpp; int server_Bpp; int client_bpp; int j; int line_bytes; BITMAP_DATA *bd; char *dst_data; char *dst_data1; char *src; char *dst; mod = ((struct mod_context *)context)->modi; LLOGLN(10, ("lfreerdp_bitmap_update: %d %d", bitmap->number, bitmap->count)); server_bpp = mod->inst->settings->color_depth; server_Bpp = (server_bpp + 7) / 8; client_bpp = mod->bpp; for (index = 0; index < bitmap->number; index++) { bd = &bitmap->rectangles[index]; cx = (bd->destRight - bd->destLeft) + 1; cy = (bd->destBottom - bd->destTop) + 1; line_bytes = server_Bpp * bd->width; dst_data = (char *)g_malloc(bd->height * line_bytes + 16, 0); if (bd->compressed) { LLOGLN(20, ("decompress size : %d", bd->bitmapLength)); if (!bitmap_decompress(bd->bitmapDataStream, (tui8 *)dst_data, bd->width, bd->height, bd->bitmapLength, server_bpp, server_bpp)) { LLOGLN(0, ("Failure to decompress the bitmap")); } } else { /* bitmap is upside down */ LLOGLN(10, ("bitmap upside down")); src = (char *)(bd->bitmapDataStream); dst = dst_data + bd->height * line_bytes; for (j = 0; j < bd->height; j++) { dst -= line_bytes; g_memcpy(dst, src, line_bytes); src += line_bytes; } } dst_data1 = convert_bitmap(server_bpp, client_bpp, dst_data, bd->width, bd->height, mod->colormap); mod->server_paint_rect(mod, bd->destLeft, bd->destTop, cx, cy, dst_data1, bd->width, bd->height, 0, 0); if (dst_data1 != dst_data) { g_free(dst_data1); } g_free(dst_data); } } /******************************************************************************/ static void lfreerdp_dst_blt(rdpContext *context, DSTBLT_ORDER *dstblt) { struct mod *mod; mod = ((struct mod_context *)context)->modi; LLOGLN(10, ("lfreerdp_dst_blt:")); mod->server_set_opcode(mod, dstblt->bRop); mod->server_fill_rect(mod, dstblt->nLeftRect, dstblt->nTopRect, dstblt->nWidth, dstblt->nHeight); mod->server_set_opcode(mod, 0xcc); } /******************************************************************************/ static void lfreerdp_pat_blt(rdpContext *context, PATBLT_ORDER *patblt) { struct mod *mod; int idx; int fgcolor; int bgcolor; int server_bpp; int client_bpp; struct brush_item *bi; mod = ((struct mod_context *)context)->modi; LLOGLN(10, ("lfreerdp_pat_blt:")); server_bpp = mod->inst->settings->color_depth; client_bpp = mod->bpp; LLOGLN(10, ("lfreerdp_pat_blt: bpp %d %d", server_bpp, client_bpp)); fgcolor = convert_color(server_bpp, client_bpp, patblt->foreColor, mod->colormap); bgcolor = convert_color(server_bpp, client_bpp, patblt->backColor, mod->colormap); LLOGLN(10, ("lfreerdp_pat_blt: nLeftRect %d nTopRect %d " "nWidth %d nHeight %d fgcolor 0x%8.8x bgcolor 0x%8.8x", patblt->nLeftRect, patblt->nTopRect, patblt->nWidth, patblt->nHeight, fgcolor, bgcolor)); if (fgcolor == bgcolor) { LLOGLN(0, ("Warning same color on both bg and fg")); } mod->server_set_mixmode(mod, 1); mod->server_set_opcode(mod, patblt->bRop); mod->server_set_fgcolor(mod, fgcolor); mod->server_set_bgcolor(mod, bgcolor); if (patblt->brush.style & 0x80) { idx = patblt->brush.hatch; if ((idx < 0) || (idx >= 64)) { LLOGLN(0, ("lfreerdp_pat_blt: error")); return; } bi = mod->brush_cache + idx; mod->server_set_brush(mod, patblt->brush.x, patblt->brush.y, 3, bi->b8x8); } else { mod->server_set_brush(mod, patblt->brush.x, patblt->brush.y, patblt->brush.style, (char *)(patblt->brush.p8x8)); } mod->server_fill_rect(mod, patblt->nLeftRect, patblt->nTopRect, patblt->nWidth, patblt->nHeight); mod->server_set_opcode(mod, 0xcc); mod->server_set_mixmode(mod, 0); } /******************************************************************************/ static void lfreerdp_scr_blt(rdpContext *context, SCRBLT_ORDER *scrblt) { struct mod *mod; mod = ((struct mod_context *)context)->modi; LLOGLN(10, ("lfreerdp_scr_blt:")); mod->server_set_opcode(mod, scrblt->bRop); mod->server_screen_blt(mod, scrblt->nLeftRect, scrblt->nTopRect, scrblt->nWidth, scrblt->nHeight, scrblt->nXSrc, scrblt->nYSrc); mod->server_set_opcode(mod, 0xcc); } /******************************************************************************/ static void lfreerdp_opaque_rect(rdpContext *context, OPAQUE_RECT_ORDER *opaque_rect) { struct mod *mod; int server_bpp; int client_bpp; int fgcolor; mod = ((struct mod_context *)context)->modi; LLOGLN(10, ("lfreerdp_opaque_rect:")); server_bpp = mod->inst->settings->color_depth; client_bpp = mod->bpp; fgcolor = convert_color(server_bpp, client_bpp, opaque_rect->color, mod->colormap); LLOGLN(10, ("lfreerdp_opaque_rect: nLeftRect %d nTopRect %d " "nWidth %d nHeight %d fgcolor 0x%8.8x", opaque_rect->nLeftRect, opaque_rect->nTopRect, opaque_rect->nWidth, opaque_rect->nHeight, fgcolor)); mod->server_set_fgcolor(mod, fgcolor); mod->server_fill_rect(mod, opaque_rect->nLeftRect, opaque_rect->nTopRect, opaque_rect->nWidth, opaque_rect->nHeight); } /******************************************************************************/ static void lfreerdp_mem_blt(rdpContext *context, MEMBLT_ORDER *memblt) { int id; int idx; struct mod *mod; struct bitmap_item *bi; mod = ((struct mod_context *)context)->modi; LLOGLN(12, ("lfreerdp_mem_blt: cacheId %d cacheIndex %d", memblt->cacheId, memblt->cacheIndex)); id = memblt->cacheId; idx = memblt->cacheIndex; if (idx == 32767) /* BITMAPCACHE_WAITING_LIST_INDEX */ { idx = 4096 - 1; } if ((id < 0) || (id >= 4)) { LLOGLN(0, ("lfreerdp_mem_blt: bad id [%d]", id)); return; } if ((idx < 0) || (idx >= 4096)) { LLOGLN(0, ("lfreerdp_mem_blt: bad idx [%d]", idx)); return; } bi = &(mod->bitmap_cache[id][idx]); mod->server_set_opcode(mod, memblt->bRop); mod->server_paint_rect(mod, memblt->nLeftRect, memblt->nTopRect, memblt->nWidth, memblt->nHeight, bi->data, bi->width, bi->height, memblt->nXSrc, memblt->nYSrc); mod->server_set_opcode(mod, 0xcc); } /******************************************************************************/ static void lfreerdp_glyph_index(rdpContext *context, GLYPH_INDEX_ORDER *glyph_index) { struct mod *mod; int server_bpp; int client_bpp; int fgcolor; int bgcolor; int opLeft; int opTop; int opRight; int opBottom; mod = ((struct mod_context *)context)->modi; LLOGLN(10, ("lfreerdp_glyph_index:")); server_bpp = mod->inst->settings->color_depth; client_bpp = mod->bpp; fgcolor = convert_color(server_bpp, client_bpp, glyph_index->foreColor, mod->colormap); bgcolor = convert_color(server_bpp, client_bpp, glyph_index->backColor, mod->colormap); LLOGLN(10, ("lfreerdp_glyph_index: " "bkLeft %d bkTop %d width %d height %d " "opLeft %d opTop %d width %d height %d " "cbData %d fgcolor 0x%8.8x bgcolor 0x%8.8x fOpRedundant %d", glyph_index->bkLeft, glyph_index->bkTop, glyph_index->bkRight - glyph_index->bkLeft, glyph_index->bkBottom - glyph_index->bkTop, glyph_index->opLeft, glyph_index->opTop, glyph_index->opRight - glyph_index->opLeft, glyph_index->opBottom - glyph_index->opTop, glyph_index->cbData, fgcolor, bgcolor, glyph_index->fOpRedundant)); mod->server_set_bgcolor(mod, fgcolor); mod->server_set_fgcolor(mod, bgcolor); opLeft = glyph_index->opLeft; opTop = glyph_index->opTop; opRight = glyph_index->opRight; opBottom = glyph_index->opBottom; #if 1 /* workarounds for freerdp not using fOpRedundant in glyph.c::update_gdi_glyph_index */ if (glyph_index->fOpRedundant) { opLeft = glyph_index->bkLeft; opTop = glyph_index->bkTop; opRight = glyph_index->bkRight; opBottom = glyph_index->bkBottom; } #endif mod->server_draw_text(mod, glyph_index->cacheId, glyph_index->flAccel, glyph_index->fOpRedundant, glyph_index->bkLeft, glyph_index->bkTop, glyph_index->bkRight, glyph_index->bkBottom, opLeft, opTop, opRight, opBottom, glyph_index->x, glyph_index->y, (char *)(glyph_index->data), glyph_index->cbData); } /******************************************************************************/ static void lfreerdp_line_to(rdpContext *context, LINE_TO_ORDER *line_to) { struct mod *mod; int server_bpp; int client_bpp; int fgcolor; int bgcolor; mod = ((struct mod_context *)context)->modi; LLOGLN(10, ("lfreerdp_line_to:")); mod->server_set_opcode(mod, line_to->bRop2); server_bpp = mod->inst->settings->color_depth; client_bpp = mod->bpp; fgcolor = convert_color(server_bpp, client_bpp, line_to->penColor, mod->colormap); bgcolor = convert_color(server_bpp, client_bpp, line_to->backColor, mod->colormap); mod->server_set_fgcolor(mod, fgcolor); mod->server_set_bgcolor(mod, bgcolor); mod->server_set_pen(mod, line_to->penStyle, line_to->penWidth); mod->server_draw_line(mod, line_to->nXStart, line_to->nYStart, line_to->nXEnd, line_to->nYEnd); mod->server_set_opcode(mod, 0xcc); } /******************************************************************************/ static void lfreerdp_cache_bitmap(rdpContext *context, CACHE_BITMAP_ORDER *cache_bitmap_order) { LLOGLN(0, ("lfreerdp_cache_bitmap: - no code here")); } /******************************************************************************/ /* Turn the bitmap upside down*/ static void lfreerdp_upsidedown(uint8 *destination, CACHE_BITMAP_V2_ORDER *cache_bitmap_v2_order, int server_Bpp) { tui8 *src; tui8 *dst; int line_bytes; int j; if (destination == NULL) { LLOGLN(0, ("lfreerdp_upsidedown: destination pointer is NULL !!!")); return; } line_bytes = server_Bpp * cache_bitmap_v2_order->bitmapWidth; src = cache_bitmap_v2_order->bitmapDataStream; dst = destination + ((cache_bitmap_v2_order->bitmapHeight) * line_bytes); for (j = 0; j < cache_bitmap_v2_order->bitmapHeight; j++) { dst -= line_bytes; g_memcpy(dst, src, line_bytes); src += line_bytes; } } /******************************************************************************/ static void lfreerdp_cache_bitmapV2(rdpContext *context, CACHE_BITMAP_V2_ORDER *cache_bitmap_v2_order) { char *dst_data; char *dst_data1; int bytes; int width; int height; int id; int idx; int flags; int server_bpp; int server_Bpp; int client_bpp; struct mod *mod; LLOGLN(10, ("lfreerdp_cache_bitmapV2: %d %d 0x%8.8x compressed %d", cache_bitmap_v2_order->cacheId, cache_bitmap_v2_order->cacheIndex, cache_bitmap_v2_order->flags, cache_bitmap_v2_order->compressed)); mod = ((struct mod_context *)context)->modi; id = cache_bitmap_v2_order->cacheId; idx = cache_bitmap_v2_order->cacheIndex; flags = cache_bitmap_v2_order->flags; if (flags & 0x10) /* CBR2_DO_NOT_CACHE */ { LLOGLN(10, ("lfreerdp_cache_bitmapV2: CBR2_DO_NOT_CACHE")); idx = 4096 - 1; } if ((id < 0) || (id >= 4)) { LLOGLN(0, ("lfreerdp_cache_bitmapV2: bad id [%d]", id)); return; } if ((idx < 0) || (idx >= 4096)) { LLOGLN(0, ("lfreerdp_cache_bitmapV2: bad idx [%d]", idx)); return; } server_bpp = mod->inst->settings->color_depth; server_Bpp = (server_bpp + 7) / 8; client_bpp = mod->bpp; width = cache_bitmap_v2_order->bitmapWidth; height = cache_bitmap_v2_order->bitmapHeight; bytes = width * height * server_Bpp + 16; dst_data = (char *)g_malloc(bytes, 0); if (cache_bitmap_v2_order->compressed) { bitmap_decompress(cache_bitmap_v2_order->bitmapDataStream, (tui8 *)dst_data, width, height, cache_bitmap_v2_order->bitmapLength, server_bpp, server_bpp); } else { /* Uncompressed bitmaps are upside down */ lfreerdp_upsidedown((tui8 *)dst_data, cache_bitmap_v2_order, server_Bpp); LLOGLN(10, ("lfreerdp_cache_bitmapV2: upside down progressed")); } dst_data1 = convert_bitmap(server_bpp, client_bpp, dst_data, width, height, mod->colormap); g_free(mod->bitmap_cache[id][idx].data); mod->bitmap_cache[id][idx].width = width; mod->bitmap_cache[id][idx].height = height; mod->bitmap_cache[id][idx].data = dst_data1; if (dst_data != dst_data1) { g_free(dst_data); } } /******************************************************************************/ static void lfreerdp_cache_glyph(rdpContext *context, CACHE_GLYPH_ORDER *cache_glyph_order) { int index; GLYPH_DATA *gd; struct mod *mod; mod = ((struct mod_context *)context)->modi; LLOGLN(10, ("lfreerdp_cache_glyph: %d", cache_glyph_order->cGlyphs)); for (index = 0; index < cache_glyph_order->cGlyphs; index++) { gd = cache_glyph_order->glyphData[index]; LLOGLN(10, (" %d %d %d %d %d", gd->cacheIndex, gd->x, gd->y, gd->cx, gd->cy)); mod->server_add_char(mod, cache_glyph_order->cacheId, gd->cacheIndex, gd->x, gd->y, gd->cx, gd->cy, (char *)(gd->aj)); free(gd->aj); gd->aj = 0; free(gd); cache_glyph_order->glyphData[index] = 0; } free(cache_glyph_order->unicodeCharacters); cache_glyph_order->unicodeCharacters = 0; } /******************************************************************************/ static void lfreerdp_cache_brush(rdpContext *context, CACHE_BRUSH_ORDER *cache_brush_order) { int idx; int bytes; int bpp; int cx; int cy; struct mod *mod; mod = ((struct mod_context *)context)->modi; bpp = cache_brush_order->bpp; cx = cache_brush_order->cx; cy = cache_brush_order->cy; idx = cache_brush_order->index; bytes = cache_brush_order->length; LLOGLN(10, ("lfreerdp_cache_brush: bpp %d cx %d cy %d idx %d bytes %d", bpp, cx, cy, idx, bytes)); if ((idx < 0) || (idx >= 64)) { LLOGLN(0, ("lfreerdp_cache_brush: error idx %d", idx)); return; } if ((bpp != 1) || (cx != 8) || (cy != 8)) { LLOGLN(0, ("lfreerdp_cache_brush: error unsupported brush " "bpp %d cx %d cy %d", bpp, cx, cy)); return; } mod->brush_cache[idx].bpp = bpp; mod->brush_cache[idx].width = cx; mod->brush_cache[idx].height = cy; mod->brush_cache[idx].data = mod->brush_cache[idx].b8x8; if (bytes > 8) { bytes = 8; } g_memset(mod->brush_cache[idx].data, 0, 8); if (bytes > 0) { if (bytes > 8) { LLOGLN(0, ("lfreerdp_cache_brush: bytes to big %d", bytes)); bytes = 8; } g_memcpy(mod->brush_cache[idx].data, cache_brush_order->data, bytes); } LLOGLN(10, ("lfreerdp_cache_brush: out bpp %d cx %d cy %d idx %d bytes %d", bpp, cx, cy, idx, bytes)); free(cache_brush_order->data); cache_brush_order->data = 0; } /******************************************************************************/ static void lfreerdp_pointer_position(rdpContext *context, POINTER_POSITION_UPDATE *pointer_position) { LLOGLN(0, ("lfreerdp_pointer_position: - no code here")); } /******************************************************************************/ static void lfreerdp_pointer_system(rdpContext *context, POINTER_SYSTEM_UPDATE *pointer_system) { LLOGLN(0, ("lfreerdp_pointer_system: - no code here type value = %d", pointer_system->type)); } /******************************************************************************/ static void lfreerdp_pointer_color(rdpContext *context, POINTER_COLOR_UPDATE *pointer_color) { LLOGLN(0, ("lfreerdp_pointer_color: - no code here")); } /******************************************************************************/ static int lfreerdp_get_pixel(void *bits, int width, int height, int bpp, int delta, int x, int y) { int start; int shift; int pixel; tui8 *src8; if (bpp == 1) { src8 = (tui8 *)bits; start = (y * delta) + x / 8; shift = x % 8; pixel = (src8[start] & (0x80 >> shift)) != 0; return pixel ? 0xffffff : 0; } else if (bpp == 32) { src8 = (tui8 *)bits; src8 += y * delta + x * 4; pixel = ((int *)(src8))[0]; return pixel; } else { LLOGLN(0, ("lfreerdp_get_pixel: unknown bpp %d", bpp)); } return 0; } /******************************************************************************/ static int lfreerdp_set_pixel(int pixel, void *bits, int width, int height, int bpp, int delta, int x, int y) { tui8 *dst8; int start; int shift; if (bpp == 1) { dst8 = (tui8 *)bits; start = (y * delta) + x / 8; shift = x % 8; if (pixel) { dst8[start] = dst8[start] | (0x80 >> shift); } else { dst8[start] = dst8[start] & ~(0x80 >> shift); } } else if (bpp == 24) { dst8 = (tui8 *)bits; dst8 += y * delta + x * 3; dst8[0] = (pixel >> 0) & 0xff; dst8[1] = (pixel >> 8) & 0xff; dst8[2] = (pixel >> 16) & 0xff; } else if (bpp == 32) { dst8 = (tui8 *)bits; dst8 += y * delta + x * 4; ((int *)(dst8))[0] = pixel; } else { LLOGLN(0, ("lfreerdp_set_pixel: unknown bpp %d", bpp)); } return 0; } /******************************************************************************/ static int lfreerdp_convert_color_image(void *dst, int dst_width, int dst_height, int dst_bpp, int dst_delta, void *src, int src_width, int src_height, int src_bpp, int src_delta) { int i; int j; int pixel; for (j = 0; j < dst_height; j++) { for (i = 0; i < dst_width; i++) { pixel = lfreerdp_get_pixel(src, src_width, src_height, src_bpp, src_delta, i, j); lfreerdp_set_pixel(pixel, dst, dst_width, dst_height, dst_bpp, dst_delta, i, j); } } return 0; } /******************************************************************************/ static void lfreerdp_pointer_new(rdpContext *context, POINTER_NEW_UPDATE *pointer_new) { struct mod *mod; int index; int bytes_per_pixel; int bits_per_pixel; tui8 *dst; tui8 *src; mod = ((struct mod_context *)context)->modi; LLOGLN(20, ("lfreerdp_pointer_new:")); LLOGLN(20, (" bpp %d", pointer_new->xorBpp)); LLOGLN(20, (" width %d height %d", pointer_new->colorPtrAttr.width, pointer_new->colorPtrAttr.height)); LLOGLN(20, (" lengthXorMask %d lengthAndMask %d", pointer_new->colorPtrAttr.lengthXorMask, pointer_new->colorPtrAttr.lengthAndMask)); index = pointer_new->colorPtrAttr.cacheIndex; if (index >= 32) { LLOGLN(0, ("lfreerdp_pointer_new: pointer index too big")); return ; } if (pointer_new->xorBpp == 1 && pointer_new->colorPtrAttr.width == 32 && pointer_new->colorPtrAttr.height == 32) { LLOGLN(10, ("lfreerdp_pointer_new:")); mod->pointer_cache[index].hotx = pointer_new->colorPtrAttr.xPos; mod->pointer_cache[index].hoty = pointer_new->colorPtrAttr.yPos; mod->pointer_cache[index].bpp = 0; dst = (tui8 *)(mod->pointer_cache[index].data); dst += 32 * 32 * 3 - 32 * 3; src = pointer_new->colorPtrAttr.xorMaskData; lfreerdp_convert_color_image(dst, 32, 32, 24, 32 * -3, src, 32, 32, 1, 32 / 8); dst = (tui8 *)(mod->pointer_cache[index].mask); dst += ( 32 * 32 / 8) - (32 / 8); src = pointer_new->colorPtrAttr.andMaskData; lfreerdp_convert_color_image(dst, 32, 32, 1, 32 / -8, src, 32, 32, 1, 32 / 8); } else if (pointer_new->xorBpp >= 8 && pointer_new->colorPtrAttr.width == 32 && pointer_new->colorPtrAttr.height == 32) { bytes_per_pixel = (pointer_new->xorBpp + 7) / 8; bits_per_pixel = pointer_new->xorBpp; LLOGLN(10, ("lfreerdp_pointer_new: bpp %d Bpp %d", bits_per_pixel, bytes_per_pixel)); mod->pointer_cache[index].hotx = pointer_new->colorPtrAttr.xPos; mod->pointer_cache[index].hoty = pointer_new->colorPtrAttr.yPos; mod->pointer_cache[index].bpp = bits_per_pixel; memcpy(mod->pointer_cache[index].data, pointer_new->colorPtrAttr.xorMaskData, 32 * 32 * bytes_per_pixel); memcpy(mod->pointer_cache[index].mask, pointer_new->colorPtrAttr.andMaskData, 32 * (32 / 8)); } else { LLOGLN(0, ("lfreerdp_pointer_new: error bpp %d width %d height %d index: %d", pointer_new->xorBpp, pointer_new->colorPtrAttr.width, pointer_new->colorPtrAttr.height, index)); } mod->server_set_pointer_ex(mod, mod->pointer_cache[index].hotx, mod->pointer_cache[index].hoty, mod->pointer_cache[index].data, mod->pointer_cache[index].mask, mod->pointer_cache[index].bpp); free(pointer_new->colorPtrAttr.xorMaskData); pointer_new->colorPtrAttr.xorMaskData = 0; free(pointer_new->colorPtrAttr.andMaskData); pointer_new->colorPtrAttr.andMaskData = 0; } /******************************************************************************/ static void lfreerdp_pointer_cached(rdpContext *context, POINTER_CACHED_UPDATE *pointer_cached) { struct mod *mod; int index; mod = ((struct mod_context *)context)->modi; index = pointer_cached->cacheIndex; LLOGLN(10, ("lfreerdp_pointer_cached:%d", index)); mod->server_set_pointer_ex(mod, mod->pointer_cache[index].hotx, mod->pointer_cache[index].hoty, mod->pointer_cache[index].data, mod->pointer_cache[index].mask, mod->pointer_cache[index].bpp); } /******************************************************************************/ static void lfreerdp_polygon_cb(rdpContext *context, POLYGON_CB_ORDER *polygon_cb) { LLOGLN(0, ("lfreerdp_polygon_sc called:- not supported!!!!!!!!!!!!!!!!!!!!")); } /******************************************************************************/ static void lfreerdp_polygon_sc(rdpContext *context, POLYGON_SC_ORDER *polygon_sc) { struct mod *mod; int i, npoints; struct { short x, y; } points[4]; int fgcolor; int server_bpp, client_bpp; mod = ((struct mod_context *)context)->modi; LLOGLN(10, ("lfreerdp_polygon_sc :%d(points) %d(color) %d(fillmode) " "%d(bRop) %d(cbData) %d(x) %d(y)", polygon_sc->nDeltaEntries, polygon_sc->brushColor, polygon_sc->fillMode, polygon_sc->bRop2, polygon_sc->cbData, polygon_sc->xStart, polygon_sc->yStart)); if (polygon_sc->nDeltaEntries == 3) { server_bpp = mod->inst->settings->color_depth; client_bpp = mod->bpp; points[0].x = polygon_sc->xStart; points[0].y = polygon_sc->yStart; for (i = 0; i < polygon_sc->nDeltaEntries; i++) { points[i + 1].x = 0; // polygon_sc->points[i].x; points[i + 1].y = 0; // polygon_sc->points[i].y; } fgcolor = convert_color(server_bpp, client_bpp, polygon_sc->brushColor, mod->colormap); mod->server_set_opcode(mod, polygon_sc->bRop2); mod->server_set_bgcolor(mod, 255); mod->server_set_fgcolor(mod, fgcolor); mod->server_set_pen(mod, 1, 1); // style, width // TODO replace with correct brush; this is a workaround // This workaround handles the text cursor in microsoft word. mod->server_draw_line(mod, polygon_sc->xStart, polygon_sc->yStart, polygon_sc->xStart, polygon_sc->yStart + points[2].y); // mod->server_fill_rect(mod, points[0].x, points[0].y, // points[0].x-points[3].x, points[0].y-points[2].y); // mod->server_set_brush(mod,); // howto use this on our indata?? mod->server_set_opcode(mod, 0xcc); } else { LLOGLN(0, ("Not handled number of points in lfreerdp_polygon_sc")); } } /******************************************************************************/ static void lfreerdp_synchronize(rdpContext *context) { struct mod *mod; mod = ((struct mod_context *)context)->modi; LLOGLN(12, ("lfreerdp_synchronize received - not handled")); } /******************************************************************************/ static boolean lfreerdp_pre_connect(freerdp *instance) { struct mod *mod; int index; int error; int num_chans; int ch_flags; char ch_name[256]; char *dst_ch_name; LLOGLN(0, ("lfreerdp_pre_connect:")); mod = ((struct mod_context *)(instance->context))->modi; verifyColorMap(mod); num_chans = 0; index = 0; error = mod->server_query_channel(mod, index, ch_name, &ch_flags); while (error == 0) { num_chans++; LLOGLN(10, ("lfreerdp_pre_connect: got channel [%s], id [%d], flags [0x%8.8x]", ch_name, index, ch_flags)); dst_ch_name = instance->settings->channels[index].name; g_memset(dst_ch_name, 0, 8); g_snprintf(dst_ch_name, 8, "%s", ch_name); instance->settings->channels[index].options = ch_flags; index++; error = mod->server_query_channel(mod, index, ch_name, &ch_flags); } instance->settings->num_channels = num_chans; instance->settings->offscreen_bitmap_cache = 0; instance->settings->draw_nine_grid = 0; instance->settings->glyph_cache = true; /* GLYPH_SUPPORT_FULL and GLYPH_SUPPORT_PARTIAL seem to be the same */ /* disabled as workaround for corrupted display like black bars left of cmd with W2K8 */ /* instance->settings->glyphSupportLevel = GLYPH_SUPPORT_FULL; */ instance->settings->glyphSupportLevel = GLYPH_SUPPORT_NONE; instance->settings->order_support[NEG_DSTBLT_INDEX] = 1; /* 0x00 */ instance->settings->order_support[NEG_PATBLT_INDEX] = 1; instance->settings->order_support[NEG_SCRBLT_INDEX] = 1; instance->settings->order_support[NEG_MEMBLT_INDEX] = 1; instance->settings->order_support[NEG_MEM3BLT_INDEX] = 0; instance->settings->order_support[NEG_ATEXTOUT_INDEX] = 0; instance->settings->order_support[NEG_AEXTTEXTOUT_INDEX] = 0; instance->settings->order_support[NEG_DRAWNINEGRID_INDEX] = 0; instance->settings->order_support[NEG_LINETO_INDEX] = 1; /* 0x08 */ instance->settings->order_support[NEG_MULTI_DRAWNINEGRID_INDEX] = 0; instance->settings->order_support[NEG_OPAQUE_RECT_INDEX] = 1; instance->settings->order_support[NEG_SAVEBITMAP_INDEX] = 0; instance->settings->order_support[NEG_WTEXTOUT_INDEX] = 0; instance->settings->order_support[NEG_MEMBLT_V2_INDEX] = 1; instance->settings->order_support[NEG_MEM3BLT_V2_INDEX] = 0; instance->settings->order_support[NEG_MULTIDSTBLT_INDEX] = 0; instance->settings->order_support[NEG_MULTIPATBLT_INDEX] = 0; /* 0x10 */ instance->settings->order_support[NEG_MULTISCRBLT_INDEX] = 0; instance->settings->order_support[NEG_MULTIOPAQUERECT_INDEX] = 0; instance->settings->order_support[NEG_FAST_INDEX_INDEX] = 0; instance->settings->order_support[NEG_POLYGON_SC_INDEX] = 0; instance->settings->order_support[NEG_POLYGON_CB_INDEX] = 0; instance->settings->order_support[NEG_POLYLINE_INDEX] = 0; /* 0x17 missing */ instance->settings->order_support[NEG_FAST_GLYPH_INDEX] = 0; /* 0x18 */ instance->settings->order_support[NEG_ELLIPSE_SC_INDEX] = 0; instance->settings->order_support[NEG_ELLIPSE_CB_INDEX] = 0; /* disabled as workaround for corrupted display like black bars left of cmd with W2K8 */ /* instance->settings->order_support[NEG_GLYPH_INDEX_INDEX] = 1; */ instance->settings->order_support[NEG_GLYPH_INDEX_INDEX] = 0; instance->settings->order_support[NEG_GLYPH_WEXTTEXTOUT_INDEX] = 0; instance->settings->order_support[NEG_GLYPH_WLONGTEXTOUT_INDEX] = 0; instance->settings->order_support[NEG_GLYPH_WLONGEXTTEXTOUT_INDEX] = 0; /* 0x1F missing*/ instance->settings->bitmap_cache = 1; instance->settings->bitmapCacheV2NumCells = 3; // 5; instance->settings->bitmapCacheV2CellInfo[0].numEntries = 600; // 0x78; instance->settings->bitmapCacheV2CellInfo[0].persistent = 0; instance->settings->bitmapCacheV2CellInfo[1].numEntries = 600; //0x78; // 600; instance->settings->bitmapCacheV2CellInfo[1].persistent = 0; instance->settings->bitmapCacheV2CellInfo[2].numEntries = 2048; //0x150; // 2048; instance->settings->bitmapCacheV2CellInfo[2].persistent = 0; instance->settings->bitmapCacheV2CellInfo[3].numEntries = 4096; // 4096; instance->settings->bitmapCacheV2CellInfo[3].persistent = 0; instance->settings->bitmapCacheV2CellInfo[4].numEntries = 2048; // 2048; instance->settings->bitmapCacheV2CellInfo[4].persistent = 0; instance->settings->bitmap_cache_v3 = 1; instance->settings->username = g_strdup(mod->username); instance->settings->password = g_strdup(mod->password); instance->settings->domain = g_strdup(mod->domain); if (mod->client_info.rail_support_level > 0) { LLOGLN(0, ("Railsupport !!!!!!!!!!!!!!!!!!")); instance->settings->remote_app = 1; instance->settings->rail_langbar_supported = 1; instance->settings->workarea = 1; instance->settings->performance_flags = PERF_DISABLE_WALLPAPER | PERF_DISABLE_FULLWINDOWDRAG; instance->settings->num_icon_caches = mod->client_info.wnd_num_icon_caches; instance->settings->num_icon_cache_entries = mod->client_info.wnd_num_icon_cache_entries; } else { LLOGLN(10, ("Special PerformanceFlags changed")); instance->settings->performance_flags = PERF_DISABLE_WALLPAPER | PERF_DISABLE_FULLWINDOWDRAG | PERF_DISABLE_MENUANIMATIONS | PERF_DISABLE_THEMING; // | PERF_DISABLE_CURSOR_SHADOW | PERF_DISABLE_CURSORSETTINGS; } instance->settings->compression = 0; instance->settings->ignore_certificate = 1; // Multi Monitor Settings instance->settings->num_monitors = mod->client_info.monitorCount; for (index = 0; index < mod->client_info.monitorCount; index++) { instance->settings->monitors[index].x = mod->client_info.minfo[index].left; instance->settings->monitors[index].y = mod->client_info.minfo[index].top; instance->settings->monitors[index].width = mod->client_info.minfo[index].right; instance->settings->monitors[index].height = mod->client_info.minfo[index].bottom; instance->settings->monitors[index].is_primary = mod->client_info.minfo[index].is_primary; } instance->update->BeginPaint = lfreerdp_begin_paint; instance->update->EndPaint = lfreerdp_end_paint; instance->update->SetBounds = lfreerdp_set_bounds; instance->update->BitmapUpdate = lfreerdp_bitmap_update; instance->update->Synchronize = lfreerdp_synchronize; instance->update->primary->DstBlt = lfreerdp_dst_blt; instance->update->primary->PatBlt = lfreerdp_pat_blt; instance->update->primary->ScrBlt = lfreerdp_scr_blt; instance->update->primary->OpaqueRect = lfreerdp_opaque_rect; instance->update->primary->MemBlt = lfreerdp_mem_blt; instance->update->primary->GlyphIndex = lfreerdp_glyph_index; instance->update->primary->LineTo = lfreerdp_line_to; instance->update->primary->PolygonSC = lfreerdp_polygon_sc ; instance->update->primary->PolygonCB = lfreerdp_polygon_cb; instance->update->secondary->CacheBitmap = lfreerdp_cache_bitmap; instance->update->secondary->CacheBitmapV2 = lfreerdp_cache_bitmapV2; instance->update->secondary->CacheGlyph = lfreerdp_cache_glyph; instance->update->secondary->CacheBrush = lfreerdp_cache_brush; instance->update->pointer->PointerPosition = lfreerdp_pointer_position; instance->update->pointer->PointerSystem = lfreerdp_pointer_system; instance->update->pointer->PointerColor = lfreerdp_pointer_color; instance->update->pointer->PointerNew = lfreerdp_pointer_new; instance->update->pointer->PointerCached = lfreerdp_pointer_cached; if ((mod->username[0] != 0) && (mod->password[0] != 0)) { /* since we have username and password, we can try nla */ instance->settings->nla_security = 1; } else { instance->settings->nla_security = 0; } return 1; } /*****************************************************************************/ void lrail_WindowCreate(rdpContext *context, WINDOW_ORDER_INFO *orderInfo, WINDOW_STATE_ORDER *window_state) { int index; struct mod *mod; struct rail_window_state_order wso; UNICONV *uniconv; LLOGLN(10, ("lrail_WindowCreate:")); uniconv = freerdp_uniconv_new(); mod = ((struct mod_context *)context)->modi; memset(&wso, 0, sizeof(wso)); /* copy the window state order */ wso.owner_window_id = window_state->ownerWindowId; wso.style = window_state->style; wso.extended_style = window_state->extendedStyle; wso.show_state = window_state->showState; if (orderInfo->fieldFlags & WINDOW_ORDER_FIELD_TITLE) { wso.title_info = freerdp_uniconv_in(uniconv, window_state->titleInfo.string, window_state->titleInfo.length); } LLOGLN(10, ("lrail_WindowCreate: %s", wso.title_info)); wso.client_offset_x = window_state->clientOffsetX; wso.client_offset_y = window_state->clientOffsetY; wso.client_area_width = window_state->clientAreaWidth; wso.client_area_height = window_state->clientAreaHeight; wso.rp_content = window_state->RPContent; wso.root_parent_handle = window_state->rootParentHandle; wso.window_offset_x = window_state->windowOffsetX; wso.window_offset_y = window_state->windowOffsetY; wso.window_client_delta_x = window_state->windowClientDeltaX; wso.window_client_delta_y = window_state->windowClientDeltaY; wso.window_width = window_state->windowWidth; wso.window_height = window_state->windowHeight; wso.num_window_rects = window_state->numWindowRects; if (orderInfo->fieldFlags & WINDOW_ORDER_FIELD_WND_RECTS) { wso.window_rects = (struct rail_window_rect *) g_malloc(sizeof(struct rail_window_rect) * wso.num_window_rects, 0); for (index = 0; index < wso.num_window_rects; index++) { wso.window_rects[index].left = window_state->windowRects[index].left; wso.window_rects[index].top = window_state->windowRects[index].top; wso.window_rects[index].right = window_state->windowRects[index].right; wso.window_rects[index].bottom = window_state->windowRects[index].bottom; } } wso.visible_offset_x = window_state->visibleOffsetX; wso.visible_offset_y = window_state->visibleOffsetY; wso.num_visibility_rects = window_state->numVisibilityRects; if (orderInfo->fieldFlags & WINDOW_ORDER_FIELD_VISIBILITY) { wso.visibility_rects = (struct rail_window_rect *) g_malloc(sizeof(struct rail_window_rect) * wso.num_visibility_rects, 0); for (index = 0; index < wso.num_visibility_rects; index++) { wso.visibility_rects[index].left = window_state->visibilityRects[index].left; wso.visibility_rects[index].top = window_state->visibilityRects[index].top; wso.visibility_rects[index].right = window_state->visibilityRects[index].right; wso.visibility_rects[index].bottom = window_state->visibilityRects[index].bottom; } } mod->server_window_new_update(mod, orderInfo->windowId, &wso, orderInfo->fieldFlags); free(wso.title_info); g_free(wso.window_rects); g_free(wso.visibility_rects); } /*****************************************************************************/ void lrail_WindowUpdate(rdpContext *context, WINDOW_ORDER_INFO *orderInfo, WINDOW_STATE_ORDER *window_state) { LLOGLN(10, ("lrail_WindowUpdate:")); lrail_WindowCreate(context, orderInfo, window_state); } /*****************************************************************************/ void lrail_WindowDelete(rdpContext *context, WINDOW_ORDER_INFO *orderInfo) { struct mod *mod; LLOGLN(10, ("lrail_WindowDelete:")); mod = ((struct mod_context *)context)->modi; mod->server_window_delete(mod, orderInfo->windowId); } /*****************************************************************************/ void lrail_WindowIcon(rdpContext *context, WINDOW_ORDER_INFO *orderInfo, WINDOW_ICON_ORDER *window_icon) { struct mod *mod; struct rail_icon_info rii; LLOGLN(10, ("lrail_WindowIcon:")); mod = ((struct mod_context *)context)->modi; memset(&rii, 0, sizeof(rii)); rii.bpp = window_icon->iconInfo->bpp; rii.width = window_icon->iconInfo->width; rii.height = window_icon->iconInfo->height; rii.cmap_bytes = window_icon->iconInfo->cbColorTable; rii.mask_bytes = window_icon->iconInfo->cbBitsMask; rii.data_bytes = window_icon->iconInfo->cbBitsColor; rii.mask = (char *)(window_icon->iconInfo->bitsMask); rii.cmap = (char *)(window_icon->iconInfo->colorTable); rii.data = (char *)(window_icon->iconInfo->bitsColor); mod->server_window_icon(mod, orderInfo->windowId, window_icon->iconInfo->cacheEntry, window_icon->iconInfo->cacheId, &rii, orderInfo->fieldFlags); } /*****************************************************************************/ void lrail_WindowCachedIcon(rdpContext *context, WINDOW_ORDER_INFO *orderInfo, WINDOW_CACHED_ICON_ORDER *window_cached_icon) { struct mod *mod; LLOGLN(10, ("lrail_WindowCachedIcon:")); mod = ((struct mod_context *)context)->modi; mod->server_window_cached_icon(mod, orderInfo->windowId, window_cached_icon->cachedIcon.cacheEntry, window_cached_icon->cachedIcon.cacheId, orderInfo->fieldFlags); } /*****************************************************************************/ void lrail_NotifyIconCreate(rdpContext *context, WINDOW_ORDER_INFO *orderInfo, NOTIFY_ICON_STATE_ORDER *notify_icon_state) { struct mod *mod; struct rail_notify_state_order rnso; UNICONV *uniconv; LLOGLN(10, ("lrail_NotifyIconCreate:")); uniconv = freerdp_uniconv_new(); mod = ((struct mod_context *)context)->modi; memset(&rnso, 0, sizeof(rnso)); rnso.version = notify_icon_state->version; if (orderInfo->fieldFlags & WINDOW_ORDER_FIELD_NOTIFY_TIP) { rnso.tool_tip = freerdp_uniconv_in(uniconv, notify_icon_state->toolTip.string, notify_icon_state->toolTip.length); } if (orderInfo->fieldFlags & WINDOW_ORDER_FIELD_NOTIFY_INFO_TIP) { rnso.infotip.timeout = notify_icon_state->infoTip.timeout; rnso.infotip.flags = notify_icon_state->infoTip.flags; rnso.infotip.text = freerdp_uniconv_in(uniconv, notify_icon_state->infoTip.text.string, notify_icon_state->infoTip.text.length); rnso.infotip.title = freerdp_uniconv_in(uniconv, notify_icon_state->infoTip.title.string, notify_icon_state->infoTip.title.length); } rnso.state = notify_icon_state->state; rnso.icon_cache_entry = notify_icon_state->icon.cacheEntry; rnso.icon_cache_id = notify_icon_state->icon.cacheId; rnso.icon_info.bpp = notify_icon_state->icon.bpp; rnso.icon_info.width = notify_icon_state->icon.width; rnso.icon_info.height = notify_icon_state->icon.height; rnso.icon_info.cmap_bytes = notify_icon_state->icon.cbColorTable; rnso.icon_info.mask_bytes = notify_icon_state->icon.cbBitsMask; rnso.icon_info.data_bytes = notify_icon_state->icon.cbBitsColor; rnso.icon_info.mask = (char *)(notify_icon_state->icon.bitsMask); rnso.icon_info.cmap = (char *)(notify_icon_state->icon.colorTable); rnso.icon_info.data = (char *)(notify_icon_state->icon.bitsColor); mod->server_notify_new_update(mod, orderInfo->windowId, orderInfo->notifyIconId, &rnso, orderInfo->fieldFlags); free(rnso.tool_tip); free(rnso.infotip.text); free(rnso.infotip.title); } /*****************************************************************************/ void lrail_NotifyIconUpdate(rdpContext *context, WINDOW_ORDER_INFO *orderInfo, NOTIFY_ICON_STATE_ORDER *notify_icon_state) { LLOGLN(10, ("lrail_NotifyIconUpdate:")); lrail_NotifyIconCreate(context, orderInfo, notify_icon_state); } /*****************************************************************************/ void lrail_NotifyIconDelete(rdpContext *context, WINDOW_ORDER_INFO *orderInfo) { struct mod *mod; LLOGLN(10, ("lrail_NotifyIconDelete:")); mod = ((struct mod_context *)context)->modi; mod->server_notify_delete(mod, orderInfo->windowId, orderInfo->notifyIconId); } /*****************************************************************************/ void lrail_MonitoredDesktop(rdpContext *context, WINDOW_ORDER_INFO *orderInfo, MONITORED_DESKTOP_ORDER *monitored_desktop) { int index; struct mod *mod; struct rail_monitored_desktop_order rmdo; LLOGLN(10, ("lrail_MonitoredDesktop:")); mod = ((struct mod_context *)context)->modi; memset(&rmdo, 0, sizeof(rmdo)); rmdo.active_window_id = monitored_desktop->activeWindowId; rmdo.num_window_ids = monitored_desktop->numWindowIds; if (orderInfo->fieldFlags & WINDOW_ORDER_FIELD_DESKTOP_ZORDER) { if (rmdo.num_window_ids > 0) { rmdo.window_ids = (int *)g_malloc(sizeof(int) * rmdo.num_window_ids, 0); for (index = 0; index < rmdo.num_window_ids; index++) { rmdo.window_ids[index] = monitored_desktop->windowIds[index]; } } } mod->server_monitored_desktop(mod, &rmdo, orderInfo->fieldFlags); g_free(rmdo.window_ids); } /*****************************************************************************/ void lrail_NonMonitoredDesktop(rdpContext *context, WINDOW_ORDER_INFO *orderInfo) { struct mod *mod; struct rail_monitored_desktop_order rmdo; LLOGLN(10, ("lrail_NonMonitoredDesktop:")); mod = ((struct mod_context *)context)->modi; memset(&rmdo, 0, sizeof(rmdo)); mod->server_monitored_desktop(mod, &rmdo, orderInfo->fieldFlags); } /******************************************************************************/ static boolean lfreerdp_post_connect(freerdp *instance) { struct mod *mod; LLOGLN(10, ("lfreerdp_post_connect:")); mod = ((struct mod_context *)(instance->context))->modi; g_memset(mod->password, 0, sizeof(mod->password)); mod->inst->update->window->WindowCreate = lrail_WindowCreate; mod->inst->update->window->WindowUpdate = lrail_WindowUpdate; mod->inst->update->window->WindowDelete = lrail_WindowDelete; mod->inst->update->window->WindowIcon = lrail_WindowIcon; mod->inst->update->window->WindowCachedIcon = lrail_WindowCachedIcon; mod->inst->update->window->NotifyIconCreate = lrail_NotifyIconCreate; mod->inst->update->window->NotifyIconUpdate = lrail_NotifyIconUpdate; mod->inst->update->window->NotifyIconDelete = lrail_NotifyIconDelete; mod->inst->update->window->MonitoredDesktop = lrail_MonitoredDesktop; mod->inst->update->window->NonMonitoredDesktop = lrail_NonMonitoredDesktop; return 1; } /******************************************************************************/ static void lfreerdp_context_new(freerdp *instance, rdpContext *context) { LLOGLN(0, ("lfreerdp_context_new: %p", context)); } /******************************************************************************/ static void lfreerdp_context_free(freerdp *instance, rdpContext *context) { LLOGLN(0, ("lfreerdp_context_free: - no code here")); } /******************************************************************************/ static int lfreerdp_receive_channel_data(freerdp *instance, int channelId, uint8 *data, int size, int flags, int total_size) { struct mod *mod; int lchid; int index; int error; mod = ((struct mod_context *)(instance->context))->modi; lchid = -1; for (index = 0; index < instance->settings->num_channels; index++) { if (instance->settings->channels[index].channel_id == channelId) { lchid = index; break; } } if (lchid >= 0) { LLOGLN(10, ("lfreerdp_receive_channel_data: server to client, chanid: %d", lchid)); error = mod->server_send_to_channel(mod, lchid, (char *)data, size, total_size, flags); if (error != 0) { LLOGLN(0, ("lfreerdp_receive_channel_data: error %d", error)); } } else { LLOGLN(0, ("lfreerdp_receive_channel_data: bad lchid")); } return 0; } /******************************************************************************/ static boolean lfreerdp_authenticate(freerdp *instance, char **username, char **password, char **domain) { LLOGLN(0, ("lfreerdp_authenticate: - no code here")); return 1; } /******************************************************************************/ static boolean lfreerdp_verify_certificate(freerdp *instance, char *subject, char *issuer, char *fingerprint) { LLOGLN(0, ("lfreerdp_verify_certificate: - no code here")); return 1; } /******************************************************************************/ static int lfreerdp_session_info(freerdp* instance, uint8* data, int data_bytes) { struct mod *mod; int error; LLOGLN(10, ("lfreerdp_session_info:")); error = 0; mod = ((struct mod_context *)(instance->context))->modi; if (mod != 0) { LLOGLN(10, ("lfreerdp_session_info: mod->server_session_info %p", mod->server_session_info)); if (mod->server_session_info != 0) { error = mod->server_session_info(mod, (char *)data, data_bytes); } } return error; } /******************************************************************************/ tintptr EXPORT_CC mod_init(void) { struct mod *mod; modContext *lcon; LLOGLN(0, ("mod_init:")); mod = (struct mod *)g_malloc(sizeof(struct mod), 1); freerdp_get_version(&(mod->vmaj), &(mod->vmin), &(mod->vrev)); LLOGLN(0, (" FreeRDP version major %d minor %d revision %d", mod->vmaj, mod->vmin, mod->vrev)); mod->size = sizeof(struct mod); mod->version = CURRENT_MOD_VER; mod->handle = (tintptr) mod; mod->mod_connect = lxrdp_connect; mod->mod_start = lxrdp_start; mod->mod_event = lxrdp_event; mod->mod_signal = lxrdp_signal; mod->mod_end = lxrdp_end; mod->mod_set_param = lxrdp_set_param; mod->mod_session_change = lxrdp_session_change; mod->mod_get_wait_objs = lxrdp_get_wait_objs; mod->mod_check_wait_objs = lxrdp_check_wait_objs; mod->inst = freerdp_new(); mod->inst->PreConnect = lfreerdp_pre_connect; mod->inst->PostConnect = lfreerdp_post_connect; mod->inst->context_size = sizeof(modContext); mod->inst->ContextNew = lfreerdp_context_new; mod->inst->ContextFree = lfreerdp_context_free; mod->inst->ReceiveChannelData = lfreerdp_receive_channel_data; mod->inst->Authenticate = lfreerdp_authenticate; mod->inst->VerifyCertificate = lfreerdp_verify_certificate; #if defined(VERSION_STRUCT_RDP_FREERDP) #if VERSION_STRUCT_RDP_FREERDP > 0 mod->inst->SessionInfo = lfreerdp_session_info; #endif #endif freerdp_context_new(mod->inst); lcon = (modContext *)(mod->inst->context); lcon->modi = mod; LLOGLN(10, ("mod_init: mod %p", mod)); return (tintptr) mod; } /******************************************************************************/ int EXPORT_CC mod_exit(tintptr handle) { struct mod *mod = (struct mod *) handle; LLOGLN(0, ("mod_exit:")); if (mod == 0) { return 0; } if (mod->inst == NULL) { LLOGLN(0, ("mod_exit - null pointer for inst:")); g_free(mod); return 0 ; } freerdp_disconnect(mod->inst); if ((mod->vmaj == 1) && (mod->vmin == 0) && (mod->vrev == 1)) { /* this version has a bug with double free in freerdp_free */ } else { freerdp_context_free(mod->inst); } freerdp_free(mod->inst); g_free(mod); return 0; } xrdp-0.9.5/neutrinordp/Makefile.am000644 001751 001751 00000001113 13133557325 017032 0ustar00metameta000000 000000 AM_CPPFLAGS = \ -DXRDP_CFG_PATH=\"${sysconfdir}/xrdp\" \ -DXRDP_SBIN_PATH=\"${sbindir}\" \ -DXRDP_SHARE_PATH=\"${datadir}/xrdp\" \ -DXRDP_PID_PATH=\"${localstatedir}/run\" \ -I$(top_srcdir)/common \ $(FREERDP_CFLAGS) if XRDP_DEBUG AM_CPPFLAGS += -DXRDP_DEBUG endif module_LTLIBRARIES = \ libxrdpneutrinordp.la libxrdpneutrinordp_la_SOURCES = \ xrdp-color.c \ xrdp-color.h \ xrdp-neutrinordp.c \ xrdp-neutrinordp.h libxrdpneutrinordp_la_LIBADD = \ $(top_builddir)/common/libcommon.la \ $(FREERDP_LIBS) libxrdpneutrinordp_la_LDFLAGS = -avoid-version -module xrdp-0.9.5/neutrinordp/xrdp-color.c000644 001751 001751 00000020004 13174271344 017232 0ustar00metameta000000 000000 /** * FreeRDP: A Remote Desktop Protocol Server * freerdp wrapper * * Copyright 2011-2012 Jay Sorg * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ #if defined(HAVE_CONFIG_H) #include #endif #include "xrdp-neutrinordp.h" char * convert_bitmap(int in_bpp, int out_bpp, char *bmpdata, int width, int height, int *palette) { char *out; char *src; char *dst; int i; int j; int red; int green; int blue; int pixel; if ((in_bpp == 8) && (out_bpp == 8)) { out = (char *)g_malloc(width * height, 0); src = bmpdata; dst = out; for (i = 0; i < height; i++) { for (j = 0; j < width; j++) { pixel = *((tui8 *)src); pixel = palette[pixel]; SPLITCOLOR32(red, green, blue, pixel); pixel = COLOR8(red, green, blue); *dst = pixel; src++; dst++; } } return out; } if ((in_bpp == 8) && (out_bpp == 16)) { out = (char *)g_malloc(width * height * 2, 0); src = bmpdata; dst = out; for (i = 0; i < height; i++) { for (j = 0; j < width; j++) { pixel = *((tui8 *)src); pixel = palette[pixel]; SPLITCOLOR32(red, green, blue, pixel); pixel = COLOR16(red, green, blue); *((tui16 *)dst) = pixel; src++; dst += 2; } } return out; } if ((in_bpp == 8) && (out_bpp == 24)) { out = (char *)g_malloc(width * height * 4, 0); src = bmpdata; dst = out; for (i = 0; i < height; i++) { for (j = 0; j < width; j++) { pixel = *((tui8 *)src); pixel = palette[pixel]; SPLITCOLOR32(red, green, blue, pixel); pixel = COLOR24RGB(red, green, blue); *((tui32 *)dst) = pixel; src++; dst += 4; } } return out; } if ((in_bpp == 15) && (out_bpp == 16)) { out = (char *)g_malloc(width * height * 2, 0); src = bmpdata; dst = out; for (i = 0; i < height; i++) { for (j = 0; j < width; j++) { pixel = *((tui16 *)src); SPLITCOLOR15(red, green, blue, pixel); pixel = COLOR16(red, green, blue); *((tui16 *)dst) = pixel; src += 2; dst += 2; } } return out; } if ((in_bpp == 15) && (out_bpp == 24)) { out = (char *)g_malloc(width * height * 4, 0); src = bmpdata; dst = out; for (i = 0; i < height; i++) { for (j = 0; j < width; j++) { pixel = *((tui16 *)src); SPLITCOLOR15(red, green, blue, pixel); pixel = COLOR24RGB(red, green, blue); *((tui32 *)dst) = pixel; src += 2; dst += 4; } } return out; } if ((in_bpp == 15) && (out_bpp == 15)) { return bmpdata; } if ((in_bpp == 16) && (out_bpp == 16)) { return bmpdata; } if ((in_bpp == 16) && (out_bpp == 24)) { out = (char *)g_malloc(width * height * 4, 0); src = bmpdata; dst = out; for (i = 0; i < height; i++) { for (j = 0; j < width; j++) { pixel = *((tui16 *)src); SPLITCOLOR16(red, green, blue, pixel); pixel = COLOR24RGB(red, green, blue); *((tui32 *)dst) = pixel; src += 2; dst += 4; } } return out; } if ((in_bpp == 24) && (out_bpp == 24)) { out = (char *)g_malloc(width * height * 4, 0); src = bmpdata; dst = out; for (i = 0; i < height; i++) { for (j = 0; j < width; j++) { blue = *((tui8 *)src); src++; green = *((tui8 *)src); src++; red = *((tui8 *)src); src++; pixel = COLOR24RGB(red, green, blue); *((tui32 *)dst) = pixel; dst += 4; } } return out; } if ((in_bpp == 32) && (out_bpp == 24)) { return bmpdata; } if ((in_bpp == 32) && (out_bpp == 32)) { return bmpdata; } if ((in_bpp == 16) && (out_bpp == 32)) { out = (char *)g_malloc(width * height * 4, 0); src = bmpdata; dst = out; for (i = 0; i < height; i++) { for (j = 0; j < width; j++) { pixel = *((tui16 *)src); SPLITCOLOR16(red, green, blue, pixel); pixel = COLOR24RGB(red, green, blue); *((tui32 *)dst) = pixel; src += 2; dst += 4; } } return out; } g_writeln("convert_bitmap: error unknown conversion from %d to %d", in_bpp, out_bpp); return 0; } /*****************************************************************************/ /* returns color or 0 */ int convert_color(int in_bpp, int out_bpp, int in_color, int *palette) { int pixel; int red; int green; int blue; if ((in_bpp == 1) && (out_bpp == 24)) { pixel = in_color == 0 ? 0 : 0xffffff; return pixel; } if ((in_bpp == 8) && (out_bpp == 8)) { pixel = palette[in_color]; SPLITCOLOR32(red, green, blue, pixel); pixel = COLOR8(red, green, blue); return pixel; } if ((in_bpp == 8) && (out_bpp == 16)) { pixel = palette[in_color]; SPLITCOLOR32(red, green, blue, pixel); pixel = COLOR16(red, green, blue); return pixel; } if ((in_bpp == 8) && (out_bpp == 24)) { pixel = palette[in_color]; SPLITCOLOR32(red, green, blue, pixel); pixel = COLOR24BGR(red, green, blue); return pixel; } if ((in_bpp == 15) && (out_bpp == 16)) { pixel = in_color; SPLITCOLOR15(red, green, blue, pixel); pixel = COLOR16(red, green, blue); return pixel; } if ((in_bpp == 15) && (out_bpp == 24)) { pixel = in_color; SPLITCOLOR15(red, green, blue, pixel); pixel = COLOR24BGR(red, green, blue); return pixel; } if ((in_bpp == 15) && (out_bpp == 15)) { return in_color; } if ((in_bpp == 16) && (out_bpp == 16)) { return in_color; } if ((in_bpp == 16) && (out_bpp == 24)) { pixel = in_color; SPLITCOLOR16(red, green, blue, pixel); pixel = COLOR24BGR(red, green, blue); return pixel; } if ((in_bpp == 16) && (out_bpp == 32)) { pixel = in_color; SPLITCOLOR16(red, green, blue, pixel); pixel = COLOR24BGR(red, green, blue); return pixel; } if ((in_bpp == 24) && (out_bpp == 24)) { return in_color; } if ((in_bpp == 32) && (out_bpp == 24)) { return in_color; } if ((in_bpp == 32) && (out_bpp == 32)) { return in_color; } g_writeln("convert_color: error unknown conversion from %d to %d", in_bpp, out_bpp); return 0; } xrdp-0.9.5/neutrinordp/Makefile.in000644 001751 001751 00000053076 13220730774 017060 0ustar00metameta000000 000000 # Makefile.in generated by automake 1.15.1 from Makefile.am. # @configure_input@ # Copyright (C) 1994-2017 Free Software Foundation, Inc. # This Makefile.in is free software; the Free Software Foundation # gives unlimited permission to copy and/or distribute it, # with or without modifications, as long as this notice is preserved. # This program is distributed in the hope that it will be useful, # but WITHOUT ANY WARRANTY, to the extent permitted by law; without # even the implied warranty of MERCHANTABILITY or FITNESS FOR A # PARTICULAR PURPOSE. @SET_MAKE@ VPATH = @srcdir@ am__is_gnu_make = { \ if test -z '$(MAKELEVEL)'; then \ false; \ elif test -n '$(MAKE_HOST)'; then \ true; \ elif test -n '$(MAKE_VERSION)' && test -n '$(CURDIR)'; then \ true; \ else \ false; \ fi; \ } am__make_running_with_option = \ case $${target_option-} in \ ?) ;; \ *) echo "am__make_running_with_option: internal error: invalid" \ "target option '$${target_option-}' specified" >&2; \ exit 1;; \ esac; \ has_opt=no; \ sane_makeflags=$$MAKEFLAGS; \ if $(am__is_gnu_make); then \ sane_makeflags=$$MFLAGS; \ else \ case $$MAKEFLAGS in \ *\\[\ \ ]*) \ bs=\\; \ sane_makeflags=`printf '%s\n' "$$MAKEFLAGS" \ | sed "s/$$bs$$bs[$$bs $$bs ]*//g"`;; \ esac; \ fi; \ skip_next=no; \ strip_trailopt () \ { \ flg=`printf '%s\n' "$$flg" | sed "s/$$1.*$$//"`; \ }; \ for flg in $$sane_makeflags; do \ test $$skip_next = yes && { skip_next=no; continue; }; \ case $$flg in \ *=*|--*) continue;; \ -*I) strip_trailopt 'I'; skip_next=yes;; \ -*I?*) strip_trailopt 'I';; \ -*O) strip_trailopt 'O'; skip_next=yes;; \ -*O?*) strip_trailopt 'O';; \ -*l) strip_trailopt 'l'; skip_next=yes;; \ -*l?*) strip_trailopt 'l';; \ -[dEDm]) skip_next=yes;; \ -[JT]) skip_next=yes;; \ esac; \ case $$flg in \ *$$target_option*) has_opt=yes; break;; \ esac; \ done; \ test $$has_opt = yes am__make_dryrun = (target_option=n; $(am__make_running_with_option)) am__make_keepgoing = (target_option=k; $(am__make_running_with_option)) pkgdatadir = $(datadir)/@PACKAGE@ pkgincludedir = $(includedir)/@PACKAGE@ pkglibdir = $(libdir)/@PACKAGE@ pkglibexecdir = $(libexecdir)/@PACKAGE@ am__cd = CDPATH="$${ZSH_VERSION+.}$(PATH_SEPARATOR)" && cd install_sh_DATA = $(install_sh) -c -m 644 install_sh_PROGRAM = $(install_sh) -c install_sh_SCRIPT = $(install_sh) -c INSTALL_HEADER = $(INSTALL_DATA) transform = $(program_transform_name) NORMAL_INSTALL = : PRE_INSTALL = : POST_INSTALL = : NORMAL_UNINSTALL = : PRE_UNINSTALL = : POST_UNINSTALL = : build_triplet = @build@ host_triplet = @host@ @XRDP_DEBUG_TRUE@am__append_1 = -DXRDP_DEBUG subdir = neutrinordp ACLOCAL_M4 = $(top_srcdir)/aclocal.m4 am__aclocal_m4_deps = $(top_srcdir)/m4/ax_append_compile_flags.m4 \ $(top_srcdir)/m4/ax_append_flag.m4 \ $(top_srcdir)/m4/ax_cflags_warn_all.m4 \ $(top_srcdir)/m4/ax_check_compile_flag.m4 \ $(top_srcdir)/m4/ax_gcc_func_attribute.m4 \ $(top_srcdir)/m4/ax_require_defined.m4 \ $(top_srcdir)/m4/ax_type_socklen_t.m4 \ $(top_srcdir)/m4/libtool.m4 $(top_srcdir)/m4/ltoptions.m4 \ $(top_srcdir)/m4/ltsugar.m4 $(top_srcdir)/m4/ltversion.m4 \ $(top_srcdir)/m4/lt~obsolete.m4 $(top_srcdir)/m4/pkg.m4 \ $(top_srcdir)/configure.ac am__configure_deps = $(am__aclocal_m4_deps) $(CONFIGURE_DEPENDENCIES) \ $(ACLOCAL_M4) DIST_COMMON = $(srcdir)/Makefile.am $(am__DIST_COMMON) mkinstalldirs = $(install_sh) -d CONFIG_HEADER = $(top_builddir)/config_ac.h CONFIG_CLEAN_FILES = CONFIG_CLEAN_VPATH_FILES = am__vpath_adj_setup = srcdirstrip=`echo "$(srcdir)" | sed 's|.|.|g'`; am__vpath_adj = case $$p in \ $(srcdir)/*) f=`echo "$$p" | sed "s|^$$srcdirstrip/||"`;; \ *) f=$$p;; \ esac; am__strip_dir = f=`echo $$p | sed -e 's|^.*/||'`; am__install_max = 40 am__nobase_strip_setup = \ srcdirstrip=`echo "$(srcdir)" | sed 's/[].[^$$\\*|]/\\\\&/g'` am__nobase_strip = \ for p in $$list; do echo "$$p"; done | sed -e "s|$$srcdirstrip/||" am__nobase_list = $(am__nobase_strip_setup); \ for p in $$list; do echo "$$p $$p"; done | \ sed "s| $$srcdirstrip/| |;"' / .*\//!s/ .*/ ./; s,\( .*\)/[^/]*$$,\1,' | \ $(AWK) 'BEGIN { files["."] = "" } { files[$$2] = files[$$2] " " $$1; \ if (++n[$$2] == $(am__install_max)) \ { print $$2, files[$$2]; n[$$2] = 0; files[$$2] = "" } } \ END { for (dir in files) print dir, files[dir] }' am__base_list = \ sed '$$!N;$$!N;$$!N;$$!N;$$!N;$$!N;$$!N;s/\n/ /g' | \ sed '$$!N;$$!N;$$!N;$$!N;s/\n/ /g' am__uninstall_files_from_dir = { \ test -z "$$files" \ || { test ! -d "$$dir" && test ! -f "$$dir" && test ! -r "$$dir"; } \ || { echo " ( cd '$$dir' && rm -f" $$files ")"; \ $(am__cd) "$$dir" && rm -f $$files; }; \ } am__installdirs = "$(DESTDIR)$(moduledir)" LTLIBRARIES = $(module_LTLIBRARIES) am__DEPENDENCIES_1 = libxrdpneutrinordp_la_DEPENDENCIES = \ $(top_builddir)/common/libcommon.la $(am__DEPENDENCIES_1) am_libxrdpneutrinordp_la_OBJECTS = xrdp-color.lo xrdp-neutrinordp.lo libxrdpneutrinordp_la_OBJECTS = $(am_libxrdpneutrinordp_la_OBJECTS) AM_V_lt = $(am__v_lt_@AM_V@) am__v_lt_ = $(am__v_lt_@AM_DEFAULT_V@) am__v_lt_0 = --silent am__v_lt_1 = libxrdpneutrinordp_la_LINK = $(LIBTOOL) $(AM_V_lt) --tag=CC \ $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=link $(CCLD) \ $(AM_CFLAGS) $(CFLAGS) $(libxrdpneutrinordp_la_LDFLAGS) \ $(LDFLAGS) -o $@ AM_V_P = $(am__v_P_@AM_V@) am__v_P_ = $(am__v_P_@AM_DEFAULT_V@) am__v_P_0 = false am__v_P_1 = : AM_V_GEN = $(am__v_GEN_@AM_V@) am__v_GEN_ = $(am__v_GEN_@AM_DEFAULT_V@) am__v_GEN_0 = @echo " GEN " $@; am__v_GEN_1 = AM_V_at = $(am__v_at_@AM_V@) am__v_at_ = $(am__v_at_@AM_DEFAULT_V@) am__v_at_0 = @ am__v_at_1 = DEFAULT_INCLUDES = -I.@am__isrc@ -I$(top_builddir) depcomp = $(SHELL) $(top_srcdir)/depcomp am__depfiles_maybe = depfiles am__mv = mv -f COMPILE = $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) \ $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) LTCOMPILE = $(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) \ $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) \ $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) \ $(AM_CFLAGS) $(CFLAGS) AM_V_CC = $(am__v_CC_@AM_V@) am__v_CC_ = $(am__v_CC_@AM_DEFAULT_V@) am__v_CC_0 = @echo " CC " $@; am__v_CC_1 = CCLD = $(CC) LINK = $(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) \ $(LIBTOOLFLAGS) --mode=link $(CCLD) $(AM_CFLAGS) $(CFLAGS) \ $(AM_LDFLAGS) $(LDFLAGS) -o $@ AM_V_CCLD = $(am__v_CCLD_@AM_V@) am__v_CCLD_ = $(am__v_CCLD_@AM_DEFAULT_V@) am__v_CCLD_0 = @echo " CCLD " $@; am__v_CCLD_1 = SOURCES = $(libxrdpneutrinordp_la_SOURCES) DIST_SOURCES = $(libxrdpneutrinordp_la_SOURCES) am__can_run_installinfo = \ case $$AM_UPDATE_INFO_DIR in \ n|no|NO) false;; \ *) (install-info --version) >/dev/null 2>&1;; \ esac am__tagged_files = $(HEADERS) $(SOURCES) $(TAGS_FILES) $(LISP) # Read a list of newline-separated strings from the standard input, # and print each of them once, without duplicates. Input order is # *not* preserved. am__uniquify_input = $(AWK) '\ BEGIN { nonempty = 0; } \ { items[$$0] = 1; nonempty = 1; } \ END { if (nonempty) { for (i in items) print i; }; } \ ' # Make sure the list of sources is unique. This is necessary because, # e.g., the same source file might be shared among _SOURCES variables # for different programs/libraries. am__define_uniq_tagged_files = \ list='$(am__tagged_files)'; \ unique=`for i in $$list; do \ if test -f "$$i"; then echo $$i; else echo $(srcdir)/$$i; fi; \ done | $(am__uniquify_input)` ETAGS = etags CTAGS = ctags am__DIST_COMMON = $(srcdir)/Makefile.in $(top_srcdir)/depcomp DISTFILES = $(DIST_COMMON) $(DIST_SOURCES) $(TEXINFOS) $(EXTRA_DIST) ACLOCAL = @ACLOCAL@ AMTAR = @AMTAR@ AM_DEFAULT_VERBOSITY = @AM_DEFAULT_VERBOSITY@ AR = @AR@ AUTOCONF = @AUTOCONF@ AUTOHEADER = @AUTOHEADER@ AUTOMAKE = @AUTOMAKE@ AWK = @AWK@ CC = @CC@ CCDEPMODE = @CCDEPMODE@ CFLAGS = @CFLAGS@ CPP = @CPP@ CPPFLAGS = @CPPFLAGS@ CYGPATH_W = @CYGPATH_W@ DEFS = @DEFS@ DEPDIR = @DEPDIR@ DLLTOOL = @DLLTOOL@ DLOPEN_LIBS = @DLOPEN_LIBS@ DSYMUTIL = @DSYMUTIL@ DUMPBIN = @DUMPBIN@ ECHO_C = @ECHO_C@ ECHO_N = @ECHO_N@ ECHO_T = @ECHO_T@ EGREP = @EGREP@ EXEEXT = @EXEEXT@ FDKAAC_CFLAGS = @FDKAAC_CFLAGS@ FDKAAC_LIBS = @FDKAAC_LIBS@ FGREP = @FGREP@ FREERDP_CFLAGS = @FREERDP_CFLAGS@ FREERDP_LIBS = @FREERDP_LIBS@ FUSE_CFLAGS = @FUSE_CFLAGS@ FUSE_LIBS = @FUSE_LIBS@ GREP = @GREP@ INSTALL = @INSTALL@ INSTALL_DATA = @INSTALL_DATA@ INSTALL_PROGRAM = @INSTALL_PROGRAM@ INSTALL_SCRIPT = @INSTALL_SCRIPT@ INSTALL_STRIP_PROGRAM = @INSTALL_STRIP_PROGRAM@ LD = @LD@ LDFLAGS = @LDFLAGS@ LIBOBJS = @LIBOBJS@ LIBS = @LIBS@ LIBTOOL = @LIBTOOL@ LIPO = @LIPO@ LN_S = @LN_S@ LTLIBOBJS = @LTLIBOBJS@ LT_SYS_LIBRARY_PATH = @LT_SYS_LIBRARY_PATH@ MAKEINFO = @MAKEINFO@ MANIFEST_TOOL = @MANIFEST_TOOL@ MKDIR_P = @MKDIR_P@ NM = @NM@ NMEDIT = @NMEDIT@ OBJDUMP = @OBJDUMP@ OBJEXT = @OBJEXT@ OPENSSL = @OPENSSL@ OPENSSL_CFLAGS = @OPENSSL_CFLAGS@ OPENSSL_LIBS = @OPENSSL_LIBS@ OTOOL = @OTOOL@ OTOOL64 = @OTOOL64@ PACKAGE = @PACKAGE@ PACKAGE_BUGREPORT = @PACKAGE_BUGREPORT@ PACKAGE_NAME = @PACKAGE_NAME@ PACKAGE_STRING = @PACKAGE_STRING@ PACKAGE_TARNAME = @PACKAGE_TARNAME@ PACKAGE_URL = @PACKAGE_URL@ PACKAGE_VERSION = @PACKAGE_VERSION@ PAM_RULES = @PAM_RULES@ PATH_SEPARATOR = @PATH_SEPARATOR@ PIXMAN_CFLAGS = @PIXMAN_CFLAGS@ PIXMAN_LIBS = @PIXMAN_LIBS@ PKG_CONFIG = @PKG_CONFIG@ PKG_CONFIG_LIBDIR = @PKG_CONFIG_LIBDIR@ PKG_CONFIG_PATH = @PKG_CONFIG_PATH@ RANLIB = @RANLIB@ SED = @SED@ SET_MAKE = @SET_MAKE@ SHELL = @SHELL@ STRIP = @STRIP@ TurboJpegIncDir = @TurboJpegIncDir@ TurboJpegLibDir = @TurboJpegLibDir@ VERSION = @VERSION@ XMKMF = @XMKMF@ X_CFLAGS = @X_CFLAGS@ X_EXTRA_LIBS = @X_EXTRA_LIBS@ X_LIBS = @X_LIBS@ X_PRE_LIBS = @X_PRE_LIBS@ abs_builddir = @abs_builddir@ abs_srcdir = @abs_srcdir@ abs_top_builddir = @abs_top_builddir@ abs_top_srcdir = @abs_top_srcdir@ ac_ct_AR = @ac_ct_AR@ ac_ct_CC = @ac_ct_CC@ ac_ct_DUMPBIN = @ac_ct_DUMPBIN@ am__include = @am__include@ am__leading_dot = @am__leading_dot@ am__quote = @am__quote@ am__tar = @am__tar@ am__untar = @am__untar@ bindir = @bindir@ build = @build@ build_alias = @build_alias@ build_cpu = @build_cpu@ build_os = @build_os@ build_vendor = @build_vendor@ builddir = @builddir@ datadir = @datadir@ datarootdir = @datarootdir@ docdir = @docdir@ dvidir = @dvidir@ exec_prefix = @exec_prefix@ host = @host@ host_alias = @host_alias@ host_cpu = @host_cpu@ host_os = @host_os@ host_vendor = @host_vendor@ htmldir = @htmldir@ includedir = @includedir@ infodir = @infodir@ install_sh = @install_sh@ libdir = @libdir@ libexecdir = @libexecdir@ localedir = @localedir@ localstatedir = @localstatedir@ mandir = @mandir@ mkdir_p = @mkdir_p@ moduledir = @moduledir@ oldincludedir = @oldincludedir@ pdfdir = @pdfdir@ pkgconfigdir = @pkgconfigdir@ prefix = @prefix@ program_transform_name = @program_transform_name@ psdir = @psdir@ sbindir = @sbindir@ sharedstatedir = @sharedstatedir@ socketdir = @socketdir@ srcdir = @srcdir@ subdirs = @subdirs@ sysconfdir = @sysconfdir@ systemdsystemunitdir = @systemdsystemunitdir@ target_alias = @target_alias@ top_build_prefix = @top_build_prefix@ top_builddir = @top_builddir@ top_srcdir = @top_srcdir@ AM_CPPFLAGS = -DXRDP_CFG_PATH=\"${sysconfdir}/xrdp\" \ -DXRDP_SBIN_PATH=\"${sbindir}\" \ -DXRDP_SHARE_PATH=\"${datadir}/xrdp\" \ -DXRDP_PID_PATH=\"${localstatedir}/run\" \ -I$(top_srcdir)/common $(FREERDP_CFLAGS) $(am__append_1) module_LTLIBRARIES = \ libxrdpneutrinordp.la libxrdpneutrinordp_la_SOURCES = \ xrdp-color.c \ xrdp-color.h \ xrdp-neutrinordp.c \ xrdp-neutrinordp.h libxrdpneutrinordp_la_LIBADD = \ $(top_builddir)/common/libcommon.la \ $(FREERDP_LIBS) libxrdpneutrinordp_la_LDFLAGS = -avoid-version -module all: all-am .SUFFIXES: .SUFFIXES: .c .lo .o .obj $(srcdir)/Makefile.in: $(srcdir)/Makefile.am $(am__configure_deps) @for dep in $?; do \ case '$(am__configure_deps)' in \ *$$dep*) \ ( cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh ) \ && { if test -f $@; then exit 0; else break; fi; }; \ exit 1;; \ esac; \ done; \ echo ' cd $(top_srcdir) && $(AUTOMAKE) --foreign neutrinordp/Makefile'; \ $(am__cd) $(top_srcdir) && \ $(AUTOMAKE) --foreign neutrinordp/Makefile Makefile: $(srcdir)/Makefile.in $(top_builddir)/config.status @case '$?' in \ *config.status*) \ cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh;; \ *) \ echo ' cd $(top_builddir) && $(SHELL) ./config.status $(subdir)/$@ $(am__depfiles_maybe)'; \ cd $(top_builddir) && $(SHELL) ./config.status $(subdir)/$@ $(am__depfiles_maybe);; \ esac; $(top_builddir)/config.status: $(top_srcdir)/configure $(CONFIG_STATUS_DEPENDENCIES) cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh $(top_srcdir)/configure: $(am__configure_deps) cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh $(ACLOCAL_M4): $(am__aclocal_m4_deps) cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh $(am__aclocal_m4_deps): install-moduleLTLIBRARIES: $(module_LTLIBRARIES) @$(NORMAL_INSTALL) @list='$(module_LTLIBRARIES)'; test -n "$(moduledir)" || list=; \ list2=; for p in $$list; do \ if test -f $$p; then \ list2="$$list2 $$p"; \ else :; fi; \ done; \ test -z "$$list2" || { \ echo " $(MKDIR_P) '$(DESTDIR)$(moduledir)'"; \ $(MKDIR_P) "$(DESTDIR)$(moduledir)" || exit 1; \ echo " $(LIBTOOL) $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=install $(INSTALL) $(INSTALL_STRIP_FLAG) $$list2 '$(DESTDIR)$(moduledir)'"; \ $(LIBTOOL) $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=install $(INSTALL) $(INSTALL_STRIP_FLAG) $$list2 "$(DESTDIR)$(moduledir)"; \ } uninstall-moduleLTLIBRARIES: @$(NORMAL_UNINSTALL) @list='$(module_LTLIBRARIES)'; test -n "$(moduledir)" || list=; \ for p in $$list; do \ $(am__strip_dir) \ echo " $(LIBTOOL) $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=uninstall rm -f '$(DESTDIR)$(moduledir)/$$f'"; \ $(LIBTOOL) $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=uninstall rm -f "$(DESTDIR)$(moduledir)/$$f"; \ done clean-moduleLTLIBRARIES: -test -z "$(module_LTLIBRARIES)" || rm -f $(module_LTLIBRARIES) @list='$(module_LTLIBRARIES)'; \ locs=`for p in $$list; do echo $$p; done | \ sed 's|^[^/]*$$|.|; s|/[^/]*$$||; s|$$|/so_locations|' | \ sort -u`; \ test -z "$$locs" || { \ echo rm -f $${locs}; \ rm -f $${locs}; \ } libxrdpneutrinordp.la: $(libxrdpneutrinordp_la_OBJECTS) $(libxrdpneutrinordp_la_DEPENDENCIES) $(EXTRA_libxrdpneutrinordp_la_DEPENDENCIES) $(AM_V_CCLD)$(libxrdpneutrinordp_la_LINK) -rpath $(moduledir) $(libxrdpneutrinordp_la_OBJECTS) $(libxrdpneutrinordp_la_LIBADD) $(LIBS) mostlyclean-compile: -rm -f *.$(OBJEXT) distclean-compile: -rm -f *.tab.c @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/xrdp-color.Plo@am__quote@ @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/xrdp-neutrinordp.Plo@am__quote@ .c.o: @am__fastdepCC_TRUE@ $(AM_V_CC)$(COMPILE) -MT $@ -MD -MP -MF $(DEPDIR)/$*.Tpo -c -o $@ $< @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) $(DEPDIR)/$*.Tpo $(DEPDIR)/$*.Po @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='$<' object='$@' libtool=no @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(COMPILE) -c -o $@ $< .c.obj: @am__fastdepCC_TRUE@ $(AM_V_CC)$(COMPILE) -MT $@ -MD -MP -MF $(DEPDIR)/$*.Tpo -c -o $@ `$(CYGPATH_W) '$<'` @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) $(DEPDIR)/$*.Tpo $(DEPDIR)/$*.Po @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='$<' object='$@' libtool=no @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(COMPILE) -c -o $@ `$(CYGPATH_W) '$<'` .c.lo: @am__fastdepCC_TRUE@ $(AM_V_CC)$(LTCOMPILE) -MT $@ -MD -MP -MF $(DEPDIR)/$*.Tpo -c -o $@ $< @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) $(DEPDIR)/$*.Tpo $(DEPDIR)/$*.Plo @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='$<' object='$@' libtool=yes @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(LTCOMPILE) -c -o $@ $< mostlyclean-libtool: -rm -f *.lo clean-libtool: -rm -rf .libs _libs ID: $(am__tagged_files) $(am__define_uniq_tagged_files); mkid -fID $$unique tags: tags-am TAGS: tags tags-am: $(TAGS_DEPENDENCIES) $(am__tagged_files) set x; \ here=`pwd`; \ $(am__define_uniq_tagged_files); \ shift; \ if test -z "$(ETAGS_ARGS)$$*$$unique"; then :; else \ test -n "$$unique" || unique=$$empty_fix; \ if test $$# -gt 0; then \ $(ETAGS) $(ETAGSFLAGS) $(AM_ETAGSFLAGS) $(ETAGS_ARGS) \ "$$@" $$unique; \ else \ $(ETAGS) $(ETAGSFLAGS) $(AM_ETAGSFLAGS) $(ETAGS_ARGS) \ $$unique; \ fi; \ fi ctags: ctags-am CTAGS: ctags ctags-am: $(TAGS_DEPENDENCIES) $(am__tagged_files) $(am__define_uniq_tagged_files); \ test -z "$(CTAGS_ARGS)$$unique" \ || $(CTAGS) $(CTAGSFLAGS) $(AM_CTAGSFLAGS) $(CTAGS_ARGS) \ $$unique GTAGS: here=`$(am__cd) $(top_builddir) && pwd` \ && $(am__cd) $(top_srcdir) \ && gtags -i $(GTAGS_ARGS) "$$here" cscopelist: cscopelist-am cscopelist-am: $(am__tagged_files) list='$(am__tagged_files)'; \ case "$(srcdir)" in \ [\\/]* | ?:[\\/]*) sdir="$(srcdir)" ;; \ *) sdir=$(subdir)/$(srcdir) ;; \ esac; \ for i in $$list; do \ if test -f "$$i"; then \ echo "$(subdir)/$$i"; \ else \ echo "$$sdir/$$i"; \ fi; \ done >> $(top_builddir)/cscope.files distclean-tags: -rm -f TAGS ID GTAGS GRTAGS GSYMS GPATH tags distdir: $(DISTFILES) @srcdirstrip=`echo "$(srcdir)" | sed 's/[].[^$$\\*]/\\\\&/g'`; \ topsrcdirstrip=`echo "$(top_srcdir)" | sed 's/[].[^$$\\*]/\\\\&/g'`; \ list='$(DISTFILES)'; \ dist_files=`for file in $$list; do echo $$file; done | \ sed -e "s|^$$srcdirstrip/||;t" \ -e "s|^$$topsrcdirstrip/|$(top_builddir)/|;t"`; \ case $$dist_files in \ */*) $(MKDIR_P) `echo "$$dist_files" | \ sed '/\//!d;s|^|$(distdir)/|;s,/[^/]*$$,,' | \ sort -u` ;; \ esac; \ for file in $$dist_files; do \ if test -f $$file || test -d $$file; then d=.; else d=$(srcdir); fi; \ if test -d $$d/$$file; then \ dir=`echo "/$$file" | sed -e 's,/[^/]*$$,,'`; \ if test -d "$(distdir)/$$file"; then \ find "$(distdir)/$$file" -type d ! -perm -700 -exec chmod u+rwx {} \;; \ fi; \ if test -d $(srcdir)/$$file && test $$d != $(srcdir); then \ cp -fpR $(srcdir)/$$file "$(distdir)$$dir" || exit 1; \ find "$(distdir)/$$file" -type d ! -perm -700 -exec chmod u+rwx {} \;; \ fi; \ cp -fpR $$d/$$file "$(distdir)$$dir" || exit 1; \ else \ test -f "$(distdir)/$$file" \ || cp -p $$d/$$file "$(distdir)/$$file" \ || exit 1; \ fi; \ done check-am: all-am check: check-am all-am: Makefile $(LTLIBRARIES) installdirs: for dir in "$(DESTDIR)$(moduledir)"; do \ test -z "$$dir" || $(MKDIR_P) "$$dir"; \ done install: install-am install-exec: install-exec-am install-data: install-data-am uninstall: uninstall-am install-am: all-am @$(MAKE) $(AM_MAKEFLAGS) install-exec-am install-data-am installcheck: installcheck-am install-strip: if test -z '$(STRIP)'; then \ $(MAKE) $(AM_MAKEFLAGS) INSTALL_PROGRAM="$(INSTALL_STRIP_PROGRAM)" \ install_sh_PROGRAM="$(INSTALL_STRIP_PROGRAM)" INSTALL_STRIP_FLAG=-s \ install; \ else \ $(MAKE) $(AM_MAKEFLAGS) INSTALL_PROGRAM="$(INSTALL_STRIP_PROGRAM)" \ install_sh_PROGRAM="$(INSTALL_STRIP_PROGRAM)" INSTALL_STRIP_FLAG=-s \ "INSTALL_PROGRAM_ENV=STRIPPROG='$(STRIP)'" install; \ fi mostlyclean-generic: clean-generic: distclean-generic: -test -z "$(CONFIG_CLEAN_FILES)" || rm -f $(CONFIG_CLEAN_FILES) -test . = "$(srcdir)" || test -z "$(CONFIG_CLEAN_VPATH_FILES)" || rm -f $(CONFIG_CLEAN_VPATH_FILES) maintainer-clean-generic: @echo "This command is intended for maintainers to use" @echo "it deletes files that may require special tools to rebuild." clean: clean-am clean-am: clean-generic clean-libtool clean-moduleLTLIBRARIES \ mostlyclean-am distclean: distclean-am -rm -rf ./$(DEPDIR) -rm -f Makefile distclean-am: clean-am distclean-compile distclean-generic \ distclean-tags dvi: dvi-am dvi-am: html: html-am html-am: info: info-am info-am: install-data-am: install-moduleLTLIBRARIES install-dvi: install-dvi-am install-dvi-am: install-exec-am: install-html: install-html-am install-html-am: install-info: install-info-am install-info-am: install-man: install-pdf: install-pdf-am install-pdf-am: install-ps: install-ps-am install-ps-am: installcheck-am: maintainer-clean: maintainer-clean-am -rm -rf ./$(DEPDIR) -rm -f Makefile maintainer-clean-am: distclean-am maintainer-clean-generic mostlyclean: mostlyclean-am mostlyclean-am: mostlyclean-compile mostlyclean-generic \ mostlyclean-libtool pdf: pdf-am pdf-am: ps: ps-am ps-am: uninstall-am: uninstall-moduleLTLIBRARIES .MAKE: install-am install-strip .PHONY: CTAGS GTAGS TAGS all all-am check check-am clean clean-generic \ clean-libtool clean-moduleLTLIBRARIES cscopelist-am ctags \ ctags-am distclean distclean-compile distclean-generic \ distclean-libtool distclean-tags distdir dvi dvi-am html \ html-am info info-am install install-am install-data \ install-data-am install-dvi install-dvi-am install-exec \ install-exec-am install-html install-html-am install-info \ install-info-am install-man install-moduleLTLIBRARIES \ install-pdf install-pdf-am install-ps install-ps-am \ install-strip installcheck installcheck-am installdirs \ maintainer-clean maintainer-clean-generic mostlyclean \ mostlyclean-compile mostlyclean-generic mostlyclean-libtool \ pdf pdf-am ps ps-am tags tags-am uninstall uninstall-am \ uninstall-moduleLTLIBRARIES .PRECIOUS: Makefile # Tell versions [3.59,3.63) of GNU make to not export all variables. # Otherwise a system limit (for SysV at least) may be exceeded. .NOEXPORT: xrdp-0.9.5/neutrinordp/xrdp-neutrinordp.h000644 001751 001751 00000021375 13133557325 020507 0ustar00metameta000000 000000 /** * FreeRDP: A Remote Desktop Protocol Server * freerdp wrapper * * Copyright 2011-2013 Jay Sorg * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ /* include other h files */ #include "arch.h" #include "parse.h" #include "os_calls.h" #include "defines.h" #include "xrdp_rail.h" #include "xrdp_client_info.h" /* this is the freerdp main header */ #include #include #include #include //#include //#include "/home/jay/git/jsorg71/staging/include/freerdp/freerdp.h" struct bitmap_item { int width; int height; char *data; }; struct brush_item { int bpp; int width; int height; char *data; char b8x8[8]; }; struct pointer_item { int hotx; int hoty; char data[32 * 32 * 4]; char mask[32 * 32 / 8]; int bpp; }; #define CURRENT_MOD_VER 3 struct mod { int size; /* size of this struct */ int version; /* internal version */ /* client functions */ int (*mod_start)(struct mod *v, int w, int h, int bpp); int (*mod_connect)(struct mod *v); int (*mod_event)(struct mod *v, int msg, long param1, long param2, long param3, long param4); int (*mod_signal)(struct mod *v); int (*mod_end)(struct mod *v); int (*mod_set_param)(struct mod *v, const char *name, const char *value); int (*mod_session_change)(struct mod *v, int, int); int (*mod_get_wait_objs)(struct mod *v, tbus *read_objs, int *rcount, tbus *write_objs, int *wcount, int *timeout); int (*mod_check_wait_objs)(struct mod *v); tintptr mod_dumby[100 - 9]; /* align, 100 minus the number of mod functions above */ /* server functions */ int (*server_begin_update)(struct mod *v); int (*server_end_update)(struct mod *v); int (*server_fill_rect)(struct mod *v, int x, int y, int cx, int cy); int (*server_screen_blt)(struct mod *v, int x, int y, int cx, int cy, int srcx, int srcy); int (*server_paint_rect)(struct mod *v, int x, int y, int cx, int cy, char *data, int width, int height, int srcx, int srcy); int (*server_set_pointer)(struct mod *v, int x, int y, char *data, char *mask); int (*server_palette)(struct mod *v, int *palette); int (*server_msg)(struct mod *v, char *msg, int code); int (*server_is_term)(struct mod *v); int (*server_set_clip)(struct mod *v, int x, int y, int cx, int cy); int (*server_reset_clip)(struct mod *v); int (*server_set_fgcolor)(struct mod *v, int fgcolor); int (*server_set_bgcolor)(struct mod *v, int bgcolor); int (*server_set_opcode)(struct mod *v, int opcode); int (*server_set_mixmode)(struct mod *v, int mixmode); int (*server_set_brush)(struct mod *v, int x_origin, int y_origin, int style, char *pattern); int (*server_set_pen)(struct mod *v, int style, int width); int (*server_draw_line)(struct mod *v, int x1, int y1, int x2, int y2); int (*server_add_char)(struct mod *v, int font, int character, int offset, int baseline, int width, int height, char *data); int (*server_draw_text)(struct mod *v, int font, int flags, int mixmode, int clip_left, int clip_top, int clip_right, int clip_bottom, int box_left, int box_top, int box_right, int box_bottom, int x, int y, char *data, int data_len); int (*server_reset)(struct mod *v, int width, int height, int bpp); int (*server_query_channel)(struct mod *v, int index, char *channel_name, int *channel_flags); int (*server_get_channel_id)(struct mod *v, const char *name); int (*server_send_to_channel)(struct mod *v, int channel_id, char *data, int data_len, int total_data_len, int flags); int (*server_bell_trigger)(struct mod *v); /* off screen bitmaps */ int (*server_create_os_surface)(struct mod *v, int rdpindex, int width, int height); int (*server_switch_os_surface)(struct mod *v, int rdpindex); int (*server_delete_os_surface)(struct mod *v, int rdpindex); int (*server_paint_rect_os)(struct mod *mod, int x, int y, int cx, int cy, int rdpindex, int srcx, int srcy); int (*server_set_hints)(struct mod *mod, int hints, int mask); /* rail */ int (*server_window_new_update)(struct mod *mod, int window_id, struct rail_window_state_order *window_state, int flags); int (*server_window_delete)(struct mod *mod, int window_id); int (*server_window_icon)(struct mod *mod, int window_id, int cache_entry, int cache_id, struct rail_icon_info *icon_info, int flags); int (*server_window_cached_icon)(struct mod *mod, int window_id, int cache_entry, int cache_id, int flags); int (*server_notify_new_update)(struct mod *mod, int window_id, int notify_id, struct rail_notify_state_order *notify_state, int flags); int (*server_notify_delete)(struct mod *mod, int window_id, int notify_id); int (*server_monitored_desktop)(struct mod *mod, struct rail_monitored_desktop_order *mdo, int flags); int (*server_set_pointer_ex)(struct mod *mod, int x, int y, char *data, char *mask, int bpp); int (*server_add_char_alpha)(struct mod* mod, int font, int character, int offset, int baseline, int width, int height, char* data); int (*server_create_os_surface_bpp)(struct mod* v, int rdpindex, int width, int height, int bpp); int (*server_paint_rect_bpp)(struct mod* v, int x, int y, int cx, int cy, char* data, int width, int height, int srcx, int srcy, int bpp); int (*server_composite)(struct mod* v, int srcidx, int srcformat, int srcwidth, int srcrepeat, int* srctransform, int mskflags, int mskidx, int mskformat, int mskwidth, int mskrepeat, int op, int srcx, int srcy, int mskx, int msky, int dstx, int dsty, int width, int height, int dstformat); int (*server_paint_rects)(struct mod* v, int num_drects, short *drects, int num_crects, short *crects, char *data, int width, int height, int flags, int frame_id); int (*server_session_info)(struct mod* v, const char *data, int data_bytes); tintptr server_dumby[100 - 44]; /* align, 100 minus the number of server functions above */ /* common */ tintptr handle; /* pointer to self as long */ tintptr wm; tintptr painter; tintptr si; /* mod data */ int sck; int width; int height; int bpp; int colormap[256]; char *chan_buf; int chan_buf_valid; int chan_buf_bytes; int vmaj; int vmin; int vrev; char username[256]; char password[256]; char domain[256]; int bool_keyBoardSynced ; /* Numlock can be out of sync, we hold state here to resolve */ int keyBoardLockInfo ; /* Holds initial numlock capslock state */ struct xrdp_client_info client_info; struct rdp_freerdp *inst; struct bitmap_item bitmap_cache[4][4096]; struct brush_item brush_cache[64]; struct pointer_item pointer_cache[32]; }; xrdp-0.9.5/neutrinordp/xrdp-color.h000644 001751 001751 00000001614 13174271344 017245 0ustar00metameta000000 000000 /** * FreeRDP: A Remote Desktop Protocol Server * freerdp wrapper * * Copyright 2011-2012 Jay Sorg * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ #ifndef __XRDP_COLOR_H #define __XRDP_COLOR_H char * convert_bitmap(int in_bpp, int out_bpp, char *bmpdata, int width, int height, int *palette); int convert_color(int in_bpp, int out_bpp, int in_color, int *palette); #endif xrdp-0.9.5/tests/tcp_proxy/000755 001751 001751 00000000000 13174271344 015621 5ustar00metameta000000 000000 xrdp-0.9.5/tests/gtcp_proxy/000755 001751 001751 00000000000 13174271344 015770 5ustar00metameta000000 000000 xrdp-0.9.5/tests/readme.txt000644 001751 001751 00000000052 12251743072 015562 0ustar00metameta000000 000000 this directory contains different tests xrdp-0.9.5/tests/memtest/000755 001751 001751 00000000000 13125122134 015234 5ustar00metameta000000 000000 xrdp-0.9.5/tests/.gitignore000644 001751 001751 00000000012 13127114621 015543 0ustar00metameta000000 000000 !Makefile xrdp-0.9.5/tests/memtest/memtest.c000644 001751 001751 00000002477 13125122134 017070 0ustar00metameta000000 000000 #include #include #include #include "libmem.h" int main(int argc, char** argv) { void* obj; unsigned int addr1; unsigned int addr2; unsigned int addr3; unsigned int addr4; unsigned int addr5; int index; int rd; srand(time(0)); obj = libmem_init(0x80000000, 64 * 1024 * 1024); for (index = 0; index < 256; index++) { rd = rand() & 0xffff; printf("1 rd %d\n", rd); addr1 = libmem_alloc(obj, rd); rd = rand() & 0xffff; printf("2 rd %d\n", rd); addr2 = libmem_alloc(obj, rd); rd = rand() & 0xffff; printf("3 rd %d\n", rd); addr3 = libmem_alloc(obj, rd); rd = rand() & 0xffff; printf("4 rd %d\n", rd); addr4 = libmem_alloc(obj, rd); addr5 = libmem_alloc(obj, rd); libmem_free(obj, addr1); printf("5\n"); addr1 = libmem_alloc(obj, 64); printf("6\n"); libmem_free(obj, addr3); printf("7\n"); addr3 = libmem_alloc(obj, 64 * 1024); libmem_free(obj, addr5); addr5 = libmem_alloc(obj, 64 * 1024); printf("8\n"); libmem_free(obj, addr1); printf("9\n"); libmem_free(obj, addr2); printf("10\n"); libmem_free(obj, addr3); libmem_free(obj, addr4); if (index == 255) { libmem_set_flags(obj, 1); } libmem_free(obj, addr5); } libmem_deinit(obj); return 0; } xrdp-0.9.5/tests/memtest/libmem.c000644 001751 001751 00000021223 13125122134 016645 0ustar00metameta000000 000000 #include #include #include #define ALIGN_BY 32 #define ALIGN_BY_M1 (ALIGN_BY - 1) #define ALIGN(_in) (((_in) + ALIGN_BY_M1) & (~ALIGN_BY_M1)) #define LLOG_LEVEL 1 #define LLOGLN(_log_level, _params) \ do { \ if (_log_level < LLOG_LEVEL) \ { \ printf _params ; \ printf ("\n") ; \ } \ } while (0) struct mem_item { unsigned int addr; int bytes; struct mem_item* next; struct mem_item* prev; }; struct mem_info { unsigned int addr; int bytes; int flags; struct mem_item* free_head; struct mem_item* free_tail; struct mem_item* used_head; struct mem_item* used_tail; int total_bytes; }; /*****************************************************************************/ static int libmem_free_mem_item(struct mem_info* self, struct mem_item* mi) { if (self == 0 || mi == 0) { return 0; } if (mi->prev != 0) { mi->prev->next = mi->next; } if (mi->next != 0) { mi->next->prev = mi->prev; } if (mi == self->free_head) { self->free_head = mi->next; } if (mi == self->free_tail) { self->free_tail = mi->prev; } if (mi == self->used_head) { self->used_head = mi->next; } if (mi == self->used_tail) { self->used_tail = mi->prev; } free(mi); return 0; } /*****************************************************************************/ void* libmem_init(unsigned int addr, int bytes) { struct mem_info* self; struct mem_item* mi; self = (struct mem_info*)malloc(sizeof(struct mem_info)); memset(self, 0, sizeof(struct mem_info)); self->addr = addr; self->bytes = bytes; //self->flags = 1; mi = (struct mem_item*)malloc(sizeof(struct mem_item)); memset(mi, 0, sizeof(struct mem_item)); mi->addr = addr; mi->bytes = bytes; self->free_head = mi; self->free_tail = mi; return self; } /*****************************************************************************/ void libmem_deinit(void* aself) { struct mem_info* self; self = (struct mem_info*)aself; if (self == 0) { return; } while (self->free_head != 0) { libmem_free_mem_item(self, self->free_head); } while (self->used_head != 0) { libmem_free_mem_item(self, self->used_head); } free(self); } /****************************************************************************/ static int libmem_add_used_item(struct mem_info* self, unsigned int addr, int bytes) { struct mem_item* mi; struct mem_item* new_mi; int added; if (self == 0 || addr == 0) { return 1; } if (self->used_head == 0) { /* add first item */ new_mi = (struct mem_item*)malloc(sizeof(struct mem_item)); memset(new_mi, 0, sizeof(struct mem_item)); new_mi->addr = addr; new_mi->bytes = bytes; self->used_head = new_mi; self->used_tail = new_mi; return 0; } added = 0; mi = self->used_head; while (mi != 0) { if (mi->addr > addr) { /* add before */ new_mi = (struct mem_item*)malloc(sizeof(struct mem_item)); memset(new_mi, 0, sizeof(struct mem_item)); new_mi->addr = addr; new_mi->bytes = bytes; new_mi->prev = mi->prev; new_mi->next = mi; if (mi->prev != 0) { mi->prev->next = new_mi; } mi->prev = new_mi; if (self->used_head == mi) { self->used_head = new_mi; } added = 1; break; } mi = mi->next; } if (!added) { /* add last */ new_mi = (struct mem_item*)malloc(sizeof(struct mem_item)); memset(new_mi, 0, sizeof(struct mem_item)); new_mi->addr = addr; new_mi->bytes = bytes; self->used_tail->next = new_mi; new_mi->prev = self->used_tail; self->used_tail = new_mi; } return 0; } /****************************************************************************/ static int libmem_add_free_item(struct mem_info* self, unsigned int addr, int bytes) { struct mem_item* mi; struct mem_item* new_mi; int added; if (self == 0 || addr == 0) { return 1; } if (self->free_head == 0) { /* add first item */ new_mi = (struct mem_item*)malloc(sizeof(struct mem_item)); memset(new_mi, 0, sizeof(struct mem_item)); new_mi->addr = addr; new_mi->bytes = bytes; self->free_head = new_mi; self->free_tail = new_mi; return 0; } added = 0; mi = self->free_head; while (mi != 0) { if (mi->addr > addr) { if (mi->prev != 0) { if (mi->prev->addr + mi->prev->bytes == addr) { /* don't need to add, just make prev bigger */ mi->prev->bytes += bytes; if (mi->prev->addr + mi->prev->bytes == mi->addr) { /* here we can remove one */ mi->prev->bytes += mi->bytes; libmem_free_mem_item(self, mi); } return 0; } } if (addr + bytes == mi->addr) { /* don't need to add here either */ mi->addr = addr; mi->bytes += bytes; return 0; } /* add before */ new_mi = (struct mem_item*)malloc(sizeof(struct mem_item)); memset(new_mi, 0, sizeof(struct mem_item)); new_mi->addr = addr; new_mi->bytes = bytes; new_mi->prev = mi->prev; new_mi->next = mi; if (mi->prev != 0) { mi->prev->next = new_mi; } mi->prev = new_mi; if (self->free_head == mi) { self->free_head = new_mi; } added = 1; break; } mi = mi->next; } if (!added) { /* add last */ new_mi = (struct mem_item*)malloc(sizeof(struct mem_item)); memset(new_mi, 0, sizeof(struct mem_item)); new_mi->addr = addr; new_mi->bytes = bytes; self->free_tail->next = new_mi; new_mi->prev = self->free_tail; self->free_tail = new_mi; } return 0; } /*****************************************************************************/ static int libmem_print(struct mem_info* self) { struct mem_item* mi; LLOGLN(0, ("libmem_print:")); LLOGLN(0, (" used_head %p", self->used_head)); LLOGLN(0, (" used_tail %p", self->used_tail)); mi = self->used_head; if (mi != 0) { LLOGLN(0, (" used list")); while (mi != 0) { LLOGLN(0, (" ptr %p prev %p next %p addr 0x%8.8x bytes %d", mi, mi->prev, mi->next, mi->addr, mi->bytes)); mi = mi->next; } } LLOGLN(0, (" free_head %p", self->free_head)); LLOGLN(0, (" free_tail %p", self->free_tail)); mi = self->free_head; if (mi != 0) { LLOGLN(0, (" free list")); while (mi != 0) { LLOGLN(0, (" ptr %p prev %p next %p addr 0x%8.8x bytes %d", mi, mi->prev, mi->next, mi->addr, mi->bytes)); mi = mi->next; } } return 0; } /*****************************************************************************/ unsigned int libmem_alloc(void* obj, int bytes) { struct mem_info* self; struct mem_item* mi; unsigned int addr; if (bytes < 1) { return 0; } bytes = ALIGN(bytes); self = (struct mem_info*)obj; addr = 0; mi = self->free_head; while (mi != 0) { if (bytes <= mi->bytes) { addr = mi->addr; mi->bytes -= bytes; mi->addr += bytes; if (mi->bytes < 1) { libmem_free_mem_item(self, mi); } break; } mi = mi->next; } if (addr != 0) { self->total_bytes += bytes; libmem_add_used_item(self, addr, bytes); if (self->flags & 1) { libmem_print(self); } } else { LLOGLN(0, ("libmem_alloc: error")); } return addr; } /*****************************************************************************/ int libmem_free(void* obj, unsigned int addr) { struct mem_info* self; struct mem_item* mi; if (addr == 0) { return 0; } self = (struct mem_info*)obj; mi = self->used_tail; while (mi != 0) { if (mi->addr == addr) { self->total_bytes -= mi->bytes; libmem_add_free_item(self, mi->addr, mi->bytes); libmem_free_mem_item(self, mi); if (self->flags & 1) { libmem_print(self); } return 0; } mi = mi->prev; } LLOGLN(0, ("libmem_free: error")); return 1; } /*****************************************************************************/ int libmem_set_flags(void* obj, int flags) { struct mem_info* self; self = (struct mem_info*)obj; self->flags |= flags; return 0; } /*****************************************************************************/ int libmem_clear_flags(void* obj, int flags) { struct mem_info* self; self = (struct mem_info*)obj; self->flags &= ~flags; return 0; } /*****************************************************************************/ int libmem_get_alloced_bytes(void* obj) { struct mem_info* self; self = (struct mem_info*)obj; return self->total_bytes; } xrdp-0.9.5/tests/memtest/libmem.h000644 001751 001751 00000000543 13125122134 016654 0ustar00metameta000000 000000 #ifndef _LIBMEM_C #define _LIBMEM_C void* libmem_init(unsigned int addr, int bytes); void libmem_deinit(void* aself); unsigned int libmem_alloc(void* obj, int bytes); int libmem_free(void* obj, unsigned int addr); int libmem_set_flags(void* obj, int flags); int libmem_clear_flags(void* obj, int flags); int libmem_get_alloced_bytes(void* obj); #endif xrdp-0.9.5/tests/memtest/Makefile000644 001751 001751 00000000226 13125122134 016674 0ustar00metameta000000 000000 OBJS = libmem.o memtest.o #CFLAGS = -O2 -Wall CFLAGS = -g all: memtest memtest: $(OBJS) $(CC) -o memtest $(OBJS) clean: rm -f $(OBJS) librdp.a xrdp-0.9.5/tests/gtcp_proxy/gtcp-proxy.c000644 001751 001751 00000046224 13127114621 020250 0ustar00metameta000000 000000 /** * xrdp: A Remote Desktop Protocol server. * * Copyright (C) Laxmikant Rashinkar 2013 LK.Rashinkar@gmail.com * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ #include #include #include #include "gtcp.h" #define WINDOW_TITLE "Tcp Proxy Version 1.0" #define CONTEXT_ID 1 #define MSG_INFO GTK_MESSAGE_INFO #define MSG_WARN GTK_MESSAGE_WARNING #define MSG_ERROR GTK_MESSAGE_ERROR #define MAIN_THREAD_YES 0 #define MAIN_THREAD_NO 1 /* globals */ pthread_t g_tid; int g_keep_running = 1; int g_loc_io_count = 0; /* bytes read from local port */ int g_rem_io_count = 0; /* bytes read from remote port */ GtkWidget *g_btn_start; GtkWidget *g_tbx_loc_port; GtkWidget *g_tbx_rem_ip; GtkWidget *g_tbx_rem_port; GtkWidget *g_tbx_loc_stats; GtkWidget *g_tbx_rem_stats; GtkWidget *g_statusbar; GtkWidget *g_txtvu_loc_port; GtkWidget *g_txtvu_rem_port; /* forward declarations */ static void *tcp_proxy(void *arg); static void show_msg(int not_main_thread, int style, const gchar *title, const gchar *msg); static void show_status(int not_main_thread, char *msg); static void clear_status(int not_main_thread); static void enable_btn_start(int main_thread); static void disable_btn_start(int main_thread); /* getters */ static char *get_local_port(); static char *get_remote_ip(); static char *get_remote_port(); /* setters */ static void show_loc_port_stats(int main_thread, int count); static void show_rem_port_stats(int main_thread, int count); /* handlers */ static gboolean on_delete_event(GtkWidget *widget, GdkEvent *ev, gpointer data); static void on_destroy(GtkWidget *widget, gpointer data); static void on_start_clicked(GtkWidget *widget, gpointer data); static void on_clear_clicked(GtkWidget *widget, gpointer data); static void on_quit_clicked(GtkWidget *widget, gpointer data); int main(int argc, char **argv) { /* init threads */ g_thread_init(NULL); gdk_threads_init(); /* setup GTK */ gtk_init(&argc, &argv); /* create labels and right justify them */ GtkWidget *lbl_loc_port = gtk_label_new("Local port"); GtkWidget *lbl_rem_ip = gtk_label_new("Remote IP"); GtkWidget *lbl_rem_port = gtk_label_new("Remote port"); GtkWidget *lbl_loc_stats = gtk_label_new("Local port recv stats"); GtkWidget *lbl_rem_stats = gtk_label_new("Remote port recv stats"); gtk_misc_set_alignment(GTK_MISC(lbl_loc_port), 1.0, 0.5); gtk_misc_set_alignment(GTK_MISC(lbl_rem_ip), 1.0, 0.5); gtk_misc_set_alignment(GTK_MISC(lbl_rem_port), 1.0, 0.5); gtk_misc_set_alignment(GTK_MISC(lbl_loc_stats), 1.0, 0.5); gtk_misc_set_alignment(GTK_MISC(lbl_rem_stats), 1.0, 0.5); /* create text boxes */ g_tbx_loc_port = gtk_entry_new(); g_tbx_rem_ip = gtk_entry_new(); g_tbx_rem_port = gtk_entry_new(); g_tbx_loc_stats = gtk_entry_new(); g_tbx_rem_stats = gtk_entry_new(); /* stat text boxes are read only */ gtk_entry_set_editable(GTK_ENTRY(g_tbx_loc_stats), FALSE); gtk_entry_set_editable(GTK_ENTRY(g_tbx_rem_stats), FALSE); /* enable when debugging */ #if 0 gtk_entry_set_text(GTK_ENTRY(g_tbx_loc_port), "1234"); gtk_entry_set_text(GTK_ENTRY(g_tbx_rem_ip), "192.168.2.20"); gtk_entry_set_text(GTK_ENTRY(g_tbx_rem_port), "43222"); #endif /* setup buttons inside a HBox */ g_btn_start = gtk_button_new_with_label("Start listening"); GtkWidget *btn_clear = gtk_button_new_with_label("Clear receive stats"); GtkWidget *btn_quit = gtk_button_new_with_label("Quit application"); GtkWidget *hbox = gtk_hbox_new(FALSE, 5); gtk_box_pack_start_defaults(GTK_BOX(hbox), g_btn_start); gtk_box_pack_start_defaults(GTK_BOX(hbox), btn_clear); gtk_box_pack_start_defaults(GTK_BOX(hbox), btn_quit); #if 0 g_txtvu_loc_port = gtk_text_view_new(); g_txtvu_rem_port = gtk_text_view_new(); #endif /* create table */ GtkWidget *table = gtk_table_new(8, 3, FALSE); int row = 0; /* insert labels into table */ gtk_table_attach(GTK_TABLE(table), lbl_loc_port, 0, 1, row, row + 1, GTK_FILL, GTK_FILL, 5, 0); row++; gtk_table_attach(GTK_TABLE(table), lbl_rem_ip, 0, 1, row, row + 1, GTK_FILL, GTK_FILL, 5, 0); row++; gtk_table_attach(GTK_TABLE(table), lbl_rem_port, 0, 1, row, row + 1, GTK_FILL, GTK_FILL, 5, 0); row++; gtk_table_attach(GTK_TABLE(table), lbl_loc_stats, 0, 1, row, row + 1, GTK_FILL, GTK_FILL, 5, 0); row++; gtk_table_attach(GTK_TABLE(table), lbl_rem_stats, 0, 1, row, row + 1, GTK_FILL, GTK_FILL, 5, 0); row++; row = 0; /* insert text boxes into table */ gtk_table_attach(GTK_TABLE(table), g_tbx_loc_port, 1, 2, row, row + 1, GTK_FILL, GTK_FILL, 5, 0); row++; gtk_table_attach(GTK_TABLE(table), g_tbx_rem_ip, 1, 2, row, row + 1, GTK_FILL, GTK_FILL, 5, 0); row++; gtk_table_attach(GTK_TABLE(table), g_tbx_rem_port, 1, 2, row, row + 1, GTK_FILL, GTK_FILL, 5, 0); row++; gtk_table_attach(GTK_TABLE(table), g_tbx_loc_stats, 1, 2, row, row + 1, GTK_FILL, GTK_FILL, 5, 0); row++; gtk_table_attach(GTK_TABLE(table), g_tbx_rem_stats, 1, 2, row, row + 1, GTK_FILL, GTK_FILL, 5, 0); row++; row++; /* insert hbox with buttons into table */ gtk_table_attach(GTK_TABLE(table), hbox, 1, 2, row, row + 1, GTK_FILL, GTK_FILL, 5, 0); row++; #if 0 /* text view to display hexdumps */ gtk_table_attach(GTK_TABLE(table), g_txtvu_loc_port, 0, 2, row, row + 1, GTK_FILL, GTK_FILL, 5, 0); row++; #endif /* status bar to display messages */ g_statusbar = gtk_statusbar_new(); gtk_statusbar_set_has_resize_grip(GTK_STATUSBAR(g_statusbar), TRUE); gtk_table_attach(GTK_TABLE(table), g_statusbar, 0, 2, row, row + 1, GTK_FILL, GTK_FILL, 5, 0); /* setup main window */ GtkWidget *window = gtk_window_new(GTK_WINDOW_TOPLEVEL); gtk_container_set_border_width(GTK_CONTAINER(window), 5); gtk_window_set_default_size(GTK_WINDOW(window), 640, 480); gtk_window_set_title(GTK_WINDOW(window), WINDOW_TITLE); gtk_window_set_position(GTK_WINDOW(window), GTK_WIN_POS_CENTER); gtk_window_set_resizable(GTK_WINDOW(window), FALSE); gtk_container_add(GTK_CONTAINER(window), table); gtk_widget_show_all(window); /* setup callbacks */ g_signal_connect(window, "delete-event", G_CALLBACK(on_delete_event), NULL); g_signal_connect(window, "destroy", G_CALLBACK(on_destroy), NULL); g_signal_connect(g_btn_start, "clicked", G_CALLBACK(on_start_clicked), NULL); g_signal_connect(btn_clear, "clicked", G_CALLBACK(on_clear_clicked), NULL); g_signal_connect(btn_quit, "clicked", G_CALLBACK(on_quit_clicked), NULL); gdk_threads_enter(); gtk_main(); gdk_threads_leave(); return 0; } /** * Start listening on specified local socket; when we get a connection, * connect to specified remote server and transfer data between local * and remote server *****************************************************************************/ static void *tcp_proxy(void *arg) { char buf[1024 * 32]; int lis_skt = -1; int acc_skt = -1; int con_skt = -1; int sel = 0; int rv = 0; int i = 0; int count = 0; int sent = 0; /* create listener socket */ if ((lis_skt = tcp_socket_create()) < 0) { show_msg(MAIN_THREAD_NO, MSG_ERROR, "Creating socket", "\nOperation failed. System out of resources"); enable_btn_start(MAIN_THREAD_NO); return NULL; } /* place it in non blocking mode */ tcp_set_non_blocking(lis_skt); if ((rv = tcp_bind(lis_skt, get_local_port())) != 0) { show_msg(MAIN_THREAD_NO, MSG_ERROR, "Bind error", "\nUnable to bind socket, cannot continue"); tcp_close(lis_skt); enable_btn_start(MAIN_THREAD_NO); return NULL; } /* listen for incoming connection */ if (tcp_listen(lis_skt)) { show_msg(MAIN_THREAD_NO, MSG_ERROR, "Listen error", "\nUnable to listen on socket, cannot continue"); tcp_close(lis_skt); enable_btn_start(MAIN_THREAD_NO); return NULL; } show_status(MAIN_THREAD_NO, "Waiting for client connections"); /* accept incoming connection */ while (g_keep_running) { acc_skt = tcp_accept(lis_skt); if (acc_skt > 0) { /* client connected */ show_status(MAIN_THREAD_NO, "Client connected"); tcp_close(lis_skt); lis_skt = -1; break; } if ((acc_skt < 0) && (tcp_last_error_would_block())) { /* no connection, try again */ usleep(250); continue; } else { tcp_close(lis_skt); lis_skt = -1; enable_btn_start(MAIN_THREAD_NO); return NULL; } } /* we have a client connection, try connecting to server */ if ((con_skt = tcp_socket()) < 0) { show_msg(MAIN_THREAD_NO, MSG_ERROR, "Creating socket", "\nOperation failed. System out of resources"); tcp_close(lis_skt); tcp_close(acc_skt); enable_btn_start(MAIN_THREAD_NO); return NULL; } /* place it in non blocking mode */ tcp_set_non_blocking(con_skt); rv = tcp_connect(con_skt, get_remote_ip(), get_remote_port()); #if 0 if (rv < 0) { show_status(MAIN_THREAD_NO, "Could not connect to server"); tcp_close(lis_skt); tcp_close(acc_skt); enable_btn_start(MAIN_THREAD_NO); return NULL; } #endif if ((rv < 0) && (tcp_last_error_would_block(con_skt))) { for (i = 0; i < 100; i++) { if (tcp_can_send(con_skt, 100)) break; usleep(100); } if (i == 100) { show_status(MAIN_THREAD_NO, "Could not connect to server"); tcp_close(lis_skt); tcp_close(acc_skt); enable_btn_start(MAIN_THREAD_NO); return NULL; } } show_status(MAIN_THREAD_NO, "Connected to server"); rv = 0; while (g_keep_running && rv == 0) { if ((sel = tcp_select(con_skt, acc_skt)) == 0) { usleep(10); continue; } if (sel & 1) { /* can read from con_skt without blocking */ count = tcp_recv(con_skt, buf, 1024 * 16, 0); rv = count < 1; if (rv == 0) { g_loc_io_count += count; show_loc_port_stats(MAIN_THREAD_NO, g_loc_io_count); /* TODO: hexdump data here */ sent = 0; while ((sent < count) && (rv == 0) && (g_keep_running)) { i = tcp_send(acc_skt, buf + sent, count - sent, 0); if ((i == -1) && tcp_last_error_would_block(acc_skt)) { tcp_can_send(acc_skt, 1000); } else if (i < 1) { rv = 1; } else { sent += i; } } } } if (sel & 2) { /* can read from acc_skt without blocking */ count = tcp_recv(acc_skt, buf, 1024 * 16, 0); rv = count < 1; if (rv == 0) { g_rem_io_count += count; show_rem_port_stats(MAIN_THREAD_NO, g_rem_io_count); /* TODO: hexdump data here */ sent = 0; while ((sent < count) && (rv == 0) && (g_keep_running)) { i = tcp_send(con_skt, buf + sent, count - sent, 0); if ((i == -1) && tcp_last_error_would_block(con_skt)) { tcp_can_send(con_skt, 1000); } else if (i < 1) { rv = 1; } else { sent += i; } } } } } tcp_close(lis_skt); tcp_close(con_skt); tcp_close(acc_skt); show_status(MAIN_THREAD_NO, "Connection closed"); enable_btn_start(MAIN_THREAD_NO); return NULL; } /** * Display a message using specified style dialog * * @param style information, warning or error * @param title text to be displayed in title bar * @param msg message to be displayed *****************************************************************************/ static void show_msg(int not_main_window, int style, const gchar *title, const gchar *msg) { GtkWidget *dialog; if (not_main_window) gdk_threads_enter(); dialog = gtk_message_dialog_new(GTK_WINDOW(NULL), GTK_DIALOG_DESTROY_WITH_PARENT, style, GTK_BUTTONS_OK, "%s", msg); gtk_window_set_title(GTK_WINDOW(dialog), title); gtk_dialog_run(GTK_DIALOG(dialog)); gtk_widget_destroy(dialog); if (not_main_window) gdk_threads_leave(); } /** * Write message to status bar *****************************************************************************/ static void show_status(int not_main_thread, char *msg) { if (not_main_thread) gdk_threads_enter(); gtk_statusbar_push(GTK_STATUSBAR(g_statusbar), CONTEXT_ID, msg); if (not_main_thread) gdk_threads_leave(); } /** * Clear status bar *****************************************************************************/ static void clear_status(int not_main_thread) { if (not_main_thread) gdk_threads_enter(); gtk_statusbar_remove_all(GTK_STATUSBAR(g_statusbar), CONTEXT_ID); if (not_main_thread) gdk_threads_leave(); } /** * Enable 'Start Listening' button *****************************************************************************/ static void enable_btn_start(int not_main_thread) { if (not_main_thread) gdk_threads_enter(); gtk_widget_set_sensitive(GTK_WIDGET(g_btn_start), TRUE); if (not_main_thread) gdk_threads_leave(); } /** * Disable 'Start Listening' button *****************************************************************************/ static void disable_btn_start(int not_main_thread) { if (not_main_thread) gdk_threads_enter(); gtk_widget_set_sensitive(GTK_WIDGET(g_btn_start), FALSE); if (not_main_thread) gdk_threads_leave(); } /** * Return local port setting *****************************************************************************/ static char *get_local_port() { const char *cptr = gtk_entry_get_text(GTK_ENTRY(g_tbx_loc_port)); return (char *) cptr; } /** * Return remote IP setting *****************************************************************************/ static char *get_remote_ip() { const char *cptr = gtk_entry_get_text(GTK_ENTRY(g_tbx_rem_ip)); return (char *) cptr; } /** * Return remote port setting *****************************************************************************/ static char *get_remote_port() { const char *cptr = gtk_entry_get_text(GTK_ENTRY(g_tbx_rem_port)); return (char *) cptr; } /** * Update local port stat counter *****************************************************************************/ static void show_loc_port_stats(int not_main_thread, int count) { char buf[128]; sprintf(buf, "%d", count); if (not_main_thread) gdk_threads_enter(); gtk_entry_set_text(GTK_ENTRY(g_tbx_loc_stats), buf); if (not_main_thread) gdk_threads_leave(); } /** * Update remote port stat counter *****************************************************************************/ static void show_rem_port_stats(int not_main_thread, int count) { char buf[128]; sprintf(buf, "%d", count); if (not_main_thread) gdk_threads_enter(); gtk_entry_set_text(GTK_ENTRY(g_tbx_rem_stats), buf); if (not_main_thread) gdk_threads_leave(); } /** * User clicked on window close button *****************************************************************************/ static gboolean on_delete_event(GtkWidget *widget, GdkEvent *ev, gpointer data) { return FALSE; } /** * Close application *****************************************************************************/ static void on_destroy(GtkWidget *widget, gpointer data) { /* this will destroy all windows and return control to gtk_main() */ gtk_main_quit(); } /** * Start a thread that listens for incoming connections *****************************************************************************/ static void on_start_clicked(GtkWidget *widget, gpointer data) { /* local port must be specified */ if (gtk_entry_get_text_length(GTK_ENTRY(g_tbx_loc_port)) == 0) { show_msg(MAIN_THREAD_YES, MSG_ERROR, "Invalid entry", "\nYou must enter a value for Local Port"); return; } /* remote IP must be specified */ if (gtk_entry_get_text_length(GTK_ENTRY(g_tbx_rem_ip)) == 0) { show_msg(MAIN_THREAD_YES, MSG_ERROR, "Invalid entry", "\nYou must enter a value for Remote IP"); return; } /* remote port must be specified */ if (gtk_entry_get_text_length(GTK_ENTRY(g_tbx_rem_port)) == 0) { show_msg(MAIN_THREAD_YES, MSG_ERROR, "Invalid entry", "\nYou must enter a value for Remote Port"); return; } if (pthread_create(&g_tid, NULL, tcp_proxy, NULL)) { show_msg(MAIN_THREAD_YES, MSG_ERROR, "Starting listener", "\nThread create error. System out of resources"); return; } disable_btn_start(MAIN_THREAD_YES); } /** * Clear stat counters *****************************************************************************/ static void on_clear_clicked(GtkWidget *widget, gpointer data) { g_loc_io_count = 0; g_rem_io_count = 0; show_loc_port_stats(MAIN_THREAD_YES, g_loc_io_count); show_rem_port_stats(MAIN_THREAD_YES, g_rem_io_count); } /** * Quit application *****************************************************************************/ static void on_quit_clicked(GtkWidget *widget, gpointer data) { /* this will destroy all windows and return control to gtk_main() */ gtk_main_quit(); } xrdp-0.9.5/tests/gtcp_proxy/Makefile000644 001751 001751 00000000715 13174271344 017433 0ustar00metameta000000 000000 # := evaluates the expression just once # = evaluates the expression each time it is used CFLAGS := $(shell pkg-config --cflags gtk+-2.0) CFLAGS += -O2 -Wall #LDFLAGS = -Wl LIBS := $(shell pkg-config --libs gtk+-2.0) LIBS += -ldl -lgthread-2.0 OBJS = gtcp-proxy.o gtcp.o all: gtcp-proxy gtcp-proxy: $(OBJS) gcc -Wall $(CFLAGS) $(LDFLAGS) gtcp-proxy.c gtcp.o -o gtcp-proxy $(LIBS) gtcp.o: gtcp.c gcc -c gtcp.c clean:: -rm gtcp-proxy.o gtcp.o gtcp-proxy xrdp-0.9.5/tests/gtcp_proxy/gtcp.c000644 001751 001751 00000020725 13127114621 017067 0ustar00metameta000000 000000 /** * xrdp: A Remote Desktop Protocol server. * * Copyright (C) Jay Sorg 2013 * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ #include "gtcp.h" /** * Return a newly created socket or -1 on error *****************************************************************************/ int tcp_socket_create(void) { int rv; int option_value; socklen_t option_len; /* in win32 a socket is an unsigned int, in linux, it's an int */ if ((rv = (int) socket(PF_INET, SOCK_STREAM, 0)) < 0) return -1; option_len = sizeof(option_value); if (getsockopt(rv, SOL_SOCKET, SO_REUSEADDR, (char *) &option_value, &option_len) == 0) { if (option_value == 0) { option_value = 1; option_len = sizeof(option_value); setsockopt(rv, SOL_SOCKET, SO_REUSEADDR, (char *) &option_value, option_len); } } option_len = sizeof(option_value); if (getsockopt(rv, SOL_SOCKET, SO_SNDBUF, (char *) &option_value, &option_len) == 0) { if (option_value < (1024 * 32)) { option_value = 1024 * 32; option_len = sizeof(option_value); setsockopt(rv, SOL_SOCKET, SO_SNDBUF, (char *) &option_value, option_len); } } return rv; } /** * Place specified socket in non blocking mode *****************************************************************************/ void tcp_set_non_blocking(int skt) { unsigned long i; #if defined(_WIN32) i = 1; ioctlsocket(skt, FIONBIO, &i); #else i = fcntl(skt, F_GETFL); i = i | O_NONBLOCK; fcntl(skt, F_SETFL, i); #endif } /** * Assign name to socket * * @param skt the socket to bind * @param port the port to bind to * * @return 0 on success, -1 on error *****************************************************************************/ int tcp_bind(int skt, char *port) { struct sockaddr_in s; memset(&s, 0, sizeof(struct sockaddr_in)); s.sin_family = AF_INET; s.sin_port = htons((uint16_t) atoi(port)); s.sin_addr.s_addr = INADDR_ANY; return bind(skt, (struct sockaddr *) &s, sizeof(struct sockaddr_in)); } /** * Listen for incoming connections * * @param skt the socket to listen on * * @return 0 on success, -1 on error *****************************************************************************/ int tcp_listen(int skt) { return listen(skt, 2); } /** * Accept incoming connection * * @param skt socket to accept incoming connection on * * @return 0 on success, -1 on error *****************************************************************************/ int tcp_accept(int skt) { int ret ; char ipAddr[256] ; struct sockaddr_in s; socklen_t i; i = sizeof(struct sockaddr_in); memset(&s, 0, i); return accept(skt, (struct sockaddr *)&s, &i); } /** * Check if the socket would block * * @return TRUE if would block, else FALSE *****************************************************************************/ int tcp_last_error_would_block() { #if defined(_WIN32) return WSAGetLastError() == WSAEWOULDBLOCK; #else return (errno == EWOULDBLOCK) || (errno == EAGAIN) || (errno == EINPROGRESS); #endif } /** * Close specified socket *****************************************************************************/ void tcp_close(int skt) { if (skt <= 0) return; #if defined(_WIN32) closesocket(skt); #else close(skt); #endif } /** * Create a new socket * * @return new socket or -1 on error *****************************************************************************/ int tcp_socket(void) { int rv; int option_value; socklen_t option_len; /* in win32 a socket is an unsigned int, in linux, it's an int */ if ((rv = (int) socket(PF_INET, SOCK_STREAM, 0)) < 0) return -1; option_len = sizeof(option_value); if (getsockopt(rv, SOL_SOCKET, SO_REUSEADDR, (char *) &option_value, &option_len) == 0) { if (option_value == 0) { option_value = 1; option_len = sizeof(option_value); setsockopt(rv, SOL_SOCKET, SO_REUSEADDR, (char *) &option_value, option_len); } } option_len = sizeof(option_value); if (getsockopt(rv, SOL_SOCKET, SO_SNDBUF, (char *) &option_value, &option_len) == 0) { if (option_value < (1024 * 32)) { option_value = 1024 * 32; option_len = sizeof(option_value); setsockopt(rv, SOL_SOCKET, SO_SNDBUF, (char *) &option_value, option_len); } } return rv; } /** * Connect to a server * * @param skt opaque socket obj * @param address connect to this server * @param port using this port * * @return 0 on success, -1 on error *****************************************************************************/ int tcp_connect(int skt, const char *hostname, const char *port) { struct sockaddr_in s; struct hostent *h; memset(&s, 0, sizeof(struct sockaddr_in)); s.sin_family = AF_INET; s.sin_port = htons((uint16_t) atoi(port)); s.sin_addr.s_addr = inet_addr(hostname); if (s.sin_addr.s_addr == INADDR_NONE) { h = gethostbyname(hostname); if (h != 0) { if (h->h_name != 0) { if (h->h_addr_list != 0) { if ((*(h->h_addr_list)) != 0) { s.sin_addr.s_addr = *((int *)(*(h->h_addr_list))); } } } } } return connect(skt, (struct sockaddr *) &s, sizeof(struct sockaddr_in)); } /** * Return 1 if we can write to the socket, 0 otherwise *****************************************************************************/ int tcp_can_send(int skt, int millis) { fd_set wfds; struct timeval time; int rv; time.tv_sec = millis / 1000; time.tv_usec = (millis * 1000) % 1000000; FD_ZERO(&wfds); if (skt > 0) { FD_SET(((unsigned int) skt), &wfds); rv = select(skt + 1, 0, &wfds, 0, &time); if (rv > 0) { return tcp_socket_ok(skt); } } return 0; } /** * Return 1 if socket is OK, 0 otherwise *****************************************************************************/ int tcp_socket_ok(int skt) { int opt; socklen_t opt_len = sizeof(opt); if (getsockopt(skt, SOL_SOCKET, SO_ERROR, (char *) (&opt), &opt_len) == 0) { if (opt == 0) return 1; } return 0; } /** * Check if specified sockets can be operated on without blocking * * @return 1 if they can be operated on or 0 if blocking would occur *****************************************************************************/ int tcp_select(int sck1, int sck2) { fd_set rfds; struct timeval time; int max = 0; int rv = 0; memset(&rfds, 0, sizeof(fd_set)); memset(&time, 0, sizeof(struct timeval)); time.tv_sec = 0; time.tv_usec = 0; FD_ZERO(&rfds); if (sck1 > 0) FD_SET(((unsigned int) sck1), &rfds); if (sck2 > 0) FD_SET(((unsigned int) sck2), &rfds); max = sck1; if (sck2 > max) max = sck2; rv = select(max + 1, &rfds, 0, 0, &time); if (rv > 0) { rv = 0; if (FD_ISSET(((unsigned int) sck1), &rfds)) rv = rv | 1; if (FD_ISSET(((unsigned int)sck2), &rfds)) rv = rv | 2; } else { rv = 0; } return rv; } int tcp_recv(int skt, void *ptr, int len, int flags) { #if defined(_WIN32) return recv(skt, (char *) ptr, len, flags); #else return recv(skt, ptr, len, flags); #endif } int tcp_send(int skt, const void *ptr, int len, int flags) { #if defined(_WIN32) return send(skt, (const char *)ptr, len, flags); #else return send(skt, ptr, len, flags); #endif } xrdp-0.9.5/tests/gtcp_proxy/hexdump.c000644 001751 001751 00000007022 13125122134 017573 0ustar00metameta000000 000000 /** * xrdp: A Remote Desktop Protocol server. * * Copyright (C) Laxmikant Rashinkar 2013 LK.Rashinkar@gmail.com * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ #include #include #include /** * An optimized hexdump function * * @param address address to display in address column * @param buf data to hexdump * @param len number of bytes to dump *****************************************************************************/ void hexdump(int address, char *buf, int len) { uint32_t addr; char outbuf[80]; int blocks; int residual; int i; int j; int buf_index; int index2; /* data column */ int index3; /* ascii column */ unsigned char c; char cvt[] = {'0', '1', '2', '3', '4', '5', '6', '7', '8', '9', 'a', 'b', 'c', 'd', 'e', 'f'}; if ((buf == NULL) || (len <= 0)) return; addr = (address < 0) ? 0 : address; blocks = len / 16; residual = len - blocks * 16; buf_index = 0; for (i = 0; i < blocks; i++) { index2 = 10; index3 = 60; outbuf[9] = ' '; outbuf[8] = ' '; outbuf[7] = cvt[(addr >> 0) & 0x0000000f]; outbuf[6] = cvt[(addr >> 4) & 0x0000000f]; outbuf[5] = cvt[(addr >> 8) & 0x0000000f]; outbuf[4] = cvt[(addr >> 12) & 0x0000000f]; outbuf[3] = cvt[(addr >> 16) & 0x0000000f]; outbuf[2] = cvt[(addr >> 20) & 0x0000000f]; outbuf[1] = cvt[(addr >> 24) & 0x0000000f]; outbuf[0] = cvt[(addr >> 28) & 0x0000000f]; addr += 16; /* insert spaces */ outbuf[8] = ' '; outbuf[9] = ' '; outbuf[58] = ' '; outbuf[59] = ' '; for (j = 0; j < 16; j++) { c = buf[buf_index++]; outbuf[index2++] = cvt[(c >> 4) & 0x0f]; outbuf[index2++] = cvt[(c >> 0) & 0x0f]; outbuf[index2++] = ' '; if ((c >= 0x20) && (c <= 0x7e)) outbuf[index3++] = c; else outbuf[index3++] = '.'; } outbuf[index3] = 0; puts(outbuf); } if (!residual) return; outbuf[7] = cvt[(addr >> 0) & 0x0000000f]; outbuf[6] = cvt[(addr >> 4) & 0x0000000f]; outbuf[5] = cvt[(addr >> 8) & 0x0000000f]; outbuf[4] = cvt[(addr >> 12) & 0x0000000f]; outbuf[3] = cvt[(addr >> 16) & 0x0000000f]; outbuf[2] = cvt[(addr >> 20) & 0x0000000f]; outbuf[1] = cvt[(addr >> 24) & 0x0000000f]; outbuf[0] = cvt[(addr >> 28) & 0x0000000f]; addr += 16; index2 = 10; index3 = 60; memset(&outbuf[8], ' ', 68); for (j = 0; j < residual; j++) { c = buf[buf_index++]; outbuf[index2++] = cvt[(c >> 4) & 0x0f]; outbuf[index2++] = cvt[(c >> 0) & 0x0f]; outbuf[index2++] = ' '; if ((c >= 0x20) && (c <= 0x7e)) outbuf[index3++] = c; else outbuf[index3++] = '.'; } outbuf[index3] = 0; puts(outbuf); } xrdp-0.9.5/tests/gtcp_proxy/README.txt000644 001751 001751 00000000147 13125122134 017454 0ustar00metameta000000 000000 gtcp-proxy is a 'man in the middle' program to monitor data flowing between two network connections. xrdp-0.9.5/tests/gtcp_proxy/gtcp.h000644 001751 001751 00000002621 13125122134 017063 0ustar00metameta000000 000000 /** * xrdp: A Remote Desktop Protocol server. * * Copyright (C) Jay Sorg 2013 * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ #ifndef _GTCP_H #define _GTCP_H #include #include #include #include #include #include #include #include #include #include int tcp_socket_create(void); void tcp_set_non_blocking(int skt); int tcp_bind(int skt, char *port); int tcp_listen(int skt); int tcp_accept(int skt); int tcp_last_error_would_block(); void tcp_close(int skt); int tcp_socket(void); int tcp_connect(int skt, const char *hostname, const char *port); int tcp_can_send(int skt, int millis); int tcp_socket_ok(int skt); int tcp_select(int sck1, int sck2); int tcp_recv(int skt, void *ptr, int len, int flags); int tcp_send(int skt, const void *ptr, int len, int flags); #endif xrdp-0.9.5/tests/tcp_proxy/main.c000644 001751 001751 00000037116 13174271344 016721 0ustar00metameta000000 000000 /** * xrdp: A Remote Desktop Protocol server. * * Copyright (C) Jay Sorg 2004-2014 * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ #include #include #include #include #include #include #include #include #include #include #include #include #include #include int g_loc_io_count = 0; // bytes read from local port int g_rem_io_count = 0; // bytes read from remote port static int g_terminated = 0; static char g_buf[1024 * 32]; #define #define typedef unsigned short tui16; /*****************************************************************************/ static void g_memset(void *ptr, int val, int size) { memset(ptr, val, size); } /*****************************************************************************/ static void g_printf(const char *format, ...) { va_list ap; va_start(ap, format); vfprintf(stdout, format, ap); va_end(ap); } /*****************************************************************************/ static void g_writeln(const char *format, ...) { va_list ap; va_start(ap, format); vfprintf(stdout, format, ap); va_end(ap); g_printf("\n"); } /*****************************************************************************/ static void g_hexdump(char *p, int len) { unsigned char *line; int i; int thisline; int offset; line = (unsigned char *)p; offset = 0; while (offset < len) { g_printf("%04x ", offset); thisline = len - offset; if (thisline > 16) { thisline = 16; } for (i = 0; i < thisline; i++) { g_printf("%02x ", line[i]); } for (; i < 16; i++) { g_printf(" "); } for (i = 0; i < thisline; i++) { g_printf("%c", (line[i] >= 0x20 && line[i] < 0x7f) ? line[i] : '.'); } g_writeln("%s", ""); offset += thisline; line += thisline; } } /*****************************************************************************/ static int g_tcp_socket(void) { int rv; int option_value; socklen_t option_len; rv = (int)socket(AF_INET, SOCK_STREAM, 0); if (rv < 0) { return -1; } option_len = sizeof(option_value); if (getsockopt(rv, SOL_SOCKET, SO_REUSEADDR, (char *)&option_value, &option_len) == 0) { if (option_value == 0) { option_value = 1; option_len = sizeof(option_value); setsockopt(rv, SOL_SOCKET, SO_REUSEADDR, (char *)&option_value, option_len); } } option_len = sizeof(option_value); if (getsockopt(rv, SOL_SOCKET, SO_SNDBUF, (char *)&option_value, &option_len) == 0) { if (option_value < (1024 * 32)) { option_value = 1024 * 32; option_len = sizeof(option_value); setsockopt(rv, SOL_SOCKET, SO_SNDBUF, (char *)&option_value, option_len); } } return rv; } /*****************************************************************************/ static int g_tcp_set_non_blocking(int sck) { unsigned long i; i = fcntl(sck, F_GETFL); i = i | O_NONBLOCK; fcntl(sck, F_SETFL, i); return 0; } /*****************************************************************************/ static int g_tcp_bind(int sck, const char* port) { struct sockaddr_in s; memset(&s, 0, sizeof(struct sockaddr_in)); s.sin_family = AF_INET; s.sin_port = htons((tui16)atoi(port)); s.sin_addr.s_addr = INADDR_ANY; return bind(sck, (struct sockaddr*)&s, sizeof(struct sockaddr_in)); } /*****************************************************************************/ static int g_tcp_listen(int sck) { return listen(sck, 2); } /*****************************************************************************/ static int g_tcp_select(int sck1, int sck2) { fd_set rfds; struct timeval time; int max = 0; int rv = 0; g_memset(&rfds, 0, sizeof(fd_set)); g_memset(&time, 0, sizeof(struct timeval)); time.tv_sec = 0; time.tv_usec = 0; FD_ZERO(&rfds); if (sck1 > 0) { FD_SET(((unsigned int)sck1), &rfds); } if (sck2 > 0) { FD_SET(((unsigned int)sck2), &rfds); } max = sck1; if (sck2 > max) { max = sck2; } rv = select(max + 1, &rfds, 0, 0, &time); if (rv > 0) { rv = 0; if (FD_ISSET(((unsigned int)sck1), &rfds)) { rv = rv | 1; } if (FD_ISSET(((unsigned int)sck2), &rfds)) { rv = rv | 2; } } else { rv = 0; } return rv; } /*****************************************************************************/ static int g_tcp_recv(int sck, void *ptr, int len, int flags) { return recv(sck, ptr, len, flags); } /*****************************************************************************/ static void g_tcp_close(int sck) { if (sck == 0) { return; } close(sck); } /*****************************************************************************/ static int g_tcp_send(int sck, const void *ptr, int len, int flags) { return send(sck, ptr, len, flags); } /*****************************************************************************/ void g_sleep(int msecs) { usleep(msecs * 1000); } /*****************************************************************************/ static int g_tcp_last_error_would_block(int sck) { return (errno == EWOULDBLOCK) || (errno == EAGAIN) || (errno == EINPROGRESS); } /*****************************************************************************/ static int g_tcp_accept(int sck) { int ret ; struct sockaddr_in s; unsigned int i; i = sizeof(struct sockaddr_in); memset(&s, 0, i); ret = accept(sck, (struct sockaddr *)&s, &i); return ret ; } /*****************************************************************************/ static int g_tcp_connect(int sck, const char* address, const char* port) { struct sockaddr_in s; struct hostent* h; g_memset(&s, 0, sizeof(struct sockaddr_in)); s.sin_family = AF_INET; s.sin_port = htons((tui16)atoi(port)); s.sin_addr.s_addr = inet_addr(address); if (s.sin_addr.s_addr == INADDR_NONE) { h = gethostbyname(address); if (h != 0) { if (h->h_name != 0) { if (h->h_addr_list != 0) { if ((*(h->h_addr_list)) != 0) { s.sin_addr.s_addr = *((int*)(*(h->h_addr_list))); } } } } } return connect(sck, (struct sockaddr*)&s, sizeof(struct sockaddr_in)); } /*****************************************************************************/ static int g_tcp_socket_ok(int sck) { int opt; socklen_t opt_len = sizeof(opt); if (getsockopt(sck, SOL_SOCKET, SO_ERROR, (char *)(&opt), &opt_len) == 0) { if (opt == 0) { return 1; } } return 0; } /*****************************************************************************/ static void g_init(const char *app_name) { setlocale(LC_CTYPE, ""); } /*****************************************************************************/ static void g_deinit(void) { } /*****************************************************************************/ static int g_tcp_can_send(int sck, int millis) { fd_set wfds; struct timeval time; int rv; time.tv_sec = millis / 1000; time.tv_usec = (millis * 1000) % 1000000; FD_ZERO(&wfds); if (sck > 0) { FD_SET(((unsigned int)sck), &wfds); rv = select(sck + 1, 0, &wfds, 0, &time); if (rv > 0) { return g_tcp_socket_ok(sck); } } return 0; } /*****************************************************************************/ static void g_signal_user_interrupt(void (*func)(int)) { signal(SIGINT, func); } /*****************************************************************************/ static void g_signal_terminate(void (*func)(int)) { signal(SIGTERM, func); } /*****************************************************************************/ static void g_signal_usr1(void (*func)(int)) { signal(SIGUSR1, func); } /*****************************************************************************/ static int g_strcasecmp(const char *c1, const char *c2) { return strcasecmp(c1, c2); } /*****************************************************************************/ static int main_loop(char *local_port, char *remote_ip, char *remote_port, int hexdump) { int lis_sck; int acc_sck; int con_sck; int sel; int count; int sent; int error; int i; int acc_to_con; int con_to_acc; acc_to_con = 0; con_to_acc = 0; acc_sck = 0; /* create the listening socket and setup options */ lis_sck = g_tcp_socket(); g_tcp_set_non_blocking(lis_sck); error = g_tcp_bind(lis_sck, local_port); if (error != 0) { g_writeln("bind failed"); } /* listen for an incoming connection */ if (error == 0) { error = g_tcp_listen(lis_sck); if (error == 0) { g_writeln("listening for connection"); } } /* accept an incoming connection */ if (error == 0) { while ((!g_terminated) && (error == 0)) { acc_sck = g_tcp_accept(lis_sck); if ((acc_sck == -1) && g_tcp_last_error_would_block(lis_sck)) { g_sleep(100); } else if (acc_sck == -1) { error = 1; } else { break; } } if (error == 0) { error = g_terminated; } /* stop listening */ g_tcp_close(lis_sck); lis_sck = 0; if (error == 0) { g_writeln("got connection"); } } /* connect outgoing socket */ con_sck = 0; if (error == 0) { con_sck = g_tcp_socket(); g_tcp_set_non_blocking(con_sck); error = g_tcp_connect(con_sck, remote_ip, remote_port); if ((error == -1) && g_tcp_last_error_would_block(con_sck)) { error = 0; i = 0; while ((!g_tcp_can_send(con_sck, 100)) && (!g_terminated) && (i < 100)) { g_sleep(100); i++; } if (i > 99) { g_writeln("timeout connecting"); error = 1; } if (g_terminated) { error = 1; } } if ((error != 0) && (!g_terminated)) { g_writeln("error connecting to remote\r\n"); } } while ((!g_terminated) && (error == 0)) { sel = g_tcp_select(con_sck, acc_sck); if (sel == 0) { g_sleep(10); continue; } if (sel & 1) { // can read from con_sck w/o blocking count = g_tcp_recv(con_sck, g_buf, 1024 * 16, 0); error = count < 1; if (error == 0) { g_loc_io_count += count; con_to_acc += count; if (hexdump) { g_writeln("from remove, the socket from connect"); g_hexdump(g_buf, count); } #if 0 g_writeln("local_io_count: %d\tremote_io_count: %d", g_loc_io_count, g_rem_io_count); #endif sent = 0; while ((sent < count) && (error == 0) && (!g_terminated)) { i = g_tcp_send(acc_sck, g_buf + sent, count - sent, 0); if ((i == -1) && g_tcp_last_error_would_block(acc_sck)) { g_tcp_can_send(acc_sck, 1000); } else if (i < 1) { error = 1; } else { sent += i; } } } } if (sel & 2) { // can read from acc_sck w/o blocking count = g_tcp_recv(acc_sck, g_buf, 1024 * 16, 0); error = count < 1; if (error == 0) { g_rem_io_count += count; acc_to_con += count; if (hexdump) { g_writeln("from accepted, the socket from accept"); g_hexdump(g_buf, count); } #if 0 g_writeln("local_io_count: %d\tremote_io_count: %d", g_loc_io_count, g_rem_io_count); #endif sent = 0; while ((sent < count) && (error == 0) && (!g_terminated)) { i = g_tcp_send(con_sck, g_buf + sent, count - sent, 0); if ((i == -1) && g_tcp_last_error_would_block(con_sck)) { g_tcp_can_send(con_sck, 1000); } else if (i < 1) { error = 1; } else { sent += i; } } } } } g_tcp_close(lis_sck); g_tcp_close(con_sck); g_tcp_close(acc_sck); g_writeln("acc_to_con %d", acc_to_con); g_writeln("con_to_acc %d", con_to_acc); return 0; } /*****************************************************************************/ static int usage(void) { g_writeln("tcp_proxy [dump]"); return 0; } /*****************************************************************************/ void proxy_shutdown(int sig) { g_writeln("shutting down"); g_terminated = 1; } void clear_counters(int sig) { g_writeln("cleared counters at: local_io_count: %d remote_io_count: %d", g_loc_io_count, g_rem_io_count); g_loc_io_count = 0; g_rem_io_count = 0; } /*****************************************************************************/ int main(int argc, char **argv) { int dump; if (argc < 4) { usage(); return 0; } g_init("tcp_proxy"); g_signal_user_interrupt(proxy_shutdown); /* SIGINT */ g_signal_usr1(clear_counters); /* SIGUSR1 */ g_signal_terminate(proxy_shutdown); /* SIGTERM */ if (argc < 5) { while (!g_terminated) { g_loc_io_count = 0; g_rem_io_count = 0; main_loop(argv[1], argv[2], argv[3], 0); } } else { dump = g_strcasecmp(argv[4], "dump") == 0; while (!g_terminated) { main_loop(argv[1], argv[2], argv[3], dump); } } g_deinit(); return 0; } xrdp-0.9.5/tests/tcp_proxy/Makefile000644 001751 001751 00000000275 13125122134 017251 0ustar00metameta000000 000000 CFLAGS = -O2 -Wall LDFLAGS = OBJS = main.o LIBS = -ldl all: tcp_proxy tcp_proxy: $(OBJS) $(CC) $(CFLAGS) $(LDFLAGS) -o tcp_proxy $(OBJS) $(LIBS) .PHONY clean: rm -f $(OBJS) tcp_proxy xrdp-0.9.5/xrdp/xrdp_listen.c000644 001751 001751 00000044271 13220727202 016103 0ustar00metameta000000 000000 /** * xrdp: A Remote Desktop Protocol server. * * Copyright (C) Jay Sorg 2004-2014 * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. * * listen for incoming connection */ #if defined(HAVE_CONFIG_H) #include #endif #include "xrdp.h" #include "log.h" /* 'g_process' is protected by the semaphore 'g_process_sem'. One thread sets g_process and waits for the other to process it */ static tbus g_process_sem = 0; static struct xrdp_process *g_process = 0; /*****************************************************************************/ static int xrdp_listen_create_pro_done(struct xrdp_listen *self) { int pid; char text[256]; pid = g_getpid(); g_snprintf(text, 255, "xrdp_%8.8x_listen_pro_done_event", pid); self->pro_done_event = g_create_wait_obj(text); if (self->pro_done_event == 0) { log_message(LOG_LEVEL_ERROR,"Failure creating pro_done_event"); } return 0; } /*****************************************************************************/ struct xrdp_listen * xrdp_listen_create(void) { struct xrdp_listen *self; self = (struct xrdp_listen *)g_malloc(sizeof(struct xrdp_listen), 1); xrdp_listen_create_pro_done(self); self->process_list = list_create(); if (g_process_sem == 0) { g_process_sem = tc_sem_create(0); } /* setting TCP mode now, may change later */ self->listen_trans = trans_create(TRANS_MODE_TCP, 16, 16); if (self->listen_trans == 0) { log_message(LOG_LEVEL_ERROR,"xrdp_listen_create: trans_create failed"); } else { self->listen_trans->is_term = g_is_term; } return self; } /*****************************************************************************/ void xrdp_listen_delete(struct xrdp_listen *self) { if (self->listen_trans != 0) { trans_delete(self->listen_trans); } if (g_process_sem != 0) { tc_sem_delete(g_process_sem); g_process_sem = 0; } g_delete_wait_obj(self->pro_done_event); list_delete(self->process_list); g_free(self); } /*****************************************************************************/ /* returns error */ static int xrdp_listen_add_pro(struct xrdp_listen *self, struct xrdp_process *process) { list_add_item(self->process_list, (tbus)process); return 0; } /*****************************************************************************/ static int xrdp_listen_delete_done_pro(struct xrdp_listen *self) { int i; struct xrdp_process *pro; for (i = self->process_list->count - 1; i >= 0; i--) { pro = (struct xrdp_process *)list_get_item(self->process_list, i); if (pro != 0) { if (pro->status < 0) { xrdp_process_delete(pro); list_remove_item(self->process_list, i); } } } return 0; } /*****************************************************************************/ /* i can't get stupid in_val to work, hum using global var for now */ THREAD_RV THREAD_CC xrdp_process_run(void *in_val) { struct xrdp_process *process; DEBUG(("process started")); process = g_process; g_process = 0; tc_sem_inc(g_process_sem); xrdp_process_main_loop(process); DEBUG(("process done")); return 0; } /*****************************************************************************/ static int xrdp_listen_get_port_address(char *port, int port_bytes, char *address, int address_bytes, int *tcp_nodelay, int *tcp_keepalive, int *mode, struct xrdp_startup_params *startup_param) { int fd; int error; int index; char *val; struct list *names; struct list *values; char cfg_file[256]; /* default to port 3389 */ g_strncpy(port, "3389", port_bytes - 1); /* Default to all */ g_strncpy(address, "0.0.0.0", address_bytes - 1); /* see if port or address is in xrdp.ini file */ g_snprintf(cfg_file, 255, "%s/xrdp.ini", XRDP_CFG_PATH); fd = g_file_open(cfg_file); *mode = TRANS_MODE_TCP; *tcp_nodelay = 0 ; *tcp_keepalive = 0 ; if (fd != -1) { names = list_create(); names->auto_free = 1; values = list_create(); values->auto_free = 1; if (file_read_section(fd, "globals", names, values) == 0) { for (index = 0; index < names->count; index++) { val = (char *)list_get_item(names, index); if (val != 0) { if (g_strcasecmp(val, "port") == 0) { val = (char *)list_get_item(values, index); if (val[0] == '/') { g_strncpy(port, val, port_bytes - 1); } else { error = g_atoi(val); if ((error > 0) && (error < 65000)) { g_strncpy(port, val, port_bytes - 1); } } } if (g_strcasecmp(val, "use_vsock") == 0) { val = (char *)list_get_item(values, index); if (g_text2bool(val) == 1) { *mode = TRANS_MODE_VSOCK; } } if (g_strcasecmp(val, "address") == 0) { val = (char *)list_get_item(values, index); g_strncpy(address, val, address_bytes - 1); } if (g_strcasecmp(val, "fork") == 0) { val = (char *)list_get_item(values, index); startup_param->fork = g_text2bool(val); } if (g_strcasecmp(val, "tcp_nodelay") == 0) { val = (char *)list_get_item(values, index); *tcp_nodelay = g_text2bool(val); } if (g_strcasecmp(val, "tcp_keepalive") == 0) { val = (char *)list_get_item(values, index); *tcp_keepalive = g_text2bool(val); } if (g_strcasecmp(val, "tcp_send_buffer_bytes") == 0) { val = (char *)list_get_item(values, index); startup_param->send_buffer_bytes = g_atoi(val); } if (g_strcasecmp(val, "tcp_recv_buffer_bytes") == 0) { val = (char *)list_get_item(values, index); startup_param->recv_buffer_bytes = g_atoi(val); } } } } list_delete(names); list_delete(values); } if (fd != -1) g_file_close(fd); /* startup_param overrides */ if (startup_param->port[0] != 0) { g_strncpy(port, startup_param->port, port_bytes - 1); } return 0; } /*****************************************************************************/ static int xrdp_listen_fork(struct xrdp_listen *self, struct trans *server_trans) { int pid; struct xrdp_process *process; pid = g_fork(); if (pid == 0) { /* child */ /* recreate some main globals */ xrdp_child_fork(); /* recreate the process done wait object, not used in fork mode */ /* close, don't delete this */ g_close_wait_obj(self->pro_done_event); xrdp_listen_create_pro_done(self); /* delete listener, child need not listen */ trans_delete(self->listen_trans); self->listen_trans = 0; /* new connect instance */ process = xrdp_process_create(self, 0); process->server_trans = server_trans; g_process = process; xrdp_process_run(0); xrdp_process_delete(process); /* mark this process to exit */ g_set_term(1); return 0; } /* parent */ trans_delete(server_trans); return 0; } /*****************************************************************************/ /* a new connection is coming in */ int xrdp_listen_conn_in(struct trans *self, struct trans *new_self) { struct xrdp_process *process; struct xrdp_listen *lis; lis = (struct xrdp_listen *)(self->callback_data); if (lis->startup_params->fork) { return xrdp_listen_fork(lis, new_self); } process = xrdp_process_create(lis, lis->pro_done_event); if (xrdp_listen_add_pro(lis, process) == 0) { /* start thread */ process->server_trans = new_self; g_process = process; tc_thread_create(xrdp_process_run, 0); tc_sem_dec(g_process_sem); /* this will wait */ } else { xrdp_process_delete(process); } return 0; } /*****************************************************************************/ /* wait for incoming connections passes through trans_listen_address return value */ int xrdp_listen_main_loop(struct xrdp_listen *self) { int error; int robjs_count; int cont; int timeout = 0; char port[128]; char address[256]; tbus robjs[8]; tbus term_obj; tbus sync_obj; tbus done_obj; int tcp_nodelay; int tcp_keepalive; int bytes; self->status = 1; if (xrdp_listen_get_port_address(port, sizeof(port), address, sizeof(address), &tcp_nodelay, &tcp_keepalive, &self->listen_trans->mode, self->startup_params) != 0) { log_message(LOG_LEVEL_ERROR,"xrdp_listen_main_loop: xrdp_listen_get_port failed"); self->status = -1; return 1; } if (port[0] == '/') { /* set UDS mode */ self->listen_trans->mode = TRANS_MODE_UNIX; /* not valid with UDS */ tcp_nodelay = 0; } else if (self->listen_trans->mode == TRANS_MODE_VSOCK) { /* not valid with VSOCK */ tcp_nodelay = 0; } /* Create socket */ error = trans_listen_address(self->listen_trans, port, address); if (port[0] == '/') { g_chmod_hex(port, 0x0666); } if (error == 0) { log_message(LOG_LEVEL_INFO, "listening to port %s on %s", port, address); if (tcp_nodelay) { if (g_tcp_set_no_delay(self->listen_trans->sck)) { log_message(LOG_LEVEL_ERROR,"Error setting tcp_nodelay"); } } if (tcp_keepalive) { if (g_tcp_set_keepalive(self->listen_trans->sck)) { log_message(LOG_LEVEL_ERROR,"Error setting tcp_keepalive"); } } if (self->startup_params->send_buffer_bytes > 0) { bytes = self->startup_params->send_buffer_bytes; log_message(LOG_LEVEL_INFO, "setting send buffer to %d bytes", bytes); if (g_sck_set_send_buffer_bytes(self->listen_trans->sck, bytes) != 0) { log_message(LOG_LEVEL_ERROR, "error setting send buffer"); } else { if (g_sck_get_send_buffer_bytes(self->listen_trans->sck, &bytes) != 0) { log_message(LOG_LEVEL_ERROR, "error getting send buffer"); } else { log_message(LOG_LEVEL_INFO, "send buffer set to %d bytes", bytes); } } } if (self->startup_params->recv_buffer_bytes > 0) { bytes = self->startup_params->recv_buffer_bytes; log_message(LOG_LEVEL_INFO, "setting recv buffer to %d bytes", bytes); if (g_sck_set_recv_buffer_bytes(self->listen_trans->sck, bytes) != 0) { log_message(LOG_LEVEL_ERROR, "error setting recv buffer"); } else { if (g_sck_get_recv_buffer_bytes(self->listen_trans->sck, &bytes) != 0) { log_message(LOG_LEVEL_ERROR, "error getting recv buffer"); } else { log_message(LOG_LEVEL_INFO, "recv buffer set to %d bytes", bytes); } } } self->listen_trans->trans_conn_in = xrdp_listen_conn_in; self->listen_trans->callback_data = self; term_obj = g_get_term_event(); /*Global termination event */ sync_obj = g_get_sync_event(); done_obj = self->pro_done_event; cont = 1; while (cont) { /* build the wait obj list */ robjs_count = 0; robjs[robjs_count++] = term_obj; robjs[robjs_count++] = sync_obj; robjs[robjs_count++] = done_obj; timeout = -1; if (trans_get_wait_objs(self->listen_trans, robjs, &robjs_count) != 0) { break; } /* wait - timeout -1 means wait indefinitely*/ if (g_obj_wait(robjs, robjs_count, 0, 0, timeout) != 0) { /* error, should not get here */ g_sleep(100); } if (g_is_wait_obj_set(term_obj)) /* termination called */ { break; } /* some function must be processed by this thread */ if (g_is_wait_obj_set(sync_obj)) { g_reset_wait_obj(sync_obj); g_process_waiting_function(); /* run the function */ } if (g_is_wait_obj_set(done_obj)) /* pro_done_event */ { g_reset_wait_obj(done_obj); /* a process has died remove it from lists*/ xrdp_listen_delete_done_pro(self); } /* Run the callback when accept() returns a new socket*/ if (trans_check_wait_objs(self->listen_trans) != 0) { break; } } /* stop listening */ trans_delete(self->listen_trans); self->listen_trans = 0; /* second loop to wait for all process threads to close */ cont = 1; while (cont) { if (self->process_list->count == 0) { break; } timeout = -1; /* build the wait obj list */ robjs_count = 0; robjs[robjs_count++] = sync_obj; robjs[robjs_count++] = done_obj; /* wait - timeout -1 means wait indefinitely*/ if (g_obj_wait(robjs, robjs_count, 0, 0, timeout) != 0) { /* error, should not get here */ g_sleep(100); } /* some function must be processed by this thread */ if (g_is_wait_obj_set(sync_obj)) { g_reset_wait_obj(sync_obj); g_process_waiting_function(); /* run the function that is waiting*/ } if (g_is_wait_obj_set(done_obj)) /* pro_done_event */ { g_reset_wait_obj(done_obj); xrdp_listen_delete_done_pro(self); } } } else { log_message(LOG_LEVEL_ERROR,"xrdp_listen_main_loop: listen error, possible port " "already in use"); #if !defined(XRDP_ENABLE_VSOCK) if (self->listen_trans->mode == TRANS_MODE_VSOCK) { log_message(LOG_LEVEL_ERROR,"xrdp_listen_main_loop: listen error, " "vsock support not compiled and config requested"); } #endif } self->status = -1; return error; } /*****************************************************************************/ /* returns 0 if xrdp can listen returns 1 if xrdp cannot listen */ int xrdp_listen_test(void) { int rv = 0; char port[128]; int mode; char address[256]; int tcp_nodelay; int tcp_keepalive; struct xrdp_listen *xrdp_listen; struct xrdp_startup_params *startup_params; startup_params = (struct xrdp_startup_params *) g_malloc(sizeof(struct xrdp_startup_params), 1); xrdp_listen = xrdp_listen_create(); xrdp_listen->startup_params = startup_params; if (xrdp_listen_get_port_address(port, sizeof(port), address, sizeof(address), &tcp_nodelay, &tcp_keepalive, &mode, xrdp_listen->startup_params) != 0) { log_message(LOG_LEVEL_DEBUG, "xrdp_listen_test: " "xrdp_listen_get_port_address failed"); rv = 1; goto done; } /* try to listen */ log_message(LOG_LEVEL_DEBUG, "Testing if xrdp can listen on %s port %s.", address, port); rv = trans_listen_address(xrdp_listen->listen_trans, port, address); if (rv == 0) { /* if listen succeeded, stop listen immediately */ trans_delete(xrdp_listen->listen_trans); xrdp_listen->listen_trans = 0; } goto done; done: xrdp_listen_delete(xrdp_listen); g_free(startup_params); return rv; } xrdp-0.9.5/xrdp/xrdp_keyboard.ini000644 001751 001751 00000006441 13220727202 016737 0ustar00metameta000000 000000 ; ; RDP Keyboard <-> X11 Keyboard layout map ; ; How this file works: ; 1. load the file and scan each section to find matching "keyboard_type" ; and "keyboard_subtype" based on the values received from the client. ; If not found, then jump to default section. ; 2. in the selected section, look for "rdp_layouts" and "layouts_map". ; Based on the "keylayout" value from the client, find the right x11 ; layout value. ; 3. model/variant are inferred based on the "keyboard_type" and ; "keyboard_subtype", but they can be overridden. ; ; ; RDP Keyboard Type (http://msdn.microsoft.com/en-us/library/cc240563.aspx) ; ; 0 is not a valid value ; ; 1 - IBM PC/XT or compatible (83-key) keyboard ; 2 - Olivetti "ICO" (102-key) keyboard ; 3 - IBM PC/AT (84-key) or similar keyboard ; 4 - IBM enhanced (101- or 102-key) keyboard ; 5 - Nokia 1050 and similar keyboards ; 6 - Nokia 9140 and similar keyboards ; 7 - Japanese keyboard ; ; RDP Keyboard Subtype is vendor dependent. XRDP defines as follows: ; ; 0 is not a valid value ; ; 1 - Standard ; 2 - FreeRDP JP keyboard ; 3 - Macintosh ; ... - < any vendor dependent subtype > ; ; The list can be augmented. ; ; default [default] ; keyboard_type and keyboard_subtype is not read for default section. It ; is only a placeholder to keep consistency. Default model/variant are ; platform dependent, and could be overridden if needed. keyboard_type=0 keyboard_subtype=0 ; user could override variant and model, but generally they should be inferred ; automatically based on keyboard type and subtype ;variant= ;model= ; A list of supported RDP keyboard layouts rdp_layouts=default_rdp_layouts ; The map from RDP keyboard layout to X11 keyboard layout layouts_map=default_layouts_map [default_rdp_layouts] rdp_layout_us=0x00000409 rdp_layout_us_dvorak=0x00010409 rdp_layout_de=0x00000407 rdp_layout_es=0x0000040A rdp_layout_fi=0x0000040B rdp_layout_fr=0x0000040C rdp_layout_it=0x00000410 rdp_layout_jp=0x00000411 rdp_layout_jp=0xe0010411 rdp_layout_jp=0xe0200411 rdp_layout_jp=0xe0210411 rdp_layout_kr=0x00000412 rdp_layout_pl=0x00000415 rdp_layout_br=0x00000416 rdp_layout_ru=0x00000419 rdp_layout_se=0x0000041D rdp_layout_ch=0x00000807 rdp_layout_gb=0x00000809 rdp_layout_be=0x00000813 rdp_layout_pt=0x00000816 ; = [default_layouts_map] rdp_layout_us=us rdp_layout_us_dvorak=dvorak rdp_layout_de=de rdp_layout_es=es rdp_layout_fi=fi rdp_layout_fr=fr rdp_layout_it=it rdp_layout_jp=jp rdp_layout_kr=kr rdp_layout_pl=pl rdp_layout_br=br(abnt2) rdp_layout_ru=ru rdp_layout_se=se rdp_layout_ch=ch rdp_layout_gb=gb rdp_layout_be=be rdp_layout_pt=pt ; if two sections have the same keyboard_type and keyboard_subtype, then ; the latter could override the former. [rdp_keyboard_mac] keyboard_type=4 keyboard_subtype=3 rdp_layouts=default_rdp_layouts layouts_map=rdp_layouts_map_mac [rdp_keyboard_jp] keyboard_type=7 keyboard_subtype=2 model=pc105 rdp_layouts=default_rdp_layouts layouts_map=default_layouts_map [rdp_layouts_map_mac] rdp_layout_us=us rdp_layout_us_dvorak=dvorak rdp_layout_de=de rdp_layout_es=es rdp_layout_fi=fi rdp_layout_fr=fr rdp_layout_it=it rdp_layout_jp=jp rdp_layout_kr=kr rdp_layout_pl=pl rdp_layout_br=br(abnt2) rdp_layout_ru=ru rdp_layout_se=se rdp_layout_ch=ch rdp_layout_gb=gb rdp_layout_be=be rdp_layout_pt=pt xrdp-0.9.5/xrdp/cursor0.cur000644 001751 001751 00000000506 12251743072 015513 0ustar00metameta000000 000000  0( @€ÿÿÿ€@@€„€É©’ƒà€@€€‚„ˆ À€ÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿþÿÿü?ÿÿü?ÿÿøÿÿxÿÿ0ÿÿÿÿÿÿÿÿÿÿÿ?ÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿ?ÿÿÿÿÿÿxrdp-0.9.5/xrdp/lang.c000644 001751 001751 00000022765 13174271344 014506 0ustar00metameta000000 000000 /** * xrdp: A Remote Desktop Protocol server. * * Copyright (C) Jay Sorg 2004-2014 * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. * * keylayout * maximum unicode 19996(0x4e00) */ #if defined(HAVE_CONFIG_H) #include #endif #include "xrdp.h" #include "log.h" /* map for rdp to x11 scancodes code1 is regular scancode, code2 is extended scancode */ struct codepair { tui8 code1; tui8 code2; }; static struct codepair g_map[] = { { 0, 0 }, { 9, 0 }, { 10, 0 }, { 11, 0 }, { 12, 0 }, /* 0 - 4 */ { 13, 0 }, { 14, 0 }, { 15, 0 }, { 16, 0 }, { 17, 0 }, /* 5 - 9 */ { 18, 0 }, { 19, 0 }, { 20, 0 }, { 21, 0 }, { 22, 0 }, /* 10 - 14 */ { 23, 0 }, { 24, 0 }, { 25, 0 }, { 26, 0 }, { 27, 0 }, /* 15 - 19 */ { 28, 0 }, { 29, 0 }, { 30, 0 }, { 31, 0 }, { 32, 0 }, /* 20 - 24 */ { 33, 0 }, { 34, 0 }, { 35, 0 }, { 36, 108 }, { 37, 109 }, /* 25 - 29 */ { 38, 0 }, { 39, 0 }, { 40, 0 }, { 41, 0 }, { 42, 0 }, /* 30 - 34 */ { 43, 0 }, { 44, 0 }, { 45, 0 }, { 46, 0 }, { 47, 0 }, /* 35 - 39 */ { 48, 0 }, { 49, 0 }, { 50, 0 }, { 51, 0 }, { 52, 0 }, /* 40 - 44 */ { 53, 0 }, { 54, 0 }, { 55, 0 }, { 56, 0 }, { 57, 0 }, /* 45 - 49 */ { 58, 0 }, { 59, 0 }, { 60, 0 }, { 61, 112 }, { 62, 0 }, /* 50 - 54 */ { 63, 111 }, { 64, 113 }, { 65, 0 }, { 66, 0 }, { 67, 0 }, /* 55 - 59 */ { 68, 0 }, { 69, 0 }, { 70, 0 }, { 71, 0 }, { 72, 0 }, /* 60 - 64 */ { 73, 0 }, { 74, 0 }, { 75, 0 }, { 76, 0 }, { 77, 0 }, /* 65 - 69 */ { 78, 0 }, { 79, 97 }, { 80, 98 }, { 81, 99 }, { 82, 0 }, /* 70 - 74 */ { 83, 100 }, { 84, 0 }, { 85, 102 }, { 86, 0 }, { 87, 103 }, /* 75 - 79 */ { 88, 104 }, { 89, 105 }, { 90, 106 }, { 91, 107 }, { 92, 0 }, /* 80 - 84 */ { 93, 0 }, { 94, 0 }, { 95, 0 }, { 96, 0 }, { 97, 0 }, /* 85 - 89 */ { 98, 0 }, { 0, 115 }, { 0, 116 }, { 0, 117 }, { 102, 0 }, /* 90 - 94 */ { 103, 0 }, { 104, 0 }, { 105, 0 }, { 106, 0 }, { 107, 0 }, /* 95 - 99 */ { 108, 0 }, { 109, 0 }, { 110, 0 }, { 111, 0 }, { 112, 0 }, /* 100 - 104 */ { 113, 0 }, { 114, 0 }, { 115, 0 }, { 116, 0 }, { 117, 0 }, /* 105 - 109 */ { 118, 0 }, { 119, 0 }, { 120, 0 }, { 121, 0 }, { 122, 0 }, /* 110 - 114 */ { 123, 0 }, { 124, 0 }, { 125, 0 }, { 126, 0 }, { 127, 0 }, /* 115 - 119 */ { 128, 0 }, { 129, 0 }, { 130, 0 }, { 131, 0 }, { 132, 0 }, /* 120 - 124 */ { 133, 0 }, { 134, 0 }, { 135, 0 } /* 125 - 127 */ }; /*****************************************************************************/ struct xrdp_key_info * get_key_info_from_scan_code(int device_flags, int scan_code, int *keys, int caps_lock, int num_lock, int scroll_lock, struct xrdp_keymap *keymap) { struct xrdp_key_info *rv; int shift; int altgr; int ext; int index; ext = device_flags & KBD_FLAG_EXT; /* 0x0100 */ shift = keys[42] || keys[54]; altgr = keys[56] & KBD_FLAG_EXT; /* right alt */ rv = 0; scan_code = scan_code & 0x7f; index = ext ? g_map[scan_code].code2 : g_map[scan_code].code1; /* keymap file is created with numlock off so we have to do this */ if ((index >= 79) && (index <= 91)) { if (num_lock) { rv = &(keymap->keys_shift[index]); } else { rv = &(keymap->keys_noshift[index]); } } else if (shift && caps_lock && altgr) { rv = &(keymap->keys_shiftcapslockaltgr[index]); } else if (shift && caps_lock) { rv = &(keymap->keys_shiftcapslock[index]); } else if (shift && altgr) { rv = &(keymap->keys_shiftaltgr[index]); } else if (shift) { rv = &(keymap->keys_shift[index]); } else if (caps_lock && altgr) { rv = &(keymap->keys_capslockaltgr[index]); } else if (caps_lock) { rv = &(keymap->keys_capslock[index]); } else if (altgr) { rv = &(keymap->keys_altgr[index]); } else { rv = &(keymap->keys_noshift[index]); } return rv; } /*****************************************************************************/ int get_keysym_from_scan_code(int device_flags, int scan_code, int *keys, int caps_lock, int num_lock, int scroll_lock, struct xrdp_keymap *keymap) { struct xrdp_key_info *ki; ki = get_key_info_from_scan_code(device_flags, scan_code, keys, caps_lock, num_lock, scroll_lock, keymap); if (ki == 0) { return 0; } return ki->sym; } /*****************************************************************************/ twchar get_char_from_scan_code(int device_flags, int scan_code, int *keys, int caps_lock, int num_lock, int scroll_lock, struct xrdp_keymap *keymap) { struct xrdp_key_info *ki; ki = get_key_info_from_scan_code(device_flags, scan_code, keys, caps_lock, num_lock, scroll_lock, keymap); if (ki == 0) { return 0; } return (twchar)(ki->chr); } /*****************************************************************************/ static int km_read_section(int fd, const char *section_name, struct xrdp_key_info *keymap) { struct list *names; struct list *values; int index; int code; int pos1; char *name; char *value; names = list_create(); names->auto_free = 1; values = list_create(); values->auto_free = 1; if (file_read_section(fd, section_name, names, values) == 0) { for (index = names->count - 1; index >= 0; index--) { name = (char *)list_get_item(names, index); value = (char *)list_get_item(values, index); if ((name != 0) && (value != 0)) { if (g_strncasecmp(name, "key", 3) == 0) { code = g_atoi(name + 3); } else { code = g_atoi(name); } if ((code >= 0) && (code < 256)) { pos1 = g_pos(value, ":"); if (pos1 >= 0) { keymap[code].chr = g_atoi(value + pos1 + 1); } keymap[code].sym = g_atoi(value); } } } } list_delete(names); list_delete(values); return 0; } /*****************************************************************************/ int get_keymaps(int keylayout, struct xrdp_keymap *keymap) { int fd; int basic_key_layout = keylayout & 0x0000ffff; char *filename; struct xrdp_keymap *lkeymap; filename = (char *)g_malloc(256, 0); /* check if there is a keymap file e.g. km-e00100411.ini */ g_snprintf(filename, 255, "%s/km-%08x.ini", XRDP_CFG_PATH, keylayout); /* if the file does not exist, use only lower 16 bits instead */ if (!g_file_exist(filename)) { log_message(LOG_LEVEL_INFO, "Cannot find keymap file %s", filename); /* e.g. km-00000411.ini */ g_snprintf(filename, 255, "%s/km-%08x.ini", XRDP_CFG_PATH, basic_key_layout); } /* finally, use 'en-us' */ if (!g_file_exist(filename)) { log_message(LOG_LEVEL_INFO, "Cannot find keymap file %s", filename); g_snprintf(filename, 255, "%s/km-00000409.ini", XRDP_CFG_PATH); } if (g_file_exist(filename)) { fd = g_file_open(filename); log_message(LOG_LEVEL_INFO, "Loading keymap file %s", filename); if (fd != -1) { lkeymap = (struct xrdp_keymap *)g_malloc(sizeof(struct xrdp_keymap), 0); /* make a copy of the built-in keymap */ g_memcpy(lkeymap, keymap, sizeof(struct xrdp_keymap)); /* clear the keymaps */ g_memset(keymap, 0, sizeof(struct xrdp_keymap)); /* read the keymaps */ km_read_section(fd, "noshift", keymap->keys_noshift); km_read_section(fd, "shift", keymap->keys_shift); km_read_section(fd, "altgr", keymap->keys_altgr); km_read_section(fd, "shiftaltgr", keymap->keys_shiftaltgr); km_read_section(fd, "capslock", keymap->keys_capslock); km_read_section(fd, "capslockaltgr", keymap->keys_capslockaltgr); km_read_section(fd, "shiftcapslock", keymap->keys_shiftcapslock); km_read_section(fd, "shiftcapslockaltgr", keymap->keys_shiftcapslockaltgr); if (g_memcmp(lkeymap, keymap, sizeof(struct xrdp_keymap)) != 0) { log_message(LOG_LEVEL_WARNING, "local keymap file for 0x%08x found and doesn't match " "built in keymap, using local keymap file", keylayout); } g_free(lkeymap); g_file_close(fd); } } else { log_message(LOG_LEVEL_WARNING, "File does not exist: %s", filename); } g_free(filename); return 0; } xrdp-0.9.5/xrdp/xrdp.h000644 001751 001751 00000042643 13206023530 014530 0ustar00metameta000000 000000 /** * xrdp: A Remote Desktop Protocol server. * * Copyright (C) Jay Sorg 2004-2014 * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. * * main include file */ /* include other h files */ #include "arch.h" #include "parse.h" #include "trans.h" #include "list.h" #include "list16.h" #include "libxrdpinc.h" #include "xrdp_constants.h" #include "xrdp_types.h" #include "defines.h" #include "os_calls.h" #include "ssl_calls.h" #include "thread_calls.h" #include "file.h" #include "xrdp_client_info.h" #include "log.h" /* xrdp.c */ long g_xrdp_sync(long (*sync_func)(long param1, long param2), long sync_param1, long sync_param2); int g_is_term(void); void g_set_term(int in_val); tbus g_get_term_event(void); tbus g_get_sync_event(void); void g_process_waiting_function(void); /* xrdp_cache.c */ struct xrdp_cache* xrdp_cache_create(struct xrdp_wm* owner, struct xrdp_session* session, struct xrdp_client_info* client_info); void xrdp_cache_delete(struct xrdp_cache* self); int xrdp_cache_reset(struct xrdp_cache* self, struct xrdp_client_info* client_info); int xrdp_cache_add_bitmap(struct xrdp_cache* self, struct xrdp_bitmap* bitmap, int hints); int xrdp_cache_add_palette(struct xrdp_cache* self, int* palette); int xrdp_cache_add_char(struct xrdp_cache* self, struct xrdp_font_char* font_item); int xrdp_cache_add_pointer(struct xrdp_cache* self, struct xrdp_pointer_item* pointer_item); int xrdp_cache_add_pointer_static(struct xrdp_cache* self, struct xrdp_pointer_item* pointer_item, int index); int xrdp_cache_add_brush(struct xrdp_cache* self, char* brush_item_data); int xrdp_cache_add_os_bitmap(struct xrdp_cache* self, struct xrdp_bitmap* bitmap, int rdpindex); int xrdp_cache_remove_os_bitmap(struct xrdp_cache* self, int rdpindex); struct xrdp_os_bitmap_item* xrdp_cache_get_os_bitmap(struct xrdp_cache* self, int rdpindex); /* xrdp_wm.c */ struct xrdp_wm* xrdp_wm_create(struct xrdp_process* owner, struct xrdp_client_info* client_info); void xrdp_wm_delete(struct xrdp_wm* self); int xrdp_wm_send_palette(struct xrdp_wm* self); int xrdp_wm_send_bell(struct xrdp_wm* self); int xrdp_wm_load_static_colors_plus(struct xrdp_wm* self, char* autorun_name); int xrdp_wm_load_static_pointers(struct xrdp_wm* self); int xrdp_wm_init(struct xrdp_wm* self); int xrdp_wm_send_bitmap(struct xrdp_wm* self, struct xrdp_bitmap* bitmap, int x, int y, int cx, int cy); int xrdp_wm_set_pointer(struct xrdp_wm* self, int cache_idx); unsigned int xrdp_wm_htoi (const char *ptr); int xrdp_wm_set_focused(struct xrdp_wm* self, struct xrdp_bitmap* wnd); int xrdp_wm_get_vis_region(struct xrdp_wm* self, struct xrdp_bitmap* bitmap, int x, int y, int cx, int cy, struct xrdp_region* region, int clip_children); int xrdp_wm_mouse_move(struct xrdp_wm* self, int x, int y); int xrdp_wm_mouse_click(struct xrdp_wm* self, int x, int y, int but, int down); int xrdp_wm_key(struct xrdp_wm* self, int device_flags, int scan_code); int xrdp_wm_key_sync(struct xrdp_wm* self, int device_flags, int key_flags); int xrdp_wm_pu(struct xrdp_wm* self, struct xrdp_bitmap* control); int xrdp_wm_send_pointer(struct xrdp_wm* self, int cache_idx, char* data, char* mask, int x, int y, int bpp); int xrdp_wm_pointer(struct xrdp_wm* self, char* data, char* mask, int x, int y, int bpp); int callback(intptr_t id, int msg, intptr_t param1, intptr_t param2, intptr_t param3, intptr_t param4); int xrdp_wm_delete_all_children(struct xrdp_wm* self); int xrdp_wm_show_log(struct xrdp_wm *self); int xrdp_wm_log_msg(struct xrdp_wm *self, enum logLevels loglevel, const char *fmt, ...) printflike(3, 4); int xrdp_wm_get_wait_objs(struct xrdp_wm* self, tbus* robjs, int* rc, tbus* wobjs, int* wc, int* timeout); int xrdp_wm_check_wait_objs(struct xrdp_wm* self); int xrdp_wm_set_login_mode(struct xrdp_wm* self, int login_mode); /* xrdp_process.c */ struct xrdp_process* xrdp_process_create(struct xrdp_listen* owner, tbus done_event); void xrdp_process_delete(struct xrdp_process* self); int xrdp_process_main_loop(struct xrdp_process* self); /* xrdp_listen.c */ struct xrdp_listen* xrdp_listen_create(void); void xrdp_listen_delete(struct xrdp_listen* self); int xrdp_listen_main_loop(struct xrdp_listen* self); int xrdp_listen_test(void); /* xrdp_region.c */ struct xrdp_region* xrdp_region_create(struct xrdp_wm* wm); void xrdp_region_delete(struct xrdp_region* self); int xrdp_region_add_rect(struct xrdp_region* self, struct xrdp_rect* rect); int xrdp_region_subtract_rect(struct xrdp_region* self, struct xrdp_rect* rect); int xrdp_region_intersect_rect(struct xrdp_region* self, struct xrdp_rect* rect); int xrdp_region_get_rect(struct xrdp_region* self, int index, struct xrdp_rect* rect); /* xrdp_bitmap.c */ struct xrdp_bitmap* xrdp_bitmap_create(int width, int height, int bpp, int type, struct xrdp_wm* wm); struct xrdp_bitmap* xrdp_bitmap_create_with_data(int width, int height, int bpp, char* data, struct xrdp_wm* wm); void xrdp_bitmap_delete(struct xrdp_bitmap* self); struct xrdp_bitmap* xrdp_bitmap_get_child_by_id(struct xrdp_bitmap* self, int id); int xrdp_bitmap_set_focus(struct xrdp_bitmap* self, int focused); int xrdp_bitmap_resize(struct xrdp_bitmap* self, int width, int height); int xrdp_bitmap_load(struct xrdp_bitmap* self, const char* filename, int* palette); int xrdp_bitmap_get_pixel(struct xrdp_bitmap* self, int x, int y); int xrdp_bitmap_set_pixel(struct xrdp_bitmap* self, int x, int y, int pixel); int xrdp_bitmap_copy_box(struct xrdp_bitmap* self, struct xrdp_bitmap* dest, int x, int y, int cx, int cy); int xrdp_bitmap_hash_crc(struct xrdp_bitmap *self); int xrdp_bitmap_copy_box_with_crc(struct xrdp_bitmap* self, struct xrdp_bitmap* dest, int x, int y, int cx, int cy); int xrdp_bitmap_compare(struct xrdp_bitmap* self, struct xrdp_bitmap* b); int xrdp_bitmap_invalidate(struct xrdp_bitmap* self, struct xrdp_rect* rect); int xrdp_bitmap_def_proc(struct xrdp_bitmap* self, int msg, int param1, int param2); int xrdp_bitmap_to_screenx(struct xrdp_bitmap* self, int x); int xrdp_bitmap_to_screeny(struct xrdp_bitmap* self, int y); int xrdp_bitmap_from_screenx(struct xrdp_bitmap* self, int x); int xrdp_bitmap_from_screeny(struct xrdp_bitmap* self, int y); int xrdp_bitmap_get_screen_clip(struct xrdp_bitmap* self, struct xrdp_painter* painter, struct xrdp_rect* rect, int* dx, int* dy); /* xrdp_painter.c */ struct xrdp_painter* xrdp_painter_create(struct xrdp_wm* wm, struct xrdp_session* session); void xrdp_painter_delete(struct xrdp_painter* self); int wm_painter_set_target(struct xrdp_painter* self); int xrdp_painter_begin_update(struct xrdp_painter* self); int xrdp_painter_end_update(struct xrdp_painter* self); int xrdp_painter_font_needed(struct xrdp_painter* self); int xrdp_painter_set_clip(struct xrdp_painter* self, int x, int y, int cx, int cy); int xrdp_painter_clr_clip(struct xrdp_painter* self); int xrdp_painter_fill_rect(struct xrdp_painter* self, struct xrdp_bitmap* bitmap, int x, int y, int cx, int cy); int xrdp_painter_draw_bitmap(struct xrdp_painter* self, struct xrdp_bitmap* bitmap, struct xrdp_bitmap* to_draw, int x, int y, int cx, int cy); int xrdp_painter_text_width(struct xrdp_painter* self, const char *text); int xrdp_painter_text_height(struct xrdp_painter* self, const char *text); int xrdp_painter_draw_text(struct xrdp_painter* self, struct xrdp_bitmap* bitmap, int x, int y, const char* text); int xrdp_painter_draw_text2(struct xrdp_painter* self, struct xrdp_bitmap* bitmap, int font, int flags, int mixmode, int clip_left, int clip_top, int clip_right, int clip_bottom, int box_left, int box_top, int box_right, int box_bottom, int x, int y, char* data, int data_len); int xrdp_painter_copy(struct xrdp_painter* self, struct xrdp_bitmap* src, struct xrdp_bitmap* dst, int x, int y, int cx, int cy, int srcx, int srcy); int xrdp_painter_composite(struct xrdp_painter* self, struct xrdp_bitmap* src, int srcformat, int srcwidth, int srcrepeat, struct xrdp_bitmap* dst, int* srctransform, int mskflags, struct xrdp_bitmap* msk, int mskformat, int mskwidth, int mskrepeat, int op, int srcx, int srcy, int mskx, int msky, int dstx, int dsty, int width, int height, int dstformat); int xrdp_painter_line(struct xrdp_painter* self, struct xrdp_bitmap* bitmap, int x1, int y1, int x2, int y2); /* xrdp_font.c */ struct xrdp_font* xrdp_font_create(struct xrdp_wm* wm); void xrdp_font_delete(struct xrdp_font* self); int xrdp_font_item_compare(struct xrdp_font_char* font1, struct xrdp_font_char* font2); /* funcs.c */ int rect_contains_pt(struct xrdp_rect* in, int x, int y); int rect_intersect(struct xrdp_rect* in1, struct xrdp_rect* in2, struct xrdp_rect* out); int rect_contained_by(struct xrdp_rect* in1, int left, int top, int right, int bottom); int check_bounds(struct xrdp_bitmap* b, int* x, int* y, int* cx, int* cy); int add_char_at(char* text, int text_size, twchar ch, int index); int remove_char_at(char* text, int text_size, int index); int set_string(char** in_str, const char* in); int wchar_repeat(twchar* dest, int dest_size_in_wchars, twchar ch, int repeat); /* in lang.c */ struct xrdp_key_info* get_key_info_from_scan_code(int device_flags, int scan_code, int* keys, int caps_lock, int num_lock, int scroll_lock, struct xrdp_keymap* keymap); int get_keysym_from_scan_code(int device_flags, int scan_code, int* keys, int caps_lock, int num_lock, int scroll_lock, struct xrdp_keymap* keymap); twchar get_char_from_scan_code(int device_flags, int scan_code, int* keys, int caps_lock, int num_lock, int scroll_lock, struct xrdp_keymap* keymap); int get_keymaps(int keylayout, struct xrdp_keymap* keymap); /* xrdp_login_wnd.c */ int xrdp_login_wnd_create(struct xrdp_wm* self); int load_xrdp_config(struct xrdp_config *config, int bpp); /* xrdp_bitmap_compress.c */ int xrdp_bitmap_compress(char* in_data, int width, int height, struct stream* s, int bpp, int byte_limit, int start_line, struct stream* temp, int e); /* xrdp_mm.c */ struct xrdp_mm* xrdp_mm_create(struct xrdp_wm* owner); void xrdp_mm_delete(struct xrdp_mm* self); int xrdp_mm_connect(struct xrdp_mm* self); int xrdp_mm_process_channel_data(struct xrdp_mm* self, tbus param1, tbus param2, tbus param3, tbus param4); int xrdp_mm_get_wait_objs(struct xrdp_mm* self, tbus* read_objs, int* rcount, tbus* write_objs, int* wcount, int* timeout); int xrdp_mm_check_chan(struct xrdp_mm *self); int xrdp_mm_check_wait_objs(struct xrdp_mm* self); int xrdp_mm_frame_ack(struct xrdp_mm *self, int frame_id); int server_begin_update(struct xrdp_mod* mod); int server_end_update(struct xrdp_mod* mod); int server_bell_trigger(struct xrdp_mod* mod); int server_fill_rect(struct xrdp_mod* mod, int x, int y, int cx, int cy); int server_screen_blt(struct xrdp_mod* mod, int x, int y, int cx, int cy, int srcx, int srcy); int server_paint_rect(struct xrdp_mod* mod, int x, int y, int cx, int cy, char* data, int width, int height, int srcx, int srcy); int server_paint_rect_bpp(struct xrdp_mod* mod, int x, int y, int cx, int cy, char* data, int width, int height, int srcx, int srcy, int bpp); int server_composite(struct xrdp_mod* mod, int srcidx, int srcformat, int srcwidth, int srcrepeat, int* srctransform, int mskflags, int mskidx, int mskformat, int mskwidth, int mskrepeat, int op, int srcx, int srcy, int mskx, int msky, int dstx, int dsty, int width, int height, int dstformat); int server_paint_rects(struct xrdp_mod* mod, int num_drects, short *drects, int num_crects, short *crects, char *data, int width, int height, int flags, int frame_id); int server_set_pointer(struct xrdp_mod* mod, int x, int y, char* data, char* mask); int server_set_pointer_ex(struct xrdp_mod* mod, int x, int y, char* data, char* mask, int bpp); int server_palette(struct xrdp_mod* mod, int* palette); int server_msg(struct xrdp_mod* mod, char* msg, int code); int server_is_term(struct xrdp_mod* mod); int xrdp_child_fork(void); int server_set_clip(struct xrdp_mod* mod, int x, int y, int cx, int cy); int server_reset_clip(struct xrdp_mod* mod); int server_set_fgcolor(struct xrdp_mod* mod, int fgcolor); int server_set_bgcolor(struct xrdp_mod* mod, int bgcolor); int server_set_opcode(struct xrdp_mod* mod, int opcode); int server_set_mixmode(struct xrdp_mod* mod, int mixmode); int server_set_brush(struct xrdp_mod* mod, int x_origin, int y_origin, int style, char* pattern); int server_set_pen(struct xrdp_mod* mod, int style, int width); int server_draw_line(struct xrdp_mod* mod, int x1, int y1, int x2, int y2); int server_add_char(struct xrdp_mod* mod, int font, int character, int offset, int baseline, int width, int height, char* data); int server_draw_text(struct xrdp_mod* mod, int font, int flags, int mixmode, int clip_left, int clip_top, int clip_right, int clip_bottom, int box_left, int box_top, int box_right, int box_bottom, int x, int y, char* data, int data_len); int server_reset(struct xrdp_mod* mod, int width, int height, int bpp); int is_channel_allowed(struct xrdp_wm* wm, int channel_id); int server_query_channel(struct xrdp_mod* mod, int index, char* channel_name, int* channel_flags); int server_get_channel_id(struct xrdp_mod* mod, const char *name); int server_send_to_channel(struct xrdp_mod* mod, int channel_id, char* data, int data_len, int total_data_len, int flags); int server_create_os_surface(struct xrdp_mod* mod, int id, int width, int height); int server_create_os_surface_bpp(struct xrdp_mod* mod, int id, int width, int height, int bpp); int server_switch_os_surface(struct xrdp_mod* mod, int id); int server_delete_os_surface(struct xrdp_mod* mod, int id); int server_paint_rect_os(struct xrdp_mod* mod, int x, int y, int cx, int cy, int id, int srcx, int srcy); int server_set_hints(struct xrdp_mod* mod, int hints, int mask); int server_window_new_update(struct xrdp_mod* mod, int window_id, struct rail_window_state_order* window_state, int flags); int server_window_delete(struct xrdp_mod* mod, int window_id); int server_window_icon(struct xrdp_mod* mod, int window_id, int cache_entry, int cache_id, struct rail_icon_info* icon_info, int flags); int server_window_cached_icon(struct xrdp_mod* mod, int window_id, int cache_entry, int cache_id, int flags); int server_notify_new_update(struct xrdp_mod* mod, int window_id, int notify_id, struct rail_notify_state_order* notify_state, int flags); int server_notify_delete(struct xrdp_mod* mod, int window_id, int notify_id); int server_monitored_desktop(struct xrdp_mod* mod, struct rail_monitored_desktop_order* mdo, int flags); int server_add_char_alpha(struct xrdp_mod* mod, int font, int character, int offset, int baseline, int width, int height, char* data); int server_session_info(struct xrdp_mod *mod, const char *data, int data_bytes); xrdp-0.9.5/xrdp/xrdp_font.c000644 001751 001751 00000013175 13174271344 015563 0ustar00metameta000000 000000 /** * xrdp: A Remote Desktop Protocol server. * * Copyright (C) Jay Sorg 2004-2014 * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. * * fonts */ /* The fv1 files contain Font File Header (just one) FNT1 4 bytes Font Name 32 bytes Font Size 2 bytes Font Style 2 bytes Pad 8 bytes Font Data (repeats) Width 2 bytes Height 2 bytes Baseline 2 bytes Offset 2 bytes Incby 2 bytes Pad 6 bytes Glyph Data var, see FONT_DATASIZE macro */ #if defined(HAVE_CONFIG_H) #include #endif #include "xrdp.h" #include "log.h" #if 0 /* not used */ static char w_char[] = { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x08, 0x20, 0x80, 0x08, 0x50, 0x80, 0x04, 0x51, 0x00, 0x04, 0x51, 0x00, 0x04, 0x51, 0x00, 0x02, 0x8a, 0x00, 0x02, 0x8a, 0x00, 0x02, 0x8a, 0x00, 0x01, 0x04, 0x00, 0x01, 0x04, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, }; #endif /*****************************************************************************/ struct xrdp_font * xrdp_font_create(struct xrdp_wm *wm) { struct xrdp_font *self; struct stream *s; int fd; int b; int i; int index; int datasize; int file_size; struct xrdp_font_char *f; char file_path[256]; DEBUG(("in xrdp_font_create")); g_snprintf(file_path, 255, "%s/%s", XRDP_SHARE_PATH, DEFAULT_FONT_NAME); if (!g_file_exist(file_path)) { log_message(LOG_LEVEL_ERROR,"xrdp_font_create: error font file [%s] does not exist", file_path); return 0; } file_size = g_file_get_size(file_path); if (file_size < 1) { log_message(LOG_LEVEL_ERROR,"xrdp_font_create: error reading font from file [%s]", file_path); return 0; } self = (struct xrdp_font *)g_malloc(sizeof(struct xrdp_font), 1); self->wm = wm; make_stream(s); init_stream(s, file_size + 1024); fd = g_file_open(file_path); if (fd != -1) { b = g_file_read(fd, s->data, file_size + 1024); g_file_close(fd); if (b > 0) { s->end = s->data + b; in_uint8s(s, 4); in_uint8a(s, self->name, 32); in_uint16_le(s, self->size); in_uint16_le(s, self->style); in_uint8s(s, 8); index = 32; while (s_check_rem(s, 16)) { f = self->font_items + index; in_sint16_le(s, i); f->width = i; in_sint16_le(s, i); f->height = i; in_sint16_le(s, i); f->baseline = i; in_sint16_le(s, i); f->offset = i; in_sint16_le(s, i); f->incby = i; in_uint8s(s, 6); datasize = FONT_DATASIZE(f); if (datasize < 0 || datasize > 512) { /* shouldn't happen */ log_message(LOG_LEVEL_ERROR,"error in xrdp_font_create, datasize wrong"); log_message(LOG_LEVEL_DEBUG,"width %d height %d datasize %d index %d", f->width, f->height, datasize, index); break; } if (s_check_rem(s, datasize)) { f->data = (char *)g_malloc(datasize, 0); in_uint8a(s, f->data, datasize); } else { log_message(LOG_LEVEL_ERROR,"error in xrdp_font_create"); } index++; } } } free_stream(s); /* self->font_items[0].offset = -4; self->font_items[0].baseline = -16; self->font_items[0].width = 24; self->font_items[0].height = 16; self->font_items[0].data = g_malloc(3 * 16, 0); g_memcpy(self->font_items[0].data, w_char, 3 * 16); */ DEBUG(("out xrdp_font_create")); return self; } /*****************************************************************************/ /* free the font and all the items */ void xrdp_font_delete(struct xrdp_font *self) { int i; if (self == 0) { return; } for (i = 0; i < NUM_FONTS; i++) { g_free(self->font_items[i].data); } g_free(self); } /*****************************************************************************/ /* compare the two font items returns 1 if they match */ int xrdp_font_item_compare(struct xrdp_font_char *font1, struct xrdp_font_char *font2) { int datasize; if (font1 == 0) { return 0; } if (font2 == 0) { return 0; } if (font1->offset != font2->offset) { return 0; } if (font1->baseline != font2->baseline) { return 0; } if (font1->width != font2->width) { return 0; } if (font1->height != font2->height) { return 0; } datasize = FONT_DATASIZE(font1); if (g_memcmp(font1->data, font2->data, datasize) == 0) { return 1; } return 0; } xrdp-0.9.5/xrdp/xrdpwin.c000644 001751 001751 00000043453 13174271344 015255 0ustar00metameta000000 000000 /** * xrdp: A Remote Desktop Protocol server. * * Copyright (C) Jay Sorg 2004-2014 * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. * * main program */ #if defined(HAVE_CONFIG_H) #include #endif #if defined(_WIN32) #include #endif #include "xrdp.h" static struct xrdp_listen *g_listen = 0; static long g_threadid = 0; /* main threadid */ #if defined(_WIN32) static SERVICE_STATUS_HANDLE g_ssh = 0; static SERVICE_STATUS g_service_status; #endif static long g_sync_mutex = 0; static long g_sync1_mutex = 0; static tbus g_term_event = 0; static tbus g_sync_event = 0; /* synchronize stuff */ static int g_sync_command = 0; static long g_sync_result = 0; static long g_sync_param1 = 0; static long g_sync_param2 = 0; static long (*g_sync_func)(long param1, long param2); /*****************************************************************************/ long g_xrdp_sync(long (*sync_func)(long param1, long param2), long sync_param1, long sync_param2) { long sync_result; int sync_command; if (tc_threadid_equal(tc_get_threadid(), g_threadid)) { /* this is the main thread, call the function directly */ sync_result = sync_func(sync_param1, sync_param2); } else { tc_mutex_lock(g_sync1_mutex); tc_mutex_lock(g_sync_mutex); g_sync_param1 = sync_param1; g_sync_param2 = sync_param2; g_sync_func = sync_func; g_sync_command = 100; tc_mutex_unlock(g_sync_mutex); g_set_wait_obj(g_sync_event); do { g_sleep(100); tc_mutex_lock(g_sync_mutex); sync_command = g_sync_command; sync_result = g_sync_result; tc_mutex_unlock(g_sync_mutex); } while (sync_command != 0); tc_mutex_unlock(g_sync1_mutex); } return sync_result; } /*****************************************************************************/ void xrdp_shutdown(int sig) { tbus threadid; threadid = tc_get_threadid(); g_writeln("shutting down"); g_writeln("signal %d threadid %p", sig, threadid); if (!g_is_wait_obj_set(g_term_event)) { g_set_wait_obj(g_term_event); } } /*****************************************************************************/ int g_is_term(void) { return g_is_wait_obj_set(g_term_event); } /*****************************************************************************/ void g_set_term(int in_val) { if (in_val) { g_set_wait_obj(g_term_event); } else { g_reset_wait_obj(g_term_event); } } /*****************************************************************************/ tbus g_get_term_event(void) { return g_term_event; } /*****************************************************************************/ tbus g_get_sync_event(void) { return g_sync_event; } /*****************************************************************************/ void pipe_sig(int sig_num) { /* do nothing */ g_writeln("got XRDP WIN SIGPIPE(%d)", sig_num); } /*****************************************************************************/ void g_process_waiting_function(void) { tc_mutex_lock(g_sync_mutex); if (g_sync_command != 0) { if (g_sync_func != 0) { if (g_sync_command == 100) { g_sync_result = g_sync_func(g_sync_param1, g_sync_param2); } } g_sync_command = 0; } tc_mutex_unlock(g_sync_mutex); } /* win32 service control functions */ #if defined(_WIN32) /*****************************************************************************/ VOID WINAPI MyHandler(DWORD fdwControl) { if (g_ssh == 0) { return; } if (fdwControl == SERVICE_CONTROL_STOP) { g_service_status.dwCurrentState = SERVICE_STOP_PENDING; g_set_term(1); } else if (fdwControl == SERVICE_CONTROL_PAUSE) { /* shouldn't happen */ } else if (fdwControl == SERVICE_CONTROL_CONTINUE) { /* shouldn't happen */ } else if (fdwControl == SERVICE_CONTROL_INTERROGATE) { } else if (fdwControl == SERVICE_CONTROL_SHUTDOWN) { g_service_status.dwCurrentState = SERVICE_STOP_PENDING; g_set_term(1); } SetServiceStatus(g_ssh, &g_service_status); } /*****************************************************************************/ static void log_event(HANDLE han, char *msg) { ReportEvent(han, EVENTLOG_INFORMATION_TYPE, 0, 0, 0, 1, 0, &msg, 0); } /*****************************************************************************/ VOID WINAPI MyServiceMain(DWORD dwArgc, LPTSTR *lpszArgv) { WSADATA w; char text[256]; int pid; //HANDLE event_han; // int fd; // char text[256]; // fd = g_file_open("c:\\temp\\xrdp\\log.txt"); // g_file_write(fd, "hi\r\n", 4); //event_han = RegisterEventSource(0, "xrdp"); //log_event(event_han, "hi xrdp log"); g_threadid = tc_get_threadid(); g_set_current_dir("c:\\temp\\xrdp"); g_listen = 0; WSAStartup(2, &w); g_sync_mutex = tc_mutex_create(); g_sync1_mutex = tc_mutex_create(); pid = g_getpid(); g_snprintf(text, 255, "xrdp_%8.8x_main_term", pid); g_term_event = g_create_wait_obj(text); g_snprintf(text, 255, "xrdp_%8.8x_main_sync", pid); g_sync_event = g_create_wait_obj(text); g_memset(&g_service_status, 0, sizeof(SERVICE_STATUS)); g_service_status.dwServiceType = SERVICE_WIN32_OWN_PROCESS; g_service_status.dwCurrentState = SERVICE_RUNNING; g_service_status.dwControlsAccepted = SERVICE_CONTROL_INTERROGATE | SERVICE_ACCEPT_STOP | SERVICE_ACCEPT_SHUTDOWN; g_service_status.dwWin32ExitCode = NO_ERROR; g_service_status.dwServiceSpecificExitCode = 0; g_service_status.dwCheckPoint = 0; g_service_status.dwWaitHint = 0; // g_sprintf(text, "calling RegisterServiceCtrlHandler\r\n"); // g_file_write(fd, text, g_strlen(text)); g_ssh = RegisterServiceCtrlHandler("xrdp", MyHandler); if (g_ssh != 0) { // g_sprintf(text, "ok\r\n"); // g_file_write(fd, text, g_strlen(text)); SetServiceStatus(g_ssh, &g_service_status); g_listen = xrdp_listen_create(); xrdp_listen_main_loop(g_listen); g_sleep(100); g_service_status.dwCurrentState = SERVICE_STOPPED; SetServiceStatus(g_ssh, &g_service_status); } else { //g_sprintf(text, "RegisterServiceCtrlHandler failed\r\n"); //g_file_write(fd, text, g_strlen(text)); } xrdp_listen_delete(g_listen); tc_mutex_delete(g_sync_mutex); tc_mutex_delete(g_sync1_mutex); g_destroy_wait_obj(g_term_event); g_destroy_wait_obj(g_sync_event); WSACleanup(); //CloseHandle(event_han); } #endif /*****************************************************************************/ int main(int argc, char **argv) { int test; int host_be; #if defined(_WIN32) WSADATA w; SC_HANDLE sc_man; SC_HANDLE sc_ser; int run_as_service; SERVICE_TABLE_ENTRY te[2]; #else int pid; int fd; int no_daemon; char text[256]; char pid_file[256]; #endif g_init(); ssl_init(); /* check compiled endian with actual endian */ test = 1; host_be = !((int)(*(unsigned char *)(&test))); #if defined(B_ENDIAN) if (!host_be) #endif #if defined(L_ENDIAN) if (host_be) #endif { g_writeln("endian wrong, edit arch.h"); return 0; } /* check long, int and void* sizes */ if (sizeof(int) != 4) { g_writeln("unusable int size, must be 4"); return 0; } if (sizeof(long) != sizeof(void *)) { g_writeln("long size must match void* size"); return 0; } if (sizeof(long) != 4 && sizeof(long) != 8) { g_writeln("unusable long size, must be 4 or 8"); return 0; } if (sizeof(tui64) != 8) { g_writeln("unusable tui64 size, must be 8"); return 0; } #if defined(_WIN32) run_as_service = 1; if (argc == 2) { if (g_strncasecmp(argv[1], "-help", 255) == 0 || g_strncasecmp(argv[1], "--help", 255) == 0 || g_strncasecmp(argv[1], "-h", 255) == 0) { g_writeln("%s", ""); g_writeln("xrdp: A Remote Desktop Protocol server."); g_writeln("Copyright (C) Jay Sorg 2004-2011"); g_writeln("See http://xrdp.sourceforge.net for more information."); g_writeln("%s", ""); g_writeln("Usage: xrdp [options]"); g_writeln(" -h: show help"); g_writeln(" -install: install service"); g_writeln(" -remove: remove service"); g_writeln("%s", ""); g_exit(0); } else if (g_strncasecmp(argv[1], "-install", 255) == 0 || g_strncasecmp(argv[1], "--install", 255) == 0 || g_strncasecmp(argv[1], "-i", 255) == 0) { /* open service manager */ sc_man = OpenSCManager(0, 0, GENERIC_WRITE); if (sc_man == 0) { g_writeln("error OpenSCManager, do you have rights?"); g_exit(0); } /* check if service is already installed */ sc_ser = OpenService(sc_man, "xrdp", SERVICE_ALL_ACCESS); if (sc_ser == 0) { /* install service */ CreateService(sc_man, "xrdp", "xrdp", SERVICE_ALL_ACCESS, SERVICE_WIN32_OWN_PROCESS, SERVICE_DEMAND_START, SERVICE_ERROR_IGNORE, "c:\\temp\\xrdp\\xrdp.exe", 0, 0, 0, 0, 0); } else { g_writeln("error service is already installed"); CloseServiceHandle(sc_ser); CloseServiceHandle(sc_man); g_exit(0); } CloseServiceHandle(sc_man); g_exit(0); } else if (g_strncasecmp(argv[1], "-remove", 255) == 0 || g_strncasecmp(argv[1], "--remove", 255) == 0 || g_strncasecmp(argv[1], "-r", 255) == 0) { /* open service manager */ sc_man = OpenSCManager(0, 0, GENERIC_WRITE); if (sc_man == 0) { g_writeln("error OpenSCManager, do you have rights?"); g_exit(0); } /* check if service is already installed */ sc_ser = OpenService(sc_man, "xrdp", SERVICE_ALL_ACCESS); if (sc_ser == 0) { g_writeln("error service is not installed"); CloseServiceHandle(sc_man); g_exit(0); } DeleteService(sc_ser); CloseServiceHandle(sc_man); g_exit(0); } else { g_writeln("Unknown Parameter"); g_writeln("xrdp -h for help"); g_writeln("%s", ""); g_exit(0); } } else if (argc > 1) { g_writeln("Unknown Parameter"); g_writeln("xrdp -h for help"); g_writeln("%s", ""); g_exit(0); } if (run_as_service) { g_memset(&te, 0, sizeof(te)); te[0].lpServiceName = "xrdp"; te[0].lpServiceProc = MyServiceMain; StartServiceCtrlDispatcher(&te); g_exit(0); } WSAStartup(2, &w); #else /* _WIN32 */ g_snprintf(pid_file, 255, "%s/xrdp.pid", XRDP_PID_PATH); no_daemon = 0; if (argc == 2) { if ((g_strncasecmp(argv[1], "-kill", 255) == 0) || (g_strncasecmp(argv[1], "--kill", 255) == 0) || (g_strncasecmp(argv[1], "-k", 255) == 0)) { g_writeln("stopping xrdp"); /* read the xrdp.pid file */ fd = -1; if (g_file_exist(pid_file)) /* xrdp.pid */ { fd = g_file_open(pid_file); /* xrdp.pid */ } if (fd == -1) { g_writeln("cannot open %s, maybe xrdp is not running", pid_file); } else { g_memset(text, 0, 32); g_file_read(fd, text, 31); pid = g_atoi(text); g_writeln("stopping process id %d", pid); if (pid > 0) { g_sigterm(pid); } g_file_close(fd); } g_exit(0); } else if (g_strncasecmp(argv[1], "-nodaemon", 255) == 0 || g_strncasecmp(argv[1], "--nodaemon", 255) == 0 || g_strncasecmp(argv[1], "-nd", 255) == 0 || g_strncasecmp(argv[1], "--nd", 255) == 0 || g_strncasecmp(argv[1], "-ns", 255) == 0 || g_strncasecmp(argv[1], "--ns", 255) == 0) { no_daemon = 1; } else if (g_strncasecmp(argv[1], "-help", 255) == 0 || g_strncasecmp(argv[1], "--help", 255) == 0 || g_strncasecmp(argv[1], "-h", 255) == 0) { g_writeln("%s", ""); g_writeln("xrdp: A Remote Desktop Protocol server."); g_writeln("Copyright (C) Jay Sorg 2004-2011"); g_writeln("See http://xrdp.sourceforge.net for more information."); g_writeln("%s", ""); g_writeln("Usage: xrdp [options]"); g_writeln(" -h: show help"); g_writeln(" -nodaemon: don't fork into background"); g_writeln(" -kill: shut down xrdp"); g_writeln("%s", ""); g_exit(0); } else if ((g_strncasecmp(argv[1], "-v", 255) == 0) || (g_strncasecmp(argv[1], "--version", 255) == 0)) { g_writeln("%s", ""); g_writeln("xrdp: A Remote Desktop Protocol server."); g_writeln("Copyright (C) Jay Sorg 2004-2011"); g_writeln("See http://xrdp.sourceforge.net for more information."); g_writeln("Version %s", PACKAGE_VERSION); g_writeln("%s", ""); g_exit(0); } else { g_writeln("Unknown Parameter"); g_writeln("xrdp -h for help"); g_writeln("%s", ""); g_exit(0); } } else if (argc > 1) { g_writeln("Unknown Parameter"); g_writeln("xrdp -h for help"); g_writeln("%s", ""); g_exit(0); } if (g_file_exist(pid_file)) /* xrdp.pid */ { g_writeln("It looks like xrdp is already running."); g_writeln("If not, delete %s and try again.", pid_file); g_exit(0); } if (!no_daemon) { /* make sure we can write to pid file */ fd = g_file_open(pid_file); /* xrdp.pid */ if (fd == -1) { g_writeln("running in daemon mode with no access to pid files, quitting"); g_exit(0); } if (g_file_write(fd, "0", 1) == -1) { g_writeln("running in daemon mode with no access to pid files, quitting"); g_exit(0); } g_file_close(fd); g_file_delete(pid_file); } if (!no_daemon) { /* start of daemonizing code */ pid = g_fork(); if (pid == -1) { g_writeln("problem forking"); g_exit(1); } if (0 != pid) { g_writeln("process %d started ok", pid); /* exit, this is the main process */ g_exit(0); } g_sleep(1000); g_file_close(0); g_file_close(1); g_file_close(2); g_file_open("/dev/null"); g_file_open("/dev/null"); g_file_open("/dev/null"); /* end of daemonizing code */ } if (!no_daemon) { /* write the pid to file */ pid = g_getpid(); fd = g_file_open(pid_file); /* xrdp.pid */ if (fd == -1) { g_writeln("trying to write process id to xrdp.pid"); g_writeln("problem opening xrdp.pid"); g_writeln("maybe no rights"); } else { g_sprintf(text, "%d", pid); g_file_write(fd, text, g_strlen(text)); g_file_close(fd); } } #endif g_threadid = tc_get_threadid(); g_listen = xrdp_listen_create(); g_signal_user_interrupt(xrdp_shutdown); /* SIGINT */ g_signal_pipe(pipe_sig); /* SIGPIPE */ g_signal_terminate(xrdp_shutdown); /* SIGTERM */ g_sync_mutex = tc_mutex_create(); g_sync1_mutex = tc_mutex_create(); pid = g_getpid(); g_snprintf(text, 255, "xrdp_%8.8x_main_term", pid); g_term_event = g_create_wait_obj(text); g_snprintf(text, 255, "xrdp_%8.8x_main_sync", pid); g_sync_event = g_create_wait_obj(text); if (g_term_event == 0) { g_writeln("error creating g_term_event"); } xrdp_listen_main_loop(g_listen); xrdp_listen_delete(g_listen); tc_mutex_delete(g_sync_mutex); tc_mutex_delete(g_sync1_mutex); g_delete_wait_obj(g_term_event); g_delete_wait_obj(g_sync_event); #if defined(_WIN32) /* I don't think it ever gets here */ /* when running in win32 app mode, control c exits right away */ WSACleanup(); #else /* delete the xrdp.pid file */ g_file_delete(pid_file); #endif return 0; } xrdp-0.9.5/xrdp/Makefile.in000644 001751 001751 00000064440 13220730775 015462 0ustar00metameta000000 000000 # Makefile.in generated by automake 1.15.1 from Makefile.am. # @configure_input@ # Copyright (C) 1994-2017 Free Software Foundation, Inc. # This Makefile.in is free software; the Free Software Foundation # gives unlimited permission to copy and/or distribute it, # with or without modifications, as long as this notice is preserved. # This program is distributed in the hope that it will be useful, # but WITHOUT ANY WARRANTY, to the extent permitted by law; without # even the implied warranty of MERCHANTABILITY or FITNESS FOR A # PARTICULAR PURPOSE. @SET_MAKE@ VPATH = @srcdir@ am__is_gnu_make = { \ if test -z '$(MAKELEVEL)'; then \ false; \ elif test -n '$(MAKE_HOST)'; then \ true; \ elif test -n '$(MAKE_VERSION)' && test -n '$(CURDIR)'; then \ true; \ else \ false; \ fi; \ } am__make_running_with_option = \ case $${target_option-} in \ ?) ;; \ *) echo "am__make_running_with_option: internal error: invalid" \ "target option '$${target_option-}' specified" >&2; \ exit 1;; \ esac; \ has_opt=no; \ sane_makeflags=$$MAKEFLAGS; \ if $(am__is_gnu_make); then \ sane_makeflags=$$MFLAGS; \ else \ case $$MAKEFLAGS in \ *\\[\ \ ]*) \ bs=\\; \ sane_makeflags=`printf '%s\n' "$$MAKEFLAGS" \ | sed "s/$$bs$$bs[$$bs $$bs ]*//g"`;; \ esac; \ fi; \ skip_next=no; \ strip_trailopt () \ { \ flg=`printf '%s\n' "$$flg" | sed "s/$$1.*$$//"`; \ }; \ for flg in $$sane_makeflags; do \ test $$skip_next = yes && { skip_next=no; continue; }; \ case $$flg in \ *=*|--*) continue;; \ -*I) strip_trailopt 'I'; skip_next=yes;; \ -*I?*) strip_trailopt 'I';; \ -*O) strip_trailopt 'O'; skip_next=yes;; \ -*O?*) strip_trailopt 'O';; \ -*l) strip_trailopt 'l'; skip_next=yes;; \ -*l?*) strip_trailopt 'l';; \ -[dEDm]) skip_next=yes;; \ -[JT]) skip_next=yes;; \ esac; \ case $$flg in \ *$$target_option*) has_opt=yes; break;; \ esac; \ done; \ test $$has_opt = yes am__make_dryrun = (target_option=n; $(am__make_running_with_option)) am__make_keepgoing = (target_option=k; $(am__make_running_with_option)) pkgdatadir = $(datadir)/@PACKAGE@ pkgincludedir = $(includedir)/@PACKAGE@ pkglibdir = $(libdir)/@PACKAGE@ pkglibexecdir = $(libexecdir)/@PACKAGE@ am__cd = CDPATH="$${ZSH_VERSION+.}$(PATH_SEPARATOR)" && cd install_sh_DATA = $(install_sh) -c -m 644 install_sh_PROGRAM = $(install_sh) -c install_sh_SCRIPT = $(install_sh) -c INSTALL_HEADER = $(INSTALL_DATA) transform = $(program_transform_name) NORMAL_INSTALL = : PRE_INSTALL = : POST_INSTALL = : NORMAL_UNINSTALL = : PRE_UNINSTALL = : POST_UNINSTALL = : build_triplet = @build@ host_triplet = @host@ @XRDP_DEBUG_TRUE@am__append_1 = -DXRDP_DEBUG @XRDP_RFXCODEC_TRUE@am__append_2 = -DXRDP_RFXCODEC \ @XRDP_RFXCODEC_TRUE@ -I$(top_srcdir)/librfxcodec/include @XRDP_RFXCODEC_TRUE@am__append_3 = $(top_builddir)/librfxcodec/src/.libs/librfxencode.a @XRDP_PIXMAN_TRUE@am__append_4 = -DXRDP_PIXMAN $(PIXMAN_CFLAGS) @XRDP_PIXMAN_TRUE@am__append_5 = $(PIXMAN_LIBS) @XRDP_PAINTER_TRUE@am__append_6 = -DXRDP_PAINTER \ @XRDP_PAINTER_TRUE@ -I$(top_srcdir)/libpainter/include @XRDP_PAINTER_TRUE@am__append_7 = $(top_builddir)/libpainter/src/.libs/libpainter.a sbin_PROGRAMS = xrdp$(EXEEXT) subdir = xrdp ACLOCAL_M4 = $(top_srcdir)/aclocal.m4 am__aclocal_m4_deps = $(top_srcdir)/m4/ax_append_compile_flags.m4 \ $(top_srcdir)/m4/ax_append_flag.m4 \ $(top_srcdir)/m4/ax_cflags_warn_all.m4 \ $(top_srcdir)/m4/ax_check_compile_flag.m4 \ $(top_srcdir)/m4/ax_gcc_func_attribute.m4 \ $(top_srcdir)/m4/ax_require_defined.m4 \ $(top_srcdir)/m4/ax_type_socklen_t.m4 \ $(top_srcdir)/m4/libtool.m4 $(top_srcdir)/m4/ltoptions.m4 \ $(top_srcdir)/m4/ltsugar.m4 $(top_srcdir)/m4/ltversion.m4 \ $(top_srcdir)/m4/lt~obsolete.m4 $(top_srcdir)/m4/pkg.m4 \ $(top_srcdir)/configure.ac am__configure_deps = $(am__aclocal_m4_deps) $(CONFIGURE_DEPENDENCIES) \ $(ACLOCAL_M4) DIST_COMMON = $(srcdir)/Makefile.am $(dist_xrdppkgdata_DATA) \ $(dist_xrdpsysconf_DATA) $(am__DIST_COMMON) mkinstalldirs = $(install_sh) -d CONFIG_HEADER = $(top_builddir)/config_ac.h CONFIG_CLEAN_FILES = CONFIG_CLEAN_VPATH_FILES = am__installdirs = "$(DESTDIR)$(sbindir)" "$(DESTDIR)$(xrdppkgdatadir)" \ "$(DESTDIR)$(xrdpsysconfdir)" PROGRAMS = $(sbin_PROGRAMS) am_xrdp_OBJECTS = funcs.$(OBJEXT) lang.$(OBJEXT) xrdp.$(OBJEXT) \ xrdp_bitmap.$(OBJEXT) xrdp_cache.$(OBJEXT) \ xrdp_encoder.$(OBJEXT) xrdp_font.$(OBJEXT) \ xrdp_listen.$(OBJEXT) xrdp_login_wnd.$(OBJEXT) \ xrdp_mm.$(OBJEXT) xrdp_painter.$(OBJEXT) \ xrdp_process.$(OBJEXT) xrdp_region.$(OBJEXT) xrdp_wm.$(OBJEXT) xrdp_OBJECTS = $(am_xrdp_OBJECTS) am__DEPENDENCIES_1 = @XRDP_PIXMAN_TRUE@am__DEPENDENCIES_2 = $(am__DEPENDENCIES_1) am__DEPENDENCIES_3 = $(am__append_3) $(am__DEPENDENCIES_2) \ $(am__append_7) xrdp_DEPENDENCIES = $(top_builddir)/common/libcommon.la \ $(top_builddir)/libxrdp/libxrdp.la $(am__DEPENDENCIES_3) AM_V_lt = $(am__v_lt_@AM_V@) am__v_lt_ = $(am__v_lt_@AM_DEFAULT_V@) am__v_lt_0 = --silent am__v_lt_1 = AM_V_P = $(am__v_P_@AM_V@) am__v_P_ = $(am__v_P_@AM_DEFAULT_V@) am__v_P_0 = false am__v_P_1 = : AM_V_GEN = $(am__v_GEN_@AM_V@) am__v_GEN_ = $(am__v_GEN_@AM_DEFAULT_V@) am__v_GEN_0 = @echo " GEN " $@; am__v_GEN_1 = AM_V_at = $(am__v_at_@AM_V@) am__v_at_ = $(am__v_at_@AM_DEFAULT_V@) am__v_at_0 = @ am__v_at_1 = DEFAULT_INCLUDES = -I.@am__isrc@ -I$(top_builddir) depcomp = $(SHELL) $(top_srcdir)/depcomp am__depfiles_maybe = depfiles am__mv = mv -f COMPILE = $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) \ $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) LTCOMPILE = $(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) \ $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) \ $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) \ $(AM_CFLAGS) $(CFLAGS) AM_V_CC = $(am__v_CC_@AM_V@) am__v_CC_ = $(am__v_CC_@AM_DEFAULT_V@) am__v_CC_0 = @echo " CC " $@; am__v_CC_1 = CCLD = $(CC) LINK = $(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) \ $(LIBTOOLFLAGS) --mode=link $(CCLD) $(AM_CFLAGS) $(CFLAGS) \ $(AM_LDFLAGS) $(LDFLAGS) -o $@ AM_V_CCLD = $(am__v_CCLD_@AM_V@) am__v_CCLD_ = $(am__v_CCLD_@AM_DEFAULT_V@) am__v_CCLD_0 = @echo " CCLD " $@; am__v_CCLD_1 = SOURCES = $(xrdp_SOURCES) DIST_SOURCES = $(xrdp_SOURCES) am__can_run_installinfo = \ case $$AM_UPDATE_INFO_DIR in \ n|no|NO) false;; \ *) (install-info --version) >/dev/null 2>&1;; \ esac am__vpath_adj_setup = srcdirstrip=`echo "$(srcdir)" | sed 's|.|.|g'`; am__vpath_adj = case $$p in \ $(srcdir)/*) f=`echo "$$p" | sed "s|^$$srcdirstrip/||"`;; \ *) f=$$p;; \ esac; am__strip_dir = f=`echo $$p | sed -e 's|^.*/||'`; am__install_max = 40 am__nobase_strip_setup = \ srcdirstrip=`echo "$(srcdir)" | sed 's/[].[^$$\\*|]/\\\\&/g'` am__nobase_strip = \ for p in $$list; do echo "$$p"; done | sed -e "s|$$srcdirstrip/||" am__nobase_list = $(am__nobase_strip_setup); \ for p in $$list; do echo "$$p $$p"; done | \ sed "s| $$srcdirstrip/| |;"' / .*\//!s/ .*/ ./; s,\( .*\)/[^/]*$$,\1,' | \ $(AWK) 'BEGIN { files["."] = "" } { files[$$2] = files[$$2] " " $$1; \ if (++n[$$2] == $(am__install_max)) \ { print $$2, files[$$2]; n[$$2] = 0; files[$$2] = "" } } \ END { for (dir in files) print dir, files[dir] }' am__base_list = \ sed '$$!N;$$!N;$$!N;$$!N;$$!N;$$!N;$$!N;s/\n/ /g' | \ sed '$$!N;$$!N;$$!N;$$!N;s/\n/ /g' am__uninstall_files_from_dir = { \ test -z "$$files" \ || { test ! -d "$$dir" && test ! -f "$$dir" && test ! -r "$$dir"; } \ || { echo " ( cd '$$dir' && rm -f" $$files ")"; \ $(am__cd) "$$dir" && rm -f $$files; }; \ } DATA = $(dist_xrdppkgdata_DATA) $(dist_xrdpsysconf_DATA) am__tagged_files = $(HEADERS) $(SOURCES) $(TAGS_FILES) $(LISP) # Read a list of newline-separated strings from the standard input, # and print each of them once, without duplicates. Input order is # *not* preserved. am__uniquify_input = $(AWK) '\ BEGIN { nonempty = 0; } \ { items[$$0] = 1; nonempty = 1; } \ END { if (nonempty) { for (i in items) print i; }; } \ ' # Make sure the list of sources is unique. This is necessary because, # e.g., the same source file might be shared among _SOURCES variables # for different programs/libraries. am__define_uniq_tagged_files = \ list='$(am__tagged_files)'; \ unique=`for i in $$list; do \ if test -f "$$i"; then echo $$i; else echo $(srcdir)/$$i; fi; \ done | $(am__uniquify_input)` ETAGS = etags CTAGS = ctags am__DIST_COMMON = $(srcdir)/Makefile.in $(top_srcdir)/depcomp DISTFILES = $(DIST_COMMON) $(DIST_SOURCES) $(TEXINFOS) $(EXTRA_DIST) ACLOCAL = @ACLOCAL@ AMTAR = @AMTAR@ AM_DEFAULT_VERBOSITY = @AM_DEFAULT_VERBOSITY@ AR = @AR@ AUTOCONF = @AUTOCONF@ AUTOHEADER = @AUTOHEADER@ AUTOMAKE = @AUTOMAKE@ AWK = @AWK@ CC = @CC@ CCDEPMODE = @CCDEPMODE@ CFLAGS = @CFLAGS@ CPP = @CPP@ CPPFLAGS = @CPPFLAGS@ CYGPATH_W = @CYGPATH_W@ DEFS = @DEFS@ DEPDIR = @DEPDIR@ DLLTOOL = @DLLTOOL@ DLOPEN_LIBS = @DLOPEN_LIBS@ DSYMUTIL = @DSYMUTIL@ DUMPBIN = @DUMPBIN@ ECHO_C = @ECHO_C@ ECHO_N = @ECHO_N@ ECHO_T = @ECHO_T@ EGREP = @EGREP@ EXEEXT = @EXEEXT@ FDKAAC_CFLAGS = @FDKAAC_CFLAGS@ FDKAAC_LIBS = @FDKAAC_LIBS@ FGREP = @FGREP@ FREERDP_CFLAGS = @FREERDP_CFLAGS@ FREERDP_LIBS = @FREERDP_LIBS@ FUSE_CFLAGS = @FUSE_CFLAGS@ FUSE_LIBS = @FUSE_LIBS@ GREP = @GREP@ INSTALL = @INSTALL@ INSTALL_DATA = @INSTALL_DATA@ INSTALL_PROGRAM = @INSTALL_PROGRAM@ INSTALL_SCRIPT = @INSTALL_SCRIPT@ INSTALL_STRIP_PROGRAM = @INSTALL_STRIP_PROGRAM@ LD = @LD@ LDFLAGS = @LDFLAGS@ LIBOBJS = @LIBOBJS@ LIBS = @LIBS@ LIBTOOL = @LIBTOOL@ LIPO = @LIPO@ LN_S = @LN_S@ LTLIBOBJS = @LTLIBOBJS@ LT_SYS_LIBRARY_PATH = @LT_SYS_LIBRARY_PATH@ MAKEINFO = @MAKEINFO@ MANIFEST_TOOL = @MANIFEST_TOOL@ MKDIR_P = @MKDIR_P@ NM = @NM@ NMEDIT = @NMEDIT@ OBJDUMP = @OBJDUMP@ OBJEXT = @OBJEXT@ OPENSSL = @OPENSSL@ OPENSSL_CFLAGS = @OPENSSL_CFLAGS@ OPENSSL_LIBS = @OPENSSL_LIBS@ OTOOL = @OTOOL@ OTOOL64 = @OTOOL64@ PACKAGE = @PACKAGE@ PACKAGE_BUGREPORT = @PACKAGE_BUGREPORT@ PACKAGE_NAME = @PACKAGE_NAME@ PACKAGE_STRING = @PACKAGE_STRING@ PACKAGE_TARNAME = @PACKAGE_TARNAME@ PACKAGE_URL = @PACKAGE_URL@ PACKAGE_VERSION = @PACKAGE_VERSION@ PAM_RULES = @PAM_RULES@ PATH_SEPARATOR = @PATH_SEPARATOR@ PIXMAN_CFLAGS = @PIXMAN_CFLAGS@ PIXMAN_LIBS = @PIXMAN_LIBS@ PKG_CONFIG = @PKG_CONFIG@ PKG_CONFIG_LIBDIR = @PKG_CONFIG_LIBDIR@ PKG_CONFIG_PATH = @PKG_CONFIG_PATH@ RANLIB = @RANLIB@ SED = @SED@ SET_MAKE = @SET_MAKE@ SHELL = @SHELL@ STRIP = @STRIP@ TurboJpegIncDir = @TurboJpegIncDir@ TurboJpegLibDir = @TurboJpegLibDir@ VERSION = @VERSION@ XMKMF = @XMKMF@ X_CFLAGS = @X_CFLAGS@ X_EXTRA_LIBS = @X_EXTRA_LIBS@ X_LIBS = @X_LIBS@ X_PRE_LIBS = @X_PRE_LIBS@ abs_builddir = @abs_builddir@ abs_srcdir = @abs_srcdir@ abs_top_builddir = @abs_top_builddir@ abs_top_srcdir = @abs_top_srcdir@ ac_ct_AR = @ac_ct_AR@ ac_ct_CC = @ac_ct_CC@ ac_ct_DUMPBIN = @ac_ct_DUMPBIN@ am__include = @am__include@ am__leading_dot = @am__leading_dot@ am__quote = @am__quote@ am__tar = @am__tar@ am__untar = @am__untar@ bindir = @bindir@ build = @build@ build_alias = @build_alias@ build_cpu = @build_cpu@ build_os = @build_os@ build_vendor = @build_vendor@ builddir = @builddir@ datadir = @datadir@ datarootdir = @datarootdir@ docdir = @docdir@ dvidir = @dvidir@ exec_prefix = @exec_prefix@ host = @host@ host_alias = @host_alias@ host_cpu = @host_cpu@ host_os = @host_os@ host_vendor = @host_vendor@ htmldir = @htmldir@ includedir = @includedir@ infodir = @infodir@ install_sh = @install_sh@ libdir = @libdir@ libexecdir = @libexecdir@ localedir = @localedir@ localstatedir = @localstatedir@ mandir = @mandir@ mkdir_p = @mkdir_p@ moduledir = @moduledir@ oldincludedir = @oldincludedir@ pdfdir = @pdfdir@ pkgconfigdir = @pkgconfigdir@ prefix = @prefix@ program_transform_name = @program_transform_name@ psdir = @psdir@ sbindir = @sbindir@ sharedstatedir = @sharedstatedir@ socketdir = @socketdir@ srcdir = @srcdir@ subdirs = @subdirs@ sysconfdir = @sysconfdir@ systemdsystemunitdir = @systemdsystemunitdir@ target_alias = @target_alias@ top_build_prefix = @top_build_prefix@ top_builddir = @top_builddir@ top_srcdir = @top_srcdir@ EXTRA_DIST = \ czech.txt \ rdp-scan-codes.txt \ xrdpwin.c AM_CPPFLAGS = -DXRDP_CFG_PATH=\"${sysconfdir}/xrdp\" \ -DXRDP_SBIN_PATH=\"${sbindir}\" \ -DXRDP_SHARE_PATH=\"${datadir}/xrdp\" \ -DXRDP_PID_PATH=\"${localstatedir}/run\" \ -DXRDP_MODULE_PATH=\"${moduledir}\" \ -DXRDP_SOCKET_PATH=\"${socketdir}\" -I$(top_builddir) \ -I$(top_srcdir)/common -I$(top_srcdir)/libxrdp $(am__append_1) \ $(am__append_2) $(am__append_4) $(am__append_6) XRDP_EXTRA_LIBS = $(am__append_3) $(am__append_5) $(am__append_7) xrdp_SOURCES = \ funcs.c \ lang.c \ xrdp.c \ xrdp.h \ xrdp_bitmap.c \ xrdp_cache.c \ xrdp_encoder.c \ xrdp_encoder.h \ xrdp_font.c \ xrdp_listen.c \ xrdp_login_wnd.c \ xrdp_mm.c \ xrdp_painter.c \ xrdp_process.c \ xrdp_region.c \ xrdp_types.h \ xrdp_wm.c xrdp_LDADD = \ $(top_builddir)/common/libcommon.la \ $(top_builddir)/libxrdp/libxrdp.la \ $(XRDP_EXTRA_LIBS) xrdpsysconfdir = $(sysconfdir)/xrdp dist_xrdpsysconf_DATA = \ xrdp.ini \ xrdp_keyboard.ini xrdppkgdatadir = $(datadir)/xrdp dist_xrdppkgdata_DATA = \ ad24b.bmp \ ad256.bmp \ xrdp24b.bmp \ xrdp256.bmp \ xrdp_logo.bmp \ sans-10.fv1 \ cursor0.cur \ cursor1.cur all: all-am .SUFFIXES: .SUFFIXES: .c .lo .o .obj $(srcdir)/Makefile.in: $(srcdir)/Makefile.am $(am__configure_deps) @for dep in $?; do \ case '$(am__configure_deps)' in \ *$$dep*) \ ( cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh ) \ && { if test -f $@; then exit 0; else break; fi; }; \ exit 1;; \ esac; \ done; \ echo ' cd $(top_srcdir) && $(AUTOMAKE) --foreign xrdp/Makefile'; \ $(am__cd) $(top_srcdir) && \ $(AUTOMAKE) --foreign xrdp/Makefile Makefile: $(srcdir)/Makefile.in $(top_builddir)/config.status @case '$?' in \ *config.status*) \ cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh;; \ *) \ echo ' cd $(top_builddir) && $(SHELL) ./config.status $(subdir)/$@ $(am__depfiles_maybe)'; \ cd $(top_builddir) && $(SHELL) ./config.status $(subdir)/$@ $(am__depfiles_maybe);; \ esac; $(top_builddir)/config.status: $(top_srcdir)/configure $(CONFIG_STATUS_DEPENDENCIES) cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh $(top_srcdir)/configure: $(am__configure_deps) cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh $(ACLOCAL_M4): $(am__aclocal_m4_deps) cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh $(am__aclocal_m4_deps): install-sbinPROGRAMS: $(sbin_PROGRAMS) @$(NORMAL_INSTALL) @list='$(sbin_PROGRAMS)'; test -n "$(sbindir)" || list=; \ if test -n "$$list"; then \ echo " $(MKDIR_P) '$(DESTDIR)$(sbindir)'"; \ $(MKDIR_P) "$(DESTDIR)$(sbindir)" || exit 1; \ fi; \ for p in $$list; do echo "$$p $$p"; done | \ sed 's/$(EXEEXT)$$//' | \ while read p p1; do if test -f $$p \ || test -f $$p1 \ ; then echo "$$p"; echo "$$p"; else :; fi; \ done | \ sed -e 'p;s,.*/,,;n;h' \ -e 's|.*|.|' \ -e 'p;x;s,.*/,,;s/$(EXEEXT)$$//;$(transform);s/$$/$(EXEEXT)/' | \ sed 'N;N;N;s,\n, ,g' | \ $(AWK) 'BEGIN { files["."] = ""; dirs["."] = 1 } \ { d=$$3; if (dirs[d] != 1) { print "d", d; dirs[d] = 1 } \ if ($$2 == $$4) files[d] = files[d] " " $$1; \ else { print "f", $$3 "/" $$4, $$1; } } \ END { for (d in files) print "f", d, files[d] }' | \ while read type dir files; do \ if test "$$dir" = .; then dir=; else dir=/$$dir; fi; \ test -z "$$files" || { \ echo " $(INSTALL_PROGRAM_ENV) $(LIBTOOL) $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=install $(INSTALL_PROGRAM) $$files '$(DESTDIR)$(sbindir)$$dir'"; \ $(INSTALL_PROGRAM_ENV) $(LIBTOOL) $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=install $(INSTALL_PROGRAM) $$files "$(DESTDIR)$(sbindir)$$dir" || exit $$?; \ } \ ; done uninstall-sbinPROGRAMS: @$(NORMAL_UNINSTALL) @list='$(sbin_PROGRAMS)'; test -n "$(sbindir)" || list=; \ files=`for p in $$list; do echo "$$p"; done | \ sed -e 'h;s,^.*/,,;s/$(EXEEXT)$$//;$(transform)' \ -e 's/$$/$(EXEEXT)/' \ `; \ test -n "$$list" || exit 0; \ echo " ( cd '$(DESTDIR)$(sbindir)' && rm -f" $$files ")"; \ cd "$(DESTDIR)$(sbindir)" && rm -f $$files clean-sbinPROGRAMS: @list='$(sbin_PROGRAMS)'; test -n "$$list" || exit 0; \ echo " rm -f" $$list; \ rm -f $$list || exit $$?; \ test -n "$(EXEEXT)" || exit 0; \ list=`for p in $$list; do echo "$$p"; done | sed 's/$(EXEEXT)$$//'`; \ echo " rm -f" $$list; \ rm -f $$list xrdp$(EXEEXT): $(xrdp_OBJECTS) $(xrdp_DEPENDENCIES) $(EXTRA_xrdp_DEPENDENCIES) @rm -f xrdp$(EXEEXT) $(AM_V_CCLD)$(LINK) $(xrdp_OBJECTS) $(xrdp_LDADD) $(LIBS) mostlyclean-compile: -rm -f *.$(OBJEXT) distclean-compile: -rm -f *.tab.c @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/funcs.Po@am__quote@ @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/lang.Po@am__quote@ @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/xrdp.Po@am__quote@ @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/xrdp_bitmap.Po@am__quote@ @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/xrdp_cache.Po@am__quote@ @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/xrdp_encoder.Po@am__quote@ @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/xrdp_font.Po@am__quote@ @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/xrdp_listen.Po@am__quote@ @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/xrdp_login_wnd.Po@am__quote@ @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/xrdp_mm.Po@am__quote@ @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/xrdp_painter.Po@am__quote@ @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/xrdp_process.Po@am__quote@ @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/xrdp_region.Po@am__quote@ @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/xrdp_wm.Po@am__quote@ .c.o: @am__fastdepCC_TRUE@ $(AM_V_CC)$(COMPILE) -MT $@ -MD -MP -MF $(DEPDIR)/$*.Tpo -c -o $@ $< @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) $(DEPDIR)/$*.Tpo $(DEPDIR)/$*.Po @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='$<' object='$@' libtool=no @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(COMPILE) -c -o $@ $< .c.obj: @am__fastdepCC_TRUE@ $(AM_V_CC)$(COMPILE) -MT $@ -MD -MP -MF $(DEPDIR)/$*.Tpo -c -o $@ `$(CYGPATH_W) '$<'` @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) $(DEPDIR)/$*.Tpo $(DEPDIR)/$*.Po @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='$<' object='$@' libtool=no @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(COMPILE) -c -o $@ `$(CYGPATH_W) '$<'` .c.lo: @am__fastdepCC_TRUE@ $(AM_V_CC)$(LTCOMPILE) -MT $@ -MD -MP -MF $(DEPDIR)/$*.Tpo -c -o $@ $< @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) $(DEPDIR)/$*.Tpo $(DEPDIR)/$*.Plo @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='$<' object='$@' libtool=yes @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(LTCOMPILE) -c -o $@ $< mostlyclean-libtool: -rm -f *.lo clean-libtool: -rm -rf .libs _libs install-dist_xrdppkgdataDATA: $(dist_xrdppkgdata_DATA) @$(NORMAL_INSTALL) @list='$(dist_xrdppkgdata_DATA)'; test -n "$(xrdppkgdatadir)" || list=; \ if test -n "$$list"; then \ echo " $(MKDIR_P) '$(DESTDIR)$(xrdppkgdatadir)'"; \ $(MKDIR_P) "$(DESTDIR)$(xrdppkgdatadir)" || exit 1; \ fi; \ for p in $$list; do \ if test -f "$$p"; then d=; else d="$(srcdir)/"; fi; \ echo "$$d$$p"; \ done | $(am__base_list) | \ while read files; do \ echo " $(INSTALL_DATA) $$files '$(DESTDIR)$(xrdppkgdatadir)'"; \ $(INSTALL_DATA) $$files "$(DESTDIR)$(xrdppkgdatadir)" || exit $$?; \ done uninstall-dist_xrdppkgdataDATA: @$(NORMAL_UNINSTALL) @list='$(dist_xrdppkgdata_DATA)'; test -n "$(xrdppkgdatadir)" || list=; \ files=`for p in $$list; do echo $$p; done | sed -e 's|^.*/||'`; \ dir='$(DESTDIR)$(xrdppkgdatadir)'; $(am__uninstall_files_from_dir) install-dist_xrdpsysconfDATA: $(dist_xrdpsysconf_DATA) @$(NORMAL_INSTALL) @list='$(dist_xrdpsysconf_DATA)'; test -n "$(xrdpsysconfdir)" || list=; \ if test -n "$$list"; then \ echo " $(MKDIR_P) '$(DESTDIR)$(xrdpsysconfdir)'"; \ $(MKDIR_P) "$(DESTDIR)$(xrdpsysconfdir)" || exit 1; \ fi; \ for p in $$list; do \ if test -f "$$p"; then d=; else d="$(srcdir)/"; fi; \ echo "$$d$$p"; \ done | $(am__base_list) | \ while read files; do \ echo " $(INSTALL_DATA) $$files '$(DESTDIR)$(xrdpsysconfdir)'"; \ $(INSTALL_DATA) $$files "$(DESTDIR)$(xrdpsysconfdir)" || exit $$?; \ done uninstall-dist_xrdpsysconfDATA: @$(NORMAL_UNINSTALL) @list='$(dist_xrdpsysconf_DATA)'; test -n "$(xrdpsysconfdir)" || list=; \ files=`for p in $$list; do echo $$p; done | sed -e 's|^.*/||'`; \ dir='$(DESTDIR)$(xrdpsysconfdir)'; $(am__uninstall_files_from_dir) ID: $(am__tagged_files) $(am__define_uniq_tagged_files); mkid -fID $$unique tags: tags-am TAGS: tags tags-am: $(TAGS_DEPENDENCIES) $(am__tagged_files) set x; \ here=`pwd`; \ $(am__define_uniq_tagged_files); \ shift; \ if test -z "$(ETAGS_ARGS)$$*$$unique"; then :; else \ test -n "$$unique" || unique=$$empty_fix; \ if test $$# -gt 0; then \ $(ETAGS) $(ETAGSFLAGS) $(AM_ETAGSFLAGS) $(ETAGS_ARGS) \ "$$@" $$unique; \ else \ $(ETAGS) $(ETAGSFLAGS) $(AM_ETAGSFLAGS) $(ETAGS_ARGS) \ $$unique; \ fi; \ fi ctags: ctags-am CTAGS: ctags ctags-am: $(TAGS_DEPENDENCIES) $(am__tagged_files) $(am__define_uniq_tagged_files); \ test -z "$(CTAGS_ARGS)$$unique" \ || $(CTAGS) $(CTAGSFLAGS) $(AM_CTAGSFLAGS) $(CTAGS_ARGS) \ $$unique GTAGS: here=`$(am__cd) $(top_builddir) && pwd` \ && $(am__cd) $(top_srcdir) \ && gtags -i $(GTAGS_ARGS) "$$here" cscopelist: cscopelist-am cscopelist-am: $(am__tagged_files) list='$(am__tagged_files)'; \ case "$(srcdir)" in \ [\\/]* | ?:[\\/]*) sdir="$(srcdir)" ;; \ *) sdir=$(subdir)/$(srcdir) ;; \ esac; \ for i in $$list; do \ if test -f "$$i"; then \ echo "$(subdir)/$$i"; \ else \ echo "$$sdir/$$i"; \ fi; \ done >> $(top_builddir)/cscope.files distclean-tags: -rm -f TAGS ID GTAGS GRTAGS GSYMS GPATH tags distdir: $(DISTFILES) @srcdirstrip=`echo "$(srcdir)" | sed 's/[].[^$$\\*]/\\\\&/g'`; \ topsrcdirstrip=`echo "$(top_srcdir)" | sed 's/[].[^$$\\*]/\\\\&/g'`; \ list='$(DISTFILES)'; \ dist_files=`for file in $$list; do echo $$file; done | \ sed -e "s|^$$srcdirstrip/||;t" \ -e "s|^$$topsrcdirstrip/|$(top_builddir)/|;t"`; \ case $$dist_files in \ */*) $(MKDIR_P) `echo "$$dist_files" | \ sed '/\//!d;s|^|$(distdir)/|;s,/[^/]*$$,,' | \ sort -u` ;; \ esac; \ for file in $$dist_files; do \ if test -f $$file || test -d $$file; then d=.; else d=$(srcdir); fi; \ if test -d $$d/$$file; then \ dir=`echo "/$$file" | sed -e 's,/[^/]*$$,,'`; \ if test -d "$(distdir)/$$file"; then \ find "$(distdir)/$$file" -type d ! -perm -700 -exec chmod u+rwx {} \;; \ fi; \ if test -d $(srcdir)/$$file && test $$d != $(srcdir); then \ cp -fpR $(srcdir)/$$file "$(distdir)$$dir" || exit 1; \ find "$(distdir)/$$file" -type d ! -perm -700 -exec chmod u+rwx {} \;; \ fi; \ cp -fpR $$d/$$file "$(distdir)$$dir" || exit 1; \ else \ test -f "$(distdir)/$$file" \ || cp -p $$d/$$file "$(distdir)/$$file" \ || exit 1; \ fi; \ done check-am: all-am check: check-am all-am: Makefile $(PROGRAMS) $(DATA) installdirs: for dir in "$(DESTDIR)$(sbindir)" "$(DESTDIR)$(xrdppkgdatadir)" "$(DESTDIR)$(xrdpsysconfdir)"; do \ test -z "$$dir" || $(MKDIR_P) "$$dir"; \ done install: install-am install-exec: install-exec-am install-data: install-data-am uninstall: uninstall-am install-am: all-am @$(MAKE) $(AM_MAKEFLAGS) install-exec-am install-data-am installcheck: installcheck-am install-strip: if test -z '$(STRIP)'; then \ $(MAKE) $(AM_MAKEFLAGS) INSTALL_PROGRAM="$(INSTALL_STRIP_PROGRAM)" \ install_sh_PROGRAM="$(INSTALL_STRIP_PROGRAM)" INSTALL_STRIP_FLAG=-s \ install; \ else \ $(MAKE) $(AM_MAKEFLAGS) INSTALL_PROGRAM="$(INSTALL_STRIP_PROGRAM)" \ install_sh_PROGRAM="$(INSTALL_STRIP_PROGRAM)" INSTALL_STRIP_FLAG=-s \ "INSTALL_PROGRAM_ENV=STRIPPROG='$(STRIP)'" install; \ fi mostlyclean-generic: clean-generic: distclean-generic: -test -z "$(CONFIG_CLEAN_FILES)" || rm -f $(CONFIG_CLEAN_FILES) -test . = "$(srcdir)" || test -z "$(CONFIG_CLEAN_VPATH_FILES)" || rm -f $(CONFIG_CLEAN_VPATH_FILES) maintainer-clean-generic: @echo "This command is intended for maintainers to use" @echo "it deletes files that may require special tools to rebuild." clean: clean-am clean-am: clean-generic clean-libtool clean-sbinPROGRAMS \ mostlyclean-am distclean: distclean-am -rm -rf ./$(DEPDIR) -rm -f Makefile distclean-am: clean-am distclean-compile distclean-generic \ distclean-tags dvi: dvi-am dvi-am: html: html-am html-am: info: info-am info-am: install-data-am: install-dist_xrdppkgdataDATA \ install-dist_xrdpsysconfDATA install-dvi: install-dvi-am install-dvi-am: install-exec-am: install-sbinPROGRAMS install-html: install-html-am install-html-am: install-info: install-info-am install-info-am: install-man: install-pdf: install-pdf-am install-pdf-am: install-ps: install-ps-am install-ps-am: installcheck-am: maintainer-clean: maintainer-clean-am -rm -rf ./$(DEPDIR) -rm -f Makefile maintainer-clean-am: distclean-am maintainer-clean-generic mostlyclean: mostlyclean-am mostlyclean-am: mostlyclean-compile mostlyclean-generic \ mostlyclean-libtool pdf: pdf-am pdf-am: ps: ps-am ps-am: uninstall-am: uninstall-dist_xrdppkgdataDATA \ uninstall-dist_xrdpsysconfDATA uninstall-sbinPROGRAMS .MAKE: install-am install-strip .PHONY: CTAGS GTAGS TAGS all all-am check check-am clean clean-generic \ clean-libtool clean-sbinPROGRAMS cscopelist-am ctags ctags-am \ distclean distclean-compile distclean-generic \ distclean-libtool distclean-tags distdir dvi dvi-am html \ html-am info info-am install install-am install-data \ install-data-am install-dist_xrdppkgdataDATA \ install-dist_xrdpsysconfDATA install-dvi install-dvi-am \ install-exec install-exec-am install-html install-html-am \ install-info install-info-am install-man install-pdf \ install-pdf-am install-ps install-ps-am install-sbinPROGRAMS \ install-strip installcheck installcheck-am installdirs \ maintainer-clean maintainer-clean-generic mostlyclean \ mostlyclean-compile mostlyclean-generic mostlyclean-libtool \ pdf pdf-am ps ps-am tags tags-am uninstall uninstall-am \ uninstall-dist_xrdppkgdataDATA uninstall-dist_xrdpsysconfDATA \ uninstall-sbinPROGRAMS .PRECIOUS: Makefile # Tell versions [3.59,3.63) of GNU make to not export all variables. # Otherwise a system limit (for SysV at least) may be exceeded. .NOEXPORT: xrdp-0.9.5/xrdp/xrdp_login_wnd.c000644 001751 001751 00000115462 13206666623 016603 0ustar00metameta000000 000000 /** * xrdp: A Remote Desktop Protocol server. * * Copyright (C) Jay Sorg 2004-2014 * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. * * main login window and login help window */ #if defined(HAVE_CONFIG_H) #include #endif #include "base64.h" #include "xrdp.h" #include "log.h" #define ASK "ask" #define ASK_LEN g_strlen(ASK) #define BASE64PREFIX "{base64}" #define BASE64PREFIX_LEN g_strlen(BASE64PREFIX) /*****************************************************************************/ /* all login help screen events go here */ static int xrdp_wm_login_help_notify(struct xrdp_bitmap *wnd, struct xrdp_bitmap *sender, int msg, long param1, long param2) { struct xrdp_painter *p; if (wnd == 0) { return 0; } if (sender == 0) { return 0; } if (wnd->owner == 0) { return 0; } if (msg == 1) /* click */ { if (sender->id == 1) /* ok button */ { if (sender->owner->notify != 0) { wnd->owner->notify(wnd->owner, wnd, 100, 1, 0); /* ok */ } } } else if (msg == WM_PAINT) /* 3 */ { p = (struct xrdp_painter *)param1; if (p != 0) { p->fg_color = wnd->wm->black; xrdp_painter_draw_text(p, wnd, 10, 30, "You must be authenticated \ before using this"); xrdp_painter_draw_text(p, wnd, 10, 46, "session."); xrdp_painter_draw_text(p, wnd, 10, 78, "Enter a valid username in \ the username edit box."); xrdp_painter_draw_text(p, wnd, 10, 94, "Enter the password in \ the password edit box."); xrdp_painter_draw_text(p, wnd, 10, 110, "Both the username and \ password are case"); xrdp_painter_draw_text(p, wnd, 10, 126, "sensitive."); xrdp_painter_draw_text(p, wnd, 10, 158, "Contact your system \ administrator if you are"); xrdp_painter_draw_text(p, wnd, 10, 174, "having problems \ logging on."); } } return 0; } #if 0 /*****************************************************************************/ static int xrdp_wm_popup_notify(struct xrdp_bitmap *wnd, struct xrdp_bitmap *sender, int msg, int param1, int param2) { return 0; } #endif /*****************************************************************************/ int xrdp_wm_delete_all_children(struct xrdp_wm *self) { int index; struct xrdp_bitmap *b; struct xrdp_rect rect; for (index = self->screen->child_list->count - 1; index >= 0; index--) { b = (struct xrdp_bitmap *)list_get_item(self->screen->child_list, index); MAKERECT(rect, b->left, b->top, b->width, b->height); xrdp_bitmap_delete(b); xrdp_bitmap_invalidate(self->screen, &rect); } return 0; } /*****************************************************************************/ static int set_mod_data_item(struct xrdp_mod_data *mod, char *name, char *value) { int index; for (index = 0; index < mod->names->count; index++) { if (g_strncmp(name, (char *)list_get_item(mod->names, index), 255) == 0) { list_remove_item(mod->values, index); list_insert_item(mod->values, index, (long)g_strdup(value)); } } return 0; } /*****************************************************************************/ static int xrdp_wm_help_clicked(struct xrdp_bitmap *wnd) { struct xrdp_bitmap *help; struct xrdp_bitmap *but; /* create help screen */ help = xrdp_bitmap_create(DEFAULT_WND_HELP_W, DEFAULT_WND_HELP_H, wnd->wm->screen->bpp, WND_TYPE_WND, wnd->wm); list_insert_item(wnd->wm->screen->child_list, 0, (long)help); help->parent = wnd->wm->screen; help->owner = wnd; wnd->modal_dialog = help; help->bg_color = wnd->wm->grey; help->left = wnd->wm->screen->width / 2 - help->width / 2; help->top = wnd->wm->screen->height / 2 - help->height / 2; help->notify = xrdp_wm_login_help_notify; set_string(&help->caption1, "Login help"); /* ok button */ but = xrdp_bitmap_create(DEFAULT_BUTTON_W, DEFAULT_BUTTON_H, wnd->wm->screen->bpp, WND_TYPE_BUTTON, wnd->wm); list_insert_item(help->child_list, 0, (long)but); but->parent = help; but->owner = help; but->left = ((DEFAULT_WND_HELP_W / 2) - (DEFAULT_BUTTON_W / 2)); /* center */ but->top = DEFAULT_WND_HELP_H - DEFAULT_BUTTON_H - 15; but->id = 1; but->tab_stop = 1; set_string(&but->caption1, "OK"); /* draw it */ help->focused_control = but; help->default_button = but; help->esc_button = but; xrdp_bitmap_invalidate(help, 0); xrdp_wm_set_focused(wnd->wm, help); return 0; } /*****************************************************************************/ static int xrdp_wm_cancel_clicked(struct xrdp_bitmap *wnd) { if (wnd != 0) { if (wnd->wm != 0) { if (wnd->wm->pro_layer != 0) { g_set_wait_obj(wnd->wm->pro_layer->self_term_event); } } } return 0; } /*****************************************************************************/ static int xrdp_wm_ok_clicked(struct xrdp_bitmap *wnd) { struct xrdp_bitmap *combo; struct xrdp_bitmap *label; struct xrdp_bitmap *edit; struct xrdp_wm *wm; struct xrdp_mod_data *mod_data; int i; wm = wnd->wm; combo = xrdp_bitmap_get_child_by_id(wnd, 6); if (combo != 0) { mod_data = (struct xrdp_mod_data *) list_get_item(combo->data_list, combo->item_index); if (mod_data != 0) { /* get the user typed values */ i = 100; label = xrdp_bitmap_get_child_by_id(wnd, i); edit = xrdp_bitmap_get_child_by_id(wnd, i + 1); while (label != 0 && edit != 0) { set_mod_data_item(mod_data, label->caption1, edit->caption1); i += 2; label = xrdp_bitmap_get_child_by_id(wnd, i); edit = xrdp_bitmap_get_child_by_id(wnd, i + 1); } list_delete(wm->mm->login_names); list_delete(wm->mm->login_values); wm->mm->login_names = list_create(); wm->mm->login_names->auto_free = 1; wm->mm->login_values = list_create(); wm->mm->login_values->auto_free = 1; /* will copy these cause dialog gets freed */ list_append_list_strdup(mod_data->names, wm->mm->login_names, 0); list_append_list_strdup(mod_data->values, wm->mm->login_values, 0); xrdp_wm_set_login_mode(wm, 2); } } else { log_message(LOG_LEVEL_ERROR, "Combo is 0 - potential programming error"); } return 0; } /*****************************************************************************/ /** * This is an internal function in this file used to parse the domain * information sent from the client. If the information starts * with '_' the domain field contains the IP/DNS to connect to. * If the domain field contains an additional '__' the char that * follows this '__' is an index number of a preferred combo choice. * Valid values for this choice is 0-9. But this function will only return * index numbers between 0 and the max number of combo items -1. * Example: _192.168.1.2__1 result in a resultbuffer containing * 192.168.1.2 and the return value will be 1. Meaning that * index 1 is the preferred combo choice. * * Users can create shortcuts where this information is configured. These * shortcuts simplifies login. * @param originalDomainInfo indata to this function * @param comboMax the max number of combo choices * @param decode if true then we perform decoding of combo choice * @param resultBuffer must be pre allocated before calling this function. * Holds the IP. The size of this buffer must be 256 bytes * @return the index number of the combobox that the user prefer. * 0 if the user does not prefer any choice. */ static int xrdp_wm_parse_domain_information(char *originalDomainInfo, int comboMax, int decode, char *resultBuffer) { int ret; int pos; int comboxindex; char index[2]; /* If the first char in the domain name is '_' we use the domain name as IP*/ ret = 0; /* default return value */ /* resultBuffer assumed to be 256 chars */ g_memset(resultBuffer, 0, 256); if (originalDomainInfo[0] == '_') { /* we try to locate a number indicating what combobox index the user * prefer the information is loaded from domain field, from the client * log_message(LOG_LEVEL_DEBUG, "domain contains _"); * We must use valid chars in the domain name. * Underscore is a valid name in the domain. * Invalid chars are ignored in microsoft client therefore we use '_' * again. this sec '__' contains the split for index.*/ pos = g_pos(&originalDomainInfo[1], "__"); if (pos > 0) { /* an index is found we try to use it log_message(LOG_LEVEL_DEBUG, "domain contains index char __");*/ if (decode) { g_memset(index, 0, 2); /* we just accept values 0-9 (one figure) */ g_strncpy(index, &originalDomainInfo[pos + 3], 1); comboxindex = g_htoi(index); log_message(LOG_LEVEL_DEBUG, "index value as string: %s, as int: %d, max: %d", index, comboxindex, comboMax - 1); /* limit to max number of items in combo box */ if ((comboxindex > 0) && (comboxindex < comboMax)) { log_message(LOG_LEVEL_DEBUG, "domain contains a valid " "index number"); ret = comboxindex; /* preferred index for combo box. */ } } /* pos limit the String to only contain the IP */ g_strncpy(resultBuffer, &originalDomainInfo[1], pos); } else { /* log_message(LOG_LEVEL_DEBUG, "domain does not contain _"); */ g_strncpy(resultBuffer, &originalDomainInfo[1], 255); } } return ret; } /******************************************************************************/ static int xrdp_wm_show_edits(struct xrdp_wm *self, struct xrdp_bitmap *combo) { int count; int index; int insert_index; int username_set; char *name; char *value; struct xrdp_mod_data *mod; struct xrdp_bitmap *b; struct xrdp_cfg_globals *globals; char resultIP[256]; char *plain; /* base64 decoded string */ size_t base64_length; /* length of base64 string */ globals = &self->xrdp_config->cfg_globals; username_set = 0; /* free labels and edits, cause we will create them */ /* creation or combo changed */ for (index = 100; index < 200; index++) { b = xrdp_bitmap_get_child_by_id(combo->parent, index); xrdp_bitmap_delete(b); } insert_index = list_index_of(self->login_window->child_list, (long)combo); /* find combo in the list */ insert_index++; mod = (struct xrdp_mod_data *) list_get_item(combo->data_list, combo->item_index); if (mod != 0) { count = 0; for (index = 0; index < mod->names->count; index++) { value = (char *)list_get_item(mod->values, index); /* if the value begins with "{base64}", decode the string following it */ if (g_strncmp(BASE64PREFIX, value, BASE64PREFIX_LEN) == 0) { base64_length = g_strlen(value + BASE64PREFIX_LEN); plain = (char *)g_malloc(base64_length, 0); base64_decode(plain, value + BASE64PREFIX_LEN, base64_length); g_strncpy(value, plain, g_strlen(plain)); g_free(plain); } else if (g_strncmp(ASK, value, ASK_LEN) == 0) { /* label */ b = xrdp_bitmap_create(95, DEFAULT_EDIT_H, self->screen->bpp, WND_TYPE_LABEL, self); list_insert_item(self->login_window->child_list, insert_index, (long)b); insert_index++; b->parent = self->login_window; b->owner = self->login_window; b->left = globals->ls_label_x_pos; b->top = globals->ls_input_y_pos + DEFAULT_COMBO_H + 5 + (DEFAULT_EDIT_H + 5) * count; b->id = 100 + 2 * count; name = (char *)list_get_item(mod->names, index); set_string(&b->caption1, name); /* edit */ b = xrdp_bitmap_create(DEFAULT_EDIT_W, DEFAULT_EDIT_H, self->screen->bpp, WND_TYPE_EDIT, self); list_insert_item(self->login_window->child_list, insert_index, (long)b); insert_index++; b->parent = self->login_window; b->owner = self->login_window; b->left = globals->ls_input_x_pos; b->top = globals->ls_input_y_pos + DEFAULT_COMBO_H + 5 + (DEFAULT_EDIT_H + 5) * count; b->id = 100 + 2 * count + 1; b->pointer = 1; b->tab_stop = 1; b->caption1 = (char *)g_malloc(256, 1); /* ask{base64}... 3 for "ask", 8 for "{base64}" */ if (g_strncmp(BASE64PREFIX, value + ASK_LEN, BASE64PREFIX_LEN) == 0) { base64_length = g_strlen(value + ASK_LEN + BASE64PREFIX_LEN); plain = (char *)g_malloc(base64_length, 0); base64_decode(plain, value + ASK_LEN + BASE64PREFIX_LEN, base64_length); g_strncpy(b->caption1, plain, 255); g_free(plain); } else { g_strncpy(b->caption1, value + ASK_LEN, 255); } b->edit_pos = g_mbstowcs(0, b->caption1, 0); if (self->login_window->focused_control == 0) { self->login_window->focused_control = b; } /* Use the domain name as the destination IP/DNS This is useful in a gateway setup. */ if (g_strncmp(name, "ip", 255) == 0) { /* If the first char in the domain name is '_' we use the domain name as IP */ if (self->session->client_info->domain[0] == '_') { xrdp_wm_parse_domain_information( self->session->client_info->domain, combo->data_list->count, 0, resultIP); g_strncpy(b->caption1, resultIP, 255); b->edit_pos = g_mbstowcs(0, b->caption1, 0); } } if (g_strncmp(name, "username", 255) == 0 && self->session->client_info->username[0]) { g_strncpy(b->caption1, self->session->client_info->username, 255); b->edit_pos = g_mbstowcs(0, b->caption1, 0); if (b->edit_pos > 0) { username_set = 1; } } if ((g_strncmp(name, "password", 255) == 0) || (g_strncmp(name, "pampassword", 255) == 0)) { b->password_char = '*'; if (username_set) { if (b->parent != 0) { b->parent->focused_control = b; } } } count++; } } } return 0; } /*****************************************************************************/ /* all login screen events go here */ static int xrdp_wm_login_notify(struct xrdp_bitmap *wnd, struct xrdp_bitmap *sender, int msg, long param1, long param2) { struct xrdp_bitmap *b; struct xrdp_rect rect; int i; if (wnd->modal_dialog != 0 && msg != 100) { return 0; } if (msg == 1) /* click */ { if (sender->id == 1) /* help button */ { xrdp_wm_help_clicked(wnd); } else if (sender->id == 2) /* cancel button */ { xrdp_wm_cancel_clicked(wnd); } else if (sender->id == 3) /* ok button */ { xrdp_wm_ok_clicked(wnd); } } else if (msg == 2) /* mouse move */ { } else if (msg == 100) /* modal result is done */ { i = list_index_of(wnd->wm->screen->child_list, (long)sender); if (i >= 0) { b = (struct xrdp_bitmap *) list_get_item(wnd->wm->screen->child_list, i); list_remove_item(sender->wm->screen->child_list, i); MAKERECT(rect, b->left, b->top, b->width, b->height); xrdp_bitmap_invalidate(wnd->wm->screen, &rect); xrdp_bitmap_delete(sender); wnd->modal_dialog = 0; xrdp_wm_set_focused(wnd->wm, wnd); } } else if (msg == CB_ITEMCHANGE) /* combo box change */ { xrdp_wm_show_edits(wnd->wm, sender); xrdp_bitmap_invalidate(wnd, 0); /* invalidate the whole dialog for now */ } return 0; } /******************************************************************************/ static int xrdp_wm_login_fill_in_combo(struct xrdp_wm *self, struct xrdp_bitmap *b) { struct list *sections; struct list *section_names; struct list *section_values; int fd; int i; int j; char *p; char *q; char *r; char name[256]; char cfg_file[256]; struct xrdp_mod_data *mod_data; sections = list_create(); sections->auto_free = 1; section_names = list_create(); section_names->auto_free = 1; section_values = list_create(); section_values->auto_free = 1; g_snprintf(cfg_file, 255, "%s/xrdp.ini", XRDP_CFG_PATH); fd = g_file_open(cfg_file); /* xrdp.ini */ if (fd < 0) { log_message(LOG_LEVEL_ERROR, "Could not read xrdp ini file %s", cfg_file); list_delete(sections); list_delete(section_names); list_delete(section_values); return 1; } file_read_sections(fd, sections); for (i = 0; i < sections->count; i++) { p = (char *)list_get_item(sections, i); file_read_section(fd, p, section_names, section_values); if ((g_strncasecmp(p, "globals", 255) == 0) || (g_strncasecmp(p, "channels", 255) == 0) || (g_strncasecmp(p, "Logging", 255) == 0)) { } else { g_strncpy(name, p, 255); mod_data = (struct xrdp_mod_data *) g_malloc(sizeof(struct xrdp_mod_data), 1); mod_data->names = list_create(); mod_data->names->auto_free = 1; mod_data->values = list_create(); mod_data->values->auto_free = 1; for (j = 0; j < section_names->count; j++) { q = (char *)list_get_item(section_names, j); r = (char *)list_get_item(section_values, j); if (g_strncmp("name", q, 255) == 0) { g_strncpy(name, r, 255); } list_add_item(mod_data->names, (long)g_strdup(q)); list_add_item(mod_data->values, (long)g_strdup(r)); } list_add_item(b->string_list, (long)g_strdup(name)); list_add_item(b->data_list, (long)mod_data); } } g_file_close(fd); list_delete(sections); list_delete(section_names); list_delete(section_values); return 0; } /******************************************************************************/ int xrdp_login_wnd_create(struct xrdp_wm *self) { struct xrdp_bitmap *but; struct xrdp_bitmap *combo; struct xrdp_cfg_globals *globals; char buf[256]; char buf1[256]; char resultIP[256]; int log_width; int log_height; int regular; int primary_x_offset; int primary_y_offset; int index; int x; int y; int cx; int cy; globals = &self->xrdp_config->cfg_globals; primary_x_offset = self->screen->width / 2; primary_y_offset = self->screen->height / 2; log_width = globals->ls_width; log_height = globals->ls_height; regular = 1; if (self->screen->width < log_width) { if (self->screen->width < 240) { log_width = self->screen->width - 4; } else { log_width = 240; } regular = 0; } /* multimon scenario, draw login window on primary monitor */ if (self->client_info->monitorCount > 1) { for (index = 0; index < self->client_info->monitorCount; index++) { if (self->client_info->minfo_wm[index].is_primary) { x = self->client_info->minfo_wm[index].left; y = self->client_info->minfo_wm[index].top; cx = self->client_info->minfo_wm[index].right; cy = self->client_info->minfo_wm[index].bottom; primary_x_offset = x + ((cx - x) / 2); primary_y_offset = y + ((cy - y) / 2); break; } } } /* draw login window */ self->login_window = xrdp_bitmap_create(log_width, log_height, self->screen->bpp, WND_TYPE_WND, self); list_add_item(self->screen->child_list, (long)self->login_window); self->login_window->parent = self->screen; self->login_window->owner = self->screen; self->login_window->bg_color = globals->ls_bg_color; self->login_window->left = primary_x_offset - self->login_window->width / 2; self->login_window->top = primary_y_offset - self->login_window->height / 2; self->login_window->notify = xrdp_wm_login_notify; /* if window title not specified, use hostname as default */ if (globals->ls_title[0] == 0) { g_gethostname(buf1, 256); g_sprintf(buf, "Login to %s", buf1); set_string(&self->login_window->caption1, buf); } else { /*self->login_window->caption1 = globals->ls_title[0];*/ g_sprintf(buf, "%s", globals->ls_title); set_string(&self->login_window->caption1, buf); } if (regular) { /* Load the background image. */ /* If no file is specified no default image will be loaded. */ /* We only load the image if bpp > 8 */ if (globals->ls_background_image[0] != 0 && self->screen->bpp > 8) { char fileName[256] ; but = xrdp_bitmap_create(4, 4, self->screen->bpp, WND_TYPE_IMAGE, self); if (globals->ls_background_image[0] == '/') { g_snprintf(fileName, 255, "%s", globals->ls_background_image); } else { g_snprintf(fileName, 255, "%s/%s", XRDP_SHARE_PATH, globals->ls_background_image); } log_message(LOG_LEVEL_DEBUG, "We try to load the following background file: %s", fileName); xrdp_bitmap_load(but, fileName, self->palette); but->parent = self->screen; but->owner = self->screen; but->left = self->screen->width - but->width; but->top = self->screen->height - but->height; list_add_item(self->screen->child_list, (long)but); } /* if logo image not specified, use default */ if (globals->ls_logo_filename[0] == 0) g_snprintf(globals->ls_logo_filename, 255, "%s/xrdp_logo.bmp", XRDP_SHARE_PATH); /* logo image */ but = xrdp_bitmap_create(4, 4, self->screen->bpp, WND_TYPE_IMAGE, self); if (self->screen->bpp <= 8) g_snprintf(globals->ls_logo_filename, 255, "%s/ad256.bmp", XRDP_SHARE_PATH); xrdp_bitmap_load(but, globals->ls_logo_filename, self->palette); but->parent = self->login_window; but->owner = self->login_window; but->left = globals->ls_logo_x_pos; but->top = globals->ls_logo_y_pos; list_add_item(self->login_window->child_list, (long)but); } /* label */ but = xrdp_bitmap_create(globals->ls_label_width, DEFAULT_EDIT_H, self->screen->bpp, WND_TYPE_LABEL, self); list_add_item(self->login_window->child_list, (long)but); but->parent = self->login_window; but->owner = self->login_window; but->left = globals->ls_label_x_pos; but->top = globals->ls_input_y_pos; set_string(&but->caption1, "Session"); /* combo */ combo = xrdp_bitmap_create(globals->ls_input_width, DEFAULT_COMBO_H, self->screen->bpp, WND_TYPE_COMBO, self); list_add_item(self->login_window->child_list, (long)combo); combo->parent = self->login_window; combo->owner = self->login_window; combo->left = globals->ls_input_x_pos; combo->top = globals->ls_input_y_pos; combo->id = 6; combo->tab_stop = 1; xrdp_wm_login_fill_in_combo(self, combo); /* OK button */ but = xrdp_bitmap_create(globals->ls_btn_ok_width, globals->ls_btn_ok_height, self->screen->bpp, WND_TYPE_BUTTON, self); list_add_item(self->login_window->child_list, (long)but); but->parent = self->login_window; but->owner = self->login_window; but->left = globals->ls_btn_ok_x_pos; but->top = globals->ls_btn_ok_y_pos; but->id = 3; set_string(&but->caption1, "OK"); but->tab_stop = 1; self->login_window->default_button = but; /* Cancel button */ but = xrdp_bitmap_create(globals->ls_btn_cancel_width, globals->ls_btn_cancel_height, self->screen->bpp, WND_TYPE_BUTTON, self); list_add_item(self->login_window->child_list, (long)but); but->parent = self->login_window; but->owner = self->login_window; but->left = globals->ls_btn_cancel_x_pos; but->top = globals->ls_btn_cancel_y_pos; but->id = 2; set_string(&but->caption1, "Cancel"); but->tab_stop = 1; self->login_window->esc_button = but; /* labels and edits. * parameter: 1 = decode domain field index information from client. * We only perform this the first time for each connection. */ combo->item_index = xrdp_wm_parse_domain_information( self->session->client_info->domain, combo->data_list->count, 1, resultIP /* just a dummy place holder, we ignore */ ); xrdp_wm_show_edits(self, combo); return 0; } /** * Load configuration from xrdp.ini file * * @return 0 on success, -1 on failure *****************************************************************************/ int load_xrdp_config(struct xrdp_config *config, int bpp) { struct xrdp_cfg_globals *globals; struct list *names; struct list *values; char *n; char *v; char buf[256]; int fd; int i; if (!config) return -1; globals = &config->cfg_globals; /* set default values in case we can't get them from xrdp.ini file */ globals->ini_version = 1; globals->ls_top_window_bg_color = HCOLOR(bpp, xrdp_wm_htoi("009cb5")); globals->ls_bg_color = HCOLOR(bpp, xrdp_wm_htoi("dedede")); globals->ls_width = 350; globals->ls_height = 350; globals->ls_logo_x_pos = 63; globals->ls_logo_y_pos = 50; globals->ls_label_x_pos = 30; globals->ls_label_width = 60; globals->ls_input_x_pos = 110; globals->ls_input_width = 210; globals->ls_input_y_pos = 150; globals->ls_btn_ok_x_pos = 150; globals->ls_btn_ok_y_pos = 300; globals->ls_btn_ok_width = 85; globals->ls_btn_ok_height =30; globals->ls_btn_cancel_x_pos = 245; globals->ls_btn_cancel_y_pos = 300; globals->ls_btn_cancel_width = 85; globals->ls_btn_cancel_height = 30; /* open xrdp.ini file */ g_snprintf(buf, 255, "%s/xrdp.ini", XRDP_CFG_PATH); if ((fd = g_file_open(buf)) < 0) { log_message(LOG_LEVEL_ERROR,"load_config: Could not read " "xrdp.ini file %s", buf); return -1; } names = list_create(); values = list_create(); names->auto_free = 1; values->auto_free = 1; if (file_read_section(fd, "globals", names, values) != 0) { list_delete(names); list_delete(values); g_file_close(fd); log_message(LOG_LEVEL_ERROR,"load_config: Could not read globals " "section from xrdp.ini file %s", buf); return -1; } for (i = 0; i < names->count; i++) { n = (char *) list_get_item(names, i); v = (char *) list_get_item(values, i); /* * parse globals section */ if (g_strncmp(n, "ini_version", 64) == 0) globals->ini_version = g_atoi(v); else if (g_strncmp(n, "bitmap_cache", 64) == 0) globals->use_bitmap_cache = g_text2bool(v); else if (g_strncmp(n, "bitmap_compression", 64) == 0) globals->use_bitmap_compression = g_text2bool(v); else if (g_strncmp(n, "port", 64) == 0) globals->port = g_atoi(v); else if (g_strncmp(n, "crypt_level", 64) == 0) { if (g_strcmp(v, "low") == 0) globals->crypt_level = 1; else if (g_strcmp(v, "medium") == 0) globals->crypt_level = 2; else globals->crypt_level = 3; } else if (g_strncmp(n, "allow_channels", 64) == 0) globals->allow_channels = g_text2bool(v); else if (g_strncmp(n, "max_bpp", 64) == 0) globals->max_bpp = g_atoi(v); else if (g_strncmp(n, "fork", 64) == 0) globals->fork = g_text2bool(v); else if (g_strncmp(n, "tcp_nodelay", 64) == 0) globals->tcp_nodelay = g_text2bool(v); else if (g_strncmp(n, "tcp_keepalive", 64) == 0) globals->tcp_keepalive = g_text2bool(v); else if (g_strncmp(n, "tcp_send_buffer_bytes", 64) == 0) globals->tcp_send_buffer_bytes = g_atoi(v); else if (g_strncmp(n, "tcp_recv_buffer_bytes", 64) == 0) globals->tcp_recv_buffer_bytes = g_atoi(v); /* colors */ else if (g_strncmp(n, "grey", 64) == 0) globals->grey = xrdp_wm_htoi(v); else if (g_strncmp(n, "black", 64) == 0) globals->black = xrdp_wm_htoi(v); else if (g_strncmp(n, "dark_grey", 64) == 0) globals->dark_grey = xrdp_wm_htoi(v); else if (g_strncmp(n, "blue", 64) == 0) globals->blue = xrdp_wm_htoi(v); else if (g_strncmp(n, "dark_blue", 64) == 0) globals->dark_blue = xrdp_wm_htoi(v); else if (g_strncmp(n, "white", 64) == 0) globals->white = xrdp_wm_htoi(v); else if (g_strncmp(n, "red", 64) == 0) globals->red = xrdp_wm_htoi(v); else if (g_strncmp(n, "green", 64) == 0) globals->green = xrdp_wm_htoi(v); else if (g_strncmp(n, "background", 64) == 0) globals->background = xrdp_wm_htoi(v); /* misc stuff */ else if (g_strncmp(n, "autorun", 255) == 0) g_strncpy(globals->autorun, v, 255); else if (g_strncmp(n, "hidelogwindow", 64) == 0) globals->hidelogwindow = g_text2bool(v); else if (g_strncmp(n, "require_credentials", 64) == 0) globals->require_credentials = g_text2bool(v); else if (g_strncmp(n, "bulk_compression", 64) == 0) globals->bulk_compression = g_text2bool(v); else if (g_strncmp(n, "new_cursors", 64) == 0) globals->new_cursors = g_text2bool(v); else if (g_strncmp(n, "nego_sec_layer", 64) == 0) globals->nego_sec_layer = g_atoi(v); else if (g_strncmp(n, "allow_multimon", 64) == 0) globals->allow_multimon = g_text2bool(v); /* login screen values */ else if (g_strncmp(n, "ls_top_window_bg_color", 64) == 0) globals->ls_top_window_bg_color = HCOLOR(bpp, xrdp_wm_htoi(v)); else if (g_strncmp(n, "ls_width", 64) == 0) globals->ls_width = g_atoi(v); else if (g_strncmp(n, "ls_height", 64) == 0) globals->ls_height = g_atoi(v); else if (g_strncmp(n, "ls_bg_color", 64) == 0) globals->ls_bg_color = HCOLOR(bpp, xrdp_wm_htoi(v)); else if (g_strncmp(n, "ls_title", 255) == 0) { g_strncpy(globals->ls_title, v, 255); globals->ls_title[255] = 0; } else if (g_strncmp(n, "ls_logo_filename", 255) == 0) { g_strncpy(globals->ls_logo_filename, v, 255); globals->ls_logo_filename[255] = 0; } else if (g_strncmp(n, "ls_background_image", 255) == 0) { g_strncpy(globals->ls_background_image, v, 255); globals->ls_background_image[255] = 0; } else if (g_strncmp(n, "ls_logo_x_pos", 64) == 0) globals->ls_logo_x_pos = g_atoi(v); else if (g_strncmp(n, "ls_logo_y_pos", 64) == 0) globals->ls_logo_y_pos = g_atoi(v); else if (g_strncmp(n, "ls_label_x_pos", 64) == 0) globals->ls_label_x_pos = g_atoi(v); else if (g_strncmp(n, "ls_label_width", 64) == 0) globals->ls_label_width = g_atoi(v); else if (g_strncmp(n, "ls_input_x_pos", 64) == 0) globals->ls_input_x_pos = g_atoi(v); else if (g_strncmp(n, "ls_input_width", 64) == 0) globals->ls_input_width = g_atoi(v); else if (g_strncmp(n, "ls_input_y_pos", 64) == 0) globals->ls_input_y_pos = g_atoi(v); else if (g_strncmp(n, "ls_btn_ok_x_pos", 64) == 0) globals->ls_btn_ok_x_pos = g_atoi(v); else if (g_strncmp(n, "ls_btn_ok_y_pos", 64) == 0) globals->ls_btn_ok_y_pos = g_atoi(v); else if (g_strncmp(n, "ls_btn_ok_width", 64) == 0) globals->ls_btn_ok_width = g_atoi(v); else if (g_strncmp(n, "ls_btn_ok_height", 64) == 0) globals->ls_btn_ok_height = g_atoi(v); else if (g_strncmp(n, "ls_btn_cancel_x_pos", 64) == 0) globals->ls_btn_cancel_x_pos = g_atoi(v); else if (g_strncmp(n, "ls_btn_cancel_y_pos", 64) == 0) globals->ls_btn_cancel_y_pos = g_atoi(v); else if (g_strncmp(n, "ls_btn_cancel_width", 64) == 0) globals->ls_btn_cancel_width = g_atoi(v); else if (g_strncmp(n, "ls_btn_cancel_height", 64) == 0) globals->ls_btn_cancel_height = g_atoi(v); } #if 0 g_writeln("ini_version: %d", globals->ini_version); g_writeln("use_bitmap_cache: %d", globals->use_bitmap_cache); g_writeln("use_bitmap_compression: %d", globals->use_bitmap_compression); g_writeln("port: %d", globals->port); g_writeln("crypt_level: %d", globals->crypt_level); g_writeln("allow_channels: %d", globals->allow_channels); g_writeln("max_bpp: %d", globals->max_bpp); g_writeln("fork: %d", globals->fork); g_writeln("tcp_nodelay: %d", globals->tcp_nodelay); g_writeln("tcp_keepalive: %d", globals->tcp_keepalive); g_writeln("tcp_send_buffer_bytes: %d", globals->tcp_send_buffer_bytes); g_writeln("tcp_recv_buffer_bytes: %d", globals->tcp_recv_buffer_bytes); g_writeln("new_cursors: %d", globals->new_cursors); g_writeln("allow_multimon: %d", globals->allow_multimon); g_writeln("grey: %d", globals->grey); g_writeln("black: %d", globals->black); g_writeln("dark_grey: %d", globals->dark_grey); g_writeln("blue: %d", globals->blue); g_writeln("dark_blue: %d", globals->dark_blue); g_writeln("white: %d", globals->white); g_writeln("red: %d", globals->red); g_writeln("green: %d", globals->green); g_writeln("background: %d", globals->background); g_writeln("autorun: %s", globals->autorun); g_writeln("hidelogwindow: %d", globals->hidelogwindow); g_writeln("require_credentials: %d", globals->require_credentials); g_writeln("bulk_compression: %d", globals->bulk_compression); g_writeln("new_cursors: %d", globals->new_cursors); g_writeln("nego_sec_layer: %d", globals->nego_sec_layer); g_writeln("allow_multimon: %d", globals->allow_multimon); g_writeln("ls_top_window_bg_color: %x", globals->ls_top_window_bg_color); g_writeln("ls_width: %d", globals->ls_width); g_writeln("ls_height: %d", globals->ls_height); g_writeln("ls_bg_color: %x", globals->ls_bg_color); g_writeln("ls_title: %s", globals->ls_title); g_writeln("ls_logo_filename: %s", globals->ls_logo_filename); g_writeln("ls_logo_x_pos: %d", globals->ls_logo_x_pos); g_writeln("ls_logo_y_pos: %d", globals->ls_logo_y_pos); g_writeln("ls_label_x_pos: %d", globals->ls_label_x_pos); g_writeln("ls_label_width: %d", globals->ls_label_width); g_writeln("ls_input_x_pos: %d", globals->ls_input_x_pos); g_writeln("ls_input_width: %d", globals->ls_input_width); g_writeln("ls_input_y_pos: %d", globals->ls_input_y_pos); g_writeln("ls_btn_ok_x_pos: %d", globals->ls_btn_ok_x_pos); g_writeln("ls_btn_ok_y_pos: %d", globals->ls_btn_ok_y_pos); g_writeln("ls_btn_ok_width: %d", globals->ls_btn_ok_width); g_writeln("ls_btn_ok_height: %d", globals->ls_btn_ok_height); g_writeln("ls_btn_cancel_x_pos: %d", globals->ls_btn_cancel_x_pos); g_writeln("ls_btn_cancel_y_pos: %d", globals->ls_btn_cancel_y_pos); g_writeln("ls_btn_cancel_width: %d", globals->ls_btn_cancel_width); g_writeln("ls_btn_cancel_height: %d", globals->ls_btn_cancel_height); #endif list_delete(names); list_delete(values); g_file_close(fd); return 0; } xrdp-0.9.5/xrdp/xrdp_wm.c000644 001751 001751 00000172130 13220727202 015224 0ustar00metameta000000 000000 /** * xrdp: A Remote Desktop Protocol server. * * Copyright (C) Jay Sorg 2004-2014 * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. * * simple window manager */ #if defined(HAVE_CONFIG_H) #include #endif #include #include #include "xrdp.h" #include "log.h" /*****************************************************************************/ struct xrdp_wm * xrdp_wm_create(struct xrdp_process *owner, struct xrdp_client_info *client_info) { struct xrdp_wm *self = (struct xrdp_wm *)NULL; char event_name[256]; int pid = 0; /* initialize (zero out) local variables: */ g_memset(event_name, 0, sizeof(char) * 256); self = (struct xrdp_wm *)g_malloc(sizeof(struct xrdp_wm), 1); self->client_info = client_info; self->screen = xrdp_bitmap_create(client_info->width, client_info->height, client_info->bpp, WND_TYPE_SCREEN, self); self->screen->wm = self; self->pro_layer = owner; self->session = owner->session; pid = g_getpid(); g_snprintf(event_name, 255, "xrdp_%8.8x_wm_login_mode_event_%8.8x", pid, owner->session_id); log_message(LOG_LEVEL_DEBUG, "%s", event_name); self->login_mode_event = g_create_wait_obj(event_name); self->painter = xrdp_painter_create(self, self->session); self->cache = xrdp_cache_create(self, self->session, self->client_info); self->log = list_create(); self->log->auto_free = 1; self->mm = xrdp_mm_create(self); self->default_font = xrdp_font_create(self); /* this will use built in keymap or load from file */ get_keymaps(self->session->client_info->keylayout, &(self->keymap)); xrdp_wm_set_login_mode(self, 0); self->target_surface = self->screen; self->current_surface_index = 0xffff; /* screen */ /* to store configuration from xrdp.ini */ self->xrdp_config = g_new0(struct xrdp_config, 1); return self; } /*****************************************************************************/ void xrdp_wm_delete(struct xrdp_wm *self) { if (self == 0) { return; } xrdp_mm_delete(self->mm); xrdp_cache_delete(self->cache); xrdp_painter_delete(self->painter); xrdp_bitmap_delete(self->screen); /* free the log */ list_delete(self->log); /* free default font */ xrdp_font_delete(self->default_font); g_delete_wait_obj(self->login_mode_event); if (self->xrdp_config) g_free(self->xrdp_config); /* free self */ g_free(self); } /*****************************************************************************/ int xrdp_wm_send_palette(struct xrdp_wm *self) { return libxrdp_send_palette(self->session, self->palette); } /*****************************************************************************/ int xrdp_wm_send_bell(struct xrdp_wm *self) { return libxrdp_send_bell(self->session); } /*****************************************************************************/ int xrdp_wm_send_bitmap(struct xrdp_wm *self, struct xrdp_bitmap *bitmap, int x, int y, int cx, int cy) { return libxrdp_send_bitmap(self->session, bitmap->width, bitmap->height, bitmap->bpp, bitmap->data, x, y, cx, cy); } /*****************************************************************************/ int xrdp_wm_set_focused(struct xrdp_wm *self, struct xrdp_bitmap *wnd) { struct xrdp_bitmap *focus_out_control; struct xrdp_bitmap *focus_in_control; if (self == 0) { return 0; } if (self->focused_window == wnd) { return 0; } focus_out_control = 0; focus_in_control = 0; if (self->focused_window != 0) { xrdp_bitmap_set_focus(self->focused_window, 0); focus_out_control = self->focused_window->focused_control; } self->focused_window = wnd; if (self->focused_window != 0) { xrdp_bitmap_set_focus(self->focused_window, 1); focus_in_control = self->focused_window->focused_control; } xrdp_bitmap_invalidate(focus_out_control, 0); xrdp_bitmap_invalidate(focus_in_control, 0); return 0; } /******************************************************************************/ static int xrdp_wm_get_pixel(char *data, int x, int y, int width, int bpp) { int start; int shift; if (bpp == 1) { width = (width + 7) / 8; start = (y * width) + x / 8; shift = x % 8; return (data[start] & (0x80 >> shift)) != 0; } else if (bpp == 4) { width = (width + 1) / 2; start = y * width + x / 2; shift = x % 2; if (shift == 0) { return (data[start] & 0xf0) >> 4; } else { return data[start] & 0x0f; } } return 0; } /*****************************************************************************/ int xrdp_wm_pointer(struct xrdp_wm *self, char *data, char *mask, int x, int y, int bpp) { int bytes; struct xrdp_pointer_item pointer_item; if (bpp == 0) { bpp = 24; } bytes = ((bpp + 7) / 8) * 32 * 32; g_memset(&pointer_item, 0, sizeof(struct xrdp_pointer_item)); pointer_item.x = x; pointer_item.y = y; pointer_item.bpp = bpp; g_memcpy(pointer_item.data, data, bytes); g_memcpy(pointer_item.mask, mask, 32 * 32 / 8); self->screen->pointer = xrdp_cache_add_pointer(self->cache, &pointer_item); return 0; } /*****************************************************************************/ /* returns error */ int xrdp_wm_load_pointer(struct xrdp_wm *self, char *file_name, char *data, char *mask, int *x, int *y) { int fd; int bpp; int w; int h; int i; int j; int pixel; int palette[16]; struct stream *fs; if (!g_file_exist(file_name)) { log_message(LOG_LEVEL_ERROR,"xrdp_wm_load_pointer: error pointer file [%s] does not exist", file_name); return 1; } make_stream(fs); init_stream(fs, 8192); fd = g_file_open(file_name); if (fd < 0) { log_message(LOG_LEVEL_ERROR,"xrdp_wm_load_pointer: error loading pointer from file [%s]", file_name); xstream_free(fs); return 1; } g_file_read(fd, fs->data, 8192); g_file_close(fd); in_uint8s(fs, 6); in_uint8(fs, w); in_uint8(fs, h); in_uint8s(fs, 2); in_uint16_le(fs, *x); in_uint16_le(fs, *y); in_uint8s(fs, 22); in_uint8(fs, bpp); in_uint8s(fs, 25); if (w == 32 && h == 32) { if (bpp == 1) { for (i = 0; i < 2; i++) { in_uint32_le(fs, pixel); palette[i] = pixel; } for (i = 0; i < 32; i++) { for (j = 0; j < 32; j++) { pixel = palette[xrdp_wm_get_pixel(fs->p, j, i, 32, 1)]; *data = pixel; data++; *data = pixel >> 8; data++; *data = pixel >> 16; data++; } } in_uint8s(fs, 128); } else if (bpp == 4) { for (i = 0; i < 16; i++) { in_uint32_le(fs, pixel); palette[i] = pixel; } for (i = 0; i < 32; i++) { for (j = 0; j < 32; j++) { pixel = palette[xrdp_wm_get_pixel(fs->p, j, i, 32, 1)]; *data = pixel; data++; *data = pixel >> 8; data++; *data = pixel >> 16; data++; } } in_uint8s(fs, 512); } g_memcpy(mask, fs->p, 128); /* mask */ } free_stream(fs); return 0; } /*****************************************************************************/ int xrdp_wm_send_pointer(struct xrdp_wm *self, int cache_idx, char *data, char *mask, int x, int y, int bpp) { return libxrdp_send_pointer(self->session, cache_idx, data, mask, x, y, bpp); } /*****************************************************************************/ int xrdp_wm_set_pointer(struct xrdp_wm *self, int cache_idx) { return libxrdp_set_pointer(self->session, cache_idx); } /*****************************************************************************/ /* convert hex string to int */ unsigned int xrdp_wm_htoi (const char *ptr) { unsigned int value = 0; char ch = *ptr; while (ch == ' ' || ch == '\t') { ch = *(++ptr); } for (;;) { if (ch >= '0' && ch <= '9') { value = (value << 4) + (ch - '0'); } else if (ch >= 'A' && ch <= 'F') { value = (value << 4) + (ch - 'A' + 10); } else if (ch >= 'a' && ch <= 'f') { value = (value << 4) + (ch - 'a' + 10); } else { return value; } ch = *(++ptr); } } /*****************************************************************************/ int xrdp_wm_load_static_colors_plus(struct xrdp_wm *self, char *autorun_name) { int bindex; int gindex; int rindex; int fd; int index; char *val; struct list *names; struct list *values; char cfg_file[256]; if (autorun_name != 0) { autorun_name[0] = 0; } /* initialize with defaults */ self->black = HCOLOR(self->screen->bpp, 0x000000); self->grey = HCOLOR(self->screen->bpp, 0xc0c0c0); self->dark_grey = HCOLOR(self->screen->bpp, 0x808080); self->blue = HCOLOR(self->screen->bpp, 0x0000ff); self->dark_blue = HCOLOR(self->screen->bpp, 0x00007f); self->white = HCOLOR(self->screen->bpp, 0xffffff); self->red = HCOLOR(self->screen->bpp, 0xff0000); self->green = HCOLOR(self->screen->bpp, 0x00ff00); self->background = HCOLOR(self->screen->bpp, 0x000000); /* now load them from the globals in xrdp.ini if defined */ g_snprintf(cfg_file, 255, "%s/xrdp.ini", XRDP_CFG_PATH); fd = g_file_open(cfg_file); if (fd > 0) { names = list_create(); names->auto_free = 1; values = list_create(); values->auto_free = 1; if (file_read_section(fd, "globals", names, values) == 0) { for (index = 0; index < names->count; index++) { val = (char *)list_get_item(names, index); if (val != 0) { if (g_strcasecmp(val, "black") == 0) { val = (char *)list_get_item(values, index); self->black = HCOLOR(self->screen->bpp,xrdp_wm_htoi(val)); } else if (g_strcasecmp(val, "grey") == 0) { val = (char *)list_get_item(values, index); self->grey = HCOLOR(self->screen->bpp, xrdp_wm_htoi(val)); } else if (g_strcasecmp(val, "dark_grey") == 0) { val = (char *)list_get_item(values, index); self->dark_grey = HCOLOR(self->screen->bpp, xrdp_wm_htoi(val)); } else if (g_strcasecmp(val, "blue") == 0) { val = (char *)list_get_item(values, index); self->blue = HCOLOR(self->screen->bpp, xrdp_wm_htoi(val)); } else if (g_strcasecmp(val, "dark_blue") == 0) { val = (char *)list_get_item(values, index); self->dark_blue = HCOLOR(self->screen->bpp, xrdp_wm_htoi(val)); } else if (g_strcasecmp(val, "white") == 0) { val = (char *)list_get_item(values, index); self->white = HCOLOR(self->screen->bpp, xrdp_wm_htoi(val)); } else if (g_strcasecmp(val, "red") == 0) { val = (char *)list_get_item(values, index); self->red = HCOLOR(self->screen->bpp, xrdp_wm_htoi(val)); } else if (g_strcasecmp(val, "green") == 0) { val = (char *)list_get_item(values, index); self->green = HCOLOR(self->screen->bpp, xrdp_wm_htoi(val)); } else if (g_strcasecmp(val, "background") == 0) { val = (char *)list_get_item(values, index); self->background = HCOLOR(self->screen->bpp, xrdp_wm_htoi(val)); } else if (g_strcasecmp(val, "autorun") == 0) { val = (char *)list_get_item(values, index); if (autorun_name != 0) { g_strncpy(autorun_name, val, 255); } } else if (g_strcasecmp(val, "hidelogwindow") == 0) { val = (char *)list_get_item(values, index); self->hide_log_window = g_text2bool(val); } else if (g_strcasecmp(val, "pamerrortxt") == 0) { val = (char *)list_get_item(values, index); g_strncpy(self->pamerrortxt, val, 255); } } } } list_delete(names); list_delete(values); g_file_close(fd); } else { log_message(LOG_LEVEL_ERROR,"xrdp_wm_load_static_colors: Could not read xrdp.ini file %s", cfg_file); } if (self->screen->bpp == 8) { /* rgb332 */ for (bindex = 0; bindex < 4; bindex++) { for (gindex = 0; gindex < 8; gindex++) { for (rindex = 0; rindex < 8; rindex++) { self->palette[(bindex << 6) | (gindex << 3) | rindex] = (((rindex << 5) | (rindex << 2) | (rindex >> 1)) << 16) | (((gindex << 5) | (gindex << 2) | (gindex >> 1)) << 8) | ((bindex << 6) | (bindex << 4) | (bindex << 2) | (bindex)); } } } xrdp_wm_send_palette(self); } return 0; } /*****************************************************************************/ /* returns error */ int xrdp_wm_load_static_pointers(struct xrdp_wm *self) { struct xrdp_pointer_item pointer_item; char file_path[256]; DEBUG(("sending cursor")); g_snprintf(file_path, 255, "%s/cursor1.cur", XRDP_SHARE_PATH); g_memset(&pointer_item, 0, sizeof(pointer_item)); xrdp_wm_load_pointer(self, file_path, pointer_item.data, pointer_item.mask, &pointer_item.x, &pointer_item.y); xrdp_cache_add_pointer_static(self->cache, &pointer_item, 1); DEBUG(("sending cursor")); g_snprintf(file_path, 255, "%s/cursor0.cur", XRDP_SHARE_PATH); g_memset(&pointer_item, 0, sizeof(pointer_item)); xrdp_wm_load_pointer(self, file_path, pointer_item.data, pointer_item.mask, &pointer_item.x, &pointer_item.y); xrdp_cache_add_pointer_static(self->cache, &pointer_item, 0); return 0; } /*****************************************************************************/ int xrdp_wm_init(struct xrdp_wm *self) { int fd; int index; struct list *names; struct list *values; char *q; const char *r; char param[256]; char default_section_name[256]; char section_name[256]; char cfg_file[256]; char autorun_name[256]; g_writeln("in xrdp_wm_init: "); load_xrdp_config(self->xrdp_config, self->screen->bpp); xrdp_wm_load_static_colors_plus(self, autorun_name); xrdp_wm_load_static_pointers(self); self->screen->bg_color = self->xrdp_config->cfg_globals.ls_top_window_bg_color; if (self->session->client_info->rdp_autologin) { /* * NOTE: this should eventually be accessed from self->xrdp_config */ g_snprintf(cfg_file, 255, "%s/xrdp.ini", XRDP_CFG_PATH); fd = g_file_open(cfg_file); /* xrdp.ini */ if (fd != -1) { names = list_create(); names->auto_free = 1; values = list_create(); values->auto_free = 1; /* pick up the first section name except for 'globals', 'Logging', 'channels' * in xrdp.ini and use it as default section name */ file_read_sections(fd, names); default_section_name[0] = '\0'; for (index = 0; index < names->count; index++) { q = (char *)list_get_item(names, index); if ((g_strncasecmp("globals", q, 8) != 0) && (g_strncasecmp("Logging", q, 8) != 0) && (g_strncasecmp("channels", q, 9) != 0)) { g_strncpy(default_section_name, q, 255); break; } } /* look for module name to be loaded */ if (autorun_name[0] != 0) { /* if autorun is configured in xrdp.ini, we enforce that module to be loaded */ g_strncpy(section_name, autorun_name, 255); } else if (self->session->client_info->domain[0] != '\0' && self->session->client_info->domain[0] != '_') { /* domain names that starts with '_' are reserved for IP/DNS to * simplify for the user in a proxy setup */ /* we use the domain name as the module name to be loaded */ g_strncpy(section_name, self->session->client_info->domain, 255); } else { /* if no domain is given, and autorun is not specified in xrdp.ini * use default_section_name as section_name */ g_strncpy(section_name, default_section_name, 255); } list_clear(names); /* if given section name doesn't match any sections configured * in xrdp.ini, fallback to default_section_name */ if (file_read_section(fd, section_name, names, values) != 0) { log_message(LOG_LEVEL_INFO, "Module \"%s\" specified by %s from %s port %s " "is not configured. Using \"%s\" instead.", section_name, self->session->client_info->username, self->session->client_info->client_addr, self->session->client_info->client_port, default_section_name); list_clear(names); list_clear(values); g_strncpy(section_name, default_section_name, 255); } /* look for the required module in xrdp.ini, fetch its parameters */ if (file_read_section(fd, section_name, names, values) == 0) { for (index = 0; index < names->count; index++) { q = (char *)list_get_item(names, index); r = (char *)list_get_item(values, index); if (g_strncmp("password", q, 255) == 0) { /* if the password has been asked for by the module, use what the client says. if the password has been manually set in the config, use that instead of what the client says. */ if (g_strncmp("ask", r, 3) == 0) { r = self->session->client_info->password; } } else if (g_strncmp("username", q, 255) == 0) { /* if the username has been asked for by the module, use what the client says. if the username has been manually set in the config, use that instead of what the client says. */ if (g_strncmp("ask", r, 3) == 0) { r = self->session->client_info->username; } } else if (g_strncmp("ip", q, 255) == 0) { /* if the ip has been asked for by the module, use what the client says (target ip should be in 'domain' field, when starting with "_") if the ip has been manually set in the config, use that instead of what the client says. */ if (g_strncmp("ask", r, 3) == 0) { if (self->session->client_info->domain[0] == '_') { g_strncpy(param, &self->session->client_info->domain[1], 255); r = param; } } } else if (g_strncmp("port", q, 255) == 0) { if (g_strncmp("ask3389", r, 7) == 0) { r = "3389"; /* use default */ } } list_add_item(self->mm->login_names, (long)g_strdup(q)); list_add_item(self->mm->login_values, (long)g_strdup(r)); } xrdp_wm_set_login_mode(self, 2); } else { /* Hopefully, we never reach here. */ log_message(LOG_LEVEL_DEBUG, "Control should never reach %s:%d", __FILE__, __LINE__); } list_delete(names); list_delete(values); g_file_close(fd); } else { log_message(LOG_LEVEL_ERROR,"xrdp_wm_init: Could not read xrdp.ini file %s", cfg_file); } } else { g_writeln(" xrdp_wm_init: no autologin / auto run detected, draw login window"); xrdp_login_wnd_create(self); /* clear screen */ xrdp_bitmap_invalidate(self->screen, 0); xrdp_wm_set_focused(self, self->login_window); xrdp_wm_set_login_mode(self, 1); } g_writeln("out xrdp_wm_init: "); return 0; } /*****************************************************************************/ /* returns the number for rects visible for an area relative to a drawable */ /* putting the rects in region */ int xrdp_wm_get_vis_region(struct xrdp_wm *self, struct xrdp_bitmap *bitmap, int x, int y, int cx, int cy, struct xrdp_region *region, int clip_children) { int i; struct xrdp_bitmap *p; struct xrdp_rect a; struct xrdp_rect b; /* area we are drawing */ MAKERECT(a, bitmap->left + x, bitmap->top + y, cx, cy); p = bitmap->parent; while (p != 0) { RECTOFFSET(a, p->left, p->top); p = p->parent; } a.left = MAX(self->screen->left, a.left); a.top = MAX(self->screen->top, a.top); a.right = MIN(self->screen->left + self->screen->width, a.right); a.bottom = MIN(self->screen->top + self->screen->height, a.bottom); xrdp_region_add_rect(region, &a); if (clip_children) { /* loop through all windows in z order */ for (i = 0; i < self->screen->child_list->count; i++) { p = (struct xrdp_bitmap *)list_get_item(self->screen->child_list, i); if (p == bitmap || p == bitmap->parent) { return 0; } MAKERECT(b, p->left, p->top, p->width, p->height); xrdp_region_subtract_rect(region, &b); } } return 0; } /*****************************************************************************/ /* return the window at x, y on the screen */ static struct xrdp_bitmap * xrdp_wm_at_pos(struct xrdp_bitmap *wnd, int x, int y, struct xrdp_bitmap **wnd1) { int i; struct xrdp_bitmap *p; struct xrdp_bitmap *q; /* loop through all windows in z order */ for (i = 0; i < wnd->child_list->count; i++) { p = (struct xrdp_bitmap *)list_get_item(wnd->child_list, i); if (x >= p->left && y >= p->top && x < p->left + p->width && y < p->top + p->height) { if (wnd1 != 0) { *wnd1 = p; } q = xrdp_wm_at_pos(p, x - p->left, y - p->top, 0); if (q == 0) { return p; } else { return q; } } } return 0; } /*****************************************************************************/ static int xrdp_wm_xor_pat(struct xrdp_wm *self, int x, int y, int cx, int cy) { self->painter->clip_children = 0; self->painter->rop = 0x5a; xrdp_painter_begin_update(self->painter); self->painter->use_clip = 0; self->painter->mix_mode = 1; self->painter->brush.pattern[0] = 0xaa; self->painter->brush.pattern[1] = 0x55; self->painter->brush.pattern[2] = 0xaa; self->painter->brush.pattern[3] = 0x55; self->painter->brush.pattern[4] = 0xaa; self->painter->brush.pattern[5] = 0x55; self->painter->brush.pattern[6] = 0xaa; self->painter->brush.pattern[7] = 0x55; self->painter->brush.x_origin = 0; self->painter->brush.x_origin = 0; self->painter->brush.style = 3; self->painter->bg_color = self->black; self->painter->fg_color = self->white; /* top */ xrdp_painter_fill_rect(self->painter, self->screen, x, y, cx, 5); /* bottom */ xrdp_painter_fill_rect(self->painter, self->screen, x, y + (cy - 5), cx, 5); /* left */ xrdp_painter_fill_rect(self->painter, self->screen, x, y + 5, 5, cy - 10); /* right */ xrdp_painter_fill_rect(self->painter, self->screen, x + (cx - 5), y + 5, 5, cy - 10); xrdp_painter_end_update(self->painter); self->painter->rop = 0xcc; self->painter->clip_children = 1; self->painter->mix_mode = 0; return 0; } /*****************************************************************************/ /* return true if rect is totally exposed going in reverse z order */ /* from wnd up */ static int xrdp_wm_is_rect_vis(struct xrdp_wm *self, struct xrdp_bitmap *wnd, struct xrdp_rect *rect) { struct xrdp_rect wnd_rect; struct xrdp_bitmap *b; int i;; /* if rect is part off screen */ if (rect->left < 0) { return 0; } if (rect->top < 0) { return 0; } if (rect->right >= self->screen->width) { return 0; } if (rect->bottom >= self->screen->height) { return 0; } i = list_index_of(self->screen->child_list, (long)wnd); i--; while (i >= 0) { b = (struct xrdp_bitmap *)list_get_item(self->screen->child_list, i); MAKERECT(wnd_rect, b->left, b->top, b->width, b->height); if (rect_intersect(rect, &wnd_rect, 0)) { return 0; } i--; } return 1; } /*****************************************************************************/ static int xrdp_wm_move_window(struct xrdp_wm *self, struct xrdp_bitmap *wnd, int dx, int dy) { struct xrdp_rect rect1; struct xrdp_rect rect2; struct xrdp_region *r; int i; MAKERECT(rect1, wnd->left, wnd->top, wnd->width, wnd->height); self->painter->clip_children = 0; if (xrdp_wm_is_rect_vis(self, wnd, &rect1)) { rect2 = rect1; RECTOFFSET(rect2, dx, dy); if (xrdp_wm_is_rect_vis(self, wnd, &rect2)) { xrdp_painter_begin_update(self->painter); xrdp_painter_copy(self->painter, self->screen, self->screen, wnd->left + dx, wnd->top + dy, wnd->width, wnd->height, wnd->left, wnd->top); xrdp_painter_end_update(self->painter); wnd->left += dx; wnd->top += dy; r = xrdp_region_create(self); xrdp_region_add_rect(r, &rect1); xrdp_region_subtract_rect(r, &rect2); i = 0; while (xrdp_region_get_rect(r, i, &rect1) == 0) { xrdp_bitmap_invalidate(self->screen, &rect1); i++; } xrdp_region_delete(r); self->painter->clip_children = 1; return 0; } } self->painter->clip_children = 1; wnd->left += dx; wnd->top += dy; xrdp_bitmap_invalidate(self->screen, &rect1); xrdp_bitmap_invalidate(wnd, 0); return 0; } /*****************************************************************************/ static int xrdp_wm_undraw_dragging_box(struct xrdp_wm *self, int do_begin_end) { int boxx; int boxy; if (self == 0) { return 0; } if (self->dragging) { if (self->draggingxorstate) { if (do_begin_end) { xrdp_painter_begin_update(self->painter); } boxx = self->draggingx - self->draggingdx; boxy = self->draggingy - self->draggingdy; xrdp_wm_xor_pat(self, boxx, boxy, self->draggingcx, self->draggingcy); self->draggingxorstate = 0; if (do_begin_end) { xrdp_painter_end_update(self->painter); } } } return 0; } /*****************************************************************************/ static int xrdp_wm_draw_dragging_box(struct xrdp_wm *self, int do_begin_end) { int boxx; int boxy; if (self == 0) { return 0; } if (self->dragging) { if (!self->draggingxorstate) { if (do_begin_end) { xrdp_painter_begin_update(self->painter); } boxx = self->draggingx - self->draggingdx; boxy = self->draggingy - self->draggingdy; xrdp_wm_xor_pat(self, boxx, boxy, self->draggingcx, self->draggingcy); self->draggingxorstate = 1; if (do_begin_end) { xrdp_painter_end_update(self->painter); } } } return 0; } /*****************************************************************************/ int xrdp_wm_mouse_move(struct xrdp_wm *self, int x, int y) { struct xrdp_bitmap *b; if (self == 0) { return 0; } if (x < 0) { x = 0; } if (y < 0) { y = 0; } if (x >= self->screen->width) { x = self->screen->width; } if (y >= self->screen->height) { y = self->screen->height; } self->mouse_x = x; self->mouse_y = y; if (self->dragging) { xrdp_painter_begin_update(self->painter); xrdp_wm_undraw_dragging_box(self, 0); self->draggingx = x; self->draggingy = y; xrdp_wm_draw_dragging_box(self, 0); xrdp_painter_end_update(self->painter); return 0; } b = xrdp_wm_at_pos(self->screen, x, y, 0); if (b == 0) /* if b is null, the movement must be over the screen */ { if (self->screen->pointer != self->current_pointer) { xrdp_wm_set_pointer(self, self->screen->pointer); self->current_pointer = self->screen->pointer; } if (self->mm->mod != 0) /* if screen is mod controlled */ { if (self->mm->mod->mod_event != 0) { self->mm->mod->mod_event(self->mm->mod, WM_MOUSEMOVE, x, y, 0, 0); } } } if (self->button_down != 0) { if (b == self->button_down && self->button_down->state == 0) { self->button_down->state = 1; xrdp_bitmap_invalidate(self->button_down, 0); } else if (b != self->button_down) { self->button_down->state = 0; xrdp_bitmap_invalidate(self->button_down, 0); } } if (b != 0) { if (!self->dragging) { if (b->pointer != self->current_pointer) { xrdp_wm_set_pointer(self, b->pointer); self->current_pointer = b->pointer; } xrdp_bitmap_def_proc(b, WM_MOUSEMOVE, xrdp_bitmap_from_screenx(b, x), xrdp_bitmap_from_screeny(b, y)); if (self->button_down == 0) { if (b->notify != 0) { b->notify(b->owner, b, 2, x, y); } } } } return 0; } /*****************************************************************************/ static int xrdp_wm_clear_popup(struct xrdp_wm *self) { int i; struct xrdp_rect rect; //struct xrdp_bitmap* b; //b = 0; if (self->popup_wnd != 0) { //b = self->popup_wnd->popped_from; i = list_index_of(self->screen->child_list, (long)self->popup_wnd); list_remove_item(self->screen->child_list, i); MAKERECT(rect, self->popup_wnd->left, self->popup_wnd->top, self->popup_wnd->width, self->popup_wnd->height); xrdp_bitmap_invalidate(self->screen, &rect); xrdp_bitmap_delete(self->popup_wnd); } //xrdp_wm_set_focused(self, b->parent); return 0; } /*****************************************************************************/ int xrdp_wm_mouse_click(struct xrdp_wm *self, int x, int y, int but, int down) { struct xrdp_bitmap *control; struct xrdp_bitmap *focus_out_control; struct xrdp_bitmap *wnd; int newx; int newy; int oldx; int oldy; if (self == 0) { return 0; } if (x < 0) { x = 0; } if (y < 0) { y = 0; } if (x >= self->screen->width) { x = self->screen->width; } if (y >= self->screen->height) { y = self->screen->height; } if (self->dragging && but == 1 && !down && self->dragging_window != 0) { /* if done dragging */ self->draggingx = x; self->draggingy = y; newx = self->draggingx - self->draggingdx; newy = self->draggingy - self->draggingdy; oldx = self->dragging_window->left; oldy = self->dragging_window->top; /* draw xor box one more time */ if (self->draggingxorstate) { xrdp_wm_xor_pat(self, newx, newy, self->draggingcx, self->draggingcy); } self->draggingxorstate = 0; /* move screen to new location */ xrdp_wm_move_window(self, self->dragging_window, newx - oldx, newy - oldy); self->dragging_window = 0; self->dragging = 0; } wnd = 0; control = xrdp_wm_at_pos(self->screen, x, y, &wnd); if (control == 0) { if (self->mm->mod != 0) /* if screen is mod controlled */ { if (self->mm->mod->mod_event != 0) { if (down) { self->mm->mod->mod_event(self->mm->mod, WM_MOUSEMOVE, x, y, 0, 0); } if (but == 1 && down) { self->mm->mod->mod_event(self->mm->mod, WM_LBUTTONDOWN, x, y, 0, 0); } else if (but == 1 && !down) { self->mm->mod->mod_event(self->mm->mod, WM_LBUTTONUP, x, y, 0, 0); } if (but == 2 && down) { self->mm->mod->mod_event(self->mm->mod, WM_RBUTTONDOWN, x, y, 0, 0); } else if (but == 2 && !down) { self->mm->mod->mod_event(self->mm->mod, WM_RBUTTONUP, x, y, 0, 0); } if (but == 3 && down) { self->mm->mod->mod_event(self->mm->mod, WM_BUTTON3DOWN, x, y, 0, 0); } else if (but == 3 && !down) { self->mm->mod->mod_event(self->mm->mod, WM_BUTTON3UP, x, y, 0, 0); } /* vertical scroll */ if (but == 4) { self->mm->mod->mod_event(self->mm->mod, WM_BUTTON4DOWN, self->mouse_x, self->mouse_y, 0, 0); self->mm->mod->mod_event(self->mm->mod, WM_BUTTON4UP, self->mouse_x, self->mouse_y, 0, 0); } if (but == 5) { self->mm->mod->mod_event(self->mm->mod, WM_BUTTON5DOWN, self->mouse_x, self->mouse_y, 0, 0); self->mm->mod->mod_event(self->mm->mod, WM_BUTTON5UP, self->mouse_x, self->mouse_y, 0, 0); } /* horizontal scroll */ if (but == 6) { self->mm->mod->mod_event(self->mm->mod, WM_BUTTON6DOWN, self->mouse_x, self->mouse_y, 0, 0); self->mm->mod->mod_event(self->mm->mod, WM_BUTTON6UP, self->mouse_x, self->mouse_y, 0, 0); } if (but == 7) { self->mm->mod->mod_event(self->mm->mod, WM_BUTTON7DOWN, self->mouse_x, self->mouse_y, 0, 0); self->mm->mod->mod_event(self->mm->mod, WM_BUTTON7UP, self->mouse_x, self->mouse_y, 0, 0); } } } } if (self->popup_wnd != 0) { if (self->popup_wnd == control && !down) { xrdp_bitmap_def_proc(self->popup_wnd, WM_LBUTTONUP, x, y); xrdp_wm_clear_popup(self); self->button_down = 0; return 0; } else if (self->popup_wnd != control && down) { xrdp_wm_clear_popup(self); self->button_down = 0; return 0; } } if (control != 0) { if (wnd != 0) { if (wnd->modal_dialog != 0) /* if window has a modal dialog */ { return 0; } if (control == wnd) { } else if (control->tab_stop) { focus_out_control = wnd->focused_control; wnd->focused_control = control; xrdp_bitmap_invalidate(focus_out_control, 0); xrdp_bitmap_invalidate(control, 0); } } if ((control->type == WND_TYPE_BUTTON || control->type == WND_TYPE_COMBO) && but == 1 && !down && self->button_down == control) { /* if clicking up on a button that was clicked down */ self->button_down = 0; control->state = 0; xrdp_bitmap_invalidate(control, 0); if (control->parent != 0) { if (control->parent->notify != 0) { /* control can be invalid after this */ control->parent->notify(control->owner, control, 1, x, y); } } } else if ((control->type == WND_TYPE_BUTTON || control->type == WND_TYPE_COMBO) && but == 1 && down) { /* if clicking down on a button or combo */ self->button_down = control; control->state = 1; xrdp_bitmap_invalidate(control, 0); if (control->type == WND_TYPE_COMBO) { xrdp_wm_pu(self, control); } } else if (but == 1 && down) { if (self->popup_wnd == 0) { xrdp_wm_set_focused(self, wnd); if (control->type == WND_TYPE_WND && y < (control->top + 21)) { /* if dragging */ if (self->dragging) /* rarely happens */ { newx = self->draggingx - self->draggingdx; newy = self->draggingy - self->draggingdy; if (self->draggingxorstate) { xrdp_wm_xor_pat(self, newx, newy, self->draggingcx, self->draggingcy); } self->draggingxorstate = 0; } self->dragging = 1; self->dragging_window = control; self->draggingorgx = control->left; self->draggingorgy = control->top; self->draggingx = x; self->draggingy = y; self->draggingdx = x - control->left; self->draggingdy = y - control->top; self->draggingcx = control->width; self->draggingcy = control->height; } } } } else { xrdp_wm_set_focused(self, 0); } /* no matter what, mouse is up, reset button_down */ if (but == 1 && !down && self->button_down != 0) { self->button_down = 0; } return 0; } /*****************************************************************************/ int xrdp_wm_key(struct xrdp_wm *self, int device_flags, int scan_code) { int msg; struct xrdp_key_info *ki; /*g_printf("count %d\n", self->key_down_list->count);*/ scan_code = scan_code % 128; if (self->popup_wnd != 0) { xrdp_wm_clear_popup(self); return 0; } if (device_flags & KBD_FLAG_UP) /* 0x8000 */ { self->keys[scan_code] = 0; msg = WM_KEYUP; } else /* key down */ { self->keys[scan_code] = 1 | device_flags; msg = WM_KEYDOWN; switch (scan_code) { case 58: self->caps_lock = !self->caps_lock; break; /* caps lock */ case 69: self->num_lock = !self->num_lock; break; /* num lock */ case 70: self->scroll_lock = !self->scroll_lock; break; /* scroll lock */ } } if (self->mm->mod != 0) { if (self->mm->mod->mod_event != 0) { ki = get_key_info_from_scan_code (device_flags, scan_code, self->keys, self->caps_lock, self->num_lock, self->scroll_lock, &(self->keymap)); if (ki != 0) { self->mm->mod->mod_event(self->mm->mod, msg, ki->chr, ki->sym, scan_code, device_flags); } } } else if (self->focused_window != 0) { xrdp_bitmap_def_proc(self->focused_window, msg, scan_code, device_flags); } return 0; } /*****************************************************************************/ /* happens when client gets focus and sends key modifier info */ int xrdp_wm_key_sync(struct xrdp_wm *self, int device_flags, int key_flags) { self->num_lock = 0; self->scroll_lock = 0; self->caps_lock = 0; if (key_flags & 1) { self->scroll_lock = 1; } if (key_flags & 2) { self->num_lock = 1; } if (key_flags & 4) { self->caps_lock = 1; } if (self->mm->mod != 0) { if (self->mm->mod->mod_event != 0) { self->mm->mod->mod_event(self->mm->mod, 17, key_flags, device_flags, key_flags, device_flags); } } return 0; } /*****************************************************************************/ int xrdp_wm_key_unicode(struct xrdp_wm *self, int device_flags, int unicode) { int index; for (index = XR_MIN_KEY_CODE; index < XR_MAX_KEY_CODE; index++) { if (unicode == self->keymap.keys_noshift[index].chr) { xrdp_wm_key(self, device_flags, index - XR_MIN_KEY_CODE); return 0; } } for (index = XR_MIN_KEY_CODE; index < XR_MAX_KEY_CODE; index++) { if (unicode == self->keymap.keys_shift[index].chr) { if (device_flags & KBD_FLAG_UP) { xrdp_wm_key(self, device_flags, index - XR_MIN_KEY_CODE); xrdp_wm_key(self, KBD_FLAG_UP, XR_RDP_SCAN_LSHIFT); } else { xrdp_wm_key(self, KBD_FLAG_DOWN, XR_RDP_SCAN_LSHIFT); xrdp_wm_key(self, device_flags, index - XR_MIN_KEY_CODE); } return 0; } } for (index = XR_MIN_KEY_CODE; index < XR_MAX_KEY_CODE; index++) { if (unicode == self->keymap.keys_altgr[index].chr) { if (device_flags & KBD_FLAG_UP) { xrdp_wm_key(self, device_flags, index - XR_MIN_KEY_CODE); xrdp_wm_key(self, KBD_FLAG_UP | KBD_FLAG_EXT, XR_RDP_SCAN_ALT); } else { xrdp_wm_key(self, KBD_FLAG_DOWN | KBD_FLAG_EXT, XR_RDP_SCAN_ALT); xrdp_wm_key(self, device_flags, index - XR_MIN_KEY_CODE); } return 0; } } for (index = XR_MIN_KEY_CODE; index < XR_MAX_KEY_CODE; index++) { if (unicode == self->keymap.keys_shiftaltgr[index].chr) { if (device_flags & KBD_FLAG_UP) { xrdp_wm_key(self, device_flags, index - XR_MIN_KEY_CODE); xrdp_wm_key(self, KBD_FLAG_UP | KBD_FLAG_EXT, XR_RDP_SCAN_ALT); xrdp_wm_key(self, KBD_FLAG_UP, XR_RDP_SCAN_LSHIFT); } else { xrdp_wm_key(self, KBD_FLAG_DOWN, XR_RDP_SCAN_LSHIFT); xrdp_wm_key(self, KBD_FLAG_DOWN | KBD_FLAG_EXT, XR_RDP_SCAN_ALT); xrdp_wm_key(self, device_flags, index - XR_MIN_KEY_CODE); } return 0; } } return 0; } /*****************************************************************************/ int xrdp_wm_pu(struct xrdp_wm *self, struct xrdp_bitmap *control) { int x; int y; if (self == 0) { return 0; } if (control == 0) { return 0; } self->popup_wnd = xrdp_bitmap_create(control->width, DEFAULT_WND_SPECIAL_H, self->screen->bpp, WND_TYPE_SPECIAL, self); self->popup_wnd->popped_from = control; self->popup_wnd->parent = self->screen; self->popup_wnd->owner = self->screen; x = xrdp_bitmap_to_screenx(control, 0); y = xrdp_bitmap_to_screeny(control, 0); self->popup_wnd->left = x; self->popup_wnd->top = y + control->height; self->popup_wnd->item_index = control->item_index; list_insert_item(self->screen->child_list, 0, (long)self->popup_wnd); xrdp_bitmap_invalidate(self->popup_wnd, 0); return 0; } /*****************************************************************************/ static int xrdp_wm_process_input_mouse(struct xrdp_wm *self, int device_flags, int x, int y) { DEBUG(("mouse event flags %4.4x x %d y %d", device_flags, x, y)); if (device_flags & PTRFLAGS_MOVE) { xrdp_wm_mouse_move(self, x, y); } if (device_flags & PTRFLAGS_BUTTON1) { if (device_flags & PTRFLAGS_DOWN) { xrdp_wm_mouse_click(self, x, y, 1, 1); } else { xrdp_wm_mouse_click(self, x, y, 1, 0); } } if (device_flags & PTRFLAGS_BUTTON2) { if (device_flags & PTRFLAGS_DOWN) { xrdp_wm_mouse_click(self, x, y, 2, 1); } else { xrdp_wm_mouse_click(self, x, y, 2, 0); } } if (device_flags & PTRFLAGS_BUTTON3) { if (device_flags & PTRFLAGS_DOWN) { xrdp_wm_mouse_click(self, x, y, 3, 1); } else { xrdp_wm_mouse_click(self, x, y, 3, 0); } } /* vertical mouse wheel */ if (device_flags & PTRFLAGS_WHEEL) { if (device_flags & PTRFLAGS_WHEEL_NEGATIVE) { xrdp_wm_mouse_click(self, 0, 0, 5, 0); } else { xrdp_wm_mouse_click(self, 0, 0, 4, 0); } } /* horizontal mouse wheel */ /** * As mstsc does MOUSE not MOUSEX for horizontal scrolling, * PTRFLAGS_HWHEEL must be handled here. */ if (device_flags & PTRFLAGS_HWHEEL) { if (device_flags & PTRFLAGS_WHEEL_NEGATIVE) { xrdp_wm_mouse_click(self, 0, 0, 6, 0); } else { xrdp_wm_mouse_click(self, 0, 0, 7, 0); } } return 0; } /*****************************************************************************/ static int xrdp_wm_process_input_mousex(struct xrdp_wm* self, int device_flags, int x, int y) { if (device_flags & PTRXFLAGS_DOWN) { if (device_flags & PTRXFLAGS_BUTTON1) { xrdp_wm_mouse_click(self, x, y, 6, 1); } else if (device_flags & PTRXFLAGS_BUTTON2) { xrdp_wm_mouse_click(self, x, y, 7, 1); } } else { if (device_flags & PTRXFLAGS_BUTTON1) { xrdp_wm_mouse_click(self, x, y, 6, 0); } else if (device_flags & PTRXFLAGS_BUTTON2) { xrdp_wm_mouse_click(self, x, y, 7, 0); } } return 0; } /******************************************************************************/ /* param1 = MAKELONG(channel_id, flags) param2 = size param3 = pointer to data param4 = total size */ static int xrdp_wm_process_channel_data(struct xrdp_wm *self, tbus param1, tbus param2, tbus param3, tbus param4) { int rv; int chanid ; rv = 1; if (self->mm->mod != 0) { chanid = LOWORD(param1); if (is_channel_allowed(self, chanid)) { if (self->mm->usechansrv) { rv = xrdp_mm_process_channel_data(self->mm, param1, param2, param3, param4); } else { if (self->mm->mod->mod_event != 0) { rv = self->mm->mod->mod_event(self->mm->mod, 0x5555, param1, param2, param3, param4); } } } } return rv; } /******************************************************************************/ /* this is the callbacks coming from libxrdp.so */ int callback(intptr_t id, int msg, intptr_t param1, intptr_t param2, intptr_t param3, intptr_t param4) { int rv; struct xrdp_wm *wm; struct xrdp_rect rect; if (id == 0) /* "id" should be "struct xrdp_process*" as long */ { return 0; } wm = ((struct xrdp_process *)id)->wm; if (wm == 0) { return 0; } rv = 0; switch (msg) { case RDP_INPUT_SYNCHRONIZE: rv = xrdp_wm_key_sync(wm, param3, param1); break; case RDP_INPUT_SCANCODE: rv = xrdp_wm_key(wm, param3, param1); break; case RDP_INPUT_UNICODE: rv = xrdp_wm_key_unicode(wm, param3, param1); break; case RDP_INPUT_MOUSE: rv = xrdp_wm_process_input_mouse(wm, param3, param1, param2); break; case RDP_INPUT_MOUSEX: rv = xrdp_wm_process_input_mousex(wm, param3, param1, param2); break; case 0x4444: /* invalidate, this is not from RDP_DATA_PDU_INPUT */ /* like the rest, it's from RDP_PDU_DATA with code 33 */ /* it's the rdp client asking for a screen update */ MAKERECT(rect, param1, param2, param3, param4); rv = xrdp_bitmap_invalidate(wm->screen, &rect); break; case 0x5555: /* called from xrdp_channel.c, channel data has come in, pass it to module if there is one */ rv = xrdp_wm_process_channel_data(wm, param1, param2, param3, param4); break; case 0x5556: rv = xrdp_mm_check_chan(wm->mm); break; case 0x5557: //g_writeln("callback: frame ack %d", param1); xrdp_mm_frame_ack(wm->mm, param1); break; } return rv; } /******************************************************************************/ /* returns error */ /* this gets called when there is nothing on any socket */ static int xrdp_wm_login_mode_changed(struct xrdp_wm *self) { if (self == 0) { return 0; } g_writeln("xrdp_wm_login_mode_changed: login_mode is %d", self->login_mode); if (self->login_mode == 0) { /* this is the initial state of the login window */ xrdp_wm_set_login_mode(self, 1); /* put the wm in login mode */ list_clear(self->log); xrdp_wm_delete_all_children(self); self->dragging = 0; xrdp_wm_init(self); } else if (self->login_mode == 2) { if (xrdp_mm_connect(self->mm) == 0) { xrdp_wm_set_login_mode(self, 3); /* put the wm in connected mode */ xrdp_wm_delete_all_children(self); self->dragging = 0; } else { /* we do nothing on connect error so far */ } } else if (self->login_mode == 10) { xrdp_wm_delete_all_children(self); self->dragging = 0; xrdp_wm_set_login_mode(self, 11); } return 0; } /*****************************************************************************/ /* this is the log windows notify function */ static int xrdp_wm_log_wnd_notify(struct xrdp_bitmap *wnd, struct xrdp_bitmap *sender, int msg, long param1, long param2) { struct xrdp_painter *painter; struct xrdp_wm *wm; struct xrdp_rect rect; int index; char *text; if (wnd == 0) { return 0; } if (sender == 0) { return 0; } if (wnd->owner == 0) { return 0; } wm = wnd->wm; if (msg == 1) /* click */ { if (sender->id == 1) /* ok button */ { /* close the log window */ MAKERECT(rect, wnd->left, wnd->top, wnd->width, wnd->height); xrdp_bitmap_delete(wnd); xrdp_bitmap_invalidate(wm->screen, &rect); /* if module is gone, reset the session when ok is clicked */ if (wm->mm->mod_handle == 0) { /* make sure autologin is off */ wm->session->client_info->rdp_autologin = 0; xrdp_wm_set_login_mode(wm, 0); /* reset session */ } } } else if (msg == WM_PAINT) /* 3 */ { painter = (struct xrdp_painter *)param1; if (painter != 0) { painter->fg_color = wnd->wm->black; for (index = 0; index < wnd->wm->log->count; index++) { text = (char *)list_get_item(wnd->wm->log, index); xrdp_painter_draw_text(painter, wnd, 10, 30 + index * 15, text); } } } return 0; } static void add_string_to_logwindow(const char *msg, struct list *log) { const char *new_part_message; const char *current_pointer = msg; int len_done = 0; do { new_part_message = g_strndup(current_pointer, LOG_WINDOW_CHAR_PER_LINE); g_writeln("%s", new_part_message); list_add_item(log, (tintptr) new_part_message); len_done += g_strlen(new_part_message); current_pointer += g_strlen(new_part_message); } while ((len_done < g_strlen(msg)) && (len_done < DEFAULT_STRING_LEN)); } /*****************************************************************************/ int xrdp_wm_show_log(struct xrdp_wm *self) { struct xrdp_bitmap *but; int w; int h; int xoffset; int yoffset; int index; int primary_x_offset; int primary_y_offset; if (self->hide_log_window) { /* make sure autologin is off */ self->session->client_info->rdp_autologin = 0; xrdp_wm_set_login_mode(self, 0); /* reset session */ return 0; } if (self->log_wnd == 0) { w = DEFAULT_WND_LOG_W; h = DEFAULT_WND_LOG_H; xoffset = 10; yoffset = 10; if (self->screen->width < w) { w = self->screen->width - 4; xoffset = 2; } if (self->screen->height < h) { h = self->screen->height - 4; yoffset = 2; } primary_x_offset = 0; primary_y_offset = 0; /* multimon scenario, draw log window on primary monitor */ if (self->client_info->monitorCount > 1) { for (index = 0; index < self->client_info->monitorCount; index++) { if (self->client_info->minfo_wm[index].is_primary) { primary_x_offset = self->client_info->minfo_wm[index].left; primary_y_offset = self->client_info->minfo_wm[index].top; break; } } } /* log window */ self->log_wnd = xrdp_bitmap_create(w, h, self->screen->bpp, WND_TYPE_WND, self); list_add_item(self->screen->child_list, (long)self->log_wnd); self->log_wnd->parent = self->screen; self->log_wnd->owner = self->screen; self->log_wnd->bg_color = self->grey; self->log_wnd->left = primary_x_offset + xoffset; self->log_wnd->top = primary_y_offset + yoffset; set_string(&(self->log_wnd->caption1), "Connection Log"); /* ok button */ but = xrdp_bitmap_create(DEFAULT_BUTTON_W, DEFAULT_BUTTON_H, self->screen->bpp, WND_TYPE_BUTTON, self); list_insert_item(self->log_wnd->child_list, 0, (long)but); but->parent = self->log_wnd; but->owner = self->log_wnd; but->left = (w - DEFAULT_BUTTON_W) - xoffset; but->top = (h - DEFAULT_BUTTON_H) - yoffset; but->id = 1; but->tab_stop = 1; set_string(&but->caption1, "OK"); self->log_wnd->focused_control = but; /* set notify function */ self->log_wnd->notify = xrdp_wm_log_wnd_notify; } xrdp_wm_set_focused(self, self->log_wnd); xrdp_bitmap_invalidate(self->log_wnd, 0); return 0; } /*****************************************************************************/ int xrdp_wm_log_msg(struct xrdp_wm *self, enum logLevels loglevel, const char *fmt, ...) { va_list ap; char msg[256]; va_start(ap, fmt); vsnprintf(msg, sizeof(msg), fmt, ap); va_end(ap); log_message(loglevel, "xrdp_wm_log_msg: %s", msg); add_string_to_logwindow(msg, self->log); return 0; } /*****************************************************************************/ int xrdp_wm_get_wait_objs(struct xrdp_wm *self, tbus *robjs, int *rc, tbus *wobjs, int *wc, int *timeout) { int i; if (self == 0) { return 0; } i = *rc; robjs[i++] = self->login_mode_event; *rc = i; return xrdp_mm_get_wait_objs(self->mm, robjs, rc, wobjs, wc, timeout); } /******************************************************************************/ int xrdp_wm_check_wait_objs(struct xrdp_wm *self) { int rv; if (self == 0) { return 0; } rv = 0; if (g_is_wait_obj_set(self->login_mode_event)) { g_reset_wait_obj(self->login_mode_event); xrdp_wm_login_mode_changed(self); } if (rv == 0) { rv = xrdp_mm_check_wait_objs(self->mm); } return rv; } /*****************************************************************************/ int xrdp_wm_set_login_mode(struct xrdp_wm *self, int login_mode) { self->login_mode = login_mode; g_set_wait_obj(self->login_mode_event); return 0; } xrdp-0.9.5/xrdp/xrdp_logo.bmp000644 001751 001751 00000304766 13125122134 016106 0ustar00metameta000000 000000 BMö‰6(ðŒÀ‰  ÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿþþþþÿÿÿÿÿÿÿÿþþþüüûîöûÇáù¬ÑûµÔûÜëúøûûþþýÿÿÿÿÿþÿÿÿþþþÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿþþþÿÿÿÿÿþÿÿþþþþÛìùrµö‡ûyýxýsýnû2ˆõ©Ì÷ðõúþþýÿÿÿÿÿÿþþþÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿþÿÿÿÿÿÿþþõùû«Ôù(“ú „ý ÿÿ{ÿuþrûmùeöS–òÕäõþþýÿÿÿÿÿÿþþþÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿþþþÿÿÿÿÿþð÷û•ÌøŽûŒþŠý ‚þÿ{ÿuþrûoùl÷cõ/~òÈÙ÷þýýÿÿÿÿÿÿþþþÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿþþþÿÿÿÿÿÿõúý™Îø‘ü‘þŒþŠü†üþzÿuþrûoùlöhö^ô.wîËÜôþþýÿÿÿþþÿþþþÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿþþþÿÿÿÿÿÿúýþ°Úù#˜ú&•ÿ‘þ‹þ‡þˆü‡ü }þtýpûoùlöhödó]òE‰îÜçöÿÿþÿÿÿþþþÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿþþÿÿÿþþþþÑêú8£ú)™ÿ%•þ!’ü2˜ùM¤úrµú€¼øg­ú7ú|ùoùköhöeô iôWîoŸîïóúÿÿþÿÿÿþþþÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿþþþÿÿÿÿÿþìöúg»ø*œþ*šþ3›üj´õÊáöÿÿûÿÿþÿÿýÿÿûùüû¥ÌùAõ nõgö iõcò_ïVìªÃîûüüÿÿÿÿÿÿþþþÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿþþÿÿÿþüýý§×ö*Ÿý1Ÿþ?£ú›Ì÷ÿýùÿÿþÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿýçð÷l¦ôrôcóbò_ïYí(nêÛåõþþþÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿþþÿáñùG¯ø5£ÿF§ú«Ôõÿÿúÿÿÿÿÿÿþþþÿÿÿÿÿÿÿÿÿþþþþþÿÿÿþøúúv©ñ hñ`ò_ï\íNèz¢ìøùûÿÿþÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿþþþÿÿÿÿÿÿÿÿÿÿÿÿþþþÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿþýýýÌ÷3¤ýA¨ý¢Ðõÿÿûÿÿÿþþþÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿþþþþÿÿÿÿþôöødñdñ^ï\íVé YèÎÚòýþþÿÿþÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿþþþÿÿÿÿÿÿÿÿÿþþþÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿþþþýýýýýýþþþÿÿÿþþþÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿþþþþþÿÞðùE®ü<¨þ‰Ç÷ÿýùÿÿÿþþþÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿþþþþþÿÿÿþáë÷A†ñ_ï\íSéJçwëüûüÿÿÿÿÿÿÿÿÿÿÿÿþþþÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿýýýýýýþþþÿÿÿþþþÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿýýýúúúûûûüüüþþþÿÿÿþþþÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿþþÿÿþþ‘Ïø>«þd·øîóöÿÿÿþþþÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿþþþþþÿÿÿþ¸ÑõlïVí7zìu¢î¤¾ñèïûìóýÿþýÿÿþÿÿÿÿþÿþþþÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿûûûúúúüüüþþþÿÿÿþþþÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿþþþÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿþþþÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿýýýúúúúúúûûûýýýþþþÿÿÿþþþÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿþþþÿÿÿåóûTµûN±ûÅßóÿÿþþþÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿþþþÿÿÿÿÿüw¤òv¥ô·Ëñ«À逤êb–ôa•óxŸì¡¸êèìöÿÿÿþþÿþþþÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿûûûúúúúúúüüüþþþÿÿÿþþþÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿþþþÿÿÿÿÿÿþþþýýýýýýýýýþþþÿÿÿÿÿÿÿÿÿþþþÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿþþþýýýüüüúúúùùùüüüþþþÿÿÿþþþÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿþþÿÿÿþ¡ØùB®þ†ÇöÿýúÿÿÿþþþÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿþþþÿÿÿìóúÍÓêrŠÓ+_Ò QÛNäGã@Ø JÍ\}ÐÈÐéÿÿÿþþþÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿýýýýýýûûûùùùúúúþþþÿÿÿþþþÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿþþþþþþýýýþþþüüüýýýýýýýýýýýýþþþÿÿÿþþþÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿþþþÿÿÿÿÿÿþþþûûûùùùúúúüüüþþþÿÿÿþþþÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿõúû`¾úR¶ûÜìöÿÿÿþþþÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿþþþÿÿÿàãìczÅ9_Å:gÎ9jÖ=rÝ\ØEÌ>Ã.³<[»×ÛìÿÿÿþþþÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿþþþÿÿÿÿÿÿýýýùùùùùùüüüýýýÿÿÿþþþÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿþþþüüüýýýüüüüüüýýýüüüüüüûûûýýýþþþÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿþþþÿÿÿþþþüüüúúúùùùýýýÿÿÿÿÿÿþþþÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿþþþÿÿÿÂæøLµþÍõÿÿüÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿv†ÁJd»;]¼'P¼1[Ç'UÍFoÖMÄ4ZÁ*«&¡Wj¶ÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿþþþÿÿÿýýýûûûúúúûûûþþþÿÿÿþþþÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿþþþüüüüüüûûûüüüûûûüüüûûûüüüýýýþþþÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿþþþÿÿÿþþþüüüúúúûûûýýýþþþÿÿÿþþþÿÿÿÿÿÿÿÿÿÿÿÿþÿÿÿÿþ~ÌùU¹üâîõÿÿÿþþþÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿ×ÙèOb®J_²=®4_Ë(YÑ-\Õ1a×:g×?gÐ5®”-—ËÍáÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿýýýûûûúúúüüüþþþÿÿÿþþþÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿþþþüüüûûûüüüüüüüüüüüüüüüüüüüüüþþþÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿþþþÿÿÿÿÿÿûûûùùùúúúüüüþþþÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿêôúY¾ü‡Ìõÿþüÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿœ¢ÌT`«6R²+^Î9sÞYÛ'iÝ#eÛBzá0kÜ YÏ%Ÿ ‹‹Ãÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿþþþÿÿÿÿÿÿþþþùùùúúúûûûþþþÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿþþþüüüûûûüüüýýýüüüýýýýýýüüüüüüþþþÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿþþþÿÿÿýýýüüüüüüûûûþþþÿÿÿÿÿÿþþþÿÿÿþþþÿÿÿ²á÷QºýÔéôÿÿÿþþþÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿƒˆ¼LU 8oÐ"ráLçnáqáLŽç"tá@…ãmàLË „qv²ÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿþþþÿÿÿþþþüüüüüüûûûüüüÿÿÿÿÿÿþþþÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿþþþüüüýýýûûûüüüüüüüüüûûûûûûýýýþþþÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿþþþþþþýýýûûûüüüýýýþþþÿÿÿþþþþÿÿÿÿý{ÍùsÅ÷úûûÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿŽ‘½;JP‘âzå,ŠçF˜êF˜ë,‹ê ‚æOësåhß,“z~²ÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿþþþþþþþþþûûûûûûýýýþþþÿÿÿþþþÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿþþþüüüýýýýýýüüüúúúûûûýýýüüüýýýÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿþþþÿÿÿÿÿÿþþþûûûúúúúúúýýýÿÿÿÿÿÿÿÿÿé÷ú]Àý¯Ûôÿÿþþÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿ¿Ö%@A’áM§ð+—ë’í"•í4œïQ¬ð"”ë‚ìyã= ­¬Êÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿþþþÿÿÿÿÿÿÿÿÿýýýúúúúúúüüüþþþÿÿÿþþþÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿþþþþþþýýýüüüýýýýýýüüüûûûýýýþþþÿÿÿþþþÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿþþþÿÿÿýýýûûûúúúûûûýýýþþþÿÿÿ¼æù]ÁüêòöÿÿÿþþþÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿýFN™…á,§òJ²òP¹óQ¹öD´ô¤ò˜ñ”òŠé3B•ø÷÷ÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿþþþÿÿÿþþþüüüúúúûûûüüüþþþÿÿÿþþþÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿþþþÿÿÿÿÿÿþþþþþþýýýýýýþþþþþþþþþÿÿÿþþþÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿûûûøøøúúúúúúúúúýüýÿÿÿ‹ÕúˆÎ÷üüýÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿþÿÿÿÿÿÅÀÔqÁ¡ó «ø °ø °ú °ü¬ù©ø¤öuÈ´°Éÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿýýýøøøùùùúúúúúúüüüþþþÿÿÿþþþÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿþþþÿÿÿÿÿÿþþþþþþþþþþþþÿÿÿÿÿÿþþþÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿûûûöööûûûüüüúúúûûû÷ûúhÆüÀàöþþþÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿþþþÿÿÿÿþþ¸¹Ð"…˶ù½ÿ¾ÿ¾ÿ½ÿ¸ú†Î£¬ÈþþüÿÿÿþþþÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿþþþøøøøøøüüüúúúúúúüüüþþþÿÿÿþþþÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿþþþÿÿÿÿÿÿÿÿÿÿÿÿþþþÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿþþþþþþþþþþþþýýýûúùØíõdÅûíõ÷þþþþþþÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿþþþÿÿÿûúûàäëv£È$ÎÖ’ÙÐk ÉÙßæúøùÿÿÿþþþÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿþþþþþþþþþþþþþþþûûûøøøûûûþþþÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿþþþÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿýû¨ßøˆÑ÷úüýÿþþÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿþþþÿÿÿÿÿÿþþþøøúóøúéñ÷æïññùõËÖïr’æäéðÿÿÿþþþÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿþþþÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿýýýûûûýýýÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿþþþÿÿÿÿÿþ€Óû±Þõüþþÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿþþþÿÿÿÿÿÿþþþþþþÿÿÿd‹èWãEÝ Hܰ¿ìÿÿýÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿþþþÿÿÿþþþþþþþþþÿÿÿþþþÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿþþþÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿþÿÿþþþþþÿþþþþþþþþþþþÿþÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿþÿÿÿþþÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿõûûhÊýÜî÷þþþÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿw›ëGÞCÞEÝw“ãÿÿùÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿþþþÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿþþÿþþþþþþþþþþþþþþþþþþþþþþþþþþþþþÿÿÿÿþþþþþþÿÿÿþþþÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿþþþÿÿþÿÿÿÿþÿÿþÿþþþýþþüÿþûþüùýúøþûøþûøýüùýúùýüüþýýþþýþþþþþÿþÿÿþÿÿÿþÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿþþþÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÑîûzÏúôøúÿþþÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿ¹ÊïFÞCÞBÜBkÝÿþ÷ÿÿÿþþþÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿþþþÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿþþþþþþþþþþþþþþþýüüûúùø÷õõôñóóïòñíññíññíòôðööóüûùþýüýýüýþþÿÿÿÿÿÿÿÿÿÿÿÿþþþÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿþþþþÿþÿÿÿÿþÿþÿÿúþüóüøâüóÄýã¦üÔŒûÉ€øÅsûÀrûÂrüÃ~úƉúÊýÖ±ýÝÄûåÝüðïýøòýûõþúúþýýþþÿþÿÿþÿÿþÿÿÿÿÿÿÿÿÿÿÿÿÿþþþÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿþþþÿÿÿ°ãû¡Ú÷úýþÿÿÿþþþÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿòöùKàCÞAÜLÛðñòÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿþþþÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿþÿÿþþþþþþýýþüüü÷öôòðíìèâèãÝãÚÈáϪäÊŽåÄvêÀ^ê¿Oï¿EïÀAðÀBíÂHìÆWèÉpæÔ”èàÀðîæûúóþþýþþÿÿÿÿÿÿþþþþÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿþÿþÿþÿÿþÿøþüàýï£úÒXø­'ø– ú•&úš)ú›-ø 8ú£6ú¤:û§?ûª?ú¬Eû­Fû±Gü³Gü³Mü·cû†ûΧýÝËýëèýöðþùóþûüþþÿþÿÿþÿÿþÿÿÿÿÿÿÿÿÿþþþÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿ“ÚûÀåöüýþÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿþþþÿÿÿ?oåBÞAÜKÜÃÌìÿÿýÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿþþÿýþþýýþúúùôòïìèáæáÔàÓ´âŇè»Yï³2ð«ö§ò«ö¯ô³ù±ú³ø´ø·ù¸ú¹úºû½ø¿úÀöÄîÐ`ïâ¶øõîýýýÿÿÿÿÿþþþþÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿþþþÿÿÿÿþÿîýõ™úË-÷—úŒ ú‘"ú“$ù”&ù˜+ù›8ù¢Aù§Uû±iû»€úÆŽûΗúјûÒ”ûÒûÐûÊqüÆcûÀ^û¾Zû¾^üÀwýÌ›ýÛÂýèäýôðýøöþûþþþÿþÿÿþÿÿÿÿÿÿÿÿÿÿþþþÿÿÿÿÿýuÐüÝðøþþþÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿyšìBÞDÝJÛ¤åÿÿûÿÿÿÿÿÿÿÿÿÿÿÿþþÿüýþúûüöôñïéáæÞÎáΪå¾ví²@ò¦ô£ó¦õ¨ö«ö­ö­÷°ù³ùµö¸ ø¶ø¸ùºú»û½ú¾üÀýÃûÆûÇýÇúÇïÑLóëÅýüûÿÿÿÿÿþþþþÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿþþþÿÿÿÿÿÿåýñkù³ ÷øŠùùú ù‘3ø›^ø°£ûÓáýðÿüÿÿþÿÿýÿÿþÿÿþÿÿþÿÿþÿÿÿÿÿþÿÿþÿÿüÿðýøÙûð¾üåžüÚ‚üÏjüÆjüÉ…üÒ­üáÒüïæý÷óþûýþþÿþÿÿþÿÿÿÿÿÿÿäõûÓúñøúÿþþÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿ¯ÃíDß FÝ@Úa€àÿÿùÿÿÿþþÿûüþúúûõòìëä×ãÕ½âÅŒè´Mñ¥õŸô¡ö¤õ¦ö©ö«÷­÷®÷¯÷±ø³ú³ø¶÷¸÷» û¼ù»ù½üÀüÁûÃûÇúÈ üÇýÊýËýËõÎõé¨üýüÿÿÿÿÿþÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿþÿþÿÿÿðý÷vø¶÷yø„ø†ù†ù‡øPø§¿ûßÿüÿÿþÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿþÿÿýÿùüüÙüð³ûã‹ûÔxüÎ…üÔ¦üáËýìàýóñþúýþþÿÿÿÊìüÚøöûýÿÿþÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿåêô JÞ?Ý<Ú6^ÜÿýõúûýóðëéáÑãѰå½zì¬7ô¡ ô ó õ£õ¥õ¦ö©õ©õ©ö¬÷±ö´ ÷¸õ¼÷¾!úÁ&÷Ã(øÅ'øÆ,ùÊ1øÇ%÷ÆûÅûÇúÆúÈüÉýÊþÌÿÎþÏþÐøØ ÷ñ»ýþÿÿÿÿÿþþÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿþÿ±ùÔö|÷| ÷~ø ø÷„bù°ãüñÿþÿÿÿÿÿÿÿÿþþþÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿþþþÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿýÿùüûÓüï¨üà…üÕ‰üÕ¬ýâÌýîçÿõ©åú¹ãùûüÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿþþþÿÿÿþþþ#YâKÞ'YßYuÖíáÎåÒ±å½yì©4òšôšóŸô¡õ¥ô¦õ¥ö§õ«õ°ö·&ö»0ôÂ>õÌ]÷Ø÷ßœüê»úñËööÜúøèýúêüùéúøåùôÖûî½øå–÷ÜiõÔ?úÏýÌþÍþÏþÑþÔþÔýÔ÷ä]üúçÿÿÿþÿþÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿþþþÿÿÿìüóló¬ôröz÷y÷{ø{Kø¢Ùüìÿþÿÿÿÿþþþÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿþÿÿÿþþÿÿÿÿÿÿÿÿÿÿÿÿÿþÿÿýþåüó´ûå‘üÚšþÛ|Ýô¸êñâýöùþýÿþÿÿÿÿÿÿÿÿÿÿþþþÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿþþþÿÿÿÿÿÿÿÿÿþþÿùûÿz™ç}‘ÊǺ±ó̈ê«Bï™ô˜óœóŸô¡ô¡ó¡õ¥ó¯ô·0ô½>õÊcõØøé¿ü÷êûÿÿüÿÿûÿÿýÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿýÿÿüÿÿúýùûî±ùÜTúÔþÒþÓÿÖÿ×ÿ×øÛúó¾þÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÙúè@îòuòuõwöw ö~¢ùÍÿþÿÿÿÿþþþÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿþÿþÿþÿÿÿÿÿÿÿÿÿÿÿþÿÿýÿãþñ|Øú¨ñå¨üâ¿ýêÔýòîþúÿþÿÿþÿÿÿÿÿÿÿþþþÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿþþþÿÿÿÿÿÿÿÿÿüþÿøûÿñïìêÜÄòÑ™÷ºZõ£ò•ò™òó ô ô ó¥ô°%ôºAõÇc÷Ù•øíÎúýüúÿÿüÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿþþþÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿþþþÿÿÿÿÿÿÿÿÿÿÿÿþÿÿúûø÷ê—ûÚ"ÿÖÿØÿÙÿÚ ýØ÷íšüýüÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÌ÷ß!é|îtðuòuór9ô“ÎûãÿÿÿþþþÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿþþþÿÿÿÿÿÿõûýŽÙûìöúÙüñ«üä¡ýá´ýéÇýîàþõûþþÿþÿÿÿÿÿÿÿÿþþþÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿþþþÿÿÿÿÿÿÿÿÿûüÿõùýïçÜéÒ­æ¾|ì¦4ó•ò—ó›ó÷¡òžó¤ó°+ô¾OôÎz÷ãµûøîûÿÿüÿÿþÿÿÿÿÿÿÿÿÿÿÿÿÿÿþþþÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿþþþÿÿÿþÿÿûþÿøï¡üÛÿÚþÛ þÛÿÚùêƒýüòÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿþÿÆôÚæqëo ívïtðnUõ¢äüðÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÚôü ÞùóúþÿÿÿÿýÿõýúÊüí§üä°üæ¿üëÓýòõþüÿþÿÿÿÿÿÿÿÿþÿþÿþÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿþþþÿÿÿÿÿÿþÿÿùûÿòõøíßÌæÉ–ê±Xïœó˜ôšñšõžû¢õ Ý›$ó¿QõÏ€÷æ¾ûúõüÿÿþÿÿÿÿÿÿÿÿÿÿÿÿÿÿþþþÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿþþþÿÿÿÿÿÿûûöøéuýÛþÛþÝÿÝ úëýüñÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿþÿËóÜâtéiêo ësíl^ô¦ëýõÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÇîü³äùöüþÿÿÿÿÿÿÿÿÿÿþÿÿýþàüõ¶üç°ûæ»üêËýðìþúÿþÿÿÿÿÿÿÿÿÿþþþÿÿÿÿÿÿÿþþþþþþÿÿÿÿÿÿþÿÿ÷ûÿðððëØ½æÃ‡êªFð—ó•ô˜ñ™óœðœÛ•«ƒGmjlpŸùöéýÿÿýÿÿÿÿÿÿÿÿÿÿÿþþþÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿþþþÿÿþþÿÿøó¶úß+ÿÞþßþßúíŽýüõÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿ×õä9ßçdèièlêl\ñ¡æüðÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿµèüÅêøùýþÿÿÿÿÿÿþþþÿÿÿÿÿÿÿÿÿÿþÿðüùÇüí´üè·üêÅýïåþøÿþÿÿþÿÿÿÿÿþÿþþþÿÿÿÿÿÿýþÿöúÿðîíêÓ®ç¸rí¦9ò˜ò”ó˜ò™òšðñ°9òÈv—FÅ3áLÞêìñÿÿÿÿÿÿþþþÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿþþþÿÿÿú÷×úäQÿßþàýàúñ©ýþþÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿþþþÿÿÿé÷ïcß™â^ægçhègHí“Öúæÿÿÿþþþÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿþþÿÿÿÿ âü×ðøýþþÿÿÿÿÿÿÿÿÿÿÿÿþþþÿÿÿÿÿÿÿÿÿÿþÿùýüÓüò¼üë·üêÀýìâþøÿþÿÿÿÿÿÿÿýþÿöúÿîëèêΦèµcíŸ%ñ•ô—ô™ó—ñ—ï¤ò½XôÓøéÊ÷úü_ˆð>ß:×JÖËÒêÿÿþÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿûùæûècÿàÿá ûã-üöÆþÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿûùú—ã·ß[ãdäfæd!èyºöÕÿÿÿÿÿþÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿþÿþÿÿÿ“ÝûäôùÿþþÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿþþþÿÿÿÿÿÿÿÿÿÿÿÿüýýÝüôÃüì¸üë¼þíãþ÷÷úÿíëéêÌ¡é°Yíœñ”ò–òšó—ï•ðª*óÇqòܪûôåüÿÿþÿÿüýÿ†¢é=Ú ?×F×®ºèÿÿüÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿúùæùèfÿáÿâ ùé_üúßÿÿÿþþþÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿýÿÅëÓ&Ùnß_ácâdãbñ¹ÿþÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿþþý•Þúê÷üÿÿþÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿþÿÿÿþþÿÿÿÿÿÿÿþÿþþþáûöÅ÷òÖëäëÌ¡é°Xíœ ñ’ñ“ñ™ò—ð—ï°;óψöäÁûúôüÿÿÿÿÿÿÿÿÿÿÿüýþ©¼ì8Ù>ØH×’¤äÿÿúÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿùùÛùè]þâ üä$úñ›ýýøÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿìôîlÚ˜ÛVÞ`ßbà\Ré”áúìÿÿÿþþþÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿîùû¡àøîùýÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿþþþÿÿÿÿÿÿÿÿÿøûÿðíðìÎ¥é®Qîšð’ñ–ó˜ö–ñšò´FóÔ˜öêÐüýûþÿÿÿÿÿÿÿÿÿÿÿþþþÿÿÿþþþÊØð5Ø:×BÖ|“àÿÿøÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿþþþÿÿÿú÷ÆùçNýå-úèIü÷Êþÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿþþþÿÿÿÿÿÿÿÿÿþþþÿÿÿÿÿÿþþþÿÿÿÿúý®äÃØeÜ\Ý_Þ_ái¯óÌÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿßõû­äùòúþÿÿÿþþþÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿþþþÿÿÿÿÿÿÿÿÿùüÿîñôêÒ±ì®Ríšð‘ò“ó–ò•ížлPåÚ¢ùïÚýþþþÿÿÿÿÿÿÿÿÿÿÿþþþÿÿÿÿÿÿÿÿÿÿÿþçí÷9×:×<Ôf€Þÿÿ÷ÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿýÿÿùò¥úæ6üç2øî‰üûðÿÿÿþþþÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿüüüýýýÿÿÿþþþÿÿÿÿÿÿÿÿÿÿÿÿæðêaØ‘ÙSÛ\Ü^ÜYcéœêûñÿÿÿþþþÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÑñý¸èùõûþÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿþþþÿÿÿÿÿÿÿÿÿûýÿïóøêÚÃë±[í›ð’ñ’ó•ò”ò™ôºVõÞ±ØñÙ³úçÊýóùþýÿÿÿÿÿÿþþþþÿþÿÿÿÿÿÿÿÿÿþÿÿÿÿÿòõüJÙ:×<ÖLjÛÿÿõÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿþþþÿÿÿûûïøíƒüç0úêLùöÃýþÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿþþþþþþûûûúúúþþþÿÿÿÿÿÿÿÿÿþþþÿÿÿÿúý®äÃÔg×VÙZÚ]Þg²òÍÿÿÿÿÿÿþþþÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÄîüÄëøøüþÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿþþÿòôúêâÖê¶kí›!ð“ñ’ò•ñ”ï—ñ¶LöÞ±ûõçþþþùþÿçûôÑ÷î«úåÍýòþþþÿÿÿÿÿÿÿÿÿþþþÿÿÿþþþÿÿÿôöý3`Þ>Ø9Õ1XØþûñÿÿÿþþþÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿþþÿÿù÷ÈùêSüç/úñüýõþÿÿÿÿþÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿþþþþþþùùùúúúûûûÿÿÿÿÿÿþþþþþþÿÿÿÿÿÿðòðrØ™ÓR×[ Ù_ÙXKã‰ßøêÿÿÿþÿþÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿþþþÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿ¸ìûÏíøúýþÿÿÿÿÿÿÿÿÿÿÿÿþþþÿÿÿÿÿÿõøûëêéêÀƒí#ï“ ñ’ò•ò•ñ–ð±@õÜ®ûôèþþýþÿÿÿÿÿÿÿÿüûûõùøçùõÀùì§üèÚÿöÿþÿÿÿÿÿÿÿÿþÿÿÿÿÿÿÿöøýTzá;Ø5Ô'Q×êëîÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿþþþÿÿÿÿÿÿÿÿÿÿÿÿþþþÿÿÿþþþÿÿÿüüø÷ñ–üé1ûî_ûùÑÿÿÿÿÿÿþþþÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿþþþüüüüüüûûûúúúýýýÿÿÿþþþþþþÿÿÿÿüÿÉæÓ>ÒwÕUÖZ×XØWŽìµ÷ýúÿÿÿþþþÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿþþþÿÿÿÿÿÿþþþýýýýýýþþþÿÿÿ­èüØò÷ýþýÿÿÿÿÿÿþþþÿÿÿÿÿÿúüýíñõêΨì¥9ð• ð‘ñ”ó—ð”ñ©/óÙ¤ùõèýüûÿÿÿÿÿÿÿþþþþþÿÿÿýýýüüüýüüñù÷ãúô°ûç­ýéðþûÿÿÿÿÿÿþþþÿÿÿ÷ùýh‰â6×5Ô$OÖ×ÛëÿÿþÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿþþþÿÿÿÿÿÿþþþýýýýýýþþþÿÿÿÿÿÿÿÿÿþÿÿûøÏûìVûë?øô¥ýýþÿÿÿþþþÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿþþþþþþþþþüüüùùùûûûþþþÿÿÿþþþÿÿÿÿÿÿûöù™Ý²Ñ^ÒRÔWÕUÚfÈôÚÿÿÿÿÿÿþþþÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿþþþÿÿÿþþþýýýýýýþþþþþþüüüÿÿþ¥äúäôùÿþþÿÿÿÿÿÿÿÿÿýþþñõùêÜÊí¬Hì–ð”ñ– ó•î•ð¢òÒ•ùôèüûúþÿÿþÿÿÿÿþþþþÿÿÿÿÿÿÿÿÿþþþþþþýýýúúúúúúòûùÛûó¡ûåÁþðûþüÿÿÿÿÿÿùúý|šç5Ö5Ô LÖÆÌéÿÿýÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿþþþýýýþþþþþþýýýüüüþþþþþÿüüóùò”üì5ùñ‚ûûîÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿþþþÿÿÿÿÿÿÿÿÿþþþüüüøøøùùùýýýÿÿÿþþþÿÿÿÿÿÿîîîjÓÎPÐSÓUÓRJá…äùìÿÿÿþÿþþþþÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿþþþýýýüüüüüüûûûûûûüüüÿþü¸çøéõùÿþþÿÿÿÿÿÿöøúééçê¼vî•ð“ñ”ò•ñ–ðžðÇwøóäüúøþÿÿþÿÿÿÿÿÿÿÿþþþÿÿÿÿÿÿÿÿÿþþþÿÿÿÿÿÿþþþþþþùùùùøùúûûôýûÉûíœýâÝÿ÷ÿÿÿûûþ”«ê4Ö5ÔIÕ³¾çÿÿûÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿþþþþþþüüüüüüüüüûûûûûûüüüüüüûüÿúöÃüìHûðdúøÐþþÿÿÿÿþþþÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿþþþÿÿÿÿÿÿþþþûûûúúúúúúýýýÿÿÿþþþÿÿÿÿýÿÓçÚCÏwÍKÐRÑTÓQæ¨òùöÿþÿÿÿþÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿýýýýýýýýýûûûûûûûûûûûûÿÿýªäøèõúÿþþüüýïòõêÏ©î&î” ð“ñ”ò—ð—ñ¸NøîØüüùþÿÿþÿÿÿÿÿÿÿþÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿþþþÿÿÿÿÿÿüüüúúúø÷ôìçÅóñáíûù±úå¨þèñûü«¼í3Ö6ÔFÕ¢°äÿÿûÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿþþþüüüþþþûûûûûûûûûûûûûûûýýÿø÷âùïzýíOùõ°ýþÿÿÿÿÿÿþÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿþþþÿÿÿÿÿÿþþþüüüùùùúúúýýýÿÿÿÿÿÿÿÿÿýøü´ßÂ+ÍeÍLÏRÐSÑR­íÅûýüÿÿÿþþþÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿýýýüüüüüüüüüýýýüüüûûûþýû«ãöéöúôõøêäØî®Rï” ð’ð”ó˜ð–ò¨'ôßµùýúÿþþþÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿýýýàÖœµœ¶ÖÈtÚщÙöå›ûåÊæ2Ö6ÔCÕ’£âÿÿùÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿþþþûûûýýýüüüýýýüüüûûûüüýüüöôñ²ûîdûô”üýþÿÿÿÿÿÿþþþÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿþþþÿÿÿÿÿÿþþþúúúùùùúúúþþþÿÿÿÿÿÿÿÿÿúôù’Ø©ËXËMÎQÏQÒ[ÌóÛþþþÿÿÿþþþÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿýýýüüüüüüýýýüüüüüüýüüñùú¶æöáîóîÅ‘î™ð“ð”ò•ò–ðœðÌ…ùúõüýýÿÿÿÿÿÿÿþþþþþÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿãÚ¥µœÁ¬,üüüýýúýýüöüû¢Øæ1Ö6Ô@Ô…˜ßÿÿøÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿþþþûûûüüüüüüýýýûûûüýýûûûùõÈùîhùõžúüíÿÿÿÿÿÿþþþÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿþþþÿÿÿÿÿÿýýýúúúýýýýýýÿÿÿÿÿÿÿÿÿôïôrÓ” ÈQÊMÌOÍO*ÕhÛöçþþÿÿÿÿÿÿÿþþþÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿýýýýýýýýýûûûýýýýýýýýýîòñëæÛí´[î” ñ”ñ•ó˜ð–ñµLøñÝûýþÿÿÿÿÿÿþþþþþþÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿþþþëä¼µœ½¨ üüüüüüÿÿÿÿÿþáçõ1Õ6Ô=ÔxÞÿÿ÷ÿÿÿÿÿÿþþþÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿþþþüüüþþþúúúüüüýþþüüþú÷Ûöðoúõ–ùùèþþÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿýýýúúúúúúûûûýýýÿÿÿÿÿÿÿÿÿîêì_Î…ÇMÉLËOÌJ?×wåøíþþþÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿþþþýýýýýýýüýüüü÷÷÷ëêèìÒ­ò¸^ï—ð”ò—ñ™ñ¤óÚ«ûþþÿÿÿÿÿÿþþþþþþÿÿÿÿÿÿþþþÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿöô䵜¸  ùùùúúúüüüÿÿÿëïû8Õ6Ô ;ÔiƒÝýÿõüÿþÿþÿÿÿÿÿÿþþþÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿþþþþþþüüüýýýüûüûûüøøç÷ñúóùúàýüÿÿÿÿþþþÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿþþþýýýúúúúúúûûûýýýÿÿÿÿÿÿÿýþãæãMÌxÇIÈKÊNËJSÚ„íùñÿþÿÿÿÿþþþÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿþþþÿÿÿþþþüüüýýýøøöïç×ðÇ‚ñ²Mð›ò–ó˜ñ ñÁhø÷íüÿÿÿÿÿþþþÿÿÿþþþÿÿÿÿÿÿþþþüüüÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿþþþ»¤µœòïÛùùùúúúüüüíðüCÙ5Ô 9Ó[yÙÐþçÂþîûýüþÿÿÿþÿÿÿÿþþþÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿþþþüüüüüüþþÿúùóøöºü÷–ùøÕüýÿÿÿÿþþþÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿýýýøøøùùùúúúûûûýýýÿÿÿÿÿÿþûýØãÚAÊnÆHÇJÈLÉGaÚîùóÿþÿÿÿÿþþþÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿþþþÿÿÿÿÿÿþÿÿûûüïîéêÈ“í£0ñ™ñ”ò–òšó©)õâ¼üÿÿÿÿÿÿÿÿÿÿÿÿÿÿþþþÿÿÿÿÿÿþþþúúúýýýÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿ˹LµœãÛªøøøûûûúúúìïú"MÛ5Ô7ÓZpÚôüðµûç§üäèýùûþþÿÿÿÿÿÿþÿþþþÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿþþþÿÿÿÿÿÿÿÿÿüüööó³ùñoùö¾þüÿÿÿÿþþþÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿþþþúúú÷÷÷úúúûûûøøøúúúýýýþþþÿÿÿýùýÒáÕ;ÈiÄGÆGÇKÇDgÜ’îùòÿÿÿþÿÿþþþÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿþþþÿÿÿÿÿÿþþÿ÷ööëàÎê²Xï“ð“ò–ñ˜îòÂlø÷ìÿÿÿÿÿÿÿþþþþþÿÿÿþþþÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÞÓµœÑÃløøøüüüùùùéíö-ZÙ6Õ5ÓKiÙÿÿôÿÿÿÒúðžûãÌýïøþüÿþÿÿþÿÿÿþþþþÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿþþþÿÿÿÿÿÿýýùø÷¿ûôaú÷¯ýýÿÿÿÿþþþÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÜщ¿©$·ž¾¨ ÕÇoøöêÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿþþþÿÿÿþþþýýýÿÿÿþþþûûûúúúúúúþþþÿÿÿÿÿÿþøüËßÑ7ÇfÃDÅFÇIÇEhÜ‘îùòÿÿÿÿÿÿþþþÿÿÿÿÿÿÿÿÿþþþþþþÿÿÿÿÿÿüüþóñíìЦí¡-ðó—ó˜ó›ߨ/ÙØ³öýÿÿÿÿÿÿÿþþþÿÿÿÿÿÿÿÿÿþþþÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿóïÖµœÁ¬+þþþÿÿÿýüüïòùUzÝCÕ2ÓBb×ÿþóÿÿÿÿþÿêû÷§úä²ýéëýúýþþÿÿÿÿÿÿþþþÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿýýûù÷Åúófû÷­ýüÿÿÿÿþþþÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿ¹¡¿©#ûúôåܧ¶¿©$ûúôÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿþþþÿÿÿÿÿÿÿÿÿÿÿÿþþþûûûüüüþþþÿÿÿþþþÿÿÿýøûÊßÐ8ÇgÂDÄDÆHÄCeÙŽëøðÿÿÿÿÿÿþþþÿÿÿþþþÿÿÿÿÿÿþÿÿúúûñèÛí¾xï— ò“ó—ò˜ñ¡÷ÃeÄæãÌòÿøýþÿÿÿþþþÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿ¾¨!µœöóâÿÿÿÿÿÿòôû[}à1Ò3Ò:]Öÿýòÿÿÿÿÿÿÿÿÿúüü¾úé£üåÖýôùþýÿÿÿÿÿÿÿþÿþÿþÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿþþþÿÿÿýýûù÷Êùômüù«ýýÿÿÿÿþþþÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÙÌ}ͼSÿÿÿÿÿÿÕÇqµœàÖ—ÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿþþþÿÿÿþþþþþþÿÿÿþþþÿÿÿþþþÿÿÿýøüÌàÒ:ÆgÁBÂCÄFÃB]׈âöëÿÿÿÿÿÿþþþÿÿÿÿÿÿýþÿ÷÷öîÜ¿ï°Nó’ó–ñ˜ð›ò«*ôמÿþûÊóÿÐñúùýþÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÖÉuµœßÔ’þþþÿÿÿñôüEjß4Ó5Ò7\ÖýûñÿÿÿþþþÿÿþÿÿÿÿýÿÔúñŸúâÃüìóþûÿÿÿÿÿÿÿÿÿþþþÿÿÿÿÿÿÿÿÿÿÿÿþþþÿÿÿýýüù÷Êúõsùø¯ýþÿÿÿÿþþþÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿîéǵœÍ¼SÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿþþþÿÿÿÿÿÿþþþÿÿÿÿÿÿÿÿÿþþþÿÿÿþøûÏáÓBÆl¾@ÂBÃDÃANÒ}ÜôäÿÿÿÿÿÿÿÿÿüýþõòííÏžî¡)ñ‘ó™ó˜ïŸ ïºQ÷ìÎüÿÿÿÿÿÃáз¢ʺPöóâÿÿÿÿÿÿÿÿÿåݨ½§»¤ØÊyüüøÿÿÿÿÿÿÒÃgÀ«'åܦÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿù÷ëȵB»¤ØËzûúóÿÿÿÿÿÿé⵺£Á¬*éâ¶ÿÿÿïêʵœ¹¡¹¢Á­,ƵH„ˆiA¸=Õ>aØ÷öïÿÿÿÿÿÿÿÿÿþþþÿÿÿÿþÿëú÷ªùã±üæáþöýþþÿþÿþÿÿþþþÿÿÿÿÿÿþþþÿÿÿýýüúøÆúõwûúµýýÿÿÿÿþþþÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿúùðÒÃgŲ:ξYȶDÕÇoûùòÿÿÿÿÿÿúøïÒÂdÆ´>˹MŲ:èà°ÿÿÿÿÿÿÿÿÿÿÿÿÏ¿\İ6þýüÿÿÿÿÿÿç߯®/ϾZá×™ÿÿÿÿÿÿÏ¿\İ6þýüÿÿÿÿÿÿç߯®/ϾZá×™ÿÿÿÿÿÿûúóÔÆmÉ·GÏ¿\ȶDÇ´@âÙžýýûÿÿÿúùðÒÃgŲ:ξYȶDÕÇoûùòÿÿÿùøíÉ·HξYÔÆmüûöÿÿÿÿÿÿÿÿÿæÞªÀ«'νWäÛ£ÿÿÿÿÿÿÏ¿\İ6þýüÿÿÿÿÿÿç߯®/ϾZá×™ÿÿÿÿÿÿñíÑÇ´?ÏÀ]Ì»Rµœ»¥þþþÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿþþþÿÿÿüùüÚâÛLÆr¾@ÁBÂCÂAAÏqÏñÛÿÿÿûûýñèÛîÁyñ›ó˜ò™ñšñ¦òËøöëþÿÿÿÿÿÿÿÿÀÞȶŸƳ>¾¨ öòàÿÿÿðë̵µœØË{íçÂØËzýýúÿÿÿêã¹µœ½¦ÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿ×ÊwµœµœÈ¶DǵAñíÑÿÿÿÉ·Gµœ¸  ÐÁ`ãÚ¡øö赜µœîéÇÿÿÿóõüb|ÁwyHena8[Ñôóîÿÿÿÿÿÿÿÿÿÿÿÿþþþÿÿÿÿÿÿúüû·úæ£ûâÓýñüþýÿÿÿÿÿÿþþþÿÿþÿÿÿþþýùøÂüö|ûú¼ýþÿÿÿÿþþþÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÏÀ]µùøíÿÿÿþþýáךξYÿÿÿÿÿÿÏÀ]¸  üûõÿÿÿêã¹µœÚ΂ÿÿÿÿÿÿÿÿÿÏ¿[µœïêÊÿÿÿÿÿÿı7µœóïÖʸIîèÅÿÿÿÏ¿[µœïêÊÿÿÿÿÿÿı7µœóïÖʸIîèÅÿÿÿÓÄhµœù÷ëÿÿÿÿÿÿñíÒ­.ÔÅkÿÿÿÏÀ]µùøíÿÿÿþþýáךξYÿÿÿãÙŸµœúùðæÞ¬Í¼Sÿÿÿÿÿÿÿÿÿİ5µœôðÚÆ³=îèÆÿÿÿÏ¿[µœïêÊÿÿÿÿÿÿı7µœóïÖʸIîèÅÿÿÿİ5ØËzÿÿÿöóỤµœõñÝÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿþþþÿÿÿýúüÞåáZÈz½B¾>ÁBÁ?0Íd»ëÉôßÅð´Yò”óšòžñžï¯4ôݪûþÿþÿÿÿþþþþþÿÿÿÀìöÃÂrûýþòîÔÉ·Gýüù˺OµœÍ½Uÿÿÿÿÿÿøöéêäºÿÿÿþþý½¦µœñìÏÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿʹKµœÊ¸JÿÿÿûúóÏÀ]óïÖÉ·HµœÏ¾Zÿÿÿåܦ÷ôåØÊyµœÝÒÿÿÿóõüZ}á9ÕrtLˆ:îîçÿÿÿþþþÿÿÿÿÿÿÿÿÿþþþþÿþÿÿÿÿýÿËúì ûàÂýìöþüÿþÿÿÿÿÿÿÿýýúûù½ú÷…üúÊþþÿÿÿÿþþþÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿ¹¡»¤ÿÿÿÿÿÿÿÿÿÿÿÿûúôÿÿÿÿÿÿ¹¢»¥ÿÿÿÿÿÿÿÿÿÑÁaµœîéÇÿÿÿÿÿÿá×™µœÝÑŠÿÿÿÿÿÿÔÆnµœÝÒŒêã¹ÓÅjÿÿÿá×™µœÝÑŠÿÿÿÿÿÿÔÆnµœÝÒŒêã¹ÓÅjÿÿÿ»¤¼¥ÿÿÿÿÿÿÿÿÿÿÿÿüû÷úùñÿÿÿ¹¡»¤ÿÿÿÿÿÿÿÿÿÿÿÿûúôÿÿÿéá´µœëå½ÿÿÿ˺OòíÓÿÿÿÿÿÿÓÅjµœÜЈêã¹ÒÃeÿÿÿá×™µœÝÑŠÿÿÿÿÿÿÔÆnµœÝÒŒêã¹ÓÅjýýûµÖÉuÿÿÿÿÿÿÚεœäÚ¢ÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿþþþÿÿÿýûüèèæjˇ¼D¼<¿AÀ? ÄP¡¹Rï“öšò›ï  ï¿]öêÍýÿÿÿÿÿÿþþþþþÿÿÿÿÿÿ¾ïüÐçÛûýþÿÿÿðëÍÖÈrµµœóïÖÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÔÅkµœØÊyÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿξYµœÓÄiÿÿÿÿÿÿüû÷ξXÒÃgµœÍ¼Tÿÿÿÿÿÿÿÿÿöô㵜Á¬+ÿÿÿóöü\â1Ó 7Ç­— ̽bÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿþþþÿÿÿÿþÿßûò úß±üæìþùýþÿûûõúø²ùøŠûúØþþÿÿÿÿþþþÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿ¼¦µœúøîÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿ»¥µœúùñÿÿÿÿÿÿèà±µœËºNÿÿÿÿÿÿóïØµœÊ¸JÿÿÿÿÿÿñìеœÄ°6ÿÿÿÿÿÿÿÿÿóïØµœÊ¸JÿÿÿÿÿÿñìеœÄ°6ÿÿÿÿÿÿÿÿÿº¢µœûúôÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿ¼¦µœúøîÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿøõ絜ÙÌ~ÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿïéȵœÀ«(þþþÿÿÿÿÿÿóïØµœÊ¸JÿÿÿÿÿÿñìеœÄ°6ÿÿÿÿÿÿþþþ¹¡˹Lÿÿÿÿÿÿìå¾µœÒÃgÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿþþþÿÿÿþýþîìí€Ï–½L»9½@¾>¼6‹«åŸù¦ñÊ{÷óãþÿÿÿÿÿþþþÿÿÿÿÿÿÿÿÿÿÿÿ¾îüÕóúûýþÿÿÿÿÿÿÕÇoµœÅ±8ÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿê亵œ½¦þýüÿÿÿÿÿÿÿÿÿÿÿÿÚεœÍ½VÿÿÿÿÿÿÿÿÿõñÝ­.µœÀª&ÿÿÿÿÿÿÿÿÿÿÿÿʸIµœìæÀóöýZ}â2Ó2Ó~UµœðëÎÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿþþþþÿÿÿÿÿìû÷©úá¥üçëüêû÷©üú”úûáýþÿÿÿÿþþþÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿ˺Oµœç߯ÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿ˹Lµœèá³ÿÿÿÿÿÿúù𵜼¦ÿÿÿÿÿÿþþþ»¤¹¡ýýûÿÿÿÿÿÿÀ«)µœù÷ìÿÿÿÿÿÿþþþ»¤¹¡ýýûÿÿÿÿÿÿÀ«)µœù÷ìÿÿÿÿÿÿȵBµœµœµ»¤Ç´?ãÚ¡ýýûÿÿÿ˺Oµœç߯ÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿ½¦Ç´@ÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿþþþÀ«'µœïêÉÿÿÿÿÿÿþþþ»¤¹¡ýýûÿÿÿÿÿÿÀ«)µœù÷ìÿÿÿÿÿÿÇ´?º¢þýüÿÿÿûúô¶Á­,ÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿþþþÿÿÿÿÿÿÿþÿñïõ”Ö¯*Á]¹4½?¿A ¿?pµ1ÕÌ~ÿüÿÿÿÿÿÿþþþþÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿ¾îüÖòúûýþÿÿÿÿÿÿÒÃfµœØËzÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿüûõ¶µœæÝ©ÿÿÿÿÿÿÿÿÿÿÿÿðë̵œ¿©#ÿÿÿÿÿÿÿÿÿÿÿÿ×Évµœµœúùñÿÿÿÿÿÿÿÿÿèà°µœÉ·Fóöý\~â2Ó2Ó^mˆµœÓÅjÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿþþþþÿþÿÿÿøûÿ¼ùÏáù™×ù™ýüìÿþÿÿÿÿþþþÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿïê˵œÏÀ]ÿÿÿÿÿÿÆ´>àÖ–ÿÿÿÿÿÿîèÆµœÑÁaÿÿÿÿÿÿÿÿÿ»¤º¢ÿÿÿÐÀ_îéÇͽUµœèà°ÿÿÿÿÿÿÒÃfµœêã¸ÿÿÿÐÀ_îéÇͽUµœèà°ÿÿÿÿÿÿÒÃfµœêã¸ÿÿÿÿÿÿç߯µœÛÏ„÷ôåíèÄÌ»RµœÔÆnÿÿÿïê˵œÏÀ]ÿÿÿÿÿÿÆ´>àÖ–ÿÿÿÿÿÿÌ»P·ŸüüøÿÿÿÿÿÿÿÿÿÒÂdæÞ¬ÜЇµœÓÅjÿÿÿÐÀ_îéÇͽUµœèà°ÿÿÿÿÿÿÒÃfµœêã¸ÿÿÿÿÿÿçß­µœíæÁÿÿÿÿÿÿİ6µœúøïÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿþþþÿÿÿúýÿñç×ëÀy«ÍžAÅq¸4»<½?ÁIPÑ|ÅîÔÿÿÿÿÿÿþÿþþþþÿÿÿÿÿÿÿÿÿÿÿÿ¾îü×óúûýþÿÿÿÿÿÿİ6µœÆ³=ûúóÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿı7µœÃ¯1üüøÿÿÿÿÿÿÿÿÿÿÿÿÆ´>µœñíÑÿÿÿÿÿÿÿÿÿ÷ôä¶µœìå¾ÿÿÿÿÿÿÿÿÿþýü½¨µœáܵ[~â2Ó2ÓPeµœÀ«)ÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿþþþÿÿÿýýÿüúÕÿùžðø­˜úÔÀýìþÿÿÿÿÿþþþÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÝÑŠ¶žìæÀÿÿÿŲ:ı7ÿÿÿÿÿÿÿÿÿÚ΂µœêã¹ÿÿÿûúô¸  ÐÀ_ÿÿÿæÝ©ÕÇqÜЈµœÀ«'öòàÿÿÿÞÓŽµœèá³ÿÿÿæÝ©ÕÇqÜЈµœÀ«'öòàÿÿÿÞÓŽµœèá³ÿÿÿÿÿÿÿÿÿÓÅj¹¢òîÕÿÿÿøö鵜Ƴ<ÿÿÿÿÿÿÝÑŠ¶žìæÀÿÿÿŲ:ı7ÿÿÿÿÿÿÛÏ„µœíçÂÿÿÿÿÿÿÿÿÿîèÅı7ôðÚµœÄ°6ÿÿÿæÝ©ÕÇqÜЈµœÀ«'öòàÿÿÿÞÓŽµœèá³ÿÿÿÿÿÿþþýÌ»RÇ´@ýýúþþþÆ´>µœêã¸ÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿþþþÿÿÿÿÿÿùüÿîàÆí²Eò›î²KÄÊ—ZÈ€·7º9¼=½=4Éc¨ç½ýýþÿÿÿþÿþþþþÿÿÿÿÿÿÿÿÿÀîüÖòúûýþÿÿÿÿÿÿ½¦µœíçÃÔÅlÿÿÿÿÿÿÿÿÿêã·ÿÿÿÿÿÿÿÿÿÒÃgµœË¹MÒÃeþþþÿÿÿöôãÿÿÿñìÏ·žÏ¿\ÿÿÿÿÿÿÿÿÿÿÿÿϾZµœÛІÿÿÿÿÿÿÿÿÿÿÿÿÜЈµœÀ­0_Ï2Ó2ÓRg›µœ¹¢ÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿþþþÿÿþÿÿÿýýÿûùÅù÷œûûÃüüùÎúíú×®þäûþýÿÿÿþþþÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿêã¸ÈµBÌ»R˹LæÞ¬ÿÿÿÿÿÿÿÿÿÿÿÿç߯Ʋ;˺NÆ´>ÒÃfúùðÿÿÿýýúÒÂdƳ<ÏÀ]õòÞÏÀ]Ï¿\­-ÒÂdýýûÿÿÿýýúÒÂdƳ<ÏÀ]õòÞÏÀ]Ï¿\­-ÒÂdýýûÿÿÿÿÿÿÿÿÿÿÿÿç߭˺OÑÂcƳ<ǵAðëÎÿÿÿÿÿÿÿÿÿêã¸ÈµBÌ»R˹LæÞ¬ÿÿÿǵAµœµœµœµœñìÏÿÿÿÿÿÿäۣξXÀ«'æÞ«ÿÿÿýýúÒÂdƳ<ÏÀ]õòÞÏÀ]Ï¿\­-ÒÂdýýûÿÿÿÿÿÿÿÿÿýýû×ÉvÇ´?Ì»QÒÃe½§ñìÐÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿþþþÿÿÿÿÿÿùýÿïÛ´í¬7òšóŸóžð¯5ÕÚ¿vË‘¹A·5»=»:ÃR„Ý ëøðÿÿÿÿÿÿþÿþþþþÿÿÿÀîüÕòúûýþßÕ“ÿÿÿ·Ÿ ¶þýüåݨÒÃeúùðÿÿÿÓÄiøõççß®þþýßÔ’µœÑÂb˺OÆ´>ÛÏ…¾©"ïêËÿÿÿäÛ¤¶èá²ÿÿÿÿÿÿÿÿÿêã¹µœÊ¹Kÿÿÿÿÿÿÿÿÿÿÿÿùøí·Ÿ ı=ŽŽ[:Á2Ó|}Zµœ¾¨!þþþÿÿÿÿÿÿÿÿÿÿÿÿþþþÿÿþþþÿüü÷úûµùø¢ûúÔþýþÿÿÿÿýÿ×úïùÖ¢þßùþüÿÿÿÿþþþÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿù÷뵜˹Lÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿþþþÿÿÿÿÿÿ÷üÿîÔ¡ï¬0óó ô¡ó£ò΂ùóêêíì“Ѥ*¼T¶/º<º: ¿F\Ò€ÑðÛÿÿÿÿÿÿþÿþÿÿÿÁïýÔñûûýþñíÒÒÃfµœÂ­.ÿÿÿÿÿÿÞÓ¸  ­.¶èá³öòàØÊyÐÀ^µœËºOù÷뽨µœµœØÊyÿÿÿÿÿÿêã¸Àª&ßÔ’ýüùþþþãÚ µœ¹¢þþþÿÿÿÿÿÿëå½ûùòÐÀ^µœf±yyE…+µœµœÖÈsÿÿÿÿÿÿÿÿÿÿÿÿþþþÿÿÿþþÿûúçù÷§úú¯úúäýýÿÿÿÿþÿþÿÿÿÿþÿáúóùÖ—þÜõþûÿÿÿþÿÿþþþÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿï1¸  ýýúÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÔÅk¹¢áךÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿþþþÿÿÿÿÿÿ÷ûÿïЖï¨óŸô¤ õ£ò§ óÙ˜úùòÿÿÿÿýþóòó³Ù¾JÂj´1¸8¹:»>5Çc­ç¾ÿýþÿÿÿÿÿÿÅðýÔòûúýþÿÿÿðëÎÌ»RæÞ«ÿÿÿÿÿÿÿÿÿìæ¿Í½VÑÁaüûõÿÿÿûúôÜЇ˹Lèà°ÿÿÿøõçÓÅjʹKðëÍÿÿÿÿÿÿÿÿÿüûõäÛ¤ÑÂb˹LÉ·Gİ5µœñìÏÿÿÿÿÿÿýýúÝÒÉ·Hµœ„‰h3ÓBY…Œ†AÐÁgüû÷ÿÿÿÿÿÿþþþÿÿþÿÿÿýýÿúúÕùø£úù¾ýýñþþÿþþÿÿÿþþþþþþþÿÿÿÿþÿçûõ“øÕý×îýùÿþÿÿÿÿþþþÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿãÚ¡º£øöèÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿ¼¦µœ¼¥þþþÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿþþþÿÿþÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿöùýï͈ñ§ó¡ó¢õ£ó«ôß©ûûøÿÿÿÿÿÿÿÿÿÿþÿø÷øÐãÕmÈ… ¶9¶2¸:¹:ÁP{Ù—ë÷ïÿÿÿËòþÓòúùýþÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿê亵œÝÑ‹ÿÿÿÿÿÿÿÿÿÿÿÿéâ¶Ä²A€†j3Ô2Ò2WÕøõîÿÿÿÿÿÿþþþÿÿþþþÿüýýúú¿ùù¤ûûÒýýùþþÿÿÿÿÿÿþþþþÿÿÿÿÿÿþþþÿÿÿÿþÿéúô”÷ÔƒýÕêýùÿþÿÿÿÿþþþÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿîéÇǵAØÊyÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿþþþÿþþÿÿÿþÿÿúþÿùðÕûì»úìÄúùïüÿÿðãÂî¥ó¡ô£õ¤ò©õå¹ýþýþÿÿÿÿÿþþþþþþÿÿÿÿÿÿüúüäëæ•Ñ¤%¹M³/¹@¹< ¼CDÌoÎðÓÏòÿÒòûùýýÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿþýü¼¥É·Fÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿñóü?gÞ3Ô2Ò5YÔüøîÿÿÿÿÿþÿÿÿþþÿüûíùø¬ûû°üüãýýüÿÿÿÿÿÿþþþÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿþþþÿÿÿÿþÿêúõ’øÕ„üÔæüöÿþÿÿÿÿþþþÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿþþþÿþþÿÿÿûýüéРâ¬>é®!ò·í²!ä¨'â¶eñéÖôÚ¡ñ¦ ô¤õ¬õæ¼ýþþÿÿÿÿÿþþþþÿÿÿÿÿÿþþþÿÿÿÿÿÿÿýþðòñºÛÂOÂmµ4¶6¸9º;$ÃRhÕ¦ÊîõýþÿÿÿÿÿÿþþþþÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿØÊy·žûúóþþþÿÿÿÿÿÿÿÿÿðóü7dß4Ô3Ó=]ÖÿüðÿÿÿþþÿýýÿúûØùù¢úûÅýþôþþÿþþÿÿÿþþþþÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿþþþÿÿÿÿþÿêûõöÒzüÏæüõÿþÿÿÿþþÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿþþþÿÿÿ÷õòÙ°sÌ„Õ‹à—æžã›ÛÑŠËŠ+çÝÇñÙ˜ð®öèÁýþýÿÿÿþþþÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿþþþÿÿÿÿÿÿÿþÿøøøÚæÝyʵ=´0·8¸8»BEÊr×ñßÿþÿÿÿÿÿÿÿþþþÿÿÿÿÿÿþþþÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿõòÞµœæÞ«ÿÿÿÿÿÿÿÿÿÿÿÿïòü-[Ý4Ô4ÓGdÖÿüñÿÿÿüüùùù¾ùú¤úûÜýýûþÿÿÿÿÿÿÿþþþþÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿþþçûô€øÌ{üÏêüøÿÿÿþþþÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿüþÿÕ°…»nÅuÌ~Óˆ×Ö‹χ Èz¿lºw(îëâöïÒþþýÿÿÿþþþÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿþþþþþþÿÿÿþþþüûüìïí®×·4»V²/¶5·7¹<ÀO”ß«úüüÿÿÿÿÿÿÿÿÿþþþÿÿÿþþþÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿ˺NϾZÿÿÿÿÿÿÿÿÿÿÿÿïòü,WÝ4Ô6ÓRkØþûôþüëúù¨úû·ýýðþþýþþÿÿÿþþþþÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿþþþþÿÿÿÿÿþþþàùðuøÈ~ýÏïýùÿÿÿþþþÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿþþþÿÿÿçÒÁ·r-²]¼m ËzÝ…âŒÞŽ Ó¿m¶c¬WË£~ýüûÿÿÿþþþÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿþÿþþþþÿÿÿöõõ×ãØgÇ´7´3¶8·9 ¼@HËoØñáÿþÿÿÿÿÿÿÿÿÿÿþþþþþþÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿîéȸ  üûõÿÿÿÿÿÿÿÿÿíñü LÚ <Õ7Ò\s×üøËûú¡úúÕýýúÿÿÿþþÿÿÿþþþþÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿþþþÿÿÿÿÿÿþþþØøìfù„þÑöþüÿÿÿþþþÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿЪŒŸF¯XÖ‚î  òŸð¡ ïŸðè•»f§O§Z úø÷þÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿþþþÿÿÿÿÿÿÿÿÿÿÿÿüüüííí¥Õ±(¸N²1¶6·8¸:½FݤûûûÿÿÿÿÿÿþþþþþþþþþÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿþþþÿÿÿȶDåܦÿÿÿþþþÿÿÿìðû =Ö9ÔAÔa|ÖþúÞýýíýýüÿÿÿÿÿÿÿÿþþþþÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿþþþÿÿÿÿÿÿüýýË÷çZú¼üÒûýýÿÿÿþþþÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿù÷÷Àkš=Ò‚õ¬ô­ô²ó¯ó­ô®ó¬î¦®U—:ïèâþþþÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿþþþÿÿÿÿÿÿÿþÿóôöÚäÜbÆ| ³6³3¶6·8¹;EËnÌðØÿþÿÿÿÿÿÿÿþþþþþþÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿüüüýýýÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿþþþÿÿÿÿÿÿìæ¿Ç´@þþþÿÿÿÿÿÿèìù4Ö7ÔCÕz‘Ýüúòÿÿÿþþÿÿÿÿþþþÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿþþþÿÿÿÿÿÿøýû²öÜQûºšûØÿþÿÿÿÿþþþÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿöôó¸‚f°Yêª÷¼ô½ ö½ö¾ õ¼ö»õºø¼Ðˆ”4çàÙþþþÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿþþþÿÿÿÿÿÿÿÿÿÿÿÿþþþÿÿÿþþþÿÿÿÿÿÿÿÿÿñùù×èï¦Õ´(¸L³2´6 ¸=º=¾GpÕŒîøñüýþÿÿÿþþþþþþþþþÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿþþþþþþþþþþþþþþþÿÿÿÿÿÿÿÿÿþþþþþþÿÿÿÿÿÿÿÿÿÿÿÿƲ;óï×ÿÿÿýýýÔßî1Ö:ÕEÕ{ŽÛþüôÿÿÿÿÿÿþþþÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿþþþÿÿÿÿÿÿÿÿÿþþþÿÿÿÿÿÿþþþÿÿÿÿþÿïûö”öÏRüº­ýßÿýÿÿÿÿþþþÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿûþþ¹†u¼kùÈøÉ÷ÉøËùËøÍ ÷ÊøÉùÉè°”7ôòðþþþÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿþþþûûûûûûýýýÿÿÿÿÿÿþþþÿÿÿÿÿÿÿÿÿõýüªæûåñöãçãmÉ„¶Aµ:´5¶7¹B¾LŸá³üüüþÿþÿþÿÿÿÿÿÿÿþþþÿÿÿÿÿÿþþþÿÿÿÿÿÿÿÿÿÿÿÿþþþÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿþþþÿÿÿÿÿÿìæÁÑÂdüüù÷øÍÄÑž2Û9Õ?Õ‹™Þþüõÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿüüüúúúýýýÿÿÿÿÿÿþþþÿÿÿþþþÿÿÿÿþÿßúïj÷¾_û¾ÄüçÿþÿÿÿÿþþþÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿþþþÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÊ¥ Á€ùÒú×úÙúÙúÚüÚùÛ ù×ú×嵩hCüúùÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿýýýúúúúúúûûûþþþÿÿÿÿÿÿþþþÿÿÿÿÿþÿÿÿ¥æúéøýþýýõðõ¿ÝÆ4»W ²8³4µ5¹A·9=ÈgÌïÖùüüÿÿþÿÿÿÿÿÿÿÿÿþþþÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿþþþÿÿÿÿÿÿþþÿþþÿüüúÏ¿Xñîùù¶´Ãë3Ö6ÔCÔ•¥ßþý÷ÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿûûûúúúúúúýýýÿÿÿÿÿÿþþþÿÿÿþþþÿÿÿÿýþÅøäLú³qûÄßüòÿÿÿÿÿÿþþþÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿþþþÿÿÿÿÿÿþþþþþþþþþþþþþþþÿÿÿÿÿÿéÝàÇTåÁþèüçüèüèüèýèúç ýåÇŒ ×Á´ýýýÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿþþþûûûûûûûûûüüüýýýÿÿÿÿÿÿþþþþþÿÿÿÿ¤åùè÷üÿÿÿÿÿÿù÷ùïëîŠÏ›´A²6´4·@·6¸;eÒ†àôæùüúÿÿÿÿÿÿÿÿÿÿÿÿþþþÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿþþþÿÿÿÿÿÿþþþþþÿýýüúûôø÷¼óòŽÓÅcúûÿ ´ë3Ö6ÔFÔ¤²àÿýøÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿüüüûûûûûûûûûüüüÿÿÿÿÿÿþþþÿÿÿþþþÿÿÿôûùžõÑBú¯ŒûÏõüúÿÿÿÿÿÿþþþÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿòíÓʸIϾZÌ»Q­.ÜЇüûõÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÝÑŠÀ«)ÏÀ]ÐÁ`æÞªÀ«'Ì»Rëä¼ÿÿÿïêÉÉ·HÏÀ]Ï¿\˹MÔÆnóïÖÿÿÿùøíÉ·HξYÔÆmüûöÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿþþþþþþþþþüüüüüüüüüýýýÿÿÿþþþýÿÿк®Ð¯/ùêýôþöþöþ÷þõûñëØÀ—vö÷÷þÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿþþþÿÿÿÿÿÿþþþúúú÷÷÷úúúþþþÿÿÿÿÿÿþþþÿÿÿ£åúæöûÿÿþÿÿÿþþþþþþ÷óö×äÚYÄu´:³3 ·=·8·3½GŠÛ¡æöí÷ýúÿÿÿÿþÿÿÿÿÿÿÿþþþÿÿÿÿÿÿÿÿÿÿÿÿþþþÿÿÿþþþþþÿüüûúúö÷ößøø¢ùúÌþýÿÝÒëæÇ‰¤ê4Ö5ÔIÔ¶¿âÿþúÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿþþþÿÿÿÿÿÿüüü÷÷÷ùùùýýýþþþÿÿÿþþþÿÿÿÿÿÿÿþÿÛøìjö¼Eû°¦ûÚÿýÿÿÿÿþÿþÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿƳ=¶Û΃ÿÿÿØÌ|µœÆ³<ýýûÿÿÿÿÿÿÿÿÿñìеœ×ÉvÿÿÿóïÖ¶ž¶žù÷ì®0þþþƲ;ξYÿÿÿÿÿÿþþþßÕ“·Ÿ ïéÈãÙŸµœúùðæÞ¬Í¼Sÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿþþþýýýüüüþþþüüüýýýýýýüýþ÷öññØ‘õã¤ØÇ¸Ö½@óëù÷ú÷ùöùõ æÕÌ«{øøøÿÿÿÿÿÿþþþÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿþþþÿÿÿýýýûûûúúúúúúýýýÿÿÿÿÿÿÿÿÿªæüáôúþþþÿÿÿÿÿÿÿÿÿÿÿÿýüýõðõ¶Û¾8¼[´< ¶;µ6¶7µ4&ÂUŸâ´é÷ïúüûÿÿÿÿÿÿþÿþþþþÿÿÿÿÿþþþÿÿÿÿþþÿýýþúúöûûêøù»úùÊýüùúûÿûûûûûøË¼Vu“Þ5Ö5Ô!LÔÇÎãÿÿýÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿþþþÿÿÿûûûûûûúúúüüüÿÿÿÿÿÿþþþþþþÿÿÿÿüþ²÷Ú<úª_ú¹Ìûèÿþÿÿÿÿþþþÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿ×Êxµœ¾©"ÿÿÿûúô»¤µœåݨÿÿÿÿÿÿÿÿÿë仵œÑÂbÿÿÿÿÿÿÌ»PµœòíÓÌ»PóïרÌ|¾©"ÿÿÿÿÿÿÿÿÿôñܵœËºOéá´µœëå½ÿÿÿ˺OòíÓÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿþþþüüüþþþúúúüüüüüüüüüúûþôæ¿ô¿2ó¸öâ”éàÔ×ÁšÙ¿YßÅ=ÛÃMÔºxãÕÓûþÿÿÿÿÿÿÿþþþÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿþþþÿÿÿþþþûûûùùùüüüþþþþþþÿÿÿ³éüÕñùüýþÿÿÿÿÿÿÿÿÿþþþÿÿÿÿÿÿû÷úðìï‘Ñ *¸M¶@´3¶5µ5¶6;Çe®æ¾ë÷ïüýüÿÿÿÿÿÿþÿþÿÿþÿÿÿþþÿüüõùúëúùÑøø´ùûãúûþüüüýüüûûûýýýéæÍ]7Ö5Ô#OÔØÜåÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿüüüúúúúúúýýýþþþÿÿÿþþþþþþÿÿÿäûñuö¿/û£‚úÈîüøÿÿÿþÿþÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿöôãûúôÿÿÿÿÿÿÐÁ`µœÏÀ]ÿÿÿÿÿÿÿÿÿøö赜Á¬*ÿÿÿÿÿÿÝÒµœàÕ•ÿÿÿÿÿÿÿÿÿýýûóï×ÜЇɷG¸  µœÍ¼Søõ絜ÙÌ~ÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿþþþüüüûûûüüüüüüûûûüýÿ÷òáóÑqö½!ø¹ ù¶õË;øñÏüÿÿþÿÿýÿÿþÿÿÿÿÿÿÿÿÿþþþþþÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿþþþÿÿÿþþþûûûúúúûûûýýýÿÿÿ¿îüÌîúùýþÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿþþþúõúàèáẗ+ºO µ8³2µ6¶4¸9KËqµèÄéøîþþþÿÿÿÿÿÿþþùüûêøøÄùùµúûÞûúýüüÿûûûýýýûûûüüüýýüóõûs€Zik4Ô(RÔíìéÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿþþþÿÿÿÿÿÿýýýúúúúúúüüüþþþÿÿÿÿÿÿÿÿÿÿüÿ®øØ:ú¦?úª°üÜÿþÿÿÿÿþþþÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿåܦµœ¼¥þþþÿÿÿÿÿÿÿÿÿï2µœñíÑÿÿÿïêʵœÎ½Wÿÿÿÿÿÿÿÿÿêã¹µµœµœ¸¡ ÑÂbúùðÿÿÿ½¦Ç´@ÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿþþþüüüûûûüüüüüüýýýúûüòá¨ñÂ5öÁ,ù½ûºôÆ+øîÈÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿþþþÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿþþþÿÿÿüüüúúúúúúûûûÿÿþÌðýÁëù÷üþÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿþþþÿÿÿÿÿÿÿÿÿÿýþøôöÍäÑgÈ€¹G´5´3¶7¶3º:RÐy´éÅç÷ëýýíýúÑùù©úûÅüüöüüþüüüüüüüüüýýýüüüýýýüüûòôû&VÜouRipX8\Ñü÷íÿÿÿþþþÿÿÿþþþýýúÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿþþþÿÿÿþþþúúúúúúúúúýýýÿÿÿÿÿÿþþþÿÿÿÛúìeöµ)ûžjû¼Þýðÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿøö굜µœòíÓÿÿÿÓÄiêã¹ÜщµœÕÇqÿÿÿýýû¸  ¼¥þþþÿÿÿÿÿÿØÌ|¶áØ›ôñÜþþýÕÇoç߯ÿÿÿÌ»P·Ÿüüøÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿþþþüüüüüüüüüýýýûüÿ÷òÝòÎ[öÂ)÷Ç4ù½ù½ô߉ûýúÿÿÿþþþÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿþþþþþþýýýûûûÿþýÙòý¶çúôûþÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿþþþÿÿÿÿÿÿÿÿÿÿûþ÷ñöºßÂTÄr·E³4´3¶6µ3¹=UÏv®æ„ßó¦üýòÿþÿýýþüüüûûûýýýüüüüüüýýýüüüüüüîñú @Ù;Ò}@¤”"äÚ ýýûÿÿÿÿÿÿíæÁßÕ“ÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿþþþþþþýýýüüüûûûþþþþþþÿÿÿÿÿÿüúû÷É+ù1ú¡£üÖüþþÿÿÿþþþÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿï2µœÝÒÿÿÿíèÄʸIóïÖµœÅ±8ÿÿÿÿÿÿȶDµœôñÛÿÿÿÿÿÿóïÖº£öóáÿÿÿÿÿÿï3ı7ÿÿÿÛÏ„µœíçÂÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿþþþüüüýýýüüüüüüúúúòà£óÂ'øÊ>øÅ!ü¾÷Ì0øðËþÿÿÿÿþÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿþþþÿÿÿÿÿÿýýýûûûýûûåõúªãúñúþÿÿÿþþþÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿþþþÿÿÿÿÿÿÿÿÿÿúÿõñó©Û¶OÂp·F²1´3¶7µ2¹@OÎ{¤å»ÙóàûûûÿþÿþýýüüüûûûûûûüüüûûûüüüÚãô5×:× =Ï™’Kµœ¸¡ Ƴ<É·G¹¡ÐÀ_ÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿþþþÿÿÿÿÿÿþþþüüüúúúûûûýýýÿÿÿÿÿÿÿýÿ³øÙ<ø¢'ú›aù·Üýïÿÿÿþÿþÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿ×ÊxµœÉ·HÿÿÿÿÿÿáיϿ[®0èà±ÿÿÿÿÿÿê㸻¤õòÞÿÿÿÿÿÿÿÿÿïêÉÏ¿[ÓÄhÒÃe˺Oêã¹ÇµAµœµœµœµœñìÏÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿþþþýýýýýýýýýýýÿøõæóØ|ùÌ>ùÉ-úÂüÁùÜqüûôÿÿÿþþþÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿþþþÿÿÿýýýûúúôøù£ß÷îøýÿÿÿÿÿÿþþþÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿþþþþþþÿÿÿÿÿÿÿþÿÿùÿìíÙ¡ØQÃq·F³2µ4·9¶4¹:CËm”à¬ËïÕøûùÿþÿÿüþüüüüüüýýýûûüºÊï6Ù:× ?Ô}”ÜÞÒ¸  µœµœµœØËzÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿþþþÿÿÿþþþûûûúúúûûûýýýþþþÿÿÿÎùæR÷«%ú™,ù°ûÛÿþÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿìå¾µœ·Ÿ üüøÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿù÷뵜˹Lÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿþþþÿÿÿÿÿÿþþþýýýüýÿ÷ìÄ÷Ì8ûÅúÂûÄùÈ úé¤þÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿüüüúúúÿüùŸÞöéõùþþýÿÿÿÿÿÿþþþÿÿÿÿÿÿÿÿÿÿÿÿþþþÿÿÿÿÿÿÿÿÿþþÿüýýûüâúûÈûúÀÿùàëðï¡Ù¯UÅs¹H´2µ3·9¸5¹55ÈaÛ»êÉìøðÿþÿÿýÿýýýüýþ™°ë8Ù:×CÕ˜¨Þþü÷ù÷ìÜЈͼSÐÁ`úøîÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿþþþúúúúúúúúúúúúýýýÿÿÿÞúî^÷°ù”ù”yùÀëýöÿÿÿþÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿüüø·Ÿ µœëä¼ÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿï1¸  ýýúÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿþþþÿÿÿÿÿÿÿÿÿûû÷ó݇û¾ýÃûÆüÅøÒ4úòÉÿÿÿþþþÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿúúúöööÿüúªâùâñ÷ûûûþþþÿÿÿÿÿÿþþþÿÿÿþþþÿÿÿÿÿÿÿÿÿþþÿüüûúúÚøø¿ùù·ûü»üýáÿÿÿÿþÿÿûÿêðë£Ú²^Èy"»K³1µ2¸9·6·2 ÄUgÕŠ£ä¹Ùòáÿÿÿÿýÿv”è:Ú:×GÕ´¾áÿþûÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿýýý÷÷÷øøøûûûúúúúúúÿýÿåúñdø²ù!ù“Eù¤ÓýêÿÿÿþþþÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿýýûÆ´>­.¶žµœ»¤νWÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿãÚ¡º£øöèÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿþþþÿÿÿû÷ãôÔTýÃüÇüÈþÈøÙOù÷ßÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿýýýúúúÿÿý³èûÒí÷÷øùûûúþþþþþþþþþÿÿÿÿÿÿÿÿÿþþÿüûõùøÏùø¸ùø¶ûú½üüãþþÿþþÿÿÿÿÿÿÿÿÿÿÿþÿÿûÿîñí­Þ¸j˃+½S³1´3¸9º:º6 ¿GLÏu†ß£·éËNzÜ4á7ÚIÕÐÕãÿÿþÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿþþþÿÿÿÿÿÿÿÿþþþÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿþþþûûûûûûþþþüüüúúúþúüÝøìZø¬úŒù‘ùºüÞÿþÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿûôÕõÎ/üÆüÈýÊÿÊøÞ]ùùëÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿþþþÿÿÿÿÿÿÿÿÿ»ëü½éùó÷ùûûúþþþÿÿÿÿÿÿýþÿüýÿûûèúúÁúù³øøºûûÄüüçþþÿþþÿÿÿÿÿÿÿþþþÿÿÿþþþÿÿÿÿÿÿÿþÿÿüÿñóñ¸áÃzÏ:Á`µ4µ3¹9º;º9¼;*Ç^œ~rQ¼(SØõìíÿÿÿÿÿÿÿÿÿÿÿÿþþþÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿþþþÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿþþþÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿþþþÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿüüüÿúýÆøß@÷œùˆøúŠœûÎúþüÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿüóÍöÌýÊþÌþÍÿÍøá^ùûìÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÐïü«ãùôúüþþþÿÿÿþþÿüüüøùÕúù±ùø¯ùû¹ýûÎþþòþþÿþþÿÿÿÿÿÿÿþþþÿÿÿÿÿÿÿÿÿÿÿÿþþþÿÿÿÿÿÿÿÿÿÿþÿÿüÿøöøÇæÐŽÔ¡OÅo ¸>µ2¹7»=¼;Â9»H dœƒ¢â³ÛöåÿþÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿþþþÿÿÿþþþþþþÿÿÿÿÿÿéøîÃóÕµòÎÆò×ðúóÿÿÿÿÿÿÿÿÿþþþÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿþþþÿÿÿÿþþÿüÿœùË÷†øˆ÷Žùˆ…ûÂòþøÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿüôÌ÷ÏÿËÿÏþÑþÐøßLùøÝÿÿÿþþþÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿþþþÿÿÿÿÿÿæõü–ÝüðûÿýýÿúúæøùÄúù¥øø¯ûúÁûüÚýþ÷þýÿÿÿÿÿÿÿÿÿÿþþþÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿþþþÿÿÿÿÿÿÿÿÿÿýÿÿùþ×ëۦݵlÌ„#¾Q´0·5»<¾=Ã<Å?"É[MÔ{gÚ ç¹Úôãÿþÿÿÿÿÿÿÿÿÿÿÿÿÿþÿþÿÿÿåóê‰Õ£KË|/Ðo%Ön3ÏpOË}’Öªöú÷ÿÿÿþþþÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿþþþÿÿÿÿÿÿØüéFø øøŠ÷ˆ÷‚ú¾ðþøÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿüõÑ÷Ô&ÿÏÿÒþÔÿÔùÛ$øó½þÿÿÿÿþÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿþþþÿÿÿÿÿÿþþÿÿÿÿøùÿªâðîõÉúù¢ùø¤ùú¼üûÎûüåþþþþþÿÿÿÿÿÿþþþþÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿþþþÿÿÿÿÿÿÿÿÿÿÿÿÿþÿÿüÿéñê»ãNjՠNËlº<·2»:¾@ ÁEÁDÄFÉT;Ðn^Ù‰Žä­ÇðÕùüúÿÿÿÿÿÿÔçÙZ·x ¥A­>¹F¿J¹G¬<¥Ib¸|ìõïÿÿÿþþþÿÿÿÿÿÿÿÿÿÿÿÿþþþÿÿÿÿÿÿÿÿÿÿÿÿáûî\÷¤ ÷| ÷‚ø„ø„ø|‰ùÃõýúÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿüøßøÝJÿÒþÔÿÖÿ×ü×ùé~ýýùÿÿÿÿþþþþþÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿþþþÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿþþÿýüÿûúõøøÍûø Ýï•ïöªúúÃüûÛþþóþþÿþþÿÿÿÿÿÿÿþþþÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿþþþÿÿÿÿÿÿÿÿÿÿþÿÿýÿø÷ø¦ÊÓ£Ö»ƒÜ1Ç[º8º7½> ÁFÂFÁ>ÄCÈQ-Ïg@Õt›è·ßîä^­t‹.—4¡;ª@­C©A¡:–3Œ0e®wÿþÿÿÿÿÿÿÿÿþÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿþýÿ·øÕHó˜ óyõz÷{ø|ø€÷|©úÒÿþÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿüýùøêýÔÿ×þØÿÙþÙûÝ'ùð±ýýÿÿÿÿÿÿþþþþÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿþþþÿÿÿÿÿÿÿÿÿÿÿÿÿþÿÿþÿúüÿùùïøöÇùöœú÷ˆù÷œÿü¼¸æÕÊìåúýüþþÿÿÿÿÿÿÿÿÿÿþþþÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿþþþÿÿÿÿÿÿþþÿT}å=häeÙ“½Ì¦ßµ^Í€ÀN¹2¾>ÀDÁAÃCÄCÄA˜êµ˜Á €.%Œ.ž4©8«8©95‰,( {)¼ÙÁÿþÿÿÿÿÿÿÿÿÿÿÿýÿÿþÿÖúå˜ôÀUñš"îîtñwòvôwöx÷v5ö’ÑüæÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿþÿÿúöÓøß:þØÿÛ þÛ þÝþÝýà0÷î¤ùúûþÿÿÿÿÿÿÿÿÿÿÿþÿþÿþÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿþþþþþÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿþÿÿýþÿüüÿùøú÷÷Øöõ¯ùõ‹ú÷ø÷”ùúµûúÕüüçÿÿø¾éÿ«âûøüÿÿÿÿÿÿÿþþþÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿøùû HÞ?ÝIÜBfÞòðéåóéÈèџܲ\Ï~ÂR½:¿:Á>%Ì^³æÃ_œlh„(¨;µB¸C¹C¸DµB©:|%n\›gõýú{ë§{î©hì¡Qé’<é†+ë~étéjêm ítîrïsñuóuôqŒøÀùýûÿÿÿþþþÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿþþþÿÿÿþþýùñ®ùÝ þÚýÝýÞþßþßûá)÷ådõï½øùûûþÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿþþÿÿÿÿÿÿÿÿÿÿýýÿûüÿ÷úÿø÷ï÷õÏöô®ùóŒûôrùõwù÷•ûú¸üüÙûüéýþöþþÿþþÿÿÿÿÕñûÙûôûþÿÿþÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÎÙïBß GÝ?ÚChÙöóìÿÿÿÿýÿùúúäóéÏëØ©âºeÒˆÃR=Ðm§×³C…Nl©DÃTÄUÄVÄUÄVÃUÃS®Ff%s0úÿý ßj ÜcÞdàcáaãcåeçi èoêkëníqîqïlbô¦åüðÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿþÿÿÿýýùøñµ÷â>ûÞþßÿßÿàþáþá&ûå7ùæOùê}öî§öòÆöõÞø÷èø÷óõ÷òøöìööáöóÖ÷óÇöó³÷òœùð‡ûònùódúódùó}û÷ŸüúÅúüâûýîýþøþþÿþþÿþþÿÿÿÿÿÿÿÿÿÿòûüwÐüî÷üÿÿþÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿ˜²í HßBÝBÚqŠÛúøòÿÿÿÿÿÿÿÿÿÿþÿÿþÿúûúéõí×îߨñáÁÚÆ>>???@@@AAACCCCCCyyyäääøøøäääyyyCCCAAA@@@>>><<<:::888555222000---***'''$$$"""  !!!###$$$&&&(((***+++---...//////000000000000000000/////////......---,,,++++++))))))((('''&&&%%%%%%$$$#########""""""""""""#########$$$%%%&&&'''((()))***+++---...///000222333444666666888999:::;;;<<<>>>???@@@BBBCCCEEEFFFGGGHHHIIIfffÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿfffHHHGGGEEECCC@@@>>>;;;888555222///,,,)))&&&###    """%%%''')))+++---///111222333444555666666666666666666555555555444444333222111000///...---,,,+++******)))((((((((('''''''''''''''((())))))+++,,,---...///000111222444555777888999;;;<<<===>>>???AAABBBCCCDDDEEEGGGHHHJJJKKKMMMNNNOOOPPP€€€äääÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿää䀀€OOOMMMKKKIIIGGGDDDAAA>>>;;;888444111...***'''$$$!!!  !!!$$$&&&)))+++...000222444666888999:::;;;<<<<<<<<<<<<<<<<<<;;;;;;;;;:::999888888777666444333222111000000///...---------,,,,,,,,,,,,------...///000111222333555666777999:::<<<===???@@@AAACCCDDDEEEFFFGGGHHHJJJKKKLLLNNNOOOPPPRRRSSSTTTVVVWWW€€€üüüÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿüüü€€€UUUTTTRRROOOMMMJJJGGGDDDAAA===:::666222///+++((($$$!!!  !!!$$$'''***---000222555888:::<<<>>>???@@@AAABBBBBBBBBBBBBBBBBBBBBAAAAAA@@@???>>>>>><<<;;;:::999888777666555444333333222222111111111222222333333444666777888999;;;<<<===???@@@BBBDDDEEEGGGHHHJJJKKKLLLMMMNNNOOOPPPRRRSSSTTTVVVWWWYYYZZZ[[[\\\]]]€€€ÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿ€€€\\\ZZZXXXVVVSSSPPPMMMJJJFFFCCC???;;;777333000,,,((($$$   !!!$$$(((+++...111444777:::===???AAACCCEEEFFFGGGHHHHHHHHHHHHHHHHHHHHHGGGGGGFFFEEEDDDCCCBBBAAA???>>>===<<<;;;:::999999888777777777777666777777888999:::;;;<<<>>>???AAABBBDDDEEEGGGHHHJJJLLLMMMOOOPPPQQQSSSTTTUUUVVVWWWYYYZZZ[[[\\\^^^___aaabbbcccddd€€€ÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿ€€€bbb```^^^\\\YYYVVVSSSOOOLLLHHHDDD@@@<<<888444000,,,(((###    $$$'''+++///<<>>======<<<<<<<<<<<<<<<<<<===>>>???AAABBBCCCEEEFFFHHHJJJKKKMMMOOOQQQRRRTTTUUUWWWXXXZZZ[[[\\\pkk‚ss||‚ttrnncccdddfffggghhhiiijjj€€€ÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿ€€€hhhfffdddbbb___\\\XXXUUUQQQMMMIIIEEE@@@<<<888333///+++'''###  """&&&***...===ww€77Æ ôïJJ°vv€QQQLLLNNNPPPRRRSSSSSSTTTYYYuu€PP«í õ22ËxxƒZZZQQQOOONNNMMMLLLozo\\äøä\\mymCCCBBBBBBAAAAAAAAAAAABBBBBBCCCDDDEEEFFFHHHIIIKKKLLL\\\igg{mm‚xxzzrrymmddd\\\^^^___```aaassž^^äøäž^^uujjjlllmmmnnnoooppp€€€ÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿ€€€nnnllljjjgggmmm‚‚‚nnn\\\FFF@@@<<<777333...***%%%!!!   $$$)))---111eeq88Åÿÿÿÿ..Ïww‚[[[SSSUUUWWWXXXYYY```ww‚55Çÿÿÿÿ00Îqq}VVVUUUTTTRRReje]]ÿÿÿÿÿ\\aeaGGGGGGGGGFFFFFFFFFGGGGGGHHHIIIJJJLLLMMMOOOXXX~rr“ffºBB×((ò ö ãÌ22‘kk‚vvllleeefffuppž^^ÿÿÿÿÿŸ^^zuurrrssstttuuuuuu€€€ÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿ€€€sssqqquuuƒƒƒ˜˜˜ÔÔÔëëëüüüøøøÞÞÞÄÄÄ›››PPP@@@;;;666111,,,((($$$  """'''+++///444ww€ óÿÿÿÿÿ##ÜxxƒcccZZZ\\\]]]fffyyƒ))Ôÿÿÿÿÿû}}[[[ZZZYYYWWWrräÿÿÿÿÿäq€qLLLLLLLLLKKKKKKKKKLLLLLLMMMNNNOOOQQQSSSjff„xxË22ÿÿÿÿÿÿÿÿÝ""ˆuuvrrlll„uuäÿÿÿÿÿä…wwwwwxxxyyyzzzzzz€€€ÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿ€€€xxx~~~ŒŒŒäääÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÓÓÓ………fff???999444///***&&&!!!  $$$)))---222666ww€ïÿÿÿÿÿÿåww†jjlaaakkkxx„àÿÿÿÿÿÿö{{‚```^^^]]]\\\~€~üÿÿÿÿÿü~€~QQQQQQPPPPPPPPPPPPQQQQQQRRRSSSTTTVVVlhh”ggðÿÿÿÿÿÿÿÿÿÿó “jj}vv~~üÿÿÿÿÿü~~|||}}}}}}~~~€€€ÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿ€€€‚‚‚™™™öööÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿõõõ˜˜˜ccc<<<777222---(((###  !!!&&&***///444999bbkKK¯ÿÿÿÿÿÿÿírr‹uuzttˆèÿÿÿÿÿÿÿCCºqq}dddcccbbb```€€€ÿÿÿÿÿÿÿ€€€VVVUUUUUUTTTTTTUUUUUUVVVWWWXXXYYYaaa„xxðÿÿÿÿÿÿÿÿÿÿÿÿö ‡ww€€€ÿÿÿÿÿÿÿ€€€€€€‚‚‚‚‚‚ƒƒƒ€€€ÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿ€€€ŠŠŠøøøÿÿÿÿÿÿÿÿÿþþþýýýÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿóóó„„„KKK999444///***%%%   """''',,,111666;;;CCCtt~>>¾ÿÿÿÿÿÿÿ óHHµðÿÿÿÿÿÿÿ77Æyyƒjjjhhhgggfffddd€€€ÿÿÿÿÿÿÿ€€€ZZZYYYYYYYYYYYYYYYZZZZZZ[[[\\\]]]€ttË22ÿÿÿÿÿÿô ©TT‰uu†yy¡]]êÿÿÚ%%}}ÿÿÿÿÿÿÿ€€€„„„………………††††††€€€ÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿ„„„ÞÞÞÿÿÿÿÿÿîîî   „„„ƒƒƒ™™™æææÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÑÑÑ}}}<<<666000+++&&&"""  ###(((---222777<<>>CCCHHHOOOpp{WW¤üÿÿÿÿÿÿÿÿÿÿÿþQQ¬ww‚qqqooonnnnnnlllkkkjjj€€€ÿÿÿÿÿÿÿ€€€`````````___``````aaaaaabbbcccsqq»CCÿÿÿÿÿÿœbb{yyxxxzzz|||~~~€€€‹ttûÿÿÿÿÿÿÿÿÿ€€€‰‰‰ŠŠŠŠŠŠŠŠŠŠŠŠ€€€ÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿþþþ•••|||yyyvvvqqqqqq‰‰‰úúúÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿ¼¼¼aaa888333...)))$$$   $$$***///444999???DDDIIINNNSSSooxbb™øÿÿÿÿÿÿÿÿÿú]] wwrrrqqqqqqpppooonnnmmmlll€€€ÿÿÿÿÿÿÿ€€€ccccccbbbbbbbbbbbbcccdddeeefffrr×((ÿÿÿÿÿì„zzyyy{{{}}}ƒƒƒ‡zzÕ))ÿÿÿÿÿÿÿÿÿ€€€‹‹‹‹‹‹‹‹‹ŒŒŒŒŒŒ€€€ÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿèè膆†€€€}}}zzzvvvrrrnnnØØØÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÙÙÙxxx999444...)))$$$    %%%***///555:::???EEEJJJOOOTTTXXXppv__œÿÿÿÿÿÿÿÿÿXX¥xxssssssrrrrrrqqqpppooonnnmmm€€€ÿÿÿÿÿÿÿzƒzfffdddddddddddddddeeeeeefffhhhƒyyò ÿÿÿÿÿÖ((…vv{{{}}}ƒƒƒ„„„ƒ½AAÿÿÿÿÿÿÿÿÿ€€€ŒŒŒŒŒŒŒŒŒŒŒŒŒŒŒ€€€ÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÑÑц††€€€}}}zzzvvvrrrnnnvvv¾¾¾ÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿóóó:::444///***%%%    %%%***///444:::???EEEIIIOOOSSS^^^xx‚66Çÿÿÿÿÿÿÿÿÿ..Ïzz„uuusssrrrrrrqqqpppooonnnmmm€€€ÿÿÿÿÿÿÿZ¢Zoooeeeeeeeeeeeeeeeffffffgggiiiƒyyò ÿÿÿÿÿÖ((…vv|||~~~€€€‚‚‚„„„………„‚‚½AAÿÿÿÿÿÿÿÿÿ€€€ŒŒŒŒŒŒŒŒŒ‹‹‹‹‹‹€€€ÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÔÔÔ†††|||yyyuuurrrmmmwwwÂÂÂÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿððð€€€:::444///)))%%%    $$$)))///444999>>>DDDIIINNN]]]yy‚**Óÿÿÿÿÿÿÿÿÿÿÿ$$Úzz„uuuqqqqqqpppooonnnmmmlll€€€ÿÿÿÿÿÿÿ#Û#yƒykkkeeeeeeeeeeeefffggghhhiiiss×((ÿÿÿÿÿì„zz|||~~~€€€‚‚‚„„„………ˆ{{Õ))ÿÿÿÿÿÿÿÿÿ€€€‹‹‹‹‹‹ŠŠŠŠŠŠŠŠŠ€€€ÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿëëë………}}}zzzwwwtttppplll‚‚‚ÛÛÛÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÕÕÕvvv999333...)))$$$   $$$)))...333888===CCCHHH]]]ww„!!Þÿÿÿÿÿÿÿÿÿÿÿÿÿãww†ttuooonnnnnnmmmlllkkk€€€ÿÿÿÿÿÿÿÿàw†wq€qpppkkknnnppprrrnnnhhhvtt»CCÿÿÿÿÿÿœbb~||}}}ƒƒƒƒƒƒ‹ttûÿÿÿÿÿÿÿÿÿ€€€‰‰‰‰‰‰ˆˆˆˆˆˆ‡‡‡€€€ÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿžžž}}}wwwtttqqqmmmqqqŽŽŽýýýÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿ¸¸¸^^^888333---((($$$  ###(((---222777<<>>??????@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@???????????????>>>>>>???????????????????????????@@@@@@@@@AAABBBCCCDDDEEEGGGHHHIIIJJJLLLNNNOOOQQQSSSTTTVVVWWWYYYZZZZZZ€~~üÿÿÿÿÿü€~~XXXVVVUUUTTTSSSQQQPPPOOOMMMLLLKKKJJJIIIHHHGGGFFFEEECCCBBB@@@>>><<<:::888666333000...+++(((%%%""" ___ƒƒƒººº©©©‡‡‡ÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉɾ¾¾………–––*** """$$$'''))),,,...000222444555777888888999999999999::::::::::::::::::::::::999999999999999999999999999999999999::::::::::::::::::;;;<<<<<<===>>>???AAABBBCCCDDDFFFGGGIIIKKKLLLNNNOOOQQQRRRSSSTTT€rräÿÿÿÿÿä€rrQQQPPPNNNMMMLLLKKKIIIHHHGGGFFFDDDCCCBBBAAA@@@???>>>===;;;:::888666444222000...,,,)))'''$$$!!! WWW”””ÇÇÇÉÉÉ•••™™™ÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉɺºº„„„   ÉÉÉ»»»}}} !!!###%%%''')))+++---...000111222222333333333333444444444444444444444444333333333333333333333333333444444444444444444444444555555666666777888999;;;<<<===>>>???AAABBBDDDFFFGGGIIIJJJKKKLLLMMMhcc]]ÿÿÿÿÿ]]gbbJJJIIIHHHGGGEEEDDDBBBAAA@@@???>>><<<<<<;;;:::999888666555333222000///---+++)))'''%%%"""  (((‚‚‚ÆÆÆÉÉÉÉÉɈˆˆ­­­ÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉɶ¶¶ƒƒƒ§§§ÉÉÉÉÉÉÉÉɯ¯¯www  !!!"""$$$&&&''')))***+++,,,---------------...........................---...------------.........................../////////000111222222333555555777888999:::<<<>>>???AAABBBCCCDDDEEEFFFFFFznn\\äøä\\ynnDDDCCCBBBAAA@@@???===<<<;;;999888777666555444333222111000///---,,,+++)))(((&&&$$$"""   {{{¹¹¹ÉÉÉÉÉÉÇÇÇÅÅÅÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉɯ¯¯‚‚‚­­­ÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉžžžhhh  !!!"""$$$%%%&&&&&&'''''''''((((((((((((((((((((((((((((((((((((((((((((((((((((((((())))))))))))))))))))))))******++++++,,,---...///000111222333444666777999:::;;;===>>>>>>???@@@@@@a\\~oo€||~ooa\\>>>>>>===<<<:::999888777666444333222111000///...---,,,+++***)))((('''%%%$$$###!!! 444“““ÉÉÉÉÉÉÉÉɾ¾¾ƒƒƒÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉɪªª‚‚‚³³³ÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÈÈÈOOO  !!!!!!"""""""""""""""#####################444@@@MMMNNN(((#####################$$$$$$$$$$$$$$$$$$$$$$$$%%%&&&&&&'''((()))***+++,,,---...///111222444555666777888999999999:::999999999888888777666555444333222111///...---,,,+++***)))(((''''''&&&$$$$$$"""!!!  [[[­­­ÉÉÉÉÉÉÉÉÉÈÈÈÂÂÂÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉ¢¢¢ƒƒƒ¸¸¸ÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÅÅŃƒƒ333 ___”””~~~VVV''' !!!"""###$$$$$$%%%&&&'''(((***+++,,,...///000111222222333333333333333333222222111000///...---,,,+++***((('''&&&%%%$$$$$$###"""!!!  yyy¾¾¾ÉÉÉÉÉÉÉÉÉÉÉÉŠŠŠ«««ÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉœœœ„„„½½½ÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉɾ¾¾~~~ AAA}}}ÆÆÆÉÉÉÉÉÉÉÉÉÀÀÀššš|||+++ !!!"""###$$$%%%'''((()))***+++,,,,,,------------------,,,,,,++++++***)))(((&&&%%%$$$###"""!!!   ÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉššš———ÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÇÇÇ–––………ÂÂÂÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉ´´´zzz +++VVV|||€€€………ÇÇÇÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉɯ¯¯|||+++ """###$$$%%%&&&&&&''''''((((((((('''''''''&&&&&&%%%$$$###"""!!!  ‚‚‚ÉÉÉÉÉÉÉÉÉÉÉÉÉÉɬ¬¬‡‡‡ÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÆÆÆ‘‘‘†††ÄÄÄÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉ£££nnn ###LLLyyy‚‚‚žžžƒƒƒŽŽŽœœœÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉɱ±±||| !!!""""""""""""""""""""""""!!!!!!  ~~~ÇÇÇÉÉÉÉÉÉÉÉÉÉÉÉÁÁÁƒƒƒ³³³ÉÉÉÉÉÉÉÉÉÅÅʼn‰‰ÇÇÇÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉ’’’XXX qqq€€€»»»ÇÇLjˆˆÉÉÉÅÅÅ………­­­ÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉ———MMM qqq¹¹¹ÉÉÉÉÉÉÉÉÉÉÉÉÉÉɨ¨¨………ÉÉÉÉÉÉÁÁÁ‰‰‰ÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÆÆÆ………;;; sss¤¤¤ÈÈÈÉÉÉÉÉÉ•••„„„ÆÆÆÉÉÉÉÉɺººƒƒƒ¼¼¼ÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÀÀÀ}}}  PPP¨¨¨ÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÈÈÈŒŒŒššš¿¿¿†††’’’ÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÁÁÁ### lllœœœÉÉÉÉÉÉÉÉÉžžžƒƒƒÁÁÁÉÉÉÉÉÉÉÉÉÉÉɨ¨¨‡‡‡ÄÄÄÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉ———FFF  +++ˆˆˆÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉɽ½½‚‚‚ƒƒƒ™™™ÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉ···|||ccc”””ÉÉÉÉÉÉÉÉɧ§§ƒƒƒ»»»ÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉ•••“““ÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉ´´´kkk  rrr±±±ÉÉÉÉÉÉÉÉÉÉÉɹ¹¹’’’‚‚‚‚‚‚ÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉ©©©sssWWWÈÈÈÉÉÉÉÉɰ°°‚‚‚²²²ÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÇÇLJ‡‡£££ÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÄÄÄ}}}  €€€ÅÅÅÈÈȳ³³ŠŠŠ‚‚‚ºººˆˆˆ’’’ÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉ———```KKKˆˆˆÆÆÆÉÉÉÉÉɸ¸¸ƒƒƒªªªÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÀÀÀƒƒƒµµµÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉ€€€ VVV’’’………ƒƒƒŽŽŽÀÀÀÉÉÉÉÉÉÁÁÁ………œœœÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÇÇlj‰‰DDD===„„„ÄÄÄÉÉÉÉÉɾ¾¾„„„žžžÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉɰ°°„„„ÀÀÀÉÉÉÉÉÉÉÉÉÉÉÉŠŠŠ((( |||‰‰‰ÀÀÀÉÉÉÉÉÉÉÉÉÉÉÉÉÉɽ½½ƒƒƒ§§§ÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÃÃÀ€€)))000ÁÁÁÉÉÉÉÉÉÂÂÂ………’’’ÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉ‹‹‹ÇÇÇÉÉÉÉÉÉÉÉÉ„„„~~~»»»ÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉ···‚‚‚°°°ÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉ»»»}}}%%%¾¾¾ÉÉÉÉÉÉÅÅʼn‰‰ŠŠŠÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉ‹‹‹™™™ÉÉÉÉÉÉÉÉÉ€€€)))¿¿¿ÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉɯ¯¯‚‚‚¹¹¹ÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉ®®®vvv }}}ºººÉÉÉÉÉÉÇÇdž††ÇÇÇÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÄÄÄ„„„«««ÉÉÉÄÄÄ~~~666‚‚‚ÃÃÃÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉɧ§§ƒƒƒ¿¿¿ÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉfff|||µµµÉÉÉÉÉÉÉÉÉ–––ƒƒƒÄÄÄÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉ···‚‚‚»»»£££VVVDDD†††ÆÆÆÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉ„„„ÄÄÄÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÈÈÈŒŒŒMMMxxx¯¯¯ÉÉÉÉÉÉÉÉÉŸŸŸƒƒƒ¾¾¾ÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉɤ¤¤†††SSSŒŒŒÇÇÇÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉ”””†††ÇÇÇÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÄÄÄ‚‚‚000 ttt¦¦¦ÉÉÉÉÉÉÉÉɪªª‚‚‚···ÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉɇ‡‡rrraaa”””ÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÇÇÇŽŽŽ‹‹‹ÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉɽ½½~~~mmmŸŸŸÉÉÉÉÉÉÉÉɲ²²‚‚‚®®®ÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉ®®®uuukkkÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÅÅʼn‰‰“““ÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉɲ²²€€€–––ÉÉÉÉÉÉÉÉɹ¹¹‚‚‚£££ÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉɼ¼¼}}} sss¦¦¦ÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÁÁÁ………ÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉŽŽŽÇÇÇÉÉÉ¿¿¿ƒƒƒ———ÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÅÅÅ‚‚‚---xxx¯¯¯ÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉɽ½½ƒƒƒ¨¨¨ÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÈÈȇ‡‡———ÃÃÆ††ÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉŽŽŽNNN|||···ÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉ···‚‚‚±±±ÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÃÃÄ„„‡‡‡ÈÈÈÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉ¢¢¢kkk~~~»»»ÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉɯ¯¯‚‚‚¹¹¹ÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉɺººˆˆˆÆÆÆÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉɵµµzzz )))€€€ÀÀÀÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉɧ§§ƒƒƒÀÀÀÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÀÀÀ888‚‚‚ÃÃÃÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉ„„„ÅÅÅÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÇÇdž††:::FFF‡‡‡ÆÆÆÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉ•••‡‡‡ÈÈÈÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉ•••[[[UUUŒŒŒÈÈÈÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÇÇÇŽŽŽŒŒŒÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉɪªªrrrbbb•••ÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÅÅʼn‰‰”””ÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉɺºº|||lllžžžÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÁÁÁ………žžžÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÃÃÀ€€((( ttt¦¦¦ÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉɽ½½ƒƒƒ©©©ÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÈÈÈŠŠŠGGGyyy°°°ÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉ···‚‚‚±±±ÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉžžžfff|||···ÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉɯ¯¯‚‚‚¹¹¹ÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉɱ±±xxx ~~~¼¼¼ÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉɧ§§ƒƒƒÀÀÀÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉɾ¾¾~~~***€€€ÀÀÀÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉ………ÄÄÄÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÆÆÆƒƒƒ333888‚‚‚ÃÃÃÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉ•••ˆˆˆÈÈÈÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉ‘‘‘UUUHHH‡‡‡ÆÆÆÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÇÇÇŒŒŒ½½½ÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉɦ¦¦nnnVVVÈÈÈÉÉÉ¿¿¿¯¯¯œœœ‰‰‰‚‚‚¨¨¨ÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉ···{{{gggˆˆˆƒƒƒƒƒƒ………›››€€€˜˜˜ÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉ“““RRR ttt———¹¹¹ÉÉÉÉÉÉÂÂÂ………ÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÃÃÃ,,,mmmžžžÉÉÉÉÉÉÉÉÉÆÆÆ‰‰‰‡‡‡ÈÈÈÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉɼ¼¼}}}ccc•••ÉÉÉÉÉÉÉÉÉÈÈȃƒƒÅÅÅÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉɰ°°xxx VVVÈÈÈÉÉÉÉÉÉÉÉɘ˜˜ƒƒƒÁÁÁÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉŸŸŸjjjIII‡‡‡ÆÆÆÉÉÉÉÉÉÉÉÉ£££‚‚‚ºººÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉRRR999ƒƒƒÄÄÄÉÉÉÉÉÉÉÉÉ­­­‚‚‚²²²ÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÅÅŃƒƒ666+++€€€ÁÁÁÉÉÉÉÉÉÉÉÉ···‚‚‚¦¦¦ÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉ¿¿¿~~~"""~~~¼¼¼ÉÉÉÉÉÉÉÉɽ½½ƒƒƒ›››ÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉɶ¶¶{{{|||···ÉÉÉÉÉÉÉÉÉÂÂÂ………ÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉɦ¦¦pppzzz°°°ÉÉÉÉÉÉÉÉÉÆÆÆŠŠŠ‰‰‰ÈÈÈÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉ”””\\\ uuu©©©ÉÉÉÉÉÉÉÉÉÈÈÈ‘‘‘„„„ÇÇÇÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÇÇLJ‡‡AAAnnn   ÉÉÉÉÉÉÉÉÉÉÉÉšššƒƒƒÂÂÂÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉ€€€&&&ddd–––ÉÉÉÉÉÉÉÉÉÉÉɤ¤¤ƒƒƒ¼¼¼ÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÈÈÈÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉɺºº|||YYYÈÈÈÉÉÉÉÉÉÉÉɯ¯¯‚‚‚³³³ÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉɱ±±„„„ÃÃÃÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉɬ¬¬uuuJJJˆˆˆÆÆÆÉÉÉÉÉÉÉÉɸ¸¸‚‚‚ªªªÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÁÁÁƒƒƒ‡‡‡ÈÈÈÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉ›››eee;;;ƒƒƒÄÄÄÉÉÉÉÉÉÉÉɾ¾¾ƒƒƒžžžÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉɆ††›››ÇÇÇÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÈÈÈ‹‹‹KKK...€€€ÁÁÁÉÉÉÉÉÉÉÉÉÃÃÆ††“““ÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉ”””‹‹‹ÇÇÇÉÉÉÅÅňˆˆ˜˜˜ÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÄÄÄ‚‚‚///###~~~½½½ÉÉÉÉÉÉÉÉÉÆÆÆ‹‹‹ŠŠŠÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉɪªªƒƒƒ¿¿¿ÉÉÉÉÉÉÉÉÉÀÀÀ„„„¥¥¥ÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉɽ½½~~~}}}¸¸¸ÉÉÉÉÉÉÉÉÉÈÈÈ’’’†††ÇÇÇÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉ¿¿¿‚‚‚¬¬¬ÉÉÉÉÉÉÉÉÉÉÉÉÉÉɹ¹¹ƒƒƒ°°°ÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉɳ³³yyy zzz±±±ÉÉÉÉÉÉÉÉÉÉÉÉ›››ƒƒƒÃÃÃÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÇÇdž††```………ÅÅÅÉÉÉÉÉÉÉÉÉÉÉÉÉÉɯ¯¯‚‚‚ºººÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉ¢¢¢lll vvvªªªÉÉÉÉÉÉÉÉÉÉÉɦ¦¦‚‚‚½½½ÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉɘ˜˜^^^NNN‰‰‰ÇÇÇÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉ£££ƒƒƒÂÂÂÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉ‘‘‘VVVooo¡¡¡ÉÉÉÉÉÉÉÉÉÉÉɰ°°‚‚‚¶¶¶ÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉ«««ttt[[[ÈÈÈÉÉÉÉÉÉÉÉÉÉÉÉÉÉɘ˜˜†††ÇÇÇÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÆÆÆOOOfff˜˜˜ÉÉÉÉÉÉÉÉÉÉÉɸ¸¸ƒƒƒ¬¬¬ÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉ»»»}}}fff˜˜˜ÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÇÇÇŽŽŽ‹‹‹ÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉɬ¬¬‚‚‚yyy[[[ÈÈÈÉÉÉÉÉÉÉÉÉ¿¿¿ƒƒƒ¡¡¡ÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÄÄÄ+++ooo   ÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÄÄĈˆˆ•••ÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÄÄăƒƒªªª‹‹‹333LLL‰‰‰ÇÇÇÉÉÉÉÉÉÉÉÉÃÃLJ‡•••ÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉŒŒŒLLL uuu¨¨¨ÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉ¿¿¿„„„¢¢¢ÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉ‹‹‹ŽŽŽÉÉÉ···sssXXXƒƒƒ………‰‰‰˜˜˜¡¡¡ŠŠŠ‹‹‹ÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉ   iiiyyy°°°ÉÉÉÉÉÉÉÉÉÉÉÉÉÉɹ¹¹ƒƒƒ®®®ÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉ«««ƒƒƒÀÀÀÉÉÉÈÈÈ~~~ }}}¶¶¶¶¶¶­­­¤¤¤———ˆˆˆ’’’ÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉ´´´yyy |||···ÉÉÉÉÉÉÉÉÉÉÉÉÉÉɯ¯¯‚‚‚¹¹¹ÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÃÃꪪÉÉÉÉÉÉÉÉÉ„„„ RRRšššÉÉÉÉÉÉÉÉÉÉÉÉÇÇLjˆˆ   ŠŠŠ’’’ÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÀÀÀ~~~~~~»»»ÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉ¢¢¢ƒƒƒÁÁÁÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉ‹‹‹ŽŽŽÉÉÉÉÉÉÉÉÉÉÉÉššš:::ÅÅÅÉÉÉÉÉÉÉÉÉÉÉÉ¢¢¢‡‡‡ÉÉÉÅÅÅ‹‹‹ÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÇÇÇ………888)))¿¿¿ÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉ———………ÆÆÆÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉ«««ƒƒƒÀÀÀÉÉÉÉÉÉÉÉÉÉÉÉ©©©NNNbbbªªªÉÉÉÉÉÉÉÉÉÉÉɽ½½‚‚‚»»»ÉÉÉÉÉÉÅÅÅŽŽŽÈÈÈÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉ”””ZZZ555‚‚‚ÃÃÃÉÉÉÉÉÉÉÉÉÉÉÉÇÇlj‰‰ÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉɃƒƒªªªÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉ¢¢¢???{{{ÁÁÁÉÉÉÉÉÉÉÉÉÉÉÉššš‘‘‘ÉÉÉÉÉÉÉÉÉÉÉÉÆÆÆŽŽŽ‹‹‹ÈÈÈÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉ©©©rrrCCC………ÅÅÅÉÉÉÉÉÉÉÉÉÉÉÉÄÄ懇’’’ÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉŠŠŠŽŽŽÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉ–––444ÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉŒŒŒ©©©ÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÆÆÆ‘‘‘ˆˆˆÇÇÇÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉɹ¹¹|||QQQŠŠŠÇÇÇÉÉÉÉÉÉÉÉÉÉÉÉ¿¿¿ƒƒƒŸŸŸÉÉÉÉÉÉÉÉÉÉÉÉÉÉɪªªƒƒƒÀÀÀÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉ‹‹‹***(((‰‰‰ÉÉÉÉÉÉÉÉÉÉÉÉÉÉɃƒƒ¿¿¿ÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÇÇÇ’’’ˆˆˆÆÆÆÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÃÃÀ€€''']]]‘‘‘ÈÈÈÉÉÉÉÉÉÉÉÉÉÉɸ¸¸‚‚‚¬¬¬ÉÉÉÉÉÉÉÉɃƒƒªªªÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÅÅÅ~~~ CCC¡¡¡ÉÉÉÉÉÉÉÉÉÉÉÉÁÁÁ‚‚‚ÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÇÇÇ•••†††ÄÄÄÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÈÈÈŠŠŠFFFggg™™™ÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉ­­­‚‚‚···ÉÉÉÉÉɉ‰‰ŽŽŽÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉɦ¦¦YYYQQQªªªÉÉÉÉÉÉÉÉÉÉÉÉ´´´‡‡‡ÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÈÈÈ–––†††ÃÃÃÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉeeeppp¡¡¡ÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉ¢¢¢ƒƒƒ¿¿¿§§§‚‚‚ÀÀÀÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÈÈÈ€€€000ÉÉÉÉÉÉÉÉÉÉÉɰ°°ˆˆˆÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÈÈÈššš„„„ÂÂÂÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉɱ±±xxx yyy„„„ŠŠŠ•••žžž¦¦¦®®®ŒŒŒƒƒƒƒƒƒªªªÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÈÈÈ‘‘‘```€€€ÉÉÉÉÉÉÉÉÉÉÉɽ½½ƒƒƒÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉ›››„„„ÀÀÀÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉɾ¾¾~~~nnn€€€„„„‡‡‡………„„„‚‚‚€€€ƒƒƒ³³³ÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÈÈÈ‘‘‘aaa|||ÂÂÂÉÉÉÉÉÉÉÉÉÈÈÈ‚‚‚ÁÁÁÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉžžžƒƒƒ½½½ÉÉÉÉÉÉÉÉÉÉÉÉÆÆÆƒƒƒ333555|||†††”””¢¢¢¬¬¬‚‚‚¢¢¢ÂÂÂÉÉÉÁÁÁ©©©………```ddd¬¬¬ÉÉÉÉÉÉÉÉÉÉÉÉŒŒŒ©©©ÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉ   ƒƒƒ¼¼¼ÉÉÉÉÉÉÉÉÉ’’’UUU"""333@@@TTTgggvvv|||||||||WWW'''~~~¿¿¿ÉÉÉÉÉÉÉÉÉœœœ‘‘‘ÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉ£££ƒƒƒºººÉÉɦ¦¦ooo666„„„ÇÇÇÉÉÉÉÉɽ½½‚‚‚¶¶¶ÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉɦ¦¦ƒƒƒ§§§{{{YYY•••ÉÉÉÉÉÉÉÉÉ¥¥¥„„„ÈÈÈÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉœœœ%%%pppŒŒŒ¾¾¾ÉÉÉÈÈÈ”””ÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉɪªª{{{---:::|||™™™ÁÁÁ¾¾¾ƒƒƒ‘‘‘ÄÄÄÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÈÈÈ›››ttt NNN{{{€€€ŒŒŒ€€€ƒƒƒ¡¡¡ÈÈÈÉÉÉÉÉÉÉÉÉÉÉÉÉÉÉÃÃꪪ………eee222YYYzzz€€€€€€ŠŠŠ–––¦¦¦§§§†††}}}YYY&&& '''555EEEPPP&&&xrdp-0.9.5/xrdp/cursor1.cur000644 001751 001751 00000000506 12251743072 015514 0ustar00metameta000000 000000  0( @ÿÿÿðð€€€€€€€€€€€€ððÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿáÿÿàÿÿàÿÿüÿÿüÿÿüÿÿüÿÿüÿÿüÿÿüÿÿüÿÿüÿÿüÿÿüÿÿüÿÿàÿÿàÿÿáÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿxrdp-0.9.5/xrdp/rdp-scan-codes.txt000644 001751 001751 00000012021 13127114621 016734 0ustar00metameta000000 000000 complete rdp key code listing en-us 4000s in the down flags column is from repeating keys(holding a key down) When holding a key down, the down flags repeat but the up flags only come once at the end. Rdesktop does not do this as of yet. It always sends down and up for each repeat. key rdp code down flags up flags esc 0x01 1 0000 8000 1 0x02 2 0000 8000 2 0x03 3 0000 8000 3 0x04 4 0000 8000 4 0x05 5 0000 8000 5 0x06 6 0000 8000 6 0x07 7 0000 8000 7 0x08 8 0000 8000 8 0x09 9 0000 8000 9 0x0a 10 0000 8000 0 0x0b 11 0000 8000 - 0x0c 12 0000 8000 = 0x0d 13 0000 8000 backspace 0x0e 14 0000 8000 tab 0x0f 15 0000 8000 q 0x10 16 0000 8000 w 0x11 17 0000 8000 e 0x12 18 0000 8000 r 0x13 19 0000 8000 t 0x14 20 0000 8000 y 0x15 21 0000 8000 u 0x16 22 0000 8000 i 0x17 23 0000 8000 o 0x18 24 0000 8000 p 0x19 25 0000 8000 [ 0x1a 26 0000 8000 ] 0x1b 27 0000 8000 enter 0x1c 28 0000 8000 left ctrl 0x1d 29 0000/4000 c000 right ctrl 0x1d 29 0100/4100 c100 a 0x1e 30 0000 8000 s 0x1f 31 0000 8000 d 0x20 32 0000 8000 f 0x21 33 0000 8000 g 0x22 34 0000 8000 h 0x23 35 0000 8000 j 0x24 36 0000 8000 k 0x25 37 0000 8000 l 0x26 38 0000 8000 ; 0x27 39 0000 8000 ' 0x28 40 0000 8000 ` 0x29 41 0000 8000 left shift 0x2a 42 0000/4000 c000 \ 0x2b 43 0000 8000 z 0x2c 44 0000 8000 x 0x2d 45 0000 8000 c 0x2e 46 0000 8000 v 0x2f 47 0000 8000 b 0x30 48 0000 8000 n 0x31 49 0000 8000 m 0x32 50 0000 8000 , 0x33 51 0000 8000 . 0x34 52 0000 8000 / 0x35 53 0000 8000 /(keypad) 0x35 53 0100 8100 right shift 0x36 54 0000/4000 c000 *(keypad) 0x37 55 0000 8000 print scrn 0x37 55 0100 8100 left alt 0x38 56 0000/4000 c000 right alt 0x38 56 0100/4100 c100 space 0x39 57 0000 8000 caps lock 0x3a 58 0000/4000 c000 f1 0x3b 59 0000 8000 f2 0x3c 60 0000 8000 f3 0x3d 61 0000 8000 f4 0x3e 62 0000 8000 f5 0x3f 63 0000 8000 f6 0x40 64 0000 8000 f7 0x41 65 0000 8000 f8 0x42 66 0000 8000 f9 0x43 67 0000 8000 f10 0x44 68 0000 8000 num lock 0x45 69 0000/4000 c000 scroll lock 0x46 70 0000/4000 c000 7(keypad) 0x47 71 0000 8000 home 0x47 71 0100 8100 8(keypad) 0x48 72 0000 8000 up arrow 0x48 72 0100 8100 9(keypad) 0x49 73 0000 8000 pg up 0x49 73 0100 8100 -(keypad) 0x4a 74 0000 8000 4(keypad) 0x4b 75 0000 8000 left arrow 0x4b 75 0100 8100 5(keypad) 0x4c 76 0000 8000 6(keypad) 0x4d 77 0000 8000 right arrow 0x4d 77 0100 8100 +(keypad) 0x4e 78 0000 8000 1(keypad) 0x4f 79 0000 8000 end 0x4f 79 0100 8100 2(keypad) 0x50 80 0000 8000 down arrow 0x50 80 0100 8100 3(keypad) 0x51 81 0000 8000 pg down 0x51 81 0100 8100 0(keypad) 0x52 82 0000 8000 insert 0x52 82 0100 8100 .(keypad) 0x53 83 0000 8000 delete 0x53 83 0100 8100 ? 0x54 84 ? 0x55 85 ? 0x56 86 f11 0x57 87 0000 8000 f12 0x58 88 0000 8000 ? 0x59 89 ? 0x5a 90 left win 0x5b 91 0100 8100 right win 0x5c 92 0100 8100 menu key 0x5d 93 0100 8100 pause break 0x1d 29 0200 8200 0x45 69 0000 8000 This is a special key that sends 2 down and 2 up like this down 001d 0200 down 0045 0000 up 001d 8200 up 0045 8000 xrdp-0.9.5/xrdp/xrdp_encoder.h000644 001751 001751 00000003110 13174271344 016225 0ustar00metameta000000 000000 #ifndef _XRDP_ENCODER_H #define _XRDP_ENCODER_H #include "arch.h" #include "fifo.h" struct xrdp_enc_data; /* for codec mode operations */ struct xrdp_encoder { struct xrdp_mm *mm; int in_codec_mode; int codec_id; int codec_quality; int max_compressed_bytes; tbus xrdp_encoder_event_to_proc; tbus xrdp_encoder_event_processed; tbus xrdp_encoder_term; FIFO *fifo_to_proc; FIFO *fifo_processed; tbus mutex; int (*process_enc)(struct xrdp_encoder *self, struct xrdp_enc_data *enc); void *codec_handle; int frame_id_client; /* last frame id received from client */ int frame_id_server; /* last frame id received from Xorg */ int frame_id_server_sent; int frames_in_flight; }; /* used when scheduling tasks in xrdp_encoder.c */ struct xrdp_enc_data { struct xrdp_mod *mod; int num_drects; short *drects; /* 4 * num_drects */ int num_crects; short *crects; /* 4 * num_crects */ char *data; int width; int height; int flags; int frame_id; }; typedef struct xrdp_enc_data XRDP_ENC_DATA; /* used when scheduling tasks from xrdp_encoder.c */ struct xrdp_enc_data_done { int comp_bytes; int pad_bytes; char *comp_pad_data; struct xrdp_enc_data *enc; int last; /* true is this is last message for enc */ int x; int y; int cx; int cy; }; typedef struct xrdp_enc_data_done XRDP_ENC_DATA_DONE; struct xrdp_encoder * xrdp_encoder_create(struct xrdp_mm *mm); void xrdp_encoder_delete(struct xrdp_encoder *self); THREAD_RV THREAD_CC proc_enc_msg(void *arg); #endif xrdp-0.9.5/xrdp/Makefile.am000644 001751 001751 00000003157 13174271344 015447 0ustar00metameta000000 000000 EXTRA_DIST = \ czech.txt \ rdp-scan-codes.txt \ xrdpwin.c AM_CPPFLAGS = \ -DXRDP_CFG_PATH=\"${sysconfdir}/xrdp\" \ -DXRDP_SBIN_PATH=\"${sbindir}\" \ -DXRDP_SHARE_PATH=\"${datadir}/xrdp\" \ -DXRDP_PID_PATH=\"${localstatedir}/run\" \ -DXRDP_MODULE_PATH=\"${moduledir}\" \ -DXRDP_SOCKET_PATH=\"${socketdir}\" \ -I$(top_builddir) \ -I$(top_srcdir)/common \ -I$(top_srcdir)/libxrdp XRDP_EXTRA_LIBS = if XRDP_DEBUG AM_CPPFLAGS += -DXRDP_DEBUG endif if XRDP_RFXCODEC AM_CPPFLAGS += -DXRDP_RFXCODEC AM_CPPFLAGS += -I$(top_srcdir)/librfxcodec/include XRDP_EXTRA_LIBS += $(top_builddir)/librfxcodec/src/.libs/librfxencode.a endif if XRDP_PIXMAN AM_CPPFLAGS += -DXRDP_PIXMAN AM_CPPFLAGS += $(PIXMAN_CFLAGS) XRDP_EXTRA_LIBS += $(PIXMAN_LIBS) endif if XRDP_PAINTER AM_CPPFLAGS += -DXRDP_PAINTER AM_CPPFLAGS += -I$(top_srcdir)/libpainter/include XRDP_EXTRA_LIBS += $(top_builddir)/libpainter/src/.libs/libpainter.a endif sbin_PROGRAMS = \ xrdp xrdp_SOURCES = \ funcs.c \ lang.c \ xrdp.c \ xrdp.h \ xrdp_bitmap.c \ xrdp_cache.c \ xrdp_encoder.c \ xrdp_encoder.h \ xrdp_font.c \ xrdp_listen.c \ xrdp_login_wnd.c \ xrdp_mm.c \ xrdp_painter.c \ xrdp_process.c \ xrdp_region.c \ xrdp_types.h \ xrdp_wm.c xrdp_LDADD = \ $(top_builddir)/common/libcommon.la \ $(top_builddir)/libxrdp/libxrdp.la \ $(XRDP_EXTRA_LIBS) xrdpsysconfdir=$(sysconfdir)/xrdp dist_xrdpsysconf_DATA = \ xrdp.ini \ xrdp_keyboard.ini xrdppkgdatadir=$(datadir)/xrdp dist_xrdppkgdata_DATA = \ ad24b.bmp \ ad256.bmp \ xrdp24b.bmp \ xrdp256.bmp \ xrdp_logo.bmp \ sans-10.fv1 \ cursor0.cur \ cursor1.cur xrdp-0.9.5/xrdp/xrdp256.bmp000644 001751 001751 00000140176 13127114621 015320 0ustar00metameta000000 000000 BM~À~(ÀÀ  333fff™™™ÌÌÌÿÿÿ€€`€ €€€€ÿÀÀÀðûÿÈÐÔÀ  À €ÀÀ ÿÿ                                                                                                                                                                                                 xrdp-0.9.5/xrdp/xrdp_region.c000644 001751 001751 00000007222 13174271344 016074 0ustar00metameta000000 000000 /** * xrdp: A Remote Desktop Protocol server. * * Copyright (C) Jay Sorg 2004-2014 * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. * * region */ #if defined(HAVE_CONFIG_H) #include #endif #include "xrdp.h" #if defined(XRDP_PIXMAN) #include #else #include "pixman-region.h" #endif /*****************************************************************************/ struct xrdp_region * xrdp_region_create(struct xrdp_wm *wm) { struct xrdp_region *self; self = (struct xrdp_region *)g_malloc(sizeof(struct xrdp_region), 1); self->wm = wm; self->reg = (struct pixman_region16 *) g_malloc(sizeof(struct pixman_region16), 1); pixman_region_init(self->reg); return self; } /*****************************************************************************/ void xrdp_region_delete(struct xrdp_region *self) { if (self == 0) { return; } pixman_region_fini(self->reg); g_free(self->reg); g_free(self); } /*****************************************************************************/ /* returns error */ int xrdp_region_add_rect(struct xrdp_region *self, struct xrdp_rect *rect) { struct pixman_region16 lreg; pixman_region_init_rect(&lreg, rect->left, rect->top, rect->right - rect->left, rect->bottom - rect->top); if (!pixman_region_union(self->reg, self->reg, &lreg)) { pixman_region_fini(&lreg); return 1; } pixman_region_fini(&lreg); return 0; } /*****************************************************************************/ /* returns error */ int xrdp_region_subtract_rect(struct xrdp_region *self, struct xrdp_rect *rect) { struct pixman_region16 lreg; pixman_region_init_rect(&lreg, rect->left, rect->top, rect->right - rect->left, rect->bottom - rect->top); if (!pixman_region_subtract(self->reg, self->reg, &lreg)) { pixman_region_fini(&lreg); return 1; } pixman_region_fini(&lreg); return 0; } /*****************************************************************************/ /* returns error */ int xrdp_region_intersect_rect(struct xrdp_region* self, struct xrdp_rect* rect) { struct pixman_region16 lreg; pixman_region_init_rect(&lreg, rect->left, rect->top, rect->right - rect->left, rect->bottom - rect->top); if (!pixman_region_intersect(self->reg, self->reg, &lreg)) { pixman_region_fini(&lreg); return 1; } pixman_region_fini(&lreg); return 0; } /*****************************************************************************/ /* returns error */ int xrdp_region_get_rect(struct xrdp_region *self, int index, struct xrdp_rect *rect) { struct pixman_box16 *box; int count; box = pixman_region_rectangles(self->reg, &count); if ((box != 0) && (index >= 0) && (index < count)) { rect->left = box[index].x1; rect->top = box[index].y1; rect->right = box[index].x2; rect->bottom = box[index].y2; return 0; } return 1; } xrdp-0.9.5/xrdp/xrdp_process.c000644 001751 001751 00000021542 13174271344 016270 0ustar00metameta000000 000000 /** * xrdp: A Remote Desktop Protocol server. * * Copyright (C) Jay Sorg 2004-2014 * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. * * main rdp process */ #if defined(HAVE_CONFIG_H) #include #endif #include "xrdp.h" static int g_session_id = 0; /*****************************************************************************/ /* always called from xrdp_listen thread */ struct xrdp_process * xrdp_process_create(struct xrdp_listen *owner, tbus done_event) { struct xrdp_process *self; char event_name[256]; int pid; self = (struct xrdp_process *)g_malloc(sizeof(struct xrdp_process), 1); self->lis_layer = owner; self->done_event = done_event; g_session_id++; self->session_id = g_session_id; pid = g_getpid(); g_snprintf(event_name, 255, "xrdp_%8.8x_process_self_term_event_%8.8x", pid, self->session_id); self->self_term_event = g_create_wait_obj(event_name); return self; } /*****************************************************************************/ void xrdp_process_delete(struct xrdp_process *self) { if (self == 0) { return; } g_delete_wait_obj(self->self_term_event); libxrdp_exit(self->session); xrdp_wm_delete(self->wm); trans_delete(self->server_trans); g_free(self); } /*****************************************************************************/ static int xrdp_process_loop(struct xrdp_process *self, struct stream *s) { int rv; rv = 0; if (self->session != 0) { rv = libxrdp_process_data(self->session, s); if ((self->wm == 0) && (self->session->up_and_running) && (rv == 0)) { DEBUG(("calling xrdp_wm_init and creating wm")); self->wm = xrdp_wm_create(self, self->session->client_info); /* at this point the wm(window manager) is create and wm::login_mode is zero and login_mode_event is set so xrdp_wm_init should be called by xrdp_wm_check_wait_objs */ } } return rv; } /*****************************************************************************/ /* returns boolean */ /* this is so libxrdp.so can known when to quit looping */ static int xrdp_is_term(void) { return g_is_term(); } /*****************************************************************************/ static int xrdp_process_mod_end(struct xrdp_process *self) { if (self->wm != 0) { if (self->wm->mm != 0) { if (self->wm->mm->mod != 0) { if (self->wm->mm->mod->mod_end != 0) { return self->wm->mm->mod->mod_end(self->wm->mm->mod); } } } } return 0; } /*****************************************************************************/ static int xrdp_process_data_in(struct trans *self) { struct xrdp_process *pro; struct stream *s; int len; DEBUG(("xrdp_process_data_in")); pro = (struct xrdp_process *)(self->callback_data); s = pro->server_trans->in_s; switch (pro->server_trans->extra_flags) { case 0: /* early in connection sequence, we're in this mode */ if (xrdp_process_loop(pro, 0) != 0) { g_writeln("xrdp_process_data_in: " "xrdp_process_loop failed"); return 1; } if (pro->session->up_and_running) { pro->server_trans->header_size = 2; pro->server_trans->extra_flags = 1; init_stream(s, 0); } break; case 1: /* we got 2 bytes */ if (s->p[0] == 3) { pro->server_trans->header_size = 4; pro->server_trans->extra_flags = 2; } else { if (s->p[1] & 0x80) { pro->server_trans->header_size = 3; pro->server_trans->extra_flags = 2; } else { len = (tui8)(s->p[1]); pro->server_trans->header_size = len; pro->server_trans->extra_flags = 3; } } len = (int) (s->end - s->data); if (pro->server_trans->header_size > len) { /* not enough data read yet */ break; } /* FALLTHROUGH */ case 2: /* we have enough now to get the PDU bytes */ len = libxrdp_get_pdu_bytes(s->p); if (len == -1) { g_writeln("xrdp_process_data_in: " "xrdp_process_get_packet_bytes failed"); return 1; } pro->server_trans->header_size = len; pro->server_trans->extra_flags = 3; len = (int) (s->end - s->data); if (pro->server_trans->header_size > len) { /* not enough data read yet */ break; } /* FALLTHROUGH */ case 3: /* the whole PDU is read in now process */ s->p = s->data; if (xrdp_process_loop(pro, s) != 0) { g_writeln("xrdp_process_data_in: " "xrdp_process_loop failed"); return 1; } init_stream(s, 0); pro->server_trans->header_size = 2; pro->server_trans->extra_flags = 1; break; } return 0; } /*****************************************************************************/ int xrdp_process_main_loop(struct xrdp_process *self) { int robjs_count; int wobjs_count; int cont; int timeout = 0; tbus robjs[32]; tbus wobjs[32]; tbus term_obj; DEBUG(("xrdp_process_main_loop")); self->status = 1; self->server_trans->extra_flags = 0; self->server_trans->header_size = 0; self->server_trans->no_stream_init_on_data_in = 1; self->server_trans->trans_data_in = xrdp_process_data_in; self->server_trans->callback_data = self; init_stream(self->server_trans->in_s, 8192 * 4); self->session = libxrdp_init((tbus)self, self->server_trans); self->server_trans->si = &(self->session->si); self->server_trans->my_source = XRDP_SOURCE_CLIENT; /* this callback function is in xrdp_wm.c */ self->session->callback = callback; /* this function is just above */ self->session->is_term = xrdp_is_term; if (libxrdp_process_incoming(self->session) == 0) { init_stream(self->server_trans->in_s, 32 * 1024); term_obj = g_get_term_event(); cont = 1; while (cont) { /* build the wait obj list */ timeout = -1; robjs_count = 0; wobjs_count = 0; robjs[robjs_count++] = term_obj; robjs[robjs_count++] = self->self_term_event; xrdp_wm_get_wait_objs(self->wm, robjs, &robjs_count, wobjs, &wobjs_count, &timeout); trans_get_wait_objs_rw(self->server_trans, robjs, &robjs_count, wobjs, &wobjs_count, &timeout); /* wait */ if (g_obj_wait(robjs, robjs_count, wobjs, wobjs_count, timeout) != 0) { /* error, should not get here */ g_sleep(100); } if (g_is_wait_obj_set(term_obj)) /* term */ { break; } if (g_is_wait_obj_set(self->self_term_event)) { break; } if (xrdp_wm_check_wait_objs(self->wm) != 0) { break; } if (trans_check_wait_objs(self->server_trans) != 0) { break; } } /* send disconnect message if possible */ libxrdp_disconnect(self->session); } else { g_writeln("xrdp_process_main_loop: libxrdp_process_incoming failed"); /* this will try to send a disconnect, maybe should check that connection got far enough */ libxrdp_disconnect(self->session); } /* Run end in module */ xrdp_process_mod_end(self); libxrdp_exit(self->session); self->session = 0; self->status = -1; g_set_wait_obj(self->done_event); return 0; } xrdp-0.9.5/xrdp/xrdp_painter.c000644 001751 001751 00000126274 13174271344 016264 0ustar00metameta000000 000000 /** * xrdp: A Remote Desktop Protocol server. * * Copyright (C) Jay Sorg 2004-2014 * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. * * painter, gc */ #if defined(HAVE_CONFIG_H) #include #endif #include "xrdp.h" #if defined(XRDP_PAINTER) #include /* libpainter */ #endif #define LLOG_LEVEL 1 #define LLOGLN(_level, _args) \ do \ { \ if (_level < LLOG_LEVEL) \ { \ g_write("xrdp:xrdp_painter [%10.10u]: ", g_time3()); \ g_writeln _args ; \ } \ } \ while (0) #if defined(XRDP_PAINTER) /*****************************************************************************/ static int xrdp_painter_add_dirty_rect(struct xrdp_painter *self, int x, int y, int cx, int cy, struct xrdp_rect *clip_rect) { int x2; int y2; struct xrdp_rect rect; if (clip_rect != 0) { x2 = x + cx; y2 = y + cy; x = MAX(x, clip_rect->left); y = MAX(y, clip_rect->top); x2 = MIN(x2, clip_rect->right); y2 = MIN(y2, clip_rect->bottom); cx = x2 - x; cy = y2 - y; } if (cx < 1 || cy < 1) { return 0; } rect.left = x; rect.top = y; rect.right = x + cx; rect.bottom = y + cy; xrdp_region_add_rect(self->dirty_region, &rect); LLOGLN(10, ("xrdp_painter_add_dirty_rect: x %d y %d cx %d cy %d", x, y, cx, cy)); return 0; } /*****************************************************************************/ static int xrdp_painter_send_dirty(struct xrdp_painter *self) { int cx; int cy; int bpp; int Bpp; int index; int jndex; int error; char *ldata; char *src; char *dst; struct xrdp_rect rect; LLOGLN(10, ("xrdp_painter_send_dirty:")); bpp = self->wm->screen->bpp; Bpp = (bpp + 7) / 8; if (Bpp == 3) { Bpp = 4; } jndex = 0; error = xrdp_region_get_rect(self->dirty_region, jndex, &rect); while (error == 0) { cx = rect.right - rect.left; cy = rect.bottom - rect.top; ldata = (char *)g_malloc(cx * cy * Bpp, 0); if (ldata == 0) { return 1; } src = self->wm->screen->data; src += self->wm->screen->line_size * rect.top; src += rect.left * Bpp; dst = ldata; for (index = 0; index < cy; index++) { g_memcpy(dst, src, cx * Bpp); src += self->wm->screen->line_size; dst += cx * Bpp; } LLOGLN(10, ("xrdp_painter_send_dirty: x %d y %d cx %d cy %d", rect.left, rect.top, cx, cy)); libxrdp_send_bitmap(self->session, cx, cy, bpp, ldata, rect.left, rect.top, cx, cy); g_free(ldata); jndex++; error = xrdp_region_get_rect(self->dirty_region, jndex, &rect); } xrdp_region_delete(self->dirty_region); self->dirty_region = xrdp_region_create(self->wm); return 0; } #endif /*****************************************************************************/ struct xrdp_painter * xrdp_painter_create(struct xrdp_wm *wm, struct xrdp_session *session) { struct xrdp_painter *self; LLOGLN(10, ("xrdp_painter_create:")); self = (struct xrdp_painter *)g_malloc(sizeof(struct xrdp_painter), 1); self->wm = wm; self->session = session; self->rop = 0xcc; /* copy will use 0xcc */ self->clip_children = 1; if (self->session->client_info->no_orders_supported) { #if defined(XRDP_PAINTER) if (painter_create(&(self->painter)) != PT_ERROR_NONE) { self->painter = 0; LLOGLN(0, ("xrdp_painter_create: painter_create failed")); } else { LLOGLN(10, ("xrdp_painter_create: painter_create success")); } self->dirty_region = xrdp_region_create(wm); #endif } return self; } /*****************************************************************************/ void xrdp_painter_delete(struct xrdp_painter *self) { LLOGLN(10, ("xrdp_painter_delete:")); if (self == 0) { return; } #if defined(XRDP_PAINTER) painter_delete(self->painter); xrdp_region_delete(self->dirty_region); #endif g_free(self); } /*****************************************************************************/ int wm_painter_set_target(struct xrdp_painter *self) { int surface_index; int index; struct list *del_list; LLOGLN(10, ("wm_painter_set_target:")); if (self->painter != 0) { return 0; } if (self->wm->target_surface->type == WND_TYPE_SCREEN) { if (self->wm->current_surface_index != 0xffff) { libxrdp_orders_send_switch_os_surface(self->session, 0xffff); self->wm->current_surface_index = 0xffff; } } else if (self->wm->target_surface->type == WND_TYPE_OFFSCREEN) { surface_index = self->wm->target_surface->item_index; if (surface_index != self->wm->current_surface_index) { if (self->wm->target_surface->tab_stop == 0) /* tab_stop is hack */ { del_list = self->wm->cache->xrdp_os_del_list; index = list_index_of(del_list, surface_index); list_remove_item(del_list, index); libxrdp_orders_send_create_os_surface(self->session, surface_index, self->wm->target_surface->width, self->wm->target_surface->height, del_list); self->wm->target_surface->tab_stop = 1; list_clear(del_list); } libxrdp_orders_send_switch_os_surface(self->session, surface_index); self->wm->current_surface_index = surface_index; } } else { g_writeln("xrdp_painter_begin_update: bad target_surface"); } return 0; } /*****************************************************************************/ int xrdp_painter_begin_update(struct xrdp_painter *self) { LLOGLN(10, ("xrdp_painter_begin_update:")); if (self == 0) { return 0; } self->begin_end_level++; if (self->painter != 0) { return 0; } libxrdp_orders_init(self->session); wm_painter_set_target(self); return 0; } /*****************************************************************************/ int xrdp_painter_end_update(struct xrdp_painter *self) { LLOGLN(10, ("xrdp_painter_end_update:")); if (self == 0) { return 0; } self->begin_end_level--; if (self->painter != 0) { #if defined(XRDP_PAINTER) if (self->begin_end_level == 0) { xrdp_painter_send_dirty(self); return 0; } #endif } libxrdp_orders_send(self->session); return 0; } /*****************************************************************************/ int xrdp_painter_font_needed(struct xrdp_painter *self) { if (self->font == 0) { self->font = self->wm->default_font; } return 0; } #if 0 /*****************************************************************************/ /* returns boolean, true if there is something to draw */ static int xrdp_painter_clip_adj(struct xrdp_painter *self, int *x, int *y, int *cx, int *cy) { int dx; int dy; if (!self->use_clip) { return 1; } if (self->clip.left > *x) { dx = self->clip.left - *x; } else { dx = 0; } if (self->clip.top > *y) { dy = self->clip.top - *y; } else { dy = 0; } if (*x + *cx > self->clip.right) { *cx = *cx - ((*x + *cx) - self->clip.right); } if (*y + *cy > self->clip.bottom) { *cy = *cy - ((*y + *cy) - self->clip.bottom); } *cx = *cx - dx; *cy = *cy - dy; if (*cx <= 0) { return 0; } if (*cy <= 0) { return 0; } *x = *x + dx; *y = *y + dy; return 1; } #endif /*****************************************************************************/ int xrdp_painter_set_clip(struct xrdp_painter *self, int x, int y, int cx, int cy) { self->use_clip = &self->clip; self->clip.left = x; self->clip.top = y; self->clip.right = x + cx; self->clip.bottom = y + cy; return 0; } /*****************************************************************************/ int xrdp_painter_clr_clip(struct xrdp_painter *self) { self->use_clip = 0; return 0; } #if 0 /*****************************************************************************/ static int xrdp_painter_rop(int rop, int src, int dst) { switch (rop & 0x0f) { case 0x0: return 0; case 0x1: return ~(src | dst); case 0x2: return (~src) & dst; case 0x3: return ~src; case 0x4: return src & (~dst); case 0x5: return ~(dst); case 0x6: return src ^ dst; case 0x7: return ~(src & dst); case 0x8: return src & dst; case 0x9: return ~(src) ^ dst; case 0xa: return dst; case 0xb: return (~src) | dst; case 0xc: return src; case 0xd: return src | (~dst); case 0xe: return src | dst; case 0xf: return ~0; } return dst; } #endif /*****************************************************************************/ int xrdp_painter_text_width(struct xrdp_painter *self, const char *text) { int index; int rv; int len; struct xrdp_font_char *font_item; twchar *wstr; LLOGLN(10, ("xrdp_painter_text_width:")); xrdp_painter_font_needed(self); if (self->font == 0) { return 0; } if (text == 0) { return 0; } rv = 0; len = g_mbstowcs(0, text, 0); wstr = (twchar *)g_malloc((len + 2) * sizeof(twchar), 0); g_mbstowcs(wstr, text, len + 1); for (index = 0; index < len; index++) { font_item = self->font->font_items + wstr[index]; rv = rv + font_item->incby; } g_free(wstr); return rv; } /*****************************************************************************/ int xrdp_painter_text_height(struct xrdp_painter *self, const char *text) { int index; int rv; int len; struct xrdp_font_char *font_item; twchar *wstr; LLOGLN(10, ("xrdp_painter_text_height:")); xrdp_painter_font_needed(self); if (self->font == 0) { return 0; } if (text == 0) { return 0; } rv = 0; len = g_mbstowcs(0, text, 0); wstr = (twchar *)g_malloc((len + 2) * sizeof(twchar), 0); g_mbstowcs(wstr, text, len + 1); for (index = 0; index < len; index++) { font_item = self->font->font_items + wstr[index]; rv = MAX(rv, font_item->height); } g_free(wstr); return rv; } /*****************************************************************************/ static int xrdp_painter_setup_brush(struct xrdp_painter *self, struct xrdp_brush *out_brush, struct xrdp_brush *in_brush) { int cache_id; LLOGLN(10, ("xrdp_painter_setup_brush:")); if (self->painter != 0) { return 0; } g_memcpy(out_brush, in_brush, sizeof(struct xrdp_brush)); if (in_brush->style == 3) { if (self->session->client_info->brush_cache_code == 1) { cache_id = xrdp_cache_add_brush(self->wm->cache, in_brush->pattern); g_memset(out_brush->pattern, 0, 8); out_brush->pattern[0] = cache_id; out_brush->style = 0x81; } } return 0; } #if defined(XRDP_PAINTER) /*****************************************************************************/ static int get_pt_format(struct xrdp_painter *self) { switch (self->wm->screen->bpp) { case 8: return PT_FORMAT_r3g3b2; case 15: return PT_FORMAT_a1r5g5b5; case 16: return PT_FORMAT_r5g6b5; } return PT_FORMAT_a8r8g8b8; } /*****************************************************************************/ static int get_rgb_from_rdp_color(struct xrdp_painter *self, int rdp_color) { if (self->wm->screen->bpp < 24) { return rdp_color; } /* well, this is really BGR2RGB */ return XR_RGB2BGR(rdp_color); } #endif /*****************************************************************************/ /* fill in an area of the screen with one color */ int xrdp_painter_fill_rect(struct xrdp_painter *self, struct xrdp_bitmap *dst, int x, int y, int cx, int cy) { struct xrdp_rect clip_rect; struct xrdp_rect draw_rect; struct xrdp_rect rect; struct xrdp_region *region; struct xrdp_brush brush; int k; int dx; int dy; int rop; LLOGLN(10, ("xrdp_painter_fill_rect:")); if (self == 0) { return 0; } dx = 0; dy = 0; if (self->painter != 0) { #if defined(XRDP_PAINTER) struct painter_bitmap dst_pb; struct xrdp_bitmap *ldst; struct painter_bitmap pat; LLOGLN(10, ("xrdp_painter_fill_rect: dst->type %d", dst->type)); if (dst->type != WND_TYPE_OFFSCREEN) { LLOGLN(10, ("xrdp_painter_fill_rect: using painter")); ldst = self->wm->screen; g_memset(&dst_pb, 0, sizeof(dst_pb)); dst_pb.format = get_pt_format(self); dst_pb.width = ldst->width; dst_pb.stride_bytes = ldst->line_size; dst_pb.height = ldst->height; dst_pb.data = ldst->data; LLOGLN(10, ("xrdp_painter_fill_rect: ldst->width %d ldst->height %d " "dst->data %p self->fg_color %d", ldst->width, ldst->height, ldst->data, self->fg_color)); xrdp_bitmap_get_screen_clip(dst, self, &clip_rect, &dx, &dy); region = xrdp_region_create(self->wm); xrdp_wm_get_vis_region(self->wm, dst, x, y, cx, cy, region, self->clip_children); x += dx; y += dy; rop = self->rop; switch (self->rop) { case 0x5a: rop = PT_ROP_DSx; break; case 0xf0: rop = PT_ROP_S; break; case 0xfb: rop = PT_ROP_D; break; case 0xc0: rop = PT_ROP_DSa; break; } painter_set_rop(self->painter, rop); if (self->mix_mode == 0) { painter_set_pattern_mode(self->painter, PT_PATTERN_MODE_OPAQUE); painter_set_fgcolor(self->painter, get_rgb_from_rdp_color(self, self->fg_color)); k = 0; while (xrdp_region_get_rect(region, k, &rect) == 0) { if (rect_intersect(&rect, &clip_rect, &draw_rect)) { painter_set_clip(self->painter, draw_rect.left, draw_rect.top, draw_rect.right - draw_rect.left, draw_rect.bottom - draw_rect.top); painter_fill_rect(self->painter, &dst_pb, x, y, cx, cy); xrdp_painter_add_dirty_rect(self, x, y, cx, cy, &draw_rect); } k++; } } else { painter_set_pattern_mode(self->painter, PT_PATTERN_MODE_OPAQUE); painter_set_fgcolor(self->painter, get_rgb_from_rdp_color(self, self->fg_color)); painter_set_bgcolor(self->painter, get_rgb_from_rdp_color(self, self->bg_color)); painter_set_pattern_origin(self->painter, self->brush.x_origin, self->brush.y_origin); g_memset(&pat, 0, sizeof(pat)); pat.format = PT_FORMAT_c1; pat.width = 8; pat.stride_bytes = 1; pat.height = 8; pat.data = self->brush.pattern; k = 0; while (xrdp_region_get_rect(region, k, &rect) == 0) { if (rect_intersect(&rect, &clip_rect, &draw_rect)) { painter_set_clip(self->painter, draw_rect.left, draw_rect.top, draw_rect.right - draw_rect.left, draw_rect.bottom - draw_rect.top); painter_fill_pattern(self->painter, &dst_pb, &pat, x, y, x, y, cx, cy); xrdp_painter_add_dirty_rect(self, x, y, cx, cy, &draw_rect); } k++; } } painter_clear_clip(self->painter); xrdp_region_delete(region); } return 0; #endif } /* todo data */ if (dst->type == WND_TYPE_BITMAP) /* 0 */ { return 0; } xrdp_bitmap_get_screen_clip(dst, self, &clip_rect, &dx, &dy); region = xrdp_region_create(self->wm); if (dst->type != WND_TYPE_OFFSCREEN) { xrdp_wm_get_vis_region(self->wm, dst, x, y, cx, cy, region, self->clip_children); } else { xrdp_region_add_rect(region, &clip_rect); } x += dx; y += dy; if (self->mix_mode == 0 && self->rop == 0xcc) { k = 0; while (xrdp_region_get_rect(region, k, &rect) == 0) { if (rect_intersect(&rect, &clip_rect, &draw_rect)) { libxrdp_orders_rect(self->session, x, y, cx, cy, self->fg_color, &draw_rect); } k++; } } else if (self->mix_mode == 0 && ((self->rop & 0xf) == 0x0 || /* black */ (self->rop & 0xf) == 0xf || /* white */ (self->rop & 0xf) == 0x5)) /* DSTINVERT */ { k = 0; while (xrdp_region_get_rect(region, k, &rect) == 0) { if (rect_intersect(&rect, &clip_rect, &draw_rect)) { libxrdp_orders_dest_blt(self->session, x, y, cx, cy, self->rop, &draw_rect); } k++; } } else { k = 0; rop = self->rop; /* if opcode is in the form 0x00, 0x11, 0x22, ... convert it */ if (((rop & 0xf0) >> 4) == (rop & 0xf)) { switch (rop) { case 0x66: /* xor */ rop = 0x5a; break; case 0xaa: /* noop */ rop = 0xfb; break; case 0xcc: /* copy */ rop = 0xf0; break; case 0x88: /* and */ rop = 0xc0; break; } } xrdp_painter_setup_brush(self, &brush, &self->brush); while (xrdp_region_get_rect(region, k, &rect) == 0) { if (rect_intersect(&rect, &clip_rect, &draw_rect)) { libxrdp_orders_pat_blt(self->session, x, y, cx, cy, rop, self->bg_color, self->fg_color, &brush, &draw_rect); } k++; } } xrdp_region_delete(region); return 0; } /*****************************************************************************/ int xrdp_painter_draw_text(struct xrdp_painter *self, struct xrdp_bitmap *dst, int x, int y, const char *text) { int i; int f; int c; int k; int x1; int y1; int flags; int len; int index; int total_width; int total_height; int dx; int dy; char *data; struct xrdp_region *region; struct xrdp_rect rect; struct xrdp_rect clip_rect; struct xrdp_rect draw_rect; struct xrdp_font *font; struct xrdp_font_char *font_item; twchar *wstr; LLOGLN(10, ("xrdp_painter_draw_text:")); if (self == 0) { return 0; } len = g_mbstowcs(0, text, 0); if (len < 1) { return 0; } /* todo data */ if (dst->type == 0) { return 0; } xrdp_painter_font_needed(self); if (self->font == 0) { return 0; } if (self->painter != 0) { #if defined(XRDP_PAINTER) struct painter_bitmap pat; struct painter_bitmap dst_pb; struct xrdp_bitmap *ldst; if (dst->type != WND_TYPE_OFFSCREEN) { ldst = self->wm->screen; /* convert to wide char */ wstr = (twchar *)g_malloc((len + 2) * sizeof(twchar), 0); g_mbstowcs(wstr, text, len + 1); font = self->font; total_width = 0; total_height = 0; for (index = 0; index < len; index++) { font_item = font->font_items + wstr[index]; k = font_item->incby; total_width += k; total_height = MAX(total_height, font_item->height); } xrdp_bitmap_get_screen_clip(dst, self, &clip_rect, &dx, &dy); region = xrdp_region_create(self->wm); xrdp_wm_get_vis_region(self->wm, dst, x, y, total_width, total_height, region, self->clip_children); x += dx; y += dy; g_memset(&dst_pb, 0, sizeof(dst_pb)); dst_pb.format = get_pt_format(self); dst_pb.width = ldst->width; dst_pb.stride_bytes = ldst->line_size; dst_pb.height = ldst->height; dst_pb.data = ldst->data; painter_set_rop(self->painter, PT_ROP_S); painter_set_pattern_origin(self->painter, 0, 0); painter_set_pattern_mode(self->painter, PT_PATTERN_MODE_NORMAL); painter_set_fgcolor(self->painter, get_rgb_from_rdp_color(self, self->fg_color)); k = 0; while (xrdp_region_get_rect(region, k, &rect) == 0) { if (rect_intersect(&rect, &clip_rect, &draw_rect)) { painter_set_clip(self->painter, draw_rect.left, draw_rect.top, draw_rect.right - draw_rect.left, draw_rect.bottom - draw_rect.top); for (index = 0; index < len; index++) { font_item = font->font_items + wstr[index]; g_memset(&pat, 0, sizeof(pat)); pat.format = PT_FORMAT_c1; pat.width = font_item->width; pat.stride_bytes = (font_item->width + 7) / 8; pat.height = font_item->height; pat.data = font_item->data; x1 = x + font_item->offset; y1 = y + (font_item->height + font_item->baseline); painter_fill_pattern(self->painter, &dst_pb, &pat, 0, 0, x1, y1, font_item->width, font_item->height); xrdp_painter_add_dirty_rect(self, x, y, font_item->width, font_item->height, &draw_rect); x += font_item->incby; } } k++; } painter_clear_clip(self->painter); xrdp_region_delete(region); g_free(wstr); } return 0; #endif } /* convert to wide char */ wstr = (twchar *)g_malloc((len + 2) * sizeof(twchar), 0); g_mbstowcs(wstr, text, len + 1); font = self->font; f = 0; k = 0; total_width = 0; total_height = 0; data = (char *)g_malloc(len * 4, 1); for (index = 0; index < len; index++) { font_item = font->font_items + wstr[index]; i = xrdp_cache_add_char(self->wm->cache, font_item); f = HIWORD(i); c = LOWORD(i); data[index * 2] = c; data[index * 2 + 1] = k; k = font_item->incby; total_width += k; total_height = MAX(total_height, font_item->height); } xrdp_bitmap_get_screen_clip(dst, self, &clip_rect, &dx, &dy); region = xrdp_region_create(self->wm); if (dst->type != WND_TYPE_OFFSCREEN) { xrdp_wm_get_vis_region(self->wm, dst, x, y, total_width, total_height, region, self->clip_children); } else { xrdp_region_add_rect(region, &clip_rect); } x += dx; y += dy; k = 0; while (xrdp_region_get_rect(region, k, &rect) == 0) { if (rect_intersect(&rect, &clip_rect, &draw_rect)) { x1 = x; y1 = y + total_height; flags = 0x03; /* 0x03 0x73; TEXT2_IMPLICIT_X and something else */ libxrdp_orders_text(self->session, f, flags, 0, self->fg_color, 0, x - 1, y - 1, x + total_width, y + total_height, 0, 0, 0, 0, x1, y1, data, len * 2, &draw_rect); } k++; } xrdp_region_delete(region); g_free(data); g_free(wstr); return 0; } /*****************************************************************************/ int xrdp_painter_draw_text2(struct xrdp_painter *self, struct xrdp_bitmap *dst, int font, int flags, int mixmode, int clip_left, int clip_top, int clip_right, int clip_bottom, int box_left, int box_top, int box_right, int box_bottom, int x, int y, char *data, int data_len) { struct xrdp_rect clip_rect; struct xrdp_rect draw_rect; struct xrdp_rect rect; struct xrdp_region *region; int k; int dx; int dy; LLOGLN(0, ("xrdp_painter_draw_text2:")); if (self == 0) { return 0; } if (self->painter != 0) { return 0; } /* todo data */ if (dst->type == WND_TYPE_BITMAP) { return 0; } xrdp_bitmap_get_screen_clip(dst, self, &clip_rect, &dx, &dy); region = xrdp_region_create(self->wm); if (dst->type != WND_TYPE_OFFSCREEN) { if (box_right - box_left > 1) { xrdp_wm_get_vis_region(self->wm, dst, box_left, box_top, box_right - box_left, box_bottom - box_top, region, self->clip_children); } else { xrdp_wm_get_vis_region(self->wm, dst, clip_left, clip_top, clip_right - clip_left, clip_bottom - clip_top, region, self->clip_children); } } else { xrdp_region_add_rect(region, &clip_rect); } clip_left += dx; clip_top += dy; clip_right += dx; clip_bottom += dy; box_left += dx; box_top += dy; box_right += dx; box_bottom += dy; x += dx; y += dy; k = 0; while (xrdp_region_get_rect(region, k, &rect) == 0) { if (rect_intersect(&rect, &clip_rect, &draw_rect)) { libxrdp_orders_text(self->session, font, flags, mixmode, self->fg_color, self->bg_color, clip_left, clip_top, clip_right, clip_bottom, box_left, box_top, box_right, box_bottom, x, y, data, data_len, &draw_rect); } k++; } xrdp_region_delete(region); return 0; } /*****************************************************************************/ int xrdp_painter_copy(struct xrdp_painter *self, struct xrdp_bitmap *src, struct xrdp_bitmap *dst, int x, int y, int cx, int cy, int srcx, int srcy) { struct xrdp_rect clip_rect; struct xrdp_rect draw_rect; struct xrdp_rect rect1; struct xrdp_rect rect2; struct xrdp_region *region; struct xrdp_bitmap *b; int i; int j; int k; int dx; int dy; int palette_id; int bitmap_id; int cache_id; int cache_idx; int dstx; int dsty; int w; int h; int index; struct list *del_list; LLOGLN(10, ("xrdp_painter_copy:")); if (self == 0 || src == 0 || dst == 0) { return 0; } if (self->painter != 0) { #if defined(XRDP_PAINTER) struct painter_bitmap src_pb; struct painter_bitmap dst_pb; struct xrdp_bitmap *ldst; LLOGLN(10, ("xrdp_painter_copy: src->type %d dst->type %d", src->type, dst->type)); LLOGLN(10, ("xrdp_painter_copy: self->rop 0x%2.2x", self->rop)); if (dst->type != WND_TYPE_OFFSCREEN) { LLOGLN(10, ("xrdp_painter_copy: using painter")); ldst = self->wm->screen; g_memset(&dst_pb, 0, sizeof(dst_pb)); dst_pb.format = get_pt_format(self); dst_pb.width = ldst->width; dst_pb.stride_bytes = ldst->line_size; dst_pb.height = ldst->height; dst_pb.data = ldst->data; g_memset(&src_pb, 0, sizeof(src_pb)); src_pb.format = get_pt_format(self); src_pb.width = src->width; src_pb.stride_bytes = src->line_size; src_pb.height = src->height; src_pb.data = src->data; xrdp_bitmap_get_screen_clip(dst, self, &clip_rect, &dx, &dy); region = xrdp_region_create(self->wm); xrdp_wm_get_vis_region(self->wm, dst, x, y, cx, cy, region, self->clip_children); x += dx; y += dy; k = 0; painter_set_rop(self->painter, self->rop); while (xrdp_region_get_rect(region, k, &rect1) == 0) { if (rect_intersect(&rect1, &clip_rect, &draw_rect)) { painter_set_clip(self->painter, draw_rect.left, draw_rect.top, draw_rect.right - draw_rect.left, draw_rect.bottom - draw_rect.top); LLOGLN(10, (" x %d y %d cx %d cy %d srcx %d srcy %d", x, y, cx, cy, srcx, srcy)); painter_copy(self->painter, &dst_pb, x, y, cx, cy, &src_pb, srcx, srcy); xrdp_painter_add_dirty_rect(self, x, y, cx, cy, &draw_rect); } k++; } painter_clear_clip(self->painter); xrdp_region_delete(region); } return 0; #endif } /* todo data */ if (dst->type == WND_TYPE_BITMAP) { return 0; } if (src->type == WND_TYPE_SCREEN) { xrdp_bitmap_get_screen_clip(dst, self, &clip_rect, &dx, &dy); region = xrdp_region_create(self->wm); if (dst->type != WND_TYPE_OFFSCREEN) { xrdp_wm_get_vis_region(self->wm, dst, x, y, cx, cy, region, self->clip_children); } else { xrdp_region_add_rect(region, &clip_rect); } x += dx; y += dy; srcx += dx; srcy += dy; k = 0; while (xrdp_region_get_rect(region, k, &rect1) == 0) { if (rect_intersect(&rect1, &clip_rect, &draw_rect)) { libxrdp_orders_screen_blt(self->session, x, y, cx, cy, srcx, srcy, self->rop, &draw_rect); } k++; } xrdp_region_delete(region); } else if (src->type == WND_TYPE_OFFSCREEN) { //g_writeln("xrdp_painter_copy: todo"); xrdp_bitmap_get_screen_clip(dst, self, &clip_rect, &dx, &dy); region = xrdp_region_create(self->wm); if (dst->type != WND_TYPE_OFFSCREEN) { //g_writeln("off screen to screen"); xrdp_wm_get_vis_region(self->wm, dst, x, y, cx, cy, region, self->clip_children); } else { //g_writeln("off screen to off screen"); xrdp_region_add_rect(region, &clip_rect); } x += dx; y += dy; palette_id = 0; cache_id = 255; // todo cache_idx = src->item_index; // todo if (src->tab_stop == 0) { g_writeln("xrdp_painter_copy: warning src not created"); del_list = self->wm->cache->xrdp_os_del_list; index = list_index_of(del_list, cache_idx); list_remove_item(del_list, index); libxrdp_orders_send_create_os_surface(self->session, cache_idx, src->width, src->height, del_list); src->tab_stop = 1; list_clear(del_list); } k = 0; while (xrdp_region_get_rect(region, k, &rect1) == 0) { if (rect_intersect(&rect1, &clip_rect, &rect2)) { MAKERECT(rect1, x, y, cx, cy); if (rect_intersect(&rect2, &rect1, &draw_rect)) { libxrdp_orders_mem_blt(self->session, cache_id, palette_id, x, y, cx, cy, self->rop, srcx, srcy, cache_idx, &draw_rect); } } k++; } xrdp_region_delete(region); } else if (src->data != 0) /* todo, the non bitmap cache part is gone, it should be put back */ { xrdp_bitmap_get_screen_clip(dst, self, &clip_rect, &dx, &dy); region = xrdp_region_create(self->wm); if (dst->type != WND_TYPE_OFFSCREEN) { xrdp_wm_get_vis_region(self->wm, dst, x, y, cx, cy, region, self->clip_children); } else { xrdp_region_add_rect(region, &clip_rect); } x += dx; y += dy; palette_id = 0; j = srcy; while (j < (srcy + cy)) { i = srcx; while (i < (srcx + cx)) { w = MIN(64, ((srcx + cx) - i)); h = MIN(64, ((srcy + cy) - j)); b = xrdp_bitmap_create(w, h, src->bpp, 0, self->wm); #if 1 xrdp_bitmap_copy_box_with_crc(src, b, i, j, w, h); #else xrdp_bitmap_copy_box(src, b, i, j, w, h); xrdp_bitmap_hash_crc(b); #endif bitmap_id = xrdp_cache_add_bitmap(self->wm->cache, b, self->wm->hints); cache_id = HIWORD(bitmap_id); cache_idx = LOWORD(bitmap_id); dstx = (x + i) - srcx; dsty = (y + j) - srcy; k = 0; while (xrdp_region_get_rect(region, k, &rect1) == 0) { if (rect_intersect(&rect1, &clip_rect, &rect2)) { MAKERECT(rect1, dstx, dsty, w, h); if (rect_intersect(&rect2, &rect1, &draw_rect)) { libxrdp_orders_mem_blt(self->session, cache_id, palette_id, dstx, dsty, w, h, self->rop, 0, 0, cache_idx, &draw_rect); } } k++; } i += 64; } j += 64; } xrdp_region_delete(region); } return 0; } /*****************************************************************************/ int xrdp_painter_composite(struct xrdp_painter* self, struct xrdp_bitmap* src, int srcformat, int srcwidth, int srcrepeat, struct xrdp_bitmap* dst, int* srctransform, int mskflags, struct xrdp_bitmap* msk, int mskformat, int mskwidth, int mskrepeat, int op, int srcx, int srcy, int mskx, int msky, int dstx, int dsty, int width, int height, int dstformat) { struct xrdp_rect clip_rect; struct xrdp_rect draw_rect; struct xrdp_rect rect1; struct xrdp_rect rect2; struct xrdp_region* region; int k; int dx; int dy; int cache_srcidx; int cache_mskidx; LLOGLN(0, ("xrdp_painter_composite:")); if (self == 0 || src == 0 || dst == 0) { return 0; } if (self->painter != 0) { return 0; } /* todo data */ if (dst->type == WND_TYPE_BITMAP) { return 0; } if (src->type == WND_TYPE_OFFSCREEN) { xrdp_bitmap_get_screen_clip(dst, self, &clip_rect, &dx, &dy); region = xrdp_region_create(self->wm); xrdp_region_add_rect(region, &clip_rect); dstx += dx; dsty += dy; cache_srcidx = src->item_index; cache_mskidx = -1; if (mskflags & 1) { if (msk != 0) { cache_mskidx = msk->item_index; // todo } } k = 0; while (xrdp_region_get_rect(region, k, &rect1) == 0) { if (rect_intersect(&rect1, &clip_rect, &rect2)) { MAKERECT(rect1, dstx, dsty, width, height); if (rect_intersect(&rect2, &rect1, &draw_rect)) { libxrdp_orders_composite_blt(self->session, cache_srcidx, srcformat, srcwidth, srcrepeat, srctransform, mskflags, cache_mskidx, mskformat, mskwidth, mskrepeat, op, srcx, srcy, mskx, msky, dstx, dsty, width, height, dstformat, &draw_rect); } } k++; } xrdp_region_delete(region); } return 0; } /*****************************************************************************/ int xrdp_painter_line(struct xrdp_painter *self, struct xrdp_bitmap *dst, int x1, int y1, int x2, int y2) { struct xrdp_rect clip_rect; struct xrdp_rect draw_rect; struct xrdp_rect rect; struct xrdp_region *region; int k; int dx; int dy; int rop; LLOGLN(10, ("xrdp_painter_line:")); if (self == 0) { return 0; } if (self->painter != 0) { #if defined(XRDP_PAINTER) int x; int y; int cx; int cy; struct painter_bitmap dst_pb; struct xrdp_bitmap *ldst; LLOGLN(10, ("xrdp_painter_line: dst->type %d", dst->type)); LLOGLN(10, ("xrdp_painter_line: self->rop 0x%2.2x", self->rop)); if (dst->type != WND_TYPE_OFFSCREEN) { LLOGLN(10, ("xrdp_painter_line: using painter")); ldst = self->wm->screen; g_memset(&dst_pb, 0, sizeof(dst_pb)); dst_pb.format = get_pt_format(self); dst_pb.width = ldst->width; dst_pb.stride_bytes = ldst->line_size; dst_pb.height = ldst->height; dst_pb.data = ldst->data; xrdp_bitmap_get_screen_clip(dst, self, &clip_rect, &dx, &dy); region = xrdp_region_create(self->wm); x = MIN(x1, x2); y = MIN(y1, y2); cx = g_abs(x1 - x2) + 1; cy = g_abs(y1 - y2) + 1; xrdp_wm_get_vis_region(self->wm, dst, x, y, cx, cy, region, self->clip_children); x1 += dx; y1 += dy; x2 += dx; y2 += dy; k = 0; rop = self->rop; painter_set_rop(self->painter, rop); painter_set_fgcolor(self->painter, self->pen.color); while (xrdp_region_get_rect(region, k, &rect) == 0) { if (rect_intersect(&rect, &clip_rect, &draw_rect)) { painter_set_clip(self->painter, draw_rect.left, draw_rect.top, draw_rect.right - draw_rect.left, draw_rect.bottom - draw_rect.top); painter_line(self->painter, &dst_pb, x1, y1, x2, y2, self->pen.width, 0); xrdp_painter_add_dirty_rect(self, x, y, cx, cy, &draw_rect); } k++; } painter_clear_clip(self->painter); xrdp_region_delete(region); } return 0; #endif } /* todo data */ if (dst->type == WND_TYPE_BITMAP) { return 0; } xrdp_bitmap_get_screen_clip(dst, self, &clip_rect, &dx, &dy); region = xrdp_region_create(self->wm); if (dst->type != WND_TYPE_OFFSCREEN) { xrdp_wm_get_vis_region(self->wm, dst, MIN(x1, x2), MIN(y1, y2), g_abs(x1 - x2) + 1, g_abs(y1 - y2) + 1, region, self->clip_children); } else { xrdp_region_add_rect(region, &clip_rect); } x1 += dx; y1 += dy; x2 += dx; y2 += dy; k = 0; rop = self->rop; if (rop < 0x01 || rop > 0x10) { rop = (rop & 0xf) + 1; } while (xrdp_region_get_rect(region, k, &rect) == 0) { if (rect_intersect(&rect, &clip_rect, &draw_rect)) { libxrdp_orders_line(self->session, 1, x1, y1, x2, y2, rop, self->bg_color, &self->pen, &draw_rect); } k++; } xrdp_region_delete(region); return 0; } xrdp-0.9.5/xrdp/xrdp_cache.c000644 001751 001751 00000056550 13220727202 015653 0ustar00metameta000000 000000 /** * xrdp: A Remote Desktop Protocol server. * * Copyright (C) Jay Sorg 2004-2014 * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. * * cache */ #if defined(HAVE_CONFIG_H) #include #endif #include "xrdp.h" #include "log.h" #define LLOG_LEVEL 1 #define LLOGLN(_level, _args) \ do \ { \ if (_level < LLOG_LEVEL) \ { \ g_write("xrdp:xrdp_cache [%10.10u]: ", g_time3()); \ g_writeln _args ; \ } \ } \ while (0) /*****************************************************************************/ static int xrdp_cache_reset_lru(struct xrdp_cache *self) { int index; int jndex; struct xrdp_lru_item *lru; for (index = 0; index < XRDP_MAX_BITMAP_CACHE_ID; index++) { /* fist item */ lru = &(self->bitmap_lrus[index][0]); lru->next = 1; lru->prev = -1; /* middle items */ for (jndex = 1; jndex < XRDP_MAX_BITMAP_CACHE_IDX - 1; jndex++) { lru = &(self->bitmap_lrus[index][jndex]); lru->next = jndex + 1; lru->prev = jndex - 1; } /* last item */ lru = &(self->bitmap_lrus[index][XRDP_MAX_BITMAP_CACHE_IDX - 1]); lru->next = -1; lru->prev = XRDP_MAX_BITMAP_CACHE_IDX - 2; self->lru_head[index] = 0; self->lru_tail[index] = XRDP_MAX_BITMAP_CACHE_IDX - 1; self->lru_reset[index] = 1; } return 0; } /*****************************************************************************/ static int xrdp_cache_reset_crc(struct xrdp_cache *self) { int index; int jndex; for (index = 0; index < XRDP_MAX_BITMAP_CACHE_ID; index++) { for (jndex = 0; jndex < 64 * 1024; jndex++) { /* it's ok to deinit a zeroed out struct list16 */ list16_deinit(&(self->crc16[index][jndex])); list16_init(&(self->crc16[index][jndex])); } } return 0; } /*****************************************************************************/ struct xrdp_cache * xrdp_cache_create(struct xrdp_wm *owner, struct xrdp_session *session, struct xrdp_client_info *client_info) { struct xrdp_cache *self; self = (struct xrdp_cache *)g_malloc(sizeof(struct xrdp_cache), 1); self->wm = owner; self->session = session; self->use_bitmap_comp = client_info->use_bitmap_comp; self->cache1_entries = MIN(XRDP_MAX_BITMAP_CACHE_IDX, client_info->cache1_entries); self->cache1_entries = MAX(self->cache1_entries, 0); self->cache1_size = client_info->cache1_size; self->cache2_entries = MIN(XRDP_MAX_BITMAP_CACHE_IDX, client_info->cache2_entries); self->cache2_entries = MAX(self->cache2_entries, 0); self->cache2_size = client_info->cache2_size; self->cache3_entries = MIN(XRDP_MAX_BITMAP_CACHE_IDX, client_info->cache3_entries); self->cache3_entries = MAX(self->cache3_entries, 0); self->cache3_size = client_info->cache3_size; self->bitmap_cache_persist_enable = client_info->bitmap_cache_persist_enable; self->bitmap_cache_version = client_info->bitmap_cache_version; self->pointer_cache_entries = client_info->pointer_cache_entries; self->xrdp_os_del_list = list_create(); xrdp_cache_reset_lru(self); xrdp_cache_reset_crc(self); LLOGLN(10, ("xrdp_cache_create: 0 %d 1 %d 2 %d", self->cache1_entries, self->cache2_entries, self->cache3_entries)); return self; } /*****************************************************************************/ void xrdp_cache_delete(struct xrdp_cache *self) { int i; int j; if (self == 0) { return; } /* free all the cached bitmaps */ for (i = 0; i < XRDP_MAX_BITMAP_CACHE_ID; i++) { for (j = 0; j < XRDP_MAX_BITMAP_CACHE_IDX; j++) { xrdp_bitmap_delete(self->bitmap_items[i][j].bitmap); } } /* free all the cached font items */ for (i = 0; i < 12; i++) { for (j = 0; j < 256; j++) { g_free(self->char_items[i][j].font_item.data); } } /* free all the off screen bitmaps */ for (i = 0; i < 2000; i++) { xrdp_bitmap_delete(self->os_bitmap_items[i].bitmap); } list_delete(self->xrdp_os_del_list); /* free all crc lists */ for (i = 0; i < XRDP_MAX_BITMAP_CACHE_ID; i++) { for (j = 0; j < 64 * 1024; j++) { list16_deinit(&(self->crc16[i][j])); } } g_free(self); } /*****************************************************************************/ int xrdp_cache_reset(struct xrdp_cache *self, struct xrdp_client_info *client_info) { struct xrdp_wm *wm; struct xrdp_session *session; int i; int j; /* free all the cached bitmaps */ for (i = 0; i < XRDP_MAX_BITMAP_CACHE_ID; i++) { for (j = 0; j < XRDP_MAX_BITMAP_CACHE_IDX; j++) { xrdp_bitmap_delete(self->bitmap_items[i][j].bitmap); } } /* free all the cached font items */ for (i = 0; i < 12; i++) { for (j = 0; j < 256; j++) { g_free(self->char_items[i][j].font_item.data); } } /* save these */ wm = self->wm; session = self->session; /* set whole struct to zero */ g_memset(self, 0, sizeof(struct xrdp_cache)); /* set some stuff back */ self->wm = wm; self->session = session; self->use_bitmap_comp = client_info->use_bitmap_comp; self->cache1_entries = client_info->cache1_entries; self->cache1_size = client_info->cache1_size; self->cache2_entries = client_info->cache2_entries; self->cache2_size = client_info->cache2_size; self->cache3_entries = client_info->cache3_entries; self->cache3_size = client_info->cache3_size; self->bitmap_cache_persist_enable = client_info->bitmap_cache_persist_enable; self->bitmap_cache_version = client_info->bitmap_cache_version; self->pointer_cache_entries = client_info->pointer_cache_entries; xrdp_cache_reset_lru(self); xrdp_cache_reset_crc(self); return 0; } #define COMPARE_WITH_CRC32(_b1, _b2) \ ((_b1 != 0) && (_b2 != 0) && (_b1->crc32 == _b2->crc32) && \ (_b1->bpp == _b2->bpp) && \ (_b1->width == _b2->width) && (_b1->height == _b2->height)) /*****************************************************************************/ static int xrdp_cache_update_lru(struct xrdp_cache *self, int cache_id, int lru_index) { int tail_index; struct xrdp_lru_item *nextlru; struct xrdp_lru_item *prevlru; struct xrdp_lru_item *thislru; struct xrdp_lru_item *taillru; LLOGLN(10, ("xrdp_cache_update_lru: lru_index %d", lru_index)); if ((lru_index < 0) || (lru_index >= XRDP_MAX_BITMAP_CACHE_IDX)) { LLOGLN(0, ("xrdp_cache_update_lru: error")); return 1; } if (self->lru_tail[cache_id] == lru_index) { /* nothing to do */ return 0; } else if (self->lru_head[cache_id] == lru_index) { /* moving head item to tail */ thislru = &(self->bitmap_lrus[cache_id][lru_index]); nextlru = &(self->bitmap_lrus[cache_id][thislru->next]); tail_index = self->lru_tail[cache_id]; taillru = &(self->bitmap_lrus[cache_id][tail_index]); /* unhook old */ nextlru->prev = -1; /* set head to next */ self->lru_head[cache_id] = thislru->next; /* move to tail and hook up */ taillru->next = lru_index; thislru->prev = tail_index; thislru->next = -1; /* update tail */ self->lru_tail[cache_id] = lru_index; } else { /* move middle item */ thislru = &(self->bitmap_lrus[cache_id][lru_index]); prevlru = &(self->bitmap_lrus[cache_id][thislru->prev]); nextlru = &(self->bitmap_lrus[cache_id][thislru->next]); tail_index = self->lru_tail[cache_id]; taillru = &(self->bitmap_lrus[cache_id][tail_index]); /* unhook old */ prevlru->next = thislru->next; nextlru->prev = thislru->prev; /* move to tail and hook up */ taillru->next = lru_index; thislru->prev = tail_index; thislru->next = -1; /* update tail */ self->lru_tail[cache_id] = lru_index; } return 0; } /*****************************************************************************/ /* returns cache id */ int xrdp_cache_add_bitmap(struct xrdp_cache *self, struct xrdp_bitmap *bitmap, int hints) { int index; int jndex; int cache_id; int cache_idx; int bmp_size; int e; int Bpp; int crc16; int iig; int found; int cache_entries; int lru_index; struct list16 *ll; struct xrdp_bitmap *lbm; struct xrdp_lru_item *llru; LLOGLN(10, ("xrdp_cache_add_bitmap:")); LLOGLN(10, ("xrdp_cache_add_bitmap: crc16 0x%4.4x", bitmap->crc16)); e = (4 - (bitmap->width % 4)) & 3; found = 0; cache_id = 0; cache_entries = 0; /* client Bpp, bmp_size */ Bpp = (bitmap->bpp + 7) / 8; bmp_size = (bitmap->width + e) * bitmap->height * Bpp; self->bitmap_stamp++; if (bmp_size <= self->cache1_size) { cache_id = 0; cache_entries = self->cache1_entries; } else if (bmp_size <= self->cache2_size) { cache_id = 1; cache_entries = self->cache2_entries; } else if (bmp_size <= self->cache3_size) { cache_id = 2; cache_entries = self->cache3_entries; } else { log_message(LOG_LEVEL_ERROR, "error in xrdp_cache_add_bitmap, " "too big(%d) bpp %d", bmp_size, bitmap->bpp); return 0; } crc16 = bitmap->crc16; ll = &(self->crc16[cache_id][crc16]); for (jndex = 0; jndex < ll->count; jndex++) { cache_idx = list16_get_item(ll, jndex); if (COMPARE_WITH_CRC32 (self->bitmap_items[cache_id][cache_idx].bitmap, bitmap)) { LLOGLN(10, ("found bitmap at %d %d", index, jndex)); found = 1; break; } } if (found) { lru_index = self->bitmap_items[cache_id][cache_idx].lru_index; self->bitmap_items[cache_id][cache_idx].stamp = self->bitmap_stamp; xrdp_bitmap_delete(bitmap); /* update lru to end */ xrdp_cache_update_lru(self, cache_id, lru_index); return MAKELONG(cache_idx, cache_id); } /* find lru */ /* check for reset */ if (self->lru_reset[cache_id]) { self->lru_reset[cache_id] = 0; LLOGLN(0, ("xrdp_cache_add_bitmap: reset detected cache_id %d", cache_id)); self->lru_tail[cache_id] = cache_entries - 1; index = self->lru_tail[cache_id]; llru = &(self->bitmap_lrus[cache_id][index]); llru->next = -1; } /* lru is item at head */ lru_index = self->lru_head[cache_id]; cache_idx = lru_index; /* update lru to end */ xrdp_cache_update_lru(self, cache_id, lru_index); LLOGLN(10, ("xrdp_cache_add_bitmap: oldest %d %d", cache_id, cache_idx)); LLOGLN(10, ("adding bitmap at %d %d old ptr %p new ptr %p", cache_id, cache_idx, self->bitmap_items[cache_id][cache_idx].bitmap, bitmap)); /* remove old, about to be deleted, from crc16 list */ lbm = self->bitmap_items[cache_id][cache_idx].bitmap; if (lbm != 0) { crc16 = lbm->crc16; ll = &(self->crc16[cache_id][crc16]); iig = list16_index_of(ll, cache_idx); if (iig == -1) { LLOGLN(0, ("xrdp_cache_add_bitmap: error removing cache_idx")); } LLOGLN(10, ("xrdp_cache_add_bitmap: removing index %d from crc16 %d", iig, crc16)); list16_remove_item(ll, iig); xrdp_bitmap_delete(lbm); } /* set, send bitmap and return */ self->bitmap_items[cache_id][cache_idx].bitmap = bitmap; self->bitmap_items[cache_id][cache_idx].stamp = self->bitmap_stamp; self->bitmap_items[cache_id][cache_idx].lru_index = lru_index; /* add to crc16 list */ crc16 = bitmap->crc16; ll = &(self->crc16[cache_id][crc16]); list16_add_item(ll, cache_idx); if (ll->count > 1) { LLOGLN(10, ("xrdp_cache_add_bitmap: count %d", ll->count)); } if (self->use_bitmap_comp) { if (self->bitmap_cache_version & 4) { if (libxrdp_orders_send_bitmap3(self->session, bitmap->width, bitmap->height, bitmap->bpp, bitmap->data, cache_id, cache_idx, hints) == 0) { return MAKELONG(cache_idx, cache_id); } } if (self->bitmap_cache_version & 2) { libxrdp_orders_send_bitmap2(self->session, bitmap->width, bitmap->height, bitmap->bpp, bitmap->data, cache_id, cache_idx, hints); } else if (self->bitmap_cache_version & 1) { libxrdp_orders_send_bitmap(self->session, bitmap->width, bitmap->height, bitmap->bpp, bitmap->data, cache_id, cache_idx); } } else { if (self->bitmap_cache_version & 2) { libxrdp_orders_send_raw_bitmap2(self->session, bitmap->width, bitmap->height, bitmap->bpp, bitmap->data, cache_id, cache_idx); } else if (self->bitmap_cache_version & 1) { libxrdp_orders_send_raw_bitmap(self->session, bitmap->width, bitmap->height, bitmap->bpp, bitmap->data, cache_id, cache_idx); } } return MAKELONG(cache_idx, cache_id); } /*****************************************************************************/ /* not used */ /* not sure how to use a palette in rdp */ int xrdp_cache_add_palette(struct xrdp_cache *self, int *palette) { int i; int oldest; int index; if (self == 0) { return 0; } if (palette == 0) { return 0; } if (self->wm->screen->bpp > 8) { return 0; } self->palette_stamp++; /* look for match */ for (i = 0; i < 6; i++) { if (g_memcmp(palette, self->palette_items[i].palette, 256 * sizeof(int)) == 0) { self->palette_items[i].stamp = self->palette_stamp; return i; } } /* look for oldest */ index = 0; oldest = 0x7fffffff; for (i = 0; i < 6; i++) { if (self->palette_items[i].stamp < oldest) { oldest = self->palette_items[i].stamp; index = i; } } /* set, send palette and return */ g_memcpy(self->palette_items[index].palette, palette, 256 * sizeof(int)); self->palette_items[index].stamp = self->palette_stamp; libxrdp_orders_send_palette(self->session, palette, index); return index; } /*****************************************************************************/ int xrdp_cache_add_char(struct xrdp_cache *self, struct xrdp_font_char *font_item) { int i; int j; int oldest; int f; int c; int datasize; struct xrdp_font_char *fi; self->char_stamp++; /* look for match */ for (i = 7; i < 12; i++) { for (j = 0; j < 250; j++) { if (xrdp_font_item_compare(&self->char_items[i][j].font_item, font_item)) { self->char_items[i][j].stamp = self->char_stamp; DEBUG(("found font at %d %d", i, j)); return MAKELONG(j, i); } } } /* look for oldest */ f = 0; c = 0; oldest = 0x7fffffff; for (i = 7; i < 12; i++) { for (j = 0; j < 250; j++) { if (self->char_items[i][j].stamp < oldest) { oldest = self->char_items[i][j].stamp; f = i; c = j; } } } DEBUG(("adding char at %d %d", f, c)); /* set, send char and return */ fi = &self->char_items[f][c].font_item; g_free(fi->data); datasize = FONT_DATASIZE(font_item); fi->data = (char *)g_malloc(datasize, 1); g_memcpy(fi->data, font_item->data, datasize); fi->offset = font_item->offset; fi->baseline = font_item->baseline; fi->width = font_item->width; fi->height = font_item->height; self->char_items[f][c].stamp = self->char_stamp; libxrdp_orders_send_font(self->session, fi, f, c); return MAKELONG(c, f); } /*****************************************************************************/ /* added the pointer to the cache and send it to client, it also sets the client if it finds it returns the index in the cache does not take ownership of pointer_item */ int xrdp_cache_add_pointer(struct xrdp_cache *self, struct xrdp_pointer_item *pointer_item) { int i; int oldest; int index; if (self == 0) { return 0; } self->pointer_stamp++; /* look for match */ for (i = 2; i < self->pointer_cache_entries; i++) { if (self->pointer_items[i].x == pointer_item->x && self->pointer_items[i].y == pointer_item->y && g_memcmp(self->pointer_items[i].data, pointer_item->data, 32 * 32 * 4) == 0 && g_memcmp(self->pointer_items[i].mask, pointer_item->mask, 32 * 32 / 8) == 0 && self->pointer_items[i].bpp == pointer_item->bpp) { self->pointer_items[i].stamp = self->pointer_stamp; xrdp_wm_set_pointer(self->wm, i); self->wm->current_pointer = i; DEBUG(("found pointer at %d", i)); return i; } } /* look for oldest */ index = 2; oldest = 0x7fffffff; for (i = 2; i < self->pointer_cache_entries; i++) { if (self->pointer_items[i].stamp < oldest) { oldest = self->pointer_items[i].stamp; index = i; } } self->pointer_items[index].x = pointer_item->x; self->pointer_items[index].y = pointer_item->y; g_memcpy(self->pointer_items[index].data, pointer_item->data, 32 * 32 * 4); g_memcpy(self->pointer_items[index].mask, pointer_item->mask, 32 * 32 / 8); self->pointer_items[index].stamp = self->pointer_stamp; self->pointer_items[index].bpp = pointer_item->bpp; xrdp_wm_send_pointer(self->wm, index, self->pointer_items[index].data, self->pointer_items[index].mask, self->pointer_items[index].x, self->pointer_items[index].y, self->pointer_items[index].bpp); self->wm->current_pointer = index; DEBUG(("adding pointer at %d", index)); return index; } /*****************************************************************************/ /* this does not take ownership of pointer_item, it makes a copy */ int xrdp_cache_add_pointer_static(struct xrdp_cache *self, struct xrdp_pointer_item *pointer_item, int index) { if (self == 0) { return 0; } self->pointer_items[index].x = pointer_item->x; self->pointer_items[index].y = pointer_item->y; g_memcpy(self->pointer_items[index].data, pointer_item->data, 32 * 32 * 4); g_memcpy(self->pointer_items[index].mask, pointer_item->mask, 32 * 32 / 8); self->pointer_items[index].stamp = self->pointer_stamp; self->pointer_items[index].bpp = pointer_item->bpp; xrdp_wm_send_pointer(self->wm, index, self->pointer_items[index].data, self->pointer_items[index].mask, self->pointer_items[index].x, self->pointer_items[index].y, self->pointer_items[index].bpp); self->wm->current_pointer = index; DEBUG(("adding pointer at %d", index)); return index; } /*****************************************************************************/ /* this does not take ownership of brush_item_data, it makes a copy */ int xrdp_cache_add_brush(struct xrdp_cache *self, char *brush_item_data) { int i; int oldest; int index; if (self == 0) { return 0; } self->brush_stamp++; /* look for match */ for (i = 0; i < 64; i++) { if (g_memcmp(self->brush_items[i].pattern, brush_item_data, 8) == 0) { self->brush_items[i].stamp = self->brush_stamp; DEBUG(("found brush at %d", i)); return i; } } /* look for oldest */ index = 0; oldest = 0x7fffffff; for (i = 0; i < 64; i++) { if (self->brush_items[i].stamp < oldest) { oldest = self->brush_items[i].stamp; index = i; } } g_memcpy(self->brush_items[index].pattern, brush_item_data, 8); self->brush_items[index].stamp = self->brush_stamp; libxrdp_orders_send_brush(self->session, 8, 8, 1, 0x81, 8, self->brush_items[index].pattern, index); DEBUG(("adding brush at %d", index)); return index; } /*****************************************************************************/ /* returns error */ int xrdp_cache_add_os_bitmap(struct xrdp_cache *self, struct xrdp_bitmap *bitmap, int rdpindex) { struct xrdp_os_bitmap_item *bi; if ((rdpindex < 0) || (rdpindex >= 2000)) { return 1; } bi = self->os_bitmap_items + rdpindex; bi->bitmap = bitmap; return 0; } /*****************************************************************************/ /* returns error */ int xrdp_cache_remove_os_bitmap(struct xrdp_cache *self, int rdpindex) { struct xrdp_os_bitmap_item *bi; int index; if ((rdpindex < 0) || (rdpindex >= 2000)) { return 1; } bi = self->os_bitmap_items + rdpindex; if (bi->bitmap->tab_stop) { index = list_index_of(self->xrdp_os_del_list, rdpindex); if (index == -1) { list_add_item(self->xrdp_os_del_list, rdpindex); } } xrdp_bitmap_delete(bi->bitmap); g_memset(bi, 0, sizeof(struct xrdp_os_bitmap_item)); return 0; } /*****************************************************************************/ struct xrdp_os_bitmap_item * xrdp_cache_get_os_bitmap(struct xrdp_cache *self, int rdpindex) { struct xrdp_os_bitmap_item *bi; if ((rdpindex < 0) || (rdpindex >= 2000)) { return 0; } bi = self->os_bitmap_items + rdpindex; return bi; } xrdp-0.9.5/xrdp/xrdp.c000644 001751 001751 00000042416 13206023530 014521 0ustar00metameta000000 000000 /** * xrdp: A Remote Desktop Protocol server. * * Copyright (C) Jay Sorg 2004-2014 * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. * * main program */ #if defined(HAVE_CONFIG_H) #include #endif #include "xrdp.h" #include "log.h" #if !defined(PACKAGE_VERSION) #define PACKAGE_VERSION "???" #endif #define THREAD_WAITING 100 static struct xrdp_listen *g_listen = 0; static long g_threadid = 0; /* main threadid */ static long g_sync_mutex = 0; static long g_sync1_mutex = 0; static tbus g_term_event = 0; static tbus g_sync_event = 0; /* synchronize stuff */ static int g_sync_command = 0; static long g_sync_result = 0; static long g_sync_param1 = 0; static long g_sync_param2 = 0; static long (*g_sync_func)(long param1, long param2); /*****************************************************************************/ /* This function is used to run a function from the main thread. Sync_func is the function pointer that will run from main thread The function can have two long in parameters and must return long */ long g_xrdp_sync(long (*sync_func)(long param1, long param2), long sync_param1, long sync_param2) { long sync_result; int sync_command; /* If the function is called from the main thread, the function can * be called directly. g_threadid= main thread ID*/ if (tc_threadid_equal(tc_get_threadid(), g_threadid)) { /* this is the main thread, call the function directly */ /* in fork mode, this always happens too */ sync_result = sync_func(sync_param1, sync_param2); /*g_writeln("g_xrdp_sync processed IN main thread -> continue");*/ } else { /* All threads have to wait here until the main thread * process the function. g_process_waiting_function() is called * from the listening thread. g_process_waiting_function() process the function*/ tc_mutex_lock(g_sync1_mutex); tc_mutex_lock(g_sync_mutex); g_sync_param1 = sync_param1; g_sync_param2 = sync_param2; g_sync_func = sync_func; /* set a value THREAD_WAITING so the g_process_waiting_function function * know if any function must be processed */ g_sync_command = THREAD_WAITING; tc_mutex_unlock(g_sync_mutex); /* set this event so that the main thread know if * g_process_waiting_function() must be called */ g_set_wait_obj(g_sync_event); do { g_sleep(100); tc_mutex_lock(g_sync_mutex); /* load new value from global to see if the g_process_waiting_function() * function has processed the function */ sync_command = g_sync_command; sync_result = g_sync_result; tc_mutex_unlock(g_sync_mutex); } while (sync_command != 0); /* loop until g_process_waiting_function() * has processed the request */ tc_mutex_unlock(g_sync1_mutex); /*g_writeln("g_xrdp_sync processed BY main thread -> continue");*/ } return sync_result; } /*****************************************************************************/ void xrdp_shutdown(int sig) { tbus threadid; threadid = tc_get_threadid(); g_writeln("shutting down"); g_writeln("signal %d threadid %lld", sig, (long long)threadid); if (!g_is_wait_obj_set(g_term_event)) { g_set_wait_obj(g_term_event); } } /*****************************************************************************/ void xrdp_child(int sig) { g_waitchild(); } /*****************************************************************************/ /* called in child just after fork */ int xrdp_child_fork(void) { int pid; char text[256]; /* close, don't delete these */ g_close_wait_obj(g_term_event); g_close_wait_obj(g_sync_event); pid = g_getpid(); g_snprintf(text, 255, "xrdp_%8.8x_main_term", pid); g_term_event = g_create_wait_obj(text); g_snprintf(text, 255, "xrdp_%8.8x_main_sync", pid); g_sync_event = g_create_wait_obj(text); return 0; } /*****************************************************************************/ int g_is_term(void) { return g_is_wait_obj_set(g_term_event); } /*****************************************************************************/ void g_set_term(int in_val) { if (in_val) { g_set_wait_obj(g_term_event); } else { g_reset_wait_obj(g_term_event); } } /*****************************************************************************/ tbus g_get_term_event(void) { return g_term_event; } /*****************************************************************************/ tbus g_get_sync_event(void) { return g_sync_event; } /*****************************************************************************/ void pipe_sig(int sig_num) { /* do nothing */ g_writeln("got XRDP SIGPIPE(%d)", sig_num); } /*****************************************************************************/ /*Some function must be called from the main thread. if g_sync_command==THREAD_WAITING a function is waiting to be processed*/ void g_process_waiting_function(void) { tc_mutex_lock(g_sync_mutex); if (g_sync_command != 0) { if (g_sync_func != 0) { if (g_sync_command == THREAD_WAITING) { g_sync_result = g_sync_func(g_sync_param1, g_sync_param2); } } g_sync_command = 0; } tc_mutex_unlock(g_sync_mutex); } /*****************************************************************************/ int xrdp_process_params(int argc, char **argv, struct xrdp_startup_params *startup_params) { int index; char option[128]; char value[128]; index = 1; while (index < argc) { g_strncpy(option, argv[index], 127); if (index + 1 < argc) { g_strncpy(value, argv[index + 1], 127); } else { value[0] = 0; } if ((g_strncasecmp(option, "-help", 255)) == 0 || (g_strncasecmp(option, "--help", 255)) == 0 || (g_strncasecmp(option, "-h", 255)) == 0) { startup_params->help = 1; } else if ((g_strncasecmp(option, "-kill", 255) == 0) || (g_strncasecmp(option, "--kill", 255) == 0) || (g_strncasecmp(option, "-k", 255) == 0)) { startup_params->kill = 1; } else if ((g_strncasecmp(option, "-nodaemon", 255) == 0) || (g_strncasecmp(option, "--nodaemon", 255) == 0) || (g_strncasecmp(option, "-n", 255) == 0) || (g_strncasecmp(option, "-nd", 255) == 0) || (g_strncasecmp(option, "--nd", 255) == 0) || (g_strncasecmp(option, "-ns", 255) == 0) || (g_strncasecmp(option, "--ns", 255) == 0)) { startup_params->no_daemon = 1; } else if ((g_strncasecmp(option, "-v", 255) == 0) || (g_strncasecmp(option, "--version", 255) == 0)) { startup_params->version = 1; } else if ((g_strncasecmp(option, "-p", 255) == 0) || (g_strncasecmp(option, "--port", 255) == 0)) { index++; g_strncpy(startup_params->port, value, 127); if (g_strlen(startup_params->port) < 1) { g_writeln("error processing params, port [%s]", startup_params->port); return 1; } else { g_writeln("--port parameter found, ini override [%s]", startup_params->port); } } else if ((g_strncasecmp(option, "-f", 255) == 0) || (g_strncasecmp(option, "--fork", 255) == 0)) { startup_params->fork = 1; g_writeln("--fork parameter found, ini override"); } else { return 1; } index++; } return 0; } /*****************************************************************************/ /* Basic sanity checks before any forking */ int xrdp_sanity_check(void) { int intval = 1; int host_be; char key_file[256]; /* check compiled endian with actual endian */ host_be = !((int)(*(unsigned char *)(&intval))); #if defined(B_ENDIAN) if (!host_be) { g_writeln("Not a big endian machine, edit arch.h"); return 1; } #endif #if defined(L_ENDIAN) if (host_be) { g_writeln("Not a little endian machine, edit arch.h"); return 1; } #endif /* check long, int and void* sizes */ if (sizeof(int) != 4) { g_writeln("unusable int size, must be 4"); return 1; } if (sizeof(long) != sizeof(void *)) { g_writeln("long size must match void* size"); return 1; } if (sizeof(long) != 4 && sizeof(long) != 8) { g_writeln("unusable long size, must be 4 or 8"); return 1; } if (sizeof(tui64) != 8) { g_writeln("unusable tui64 size, must be 8"); return 1; } g_snprintf(key_file, 255, "%s/rsakeys.ini", XRDP_CFG_PATH); if (!g_file_exist(key_file)) { g_writeln("File %s is missing, create it using xrdp-keygen", key_file); return 1; } return 0; } /*****************************************************************************/ int main(int argc, char **argv) { int exit_status = 0; int test; char cfg_file[256]; enum logReturns error; struct xrdp_startup_params *startup_params; int pid; int fd; int no_daemon; char text[256]; char pid_file[256]; g_init("xrdp"); ssl_init(); for (test = 0; test < argc; test++) { DEBUG(("Argument %i - %s", test, argv[test])); } g_snprintf(cfg_file, 255, "%s/xrdp.ini", XRDP_CFG_PATH); startup_params = (struct xrdp_startup_params *) g_malloc(sizeof(struct xrdp_startup_params), 1); if (xrdp_process_params(argc, argv, startup_params) != 0) { g_writeln("Unknown Parameter"); g_writeln("xrdp -h for help"); g_writeln("%s", ""); g_deinit(); g_exit(0); } g_snprintf(pid_file, 255, "%s/xrdp.pid", XRDP_PID_PATH); no_daemon = 0; if (startup_params->help) { g_writeln("%s", ""); g_writeln("xrdp: A Remote Desktop Protocol server."); g_writeln("Copyright (C) Jay Sorg 2004-2014"); g_writeln("See http://www.xrdp.org for more information."); g_writeln("%s", ""); g_writeln("Usage: xrdp [options]"); g_writeln(" -h, --help show help"); g_writeln(" -n, --nodaemon don't fork into background"); g_writeln(" -k, --kill shut down xrdp"); g_writeln(" -p, --port tcp listen port"); g_writeln(" -f, --fork fork on new connection"); g_writeln("%s", ""); g_deinit(); g_exit(0); } if (startup_params->version) { g_writeln("%s", ""); g_writeln("xrdp: A Remote Desktop Protocol server."); g_writeln("Copyright (C) Jay Sorg 2004-2014"); g_writeln("See http://www.xrdp.org for more information."); g_writeln("Version %s", PACKAGE_VERSION); g_writeln("%s", ""); g_deinit(); g_exit(0); } if (xrdp_sanity_check() != 0) { g_writeln("Fatal error occurred, exiting"); g_deinit(); g_exit(1); } if (startup_params->kill) { g_writeln("stopping xrdp"); /* read the xrdp.pid file */ fd = -1; if (g_file_exist(pid_file)) /* xrdp.pid */ { fd = g_file_open(pid_file); /* xrdp.pid */ } if (fd == -1) { g_writeln("cannot open %s, maybe xrdp is not running", pid_file); } else { g_memset(text, 0, 32); g_file_read(fd, text, 31); pid = g_atoi(text); g_writeln("stopping process id %d", pid); if (pid > 0) { g_sigterm(pid); } g_file_close(fd); } g_deinit(); g_exit(0); } /* starting logging subsystem */ error = log_start(cfg_file, "xrdp"); if (error != LOG_STARTUP_OK) { switch (error) { case LOG_ERROR_MALLOC: g_writeln("error on malloc. cannot start logging. quitting."); break; case LOG_ERROR_FILE_OPEN: g_writeln("error opening log file [%s]. quitting.", getLogFile(text, 255)); break; default: g_writeln("log_start error"); break; } g_deinit(); g_exit(1); } if (g_file_exist(pid_file)) /* xrdp.pid */ { g_writeln("It looks like xrdp is already running."); g_writeln("If not, delete %s and try again.", pid_file); g_deinit(); g_exit(0); } if (startup_params->no_daemon) { no_daemon = 1; } if (!no_daemon) { /* make sure containing directory exists */ g_create_path(pid_file); /* make sure we can write to pid file */ fd = g_file_open(pid_file); /* xrdp.pid */ if (fd == -1) { g_writeln("running in daemon mode with no access to pid files, quitting"); g_deinit(); g_exit(0); } if (g_file_write(fd, "0", 1) == -1) { g_writeln("running in daemon mode with no access to pid files, quitting"); g_deinit(); g_exit(0); } g_file_close(fd); g_file_delete(pid_file); } if (!no_daemon) { /* start of daemonizing code */ pid = g_fork(); if (pid == -1) { g_writeln("problem forking"); g_deinit(); g_exit(1); } if (0 != pid) { /* if can't listen, exit with failure status */ if (xrdp_listen_test() != 0) { log_message(LOG_LEVEL_ERROR, "Failed to start xrdp daemon, " "possibly address already in use."); g_deinit(); /* must exit with failure status, or systemd cannot detect xrdp daemon couldn't start properly */ g_exit(1); } g_writeln("daemon process %d started ok", pid); /* exit, this is the main process */ g_deinit(); g_exit(0); } g_sleep(1000); /* write the pid to file */ pid = g_getpid(); fd = g_file_open(pid_file); /* xrdp.pid */ if (fd == -1) { g_writeln("trying to write process id to xrdp.pid"); g_writeln("problem opening xrdp.pid"); g_writeln("maybe no rights"); } else { g_sprintf(text, "%d", pid); g_file_write(fd, text, g_strlen(text)); g_file_close(fd); } g_sleep(1000); g_file_close(0); g_file_close(1); g_file_close(2); if (g_file_open("/dev/null") < 0) { } if (g_file_open("/dev/null") < 0) { } if (g_file_open("/dev/null") < 0) { } /* end of daemonizing code */ } g_threadid = tc_get_threadid(); g_listen = xrdp_listen_create(); g_signal_user_interrupt(xrdp_shutdown); /* SIGINT */ g_signal_pipe(pipe_sig); /* SIGPIPE */ g_signal_terminate(xrdp_shutdown); /* SIGTERM */ g_signal_child_stop(xrdp_child); /* SIGCHLD */ g_sync_mutex = tc_mutex_create(); g_sync1_mutex = tc_mutex_create(); pid = g_getpid(); log_message(LOG_LEVEL_INFO, "starting xrdp with pid %d", pid); g_snprintf(text, 255, "xrdp_%8.8x_main_term", pid); g_term_event = g_create_wait_obj(text); if (g_term_event == 0) { g_writeln("error creating g_term_event"); } g_snprintf(text, 255, "xrdp_%8.8x_main_sync", pid); g_sync_event = g_create_wait_obj(text); if (g_sync_event == 0) { g_writeln("error creating g_sync_event"); } g_listen->startup_params = startup_params; exit_status = xrdp_listen_main_loop(g_listen); xrdp_listen_delete(g_listen); tc_mutex_delete(g_sync_mutex); tc_mutex_delete(g_sync1_mutex); g_delete_wait_obj(g_term_event); g_delete_wait_obj(g_sync_event); /* only main process should delete pid file */ if ((!no_daemon) && (pid == g_getpid())) { /* delete the xrdp.pid file */ g_file_delete(pid_file); } g_free(startup_params); log_end(); g_deinit(); if (exit_status == 0) { g_exit(0); } else { g_exit(1); } return 0; } xrdp-0.9.5/xrdp/funcs.c000644 001751 001751 00000012214 13174271344 014667 0ustar00metameta000000 000000 /** * xrdp: A Remote Desktop Protocol server. * * Copyright (C) Jay Sorg 2004-2014 * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. * * simple functions */ #if defined(HAVE_CONFIG_H) #include #endif #include "xrdp.h" /*****************************************************************************/ /* returns boolean */ int rect_contains_pt(struct xrdp_rect *in, int x, int y) { if (x < in->left) { return 0; } if (y < in->top) { return 0; } if (x >= in->right) { return 0; } if (y >= in->bottom) { return 0; } return 1; } /*****************************************************************************/ int rect_intersect(struct xrdp_rect *in1, struct xrdp_rect *in2, struct xrdp_rect *out) { int rv; struct xrdp_rect dumby; if (out == 0) { out = &dumby; } *out = *in1; if (in2->left > in1->left) { out->left = in2->left; } if (in2->top > in1->top) { out->top = in2->top; } if (in2->right < in1->right) { out->right = in2->right; } if (in2->bottom < in1->bottom) { out->bottom = in2->bottom; } rv = !ISRECTEMPTY(*out); if (!rv) { g_memset(out, 0, sizeof(struct xrdp_rect)); } return rv; } /*****************************************************************************/ /* returns boolean */ int rect_contained_by(struct xrdp_rect *in1, int left, int top, int right, int bottom) { if (left < in1->left || top < in1->top || right > in1->right || bottom > in1->bottom) { return 0; } else { return 1; } } /*****************************************************************************/ /* adjust the bounds to fit in the bitmap */ /* return false if there is nothing to draw else return true */ int check_bounds(struct xrdp_bitmap *b, int *x, int *y, int *cx, int *cy) { if (*x >= b->width) { return 0; } if (*y >= b->height) { return 0; } if (*x < 0) { *cx += *x; *x = 0; } if (*y < 0) { *cy += *y; *y = 0; } if (*cx <= 0) { return 0; } if (*cy <= 0) { return 0; } if (*x + *cx > b->width) { *cx = b->width - *x; } if (*y + *cy > b->height) { *cy = b->height - *y; } return 1; } /*****************************************************************************/ /* add a ch at index position in text, index starts at 0 */ /* if index = -1 add it to the end */ int add_char_at(char *text, int text_size, twchar ch, int index) { int len; int i; twchar *wstr; len = g_mbstowcs(0, text, 0); wstr = (twchar *)g_malloc((len + 16) * sizeof(twchar), 0); g_mbstowcs(wstr, text, len + 1); if ((index >= len) || (index < 0)) { wstr[len] = ch; wstr[len + 1] = 0; g_wcstombs(text, wstr, text_size); g_free(wstr); return 0; } for (i = (len - 1); i >= index; i--) { wstr[i + 1] = wstr[i]; } wstr[i + 1] = ch; wstr[len + 1] = 0; g_wcstombs(text, wstr, text_size); g_free(wstr); return 0; } /*****************************************************************************/ /* remove a ch at index position in text, index starts at 0 */ /* if index = -1 remove it from the end */ int remove_char_at(char *text, int text_size, int index) { int len; int i; twchar *wstr; len = g_mbstowcs(0, text, 0); if (len <= 0) { return 0; } wstr = (twchar *)g_malloc((len + 16) * sizeof(twchar), 0); g_mbstowcs(wstr, text, len + 1); if ((index >= (len - 1)) || (index < 0)) { wstr[len - 1] = 0; g_wcstombs(text, wstr, text_size); g_free(wstr); return 0; } for (i = index; i < (len - 1); i++) { wstr[i] = wstr[i + 1]; } wstr[len - 1] = 0; g_wcstombs(text, wstr, text_size); g_free(wstr); return 0; } /*****************************************************************************/ int set_string(char **in_str, const char *in) { if (in_str == 0) { return 0; } g_free(*in_str); *in_str = g_strdup(in); return 0; } /*****************************************************************************/ int wchar_repeat(twchar *dest, int dest_size_in_wchars, twchar ch, int repeat) { int index; for (index = 0; index < repeat; index++) { if (index >= dest_size_in_wchars) { break; } dest[index] = ch; } return 0; } xrdp-0.9.5/xrdp/xrdp_types.h000644 001751 001751 00000045511 13133557325 015766 0ustar00metameta000000 000000 /** * xrdp: A Remote Desktop Protocol server. * * Copyright (C) Jay Sorg 2004-2014 * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. * * types */ #ifndef _XRDP_TYPES_H_ #define _XRDP_TYPES_H_ #define DEFAULT_STRING_LEN 255 #define LOG_WINDOW_CHAR_PER_LINE 60 #include "xrdp_rail.h" #include "xrdp_constants.h" #include "fifo.h" #define MAX_NR_CHANNELS 16 #define MAX_CHANNEL_NAME 16 /* lib */ struct xrdp_mod { int size; /* size of this struct */ int version; /* internal version */ /* client functions */ int (*mod_start)(struct xrdp_mod* v, int w, int h, int bpp); int (*mod_connect)(struct xrdp_mod* v); int (*mod_event)(struct xrdp_mod* v, int msg, long param1, long param2, long param3, long param4); int (*mod_signal)(struct xrdp_mod* v); int (*mod_end)(struct xrdp_mod* v); int (*mod_set_param)(struct xrdp_mod *v, const char *name, const char *value); int (*mod_session_change)(struct xrdp_mod* v, int, int); int (*mod_get_wait_objs)(struct xrdp_mod* v, tbus* read_objs, int* rcount, tbus* write_objs, int* wcount, int* timeout); int (*mod_check_wait_objs)(struct xrdp_mod* v); int (*mod_frame_ack)(struct xrdp_mod* v, int flags, int frame_id); tintptr mod_dumby[100 - 10]; /* align, 100 minus the number of mod functions above */ /* server functions */ int (*server_begin_update)(struct xrdp_mod* v); int (*server_end_update)(struct xrdp_mod* v); int (*server_fill_rect)(struct xrdp_mod* v, int x, int y, int cx, int cy); int (*server_screen_blt)(struct xrdp_mod* v, int x, int y, int cx, int cy, int srcx, int srcy); int (*server_paint_rect)(struct xrdp_mod* v, int x, int y, int cx, int cy, char* data, int width, int height, int srcx, int srcy); int (*server_set_pointer)(struct xrdp_mod* v, int x, int y, char* data, char* mask); int (*server_palette)(struct xrdp_mod* v, int* palette); int (*server_msg)(struct xrdp_mod* v, char* msg, int code); int (*server_is_term)(struct xrdp_mod* v); int (*server_set_clip)(struct xrdp_mod* v, int x, int y, int cx, int cy); int (*server_reset_clip)(struct xrdp_mod* v); int (*server_set_fgcolor)(struct xrdp_mod* v, int fgcolor); int (*server_set_bgcolor)(struct xrdp_mod* v, int bgcolor); int (*server_set_opcode)(struct xrdp_mod* v, int opcode); int (*server_set_mixmode)(struct xrdp_mod* v, int mixmode); int (*server_set_brush)(struct xrdp_mod* v, int x_origin, int y_origin, int style, char* pattern); int (*server_set_pen)(struct xrdp_mod* v, int style, int width); int (*server_draw_line)(struct xrdp_mod* v, int x1, int y1, int x2, int y2); int (*server_add_char)(struct xrdp_mod* v, int font, int character, int offset, int baseline, int width, int height, char* data); int (*server_draw_text)(struct xrdp_mod* v, int font, int flags, int mixmode, int clip_left, int clip_top, int clip_right, int clip_bottom, int box_left, int box_top, int box_right, int box_bottom, int x, int y, char* data, int data_len); int (*server_reset)(struct xrdp_mod* v, int width, int height, int bpp); int (*server_query_channel)(struct xrdp_mod* v, int index, char* channel_name, int* channel_flags); int (*server_get_channel_id)(struct xrdp_mod* v, const char *name); int (*server_send_to_channel)(struct xrdp_mod* v, int channel_id, char* data, int data_len, int total_data_len, int flags); int (*server_bell_trigger)(struct xrdp_mod* v); /* off screen bitmaps */ int (*server_create_os_surface)(struct xrdp_mod* v, int rdpindex, int width, int height); int (*server_switch_os_surface)(struct xrdp_mod* v, int rdpindex); int (*server_delete_os_surface)(struct xrdp_mod* v, int rdpindex); int (*server_paint_rect_os)(struct xrdp_mod* mod, int x, int y, int cx, int cy, int rdpindex, int srcx, int srcy); int (*server_set_hints)(struct xrdp_mod* mod, int hints, int mask); /* rail */ int (*server_window_new_update)(struct xrdp_mod* mod, int window_id, struct rail_window_state_order* window_state, int flags); int (*server_window_delete)(struct xrdp_mod* mod, int window_id); int (*server_window_icon)(struct xrdp_mod* mod, int window_id, int cache_entry, int cache_id, struct rail_icon_info* icon_info, int flags); int (*server_window_cached_icon)(struct xrdp_mod* mod, int window_id, int cache_entry, int cache_id, int flags); int (*server_notify_new_update)(struct xrdp_mod* mod, int window_id, int notify_id, struct rail_notify_state_order* notify_state, int flags); int (*server_notify_delete)(struct xrdp_mod* mod, int window_id, int notify_id); int (*server_monitored_desktop)(struct xrdp_mod* mod, struct rail_monitored_desktop_order* mdo, int flags); int (*server_set_pointer_ex)(struct xrdp_mod* v, int x, int y, char* data, char* mask, int bpp); int (*server_add_char_alpha)(struct xrdp_mod* mod, int font, int character, int offset, int baseline, int width, int height, char* data); int (*server_create_os_surface_bpp)(struct xrdp_mod* v, int rdpindex, int width, int height, int bpp); int (*server_paint_rect_bpp)(struct xrdp_mod* v, int x, int y, int cx, int cy, char* data, int width, int height, int srcx, int srcy, int bpp); int (*server_composite)(struct xrdp_mod* v, int srcidx, int srcformat, int srcwidth, int srcrepeat, int* srctransform, int mskflags, int mskidx, int mskformat, int mskwidth, int mskrepeat, int op, int srcx, int srcy, int mskx, int msky, int dstx, int dsty, int width, int height, int dstformat); int (*server_paint_rects)(struct xrdp_mod* v, int num_drects, short *drects, int num_crects, short *crects, char *data, int width, int height, int flags, int frame_id); int (*server_session_info)(struct xrdp_mod* v, const char *data, int data_bytes); tintptr server_dumby[100 - 44]; /* align, 100 minus the number of server functions above */ /* common */ tintptr handle; /* pointer to self as int */ tintptr wm; /* struct xrdp_wm* */ tintptr painter; tintptr si; }; /* header for bmp file */ struct xrdp_bmp_header { int size; int image_width; int image_height; short planes; short bit_count; int compression; int image_size; int x_pels_per_meter; int y_pels_per_meter; int clr_used; int clr_important; }; struct xrdp_palette_item { int stamp; int palette[256]; }; struct xrdp_bitmap_item { int stamp; int lru_index; struct xrdp_bitmap* bitmap; }; struct xrdp_lru_item { int next; int prev; }; struct xrdp_os_bitmap_item { int id; struct xrdp_bitmap* bitmap; }; struct xrdp_char_item { int stamp; struct xrdp_font_char font_item; }; struct xrdp_pointer_item { int stamp; int x; /* hotspot */ int y; char data[32 * 32 * 4]; char mask[32 * 32 / 8]; int bpp; }; struct xrdp_brush_item { int stamp; /* expand this to a structure to handle more complicated brushes for now it's 8x8 1bpp brushes only */ char pattern[8]; }; /* moved to xrdp_constants.h #define XRDP_BITMAP_CACHE_ENTRIES 2048 */ /* difference caches */ struct xrdp_cache { struct xrdp_wm* wm; /* owner */ struct xrdp_session* session; /* palette */ int palette_stamp; struct xrdp_palette_item palette_items[6]; /* bitmap */ int bitmap_stamp; struct xrdp_bitmap_item bitmap_items[XRDP_MAX_BITMAP_CACHE_ID] [XRDP_MAX_BITMAP_CACHE_IDX]; /* lru optimize */ struct xrdp_lru_item bitmap_lrus[XRDP_MAX_BITMAP_CACHE_ID] [XRDP_MAX_BITMAP_CACHE_IDX]; int lru_head[XRDP_MAX_BITMAP_CACHE_ID]; int lru_tail[XRDP_MAX_BITMAP_CACHE_ID]; int lru_reset[XRDP_MAX_BITMAP_CACHE_ID]; /* crc optimize */ struct list16 crc16[XRDP_MAX_BITMAP_CACHE_ID][64 * 1024]; int use_bitmap_comp; int cache1_entries; int cache1_size; int cache2_entries; int cache2_size; int cache3_entries; int cache3_size; int bitmap_cache_persist_enable; int bitmap_cache_version; /* font */ int char_stamp; struct xrdp_char_item char_items[12][256]; /* pointer */ int pointer_stamp; struct xrdp_pointer_item pointer_items[32]; int pointer_cache_entries; int brush_stamp; struct xrdp_brush_item brush_items[64]; struct xrdp_os_bitmap_item os_bitmap_items[2000]; struct list* xrdp_os_del_list; }; /* defined later */ struct xrdp_enc_data; struct xrdp_mm { struct xrdp_wm* wm; /* owner */ int connected_state; /* true if connected to sesman else false */ struct trans* sesman_trans; /* connection to sesman */ int sesman_trans_up; /* true once connected to sesman */ int delete_sesman_trans; /* boolean set when done with sesman connection */ struct list* login_names; struct list* login_values; /* mod vars */ long mod_handle; /* returned from g_load_library */ struct xrdp_mod* (*mod_init)(void); int (*mod_exit)(struct xrdp_mod*); struct xrdp_mod* mod; /* module interface */ int display; /* 10 for :10.0, 11 for :11.0, etc */ int code; /* 0=Xvnc session, 10=X11rdp session, 20=xorg driver mode */ int sesman_controlled; /* true if this is a sesman session */ struct trans* chan_trans; /* connection to chansrv */ int chan_trans_up; /* true once connected to chansrv */ int delete_chan_trans; /* boolean set when done with channel connection */ int usechansrv; /* true if chansrvport is set in xrdp.ini or using sesman */ struct xrdp_encoder *encoder; }; struct xrdp_key_info { int sym; int chr; }; struct xrdp_keymap { struct xrdp_key_info keys_noshift[256]; struct xrdp_key_info keys_shift[256]; struct xrdp_key_info keys_altgr[256]; struct xrdp_key_info keys_shiftaltgr[256]; struct xrdp_key_info keys_capslock[256]; struct xrdp_key_info keys_capslockaltgr[256]; struct xrdp_key_info keys_shiftcapslock[256]; struct xrdp_key_info keys_shiftcapslockaltgr[256]; }; /* the window manager */ struct xrdp_wm { struct xrdp_process* pro_layer; /* owner */ struct xrdp_bitmap* screen; struct xrdp_session* session; struct xrdp_painter* painter; struct xrdp_cache* cache; int palette[256]; struct xrdp_bitmap* login_window; /* generic colors */ int black; int grey; int dark_grey; int blue; int dark_blue; int white; int red; int green; int background; /* dragging info */ int dragging; int draggingx; int draggingy; int draggingcx; int draggingcy; int draggingdx; int draggingdy; int draggingorgx; int draggingorgy; int draggingxorstate; struct xrdp_bitmap* dragging_window; /* the down(clicked) button */ struct xrdp_bitmap* button_down; /* popup for combo box */ struct xrdp_bitmap* popup_wnd; /* focused window */ struct xrdp_bitmap* focused_window; /* pointer */ int current_pointer; int mouse_x; int mouse_y; /* keyboard info */ int keys[256]; /* key states 0 up 1 down*/ int caps_lock; int scroll_lock; int num_lock; /* client info */ struct xrdp_client_info* client_info; /* session log */ struct list* log; struct xrdp_bitmap* log_wnd; int login_mode; tbus login_mode_event; struct xrdp_mm* mm; struct xrdp_font* default_font; struct xrdp_keymap keymap; int hide_log_window; struct xrdp_bitmap* target_surface; /* either screen or os surface */ int current_surface_index; int hints; int allowedchannels[MAX_NR_CHANNELS]; int allowedinitialized ; char pamerrortxt[256]; /* configuration derived from xrdp.ini */ struct xrdp_config *xrdp_config; }; /* rdp process */ struct xrdp_process { int status; struct trans* server_trans; /* in tcp server mode */ tbus self_term_event; struct xrdp_listen* lis_layer; /* owner */ struct xrdp_session* session; /* create these when up and running */ struct xrdp_wm* wm; //int app_sck; tbus done_event; int session_id; }; /* rdp listener */ struct xrdp_listen { int status; struct trans* listen_trans; /* in tcp listen mode */ struct list* process_list; tbus pro_done_event; struct xrdp_startup_params* startup_params; }; /* region */ struct xrdp_region { struct xrdp_wm* wm; /* owner */ struct pixman_region16 *reg; }; /* painter */ struct xrdp_painter { int rop; struct xrdp_rect* use_clip; /* nil if not using clip */ struct xrdp_rect clip; int clip_children; int bg_color; int fg_color; int mix_mode; struct xrdp_brush brush; struct xrdp_pen pen; struct xrdp_session* session; struct xrdp_wm* wm; /* owner */ struct xrdp_font* font; void *painter; struct xrdp_region *dirty_region; int begin_end_level; }; /* window or bitmap */ struct xrdp_bitmap { /* 0 = bitmap 1 = window 2 = screen 3 = button 4 = image 5 = edit 6 = label 7 = combo 8 = special */ int type; int width; int height; struct xrdp_wm* wm; /* msg 1 = click 2 = mouse move 3 = paint 100 = modal result */ /* see messages in constants.h */ int (*notify)(struct xrdp_bitmap* wnd, struct xrdp_bitmap* sender, int msg, long param1, long param2); /* for bitmap */ int bpp; int line_size; /* in bytes */ int do_not_free_data; char* data; /* for all but bitmap */ int left; int top; int pointer; int bg_color; int tab_stop; int id; char* caption1; /* for window or screen */ struct xrdp_bitmap* modal_dialog; struct xrdp_bitmap* focused_control; struct xrdp_bitmap* owner; /* window that created us */ struct xrdp_bitmap* parent; /* window contained in */ /* for modal dialog */ struct xrdp_bitmap* default_button; /* button when enter is pressed */ struct xrdp_bitmap* esc_button; /* button when esc is pressed */ /* list of child windows */ struct list* child_list; /* for edit */ int edit_pos; twchar password_char; /* for button or combo */ int state; /* for button 0 = normal 1 = down */ /* for combo */ struct list* string_list; struct list* data_list; /* for combo or popup */ int item_index; /* for popup */ struct xrdp_bitmap* popped_from; int item_height; /* crc */ int crc32; int crc16; }; #define NUM_FONTS 0x4e00 #define DEFAULT_FONT_NAME "sans-10.fv1" #define DEFAULT_ELEMENT_TOP 35 #define DEFAULT_BUTTON_W 60 #define DEFAULT_BUTTON_H 23 #define DEFAULT_COMBO_W 210 #define DEFAULT_COMBO_H 21 #define DEFAULT_EDIT_W 210 #define DEFAULT_EDIT_H 21 #define DEFAULT_WND_LOGIN_W 425 #define DEFAULT_WND_LOGIN_H 475 #define DEFAULT_WND_HELP_W 340 #define DEFAULT_WND_HELP_H 300 #define DEFAULT_WND_LOG_W 400 #define DEFAULT_WND_LOG_H 400 #define DEFAULT_WND_SPECIAL_H 100 /* font */ struct xrdp_font { struct xrdp_wm* wm; struct xrdp_font_char font_items[NUM_FONTS]; char name[32]; int size; int style; }; /* module */ struct xrdp_mod_data { struct list* names; struct list* values; }; struct xrdp_startup_params { char port[128]; int kill; int no_daemon; int help; int version; int fork; int send_buffer_bytes; int recv_buffer_bytes; }; /* * For storing xrdp.ini configuration settings */ struct xrdp_cfg_globals { int ini_version; /* xrdp.ini file version number */ int use_bitmap_cache; int use_bitmap_compression; int port; int crypt_level; /* low=1, medium=2, high=3 */ int allow_channels; int max_bpp; int fork; int tcp_nodelay; int tcp_keepalive; int tcp_send_buffer_bytes; int tcp_recv_buffer_bytes; char autorun[256]; int hidelogwindow; int require_credentials; int bulk_compression; int new_cursors; int nego_sec_layer; int allow_multimon; /* colors */ int grey; int black; int dark_grey; int blue; int dark_blue; int white; int red; int green; int background; /* login screen */ int ls_top_window_bg_color; /* top level window background color */ int ls_width; /* window width */ int ls_height; /* window height */ int ls_bg_color; /* background color */ char ls_logo_filename[256]; /* logo filename */ char ls_background_image[256]; /* background image file name */ int ls_logo_x_pos; /* logo x co-ordinate */ int ls_logo_y_pos; /* logo y co-ordinate */ int ls_label_x_pos; /* x pos of labels */ int ls_label_width; /* width of labels */ int ls_input_x_pos; /* x pos of text and combo boxes */ int ls_input_width; /* width of input and combo boxes */ int ls_input_y_pos; /* y pos for for first label and combo box */ int ls_btn_ok_x_pos; /* x pos for OK button */ int ls_btn_ok_y_pos; /* y pos for OK button */ int ls_btn_ok_width; /* width of OK button */ int ls_btn_ok_height; /* height of OK button */ int ls_btn_cancel_x_pos; /* x pos for Cancel button */ int ls_btn_cancel_y_pos; /* y pos for Cancel button */ int ls_btn_cancel_width; /* width of Cancel button */ int ls_btn_cancel_height; /* height of Cancel button */ char ls_title[256]; /* loginscreen window title */ }; struct xrdp_cfg_logging { }; struct xrdp_cfg_channels { }; struct xrdp_config { struct xrdp_cfg_globals cfg_globals; struct xrdp_cfg_logging cfg_logging; struct xrdp_cfg_channels cfg_channels; }; #endif xrdp-0.9.5/xrdp/xrdp_bitmap.c000644 001751 001751 00000174665 13220727201 016073 0ustar00metameta000000 000000 /** * xrdp: A Remote Desktop Protocol server. * * Copyright (C) Jay Sorg 2004-2014 * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. * * bitmap, drawable * this is a object that can be drawn on with a painter * all windows, bitmaps, even the screen are of this type * maybe it should be called xrdp_drawable */ #if defined(HAVE_CONFIG_H) #include #endif #include "xrdp.h" #include "log.h" #define LLOG_LEVEL 1 #define LLOGLN(_level, _args) \ do \ { \ if (_level < LLOG_LEVEL) \ { \ g_write("xrdp:xrdp_bitmap [%10.10u]: ", g_time3()); \ g_writeln _args ; \ } \ } \ while (0) static const unsigned int g_crc_table[256] = { 0x00000000, 0x77073096, 0xee0e612c, 0x990951ba, 0x076dc419, 0x706af48f, 0xe963a535, 0x9e6495a3, 0x0edb8832, 0x79dcb8a4, 0xe0d5e91e, 0x97d2d988, 0x09b64c2b, 0x7eb17cbd, 0xe7b82d07, 0x90bf1d91, 0x1db71064, 0x6ab020f2, 0xf3b97148, 0x84be41de, 0x1adad47d, 0x6ddde4eb, 0xf4d4b551, 0x83d385c7, 0x136c9856, 0x646ba8c0, 0xfd62f97a, 0x8a65c9ec, 0x14015c4f, 0x63066cd9, 0xfa0f3d63, 0x8d080df5, 0x3b6e20c8, 0x4c69105e, 0xd56041e4, 0xa2677172, 0x3c03e4d1, 0x4b04d447, 0xd20d85fd, 0xa50ab56b, 0x35b5a8fa, 0x42b2986c, 0xdbbbc9d6, 0xacbcf940, 0x32d86ce3, 0x45df5c75, 0xdcd60dcf, 0xabd13d59, 0x26d930ac, 0x51de003a, 0xc8d75180, 0xbfd06116, 0x21b4f4b5, 0x56b3c423, 0xcfba9599, 0xb8bda50f, 0x2802b89e, 0x5f058808, 0xc60cd9b2, 0xb10be924, 0x2f6f7c87, 0x58684c11, 0xc1611dab, 0xb6662d3d, 0x76dc4190, 0x01db7106, 0x98d220bc, 0xefd5102a, 0x71b18589, 0x06b6b51f, 0x9fbfe4a5, 0xe8b8d433, 0x7807c9a2, 0x0f00f934, 0x9609a88e, 0xe10e9818, 0x7f6a0dbb, 0x086d3d2d, 0x91646c97, 0xe6635c01, 0x6b6b51f4, 0x1c6c6162, 0x856530d8, 0xf262004e, 0x6c0695ed, 0x1b01a57b, 0x8208f4c1, 0xf50fc457, 0x65b0d9c6, 0x12b7e950, 0x8bbeb8ea, 0xfcb9887c, 0x62dd1ddf, 0x15da2d49, 0x8cd37cf3, 0xfbd44c65, 0x4db26158, 0x3ab551ce, 0xa3bc0074, 0xd4bb30e2, 0x4adfa541, 0x3dd895d7, 0xa4d1c46d, 0xd3d6f4fb, 0x4369e96a, 0x346ed9fc, 0xad678846, 0xda60b8d0, 0x44042d73, 0x33031de5, 0xaa0a4c5f, 0xdd0d7cc9, 0x5005713c, 0x270241aa, 0xbe0b1010, 0xc90c2086, 0x5768b525, 0x206f85b3, 0xb966d409, 0xce61e49f, 0x5edef90e, 0x29d9c998, 0xb0d09822, 0xc7d7a8b4, 0x59b33d17, 0x2eb40d81, 0xb7bd5c3b, 0xc0ba6cad, 0xedb88320, 0x9abfb3b6, 0x03b6e20c, 0x74b1d29a, 0xead54739, 0x9dd277af, 0x04db2615, 0x73dc1683, 0xe3630b12, 0x94643b84, 0x0d6d6a3e, 0x7a6a5aa8, 0xe40ecf0b, 0x9309ff9d, 0x0a00ae27, 0x7d079eb1, 0xf00f9344, 0x8708a3d2, 0x1e01f268, 0x6906c2fe, 0xf762575d, 0x806567cb, 0x196c3671, 0x6e6b06e7, 0xfed41b76, 0x89d32be0, 0x10da7a5a, 0x67dd4acc, 0xf9b9df6f, 0x8ebeeff9, 0x17b7be43, 0x60b08ed5, 0xd6d6a3e8, 0xa1d1937e, 0x38d8c2c4, 0x4fdff252, 0xd1bb67f1, 0xa6bc5767, 0x3fb506dd, 0x48b2364b, 0xd80d2bda, 0xaf0a1b4c, 0x36034af6, 0x41047a60, 0xdf60efc3, 0xa867df55, 0x316e8eef, 0x4669be79, 0xcb61b38c, 0xbc66831a, 0x256fd2a0, 0x5268e236, 0xcc0c7795, 0xbb0b4703, 0x220216b9, 0x5505262f, 0xc5ba3bbe, 0xb2bd0b28, 0x2bb45a92, 0x5cb36a04, 0xc2d7ffa7, 0xb5d0cf31, 0x2cd99e8b, 0x5bdeae1d, 0x9b64c2b0, 0xec63f226, 0x756aa39c, 0x026d930a, 0x9c0906a9, 0xeb0e363f, 0x72076785, 0x05005713, 0x95bf4a82, 0xe2b87a14, 0x7bb12bae, 0x0cb61b38, 0x92d28e9b, 0xe5d5be0d, 0x7cdcefb7, 0x0bdbdf21, 0x86d3d2d4, 0xf1d4e242, 0x68ddb3f8, 0x1fda836e, 0x81be16cd, 0xf6b9265b, 0x6fb077e1, 0x18b74777, 0x88085ae6, 0xff0f6a70, 0x66063bca, 0x11010b5c, 0x8f659eff, 0xf862ae69, 0x616bffd3, 0x166ccf45, 0xa00ae278, 0xd70dd2ee, 0x4e048354, 0x3903b3c2, 0xa7672661, 0xd06016f7, 0x4969474d, 0x3e6e77db, 0xaed16a4a, 0xd9d65adc, 0x40df0b66, 0x37d83bf0, 0xa9bcae53, 0xdebb9ec5, 0x47b2cf7f, 0x30b5ffe9, 0xbdbdf21c, 0xcabac28a, 0x53b39330, 0x24b4a3a6, 0xbad03605, 0xcdd70693, 0x54de5729, 0x23d967bf, 0xb3667a2e, 0xc4614ab8, 0x5d681b02, 0x2a6f2b94, 0xb40bbe37, 0xc30c8ea1, 0x5a05df1b, 0x2d02ef8d }; #define CRC_START(in_crc) (in_crc) = 0xFFFFFFFF #define CRC_PASS(in_pixel, in_crc) \ (in_crc) = g_crc_table[((in_crc) ^ (in_pixel)) & 0xff] ^ ((in_crc) >> 8) #define CRC_END(in_crc) (in_crc) = ((in_crc) ^ 0xFFFFFFFF) /*****************************************************************************/ struct xrdp_bitmap * xrdp_bitmap_create(int width, int height, int bpp, int type, struct xrdp_wm *wm) { struct xrdp_bitmap *self = (struct xrdp_bitmap *)NULL; int Bpp = 0; self = (struct xrdp_bitmap *)g_malloc(sizeof(struct xrdp_bitmap), 1); self->type = type; self->width = width; self->height = height; self->bpp = bpp; Bpp = 4; switch (bpp) { case 8: Bpp = 1; break; case 15: Bpp = 2; break; case 16: Bpp = 2; break; } if (self->type == WND_TYPE_BITMAP || self->type == WND_TYPE_IMAGE) { self->data = (char *)g_malloc(width * height * Bpp, 0); } #if defined(XRDP_PAINTER) if (self->type == WND_TYPE_SCREEN) /* noorders */ { LLOGLN(0, ("xrdp_bitmap_create: noorders")); self->data = (char *) g_malloc(width * height * Bpp, 0); } #endif if (self->type != WND_TYPE_BITMAP) { self->child_list = list_create(); } self->line_size = width * Bpp; if (self->type == WND_TYPE_COMBO) { self->string_list = list_create(); self->string_list->auto_free = 1; self->data_list = list_create(); self->data_list->auto_free = 1; } self->wm = wm; return self; } /*****************************************************************************/ struct xrdp_bitmap * xrdp_bitmap_create_with_data(int width, int height, int bpp, char *data, struct xrdp_wm *wm) { struct xrdp_bitmap *self = (struct xrdp_bitmap *)NULL; int Bpp; #if defined(NEED_ALIGN) tintptr data_as_int; #endif self = (struct xrdp_bitmap *)g_malloc(sizeof(struct xrdp_bitmap), 1); self->type = WND_TYPE_BITMAP; self->width = width; self->height = height; self->bpp = bpp; self->wm = wm; Bpp = 4; switch (bpp) { case 8: Bpp = 1; break; case 15: Bpp = 2; break; case 16: Bpp = 2; break; } self->line_size = width * Bpp; #if defined(NEED_ALIGN) data_as_int = (tintptr) data; if (((bpp >= 24) && (data_as_int & 3)) || (((bpp == 15) || (bpp == 16)) && (data_as_int & 1))) { /* got to copy data here, it's not aligned other calls in this file assume alignment */ self->data = (char *)g_malloc(width * height * Bpp, 0); g_memcpy(self->data, data, width * height * Bpp); return self; } #endif self->data = data; self->do_not_free_data = 1; return self; } /*****************************************************************************/ void xrdp_bitmap_delete(struct xrdp_bitmap *self) { int i = 0; struct xrdp_mod_data *mod_data = (struct xrdp_mod_data *)NULL; if (self == 0) { return; } if (self->wm != 0) { if (self->wm->focused_window != 0) { if (self->wm->focused_window->focused_control == self) { self->wm->focused_window->focused_control = 0; } } if (self->wm->focused_window == self) { self->wm->focused_window = 0; } if (self->wm->dragging_window == self) { self->wm->dragging_window = 0; } if (self->wm->button_down == self) { self->wm->button_down = 0; } if (self->wm->popup_wnd == self) { self->wm->popup_wnd = 0; } if (self->wm->login_window == self) { self->wm->login_window = 0; } if (self->wm->log_wnd == self) { self->wm->log_wnd = 0; } } if (self->child_list != 0) { for (i = self->child_list->count - 1; i >= 0; i--) { xrdp_bitmap_delete((struct xrdp_bitmap *)self->child_list->items[i]); } list_delete(self->child_list); } if (self->parent != 0) { i = list_index_of(self->parent->child_list, (long)self); if (i >= 0) { list_remove_item(self->parent->child_list, i); } } if (self->string_list != 0) /* for combo */ { list_delete(self->string_list); } if (self->data_list != 0) /* for combo */ { for (i = 0; i < self->data_list->count; i++) { mod_data = (struct xrdp_mod_data *)list_get_item(self->data_list, i); if (mod_data != 0) { list_delete(mod_data->names); list_delete(mod_data->values); } } list_delete(self->data_list); } if (!self->do_not_free_data) { g_free(self->data); } g_free(self->caption1); g_free(self); } /*****************************************************************************/ struct xrdp_bitmap * xrdp_bitmap_get_child_by_id(struct xrdp_bitmap *self, int id) { int i = 0; struct xrdp_bitmap *b = (struct xrdp_bitmap *)NULL; for (i = 0; i < self->child_list->count; i++) { b = (struct xrdp_bitmap *)list_get_item(self->child_list, i); if (b->id == id) { return b; } } return 0; } /*****************************************************************************/ /* if focused is true focus this window else unfocus it */ /* returns error */ int xrdp_bitmap_set_focus(struct xrdp_bitmap *self, int focused) { struct xrdp_painter *painter = (struct xrdp_painter *)NULL; if (self == 0) { return 0; } if (self->type != WND_TYPE_WND) /* 1 */ { return 0; } painter = xrdp_painter_create(self->wm, self->wm->session); xrdp_painter_font_needed(painter); xrdp_painter_begin_update(painter); if (focused) { /* active title bar */ painter->fg_color = self->wm->blue; xrdp_painter_fill_rect(painter, self, 3, 3, self->width - 5, 18); painter->fg_color = self->wm->white; } else { /* inactive title bar */ painter->fg_color = self->wm->dark_grey; xrdp_painter_fill_rect(painter, self, 3, 3, self->width - 5, 18); painter->fg_color = self->wm->black; } xrdp_painter_draw_text(painter, self, 4, 4, self->caption1); xrdp_painter_end_update(painter); xrdp_painter_delete(painter); return 0; } /*****************************************************************************/ static int xrdp_bitmap_get_index(struct xrdp_bitmap *self, int *palette, int color) { int r = 0; int g = 0; int b = 0; r = (color & 0xff0000) >> 16; g = (color & 0x00ff00) >> 8; b = (color & 0x0000ff) >> 0; r = (r >> 5) << 0; g = (g >> 5) << 3; b = (b >> 6) << 6; return (b | g | r); } /*****************************************************************************/ /* returns error */ int xrdp_bitmap_resize(struct xrdp_bitmap *self, int width, int height) { int Bpp = 0; if ((width == self->width) && (height == self->height)) { return 0; } if (self->do_not_free_data) { return 1; } self->width = width; self->height = height; Bpp = 4; switch (self->bpp) { case 8: Bpp = 1; break; case 15: Bpp = 2; break; case 16: Bpp = 2; break; } g_free(self->data); self->data = (char *)g_malloc(width * height * Bpp, 0); self->line_size = width * Bpp; return 0; } /*****************************************************************************/ /* load a bmp file */ /* return 0 ok */ /* return 1 error */ int xrdp_bitmap_load(struct xrdp_bitmap *self, const char *filename, int *palette) { int fd = 0; int i = 0; int j = 0; int k = 0; int color = 0; int size = 0; int palette1[256]; char type1[4]; struct xrdp_bmp_header header; struct stream *s = (struct stream *)NULL; g_memset(palette1, 0, sizeof(int) * 256); g_memset(type1, 0, sizeof(char) * 4); g_memset(&header, 0, sizeof(struct xrdp_bmp_header)); if (!g_file_exist(filename)) { log_message(LOG_LEVEL_ERROR, "xrdp_bitmap_load: error bitmap file [%s] " "does not exist", filename); return 1; } fd = g_file_open(filename); if (fd != -1) { /* read file type */ if (g_file_read(fd, type1, 2) != 2) { log_message(LOG_LEVEL_ERROR, "xrdp_bitmap_load: error bitmap file [%s] " "read error", filename); g_file_close(fd); return 1; } if ((type1[0] != 'B') || (type1[1] != 'M')) { log_message(LOG_LEVEL_ERROR, "xrdp_bitmap_load: error bitmap file [%s] " "not BMP file", filename); g_file_close(fd); return 1; } /* read file size */ make_stream(s); init_stream(s, 8192); g_file_read(fd, s->data, 4); in_uint32_le(s, size); /* read bmp header */ if (g_file_seek(fd, 14) < 0) { log_message(LOG_LEVEL_ERROR, "xrdp_bitmap_load: seek error in file %s", filename); free_stream(s); g_file_close(fd); return 1; } init_stream(s, 8192); g_file_read(fd, s->data, 40); /* size better be 40 */ in_uint32_le(s, header.size); in_uint32_le(s, header.image_width); in_uint32_le(s, header.image_height); in_uint16_le(s, header.planes); in_uint16_le(s, header.bit_count); in_uint32_le(s, header.compression); in_uint32_le(s, header.image_size); in_uint32_le(s, header.x_pels_per_meter); in_uint32_le(s, header.y_pels_per_meter); in_uint32_le(s, header.clr_used); in_uint32_le(s, header.clr_important); if ((header.bit_count != 4) && (header.bit_count != 8) && (header.bit_count != 24)) { log_message(LOG_LEVEL_ERROR, "xrdp_bitmap_load: error bitmap file [%s] " "bad bpp %d", filename, header.bit_count); free_stream(s); g_file_close(fd); return 1; } if (header.bit_count == 24) /* 24 bit bitmap */ { if (g_file_seek(fd, 14 + header.size) < 0) { log_message(LOG_LEVEL_ERROR, "xrdp_bitmap_load: seek error in file %s", filename); } xrdp_bitmap_resize(self, header.image_width, header.image_height); size = header.image_width * header.image_height * 3; init_stream(s, size); /* read data */ for (i = header.image_height - 1; i >= 0; i--) { size = header.image_width * 3; k = g_file_read(fd, s->data + i * size, size); if (k != size) { log_message(LOG_LEVEL_ERROR, "xrdp_bitmap_load: error bitmap " "file [%s] read", filename); } } for (i = 0; i < self->height; i++) { for (j = 0; j < self->width; j++) { in_uint8(s, k); color = k; in_uint8(s, k); color |= k << 8; in_uint8(s, k); color |= k << 16; if (self->bpp == 8) { color = xrdp_bitmap_get_index(self, palette, color); } else if (self->bpp == 15) { color = COLOR15((color & 0xff0000) >> 16, (color & 0x00ff00) >> 8, (color & 0x0000ff) >> 0); } else if (self->bpp == 16) { color = COLOR16((color & 0xff0000) >> 16, (color & 0x00ff00) >> 8, (color & 0x0000ff) >> 0); } xrdp_bitmap_set_pixel(self, j, i, color); } } } else if (header.bit_count == 8) /* 8 bit bitmap */ { /* read palette */ if (g_file_seek(fd, 14 + header.size) < 0) { log_message(LOG_LEVEL_ERROR, "xrdp_bitmap_load: seek error in file %s", filename); } init_stream(s, 8192); g_file_read(fd, s->data, header.clr_used * sizeof(int)); for (i = 0; i < header.clr_used; i++) { in_uint32_le(s, palette1[i]); } xrdp_bitmap_resize(self, header.image_width, header.image_height); size = header.image_width * header.image_height; init_stream(s, size); /* read data */ for (i = header.image_height - 1; i >= 0; i--) { size = header.image_width; k = g_file_read(fd, s->data + i * size, size); if (k != size) { log_message(LOG_LEVEL_ERROR, "xrdp_bitmap_load: error bitmap " "file [%s] read", filename); } } for (i = 0; i < self->height; i++) { for (j = 0; j < self->width; j++) { in_uint8(s, k); color = palette1[k]; if (self->bpp == 8) { color = xrdp_bitmap_get_index(self, palette, color); } else if (self->bpp == 15) { color = COLOR15((color & 0xff0000) >> 16, (color & 0x00ff00) >> 8, (color & 0x0000ff) >> 0); } else if (self->bpp == 16) { color = COLOR16((color & 0xff0000) >> 16, (color & 0x00ff00) >> 8, (color & 0x0000ff) >> 0); } xrdp_bitmap_set_pixel(self, j, i, color); } } } else if (header.bit_count == 4) /* 4 bit bitmap */ { /* read palette */ if (g_file_seek(fd, 14 + header.size) < 0) { log_message(LOG_LEVEL_ERROR, "xrdp_bitmap_load: seek error in file %s", filename); } init_stream(s, 8192); g_file_read(fd, s->data, header.clr_used * sizeof(int)); for (i = 0; i < header.clr_used; i++) { in_uint32_le(s, palette1[i]); } xrdp_bitmap_resize(self, header.image_width, header.image_height); size = (header.image_width * header.image_height) / 2; init_stream(s, size); /* read data */ for (i = header.image_height - 1; i >= 0; i--) { size = header.image_width / 2; k = g_file_read(fd, s->data + i * size, size); if (k != size) { log_message(LOG_LEVEL_ERROR, "xrdp_bitmap_load: error bitmap " "file [%s] read", filename); } } for (i = 0; i < self->height; i++) { for (j = 0; j < self->width; j++) { if ((j & 1) == 0) { in_uint8(s, k); color = (k >> 4) & 0xf; } else { color = k & 0xf; } color = palette1[color]; if (self->bpp == 8) { color = xrdp_bitmap_get_index(self, palette, color); } else if (self->bpp == 15) { color = COLOR15((color & 0xff0000) >> 16, (color & 0x00ff00) >> 8, (color & 0x0000ff) >> 0); } else if (self->bpp == 16) { color = COLOR16((color & 0xff0000) >> 16, (color & 0x00ff00) >> 8, (color & 0x0000ff) >> 0); } xrdp_bitmap_set_pixel(self, j, i, color); } } } g_file_close(fd); free_stream(s); } else { log_message(LOG_LEVEL_ERROR, "xrdp_bitmap_load: error loading bitmap " "from file [%s]", filename); return 1; } return 0; } /*****************************************************************************/ int xrdp_bitmap_get_pixel(struct xrdp_bitmap *self, int x, int y) { if (self == 0) { return 0; } if (self->data == 0) { return 0; } if (x >= 0 && x < self->width && y >= 0 && y < self->height) { if (self->bpp == 8) { return GETPIXEL8(self->data, x, y, self->width); } else if (self->bpp == 15 || self->bpp == 16) { return GETPIXEL16(self->data, x, y, self->width); } else if (self->bpp >= 24) { return GETPIXEL32(self->data, x, y, self->width); } } return 0; } /*****************************************************************************/ int xrdp_bitmap_set_pixel(struct xrdp_bitmap *self, int x, int y, int pixel) { if (self == 0) { return 0; } if (self->data == 0) { return 0; } if (x >= 0 && x < self->width && y >= 0 && y < self->height) { if (self->bpp == 8) { SETPIXEL8(self->data, x, y, self->width, pixel); } else if (self->bpp == 15 || self->bpp == 16) { SETPIXEL16(self->data, x, y, self->width, pixel); } else if (self->bpp >= 24) { SETPIXEL32(self->data, x, y, self->width, pixel); } } return 0; } /*****************************************************************************/ /* copy part of self at x, y to 0, 0 in dest */ /* returns error */ int xrdp_bitmap_copy_box(struct xrdp_bitmap *self, struct xrdp_bitmap *dest, int x, int y, int cx, int cy) { int i; int destx; int desty; int incs; int incd; tui8 *s8; tui8 *d8; tui16 *s16; tui16 *d16; tui32 *s32; tui32 *d32; if (self == 0) { return 1; } if (dest == 0) { return 1; } if (self->type != WND_TYPE_BITMAP && self->type != WND_TYPE_IMAGE) { return 1; } if (dest->type != WND_TYPE_BITMAP && dest->type != WND_TYPE_IMAGE) { return 1; } if (self->bpp != dest->bpp) { return 1; } destx = 0; desty = 0; if (!check_bounds(self, &x, &y, &cx, &cy)) { return 1; } if (!check_bounds(dest, &destx, &desty, &cx, &cy)) { return 1; } if (self->bpp >= 24) { s32 = ((tui32 *)(self->data)) + (self->width * y + x); d32 = ((tui32 *)(dest->data)) + (dest->width * desty + destx); incs = self->width - cx; incd = dest->width - cx; for (i = 0; i < cy; i++) { g_memcpy(d32, s32, cx * 4); s32 += cx; d32 += cx; s32 += incs; d32 += incd; } } else if (self->bpp == 15 || self->bpp == 16) { s16 = ((tui16 *)(self->data)) + (self->width * y + x); d16 = ((tui16 *)(dest->data)) + (dest->width * desty + destx); incs = self->width - cx; incd = dest->width - cx; for (i = 0; i < cy; i++) { g_memcpy(d16, s16, cx * 2); s16 += cx; d16 += cx; s16 += incs; d16 += incd; } } else if (self->bpp == 8) { s8 = ((tui8 *)(self->data)) + (self->width * y + x); d8 = ((tui8 *)(dest->data)) + (dest->width * desty + destx); incs = self->width - cx; incd = dest->width - cx; for (i = 0; i < cy; i++) { g_memcpy(d8, s8, cx); s8 += cx; d8 += cx; s8 += incs; d8 += incd; } } else { return 1; } return 0; } /*****************************************************************************/ int xrdp_bitmap_hash_crc(struct xrdp_bitmap *self) { void *hash; int bytes; int crc; int index; char hash_data[16]; if (self->bpp >= 24) { bytes = self->width * self->height * 4; } else if (self->bpp == 15 || self->bpp == 16) { bytes = self->width * self->height * 2; } else if (self->bpp == 8) { bytes = self->width * self->height; } else { return 1; } hash = ssl_md5_info_create(); ssl_md5_transform(hash, self->data, bytes); ssl_md5_complete(hash, hash_data); ssl_md5_info_delete(hash); CRC_START(crc); CRC_PASS(self->width, crc); CRC_PASS(self->width >> 8, crc); CRC_PASS(self->height, crc); CRC_PASS(self->height >> 8, crc); for (index = 0; index < 16; index++) { CRC_PASS(hash_data[index], crc); } CRC_END(crc); self->crc32 = crc; self->crc16 = self->crc32 & 0xffff; return 0; } /*****************************************************************************/ /* copy part of self at x, y to 0, 0 in dest */ /* returns error */ int xrdp_bitmap_copy_box_with_crc(struct xrdp_bitmap *self, struct xrdp_bitmap *dest, int x, int y, int cx, int cy) { int i; int j; int destx; int desty; int pixel; int crc; int incs; int incd; tui8 *s8; tui8 *d8; tui16 *s16; tui16 *d16; tui32 *s32; tui32 *d32; if (self == 0) { return 1; } if (dest == 0) { return 1; } if (self->type != WND_TYPE_BITMAP && self->type != WND_TYPE_IMAGE) { return 1; } if (dest->type != WND_TYPE_BITMAP && dest->type != WND_TYPE_IMAGE) { return 1; } if (self->bpp != dest->bpp) { return 1; } destx = 0; desty = 0; if (!check_bounds(self, &x, &y, &cx, &cy)) { return 1; } if (!check_bounds(dest, &destx, &desty, &cx, &cy)) { return 1; } CRC_START(crc); CRC_PASS(self->width, crc); CRC_PASS(self->width >> 8, crc); CRC_PASS(self->height, crc); CRC_PASS(self->height >> 8, crc); if (self->bpp == 32) { s32 = ((tui32 *)(self->data)) + (self->width * y + x); d32 = ((tui32 *)(dest->data)) + (dest->width * desty + destx); incs = self->width - cx; incd = dest->width - cx; for (i = 0; i < cy; i++) { j = 0; while (j < cx - 4) { pixel = *s32; *d32 = pixel; CRC_PASS(pixel, crc); CRC_PASS(pixel >> 8, crc); CRC_PASS(pixel >> 16, crc); CRC_PASS(pixel >> 24, crc); s32++; d32++; pixel = *s32; *d32 = pixel; CRC_PASS(pixel, crc); CRC_PASS(pixel >> 8, crc); CRC_PASS(pixel >> 16, crc); CRC_PASS(pixel >> 24, crc); s32++; d32++; pixel = *s32; *d32 = pixel; CRC_PASS(pixel, crc); CRC_PASS(pixel >> 8, crc); CRC_PASS(pixel >> 16, crc); CRC_PASS(pixel >> 24, crc); s32++; d32++; pixel = *s32; *d32 = pixel; CRC_PASS(pixel, crc); CRC_PASS(pixel >> 8, crc); CRC_PASS(pixel >> 16, crc); CRC_PASS(pixel >> 24, crc); s32++; d32++; j += 4; } while (j < cx) { pixel = *s32; *d32 = pixel; CRC_PASS(pixel, crc); CRC_PASS(pixel >> 8, crc); CRC_PASS(pixel >> 16, crc); CRC_PASS(pixel >> 24, crc); s32++; d32++; j += 1; } s32 += incs; d32 += incd; } } else if (self->bpp == 24) { s32 = ((tui32 *)(self->data)) + (self->width * y + x); d32 = ((tui32 *)(dest->data)) + (dest->width * desty + destx); incs = self->width - cx; incd = dest->width - cx; for (i = 0; i < cy; i++) { j = 0; while (j < cx - 4) { pixel = *s32; *d32 = pixel; CRC_PASS(pixel, crc); CRC_PASS(pixel >> 8, crc); CRC_PASS(pixel >> 16, crc); s32++; d32++; pixel = *s32; *d32 = pixel; CRC_PASS(pixel, crc); CRC_PASS(pixel >> 8, crc); CRC_PASS(pixel >> 16, crc); s32++; d32++; pixel = *s32; *d32 = pixel; CRC_PASS(pixel, crc); CRC_PASS(pixel >> 8, crc); CRC_PASS(pixel >> 16, crc); s32++; d32++; pixel = *s32; *d32 = pixel; CRC_PASS(pixel, crc); CRC_PASS(pixel >> 8, crc); CRC_PASS(pixel >> 16, crc); s32++; d32++; j += 4; } while (j < cx) { pixel = *s32; *d32 = pixel; CRC_PASS(pixel, crc); CRC_PASS(pixel >> 8, crc); CRC_PASS(pixel >> 16, crc); s32++; d32++; j += 1; } s32 += incs; d32 += incd; } } else if (self->bpp == 15 || self->bpp == 16) { s16 = ((tui16 *)(self->data)) + (self->width * y + x); d16 = ((tui16 *)(dest->data)) + (dest->width * desty + destx); incs = self->width - cx; incd = dest->width - cx; for (i = 0; i < cy; i++) { for (j = 0; j < cx; j++) { pixel = *s16; *d16 = pixel; CRC_PASS(pixel, crc); CRC_PASS(pixel >> 8, crc); s16++; d16++; } s16 += incs; d16 += incd; } } else if (self->bpp == 8) { s8 = ((tui8 *)(self->data)) + (self->width * y + x); d8 = ((tui8 *)(dest->data)) + (dest->width * desty + destx); incs = self->width - cx; incd = dest->width - cx; for (i = 0; i < cy; i++) { for (j = 0; j < cx; j++) { pixel = *s8; *d8 = pixel; CRC_PASS(pixel, crc); s8++; d8++; } s8 += incs; d8 += incd; } } else { return 1; } CRC_END(crc); dest->crc32 = crc; dest->crc16 = dest->crc32 & 0xffff; LLOGLN(10, ("xrdp_bitmap_copy_box_with_crc: crc16 0x%4.4x", dest->crc16)); LLOGLN(10, ("xrdp_bitmap_copy_box_with_crc: width %d height %d", dest->width, dest->height)); return 0; } /*****************************************************************************/ /* returns true if they are the same, else returns false */ int xrdp_bitmap_compare(struct xrdp_bitmap *self, struct xrdp_bitmap *b) { LLOGLN(10, ("xrdp_bitmap_compare:")); if (self == 0) { return 0; } if (b == 0) { return 0; } if (self->bpp != b->bpp) { return 0; } if (self->width != b->width) { return 0; } if (self->height != b->height) { return 0; } if (g_memcmp(self->data, b->data, b->height * b->line_size) == 0) { return 1; } return 0; } /*****************************************************************************/ static int xrdp_bitmap_draw_focus_box(struct xrdp_bitmap *self, struct xrdp_painter *painter, int x, int y, int cx, int cy) { painter->rop = 0xf0; xrdp_painter_begin_update(painter); painter->use_clip = 0; painter->mix_mode = 1; painter->brush.pattern[0] = 0xaa; painter->brush.pattern[1] = 0x55; painter->brush.pattern[2] = 0xaa; painter->brush.pattern[3] = 0x55; painter->brush.pattern[4] = 0xaa; painter->brush.pattern[5] = 0x55; painter->brush.pattern[6] = 0xaa; painter->brush.pattern[7] = 0x55; painter->brush.x_origin = x; painter->brush.x_origin = x; painter->brush.style = 3; painter->fg_color = self->wm->black; painter->bg_color = self->parent->bg_color; /* top */ xrdp_painter_fill_rect(painter, self, x, y, cx, 1); /* bottom */ xrdp_painter_fill_rect(painter, self, x, y + (cy - 1), cx, 1); /* left */ xrdp_painter_fill_rect(painter, self, x, y + 1, 1, cy - 2); /* right */ xrdp_painter_fill_rect(painter, self, x + (cx - 1), y + 1, 1, cy - 2); xrdp_painter_end_update(painter); painter->rop = 0xcc; painter->mix_mode = 0; return 0; } /*****************************************************************************/ /* x and y are in relation to self for 0, 0 is the top left of the control */ static int xrdp_bitmap_draw_button(struct xrdp_bitmap *self, struct xrdp_painter *painter, int x, int y, int w, int h, int down) { if (down) { /* gray box */ painter->fg_color = self->wm->grey; xrdp_painter_fill_rect(painter, self, x, y, w, h); /* black top line */ painter->fg_color = self->wm->black; xrdp_painter_fill_rect(painter, self, x, y, w, 1); /* black left line */ painter->fg_color = self->wm->black; xrdp_painter_fill_rect(painter, self, x, y, 1, h); /* dark grey top line */ painter->fg_color = self->wm->dark_grey; xrdp_painter_fill_rect(painter, self, x + 1, y + 1, w - 2, 1); /* dark grey left line */ painter->fg_color = self->wm->dark_grey; xrdp_painter_fill_rect(painter, self, x + 1, y + 1, 1, h - 2); /* dark grey bottom line */ painter->fg_color = self->wm->dark_grey; xrdp_painter_fill_rect(painter, self, x + 1, y + (h - 2), w - 1, 1); /* dark grey right line */ painter->fg_color = self->wm->dark_grey; xrdp_painter_fill_rect(painter, self, x + (w - 2), y + 1, 1, h - 1); /* black bottom line */ painter->fg_color = self->wm->black; xrdp_painter_fill_rect(painter, self, x, y + (h - 1), w, 1); /* black right line */ painter->fg_color = self->wm->black; xrdp_painter_fill_rect(painter, self, x + (w - 1), y, 1, h); } else { /* gray box */ painter->fg_color = self->wm->grey; xrdp_painter_fill_rect(painter, self, x, y, w, h); /* white top line */ painter->fg_color = self->wm->white; xrdp_painter_fill_rect(painter, self, x, y, w, 1); /* white left line */ painter->fg_color = self->wm->white; xrdp_painter_fill_rect(painter, self, x, y, 1, h); /* dark grey bottom line */ painter->fg_color = self->wm->dark_grey; xrdp_painter_fill_rect(painter, self, x + 1, y + (h - 2), w - 1, 1); /* dark grey right line */ painter->fg_color = self->wm->dark_grey; xrdp_painter_fill_rect(painter, self, (x + w) - 2, y + 1, 1, h - 1); /* black bottom line */ painter->fg_color = self->wm->black; xrdp_painter_fill_rect(painter, self, x, y + (h - 1), w, 1); /* black right line */ painter->fg_color = self->wm->black; xrdp_painter_fill_rect(painter, self, x + (w - 1), y, 1, h); } return 0; } /*****************************************************************************/ /* nil for rect means the whole thing */ /* returns error */ int xrdp_bitmap_invalidate(struct xrdp_bitmap *self, struct xrdp_rect *rect) { int i; int w; int h; int x; int y; struct xrdp_bitmap *b; struct xrdp_rect r1; struct xrdp_rect r2; struct xrdp_painter *painter; twchar wtext[256]; char text[256]; char *p; if (self == 0) /* if no bitmap */ { return 0; } if (self->type == WND_TYPE_BITMAP) /* if 0, bitmap, leave */ { return 0; } painter = xrdp_painter_create(self->wm, self->wm->session); xrdp_painter_font_needed(painter); painter->rop = 0xcc; /* copy */ if (rect == 0) { painter->use_clip = 0; } else { if (ISRECTEMPTY(*rect)) { xrdp_painter_delete(painter); return 0; } painter->clip = *rect; painter->use_clip = &painter->clip; } xrdp_painter_begin_update(painter); if (self->type == WND_TYPE_WND) /* 1 */ { /* draw grey background */ painter->fg_color = self->bg_color; xrdp_painter_fill_rect(painter, self, 0, 0, self->width, self->height); /* top white line */ painter->fg_color = self->wm->white; xrdp_painter_fill_rect(painter, self, 1, 1, self->width - 2, 1); /* left white line */ painter->fg_color = self->wm->white; xrdp_painter_fill_rect(painter, self, 1, 1, 1, self->height - 2); /* bottom dark grey line */ painter->fg_color = self->wm->dark_grey; xrdp_painter_fill_rect(painter, self, 1, self->height - 2, self->width - 2, 1); /* right dark grey line */ painter->fg_color = self->wm->dark_grey; xrdp_painter_fill_rect(painter, self, self->width - 2, 1, 1, self->height - 2); /* bottom black line */ painter->fg_color = self->wm->black; xrdp_painter_fill_rect(painter, self, 0, self->height - 1, self->width, 1); /* right black line */ painter->fg_color = self->wm->black; xrdp_painter_fill_rect(painter, self, self->width - 1, 0, 1, self->height); if (self->wm->focused_window == self) { /* active title bar */ painter->fg_color = self->wm->blue; xrdp_painter_fill_rect(painter, self, 3, 3, self->width - 5, 18); painter->fg_color = self->wm->white; } else { /* inactive title bar */ painter->fg_color = self->wm->dark_grey; xrdp_painter_fill_rect(painter, self, 3, 3, self->width - 5, 18); painter->fg_color = self->wm->black; } xrdp_painter_draw_text(painter, self, 4, 4, self->caption1); } else if (self->type == WND_TYPE_SCREEN) /* 2 */ { if (self->wm->mm->mod != 0) { if (self->wm->mm->mod->mod_event != 0) { if (rect != 0) { x = rect->left; y = rect->top; w = rect->right - rect->left; h = rect->bottom - rect->top; if (check_bounds(self->wm->screen, &x, &y, &w, &h)) { self->wm->mm->mod->mod_event(self->wm->mm->mod, WM_INVALIDATE, MAKELONG(y, x), MAKELONG(h, w), 0, 0); } } else { x = 0; y = 0; w = self->wm->screen->width; h = self->wm->screen->height; self->wm->mm->mod->mod_event(self->wm->mm->mod, WM_INVALIDATE, MAKELONG(y, x), MAKELONG(h, w), 0, 0); } } } else { painter->fg_color = self->bg_color; xrdp_painter_fill_rect(painter, self, 0, 0, self->width, self->height); } } else if (self->type == WND_TYPE_BUTTON) /* 3 */ { if (self->state == BUTTON_STATE_UP) /* 0 */ { xrdp_bitmap_draw_button(self, painter, 0, 0, self->width, self->height, 0); w = xrdp_painter_text_width(painter, self->caption1); h = xrdp_painter_text_height(painter, self->caption1); painter->fg_color = self->wm->black; xrdp_painter_draw_text(painter, self, self->width / 2 - w / 2, self->height / 2 - h / 2, self->caption1); if (self->parent != 0) { if (self->wm->focused_window == self->parent) { if (self->parent->focused_control == self) { xrdp_bitmap_draw_focus_box(self, painter, 4, 4, self->width - 8, self->height - 8); } } } } else if (self->state == BUTTON_STATE_DOWN) /* 1 */ { xrdp_bitmap_draw_button(self, painter, 0, 0, self->width, self->height, 1); w = xrdp_painter_text_width(painter, self->caption1); h = xrdp_painter_text_height(painter, self->caption1); painter->fg_color = self->wm->black; xrdp_painter_draw_text(painter, self, (self->width / 2 - w / 2) + 1, (self->height / 2 - h / 2) + 1, self->caption1); if (self->parent != 0) if (self->wm->focused_window == self->parent) if (self->parent->focused_control == self) xrdp_bitmap_draw_focus_box(self, painter, 4, 4, self->width - 8, self->height - 8); } } else if (self->type == WND_TYPE_IMAGE) /* 4 */ { xrdp_painter_copy(painter, self, self, 0, 0, self->width, self->height, 0, 0); } else if (self->type == WND_TYPE_EDIT) /* 5 */ { /* draw gray box */ painter->fg_color = self->wm->grey; xrdp_painter_fill_rect(painter, self, 0, 0, self->width, self->height); /* main white background */ painter->fg_color = self->wm->white; xrdp_painter_fill_rect(painter, self, 1, 1, self->width - 3, self->height - 3); /* dark grey top line */ painter->fg_color = self->wm->dark_grey; xrdp_painter_fill_rect(painter, self, 0, 0, self->width, 1); /* dark grey left line */ painter->fg_color = self->wm->dark_grey; xrdp_painter_fill_rect(painter, self, 0, 0, 1, self->height); /* white bottom line */ painter->fg_color = self->wm->white; xrdp_painter_fill_rect(painter, self, 0, self->height - 1, self->width, 1); /* white right line */ painter->fg_color = self->wm->white; xrdp_painter_fill_rect(painter, self, self->width - 1, 0, 1, self->height); /* black left line */ painter->fg_color = self->wm->black; xrdp_painter_fill_rect(painter, self, 1, 1, 1, self->height - 3); /* black top line */ painter->fg_color = self->wm->black; xrdp_painter_fill_rect(painter, self, 1, 1, self->width - 3, 1); /* draw text */ painter->fg_color = self->wm->black; if (self->password_char != 0) { i = g_mbstowcs(0, self->caption1, 0); g_memset(text, self->password_char, i); text[i] = 0; xrdp_painter_draw_text(painter, self, 4, 2, text); } else { xrdp_painter_draw_text(painter, self, 4, 2, self->caption1); } /* draw xor box(cursor) */ if (self->parent != 0) { if (self->parent->focused_control == self) { if (self->password_char != 0) { wchar_repeat(wtext, 255, self->password_char, self->edit_pos); wtext[self->edit_pos] = 0; g_wcstombs(text, wtext, 255); } else { g_mbstowcs(wtext, self->caption1, 255); wtext[self->edit_pos] = 0; g_wcstombs(text, wtext, 255); } w = xrdp_painter_text_width(painter, text); painter->fg_color = self->wm->white; painter->rop = 0x5a; xrdp_painter_fill_rect(painter, self, 4 + w, 3, 2, self->height - 6); } } /* reset rop back */ painter->rop = 0xcc; } else if (self->type == WND_TYPE_LABEL) /* 6 */ { painter->fg_color = self->wm->black; xrdp_painter_draw_text(painter, self, 0, 0, self->caption1); } else if (self->type == WND_TYPE_COMBO) /* 7 combo box */ { /* draw gray box */ painter->fg_color = self->wm->grey; xrdp_painter_fill_rect(painter, self, 0, 0, self->width, self->height); /* white background */ painter->fg_color = self->wm->white; xrdp_painter_fill_rect(painter, self, 1, 1, self->width - 3, self->height - 3); if (self->parent->focused_control == self) { painter->fg_color = self->wm->dark_blue; xrdp_painter_fill_rect(painter, self, 3, 3, (self->width - 6) - 18, self->height - 5); } /* dark grey top line */ painter->fg_color = self->wm->dark_grey; xrdp_painter_fill_rect(painter, self, 0, 0, self->width, 1); /* dark grey left line */ painter->fg_color = self->wm->dark_grey; xrdp_painter_fill_rect(painter, self, 0, 0, 1, self->height); /* white bottom line */ painter->fg_color = self->wm->white; xrdp_painter_fill_rect(painter, self, 0, self->height - 1, self->width, 1); /* white right line */ painter->fg_color = self->wm->white; xrdp_painter_fill_rect(painter, self, self->width - 1, 0, 1, self->height); /* black left line */ painter->fg_color = self->wm->black; xrdp_painter_fill_rect(painter, self, 1, 1, 1, self->height - 3); /* black top line */ painter->fg_color = self->wm->black; xrdp_painter_fill_rect(painter, self, 1, 1, self->width - 3, 1); /* draw text */ if (self->parent->focused_control == self) { painter->fg_color = self->wm->white; } else { painter->fg_color = self->wm->black; } xrdp_painter_draw_text(painter, self, 4, 2, (char *)list_get_item(self->string_list, self->item_index)); /* draw button on right */ x = self->width - 20; y = 2; w = (self->width - x) - 2; h = self->height - 4; /* looks better with a background around */ painter->fg_color = self->wm->grey; xrdp_painter_fill_rect(painter, self, x, y, w, h); if (self->state == BUTTON_STATE_UP) /* 0 */ { xrdp_bitmap_draw_button(self, painter, x + 1, y + 1, w - 1, h - 1, 0); } else { xrdp_bitmap_draw_button(self, painter, x + 1, y + 1, w - 1, h - 1, 1); } /* draw the arrow */ w = w / 2; x = x + (w / 2) + 1; h = (h / 2) + 2; y = y + (h / 2) + 1; painter->fg_color = self->wm->black; for (i = w; i > 0; i = i - 2) { xrdp_painter_fill_rect(painter, self, x, y, i, 1); y++; x = x + 1; } } else if (self->type == WND_TYPE_SPECIAL) /* 8 special */ { if (self->popped_from != 0) { /* change height if there are too many items in the list */ i = xrdp_painter_text_height(painter, "W"); i = self->popped_from->string_list->count * i; if (i > self->height) { self->height = i; } } painter->fg_color = self->wm->white; xrdp_painter_fill_rect(painter, self, 0, 0, self->width, self->height); /* draw the list items */ if (self->popped_from != 0) { y = 0; for (i = 0; i < self->popped_from->string_list->count; i++) { p = (char *)list_get_item(self->popped_from->string_list, i); h = xrdp_painter_text_height(painter, p); self->item_height = h; if (i == self->item_index) { painter->fg_color = self->wm->blue; xrdp_painter_fill_rect(painter, self, 0, y, self->width, h); painter->fg_color = self->wm->white; } else { painter->fg_color = self->wm->black; } xrdp_painter_draw_text(painter, self, 2, y, p); y = y + h; } } } /* notify */ if (self->notify != 0) { self->notify(self, self, WM_PAINT, (long)painter, 0); /* 3 */ } /* draw any child windows in the area */ for (i = 0; i < self->child_list->count; i++) { b = (struct xrdp_bitmap *)list_get_item(self->child_list, i); if (rect == 0) { xrdp_bitmap_invalidate(b, 0); } else { MAKERECT(r1, b->left, b->top, b->width, b->height); if (rect_intersect(rect, &r1, &r2)) { RECTOFFSET(r2, -(b->left), -(b->top)); xrdp_bitmap_invalidate(b, &r2); } } } xrdp_painter_end_update(painter); xrdp_painter_delete(painter); return 0; } /*****************************************************************************/ /* returns error */ int xrdp_bitmap_def_proc(struct xrdp_bitmap *self, int msg, int param1, int param2) { twchar c; int n; int i; int shift; int ext; int scan_code; int num_bytes; int num_chars; struct xrdp_bitmap *b; struct xrdp_bitmap *focus_out_control; if (self == 0) { return 0; } if (self->wm == 0) { return 0; } if (self->type == WND_TYPE_WND) { if (msg == WM_KEYDOWN) { scan_code = param1 % 128; if (scan_code == 15) /* tab */ { /* move to next tab stop */ shift = self->wm->keys[42] || self->wm->keys[54]; i = -1; if (self->child_list != 0) { i = list_index_of(self->child_list, (long)self->focused_control); if (shift) { i--; if (i < 0) { i = self->child_list->count - 1; } } else { i++; if (i >= self->child_list->count) { i = 0; } } n = self->child_list->count; b = (struct xrdp_bitmap *)list_get_item(self->child_list, i); while (b != self->focused_control && b != 0 && n > 0) { n--; if (b->tab_stop) { focus_out_control = self->focused_control; self->focused_control = b; xrdp_bitmap_invalidate(focus_out_control, 0); xrdp_bitmap_invalidate(b, 0); break; } if (shift) { i--; if (i < 0) { i = self->child_list->count - 1; } } else { i++; if (i >= self->child_list->count) { i = 0; } } b = (struct xrdp_bitmap *)list_get_item(self->child_list, i); } } } else if (scan_code == 28) /* enter */ { if (self->default_button != 0) { if (self->notify != 0) { /* I think this should use def_proc */ self->notify(self, self->default_button, 1, 0, 0); return 0; } } } else if (scan_code == 1) /* esc */ { if (self->esc_button != 0) { if (self->notify != 0) { /* I think this should use def_proc */ self->notify(self, self->esc_button, 1, 0, 0); return 0; } } } } if (self->focused_control != 0) { xrdp_bitmap_def_proc(self->focused_control, msg, param1, param2); } } else if (self->type == WND_TYPE_EDIT) { if (msg == WM_KEYDOWN) { scan_code = param1 % 128; ext = param2 & 0x0100; /* left or up arrow */ if ((scan_code == 75 || scan_code == 72) && (ext || self->wm->num_lock == 0)) { if (self->edit_pos > 0) { self->edit_pos--; xrdp_bitmap_invalidate(self, 0); } } /* right or down arrow */ else if ((scan_code == 77 || scan_code == 80) && (ext || self->wm->num_lock == 0)) { if (self->edit_pos < g_mbstowcs(0, self->caption1, 0)) { self->edit_pos++; xrdp_bitmap_invalidate(self, 0); } } /* backspace */ else if (scan_code == 14) { n = g_mbstowcs(0, self->caption1, 0); if (n > 0) { if (self->edit_pos > 0) { self->edit_pos--; remove_char_at(self->caption1, 255, self->edit_pos); xrdp_bitmap_invalidate(self, 0); } } } /* delete */ else if (scan_code == 83 && (ext || self->wm->num_lock == 0)) { n = g_mbstowcs(0, self->caption1, 0); if (n > 0) { if (self->edit_pos < n) { remove_char_at(self->caption1, 255, self->edit_pos); xrdp_bitmap_invalidate(self, 0); } } } /* end */ else if (scan_code == 79 && (ext || self->wm->num_lock == 0)) { n = g_mbstowcs(0, self->caption1, 0); if (self->edit_pos < n) { self->edit_pos = n; xrdp_bitmap_invalidate(self, 0); } } /* home */ else if ((scan_code == 71) && (ext || (self->wm->num_lock == 0))) { if (self->edit_pos > 0) { self->edit_pos = 0; xrdp_bitmap_invalidate(self, 0); } } else { c = get_char_from_scan_code (param2, scan_code, self->wm->keys, self->wm->caps_lock, self->wm->num_lock, self->wm->scroll_lock, &(self->wm->keymap)); num_chars = g_mbstowcs(0, self->caption1, 0); num_bytes = g_strlen(self->caption1); if ((c >= 32) && (num_chars < 127) && (num_bytes < 250)) { add_char_at(self->caption1, 255, c, self->edit_pos); self->edit_pos++; xrdp_bitmap_invalidate(self, 0); } } } } else if (self->type == WND_TYPE_COMBO) { if (msg == WM_KEYDOWN) { scan_code = param1 % 128; ext = param2 & 0x0100; /* left or up arrow */ if (((scan_code == 75) || (scan_code == 72)) && (ext || (self->wm->num_lock == 0))) { if (self->item_index > 0) { self->item_index--; xrdp_bitmap_invalidate(self, 0); if (self->parent->notify != 0) { self->parent->notify(self->parent, self, CB_ITEMCHANGE, 0, 0); } } } /* right or down arrow */ else if ((scan_code == 77 || scan_code == 80) && (ext || self->wm->num_lock == 0)) { if ((self->item_index + 1) < self->string_list->count) { self->item_index++; xrdp_bitmap_invalidate(self, 0); if (self->parent->notify != 0) { self->parent->notify(self->parent, self, CB_ITEMCHANGE, 0, 0); } } } } } else if (self->type == WND_TYPE_SPECIAL) { if (msg == WM_MOUSEMOVE) { if (self->item_height > 0 && self->popped_from != 0) { i = param2; i = i / self->item_height; if (i != self->item_index && i < self->popped_from->string_list->count) { self->item_index = i; xrdp_bitmap_invalidate(self, 0); } } } else if (msg == WM_LBUTTONUP) { if (self->popped_from != 0) { self->popped_from->item_index = self->item_index; xrdp_bitmap_invalidate(self->popped_from, 0); if (self->popped_from->parent->notify != 0) { self->popped_from->parent->notify(self->popped_from->parent, self->popped_from, CB_ITEMCHANGE, 0, 0); } } } } return 0; } /*****************************************************************************/ /* convert the controls coords to screen coords */ int xrdp_bitmap_to_screenx(struct xrdp_bitmap *self, int x) { int i; i = x; while (self != 0) { i = i + self->left; self = self->parent; } return i; } /*****************************************************************************/ /* convert the controls coords to screen coords */ int xrdp_bitmap_to_screeny(struct xrdp_bitmap *self, int y) { int i; i = y; while (self != 0) { i = i + self->top; self = self->parent; } return i; } /*****************************************************************************/ /* convert the screen coords to controls coords */ int xrdp_bitmap_from_screenx(struct xrdp_bitmap *self, int x) { int i; i = x; while (self != 0) { i = i - self->left; self = self->parent; } return i; } /*****************************************************************************/ /* convert the screen coords to controls coords */ int xrdp_bitmap_from_screeny(struct xrdp_bitmap *self, int y) { int i; i = y; while (self != 0) { i = i - self->top; self = self->parent; } return i; } /*****************************************************************************/ int xrdp_bitmap_get_screen_clip(struct xrdp_bitmap *self, struct xrdp_painter *painter, struct xrdp_rect *rect, int *dx, int *dy) { int ldx; int ldy; if (painter->use_clip) { *rect = painter->clip; } else { rect->left = 0; rect->top = 0; rect->right = self->width; rect->bottom = self->height; } ldx = xrdp_bitmap_to_screenx(self, 0); ldy = xrdp_bitmap_to_screeny(self, 0); rect->left += ldx; rect->top += ldy; rect->right += ldx; rect->bottom += ldy; if (dx != 0) { *dx = ldx; } if (dy != 0) { *dy = ldy; } return 0; } xrdp-0.9.5/xrdp/xrdp_mm.c000644 001751 001751 00000307007 13220727202 015215 0ustar00metameta000000 000000 /** * xrdp: A Remote Desktop Protocol server. * * Copyright (C) Jay Sorg 2004-2014 * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. * * module manager */ #if defined(HAVE_CONFIG_H) #include #endif #include "xrdp.h" #include "log.h" #ifndef USE_NOPAM #if defined(HAVE__PAM_TYPES_H) #define LINUXPAM 1 #include #elif defined(HAVE_PAM_CONSTANTS_H) #define OPENPAM 1 #include #endif #endif /* USE_NOPAM */ #include "xrdp_encoder.h" #include "xrdp_sockets.h" #define LLOG_LEVEL 1 #define LLOGLN(_level, _args) \ do \ { \ if (_level < LLOG_LEVEL) \ { \ g_write("xrdp:xrdp_mm [%10.10u]: ", g_time3()); \ g_writeln _args ; \ } \ } \ while (0) /*****************************************************************************/ struct xrdp_mm * xrdp_mm_create(struct xrdp_wm *owner) { struct xrdp_mm *self; self = (struct xrdp_mm *)g_malloc(sizeof(struct xrdp_mm), 1); self->wm = owner; self->login_names = list_create(); self->login_names->auto_free = 1; self->login_values = list_create(); self->login_values->auto_free = 1; LLOGLN(0, ("xrdp_mm_create: bpp %d mcs_connection_type %d " "jpeg_codec_id %d v3_codec_id %d rfx_codec_id %d " "h264_codec_id %d", self->wm->client_info->bpp, self->wm->client_info->mcs_connection_type, self->wm->client_info->jpeg_codec_id, self->wm->client_info->v3_codec_id, self->wm->client_info->rfx_codec_id, self->wm->client_info->h264_codec_id)); self->encoder = xrdp_encoder_create(self); return self; } /*****************************************************************************/ /* called from main thread */ static long xrdp_mm_sync_unload(long param1, long param2) { return g_free_library(param1); } /*****************************************************************************/ /* called from main thread */ static long xrdp_mm_sync_load(long param1, long param2) { long rv; char *libname; libname = (char *)param1; rv = g_load_library(libname); return rv; } /*****************************************************************************/ static void xrdp_mm_module_cleanup(struct xrdp_mm *self) { log_message(LOG_LEVEL_DEBUG, "xrdp_mm_module_cleanup"); if (self->mod != 0) { if (self->mod_exit != 0) { /* let the module cleanup */ self->mod_exit(self->mod); } } if (self->mod_handle != 0) { /* Let the main thread unload the module.*/ g_xrdp_sync(xrdp_mm_sync_unload, self->mod_handle, 0); } trans_delete(self->chan_trans); self->chan_trans = 0; self->chan_trans_up = 0; self->mod_init = 0; self->mod_exit = 0; self->mod = 0; self->mod_handle = 0; if (self->wm->hide_log_window) { /* make sure autologin is off */ self->wm->session->client_info->rdp_autologin = 0; xrdp_wm_set_login_mode(self->wm, 0); /* reset session */ } } /*****************************************************************************/ void xrdp_mm_delete(struct xrdp_mm *self) { if (self == 0) { return; } /* free any module stuff */ xrdp_mm_module_cleanup(self); /* shutdown thread */ xrdp_encoder_delete(self->encoder); trans_delete(self->sesman_trans); self->sesman_trans = 0; self->sesman_trans_up = 0; list_delete(self->login_names); list_delete(self->login_values); g_free(self); } /*****************************************************************************/ /* Send login information to sesman */ static int xrdp_mm_send_login(struct xrdp_mm *self) { struct stream *s; int rv; int index; int count; int xserverbpp; char *username; char *password; char *name; char *value; xrdp_wm_log_msg(self->wm, LOG_LEVEL_DEBUG, "sending login info to session manager, please wait..."); username = 0; password = 0; self->code = 0; xserverbpp = 0; count = self->login_names->count; for (index = 0; index < count; index++) { name = (char *)list_get_item(self->login_names, index); value = (char *)list_get_item(self->login_values, index); if (g_strcasecmp(name, "username") == 0) { username = value; } else if (g_strcasecmp(name, "password") == 0) { password = value; } else if (g_strcasecmp(name, "code") == 0) { /* this code is either 0 for Xvnc, 10 for X11rdp or 20 for Xorg */ self->code = g_atoi(value); } else if (g_strcasecmp(name, "xserverbpp") == 0) { xserverbpp = g_atoi(value); } } if ((username == 0) || (password == 0)) { xrdp_wm_log_msg(self->wm, LOG_LEVEL_ERROR, "Error finding username and password"); return 1; } s = trans_get_out_s(self->sesman_trans, 8192); s_push_layer(s, channel_hdr, 8); /* this code is either 0 for Xvnc, 10 for X11rdp or 20 for Xorg */ out_uint16_be(s, self->code); index = g_strlen(username); out_uint16_be(s, index); out_uint8a(s, username, index); index = g_strlen(password); out_uint16_be(s, index); out_uint8a(s, password, index); out_uint16_be(s, self->wm->screen->width); out_uint16_be(s, self->wm->screen->height); /* select and send X server bpp */ if (xserverbpp == 0) { if (self->code == 20) { xserverbpp = 24; /* xorgxrdp is always at 24 bpp */ } else { xserverbpp = self->wm->screen->bpp; /* use client's bpp */ } } out_uint16_be(s, xserverbpp); /* send domain */ if(self->wm->client_info->domain[0]!='_') { index = g_strlen(self->wm->client_info->domain); out_uint16_be(s, index); out_uint8a(s, self->wm->client_info->domain, index); } else { out_uint16_be(s, 0); /* out_uint8a(s, "", 0); */ } /* send program / shell */ index = g_strlen(self->wm->client_info->program); out_uint16_be(s, index); out_uint8a(s, self->wm->client_info->program, index); /* send directory */ index = g_strlen(self->wm->client_info->directory); out_uint16_be(s, index); out_uint8a(s, self->wm->client_info->directory, index); /* send client ip */ index = g_strlen(self->wm->client_info->client_ip); out_uint16_be(s, index); out_uint8a(s, self->wm->client_info->client_ip, index); s_mark_end(s); s_pop_layer(s, channel_hdr); /* Version 0 of the protocol to sesman is currently used by XRDP */ out_uint32_be(s, 0); /* version */ index = (int)(s->end - s->data); out_uint32_be(s, index); /* size */ rv = trans_force_write(self->sesman_trans); if (rv != 0) { xrdp_wm_log_msg(self->wm, LOG_LEVEL_WARNING, "xrdp_mm_send_login: xrdp_mm_send_login failed"); } return rv; } /*****************************************************************************/ /* returns error */ /* this goes through the login_names looking for one called 'aname' then it copies the corresponding login_values item into 'dest' 'dest' must be at least 'dest_len' + 1 bytes in size */ static int xrdp_mm_get_value(struct xrdp_mm *self, const char *aname, char *dest, int dest_len) { char *name; char *value; int index; int count; int rv; rv = 1; /* find the library name */ dest[0] = 0; count = self->login_names->count; for (index = 0; index < count; index++) { name = (char *)list_get_item(self->login_names, index); value = (char *)list_get_item(self->login_values, index); if ((name == 0) || (value == 0)) { break; } if (g_strcasecmp(name, aname) == 0) { g_strncpy(dest, value, dest_len); rv = 0; } } return rv; } /*****************************************************************************/ static int xrdp_mm_setup_mod1(struct xrdp_mm *self) { void *func; char lib[256]; char text[256]; if (self == 0) { return 1; } lib[0] = 0; if (xrdp_mm_get_value(self, "lib", lib, 255) != 0) { xrdp_wm_log_msg(self->wm, LOG_LEVEL_ERROR, "no library name specified in xrdp.ini, please add " "lib=libxrdp-vnc.so or similar"); return 1; } if (lib[0] == 0) { xrdp_wm_log_msg(self->wm, LOG_LEVEL_ERROR, "empty library name specified in xrdp.ini, please " "add lib=libxrdp-vnc.so or similar"); return 1; } if (self->mod_handle == 0) { g_snprintf(text, 255, "%s/%s", XRDP_MODULE_PATH, lib); /* Let the main thread load the lib,*/ self->mod_handle = g_xrdp_sync(xrdp_mm_sync_load, (tintptr)text, 0); if (self->mod_handle != 0) { func = g_get_proc_address(self->mod_handle, "mod_init"); if (func == 0) { func = g_get_proc_address(self->mod_handle, "_mod_init"); } if (func == 0) { xrdp_wm_log_msg(self->wm, LOG_LEVEL_ERROR, "error finding proc mod_init in %s, " "not a valid xrdp backend", lib); } self->mod_init = (struct xrdp_mod * ( *)(void))func; func = g_get_proc_address(self->mod_handle, "mod_exit"); if (func == 0) { func = g_get_proc_address(self->mod_handle, "_mod_exit"); } if (func == 0) { xrdp_wm_log_msg(self->wm, LOG_LEVEL_ERROR, "error finding proc mod_exit in %s, " "not a valid xrdp backend", lib); } self->mod_exit = (int ( *)(struct xrdp_mod *))func; if ((self->mod_init != 0) && (self->mod_exit != 0)) { self->mod = self->mod_init(); if (self->mod != 0) { g_writeln("loaded module '%s' ok, interface size %d, version %d", lib, self->mod->size, self->mod->version); } } else { log_message(LOG_LEVEL_ERROR,"no mod_init or mod_exit address found"); } } else { xrdp_wm_log_msg(self->wm, LOG_LEVEL_ERROR, "error loading %s specified in xrdp.ini, please " "add a valid entry like lib=libxrdp-vnc.so or " "similar", lib); return 1; } if (self->mod != 0) { self->mod->wm = (long)(self->wm); self->mod->server_begin_update = server_begin_update; self->mod->server_end_update = server_end_update; self->mod->server_bell_trigger = server_bell_trigger; self->mod->server_fill_rect = server_fill_rect; self->mod->server_screen_blt = server_screen_blt; self->mod->server_paint_rect = server_paint_rect; self->mod->server_set_pointer = server_set_pointer; self->mod->server_set_pointer_ex = server_set_pointer_ex; self->mod->server_palette = server_palette; self->mod->server_msg = server_msg; self->mod->server_is_term = server_is_term; self->mod->server_set_clip = server_set_clip; self->mod->server_reset_clip = server_reset_clip; self->mod->server_set_fgcolor = server_set_fgcolor; self->mod->server_set_bgcolor = server_set_bgcolor; self->mod->server_set_opcode = server_set_opcode; self->mod->server_set_mixmode = server_set_mixmode; self->mod->server_set_brush = server_set_brush; self->mod->server_set_pen = server_set_pen; self->mod->server_draw_line = server_draw_line; self->mod->server_add_char = server_add_char; self->mod->server_draw_text = server_draw_text; self->mod->server_reset = server_reset; self->mod->server_query_channel = server_query_channel; self->mod->server_get_channel_id = server_get_channel_id; self->mod->server_send_to_channel = server_send_to_channel; self->mod->server_create_os_surface = server_create_os_surface; self->mod->server_switch_os_surface = server_switch_os_surface; self->mod->server_delete_os_surface = server_delete_os_surface; self->mod->server_paint_rect_os = server_paint_rect_os; self->mod->server_set_hints = server_set_hints; self->mod->server_window_new_update = server_window_new_update; self->mod->server_window_delete = server_window_delete; self->mod->server_window_icon = server_window_icon; self->mod->server_window_cached_icon = server_window_cached_icon; self->mod->server_notify_new_update = server_notify_new_update; self->mod->server_notify_delete = server_notify_delete; self->mod->server_monitored_desktop = server_monitored_desktop; self->mod->server_add_char_alpha = server_add_char_alpha; self->mod->server_create_os_surface_bpp = server_create_os_surface_bpp; self->mod->server_paint_rect_bpp = server_paint_rect_bpp; self->mod->server_composite = server_composite; self->mod->server_paint_rects = server_paint_rects; self->mod->server_session_info = server_session_info; self->mod->si = (tintptr) &(self->wm->session->si); } } /* id self->mod is null, there must be a problem */ if (self->mod == 0) { DEBUG(("problem loading lib in xrdp_mm_setup_mod1")); return 1; } return 0; } /*****************************************************************************/ static int xrdp_mm_setup_mod2(struct xrdp_mm *self, tui8 *guid) { char text[256]; const char *name; const char *value; int i; int rv; int key_flags; int device_flags; int use_uds; rv = 1; /* failure */ g_memset(text, 0, sizeof(text)); if (!g_is_wait_obj_set(self->wm->pro_layer->self_term_event)) { if (self->mod->mod_start(self->mod, self->wm->screen->width, self->wm->screen->height, self->wm->screen->bpp) != 0) { g_set_wait_obj(self->wm->pro_layer->self_term_event); /* kill session */ } } if (!g_is_wait_obj_set(self->wm->pro_layer->self_term_event)) { if (self->display > 0) { if (self->code == 0) /* Xvnc */ { g_snprintf(text, 255, "%d", 5900 + self->display); } else if (self->code == 10 || self->code == 20) /* X11rdp/Xorg */ { use_uds = 1; if (xrdp_mm_get_value(self, "ip", text, 255) == 0) { if (g_strcmp(text, "127.0.0.1") != 0) { use_uds = 0; } } if (use_uds) { g_snprintf(text, 255, XRDP_X11RDP_STR, self->display); } else { g_snprintf(text, 255, "%d", 6200 + self->display); } } else { g_set_wait_obj(self->wm->pro_layer->self_term_event); /* kill session */ } } } if (!g_is_wait_obj_set(self->wm->pro_layer->self_term_event)) { /* this adds the port to the end of the list, it will already be in the list as -1 the module should use the last one */ if (g_strlen(text) > 0) { list_add_item(self->login_names, (long)g_strdup("port")); list_add_item(self->login_values, (long)g_strdup(text)); } /* always set these */ self->mod->mod_set_param(self->mod, "client_info", (const char *) (self->wm->session->client_info)); name = self->wm->session->client_info->hostname; self->mod->mod_set_param(self->mod, "hostname", name); g_snprintf(text, 255, "%d", self->wm->session->client_info->keylayout); self->mod->mod_set_param(self->mod, "keylayout", text); if (guid != 0) { self->mod->mod_set_param(self->mod, "guid", (char *) guid); } for (i = 0; i < self->login_names->count; i++) { name = (const char *) list_get_item(self->login_names, i); value = (const char *) list_get_item(self->login_values, i); self->mod->mod_set_param(self->mod, name, value); } /* connect */ if (self->mod->mod_connect(self->mod) == 0) { rv = 0; /* connect success */ } else { xrdp_wm_show_log(self->wm); if (self->wm->hide_log_window) { rv = 1; } } } if (rv == 0) { /* sync modifiers */ key_flags = 0; device_flags = 0; if (self->wm->scroll_lock) { key_flags |= 1; } if (self->wm->num_lock) { key_flags |= 2; } if (self->wm->caps_lock) { key_flags |= 4; } if (self->mod != 0) { if (self->mod->mod_event != 0) { self->mod->mod_event(self->mod, 17, key_flags, device_flags, key_flags, device_flags); } } } return rv; } /*****************************************************************************/ /* returns error send a list of channels to the channel handler */ static int xrdp_mm_trans_send_channel_setup(struct xrdp_mm *self, struct trans *trans) { int index; int chan_id; int chan_flags; int size; struct stream *s; char chan_name[256]; g_memset(chan_name, 0, sizeof(char) * 256); s = trans_get_out_s(trans, 8192); if (s == 0) { return 1; } s_push_layer(s, iso_hdr, 8); s_push_layer(s, mcs_hdr, 8); s_push_layer(s, sec_hdr, 2); index = 0; while (libxrdp_query_channel(self->wm->session, index, chan_name, &chan_flags) == 0) { chan_id = libxrdp_get_channel_id(self->wm->session, chan_name); out_uint8a(s, chan_name, 8); out_uint16_le(s, chan_id); out_uint16_le(s, chan_flags); index++; } s_mark_end(s); s_pop_layer(s, sec_hdr); out_uint16_le(s, index); s_pop_layer(s, mcs_hdr); size = (int)(s->end - s->p); out_uint32_le(s, 3); /* msg id */ out_uint32_le(s, size); /* msg size */ s_pop_layer(s, iso_hdr); size = (int)(s->end - s->p); out_uint32_le(s, 0); /* version */ out_uint32_le(s, size); /* block size */ return trans_force_write(trans); } /*****************************************************************************/ /* returns error */ static int xrdp_mm_trans_send_channel_data_response(struct xrdp_mm *self, struct trans *trans) { struct stream *s; s = trans_get_out_s(trans, 8192); if (s == 0) { return 1; } out_uint32_le(s, 0); /* version */ out_uint32_le(s, 8 + 8); /* size */ out_uint32_le(s, 7); /* msg id */ out_uint32_le(s, 8); /* size */ s_mark_end(s); return trans_force_write(trans); } /*****************************************************************************/ /* returns error init is done, sent channel setup */ static int xrdp_mm_trans_process_init_response(struct xrdp_mm *self, struct trans *trans) { return xrdp_mm_trans_send_channel_setup(self, trans); } /*****************************************************************************/ /* returns error data coming in from the channel handler, send it to the client */ static int xrdp_mm_trans_process_channel_data(struct xrdp_mm *self, struct trans *trans) { struct stream *s; int size; int total_size; int chan_id; int chan_flags; int rv; s = trans_get_in_s(trans); if (s == 0) { return 1; } in_uint16_le(s, chan_id); in_uint16_le(s, chan_flags); in_uint16_le(s, size); in_uint32_le(s, total_size); rv = xrdp_mm_trans_send_channel_data_response(self, trans); if (rv == 0) { if (is_channel_allowed(self->wm, chan_id)) { rv = libxrdp_send_to_channel(self->wm->session, chan_id, s->p, size, total_size, chan_flags); } } return rv; } /*****************************************************************************/ /* returns error process rail create window order */ static int xrdp_mm_process_rail_create_window(struct xrdp_mm* self, struct stream* s) { int flags; int window_id; int title_bytes; int index; int bytes; int rv; struct rail_window_state_order rwso; g_memset(&rwso, 0, sizeof(rwso)); in_uint32_le(s, window_id); g_writeln("xrdp_mm_process_rail_create_window: 0x%8.8x", window_id); in_uint32_le(s, rwso.owner_window_id); in_uint32_le(s, rwso.style); in_uint32_le(s, rwso.extended_style); in_uint32_le(s, rwso.show_state); in_uint16_le(s, title_bytes); if (title_bytes > 0) { rwso.title_info = g_new(char, title_bytes + 1); in_uint8a(s, rwso.title_info, title_bytes); rwso.title_info[title_bytes] = 0; } in_uint32_le(s, rwso.client_offset_x); in_uint32_le(s, rwso.client_offset_y); in_uint32_le(s, rwso.client_area_width); in_uint32_le(s, rwso.client_area_height); in_uint32_le(s, rwso.rp_content); in_uint32_le(s, rwso.root_parent_handle); in_uint32_le(s, rwso.window_offset_x); in_uint32_le(s, rwso.window_offset_y); in_uint32_le(s, rwso.window_client_delta_x); in_uint32_le(s, rwso.window_client_delta_y); in_uint32_le(s, rwso.window_width); in_uint32_le(s, rwso.window_height); in_uint16_le(s, rwso.num_window_rects); if (rwso.num_window_rects > 0) { bytes = sizeof(struct rail_window_rect) * rwso.num_window_rects; rwso.window_rects = (struct rail_window_rect*)g_malloc(bytes, 0); for (index = 0; index < rwso.num_window_rects; index++) { in_uint16_le(s, rwso.window_rects[index].left); in_uint16_le(s, rwso.window_rects[index].top); in_uint16_le(s, rwso.window_rects[index].right); in_uint16_le(s, rwso.window_rects[index].bottom); } } in_uint32_le(s, rwso.visible_offset_x); in_uint32_le(s, rwso.visible_offset_y); in_uint16_le(s, rwso.num_visibility_rects); if (rwso.num_visibility_rects > 0) { bytes = sizeof(struct rail_window_rect) * rwso.num_visibility_rects; rwso.visibility_rects = (struct rail_window_rect*)g_malloc(bytes, 0); for (index = 0; index < rwso.num_visibility_rects; index++) { in_uint16_le(s, rwso.visibility_rects[index].left); in_uint16_le(s, rwso.visibility_rects[index].top); in_uint16_le(s, rwso.visibility_rects[index].right); in_uint16_le(s, rwso.visibility_rects[index].bottom); } } in_uint32_le(s, flags); rv = libxrdp_orders_init(self->wm->session); if (rv == 0) { rv = libxrdp_window_new_update(self->wm->session, window_id, &rwso, flags); } if (rv == 0) { rv = libxrdp_orders_send(self->wm->session); } g_free(rwso.title_info); g_free(rwso.window_rects); g_free(rwso.visibility_rects); return rv; } #if 0 /*****************************************************************************/ /* returns error process rail configure window order */ static int xrdp_mm_process_rail_configure_window(struct xrdp_mm* self, struct stream* s) { int flags; int window_id; int index; int bytes; int rv; struct rail_window_state_order rwso; g_memset(&rwso, 0, sizeof(rwso)); in_uint32_le(s, window_id); g_writeln("xrdp_mm_process_rail_configure_window: 0x%8.8x", window_id); in_uint32_le(s, rwso.client_offset_x); in_uint32_le(s, rwso.client_offset_y); in_uint32_le(s, rwso.client_area_width); in_uint32_le(s, rwso.client_area_height); in_uint32_le(s, rwso.rp_content); in_uint32_le(s, rwso.root_parent_handle); in_uint32_le(s, rwso.window_offset_x); in_uint32_le(s, rwso.window_offset_y); in_uint32_le(s, rwso.window_client_delta_x); in_uint32_le(s, rwso.window_client_delta_y); in_uint32_le(s, rwso.window_width); in_uint32_le(s, rwso.window_height); in_uint16_le(s, rwso.num_window_rects); if (rwso.num_window_rects > 0) { bytes = sizeof(struct rail_window_rect) * rwso.num_window_rects; rwso.window_rects = (struct rail_window_rect*)g_malloc(bytes, 0); for (index = 0; index < rwso.num_window_rects; index++) { in_uint16_le(s, rwso.window_rects[index].left); in_uint16_le(s, rwso.window_rects[index].top); in_uint16_le(s, rwso.window_rects[index].right); in_uint16_le(s, rwso.window_rects[index].bottom); } } in_uint32_le(s, rwso.visible_offset_x); in_uint32_le(s, rwso.visible_offset_y); in_uint16_le(s, rwso.num_visibility_rects); if (rwso.num_visibility_rects > 0) { bytes = sizeof(struct rail_window_rect) * rwso.num_visibility_rects; rwso.visibility_rects = (struct rail_window_rect*)g_malloc(bytes, 0); for (index = 0; index < rwso.num_visibility_rects; index++) { in_uint16_le(s, rwso.visibility_rects[index].left); in_uint16_le(s, rwso.visibility_rects[index].top); in_uint16_le(s, rwso.visibility_rects[index].right); in_uint16_le(s, rwso.visibility_rects[index].bottom); } } in_uint32_le(s, flags); rv = libxrdp_orders_init(self->wm->session); if (rv == 0) { rv = libxrdp_window_new_update(self->wm->session, window_id, &rwso, flags); } if (rv == 0) { rv = libxrdp_orders_send(self->wm->session); } g_free(rwso.window_rects); g_free(rwso.visibility_rects); return rv; } #endif /*****************************************************************************/ /* returns error process rail destroy window order */ static int xrdp_mm_process_rail_destroy_window(struct xrdp_mm* self, struct stream* s) { int window_id; int rv; in_uint32_le(s, window_id); g_writeln("xrdp_mm_process_rail_destroy_window 0x%8.8x", window_id); rv = libxrdp_orders_init(self->wm->session); if (rv == 0) { rv = libxrdp_window_delete(self->wm->session, window_id); } if (rv == 0) { rv = libxrdp_orders_send(self->wm->session); } return rv; } /*****************************************************************************/ /* returns error process rail update window (show state) order */ static int xrdp_mm_process_rail_show_window(struct xrdp_mm* self, struct stream* s) { int window_id; int rv; int flags; struct rail_window_state_order rwso; g_memset(&rwso, 0, sizeof(rwso)); in_uint32_le(s, window_id); in_uint32_le(s, flags); in_uint32_le(s, rwso.show_state); g_writeln("xrdp_mm_process_rail_show_window 0x%8.8x %x", window_id, rwso.show_state); rv = libxrdp_orders_init(self->wm->session); if (rv == 0) { rv = libxrdp_window_new_update(self->wm->session, window_id, &rwso, flags); } if (rv == 0) { rv = libxrdp_orders_send(self->wm->session); } return rv; } /*****************************************************************************/ /* returns error process rail update window (title) order */ static int xrdp_mm_process_rail_update_window_text(struct xrdp_mm* self, struct stream* s) { int size; int flags; int rv = 0; int window_id; struct rail_window_state_order rwso; g_writeln("xrdp_mm_process_rail_update_window_text:"); in_uint32_le(s, window_id); in_uint32_le(s, flags); g_writeln(" update window title info: 0x%8.8x", window_id); g_memset(&rwso, 0, sizeof(rwso)); in_uint32_le(s, size); /* title size */ rwso.title_info = g_new(char, size + 1); in_uint8a(s, rwso.title_info, size); rwso.title_info[size] = 0; g_writeln(" set window title %s size %d 0x%8.8x", rwso.title_info, size, flags); rv = libxrdp_orders_init(self->wm->session); if (rv == 0) { rv = libxrdp_window_new_update(self->wm->session, window_id, &rwso, flags); } if (rv == 0) { rv = libxrdp_orders_send(self->wm->session); } g_writeln(" set window title %s %d", rwso.title_info, rv); g_free(rwso.title_info); return rv; } /*****************************************************************************/ /* returns error process alternate secondary drawing orders for rail channel */ static int xrdp_mm_process_rail_drawing_orders(struct xrdp_mm* self, struct trans* trans) { struct stream* s; int order_type; int rv = 0; s = trans_get_in_s(trans); if (s == 0) { return 1; } in_uint32_le(s, order_type); switch(order_type) { case 2: /* create_window */ xrdp_mm_process_rail_create_window(self, s); break; case 4: /* destroy_window */ xrdp_mm_process_rail_destroy_window(self, s); break; case 6: /* show_window */ rv = xrdp_mm_process_rail_show_window(self, s); break; case 8: /* update title info */ rv = xrdp_mm_process_rail_update_window_text(self, s); break; default: break; } return rv; } /*****************************************************************************/ /* returns error process a message for the channel handler */ static int xrdp_mm_chan_process_msg(struct xrdp_mm *self, struct trans *trans, struct stream *s) { int rv; int id; int size; char *next_msg; rv = 0; while (s_check_rem(s, 8)) { next_msg = s->p; in_uint32_le(s, id); in_uint32_le(s, size); next_msg += size; switch (id) { case 2: /* channel init response */ rv = xrdp_mm_trans_process_init_response(self, trans); break; case 4: /* channel setup response */ break; case 6: /* channel data response */ break; case 8: /* channel data */ rv = xrdp_mm_trans_process_channel_data(self, trans); break; case 10: /* rail alternate secondary drawing orders */ rv = xrdp_mm_process_rail_drawing_orders(self, trans); break; default: log_message(LOG_LEVEL_ERROR,"xrdp_mm_chan_process_msg: unknown id %d", id); break; } if (rv != 0) { break; } s->p = next_msg; } return rv; } /*****************************************************************************/ /* this is callback from trans obj returns error */ static int xrdp_mm_chan_data_in(struct trans *trans) { struct xrdp_mm *self; struct stream *s; int size; int error; if (trans == 0) { return 1; } self = (struct xrdp_mm *)(trans->callback_data); s = trans_get_in_s(trans); if (s == 0) { return 1; } in_uint8s(s, 4); /* id */ in_uint32_le(s, size); error = trans_force_read(trans, size - 8); if (error == 0) { /* here, the entire message block is read in, process it */ error = xrdp_mm_chan_process_msg(self, trans, s); } return error; } /*****************************************************************************/ static int xrdp_mm_chan_send_init(struct xrdp_mm *self) { struct stream *s; s = trans_get_out_s(self->chan_trans, 8192); if (s == 0) { return 1; } out_uint32_le(s, 0); /* version */ out_uint32_le(s, 8 + 8); /* size */ out_uint32_le(s, 1); /* msg id */ out_uint32_le(s, 8); /* size */ s_mark_end(s); return trans_force_write(self->chan_trans); } /*****************************************************************************/ /* connect to chansrv */ static int xrdp_mm_connect_chansrv(struct xrdp_mm *self, const char *ip, const char *port) { int index; self->usechansrv = 1; /* connect channel redir */ if ((g_strcmp(ip, "127.0.0.1") == 0) || (ip[0] == 0)) { /* unix socket */ self->chan_trans = trans_create(TRANS_MODE_UNIX, 8192, 8192); } else { /* tcp */ self->chan_trans = trans_create(TRANS_MODE_TCP, 8192, 8192); } self->chan_trans->is_term = g_is_term; self->chan_trans->si = &(self->wm->session->si); self->chan_trans->my_source = XRDP_SOURCE_CHANSRV; self->chan_trans->trans_data_in = xrdp_mm_chan_data_in; self->chan_trans->header_size = 8; self->chan_trans->callback_data = self; /* try to connect up to 4 times */ for (index = 0; index < 4; index++) { if (trans_connect(self->chan_trans, ip, port, 3000) == 0) { self->chan_trans_up = 1; break; } g_sleep(1000); log_message(LOG_LEVEL_ERROR,"xrdp_mm_connect_chansrv: connect failed " "trying again..."); } if (!(self->chan_trans_up)) { log_message(LOG_LEVEL_ERROR,"xrdp_mm_connect_chansrv: error in " "trans_connect chan"); } if (self->chan_trans_up) { if (xrdp_mm_chan_send_init(self) != 0) { log_message(LOG_LEVEL_ERROR,"xrdp_mm_connect_chansrv: error in " "xrdp_mm_chan_send_init"); } else { log_message(LOG_LEVEL_DEBUG,"xrdp_mm_connect_chansrv: chansrv " "connect successful"); } } return 0; } static void cleanup_sesman_connection(struct xrdp_mm *self) { self->delete_sesman_trans = 1; self->connected_state = 0; if (self->wm->login_mode != 10) { xrdp_wm_set_login_mode(self->wm, 11); xrdp_mm_module_cleanup(self); } } /*****************************************************************************/ static int xrdp_mm_process_login_response(struct xrdp_mm *self, struct stream *s) { int ok; int display; int rv; char ip[256]; char port[256]; tui8 guid[16]; tui8* pguid; rv = 0; in_uint16_be(s, ok); in_uint16_be(s, display); pguid = 0; if (s_check_rem(s, 16)) { in_uint8a(s, guid, 16); pguid = guid; } if (ok) { self->display = display; xrdp_wm_log_msg(self->wm, LOG_LEVEL_INFO, "login successful for display %d", display); if (xrdp_mm_setup_mod1(self) == 0) { if (xrdp_mm_setup_mod2(self, pguid) == 0) { xrdp_mm_get_value(self, "ip", ip, 255); xrdp_wm_set_login_mode(self->wm, 10); self->wm->dragging = 0; /* connect channel redir */ if ((g_strcmp(ip, "127.0.0.1") == 0) || (ip[0] == 0)) { g_snprintf(port, 255, XRDP_CHANSRV_STR, display); } else { g_snprintf(port, 255, "%d", 7200 + display); } xrdp_mm_connect_chansrv(self, ip, port); } } } else { xrdp_wm_log_msg(self->wm, LOG_LEVEL_INFO, "login failed for display %d", display); xrdp_wm_show_log(self->wm); if (self->wm->hide_log_window) { rv = 1; } } cleanup_sesman_connection(self); return rv; } /*****************************************************************************/ static int xrdp_mm_get_sesman_port(char *port, int port_bytes) { int fd; int error; int index; char *val; char cfg_file[256]; struct list *names; struct list *values; g_memset(cfg_file, 0, sizeof(char) * 256); /* default to port 3350 */ g_strncpy(port, "3350", port_bytes - 1); /* see if port is in sesman.ini file */ g_snprintf(cfg_file, 255, "%s/sesman.ini", XRDP_CFG_PATH); fd = g_file_open(cfg_file); if (fd > 0) { names = list_create(); names->auto_free = 1; values = list_create(); values->auto_free = 1; if (file_read_section(fd, "Globals", names, values) == 0) { for (index = 0; index < names->count; index++) { val = (char *)list_get_item(names, index); if (val != 0) { if (g_strcasecmp(val, "ListenPort") == 0) { val = (char *)list_get_item(values, index); error = g_atoi(val); if ((error > 0) && (error < 65000)) { g_strncpy(port, val, port_bytes - 1); } break; } } } } list_delete(names); list_delete(values); } if (fd != -1) g_file_close(fd); return 0; } /*****************************************************************************/ /* returns error data coming from client that need to go to channel handler */ int xrdp_mm_process_channel_data(struct xrdp_mm *self, tbus param1, tbus param2, tbus param3, tbus param4) { struct stream *s; int rv; int length; int total_length; int flags; int id; char *data; rv = 0; if ((self->chan_trans != 0) && self->chan_trans_up) { s = trans_get_out_s(self->chan_trans, 8192); if (s != 0) { id = LOWORD(param1); flags = HIWORD(param1); length = param2; data = (char *)param3; total_length = param4; if (total_length < length) { log_message(LOG_LEVEL_DEBUG,"WARNING in xrdp_mm_process_channel_data(): total_len < length"); total_length = length; } out_uint32_le(s, 0); /* version */ out_uint32_le(s, 8 + 8 + 2 + 2 + 2 + 4 + length); out_uint32_le(s, 5); /* msg id */ out_uint32_le(s, 8 + 2 + 2 + 2 + 4 + length); out_uint16_le(s, id); out_uint16_le(s, flags); out_uint16_le(s, length); out_uint32_le(s, total_length); out_uint8a(s, data, length); s_mark_end(s); rv = trans_force_write(self->chan_trans); } } return rv; } /*****************************************************************************/ /* This is the callback registered for sesman communication replies. */ static int xrdp_mm_sesman_data_in(struct trans *trans) { struct xrdp_mm *self; struct stream *s; int version; int size; int error; int code; if (trans == 0) { return 1; } self = (struct xrdp_mm *)(trans->callback_data); s = trans_get_in_s(trans); if (s == 0) { return 1; } in_uint32_be(s, version); in_uint32_be(s, size); error = trans_force_read(trans, size - 8); if (error == 0) { in_uint16_be(s, code); switch (code) { /* even when the request is denied the reply will hold 3 as the command. */ case 3: error = xrdp_mm_process_login_response(self, s); break; default: xrdp_wm_log_msg(self->wm, LOG_LEVEL_ERROR, "Undefined reply code %d received from sesman", code); cleanup_sesman_connection(self); break; } } return error; } #ifndef USE_NOPAM /*********************************************************************/ /* return 0 on success */ static int access_control(char *username, char *password, char *srv) { int reply; int rec = 32+1; /* 32 is reserved for PAM failures this means connect failure */ struct stream *in_s; struct stream *out_s; unsigned long version; unsigned short int dummy; unsigned short int pAM_errorcode; unsigned short int code; unsigned long size; int index; int socket = g_tcp_socket(); char port[8]; if (socket != -1) { xrdp_mm_get_sesman_port(port, sizeof(port)); /* we use a blocking socket here */ reply = g_tcp_connect(socket, srv, port); if (reply == 0) { make_stream(in_s); init_stream(in_s, 500); make_stream(out_s); init_stream(out_s, 500); s_push_layer(out_s, channel_hdr, 8); out_uint16_be(out_s, 4); /*0x04 means SCP_GW_AUTHENTICATION*/ index = g_strlen(username); out_uint16_be(out_s, index); out_uint8a(out_s, username, index); index = g_strlen(password); out_uint16_be(out_s, index); out_uint8a(out_s, password, index); s_mark_end(out_s); s_pop_layer(out_s, channel_hdr); out_uint32_be(out_s, 0); /* version */ index = (int)(out_s->end - out_s->data); out_uint32_be(out_s, index); /* size */ /* g_writeln("Number of data to send : %d",index); */ reply = g_tcp_send(socket, out_s->data, index, 0); free_stream(out_s); if (reply > 0) { /* We wait in 5 sec for a reply from sesman*/ if (g_sck_can_recv(socket, 5000)) { reply = g_tcp_recv(socket, in_s->end, 500, 0); if (reply > 0) { in_s->end = in_s->end + reply; in_uint32_be(in_s, version); /*g_writeln("Version number in reply from sesman: %d",version) ; */ in_uint32_be(in_s, size); if ((size == 14) && (version == 0)) { in_uint16_be(in_s, code); in_uint16_be(in_s, pAM_errorcode); /* this variable holds the PAM error code if the variable is >32 it is a "invented" code */ in_uint16_be(in_s, dummy); if (code != 4) /*0x04 means SCP_GW_AUTHENTICATION*/ { log_message(LOG_LEVEL_ERROR, "Returned cmd code from " "sesman is corrupt"); } else { rec = pAM_errorcode; /* here we read the reply from the access control */ } } else { log_message(LOG_LEVEL_ERROR, "Corrupt reply size or " "version from sesman: %ld", size); } } else { log_message(LOG_LEVEL_ERROR, "No data received from sesman"); } } else { log_message(LOG_LEVEL_ERROR, "Timeout when waiting for sesman"); } } else { log_message(LOG_LEVEL_ERROR, "No success sending to sesman"); } free_stream(in_s); g_tcp_close(socket); } else { log_message(LOG_LEVEL_ERROR, "Failure connecting to socket sesman"); } } else { log_message(LOG_LEVEL_ERROR, "Failure creating socket - for access control"); } if (socket != -1) g_tcp_close(socket); return rec; } #endif /*****************************************************************************/ /* This routine clears all states to make sure that our next login will be * as expected. If the user does not press ok on the log window and try to * connect again we must make sure that no previous information is stored.*/ static void cleanup_states(struct xrdp_mm *self) { if (self != NULL) { self-> connected_state = 0; /* true if connected to sesman else false */ self-> sesman_trans = NULL; /* connection to sesman */ self-> sesman_trans_up = 0; /* true once connected to sesman */ self-> delete_sesman_trans = 0; /* boolean set when done with sesman connection */ self-> display = 0; /* 10 for :10.0, 11 for :11.0, etc */ self-> code = 0; /* 0 Xvnc session, 10 X11rdp session, 20 Xorg session */ self-> sesman_controlled = 0; /* true if this is a sesman session */ self-> chan_trans = NULL; /* connection to chansrv */ self-> chan_trans_up = 0; /* true once connected to chansrv */ self-> delete_chan_trans = 0; /* boolean set when done with channel connection */ self-> usechansrv = 0; /* true if chansrvport is set in xrdp.ini or using sesman */ } } #ifndef USE_NOPAM static const char * getPAMError(const int pamError, char *text, int text_bytes) { switch (pamError) { #if defined(LINUXPAM) case PAM_SUCCESS: return "Success"; case PAM_OPEN_ERR: return "dlopen() failure"; case PAM_SYMBOL_ERR: return "Symbol not found"; case PAM_SERVICE_ERR: return "Error in service module"; case PAM_SYSTEM_ERR: return "System error"; case PAM_BUF_ERR: return "Memory buffer error"; case PAM_PERM_DENIED: return "Permission denied"; case PAM_AUTH_ERR: return "Authentication failure"; case PAM_CRED_INSUFFICIENT: return "Insufficient credentials to access authentication data"; case PAM_AUTHINFO_UNAVAIL: return "Authentication service cannot retrieve authentication info."; case PAM_USER_UNKNOWN: return "User not known to the underlying authentication module"; case PAM_MAXTRIES: return "Have exhausted maximum number of retries for service."; case PAM_NEW_AUTHTOK_REQD: return "Authentication token is no longer valid; new one required."; case PAM_ACCT_EXPIRED: return "User account has expired"; case PAM_CRED_UNAVAIL: return "Authentication service cannot retrieve user credentials"; case PAM_CRED_EXPIRED: return "User credentials expired"; case PAM_CRED_ERR: return "Failure setting user credentials"; case PAM_NO_MODULE_DATA: return "No module specific data is present"; case PAM_BAD_ITEM: return "Bad item passed to pam_*_item()"; case PAM_CONV_ERR: return "Conversation error"; case PAM_AUTHTOK_ERR: return "Authentication token manipulation error"; case PAM_AUTHTOK_LOCK_BUSY: return "Authentication token lock busy"; case PAM_AUTHTOK_DISABLE_AGING: return "Authentication token aging disabled"; case PAM_TRY_AGAIN: return "Failed preliminary check by password service"; case PAM_IGNORE: return "Please ignore underlying account module"; case PAM_MODULE_UNKNOWN: return "Module is unknown"; case PAM_AUTHTOK_EXPIRED: return "Authentication token expired"; case PAM_CONV_AGAIN: return "Conversation is waiting for event"; case PAM_INCOMPLETE: return "Application needs to call libpam again"; case 32 + 1: return "Error connecting to PAM"; case 32 + 3: return "Username okey but group problem"; default: g_snprintf(text, text_bytes, "Not defined PAM error:%d", pamError); return text; #elif defined(OPENPAM) case PAM_SUCCESS: /* 0 */ return "Success"; case PAM_OPEN_ERR: return "dlopen() failure"; case PAM_SYMBOL_ERR: return "Symbol not found"; case PAM_SERVICE_ERR: return "Error in service module"; case PAM_SYSTEM_ERR: return "System error"; case PAM_BUF_ERR: return "Memory buffer error"; case PAM_CONV_ERR: return "Conversation error"; case PAM_PERM_DENIED: return "Permission denied"; case PAM_MAXTRIES: return "Have exhausted maximum number of retries for service."; case PAM_AUTH_ERR: return "Authentication failure"; case PAM_NEW_AUTHTOK_REQD: /* 10 */ return "Authentication token is no longer valid; new one required."; case PAM_CRED_INSUFFICIENT: return "Insufficient credentials to access authentication data"; case PAM_AUTHINFO_UNAVAIL: return "Authentication service cannot retrieve authentication info."; case PAM_USER_UNKNOWN: return "User not known to the underlying authentication module"; case PAM_CRED_UNAVAIL: return "Authentication service cannot retrieve user credentials"; case PAM_CRED_EXPIRED: return "User credentials expired"; case PAM_CRED_ERR: return "Failure setting user credentials"; case PAM_ACCT_EXPIRED: return "User account has expired"; case PAM_AUTHTOK_EXPIRED: return "Authentication token expired"; case PAM_SESSION_ERR: return "Session failure"; case PAM_AUTHTOK_ERR: /* 20 */ return "Authentication token manipulation error"; case PAM_AUTHTOK_RECOVERY_ERR: return "Failed to recover old authentication token"; case PAM_AUTHTOK_LOCK_BUSY: return "Authentication token lock busy"; case PAM_AUTHTOK_DISABLE_AGING: return "Authentication token aging disabled"; case PAM_NO_MODULE_DATA: return "No module specific data is present"; case PAM_IGNORE: return "Please ignore underlying account module"; case PAM_ABORT: return "General failure"; case PAM_TRY_AGAIN: return "Failed preliminary check by password service"; case PAM_MODULE_UNKNOWN: return "Module is unknown"; case PAM_DOMAIN_UNKNOWN: /* 29 */ return "Unknown authentication domain"; default: g_snprintf(text, text_bytes, "Not defined PAM error:%d", pamError); return text; #endif } } static const char * getPAMAdditionalErrorInfo(const int pamError, struct xrdp_mm *self) { switch (pamError) { #if defined(LINUXPAM) case PAM_SUCCESS: return NULL; case PAM_OPEN_ERR: case PAM_SYMBOL_ERR: case PAM_SERVICE_ERR: case PAM_SYSTEM_ERR: case PAM_BUF_ERR: case PAM_PERM_DENIED: case PAM_AUTH_ERR: case PAM_CRED_INSUFFICIENT: case PAM_AUTHINFO_UNAVAIL: case PAM_USER_UNKNOWN: case PAM_CRED_UNAVAIL: case PAM_CRED_ERR: case PAM_NO_MODULE_DATA: case PAM_BAD_ITEM: case PAM_CONV_ERR: case PAM_AUTHTOK_ERR: case PAM_AUTHTOK_LOCK_BUSY: case PAM_AUTHTOK_DISABLE_AGING: case PAM_TRY_AGAIN: case PAM_IGNORE: case PAM_MODULE_UNKNOWN: case PAM_CONV_AGAIN: case PAM_INCOMPLETE: case _PAM_RETURN_VALUES + 1: case _PAM_RETURN_VALUES + 3: return NULL; case PAM_MAXTRIES: case PAM_NEW_AUTHTOK_REQD: case PAM_ACCT_EXPIRED: case PAM_CRED_EXPIRED: case PAM_AUTHTOK_EXPIRED: if (self->wm->pamerrortxt[0]) { return self->wm->pamerrortxt; } else { return "Authentication error - Verify that user/password is valid"; } default: return "No expected error"; #elif defined(OPENPAM) case PAM_SUCCESS: /* 0 */ return NULL; case PAM_OPEN_ERR: case PAM_SYMBOL_ERR: case PAM_SERVICE_ERR: case PAM_SYSTEM_ERR: case PAM_BUF_ERR: case PAM_CONV_ERR: case PAM_PERM_DENIED: case PAM_MAXTRIES: case PAM_AUTH_ERR: case PAM_NEW_AUTHTOK_REQD: /* 10 */ case PAM_CRED_INSUFFICIENT: case PAM_AUTHINFO_UNAVAIL: case PAM_USER_UNKNOWN: case PAM_CRED_UNAVAIL: case PAM_CRED_EXPIRED: case PAM_CRED_ERR: case PAM_ACCT_EXPIRED: case PAM_AUTHTOK_EXPIRED: case PAM_SESSION_ERR: case PAM_AUTHTOK_ERR: /* 20 */ case PAM_AUTHTOK_RECOVERY_ERR: case PAM_AUTHTOK_LOCK_BUSY: case PAM_AUTHTOK_DISABLE_AGING: case PAM_NO_MODULE_DATA: case PAM_IGNORE: case PAM_ABORT: case PAM_TRY_AGAIN: case PAM_MODULE_UNKNOWN: case PAM_DOMAIN_UNKNOWN: /* 29 */ if (self->wm->pamerrortxt[0]) { return self->wm->pamerrortxt; } else { return "Authentication error - Verify that user/password is valid"; } default: return "No expected error"; #endif } } #endif /*****************************************************************************/ int xrdp_mm_connect(struct xrdp_mm *self) { struct list *names; struct list *values; int index; int count; int ok; int rv; char *name; char *value; char ip[256]; char port[8]; char chansrvport[256]; #ifndef USE_NOPAM int use_pam_auth = 0; char pam_auth_sessionIP[256]; char pam_auth_password[256]; char pam_auth_username[256]; #endif char username[256]; char password[256]; username[0] = 0; password[0] = 0; /* make sure we start in correct state */ cleanup_states(self); g_memset(ip, 0, sizeof(ip)); g_memset(port, 0, sizeof(port)); g_memset(chansrvport, 0, sizeof(chansrvport)); rv = 0; /* success */ names = self->login_names; values = self->login_values; count = names->count; for (index = 0; index < count; index++) { name = (char *)list_get_item(names, index); value = (char *)list_get_item(values, index); if (g_strcasecmp(name, "ip") == 0) { g_strncpy(ip, value, 255); } else if (g_strcasecmp(name, "port") == 0) { if (g_strcasecmp(value, "-1") == 0) { self->sesman_controlled = 1; } } #ifndef USE_NOPAM else if (g_strcasecmp(name, "pamusername") == 0) { use_pam_auth = 1; g_strncpy(pam_auth_username, value, 255); } else if (g_strcasecmp(name, "pamsessionmng") == 0) { g_strncpy(pam_auth_sessionIP, value, 255); } else if (g_strcasecmp(name, "pampassword") == 0) { g_strncpy(pam_auth_password, value, 255); } #endif else if (g_strcasecmp(name, "password") == 0) { g_strncpy(password, value, 255); } else if (g_strcasecmp(name, "username") == 0) { g_strncpy(username, value, 255); } else if (g_strcasecmp(name, "chansrvport") == 0) { g_strncpy(chansrvport, value, 255); self->usechansrv = 1; } } #ifndef USE_NOPAM if (use_pam_auth) { int reply; char pam_error[128]; const char *additionalError; xrdp_wm_log_msg(self->wm, LOG_LEVEL_DEBUG, "Please wait, we now perform access control..."); /* g_writeln("we use pam modules to check if we can approve this user"); */ if (!g_strncmp(pam_auth_username, "same", 255)) { log_message(LOG_LEVEL_DEBUG, "pamusername copied from username - same: %s", username); g_strncpy(pam_auth_username, username, 255); } if (!g_strncmp(pam_auth_password, "same", 255)) { log_message(LOG_LEVEL_DEBUG, "pam_auth_password copied from username - same: %s", password); g_strncpy(pam_auth_password, password, 255); } /* access_control return 0 on success */ reply = access_control(pam_auth_username, pam_auth_password, pam_auth_sessionIP); xrdp_wm_log_msg(self->wm, LOG_LEVEL_INFO, "Reply from access control: %s", getPAMError(reply, pam_error, 127)); additionalError = getPAMAdditionalErrorInfo(reply, self); if (additionalError && additionalError[0]) { xrdp_wm_log_msg(self->wm, LOG_LEVEL_INFO, "%s", additionalError); } if (reply != 0) { rv = 1; return rv; } } #endif if (self->sesman_controlled) { ok = 0; trans_delete(self->sesman_trans); self->sesman_trans = trans_create(TRANS_MODE_TCP, 8192, 8192); self->sesman_trans->is_term = g_is_term; xrdp_mm_get_sesman_port(port, sizeof(port)); xrdp_wm_log_msg(self->wm, LOG_LEVEL_DEBUG, "connecting to sesman ip %s port %s", ip, port); /* xrdp_mm_sesman_data_in is the callback that is called when data arrives */ self->sesman_trans->trans_data_in = xrdp_mm_sesman_data_in; self->sesman_trans->header_size = 8; self->sesman_trans->callback_data = self; /* try to connect up to 4 times */ for (index = 0; index < 4; index++) { if (trans_connect(self->sesman_trans, ip, port, 3000) == 0) { self->sesman_trans_up = 1; ok = 1; break; } g_sleep(1000); g_writeln("xrdp_mm_connect: connect failed " "trying again..."); } if (ok) { /* fully connect */ xrdp_wm_log_msg(self->wm, LOG_LEVEL_INFO, "sesman connect ok"); self->connected_state = 1; rv = xrdp_mm_send_login(self); } else { xrdp_wm_log_msg(self->wm, LOG_LEVEL_ERROR, "Error connecting to sesman: %s port: %s", ip, port); trans_delete(self->sesman_trans); self->sesman_trans = 0; self->sesman_trans_up = 0; rv = 1; } } else /* no sesman */ { if (xrdp_mm_setup_mod1(self) == 0) { if (xrdp_mm_setup_mod2(self, 0) == 0) { xrdp_wm_set_login_mode(self->wm, 10); rv = 0; /*success*/ } else { /* connect error */ xrdp_wm_log_msg(self->wm, LOG_LEVEL_ERROR, "Error connecting to: %s", ip); rv = 1; /* failure */ } } else { log_message(LOG_LEVEL_ERROR,"Failure setting up module"); } if (self->wm->login_mode != 10) { xrdp_wm_set_login_mode(self->wm, 11); xrdp_mm_module_cleanup(self); rv = 1; /* failure */ } } if ((self->wm->login_mode == 10) && (self->sesman_controlled == 0) && (self->usechansrv != 0)) { /* if sesman controlled, this will connect later */ xrdp_mm_connect_chansrv(self, "", chansrvport); } log_message(LOG_LEVEL_DEBUG,"return value from xrdp_mm_connect %d", rv); return rv; } /*****************************************************************************/ int xrdp_mm_get_wait_objs(struct xrdp_mm *self, tbus *read_objs, int *rcount, tbus *write_objs, int *wcount, int *timeout) { int rv = 0; if (self == 0) { return 0; } rv = 0; if ((self->sesman_trans != 0) && self->sesman_trans_up) { trans_get_wait_objs(self->sesman_trans, read_objs, rcount); } if ((self->chan_trans != 0) && self->chan_trans_up) { trans_get_wait_objs(self->chan_trans, read_objs, rcount); } if (self->mod != 0) { if (self->mod->mod_get_wait_objs != 0) { rv = self->mod->mod_get_wait_objs(self->mod, read_objs, rcount, write_objs, wcount, timeout); } } if (self->encoder != 0) { read_objs[(*rcount)++] = self->encoder->xrdp_encoder_event_processed; } return rv; } #define DUMP_JPEG 0 #if DUMP_JPEG /*****************************************************************************/ static int xrdp_mm_dump_jpeg(struct xrdp_mm *self, XRDP_ENC_DATA_DONE *enc_done) { static tbus ii; static int jj; struct _header { char tag[4]; int width; int height; int bytes_follow; } header; tui16 *pheader_bytes; int cx; int cy; pheader_bytes = (tui16 *) (enc_done->comp_pad_data + enc_done->pad_bytes); cx = enc_done->enc->crects[enc_done->index * 4 + 2]; cy = enc_done->enc->crects[enc_done->index * 4 + 3]; header.tag[0] = 'B'; header.tag[1] = 'E'; header.tag[2] = 'E'; header.tag[3] = 'F'; header.width = cx; header.height = cy; header.bytes_follow = enc_done->comp_bytes - (2 + pheader_bytes[0]); if (ii == 0) { ii = g_file_open("/tmp/jpeg.beef.bin"); if (ii == -1) { ii = 0; } } if (ii != 0) { g_file_write(ii, (char*)&header, sizeof(header)); g_file_write(ii, enc_done->comp_pad_data + enc_done->pad_bytes + 2 + pheader_bytes[0], enc_done->comp_bytes - (2 + pheader_bytes[0])); jj++; g_writeln("dumping jpeg index %d", jj); } return 0; } #endif /*****************************************************************************/ int xrdp_mm_check_chan(struct xrdp_mm *self) { //g_writeln("xrdp_mm_check_chan:"); if ((self->chan_trans != 0) && self->chan_trans_up) { if (trans_check_wait_objs(self->chan_trans) != 0) { self->delete_chan_trans = 1; } } if (self->delete_chan_trans) { trans_delete(self->chan_trans); self->chan_trans = 0; self->chan_trans_up = 0; self->delete_chan_trans = 0; } return 0; } /*****************************************************************************/ static int xrdp_mm_update_module_frame_ack(struct xrdp_mm *self) { int fif; struct xrdp_encoder *encoder; encoder = self->encoder; fif = encoder->frames_in_flight; if (encoder->frame_id_client + fif > encoder->frame_id_server) { if (encoder->frame_id_server > encoder->frame_id_server_sent) { LLOGLN(10, ("xrdp_mm_update_module_ack: frame_id_server %d", encoder->frame_id_server)); encoder->frame_id_server_sent = encoder->frame_id_server; self->mod->mod_frame_ack(self->mod, 0, encoder->frame_id_server); } } return 0; } /*****************************************************************************/ static int xrdp_mm_process_enc_done(struct xrdp_mm *self) { XRDP_ENC_DATA_DONE *enc_done; int x; int y; int cx; int cy; while (1) { tc_mutex_lock(self->encoder->mutex); enc_done = (XRDP_ENC_DATA_DONE *) fifo_remove_item(self->encoder->fifo_processed); tc_mutex_unlock(self->encoder->mutex); if (enc_done == NULL) { break; } /* do something with msg */ LLOGLN(10, ("xrdp_mm_process_enc_done: message back bytes %d", enc_done->comp_bytes)); x = enc_done->x; y = enc_done->y; cx = enc_done->cx; cy = enc_done->cy; if (enc_done->comp_bytes > 0) { libxrdp_fastpath_send_frame_marker(self->wm->session, 0, enc_done->enc->frame_id); libxrdp_fastpath_send_surface(self->wm->session, enc_done->comp_pad_data, enc_done->pad_bytes, enc_done->comp_bytes, x, y, x + cx, y + cy, 32, self->encoder->codec_id, cx, cy); libxrdp_fastpath_send_frame_marker(self->wm->session, 1, enc_done->enc->frame_id); } /* free enc_done */ if (enc_done->last) { LLOGLN(10, ("xrdp_mm_process_enc_done: last set")); if (self->wm->client_info->use_frame_acks == 0) { self->mod->mod_frame_ack(self->mod, enc_done->enc->flags, enc_done->enc->frame_id); } else { self->encoder->frame_id_server = enc_done->enc->frame_id; xrdp_mm_update_module_frame_ack(self); } g_free(enc_done->enc->drects); g_free(enc_done->enc->crects); g_free(enc_done->enc); } g_free(enc_done->comp_pad_data); g_free(enc_done); } return 0; } /*****************************************************************************/ int xrdp_mm_check_wait_objs(struct xrdp_mm *self) { int rv; if (self == 0) { return 0; } rv = 0; if ((self->sesman_trans != NULL) && self->sesman_trans_up) { if (trans_check_wait_objs(self->sesman_trans) != 0) { self->delete_sesman_trans = 1; if (self->wm->hide_log_window) { /* if hide_log_window, this is fatal */ rv = 1; } } } if ((self->chan_trans != NULL) && self->chan_trans_up) { if (trans_check_wait_objs(self->chan_trans) != 0) { self->delete_chan_trans = 1; } } if (self->mod != NULL) { if (self->mod->mod_check_wait_objs != NULL) { rv = self->mod->mod_check_wait_objs(self->mod); } } if (self->delete_sesman_trans) { trans_delete(self->sesman_trans); self->sesman_trans = NULL; self->sesman_trans_up = 0; self->delete_sesman_trans = 0; } if (self->delete_chan_trans) { trans_delete(self->chan_trans); self->chan_trans = NULL; self->chan_trans_up = 0; self->delete_chan_trans = 0; } if (self->encoder != NULL) { if (g_is_wait_obj_set(self->encoder->xrdp_encoder_event_processed)) { g_reset_wait_obj(self->encoder->xrdp_encoder_event_processed); xrdp_mm_process_enc_done(self); } } return rv; } /*****************************************************************************/ /* frame ack from client */ int xrdp_mm_frame_ack(struct xrdp_mm *self, int frame_id) { struct xrdp_encoder *encoder; LLOGLN(10, ("xrdp_mm_frame_ack:")); if (self->wm->client_info->use_frame_acks == 0) { return 1; } encoder = self->encoder; LLOGLN(10, ("xrdp_mm_frame_ack: incoming %d, client %d, server %d", frame_id, encoder->frame_id_client, encoder->frame_id_server)); if ((frame_id < 0) || (frame_id > encoder->frame_id_server)) { /* if frame_id is negative or bigger then what server last sent just ack all sent frames */ /* some clients can send big number just to clear all pending frames */ encoder->frame_id_client = encoder->frame_id_server; } else { /* frame acks can come out of order so ignore older one */ encoder->frame_id_client = MAX(frame_id, encoder->frame_id_client); } xrdp_mm_update_module_frame_ack(self); return 0; } #if 0 /*****************************************************************************/ struct xrdp_painter * get_painter(struct xrdp_mod *mod) { struct xrdp_wm *wm; struct xrdp_painter *p; p = (struct xrdp_painter *)(mod->painter); if (p == 0) { wm = (struct xrdp_wm *)(mod->wm); p = xrdp_painter_create(wm, wm->session); mod->painter = (tintptr)p; } return p; } #endif /*****************************************************************************/ int server_begin_update(struct xrdp_mod *mod) { struct xrdp_wm *wm; struct xrdp_painter *p; wm = (struct xrdp_wm *)(mod->wm); p = xrdp_painter_create(wm, wm->session); xrdp_painter_begin_update(p); mod->painter = (long)p; return 0; } /*****************************************************************************/ int server_end_update(struct xrdp_mod *mod) { struct xrdp_painter *p; p = (struct xrdp_painter *)(mod->painter); if (p == 0) { return 0; } xrdp_painter_end_update(p); xrdp_painter_delete(p); mod->painter = 0; return 0; } /*****************************************************************************/ /* got bell signal... try to send to client */ int server_bell_trigger(struct xrdp_mod *mod) { struct xrdp_wm *wm; wm = (struct xrdp_wm *)(mod->wm); xrdp_wm_send_bell(wm); return 0; } /*****************************************************************************/ int server_fill_rect(struct xrdp_mod *mod, int x, int y, int cx, int cy) { struct xrdp_wm *wm; struct xrdp_painter *p; p = (struct xrdp_painter *)(mod->painter); if (p == 0) { return 0; } wm = (struct xrdp_wm *)(mod->wm); xrdp_painter_fill_rect(p, wm->target_surface, x, y, cx, cy); return 0; } /*****************************************************************************/ int server_screen_blt(struct xrdp_mod *mod, int x, int y, int cx, int cy, int srcx, int srcy) { struct xrdp_wm *wm; struct xrdp_painter *p; p = (struct xrdp_painter *)(mod->painter); if (p == 0) { return 0; } wm = (struct xrdp_wm *)(mod->wm); p->rop = 0xcc; xrdp_painter_copy(p, wm->screen, wm->target_surface, x, y, cx, cy, srcx, srcy); return 0; } /*****************************************************************************/ int server_paint_rect(struct xrdp_mod *mod, int x, int y, int cx, int cy, char *data, int width, int height, int srcx, int srcy) { struct xrdp_wm *wm; struct xrdp_bitmap *b; struct xrdp_painter *p; p = (struct xrdp_painter *)(mod->painter); if (p == 0) { return 0; } wm = (struct xrdp_wm *)(mod->wm); b = xrdp_bitmap_create_with_data(width, height, wm->screen->bpp, data, wm); xrdp_painter_copy(p, b, wm->target_surface, x, y, cx, cy, srcx, srcy); xrdp_bitmap_delete(b); return 0; } /*****************************************************************************/ int server_paint_rect_bpp(struct xrdp_mod* mod, int x, int y, int cx, int cy, char* data, int width, int height, int srcx, int srcy, int bpp) { struct xrdp_wm* wm; struct xrdp_bitmap* b; struct xrdp_painter* p; p = (struct xrdp_painter*)(mod->painter); if (p == 0) { return 0; } wm = (struct xrdp_wm*)(mod->wm); b = xrdp_bitmap_create_with_data(width, height, bpp, data, wm); xrdp_painter_copy(p, b, wm->target_surface, x, y, cx, cy, srcx, srcy); xrdp_bitmap_delete(b); return 0; } /*****************************************************************************/ int server_composite(struct xrdp_mod* mod, int srcidx, int srcformat, int srcwidth, int srcrepeat, int* srctransform, int mskflags, int mskidx, int mskformat, int mskwidth, int mskrepeat, int op, int srcx, int srcy, int mskx, int msky, int dstx, int dsty, int width, int height, int dstformat) { struct xrdp_wm* wm; struct xrdp_bitmap* b; struct xrdp_bitmap* msk; struct xrdp_painter* p; struct xrdp_os_bitmap_item* bi; p = (struct xrdp_painter*)(mod->painter); if (p == 0) { return 0; } wm = (struct xrdp_wm*)(mod->wm); b = 0; msk = 0; bi = xrdp_cache_get_os_bitmap(wm->cache, srcidx); if (bi != 0) { b = bi->bitmap; } if (mskflags & 1) { bi = xrdp_cache_get_os_bitmap(wm->cache, mskidx); if (bi != 0) { msk = bi->bitmap; } } if (b != 0) { xrdp_painter_composite(p, b, srcformat, srcwidth, srcrepeat, wm->target_surface, srctransform, mskflags, msk, mskformat, mskwidth, mskrepeat, op, srcx, srcy, mskx, msky, dstx, dsty, width, height, dstformat); } else { g_writeln("server_composite: error finding id %d or %d", srcidx, mskidx); } return 0; } /*****************************************************************************/ int server_paint_rects(struct xrdp_mod* mod, int num_drects, short *drects, int num_crects, short *crects, char *data, int width, int height, int flags, int frame_id) { struct xrdp_wm* wm; struct xrdp_mm* mm; struct xrdp_painter* p; struct xrdp_bitmap *b; short *s; int index; XRDP_ENC_DATA *enc_data; wm = (struct xrdp_wm*)(mod->wm); mm = wm->mm; LLOGLN(10, ("server_paint_rects:")); LLOGLN(10, ("server_paint_rects: %p", mm->encoder)); if (mm->encoder != 0) { /* copy formal params to XRDP_ENC_DATA */ enc_data = (XRDP_ENC_DATA *) g_malloc(sizeof(XRDP_ENC_DATA), 1); if (enc_data == 0) { return 1; } enc_data->drects = (short *) g_malloc(sizeof(short) * num_drects * 4, 0); if (enc_data->drects == 0) { g_free(enc_data); return 1; } enc_data->crects = (short *) g_malloc(sizeof(short) * num_crects * 4, 0); if (enc_data->crects == 0) { g_free(enc_data->drects); g_free(enc_data); return 1; } g_memcpy(enc_data->drects, drects, sizeof(short) * num_drects * 4); g_memcpy(enc_data->crects, crects, sizeof(short) * num_crects * 4); enc_data->mod = mod; enc_data->num_drects = num_drects; enc_data->num_crects = num_crects; enc_data->data = data; enc_data->width = width; enc_data->height = height; enc_data->flags = flags; enc_data->frame_id = frame_id; if (width == 0 || height == 0) { LLOGLN(10, ("server_paint_rects: error")); } /* insert into fifo for encoder thread to process */ tc_mutex_lock(mm->encoder->mutex); fifo_add_item(mm->encoder->fifo_to_proc, (void *) enc_data); tc_mutex_unlock(mm->encoder->mutex); /* signal xrdp_encoder thread */ g_set_wait_obj(mm->encoder->xrdp_encoder_event_to_proc); return 0; } //g_writeln("server_paint_rects:"); p = (struct xrdp_painter*)(mod->painter); if (p == 0) { return 0; } b = xrdp_bitmap_create_with_data(width, height, wm->screen->bpp, data, wm); s = crects; for (index = 0; index < num_crects; index++) { xrdp_painter_copy(p, b, wm->target_surface, s[0], s[1], s[2], s[3], s[0], s[1]); s += 4; } xrdp_bitmap_delete(b); mm->mod->mod_frame_ack(mm->mod, flags, frame_id); return 0; } /*****************************************************************************/ int server_session_info(struct xrdp_mod *mod, const char *data, int data_bytes) { struct xrdp_wm *wm; LLOGLN(10, ("server_session_info:")); wm = (struct xrdp_wm *)(mod->wm); return libxrdp_send_session_info(wm->session, data, data_bytes); } /*****************************************************************************/ int server_set_pointer(struct xrdp_mod *mod, int x, int y, char *data, char *mask) { struct xrdp_wm *wm; wm = (struct xrdp_wm *)(mod->wm); xrdp_wm_pointer(wm, data, mask, x, y, 0); return 0; } /*****************************************************************************/ int server_set_pointer_ex(struct xrdp_mod *mod, int x, int y, char *data, char *mask, int bpp) { struct xrdp_wm *wm; wm = (struct xrdp_wm *)(mod->wm); xrdp_wm_pointer(wm, data, mask, x, y, bpp); return 0; } /*****************************************************************************/ int server_palette(struct xrdp_mod *mod, int *palette) { struct xrdp_wm *wm; wm = (struct xrdp_wm *)(mod->wm); if (g_memcmp(wm->palette, palette, 255 * sizeof(int)) != 0) { g_memcpy(wm->palette, palette, 256 * sizeof(int)); xrdp_wm_send_palette(wm); } return 0; } /*****************************************************************************/ int server_msg(struct xrdp_mod *mod, char *msg, int code) { struct xrdp_wm *wm; if (code == 1) { g_writeln("%s",msg); return 0; } wm = (struct xrdp_wm *)(mod->wm); return xrdp_wm_log_msg(wm, LOG_LEVEL_DEBUG, "%s", msg); } /*****************************************************************************/ int server_is_term(struct xrdp_mod *mod) { return g_is_term(); } /*****************************************************************************/ int server_set_clip(struct xrdp_mod *mod, int x, int y, int cx, int cy) { struct xrdp_painter *p; p = (struct xrdp_painter *)(mod->painter); if (p == 0) { return 0; } return xrdp_painter_set_clip(p, x, y, cx, cy); } /*****************************************************************************/ int server_reset_clip(struct xrdp_mod *mod) { struct xrdp_painter *p; p = (struct xrdp_painter *)(mod->painter); if (p == 0) { return 0; } return xrdp_painter_clr_clip(p); } /*****************************************************************************/ int server_set_fgcolor(struct xrdp_mod *mod, int fgcolor) { struct xrdp_painter *p; p = (struct xrdp_painter *)(mod->painter); if (p == 0) { return 0; } p->fg_color = fgcolor; p->pen.color = p->fg_color; return 0; } /*****************************************************************************/ int server_set_bgcolor(struct xrdp_mod *mod, int bgcolor) { struct xrdp_painter *p; p = (struct xrdp_painter *)(mod->painter); if (p == 0) { return 0; } p->bg_color = bgcolor; return 0; } /*****************************************************************************/ int server_set_opcode(struct xrdp_mod *mod, int opcode) { struct xrdp_painter *p; p = (struct xrdp_painter *)(mod->painter); if (p == 0) { return 0; } p->rop = opcode; return 0; } /*****************************************************************************/ int server_set_mixmode(struct xrdp_mod *mod, int mixmode) { struct xrdp_painter *p; p = (struct xrdp_painter *)(mod->painter); if (p == 0) { return 0; } p->mix_mode = mixmode; return 0; } /*****************************************************************************/ int server_set_brush(struct xrdp_mod *mod, int x_origin, int y_origin, int style, char *pattern) { struct xrdp_painter *p; p = (struct xrdp_painter *)(mod->painter); if (p == 0) { return 0; } p->brush.x_origin = x_origin; p->brush.y_origin = y_origin; p->brush.style = style; g_memcpy(p->brush.pattern, pattern, 8); return 0; } /*****************************************************************************/ int server_set_pen(struct xrdp_mod *mod, int style, int width) { struct xrdp_painter *p; p = (struct xrdp_painter *)(mod->painter); if (p == 0) { return 0; } p->pen.style = style; p->pen.width = width; return 0; } /*****************************************************************************/ int server_draw_line(struct xrdp_mod *mod, int x1, int y1, int x2, int y2) { struct xrdp_wm *wm; struct xrdp_painter *p; p = (struct xrdp_painter *)(mod->painter); if (p == 0) { return 0; } wm = (struct xrdp_wm *)(mod->wm); return xrdp_painter_line(p, wm->target_surface, x1, y1, x2, y2); } /*****************************************************************************/ int server_add_char(struct xrdp_mod *mod, int font, int character, int offset, int baseline, int width, int height, char *data) { struct xrdp_font_char fi; fi.offset = offset; fi.baseline = baseline; fi.width = width; fi.height = height; fi.incby = 0; fi.data = data; fi.bpp = 1; return libxrdp_orders_send_font(((struct xrdp_wm *)mod->wm)->session, &fi, font, character); } /*****************************************************************************/ int server_draw_text(struct xrdp_mod *mod, int font, int flags, int mixmode, int clip_left, int clip_top, int clip_right, int clip_bottom, int box_left, int box_top, int box_right, int box_bottom, int x, int y, char *data, int data_len) { struct xrdp_wm *wm; struct xrdp_painter *p; p = (struct xrdp_painter *)(mod->painter); if (p == 0) { return 0; } wm = (struct xrdp_wm *)(mod->wm); return xrdp_painter_draw_text2(p, wm->target_surface, font, flags, mixmode, clip_left, clip_top, clip_right, clip_bottom, box_left, box_top, box_right, box_bottom, x, y, data, data_len); } /*****************************************************************************/ int server_reset(struct xrdp_mod *mod, int width, int height, int bpp) { struct xrdp_wm *wm; wm = (struct xrdp_wm *)(mod->wm); if (wm->client_info == 0) { return 1; } /* older client can't resize */ if (wm->client_info->build <= 419) { return 0; } /* if same, don't need to do anything */ if (wm->client_info->width == width && wm->client_info->height == height && wm->client_info->bpp == bpp) { return 0; } /* reset lib, client_info gets updated in libxrdp_reset */ if (libxrdp_reset(wm->session, width, height, bpp) != 0) { return 1; } /* reset cache */ xrdp_cache_reset(wm->cache, wm->client_info); /* resize the main window */ xrdp_bitmap_resize(wm->screen, wm->client_info->width, wm->client_info->height); /* load some stuff */ xrdp_wm_load_static_colors_plus(wm, 0); xrdp_wm_load_static_pointers(wm); return 0; } /* read the channel section of the ini file into lists * return 1 on success 0 on failure */ int read_allowed_channel_names(struct list *names, struct list *values) { int fd; int ret = 0; char cfg_file[256]; g_snprintf(cfg_file, 255, "%s/xrdp.ini", XRDP_CFG_PATH); fd = g_file_open(cfg_file); if (fd != -1) { names->auto_free = 1; values->auto_free = 1; /* all values in this section can be valid channel names */ if (file_read_section(fd, "channels", names, values) == 0) { ret = 1; } else { log_message(LOG_LEVEL_ERROR,"Failure reading channel section of configuration"); } g_file_close(fd); } return ret; } /* internal function return -1 if name is not in list * otherwise return the index 0->count-1*/ int find_name_in_lists(char *inName, struct list *names) { int reply = -1; /*means not in the list*/ int index; char *name; for (index = 0; index < names->count; index++) { name = (char *)list_get_item(names, index); if ( (name != 0) && (g_strncasecmp(name, inName, MAX_CHANNEL_NAME) == 0) ) { reply = index; break; /* stop loop - item found*/ } } return reply; } #define CHANNEL_NAME_PREFIX "channel." /* update the channel lists from connection specific overrides * return 1 on success 0 on failure */ int update_allowed_channel_names(struct xrdp_wm *wm, struct list *names, struct list *values) { int ret = 1; int index; int oldindex; char *val; char *name; //wm->mm->login_names,wm->mm->login_values for (index = 0; index < wm->mm->login_names->count; index++) { name = (char *)list_get_item(wm->mm->login_names, index); if ( (name != 0) && (g_strncmp( name, CHANNEL_NAME_PREFIX, g_strlen(CHANNEL_NAME_PREFIX)) == 0 ) ) { name += g_strlen(CHANNEL_NAME_PREFIX); // locate and remove from list oldindex = find_name_in_lists(name, names); if (oldindex >= 0) { list_remove_item(names, oldindex); list_remove_item(values, oldindex); } val = (char *)list_get_item(wm->mm->login_values, index); // (re)add to lists list_add_item(names, (tbus)g_strdup(name)); list_add_item(values, (tbus)g_strdup(val)); } } return ret; } /* internal function return 1 if name is in list of channels * and if the value is allowed */ int is_channel_enabled(char *inName, struct list *names, struct list *values) { int reply = 0; /*means not in the list*/ int index; char *val; index = find_name_in_lists(inName, names); if ( index >= 0 ) { val = (char *)list_get_item(values, index); reply = g_text2bool(val); if (reply == 0) { log_message(LOG_LEVEL_INFO,"This channel is disabled: %s", inName); } } else { log_message(LOG_LEVEL_INFO,"This channel is disabled (not in List): %s", inName); } return reply; } /* internal function only used once per session * creates the list of allowed channels and store the information * in wm struct */ void init_channel_allowed(struct xrdp_wm *wm) { int error; int i; char channelname[MAX_CHANNEL_NAME]; int index = 0; int allowindex = 0; struct list *names; struct list *values; /* first reset allowedchannels */ for (i = 0; i < MAX_NR_CHANNELS; i++) { /* 0 is a valid channel so we use -1 to mark the index as unused */ wm->allowedchannels[i] = -1; } names = list_create(); values = list_create(); /* You can override the list of allowed channels individually for each * session type. */ if ( read_allowed_channel_names(names, values) && update_allowed_channel_names(wm, names, values) ) { do { /* libxrdp_query_channel return 1 on error*/ error = libxrdp_query_channel(wm->session, index, channelname, NULL); if (error == 0) { /* examples of channel names: rdpdr ; rdpsnd ; drdynvc ; cliprdr */ if (is_channel_enabled(channelname, names, values)) { log_message(LOG_LEVEL_INFO,"The following channel is allowed: %s (%d)", channelname, index); wm->allowedchannels[allowindex] = index; allowindex++; if (allowindex >= MAX_NR_CHANNELS) { log_message(LOG_LEVEL_ALWAYS,"Programming error in is_channel_allowed"); error = 1; /* end loop */ } } else { log_message(LOG_LEVEL_INFO,"The following channel is not allowed: %s (%d)", channelname, index); } index++; } } while ((error == 0) && (index < MAX_NR_CHANNELS)); } else { log_message(LOG_LEVEL_ERROR,"Error reading channel section in inifile"); } list_delete(names); list_delete(values); } /*****************************************************************************/ /* This function returns 1 if the channelID is allowed by rule set * returns 0 if not allowed */ int is_channel_allowed(struct xrdp_wm *wm, int channel_id) { int i; int reply = 0; /* not allowed */ /* The first time each client is using this function we have to * define the list of allowed channels */ if (wm->allowedinitialized == 0) { init_channel_allowed(wm); log_message(LOG_LEVEL_DEBUG,"The allow channel list now initialized for this session"); wm->allowedinitialized = 1; } for (i = 0; i < MAX_NR_CHANNELS; i++) { if (channel_id == wm->allowedchannels[i]) { /*g_writeln("Channel allowed: %d",channel_id);*/ reply = 1; /*channel allowed*/ break; } else if (wm->allowedchannels[i] == -1) { /* We are in the unused space of the allowedchannels list * We can end the loop */ break; } } return reply; } /*****************************************************************************/ /*return 0 if the index is not found*/ int server_query_channel(struct xrdp_mod *mod, int index, char *channel_name, int *channel_flags) { struct xrdp_wm *wm; wm = (struct xrdp_wm *)(mod->wm); if (wm->mm->usechansrv) { return 1; } return libxrdp_query_channel(wm->session, index, channel_name, channel_flags); } /*****************************************************************************/ /* returns -1 on error */ int server_get_channel_id(struct xrdp_mod *mod, const char *name) { struct xrdp_wm *wm; wm = (struct xrdp_wm *)(mod->wm); if (wm->mm->usechansrv) { return -1; } return libxrdp_get_channel_id(wm->session, name); } /*****************************************************************************/ int server_send_to_channel(struct xrdp_mod *mod, int channel_id, char *data, int data_len, int total_data_len, int flags) { struct xrdp_wm *wm; wm = (struct xrdp_wm *)(mod->wm); if (is_channel_allowed(wm, channel_id)) { if (wm->mm->usechansrv) { /* * Xvnc backend reaches here * should not return 1 as this case is not an error */ return 0; } /* vnc proxy mode reaches here */ return libxrdp_send_to_channel(wm->session, channel_id, data, data_len, total_data_len, flags); } else { return 1; } } /*****************************************************************************/ int server_create_os_surface(struct xrdp_mod *mod, int rdpindex, int width, int height) { struct xrdp_wm *wm; struct xrdp_bitmap *bitmap; int error; wm = (struct xrdp_wm *)(mod->wm); bitmap = xrdp_bitmap_create(width, height, wm->screen->bpp, WND_TYPE_OFFSCREEN, wm); error = xrdp_cache_add_os_bitmap(wm->cache, bitmap, rdpindex); if (error != 0) { log_message(LOG_LEVEL_ERROR,"server_create_os_surface: xrdp_cache_add_os_bitmap failed"); return 1; } bitmap->item_index = rdpindex; bitmap->id = rdpindex; return 0; } /*****************************************************************************/ int server_create_os_surface_bpp(struct xrdp_mod* mod, int rdpindex, int width, int height, int bpp) { struct xrdp_wm* wm; struct xrdp_bitmap* bitmap; int error; wm = (struct xrdp_wm*)(mod->wm); bitmap = xrdp_bitmap_create(width, height, bpp, WND_TYPE_OFFSCREEN, wm); error = xrdp_cache_add_os_bitmap(wm->cache, bitmap, rdpindex); if (error != 0) { g_writeln("server_create_os_surface_bpp: xrdp_cache_add_os_bitmap failed"); return 1; } bitmap->item_index = rdpindex; bitmap->id = rdpindex; return 0; } /*****************************************************************************/ int server_switch_os_surface(struct xrdp_mod *mod, int rdpindex) { struct xrdp_wm *wm; struct xrdp_os_bitmap_item *bi; struct xrdp_painter *p; //g_writeln("server_switch_os_surface: id 0x%x", id); wm = (struct xrdp_wm *)(mod->wm); if (rdpindex == -1) { //g_writeln("server_switch_os_surface: setting target_surface to screen"); wm->target_surface = wm->screen; p = (struct xrdp_painter *)(mod->painter); if (p != 0) { //g_writeln("setting target"); wm_painter_set_target(p); } return 0; } bi = xrdp_cache_get_os_bitmap(wm->cache, rdpindex); if ((bi != 0) && (bi->bitmap != 0)) { //g_writeln("server_switch_os_surface: setting target_surface to rdpid %d", id); wm->target_surface = bi->bitmap; p = (struct xrdp_painter *)(mod->painter); if (p != 0) { //g_writeln("setting target"); wm_painter_set_target(p); } } else { log_message(LOG_LEVEL_ERROR,"server_switch_os_surface: error finding id %d", rdpindex); } return 0; } /*****************************************************************************/ int server_delete_os_surface(struct xrdp_mod *mod, int rdpindex) { struct xrdp_wm *wm; struct xrdp_painter *p; //g_writeln("server_delete_os_surface: id 0x%x", id); wm = (struct xrdp_wm *)(mod->wm); if (wm->target_surface->type == WND_TYPE_OFFSCREEN) { if (wm->target_surface->id == rdpindex) { g_writeln("server_delete_os_surface: setting target_surface to screen"); wm->target_surface = wm->screen; p = (struct xrdp_painter *)(mod->painter); if (p != 0) { //g_writeln("setting target"); wm_painter_set_target(p); } } } xrdp_cache_remove_os_bitmap(wm->cache, rdpindex); return 0; } /*****************************************************************************/ int server_paint_rect_os(struct xrdp_mod *mod, int x, int y, int cx, int cy, int rdpindex, int srcx, int srcy) { struct xrdp_wm *wm; struct xrdp_bitmap *b; struct xrdp_painter *p; struct xrdp_os_bitmap_item *bi; p = (struct xrdp_painter *)(mod->painter); if (p == 0) { return 0; } wm = (struct xrdp_wm *)(mod->wm); bi = xrdp_cache_get_os_bitmap(wm->cache, rdpindex); if (bi != 0) { b = bi->bitmap; xrdp_painter_copy(p, b, wm->target_surface, x, y, cx, cy, srcx, srcy); } else { log_message(LOG_LEVEL_ERROR,"server_paint_rect_os: error finding id %d", rdpindex); } return 0; } /*****************************************************************************/ int server_set_hints(struct xrdp_mod *mod, int hints, int mask) { struct xrdp_wm *wm; wm = (struct xrdp_wm *)(mod->wm); if (mask & 1) { if (hints & 1) { wm->hints |= 1; } else { wm->hints &= ~1; } } return 0; } /*****************************************************************************/ int server_window_new_update(struct xrdp_mod *mod, int window_id, struct rail_window_state_order *window_state, int flags) { struct xrdp_wm *wm; wm = (struct xrdp_wm *)(mod->wm); return libxrdp_window_new_update(wm->session, window_id, window_state, flags); } /*****************************************************************************/ int server_window_delete(struct xrdp_mod *mod, int window_id) { struct xrdp_wm *wm; wm = (struct xrdp_wm *)(mod->wm); return libxrdp_window_delete(wm->session, window_id); } /*****************************************************************************/ int server_window_icon(struct xrdp_mod *mod, int window_id, int cache_entry, int cache_id, struct rail_icon_info *icon_info, int flags) { struct xrdp_wm *wm; wm = (struct xrdp_wm *)(mod->wm); return libxrdp_window_icon(wm->session, window_id, cache_entry, cache_id, icon_info, flags); } /*****************************************************************************/ int server_window_cached_icon(struct xrdp_mod *mod, int window_id, int cache_entry, int cache_id, int flags) { struct xrdp_wm *wm; wm = (struct xrdp_wm *)(mod->wm); return libxrdp_window_cached_icon(wm->session, window_id, cache_entry, cache_id, flags); } /*****************************************************************************/ int server_notify_new_update(struct xrdp_mod *mod, int window_id, int notify_id, struct rail_notify_state_order *notify_state, int flags) { struct xrdp_wm *wm; wm = (struct xrdp_wm *)(mod->wm); return libxrdp_notify_new_update(wm->session, window_id, notify_id, notify_state, flags); } /*****************************************************************************/ int server_notify_delete(struct xrdp_mod *mod, int window_id, int notify_id) { struct xrdp_wm *wm; wm = (struct xrdp_wm *)(mod->wm); return libxrdp_notify_delete(wm->session, window_id, notify_id); } /*****************************************************************************/ int server_monitored_desktop(struct xrdp_mod *mod, struct rail_monitored_desktop_order *mdo, int flags) { struct xrdp_wm *wm; wm = (struct xrdp_wm *)(mod->wm); return libxrdp_monitored_desktop(wm->session, mdo, flags); } /*****************************************************************************/ int server_add_char_alpha(struct xrdp_mod* mod, int font, int character, int offset, int baseline, int width, int height, char* data) { struct xrdp_font_char fi; fi.offset = offset; fi.baseline = baseline; fi.width = width; fi.height = height; fi.incby = 0; fi.data = data; fi.bpp = 8; return libxrdp_orders_send_font(((struct xrdp_wm*)mod->wm)->session, &fi, font, character); } xrdp-0.9.5/xrdp/czech.txt000644 001751 001751 00000003103 12251743072 015234 0ustar00metameta000000 000000 no shift 003b 002b 011b 0161 010d 0159 017e 00fd 00e1 00ed 0039 003d 00b4 ; + Ä› Å¡ Ä Å™ ž ý á í é = ´ 0071 0071 0065 0072 0074 007a 0075 0069 006f 0070 00fa 0029 00a8 q w e r t z u i o p ú ) ¨ 0061 0073 0064 0066 0067 0068 006a 006b 006c 016f 00a7 a s d f g h j k l ů § 0079 0078 0063 0076 0062 006e 006d 002c 002e 002d y x c v b n m , . - shift 00b0 0031 0032 0033 0034 0035 0036 0037 0038 0039 0030 0025 02c7 ° 1 2 3 4 5 6 7 8 9 0 % ˇ 0051 0057 0045 0052 0054 005a 0055 0049 004f 0050 002f 0028 0027 Q W E R T Z U I O P / ( ' 0041 0053 0044 0046 0047 0048 004a 004b 004c 0022 0021 A S D F G H J K L " ! 0059 0058 0043 0056 0042 004e 004d 003f 003a 005f Y X C V B N M ? : _ altgr 007e 02c7 005e 02d8 00b0 02db 0060 00b7 00b4 02dd 00a8 00b8 ~ ˇ ^ ˘ ° Ë› ` · ´ Ë Â¨ ¸ 005c 007c 20ac 00f7 00d7 00a4 \ | € ÷ × ¤ 0111 0110 005b 005d 0142 0141 0024 00df Ä‘ Ä [ ] Å‚ Å $ ß 0023 0026 0040 007b 007d 003c 003e 002a # & @ { } < > * xrdp-0.9.5/xrdp/xrdp_encoder.c000644 001751 001751 00000036224 13201006747 016226 0ustar00metameta000000 000000 /** * xrdp: A Remote Desktop Protocol server. * * Copyright (C) Laxmikant Rashinkar 2004-2014 * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. * * Encoder */ #if defined(HAVE_CONFIG_H) #include #endif #include "xrdp_encoder.h" #include "xrdp.h" #include "thread_calls.h" #include "fifo.h" #ifdef XRDP_RFXCODEC #include "rfxcodec_encode.h" #endif #define LLOG_LEVEL 1 #define LLOGLN(_level, _args) \ do \ { \ if (_level < LLOG_LEVEL) \ { \ g_write("xrdp:xrdp_encoder [%10.10u]: ", g_time3()); \ g_writeln _args ; \ } \ } \ while (0) #define XRDP_SURCMD_PREFIX_BYTES 256 /*****************************************************************************/ static int process_enc_jpg(struct xrdp_encoder *self, XRDP_ENC_DATA *enc); #ifdef XRDP_RFXCODEC static int process_enc_rfx(struct xrdp_encoder *self, XRDP_ENC_DATA *enc); #endif static int process_enc_h264(struct xrdp_encoder *self, XRDP_ENC_DATA *enc); /*****************************************************************************/ struct xrdp_encoder * xrdp_encoder_create(struct xrdp_mm *mm) { struct xrdp_encoder *self; struct xrdp_client_info *client_info; char buf[1024]; int pid; client_info = mm->wm->client_info; if (client_info->mcs_connection_type != CONNECTION_TYPE_LAN) { return 0; } if (client_info->bpp < 24) { return 0; } self = (struct xrdp_encoder *)g_malloc(sizeof(struct xrdp_encoder), 1); self->mm = mm; if (client_info->jpeg_codec_id != 0) { LLOGLN(0, ("xrdp_encoder_create: starting jpeg codec session")); self->codec_id = client_info->jpeg_codec_id; self->in_codec_mode = 1; self->codec_quality = client_info->jpeg_prop[0]; client_info->capture_code = 0; client_info->capture_format = /* XRDP_a8b8g8r8 */ (32 << 24) | (3 << 16) | (8 << 12) | (8 << 8) | (8 << 4) | 8; self->process_enc = process_enc_jpg; } #ifdef XRDP_RFXCODEC else if (client_info->rfx_codec_id != 0) { LLOGLN(0, ("xrdp_encoder_create: starting rfx codec session")); self->codec_id = client_info->rfx_codec_id; self->in_codec_mode = 1; client_info->capture_code = 2; self->process_enc = process_enc_rfx; self->codec_handle = rfxcodec_encode_create(mm->wm->screen->width, mm->wm->screen->height, RFX_FORMAT_YUV, 0); } #endif else if (client_info->h264_codec_id != 0) { LLOGLN(0, ("xrdp_encoder_create: starting h264 codec session")); self->codec_id = client_info->h264_codec_id; self->in_codec_mode = 1; client_info->capture_code = 3; client_info->capture_format = /* XRDP_nv12 */ (12 << 24) | (64 << 16) | (0 << 12) | (0 << 8) | (0 << 4) | 0; self->process_enc = process_enc_h264; } else { g_free(self); return 0; } LLOGLN(0, ("init_xrdp_encoder: initializing encoder codec_id %d", self->codec_id)); /* setup required FIFOs */ self->fifo_to_proc = fifo_create(); self->fifo_processed = fifo_create(); self->mutex = tc_mutex_create(); pid = g_getpid(); /* setup wait objects for signalling */ g_snprintf(buf, 1024, "xrdp_%8.8x_encoder_event_to_proc", pid); self->xrdp_encoder_event_to_proc = g_create_wait_obj(buf); g_snprintf(buf, 1024, "xrdp_%8.8x_encoder_event_processed", pid); self->xrdp_encoder_event_processed = g_create_wait_obj(buf); g_snprintf(buf, 1024, "xrdp_%8.8x_encoder_term", pid); self->xrdp_encoder_term = g_create_wait_obj(buf); self->max_compressed_bytes = client_info->max_fastpath_frag_bytes & ~15; self->frames_in_flight = client_info->max_unacknowledged_frame_count; /* make sure frames_in_flight is at least 1 */ self->frames_in_flight = MAX(self->frames_in_flight, 1); /* create thread to process messages */ tc_thread_create(proc_enc_msg, self); return self; } /*****************************************************************************/ void xrdp_encoder_delete(struct xrdp_encoder *self) { XRDP_ENC_DATA *enc; XRDP_ENC_DATA_DONE *enc_done; FIFO *fifo; LLOGLN(0, ("xrdp_encoder_delete:")); if (self == 0) { return; } if (self->in_codec_mode == 0) { return; } /* tell worker thread to shut down */ g_set_wait_obj(self->xrdp_encoder_term); g_sleep(1000); /* todo delete specific encoder */ /* destroy wait objects used for signalling */ g_delete_wait_obj(self->xrdp_encoder_event_to_proc); g_delete_wait_obj(self->xrdp_encoder_event_processed); g_delete_wait_obj(self->xrdp_encoder_term); /* cleanup fifo_to_proc */ fifo = self->fifo_to_proc; if (fifo) { while (!fifo_is_empty(fifo)) { enc = (XRDP_ENC_DATA *) fifo_remove_item(fifo); if (enc == 0) { continue; } g_free(enc->drects); g_free(enc->crects); g_free(enc); } fifo_delete(fifo); } /* cleanup fifo_processed */ fifo = self->fifo_processed; if (fifo) { while (!fifo_is_empty(fifo)) { enc_done = (XRDP_ENC_DATA_DONE *) fifo_remove_item(fifo); if (enc_done == 0) { continue; } g_free(enc_done->comp_pad_data); g_free(enc_done); } fifo_delete(fifo); } g_free(self); } /*****************************************************************************/ /* called from encoder thread */ static int process_enc_jpg(struct xrdp_encoder *self, XRDP_ENC_DATA *enc) { int index; int x; int y; int cx; int cy; int quality; int error; int out_data_bytes; int count; char *out_data; XRDP_ENC_DATA_DONE *enc_done; FIFO *fifo_processed; tbus mutex; tbus event_processed; LLOGLN(10, ("process_enc_jpg:")); quality = self->codec_quality; fifo_processed = self->fifo_processed; mutex = self->mutex; event_processed = self->xrdp_encoder_event_processed; count = enc->num_crects; for (index = 0; index < count; index++) { x = enc->crects[index * 4 + 0]; y = enc->crects[index * 4 + 1]; cx = enc->crects[index * 4 + 2]; cy = enc->crects[index * 4 + 3]; if (cx < 1 || cy < 1) { LLOGLN(0, ("process_enc_jpg: error 1")); continue; } LLOGLN(10, ("process_enc_jpg: x %d y %d cx %d cy %d", x, y, cx, cy)); out_data_bytes = MAX((cx + 4) * cy * 4, 8192); if ((out_data_bytes < 1) || (out_data_bytes > 16 * 1024 * 1024)) { LLOGLN(0, ("process_enc_jpg: error 2")); return 1; } out_data = (char *) g_malloc(out_data_bytes + 256 + 2, 0); if (out_data == 0) { LLOGLN(0, ("process_enc_jpg: error 3")); return 1; } out_data[256] = 0; /* header bytes */ out_data[257] = 0; error = libxrdp_codec_jpeg_compress(self->mm->wm->session, 0, enc->data, enc->width, enc->height, enc->width * 4, x, y, cx, cy, quality, out_data + 256 + 2, &out_data_bytes); if (error < 0) { LLOGLN(0, ("process_enc_jpg: jpeg error %d bytes %d", error, out_data_bytes)); g_free(out_data); return 1; } LLOGLN(10, ("jpeg error %d bytes %d", error, out_data_bytes)); enc_done = (XRDP_ENC_DATA_DONE *) g_malloc(sizeof(XRDP_ENC_DATA_DONE), 1); enc_done->comp_bytes = out_data_bytes + 2; enc_done->pad_bytes = 256; enc_done->comp_pad_data = out_data; enc_done->enc = enc; enc_done->last = index == (enc->num_crects - 1); enc_done->x = x; enc_done->y = y; enc_done->cx = cx; enc_done->cy = cy; /* done with msg */ /* inform main thread done */ tc_mutex_lock(mutex); fifo_add_item(fifo_processed, enc_done); tc_mutex_unlock(mutex); /* signal completion for main thread */ g_set_wait_obj(event_processed); } return 0; } #ifdef XRDP_RFXCODEC /*****************************************************************************/ /* called from encoder thread */ static int process_enc_rfx(struct xrdp_encoder *self, XRDP_ENC_DATA *enc) { int index; int x; int y; int cx; int cy; int out_data_bytes; int count; int error; char *out_data; XRDP_ENC_DATA_DONE *enc_done; FIFO *fifo_processed; tbus mutex; tbus event_processed; struct rfx_tile *tiles; struct rfx_rect *rfxrects; int alloc_bytes; LLOGLN(10, ("process_enc_rfx:")); LLOGLN(10, ("process_enc_rfx: num_crects %d num_drects %d", enc->num_crects, enc->num_drects)); fifo_processed = self->fifo_processed; mutex = self->mutex; event_processed = self->xrdp_encoder_event_processed; error = 1; out_data = NULL; out_data_bytes = 0; if ((enc->num_crects > 0) && (enc->num_drects > 0)) { alloc_bytes = XRDP_SURCMD_PREFIX_BYTES; alloc_bytes += self->max_compressed_bytes; alloc_bytes += sizeof(struct rfx_tile) * enc->num_crects + sizeof(struct rfx_rect) * enc->num_drects; out_data = g_new(char, alloc_bytes); if (out_data != NULL) { tiles = (struct rfx_tile *) (out_data + XRDP_SURCMD_PREFIX_BYTES + self->max_compressed_bytes); rfxrects = (struct rfx_rect *) (tiles + enc->num_crects); count = enc->num_crects; for (index = 0; index < count; index++) { x = enc->crects[index * 4 + 0]; y = enc->crects[index * 4 + 1]; cx = enc->crects[index * 4 + 2]; cy = enc->crects[index * 4 + 3]; tiles[index].x = x; tiles[index].y = y; tiles[index].cx = cx; tiles[index].cy = cy; tiles[index].quant_y = 0; tiles[index].quant_cb = 0; tiles[index].quant_cr = 0; } count = enc->num_drects; for (index = 0; index < count; index++) { x = enc->drects[index * 4 + 0]; y = enc->drects[index * 4 + 1]; cx = enc->drects[index * 4 + 2]; cy = enc->drects[index * 4 + 3]; rfxrects[index].x = x; rfxrects[index].y = y; rfxrects[index].cx = cx; rfxrects[index].cy = cy; } out_data_bytes = self->max_compressed_bytes; error = rfxcodec_encode(self->codec_handle, out_data + XRDP_SURCMD_PREFIX_BYTES, &out_data_bytes, enc->data, enc->width, enc->height, enc->width * 4, rfxrects, enc->num_drects, tiles, enc->num_crects, 0, 0); } } LLOGLN(10, ("process_enc_rfx: rfxcodec_encode rv %d", error)); /* only if enc_done->comp_bytes is not zero is something sent to the client but you must always send something back even on error so Xorg can get ack */ enc_done = g_new0(XRDP_ENC_DATA_DONE, 1); if (enc_done == NULL) { return 1; } enc_done->comp_bytes = error == 0 ? out_data_bytes : 0; enc_done->pad_bytes = XRDP_SURCMD_PREFIX_BYTES; enc_done->comp_pad_data = out_data; enc_done->enc = enc; enc_done->last = 1; enc_done->cx = self->mm->wm->screen->width; enc_done->cy = self->mm->wm->screen->height; /* done with msg */ /* inform main thread done */ tc_mutex_lock(mutex); fifo_add_item(fifo_processed, enc_done); tc_mutex_unlock(mutex); /* signal completion for main thread */ g_set_wait_obj(event_processed); return 0; } #endif /*****************************************************************************/ /* called from encoder thread */ static int process_enc_h264(struct xrdp_encoder *self, XRDP_ENC_DATA *enc) { LLOGLN(0, ("process_enc_x264:")); return 0; } /** * Encoder thread main loop *****************************************************************************/ THREAD_RV THREAD_CC proc_enc_msg(void *arg) { XRDP_ENC_DATA *enc; FIFO *fifo_to_proc; tbus mutex; tbus event_to_proc; tbus term_obj; tbus lterm_obj; int robjs_count; int wobjs_count; int cont; int timeout; tbus robjs[32]; tbus wobjs[32]; struct xrdp_encoder *self; LLOGLN(0, ("proc_enc_msg: thread is running")); self = (struct xrdp_encoder *) arg; if (self == 0) { LLOGLN(0, ("proc_enc_msg: self nil")); return 0; } fifo_to_proc = self->fifo_to_proc; mutex = self->mutex; event_to_proc = self->xrdp_encoder_event_to_proc; term_obj = g_get_term_event(); lterm_obj = self->xrdp_encoder_term; cont = 1; while (cont) { timeout = -1; robjs_count = 0; wobjs_count = 0; robjs[robjs_count++] = term_obj; robjs[robjs_count++] = lterm_obj; robjs[robjs_count++] = event_to_proc; if (g_obj_wait(robjs, robjs_count, wobjs, wobjs_count, timeout) != 0) { /* error, should not get here */ g_sleep(100); } if (g_is_wait_obj_set(term_obj)) /* global term */ { LLOGLN(0, ("proc_enc_msg: global term")); break; } if (g_is_wait_obj_set(lterm_obj)) /* xrdp_mm term */ { LLOGLN(0, ("proc_enc_msg: xrdp_mm term")); break; } if (g_is_wait_obj_set(event_to_proc)) { /* clear it right away */ g_reset_wait_obj(event_to_proc); /* get first msg */ tc_mutex_lock(mutex); enc = (XRDP_ENC_DATA *) fifo_remove_item(fifo_to_proc); tc_mutex_unlock(mutex); while (enc != 0) { /* do work */ self->process_enc(self, enc); /* get next msg */ tc_mutex_lock(mutex); enc = (XRDP_ENC_DATA *) fifo_remove_item(fifo_to_proc); tc_mutex_unlock(mutex); } } } /* end while (cont) */ LLOGLN(0, ("proc_enc_msg: thread exit")); return 0; } xrdp-0.9.5/xrdp/ad24b.bmp000644 001751 001751 00000162746 12251743072 015016 0ustar00metameta000000 000000 BMæå6(ŒŒ°å  ÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÿÿÿÿÿÿÿÿÿÿÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÿÿÿÿÿÿÿÿÿÿÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÿÿÿÿÿÿÿÿÿÿÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÿÿÿÿÿÿÿÿÿÿÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÿÿÿÿÿÿÿÿÿÿÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÿÿÿÿÿÿÿÿÿÿÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÿÿÿÿÿÿÿÿÿÿÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÿÿÿÿÿÿÿÿÿÿÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÿÿÿÿÿÿÿÿÿÿÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÿÿÿÿÿÿÿÿÿÿÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÿÿÿÿÿÿÿÿÿÿÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÿÿÿÿÿÿÿÿÿÿÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÿÿÿÿÿÿÿÿÿÿÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÿÿÿÿÿÿÿÿÿÿÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÿÿÿÿÿÿÿÿÿÿÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÿÿÿÿÿÿÿÿÿÿÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÿÿÿÿÿÿÿÿÿÿÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀ™™™fffffffff333ffffff™™™ÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÿÿÿÿÿÿÿÿÿÿÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀffffffÌ™fÌ™fÿ™™ÿ™™ÿ™™Ì™f™ffffffff™™™ÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÿÿÿÿÿÿÿÿÿÿÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀ™™™ffffffffffff™™™ÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀffffff™ffÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™Ì™ffff™™™ÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÿÿÿÿÿÿÿÿÿÿÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀfffffff™ffÌffÌ™fÌff™fffffffÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀ™™™333fffÌ™fÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™ffff™™™ÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÿÿÿÿÿÿÿÿÿÿÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀ™™™™™™™™™ÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀfffffff™f™Ì™™Ì™™Ì™™Ì™™Ì™™Ì™™Ì™f™ffffÀÀÀÀÀÀÀÀÀÀÀÀfffffff33™ffÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ffffffÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÿÿÿÿÿÿÿÿÿÿÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀ™™™fffff™ff™ffffff™™™ÀÀÀÀÀÀÀÀÀÀÀÀ™™™fff333f™f™Ì™™Ì™™Ì™™Ì™™Ì™™Ì™™Ì™™Ì™™Ì™f™ffff™™™™™™fffÌ™f™fffffÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™ffffffffffÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÿÿÿÿÿÿÿÿÿÿÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀ™™™ffffff™™ÌÌÌÿÌÌÿÌÌÿ™™ÿff™fffÀÀÀÀÀÀffffffffffff™Ì™™Ì™™Ì™™Ì™™Ì™™Ì™™Ì™™Ì™™Ì™™Ì™f™f3f3ffffffÿ™fÿ™™fffÌ™fÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™Ì™ffff™ffÿ™™™ff™™™ÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÿÿÿÿÿÿÿÿÿÿÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀfffffffff™™ÌÌÌÿÌÌÿÌÌÿÌÌÿÌÌÿ™™Ìffffffffff™f™Ì™ffff™f™Ì™™Ì™™Ì™™Ì™™Ì™™Ì™™Ì™™Ì™™Ì™f™f3fff™ffffÿ™™ÿ™™ÿ™™333ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™Ì™ffff™ffÿ™™ÿ™™ÿ™™fff™™™ÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÿÿÿÿÿÿÿÿÿÿÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀ™™™ff™™™™fffÌÌÿÌÌÿÌÌÿÌÌÿÌÌÿ™™Ìfffff™ffffff™Ì™™Ì™ffffÌf™Ì™™Ì™™Ì™™Ì™™Ì™™Ì™™Ì™™Ì™f™fffffÌffffÌ™fÿ™™ÿ™™Ì™ffffÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™Ì™fff3™ffÿ™™ÿ™™ÿ™™ÿ™™Ì™ffffÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÿÿÿÿÿÿÿÿÿÿÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀfff™™ÿff™ff™ÌÌÿÌÌÿÌÌÿÌÌÿ™™Ìfffff™ÌÌÿfff™Ì™™Ì™™Ì™333™Ì™™Ì™™Ì™™Ì™™Ì™™Ì™™Ì™™Ì™ffffff™Ì™f™f™ffÿ™™ÿ™™ÿ™™Ì™ffffÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™Ì™fff3Ì™fÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™Ì™ffffÀÀÀÀÀÀÀÀÀÀÀÀ™™™™™™™™™ÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÿÿÿÿÿÿÿÿÿÿÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀ™™™ff™ÌÌÿff™fffÌÌÿÌÌÿÌÌÿ™™Ìfff™™™ÌÌÿ™™Ìfff™Ì™™Ì™™Ì™ffffÌf™Ì™™Ì™™Ì™™Ì™™Ì™™Ì™ffffff™Ì™™Ì™fffÌ™fÿ™™ÿ™™ÿ™™Ì™ffffÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™Ì™fff3Ì™fÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™™fffffÀÀÀÀÀÀfffffff™ff™fffffffÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀ™™™fffff3ffffff™™™ÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÿÿÿÿÿÿÿÿÿÿÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀfff™™™ÌÌÿ™™ÌfffÌÌÿÌÌÿ™™Ìfff™™ÌÌÌÿÌÌÿ™™Ìfff™Ì™™Ì™™Ì™ffff™f™Ì™™Ì™™Ì™™Ì™™Ì™ffffff™Ì™™Ì™™Ì™ff3ÿ™™ÿ™™ÿ™™ÿ™™ÿ™ff33ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™™ffff3Ì™fÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™™fffff3f3fff™Ì™™Ì™™Ì™™Ì™f™ffffÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀffffffÌ™fÿ™™ÿ™™ÿ™f™fffff™™™ÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÿÿÿÿÿÿÿÿÿÿÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀ™™™ff™ÌÌÿ™™ÿfff™™™™™™fff™™ÌÌÌÿÌÌÿÌÌÿff™f™f™Ì™™Ì™™Ì™f™ffff™Ì™™Ì™™Ì™™Ì™ffffff™Ì™™Ì™™Ì™f™ffffÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ff3Ì™fÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™™fffffÌ™fÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™fffffffff™Ì™™Ì™™Ì™™Ì™™Ì™f™ffffÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀ™™™fff333fffÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™fff™™™ÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÿÿÿÿÿÿÿÿÿÿÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀ™™™fffÌÌÿÌÌÿ™™Ìffffff™™ÌÌÌÿÌÌÿÌÌÿÌÌÿ™™Ìfff™Ì™™Ì™™Ì™™Ì™3f3fÌf™Ì™™Ì™ffffff™Ì™™Ì™™Ì™™Ì™f™f™ffÿ™™ÿ™™ÿ™™ÿ™™ÿ™™fff™ffÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™™fffffÿ™fÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™ffffffffff™Ì™™Ì™™Ì™™Ì™™Ì™fff™™™ÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀ™ffffffff333fffff3Ì™fÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™fff™™™ÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÿÿÿÿÿÿÿÿÿÿÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀfff™™™ff™fffffffffÌÌÿÌÌÿÌÌÿÌÌÿÌÌÿ™™ÿfff™Ì™™Ì™™Ì™™Ì™f™ffff™Ì™ffffff™Ì™™Ì™™Ì™™Ì™™Ì™f™ffffÿ™™ÿ™™ÿ™™ÿ™™ÿ™™™fffffÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ffffffÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™Ì™ffffffff™f™Ì™™Ì™™Ì™™Ì™fÌ™fffÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀ™™™ffffff™ffÿ™fffffffÿ™™™fffffÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™fffÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÿÿÿÿÿÿÿÿÿÿÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀ™™™333fff™™Ì™™ÿffffffÌÌÿÌÌÿÌÌÿÌÌÿÌÌÿffffÌf™Ì™™Ì™™Ì™™Ì™fff333f™f™Ì™™Ì™™Ì™™Ì™™Ì™™Ì™™Ì™fffÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™fff™ffÿ™™ÿ™™ÿ™™ffffffÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™Ì™ffff3f3f™f™Ì™™Ì™™Ì™™Ì™fffÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀfff™ffÌ™fÿ™™ÿ™™™fffffÿ™™ÿ™™ÿ™™fff™ffÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™™ff™™™ÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÿÿÿÿÿÿÿÿÿÿÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀ™™™fff™™ÿÌÌÿ™™Ìfffff™ÌÌÿÌÌÿÌÌÿÌÌÿ™™Ìfff™Ì™™Ì™f™ffff3ff333fÌ™™Ì™™Ì™™Ì™™Ì™™Ì™™Ì™™Ì™fffÿ™fÿ™™ÿ™™ÿ™™ÿ™™ÿ™™Ì™fff3ÿ™™ÿ™fffffffÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™™fffff3f3™Ì™™Ì™™Ì™™Ì™fff™™™ÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀfff™ffÿ™™ÿ™™ÿ™™™fffffÿ™fÿ™™ÿ™™ÿ™™ÿ™™fff™ffÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™fffÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÿÿÿÿÿÿÿÿÿÿÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀ™™™fff™™ÿÌÌÿ™™Ìfff™™™ÌÌÿÌÌÿÌÌÿÌÌÿfffffffffffff™f™Ì™f™f3f3™Ì™™Ì™™Ì™™Ì™™Ì™™Ì™™Ì™fffÌ™fÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™™fffffffffffÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™fffffffff™Ì™™Ì™™Ì™f™f™™™ÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀfff™ffÿ™™ÿ™™ÿ™™Ì™fff3Ì™fÿ™™ÿ™™ÿ™™ÿ™™ÿ™™Ì™fff3Ì™fÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™™ff™™™ÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÿÿÿÿÿÿÿÿÿÿÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀfffff™ÌÌÿÌÌÿ™™Ìfff™™ÌÌÌÿÌÌÿÌÌÿ™™Ì3f3fff™Ì™™Ì™™Ì™™Ì™f™ffff™Ì™™Ì™™Ì™™Ì™™Ì™™Ì™f™ffffÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™™ff333fffÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™fffffffff™Ì™™Ì™f™f™™™ÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀ™™™fffÿ™™ÿ™™ÿ™™Ì™fff3Ì™fÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™Ìfffffÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™Ì™ffffÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÿÿÿÿÿÿÿÿÿÿÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀfffff™ÌÌÿÌÌÿ™™Ìfff™™ÌÌÌÿÌÌÿÌÌÿ™™Ìfff™Ì™™Ì™™Ì™™Ì™™Ì™ffffff™Ì™™Ì™™Ì™™Ì™™Ì™™Ì™fff™ffÿ™™ÿ™™ÿ™f™ffff3fff™ffff3Ì™fÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™Ì™ffffffff™f™Ì™f™f™™™ÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀ™™™fffÿ™™ÿ™™ÿ™™Ì™fff3™ffÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™™fffffÿ™™ÿ™™ÿ™™ÿ™™ÿ™™Ì™ffffÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÿÿÿÿÿÿÿÿÿÿÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀfff™™™ÌÌÿÌÌÿ™™™fff™™ÌÌÌÿÌÌÿÌÌÿ™™Ìfff™Ì™™Ì™™Ì™™Ì™™Ì™ffffff™Ì™™Ì™™Ì™™Ì™™Ì™™Ì™fffÌ™f™ffff3fffÌ™fÿ™™ÿ™™™fffffÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™Ì™ffff3f3fÌffffÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀ™™™fffÿ™™ÿ™™ÿ™™Ì™ffff™ffÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™fff™ffÿ™™ÿ™™ÿ™™ÿ™™ÿ™™fffÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÿÿÿÿÿÿÿÿÿÿÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀfff™™ÌÌÌÿÌÌÿff™fff™™ÿÌÌÿÌÌÿÌÌÿ™™™fff™Ì™™Ì™™Ì™™Ì™™Ì™ffffff™Ì™™Ì™™Ì™™Ì™™Ì™f™fff3fffÌ™fÿ™™ÿ™™ÿ™™ÿ™™ÿ™™™fffffÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™™fffff333fffÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀ™™™fffÌ™fÿ™™ÿ™™ÿ™™ffffffÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™fff3Ì™fÿ™™ÿ™™ÿ™™ÿ™™333ÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÿÿÿÿÿÿÿÿÿÿÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀfff™™ÌÌÌÿÌÌÿff™fffÌÌÿÌÌÿÌÌÿÌÌÿff™fff™Ì™™Ì™™Ì™™Ì™™Ì™ffff™f™Ì™™Ì™™Ì™™Ì™™Ì™fff™ffÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ffffffÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™fffff3ÌÌÌÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀfffÌ™fÿ™™ÿ™™ÿ™™ffffffÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™Ì™fff3Ì™fÿ™™ÿ™™ÿ™™fffÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÿÿÿÿÿÿÿÿÿÿÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀfff™™ÌÌÌÿ™™ÿffffffÌÌÿÌÌÿÌÌÿÌÌÿffffff™Ì™™Ì™™Ì™™Ì™™Ì™3f3f™f™Ì™™Ì™™Ì™™Ì™™Ì™fff™ffÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ffffffÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™fff™™™ÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀfffÌ™fÿ™™ÿ™™ÿ™™ffffffÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™™fffffÿ™™ÿ™™Ì™ffffÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÿÿÿÿÿÿÿÿÿÿÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀfff™™ÌÌÌÿ™™ÿffffffÌÌÿÌÌÿÌÌÿ™™ÿffff™f™Ì™™Ì™™Ì™™Ì™fÌf3f3f™f™Ì™™Ì™™Ì™™Ì™™Ì™fffÌ™fÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™ffff™ffÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™Ì™ffffÌÌÌÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀfffÌ™fÿ™™ÿ™™ÿ™™™fffffÿ™fÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™fff™ffÿ™™™ff™™™ÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÿÿÿÿÿÿÿÿÿÿÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀ™™™fff™™ÿÌÌÿ™™ÿfffff™ÌÌÿÌÌÿÌÌÿ™™ÿffff™f™Ì™™Ì™™Ì™™Ì™f™f3f3fÌ™™Ì™™Ì™™Ì™™Ì™™Ì™fffÌ™fÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™Ì™fff3™ffÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™Ì™ffffÌÌÌÀÀÀÀÀÀÀÀÀÀÀÀfffÌ™fÿ™™ÿ™™ÿ™™™fffffÌ™fÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™fff™fffffÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÿÿÿÿÿÿÿÿÿÿÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀ™™™fff™™ÿÌÌÿ™™Ìfff™™™ÌÌÿÌÌÿÌÌÿ™™Ìffff™f™Ì™™Ì™™Ì™™Ì™f™ffff™Ì™™Ì™™Ì™™Ì™™Ì™fÌ™fffÌ™fÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™Ì™fff3Ì™fÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™™fffffÌÌÌÀÀÀÌÌÌfff™ffÿ™™ÿ™™ÿ™™Ì™fff3Ì™fÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™Ì™ff33fffÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÿÿÿÿÿÿÿÿÿÿÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀ™™™fff™™ÿ™™ÿ™™™33fff™ÌÌÿÌÌÿÌÌÿ™™ÌffffÌf™Ì™™Ì™™Ì™™Ì™f™ffff™Ì™™Ì™™Ì™™Ì™™Ì™f™ffffÌ™fÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™Ì™fff3Ì™fÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™™ff™ffÀÀÀfff™ffÿ™™ÿ™™ÿ™™Ì™fff3Ì™fÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™Ì™ffffÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÿÿÿÿÿÿÿÿÿÿÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀffffff333ffffffff™ÌÌÿÌÌÿÌÌÿÌÌÿ™™ÌffffÌ™™Ì™™Ì™™Ì™™Ì™ffffff™Ì™™Ì™™Ì™™Ì™™Ì™f™ffffÿ™fÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™™ffff3Ì™fÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ffffff™ffÿ™™ÿ™™ÿ™™Ì™fff3™ffÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™Ì™ffffÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÿÿÿÿÿÿÿÿÿÿÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀfffff™™™Ìfffff™ÌÌÿÌÌÿÌÌÿÌÌÿÌÌÿÌÌÿ™™Ìfff™Ì™™Ì™™Ì™™Ì™™Ì™ffffff™Ì™™Ì™™Ì™™Ì™™Ì™f™ffffÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™™fffffÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™Ì™ff33Ì™fÿ™™ÿ™™ÿ™ffff™ffÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™fff™™™ÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÿÿÿÿÿÿÿÿÿÿÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀfff™™™™™ÿffffffÌÌÿÌÌÿÌÌÿÌÌÿÌÌÿÌÌÿÌÌÿÌÌÿ™™Ìfff™Ì™™Ì™™Ì™™Ì™™Ì™ffffff™Ì™™Ì™™Ì™™Ì™™Ì™f™ffffÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™™fffffÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™™ffff3Ì™fÿ™™ffffffÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™™ff™™™ÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÿÿÿÿÿÿÿÿÿÿÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀfff™™™™™ÿffffffÌÌÿÌÌÿÌÌÿÌÌÿÌÌÿÌÌÿÌÌÿÌÌÿÌÌÿÌÌÿf™™fff™Ì™™Ì™™Ì™™Ì™™Ì™ffff™f™Ì™™Ì™™Ì™™Ì™™Ì™fff™ffÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ffffffÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™™fffffffffffÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™™fffffÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÿÿÿÿÿÿÿÿÿÿÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀfffff™ÌÌÿffffff™™ÿÌÌÿÌÌÿÌÌÿÌÌÿÌÌÿÌÌÿÌÌÿÌÌÿÌÌÿÌÌÿÌÌÿff™fff™Ì™™Ì™™Ì™™Ì™™Ì™3f3f™f™Ì™™Ì™™Ì™™Ì™™Ì™fff™ffÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ffffffÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ffffffÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™Ì™ffffÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÿÿÿÿÿÿÿÿÿÿÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀff™ff™ÌÌÿff™fff™™ÿÌÌÿÌÌÿÌÌÿÌÌÿÌÌÿÌÌÿÌÌÿÌÌÿÌÌÿÌÌÿÌÌÿÌÌÿÌÌÿffffff™Ì™™Ì™™Ì™™Ì™fÌf3f3f™f™Ì™™Ì™™Ì™™Ì™™Ì™fff™ffÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™ffff™ffÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™fÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™ffffÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÿÿÿÿÿÿÿÿÿÿÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀ™™™fff™™ÿ™™™fff™™ÌÌÌÿÌÌÿÌÌÿÌÌÿÌÌÿÌÌÿÌÌÿÌÌÿÌÌÿÌÌÿ™™ÿÌÌÿÌÌÿÌÌÿ™™ÿffff™f™Ì™™Ì™™Ì™™Ì™f™f3f3fÌ™™Ì™™Ì™™Ì™™Ì™™Ì™fffÌ™fÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™Ì™fff3™ffÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™fff™™™ÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÿÿÿÿÿÿÿÿÿÿÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀ™™™fff™™ÿ™™Ìfff™™ÌÌÌÿÌÌÿÌÌÿÌÌÿÌÌÿÌÌÿÌÌÿÌÌÿÌÌÿÌÌÿ™™ÿfff™™™ÌÌÿÌÌÿÌÌÿ™™ÿffff™f™Ì™™Ì™™Ì™™Ì™f™ffff™Ì™™Ì™™Ì™™Ì™™Ì™™Ì™fffÌ™fÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™Ì™fff3Ì™fÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™™fffffÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÿÿÿÿÿÿÿÿÿÿÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀ™™™fff™™Ì™™Ìfff™™ÌÌÌÿÌÌÿÌÌÿÌÌÿÌÌÿÌÌÿÌÌÿÌÌÿÌÌÿÌÌÿÌÌÿfffffffff™™ÌÌÌÿÌÌÿÌÌÿ™™Ìffff™f™Ì™™Ì™fÌff™f3f33f3™Ì™™Ì™™Ì™™Ì™™Ì™fÌ™fffÌ™fÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™Ì™fff3Ì™fÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™Ì™ffffÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÿÿÿÿÿÿÿÿÿÿÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀfff™™Ì™™Ìfffff™ÌÌÿÌÌÿÌÌÿÌÌÿÌÌÿÌÌÿÌÌÿÌÌÿÌÌÿÌÌÿÌÌÿff™fff™™ÿ™™Ìfff™™ÌÌÌÿÌÌÿÌÌÿ™™Ìffffff333ffffff333f™f™Ì™™Ì™™Ì™™Ì™™Ì™™Ì™f™ffffÌ™fÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™™ffff3Ì™fÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™Ì™ffffÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÿÿÿÿÿÿÿÿÿÿÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀfff™™Ì™™ÿfffff™ÌÌÿÌÌÿÌÌÿÌÌÿÌÌÿÌÌÿÌÌÿÌÌÿÌÌÿÌÌÿÌÌÿ™™Ìffffff™™ÿÌÌÿ™™™fff™™ÿÌÌÿÌÌÿ™™™ffff™f™Ì™™Ì™ffffff™Ì™™Ì™™Ì™™Ì™™Ì™™Ì™™Ì™™Ì™f™ffffÿ™fÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™™fffffÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™fff™™™ÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÿÿÿÿÿÿÿÿÿÿÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀfff™™Ì™™ÿffffffÌÌÿÌÌÿÌÌÿÌÌÿÌÌÿÌÌÿÌÌÿÌÌÿÌÌÿÌÌÿÌÌÿ™™ÿfff™™™™™™fffÌÌÿÌÌÿff™fffÌÌÿ™™Ìfff™Ì™™Ì™™Ì™ffffff™Ì™™Ì™™Ì™™Ì™™Ì™™Ì™™Ì™™Ì™™Ì™™Ì™f™ffffÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™™fffffÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™fff™™™ÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÿÿÿÿÿÿÿÿÿÿÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀfff™™ÌÌÌÿffffffÌÌÿÌÌÿÌÌÿÌÌÿÌÌÿÌÌÿÌÌÿÌÌÿÌÌÿÌÌÿÌÌÿÌÌÿff™™™™ÀÀÀÀÀÀfffff™ÌÌÿ™™ÿffffffffffÌ™™Ì™™Ì™ffffff™Ì™™Ì™™Ì™™Ì™™Ì™™Ì™™Ì™™Ì™™Ì™™Ì™™Ì™™Ì™f™ffffÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ffffffÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™™fffffÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÿÿÿÿÿÿÿÿÿÿÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀfffffffffffffff™™ÿÌÌÿÌÌÿÌÌÿÌÌÿÌÌÿÌÌÿÌÌÿÌÌÿÌÌÿÌÌÿÌÌÿ™™™fffÀÀÀÀÀÀÀÀÀÀÀÀfffff™ÌÌÿ™™Ì3f3fÌf™Ì™™Ì™ffffff™Ì™™Ì™™Ì™™Ì™™Ì™™Ì™™Ì™™Ì™™Ì™™Ì™™Ì™™Ì™™Ì™™Ì™fff™ffÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ffffffÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™Ì™ffffÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÿÿÿÿÿÿÿÿÿÿÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀ™™™fff™™Ì™™Ì333fffff™ÌÌÿÌÌÿÌÌÿÌÌÿÌÌÿÌÌÿÌÌÿÌÌÿÌÌÿÌÌÿ™™ÌfffÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀfffff™ffff™f™Ì™™Ì™f™ffff™Ì™™Ì™™Ì™™Ì™™Ì™™Ì™™Ì™™Ì™™Ì™™Ì™™Ì™™Ì™™Ì™™Ì™™Ì™™Ì™fff™ffÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™ffff™ffÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™Ì™ffffÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÿÿÿÿÿÿÿÿÿÿÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀfff™™ÌÌÌÿff™fff™™Ìfffff™ÌÌÿÌÌÿÌÌÿÌÌÿÌÌÿÌÌÿÌÌÿÌÌÿ™™ÌfffÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÌÌÌffff™f™Ì™™Ì™f™f3f3fÌf™Ì™™Ì™™Ì™™Ì™™Ì™™Ì™™Ì™™Ì™™Ì™™Ì™™Ì™™Ì™™Ì™™Ì™™Ì™™Ì™™Ì™fff™ffÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™Ì™fff3™ffÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™fff™™™ÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÿÿÿÿÿÿÿÿÿÿÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀfffÌÌÿÌÌÿfff™™ÌÌÌÿ™™Ìfffff™ÌÌÿÌÌÿÌÌÿÌÌÿÌÌÿÌÌÿ™™ÿfff™™™ÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀffff™f™Ì™™Ì™fÌf3f3f™f™Ì™™Ì™™Ì™™Ì™™Ì™™Ì™™Ì™™Ì™™Ì™™Ì™™Ì™™Ì™™Ì™™Ì™™Ì™™Ì™™Ì™™Ì™™Ì™fffÌ™fÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™Ì™fff3Ì™fÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™™ff™™™ÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÿÿÿÿÿÿÿÿÿÿÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀ™™™fffÌÌÿ™™ÌfffÌÌÿÌÌÿÌÌÿ™™Ìfffff™ÌÌÿÌÌÿÌÌÿÌÌÿÌÌÿff™fffÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀffff™f™Ì™™Ì™™Ì™3f3f™f™Ì™™Ì™™Ì™™Ì™™Ì™™Ì™™Ì™™Ì™™Ì™™Ì™™Ì™™Ì™™Ì™™Ì™™Ì™™Ì™™Ì™™Ì™™Ì™™Ì™™Ì™fffÌ™fÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™Ì™fff3Ì™fÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™™fffffÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÿÿÿÿÿÿÿÿÿÿÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀfffÌÌÿ™™ÌfffÌÌÿÌÌÿÌÌÿÌÌÿ™™ÌffffffÌÌÿÌÌÿÌÌÿ™™ÌfffÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀ™™™fff™Ì™™Ì™™Ì™ffffff™Ì™™Ì™™Ì™™Ì™™Ì™™Ì™™Ì™™Ì™™Ì™™Ì™™Ì™™Ì™™Ì™™Ì™™Ì™™Ì™™Ì™™Ì™™Ì™™Ì™™Ì™™Ì™fÌ™fffÌ™fÿ™™ÿ™™ÿ™™ÿ™™Ì™f™fffff333Ì™fÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™Ì™ffffÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÿÿÿÿÿÿÿÿÿÿÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀfff™™ÿ™™ÿ33f™™ÿÌÌÿÌÌÿÌÌÿÌÌÿ™™ÌffffffÌÌÿ™™ÌfffÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀ™™™fff™Ì™™Ì™™Ì™ffffff™Ì™™Ì™™Ì™™Ì™™Ì™™Ì™™Ì™™Ì™™Ì™™Ì™™Ì™™Ì™™Ì™™Ì™™Ì™™Ì™™Ì™™Ì™fff™Ì™™Ì™™Ì™™Ì™™Ì™f™ffff™fffffffff33ffffff333fffÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™fff™™™ÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÿÿÿÿÿÿÿÿÿÿÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀfffff™ÌÌÿfff™™™ÌÌÿÌÌÿÌÌÿÌÌÿÌÌÿ™™ÿfffffffff™™™ÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀ™™™fff™Ì™™Ì™™Ì™ffffff™Ì™™Ì™™Ì™™Ì™™Ì™™Ì™™Ì™™Ì™™Ì™™Ì™™Ì™™Ì™™Ì™™Ì™™Ì™™Ì™™Ì™™Ì™fff3f3fff™Ì™™Ì™™Ì™™Ì™™Ì™ffffff™ffÌ™fÿ™™ÿ™™ffffffÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™™fffffÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÿÿÿÿÿÿÿÿÿÿÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀfff™™™™™Ìfff™™ÿÌÌÿÌÌÿÌÌÿÌÌÿÌÌÿ™™Ì333fffÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀ™™™fff™Ì™™Ì™™Ì™f™ffff™Ì™™Ì™™Ì™™Ì™™Ì™™Ì™™Ì™™Ì™™Ì™™Ì™™Ì™™Ì™™Ì™™Ì™™Ì™™Ì™™Ì™™Ì™ffffff™Ì™ffff™f™Ì™™Ì™™Ì™fff™ffÿ™™ÿ™™ÿ™™ÿ™™ffffffÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™™ff™™fÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÿÿÿÿÿÿÿÿÿÿÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀffffffffffff™™ÌÌÌÿÌÌÿ™™ÿ™™Ìfff™™™ÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀffffÌ™™Ì™™Ì™f™ffff™Ì™™Ì™™Ì™™Ì™™Ì™™Ì™™Ì™™Ì™™Ì™™Ì™™Ì™™Ì™™Ì™™Ì™™Ì™™Ì™™Ì™™Ì™f™f3f3™Ì™™Ì™™Ì™3f3f™f™Ì™fff™ffÿ™™ÿ™™ÿ™™ÿ™™ffffffÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™fff™™™ÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÿÿÿÿÿÿÿÿÿÿÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀ™™™™™™fff33fffffffffffff™™™ÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀffffÌf™Ì™™Ì™f™f3f3fÌ™™Ì™™Ì™™Ì™™Ì™™Ì™™Ì™™Ì™™Ì™™Ì™™Ì™™Ì™™Ì™™Ì™™Ì™™Ì™™Ì™™Ì™™Ì™3f3f™f™Ì™™Ì™™Ì™f™f3f3ffffffÿ™™ÿ™™ÿ™™ÿ™™™ffff3Ì™fÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™ffffÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÿÿÿÿÿÿÿÿÿÿÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀffff™f™Ì™™Ì™fÌf3f3f™f™Ì™™Ì™™Ì™™Ì™™Ì™™Ì™™Ì™™Ì™™Ì™™Ì™™Ì™™Ì™™Ì™™Ì™™Ì™™Ì™™Ì™™Ì™fffffffff™Ì™™Ì™™Ì™™Ì™ffffffÿ™™ÿ™™ÿ™™ÿ™™™ffff3Ì™fÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™Ì™ffffÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÿÿÿÿÿÿÿÿÿÿÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀffff™f™Ì™™Ì™™Ì™3fff™f™Ì™™Ì™™Ì™™Ì™™Ì™™Ì™™Ì™™Ì™™Ì™™Ì™™Ì™™Ì™™Ì™™Ì™™Ì™™Ì™™Ì™™Ì™f™ffffÀÀÀ™™™fff™Ì™™Ì™f™ffffÿ™™ÿ™™ÿ™™ÿ™™Ì™fff3Ì™fÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™Ì™ffffÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÿÿÿÿÿÿÿÿÿÿÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀffff™f™Ì™™Ì™™Ì™ffff™f™Ì™™Ì™™Ì™™Ì™™Ì™™Ì™™Ì™™Ì™™Ì™™Ì™™Ì™™Ì™™Ì™™Ì™™Ì™™Ì™™Ì™™Ì™f™ffffÌÌÌÀÀÀÀÀÀ™™™ffff™ffffÌ™fÿ™™ÿ™™ÿ™™Ì™fff3™ffÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™™fffffÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÿÿÿÿÿÿÿÿÿÿÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀffff™f™Ì™™Ì™™Ì™ffffff™Ì™™Ì™™Ì™™Ì™™Ì™™Ì™™Ì™™Ì™™Ì™™Ì™™Ì™™Ì™™Ì™™Ì™™Ì™™Ì™™Ì™™Ì™™Ì™fffÌÌÌÀÀÀÀÀÀÀÀÀÀÀÀffffffÌ™fÿ™™ÿ™™ÿ™™Ì™fff3™ffÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™fff™™™ÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÿÿÿÿÿÿÿÿÿÿÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀfffffffffffff™fffffff™Ì™™Ì™™Ì™™Ì™™Ì™™Ì™™Ì™™Ì™™Ì™™Ì™™Ì™™Ì™™Ì™™Ì™™Ì™™Ì™™Ì™™Ì™™Ì™fff™™™ÀÀÀÀÀÀÀÀÀÀÀÀÌÌÌfffÌ™fÿ™™ÿ™™ÿ™™ÿ™™ffffffÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™fff™™™ÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÿÿÿÿÿÿÿÿÿÿÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀ™™™ffff™ff™ff™ffff333fff™Ì™™Ì™™Ì™™Ì™™Ì™™Ì™™Ì™™Ì™™Ì™™Ì™™Ì™™Ì™™Ì™™Ì™™Ì™™Ì™™Ì™™Ì™fff™™™ÀÀÀÀÀÀÀÀÀÀÀÀÌÌÌfffÌ™fÿ™™ÿ™™ÿ™™ÿ™™ffffffÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™Ì™ffffÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÿÿÿÿÿÿÿÿÿÿÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀffff™f™Ì™™Ì™™Ì™ffff™fffffff™Ì™™Ì™™Ì™™Ì™™Ì™™Ì™™Ì™™Ì™™Ì™™Ì™™Ì™™Ì™™Ì™™Ì™™Ì™™Ì™f™ffffÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀfff™ffÿ™™ÿ™™ÿ™™ÿ™™ffffffÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™Ì™ffffÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÿÿÿÿÿÿÿÿÿÿÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀ™™™fff™Ì™™Ì™™Ì™f™ffff™Ì™™Ì™ffffff™Ì™™Ì™™Ì™™Ì™™Ì™™Ì™™Ì™™Ì™™Ì™™Ì™™Ì™™Ì™™Ì™™Ì™fÌffffÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀfff™ffÿ™™ÿ™™ÿ™™ÿ™™™ffff3ÿ™fÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™™fffffÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÿÿÿÿÿÿÿÿÿÿÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀ™™™f™f™Ì™™Ì™™Ì™ffffÌf™Ì™™Ì™™Ì™ffffff™Ì™™Ì™™Ì™™Ì™™Ì™™Ì™™Ì™™Ì™™Ì™™Ì™™Ì™™Ì™™Ì™fffÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀfff™ffÿ™™ÿ™™ÿ™™ÿ™™™ffff3Ì™fÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™fff™™™ÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÿÿÿÿÿÿÿÿÿÿÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀffffÌf™Ì™™Ì™™Ì™3f3™Ì™™Ì™™Ì™™Ì™™Ì™ffffff™Ì™™Ì™™Ì™™Ì™™Ì™™Ì™™Ì™™Ì™™Ì™™Ì™™Ì™fff™™™ÀÀÀÀÀÀÀÀÀÀÀÀ™™™fffÿ™™ÿ™™ÿ™™ÿ™™Ì™fff3Ì™fÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™Ì™f™ffÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™fff™™™ÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÿÿÿÿÿÿÿÿÿÿÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀfff™Ì™™Ì™™Ì™fÌffff™Ì™™Ì™™Ì™™Ì™™Ì™™Ì™ffffff™Ì™™Ì™™Ì™™Ì™™Ì™™Ì™™Ì™™Ì™™Ì™f™ffffÀÀÀÀÀÀÀÀÀÀÀÀ™™™fffÿ™™ÿ™™ÿ™™ÿ™™Ì™fff3™ffÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™fff3f33Ì™fÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™Ì™ffffÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÿÿÿÿÿÿÿÿÿÿÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀfff™Ì™™Ì™™Ì™f™ffff™Ì™™Ì™™Ì™™Ì™™Ì™™Ì™™Ì™ffffff™Ì™™Ì™™Ì™™Ì™™Ì™™Ì™™Ì™f™ffffÀÀÀÀÀÀÀÀÀÀÀÀ™™™fffÿ™™ÿ™™ÿ™™ÿ™™Ì™ffff™ffÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™fff™ffÌ™fff3Ì™fÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™Ì™ffffÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÿÿÿÿÿÿÿÿÿÿÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀffffÌ™™Ì™™Ì™f™ffff™Ì™™Ì™™Ì™™Ì™™Ì™™Ì™™Ì™™Ì™ffffff™Ì™™Ì™™Ì™™Ì™™Ì™™Ì™fffÀÀÀÀÀÀÀÀÀÀÀÀ™™™fffÌ™fÿ™™ÿ™™ÿ™™ÿ™™ffffffÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™™fffffÿ™™ÿ™™™fffffÿ™fÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™™fffffÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÿÿÿÿÿÿÿÿÿÿÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀ™™™f™f™Ì™™Ì™™Ì™fff™Ì™™Ì™™Ì™™Ì™™Ì™™Ì™™Ì™™Ì™™Ì™ffffff™Ì™™Ì™™Ì™™Ì™fff™™™ÀÀÀÀÀÀÀÀÀÀÀÀfffÌ™fÿ™™ÿ™™ÿ™™ÿ™™ffffffÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™™ffff3Ì™fÿ™™ÿ™™ÿ™™™fffffÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™™fffffÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÿÿÿÿÿÿÿÿÿÿÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀ™™™fff™Ì™™Ì™™Ì™3f3™Ì™™Ì™™Ì™™Ì™™Ì™™Ì™™Ì™™Ì™™Ì™™Ì™f™ffff™Ì™™Ì™fff™™™ÀÀÀÀÀÀÀÀÀÀÀÀfffÌ™fÿ™™ÿ™™ÿ™™ÿ™™™fffffÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™Ì™fff3Ì™fÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ffffffÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™fff™™™ÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÿÿÿÿÿÿÿÿÿÿÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀffff™f™Ì™™Ì™ffffff™Ì™™Ì™™Ì™™Ì™™Ì™™Ì™™Ì™™Ì™™Ì™™Ì™f™fffff™ffffÀÀÀÀÀÀÀÀÀÀÀÀfffÌ™fÿ™™ÿ™™ÿ™™ÿ™™™fffffÿ™fÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ffffffÌ™fÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ffffffÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™ffff™™™ÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÿÿÿÿÿÿÿÿÿÿÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀffff™f™Ì™™Ì™3f3f™f™Ì™™Ì™™Ì™™Ì™™Ì™™Ì™™Ì™™Ì™™Ì™™Ì™ffffffÀÀÀÀÀÀÀÀÀÀÀÀfff™ffÿ™™ÿ™™ÿ™™ÿ™™™ffff3Ì™fÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™™fffffÌÌÌfffÌ™fÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™ffff™ffÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™Ì™ffffÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÿÿÿÿÿÿÿÿÿÿÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀffffff™Ì™f™fffffÌ™™Ì™™Ì™™Ì™™Ì™™Ì™™Ì™™Ì™™Ì™f™ffffÀÀÀÀÀÀÀÀÀÀÀÀfff™ffÿ™™ÿ™™ÿ™™ÿ™™Ì™fff3Ì™fÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™Ì™ffffÌÌÌÀÀÀÌÌÌfffÌ™fÿ™™ÿ™™ÿ™™ÿ™™ÿ™™Ì™fff3Ì™fÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™Ì™ffffÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÿÿÿÿÿÿÿÿÿÿÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀ™™™ffffff3333f3fff™Ì™™Ì™™Ì™™Ì™™Ì™f™fffffffÀÀÀÀÀÀÀÀÀÀÀÀfff™ffÿ™™ÿ™™ÿ™™ÿ™™Ì™fff3™ffÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™Ì™ffffÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀfffÌ™fÿ™™ÿ™™ÿ™™ÿ™™ÿ™™Ì™fff3Ì™fÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™™ff333™™™ÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÿÿÿÿÿÿÿÿÿÿÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀ™™™fff3f33f3fffffffffffffff™™™ÀÀÀÀÀÀÀÀÀÀÀÀ™™™fffÿ™™ÿ™™ÿ™™ÿ™™ÿ™ffff™ffÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™fff™™™ÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀ™™™fffÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™™fffffÿ™fÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™ffff™fffffÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÿÿÿÿÿÿÿÿÿÿÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀ™™™™™™ÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀ™™™fffÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ffffffÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™fff™™™ÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀ™™™fffÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™™fffffÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ffffffÿ™™™ff™™™ÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÿÿÿÿÿÿÿÿÿÿÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀfff333™ff™ffÌ™fÌ™fÿ™™ffffffÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™™fffffÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀ™™™fffÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ffffffÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™™ffff3ÿ™fÿ™™Ì™ffffÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÿÿÿÿÿÿÿÿÿÿÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀfff™ff™ffffffff333f33f33Ì™fÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™Ì™ffffÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀfff™ffÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ffffffÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™fff3Ì™fÿ™™ÿ™™ÿ™ffffÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÿÿÿÿÿÿÿÿÿÿÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀfff™ffÿ™™ÿ™™ÿ™™ÿ™™ÿ™™fffffffffÌ™fÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™Ì™ffffÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀfff™ffÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™ffff™ffÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ffffffÿ™™ÿ™™ÿ™™ÿ™™fffÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÿÿÿÿÿÿÿÿÿÿÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀfffÿ™™ÿ™™ÿ™™ÿ™™ÿ™™™fffffÿ™™™fffffÌ™fÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™fff™™™ÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀfff™ffÿ™™ÿ™™ÿ™™ÿ™™ÿ™™Ì™fff3Ìffÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™™ffff3ÿ™fÿ™™ÿ™™ÿ™™ÿ™™fff™™™ÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÿÿÿÿÿÿÿÿÿÿÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀfffÌ™fÿ™™ÿ™™ÿ™™ÿ™™Ì™fff3Ì™fÿ™™ÿ™™™ffff3Ì™fÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™™fffffÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀfffÌ™fÿ™™ÿ™™ÿ™™ÿ™™ÿ™™Ì™fff3Ì™fÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™ffffÌ™fÿ™™ÿ™™ÿ™™ÿ™™ÿ™™fff™™™ÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÿÿÿÿÿÿÿÿÿÿÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀfffÿ™™ÿ™™ÿ™™ÿ™™ÿ™™fff™ffÿ™™ÿ™™ÿ™™ÿ™™Ì™fff3Ì™fÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™Ì™ffffÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀfffÌ™fÿ™™ÿ™™ÿ™™ÿ™™ÿ™™™fffffÌ™fÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ffffffÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™fffÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÿÿÿÿÿÿÿÿÿÿÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀ™™™fffÿ™™ÿ™™ÿ™™ÿ™™ÿ™™f33ÿ™fÿ™™ÿ™™ÿ™™ÿ™™ÿ™™Ì™fff3Ì™fÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™Ì™ffffÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀfffÌ™fÿ™™ÿ™™ÿ™™ÿ™™ÿ™™™fffffÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™™ffff3ÿ™fÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™fffÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÿÿÿÿÿÿÿÿÿÿÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀ™™™™ffÿ™™ÿ™™ÿ™™ÿ™™Ì™fff3ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™Ì™fff3Ì™fÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™fff™™™ÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀfffÌ™fÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ffffffÿ™™ÿ™™ÿ™™ÿ™™ÿ™fff3Ì™fÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™Ì™ffffÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÿÿÿÿÿÿÿÿÿÿÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀfffÌ™fÿ™™ÿ™™ÿ™™ÿ™™Ì™ffffÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™Ì™fff3Ì™fÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™fff™™™ÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀ™™™fffÿ™fÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ffffffÿ™™ÿ™™ÿ™™ffffffÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™™ff™™™ÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÿÿÿÿÿÿÿÿÿÿÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀfffÌ™fÿ™™ÿ™™ÿ™™ÿ™™™fffffÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™Ì™fff3™ffÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™™fffffÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀ™™™fffÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™ffff™ffÿ™™™ffff3ÿ™fÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™fffÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÿÿÿÿÿÿÿÿÿÿÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀfffÌ™fÿ™™ÿ™™ÿ™™ÿ™™™ff™ffÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™Ì™fff3™ffÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™Ì™ffffÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀ™™™fffÌ™fÌ™fÌ™fÿ™fÿ™™Ì™fff3™ffff3Ì™fÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™™fffffÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÿÿÿÿÿÿÿÿÿÿÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀ™™™™ffÿ™™ÿ™™ÿ™™ÿ™™™fffffÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™Ì™fff3™ffÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™Ì™ffffÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀfff333333ff3ff3ff3ffffffff3fffÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™™fffffÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÿÿÿÿÿÿÿÿÿÿÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀ™™™fffÿ™™ÿ™™ÿ™™ÿ™™Ì™ffffÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™Ì™fff3™ffÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™fff™™™ÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀ™™™ffffff™ff™ff™ff™ffÌ™fffffffÿ™™ÿ™™ÿ™™ÿ™™Ì™f™fffffÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÿÿÿÿÿÿÿÿÿÿÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀfffÿ™™ÿ™™ÿ™™ÿ™™ÿ™™f33ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™Ì™fff3™ffÿ™™ÿ™™ÿ™™ÿ™™™ff™ffÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀ™™™™™™™ffffffffff3333333ffffff™ffffffff™™™ÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÿÿÿÿÿÿÿÿÿÿÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀfff™ffÿ™™ÿ™™ÿ™™ÿ™™fffÌ™fÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™Ì™ffff™ffÿ™™ÿ™™™fffffÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀ™™™™™™™™™ÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÿÿÿÿÿÿÿÿÿÿÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀfffÌ™fÿ™™ÿ™™ÿ™™™fffffÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™Ì™ffff™ffÌ™ffffÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÿÿÿÿÿÿÿÿÿÿÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀfffÌ™fÿ™™ÿ™™ÿ™™fff™ffÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™Ì™ffffff3ÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÿÿÿÿÿÿÿÿÿÿÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀ™™™fffÌ™fÿ™™ÿ™™Ì™fff3Ì™fÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™Ì™ffff™™™ÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÿÿÿÿÿÿÿÿÿÿÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀ™™™fff™ffÌ™fÿ™™™fffffÌ™fÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™™fffffÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÿÿÿÿÿÿÿÿÿÿÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀ™™™ffffff™ffffff33™ffÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™ÿ™™Ì™f™fffffÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÿÿÿÿÿÿÿÿÿÿÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀ™™™™™™fff333333fff™ffÌ™fÌ™fÿ™fÌ™f™ffffffff™™™ÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÿÿÿÿÿÿÿÿÿÿÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀ™™™™™™ffffffffffff™™™ÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÿÿÿÿÿÿÿÿÿÿÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÿÿÿÿÿÿÿÿÿÿÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÿÿÿÿÿÿÿÿÿÿÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÿÿÿÿÿÿÿÿÿÿÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÿÿÿÿÿÿÿÿÿÿÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÿÿÿÿÿÿÿÿÿÿÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÿÿÿÿÿÿÿÿÿÿÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÿÿÿÿÿÿÿÿÿÿÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÿÿÿÿÿÿÿÿÿÿÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÿÿÿÿÿÿÿÿÿÿÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÿÿÿÿÿÿÿÿÿÿÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÿÿÿÿÿÿÿÿÿÿÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÿÿÿÿÿÿÿÿÿÿÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÿÿÿÿÿÿÿÿÿÿÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÿÿÿÿÿÿÿÿÿÿÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÿÿÿÿÿÿÿÿÿÿÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÿÿÿÿÿÿÿÿÿÿÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÿÿÿÿÿÿÿÿÿÿÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÿÿÿÿÿÿÿÿÿÿÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÿÿÿÿÿÿÿÿÿÿÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÿÿÿÿÿÿÿÿÿÿÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÿÿÿÿÿÿÿÿÿÿÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÀÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿxrdp-0.9.5/xrdp/sans-10.fv1000644 001751 001751 00002407014 13127114621 015205 0ustar00metameta000000 000000 FNT1DejaVu Sans ñÿñÿ€€€€€€€€ñÿ     ñÿ €$ÿ$$hñÿ|’p’| ñÿ `€‘’’dÀ  À ñÿ 8D@ P€ˆ€…Ã|€ñÿ€€€€ñÿ`@@€€€€€€@@ ñÿ€@@ @@€ñÿ’|8Ö ñÿ ÿ€ñÿ@@€ñÿàñÿ€€ñÿ `@@@€€ñÿxH„„„„„Hxñÿà øñÿxŒ @üñÿx„8„xñÿ((HHˆüñÿø€€ø Œxñÿ8D€¸Ì„„Lxñÿü @ñÿx„„„x„„„xñÿxÈ„„Ìtˆpñÿ€€€€ñÿ@@@@€ñÿ p€pñÿ ÿÿñÿ €pp€ñÿpˆ ñÿ  À@@ ‘ ‘ ‘@€@ € ñÿ ""AA€€ñÿ ü‚‚‚ü‚‚‚üñÿ A€€‡A>ñÿ ÿñÿ€€€€€€€€€ñÿÿÿ Àñÿ„ˆ À ˆ„ñÿ€€€€€€€€ü ñÿ Á€Á€¢€¢€”€”€ˆ€€€€€ñÿ ÁÁ¡‘™‰…ƒƒñÿ cÝ€ € € €Ý€c>ñÿpxˆøøñÿ$lØØl$ñÿ ÿñÿà ñÿ >cÝ€”€˜€˜€Õ€c>ñÿðñÿ`` ñÿ ÿ€ÿ€ñÿð `ðñÿð`ðñÿ@€ñÿ„„„„„„þ€€€ñÿ|ôôôtñÿ€€ñÿ@ àñÿÀ@@@àñÿpˆˆˆpøñÿØllØ ñÿ Á€ABBä`  ð0 ñÿ Á€ABBåà @À1à ñÿ ñ€bô`  ð0 ñÿ @€ˆp ñÿ ""AA€€ ñÿ ""AA€€ ñÿ ""AA€€ ñÿ ""AA€€ ñÿ ""AA€€ ñÿ ">AA€€ ñÿ ð #ð>BBƒðñÿ ""AA€€ñÿxx„|„Œt ñÿ ""AA€€ñÿH0x„|„Œt ñÿ ""AA€€€ñÿx„|„Œt ñÿ A€€‡A>ñÿ0H|Ì„„„Ì|L8ñÿ $>A€€‡A>ñÿH0|Ì„„„Ì|L8ñÿ >A€€‡A>ñÿ |Ì„„„Ì|L8ñÿ >A€€‡A>ñÿ |Ì„„„Ì|L8ñÿ $ÿñÿÿÿpØ .1!!!!! ñÿ @€@€ÿÀ@€€@€@€@€@€ñÿ @@ð@\bBBBBBñÿÿÿè¸ ñÿÿÿè¸ ñÿÿÿø ñÿÿÿø ñÿÿÿˆp ñÿÿÿˆp ñÿ€€€€€€€€€€€Àñÿ€€€€€€€€€€Àñÿ€€€€€€€€€€ñÿ€€€€€€€ñÿˆˆˆˆˆˆˆˆˆ0ñÿˆˆˆˆˆˆˆˆñÿÿÿpØ ÀñÿÿÿpØ `ñÿ„ˆ À ˆ„ñÿ€€€€ˆ À ˆñÿˆ À ˆñÿ @€€€€€€€€üñÿ€€€€€€€€€€€€ñÿ€€€€€€€€ü ñÿ@@@@@@@@@@@€€ñÿ€€€€€€üñÿ€€€€€€€€€ñÿ€€€ˆˆ€€€üñÿ€€€€€  €€€€ñÿ@@@p@À@@~ñÿ@@@@`@À@@@@ñÿ ÁÁ¡‘™‰…ƒƒñÿ ¸Ä„„„„„ñÿ ÁÁ¡‘™‰…ƒƒñÿ¸Ä„„„„„ ñÿ $ÁÁ¡‘™‰…ƒƒñÿH0¸Ä„„„„„ñÿ @@®1!!!!!ñÿ Á¡‘™‰…ƒñÿ¸Ä„„„„„8ñÿ <B€€€€€B<ñÿ xÈ€€€Èp ñÿ ~C@€@€ð€@€@€C~ ñÿþÿ €ÐÀ     À€ñÿ >~‚‚‚~ñÿ||Ì„„„Ì|ñÿxÌ„„„„hxñÿüüüñÿ > Àñÿÿÿ x À ñÿ À?A€€‡A>ñÿBB$$$$ ñÿ €€€€¸ÀÄ`„ „ „ „`ƒ€ñÿ€€€€€€€€`ñÿ@@@@ð@@@@ñÿ †‘ à°˜„‚ñÿ`€€€ˆ À ˆñÿ@@@@@@à@@@@ñÿ48X<$$FB ñÿ „`„`„`„`„`„`„`Ì`wà ñÿÿÿ 0@0@(@$@&@"@!@ À À Àñÿ¸Ä„„„„„ñÿ @ñÿ ~‹‰‰‰Éy ñÿþÿÑ€€€€ñÿp€€€¸Ì„„„Ìø€€€ñÿ ÀøÌÄÄÌøÄÆñÿ8fx@À@~ñÿpˆp€ˆpñÿüÀ`0 @Àüñÿþÿp|ñÿ@@ø@@@@@80ñÿ~ñÿ0@@@ð@@@@@pñÿþ ñÿ @ÀÃ<ñÿ‡„„„„Œtñÿ çBBB<ñÿ €†‚†| ñÿ ÀD@(@( ñÿ ‡D€H(00 `Àñÿ ÿ ~0 @ÿñÿøx`Àøñÿ ü 0<üñÿ þ@ ð€€€üñÿü@ 0pÀ€€Ä8ñÿø p€ˆxñÿpØ ü0`Àüñÿ üÀÀÀü‚‚üñÿø€€€ø ˜ðñÿ@@ð`0ðñÿ¼Ä†„Œ˜ À€€ñÿ€€€€€€€€€€€€€€ñÿñÿ ø ø ñÿ€€€€€€€€ñÿ ü€†† ü€ñÿ(ü†| †@ü| ñÿP |øÌ„„ „@Ì€|øñÿ ýñÿ €€ýñÿ€ €€        ` ñÿ Á@Á@¡@‘@™@‰@…@ƒ@ƒ@@@€ ñÿ @ÁÁ¡@‘@™@‰@…@ƒ@ƒ@@@Àñÿ ¹Å…………… ñÿ ""AA€€ñÿH0x„|„ŒtñÿÿÿP ñÿÿÿP ñÿ $BBƒð ñÿ {À†` à„Š qÀ ñÿ >A€€‡‡€A>ñÿ|Ì„„„Ì|þD8ñÿ  >A€€‡A>ñÿ`|Ì„„„Ì|L8ñÿ$„ˆ À ˆ„ñÿÿÿØp "$(0($"ñÿ A€€‡A>ñÿ @|Ì„„„Ì|L8 ñÿÿ€ðñÿ þÂÂÆÄØðÀÀÀÀÀñÿ ÁÁ¡‘™‰…ƒƒñÿ¸Ä„„„„„ ñÿ ">AA€€ñÿ2LH0x„|„Œt ñÿ ð #ð>BBƒð ñÿ {À†` à„Š qÀñÿ =B…‰‰‘¡B¼ñÿ @|Ì”¤¤Ìø ñÿ (""AA€€ñÿP(x„|„Œt ñÿ ""AA€€ñÿpx„|„ŒtñÿP(ü€€€ü€€€üñÿ(xÌ„ü€Ä8ñÿ$ü€€€ü€€€üñÿ8xÌ„ü€Ä8ñÿÿÿ P ñÿ P€€€€€€€ñÿ`@@@@@@@@@ñÿà@@@@@@@ñÿ (dHP``|ñÿ@@@@à@@@~ ñÿÿÿ€€  ,Lñÿø€€pð  ñÿø @€À`0ñÿü< ñÿðp@@ñÿ ~AAA~AñA~ ñÿ @€@€@€@€ÿÀ@€@€a€? ñÿ ""cAA€€ñÿüÈÈüÐÐààü@ñÿx””ü à|@ñÿÿÿ p Àñÿ@@@@à@@@@@À ñÿ =CC=ÀÀñÿ|Ì„„„Ì|ñÿ|BBBüDBBAñÿX`@à@@@ñÿBÿ$ñÿBFdÿ(0`ñÿ¸Ä„ø€„xñÿ|Ì„„„Ì|ñÿøÌ„„„Ìøñÿp€€€øÌ„„„ÌøñÿððñÿpÈ€€¸èx@ñÿ|Ì„„„Ì|ñÿ |Ì„„„Ì|ñÿxÌ„üŒxñÿxŒü„Ìx ñÿ x 5Ä€Œxñÿx€€p€€xñÿpˆpˆp ñÿ p q€ˆpñÿ ñÿø„„ø„„øñÿ x„‚r‚„x ñÿ €<D€Œ„Ä|ñÿ „„„ü„„„ñÿþÿøàñÿ D$ 4Dñÿ€€€€€€ø ñÿ €|Ì„„„Ì|ñÿp˜0 p ñÿpÈ€€€À` p ñÿ ðŒ „@„€…€wð ñÿðŒ „@„€„àŒ0t0À ñÿ ðŒ „@„€…àÐwà€ ñÿ @@ÿÀDDC€@@@@?ÀñÿDDüDDDDD<  ñÿ @@ÿ€LHHIN€?€ ñÿ 8 `ÿÀl@l@l@l@l@l@@@€ñÿ€€€¼à༆‚üñÿ €€€þ„Œ˜° þñÿ”tlH´thñÿü„„ü„„ñÿÀ@`bbbbb"> ñÿ À@`bbbbb">€ñÿ€€ðñÿÀ€àñÿ@@@@@@Àñÿà€€€ñÿ àñÿ à ñÿà àñÿ”tlHñÿP` @ñÿÀÀ€ñÿðð ñÿ@€€ñÿ@@€ñÿÀ@@ñÿ€€€ñÿ€€€ñÿÀ @@@ñÿ`€€@@@ñÿ À€`ñÿÀ`€ñÿ`PñÿP` ñÿ`ñÿ`ñÿ€€€€ñÿðñÿ`@ñÿ@ ñÿ€€€€ñÿðñÿ@ ñÿ @ñÿà@@àñÿà@ñÿ€€€ñÿ€€€ñÿ@@àñÿà@@ñÿ ð ñÿàñÿ`ñÿ€ñÿ``ñÿ€€ÀñÿаñÿP ñÿ à 0ñÿÀàñÿ @` àñÿ€€€€€€ñÿÀÀ àñÿ ``ñÿ`€€@@@ñÿðñÿðñÿðñÿðñÿðñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿ`Pñÿððñÿ  ñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿ`ñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿð€ñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿÀÀ€ñÿ@ÀÀñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿ€€ñÿððñÿpÈ€  ÈpñÿðHHðñÿ@@@@€ñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿ@€ñÿ@€  ñÿ @ˆ""AA€€ñÿ€€ ñÿÿÿ @Ÿ€€€ ñÿ @ @ @ @ @?À @ @ @ @ñÿ@  ñÿþ‚‚‚‚‚‚‚‚‚þ ñÿ @ž!@€@€@€@€@€!ñÿþ‚‚‚‚‚‚‚‚‚þ ñÿÿÿ @ˆ @@€€ ñÿÿÿ @€ @ @ @ @€€9Àñÿ@€ €€€€€€` ñÿ ""AA€€ñÿ ü‚‚‚ü‚‚‚üñÿü€€€€€€€€ ñÿ ""cAAÿ€ñÿü€€€ü€€€üñÿ ÿ @ÿñÿ ÿñÿ Iˆ€ˆ€ˆ€I>ñÿÃB$$Bà ñÿ ˆ€ˆ€ˆ€ˆ€É€k>ñÿ ñÿxŒ„„„Ìx000ñÿ~@€€€€€@x ñÿ|À€€€Àpñÿø€€€ø€€€€ñÿÿÿ 0 Àñÿ À`BLtÄñÿ @@|ü ñÿ 8æ!#€&€$€€€€€€ñÿÀ0(T¤ ñÿ @€ÀÀ€@Œ@Œ@Œ@Œ@ÿÀs€€ ñÿ Á€€€ˆ€ˆ€Ý€w ñÿ cÃÃG{ñÿ d„„„„Ä| ñÿ ÀÀþãÁÁ€Á€Áà ñÿ>FN2üñÿ >c ``? ñÿx„0`€D8ñÿ Ã$<<$Bÿñÿç4<&ÿñÿ |À¼Æ‚‚‚Æ|ñÿp€øŒ„„„ŒxñÿÿÛñÿþ’ñÿ Æ,(8HÈŽñÿ|D„†„ĸÀ`<ñÿpÈ€€€Èpñÿ@@@@@@@@@@À ñÿ fÃÿÿÁC>ñÿxÀ€ø€Àxñÿø ü ðñÿ€øŒ„„Œø€€ñÿ€€€€øÌ„„„Ìø€€€ñÿ A€€þ€€A>ñÿ |€À|†|ñÿ€€€€€€€€€ñÿ @@@@@@@@@ñÿÿÿ À ñÿ?!!!!ð!!Að ñÿ‚‚‚‚ÿà‚‚‚ƒà ñÿ þ€€€€€ñÿ ‚„ˆ°øÈ„‚ƒñÿ ƒƒ…‰™‘¡ÁÁñÿ$‚DD,(8`ñÿ ‚‚‚‚‚‚‚‚þ ñÿ ""AA€€ñÿ ü€€€ü‚‚‚üñÿ ü‚‚‚ü‚‚‚üñÿü€€€€€€€€ ñÿ ?!!!!!!Aÿ€€€€€ñÿü€€€ü€€€ü ñÿÂb02`ÀÀ' " BÂñÿ |‚†xñÿ ƒƒ…‰™‘¡ÁÁñÿ $ƒƒ…‰™‘¡ÁÁñÿ ‚„ˆ°øÈ„‚ƒñÿ ?!!!!!!A ñÿ Á€Á€¢€¢€”€”€ˆ€€€€€ñÿ ÿñÿ Iˆ€ˆ€ˆ€I>ñÿÃB$$BÃñÿ ‚‚‚‚‚‚‚‚ÿñÿ ‚‚‚‚~ ñÿ „ „ „ „ „ „ „ „ ÿà ñÿ„ „ „ „ „ „ „ „ ÿð ñÿ à ? € € €? ñÿ €€€€€€€€ü€‚€‚€‚€ü€ñÿ €€€€ü‚‚‚üñÿ |‚‚| ñÿ‡Àˆ ðˆ ‡Àñÿ ~‚‚‚~"bB‚ñÿx„|„Œtñÿ8@€€øÌ„„„Ìxñÿø„„ø„„øñÿø€€€€€€ñÿ >""""BÿñÿxÌ„ü€Ä8 ñÿ D@$€?€$€D@Ä`ñÿpˆpˆpñÿŒŒ”´¤ÄÄñÿH0ŒŒ”´¤ÄÄñÿˆ ðˆŒñÿ>""""BÂñÿ ÆÆªªª’‚ñÿ„„„ü„„„ñÿxÌ„„„Ìxñÿü„„„„„„ñÿøÌ„„„Ìø€€€ñÿpÈ€€€Èpñÿ þñÿ‚DD(( À ñÿ É€ˆ€ˆ€ˆ€É€ñÿ‚D((D‚ñÿ „„„„„„þñÿ„„„| ñÿ ˆ€ˆ€ˆ€ˆ€ˆ€ˆ€ÿ€ ñÿ ˆ€ˆ€ˆ€ˆ€ˆ€ˆ€ÿÀ@@ ñÿ ð€€ñÿ ù……ùñÿ€€€ø„„øñÿp˜x˜p ñÿ ™€€ð€€™€ñÿ|„„|dD„ñÿ xÌ„ü€Ä8ñÿ(xÌ„ü€Ä8ñÿ```ü`|bbbbñÿ ø€€€€€€ñÿpÈ€ø€Èpñÿpˆ€pˆpñÿ€€€€€€€€ñÿ @@@@@@@ñÿ@@@@@@@@@@À ñÿ >""#À" B ÃÀ ñÿ „„„ÿ€„@„@‡€ñÿ@@@ø@@\bBBBñÿ ˆ ðˆŒñÿ ŒŒ”´¤ÄÄñÿ$‚DD(( Àñÿ ‚‚‚‚‚‚þ ñÿ @€ÀÀ€@Œ@Œ@Œ@Œ@ÿÀs€ ñÿ A€€€€ˆ€ˆ€”€w ñÿ ü€€€€ñÿ ø >!!> ñÿ €Î`È Øÿ€ÐÐØÌ ÇÀñÿ °þ° ñÿ  ?€?Àd@D`Ä ñÿ 1/D€DÀñÿÁ€ÃÀÂ@þ`ÇàÏðÉوш ñÿ ƒ‡„€øÀ@“ ³ ñÿ b&4<zÙ™™ñÿüHx0ü´´ ñÿ ÏàÌ@ÄÀþ€Ç€Í@Ù Ñ Ñ0 ñÿ Ÿ€™‹þ”€”€ñÿHPpÜ8 ø€øtñÿP`øpð€°@ ñÿ Ì`L€L€m€-- ñÿ D`D€d€%€%5 ñÿ fÃÿÿÁC>ñÿxŒ„ü„Œx ñÿ ÀÁÀAc""6ñÿ CFd$,8 ñÿ ÀÁÀAc""6ñÿ  CFd$,8 ñÿ 0XˆŽ @ÀŒÀÈ€p€ ñÿ t@žÀЀЀ‰€™s ñÿ €@À€@€`€`€`À@dÀñÿ ~ÃÃ~ñÿ€€@À€€€ ‡ ÿøpx ñÿ @ € € € qà ñÿ ?@€ÀÀ€@Œ@Œ@Œ@Œ@ÿÀs€ ñÿ >*A€€€ˆ€ˆ€Ù€wñÿ vÀ€€€€À`>ñÿxÀ€€€Àxñÿ8t0xñÿþ‚‚‚‚‚‚‚‚‚þñÿóÿÀ 8$ `€@<$ àñÿôÿ€1€ à``„ ñÿ $ÆÆÊÊÒÒââÀñÿ H8ŒŒ””¤äÆñÿ `ð`|gaac~ñÿ@@à@@|BB|ñÿüÄÔÌþÀÀÀÀñÿ¼Ä„†„̼„€€ñÿü€€€€€€€€ñÿø€€€€€€ñÿ ? þ ñÿ> ü ñÿüÀÀøÌÆÂ ñÿø€€øˆŒŒ 0ñÿc30`À 0#cC  ñÿ d@4€€&Àd@D ñÿ |‚†x pñÿpˆpˆp pñÿ ÆÌØðèÌÄÂÃñÿˆ ð؈†ñÿ ÆÌØðèìÄÂÃñÿˆ° ðøˆ„ ñÿ cölxtfbaa€ñÿ@ø@DHPxlDB ñÿ ðÀ€€€À` ñÿ ñ€ ñÿ ÃÃÃÿÃÃÃÃÀ€€ñÿ „„„ü„„‡ ñÿ ÃðÃÃÿÃÃÃÃà ñÿ ‡À„„ü„„„ ñÿÿÃÃÃàÃ0ÃÃÃÃ0 ñÿ ü„„‡À„`„`„``@À ñÿ vÀ†‰‰ÉK>€ñÿxÀœ––Ôxñÿ 22"""Ãñÿ ÃÃÃÿÃÃÃàñÿ „„„ü„„„ ñÿ ÃÃÃÿÃÃÃÃÀñÿ „„„ü„„‡ñÿ ††Æ~ñÿŒŒÌ|  ñÿ á€â€â€Ò€Ô€Ô€Ì€À€ÀÀ@€ ñÿ ç§«››ƒ€ñÿ€€€€€€€€€€€ ñÿ ""AA€€ñÿH0x„|„Œt ñÿ ""AA€€ñÿ0x„|„Œt ñÿ ð #ð>BBƒð ñÿ {À†` à„Š qÀñÿH0ü€€€ü€€€üñÿH0xÌ„ü€Ä8ñÿ ñÿxÌ„ü„Ìx ñÿ fÃÿÿÁC>ñÿ(xÌ„ü„Ìxñÿ (|‚‚|ñÿPp˜x˜pñÿ<‚DD,(8`ñÿ<‚DD(( Àñÿ‚DD,(8`ñÿ‚DD(( Àñÿ(‚DD,(8`ñÿ ‚DD(( Àñÿ ‚‚‚‚~ñÿ(„„„|ñÿüÀÀÀÀÀÀÀà ñÿø€€€€€à`` ñÿ €€€€€€€€ü€‚€‚€‚€ü€ñÿ ù……ùñÿ ? þ < 8ñÿ> ü < 0ñÿ c2&cAñÿF$8dB ñÿ c2&cAñÿF$~8dBñÿ >憆Æ~ñÿøˆˆø ñÿ  > æ † † Æ`{À ñÿ €ø€ˆ€Œ€÷€ ñÿ pÜ@8@@@@@À ñÿ ø€p€€€ñÿ pÜ8ñÿøp  ñÿ€€˜˜˜1˜1˜!Àð ñÿ >22 " " " Áà ñÿÿ€ð ñÿ „„„@ü@„@†@ƒÀñÿ sÀ€ÁC>ñÿ |À€„„Äx ñÿ ÿ€€€€€ €ñÿ þñÿ|€€€p€€€|ñÿx€€p€€xñÿ ?#####cC‚ ñÿ>222""Âñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þ ñÿ €B@<@ñÿ >Àþ€€ ñÿ >ÃÁ?À   ñÿ >ÃÀ  ñÿ €€þ‚‚€ÂB|ñÿ0LÄ„„L4 ˜üñÿ €€þ€€€øñÿ >À€€€€þ ñÿ 8fŸ€’@’@ž€€€ ñÿ €Â@‚@‚ÂF<ñÿ €€ü€€€ñÿ€€€€€€€€ø ñÿ €€ù€™€™€™€™€‰ ñÿ €@?ðP0` ` ` `0@À€ñÿ €€‚‚Âf:ñÿ 0`Àþñÿ0LÄ„„L4Løþ ñÿ <ÃÀ ñÿ @þAAAAc? ñÿ ƒÀ‚@‚‚‚‚ÂB|ñÿ 8ÆüƒÂ~ ñÿ €€p  `€ñÿ €þ8`À€‚‚B|ñÿ <Ãñÿ 8f‚ pxñÿ ~Û™ñÿ0LÄ„ÄD$˜ü ñÿ >ÃÀ ñÿ Ã< ñÿ ‚‚Âf:€@@ñÿ |€À|†|ñÿ >À€€€€€ñÿ 8Æ‚Â<ƒÂ~ ñÿ €€ü€€€€ ñÿ >Iˆ€ˆ€ˆ€I> ñÿ 3!€1¿ ÿ! € ñÿ ñÿ0ü @À€À@>ñÿ0ü @À€À@>ñÿ àñÿ@ àñÿÿÿðñÿÿÿðñÿdd‚lƒø‚„xñÿ€@dd‚lƒø‚„xñÿ0l„ƒƒð‚„xñÿ0l„ƒƒð‚„x ñÿ !€&À,@8Àÿ ñÿ $!€&À,@8Àÿñÿ0`€ø`À€€Â~ñÿ@0`€ø`À€€Â~ñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿð ñÿ @à  €à€`ÿÀñÿ  ‡ƒ†Üpñÿ  ƒþñÿ ‚‚Ìxñÿ<$ü€€€€ñÿ ƒƒ‚Æ|ñÿ`ðˆˆðñÿÿÿ$4ðñÿ ƒƒÎ8ñÿ ƒƒÎ8(ñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿ Àñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿ€ñÿ€À@@@@@@ñÿˆÈp@@@@@ñÿV^| ñÿ0@@`À€ÀxñÿpPˆˆˆˆˆpñÿðñÿDD(((8ñÿ8((hDDñÿðøñÿˆ @Hˆñÿ Àñÿ@€€ñÿ øpP ñÿ €@€@ÁÀñÿ  ‡ƒ†Üpñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿÀÀñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þ ñÿ €@€@ÁÀ ñÿ €@€@ÁÀ ñÿ €@€@ÁÀ ñÿ €@€@ÁÀ ñÿ ˆ@€@ÁÀ ñÿ €@€@ÁÀ ñÿ €@€@ÁÀ ñÿ €@€@ÁÀñÿ00@0ü @À€À@>ñÿ0ü @À€À@>ñÿ0ü @À”À@>ñÿ0ü @È€È@>ñÿ(0ü @À€À@>ñÿ0ü @Ô€È@>ñÿ0ü @Ô€Ô@>ñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿÿÿðñÿÿÿ ðñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þ ñÿÿÿ€óñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿÿÿ ðñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þ ñÿ à  €à€`ÿÀñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þ ñÿ @ à  €à€`ÿÀñÿþ‚‚‚‚‚‚‚‚‚þ ñÿ   à  €à€`ÿÀñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þ ñÿ À€€€ÿñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þ ñÿ À À€€€ÿñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿ ‚‚Ìxñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿ ƒƒ‚Æ|ñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿ0ü @Ô€È@>ñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿÿÿ$4ðñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿ ƒƒÎ8ñÿþ‚‚‚‚‚‚‚‚‚þñÿ P`ƒƒÎ8ñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿ`ðˆˆðñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿ€ñÿ€À@@@@@@ñÿˆÈp@@@@@ñÿV^| ñÿ¸àx@@@@@ñÿpPˆˆˆˆ¨Øñÿp@@x0`@ÀñÿDD(((8ñÿ8((hDDñÿðøñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿ ü¤¤ø¤¦¤ü ñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿ ü¢â"â¢âñÿ |â¢â~ññÿþ‚‚‚‚‚‚‚‚‚þñÿ |†ââ‚òòñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿà°ðàñÿü„œ,4ñÿþ‚‚‚‚‚‚‚‚‚þñÿ ~¢Æ8ÆŽúñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿ ââ‚b‚†|ñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿ |‚‚‚â¢âñÿ@ì´„„„ääñÿ þ¡á!9)9ñÿ ÞòR’’’òñÿþ‚‚‚‚‚‚‚‚‚þñÿ â¢â"""Üñÿâ¢Â‚‚†|ñÿâ¢Â‚‚†|ñÿ ÏëÆ’’’þñÿ â¢â’’’üñÿ â¢B’’’þñÿ â¢B’’’þñÿþ‚‚‚‚‚‚‚‚‚þñÿ !!!!!áþñÿ ââ‚b‚†|ñÿ þ‚ð¢|ñÿþ‚‚‚‚‚‚‚‚‚þñÿ~Cs[knñÿþ‚‚‚‚‚‚‚‚‚þñÿx„ääxñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þ ñÿ €g€cs[kn ñÿ ÿ€ü€D€„€„€„€x€ñÿþ‚‚‚‚‚‚‚‚‚þñÿx„„|äøñÿ ûÆ|ââ| ñÿ 0XØÇ€Y#  ñÿâ¢|â¢|ñÿpÈèè ñÿúÿàààÐÐñÿþ‚‚‚‚‚‚‚‚‚þñÿ rN ä䄸ñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿà€€€€ààñÿ ˆˆîîñÿÀà°P( 8(ñÿx„„X0 8(8ñÿÀ@@p0 0(8ñÿþ‚‚‚‚‚‚‚‚‚þñÿ ì´Ä¤ä„|ñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿxÌ„„„Äxñÿü„†ædñÿ0`ÀŒ”ŒÄx ñÿ €€ ####òþñÿ0`ÀœœˆÌ>ñÿø°`ÀœœˆÌ> ñÿ =€ÆâÂ’’’þñÿ þâ"""ââñÿþ‚‚‚‚‚‚‚‚‚þñÿ ò’’’Ò²Þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þ ñÿ ÿ°ü°D°„°„°‡°{à ñÿ ÿ ü D „ „ … {àñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þ ñÿ ÿ€AAc"" ñÿ  ""cAAÿ€ ñÿ ""cAAÿ€ ñÿ ""cAAÿ€ñÿ €à˜††˜à€ñÿ €à˜††˜à€ñÿ (€à˜††˜à€ñÿþ‚‚‚‚‚‚‚‚‚þñÿ €à˜†±†˜à€ñÿ aañÿ aa ñÿ À € €1€Ñ  ñÿ ÿ€AAc"`" ñÿ  Ñ1€ € €À ñÿ ""`cAAÿ€ ñÿ  Ñ1€ € €À ñÿ ""`cAAÿ€ ñÿ ÀÐ À ñÿ €à˜†`†˜à€ ñÿ ÀÐ À ñÿ €à˜†`†˜à€ñÿ ‚à˜††˜à€ ñÿ à Ð  à ñÿ a`a ñÿ  à Ð  à ñÿ a`añÿ aañÿþ‚‚‚‚‚‚‚‚‚þñÿÀñÿ 0PPˆøñÿ0 @€ñÿ€@` ñÿ€  `ñÿ@  €ñÿÀ àñÿ@  `ñÿ(HPPñÿñÿÀñÿàñÿ@@@@ñÿà@@@ñÿÿ AAc"" ñÿ €À"@"cAAÿ€ ñÿ à€˜À†@†˜à€ ñÿ@ 0aa ñÿ €€€€AA"" ñÿ  ""cAA€€ ñÿ ""cAA€€ ñÿ ""cAA€€ñÿ €``€ñÿ €``€ñÿ (€``€ñÿþ‚‚‚‚‚‚‚‚‚þñÿ €`a`€ñÿ `€`ñÿ `€` ñÿ @@@@ € €Ñ  ñÿ €€€€AA"`" ñÿ  Ñ1€ € €@@ ñÿ ""`cAA€€ ñÿ  Ñ1€ € €@@ ñÿ ""`cAA€€ ñÿ  ÀÀ À  ñÿ €```€ ñÿ  ÀÀ À  ñÿ €```€ ñÿ  À Ð À ñÿ `€`` ñÿ  À Ð À ñÿ `€``ñÿ `€`ñÿpÀpñÿ€€€€€ñÿþ‚‚‚‚‚‚‚‚‚þñÿ Ã<ñÿ  <Ãñÿ <Ãñÿ <Ãñÿ üüñÿ üüñÿ üüñÿþ‚‚‚‚‚‚‚‚‚þñÿ üaüñÿ ?@€€€€€@?ñÿ ?@€€€€€@? ñÿ @ @ @ @à@ @ @0À ñÿ ÀÃ< ñÿ 0À @ @à@ @ @ @ @ ñÿ <ÃÀ ñÿ 0À @ @à@ @ @ @ @ ñÿ <ÃÀ ñÿ €@ À @€ ñÿ üÀü ñÿ €@ À @€ ñÿ üÀü ñÿ àÐà ñÿ ?@€€€À€€@? ñÿ àÐà ñÿ ?@€€€À€€@? ñÿ À   Àñÿp€€€p ñÿ @@@@@Ã< ñÿ <@Ã@@@@ ñÿ ü@@@@@ü ñÿ ?@@@€@€@€@€€@?ñÿxÌ„„Ì|ñÿ$xÌ„„Ìø€€€ñÿxÌ„„Ìø€€€ñÿxÌ„„Ìø€€€ñÿ|Ì„„Ìxñÿ|Ì„„Ìxñÿ |Ì„„Ìxñÿ€€€øÌ„„Ìxñÿ€€€€øÌ„„Ìx ñÿ €€€Ù€€€€€ ñÿ xÌ„„Í€|ñÿ 3!!ó> ñÿ xÌ„„Í€ø€€€ñÿ 3!!ó> ñÿ xÌ„„Í€ø€€€ ñÿ €€€€Ù€€€€ ñÿ |Í€„„Ìx ñÿ €€€€Ù€€€€ ñÿ |Í€„„Ìxñÿ >ó!!3 ñÿ €€€øÍ€„„Ìxñÿ >ó!!3 ñÿ €€€€øÍ€„„Ìxñÿ @ÀÀ|fBÂæ<ñÿ€ààñÿ0Ðpñÿ yÍ……Í| ñÿ x€Ì€„€„€Ì€ø€€€ñÿ }Í„„Ìx ñÿ €€€€€€ø€Ì€„„ÌxñÿxÌ„ñÿ$xÌ„€€€€€€ñÿxÌ„€€€€€€ñÿxÌ„€€€€€€ñÿ„Ìxñÿ„Ìxñÿ „Ìxñÿ€€€€€€„Ìxñÿ€€€€€€€„Ìx ñÿ €€€À€€€€€ ñÿ xÌ„€ñÿ 3! à ñÿ xÌ„€€€€€€ñÿ 3! à ñÿ xÌ„€€€€€€ ñÿ €€€€À€€€€ ñÿ €„Ìx ñÿ €€€€À€€€€ ñÿ €„Ìxñÿ à !3 ñÿ €€€€€€„Ìxñÿ à !3 ñÿ €€€€€€€„Ìxñÿ @ÀÀ@@@Âæ<ñÿ€€€àñÿàñÿüñÿ$ü€€€€€€€€ñÿü€€€€€€€€ñÿü€€€€€€€€ñÿüñÿüñÿ üñÿ€€€€€€€€üñÿ€€€€€€€€€üñÿ ?Á ñÿ ü€ñÿ ? à ñÿ ü€€€€€€€€ñÿ ? à ñÿ ü€€€€€€€€ñÿ Á? ñÿ €üñÿ Á? ñÿ €üñÿ à ? ñÿ €€€€€€€€üñÿ à ? ñÿ €€€€€€€€€üñÿ @ÀÀ@@@ÀÀ~ñÿ€€€€àñÿx€€€xñÿ àñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þ ñÿ ÿ€ @@@ À€ ñÿ $$ÀŒ„„Ìx ñÿ ÀŒ„„Ìx ñÿ ÀŒ„„Ìx ñÿ € À@@ Àÿ€ ñÿ € À@@ Àÿ€ ñÿ €€ À@@ Àÿ€ ñÿ xÌ„„ÌÀ ñÿ xÌ„„ÌÀ ñÿðÁˆ˜ð ñÿ ÿ€ p@@ À€ ñÿÙ€€€€ø ñÿ xÍ€„„ÌÀ ñÿÙ€€€€ø ñÿ xÍ€„„ÌÀ ñÿ (xÌ„„ÌÀñÿ`|ñÿpñÿ$$ø ñÿ ÿ€@@@À€ ñÿ $$À€€€À` ñÿ À€€€À` ñÿ À€€€À` ñÿ €À@@Àÿ€ ñÿ €À@@Àÿ€ ñÿ €€À@@Àÿ€ ñÿ `À€€ÀÀ ñÿ `À€€ÀÀ ñÿðÀ0 ñÿ ÿ€p@@À€ ñÿøÐ ñÿ À€0€€À` ñÿøÐ ñÿ À€0€€À` ñÿ0Àð ñÿ €ð@@Àÿ€ ñÿ@0Àð ñÿ €ð@@Àÿ€ ñÿ Øø ñÿ `À0€€ÀÀ ñÿ Øø ñÿ `À0€€ÀÀñÿ@€€|ñÿþ‚‚‚‚‚‚‚‚‚þñÿ ðà>øÀ<ñÿ€€€@`ñÿ à€€€ñÿà€€€ñÿà€€€ñÿ`@€€€ñÿ`@€€€ñÿ `@€€€ñÿ€€€àñÿ€€€€à ñÿ Ì€€€€ñÿ €€€@cñÿ Æ8 ñÿ €à€€€ñÿ Æ8 ñÿ €à€€€ ñÿ €€€€Ìñÿ c@€€€ ñÿ €€€€Ìñÿ c@€€€ñÿ 8Æ ñÿ €€€à€ñÿ 8Æ ñÿ €€€€à€ñÿ @ÀÀp ‚‚ñÿ€à0ñÿ`€€pàñÿ`€€ñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þ ñÿ 0XÈ€ € ñÿ  €€ÈHx ñÿ  €€ÈHx ñÿ xÀL`Ä Æ B`!À ñÿ xÀL`Ä Æ B`!À ñÿ !ÀB`F Ä L`xÀ ñÿ !ÀB`F Ä L`xÀ ñÿ 2 `À ñÿ 0XÈ`€ € ñÿ €` Â2 ñÿ  €€`ÈHx ñÿ €€` Â2 ñÿ  €€`ÈHx ñÿ0Ó11ˆ˜pñÿxÀLlÄ Æ B`!À ñÿ0Ó11ˆ˜pñÿxÀLlÄ Æ B`!À ñÿpИˆ10ñÿ!ÀBlF Ä L`xÀ ñÿpИˆ10ñÿ!ÀBlF Ä L`xÀñÿL–¦äñÿ @ÀüñÿH0@  ü€€€ñÿ@  ü€€€ñÿ@@  ü€€€ñÿüÀ@ ñÿüÀ@ ñÿüÀ@ ñÿ€€€ü  @ñÿ€€€€ü  @ ñÿ Ø€€€€ ñÿ  @Á€üñÿ Ã? ñÿ @  €ü€€€ñÿ Ã? ñÿ @@  €ü€€€ ñÿ €€€€Ø ñÿ üÁ€@  ñÿ €€€€€Ø ñÿ üÁ€@ ñÿ ?à ñÿ €€€ü € @ñÿ ?à ñÿ €€€€ü € @ñÿ @ÀÀ~ˆ ñÿ€ð0 @ñÿþ‚‚‚‚‚‚‚‚‚þñÿ@@@@ñÿ€P `P ñÿ ‡À„„„Ìx ñÿ ø@@@@ À€ ñÿ € À@@@ø@ ñÿ $$xÌ„„„‡À ñÿ xÌ„„„‡À ñÿ xÌ„„„‡Àñÿø  ø€€€ñÿ ø  ø€€€ñÿ€€€ø  øñÿ|À€€À|ñÿ |À€€À|ñÿ|À€€À| ñÿ €Ø€€€€ñÿ |À€€Ã|ñÿp€€pñÿþ‚‚‚‚‚‚‚‚‚þñÿ ðxà|Àñÿ á¢âFDD((ñÿ $((DDFâ¢áñÿ ((DDFâ¢áñÿ ((DDFâ¢áñÿ à¸î`€ñÿ à¸î`€ñÿ wÀÀpñÿ wÀÀp ñÿ à àØÀ ñÿ wÀÀ`pñÿø€pñÿ `ÒÒâ‚‚‚ÂB|ñÿ ŠŠ†‚‚‚ÂB|ñÿ 8f‚‚‚‚â’rñÿ 8f‚‚‚‚ŽŠŽñÿ 8f‚‚‚‚â’rñÿ 8f‚‚‚‚ŽŠŽñÿ ü¢Ãøñÿ ü¢Ãøñÿ ņ€€€À`?ñÿ ņ€€€À`? ñÿ à ÀÐ à ñÿ ņ€€À€À`?ñÿ0Ø€€€xñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þ ñÿ 8lFÂF~À€ ñÿ €€€€€Pp0 ñÿ €€€€€Pp0 ñÿ €€:@fÂÂF| ñÿ €€:@fÂÂF| ñÿ 0PП€€€€ ñÿ 0PП€€€€ñÿ@ÀÐ(D8ñÿ ÿñÿ€P `P ñÿ ÀsÀ†`„ t `À ñÿsÀ†`„ t `À ñÿ€sÀ†`„ t `À ñÿp € € sà`  `À ñÿ@p € € sà`  `À ñÿt„„wÀ`  `À ñÿt„„wÀ`  `À ñÿ t‡„€t€ñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þ ñÿ xÌ„€€ ñÿ €€ÐP00 ñÿ €€„Ìx ñÿ 00PЀ€ñÿ$`xÌz„ €€€€€€ñÿ`xÌz„ €€€€€€ñÿ`xÌz„ €€€€€€ ñÿ ` z   `À ñÿ @` z   `Àñÿ`€€z€ €€€„Ìxñÿ€`€€z€ €€€„Ìxñÿ `z  ñÿb•€”€ÐP ñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þ ñÿ ÀÀ€€€À` ñÿ ÀÀ€€€À` ñÿ €À@@Àÿ€À0 ñÿ €À@@Àÿ€À0 ñÿ `À€€ÀÀÀ ñÿ `À€€ÀÀÀñÿ@€€|ñÿ @Àüñÿ ``ð`ñÿ ``ð`ñÿü€@` ñÿü€@` ñÿ`ð`ñÿ@`ð`ñÿ@à@8 ñÿ€€€øÌ„„Ìøñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿ ü††üñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿ ?aa?ñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿð @€ðñÿðP @Àðñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿ`` ñÿsÀ†`„ t `à ñÿ`ff>&FFñÿFF&>ff>ñÿþñÿŒŒŒŒŒÈxñÿ þþø ñÿ À€@@€@Àñÿþþüþñÿ‚‚DD(( ñÿ ˆ€ˆ€IUU""ñÿø @€øñÿø 0ðñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿø€€€€€€ñÿ((DDD‚ñÿøˆˆˆˆˆˆñÿøˆˆø€€€ñÿ¤¤¤¤ø ñÿ>""""BÂñÿ 0PH¸ˆñÿ0P\°ŽñÿÀ°ðàñÿþ‚‚‚‚‚‚‚‚‚þñÿÀ°ˆˆˆðñÿð€€À€ðñÿà ` àñÿ8D€ŒD8ñÿ€ð€ñÿ€€€€€€ñÿ@@@@@@€ñÿ ÀÀ ñÿ€€€€€ðñÿˆˆØè¨ˆñÿ€Ðа°ñÿ°°ÐЀñÿ0L„„D8ñÿhHxˆxñÿÀ°à€€ñÿÀ°àñÿø ñÿ`ñÿ‰™Zjf$ñÿðp`ñÿðàpñÿp`ñÿ ü~ñÿ€à`ñÿp`ñÿpø€pñÿàðàñÿÀÀ€àñÿ` `Àñÿppðñÿ€€€€€ñÿ€ ÀÀ ñÿ þ’’’ñÿðpñÿ``ñÿðàñÿpˆñÿpñÿààñÿ@@@@`ñÿ  Àñÿðpñÿ¤¤ØñÿP` ñÿþ‚‚‚‚‚‚‚‚‚þñÿà  àà€ñÿP` ñÿ0@pˆpñÿx¨¨p ñÿP` `Pñÿ€€€€€ñÿà€€€ñÿ  ÀñÿP` ñÿà  àà€ñÿP` ñÿ0@pˆpñÿx¨¨p ñÿP` `Pñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿ|ÀìƆÄ̸ñÿ€ð€ñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿà@@à@@àñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿ€€€€€€€€€à`@€ñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿððñÿp€€pñÿp€°pñÿP Pˆpñÿ`À Àñÿ`@@@@@ñÿ@@@À€ñÿppðñÿ  àñÿ@@@@@ñÿ€€€€ñÿ@@@àñÿ@@@àñÿÿÿ Àñÿ€€€€€€€ñÿ€€€€€€€ñÿ€€€àñÿü¤¤ñÿ¤¤ÜñÿpHHH€ñÿàñÿÐаñÿpˆðpñÿp p¨°p ñÿð@0àÀñÿ`@@@@@€ñÿ@@@@` ñÿðpñÿPˆˆpñÿ   àñÿà  àñÿ PPñÿp @ðñÿp @ðñÿp pðñÿp pðñÿpPˆøPpñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þ ñÿ ""AA€€ñÿx„|„ŒtxHxñÿ ü‚‚‚ü‚‚‚üñÿ€€€€øÌ„„„Ìøñÿ ü‚‚‚ü‚‚‚üñÿ€€€€øÌ„„„Ìø ñÿ ü‚‚‚ü‚‚‚üxñÿ€€€€øÌ„„„Ìøxñÿ A€€‡A>ñÿð|Ì„„„Ì|L8ñÿ ÿñÿ€€€€¸Ä„„„„„ñÿ ÿñÿ€€€€¸Ä„„„„„ ñÿ ÿñÿà@@@\bBBBBB ñÿ @€@€@€@€€@€@€@€@€@ àñÿ@@@@\bBBBBB@ àñÿ ÿH0ñÿ€€€€¸Ä„„„„„`ñÿ@@@@@@@@@ð€ñÿ@@@@@@@@ð€ñÿ €€€€€€€€€ñÿ@€ €€€€€€€ñÿ„ˆ À ˆ„ñÿ@€€€€ˆ À ˆñÿ„ˆ À ˆ„ñÿ€€€€ˆ À ˆ ñÿ„ˆ À ˆ„<ñÿ€€€€ˆ À ˆxñÿ€€€€€€€€ü ñÿ€€€€€€€€€€€€ñÿð@@@@@@@@~ñÿð@@@@@@@@@@@@ñÿ€€€€€€€€üxñÿ@@@@@@@@@@@ðñÿ€€€€€€€€ü0Hñÿ@@@@@@@@@@@` ñÿ Á€Á€¢€¢€”€”€ˆ€€€€€ ñÿ ¹ÀÆ „ „ „ „ „ ñÿ Á€Á€¢€¢€”€”€ˆ€€€€€ ñÿ ¹ÀÆ „ „ „ „ „ ñÿ Á€Á€¢€¢€”€”€ˆ€€€€€ ñÿ ¹ÀÆ „ „ „ „ „ ñÿ ÁÁ¡‘™‰…ƒƒñÿ ¸Ä„„„„„ñÿ ÁÁ¡‘™‰…ƒƒñÿ¸Ä„„„„„ ñÿ ÁÁ¡‘™‰…ƒƒ<ñÿ¸Ä„„„„„xñÿ ÁÁ¡‘™‰…ƒƒ$ñÿ¸Ä„„„„„0Hñÿ  ñÿ@ Pñÿ@€ ñÿ@ ñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þ ñÿ A€€€€ˆ€ˆ€”€w ñÿ A€€€€ˆ€ˆ€”€w ñÿ A€€€€ˆ€ˆ€”€wñÿþ‚‚‚‚‚‚‚‚‚þ ñÿ 4,A€€€€ˆ€ˆ€”€w ñÿ 4,A€€€€ˆ€ˆ€”€w ñÿ @'€@     @€ ñÿ @ž!@€@€@€@€@€! ñÿ @'€@    @@à ñÿÿÿ @€ @ @ @ @€€9Àñÿ ñÿ|PÐÐP<ñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þ ñÿ `x@Àx€É8{HÀ€Àx ñÿ `x@Àx€Éx{H`8xñÿ b      `> ñÿaà’”dàñÿ x    àx? ñÿ @xÀÀ€Á€A`zИˆ˜ð ñÿ@xÀÀ€Á€AzHHHHxñÿ|€€€p€€€|ñÿ |‚‚| ñÿ gÀ””dÀñÿþ‚‚‚‚‚‚‚‚‚þ ñÿ h`H@H@€€€€@p` ñÿ  "-€0€€€€à€ ñÿ 〢€¢€¢€¾€¢€¢€¢€ã€ñÿ >"bBBBFñÿ ~ ~bBBFD„ñÿhˆàñÿ 0þä8 ñÿ  €@€¸€‡ñÿ(0PP``@@ð ñÿ Hÿ€HO€HÀH@H@H@HÀO€ñÿ ðÑÉ©••‹‰‡ ñÿq€qyi0mHeHg0cÃx ñÿ >Až€’€ž€€€A>ñÿ FJqBb¤¨ Àñÿ þ¥¥¦¾   à ñÿ f¥¥¥¥¥¥e6 ñÿ i€H€H€  pÀ ñÿ c½‘‘’ဠñÿ þ¥¥¥¾ª¥¥ã€ ñÿ ü‚‚‚þÀ€‚€†@ñÿ üÌÔÔøìä€ñÿ Ëwá ñÿü'À(@(@.@(@'øñÿ éOII ñÿ ÉIs2"64\H€ñÿ  (HP ÿñÿø x0@x  ˜ðñÿ AA€€ ñÿ ó‘‘€!!þñÿ r˜ À@| ñÿ @€À€À€ÿÀ@?ñÿ8D„˜àˆðñÿ8D@@0@€€„| ñÿ ˆˆðñÿ | ü ñÿ0Ø(`     " â8ñÿpàñÿ €†Ãcu˜ŒÆcá ñÿ ÿñÿxxñÿþñÿ p ðpppppø ñÿ Á €À€€€€€€Á€~ñÿð„DŠ(úŠŸ(‘Ä ñÿ €µ55553€ ñÿ ñ ñÿ ü       à ñÿ ÿ€¢€¢€¢€¢€¢€¢€¢€ã€ ñÿ ÿ€H$ € $HÿÀñÿ 8΃á‚|ñÿüñÿüñÿ<$Bà ñÿ R€¢€¢€¢€¢€¥Âüñÿ }¦ÆÊÊÊüñÿ|¤Ä¼ÀÀøñÿ0P``` `ñÿÿÿ(000PPP`Àñÿþ‚‚‚‚‚‚‚‚‚þ ñÿ y€0€x€L€Gñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿøøñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þ ñÿ Á€ABBåà À 1à ñÿ ñ€"bõà À 1à ñÿ Á€ABCÀå À  1À ñÿ ñ€"cÀõ À  1À ñÿ ñ€bÀõ À  1À ñÿ 1€Q’ûÀ À  1À ñÿ Á€ABBÀå À  0À ñÿ à€áÀå À  0À ñÿ Á€ABBÀå @ À 1À ñÿ ñ€bÀõ @ À 1À ñÿ à€áÀå @ À 1À ñÿ ð!€!BBÀE @ À 1À ñÿÁ€ABBä0ñÿ€€€€€€€€€ñÿñÿ ””””””””” ñÿ     @@ˆ€ˆ€……‚ ñÿ €€€€AA"" ñÿ €À€ÀA@A@"@"@@@@ ñÿ€È€ÈAHAH"H"HHHHñÿ€Ê€ÊAJAJ"J"JJJJ ñÿ °À€‰†††‰€°Àñÿ ÃB$$Bà ñÿ Ã@B@$@@@@$@B@Ã@ ñÿÃHBH$HHHH$HBHÃHñÿ€€€€€€€€üñÿ ñÿ @ÿ€ ñÿ ÿ€€@ñÿ €Àà €€€€€€ñÿ `à  ñÿ ÿ€ ñÿ ÿ€€ñÿ €€€€€€€ À€ñÿ  ` ñÿ €ÿÀ€1`ÿÀ`0 ñÿ rúª""""*€' ñÿ 0`ÿÀ`1€ÿÀ€ ñÿ @ÿ€ÿ€@@ÿ€À` ñÿ "wÿ€ª€"""""" ñÿ ÿ€ÿ€ÿ€€ ñÿ """"""ª€w" ñÿ @ÿ€ÿ€€ ñÿ ÿ€ÿ€€@ ñÿ €„„{ ñÿ ˆ€‰€w ñÿ ÿ€1€o ñÿ €€€ñÿ pØØPPPPPP ñÿ ÿ€€ñÿ PPPPPPØP ñÿ €€€ñÿ pØØPPPØP ñÿ ð È$ ñÿ  $H ñÿ H$ ñÿ  $È ð ñÿ €€ÿ€ ñÿ ÿ€€ÿ ñÿ @Þ€­@ ñÿ ¿€_€ñÿ pø¨ ø ø ñÿ ø ø ¨p ñÿ @ô€€@ñÿ pø¨ ñÿ ·€€ñÿ ¨p ñÿ  ÿ€à°€ ñÿ €€ÿ€€€€ ñÿ ?À@@@@?€ñÿ (D((((((8 ñÿ ÿ€€@€@€ñÿ 8(((((l(ñÿ (D(((888ñÿ (D(((((Ä|ñÿ (Tî((((Ä|ñÿ 8T88888Ô|ñÿ (T(D((((8ñÿ (T(D(((Ä| ñÿ Âÿ€€€€ÿ ñÿ ÿ¼°¸¬†ƒ€ ñÿ À`€0€€€€€€ÿ€ñÿ (D((((l( ñÿ yÿ€I€; ñÿ '/€*€""""ªr ñÿ €ÿ€ÿ€€ÿ€€ ñÿ Dÿ€„D ñÿ ÿ€€ ñÿ Iÿ€‰€K ñÿ Jÿ€ŠJ ñÿ *)ÿ€)€+( ñÿ uÿ€•€W4 ñÿ `€ ñÿ €~€ ñÿ €a@@ € ñÿ ÁA""6ñÿ0HŒ€€€€„ÌxñÿpXh˜˜`ñÿüüüñÿüü$$Dü@ ñÿ ?C„€ˆ€ˆ€€ €A¾ ñÿ 6"cAAÿ€ ñÿ ÿACb"4 ñÿ ?€`@€ÿ€€@`?€ ñÿ ?€bD„ÿ€ˆHx?€ñÿ ~@þ€@> ñÿ þ€€ÿ€€€þ ñÿ þ€€ÿ€€€þ ñÿ üþüñÿððððððñÿ ÿñÿ ÿñÿ ÿ@ 0 0`Àÿñÿ ÿ ñÿ ÿ€ÿ€ÿ€ ñÿ ÿ€ñÿþÿ @Àñÿ€€@@@` ñÿ Ö8|Öñÿ``ñÿ€€ñÿÄH(00ñÿ<<ÄH(00ñÿ &>ÄH(00ñÿ tˆˆT ñÿ f™™™fñÿ €€€€€€€þ ñÿ  0 `ÿ€ ñÿ $b€ ñÿ €tBt€ñÿ€€€€€€€€€€€€€ñÿ 0 à ñÿ             ñÿPPPPPXpÐPPPPPñÿ 00pPHȈŒñÿ „ŒÈHXP00ñÿ øŒ„„„„„ñÿ „„„„„„ˆxñÿ(  Àñÿ -$$$$$$$$$´Ø ñÿ -P$@$@$@$@$@$@$@$@$@µ@Ù€ñÿ( p¨¨¨p  À ñÿ +"&~¥¥¥~$$´È ñÿ +P"À&@à¤P¤P¤Pà$@$@µÀÉ€ñÿ( `°¼(  Àñÿ( p¨¸¨p  Àñÿ( p¨¸¨p  Àñÿ‚‚ñÿ‚‚ñÿ€€€€ñÿ‚‚‚‚ñÿ ÿ ñÿ €ü€€ñÿ ÿ ñÿ y€ ñÿ y€ ñÿ p€ ñÿ q˜€€G ñÿ pHI ñÿ@@@@@À@@ ñÿ  y€ ñÿ ÿ€p€Ï ñÿ }€†ÿ€ ñÿ }€Žÿ€ ñÿ €ß€ÿ€ÿ€ ñÿ €ß€ÿ€ ÿ€ ñÿ &€ßˆÿ€ÿ€ ñÿ qŽqŽ ñÿ }€Žx€ß0 ñÿ 0€ßy€†ÿ€ ñÿ 0€ß}€†p€ ñÿ †}€€ÿ€ÿ€ ñÿ €€ÿ€€€ ñÿ 6ã€ã€6 ñÿ 6ã€ÿ€ñÿ ÿÿñÿ ÿÿñÿ €€ÿÿñÿ ÿÿ€€ ñÿ ¿À€¿À€ ñÿ ÿ@@ÿ@@ ñÿ ÿ€$ÿ€ ñÿ $ÿ€ÿ€ ñÿ ÿ€ÿ€ ñÿ "ÿ€ÿ€ ñÿ "ÿ€ÿ€ ñÿ $ÿ€ÿ€ ñÿ >ÿ€ÿ€ ñÿ ~²nÿ€ÿ€ ñÿ 6***ÿ€ÿ€ ñÿ ÿ€ÿ€ñÿ ÿÿ`@ñÿ ÿÿÿ ñÿ ÿ€ÿ€ÿ€ ñÿ ÿÿÿÿñÿ ààÿñÿ ÀxxÀÿ ñÿ €<à<€ÿ€ÿ€ ñÿ à€ðÿ€ÿ€ ñÿ €<à<€ÿ€ÿ€0 ñÿ à€ðÿ€ÿ€0 ñÿ`9€Æç9Àp ñÿ„ç9Àp`9€Æñÿ```ðp``` ñÿ „€ÿ€°€ ñÿ €€äx€ ñÿ „ä €<à ñÿ €€|ì €ÿ€ ñÿ „ü €<ðÿ€ ñÿ €€xà€€ÿ€‚ ñÿ €ð€<à €ß ñÿ €€|ì €€ÿ€’ ñÿ „ü €<ð0€ÿ ñÿ ððñ€<à ñÿ Àx€yÇxà ñÿ üøù€<ð ñÿ Ä|€yÏxð ñÿ €€ ðx€ ñÿ €`8€0`€ ñÿ €€xøñ€€€ ñÿ €À0€8Ç€¸`€ ñÿ €€xø€€x€ ñÿ €À0€8À€x€ ñÿ €€ ôx€ ñÿ „d8€0` @@ ñÿ €@€€@?€ ñÿ þ€€þ ñÿ €DˆˆH?€ ñÿ þ €€þ0 ñÿ ?€@€€@€€ ñÿ þ€€þÿ ñÿ ?€D„ˆH€€ ñÿ þ€€ þÿ ñÿ ?€@€€@€€ ñÿ þþ€ñÿ „„„¤ô¤ˆxñÿ „„„„¤¤ˆxñÿ „„„¤ô¤ˆxñÿ ÿ€€€€ÿñÿ ÿÿñÿ ÿ€€€€ÿÿñÿ ÿÿÿñÿ ü„„„„„„„ñÿ „„„„„„„ü ñÿ >I‰¾€ˆ€ÉI> ñÿ >A¾€€€ÁA> ñÿ >A·œ€œ€÷A> ñÿ >A‡Œ€˜€ñA> ñÿ >Aˆ€ˆ€ÁA> ñÿ >A¤€¤€ÝA> ñÿ >I«œ€œ€ëI> ñÿ >A½€€€€ùA> ñÿ >A¼€€€ÁA> ñÿ ÿ€ˆ€ˆ€¾€ˆ€ˆ€ˆ€ÿ€ ñÿ ÿ€€€€€¾€€€€€€€ÿ€ ñÿ ÿ€¢€÷€œ€œ€¶€ã€ÿ€ ñÿ ÿ€€€€€ˆ€ˆ€€€€€ÿ€ ñÿ €€€€ÿ€€€€€ ñÿ €€€€ÿ€€€€€ ñÿ ÿ€ ñÿ ÿ€ñÿ€€€€ø€€€€ñÿ€€€ø€ø€€€ ñÿ €€€ÿ€€ÿ€€€€ ñÿ     ¿€     ñÿ  ¨¨¨§€¨¨¨  ñÿ    ¿€ ¿€    ñÿ ‚„„„ÿ€ˆ  ñÿ ‚„„ÿ€ˆÿ€  ñÿ ¡¡¢¢¿€¤¤¨¨ ñÿ ¡¡¢¿€¤¿€¤¨¨ñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þ ñÿ €€€á€á€€€€ ñÿ €ðœƒ€ƒœð€ ñÿ €€€a€á€9€€€ÿ€ ñÿ €àœ‡ƒ€ŒðÀÿ€ ñÿ àà¿à à@@ ñÿ ààÿ à @@ ñÿ €þ€€ ñÿ ã€ñÿà@@@@@@@@ñÿ BFd$,8þñÿ þ8($dDFñÿ þBFd$,(ñÿ €€àˆˆþñÿ  "B‚þ ñÿ 1!€ €@À@@À@€` ñÿ À@@@@À`€ €1  ñÿ >A€€€€€€€€€€€€€€€€€€€€ ñÿ €€€€€€€€€€€€€€€€€€€A>ñÿ00HHˆ„„ˆHP00ñÿ€€ñÿ@ð` ñÿþ‚‚‚‚‚‚‚‚‚þ ñÿ À`àà› Ž Ž ± ààÀ` ñÿ À`àÀ›ŽŽ±€àÀÀ` ñÿ À``à   1 `àÀ` ñÿ À` 1€`ÀÀ` ñÿ `À1€`ÀÀ` ñÿ ß0€ÿ€ñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þ ñÿ €€áq€ ñÿ €àC€G<àñÿ€c9ŒÆ0ç09Îs€€ñÿ„ ç89Îs€c9ŒÆ0 ñÿ €àx€ÿ€€x€8À ñÿ À<€ð€ÿ€€pð€ ñÿ ÿ€ÿ€€xð€ ñÿ ÿ€ÿ€€x€<À ñÿ €€€ãð<€ ñÿ €À`œg€<€`€ ñÿ €€|øñ€€# €@ ñÿ ‚Â4€8×€¸` @ ñÿ ÿ€„Œˆˆÿ€ÿ€ ñÿ ÿ€€ € € €ÿ€ÿ€ ñÿ ÿ€€€€€ÿ€ ÿ€ ñÿ ÿ€€€€€ÿ€ ÿ€ ñÿ €€xà € €ÿ€š ñÿ €ð€<è €ÿ€š ñÿ €€xø€€x€ ñÿ €À0€8À„x€ ñÿ €€€å€í€€€€ ñÿ „øœ“€“¼ð @@ ñÿ €€€e€í€9€€€ÿ€ ñÿ „䜋œðð ÿ@ñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þ ñÿ à ÿà0à ñÿ ?€`@€€€ÿ€€€@€`?€ñÿ ~Bþ‚@> ñÿ ?€`@€ÿ€€@`?€ ñÿ €?€`@€ÿ€€@`?€ñÿ ~~@þ€@> ñÿ ?€`@€ÿ€€@`?€€ ñÿ ?€`@ÿ€€ÿ€@`?€ ñÿ þ€ÿà€ü ñÿ þ€€€€ÿ€€€€€þñÿ ü‚þ‚ü ñÿ ÿ€þ€€ÿ€€€þñÿ þüþü ñÿ ÿ€€€€ÿ€€€€ÿ€ñÿfFŠRb|ñÿ ¸lñÿ0H„„„„üñÿ p؈ñÿ ˆp ñÿ ø p؈ñÿ øø p؈ñÿÀ€À@@À€À@@ñÿà€€€€€€€€€€€ñÿà ñÿ€€€€€€€€€€€àñÿ àñÿ x€€€€ñÿ àñÿ €€€€xñÿ à ñÿ ÿ€€€ñÿü„„„„üñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þ ñÿ 〢€”€ÿ€ÿ€”€¶€ã€ ñÿ €€ÿ€ñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿð€€€ñÿðñÿ€€€ðñÿðñÿ` €€€€€€€€€€€ñÿ àñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þ ñÿ÷x €À@ ñÿøx€øñÿÿø°l˜Æƒ‡€‡€˜Â°dÿø ñÿÿø°h˜Èˆ‡‡ˆ˜È°hÿøñÿÿÿ€Û¶€»v€€€·n€¶Î€€€ƒà€ÿÿ€ñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿÿ€ €„€ H€@0€À0€`H€0„€€ÿ€ ñÿ e€‚€À€À€À€€†€cñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿ€€€€€€`ñÿxÌ„„„̸€€€ ñÿ A€€€€ˆ€ˆ€”€wñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿ r΄„„Ìvñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þ ñÿ áÀ!!?ñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þ ñÿ0ø  øxñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þ ñÿ ?€ @@@€ € @@@@ €€ñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿ `@@@À€€€€ñÿ€€€€€€€€€€€€€ñÿ€€€€À@@@` ñÿ€@@ ñÿ€€€€€€€€€€€€€ñÿ0 @@Àñÿð€€€€€€€€€€€€ñÿ€€€€€€€€€€€€€ñÿ€€€€€€€€€€€€ðñÿðñÿ€€€€€€€€€€€€€ñÿðñÿ 8@À€€€€€€€€€€ñÿ à0ñÿ €€€€€€€€€€À@xñÿ €€€€€€€€€€€€€ñÿ àñÿ €€€€À@x@À€€€€ñÿ àñÿ€€€€€€€€€€€€€ñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þ ñÿ À@@?@@@@@?€ ñÿ ?ÀÿÀÿÀÿÀñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þ ñÿ i€¶€Á€Á€Á€¢€œ€cñÿþ‚‚‚‚‚‚‚‚‚þ ñÿ ?À €@€Aÿñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þ ñÿÿÿ 8à/1!!€!1.ñÿ„„„üñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þ ñÿ 3È€˜€ˆ@ˆ@ˆ@ž€A> ñÿ 3Ü€‚€‚@„@ˆ@ž€A> ñÿ 3Ü€‚€‚@Ž@‚@ž€A> ñÿ 3Ä€Œ€”@”@¾@„€A> ñÿ 3Þ€€œ@‚@‚@ž€A> ñÿ 3΀€œ@²@¢@–€I> ñÿ 3^€‚@†@„@„@ˆ€@€? ñÿ 3Ì€’€’@ž@¢@–€I> ñÿ 3Ì€’€’@ž@‚@œ€A> ñÿ 3Ó€µ€”À”À•@»€A>ñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þ ñÿ ÿÀÿÀÿÀÿÀÿÀÿÀ ñÿ ÿÀ ñÿ ÿÀÿÀÿÀ ñÿ ÿÀÿÀÿÀÿÀÿÀ ñÿ ÿÀÿÀÿÀÿÀÿÀÿÀ ñÿ ÿÀÿÀÿÀÿÀÿÀÿÀÿÀÿÀ ñÿ ÿÀÿÀÿÀÿÀÿÀÿÀÿÀÿÀÿÀÿÀ ñÿ ÿÀÿÀÿÀÿÀÿÀÿÀÿÀÿÀÿÀÿÀÿÀ ñÿ ÿÀÿÀÿÀÿÀÿÀÿÀÿÀÿÀÿÀÿÀÿÀÿÀÿÀ ñÿ ÿ€ÿ€ÿ€ÿ€ÿ€ÿ€ÿ€ÿ€ÿ€ÿ€ÿ€ÿ€ÿ€ñÿ ÿÿÿÿÿÿÿÿÿÿÿÿÿñÿ üüüüüüüüüüüüüñÿ øøøøøøøøøøøøøñÿ ðððððððððððððñÿ ÀÀÀÀÀÀÀÀÀÀÀÀÀñÿ €€€€€€€€€€€€€ñÿ øøøøøøøøøøøøø ñÿ „„0€0€„0€0€„„0€ ñÿ ´€´€K@´€´€K@K@´€K@K@´€´€K@ ñÿ {À{ÀÏ@Ï@ÿÀ{ÀÿÀÏ@Ï@{À{ÀÿÀÏ@ ñÿ ÿÀñÿ €€€€€€€€€€€€€ñÿ øøøøøøñÿ øøøøøøñÿ øøøøøø ñÿ øøøøøøÿÀÿÀÿÀÿÀÿÀÿÀ ñÿ øøøøøøÀÀÀÀÀÀ ñÿ ÿÀÿÀÿÀÿÀÿÀÿÀøøøøøø ñÿ ÿÀÿÀÿÀÿÀÿÀÿÀÀÀÀÀÀÀñÿ øøøøøø ñÿ ÀÀÀÀÀÀøøøøøø ñÿ ÀÀÀÀÀÀÿÀÿÀÿÀÿÀÿÀÿÀ ñÿ ÿÀÿÀÿÀÿÀÿÀÿÀÿÀÿÀÿÀÿÀ ñÿ ÿÀ€@€@€@€@€@€@€@€@ÿÀ ñÿ ÿÀ€@€@€@€@€@€@€@€@€ ñÿ ÿÀ¿À¿À¿À¿À¿À¿À¿À€@ÿÀ ñÿ ÿÀÿÀ€@ÿÀ€@ÿÀ€@ÿÀ€@ÿÀ ñÿ ÿÀ­@­@­@­@­@­@­@­@ÿÀ ñÿ ÿÀÿÀ­@ÿÀ­@ÿÀ­@ÿÀ­@ÿÀ ñÿ ÿÀ”ÀÊ@¥@ÒÀ©@”ÀÊ@¥@ÿÀ ñÿ ÿÀÊ@”À©@Ò@¤ÀÉ@’À¥@ÿÀ ñÿ ÿÀÞÀÞÀ­@ÒÀ­ÀÝÀÚÀ¥@ÿÀñÿ þþþþþþþñÿ þ‚‚‚‚‚þ ñÿ ÿÀÿÀÿÀÿÀÿÀ ñÿ ÿÀ€@€@€@ÿÀñÿøøøøøøøøøøñÿøˆˆˆˆˆˆˆˆø ñÿ ?À?€€ÿ ñÿ ?À €@€Aÿ ñÿ ??€€ÿÀ ñÿ "!A@€€€ÿÀñÿ08x|üñÿ0HH„ü ñÿ ÀðüÿÿÀÿüðÀ ñÿ À°Œƒ€À†˜àñÿÀðüøà€ñÿÀ°Œ˜à€ ñÿ àþÿÀþð€ ñÿ àžÀ†¸À ñÿ ÿÀ€€?? ñÿ ÿÀ@€@€!! ñÿü|x80ñÿü„HH0 ñÿ ÀÀÀ?ÀÿÀ?ÀÀÀÀ ñÿ À@ @0@À@ @@@Àñÿ <ü< ñÿ 4Ä$ ñÿ ÀÀÿÀÀÀ@ ñÿ À@à@@@À ñÿ ?€ÿÀ€? ñÿ !@€€@@€! ñÿ -^€¿@^€- ñÿ >M€¾€¿@ÿ@¿@¾€\€#ñÿ00HHˆ„„ˆHP00 ñÿ >A€€€€@€@€@€€@€# ñÿ A€@€@€@@€ ñÿ >U€Õ€Õ@Õ@Õ@Õ€U€7 ñÿ >A€ˆ€–@¢@’@œ€@€# ñÿ €€ÿÀÿÀÿÀÿÀ€€ ñÿ >y€ø€ø€ø@ø@ø€x€; ñÿ >G€‡€‡€‡À‡À‡€G€' ñÿ >€ÿ€ÿ€ÿÀ€@€€@€# ñÿ >A€€€€€€@ÿÀÿ€€? ñÿ >G€‡€‡€‡À€@€€@€# ñÿ >G€‡€‡€‡ÀÿÀÿ€€? ñÿ8xøøøøøx8ñÿàðøøøøøðà€ñÿ ÿÿÿçÃÃçÿÿÿ ñÿ ÿÀÿÀìÀ¿@¿ÀÿÀÿÀÿÀÿÀ¿@ÎÀóÀÿÀ ñÿ ÿÀÿÀìÀ¿@¿ÀÿÀÀ ñÿ ÀÿÀ¿@ÎÀóÀÿÀñÿ0@€€€ñÿ`ñÿ Àñÿ€€@  ñÿ >A€€€€@@ ñÿ €@€€@€# ñÿ @ÀÀÀÀÀÀ?ÀÀÿÀ ñÿ €Ààðøüþÿÿ€ÿÀ ñÿ ÿ€ÿþüøðàÀ€ ñÿ À?ÀÀÀÀÀÀÀ@ñÿ`à ñÿ ÿÀø@ø@ø@ø@ø@ø@ø@ø@ÿÀ ñÿ ÿÀ‡À‡À‡À‡À‡À‡À‡À‡ÀÿÀ ñÿ ÿÀÿ@þ@ü@ø@ð@à@À@€@ÿÀ ñÿ ÿÀ€ÀÀƒÀ‡ÀÀŸÀ¿ÀÿÀÿÀ ñÿ ÿÀ„@„@„@„@„@„@„@„@ÿÀ ñÿ "-A@€€€ÿÀ ñÿ 99x€x€ÿÀ ñÿ &'GG€‡€ÿÀ ñÿ€0@@ €€€€€€€@ `€ ñÿ ÿÀ„@„@„@ü@€@€@€@€@ÿÀ ñÿ ÿÀ€@€@€@ü@„@„@„@„@ÿÀ ñÿ ÿÀ€@€@€@‡À„@„@„@„@ÿÀ ñÿ ÿÀ„@„@„@‡À€@€@€@€@ÿÀ ñÿ >I€ˆ€ˆ€ø@€@€€@€# ñÿ >A€€€€€ø@ˆ@ˆ€H€+ ñÿ >A€€€€€Àˆ@ˆ€H€+ ñÿ >I€ˆ€ˆ€À€@€€@€# ñÿ ÿ€‚„ˆ À€ ñÿ À @@@@@@À@ ñÿ €À ˆ„‚€€ÿÀ ñÿ ÿ€€€€€€€€€€€€€€€ÿ€ ñÿ ÿ€ÿ€ÿ€ÿ€ÿ€ÿ€ÿ€ÿ€ÿ€ñÿ þ‚‚‚‚‚þñÿ þþþþþþþ ñÿ @À@@@@@ @@@ÿÀ ñÿ ).ßÀ#@ ñÿ €?à?àÿà ñÿ ?€ÿÀ ñÿ   €ŽR«€ €! ñÿ `  À ñÿ  ÿ€?2! ñÿ ó€A"">!ñÿ @€@  ñÿ ÿ€€€‚„„‚€€€À ñÿ ?@€€€Œ@Œ@€€€€A> ñÿ Á€€€€À€€ã€’@’@〠ñÿ 〒@²ÀÁ€€À€À€€a€>ñÿ <|„„„Ìx ñÿ à  " ÝÀˆˆˆpñÿ?ðà÷üžd;ð?0;x>ø?øñÿø $”¤k\7°LLGð ñÿ ÿÀ€@€@€@€@€@€@€@ÿÀ ñÿ ÿÀ@‚@„@„@ˆ@˜@@ÿÀ ñÿ ÿÀ¡@²@œ@Œ@–@£@€@ÿÀñÿ€ˆP` Pˆ ñÿ @€@@@ÿ€;@ ñÿ ÷€À€?€ ñÿ a€€€€€€€€€€€€ÿÀ ñÿ ?€€ÿ€ÿ€ÿ€ÿ€ÿÀ ñÿ  i€ÿÀ{€k€ ñÿ €¾€½€}€ ñÿ ÿÀ€€€€€ ñÿ ÿÀüþüøx ñÿ ÿÀ€ €0€€€ñÿ4ôä„„„ü ñÿ ÿÀŽ‚„„|ñÿü„„„ôt ñÿ AA7Ý€ºÀ_ò€Í€ ñÿ ?á0 '€< ñÿ ?c€ó€ÿÀŒ@”€Œ€_> ñÿ "!!?Ö€.@ s€ñÿ þÜ|xTxX00ñÿ 8(™ÿñÿ(ì0ñÿ V<88|Vñÿ pø ñÿ ˆ@ÿÀˆ@ ñÿ >`ÀÁÁ€À€`p ñÿ k©€©@©@©€š€ñÿ üÖÖºÖz8 ñÿ € €€€#€|€@@ ñÿ ?I€ˆ€ˆ@œ@ª€i€i ñÿ €€ð€ø@Û@ø€€ ñÿ ÿÀÿÀÿÀ ñÿ óÀÿÀÿÀ ñÿ ÿÀóÀÿÀ ñÿ óÀóÀÿÀ ñÿ ÿÀÿÀóÀ ñÿ óÀÿÀóÀ ñÿ ÿÀóÀóÀ ñÿ óÀóÀóÀ ñÿ {{T€óÀ^€k{€ ñÿ ?A€’€’@Œ@’€b€a ñÿ ?A€’€’@¢@’€L€a ñÿ ?€Ì€ÿÀÞÀ߀a€ ñÿ ).ÓÀ+@ñÿ p(((0`ñÿ 8` ÀÀ  P8ñÿ„„xH„„„x xñÿ |‚‚Â|<ñÿ <|‚‚Âl ñÿ ÀÀ?@F‚‚‚F<ñÿ zʆ þñÿ €à€°HD„ˆñÿ ÓRR~RRÓ8(ñÿ 8ÒWRV<8ñÿ à˜Œˆø€€€€ø ñÿ @£À’@”@  ñÿ @Á€!6!!!# ñÿ ÿ€"""""">ဠñÿ ?X€ˆˆw€€€‡€~ñÿ ""b’”¤H ñÿ ¶JJÀK@K@J@J@J€J€ ñÿ "!"óÀÿÀ ñÿ [mIIIIIIH€` ñÿ ÀÀ@>@@ @"@€ ñÿ XXh('€€€ ñÿ €’€€’€ñÿ ÃD$$þ$$D‚ ñÿ  6M€ˆ€ˆ€H€?A? ñÿ ok€®€_km3??ñÿ þ‚|DDD|‚þñÿ p0XˆpPPˆüñÿ pHÄ„‚’bB~ñÿ 8$D(V‚ÿ ñÿ  6o€û€û€{€?_? ñÿ /j€ª€[[=#??ñÿ þB|||||‚þñÿ 00Xˆpppxüñÿ P0ø|~î~>ñÿ <<8~þÿÿñÿ 8<~þÿîT ñÿ ÷€ˆ€€€€€@€A"ñÿ 8(D‚‚BD( ñÿ  €ÿ€w€{ñÿ (D‚‚ºT ñÿ w€ÿ€ÿ€€€? ñÿ 8<~þ~< ñÿ >"" €œ€{ ñÿ 8V4,Ë€€€@€?ñÿ ààñÿ,$ ààñÿ &"""""bæ ñÿ € €€ € € € €ã€ã€ñÿ€€€€°Ð Àñÿ€ à  à  ñÿ `  °à€ñÿ ‘~‘ñÿ ç ñÿ >M7•@Á€~€M2 ñÿ "E€Ä€€@û€ ñÿ "E€È€ž@û€ ñÿ "M€Â€œ@û€ ñÿ " U€Þ€„@û€ ñÿ "]€Â€œ@û€ ñÿ "]€Ô€Œ@û€ ñÿ "E€Ä€ˆ@û€ ñÿ "A€À€€@û€ ñÿ 76a€áÀÀ€{€? ñÿ ?i€é€žÀž@¿€H€ ñÿ Ÿ€¶€á@áÀဿ€E> ñÿ €€²€Í@ÉÀµ€‚€A>ñÿ `@@0¼„„Ëx ñÿ ÿ€€€€€ˆ€Œ€€€€€€€ÿ€ ñÿ ÿ€‚€ƒ€€€€€ €°€€€ÿ€ ñÿ ÿ€‚€ƒ€ˆ€Œ€ €°€€€ÿ€ ñÿ ÿ€¢€³€€€€€¢€³€€€ÿ€ ñÿ ÿ€¢€³€ˆ€Œ€¢€³€€€ÿ€ ñÿ ÿ€¢€£€¢€³€€€³€€€ÿ€ ñÿ ?@€€€@ƒ@€€€€A> ñÿ ?@€€€¡@£@€€€€A> ñÿ ?€ÿ€þÀüÀÿ€€ ñÿ ?€ÿ€ÞÀÜÀÿ€€ ñÿ ÿÀ ñÿ óÀ ñÿ ÿÀÿÀ ñÿ óÀÿÀ ñÿ ÿÀóÀ ñÿ óÀóÀñÿ À°Ž‚‚‚ú„€ñÿ Àp~~~~Ž€€ ñÿ sa€ñÀš@ q€ ñÿ  ?ˆ€È€?ñÿ BD(8nv‰ñÿ àà8``8`0 ñÿ  s€b€¢€’€”@”@ó€ ñÿ O‡€€@@ñÿ <$$™v8 ñÿ aÀ€H€ŒÀ@€Asñÿ Þî(ñÿ 8(ÿ¦z­µj8ñÿ Û½üº|(ñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þ ñÿ *)A@€ˆ€ÿÀñÿ 0``€ ñÿ 6I”€”€”€$$>$ ñÿ ÀÀ À?L€L@Œ@L€? ñÿ ÀÀÀ?L€L€Œ@L€€|ñÿ  8L„„Dxxñÿ 8pˆ„„ˆx ñÿ w{ºt>"B"6>ñÿ 8X|8D„„D8 ñÿ 0M€…@‡à…Àxñÿ xÌ„„Ìxñÿ xüüüüxñÿ ``ñÿ |ªª| ñÿ 뀜€œ€¿€H ñÿ qÀ‘ Ž ñÀ ñÿ ~€€~ñÿ pPЈPP ñÿ |‚‚Â|ñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þ ñÿ p0ÏÀô ñÿ €Á€fãÀ ñÿ B¿ÀHp ñÿ `áà~€öÀa@ñÿþ‚‚‚‚‚‚‚‚‚þ ñÿ cœ€€°€ €°€Q> ñÿ c‰˜€ˆ€º€ç€Â€A> ñÿ  Œÿ€Œ ñÿ ÿ€Á€¾€œ€ª€Á€ÿ€ñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿ ðð°ðÐÐаð ñÿ >IÀXÀ°ÀtÀ‹ñÿ pèÔj6  ñÿ ¿€á@ÿ€ñÿ +VªÔèp ñÿ |‹—€ê ñÿ ÿ÷€þñÿ  à@ñÿ  \xp`ñÿ Æl88lÆ‚ ñÿ "w>>÷€cñÿ f,88hÌÀ€ñÿ Çî|x8|þÌ€ ñÿ <,뀈€ÿ€ˆ€o, ñÿ ÿ€ÿ€ÿ€ ñÿ ÿ€÷€ ñÿ ã€ã€ã€ñÿ þþñÿ xÌ‚ÎÎHHH8ñÿ xÖþþÖXXX8 ñÿ >ˆ€É€ÿ€ˆ€ˆ€> ñÿ ïcBcÿ€ ñÿ É€ÿ€ ñÿ É€ÿ€É€ ñÿ ë€ÿ€ë€ ñÿ <Kë€ÿ€k ñÿ > ñÿ "C4ñÿþ‚‚‚‚‚‚‚‚‚þ ñÿ àÀ@€!€!$€{€ ñÿ w÷瀀€Á€Ã€É€]> ñÿ  sÀ!€! ñÿ îÀ^€/€/$€{€ ñÿ  wÀ.€+1 ñÿ  {À%€! ñÿ  À'€+1 ñÿ  áÀ!€#-;0€ ñÿ Yÿ€>ÿ€û€ ñÿ ë€6$wÉ€ ñÿ I*ÿ€*I ñÿ %€5€ ñÿ k^n—€vVy ñÿ I>>É ñÿ J>>*I ñÿ {>ÿ€>~I ñÿ *>>ÿ€¾€* ñÿ ,]¾€ÿ€ß>]* ñÿ Éë€ë€É€ ñÿ Éë€ë€É€ ñÿ ßë€ÿ\ë€û€ ñÿ ×û€ÿ€] ñÿ ÷€ã€Á€Ccv ñÿ $€¾€]Iv ñÿ ß»æ€ã€Õ€¿½^ ñÿ w•Ý€£€¢€ã€Ý€·~ ñÿ ßì€ÿ€T ñÿ >kkª€ ñÿ >kÝ*û€. ñÿ IIÿ€œ€ë€Ë€_ ñÿ Éë€ë€Ë€ ñÿ I*<ë€*I ñÿ ]2Ý€ÿ€,*] ñÿ K*ë€${I ñÿ k*œ€ÿ€<kIñÿþ‚‚‚‚‚‚‚‚‚þ ñÿ <C€€€@€@€@€@€€€€ñÿþ‚‚‚‚‚‚‚‚‚þ ñÿ ÿÀ€@€@€@€@€@€@€@ÿÀÿÀ ñÿ ÿÀ€@€@€@€@€@€@€@€@ÿ€ ñÿ ÿÀ€@€@€@€@€@€@€@ÿÀÿÀ ñÿ ÿÀ€@€@€@€@€@€@€@€@ÿÀñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þ ñÿ ?€÷€oñÿþ‚‚‚‚‚‚‚‚‚þñÿ €€€€€€€€€€€€€ñÿ àààààààààààààñÿ øøøøøøøøøøøøøñÿ@ÀÀÀñÿÀÀ@€ñÿHØØØñÿØØHñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿ ~ôôô|ddLxñÿ pøøø pppñÿ Lîþ|0888 ñÿ ÷€÷€ÿ€ÿ>ñÿ pøü|>üøøpñÿ y™†>~~<2 ñÿ LlÞ€Ÿ€Nñÿ  `ÀÀÀÀÀÀ` ñÿ À 00 Àñÿ 00```àà```00ñÿ ``0000000p``ñÿ 00``ÀÀÀ``00ñÿ À``0000``Àñÿ 8p`ààp88 ñÿ àp08  88pàñÿ 88ppàpp88ñÿ pp8888ppñÿ @€€€€€€€€€@ ñÿ €@@@@@@@@@@@€ñÿ 80000ð0000ñÿ àp0000<000pà ñÿ ?w€÷€÷À÷À÷Àá€> ñÿ ?c€ý€ýÀûÀ÷Àé€> ñÿ ?a€ý€ýÀñÀüÀé€> ñÿ ?{€ó€ëÀëÀÑÀû€> ñÿ ?a€ï€ãÀýÀýÀé€> ñÿ ?c€ß€ÇÀÏÀÏÀK€> ñÿ ?a€ý€ûÀûÀóÀ÷€> ñÿ ?s€í€íÀãÀÍÀé€> ñÿ ?y€|ÀüÀøÀþÀt€?€ ñÿ ?o€ï€ë@ë@ë@Ä€> ñÿ $€\@„ „ „ „ „@_@ € ñÿ ,€S@ ƒ ‚ „ ˆ@_@ € ñÿ .€S@ ‚ ‡ @^@ € ñÿ "€F@Š ’ ’ ¿ ‚@B@ € ñÿ >€P@ ž @^@ € ñÿ &€X@ ž ‘ ‘ ‘@N@ € ñÿ ?€A@‚ ‚ „ „ „@H@ € ñÿ .€Q@‘ š ž ‘ ‘@^@ € ñÿ ,€[@‘ ‘ › … @^@ € ñÿ 3€TÀ” ” ” ” ”À[@ € ñÿ ;€kÀûàûàûàûà{À`À?€ ñÿ 3€lÀþàüàýàûàwÀhÀ?€ ñÿ 1€lÀþàýàüàþà~ÀaÀ?€ ñÿ =€}ÀõàýàíàÐà}À}À?€ ñÿ !€oÀïàáàþàþà~ÀaÀ?€ ñÿ 9€gÀïàñàîàîànÀqÀ?€ ñÿ  €~Àýàýàûàûà{ÀwÀ?€ ñÿ 1€nÀîàåàçàîànÀaÀ?€ ñÿ 3€dÀîàîàäàþà~ÀaÀ?€ ñÿ .€m@ïàë ë ë o@D@?€ ñÿ ÿ€ÿ€ñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿ €À`0 ñÿ ÿ€ó€ñÿ 0`À€ ñÿ  ñÿ ÿ€ÿ€ ñÿ €€ ñÿ ÿ€ÿ€ ñÿ /€/€ ñÿ .¯€¯. ñÿ ÿ€ÿ€ ñÿ @80À ñÿ @8"\  ñÿ @p<??<p@ ñÿ ÿÿ€ÿ€ ñÿ ÿ€ÿ€ƒñÿ ðøøð ñÿ þÿÿü ñÿ û€ú ñÿ ý€€þ ñÿ €€~@@@€Àÿ€ ñÿ ÿ€üÀ@@@@?@€ñÿ 䂃öüñÿ þ‡ƒ‚ô ñÿ ù€€€ÿñÿþ‚‚‚‚‚‚‚‚‚þ ñÿ ý€€€€~ñÿ |ö| ñÿ ñ±€ÿðñÿ 0x8 ñÿ ðy€ñÿ 8x0 ñÿ ðx8 ñÿ ðñ€ÿñÿ 8xð ñÿ ø€÷ ñÿ bù ñÿ ù€y€ñ ñÿ û€}€ú ñÿ x€z ñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿ0(HD„ü„HH00ñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿð          ðñÿðPPPPPPPPPPðñÿ @@@€€@@@ ñÿ€À@@@ @@@€€ñÿ((PPP  PPP((ñÿ ðPPP((PPP  ñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þ ñÿ 6wÕ€Õ€UUUU ñÿ UUUUÕ€U6 ñÿ €@\@8 @@€ ñÿ 6EG@C€Ab> ñÿ%€DÿøDˆD%€ñÿ @ÿÿ€@ ñÿÿÿ€ñÿ0`ÿÿ€`0ñÿÿ€€€ÿñÿÿÿ€€ÿñÿÿ€€€€ÿñÿ€@€ÿÿ€€€@€€ñÿ€€ÿÿ€€€€€ñÿ€ÿ€€€€€ÿ€€ñÿ€ÿÿ€€€€ÿÿ€ñÿW¯€«W€ñÿ ñÿ ÀÀñÿ ÀÀñÿ ÀÀÀÀñÿ ÀÀñÿ ÀÀÀÀñÿ ÀÀÀÀñÿ ÀÀÀÀÀÀñÿ ÀÀñÿ ÌÌñÿ ÀÀñÿ ÌÌÀÀñÿ ÀÀñÿ ÌÌÀÀñÿ ÀÀÀÀñÿ ÌÌÀÀÀÀñÿ ÀÀñÿ ÀÀ ñÿ ÌÌñÿ ÀÀÌÌñÿ ÀÀñÿ ÀÀ ÀÀñÿ ÌÌÀÀñÿ ÀÀÌÌÀÀñÿ ÀÀÀÀñÿ ÌÌ ñÿ ÌÌñÿ ÌÌÌÌñÿ ÀÀñÿ ÌÌ ÀÀñÿ ÌÌÀÀñÿ ÌÌÌÌÀÀñÿ ÀÀñÿ ÀÀ ñÿ ÀÀ ñÿ ÀÀÀÀ ñÿ ÌÌñÿ ÀÀÌÌñÿ ÀÀÌÌñÿ ÀÀÀÀÌÌñÿ ÀÀÀÀñÿ ÌÌ ñÿ ÀÀ ñÿ ÌÌÀÀ ñÿ ÌÌñÿ ÌÌÌÌñÿ ÀÀÌÌñÿ ÌÌÀÀÌÌñÿ ÀÀÀÀñÿ ÀÀ ñÿ ÌÌ ñÿ ÀÀÌÌ ñÿ ÌÌñÿ ÀÀ ÌÌñÿ ÌÌÌÌñÿ ÀÀÌÌÌÌñÿ ÀÀÀÀÀÀñÿ ÌÌ ñÿ ÌÌ ñÿ ÌÌÌÌ ñÿ ÌÌñÿ ÌÌ ÌÌñÿ ÌÌÌÌñÿ ÌÌÌÌÌÌñÿ ÀÀñÿ ÀÀÀÀñÿ ÀÀÀÀñÿ ÀÀÀÀÀÀñÿ ÀÀÀÀñÿ ÀÀÀÀÀÀñÿ ÀÀÀÀÀÀñÿ ÀÀÀÀÀÀÀÀñÿ ÀÀñÿ ÌÌÀÀñÿ ÀÀÀÀñÿ ÌÌÀÀÀÀñÿ ÀÀÀÀñÿ ÌÌÀÀÀÀñÿ ÀÀÀÀÀÀñÿ ÌÌÀÀÀÀÀÀñÿ ÀÀñÿ ÀÀ ÀÀñÿ ÌÌÀÀñÿ ÀÀÌÌÀÀñÿ ÀÀÀÀñÿ ÀÀ ÀÀÀÀñÿ ÌÌÀÀÀÀñÿ ÀÀÌÌÀÀÀÀñÿ ÀÀñÿ ÌÌ ÀÀñÿ ÌÌÀÀñÿ ÌÌÌÌÀÀñÿ ÀÀÀÀñÿ ÌÌ ÀÀÀÀñÿ ÌÌÀÀÀÀñÿ ÌÌÌÌÀÀÀÀñÿ ÀÀñÿ ÀÀ ÀÀñÿ ÀÀ ÀÀñÿ ÀÀÀÀ ÀÀñÿ ÌÌÀÀñÿ ÀÀÌÌÀÀñÿ ÀÀÌÌÀÀñÿ ÀÀÀÀÌÌÀÀñÿ ÀÀñÿ ÌÌ ÀÀñÿ ÀÀ ÀÀñÿ ÌÌÀÀ ÀÀñÿ ÌÌÀÀñÿ ÌÌÌÌÀÀñÿ ÀÀÌÌÀÀñÿ ÌÌÀÀÌÌÀÀñÿ ÀÀñÿ ÀÀ ÀÀñÿ ÌÌ ÀÀñÿ ÀÀÌÌ ÀÀñÿ ÌÌÀÀñÿ ÀÀ ÌÌÀÀñÿ ÌÌÌÌÀÀñÿ ÀÀÌÌÌÌÀÀñÿ ÀÀñÿ ÌÌ ÀÀñÿ ÌÌ ÀÀñÿ ÌÌÌÌ ÀÀñÿ ÌÌÀÀñÿ ÌÌ ÌÌÀÀñÿ ÌÌÌÌÀÀñÿ ÌÌÌÌÌÌÀÀñÿ ÀÀñÿ ÀÀ ñÿ ÀÀ ñÿ ÀÀÀÀ ñÿ ÀÀ ñÿ ÀÀÀÀ ñÿ ÀÀÀÀ ñÿ ÀÀÀÀÀÀ ñÿ ÀÀÀÀñÿ ÌÌ ñÿ ÀÀ ñÿ ÌÌÀÀ ñÿ ÀÀ ñÿ ÌÌÀÀ ñÿ ÀÀÀÀ ñÿ ÌÌÀÀÀÀ ñÿ ÀÀÀÀñÿ ÀÀ ñÿ ÌÌ ñÿ ÀÀÌÌ ñÿ ÀÀ ñÿ ÀÀ ÀÀ ñÿ ÌÌÀÀ ñÿ ÀÀÌÌÀÀ ñÿ ÀÀÀÀÀÀñÿ ÌÌ ñÿ ÌÌ ñÿ ÌÌÌÌ ñÿ ÀÀ ñÿ ÌÌ ÀÀ ñÿ ÌÌÀÀ ñÿ ÌÌÌÌÀÀ ñÿ ÀÀÀÀñÿ ÀÀ ñÿ ÀÀ ñÿ ÀÀÀÀ ñÿ ÌÌ ñÿ ÀÀÌÌ ñÿ ÀÀÌÌ ñÿ ÀÀÀÀÌÌ ñÿ ÀÀÀÀÀÀñÿ ÌÌ ñÿ ÀÀ ñÿ ÌÌÀÀ ñÿ ÌÌ ñÿ ÌÌÌÌ ñÿ ÀÀÌÌ ñÿ ÌÌÀÀÌÌ ñÿ ÀÀÀÀÀÀñÿ ÀÀ ñÿ ÌÌ ñÿ ÀÀÌÌ ñÿ ÌÌ ñÿ ÀÀ ÌÌ ñÿ ÌÌÌÌ ñÿ ÀÀÌÌÌÌ ñÿ ÀÀÀÀÀÀÀÀñÿ ÌÌ ñÿ ÌÌ ñÿ ÌÌÌÌ ñÿ ÌÌ ñÿ ÌÌ ÌÌ ñÿ ÌÌÌÌ ñÿ ÌÌÌÌÌÌ ñÿ ÌÌñÿ ÀÀÌÌñÿ ÀÀÌÌñÿ ÀÀÀÀÌÌñÿ ÀÀÌÌñÿ ÀÀÀÀÌÌñÿ ÀÀÀÀÌÌñÿ ÀÀÀÀÀÀÌÌñÿ ÌÌñÿ ÌÌÌÌñÿ ÀÀÌÌñÿ ÌÌÀÀÌÌñÿ ÀÀÌÌñÿ ÌÌÀÀÌÌñÿ ÀÀÀÀÌÌñÿ ÌÌÀÀÀÀÌÌñÿ ÌÌñÿ ÀÀ ÌÌñÿ ÌÌÌÌñÿ ÀÀÌÌÌÌñÿ ÀÀÌÌñÿ ÀÀ ÀÀÌÌñÿ ÌÌÀÀÌÌñÿ ÀÀÌÌÀÀÌÌñÿ ÌÌñÿ ÌÌ ÌÌñÿ ÌÌÌÌñÿ ÌÌÌÌÌÌñÿ ÀÀÌÌñÿ ÌÌ ÀÀÌÌñÿ ÌÌÀÀÌÌñÿ ÌÌÌÌÀÀÌÌñÿ ÌÌñÿ ÀÀ ÌÌñÿ ÀÀ ÌÌñÿ ÀÀÀÀ ÌÌñÿ ÌÌÌÌñÿ ÀÀÌÌÌÌñÿ ÀÀÌÌÌÌñÿ ÀÀÀÀÌÌÌÌñÿ ÌÌñÿ ÌÌ ÌÌñÿ ÀÀ ÌÌñÿ ÌÌÀÀ ÌÌñÿ ÌÌÌÌñÿ ÌÌÌÌÌÌñÿ ÀÀÌÌÌÌñÿ ÌÌÀÀÌÌÌÌñÿ ÌÌñÿ ÀÀ ÌÌñÿ ÌÌ ÌÌñÿ ÀÀÌÌ ÌÌñÿ ÌÌÌÌñÿ ÀÀ ÌÌÌÌñÿ ÌÌÌÌÌÌñÿ ÀÀÌÌÌÌÌÌñÿ ÌÌñÿ ÌÌ ÌÌñÿ ÌÌ ÌÌñÿ ÌÌÌÌ ÌÌñÿ ÌÌÌÌñÿ ÌÌ ÌÌÌÌñÿ ÌÌÌÌÌÌñÿ ÌÌÌÌÌÌÌÌñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þ ñÿ €€€€€€€€ ñÿ ‚ÿ€€€ÿ€ñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿ 8|ÖÖTTTTTñÿ TTTTTÖT8ñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿ  >MEAAc>ñÿ >YQAAc>ñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿ ñÿ ð€x€ÿ€ÿ€€à> ñÿ €€xà€€ÿ€€ÿ€ ñÿ €ð€<à€ÿ€€ÿ€ ñÿ €à<€}€†À|€à ñÿ À|€>à}€†€ð<€ ñÿ €øø‡€x€ðÿ€ÿ€ ñÿ ø€€ð€ð|€ÿ€ÿ€ ñÿ €€ð|Ç€<À>€>À<À ñÿ €ø€ñ€á€>à>  ñÿ €q€Žpà8€ ñÿ à<Ç8€€p€ ñÿ €q€Žpá9€ ñÿ à<Ç8€ƒ€Žp€ ñÿ ÿ€ÿ€€<à<€ ñÿ ÿ€ÿ€à€ð ñÿ €<Ç€<À<à<€ ñÿ ðá€ã€€ð ñÿ Ï0€€ðð€ ñÿ Ï0€À<€x€ ñÿ ß0€€ðð€ÿ€ÿ€ ñÿ ß0€Àx€x€ÿ€ÿ€ñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þ ñÿ 6ã€ÿ€ÿ€ ñÿ €€xø€€ÿ€ ñÿ €À0€8À€ÿ€ ñÿ €€xø€€ÿ€ ñÿ €À0€8À„ÿ€ ñÿ €€ø|€ÿ€ÿ€ÿ€ ñÿ Àp€`€ÿ€ÿ€ÿ€ ñÿ €€ø|€ÿ€ÿ€0 ñÿ Àp€`€ÿ€ÿ€0 ñÿ €à€0€ß0€ß ñÿ €`<€8À€0€ß0€ß ñÿ €à€4€Ï8€ß ñÿ €`<€8À„4€Ï8€ßñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þ ñÿ €€xàã€ã€<€ ñÿ €ð€<ã€<ã€<àñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿþ‚‚‚‚‚‚‚‚‚þñÿ  $H`ñÿ ð È$ ñÿ `H$ ñÿ  $È ð ñÿ ?€@@@@?€ ñÿ ?ÀÀÀ0ñÿ 8|8888888ñÿ 888888|8ñÿ &2; \ exit 1;; \ esac; \ has_opt=no; \ sane_makeflags=$$MAKEFLAGS; \ if $(am__is_gnu_make); then \ sane_makeflags=$$MFLAGS; \ else \ case $$MAKEFLAGS in \ *\\[\ \ ]*) \ bs=\\; \ sane_makeflags=`printf '%s\n' "$$MAKEFLAGS" \ | sed "s/$$bs$$bs[$$bs $$bs ]*//g"`;; \ esac; \ fi; \ skip_next=no; \ strip_trailopt () \ { \ flg=`printf '%s\n' "$$flg" | sed "s/$$1.*$$//"`; \ }; \ for flg in $$sane_makeflags; do \ test $$skip_next = yes && { skip_next=no; continue; }; \ case $$flg in \ *=*|--*) continue;; \ -*I) strip_trailopt 'I'; skip_next=yes;; \ -*I?*) strip_trailopt 'I';; \ -*O) strip_trailopt 'O'; skip_next=yes;; \ -*O?*) strip_trailopt 'O';; \ -*l) strip_trailopt 'l'; skip_next=yes;; \ -*l?*) strip_trailopt 'l';; \ -[dEDm]) skip_next=yes;; \ -[JT]) skip_next=yes;; \ esac; \ case $$flg in \ *$$target_option*) has_opt=yes; break;; \ esac; \ done; \ test $$has_opt = yes am__make_dryrun = (target_option=n; $(am__make_running_with_option)) am__make_keepgoing = (target_option=k; $(am__make_running_with_option)) pkgdatadir = $(datadir)/@PACKAGE@ pkgincludedir = $(includedir)/@PACKAGE@ pkglibdir = $(libdir)/@PACKAGE@ pkglibexecdir = $(libexecdir)/@PACKAGE@ am__cd = CDPATH="$${ZSH_VERSION+.}$(PATH_SEPARATOR)" && cd install_sh_DATA = $(install_sh) -c -m 644 install_sh_PROGRAM = $(install_sh) -c install_sh_SCRIPT = $(install_sh) -c INSTALL_HEADER = $(INSTALL_DATA) transform = $(program_transform_name) NORMAL_INSTALL = : PRE_INSTALL = : POST_INSTALL = : NORMAL_UNINSTALL = : PRE_UNINSTALL = : POST_UNINSTALL = : build_triplet = @build@ host_triplet = @host@ bin_PROGRAMS = xrdp-keygen$(EXEEXT) subdir = keygen ACLOCAL_M4 = $(top_srcdir)/aclocal.m4 am__aclocal_m4_deps = $(top_srcdir)/m4/ax_append_compile_flags.m4 \ $(top_srcdir)/m4/ax_append_flag.m4 \ $(top_srcdir)/m4/ax_cflags_warn_all.m4 \ $(top_srcdir)/m4/ax_check_compile_flag.m4 \ $(top_srcdir)/m4/ax_gcc_func_attribute.m4 \ $(top_srcdir)/m4/ax_require_defined.m4 \ $(top_srcdir)/m4/ax_type_socklen_t.m4 \ $(top_srcdir)/m4/libtool.m4 $(top_srcdir)/m4/ltoptions.m4 \ $(top_srcdir)/m4/ltsugar.m4 $(top_srcdir)/m4/ltversion.m4 \ $(top_srcdir)/m4/lt~obsolete.m4 $(top_srcdir)/m4/pkg.m4 \ $(top_srcdir)/configure.ac am__configure_deps = $(am__aclocal_m4_deps) $(CONFIGURE_DEPENDENCIES) \ $(ACLOCAL_M4) DIST_COMMON = $(srcdir)/Makefile.am $(am__DIST_COMMON) mkinstalldirs = $(install_sh) -d CONFIG_HEADER = $(top_builddir)/config_ac.h CONFIG_CLEAN_FILES = CONFIG_CLEAN_VPATH_FILES = am__installdirs = "$(DESTDIR)$(bindir)" PROGRAMS = $(bin_PROGRAMS) am_xrdp_keygen_OBJECTS = keygen.$(OBJEXT) xrdp_keygen_OBJECTS = $(am_xrdp_keygen_OBJECTS) xrdp_keygen_DEPENDENCIES = $(top_builddir)/common/libcommon.la AM_V_lt = $(am__v_lt_@AM_V@) am__v_lt_ = $(am__v_lt_@AM_DEFAULT_V@) am__v_lt_0 = --silent am__v_lt_1 = AM_V_P = $(am__v_P_@AM_V@) am__v_P_ = $(am__v_P_@AM_DEFAULT_V@) am__v_P_0 = false am__v_P_1 = : AM_V_GEN = $(am__v_GEN_@AM_V@) am__v_GEN_ = $(am__v_GEN_@AM_DEFAULT_V@) am__v_GEN_0 = @echo " GEN " $@; am__v_GEN_1 = AM_V_at = $(am__v_at_@AM_V@) am__v_at_ = $(am__v_at_@AM_DEFAULT_V@) am__v_at_0 = @ am__v_at_1 = DEFAULT_INCLUDES = -I.@am__isrc@ -I$(top_builddir) depcomp = $(SHELL) $(top_srcdir)/depcomp am__depfiles_maybe = depfiles am__mv = mv -f COMPILE = $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) \ $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) LTCOMPILE = $(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) \ $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) \ $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) \ $(AM_CFLAGS) $(CFLAGS) AM_V_CC = $(am__v_CC_@AM_V@) am__v_CC_ = $(am__v_CC_@AM_DEFAULT_V@) am__v_CC_0 = @echo " CC " $@; am__v_CC_1 = CCLD = $(CC) LINK = $(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) \ $(LIBTOOLFLAGS) --mode=link $(CCLD) $(AM_CFLAGS) $(CFLAGS) \ $(AM_LDFLAGS) $(LDFLAGS) -o $@ AM_V_CCLD = $(am__v_CCLD_@AM_V@) am__v_CCLD_ = $(am__v_CCLD_@AM_DEFAULT_V@) am__v_CCLD_0 = @echo " CCLD " $@; am__v_CCLD_1 = SOURCES = $(xrdp_keygen_SOURCES) DIST_SOURCES = $(xrdp_keygen_SOURCES) am__can_run_installinfo = \ case $$AM_UPDATE_INFO_DIR in \ n|no|NO) false;; \ *) (install-info --version) >/dev/null 2>&1;; \ esac am__tagged_files = $(HEADERS) $(SOURCES) $(TAGS_FILES) $(LISP) # Read a list of newline-separated strings from the standard input, # and print each of them once, without duplicates. Input order is # *not* preserved. am__uniquify_input = $(AWK) '\ BEGIN { nonempty = 0; } \ { items[$$0] = 1; nonempty = 1; } \ END { if (nonempty) { for (i in items) print i; }; } \ ' # Make sure the list of sources is unique. This is necessary because, # e.g., the same source file might be shared among _SOURCES variables # for different programs/libraries. am__define_uniq_tagged_files = \ list='$(am__tagged_files)'; \ unique=`for i in $$list; do \ if test -f "$$i"; then echo $$i; else echo $(srcdir)/$$i; fi; \ done | $(am__uniquify_input)` ETAGS = etags CTAGS = ctags am__DIST_COMMON = $(srcdir)/Makefile.in $(top_srcdir)/depcomp DISTFILES = $(DIST_COMMON) $(DIST_SOURCES) $(TEXINFOS) $(EXTRA_DIST) ACLOCAL = @ACLOCAL@ AMTAR = @AMTAR@ AM_DEFAULT_VERBOSITY = @AM_DEFAULT_VERBOSITY@ AR = @AR@ AUTOCONF = @AUTOCONF@ AUTOHEADER = @AUTOHEADER@ AUTOMAKE = @AUTOMAKE@ AWK = @AWK@ CC = @CC@ CCDEPMODE = @CCDEPMODE@ CFLAGS = @CFLAGS@ CPP = @CPP@ CPPFLAGS = @CPPFLAGS@ CYGPATH_W = @CYGPATH_W@ DEFS = @DEFS@ DEPDIR = @DEPDIR@ DLLTOOL = @DLLTOOL@ DLOPEN_LIBS = @DLOPEN_LIBS@ DSYMUTIL = @DSYMUTIL@ DUMPBIN = @DUMPBIN@ ECHO_C = @ECHO_C@ ECHO_N = @ECHO_N@ ECHO_T = @ECHO_T@ EGREP = @EGREP@ EXEEXT = @EXEEXT@ FDKAAC_CFLAGS = @FDKAAC_CFLAGS@ FDKAAC_LIBS = @FDKAAC_LIBS@ FGREP = @FGREP@ FREERDP_CFLAGS = @FREERDP_CFLAGS@ FREERDP_LIBS = @FREERDP_LIBS@ FUSE_CFLAGS = @FUSE_CFLAGS@ FUSE_LIBS = @FUSE_LIBS@ GREP = @GREP@ INSTALL = @INSTALL@ INSTALL_DATA = @INSTALL_DATA@ INSTALL_PROGRAM = @INSTALL_PROGRAM@ INSTALL_SCRIPT = @INSTALL_SCRIPT@ INSTALL_STRIP_PROGRAM = @INSTALL_STRIP_PROGRAM@ LD = @LD@ LDFLAGS = @LDFLAGS@ LIBOBJS = @LIBOBJS@ LIBS = @LIBS@ LIBTOOL = @LIBTOOL@ LIPO = @LIPO@ LN_S = @LN_S@ LTLIBOBJS = @LTLIBOBJS@ LT_SYS_LIBRARY_PATH = @LT_SYS_LIBRARY_PATH@ MAKEINFO = @MAKEINFO@ MANIFEST_TOOL = @MANIFEST_TOOL@ MKDIR_P = @MKDIR_P@ NM = @NM@ NMEDIT = @NMEDIT@ OBJDUMP = @OBJDUMP@ OBJEXT = @OBJEXT@ OPENSSL = @OPENSSL@ OPENSSL_CFLAGS = @OPENSSL_CFLAGS@ OPENSSL_LIBS = @OPENSSL_LIBS@ OTOOL = @OTOOL@ OTOOL64 = @OTOOL64@ PACKAGE = @PACKAGE@ PACKAGE_BUGREPORT = @PACKAGE_BUGREPORT@ PACKAGE_NAME = @PACKAGE_NAME@ PACKAGE_STRING = @PACKAGE_STRING@ PACKAGE_TARNAME = @PACKAGE_TARNAME@ PACKAGE_URL = @PACKAGE_URL@ PACKAGE_VERSION = @PACKAGE_VERSION@ PAM_RULES = @PAM_RULES@ PATH_SEPARATOR = @PATH_SEPARATOR@ PIXMAN_CFLAGS = @PIXMAN_CFLAGS@ PIXMAN_LIBS = @PIXMAN_LIBS@ PKG_CONFIG = @PKG_CONFIG@ PKG_CONFIG_LIBDIR = @PKG_CONFIG_LIBDIR@ PKG_CONFIG_PATH = @PKG_CONFIG_PATH@ RANLIB = @RANLIB@ SED = @SED@ SET_MAKE = @SET_MAKE@ SHELL = @SHELL@ STRIP = @STRIP@ TurboJpegIncDir = @TurboJpegIncDir@ TurboJpegLibDir = @TurboJpegLibDir@ VERSION = @VERSION@ XMKMF = @XMKMF@ X_CFLAGS = @X_CFLAGS@ X_EXTRA_LIBS = @X_EXTRA_LIBS@ X_LIBS = @X_LIBS@ X_PRE_LIBS = @X_PRE_LIBS@ abs_builddir = @abs_builddir@ abs_srcdir = @abs_srcdir@ abs_top_builddir = @abs_top_builddir@ abs_top_srcdir = @abs_top_srcdir@ ac_ct_AR = @ac_ct_AR@ ac_ct_CC = @ac_ct_CC@ ac_ct_DUMPBIN = @ac_ct_DUMPBIN@ am__include = @am__include@ am__leading_dot = @am__leading_dot@ am__quote = @am__quote@ am__tar = @am__tar@ am__untar = @am__untar@ bindir = @bindir@ build = @build@ build_alias = @build_alias@ build_cpu = @build_cpu@ build_os = @build_os@ build_vendor = @build_vendor@ builddir = @builddir@ datadir = @datadir@ datarootdir = @datarootdir@ docdir = @docdir@ dvidir = @dvidir@ exec_prefix = @exec_prefix@ host = @host@ host_alias = @host_alias@ host_cpu = @host_cpu@ host_os = @host_os@ host_vendor = @host_vendor@ htmldir = @htmldir@ includedir = @includedir@ infodir = @infodir@ install_sh = @install_sh@ libdir = @libdir@ libexecdir = @libexecdir@ localedir = @localedir@ localstatedir = @localstatedir@ mandir = @mandir@ mkdir_p = @mkdir_p@ moduledir = @moduledir@ oldincludedir = @oldincludedir@ pdfdir = @pdfdir@ pkgconfigdir = @pkgconfigdir@ prefix = @prefix@ program_transform_name = @program_transform_name@ psdir = @psdir@ sbindir = @sbindir@ sharedstatedir = @sharedstatedir@ socketdir = @socketdir@ srcdir = @srcdir@ subdirs = @subdirs@ sysconfdir = @sysconfdir@ systemdsystemunitdir = @systemdsystemunitdir@ target_alias = @target_alias@ top_build_prefix = @top_build_prefix@ top_builddir = @top_builddir@ top_srcdir = @top_srcdir@ EXTRA_DIST = openssl.conf AM_CPPFLAGS = \ -DXRDP_CFG_PATH=\"${sysconfdir}/xrdp\" \ -DXRDP_SBIN_PATH=\"${sbindir}\" \ -DXRDP_SHARE_PATH=\"${datadir}/xrdp\" \ -DXRDP_PID_PATH=\"${localstatedir}/run\" \ -I$(top_srcdir)/common xrdp_keygen_SOURCES = keygen.c xrdp_keygen_LDADD = \ $(top_builddir)/common/libcommon.la xrdpsysconfdir = $(sysconfdir)/xrdp all: all-am .SUFFIXES: .SUFFIXES: .c .lo .o .obj $(srcdir)/Makefile.in: $(srcdir)/Makefile.am $(am__configure_deps) @for dep in $?; do \ case '$(am__configure_deps)' in \ *$$dep*) \ ( cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh ) \ && { if test -f $@; then exit 0; else break; fi; }; \ exit 1;; \ esac; \ done; \ echo ' cd $(top_srcdir) && $(AUTOMAKE) --foreign keygen/Makefile'; \ $(am__cd) $(top_srcdir) && \ $(AUTOMAKE) --foreign keygen/Makefile Makefile: $(srcdir)/Makefile.in $(top_builddir)/config.status @case '$?' in \ *config.status*) \ cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh;; \ *) \ echo ' cd $(top_builddir) && $(SHELL) ./config.status $(subdir)/$@ $(am__depfiles_maybe)'; \ cd $(top_builddir) && $(SHELL) ./config.status $(subdir)/$@ $(am__depfiles_maybe);; \ esac; $(top_builddir)/config.status: $(top_srcdir)/configure $(CONFIG_STATUS_DEPENDENCIES) cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh $(top_srcdir)/configure: $(am__configure_deps) cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh $(ACLOCAL_M4): $(am__aclocal_m4_deps) cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh $(am__aclocal_m4_deps): install-binPROGRAMS: $(bin_PROGRAMS) @$(NORMAL_INSTALL) @list='$(bin_PROGRAMS)'; test -n "$(bindir)" || list=; \ if test -n "$$list"; then \ echo " $(MKDIR_P) '$(DESTDIR)$(bindir)'"; \ $(MKDIR_P) "$(DESTDIR)$(bindir)" || exit 1; \ fi; \ for p in $$list; do echo "$$p $$p"; done | \ sed 's/$(EXEEXT)$$//' | \ while read p p1; do if test -f $$p \ || test -f $$p1 \ ; then echo "$$p"; echo "$$p"; else :; fi; \ done | \ sed -e 'p;s,.*/,,;n;h' \ -e 's|.*|.|' \ -e 'p;x;s,.*/,,;s/$(EXEEXT)$$//;$(transform);s/$$/$(EXEEXT)/' | \ sed 'N;N;N;s,\n, ,g' | \ $(AWK) 'BEGIN { files["."] = ""; dirs["."] = 1 } \ { d=$$3; if (dirs[d] != 1) { print "d", d; dirs[d] = 1 } \ if ($$2 == $$4) files[d] = files[d] " " $$1; \ else { print "f", $$3 "/" $$4, $$1; } } \ END { for (d in files) print "f", d, files[d] }' | \ while read type dir files; do \ if test "$$dir" = .; then dir=; else dir=/$$dir; fi; \ test -z "$$files" || { \ echo " $(INSTALL_PROGRAM_ENV) $(LIBTOOL) $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=install $(INSTALL_PROGRAM) $$files '$(DESTDIR)$(bindir)$$dir'"; \ $(INSTALL_PROGRAM_ENV) $(LIBTOOL) $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=install $(INSTALL_PROGRAM) $$files "$(DESTDIR)$(bindir)$$dir" || exit $$?; \ } \ ; done uninstall-binPROGRAMS: @$(NORMAL_UNINSTALL) @list='$(bin_PROGRAMS)'; test -n "$(bindir)" || list=; \ files=`for p in $$list; do echo "$$p"; done | \ sed -e 'h;s,^.*/,,;s/$(EXEEXT)$$//;$(transform)' \ -e 's/$$/$(EXEEXT)/' \ `; \ test -n "$$list" || exit 0; \ echo " ( cd '$(DESTDIR)$(bindir)' && rm -f" $$files ")"; \ cd "$(DESTDIR)$(bindir)" && rm -f $$files clean-binPROGRAMS: @list='$(bin_PROGRAMS)'; test -n "$$list" || exit 0; \ echo " rm -f" $$list; \ rm -f $$list || exit $$?; \ test -n "$(EXEEXT)" || exit 0; \ list=`for p in $$list; do echo "$$p"; done | sed 's/$(EXEEXT)$$//'`; \ echo " rm -f" $$list; \ rm -f $$list xrdp-keygen$(EXEEXT): $(xrdp_keygen_OBJECTS) $(xrdp_keygen_DEPENDENCIES) $(EXTRA_xrdp_keygen_DEPENDENCIES) @rm -f xrdp-keygen$(EXEEXT) $(AM_V_CCLD)$(LINK) $(xrdp_keygen_OBJECTS) $(xrdp_keygen_LDADD) $(LIBS) mostlyclean-compile: -rm -f *.$(OBJEXT) distclean-compile: -rm -f *.tab.c @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/keygen.Po@am__quote@ .c.o: @am__fastdepCC_TRUE@ $(AM_V_CC)$(COMPILE) -MT $@ -MD -MP -MF $(DEPDIR)/$*.Tpo -c -o $@ $< @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) $(DEPDIR)/$*.Tpo $(DEPDIR)/$*.Po @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='$<' object='$@' libtool=no @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(COMPILE) -c -o $@ $< .c.obj: @am__fastdepCC_TRUE@ $(AM_V_CC)$(COMPILE) -MT $@ -MD -MP -MF $(DEPDIR)/$*.Tpo -c -o $@ `$(CYGPATH_W) '$<'` @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) $(DEPDIR)/$*.Tpo $(DEPDIR)/$*.Po @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='$<' object='$@' libtool=no @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(COMPILE) -c -o $@ `$(CYGPATH_W) '$<'` .c.lo: @am__fastdepCC_TRUE@ $(AM_V_CC)$(LTCOMPILE) -MT $@ -MD -MP -MF $(DEPDIR)/$*.Tpo -c -o $@ $< @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) $(DEPDIR)/$*.Tpo $(DEPDIR)/$*.Plo @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='$<' object='$@' libtool=yes @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(LTCOMPILE) -c -o $@ $< mostlyclean-libtool: -rm -f *.lo clean-libtool: -rm -rf .libs _libs ID: $(am__tagged_files) $(am__define_uniq_tagged_files); mkid -fID $$unique tags: tags-am TAGS: tags tags-am: $(TAGS_DEPENDENCIES) $(am__tagged_files) set x; \ here=`pwd`; \ $(am__define_uniq_tagged_files); \ shift; \ if test -z "$(ETAGS_ARGS)$$*$$unique"; then :; else \ test -n "$$unique" || unique=$$empty_fix; \ if test $$# -gt 0; then \ $(ETAGS) $(ETAGSFLAGS) $(AM_ETAGSFLAGS) $(ETAGS_ARGS) \ "$$@" $$unique; \ else \ $(ETAGS) $(ETAGSFLAGS) $(AM_ETAGSFLAGS) $(ETAGS_ARGS) \ $$unique; \ fi; \ fi ctags: ctags-am CTAGS: ctags ctags-am: $(TAGS_DEPENDENCIES) $(am__tagged_files) $(am__define_uniq_tagged_files); \ test -z "$(CTAGS_ARGS)$$unique" \ || $(CTAGS) $(CTAGSFLAGS) $(AM_CTAGSFLAGS) $(CTAGS_ARGS) \ $$unique GTAGS: here=`$(am__cd) $(top_builddir) && pwd` \ && $(am__cd) $(top_srcdir) \ && gtags -i $(GTAGS_ARGS) "$$here" cscopelist: cscopelist-am cscopelist-am: $(am__tagged_files) list='$(am__tagged_files)'; \ case "$(srcdir)" in \ [\\/]* | ?:[\\/]*) sdir="$(srcdir)" ;; \ *) sdir=$(subdir)/$(srcdir) ;; \ esac; \ for i in $$list; do \ if test -f "$$i"; then \ echo "$(subdir)/$$i"; \ else \ echo "$$sdir/$$i"; \ fi; \ done >> $(top_builddir)/cscope.files distclean-tags: -rm -f TAGS ID GTAGS GRTAGS GSYMS GPATH tags distdir: $(DISTFILES) @srcdirstrip=`echo "$(srcdir)" | sed 's/[].[^$$\\*]/\\\\&/g'`; \ topsrcdirstrip=`echo "$(top_srcdir)" | sed 's/[].[^$$\\*]/\\\\&/g'`; \ list='$(DISTFILES)'; \ dist_files=`for file in $$list; do echo $$file; done | \ sed -e "s|^$$srcdirstrip/||;t" \ -e "s|^$$topsrcdirstrip/|$(top_builddir)/|;t"`; \ case $$dist_files in \ */*) $(MKDIR_P) `echo "$$dist_files" | \ sed '/\//!d;s|^|$(distdir)/|;s,/[^/]*$$,,' | \ sort -u` ;; \ esac; \ for file in $$dist_files; do \ if test -f $$file || test -d $$file; then d=.; else d=$(srcdir); fi; \ if test -d $$d/$$file; then \ dir=`echo "/$$file" | sed -e 's,/[^/]*$$,,'`; \ if test -d "$(distdir)/$$file"; then \ find "$(distdir)/$$file" -type d ! -perm -700 -exec chmod u+rwx {} \;; \ fi; \ if test -d $(srcdir)/$$file && test $$d != $(srcdir); then \ cp -fpR $(srcdir)/$$file "$(distdir)$$dir" || exit 1; \ find "$(distdir)/$$file" -type d ! -perm -700 -exec chmod u+rwx {} \;; \ fi; \ cp -fpR $$d/$$file "$(distdir)$$dir" || exit 1; \ else \ test -f "$(distdir)/$$file" \ || cp -p $$d/$$file "$(distdir)/$$file" \ || exit 1; \ fi; \ done check-am: all-am check: check-am all-am: Makefile $(PROGRAMS) installdirs: for dir in "$(DESTDIR)$(bindir)"; do \ test -z "$$dir" || $(MKDIR_P) "$$dir"; \ done install: install-am install-exec: install-exec-am install-data: install-data-am uninstall: uninstall-am install-am: all-am @$(MAKE) $(AM_MAKEFLAGS) install-exec-am install-data-am installcheck: installcheck-am install-strip: if test -z '$(STRIP)'; then \ $(MAKE) $(AM_MAKEFLAGS) INSTALL_PROGRAM="$(INSTALL_STRIP_PROGRAM)" \ install_sh_PROGRAM="$(INSTALL_STRIP_PROGRAM)" INSTALL_STRIP_FLAG=-s \ install; \ else \ $(MAKE) $(AM_MAKEFLAGS) INSTALL_PROGRAM="$(INSTALL_STRIP_PROGRAM)" \ install_sh_PROGRAM="$(INSTALL_STRIP_PROGRAM)" INSTALL_STRIP_FLAG=-s \ "INSTALL_PROGRAM_ENV=STRIPPROG='$(STRIP)'" install; \ fi mostlyclean-generic: clean-generic: distclean-generic: -test -z "$(CONFIG_CLEAN_FILES)" || rm -f $(CONFIG_CLEAN_FILES) -test . = "$(srcdir)" || test -z "$(CONFIG_CLEAN_VPATH_FILES)" || rm -f $(CONFIG_CLEAN_VPATH_FILES) maintainer-clean-generic: @echo "This command is intended for maintainers to use" @echo "it deletes files that may require special tools to rebuild." clean: clean-am clean-am: clean-binPROGRAMS clean-generic clean-libtool mostlyclean-am distclean: distclean-am -rm -rf ./$(DEPDIR) -rm -f Makefile distclean-am: clean-am distclean-compile distclean-generic \ distclean-tags dvi: dvi-am dvi-am: html: html-am html-am: info: info-am info-am: install-data-am: @$(NORMAL_INSTALL) $(MAKE) $(AM_MAKEFLAGS) install-data-hook install-dvi: install-dvi-am install-dvi-am: install-exec-am: install-binPROGRAMS install-html: install-html-am install-html-am: install-info: install-info-am install-info-am: install-man: install-pdf: install-pdf-am install-pdf-am: install-ps: install-ps-am install-ps-am: installcheck-am: maintainer-clean: maintainer-clean-am -rm -rf ./$(DEPDIR) -rm -f Makefile maintainer-clean-am: distclean-am maintainer-clean-generic mostlyclean: mostlyclean-am mostlyclean-am: mostlyclean-compile mostlyclean-generic \ mostlyclean-libtool pdf: pdf-am pdf-am: ps: ps-am ps-am: uninstall-am: uninstall-binPROGRAMS @$(NORMAL_INSTALL) $(MAKE) $(AM_MAKEFLAGS) uninstall-hook .MAKE: install-am install-data-am install-strip uninstall-am .PHONY: CTAGS GTAGS TAGS all all-am check check-am clean \ clean-binPROGRAMS clean-generic clean-libtool cscopelist-am \ ctags ctags-am distclean distclean-compile distclean-generic \ distclean-libtool distclean-tags distdir dvi dvi-am html \ html-am info info-am install install-am install-binPROGRAMS \ install-data install-data-am install-data-hook install-dvi \ install-dvi-am install-exec install-exec-am install-html \ install-html-am install-info install-info-am install-man \ install-pdf install-pdf-am install-ps install-ps-am \ install-strip installcheck installcheck-am installdirs \ maintainer-clean maintainer-clean-generic mostlyclean \ mostlyclean-compile mostlyclean-generic mostlyclean-libtool \ pdf pdf-am ps ps-am tags tags-am uninstall uninstall-am \ uninstall-binPROGRAMS uninstall-hook .PRECIOUS: Makefile install-data-hook: umask 077 && \ if [ ! -f $(DESTDIR)$(xrdpsysconfdir)/rsakeys.ini ]; then \ ./xrdp-keygen xrdp $(DESTDIR)$(xrdpsysconfdir)/rsakeys.ini; \ fi && \ if [ ! -f $(DESTDIR)$(xrdpsysconfdir)/cert.pem ]; then \ $(OPENSSL) req -x509 -newkey rsa:2048 -sha256 -nodes \ -keyout $(DESTDIR)$(xrdpsysconfdir)/key.pem -out \ $(DESTDIR)$(xrdpsysconfdir)/cert.pem -days 365 \ -subj /C=US/ST=CA/L=Sunnyvale/O=xrdp/CN=www.xrdp.org \ -config $(srcdir)/openssl.conf; \ fi uninstall-hook: rm -f $(DESTDIR)$(xrdpsysconfdir)/rsakeys.ini rm -f $(DESTDIR)$(xrdpsysconfdir)/cert.pem rm -f $(DESTDIR)$(xrdpsysconfdir)/key.pem # Tell versions [3.59,3.63) of GNU make to not export all variables. # Otherwise a system limit (for SysV at least) may be exceeded. .NOEXPORT: xrdp-0.9.5/keygen/openssl.conf000644 001751 001751 00000002074 13133557325 016250 0ustar00metameta000000 000000 [req] distinguished_name = req_distinguished_name # The extensions to add to the self signed cert x509_extensions = v3_ca [req_distinguished_name] [v3_ca] # Extensions for a typical CA - PKIX recommendation. subjectKeyIdentifier = hash authorityKeyIdentifier = keyid:always, issuer # This is what PKIX recommends but some broken software chokes on critical # extensions. #basicConstraints = critical, CA:true # So we do this instead. basicConstraints = CA:true # Key usage: this is typical for a CA certificate. However since it will # prevent it being used as an test self-signed certificate it is best # left out by default. #keyUsage = cRLSign, keyCertSign # Some might want this also #nsCertType = sslCA, emailCA # Include email address in subject alt name: another PKIX recommendation #subjectAltName = email:copy # Copy issuer details #issuerAltName = issuer:copy # DER hex encoding of an extension: experts only! #obj = DER:02:03 # Where 'obj' is a standard or added object # You can even override a supported extension: #basicConstraints = critical, DER:30:03:01:01:FF xrdp-0.9.5/keygen/keygen.c000644 001751 001751 00000046032 13174271344 015345 0ustar00metameta000000 000000 /** * xrdp: A Remote Desktop Protocol server. * * Copyright (C) Jay Sorg 2004-2014 * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. * * rsa key generator for xrdp */ /* references: http://www.securiteam.com/windowsntfocus/5EP010KG0G.html */ #if defined(HAVE_CONFIG_H) #include #endif #include "os_calls.h" #include "ssl_calls.h" #include "arch.h" #include "list.h" #include "file.h" /* this is the signature size in bytes */ #define TSSK_KEY_LENGTH 64 /* default to 2048 bit key size, can set changed, set */ static int g_key_size_bits = 2048; static tui8 g_exponent[4] = { 0x01, 0x00, 0x01, 0x00 }; /* 4 bytes public exponent */ static tui8 g_ppk_e[4] = { 0x5B, 0x7B, 0x88, 0xC0 }; /* 64 byte modulus */ static tui8 g_ppk_n[72] = /* 64 bytes + 8 bytes pad */ { 0x3D, 0x3A, 0x5E, 0xBD, 0x72, 0x43, 0x3E, 0xC9, 0x4D, 0xBB, 0xC1, 0x1E, 0x4A, 0xBA, 0x5F, 0xCB, 0x3E, 0x88, 0x20, 0x87, 0xEF, 0xF5, 0xC1, 0xE2, 0xD7, 0xB7, 0x6B, 0x9A, 0xF2, 0x52, 0x45, 0x95, 0xCE, 0x63, 0x65, 0x6B, 0x58, 0x3A, 0xFE, 0xEF, 0x7C, 0xE7, 0xBF, 0xFE, 0x3D, 0xF6, 0x5C, 0x7D, 0x6C, 0x5E, 0x06, 0x09, 0x1A, 0xF5, 0x61, 0xBB, 0x20, 0x93, 0x09, 0x5F, 0x05, 0x6D, 0xEA, 0x87, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }; /* 64 bytes private exponent */ static tui8 g_ppk_d[108] = /* 64 bytes + 44 bytes pad */ { 0x87, 0xA7, 0x19, 0x32, 0xDA, 0x11, 0x87, 0x55, 0x58, 0x00, 0x16, 0x16, 0x25, 0x65, 0x68, 0xF8, 0x24, 0x3E, 0xE6, 0xFA, 0xE9, 0x67, 0x49, 0x94, 0xCF, 0x92, 0xCC, 0x33, 0x99, 0xE8, 0x08, 0x60, 0x17, 0x9A, 0x12, 0x9F, 0x24, 0xDD, 0xB1, 0x24, 0x99, 0xC7, 0x3A, 0xB8, 0x0A, 0x7B, 0x0D, 0xDD, 0x35, 0x07, 0x79, 0x17, 0x0B, 0x51, 0x9B, 0xB3, 0xC7, 0x10, 0x01, 0x13, 0xE7, 0x3F, 0xF3, 0x5F, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }; /* 512 bit proprietary certificate dwVersion 0 4 bytes always 0x00000001 dwSigAlgId 4 4 bytes always 0x00000001 dwKeyAlgId 8 4 bytes always 0x00000001 wPublicKeyBlobType 12 2 bytes always 0x0006 wPublicKeyBlobLen 14 2 bytes 0x005C 92 bytes magic 16 4 bytes always 0x31415352 keylen 20 4 bytes 0x0048 72 bytes bitlen 24 4 bytes 0x0200 512 bits datalen 28 4 bytes 0x003F 63 bytes pubExp 32 4 bytes 0x00010001 modulus 36 72 bytes wSignatureBlobType 108 2 bytes always 0x0008 wSignatureBlobLen 110 2 bytes 0x0048 72 bytes SignatureBlob 112 72 bytes */ static tui8 g_testkey512[184] = /* 512 bit test key */ { 0x01, 0x00, 0x00, 0x00, 0x01, 0x00, 0x00, 0x00, /* 0 */ 0x01, 0x00, 0x00, 0x00, 0x06, 0x00, 0x5c, 0x00, 0x52, 0x53, 0x41, 0x31, 0x48, 0x00, 0x00, 0x00, 0x00, 0x02, 0x00, 0x00, 0x3f, 0x00, 0x00, 0x00, 0x01, 0x00, 0x01, 0x00, 0x79, 0x6f, 0xb4, 0xdf, /* 32 */ 0xa6, 0x95, 0xb9, 0xa9, 0x61, 0xe3, 0xc4, 0x5e, 0xff, 0x6b, 0xd8, 0x81, 0x8a, 0x12, 0x4a, 0x93, 0x42, 0x97, 0x18, 0x93, 0xac, 0xd1, 0x3a, 0x38, 0x3c, 0x68, 0x50, 0x19, 0x31, 0xb6, 0x84, 0x51, /* 64 */ 0x79, 0xfb, 0x1c, 0xe7, 0xe3, 0x99, 0x20, 0xc7, 0x84, 0xdf, 0xd1, 0xaa, 0xb5, 0x15, 0xef, 0x47, 0x7e, 0xfc, 0x88, 0xeb, 0x29, 0xc3, 0x27, 0x5a, 0x35, 0xf8, 0xfd, 0xaa, 0x00, 0x00, 0x00, 0x00, /* 96 */ 0x00, 0x00, 0x00, 0x00, 0x08, 0x00, 0x48, 0x00, 0x32, 0x3b, 0xde, 0x6f, 0x18, 0x97, 0x1e, 0xc3, 0x6b, 0x2b, 0x2d, 0xe4, 0xfc, 0x2d, 0xa2, 0x8e, 0x32, 0x3c, 0xf3, 0x1b, 0x24, 0x90, 0x57, 0x4d, /* 128 */ 0x8e, 0xe4, 0x69, 0xfc, 0x16, 0x8d, 0x41, 0x92, 0x78, 0xc7, 0x9c, 0xb4, 0x26, 0xff, 0xe8, 0x3e, 0xa1, 0x8a, 0xf5, 0x57, 0xc0, 0x7f, 0x3e, 0x21, 0x17, 0x32, 0x30, 0x6f, 0x79, 0xe1, 0x36, 0xcd, /* 160 */ 0xb6, 0x8e, 0xbe, 0x57, 0x57, 0xd2, 0xa9, 0x36, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }; /* 2048 bit proprietary certificate dwVersion 0 4 bytes always 0x00000001 dwSigAlgId 4 4 bytes always 0x00000001 dwKeyAlgId 8 4 bytes always 0x00000001 wPublicKeyBlobType 12 2 bytes always 0x0006 wPublicKeyBlobLen 14 2 bytes 0x011C 284 bytes magic 16 4 bytes always 0x31415352 keylen 20 4 bytes 0x0108 264 bytes bitlen 24 4 bytes 0x0800 2048 bits datalen 28 4 bytes 0x00FF 255 bytes pubExp 32 4 bytes 0x00010001 modulus 36 264 bytes wSignatureBlobType 300 2 bytes always 0x0008 wSignatureBlobLen 302 2 bytes 0x0048 72 bytes SignatureBlob 304 72 bytes */ static tui8 g_testkey2048[376] = /* 2048 bit test key */ { 0x01, 0x00, 0x00, 0x00, 0x01, 0x00, 0x00, 0x00, /* 0 */ 0x01, 0x00, 0x00, 0x00, 0x06, 0x00, 0x1c, 0x01, 0x52, 0x53, 0x41, 0x31, 0x08, 0x01, 0x00, 0x00, 0x00, 0x08, 0x00, 0x00, 0xff, 0x00, 0x00, 0x00, 0x01, 0x00, 0x01, 0x00, 0x13, 0x77, 0x6d, 0xd8, /* 32 */ 0x7b, 0x6e, 0x6f, 0xb4, 0x27, 0x6d, 0x70, 0x3a, 0x97, 0x5f, 0xcb, 0x50, 0x9b, 0x13, 0x6b, 0xc7, 0xba, 0xdf, 0x73, 0x54, 0x17, 0x35, 0xf0, 0x09, 0x9e, 0x9d, 0x0b, 0x6a, 0x2c, 0x9f, 0xd1, 0x0c, /* 64 */ 0xc6, 0x47, 0x83, 0xde, 0xca, 0x90, 0x20, 0xac, 0x70, 0x63, 0x9b, 0xb7, 0x49, 0x07, 0x0b, 0xf5, 0xf2, 0x38, 0x2a, 0x40, 0xff, 0xf1, 0xba, 0x97, 0x79, 0x3e, 0xd4, 0xd1, 0xf3, 0x41, 0x0f, 0x91, /* 96 */ 0xfe, 0x1a, 0x86, 0xf4, 0x1b, 0xef, 0xcc, 0x29, 0xa3, 0x35, 0x6f, 0x60, 0xfa, 0x98, 0x53, 0x51, 0x80, 0x57, 0x15, 0x2f, 0xe1, 0x8b, 0xd7, 0x86, 0x15, 0x2d, 0xb5, 0xec, 0x7a, 0xdd, 0xc5, 0x1d, /* 128 */ 0x1b, 0x88, 0x53, 0x67, 0x86, 0xe1, 0x6e, 0xcd, 0x4e, 0x2e, 0xfd, 0xd2, 0x49, 0x04, 0xfb, 0x1d, 0x95, 0xf0, 0xe9, 0x7f, 0x97, 0xa3, 0x1b, 0xb2, 0x92, 0x2e, 0x62, 0x2a, 0x96, 0xd4, 0xea, 0x18, /* 160 */ 0x8e, 0x99, 0x41, 0xea, 0x83, 0xb5, 0xf1, 0x0e, 0xea, 0x53, 0x70, 0x99, 0xd7, 0x9e, 0x0c, 0x65, 0x2b, 0xf4, 0xdc, 0x0e, 0xe7, 0x9e, 0xce, 0x04, 0x25, 0x01, 0x88, 0xc4, 0xc1, 0xd2, 0xa4, 0x18, /* 192 */ 0xc2, 0x8a, 0x52, 0x0f, 0x01, 0xb2, 0x71, 0x30, 0x44, 0x3f, 0x5b, 0x11, 0x2e, 0xe7, 0x53, 0xa0, 0xc8, 0x1f, 0x77, 0xaf, 0xb5, 0xbb, 0xaf, 0x12, 0xe8, 0x19, 0x0c, 0xf6, 0x1f, 0xa8, 0x3e, 0x11, /* 224 */ 0x34, 0xe4, 0xac, 0x1c, 0x1c, 0x00, 0xbb, 0xb9, 0x2f, 0xbb, 0x81, 0x76, 0x4e, 0x46, 0xda, 0x73, 0x00, 0x82, 0x71, 0xa4, 0x62, 0xc3, 0xd4, 0x3f, 0xda, 0x34, 0x54, 0x27, 0xe3, 0xd0, 0x3a, 0x73, /* 256 */ 0x2f, 0x99, 0xc4, 0x91, 0x56, 0x12, 0x98, 0xa8, 0x3b, 0x8d, 0x61, 0x83, 0x62, 0xb7, 0x20, 0x61, 0x4d, 0xc9, 0x41, 0xd1, 0x40, 0x02, 0x11, 0x4b, 0x63, 0x46, 0xc7, 0xc1, 0x00, 0x00, 0x00, 0x00, /* 288 */ 0x00, 0x00, 0x00, 0x00, 0x08, 0x00, 0x48, 0x00, 0x00, 0x50, 0xb7, 0x75, 0xf3, 0x77, 0x99, 0xb2, 0xd3, 0xdd, 0xcd, 0x83, 0x6e, 0xdb, 0x0a, 0x29, 0x88, 0x05, 0xb5, 0x8a, 0x49, 0xd5, 0xa8, 0x5a, /* 320 */ 0xc3, 0xb7, 0x18, 0xc2, 0x3c, 0x1e, 0xde, 0xd3, 0x8f, 0xdd, 0x21, 0x27, 0x84, 0xa0, 0xc8, 0x8d, 0x65, 0xce, 0x5d, 0x3d, 0x46, 0x65, 0x88, 0xfc, 0x35, 0x0a, 0x04, 0xa0, 0xda, 0xc1, 0xab, 0xbf, /* 352 */ 0xcd, 0xf1, 0x7e, 0x71, 0x7b, 0xf8, 0x4a, 0x78, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }; /*****************************************************************************/ static int out_params(void) { g_writeln("%s", ""); g_writeln("xrdp rsa key gen utility examples"); g_writeln(" xrdp-keygen xrdp ['path and file name' | auto] [512 or 2048]"); g_writeln(" xrdp-keygen test"); g_writeln("%s", ""); return 0; } /*****************************************************************************/ /* this is the special key signing algorithm */ static int sign_key(const char *e_data, int e_len, const char *n_data, int n_len, char *sign_data, int sign_len) { char *key; char *md5_final; void *md5; if ((e_len != 4) || ((n_len != 64) && (n_len != 256)) || (sign_len != 64)) { return 1; } if (n_len == 64) { key = (char *)g_malloc(184, 0); md5_final = (char *)g_malloc(64, 0); md5 = ssl_md5_info_create(); /* copy the test key */ g_memcpy(key, g_testkey512, 184); /* replace e and n */ g_memcpy(key + 32, e_data, e_len); g_memcpy(key + 36, n_data, n_len); ssl_md5_clear(md5); /* the first 108 bytes */ ssl_md5_transform(md5, key, 108); /* set the whole thing with 0xff */ g_memset(md5_final, 0xff, 64); /* digest 16 bytes */ ssl_md5_complete(md5, md5_final); /* set non 0xff array items */ md5_final[16] = 0; md5_final[62] = 1; md5_final[63] = 0; /* encrypt */ ssl_mod_exp(sign_data, sign_len, md5_final, 64, (char *)g_ppk_n, 64, (char *)g_ppk_d, 64); /* cleanup */ ssl_md5_info_delete(md5); g_free(key); g_free(md5_final); } else if (n_len == 256) { key = (char *)g_malloc(376, 0); md5_final = (char *)g_malloc(64, 0); md5 = ssl_md5_info_create(); /* copy the test key */ g_memcpy(key, g_testkey2048, 376); /* replace e and n */ g_memcpy(key + 32, e_data, e_len); g_memcpy(key + 36, n_data, n_len); ssl_md5_clear(md5); /* the first 300 bytes */ ssl_md5_transform(md5, key, 300); /* set the whole thing with 0xff */ g_memset(md5_final, 0xff, 64); /* digest 16 bytes */ ssl_md5_complete(md5, md5_final); /* set non 0xff array items */ md5_final[16] = 0; md5_final[62] = 1; md5_final[63] = 0; /* encrypt */ ssl_mod_exp(sign_data, sign_len, md5_final, 64, (char *)g_ppk_n, 64, (char *)g_ppk_d, 64); /* cleanup */ ssl_md5_info_delete(md5); g_free(key); g_free(md5_final); } return 0; } /*****************************************************************************/ static int write_out_line(int fd, const char *name, const char *data, int len) { int max; int error; int index; int data_item; int buf_pos; char *buf; char *text; text = (char *)g_malloc(256, 0); max = len; max = max * 10; buf_pos = g_strlen(name); max = max + buf_pos + 16; buf = (char *)g_malloc(max, 0); g_strncpy(buf, name, max - 1); buf[buf_pos] = '='; buf_pos++; for (index = 0; index < len; index++) { data_item = (tui8)(data[index]); g_snprintf(text, 255, "0x%2.2x", data_item); if (index != 0) { buf[buf_pos] = ','; buf_pos++; } buf[buf_pos] = text[0]; buf_pos++; buf[buf_pos] = text[1]; buf_pos++; buf[buf_pos] = text[2]; buf_pos++; buf[buf_pos] = text[3]; buf_pos++; } buf[buf_pos] = '\n'; buf_pos++; buf[buf_pos] = 0; error = g_file_write(fd, buf, buf_pos) == -1; g_free(buf); g_free(text); return error; } /*****************************************************************************/ static int save_all(const char *e_data, int e_len, const char *n_data, int n_len, const char *d_data, int d_len, const char *sign_data, int sign_len, const char *path_and_file_name) { int fd; char filename[256]; if (path_and_file_name == 0) { g_strncpy(filename, "rsakeys.ini", 255); } else { g_strncpy(filename, path_and_file_name, 255); } g_writeln("saving to %s", filename); g_writeln("%s", ""); if (g_file_exist(filename)) { if (g_file_delete(filename) == 0) { g_writeln("problem deleting %s, maybe no rights", filename); return 1; } } fd = g_file_open(filename); if (fd != -1) { if (g_file_write(fd, "[keys]\n", 7) == -1) { g_writeln("problem writing to %s, maybe no rights", filename); g_file_close(fd); return 1; } write_out_line(fd, "pub_exp", e_data, e_len); write_out_line(fd, "pub_mod", n_data, n_len); write_out_line(fd, "pub_sig", sign_data, sign_len); write_out_line(fd, "pri_exp", d_data, d_len); } else { g_writeln("problem opening %s, maybe no rights", filename); return 1; } g_file_close(fd); return 0; } /*****************************************************************************/ static int key_gen(const char *path_and_file_name) { char *e_data; char *n_data; char *d_data; char *sign_data; int e_len; int n_len; int d_len; int sign_len; int error; e_data = (char *)g_exponent; n_data = (char *)g_malloc(256, 0); d_data = (char *)g_malloc(256, 0); sign_data = (char *)g_malloc(64, 0); e_len = 4; n_len = g_key_size_bits / 8; d_len = n_len; sign_len = 64; error = 0; g_writeln("%s", ""); g_writeln("Generating %d bit rsa key...", g_key_size_bits); g_writeln("%s", ""); if (error == 0) { error = ssl_gen_key_xrdp1(g_key_size_bits, e_data, e_len, n_data, n_len, d_data, d_len); if (error != 0) { g_writeln("error %d in key_gen, ssl_gen_key_xrdp1", error); } } if (error == 0) { g_writeln("ssl_gen_key_xrdp1 ok"); g_writeln("%s", ""); error = sign_key(e_data, e_len, n_data, n_len, sign_data, sign_len); if (error != 0) { g_writeln("error %d in key_gen, sign_key", error); } } if (error == 0) { error = save_all(e_data, e_len, n_data, n_len, d_data, d_len, sign_data, sign_len, path_and_file_name); if (error != 0) { g_writeln("error %d in key_gen, save_all", error); } } g_free(n_data); g_free(d_data); g_free(sign_data); return error; } /*****************************************************************************/ static int key_gen_auto(void) { return key_gen("/etc/xrdp/rsakeys.ini"); } /*****************************************************************************/ static int key_test512(void) { char *md5_final; char *sig; void *md5; md5_final = (char *)g_malloc(64, 0); sig = (char *)g_malloc(64, 0); md5 = ssl_md5_info_create(); g_writeln("original key is:"); g_hexdump((char *)g_testkey512, 184); g_writeln("original exponent is:"); g_hexdump((char *)g_testkey512 + 32, 4); g_writeln("original modulus is:"); g_hexdump((char *)g_testkey512 + 36, 64); g_writeln("original signature is:"); g_hexdump((char *)g_testkey512 + 112, 64); ssl_md5_clear(md5); ssl_md5_transform(md5, (char *)g_testkey512, 108); g_memset(md5_final, 0xff, 64); ssl_md5_complete(md5, md5_final); g_writeln("md5 hash of first 108 bytes of this key is:"); g_hexdump(md5_final, 16); md5_final[16] = 0; md5_final[62] = 1; md5_final[63] = 0; ssl_mod_exp(sig, 64, md5_final, 64, (char *)g_ppk_n, 64, (char *)g_ppk_d, 64); g_writeln("produced signature(this should match original " "signature above) is:"); g_hexdump(sig, 64); g_memset(md5_final, 0, 64); ssl_mod_exp(md5_final, 64, (char *)g_testkey512 + 112, 64, (char *)g_ppk_n, 64, (char *)g_ppk_e, 4); g_writeln("decrypted hash of first 108 bytes of this key is:"); g_hexdump(md5_final, 64); ssl_md5_info_delete(md5); g_free(md5_final); g_free(sig); return 0; } /*****************************************************************************/ static int key_test2048(void) { char *md5_final; char *sig; void *md5; md5_final = (char *)g_malloc(64, 0); sig = (char *)g_malloc(64, 0); md5 = ssl_md5_info_create(); g_writeln("original key is:"); g_hexdump((char *)g_testkey2048, 376); g_writeln("original exponent is:"); g_hexdump((char *)g_testkey2048 + 32, 4); g_writeln("original modulus is:"); g_hexdump((char *)g_testkey2048 + 36, 256); g_writeln("original signature is:"); g_hexdump((char *)g_testkey2048 + 304, 64); ssl_md5_clear(md5); ssl_md5_transform(md5, (char *)g_testkey2048, 300); g_memset(md5_final, 0xff, 64); ssl_md5_complete(md5, md5_final); g_writeln("md5 hash of first 300 bytes of this key is:"); g_hexdump(md5_final, 16); md5_final[16] = 0; md5_final[62] = 1; md5_final[63] = 0; ssl_mod_exp(sig, 64, md5_final, 64, (char *)g_ppk_n, 64, (char *)g_ppk_d, 64); g_writeln("produced signature(this should match original " "signature above) is:"); g_hexdump(sig, 64); g_memset(md5_final, 0, 64); ssl_mod_exp(md5_final, 64, (char *)g_testkey2048 + 304, 64, (char *)g_ppk_n, 64, (char *)g_ppk_e, 4); g_writeln("decrypted hash of first 108 bytes of this key is:"); g_hexdump(md5_final, 64); ssl_md5_info_delete(md5); g_free(md5_final); g_free(sig); return 0; } /*****************************************************************************/ int main(int argc, char **argv) { if (argc > 1) { if (g_strcasecmp(argv[1], "xrdp") == 0) { if (argc > 2) { if (argc > 3) { g_key_size_bits = g_atoi(argv[3]); if ((g_key_size_bits != 512) && (g_key_size_bits != 2048)) { out_params(); return 0; } } if (g_strcasecmp(argv[2], "auto") == 0) { if (g_getuid() != 0) { g_writeln("must run as root"); return 0; } return key_gen_auto(); } else { return key_gen(argv[2]); } } else { return key_gen(0); } } else if (g_strcasecmp(argv[1], "test") == 0) { g_writeln("%s", ""); g_writeln("testing 512 bit key"); key_test512(); g_writeln("%s", ""); g_writeln("testing 2048 bit key"); key_test2048(); return 0; } } out_params(); return 0; }